@economic/taco 1.1.13-alpha.0 → 1.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (224) hide show
  1. package/dist/components/Group/Group.d.ts +11 -1
  2. package/dist/components/Icon/components/ChevronLeftSolid.d.ts +3 -0
  3. package/dist/components/Icon/components/ChevronRightSolid.d.ts +3 -0
  4. package/dist/components/Icon/components/index.d.ts +1 -1
  5. package/dist/components/Input/Input.d.ts +1 -1
  6. package/dist/components/Menu/Menu.d.ts +2 -2
  7. package/dist/components/Menu/components/Item.d.ts +1 -1
  8. package/dist/components/Menu/components/Link.d.ts +1 -1
  9. package/dist/components/Toast/Toast.d.ts +2 -2
  10. package/dist/components/Toast/Toaster.d.ts +2 -2
  11. package/dist/esm/components/Accordion/Accordion.js +31 -34
  12. package/dist/esm/components/Accordion/Accordion.js.map +1 -1
  13. package/dist/esm/components/Backdrop/Backdrop.js +2 -2
  14. package/dist/esm/components/Backdrop/Backdrop.js.map +1 -1
  15. package/dist/esm/components/Badge/Badge.js +14 -14
  16. package/dist/esm/components/Badge/Badge.js.map +1 -1
  17. package/dist/esm/components/Banner/Banner.js +7 -5
  18. package/dist/esm/components/Banner/Banner.js.map +1 -1
  19. package/dist/esm/components/Banner/util.js +1 -1
  20. package/dist/esm/components/Banner/util.js.map +1 -1
  21. package/dist/esm/components/Button/Button.js +12 -13
  22. package/dist/esm/components/Button/Button.js.map +1 -1
  23. package/dist/esm/components/Button/util.js +18 -23
  24. package/dist/esm/components/Button/util.js.map +1 -1
  25. package/dist/esm/components/Calendar/Calendar.js +56 -71
  26. package/dist/esm/components/Calendar/Calendar.js.map +1 -1
  27. package/dist/esm/components/Card/Card.js +13 -12
  28. package/dist/esm/components/Card/Card.js.map +1 -1
  29. package/dist/esm/components/Checkbox/Checkbox.js +15 -18
  30. package/dist/esm/components/Checkbox/Checkbox.js.map +1 -1
  31. package/dist/esm/components/Combobox/Combobox.js +23 -25
  32. package/dist/esm/components/Combobox/Combobox.js.map +1 -1
  33. package/dist/esm/components/Combobox/useCombobox.js +78 -99
  34. package/dist/esm/components/Combobox/useCombobox.js.map +1 -1
  35. package/dist/esm/components/Datepicker/Datepicker.js +48 -52
  36. package/dist/esm/components/Datepicker/Datepicker.js.map +1 -1
  37. package/dist/esm/components/Datepicker/useDatepicker.js +27 -34
  38. package/dist/esm/components/Datepicker/useDatepicker.js.map +1 -1
  39. package/dist/esm/components/Dialog/Context.js +4 -4
  40. package/dist/esm/components/Dialog/Context.js.map +1 -1
  41. package/dist/esm/components/Dialog/Dialog.js +39 -58
  42. package/dist/esm/components/Dialog/Dialog.js.map +1 -1
  43. package/dist/esm/components/Dialog/components/Content.js +39 -44
  44. package/dist/esm/components/Dialog/components/Content.js.map +1 -1
  45. package/dist/esm/components/Dialog/components/Drawer.js +3 -3
  46. package/dist/esm/components/Dialog/components/Drawer.js.map +1 -1
  47. package/dist/esm/components/Dialog/components/Extra.js +2 -2
  48. package/dist/esm/components/Dialog/components/Extra.js.map +1 -1
  49. package/dist/esm/components/Dialog/components/Trigger.js +2 -2
  50. package/dist/esm/components/Dialog/components/Trigger.js.map +1 -1
  51. package/dist/esm/components/Field/Field.js +10 -12
  52. package/dist/esm/components/Field/Field.js.map +1 -1
  53. package/dist/esm/components/Form/Form.js +6 -8
  54. package/dist/esm/components/Form/Form.js.map +1 -1
  55. package/dist/esm/components/Group/Group.js +9 -8
  56. package/dist/esm/components/Group/Group.js.map +1 -1
  57. package/dist/esm/components/Hanger/Hanger.js +27 -35
  58. package/dist/esm/components/Hanger/Hanger.js.map +1 -1
  59. package/dist/esm/components/HoverCard/HoverCard.js +8 -9
  60. package/dist/esm/components/HoverCard/HoverCard.js.map +1 -1
  61. package/dist/esm/components/Icon/Icon.js +7 -8
  62. package/dist/esm/components/Icon/Icon.js.map +1 -1
  63. package/dist/esm/components/Icon/components/ChevronLeftSolid.js +20 -0
  64. package/dist/esm/components/Icon/components/ChevronLeftSolid.js.map +1 -0
  65. package/dist/esm/components/Icon/components/ChevronRightSolid.js +20 -0
  66. package/dist/esm/components/Icon/components/ChevronRightSolid.js.map +1 -0
  67. package/dist/esm/components/Icon/components/index.js +8 -4
  68. package/dist/esm/components/Icon/components/index.js.map +1 -1
  69. package/dist/esm/components/IconButton/IconButton.js +9 -11
  70. package/dist/esm/components/IconButton/IconButton.js.map +1 -1
  71. package/dist/esm/components/Input/Input.js +25 -25
  72. package/dist/esm/components/Input/Input.js.map +1 -1
  73. package/dist/esm/components/Input/util.js +2 -2
  74. package/dist/esm/components/Input/util.js.map +1 -1
  75. package/dist/esm/components/Listbox/Listbox.js +24 -25
  76. package/dist/esm/components/Listbox/Listbox.js.map +1 -1
  77. package/dist/esm/components/Listbox/ScrollableList.js +65 -84
  78. package/dist/esm/components/Listbox/ScrollableList.js.map +1 -1
  79. package/dist/esm/components/Listbox/useListbox.js +53 -61
  80. package/dist/esm/components/Listbox/useListbox.js.map +1 -1
  81. package/dist/esm/components/Listbox/useMultiListbox.js +69 -96
  82. package/dist/esm/components/Listbox/useMultiListbox.js.map +1 -1
  83. package/dist/esm/components/Listbox/useTypeahead.js +10 -9
  84. package/dist/esm/components/Listbox/useTypeahead.js.map +1 -1
  85. package/dist/esm/components/Listbox/util.js +48 -85
  86. package/dist/esm/components/Listbox/util.js.map +1 -1
  87. package/dist/esm/components/Menu/Context.js +2 -2
  88. package/dist/esm/components/Menu/Context.js.map +1 -1
  89. package/dist/esm/components/Menu/Menu.js +16 -34
  90. package/dist/esm/components/Menu/Menu.js.map +1 -1
  91. package/dist/esm/components/Menu/components/Checkbox.js +9 -10
  92. package/dist/esm/components/Menu/components/Checkbox.js.map +1 -1
  93. package/dist/esm/components/Menu/components/Content.js +9 -11
  94. package/dist/esm/components/Menu/components/Content.js.map +1 -1
  95. package/dist/esm/components/Menu/components/Header.js +3 -3
  96. package/dist/esm/components/Menu/components/Header.js.map +1 -1
  97. package/dist/esm/components/Menu/components/Item.js +30 -31
  98. package/dist/esm/components/Menu/components/Item.js.map +1 -1
  99. package/dist/esm/components/Menu/components/Link.js +10 -11
  100. package/dist/esm/components/Menu/components/Link.js.map +1 -1
  101. package/dist/esm/components/Menu/components/RadioGroup.js +17 -19
  102. package/dist/esm/components/Menu/components/RadioGroup.js.map +1 -1
  103. package/dist/esm/components/Menu/components/Separator.js +1 -1
  104. package/dist/esm/components/Menu/components/Separator.js.map +1 -1
  105. package/dist/esm/components/Menu/components/Trigger.js +4 -4
  106. package/dist/esm/components/Menu/components/Trigger.js.map +1 -1
  107. package/dist/esm/components/Navigation/Navigation.js +35 -44
  108. package/dist/esm/components/Navigation/Navigation.js.map +1 -1
  109. package/dist/esm/components/Pagination/PageNumbers.js +23 -28
  110. package/dist/esm/components/Pagination/PageNumbers.js.map +1 -1
  111. package/dist/esm/components/Pagination/Pagination.js +39 -56
  112. package/dist/esm/components/Pagination/Pagination.js.map +1 -1
  113. package/dist/esm/components/Pagination/usePagination.js +7 -21
  114. package/dist/esm/components/Pagination/usePagination.js.map +1 -1
  115. package/dist/esm/components/Pagination/usePaginationShortcuts.js +13 -14
  116. package/dist/esm/components/Pagination/usePaginationShortcuts.js.map +1 -1
  117. package/dist/esm/components/Popover/Popover.js +29 -34
  118. package/dist/esm/components/Popover/Popover.js.map +1 -1
  119. package/dist/esm/components/Popover/Primitives.js +7 -8
  120. package/dist/esm/components/Popover/Primitives.js.map +1 -1
  121. package/dist/esm/components/Progress/Progress.js +11 -15
  122. package/dist/esm/components/Progress/Progress.js.map +1 -1
  123. package/dist/esm/components/Provider/Provider.js +13 -18
  124. package/dist/esm/components/Provider/Provider.js.map +1 -1
  125. package/dist/esm/components/RadioGroup/RadioGroup.js +45 -57
  126. package/dist/esm/components/RadioGroup/RadioGroup.js.map +1 -1
  127. package/dist/esm/components/SearchInput/SearchInput.js +10 -12
  128. package/dist/esm/components/SearchInput/SearchInput.js.map +1 -1
  129. package/dist/esm/components/Select/Select.js +30 -31
  130. package/dist/esm/components/Select/Select.js.map +1 -1
  131. package/dist/esm/components/Select/useSelect.js +69 -88
  132. package/dist/esm/components/Select/useSelect.js.map +1 -1
  133. package/dist/esm/components/Spinner/Spinner.js +12 -19
  134. package/dist/esm/components/Spinner/Spinner.js.map +1 -1
  135. package/dist/esm/components/Switch/Switch.js +9 -10
  136. package/dist/esm/components/Switch/Switch.js.map +1 -1
  137. package/dist/esm/components/Table/components/BaseTable.js +23 -30
  138. package/dist/esm/components/Table/components/BaseTable.js.map +1 -1
  139. package/dist/esm/components/Table/components/PaginatedTable.js +3 -7
  140. package/dist/esm/components/Table/components/PaginatedTable.js.map +1 -1
  141. package/dist/esm/components/Table/components/Table.js +18 -25
  142. package/dist/esm/components/Table/components/Table.js.map +1 -1
  143. package/dist/esm/components/Table/components/WindowedTable.js +89 -109
  144. package/dist/esm/components/Table/components/WindowedTable.js.map +1 -1
  145. package/dist/esm/components/Table/hooks/plugins/useRowActions.js +123 -148
  146. package/dist/esm/components/Table/hooks/plugins/useRowActions.js.map +1 -1
  147. package/dist/esm/components/Table/hooks/plugins/useRowDraggable.js +57 -61
  148. package/dist/esm/components/Table/hooks/plugins/useRowDraggable.js.map +1 -1
  149. package/dist/esm/components/Table/hooks/plugins/useRowEditing.js +39 -36
  150. package/dist/esm/components/Table/hooks/plugins/useRowEditing.js.map +1 -1
  151. package/dist/esm/components/Table/hooks/plugins/useRowSelect.js +79 -89
  152. package/dist/esm/components/Table/hooks/plugins/useRowSelect.js.map +1 -1
  153. package/dist/esm/components/Table/hooks/useRowCreation.js +29 -64
  154. package/dist/esm/components/Table/hooks/useRowCreation.js.map +1 -1
  155. package/dist/esm/components/Table/hooks/useTable.js +123 -141
  156. package/dist/esm/components/Table/hooks/useTable.js.map +1 -1
  157. package/dist/esm/components/Table/hooks/useTableKeyboardNavigation.js +23 -27
  158. package/dist/esm/components/Table/hooks/useTableKeyboardNavigation.js.map +1 -1
  159. package/dist/esm/components/Table/util/renderColumn.js +10 -10
  160. package/dist/esm/components/Table/util/renderColumn.js.map +1 -1
  161. package/dist/esm/components/Table/util/renderRow.js +37 -46
  162. package/dist/esm/components/Table/util/renderRow.js.map +1 -1
  163. package/dist/esm/components/Table/util/rowIndexPath.js +14 -16
  164. package/dist/esm/components/Table/util/rowIndexPath.js.map +1 -1
  165. package/dist/esm/components/Table/util/sortTypes.js +23 -31
  166. package/dist/esm/components/Table/util/sortTypes.js.map +1 -1
  167. package/dist/esm/components/Table/util.js +29 -41
  168. package/dist/esm/components/Table/util.js.map +1 -1
  169. package/dist/esm/components/Tabs/Tabs.js +25 -27
  170. package/dist/esm/components/Tabs/Tabs.js.map +1 -1
  171. package/dist/esm/components/Textarea/Textarea.js +11 -9
  172. package/dist/esm/components/Textarea/Textarea.js.map +1 -1
  173. package/dist/esm/components/Toast/Toast.js +27 -23
  174. package/dist/esm/components/Toast/Toast.js.map +1 -1
  175. package/dist/esm/components/Toast/Toaster.js +88 -118
  176. package/dist/esm/components/Toast/Toaster.js.map +1 -1
  177. package/dist/esm/components/Toast/util.js +2 -2
  178. package/dist/esm/components/Toast/util.js.map +1 -1
  179. package/dist/esm/components/Tooltip/Tooltip.js +7 -8
  180. package/dist/esm/components/Tooltip/Tooltip.js.map +1 -1
  181. package/dist/esm/components/Tour/Tour.js +46 -53
  182. package/dist/esm/components/Tour/Tour.js.map +1 -1
  183. package/dist/esm/components/Treeview/Treeview.js +26 -36
  184. package/dist/esm/components/Treeview/Treeview.js.map +1 -1
  185. package/dist/esm/components/VisuallyHidden/VisuallyHidden.js +1 -1
  186. package/dist/esm/components/VisuallyHidden/VisuallyHidden.js.map +1 -1
  187. package/dist/esm/index.css +1 -9
  188. package/dist/esm/index.js +1 -1
  189. package/dist/esm/primitives/Button.js +9 -13
  190. package/dist/esm/primitives/Button.js.map +1 -1
  191. package/dist/esm/utils/date.js +20 -40
  192. package/dist/esm/utils/date.js.map +1 -1
  193. package/dist/esm/utils/hooks/useBoundingClientRectListener.js +12 -20
  194. package/dist/esm/utils/hooks/useBoundingClientRectListener.js.map +1 -1
  195. package/dist/esm/utils/hooks/useDraggable.js +16 -17
  196. package/dist/esm/utils/hooks/useDraggable.js.map +1 -1
  197. package/dist/esm/utils/hooks/useDropTarget.js +7 -10
  198. package/dist/esm/utils/hooks/useDropTarget.js.map +1 -1
  199. package/dist/esm/utils/hooks/useListKeyboardNavigation.js +15 -30
  200. package/dist/esm/utils/hooks/useListKeyboardNavigation.js.map +1 -1
  201. package/dist/esm/utils/hooks/useListScrollTo.js +9 -9
  202. package/dist/esm/utils/hooks/useListScrollTo.js.map +1 -1
  203. package/dist/esm/utils/hooks/useOnClickOutside.js +6 -8
  204. package/dist/esm/utils/hooks/useOnClickOutside.js.map +1 -1
  205. package/dist/esm/utils/hooks/useProxiedRef.js +3 -3
  206. package/dist/esm/utils/hooks/useProxiedRef.js.map +1 -1
  207. package/dist/esm/utils/hooks/useTimer.js +9 -17
  208. package/dist/esm/utils/hooks/useTimer.js.map +1 -1
  209. package/dist/esm/utils/input.js +8 -12
  210. package/dist/esm/utils/input.js.map +1 -1
  211. package/dist/esm/utils/mergeRefs.js +2 -2
  212. package/dist/esm/utils/mergeRefs.js.map +1 -1
  213. package/dist/esm/utils/taillwind.js +2 -2
  214. package/dist/esm/utils/taillwind.js.map +1 -1
  215. package/dist/index.css +1 -9
  216. package/dist/taco.cjs.development.js +2368 -2883
  217. package/dist/taco.cjs.development.js.map +1 -1
  218. package/dist/taco.cjs.production.min.js +1 -1
  219. package/dist/taco.cjs.production.min.js.map +1 -1
  220. package/dist/utils/hooks/useListKeyboardNavigation.d.ts +1 -1
  221. package/package.json +4 -5
  222. package/types.json +13 -4
  223. package/dist/esm/_virtual/_rollupPluginBabelHelpers.js +0 -34
  224. package/dist/esm/_virtual/_rollupPluginBabelHelpers.js.map +0 -1
