@pnx-mixtape/mxds 0.0.7 → 0.0.8

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.
Files changed (79) hide show
  1. package/dist/build/accordion.css +108 -0
  2. package/dist/build/accordion.entry.js +139 -0
  3. package/dist/build/accordion.entry.js.map +1 -0
  4. package/dist/build/base.css +996 -0
  5. package/dist/build/breadcrumb.css +51 -0
  6. package/dist/build/button.css +132 -0
  7. package/dist/build/callout.css +11 -0
  8. package/dist/build/card.css +149 -0
  9. package/dist/build/chunks/disclosure-widget-CQLPJ8Ta.js +124 -0
  10. package/dist/build/chunks/disclosure-widget-CQLPJ8Ta.js.map +1 -0
  11. package/dist/build/chunks/drop-menu.entry-BC6x9vst.js +132 -0
  12. package/dist/build/chunks/drop-menu.entry-BC6x9vst.js.map +1 -0
  13. package/dist/build/chunks/keyboard-C73DHu0c.js +101 -0
  14. package/dist/build/chunks/keyboard-C73DHu0c.js.map +1 -0
  15. package/dist/build/chunks/polyfills-CJ5uTmUJ.js +749 -0
  16. package/dist/build/chunks/polyfills-CJ5uTmUJ.js.map +1 -0
  17. package/dist/build/chunks/popover-wbPSyFRj.js +654 -0
  18. package/dist/build/chunks/popover-wbPSyFRj.js.map +1 -0
  19. package/dist/build/chunks/utilities-B4YZb689.js +243 -0
  20. package/dist/build/chunks/utilities-B4YZb689.js.map +1 -0
  21. package/dist/build/constants.css +120 -0
  22. package/dist/build/container-grid.css +208 -0
  23. package/dist/build/content-block.css +36 -0
  24. package/dist/build/dialog.css +98 -0
  25. package/dist/build/dialog.entry.js +113 -0
  26. package/dist/build/dialog.entry.js.map +1 -0
  27. package/dist/build/drop-menu.css +78 -0
  28. package/dist/build/drop-menu.entry.js +2 -0
  29. package/dist/build/drop-menu.entry.js.map +1 -0
  30. package/dist/build/drupal.css +74 -0
  31. package/dist/build/footer.css +151 -0
  32. package/dist/build/form.css +517 -0
  33. package/dist/build/global-alert.css +60 -0
  34. package/dist/build/global-alert.entry.js +68 -0
  35. package/dist/build/global-alert.entry.js.map +1 -0
  36. package/dist/build/grid.css +200 -0
  37. package/dist/build/header.css +138 -0
  38. package/dist/build/header.entry.js +103 -0
  39. package/dist/build/header.entry.js.map +1 -0
  40. package/dist/build/hero-banner.css +62 -0
  41. package/dist/build/icon.css +399 -0
  42. package/dist/build/in-page-alert.css +94 -0
  43. package/dist/build/in-page-navigation.css +17 -0
  44. package/dist/build/in-page-navigation.entry.js +89 -0
  45. package/dist/build/in-page-navigation.entry.js.map +1 -0
  46. package/dist/build/link-list.css +72 -0
  47. package/dist/build/list-item.css +114 -0
  48. package/dist/build/masthead.css +30 -0
  49. package/dist/build/navigation.css +392 -0
  50. package/dist/build/navigation.entry.js +124 -0
  51. package/dist/build/navigation.entry.js.map +1 -0
  52. package/dist/build/page.css +80 -0
  53. package/dist/build/pagination.css +130 -0
  54. package/dist/build/section.css +163 -0
  55. package/dist/build/side-navigation.css +88 -0
  56. package/dist/build/sidebar.css +105 -0
  57. package/dist/build/social-links.css +20 -0
  58. package/dist/build/steps.css +118 -0
  59. package/dist/build/steps.entry.js +2 -0
  60. package/dist/build/steps.entry.js.map +1 -0
  61. package/dist/build/sticky.css +47 -0
  62. package/dist/build/sticky.entry.js +60 -0
  63. package/dist/build/sticky.entry.js.map +1 -0
  64. package/dist/build/tabs.css +109 -0
  65. package/dist/build/tabs.entry.js +202 -0
  66. package/dist/build/tabs.entry.js.map +1 -0
  67. package/dist/build/tag.css +67 -0
  68. package/dist/build/tiles.css +61 -0
  69. package/dist/build/utilities.css +178 -0
  70. package/package.json +2 -2
  71. package/src/Component/Card/Card.tsx +7 -7
  72. package/src/Component/Card/__snapshots__/Card.stories.ts.snap +1 -1
  73. package/src/Component/Card/__snapshots__/Card.stories.tsx.snap +5 -5
  74. package/src/Component/Card/card.css +3 -3
  75. package/src/Component/ContentBlock/ContentBlock.tsx +1 -1
  76. package/src/Component/ContentBlock/__snapshots__/ContentBlock.stories.tsx.snap +1 -1
  77. package/src/Component/ListItem/__snapshots__/ListItem.stories.ts.snap +1 -1
  78. package/src/Component/ListItem/list-item.css +1 -1
  79. package/src/Layout/Footer/Footer.stories.ts +1 -1
