@activecollab/components 2.0.241 → 2.0.243
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/dist/cjs/components/Autocomplete/Autocomplete.js +3 -0
- package/dist/cjs/components/Autocomplete/Autocomplete.js.map +1 -1
- package/dist/cjs/components/ConfirmDialog/ConfirmDialog.js +5 -2
- package/dist/cjs/components/ConfirmDialog/ConfirmDialog.js.map +1 -1
- package/dist/cjs/components/Dialog/Styles.js +1 -1
- package/dist/cjs/components/Dialog/Styles.js.map +1 -1
- package/dist/cjs/components/Select/Option/Option.js.map +1 -1
- package/dist/esm/components/Autocomplete/Autocomplete.d.ts.map +1 -1
- package/dist/esm/components/Autocomplete/Autocomplete.js +3 -0
- package/dist/esm/components/Autocomplete/Autocomplete.js.map +1 -1
- package/dist/esm/components/ConfirmDialog/ConfirmDialog.d.ts +1 -0
- package/dist/esm/components/ConfirmDialog/ConfirmDialog.d.ts.map +1 -1
- package/dist/esm/components/ConfirmDialog/ConfirmDialog.js +4 -2
- package/dist/esm/components/ConfirmDialog/ConfirmDialog.js.map +1 -1
- package/dist/esm/components/Dialog/Styles.d.ts.map +1 -1
- package/dist/esm/components/Dialog/Styles.js +1 -1
- package/dist/esm/components/Dialog/Styles.js.map +1 -1
- package/dist/esm/components/Select/Option/Option.d.ts +2 -0
- package/dist/esm/components/Select/Option/Option.d.ts.map +1 -1
- package/dist/esm/components/Select/Option/Option.js.map +1 -1
- package/dist/index.js +9 -3
- package/dist/index.js.map +1 -1
- package/dist/index.min.js +1 -1
- package/dist/index.min.js.map +1 -1
- package/package.json +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Autocomplete.js","names":["React","useCallback","useState","useMemo","useEffect","useRef","useVirtualizer","handleKeyboardMovement","StyledAutocompleteBody","StyledAutocompleteNewItem","StyledAutocompleteScrollShadow","highlightText","Option","StyledOption","OptionGroup","isOptionGroup","item","options","undefined","Autocomplete","_ref","type","inputEl","selected","emptyValue","noResultText","renderOption","option","name","defaultValue","sortDirection","handleChange","optionClassName","handleEmptyAction","disabledInternalSort","AutocompleteClassName","handleDefaultOptionChange","preselectDefaultValue","keepSameOptionsOrder","autoHeightMax","clearInputOnSelect","mixedOptions","filterCriteria","disableVirtualization","listContainerRef","itemRef","selectedOptions","Array","isArray","handleSort","opts","_opts$","isGrouped","sortOptions","a","b","aSelected","includes","id","bSelected","aMixed","bMixed","map","group","sortedGroupOptions","sort","sortList","_options$","sortedOptions","localeCompare","sortedList","setSortedList","hover","setHover","by","filter","setFilter","handleEmpty","e","button","_inputEl$current","current","focus","onAddNewMouseEnter","showAddNew","trim","every","v","toLowerCase","filterOptions","trimmedFilter","matchesFilter","nameMatch","hovered","reduce","acc","groupedOption","filteredOptions","length","list","showDefaultOption","flatOptions","showNoResultCondition","virtualItems","items","push","forEach","index","shouldUseVirtualization","rowVirtualizer","count","getScrollElement","estimateSize","overscan","gap","handleInputChange","target","key","value","handleHoverCallback","toggleSelected","result","_id","dispatchEvent","Event","bubbles","handleMouseEnter","handleClick","preventDefault","handleRenderOption","createElement","checked","tooltip","renderOptions","onChange","ref","onMouseEnter","onClick","className","handleOnMouseLeave","findIndex","scrollToIndex","align","handleOnKeyDown","_inputEl$current2","listenerTarget","document","addEventListener","removeEventListener","isDefaultOptionSelected","renderVirtualItem","virtualItem","String","_StyledStyledOption","onMouseDown","$isHidden","_ref2","onScroll","onMouseLeave","style","height","Math","min","getTotalSize","overflow","width","position","getVirtualItems","virtualRow","top","left","transform","start","Fragment","displayName","_styled","withConfig","componentId"],"sources":["../../../../src/components/Autocomplete/Autocomplete.tsx"],"sourcesContent":["import React, {\n type FC,\n useCallback,\n useState,\n useMemo,\n useEffect,\n useRef,\n type ReactNode,\n type ReactElement,\n type MutableRefObject,\n} from \"react\";\n\nimport { useVirtualizer } from \"@tanstack/react-virtual\";\n\nimport { handleKeyboardMovement } from \"./HandleKeyboard\";\nimport {\n StyledAutocompleteBody,\n StyledAutocompleteNewItem,\n StyledAutocompleteScrollShadow,\n} from \"./Styles\";\nimport highlightText from \"../../hooks/useHighlightText\";\nimport { type IOptionItemProps, Option } from \"../Select/Option\";\nimport { StyledOption } from \"../Select/Option/Styles\";\nimport { type IOptionGroupProps, OptionGroup } from \"../Select/OptionGroup\";\n\nexport function isOptionGroup(\n item: IOptionGroupProps | IOptionItemProps\n): item is IOptionGroupProps {\n return (item as IOptionGroupProps).options !== undefined;\n}\n\nexport interface IAutocompleteProps {\n /** Select type: single or multiple */\n type?: \"single\" | \"multiple\";\n /** List of options or group options */\n options?: (IOptionGroupProps | IOptionItemProps)[];\n /** Selected values */\n selected?: (string | number)[] | string | number;\n /** Mixed options values */\n mixedOptions?: (string | number)[];\n /** Input Element. */\n inputEl?: MutableRefObject<HTMLInputElement | null | undefined>;\n /** Text for empty value */\n emptyValue?: string;\n /** Text for No result */\n noResultText?: string;\n /** Render option */\n renderOption?: (\n option: Record<string, ReactNode>,\n data: Record<string, unknown>\n ) => string | ReactElement;\n /** Default value that renders on top of list */\n defaultValue?: string;\n /** Sort direction for labels */\n sortDirection?: \"asc\" | \"desc\";\n /** handleChange callback */\n handleChange?: (\n e: (string | number)[] | string | number | null | undefined\n ) => void;\n /** ClassName for single option */\n optionClassName?: string;\n /** handleEmptyAction */\n handleEmptyAction?: (e: string | number) => void;\n /** Disable sorting options */\n disabledInternalSort?: boolean;\n /** ClassName for Autocomplete component */\n AutocompleteClassName?: string;\n /** handleDefaultOptionChange callback */\n handleDefaultOptionChange?: () => void;\n /** Should default value be selected */\n preselectDefaultValue?: boolean;\n /** Should order stay the same after choosing an option */\n keepSameOptionsOrder?: boolean;\n /** Set max height property for scrollbars */\n autoHeightMax?: number;\n /** Clear input on select - works in single mode */\n clearInputOnSelect?: boolean;\n /** Custom filter function for additional filtering criteria */\n filterCriteria?: (option: IOptionItemProps, filter: string) => boolean;\n disableVirtualization?: boolean;\n}\n\ninterface IHover {\n item: number | string | undefined | null;\n by: \"mouse\" | \"keyboard\" | undefined;\n}\n\ninterface VirtualItem {\n type: \"default\" | \"option\" | \"group\" | \"addNew\" | \"noResult\";\n id: string | number;\n item?: IOptionItemProps | IOptionGroupProps;\n index?: number;\n}\n\nexport const Autocomplete: FC<IAutocompleteProps> = ({\n type,\n options = [],\n inputEl,\n selected = [],\n emptyValue,\n noResultText,\n renderOption = (option) => option?.name,\n defaultValue,\n sortDirection = \"asc\",\n handleChange,\n optionClassName,\n handleEmptyAction,\n disabledInternalSort,\n AutocompleteClassName,\n handleDefaultOptionChange,\n preselectDefaultValue,\n keepSameOptionsOrder = false,\n autoHeightMax = 340,\n clearInputOnSelect,\n mixedOptions = [],\n filterCriteria,\n disableVirtualization,\n}) => {\n const listContainerRef = useRef<HTMLDivElement>(null);\n const itemRef = useRef<HTMLLIElement>(null);\n\n const selectedOptions = useMemo(() => {\n if (Array.isArray(selected)) {\n return selected;\n }\n return [selected];\n }, [selected]);\n\n const handleSort = useCallback(\n (opts) => {\n if (keepSameOptionsOrder) {\n return opts;\n }\n\n const isGrouped = Array.isArray(opts[0]?.options);\n\n const sortOptions = (a, b) => {\n const aSelected = selectedOptions.includes(a.id);\n const bSelected = selectedOptions.includes(b.id);\n const aMixed = mixedOptions.includes(a.id);\n const bMixed = mixedOptions.includes(b.id);\n\n if (aSelected && !bSelected) {\n return -1;\n }\n if (!aSelected && bSelected) {\n return 1;\n }\n if (aMixed && !bMixed) {\n return -1;\n }\n if (!aMixed && bMixed) {\n return 1;\n }\n return 0;\n };\n\n if (isGrouped) {\n return opts.map((group) => {\n const sortedGroupOptions = group.options.sort(sortOptions);\n\n return {\n ...group,\n options: sortedGroupOptions,\n };\n });\n } else {\n return opts.sort(sortOptions);\n }\n },\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [mixedOptions, selectedOptions]\n );\n\n const sortList = useCallback(\n (options) => {\n if (disabledInternalSort) {\n return handleSort([...options]);\n }\n\n const isGrouped = Array.isArray(options[0]?.options);\n\n if (isGrouped) {\n const sortedOptions = options.map((group) => {\n const sortedGroupOptions = group.options.sort((a, b) =>\n sortDirection === \"asc\"\n ? a.name.localeCompare(b.name)\n : b.name.localeCompare(a.name)\n );\n\n return {\n ...group,\n options: handleSort(sortedGroupOptions),\n };\n });\n\n return handleSort(sortedOptions);\n } else {\n const sortedOptions = options.sort((a, b) =>\n sortDirection === \"asc\"\n ? a.name.localeCompare(b.name)\n : b.name.localeCompare(a.name)\n );\n\n return handleSort(sortedOptions);\n }\n },\n [sortDirection, disabledInternalSort, handleSort]\n );\n\n const [sortedList, setSortedList] = useState(() => sortList(options));\n\n useEffect(() => {\n setSortedList(sortList(options));\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [options]);\n\n const [hover, setHover] = useState<IHover>({\n item: undefined,\n by: undefined,\n });\n const [filter, setFilter] = useState(\"\");\n\n const handleEmpty = useCallback(\n (e) => {\n if (e && e.button !== 0) {\n return;\n }\n if (handleEmptyAction) {\n inputEl?.current?.focus();\n setFilter(\"\");\n handleEmptyAction(filter);\n }\n },\n [filter, handleEmptyAction, inputEl]\n );\n\n const onAddNewMouseEnter = useCallback(\n () => setHover({ item: \"addNew\", by: \"mouse\" }),\n []\n );\n\n const showAddNew = useMemo(() => {\n return !!(\n emptyValue &&\n filter.trim() &&\n options.every((option) => {\n if (isOptionGroup(option)) {\n return option.options.every(\n (v) => v.name.toLowerCase() !== filter.trim().toLowerCase()\n );\n }\n return option.name.toLowerCase() !== filter.trim().toLowerCase();\n })\n );\n }, [emptyValue, filter, options]);\n\n const filterOptions = useCallback(\n (options, filter) => {\n const trimmedFilter = filter.trim();\n const isGrouped = options[0] && isOptionGroup(options[0]);\n\n const matchesFilter = (option: IOptionItemProps) => {\n const nameMatch = option.name\n .toLowerCase()\n .includes(trimmedFilter.toLowerCase());\n\n if (filterCriteria && trimmedFilter) {\n return nameMatch || filterCriteria(option, trimmedFilter);\n }\n\n return nameMatch;\n };\n\n if (isGrouped) {\n let hovered = false;\n return options.reduce((acc, groupedOption) => {\n const filteredOptions = groupedOption.options.filter(matchesFilter);\n\n if (filteredOptions.length > 0) {\n if (!hovered && filter) {\n setHover({ item: filteredOptions[0].id, by: \"keyboard\" });\n }\n hovered = true;\n return [...acc, { ...groupedOption, options: filteredOptions }];\n }\n return [...acc];\n }, []);\n } else {\n const filteredOptions = options.filter(matchesFilter);\n\n if (filter && filteredOptions.length > 0) {\n setHover({ item: filteredOptions[0].id, by: \"keyboard\" });\n }\n if (filteredOptions.length === 0 && emptyValue) {\n setHover({ item: \"addNew\", by: \"keyboard\" });\n }\n return filteredOptions;\n }\n },\n [emptyValue, filterCriteria]\n );\n\n const list = useMemo(\n () => filterOptions(sortedList, filter),\n [filter, filterOptions, sortedList]\n );\n\n const showDefaultOption = useMemo(\n () => !!defaultValue && !filter,\n [defaultValue, filter]\n );\n\n const flatOptions = useMemo(() => {\n const options = list.reduce(\n (\n acc: (IOptionItemProps | IOptionGroupProps | [])[],\n option: IOptionItemProps | IOptionGroupProps\n ) => {\n if (!isOptionGroup(option)) {\n return [...acc, option];\n }\n return [...acc, ...option.options];\n },\n []\n );\n return filterOptions(options, filter);\n }, [filter, filterOptions, list]);\n\n const showNoResultCondition = useMemo(\n () =>\n noResultText &&\n !showAddNew &&\n list.length < 1 &&\n ((defaultValue && filter) || !defaultValue),\n [noResultText, showAddNew, list.length, defaultValue, filter]\n );\n\n const virtualItems = useMemo(() => {\n const items: VirtualItem[] = [];\n\n if (showDefaultOption) {\n items.push({\n type: \"default\",\n id: \"default\",\n });\n }\n\n list.forEach((item, index) => {\n if (isOptionGroup(item)) {\n items.push({\n type: \"group\",\n id: item.id,\n item,\n });\n\n item.options.forEach((option) => {\n items.push({\n type: \"option\",\n id: option.id,\n item: option,\n index,\n });\n });\n } else {\n items.push({\n type: \"option\",\n id: item.id,\n item,\n index,\n });\n }\n });\n\n if (showNoResultCondition) {\n items.push({\n type: \"noResult\",\n id: \"noResult\",\n });\n }\n\n if (showAddNew) {\n items.push({\n type: \"addNew\",\n id: \"addNew\",\n });\n }\n\n return items;\n }, [list, showDefaultOption, showNoResultCondition, showAddNew]);\n\n const shouldUseVirtualization =\n !disableVirtualization && virtualItems.length > 40;\n\n const rowVirtualizer = useVirtualizer({\n count: virtualItems.length,\n getScrollElement: () => listContainerRef.current,\n estimateSize: () => 28,\n overscan: 5,\n gap: 4,\n });\n\n const handleInputChange = useCallback((e) => {\n if (\n e.target &&\n !(e.key === \"ArrowDown\") &&\n !(e.key === \"ArrowUp\") &&\n !(e.key === \"Enter\")\n ) {\n setFilter(e.target.value);\n }\n }, []);\n\n const handleHoverCallback = useCallback(\n (e: number | string | undefined): void => {\n setHover({ item: e, by: \"mouse\" });\n },\n []\n );\n\n const toggleSelected = useCallback(\n (id) => {\n let result;\n\n if (id !== null) {\n if (type === \"multiple\") {\n if (selectedOptions.includes(id)) {\n result = selectedOptions.filter((_id) => _id !== id);\n } else {\n result = [...selectedOptions, id];\n }\n } else {\n result = id;\n }\n if (clearInputOnSelect && inputEl?.current) {\n inputEl.current.value = \"\";\n inputEl.current.dispatchEvent(new Event(\"change\", { bubbles: true }));\n }\n setFilter(\"\");\n } else {\n if (typeof handleDefaultOptionChange === \"function\") {\n handleDefaultOptionChange();\n return;\n }\n }\n\n if (typeof handleChange === \"function\") {\n handleChange(result);\n }\n },\n [\n clearInputOnSelect,\n handleChange,\n handleDefaultOptionChange,\n inputEl,\n selectedOptions,\n type,\n ]\n );\n\n const handleMouseEnter = useCallback((e) => {\n if (e === undefined || e === null) {\n return setHover({ item: null, by: \"mouse\" });\n }\n setHover({ item: e, by: \"mouse\" });\n }, []);\n\n const handleClick = useCallback(\n (e) => {\n e.preventDefault();\n toggleSelected(hover.item);\n },\n [toggleSelected, hover]\n );\n\n const handleRenderOption = useCallback(\n (item: IOptionItemProps | IOptionGroupProps, index) => {\n if (isOptionGroup(item)) {\n return (\n <OptionGroup\n checked={selectedOptions}\n name={item.name}\n tooltip={item.tooltip}\n key={item.id}\n setHover={handleHoverCallback}\n id={item.id}\n hover={hover.item}\n options={item.options}\n renderOptions={handleRenderOption}\n type={type}\n onChange={handleChange}\n filter={filter}\n mixedOptions={mixedOptions}\n />\n );\n }\n return (\n <Option\n name={item.name}\n ref={hover.item === item.id ? itemRef : null}\n key={index}\n tooltip={item.tooltip}\n onMouseEnter={handleMouseEnter}\n onClick={handleClick}\n id={item.id}\n hover={item.id === hover.item}\n className={optionClassName}\n renderOption={renderOption(\n { ...item, name: highlightText(item.name, filter) },\n {\n id: `option_${item.id}`,\n checked: selectedOptions && selectedOptions.includes(item.id),\n hover: hover.item === item.id,\n onChange: () => null,\n }\n )}\n />\n );\n },\n [\n handleClick,\n handleMouseEnter,\n hover.item,\n optionClassName,\n renderOption,\n filter,\n selectedOptions,\n handleHoverCallback,\n type,\n handleChange,\n mixedOptions,\n ]\n );\n\n const handleOnMouseLeave = useCallback(() => {\n setHover({ item: undefined, by: \"mouse\" });\n }, []);\n\n useEffect(() => {\n if (hover.by === \"keyboard\" && hover.item !== undefined) {\n const index = virtualItems.findIndex((item) => item.id === hover.item);\n if (index !== -1) {\n rowVirtualizer.scrollToIndex(index, { align: \"center\" });\n }\n }\n }, [hover, rowVirtualizer, virtualItems]);\n\n const handleOnKeyDown = useCallback(\n (e) => {\n if (e.key === \"Enter\") {\n e.preventDefault();\n\n if (hover.item === undefined && filter === \"\") {\n return;\n }\n if (hover.item === \"addNew\") {\n handleEmpty(null);\n return;\n }\n if (hover.item === null && handleDefaultOptionChange) {\n handleDefaultOptionChange();\n return;\n }\n\n if (typeof hover.item !== \"undefined\" || hover.item !== null) {\n toggleSelected(hover.item);\n setFilter(\"\");\n }\n return;\n }\n setHover({\n item: handleKeyboardMovement(\n e,\n hover.item,\n flatOptions,\n showAddNew,\n showDefaultOption\n ),\n by: \"keyboard\",\n });\n },\n [\n filter,\n flatOptions,\n toggleSelected,\n handleDefaultOptionChange,\n handleEmpty,\n hover,\n showAddNew,\n showDefaultOption,\n ]\n );\n\n useEffect(() => {\n const listenerTarget = inputEl?.current ?? document;\n listenerTarget.addEventListener(\"input\", handleInputChange);\n listenerTarget.addEventListener(\"keydown\", handleOnKeyDown);\n return () => {\n listenerTarget.removeEventListener(\"input\", handleInputChange);\n listenerTarget.removeEventListener(\"keydown\", handleOnKeyDown);\n };\n }, [handleInputChange, handleOnKeyDown, inputEl]);\n\n const isDefaultOptionSelected = useCallback(() => {\n if (preselectDefaultValue) {\n return selectedOptions.length < 1 || selectedOptions[0] === \"\";\n } else {\n return (\n selectedOptions[0] === null ||\n selectedOptions.length === flatOptions.length\n );\n }\n }, [flatOptions.length, preselectDefaultValue, selectedOptions]);\n\n const renderVirtualItem = useCallback(\n (virtualItem: VirtualItem, index: number) => {\n switch (virtualItem.type) {\n case \"default\":\n return (\n <Option\n name={String(defaultValue)}\n ref={hover.item === null ? itemRef : null}\n hover={hover.item === null}\n onMouseEnter={handleMouseEnter}\n onClick={(e) => {\n e.preventDefault();\n toggleSelected(null);\n }}\n renderOption={renderOption(\n { name: defaultValue, id: null },\n {\n checked: isDefaultOptionSelected(),\n hover: hover.item === null,\n onChange: () => null,\n }\n )}\n />\n );\n\n case \"group\":\n if (!virtualItem.item || !isOptionGroup(virtualItem.item))\n return null;\n return (\n <OptionGroup\n checked={selectedOptions}\n name={virtualItem.item.name}\n tooltip={virtualItem.item.tooltip}\n key={virtualItem.item.id}\n setHover={handleHoverCallback}\n id={virtualItem.item.id}\n hover={hover.item}\n options={virtualItem.item.options}\n renderOptions={handleRenderOption}\n type={type}\n onChange={handleChange}\n filter={filter}\n mixedOptions={mixedOptions}\n />\n );\n\n case \"option\":\n if (!virtualItem.item || isOptionGroup(virtualItem.item)) return null;\n return (\n <Option\n name={(virtualItem.item as IOptionItemProps).name}\n ref={hover.item === virtualItem.id ? itemRef : null}\n key={index}\n tooltip={(virtualItem.item as IOptionItemProps).tooltip}\n onMouseEnter={() => handleMouseEnter(virtualItem.id)}\n onClick={handleClick}\n id={virtualItem.id}\n hover={virtualItem.id === hover.item}\n className={optionClassName}\n renderOption={renderOption(\n {\n ...(virtualItem.item as IOptionItemProps),\n name: highlightText(\n (virtualItem.item as IOptionItemProps).name,\n filter\n ),\n },\n {\n id: `option_${virtualItem.id}`,\n checked:\n selectedOptions && selectedOptions.includes(virtualItem.id),\n hover: hover.item === virtualItem.id,\n onChange: () => null,\n }\n )}\n />\n );\n\n case \"noResult\":\n return <StyledOption css=\"cursor: auto\">{noResultText}</StyledOption>;\n\n case \"addNew\":\n return (\n <StyledAutocompleteNewItem\n ref={hover.item === \"addNew\" ? itemRef : null}\n key=\"emptyValue\"\n hover={hover.item === \"addNew\"}\n onMouseDown={handleEmpty}\n onMouseEnter={onAddNewMouseEnter}\n >\n {emptyValue}\n </StyledAutocompleteNewItem>\n );\n\n default:\n return null;\n }\n },\n [\n defaultValue,\n hover.item,\n handleMouseEnter,\n renderOption,\n isDefaultOptionSelected,\n selectedOptions,\n handleHoverCallback,\n handleRenderOption,\n type,\n handleChange,\n filter,\n mixedOptions,\n handleClick,\n optionClassName,\n noResultText,\n handleEmpty,\n onAddNewMouseEnter,\n emptyValue,\n toggleSelected,\n ]\n );\n\n return (\n <StyledAutocompleteScrollShadow\n className={AutocompleteClassName}\n $isHidden={\n !defaultValue && !emptyValue && !noResultText && list.length < 1\n }\n >\n {({ onScroll }) => (\n <StyledAutocompleteBody key=\"body\" onMouseLeave={handleOnMouseLeave}>\n <div\n ref={listContainerRef}\n style={{\n height: `${Math.min(\n rowVirtualizer.getTotalSize() + 12,\n autoHeightMax\n )}px`,\n overflow: \"auto\",\n }}\n onScroll={(e) => {\n if (onScroll) onScroll(e);\n }}\n >\n <div\n style={{\n height: `${rowVirtualizer.getTotalSize()}px`,\n width: \"100%\",\n position: \"relative\",\n }}\n >\n {shouldUseVirtualization\n ? rowVirtualizer.getVirtualItems().map((virtualRow) => {\n const item = virtualItems[virtualRow.index];\n return (\n <div\n key={virtualRow.index}\n data-index={virtualRow.index}\n style={{\n position: \"absolute\",\n top: 0,\n left: 0,\n width: \"100%\",\n transform: `translateY(${virtualRow.start}px)`,\n }}\n >\n {renderVirtualItem(item, virtualRow.index)}\n </div>\n );\n })\n : virtualItems.map((item, index) => (\n <React.Fragment key={index}>\n {renderVirtualItem(item, index)}\n </React.Fragment>\n ))}\n </div>\n </div>\n </StyledAutocompleteBody>\n )}\n </StyledAutocompleteScrollShadow>\n );\n};\n\nAutocomplete.displayName = \"Autocomplete\";\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"Autocomplete.js","names":["React","useCallback","useState","useMemo","useEffect","useRef","useVirtualizer","handleKeyboardMovement","StyledAutocompleteBody","StyledAutocompleteNewItem","StyledAutocompleteScrollShadow","highlightText","Option","StyledOption","OptionGroup","isOptionGroup","item","options","undefined","Autocomplete","_ref","type","inputEl","selected","emptyValue","noResultText","renderOption","option","name","defaultValue","sortDirection","handleChange","optionClassName","handleEmptyAction","disabledInternalSort","AutocompleteClassName","handleDefaultOptionChange","preselectDefaultValue","keepSameOptionsOrder","autoHeightMax","clearInputOnSelect","mixedOptions","filterCriteria","disableVirtualization","listContainerRef","itemRef","selectedOptions","Array","isArray","handleSort","opts","_opts$","isGrouped","sortOptions","a","b","aSelected","includes","id","bSelected","aMixed","bMixed","map","group","sortedGroupOptions","sort","sortList","_options$","sortedOptions","localeCompare","sortedList","setSortedList","hover","setHover","by","filter","setFilter","handleEmpty","e","button","_inputEl$current","current","focus","onAddNewMouseEnter","showAddNew","trim","every","v","toLowerCase","filterOptions","trimmedFilter","matchesFilter","hidden","nameMatch","hovered","reduce","acc","groupedOption","filteredOptions","length","list","showDefaultOption","flatOptions","showNoResultCondition","virtualItems","items","push","forEach","index","shouldUseVirtualization","rowVirtualizer","count","getScrollElement","estimateSize","overscan","gap","handleInputChange","target","key","value","handleHoverCallback","toggleSelected","result","_id","dispatchEvent","Event","bubbles","handleMouseEnter","handleClick","preventDefault","handleRenderOption","createElement","checked","tooltip","renderOptions","onChange","ref","onMouseEnter","onClick","className","handleOnMouseLeave","findIndex","scrollToIndex","align","handleOnKeyDown","_inputEl$current2","listenerTarget","document","addEventListener","removeEventListener","isDefaultOptionSelected","renderVirtualItem","virtualItem","String","_StyledStyledOption","onMouseDown","$isHidden","_ref2","onScroll","onMouseLeave","style","height","Math","min","getTotalSize","overflow","width","position","getVirtualItems","virtualRow","top","left","transform","start","Fragment","displayName","_styled","withConfig","componentId"],"sources":["../../../../src/components/Autocomplete/Autocomplete.tsx"],"sourcesContent":["import React, {\n type FC,\n useCallback,\n useState,\n useMemo,\n useEffect,\n useRef,\n type ReactNode,\n type ReactElement,\n type MutableRefObject,\n} from \"react\";\n\nimport { useVirtualizer } from \"@tanstack/react-virtual\";\n\nimport { handleKeyboardMovement } from \"./HandleKeyboard\";\nimport {\n StyledAutocompleteBody,\n StyledAutocompleteNewItem,\n StyledAutocompleteScrollShadow,\n} from \"./Styles\";\nimport highlightText from \"../../hooks/useHighlightText\";\nimport { type IOptionItemProps, Option } from \"../Select/Option\";\nimport { StyledOption } from \"../Select/Option/Styles\";\nimport { type IOptionGroupProps, OptionGroup } from \"../Select/OptionGroup\";\n\nexport function isOptionGroup(\n item: IOptionGroupProps | IOptionItemProps\n): item is IOptionGroupProps {\n return (item as IOptionGroupProps).options !== undefined;\n}\n\nexport interface IAutocompleteProps {\n /** Select type: single or multiple */\n type?: \"single\" | \"multiple\";\n /** List of options or group options */\n options?: (IOptionGroupProps | IOptionItemProps)[];\n /** Selected values */\n selected?: (string | number)[] | string | number;\n /** Mixed options values */\n mixedOptions?: (string | number)[];\n /** Input Element. */\n inputEl?: MutableRefObject<HTMLInputElement | null | undefined>;\n /** Text for empty value */\n emptyValue?: string;\n /** Text for No result */\n noResultText?: string;\n /** Render option */\n renderOption?: (\n option: Record<string, ReactNode>,\n data: Record<string, unknown>\n ) => string | ReactElement;\n /** Default value that renders on top of list */\n defaultValue?: string;\n /** Sort direction for labels */\n sortDirection?: \"asc\" | \"desc\";\n /** handleChange callback */\n handleChange?: (\n e: (string | number)[] | string | number | null | undefined\n ) => void;\n /** ClassName for single option */\n optionClassName?: string;\n /** handleEmptyAction */\n handleEmptyAction?: (e: string | number) => void;\n /** Disable sorting options */\n disabledInternalSort?: boolean;\n /** ClassName for Autocomplete component */\n AutocompleteClassName?: string;\n /** handleDefaultOptionChange callback */\n handleDefaultOptionChange?: () => void;\n /** Should default value be selected */\n preselectDefaultValue?: boolean;\n /** Should order stay the same after choosing an option */\n keepSameOptionsOrder?: boolean;\n /** Set max height property for scrollbars */\n autoHeightMax?: number;\n /** Clear input on select - works in single mode */\n clearInputOnSelect?: boolean;\n /** Custom filter function for additional filtering criteria */\n filterCriteria?: (option: IOptionItemProps, filter: string) => boolean;\n disableVirtualization?: boolean;\n}\n\ninterface IHover {\n item: number | string | undefined | null;\n by: \"mouse\" | \"keyboard\" | undefined;\n}\n\ninterface VirtualItem {\n type: \"default\" | \"option\" | \"group\" | \"addNew\" | \"noResult\";\n id: string | number;\n item?: IOptionItemProps | IOptionGroupProps;\n index?: number;\n}\n\nexport const Autocomplete: FC<IAutocompleteProps> = ({\n type,\n options = [],\n inputEl,\n selected = [],\n emptyValue,\n noResultText,\n renderOption = (option) => option?.name,\n defaultValue,\n sortDirection = \"asc\",\n handleChange,\n optionClassName,\n handleEmptyAction,\n disabledInternalSort,\n AutocompleteClassName,\n handleDefaultOptionChange,\n preselectDefaultValue,\n keepSameOptionsOrder = false,\n autoHeightMax = 340,\n clearInputOnSelect,\n mixedOptions = [],\n filterCriteria,\n disableVirtualization,\n}) => {\n const listContainerRef = useRef<HTMLDivElement>(null);\n const itemRef = useRef<HTMLLIElement>(null);\n\n const selectedOptions = useMemo(() => {\n if (Array.isArray(selected)) {\n return selected;\n }\n return [selected];\n }, [selected]);\n\n const handleSort = useCallback(\n (opts) => {\n if (keepSameOptionsOrder) {\n return opts;\n }\n\n const isGrouped = Array.isArray(opts[0]?.options);\n\n const sortOptions = (a, b) => {\n const aSelected = selectedOptions.includes(a.id);\n const bSelected = selectedOptions.includes(b.id);\n const aMixed = mixedOptions.includes(a.id);\n const bMixed = mixedOptions.includes(b.id);\n\n if (aSelected && !bSelected) {\n return -1;\n }\n if (!aSelected && bSelected) {\n return 1;\n }\n if (aMixed && !bMixed) {\n return -1;\n }\n if (!aMixed && bMixed) {\n return 1;\n }\n return 0;\n };\n\n if (isGrouped) {\n return opts.map((group) => {\n const sortedGroupOptions = group.options.sort(sortOptions);\n\n return {\n ...group,\n options: sortedGroupOptions,\n };\n });\n } else {\n return opts.sort(sortOptions);\n }\n },\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [mixedOptions, selectedOptions]\n );\n\n const sortList = useCallback(\n (options) => {\n if (disabledInternalSort) {\n return handleSort([...options]);\n }\n\n const isGrouped = Array.isArray(options[0]?.options);\n\n if (isGrouped) {\n const sortedOptions = options.map((group) => {\n const sortedGroupOptions = group.options.sort((a, b) =>\n sortDirection === \"asc\"\n ? a.name.localeCompare(b.name)\n : b.name.localeCompare(a.name)\n );\n\n return {\n ...group,\n options: handleSort(sortedGroupOptions),\n };\n });\n\n return handleSort(sortedOptions);\n } else {\n const sortedOptions = options.sort((a, b) =>\n sortDirection === \"asc\"\n ? a.name.localeCompare(b.name)\n : b.name.localeCompare(a.name)\n );\n\n return handleSort(sortedOptions);\n }\n },\n [sortDirection, disabledInternalSort, handleSort]\n );\n\n const [sortedList, setSortedList] = useState(() => sortList(options));\n\n useEffect(() => {\n setSortedList(sortList(options));\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [options]);\n\n const [hover, setHover] = useState<IHover>({\n item: undefined,\n by: undefined,\n });\n const [filter, setFilter] = useState(\"\");\n\n const handleEmpty = useCallback(\n (e) => {\n if (e && e.button !== 0) {\n return;\n }\n if (handleEmptyAction) {\n inputEl?.current?.focus();\n setFilter(\"\");\n handleEmptyAction(filter);\n }\n },\n [filter, handleEmptyAction, inputEl]\n );\n\n const onAddNewMouseEnter = useCallback(\n () => setHover({ item: \"addNew\", by: \"mouse\" }),\n []\n );\n\n const showAddNew = useMemo(() => {\n return !!(\n emptyValue &&\n filter.trim() &&\n options.every((option) => {\n if (isOptionGroup(option)) {\n return option.options.every(\n (v) => v.name.toLowerCase() !== filter.trim().toLowerCase()\n );\n }\n return option.name.toLowerCase() !== filter.trim().toLowerCase();\n })\n );\n }, [emptyValue, filter, options]);\n\n const filterOptions = useCallback(\n (options, filter) => {\n const trimmedFilter = filter.trim();\n const isGrouped = options[0] && isOptionGroup(options[0]);\n\n const matchesFilter = (option: IOptionItemProps) => {\n if (option.hidden) {\n return false;\n }\n\n const nameMatch = option.name\n .toLowerCase()\n .includes(trimmedFilter.toLowerCase());\n\n if (filterCriteria && trimmedFilter) {\n return nameMatch || filterCriteria(option, trimmedFilter);\n }\n\n return nameMatch;\n };\n\n if (isGrouped) {\n let hovered = false;\n return options.reduce((acc, groupedOption) => {\n const filteredOptions = groupedOption.options.filter(matchesFilter);\n\n if (filteredOptions.length > 0) {\n if (!hovered && filter) {\n setHover({ item: filteredOptions[0].id, by: \"keyboard\" });\n }\n hovered = true;\n return [...acc, { ...groupedOption, options: filteredOptions }];\n }\n return [...acc];\n }, []);\n } else {\n const filteredOptions = options.filter(matchesFilter);\n\n if (filter && filteredOptions.length > 0) {\n setHover({ item: filteredOptions[0].id, by: \"keyboard\" });\n }\n if (filteredOptions.length === 0 && emptyValue) {\n setHover({ item: \"addNew\", by: \"keyboard\" });\n }\n return filteredOptions;\n }\n },\n [emptyValue, filterCriteria]\n );\n\n const list = useMemo(\n () => filterOptions(sortedList, filter),\n [filter, filterOptions, sortedList]\n );\n\n const showDefaultOption = useMemo(\n () => !!defaultValue && !filter,\n [defaultValue, filter]\n );\n\n const flatOptions = useMemo(() => {\n const options = list.reduce(\n (\n acc: (IOptionItemProps | IOptionGroupProps | [])[],\n option: IOptionItemProps | IOptionGroupProps\n ) => {\n if (!isOptionGroup(option)) {\n return [...acc, option];\n }\n return [...acc, ...option.options];\n },\n []\n );\n return filterOptions(options, filter);\n }, [filter, filterOptions, list]);\n\n const showNoResultCondition = useMemo(\n () =>\n noResultText &&\n !showAddNew &&\n list.length < 1 &&\n ((defaultValue && filter) || !defaultValue),\n [noResultText, showAddNew, list.length, defaultValue, filter]\n );\n\n const virtualItems = useMemo(() => {\n const items: VirtualItem[] = [];\n\n if (showDefaultOption) {\n items.push({\n type: \"default\",\n id: \"default\",\n });\n }\n\n list.forEach((item, index) => {\n if (isOptionGroup(item)) {\n items.push({\n type: \"group\",\n id: item.id,\n item,\n });\n\n item.options.forEach((option) => {\n items.push({\n type: \"option\",\n id: option.id,\n item: option,\n index,\n });\n });\n } else {\n items.push({\n type: \"option\",\n id: item.id,\n item,\n index,\n });\n }\n });\n\n if (showNoResultCondition) {\n items.push({\n type: \"noResult\",\n id: \"noResult\",\n });\n }\n\n if (showAddNew) {\n items.push({\n type: \"addNew\",\n id: \"addNew\",\n });\n }\n\n return items;\n }, [list, showDefaultOption, showNoResultCondition, showAddNew]);\n\n const shouldUseVirtualization =\n !disableVirtualization && virtualItems.length > 40;\n\n const rowVirtualizer = useVirtualizer({\n count: virtualItems.length,\n getScrollElement: () => listContainerRef.current,\n estimateSize: () => 28,\n overscan: 5,\n gap: 4,\n });\n\n const handleInputChange = useCallback((e) => {\n if (\n e.target &&\n !(e.key === \"ArrowDown\") &&\n !(e.key === \"ArrowUp\") &&\n !(e.key === \"Enter\")\n ) {\n setFilter(e.target.value);\n }\n }, []);\n\n const handleHoverCallback = useCallback(\n (e: number | string | undefined): void => {\n setHover({ item: e, by: \"mouse\" });\n },\n []\n );\n\n const toggleSelected = useCallback(\n (id) => {\n let result;\n\n if (id !== null) {\n if (type === \"multiple\") {\n if (selectedOptions.includes(id)) {\n result = selectedOptions.filter((_id) => _id !== id);\n } else {\n result = [...selectedOptions, id];\n }\n } else {\n result = id;\n }\n if (clearInputOnSelect && inputEl?.current) {\n inputEl.current.value = \"\";\n inputEl.current.dispatchEvent(new Event(\"change\", { bubbles: true }));\n }\n setFilter(\"\");\n } else {\n if (typeof handleDefaultOptionChange === \"function\") {\n handleDefaultOptionChange();\n return;\n }\n }\n\n if (typeof handleChange === \"function\") {\n handleChange(result);\n }\n },\n [\n clearInputOnSelect,\n handleChange,\n handleDefaultOptionChange,\n inputEl,\n selectedOptions,\n type,\n ]\n );\n\n const handleMouseEnter = useCallback((e) => {\n if (e === undefined || e === null) {\n return setHover({ item: null, by: \"mouse\" });\n }\n setHover({ item: e, by: \"mouse\" });\n }, []);\n\n const handleClick = useCallback(\n (e) => {\n e.preventDefault();\n toggleSelected(hover.item);\n },\n [toggleSelected, hover]\n );\n\n const handleRenderOption = useCallback(\n (item: IOptionItemProps | IOptionGroupProps, index) => {\n if (isOptionGroup(item)) {\n return (\n <OptionGroup\n checked={selectedOptions}\n name={item.name}\n tooltip={item.tooltip}\n key={item.id}\n setHover={handleHoverCallback}\n id={item.id}\n hover={hover.item}\n options={item.options}\n renderOptions={handleRenderOption}\n type={type}\n onChange={handleChange}\n filter={filter}\n mixedOptions={mixedOptions}\n />\n );\n }\n return (\n <Option\n name={item.name}\n ref={hover.item === item.id ? itemRef : null}\n key={index}\n tooltip={item.tooltip}\n onMouseEnter={handleMouseEnter}\n onClick={handleClick}\n id={item.id}\n hover={item.id === hover.item}\n className={optionClassName}\n renderOption={renderOption(\n { ...item, name: highlightText(item.name, filter) },\n {\n id: `option_${item.id}`,\n checked: selectedOptions && selectedOptions.includes(item.id),\n hover: hover.item === item.id,\n onChange: () => null,\n }\n )}\n />\n );\n },\n [\n handleClick,\n handleMouseEnter,\n hover.item,\n optionClassName,\n renderOption,\n filter,\n selectedOptions,\n handleHoverCallback,\n type,\n handleChange,\n mixedOptions,\n ]\n );\n\n const handleOnMouseLeave = useCallback(() => {\n setHover({ item: undefined, by: \"mouse\" });\n }, []);\n\n useEffect(() => {\n if (hover.by === \"keyboard\" && hover.item !== undefined) {\n const index = virtualItems.findIndex((item) => item.id === hover.item);\n if (index !== -1) {\n rowVirtualizer.scrollToIndex(index, { align: \"center\" });\n }\n }\n }, [hover, rowVirtualizer, virtualItems]);\n\n const handleOnKeyDown = useCallback(\n (e) => {\n if (e.key === \"Enter\") {\n e.preventDefault();\n\n if (hover.item === undefined && filter === \"\") {\n return;\n }\n if (hover.item === \"addNew\") {\n handleEmpty(null);\n return;\n }\n if (hover.item === null && handleDefaultOptionChange) {\n handleDefaultOptionChange();\n return;\n }\n\n if (typeof hover.item !== \"undefined\" || hover.item !== null) {\n toggleSelected(hover.item);\n setFilter(\"\");\n }\n return;\n }\n setHover({\n item: handleKeyboardMovement(\n e,\n hover.item,\n flatOptions,\n showAddNew,\n showDefaultOption\n ),\n by: \"keyboard\",\n });\n },\n [\n filter,\n flatOptions,\n toggleSelected,\n handleDefaultOptionChange,\n handleEmpty,\n hover,\n showAddNew,\n showDefaultOption,\n ]\n );\n\n useEffect(() => {\n const listenerTarget = inputEl?.current ?? document;\n listenerTarget.addEventListener(\"input\", handleInputChange);\n listenerTarget.addEventListener(\"keydown\", handleOnKeyDown);\n return () => {\n listenerTarget.removeEventListener(\"input\", handleInputChange);\n listenerTarget.removeEventListener(\"keydown\", handleOnKeyDown);\n };\n }, [handleInputChange, handleOnKeyDown, inputEl]);\n\n const isDefaultOptionSelected = useCallback(() => {\n if (preselectDefaultValue) {\n return selectedOptions.length < 1 || selectedOptions[0] === \"\";\n } else {\n return (\n selectedOptions[0] === null ||\n selectedOptions.length === flatOptions.length\n );\n }\n }, [flatOptions.length, preselectDefaultValue, selectedOptions]);\n\n const renderVirtualItem = useCallback(\n (virtualItem: VirtualItem, index: number) => {\n switch (virtualItem.type) {\n case \"default\":\n return (\n <Option\n name={String(defaultValue)}\n ref={hover.item === null ? itemRef : null}\n hover={hover.item === null}\n onMouseEnter={handleMouseEnter}\n onClick={(e) => {\n e.preventDefault();\n toggleSelected(null);\n }}\n renderOption={renderOption(\n { name: defaultValue, id: null },\n {\n checked: isDefaultOptionSelected(),\n hover: hover.item === null,\n onChange: () => null,\n }\n )}\n />\n );\n\n case \"group\":\n if (!virtualItem.item || !isOptionGroup(virtualItem.item))\n return null;\n return (\n <OptionGroup\n checked={selectedOptions}\n name={virtualItem.item.name}\n tooltip={virtualItem.item.tooltip}\n key={virtualItem.item.id}\n setHover={handleHoverCallback}\n id={virtualItem.item.id}\n hover={hover.item}\n options={virtualItem.item.options}\n renderOptions={handleRenderOption}\n type={type}\n onChange={handleChange}\n filter={filter}\n mixedOptions={mixedOptions}\n />\n );\n\n case \"option\":\n if (!virtualItem.item || isOptionGroup(virtualItem.item)) return null;\n return (\n <Option\n name={(virtualItem.item as IOptionItemProps).name}\n ref={hover.item === virtualItem.id ? itemRef : null}\n key={index}\n tooltip={(virtualItem.item as IOptionItemProps).tooltip}\n onMouseEnter={() => handleMouseEnter(virtualItem.id)}\n onClick={handleClick}\n id={virtualItem.id}\n hover={virtualItem.id === hover.item}\n className={optionClassName}\n renderOption={renderOption(\n {\n ...(virtualItem.item as IOptionItemProps),\n name: highlightText(\n (virtualItem.item as IOptionItemProps).name,\n filter\n ),\n },\n {\n id: `option_${virtualItem.id}`,\n checked:\n selectedOptions && selectedOptions.includes(virtualItem.id),\n hover: hover.item === virtualItem.id,\n onChange: () => null,\n }\n )}\n />\n );\n\n case \"noResult\":\n return <StyledOption css=\"cursor: auto\">{noResultText}</StyledOption>;\n\n case \"addNew\":\n return (\n <StyledAutocompleteNewItem\n ref={hover.item === \"addNew\" ? itemRef : null}\n key=\"emptyValue\"\n hover={hover.item === \"addNew\"}\n onMouseDown={handleEmpty}\n onMouseEnter={onAddNewMouseEnter}\n >\n {emptyValue}\n </StyledAutocompleteNewItem>\n );\n\n default:\n return null;\n }\n },\n [\n defaultValue,\n hover.item,\n handleMouseEnter,\n renderOption,\n isDefaultOptionSelected,\n selectedOptions,\n handleHoverCallback,\n handleRenderOption,\n type,\n handleChange,\n filter,\n mixedOptions,\n handleClick,\n optionClassName,\n noResultText,\n handleEmpty,\n onAddNewMouseEnter,\n emptyValue,\n toggleSelected,\n ]\n );\n\n return (\n <StyledAutocompleteScrollShadow\n className={AutocompleteClassName}\n $isHidden={\n !defaultValue && !emptyValue && !noResultText && list.length < 1\n }\n >\n {({ onScroll }) => (\n <StyledAutocompleteBody key=\"body\" onMouseLeave={handleOnMouseLeave}>\n <div\n ref={listContainerRef}\n style={{\n height: `${Math.min(\n rowVirtualizer.getTotalSize() + 12,\n autoHeightMax\n )}px`,\n overflow: \"auto\",\n }}\n onScroll={(e) => {\n if (onScroll) onScroll(e);\n }}\n >\n <div\n style={{\n height: `${rowVirtualizer.getTotalSize()}px`,\n width: \"100%\",\n position: \"relative\",\n }}\n >\n {shouldUseVirtualization\n ? rowVirtualizer.getVirtualItems().map((virtualRow) => {\n const item = virtualItems[virtualRow.index];\n return (\n <div\n key={virtualRow.index}\n data-index={virtualRow.index}\n style={{\n position: \"absolute\",\n top: 0,\n left: 0,\n width: \"100%\",\n transform: `translateY(${virtualRow.start}px)`,\n }}\n >\n {renderVirtualItem(item, virtualRow.index)}\n </div>\n );\n })\n : virtualItems.map((item, index) => (\n <React.Fragment key={index}>\n {renderVirtualItem(item, index)}\n </React.Fragment>\n ))}\n </div>\n </div>\n </StyledAutocompleteBody>\n )}\n </StyledAutocompleteScrollShadow>\n );\n};\n\nAutocomplete.displayName = \"Autocomplete\";\n"],"mappings":";AAAA,OAAOA,KAAK,IAEVC,WAAW,EACXC,QAAQ,EACRC,OAAO,EACPC,SAAS,EACTC,MAAM,QAID,OAAO;AAEd,SAASC,cAAc,QAAQ,yBAAyB;AAExD,SAASC,sBAAsB,QAAQ,kBAAkB;AACzD,SACEC,sBAAsB,EACtBC,yBAAyB,EACzBC,8BAA8B,QACzB,UAAU;AACjB,OAAOC,aAAa,MAAM,8BAA8B;AACxD,SAAgCC,MAAM,QAAQ,kBAAkB;AAChE,SAASC,YAAY,QAAQ,yBAAyB;AACtD,SAAiCC,WAAW,QAAQ,uBAAuB;AAE3E,OAAO,SAASC,aAAaA,CAC3BC,IAA0C,EACf;EAC3B,OAAQA,IAAI,CAAuBC,OAAO,KAAKC,SAAS;AAC1D;AAiEA,OAAO,MAAMC,YAAoC,GAAGC,IAAA,IAuB9C;EAAA,IAvB+C;IACnDC,IAAI;IACJJ,OAAO,GAAG,EAAE;IACZK,OAAO;IACPC,QAAQ,GAAG,EAAE;IACbC,UAAU;IACVC,YAAY;IACZC,YAAY,GAAIC,MAAM,IAAKA,MAAM,oBAANA,MAAM,CAAEC,IAAI;IACvCC,YAAY;IACZC,aAAa,GAAG,KAAK;IACrBC,YAAY;IACZC,eAAe;IACfC,iBAAiB;IACjBC,oBAAoB;IACpBC,qBAAqB;IACrBC,yBAAyB;IACzBC,qBAAqB;IACrBC,oBAAoB,GAAG,KAAK;IAC5BC,aAAa,GAAG,GAAG;IACnBC,kBAAkB;IAClBC,YAAY,GAAG,EAAE;IACjBC,cAAc;IACdC;EACF,CAAC,GAAAvB,IAAA;EACC,MAAMwB,gBAAgB,GAAGvC,MAAM,CAAiB,IAAI,CAAC;EACrD,MAAMwC,OAAO,GAAGxC,MAAM,CAAgB,IAAI,CAAC;EAE3C,MAAMyC,eAAe,GAAG3C,OAAO,CAAC,MAAM;IACpC,IAAI4C,KAAK,CAACC,OAAO,CAACzB,QAAQ,CAAC,EAAE;MAC3B,OAAOA,QAAQ;IACjB;IACA,OAAO,CAACA,QAAQ,CAAC;EACnB,CAAC,EAAE,CAACA,QAAQ,CAAC,CAAC;EAEd,MAAM0B,UAAU,GAAGhD,WAAW,CAC3BiD,IAAI,IAAK;IAAA,IAAAC,MAAA;IACR,IAAIb,oBAAoB,EAAE;MACxB,OAAOY,IAAI;IACb;IAEA,MAAME,SAAS,GAAGL,KAAK,CAACC,OAAO,EAAAG,MAAA,GAACD,IAAI,CAAC,CAAC,CAAC,qBAAPC,MAAA,CAASlC,OAAO,CAAC;IAEjD,MAAMoC,WAAW,GAAGA,CAACC,CAAC,EAAEC,CAAC,KAAK;MAC5B,MAAMC,SAAS,GAAGV,eAAe,CAACW,QAAQ,CAACH,CAAC,CAACI,EAAE,CAAC;MAChD,MAAMC,SAAS,GAAGb,eAAe,CAACW,QAAQ,CAACF,CAAC,CAACG,EAAE,CAAC;MAChD,MAAME,MAAM,GAAGnB,YAAY,CAACgB,QAAQ,CAACH,CAAC,CAACI,EAAE,CAAC;MAC1C,MAAMG,MAAM,GAAGpB,YAAY,CAACgB,QAAQ,CAACF,CAAC,CAACG,EAAE,CAAC;MAE1C,IAAIF,SAAS,IAAI,CAACG,SAAS,EAAE;QAC3B,OAAO,CAAC,CAAC;MACX;MACA,IAAI,CAACH,SAAS,IAAIG,SAAS,EAAE;QAC3B,OAAO,CAAC;MACV;MACA,IAAIC,MAAM,IAAI,CAACC,MAAM,EAAE;QACrB,OAAO,CAAC,CAAC;MACX;MACA,IAAI,CAACD,MAAM,IAAIC,MAAM,EAAE;QACrB,OAAO,CAAC;MACV;MACA,OAAO,CAAC;IACV,CAAC;IAED,IAAIT,SAAS,EAAE;MACb,OAAOF,IAAI,CAACY,GAAG,CAAEC,KAAK,IAAK;QACzB,MAAMC,kBAAkB,GAAGD,KAAK,CAAC9C,OAAO,CAACgD,IAAI,CAACZ,WAAW,CAAC;QAE1D,OAAO;UACL,GAAGU,KAAK;UACR9C,OAAO,EAAE+C;QACX,CAAC;MACH,CAAC,CAAC;IACJ,CAAC,MAAM;MACL,OAAOd,IAAI,CAACe,IAAI,CAACZ,WAAW,CAAC;IAC/B;EACF,CAAC;EACD;EACA,CAACZ,YAAY,EAAEK,eAAe,CAChC,CAAC;EAED,MAAMoB,QAAQ,GAAGjE,WAAW,CACzBgB,OAAO,IAAK;IAAA,IAAAkD,SAAA;IACX,IAAIjC,oBAAoB,EAAE;MACxB,OAAOe,UAAU,CAAC,CAAC,GAAGhC,OAAO,CAAC,CAAC;IACjC;IAEA,MAAMmC,SAAS,GAAGL,KAAK,CAACC,OAAO,EAAAmB,SAAA,GAAClD,OAAO,CAAC,CAAC,CAAC,qBAAVkD,SAAA,CAAYlD,OAAO,CAAC;IAEpD,IAAImC,SAAS,EAAE;MACb,MAAMgB,aAAa,GAAGnD,OAAO,CAAC6C,GAAG,CAAEC,KAAK,IAAK;QAC3C,MAAMC,kBAAkB,GAAGD,KAAK,CAAC9C,OAAO,CAACgD,IAAI,CAAC,CAACX,CAAC,EAAEC,CAAC,KACjDzB,aAAa,KAAK,KAAK,GACnBwB,CAAC,CAAC1B,IAAI,CAACyC,aAAa,CAACd,CAAC,CAAC3B,IAAI,CAAC,GAC5B2B,CAAC,CAAC3B,IAAI,CAACyC,aAAa,CAACf,CAAC,CAAC1B,IAAI,CACjC,CAAC;QAED,OAAO;UACL,GAAGmC,KAAK;UACR9C,OAAO,EAAEgC,UAAU,CAACe,kBAAkB;QACxC,CAAC;MACH,CAAC,CAAC;MAEF,OAAOf,UAAU,CAACmB,aAAa,CAAC;IAClC,CAAC,MAAM;MACL,MAAMA,aAAa,GAAGnD,OAAO,CAACgD,IAAI,CAAC,CAACX,CAAC,EAAEC,CAAC,KACtCzB,aAAa,KAAK,KAAK,GACnBwB,CAAC,CAAC1B,IAAI,CAACyC,aAAa,CAACd,CAAC,CAAC3B,IAAI,CAAC,GAC5B2B,CAAC,CAAC3B,IAAI,CAACyC,aAAa,CAACf,CAAC,CAAC1B,IAAI,CACjC,CAAC;MAED,OAAOqB,UAAU,CAACmB,aAAa,CAAC;IAClC;EACF,CAAC,EACD,CAACtC,aAAa,EAAEI,oBAAoB,EAAEe,UAAU,CAClD,CAAC;EAED,MAAM,CAACqB,UAAU,EAAEC,aAAa,CAAC,GAAGrE,QAAQ,CAAC,MAAMgE,QAAQ,CAACjD,OAAO,CAAC,CAAC;EAErEb,SAAS,CAAC,MAAM;IACdmE,aAAa,CAACL,QAAQ,CAACjD,OAAO,CAAC,CAAC;IAChC;EACF,CAAC,EAAE,CAACA,OAAO,CAAC,CAAC;EAEb,MAAM,CAACuD,KAAK,EAAEC,QAAQ,CAAC,GAAGvE,QAAQ,CAAS;IACzCc,IAAI,EAAEE,SAAS;IACfwD,EAAE,EAAExD;EACN,CAAC,CAAC;EACF,MAAM,CAACyD,MAAM,EAAEC,SAAS,CAAC,GAAG1E,QAAQ,CAAC,EAAE,CAAC;EAExC,MAAM2E,WAAW,GAAG5E,WAAW,CAC5B6E,CAAC,IAAK;IACL,IAAIA,CAAC,IAAIA,CAAC,CAACC,MAAM,KAAK,CAAC,EAAE;MACvB;IACF;IACA,IAAI9C,iBAAiB,EAAE;MAAA,IAAA+C,gBAAA;MACrB1D,OAAO,aAAA0D,gBAAA,GAAP1D,OAAO,CAAE2D,OAAO,aAAhBD,gBAAA,CAAkBE,KAAK,CAAC,CAAC;MACzBN,SAAS,CAAC,EAAE,CAAC;MACb3C,iBAAiB,CAAC0C,MAAM,CAAC;IAC3B;EACF,CAAC,EACD,CAACA,MAAM,EAAE1C,iBAAiB,EAAEX,OAAO,CACrC,CAAC;EAED,MAAM6D,kBAAkB,GAAGlF,WAAW,CACpC,MAAMwE,QAAQ,CAAC;IAAEzD,IAAI,EAAE,QAAQ;IAAE0D,EAAE,EAAE;EAAQ,CAAC,CAAC,EAC/C,EACF,CAAC;EAED,MAAMU,UAAU,GAAGjF,OAAO,CAAC,MAAM;IAC/B,OAAO,CAAC,EACNqB,UAAU,IACVmD,MAAM,CAACU,IAAI,CAAC,CAAC,IACbpE,OAAO,CAACqE,KAAK,CAAE3D,MAAM,IAAK;MACxB,IAAIZ,aAAa,CAACY,MAAM,CAAC,EAAE;QACzB,OAAOA,MAAM,CAACV,OAAO,CAACqE,KAAK,CACxBC,CAAC,IAAKA,CAAC,CAAC3D,IAAI,CAAC4D,WAAW,CAAC,CAAC,KAAKb,MAAM,CAACU,IAAI,CAAC,CAAC,CAACG,WAAW,CAAC,CAC5D,CAAC;MACH;MACA,OAAO7D,MAAM,CAACC,IAAI,CAAC4D,WAAW,CAAC,CAAC,KAAKb,MAAM,CAACU,IAAI,CAAC,CAAC,CAACG,WAAW,CAAC,CAAC;IAClE,CAAC,CAAC,CACH;EACH,CAAC,EAAE,CAAChE,UAAU,EAAEmD,MAAM,EAAE1D,OAAO,CAAC,CAAC;EAEjC,MAAMwE,aAAa,GAAGxF,WAAW,CAC/B,CAACgB,OAAO,EAAE0D,MAAM,KAAK;IACnB,MAAMe,aAAa,GAAGf,MAAM,CAACU,IAAI,CAAC,CAAC;IACnC,MAAMjC,SAAS,GAAGnC,OAAO,CAAC,CAAC,CAAC,IAAIF,aAAa,CAACE,OAAO,CAAC,CAAC,CAAC,CAAC;IAEzD,MAAM0E,aAAa,GAAIhE,MAAwB,IAAK;MAClD,IAAIA,MAAM,CAACiE,MAAM,EAAE;QACjB,OAAO,KAAK;MACd;MAEA,MAAMC,SAAS,GAAGlE,MAAM,CAACC,IAAI,CAC1B4D,WAAW,CAAC,CAAC,CACb/B,QAAQ,CAACiC,aAAa,CAACF,WAAW,CAAC,CAAC,CAAC;MAExC,IAAI9C,cAAc,IAAIgD,aAAa,EAAE;QACnC,OAAOG,SAAS,IAAInD,cAAc,CAACf,MAAM,EAAE+D,aAAa,CAAC;MAC3D;MAEA,OAAOG,SAAS;IAClB,CAAC;IAED,IAAIzC,SAAS,EAAE;MACb,IAAI0C,OAAO,GAAG,KAAK;MACnB,OAAO7E,OAAO,CAAC8E,MAAM,CAAC,CAACC,GAAG,EAAEC,aAAa,KAAK;QAC5C,MAAMC,eAAe,GAAGD,aAAa,CAAChF,OAAO,CAAC0D,MAAM,CAACgB,aAAa,CAAC;QAEnE,IAAIO,eAAe,CAACC,MAAM,GAAG,CAAC,EAAE;UAC9B,IAAI,CAACL,OAAO,IAAInB,MAAM,EAAE;YACtBF,QAAQ,CAAC;cAAEzD,IAAI,EAAEkF,eAAe,CAAC,CAAC,CAAC,CAACxC,EAAE;cAAEgB,EAAE,EAAE;YAAW,CAAC,CAAC;UAC3D;UACAoB,OAAO,GAAG,IAAI;UACd,OAAO,CAAC,GAAGE,GAAG,EAAE;YAAE,GAAGC,aAAa;YAAEhF,OAAO,EAAEiF;UAAgB,CAAC,CAAC;QACjE;QACA,OAAO,CAAC,GAAGF,GAAG,CAAC;MACjB,CAAC,EAAE,EAAE,CAAC;IACR,CAAC,MAAM;MACL,MAAME,eAAe,GAAGjF,OAAO,CAAC0D,MAAM,CAACgB,aAAa,CAAC;MAErD,IAAIhB,MAAM,IAAIuB,eAAe,CAACC,MAAM,GAAG,CAAC,EAAE;QACxC1B,QAAQ,CAAC;UAAEzD,IAAI,EAAEkF,eAAe,CAAC,CAAC,CAAC,CAACxC,EAAE;UAAEgB,EAAE,EAAE;QAAW,CAAC,CAAC;MAC3D;MACA,IAAIwB,eAAe,CAACC,MAAM,KAAK,CAAC,IAAI3E,UAAU,EAAE;QAC9CiD,QAAQ,CAAC;UAAEzD,IAAI,EAAE,QAAQ;UAAE0D,EAAE,EAAE;QAAW,CAAC,CAAC;MAC9C;MACA,OAAOwB,eAAe;IACxB;EACF,CAAC,EACD,CAAC1E,UAAU,EAAEkB,cAAc,CAC7B,CAAC;EAED,MAAM0D,IAAI,GAAGjG,OAAO,CAClB,MAAMsF,aAAa,CAACnB,UAAU,EAAEK,MAAM,CAAC,EACvC,CAACA,MAAM,EAAEc,aAAa,EAAEnB,UAAU,CACpC,CAAC;EAED,MAAM+B,iBAAiB,GAAGlG,OAAO,CAC/B,MAAM,CAAC,CAAC0B,YAAY,IAAI,CAAC8C,MAAM,EAC/B,CAAC9C,YAAY,EAAE8C,MAAM,CACvB,CAAC;EAED,MAAM2B,WAAW,GAAGnG,OAAO,CAAC,MAAM;IAChC,MAAMc,OAAO,GAAGmF,IAAI,CAACL,MAAM,CACzB,CACEC,GAAkD,EAClDrE,MAA4C,KACzC;MACH,IAAI,CAACZ,aAAa,CAACY,MAAM,CAAC,EAAE;QAC1B,OAAO,CAAC,GAAGqE,GAAG,EAAErE,MAAM,CAAC;MACzB;MACA,OAAO,CAAC,GAAGqE,GAAG,EAAE,GAAGrE,MAAM,CAACV,OAAO,CAAC;IACpC,CAAC,EACD,EACF,CAAC;IACD,OAAOwE,aAAa,CAACxE,OAAO,EAAE0D,MAAM,CAAC;EACvC,CAAC,EAAE,CAACA,MAAM,EAAEc,aAAa,EAAEW,IAAI,CAAC,CAAC;EAEjC,MAAMG,qBAAqB,GAAGpG,OAAO,CACnC,MACEsB,YAAY,IACZ,CAAC2D,UAAU,IACXgB,IAAI,CAACD,MAAM,GAAG,CAAC,KACbtE,YAAY,IAAI8C,MAAM,IAAK,CAAC9C,YAAY,CAAC,EAC7C,CAACJ,YAAY,EAAE2D,UAAU,EAAEgB,IAAI,CAACD,MAAM,EAAEtE,YAAY,EAAE8C,MAAM,CAC9D,CAAC;EAED,MAAM6B,YAAY,GAAGrG,OAAO,CAAC,MAAM;IACjC,MAAMsG,KAAoB,GAAG,EAAE;IAE/B,IAAIJ,iBAAiB,EAAE;MACrBI,KAAK,CAACC,IAAI,CAAC;QACTrF,IAAI,EAAE,SAAS;QACfqC,EAAE,EAAE;MACN,CAAC,CAAC;IACJ;IAEA0C,IAAI,CAACO,OAAO,CAAC,CAAC3F,IAAI,EAAE4F,KAAK,KAAK;MAC5B,IAAI7F,aAAa,CAACC,IAAI,CAAC,EAAE;QACvByF,KAAK,CAACC,IAAI,CAAC;UACTrF,IAAI,EAAE,OAAO;UACbqC,EAAE,EAAE1C,IAAI,CAAC0C,EAAE;UACX1C;QACF,CAAC,CAAC;QAEFA,IAAI,CAACC,OAAO,CAAC0F,OAAO,CAAEhF,MAAM,IAAK;UAC/B8E,KAAK,CAACC,IAAI,CAAC;YACTrF,IAAI,EAAE,QAAQ;YACdqC,EAAE,EAAE/B,MAAM,CAAC+B,EAAE;YACb1C,IAAI,EAAEW,MAAM;YACZiF;UACF,CAAC,CAAC;QACJ,CAAC,CAAC;MACJ,CAAC,MAAM;QACLH,KAAK,CAACC,IAAI,CAAC;UACTrF,IAAI,EAAE,QAAQ;UACdqC,EAAE,EAAE1C,IAAI,CAAC0C,EAAE;UACX1C,IAAI;UACJ4F;QACF,CAAC,CAAC;MACJ;IACF,CAAC,CAAC;IAEF,IAAIL,qBAAqB,EAAE;MACzBE,KAAK,CAACC,IAAI,CAAC;QACTrF,IAAI,EAAE,UAAU;QAChBqC,EAAE,EAAE;MACN,CAAC,CAAC;IACJ;IAEA,IAAI0B,UAAU,EAAE;MACdqB,KAAK,CAACC,IAAI,CAAC;QACTrF,IAAI,EAAE,QAAQ;QACdqC,EAAE,EAAE;MACN,CAAC,CAAC;IACJ;IAEA,OAAO+C,KAAK;EACd,CAAC,EAAE,CAACL,IAAI,EAAEC,iBAAiB,EAAEE,qBAAqB,EAAEnB,UAAU,CAAC,CAAC;EAEhE,MAAMyB,uBAAuB,GAC3B,CAAClE,qBAAqB,IAAI6D,YAAY,CAACL,MAAM,GAAG,EAAE;EAEpD,MAAMW,cAAc,GAAGxG,cAAc,CAAC;IACpCyG,KAAK,EAAEP,YAAY,CAACL,MAAM;IAC1Ba,gBAAgB,EAAEA,CAAA,KAAMpE,gBAAgB,CAACqC,OAAO;IAChDgC,YAAY,EAAEA,CAAA,KAAM,EAAE;IACtBC,QAAQ,EAAE,CAAC;IACXC,GAAG,EAAE;EACP,CAAC,CAAC;EAEF,MAAMC,iBAAiB,GAAGnH,WAAW,CAAE6E,CAAC,IAAK;IAC3C,IACEA,CAAC,CAACuC,MAAM,IACR,EAAEvC,CAAC,CAACwC,GAAG,KAAK,WAAW,CAAC,IACxB,EAAExC,CAAC,CAACwC,GAAG,KAAK,SAAS,CAAC,IACtB,EAAExC,CAAC,CAACwC,GAAG,KAAK,OAAO,CAAC,EACpB;MACA1C,SAAS,CAACE,CAAC,CAACuC,MAAM,CAACE,KAAK,CAAC;IAC3B;EACF,CAAC,EAAE,EAAE,CAAC;EAEN,MAAMC,mBAAmB,GAAGvH,WAAW,CACpC6E,CAA8B,IAAW;IACxCL,QAAQ,CAAC;MAAEzD,IAAI,EAAE8D,CAAC;MAAEJ,EAAE,EAAE;IAAQ,CAAC,CAAC;EACpC,CAAC,EACD,EACF,CAAC;EAED,MAAM+C,cAAc,GAAGxH,WAAW,CAC/ByD,EAAE,IAAK;IACN,IAAIgE,MAAM;IAEV,IAAIhE,EAAE,KAAK,IAAI,EAAE;MACf,IAAIrC,IAAI,KAAK,UAAU,EAAE;QACvB,IAAIyB,eAAe,CAACW,QAAQ,CAACC,EAAE,CAAC,EAAE;UAChCgE,MAAM,GAAG5E,eAAe,CAAC6B,MAAM,CAAEgD,GAAG,IAAKA,GAAG,KAAKjE,EAAE,CAAC;QACtD,CAAC,MAAM;UACLgE,MAAM,GAAG,CAAC,GAAG5E,eAAe,EAAEY,EAAE,CAAC;QACnC;MACF,CAAC,MAAM;QACLgE,MAAM,GAAGhE,EAAE;MACb;MACA,IAAIlB,kBAAkB,IAAIlB,OAAO,YAAPA,OAAO,CAAE2D,OAAO,EAAE;QAC1C3D,OAAO,CAAC2D,OAAO,CAACsC,KAAK,GAAG,EAAE;QAC1BjG,OAAO,CAAC2D,OAAO,CAAC2C,aAAa,CAAC,IAAIC,KAAK,CAAC,QAAQ,EAAE;UAAEC,OAAO,EAAE;QAAK,CAAC,CAAC,CAAC;MACvE;MACAlD,SAAS,CAAC,EAAE,CAAC;IACf,CAAC,MAAM;MACL,IAAI,OAAOxC,yBAAyB,KAAK,UAAU,EAAE;QACnDA,yBAAyB,CAAC,CAAC;QAC3B;MACF;IACF;IAEA,IAAI,OAAOL,YAAY,KAAK,UAAU,EAAE;MACtCA,YAAY,CAAC2F,MAAM,CAAC;IACtB;EACF,CAAC,EACD,CACElF,kBAAkB,EAClBT,YAAY,EACZK,yBAAyB,EACzBd,OAAO,EACPwB,eAAe,EACfzB,IAAI,CAER,CAAC;EAED,MAAM0G,gBAAgB,GAAG9H,WAAW,CAAE6E,CAAC,IAAK;IAC1C,IAAIA,CAAC,KAAK5D,SAAS,IAAI4D,CAAC,KAAK,IAAI,EAAE;MACjC,OAAOL,QAAQ,CAAC;QAAEzD,IAAI,EAAE,IAAI;QAAE0D,EAAE,EAAE;MAAQ,CAAC,CAAC;IAC9C;IACAD,QAAQ,CAAC;MAAEzD,IAAI,EAAE8D,CAAC;MAAEJ,EAAE,EAAE;IAAQ,CAAC,CAAC;EACpC,CAAC,EAAE,EAAE,CAAC;EAEN,MAAMsD,WAAW,GAAG/H,WAAW,CAC5B6E,CAAC,IAAK;IACLA,CAAC,CAACmD,cAAc,CAAC,CAAC;IAClBR,cAAc,CAACjD,KAAK,CAACxD,IAAI,CAAC;EAC5B,CAAC,EACD,CAACyG,cAAc,EAAEjD,KAAK,CACxB,CAAC;EAED,MAAM0D,kBAAkB,GAAGjI,WAAW,CACpC,CAACe,IAA0C,EAAE4F,KAAK,KAAK;IACrD,IAAI7F,aAAa,CAACC,IAAI,CAAC,EAAE;MACvB,oBACEhB,KAAA,CAAAmI,aAAA,CAACrH,WAAW;QACVsH,OAAO,EAAEtF,eAAgB;QACzBlB,IAAI,EAAEZ,IAAI,CAACY,IAAK;QAChByG,OAAO,EAAErH,IAAI,CAACqH,OAAQ;QACtBf,GAAG,EAAEtG,IAAI,CAAC0C,EAAG;QACbe,QAAQ,EAAE+C,mBAAoB;QAC9B9D,EAAE,EAAE1C,IAAI,CAAC0C,EAAG;QACZc,KAAK,EAAEA,KAAK,CAACxD,IAAK;QAClBC,OAAO,EAAED,IAAI,CAACC,OAAQ;QACtBqH,aAAa,EAAEJ,kBAAmB;QAClC7G,IAAI,EAAEA,IAAK;QACXkH,QAAQ,EAAExG,YAAa;QACvB4C,MAAM,EAAEA,MAAO;QACflC,YAAY,EAAEA;MAAa,CAC5B,CAAC;IAEN;IACA,oBACEzC,KAAA,CAAAmI,aAAA,CAACvH,MAAM;MACLgB,IAAI,EAAEZ,IAAI,CAACY,IAAK;MAChB4G,GAAG,EAAEhE,KAAK,CAACxD,IAAI,KAAKA,IAAI,CAAC0C,EAAE,GAAGb,OAAO,GAAG,IAAK;MAC7CyE,GAAG,EAAEV,KAAM;MACXyB,OAAO,EAAErH,IAAI,CAACqH,OAAQ;MACtBI,YAAY,EAAEV,gBAAiB;MAC/BW,OAAO,EAAEV,WAAY;MACrBtE,EAAE,EAAE1C,IAAI,CAAC0C,EAAG;MACZc,KAAK,EAAExD,IAAI,CAAC0C,EAAE,KAAKc,KAAK,CAACxD,IAAK;MAC9B2H,SAAS,EAAE3G,eAAgB;MAC3BN,YAAY,EAAEA,YAAY,CACxB;QAAE,GAAGV,IAAI;QAAEY,IAAI,EAAEjB,aAAa,CAACK,IAAI,CAACY,IAAI,EAAE+C,MAAM;MAAE,CAAC,EACnD;QACEjB,EAAE,cAAY1C,IAAI,CAAC0C,EAAI;QACvB0E,OAAO,EAAEtF,eAAe,IAAIA,eAAe,CAACW,QAAQ,CAACzC,IAAI,CAAC0C,EAAE,CAAC;QAC7Dc,KAAK,EAAEA,KAAK,CAACxD,IAAI,KAAKA,IAAI,CAAC0C,EAAE;QAC7B6E,QAAQ,EAAEA,CAAA,KAAM;MAClB,CACF;IAAE,CACH,CAAC;EAEN,CAAC,EACD,CACEP,WAAW,EACXD,gBAAgB,EAChBvD,KAAK,CAACxD,IAAI,EACVgB,eAAe,EACfN,YAAY,EACZiD,MAAM,EACN7B,eAAe,EACf0E,mBAAmB,EACnBnG,IAAI,EACJU,YAAY,EACZU,YAAY,CAEhB,CAAC;EAED,MAAMmG,kBAAkB,GAAG3I,WAAW,CAAC,MAAM;IAC3CwE,QAAQ,CAAC;MAAEzD,IAAI,EAAEE,SAAS;MAAEwD,EAAE,EAAE;IAAQ,CAAC,CAAC;EAC5C,CAAC,EAAE,EAAE,CAAC;EAENtE,SAAS,CAAC,MAAM;IACd,IAAIoE,KAAK,CAACE,EAAE,KAAK,UAAU,IAAIF,KAAK,CAACxD,IAAI,KAAKE,SAAS,EAAE;MACvD,MAAM0F,KAAK,GAAGJ,YAAY,CAACqC,SAAS,CAAE7H,IAAI,IAAKA,IAAI,CAAC0C,EAAE,KAAKc,KAAK,CAACxD,IAAI,CAAC;MACtE,IAAI4F,KAAK,KAAK,CAAC,CAAC,EAAE;QAChBE,cAAc,CAACgC,aAAa,CAAClC,KAAK,EAAE;UAAEmC,KAAK,EAAE;QAAS,CAAC,CAAC;MAC1D;IACF;EACF,CAAC,EAAE,CAACvE,KAAK,EAAEsC,cAAc,EAAEN,YAAY,CAAC,CAAC;EAEzC,MAAMwC,eAAe,GAAG/I,WAAW,CAChC6E,CAAC,IAAK;IACL,IAAIA,CAAC,CAACwC,GAAG,KAAK,OAAO,EAAE;MACrBxC,CAAC,CAACmD,cAAc,CAAC,CAAC;MAElB,IAAIzD,KAAK,CAACxD,IAAI,KAAKE,SAAS,IAAIyD,MAAM,KAAK,EAAE,EAAE;QAC7C;MACF;MACA,IAAIH,KAAK,CAACxD,IAAI,KAAK,QAAQ,EAAE;QAC3B6D,WAAW,CAAC,IAAI,CAAC;QACjB;MACF;MACA,IAAIL,KAAK,CAACxD,IAAI,KAAK,IAAI,IAAIoB,yBAAyB,EAAE;QACpDA,yBAAyB,CAAC,CAAC;QAC3B;MACF;MAEA,IAAI,OAAOoC,KAAK,CAACxD,IAAI,KAAK,WAAW,IAAIwD,KAAK,CAACxD,IAAI,KAAK,IAAI,EAAE;QAC5DyG,cAAc,CAACjD,KAAK,CAACxD,IAAI,CAAC;QAC1B4D,SAAS,CAAC,EAAE,CAAC;MACf;MACA;IACF;IACAH,QAAQ,CAAC;MACPzD,IAAI,EAAET,sBAAsB,CAC1BuE,CAAC,EACDN,KAAK,CAACxD,IAAI,EACVsF,WAAW,EACXlB,UAAU,EACViB,iBACF,CAAC;MACD3B,EAAE,EAAE;IACN,CAAC,CAAC;EACJ,CAAC,EACD,CACEC,MAAM,EACN2B,WAAW,EACXmB,cAAc,EACdrF,yBAAyB,EACzByC,WAAW,EACXL,KAAK,EACLY,UAAU,EACViB,iBAAiB,CAErB,CAAC;EAEDjG,SAAS,CAAC,MAAM;IAAA,IAAA6I,iBAAA;IACd,MAAMC,cAAc,IAAAD,iBAAA,GAAG3H,OAAO,oBAAPA,OAAO,CAAE2D,OAAO,YAAAgE,iBAAA,GAAIE,QAAQ;IACnDD,cAAc,CAACE,gBAAgB,CAAC,OAAO,EAAEhC,iBAAiB,CAAC;IAC3D8B,cAAc,CAACE,gBAAgB,CAAC,SAAS,EAAEJ,eAAe,CAAC;IAC3D,OAAO,MAAM;MACXE,cAAc,CAACG,mBAAmB,CAAC,OAAO,EAAEjC,iBAAiB,CAAC;MAC9D8B,cAAc,CAACG,mBAAmB,CAAC,SAAS,EAAEL,eAAe,CAAC;IAChE,CAAC;EACH,CAAC,EAAE,CAAC5B,iBAAiB,EAAE4B,eAAe,EAAE1H,OAAO,CAAC,CAAC;EAEjD,MAAMgI,uBAAuB,GAAGrJ,WAAW,CAAC,MAAM;IAChD,IAAIoC,qBAAqB,EAAE;MACzB,OAAOS,eAAe,CAACqD,MAAM,GAAG,CAAC,IAAIrD,eAAe,CAAC,CAAC,CAAC,KAAK,EAAE;IAChE,CAAC,MAAM;MACL,OACEA,eAAe,CAAC,CAAC,CAAC,KAAK,IAAI,IAC3BA,eAAe,CAACqD,MAAM,KAAKG,WAAW,CAACH,MAAM;IAEjD;EACF,CAAC,EAAE,CAACG,WAAW,CAACH,MAAM,EAAE9D,qBAAqB,EAAES,eAAe,CAAC,CAAC;EAEhE,MAAMyG,iBAAiB,GAAGtJ,WAAW,CACnC,CAACuJ,WAAwB,EAAE5C,KAAa,KAAK;IAC3C,QAAQ4C,WAAW,CAACnI,IAAI;MACtB,KAAK,SAAS;QACZ,oBACErB,KAAA,CAAAmI,aAAA,CAACvH,MAAM;UACLgB,IAAI,EAAE6H,MAAM,CAAC5H,YAAY,CAAE;UAC3B2G,GAAG,EAAEhE,KAAK,CAACxD,IAAI,KAAK,IAAI,GAAG6B,OAAO,GAAG,IAAK;UAC1C2B,KAAK,EAAEA,KAAK,CAACxD,IAAI,KAAK,IAAK;UAC3ByH,YAAY,EAAEV,gBAAiB;UAC/BW,OAAO,EAAG5D,CAAC,IAAK;YACdA,CAAC,CAACmD,cAAc,CAAC,CAAC;YAClBR,cAAc,CAAC,IAAI,CAAC;UACtB,CAAE;UACF/F,YAAY,EAAEA,YAAY,CACxB;YAAEE,IAAI,EAAEC,YAAY;YAAE6B,EAAE,EAAE;UAAK,CAAC,EAChC;YACE0E,OAAO,EAAEkB,uBAAuB,CAAC,CAAC;YAClC9E,KAAK,EAAEA,KAAK,CAACxD,IAAI,KAAK,IAAI;YAC1BuH,QAAQ,EAAEA,CAAA,KAAM;UAClB,CACF;QAAE,CACH,CAAC;MAGN,KAAK,OAAO;QACV,IAAI,CAACiB,WAAW,CAACxI,IAAI,IAAI,CAACD,aAAa,CAACyI,WAAW,CAACxI,IAAI,CAAC,EACvD,OAAO,IAAI;QACb,oBACEhB,KAAA,CAAAmI,aAAA,CAACrH,WAAW;UACVsH,OAAO,EAAEtF,eAAgB;UACzBlB,IAAI,EAAE4H,WAAW,CAACxI,IAAI,CAACY,IAAK;UAC5ByG,OAAO,EAAEmB,WAAW,CAACxI,IAAI,CAACqH,OAAQ;UAClCf,GAAG,EAAEkC,WAAW,CAACxI,IAAI,CAAC0C,EAAG;UACzBe,QAAQ,EAAE+C,mBAAoB;UAC9B9D,EAAE,EAAE8F,WAAW,CAACxI,IAAI,CAAC0C,EAAG;UACxBc,KAAK,EAAEA,KAAK,CAACxD,IAAK;UAClBC,OAAO,EAAEuI,WAAW,CAACxI,IAAI,CAACC,OAAQ;UAClCqH,aAAa,EAAEJ,kBAAmB;UAClC7G,IAAI,EAAEA,IAAK;UACXkH,QAAQ,EAAExG,YAAa;UACvB4C,MAAM,EAAEA,MAAO;UACflC,YAAY,EAAEA;QAAa,CAC5B,CAAC;MAGN,KAAK,QAAQ;QACX,IAAI,CAAC+G,WAAW,CAACxI,IAAI,IAAID,aAAa,CAACyI,WAAW,CAACxI,IAAI,CAAC,EAAE,OAAO,IAAI;QACrE,oBACEhB,KAAA,CAAAmI,aAAA,CAACvH,MAAM;UACLgB,IAAI,EAAG4H,WAAW,CAACxI,IAAI,CAAsBY,IAAK;UAClD4G,GAAG,EAAEhE,KAAK,CAACxD,IAAI,KAAKwI,WAAW,CAAC9F,EAAE,GAAGb,OAAO,GAAG,IAAK;UACpDyE,GAAG,EAAEV,KAAM;UACXyB,OAAO,EAAGmB,WAAW,CAACxI,IAAI,CAAsBqH,OAAQ;UACxDI,YAAY,EAAEA,CAAA,KAAMV,gBAAgB,CAACyB,WAAW,CAAC9F,EAAE,CAAE;UACrDgF,OAAO,EAAEV,WAAY;UACrBtE,EAAE,EAAE8F,WAAW,CAAC9F,EAAG;UACnBc,KAAK,EAAEgF,WAAW,CAAC9F,EAAE,KAAKc,KAAK,CAACxD,IAAK;UACrC2H,SAAS,EAAE3G,eAAgB;UAC3BN,YAAY,EAAEA,YAAY,CACxB;YACE,GAAI8H,WAAW,CAACxI,IAAyB;YACzCY,IAAI,EAAEjB,aAAa,CAChB6I,WAAW,CAACxI,IAAI,CAAsBY,IAAI,EAC3C+C,MACF;UACF,CAAC,EACD;YACEjB,EAAE,cAAY8F,WAAW,CAAC9F,EAAI;YAC9B0E,OAAO,EACLtF,eAAe,IAAIA,eAAe,CAACW,QAAQ,CAAC+F,WAAW,CAAC9F,EAAE,CAAC;YAC7Dc,KAAK,EAAEA,KAAK,CAACxD,IAAI,KAAKwI,WAAW,CAAC9F,EAAE;YACpC6E,QAAQ,EAAEA,CAAA,KAAM;UAClB,CACF;QAAE,CACH,CAAC;MAGN,KAAK,UAAU;QACb,oBAAOvI,KAAA,CAAAmI,aAAA,CAAAuB,mBAAA,QAAkCjI,YAA2B,CAAC;MAEvE,KAAK,QAAQ;QACX,oBACEzB,KAAA,CAAAmI,aAAA,CAAC1H,yBAAyB;UACxB+H,GAAG,EAAEhE,KAAK,CAACxD,IAAI,KAAK,QAAQ,GAAG6B,OAAO,GAAG,IAAK;UAC9CyE,GAAG,EAAC,YAAY;UAChB9C,KAAK,EAAEA,KAAK,CAACxD,IAAI,KAAK,QAAS;UAC/B2I,WAAW,EAAE9E,WAAY;UACzB4D,YAAY,EAAEtD;QAAmB,GAEhC3D,UACwB,CAAC;MAGhC;QACE,OAAO,IAAI;IACf;EACF,CAAC,EACD,CACEK,YAAY,EACZ2C,KAAK,CAACxD,IAAI,EACV+G,gBAAgB,EAChBrG,YAAY,EACZ4H,uBAAuB,EACvBxG,eAAe,EACf0E,mBAAmB,EACnBU,kBAAkB,EAClB7G,IAAI,EACJU,YAAY,EACZ4C,MAAM,EACNlC,YAAY,EACZuF,WAAW,EACXhG,eAAe,EACfP,YAAY,EACZoD,WAAW,EACXM,kBAAkB,EAClB3D,UAAU,EACViG,cAAc,CAElB,CAAC;EAED,oBACEzH,KAAA,CAAAmI,aAAA,CAACzH,8BAA8B;IAC7BiI,SAAS,EAAExG,qBAAsB;IACjCyH,SAAS,EACP,CAAC/H,YAAY,IAAI,CAACL,UAAU,IAAI,CAACC,YAAY,IAAI2E,IAAI,CAACD,MAAM,GAAG;EAChE,GAEA0D,KAAA;IAAA,IAAC;MAAEC;IAAS,CAAC,GAAAD,KAAA;IAAA,oBACZ7J,KAAA,CAAAmI,aAAA,CAAC3H,sBAAsB;MAAC8G,GAAG,EAAC,MAAM;MAACyC,YAAY,EAAEnB;IAAmB,gBAClE5I,KAAA,CAAAmI,aAAA;MACEK,GAAG,EAAE5F,gBAAiB;MACtBoH,KAAK,EAAE;QACLC,MAAM,EAAKC,IAAI,CAACC,GAAG,CACjBrD,cAAc,CAACsD,YAAY,CAAC,CAAC,GAAG,EAAE,EAClC7H,aACF,CAAC,OAAI;QACL8H,QAAQ,EAAE;MACZ,CAAE;MACFP,QAAQ,EAAGhF,CAAC,IAAK;QACf,IAAIgF,QAAQ,EAAEA,QAAQ,CAAChF,CAAC,CAAC;MAC3B;IAAE,gBAEF9E,KAAA,CAAAmI,aAAA;MACE6B,KAAK,EAAE;QACLC,MAAM,EAAKnD,cAAc,CAACsD,YAAY,CAAC,CAAC,OAAI;QAC5CE,KAAK,EAAE,MAAM;QACbC,QAAQ,EAAE;MACZ;IAAE,GAED1D,uBAAuB,GACpBC,cAAc,CAAC0D,eAAe,CAAC,CAAC,CAAC1G,GAAG,CAAE2G,UAAU,IAAK;MACnD,MAAMzJ,IAAI,GAAGwF,YAAY,CAACiE,UAAU,CAAC7D,KAAK,CAAC;MAC3C,oBACE5G,KAAA,CAAAmI,aAAA;QACEb,GAAG,EAAEmD,UAAU,CAAC7D,KAAM;QACtB,cAAY6D,UAAU,CAAC7D,KAAM;QAC7BoD,KAAK,EAAE;UACLO,QAAQ,EAAE,UAAU;UACpBG,GAAG,EAAE,CAAC;UACNC,IAAI,EAAE,CAAC;UACPL,KAAK,EAAE,MAAM;UACbM,SAAS,kBAAgBH,UAAU,CAACI,KAAK;QAC3C;MAAE,GAEDtB,iBAAiB,CAACvI,IAAI,EAAEyJ,UAAU,CAAC7D,KAAK,CACtC,CAAC;IAEV,CAAC,CAAC,GACFJ,YAAY,CAAC1C,GAAG,CAAC,CAAC9C,IAAI,EAAE4F,KAAK,kBAC3B5G,KAAA,CAAAmI,aAAA,CAACnI,KAAK,CAAC8K,QAAQ;MAACxD,GAAG,EAAEV;IAAM,GACxB2C,iBAAiB,CAACvI,IAAI,EAAE4F,KAAK,CAChB,CACjB,CACF,CACF,CACiB,CAAC;EAAA,CAEG,CAAC;AAErC,CAAC;AAEDzF,YAAY,CAAC4J,WAAW,GAAG,cAAc;AAAC,IAAArB,mBAAA,GAAAsB,OAAA,CAAAnK,YAAA,EAAAoK,UAAA;EAAAF,WAAA;EAAAG,WAAA;AAAA"}
|
|
@@ -10,6 +10,7 @@ export interface ConfirmDialogProps {
|
|
|
10
10
|
cancelBtnText?: string;
|
|
11
11
|
shouldShowCancelButton?: boolean;
|
|
12
12
|
isLoading?: boolean;
|
|
13
|
+
fullWidth?: boolean;
|
|
13
14
|
}
|
|
14
15
|
export declare const ConfirmDialog: React.ForwardRefExoticComponent<ConfirmDialogProps & React.RefAttributes<HTMLDivElement>>;
|
|
15
16
|
//# sourceMappingURL=ConfirmDialog.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ConfirmDialog.d.ts","sourceRoot":"","sources":["../../../../src/components/ConfirmDialog/ConfirmDialog.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAgC,MAAM,OAAO,CAAC;AAQrD,MAAM,WAAW,kBAAkB;IACjC,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,QAAQ,CAAC,EAAE,MAAM,IAAI,CAAC;IACtB,SAAS,CAAC,EAAE,MAAM,IAAI,CAAC;IACvB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,sBAAsB,CAAC,EAAE,OAAO,CAAC;IACjC,SAAS,CAAC,EAAE,OAAO,CAAC;CACrB;AAED,eAAO,MAAM,aAAa,
|
|
1
|
+
{"version":3,"file":"ConfirmDialog.d.ts","sourceRoot":"","sources":["../../../../src/components/ConfirmDialog/ConfirmDialog.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAgC,MAAM,OAAO,CAAC;AAQrD,MAAM,WAAW,kBAAkB;IACjC,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,QAAQ,CAAC,EAAE,MAAM,IAAI,CAAC;IACtB,SAAS,CAAC,EAAE,MAAM,IAAI,CAAC;IACvB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,sBAAsB,CAAC,EAAE,OAAO,CAAC;IACjC,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,SAAS,CAAC,EAAE,OAAO,CAAC;CACrB;AAED,eAAO,MAAM,aAAa,2FA2EzB,CAAC"}
|
|
@@ -14,7 +14,8 @@ export const ConfirmDialog = /*#__PURE__*/forwardRef((_ref, ref) => {
|
|
|
14
14
|
confirmBtnText = "OK",
|
|
15
15
|
cancelBtnText = "Cancel",
|
|
16
16
|
shouldShowCancelButton = true,
|
|
17
|
-
isLoading = false
|
|
17
|
+
isLoading = false,
|
|
18
|
+
fullWidth = false
|
|
18
19
|
} = _ref;
|
|
19
20
|
useEffect(() => {
|
|
20
21
|
const handleKeyDown = event => {
|
|
@@ -35,7 +36,8 @@ export const ConfirmDialog = /*#__PURE__*/forwardRef((_ref, ref) => {
|
|
|
35
36
|
open: open,
|
|
36
37
|
onClose: onCancel,
|
|
37
38
|
className: classnames("c-confirm-dialog", className),
|
|
38
|
-
disableCloseOnEsc: isLoading
|
|
39
|
+
disableCloseOnEsc: isLoading,
|
|
40
|
+
fullWidth: fullWidth
|
|
39
41
|
}, /*#__PURE__*/React.createElement(Dialog.Title, null, dialogTitle), /*#__PURE__*/React.createElement(Dialog.ContentDivider, null), /*#__PURE__*/React.createElement(Dialog.Content, null, /*#__PURE__*/React.createElement(Body2, {
|
|
40
42
|
lineHeight: "loose",
|
|
41
43
|
color: "secondary",
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ConfirmDialog.js","names":["React","forwardRef","useEffect","classnames","Button","Dialog","Body2","ConfirmDialog","_ref","ref","open","onCancel","onConfirm","className","dialogTitle","dialogContent","confirmBtnText","cancelBtnText","shouldShowCancelButton","isLoading","handleKeyDown","event","key","preventDefault","window","addEventListener","removeEventListener","createElement","onClose","disableCloseOnEsc","Title","ContentDivider","Content","lineHeight","color","whitespace","Actions","variant","style","marginRight","onClick","disabled","type","displayName"],"sources":["../../../../src/components/ConfirmDialog/ConfirmDialog.tsx"],"sourcesContent":["import React, { forwardRef, useEffect } from \"react\";\n\nimport classnames from \"classnames\";\n\nimport { Button } from \"../Button/Button\";\nimport { Dialog } from \"../Dialog\";\nimport { Body2 } from \"../Typography/Variants/Body2\";\n\nexport interface ConfirmDialogProps {\n open?: boolean;\n onCancel?: () => void;\n onConfirm?: () => void;\n className?: string;\n dialogTitle?: string;\n dialogContent?: string;\n confirmBtnText?: string;\n cancelBtnText?: string;\n shouldShowCancelButton?: boolean;\n isLoading?: boolean;\n}\n\nexport const ConfirmDialog = forwardRef<HTMLDivElement, ConfirmDialogProps>(\n (\n {\n open = false,\n onCancel,\n onConfirm,\n className,\n dialogTitle = \"Discard changes?\",\n dialogContent = \"All unsaved changes will be lost.\",\n confirmBtnText = \"OK\",\n cancelBtnText = \"Cancel\",\n shouldShowCancelButton = true,\n isLoading = false,\n },\n ref\n ) => {\n useEffect(() => {\n const handleKeyDown = (event: KeyboardEvent) => {\n if (event.key === \"Enter\" && onConfirm) {\n event.preventDefault();\n onConfirm();\n }\n };\n\n if (open) {\n window.addEventListener(\"keydown\", handleKeyDown);\n }\n\n return () => {\n window.removeEventListener(\"keydown\", handleKeyDown);\n };\n }, [open, onConfirm]);\n\n return (\n <Dialog\n ref={ref}\n open={open}\n onClose={onCancel}\n className={classnames(\"c-confirm-dialog\", className)}\n disableCloseOnEsc={isLoading}\n >\n <Dialog.Title>{dialogTitle}</Dialog.Title>\n <Dialog.ContentDivider />\n <Dialog.Content>\n <Body2 lineHeight=\"loose\" color=\"secondary\" whitespace=\"pre-line\">\n {dialogContent}\n </Body2>\n </Dialog.Content>\n <Dialog.ContentDivider />\n <Dialog.Actions>\n <Button\n variant=\"primary\"\n style={{ marginRight: \"12px\" }}\n onClick={onConfirm}\n disabled={isLoading}\n >\n {confirmBtnText}\n </Button>\n {shouldShowCancelButton ? (\n <Button\n variant=\"secondary\"\n data-action=\"cancel\"\n onClick={onCancel}\n type=\"button\"\n disabled={isLoading}\n >\n {cancelBtnText}\n </Button>\n ) : null}\n </Dialog.Actions>\n </Dialog>\n );\n }\n);\n\nConfirmDialog.displayName = \"ConfirmDialog\";\n"],"mappings":"AAAA,OAAOA,KAAK,IAAIC,UAAU,EAAEC,SAAS,QAAQ,OAAO;AAEpD,OAAOC,UAAU,MAAM,YAAY;AAEnC,SAASC,MAAM,QAAQ,kBAAkB;AACzC,SAASC,MAAM,QAAQ,WAAW;AAClC,SAASC,KAAK,QAAQ,8BAA8B;
|
|
1
|
+
{"version":3,"file":"ConfirmDialog.js","names":["React","forwardRef","useEffect","classnames","Button","Dialog","Body2","ConfirmDialog","_ref","ref","open","onCancel","onConfirm","className","dialogTitle","dialogContent","confirmBtnText","cancelBtnText","shouldShowCancelButton","isLoading","fullWidth","handleKeyDown","event","key","preventDefault","window","addEventListener","removeEventListener","createElement","onClose","disableCloseOnEsc","Title","ContentDivider","Content","lineHeight","color","whitespace","Actions","variant","style","marginRight","onClick","disabled","type","displayName"],"sources":["../../../../src/components/ConfirmDialog/ConfirmDialog.tsx"],"sourcesContent":["import React, { forwardRef, useEffect } from \"react\";\n\nimport classnames from \"classnames\";\n\nimport { Button } from \"../Button/Button\";\nimport { Dialog } from \"../Dialog\";\nimport { Body2 } from \"../Typography/Variants/Body2\";\n\nexport interface ConfirmDialogProps {\n open?: boolean;\n onCancel?: () => void;\n onConfirm?: () => void;\n className?: string;\n dialogTitle?: string;\n dialogContent?: string;\n confirmBtnText?: string;\n cancelBtnText?: string;\n shouldShowCancelButton?: boolean;\n isLoading?: boolean;\n fullWidth?: boolean;\n}\n\nexport const ConfirmDialog = forwardRef<HTMLDivElement, ConfirmDialogProps>(\n (\n {\n open = false,\n onCancel,\n onConfirm,\n className,\n dialogTitle = \"Discard changes?\",\n dialogContent = \"All unsaved changes will be lost.\",\n confirmBtnText = \"OK\",\n cancelBtnText = \"Cancel\",\n shouldShowCancelButton = true,\n isLoading = false,\n fullWidth = false,\n },\n ref\n ) => {\n useEffect(() => {\n const handleKeyDown = (event: KeyboardEvent) => {\n if (event.key === \"Enter\" && onConfirm) {\n event.preventDefault();\n onConfirm();\n }\n };\n\n if (open) {\n window.addEventListener(\"keydown\", handleKeyDown);\n }\n\n return () => {\n window.removeEventListener(\"keydown\", handleKeyDown);\n };\n }, [open, onConfirm]);\n\n return (\n <Dialog\n ref={ref}\n open={open}\n onClose={onCancel}\n className={classnames(\"c-confirm-dialog\", className)}\n disableCloseOnEsc={isLoading}\n fullWidth={fullWidth}\n >\n <Dialog.Title>{dialogTitle}</Dialog.Title>\n <Dialog.ContentDivider />\n <Dialog.Content>\n <Body2 lineHeight=\"loose\" color=\"secondary\" whitespace=\"pre-line\">\n {dialogContent}\n </Body2>\n </Dialog.Content>\n <Dialog.ContentDivider />\n <Dialog.Actions>\n <Button\n variant=\"primary\"\n style={{ marginRight: \"12px\" }}\n onClick={onConfirm}\n disabled={isLoading}\n >\n {confirmBtnText}\n </Button>\n {shouldShowCancelButton ? (\n <Button\n variant=\"secondary\"\n data-action=\"cancel\"\n onClick={onCancel}\n type=\"button\"\n disabled={isLoading}\n >\n {cancelBtnText}\n </Button>\n ) : null}\n </Dialog.Actions>\n </Dialog>\n );\n }\n);\n\nConfirmDialog.displayName = \"ConfirmDialog\";\n"],"mappings":"AAAA,OAAOA,KAAK,IAAIC,UAAU,EAAEC,SAAS,QAAQ,OAAO;AAEpD,OAAOC,UAAU,MAAM,YAAY;AAEnC,SAASC,MAAM,QAAQ,kBAAkB;AACzC,SAASC,MAAM,QAAQ,WAAW;AAClC,SAASC,KAAK,QAAQ,8BAA8B;AAgBpD,OAAO,MAAMC,aAAa,gBAAGN,UAAU,CACrC,CAAAO,IAAA,EAcEC,GAAG,KACA;EAAA,IAdH;IACEC,IAAI,GAAG,KAAK;IACZC,QAAQ;IACRC,SAAS;IACTC,SAAS;IACTC,WAAW,GAAG,kBAAkB;IAChCC,aAAa,GAAG,mCAAmC;IACnDC,cAAc,GAAG,IAAI;IACrBC,aAAa,GAAG,QAAQ;IACxBC,sBAAsB,GAAG,IAAI;IAC7BC,SAAS,GAAG,KAAK;IACjBC,SAAS,GAAG;EACd,CAAC,GAAAZ,IAAA;EAGDN,SAAS,CAAC,MAAM;IACd,MAAMmB,aAAa,GAAIC,KAAoB,IAAK;MAC9C,IAAIA,KAAK,CAACC,GAAG,KAAK,OAAO,IAAIX,SAAS,EAAE;QACtCU,KAAK,CAACE,cAAc,CAAC,CAAC;QACtBZ,SAAS,CAAC,CAAC;MACb;IACF,CAAC;IAED,IAAIF,IAAI,EAAE;MACRe,MAAM,CAACC,gBAAgB,CAAC,SAAS,EAAEL,aAAa,CAAC;IACnD;IAEA,OAAO,MAAM;MACXI,MAAM,CAACE,mBAAmB,CAAC,SAAS,EAAEN,aAAa,CAAC;IACtD,CAAC;EACH,CAAC,EAAE,CAACX,IAAI,EAAEE,SAAS,CAAC,CAAC;EAErB,oBACEZ,KAAA,CAAA4B,aAAA,CAACvB,MAAM;IACLI,GAAG,EAAEA,GAAI;IACTC,IAAI,EAAEA,IAAK;IACXmB,OAAO,EAAElB,QAAS;IAClBE,SAAS,EAAEV,UAAU,CAAC,kBAAkB,EAAEU,SAAS,CAAE;IACrDiB,iBAAiB,EAAEX,SAAU;IAC7BC,SAAS,EAAEA;EAAU,gBAErBpB,KAAA,CAAA4B,aAAA,CAACvB,MAAM,CAAC0B,KAAK,QAAEjB,WAA0B,CAAC,eAC1Cd,KAAA,CAAA4B,aAAA,CAACvB,MAAM,CAAC2B,cAAc,MAAE,CAAC,eACzBhC,KAAA,CAAA4B,aAAA,CAACvB,MAAM,CAAC4B,OAAO,qBACbjC,KAAA,CAAA4B,aAAA,CAACtB,KAAK;IAAC4B,UAAU,EAAC,OAAO;IAACC,KAAK,EAAC,WAAW;IAACC,UAAU,EAAC;EAAU,GAC9DrB,aACI,CACO,CAAC,eACjBf,KAAA,CAAA4B,aAAA,CAACvB,MAAM,CAAC2B,cAAc,MAAE,CAAC,eACzBhC,KAAA,CAAA4B,aAAA,CAACvB,MAAM,CAACgC,OAAO,qBACbrC,KAAA,CAAA4B,aAAA,CAACxB,MAAM;IACLkC,OAAO,EAAC,SAAS;IACjBC,KAAK,EAAE;MAAEC,WAAW,EAAE;IAAO,CAAE;IAC/BC,OAAO,EAAE7B,SAAU;IACnB8B,QAAQ,EAAEvB;EAAU,GAEnBH,cACK,CAAC,EACRE,sBAAsB,gBACrBlB,KAAA,CAAA4B,aAAA,CAACxB,MAAM;IACLkC,OAAO,EAAC,WAAW;IACnB,eAAY,QAAQ;IACpBG,OAAO,EAAE9B,QAAS;IAClBgC,IAAI,EAAC,QAAQ;IACbD,QAAQ,EAAEvB;EAAU,GAEnBF,aACK,CAAC,GACP,IACU,CACV,CAAC;AAEb,CACF,CAAC;AAEDV,aAAa,CAACqC,WAAW,GAAG,eAAe"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Styles.d.ts","sourceRoot":"","sources":["../../../../src/components/Dialog/Styles.ts"],"names":[],"mappings":"AAMA,eAAO,MAAM,YAAY;;
|
|
1
|
+
{"version":3,"file":"Styles.d.ts","sourceRoot":"","sources":["../../../../src/components/Dialog/Styles.ts"],"names":[],"mappings":"AAMA,eAAO,MAAM,YAAY;;SA+BxB,CAAC;AAIF,eAAO,MAAM,iBAAiB,oEAK7B,CAAC;AAGF,eAAO,MAAM,mBAAmB,oEAQ/B,CAAC;AAGF,eAAO,MAAM,0BAA0B,oEAGtC,CAAC;AAGF,eAAO,MAAM,mBAAmB,oEAK/B,CAAC"}
|
|
@@ -5,7 +5,7 @@ import { FontStyle } from "../FontStyle";
|
|
|
5
5
|
export const StyledDialog = styled.div.withConfig({
|
|
6
6
|
displayName: "Styles__StyledDialog",
|
|
7
7
|
componentId: "sc-jwpvgm-0"
|
|
8
|
-
})(["display:flex;flex-direction:column;flex:1 1 auto;max-height:calc(100vh - 156px);background-color:var(--page-paper-main);color:var(--color-theme-900);box-shadow:var(--shadow-primary);border-radius:8px;width:310px;margin:60px auto 30px auto;position:relative;", " ", " ", " ", "{width:540px;margin:126px auto 30px auto;}"], props => props.$fullWidth && css(["width:calc(100% - 32px);max-width:640px;margin-left:16px;margin-right:16px;"]), FontStyle, BoxSizingStyle, screen.sm);
|
|
8
|
+
})(["display:flex;flex-direction:column;flex:1 1 auto;max-height:calc(100vh - 156px);background-color:var(--page-paper-main);color:var(--color-theme-900);box-shadow:var(--shadow-primary);border-radius:8px;width:310px;margin:60px auto 30px auto;position:relative;", " ", " ", " ", "{width:540px;margin:126px auto 30px auto;}"], props => props.$fullWidth && css(["@media (max-width:640px){width:calc(100% - 32px);max-width:640px;margin-left:16px;margin-right:16px;}"]), FontStyle, BoxSizingStyle, screen.sm);
|
|
9
9
|
StyledDialog.displayName = "StyledDialog";
|
|
10
10
|
export const StyledDialogTitle = styled.div.withConfig({
|
|
11
11
|
displayName: "Styles__StyledDialogTitle",
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Styles.js","names":["styled","css","BoxSizingStyle","screen","FontStyle","StyledDialog","div","withConfig","displayName","componentId","props","$fullWidth","sm","StyledDialogTitle","StyledDialogContent","StyledDialogContentDivider","StyledDialogActions"],"sources":["../../../../src/components/Dialog/Styles.ts"],"sourcesContent":["import styled, { css } from \"styled-components\";\n\nimport { BoxSizingStyle } from \"../BoxSizingStyle\";\nimport { screen } from \"../BreakPoints\";\nimport { FontStyle } from \"../FontStyle\";\n\nexport const StyledDialog = styled.div<{ $fullWidth?: boolean }>`\n display: flex;\n flex-direction: column;\n flex: 1 1 auto;\n max-height: calc(100vh - 156px);\n background-color: var(--page-paper-main);\n color: var(--color-theme-900);\n box-shadow: var(--shadow-primary);\n border-radius: 8px;\n width: 310px;\n margin: 60px auto 30px auto;\n position: relative;\n\n ${(props) =>\n props.$fullWidth &&\n css`\n width: calc(100% - 32px);\n
|
|
1
|
+
{"version":3,"file":"Styles.js","names":["styled","css","BoxSizingStyle","screen","FontStyle","StyledDialog","div","withConfig","displayName","componentId","props","$fullWidth","sm","StyledDialogTitle","StyledDialogContent","StyledDialogContentDivider","StyledDialogActions"],"sources":["../../../../src/components/Dialog/Styles.ts"],"sourcesContent":["import styled, { css } from \"styled-components\";\n\nimport { BoxSizingStyle } from \"../BoxSizingStyle\";\nimport { screen } from \"../BreakPoints\";\nimport { FontStyle } from \"../FontStyle\";\n\nexport const StyledDialog = styled.div<{ $fullWidth?: boolean }>`\n display: flex;\n flex-direction: column;\n flex: 1 1 auto;\n max-height: calc(100vh - 156px);\n background-color: var(--page-paper-main);\n color: var(--color-theme-900);\n box-shadow: var(--shadow-primary);\n border-radius: 8px;\n width: 310px;\n margin: 60px auto 30px auto;\n position: relative;\n\n ${(props) =>\n props.$fullWidth &&\n css`\n @media (max-width: 640px) {\n width: calc(100% - 32px);\n max-width: 640px;\n margin-left: 16px;\n margin-right: 16px;\n }\n `}\n\n ${FontStyle}\n ${BoxSizingStyle}\n\n ${screen.sm} {\n width: 540px;\n margin: 126px auto 30px auto;\n }\n`;\n\nStyledDialog.displayName = \"StyledDialog\";\n\nexport const StyledDialogTitle = styled.div`\n padding: 20px 30px;\n\n ${FontStyle}\n ${BoxSizingStyle}\n`;\nStyledDialogTitle.displayName = \"StyledDialogTitle\";\n\nexport const StyledDialogContent = styled.div`\n padding: 20px 30px;\n max-height: 580px;\n overflow-y: auto;\n flex: 1 1 auto;\n\n ${FontStyle}\n ${BoxSizingStyle}\n`;\nStyledDialogContent.displayName = \"StyledDialogContent\";\n\nexport const StyledDialogContentDivider = styled.div`\n border-top: 1px solid var(--border-primary);\n height: 1px;\n`;\nStyledDialogContentDivider.displayName = \"StyledDialogContentDivider\";\n\nexport const StyledDialogActions = styled.div`\n padding: 20px 30px;\n\n ${FontStyle}\n ${BoxSizingStyle}\n`;\nStyledDialogActions.displayName = \"StyledDialogActions\";\n"],"mappings":"AAAA,OAAOA,MAAM,IAAIC,GAAG,QAAQ,mBAAmB;AAE/C,SAASC,cAAc,QAAQ,mBAAmB;AAClD,SAASC,MAAM,QAAQ,gBAAgB;AACvC,SAASC,SAAS,QAAQ,cAAc;AAExC,OAAO,MAAMC,YAAY,GAAGL,MAAM,CAACM,GAAG,CAAAC,UAAA;EAAAC,WAAA;EAAAC,WAAA;AAAA,uUAajCC,KAAK,IACNA,KAAK,CAACC,UAAU,IAChBV,GAAG,2GAOF,EAEDG,SAAS,EACTF,cAAc,EAEdC,MAAM,CAACS,EAAE,CAIZ;AAEDP,YAAY,CAACG,WAAW,GAAG,cAAc;AAEzC,OAAO,MAAMK,iBAAiB,GAAGb,MAAM,CAACM,GAAG,CAAAC,UAAA;EAAAC,WAAA;EAAAC,WAAA;AAAA,oCAGvCL,SAAS,EACTF,cAAc,CACjB;AACDW,iBAAiB,CAACL,WAAW,GAAG,mBAAmB;AAEnD,OAAO,MAAMM,mBAAmB,GAAGd,MAAM,CAACM,GAAG,CAAAC,UAAA;EAAAC,WAAA;EAAAC,WAAA;AAAA,mFAMzCL,SAAS,EACTF,cAAc,CACjB;AACDY,mBAAmB,CAACN,WAAW,GAAG,qBAAqB;AAEvD,OAAO,MAAMO,0BAA0B,GAAGf,MAAM,CAACM,GAAG,CAAAC,UAAA;EAAAC,WAAA;EAAAC,WAAA;AAAA,8DAGnD;AACDM,0BAA0B,CAACP,WAAW,GAAG,4BAA4B;AAErE,OAAO,MAAMQ,mBAAmB,GAAGhB,MAAM,CAACM,GAAG,CAAAC,UAAA;EAAAC,WAAA;EAAAC,WAAA;AAAA,oCAGzCL,SAAS,EACTF,cAAc,CACjB;AACDc,mBAAmB,CAACR,WAAW,GAAG,qBAAqB"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Option.d.ts","sourceRoot":"","sources":["../../../../../src/components/Select/Option/Option.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAEZ,iBAAiB,EACjB,SAAS,EAGV,MAAM,OAAO,CAAC;AAMf,MAAM,WAAW,gBAAgB;IAC/B,sBAAsB;IACtB,EAAE,EAAE,MAAM,GAAG,MAAM,CAAC;IACpB,sBAAsB;IACtB,IAAI,EAAE,MAAM,CAAC;IACb,0BAA0B;IAC1B,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,yCAAyC;IACzC,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,0CAA0C;IAC1C,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC;IAC1B,0BAA0B;IAC1B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,2BAA2B;IAC3B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,qBAAqB;IACrB,KAAK,CAAC,EAAE,OAAO,CAAC;
|
|
1
|
+
{"version":3,"file":"Option.d.ts","sourceRoot":"","sources":["../../../../../src/components/Select/Option/Option.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAEZ,iBAAiB,EACjB,SAAS,EAGV,MAAM,OAAO,CAAC;AAMf,MAAM,WAAW,gBAAgB;IAC/B,sBAAsB;IACtB,EAAE,EAAE,MAAM,GAAG,MAAM,CAAC;IACpB,sBAAsB;IACtB,IAAI,EAAE,MAAM,CAAC;IACb,0BAA0B;IAC1B,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,yCAAyC;IACzC,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,0CAA0C;IAC1C,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC;IAC1B,0BAA0B;IAC1B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,2BAA2B;IAC3B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,qBAAqB;IACrB,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,kBAAkB;IAClB,MAAM,CAAC,EAAE,OAAO,CAAC;CAClB;AAED,UAAU,0BAA0B;IAClC,sBAAsB;IACtB,EAAE,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IACrB,sBAAsB;IACtB,IAAI,EAAE,MAAM,CAAC;IACb,0BAA0B;IAC1B,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,oBAAoB;IACpB,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,2BAA2B;IAC3B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,6BAA6B;IAC7B,YAAY,CAAC,EAAE,SAAS,CAAC;IACzB,8BAA8B;IAC9B,YAAY,CAAC,EAAE,CAAC,CAAC,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS,KAAK,IAAI,CAAC;IACxD,qBAAqB;IACrB,OAAO,CAAC,EAAE,iBAAiB,CAAC,aAAa,CAAC,CAAC;CAC5C;AAED,eAAO,MAAM,MAAM,kGAkClB,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Option.js","names":["React","forwardRef","useCallback","classnames","StyledOption","Option","_ref","ref","id","name","tooltip","hover","className","renderOption","onMouseEnter","onClick","handleOnMouseEnter","createElement","title","onTouchStart","displayName"],"sources":["../../../../../src/components/Select/Option/Option.tsx"],"sourcesContent":["import React, {\n forwardRef,\n MouseEventHandler,\n ReactNode,\n Ref,\n useCallback,\n} from \"react\";\n\nimport classnames from \"classnames\";\n\nimport { StyledOption } from \"./Styles\";\n\nexport interface IOptionItemProps {\n /** Value of option */\n id: string | number;\n /** Label of option */\n name: string;\n /** Content for tooltip */\n tooltip?: string;\n /** Additional info right-side of name */\n additionalInfo?: string;\n /** image url for Avatar or MultiAvatar */\n image?: string | string[];\n /** Hex color for label */\n color?: string;\n /** Color for chip label */\n chipColor?: string;\n /** Value of mixed */\n mixed?: boolean;\n}\n\ninterface IAdditionalOptionItemProps {\n /** Value of option */\n id?: string | number;\n /** Label of option */\n name: string;\n /** Content for tooltip */\n tooltip?: string;\n /** Hovered state */\n hover?: boolean;\n /** Class name of option */\n className?: string;\n /** Render option function */\n renderOption?: ReactNode;\n /** On mouse enter callback */\n onMouseEnter?: (e: string | number | undefined) => void;\n /** On mouse click */\n onClick?: MouseEventHandler<HTMLLIElement>;\n}\n\nexport const Option = forwardRef(\n (\n {\n id,\n name,\n tooltip = \"\",\n hover,\n className,\n renderOption,\n onMouseEnter,\n onClick = () => null,\n }: IAdditionalOptionItemProps,\n ref: Ref<HTMLLIElement>\n ) => {\n const handleOnMouseEnter = useCallback(() => {\n if (onMouseEnter) {\n onMouseEnter(id);\n }\n }, [onMouseEnter, id]);\n\n return (\n <StyledOption\n ref={hover ? ref : null}\n title={tooltip ? tooltip : name}\n onMouseEnter={handleOnMouseEnter}\n onTouchStart={handleOnMouseEnter}\n className={classnames(\"c-option\", className)}\n hover={hover}\n onClick={onClick}\n >\n {renderOption ? renderOption : name}\n </StyledOption>\n );\n }\n);\n\nOption.displayName = \"Option\";\n"],"mappings":"AAAA,OAAOA,KAAK,IACVC,UAAU,EAIVC,WAAW,QACN,OAAO;AAEd,OAAOC,UAAU,MAAM,YAAY;AAEnC,SAASC,YAAY,QAAQ,UAAU;
|
|
1
|
+
{"version":3,"file":"Option.js","names":["React","forwardRef","useCallback","classnames","StyledOption","Option","_ref","ref","id","name","tooltip","hover","className","renderOption","onMouseEnter","onClick","handleOnMouseEnter","createElement","title","onTouchStart","displayName"],"sources":["../../../../../src/components/Select/Option/Option.tsx"],"sourcesContent":["import React, {\n forwardRef,\n MouseEventHandler,\n ReactNode,\n Ref,\n useCallback,\n} from \"react\";\n\nimport classnames from \"classnames\";\n\nimport { StyledOption } from \"./Styles\";\n\nexport interface IOptionItemProps {\n /** Value of option */\n id: string | number;\n /** Label of option */\n name: string;\n /** Content for tooltip */\n tooltip?: string;\n /** Additional info right-side of name */\n additionalInfo?: string;\n /** image url for Avatar or MultiAvatar */\n image?: string | string[];\n /** Hex color for label */\n color?: string;\n /** Color for chip label */\n chipColor?: string;\n /** Value of mixed */\n mixed?: boolean;\n /** Hide option */\n hidden?: boolean;\n}\n\ninterface IAdditionalOptionItemProps {\n /** Value of option */\n id?: string | number;\n /** Label of option */\n name: string;\n /** Content for tooltip */\n tooltip?: string;\n /** Hovered state */\n hover?: boolean;\n /** Class name of option */\n className?: string;\n /** Render option function */\n renderOption?: ReactNode;\n /** On mouse enter callback */\n onMouseEnter?: (e: string | number | undefined) => void;\n /** On mouse click */\n onClick?: MouseEventHandler<HTMLLIElement>;\n}\n\nexport const Option = forwardRef(\n (\n {\n id,\n name,\n tooltip = \"\",\n hover,\n className,\n renderOption,\n onMouseEnter,\n onClick = () => null,\n }: IAdditionalOptionItemProps,\n ref: Ref<HTMLLIElement>\n ) => {\n const handleOnMouseEnter = useCallback(() => {\n if (onMouseEnter) {\n onMouseEnter(id);\n }\n }, [onMouseEnter, id]);\n\n return (\n <StyledOption\n ref={hover ? ref : null}\n title={tooltip ? tooltip : name}\n onMouseEnter={handleOnMouseEnter}\n onTouchStart={handleOnMouseEnter}\n className={classnames(\"c-option\", className)}\n hover={hover}\n onClick={onClick}\n >\n {renderOption ? renderOption : name}\n </StyledOption>\n );\n }\n);\n\nOption.displayName = \"Option\";\n"],"mappings":"AAAA,OAAOA,KAAK,IACVC,UAAU,EAIVC,WAAW,QACN,OAAO;AAEd,OAAOC,UAAU,MAAM,YAAY;AAEnC,SAASC,YAAY,QAAQ,UAAU;AA0CvC,OAAO,MAAMC,MAAM,gBAAGJ,UAAU,CAC9B,CAAAK,IAAA,EAWEC,GAAuB,KACpB;EAAA,IAXH;IACEC,EAAE;IACFC,IAAI;IACJC,OAAO,GAAG,EAAE;IACZC,KAAK;IACLC,SAAS;IACTC,YAAY;IACZC,YAAY;IACZC,OAAO,GAAGA,CAAA,KAAM;EACU,CAAC,GAAAT,IAAA;EAG7B,MAAMU,kBAAkB,GAAGd,WAAW,CAAC,MAAM;IAC3C,IAAIY,YAAY,EAAE;MAChBA,YAAY,CAACN,EAAE,CAAC;IAClB;EACF,CAAC,EAAE,CAACM,YAAY,EAAEN,EAAE,CAAC,CAAC;EAEtB,oBACER,KAAA,CAAAiB,aAAA,CAACb,YAAY;IACXG,GAAG,EAAEI,KAAK,GAAGJ,GAAG,GAAG,IAAK;IACxBW,KAAK,EAAER,OAAO,GAAGA,OAAO,GAAGD,IAAK;IAChCK,YAAY,EAAEE,kBAAmB;IACjCG,YAAY,EAAEH,kBAAmB;IACjCJ,SAAS,EAAET,UAAU,CAAC,UAAU,EAAES,SAAS,CAAE;IAC7CD,KAAK,EAAEA,KAAM;IACbI,OAAO,EAAEA;EAAQ,GAEhBF,YAAY,GAAGA,YAAY,GAAGJ,IACnB,CAAC;AAEnB,CACF,CAAC;AAEDJ,MAAM,CAACe,WAAW,GAAG,QAAQ"}
|
package/dist/index.js
CHANGED
|
@@ -12560,7 +12560,7 @@
|
|
|
12560
12560
|
displayName: "Styles__StyledDialog",
|
|
12561
12561
|
componentId: "sc-jwpvgm-0"
|
|
12562
12562
|
})(["display:flex;flex-direction:column;flex:1 1 auto;max-height:calc(100vh - 156px);background-color:var(--page-paper-main);color:var(--color-theme-900);box-shadow:var(--shadow-primary);border-radius:8px;width:310px;margin:60px auto 30px auto;position:relative;", " ", " ", " ", "{width:540px;margin:126px auto 30px auto;}"], function (props) {
|
|
12563
|
-
return props.$fullWidth && styled.css(["width:calc(100% - 32px);max-width:640px;margin-left:16px;margin-right:16px;"]);
|
|
12563
|
+
return props.$fullWidth && styled.css(["@media (max-width:640px){width:calc(100% - 32px);max-width:640px;margin-left:16px;margin-right:16px;}"]);
|
|
12564
12564
|
}, FontStyle, BoxSizingStyle, screen.sm);
|
|
12565
12565
|
StyledDialog.displayName = "StyledDialog";
|
|
12566
12566
|
var StyledDialogTitle = styled__default["default"].div.withConfig({
|
|
@@ -13130,7 +13130,9 @@
|
|
|
13130
13130
|
_ref$shouldShowCancel = _ref.shouldShowCancelButton,
|
|
13131
13131
|
shouldShowCancelButton = _ref$shouldShowCancel === void 0 ? true : _ref$shouldShowCancel,
|
|
13132
13132
|
_ref$isLoading = _ref.isLoading,
|
|
13133
|
-
isLoading = _ref$isLoading === void 0 ? false : _ref$isLoading
|
|
13133
|
+
isLoading = _ref$isLoading === void 0 ? false : _ref$isLoading,
|
|
13134
|
+
_ref$fullWidth = _ref.fullWidth,
|
|
13135
|
+
fullWidth = _ref$fullWidth === void 0 ? false : _ref$fullWidth;
|
|
13134
13136
|
React.useEffect(function () {
|
|
13135
13137
|
var handleKeyDown = function handleKeyDown(event) {
|
|
13136
13138
|
if (event.key === "Enter" && onConfirm) {
|
|
@@ -13150,7 +13152,8 @@
|
|
|
13150
13152
|
open: open,
|
|
13151
13153
|
onClose: onCancel,
|
|
13152
13154
|
className: classNames__default["default"]("c-confirm-dialog", className),
|
|
13153
|
-
disableCloseOnEsc: isLoading
|
|
13155
|
+
disableCloseOnEsc: isLoading,
|
|
13156
|
+
fullWidth: fullWidth
|
|
13154
13157
|
}, /*#__PURE__*/React__default["default"].createElement(Dialog.Title, null, dialogTitle), /*#__PURE__*/React__default["default"].createElement(Dialog.ContentDivider, null), /*#__PURE__*/React__default["default"].createElement(Dialog.Content, null, /*#__PURE__*/React__default["default"].createElement(Body2, {
|
|
13155
13158
|
lineHeight: "loose",
|
|
13156
13159
|
color: "secondary",
|
|
@@ -17338,6 +17341,9 @@
|
|
|
17338
17341
|
var trimmedFilter = filter.trim();
|
|
17339
17342
|
var isGrouped = options[0] && isOptionGroup(options[0]);
|
|
17340
17343
|
var matchesFilter = function matchesFilter(option) {
|
|
17344
|
+
if (option.hidden) {
|
|
17345
|
+
return false;
|
|
17346
|
+
}
|
|
17341
17347
|
var nameMatch = option.name.toLowerCase().includes(trimmedFilter.toLowerCase());
|
|
17342
17348
|
if (filterCriteria && trimmedFilter) {
|
|
17343
17349
|
return nameMatch || filterCriteria(option, trimmedFilter);
|