@mattilsynet/design 1.1.7 → 1.2.0
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/mtds/app/app-observer.js +1 -1
- package/mtds/app/app-toggle.js +26 -11
- package/mtds/app/app-toggle.js.map +1 -1
- package/mtds/app/app-toggle2.js +14 -27
- package/mtds/app/app-toggle2.js.map +1 -1
- package/mtds/app/app.js +1 -1
- package/mtds/badge/badge.stories.d.ts +1 -0
- package/mtds/external/@u-elements/u-combobox/dist/u-combobox.js +233 -0
- package/mtds/external/@u-elements/u-combobox/dist/u-combobox.js.map +1 -0
- package/mtds/external/@u-elements/u-datalist/dist/u-datalist.js +128 -155
- package/mtds/external/@u-elements/u-datalist/dist/u-datalist.js.map +1 -1
- package/mtds/field/field-observer.js +42 -34
- package/mtds/field/field-observer.js.map +1 -1
- package/mtds/field/field.d.ts +9 -5
- package/mtds/field/field.js +48 -48
- package/mtds/field/field.js.map +1 -1
- package/mtds/field/field.stories.d.ts +5 -3
- package/mtds/illustrations/illustrations.json +103 -58
- package/mtds/index.d.ts +1 -1
- package/mtds/index.iife.js +13 -6
- package/mtds/index.js +9 -9
- package/mtds/input/input.d.ts +2 -0
- package/mtds/input/input.js +15 -10
- package/mtds/input/input.js.map +1 -1
- package/mtds/logo-english.svg +1 -1
- package/mtds/logo-samisk.svg +1 -1
- package/mtds/logo.svg +1 -1
- package/mtds/matomo.d.ts +6 -0
- package/mtds/package.json.js +1 -1
- package/mtds/react.js +35 -34
- package/mtds/styles.css +1 -1
- package/mtds/styles.json +39 -39
- package/mtds/styles.module.css.js +76 -74
- package/mtds/styles.module.css.js.map +1 -1
- package/mtds/table/table.d.ts +2 -2
- package/mtds/table/table.js.map +1 -1
- package/mtds/utils.d.ts +1 -1
- package/mtds/utils.js +62 -61
- package/mtds/utils.js.map +1 -1
- package/package.json +22 -20
- package/mtds/external/@u-elements/u-tags/dist/u-tags.js +0 -365
- package/mtds/external/@u-elements/u-tags/dist/u-tags.js.map +0 -1
- package/mtds/field/field-helper.d.ts +0 -1
package/mtds/app/app-observer.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import m from "../styles.module.css.js";
|
|
2
2
|
import { onLoaded as C, onMutation as T, on as r, QUICK_EVENT as p, debounce as P } from "../utils.js";
|
|
3
|
-
import "./app-
|
|
3
|
+
import "./app-toggle2.js";
|
|
4
4
|
const f = m.app.split(" ")[0], _ = m.sticky.split(" ")[0], h = '[data-command="toggle-app-expanded"]', g = `.${f} > dialog,.${f} dialog ~ main`, S = (t) => {
|
|
5
5
|
document.startViewTransition ? document.startViewTransition(t) : t();
|
|
6
6
|
}, E = (t) => (
|
package/mtds/app/app-toggle.js
CHANGED
|
@@ -1,12 +1,27 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
1
|
+
const t = `if (
|
|
2
|
+
typeof window !== "undefined" &&
|
|
3
|
+
window.CSSStyleSheet &&
|
|
4
|
+
document.adoptedStyleSheets
|
|
5
|
+
)
|
|
6
|
+
(() => {
|
|
7
|
+
const key = "--mtds-app-expanded";
|
|
8
|
+
const sheet = new CSSStyleSheet();
|
|
9
|
+
const prev = () => !window.localStorage.getItem(key)?.includes("false");
|
|
10
|
+
|
|
11
|
+
document.adoptedStyleSheets.push(sheet);
|
|
12
|
+
window.mtdsToggleAppExpanded = (force) => {
|
|
13
|
+
try {
|
|
14
|
+
const next = force ?? !prev();
|
|
15
|
+
sheet.replaceSync?.(\`:root { \${key}: var(\${key}--\${next})}\`);
|
|
16
|
+
window.localStorage.setItem(key, next);
|
|
17
|
+
} catch (err) {} // localStorage is full or replaceSync is not supported
|
|
18
|
+
};
|
|
19
|
+
|
|
20
|
+
// Set and store initial state
|
|
21
|
+
window.mtdsToggleAppExpanded(prev());
|
|
22
|
+
})();
|
|
23
|
+
`;
|
|
24
|
+
export {
|
|
25
|
+
t as default
|
|
26
|
+
};
|
|
12
27
|
//# sourceMappingURL=app-toggle.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"app-toggle.js","sources":["../../designsystem/app/app-toggle.js"],"sourcesContent":["if (
|
|
1
|
+
{"version":3,"file":"app-toggle.js","sources":["../../designsystem/app/app-toggle.js?raw"],"sourcesContent":["export default \"if (\\n\\ttypeof window !== \\\"undefined\\\" &&\\n\\twindow.CSSStyleSheet &&\\n\\tdocument.adoptedStyleSheets\\n)\\n\\t(() => {\\n\\t\\tconst key = \\\"--mtds-app-expanded\\\";\\n\\t\\tconst sheet = new CSSStyleSheet();\\n\\t\\tconst prev = () => !window.localStorage.getItem(key)?.includes(\\\"false\\\");\\n\\n\\t\\tdocument.adoptedStyleSheets.push(sheet);\\n\\t\\twindow.mtdsToggleAppExpanded = (force) => {\\n\\t\\t\\ttry {\\n\\t\\t\\t\\tconst next = force ?? !prev();\\n\\t\\t\\t\\tsheet.replaceSync?.(`:root { ${key}: var(${key}--${next})}`);\\n\\t\\t\\t\\twindow.localStorage.setItem(key, next);\\n\\t\\t\\t} catch (err) {} // localStorage is full or replaceSync is not supported\\n\\t\\t};\\n\\n\\t\\t// Set and store initial state\\n\\t\\twindow.mtdsToggleAppExpanded(prev());\\n\\t})();\\n\""],"names":["script"],"mappings":"AAAA,MAAeA,IAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;"}
|
package/mtds/app/app-toggle2.js
CHANGED
|
@@ -1,28 +1,15 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
sheet.replaceSync?.(\`:root { \${key}: var(\${key}--\${next})}\`);
|
|
17
|
-
window.localStorage.setItem(key, next);
|
|
18
|
-
} catch (err) {} // LocalStorage is full or replaceSync is not supported
|
|
19
|
-
};
|
|
20
|
-
|
|
21
|
-
// Set and store initial state - double to get initial value
|
|
22
|
-
window.mtdsToggleAppExpanded(false);
|
|
23
|
-
})();
|
|
24
|
-
`;
|
|
25
|
-
export {
|
|
26
|
-
t as default
|
|
27
|
-
};
|
|
1
|
+
typeof window < "u" && window.CSSStyleSheet && document.adoptedStyleSheets && (() => {
|
|
2
|
+
const e = "--mtds-app-expanded", t = new CSSStyleSheet(), n = () => {
|
|
3
|
+
var d;
|
|
4
|
+
return !((d = window.localStorage.getItem(e)) != null && d.includes("false"));
|
|
5
|
+
};
|
|
6
|
+
document.adoptedStyleSheets.push(t), window.mtdsToggleAppExpanded = (d) => {
|
|
7
|
+
var p;
|
|
8
|
+
try {
|
|
9
|
+
const o = d ?? !n();
|
|
10
|
+
(p = t.replaceSync) == null || p.call(t, `:root { ${e}: var(${e}--${o})}`), window.localStorage.setItem(e, o);
|
|
11
|
+
} catch {
|
|
12
|
+
}
|
|
13
|
+
}, window.mtdsToggleAppExpanded(n());
|
|
14
|
+
})();
|
|
28
15
|
//# sourceMappingURL=app-toggle2.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"app-toggle2.js","sources":["../../designsystem/app/app-toggle.js
|
|
1
|
+
{"version":3,"file":"app-toggle2.js","sources":["../../designsystem/app/app-toggle.js"],"sourcesContent":["if (\n\ttypeof window !== \"undefined\" &&\n\twindow.CSSStyleSheet &&\n\tdocument.adoptedStyleSheets\n)\n\t(() => {\n\t\tconst key = \"--mtds-app-expanded\";\n\t\tconst sheet = new CSSStyleSheet();\n\t\tconst prev = () => !window.localStorage.getItem(key)?.includes(\"false\");\n\n\t\tdocument.adoptedStyleSheets.push(sheet);\n\t\twindow.mtdsToggleAppExpanded = (force) => {\n\t\t\ttry {\n\t\t\t\tconst next = force ?? !prev();\n\t\t\t\tsheet.replaceSync?.(`:root { ${key}: var(${key}--${next})}`);\n\t\t\t\twindow.localStorage.setItem(key, next);\n\t\t\t} catch (err) {} // localStorage is full or replaceSync is not supported\n\t\t};\n\n\t\t// Set and store initial state\n\t\twindow.mtdsToggleAppExpanded(prev());\n\t})();\n"],"names":["key","sheet","prev","_a","force","next"],"mappings":"AACC,OAAO,SAAW,OAClB,OAAO,iBACP,SAAS,uBAER,MAAM;AACN,QAAMA,IAAM,uBACNC,IAAQ,IAAI,cAAe,GAC3BC,IAAO,MAAM;AARrB,QAAAC;AAQqB,cAACA,IAAA,OAAO,aAAa,QAAQH,CAAG,MAA/B,QAAAG,EAAkC,SAAS;AAAA;AAE/D,WAAS,mBAAmB,KAAKF,CAAK,GACtC,OAAO,wBAAwB,CAACG,MAAU;AAX5C,QAAAD;AAYG,QAAI;AACH,YAAME,IAAOD,KAAS,CAACF,EAAM;AAC7B,OAAAC,IAAAF,EAAM,gBAAN,QAAAE,EAAA,KAAAF,GAAoB,WAAWD,CAAG,SAASA,CAAG,KAAKK,CAAI,OACvD,OAAO,aAAa,QAAQL,GAAKK,CAAI;AAAA,IACzC,QAAiB;AAAA,IAAE;AAAA,EAChB,GAGD,OAAO,sBAAsBH,GAAM;AACrC,GAAK;"}
|
package/mtds/app/app.js
CHANGED
|
@@ -2,7 +2,7 @@ import { jsx as o } from "react/jsx-runtime";
|
|
|
2
2
|
import { clsx as a } from "../external/clsx/dist/clsx.js";
|
|
3
3
|
import { forwardRef as p } from "react";
|
|
4
4
|
import c from "../styles.module.css.js";
|
|
5
|
-
import m from "./app-
|
|
5
|
+
import m from "./app-toggle.js";
|
|
6
6
|
const f = p(function({ as: r, className: t, ...n }, e) {
|
|
7
7
|
return /* @__PURE__ */ o(r || "div", { className: a(c.app, t), ref: e, ...n });
|
|
8
8
|
}), d = p(function({ as: r, className: t, ...n }, e) {
|
|
@@ -0,0 +1,233 @@
|
|
|
1
|
+
var W = Object.defineProperty, N = Object.getOwnPropertySymbols, Y = Object.prototype.hasOwnProperty, z = Object.prototype.propertyIsEnumerable, R = (t, e, o) => e in t ? W(t, e, { enumerable: !0, configurable: !0, writable: !0, value: o }) : t[e] = o, G = (t, e) => {
|
|
2
|
+
for (var o in e || (e = {}))
|
|
3
|
+
Y.call(e, o) && R(t, o, e[o]);
|
|
4
|
+
if (N)
|
|
5
|
+
for (var o of N(e))
|
|
6
|
+
z.call(e, o) && R(t, o, e[o]);
|
|
7
|
+
return t;
|
|
8
|
+
}, C = typeof window < "u" && typeof window.document < "u" && typeof window.navigator < "u", B = C && /android/i.test(navigator.userAgent), J = C && /firefox/i.test(navigator.userAgent), Q = C && /iPad|iPhone|iPod/.test(navigator.userAgent), P;
|
|
9
|
+
C && // @ts-expect-error Typescript has not implemented userAgentData yet https://stackoverflow.com/a/71392474
|
|
10
|
+
/^Mac/i.test(((P = navigator.userAgentData) == null ? void 0 : P.platform) || navigator.platform);
|
|
11
|
+
var Z = "outline: 1px dotted; outline: 5px auto Highlight; outline: 5px auto -webkit-focus-ring-color", tt = typeof HTMLElement > "u" ? class {
|
|
12
|
+
} : HTMLElement;
|
|
13
|
+
function u(t, e, o) {
|
|
14
|
+
return o === void 0 ? t.getAttribute(e) : (o === null ? t.removeAttribute(e) : t.getAttribute(e) !== o && t.setAttribute(e, o), null);
|
|
15
|
+
}
|
|
16
|
+
var F = (t, e, o) => {
|
|
17
|
+
for (const n of o[0].split(","))
|
|
18
|
+
o[0] = n, Element.prototype[`${t}EventListener`].apply(e, o);
|
|
19
|
+
}, V = (t, ...e) => F("add", t, e), et = (t, ...e) => F("remove", t, e), I = /* @__PURE__ */ new WeakMap(), $ = (t, e) => {
|
|
20
|
+
if (e === void 0) return I.get(t);
|
|
21
|
+
try {
|
|
22
|
+
I.get(t).disconnect(), I.delete(t);
|
|
23
|
+
} catch {
|
|
24
|
+
}
|
|
25
|
+
if (e) {
|
|
26
|
+
const o = new MutationObserver(
|
|
27
|
+
(n) => t.handleEvent({ type: "mutation", detail: n })
|
|
28
|
+
);
|
|
29
|
+
o.observe(t, e), I.set(t, o);
|
|
30
|
+
}
|
|
31
|
+
}, ot = (t) => {
|
|
32
|
+
const e = "key" in t && (t.key === " " || t.key === "Enter");
|
|
33
|
+
return e && t.preventDefault(), e && t.target instanceof HTMLElement && t.target.click(), e;
|
|
34
|
+
}, it = (t) => {
|
|
35
|
+
var e;
|
|
36
|
+
const o = ((e = t.getRootNode) == null ? void 0 : e.call(t)) || t.ownerDocument;
|
|
37
|
+
return o instanceof Document || o instanceof ShadowRoot ? o : document;
|
|
38
|
+
}, nt = 0, rt = (t) => t ? (t.id || (t.id = `:${t.nodeName.toLowerCase()}${(++nt).toString(32)}`), t.id) : "", w = (t, e, o) => {
|
|
39
|
+
const n = document.createElement(t);
|
|
40
|
+
if (e && (n.textContent = e), o) for (const [i, r] of Object.entries(o)) u(n, i, r);
|
|
41
|
+
return n;
|
|
42
|
+
}, at = {
|
|
43
|
+
define: (t, e) => !C || window.customElements.get(t) || window.customElements.define(t, e)
|
|
44
|
+
}, lt = (t) => {
|
|
45
|
+
const e = w("div");
|
|
46
|
+
return e.style.cssText = "position:fixed;overflow:hidden;width:1px;white-space:nowrap", u(e, "aria-live", t), e;
|
|
47
|
+
}, st = (t, e, o = "") => {
|
|
48
|
+
var n, i;
|
|
49
|
+
const r = { bubbles: !0, composed: !0, data: e, inputType: o }, l = HTMLInputElement.prototype;
|
|
50
|
+
t.dispatchEvent(new InputEvent("beforeinput", r)), (i = (n = Object.getOwnPropertyDescriptor(l, "value")) == null ? void 0 : n.set) == null || i.call(t, e), t.dispatchEvent(new InputEvent("input", r)), t.dispatchEvent(new Event("change", { bubbles: !0 }));
|
|
51
|
+
}, b, ut = 0, L = !1, H = "blur,focus,click,input,keydown,mousedown,mouseup", dt = { once: !0, passive: !0 }, ct = J && !B, vt = B || Q, x = "false", pt = "insertReplacementText", k = {
|
|
52
|
+
added: "Added",
|
|
53
|
+
empty: "No selected",
|
|
54
|
+
found: "Navigate left to find %d selected",
|
|
55
|
+
invalid: "Invalid value",
|
|
56
|
+
of: "of",
|
|
57
|
+
remove: "Press to remove",
|
|
58
|
+
removed: "Removed"
|
|
59
|
+
}, mt = class extends tt {
|
|
60
|
+
constructor() {
|
|
61
|
+
super(), this._speak = "", this._texts = G({}, k), this._value = "", this.attachShadow({ mode: "open" }).append(
|
|
62
|
+
w("slot"),
|
|
63
|
+
// Content slot
|
|
64
|
+
w(
|
|
65
|
+
"style",
|
|
66
|
+
`:host(:not([hidden])) { display: block; cursor: pointer } /* Must be display block in Safari to allow focus inside */
|
|
67
|
+
:host(:not([data-multiple])) ::slotted(data),
|
|
68
|
+
:host([data-multiple="false"]) ::slotted(data) { display: none } /* Hide data if not multiple */
|
|
69
|
+
::slotted(data) { display: inline-block; pointer-events: none }
|
|
70
|
+
::slotted(data)::after { content: '\\00D7'; content: '\\00D7' / ''; padding-inline: .5ch; pointer-events: auto }
|
|
71
|
+
::slotted(data:focus) { ${Z} }`
|
|
72
|
+
// Show focus outline around ::after only
|
|
73
|
+
)
|
|
74
|
+
);
|
|
75
|
+
}
|
|
76
|
+
// Locally store value to store value before input-click
|
|
77
|
+
// Using ES2015 syntax for backwards compatibility
|
|
78
|
+
static get observedAttributes() {
|
|
79
|
+
return Object.keys(k).map((t) => `data-sr-${t}`);
|
|
80
|
+
}
|
|
81
|
+
connectedCallback() {
|
|
82
|
+
this._root = it(this), V(this, H, this, !0), $(this, { childList: !0 }), setTimeout(E, 0, this), setTimeout(S, 0, this);
|
|
83
|
+
}
|
|
84
|
+
attributeChangedCallback(t, e, o) {
|
|
85
|
+
const n = t.split("data-sr-")[1];
|
|
86
|
+
k[n] && (this._texts[n] = o || k[n]);
|
|
87
|
+
}
|
|
88
|
+
disconnectedCallback() {
|
|
89
|
+
j(this), $(this, !1), et(this, H, this, !0), this._root = void 0;
|
|
90
|
+
}
|
|
91
|
+
handleEvent(t) {
|
|
92
|
+
const e = t.target;
|
|
93
|
+
t.type === "blur" && ht(this), t.type === "click" && bt(this, t), t.type === "focus" && ft(this, t), t.type === "input" && gt(this, t), t.type === "keydown" && yt(this, t), t.type === "mousedown" && (L = this.contains(e)), t.type === "mouseup" && (L = !1), t.type === "mutation" && E(this, t);
|
|
94
|
+
}
|
|
95
|
+
get multiple() {
|
|
96
|
+
var t;
|
|
97
|
+
return ((t = u(this, "data-multiple")) != null ? t : x) !== x;
|
|
98
|
+
}
|
|
99
|
+
set multiple(t) {
|
|
100
|
+
u(this, "data-multiple", t ? "" : null);
|
|
101
|
+
}
|
|
102
|
+
get creatable() {
|
|
103
|
+
var t;
|
|
104
|
+
return ((t = u(this, "data-creatable")) != null ? t : x) !== x;
|
|
105
|
+
}
|
|
106
|
+
set creatable(t) {
|
|
107
|
+
u(this, "data-creatable", t ? "" : null);
|
|
108
|
+
}
|
|
109
|
+
get control() {
|
|
110
|
+
return this._control || this.querySelector("input");
|
|
111
|
+
}
|
|
112
|
+
get list() {
|
|
113
|
+
return this._list || this.querySelector("u-datalist,datalist") || null;
|
|
114
|
+
}
|
|
115
|
+
get items() {
|
|
116
|
+
return this._items || this.getElementsByTagName("data");
|
|
117
|
+
}
|
|
118
|
+
get options() {
|
|
119
|
+
var t, e;
|
|
120
|
+
const o = `${((t = this.list) == null ? void 0 : t.nodeName) === "U-DATALIST" ? "u-" : ""}option`;
|
|
121
|
+
return this._options || ((e = this.list) == null ? void 0 : e.getElementsByTagName(o));
|
|
122
|
+
}
|
|
123
|
+
get values() {
|
|
124
|
+
return [...this.items].map(({ value: t }) => t);
|
|
125
|
+
}
|
|
126
|
+
add(t) {
|
|
127
|
+
var e;
|
|
128
|
+
const o = M(t);
|
|
129
|
+
this.values.includes(o.value) || // Prevent duplicates
|
|
130
|
+
((e = this.control) == null || e.insertAdjacentElement("beforebegin", o));
|
|
131
|
+
}
|
|
132
|
+
}, _ = (t) => {
|
|
133
|
+
var e;
|
|
134
|
+
return ((e = t == null ? void 0 : t.textContent) == null ? void 0 : e.trim()) || "";
|
|
135
|
+
}, M = (t) => typeof t == "string" ? w("data", t, { value: t }) : t instanceof HTMLDataElement ? t : w("data", t.label || t.value, {
|
|
136
|
+
value: t.value || t.label || ""
|
|
137
|
+
}), j = (t) => {
|
|
138
|
+
t._focus = t._control = t._items = t._list = t._options = void 0;
|
|
139
|
+
}, E = (t, e) => {
|
|
140
|
+
var o, n, i;
|
|
141
|
+
let { _focus: r, _speak: l, _texts: d, items: m, control: a, list: v, multiple: c } = t;
|
|
142
|
+
const { addedNodes: p, removedNodes: T } = (e == null ? void 0 : e.detail[0]) || {}, f = (e == null ? void 0 : e.detail[1]) || (p == null ? void 0 : p[1]) || (p == null ? void 0 : p[1]) ? null : (p == null ? void 0 : p[0]) || (T == null ? void 0 : T[0]), A = c ? m.length : 1, O = [];
|
|
143
|
+
(f == null ? void 0 : f.nodeName) === "DATA" && (c ? r : f === r) && (l = `${d[f.isConnected ? "added" : "removed"]} ${_(f)}, `, (vt || r === a) && (b.textContent = l), a == null || a.focus(), setTimeout(() => {
|
|
144
|
+
var s, h;
|
|
145
|
+
(h = (s = (r == null ? void 0 : r.nodeName) === "DATA" ? a : r) == null ? void 0 : s.focus) == null || h.call(s), t._speak = "", ct ? V(t, "blur", () => E(t), dt) : setTimeout(E, 100, t);
|
|
146
|
+
}, 100));
|
|
147
|
+
const q = f != null && f.isConnected ? f : m[0];
|
|
148
|
+
for (const s of m)
|
|
149
|
+
if (!c && s !== q) s.remove();
|
|
150
|
+
else {
|
|
151
|
+
const h = _(s), D = s.value || h, X = `${l}${h}, ${d.remove}, ${O.push(D)} ${d.of} ${A}`;
|
|
152
|
+
u(s, "role", "button"), u(s, "value", D), u(s, "tabindex", "-1"), u(s, "aria-label", X);
|
|
153
|
+
}
|
|
154
|
+
for (const s of t.options || []) {
|
|
155
|
+
const h = (o = u(s, "value")) != null ? o : _(s);
|
|
156
|
+
u(s, "aria-label", l ? `${l}${_(s)}` : null), u(s, "selected", O.includes(h) ? "" : null);
|
|
157
|
+
}
|
|
158
|
+
const U = `${l}${_((n = a == null ? void 0 : a.labels) == null ? void 0 : n[0])}, ${c ? A ? d.found.replace("%d", `${A}`) : d.empty : ""}`;
|
|
159
|
+
v && u(v, "aria-multiselectable", `${c}`), a && u(a, "list", rt(v)), a && u(a, "aria-label", U), a && (t._value = a.value);
|
|
160
|
+
const g = t.querySelector("select");
|
|
161
|
+
g && (g.multiple = c);
|
|
162
|
+
for (const s of (g == null ? void 0 : g.options) || []) s.remove();
|
|
163
|
+
g == null || g.append(...O.map((s) => new Option("", s, !0, !0))), (i = $(t)) == null || i.takeRecords();
|
|
164
|
+
}, S = (t, e) => {
|
|
165
|
+
const { multiple: o, control: n, items: i } = t;
|
|
166
|
+
if (!(o || !n || !i[0])) {
|
|
167
|
+
if (e) return st(n, _(t.items[0]), "insertText");
|
|
168
|
+
n.value = _(t.items[0]);
|
|
169
|
+
}
|
|
170
|
+
}, K = (t) => {
|
|
171
|
+
var e;
|
|
172
|
+
const { options: o = [], creatable: n, control: i, items: r, multiple: l } = t, d = ((e = i == null ? void 0 : i.value) == null ? void 0 : e.trim()) || "", m = d.toLowerCase() || null;
|
|
173
|
+
let a = [...o].find((c) => c.label.trim().toLowerCase() === m);
|
|
174
|
+
const v = { bubbles: !0, cancelable: !0, detail: a };
|
|
175
|
+
if (t.dispatchEvent(new CustomEvent("beforematch", v)))
|
|
176
|
+
for (const c of o) c.selected = c === a;
|
|
177
|
+
if (a = [...o].find((c) => c.selected), !a && n && d)
|
|
178
|
+
return y(t, M(d));
|
|
179
|
+
if (!a && !l && r[0]) return y(t, r[0]);
|
|
180
|
+
if (!a || t.values.includes(a.value)) return E(t);
|
|
181
|
+
y(t, a, !1);
|
|
182
|
+
}, y = (t, e, o = !0) => {
|
|
183
|
+
const n = M(e), i = [...t.items].find((l) => l.value === e.value), r = { bubbles: !0, cancelable: !0, detail: i || n };
|
|
184
|
+
if (!(i && !o)) {
|
|
185
|
+
if (!t.dispatchEvent(new CustomEvent("beforechange", r)))
|
|
186
|
+
return E(t);
|
|
187
|
+
i ? i.remove() : t.add(n), t.dispatchEvent(new CustomEvent("afterchange", r));
|
|
188
|
+
}
|
|
189
|
+
}, ft = (t, { target: e }) => {
|
|
190
|
+
b || (b = lt("assertive")), b.isConnected || document.body.appendChild(b), e instanceof HTMLElement && (t._focus = e), t._items || (t._control = t.control || void 0, t._items = t.items, t._list = t.list || void 0, t._options = t.options || void 0);
|
|
191
|
+
}, ht = (t) => L || setTimeout(_t, 0, t), _t = (t) => {
|
|
192
|
+
var e;
|
|
193
|
+
!t._focus || t.contains((e = t._root) == null ? void 0 : e.activeElement) || (S(t, !0), j(t));
|
|
194
|
+
}, bt = (t, e) => {
|
|
195
|
+
var o;
|
|
196
|
+
const { clientX: n, clientY: i, target: r } = e;
|
|
197
|
+
for (const l of t.items) {
|
|
198
|
+
const { top: d, right: m, bottom: a, left: v } = l.getBoundingClientRect();
|
|
199
|
+
if (l.contains(r)) return y(t, l);
|
|
200
|
+
if (i >= d && i <= a && n >= v && n <= m) return l.focus();
|
|
201
|
+
}
|
|
202
|
+
r === t && ((o = t.control) == null || o.focus());
|
|
203
|
+
}, gt = (t, e) => {
|
|
204
|
+
var o;
|
|
205
|
+
const { options: n = [], control: i, multiple: r } = t, l = ((o = i == null ? void 0 : i.value) == null ? void 0 : o.trim()) || "";
|
|
206
|
+
if (!(e instanceof InputEvent ? !e.inputType || e.inputType === pt : !!l)) return r || K(t);
|
|
207
|
+
e.stopImmediatePropagation(), i && (i.value = t._value);
|
|
208
|
+
for (const m of n)
|
|
209
|
+
if (m.value && m.value === l)
|
|
210
|
+
return y(t, m, r), setTimeout(S, 0, t, !0);
|
|
211
|
+
}, yt = (t, e) => {
|
|
212
|
+
var o;
|
|
213
|
+
if (e.altKey || e.ctrlKey || e.metaKey || e.shiftKey) return;
|
|
214
|
+
const { _texts: n, control: i, items: r, multiple: l } = t, { key: d, repeat: m, target: a } = e, v = i && i === a, c = v && (i == null ? void 0 : i.selectionEnd);
|
|
215
|
+
let p = v ? r.length : [...r].indexOf(a);
|
|
216
|
+
if (!(p === -1 || !v && ot(e))) {
|
|
217
|
+
if (d === "ArrowRight" && !v) p += 1;
|
|
218
|
+
else if (d === "ArrowLeft" && !c) p -= 1;
|
|
219
|
+
else if (d === "Enter" && v) {
|
|
220
|
+
const T = u(i, "form");
|
|
221
|
+
return u(i, "form", "#"), requestAnimationFrame(() => u(i, "form", T)), l ? K(t) : !t.items[0] && b && (b.textContent = `${n.invalid}${++ut % 2 ? " " : ""}`), S(t, !0);
|
|
222
|
+
} else if ((d === "Backspace" || d === "Delete") && !c) {
|
|
223
|
+
if (e.preventDefault(), !m && r[p]) return y(t, r[p]);
|
|
224
|
+
v && (p -= 1);
|
|
225
|
+
} else return v || (i == null ? void 0 : i.focus());
|
|
226
|
+
e.preventDefault(), (o = r[Math.max(0, p)] || i) == null || o.focus();
|
|
227
|
+
}
|
|
228
|
+
};
|
|
229
|
+
at.define("u-combobox", mt);
|
|
230
|
+
export {
|
|
231
|
+
mt as UHTMLComboboxElement
|
|
232
|
+
};
|
|
233
|
+
//# sourceMappingURL=u-combobox.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"u-combobox.js","sources":["../../../../../node_modules/@u-elements/u-combobox/dist/u-combobox.js"],"sourcesContent":["var __defProp = Object.defineProperty;\nvar __getOwnPropSymbols = Object.getOwnPropertySymbols;\nvar __hasOwnProp = Object.prototype.hasOwnProperty;\nvar __propIsEnum = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp.call(b, prop))\n __defNormalProp(a, prop, b[prop]);\n if (__getOwnPropSymbols)\n for (var prop of __getOwnPropSymbols(b)) {\n if (__propIsEnum.call(b, prop))\n __defNormalProp(a, prop, b[prop]);\n }\n return a;\n};\n\n// ../utils.ts\nvar IS_BROWSER = typeof window !== \"undefined\" && typeof window.document !== \"undefined\" && typeof window.navigator !== \"undefined\";\nvar IS_ANDROID = IS_BROWSER && /android/i.test(navigator.userAgent);\nvar IS_FIREFOX = IS_BROWSER && /firefox/i.test(navigator.userAgent);\nvar IS_IOS = IS_BROWSER && /iPad|iPhone|iPod/.test(navigator.userAgent);\nvar _a;\nIS_BROWSER && // @ts-expect-error Typescript has not implemented userAgentData yet https://stackoverflow.com/a/71392474\n/^Mac/i.test(((_a = navigator.userAgentData) == null ? void 0 : _a.platform) || navigator.platform);\nvar FOCUS_OUTLINE = \"outline: 1px dotted; outline: 5px auto Highlight; outline: 5px auto -webkit-focus-ring-color\";\nvar UHTMLElement = typeof HTMLElement === \"undefined\" ? class {\n} : HTMLElement;\nfunction attr(el, name, value) {\n if (value === void 0) return el.getAttribute(name);\n if (value === null) el.removeAttribute(name);\n else if (el.getAttribute(name) !== value) el.setAttribute(name, value);\n return null;\n}\nvar events = (action, element, rest) => {\n for (const type of rest[0].split(\",\")) {\n rest[0] = type;\n Element.prototype[`${action}EventListener`].apply(element, rest);\n }\n};\nvar on = (element, ...rest) => events(\"add\", element, rest);\nvar off = (element, ...rest) => events(\"remove\", element, rest);\nvar observers = /* @__PURE__ */ new WeakMap();\nvar mutationObserver = (element, options) => {\n if (options === void 0) return observers.get(element);\n try {\n observers.get(element).disconnect();\n observers.delete(element);\n } catch (err) {\n }\n if (options) {\n const observer = new MutationObserver(\n (detail) => element.handleEvent({ type: \"mutation\", detail })\n );\n observer.observe(element, options);\n observers.set(element, observer);\n }\n};\nvar asButton = (event) => {\n const isClick = \"key\" in event && (event.key === \" \" || event.key === \"Enter\");\n if (isClick) event.preventDefault();\n if (isClick && event.target instanceof HTMLElement) event.target.click();\n return isClick;\n};\nvar getRoot = (node) => {\n var _a2;\n const root = ((_a2 = node.getRootNode) == null ? void 0 : _a2.call(node)) || node.ownerDocument;\n return root instanceof Document || root instanceof ShadowRoot ? root : document;\n};\nvar id = 0;\nvar useId = (el) => {\n if (!el) return \"\";\n if (!el.id) el.id = `:${el.nodeName.toLowerCase()}${(++id).toString(32)}`;\n return el.id;\n};\nvar createElement = (tagName, text2, attrs) => {\n const el = document.createElement(tagName);\n if (text2) el.textContent = text2;\n if (attrs) for (const [key, val] of Object.entries(attrs)) attr(el, key, val);\n return el;\n};\nvar customElements = {\n define: (name, instance) => !IS_BROWSER || window.customElements.get(name) || window.customElements.define(name, instance)\n};\nvar createAriaLive = (mode) => {\n const live = createElement(\"div\");\n live.style.cssText = \"position:fixed;overflow:hidden;width:1px;white-space:nowrap\";\n attr(live, \"aria-live\", mode);\n return live;\n};\nvar setValue = (input, data, type = \"\") => {\n var _a2, _b;\n const event = { bubbles: true, composed: true, data, inputType: type };\n const proto = HTMLInputElement.prototype;\n input.dispatchEvent(new InputEvent(\"beforeinput\", event));\n (_b = (_a2 = Object.getOwnPropertyDescriptor(proto, \"value\")) == null ? void 0 : _a2.set) == null ? void 0 : _b.call(input, data);\n input.dispatchEvent(new InputEvent(\"input\", event));\n input.dispatchEvent(new Event(\"change\", { bubbles: true }));\n};\n\n// u-combobox.ts\nvar LIVE;\nvar LIVE_SR_FIX = 0;\nvar IS_PRESS = false;\nvar EVENTS = \"blur,focus,click,input,keydown,mousedown,mouseup\";\nvar EVENT_ONCE = { once: true, passive: true };\nvar IS_FIREFOX_MAC = IS_FIREFOX && !IS_ANDROID;\nvar IS_MOBILE = IS_ANDROID || IS_IOS;\nvar FALSE = \"false\";\nvar CLICK = \"insertReplacementText\";\nvar TEXTS = {\n added: \"Added\",\n empty: \"No selected\",\n found: \"Navigate left to find %d selected\",\n invalid: \"Invalid value\",\n of: \"of\",\n remove: \"Press to remove\",\n removed: \"Removed\"\n};\nvar UHTMLComboboxElement = class extends UHTMLElement {\n constructor() {\n super();\n this._speak = \"\";\n this._texts = __spreadValues({}, TEXTS);\n this._value = \"\";\n this.attachShadow({ mode: \"open\" }).append(\n createElement(\"slot\"),\n // Content slot\n createElement(\n \"style\",\n `:host(:not([hidden])) { display: block; cursor: pointer } /* Must be display block in Safari to allow focus inside */\n\t\t\t\t:host(:not([data-multiple])) ::slotted(data),\n\t\t\t\t:host([data-multiple=\"false\"]) ::slotted(data) { display: none } /* Hide data if not multiple */\n\t\t\t\t::slotted(data) { display: inline-block; pointer-events: none }\n ::slotted(data)::after { content: '\\\\00D7'; content: '\\\\00D7' / ''; padding-inline: .5ch; pointer-events: auto }\n ::slotted(data:focus) { ${FOCUS_OUTLINE} }`\n // Show focus outline around ::after only\n )\n );\n }\n // Locally store value to store value before input-click\n // Using ES2015 syntax for backwards compatibility\n static get observedAttributes() {\n return Object.keys(TEXTS).map((key) => `data-sr-${key}`);\n }\n connectedCallback() {\n this._root = getRoot(this);\n on(this, EVENTS, this, true);\n mutationObserver(this, { childList: true });\n setTimeout(render, 0, this);\n setTimeout(syncInputValue, 0, this);\n }\n attributeChangedCallback(prop, _, val) {\n const text2 = prop.split(\"data-sr-\")[1];\n if (TEXTS[text2]) this._texts[text2] = val || TEXTS[text2];\n }\n disconnectedCallback() {\n disconnectCache(this);\n mutationObserver(this, false);\n off(this, EVENTS, this, true);\n this._root = void 0;\n }\n handleEvent(event) {\n const target = event.target;\n if (event.type === \"blur\") onBlur(this);\n if (event.type === \"click\") onClick(this, event);\n if (event.type === \"focus\") onFocus(this, event);\n if (event.type === \"input\") onInput(this, event);\n if (event.type === \"keydown\") onKeyDown(this, event);\n if (event.type === \"mousedown\") IS_PRESS = this.contains(target);\n if (event.type === \"mouseup\") IS_PRESS = false;\n if (event.type === \"mutation\") render(this, event);\n }\n get multiple() {\n var _a2;\n return ((_a2 = attr(this, \"data-multiple\")) != null ? _a2 : FALSE) !== FALSE;\n }\n set multiple(value) {\n attr(this, \"data-multiple\", value ? \"\" : null);\n }\n get creatable() {\n var _a2;\n return ((_a2 = attr(this, \"data-creatable\")) != null ? _a2 : FALSE) !== FALSE;\n }\n set creatable(value) {\n attr(this, \"data-creatable\", value ? \"\" : null);\n }\n get control() {\n return this._control || this.querySelector(\"input\");\n }\n get list() {\n return this._list || this.querySelector(\"u-datalist,datalist\") || null;\n }\n get items() {\n return this._items || this.getElementsByTagName(\"data\");\n }\n get options() {\n var _a2, _b;\n const tag = `${((_a2 = this.list) == null ? void 0 : _a2.nodeName) === \"U-DATALIST\" ? \"u-\" : \"\"}option`;\n return this._options || ((_b = this.list) == null ? void 0 : _b.getElementsByTagName(tag));\n }\n get values() {\n return [...this.items].map(({ value }) => value);\n }\n add(value) {\n var _a2;\n const item = createItem(value);\n this.values.includes(item.value) || // Prevent duplicates\n ((_a2 = this.control) == null ? void 0 : _a2.insertAdjacentElement(\"beforebegin\", item));\n }\n};\nvar text = (el) => {\n var _a2;\n return ((_a2 = el == null ? void 0 : el.textContent) == null ? void 0 : _a2.trim()) || \"\";\n};\nvar createItem = (value) => {\n if (typeof value === \"string\") return createElement(\"data\", value, { value });\n if (value instanceof HTMLDataElement) return value;\n return createElement(\"data\", value.label || value.value, {\n value: value.value || value.label || \"\"\n });\n};\nvar disconnectCache = (el) => {\n el._focus = el._control = el._items = el._list = el._options = void 0;\n};\nvar render = (self, e) => {\n var _a2, _b, _c;\n let { _focus, _speak, _texts, items, control, list, multiple } = self;\n const { addedNodes, removedNodes } = (e == null ? void 0 : e.detail[0]) || {};\n const isMultiEdit = (e == null ? void 0 : e.detail[1]) || (addedNodes == null ? void 0 : addedNodes[1]) || (addedNodes == null ? void 0 : addedNodes[1]);\n const edit = isMultiEdit ? null : (addedNodes == null ? void 0 : addedNodes[0]) || (removedNodes == null ? void 0 : removedNodes[0]);\n const total = multiple ? items.length : 1;\n const values = [];\n if ((edit == null ? void 0 : edit.nodeName) === \"DATA\" && (multiple ? _focus : edit === _focus)) {\n _speak = `${_texts[edit.isConnected ? \"added\" : \"removed\"]} ${text(edit)}, `;\n if (IS_MOBILE || _focus === control) LIVE.textContent = _speak;\n control == null ? void 0 : control.focus();\n setTimeout(() => {\n var _a3, _b2;\n (_b2 = (_a3 = (_focus == null ? void 0 : _focus.nodeName) === \"DATA\" ? control : _focus) == null ? void 0 : _a3.focus) == null ? void 0 : _b2.call(_a3);\n self._speak = \"\";\n if (IS_FIREFOX_MAC) on(self, \"blur\", () => render(self), EVENT_ONCE);\n else setTimeout(render, 100, self);\n }, 100);\n }\n const keep = (edit == null ? void 0 : edit.isConnected) ? edit : items[0];\n for (const item of items) {\n if (!multiple && item !== keep) item.remove();\n else {\n const label2 = text(item);\n const value = item.value || label2;\n const aria = `${_speak}${label2}, ${_texts.remove}, ${values.push(value)} ${_texts.of} ${total}`;\n attr(item, \"role\", \"button\");\n attr(item, \"value\", value);\n attr(item, \"tabindex\", \"-1\");\n attr(item, \"aria-label\", aria);\n }\n }\n for (const opt of self.options || []) {\n const value = (_a2 = attr(opt, \"value\")) != null ? _a2 : text(opt);\n attr(opt, \"aria-label\", _speak ? `${_speak}${text(opt)}` : null);\n attr(opt, \"selected\", values.includes(value) ? \"\" : null);\n }\n const label = `${_speak}${text((_b = control == null ? void 0 : control.labels) == null ? void 0 : _b[0])}, ${multiple ? total ? _texts.found.replace(\"%d\", `${total}`) : _texts.empty : \"\"}`;\n if (list) attr(list, \"aria-multiselectable\", `${multiple}`);\n if (control) attr(control, \"list\", useId(list));\n if (control) attr(control, \"aria-label\", label);\n if (control) self._value = control.value;\n const select = self.querySelector(\"select\");\n if (select) select.multiple = multiple;\n for (const opt of (select == null ? void 0 : select.options) || []) opt.remove();\n select == null ? void 0 : select.append(...values.map((value) => new Option(\"\", value, true, true)));\n (_c = mutationObserver(self)) == null ? void 0 : _c.takeRecords();\n};\nvar syncInputValue = (self, withEvent) => {\n const { multiple, control, items } = self;\n if (multiple || !control || !items[0]) return;\n if (withEvent) return setValue(control, text(self.items[0]), \"insertText\");\n control.value = text(self.items[0]);\n};\nvar dispatchMatch = (self) => {\n var _a2;\n const { options = [], creatable, control, items, multiple } = self;\n const value = ((_a2 = control == null ? void 0 : control.value) == null ? void 0 : _a2.trim()) || \"\";\n const query = value.toLowerCase() || null;\n let match = [...options].find((o) => o.label.trim().toLowerCase() === query);\n const event = { bubbles: true, cancelable: true, detail: match };\n if (self.dispatchEvent(new CustomEvent(\"beforematch\", event)))\n for (const opt of options) opt.selected = opt === match;\n match = [...options].find((o) => o.selected);\n if (!match && creatable && value)\n return dispatchChange(self, createItem(value));\n if (!match && !multiple && items[0]) return dispatchChange(self, items[0]);\n if (!match || self.values.includes(match.value)) return render(self);\n dispatchChange(self, match, false);\n};\nvar dispatchChange = (self, item, removeable = true) => {\n const add = createItem(item);\n const remove = [...self.items].find((i) => i.value === item.value);\n const event = { bubbles: true, cancelable: true, detail: remove || add };\n if (remove && !removeable) return;\n if (!self.dispatchEvent(new CustomEvent(\"beforechange\", event)))\n return render(self);\n remove ? remove.remove() : self.add(add);\n self.dispatchEvent(new CustomEvent(\"afterchange\", event));\n};\nvar onFocus = (self, { target }) => {\n if (!LIVE) LIVE = createAriaLive(\"assertive\");\n if (!LIVE.isConnected) document.body.appendChild(LIVE);\n if (target instanceof HTMLElement) self._focus = target;\n if (!self._items) {\n self._control = self.control || void 0;\n self._items = self.items;\n self._list = self.list || void 0;\n self._options = self.options || void 0;\n }\n};\nvar onBlur = (self) => IS_PRESS || setTimeout(onBlurred, 0, self);\nvar onBlurred = (self) => {\n var _a2;\n if (!self._focus || self.contains((_a2 = self._root) == null ? void 0 : _a2.activeElement)) return;\n syncInputValue(self, true);\n disconnectCache(self);\n};\nvar onClick = (self, event) => {\n var _a2;\n const { clientX: x, clientY: y, target } = event;\n for (const item of self.items) {\n const { top, right, bottom, left } = item.getBoundingClientRect();\n if (item.contains(target)) return dispatchChange(self, item);\n if (y >= top && y <= bottom && x >= left && x <= right) return item.focus();\n }\n if (target === self) (_a2 = self.control) == null ? void 0 : _a2.focus();\n};\nvar onInput = (self, event) => {\n var _a2;\n const { options = [], control, multiple } = self;\n const value = ((_a2 = control == null ? void 0 : control.value) == null ? void 0 : _a2.trim()) || \"\";\n const isClick = event instanceof InputEvent ? !event.inputType || event.inputType === CLICK : !!value;\n if (!isClick) return multiple || dispatchMatch(self);\n event.stopImmediatePropagation();\n if (control) control.value = self._value;\n for (const opt of options)\n if (opt.value && opt.value === value) {\n dispatchChange(self, opt, multiple);\n return setTimeout(syncInputValue, 0, self, true);\n }\n};\nvar onKeyDown = (self, event) => {\n var _a2;\n if (event.altKey || event.ctrlKey || event.metaKey || event.shiftKey) return;\n const { _texts, control, items, multiple } = self;\n const { key, repeat, target } = event;\n const isControl = control && control === target;\n const inText = isControl && (control == null ? void 0 : control.selectionEnd);\n let index = isControl ? items.length : [...items].indexOf(target);\n if (index === -1 || !isControl && asButton(event)) return;\n if (key === \"ArrowRight\" && !isControl) index += 1;\n else if (key === \"ArrowLeft\" && !inText) index -= 1;\n else if (key === \"Enter\" && isControl) {\n const form = attr(control, \"form\");\n attr(control, \"form\", \"#\");\n requestAnimationFrame(() => attr(control, \"form\", form));\n if (multiple) dispatchMatch(self);\n else if (!self.items[0] && LIVE)\n LIVE.textContent = `${_texts.invalid}${++LIVE_SR_FIX % 2 ? \"\\xA0\" : \"\"}`;\n return syncInputValue(self, true);\n } else if ((key === \"Backspace\" || key === \"Delete\") && !inText) {\n event.preventDefault();\n if (!repeat && items[index]) return dispatchChange(self, items[index]);\n if (isControl) index -= 1;\n } else return isControl || (control == null ? void 0 : control.focus());\n event.preventDefault();\n (_a2 = items[Math.max(0, index)] || control) == null ? void 0 : _a2.focus();\n};\ncustomElements.define(\"u-combobox\", UHTMLComboboxElement);\n\nexport { UHTMLComboboxElement };\n"],"names":["__defProp","__getOwnPropSymbols","__hasOwnProp","__propIsEnum","__defNormalProp","obj","key","value","__spreadValues","a","b","prop","IS_BROWSER","IS_ANDROID","IS_FIREFOX","IS_IOS","_a","FOCUS_OUTLINE","UHTMLElement","attr","el","name","events","action","element","rest","type","on","off","observers","mutationObserver","options","observer","detail","asButton","event","isClick","getRoot","node","_a2","root","id","useId","createElement","tagName","text2","attrs","val","customElements","instance","createAriaLive","mode","live","setValue","input","data","_b","proto","LIVE","LIVE_SR_FIX","IS_PRESS","EVENTS","EVENT_ONCE","IS_FIREFOX_MAC","IS_MOBILE","FALSE","CLICK","TEXTS","UHTMLComboboxElement","render","syncInputValue","_","disconnectCache","target","onBlur","onClick","onFocus","onInput","onKeyDown","tag","item","createItem","text","self","_c","_focus","_speak","_texts","items","control","list","multiple","addedNodes","removedNodes","edit","total","values","_a3","_b2","keep","label2","aria","opt","label","select","withEvent","dispatchMatch","creatable","query","match","o","dispatchChange","removeable","add","remove","i","onBlurred","x","y","top","right","bottom","left","repeat","isControl","inText","index","form"],"mappings":"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","x_google_ignoreList":[0]}
|