@vuu-ui/vuu-filters 0.0.26

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 (223) hide show
  1. package/LICENSE +201 -0
  2. package/README.md +0 -0
  3. package/cjs/FilterModel.js +233 -0
  4. package/cjs/FilterModel.js.map +1 -0
  5. package/cjs/filter-bar/FilterBar.css.js +6 -0
  6. package/cjs/filter-bar/FilterBar.css.js.map +1 -0
  7. package/cjs/filter-bar/FilterBar.js +134 -0
  8. package/cjs/filter-bar/FilterBar.js.map +1 -0
  9. package/cjs/filter-bar/FilterBarMenu.js +12 -0
  10. package/cjs/filter-bar/FilterBarMenu.js.map +1 -0
  11. package/cjs/filter-bar/filterBarFocusManagement.js +35 -0
  12. package/cjs/filter-bar/filterBarFocusManagement.js.map +1 -0
  13. package/cjs/filter-bar/useApplyFilterOnChange.js +33 -0
  14. package/cjs/filter-bar/useApplyFilterOnChange.js.map +1 -0
  15. package/cjs/filter-bar/useFilterBar.js +250 -0
  16. package/cjs/filter-bar/useFilterBar.js.map +1 -0
  17. package/cjs/filter-bar/useFilterState.js +150 -0
  18. package/cjs/filter-bar/useFilterState.js.map +1 -0
  19. package/cjs/filter-clause/ExpandoCombobox.css.js +6 -0
  20. package/cjs/filter-clause/ExpandoCombobox.css.js.map +1 -0
  21. package/cjs/filter-clause/ExpandoCombobox.js +148 -0
  22. package/cjs/filter-clause/ExpandoCombobox.js.map +1 -0
  23. package/cjs/filter-clause/FilterClause.css.js +6 -0
  24. package/cjs/filter-clause/FilterClause.css.js.map +1 -0
  25. package/cjs/filter-clause/FilterClause.js +112 -0
  26. package/cjs/filter-clause/FilterClause.js.map +1 -0
  27. package/cjs/filter-clause/filterClauseFocusManagement.js +203 -0
  28. package/cjs/filter-clause/filterClauseFocusManagement.js.map +1 -0
  29. package/cjs/filter-clause/operator-utils.js +20 -0
  30. package/cjs/filter-clause/operator-utils.js.map +1 -0
  31. package/cjs/filter-clause/useFilterClause.js +142 -0
  32. package/cjs/filter-clause/useFilterClause.js.map +1 -0
  33. package/cjs/filter-clause/value-editors/FilterClauseValueEditor.js +77 -0
  34. package/cjs/filter-clause/value-editors/FilterClauseValueEditor.js.map +1 -0
  35. package/cjs/filter-clause/value-editors/FilterClauseValueEditorDate.js +75 -0
  36. package/cjs/filter-clause/value-editors/FilterClauseValueEditorDate.js.map +1 -0
  37. package/cjs/filter-clause/value-editors/FilterClauseValueEditorNumber.js +55 -0
  38. package/cjs/filter-clause/value-editors/FilterClauseValueEditorNumber.js.map +1 -0
  39. package/cjs/filter-clause/value-editors/FilterClauseValueEditorText.js +193 -0
  40. package/cjs/filter-clause/value-editors/FilterClauseValueEditorText.js.map +1 -0
  41. package/cjs/filter-editor/FilterClauseCombinator.css.js +6 -0
  42. package/cjs/filter-editor/FilterClauseCombinator.css.js.map +1 -0
  43. package/cjs/filter-editor/FilterClauseCombinator.js +42 -0
  44. package/cjs/filter-editor/FilterClauseCombinator.js.map +1 -0
  45. package/cjs/filter-editor/FilterEditor.css.js +6 -0
  46. package/cjs/filter-editor/FilterEditor.css.js.map +1 -0
  47. package/cjs/filter-editor/FilterEditor.js +97 -0
  48. package/cjs/filter-editor/FilterEditor.js.map +1 -0
  49. package/cjs/filter-editor/useFilterEditor.js +188 -0
  50. package/cjs/filter-editor/useFilterEditor.js.map +1 -0
  51. package/cjs/filter-input/FilterInput.css.js +6 -0
  52. package/cjs/filter-input/FilterInput.css.js.map +1 -0
  53. package/cjs/filter-input/FilterInput.js +52 -0
  54. package/cjs/filter-input/FilterInput.js.map +1 -0
  55. package/cjs/filter-input/FilterLanguage.js +24 -0
  56. package/cjs/filter-input/FilterLanguage.js.map +1 -0
  57. package/cjs/filter-input/filterInfo.js +17 -0
  58. package/cjs/filter-input/filterInfo.js.map +1 -0
  59. package/cjs/filter-input/highlighting.js +12 -0
  60. package/cjs/filter-input/highlighting.js.map +1 -0
  61. package/cjs/filter-input/theme.js +79 -0
  62. package/cjs/filter-input/theme.js.map +1 -0
  63. package/cjs/filter-input/useCodeMirrorEditor.js +136 -0
  64. package/cjs/filter-input/useCodeMirrorEditor.js.map +1 -0
  65. package/cjs/filter-input/useFilterAutoComplete.js +243 -0
  66. package/cjs/filter-input/useFilterAutoComplete.js.map +1 -0
  67. package/cjs/filter-input/useFilterSuggestionProvider.js +206 -0
  68. package/cjs/filter-input/useFilterSuggestionProvider.js.map +1 -0
  69. package/cjs/filter-pill/FilterPill.css.js +6 -0
  70. package/cjs/filter-pill/FilterPill.css.js.map +1 -0
  71. package/cjs/filter-pill/FilterPill.js +147 -0
  72. package/cjs/filter-pill/FilterPill.js.map +1 -0
  73. package/cjs/filter-pill/FilterPillMenuOptions.js +32 -0
  74. package/cjs/filter-pill/FilterPillMenuOptions.js.map +1 -0
  75. package/cjs/filter-pill/filterAsReactNode.js +27 -0
  76. package/cjs/filter-pill/filterAsReactNode.js.map +1 -0
  77. package/cjs/filter-pill/getFilterLabel.js +22 -0
  78. package/cjs/filter-pill/getFilterLabel.js.map +1 -0
  79. package/cjs/filter-pill/getFilterTooltipText.js +41 -0
  80. package/cjs/filter-pill/getFilterTooltipText.js.map +1 -0
  81. package/cjs/filter-utils.js +328 -0
  82. package/cjs/filter-utils.js.map +1 -0
  83. package/cjs/index.js +50 -0
  84. package/cjs/index.js.map +1 -0
  85. package/cjs/use-filter-config.js +39 -0
  86. package/cjs/use-filter-config.js.map +1 -0
  87. package/cjs/use-rest-config.js +63 -0
  88. package/cjs/use-rest-config.js.map +1 -0
  89. package/esm/FilterModel.js +230 -0
  90. package/esm/FilterModel.js.map +1 -0
  91. package/esm/filter-bar/FilterBar.css.js +4 -0
  92. package/esm/filter-bar/FilterBar.css.js.map +1 -0
  93. package/esm/filter-bar/FilterBar.js +132 -0
  94. package/esm/filter-bar/FilterBar.js.map +1 -0
  95. package/esm/filter-bar/FilterBarMenu.js +10 -0
  96. package/esm/filter-bar/FilterBarMenu.js.map +1 -0
  97. package/esm/filter-bar/filterBarFocusManagement.js +33 -0
  98. package/esm/filter-bar/filterBarFocusManagement.js.map +1 -0
  99. package/esm/filter-bar/useApplyFilterOnChange.js +31 -0
  100. package/esm/filter-bar/useApplyFilterOnChange.js.map +1 -0
  101. package/esm/filter-bar/useFilterBar.js +248 -0
  102. package/esm/filter-bar/useFilterBar.js.map +1 -0
  103. package/esm/filter-bar/useFilterState.js +148 -0
  104. package/esm/filter-bar/useFilterState.js.map +1 -0
  105. package/esm/filter-clause/ExpandoCombobox.css.js +4 -0
  106. package/esm/filter-clause/ExpandoCombobox.css.js.map +1 -0
  107. package/esm/filter-clause/ExpandoCombobox.js +146 -0
  108. package/esm/filter-clause/ExpandoCombobox.js.map +1 -0
  109. package/esm/filter-clause/FilterClause.css.js +4 -0
  110. package/esm/filter-clause/FilterClause.css.js.map +1 -0
  111. package/esm/filter-clause/FilterClause.js +110 -0
  112. package/esm/filter-clause/FilterClause.js.map +1 -0
  113. package/esm/filter-clause/filterClauseFocusManagement.js +189 -0
  114. package/esm/filter-clause/filterClauseFocusManagement.js.map +1 -0
  115. package/esm/filter-clause/operator-utils.js +16 -0
  116. package/esm/filter-clause/operator-utils.js.map +1 -0
  117. package/esm/filter-clause/useFilterClause.js +140 -0
  118. package/esm/filter-clause/useFilterClause.js.map +1 -0
  119. package/esm/filter-clause/value-editors/FilterClauseValueEditor.js +75 -0
  120. package/esm/filter-clause/value-editors/FilterClauseValueEditor.js.map +1 -0
  121. package/esm/filter-clause/value-editors/FilterClauseValueEditorDate.js +73 -0
  122. package/esm/filter-clause/value-editors/FilterClauseValueEditorDate.js.map +1 -0
  123. package/esm/filter-clause/value-editors/FilterClauseValueEditorNumber.js +53 -0
  124. package/esm/filter-clause/value-editors/FilterClauseValueEditorNumber.js.map +1 -0
  125. package/esm/filter-clause/value-editors/FilterClauseValueEditorText.js +191 -0
  126. package/esm/filter-clause/value-editors/FilterClauseValueEditorText.js.map +1 -0
  127. package/esm/filter-editor/FilterClauseCombinator.css.js +4 -0
  128. package/esm/filter-editor/FilterClauseCombinator.css.js.map +1 -0
  129. package/esm/filter-editor/FilterClauseCombinator.js +40 -0
  130. package/esm/filter-editor/FilterClauseCombinator.js.map +1 -0
  131. package/esm/filter-editor/FilterEditor.css.js +4 -0
  132. package/esm/filter-editor/FilterEditor.css.js.map +1 -0
  133. package/esm/filter-editor/FilterEditor.js +95 -0
  134. package/esm/filter-editor/FilterEditor.js.map +1 -0
  135. package/esm/filter-editor/useFilterEditor.js +186 -0
  136. package/esm/filter-editor/useFilterEditor.js.map +1 -0
  137. package/esm/filter-input/FilterInput.css.js +4 -0
  138. package/esm/filter-input/FilterInput.css.js.map +1 -0
  139. package/esm/filter-input/FilterInput.js +50 -0
  140. package/esm/filter-input/FilterInput.js.map +1 -0
  141. package/esm/filter-input/FilterLanguage.js +22 -0
  142. package/esm/filter-input/FilterLanguage.js.map +1 -0
  143. package/esm/filter-input/filterInfo.js +15 -0
  144. package/esm/filter-input/filterInfo.js.map +1 -0
  145. package/esm/filter-input/highlighting.js +10 -0
  146. package/esm/filter-input/highlighting.js.map +1 -0
  147. package/esm/filter-input/theme.js +77 -0
  148. package/esm/filter-input/theme.js.map +1 -0
  149. package/esm/filter-input/useCodeMirrorEditor.js +134 -0
  150. package/esm/filter-input/useCodeMirrorEditor.js.map +1 -0
  151. package/esm/filter-input/useFilterAutoComplete.js +241 -0
  152. package/esm/filter-input/useFilterAutoComplete.js.map +1 -0
  153. package/esm/filter-input/useFilterSuggestionProvider.js +204 -0
  154. package/esm/filter-input/useFilterSuggestionProvider.js.map +1 -0
  155. package/esm/filter-pill/FilterPill.css.js +4 -0
  156. package/esm/filter-pill/FilterPill.css.js.map +1 -0
  157. package/esm/filter-pill/FilterPill.js +145 -0
  158. package/esm/filter-pill/FilterPill.js.map +1 -0
  159. package/esm/filter-pill/FilterPillMenuOptions.js +27 -0
  160. package/esm/filter-pill/FilterPillMenuOptions.js.map +1 -0
  161. package/esm/filter-pill/filterAsReactNode.js +25 -0
  162. package/esm/filter-pill/filterAsReactNode.js.map +1 -0
  163. package/esm/filter-pill/getFilterLabel.js +20 -0
  164. package/esm/filter-pill/getFilterLabel.js.map +1 -0
  165. package/esm/filter-pill/getFilterTooltipText.js +39 -0
  166. package/esm/filter-pill/getFilterTooltipText.js.map +1 -0
  167. package/esm/filter-utils.js +307 -0
  168. package/esm/filter-utils.js.map +1 -0
  169. package/esm/index.js +13 -0
  170. package/esm/index.js.map +1 -0
  171. package/esm/use-filter-config.js +37 -0
  172. package/esm/use-filter-config.js.map +1 -0
  173. package/esm/use-rest-config.js +61 -0
  174. package/esm/use-rest-config.js.map +1 -0
  175. package/package.json +48 -0
  176. package/types/FilterModel.d.ts +43 -0
  177. package/types/column-filter/utils.d.ts +4 -0
  178. package/types/filter-bar/FilterBar.d.ts +22 -0
  179. package/types/filter-bar/FilterBarMenu.d.ts +2 -0
  180. package/types/filter-bar/filterBarFocusManagement.d.ts +1 -0
  181. package/types/filter-bar/index.d.ts +1 -0
  182. package/types/filter-bar/useApplyFilterOnChange.d.ts +10 -0
  183. package/types/filter-bar/useFilterBar.d.ts +30 -0
  184. package/types/filter-bar/useFilterState.d.ts +17 -0
  185. package/types/filter-clause/ExpandoCombobox.d.ts +10 -0
  186. package/types/filter-clause/FilterClause.d.ts +17 -0
  187. package/types/filter-clause/FilterMenu.d.ts +10 -0
  188. package/types/filter-clause/FilterMenuOptions.d.ts +6 -0
  189. package/types/filter-clause/filterClauseFocusManagement.d.ts +16 -0
  190. package/types/filter-clause/filterClauseTypes.d.ts +13 -0
  191. package/types/filter-clause/index.d.ts +3 -0
  192. package/types/filter-clause/operator-utils.d.ts +4 -0
  193. package/types/filter-clause/useFilterClause.d.ts +24 -0
  194. package/types/filter-clause/value-editors/FilterClauseValueEditor.d.ts +13 -0
  195. package/types/filter-clause/value-editors/FilterClauseValueEditorDate.d.ts +10 -0
  196. package/types/filter-clause/value-editors/FilterClauseValueEditorNumber.d.ts +10 -0
  197. package/types/filter-clause/value-editors/FilterClauseValueEditorText.d.ts +11 -0
  198. package/types/filter-editor/FilterClauseCombinator.d.ts +9 -0
  199. package/types/filter-editor/FilterEditor.d.ts +16 -0
  200. package/types/filter-editor/index.d.ts +1 -0
  201. package/types/filter-editor/useFilterEditor.d.ts +31 -0
  202. package/types/filter-input/FilterInput.d.ts +10 -0
  203. package/types/filter-input/FilterLanguage.d.ts +2 -0
  204. package/types/filter-input/filterInfo.d.ts +1 -0
  205. package/types/filter-input/highlighting.d.ts +1 -0
  206. package/types/filter-input/index.d.ts +3 -0
  207. package/types/filter-input/theme.d.ts +1 -0
  208. package/types/filter-input/useCodeMirrorEditor.d.ts +35 -0
  209. package/types/filter-input/useFilterAutoComplete.d.ts +9 -0
  210. package/types/filter-input/useFilterSuggestionProvider.d.ts +16 -0
  211. package/types/filter-pill/FilterPill.d.ts +17 -0
  212. package/types/filter-pill/FilterPillMenuOptions.d.ts +12 -0
  213. package/types/filter-pill/filterAsReactNode.d.ts +3 -0
  214. package/types/filter-pill/getFilterLabel.d.ts +2 -0
  215. package/types/filter-pill/getFilterTooltipText.d.ts +2 -0
  216. package/types/filter-pill/index.d.ts +1 -0
  217. package/types/filter-pill-menu/FilterPillMenu.d.ts +18 -0
  218. package/types/filter-pill-menu/FilterPillMenuOptions.d.ts +12 -0
  219. package/types/filter-pill-menu/index.d.ts +1 -0
  220. package/types/filter-utils.d.ts +48 -0
  221. package/types/index.d.ts +8 -0
  222. package/types/use-filter-config.d.ts +12 -0
  223. package/types/use-rest-config.d.ts +11 -0