@@ -1,53 +1,52 @@
1
- import { objectWithoutPropertiesLoose as _objectWithoutPropertiesLoose, extends as _extends } from '../../_virtual/_rollupPluginBabelHelpers.js';
2
1
  import { forwardRef, createElement } from 'react';
3
2
  import cn from 'classnames';
4
3
  import { ScrollableList } from './ScrollableList.js';
5
4
  import { useListbox } from './useListbox.js';
6
5
  import { useMultiListbox } from './useMultiListbox.js';
7
6
 
8
- var _excluded = ["className"],
9
- _excluded2 = ["className"];
10
- var Listbox = /*#__PURE__*/forwardRef(function Listbox(props, ref) {
11
- var externalClassName = props.className,
12
- otherProps = _objectWithoutPropertiesLoose(props, _excluded);
13
-
14
- var _useListbox = useListbox(otherProps, ref),
15
- list = _useListbox.list,
16
- input = _useListbox.input;
17
-
18
- var className = cn('bg-white inline-flex relative w-full', externalClassName);
7
+ const Listbox = /*#__PURE__*/forwardRef(function Listbox(props, ref) {
8
+ const {
9
+ className: externalClassName,
10
+ ...otherProps
11
+ } = props;
12
+ const {
13
+ list,
14
+ input
15
+ } = useListbox(otherProps, ref);
16
+ const className = cn('bg-white inline-flex relative w-full', externalClassName);
19
17
  return createElement("span", {
20
18
  "data-taco": "listbox",
21
19
  className: className
22
20
  }, createElement(ScrollableList, Object.assign({}, list, {
23
- style: _extends({}, list.style, {
21
+ style: { ...list.style,
24
22
  maxHeight: 'calc(12rem + 2px)'
25
23
  /* (6 * option height) + listbox border */
26
24
 
27
- })
25
+ }
28
26
  })), createElement("input", Object.assign({}, input, {
29
27
  className: "hidden",
30
28
  type: "text"
31
29
  })));
32
30
  });
33
- var MultiListbox = /*#__PURE__*/forwardRef(function Listbox(props, ref) {
34
- var externalClassName = props.className,
35
- otherProps = _objectWithoutPropertiesLoose(props, _excluded2);
36
-
37
- var _useMultiListbox = useMultiListbox(otherProps, ref),
38
- list = _useMultiListbox.list,
39
- input = _useMultiListbox.input;
40
-
41
- var className = cn('bg-white inline-flex relative w-full', externalClassName);
31
+ const MultiListbox = /*#__PURE__*/forwardRef(function Listbox(props, ref) {
32
+ const {
33
+ className: externalClassName,
34
+ ...otherProps
35
+ } = props;
36
+ const {
37
+ list,
38
+ input
39
+ } = useMultiListbox(otherProps, ref);
40
+ const className = cn('bg-white inline-flex relative w-full', externalClassName);
42
41
  return createElement("span", {
43
42
  "data-taco": "listbox",
44
43
  className: className
45
44
  }, createElement(ScrollableList, Object.assign({}, list, {
46
- style: _extends({}, list.style, {
45
+ style: { ...list.style,
47
46
  maxHeight: 'calc(12rem + 2px + 2px)'
48
47
  /* (6 * option height) + listbox border + ALL_OPTIONS bottom border */
49
48
 
50
- })
49
+ }
51
50
  })), createElement("input", Object.assign({}, input, {
52
51
  className: "hidden",
53
52
  type: "text"
@@ -1 +1 @@
1
- {"version":3,"file":"Listbox.js","sources":["../../../../src/components/Listbox/Listbox.tsx"],"sourcesContent":["import * as React from 'react';\nimport cn from 'classnames';\nimport { useListbox } from './useListbox';\nimport { useMultiListbox } from './useMultiListbox';\nimport { ScrollableList, ScrollableListItemValue, ScrollableListItem } from './ScrollableList';\n\nexport type ListboxItem = ScrollableListItem;\nexport type ListboxValue = ScrollableListItemValue;\n\nexport type ListboxTexts = {\n /**\n * Text displayed in the listbox if no data provided.\n * To read more about how to provide the text, see [Provider](component:provider) component\n */\n empty: string;\n /**\n * Text displayed in the listbox to indicate the data is loading.\n * Read more about how to provide the text in [Provider](component:provider) component\n */\n loading: string;\n /**\n * The first option displayed in a multiselect listbox that selects all available options.\n * Read more about how to provide the text in [Provider](component:provider) component\n */\n allOption: string;\n};\n\nexport type ListboxProps = Pick<React.InputHTMLAttributes<HTMLInputElement>, 'onChange' | 'onFocus'> &\n Omit<React.InputHTMLAttributes<HTMLElement>, 'defaultValue' | 'onChange' | 'value'> & {\n /** Data indicating the options in listbox */\n data?: ListboxItem[];\n /**\n * Initial value of the listbox.\n * This is used when listbox is mounted, if no value is provided.\n * *Note* that listbox is a controlled component, setting this will also trigger the `onChange` event\n */\n defaultValue?: ListboxValue;\n /** Set what value should have an empty option in listbox */\n emptyValue?: ListboxValue;\n /** Draws attention to the listbox by changing its style and making it visually prominent */\n highlighted?: boolean;\n /* Whether the input is in an invalid state */\n invalid?: boolean;\n /**\n * Shows a loading indicator with a text next to it.\n * Read more about how to provide the text in [Provider](component:provider) component\n */\n loading?: boolean;\n /**\n * Value of the listbox representing the selected item.\n * It needs to be an existing value from the provided data\n */\n value?: ListboxValue;\n };\n\nexport const Listbox = React.forwardRef(function Listbox(props: ListboxProps, ref: React.Ref<HTMLInputElement>) {\n const { className: externalClassName, ...otherProps } = props;\n const { list, input } = useListbox(otherProps, ref);\n const className = cn('bg-white inline-flex relative w-full', externalClassName);\n\n return (\n <span data-taco=\"listbox\" className={className}>\n <ScrollableList\n {...list}\n style={{ ...list.style, maxHeight: 'calc(12rem + 2px)' /* (6 * option height) + listbox border */ }}\n />\n <input {...input} className=\"hidden\" type=\"text\" />\n </span>\n );\n});\n\nexport const MultiListbox = React.forwardRef(function Listbox(props: ListboxProps, ref: React.Ref<HTMLInputElement>) {\n const { className: externalClassName, ...otherProps } = props;\n const { list, input } = useMultiListbox(otherProps, ref);\n const className = cn('bg-white inline-flex relative w-full', externalClassName);\n\n return (\n <span data-taco=\"listbox\" className={className}>\n <ScrollableList\n {...list}\n style={{\n ...list.style,\n maxHeight: 'calc(12rem + 2px + 2px)' /* (6 * option height) + listbox border + ALL_OPTIONS bottom border */,\n }}\n />\n <input {...input} className=\"hidden\" type=\"text\" />\n </span>\n );\n});\n"],"names":["Listbox","React","props","ref","externalClassName","className","otherProps","useListbox","list","input","cn","ScrollableList","style","maxHeight","type","MultiListbox","useMultiListbox"],"mappings":";;;;;;;;;IAuDaA,OAAO,gBAAGC,UAAA,CAAiB,SAASD,OAAT,CAAiBE,KAAjB,EAAsCC,GAAtC;EACpC,IAAmBC,iBAAnB,GAAwDF,KAAxD,CAAQG,SAAR;MAAyCC,UAAzC,iCAAwDJ,KAAxD;;EACA,kBAAwBK,UAAU,CAACD,UAAD,EAAaH,GAAb,CAAlC;MAAQK,IAAR,eAAQA,IAAR;MAAcC,KAAd,eAAcA,KAAd;;EACA,IAAMJ,SAAS,GAAGK,EAAE,CAAC,sCAAD,EAAyCN,iBAAzC,CAApB;EAEA,OACIH,aAAA,OAAA;iBAAgB;IAAUI,SAAS,EAAEA;GAArC,EACIJ,aAAA,CAACU,cAAD,oBACQH;IACJI,KAAK,eAAOJ,IAAI,CAACI,KAAZ;MAAmBC,SAAS,EAAE;;;;IAFvC,CADJ,EAKIZ,aAAA,QAAA,oBAAWQ;IAAOJ,SAAS,EAAC;IAASS,IAAI,EAAC;IAA1C,CALJ,CADJ;AASH,CAdsB;IAgBVC,YAAY,gBAAGd,UAAA,CAAiB,SAASD,OAAT,CAAiBE,KAAjB,EAAsCC,GAAtC;EACzC,IAAmBC,iBAAnB,GAAwDF,KAAxD,CAAQG,SAAR;MAAyCC,UAAzC,iCAAwDJ,KAAxD;;EACA,uBAAwBc,eAAe,CAACV,UAAD,EAAaH,GAAb,CAAvC;MAAQK,IAAR,oBAAQA,IAAR;MAAcC,KAAd,oBAAcA,KAAd;;EACA,IAAMJ,SAAS,GAAGK,EAAE,CAAC,sCAAD,EAAyCN,iBAAzC,CAApB;EAEA,OACIH,aAAA,OAAA;iBAAgB;IAAUI,SAAS,EAAEA;GAArC,EACIJ,aAAA,CAACU,cAAD,oBACQH;IACJI,KAAK,eACEJ,IAAI,CAACI,KADP;MAEDC,SAAS,EAAE;;;;IAJnB,CADJ,EAQIZ,aAAA,QAAA,oBAAWQ;IAAOJ,SAAS,EAAC;IAASS,IAAI,EAAC;IAA1C,CARJ,CADJ;AAYH,CAjB2B;;;;"}
1
+ {"version":3,"file":"Listbox.js","sources":["../../../../src/components/Listbox/Listbox.tsx"],"sourcesContent":["import * as React from 'react';\nimport cn from 'classnames';\nimport { useListbox } from './useListbox';\nimport { useMultiListbox } from './useMultiListbox';\nimport { ScrollableList, ScrollableListItemValue, ScrollableListItem } from './ScrollableList';\n\nexport type ListboxItem = ScrollableListItem;\nexport type ListboxValue = ScrollableListItemValue;\n\nexport type ListboxTexts = {\n /**\n * Text displayed in the listbox if no data provided.\n * To read more about how to provide the text, see [Provider](component:provider) component\n */\n empty: string;\n /**\n * Text displayed in the listbox to indicate the data is loading.\n * Read more about how to provide the text in [Provider](component:provider) component\n */\n loading: string;\n /**\n * The first option displayed in a multiselect listbox that selects all available options.\n * Read more about how to provide the text in [Provider](component:provider) component\n */\n allOption: string;\n};\n\nexport type ListboxProps = Pick<React.InputHTMLAttributes<HTMLInputElement>, 'onChange' | 'onFocus'> &\n Omit<React.InputHTMLAttributes<HTMLElement>, 'defaultValue' | 'onChange' | 'value'> & {\n /** Data indicating the options in listbox */\n data?: ListboxItem[];\n /**\n * Initial value of the listbox.\n * This is used when listbox is mounted, if no value is provided.\n * *Note* that listbox is a controlled component, setting this will also trigger the `onChange` event\n */\n defaultValue?: ListboxValue;\n /** Set what value should have an empty option in listbox */\n emptyValue?: ListboxValue;\n /** Draws attention to the listbox by changing its style and making it visually prominent */\n highlighted?: boolean;\n /* Whether the input is in an invalid state */\n invalid?: boolean;\n /**\n * Shows a loading indicator with a text next to it.\n * Read more about how to provide the text in [Provider](component:provider) component\n */\n loading?: boolean;\n /**\n * Value of the listbox representing the selected item.\n * It needs to be an existing value from the provided data\n */\n value?: ListboxValue;\n };\n\nexport const Listbox = React.forwardRef(function Listbox(props: ListboxProps, ref: React.Ref<HTMLInputElement>) {\n const { className: externalClassName, ...otherProps } = props;\n const { list, input } = useListbox(otherProps, ref);\n const className = cn('bg-white inline-flex relative w-full', externalClassName);\n\n return (\n <span data-taco=\"listbox\" className={className}>\n <ScrollableList\n {...list}\n style={{ ...list.style, maxHeight: 'calc(12rem + 2px)' /* (6 * option height) + listbox border */ }}\n />\n <input {...input} className=\"hidden\" type=\"text\" />\n </span>\n );\n});\n\nexport const MultiListbox = React.forwardRef(function Listbox(props: ListboxProps, ref: React.Ref<HTMLInputElement>) {\n const { className: externalClassName, ...otherProps } = props;\n const { list, input } = useMultiListbox(otherProps, ref);\n const className = cn('bg-white inline-flex relative w-full', externalClassName);\n\n return (\n <span data-taco=\"listbox\" className={className}>\n <ScrollableList\n {...list}\n style={{\n ...list.style,\n maxHeight: 'calc(12rem + 2px + 2px)' /* (6 * option height) + listbox border + ALL_OPTIONS bottom border */,\n }}\n />\n <input {...input} className=\"hidden\" type=\"text\" />\n </span>\n );\n});\n"],"names":["Listbox","React","props","ref","className","externalClassName","otherProps","list","input","useListbox","cn","ScrollableList","style","maxHeight","type","MultiListbox","useMultiListbox"],"mappings":";;;;;;MAuDaA,OAAO,gBAAGC,UAAA,CAAiB,SAASD,OAAT,CAAiBE,KAAjB,EAAsCC,GAAtC;EACpC,MAAM;IAAEC,SAAS,EAAEC,iBAAb;IAAgC,GAAGC;MAAeJ,KAAxD;EACA,MAAM;IAAEK,IAAF;IAAQC;MAAUC,UAAU,CAACH,UAAD,EAAaH,GAAb,CAAlC;EACA,MAAMC,SAAS,GAAGM,EAAE,CAAC,sCAAD,EAAyCL,iBAAzC,CAApB;EAEA,OACIJ,aAAA,OAAA;iBAAgB;IAAUG,SAAS,EAAEA;GAArC,EACIH,aAAA,CAACU,cAAD,oBACQJ;IACJK,KAAK,EAAE,EAAE,GAAGL,IAAI,CAACK,KAAV;MAAiBC,SAAS,EAAE;;;;IAFvC,CADJ,EAKIZ,aAAA,QAAA,oBAAWO;IAAOJ,SAAS,EAAC;IAASU,IAAI,EAAC;IAA1C,CALJ,CADJ;AASH,CAdsB;MAgBVC,YAAY,gBAAGd,UAAA,CAAiB,SAASD,OAAT,CAAiBE,KAAjB,EAAsCC,GAAtC;EACzC,MAAM;IAAEC,SAAS,EAAEC,iBAAb;IAAgC,GAAGC;MAAeJ,KAAxD;EACA,MAAM;IAAEK,IAAF;IAAQC;MAAUQ,eAAe,CAACV,UAAD,EAAaH,GAAb,CAAvC;EACA,MAAMC,SAAS,GAAGM,EAAE,CAAC,sCAAD,EAAyCL,iBAAzC,CAApB;EAEA,OACIJ,aAAA,OAAA;iBAAgB;IAAUG,SAAS,EAAEA;GAArC,EACIH,aAAA,CAACU,cAAD,oBACQJ;IACJK,KAAK,EAAE,EACH,GAAGL,IAAI,CAACK,KADL;MAEHC,SAAS,EAAE;;;;IAJnB,CADJ,EAQIZ,aAAA,QAAA,oBAAWO;IAAOJ,SAAS,EAAC;IAASU,IAAI,EAAC;IAA1C,CARJ,CADJ;AAYH,CAjB2B;;;;"}
@@ -1,4 +1,3 @@
1
- import { objectWithoutPropertiesLoose as _objectWithoutPropertiesLoose, extends as _extends } from '../../_virtual/_rollupPluginBabelHelpers.js';
2
1
  import { forwardRef, useMemo, createRef, useEffect, createElement } from 'react';
3
2
  import cn from 'classnames';
4
3
  import { Spinner } from '../Spinner/Spinner.js';
@@ -6,17 +5,13 @@ import { useLocalization } from '../Provider/Provider.js';
6
5
  import { Checkbox } from '../Checkbox/Checkbox.js';
7
6
  import { useProxiedRef } from '../../utils/hooks/useProxiedRef.js';
8
7
  import { getInputClasses } from '../Input/util.js';
9
- import { getNextIndexFromKeycode } from '../../utils/hooks/useListKeyboardNavigation.js';
8
+ import { getNextIndexFromKey } from '../../utils/hooks/useListKeyboardNavigation.js';
10
9
  import { useListScrollTo } from '../../utils/hooks/useListScrollTo.js';
11
10
 
12
- var _excluded = ["data", "disabled", "highlighted", "id", "invalid", "loading", "onChange", "onClick", "onFocus", "onKeyDown", "readOnly", "scrollOnFocus", "value", "multiselect", "selectedIndexes", "allOptionsSelected"],
13
- _excluded2 = ["children", "icon"];
14
- var getId = function getId(id, value) {
15
- return id + "_" + value;
16
- };
11
+ const getId = (id, value) => `${id}_${value}`;
17
12
 
18
- var getNextEnabledItem = function getNextEnabledItem(event, data, index) {
19
- var nextIndex = getNextIndexFromKeycode(event.keyCode, data.length, index);
13
+ const getNextEnabledItem = (event, data, index) => {
14
+ const nextIndex = getNextIndexFromKey(event.key, data.length, index);
20
15
 
21
16
  if (nextIndex) {
22
17
  if (nextIndex === index) {
@@ -29,40 +24,35 @@ var getNextEnabledItem = function getNextEnabledItem(event, data, index) {
29
24
  return nextIndex;
30
25
  };
31
26
 
32
- var ScrollableList = /*#__PURE__*/forwardRef(function ScrollableList(props, ref) {
33
- var data = props.data,
34
- disabled = props.disabled,
35
- id = props.id,
36
- loading = props.loading,
37
- setCurrentIndex = props.onChange,
38
- onClick = props.onClick,
39
- onFocus = props.onFocus,
40
- onKeyDown = props.onKeyDown,
41
- readOnly = props.readOnly,
42
- _props$scrollOnFocus = props.scrollOnFocus,
43
- scrollOnFocus = _props$scrollOnFocus === void 0 ? false : _props$scrollOnFocus,
44
- currentIndex = props.value,
45
- multiselect = props.multiselect,
46
- _props$selectedIndexe = props.selectedIndexes,
47
- selectedIndexes = _props$selectedIndexe === void 0 ? [] : _props$selectedIndexe,
48
- _props$allOptionsSele = props.allOptionsSelected,
49
- allOptionsSelected = _props$allOptionsSele === void 0 ? false : _props$allOptionsSele,
50
- otherProps = _objectWithoutPropertiesLoose(props, _excluded);
51
-
52
- var listRef = useProxiedRef(ref);
53
- var itemRefs = useMemo(function () {
54
- return data.map(function () {
55
- return createRef();
56
- });
57
- }, [data]);
58
-
59
- var _useLocalization = useLocalization(),
60
- texts = _useLocalization.texts;
61
-
62
- var _useListScrollTo = useListScrollTo(listRef, itemRefs),
63
- scrollTo = _useListScrollTo.scrollTo;
64
-
65
- useEffect(function () {
27
+ const ScrollableList = /*#__PURE__*/forwardRef(function ScrollableList(props, ref) {
28
+ const {
29
+ data,
30
+ disabled,
31
+ highlighted,
32
+ id,
33
+ invalid: _,
34
+ loading,
35
+ onChange: setCurrentIndex,
36
+ onClick,
37
+ onFocus,
38
+ onKeyDown,
39
+ readOnly,
40
+ scrollOnFocus = false,
41
+ value: currentIndex,
42
+ multiselect,
43
+ selectedIndexes = [],
44
+ allOptionsSelected = false,
45
+ ...otherProps
46
+ } = props;
47
+ const listRef = useProxiedRef(ref);
48
+ const itemRefs = useMemo(() => data.map(() => createRef()), [data]);
49
+ const {
50
+ texts
51
+ } = useLocalization();
52
+ const {
53
+ scrollTo
54
+ } = useListScrollTo(listRef, itemRefs);
55
+ useEffect(() => {
66
56
  var _itemRefs$currentInde;
67
57
 
68
58
  if (currentIndex && (_itemRefs$currentInde = itemRefs[currentIndex]) !== null && _itemRefs$currentInde !== void 0 && _itemRefs$currentInde.current) {
@@ -73,12 +63,12 @@ var ScrollableList = /*#__PURE__*/forwardRef(function ScrollableList(props, ref)
73
63
  });
74
64
  }
75
65
  }, []);
76
- useEffect(function () {
66
+ useEffect(() => {
77
67
  scrollTo(currentIndex);
78
68
  }, [currentIndex]);
79
69
 
80
- var handleKeyDown = function handleKeyDown(event) {
81
- var nextIndex = getNextEnabledItem(event, data, currentIndex);
70
+ const handleKeyDown = event => {
71
+ const nextIndex = getNextEnabledItem(event, data, currentIndex);
82
72
 
83
73
  if (nextIndex !== undefined && nextIndex !== currentIndex) {
84
74
  event.preventDefault();
@@ -88,23 +78,21 @@ var ScrollableList = /*#__PURE__*/forwardRef(function ScrollableList(props, ref)
88
78
 
89
79
  if (onKeyDown) {
90
80
  event.persist();
91
- var index = nextIndex !== undefined ? nextIndex : currentIndex;
81
+ const index = nextIndex !== undefined ? nextIndex : currentIndex;
92
82
  onKeyDown(event, index);
93
83
  }
94
84
  };
95
85
 
96
- var handleClick = function handleClick(index) {
97
- return function (event) {
98
- setCurrentIndex(index);
86
+ const handleClick = index => event => {
87
+ setCurrentIndex(index);
99
88
 
100
- if (onClick) {
101
- event.persist();
102
- onClick(event, index);
103
- }
104
- };
89
+ if (onClick) {
90
+ event.persist();
91
+ onClick(event, index);
92
+ }
105
93
  };
106
94
 
107
- var handleFocus = function handleFocus(event) {
95
+ const handleFocus = event => {
108
96
  if (scrollOnFocus) {
109
97
  scrollTo(currentIndex);
110
98
  }
@@ -115,36 +103,33 @@ var ScrollableList = /*#__PURE__*/forwardRef(function ScrollableList(props, ref)
115
103
  }
116
104
  };
117
105
 
118
- var getOptionCheckedState = function getOptionCheckedState(optionValue, index) {
106
+ const getOptionCheckedState = (optionValue, index) => {
119
107
  if (optionValue === '#ALL-OPTIONS#') {
120
108
  return allOptionsSelected;
121
109
  } else if (!optionValue || !selectedIndexes) {
122
110
  return false;
123
111
  } else {
124
- return selectedIndexes.findIndex(function (i) {
125
- return i === index;
126
- }) !== -1;
112
+ return selectedIndexes.findIndex(i => i === index) !== -1;
127
113
  }
128
114
  };
129
115
 
130
- var list = _extends({}, otherProps, {
116
+ const list = { ...otherProps,
131
117
  className: cn('inline-flex flex-col list-none !p-0 m-0 overflow-y-auto h-auto', getInputClasses(props), {
132
118
  'yt-list--multiselect': multiselect,
133
119
  'pointer-events-none': disabled,
134
120
  'cursor-not-allowed': disabled || readOnly
135
121
  }, otherProps.className),
136
- disabled: disabled,
137
- id: id,
122
+ disabled,
123
+ id,
138
124
  onFocus: !disabled && !readOnly ? handleFocus : undefined,
139
125
  onKeyDown: !disabled && !readOnly ? handleKeyDown : undefined,
140
- readOnly: readOnly,
126
+ readOnly,
141
127
  ref: listRef,
142
128
  role: 'listbox',
143
129
  tabIndex: otherProps.tabIndex || 0
144
- });
145
-
146
- var options = data.map(function (option, index) {
147
- var depth = option.path ? option.path.split('.').length - 1 : 0;
130
+ };
131
+ const options = data.map((option, index) => {
132
+ const depth = option.path ? option.path.split('.').length - 1 : 0;
148
133
  return {
149
134
  'aria-selected': multiselect ? getOptionCheckedState(String(option.value), index) : currentIndex === index,
150
135
  'data-focused': currentIndex === index,
@@ -160,7 +145,7 @@ var ScrollableList = /*#__PURE__*/forwardRef(function ScrollableList(props, ref)
160
145
  ref: itemRefs[index],
161
146
  role: 'option',
162
147
  style: depth > 0 ? {
163
- paddingLeft: depth + 1 + "rem"
148
+ paddingLeft: `${depth + 1}rem`
164
149
  } : undefined
165
150
  };
166
151
  });
@@ -170,21 +155,17 @@ var ScrollableList = /*#__PURE__*/forwardRef(function ScrollableList(props, ref)
170
155
  className: "yt-list__empty"
171
156
  }, createElement("span", null, createElement(Spinner, {
172
157
  delay: 0
173
- })), createElement("span", null, texts.listbox.loading)) : options.length ? options.map(function (_ref) {
174
- var children = _ref.children,
175
- icon = _ref.icon,
176
- optionProps = _objectWithoutPropertiesLoose(_ref, _excluded2);
177
-
178
- return createElement("li", Object.assign({}, optionProps), icon, createElement("span", {
179
- className: "flex-grow truncate text-left"
180
- }, children), multiselect && createElement(Checkbox, {
181
- checked: optionProps['aria-selected'],
182
- onChange: function onChange() {
183
- return null;
184
- },
185
- className: "pointer-events-none ml-2 self-center p-px"
186
- }));
187
- }) : createElement("li", {
158
+ })), createElement("span", null, texts.listbox.loading)) : options.length ? options.map(({
159
+ children,
160
+ icon,
161
+ ...optionProps
162
+ }) => createElement("li", Object.assign({}, optionProps), icon, createElement("span", {
163
+ className: "flex-grow truncate text-left"
164
+ }, children), multiselect && createElement(Checkbox, {
165
+ checked: optionProps['aria-selected'],
166
+ onChange: () => null,
167
+ className: "pointer-events-none ml-2 self-center p-px"
168
+ }))) : createElement("li", {
188
169
  className: "yt-list__empty"
189
170
  }, createElement("span", null, texts.listbox.empty)));
190
171
  });
@@ -1 +1 @@
1
- {"version":3,"file":"ScrollableList.js","sources":["../../../../src/components/Listbox/ScrollableList.tsx"],"sourcesContent":["import * as React from 'react';\nimport cn from 'classnames';\nimport { useProxiedRef } from '../../utils/hooks/useProxiedRef';\nimport { getNextIndexFromKeycode } from '../../utils/hooks/useListKeyboardNavigation';\nimport { useListScrollTo } from '../../utils/hooks/useListScrollTo';\nimport './ScrollableList.css';\nimport { Spinner } from '../Spinner/Spinner';\nimport { useLocalization } from '../Provider/Provider';\nimport { Checkbox } from '../Checkbox/Checkbox';\nimport { getInputClasses } from '../Input/util';\n\nexport type ScrollableListItemValue = string | number | boolean | null;\n\nexport type ScrollableListItem = {\n /**\n * Set whether the item is disabled.\n * This will both change the style and make the item unselectable\n */\n disabled?: boolean;\n /* Specifies whether the item has child items -- intended for internal use only */\n hasChildren?: boolean;\n /** Place an icon before the item's text */\n icon?: React.ReactElement;\n /* The index path to the item -- intended for internal use only */\n path?: string;\n /** Text describing the item */\n text: string | JSX.Element;\n /** Value of the item */\n value: ScrollableListItemValue;\n /** Child items to show hierarchical data */\n children?: ScrollableListItem[];\n};\n\n/** @internal */\nexport type ScrollableListProps = Omit<\n React.HTMLAttributes<HTMLUListElement>,\n 'defaultValue' | 'id' | 'onChange' | 'onClick' | 'onKeyDown'\n> & {\n /** Data indicating the options in scrollable list */\n data: ScrollableListItem[];\n /** Sets the list to be disabled */\n disabled?: boolean;\n /** Draws attention to the scrollable list by changing its style and making it visually prominent */\n highlighted?: boolean;\n /** Set an id for the scrollable list */\n id: string;\n /* Whether the input is in an invalid state */\n invalid?: boolean;\n /**\n * Shows a loading indicator with a text next to it.\n * Read more about how to provide the text in `Provider` component.\n */\n loading?: boolean;\n /**\n * Handler called when current active/selected option changes in a scrollable list.\n * @param index indicates the index of the current active option\n */\n onChange: (index: number) => void;\n /** Handler called when option is clicked */\n onClick?: (event: React.MouseEvent<HTMLLIElement>, index: number) => void;\n /**\n * Set whether the selected item should be scrolled into view when listbox is focused.\n * Default value is `false`\n */\n scrollOnFocus?: boolean;\n /** Handler called when a key is pressed */\n onKeyDown?: (event: React.KeyboardEvent<HTMLUListElement>, index: number | undefined) => void;\n /* Sets the list to read only mode */\n readOnly?: boolean;\n /**\n * Value of the scrollable list representing the selected item.\n * It needs to be an existing value from the provided data.\n */\n value: number | undefined;\n /**\n * Allows to select multiple items from the list\n */\n multiselect?: boolean;\n /**\n * Contains the currently selected values when multiselect mode is ON.\n */\n selectedIndexes?: number[];\n /**\n * True when all available (not disabled) options are selected\n */\n allOptionsSelected?: boolean;\n};\n\n/** @internal */\nexport type ScrollableListPropsWithRef = ScrollableListProps & React.RefAttributes<HTMLUListElement>;\n\nexport const getId = (id: string, value: ScrollableListItemValue): string => `${id}_${value}`;\n\nconst getNextEnabledItem = (\n event: React.KeyboardEvent<HTMLElement>,\n data: ScrollableListItem[],\n index: number | undefined\n): number | undefined => {\n const nextIndex = getNextIndexFromKeycode(event.keyCode, data.length, index);\n\n if (nextIndex) {\n if (nextIndex === index) {\n return index;\n } else if (data[nextIndex] && data[nextIndex].disabled) {\n return getNextEnabledItem(event, data, nextIndex);\n }\n }\n\n return nextIndex;\n};\n\nexport const ScrollableList = React.forwardRef(function ScrollableList(\n props: ScrollableListProps,\n ref: React.Ref<HTMLUListElement>\n) {\n const {\n data,\n disabled,\n highlighted,\n id,\n invalid: _,\n loading,\n onChange: setCurrentIndex,\n onClick,\n onFocus,\n onKeyDown,\n readOnly,\n scrollOnFocus = false,\n value: currentIndex,\n multiselect,\n selectedIndexes = [],\n allOptionsSelected = false,\n ...otherProps\n } = props;\n const listRef = useProxiedRef<HTMLUListElement>(ref);\n const itemRefs = React.useMemo(() => data.map(() => React.createRef<HTMLLIElement>()), [data]);\n const { texts } = useLocalization();\n const { scrollTo } = useListScrollTo(listRef, itemRefs);\n\n React.useEffect(() => {\n if (currentIndex && itemRefs[currentIndex]?.current) {\n itemRefs[currentIndex].current?.scrollIntoView({\n block: 'center',\n });\n }\n }, []);\n\n React.useEffect(() => {\n scrollTo(currentIndex);\n }, [currentIndex]);\n\n const handleKeyDown = (event: React.KeyboardEvent<HTMLUListElement>): void => {\n const nextIndex = getNextEnabledItem(event, data, currentIndex);\n\n if (nextIndex !== undefined && nextIndex !== currentIndex) {\n event.preventDefault();\n scrollTo(nextIndex);\n setCurrentIndex(nextIndex);\n }\n\n if (onKeyDown) {\n event.persist();\n const index = nextIndex !== undefined ? nextIndex : currentIndex;\n onKeyDown(event, index);\n }\n };\n\n const handleClick = (index: number) => (event: React.MouseEvent<HTMLLIElement>) => {\n setCurrentIndex(index);\n\n if (onClick) {\n event.persist();\n onClick(event, index);\n }\n };\n\n const handleFocus = (event: React.FocusEvent<HTMLUListElement>): void => {\n if (scrollOnFocus) {\n scrollTo(currentIndex);\n }\n\n if (onFocus) {\n event.persist();\n onFocus(event);\n }\n };\n\n const getOptionCheckedState = (optionValue: string, index: number): boolean => {\n if (optionValue === '#ALL-OPTIONS#') {\n return allOptionsSelected;\n } else if (!optionValue || !selectedIndexes) {\n return false;\n } else {\n return selectedIndexes.findIndex(i => i === index) !== -1;\n }\n };\n\n const list: React.HTMLAttributes<HTMLUListElement> &\n React.RefAttributes<HTMLUListElement> & { disabled?: boolean; readOnly?: boolean } = {\n ...otherProps,\n className: cn(\n 'inline-flex flex-col list-none !p-0 m-0 overflow-y-auto h-auto',\n getInputClasses(props),\n {\n 'yt-list--multiselect': multiselect,\n 'pointer-events-none': disabled,\n 'cursor-not-allowed': disabled || readOnly,\n },\n otherProps.className\n ),\n disabled,\n id,\n onFocus: !disabled && !readOnly ? handleFocus : undefined,\n onKeyDown: !disabled && !readOnly ? handleKeyDown : undefined,\n readOnly,\n ref: listRef,\n role: 'listbox',\n tabIndex: otherProps.tabIndex || 0,\n };\n\n const options = data.map((option, index) => {\n const depth = option.path ? option.path.split('.').length - 1 : 0;\n\n return {\n 'aria-selected': multiselect ? getOptionCheckedState(String(option.value), index) : currentIndex === index,\n 'data-focused': currentIndex === index,\n children: option.text,\n className: cn(\n 'flex items-center px-3 w-full cursor-pointer bg-white flex-[0_0_2rem] focus:wcag-blue focus:border-blue',\n {\n 'sticky top-0 font-bold': depth === 0 && !!option.hasChildren,\n }\n ),\n disabled: option.disabled,\n icon: option.icon,\n id: getId(id, option.value),\n key: getId(id, option.value),\n onClick: !disabled && !readOnly ? handleClick(index) : undefined,\n ref: itemRefs[index],\n role: 'option',\n style:\n depth > 0\n ? {\n paddingLeft: `${depth + 1}rem`,\n }\n : undefined,\n };\n });\n\n return (\n <ul {...list} data-taco=\"scrollable-list\">\n {loading ? (\n <li className=\"yt-list__empty\">\n <span>\n <Spinner delay={0} />\n </span>\n <span>{texts.listbox.loading}</span>\n </li>\n ) : options.length ? (\n options.map(({ children, icon, ...optionProps }) => (\n <li {...optionProps}>\n {icon}\n <span className=\"flex-grow truncate text-left\">{children}</span>\n {multiselect && (\n <Checkbox\n checked={optionProps['aria-selected']}\n onChange={() => null}\n className=\"pointer-events-none ml-2 self-center p-px\"\n />\n )}\n </li>\n ))\n ) : (\n <li className=\"yt-list__empty\">\n <span>{texts.listbox.empty}</span>\n </li>\n )}\n </ul>\n );\n});\n"],"names":["getId","id","value","getNextEnabledItem","event","data","index","nextIndex","getNextIndexFromKeycode","keyCode","length","disabled","ScrollableList","React","props","ref","loading","setCurrentIndex","onChange","onClick","onFocus","onKeyDown","readOnly","scrollOnFocus","currentIndex","multiselect","selectedIndexes","allOptionsSelected","otherProps","listRef","useProxiedRef","itemRefs","map","useLocalization","texts","useListScrollTo","scrollTo","current","scrollIntoView","block","handleKeyDown","undefined","preventDefault","persist","handleClick","handleFocus","getOptionCheckedState","optionValue","findIndex","i","list","className","cn","getInputClasses","role","tabIndex","options","option","depth","path","split","String","children","text","hasChildren","icon","key","style","paddingLeft","Spinner","delay","listbox","optionProps","Checkbox","checked","empty"],"mappings":"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"}
1
+ {"version":3,"file":"ScrollableList.js","sources":["../../../../src/components/Listbox/ScrollableList.tsx"],"sourcesContent":["import * as React from 'react';\nimport cn from 'classnames';\nimport { useProxiedRef } from '../../utils/hooks/useProxiedRef';\nimport { getNextIndexFromKey } from '../../utils/hooks/useListKeyboardNavigation';\nimport { useListScrollTo } from '../../utils/hooks/useListScrollTo';\nimport './ScrollableList.css';\nimport { Spinner } from '../Spinner/Spinner';\nimport { useLocalization } from '../Provider/Provider';\nimport { Checkbox } from '../Checkbox/Checkbox';\nimport { getInputClasses } from '../Input/util';\n\nexport type ScrollableListItemValue = string | number | boolean | null;\n\nexport type ScrollableListItem = {\n /**\n * Set whether the item is disabled.\n * This will both change the style and make the item unselectable\n */\n disabled?: boolean;\n /* Specifies whether the item has child items -- intended for internal use only */\n hasChildren?: boolean;\n /** Place an icon before the item's text */\n icon?: React.ReactElement;\n /* The index path to the item -- intended for internal use only */\n path?: string;\n /** Text describing the item */\n text: string | JSX.Element;\n /** Value of the item */\n value: ScrollableListItemValue;\n /** Child items to show hierarchical data */\n children?: ScrollableListItem[];\n};\n\n/** @internal */\nexport type ScrollableListProps = Omit<\n React.HTMLAttributes<HTMLUListElement>,\n 'defaultValue' | 'id' | 'onChange' | 'onClick' | 'onKeyDown'\n> & {\n /** Data indicating the options in scrollable list */\n data: ScrollableListItem[];\n /** Sets the list to be disabled */\n disabled?: boolean;\n /** Draws attention to the scrollable list by changing its style and making it visually prominent */\n highlighted?: boolean;\n /** Set an id for the scrollable list */\n id: string;\n /* Whether the input is in an invalid state */\n invalid?: boolean;\n /**\n * Shows a loading indicator with a text next to it.\n * Read more about how to provide the text in `Provider` component.\n */\n loading?: boolean;\n /**\n * Handler called when current active/selected option changes in a scrollable list.\n * @param index indicates the index of the current active option\n */\n onChange: (index: number) => void;\n /** Handler called when option is clicked */\n onClick?: (event: React.MouseEvent<HTMLLIElement>, index: number) => void;\n /**\n * Set whether the selected item should be scrolled into view when listbox is focused.\n * Default value is `false`\n */\n scrollOnFocus?: boolean;\n /** Handler called when a key is pressed */\n onKeyDown?: (event: React.KeyboardEvent<HTMLUListElement>, index: number | undefined) => void;\n /* Sets the list to read only mode */\n readOnly?: boolean;\n /**\n * Value of the scrollable list representing the selected item.\n * It needs to be an existing value from the provided data.\n */\n value: number | undefined;\n /**\n * Allows to select multiple items from the list\n */\n multiselect?: boolean;\n /**\n * Contains the currently selected values when multiselect mode is ON.\n */\n selectedIndexes?: number[];\n /**\n * True when all available (not disabled) options are selected\n */\n allOptionsSelected?: boolean;\n};\n\n/** @internal */\nexport type ScrollableListPropsWithRef = ScrollableListProps & React.RefAttributes<HTMLUListElement>;\n\nexport const getId = (id: string, value: ScrollableListItemValue): string => `${id}_${value}`;\n\nconst getNextEnabledItem = (\n event: React.KeyboardEvent<HTMLElement>,\n data: ScrollableListItem[],\n index: number | undefined\n): number | undefined => {\n const nextIndex = getNextIndexFromKey(event.key, data.length, index);\n\n if (nextIndex) {\n if (nextIndex === index) {\n return index;\n } else if (data[nextIndex] && data[nextIndex].disabled) {\n return getNextEnabledItem(event, data, nextIndex);\n }\n }\n\n return nextIndex;\n};\n\nexport const ScrollableList = React.forwardRef(function ScrollableList(\n props: ScrollableListProps,\n ref: React.Ref<HTMLUListElement>\n) {\n const {\n data,\n disabled,\n highlighted,\n id,\n invalid: _,\n loading,\n onChange: setCurrentIndex,\n onClick,\n onFocus,\n onKeyDown,\n readOnly,\n scrollOnFocus = false,\n value: currentIndex,\n multiselect,\n selectedIndexes = [],\n allOptionsSelected = false,\n ...otherProps\n } = props;\n const listRef = useProxiedRef<HTMLUListElement>(ref);\n const itemRefs = React.useMemo(() => data.map(() => React.createRef<HTMLLIElement>()), [data]);\n const { texts } = useLocalization();\n const { scrollTo } = useListScrollTo(listRef, itemRefs);\n\n React.useEffect(() => {\n if (currentIndex && itemRefs[currentIndex]?.current) {\n itemRefs[currentIndex].current?.scrollIntoView({\n block: 'center',\n });\n }\n }, []);\n\n React.useEffect(() => {\n scrollTo(currentIndex);\n }, [currentIndex]);\n\n const handleKeyDown = (event: React.KeyboardEvent<HTMLUListElement>): void => {\n const nextIndex = getNextEnabledItem(event, data, currentIndex);\n\n if (nextIndex !== undefined && nextIndex !== currentIndex) {\n event.preventDefault();\n scrollTo(nextIndex);\n setCurrentIndex(nextIndex);\n }\n\n if (onKeyDown) {\n event.persist();\n const index = nextIndex !== undefined ? nextIndex : currentIndex;\n onKeyDown(event, index);\n }\n };\n\n const handleClick = (index: number) => (event: React.MouseEvent<HTMLLIElement>) => {\n setCurrentIndex(index);\n\n if (onClick) {\n event.persist();\n onClick(event, index);\n }\n };\n\n const handleFocus = (event: React.FocusEvent<HTMLUListElement>): void => {\n if (scrollOnFocus) {\n scrollTo(currentIndex);\n }\n\n if (onFocus) {\n event.persist();\n onFocus(event);\n }\n };\n\n const getOptionCheckedState = (optionValue: string, index: number): boolean => {\n if (optionValue === '#ALL-OPTIONS#') {\n return allOptionsSelected;\n } else if (!optionValue || !selectedIndexes) {\n return false;\n } else {\n return selectedIndexes.findIndex(i => i === index) !== -1;\n }\n };\n\n const list: React.HTMLAttributes<HTMLUListElement> &\n React.RefAttributes<HTMLUListElement> & { disabled?: boolean; readOnly?: boolean } = {\n ...otherProps,\n className: cn(\n 'inline-flex flex-col list-none !p-0 m-0 overflow-y-auto h-auto',\n getInputClasses(props),\n {\n 'yt-list--multiselect': multiselect,\n 'pointer-events-none': disabled,\n 'cursor-not-allowed': disabled || readOnly,\n },\n otherProps.className\n ),\n disabled,\n id,\n onFocus: !disabled && !readOnly ? handleFocus : undefined,\n onKeyDown: !disabled && !readOnly ? handleKeyDown : undefined,\n readOnly,\n ref: listRef,\n role: 'listbox',\n tabIndex: otherProps.tabIndex || 0,\n };\n\n const options = data.map((option, index) => {\n const depth = option.path ? option.path.split('.').length - 1 : 0;\n\n return {\n 'aria-selected': multiselect ? getOptionCheckedState(String(option.value), index) : currentIndex === index,\n 'data-focused': currentIndex === index,\n children: option.text,\n className: cn(\n 'flex items-center px-3 w-full cursor-pointer bg-white flex-[0_0_2rem] focus:wcag-blue focus:border-blue',\n {\n 'sticky top-0 font-bold': depth === 0 && !!option.hasChildren,\n }\n ),\n disabled: option.disabled,\n icon: option.icon,\n id: getId(id, option.value),\n key: getId(id, option.value),\n onClick: !disabled && !readOnly ? handleClick(index) : undefined,\n ref: itemRefs[index],\n role: 'option',\n style:\n depth > 0\n ? {\n paddingLeft: `${depth + 1}rem`,\n }\n : undefined,\n };\n });\n\n return (\n <ul {...list} data-taco=\"scrollable-list\">\n {loading ? (\n <li className=\"yt-list__empty\">\n <span>\n <Spinner delay={0} />\n </span>\n <span>{texts.listbox.loading}</span>\n </li>\n ) : options.length ? (\n options.map(({ children, icon, ...optionProps }) => (\n <li {...optionProps}>\n {icon}\n <span className=\"flex-grow truncate text-left\">{children}</span>\n {multiselect && (\n <Checkbox\n checked={optionProps['aria-selected']}\n onChange={() => null}\n className=\"pointer-events-none ml-2 self-center p-px\"\n />\n )}\n </li>\n ))\n ) : (\n <li className=\"yt-list__empty\">\n <span>{texts.listbox.empty}</span>\n </li>\n )}\n </ul>\n );\n});\n"],"names":["getId","id","value","getNextEnabledItem","event","data","index","nextIndex","getNextIndexFromKey","key","length","disabled","ScrollableList","React","props","ref","highlighted","invalid","_","loading","onChange","setCurrentIndex","onClick","onFocus","onKeyDown","readOnly","scrollOnFocus","currentIndex","multiselect","selectedIndexes","allOptionsSelected","otherProps","listRef","useProxiedRef","itemRefs","map","texts","useLocalization","scrollTo","useListScrollTo","current","scrollIntoView","block","handleKeyDown","undefined","preventDefault","persist","handleClick","handleFocus","getOptionCheckedState","optionValue","findIndex","i","list","className","cn","getInputClasses","role","tabIndex","options","option","depth","path","split","String","children","text","hasChildren","icon","style","paddingLeft","Spinner","delay","listbox","optionProps","Checkbox","checked","empty"],"mappings":"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"}
@@ -1,46 +1,40 @@
1
- import { objectWithoutPropertiesLoose as _objectWithoutPropertiesLoose, extends as _extends } from '../../_virtual/_rollupPluginBabelHelpers.js';
2
1
  import { useMemo, useEffect } from 'react';
3
2
  import { v4 } from 'uuid';
4
3
  import { useProxiedRef } from '../../utils/hooks/useProxiedRef.js';
5
4
  import { useFlattenedData, getIndexFromValue, getActiveDescendant, setInputValueByRef, findByValue, sanitizeItem } from './util.js';
6
5
  import { useTypeahead } from './useTypeahead.js';
7
6
 
8
- var _excluded = ["data", "defaultValue", "disabled", "emptyValue", "id", "invalid", "name", "onChange", "onFocus", "onKeyDown", "value"];
9
- var useListbox = function useListbox(_ref, ref) {
10
- var _ref$data = _ref.data,
11
- externalData = _ref$data === void 0 ? [] : _ref$data,
12
- defaultValue = _ref.defaultValue,
13
- disabled = _ref.disabled,
14
- emptyValue = _ref.emptyValue,
15
- nativeId = _ref.id,
16
- invalid = _ref.invalid,
17
- name = _ref.name,
18
- onChange = _ref.onChange,
19
- onFocus = _ref.onFocus,
20
- onKeyDown = _ref.onKeyDown,
21
- _ref$value = _ref.value,
22
- value = _ref$value === void 0 ? emptyValue : _ref$value,
23
- otherProps = _objectWithoutPropertiesLoose(_ref, _excluded);
24
-
25
- var data = useFlattenedData(emptyValue !== undefined ? [{
7
+ const useListbox = ({
8
+ data: externalData = [],
9
+ defaultValue,
10
+ disabled,
11
+ emptyValue,
12
+ id: nativeId,
13
+ invalid,
14
+ name,
15
+ onChange,
16
+ onFocus,
17
+ onKeyDown,
18
+ value = emptyValue,
19
+ ...otherProps
20
+ }, ref) => {
21
+ const data = useFlattenedData(emptyValue !== undefined ? [{
26
22
  text: '',
27
23
  value: emptyValue
28
- }].concat(externalData) : externalData);
29
- var id = useMemo(function () {
30
- return nativeId || v4();
31
- }, [nativeId]);
32
- var inputRef = useProxiedRef(ref);
33
- var currentIndex = value !== undefined ? getIndexFromValue(data, value) : undefined;
34
-
35
- var _useTypeahead = useTypeahead({
36
- data: data,
37
- currentIndex: currentIndex
38
- }),
39
- getNextIndex = _useTypeahead.getNextIndex;
40
-
41
- var setInputValueByIndex = function setInputValueByIndex(index) {
24
+ }, ...externalData] : externalData);
25
+ const id = useMemo(() => nativeId || v4(), [nativeId]);
26
+ const inputRef = useProxiedRef(ref);
27
+ const currentIndex = value !== undefined ? getIndexFromValue(data, value) : undefined;
28
+ const {
29
+ getNextIndex
30
+ } = useTypeahead({
31
+ data,
32
+ currentIndex
33
+ });
34
+
35
+ const setInputValueByIndex = index => {
42
36
  if (index !== undefined) {
43
- var option = data[index];
37
+ const option = data[index];
44
38
 
45
39
  if (option && !option.disabled) {
46
40
  setInputValueByRef(inputRef.current, option.value);
@@ -48,14 +42,14 @@ var useListbox = function useListbox(_ref, ref) {
48
42
  }
49
43
  };
50
44
 
51
- var handleListboxChange = function handleListboxChange(index) {
45
+ const handleListboxChange = index => {
52
46
  setInputValueByIndex(index);
53
47
  };
54
48
 
55
- useEffect(function () {
49
+ useEffect(() => {
56
50
  if (data.length && currentIndex === undefined) {
57
51
  if (defaultValue !== undefined) {
58
- var defaultValueIndex = getIndexFromValue(data, defaultValue);
52
+ const defaultValueIndex = getIndexFromValue(data, defaultValue);
59
53
 
60
54
  if (defaultValueIndex !== undefined) {
61
55
  setInputValueByIndex(defaultValueIndex);
@@ -66,11 +60,12 @@ var useListbox = function useListbox(_ref, ref) {
66
60
  }
67
61
  }, [data]);
68
62
 
69
- var handleListboxKeyDown = function handleListboxKeyDown(event) {
70
- var charKey = String.fromCharCode(event.keyCode);
63
+ const handleListboxKeyDown = event => {
64
+ const charKey = event.key; // event.key always returns the whole string (String.fromCharCode(event.keyCode) does not)
65
+ // We need to filter out only alphabetical or numeric letters, that's why that condition has been changed
71
66
 
72
- if (charKey.match(/(\w)/g)) {
73
- var nextIndex = getNextIndex(charKey);
67
+ if (charKey.length === 1 && /(\w)/g.test(charKey)) {
68
+ const nextIndex = getNextIndex(charKey);
74
69
 
75
70
  if (nextIndex > -1 && nextIndex !== currentIndex) {
76
71
  setInputValueByIndex(nextIndex);
@@ -85,7 +80,7 @@ var useListbox = function useListbox(_ref, ref) {
85
80
  }
86
81
  };
87
82
 
88
- var handleListboxFocus = function handleListboxFocus(event) {
83
+ const handleListboxFocus = event => {
89
84
  if (currentIndex === undefined && data.length) {
90
85
  setInputValueByIndex(0);
91
86
  }
@@ -96,26 +91,24 @@ var useListbox = function useListbox(_ref, ref) {
96
91
  }
97
92
  };
98
93
 
99
- var handleInputChange = function handleInputChange(event) {
94
+ const handleInputChange = event => {
100
95
  event.persist();
101
96
 
102
97
  if (onChange) {
103
98
  var _item$path$split, _item$path;
104
99
 
105
- var item = findByValue(data, event.target.value);
100
+ const item = findByValue(data, event.target.value);
106
101
  event.detail = sanitizeItem(item);
107
- var indexes = (_item$path$split = item === null || item === void 0 ? void 0 : (_item$path = item.path) === null || _item$path === void 0 ? void 0 : _item$path.split('.')) !== null && _item$path$split !== void 0 ? _item$path$split : [];
102
+ const indexes = (_item$path$split = item === null || item === void 0 ? void 0 : (_item$path = item.path) === null || _item$path === void 0 ? void 0 : _item$path.split('.')) !== null && _item$path$split !== void 0 ? _item$path$split : [];
108
103
 
109
104
  if (indexes.length > 1) {
110
105
  // we don't want to map the current item
111
106
  indexes.pop(); // we need to rebuild the path as we map
112
107
 
113
- var lastPath;
114
- event.detail.parents = indexes.map(function (i) {
108
+ let lastPath;
109
+ event.detail.parents = indexes.map(i => {
115
110
  lastPath = lastPath ? [lastPath, i].join('.') : i;
116
- return sanitizeItem(data.find(function (i) {
117
- return i.path === lastPath;
118
- }));
111
+ return sanitizeItem(data.find(i => i.path === lastPath));
119
112
  });
120
113
  }
121
114
 
@@ -123,30 +116,29 @@ var useListbox = function useListbox(_ref, ref) {
123
116
  }
124
117
  };
125
118
 
126
- var list = _extends({}, otherProps, {
119
+ const list = { ...otherProps,
127
120
  'aria-activedescendant': getActiveDescendant(data, currentIndex, id),
128
- data: data,
129
- disabled: disabled,
130
- id: id,
131
- invalid: invalid,
121
+ data,
122
+ disabled,
123
+ id,
124
+ invalid,
132
125
  onChange: handleListboxChange,
133
126
  onFocus: handleListboxFocus,
134
127
  onKeyDown: handleListboxKeyDown,
135
128
  scrollOnFocus: true,
136
129
  tabIndex: disabled ? -1 : otherProps.tabIndex ? otherProps.tabIndex : 0,
137
130
  value: currentIndex
138
- });
139
-
140
- var input = {
141
- name: name,
131
+ };
132
+ const input = {
133
+ name,
142
134
  onChange: handleInputChange,
143
135
  ref: inputRef,
144
136
  tabIndex: -1,
145
137
  value: value !== null && value !== void 0 ? value : ''
146
138
  };
147
139
  return {
148
- list: list,
149
- input: input
140
+ list,
141
+ input
150
142
  };
151
143
  };
152
144