@salutejs/plasma-new-hope 0.271.0-canary.1778.13390888088.0 → 0.271.0-canary.1782.13387584790.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (86) hide show
  1. package/cjs/components/Combobox/ComboboxNew/Combobox.js +5 -1
  2. package/cjs/components/Combobox/ComboboxNew/Combobox.js.map +1 -1
  3. package/cjs/components/Notification/Notification.css +11 -11
  4. package/cjs/components/Notification/Notification.js +3 -7
  5. package/cjs/components/Notification/Notification.js.map +1 -1
  6. package/cjs/components/Notification/Notification.styles.js +26 -42
  7. package/cjs/components/Notification/Notification.styles.js.map +1 -1
  8. package/cjs/components/Notification/{Notification.styles_gk4bgs.css → Notification.styles_1u5gusp.css} +2 -2
  9. package/cjs/components/Notification/Notification.tokens.js +0 -1
  10. package/cjs/components/Notification/Notification.tokens.js.map +1 -1
  11. package/cjs/components/Notification/Notification.types.js.map +1 -1
  12. package/cjs/components/Notification/NotificationsPortal.js +0 -1
  13. package/cjs/components/Notification/NotificationsPortal.js.map +1 -1
  14. package/cjs/components/Notification/NotificationsProvider.css +11 -11
  15. package/cjs/index.css +11 -11
  16. package/emotion/cjs/components/Combobox/ComboboxNew/Combobox.js +5 -1
  17. package/emotion/cjs/components/Notification/Notification.js +3 -7
  18. package/emotion/cjs/components/Notification/Notification.styles.js +26 -32
  19. package/emotion/cjs/components/Notification/Notification.tokens.js +0 -1
  20. package/emotion/cjs/components/Notification/NotificationsPortal.js +1 -2
  21. package/emotion/cjs/examples/plasma_b2c/components/Notification/Notification.config.js +7 -11
  22. package/emotion/cjs/examples/plasma_b2c/components/Notification/Notification.stories.tsx +3 -35
  23. package/emotion/cjs/examples/plasma_web/components/Notification/Notification.config.js +7 -11
  24. package/emotion/cjs/examples/plasma_web/components/Notification/Notification.stories.tsx +2 -18
  25. package/emotion/es/components/Combobox/ComboboxNew/Combobox.js +5 -1
  26. package/emotion/es/components/Notification/Notification.js +3 -7
  27. package/emotion/es/components/Notification/Notification.styles.js +26 -32
  28. package/emotion/es/components/Notification/Notification.tokens.js +0 -1
  29. package/emotion/es/components/Notification/NotificationsPortal.js +1 -2
  30. package/emotion/es/examples/plasma_b2c/components/Notification/Notification.config.js +7 -11
  31. package/emotion/es/examples/plasma_b2c/components/Notification/Notification.stories.tsx +3 -35
  32. package/emotion/es/examples/plasma_web/components/Notification/Notification.config.js +7 -11
  33. package/emotion/es/examples/plasma_web/components/Notification/Notification.stories.tsx +2 -18
  34. package/es/components/Combobox/ComboboxNew/Combobox.js +5 -1
  35. package/es/components/Combobox/ComboboxNew/Combobox.js.map +1 -1
  36. package/es/components/Notification/Notification.css +11 -11
  37. package/es/components/Notification/Notification.js +3 -7
  38. package/es/components/Notification/Notification.js.map +1 -1
  39. package/es/components/Notification/Notification.styles.js +26 -42
  40. package/es/components/Notification/Notification.styles.js.map +1 -1
  41. package/es/components/Notification/{Notification.styles_gk4bgs.css → Notification.styles_1u5gusp.css} +2 -2
  42. package/es/components/Notification/Notification.tokens.js +0 -1
  43. package/es/components/Notification/Notification.tokens.js.map +1 -1
  44. package/es/components/Notification/Notification.types.js.map +1 -1
  45. package/es/components/Notification/NotificationsPortal.js +0 -1
  46. package/es/components/Notification/NotificationsPortal.js.map +1 -1
  47. package/es/components/Notification/NotificationsProvider.css +11 -11
  48. package/es/index.css +11 -11
  49. package/package.json +2 -2
  50. package/styled-components/cjs/components/Combobox/ComboboxNew/Combobox.js +5 -1
  51. package/styled-components/cjs/components/Notification/Notification.js +3 -7
  52. package/styled-components/cjs/components/Notification/Notification.styles.js +15 -21
  53. package/styled-components/cjs/components/Notification/Notification.tokens.js +0 -1
  54. package/styled-components/cjs/components/Notification/NotificationsPortal.js +0 -1
  55. package/styled-components/cjs/examples/plasma_b2c/components/Notification/Notification.config.js +1 -5
  56. package/styled-components/cjs/examples/plasma_b2c/components/Notification/Notification.stories.tsx +3 -35
  57. package/styled-components/cjs/examples/plasma_web/components/Notification/Notification.config.js +1 -5
  58. package/styled-components/cjs/examples/plasma_web/components/Notification/Notification.stories.tsx +2 -18
  59. package/styled-components/es/components/Combobox/ComboboxNew/Combobox.js +5 -1
  60. package/styled-components/es/components/Notification/Notification.js +3 -7
  61. package/styled-components/es/components/Notification/Notification.styles.js +15 -21
  62. package/styled-components/es/components/Notification/Notification.tokens.js +0 -1
  63. package/styled-components/es/components/Notification/NotificationsPortal.js +0 -1
  64. package/styled-components/es/examples/plasma_b2c/components/Notification/Notification.config.js +1 -5
  65. package/styled-components/es/examples/plasma_b2c/components/Notification/Notification.stories.tsx +3 -35
  66. package/styled-components/es/examples/plasma_web/components/Notification/Notification.config.js +1 -5
  67. package/styled-components/es/examples/plasma_web/components/Notification/Notification.stories.tsx +2 -18
  68. package/types/components/Combobox/ComboboxNew/Combobox.d.ts.map +1 -1
  69. package/types/components/Combobox/ComboboxNew/Combobox.types.d.ts +4 -0
  70. package/types/components/Combobox/ComboboxNew/Combobox.types.d.ts.map +1 -1
  71. package/types/components/Notification/Notification.d.ts.map +1 -1
  72. package/types/components/Notification/Notification.styles.d.ts +2 -6
  73. package/types/components/Notification/Notification.styles.d.ts.map +1 -1
  74. package/types/components/Notification/Notification.tokens.d.ts +0 -1
  75. package/types/components/Notification/Notification.tokens.d.ts.map +1 -1
  76. package/types/components/Notification/Notification.types.d.ts +0 -8
  77. package/types/components/Notification/Notification.types.d.ts.map +1 -1
  78. package/types/components/Notification/NotificationsPortal.d.ts.map +1 -1
  79. package/types/examples/plasma_b2c/components/Combobox/Combobox.d.ts +48 -0
  80. package/types/examples/plasma_b2c/components/Combobox/Combobox.d.ts.map +1 -1
  81. package/types/examples/plasma_b2c/components/Notification/Notification.config.d.ts +0 -4
  82. package/types/examples/plasma_b2c/components/Notification/Notification.config.d.ts.map +1 -1
  83. package/types/examples/plasma_web/components/Combobox/Combobox.d.ts +48 -0
  84. package/types/examples/plasma_web/components/Combobox/Combobox.d.ts.map +1 -1
  85. package/types/examples/plasma_web/components/Notification/Notification.config.d.ts +0 -4
  86. package/types/examples/plasma_web/components/Notification/Notification.config.d.ts.map +1 -1
