@purpur/library 9.0.10 → 9.1.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/CHANGELOG.json +33 -0
- package/CHANGELOG.md +15 -1
- package/dist/LICENSE.txt +45 -24
- package/dist/{autocomplete-Dy8YL7Mo.js → autocomplete-B421J7CS.js} +2 -2
- package/dist/{autocomplete-Dy8YL7Mo.js.map → autocomplete-B421J7CS.js.map} +1 -1
- package/dist/{autocomplete-Dn503hFM.mjs → autocomplete-B8L-dTmF.mjs} +3 -3
- package/dist/{autocomplete-Dn503hFM.mjs.map → autocomplete-B8L-dTmF.mjs.map} +1 -1
- package/dist/autocomplete.cjs.js +1 -1
- package/dist/autocomplete.es.js +1 -1
- package/dist/chat-field-CxOqk0-9.js +2 -0
- package/dist/chat-field-CxOqk0-9.js.map +1 -0
- package/dist/chat-field-yK-TwW0D.mjs +149 -0
- package/dist/chat-field-yK-TwW0D.mjs.map +1 -0
- package/dist/chat-field.cjs.js +2 -0
- package/dist/chat-field.cjs.js.map +1 -0
- package/dist/chat-field.es.js +5 -0
- package/dist/chat-field.es.js.map +1 -0
- package/dist/components/autocomplete/src/autocomplete.d.ts.map +1 -1
- package/dist/components/chat-field/src/chat-field.d.ts +71 -0
- package/dist/components/chat-field/src/chat-field.d.ts.map +1 -0
- package/dist/components/dismissable-chip-group/src/dismissable-chip-group-item.d.ts.map +1 -1
- package/dist/components/dismissable-chip-group/src/dismissable-chip-group.d.ts +6 -1
- package/dist/components/dismissable-chip-group/src/dismissable-chip-group.d.ts.map +1 -1
- package/dist/components/dropdown/src/dropdown-combobox.d.ts +34 -0
- package/dist/components/dropdown/src/dropdown-combobox.d.ts.map +1 -0
- package/dist/components/dropdown/src/dropdown-select.d.ts +34 -0
- package/dist/components/dropdown/src/dropdown-select.d.ts.map +1 -0
- package/dist/components/dropdown/src/dropdown-shared.d.ts +51 -0
- package/dist/components/dropdown/src/dropdown-shared.d.ts.map +1 -0
- package/dist/components/dropdown/src/dropdown.d.ts +6 -0
- package/dist/components/dropdown/src/dropdown.d.ts.map +1 -0
- package/dist/components/dropdown/src/dropdown.types.d.ts +94 -0
- package/dist/components/dropdown/src/dropdown.types.d.ts.map +1 -0
- package/dist/components/dropdown/src/useDropdown.d.ts +38 -0
- package/dist/components/dropdown/src/useDropdown.d.ts.map +1 -0
- package/dist/components/dropdown/src/useDropdownFilter.d.ts +9 -0
- package/dist/components/dropdown/src/useDropdownFilter.d.ts.map +1 -0
- package/dist/components/dropdown/src/useDropdownHighlight.d.ts +19 -0
- package/dist/components/dropdown/src/useDropdownHighlight.d.ts.map +1 -0
- package/dist/components/dropdown/src/useDropdownInput.d.ts +12 -0
- package/dist/components/dropdown/src/useDropdownInput.d.ts.map +1 -0
- package/dist/components/dropdown/src/useOnClickOutside.d.ts +2 -0
- package/dist/components/dropdown/src/useOnClickOutside.d.ts.map +1 -0
- package/dist/components/listbox/src/listbox-item.d.ts +2 -0
- package/dist/components/listbox/src/listbox-item.d.ts.map +1 -1
- package/dist/components/search-field/src/search-field-autocomplete.d.ts +73 -0
- package/dist/components/search-field/src/search-field-autocomplete.d.ts.map +1 -0
- package/dist/components/search-field/src/search-field-base.d.ts +97 -0
- package/dist/components/search-field/src/search-field-base.d.ts.map +1 -0
- package/dist/components/search-field/src/search-field.d.ts +123 -41
- package/dist/components/search-field/src/search-field.d.ts.map +1 -1
- package/dist/components/text-field/src/text-field-ai.d.ts +669 -0
- package/dist/components/text-field/src/text-field-ai.d.ts.map +1 -0
- package/dist/components/text-field/src/text-field-base.d.ts +671 -0
- package/dist/components/text-field/src/text-field-base.d.ts.map +1 -0
- package/dist/components/text-field/src/text-field.d.ts +42 -4
- package/dist/components/text-field/src/text-field.d.ts.map +1 -1
- package/dist/components-metadata.js +29 -1
- package/dist/{date-field-DACXrowI.mjs → date-field-4tYMPw89.mjs} +2 -2
- package/dist/{date-field-DACXrowI.mjs.map → date-field-4tYMPw89.mjs.map} +1 -1
- package/dist/{date-field-Z3LKO4b7.js → date-field-B7ipm5sH.js} +2 -2
- package/dist/{date-field-Z3LKO4b7.js.map → date-field-B7ipm5sH.js.map} +1 -1
- package/dist/date-field.cjs.js +1 -1
- package/dist/date-field.es.js +1 -1
- package/dist/{date-picker-5Gr_cEqA.js → date-picker-B8L1Hm8r.js} +2 -2
- package/dist/{date-picker-5Gr_cEqA.js.map → date-picker-B8L1Hm8r.js.map} +1 -1
- package/dist/{date-picker-CdVUA8NC.mjs → date-picker-Bp_XpoOF.mjs} +2 -2
- package/dist/{date-picker-CdVUA8NC.mjs.map → date-picker-Bp_XpoOF.mjs.map} +1 -1
- package/dist/date-picker.cjs.js +1 -1
- package/dist/date-picker.es.js +1 -1
- package/dist/dismissable-chip-group-Cd23yjBa.js +2 -0
- package/dist/dismissable-chip-group-Cd23yjBa.js.map +1 -0
- package/dist/dismissable-chip-group-D-gD93ON.mjs +89 -0
- package/dist/dismissable-chip-group-D-gD93ON.mjs.map +1 -0
- package/dist/dismissable-chip-group.cjs.js +1 -1
- package/dist/dismissable-chip-group.es.js +5 -2
- package/dist/dropdown-BC6evqyq.js +2 -0
- package/dist/dropdown-BC6evqyq.js.map +1 -0
- package/dist/dropdown-C-Ze4gvG.mjs +771 -0
- package/dist/dropdown-C-Ze4gvG.mjs.map +1 -0
- package/dist/dropdown.cjs.js +2 -0
- package/dist/dropdown.cjs.js.map +1 -0
- package/dist/dropdown.es.js +6 -0
- package/dist/dropdown.es.js.map +1 -0
- package/dist/libraries/library/src/chat-field.d.ts +6 -0
- package/dist/libraries/library/src/chat-field.d.ts.map +1 -0
- package/dist/libraries/library/src/dropdown.d.ts +6 -0
- package/dist/libraries/library/src/dropdown.d.ts.map +1 -0
- package/dist/libraries/library/src/library.d.ts +2 -0
- package/dist/libraries/library/src/library.d.ts.map +1 -1
- package/dist/library.cjs.js +1 -1
- package/dist/library.es.js +601 -591
- package/dist/library.es.js.map +1 -1
- package/dist/listbox-COBHLRtB.js +2 -0
- package/dist/listbox-COBHLRtB.js.map +1 -0
- package/dist/listbox-DG4KmQP_.mjs +66 -0
- package/dist/listbox-DG4KmQP_.mjs.map +1 -0
- package/dist/listbox.cjs.js +1 -1
- package/dist/listbox.es.js +1 -1
- package/dist/purpur.css +1 -1
- package/dist/{quantity-selector-w10wKMmT.mjs → quantity-selector-CsR6KTG3.mjs} +2 -2
- package/dist/{quantity-selector-w10wKMmT.mjs.map → quantity-selector-CsR6KTG3.mjs.map} +1 -1
- package/dist/{quantity-selector-D28He6R8.js → quantity-selector-DWDg4aFO.js} +2 -2
- package/dist/{quantity-selector-D28He6R8.js.map → quantity-selector-DWDg4aFO.js.map} +1 -1
- package/dist/quantity-selector.cjs.js +1 -1
- package/dist/quantity-selector.es.js +1 -1
- package/dist/search-field-Caj2dKLn.mjs +151 -0
- package/dist/search-field-Caj2dKLn.mjs.map +1 -0
- package/dist/search-field-DAktzYb0.js +2 -0
- package/dist/search-field-DAktzYb0.js.map +1 -0
- package/dist/search-field.cjs.js +1 -1
- package/dist/search-field.es.js +3 -2
- package/dist/{table-YR-bpfU0.mjs → table-DXYHrKI7.mjs} +2 -2
- package/dist/{table-YR-bpfU0.mjs.map → table-DXYHrKI7.mjs.map} +1 -1
- package/dist/{table-CJijBJsy.js → table-x3SDCR-z.js} +2 -2
- package/dist/{table-CJijBJsy.js.map → table-x3SDCR-z.js.map} +1 -1
- package/dist/table.cjs.js +1 -1
- package/dist/table.es.js +1 -1
- package/dist/text-field-BQYzwIrG.mjs +322 -0
- package/dist/text-field-BQYzwIrG.mjs.map +1 -0
- package/dist/text-field-BwxGMWds.js +2 -0
- package/dist/text-field-BwxGMWds.js.map +1 -0
- package/dist/text-field.cjs.js +1 -1
- package/dist/text-field.es.js +4 -3
- package/dist/use-autocomplete.es-BHDgQLae.js +2 -0
- package/dist/use-autocomplete.es-BHDgQLae.js.map +1 -0
- package/dist/use-autocomplete.es-CVv3z8t6.mjs +142 -0
- package/dist/use-autocomplete.es-CVv3z8t6.mjs.map +1 -0
- package/package.json +25 -23
- package/src/aliases.ts +8 -0
- package/src/chat-field.ts +6 -0
- package/src/dropdown.ts +6 -0
- package/src/entries.js +2 -0
- package/src/library.ts +4 -0
- package/dist/dismissable-chip-group-CnziecOt.js +0 -2
- package/dist/dismissable-chip-group-CnziecOt.js.map +0 -1
- package/dist/dismissable-chip-group-ZCYOt1sB.mjs +0 -79
- package/dist/dismissable-chip-group-ZCYOt1sB.mjs.map +0 -1
- package/dist/listbox-BmjBtIv8.js +0 -2
- package/dist/listbox-BmjBtIv8.js.map +0 -1
- package/dist/listbox-oDeP8FvH.mjs +0 -65
- package/dist/listbox-oDeP8FvH.mjs.map +0 -1
- package/dist/search-field-CNpJp3Tg.js +0 -2
- package/dist/search-field-CNpJp3Tg.js.map +0 -1
- package/dist/search-field-CWqLnqdo.mjs +0 -91
- package/dist/search-field-CWqLnqdo.mjs.map +0 -1
- package/dist/text-field-BMDf8j-K.mjs +0 -185
- package/dist/text-field-BMDf8j-K.mjs.map +0 -1
- package/dist/text-field-CiLEj0Fq.js +0 -2
- package/dist/text-field-CiLEj0Fq.js.map +0 -1
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { DropdownOption } from './dropdown.types';
|
|
2
|
+
export type HighlightedOption = DropdownOption & {
|
|
3
|
+
isSetByClickEvent?: boolean;
|
|
4
|
+
};
|
|
5
|
+
export type UseDropdownHighlightParams = {
|
|
6
|
+
options: DropdownOption[];
|
|
7
|
+
highlightFirstOption: boolean;
|
|
8
|
+
};
|
|
9
|
+
export declare const useDropdownHighlight: ({ options, highlightFirstOption, }: UseDropdownHighlightParams) => {
|
|
10
|
+
highlightedOption: HighlightedOption | undefined;
|
|
11
|
+
listboxRef: import('react').RefObject<HTMLUListElement | null>;
|
|
12
|
+
optionRefs: import('react').RefObject<Record<string, HTMLLIElement>>;
|
|
13
|
+
findNextOption: (direction: "ArrowUp" | "ArrowDown", optionsToShow: DropdownOption[]) => DropdownOption | undefined;
|
|
14
|
+
highlightOption: (option: DropdownOption | undefined) => void;
|
|
15
|
+
highlightByClick: (option: DropdownOption) => void;
|
|
16
|
+
highlightSelected: (option: DropdownOption, eventType: "CLICK" | "KEYBOARD") => void;
|
|
17
|
+
resetHighlight: () => void;
|
|
18
|
+
};
|
|
19
|
+
//# sourceMappingURL=useDropdownHighlight.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useDropdownHighlight.d.ts","sourceRoot":"","sources":["../../../../../../components/dropdown/src/useDropdownHighlight.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAEvD,MAAM,MAAM,iBAAiB,GAAG,cAAc,GAAG;IAAE,iBAAiB,CAAC,EAAE,OAAO,CAAA;CAAE,CAAC;AAEjF,MAAM,MAAM,0BAA0B,GAAG;IACvC,OAAO,EAAE,cAAc,EAAE,CAAC;IAC1B,oBAAoB,EAAE,OAAO,CAAC;CAC/B,CAAC;AAEF,eAAO,MAAM,oBAAoB,GAAI,oCAGlC,0BAA0B;;;;gCAoBd,SAAS,GAAG,WAAW,iBACnB,cAAc,EAAE,KAC9B,cAAc,GAAG,SAAS;8BAcI,cAAc,GAAG,SAAS;+BAKzB,cAAc;gCAMb,cAAc,aAAa,OAAO,GAAG,UAAU;;CAsBnF,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { DropdownOption } from './dropdown.types';
|
|
2
|
+
export type UseDropdownInputParams = {
|
|
3
|
+
controlledInputValue?: string;
|
|
4
|
+
defaultInputValue?: string;
|
|
5
|
+
selectedOption?: DropdownOption;
|
|
6
|
+
onInputChange?: (value: string) => void;
|
|
7
|
+
};
|
|
8
|
+
export declare const useDropdownInput: ({ controlledInputValue, defaultInputValue, selectedOption, onInputChange, }: UseDropdownInputParams) => {
|
|
9
|
+
displayInputValue: string;
|
|
10
|
+
populateInputField: (value: string) => void;
|
|
11
|
+
};
|
|
12
|
+
//# sourceMappingURL=useDropdownInput.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useDropdownInput.d.ts","sourceRoot":"","sources":["../../../../../../components/dropdown/src/useDropdownInput.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAEvD,MAAM,MAAM,sBAAsB,GAAG;IACnC,oBAAoB,CAAC,EAAE,MAAM,CAAC;IAC9B,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,cAAc,CAAC,EAAE,cAAc,CAAC;IAChC,aAAa,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;CACzC,CAAC;AAEF,eAAO,MAAM,gBAAgB,GAAI,6EAK9B,sBAAsB;;gCAUY,MAAM;CAS1C,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useOnClickOutside.d.ts","sourceRoot":"","sources":["../../../../../../components/dropdown/src/useOnClickOutside.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,iBAAiB,GAAI,SAAS,WAAW,GAAG,IAAI,EAAE,UAAU,MAAM,IAAI,SAgBlF,CAAC"}
|
|
@@ -7,6 +7,8 @@ export type ListboxItemProps = Omit<BaseProps<"li">, "role"> & {
|
|
|
7
7
|
selected?: boolean;
|
|
8
8
|
disabled?: boolean;
|
|
9
9
|
noninteractive?: boolean;
|
|
10
|
+
/** When true, hides the built-in checkmark icon while preserving `aria-selected`. */
|
|
11
|
+
hideSelectedIcon?: boolean;
|
|
10
12
|
};
|
|
11
13
|
export declare const ListboxItem: React.ForwardRefExoticComponent<Omit<ListboxItemProps, "ref"> & React.RefAttributes<HTMLLIElement>>;
|
|
12
14
|
export declare const isListboxItem: (child?: ReactNode) => child is ReactElement<ListboxItemProps>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"listbox-item.d.ts","sourceRoot":"","sources":["../../../../../../components/listbox/src/listbox-item.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAA8B,KAAK,YAAY,EAAE,KAAK,SAAS,EAAE,MAAM,OAAO,CAAC;AAC7F,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAWtD,MAAM,MAAM,gBAAgB,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,MAAM,CAAC,GAAG;IAC7D,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,cAAc,CAAC,EAAE,OAAO,CAAC;
|
|
1
|
+
{"version":3,"file":"listbox-item.d.ts","sourceRoot":"","sources":["../../../../../../components/listbox/src/listbox-item.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAA8B,KAAK,YAAY,EAAE,KAAK,SAAS,EAAE,MAAM,OAAO,CAAC;AAC7F,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAWtD,MAAM,MAAM,gBAAgB,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,MAAM,CAAC,GAAG;IAC7D,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,qFAAqF;IACrF,gBAAgB,CAAC,EAAE,OAAO,CAAC;CAC5B,CAAC;AAEF,eAAO,MAAM,WAAW,qGAoCtB,CAAC;AAEH,eAAO,MAAM,aAAa,GAAI,QAAQ,SAAS,KAAG,KAAK,IAAI,YAAY,CAAC,gBAAgB,CAChB,CAAC"}
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
import { default as React } from 'react';
|
|
2
|
+
import { AutocompleteOption } from '@purpur/use-autocomplete';
|
|
3
|
+
import { SearchFieldAutocompleteEnhancements, SearchFieldBaseProps } from './search-field-base';
|
|
4
|
+
export type SearchFieldAutocompleteProps = SearchFieldBaseProps & Extract<SearchFieldAutocompleteEnhancements, {
|
|
5
|
+
suggestions: AutocompleteOption[];
|
|
6
|
+
}>;
|
|
7
|
+
export declare const SearchFieldAutocomplete: React.ForwardRefExoticComponent<(Omit<{
|
|
8
|
+
"data-testid"?: string;
|
|
9
|
+
clearButtonAriaLabel: string;
|
|
10
|
+
disabled?: boolean;
|
|
11
|
+
iconOnlySearchButton?: boolean;
|
|
12
|
+
onChange?: (e: React.ChangeEvent<HTMLInputElement>) => void;
|
|
13
|
+
onClear: () => void;
|
|
14
|
+
onSearch?: (e: React.FormEvent<HTMLFormElement>) => void;
|
|
15
|
+
searchButtonLabel?: string;
|
|
16
|
+
variant: "button-attached" | "no-button";
|
|
17
|
+
formRef?: React.RefObject<HTMLFormElement>;
|
|
18
|
+
} & {
|
|
19
|
+
iconOnlySearchButton?: false;
|
|
20
|
+
searchButtonLabel: string;
|
|
21
|
+
variant: "button-attached";
|
|
22
|
+
} & Omit<import('../../text-field/src/text-field').TextFieldProps, "onChange" | "variant" | "afterField" | "endAdornment" | "startAdornment"> & {
|
|
23
|
+
onSelectSuggestion?: (option: AutocompleteOption) => void;
|
|
24
|
+
openSuggestionsOnFocus?: boolean;
|
|
25
|
+
suggestionsMaxHeight?: string | number;
|
|
26
|
+
} & {
|
|
27
|
+
suggestions: AutocompleteOption[];
|
|
28
|
+
suggestionsLabel: string;
|
|
29
|
+
}, "ref"> | Omit<{
|
|
30
|
+
"data-testid"?: string;
|
|
31
|
+
clearButtonAriaLabel: string;
|
|
32
|
+
disabled?: boolean;
|
|
33
|
+
iconOnlySearchButton?: boolean;
|
|
34
|
+
onChange?: (e: React.ChangeEvent<HTMLInputElement>) => void;
|
|
35
|
+
onClear: () => void;
|
|
36
|
+
onSearch?: (e: React.FormEvent<HTMLFormElement>) => void;
|
|
37
|
+
searchButtonLabel?: string;
|
|
38
|
+
variant: "button-attached" | "no-button";
|
|
39
|
+
formRef?: React.RefObject<HTMLFormElement>;
|
|
40
|
+
} & {
|
|
41
|
+
iconOnlySearchButton: true;
|
|
42
|
+
searchButtonLabel: string;
|
|
43
|
+
variant: "button-attached";
|
|
44
|
+
} & Omit<import('../../text-field/src/text-field').TextFieldProps, "onChange" | "variant" | "afterField" | "endAdornment" | "startAdornment"> & {
|
|
45
|
+
onSelectSuggestion?: (option: AutocompleteOption) => void;
|
|
46
|
+
openSuggestionsOnFocus?: boolean;
|
|
47
|
+
suggestionsMaxHeight?: string | number;
|
|
48
|
+
} & {
|
|
49
|
+
suggestions: AutocompleteOption[];
|
|
50
|
+
suggestionsLabel: string;
|
|
51
|
+
}, "ref"> | Omit<{
|
|
52
|
+
"data-testid"?: string;
|
|
53
|
+
clearButtonAriaLabel: string;
|
|
54
|
+
disabled?: boolean;
|
|
55
|
+
iconOnlySearchButton?: boolean;
|
|
56
|
+
onChange?: (e: React.ChangeEvent<HTMLInputElement>) => void;
|
|
57
|
+
onClear: () => void;
|
|
58
|
+
onSearch?: (e: React.FormEvent<HTMLFormElement>) => void;
|
|
59
|
+
searchButtonLabel?: string;
|
|
60
|
+
variant: "button-attached" | "no-button";
|
|
61
|
+
formRef?: React.RefObject<HTMLFormElement>;
|
|
62
|
+
} & {
|
|
63
|
+
searchButtonLabel?: never;
|
|
64
|
+
variant: "no-button";
|
|
65
|
+
} & Omit<import('../../text-field/src/text-field').TextFieldProps, "onChange" | "variant" | "afterField" | "endAdornment" | "startAdornment"> & {
|
|
66
|
+
onSelectSuggestion?: (option: AutocompleteOption) => void;
|
|
67
|
+
openSuggestionsOnFocus?: boolean;
|
|
68
|
+
suggestionsMaxHeight?: string | number;
|
|
69
|
+
} & {
|
|
70
|
+
suggestions: AutocompleteOption[];
|
|
71
|
+
suggestionsLabel: string;
|
|
72
|
+
}, "ref">) & React.RefAttributes<HTMLInputElement>>;
|
|
73
|
+
//# sourceMappingURL=search-field-autocomplete.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"search-field-autocomplete.d.ts","sourceRoot":"","sources":["../../../../../../components/search-field/src/search-field-autocomplete.tsx"],"names":[],"mappings":"AAAA,OAAO,KAA4B,MAAM,OAAO,CAAC;AAEjD,OAAO,EAAE,KAAK,kBAAkB,EAAmB,MAAM,0BAA0B,CAAC;AAIpF,OAAO,EACL,KAAK,mCAAmC,EAExC,KAAK,oBAAoB,EAC1B,MAAM,qBAAqB,CAAC;AAK7B,MAAM,MAAM,4BAA4B,GAAG,oBAAoB,GAC7D,OAAO,CAAC,mCAAmC,EAAE;IAAE,WAAW,EAAE,kBAAkB,EAAE,CAAA;CAAE,CAAC,CAAC;AAEtF,eAAO,MAAM,uBAAuB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;mDAqEnC,CAAC"}
|
|
@@ -0,0 +1,97 @@
|
|
|
1
|
+
import { default as React, ChangeEvent, CSSProperties, FormEvent, RefObject } from 'react';
|
|
2
|
+
import { TextFieldProps } from '../../text-field/src/text-field';
|
|
3
|
+
import { AutocompleteOption } from '@purpur/use-autocomplete';
|
|
4
|
+
export declare const searchFieldVariants: readonly ["button-attached", "no-button"];
|
|
5
|
+
type Variant = (typeof searchFieldVariants)[number];
|
|
6
|
+
type DefaultProps = {
|
|
7
|
+
["data-testid"]?: string;
|
|
8
|
+
/**
|
|
9
|
+
* An accessible label for the clear button.
|
|
10
|
+
* */
|
|
11
|
+
clearButtonAriaLabel: string;
|
|
12
|
+
/**
|
|
13
|
+
* Disables both the input field and submit button if `true`.
|
|
14
|
+
* */
|
|
15
|
+
disabled?: boolean;
|
|
16
|
+
/**
|
|
17
|
+
* Will display only a search icon in the search button if `true`.
|
|
18
|
+
* */
|
|
19
|
+
iconOnlySearchButton?: boolean;
|
|
20
|
+
/**
|
|
21
|
+
* Event handler called when the value of the search field changes.
|
|
22
|
+
* */
|
|
23
|
+
onChange?: (e: ChangeEvent<HTMLInputElement>) => void;
|
|
24
|
+
/**
|
|
25
|
+
* Event handler called when the clear button is clicked.
|
|
26
|
+
* */
|
|
27
|
+
onClear: () => void;
|
|
28
|
+
/**
|
|
29
|
+
* Event handler called when the search form is submitted.
|
|
30
|
+
* */
|
|
31
|
+
onSearch?: (e: FormEvent<HTMLFormElement>) => void;
|
|
32
|
+
/**
|
|
33
|
+
* The label text (or `aria-label` if `iconOnlySearchButton` is `true`) of the search button.
|
|
34
|
+
* */
|
|
35
|
+
searchButtonLabel?: string;
|
|
36
|
+
variant: Variant;
|
|
37
|
+
formRef?: RefObject<HTMLFormElement>;
|
|
38
|
+
};
|
|
39
|
+
type TextSearchButton = {
|
|
40
|
+
iconOnlySearchButton?: false;
|
|
41
|
+
searchButtonLabel: string;
|
|
42
|
+
variant: "button-attached";
|
|
43
|
+
};
|
|
44
|
+
type IconOnlySearchButton = {
|
|
45
|
+
iconOnlySearchButton: true;
|
|
46
|
+
searchButtonLabel: string;
|
|
47
|
+
variant: "button-attached";
|
|
48
|
+
};
|
|
49
|
+
type NoButton = {
|
|
50
|
+
searchButtonLabel?: never;
|
|
51
|
+
variant: "no-button";
|
|
52
|
+
};
|
|
53
|
+
export type SearchFieldBaseProps = DefaultProps & (TextSearchButton | IconOnlySearchButton | NoButton) & Omit<TextFieldProps, "startAdornment" | "endAdornment" | "afterField" | "onChange" | "variant">;
|
|
54
|
+
type SearchFieldAutocompleteSharedProps = {
|
|
55
|
+
/**
|
|
56
|
+
* Called when the user selects a suggestion.
|
|
57
|
+
*/
|
|
58
|
+
onSelectSuggestion?: (option: AutocompleteOption) => void;
|
|
59
|
+
/**
|
|
60
|
+
* Open the suggestions listbox when the input receives focus.
|
|
61
|
+
*/
|
|
62
|
+
openSuggestionsOnFocus?: boolean;
|
|
63
|
+
/**
|
|
64
|
+
* Maximum height of the suggestions listbox. A number is interpreted as px.
|
|
65
|
+
*/
|
|
66
|
+
suggestionsMaxHeight?: string | number;
|
|
67
|
+
};
|
|
68
|
+
type SearchFieldWithoutAutocomplete = SearchFieldAutocompleteSharedProps & {
|
|
69
|
+
suggestions?: never;
|
|
70
|
+
suggestionsLabel?: never;
|
|
71
|
+
};
|
|
72
|
+
type SearchFieldWithAutocomplete = SearchFieldAutocompleteSharedProps & {
|
|
73
|
+
/**
|
|
74
|
+
* The list of suggestions to display in a listbox below the field.
|
|
75
|
+
* No filtering is applied — pass the already-correct (pre-filtered) list.
|
|
76
|
+
* If autocomplete should stay enabled while there are temporarily no matches,
|
|
77
|
+
* pass an empty array instead of `undefined` or `null`. Changing this prop
|
|
78
|
+
* from an absent value to an array switches between the regular and
|
|
79
|
+
* autocomplete variants, which causes a re-render, drops input focus, and
|
|
80
|
+
* hides the listbox.
|
|
81
|
+
*/
|
|
82
|
+
suggestions: AutocompleteOption[];
|
|
83
|
+
/**
|
|
84
|
+
* Accessible label for the suggestions listbox.
|
|
85
|
+
*/
|
|
86
|
+
suggestionsLabel: string;
|
|
87
|
+
};
|
|
88
|
+
export type SearchFieldAutocompleteEnhancements = SearchFieldWithoutAutocomplete | SearchFieldWithAutocomplete;
|
|
89
|
+
export declare const SearchFieldBase: React.ForwardRefExoticComponent<(Omit<DefaultProps & TextSearchButton & Omit<TextFieldProps, "onChange" | "variant" | "afterField" | "endAdornment" | "startAdornment"> & {
|
|
90
|
+
wrapperStyle?: CSSProperties;
|
|
91
|
+
}, "ref"> | Omit<DefaultProps & IconOnlySearchButton & Omit<TextFieldProps, "onChange" | "variant" | "afterField" | "endAdornment" | "startAdornment"> & {
|
|
92
|
+
wrapperStyle?: CSSProperties;
|
|
93
|
+
}, "ref"> | Omit<DefaultProps & NoButton & Omit<TextFieldProps, "onChange" | "variant" | "afterField" | "endAdornment" | "startAdornment"> & {
|
|
94
|
+
wrapperStyle?: CSSProperties;
|
|
95
|
+
}, "ref">) & React.RefAttributes<HTMLInputElement>>;
|
|
96
|
+
export {};
|
|
97
|
+
//# sourceMappingURL=search-field-base.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"search-field-base.d.ts","sourceRoot":"","sources":["../../../../../../components/search-field/src/search-field-base.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EACZ,KAAK,WAAW,EAChB,KAAK,aAAa,EAClB,KAAK,SAAS,EAEd,KAAK,SAAS,EACf,MAAM,OAAO,CAAC;AAEf,OAAO,EAAa,KAAK,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACpE,OAAO,EAAE,KAAK,kBAAkB,EAAE,MAAM,0BAA0B,CAAC;AAMnE,eAAO,MAAM,mBAAmB,2CAA4C,CAAC;AAE7E,KAAK,OAAO,GAAG,CAAC,OAAO,mBAAmB,CAAC,CAAC,MAAM,CAAC,CAAC;AAEpD,KAAK,YAAY,GAAG;IAClB,CAAC,aAAa,CAAC,CAAC,EAAE,MAAM,CAAC;IACzB;;SAEK;IACL,oBAAoB,EAAE,MAAM,CAAC;IAC7B;;SAEK;IACL,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB;;SAEK;IACL,oBAAoB,CAAC,EAAE,OAAO,CAAC;IAC/B;;SAEK;IACL,QAAQ,CAAC,EAAE,CAAC,CAAC,EAAE,WAAW,CAAC,gBAAgB,CAAC,KAAK,IAAI,CAAC;IACtD;;SAEK;IACL,OAAO,EAAE,MAAM,IAAI,CAAC;IACpB;;SAEK;IACL,QAAQ,CAAC,EAAE,CAAC,CAAC,EAAE,SAAS,CAAC,eAAe,CAAC,KAAK,IAAI,CAAC;IACnD;;SAEK;IACL,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,OAAO,EAAE,OAAO,CAAC;IACjB,OAAO,CAAC,EAAE,SAAS,CAAC,eAAe,CAAC,CAAC;CACtC,CAAC;AAEF,KAAK,gBAAgB,GAAG;IACtB,oBAAoB,CAAC,EAAE,KAAK,CAAC;IAC7B,iBAAiB,EAAE,MAAM,CAAC;IAC1B,OAAO,EAAE,iBAAiB,CAAC;CAC5B,CAAC;AAEF,KAAK,oBAAoB,GAAG;IAC1B,oBAAoB,EAAE,IAAI,CAAC;IAC3B,iBAAiB,EAAE,MAAM,CAAC;IAC1B,OAAO,EAAE,iBAAiB,CAAC;CAC5B,CAAC;AAEF,KAAK,QAAQ,GAAG;IACd,iBAAiB,CAAC,EAAE,KAAK,CAAC;IAC1B,OAAO,EAAE,WAAW,CAAC;CACtB,CAAC;AAEF,MAAM,MAAM,oBAAoB,GAAG,YAAY,GAC7C,CAAC,gBAAgB,GAAG,oBAAoB,GAAG,QAAQ,CAAC,GACpD,IAAI,CAAC,cAAc,EAAE,gBAAgB,GAAG,cAAc,GAAG,YAAY,GAAG,UAAU,GAAG,SAAS,CAAC,CAAC;AAMlG,KAAK,kCAAkC,GAAG;IACxC;;OAEG;IACH,kBAAkB,CAAC,EAAE,CAAC,MAAM,EAAE,kBAAkB,KAAK,IAAI,CAAC;IAC1D;;OAEG;IACH,sBAAsB,CAAC,EAAE,OAAO,CAAC;IACjC;;OAEG;IACH,oBAAoB,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;CACxC,CAAC;AAEF,KAAK,8BAA8B,GAAG,kCAAkC,GAAG;IACzE,WAAW,CAAC,EAAE,KAAK,CAAC;IACpB,gBAAgB,CAAC,EAAE,KAAK,CAAC;CAC1B,CAAC;AAEF,KAAK,2BAA2B,GAAG,kCAAkC,GAAG;IACtE;;;;;;;;OAQG;IACH,WAAW,EAAE,kBAAkB,EAAE,CAAC;IAClC;;OAEG;IACH,gBAAgB,EAAE,MAAM,CAAC;CAC1B,CAAC;AAEF,MAAM,MAAM,mCAAmC,GAC3C,8BAA8B,GAC9B,2BAA2B,CAAC;AAKhC,eAAO,MAAM,eAAe;mBA/CX,aAAa;;mBAAb,aAAa;;mBAAb,aAAa;mDAkH7B,CAAC"}
|
|
@@ -1,55 +1,137 @@
|
|
|
1
|
-
import { default as React
|
|
2
|
-
import {
|
|
3
|
-
export
|
|
4
|
-
type
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
/**
|
|
8
|
-
* An accessible label for the clear button.
|
|
9
|
-
* */
|
|
1
|
+
import { default as React } from 'react';
|
|
2
|
+
import { SearchFieldAutocompleteEnhancements, SearchFieldBaseProps, searchFieldVariants } from './search-field-base';
|
|
3
|
+
export { searchFieldVariants };
|
|
4
|
+
export type SearchFieldProps = SearchFieldBaseProps & SearchFieldAutocompleteEnhancements;
|
|
5
|
+
export declare const SearchField: React.ForwardRefExoticComponent<(Omit<{
|
|
6
|
+
"data-testid"?: string;
|
|
10
7
|
clearButtonAriaLabel: string;
|
|
11
|
-
/**
|
|
12
|
-
* Disables both the input field and submit button if `true`.
|
|
13
|
-
* */
|
|
14
8
|
disabled?: boolean;
|
|
15
|
-
/**
|
|
16
|
-
* Will display only a search icon in the search button if `true`.
|
|
17
|
-
* */
|
|
18
9
|
iconOnlySearchButton?: boolean;
|
|
19
|
-
|
|
20
|
-
* Event handler called when the value of the search field changes.
|
|
21
|
-
* */
|
|
22
|
-
onChange?: (e: ChangeEvent<HTMLInputElement>) => void;
|
|
23
|
-
/**
|
|
24
|
-
* Event handler called when the clear button is clicked.
|
|
25
|
-
* */
|
|
10
|
+
onChange?: (e: React.ChangeEvent<HTMLInputElement>) => void;
|
|
26
11
|
onClear: () => void;
|
|
27
|
-
|
|
28
|
-
* Event handler called when the search form is submitted.
|
|
29
|
-
* */
|
|
30
|
-
onSearch?: (e: FormEvent<HTMLFormElement>) => void;
|
|
31
|
-
/**
|
|
32
|
-
* The label text (or `aria-label` if `iconOnlySearchButton` is `true`) of the search button.
|
|
33
|
-
* */
|
|
12
|
+
onSearch?: (e: React.FormEvent<HTMLFormElement>) => void;
|
|
34
13
|
searchButtonLabel?: string;
|
|
35
|
-
variant:
|
|
36
|
-
formRef?: RefObject<HTMLFormElement>;
|
|
37
|
-
}
|
|
38
|
-
type TextSearchButton = {
|
|
14
|
+
variant: "button-attached" | "no-button";
|
|
15
|
+
formRef?: React.RefObject<HTMLFormElement>;
|
|
16
|
+
} & {
|
|
39
17
|
iconOnlySearchButton?: false;
|
|
40
18
|
searchButtonLabel: string;
|
|
41
19
|
variant: "button-attached";
|
|
42
|
-
}
|
|
43
|
-
|
|
20
|
+
} & Omit<import('../../text-field/src/text-field').TextFieldProps, "onChange" | "variant" | "afterField" | "endAdornment" | "startAdornment"> & {
|
|
21
|
+
onSelectSuggestion?: (option: import('@purpur/use-autocomplete').AutocompleteOption) => void;
|
|
22
|
+
openSuggestionsOnFocus?: boolean;
|
|
23
|
+
suggestionsMaxHeight?: string | number;
|
|
24
|
+
} & {
|
|
25
|
+
suggestions: import('@purpur/use-autocomplete').AutocompleteOption[];
|
|
26
|
+
suggestionsLabel: string;
|
|
27
|
+
}, "ref"> | Omit<{
|
|
28
|
+
"data-testid"?: string;
|
|
29
|
+
clearButtonAriaLabel: string;
|
|
30
|
+
disabled?: boolean;
|
|
31
|
+
iconOnlySearchButton?: boolean;
|
|
32
|
+
onChange?: (e: React.ChangeEvent<HTMLInputElement>) => void;
|
|
33
|
+
onClear: () => void;
|
|
34
|
+
onSearch?: (e: React.FormEvent<HTMLFormElement>) => void;
|
|
35
|
+
searchButtonLabel?: string;
|
|
36
|
+
variant: "button-attached" | "no-button";
|
|
37
|
+
formRef?: React.RefObject<HTMLFormElement>;
|
|
38
|
+
} & {
|
|
44
39
|
iconOnlySearchButton: true;
|
|
45
40
|
searchButtonLabel: string;
|
|
46
41
|
variant: "button-attached";
|
|
47
|
-
}
|
|
48
|
-
|
|
42
|
+
} & Omit<import('../../text-field/src/text-field').TextFieldProps, "onChange" | "variant" | "afterField" | "endAdornment" | "startAdornment"> & {
|
|
43
|
+
onSelectSuggestion?: (option: import('@purpur/use-autocomplete').AutocompleteOption) => void;
|
|
44
|
+
openSuggestionsOnFocus?: boolean;
|
|
45
|
+
suggestionsMaxHeight?: string | number;
|
|
46
|
+
} & {
|
|
47
|
+
suggestions: import('@purpur/use-autocomplete').AutocompleteOption[];
|
|
48
|
+
suggestionsLabel: string;
|
|
49
|
+
}, "ref"> | Omit<{
|
|
50
|
+
"data-testid"?: string;
|
|
51
|
+
clearButtonAriaLabel: string;
|
|
52
|
+
disabled?: boolean;
|
|
53
|
+
iconOnlySearchButton?: boolean;
|
|
54
|
+
onChange?: (e: React.ChangeEvent<HTMLInputElement>) => void;
|
|
55
|
+
onClear: () => void;
|
|
56
|
+
onSearch?: (e: React.FormEvent<HTMLFormElement>) => void;
|
|
57
|
+
searchButtonLabel?: string;
|
|
58
|
+
variant: "button-attached" | "no-button";
|
|
59
|
+
formRef?: React.RefObject<HTMLFormElement>;
|
|
60
|
+
} & {
|
|
61
|
+
searchButtonLabel?: never;
|
|
62
|
+
variant: "no-button";
|
|
63
|
+
} & Omit<import('../../text-field/src/text-field').TextFieldProps, "onChange" | "variant" | "afterField" | "endAdornment" | "startAdornment"> & {
|
|
64
|
+
onSelectSuggestion?: (option: import('@purpur/use-autocomplete').AutocompleteOption) => void;
|
|
65
|
+
openSuggestionsOnFocus?: boolean;
|
|
66
|
+
suggestionsMaxHeight?: string | number;
|
|
67
|
+
} & {
|
|
68
|
+
suggestions: import('@purpur/use-autocomplete').AutocompleteOption[];
|
|
69
|
+
suggestionsLabel: string;
|
|
70
|
+
}, "ref"> | Omit<{
|
|
71
|
+
"data-testid"?: string;
|
|
72
|
+
clearButtonAriaLabel: string;
|
|
73
|
+
disabled?: boolean;
|
|
74
|
+
iconOnlySearchButton?: boolean;
|
|
75
|
+
onChange?: (e: React.ChangeEvent<HTMLInputElement>) => void;
|
|
76
|
+
onClear: () => void;
|
|
77
|
+
onSearch?: (e: React.FormEvent<HTMLFormElement>) => void;
|
|
78
|
+
searchButtonLabel?: string;
|
|
79
|
+
variant: "button-attached" | "no-button";
|
|
80
|
+
formRef?: React.RefObject<HTMLFormElement>;
|
|
81
|
+
} & {
|
|
82
|
+
iconOnlySearchButton?: false;
|
|
83
|
+
searchButtonLabel: string;
|
|
84
|
+
variant: "button-attached";
|
|
85
|
+
} & Omit<import('../../text-field/src/text-field').TextFieldProps, "onChange" | "variant" | "afterField" | "endAdornment" | "startAdornment"> & {
|
|
86
|
+
onSelectSuggestion?: (option: import('@purpur/use-autocomplete').AutocompleteOption) => void;
|
|
87
|
+
openSuggestionsOnFocus?: boolean;
|
|
88
|
+
suggestionsMaxHeight?: string | number;
|
|
89
|
+
} & {
|
|
90
|
+
suggestions?: never;
|
|
91
|
+
suggestionsLabel?: never;
|
|
92
|
+
}, "ref"> | Omit<{
|
|
93
|
+
"data-testid"?: string;
|
|
94
|
+
clearButtonAriaLabel: string;
|
|
95
|
+
disabled?: boolean;
|
|
96
|
+
iconOnlySearchButton?: boolean;
|
|
97
|
+
onChange?: (e: React.ChangeEvent<HTMLInputElement>) => void;
|
|
98
|
+
onClear: () => void;
|
|
99
|
+
onSearch?: (e: React.FormEvent<HTMLFormElement>) => void;
|
|
100
|
+
searchButtonLabel?: string;
|
|
101
|
+
variant: "button-attached" | "no-button";
|
|
102
|
+
formRef?: React.RefObject<HTMLFormElement>;
|
|
103
|
+
} & {
|
|
104
|
+
iconOnlySearchButton: true;
|
|
105
|
+
searchButtonLabel: string;
|
|
106
|
+
variant: "button-attached";
|
|
107
|
+
} & Omit<import('../../text-field/src/text-field').TextFieldProps, "onChange" | "variant" | "afterField" | "endAdornment" | "startAdornment"> & {
|
|
108
|
+
onSelectSuggestion?: (option: import('@purpur/use-autocomplete').AutocompleteOption) => void;
|
|
109
|
+
openSuggestionsOnFocus?: boolean;
|
|
110
|
+
suggestionsMaxHeight?: string | number;
|
|
111
|
+
} & {
|
|
112
|
+
suggestions?: never;
|
|
113
|
+
suggestionsLabel?: never;
|
|
114
|
+
}, "ref"> | Omit<{
|
|
115
|
+
"data-testid"?: string;
|
|
116
|
+
clearButtonAriaLabel: string;
|
|
117
|
+
disabled?: boolean;
|
|
118
|
+
iconOnlySearchButton?: boolean;
|
|
119
|
+
onChange?: (e: React.ChangeEvent<HTMLInputElement>) => void;
|
|
120
|
+
onClear: () => void;
|
|
121
|
+
onSearch?: (e: React.FormEvent<HTMLFormElement>) => void;
|
|
122
|
+
searchButtonLabel?: string;
|
|
123
|
+
variant: "button-attached" | "no-button";
|
|
124
|
+
formRef?: React.RefObject<HTMLFormElement>;
|
|
125
|
+
} & {
|
|
49
126
|
searchButtonLabel?: never;
|
|
50
127
|
variant: "no-button";
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
128
|
+
} & Omit<import('../../text-field/src/text-field').TextFieldProps, "onChange" | "variant" | "afterField" | "endAdornment" | "startAdornment"> & {
|
|
129
|
+
onSelectSuggestion?: (option: import('@purpur/use-autocomplete').AutocompleteOption) => void;
|
|
130
|
+
openSuggestionsOnFocus?: boolean;
|
|
131
|
+
suggestionsMaxHeight?: string | number;
|
|
132
|
+
} & {
|
|
133
|
+
suggestions?: never;
|
|
134
|
+
suggestionsLabel?: never;
|
|
135
|
+
}, "ref">) & React.RefAttributes<HTMLInputElement>>;
|
|
136
|
+
export { SearchFieldAutocomplete, type SearchFieldAutocompleteProps, } from './search-field-autocomplete';
|
|
55
137
|
//# sourceMappingURL=search-field.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"search-field.d.ts","sourceRoot":"","sources":["../../../../../../components/search-field/src/search-field.tsx"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"search-field.d.ts","sourceRoot":"","sources":["../../../../../../components/search-field/src/search-field.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAqB,MAAM,OAAO,CAAC;AAG1C,OAAO,EACL,KAAK,mCAAmC,EAExC,KAAK,oBAAoB,EACzB,mBAAmB,EACpB,MAAM,qBAAqB,CAAC;AAE7B,OAAO,EAAE,mBAAmB,EAAE,CAAC;AAE/B,MAAM,MAAM,gBAAgB,GAAG,oBAAoB,GAAG,mCAAmC,CAAC;AAE1F,eAAO,MAAM,WAAW;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;mDAMtB,CAAC;AAIH,OAAO,EACL,uBAAuB,EACvB,KAAK,4BAA4B,GAClC,MAAM,6BAA6B,CAAC"}
|