@@ -0,0 +1,35 @@
1
+ 'use strict';
2
+
3
+ var vuuUtils = require('@vuu-ui/vuu-utils');
4
+
5
+ const navigateToNextItem = (el, direction = "fwd") => {
6
+ const pill = vuuUtils.queryClosest(el, ".vuuFilterPill");
7
+ if (pill) {
8
+ const index = vuuUtils.getElementDataIndex(pill);
9
+ if (typeof index === "number") {
10
+ const target = direction === "fwd" ? vuuUtils.getElementByDataIndex(pill.parentElement, index + 1) : vuuUtils.getElementByDataIndex(pill.parentElement, index - 1);
11
+ if (target) {
12
+ target.focus();
13
+ } else if (direction === "fwd") {
14
+ console.log("to the button");
15
+ const filterBar = vuuUtils.queryClosest(el, ".vuuFilterBar");
16
+ const addButton = filterBar?.querySelector(
17
+ ".vuuFilterBar-add"
18
+ );
19
+ addButton?.focus();
20
+ }
21
+ }
22
+ } else {
23
+ const button = vuuUtils.queryClosest(el, ".vuuFilterBar-add");
24
+ if (button) {
25
+ const filterBar = vuuUtils.queryClosest(el, ".vuuFilterBar");
26
+ const target = filterBar?.querySelector(
27
+ ".vuuFilterPill:last-child"
28
+ );
29
+ target?.focus();
30
+ }
31
+ }
32
+ };
33
+
34
+ exports.navigateToNextItem = navigateToNextItem;
35
+ //# sourceMappingURL=filterBarFocusManagement.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"filterBarFocusManagement.js","sources":["../../src/filter-bar/filterBarFocusManagement.ts"],"sourcesContent":["import {\n getElementByDataIndex,\n getElementDataIndex,\n queryClosest,\n} from \"@vuu-ui/vuu-utils\";\n\nexport const navigateToNextItem = (\n el: HTMLElement | EventTarget,\n direction: \"bwd\" | \"fwd\" = \"fwd\"\n) => {\n const pill = queryClosest(el, \".vuuFilterPill\");\n if (pill) {\n const index = getElementDataIndex(pill);\n if (typeof index === \"number\") {\n const target =\n direction === \"fwd\"\n ? getElementByDataIndex(pill.parentElement, index + 1)\n : getElementByDataIndex(pill.parentElement, index - 1);\n if (target) {\n target.focus();\n } else if (direction === \"fwd\") {\n console.log(\"to the button\");\n const filterBar = queryClosest(el, \".vuuFilterBar\");\n const addButton = filterBar?.querySelector(\n \".vuuFilterBar-add\"\n ) as HTMLElement;\n addButton?.focus();\n }\n }\n } else {\n const button = queryClosest(el, \".vuuFilterBar-add\");\n if (button) {\n const filterBar = queryClosest(el, \".vuuFilterBar\");\n const target = filterBar?.querySelector(\n \".vuuFilterPill:last-child\"\n ) as HTMLElement;\n target?.focus();\n }\n }\n};\n"],"names":["queryClosest","getElementDataIndex","getElementByDataIndex"],"mappings":";;;;AAMO,MAAM,kBAAqB,GAAA,CAChC,EACA,EAAA,SAAA,GAA2B,KACxB,KAAA;AACH,EAAM,MAAA,IAAA,GAAOA,qBAAa,CAAA,EAAA,EAAI,gBAAgB,CAAA,CAAA;AAC9C,EAAA,IAAI,IAAM,EAAA;AACR,IAAM,MAAA,KAAA,GAAQC,6BAAoB,IAAI,CAAA,CAAA;AACtC,IAAI,IAAA,OAAO,UAAU,QAAU,EAAA;AAC7B,MAAA,MAAM,MACJ,GAAA,SAAA,KAAc,KACV,GAAAC,8BAAA,CAAsB,IAAK,CAAA,aAAA,EAAe,KAAQ,GAAA,CAAC,CACnD,GAAAA,8BAAA,CAAsB,IAAK,CAAA,aAAA,EAAe,QAAQ,CAAC,CAAA,CAAA;AACzD,MAAA,IAAI,MAAQ,EAAA;AACV,QAAA,MAAA,CAAO,KAAM,EAAA,CAAA;AAAA,OACf,MAAA,IAAW,cAAc,KAAO,EAAA;AAC9B,QAAA,OAAA,CAAQ,IAAI,eAAe,CAAA,CAAA;AAC3B,QAAM,MAAA,SAAA,GAAYF,qBAAa,CAAA,EAAA,EAAI,eAAe,CAAA,CAAA;AAClD,QAAA,MAAM,YAAY,SAAW,EAAA,aAAA;AAAA,UAC3B,mBAAA;AAAA,SACF,CAAA;AACA,QAAA,SAAA,EAAW,KAAM,EAAA,CAAA;AAAA,OACnB;AAAA,KACF;AAAA,GACK,MAAA;AACL,IAAM,MAAA,MAAA,GAASA,qBAAa,CAAA,EAAA,EAAI,mBAAmB,CAAA,CAAA;AACnD,IAAA,IAAI,MAAQ,EAAA;AACV,MAAM,MAAA,SAAA,GAAYA,qBAAa,CAAA,EAAA,EAAI,eAAe,CAAA,CAAA;AAClD,MAAA,MAAM,SAAS,SAAW,EAAA,aAAA;AAAA,QACxB,2BAAA;AAAA,OACF,CAAA;AACA,MAAA,MAAA,EAAQ,KAAM,EAAA,CAAA;AAAA,KAChB;AAAA,GACF;AACF;;;;"}
@@ -0,0 +1,33 @@
1
+ 'use strict';
2
+
3
+ var react = require('react');
4
+ var vuuUtils = require('@vuu-ui/vuu-utils');
5
+
6
+ function useApplyFilterOnChange({
7
+ activeFilterIndex,
8
+ columnsByName,
9
+ filters,
10
+ onApplyFilter
11
+ }) {
12
+ const applyFilter = react.useCallback(
13
+ (filter) => {
14
+ const query = filter ? vuuUtils.filterAsQuery(filter, { columnsByName }) : "";
15
+ onApplyFilter({ filter: query, filterStruct: filter });
16
+ },
17
+ [columnsByName, onApplyFilter]
18
+ );
19
+ react.useEffect(() => {
20
+ const activeFilters = activeFilterIndex.map((i) => filters[i]);
21
+ if (activeFilters.length === 0) {
22
+ applyFilter();
23
+ } else if (activeFilters.length === 1) {
24
+ const [filter] = activeFilters;
25
+ applyFilter(filter);
26
+ } else {
27
+ applyFilter({ op: "and", filters: activeFilters });
28
+ }
29
+ }, [activeFilterIndex, applyFilter, filters]);
30
+ }
31
+
32
+ exports.useApplyFilterOnChange = useApplyFilterOnChange;
33
+ //# sourceMappingURL=useApplyFilterOnChange.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useApplyFilterOnChange.js","sources":["../../src/filter-bar/useApplyFilterOnChange.ts"],"sourcesContent":["import { useCallback, useEffect } from \"react\";\nimport {\n ColumnDescriptorsByName,\n Filter,\n FilterState,\n} from \"@vuu-ui/vuu-filter-types\";\nimport { DataSourceFilter } from \"@vuu-ui/vuu-data-types\";\nimport { filterAsQuery } from \"@vuu-ui/vuu-utils\";\n\ninterface ApplyFilterHookProps {\n activeFilterIndex: FilterState[\"activeIndices\"];\n columnsByName: ColumnDescriptorsByName;\n filters: FilterState[\"filters\"];\n onApplyFilter: (f: DataSourceFilter) => void;\n}\n\nexport function useApplyFilterOnChange({\n activeFilterIndex,\n columnsByName,\n filters,\n onApplyFilter,\n}: ApplyFilterHookProps) {\n const applyFilter = useCallback(\n (filter?: Filter) => {\n const query = filter ? filterAsQuery(filter, { columnsByName }) : \"\";\n onApplyFilter({ filter: query, filterStruct: filter });\n },\n [columnsByName, onApplyFilter]\n );\n\n useEffect(() => {\n const activeFilters = activeFilterIndex.map((i) => filters[i]);\n if (activeFilters.length === 0) {\n applyFilter();\n } else if (activeFilters.length === 1) {\n const [filter] = activeFilters;\n applyFilter(filter);\n } else {\n applyFilter({ op: \"and\", filters: activeFilters });\n }\n }, [activeFilterIndex, applyFilter, filters]);\n}\n"],"names":["useCallback","filterAsQuery","useEffect"],"mappings":";;;;;AAgBO,SAAS,sBAAuB,CAAA;AAAA,EACrC,iBAAA;AAAA,EACA,aAAA;AAAA,EACA,OAAA;AAAA,EACA,aAAA;AACF,CAAyB,EAAA;AACvB,EAAA,MAAM,WAAc,GAAAA,iBAAA;AAAA,IAClB,CAAC,MAAoB,KAAA;AACnB,MAAA,MAAM,QAAQ,MAAS,GAAAC,sBAAA,CAAc,QAAQ,EAAE,aAAA,EAAe,CAAI,GAAA,EAAA,CAAA;AAClE,MAAA,aAAA,CAAc,EAAE,MAAA,EAAQ,KAAO,EAAA,YAAA,EAAc,QAAQ,CAAA,CAAA;AAAA,KACvD;AAAA,IACA,CAAC,eAAe,aAAa,CAAA;AAAA,GAC/B,CAAA;AAEA,EAAAC,eAAA,CAAU,MAAM;AACd,IAAA,MAAM,gBAAgB,iBAAkB,CAAA,GAAA,CAAI,CAAC,CAAM,KAAA,OAAA,CAAQ,CAAC,CAAC,CAAA,CAAA;AAC7D,IAAI,IAAA,aAAA,CAAc,WAAW,CAAG,EAAA;AAC9B,MAAY,WAAA,EAAA,CAAA;AAAA,KACd,MAAA,IAAW,aAAc,CAAA,MAAA,KAAW,CAAG,EAAA;AACrC,MAAM,MAAA,CAAC,MAAM,CAAI,GAAA,aAAA,CAAA;AACjB,MAAA,WAAA,CAAY,MAAM,CAAA,CAAA;AAAA,KACb,MAAA;AACL,MAAA,WAAA,CAAY,EAAE,EAAA,EAAI,KAAO,EAAA,OAAA,EAAS,eAAe,CAAA,CAAA;AAAA,KACnD;AAAA,GACC,EAAA,CAAC,iBAAmB,EAAA,WAAA,EAAa,OAAO,CAAC,CAAA,CAAA;AAC9C;;;;"}
@@ -0,0 +1,250 @@
1
+ 'use strict';
2
+
3
+ var vuuUiControls = require('@vuu-ui/vuu-ui-controls');
4
+ var vuuUtils = require('@vuu-ui/vuu-utils');
5
+ var react = require('react');
6
+ var useFilterState = require('./useFilterState.js');
7
+ var useApplyFilterOnChange = require('./useApplyFilterOnChange.js');
8
+ var filterBarFocusManagement = require('./filterBarFocusManagement.js');
9
+
10
+ const useFilterBar = ({
11
+ columnDescriptors,
12
+ containerRef,
13
+ defaultFilterState,
14
+ filterState,
15
+ onApplyFilter,
16
+ onFilterDeleted,
17
+ onFilterRenamed,
18
+ onFilterStateChanged
19
+ }) => {
20
+ const addButtonRef = react.useRef(null);
21
+ const [interactedFilterState, setInteractedFilterState] = react.useState();
22
+ const [promptProps, setPromptProps] = react.useState(null);
23
+ const editPillLabelAPI = react.useRef(vuuUiControls.NullEditAPI);
24
+ const columnsByName = react.useMemo(
25
+ () => columnDescriptorsByName(columnDescriptors),
26
+ [columnDescriptors]
27
+ );
28
+ const {
29
+ activeFilterIndex,
30
+ filters,
31
+ onAddFilter,
32
+ onChangeFilter,
33
+ onDeleteFilter,
34
+ onRenameFilter,
35
+ onToggleFilterActive
36
+ } = useFilterState.useFilterState({
37
+ defaultFilterState,
38
+ filterState,
39
+ onFilterDeleted,
40
+ onFilterRenamed,
41
+ onFilterStateChanged
42
+ });
43
+ useApplyFilterOnChange.useApplyFilterOnChange({
44
+ activeFilterIndex,
45
+ columnsByName,
46
+ filters,
47
+ onApplyFilter
48
+ });
49
+ const editPillLabel = react.useCallback((index, filter) => {
50
+ setTimeout(() => {
51
+ setInteractedFilterState({
52
+ filter,
53
+ index,
54
+ state: "rename"
55
+ });
56
+ }, 100);
57
+ }, []);
58
+ const focusFilterPill = react.useCallback(
59
+ (index = 0) => {
60
+ requestAnimationFrame(() => {
61
+ const target = containerRef.current?.querySelector(
62
+ `.vuuFilterPill[data-index="${index}"] button`
63
+ );
64
+ if (target) {
65
+ target.focus();
66
+ }
67
+ });
68
+ },
69
+ [containerRef]
70
+ );
71
+ const deleteConfirmed = react.useCallback(
72
+ (filter) => {
73
+ onDeleteFilter(filter);
74
+ requestAnimationFrame(() => {
75
+ if (filters.length) {
76
+ focusFilterPill(0);
77
+ }
78
+ });
79
+ },
80
+ [filters.length, focusFilterPill, onDeleteFilter]
81
+ );
82
+ const getDeletePrompt = react.useMemo(
83
+ () => (filter) => {
84
+ const close = () => {
85
+ setPromptProps(null);
86
+ focusFilterPill();
87
+ };
88
+ return {
89
+ confirmButtonLabel: "Remove",
90
+ icon: "warn-triangle",
91
+ onCancel: close,
92
+ onClose: close,
93
+ onConfirm: () => {
94
+ setPromptProps(null);
95
+ deleteConfirmed(filter);
96
+ },
97
+ text: `Are you sure you want to delete ${filter.name}`,
98
+ title: "Remove Filter",
99
+ variant: "warn"
100
+ };
101
+ },
102
+ [deleteConfirmed, focusFilterPill]
103
+ );
104
+ const deleteFilter = react.useCallback(
105
+ (filter, withPrompt) => {
106
+ if (withPrompt) {
107
+ setPromptProps(getDeletePrompt(filter));
108
+ } else {
109
+ deleteConfirmed(filter);
110
+ }
111
+ },
112
+ [deleteConfirmed, getDeletePrompt]
113
+ );
114
+ const handleExitEditFilterName = react.useCallback(
115
+ (_, editedValue = "") => {
116
+ if (interactedFilterState?.state === "rename" && interactedFilterState.filter) {
117
+ const { filter } = interactedFilterState;
118
+ const indexOfEditedFilter = onRenameFilter(filter, editedValue);
119
+ setInteractedFilterState(void 0);
120
+ focusFilterPill(indexOfEditedFilter);
121
+ }
122
+ setInteractedFilterState(void 0);
123
+ },
124
+ [focusFilterPill, interactedFilterState, onRenameFilter]
125
+ );
126
+ const handlePillMenuAction = react.useCallback(
127
+ ({ menuId, options }) => {
128
+ switch (menuId) {
129
+ case "delete-filter": {
130
+ const { filter } = options;
131
+ deleteFilter(filter, true);
132
+ return true;
133
+ }
134
+ case "rename-filter": {
135
+ const { filter } = options;
136
+ const index = filters.indexOf(filter);
137
+ editPillLabel(index, filter);
138
+ return true;
139
+ }
140
+ case "edit-filter": {
141
+ const { filter } = options;
142
+ setInteractedFilterState({
143
+ filter,
144
+ index: filters.indexOf(filter),
145
+ state: "edit"
146
+ });
147
+ return true;
148
+ }
149
+ default:
150
+ return false;
151
+ }
152
+ },
153
+ [deleteFilter, editPillLabel, filters]
154
+ );
155
+ const handlePillKeyDown = react.useCallback((e) => {
156
+ if (e.key === "ArrowRight" || e.key === "ArrowLeft") {
157
+ filterBarFocusManagement.navigateToNextItem(e.target, e.key === "ArrowLeft" ? "bwd" : "fwd");
158
+ }
159
+ }, []);
160
+ const addIfNewElseUpdate = react.useCallback(
161
+ (newOrUpdatedFilter, existing) => {
162
+ if (existing === void 0) {
163
+ const idx = onAddFilter(newOrUpdatedFilter);
164
+ focusFilterPill(idx);
165
+ editPillLabel(idx, newOrUpdatedFilter);
166
+ } else {
167
+ const idx = onChangeFilter(existing, newOrUpdatedFilter);
168
+ focusFilterPill(idx);
169
+ }
170
+ },
171
+ [editPillLabel, focusFilterPill, onAddFilter, onChangeFilter]
172
+ );
173
+ const filterSaveHandler = react.useCallback(
174
+ (filter) => {
175
+ if (interactedFilterState) {
176
+ const { filter: existingFilter } = interactedFilterState;
177
+ setInteractedFilterState(void 0);
178
+ addIfNewElseUpdate(filter, existingFilter);
179
+ }
180
+ },
181
+ [addIfNewElseUpdate, interactedFilterState]
182
+ );
183
+ const handlePillClick = react.useCallback(
184
+ (e) => {
185
+ const isEditing = e.target.querySelector(
186
+ ".vuuEditableLabel-editing"
187
+ );
188
+ if (!isEditing) {
189
+ const pill = vuuUtils.queryClosest(e.target, ".vuuFilterPill");
190
+ if (pill) {
191
+ const index = vuuUtils.getElementDataIndex(pill);
192
+ onToggleFilterActive(index, e.shiftKey);
193
+ }
194
+ }
195
+ },
196
+ [onToggleFilterActive]
197
+ );
198
+ const pillProps = {
199
+ editLabelApiRef: editPillLabelAPI,
200
+ // onBeginEdit: handleBeginEditFilterName,
201
+ onClick: handlePillClick,
202
+ onKeyDown: handlePillKeyDown,
203
+ onMenuAction: handlePillMenuAction,
204
+ onExitEditMode: handleExitEditFilterName
205
+ };
206
+ const handleClickAddButton = react.useCallback(() => {
207
+ setInteractedFilterState({
208
+ index: -1,
209
+ state: "create"
210
+ });
211
+ }, []);
212
+ const handleKeyDownAddButton = react.useCallback((evt) => {
213
+ if (evt.key === "ArrowLeft") {
214
+ filterBarFocusManagement.navigateToNextItem(evt.target, "bwd");
215
+ }
216
+ }, []);
217
+ const handleCancelEdit = react.useCallback(() => {
218
+ if (interactedFilterState) {
219
+ const { index } = interactedFilterState;
220
+ if (index === -1) {
221
+ addButtonRef.current?.focus();
222
+ } else {
223
+ focusFilterPill(index);
224
+ }
225
+ setInteractedFilterState(void 0);
226
+ }
227
+ }, [focusFilterPill, interactedFilterState]);
228
+ const addButtonProps = {
229
+ ref: addButtonRef,
230
+ onClick: handleClickAddButton,
231
+ onKeyDown: handleKeyDownAddButton
232
+ };
233
+ return {
234
+ activeFilterIndex,
235
+ addButtonProps,
236
+ columnsByName,
237
+ filters,
238
+ interactedFilterState,
239
+ onCancelEdit: handleCancelEdit,
240
+ onSave: filterSaveHandler,
241
+ pillProps,
242
+ promptProps
243
+ };
244
+ };
245
+ function columnDescriptorsByName(columns) {
246
+ return columns.reduce((m, col) => ({ ...m, [col.name]: col }), {});
247
+ }
248
+
249
+ exports.useFilterBar = useFilterBar;
250
+ //# sourceMappingURL=useFilterBar.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useFilterBar.js","sources":["../../src/filter-bar/useFilterBar.ts"],"sourcesContent":["import { MenuActionHandler } from \"@vuu-ui/vuu-data-types\";\nimport { ColumnDescriptor } from \"@vuu-ui/vuu-table-types\";\nimport { ColumnDescriptorsByName, Filter } from \"@vuu-ui/vuu-filter-types\";\nimport { PromptProps } from \"@vuu-ui/vuu-popups\";\nimport {\n EditableLabelProps,\n EditAPI,\n NullEditAPI,\n} from \"@vuu-ui/vuu-ui-controls\";\nimport { getElementDataIndex, queryClosest } from \"@vuu-ui/vuu-utils\";\nimport {\n KeyboardEventHandler,\n MouseEventHandler,\n RefObject,\n useCallback,\n useMemo,\n useRef,\n useState,\n} from \"react\";\nimport { FilterPillProps } from \"../filter-pill\";\nimport { FilterMenuOptions } from \"../filter-pill-menu\";\nimport { FilterBarProps } from \"./FilterBar\";\nimport { useFilterState } from \"./useFilterState\";\nimport { useApplyFilterOnChange } from \"./useApplyFilterOnChange\";\nimport {\n FilterEditCancelHandler,\n FilterEditSaveHandler,\n} from \"../filter-editor\";\nimport { navigateToNextItem } from \"./filterBarFocusManagement\";\n\ntype InteractedFilterState = {\n filter?: Filter;\n index: number;\n state: \"create\" | \"edit\" | \"rename\";\n};\n\nexport interface FilterBarHookProps\n extends Pick<\n FilterBarProps,\n | \"columnDescriptors\"\n | \"defaultFilterState\"\n | \"filterState\"\n | \"onApplyFilter\"\n | \"onFilterDeleted\"\n | \"onFilterRenamed\"\n | \"onFilterStateChanged\"\n > {\n containerRef: RefObject<HTMLDivElement>;\n}\n\nexport const useFilterBar = ({\n columnDescriptors,\n containerRef,\n defaultFilterState,\n filterState,\n onApplyFilter,\n onFilterDeleted,\n onFilterRenamed,\n onFilterStateChanged,\n}: FilterBarHookProps) => {\n const addButtonRef = useRef<HTMLButtonElement>(null);\n const [interactedFilterState, setInteractedFilterState] = useState<\n InteractedFilterState | undefined\n >();\n const [promptProps, setPromptProps] = useState<PromptProps | null>(null);\n const editPillLabelAPI = useRef<EditAPI>(NullEditAPI);\n\n const columnsByName = useMemo(\n () => columnDescriptorsByName(columnDescriptors),\n [columnDescriptors]\n );\n\n const {\n activeFilterIndex,\n filters,\n onAddFilter,\n onChangeFilter,\n onDeleteFilter,\n onRenameFilter,\n onToggleFilterActive,\n } = useFilterState({\n defaultFilterState,\n filterState,\n onFilterDeleted,\n onFilterRenamed,\n onFilterStateChanged,\n });\n\n //TODO do we need it ?\n useApplyFilterOnChange({\n activeFilterIndex,\n columnsByName,\n filters,\n onApplyFilter,\n });\n\n const editPillLabel = useCallback((index: number, filter: Filter) => {\n setTimeout(() => {\n setInteractedFilterState({\n filter,\n index,\n state: \"rename\",\n });\n }, 100);\n }, []);\n\n const focusFilterPill = useCallback(\n (index = 0) => {\n requestAnimationFrame(() => {\n const target = containerRef.current?.querySelector(\n `.vuuFilterPill[data-index=\"${index}\"] button`\n ) as undefined | HTMLInputElement;\n if (target) {\n target.focus();\n }\n });\n },\n [containerRef]\n );\n\n const deleteConfirmed = useCallback(\n (filter: Filter) => {\n onDeleteFilter(filter);\n\n // TODO move focus to next/previous filter\n requestAnimationFrame(() => {\n if (filters.length) {\n focusFilterPill(0);\n }\n });\n },\n [filters.length, focusFilterPill, onDeleteFilter]\n );\n\n const getDeletePrompt = useMemo(\n () => (filter: Filter) => {\n const close = () => {\n setPromptProps(null);\n focusFilterPill();\n };\n return {\n confirmButtonLabel: \"Remove\",\n icon: \"warn-triangle\",\n onCancel: close,\n onClose: close,\n onConfirm: () => {\n setPromptProps(null);\n deleteConfirmed(filter);\n },\n text: `Are you sure you want to delete ${filter.name}`,\n title: \"Remove Filter\",\n variant: \"warn\",\n } as PromptProps;\n },\n [deleteConfirmed, focusFilterPill]\n );\n\n const deleteFilter = useCallback(\n (filter: Filter, withPrompt: boolean) => {\n if (withPrompt) {\n setPromptProps(getDeletePrompt(filter));\n } else {\n deleteConfirmed(filter);\n }\n },\n [deleteConfirmed, getDeletePrompt]\n );\n\n // const handleBeginEditFilterName = useCallback((filter: Filter) => {\n // editingFilterRef.current = filter;\n // }, []);\n\n // TODO handle cancel edit name\n const handleExitEditFilterName: EditableLabelProps[\"onExitEditMode\"] =\n useCallback(\n (_, editedValue = \"\") => {\n if (\n interactedFilterState?.state === \"rename\" &&\n interactedFilterState.filter\n ) {\n const { filter } = interactedFilterState;\n const indexOfEditedFilter = onRenameFilter(filter, editedValue);\n\n setInteractedFilterState(undefined);\n focusFilterPill(indexOfEditedFilter);\n }\n setInteractedFilterState(undefined);\n },\n [focusFilterPill, interactedFilterState, onRenameFilter]\n );\n\n const handlePillMenuAction = useCallback<MenuActionHandler>(\n ({ menuId, options }) => {\n switch (menuId) {\n case \"delete-filter\": {\n const { filter } = options as FilterMenuOptions;\n deleteFilter(filter, true);\n return true;\n }\n case \"rename-filter\": {\n const { filter } = options as FilterMenuOptions;\n const index = filters.indexOf(filter);\n editPillLabel(index, filter);\n return true;\n }\n case \"edit-filter\": {\n const { filter } = options as FilterMenuOptions;\n setInteractedFilterState({\n filter,\n index: filters.indexOf(filter),\n state: \"edit\",\n });\n return true;\n }\n default:\n return false;\n }\n },\n [deleteFilter, editPillLabel, filters]\n );\n\n const handlePillKeyDown = useCallback<KeyboardEventHandler>((e) => {\n if (e.key === \"ArrowRight\" || e.key === \"ArrowLeft\") {\n navigateToNextItem(e.target, e.key === \"ArrowLeft\" ? \"bwd\" : \"fwd\");\n }\n }, []);\n\n const addIfNewElseUpdate = useCallback(\n (newOrUpdatedFilter: Filter, existing: Filter | undefined) => {\n if (existing === undefined) {\n const idx = onAddFilter(newOrUpdatedFilter);\n focusFilterPill(idx);\n editPillLabel(idx, newOrUpdatedFilter);\n } else {\n const idx = onChangeFilter(existing, newOrUpdatedFilter);\n focusFilterPill(idx);\n }\n },\n [editPillLabel, focusFilterPill, onAddFilter, onChangeFilter]\n );\n\n const filterSaveHandler = useCallback<FilterEditSaveHandler>(\n (filter) => {\n if (interactedFilterState) {\n const { filter: existingFilter } = interactedFilterState;\n setInteractedFilterState(undefined);\n addIfNewElseUpdate(filter, existingFilter);\n }\n },\n [addIfNewElseUpdate, interactedFilterState]\n );\n\n const handlePillClick = useCallback<MouseEventHandler<HTMLButtonElement>>(\n (e) => {\n const isEditing = (e.target as HTMLElement).querySelector(\n \".vuuEditableLabel-editing\"\n );\n if (!isEditing) {\n const pill = queryClosest(e.target, \".vuuFilterPill\");\n if (pill) {\n const index = getElementDataIndex(pill);\n onToggleFilterActive(index, e.shiftKey);\n }\n }\n },\n [onToggleFilterActive]\n );\n\n const pillProps: Omit<FilterPillProps, \"filter\" | \"selected\"> = {\n editLabelApiRef: editPillLabelAPI,\n // onBeginEdit: handleBeginEditFilterName,\n onClick: handlePillClick,\n onKeyDown: handlePillKeyDown,\n onMenuAction: handlePillMenuAction,\n onExitEditMode: handleExitEditFilterName,\n };\n\n const handleClickAddButton = useCallback(() => {\n setInteractedFilterState({\n index: -1,\n state: \"create\",\n });\n }, []);\n\n const handleKeyDownAddButton = useCallback<KeyboardEventHandler>((evt) => {\n if (evt.key === \"ArrowLeft\") {\n navigateToNextItem(evt.target, \"bwd\");\n }\n }, []);\n\n const handleCancelEdit = useCallback<FilterEditCancelHandler>(() => {\n if (interactedFilterState) {\n const { index } = interactedFilterState;\n if (index === -1) {\n addButtonRef.current?.focus();\n } else {\n focusFilterPill(index);\n }\n setInteractedFilterState(undefined);\n }\n }, [focusFilterPill, interactedFilterState]);\n\n const addButtonProps = {\n ref: addButtonRef,\n onClick: handleClickAddButton,\n onKeyDown: handleKeyDownAddButton,\n };\n\n return {\n activeFilterIndex,\n addButtonProps,\n columnsByName,\n filters,\n interactedFilterState,\n onCancelEdit: handleCancelEdit,\n onSave: filterSaveHandler,\n pillProps,\n promptProps,\n };\n};\n\nfunction columnDescriptorsByName(\n columns: ColumnDescriptor[]\n): ColumnDescriptorsByName {\n return columns.reduce((m, col) => ({ ...m, [col.name]: col }), {});\n}\n"],"names":["useRef","useState","NullEditAPI","useMemo","useFilterState","useApplyFilterOnChange","useCallback","navigateToNextItem","queryClosest","getElementDataIndex"],"mappings":"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"}
@@ -0,0 +1,150 @@
1
+ 'use strict';
2
+
3
+ var react = require('react');
4
+ var vuuUiControls = require('@vuu-ui/vuu-ui-controls');
5
+
6
+ const getActiveIndices = (indices, toggledIndex, preserveExisting) => {
7
+ const isActive = indices.includes(toggledIndex);
8
+ if (isActive) {
9
+ if (preserveExisting) {
10
+ return indices.filter((i) => i !== toggledIndex);
11
+ } else {
12
+ return [];
13
+ }
14
+ } else {
15
+ if (preserveExisting) {
16
+ return indices.concat(toggledIndex);
17
+ } else {
18
+ return [toggledIndex];
19
+ }
20
+ }
21
+ };
22
+ const useFilterState = ({
23
+ defaultFilterState,
24
+ onFilterDeleted,
25
+ onFilterRenamed,
26
+ onFilterStateChanged,
27
+ filterState: filterStateProp
28
+ }) => {
29
+ const [filterState, setFilterState] = vuuUiControls.useControlled({
30
+ controlled: filterStateProp,
31
+ default: defaultFilterState ?? { filters: [], activeIndices: [] },
32
+ name: "useFilterState",
33
+ state: "FilterState"
34
+ });
35
+ const handleFilterStateChange = react.useCallback(
36
+ (s) => {
37
+ setFilterState(s);
38
+ onFilterStateChanged?.(s);
39
+ },
40
+ [onFilterStateChanged, setFilterState]
41
+ );
42
+ const handleAddFilter = react.useCallback(
43
+ (filter) => {
44
+ const index = filterState.filters.length;
45
+ const newFilters = filterState.filters.concat(filter);
46
+ const newIndices = appendIfNotPresent(filterState.activeIndices, index);
47
+ handleFilterStateChange({
48
+ filters: newFilters,
49
+ activeIndices: newIndices
50
+ });
51
+ return index;
52
+ },
53
+ [filterState, handleFilterStateChange]
54
+ );
55
+ const handleDeleteFilter = react.useCallback(
56
+ (filter) => {
57
+ let index = -1;
58
+ const newFilters = filterState.filters.filter((f, i) => {
59
+ if (f !== filter) {
60
+ return true;
61
+ } else {
62
+ index = i;
63
+ return false;
64
+ }
65
+ });
66
+ const newIndices = removeIndexAndDecrementLarger(
67
+ filterState.activeIndices,
68
+ index
69
+ );
70
+ handleFilterStateChange({
71
+ filters: newFilters,
72
+ activeIndices: newIndices
73
+ });
74
+ onFilterDeleted?.(filter);
75
+ return index;
76
+ },
77
+ [
78
+ filterState.filters,
79
+ filterState.activeIndices,
80
+ handleFilterStateChange,
81
+ onFilterDeleted
82
+ ]
83
+ );
84
+ const handleRenameFilter = react.useCallback(
85
+ (filter, name) => {
86
+ let index = -1;
87
+ const newFilters = filterState.filters.map((f, i) => {
88
+ if (f === filter) {
89
+ index = i;
90
+ return { ...filter, name };
91
+ } else {
92
+ return f;
93
+ }
94
+ });
95
+ handleFilterStateChange({ ...filterState, filters: newFilters });
96
+ onFilterRenamed?.(filter, name);
97
+ return index;
98
+ },
99
+ [filterState, handleFilterStateChange, onFilterRenamed]
100
+ );
101
+ const handleChangeFilter = react.useCallback(
102
+ (oldFilter, newFilter) => {
103
+ let index = -1;
104
+ const newFilters = filterState.filters.map((f, i) => {
105
+ if (f === oldFilter) {
106
+ index = i;
107
+ return newFilter;
108
+ } else {
109
+ return f;
110
+ }
111
+ });
112
+ handleFilterStateChange({ ...filterState, filters: newFilters });
113
+ return index;
114
+ },
115
+ [filterState, handleFilterStateChange]
116
+ );
117
+ const handleToggleFilterActive = react.useCallback(
118
+ (filterIndex, preserveRemainingFilters = false) => {
119
+ handleFilterStateChange({
120
+ ...filterState,
121
+ activeIndices: getActiveIndices(
122
+ filterState.activeIndices,
123
+ filterIndex,
124
+ preserveRemainingFilters
125
+ )
126
+ });
127
+ },
128
+ [filterState, handleFilterStateChange]
129
+ );
130
+ return {
131
+ activeFilterIndex: filterState.activeIndices,
132
+ filters: filterState.filters,
133
+ onToggleFilterActive: handleToggleFilterActive,
134
+ onAddFilter: handleAddFilter,
135
+ onChangeFilter: handleChangeFilter,
136
+ onDeleteFilter: handleDeleteFilter,
137
+ onRenameFilter: handleRenameFilter
138
+ };
139
+ };
140
+ const appendIfNotPresent = (ns, n) => ns.includes(n) ? ns : ns.concat(n);
141
+ const removeIndexAndDecrementLarger = (indices, idxToRemove) => {
142
+ return indices.reduce((res, i) => {
143
+ if (i === idxToRemove)
144
+ return res;
145
+ return res.concat(i > idxToRemove ? i - 1 : i);
146
+ }, []);
147
+ };
148
+
149
+ exports.useFilterState = useFilterState;
150
+ //# sourceMappingURL=useFilterState.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useFilterState.js","sources":["../../src/filter-bar/useFilterState.ts"],"sourcesContent":["import { useCallback } from \"react\";\nimport { Filter, FilterState } from \"@vuu-ui/vuu-filter-types\";\nimport { useControlled } from \"@vuu-ui/vuu-ui-controls\";\n\nexport interface FiltersHookProps {\n defaultFilterState?: FilterState;\n filterState?: FilterState;\n onFilterDeleted?: (filter: Filter) => void;\n onFilterRenamed?: (filter: Filter, name: string) => void;\n onFilterStateChanged?: (s: FilterState) => void;\n}\n\nconst getActiveIndices = (\n indices: number[],\n toggledIndex: number,\n preserveExisting: boolean\n) => {\n const isActive = indices.includes(toggledIndex);\n if (isActive) {\n if (preserveExisting) {\n return indices.filter((i) => i !== toggledIndex);\n } else {\n return [];\n }\n } else {\n if (preserveExisting) {\n return indices.concat(toggledIndex);\n } else {\n return [toggledIndex];\n }\n }\n};\n\nexport const useFilterState = ({\n defaultFilterState,\n onFilterDeleted,\n onFilterRenamed,\n onFilterStateChanged,\n filterState: filterStateProp,\n}: FiltersHookProps) => {\n const [filterState, setFilterState] = useControlled<FilterState>({\n controlled: filterStateProp,\n default: defaultFilterState ?? { filters: [], activeIndices: [] },\n name: \"useFilterState\",\n state: \"FilterState\",\n });\n\n const handleFilterStateChange = useCallback(\n (s: FilterState) => {\n setFilterState(s);\n onFilterStateChanged?.(s);\n },\n [onFilterStateChanged, setFilterState]\n );\n\n const handleAddFilter = useCallback(\n (filter: Filter) => {\n const index = filterState.filters.length;\n const newFilters = filterState.filters.concat(filter);\n const newIndices = appendIfNotPresent(filterState.activeIndices, index);\n handleFilterStateChange({\n filters: newFilters,\n activeIndices: newIndices,\n });\n return index;\n },\n [filterState, handleFilterStateChange]\n );\n\n const handleDeleteFilter = useCallback(\n (filter: Filter) => {\n let index = -1;\n const newFilters = filterState.filters.filter((f, i) => {\n if (f !== filter) {\n return true;\n } else {\n index = i;\n return false;\n }\n });\n\n const newIndices = removeIndexAndDecrementLarger(\n filterState.activeIndices,\n index\n );\n\n handleFilterStateChange({\n filters: newFilters,\n activeIndices: newIndices,\n });\n onFilterDeleted?.(filter);\n return index;\n },\n [\n filterState.filters,\n filterState.activeIndices,\n handleFilterStateChange,\n onFilterDeleted,\n ]\n );\n\n const handleRenameFilter = useCallback(\n (filter: Filter, name: string) => {\n let index = -1;\n const newFilters = filterState.filters.map((f, i) => {\n if (f === filter) {\n index = i;\n return { ...filter, name };\n } else {\n return f;\n }\n });\n handleFilterStateChange({ ...filterState, filters: newFilters });\n onFilterRenamed?.(filter, name);\n\n return index;\n },\n [filterState, handleFilterStateChange, onFilterRenamed]\n );\n\n const handleChangeFilter = useCallback(\n (oldFilter: Filter, newFilter: Filter) => {\n let index = -1;\n const newFilters = filterState.filters.map((f, i) => {\n if (f === oldFilter) {\n index = i;\n return newFilter;\n } else {\n return f;\n }\n });\n handleFilterStateChange({ ...filterState, filters: newFilters });\n\n return index;\n },\n [filterState, handleFilterStateChange]\n );\n\n const handleToggleFilterActive = useCallback(\n (filterIndex: number, preserveRemainingFilters = false) => {\n handleFilterStateChange({\n ...filterState,\n activeIndices: getActiveIndices(\n filterState.activeIndices,\n filterIndex,\n preserveRemainingFilters\n ),\n });\n },\n [filterState, handleFilterStateChange]\n );\n\n return {\n activeFilterIndex: filterState.activeIndices,\n filters: filterState.filters,\n onToggleFilterActive: handleToggleFilterActive,\n onAddFilter: handleAddFilter,\n onChangeFilter: handleChangeFilter,\n onDeleteFilter: handleDeleteFilter,\n onRenameFilter: handleRenameFilter,\n };\n};\n\nconst appendIfNotPresent = (ns: number[], n: number) =>\n ns.includes(n) ? ns : ns.concat(n);\n\nconst removeIndexAndDecrementLarger = (\n indices: number[],\n idxToRemove: number\n) => {\n return indices.reduce<number[]>((res, i) => {\n if (i === idxToRemove) return res;\n return res.concat(i > idxToRemove ? i - 1 : i);\n }, []);\n};\n"],"names":["useControlled","useCallback"],"mappings":";;;;;AAYA,MAAM,gBAAmB,GAAA,CACvB,OACA,EAAA,YAAA,EACA,gBACG,KAAA;AACH,EAAM,MAAA,QAAA,GAAW,OAAQ,CAAA,QAAA,CAAS,YAAY,CAAA,CAAA;AAC9C,EAAA,IAAI,QAAU,EAAA;AACZ,IAAA,IAAI,gBAAkB,EAAA;AACpB,MAAA,OAAO,OAAQ,CAAA,MAAA,CAAO,CAAC,CAAA,KAAM,MAAM,YAAY,CAAA,CAAA;AAAA,KAC1C,MAAA;AACL,MAAA,OAAO,EAAC,CAAA;AAAA,KACV;AAAA,GACK,MAAA;AACL,IAAA,IAAI,gBAAkB,EAAA;AACpB,MAAO,OAAA,OAAA,CAAQ,OAAO,YAAY,CAAA,CAAA;AAAA,KAC7B,MAAA;AACL,MAAA,OAAO,CAAC,YAAY,CAAA,CAAA;AAAA,KACtB;AAAA,GACF;AACF,CAAA,CAAA;AAEO,MAAM,iBAAiB,CAAC;AAAA,EAC7B,kBAAA;AAAA,EACA,eAAA;AAAA,EACA,eAAA;AAAA,EACA,oBAAA;AAAA,EACA,WAAa,EAAA,eAAA;AACf,CAAwB,KAAA;AACtB,EAAA,MAAM,CAAC,WAAA,EAAa,cAAc,CAAA,GAAIA,2BAA2B,CAAA;AAAA,IAC/D,UAAY,EAAA,eAAA;AAAA,IACZ,OAAA,EAAS,sBAAsB,EAAE,OAAA,EAAS,EAAI,EAAA,aAAA,EAAe,EAAG,EAAA;AAAA,IAChE,IAAM,EAAA,gBAAA;AAAA,IACN,KAAO,EAAA,aAAA;AAAA,GACR,CAAA,CAAA;AAED,EAAA,MAAM,uBAA0B,GAAAC,iBAAA;AAAA,IAC9B,CAAC,CAAmB,KAAA;AAClB,MAAA,cAAA,CAAe,CAAC,CAAA,CAAA;AAChB,MAAA,oBAAA,GAAuB,CAAC,CAAA,CAAA;AAAA,KAC1B;AAAA,IACA,CAAC,sBAAsB,cAAc,CAAA;AAAA,GACvC,CAAA;AAEA,EAAA,MAAM,eAAkB,GAAAA,iBAAA;AAAA,IACtB,CAAC,MAAmB,KAAA;AAClB,MAAM,MAAA,KAAA,GAAQ,YAAY,OAAQ,CAAA,MAAA,CAAA;AAClC,MAAA,MAAM,UAAa,GAAA,WAAA,CAAY,OAAQ,CAAA,MAAA,CAAO,MAAM,CAAA,CAAA;AACpD,MAAA,MAAM,UAAa,GAAA,kBAAA,CAAmB,WAAY,CAAA,aAAA,EAAe,KAAK,CAAA,CAAA;AACtE,MAAwB,uBAAA,CAAA;AAAA,QACtB,OAAS,EAAA,UAAA;AAAA,QACT,aAAe,EAAA,UAAA;AAAA,OAChB,CAAA,CAAA;AACD,MAAO,OAAA,KAAA,CAAA;AAAA,KACT;AAAA,IACA,CAAC,aAAa,uBAAuB,CAAA;AAAA,GACvC,CAAA;AAEA,EAAA,MAAM,kBAAqB,GAAAA,iBAAA;AAAA,IACzB,CAAC,MAAmB,KAAA;AAClB,MAAA,IAAI,KAAQ,GAAA,CAAA,CAAA,CAAA;AACZ,MAAA,MAAM,aAAa,WAAY,CAAA,OAAA,CAAQ,MAAO,CAAA,CAAC,GAAG,CAAM,KAAA;AACtD,QAAA,IAAI,MAAM,MAAQ,EAAA;AAChB,UAAO,OAAA,IAAA,CAAA;AAAA,SACF,MAAA;AACL,UAAQ,KAAA,GAAA,CAAA,CAAA;AACR,UAAO,OAAA,KAAA,CAAA;AAAA,SACT;AAAA,OACD,CAAA,CAAA;AAED,MAAA,MAAM,UAAa,GAAA,6BAAA;AAAA,QACjB,WAAY,CAAA,aAAA;AAAA,QACZ,KAAA;AAAA,OACF,CAAA;AAEA,MAAwB,uBAAA,CAAA;AAAA,QACtB,OAAS,EAAA,UAAA;AAAA,QACT,aAAe,EAAA,UAAA;AAAA,OAChB,CAAA,CAAA;AACD,MAAA,eAAA,GAAkB,MAAM,CAAA,CAAA;AACxB,MAAO,OAAA,KAAA,CAAA;AAAA,KACT;AAAA,IACA;AAAA,MACE,WAAY,CAAA,OAAA;AAAA,MACZ,WAAY,CAAA,aAAA;AAAA,MACZ,uBAAA;AAAA,MACA,eAAA;AAAA,KACF;AAAA,GACF,CAAA;AAEA,EAAA,MAAM,kBAAqB,GAAAA,iBAAA;AAAA,IACzB,CAAC,QAAgB,IAAiB,KAAA;AAChC,MAAA,IAAI,KAAQ,GAAA,CAAA,CAAA,CAAA;AACZ,MAAA,MAAM,aAAa,WAAY,CAAA,OAAA,CAAQ,GAAI,CAAA,CAAC,GAAG,CAAM,KAAA;AACnD,QAAA,IAAI,MAAM,MAAQ,EAAA;AAChB,UAAQ,KAAA,GAAA,CAAA,CAAA;AACR,UAAO,OAAA,EAAE,GAAG,MAAA,EAAQ,IAAK,EAAA,CAAA;AAAA,SACpB,MAAA;AACL,UAAO,OAAA,CAAA,CAAA;AAAA,SACT;AAAA,OACD,CAAA,CAAA;AACD,MAAA,uBAAA,CAAwB,EAAE,GAAG,WAAa,EAAA,OAAA,EAAS,YAAY,CAAA,CAAA;AAC/D,MAAA,eAAA,GAAkB,QAAQ,IAAI,CAAA,CAAA;AAE9B,MAAO,OAAA,KAAA,CAAA;AAAA,KACT;AAAA,IACA,CAAC,WAAa,EAAA,uBAAA,EAAyB,eAAe,CAAA;AAAA,GACxD,CAAA;AAEA,EAAA,MAAM,kBAAqB,GAAAA,iBAAA;AAAA,IACzB,CAAC,WAAmB,SAAsB,KAAA;AACxC,MAAA,IAAI,KAAQ,GAAA,CAAA,CAAA,CAAA;AACZ,MAAA,MAAM,aAAa,WAAY,CAAA,OAAA,CAAQ,GAAI,CAAA,CAAC,GAAG,CAAM,KAAA;AACnD,QAAA,IAAI,MAAM,SAAW,EAAA;AACnB,UAAQ,KAAA,GAAA,CAAA,CAAA;AACR,UAAO,OAAA,SAAA,CAAA;AAAA,SACF,MAAA;AACL,UAAO,OAAA,CAAA,CAAA;AAAA,SACT;AAAA,OACD,CAAA,CAAA;AACD,MAAA,uBAAA,CAAwB,EAAE,GAAG,WAAa,EAAA,OAAA,EAAS,YAAY,CAAA,CAAA;AAE/D,MAAO,OAAA,KAAA,CAAA;AAAA,KACT;AAAA,IACA,CAAC,aAAa,uBAAuB,CAAA;AAAA,GACvC,CAAA;AAEA,EAAA,MAAM,wBAA2B,GAAAA,iBAAA;AAAA,IAC/B,CAAC,WAAqB,EAAA,wBAAA,GAA2B,KAAU,KAAA;AACzD,MAAwB,uBAAA,CAAA;AAAA,QACtB,GAAG,WAAA;AAAA,QACH,aAAe,EAAA,gBAAA;AAAA,UACb,WAAY,CAAA,aAAA;AAAA,UACZ,WAAA;AAAA,UACA,wBAAA;AAAA,SACF;AAAA,OACD,CAAA,CAAA;AAAA,KACH;AAAA,IACA,CAAC,aAAa,uBAAuB,CAAA;AAAA,GACvC,CAAA;AAEA,EAAO,OAAA;AAAA,IACL,mBAAmB,WAAY,CAAA,aAAA;AAAA,IAC/B,SAAS,WAAY,CAAA,OAAA;AAAA,IACrB,oBAAsB,EAAA,wBAAA;AAAA,IACtB,WAAa,EAAA,eAAA;AAAA,IACb,cAAgB,EAAA,kBAAA;AAAA,IAChB,cAAgB,EAAA,kBAAA;AAAA,IAChB,cAAgB,EAAA,kBAAA;AAAA,GAClB,CAAA;AACF,EAAA;AAEA,MAAM,kBAAA,GAAqB,CAAC,EAAA,EAAc,CACxC,KAAA,EAAA,CAAG,QAAS,CAAA,CAAC,CAAI,GAAA,EAAA,GAAK,EAAG,CAAA,MAAA,CAAO,CAAC,CAAA,CAAA;AAEnC,MAAM,6BAAA,GAAgC,CACpC,OAAA,EACA,WACG,KAAA;AACH,EAAA,OAAO,OAAQ,CAAA,MAAA,CAAiB,CAAC,GAAA,EAAK,CAAM,KAAA;AAC1C,IAAA,IAAI,CAAM,KAAA,WAAA;AAAa,MAAO,OAAA,GAAA,CAAA;AAC9B,IAAA,OAAO,IAAI,MAAO,CAAA,CAAA,GAAI,WAAc,GAAA,CAAA,GAAI,IAAI,CAAC,CAAA,CAAA;AAAA,GAC/C,EAAG,EAAE,CAAA,CAAA;AACP,CAAA;;;;"}
@@ -0,0 +1,6 @@
1
+ 'use strict';
2
+
3
+ var expandoBoxCss = ".vuuExpandoCombobox {\n --expando-combobox-height: var(--vuuExpandoCombobox-height, var(--salt-size-base));\n --expando-combobox-fontSize: var(--vuuExpandoCombobox-fontSize, 12px);\n\n --saltInput-outline: none;\n --saltInput-fontSize: var(--expando-combobox-fontSize);\n --saltInput-height: var(--expando-combobox-height);\n --saltInput-minWidth: 4px;\n\n display: inline-flex;\n flex-direction: column;\n height: var(--expando-combobox-height);\n min-width: 4px;\n padding: 0;\n}\n\n.vuuExpandoCombobox .saltInput {\n background-color: transparent;\n position: absolute;\n}\n\n.vuuExpandoCombobox .vuuDropdown {\n height: 100%;\n}\n\n/** double up the selector just to increase specificity, won't need when we use cascade layers */\n.vuuExpandoCombobox-Input.saltInput {\n border: none;\n left: 0px;\n margin: 0;\n min-height: 100%;\n padding: 0;\n right: 0px;\n width: auto;\n}\n\n.vuuExpandoCombobox .saltInput-input {\n border: none;\n box-sizing: content-box;\n display: block;\n flex: 1;\n font: inherit;\n margin: 0;\n min-width: 0;\n outline: none;\n padding: 0;\n}\n\n.vuuExpandoCombobox:before {\n content: attr(data-text);\n display: block;\n font-size: var(--expando-combobox-fontSize);\n height: 0px;\n overflow: hidden;\n /* visibility: hidden; */\n white-space: pre-wrap;\n /* position: absolute; */\n}\n";
4
+
5
+ module.exports = expandoBoxCss;
6
+ //# sourceMappingURL=ExpandoCombobox.css.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ExpandoCombobox.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;"}