@@ -23,7 +23,6 @@ const texts = ['SSH ключ успешно скопирован', 'Нельзя
23
23
  const size = ['xs', 'xxs'];
24
24
  const iconPlacement = ['top', 'left'];
25
25
  const notificationsPlacements = ['bottom-right', 'bottom-left'];
26
- const views = ['default', 'negative', 'positive', 'warning', 'info'];
27
26
 
28
27
  const longText = `JavaScript frameworks are an essential part of modern front-end web development,
29
28
  providing developers with proven tools for building scalable, interactive web applications.
@@ -65,7 +64,7 @@ const StoryDefault = ({ title, children, iconPlacement, size, layout, showLeftIc
65
64
  return (
66
65
  <Notification
67
66
  title={title}
68
- icon={showLeftIcon ? <IconDisclosureRight color="inherit" /> : ''}
67
+ icon={showLeftIcon ? <IconDisclosureRight /> : ''}
69
68
  iconPlacement={iconPlacement}
70
69
  actions={
71
70
  <Button
@@ -109,18 +108,6 @@ export const Default: StoryObj<StoryDefaultProps> = {
109
108
  type: 'select',
110
109
  },
111
110
  },
112
- view: {
113
- options: views,
114
- control: {
115
- type: 'select',
116
- },
117
- },
118
- textColor: {
119
- control: 'color',
120
- },
121
- iconColor: {
122
- control: 'color',
123
- },
124
111
  },
125
112
  args: {
126
113
  title: 'Title',
@@ -146,10 +133,7 @@ type StoryLiveDemoProps = ComponentProps<typeof Notification> & {
146
133
  const StoryLiveDemo = ({ timeout, placement, ...rest }: StoryLiveDemoProps) => {
147
134
  const count = useRef(0);
148
135
  const handleClick = useCallback(() => {
149
- addNotification(
150
- { icon: <IconDisclosureRight color="inherit" />, ...rest, ...getNotificationProps(count.current) },
151
- timeout,
152
- );
136
+ addNotification({ icon: <IconDisclosureRight />, ...rest, ...getNotificationProps(count.current) }, timeout);
153
137
  count.current++;
154
138
  }, [count, rest]);
155
139
 
@@ -26,7 +26,7 @@ import { getItemId } from './utils/getItemId.js';
26
26
  import { VirtualList } from './ui/VirtualList/VirtualList.js';
27
27
  import { Inner } from './ui/Inner/Inner.js';
28
28
 
29
- var _excluded = ["name", "multiple", "value", "onChange", "defaultValue", "isTargetAmount", "targetAmount", "items", "placement", "label", "placeholder", "helperText", "contentLeft", "textBefore", "textAfter", "variant", "listOverflow", "listHeight", "listWidth", "portal", "renderItem", "view", "size", "labelPlacement", "keepPlaceholder", "readOnly", "disabled", "alwaysOpened", "filter", "closeAfterSelect", "renderValue", "zIndex", "beforeList", "afterList", "virtual", "hintView", "hintSize"];
29
+ var _excluded = ["name", "multiple", "value", "onChange", "defaultValue", "isTargetAmount", "targetAmount", "items", "placement", "label", "placeholder", "helperText", "contentLeft", "textBefore", "textAfter", "variant", "listOverflow", "listHeight", "listWidth", "portal", "renderItem", "view", "size", "labelPlacement", "keepPlaceholder", "readOnly", "disabled", "alwaysOpened", "filter", "closeAfterSelect", "renderValue", "zIndex", "beforeList", "afterList", "virtual", "hintView", "hintSize", "onChangeValue"];
30
30
 
31
31
  /**
32
32
  * Поле ввода с выпадающим списком и возможностью фильтрации и выбора элементов.
@@ -78,6 +78,7 @@ var comboboxRoot = function comboboxRoot(Root) {
78
78
  virtual = _props$virtual === void 0 ? false : _props$virtual,
79
79
  hintView = props.hintView,
80
80
  hintSize = props.hintSize,
81
+ onChangeValue = props.onChangeValue,
81
82
  rest = _objectWithoutProperties(props, _excluded);
82
83
  var transformedItems = useMemo(function () {
83
84
  return initialItemsTransform(items || []);
@@ -203,6 +204,9 @@ var comboboxRoot = function comboboxRoot(Root) {
203
204
  dispatchFocusedPath({
204
205
  type: 'reset'
205
206
  });
207
+ if (onChangeValue) {
208
+ onChangeValue(e.target.value);
209
+ }
206
210
  };
207
211
 
208
212
  // Обработчик чипов
@@ -1 +1 @@
1
- {"version":3,"file":"Combobox.js","sources":["../../../../src/components/Combobox/ComboboxNew/Combobox.tsx"],"sourcesContent":["import React, { forwardRef, useState, useReducer, useMemo, useLayoutEffect, useRef } from 'react';\nimport type { ChangeEvent, ForwardedRef } from 'react';\nimport { safeUseId, useForkRef } from '@salutejs/plasma-core';\n\nimport { RootProps } from '../../../engines';\nimport { isEmpty } from '../../../utils';\nimport { useOutsideClick } from '../../../hooks';\nimport { sizeToIconSize } from '../../Select/utils';\n\nimport { classes } from './Combobox.tokens';\nimport { FloatingPopover } from './FloatingPopover';\nimport { useKeyNavigation, getItemByFocused } from './hooks/useKeyboardNavigation';\nimport {\n initialItemsTransform,\n updateAncestors,\n updateDescendants,\n updateSingleAncestors,\n filterItems,\n getItemId,\n getInitialValue,\n} from './utils';\nimport { Inner, StyledTextField, VirtualList } from './ui';\nimport { pathReducer, focusedPathReducer } from './reducers';\nimport { getPathMap, getTreeMaps } from './hooks/getPathMaps';\nimport { Ul, base, StyledArrow, IconArrowWrapper, StyledEmptyState } from './Combobox.styles';\nimport type { ComboboxProps } from './Combobox.types';\nimport { base as viewCSS } from './variations/_view/base';\nimport { base as sizeCSS } from './variations/_size/base';\nimport type { ItemOptionTransformed } from './ui/Inner/ui/Item/Item.types';\nimport { SelectNative } from './ui/SelectNative/SelectNative';\nimport { Context } from './Combobox.context';\n\n/**\n * Поле ввода с выпадающим списком и возможностью фильтрации и выбора элементов.\n */\n\nexport const comboboxRoot = (Root: RootProps<HTMLInputElement, Omit<ComboboxProps, 'items'>>) =>\n forwardRef<HTMLInputElement, ComboboxProps>((props, ref) => {\n const {\n name,\n multiple,\n value: outerValue,\n onChange: outerOnChange,\n defaultValue,\n isTargetAmount,\n targetAmount,\n items,\n placement = 'bottom-start',\n label,\n placeholder,\n helperText,\n contentLeft,\n textBefore,\n textAfter,\n variant = 'normal',\n listOverflow,\n listHeight,\n listWidth,\n portal,\n renderItem,\n view,\n size,\n labelPlacement,\n keepPlaceholder,\n readOnly = false,\n disabled = false,\n alwaysOpened = false,\n filter,\n closeAfterSelect: outerCloseAfterSelect,\n renderValue,\n zIndex,\n beforeList,\n afterList,\n virtual = false,\n hintView,\n hintSize,\n ...rest\n } = props;\n\n const transformedItems = useMemo(() => initialItemsTransform(items || []), [items]);\n\n // Создаем структуры для быстрой работы с деревом\n const [valueToCheckedMap, valueToItemMap, labelToItemMap] = useMemo(() => getTreeMaps(transformedItems), [\n items,\n ]);\n\n const [textValue, setTextValue] = useState(valueToItemMap.get(outerValue as string)?.label || '');\n const [internalValue, setInternalValue] = useState<string | string[]>(multiple ? [] : '');\n\n const value =\n outerValue !== null && outerValue !== undefined\n ? getInitialValue(outerValue, valueToItemMap)\n : internalValue;\n\n const inputRef = useRef<HTMLInputElement>(null);\n const floatingPopoverRef = useRef<HTMLDivElement>(null);\n const inputForkRef = useForkRef(inputRef, ref);\n const treeId = safeUseId();\n\n const filteredItems = filterItems(\n transformedItems,\n textValue,\n valueToItemMap.get(value as string)?.label as string,\n filter,\n );\n\n const [pathMap, focusedToValueMap] = useMemo(() => getPathMap(filteredItems), [filteredItems, textValue]);\n\n // Состояния дерева элементов\n const [path, dispatchPath] = useReducer(pathReducer, []);\n const [focusedPath, dispatchFocusedPath] = useReducer(focusedPathReducer, []);\n const [checked, setChecked] = useState(valueToCheckedMap);\n\n const isCurrentListOpen = alwaysOpened || Boolean(path[0]);\n const activeDescendantItemValue = getItemByFocused(focusedPath, focusedToValueMap)?.value || '';\n const withArrowInverse = isCurrentListOpen ? classes.arrowInverse : undefined;\n const closeAfterSelect = outerCloseAfterSelect ?? !multiple;\n\n // Логика работы при клике за пределами выпадающего списка\n const targetRef = useOutsideClick<HTMLUListElement>(() => {\n if (!isCurrentListOpen) {\n return;\n }\n\n dispatchPath({ type: 'reset' });\n dispatchFocusedPath({ type: 'reset' });\n\n // Проверяем, отличается ли значение в инпуте от выбранного value после закрытия дропдауна.\n // Если изменилось, то возвращаем label выбранного айтема.\n // Если нет выбранного элемента, то стираем значение инпута.\n if (textValue !== value) {\n if (isEmpty(value)) {\n setTextValue('');\n } else {\n setTextValue(valueToItemMap.get(value as string)?.label || '');\n }\n }\n }, floatingPopoverRef);\n\n // Эта функция срабатывает при изменении Combobox и\n // при изменении нативного Select для формы (срабатывает только после изменения internalValue и рендера).\n const onChange = (newValue: string | Array<string> | ChangeEvent<HTMLSelectElement> | null) => {\n // Условие для отправки изменений наружу\n if (outerOnChange) {\n // Условие для отправки если комбобокс используется без формы.\n if (!name && (typeof newValue === 'string' || Array.isArray(newValue))) {\n outerOnChange(newValue as any);\n }\n\n // Условие для отправки если комбобокс используется с формой.\n if (name && typeof newValue === 'object' && !Array.isArray(newValue)) {\n outerOnChange(newValue as any);\n }\n }\n\n // Условие для изменения внутреннего значения (только если newValue строка или массив строк).\n if (typeof newValue === 'string' || Array.isArray(newValue)) {\n setInternalValue(newValue);\n }\n };\n\n const handleClickArrow = () => {\n if (disabled || readOnly) {\n return;\n }\n\n if (isCurrentListOpen) {\n dispatchPath({ type: 'reset' });\n } else {\n dispatchPath({ type: 'opened_first_level' });\n }\n\n dispatchFocusedPath({ type: 'reset' });\n };\n\n // Обработчик изменения значения в инпуте\n const handleTextValueChange = (e: ChangeEvent<HTMLInputElement>) => {\n setTextValue(e.target.value);\n dispatchPath({ type: 'opened_first_level' });\n dispatchFocusedPath({ type: 'reset' });\n };\n\n // Обработчик чипов\n const handleChipsChange = (chipLabels: any[]) => {\n if (!Array.isArray(value)) return;\n\n // TODO: #1564\n // Из лейблов чипов получаем value у item и далее прокидываем его в onChange.\n if (renderValue && !isTargetAmount) {\n const resultValues = [...value];\n\n value.forEach((_, index) => {\n const labelAfterRenderValue = renderValue(\n labelToItemMap.get(valueToItemMap.get(value[index])!.label)!,\n );\n\n if (!chipLabels.includes(labelAfterRenderValue)) {\n resultValues.splice(index, 1);\n }\n });\n\n onChange(resultValues);\n } else {\n onChange(chipLabels.map((chipLabel) => labelToItemMap.get(chipLabel)!.value));\n }\n };\n\n // Обработчик открытия/закрытия выпадающего списка\n const handleListToggle = (opened: boolean) => {\n if (disabled || readOnly) {\n return;\n }\n\n if (opened) {\n dispatchPath({ type: 'opened_first_level' });\n } else {\n dispatchFocusedPath({ type: 'reset' });\n dispatchPath({ type: 'reset' });\n }\n };\n\n // Обработчик выбора чекбоксов (только при multiple)\n const handleCheckboxChange = (item: ItemOptionTransformed) => {\n if (!multiple) {\n return;\n }\n\n const checkedCopy = new Map(checked);\n\n if (!checkedCopy.get(item.value)) {\n checkedCopy.set(item.value, true);\n updateDescendants(item, checkedCopy, true, valueToItemMap);\n } else {\n checkedCopy.set(item.value, false);\n updateDescendants(item, checkedCopy, false);\n }\n\n updateAncestors(item, checkedCopy);\n\n const newValues: Array<string> = [];\n\n valueToItemMap.forEach((item, key) => {\n if (checkedCopy.get(key)) {\n newValues.push(item.value);\n }\n });\n\n if (!alwaysOpened && closeAfterSelect) {\n dispatchPath({ type: 'reset' });\n dispatchFocusedPath({ type: 'reset' });\n }\n\n if (onChange) {\n onChange(newValues);\n }\n\n // После выбора/снятия чекбокса скроллим к инпуту\n setTimeout(() => {\n if (inputRef.current) {\n inputRef.current.scrollIntoView({\n behavior: 'smooth',\n inline: 'start',\n });\n }\n }, 1);\n };\n\n // Обработчик клика по айтему выпадающего списка\n const handleItemClick = (item: ItemOptionTransformed, e?: React.MouseEvent<HTMLElement>) => {\n if (!isEmpty(item?.items)) {\n return;\n }\n\n if (multiple) {\n handleCheckboxChange(item);\n return;\n }\n\n if (e) {\n e.stopPropagation();\n }\n\n const isCurrentChecked = checked.get(item.value);\n\n if (!alwaysOpened && closeAfterSelect) {\n dispatchPath({ type: 'reset' });\n dispatchFocusedPath({ type: 'reset' });\n }\n\n if (onChange) {\n onChange(isCurrentChecked ? '' : item.value);\n }\n };\n\n const getChips = (): string[] => {\n if (multiple && Array.isArray(value)) {\n if (value.length === 0) return [];\n\n if (isTargetAmount) {\n return [`Выбрано ${targetAmount || value.length}`];\n }\n\n const renderValueMapper =\n renderValue && ((stringValue: string) => renderValue(valueToItemMap.get(stringValue)!));\n const valueToItemMapper = (stringValue: string) => valueToItemMap.get(stringValue)!.label;\n\n return value.map(renderValueMapper || valueToItemMapper);\n }\n\n return [];\n };\n\n const handlePressDown = (item: ItemOptionTransformed, e?: React.MouseEvent<HTMLElement>) => {\n if (isEmpty(item.items)) {\n handleItemClick(item, e);\n } else if (multiple) {\n handleCheckboxChange(item);\n }\n };\n\n const { onKeyDown } = useKeyNavigation({\n focusedPath,\n dispatchFocusedPath,\n path,\n dispatchPath,\n pathMap,\n focusedToValueMap,\n handleListToggle,\n handlePressDown,\n setTextValue,\n multiple,\n value,\n textValue,\n valueToItemMap,\n });\n\n // В данном эффекте мы следим за изменениями value снаружи и вносим коррективы в дерево чекбоксов.\n // Пример: когда юзер очистил value извне, тогда нужно пройтись по элементам и выключить все чекбоксы.\n useLayoutEffect(() => {\n const checkedCopy = new Map(checked);\n\n checkedCopy.forEach((_, key) => {\n checkedCopy.set(key, false);\n });\n\n if (!isEmpty(value)) {\n if (Array.isArray(value)) {\n value.forEach((val) => {\n checkedCopy.set(val, true);\n updateDescendants(valueToItemMap.get(val)!, checkedCopy, true);\n updateAncestors(valueToItemMap.get(val)!, checkedCopy);\n });\n } else {\n checkedCopy.set(value, 'done');\n updateSingleAncestors(valueToItemMap.get(value)!, checkedCopy, 'dot');\n }\n }\n\n setChecked(checkedCopy);\n\n setTextValue(valueToItemMap.get(value as string)?.label || '');\n\n // В deps мы кладем именно outerValue и internalValue, а не просто value.\n // Т.к. вначале нужно отфильтровать и провалидировать outerValue и результат положить в переменную.\n // А переменную, содержащую сложные типы данных, нельзя помещать в deps.\n }, [outerValue, internalValue, items]);\n\n useLayoutEffect(() => {\n if (defaultValue) {\n setInternalValue(defaultValue);\n }\n }, [defaultValue]);\n\n return (\n <Root\n size={size}\n view={view}\n labelPlacement={labelPlacement}\n disabled={disabled}\n readOnly={readOnly}\n name={name}\n hintView={hintView}\n hintSize={hintSize}\n >\n {name && (\n <SelectNative\n items={valueToItemMap}\n name={name}\n value={internalValue}\n multiple={multiple}\n onChange={onChange}\n onSetValue={setInternalValue}\n ref={ref as ForwardedRef<HTMLInputElement>}\n />\n )}\n <div>\n <Context.Provider\n value={{\n focusedPath,\n checked,\n multiple,\n size,\n handleCheckboxChange,\n handleItemClick,\n variant,\n renderItem,\n treeId,\n }}\n >\n <FloatingPopover\n ref={floatingPopoverRef}\n opened={isCurrentListOpen}\n onToggle={(opened: boolean) => opened && handleListToggle(true)}\n placement={placement}\n portal={portal}\n listWidth={listWidth}\n target={(referenceRef) => (\n <StyledTextField\n ref={name ? inputRef : (inputForkRef as ForwardedRef<HTMLInputElement>)}\n inputWrapperRef={referenceRef}\n value={textValue}\n onChange={handleTextValueChange}\n size={size}\n view={view}\n disabled={disabled}\n readOnly={readOnly}\n label={label}\n placeholder={placeholder}\n contentLeft={contentLeft}\n contentRight={\n <IconArrowWrapper disabled={disabled} onClick={handleClickArrow}>\n <StyledArrow\n color=\"inherit\"\n size={sizeToIconSize(size)}\n className={withArrowInverse}\n />\n </IconArrowWrapper>\n }\n textBefore={textBefore}\n textAfter={textAfter}\n onKeyDown={onKeyDown}\n leftHelper={helperText}\n role=\"combobox\"\n aria-autocomplete=\"list\"\n aria-controls={`${treeId}_tree_level_1`}\n aria-expanded={isCurrentListOpen}\n aria-activedescendant={\n activeDescendantItemValue ? getItemId(treeId, activeDescendantItemValue) : ''\n }\n labelPlacement={labelPlacement}\n keepPlaceholder={keepPlaceholder}\n {...(multiple\n ? {\n enumerationType: 'chip',\n chips: getChips(),\n onChangeChips: handleChipsChange,\n }\n : { enumerationType: 'plain' })}\n {...rest}\n onEnterDisabled // Пропс для отключения обработчика Enter внутри Textfield\n />\n )}\n zIndex={zIndex}\n >\n <Root\n size={size}\n view={view}\n labelPlacement={labelPlacement}\n disabled={disabled}\n readOnly={readOnly}\n name={name}\n >\n <Ul\n role=\"tree\"\n id={`${treeId}_tree_level_1`}\n aria-multiselectable={Boolean(multiple)}\n listHeight={listHeight}\n listOverflow={listOverflow}\n listWidth={listWidth}\n ref={targetRef}\n >\n {virtual ? (\n <VirtualList items={filteredItems} listHeight={listHeight} />\n ) : (\n <>\n {beforeList}\n {isEmpty(filteredItems) ? (\n <StyledEmptyState\n className={classes.emptyStateWrapper}\n size={size}\n description=\"Ничего не найдено\"\n />\n ) : (\n filteredItems.map((item, index) => (\n <Inner\n key={`${index}/0`}\n item={item}\n currentLevel={0}\n path={path}\n dispatchPath={dispatchPath}\n index={index}\n listWidth={listWidth}\n />\n ))\n )}\n {afterList}\n </>\n )}\n </Ul>\n </Root>\n </FloatingPopover>\n </Context.Provider>\n </div>\n </Root>\n );\n });\n\nexport const comboboxConfig = {\n name: 'Select',\n tag: 'div',\n layout: comboboxRoot,\n base,\n variations: {\n view: {\n css: viewCSS,\n },\n size: {\n css: sizeCSS,\n },\n readOnly: {\n css: sizeCSS,\n },\n },\n defaults: {\n view: 'default',\n size: 'm',\n labelPlacement: 'outer',\n },\n};\n"],"names":["comboboxRoot","Root","forwardRef","props","ref","_valueToItemMap$get","_valueToItemMap$get2","_getItemByFocused","name","multiple","outerValue","value","outerOnChange","onChange","defaultValue","isTargetAmount","targetAmount","items","_props$placement","placement","label","placeholder","helperText","contentLeft","textBefore","textAfter","_props$variant","variant","listOverflow","listHeight","listWidth","portal","renderItem","view","size","labelPlacement","keepPlaceholder","_props$readOnly","readOnly","_props$disabled","disabled","_props$alwaysOpened","alwaysOpened","filter","outerCloseAfterSelect","closeAfterSelect","renderValue","zIndex","beforeList","afterList","_props$virtual","virtual","hintView","hintSize","rest","_objectWithoutProperties","_excluded","transformedItems","useMemo","initialItemsTransform","_useMemo","getTreeMaps","_useMemo2","_slicedToArray","valueToCheckedMap","valueToItemMap","labelToItemMap","_useState","useState","get","_useState2","textValue","setTextValue","_useState3","_useState4","internalValue","setInternalValue","undefined","getInitialValue","inputRef","useRef","floatingPopoverRef","inputForkRef","useForkRef","treeId","safeUseId","filteredItems","filterItems","_useMemo3","getPathMap","_useMemo4","pathMap","focusedToValueMap","_useReducer","useReducer","pathReducer","_useReducer2","path","dispatchPath","_useReducer3","focusedPathReducer","_useReducer4","focusedPath","dispatchFocusedPath","_useState5","_useState6","checked","setChecked","isCurrentListOpen","Boolean","activeDescendantItemValue","getItemByFocused","withArrowInverse","classes","arrowInverse","targetRef","useOutsideClick","type","isEmpty","_valueToItemMap$get3","newValue","Array","isArray","_typeof","handleClickArrow","handleTextValueChange","e","target","handleChipsChange","chipLabels","resultValues","_toConsumableArray","forEach","_","index","labelAfterRenderValue","includes","splice","map","chipLabel","handleListToggle","opened","handleCheckboxChange","item","checkedCopy","Map","set","updateDescendants","updateAncestors","newValues","key","push","setTimeout","current","scrollIntoView","behavior","inline","handleItemClick","stopPropagation","isCurrentChecked","getChips","length","concat","renderValueMapper","stringValue","valueToItemMapper","handlePressDown","_useKeyNavigation","useKeyNavigation","onKeyDown","useLayoutEffect","_valueToItemMap$get4","val","updateSingleAncestors","React","createElement","SelectNative","onSetValue","Context","Provider","FloatingPopover","onToggle","referenceRef","StyledTextField","_extends","inputWrapperRef","contentRight","IconArrowWrapper","onClick","StyledArrow","color","sizeToIconSize","className","leftHelper","role","getItemId","enumerationType","chips","onChangeChips","onEnterDisabled","Ul","id","VirtualList","Fragment","StyledEmptyState","emptyStateWrapper","description","Inner","currentLevel","comboboxConfig","tag","layout","base","variations","css","viewCSS","sizeCSS","defaults"],"mappings":"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"}
1
+ {"version":3,"file":"Combobox.js","sources":["../../../../src/components/Combobox/ComboboxNew/Combobox.tsx"],"sourcesContent":["import React, { forwardRef, useState, useReducer, useMemo, useLayoutEffect, useRef } from 'react';\nimport type { ChangeEvent, ForwardedRef } from 'react';\nimport { safeUseId, useForkRef } from '@salutejs/plasma-core';\n\nimport { RootProps } from '../../../engines';\nimport { isEmpty } from '../../../utils';\nimport { useOutsideClick } from '../../../hooks';\nimport { sizeToIconSize } from '../../Select/utils';\n\nimport { classes } from './Combobox.tokens';\nimport { FloatingPopover } from './FloatingPopover';\nimport { useKeyNavigation, getItemByFocused } from './hooks/useKeyboardNavigation';\nimport {\n initialItemsTransform,\n updateAncestors,\n updateDescendants,\n updateSingleAncestors,\n filterItems,\n getItemId,\n getInitialValue,\n} from './utils';\nimport { Inner, StyledTextField, VirtualList } from './ui';\nimport { pathReducer, focusedPathReducer } from './reducers';\nimport { getPathMap, getTreeMaps } from './hooks/getPathMaps';\nimport { Ul, base, StyledArrow, IconArrowWrapper, StyledEmptyState } from './Combobox.styles';\nimport type { ComboboxProps } from './Combobox.types';\nimport { base as viewCSS } from './variations/_view/base';\nimport { base as sizeCSS } from './variations/_size/base';\nimport type { ItemOptionTransformed } from './ui/Inner/ui/Item/Item.types';\nimport { SelectNative } from './ui/SelectNative/SelectNative';\nimport { Context } from './Combobox.context';\n\n/**\n * Поле ввода с выпадающим списком и возможностью фильтрации и выбора элементов.\n */\n\nexport const comboboxRoot = (Root: RootProps<HTMLInputElement, Omit<ComboboxProps, 'items'>>) =>\n forwardRef<HTMLInputElement, ComboboxProps>((props, ref) => {\n const {\n name,\n multiple,\n value: outerValue,\n onChange: outerOnChange,\n defaultValue,\n isTargetAmount,\n targetAmount,\n items,\n placement = 'bottom-start',\n label,\n placeholder,\n helperText,\n contentLeft,\n textBefore,\n textAfter,\n variant = 'normal',\n listOverflow,\n listHeight,\n listWidth,\n portal,\n renderItem,\n view,\n size,\n labelPlacement,\n keepPlaceholder,\n readOnly = false,\n disabled = false,\n alwaysOpened = false,\n filter,\n closeAfterSelect: outerCloseAfterSelect,\n renderValue,\n zIndex,\n beforeList,\n afterList,\n virtual = false,\n hintView,\n hintSize,\n onChangeValue,\n ...rest\n } = props;\n\n const transformedItems = useMemo(() => initialItemsTransform(items || []), [items]);\n\n // Создаем структуры для быстрой работы с деревом\n const [valueToCheckedMap, valueToItemMap, labelToItemMap] = useMemo(() => getTreeMaps(transformedItems), [\n items,\n ]);\n\n const [textValue, setTextValue] = useState(valueToItemMap.get(outerValue as string)?.label || '');\n const [internalValue, setInternalValue] = useState<string | string[]>(multiple ? [] : '');\n\n const value =\n outerValue !== null && outerValue !== undefined\n ? getInitialValue(outerValue, valueToItemMap)\n : internalValue;\n\n const inputRef = useRef<HTMLInputElement>(null);\n const floatingPopoverRef = useRef<HTMLDivElement>(null);\n const inputForkRef = useForkRef(inputRef, ref);\n const treeId = safeUseId();\n\n const filteredItems = filterItems(\n transformedItems,\n textValue,\n valueToItemMap.get(value as string)?.label as string,\n filter,\n );\n\n const [pathMap, focusedToValueMap] = useMemo(() => getPathMap(filteredItems), [filteredItems, textValue]);\n\n // Состояния дерева элементов\n const [path, dispatchPath] = useReducer(pathReducer, []);\n const [focusedPath, dispatchFocusedPath] = useReducer(focusedPathReducer, []);\n const [checked, setChecked] = useState(valueToCheckedMap);\n\n const isCurrentListOpen = alwaysOpened || Boolean(path[0]);\n const activeDescendantItemValue = getItemByFocused(focusedPath, focusedToValueMap)?.value || '';\n const withArrowInverse = isCurrentListOpen ? classes.arrowInverse : undefined;\n const closeAfterSelect = outerCloseAfterSelect ?? !multiple;\n\n // Логика работы при клике за пределами выпадающего списка\n const targetRef = useOutsideClick<HTMLUListElement>(() => {\n if (!isCurrentListOpen) {\n return;\n }\n\n dispatchPath({ type: 'reset' });\n dispatchFocusedPath({ type: 'reset' });\n\n // Проверяем, отличается ли значение в инпуте от выбранного value после закрытия дропдауна.\n // Если изменилось, то возвращаем label выбранного айтема.\n // Если нет выбранного элемента, то стираем значение инпута.\n if (textValue !== value) {\n if (isEmpty(value)) {\n setTextValue('');\n } else {\n setTextValue(valueToItemMap.get(value as string)?.label || '');\n }\n }\n }, floatingPopoverRef);\n\n // Эта функция срабатывает при изменении Combobox и\n // при изменении нативного Select для формы (срабатывает только после изменения internalValue и рендера).\n const onChange = (newValue: string | Array<string> | ChangeEvent<HTMLSelectElement> | null) => {\n // Условие для отправки изменений наружу\n if (outerOnChange) {\n // Условие для отправки если комбобокс используется без формы.\n if (!name && (typeof newValue === 'string' || Array.isArray(newValue))) {\n outerOnChange(newValue as any);\n }\n\n // Условие для отправки если комбобокс используется с формой.\n if (name && typeof newValue === 'object' && !Array.isArray(newValue)) {\n outerOnChange(newValue as any);\n }\n }\n\n // Условие для изменения внутреннего значения (только если newValue строка или массив строк).\n if (typeof newValue === 'string' || Array.isArray(newValue)) {\n setInternalValue(newValue);\n }\n };\n\n const handleClickArrow = () => {\n if (disabled || readOnly) {\n return;\n }\n\n if (isCurrentListOpen) {\n dispatchPath({ type: 'reset' });\n } else {\n dispatchPath({ type: 'opened_first_level' });\n }\n\n dispatchFocusedPath({ type: 'reset' });\n };\n\n // Обработчик изменения значения в инпуте\n const handleTextValueChange = (e: ChangeEvent<HTMLInputElement>) => {\n setTextValue(e.target.value);\n dispatchPath({ type: 'opened_first_level' });\n dispatchFocusedPath({ type: 'reset' });\n\n if (onChangeValue) {\n onChangeValue(e.target.value);\n }\n };\n\n // Обработчик чипов\n const handleChipsChange = (chipLabels: any[]) => {\n if (!Array.isArray(value)) return;\n\n // TODO: #1564\n // Из лейблов чипов получаем value у item и далее прокидываем его в onChange.\n if (renderValue && !isTargetAmount) {\n const resultValues = [...value];\n\n value.forEach((_, index) => {\n const labelAfterRenderValue = renderValue(\n labelToItemMap.get(valueToItemMap.get(value[index])!.label)!,\n );\n\n if (!chipLabels.includes(labelAfterRenderValue)) {\n resultValues.splice(index, 1);\n }\n });\n\n onChange(resultValues);\n } else {\n onChange(chipLabels.map((chipLabel) => labelToItemMap.get(chipLabel)!.value));\n }\n };\n\n // Обработчик открытия/закрытия выпадающего списка\n const handleListToggle = (opened: boolean) => {\n if (disabled || readOnly) {\n return;\n }\n\n if (opened) {\n dispatchPath({ type: 'opened_first_level' });\n } else {\n dispatchFocusedPath({ type: 'reset' });\n dispatchPath({ type: 'reset' });\n }\n };\n\n // Обработчик выбора чекбоксов (только при multiple)\n const handleCheckboxChange = (item: ItemOptionTransformed) => {\n if (!multiple) {\n return;\n }\n\n const checkedCopy = new Map(checked);\n\n if (!checkedCopy.get(item.value)) {\n checkedCopy.set(item.value, true);\n updateDescendants(item, checkedCopy, true, valueToItemMap);\n } else {\n checkedCopy.set(item.value, false);\n updateDescendants(item, checkedCopy, false);\n }\n\n updateAncestors(item, checkedCopy);\n\n const newValues: Array<string> = [];\n\n valueToItemMap.forEach((item, key) => {\n if (checkedCopy.get(key)) {\n newValues.push(item.value);\n }\n });\n\n if (!alwaysOpened && closeAfterSelect) {\n dispatchPath({ type: 'reset' });\n dispatchFocusedPath({ type: 'reset' });\n }\n\n if (onChange) {\n onChange(newValues);\n }\n\n // После выбора/снятия чекбокса скроллим к инпуту\n setTimeout(() => {\n if (inputRef.current) {\n inputRef.current.scrollIntoView({\n behavior: 'smooth',\n inline: 'start',\n });\n }\n }, 1);\n };\n\n // Обработчик клика по айтему выпадающего списка\n const handleItemClick = (item: ItemOptionTransformed, e?: React.MouseEvent<HTMLElement>) => {\n if (!isEmpty(item?.items)) {\n return;\n }\n\n if (multiple) {\n handleCheckboxChange(item);\n return;\n }\n\n if (e) {\n e.stopPropagation();\n }\n\n const isCurrentChecked = checked.get(item.value);\n\n if (!alwaysOpened && closeAfterSelect) {\n dispatchPath({ type: 'reset' });\n dispatchFocusedPath({ type: 'reset' });\n }\n\n if (onChange) {\n onChange(isCurrentChecked ? '' : item.value);\n }\n };\n\n const getChips = (): string[] => {\n if (multiple && Array.isArray(value)) {\n if (value.length === 0) return [];\n\n if (isTargetAmount) {\n return [`Выбрано ${targetAmount || value.length}`];\n }\n\n const renderValueMapper =\n renderValue && ((stringValue: string) => renderValue(valueToItemMap.get(stringValue)!));\n const valueToItemMapper = (stringValue: string) => valueToItemMap.get(stringValue)!.label;\n\n return value.map(renderValueMapper || valueToItemMapper);\n }\n\n return [];\n };\n\n const handlePressDown = (item: ItemOptionTransformed, e?: React.MouseEvent<HTMLElement>) => {\n if (isEmpty(item.items)) {\n handleItemClick(item, e);\n } else if (multiple) {\n handleCheckboxChange(item);\n }\n };\n\n const { onKeyDown } = useKeyNavigation({\n focusedPath,\n dispatchFocusedPath,\n path,\n dispatchPath,\n pathMap,\n focusedToValueMap,\n handleListToggle,\n handlePressDown,\n setTextValue,\n multiple,\n value,\n textValue,\n valueToItemMap,\n });\n\n // В данном эффекте мы следим за изменениями value снаружи и вносим коррективы в дерево чекбоксов.\n // Пример: когда юзер очистил value извне, тогда нужно пройтись по элементам и выключить все чекбоксы.\n useLayoutEffect(() => {\n const checkedCopy = new Map(checked);\n\n checkedCopy.forEach((_, key) => {\n checkedCopy.set(key, false);\n });\n\n if (!isEmpty(value)) {\n if (Array.isArray(value)) {\n value.forEach((val) => {\n checkedCopy.set(val, true);\n updateDescendants(valueToItemMap.get(val)!, checkedCopy, true);\n updateAncestors(valueToItemMap.get(val)!, checkedCopy);\n });\n } else {\n checkedCopy.set(value, 'done');\n updateSingleAncestors(valueToItemMap.get(value)!, checkedCopy, 'dot');\n }\n }\n\n setChecked(checkedCopy);\n\n setTextValue(valueToItemMap.get(value as string)?.label || '');\n\n // В deps мы кладем именно outerValue и internalValue, а не просто value.\n // Т.к. вначале нужно отфильтровать и провалидировать outerValue и результат положить в переменную.\n // А переменную, содержащую сложные типы данных, нельзя помещать в deps.\n }, [outerValue, internalValue, items]);\n\n useLayoutEffect(() => {\n if (defaultValue) {\n setInternalValue(defaultValue);\n }\n }, [defaultValue]);\n\n return (\n <Root\n size={size}\n view={view}\n labelPlacement={labelPlacement}\n disabled={disabled}\n readOnly={readOnly}\n name={name}\n hintView={hintView}\n hintSize={hintSize}\n >\n {name && (\n <SelectNative\n items={valueToItemMap}\n name={name}\n value={internalValue}\n multiple={multiple}\n onChange={onChange}\n onSetValue={setInternalValue}\n ref={ref as ForwardedRef<HTMLInputElement>}\n />\n )}\n <div>\n <Context.Provider\n value={{\n focusedPath,\n checked,\n multiple,\n size,\n handleCheckboxChange,\n handleItemClick,\n variant,\n renderItem,\n treeId,\n }}\n >\n <FloatingPopover\n ref={floatingPopoverRef}\n opened={isCurrentListOpen}\n onToggle={(opened: boolean) => opened && handleListToggle(true)}\n placement={placement}\n portal={portal}\n listWidth={listWidth}\n target={(referenceRef) => (\n <StyledTextField\n ref={name ? inputRef : (inputForkRef as ForwardedRef<HTMLInputElement>)}\n inputWrapperRef={referenceRef}\n value={textValue}\n onChange={handleTextValueChange}\n size={size}\n view={view}\n disabled={disabled}\n readOnly={readOnly}\n label={label}\n placeholder={placeholder}\n contentLeft={contentLeft}\n contentRight={\n <IconArrowWrapper disabled={disabled} onClick={handleClickArrow}>\n <StyledArrow\n color=\"inherit\"\n size={sizeToIconSize(size)}\n className={withArrowInverse}\n />\n </IconArrowWrapper>\n }\n textBefore={textBefore}\n textAfter={textAfter}\n onKeyDown={onKeyDown}\n leftHelper={helperText}\n role=\"combobox\"\n aria-autocomplete=\"list\"\n aria-controls={`${treeId}_tree_level_1`}\n aria-expanded={isCurrentListOpen}\n aria-activedescendant={\n activeDescendantItemValue ? getItemId(treeId, activeDescendantItemValue) : ''\n }\n labelPlacement={labelPlacement}\n keepPlaceholder={keepPlaceholder}\n {...(multiple\n ? {\n enumerationType: 'chip',\n chips: getChips(),\n onChangeChips: handleChipsChange,\n }\n : { enumerationType: 'plain' })}\n {...rest}\n onEnterDisabled // Пропс для отключения обработчика Enter внутри Textfield\n />\n )}\n zIndex={zIndex}\n >\n <Root\n size={size}\n view={view}\n labelPlacement={labelPlacement}\n disabled={disabled}\n readOnly={readOnly}\n name={name}\n >\n <Ul\n role=\"tree\"\n id={`${treeId}_tree_level_1`}\n aria-multiselectable={Boolean(multiple)}\n listHeight={listHeight}\n listOverflow={listOverflow}\n listWidth={listWidth}\n ref={targetRef}\n >\n {virtual ? (\n <VirtualList items={filteredItems} listHeight={listHeight} />\n ) : (\n <>\n {beforeList}\n {isEmpty(filteredItems) ? (\n <StyledEmptyState\n className={classes.emptyStateWrapper}\n size={size}\n description=\"Ничего не найдено\"\n />\n ) : (\n filteredItems.map((item, index) => (\n <Inner\n key={`${index}/0`}\n item={item}\n currentLevel={0}\n path={path}\n dispatchPath={dispatchPath}\n index={index}\n listWidth={listWidth}\n />\n ))\n )}\n {afterList}\n </>\n )}\n </Ul>\n </Root>\n </FloatingPopover>\n </Context.Provider>\n </div>\n </Root>\n );\n });\n\nexport const comboboxConfig = {\n name: 'Select',\n tag: 'div',\n layout: comboboxRoot,\n base,\n variations: {\n view: {\n css: viewCSS,\n },\n size: {\n css: sizeCSS,\n },\n readOnly: {\n css: sizeCSS,\n },\n },\n defaults: {\n view: 'default',\n size: 'm',\n labelPlacement: 'outer',\n },\n};\n"],"names":["comboboxRoot","Root","forwardRef","props","ref","_valueToItemMap$get","_valueToItemMap$get2","_getItemByFocused","name","multiple","outerValue","value","outerOnChange","onChange","defaultValue","isTargetAmount","targetAmount","items","_props$placement","placement","label","placeholder","helperText","contentLeft","textBefore","textAfter","_props$variant","variant","listOverflow","listHeight","listWidth","portal","renderItem","view","size","labelPlacement","keepPlaceholder","_props$readOnly","readOnly","_props$disabled","disabled","_props$alwaysOpened","alwaysOpened","filter","outerCloseAfterSelect","closeAfterSelect","renderValue","zIndex","beforeList","afterList","_props$virtual","virtual","hintView","hintSize","onChangeValue","rest","_objectWithoutProperties","_excluded","transformedItems","useMemo","initialItemsTransform","_useMemo","getTreeMaps","_useMemo2","_slicedToArray","valueToCheckedMap","valueToItemMap","labelToItemMap","_useState","useState","get","_useState2","textValue","setTextValue","_useState3","_useState4","internalValue","setInternalValue","undefined","getInitialValue","inputRef","useRef","floatingPopoverRef","inputForkRef","useForkRef","treeId","safeUseId","filteredItems","filterItems","_useMemo3","getPathMap","_useMemo4","pathMap","focusedToValueMap","_useReducer","useReducer","pathReducer","_useReducer2","path","dispatchPath","_useReducer3","focusedPathReducer","_useReducer4","focusedPath","dispatchFocusedPath","_useState5","_useState6","checked","setChecked","isCurrentListOpen","Boolean","activeDescendantItemValue","getItemByFocused","withArrowInverse","classes","arrowInverse","targetRef","useOutsideClick","type","isEmpty","_valueToItemMap$get3","newValue","Array","isArray","_typeof","handleClickArrow","handleTextValueChange","e","target","handleChipsChange","chipLabels","resultValues","_toConsumableArray","forEach","_","index","labelAfterRenderValue","includes","splice","map","chipLabel","handleListToggle","opened","handleCheckboxChange","item","checkedCopy","Map","set","updateDescendants","updateAncestors","newValues","key","push","setTimeout","current","scrollIntoView","behavior","inline","handleItemClick","stopPropagation","isCurrentChecked","getChips","length","concat","renderValueMapper","stringValue","valueToItemMapper","handlePressDown","_useKeyNavigation","useKeyNavigation","onKeyDown","useLayoutEffect","_valueToItemMap$get4","val","updateSingleAncestors","React","createElement","SelectNative","onSetValue","Context","Provider","FloatingPopover","onToggle","referenceRef","StyledTextField","_extends","inputWrapperRef","contentRight","IconArrowWrapper","onClick","StyledArrow","color","sizeToIconSize","className","leftHelper","role","getItemId","enumerationType","chips","onChangeChips","onEnterDisabled","Ul","id","VirtualList","Fragment","StyledEmptyState","emptyStateWrapper","description","Inner","currentLevel","comboboxConfig","tag","layout","base","variations","css","viewCSS","sizeCSS","defaults"],"mappings":"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"}
@@ -30,14 +30,14 @@
30
30
  .Button_styles_8cvmld_s1rjh7ra__4694a0fa{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-align-self:var(--plasma-button-right-content-align-self);-ms-flex-item-align:var(--plasma-button-right-content-align);align-self:var(--plasma-button-right-content-align-self);margin:var(--s1rjh7ra-0);}
31
31
  .Button_styles_8cvmld_b9ga1dj__4694a0fa{position:relative;display:-webkit-inline-box;display:-webkit-inline-flex;display:-ms-inline-flexbox;display:inline-flex;-webkit-align-items:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center;box-sizing:border-box;-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;cursor:pointer;-webkit-tap-highlight-color:rgba(0,0,0,0);--plasma_private-btn-br:var(--plasma_computed-btn-br);border-radius:var(--plasma_private-btn-br);}a.Button_styles_8cvmld_b9ga1dj__4694a0fa{-webkit-text-decoration:none;text-decoration:none;}.Button_styles_8cvmld_b9ga1dj__4694a0fa.Button_styles_8cvmld_b9ga1dj__4694a0fa.Button_styles_8cvmld_buttonSquare__4694a0fa{width:var(--plasma-button-height);padding:0;}
32
32
 
33
- .Notification_styles_gk4bgs_sb12p__85070c43{width:-webkit-fit-content;width:-moz-fit-content;width:fit-content;}
34
- .Notification_styles_gk4bgs_crvd7hm__85070c43{position:absolute;width:var(--plasma-notification-close-icon-button-size);height:var(--plasma-notification-close-icon-button-size);-webkit-align-self:var(--plasma-notification-horizontal-icon-close-align-self);-ms-flex-item-align:var(--plasma-notification-horizontal-icon-close-align);align-self:var(--plasma-notification-horizontal-icon-close-align-self);color:var(--plasma-notification-close-icon-color);}.Notification_styles_gk4bgs_crvd7hm__85070c43:hover{color:var(--plasma-notification-close-icon-color-on-hover);}.Notification_styles_gk4bgs_crvd7hm__85070c43.Notification_styles_gk4bgs_notificationLayoutHorizontal__85070c43{position:relative;}
35
- .Notification_styles_gk4bgs_wg1ga5v__85070c43{position:relative;box-sizing:border-box;background:var(--plasma-notification-backgorund);border-radius:var(--plasma-notification-border-radius);border:var(--plasma-notification-border-width) solid var(--plasma-notification-border-color);}.Notification_styles_gk4bgs_wg1ga5v__85070c43.Notification_styles_gk4bgs_notificationLayoutHorizontal__85070c43{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-align-items:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center;gap:var(--plasma-notification-horizontal-layout-gap);}
36
- .Notification_styles_gk4bgs_b1amsn8a__85070c43{margin-top:var(--plasma-notification-buttons-margin-top);margin-left:var(--b1amsn8a-0);-webkit-align-self:var(--plasma-notification-horizontal-actions-align-self);-ms-flex-item-align:var(--plasma-notification-horizontal-actions-align);align-self:var(--plasma-notification-horizontal-actions-align-self);}.Notification_styles_gk4bgs_b1amsn8a__85070c43.Notification_styles_gk4bgs_notificationLayoutHorizontal__85070c43{margin-top:unset;margin-left:unset;}
37
- .Notification_styles_gk4bgs_i14raqr9__85070c43{width:var(--plasma-notification-content-left-icon-size);height:var(--plasma-notification-content-left-icon-size);-webkit-align-self:var(--plasma-notification-horizontal-icon-left-align-self);-ms-flex-item-align:var(--plasma-notification-horizontal-icon-left-align);align-self:var(--plasma-notification-horizontal-icon-left-align-self);color:var(--i14raqr9-0);margin-right:var(--i14raqr9-1);margin-bottom:var(--i14raqr9-2);}.Notification_styles_gk4bgs_i14raqr9__85070c43.Notification_styles_gk4bgs_notificationLayoutHorizontal__85070c43{margin-right:var(--plasma-notification-horizontal-layout-left-icon-margin);margin-bottom:unset;}
38
- .Notification_styles_gk4bgs_c157peez__85070c43{display:var(--c157peez-0);padding-top:var(--c157peez-1);}.Notification_styles_gk4bgs_c157peez__85070c43.Notification_styles_gk4bgs_notificationLayoutHorizontal__85070c43{padding:unset;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-align-items:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-flex:1;-webkit-flex-grow:1;-ms-flex-positive:1;flex-grow:1;}
39
- .Notification_styles_gk4bgs_t1vmb0f2__85070c43{padding:var(--plasma-notification-textbox-padding-top) var(--plasma-notification-textbox-padding-right) var(--plasma-notification-textbox-padding-bottom) var(--plasma-notification-textbox-padding-left);padding-top:var(--t1vmb0f2-0);padding-right:var(--t1vmb0f2-1);display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column;row-gap:var(--plasma-notification-textbox-gap);word-break:break-word;}.Notification_styles_gk4bgs_t1vmb0f2__85070c43.Notification_styles_gk4bgs_notificationLayoutHorizontal__85070c43{padding:unset;}
40
- .Notification_styles_gk4bgs_s1k4e58v__85070c43{font-family:var(--plasma-notification-title-font-family);font-size:var(--plasma-notification-title-font-size);font-style:var(--plasma-notification-title-font-style);font-weight:var(--plasma-notification-title-font-weight);-webkit-letter-spacing:var(--plasma-notification-title-font-letter-spacing);-moz-letter-spacing:var(--plasma-notification-title-font-letter-spacing);-ms-letter-spacing:var(--plasma-notification-title-font-letter-spacing);letter-spacing:var(--plasma-notification-title-font-letter-spacing);line-height:var(--plasma-notification-title-font-line-height);overflow-wrap:break-word;-webkit-hyphens:auto;-moz-hyphens:auto;-ms-hyphens:auto;hyphens:auto;color:var(--s1k4e58v-0);}
41
- .Notification_styles_gk4bgs_s92kmpm__85070c43{font-family:var(--plasma-notification-content-font-family);font-size:var(--plasma-notification-content-font-size);font-style:var(--plasma-notification-content-font-style);font-weight:var(--plasma-notification-content-font-weight);-webkit-letter-spacing:var(--plasma-notification-content-font-letter-spacing);-moz-letter-spacing:var(--plasma-notification-content-font-letter-spacing);-ms-letter-spacing:var(--plasma-notification-content-font-letter-spacing);letter-spacing:var(--plasma-notification-content-font-letter-spacing);line-height:var(--plasma-notification-content-font-line-height);overflow-wrap:break-word;-webkit-hyphens:auto;-moz-hyphens:auto;-ms-hyphens:auto;hyphens:auto;color:var(--plasma-notification-content-color);}
42
- .Notification_styles_gk4bgs_s18m0x6v__85070c43{margin-top:1rem;opacity:1;}.Notification_styles_gk4bgs_s18m0x6v__85070c43.Notification_styles_gk4bgs_s18m0x6v__85070c43.Notification_styles_gk4bgs_notificationItemOpened__85070c43{-webkit-animation:0.4s Notification_styles_gk4bgs_showAnimationS18m0x6v__85070c43 ease-out;animation:0.4s Notification_styles_gk4bgs_showAnimationS18m0x6v__85070c43 ease-out;}.Notification_styles_gk4bgs_s18m0x6v__85070c43.Notification_styles_gk4bgs_s18m0x6v__85070c43.Notification_styles_gk4bgs_notificationItemOpened__85070c43.Notification_styles_gk4bgs_notificationLeftToRightAnimation__85070c43{-webkit-animation:0.4s Notification_styles_gk4bgs_showLeftToRightAnimationS18m0x6v__85070c43 ease-out;animation:0.4s Notification_styles_gk4bgs_showLeftToRightAnimationS18m0x6v__85070c43 ease-out;}.Notification_styles_gk4bgs_s18m0x6v__85070c43.Notification_styles_gk4bgs_s18m0x6v__85070c43.Notification_styles_gk4bgs_notificationItemHidden__85070c43{-webkit-animation:0.4s Notification_styles_gk4bgs_hideAnimationS18m0x6v__85070c43 ease-out;animation:0.4s Notification_styles_gk4bgs_hideAnimationS18m0x6v__85070c43 ease-out;}.Notification_styles_gk4bgs_s18m0x6v__85070c43.Notification_styles_gk4bgs_s18m0x6v__85070c43.Notification_styles_gk4bgs_notificationItemHidden__85070c43.Notification_styles_gk4bgs_notificationLeftToRightAnimation__85070c43{-webkit-animation:0.4s Notification_styles_gk4bgs_hideLeftToRightAnimationS18m0x6v__85070c43 ease-out;animation:0.4s Notification_styles_gk4bgs_hideLeftToRightAnimationS18m0x6v__85070c43 ease-out;}@-webkit-keyframes Notification_styles_gk4bgs_showLeftToRightAnimationS18m0x6v__85070c43{0%{-webkit-transform:translateX(-100%);-ms-transform:translateX(-100%);transform:translateX(-100%);opacity:0;}100%{-webkit-transform:translateX(0);-ms-transform:translateX(0);transform:translateX(0);opacity:1;}}@keyframes Notification_styles_gk4bgs_showLeftToRightAnimationS18m0x6v__85070c43{0%{-webkit-transform:translateX(-100%);-ms-transform:translateX(-100%);transform:translateX(-100%);opacity:0;}100%{-webkit-transform:translateX(0);-ms-transform:translateX(0);transform:translateX(0);opacity:1;}}@-webkit-keyframes Notification_styles_gk4bgs_hideLeftToRightAnimationS18m0x6v__85070c43{0%{-webkit-transform:translateX(0);-ms-transform:translateX(0);transform:translateX(0);opacity:1;}100%{-webkit-transform:translateX(-100%);-ms-transform:translateX(-100%);transform:translateX(-100%);opacity:0;}}@keyframes Notification_styles_gk4bgs_hideLeftToRightAnimationS18m0x6v__85070c43{0%{-webkit-transform:translateX(0);-ms-transform:translateX(0);transform:translateX(0);opacity:1;}100%{-webkit-transform:translateX(-100%);-ms-transform:translateX(-100%);transform:translateX(-100%);opacity:0;}}@-webkit-keyframes Notification_styles_gk4bgs_showAnimationS18m0x6v__85070c43{0%{-webkit-transform:translateX(100%);-ms-transform:translateX(100%);transform:translateX(100%);opacity:0;}100%{-webkit-transform:translateX(0);-ms-transform:translateX(0);transform:translateX(0);opacity:1;}}@keyframes Notification_styles_gk4bgs_showAnimationS18m0x6v__85070c43{0%{-webkit-transform:translateX(100%);-ms-transform:translateX(100%);transform:translateX(100%);opacity:0;}100%{-webkit-transform:translateX(0);-ms-transform:translateX(0);transform:translateX(0);opacity:1;}}@-webkit-keyframes Notification_styles_gk4bgs_hideAnimationS18m0x6v__85070c43{0%{-webkit-transform:translateX(0);-ms-transform:translateX(0);transform:translateX(0);opacity:1;}100%{-webkit-transform:translateX(100%);-ms-transform:translateX(100%);transform:translateX(100%);opacity:0;}}@keyframes Notification_styles_gk4bgs_hideAnimationS18m0x6v__85070c43{0%{-webkit-transform:translateX(0);-ms-transform:translateX(0);transform:translateX(0);opacity:1;}100%{-webkit-transform:translateX(100%);-ms-transform:translateX(100%);transform:translateX(100%);opacity:0;}}
43
- .Notification_styles_gk4bgs_sfe5ql2__85070c43{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-direction:column-reverse;-ms-flex-direction:column-reverse;flex-direction:column-reverse;box-sizing:border-box;padding:0 1.5rem 1.5rem;max-height:100%;-webkit-align-items:var(--sfe5ql2-0);-webkit-box-align:var(--sfe5ql2-0);-ms-flex-align:var(--sfe5ql2-0);align-items:var(--sfe5ql2-0);}
33
+ .Notification_styles_1u5gusp_sb12p__dcdf3719{width:-webkit-fit-content;width:-moz-fit-content;width:fit-content;}
34
+ .Notification_styles_1u5gusp_crvd7hm__dcdf3719{position:absolute;width:var(--plasma-notification-close-icon-button-size);height:var(--plasma-notification-close-icon-button-size);-webkit-align-self:var(--plasma-notification-horizontal-icon-close-align-self);-ms-flex-item-align:var(--plasma-notification-horizontal-icon-close-align);align-self:var(--plasma-notification-horizontal-icon-close-align-self);color:var(--plasma-notification-close-icon-color);}.Notification_styles_1u5gusp_crvd7hm__dcdf3719:hover{color:var(--plasma-notification-close-icon-color-on-hover);}.Notification_styles_1u5gusp_crvd7hm__dcdf3719.Notification_styles_1u5gusp_notificationLayoutHorizontal__dcdf3719{position:relative;}
35
+ .Notification_styles_1u5gusp_wg1ga5v__dcdf3719{position:relative;box-sizing:border-box;background:var(--plasma-notification-backgorund);border-radius:var(--plasma-notification-border-radius);border:var(--plasma-notification-border-width) solid var(--plasma-notification-border-color);}.Notification_styles_1u5gusp_wg1ga5v__dcdf3719.Notification_styles_1u5gusp_notificationLayoutHorizontal__dcdf3719{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-align-items:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center;gap:var(--plasma-notification-horizontal-layout-gap);}
36
+ .Notification_styles_1u5gusp_b1amsn8a__dcdf3719{margin-top:var(--plasma-notification-buttons-margin-top);margin-left:var(--b1amsn8a-0);-webkit-align-self:var(--plasma-notification-horizontal-actions-align-self);-ms-flex-item-align:var(--plasma-notification-horizontal-actions-align);align-self:var(--plasma-notification-horizontal-actions-align-self);}.Notification_styles_1u5gusp_b1amsn8a__dcdf3719.Notification_styles_1u5gusp_notificationLayoutHorizontal__dcdf3719{margin-top:unset;margin-left:unset;}
37
+ .Notification_styles_1u5gusp_i14raqr9__dcdf3719{width:var(--plasma-notification-content-left-icon-size);height:var(--plasma-notification-content-left-icon-size);-webkit-align-self:var(--plasma-notification-horizontal-icon-left-align-self);-ms-flex-item-align:var(--plasma-notification-horizontal-icon-left-align);align-self:var(--plasma-notification-horizontal-icon-left-align-self);margin-right:var(--i14raqr9-0);margin-bottom:var(--i14raqr9-1);}.Notification_styles_1u5gusp_i14raqr9__dcdf3719.Notification_styles_1u5gusp_notificationLayoutHorizontal__dcdf3719{margin-right:var(--plasma-notification-horizontal-layout-left-icon-margin);margin-bottom:unset;}
38
+ .Notification_styles_1u5gusp_c157peez__dcdf3719{display:var(--c157peez-0);padding-top:var(--c157peez-1);}.Notification_styles_1u5gusp_c157peez__dcdf3719.Notification_styles_1u5gusp_notificationLayoutHorizontal__dcdf3719{padding:unset;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-align-items:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-flex:1;-webkit-flex-grow:1;-ms-flex-positive:1;flex-grow:1;}
39
+ .Notification_styles_1u5gusp_t1vmb0f2__dcdf3719{padding:var(--plasma-notification-textbox-padding-top) var(--plasma-notification-textbox-padding-right) var(--plasma-notification-textbox-padding-bottom) var(--plasma-notification-textbox-padding-left);padding-top:var(--t1vmb0f2-0);padding-right:var(--t1vmb0f2-1);display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column;row-gap:var(--plasma-notification-textbox-gap);word-break:break-word;}.Notification_styles_1u5gusp_t1vmb0f2__dcdf3719.Notification_styles_1u5gusp_notificationLayoutHorizontal__dcdf3719{padding:unset;}
40
+ .Notification_styles_1u5gusp_s1k4e58v__dcdf3719{font-family:var(--plasma-notification-title-font-family);font-size:var(--plasma-notification-title-font-size);font-style:var(--plasma-notification-title-font-style);font-weight:var(--plasma-notification-title-font-weight);-webkit-letter-spacing:var(--plasma-notification-title-font-letter-spacing);-moz-letter-spacing:var(--plasma-notification-title-font-letter-spacing);-ms-letter-spacing:var(--plasma-notification-title-font-letter-spacing);letter-spacing:var(--plasma-notification-title-font-letter-spacing);line-height:var(--plasma-notification-title-font-line-height);overflow-wrap:break-word;-webkit-hyphens:auto;-moz-hyphens:auto;-ms-hyphens:auto;hyphens:auto;}
41
+ .Notification_styles_1u5gusp_s92kmpm__dcdf3719{font-family:var(--plasma-notification-content-font-family);font-size:var(--plasma-notification-content-font-size);font-style:var(--plasma-notification-content-font-style);font-weight:var(--plasma-notification-content-font-weight);-webkit-letter-spacing:var(--plasma-notification-content-font-letter-spacing);-moz-letter-spacing:var(--plasma-notification-content-font-letter-spacing);-ms-letter-spacing:var(--plasma-notification-content-font-letter-spacing);letter-spacing:var(--plasma-notification-content-font-letter-spacing);line-height:var(--plasma-notification-content-font-line-height);overflow-wrap:break-word;-webkit-hyphens:auto;-moz-hyphens:auto;-ms-hyphens:auto;hyphens:auto;color:var(--plasma-notification-content-color);}
42
+ .Notification_styles_1u5gusp_s18m0x6v__dcdf3719{margin-top:1rem;opacity:1;}.Notification_styles_1u5gusp_s18m0x6v__dcdf3719.Notification_styles_1u5gusp_s18m0x6v__dcdf3719.Notification_styles_1u5gusp_notificationItemOpened__dcdf3719{-webkit-animation:0.4s Notification_styles_1u5gusp_showAnimationS18m0x6v__dcdf3719 ease-out;animation:0.4s Notification_styles_1u5gusp_showAnimationS18m0x6v__dcdf3719 ease-out;}.Notification_styles_1u5gusp_s18m0x6v__dcdf3719.Notification_styles_1u5gusp_s18m0x6v__dcdf3719.Notification_styles_1u5gusp_notificationItemOpened__dcdf3719.Notification_styles_1u5gusp_notificationLeftToRightAnimation__dcdf3719{-webkit-animation:0.4s Notification_styles_1u5gusp_showLeftToRightAnimationS18m0x6v__dcdf3719 ease-out;animation:0.4s Notification_styles_1u5gusp_showLeftToRightAnimationS18m0x6v__dcdf3719 ease-out;}.Notification_styles_1u5gusp_s18m0x6v__dcdf3719.Notification_styles_1u5gusp_s18m0x6v__dcdf3719.Notification_styles_1u5gusp_notificationItemHidden__dcdf3719{-webkit-animation:0.4s Notification_styles_1u5gusp_hideAnimationS18m0x6v__dcdf3719 ease-out;animation:0.4s Notification_styles_1u5gusp_hideAnimationS18m0x6v__dcdf3719 ease-out;}.Notification_styles_1u5gusp_s18m0x6v__dcdf3719.Notification_styles_1u5gusp_s18m0x6v__dcdf3719.Notification_styles_1u5gusp_notificationItemHidden__dcdf3719.Notification_styles_1u5gusp_notificationLeftToRightAnimation__dcdf3719{-webkit-animation:0.4s Notification_styles_1u5gusp_hideLeftToRightAnimationS18m0x6v__dcdf3719 ease-out;animation:0.4s Notification_styles_1u5gusp_hideLeftToRightAnimationS18m0x6v__dcdf3719 ease-out;}@-webkit-keyframes Notification_styles_1u5gusp_showLeftToRightAnimationS18m0x6v__dcdf3719{0%{-webkit-transform:translateX(-100%);-ms-transform:translateX(-100%);transform:translateX(-100%);opacity:0;}100%{-webkit-transform:translateX(0);-ms-transform:translateX(0);transform:translateX(0);opacity:1;}}@keyframes Notification_styles_1u5gusp_showLeftToRightAnimationS18m0x6v__dcdf3719{0%{-webkit-transform:translateX(-100%);-ms-transform:translateX(-100%);transform:translateX(-100%);opacity:0;}100%{-webkit-transform:translateX(0);-ms-transform:translateX(0);transform:translateX(0);opacity:1;}}@-webkit-keyframes Notification_styles_1u5gusp_hideLeftToRightAnimationS18m0x6v__dcdf3719{0%{-webkit-transform:translateX(0);-ms-transform:translateX(0);transform:translateX(0);opacity:1;}100%{-webkit-transform:translateX(-100%);-ms-transform:translateX(-100%);transform:translateX(-100%);opacity:0;}}@keyframes Notification_styles_1u5gusp_hideLeftToRightAnimationS18m0x6v__dcdf3719{0%{-webkit-transform:translateX(0);-ms-transform:translateX(0);transform:translateX(0);opacity:1;}100%{-webkit-transform:translateX(-100%);-ms-transform:translateX(-100%);transform:translateX(-100%);opacity:0;}}@-webkit-keyframes Notification_styles_1u5gusp_showAnimationS18m0x6v__dcdf3719{0%{-webkit-transform:translateX(100%);-ms-transform:translateX(100%);transform:translateX(100%);opacity:0;}100%{-webkit-transform:translateX(0);-ms-transform:translateX(0);transform:translateX(0);opacity:1;}}@keyframes Notification_styles_1u5gusp_showAnimationS18m0x6v__dcdf3719{0%{-webkit-transform:translateX(100%);-ms-transform:translateX(100%);transform:translateX(100%);opacity:0;}100%{-webkit-transform:translateX(0);-ms-transform:translateX(0);transform:translateX(0);opacity:1;}}@-webkit-keyframes Notification_styles_1u5gusp_hideAnimationS18m0x6v__dcdf3719{0%{-webkit-transform:translateX(0);-ms-transform:translateX(0);transform:translateX(0);opacity:1;}100%{-webkit-transform:translateX(100%);-ms-transform:translateX(100%);transform:translateX(100%);opacity:0;}}@keyframes Notification_styles_1u5gusp_hideAnimationS18m0x6v__dcdf3719{0%{-webkit-transform:translateX(0);-ms-transform:translateX(0);transform:translateX(0);opacity:1;}100%{-webkit-transform:translateX(100%);-ms-transform:translateX(100%);transform:translateX(100%);opacity:0;}}
43
+ .Notification_styles_1u5gusp_sfe5ql2__dcdf3719{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-direction:column-reverse;-ms-flex-direction:column-reverse;flex-direction:column-reverse;box-sizing:border-box;padding:0 1.5rem 1.5rem;max-height:100%;-webkit-align-items:var(--sfe5ql2-0);-webkit-box-align:var(--sfe5ql2-0);-ms-flex-align:var(--sfe5ql2-0);align-items:var(--sfe5ql2-0);}
@@ -12,7 +12,7 @@ import { layouts } from './Notification.types.js';
12
12
  import { Wrapper, ContentBox, IconWrapper, TextBox, StyledTitle, StyledContent, ButtonsWrapper, CloseIconWrapper, StyledNotification } from './Notification.styles.js';
13
13
  import { getLayoutClass } from './utils/index.js';
14
14
 
15
- var _excluded = ["role", "title", "children", "actions", "view", "size", "iconPlacement", "showCloseIcon", "layout", "icon", "closeIconType", "textColor", "iconColor", "onCloseButtonClick"];
15
+ var _excluded = ["role", "title", "children", "actions", "view", "size", "iconPlacement", "showCloseIcon", "layout", "icon", "closeIconType", "onCloseButtonClick"];
16
16
 
17
17
  /**
18
18
  * Компонент для небольших уведомлений пользователя
@@ -33,8 +33,6 @@ var notificationRoot = function notificationRoot(Root) {
33
33
  layout = _props$layout === void 0 ? layouts.vertical : _props$layout,
34
34
  icon = props.icon,
35
35
  closeIconType = props.closeIconType,
36
- textColor = props.textColor,
37
- iconColor = props.iconColor,
38
36
  onCloseButtonClick = props.onCloseButtonClick,
39
37
  rest = _objectWithoutProperties(props, _excluded);
40
38
  var ariaLive = 'polite';
@@ -67,15 +65,13 @@ var notificationRoot = function notificationRoot(Root) {
67
65
  className: cx(classes.contentBox, getLayoutClass(layout), withoutIconClass)
68
66
  }, icon && /*#__PURE__*/React.createElement(IconWrapper, {
69
67
  iconPlacement: IconPlacementInternal,
70
- className: cx(classes.icon, getLayoutClass(layout)),
71
- iconColor: iconColor
68
+ className: cx(classes.icon, getLayoutClass(layout))
72
69
  }, icon), /*#__PURE__*/React.createElement(TextBox, {
73
70
  iconPlacement: IconPlacementInternal,
74
71
  showCloseIcon: showCloseIcon,
75
72
  className: cx(classes.textbox, getLayoutClass(layout))
76
73
  }, title && /*#__PURE__*/React.createElement(StyledTitle, {
77
- className: classes.title,
78
- textColor: textColor
74
+ className: classes.title
79
75
  }, title), content && /*#__PURE__*/React.createElement(StyledContent, {
80
76
  className: classes.text
81
77
  }, content))), actions && /*#__PURE__*/React.createElement(ButtonsWrapper, {
@@ -1 +1 @@
1
- {"version":3,"file":"Notification.js","sources":["../../../src/components/Notification/Notification.tsx"],"sourcesContent":["import React, { forwardRef, useMemo } from 'react';\n\nimport { RootProps } from '../../engines';\nimport { cx } from '../../utils';\nimport { IconCross } from '../_Icon/Icons/IconCross';\nimport { IconCrossThin } from '../_Icon/Icons/IconCrossThin';\n\nimport { classes, tokens } from './Notification.tokens';\nimport { base as viewCSS } from './variations/_view/base';\nimport { base as layoutCSS } from './variations/_layout/base';\nimport { base as sizeCSS } from './variations/_size/base';\nimport { base as closeIconTypeCSS } from './variations/_closeIconType/base';\nimport { NotificationLayout, NotificationProps, layouts } from './Notification.types';\nimport {\n ButtonsWrapper,\n CloseIconWrapper,\n ContentBox,\n IconWrapper,\n StyledContent,\n StyledNotification,\n StyledTitle,\n TextBox,\n Wrapper,\n} from './Notification.styles';\nimport { getLayoutClass } from './utils';\n\n/**\n * Компонент для небольших уведомлений пользователя\n */\nexport const notificationRoot = (Root: RootProps<HTMLDivElement, Omit<NotificationProps, 'title'>>) =>\n forwardRef<HTMLDivElement, NotificationProps>((props, ref) => {\n const {\n role = 'status',\n title,\n children: content,\n actions,\n view,\n size,\n iconPlacement,\n showCloseIcon = true,\n layout = layouts.vertical as NotificationLayout,\n icon,\n closeIconType,\n textColor,\n iconColor,\n onCloseButtonClick,\n ...rest\n } = props;\n\n let ariaLive: 'assertive' | 'polite' = 'polite';\n let ariaAtomic = false;\n\n if (role === 'alert') {\n ariaLive = 'assertive';\n } else if (role === 'status') {\n ariaAtomic = true;\n }\n\n const isOneLine = !content || !title;\n const oneLineClass = isOneLine ? classes.oneLine : undefined;\n const withoutIconClass = icon ? undefined : classes.withoutIcon;\n const withoutCloseIconClass = showCloseIcon ? undefined : classes.withoutCloseIcon;\n\n const IconPlacementInternal = useMemo(() => (icon ? iconPlacement : undefined), [icon, iconPlacement]);\n\n return (\n <Root\n view={view}\n size={size}\n layout={layout}\n closeIconType={closeIconType}\n ref={ref}\n role={role}\n aria-live={ariaLive}\n aria-atomic={ariaAtomic}\n {...rest}\n >\n <Wrapper className={cx(classes.wrapper, getLayoutClass(layout), oneLineClass, withoutCloseIconClass)}>\n <ContentBox\n iconPlacement={IconPlacementInternal}\n className={cx(classes.contentBox, getLayoutClass(layout), withoutIconClass)}\n >\n {icon && (\n <IconWrapper\n iconPlacement={IconPlacementInternal}\n className={cx(classes.icon, getLayoutClass(layout))}\n iconColor={iconColor}\n >\n {icon}\n </IconWrapper>\n )}\n <TextBox\n iconPlacement={IconPlacementInternal}\n showCloseIcon={showCloseIcon}\n className={cx(classes.textbox, getLayoutClass(layout))}\n >\n {title && (\n <StyledTitle className={classes.title} textColor={textColor}>\n {title}\n </StyledTitle>\n )}\n {content && <StyledContent className={classes.text}>{content}</StyledContent>}\n </TextBox>\n </ContentBox>\n {actions && (\n <ButtonsWrapper\n iconPlacement={IconPlacementInternal}\n className={cx(classes.buttonsWrapper, getLayoutClass(layout))}\n >\n {actions}\n </ButtonsWrapper>\n )}\n\n {showCloseIcon && (\n <CloseIconWrapper\n view=\"clear\"\n size=\"s\"\n onClick={onCloseButtonClick}\n className={cx(classes.closeIcon, getLayoutClass(layout))}\n >\n {closeIconType === 'default' ? (\n <IconCross size=\"s\" sizeCustomProperty={tokens.closeIconSize} color=\"inherit\" />\n ) : (\n <IconCrossThin size=\"s\" sizeCustomProperty={tokens.closeIconSize} color=\"inherit\" />\n )}\n </CloseIconWrapper>\n )}\n </Wrapper>\n </Root>\n );\n });\n\nexport const notificationConfig = {\n name: 'Notification',\n tag: 'div',\n layout: notificationRoot,\n base: StyledNotification,\n variations: {\n layout: {\n css: layoutCSS,\n },\n view: {\n css: viewCSS,\n },\n size: {\n css: sizeCSS,\n },\n closeIconType: {\n css: closeIconTypeCSS,\n },\n },\n defaults: {\n view: 'default',\n layout: layouts.vertical,\n size: 'xs',\n closeIconType: 'default',\n },\n};\n"],"names":["notificationRoot","Root","forwardRef","props","ref","_props$role","role","title","content","children","actions","view","size","iconPlacement","_props$showCloseIcon","showCloseIcon","_props$layout","layout","layouts","vertical","icon","closeIconType","textColor","iconColor","onCloseButtonClick","rest","_objectWithoutProperties","_excluded","ariaLive","ariaAtomic","isOneLine","oneLineClass","classes","oneLine","undefined","withoutIconClass","withoutIcon","withoutCloseIconClass","withoutCloseIcon","IconPlacementInternal","useMemo","React","createElement","_extends","Wrapper","className","cx","wrapper","getLayoutClass","ContentBox","contentBox","IconWrapper","TextBox","textbox","StyledTitle","StyledContent","text","ButtonsWrapper","buttonsWrapper","CloseIconWrapper","onClick","closeIcon","IconCross","sizeCustomProperty","tokens","closeIconSize","color","IconCrossThin","notificationConfig","name","tag","base","StyledNotification","variations","css","layoutCSS","viewCSS","sizeCSS","closeIconTypeCSS","defaults"],"mappings":"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"}
1
+ {"version":3,"file":"Notification.js","sources":["../../../src/components/Notification/Notification.tsx"],"sourcesContent":["import React, { forwardRef, useMemo } from 'react';\n\nimport { RootProps } from '../../engines';\nimport { cx } from '../../utils';\nimport { IconCross } from '../_Icon/Icons/IconCross';\nimport { IconCrossThin } from '../_Icon/Icons/IconCrossThin';\n\nimport { classes, tokens } from './Notification.tokens';\nimport { base as viewCSS } from './variations/_view/base';\nimport { base as layoutCSS } from './variations/_layout/base';\nimport { base as sizeCSS } from './variations/_size/base';\nimport { base as closeIconTypeCSS } from './variations/_closeIconType/base';\nimport { NotificationLayout, NotificationProps, layouts } from './Notification.types';\nimport {\n ButtonsWrapper,\n CloseIconWrapper,\n ContentBox,\n IconWrapper,\n StyledContent,\n StyledNotification,\n StyledTitle,\n TextBox,\n Wrapper,\n} from './Notification.styles';\nimport { getLayoutClass } from './utils';\n\n/**\n * Компонент для небольших уведомлений пользователя\n */\nexport const notificationRoot = (Root: RootProps<HTMLDivElement, Omit<NotificationProps, 'title'>>) =>\n forwardRef<HTMLDivElement, NotificationProps>((props, ref) => {\n const {\n role = 'status',\n title,\n children: content,\n actions,\n view,\n size,\n iconPlacement,\n showCloseIcon = true,\n layout = layouts.vertical as NotificationLayout,\n icon,\n closeIconType,\n onCloseButtonClick,\n ...rest\n } = props;\n\n let ariaLive: 'assertive' | 'polite' = 'polite';\n let ariaAtomic = false;\n\n if (role === 'alert') {\n ariaLive = 'assertive';\n } else if (role === 'status') {\n ariaAtomic = true;\n }\n\n const isOneLine = !content || !title;\n const oneLineClass = isOneLine ? classes.oneLine : undefined;\n const withoutIconClass = icon ? undefined : classes.withoutIcon;\n const withoutCloseIconClass = showCloseIcon ? undefined : classes.withoutCloseIcon;\n\n const IconPlacementInternal = useMemo(() => (icon ? iconPlacement : undefined), [icon, iconPlacement]);\n\n return (\n <Root\n view={view}\n size={size}\n layout={layout}\n closeIconType={closeIconType}\n ref={ref}\n role={role}\n aria-live={ariaLive}\n aria-atomic={ariaAtomic}\n {...rest}\n >\n <Wrapper className={cx(classes.wrapper, getLayoutClass(layout), oneLineClass, withoutCloseIconClass)}>\n <ContentBox\n iconPlacement={IconPlacementInternal}\n className={cx(classes.contentBox, getLayoutClass(layout), withoutIconClass)}\n >\n {icon && (\n <IconWrapper\n iconPlacement={IconPlacementInternal}\n className={cx(classes.icon, getLayoutClass(layout))}\n >\n {icon}\n </IconWrapper>\n )}\n <TextBox\n iconPlacement={IconPlacementInternal}\n showCloseIcon={showCloseIcon}\n className={cx(classes.textbox, getLayoutClass(layout))}\n >\n {title && <StyledTitle className={classes.title}>{title}</StyledTitle>}\n {content && <StyledContent className={classes.text}>{content}</StyledContent>}\n </TextBox>\n </ContentBox>\n {actions && (\n <ButtonsWrapper\n iconPlacement={IconPlacementInternal}\n className={cx(classes.buttonsWrapper, getLayoutClass(layout))}\n >\n {actions}\n </ButtonsWrapper>\n )}\n\n {showCloseIcon && (\n <CloseIconWrapper\n view=\"clear\"\n size=\"s\"\n onClick={onCloseButtonClick}\n className={cx(classes.closeIcon, getLayoutClass(layout))}\n >\n {closeIconType === 'default' ? (\n <IconCross size=\"s\" sizeCustomProperty={tokens.closeIconSize} color=\"inherit\" />\n ) : (\n <IconCrossThin size=\"s\" sizeCustomProperty={tokens.closeIconSize} color=\"inherit\" />\n )}\n </CloseIconWrapper>\n )}\n </Wrapper>\n </Root>\n );\n });\n\nexport const notificationConfig = {\n name: 'Notification',\n tag: 'div',\n layout: notificationRoot,\n base: StyledNotification,\n variations: {\n layout: {\n css: layoutCSS,\n },\n view: {\n css: viewCSS,\n },\n size: {\n css: sizeCSS,\n },\n closeIconType: {\n css: closeIconTypeCSS,\n },\n },\n defaults: {\n view: 'default',\n layout: layouts.vertical,\n size: 'xs',\n closeIconType: 'default',\n },\n};\n"],"names":["notificationRoot","Root","forwardRef","props","ref","_props$role","role","title","content","children","actions","view","size","iconPlacement","_props$showCloseIcon","showCloseIcon","_props$layout","layout","layouts","vertical","icon","closeIconType","onCloseButtonClick","rest","_objectWithoutProperties","_excluded","ariaLive","ariaAtomic","isOneLine","oneLineClass","classes","oneLine","undefined","withoutIconClass","withoutIcon","withoutCloseIconClass","withoutCloseIcon","IconPlacementInternal","useMemo","React","createElement","_extends","Wrapper","className","cx","wrapper","getLayoutClass","ContentBox","contentBox","IconWrapper","TextBox","textbox","StyledTitle","StyledContent","text","ButtonsWrapper","buttonsWrapper","CloseIconWrapper","onClick","closeIcon","IconCross","sizeCustomProperty","tokens","closeIconSize","color","IconCrossThin","notificationConfig","name","tag","base","StyledNotification","variations","css","layoutCSS","viewCSS","sizeCSS","closeIconTypeCSS","defaults"],"mappings":"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"}
@@ -1,4 +1,4 @@
1
- import './Notification.styles_gk4bgs.css';
1
+ import './Notification.styles_1u5gusp.css';
2
2
  import { styled } from '@linaria/react';
3
3
  import { tokens } from './Notification.tokens.js';
4
4
  import { placements } from './Notification.types.js';
@@ -37,19 +37,13 @@ var ButtonsWrapper = /*#__PURE__*/styled('div')({
37
37
  });
38
38
  var _exp21 = function _exp21() {
39
39
  return function (_ref2) {
40
- var iconColor = _ref2.iconColor;
41
- return iconColor || "var(".concat(tokens.contentLeftIconColor, ")");
40
+ var iconPlacement = _ref2.iconPlacement;
41
+ return iconPlacement === placements.left ? "var(".concat(tokens.contentLeftIconMargin, ")") : 'unset';
42
42
  };
43
43
  };
44
44
  var _exp22 = function _exp22() {
45
45
  return function (_ref3) {
46
46
  var iconPlacement = _ref3.iconPlacement;
47
- return iconPlacement === placements.left ? "var(".concat(tokens.contentLeftIconMargin, ")") : 'unset';
48
- };
49
- };
50
- var _exp23 = function _exp23() {
51
- return function (_ref4) {
52
- var iconPlacement = _ref4.iconPlacement;
53
47
  return iconPlacement === placements.top ? "var(".concat(tokens.contentTopIconMargin, ")") : 'unset';
54
48
  };
55
49
  };
@@ -59,19 +53,18 @@ var IconWrapper = /*#__PURE__*/styled('div')({
59
53
  propsAsIs: false,
60
54
  vars: {
61
55
  "i14raqr9-0": [/*#__PURE__*/_exp21()],
62
- "i14raqr9-1": [/*#__PURE__*/_exp22()],
63
- "i14raqr9-2": [/*#__PURE__*/_exp23()]
56
+ "i14raqr9-1": [/*#__PURE__*/_exp22()]
64
57
  }
65
58
  });
66
- var _exp26 = function _exp26() {
67
- return function (_ref5) {
68
- var iconPlacement = _ref5.iconPlacement;
59
+ var _exp25 = function _exp25() {
60
+ return function (_ref4) {
61
+ var iconPlacement = _ref4.iconPlacement;
69
62
  return iconPlacement === placements.left ? 'flex' : 'block';
70
63
  };
71
64
  };
72
- var _exp27 = function _exp27() {
73
- return function (_ref6) {
74
- var iconPlacement = _ref6.iconPlacement;
65
+ var _exp26 = function _exp26() {
66
+ return function (_ref5) {
67
+ var iconPlacement = _ref5.iconPlacement;
75
68
  return iconPlacement ? "var(".concat(tokens.contentPaddingTop, ")") : "var(".concat(tokens.contentPaddingTopWithoutIcon, ")");
76
69
  };
77
70
  };
@@ -80,20 +73,20 @@ var ContentBox = /*#__PURE__*/styled('div')({
80
73
  "class": "c157peez",
81
74
  propsAsIs: false,
82
75
  vars: {
83
- "c157peez-0": [/*#__PURE__*/_exp26()],
84
- "c157peez-1": [/*#__PURE__*/_exp27()]
76
+ "c157peez-0": [/*#__PURE__*/_exp25()],
77
+ "c157peez-1": [/*#__PURE__*/_exp26()]
85
78
  }
86
79
  });
87
- var _exp33 = function _exp33() {
88
- return function (_ref7) {
89
- var iconPlacement = _ref7.iconPlacement;
80
+ var _exp32 = function _exp32() {
81
+ return function (_ref6) {
82
+ var iconPlacement = _ref6.iconPlacement;
90
83
  return !iconPlacement || iconPlacement === placements.top ? "var(".concat(tokens.textboxPaddingTopWithTopIcon, ")") : "var(".concat(tokens.textboxPaddingTop, ")");
91
84
  };
92
85
  };
93
- var _exp34 = function _exp34() {
94
- return function (_ref8) {
95
- var showCloseIcon = _ref8.showCloseIcon,
96
- iconPlacement = _ref8.iconPlacement;
86
+ var _exp33 = function _exp33() {
87
+ return function (_ref7) {
88
+ var showCloseIcon = _ref7.showCloseIcon,
89
+ iconPlacement = _ref7.iconPlacement;
97
90
  return showCloseIcon && iconPlacement !== placements.top ? "var(".concat(tokens.textboxPaddingRightWithCloseIcon, ")") : "var(".concat(tokens.textboxPaddingRight, ")");
98
91
  };
99
92
  };
@@ -102,23 +95,14 @@ var TextBox = /*#__PURE__*/styled('div')({
102
95
  "class": "t1vmb0f2",
103
96
  propsAsIs: false,
104
97
  vars: {
105
- "t1vmb0f2-0": [/*#__PURE__*/_exp33()],
106
- "t1vmb0f2-1": [/*#__PURE__*/_exp34()]
98
+ "t1vmb0f2-0": [/*#__PURE__*/_exp32()],
99
+ "t1vmb0f2-1": [/*#__PURE__*/_exp33()]
107
100
  }
108
101
  });
109
- var _exp44 = function _exp44() {
110
- return function (_ref9) {
111
- var textColor = _ref9.textColor;
112
- return textColor || "var(".concat(tokens.titleColor, ")");
113
- };
114
- };
115
102
  var StyledTitle = /*#__PURE__*/styled('div')({
116
103
  name: "StyledTitle",
117
104
  "class": "s1k4e58v",
118
- propsAsIs: false,
119
- vars: {
120
- "s1k4e58v-0": [/*#__PURE__*/_exp44()]
121
- }
105
+ propsAsIs: false
122
106
  });
123
107
  var StyledContent = /*#__PURE__*/styled('div')({
124
108
  name: "StyledContent",
@@ -130,9 +114,9 @@ var StyledItemWrapper = /*#__PURE__*/styled('div')({
130
114
  "class": "s18m0x6v",
131
115
  propsAsIs: false
132
116
  });
133
- var _exp57 = function _exp57() {
134
- return function (_ref10) {
135
- var placement = _ref10.placement;
117
+ var _exp55 = function _exp55() {
118
+ return function (_ref8) {
119
+ var placement = _ref8.placement;
136
120
  return placement === 'bottom-left' ? 'flex-start' : 'flex-end';
137
121
  };
138
122
  };
@@ -141,7 +125,7 @@ var StyledRoot = /*#__PURE__*/styled('div')({
141
125
  "class": "sfe5ql2",
142
126
  propsAsIs: false,
143
127
  vars: {
144
- "sfe5ql2-0": [/*#__PURE__*/_exp57()]
128
+ "sfe5ql2-0": [/*#__PURE__*/_exp55()]
145
129
  }
146
130
  });
147
131