@@ -0,0 +1,517 @@
1
+ /**
2
+ * Form
3
+ */
4
+
5
+ @layer design-system.atoms {
6
+ .mx-form-item {
7
+ max-inline-size: var(--container-max-width);
8
+ }
9
+
10
+ .mx-form-item--inline {
11
+ display: flex;
12
+ align-items: flex-start;
13
+ }
14
+
15
+ /**
16
+ * Form actions.
17
+ */
18
+ .mx-form-actions {
19
+ display: flex;
20
+ flex-wrap: wrap;
21
+ align-items: center;
22
+ gap: var(--spacing-s);
23
+ }
24
+ }
25
+
26
+ /**
27
+ * Text Input
28
+ */
29
+
30
+ @layer design-system.atoms {
31
+ :is(.mx-input__text, .mx-input__select, .mx-input__textarea) {
32
+ box-shadow: none;
33
+ font: inherit;
34
+ letter-spacing: inherit;
35
+ word-spacing: inherit;
36
+ max-inline-size: 100%;
37
+ padding-block: calc(
38
+ var(--form-spacing, var(--spacing-s)) - (2px * 2)
39
+ );
40
+ padding-block: calc(
41
+ var(--form-spacing, var(--spacing-s)) - (var(--line-width, 2px) * 2)
42
+ );
43
+ padding-inline: var(--form-spacing, var(--spacing-s));
44
+ border: 2px solid
45
+ var(--line-colour, var(--line-colour, var(--colour-border)));
46
+ border: var(--line-width, 2px) solid
47
+ var(--line-colour, var(--line-colour, var(--colour-border)));
48
+ border-radius: var(--border-radius);
49
+ background-color: var(--colour-background);
50
+ color: var(--form-colour, var(--foreground, var(--colour-foreground)));
51
+ line-height: var(--line-height-ui);
52
+ block-size: var(--form-element-height, var(--spacing-xxl));
53
+ }
54
+
55
+ :is(.mx-input__text, .mx-input__select, .mx-input__textarea):focus-visible {
56
+ outline-offset: calc(2px * -1);
57
+ outline-offset: calc(var(--line-width, 2px) * -1);
58
+ }
59
+
60
+ :is(.mx-input__text, .mx-input__select, .mx-input__textarea)::-moz-placeholder {
61
+ color: var(--placeholder-colour, var(--colour-foreground-alt));
62
+ opacity: 1;
63
+ }
64
+
65
+ :is(.mx-input__text, .mx-input__select, .mx-input__textarea)::placeholder {
66
+ color: var(--placeholder-colour, var(--colour-foreground-alt));
67
+ opacity: 1;
68
+ }
69
+
70
+ [disabled]:is(.mx-input__text, .mx-input__select, .mx-input__textarea) {
71
+ opacity: 0.6;
72
+ opacity: var(--disabled-opacity, 0.6);
73
+ cursor: not-allowed;
74
+ }
75
+
76
+ .error:is(.mx-input__text, .mx-input__select, .mx-input__textarea) {
77
+ border-color: var(--error-foreground, var(--colour-error-foreground));
78
+ }
79
+
80
+ .success:is(.mx-input__text, .mx-input__select, .mx-input__textarea) {
81
+ border-color: var(--success-foreground, var(--colour-success-foreground));
82
+ }
83
+
84
+ .mx-input--small {
85
+ min-inline-size: 0;
86
+ border-width: 1px;
87
+ }
88
+
89
+ .mx-input--wide {
90
+ inline-size: 100%;
91
+ }
92
+ }
93
+
94
+ /**
95
+ * Input Divider
96
+ */
97
+
98
+ @layer design-system.atoms {
99
+ .mx-input__divider {
100
+ padding: var(--form-spacing, var(--spacing-s));
101
+ line-height: var(--line-height-ui);
102
+ }
103
+ }
104
+
105
+ /**
106
+ * Text Input with Icon
107
+ */
108
+
109
+ @layer design-system.atoms {
110
+ .mx-input--icon {
111
+ display: inline-block;
112
+ max-inline-size: 100%;
113
+ min-inline-size: 100%;
114
+ border-radius: var(--border-radius);
115
+ background-color: var(--background, var(--colour-background));
116
+ position: relative;
117
+ }
118
+
119
+ .mx-input--icon::before {
120
+ position: absolute;
121
+ block-size: 100%;
122
+ inset-block-start: 0;
123
+ inset-inline-start: var(--form-spacing, var(--spacing-s));
124
+ }
125
+
126
+ .mx-input--icon .mx-input__text {
127
+ inline-size: 100%;
128
+ padding-inline-start: calc(var(--form-spacing, var(--spacing-s)) * 2.5);
129
+ background-color: transparent;
130
+ }
131
+
132
+ .mx-input--icon:has(.error)::before {
133
+ background-color: var(--error-foreground, var(--colour-error-foreground));
134
+ }
135
+
136
+ .mx-input--icon:has(.success)::before {
137
+ background-color: var(
138
+ --success-foreground,
139
+ var(--colour-success-foreground)
140
+ );
141
+ }
142
+ }
143
+
144
+ /**
145
+ * Text Input with Inline Button
146
+ */
147
+
148
+ @layer design-system.atoms {
149
+ .mx-form--inline-button {
150
+ position: relative;
151
+ display: flex;
152
+ max-inline-size: 100%;
153
+ min-inline-size: 100%;
154
+ border-radius: var(--border-radius);
155
+ background-color: var(--background, var(--colour-background));
156
+ border: 2px solid
157
+ var(--line-colour, var(--line-colour, var(--colour-border)));
158
+ border: var(--line-width, 2px) solid
159
+ var(--line-colour, var(--line-colour, var(--colour-border)));
160
+ }
161
+
162
+ .mx-form--inline-button:has(.mx-input__text:focus-visible) {
163
+ --outline-size: max(0.125rem, 0.15em);
164
+
165
+ outline: max(0.125rem, 0.15em)
166
+ solid currentcolor;
167
+
168
+ outline: var(--outline-width, var(--outline-size))
169
+ var(--outline-style, solid) var(--outline-color, currentcolor);
170
+ outline-offset: calc(2px * -1);
171
+ outline-offset: calc(var(--line-width, 2px) * -1);
172
+ }
173
+
174
+ .mx-form--inline-button .mx-input__text {
175
+ background-color: transparent;
176
+ border: 0;
177
+ flex-grow: 1;
178
+ }
179
+
180
+ .mx-form--inline-button .mx-input__text:focus-visible {
181
+ outline: none;
182
+ }
183
+
184
+ .mx-form--inline-button .mx-button {
185
+ margin: var(--spacing-xxxxs);
186
+ flex-shrink: 0;
187
+ border: 0;
188
+ border-radius: 3px;
189
+ block-size: calc(
190
+ var(--form-element-height, var(--spacing-xxl)) - var(--spacing-xxxs)
191
+ );
192
+ }
193
+ }
194
+
195
+ /**
196
+ * Label
197
+ */
198
+
199
+ @layer design-system.atoms {
200
+ :is(.mx-label, .mx-legend) {
201
+ display: block;
202
+ margin-block-end: var(--spacing-xxxs);
203
+ font-size: var(--font-size);
204
+ color: var(--label-foreground, var(--foreground, var(--colour-foreground)));
205
+ }
206
+
207
+ .mx-label--inline:is(.mx-label, .mx-legend) {
208
+ display: inline-block;
209
+ margin-block-end: 0;
210
+ margin-inline-end: var(--spacing-xxs);
211
+ }
212
+
213
+ .mx-checkbox [type="checkbox"] {
214
+ box-shadow: none;
215
+ -webkit-appearance: none;
216
+ -moz-appearance: none;
217
+ appearance: none;
218
+ inline-size: var(--control-size, var(--spacing-m));
219
+ block-size: var(--control-size, var(--spacing-m));
220
+ background-color: var(--background, var(--colour-background));
221
+ border: 2px solid
222
+ var(--line-colour, var(--colour-border));
223
+ border: var(--line-width, 2px) solid
224
+ var(--line-colour, var(--colour-border));
225
+ border-radius: var(--border-radius);
226
+ }
227
+
228
+ @media (pointer: coarse) {
229
+
230
+ .mx-checkbox [type="checkbox"] {
231
+ --control-size: 2rem;
232
+ }
233
+ }
234
+
235
+ .mx-checkbox [type="checkbox"]:checked {
236
+ background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16'%3E%3Cpath d='M5.6 9.6L2.4 6.4 0 8.8l5.6 5.6L16 4l-2.4-2.4z'/%3E%3C/svg%3E");
237
+ background-size: 0.75rem;
238
+ background-position: center;
239
+ }
240
+
241
+ .mx-checkbox [type="checkbox"]:focus-visible {
242
+ outline: 2px auto var(--outline-color);
243
+ outline: var(--line-width, 2px) auto var(--outline-color);
244
+ outline-offset: 0;
245
+ }
246
+ .mx-checkbox [type="checkbox"][disabled]::after {
247
+ opacity: 0.6;
248
+ opacity: var(--disabled-opacity, 0.6);
249
+ cursor: not-allowed;
250
+ content: "";
251
+ display: block;
252
+ inline-size: 100%;
253
+ block-size: 100%;
254
+ border-radius: var(--border-radius);
255
+ }
256
+
257
+ .mx-checkbox [type="checkbox"][disabled] + label {
258
+ opacity: 0.6;
259
+ opacity: var(--disabled-opacity, 0.6);
260
+ cursor: not-allowed;
261
+ }
262
+
263
+ .mx-checkbox .error[type="checkbox"] {
264
+ border-color: var(--error-foreground, var(--colour-error-foreground));
265
+ }
266
+
267
+ .mx-checkbox .success[type="checkbox"] {
268
+ border-color: var(--success-foreground, var(--colour-success-foreground));
269
+ }
270
+ }
271
+
272
+ /**
273
+ * Checkboxes
274
+ */
275
+
276
+ /**
277
+ * Radios
278
+ */
279
+
280
+ @layer design-system.atoms {
281
+ .mx-radio [type="radio"] {
282
+ box-shadow: none;
283
+ -webkit-appearance: none;
284
+ -moz-appearance: none;
285
+ appearance: none;
286
+ display: flex;
287
+ inline-size: var(--control-size, var(--spacing-m));
288
+ block-size: var(--control-size, var(--spacing-m));
289
+ background-color: var(--background, var(--colour-background));
290
+ border: 2px solid
291
+ var(--line-colour, var(--colour-border));
292
+ border: var(--line-width, 2px) solid
293
+ var(--line-colour, var(--colour-border));
294
+ border-radius: 50%;
295
+ }
296
+
297
+ @media (pointer: coarse) {
298
+ .mx-radio [type="radio"] {
299
+ --control-size: 2rem;
300
+ }
301
+ }
302
+ .mx-radio [type="radio"]:checked::after {
303
+ content: "";
304
+ display: block;
305
+ inline-size: 0.5rem;
306
+ block-size: 0.5rem;
307
+ margin: auto;
308
+ border-radius: 50%;
309
+ background-color: var(--radio-colour, var(--colour-primary));
310
+ }
311
+
312
+ .mx-radio [type="radio"]:focus-visible {
313
+ outline: 2px auto var(--outline-color);
314
+ outline: var(--line-width, 2px) auto var(--outline-color);
315
+ outline-offset: 0;
316
+ }
317
+ .mx-radio [type="radio"][disabled]::after {
318
+ opacity: 0.6;
319
+ opacity: var(--disabled-opacity, 0.6);
320
+ cursor: not-allowed;
321
+ content: "";
322
+ display: block;
323
+ inline-size: 100%;
324
+ block-size: 100%;
325
+ border-radius: 50%;
326
+ }
327
+
328
+ .mx-radio [type="radio"][disabled] + label {
329
+ opacity: 0.6;
330
+ opacity: var(--disabled-opacity, 0.6);
331
+ cursor: not-allowed;
332
+ }
333
+
334
+ .mx-radio .error[type="radio"] {
335
+ border-color: var(--error-foreground, var(--colour-error-foreground));
336
+ }
337
+
338
+ .mx-radio .success[type="radio"] {
339
+ border-color: var(--success-foreground, var(--colour-success-foreground));
340
+ }
341
+
342
+ :is(.mx-radio, .mx-checkbox) {
343
+ margin-block-end: var(--spacing-xxxs);
344
+ display: flex;
345
+ align-items: center;
346
+ gap: var(--control-gap, var(--spacing-xxs));
347
+ }
348
+
349
+ :is(.mx-radio, .mx-checkbox):last-child {
350
+ margin-block-end: 0;
351
+ }
352
+
353
+ :is(.mx-radio, .mx-checkbox) label {
354
+ cursor: pointer;
355
+ margin: 0;
356
+ }
357
+
358
+ :is(.mx-radio, .mx-checkbox) input {
359
+ flex-shrink: 0;
360
+ }
361
+
362
+ .mx-form-item--inline:is(.mx-radio, .mx-checkbox) {
363
+ display: inline-flex;
364
+ margin-inline-end: var(--control-gap, var(--spacing-xxs));
365
+ }
366
+ }
367
+
368
+ /**
369
+ * Select
370
+ */
371
+
372
+ @layer design-system.atoms {
373
+ .mx-input__select {
374
+ -webkit-appearance: none;
375
+ -moz-appearance: none;
376
+ appearance: none;
377
+ cursor: pointer;
378
+ background-color: var(--background, var(--colour-background));
379
+ background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16'%3E%3Cpath d='M8 11.4L2.6 6 4 4.6l4 4 4-4L13.4 6z'/%3E%3C/svg%3E");
380
+ background-position: right var(--form-spacing, var(--spacing-s)) center;
381
+ padding-block: 0;
382
+ padding-inline-end: var(--spacing-xl);
383
+ }
384
+
385
+ .mx-input__select[multiple] {
386
+ block-size: auto;
387
+ background-image: none;
388
+ }
389
+
390
+ .mx-input__select.mx-input--small {
391
+ padding-inline-end: var(--spacing-m);
392
+ background-position: right var(--spacing-xs) center;
393
+ }
394
+
395
+ :is(.translated-rtl .mx-input__select, [dir="rtl"] .mx-input__select) {
396
+ background-position: left var(--spacing-s) center;
397
+ }
398
+
399
+ .mx-input--small:is(.translated-rtl .mx-input__select, [dir="rtl"] .mx-input__select) {
400
+ background-position: left var(--spacing-xs) center;
401
+ }
402
+ }
403
+
404
+ /**
405
+ * Textarea
406
+ */
407
+
408
+ @layer design-system.atoms {
409
+ .mx-input__textarea {
410
+ block-size: calc(4 * var(--form-element-height, var(--spacing-xxl)));
411
+ inline-size: 100%;
412
+ }
413
+ }
414
+
415
+ /**
416
+ * Fieldset
417
+ */
418
+
419
+ @layer design-system.atoms {
420
+ .mx-fieldset {
421
+ border: 2px solid
422
+ var(--line-colour, var(--colour-border));
423
+ border: var(--line-width, 2px) solid
424
+ var(--line-colour, var(--colour-border));
425
+ border-radius: var(--border-radius);
426
+ padding: var(--form-spacing, var(--spacing-s));
427
+ min-inline-size: 0;
428
+ }
429
+
430
+ .mx-fieldset legend {
431
+ padding-block: 0;
432
+ padding-inline: var(--form-spacing, var(--spacing-s));
433
+ }
434
+
435
+ .mx-fieldset:is(.mx-fieldset--plain, :has(.mx-checkbox, .mx-radio)) {
436
+ border: 0;
437
+ padding: 0;
438
+ }
439
+
440
+ .mx-fieldset:is(.mx-fieldset--plain, :has(.mx-checkbox, .mx-radio)) legend {
441
+ padding: 0;
442
+ }
443
+
444
+ .mx-fieldset.mx-fieldset--inline {
445
+ display: flex;
446
+ flex-wrap: wrap;
447
+ gap: var(--spacing-xxs);
448
+ }
449
+
450
+ .mx-fieldset.mx-fieldset--inline :is(.form__item, .form__item--inline) {
451
+ margin: 0;
452
+ }
453
+ }
454
+
455
+ /**
456
+ * Description
457
+ */
458
+
459
+ @layer design-system.atoms {
460
+ .mx-description {
461
+ margin-block: var(--form-spacing, var(--spacing-s));
462
+ margin-inline: 0;
463
+ font-size: var(--font-size-xs);
464
+ }
465
+
466
+ .mx-description:last-child {
467
+ margin-block-end: 0;
468
+ }
469
+ }
470
+
471
+ /**
472
+ * Messages
473
+ */
474
+
475
+ @layer design-system.atoms {
476
+ :is(.mx-success-message, .mx-error-message) {
477
+ margin-block: var(--form-spacing, var(--spacing-s));
478
+ margin-inline: 0;
479
+ font-size: var(--font-size-s);
480
+ color: var(--foreground, var(--colour-foreground));
481
+ display: flex;
482
+ gap: var(--spacing-xxs);
483
+ }
484
+
485
+ :is(.mx-success-message, .mx-error-message):last-child {
486
+ margin-block-end: 0;
487
+ }
488
+
489
+ :is(.mx-success-message, .mx-error-message)::before {
490
+ content: "";
491
+ display: block;
492
+ inline-size: var(--spacing-m);
493
+ block-size: var(--spacing-m);
494
+ -webkit-mask-position: center;
495
+ mask-position: center;
496
+ -webkit-mask-repeat: no-repeat;
497
+ mask-repeat: no-repeat;
498
+ flex-shrink: 0;
499
+ }
500
+
501
+ .mx-error-message::before {
502
+ -webkit-mask-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16'%3E%3Cpath d='M8 0C3.6 0 0 3.6 0 8s3.6 8 8 8 8-3.6 8-8-3.6-8-8-8zm3.5 10.1l-1.4 1.4L8 9.4l-2.1 2.1-1.4-1.4L6.6 8 4.5 5.9l1.4-1.4L8 6.6l2.1-2.1 1.4 1.4L9.4 8l2.1 2.1z'/%3E%3C/svg%3E");
503
+ mask-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16'%3E%3Cpath d='M8 0C3.6 0 0 3.6 0 8s3.6 8 8 8 8-3.6 8-8-3.6-8-8-8zm3.5 10.1l-1.4 1.4L8 9.4l-2.1 2.1-1.4-1.4L6.6 8 4.5 5.9l1.4-1.4L8 6.6l2.1-2.1 1.4 1.4L9.4 8l2.1 2.1z'/%3E%3C/svg%3E");
504
+ background-color: var(--error-foreground, var(--colour-error-foreground));
505
+ }
506
+
507
+ .mx-success-message::before {
508
+ -webkit-mask-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16'%3E%3Cpath d='M8 0C3.6 0 0 3.6 0 8s3.6 8 8 8 8-3.6 8-8-3.6-8-8-8zM7 11.4L3.6 8 5 6.6l2 2 4-4L12.4 6 7 11.4z'/%3E%3C/svg%3E");
509
+ mask-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16'%3E%3Cpath d='M8 0C3.6 0 0 3.6 0 8s3.6 8 8 8 8-3.6 8-8-3.6-8-8-8zM7 11.4L3.6 8 5 6.6l2 2 4-4L12.4 6 7 11.4z'/%3E%3C/svg%3E");
510
+ background-color: var(
511
+ --success-foreground,
512
+ var(--colour-success-foreground)
513
+ );
514
+ }
515
+ }
516
+
517
+ /*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["form.css"],"names":[],"mappings":"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","file":"form.css","sourcesContent":["/**\n * Form\n */\n\n@layer design-system.atoms {\n  .mx-form-item {\n    max-inline-size: var(--container-max-width);\n  }\n\n  .mx-form-item--inline {\n    display: flex;\n    align-items: flex-start;\n  }\n\n  /**\n   * Form actions.\n   */\n  .mx-form-actions {\n    display: flex;\n    flex-wrap: wrap;\n    align-items: center;\n    gap: var(--spacing-s);\n  }\n}\n\n/**\n * Text Input\n */\n\n@layer design-system.atoms {\n  :is(.mx-input__text, .mx-input__select, .mx-input__textarea) {\n    box-shadow: none;\n    font: inherit;\n    letter-spacing: inherit;\n    word-spacing: inherit;\n    max-inline-size: 100%;\n    padding-block: calc(\n      var(--form-spacing, var(--spacing-s)) - (var(--line-width, 2px) * 2)\n    );\n    padding-inline: var(--form-spacing, var(--spacing-s));\n    border: var(--line-width, 2px) solid\n      var(--line-colour, var(--line-colour, var(--colour-border)));\n    border-radius: var(--border-radius);\n    background-color: var(--colour-background);\n    color: var(--form-colour, var(--foreground, var(--colour-foreground)));\n    line-height: var(--line-height-ui);\n    block-size: var(--form-element-height, var(--spacing-xxl));\n\n    &:focus-visible {\n      outline-offset: calc(var(--line-width, 2px) * -1);\n    }\n\n    &::placeholder {\n      color: var(--placeholder-colour, var(--colour-foreground-alt));\n      opacity: 1;\n    }\n\n    &[disabled] {\n      opacity: var(--disabled-opacity, 0.6);\n      cursor: not-allowed;\n    }\n\n    &.error {\n      border-color: var(--error-foreground, var(--colour-error-foreground));\n    }\n\n    &.success {\n      border-color: var(--success-foreground, var(--colour-success-foreground));\n    }\n  }\n\n  .mx-input--small {\n    min-inline-size: 0;\n    border-width: 1px;\n  }\n\n  .mx-input--wide {\n    inline-size: 100%;\n  }\n}\n\n/**\n * Input Divider\n */\n\n@layer design-system.atoms {\n  .mx-input__divider {\n    padding: var(--form-spacing, var(--spacing-s));\n    line-height: var(--line-height-ui);\n  }\n}\n\n/**\n * Text Input with Icon\n */\n\n@layer design-system.atoms {\n  .mx-input--icon {\n    display: inline-block;\n    max-inline-size: 100%;\n    min-inline-size: 100%;\n    border-radius: var(--border-radius);\n    background-color: var(--background, var(--colour-background));\n    position: relative;\n\n    &::before {\n      position: absolute;\n      block-size: 100%;\n      inset-block-start: 0;\n      inset-inline-start: var(--form-spacing, var(--spacing-s));\n    }\n\n    & .mx-input__text {\n      inline-size: 100%;\n      padding-inline-start: calc(var(--form-spacing, var(--spacing-s)) * 2.5);\n      background-color: transparent;\n    }\n\n    &:has(.error)::before {\n      background-color: var(--error-foreground, var(--colour-error-foreground));\n    }\n\n    &:has(.success)::before {\n      background-color: var(\n        --success-foreground,\n        var(--colour-success-foreground)\n      );\n    }\n  }\n}\n\n/**\n * Text Input with Inline Button\n */\n\n@layer design-system.atoms {\n  .mx-form--inline-button {\n    position: relative;\n    display: flex;\n    max-inline-size: 100%;\n    min-inline-size: 100%;\n    border-radius: var(--border-radius);\n    background-color: var(--background, var(--colour-background));\n    border: var(--line-width, 2px) solid\n      var(--line-colour, var(--line-colour, var(--colour-border)));\n\n    &:has(.mx-input__text:focus-visible) {\n      --outline-size: max(0.125rem, 0.15em);\n\n      outline: var(--outline-width, var(--outline-size))\n        var(--outline-style, solid) var(--outline-color, currentcolor);\n      outline-offset: calc(var(--line-width, 2px) * -1);\n    }\n\n    & .mx-input__text {\n      background-color: transparent;\n      border: 0;\n      flex-grow: 1;\n\n      &:focus-visible {\n        outline: none;\n      }\n    }\n\n    & .mx-button {\n      margin: var(--spacing-xxxxs);\n      flex-shrink: 0;\n      border: 0;\n      border-radius: 3px;\n      block-size: calc(\n        var(--form-element-height, var(--spacing-xxl)) - var(--spacing-xxxs)\n      );\n    }\n  }\n}\n\n/**\n * Label\n */\n\n@layer design-system.atoms {\n  :is(.mx-label, .mx-legend) {\n    display: block;\n    margin-block-end: var(--spacing-xxxs);\n    font-size: var(--font-size);\n    color: var(--label-foreground, var(--foreground, var(--colour-foreground)));\n\n    &.mx-label--inline {\n      display: inline-block;\n      margin-block-end: 0;\n      margin-inline-end: var(--spacing-xxs);\n    }\n  }\n\n  .mx-checkbox [type=\"checkbox\"] {\n    box-shadow: none;\n    appearance: none;\n    inline-size: var(--control-size, var(--spacing-m));\n    block-size: var(--control-size, var(--spacing-m));\n    background-color: var(--background, var(--colour-background));\n    border: var(--line-width, 2px) solid\n      var(--line-colour, var(--colour-border));\n    border-radius: var(--border-radius);\n\n    @media (pointer: coarse) {\n      --control-size: 2rem;\n    }\n\n    &:checked {\n      background-image: svg-load(\"./images/checkmark.svg\");\n      background-size: 0.75rem;\n      background-position: center;\n    }\n\n    &:focus-visible {\n      outline: var(--line-width, 2px) auto var(--outline-color);\n      outline-offset: 0;\n    }\n\n    &[disabled] {\n      &::after {\n        opacity: var(--disabled-opacity, 0.6);\n        cursor: not-allowed;\n        content: \"\";\n        display: block;\n        inline-size: 100%;\n        block-size: 100%;\n        border-radius: var(--border-radius);\n      }\n\n      & + label {\n        opacity: var(--disabled-opacity, 0.6);\n        cursor: not-allowed;\n      }\n    }\n\n    &.error {\n      border-color: var(--error-foreground, var(--colour-error-foreground));\n    }\n\n    &.success {\n      border-color: var(--success-foreground, var(--colour-success-foreground));\n    }\n  }\n}\n\n/**\n * Checkboxes\n */\n\n/**\n * Radios\n */\n\n@layer design-system.atoms {\n  .mx-radio [type=\"radio\"] {\n    box-shadow: none;\n    appearance: none;\n    display: flex;\n    inline-size: var(--control-size, var(--spacing-m));\n    block-size: var(--control-size, var(--spacing-m));\n    background-color: var(--background, var(--colour-background));\n    border: var(--line-width, 2px) solid\n      var(--line-colour, var(--colour-border));\n    border-radius: 50%;\n\n    @media (pointer: coarse) {\n      --control-size: 2rem;\n    }\n\n    &:checked {\n      &::after {\n        content: \"\";\n        display: block;\n        inline-size: 0.5rem;\n        block-size: 0.5rem;\n        margin: auto;\n        border-radius: 50%;\n        background-color: var(--radio-colour, var(--colour-primary));\n      }\n    }\n\n    &:focus-visible {\n      outline: var(--line-width, 2px) auto var(--outline-color);\n      outline-offset: 0;\n    }\n\n    &[disabled] {\n      &::after {\n        opacity: var(--disabled-opacity, 0.6);\n        cursor: not-allowed;\n        content: \"\";\n        display: block;\n        inline-size: 100%;\n        block-size: 100%;\n        border-radius: 50%;\n      }\n\n      & + label {\n        opacity: var(--disabled-opacity, 0.6);\n        cursor: not-allowed;\n      }\n    }\n\n    &.error {\n      border-color: var(--error-foreground, var(--colour-error-foreground));\n    }\n\n    &.success {\n      border-color: var(--success-foreground, var(--colour-success-foreground));\n    }\n  }\n\n  :is(.mx-radio, .mx-checkbox) {\n    margin-block-end: var(--spacing-xxxs);\n    display: flex;\n    align-items: center;\n    gap: var(--control-gap, var(--spacing-xxs));\n\n    &:last-child {\n      margin-block-end: 0;\n    }\n\n    & label {\n      cursor: pointer;\n      margin: 0;\n    }\n\n    & input {\n      flex-shrink: 0;\n    }\n\n    &.mx-form-item--inline {\n      display: inline-flex;\n      margin-inline-end: var(--control-gap, var(--spacing-xxs));\n    }\n  }\n}\n\n/**\n * Select\n */\n\n@layer design-system.atoms {\n  .mx-input__select {\n    appearance: none;\n    cursor: pointer;\n    background-color: var(--background, var(--colour-background));\n    background-image: svg-load(\"./images/form-chevron-down.svg\");\n    background-position: right var(--form-spacing, var(--spacing-s)) center;\n    padding-block: 0;\n    padding-inline-end: var(--spacing-xl);\n\n    &[multiple] {\n      block-size: auto;\n      background-image: none;\n    }\n\n    &.mx-input--small {\n      padding-inline-end: var(--spacing-m);\n      background-position: right var(--spacing-xs) center;\n    }\n  }\n\n  :is(.translated-rtl .mx-input__select, [dir=\"rtl\"] .mx-input__select) {\n    background-position: left var(--spacing-s) center;\n\n    &.mx-input--small {\n      background-position: left var(--spacing-xs) center;\n    }\n  }\n}\n\n/**\n * Textarea\n */\n\n@layer design-system.atoms {\n  .mx-input__textarea {\n    block-size: calc(4 * var(--form-element-height, var(--spacing-xxl)));\n    inline-size: 100%;\n  }\n}\n\n/**\n * Fieldset\n */\n\n@layer design-system.atoms {\n  .mx-fieldset {\n    border: var(--line-width, 2px) solid\n      var(--line-colour, var(--colour-border));\n    border-radius: var(--border-radius);\n    padding: var(--form-spacing, var(--spacing-s));\n    min-inline-size: 0;\n\n    & legend {\n      padding-block: 0;\n      padding-inline: var(--form-spacing, var(--spacing-s));\n    }\n\n    &:is(.mx-fieldset--plain, :has(.mx-checkbox, .mx-radio)) {\n      border: 0;\n      padding: 0;\n\n      & legend {\n        padding: 0;\n      }\n    }\n\n    &.mx-fieldset--inline {\n      display: flex;\n      flex-wrap: wrap;\n      gap: var(--spacing-xxs);\n\n      & :is(.form__item, .form__item--inline) {\n        margin: 0;\n      }\n    }\n  }\n}\n\n/**\n * Description\n */\n\n@layer design-system.atoms {\n  .mx-description {\n    margin-block: var(--form-spacing, var(--spacing-s));\n    margin-inline: 0;\n    font-size: var(--font-size-xs);\n\n    &:last-child {\n      margin-block-end: 0;\n    }\n  }\n}\n\n/**\n * Messages\n */\n\n@layer design-system.atoms {\n  :is(.mx-success-message, .mx-error-message) {\n    margin-block: var(--form-spacing, var(--spacing-s));\n    margin-inline: 0;\n    font-size: var(--font-size-s);\n    color: var(--foreground, var(--colour-foreground));\n    display: flex;\n    gap: var(--spacing-xxs);\n\n    &:last-child {\n      margin-block-end: 0;\n    }\n\n    &::before {\n      content: \"\";\n      display: block;\n      inline-size: var(--spacing-m);\n      block-size: var(--spacing-m);\n      mask-position: center;\n      mask-repeat: no-repeat;\n      flex-shrink: 0;\n    }\n  }\n\n  .mx-error-message::before {\n    mask-image: svg-load(\"./images/form-error.svg\");\n    background-color: var(--error-foreground, var(--colour-error-foreground));\n  }\n\n  .mx-success-message::before {\n    mask-image: svg-load(\"./images/form-success.svg\");\n    background-color: var(\n      --success-foreground,\n      var(--colour-success-foreground)\n    );\n  }\n}\n"]} */
@@ -0,0 +1,60 @@
1
+ /**
2
+ * Messages
3
+ */
4
+
5
+ @layer design-system.defaults {
6
+ mx-closable-alert {
7
+ display: block;
8
+ }
9
+ }
10
+
11
+ @layer design-system.components {
12
+ .mx-global-alert {
13
+ background-color: var(--background, var(--colour-primary-light));
14
+ color: var(--foreground, var(--colour-foreground));
15
+ }
16
+
17
+ .mx-global-alert .mx-global-alert__inner {
18
+ display: grid;
19
+ grid-gap: var(--gap-s);
20
+ gap: var(--gap-s);
21
+ padding-block: var(--spacing-xxs);
22
+ padding-inline: var(--spacing-s);
23
+ }
24
+
25
+ .mx-global-alert .mx-global-alert__inner:has(.mx-icon--close) {
26
+ grid-template-columns: auto min-content;
27
+ grid-template-areas: "content close";
28
+ }
29
+
30
+ .mx-global-alert .mx-global-alert__inner:has(.mx-icon--close) .message__content {
31
+ grid-area: content;
32
+ }
33
+
34
+ .mx-global-alert a {
35
+ color: inherit;
36
+ }
37
+
38
+ .mx-global-alert.mx-global-alert--critical {
39
+ --foreground: var(--colour-error-foreground);
40
+ --background: var(--colour-error-background);
41
+ }
42
+
43
+ .mx-global-alert .mx-icon--close {
44
+ --icon-size: 1rem;
45
+
46
+ grid-area: close;
47
+ -webkit-appearance: none;
48
+ -moz-appearance: none;
49
+ appearance: none;
50
+ inline-size: var(--spacing-l);
51
+ block-size: var(--spacing-l);
52
+ padding: 0;
53
+ border: 0;
54
+ background-color: transparent;
55
+ justify-content: end;
56
+ color: inherit;
57
+ }
58
+ }
59
+
60
+ /*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImdsb2JhbC1hbGVydC5jc3MiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0VBRUU7O0FBRUY7RUFDRTtJQUNFLGNBQWM7RUFDaEI7QUFDRjs7QUFFQTtFQUNFO0lBQ0UsZ0VBQWdFO0lBQ2hFLGtEQUFrRDtFQXdDcEQ7O0lBdENFO01BQ0UsYUFBYTtNQUNiLHNCQUFpQjtNQUFqQixpQkFBaUI7TUFDakIsaUNBQWlDO01BQ2pDLGdDQUFnQztJQVVsQzs7TUFSRTtRQUNFLHVDQUF1QztRQUN2QyxvQ0FBb0M7TUFLdEM7O1FBSEU7VUFDRSxrQkFBa0I7UUFDcEI7O0lBSUo7TUFDRSxjQUFjO0lBQ2hCOztJQUVBO01BQ0UsNENBQTRDO01BQzVDLDRDQUE0QztJQUM5Qzs7SUFFQTtNQUNFLGlCQUFpQjs7TUFFakIsZ0JBQWdCO01BQ2hCLHdCQUFnQjtTQUFoQixxQkFBZ0I7Y0FBaEIsZ0JBQWdCO01BQ2hCLDZCQUE2QjtNQUM3Qiw0QkFBNEI7TUFDNUIsVUFBVTtNQUNWLFNBQVM7TUFDVCw2QkFBNkI7TUFDN0Isb0JBQW9CO01BQ3BCLGNBQWM7SUFDaEI7QUFFSiIsImZpbGUiOiJnbG9iYWwtYWxlcnQuY3NzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBNZXNzYWdlc1xuICovXG5cbkBsYXllciBkZXNpZ24tc3lzdGVtLmRlZmF1bHRzIHtcbiAgbXgtY2xvc2FibGUtYWxlcnQge1xuICAgIGRpc3BsYXk6IGJsb2NrO1xuICB9XG59XG5cbkBsYXllciBkZXNpZ24tc3lzdGVtLmNvbXBvbmVudHMge1xuICAubXgtZ2xvYmFsLWFsZXJ0IHtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiB2YXIoLS1iYWNrZ3JvdW5kLCB2YXIoLS1jb2xvdXItcHJpbWFyeS1saWdodCkpO1xuICAgIGNvbG9yOiB2YXIoLS1mb3JlZ3JvdW5kLCB2YXIoLS1jb2xvdXItZm9yZWdyb3VuZCkpO1xuXG4gICAgJiAubXgtZ2xvYmFsLWFsZXJ0X19pbm5lciB7XG4gICAgICBkaXNwbGF5OiBncmlkO1xuICAgICAgZ2FwOiB2YXIoLS1nYXAtcyk7XG4gICAgICBwYWRkaW5nLWJsb2NrOiB2YXIoLS1zcGFjaW5nLXh4cyk7XG4gICAgICBwYWRkaW5nLWlubGluZTogdmFyKC0tc3BhY2luZy1zKTtcblxuICAgICAgJjpoYXMoLm14LWljb24tLWNsb3NlKSB7XG4gICAgICAgIGdyaWQtdGVtcGxhdGUtY29sdW1uczogYXV0byBtaW4tY29udGVudDtcbiAgICAgICAgZ3JpZC10ZW1wbGF0ZS1hcmVhczogXCJjb250ZW50IGNsb3NlXCI7XG5cbiAgICAgICAgJiAubWVzc2FnZV9fY29udGVudCB7XG4gICAgICAgICAgZ3JpZC1hcmVhOiBjb250ZW50O1xuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuXG4gICAgJiBhIHtcbiAgICAgIGNvbG9yOiBpbmhlcml0O1xuICAgIH1cblxuICAgICYubXgtZ2xvYmFsLWFsZXJ0LS1jcml0aWNhbCB7XG4gICAgICAtLWZvcmVncm91bmQ6IHZhcigtLWNvbG91ci1lcnJvci1mb3JlZ3JvdW5kKTtcbiAgICAgIC0tYmFja2dyb3VuZDogdmFyKC0tY29sb3VyLWVycm9yLWJhY2tncm91bmQpO1xuICAgIH1cblxuICAgICYgLm14LWljb24tLWNsb3NlIHtcbiAgICAgIC0taWNvbi1zaXplOiAxcmVtO1xuXG4gICAgICBncmlkLWFyZWE6IGNsb3NlO1xuICAgICAgYXBwZWFyYW5jZTogbm9uZTtcbiAgICAgIGlubGluZS1zaXplOiB2YXIoLS1zcGFjaW5nLWwpO1xuICAgICAgYmxvY2stc2l6ZTogdmFyKC0tc3BhY2luZy1sKTtcbiAgICAgIHBhZGRpbmc6IDA7XG4gICAgICBib3JkZXI6IDA7XG4gICAgICBiYWNrZ3JvdW5kLWNvbG9yOiB0cmFuc3BhcmVudDtcbiAgICAgIGp1c3RpZnktY29udGVudDogZW5kO1xuICAgICAgY29sb3I6IGluaGVyaXQ7XG4gICAgfVxuICB9XG59XG4iXX0= */
@@ -0,0 +1,68 @@
1
+ import { c as createElement, m as makeAnchor } from "./chunks/utilities-B4YZb689.js";
2
+ class GlobalAlert extends HTMLElement {
3
+ constructor() {
4
+ super();
5
+ this.handleClose = () => {
6
+ this.controller.abort();
7
+ this.remove();
8
+ this.localStorage = "true";
9
+ const newEvent = new CustomEvent("GlobalAlert-close", {
10
+ bubbles: true,
11
+ cancelable: true,
12
+ detail: {
13
+ id: this.id,
14
+ target: this
15
+ }
16
+ });
17
+ this.dispatchEvent(newEvent);
18
+ };
19
+ this.internals_ = this.attachInternals();
20
+ this.controller = new AbortController();
21
+ }
22
+ connectedCallback() {
23
+ if (!this.container) return;
24
+ this.id = this.id || this.generatedId();
25
+ if (this.localStorage) {
26
+ this.controller.abort();
27
+ this.remove();
28
+ return;
29
+ }
30
+ const { signal } = this.controller;
31
+ this.close?.addEventListener("click", this.handleClose, { signal });
32
+ }
33
+ disconnectedCallback() {
34
+ this.controller.abort();
35
+ this.close.remove();
36
+ }
37
+ get localStorage() {
38
+ return localStorage.getItem(this.id);
39
+ }
40
+ set localStorage(value) {
41
+ localStorage.setItem(this.id, value);
42
+ }
43
+ get container() {
44
+ const element = this.querySelector("[data-container]");
45
+ if (!element) {
46
+ throw new Error(
47
+ `${this.localName} must contain a [data-container] element.`
48
+ );
49
+ }
50
+ return element;
51
+ }
52
+ get close() {
53
+ let closeBtn = this.querySelector(".mx-icon--close");
54
+ if (!closeBtn) {
55
+ closeBtn = createElement(
56
+ `<button class="mx-icon mx-icon--close" aria-controls="${this.id}" aria-label="Close GlobalAlert" type="button"></button>`
57
+ );
58
+ this.container.appendChild(closeBtn);
59
+ }
60
+ return closeBtn;
61
+ }
62
+ generatedId() {
63
+ const id = `mx-alert-${Math.floor(Math.random() * Math.floor(1e4))}`;
64
+ return makeAnchor(id, 20);
65
+ }
66
+ }
67
+ customElements.define("mx-closable-alert", GlobalAlert);
68
+ //# sourceMappingURL=global-alert.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"global-alert.entry.js","sources":["../../src/Component/GlobalAlert/Elements/ClosableAlert.ts"],"sourcesContent":["/**\n * @file GlobalAlerts\n *\n * When a GlobalAlert is closed the id is written to local storage.\n * This is checked as the page is re-rendered, if a GlobalAlert with the same ID is\n * created it will be removed from the dom.\n */\n\nimport { makeAnchor, createElement } from \"../../../Utility/utilities\"\n\nexport default class GlobalAlert 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.container) return\n this.id = this.id || this.generatedId()\n if (this.localStorage) {\n this.controller.abort()\n this.remove()\n return\n }\n const { signal }: AbortController = this.controller\n this.close?.addEventListener(\"click\", this.handleClose, { signal })\n }\n\n disconnectedCallback(): void {\n this.controller.abort()\n this.close.remove()\n }\n\n /**\n * Handle close button click event.\n */\n handleClose = (): void => {\n this.controller.abort()\n this.remove()\n this.localStorage = \"true\"\n const newEvent: CustomEvent<{ id: string; target: GlobalAlert }> =\n new CustomEvent(\"GlobalAlert-close\", {\n bubbles: true,\n cancelable: true,\n detail: {\n id: this.id,\n target: this,\n },\n })\n this.dispatchEvent(newEvent)\n }\n\n get localStorage(): string {\n return localStorage.getItem(this.id)\n }\n\n set localStorage(value: string) {\n localStorage.setItem(this.id, value)\n }\n\n get container(): HTMLElement {\n const element: HTMLElement = this.querySelector(\"[data-container]\")\n if (!element) {\n throw new Error(\n `${this.localName} must contain a [data-container] element.`,\n )\n }\n return element\n }\n\n get close(): HTMLButtonElement {\n let closeBtn: HTMLButtonElement = this.querySelector(\".mx-icon--close\")\n if (!closeBtn) {\n closeBtn = createElement(\n `<button class=\"mx-icon mx-icon--close\" aria-controls=\"${this.id}\" aria-label=\"Close GlobalAlert\" type=\"button\"></button>`,\n ) as HTMLButtonElement\n this.container.appendChild(closeBtn)\n }\n return closeBtn\n }\n\n generatedId(): string {\n const id = `mx-alert-${Math.floor(Math.random() * Math.floor(10000))}`\n return makeAnchor(id, 20)\n }\n}\n\ncustomElements.define(\"mx-closable-alert\", GlobalAlert)\n\ndeclare global {\n interface HTMLElementTagNameMap {\n \"mx-closable-alert\": GlobalAlert\n }\n}\n"],"names":[],"mappings":";AAUA,MAAqB,oBAAoB,YAAY;AAAA,EAInD,cAAc;AACN;AAyBR,SAAA,cAAc,MAAY;AACxB,WAAK,WAAW;AAChB,WAAK,OAAO;AACZ,WAAK,eAAe;AACd,YAAA,WACJ,IAAI,YAAY,qBAAqB;AAAA,QACnC,SAAS;AAAA,QACT,YAAY;AAAA,QACZ,QAAQ;AAAA,UACN,IAAI,KAAK;AAAA,UACT,QAAQ;AAAA,QACV;AAAA,MAAA,CACD;AACH,WAAK,cAAc,QAAQ;AAAA,IAAA;AArCtB,SAAA,aAAa,KAAK;AAClB,SAAA,aAAa,IAAI;EACxB;AAAA,EAEA,oBAA0B;AACpB,QAAA,CAAC,KAAK,UAAW;AACrB,SAAK,KAAK,KAAK,MAAM,KAAK,YAAY;AACtC,QAAI,KAAK,cAAc;AACrB,WAAK,WAAW;AAChB,WAAK,OAAO;AACZ;AAAA,IACF;AACM,UAAA,EAAE,OAAO,IAAqB,KAAK;AACzC,SAAK,OAAO,iBAAiB,SAAS,KAAK,aAAa,EAAE,QAAQ;AAAA,EACpE;AAAA,EAEA,uBAA6B;AAC3B,SAAK,WAAW;AAChB,SAAK,MAAM;EACb;AAAA,EAqBA,IAAI,eAAuB;AAClB,WAAA,aAAa,QAAQ,KAAK,EAAE;AAAA,EACrC;AAAA,EAEA,IAAI,aAAa,OAAe;AACjB,iBAAA,QAAQ,KAAK,IAAI,KAAK;AAAA,EACrC;AAAA,EAEA,IAAI,YAAyB;AACrB,UAAA,UAAuB,KAAK,cAAc,kBAAkB;AAClE,QAAI,CAAC,SAAS;AACZ,YAAM,IAAI;AAAA,QACR,GAAG,KAAK,SAAS;AAAA,MAAA;AAAA,IAErB;AACO,WAAA;AAAA,EACT;AAAA,EAEA,IAAI,QAA2B;AACzB,QAAA,WAA8B,KAAK,cAAc,iBAAiB;AACtE,QAAI,CAAC,UAAU;AACF,iBAAA;AAAA,QACT,yDAAyD,KAAK,EAAE;AAAA,MAAA;AAE7D,WAAA,UAAU,YAAY,QAAQ;AAAA,IACrC;AACO,WAAA;AAAA,EACT;AAAA,EAEA,cAAsB;AACd,UAAA,KAAK,YAAY,KAAK,MAAM,KAAK,OAAO,IAAI,KAAK,MAAM,GAAK,CAAC,CAAC;AAC7D,WAAA,WAAW,IAAI,EAAE;AAAA,EAC1B;AACF;AAEA,eAAe,OAAO,qBAAqB,WAAW;"}