@pnx-mixtape/mxds 0.0.10 → 0.0.12

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -46,11 +46,6 @@
46
46
  .mx-accordions__toggle-all {
47
47
  margin-inline-start: auto;
48
48
  }
49
-
50
- .mx-accordion {
51
- contain: layout;
52
- }
53
-
54
49
  .mx-accordion .mx-accordion__toggle {
55
50
  cursor: pointer;
56
51
  inline-size: 100%;
@@ -59,6 +54,9 @@
59
54
  .mx-accordion:is(> h2, > h3, > h4, > h5, > h6) {
60
55
  all: unset;
61
56
  }
57
+ .mx-accordion:is([open], [data-open="true"]) > .mx-accordion__toggle .mx-icon--chevron-down {
58
+ transform: rotate(180deg);
59
+ }
62
60
 
63
61
  .mx-accordion--divided {
64
62
  border-block-end: 1px solid
@@ -74,17 +72,9 @@
74
72
  display: flex;
75
73
  justify-content: space-between;
76
74
  align-items: center;
75
+ gap: var(--spacing-xxs);
77
76
  }
78
-
79
- .mx-accordion--divided .mx-accordion__toggle .mx-button--icon-only {
80
- flex-shrink: 0;
81
- margin-inline-start: var(--spacing-xxs);
82
- }
83
- .mx-accordion--divided:is([open], [data-open="true"]) .mx-accordion__toggle .mx-button--icon-only {
84
- transform: rotate(180deg);
85
- }
86
-
87
- .mx-accordion--divided:is([open], [data-open="true"]) .mx-accordion__content {
77
+ .mx-accordion--divided:is([open], [data-open="true"]) > .mx-accordion__content {
88
78
  border-block-start: 1px solid
89
79
  var(--line-colour, var(--colour-border));
90
80
  border-block-start: var(--line-width, 1px) solid
@@ -105,4 +95,4 @@
105
95
  }
106
96
  }
107
97
 
108
- /*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFjY29yZGlvbi5jc3MiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0VBRUU7O0FBRUY7SUFFSTtNQUNFLHFCQUFxQjtJQU12Qjs7TUFKRTtRQUNFLGFBQWE7UUFDYixXQUFXO01BQ2I7O0VBSUo7SUFDRSxjQUFjO0VBQ2hCO0lBR0U7TUFDRSx3QkFBZ0I7U0FBaEIscUJBQWdCO2NBQWhCLGdCQUFnQjtNQUNoQixjQUFjO01BQ2Qsa0JBQWtCO01BQ2xCLGlGQUFtQjtNQUFuQixtQkFBbUI7TUFDbkIsZ0NBQWU7TUFBZixlQUFlO01BQ2YsVUFBZ0I7TUFBaEIsZ0JBQWdCO0lBQ2xCOztJQUVBO01BQ0UsYUFBYTtJQUNmO0FBRUo7O0FBRUE7RUFDRTtJQUNFLGtDQUFrQztJQUNsQyxhQUFhO0lBQ2IsbUJBQW1CO0lBQ25CLHFCQUFxQjtJQUNyQixtQkFBbUI7RUFDckI7O0VBRUE7SUFDRSx5QkFBeUI7RUFDM0I7O0VBRUE7SUFDRSxlQUFlO0VBVWpCOztJQVJFO01BQ0UsZUFBZTtNQUNmLGlCQUFpQjtJQUNuQjs7SUFFQTtNQUNFLFVBQVU7SUFDWjs7RUFHRjtJQUNFOzhDQUMwQztJQUQxQzs4Q0FDMEM7RUE2QjVDOztJQTNCRTtNQUNFLDBEQUEwRDtNQUMxRCxpQkFBNEM7TUFBNUMsNENBQTRDO01BQzVDLGFBQWE7TUFDYiw4QkFBOEI7TUFDOUIsbUJBQW1CO0lBTXJCOztNQUpFO1FBQ0UsY0FBYztRQUNkLHVDQUF1QztNQUN6QztRQUtFO1VBQ0UseUJBQXlCO1FBQzNCOztNQUdGO1FBQ0U7a0RBQzBDO1FBRDFDO2tEQUMwQztRQUMxQywwREFBMEQ7UUFDMUQsaUJBQTRDO1FBQTVDLDRDQUE0QztNQUM5QztBQUdOOztBQUVBOztFQUVFOztBQUVGO0lBRUk7TUFDRSx5QkFBeUI7SUFDM0I7QUFFSiIsImZpbGUiOiJhY2NvcmRpb24uY3NzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBBY2NvcmRpb25cbiAqL1xuXG5AbGF5ZXIgZGVzaWduLXN5c3RlbS5kZWZhdWx0cyB7XG4gIGRldGFpbHMge1xuICAgICYgc3VtbWFyeSB7XG4gICAgICBsaXN0LXN0eWxlLXR5cGU6IG5vbmU7XG5cbiAgICAgICY6aXMoOjotd2Via2l0LWRldGFpbHMtbWFya2VyLCA6Om1hcmtlcikge1xuICAgICAgICBkaXNwbGF5OiBub25lO1xuICAgICAgICBjb250ZW50OiBcIlwiO1xuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIDppcyhteC1hY2NvcmRpb24sIG14LWFjY29yZGlvbmRpdiwgbXgtYWNjb3JkaW9ubW9iaWxlKSB7XG4gICAgZGlzcGxheTogYmxvY2s7XG4gIH1cblxuICA6d2hlcmUoOmlzKGRpdi5teC1hY2NvcmRpb24sIG14LWFjY29yZGlvbmRpdikpIHtcbiAgICAmIC5teC1hY2NvcmRpb25fX3RvZ2dsZSB7XG4gICAgICBhcHBlYXJhbmNlOiBub25lO1xuICAgICAgY29sb3I6IGluaGVyaXQ7XG4gICAgICBmb250LXNpemU6IGluaGVyaXQ7XG4gICAgICBiYWNrZ3JvdW5kOiBpbml0aWFsO1xuICAgICAgYm9yZGVyOiBpbml0aWFsO1xuICAgICAgcGFkZGluZzogaW5pdGlhbDtcbiAgICB9XG5cbiAgICAmIC5teC1hY2NvcmRpb25fX2NvbnRlbnRbaW5lcnRdIHtcbiAgICAgIGRpc3BsYXk6IG5vbmU7XG4gICAgfVxuICB9XG59XG5cbkBsYXllciBkZXNpZ24tc3lzdGVtLmNvbXBvbmVudHMge1xuICAubXgtYWNjb3JkaW9uX190aXRsZSB7XG4gICAgbWFyZ2luLWJsb2NrLWVuZDogdmFyKC0tc3BhY2luZy1tKTtcbiAgICBkaXNwbGF5OiBmbGV4O1xuICAgIGZsZXgtZmxvdzogcm93IHdyYXA7XG4gICAgZ2FwOiB2YXIoLS1zcGFjaW5nLXMpO1xuICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIH1cblxuICAubXgtYWNjb3JkaW9uc19fdG9nZ2xlLWFsbCB7XG4gICAgbWFyZ2luLWlubGluZS1zdGFydDogYXV0bztcbiAgfVxuXG4gIC5teC1hY2NvcmRpb24ge1xuICAgIGNvbnRhaW46IGxheW91dDtcblxuICAgICYgLm14LWFjY29yZGlvbl9fdG9nZ2xlIHtcbiAgICAgIGN1cnNvcjogcG9pbnRlcjtcbiAgICAgIGlubGluZS1zaXplOiAxMDAlO1xuICAgIH1cblxuICAgICY6aXMoPiBoMiwgPiBoMywgPiBoNCwgPiBoNSwgPiBoNikge1xuICAgICAgYWxsOiB1bnNldDtcbiAgICB9XG4gIH1cblxuICAubXgtYWNjb3JkaW9uLS1kaXZpZGVkIHtcbiAgICBib3JkZXItYmxvY2stZW5kOiB2YXIoLS1saW5lLXdpZHRoLCAxcHgpIHNvbGlkXG4gICAgICB2YXIoLS1saW5lLWNvbG91ciwgdmFyKC0tY29sb3VyLWJvcmRlcikpO1xuXG4gICAgJiAubXgtYWNjb3JkaW9uX190b2dnbGUge1xuICAgICAgcGFkZGluZy1ibG9jazogdmFyKC0tdmVydGljYWwtcGFkZGluZywgdmFyKC0tc3BhY2luZy14eHMpKTtcbiAgICAgIHBhZGRpbmctaW5saW5lOiB2YXIoLS1ob3Jpem9udGFsLXBhZGRpbmcsIDApO1xuICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbiAgICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5cbiAgICAgICYgLm14LWJ1dHRvbi0taWNvbi1vbmx5IHtcbiAgICAgICAgZmxleC1zaHJpbms6IDA7XG4gICAgICAgIG1hcmdpbi1pbmxpbmUtc3RhcnQ6IHZhcigtLXNwYWNpbmcteHhzKTtcbiAgICAgIH1cbiAgICB9XG5cbiAgICAmOmlzKFtvcGVuXSwgW2RhdGEtb3Blbj1cInRydWVcIl0pIHtcbiAgICAgICYgLm14LWFjY29yZGlvbl9fdG9nZ2xlIHtcbiAgICAgICAgJiAubXgtYnV0dG9uLS1pY29uLW9ubHkge1xuICAgICAgICAgIHRyYW5zZm9ybTogcm90YXRlKDE4MGRlZyk7XG4gICAgICAgIH1cbiAgICAgIH1cblxuICAgICAgJiAubXgtYWNjb3JkaW9uX19jb250ZW50IHtcbiAgICAgICAgYm9yZGVyLWJsb2NrLXN0YXJ0OiB2YXIoLS1saW5lLXdpZHRoLCAxcHgpIHNvbGlkXG4gICAgICAgICAgdmFyKC0tbGluZS1jb2xvdXIsIHZhcigtLWNvbG91ci1ib3JkZXIpKTtcbiAgICAgICAgcGFkZGluZy1ibG9jazogdmFyKC0tdmVydGljYWwtcGFkZGluZywgdmFyKC0tc3BhY2luZy14eHMpKTtcbiAgICAgICAgcGFkZGluZy1pbmxpbmU6IHZhcigtLWhvcml6b250YWwtcGFkZGluZywgMCk7XG4gICAgICB9XG4gICAgfVxuICB9XG59XG5cbi8qKlxuICogUHJpbnQgc3R5bGVzaGVldFxuICovXG5cbkBtZWRpYSBwcmludCB7XG4gIC5teC1hY2NvcmRpb24ge1xuICAgICYgLm14LWFjY29yZGlvbl9fY29udGVudCB7XG4gICAgICBkaXNwbGF5OiBibG9jayAhaW1wb3J0YW50O1xuICAgIH1cbiAgfVxufVxuIl19 */
98
+ /*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFjY29yZGlvbi5jc3MiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0VBRUU7O0FBRUY7SUFFSTtNQUNFLHFCQUFxQjtJQU12Qjs7TUFKRTtRQUNFLGFBQWE7UUFDYixXQUFXO01BQ2I7O0VBSUo7SUFDRSxjQUFjO0VBQ2hCO0lBR0U7TUFDRSx3QkFBZ0I7U0FBaEIscUJBQWdCO2NBQWhCLGdCQUFnQjtNQUNoQixjQUFjO01BQ2Qsa0JBQWtCO01BQ2xCLGlGQUFtQjtNQUFuQixtQkFBbUI7TUFDbkIsZ0NBQWU7TUFBZixlQUFlO01BQ2YsVUFBZ0I7TUFBaEIsZ0JBQWdCO0lBQ2xCOztJQUVBO01BQ0UsYUFBYTtJQUNmO0FBRUo7O0FBRUE7RUFDRTtJQUNFLGtDQUFrQztJQUNsQyxhQUFhO0lBQ2IsbUJBQW1CO0lBQ25CLHFCQUFxQjtJQUNyQixtQkFBbUI7RUFDckI7O0VBRUE7SUFDRSx5QkFBeUI7RUFDM0I7SUFHRTtNQUNFLGVBQWU7TUFDZixpQkFBaUI7SUFDbkI7O0lBRUE7TUFDRSxVQUFVO0lBQ1o7UUFJSTtVQUNFLHlCQUF5QjtRQUMzQjs7RUFLTjtJQUNFOzhDQUMwQztJQUQxQzs4Q0FDMEM7RUFtQjVDOztJQWpCRTtNQUNFLDBEQUEwRDtNQUMxRCxpQkFBNEM7TUFBNUMsNENBQTRDO01BQzVDLGFBQWE7TUFDYiw4QkFBOEI7TUFDOUIsbUJBQW1CO01BQ25CLHVCQUF1QjtJQUN6QjtNQUdFO1FBQ0U7a0RBQzBDO1FBRDFDO2tEQUMwQztRQUMxQywwREFBMEQ7UUFDMUQsaUJBQTRDO1FBQTVDLDRDQUE0QztNQUM5QztBQUdOOztBQUVBOztFQUVFOztBQUVGO0lBRUk7TUFDRSx5QkFBeUI7SUFDM0I7QUFFSiIsImZpbGUiOiJhY2NvcmRpb24uY3NzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBBY2NvcmRpb25cbiAqL1xuXG5AbGF5ZXIgZGVzaWduLXN5c3RlbS5kZWZhdWx0cyB7XG4gIGRldGFpbHMge1xuICAgICYgc3VtbWFyeSB7XG4gICAgICBsaXN0LXN0eWxlLXR5cGU6IG5vbmU7XG5cbiAgICAgICY6aXMoOjotd2Via2l0LWRldGFpbHMtbWFya2VyLCA6Om1hcmtlcikge1xuICAgICAgICBkaXNwbGF5OiBub25lO1xuICAgICAgICBjb250ZW50OiBcIlwiO1xuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIDppcyhteC1hY2NvcmRpb24sIG14LWFjY29yZGlvbmRpdiwgbXgtYWNjb3JkaW9ubW9iaWxlKSB7XG4gICAgZGlzcGxheTogYmxvY2s7XG4gIH1cblxuICA6d2hlcmUoOmlzKGRpdi5teC1hY2NvcmRpb24sIG14LWFjY29yZGlvbmRpdikpIHtcbiAgICAmIC5teC1hY2NvcmRpb25fX3RvZ2dsZSB7XG4gICAgICBhcHBlYXJhbmNlOiBub25lO1xuICAgICAgY29sb3I6IGluaGVyaXQ7XG4gICAgICBmb250LXNpemU6IGluaGVyaXQ7XG4gICAgICBiYWNrZ3JvdW5kOiBpbml0aWFsO1xuICAgICAgYm9yZGVyOiBpbml0aWFsO1xuICAgICAgcGFkZGluZzogaW5pdGlhbDtcbiAgICB9XG5cbiAgICAmIC5teC1hY2NvcmRpb25fX2NvbnRlbnRbaW5lcnRdIHtcbiAgICAgIGRpc3BsYXk6IG5vbmU7XG4gICAgfVxuICB9XG59XG5cbkBsYXllciBkZXNpZ24tc3lzdGVtLmNvbXBvbmVudHMge1xuICAubXgtYWNjb3JkaW9uX190aXRsZSB7XG4gICAgbWFyZ2luLWJsb2NrLWVuZDogdmFyKC0tc3BhY2luZy1tKTtcbiAgICBkaXNwbGF5OiBmbGV4O1xuICAgIGZsZXgtZmxvdzogcm93IHdyYXA7XG4gICAgZ2FwOiB2YXIoLS1zcGFjaW5nLXMpO1xuICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIH1cblxuICAubXgtYWNjb3JkaW9uc19fdG9nZ2xlLWFsbCB7XG4gICAgbWFyZ2luLWlubGluZS1zdGFydDogYXV0bztcbiAgfVxuXG4gIC5teC1hY2NvcmRpb24ge1xuICAgICYgLm14LWFjY29yZGlvbl9fdG9nZ2xlIHtcbiAgICAgIGN1cnNvcjogcG9pbnRlcjtcbiAgICAgIGlubGluZS1zaXplOiAxMDAlO1xuICAgIH1cblxuICAgICY6aXMoPiBoMiwgPiBoMywgPiBoNCwgPiBoNSwgPiBoNikge1xuICAgICAgYWxsOiB1bnNldDtcbiAgICB9XG5cbiAgICAmOmlzKFtvcGVuXSwgW2RhdGEtb3Blbj1cInRydWVcIl0pIHtcbiAgICAgICYgPiAubXgtYWNjb3JkaW9uX190b2dnbGUge1xuICAgICAgICAmIC5teC1pY29uLS1jaGV2cm9uLWRvd24ge1xuICAgICAgICAgIHRyYW5zZm9ybTogcm90YXRlKDE4MGRlZyk7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICAubXgtYWNjb3JkaW9uLS1kaXZpZGVkIHtcbiAgICBib3JkZXItYmxvY2stZW5kOiB2YXIoLS1saW5lLXdpZHRoLCAxcHgpIHNvbGlkXG4gICAgICB2YXIoLS1saW5lLWNvbG91ciwgdmFyKC0tY29sb3VyLWJvcmRlcikpO1xuXG4gICAgJiAubXgtYWNjb3JkaW9uX190b2dnbGUge1xuICAgICAgcGFkZGluZy1ibG9jazogdmFyKC0tdmVydGljYWwtcGFkZGluZywgdmFyKC0tc3BhY2luZy14eHMpKTtcbiAgICAgIHBhZGRpbmctaW5saW5lOiB2YXIoLS1ob3Jpem9udGFsLXBhZGRpbmcsIDApO1xuICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbiAgICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gICAgICBnYXA6IHZhcigtLXNwYWNpbmcteHhzKTtcbiAgICB9XG5cbiAgICAmOmlzKFtvcGVuXSwgW2RhdGEtb3Blbj1cInRydWVcIl0pIHtcbiAgICAgICYgPiAubXgtYWNjb3JkaW9uX19jb250ZW50IHtcbiAgICAgICAgYm9yZGVyLWJsb2NrLXN0YXJ0OiB2YXIoLS1saW5lLXdpZHRoLCAxcHgpIHNvbGlkXG4gICAgICAgICAgdmFyKC0tbGluZS1jb2xvdXIsIHZhcigtLWNvbG91ci1ib3JkZXIpKTtcbiAgICAgICAgcGFkZGluZy1ibG9jazogdmFyKC0tdmVydGljYWwtcGFkZGluZywgdmFyKC0tc3BhY2luZy14eHMpKTtcbiAgICAgICAgcGFkZGluZy1pbmxpbmU6IHZhcigtLWhvcml6b250YWwtcGFkZGluZywgMCk7XG4gICAgICB9XG4gICAgfVxuICB9XG59XG5cbi8qKlxuICogUHJpbnQgc3R5bGVzaGVldFxuICovXG5cbkBtZWRpYSBwcmludCB7XG4gIC5teC1hY2NvcmRpb24ge1xuICAgICYgLm14LWFjY29yZGlvbl9fY29udGVudCB7XG4gICAgICBkaXNwbGF5OiBibG9jayAhaW1wb3J0YW50O1xuICAgIH1cbiAgfVxufVxuIl19 */
@@ -1,60 +1,4 @@
1
- import { m as makeAnchor } from "./chunks/utilities-B4YZb689.js";
2
- class Accordion extends HTMLElement {
3
- constructor() {
4
- super();
5
- this.handleOpen = () => {
6
- if (!this.details) return;
7
- this.details.open = true;
8
- };
9
- this.handleClose = () => {
10
- if (!this.details) return;
11
- this.details.open = false;
12
- };
13
- this.handleHash = () => {
14
- const { hash } = window.location;
15
- if (hash && hash === `#${this.details?.id}`) {
16
- this.handleOpen();
17
- }
18
- };
19
- this.generatedId = () => {
20
- const string = this.trigger?.textContent?.trim();
21
- return !string ? "" : makeAnchor(string);
22
- };
23
- this.internals_ = this.attachInternals();
24
- this.controller = new AbortController();
25
- }
26
- connectedCallback() {
27
- if (!this.details || !this.trigger) return;
28
- const { signal } = this.controller;
29
- document.addEventListener("beforeprint", this.handleOpen, {
30
- signal
31
- });
32
- document.addEventListener("afterprint", this.handleClose, {
33
- signal
34
- });
35
- this.handleHash();
36
- document.addEventListener("hashchange", this.handleHash, { signal });
37
- }
38
- disconnectedCallback() {
39
- this.controller.abort();
40
- }
41
- get details() {
42
- const details = this.querySelector("details");
43
- if (!details) {
44
- throw new Error(`${this.localName} must contain a <details> element.`);
45
- }
46
- details.id = details.id || this.generatedId();
47
- return details;
48
- }
49
- get trigger() {
50
- const trigger = this.querySelector("summary");
51
- if (!trigger) {
52
- throw new Error(`${this.localName} must contain a <summary> element.`);
53
- }
54
- return trigger;
55
- }
56
- }
57
- customElements.define("mx-accordion", Accordion);
1
+ import "./chunks/Accordion-DSze7pxN.js";
58
2
  class AccordionGroup extends HTMLElement {
59
3
  constructor() {
60
4
  super();
@@ -1 +1 @@
1
- {"version":3,"file":"accordion.entry.js","sources":["../../src/Component/Accordion/Elements/Accordion.ts","../../src/Component/Accordion/Elements/AccordionGroup.ts"],"sourcesContent":["/**\n * Accordion\n * @file Support opening on hash, adding an ID attribute and toggling on print.\n */\n\nimport { makeAnchor } from \"../../../Utility/utilities\"\n\nexport default class Accordion extends HTMLElement {\n internals_: ElementInternals\n controller: AbortController\n\n constructor() {\n super()\n this.internals_ = this.attachInternals()\n this.controller = new AbortController()\n }\n\n connectedCallback(): void {\n if (!this.details || !this.trigger) return\n\n const { signal }: AbortController = this.controller\n document.addEventListener(\"beforeprint\", this.handleOpen, {\n signal,\n })\n document.addEventListener(\"afterprint\", this.handleClose, {\n signal,\n })\n this.handleHash()\n document.addEventListener(\"hashchange\", this.handleHash, { signal })\n }\n\n disconnectedCallback(): void {\n this.controller.abort()\n }\n\n handleOpen = (): void => {\n if (!this.details) return\n this.details.open = true\n }\n\n handleClose = (): void => {\n if (!this.details) return\n this.details.open = false\n }\n\n handleHash = (): void => {\n const { hash }: Location = window.location\n if (hash && hash === `#${this.details?.id}`) {\n this.handleOpen()\n }\n }\n\n get details(): HTMLDetailsElement | null {\n const details: HTMLDetailsElement | null = this.querySelector(\"details\")\n if (!details) {\n throw new Error(`${this.localName} must contain a <details> element.`)\n }\n details.id = details.id || this.generatedId()\n return details\n }\n\n get trigger(): HTMLElement | null {\n const trigger: HTMLElement | null = this.querySelector(\"summary\")\n if (!trigger) {\n throw new Error(`${this.localName} must contain a <summary> element.`)\n }\n return trigger\n }\n\n generatedId = (): string => {\n const string: string | undefined = this.trigger?.textContent?.trim()\n return !string ? \"\" : makeAnchor(string)\n }\n}\n\ncustomElements.define(\"mx-accordion\", Accordion)\n\ndeclare global {\n interface HTMLElementTagNameMap {\n \"mx-accordion\": Accordion\n }\n}\n","/**\n * Accordion Group\n * @file Support opening and closing all.\n */\n\nexport default class AccordionGroup extends HTMLElement {\n internals_: ElementInternals\n controller: AbortController\n\n constructor() {\n super()\n this.internals_ = this.attachInternals()\n this.controller = new AbortController()\n }\n\n connectedCallback(): void {\n if (!this.accordions || !this.expandTrigger || !this.collapseTrigger) return\n this.collapseTrigger.disabled = true\n const { signal }: AbortController = this.controller\n this.addEventListener(\"click\", this.handleClick, {\n signal,\n })\n this.accordions.forEach(details =>\n details.addEventListener(\"toggle\", this.handleToggle, {\n signal,\n }),\n )\n }\n\n disconnectedCallback(): void {\n this.controller.abort()\n }\n\n handleClick = ({ target }) => {\n if (target === this.expandTrigger) {\n this.handleExpand()\n }\n if (target === this.collapseTrigger) {\n this.handleCollapse()\n }\n }\n\n handleExpand = () => {\n this.accordions.forEach(detail => (detail.open = true))\n this.expandTrigger.disabled = true\n this.collapseTrigger.disabled = false\n }\n\n handleCollapse = () => {\n this.accordions.forEach(detail => (detail.open = false))\n this.expandTrigger.disabled = false\n this.collapseTrigger.disabled = true\n }\n\n handleToggle = () => {\n this.expandTrigger.disabled = [...this.accordions].every(\n details => details.open === true,\n )\n this.collapseTrigger.disabled = [...this.accordions].every(\n details => details.open !== true,\n )\n }\n\n get accordions(): NodeListOf<HTMLDetailsElement> | null {\n const accordions: NodeListOf<HTMLDetailsElement> | null =\n this.querySelectorAll(\"details\")\n if (!accordions.length) {\n throw new Error(\n `${this.localName} must contain at least one <details> element.`,\n )\n }\n return accordions\n }\n\n get expandTrigger(): HTMLButtonElement | null {\n const trigger: HTMLButtonElement | null = this.querySelector(\n \"button[data-expand]\",\n )\n if (!trigger) {\n throw new Error(\n `${this.localName} must contain a <button data-expand> element.`,\n )\n }\n return trigger\n }\n\n get collapseTrigger(): HTMLButtonElement | null {\n const trigger: HTMLButtonElement | null = this.querySelector(\n \"button[data-collapse]\",\n )\n if (!trigger) {\n throw new Error(\n `${this.localName} must contain a <button data-collapse> element.`,\n )\n }\n return trigger\n }\n}\n\ncustomElements.define(\"mx-accordion-group\", AccordionGroup)\n\ndeclare global {\n interface HTMLElementTagNameMap {\n \"mx-accordion-group\": AccordionGroup\n }\n}\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"accordion.entry.js","sources":["../../src/Component/Accordion/Elements/AccordionGroup.ts"],"sourcesContent":["/**\n * Accordion Group\n * @file Support opening and closing all.\n */\n\nexport default class AccordionGroup extends HTMLElement {\n internals_: ElementInternals\n controller: AbortController\n\n constructor() {\n super()\n this.internals_ = this.attachInternals()\n this.controller = new AbortController()\n }\n\n connectedCallback(): void {\n if (!this.accordions || !this.expandTrigger || !this.collapseTrigger) return\n this.collapseTrigger.disabled = true\n const { signal }: AbortController = this.controller\n this.addEventListener(\"click\", this.handleClick, {\n signal,\n })\n this.accordions.forEach(details =>\n details.addEventListener(\"toggle\", this.handleToggle, {\n signal,\n }),\n )\n }\n\n disconnectedCallback(): void {\n this.controller.abort()\n }\n\n handleClick = ({ target }) => {\n if (target === this.expandTrigger) {\n this.handleExpand()\n }\n if (target === this.collapseTrigger) {\n this.handleCollapse()\n }\n }\n\n handleExpand = () => {\n this.accordions.forEach(detail => (detail.open = true))\n this.expandTrigger.disabled = true\n this.collapseTrigger.disabled = false\n }\n\n handleCollapse = () => {\n this.accordions.forEach(detail => (detail.open = false))\n this.expandTrigger.disabled = false\n this.collapseTrigger.disabled = true\n }\n\n handleToggle = () => {\n this.expandTrigger.disabled = [...this.accordions].every(\n details => details.open === true,\n )\n this.collapseTrigger.disabled = [...this.accordions].every(\n details => details.open !== true,\n )\n }\n\n get accordions(): NodeListOf<HTMLDetailsElement> | null {\n const accordions: NodeListOf<HTMLDetailsElement> | null =\n this.querySelectorAll(\"details\")\n if (!accordions.length) {\n throw new Error(\n `${this.localName} must contain at least one <details> element.`,\n )\n }\n return accordions\n }\n\n get expandTrigger(): HTMLButtonElement | null {\n const trigger: HTMLButtonElement | null = this.querySelector(\n \"button[data-expand]\",\n )\n if (!trigger) {\n throw new Error(\n `${this.localName} must contain a <button data-expand> element.`,\n )\n }\n return trigger\n }\n\n get collapseTrigger(): HTMLButtonElement | null {\n const trigger: HTMLButtonElement | null = this.querySelector(\n \"button[data-collapse]\",\n )\n if (!trigger) {\n throw new Error(\n `${this.localName} must contain a <button data-collapse> element.`,\n )\n }\n return trigger\n }\n}\n\ncustomElements.define(\"mx-accordion-group\", AccordionGroup)\n\ndeclare global {\n interface HTMLElementTagNameMap {\n \"mx-accordion-group\": AccordionGroup\n }\n}\n"],"names":[],"mappings":";AAKA,MAAqB,uBAAuB,YAAY;AAAA,EAItD,cAAc;AACN;AAuBM,SAAA,cAAA,CAAC,EAAE,aAAa;AACxB,UAAA,WAAW,KAAK,eAAe;AACjC,aAAK,aAAa;AAAA,MACpB;AACI,UAAA,WAAW,KAAK,iBAAiB;AACnC,aAAK,eAAe;AAAA,MACtB;AAAA,IAAA;AAGF,SAAA,eAAe,MAAM;AACnB,WAAK,WAAW,QAAQ,CAAW,WAAA,OAAO,OAAO,IAAK;AACtD,WAAK,cAAc,WAAW;AAC9B,WAAK,gBAAgB,WAAW;AAAA,IAAA;AAGlC,SAAA,iBAAiB,MAAM;AACrB,WAAK,WAAW,QAAQ,CAAW,WAAA,OAAO,OAAO,KAAM;AACvD,WAAK,cAAc,WAAW;AAC9B,WAAK,gBAAgB,WAAW;AAAA,IAAA;AAGlC,SAAA,eAAe,MAAM;AACnB,WAAK,cAAc,WAAW,CAAC,GAAG,KAAK,UAAU,EAAE;AAAA,QACjD,CAAA,YAAW,QAAQ,SAAS;AAAA,MAAA;AAE9B,WAAK,gBAAgB,WAAW,CAAC,GAAG,KAAK,UAAU,EAAE;AAAA,QACnD,CAAA,YAAW,QAAQ,SAAS;AAAA,MAAA;AAAA,IAC9B;AAjDK,SAAA,aAAa,KAAK;AAClB,SAAA,aAAa,IAAI;EACxB;AAAA,EAEA,oBAA0B;AACpB,QAAA,CAAC,KAAK,cAAc,CAAC,KAAK,iBAAiB,CAAC,KAAK,gBAAiB;AACtE,SAAK,gBAAgB,WAAW;AAC1B,UAAA,EAAE,OAAO,IAAqB,KAAK;AACpC,SAAA,iBAAiB,SAAS,KAAK,aAAa;AAAA,MAC/C;AAAA,IAAA,CACD;AACD,SAAK,WAAW;AAAA,MAAQ,CACtB,YAAA,QAAQ,iBAAiB,UAAU,KAAK,cAAc;AAAA,QACpD;AAAA,MAAA,CACD;AAAA,IAAA;AAAA,EAEL;AAAA,EAEA,uBAA6B;AAC3B,SAAK,WAAW;EAClB;AAAA,EAgCA,IAAI,aAAoD;AAChD,UAAA,aACJ,KAAK,iBAAiB,SAAS;AAC7B,QAAA,CAAC,WAAW,QAAQ;AACtB,YAAM,IAAI;AAAA,QACR,GAAG,KAAK,SAAS;AAAA,MAAA;AAAA,IAErB;AACO,WAAA;AAAA,EACT;AAAA,EAEA,IAAI,gBAA0C;AAC5C,UAAM,UAAoC,KAAK;AAAA,MAC7C;AAAA,IAAA;AAEF,QAAI,CAAC,SAAS;AACZ,YAAM,IAAI;AAAA,QACR,GAAG,KAAK,SAAS;AAAA,MAAA;AAAA,IAErB;AACO,WAAA;AAAA,EACT;AAAA,EAEA,IAAI,kBAA4C;AAC9C,UAAM,UAAoC,KAAK;AAAA,MAC7C;AAAA,IAAA;AAEF,QAAI,CAAC,SAAS;AACZ,YAAM,IAAI;AAAA,QACR,GAAG,KAAK,SAAS;AAAA,MAAA;AAAA,IAErB;AACO,WAAA;AAAA,EACT;AACF;AAEA,eAAe,OAAO,sBAAsB,cAAc;"}
@@ -5,7 +5,7 @@
5
5
  @layer design-system.atoms {
6
6
  .mx-button {
7
7
  --outline-offset: 0.0625rem;
8
- --outline-width: 0.25rem;
8
+ --outline-width: 0.125rem;
9
9
 
10
10
  display: inline-flex;
11
11
  inline-size: -moz-fit-content;
@@ -129,4 +129,4 @@
129
129
  }
130
130
  }
131
131
 
132
- /*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIl9idXR0b25zLmNzcyIsIl9idXR0b25zLXN0eWxlcy5jc3MiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0VBRUU7O0FBRUY7RUFDRTtJQUNFLDJCQUFxQjtJQUNyQix3QkFBb0I7O0lBRXBCLG9CQUFvQjtJQUNwQiw2QkFBd0I7SUFBeEIsd0JBQXdCO0lBQ3hCLHdDQUF3QztJQUN4QyxvREFBb0Q7SUFDcEQsb0NBQW9DO0lBQ3BDLCtCQUErQjtJQUMvQixrQ0FBa0M7SUFDbEM7cURBQ2lEO0lBRGpEO3FEQUNpRDtJQUNqRCxvREFBb0Q7SUFDcEQsMERBQTBEO0lBQzFELDJEQUEyRDtJQUMzRCw2REFBNkQ7SUFDN0Qsa0RBQWtEO0lBQ2xELDBCQUEwQjtJQUMxQjs7O3VCQUdtQjtFQVdyQjs7SUFURTtNQUNFLGVBQWU7TUFDZiwwQkFBMEI7SUFDNUI7O0lBRUE7TUFDRSxtQkFBbUI7TUFDbkIsWUFBWTtJQUNkOztFQUdGO0lBQ0UsaUJBQWlCO0lBQ2pCLHVCQUF1QjtFQUN6Qjs7RUFFQTtJQUNFLG9DQUFvQztJQUNwQyxzQ0FBc0M7RUFDeEM7O0VBRUE7SUFDRSxzQ0FBc0M7SUFDdEMsdUNBQXVDO0lBQ3ZDLHNDQUFzQztFQUN4Qzs7RUFFQTtJQUNFLDhCQUE4QjtJQUM5Qiw2QkFBNkI7SUFDN0IsVUFBVTtJQUNWLHlDQUF5QztJQUN6QyxnQkFBZ0I7SUFDaEIsZUFBZTtFQVdqQjs7SUFURTtNQUNFLGlCQUFpQjtNQUNqQixnQkFBZ0I7TUFDaEIsbUNBQTJCO2NBQTNCLDJCQUEyQjtJQUM3Qjs7SUFFQTtNQUNFLHFCQUFxQjtNQUFyQix1QkFBcUI7TUFBckIscUJBQXFCO0lBQ3ZCO0FBRUo7O0FDMUVBOztFQUVFOztBQUVGO0VBQ0U7SUFDRSwyQ0FBMkM7SUFDM0MsbUNBQW1DO0lBQ25DLDhDQUE4QztFQU1oRDs7SUFKRTtNQUNFLHlCQUF5QjtNQUN6QixtQ0FBbUM7SUFDckM7O0VBR0Y7SUFDRSxtQkFBbUI7SUFDbkIsZ0RBQWdEO0lBQ2hELCtCQUErQjtFQUtqQzs7SUFIRTtNQUNFLCtCQUErQjtJQUNqQzs7RUFHRjtJQUNFLG9EQUFvRDtJQUNwRCw0Q0FBNEM7SUFDNUMsOENBQThDO0VBTWhEOztJQUpFO01BQ0UseUJBQXlCO01BQ3pCLDRDQUE0QztJQUM5Qzs7RUFHRjtJQUNFLHNEQUFzRDtJQUN0RCw4Q0FBOEM7SUFDOUMsc0NBQXNDO0VBTXhDOztJQUpFO01BQ0UseUJBQXlCO01BQ3pCLDhDQUE4QztJQUNoRDtBQUVKIiwiZmlsZSI6ImJ1dHRvbi5jc3MiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEJ1dHRvbnNcbiAqL1xuXG5AbGF5ZXIgZGVzaWduLXN5c3RlbS5hdG9tcyB7XG4gIC5teC1idXR0b24ge1xuICAgIC0tb3V0bGluZS1vZmZzZXQ6IDFweDtcbiAgICAtLW91dGxpbmUtd2lkdGg6IDRweDtcblxuICAgIGRpc3BsYXk6IGlubGluZS1mbGV4O1xuICAgIGlubGluZS1zaXplOiBmaXQtY29udGVudDtcbiAgICBnYXA6IHZhcigtLWJ1dHRvbi1nYXAsIHZhcigtLXNwYWNpbmctcykpO1xuICAgIGZvbnQtc2l6ZTogdmFyKC0tYnV0dG9uLWZvbnQtc2l6ZSwgdmFyKC0tZm9udC1zaXplKSk7XG4gICAgZm9udC13ZWlnaHQ6IHZhcigtLWZvbnQtd2VpZ2h0LWJvbGQpO1xuICAgIGZvbnQtZmFtaWx5OiB2YXIoLS1mb250LWZhbWlseSk7XG4gICAgbGluZS1oZWlnaHQ6IHZhcigtLWxpbmUtaGVpZ2h0LXVpKTtcbiAgICBib3JkZXI6IHZhcigtLWxpbmUtd2lkdGgsIDJweCkgc29saWRcbiAgICAgIHZhcigtLWJ1dHRvbi1saW5lLWNvbG91ciwgdmFyKC0tY29sb3VyLWJvcmRlcikpO1xuICAgIGJvcmRlci1yYWRpdXM6IHZhcigtLXJhZGl1cywgdmFyKC0tYm9yZGVyLXJhZGl1cy1sKSk7XG4gICAgcGFkZGluZy1ibG9jazogdmFyKC0tdmVydGljYWwtcGFkZGluZywgdmFyKC0tc3BhY2luZy14eHMpKTtcbiAgICBwYWRkaW5nLWlubGluZTogdmFyKC0taG9yaXpvbnRhbC1wYWRkaW5nLCB2YXIoLS1zcGFjaW5nLW0pKTtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiB2YXIoLS1iYWNrZ3JvdW5kLCB2YXIoLS1jb2xvdXItYmFja2dyb3VuZCkpO1xuICAgIGNvbG9yOiB2YXIoLS1mb3JlZ3JvdW5kLCB2YXIoLS1jb2xvdXItZm9yZWdyb3VuZCkpO1xuICAgIHRleHQtZGVjb3JhdGlvbi1saW5lOiBub25lO1xuICAgIHRyYW5zaXRpb246XG4gICAgICAwLjJzIGNvbG9yLFxuICAgICAgMC4ycyBiYWNrZ3JvdW5kLWNvbG9yLFxuICAgICAgMC4ycyBib3JkZXItY29sb3I7XG5cbiAgICAmOmhvdmVyIHtcbiAgICAgIGN1cnNvcjogcG9pbnRlcjtcbiAgICAgIHRleHQtZGVjb3JhdGlvbi1saW5lOiBub25lO1xuICAgIH1cblxuICAgICY6ZGlzYWJsZWQge1xuICAgICAgY3Vyc29yOiBub3QtYWxsb3dlZDtcbiAgICAgIG9wYWNpdHk6IDAuMztcbiAgICB9XG4gIH1cblxuICAubXgtYnV0dG9uLS1mdWxsLXdpZHRoIHtcbiAgICBpbmxpbmUtc2l6ZTogMTAwJTtcbiAgICBqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjtcbiAgfVxuXG4gIC5teC1idXR0b24tLWxhcmdlIHtcbiAgICAtLXZlcnRpY2FsLXBhZGRpbmc6IHZhcigtLXNwYWNpbmctcyk7XG4gICAgLS1ob3Jpem9udGFsLXBhZGRpbmc6IHZhcigtLXNwYWNpbmctbCk7XG4gIH1cblxuICAubXgtYnV0dG9uLS1zbWFsbCB7XG4gICAgLS1idXR0b24tZm9udC1zaXplOiB2YXIoLS1mb250LXNpemUtcyk7XG4gICAgLS12ZXJ0aWNhbC1wYWRkaW5nOiB2YXIoLS1zcGFjaW5nLXh4eHMpO1xuICAgIC0taG9yaXpvbnRhbC1wYWRkaW5nOiB2YXIoLS1zcGFjaW5nLXMpO1xuICB9XG5cbiAgLm14LWJ1dHRvbi0taWNvbi1vbmx5IHtcbiAgICBpbmxpbmUtc2l6ZTogdmFyKC0tc3BhY2luZy14bCk7XG4gICAgYmxvY2stc2l6ZTogdmFyKC0tc3BhY2luZy14bCk7XG4gICAgcGFkZGluZzogMDtcbiAgICBib3JkZXItcmFkaXVzOiB2YXIoLS1ib3JkZXItcmFkaXVzLXJvdW5kKTtcbiAgICBvdmVyZmxvdzogaGlkZGVuO1xuICAgIGZsZXgtd3JhcDogd3JhcDtcblxuICAgICY6OmJlZm9yZSB7XG4gICAgICBpbmxpbmUtc2l6ZTogMTAwJTtcbiAgICAgIGJsb2NrLXNpemU6IDEwMCU7XG4gICAgICBtYXNrLXNpemU6IHZhcigtLXNwYWNpbmctcyk7XG4gICAgfVxuXG4gICAgJjpoYXMoLm14LWljb24pIHtcbiAgICAgIHBsYWNlLWNvbnRlbnQ6IGNlbnRlcjtcbiAgICB9XG4gIH1cbn1cbiIsIi8qKlxuICogQnV0dG9uc1xuICovXG5cbkBsYXllciBkZXNpZ24tc3lzdGVtLmF0b21zIHtcbiAgLm14LWJ1dHRvbi0tZGFyayB7XG4gICAgLS1idXR0b24tbGluZS1jb2xvdXI6IHZhcigtLWNvbG91ci1wcmltYXJ5KTtcbiAgICAtLWJhY2tncm91bmQ6IHZhcigtLWNvbG91ci1wcmltYXJ5KTtcbiAgICAtLWZvcmVncm91bmQ6IHZhcigtLWNvbG91ci1mb3JlZ3JvdW5kLXJldmVyc2UpO1xuXG4gICAgJi5idXR0b24tLW91dGxpbmUge1xuICAgICAgLS1iYWNrZ3JvdW5kOiB0cmFuc3BhcmVudDtcbiAgICAgIC0tZm9yZWdyb3VuZDogdmFyKC0tY29sb3VyLXByaW1hcnkpO1xuICAgIH1cbiAgfVxuXG4gIC5teC1idXR0b24tLWxpZ2h0IHtcbiAgICBib3JkZXI6IHRyYW5zcGFyZW50O1xuICAgIGNvbG9yOiB2YXIoLS1saW5rLWNvbG91ciwgdmFyKC0tY29sb3VyLXByaW1hcnkpKTtcbiAgICB0ZXh0LWRlY29yYXRpb24tbGluZTogdW5kZXJsaW5lO1xuXG4gICAgJjpob3ZlciB7XG4gICAgICB0ZXh0LWRlY29yYXRpb24tbGluZTogdW5kZXJsaW5lO1xuICAgIH1cbiAgfVxuXG4gIC5teC1idXR0b24tLWRlc3RydWN0aXZlIHtcbiAgICAtLWJ1dHRvbi1saW5lLWNvbG91cjogdmFyKC0tY29sb3VyLWVycm9yLWZvcmVncm91bmQpO1xuICAgIC0tYmFja2dyb3VuZDogdmFyKC0tY29sb3VyLWVycm9yLWZvcmVncm91bmQpO1xuICAgIC0tZm9yZWdyb3VuZDogdmFyKC0tY29sb3VyLWZvcmVncm91bmQtcmV2ZXJzZSk7XG5cbiAgICAmLmJ1dHRvbi0tb3V0bGluZSB7XG4gICAgICAtLWJhY2tncm91bmQ6IHRyYW5zcGFyZW50O1xuICAgICAgLS1mb3JlZ3JvdW5kOiB2YXIoLS1jb2xvdXItZXJyb3ItZm9yZWdyb3VuZCk7XG4gICAgfVxuICB9XG5cbiAgLm14LWJ1dHRvbi0td2hpdGUge1xuICAgIC0tYnV0dG9uLWxpbmUtY29sb3VyOiB2YXIoLS1jb2xvdXItZm9yZWdyb3VuZC1yZXZlcnNlKTtcbiAgICAtLWJhY2tncm91bmQ6IHZhcigtLWNvbG91ci1mb3JlZ3JvdW5kLXJldmVyc2UpO1xuICAgIC0tZm9yZWdyb3VuZDogdmFyKC0tY29sb3VyLWZvcmVncm91bmQpO1xuXG4gICAgJi5idXR0b24tLW91dGxpbmUge1xuICAgICAgLS1iYWNrZ3JvdW5kOiB0cmFuc3BhcmVudDtcbiAgICAgIC0tZm9yZWdyb3VuZDogdmFyKC0tY29sb3VyLWZvcmVncm91bmQtcmV2ZXJzZSk7XG4gICAgfVxuICB9XG59XG4iXX0= */
132
+ /*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIl9idXR0b25zLmNzcyIsIl9idXR0b25zLXN0eWxlcy5jc3MiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0VBRUU7O0FBRUY7RUFDRTtJQUNFLDJCQUFxQjtJQUNyQix5QkFBb0I7O0lBRXBCLG9CQUFvQjtJQUNwQiw2QkFBd0I7SUFBeEIsd0JBQXdCO0lBQ3hCLHdDQUF3QztJQUN4QyxvREFBb0Q7SUFDcEQsb0NBQW9DO0lBQ3BDLCtCQUErQjtJQUMvQixrQ0FBa0M7SUFDbEM7cURBQ2lEO0lBRGpEO3FEQUNpRDtJQUNqRCxvREFBb0Q7SUFDcEQsMERBQTBEO0lBQzFELDJEQUEyRDtJQUMzRCw2REFBNkQ7SUFDN0Qsa0RBQWtEO0lBQ2xELDBCQUEwQjtJQUMxQjs7O3VCQUdtQjtFQVdyQjs7SUFURTtNQUNFLGVBQWU7TUFDZiwwQkFBMEI7SUFDNUI7O0lBRUE7TUFDRSxtQkFBbUI7TUFDbkIsWUFBWTtJQUNkOztFQUdGO0lBQ0UsaUJBQWlCO0lBQ2pCLHVCQUF1QjtFQUN6Qjs7RUFFQTtJQUNFLG9DQUFvQztJQUNwQyxzQ0FBc0M7RUFDeEM7O0VBRUE7SUFDRSxzQ0FBc0M7SUFDdEMsdUNBQXVDO0lBQ3ZDLHNDQUFzQztFQUN4Qzs7RUFFQTtJQUNFLDhCQUE4QjtJQUM5Qiw2QkFBNkI7SUFDN0IsVUFBVTtJQUNWLHlDQUF5QztJQUN6QyxnQkFBZ0I7SUFDaEIsZUFBZTtFQVdqQjs7SUFURTtNQUNFLGlCQUFpQjtNQUNqQixnQkFBZ0I7TUFDaEIsbUNBQTJCO2NBQTNCLDJCQUEyQjtJQUM3Qjs7SUFFQTtNQUNFLHFCQUFxQjtNQUFyQix1QkFBcUI7TUFBckIscUJBQXFCO0lBQ3ZCO0FBRUo7O0FDMUVBOztFQUVFOztBQUVGO0VBQ0U7SUFDRSwyQ0FBMkM7SUFDM0MsbUNBQW1DO0lBQ25DLDhDQUE4QztFQU1oRDs7SUFKRTtNQUNFLHlCQUF5QjtNQUN6QixtQ0FBbUM7SUFDckM7O0VBR0Y7SUFDRSxtQkFBbUI7SUFDbkIsZ0RBQWdEO0lBQ2hELCtCQUErQjtFQUtqQzs7SUFIRTtNQUNFLCtCQUErQjtJQUNqQzs7RUFHRjtJQUNFLG9EQUFvRDtJQUNwRCw0Q0FBNEM7SUFDNUMsOENBQThDO0VBTWhEOztJQUpFO01BQ0UseUJBQXlCO01BQ3pCLDRDQUE0QztJQUM5Qzs7RUFHRjtJQUNFLHNEQUFzRDtJQUN0RCw4Q0FBOEM7SUFDOUMsc0NBQXNDO0VBTXhDOztJQUpFO01BQ0UseUJBQXlCO01BQ3pCLDhDQUE4QztJQUNoRDtBQUVKIiwiZmlsZSI6ImJ1dHRvbi5jc3MiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEJ1dHRvbnNcbiAqL1xuXG5AbGF5ZXIgZGVzaWduLXN5c3RlbS5hdG9tcyB7XG4gIC5teC1idXR0b24ge1xuICAgIC0tb3V0bGluZS1vZmZzZXQ6IDFweDtcbiAgICAtLW91dGxpbmUtd2lkdGg6IDJweDtcblxuICAgIGRpc3BsYXk6IGlubGluZS1mbGV4O1xuICAgIGlubGluZS1zaXplOiBmaXQtY29udGVudDtcbiAgICBnYXA6IHZhcigtLWJ1dHRvbi1nYXAsIHZhcigtLXNwYWNpbmctcykpO1xuICAgIGZvbnQtc2l6ZTogdmFyKC0tYnV0dG9uLWZvbnQtc2l6ZSwgdmFyKC0tZm9udC1zaXplKSk7XG4gICAgZm9udC13ZWlnaHQ6IHZhcigtLWZvbnQtd2VpZ2h0LWJvbGQpO1xuICAgIGZvbnQtZmFtaWx5OiB2YXIoLS1mb250LWZhbWlseSk7XG4gICAgbGluZS1oZWlnaHQ6IHZhcigtLWxpbmUtaGVpZ2h0LXVpKTtcbiAgICBib3JkZXI6IHZhcigtLWxpbmUtd2lkdGgsIDJweCkgc29saWRcbiAgICAgIHZhcigtLWJ1dHRvbi1saW5lLWNvbG91ciwgdmFyKC0tY29sb3VyLWJvcmRlcikpO1xuICAgIGJvcmRlci1yYWRpdXM6IHZhcigtLXJhZGl1cywgdmFyKC0tYm9yZGVyLXJhZGl1cy1sKSk7XG4gICAgcGFkZGluZy1ibG9jazogdmFyKC0tdmVydGljYWwtcGFkZGluZywgdmFyKC0tc3BhY2luZy14eHMpKTtcbiAgICBwYWRkaW5nLWlubGluZTogdmFyKC0taG9yaXpvbnRhbC1wYWRkaW5nLCB2YXIoLS1zcGFjaW5nLW0pKTtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiB2YXIoLS1iYWNrZ3JvdW5kLCB2YXIoLS1jb2xvdXItYmFja2dyb3VuZCkpO1xuICAgIGNvbG9yOiB2YXIoLS1mb3JlZ3JvdW5kLCB2YXIoLS1jb2xvdXItZm9yZWdyb3VuZCkpO1xuICAgIHRleHQtZGVjb3JhdGlvbi1saW5lOiBub25lO1xuICAgIHRyYW5zaXRpb246XG4gICAgICAwLjJzIGNvbG9yLFxuICAgICAgMC4ycyBiYWNrZ3JvdW5kLWNvbG9yLFxuICAgICAgMC4ycyBib3JkZXItY29sb3I7XG5cbiAgICAmOmhvdmVyIHtcbiAgICAgIGN1cnNvcjogcG9pbnRlcjtcbiAgICAgIHRleHQtZGVjb3JhdGlvbi1saW5lOiBub25lO1xuICAgIH1cblxuICAgICY6ZGlzYWJsZWQge1xuICAgICAgY3Vyc29yOiBub3QtYWxsb3dlZDtcbiAgICAgIG9wYWNpdHk6IDAuMztcbiAgICB9XG4gIH1cblxuICAubXgtYnV0dG9uLS1mdWxsLXdpZHRoIHtcbiAgICBpbmxpbmUtc2l6ZTogMTAwJTtcbiAgICBqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjtcbiAgfVxuXG4gIC5teC1idXR0b24tLWxhcmdlIHtcbiAgICAtLXZlcnRpY2FsLXBhZGRpbmc6IHZhcigtLXNwYWNpbmctcyk7XG4gICAgLS1ob3Jpem9udGFsLXBhZGRpbmc6IHZhcigtLXNwYWNpbmctbCk7XG4gIH1cblxuICAubXgtYnV0dG9uLS1zbWFsbCB7XG4gICAgLS1idXR0b24tZm9udC1zaXplOiB2YXIoLS1mb250LXNpemUtcyk7XG4gICAgLS12ZXJ0aWNhbC1wYWRkaW5nOiB2YXIoLS1zcGFjaW5nLXh4eHMpO1xuICAgIC0taG9yaXpvbnRhbC1wYWRkaW5nOiB2YXIoLS1zcGFjaW5nLXMpO1xuICB9XG5cbiAgLm14LWJ1dHRvbi0taWNvbi1vbmx5IHtcbiAgICBpbmxpbmUtc2l6ZTogdmFyKC0tc3BhY2luZy14bCk7XG4gICAgYmxvY2stc2l6ZTogdmFyKC0tc3BhY2luZy14bCk7XG4gICAgcGFkZGluZzogMDtcbiAgICBib3JkZXItcmFkaXVzOiB2YXIoLS1ib3JkZXItcmFkaXVzLXJvdW5kKTtcbiAgICBvdmVyZmxvdzogaGlkZGVuO1xuICAgIGZsZXgtd3JhcDogd3JhcDtcblxuICAgICY6OmJlZm9yZSB7XG4gICAgICBpbmxpbmUtc2l6ZTogMTAwJTtcbiAgICAgIGJsb2NrLXNpemU6IDEwMCU7XG4gICAgICBtYXNrLXNpemU6IHZhcigtLXNwYWNpbmctcyk7XG4gICAgfVxuXG4gICAgJjpoYXMoLm14LWljb24pIHtcbiAgICAgIHBsYWNlLWNvbnRlbnQ6IGNlbnRlcjtcbiAgICB9XG4gIH1cbn1cbiIsIi8qKlxuICogQnV0dG9uc1xuICovXG5cbkBsYXllciBkZXNpZ24tc3lzdGVtLmF0b21zIHtcbiAgLm14LWJ1dHRvbi0tZGFyayB7XG4gICAgLS1idXR0b24tbGluZS1jb2xvdXI6IHZhcigtLWNvbG91ci1wcmltYXJ5KTtcbiAgICAtLWJhY2tncm91bmQ6IHZhcigtLWNvbG91ci1wcmltYXJ5KTtcbiAgICAtLWZvcmVncm91bmQ6IHZhcigtLWNvbG91ci1mb3JlZ3JvdW5kLXJldmVyc2UpO1xuXG4gICAgJi5idXR0b24tLW91dGxpbmUge1xuICAgICAgLS1iYWNrZ3JvdW5kOiB0cmFuc3BhcmVudDtcbiAgICAgIC0tZm9yZWdyb3VuZDogdmFyKC0tY29sb3VyLXByaW1hcnkpO1xuICAgIH1cbiAgfVxuXG4gIC5teC1idXR0b24tLWxpZ2h0IHtcbiAgICBib3JkZXI6IHRyYW5zcGFyZW50O1xuICAgIGNvbG9yOiB2YXIoLS1saW5rLWNvbG91ciwgdmFyKC0tY29sb3VyLXByaW1hcnkpKTtcbiAgICB0ZXh0LWRlY29yYXRpb24tbGluZTogdW5kZXJsaW5lO1xuXG4gICAgJjpob3ZlciB7XG4gICAgICB0ZXh0LWRlY29yYXRpb24tbGluZTogdW5kZXJsaW5lO1xuICAgIH1cbiAgfVxuXG4gIC5teC1idXR0b24tLWRlc3RydWN0aXZlIHtcbiAgICAtLWJ1dHRvbi1saW5lLWNvbG91cjogdmFyKC0tY29sb3VyLWVycm9yLWZvcmVncm91bmQpO1xuICAgIC0tYmFja2dyb3VuZDogdmFyKC0tY29sb3VyLWVycm9yLWZvcmVncm91bmQpO1xuICAgIC0tZm9yZWdyb3VuZDogdmFyKC0tY29sb3VyLWZvcmVncm91bmQtcmV2ZXJzZSk7XG5cbiAgICAmLmJ1dHRvbi0tb3V0bGluZSB7XG4gICAgICAtLWJhY2tncm91bmQ6IHRyYW5zcGFyZW50O1xuICAgICAgLS1mb3JlZ3JvdW5kOiB2YXIoLS1jb2xvdXItZXJyb3ItZm9yZWdyb3VuZCk7XG4gICAgfVxuICB9XG5cbiAgLm14LWJ1dHRvbi0td2hpdGUge1xuICAgIC0tYnV0dG9uLWxpbmUtY29sb3VyOiB2YXIoLS1jb2xvdXItZm9yZWdyb3VuZC1yZXZlcnNlKTtcbiAgICAtLWJhY2tncm91bmQ6IHZhcigtLWNvbG91ci1mb3JlZ3JvdW5kLXJldmVyc2UpO1xuICAgIC0tZm9yZWdyb3VuZDogdmFyKC0tY29sb3VyLWZvcmVncm91bmQpO1xuXG4gICAgJi5idXR0b24tLW91dGxpbmUge1xuICAgICAgLS1iYWNrZ3JvdW5kOiB0cmFuc3BhcmVudDtcbiAgICAgIC0tZm9yZWdyb3VuZDogdmFyKC0tY29sb3VyLWZvcmVncm91bmQtcmV2ZXJzZSk7XG4gICAgfVxuICB9XG59XG4iXX0= */
@@ -0,0 +1,61 @@
1
+ import { m as makeAnchor } from "./utilities-B4YZb689.js";
2
+ class Accordion extends HTMLElement {
3
+ constructor() {
4
+ super();
5
+ this.handleOpen = () => {
6
+ if (!this.details) return;
7
+ this.details.open = true;
8
+ };
9
+ this.handleClose = () => {
10
+ if (!this.details) return;
11
+ this.details.open = false;
12
+ };
13
+ this.handleHash = () => {
14
+ const { hash } = window.location;
15
+ if (hash && hash === `#${this.details?.id}`) {
16
+ this.handleOpen();
17
+ }
18
+ };
19
+ this.generatedId = () => {
20
+ const string = this.trigger?.textContent?.trim();
21
+ return !string ? "" : makeAnchor(string);
22
+ };
23
+ this.internals_ = this.attachInternals();
24
+ this.controller = new AbortController();
25
+ }
26
+ connectedCallback() {
27
+ if (!this.details || !this.trigger) return;
28
+ const { signal } = this.controller;
29
+ document.addEventListener("beforeprint", this.handleOpen, {
30
+ signal
31
+ });
32
+ document.addEventListener("afterprint", this.handleClose, {
33
+ signal
34
+ });
35
+ this.handleHash();
36
+ document.addEventListener("hashchange", this.handleHash, { signal });
37
+ }
38
+ disconnectedCallback() {
39
+ this.controller.abort();
40
+ }
41
+ get details() {
42
+ const details = this.querySelector("details");
43
+ if (!details) {
44
+ throw new Error(`${this.localName} must contain a <details> element.`);
45
+ }
46
+ details.id = details.id || this.generatedId();
47
+ return details;
48
+ }
49
+ get trigger() {
50
+ const trigger = this.querySelector("summary");
51
+ if (!trigger) {
52
+ throw new Error(`${this.localName} must contain a <summary> element.`);
53
+ }
54
+ return trigger;
55
+ }
56
+ }
57
+ customElements.define("mx-accordion", Accordion);
58
+ export {
59
+ Accordion as A
60
+ };
61
+ //# sourceMappingURL=Accordion-DSze7pxN.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Accordion-DSze7pxN.js","sources":["../../../src/Component/Accordion/Elements/Accordion.ts"],"sourcesContent":["/**\n * Accordion\n * @file Support opening on hash, adding an ID attribute and toggling on print.\n */\n\nimport { makeAnchor } from \"../../../Utility/utilities\"\n\nexport default class Accordion extends HTMLElement {\n internals_: ElementInternals\n controller: AbortController\n\n constructor() {\n super()\n this.internals_ = this.attachInternals()\n this.controller = new AbortController()\n }\n\n connectedCallback(): void {\n if (!this.details || !this.trigger) return\n\n const { signal }: AbortController = this.controller\n document.addEventListener(\"beforeprint\", this.handleOpen, {\n signal,\n })\n document.addEventListener(\"afterprint\", this.handleClose, {\n signal,\n })\n this.handleHash()\n document.addEventListener(\"hashchange\", this.handleHash, { signal })\n }\n\n disconnectedCallback(): void {\n this.controller.abort()\n }\n\n handleOpen = (): void => {\n if (!this.details) return\n this.details.open = true\n }\n\n handleClose = (): void => {\n if (!this.details) return\n this.details.open = false\n }\n\n handleHash = (): void => {\n const { hash }: Location = window.location\n if (hash && hash === `#${this.details?.id}`) {\n this.handleOpen()\n }\n }\n\n get details(): HTMLDetailsElement | null {\n const details: HTMLDetailsElement | null = this.querySelector(\"details\")\n if (!details) {\n throw new Error(`${this.localName} must contain a <details> element.`)\n }\n details.id = details.id || this.generatedId()\n return details\n }\n\n get trigger(): HTMLElement | null {\n const trigger: HTMLElement | null = this.querySelector(\"summary\")\n if (!trigger) {\n throw new Error(`${this.localName} must contain a <summary> element.`)\n }\n return trigger\n }\n\n generatedId = (): string => {\n const string: string | undefined = this.trigger?.textContent?.trim()\n return !string ? \"\" : makeAnchor(string)\n }\n}\n\ncustomElements.define(\"mx-accordion\", Accordion)\n\ndeclare global {\n interface HTMLElementTagNameMap {\n \"mx-accordion\": Accordion\n }\n}\n"],"names":[],"mappings":";AAOA,MAAqB,kBAAkB,YAAY;AAAA,EAIjD,cAAc;AACN;AAuBR,SAAA,aAAa,MAAY;AACnB,UAAA,CAAC,KAAK,QAAS;AACnB,WAAK,QAAQ,OAAO;AAAA,IAAA;AAGtB,SAAA,cAAc,MAAY;AACpB,UAAA,CAAC,KAAK,QAAS;AACnB,WAAK,QAAQ,OAAO;AAAA,IAAA;AAGtB,SAAA,aAAa,MAAY;AACjB,YAAA,EAAE,KAAK,IAAc,OAAO;AAClC,UAAI,QAAQ,SAAS,IAAI,KAAK,SAAS,EAAE,IAAI;AAC3C,aAAK,WAAW;AAAA,MAClB;AAAA,IAAA;AAoBF,SAAA,cAAc,MAAc;AAC1B,YAAM,SAA6B,KAAK,SAAS,aAAa,KAAK;AACnE,aAAO,CAAC,SAAS,KAAK,WAAW,MAAM;AAAA,IAAA;AA1DlC,SAAA,aAAa,KAAK;AAClB,SAAA,aAAa,IAAI;EACxB;AAAA,EAEA,oBAA0B;AACxB,QAAI,CAAC,KAAK,WAAW,CAAC,KAAK,QAAS;AAE9B,UAAA,EAAE,OAAO,IAAqB,KAAK;AAChC,aAAA,iBAAiB,eAAe,KAAK,YAAY;AAAA,MACxD;AAAA,IAAA,CACD;AACQ,aAAA,iBAAiB,cAAc,KAAK,aAAa;AAAA,MACxD;AAAA,IAAA,CACD;AACD,SAAK,WAAW;AAChB,aAAS,iBAAiB,cAAc,KAAK,YAAY,EAAE,QAAQ;AAAA,EACrE;AAAA,EAEA,uBAA6B;AAC3B,SAAK,WAAW;EAClB;AAAA,EAmBA,IAAI,UAAqC;AACjC,UAAA,UAAqC,KAAK,cAAc,SAAS;AACvE,QAAI,CAAC,SAAS;AACZ,YAAM,IAAI,MAAM,GAAG,KAAK,SAAS,oCAAoC;AAAA,IACvE;AACA,YAAQ,KAAK,QAAQ,MAAM,KAAK,YAAY;AACrC,WAAA;AAAA,EACT;AAAA,EAEA,IAAI,UAA8B;AAC1B,UAAA,UAA8B,KAAK,cAAc,SAAS;AAChE,QAAI,CAAC,SAAS;AACZ,YAAM,IAAI,MAAM,GAAG,KAAK,SAAS,oCAAoC;AAAA,IACvE;AACO,WAAA;AAAA,EACT;AAMF;AAEA,eAAe,OAAO,gBAAgB,SAAS;"}
@@ -0,0 +1,137 @@
1
+ import { A as Accordion } from "./chunks/Accordion-DSze7pxN.js";
2
+ class AccordionMobile extends Accordion {
3
+ constructor() {
4
+ super();
5
+ this.handleBreakpoint = ({
6
+ matches
7
+ }) => {
8
+ if (!this.details) return;
9
+ this.details.toggleAttribute("open", !matches);
10
+ };
11
+ this.mq = this.getAttribute("mq") || "(max-width: 720px)";
12
+ }
13
+ connectedCallback() {
14
+ this.handleBreakpoint(this.breakpoint);
15
+ const { signal } = this.controller;
16
+ this.breakpoint.addEventListener("change", this.handleBreakpoint, {
17
+ signal
18
+ });
19
+ }
20
+ disconnectedCallback() {
21
+ this.controller.abort();
22
+ }
23
+ get breakpoint() {
24
+ return window.matchMedia(this.mq);
25
+ }
26
+ }
27
+ customElements.define("mx-accordionmobile", AccordionMobile);
28
+ const _Filters = class _Filters extends HTMLElement {
29
+ constructor() {
30
+ super();
31
+ this.handleClose = (event) => {
32
+ if (!this.details) return;
33
+ this.details.open = false;
34
+ event.preventDefault();
35
+ };
36
+ this.handleShow = (event) => {
37
+ event.preventDefault();
38
+ const wrapper = this.showBtn.previousElementSibling;
39
+ wrapper.removeAttribute("hidden");
40
+ const lastVisible = wrapper.previousElementSibling;
41
+ const input = lastVisible.querySelector("input");
42
+ if (!input) return;
43
+ input.focus({ preventScroll: true });
44
+ setTimeout(() => {
45
+ this.showBtn.setAttribute("hidden", "");
46
+ }, 100);
47
+ };
48
+ this.handleReset = () => {
49
+ this.entries.forEach((entry, key) => {
50
+ this.entries.set(key, { ...entry, count: null });
51
+ if (entry.counter) entry.counter.textContent = "";
52
+ });
53
+ this.setAttribute("count", "0");
54
+ };
55
+ this.handleCounters = () => {
56
+ const formData = new FormData(this.form, this.submitBtn);
57
+ this.entries.forEach((entry, key) => {
58
+ const { length } = formData.getAll(key).filter(Boolean);
59
+ const count = length > 0 ? length : null;
60
+ this.entries.set(key, { ...entry, count });
61
+ if (entry.counter) entry.counter.textContent = count?.toString() || "";
62
+ });
63
+ const totalCount = [...this.entries].filter(([, item]) => item.count).length;
64
+ this.setAttribute("count", totalCount.toString());
65
+ };
66
+ this.internals_ = this.attachInternals();
67
+ this.controller = new AbortController();
68
+ }
69
+ connectedCallback() {
70
+ if (!this.items) return;
71
+ const { signal } = this.controller;
72
+ this.closeBtn?.addEventListener("click", this.handleClose, {
73
+ signal
74
+ });
75
+ this.showBtn?.addEventListener("click", this.handleShow, {
76
+ signal
77
+ });
78
+ this.handleCounters();
79
+ this.addEventListener("change", this.handleCounters, { signal });
80
+ this.form?.addEventListener("submit", this.handleCounters, { signal });
81
+ this.form?.addEventListener("reset", this.handleReset, { signal });
82
+ }
83
+ disconnectedCallback() {
84
+ this.controller.abort();
85
+ }
86
+ attributeChangedCallback(name, oldValue, newValue) {
87
+ if (name === "count" && oldValue !== newValue) {
88
+ const qualifier = parseInt(newValue, 10) > 0;
89
+ this.resetBtn?.toggleAttribute("disabled", !qualifier);
90
+ this.submitBtn?.toggleAttribute("disabled", !qualifier);
91
+ if (!this.allCounter) return;
92
+ this.allCounter.textContent = qualifier ? newValue : "";
93
+ }
94
+ }
95
+ get items() {
96
+ const items = this.querySelectorAll(".mx-filter-item");
97
+ if (!items) {
98
+ throw new Error(
99
+ `${this.localName} must contain a .mx-filter-item element.`
100
+ );
101
+ }
102
+ this.entries = /* @__PURE__ */ new Map();
103
+ items.forEach((item) => {
104
+ const key = item.querySelector("input, select")?.getAttribute("name");
105
+ this.entries.set(key, {
106
+ item,
107
+ counter: item.querySelector("[data-counter]")
108
+ });
109
+ });
110
+ return items;
111
+ }
112
+ get details() {
113
+ return this.querySelector("mx-accordionmobile > details");
114
+ }
115
+ get closeBtn() {
116
+ return this.details?.querySelector("button[data-close]");
117
+ }
118
+ get form() {
119
+ return this.querySelector("form");
120
+ }
121
+ get resetBtn() {
122
+ return this.querySelector("button[type='reset']");
123
+ }
124
+ get submitBtn() {
125
+ return this.querySelector("button[type='submit']");
126
+ }
127
+ get showBtn() {
128
+ return this.querySelector("button[data-show]");
129
+ }
130
+ get allCounter() {
131
+ return this.querySelector("[data-counters]");
132
+ }
133
+ };
134
+ _Filters.observedAttributes = ["count"];
135
+ let Filters = _Filters;
136
+ customElements.define("mx-filters", Filters);
137
+ //# sourceMappingURL=filters.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"filters.entry.js","sources":["../../src/Component/Accordion/Elements/AccordionMobile.ts","../../src/Component/Filters/Elements/Filters.ts"],"sourcesContent":["/**\n * AccordionMobile\n * @file Support a mobile only <details> element, that opens at a breakpoint.\n */\n\nimport Accordion from \"./Accordion\"\n\nexport default class AccordionMobile extends Accordion {\n mq: string\n toggleAttribute!: Element[\"toggleAttribute\"]\n\n constructor() {\n super()\n this.mq = this.getAttribute(\"mq\") || \"(max-width: 720px)\"\n }\n\n connectedCallback(): void {\n this.handleBreakpoint(this.breakpoint)\n const { signal }: AbortController = this.controller\n this.breakpoint.addEventListener(\"change\", this.handleBreakpoint, {\n signal,\n })\n }\n\n disconnectedCallback(): void {\n this.controller.abort()\n }\n\n handleBreakpoint = ({\n matches,\n }: MediaQueryList | MediaQueryListEvent): void => {\n if (!this.details) return\n this.details.toggleAttribute(\"open\", !matches)\n }\n\n get breakpoint(): MediaQueryList {\n return window.matchMedia(this.mq)\n }\n}\n\ncustomElements.define(\"mx-accordionmobile\", AccordionMobile)\n\ndeclare global {\n interface HTMLElementTagNameMap {\n \"mx-accordionmobile\": AccordionMobile\n }\n}\n","/**\n * Filters\n * @file Support filter count elements and closing the \"right\" variant on mobile..\n */\n\nimport \"../../Accordion/Elements/Accordion\"\nimport \"../../Accordion/Elements/AccordionMobile\"\n\ntype EntryType = {\n item: HTMLElement\n counter?: HTMLSpanElement\n count?: number\n}\n\nexport default class Filters extends HTMLElement {\n internals_: ElementInternals\n controller: AbortController\n entries?: Map<string, EntryType>\n\n static observedAttributes = [\"count\"]\n\n constructor() {\n super()\n this.internals_ = this.attachInternals()\n this.controller = new AbortController()\n }\n\n connectedCallback(): void {\n if (!this.items) return\n\n const { signal }: AbortController = this.controller\n this.closeBtn?.addEventListener(\"click\", this.handleClose, {\n signal,\n })\n this.showBtn?.addEventListener(\"click\", this.handleShow, {\n signal,\n })\n\n this.handleCounters()\n this.addEventListener(\"change\", this.handleCounters, { signal })\n this.form?.addEventListener(\"submit\", this.handleCounters, { signal })\n this.form?.addEventListener(\"reset\", this.handleReset, { signal })\n }\n\n disconnectedCallback(): void {\n this.controller.abort()\n }\n\n attributeChangedCallback(\n name: string,\n oldValue: string,\n newValue: string,\n ): void {\n if (name === \"count\" && oldValue !== newValue) {\n const qualifier = parseInt(newValue, 10) > 0\n this.resetBtn?.toggleAttribute(\"disabled\", !qualifier)\n this.submitBtn?.toggleAttribute(\"disabled\", !qualifier)\n if (!this.allCounter) return\n this.allCounter.textContent = qualifier ? newValue : \"\"\n }\n }\n\n handleClose = (event: MouseEvent): void => {\n if (!this.details) return\n this.details.open = false\n event.preventDefault()\n }\n\n handleShow = (event: MouseEvent): void => {\n event.preventDefault()\n const wrapper = this.showBtn.previousElementSibling\n wrapper.removeAttribute(\"hidden\")\n const lastVisible = wrapper.previousElementSibling\n const input = lastVisible.querySelector(\"input\")\n if (!input) return\n input.focus({ preventScroll: true })\n setTimeout(() => {\n this.showBtn.setAttribute(\"hidden\", \"\")\n }, 100)\n }\n\n handleReset = (): void => {\n this.entries.forEach((entry, key): void => {\n this.entries.set(key, { ...entry, count: null })\n if (entry.counter) entry.counter.textContent = \"\"\n })\n this.setAttribute(\"count\", \"0\")\n }\n\n handleCounters = (): void => {\n const formData = new FormData(this.form, this.submitBtn)\n this.entries.forEach((entry, key): void => {\n const { length } = formData.getAll(key).filter(Boolean)\n const count = length > 0 ? length : null\n this.entries.set(key, { ...entry, count })\n if (entry.counter) entry.counter.textContent = count?.toString() || \"\"\n })\n\n const totalCount = [...this.entries].filter(([, item]) => item.count).length\n this.setAttribute(\"count\", totalCount.toString())\n }\n\n get items(): NodeListOf<HTMLElement> | null {\n const items: NodeListOf<HTMLElement> =\n this.querySelectorAll(\".mx-filter-item\")\n if (!items) {\n throw new Error(\n `${this.localName} must contain a .mx-filter-item element.`,\n )\n }\n this.entries = new Map()\n items.forEach(item => {\n const key = item.querySelector(\"input, select\")?.getAttribute(\"name\")\n this.entries.set(key, {\n item,\n counter: item.querySelector(\"[data-counter]\"),\n })\n })\n return items\n }\n\n get details(): HTMLDetailsElement | null {\n return this.querySelector(\"mx-accordionmobile > details\")\n }\n\n get closeBtn(): HTMLButtonElement | null {\n return this.details?.querySelector(\"button[data-close]\")\n }\n\n get form(): HTMLFormElement | null {\n return this.querySelector(\"form\")\n }\n\n get resetBtn(): HTMLButtonElement | null {\n return this.querySelector(\"button[type='reset']\")\n }\n\n get submitBtn(): HTMLButtonElement | null {\n return this.querySelector(\"button[type='submit']\")\n }\n\n get showBtn(): HTMLButtonElement | null {\n return this.querySelector(\"button[data-show]\")\n }\n\n get allCounter(): HTMLSpanElement | null {\n return this.querySelector(\"[data-counters]\")\n }\n}\n\ncustomElements.define(\"mx-filters\", Filters)\n\ndeclare global {\n interface HTMLElementTagNameMap {\n \"mx-filters\": Filters\n }\n}\n"],"names":[],"mappings":"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"}
@@ -41,6 +41,7 @@
41
41
  position: relative;
42
42
  display: grid;
43
43
  grid-template-columns: 1fr auto;
44
+ align-items: center;
44
45
  }
45
46
 
46
47
  .mx-header__brand {
@@ -88,6 +89,7 @@
88
89
 
89
90
  .mx-header__search {
90
91
  position: absolute;
92
+ z-index: 2;
91
93
  inset-block-start: 2px;
92
94
  inset-inline-start: 0;
93
95
  inline-size: 100%;
@@ -112,21 +114,34 @@
112
114
  0.2s opacity var(--ease),
113
115
  0.2s visibility var(--ease);
114
116
  }
117
+ @media (min-width: 720px) {
115
118
 
116
119
  .mx-header__search input {
117
- max-inline-size: 150px;
120
+ max-inline-size: 150px;
118
121
  }
122
+ }
119
123
 
120
124
  /**
121
125
  * Primary Header Stacked
122
126
  */
127
+ @media (min-width: 720px) {
123
128
  .mx-header__nav-inner {
124
- display: flex;
129
+ display: flex;
125
130
  }
131
+ }
126
132
 
127
133
  .mx-header__nav-right {
128
- margin-inline-start: auto;
134
+ margin-block: var(--spacing-m);
129
135
  }
136
+
137
+ @media (min-width: 720px) {
138
+
139
+ .mx-header__nav-right {
140
+ margin-inline-start: auto;
141
+ margin-block: 0;
142
+ padding-block: 4px;
143
+ }
144
+ }
130
145
  }
131
146
 
132
147
  @media print {
@@ -135,4 +150,4 @@
135
150
  }
136
151
  }
137
152
 
138
- /*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIl90b2dnbGVzLmNzcyIsIl9oZWFkZXIuY3NzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztFQUVFOztBQUVGO0VBQ0U7SUFDRSxhQUFhO0lBQ2IseUNBQXlDO0lBQ3pDLDRCQUF1QjtJQUN2QixrQkFBa0I7SUFDbEIsVUFBVTtFQWFaOztJQVhFO0VBUEY7TUFRSSxhQUFhO0VBVWpCO0lBVEU7O0lBRUE7TUFDRSx5QkFBeUI7SUFDM0I7O0lBRUE7TUFDRSxhQUFhO0lBQ2Y7SUFJQTs7RUFERjtNQUVJLGFBQWE7RUFFakI7SUFERTtBQUVKOztBQzlCQTs7RUFFRTs7QUFFRjtFQUNFO0lBQ0Usa0JBQWtCO0lBQ2xCLGFBQWE7SUFDYiwrQkFBK0I7RUFDakM7O0VBRUE7SUFDRSxhQUFhO0lBQ2IsaUNBQWlDO0lBQ2pDLG1CQUFtQjtJQUNuQix1QkFBdUI7RUFDekI7O0VBRUE7SUFDRSxhQUFhO0VBQ2Y7O0VBRUE7SUFDRSxhQUFhO0lBQ2IsZ0NBQWdDO0lBQ2hDLG1CQUFtQjtFQUNyQjs7RUFFQTtJQUNFLGlCQUFpQjtJQUNqQjs7aUNBRTZCO0VBaUIvQjs7SUFmRTs7RUFORjtNQU9JLFVBQVU7TUFDVixrQkFBa0I7TUFDbEIsaUJBQWlCO01BQ2pCLGdCQUFnQjtFQVdwQjtJQVZFOztJQUVBO01BQ0UsYUFBYTtNQUNiLFVBQVU7TUFDVixrQkFBa0I7TUFDbEI7O21DQUU2QjtJQUMvQjs7RUFHRjtJQUNFLGtCQUFrQjtJQUNsQixzQkFBc0I7SUFDdEIscUJBQXFCO0lBQ3JCLGlCQUFpQjtJQUNqQjs7aUNBRTZCO0VBbUIvQjs7SUFqQkU7O0VBVEY7TUFVSSxhQUFhO01BQ2Isa0JBQWtCO01BQ2xCLGlCQUFpQjtFQWNyQjtJQWJFOztJQUVBO01BQ0UsVUFBVTtNQUNWLGtCQUFrQjtNQUNsQjs7bUNBRTZCO0lBQy9COztJQUVBO01BQ0Usc0JBQXNCO0lBQ3hCOztFQUdGOztJQUVFO0VBQ0Y7SUFDRSxhQUFhO0VBQ2Y7O0VBRUE7SUFDRSx5QkFBeUI7RUFDM0I7QUFDRjs7QUFFQTtFQUNFO0lBQ0UsYUFBYTtFQUNmO0FBQ0YiLCJmaWxlIjoiaGVhZGVyLmNzcyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2xvYmFsIEhlYWRlclxuICovXG5cbkBsYXllciBkZXNpZ24tc3lzdGVtLmxheW91dHMge1xuICAubXgtaGVhZGVyX190b2dnbGVzIHtcbiAgICBkaXNwbGF5OiBmbGV4O1xuICAgIGdhcDogdmFyKC0tdG9nZ2xlLWdhcCwgdmFyKC0tc3BhY2luZy14cykpO1xuICAgIHBhZGRpbmctaW5saW5lLWVuZDogMnB4O1xuICAgIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgICB6LWluZGV4OiAxO1xuXG4gICAgQG1lZGlhICgtLWdsb2JhbC1uYXYtdXApIHtcbiAgICAgIGRpc3BsYXk6IG5vbmU7XG4gICAgfVxuXG4gICAgJiAubXgtYnV0dG9uLS1zZWNvbmRhcnkge1xuICAgICAgYm9yZGVyLWNvbG9yOiB0cmFuc3BhcmVudDtcbiAgICB9XG5cbiAgICAmIFtoaWRkZW5dIHtcbiAgICAgIGRpc3BsYXk6IG5vbmU7XG4gICAgfVxuICB9XG5cbiAgLmdsb2JhbC1uYXYtdXAtb25seSB7XG4gICAgQG1lZGlhICgtLWdsb2JhbC1uYXYtZG93bikge1xuICAgICAgZGlzcGxheTogbm9uZTtcbiAgICB9XG4gIH1cbn1cbiIsIi8qKlxuICogUHJpbWFyeSBIZWFkZXJcbiAqL1xuXG5AbGF5ZXIgZGVzaWduLXN5c3RlbS5sYXlvdXRzIHtcbiAgLm14LWhlYWRlcl9faW5uZXIge1xuICAgIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgICBkaXNwbGF5OiBncmlkO1xuICAgIGdyaWQtdGVtcGxhdGUtY29sdW1uczogMWZyIGF1dG87XG4gIH1cblxuICAubXgtaGVhZGVyX19icmFuZCB7XG4gICAgZGlzcGxheTogZmxleDtcbiAgICBnYXA6IHZhcigtLWJyYW5kLWdhcCwgdmFyKC0tZ2FwKSk7XG4gICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICBtYXJnaW4taW5saW5lLWVuZDogYXV0bztcbiAgfVxuXG4gIC5teC1oZWFkZXJfX25hbWUge1xuICAgIGRpc3BsYXk6IGdyaWQ7XG4gIH1cblxuICAubXgtaGVhZGVyX19tYWluIHtcbiAgICBkaXNwbGF5OiBmbGV4O1xuICAgIGdhcDogdmFyKC0tbWFpbi1nYXAsIHZhcigtLWdhcCkpO1xuICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIH1cblxuICAubXgtaGVhZGVyX19uYXYge1xuICAgIGlubGluZS1zaXplOiAxMDAlO1xuICAgIHRyYW5zaXRpb246XG4gICAgICAwLjJzIG9wYWNpdHkgdmFyKC0tZWFzZSksXG4gICAgICAwLjJzIHZpc2liaWxpdHkgdmFyKC0tZWFzZSk7XG5cbiAgICBAbWVkaWEgKC0tZ2xvYmFsLW5hdi11cCkge1xuICAgICAgei1pbmRleDogMjtcbiAgICAgIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgICAgIGlubGluZS1zaXplOiBhdXRvO1xuICAgICAgYmxvY2stc2l6ZTogYXV0bztcbiAgICB9XG5cbiAgICAmW2luZXJ0XSB7XG4gICAgICBibG9jay1zaXplOiAwO1xuICAgICAgb3BhY2l0eTogMDtcbiAgICAgIHZpc2liaWxpdHk6IGhpZGRlbjtcbiAgICAgIHRyYW5zaXRpb246XG4gICAgICAgIDAuMnMgb3BhY2l0eSB2YXIoLS1lYXNlKSxcbiAgICAgICAgMC4ycyB2aXNpYmlsaXR5IHZhcigtLWVhc2UpO1xuICAgIH1cbiAgfVxuXG4gIC5teC1oZWFkZXJfX3NlYXJjaCB7XG4gICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgIGluc2V0LWJsb2NrLXN0YXJ0OiAycHg7XG4gICAgaW5zZXQtaW5saW5lLXN0YXJ0OiAwO1xuICAgIGlubGluZS1zaXplOiAxMDAlO1xuICAgIHRyYW5zaXRpb246XG4gICAgICAwLjJzIG9wYWNpdHkgdmFyKC0tZWFzZSksXG4gICAgICAwLjJzIHZpc2liaWxpdHkgdmFyKC0tZWFzZSk7XG5cbiAgICBAbWVkaWEgKC0tZ2xvYmFsLW5hdi11cCkge1xuICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgICAgIGlubGluZS1zaXplOiBhdXRvO1xuICAgIH1cblxuICAgICZbaW5lcnRdIHtcbiAgICAgIG9wYWNpdHk6IDA7XG4gICAgICB2aXNpYmlsaXR5OiBoaWRkZW47XG4gICAgICB0cmFuc2l0aW9uOlxuICAgICAgICAwLjJzIG9wYWNpdHkgdmFyKC0tZWFzZSksXG4gICAgICAgIDAuMnMgdmlzaWJpbGl0eSB2YXIoLS1lYXNlKTtcbiAgICB9XG5cbiAgICAmIGlucHV0IHtcbiAgICAgIG1heC1pbmxpbmUtc2l6ZTogMTUwcHg7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIFByaW1hcnkgSGVhZGVyIFN0YWNrZWRcbiAgICovXG4gIC5teC1oZWFkZXJfX25hdi1pbm5lciB7XG4gICAgZGlzcGxheTogZmxleDtcbiAgfVxuXG4gIC5teC1oZWFkZXJfX25hdi1yaWdodCB7XG4gICAgbWFyZ2luLWlubGluZS1zdGFydDogYXV0bztcbiAgfVxufVxuXG5AbWVkaWEgcHJpbnQge1xuICAubXgtaGVhZGVyIC5teC1oZWFkZXJfX25hdiB7XG4gICAgZGlzcGxheTogbm9uZTtcbiAgfVxufVxuIl19 */
153
+ /*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIl90b2dnbGVzLmNzcyIsIl9oZWFkZXIuY3NzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztFQUVFOztBQUVGO0VBQ0U7SUFDRSxhQUFhO0lBQ2IseUNBQXlDO0lBQ3pDLDRCQUF1QjtJQUN2QixrQkFBa0I7SUFDbEIsVUFBVTtFQWFaOztJQVhFO0VBUEY7TUFRSSxhQUFhO0VBVWpCO0lBVEU7O0lBRUE7TUFDRSx5QkFBeUI7SUFDM0I7O0lBRUE7TUFDRSxhQUFhO0lBQ2Y7SUFJQTs7RUFERjtNQUVJLGFBQWE7RUFFakI7SUFERTtBQUVKOztBQzlCQTs7RUFFRTs7QUFFRjtFQUNFO0lBQ0Usa0JBQWtCO0lBQ2xCLGFBQWE7SUFDYiwrQkFBK0I7SUFDL0IsbUJBQW1CO0VBQ3JCOztFQUVBO0lBQ0UsYUFBYTtJQUNiLGlDQUFpQztJQUNqQyxtQkFBbUI7SUFDbkIsdUJBQXVCO0VBQ3pCOztFQUVBO0lBQ0UsYUFBYTtFQUNmOztFQUVBO0lBQ0UsYUFBYTtJQUNiLGdDQUFnQztJQUNoQyxtQkFBbUI7RUFDckI7O0VBRUE7SUFDRSxpQkFBaUI7SUFDakI7O2lDQUU2QjtFQWlCL0I7O0lBZkU7O0VBTkY7TUFPSSxVQUFVO01BQ1Ysa0JBQWtCO01BQ2xCLGlCQUFpQjtNQUNqQixnQkFBZ0I7RUFXcEI7SUFWRTs7SUFFQTtNQUNFLGFBQWE7TUFDYixVQUFVO01BQ1Ysa0JBQWtCO01BQ2xCOzttQ0FFNkI7SUFDL0I7O0VBR0Y7SUFDRSxrQkFBa0I7SUFDbEIsVUFBVTtJQUNWLHNCQUFzQjtJQUN0QixxQkFBcUI7SUFDckIsaUJBQWlCO0lBQ2pCOztpQ0FFNkI7RUFxQi9COztJQW5CRTs7RUFWRjtNQVdJLGFBQWE7TUFDYixrQkFBa0I7TUFDbEIsaUJBQWlCO0VBZ0JyQjtJQWZFOztJQUVBO01BQ0UsVUFBVTtNQUNWLGtCQUFrQjtNQUNsQjs7bUNBRTZCO0lBQy9CO01BR0U7O0lBREY7UUFFSSxzQkFBc0I7SUFFMUI7TUFERTs7RUFJSjs7SUFFRTtJQUVBO0VBREY7TUFFSSxhQUFhO0VBRWpCO0lBREU7O0VBR0Y7SUFDRSw4QkFBOEI7RUFPaEM7O0lBTEU7O0VBSEY7TUFJSSx5QkFBeUI7TUFDekIsZUFBZTtNQUNmLGtCQUFrQjtFQUV0QjtJQURFO0FBRUo7O0FBRUE7RUFDRTtJQUNFLGFBQWE7RUFDZjtBQUNGIiwiZmlsZSI6ImhlYWRlci5jc3MiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdsb2JhbCBIZWFkZXJcbiAqL1xuXG5AbGF5ZXIgZGVzaWduLXN5c3RlbS5sYXlvdXRzIHtcbiAgLm14LWhlYWRlcl9fdG9nZ2xlcyB7XG4gICAgZGlzcGxheTogZmxleDtcbiAgICBnYXA6IHZhcigtLXRvZ2dsZS1nYXAsIHZhcigtLXNwYWNpbmcteHMpKTtcbiAgICBwYWRkaW5nLWlubGluZS1lbmQ6IDJweDtcbiAgICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gICAgei1pbmRleDogMTtcblxuICAgIEBtZWRpYSAoLS1nbG9iYWwtbmF2LXVwKSB7XG4gICAgICBkaXNwbGF5OiBub25lO1xuICAgIH1cblxuICAgICYgLm14LWJ1dHRvbi0tc2Vjb25kYXJ5IHtcbiAgICAgIGJvcmRlci1jb2xvcjogdHJhbnNwYXJlbnQ7XG4gICAgfVxuXG4gICAgJiBbaGlkZGVuXSB7XG4gICAgICBkaXNwbGF5OiBub25lO1xuICAgIH1cbiAgfVxuXG4gIC5nbG9iYWwtbmF2LXVwLW9ubHkge1xuICAgIEBtZWRpYSAoLS1nbG9iYWwtbmF2LWRvd24pIHtcbiAgICAgIGRpc3BsYXk6IG5vbmU7XG4gICAgfVxuICB9XG59XG4iLCIvKipcbiAqIFByaW1hcnkgSGVhZGVyXG4gKi9cblxuQGxheWVyIGRlc2lnbi1zeXN0ZW0ubGF5b3V0cyB7XG4gIC5teC1oZWFkZXJfX2lubmVyIHtcbiAgICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gICAgZGlzcGxheTogZ3JpZDtcbiAgICBncmlkLXRlbXBsYXRlLWNvbHVtbnM6IDFmciBhdXRvO1xuICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIH1cblxuICAubXgtaGVhZGVyX19icmFuZCB7XG4gICAgZGlzcGxheTogZmxleDtcbiAgICBnYXA6IHZhcigtLWJyYW5kLWdhcCwgdmFyKC0tZ2FwKSk7XG4gICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICBtYXJnaW4taW5saW5lLWVuZDogYXV0bztcbiAgfVxuXG4gIC5teC1oZWFkZXJfX25hbWUge1xuICAgIGRpc3BsYXk6IGdyaWQ7XG4gIH1cblxuICAubXgtaGVhZGVyX19tYWluIHtcbiAgICBkaXNwbGF5OiBmbGV4O1xuICAgIGdhcDogdmFyKC0tbWFpbi1nYXAsIHZhcigtLWdhcCkpO1xuICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIH1cblxuICAubXgtaGVhZGVyX19uYXYge1xuICAgIGlubGluZS1zaXplOiAxMDAlO1xuICAgIHRyYW5zaXRpb246XG4gICAgICAwLjJzIG9wYWNpdHkgdmFyKC0tZWFzZSksXG4gICAgICAwLjJzIHZpc2liaWxpdHkgdmFyKC0tZWFzZSk7XG5cbiAgICBAbWVkaWEgKC0tZ2xvYmFsLW5hdi11cCkge1xuICAgICAgei1pbmRleDogMjtcbiAgICAgIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgICAgIGlubGluZS1zaXplOiBhdXRvO1xuICAgICAgYmxvY2stc2l6ZTogYXV0bztcbiAgICB9XG5cbiAgICAmW2luZXJ0XSB7XG4gICAgICBibG9jay1zaXplOiAwO1xuICAgICAgb3BhY2l0eTogMDtcbiAgICAgIHZpc2liaWxpdHk6IGhpZGRlbjtcbiAgICAgIHRyYW5zaXRpb246XG4gICAgICAgIDAuMnMgb3BhY2l0eSB2YXIoLS1lYXNlKSxcbiAgICAgICAgMC4ycyB2aXNpYmlsaXR5IHZhcigtLWVhc2UpO1xuICAgIH1cbiAgfVxuXG4gIC5teC1oZWFkZXJfX3NlYXJjaCB7XG4gICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgIHotaW5kZXg6IDI7XG4gICAgaW5zZXQtYmxvY2stc3RhcnQ6IDJweDtcbiAgICBpbnNldC1pbmxpbmUtc3RhcnQ6IDA7XG4gICAgaW5saW5lLXNpemU6IDEwMCU7XG4gICAgdHJhbnNpdGlvbjpcbiAgICAgIDAuMnMgb3BhY2l0eSB2YXIoLS1lYXNlKSxcbiAgICAgIDAuMnMgdmlzaWJpbGl0eSB2YXIoLS1lYXNlKTtcblxuICAgIEBtZWRpYSAoLS1nbG9iYWwtbmF2LXVwKSB7XG4gICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgcG9zaXRpb246IHJlbGF0aXZlO1xuICAgICAgaW5saW5lLXNpemU6IGF1dG87XG4gICAgfVxuXG4gICAgJltpbmVydF0ge1xuICAgICAgb3BhY2l0eTogMDtcbiAgICAgIHZpc2liaWxpdHk6IGhpZGRlbjtcbiAgICAgIHRyYW5zaXRpb246XG4gICAgICAgIDAuMnMgb3BhY2l0eSB2YXIoLS1lYXNlKSxcbiAgICAgICAgMC4ycyB2aXNpYmlsaXR5IHZhcigtLWVhc2UpO1xuICAgIH1cblxuICAgICYgaW5wdXQge1xuICAgICAgQG1lZGlhICgtLWdsb2JhbC1uYXYtdXApIHtcbiAgICAgICAgbWF4LWlubGluZS1zaXplOiAxNTBweDtcbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogUHJpbWFyeSBIZWFkZXIgU3RhY2tlZFxuICAgKi9cbiAgLm14LWhlYWRlcl9fbmF2LWlubmVyIHtcbiAgICBAbWVkaWEgKC0tZ2xvYmFsLW5hdi11cCkge1xuICAgICAgZGlzcGxheTogZmxleDtcbiAgICB9XG4gIH1cblxuICAubXgtaGVhZGVyX19uYXYtcmlnaHQge1xuICAgIG1hcmdpbi1ibG9jazogdmFyKC0tc3BhY2luZy1tKTtcblxuICAgIEBtZWRpYSAoLS1nbG9iYWwtbmF2LXVwKSB7XG4gICAgICBtYXJnaW4taW5saW5lLXN0YXJ0OiBhdXRvO1xuICAgICAgbWFyZ2luLWJsb2NrOiAwO1xuICAgICAgcGFkZGluZy1ibG9jazogNHB4O1xuICAgIH1cbiAgfVxufVxuXG5AbWVkaWEgcHJpbnQge1xuICAubXgtaGVhZGVyIC5teC1oZWFkZXJfX25hdiB7XG4gICAgZGlzcGxheTogbm9uZTtcbiAgfVxufVxuIl19 */
@@ -197,6 +197,10 @@
197
197
  }
198
198
  }
199
199
 
200
+ .mx-nav--dropdown a:focus-visible {
201
+ outline-offset: -2px;
202
+ }
203
+
200
204
  .mx-nav--dropdown li > ul {
201
205
  transition:
202
206
  0.2s opacity var(--ease),
@@ -389,4 +393,4 @@
389
393
  }
390
394
  }
391
395
 
392
- /*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["_navigation.css","_navigation-collapsible.css","_navigation-dropdown.css","_navigation-mega.css"],"names":[],"mappings":"AAAA;;EAEE;;AAEF;IAEI;;MAEE,aAAa;MACb,sBAAsB;MACtB,qBAAqB;MACrB,uBAAuB;MACvB,iDAAiD;IACnD;;IAEA;MACE,2BAA2B;;MAE3B,0BAAgD;;MAAhD,gDAAgD;IAKlD;;MAHE;QACE,+BAA4D;QAA5D,4DAA4D;MAC9D;IAKF;;MAEE,mBAAmB;MACnB,mBAAmB;MACnB,qCAAqC;IACvC;;EAGF;IACE,iFAAiB;IAAjB,mBAAiB;IACjB,UAAU;IACV,SAAS;IACT,wBAAgB;OAAhB,qBAAgB;YAAhB,gBAAgB;IAChB,kBAAkB;IAClB;;;KAGC;IACD,6BAA6B;IAC7B,4BAA4B;IAC5B,uBAA0C;IAA1C,0CAA0C;IAC1C,mBAAmB;IACnB,eAAe;EACjB;IAGE;MACE,yBAAyB;IAC3B;AAEJ;;ACzDA;;EAEE;;AAEF;IAEI;MACE,qCAAqC;IAKvC;;MAHE;IAHF;QAII,cAAc;IAElB;MADE;;IAGF;MACE,kBAAkB;IAmBpB;;MAjBE;QACE,oCAAoC;MACtC;;MAEA;QACE,cAAc;QACd,cAAc;QACd;kDAC0C;QAD1C;kDAC0C;QAC1C,sDAAsD;QACtD;iDACyC;MAK3C;;QAHE;UACE,oBAAoB;QACtB;;IAIJ;MACE,0BAA0B;IAK5B;;MAHE;;IAHF;QAII,0BAA0B;IAE9B;MADE;;IAGF;MACE,0BAA0B;IAK5B;;MAHE;;IAHF;QAII,0BAA0B;IAE9B;MADE;;IAGF;MACE;;;OAGC;MACD,cAA4C;MAA5C,4CAA4C;IAC9C;;IAEA;MACE;;gCAE0B;MAC1B,qBAAqB;MACrB,uBAAuB;IAUzB;;MARE;QACE,aAAa;QACb,UAAU;QACV,oBAAoB;QACpB;;kCAE0B;MAC5B;;IAGF;MACE,oCAAoC;IACtC;AAEJ;;ACjFA;;EAEE;;AAEF;EACE;IACE,4BAA4B;;IAE5B,8BAA8B;EA8IhC;;IA5IE;EALF;MAMI,eAAe;EA2InB;IA1IE;;IAEA;MACE,SAAS;IASX;;MAPE;QACE,kBAAkB;MAKpB;;QAHE;UACE,8BAA8B;QAChC;;IAIJ;MACE,cAAc;IAehB;QAZI;;MADF;UAEI;;;WAGC;UACD,cAA8C;UAA9C,8CAA8C;MAMlD;;UAJI;YACE,cAA8C;YAA9C,8CAA8C;UAChD;QACF;;IAIJ;MACE;;mCAE6B;IAc/B;;MAZE;QACE,aAAa;QACb,UAAU;QACV,kBAAkB;QAClB;;qCAE6B;MAK/B;;QAHE;;MARF;UASI,gBAAgB;MAEpB;QADE;;IAIJ;MACE,SAAS;MACT,gBAAgB;IA6BlB;;MA3BE;;IAJF;QAKI,iBAAiB;QACjB,cAAc;QACd,mBAAmB;QACnB,2BAA2B;IAuB/B;MAtBE;;MAEA;QACE;kDAC0C;QAD1C;kDAC0C;MAiB5C;;QAfE;;MAJF;UAKI,qBAAqB;MAczB;QAbE;;QAEA;UACE,sDAAsD;UACtD;;;WAGC;QAKH;;UAHE;;QAPF;YAQI,6DAA6D;QAEjE;UADE;;IAKN;MACE,cAAc;MACd,kBAAkB;MAClB,qBAAqB;MACrB,iBAAiB;MACjB,SAAS;IAiCX;;MA/BE;;IAPF;QAQI,kBAAkB;QAClB,kBAAyC;QAAzC,yCAAyC;QACzC,mCAAmC;QACnC;;;SAGC;QACD,cAA8C;QAA9C,8CAA8C;IAuBlD;;QArBI;UACE,yBAAyB;QAC3B;MACF;QAGE;;MADF;UAEI;oDAC0C;UAD1C;oDAC0C;MAY9C;QAXE;UAGE;YACE,gDAAgD;UAKlD;;YAHE;UAHF;cAII,sCAAsC;UAE1C;YADE;MAON;;IADF;QAEI,oBAAoB;IAMxB;;QAJI;UACE,wBAAwB;QAC1B;MACF;;IAGF;MACE;gDAC0C;MAD1C;gDAC0C;IAC5C;AAEJ;;ACvJA;;EAEE;;AAEF;IAEI;EADF;MAEI,oBAAoB;MACpB,cAAc;EAyClB;IAxCE;;IAEA;MACE,cAAc;MACd,kBAAkB;MAClB,sCAAsC;MACtC,kDAAkD;MAClD,iBAAiB;IAyBnB;;MAvBE;;IAPF;QAQI,kBAAkB;QAClB,yBAAgD;QAAhD,gDAAgD;QAChD,oBAAoB;QACpB,kBAAyC;QAAzC,yCAAyC;QACzC,oBAAoB;QACpB,uBAAuB;QACvB,qBAAqB;QACrB,4DAA4D;QAC5D;;;SAGC;QACD,cAA0C;QAA1C,0CAA0C;IAU9C;MATE;;MAEA;QACE,gDAAgD;MAKlD;;QAHE;;MAHF;UAII,sCAAsC;MAE1C;QADE;MAKF;;IADF;QAEI,oCAA2D;QAA3D,2DAA2D;QAC3D,4DAA4D;IAEhE;MADE;AAGN","file":"navigation.css","sourcesContent":["/**\n * Navigation\n */\n\n@layer design-system.atoms {\n  .mx-nav {\n    &:where(:not(:has(ul))),\n    ul {\n      display: flex;\n      flex-direction: column;\n      list-style-type: none;\n      padding-inline-start: 0;\n      font-size: var(--nav-font-size, var(--font-size));\n    }\n\n    & a[href] {\n      --link-colour: currentcolor;\n\n      text-decoration-line: var(--nav-underline, none);\n\n      &:hover {\n        text-decoration-line: var(--nav-active-underline, underline);\n      }\n    }\n  }\n\n  .mx-nav--inline {\n    &:where(:not(:has(ul))),\n    > ul {\n      flex-flow: row wrap;\n      align-items: center;\n      gap: var(--nav-gap, var(--spacing-s));\n    }\n  }\n\n  .mx-nav__toggle {\n    background: unset;\n    padding: 0;\n    border: 0;\n    appearance: none;\n    position: absolute;\n    color: var(\n      --toggle-foreground,\n      var(--foreground, var(--colour-foreground))\n    );\n    inline-size: var(--spacing-l);\n    block-size: var(--spacing-l);\n    inset-block-start: var(--toggle-top, 12px);\n    inset-inline-end: 0;\n    cursor: pointer;\n  }\n\n  .mx-nav--open {\n    & > .mx-nav__toggle::before {\n      transform: rotate(180deg);\n    }\n  }\n}\n","/**\n * Collapsible Navigation\n */\n\n@layer design-system.components {\n  .mx-nav--collapsible {\n    & .mx-nav__toggle {\n      inset-inline: auto var(--spacing-xxs);\n\n      @media (--medium-up) {\n        display: block;\n      }\n    }\n\n    & ul li {\n      position: relative;\n\n      &:has([aria-current=\"page\"], .is-active) > a {\n        font-weight: var(--font-weight-bold);\n      }\n\n      & a {\n        display: block;\n        color: inherit;\n        border-block-end: var(--line-width, 1px) solid\n          var(--line-colour, var(--colour-border));\n        padding-block: var(--item-spacing, var(--spacing-xxs));\n        padding-inline: var(--indent, var(--spacing-xxs))\n          var(--item-spacing, var(--spacing-xxs));\n\n        &:is(:focus, :focus-visible) {\n          outline-offset: -1px;\n        }\n      }\n    }\n\n    & .mx-nav__level-2 > li > a {\n      --indent: var(--spacing-s);\n\n      @media (--global-nav-up) {\n        --indent: var(--spacing-m);\n      }\n    }\n\n    & .mx-nav__level-3 > li > a {\n      --indent: var(--spacing-m);\n\n      @media (--global-nav-up) {\n        --indent: var(--spacing-l);\n      }\n    }\n\n    & :is([aria-current=\"page\"], .is-active > a) {\n      background-color: var(\n        --nav-active-background,\n        var(--background, var(--colour-background-alt))\n      );\n      color: var(--nav-active-foreground, inherit);\n    }\n\n    & li > ul {\n      transition:\n        transform 0.2s var(--ease),\n        opacity 0.8s var(--ease);\n      transform-origin: top;\n      will-change: block-size;\n\n      &[inert] {\n        block-size: 0;\n        opacity: 0;\n        transform: scaleY(0);\n        transition:\n          transform 0.8s var(--ease),\n          opacity 0.2s var(--ease);\n      }\n    }\n\n    & li:is(.mx-nav__has-subnav, :has(> ul)) > a {\n      padding-inline-end: var(--spacing-l);\n    }\n  }\n}\n","/**\n * Dropdown Navigation\n */\n\n@layer design-system.components {\n  .mx-nav--dropdown {\n    --nav-active-underline: none;\n\n    margin-block: var(--spacing-m);\n\n    @media (--global-nav-up) {\n      margin-block: 0;\n    }\n\n    & li {\n      margin: 0;\n\n      &:is(.mx-nav__has-subnav, :has(> ul)) {\n        position: relative;\n\n        & > a {\n          --toggle-gap: var(--spacing-l);\n        }\n      }\n    }\n\n    & a {\n      display: block;\n\n      &[aria-expanded=\"true\"] {\n        @media (--global-nav-up) {\n          background-color: var(\n            --nav-expanded-background,\n            var(--background, var(--colour-background-alt))\n          );\n          color: var(--nav-expanded-foreground, inherit);\n\n          & + .nav__toggle {\n            color: var(--nav-expanded-foreground, inherit);\n          }\n        }\n      }\n    }\n\n    & li > ul {\n      transition:\n        0.2s opacity var(--ease),\n        0.2s visibility var(--ease);\n\n      &[inert] {\n        block-size: 0;\n        opacity: 0;\n        visibility: hidden;\n        transition:\n          0.2s opacity var(--ease),\n          0.2s visibility var(--ease);\n\n        @media (--global-nav-up) {\n          block-size: auto;\n        }\n      }\n    }\n\n    & .mx-nav__level-1 {\n      margin: 0;\n      overflow: hidden;\n\n      @media (--global-nav-up) {\n        overflow: visible;\n        flex-flow: row;\n        align-items: center;\n        justify-content: flex-start;\n      }\n\n      & > li {\n        border-block-start: var(--line-width, 1px) solid\n          var(--line-colour, var(--colour-border));\n\n        @media (--global-nav-up) {\n          border-block-start: 0;\n        }\n\n        & > a:where(:not(.button)) {\n          padding-block: var(--item-spacing, var(--spacing-xxs));\n          padding-inline-end: var(\n            --toggle-gap,\n            var(--item-spacing, var(--spacing-xxs))\n          );\n\n          @media (--global-nav-up) {\n            padding-inline-start: var(--item-spacing, var(--spacing-xxs));\n          }\n        }\n      }\n    }\n\n    & .mx-nav__level-2 {\n      display: block;\n      position: relative;\n      inset-inline-start: 0;\n      inline-size: 100%;\n      margin: 0;\n\n      @media (--global-nav-up) {\n        position: absolute;\n        inline-size: var(--dropdown-width, 270px);\n        border-radius: var(--border-radius);\n        background-color: var(\n          --nav-expanded-background,\n          var(--background, var(--colour-background-alt))\n        );\n        color: var(--nav-expanded-foreground, inherit);\n\n        & .mx-nav__toggle::before {\n          transform: rotate(-90deg);\n        }\n      }\n\n      & > li {\n        @media (--global-nav-down) {\n          border-block-start: var(--line-width, 1px) solid\n            var(--line-colour, var(--colour-border));\n        }\n\n        & > a {\n          &:where(:not(.button)) {\n            padding: var(--item-spacing, var(--spacing-xxs));\n\n            @media (--global-nav-down) {\n              padding-inline-start: var(--spacing-l);\n            }\n          }\n        }\n      }\n    }\n\n    & .mx-nav--reverse .nav__level-2 {\n      @media (--global-nav-up) {\n        inset-inline: auto 0;\n\n        & .mx-nav__toggle::before {\n          transform: rotate(90deg);\n        }\n      }\n    }\n\n    & .mx-nav__separator {\n      border-block-start: var(--line-width, 1px) solid\n        var(--line-colour, var(--colour-border));\n    }\n  }\n}\n","/**\n * Dropdown Navigation - Mega Nav\n */\n\n@layer design-system.components {\n  .mx-nav--mega-nav {\n    @media (--global-nav-down) {\n      max-block-size: 100%;\n      overflow: auto;\n    }\n\n    & .mx-nav__level-2 ul {\n      display: block;\n      position: relative;\n      padding-inline-start: var(--spacing-l);\n      border-block-start: 1px solid var(--border-colour);\n      inline-size: 100%;\n\n      @media (--global-nav-up) {\n        position: absolute;\n        inset-inline-start: var(--dropdown-width, 270px);\n        inset-block-start: 0;\n        inline-size: var(--dropdown-width, 270px);\n        min-block-size: 100%;\n        padding-inline-start: 0;\n        border-block-start: 0;\n        border-radius: 0 var(--border-radius) var(--border-radius) 0;\n        background-color: var(\n          --expanded-background,\n          var(--colour-background-alt)\n        );\n        color: var(--expanded-foreground, inherit);\n      }\n\n      & > li > a:where(:not(.mx-button)) {\n        padding: var(--item-spacing, var(--spacing-xxs));\n\n        @media (--global-nav-down) {\n          padding-inline-start: var(--spacing-l);\n        }\n      }\n    }\n\n    & .mx-nav--reverse .mx-nav__level-2 ul {\n      @media (--global-nav-up) {\n        inset-inline-start: calc(var(--dropdown-width, 270px) * -1);\n        border-radius: var(--border-radius) 0 0 var(--border-radius);\n      }\n    }\n  }\n}\n"]} */
396
+ /*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["_navigation.css","_navigation-collapsible.css","_navigation-dropdown.css","_navigation-mega.css"],"names":[],"mappings":"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","file":"navigation.css","sourcesContent":["/**\n * Navigation\n */\n\n@layer design-system.atoms {\n  .mx-nav {\n    &:where(:not(:has(ul))),\n    ul {\n      display: flex;\n      flex-direction: column;\n      list-style-type: none;\n      padding-inline-start: 0;\n      font-size: var(--nav-font-size, var(--font-size));\n    }\n\n    & a[href] {\n      --link-colour: currentcolor;\n\n      text-decoration-line: var(--nav-underline, none);\n\n      &:hover {\n        text-decoration-line: var(--nav-active-underline, underline);\n      }\n    }\n  }\n\n  .mx-nav--inline {\n    &:where(:not(:has(ul))),\n    > ul {\n      flex-flow: row wrap;\n      align-items: center;\n      gap: var(--nav-gap, var(--spacing-s));\n    }\n  }\n\n  .mx-nav__toggle {\n    background: unset;\n    padding: 0;\n    border: 0;\n    appearance: none;\n    position: absolute;\n    color: var(\n      --toggle-foreground,\n      var(--foreground, var(--colour-foreground))\n    );\n    inline-size: var(--spacing-l);\n    block-size: var(--spacing-l);\n    inset-block-start: var(--toggle-top, 12px);\n    inset-inline-end: 0;\n    cursor: pointer;\n  }\n\n  .mx-nav--open {\n    & > .mx-nav__toggle::before {\n      transform: rotate(180deg);\n    }\n  }\n}\n","/**\n * Collapsible Navigation\n */\n\n@layer design-system.components {\n  .mx-nav--collapsible {\n    & .mx-nav__toggle {\n      inset-inline: auto var(--spacing-xxs);\n\n      @media (--medium-up) {\n        display: block;\n      }\n    }\n\n    & ul li {\n      position: relative;\n\n      &:has([aria-current=\"page\"], .is-active) > a {\n        font-weight: var(--font-weight-bold);\n      }\n\n      & a {\n        display: block;\n        color: inherit;\n        border-block-end: var(--line-width, 1px) solid\n          var(--line-colour, var(--colour-border));\n        padding-block: var(--item-spacing, var(--spacing-xxs));\n        padding-inline: var(--indent, var(--spacing-xxs))\n          var(--item-spacing, var(--spacing-xxs));\n\n        &:is(:focus, :focus-visible) {\n          outline-offset: -1px;\n        }\n      }\n    }\n\n    & .mx-nav__level-2 > li > a {\n      --indent: var(--spacing-s);\n\n      @media (--global-nav-up) {\n        --indent: var(--spacing-m);\n      }\n    }\n\n    & .mx-nav__level-3 > li > a {\n      --indent: var(--spacing-m);\n\n      @media (--global-nav-up) {\n        --indent: var(--spacing-l);\n      }\n    }\n\n    & :is([aria-current=\"page\"], .is-active > a) {\n      background-color: var(\n        --nav-active-background,\n        var(--background, var(--colour-background-alt))\n      );\n      color: var(--nav-active-foreground, inherit);\n    }\n\n    & li > ul {\n      transition:\n        transform 0.2s var(--ease),\n        opacity 0.8s var(--ease);\n      transform-origin: top;\n      will-change: block-size;\n\n      &[inert] {\n        block-size: 0;\n        opacity: 0;\n        transform: scaleY(0);\n        transition:\n          transform 0.8s var(--ease),\n          opacity 0.2s var(--ease);\n      }\n    }\n\n    & li:is(.mx-nav__has-subnav, :has(> ul)) > a {\n      padding-inline-end: var(--spacing-l);\n    }\n  }\n}\n","/**\n * Dropdown Navigation\n */\n\n@layer design-system.components {\n  .mx-nav--dropdown {\n    --nav-active-underline: none;\n\n    margin-block: var(--spacing-m);\n\n    @media (--global-nav-up) {\n      margin-block: 0;\n    }\n\n    & li {\n      margin: 0;\n\n      &:is(.mx-nav__has-subnav, :has(> ul)) {\n        position: relative;\n\n        & > a {\n          --toggle-gap: var(--spacing-l);\n        }\n      }\n    }\n\n    & a {\n      display: block;\n\n      &[aria-expanded=\"true\"] {\n        @media (--global-nav-up) {\n          background-color: var(\n            --nav-expanded-background,\n            var(--background, var(--colour-background-alt))\n          );\n          color: var(--nav-expanded-foreground, inherit);\n\n          & + .nav__toggle {\n            color: var(--nav-expanded-foreground, inherit);\n          }\n        }\n      }\n\n      &:focus-visible {\n        outline-offset: -2px;\n      }\n    }\n\n    & li > ul {\n      transition:\n        0.2s opacity var(--ease),\n        0.2s visibility var(--ease);\n\n      &[inert] {\n        block-size: 0;\n        opacity: 0;\n        visibility: hidden;\n        transition:\n          0.2s opacity var(--ease),\n          0.2s visibility var(--ease);\n\n        @media (--global-nav-up) {\n          block-size: auto;\n        }\n      }\n    }\n\n    & .mx-nav__level-1 {\n      margin: 0;\n      overflow: hidden;\n\n      @media (--global-nav-up) {\n        overflow: visible;\n        flex-flow: row;\n        align-items: center;\n        justify-content: flex-start;\n      }\n\n      & > li {\n        border-block-start: var(--line-width, 1px) solid\n          var(--line-colour, var(--colour-border));\n\n        @media (--global-nav-up) {\n          border-block-start: 0;\n        }\n\n        & > a:where(:not(.button)) {\n          padding-block: var(--item-spacing, var(--spacing-xxs));\n          padding-inline-end: var(\n            --toggle-gap,\n            var(--item-spacing, var(--spacing-xxs))\n          );\n\n          @media (--global-nav-up) {\n            padding-inline-start: var(--item-spacing, var(--spacing-xxs));\n          }\n        }\n      }\n    }\n\n    & .mx-nav__level-2 {\n      display: block;\n      position: relative;\n      inset-inline-start: 0;\n      inline-size: 100%;\n      margin: 0;\n\n      @media (--global-nav-up) {\n        position: absolute;\n        inline-size: var(--dropdown-width, 270px);\n        border-radius: var(--border-radius);\n        background-color: var(\n          --nav-expanded-background,\n          var(--background, var(--colour-background-alt))\n        );\n        color: var(--nav-expanded-foreground, inherit);\n\n        & .mx-nav__toggle::before {\n          transform: rotate(-90deg);\n        }\n      }\n\n      & > li {\n        @media (--global-nav-down) {\n          border-block-start: var(--line-width, 1px) solid\n            var(--line-colour, var(--colour-border));\n        }\n\n        & > a {\n          &:where(:not(.button)) {\n            padding: var(--item-spacing, var(--spacing-xxs));\n\n            @media (--global-nav-down) {\n              padding-inline-start: var(--spacing-l);\n            }\n          }\n        }\n      }\n    }\n\n    & .mx-nav--reverse .nav__level-2 {\n      @media (--global-nav-up) {\n        inset-inline: auto 0;\n\n        & .mx-nav__toggle::before {\n          transform: rotate(90deg);\n        }\n      }\n    }\n\n    & .mx-nav__separator {\n      border-block-start: var(--line-width, 1px) solid\n        var(--line-colour, var(--colour-border));\n    }\n  }\n}\n","/**\n * Dropdown Navigation - Mega Nav\n */\n\n@layer design-system.components {\n  .mx-nav--mega-nav {\n    @media (--global-nav-down) {\n      max-block-size: 100%;\n      overflow: auto;\n    }\n\n    & .mx-nav__level-2 ul {\n      display: block;\n      position: relative;\n      padding-inline-start: var(--spacing-l);\n      border-block-start: 1px solid var(--border-colour);\n      inline-size: 100%;\n\n      @media (--global-nav-up) {\n        position: absolute;\n        inset-inline-start: var(--dropdown-width, 270px);\n        inset-block-start: 0;\n        inline-size: var(--dropdown-width, 270px);\n        min-block-size: 100%;\n        padding-inline-start: 0;\n        border-block-start: 0;\n        border-radius: 0 var(--border-radius) var(--border-radius) 0;\n        background-color: var(\n          --expanded-background,\n          var(--colour-background-alt)\n        );\n        color: var(--expanded-foreground, inherit);\n      }\n\n      & > li > a:where(:not(.mx-button)) {\n        padding: var(--item-spacing, var(--spacing-xxs));\n\n        @media (--global-nav-down) {\n          padding-inline-start: var(--spacing-l);\n        }\n      }\n    }\n\n    & .mx-nav--reverse .mx-nav__level-2 ul {\n      @media (--global-nav-up) {\n        inset-inline-start: calc(var(--dropdown-width, 270px) * -1);\n        border-radius: var(--border-radius) 0 0 var(--border-radius);\n      }\n    }\n  }\n}\n"]} */
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@pnx-mixtape/mxds",
3
3
  "description": "The Mixtape Design System",
4
- "version": "0.0.10",
4
+ "version": "0.0.12",
5
5
  "scripts": {
6
6
  "dev": "concurrently -k -n \"VITE,STORYBOOK\" -c \"#636cff,#ff4785\" \"npm run dev-vite\" \"npm run dev-storybook\"",
7
7
  "build": "concurrently -n \"VITE,STORYBOOK\" -c \"#636cff,#ff4785\" \"npm run build-vite\" \"npm run build-storybook\"",
@@ -32,7 +32,7 @@
32
32
  "dependencies": {
33
33
  "@floating-ui/dom": "^1.6.5",
34
34
  "@oddbird/popover-polyfill": "^0.4.3",
35
- "@pnx-mixtape/ids-shape": "^0.0.16",
35
+ "@pnx-mixtape/ids-shape": "^0.0.18",
36
36
  "classnames": "^2.5.1",
37
37
  "js-cookie": "^3.0.5",
38
38
  "react": "^18.3.1",
@@ -5,7 +5,7 @@
5
5
  @layer design-system.atoms {
6
6
  .mx-button {
7
7
  --outline-offset: 1px;
8
- --outline-width: 4px;
8
+ --outline-width: 2px;
9
9
 
10
10
  display: inline-flex;
11
11
  inline-size: fit-content;
@@ -4,7 +4,7 @@
4
4
  type ? baseClass~'--'~type : null,
5
5
  align ? baseClass~'--'~align : null,
6
6
  ] %}
7
- {% set attributes = attributes ?? create_attribute().addClass(classes) %}
7
+ {% set attributes = (attributes ?? create_attribute()).addClass(classes) %}
8
8
 
9
9
  <figure{{ attributes }}>
10
10
  {{ item }}
@@ -1,4 +1,4 @@
1
- {% set attributes = attributes ?? create_attribute().addClass("mx-video") %}
1
+ {% set attributes = (attributes ?? create_attribute()).addClass("mx-video") %}
2
2
  <figure{{ attributes }}>
3
3
  <iframe
4
4
  src="{{ src }}"
@@ -0,0 +1 @@
1
+ import "./Elements/Filters"
@@ -40,6 +40,10 @@
40
40
  }
41
41
  }
42
42
  }
43
+
44
+ &:focus-visible {
45
+ outline-offset: -2px;
46
+ }
43
47
  }
44
48
 
45
49
  & li > ul {
@@ -1,25 +1,27 @@
1
1
  import { Meta, StoryObj } from "@storybook/html"
2
2
  import Component from "./header.twig"
3
- import StackedComponent from "./header-stacked.twig"
4
- import Icon from "../../Atom/Icon/icon.twig"
5
- import Logo from "../Header/twig/logo.twig"
6
- import SearchForm from "../../Form/Search/search-form.twig"
7
- import InputText from "../../Form/TextInput/input-text.twig"
8
- import Button from "../../Atom/Button/button.twig"
9
- import Navigation from "../../Component/Navigation/navigation.twig"
10
3
  import "./_header.css"
11
4
  import "./_toggles.css"
12
5
  import "./Elements/GlobalToggle"
13
- import "../../Component/Navigation/Elements/Navigation"
14
- import {
15
- ButtonTypes,
16
- Header as HeaderType,
17
- InputTypeTypes,
18
- } from "@pnx-mixtape/ids-shape"
6
+ import { ButtonTypes, Header as HeaderType } from "@pnx-mixtape/ids-shape"
19
7
  import { Page } from "../../../.storybook/decorators"
20
8
  import { Icons } from "../../enums"
21
9
 
22
- const meta: Meta<HeaderType> = {
10
+ // Deps.
11
+ import Icon from "../../Atom/Icon/icon.twig"
12
+ import Logo from "../Header/twig/logo.twig"
13
+ import Button from "../../Atom/Button/button.twig"
14
+ import Navigation from "../../Component/Navigation/navigation.twig"
15
+ // js.
16
+ import "../../Component/Navigation/Elements/Navigation"
17
+ // css.
18
+ import "../../Component/Navigation/navigation.css"
19
+
20
+ type MxHeaderType = HeaderType & {
21
+ stacked: boolean
22
+ }
23
+
24
+ const meta: Meta<MxHeaderType> = {
23
25
  tags: ["autodocs", "ids-mvp"],
24
26
  component: Component,
25
27
  args: {
@@ -64,6 +66,7 @@ const meta: Meta<HeaderType> = {
64
66
  deepControls: { enabled: true },
65
67
  },
66
68
  argTypes: {
69
+ stacked: { control: "boolean" },
67
70
  title: { control: "text" },
68
71
  description: { control: "text" },
69
72
  // @ts-expect-error The controls follow the shape
@@ -75,7 +78,7 @@ const meta: Meta<HeaderType> = {
75
78
  }
76
79
 
77
80
  export default meta
78
- type Story = StoryObj<HeaderType>
81
+ type Story = StoryObj<MxHeaderType>
79
82
 
80
83
  export const Header: Story = {}
81
84
 
@@ -88,24 +91,7 @@ export const WithTitle: Story = {
88
91
 
89
92
  export const Search: Story = {
90
93
  args: {
91
- search: SearchForm({
92
- action: "#search",
93
- input: InputText({
94
- id: "search-keyword",
95
- type: InputTypeTypes.SEARCH,
96
- name: "search-form",
97
- placeholder: "Keywords...",
98
- label: "Search by keywords",
99
- }),
100
- button: Button({
101
- title: "Search",
102
- iconOnly: true,
103
- iconStart: Icon({
104
- icon: Icons.SEARCH,
105
- }),
106
- as: ButtonTypes.SUBMIT,
107
- }),
108
- }),
94
+ search: "#search",
109
95
  },
110
96
  }
111
97
 
@@ -125,24 +111,8 @@ export const Controls: Story = {
125
111
 
126
112
  export const Stacked: Story = {
127
113
  args: {
128
- search: SearchForm({
129
- action: "#search",
130
- input: InputText({
131
- id: "search-keyword",
132
- type: InputTypeTypes.SEARCH,
133
- name: "search-form",
134
- placeholder: "Keywords...",
135
- label: "Search by keywords",
136
- }),
137
- button: Button({
138
- title: "Search",
139
- iconOnly: true,
140
- iconStart: Icon({
141
- icon: Icons.SEARCH,
142
- }),
143
- as: ButtonTypes.SUBMIT,
144
- }),
145
- }),
114
+ stacked: true,
115
+ search: "#search",
146
116
  controls: [
147
117
  Button({
148
118
  as: ButtonTypes.BUTTON,
@@ -248,5 +218,4 @@ export const Stacked: Story = {
248
218
  ],
249
219
  }),
250
220
  },
251
- render: args => `${StackedComponent(args)}`,
252
221
  }
@@ -2,7 +2,7 @@
2
2
 
3
3
  exports[`Layout/Header Controls smoke-test 1`] = `
4
4
  <div class="mx-page">
5
- <header class="mx-header mx-section mx-section--s">
5
+ <header class="mx-header mx-section__full mx-page mx-section--s">
6
6
  <div class="mx-header__inner">
7
7
  <div class="mx-header__brand">
8
8
  <a class="mx-logo"
@@ -77,7 +77,7 @@ exports[`Layout/Header Controls smoke-test 1`] = `
77
77
 
78
78
  exports[`Layout/Header Header smoke-test 1`] = `
79
79
  <div class="mx-page">
80
- <header class="mx-header mx-section mx-section--s">
80
+ <header class="mx-header mx-section__full mx-page mx-section--s">
81
81
  <div class="mx-header__inner">
82
82
  <div class="mx-header__brand">
83
83
  <a class="mx-logo"
@@ -143,7 +143,7 @@ exports[`Layout/Header Header smoke-test 1`] = `
143
143
 
144
144
  exports[`Layout/Header Search smoke-test 1`] = `
145
145
  <div class="mx-page">
146
- <header class="mx-header mx-section mx-section--s">
146
+ <header class="mx-header mx-section__full mx-page mx-section--s">
147
147
  <div class="mx-header__inner">
148
148
  <div class="mx-header__brand">
149
149
  <a class="mx-logo"
@@ -228,7 +228,7 @@ exports[`Layout/Header Search smoke-test 1`] = `
228
228
  <button class="mx-button mx-button--icon-only"
229
229
  type="submit"
230
230
  >
231
- <span class="mx-icon mx-icon--search ">
231
+ <span class="mx-icon mx-icon--search">
232
232
  </span>
233
233
  <span class="sr-only">
234
234
  Search
@@ -244,7 +244,7 @@ exports[`Layout/Header Search smoke-test 1`] = `
244
244
 
245
245
  exports[`Layout/Header Stacked smoke-test 1`] = `
246
246
  <div class="mx-page">
247
- <header class="mx-header mx-section mx-section--s">
247
+ <header class="mx-header mx-section__full mx-page mx-section--s">
248
248
  <div class="mx-header__inner">
249
249
  <div class="mx-header__brand">
250
250
  <a class="mx-logo"
@@ -273,38 +273,40 @@ exports[`Layout/Header Stacked smoke-test 1`] = `
273
273
  </button>
274
274
  </mx-global-toggle>
275
275
  </div>
276
- <div id="unique-0"
277
- class="mx-header__search"
278
- aria-label="Search"
279
- role="region"
280
- >
281
- <form class="mx-form mx-form--inline-button"
282
- role="search"
283
- action="#search"
276
+ <div class="mx-header__main">
277
+ <div id="unique-0"
278
+ class="mx-header__search"
279
+ aria-label="Search"
280
+ role="region"
284
281
  >
285
- <input class="mx-input__text "
286
- id="search-keyword"
287
- name="search-form"
288
- type="search"
289
- value
290
- aria-label="Search by keywords"
291
- placeholder="Keywords..."
292
- >
293
- <button class="mx-button mx-button--icon-only"
294
- type="submit"
282
+ <form class="mx-form mx-form--inline-button"
283
+ role="search"
284
+ action="#search"
295
285
  >
296
- <span class="mx-icon mx-icon--search ">
297
- </span>
298
- <span class="sr-only">
299
- Search
300
- </span>
301
- </button>
302
- </form>
286
+ <input class="mx-input__text "
287
+ id="search-keyword"
288
+ name="search-form"
289
+ type="search"
290
+ value
291
+ aria-label="Search by keywords"
292
+ placeholder="Keywords..."
293
+ >
294
+ <button class="mx-button mx-button--icon-only"
295
+ type="submit"
296
+ >
297
+ <span class="mx-icon mx-icon--search">
298
+ </span>
299
+ <span class="sr-only">
300
+ Search
301
+ </span>
302
+ </button>
303
+ </form>
304
+ </div>
303
305
  </div>
304
306
  </div>
305
307
  </header>
306
308
  <div id="unique-1"
307
- class="mx-header__nav mx-section"
309
+ class="mx-header__nav mx-section__full mx-page"
308
310
  aria-label="Primary navigation"
309
311
  role="region"
310
312
  >
@@ -450,7 +452,7 @@ exports[`Layout/Header Stacked smoke-test 1`] = `
450
452
 
451
453
  exports[`Layout/Header WithTitle smoke-test 1`] = `
452
454
  <div class="mx-page">
453
- <header class="mx-header mx-section mx-section--s">
455
+ <header class="mx-header mx-section__full mx-page mx-section--s">
454
456
  <div class="mx-header__inner">
455
457
  <div class="mx-header__brand">
456
458
  <a class="mx-logo"
@@ -7,6 +7,7 @@
7
7
  position: relative;
8
8
  display: grid;
9
9
  grid-template-columns: 1fr auto;
10
+ align-items: center;
10
11
  }
11
12
 
12
13
  .mx-header__brand {
@@ -51,6 +52,7 @@
51
52
 
52
53
  .mx-header__search {
53
54
  position: absolute;
55
+ z-index: 2;
54
56
  inset-block-start: 2px;
55
57
  inset-inline-start: 0;
56
58
  inline-size: 100%;
@@ -73,7 +75,9 @@
73
75
  }
74
76
 
75
77
  & input {
76
- max-inline-size: 150px;
78
+ @media (--global-nav-up) {
79
+ max-inline-size: 150px;
80
+ }
77
81
  }
78
82
  }
79
83
 
@@ -81,11 +85,19 @@
81
85
  * Primary Header Stacked
82
86
  */
83
87
  .mx-header__nav-inner {
84
- display: flex;
88
+ @media (--global-nav-up) {
89
+ display: flex;
90
+ }
85
91
  }
86
92
 
87
93
  .mx-header__nav-right {
88
- margin-inline-start: auto;
94
+ margin-block: var(--spacing-m);
95
+
96
+ @media (--global-nav-up) {
97
+ margin-inline-start: auto;
98
+ margin-block: 0;
99
+ padding-block: 4px;
100
+ }
89
101
  }
90
102
  }
91
103
 
@@ -1,7 +1,8 @@
1
1
  {% set baseClass = 'mx-header' %}
2
2
  {% set classes = [
3
3
  baseClass,
4
- 'mx-section',
4
+ 'mx-section__full',
5
+ 'mx-page',
5
6
  'mx-section--s',
6
7
  ] %}
7
8
  {% set attributes = (attributes ?? create_attribute()).addClass(classes) %}
@@ -29,19 +30,41 @@
29
30
  </div>
30
31
  {% endif %}
31
32
  <div class="mx-header__main">
32
- {% if navigation is not empty %}
33
+ {% if navigation is not empty and not stacked %}
33
34
  <div id="primary-nav" class="mx-header__nav global-nav-up-only" aria-label="Primary navigation">
34
35
  {{ navigation }}
35
36
  </div>
36
37
  {% endif %}
37
38
  {% if search is not empty %}
38
39
  <div id="primary-search" class="mx-header__search global-nav-up-only" aria-label="Search">
39
- {{ search }}
40
+ <form class="mx-form mx-form--inline-button" role="search" action="{{ search }}">
41
+ <input class="mx-input__text " id="search-keyword" name="search-form" type="search" value="" aria-label="Search by keywords" placeholder="Keywords..." />
42
+ <button class="mx-button mx-button--icon-only" type="submit">
43
+ <span class="mx-icon mx-icon--search"></span>
44
+ <span class="sr-only">Search</span>
45
+ </button>
46
+ </form>
40
47
  </div>
41
48
  {% endif %}
42
- {% for control in controls %}
43
- {{ controls }}
44
- {% endfor %}
49
+ {% if not stacked %}
50
+ {% for control in controls %}
51
+ {{ control }}
52
+ {% endfor %}
53
+ {% endif %}
45
54
  </div>
46
55
  </div>
47
56
  </header>
57
+ {% if stacked and (navigation is not empty or controls is not empty) %}
58
+ <div id="primary-nav" class="mx-header__nav mx-section__full mx-page global-nav-up-only" aria-label="Primary navigation">
59
+ <div class="mx-header__nav-inner">
60
+ {{ navigation }}
61
+ {% if controls is not empty %}
62
+ <div class="mx-header__nav-right">
63
+ {% for control in controls %}
64
+ {{ control }}
65
+ {% endfor %}
66
+ </div>
67
+ {% endif %}
68
+ </div>
69
+ </div>
70
+ {% endif %}
@@ -1,2 +0,0 @@
1
-
2
- //# sourceMappingURL=steps.entry.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"steps.entry.js","sources":[],"sourcesContent":[],"names":[],"mappings":""}
File without changes
@@ -1,51 +0,0 @@
1
- {% set baseClass = 'mx-header' %}
2
- {% set classes = [
3
- baseClass,
4
- 'mx-section',
5
- 'mx-section--s',
6
- ] %}
7
- {% set attributes = (attributes ?? create_attribute()).addClass(classes) %}
8
- <header{{ attributes }}>
9
- <div class="mx-header__inner">
10
- {% if logo is not empty or title is not empty or description is not empty %}
11
- <div class="mx-header__brand">
12
- <a class="mx-logo" href="/">{{ logo }}</a>
13
- {% if title is not empty or description is not empty %}
14
- <div class="mx-header__name">
15
- {% if title is not empty %}<strong>{{ title }}</strong>{% endif %}
16
- {{ description }}
17
- </div>
18
- {% endif %}
19
- </div>
20
- {% endif %}
21
- {% if navigation is not empty or search is not empty %}
22
- <div class="mx-header__toggles">
23
- {% if search is not empty %}
24
- <mx-global-toggle hideMenu><button aria-controls="primary-search" class="mx-button mx-button--icon-only mx-icon mx-icon--search" disabled>Open Search</button></mx-global-toggle>
25
- {% endif %}
26
- {% if navigation is not empty %}
27
- <mx-global-toggle><button aria-controls="primary-nav" class="mx-button mx-button--dark mx-button--icon-only mx-icon mx-icon--menu" disabled>Open Menu</button></mx-global-toggle>
28
- {% endif %}
29
- </div>
30
- {% endif %}
31
- {% if search is not empty %}
32
- <div id="primary-search" class="mx-header__search global-nav-up-only" aria-label="Search">
33
- {{ search }}
34
- </div>
35
- {% endif %}
36
- </div>
37
- </header>
38
- {% if navigation is not empty or controls is not empty %}
39
- <div id="primary-nav" class="mx-header__nav mx-section global-nav-up-only" aria-label="Primary navigation">
40
- <div class="mx-header__nav-inner">
41
- {{ navigation }}
42
- {% if controls is not empty %}
43
- <div class="mx-header__nav-right">
44
- {% for control in controls %}
45
- {{ controls }}
46
- {% endfor %}
47
- </div>
48
- {% endif %}
49
- </div>
50
- </div>
51
- {% endif %}