@aurodesignsystem-dev/auro-formkit 0.0.0-pr1477.2 → 0.0.0-pr1480.1
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.
- package/components/bibtemplate/dist/auro-bibtemplate.d.ts +7 -0
- package/components/bibtemplate/dist/index.js +9 -1
- package/components/bibtemplate/dist/registered.js +9 -1
- package/components/checkbox/demo/customize.min.js +1 -1
- package/components/checkbox/demo/getting-started.min.js +1 -1
- package/components/checkbox/demo/index.min.js +1 -1
- package/components/checkbox/demo/pages.json +1 -1
- package/components/checkbox/demo/why-checkbox.html +57 -0
- package/components/checkbox/demo/why-checkbox.md +86 -0
- package/components/checkbox/dist/index.js +1 -1
- package/components/checkbox/dist/registered.js +1 -1
- package/components/combobox/demo/customize.min.js +236 -18
- package/components/combobox/demo/getting-started.min.js +236 -18
- package/components/combobox/demo/index.min.js +236 -18
- package/components/combobox/demo/keyboard-behavior.md +8 -68
- package/components/combobox/demo/pages.json +1 -1
- package/components/combobox/demo/why-combobox.html +57 -0
- package/components/combobox/demo/why-combobox.md +113 -0
- package/components/combobox/dist/index.js +236 -18
- package/components/combobox/dist/registered.js +236 -18
- package/components/counter/demo/customize.min.js +233 -15
- package/components/counter/demo/index.min.js +233 -15
- package/components/counter/demo/keyboard-behavior.md +1 -0
- package/components/counter/demo/pages.json +1 -1
- package/components/counter/demo/why-counter.html +57 -0
- package/components/counter/demo/why-counter.md +108 -0
- package/components/counter/dist/index.js +10 -2
- package/components/counter/dist/registered.js +10 -2
- package/components/datepicker/demo/accessibility.md +54 -3
- package/components/datepicker/demo/api.md +11 -2
- package/components/datepicker/demo/customize.html +2 -0
- package/components/datepicker/demo/customize.js +19 -0
- package/components/datepicker/demo/customize.md +72 -8
- package/components/datepicker/demo/customize.min.js +26492 -0
- package/components/datepicker/demo/design.md +3 -1
- package/components/datepicker/demo/index.js +5 -1
- package/components/datepicker/demo/index.md +85 -2
- package/components/datepicker/demo/index.min.js +2115 -184
- package/components/datepicker/demo/keyboard-behavior.md +201 -2
- package/components/datepicker/demo/pages.json +1 -1
- package/components/datepicker/demo/voiceover.md +21 -12
- package/components/datepicker/demo/why-datepicker.html +57 -0
- package/components/datepicker/demo/why-datepicker.md +133 -0
- package/components/datepicker/dist/index.js +2010 -155
- package/components/datepicker/dist/registered.js +2010 -155
- package/components/datepicker/dist/src/auro-calendar-cell.d.ts +112 -11
- package/components/datepicker/dist/src/auro-calendar-month.d.ts +37 -0
- package/components/datepicker/dist/src/auro-calendar.d.ts +177 -0
- package/components/datepicker/dist/src/auro-datepicker.d.ts +88 -0
- package/components/datepicker/dist/src/datepickerKeyboardStrategy.d.ts +5 -3
- package/components/dropdown/demo/accessibility.md +11 -0
- package/components/dropdown/demo/api.md +1 -0
- package/components/dropdown/demo/customize.md +3 -0
- package/components/dropdown/demo/customize.min.js +223 -13
- package/components/dropdown/demo/getting-started.min.js +223 -13
- package/components/dropdown/demo/index.min.js +223 -13
- package/components/dropdown/demo/keyboard-behavior.md +1 -0
- package/components/dropdown/demo/pages.json +1 -1
- package/components/dropdown/demo/why-dropdown.html +57 -0
- package/components/dropdown/demo/why-dropdown.md +97 -0
- package/components/dropdown/dist/auro-dropdown.d.ts +33 -1
- package/components/dropdown/dist/index.js +223 -13
- package/components/dropdown/dist/registered.js +223 -13
- package/components/form/demo/customize.min.js +2726 -219
- package/components/form/demo/getting-started.min.js +2726 -219
- package/components/form/demo/index.min.js +2726 -219
- package/components/form/demo/pages.json +1 -1
- package/components/form/demo/registerDemoDeps.min.js +2726 -219
- package/components/form/demo/why-form.html +57 -0
- package/components/form/demo/why-form.md +101 -0
- package/components/input/demo/customize.min.js +1 -1
- package/components/input/demo/getting-started.min.js +1 -1
- package/components/input/demo/index.min.js +1 -1
- package/components/input/demo/pages.json +1 -1
- package/components/input/demo/why-input.html +57 -0
- package/components/input/demo/why-input.md +121 -0
- package/components/input/dist/index.js +1 -1
- package/components/input/dist/registered.js +1 -1
- package/components/menu/demo/pages.json +1 -1
- package/components/menu/demo/why-menu.html +57 -0
- package/components/menu/demo/why-menu.md +104 -0
- package/components/radio/demo/customize.min.js +2186 -0
- package/components/radio/demo/demo-support.min.js +55807 -0
- package/components/radio/demo/getting-started.js +1 -1
- package/components/radio/demo/getting-started.md +1 -1
- package/components/radio/demo/getting-started.min.js +2205 -0
- package/components/radio/demo/index.min.js +1 -1
- package/components/radio/demo/pages.json +1 -1
- package/components/radio/demo/why-radio.html +57 -0
- package/components/radio/demo/why-radio.md +92 -0
- package/components/radio/dist/index.js +1 -1
- package/components/radio/dist/registered.js +1 -1
- package/components/select/demo/customize.min.js +249 -33
- package/components/select/demo/getting-started.min.js +249 -33
- package/components/select/demo/index.min.js +249 -33
- package/components/select/demo/keyboard-behavior.md +9 -54
- package/components/select/demo/pages.json +1 -1
- package/components/select/demo/why-select.html +57 -0
- package/components/select/demo/why-select.md +128 -0
- package/components/select/dist/index.js +249 -33
- package/components/select/dist/registered.js +249 -33
- package/custom-elements.json +2446 -1502
- package/package.json +2 -2
|
@@ -0,0 +1,128 @@
|
|
|
1
|
+
<auro-header level="1" id="overview">Why auro-select?</auro-header>
|
|
2
|
+
<p>The native <code><select></code> element is one of the most difficult HTML elements to style, has no support for rich option content, and behaves inconsistently across browsers. <code>auro-select</code> provides a fully styled, accessible, and feature-rich replacement.</p>
|
|
3
|
+
<auro-header level="2" id="accessibility">Accessibility</auro-header>
|
|
4
|
+
<p>Native <code><select></code> has basic accessibility, but the dropdown behavior, keyboard navigation, and screen reader announcements vary between browsers and platforms.</p>
|
|
5
|
+
<p><code>auro-select</code> provides:</p>
|
|
6
|
+
<ul>
|
|
7
|
+
<li><strong>ARIA combobox pattern</strong> — The trigger uses <code>role="combobox"</code> with <code>aria-expanded</code>, <code>aria-controls</code>, and <code>aria-activedescendant</code> for proper screen reader semantics.</li>
|
|
8
|
+
<li><strong>Full keyboard navigation</strong> — Arrow Up/Down navigate options (with Alt modifier for jumping to first/last), Enter selects, Escape closes, Home/End jump to boundaries, Tab closes and advances focus.</li>
|
|
9
|
+
<li><strong>Screen reader announcements</strong> — <code>aria-live="polite"</code> announces selections, <code>aria-live="assertive"</code> announces validation errors. Each option carries <code>aria-setsize</code> and <code>aria-posinset</code> for position context.</li>
|
|
10
|
+
<li><strong>Active descendant</strong> — Focus stays on the trigger while arrow keys highlight options, so screen readers announce the highlighted option without disrupting focus.</li>
|
|
11
|
+
</ul>
|
|
12
|
+
<auro-header level="2" id="richOptionContent">Rich option content</auro-header>
|
|
13
|
+
<p><code><option></code> elements accept only plain text. There is no native way to add icons, secondary text, or nested groups.</p>
|
|
14
|
+
<p><code>auro-select</code> uses <code>auro-menu</code> internally, enabling:</p>
|
|
15
|
+
<ul>
|
|
16
|
+
<li>Full HTML content in each option (icons, descriptions, badges)</li>
|
|
17
|
+
<li>Nested option groups for hierarchical organization</li>
|
|
18
|
+
<li>Checkmark indicators for the selected option</li>
|
|
19
|
+
<li>Option sizing (sm, md) for different information density</li>
|
|
20
|
+
</ul>
|
|
21
|
+
<auro-header level="2" id="multiselect">Multi-select</auro-header>
|
|
22
|
+
<p>Native <code><select multiple></code> renders a scrollable list box — a UI pattern widely regarded as confusing. Users must Ctrl+click to select multiple items, and there is no checkmark or visual feedback.</p>
|
|
23
|
+
<p><code>auro-select</code> with <code>multiSelect</code> provides:</p>
|
|
24
|
+
<ul>
|
|
25
|
+
<li>A dropdown trigger that stays closed between selections</li>
|
|
26
|
+
<li>Checkmarks on each selected option</li>
|
|
27
|
+
<li>A JSON-stringified array value for easy consumption</li>
|
|
28
|
+
<li><code>clearSelection()</code> to reset all selections</li>
|
|
29
|
+
</ul>
|
|
30
|
+
<auro-header level="2" id="responsiveLayout">Responsive layout</auro-header>
|
|
31
|
+
<p>Native <code><select></code> renders a browser-controlled popup that cannot be repositioned, resized, or presented differently on mobile.</p>
|
|
32
|
+
<p><code>auro-select</code> adapts to the viewport:</p>
|
|
33
|
+
<ul>
|
|
34
|
+
<li><strong>Desktop</strong> — Options appear in a positioned dropdown using Floating UI, with configurable placement, offset, flip, shift, and auto-placement</li>
|
|
35
|
+
<li><strong>Mobile</strong> — Options open in a fullscreen dialog below a configurable breakpoint (<code>fullscreenBreakpoint</code>)</li>
|
|
36
|
+
<li><strong>Width control</strong> — <code>matchWidth</code> sizes the dropdown to the trigger, <code>flexMenuWidth</code> lets it size independently</li>
|
|
37
|
+
</ul>
|
|
38
|
+
<auro-header level="2" id="validation">Validation</auro-header>
|
|
39
|
+
<p>Native <code><select></code> validation is limited to <code>required</code>. Error messages are browser-controlled.</p>
|
|
40
|
+
<p><code>auro-select</code> integrates with the Auro form validation system:</p>
|
|
41
|
+
<ul>
|
|
42
|
+
<li>Required field validation with custom messaging</li>
|
|
43
|
+
<li>Custom error messages per validity state (<code>setCustomValidityCustomError</code>, <code>setCustomValidityValueMissing</code>)</li>
|
|
44
|
+
<li><code>noValidate</code> to disable auto-validation on blur</li>
|
|
45
|
+
<li>Error display via the <code>helpText</code> slot</li>
|
|
46
|
+
<li>Dispatches <code>auroFormElement-validated</code> events for parent form coordination</li>
|
|
47
|
+
</ul>
|
|
48
|
+
<auro-header level="2" id="displayValueCustomization">Display value customization</auro-header>
|
|
49
|
+
<p>Native <code><select></code> always shows the selected option's text. There is no way to display a formatted or alternative representation.</p>
|
|
50
|
+
<p><code>auro-select</code> provides:</p>
|
|
51
|
+
<ul>
|
|
52
|
+
<li>A <code>displayValue</code> slot for custom HTML rendering of the selected value</li>
|
|
53
|
+
<li>A <code>valueText</code> slot for formatted text display</li>
|
|
54
|
+
<li>A <code>placeholder</code> slot (or attribute) for empty-state messaging</li>
|
|
55
|
+
<li><code>forceDisplayValue</code> to always show the custom display slot</li>
|
|
56
|
+
</ul>
|
|
57
|
+
<auro-header level="2" id="designSystemIntegration">Design system integration</auro-header>
|
|
58
|
+
<p>Native <code><select></code> styling is notoriously difficult. The dropdown arrow, option list, and selected value display are all browser-controlled and resist CSS customization.</p>
|
|
59
|
+
<p><code>auro-select</code> is built with the Auro Design System:</p>
|
|
60
|
+
<ul>
|
|
61
|
+
<li>Three layout options: classic, emphasized, snowflake</li>
|
|
62
|
+
<li>Shape variants: box, pill, pill-left, pill-right</li>
|
|
63
|
+
<li>Size options (lg, xl for emphasized layout)</li>
|
|
64
|
+
<li>Light and dark theme support (<code>appearance</code>)</li>
|
|
65
|
+
<li>CSS <code>::part()</code> selectors (<code>dropdownTrigger</code>, <code>dropdownChevron</code>, <code>dropdownSize</code>, <code>helpText</code>)</li>
|
|
66
|
+
</ul>
|
|
67
|
+
<auro-header level="2" id="summary">Summary</auro-header>
|
|
68
|
+
<table>
|
|
69
|
+
<thead>
|
|
70
|
+
<tr>
|
|
71
|
+
<th>Capability</th>
|
|
72
|
+
<th><code><select></code></th>
|
|
73
|
+
<th><code>auro-select</code></th>
|
|
74
|
+
</tr>
|
|
75
|
+
</thead>
|
|
76
|
+
<tbody>
|
|
77
|
+
<tr>
|
|
78
|
+
<td>Styleable dropdown</td>
|
|
79
|
+
<td>No (browser-controlled)</td>
|
|
80
|
+
<td>Fully styled</td>
|
|
81
|
+
</tr>
|
|
82
|
+
<tr>
|
|
83
|
+
<td>Rich HTML in options</td>
|
|
84
|
+
<td>Plain text only</td>
|
|
85
|
+
<td>Full HTML (icons, groups, descriptions)</td>
|
|
86
|
+
</tr>
|
|
87
|
+
<tr>
|
|
88
|
+
<td>Multi-select UX</td>
|
|
89
|
+
<td>Ctrl+click list box</td>
|
|
90
|
+
<td>Checkmark dropdown</td>
|
|
91
|
+
</tr>
|
|
92
|
+
<tr>
|
|
93
|
+
<td>Keyboard navigation</td>
|
|
94
|
+
<td>Basic</td>
|
|
95
|
+
<td>Full (arrows, Alt+arrows, Home/End)</td>
|
|
96
|
+
</tr>
|
|
97
|
+
<tr>
|
|
98
|
+
<td>Screen reader announcements</td>
|
|
99
|
+
<td>Varies by browser</td>
|
|
100
|
+
<td>Consistent ARIA live regions</td>
|
|
101
|
+
</tr>
|
|
102
|
+
<tr>
|
|
103
|
+
<td>Mobile fullscreen</td>
|
|
104
|
+
<td>No</td>
|
|
105
|
+
<td>Automatic at breakpoint</td>
|
|
106
|
+
</tr>
|
|
107
|
+
<tr>
|
|
108
|
+
<td>Viewport-aware positioning</td>
|
|
109
|
+
<td>No</td>
|
|
110
|
+
<td>Floating UI with flip/shift/auto</td>
|
|
111
|
+
</tr>
|
|
112
|
+
<tr>
|
|
113
|
+
<td>Custom validation messages</td>
|
|
114
|
+
<td>Browser-controlled</td>
|
|
115
|
+
<td>Per-constraint custom messages</td>
|
|
116
|
+
</tr>
|
|
117
|
+
<tr>
|
|
118
|
+
<td>Display value customization</td>
|
|
119
|
+
<td>No</td>
|
|
120
|
+
<td><code>displayValue</code> and <code>valueText</code> slots</td>
|
|
121
|
+
</tr>
|
|
122
|
+
<tr>
|
|
123
|
+
<td>Theming</td>
|
|
124
|
+
<td>No</td>
|
|
125
|
+
<td>Three layouts + appearance modes</td>
|
|
126
|
+
</tr>
|
|
127
|
+
</tbody>
|
|
128
|
+
</table>
|
|
@@ -1262,30 +1262,28 @@ function navigateArrow(component, direction, options = {}) {
|
|
|
1262
1262
|
const selectKeyboardStrategy = {
|
|
1263
1263
|
ArrowDown(component, evt, ctx) {
|
|
1264
1264
|
evt.preventDefault();
|
|
1265
|
-
if (
|
|
1266
|
-
|
|
1267
|
-
|
|
1268
|
-
|
|
1269
|
-
} else {
|
|
1270
|
-
navigateArrow(component, 'down', { ctx });
|
|
1271
|
-
}
|
|
1272
|
-
} else {
|
|
1273
|
-
component.dropdown.show();
|
|
1265
|
+
if (evt.altKey || evt.metaKey) {
|
|
1266
|
+
// navigate to last enabled option
|
|
1267
|
+
selectKeyboardStrategy.End(component, evt, ctx);
|
|
1268
|
+
return;
|
|
1274
1269
|
}
|
|
1270
|
+
navigateArrow(component, 'down', {
|
|
1271
|
+
ctx,
|
|
1272
|
+
showFn: () => component.dropdown.show(),
|
|
1273
|
+
});
|
|
1275
1274
|
},
|
|
1276
1275
|
|
|
1277
1276
|
ArrowUp(component, evt, ctx) {
|
|
1278
1277
|
evt.preventDefault();
|
|
1279
|
-
if (
|
|
1280
|
-
|
|
1281
|
-
|
|
1282
|
-
|
|
1283
|
-
} else {
|
|
1284
|
-
navigateArrow(component, 'up', { ctx });
|
|
1285
|
-
}
|
|
1286
|
-
} else {
|
|
1287
|
-
component.dropdown.show();
|
|
1278
|
+
if (evt.altKey || evt.metaKey) {
|
|
1279
|
+
// navigate to first enabled option
|
|
1280
|
+
selectKeyboardStrategy.Home(component, evt, ctx);
|
|
1281
|
+
return;
|
|
1288
1282
|
}
|
|
1283
|
+
navigateArrow(component, 'up', {
|
|
1284
|
+
ctx,
|
|
1285
|
+
showFn: () => component.dropdown.show(),
|
|
1286
|
+
});
|
|
1289
1287
|
},
|
|
1290
1288
|
|
|
1291
1289
|
Escape(component, evt, ctx) {
|
|
@@ -4637,7 +4635,7 @@ function applyKeyboardStrategy(component, strategy, options = {}) {
|
|
|
4637
4635
|
});
|
|
4638
4636
|
}
|
|
4639
4637
|
|
|
4640
|
-
var styleCss$2$1 = css`:host{position:fixed;z-index:var(--depth-tooltip, 400);display:none;isolation:isolate}:host dialog{width:auto;max-width:none;height:auto;max-height:none;padding:0;border:none;margin:0;outline:none;transform:translateZ(0)}:host dialog::backdrop{background:transparent}:host(:not([isfullscreen])) dialog{position:relative;inset:unset}:host(:not([isfullscreen])) .container.shape-box{border-radius:unset}:host(:not([isfullscreen])) .container[class*=shape-pill],:host(:not([isfullscreen])) .container[class*=shape-snowflake]{border-radius:30px}:host(:not([isfullscreen])) .container[class*=shape-rounded]{border-radius:16px}:host(:not([matchWidth])) .container{min-width:fit-content}:host([isfullscreen]){position:fixed;top:0;left:0}:host([isfullscreen]) .container{width:100dvw;max-width:none;height:100dvh;max-height:none;border-radius:unset;margin-top:0;box-shadow:unset;overscroll-behavior:contain}:host([isfullscreen]) .container::backdrop{background:var(--ds-color-background-primary, #fff)}:host(:popover-open){position:fixed;overflow:visible;padding:0;border:none;margin:0;background:transparent;inset:unset;outline:none}:host([data-show]){display:flex}:host([common]:not([isfullscreen])) .container,:host([rounded]:not([isfullscreen])) .container{border-radius:var(--ds-border-radius, 0.375rem)}:host([common][isfullscreen]) .container,:host([rounded][isfullscreen]) .container{border-radius:unset;box-shadow:unset}.container{display:inline-block;overflow:auto;box-sizing:border-box;border-radius:var(--ds-border-radius, 0.375rem);margin:var(--ds-size-50, 0.25rem) 0}.util_displayHiddenVisually{position:absolute;overflow:hidden;width:1px;height:1px;padding:0;border:0;margin:-1px;clip-path:inset(50%);white-space:nowrap}`;
|
|
4638
|
+
var styleCss$2$1 = css`:host{position:fixed;z-index:var(--depth-tooltip, 400);display:none;isolation:isolate}:host dialog{width:auto;max-width:none;height:auto;max-height:none;padding:0;border:none;margin:0;outline:none;transform:translateZ(0)}:host dialog::backdrop{background:transparent}:host(:not([isfullscreen])) dialog{position:relative;inset:unset}:host(:not([isfullscreen])) .container.shape-box{border-radius:unset}:host(:not([isfullscreen])) .container[class*=shape-pill],:host(:not([isfullscreen])) .container[class*=shape-snowflake]{border-radius:30px}:host(:not([isfullscreen])) .container[class*=shape-rounded]{border-radius:16px}:host([desktopmodal]:popover-open)::backdrop{background:transparent}:host(:not([matchWidth])) .container{min-width:fit-content}:host([isfullscreen]){position:fixed;top:0;left:0}:host([isfullscreen]) .container{width:100dvw;max-width:none;height:100dvh;max-height:none;border-radius:unset;margin-top:0;box-shadow:unset;overscroll-behavior:contain}:host([isfullscreen]) .container::backdrop{background:var(--ds-color-background-primary, #fff)}:host(:popover-open){position:fixed;overflow:visible;padding:0;border:none;margin:0;background:transparent;inset:unset;outline:none}:host([data-show]){display:flex}:host([common]:not([isfullscreen])) .container,:host([rounded]:not([isfullscreen])) .container{border-radius:var(--ds-border-radius, 0.375rem)}:host([common][isfullscreen]) .container,:host([rounded][isfullscreen]) .container{border-radius:unset;box-shadow:unset}.container{display:inline-block;overflow:auto;box-sizing:border-box;border-radius:var(--ds-border-radius, 0.375rem);margin:var(--ds-size-50, 0.25rem) 0}.util_displayHiddenVisually{position:absolute;overflow:hidden;width:1px;height:1px;padding:0;border:0;margin:-1px;clip-path:inset(50%);white-space:nowrap}`;
|
|
4641
4639
|
|
|
4642
4640
|
var colorCss$2 = css`.container{background-color:var(--ds-auro-dropdownbib-container-color);box-shadow:var(--ds-auro-dropdownbib-boxshadow-color);color:var(--ds-auro-dropdownbib-text-color)}`;
|
|
4643
4641
|
|
|
@@ -5268,7 +5266,7 @@ let AuroHelpText$1 = class AuroHelpText extends LitElement {
|
|
|
5268
5266
|
}
|
|
5269
5267
|
};
|
|
5270
5268
|
|
|
5271
|
-
var formkitVersion$1 = '
|
|
5269
|
+
var formkitVersion$1 = '202605210326';
|
|
5272
5270
|
|
|
5273
5271
|
class AuroElement extends LitElement {
|
|
5274
5272
|
static get properties() {
|
|
@@ -5448,6 +5446,7 @@ class AuroDropdown extends AuroElement {
|
|
|
5448
5446
|
_intializeDefaults() {
|
|
5449
5447
|
this.appearance = 'default';
|
|
5450
5448
|
this.chevron = false;
|
|
5449
|
+
this.desktopModal = false;
|
|
5451
5450
|
this.disabled = false;
|
|
5452
5451
|
this.disableKeyboardHandling = false;
|
|
5453
5452
|
this.error = false;
|
|
@@ -5628,6 +5627,14 @@ class AuroDropdown extends AuroElement {
|
|
|
5628
5627
|
reflect: true
|
|
5629
5628
|
},
|
|
5630
5629
|
|
|
5630
|
+
/**
|
|
5631
|
+
* If declared, the dropdown will behave as a modal dialog when in a desktop viewport size.
|
|
5632
|
+
*/
|
|
5633
|
+
desktopModal: {
|
|
5634
|
+
type: Boolean,
|
|
5635
|
+
reflect: true
|
|
5636
|
+
},
|
|
5637
|
+
|
|
5631
5638
|
/**
|
|
5632
5639
|
* If declared, the dropdown will only show by calling the API .show() public method.
|
|
5633
5640
|
*/
|
|
@@ -5915,6 +5922,15 @@ class AuroDropdown extends AuroElement {
|
|
|
5915
5922
|
|
|
5916
5923
|
disconnectedCallback() {
|
|
5917
5924
|
super.disconnectedCallback();
|
|
5925
|
+
this._clearPageInert();
|
|
5926
|
+
if (this._bibTabHandler) {
|
|
5927
|
+
this.removeEventListener('keydown', this._bibTabHandler);
|
|
5928
|
+
this._bibTabHandler = undefined;
|
|
5929
|
+
}
|
|
5930
|
+
if (this.focusTrap) {
|
|
5931
|
+
this.focusTrap.disconnect();
|
|
5932
|
+
this.focusTrap = undefined;
|
|
5933
|
+
}
|
|
5918
5934
|
if (this.floater) {
|
|
5919
5935
|
this.floater.hideBib('disconnect');
|
|
5920
5936
|
this.floater.disconnect();
|
|
@@ -5942,19 +5958,45 @@ class AuroDropdown extends AuroElement {
|
|
|
5942
5958
|
if (this.isPopoverVisible) {
|
|
5943
5959
|
// Fullscreen: use showModal() for native accessibility (inert outside, focus trap)
|
|
5944
5960
|
// Desktop: use show() for Floating UI positioning + FocusTrap for focus management
|
|
5945
|
-
|
|
5946
|
-
this.
|
|
5961
|
+
this.bibElement.value.open(this.isBibFullscreen);
|
|
5962
|
+
this.updateFocusTrap();
|
|
5963
|
+
|
|
5964
|
+
// Desktop modal: make siblings inert so content outside is not interactive
|
|
5965
|
+
if (this.desktopModal && !this.isBibFullscreen) {
|
|
5966
|
+
this._setPageInert();
|
|
5967
|
+
}
|
|
5947
5968
|
} else {
|
|
5948
5969
|
this.bibElement.value.close();
|
|
5970
|
+
this._clearPageInert();
|
|
5949
5971
|
}
|
|
5950
5972
|
}
|
|
5951
5973
|
|
|
5952
5974
|
// When fullscreen strategy changes while open, re-open dialog with correct mode
|
|
5953
5975
|
// (e.g. resizing from desktop → mobile while dropdown is open)
|
|
5954
5976
|
if (changedProperties.has('isBibFullscreen') && this.isPopoverVisible && this.bibElement.value) {
|
|
5955
|
-
const useModal = this.isBibFullscreen;
|
|
5956
5977
|
this.bibElement.value.close();
|
|
5957
|
-
this.bibElement.value.open(
|
|
5978
|
+
this.bibElement.value.open(this.isBibFullscreen);
|
|
5979
|
+
|
|
5980
|
+
// Re-initialize focus management for the new strategy
|
|
5981
|
+
this.updateFocusTrap();
|
|
5982
|
+
|
|
5983
|
+
// Toggle inert: desktop modal needs it, fullscreen showModal() handles it natively
|
|
5984
|
+
if (this.desktopModal && !this.isBibFullscreen) {
|
|
5985
|
+
this._setPageInert();
|
|
5986
|
+
} else {
|
|
5987
|
+
this._clearPageInert();
|
|
5988
|
+
}
|
|
5989
|
+
}
|
|
5990
|
+
|
|
5991
|
+
// Handle desktopModal toggled while the dropdown is already open.
|
|
5992
|
+
// Re-initialize focus trapping and page inert state to match the new mode.
|
|
5993
|
+
if (changedProperties.has('desktopModal') && this.isPopoverVisible && !this.isBibFullscreen) {
|
|
5994
|
+
this.updateFocusTrap();
|
|
5995
|
+
if (this.desktopModal) {
|
|
5996
|
+
this._setPageInert();
|
|
5997
|
+
} else {
|
|
5998
|
+
this._clearPageInert();
|
|
5999
|
+
}
|
|
5958
6000
|
}
|
|
5959
6001
|
}
|
|
5960
6002
|
|
|
@@ -5964,8 +6006,14 @@ class AuroDropdown extends AuroElement {
|
|
|
5964
6006
|
* @param {CustomEvent} event - The custom event that contains the dropdown toggle information.
|
|
5965
6007
|
*/
|
|
5966
6008
|
handleDropdownToggle(event) {
|
|
5967
|
-
this.updateFocusTrap();
|
|
5968
6009
|
this.isPopoverVisible = event.detail.expanded;
|
|
6010
|
+
|
|
6011
|
+
// Tear down FocusTrap when closing. Creation happens in updated()
|
|
6012
|
+
// after the dialog is open so getFocusableElements can find content.
|
|
6013
|
+
if (!this.isPopoverVisible) {
|
|
6014
|
+
this.updateFocusTrap();
|
|
6015
|
+
}
|
|
6016
|
+
|
|
5969
6017
|
const eventType = event.detail.eventType || "unknown";
|
|
5970
6018
|
if (!this.isPopoverVisible && this.hasFocus && eventType === "keydown") {
|
|
5971
6019
|
this.trigger.focus();
|
|
@@ -6064,19 +6112,178 @@ class AuroDropdown extends AuroElement {
|
|
|
6064
6112
|
* @private
|
|
6065
6113
|
*/
|
|
6066
6114
|
updateFocusTrap() {
|
|
6115
|
+
// Always clean up existing handlers/traps before setting up new ones
|
|
6116
|
+
// to prevent duplicate listeners on repeated calls.
|
|
6117
|
+
if (this._bibTabHandler) {
|
|
6118
|
+
this.removeEventListener('keydown', this._bibTabHandler);
|
|
6119
|
+
this._bibTabHandler = undefined;
|
|
6120
|
+
}
|
|
6121
|
+
|
|
6122
|
+
if (this.focusTrap) {
|
|
6123
|
+
this.focusTrap.disconnect();
|
|
6124
|
+
this.focusTrap = undefined;
|
|
6125
|
+
}
|
|
6126
|
+
|
|
6067
6127
|
if (this.isPopoverVisible) {
|
|
6068
6128
|
if (!this.isBibFullscreen) {
|
|
6069
|
-
|
|
6070
|
-
|
|
6071
|
-
|
|
6129
|
+
if (this.desktopModal) {
|
|
6130
|
+
// Desktop modal: trap focus only within the bib content.
|
|
6131
|
+
// Can't use FocusTrap on the bib element because keydown events
|
|
6132
|
+
// from slotted content bubble through the dropdown host (light DOM),
|
|
6133
|
+
// not through the bib (shadow projection target). Using FocusTrap
|
|
6134
|
+
// on the dropdown would include the trigger in the tab cycle.
|
|
6135
|
+
// Instead, listen for Tab on the dropdown and manually wrap focus
|
|
6136
|
+
// within the bib's focusable elements.
|
|
6137
|
+
this._bibTabHandler = (event) => {
|
|
6138
|
+
if (event.key !== 'Tab') {
|
|
6139
|
+
return;
|
|
6140
|
+
}
|
|
6141
|
+
|
|
6142
|
+
// Collect focusable elements from the bib content.
|
|
6143
|
+
const focusables = getFocusableElements(this.bibContent);
|
|
6144
|
+
|
|
6145
|
+
// Fallback: try from slotted content directly
|
|
6146
|
+
if (!focusables.length) {
|
|
6147
|
+
const slot = this.shadowRoot.querySelector('.slotContent slot');
|
|
6148
|
+
const assignedNodes = slot ? slot.assignedNodes({ flatten: true }) : [];
|
|
6149
|
+
|
|
6150
|
+
for (const node of assignedNodes) {
|
|
6151
|
+
if (node.nodeType === Node.ELEMENT_NODE) {
|
|
6152
|
+
focusables.push(...getFocusableElements(node));
|
|
6153
|
+
}
|
|
6154
|
+
}
|
|
6155
|
+
}
|
|
6156
|
+
|
|
6157
|
+
if (!focusables.length) {
|
|
6158
|
+
return;
|
|
6159
|
+
}
|
|
6160
|
+
|
|
6161
|
+
event.preventDefault();
|
|
6162
|
+
|
|
6163
|
+
const direction = event.shiftKey ? -1 : 1; // eslint-disable-line no-magic-numbers
|
|
6164
|
+
|
|
6165
|
+
// Walk the active element chain through shadow roots
|
|
6166
|
+
const actives = this._getActiveElements();
|
|
6167
|
+
|
|
6168
|
+
let idx = focusables.findIndex((el) => actives.includes(el));
|
|
6169
|
+
|
|
6170
|
+
if (idx === -1) { // eslint-disable-line no-magic-numbers
|
|
6171
|
+
// Focus is not on a known element — move to first/last
|
|
6172
|
+
idx = direction === 1 ? -1 : focusables.length; // eslint-disable-line no-magic-numbers
|
|
6173
|
+
}
|
|
6174
|
+
|
|
6175
|
+
// Try each element in order, skipping any that can't receive focus
|
|
6176
|
+
// (e.g. hidden elements, elements in collapsed sections)
|
|
6177
|
+
for (let index = 0; index < focusables.length; index++) { // eslint-disable-line no-plusplus
|
|
6178
|
+
let nextIdx = idx + direction;
|
|
6179
|
+
|
|
6180
|
+
// Wrap around
|
|
6181
|
+
if (nextIdx < 0) {
|
|
6182
|
+
nextIdx = focusables.length - 1;
|
|
6183
|
+
} else if (nextIdx >= focusables.length) {
|
|
6184
|
+
nextIdx = 0;
|
|
6185
|
+
}
|
|
6186
|
+
|
|
6187
|
+
focusables[nextIdx].focus();
|
|
6188
|
+
|
|
6189
|
+
// Verify focus actually moved to the target
|
|
6190
|
+
const newActives = this._getActiveElements();
|
|
6191
|
+
|
|
6192
|
+
if (newActives.includes(focusables[nextIdx])) {
|
|
6193
|
+
return;
|
|
6194
|
+
}
|
|
6195
|
+
|
|
6196
|
+
// Focus didn't stick — skip this element and try the next
|
|
6197
|
+
idx = nextIdx;
|
|
6198
|
+
}
|
|
6199
|
+
};
|
|
6200
|
+
this.addEventListener('keydown', this._bibTabHandler);
|
|
6201
|
+
|
|
6202
|
+
// Move initial focus into the bib content, matching FocusTrap behavior
|
|
6203
|
+
requestAnimationFrame(() => {
|
|
6204
|
+
const focusables = getFocusableElements(this.bibContent);
|
|
6205
|
+
if (focusables.length) {
|
|
6206
|
+
focusables[0].focus();
|
|
6207
|
+
}
|
|
6208
|
+
});
|
|
6209
|
+
} else {
|
|
6210
|
+
// Normal desktop: use FocusTrap on the bib element
|
|
6211
|
+
this.focusTrap = new FocusTrap(this.bibContent);
|
|
6212
|
+
this.focusTrap.focusFirstElement();
|
|
6213
|
+
}
|
|
6072
6214
|
}
|
|
6073
6215
|
// Fullscreen: showModal() provides native focus trapping
|
|
6216
|
+
}
|
|
6217
|
+
}
|
|
6218
|
+
|
|
6219
|
+
/**
|
|
6220
|
+
* Returns the chain of active (focused) elements through shadow roots.
|
|
6221
|
+
* @private
|
|
6222
|
+
* @returns {Array<HTMLElement>}
|
|
6223
|
+
*/
|
|
6224
|
+
_getActiveElements() {
|
|
6225
|
+
let { activeElement } = document;
|
|
6226
|
+
const actives = [activeElement];
|
|
6227
|
+
|
|
6228
|
+
while (activeElement?.shadowRoot?.activeElement) {
|
|
6229
|
+
activeElement = activeElement.shadowRoot.activeElement;
|
|
6230
|
+
actives.push(activeElement);
|
|
6231
|
+
}
|
|
6232
|
+
|
|
6233
|
+
return actives;
|
|
6234
|
+
}
|
|
6235
|
+
|
|
6236
|
+
/**
|
|
6237
|
+
* Sets `inert` on sibling elements of the dropdown's top-level host
|
|
6238
|
+
* so that content outside the dropdown is not interactive while the modal is open.
|
|
6239
|
+
* Walks up through shadow DOM boundaries to find the outermost host element
|
|
6240
|
+
* in the light DOM, then sets `inert` on siblings at each ancestor level
|
|
6241
|
+
* to ensure all page content outside the host subtree is inert.
|
|
6242
|
+
* @private
|
|
6243
|
+
*/
|
|
6244
|
+
_setPageInert() {
|
|
6245
|
+
if (this._inertSiblings) {
|
|
6074
6246
|
return;
|
|
6075
6247
|
}
|
|
6076
6248
|
|
|
6077
|
-
|
|
6078
|
-
|
|
6079
|
-
|
|
6249
|
+
this._inertSiblings = [];
|
|
6250
|
+
|
|
6251
|
+
// Walk up through shadow DOM boundaries to find the topmost host
|
|
6252
|
+
// element in the light DOM. For example, if this dropdown is inside
|
|
6253
|
+
// auro-datepicker's shadow DOM, we walk up to the datepicker element
|
|
6254
|
+
// so we set inert on its siblings — not on the datepicker itself.
|
|
6255
|
+
let host = this;
|
|
6256
|
+
while (host.getRootNode() instanceof ShadowRoot) {
|
|
6257
|
+
host = host.getRootNode().host;
|
|
6258
|
+
}
|
|
6259
|
+
|
|
6260
|
+
// Walk up the ancestor chain, inerting siblings at each level
|
|
6261
|
+
// to ensure the entire page outside the host subtree is inert.
|
|
6262
|
+
let current = host;
|
|
6263
|
+
while (current.parentElement) {
|
|
6264
|
+
const parent = current.parentElement;
|
|
6265
|
+
for (const sibling of parent.children) {
|
|
6266
|
+
if (sibling !== current) {
|
|
6267
|
+
this._inertSiblings.push({ element: sibling, wasInert: sibling.inert });
|
|
6268
|
+
sibling.inert = true;
|
|
6269
|
+
}
|
|
6270
|
+
}
|
|
6271
|
+
current = parent;
|
|
6272
|
+
}
|
|
6273
|
+
}
|
|
6274
|
+
|
|
6275
|
+
/**
|
|
6276
|
+
* Restores `inert` state on siblings that were tracked by `_setPageInert`.
|
|
6277
|
+
* Preserves the previous inert state so externally-inerted elements are
|
|
6278
|
+
* not inadvertently re-enabled.
|
|
6279
|
+
* @private
|
|
6280
|
+
*/
|
|
6281
|
+
_clearPageInert() {
|
|
6282
|
+
if (this._inertSiblings) {
|
|
6283
|
+
for (const entry of this._inertSiblings) {
|
|
6284
|
+
entry.element.inert = entry.wasInert;
|
|
6285
|
+
}
|
|
6286
|
+
this._inertSiblings = undefined;
|
|
6080
6287
|
}
|
|
6081
6288
|
}
|
|
6082
6289
|
|
|
@@ -6315,6 +6522,7 @@ class AuroDropdown extends AuroElement {
|
|
|
6315
6522
|
shape="${this.shape}"
|
|
6316
6523
|
?data-show="${this.isPopoverVisible}"
|
|
6317
6524
|
?isfullscreen="${this.isBibFullscreen}"
|
|
6525
|
+
?desktopmodal="${this.desktopModal}"
|
|
6318
6526
|
.dialogLabel="${this.bibDialogLabel}"
|
|
6319
6527
|
${ref(this.bibElement)}
|
|
6320
6528
|
>
|
|
@@ -6682,6 +6890,14 @@ class AuroBibtemplate extends LitElement {
|
|
|
6682
6890
|
large: {
|
|
6683
6891
|
type: Boolean,
|
|
6684
6892
|
reflect: true
|
|
6893
|
+
},
|
|
6894
|
+
|
|
6895
|
+
/**
|
|
6896
|
+
* If declared, the footer slot will be rendered even when not in fullscreen mode.
|
|
6897
|
+
*/
|
|
6898
|
+
showFooter: {
|
|
6899
|
+
type: Boolean,
|
|
6900
|
+
reflect: true
|
|
6685
6901
|
}
|
|
6686
6902
|
};
|
|
6687
6903
|
}
|
|
@@ -6784,7 +7000,7 @@ class AuroBibtemplate extends LitElement {
|
|
|
6784
7000
|
<slot></slot>
|
|
6785
7001
|
</div>
|
|
6786
7002
|
|
|
6787
|
-
${this.isFullscreen ? html`
|
|
7003
|
+
${this.isFullscreen || this.showFooter ? html`
|
|
6788
7004
|
<div id="footerContainer">
|
|
6789
7005
|
<slot name="footer"></slot>
|
|
6790
7006
|
</div>` : null}
|
|
@@ -7021,7 +7237,7 @@ class AuroHelpText extends LitElement {
|
|
|
7021
7237
|
}
|
|
7022
7238
|
}
|
|
7023
7239
|
|
|
7024
|
-
var formkitVersion = '
|
|
7240
|
+
var formkitVersion = '202605210326';
|
|
7025
7241
|
|
|
7026
7242
|
var styleCss = css`.util_displayInline{display:inline}.util_displayInlineBlock{display:inline-block}.util_displayBlock{display:block}.util_displayFlex{display:flex}.util_displayHidden{display:none}.util_displayHiddenVisually{position:absolute;overflow:hidden;clip:rect(1px, 1px, 1px, 1px);width:1px;height:1px;padding:0;border:0}.body-default{font-size:var(--wcss-body-default-font-size, 1rem);font-weight:var(--wcss-body-default-weight, );line-height:var(--wcss-body-default-line-height, 1.5rem)}.body-default,.body-default-emphasized{font-family:var(--wcss-body-family, "AS Circular"),system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;letter-spacing:var(--wcss-body-letter-spacing, 0)}.body-default-emphasized{font-size:var(--wcss-body-default-emphasized-font-size, 1rem);font-weight:var(--wcss-body-default-emphasized-weight, );line-height:var(--wcss-body-default-emphasized-line-height, 1.5rem)}.body-lg{font-size:var(--wcss-body-lg-font-size, 1.125rem);font-weight:var(--wcss-body-lg-weight, );line-height:var(--wcss-body-lg-line-height, 1.625rem)}.body-lg,.body-lg-emphasized{font-family:var(--wcss-body-family, "AS Circular"),system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;letter-spacing:var(--wcss-body-letter-spacing, 0)}.body-lg-emphasized{font-size:var(--wcss-body-lg-emphasized-font-size, 1.125rem);font-weight:var(--wcss-body-lg-emphasized-weight, );line-height:var(--wcss-body-lg-emphasized-line-height, 1.625rem)}.body-sm{font-size:var(--wcss-body-sm-font-size, 0.875rem);font-weight:var(--wcss-body-sm-weight, );line-height:var(--wcss-body-sm-line-height, 1.25rem)}.body-sm,.body-sm-emphasized{font-family:var(--wcss-body-family, "AS Circular"),system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;letter-spacing:var(--wcss-body-letter-spacing, 0)}.body-sm-emphasized{font-size:var(--wcss-body-sm-emphasized-font-size, 0.875rem);font-weight:var(--wcss-body-sm-emphasized-weight, );line-height:var(--wcss-body-sm-emphasized-line-height, 1.25rem)}.body-xs{font-size:var(--wcss-body-xs-font-size, 0.75rem);font-weight:var(--wcss-body-xs-weight, );line-height:var(--wcss-body-xs-line-height, 1rem)}.body-xs,.body-xs-emphasized{font-family:var(--wcss-body-family, "AS Circular"),system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;letter-spacing:var(--wcss-body-letter-spacing, 0)}.body-xs-emphasized{font-size:var(--wcss-body-xs-emphasized-font-size, 0.75rem);font-weight:var(--wcss-body-xs-emphasized-weight, );line-height:var(--wcss-body-xs-emphasized-line-height, 1rem)}.body-2xs{font-size:var(--wcss-body-2xs-font-size, 0.625rem);font-weight:var(--wcss-body-2xs-weight, );line-height:var(--wcss-body-2xs-line-height, 0.875rem)}.body-2xs,.body-2xs-emphasized{font-family:var(--wcss-body-family, "AS Circular"),system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;letter-spacing:var(--wcss-body-letter-spacing, 0)}.body-2xs-emphasized{font-size:var(--wcss-body-2xs-emphasized-font-size, 0.625rem);font-weight:var(--wcss-body-2xs-emphasized-weight, );line-height:var(--wcss-body-2xs-emphasized-line-height, 0.875rem)}.display-2xl{font-family:var(--wcss-display-2xl-family, "AS Circular"),var(--wcss-display-2xl-family-fallback, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif);font-size:var(--wcss-display-2xl-font-size, clamp(3.5rem, 6vw, 5.375rem));font-weight:var(--wcss-display-2xl-weight, 300);letter-spacing:var(--wcss-display-2xl-letter-spacing, 0);line-height:var(--wcss-display-2xl-line-height, 1.3)}.display-xl{font-family:var(--wcss-display-xl-family, "AS Circular"),var(--wcss-display-xl-family-fallback, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif);font-size:var(--wcss-display-xl-font-size, clamp(3rem, 5.3333333333vw, 4.5rem));font-weight:var(--wcss-display-xl-weight, 300);letter-spacing:var(--wcss-display-xl-letter-spacing, 0);line-height:var(--wcss-display-xl-line-height, 1.3)}.display-lg{font-family:var(--wcss-display-lg-family, "AS Circular"),var(--wcss-display-lg-family-fallback, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif);font-size:var(--wcss-display-lg-font-size, clamp(2.75rem, 4.6666666667vw, 4rem));font-weight:var(--wcss-display-lg-weight, 300);letter-spacing:var(--wcss-display-lg-letter-spacing, 0);line-height:var(--wcss-display-lg-line-height, 1.3)}.display-md{font-family:var(--wcss-display-md-family, "AS Circular"),var(--wcss-display-md-family-fallback, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif);font-size:var(--wcss-display-md-font-size, clamp(2.5rem, 4vw, 3.5rem));font-weight:var(--wcss-display-md-weight, 300);letter-spacing:var(--wcss-display-md-letter-spacing, 0);line-height:var(--wcss-display-md-line-height, 1.3)}.display-sm{font-family:var(--wcss-display-sm-family, "AS Circular"),var(--wcss-display-sm-family-fallback, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif);font-size:var(--wcss-display-sm-font-size, clamp(2rem, 3.6666666667vw, 3rem));font-weight:var(--wcss-display-sm-weight, 300);letter-spacing:var(--wcss-display-sm-letter-spacing, 0);line-height:var(--wcss-display-sm-line-height, 1.3)}.display-xs{font-family:var(--wcss-display-xs-family, "AS Circular"),var(--wcss-display-xs-family-fallback, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif);font-size:var(--wcss-display-xs-font-size, clamp(1.75rem, 3vw, 2.375rem));font-weight:var(--wcss-display-xs-weight, 300);letter-spacing:var(--wcss-display-xs-letter-spacing, 0);line-height:var(--wcss-display-xs-line-height, 1.3)}.heading-xl{font-family:var(--wcss-heading-xl-family, "AS Circular"),var(--wcss-heading-xl-family-fallback, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif);font-size:var(--wcss-heading-xl-font-size, clamp(2rem, 3vw, 2.5rem));font-weight:var(--wcss-heading-xl-weight, 300);letter-spacing:var(--wcss-heading-xl-letter-spacing, 0);line-height:var(--wcss-heading-xl-line-height, 1.3)}.heading-lg{font-family:var(--wcss-heading-lg-family, "AS Circular"),var(--wcss-heading-lg-family-fallback, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif);font-size:var(--wcss-heading-lg-font-size, clamp(1.75rem, 2.6666666667vw, 2.25rem));font-weight:var(--wcss-heading-lg-weight, 300);letter-spacing:var(--wcss-heading-lg-letter-spacing, 0);line-height:var(--wcss-heading-lg-line-height, 1.3)}.heading-md{font-family:var(--wcss-heading-md-family, "AS Circular"),var(--wcss-heading-md-family-fallback, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif);font-size:var(--wcss-heading-md-font-size, clamp(1.625rem, 2.3333333333vw, 1.75rem));font-weight:var(--wcss-heading-md-weight, 300);letter-spacing:var(--wcss-heading-md-letter-spacing, 0);line-height:var(--wcss-heading-md-line-height, 1.3)}.heading-sm{font-family:var(--wcss-heading-sm-family, "AS Circular"),var(--wcss-heading-sm-family-fallback, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif);font-size:var(--wcss-heading-sm-font-size, clamp(1.375rem, 2vw, 1.5rem));font-weight:var(--wcss-heading-sm-weight, 300);letter-spacing:var(--wcss-heading-sm-letter-spacing, 0);line-height:var(--wcss-heading-sm-line-height, 1.3)}.heading-xs{font-family:var(--wcss-heading-xs-family, "AS Circular"),var(--wcss-heading-xs-family-fallback, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif);font-size:var(--wcss-heading-xs-font-size, clamp(1.25rem, 1.6666666667vw, 1.25rem));font-weight:var(--wcss-heading-xs-weight, 300);letter-spacing:var(--wcss-heading-xs-letter-spacing, 0);line-height:var(--wcss-heading-xs-line-height, 1.3)}.heading-2xs{font-family:var(--wcss-heading-2xs-family, "AS Circular"),var(--wcss-heading-2xs-family-fallback, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif);font-size:var(--wcss-heading-2xs-font-size, clamp(1.125rem, 1.5vw, 1.125rem));font-weight:var(--wcss-heading-2xs-weight, 300);letter-spacing:var(--wcss-heading-2xs-letter-spacing, 0);line-height:var(--wcss-heading-2xs-line-height, 1.3)}.accent-2xl{font-family:var(--wcss-accent-2xl-family, "Good OT"),var(--wcss-accent-2xl-family-fallback, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif);font-size:var(--wcss-accent-2xl-font-size, clamp(2rem, 3.1666666667vw, 2.375rem));font-weight:var(--wcss-accent-2xl-weight, 450);letter-spacing:var(--wcss-accent-2xl-letter-spacing, 0.05em);line-height:var(--wcss-accent-2xl-line-height, 1)}.accent-2xl,.accent-xl{text-transform:uppercase}.accent-xl{font-family:var(--wcss-accent-xl-family, "Good OT"),var(--wcss-accent-xl-family-fallback, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif);font-size:var(--wcss-accent-xl-font-size, clamp(1.625rem, 2.3333333333vw, 2rem));font-weight:var(--wcss-accent-xl-weight, 450);letter-spacing:var(--wcss-accent-xl-letter-spacing, 0.05em);line-height:var(--wcss-accent-xl-line-height, 1.3)}.accent-lg{font-family:var(--wcss-accent-lg-family, "Good OT"),var(--wcss-accent-lg-family-fallback, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif);font-size:var(--wcss-accent-lg-font-size, clamp(1.5rem, 2.1666666667vw, 1.75rem));font-weight:var(--wcss-accent-lg-weight, 450);letter-spacing:var(--wcss-accent-lg-letter-spacing, 0.05em);line-height:var(--wcss-accent-lg-line-height, 1.3)}.accent-lg,.accent-md{text-transform:uppercase}.accent-md{font-family:var(--wcss-accent-md-family, "Good OT"),var(--wcss-accent-md-family-fallback, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif);font-size:var(--wcss-accent-md-font-size, clamp(1.375rem, 1.8333333333vw, 1.5rem));font-weight:var(--wcss-accent-md-weight, 500);letter-spacing:var(--wcss-accent-md-letter-spacing, 0.05em);line-height:var(--wcss-accent-md-line-height, 1.3)}.accent-sm{font-family:var(--wcss-accent-sm-family, "Good OT"),var(--wcss-accent-sm-family-fallback, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif);font-size:var(--wcss-accent-sm-font-size, clamp(1.125rem, 1.5vw, 1.25rem));font-weight:var(--wcss-accent-sm-weight, 500);letter-spacing:var(--wcss-accent-sm-letter-spacing, 0.05em);line-height:var(--wcss-accent-sm-line-height, 1.3)}.accent-sm,.accent-xs{text-transform:uppercase}.accent-xs{font-family:var(--wcss-accent-xs-family, "Good OT"),var(--wcss-accent-xs-family-fallback, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif);font-size:var(--wcss-accent-xs-font-size, clamp(1rem, 1.3333333333vw, 1rem));font-weight:var(--wcss-accent-xs-weight, 500);letter-spacing:var(--wcss-accent-xs-letter-spacing, 0.1em);line-height:var(--wcss-accent-xs-line-height, 1.3)}.accent-2xs{font-family:var(--wcss-accent-2xs-family, "Good OT"),var(--wcss-accent-2xs-family-fallback, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif);font-size:var(--wcss-accent-2xs-font-size, clamp(0.875rem, 1.1666666667vw, 0.875rem));font-weight:var(--wcss-accent-2xs-weight, 450);letter-spacing:var(--wcss-accent-2xs-letter-spacing, 0.1em);line-height:var(--wcss-accent-2xs-line-height, 1.3);text-transform:uppercase}[auro-dropdown]{--ds-auro-dropdown-trigger-border-color: var(--ds-auro-select-border-color);--ds-auro-dropdown-trigger-background-color: var(--ds-auro-select-background-color);--ds-auro-dropdown-trigger-container-color: var(--ds-auro-select-background-color);--ds-auro-dropdown-trigger-outline-color: var(--ds-auro-select-outline-color)}:host{display:inline-block;text-align:left;vertical-align:top}:host([layout*=emphasized]) [auro-dropdown],:host([layout*=snowflake]) [auro-dropdown]{--ds-auro-select-border-color: transparent}:host([layout*=emphasized]) .mainContent,:host([layout*=snowflake]) .mainContent{text-align:center}.mainContent{position:relative;display:flex;overflow:hidden;flex:1;flex-direction:column;align-items:center;justify-content:center}.valueContainer [slot=displayValue]{display:none}.accents{display:flex;flex-direction:row;align-items:center;justify-content:center}::slotted([slot=typeIcon]){margin-right:var(--ds-size-100, 0.5rem)}.displayValue{display:block}.displayValue:not(.force){display:none}.displayValue:not(.force).hasContent:is(.withValue):not(.hasFocus){display:block}.triggerContent{display:flex;width:100%;align-items:center;justify-content:center}:host([layout*=emphasized]) .triggerContent{padding:0 var(--ds-size-100, 0.5rem) 0 var(--ds-size-300, 1.5rem)}:host([layout*=snowflake]) .triggerContent{padding:0 var(--ds-size-100, 0.5rem) 0 var(--ds-size-200, 1rem)}:host([layout*=snowflake]) label{padding-block:var(--ds-size-25, 0.125rem)}:host([layout*=classic]) .triggerContent{padding:0 var(--ds-size-100, 0.5rem)}:host([layout*=classic]) .mainContent{align-items:start}:host([layout*=classic]) label{overflow:hidden;cursor:text;text-overflow:ellipsis;white-space:nowrap}:host([layout*=classic]) .value{height:auto}label{color:var(--ds-auro-select-label-text-color)}:host(:is([validity]:not([validity=valid]))) [auro-dropdown]{--ds-auro-select-border-color: var(--ds-basic-color-status-error, #e31f26);--ds-auro-select-outline-color: var(--ds-basic-color-status-error, #e31f26);--ds-auro-dropdown-helptext-text-color: var(--ds-basic-color-texticon-default, #2a2a2a)}:host([ondark]:is([validity]:not([validity=valid]))) [auro-dropdown],:host([appearance=inverse]:is([validity]:not([validity=valid]))) [auro-dropdown]{--ds-auro-select-border-color: var(--ds-advanced-color-state-error-inverse, #f9a4a8);--ds-auro-select-outline-color: var(--ds-advanced-color-state-error-inverse, #f9a4a8);--ds-auro-dropdown-helptext-text-color: var(--ds-basic-color-texticon-inverse, #ffffff)}#slotHolder{display:none}:host([fluid]){width:100%}:host([disabled]){pointer-events:none;user-select:none}:host([disabled]:not([ondark])) [auro-dropdown],:host([disabled]:not([appearance=inverse])) [auro-dropdown]{--ds-auro-select-border-color: var(--ds-basic-color-border-subtle, #dddddd)}:host(:not([layout*=classic])[disabled][ondark]) [auro-dropdown],:host(:not([layout*=classic])[disabled][appearance=inverse]) [auro-dropdown]{--ds-auro-select-border-color: transparent}`;
|
|
7027
7243
|
|