@salt-ds/lab 1.0.0-alpha.10 → 1.0.0-alpha.11

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.
Files changed (153) hide show
  1. package/dist-cjs/common-hooks/useKeyboardNavigation.js +0 -3
  2. package/dist-cjs/common-hooks/useKeyboardNavigation.js.map +1 -1
  3. package/dist-cjs/dialog/DialogTitle.css.js +1 -1
  4. package/dist-cjs/dialog/DialogTitle.js +2 -3
  5. package/dist-cjs/dialog/DialogTitle.js.map +1 -1
  6. package/dist-cjs/dropdown/Dropdown.js +5 -2
  7. package/dist-cjs/dropdown/Dropdown.js.map +1 -1
  8. package/dist-cjs/dropdown/useDropdown.js +12 -0
  9. package/dist-cjs/dropdown/useDropdown.js.map +1 -1
  10. package/dist-cjs/index.js +15 -1
  11. package/dist-cjs/index.js.map +1 -1
  12. package/dist-cjs/list/useList.js +0 -1
  13. package/dist-cjs/list/useList.js.map +1 -1
  14. package/dist-cjs/list-next/ListItemNext.css.js +6 -0
  15. package/dist-cjs/list-next/ListItemNext.css.js.map +1 -0
  16. package/dist-cjs/list-next/ListItemNext.js +74 -0
  17. package/dist-cjs/list-next/ListItemNext.js.map +1 -0
  18. package/dist-cjs/list-next/ListNext.css.js +6 -0
  19. package/dist-cjs/list-next/ListNext.css.js.map +1 -0
  20. package/dist-cjs/list-next/ListNext.js +92 -0
  21. package/dist-cjs/list-next/ListNext.js.map +1 -0
  22. package/dist-cjs/list-next/ListNextContext.js +18 -0
  23. package/dist-cjs/list-next/ListNextContext.js.map +1 -0
  24. package/dist-cjs/list-next/useList.js +188 -0
  25. package/dist-cjs/list-next/useList.js.map +1 -0
  26. package/dist-cjs/logo/Logo.css.js +1 -1
  27. package/dist-cjs/logo/Logo.js +4 -36
  28. package/dist-cjs/logo/Logo.js.map +1 -1
  29. package/dist-cjs/logo/LogoImage.js +24 -0
  30. package/dist-cjs/logo/LogoImage.js.map +1 -0
  31. package/dist-cjs/logo/LogoSeparator.css.js +6 -0
  32. package/dist-cjs/logo/LogoSeparator.css.js.map +1 -0
  33. package/dist-cjs/logo/LogoSeparator.js +32 -0
  34. package/dist-cjs/logo/LogoSeparator.js.map +1 -0
  35. package/dist-cjs/query-input/internal/QueryInputBody.js +5 -5
  36. package/dist-cjs/query-input/internal/QueryInputBody.js.map +1 -1
  37. package/dist-cjs/tabs-next/OverflowMenu.js +49 -0
  38. package/dist-cjs/tabs-next/OverflowMenu.js.map +1 -0
  39. package/dist-cjs/tabs-next/TabNext.css.js +6 -0
  40. package/dist-cjs/tabs-next/TabNext.css.js.map +1 -0
  41. package/dist-cjs/tabs-next/TabNext.js +87 -0
  42. package/dist-cjs/tabs-next/TabNext.js.map +1 -0
  43. package/dist-cjs/tabs-next/TabNextContext.js +23 -0
  44. package/dist-cjs/tabs-next/TabNextContext.js.map +1 -0
  45. package/dist-cjs/tabs-next/TabstripNext.css.js +6 -0
  46. package/dist-cjs/tabs-next/TabstripNext.css.js.map +1 -0
  47. package/dist-cjs/tabs-next/TabstripNext.js +180 -0
  48. package/dist-cjs/tabs-next/TabstripNext.js.map +1 -0
  49. package/dist-cjs/toggle-button/ToggleButton.css.js +1 -1
  50. package/dist-cjs/toggle-button/ToggleButton.js +44 -74
  51. package/dist-cjs/toggle-button/ToggleButton.js.map +1 -1
  52. package/dist-cjs/toggle-button-group/ToggleButtonGroup.css.js +6 -0
  53. package/dist-cjs/toggle-button-group/ToggleButtonGroup.js +111 -0
  54. package/dist-cjs/toggle-button-group/ToggleButtonGroup.js.map +1 -0
  55. package/dist-cjs/toggle-button-group/ToggleButtonGroupContext.js +15 -0
  56. package/dist-cjs/toggle-button-group/ToggleButtonGroupContext.js.map +1 -0
  57. package/dist-es/common-hooks/useKeyboardNavigation.js +0 -3
  58. package/dist-es/common-hooks/useKeyboardNavigation.js.map +1 -1
  59. package/dist-es/dialog/DialogTitle.css.js +1 -1
  60. package/dist-es/dialog/DialogTitle.js +3 -4
  61. package/dist-es/dialog/DialogTitle.js.map +1 -1
  62. package/dist-es/dropdown/Dropdown.js +5 -2
  63. package/dist-es/dropdown/Dropdown.js.map +1 -1
  64. package/dist-es/dropdown/useDropdown.js +12 -0
  65. package/dist-es/dropdown/useDropdown.js.map +1 -1
  66. package/dist-es/index.js +8 -1
  67. package/dist-es/index.js.map +1 -1
  68. package/dist-es/list/useList.js +0 -1
  69. package/dist-es/list/useList.js.map +1 -1
  70. package/dist-es/list-next/ListItemNext.css.js +4 -0
  71. package/dist-es/list-next/ListItemNext.css.js.map +1 -0
  72. package/dist-es/list-next/ListItemNext.js +70 -0
  73. package/dist-es/list-next/ListItemNext.js.map +1 -0
  74. package/dist-es/list-next/ListNext.css.js +4 -0
  75. package/dist-es/list-next/ListNext.css.js.map +1 -0
  76. package/dist-es/list-next/ListNext.js +88 -0
  77. package/dist-es/list-next/ListNext.js.map +1 -0
  78. package/dist-es/list-next/ListNextContext.js +13 -0
  79. package/dist-es/list-next/ListNextContext.js.map +1 -0
  80. package/dist-es/list-next/useList.js +184 -0
  81. package/dist-es/list-next/useList.js.map +1 -0
  82. package/dist-es/logo/Logo.css.js +1 -1
  83. package/dist-es/logo/Logo.js +5 -37
  84. package/dist-es/logo/Logo.js.map +1 -1
  85. package/dist-es/logo/LogoImage.js +20 -0
  86. package/dist-es/logo/LogoImage.js.map +1 -0
  87. package/dist-es/logo/LogoSeparator.css.js +4 -0
  88. package/dist-es/logo/LogoSeparator.css.js.map +1 -0
  89. package/dist-es/logo/LogoSeparator.js +28 -0
  90. package/dist-es/logo/LogoSeparator.js.map +1 -0
  91. package/dist-es/query-input/internal/QueryInputBody.js +5 -5
  92. package/dist-es/query-input/internal/QueryInputBody.js.map +1 -1
  93. package/dist-es/tabs-next/OverflowMenu.js +45 -0
  94. package/dist-es/tabs-next/OverflowMenu.js.map +1 -0
  95. package/dist-es/tabs-next/TabNext.css.js +4 -0
  96. package/dist-es/tabs-next/TabNext.css.js.map +1 -0
  97. package/dist-es/tabs-next/TabNext.js +79 -0
  98. package/dist-es/tabs-next/TabNext.js.map +1 -0
  99. package/dist-es/tabs-next/TabNextContext.js +18 -0
  100. package/dist-es/tabs-next/TabNextContext.js.map +1 -0
  101. package/dist-es/tabs-next/TabstripNext.css.js +4 -0
  102. package/dist-es/tabs-next/TabstripNext.css.js.map +1 -0
  103. package/dist-es/tabs-next/TabstripNext.js +172 -0
  104. package/dist-es/tabs-next/TabstripNext.js.map +1 -0
  105. package/dist-es/toggle-button/ToggleButton.css.js +1 -1
  106. package/dist-es/toggle-button/ToggleButton.js +45 -75
  107. package/dist-es/toggle-button/ToggleButton.js.map +1 -1
  108. package/dist-es/toggle-button-group/ToggleButtonGroup.css.js +4 -0
  109. package/dist-es/toggle-button-group/ToggleButtonGroup.js +107 -0
  110. package/dist-es/toggle-button-group/ToggleButtonGroup.js.map +1 -0
  111. package/dist-es/toggle-button-group/ToggleButtonGroupContext.js +10 -0
  112. package/dist-es/toggle-button-group/ToggleButtonGroupContext.js.map +1 -0
  113. package/dist-types/dropdown/useDropdown.d.ts +1 -1
  114. package/dist-types/index.d.ts +3 -0
  115. package/dist-types/list-next/ListItemNext.d.ts +11 -0
  116. package/dist-types/list-next/ListNext.d.ts +10 -0
  117. package/dist-types/list-next/ListNextContext.d.ts +10 -0
  118. package/dist-types/list-next/index.d.ts +2 -0
  119. package/dist-types/list-next/useList.d.ts +29 -0
  120. package/dist-types/logo/Logo.d.ts +3 -31
  121. package/dist-types/logo/LogoImage.d.ts +5 -0
  122. package/dist-types/logo/LogoSeparator.d.ts +3 -0
  123. package/dist-types/logo/index.d.ts +2 -0
  124. package/dist-types/tabs-next/OverflowMenu.d.ts +11 -0
  125. package/dist-types/tabs-next/TabNext.d.ts +5 -0
  126. package/dist-types/tabs-next/TabNextContext.d.ts +17 -0
  127. package/dist-types/tabs-next/TabstripNext.d.ts +10 -0
  128. package/dist-types/tabs-next/index.d.ts +2 -0
  129. package/dist-types/toggle-button/ToggleButton.d.ts +6 -11
  130. package/dist-types/toggle-button/index.d.ts +0 -1
  131. package/dist-types/toggle-button-group/ToggleButtonGroup.d.ts +25 -0
  132. package/dist-types/toggle-button-group/ToggleButtonGroupContext.d.ts +10 -0
  133. package/dist-types/toggle-button-group/index.d.ts +2 -0
  134. package/package.json +6 -4
  135. package/dist-cjs/logo/internal/LogoTitle.js +0 -28
  136. package/dist-cjs/logo/internal/LogoTitle.js.map +0 -1
  137. package/dist-cjs/toggle-button/ToggleButtonGroup.css.js +0 -6
  138. package/dist-cjs/toggle-button/ToggleButtonGroup.js +0 -147
  139. package/dist-cjs/toggle-button/ToggleButtonGroup.js.map +0 -1
  140. package/dist-cjs/toggle-button/internal/ToggleButtonGroupContext.js +0 -10
  141. package/dist-cjs/toggle-button/internal/ToggleButtonGroupContext.js.map +0 -1
  142. package/dist-es/logo/internal/LogoTitle.js +0 -24
  143. package/dist-es/logo/internal/LogoTitle.js.map +0 -1
  144. package/dist-es/toggle-button/ToggleButtonGroup.css.js +0 -4
  145. package/dist-es/toggle-button/ToggleButtonGroup.js +0 -143
  146. package/dist-es/toggle-button/ToggleButtonGroup.js.map +0 -1
  147. package/dist-es/toggle-button/internal/ToggleButtonGroupContext.js +0 -6
  148. package/dist-es/toggle-button/internal/ToggleButtonGroupContext.js.map +0 -1
  149. package/dist-types/logo/internal/LogoTitle.d.ts +0 -6
  150. package/dist-types/toggle-button/ToggleButtonGroup.d.ts +0 -18
  151. package/dist-types/toggle-button/internal/ToggleButtonGroupContext.d.ts +0 -14
  152. /package/dist-cjs/{toggle-button → toggle-button-group}/ToggleButtonGroup.css.js.map +0 -0
  153. /package/dist-es/{toggle-button → toggle-button-group}/ToggleButtonGroup.css.js.map +0 -0
