@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.
- package/LICENSE +201 -0
- package/README.md +0 -0
- package/cjs/FilterModel.js +233 -0
- package/cjs/FilterModel.js.map +1 -0
- package/cjs/filter-bar/FilterBar.css.js +6 -0
- package/cjs/filter-bar/FilterBar.css.js.map +1 -0
- package/cjs/filter-bar/FilterBar.js +134 -0
- package/cjs/filter-bar/FilterBar.js.map +1 -0
- package/cjs/filter-bar/FilterBarMenu.js +12 -0
- package/cjs/filter-bar/FilterBarMenu.js.map +1 -0
- package/cjs/filter-bar/filterBarFocusManagement.js +35 -0
- package/cjs/filter-bar/filterBarFocusManagement.js.map +1 -0
- package/cjs/filter-bar/useApplyFilterOnChange.js +33 -0
- package/cjs/filter-bar/useApplyFilterOnChange.js.map +1 -0
- package/cjs/filter-bar/useFilterBar.js +250 -0
- package/cjs/filter-bar/useFilterBar.js.map +1 -0
- package/cjs/filter-bar/useFilterState.js +150 -0
- package/cjs/filter-bar/useFilterState.js.map +1 -0
- package/cjs/filter-clause/ExpandoCombobox.css.js +6 -0
- package/cjs/filter-clause/ExpandoCombobox.css.js.map +1 -0
- package/cjs/filter-clause/ExpandoCombobox.js +148 -0
- package/cjs/filter-clause/ExpandoCombobox.js.map +1 -0
- package/cjs/filter-clause/FilterClause.css.js +6 -0
- package/cjs/filter-clause/FilterClause.css.js.map +1 -0
- package/cjs/filter-clause/FilterClause.js +112 -0
- package/cjs/filter-clause/FilterClause.js.map +1 -0
- package/cjs/filter-clause/filterClauseFocusManagement.js +203 -0
- package/cjs/filter-clause/filterClauseFocusManagement.js.map +1 -0
- package/cjs/filter-clause/operator-utils.js +20 -0
- package/cjs/filter-clause/operator-utils.js.map +1 -0
- package/cjs/filter-clause/useFilterClause.js +142 -0
- package/cjs/filter-clause/useFilterClause.js.map +1 -0
- package/cjs/filter-clause/value-editors/FilterClauseValueEditor.js +77 -0
- package/cjs/filter-clause/value-editors/FilterClauseValueEditor.js.map +1 -0
- package/cjs/filter-clause/value-editors/FilterClauseValueEditorDate.js +75 -0
- package/cjs/filter-clause/value-editors/FilterClauseValueEditorDate.js.map +1 -0
- package/cjs/filter-clause/value-editors/FilterClauseValueEditorNumber.js +55 -0
- package/cjs/filter-clause/value-editors/FilterClauseValueEditorNumber.js.map +1 -0
- package/cjs/filter-clause/value-editors/FilterClauseValueEditorText.js +193 -0
- package/cjs/filter-clause/value-editors/FilterClauseValueEditorText.js.map +1 -0
- package/cjs/filter-editor/FilterClauseCombinator.css.js +6 -0
- package/cjs/filter-editor/FilterClauseCombinator.css.js.map +1 -0
- package/cjs/filter-editor/FilterClauseCombinator.js +42 -0
- package/cjs/filter-editor/FilterClauseCombinator.js.map +1 -0
- package/cjs/filter-editor/FilterEditor.css.js +6 -0
- package/cjs/filter-editor/FilterEditor.css.js.map +1 -0
- package/cjs/filter-editor/FilterEditor.js +97 -0
- package/cjs/filter-editor/FilterEditor.js.map +1 -0
- package/cjs/filter-editor/useFilterEditor.js +188 -0
- package/cjs/filter-editor/useFilterEditor.js.map +1 -0
- package/cjs/filter-input/FilterInput.css.js +6 -0
- package/cjs/filter-input/FilterInput.css.js.map +1 -0
- package/cjs/filter-input/FilterInput.js +52 -0
- package/cjs/filter-input/FilterInput.js.map +1 -0
- package/cjs/filter-input/FilterLanguage.js +24 -0
- package/cjs/filter-input/FilterLanguage.js.map +1 -0
- package/cjs/filter-input/filterInfo.js +17 -0
- package/cjs/filter-input/filterInfo.js.map +1 -0
- package/cjs/filter-input/highlighting.js +12 -0
- package/cjs/filter-input/highlighting.js.map +1 -0
- package/cjs/filter-input/theme.js +79 -0
- package/cjs/filter-input/theme.js.map +1 -0
- package/cjs/filter-input/useCodeMirrorEditor.js +136 -0
- package/cjs/filter-input/useCodeMirrorEditor.js.map +1 -0
- package/cjs/filter-input/useFilterAutoComplete.js +243 -0
- package/cjs/filter-input/useFilterAutoComplete.js.map +1 -0
- package/cjs/filter-input/useFilterSuggestionProvider.js +206 -0
- package/cjs/filter-input/useFilterSuggestionProvider.js.map +1 -0
- package/cjs/filter-pill/FilterPill.css.js +6 -0
- package/cjs/filter-pill/FilterPill.css.js.map +1 -0
- package/cjs/filter-pill/FilterPill.js +147 -0
- package/cjs/filter-pill/FilterPill.js.map +1 -0
- package/cjs/filter-pill/FilterPillMenuOptions.js +32 -0
- package/cjs/filter-pill/FilterPillMenuOptions.js.map +1 -0
- package/cjs/filter-pill/filterAsReactNode.js +27 -0
- package/cjs/filter-pill/filterAsReactNode.js.map +1 -0
- package/cjs/filter-pill/getFilterLabel.js +22 -0
- package/cjs/filter-pill/getFilterLabel.js.map +1 -0
- package/cjs/filter-pill/getFilterTooltipText.js +41 -0
- package/cjs/filter-pill/getFilterTooltipText.js.map +1 -0
- package/cjs/filter-utils.js +328 -0
- package/cjs/filter-utils.js.map +1 -0
- package/cjs/index.js +50 -0
- package/cjs/index.js.map +1 -0
- package/cjs/use-filter-config.js +39 -0
- package/cjs/use-filter-config.js.map +1 -0
- package/cjs/use-rest-config.js +63 -0
- package/cjs/use-rest-config.js.map +1 -0
- package/esm/FilterModel.js +230 -0
- package/esm/FilterModel.js.map +1 -0
- package/esm/filter-bar/FilterBar.css.js +4 -0
- package/esm/filter-bar/FilterBar.css.js.map +1 -0
- package/esm/filter-bar/FilterBar.js +132 -0
- package/esm/filter-bar/FilterBar.js.map +1 -0
- package/esm/filter-bar/FilterBarMenu.js +10 -0
- package/esm/filter-bar/FilterBarMenu.js.map +1 -0
- package/esm/filter-bar/filterBarFocusManagement.js +33 -0
- package/esm/filter-bar/filterBarFocusManagement.js.map +1 -0
- package/esm/filter-bar/useApplyFilterOnChange.js +31 -0
- package/esm/filter-bar/useApplyFilterOnChange.js.map +1 -0
- package/esm/filter-bar/useFilterBar.js +248 -0
- package/esm/filter-bar/useFilterBar.js.map +1 -0
- package/esm/filter-bar/useFilterState.js +148 -0
- package/esm/filter-bar/useFilterState.js.map +1 -0
- package/esm/filter-clause/ExpandoCombobox.css.js +4 -0
- package/esm/filter-clause/ExpandoCombobox.css.js.map +1 -0
- package/esm/filter-clause/ExpandoCombobox.js +146 -0
- package/esm/filter-clause/ExpandoCombobox.js.map +1 -0
- package/esm/filter-clause/FilterClause.css.js +4 -0
- package/esm/filter-clause/FilterClause.css.js.map +1 -0
- package/esm/filter-clause/FilterClause.js +110 -0
- package/esm/filter-clause/FilterClause.js.map +1 -0
- package/esm/filter-clause/filterClauseFocusManagement.js +189 -0
- package/esm/filter-clause/filterClauseFocusManagement.js.map +1 -0
- package/esm/filter-clause/operator-utils.js +16 -0
- package/esm/filter-clause/operator-utils.js.map +1 -0
- package/esm/filter-clause/useFilterClause.js +140 -0
- package/esm/filter-clause/useFilterClause.js.map +1 -0
- package/esm/filter-clause/value-editors/FilterClauseValueEditor.js +75 -0
- package/esm/filter-clause/value-editors/FilterClauseValueEditor.js.map +1 -0
- package/esm/filter-clause/value-editors/FilterClauseValueEditorDate.js +73 -0
- package/esm/filter-clause/value-editors/FilterClauseValueEditorDate.js.map +1 -0
- package/esm/filter-clause/value-editors/FilterClauseValueEditorNumber.js +53 -0
- package/esm/filter-clause/value-editors/FilterClauseValueEditorNumber.js.map +1 -0
- package/esm/filter-clause/value-editors/FilterClauseValueEditorText.js +191 -0
- package/esm/filter-clause/value-editors/FilterClauseValueEditorText.js.map +1 -0
- package/esm/filter-editor/FilterClauseCombinator.css.js +4 -0
- package/esm/filter-editor/FilterClauseCombinator.css.js.map +1 -0
- package/esm/filter-editor/FilterClauseCombinator.js +40 -0
- package/esm/filter-editor/FilterClauseCombinator.js.map +1 -0
- package/esm/filter-editor/FilterEditor.css.js +4 -0
- package/esm/filter-editor/FilterEditor.css.js.map +1 -0
- package/esm/filter-editor/FilterEditor.js +95 -0
- package/esm/filter-editor/FilterEditor.js.map +1 -0
- package/esm/filter-editor/useFilterEditor.js +186 -0
- package/esm/filter-editor/useFilterEditor.js.map +1 -0
- package/esm/filter-input/FilterInput.css.js +4 -0
- package/esm/filter-input/FilterInput.css.js.map +1 -0
- package/esm/filter-input/FilterInput.js +50 -0
- package/esm/filter-input/FilterInput.js.map +1 -0
- package/esm/filter-input/FilterLanguage.js +22 -0
- package/esm/filter-input/FilterLanguage.js.map +1 -0
- package/esm/filter-input/filterInfo.js +15 -0
- package/esm/filter-input/filterInfo.js.map +1 -0
- package/esm/filter-input/highlighting.js +10 -0
- package/esm/filter-input/highlighting.js.map +1 -0
- package/esm/filter-input/theme.js +77 -0
- package/esm/filter-input/theme.js.map +1 -0
- package/esm/filter-input/useCodeMirrorEditor.js +134 -0
- package/esm/filter-input/useCodeMirrorEditor.js.map +1 -0
- package/esm/filter-input/useFilterAutoComplete.js +241 -0
- package/esm/filter-input/useFilterAutoComplete.js.map +1 -0
- package/esm/filter-input/useFilterSuggestionProvider.js +204 -0
- package/esm/filter-input/useFilterSuggestionProvider.js.map +1 -0
- package/esm/filter-pill/FilterPill.css.js +4 -0
- package/esm/filter-pill/FilterPill.css.js.map +1 -0
- package/esm/filter-pill/FilterPill.js +145 -0
- package/esm/filter-pill/FilterPill.js.map +1 -0
- package/esm/filter-pill/FilterPillMenuOptions.js +27 -0
- package/esm/filter-pill/FilterPillMenuOptions.js.map +1 -0
- package/esm/filter-pill/filterAsReactNode.js +25 -0
- package/esm/filter-pill/filterAsReactNode.js.map +1 -0
- package/esm/filter-pill/getFilterLabel.js +20 -0
- package/esm/filter-pill/getFilterLabel.js.map +1 -0
- package/esm/filter-pill/getFilterTooltipText.js +39 -0
- package/esm/filter-pill/getFilterTooltipText.js.map +1 -0
- package/esm/filter-utils.js +307 -0
- package/esm/filter-utils.js.map +1 -0
- package/esm/index.js +13 -0
- package/esm/index.js.map +1 -0
- package/esm/use-filter-config.js +37 -0
- package/esm/use-filter-config.js.map +1 -0
- package/esm/use-rest-config.js +61 -0
- package/esm/use-rest-config.js.map +1 -0
- package/package.json +48 -0
- package/types/FilterModel.d.ts +43 -0
- package/types/column-filter/utils.d.ts +4 -0
- package/types/filter-bar/FilterBar.d.ts +22 -0
- package/types/filter-bar/FilterBarMenu.d.ts +2 -0
- package/types/filter-bar/filterBarFocusManagement.d.ts +1 -0
- package/types/filter-bar/index.d.ts +1 -0
- package/types/filter-bar/useApplyFilterOnChange.d.ts +10 -0
- package/types/filter-bar/useFilterBar.d.ts +30 -0
- package/types/filter-bar/useFilterState.d.ts +17 -0
- package/types/filter-clause/ExpandoCombobox.d.ts +10 -0
- package/types/filter-clause/FilterClause.d.ts +17 -0
- package/types/filter-clause/FilterMenu.d.ts +10 -0
- package/types/filter-clause/FilterMenuOptions.d.ts +6 -0
- package/types/filter-clause/filterClauseFocusManagement.d.ts +16 -0
- package/types/filter-clause/filterClauseTypes.d.ts +13 -0
- package/types/filter-clause/index.d.ts +3 -0
- package/types/filter-clause/operator-utils.d.ts +4 -0
- package/types/filter-clause/useFilterClause.d.ts +24 -0
- package/types/filter-clause/value-editors/FilterClauseValueEditor.d.ts +13 -0
- package/types/filter-clause/value-editors/FilterClauseValueEditorDate.d.ts +10 -0
- package/types/filter-clause/value-editors/FilterClauseValueEditorNumber.d.ts +10 -0
- package/types/filter-clause/value-editors/FilterClauseValueEditorText.d.ts +11 -0
- package/types/filter-editor/FilterClauseCombinator.d.ts +9 -0
- package/types/filter-editor/FilterEditor.d.ts +16 -0
- package/types/filter-editor/index.d.ts +1 -0
- package/types/filter-editor/useFilterEditor.d.ts +31 -0
- package/types/filter-input/FilterInput.d.ts +10 -0
- package/types/filter-input/FilterLanguage.d.ts +2 -0
- package/types/filter-input/filterInfo.d.ts +1 -0
- package/types/filter-input/highlighting.d.ts +1 -0
- package/types/filter-input/index.d.ts +3 -0
- package/types/filter-input/theme.d.ts +1 -0
- package/types/filter-input/useCodeMirrorEditor.d.ts +35 -0
- package/types/filter-input/useFilterAutoComplete.d.ts +9 -0
- package/types/filter-input/useFilterSuggestionProvider.d.ts +16 -0
- package/types/filter-pill/FilterPill.d.ts +17 -0
- package/types/filter-pill/FilterPillMenuOptions.d.ts +12 -0
- package/types/filter-pill/filterAsReactNode.d.ts +3 -0
- package/types/filter-pill/getFilterLabel.d.ts +2 -0
- package/types/filter-pill/getFilterTooltipText.d.ts +2 -0
- package/types/filter-pill/index.d.ts +1 -0
- package/types/filter-pill-menu/FilterPillMenu.d.ts +18 -0
- package/types/filter-pill-menu/FilterPillMenuOptions.d.ts +12 -0
- package/types/filter-pill-menu/index.d.ts +1 -0
- package/types/filter-utils.d.ts +48 -0
- package/types/index.d.ts +8 -0
- package/types/use-filter-config.d.ts +12 -0
- 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":"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"}
|
|
@@ -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":";;;;;;"}
|