You are here

details.pcss.css in Drupal 10

Collapsible details.

See also

collapse.js

File

core/themes/claro/css/components/details.pcss.css
View source
  1. /**
  2. * @file
  3. * Collapsible details.
  4. *
  5. * @see collapse.js
  6. */
  7. /**
  8. * Available modifiers are:
  9. * - .claro-details--accordion
  10. * - .claro-details--accordion-item
  11. *
  12. * Despite the fact that 'accordion' isn't used anywhere right now, we
  13. * implemented it (since the design defines that).
  14. * This variant can be used by setting the '#accordion' to TRUE for a
  15. * Details render element:
  16. * @code
  17. * $build['detail_accordion'] = [
  18. * '#type' => 'details',
  19. * '#accordion' => TRUE,
  20. * ];
  21. *
  22. * 'Accordion item' is used for the details of the node edit sidebar. For
  23. * creating accordion item list from a set of details, set the surrounding
  24. * Container render element's '#accordion' key to TRUE.
  25. *
  26. * 'Vertical tabs item' is used for the children of the VerticalTabs render
  27. * element.
  28. */
  29. :root {
  30. --size-summary-border-radius: calc(var(--details-border-size-radius) - var(--details-border-size));
  31. --summary-accordion-padding-vertical: calc(var(--space-l) + ((var(--space-m) - var(--space-l)) / 2));
  32. --summary-accordion-line-height: var(--space-l);
  33. }
  34. .claro-details {
  35. display: block;
  36. margin-top: var(--space-m);
  37. margin-bottom: var(--space-m);
  38. color: var(--color-text);
  39. border: var(--details-border-size) solid var(--details-border-color);
  40. border-radius: var(--details-border-size-radius);
  41. background-color: var(--color-white);
  42. box-shadow: var(--details-box-shadow);
  43. /*
  44. * The following width and min-width values ensure that the
    element
  45. * does not shift widths when opening, in the event that a parent table
  46. * element constrains the width. This can happen when toggling the
  47. * "lazy-load" option within an image field.
  48. */
  49. @nest td & {
  50. width: min-content;
  51. min-width: 100%;
  52. }
  53. }
  54. .claro-details--accordion-item,
  55. .claro-details--vertical-tabs-item {
  56. margin-top: 0;
  57. margin-bottom: 0;
  58. border-radius: 0;
  59. box-shadow: none;
  60. }
  61. .claro-details--accordion-item:first-of-type {
  62. border-top-left-radius: var(--details-border-size-radius);
  63. border-top-right-radius: var(--details-border-size-radius);
  64. }
  65. .claro-details--accordion-item:last-of-type {
  66. border-bottom-right-radius: var(--details-border-size-radius);
  67. border-bottom-left-radius: var(--details-border-size-radius);
  68. }
  69. /**
  70. * Details summary styles.
  71. */
  72. .claro-details__summary {
  73. position: relative;
  74. box-sizing: border-box;
  75. padding: var(--space-m) var(--space-m) var(--space-m) var(--details-desktop-wrapper-padding-start); /* LTR */
  76. list-style: none;
  77. cursor: pointer;
  78. transition: background-color var(--details-bg-color-transition-duration) ease-in-out;
  79. word-wrap: break-word;
  80. hyphens: auto;
  81. color: var(--color-gray-800);
  82. border-radius: var(--size-summary-border-radius);
  83. background-color: transparent;
  84. line-height: var(--space-m);
  85. }
  86. [dir="rtl"] .claro-details__summary {
  87. padding-right: var(--details-desktop-wrapper-padding-start);
  88. padding-left: var(--space-m);
  89. }
  90. /* Modifiers */
  91. .claro-details__summary--accordion,
  92. .claro-details__summary--accordion-item,
  93. .claro-details__summary--vertical-tabs-item {
  94. padding: var(--summary-accordion-padding-vertical) var(--space-l) var(--summary-accordion-padding-vertical) var(--details-desktop-wrapper-padding-start); /* LTR */
  95. background: var(--color-white);
  96. line-height: var(--summary-accordion-line-height);
  97. }
  98. [dir="rtl"] .claro-details__summary--accordion,
  99. [dir="rtl"] .claro-details__summary--accordion-item,
  100. [dir="rtl"] .claro-details__summary--vertical-tabs-item {
  101. padding-right: var(--details-desktop-wrapper-padding-start);
  102. padding-left: var(--space-l);
  103. }
  104. /**
  105. * Accordion list items must not have border radius except they are the first
  106. * or the last ones.
  107. */
  108. .claro-details__summary--accordion-item {
  109. border-radius: 0;
  110. }
  111. .claro-details--accordion-item:first-child .claro-details__summary--accordion-item {
  112. border-top-left-radius: var(--details-border-size-radius);
  113. border-top-right-radius: var(--details-border-size-radius);
  114. }
  115. .claro-details--accordion-item:last-child .claro-details__summary--accordion-item {
  116. border-bottom-right-radius: var(--details-border-size-radius);
  117. border-bottom-left-radius: var(--details-border-size-radius);
  118. }
  119. /**
  120. * Details marker styles.
  121. */
  122. /* Remove the marker on Chrome */
  123. .claro-details__summary::-webkit-details-marker {
  124. display: none;
  125. }
  126. .claro-details__summary::before {
  127. position: absolute;
  128. top: 50%;
  129. left: var(--space-s); /* LTR */
  130. display: inline-block;
  131. width: var(--space-m);
  132. height: var(--space-m);
  133. margin-top: calc(var(--space-m) / -2);
  134. content: "";
  135. transition: transform var(--details-transform-transition-duration) ease-in 0s;
  136. transform: rotate(90deg); /* LTR */
  137. text-align: center;
  138. background-image: url(../../images/icons/545560/chevron-right.svg);
  139. background-size: contain;
  140. }
  141. [dir="rtl"] .claro-details__summary::before {
  142. right: var(--space-s);
  143. left: auto;
  144. transform: rotate(-270deg);
  145. }
  146. @media (prefers-reduced-motion: reduce) {
  147. .claro-details__summary::before {
  148. transition: none;
  149. }
  150. }
  151. @media (forced-colors: active) {
  152. .claro-details__summary::before {
  153. width: 0.5625rem;
  154. height: 0.5625rem;
  155. transition: transform var(--details-transform-transition-duration) ease-in 0s, margin var(--details-transform-transition-duration) ease-in 0s;
  156. transform: rotate(135deg); /* LTR */
  157. border-top: 0.125rem solid;
  158. border-right: 0.125rem solid;
  159. background: none;
  160. }
  161. [dir="rtl"] .claro-details__summary::before {
  162. transform: rotate(-225deg);
  163. }
  164. }
  165. /**
  166. * Safari (at least version 12.1) cannot handle our details marker
  167. * transition properly.
  168. *
  169. * Every additional pointer triggered toggle event freezes the transition,
  170. * and the transition is continued and finished after the pointer leaves
  171. * the Detail elements' summary.
  172. *
  173. * Even that it is possible to provide a JavaScript workaround for it (by
  174. * adding/removing a helper class with JavaScript if the Details is
  175. * toggled), that hack will make RTL details worse than without the hack.
  176. *
  177. * This weird query was found in
  178. * https://stackoverflow.com/questions/16348489#25975282 (based on the
  179. * answer it works for Safari 10.1+)
  180. */
  181. /* stylelint-disable-next-line unit-allowed-list */
  182. @media not all and (min-resolution: 0.001dpcm) {
  183. @supports (-webkit-appearance: none) {
  184. .claro-details__summary::before {
  185. transition: none;
  186. }
  187. }
  188. }
  189. /**
  190. * Details summary focus.
  191. */
  192. .claro-details__summary::after {
  193. position: absolute;
  194. top: -1px;
  195. right: -1px;
  196. bottom: -1px;
  197. left: -1px;
  198. content: "";
  199. transition: opacity var(--details-box-shadow-transition-duration) ease-in-out;
  200. pointer-events: none;
  201. opacity: 0;
  202. border-radius: var(--details-border-size-radius);
  203. box-shadow: inset 0 0 0 var(--details-summary-focus-border-size) var(--details-summary-shadow-color);
  204. }
  205. .claro-details > .claro-details__summary--accordion-item::after,
  206. .vertical-tabs__item > .claro-details__summary--vertical-tabs-item::after {
  207. border-radius: 0;
  208. }
  209. .claro-details:first-child > .claro-details__summary--accordion-item::after,
  210. .vertical-tabs__item--first > .claro-details__summary--vertical-tabs-item::after {
  211. border-top-left-radius: var(--details-border-size-radius);
  212. border-top-right-radius: var(--details-border-size-radius);
  213. }
  214. .claro-details:last-child > .claro-details__summary--accordion-item::after,
  215. .vertical-tabs__item--last > .claro-details__summary--vertical-tabs-item::after {
  216. border-bottom-right-radius: var(--details-border-size-radius);
  217. border-bottom-left-radius: var(--details-border-size-radius);
  218. }
  219. /**
  220. * Focus box of accordions and accordion items must not have bottom border
  221. * radius if their accordion is expanded.
  222. */
  223. .claro-details[open] > .claro-details__summary--accordion::after,
  224. .claro-details[open] > .claro-details__summary--accordion-item::after,
  225. .vertical-tabs__item--last[open] > .claro-details__summary--vertical-tabs-item::after {
  226. border-bottom-right-radius: 0;
  227. border-bottom-left-radius: 0;
  228. }
  229. /**
  230. * Details summary states.
  231. */
  232. .claro-details__summary:focus {
  233. box-shadow: none;
  234. }
  235. [open] .claro-details__summary--accordion,
  236. [open] .claro-details__summary--accordion-item,
  237. [open] .claro-details__summary--vertical-tabs-item {
  238. color: var(--color-absolutezero);
  239. }
  240. .claro-details__summary:hover::before,
  241. .claro-details__summary:hover:focus::before,
  242. .claro-details[open] > .claro-details__summary:focus::before,
  243. .claro-details[open] > .claro-details__summary--accordion::before,
  244. .claro-details[open] > .claro-details__summary--accordion-item::before,
  245. .claro-details[open] > .claro-details__summary--vertical-tabs-item::before {
  246. background-image: url(../../images/icons/0036b1/chevron-right.svg);
  247. }
  248. .claro-details[open] > .claro-details__summary {
  249. border-radius: var(--size-summary-border-radius) var(--size-summary-border-radius) 0 0;
  250. }
  251. .claro-details[open] > .claro-details__summary::before {
  252. transform: rotate(-90deg); /* for LTR and RTL */
  253. }
  254. @media (forced-colors: active) {
  255. .claro-details__summary:hover::before,
  256. .claro-details__summary:hover:focus::before {
  257. background: none;
  258. }
  259. .claro-details[open] > .claro-details__summary::before,
  260. [dir="rtl"] .claro-details[open] > .claro-details__summary::before {
  261. margin-top: calc(0.125rem / -2);
  262. margin-right: 0.125rem;
  263. transform: rotate(-45deg); /* for LTR and RTL */
  264. background: none;
  265. }
  266. }
  267. .claro-details[open] > .claro-details__summary--accordion,
  268. .claro-details[open] > .claro-details__summary--accordion-item,
  269. .claro-details[open] > .claro-details__summary--vertical-tabs-item {
  270. box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
  271. }
  272. .claro-details__summary:hover {
  273. color: var(--color-absolutezero);
  274. background-color: var(--color-bgblue-hover);
  275. }
  276. /**
  277. * Focus styles.
  278. */
  279. /**
  280. * Active has to be here for Firefox.
  281. * Merges standard collapse-processed selectors.
  282. */
  283. [open] > .claro-details__summary--accordion:not(:focus):not(:active)::after,
  284. [open] > .claro-details__summary--accordion-item:not(:focus):not(:active)::after,
  285. .collapse-processed[open] > .claro-details__summary--accordion .details-title:not(:focus)::after,
  286. .collapse-processed[open] > .claro-details__summary--accordion-item .details-title:not(:focus)::after,
  287. [open] > .claro-details__summary--vertical-tabs-item:not(:focus):not(:active)::after,
  288. .collapse-processed[open] > .claro-details__summary--vertical-tabs-item .details-title:not(:focus)::after {
  289. opacity: 1;
  290. border: var(--details-summary-focus-border-size) solid var(--color-absolutezero);
  291. border-width: 0 0 0 var(--details-summary-focus-border-size); /* LTR */
  292. box-shadow: none;
  293. }
  294. [dir="rtl"] [open] > .claro-details__summary--accordion:not(:focus)::after,
  295. [dir="rtl"] [open] > .claro-details__summary--accordion-item:not(:focus)::after,
  296. [dir="rtl"] .collapse-processed[open] > .claro-details__summary--accordion .details-title:not(:focus)::after,
  297. [dir="rtl"] .collapse-processed[open] > .claro-details__summary--accordion-item .details-title:not(:focus)::after,
  298. [dir="rtl"] [open] > .claro-details__summary--vertical-tabs-item:not(:focus)::after,
  299. [dir="rtl"] .collapse-processed[open] > .claro-details__summary--vertical-tabs-item .details-title:not(:focus)::after {
  300. border-width: 0 var(--details-summary-focus-border-size) 0 0;
  301. }
  302. .claro-details__summary:focus::after,
  303. .claro-details__summary:active::after,
  304. .collapse-processed > .claro-details__summary .details-title:focus::after {
  305. opacity: 1;
  306. }
  307. /**
  308. * Safari workaround.
  309. */
  310. /* stylelint-disable-next-line unit-allowed-list */
  311. @media not all and (min-resolution: 0.001dpcm) {
  312. @supports (-webkit-appearance: none) {
  313. .claro-details__summary::after {
  314. transition: none;
  315. }
  316. }
  317. }
  318. .claro-details[open] > .claro-details__summary:focus {
  319. color: var(--color-absolutezero);
  320. }
  321. /**
  322. * Details wrapper and content.
  323. *
  324. * Accordion and accordion-item variants should have an extra background.
  325. * In that case, we render an additional wrapper 'claro-details__content' that
  326. * creates the visual margins around the content, and use the original
  327. * wrapper for setting the background color.
  328. *
  329. * If there is no border or padding defined, margins of parent-child elements
  330. * collapse to the highest value. We want to take benefit of this behavior,
  331. * because the elements inside the details content won't cause too big
  332. * vertical spacing.
  333. */
  334. .claro-details__wrapper,
  335. .claro-details__content {
  336. margin: var(--space-m);
  337. }
  338. .claro-details__wrapper--accordion,
  339. .claro-details__wrapper--accordion-item,
  340. .claro-details__wrapper--vertical-tabs-item {
  341. margin: 0;
  342. }
  343. .claro-details__wrapper--accordion::before,
  344. .claro-details__wrapper--accordion::after,
  345. .claro-details__wrapper--accordion-item::before,
  346. .claro-details__wrapper--accordion-item::after,
  347. .claro-details__wrapper--vertical-tabs-item::before,
  348. .claro-details__wrapper--vertical-tabs-item::after {
  349. display: table;
  350. clear: both;
  351. content: "";
  352. }
  353. .claro-details__wrapper--accordion,
  354. .claro-details__wrapper--accordion-item,
  355. .claro-details__wrapper--vertical-tabs-item {
  356. border-top: var(--details-border-size) solid var(--details-border-color);
  357. background-color: var(--color-gray-050-o-40);
  358. }
  359. @media screen and (min-width: 48em) {
  360. .claro-details__wrapper {
  361. margin: var(--space-l) var(--details-desktop-wrapper-padding-start);
  362. }
  363. .claro-details__wrapper--accordion,
  364. .claro-details__wrapper--accordion-item,
  365. .claro-details__wrapper--vertical-tabs-item {
  366. margin: 0;
  367. }
  368. }
  369. @media screen and (min-width: 85em) {
  370. .js .claro-details__wrapper--vertical-tabs-item {
  371. margin: 0;
  372. border-top: 0;
  373. background-color: transparent;
  374. }
  375. }
  376. .claro-details__content--accordion,
  377. .claro-details__content--accordion-item,
  378. .claro-details__content--vertical-tabs-item {
  379. margin: var(--space-m) var(--space-m) var(--space-l);
  380. }
  381. @media screen and (min-width: 85em) {
  382. .vertical-tabs .claro-details__content--vertical-tabs-item {
  383. margin: var(--space-l);
  384. }
  385. }
  386. /* Description. */
  387. .claro-details__description {
  388. margin-bottom: var(--space-m);
  389. color: var(--input-fg-color--description);
  390. font-size: var(--font-size-xs); /* ~13px */
  391. line-height: calc(17rem / 16); /* 17px */
  392. }
  393. .claro-details__description.is-disabled {
  394. color: var(--input--disabled-fg-color);
  395. }
  396. /**
  397. * Collapse processed for non-supporting browsers like IE or Edge.
  398. */
  399. .collapse-processed > .claro-details__summary {
  400. padding: 0;
  401. }
  402. .collapse-processed > .claro-details__summary::after {
  403. content: none;
  404. }
  405. .collapse-processed > .claro-details__summary .details-title {
  406. position: relative;
  407. display: block;
  408. padding: var(--space-m) var(--space-m) var(--space-m) var(--details-desktop-wrapper-padding-start); /* LTR */
  409. text-decoration: none;
  410. color: inherit;
  411. border-radius: var(--size-summary-border-radius);
  412. }
  413. [dir="rtl"] .collapse-processed > .claro-details__summary .details-title {
  414. padding-right: var(--details-desktop-wrapper-padding-start);
  415. padding-left: var(--space-m);
  416. }
  417. .collapse-processed > .claro-details__summary--accordion .details-title,
  418. .collapse-processed > .claro-details__summary--accordion-item .details-title,
  419. .collapse-processed > .claro-details__summary--vertical-tabs-item .details-title {
  420. padding: var(--summary-accordion-padding-vertical) var(--space-l) var(--summary-accordion-padding-vertical) var(--details-desktop-wrapper-padding-start); /* LTR */
  421. }
  422. [dir="rtl"] .collapse-processed > .claro-details__summary--accordion .details-title,
  423. [dir="rtl"] .collapse-processed > .claro-details__summary--accordion-item .details-title,
  424. [dir="rtl"] .collapse-processed > .claro-details__summary--vertical-tabs-item .details-title {
  425. padding-right: var(--details-desktop-wrapper-padding-start);
  426. padding-left: var(--space-l);
  427. }
  428. /* Focus and hover states. */
  429. .collapse-processed > .claro-details__summary .details-title:focus,
  430. .collapse-processed > .claro-details__summary .details-title:hover {
  431. z-index: 1;
  432. text-decoration: none;
  433. outline: none;
  434. box-shadow: none;
  435. }
  436. .collapse-processed > .claro-details__summary .details-title::after {
  437. position: absolute;
  438. top: -1px;
  439. right: -1px;
  440. bottom: -1px;
  441. left: -1px;
  442. content: "";
  443. transition: opacity var(--details-box-shadow-transition-duration) ease-in-out;
  444. pointer-events: none;
  445. opacity: 0;
  446. border: var(--details-summary-focus-border-size) solid var(--color-focus);
  447. border-radius: var(--details-border-size-radius);
  448. }
  449. .collapse-processed > .claro-details__summary .details-title:focus::after {
  450. opacity: 1;
  451. }
  452. /* Accordion item modifiers for the focus box. */
  453. .collapse-processed > .claro-details__summary--accordion-item .details-title::after,
  454. .vertical-tabs__item > .claro-details__summary--vertical-tabs-item .details-title::after {
  455. border-radius: 0;
  456. }
  457. .collapse-processed:first-child > .claro-details__summary--accordion-item .details-title::after,
  458. .vertical-tabs__item--first > .claro-details__summary--vertical-tabs-item .details-title::after {
  459. border-top-left-radius: var(--details-border-size-radius);
  460. border-top-right-radius: var(--details-border-size-radius);
  461. }
  462. .collapse-processed:last-child > .claro-details__summary--accordion-item .details-title::after,
  463. .vertical-tabs__item--last > .claro-details__summary--vertical-tabs-item .details-title::after {
  464. border-bottom-right-radius: var(--details-border-size-radius);
  465. border-bottom-left-radius: var(--details-border-size-radius);
  466. }
  467. .collapse-processed[open] > .claro-details__summary--accordion .details-title::after,
  468. .collapse-processed[open] > .claro-details__summary--accordion-item .details-title::after,
  469. .vertical-tabs__item[open] > .claro-details__summary--vertical-tabs-item .details-title::after {
  470. border-bottom-right-radius: 0;
  471. border-bottom-left-radius: 0;
  472. }
  473. .claro-details__summary-summary {
  474. display: block;
  475. color: var(--color-gray-800);
  476. font-size: var(--font-size-s);
  477. font-weight: normal;
  478. }
  479. @media (forced-colors: active) {
  480. .collapse-processed[open] > .claro-details__summary--accordion .details-title:not(:focus)::after,
  481. .collapse-processed[open] > .claro-details__summary--accordion-item .details-title:not(:focus)::after,
  482. .collapse-processed[open] > .claro-details__summary--vertical-tabs-item .details-title:not(:focus)::after {
  483. top: -1px;
  484. right: -1px;
  485. bottom: -1px;
  486. left: -1px;
  487. }
  488. .collapse-processed > .claro-details__summary .details-title::after {
  489. top: -5px;
  490. right: -5px;
  491. bottom: -5px;
  492. left: -5px;
  493. border: 2px dotted;
  494. }
  495. }
  496. .required-mark::after {
  497. display: inline-block;
  498. width: 0.4375rem;
  499. height: 0.4375rem;
  500. margin-right: 0.3em;
  501. margin-left: 0.3em;
  502. content: "";
  503. vertical-align: super;
  504. background-image: url(../../images/core/ee0000/required.svg);
  505. background-repeat: no-repeat;
  506. background-size: 0.4375rem 0.4375rem;
  507. }