@@ -0,0 +1,92 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var jsxRuntime = require('react/jsx-runtime');
6
+ var core = require('@salt-ds/core');
7
+ var React = require('react');
8
+ var clsx = require('clsx');
9
+ var useList = require('./useList.js');
10
+ var window = require('@salt-ds/window');
11
+ var styles = require('@salt-ds/styles');
12
+ var ListNext$1 = require('./ListNext.css.js');
13
+ var ListNextContext = require('./ListNextContext.js');
14
+
15
+ const withBaseName = core.makePrefixer("saltListNext");
16
+ const ListNext = React.forwardRef(
17
+ function ListNext2({
18
+ children,
19
+ className,
20
+ disabled,
21
+ id,
22
+ onSelect,
23
+ onFocus,
24
+ onBlur,
25
+ onKeyDown,
26
+ onMouseDown,
27
+ selected,
28
+ defaultSelected,
29
+ ...rest
30
+ }, ref) {
31
+ const targetWindow = window.useWindow();
32
+ styles.useComponentCssInjection({
33
+ testId: "salt-list-next",
34
+ css: ListNext$1,
35
+ window: targetWindow
36
+ });
37
+ const listId = core.useId(id);
38
+ const listRef = React.useRef(null);
39
+ const handleRef = core.useForkRef(listRef, ref);
40
+ const {
41
+ focusHandler,
42
+ keyDownHandler,
43
+ blurHandler,
44
+ mouseDownHandler,
45
+ activeDescendant,
46
+ contextValue
47
+ } = useList.useList({
48
+ disabled,
49
+ selected,
50
+ defaultSelected,
51
+ id: listId,
52
+ ref: listRef
53
+ });
54
+ const handleFocus = (event) => {
55
+ focusHandler();
56
+ onFocus == null ? void 0 : onFocus(event);
57
+ };
58
+ const handleKeyDown = (event) => {
59
+ keyDownHandler(event);
60
+ onKeyDown == null ? void 0 : onKeyDown(event);
61
+ };
62
+ const handleBlur = (event) => {
63
+ blurHandler();
64
+ onBlur == null ? void 0 : onBlur(event);
65
+ };
66
+ const handleMouseDown = (event) => {
67
+ mouseDownHandler();
68
+ onMouseDown == null ? void 0 : onMouseDown(event);
69
+ };
70
+ return /* @__PURE__ */ jsxRuntime.jsx(ListNextContext.ListNextContext.Provider, {
71
+ value: contextValue,
72
+ children: /* @__PURE__ */ jsxRuntime.jsx("ul", {
73
+ ref: handleRef,
74
+ id: listId,
75
+ className: clsx.clsx(withBaseName(), className),
76
+ role: "listbox",
77
+ tabIndex: disabled ? -1 : 0,
78
+ "aria-activedescendant": disabled ? void 0 : activeDescendant,
79
+ "aria-disabled": disabled,
80
+ onFocus: handleFocus,
81
+ onKeyDown: handleKeyDown,
82
+ onBlur: handleBlur,
83
+ onMouseDown: handleMouseDown,
84
+ ...rest,
85
+ children
86
+ })
87
+ });
88
+ }
89
+ );
90
+
91
+ exports.ListNext = ListNext;
92
+ //# sourceMappingURL=ListNext.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ListNext.js","sources":["../src/list-next/ListNext.tsx"],"sourcesContent":["import { makePrefixer, useForkRef, useId } from \"@salt-ds/core\";\nimport {\n FocusEvent,\n forwardRef,\n HTMLAttributes,\n KeyboardEvent,\n MouseEvent,\n useRef,\n} from \"react\";\nimport { clsx } from \"clsx\";\nimport { useList } from \"./useList\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport listNextCss from \"./ListNext.css\";\nimport { ListNextContext } from \"./ListNextContext\";\n\nconst withBaseName = makePrefixer(\"saltListNext\");\n\nexport interface ListNextProps extends HTMLAttributes<HTMLUListElement> {\n /**\n * If true, all items in list will be disabled.\n */\n disabled?: boolean;\n /* Value for the uncontrolled version. */\n selected?: string;\n /* Initial value for the uncontrolled version. */\n defaultSelected?: string;\n}\n\nexport const ListNext = forwardRef<HTMLUListElement, ListNextProps>(\n function ListNext(\n {\n children,\n className,\n disabled,\n id,\n onSelect,\n onFocus,\n onBlur,\n onKeyDown,\n onMouseDown,\n selected,\n defaultSelected,\n ...rest\n },\n ref\n ) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-list-next\",\n css: listNextCss,\n window: targetWindow,\n });\n\n const listId = useId(id);\n const listRef = useRef<HTMLUListElement>(null);\n const handleRef = useForkRef(listRef, ref);\n\n const {\n focusHandler,\n keyDownHandler,\n blurHandler,\n mouseDownHandler,\n activeDescendant,\n contextValue,\n } = useList({\n disabled,\n selected,\n defaultSelected,\n id: listId,\n ref: listRef,\n });\n\n const handleFocus = (event: FocusEvent<HTMLUListElement>) => {\n focusHandler();\n onFocus?.(event);\n };\n\n const handleKeyDown = (event: KeyboardEvent<HTMLUListElement>) => {\n keyDownHandler(event);\n onKeyDown?.(event);\n };\n\n const handleBlur = (event: FocusEvent<HTMLUListElement>) => {\n blurHandler();\n onBlur?.(event);\n };\n\n const handleMouseDown = (event: MouseEvent<HTMLUListElement>) => {\n mouseDownHandler();\n onMouseDown?.(event);\n };\n\n return (\n <ListNextContext.Provider value={contextValue}>\n <ul\n ref={handleRef}\n id={listId}\n className={clsx(withBaseName(), className)}\n role=\"listbox\"\n tabIndex={disabled ? -1 : 0}\n aria-activedescendant={disabled ? undefined : activeDescendant}\n aria-disabled={disabled}\n onFocus={handleFocus}\n onKeyDown={handleKeyDown}\n onBlur={handleBlur}\n onMouseDown={handleMouseDown}\n {...rest}\n >\n {children}\n </ul>\n </ListNextContext.Provider>\n );\n }\n);\n"],"names":["makePrefixer","forwardRef","ListNext","useWindow","useComponentCssInjection","listNextCss","useId","useRef","useForkRef","useList","jsx","ListNextContext","clsx"],"mappings":"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"}
@@ -0,0 +1,18 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var core = require('@salt-ds/core');
6
+ var React = require('react');
7
+
8
+ const ListNextContext = core.createContext(
9
+ "ListNextContext",
10
+ void 0
11
+ );
12
+ function useListItem() {
13
+ return React.useContext(ListNextContext);
14
+ }
15
+
16
+ exports.ListNextContext = ListNextContext;
17
+ exports.useListItem = useListItem;
18
+ //# sourceMappingURL=ListNextContext.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ListNextContext.js","sources":["../src/list-next/ListNextContext.tsx"],"sourcesContent":["import { createContext } from \"@salt-ds/core\";\nimport { SyntheticEvent, useContext } from \"react\";\n\nexport interface ListNextContextValue {\n disabled?: boolean;\n id?: string;\n select: (event: SyntheticEvent<HTMLLIElement>) => void;\n isSelected: (id: string) => boolean;\n isFocused: (id: string) => boolean;\n}\n\nexport const ListNextContext = createContext<ListNextContextValue | undefined>(\n \"ListNextContext\",\n undefined\n);\n\nexport function useListItem() {\n return useContext(ListNextContext);\n}\n"],"names":["createContext","useContext"],"mappings":";;;;;;;AAWO,MAAM,eAAkB,GAAAA,kBAAA;AAAA,EAC7B,iBAAA;AAAA,EACA,KAAA,CAAA;AACF,EAAA;AAEO,SAAS,WAAc,GAAA;AAC5B,EAAA,OAAOC,iBAAW,eAAe,CAAA,CAAA;AACnC;;;;;"}
@@ -0,0 +1,188 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var React = require('react');
6
+ var core = require('@salt-ds/core');
7
+
8
+ const useList = ({
9
+ disabled = false,
10
+ selected: selectedProp,
11
+ defaultSelected,
12
+ onChange,
13
+ id,
14
+ ref
15
+ }) => {
16
+ const [activeDescendant, setActiveDescendant] = React.useState(
17
+ void 0
18
+ );
19
+ const [showFocusRing, setShowFocusRing] = React.useState(false);
20
+ const [selectedItem, setSelectedItem] = core.useControlled({
21
+ controlled: selectedProp,
22
+ default: defaultSelected,
23
+ name: "ListNext",
24
+ state: "selected"
25
+ });
26
+ const getOptions = React.useCallback(() => {
27
+ var _a, _b;
28
+ return Array.from(
29
+ (_b = (_a = ref.current) == null ? void 0 : _a.querySelectorAll('[role="option"]:not([aria-disabled])')) != null ? _b : []
30
+ );
31
+ }, [ref]);
32
+ const updateScroll = React.useCallback(
33
+ (currentTarget) => {
34
+ const list = ref.current;
35
+ if (!list || !currentTarget)
36
+ return;
37
+ const { offsetTop, offsetHeight } = currentTarget;
38
+ const listHeight = list == null ? void 0 : list.clientHeight;
39
+ const listScrollTop = list == null ? void 0 : list.scrollTop;
40
+ if (offsetTop < listScrollTop) {
41
+ list.scrollTop = offsetTop;
42
+ } else if (offsetTop + offsetHeight > listScrollTop + listHeight) {
43
+ list.scrollTop = offsetTop + offsetHeight - listHeight;
44
+ }
45
+ },
46
+ [ref]
47
+ );
48
+ const updateActiveDescendant = React.useCallback(
49
+ (element) => {
50
+ setActiveDescendant(element.id);
51
+ updateScroll(element);
52
+ },
53
+ [setActiveDescendant, updateScroll]
54
+ );
55
+ const selectItem = React.useCallback(
56
+ (element) => {
57
+ const newValue = element == null ? void 0 : element.dataset.value;
58
+ if (newValue) {
59
+ setSelectedItem(newValue);
60
+ updateActiveDescendant(element);
61
+ }
62
+ },
63
+ [setSelectedItem, updateActiveDescendant]
64
+ );
65
+ const focusAndMoveActive = (element) => {
66
+ setShowFocusRing(true);
67
+ updateActiveDescendant(element);
68
+ };
69
+ const focusFirstItem = () => {
70
+ const activeOptions = getOptions();
71
+ const firstItem = activeOptions[0];
72
+ if (firstItem) {
73
+ focusAndMoveActive(firstItem);
74
+ }
75
+ };
76
+ const focusLastItem = () => {
77
+ const activeOptions = getOptions();
78
+ const lastItem = activeOptions[activeOptions.length - 1];
79
+ if (lastItem) {
80
+ focusAndMoveActive(lastItem);
81
+ updateScroll(lastItem);
82
+ }
83
+ };
84
+ const findNextOption = (currentOption, moves) => {
85
+ const activeOptions = getOptions();
86
+ const nextOptionIndex = currentOption ? activeOptions.indexOf(currentOption) + moves : 0;
87
+ return activeOptions[nextOptionIndex] || activeOptions[activeOptions.length - 1];
88
+ };
89
+ const findPreviousOption = (currentOption, moves) => {
90
+ const activeOptions = getOptions();
91
+ const currentOptionIndex = activeOptions.findIndex(
92
+ (i) => i.id === currentOption.id
93
+ );
94
+ return activeOptions[currentOptionIndex - moves] || activeOptions[0];
95
+ };
96
+ const select = React.useCallback(
97
+ (event) => {
98
+ const newValue = event.currentTarget.dataset.value;
99
+ if (event.type === "click") {
100
+ setShowFocusRing(false);
101
+ }
102
+ const activeOptions = getOptions();
103
+ const isActiveOption = activeOptions.findIndex((i) => i.id === event.currentTarget.id) !== -1;
104
+ if (newValue && selectedItem !== newValue && isActiveOption) {
105
+ selectItem(event.currentTarget);
106
+ onChange == null ? void 0 : onChange(event, { value: newValue });
107
+ }
108
+ },
109
+ [selectItem, selectedItem, onChange, getOptions]
110
+ );
111
+ const isSelected = React.useCallback(
112
+ (id2) => selectedItem === id2,
113
+ [selectedItem]
114
+ );
115
+ const isFocused = React.useCallback(
116
+ (id2) => activeDescendant === id2 && showFocusRing,
117
+ [activeDescendant, showFocusRing]
118
+ );
119
+ const getActiveItem = () => {
120
+ const activeOptions = getOptions();
121
+ const activeIndex = activeOptions.findIndex(
122
+ (i) => i.id === activeDescendant
123
+ );
124
+ return activeOptions[activeIndex !== -1 ? activeIndex : 0];
125
+ };
126
+ const blurHandler = () => {
127
+ setShowFocusRing(false);
128
+ };
129
+ const mouseDownHandler = () => {
130
+ setShowFocusRing(false);
131
+ };
132
+ const focusHandler = () => {
133
+ const activeElement = getActiveItem();
134
+ focusAndMoveActive(activeElement);
135
+ };
136
+ const keyDownHandler = (event) => {
137
+ const { key } = event;
138
+ const currentItem = getActiveItem();
139
+ let nextItem = currentItem;
140
+ if (!currentItem) {
141
+ return;
142
+ }
143
+ switch (key) {
144
+ case "ArrowUp":
145
+ case "ArrowDown":
146
+ nextItem = key === "ArrowUp" ? findPreviousOption(currentItem, 1) : findNextOption(currentItem, 1);
147
+ if (nextItem && nextItem !== currentItem) {
148
+ event.preventDefault();
149
+ focusAndMoveActive(nextItem);
150
+ }
151
+ break;
152
+ case "Home":
153
+ event.preventDefault();
154
+ focusFirstItem();
155
+ break;
156
+ case "End":
157
+ event.preventDefault();
158
+ focusLastItem();
159
+ break;
160
+ case " ":
161
+ case "Enter":
162
+ event.preventDefault();
163
+ nextItem && selectItem(nextItem);
164
+ break;
165
+ }
166
+ };
167
+ const contextValue = React.useMemo(
168
+ () => ({
169
+ disabled,
170
+ id,
171
+ select,
172
+ isSelected,
173
+ isFocused
174
+ }),
175
+ [disabled, id, select, isSelected, isFocused]
176
+ );
177
+ return {
178
+ focusHandler,
179
+ keyDownHandler,
180
+ blurHandler,
181
+ mouseDownHandler,
182
+ activeDescendant,
183
+ contextValue
184
+ };
185
+ };
186
+
187
+ exports.useList = useList;
188
+ //# sourceMappingURL=useList.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useList.js","sources":["../src/list-next/useList.ts"],"sourcesContent":["import {\n KeyboardEvent,\n RefObject,\n SyntheticEvent,\n useCallback,\n useMemo,\n useState,\n} from \"react\";\nimport { useControlled } from \"@salt-ds/core\";\n\ninterface UseListProps {\n /**\n * If true, all items in list will be disabled.\n */\n disabled?: boolean;\n /* Value for the uncontrolled version. */\n selected?: string;\n /* Initial value for the uncontrolled version. */\n defaultSelected?: string;\n /* Callback for the controlled version. */\n onChange?: (e: SyntheticEvent, data: { value: string }) => void;\n id?: string;\n ref: RefObject<HTMLUListElement>;\n}\n\nexport const useList = ({\n disabled = false,\n selected: selectedProp,\n defaultSelected,\n onChange,\n id,\n ref,\n}: UseListProps) => {\n const [activeDescendant, setActiveDescendant] = useState<string | undefined>(\n undefined\n );\n\n const [showFocusRing, setShowFocusRing] = useState<boolean>(false);\n const [selectedItem, setSelectedItem] = useControlled({\n controlled: selectedProp,\n default: defaultSelected,\n name: \"ListNext\",\n state: \"selected\",\n });\n\n const getOptions: () => HTMLElement[] = useCallback(() => {\n return Array.from(\n ref.current?.querySelectorAll('[role=\"option\"]:not([aria-disabled])') ??\n []\n );\n }, [ref]);\n\n const updateScroll = useCallback(\n (currentTarget: Element) => {\n const list = ref.current;\n if (!list || !currentTarget) return;\n const { offsetTop, offsetHeight } = currentTarget as HTMLLIElement;\n const listHeight = list?.clientHeight;\n const listScrollTop = list?.scrollTop;\n if (offsetTop < listScrollTop) {\n list.scrollTop = offsetTop;\n } else if (offsetTop + offsetHeight > listScrollTop + listHeight) {\n list.scrollTop = offsetTop + offsetHeight - listHeight;\n }\n },\n [ref]\n );\n\n const updateActiveDescendant = useCallback(\n (element: HTMLElement) => {\n setActiveDescendant(element.id);\n updateScroll(element);\n },\n [setActiveDescendant, updateScroll]\n );\n const selectItem = useCallback(\n (element: HTMLElement) => {\n const newValue = element?.dataset.value;\n if (newValue) {\n setSelectedItem(newValue);\n updateActiveDescendant(element);\n }\n },\n [setSelectedItem, updateActiveDescendant]\n );\n\n const focusAndMoveActive = (element: HTMLElement) => {\n setShowFocusRing(true);\n updateActiveDescendant(element);\n };\n\n const focusFirstItem = () => {\n // Find first active item\n const activeOptions = getOptions();\n const firstItem = activeOptions[0];\n if (firstItem) {\n focusAndMoveActive(firstItem);\n }\n };\n const focusLastItem = () => {\n // Find last active item\n const activeOptions = getOptions();\n const lastItem = activeOptions[activeOptions.length - 1];\n if (lastItem) {\n focusAndMoveActive(lastItem);\n updateScroll(lastItem);\n }\n };\n\n const findNextOption = (\n currentOption: HTMLElement | null,\n moves: number\n ): HTMLElement => {\n const activeOptions = getOptions();\n // Returns next item, if no current option it will return 0\n const nextOptionIndex = currentOption\n ? activeOptions.indexOf(currentOption) + moves\n : 0;\n return (\n activeOptions[nextOptionIndex] || activeOptions[activeOptions.length - 1]\n );\n };\n\n const findPreviousOption = (\n currentOption: HTMLElement,\n moves: number\n ): HTMLElement => {\n // Return the previous option if it exists; otherwise, returns first option\n const activeOptions = getOptions();\n const currentOptionIndex = activeOptions.findIndex(\n (i) => i.id === currentOption.id\n );\n return activeOptions[currentOptionIndex - moves] || activeOptions[0];\n };\n\n // CONTEXT CALLBACKS\n const select = useCallback(\n (event: SyntheticEvent<HTMLLIElement>) => {\n const newValue = event.currentTarget.dataset.value;\n if (event.type === \"click\") {\n setShowFocusRing(false);\n }\n const activeOptions = getOptions();\n const isActiveOption =\n activeOptions.findIndex((i) => i.id === event.currentTarget.id) !== -1;\n if (newValue && selectedItem !== newValue && isActiveOption) {\n selectItem(event.currentTarget);\n onChange?.(event, { value: newValue });\n }\n },\n [selectItem, selectedItem, onChange, getOptions]\n );\n\n const isSelected = useCallback(\n (id: string) => selectedItem === id,\n [selectedItem]\n );\n\n const isFocused = useCallback(\n (id: string | undefined) => activeDescendant === id && showFocusRing,\n [activeDescendant, showFocusRing]\n );\n\n const getActiveItem = () => {\n const activeOptions = getOptions();\n const activeIndex = activeOptions.findIndex(\n (i) => i.id === activeDescendant\n );\n return activeOptions[activeIndex !== -1 ? activeIndex : 0];\n };\n\n // HANDLERS\n const blurHandler = () => {\n setShowFocusRing(false);\n };\n\n const mouseDownHandler = () => {\n // When list gets focused, we can't guarantee that focus happens after click event.\n // If first focus (where !activeDescendant) happens from a click, list shouldn't render focus ring in the first element.\n setShowFocusRing(false);\n };\n\n // takes care of focus when using keyboard navigation\n const focusHandler = () => {\n const activeElement = getActiveItem();\n focusAndMoveActive(activeElement);\n };\n\n // takes care of keydown when using keyboard navigation\n const keyDownHandler = (event: KeyboardEvent<HTMLUListElement>) => {\n const { key } = event;\n const currentItem = getActiveItem();\n let nextItem = currentItem;\n if (!currentItem) {\n return;\n }\n switch (key) {\n case \"ArrowUp\":\n case \"ArrowDown\":\n nextItem =\n key === \"ArrowUp\"\n ? findPreviousOption(currentItem, 1)\n : findNextOption(currentItem, 1);\n\n if (nextItem && nextItem !== currentItem) {\n event.preventDefault();\n focusAndMoveActive(nextItem);\n }\n break;\n case \"Home\":\n event.preventDefault();\n focusFirstItem();\n break;\n case \"End\":\n event.preventDefault();\n focusLastItem();\n break;\n case \" \":\n case \"Enter\":\n event.preventDefault();\n nextItem && selectItem(nextItem);\n break;\n default:\n break;\n }\n };\n\n // CONTEXT\n const contextValue = useMemo(\n () => ({\n disabled,\n id,\n select,\n isSelected,\n isFocused,\n }),\n [disabled, id, select, isSelected, isFocused]\n );\n\n return {\n focusHandler,\n keyDownHandler,\n blurHandler,\n mouseDownHandler,\n activeDescendant,\n contextValue,\n };\n};\n"],"names":["useState","useControlled","useCallback","id","useMemo"],"mappings":"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"}
@@ -1,6 +1,6 @@
1
1
  'use strict';
2
2
 
3
- var css_248z = ".salt-density-high {\n --logo-height: var(--saltLogo-logo-height, 14px);\n}\n.salt-density-medium {\n --logo-height: var(--saltLogo-logo-height, 20px);\n}\n.salt-density-low {\n --logo-height: var(--saltLogo-logo-height, 26px);\n}\n.salt-density-touch {\n --logo-height: var(--saltLogo-logo-height, 32px);\n}\n\n.saltLogo {\n --logo-color: var(--saltLogo-color, var(--salt-text-secondary-foreground));\n --logo-divider-color: var(--saltLogo-pipe-color, var(--salt-separable-secondary-borderColor));\n --logo-divider-height: var(--saltLogo-title-height, var(--salt-size-separator-height));\n --logo-divider-margin: 0 calc(var(--salt-size-unit) * 2);\n --logo-fontSize: var(--salt-text-fontSize);\n --logo-lineHeight: var(--salt-text-lineHeight);\n}\n\n.saltLogo-compact {\n --logo-pipe-margin: 0 calc(var(--salt-size-unit) * 1.5);\n}\n\n.saltLogo {\n display: inline-flex;\n position: relative;\n align-items: center;\n justify-content: center;\n height: var(--logo-height);\n}\n\n.saltLogo img {\n max-height: 100%;\n}\n\n.saltLogo-wrapper {\n display: inline-flex;\n position: relative;\n height: var(--logo-height);\n}\n\n.saltLogo-logo {\n fill: var(--logo-color);\n margin: auto;\n stroke: none !important;\n text-align: center;\n font-size: var(--logo-fontSize);\n line-height: var(--logo-lineHeight);\n}\n\n.saltLogo-appTitle {\n align-self: center;\n color: var(--logo-color);\n position: relative;\n}\n\n.saltLogo-titlePipe {\n border-right: 1px solid var(--logo-divider-color);\n margin: var(--logo-divider-margin);\n height: var(--logo-divider-height);\n}\n";
3
+ var css_248z = "/* Styles for Logo */\n.saltLogo {\n display: inline-flex;\n position: relative;\n align-items: center;\n justify-content: center;\n height: var(--salt-size-base);\n}\n\n.saltLogo svg {\n fill: var(--salt-text-secondary-foreground);\n stroke: none;\n}\n";
4
4
 
5
5
  module.exports = css_248z;
6
6
  //# sourceMappingURL=Logo.css.js.map
@@ -6,55 +6,23 @@ var jsxRuntime = require('react/jsx-runtime');
6
6
  var React = require('react');
7
7
  var clsx = require('clsx');
8
8
  var core = require('@salt-ds/core');
9
- var LogoTitle = require('./internal/LogoTitle.js');
10
9
  var window = require('@salt-ds/window');
11
10
  var styles = require('@salt-ds/styles');
12
11
  var Logo$1 = require('./Logo.css.js');
13
12
 
14
13
  const withBaseName = core.makePrefixer("saltLogo");
15
14
  const Logo = React.forwardRef(function Logo2(props, ref) {
16
- const {
17
- appTitle,
18
- className,
19
- compact,
20
- src,
21
- ImageProps,
22
- LogoImageComponent = "img",
23
- TitleProps,
24
- ...rest
25
- } = props;
15
+ const { className, ...rest } = props;
26
16
  const targetWindow = window.useWindow();
27
17
  styles.useComponentCssInjection({
28
18
  testId: "salt-logo",
29
19
  css: Logo$1,
30
20
  window: targetWindow
31
21
  });
32
- return /* @__PURE__ */ jsxRuntime.jsxs("span", {
33
- className: clsx.clsx(withBaseName(), className, {
34
- [withBaseName("compact")]: compact
35
- }),
22
+ return /* @__PURE__ */ jsxRuntime.jsx("span", {
23
+ className: clsx.clsx(withBaseName(), className),
36
24
  ref,
37
- ...rest,
38
- children: [
39
- /* @__PURE__ */ jsxRuntime.jsx("span", {
40
- className: withBaseName("wrapper"),
41
- children: /* @__PURE__ */ jsxRuntime.jsx(LogoImageComponent, {
42
- ...ImageProps,
43
- className: clsx.clsx(withBaseName("logo"), ImageProps == null ? void 0 : ImageProps.className),
44
- src,
45
- alt: (ImageProps == null ? void 0 : ImageProps.alt) || "Logo"
46
- })
47
- }),
48
- /* @__PURE__ */ jsxRuntime.jsx(LogoTitle.LogoTitle, {
49
- ...TitleProps,
50
- className: clsx.clsx(withBaseName("appTitle"), TitleProps == null ? void 0 : TitleProps.className),
51
- label: appTitle,
52
- separatorClassname: clsx.clsx(
53
- withBaseName("titlePipe"),
54
- TitleProps == null ? void 0 : TitleProps.separatorClassname
55
- )
56
- })
57
- ]
25
+ ...rest
58
26
  });
59
27
  });
60
28
 
@@ -1 +1 @@
1
- {"version":3,"file":"Logo.js","sources":["../src/logo/Logo.tsx"],"sourcesContent":["import { ComponentPropsWithoutRef, ComponentType, forwardRef } from \"react\";\nimport { clsx } from \"clsx\";\nimport { makePrefixer } from \"@salt-ds/core\";\n\nimport { LogoTitle, LogoTitleProps } from \"./internal/LogoTitle\";\n\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\n\nimport logoCss from \"./Logo.css\";\n\nexport interface LogoProps extends ComponentPropsWithoutRef<\"span\"> {\n /**\n * Used to provide application title\n */\n appTitle?: string;\n /**\n * If `true`, the logo will be compact;\n */\n compact?: boolean;\n /**\n * Props passed to the Logo.\n */\n ImageProps?: Partial<ComponentPropsWithoutRef<\"img\">>;\n /**\n * Custom Component to render the logo image.\n * e.g. if a custom renderer instead of static image using `src` prop.\n */\n LogoImageComponent?: ComponentType<Partial<ComponentPropsWithoutRef<\"img\">>>;\n /**\n * Image src for logo.\n */\n src?: string;\n /**\n * Props passed to the Application Title if used.\n * If using a custom image then ImageProps.alt should be set to include a screen reader alternative text.\n */\n TitleProps?: Omit<Partial<LogoTitleProps>, \"label\">;\n}\n\nconst withBaseName = makePrefixer(\"saltLogo\");\n\nexport const Logo = forwardRef<HTMLSpanElement, LogoProps>(function Logo(\n props,\n ref\n) {\n const {\n appTitle,\n className,\n compact,\n src,\n ImageProps,\n LogoImageComponent = \"img\",\n TitleProps,\n ...rest\n } = props;\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-logo\",\n css: logoCss,\n window: targetWindow,\n });\n\n // TODO check if we need ImageProps and TitleProps classNames interface.\n return (\n <span\n className={clsx(withBaseName(), className, {\n [withBaseName(\"compact\")]: compact,\n })}\n ref={ref}\n {...rest}\n >\n <span className={withBaseName(\"wrapper\")}>\n <LogoImageComponent\n {...ImageProps}\n className={clsx(withBaseName(\"logo\"), ImageProps?.className)}\n src={src}\n alt={ImageProps?.alt || \"Logo\"}\n />\n </span>\n <LogoTitle\n {...TitleProps}\n className={clsx(withBaseName(\"appTitle\"), TitleProps?.className)}\n label={appTitle}\n separatorClassname={clsx(\n withBaseName(\"titlePipe\"),\n TitleProps?.separatorClassname\n )}\n />\n </span>\n );\n});\n"],"names":["makePrefixer","forwardRef","Logo","useWindow","useComponentCssInjection","logoCss","jsxs","clsx","jsx","LogoTitle"],"mappings":";;;;;;;;;;;;;AAwCA,MAAM,YAAA,GAAeA,kBAAa,UAAU,CAAA,CAAA;AAErC,MAAM,IAAO,GAAAC,gBAAA,CAAuC,SAASC,KAAAA,CAClE,OACA,GACA,EAAA;AACA,EAAM,MAAA;AAAA,IACJ,QAAA;AAAA,IACA,SAAA;AAAA,IACA,OAAA;AAAA,IACA,GAAA;AAAA,IACA,UAAA;AAAA,IACA,kBAAqB,GAAA,KAAA;AAAA,IACrB,UAAA;AAAA,IACG,GAAA,IAAA;AAAA,GACD,GAAA,KAAA,CAAA;AACJ,EAAA,MAAM,eAAeC,gBAAU,EAAA,CAAA;AAC/B,EAAyBC,+BAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,WAAA;AAAA,IACR,GAAK,EAAAC,MAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AAGD,EAAA,uBACGC,eAAA,CAAA,MAAA,EAAA;AAAA,IACC,SAAW,EAAAC,SAAA,CAAK,YAAa,EAAA,EAAG,SAAW,EAAA;AAAA,MACzC,CAAC,YAAa,CAAA,SAAS,CAAI,GAAA,OAAA;AAAA,KAC5B,CAAA;AAAA,IACD,GAAA;AAAA,IACC,GAAG,IAAA;AAAA,IAEJ,QAAA,EAAA;AAAA,sBAACC,cAAA,CAAA,MAAA,EAAA;AAAA,QAAK,SAAA,EAAW,aAAa,SAAS,CAAA;AAAA,QACrC,QAAC,kBAAAA,cAAA,CAAA,kBAAA,EAAA;AAAA,UACE,GAAG,UAAA;AAAA,UACJ,WAAWD,SAAK,CAAA,YAAA,CAAa,MAAM,CAAA,EAAG,yCAAY,SAAS,CAAA;AAAA,UAC3D,GAAA;AAAA,UACA,GAAA,EAAA,CAAK,yCAAY,GAAO,KAAA,MAAA;AAAA,SAC1B,CAAA;AAAA,OACF,CAAA;AAAA,sBACCC,cAAA,CAAAC,mBAAA,EAAA;AAAA,QACE,GAAG,UAAA;AAAA,QACJ,WAAWF,SAAK,CAAA,YAAA,CAAa,UAAU,CAAA,EAAG,yCAAY,SAAS,CAAA;AAAA,QAC/D,KAAO,EAAA,QAAA;AAAA,QACP,kBAAoB,EAAAA,SAAA;AAAA,UAClB,aAAa,WAAW,CAAA;AAAA,UACxB,UAAY,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,UAAA,CAAA,kBAAA;AAAA,SACd;AAAA,OACF,CAAA;AAAA,KAAA;AAAA,GACF,CAAA,CAAA;AAEJ,CAAC;;;;"}
1
+ {"version":3,"file":"Logo.js","sources":["../src/logo/Logo.tsx"],"sourcesContent":["import { ComponentPropsWithoutRef, forwardRef } from \"react\";\nimport { clsx } from \"clsx\";\nimport { makePrefixer } from \"@salt-ds/core\";\n\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\n\nimport logoCss from \"./Logo.css\";\n\nexport type LogoProps = ComponentPropsWithoutRef<\"span\">;\n\nconst withBaseName = makePrefixer(\"saltLogo\");\n\nexport const Logo = forwardRef<HTMLSpanElement, LogoProps>(function Logo(\n props,\n ref\n) {\n const { className, ...rest } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-logo\",\n css: logoCss,\n window: targetWindow,\n });\n\n return (\n <span className={clsx(withBaseName(), className)} ref={ref} {...rest} />\n );\n});\n"],"names":["makePrefixer","forwardRef","Logo","useWindow","useComponentCssInjection","logoCss","jsx","clsx"],"mappings":";;;;;;;;;;;;AAWA,MAAM,YAAA,GAAeA,kBAAa,UAAU,CAAA,CAAA;AAErC,MAAM,IAAO,GAAAC,gBAAA,CAAuC,SAASC,KAAAA,CAClE,OACA,GACA,EAAA;AACA,EAAM,MAAA,EAAE,SAAc,EAAA,GAAA,IAAA,EAAS,GAAA,KAAA,CAAA;AAE/B,EAAA,MAAM,eAAeC,gBAAU,EAAA,CAAA;AAC/B,EAAyBC,+BAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,WAAA;AAAA,IACR,GAAK,EAAAC,MAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AAED,EAAA,uBACGC,cAAA,CAAA,MAAA,EAAA;AAAA,IAAK,SAAW,EAAAC,SAAA,CAAK,YAAa,EAAA,EAAG,SAAS,CAAA;AAAA,IAAG,GAAA;AAAA,IAAW,GAAG,IAAA;AAAA,GAAM,CAAA,CAAA;AAE1E,CAAC;;;;"}
@@ -0,0 +1,24 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var jsxRuntime = require('react/jsx-runtime');
6
+ var React = require('react');
7
+ var clsx = require('clsx');
8
+ var core = require('@salt-ds/core');
9
+
10
+ const withBaseName = core.makePrefixer("saltLogoImage");
11
+ const LogoImage = React.forwardRef(
12
+ function LogoImage2(props, ref) {
13
+ const { className, alt, ...rest } = props;
14
+ return /* @__PURE__ */ jsxRuntime.jsx("img", {
15
+ ...rest,
16
+ alt,
17
+ className: clsx.clsx(withBaseName(), className),
18
+ ref
19
+ });
20
+ }
21
+ );
22
+
23
+ exports.LogoImage = LogoImage;
24
+ //# sourceMappingURL=LogoImage.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"LogoImage.js","sources":["../src/logo/LogoImage.tsx"],"sourcesContent":["import { ComponentPropsWithoutRef, forwardRef } from \"react\";\nimport { clsx } from \"clsx\";\nimport { makePrefixer } from \"@salt-ds/core\";\n\nexport interface LogoImageProps\n extends Omit<ComponentPropsWithoutRef<\"img\">, \"alt\"> {\n alt: string;\n}\n\nconst withBaseName = makePrefixer(\"saltLogoImage\");\n\nexport const LogoImage = forwardRef<HTMLImageElement, LogoImageProps>(\n function LogoImage(props, ref) {\n const { className, alt, ...rest } = props;\n\n return (\n <img\n {...rest}\n alt={alt}\n className={clsx(withBaseName(), className)}\n ref={ref}\n />\n );\n }\n);\n"],"names":["makePrefixer","forwardRef","LogoImage","jsx","clsx"],"mappings":";;;;;;;;;AASA,MAAM,YAAA,GAAeA,kBAAa,eAAe,CAAA,CAAA;AAE1C,MAAM,SAAY,GAAAC,gBAAA;AAAA,EACvB,SAASC,UAAU,CAAA,KAAA,EAAO,GAAK,EAAA;AAC7B,IAAA,MAAM,EAAE,SAAA,EAAW,GAAQ,EAAA,GAAA,IAAA,EAAS,GAAA,KAAA,CAAA;AAEpC,IAAA,uBACGC,cAAA,CAAA,KAAA,EAAA;AAAA,MACE,GAAG,IAAA;AAAA,MACJ,GAAA;AAAA,MACA,SAAW,EAAAC,SAAA,CAAK,YAAa,EAAA,EAAG,SAAS,CAAA;AAAA,MACzC,GAAA;AAAA,KACF,CAAA,CAAA;AAAA,GAEJ;AACF;;;;"}
@@ -0,0 +1,6 @@
1
+ 'use strict';
2
+
3
+ var css_248z = "/* Styles for LogoSeparator */\n.saltLogoSeparator {\n height: var(--salt-size-separator-height);\n margin: 0 var(--salt-spacing-100);\n border-right: var(--salt-size-border) var(--salt-separable-borderStyle) var(--salt-separable-primary-borderColor);\n}\n";
4
+
5
+ module.exports = css_248z;
6
+ //# sourceMappingURL=LogoSeparator.css.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"LogoSeparator.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;"}
@@ -0,0 +1,32 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var jsxRuntime = require('react/jsx-runtime');
6
+ var React = require('react');
7
+ var clsx = require('clsx');
8
+ var core = require('@salt-ds/core');
9
+ var window = require('@salt-ds/window');
10
+ var styles = require('@salt-ds/styles');
11
+ var LogoSeparator$1 = require('./LogoSeparator.css.js');
12
+
13
+ const withBaseName = core.makePrefixer("saltLogoSeparator");
14
+ const LogoSeparator = React.forwardRef(
15
+ function LogoSeparator2(props, ref) {
16
+ const { className, ...rest } = props;
17
+ const targetWindow = window.useWindow();
18
+ styles.useComponentCssInjection({
19
+ testId: "salt-logo-separator",
20
+ css: LogoSeparator$1,
21
+ window: targetWindow
22
+ });
23
+ return /* @__PURE__ */ jsxRuntime.jsx("span", {
24
+ ...rest,
25
+ className: clsx.clsx(withBaseName(), className),
26
+ ref
27
+ });
28
+ }
29
+ );
30
+
31
+ exports.LogoSeparator = LogoSeparator;
32
+ //# sourceMappingURL=LogoSeparator.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"LogoSeparator.js","sources":["../src/logo/LogoSeparator.tsx"],"sourcesContent":["import { ComponentPropsWithoutRef, forwardRef } from \"react\";\nimport { clsx } from \"clsx\";\nimport { makePrefixer } from \"@salt-ds/core\";\n\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\n\nimport logoSeparatorCss from \"./LogoSeparator.css\";\n\nexport type LogoSeparatorProps = ComponentPropsWithoutRef<\"span\">;\n\nconst withBaseName = makePrefixer(\"saltLogoSeparator\");\n\nexport const LogoSeparator = forwardRef<HTMLImageElement, LogoSeparatorProps>(\n function LogoSeparator(props, ref) {\n const { className, ...rest } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-logo-separator\",\n css: logoSeparatorCss,\n window: targetWindow,\n });\n\n return (\n <span {...rest} className={clsx(withBaseName(), className)} ref={ref} />\n );\n }\n);\n"],"names":["makePrefixer","forwardRef","LogoSeparator","useWindow","useComponentCssInjection","logoSeparatorCss","jsx","clsx"],"mappings":";;;;;;;;;;;;AAWA,MAAM,YAAA,GAAeA,kBAAa,mBAAmB,CAAA,CAAA;AAE9C,MAAM,aAAgB,GAAAC,gBAAA;AAAA,EAC3B,SAASC,cAAc,CAAA,KAAA,EAAO,GAAK,EAAA;AACjC,IAAM,MAAA,EAAE,SAAc,EAAA,GAAA,IAAA,EAAS,GAAA,KAAA,CAAA;AAE/B,IAAA,MAAM,eAAeC,gBAAU,EAAA,CAAA;AAC/B,IAAyBC,+BAAA,CAAA;AAAA,MACvB,MAAQ,EAAA,qBAAA;AAAA,MACR,GAAK,EAAAC,eAAA;AAAA,MACL,MAAQ,EAAA,YAAA;AAAA,KACT,CAAA,CAAA;AAED,IAAA,uBACGC,cAAA,CAAA,MAAA,EAAA;AAAA,MAAM,GAAG,IAAA;AAAA,MAAM,SAAW,EAAAC,SAAA,CAAK,YAAa,EAAA,EAAG,SAAS,CAAA;AAAA,MAAG,GAAA;AAAA,KAAU,CAAA,CAAA;AAAA,GAE1E;AACF;;;;"}
@@ -7,7 +7,8 @@ var core = require('@salt-ds/core');
7
7
  var icons = require('@salt-ds/icons');
8
8
  var React = require('react');
9
9
  var ToggleButton = require('../../toggle-button/ToggleButton.js');
10
- var ToggleButtonGroup = require('../../toggle-button/ToggleButtonGroup.js');
10
+ var ToggleButtonGroup = require('../../toggle-button-group/ToggleButtonGroup.js');
11
+ require('../../toggle-button-group/ToggleButtonGroupContext.js');
11
12
  var TokenizedInput = require('../../tokenized-input/TokenizedInput.js');
12
13
  require('../../tokenized-input/TokenizedInputBase.js');
13
14
  require('clipboard-copy');
@@ -46,8 +47,8 @@ const QueryInputBody = React.forwardRef(
46
47
  value
47
48
  };
48
49
  };
49
- const onChange = (event, index) => {
50
- const newBooleanOperator = index === 0 ? "and" : "or";
50
+ const onChange = (event) => {
51
+ const newBooleanOperator = event.currentTarget.value;
51
52
  onBooleanOperatorChange(newBooleanOperator);
52
53
  };
53
54
  return /* @__PURE__ */ jsxRuntime.jsxs("div", {
@@ -76,10 +77,9 @@ const QueryInputBody = React.forwardRef(
76
77
  className: withBaseName("separator")
77
78
  }),
78
79
  /* @__PURE__ */ jsxRuntime.jsxs(ToggleButtonGroup.ToggleButtonGroup, {
79
- variant: "secondary",
80
80
  className: withBaseName("buttonGroup"),
81
81
  "data-testid": "boolean-selector",
82
- selectedIndex: booleanOperator === "and" ? 0 : 1,
82
+ value: booleanOperator,
83
83
  onChange,
84
84
  children: [
85
85
  /* @__PURE__ */ jsxRuntime.jsx(ToggleButton.ToggleButton, {
@@ -1 +1 @@
1
- {"version":3,"file":"QueryInputBody.js","sources":["../src/query-input/internal/QueryInputBody.tsx"],"sourcesContent":["import { makePrefixer } from \"@salt-ds/core\";\nimport { FilterIcon } from \"@salt-ds/icons\";\nimport {\n ChangeEventHandler,\n FocusEventHandler,\n forwardRef,\n KeyboardEventHandler,\n Ref,\n SyntheticEvent,\n useMemo,\n} from \"react\";\n\nimport {\n ToggleButton,\n ToggleButtonGroup,\n ToggleButtonGroupChangeEventHandler,\n} from \"../../toggle-button\";\nimport {\n ChangeHandler,\n StringToItem,\n TokenizedInput,\n} from \"../../tokenized-input\";\nimport { QueryInputItem } from \"../queryInputTypes\";\nimport { BooleanOperator } from \"../useQueryInput\";\n\nconst withBaseName = makePrefixer(\"saltQueryInputBody\");\n\nexport interface QueryInputBodyProps {\n inputRef: Ref<HTMLInputElement>;\n disabled?: boolean;\n showCategory?: boolean;\n selectedItems: QueryInputItem[];\n onBlur: FocusEventHandler<HTMLInputElement>;\n onFocus: FocusEventHandler<HTMLInputElement>;\n onInputFocus: FocusEventHandler<HTMLInputElement>;\n onInputBlur: FocusEventHandler<HTMLInputElement>;\n onInputClick: (event: SyntheticEvent) => void;\n onInputClear: () => void;\n inputValue?: string;\n onInputChange: ChangeEventHandler<HTMLInputElement>;\n isFocused?: boolean;\n onSelectedItemsChange: ChangeHandler<QueryInputItem>;\n onKeyDown: KeyboardEventHandler<HTMLInputElement | HTMLButtonElement>;\n booleanOperator: BooleanOperator;\n onBooleanOperatorChange: (newBooleanOperator: BooleanOperator) => void;\n}\n\nexport const QueryInputBody = forwardRef<HTMLDivElement, QueryInputBodyProps>(\n function QueryInputBody(props, ref) {\n const {\n inputRef,\n disabled,\n selectedItems,\n onInputFocus,\n onInputBlur,\n showCategory,\n inputValue,\n onInputChange,\n isFocused,\n onInputClear,\n onSelectedItemsChange,\n onKeyDown,\n onInputClick,\n booleanOperator,\n onBooleanOperatorChange,\n } = props;\n\n const itemToString = useMemo(() => {\n if (showCategory) {\n return (item: QueryInputItem) => [item.category, item.value].join(\": \");\n }\n return (item: QueryInputItem) => item.value;\n }, [showCategory]);\n\n const stringToItem: StringToItem<QueryInputItem> = (\n selectedItems,\n value\n ) => {\n return {\n category: null,\n value,\n };\n };\n\n const onChange: ToggleButtonGroupChangeEventHandler = (event, index) => {\n const newBooleanOperator = index === 0 ? \"and\" : \"or\";\n onBooleanOperatorChange(newBooleanOperator);\n };\n\n return (\n <div ref={ref} className={withBaseName()}>\n <FilterIcon />\n <TokenizedInput\n inputRef={inputRef}\n disabled={disabled}\n className={withBaseName(\"input\")}\n selectedItems={selectedItems}\n itemToString={itemToString as any}\n stringToItem={stringToItem as any}\n onInputFocus={onInputFocus}\n onInputBlur={onInputBlur}\n value={inputValue}\n onClick={onInputClick}\n onInputChange={onInputChange}\n expanded={isFocused}\n onClear={onInputClear}\n onChange={onSelectedItemsChange as any}\n onKeyDown={onKeyDown}\n />\n <div className={withBaseName(\"separator\")} />\n <ToggleButtonGroup\n variant=\"secondary\"\n className={withBaseName(\"buttonGroup\")}\n data-testid=\"boolean-selector\"\n selectedIndex={booleanOperator === \"and\" ? 0 : 1}\n onChange={onChange}\n >\n <ToggleButton value=\"and\">And</ToggleButton>\n <ToggleButton value=\"or\">Or</ToggleButton>\n </ToggleButtonGroup>\n </div>\n );\n }\n);\n"],"names":["makePrefixer","forwardRef","QueryInputBody","useMemo","selectedItems","jsxs","jsx","FilterIcon","TokenizedInput","ToggleButtonGroup","ToggleButton"],"mappings":"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"}
1
+ {"version":3,"file":"QueryInputBody.js","sources":["../src/query-input/internal/QueryInputBody.tsx"],"sourcesContent":["import { makePrefixer } from \"@salt-ds/core\";\nimport { FilterIcon } from \"@salt-ds/icons\";\nimport {\n ChangeEventHandler,\n FocusEventHandler,\n forwardRef,\n KeyboardEventHandler,\n Ref,\n SyntheticEvent,\n useMemo,\n} from \"react\";\n\nimport { ToggleButton } from \"../../toggle-button\";\nimport { ToggleButtonGroup } from \"../../toggle-button-group\";\nimport {\n ChangeHandler,\n StringToItem,\n TokenizedInput,\n} from \"../../tokenized-input\";\nimport { QueryInputItem } from \"../queryInputTypes\";\nimport { BooleanOperator } from \"../useQueryInput\";\n\nconst withBaseName = makePrefixer(\"saltQueryInputBody\");\n\nexport interface QueryInputBodyProps {\n inputRef: Ref<HTMLInputElement>;\n disabled?: boolean;\n showCategory?: boolean;\n selectedItems: QueryInputItem[];\n onBlur: FocusEventHandler<HTMLInputElement>;\n onFocus: FocusEventHandler<HTMLInputElement>;\n onInputFocus: FocusEventHandler<HTMLInputElement>;\n onInputBlur: FocusEventHandler<HTMLInputElement>;\n onInputClick: (event: SyntheticEvent) => void;\n onInputClear: () => void;\n inputValue?: string;\n onInputChange: ChangeEventHandler<HTMLInputElement>;\n isFocused?: boolean;\n onSelectedItemsChange: ChangeHandler<QueryInputItem>;\n onKeyDown: KeyboardEventHandler<HTMLInputElement | HTMLButtonElement>;\n booleanOperator: BooleanOperator;\n onBooleanOperatorChange: (newBooleanOperator: BooleanOperator) => void;\n}\n\nexport const QueryInputBody = forwardRef<HTMLDivElement, QueryInputBodyProps>(\n function QueryInputBody(props, ref) {\n const {\n inputRef,\n disabled,\n selectedItems,\n onInputFocus,\n onInputBlur,\n showCategory,\n inputValue,\n onInputChange,\n isFocused,\n onInputClear,\n onSelectedItemsChange,\n onKeyDown,\n onInputClick,\n booleanOperator,\n onBooleanOperatorChange,\n } = props;\n\n const itemToString = useMemo(() => {\n if (showCategory) {\n return (item: QueryInputItem) => [item.category, item.value].join(\": \");\n }\n return (item: QueryInputItem) => item.value;\n }, [showCategory]);\n\n const stringToItem: StringToItem<QueryInputItem> = (\n selectedItems,\n value\n ) => {\n return {\n category: null,\n value,\n };\n };\n\n const onChange = (event: SyntheticEvent<HTMLButtonElement>) => {\n const newBooleanOperator = event.currentTarget.value as BooleanOperator;\n onBooleanOperatorChange(newBooleanOperator);\n };\n\n return (\n <div ref={ref} className={withBaseName()}>\n <FilterIcon />\n <TokenizedInput\n inputRef={inputRef}\n disabled={disabled}\n className={withBaseName(\"input\")}\n selectedItems={selectedItems}\n itemToString={itemToString as any}\n stringToItem={stringToItem as any}\n onInputFocus={onInputFocus}\n onInputBlur={onInputBlur}\n value={inputValue}\n onClick={onInputClick}\n onInputChange={onInputChange}\n expanded={isFocused}\n onClear={onInputClear}\n onChange={onSelectedItemsChange as any}\n onKeyDown={onKeyDown}\n />\n <div className={withBaseName(\"separator\")} />\n <ToggleButtonGroup\n className={withBaseName(\"buttonGroup\")}\n data-testid=\"boolean-selector\"\n value={booleanOperator}\n onChange={onChange}\n >\n <ToggleButton value=\"and\">And</ToggleButton>\n <ToggleButton value=\"or\">Or</ToggleButton>\n </ToggleButtonGroup>\n </div>\n );\n }\n);\n"],"names":["makePrefixer","forwardRef","QueryInputBody","useMemo","selectedItems","jsxs","jsx","FilterIcon","TokenizedInput","ToggleButtonGroup","ToggleButton"],"mappings":";;;;;;;;;;;;;;;;;AAsBA,MAAM,YAAA,GAAeA,kBAAa,oBAAoB,CAAA,CAAA;AAsB/C,MAAM,cAAiB,GAAAC,gBAAA;AAAA,EAC5B,SAASC,eAAe,CAAA,KAAA,EAAO,GAAK,EAAA;AAClC,IAAM,MAAA;AAAA,MACJ,QAAA;AAAA,MACA,QAAA;AAAA,MACA,aAAA;AAAA,MACA,YAAA;AAAA,MACA,WAAA;AAAA,MACA,YAAA;AAAA,MACA,UAAA;AAAA,MACA,aAAA;AAAA,MACA,SAAA;AAAA,MACA,YAAA;AAAA,MACA,qBAAA;AAAA,MACA,SAAA;AAAA,MACA,YAAA;AAAA,MACA,eAAA;AAAA,MACA,uBAAA;AAAA,KACE,GAAA,KAAA,CAAA;AAEJ,IAAM,MAAA,YAAA,GAAeC,cAAQ,MAAM;AACjC,MAAA,IAAI,YAAc,EAAA;AAChB,QAAO,OAAA,CAAC,SAAyB,CAAC,IAAA,CAAK,UAAU,IAAK,CAAA,KAAK,CAAE,CAAA,IAAA,CAAK,IAAI,CAAA,CAAA;AAAA,OACxE;AACA,MAAO,OAAA,CAAC,SAAyB,IAAK,CAAA,KAAA,CAAA;AAAA,KACxC,EAAG,CAAC,YAAY,CAAC,CAAA,CAAA;AAEjB,IAAM,MAAA,YAAA,GAA6C,CACjDC,cAAAA,EACA,KACG,KAAA;AACH,MAAO,OAAA;AAAA,QACL,QAAU,EAAA,IAAA;AAAA,QACV,KAAA;AAAA,OACF,CAAA;AAAA,KACF,CAAA;AAEA,IAAM,MAAA,QAAA,GAAW,CAAC,KAA6C,KAAA;AAC7D,MAAM,MAAA,kBAAA,GAAqB,MAAM,aAAc,CAAA,KAAA,CAAA;AAC/C,MAAA,uBAAA,CAAwB,kBAAkB,CAAA,CAAA;AAAA,KAC5C,CAAA;AAEA,IAAA,uBACGC,eAAA,CAAA,KAAA,EAAA;AAAA,MAAI,GAAA;AAAA,MAAU,WAAW,YAAa,EAAA;AAAA,MACrC,QAAA,EAAA;AAAA,wBAAAC,cAAA,CAACC,gBAAW,EAAA,EAAA,CAAA;AAAA,wBACXD,cAAA,CAAAE,6BAAA,EAAA;AAAA,UACC,QAAA;AAAA,UACA,QAAA;AAAA,UACA,SAAA,EAAW,aAAa,OAAO,CAAA;AAAA,UAC/B,aAAA;AAAA,UACA,YAAA;AAAA,UACA,YAAA;AAAA,UACA,YAAA;AAAA,UACA,WAAA;AAAA,UACA,KAAO,EAAA,UAAA;AAAA,UACP,OAAS,EAAA,YAAA;AAAA,UACT,aAAA;AAAA,UACA,QAAU,EAAA,SAAA;AAAA,UACV,OAAS,EAAA,YAAA;AAAA,UACT,QAAU,EAAA,qBAAA;AAAA,UACV,SAAA;AAAA,SACF,CAAA;AAAA,wBACCF,cAAA,CAAA,KAAA,EAAA;AAAA,UAAI,SAAA,EAAW,aAAa,WAAW,CAAA;AAAA,SAAG,CAAA;AAAA,wBAC1CD,eAAA,CAAAI,mCAAA,EAAA;AAAA,UACC,SAAA,EAAW,aAAa,aAAa,CAAA;AAAA,UACrC,aAAY,EAAA,kBAAA;AAAA,UACZ,KAAO,EAAA,eAAA;AAAA,UACP,QAAA;AAAA,UAEA,QAAA,EAAA;AAAA,4BAACH,cAAA,CAAAI,yBAAA,EAAA;AAAA,cAAa,KAAM,EAAA,KAAA;AAAA,cAAM,QAAA,EAAA,KAAA;AAAA,aAAG,CAAA;AAAA,4BAC5BJ,cAAA,CAAAI,yBAAA,EAAA;AAAA,cAAa,KAAM,EAAA,IAAA;AAAA,cAAK,QAAA,EAAA,IAAA;AAAA,aAAE,CAAA;AAAA,WAAA;AAAA,SAC7B,CAAA;AAAA,OAAA;AAAA,KACF,CAAA,CAAA;AAAA,GAEJ;AACF;;;;"}
@@ -0,0 +1,49 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var jsxRuntime = require('react/jsx-runtime');
6
+ var React = require('react');
7
+ var core = require('@salt-ds/core');
8
+ var icons = require('@salt-ds/icons');
9
+ var reactOverflow = require('@fluentui/react-overflow');
10
+ require('../dropdown/DropdownBase.js');
11
+ require('../dropdown/DropdownButton.js');
12
+ var Dropdown = require('../dropdown/Dropdown.js');
13
+ require('../responsive/useResizeObserver.js');
14
+ require('../utils/useFloatingUI.js');
15
+ require('../form-field-context-legacy/FormFieldLegacyContext.js');
16
+
17
+ const OverflowMenu = React.forwardRef(
18
+ function OverflowMenu2(props, forwardedRef) {
19
+ const { tabs, ...rest } = props;
20
+ const { ref, overflowCount, isOverflowing } = reactOverflow.useOverflowMenu();
21
+ const handleRef = core.useForkRef(ref, forwardedRef);
22
+ const itemVisibility = reactOverflow.useOverflowContext(
23
+ (context) => context.itemVisibility
24
+ );
25
+ const tabList = tabs.filter(({ value }) => !itemVisibility[value]);
26
+ if (!isOverflowing)
27
+ return null;
28
+ return /* @__PURE__ */ jsxRuntime.jsx(Dropdown.Dropdown, {
29
+ "aria-label": `${overflowCount} more tabs`,
30
+ triggerComponent: /* @__PURE__ */ jsxRuntime.jsx(core.Button, {
31
+ "aria-label": "More tabs",
32
+ variant: "secondary",
33
+ role: "combobox",
34
+ children: /* @__PURE__ */ jsxRuntime.jsx(icons.OverflowMenuIcon, {
35
+ "aria-hidden": true,
36
+ style: { margin: 0 }
37
+ })
38
+ }),
39
+ width: "auto",
40
+ ref: handleRef,
41
+ source: tabList,
42
+ selected: null,
43
+ ...rest
44
+ });
45
+ }
46
+ );
47
+
48
+ exports.OverflowMenu = OverflowMenu;
49
+ //# sourceMappingURL=OverflowMenu.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"OverflowMenu.js","sources":["../src/tabs-next/OverflowMenu.tsx"],"sourcesContent":["import { forwardRef, ReactNode } from \"react\";\nimport { Button, useForkRef } from \"@salt-ds/core\";\nimport { OverflowMenuIcon } from \"@salt-ds/icons\";\n\nimport { useOverflowContext, useOverflowMenu } from \"@fluentui/react-overflow\";\nimport { Dropdown, DropdownProps } from \"../dropdown\";\n\ntype TabValue = {\n value: string;\n label: ReactNode;\n};\n\nexport interface OverflowMenuProps extends DropdownProps<TabValue> {\n tabs: TabValue[];\n}\n\nexport const OverflowMenu = forwardRef<HTMLDivElement, OverflowMenuProps>(\n function OverflowMenu(props, forwardedRef) {\n const { tabs, ...rest } = props;\n const { ref, overflowCount, isOverflowing } =\n useOverflowMenu<HTMLDivElement>();\n const handleRef = useForkRef(ref, forwardedRef);\n const itemVisibility = useOverflowContext(\n (context) => context.itemVisibility\n );\n\n const tabList = tabs.filter(({ value }) => !itemVisibility[value]);\n\n if (!isOverflowing) return null;\n\n return (\n <Dropdown<TabValue>\n aria-label={`${overflowCount} more tabs`}\n triggerComponent={\n <Button aria-label=\"More tabs\" variant=\"secondary\" role=\"combobox\">\n <OverflowMenuIcon aria-hidden style={{ margin: 0 }} />\n </Button>\n }\n width=\"auto\"\n ref={handleRef}\n source={tabList}\n selected={null}\n {...rest}\n />\n );\n }\n);\n"],"names":["forwardRef","OverflowMenu","useOverflowMenu","useForkRef","useOverflowContext","jsx","Dropdown","Button","OverflowMenuIcon"],"mappings":";;;;;;;;;;;;;;;;AAgBO,MAAM,YAAe,GAAAA,gBAAA;AAAA,EAC1B,SAASC,aAAa,CAAA,KAAA,EAAO,YAAc,EAAA;AACzC,IAAM,MAAA,EAAE,IAAS,EAAA,GAAA,IAAA,EAAS,GAAA,KAAA,CAAA;AAC1B,IAAA,MAAM,EAAE,GAAA,EAAK,aAAe,EAAA,aAAA,KAC1BC,6BAAgC,EAAA,CAAA;AAClC,IAAM,MAAA,SAAA,GAAYC,eAAW,CAAA,GAAA,EAAK,YAAY,CAAA,CAAA;AAC9C,IAAA,MAAM,cAAiB,GAAAC,gCAAA;AAAA,MACrB,CAAC,YAAY,OAAQ,CAAA,cAAA;AAAA,KACvB,CAAA;AAEA,IAAM,MAAA,OAAA,GAAU,KAAK,MAAO,CAAA,CAAC,EAAE,KAAM,EAAA,KAAM,CAAC,cAAA,CAAe,KAAM,CAAA,CAAA,CAAA;AAEjE,IAAA,IAAI,CAAC,aAAA;AAAe,MAAO,OAAA,IAAA,CAAA;AAE3B,IAAA,uBACGC,cAAA,CAAAC,iBAAA,EAAA;AAAA,MACC,cAAY,CAAG,EAAA,aAAA,CAAA,UAAA,CAAA;AAAA,MACf,kCACGD,cAAA,CAAAE,WAAA,EAAA;AAAA,QAAO,YAAW,EAAA,WAAA;AAAA,QAAY,OAAQ,EAAA,WAAA;AAAA,QAAY,IAAK,EAAA,UAAA;AAAA,QACtD,QAAC,kBAAAF,cAAA,CAAAG,sBAAA,EAAA;AAAA,UAAiB,aAAW,EAAA,IAAA;AAAA,UAAC,KAAA,EAAO,EAAE,MAAA,EAAQ,CAAE,EAAA;AAAA,SAAG,CAAA;AAAA,OACtD,CAAA;AAAA,MAEF,KAAM,EAAA,MAAA;AAAA,MACN,GAAK,EAAA,SAAA;AAAA,MACL,MAAQ,EAAA,OAAA;AAAA,MACR,QAAU,EAAA,IAAA;AAAA,MACT,GAAG,IAAA;AAAA,KACN,CAAA,CAAA;AAAA,GAEJ;AACF;;;;"}