@navikt/ds-react 8.6.0 → 8.8.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/cjs/alert/base-alert/root/BaseAlertRoot.js +1 -2
- package/cjs/alert/base-alert/root/BaseAlertRoot.js.map +1 -1
- package/cjs/alert/info-card/index.d.ts +2 -2
- package/cjs/alert/info-card/index.js +2 -1
- package/cjs/alert/info-card/index.js.map +1 -1
- package/cjs/alert/info-card/message/InfoCardMessage.d.ts +23 -0
- package/cjs/alert/info-card/message/InfoCardMessage.js +73 -0
- package/cjs/alert/info-card/message/InfoCardMessage.js.map +1 -0
- package/cjs/alert/info-card/root/InfoCardRoot.d.ts +15 -2
- package/cjs/alert/info-card/root/InfoCardRoot.js +4 -1
- package/cjs/alert/info-card/root/InfoCardRoot.js.map +1 -1
- package/cjs/data/drag-and-drop/drag-handler/DataDragAndDropDragHandler.d.ts +21 -0
- package/cjs/data/drag-and-drop/drag-handler/DataDragAndDropDragHandler.js +24 -0
- package/cjs/data/drag-and-drop/drag-handler/DataDragAndDropDragHandler.js.map +1 -0
- package/cjs/data/drag-and-drop/item/DataDragAndDropItem.d.ts +27 -0
- package/cjs/data/drag-and-drop/item/DataDragAndDropItem.js +41 -0
- package/cjs/data/drag-and-drop/item/DataDragAndDropItem.js.map +1 -0
- package/cjs/data/drag-and-drop/root/DataDragAndDrop.context.d.ts +8 -0
- package/cjs/data/drag-and-drop/root/DataDragAndDrop.context.js +10 -0
- package/cjs/data/drag-and-drop/root/DataDragAndDrop.context.js.map +1 -0
- package/cjs/data/drag-and-drop/root/DataDragAndDropRoot.d.ts +34 -0
- package/cjs/data/drag-and-drop/root/DataDragAndDropRoot.js +61 -0
- package/cjs/data/drag-and-drop/root/DataDragAndDropRoot.js.map +1 -0
- package/cjs/data/drag-and-drop-old/drag-handler/DataDragAndDropDragHandler.d.ts +22 -0
- package/cjs/data/drag-and-drop-old/drag-handler/DataDragAndDropDragHandler.js +35 -0
- package/cjs/data/drag-and-drop-old/drag-handler/DataDragAndDropDragHandler.js.map +1 -0
- package/cjs/data/drag-and-drop-old/item/DataDragAndDropItem.d.ts +27 -0
- package/cjs/data/drag-and-drop-old/item/DataDragAndDropItem.js +86 -0
- package/cjs/data/drag-and-drop-old/item/DataDragAndDropItem.js.map +1 -0
- package/cjs/data/drag-and-drop-old/root/DataDragAndDrop.context.d.ts +5 -0
- package/cjs/data/drag-and-drop-old/root/DataDragAndDrop.context.js +6 -0
- package/cjs/data/drag-and-drop-old/root/DataDragAndDrop.context.js.map +1 -0
- package/cjs/data/drag-and-drop-old/root/DataDragAndDropRoot.d.ts +24 -0
- package/cjs/data/drag-and-drop-old/root/DataDragAndDropRoot.js +108 -0
- package/cjs/data/drag-and-drop-old/root/DataDragAndDropRoot.js.map +1 -0
- package/cjs/data/table/empty-state/DataTableEmptyState.d.ts +5 -0
- package/cjs/data/table/empty-state/DataTableEmptyState.js +57 -0
- package/cjs/data/table/empty-state/DataTableEmptyState.js.map +1 -0
- package/cjs/data/table/helpers/table-focus.js +7 -1
- package/cjs/data/table/helpers/table-focus.js.map +1 -1
- package/cjs/data/table/helpers/table-keyboard.js +1 -1
- package/cjs/data/table/helpers/table-keyboard.js.map +1 -1
- package/cjs/data/table/loading-state/DataTableLoadingState.d.ts +5 -0
- package/cjs/data/table/loading-state/DataTableLoadingState.js +57 -0
- package/cjs/data/table/loading-state/DataTableLoadingState.js.map +1 -0
- package/cjs/data/table/root/DataTable.types.d.ts +13 -0
- package/cjs/data/table/root/DataTable.types.js +3 -0
- package/cjs/data/table/root/DataTable.types.js.map +1 -0
- package/cjs/data/table/root/DataTableAuto.d.ts +60 -0
- package/cjs/data/table/root/DataTableAuto.js +99 -0
- package/cjs/data/table/root/DataTableAuto.js.map +1 -0
- package/cjs/data/table/root/DataTableRoot.context.d.ts +9 -0
- package/cjs/data/table/root/DataTableRoot.context.js +11 -0
- package/cjs/data/table/root/DataTableRoot.context.js.map +1 -0
- package/cjs/data/table/root/DataTableRoot.d.ts +30 -3
- package/cjs/data/table/root/DataTableRoot.js +12 -4
- package/cjs/data/table/root/DataTableRoot.js.map +1 -1
- package/cjs/data/table/root/useTableKeyboardNav.js +1 -0
- package/cjs/data/table/root/useTableKeyboardNav.js.map +1 -1
- package/cjs/data/table/root/useTableSelection.d.ts +55 -0
- package/cjs/data/table/root/useTableSelection.js +79 -0
- package/cjs/data/table/root/useTableSelection.js.map +1 -0
- package/cjs/data/table/td/DataTableTd.d.ts +10 -0
- package/cjs/data/table/td/DataTableTd.js +4 -2
- package/cjs/data/table/td/DataTableTd.js.map +1 -1
- package/cjs/data/table/th/DataTableTh.d.ts +27 -5
- package/cjs/data/table/th/DataTableTh.js +49 -22
- package/cjs/data/table/th/DataTableTh.js.map +1 -1
- package/cjs/data/table/th/useTableColumnResize.d.ts +64 -0
- package/cjs/data/table/th/useTableColumnResize.js +144 -0
- package/cjs/data/table/th/useTableColumnResize.js.map +1 -0
- package/cjs/data/table/thead/DataTableThead.context.d.ts +4 -0
- package/cjs/data/table/thead/DataTableThead.context.js +45 -0
- package/cjs/data/table/thead/DataTableThead.context.js.map +1 -0
- package/cjs/data/table/thead/DataTableThead.js +3 -1
- package/cjs/data/table/thead/DataTableThead.js.map +1 -1
- package/cjs/data/table/tr/DataTableTr.js +10 -2
- package/cjs/data/table/tr/DataTableTr.js.map +1 -1
- package/cjs/data/token-filter/AutoSuggest.d.ts +6 -2
- package/cjs/data/token-filter/AutoSuggest.js +44 -11
- package/cjs/data/token-filter/AutoSuggest.js.map +1 -1
- package/cjs/data/token-filter/TokenFilter.d.ts +5 -5
- package/cjs/data/token-filter/TokenFilter.js +105 -42
- package/cjs/data/token-filter/TokenFilter.js.map +1 -1
- package/cjs/data/token-filter/TokenFilter.types.d.ts +51 -33
- package/cjs/data/token-filter/helpers/generate-autocomplete-options.d.ts +2 -3
- package/cjs/data/token-filter/helpers/generate-autocomplete-options.js +11 -15
- package/cjs/data/token-filter/helpers/generate-autocomplete-options.js.map +1 -1
- package/cjs/data/token-filter/helpers/operators.d.ts +6 -6
- package/cjs/data/token-filter/helpers/operators.js +3 -4
- package/cjs/data/token-filter/helpers/operators.js.map +1 -1
- package/cjs/data/token-filter/helpers/parse-query-text.d.ts +2 -20
- package/cjs/data/token-filter/helpers/parse-query-text.js +1 -1
- package/cjs/data/token-filter/helpers/parse-query-text.js.map +1 -1
- package/cjs/data/token-filter/helpers/query-builder.d.ts +2 -2
- package/cjs/data/token-filter/helpers/query-builder.js.map +1 -1
- package/cjs/date/Date.Dialog.d.ts +5 -1
- package/cjs/date/Date.Dialog.js +6 -2
- package/cjs/date/Date.Dialog.js.map +1 -1
- package/cjs/date/Date.Input.js +1 -1
- package/cjs/date/Date.Input.js.map +1 -1
- package/cjs/date/datepicker/DatePicker.js +3 -2
- package/cjs/date/datepicker/DatePicker.js.map +1 -1
- package/cjs/date/datepicker/hooks/useDatepicker.d.ts +12 -1
- package/cjs/date/datepicker/hooks/useDatepicker.js +5 -2
- package/cjs/date/datepicker/hooks/useDatepicker.js.map +1 -1
- package/cjs/date/datepicker/hooks/useRangeDatepicker.js +3 -1
- package/cjs/date/datepicker/hooks/useRangeDatepicker.js.map +1 -1
- package/cjs/date/datepicker/parts/DatePicker.Months.d.ts +2 -1
- package/cjs/date/datepicker/parts/DatePicker.Months.js +3 -3
- package/cjs/date/datepicker/parts/DatePicker.Months.js.map +1 -1
- package/cjs/date/datepicker/parts/DatePicker.RDP.d.ts +5 -1
- package/cjs/date/datepicker/parts/DatePicker.RDP.js +2 -2
- package/cjs/date/datepicker/parts/DatePicker.RDP.js.map +1 -1
- package/cjs/date/monthpicker/MonthPicker.js +3 -2
- package/cjs/date/monthpicker/MonthPicker.js.map +1 -1
- package/cjs/date/monthpicker/hooks/useMonthPicker.d.ts +11 -1
- package/cjs/date/monthpicker/hooks/useMonthPicker.js +3 -1
- package/cjs/date/monthpicker/hooks/useMonthPicker.js.map +1 -1
- package/cjs/date/monthpicker/parts/MonthPicker.Caption.d.ts +4 -1
- package/cjs/date/monthpicker/parts/MonthPicker.Caption.js +3 -2
- package/cjs/date/monthpicker/parts/MonthPicker.Caption.js.map +1 -1
- package/cjs/dropdown/Toggle.js +5 -12
- package/cjs/dropdown/Toggle.js.map +1 -1
- package/cjs/form/checkbox/CheckboxGroup.js +1 -1
- package/cjs/form/checkbox/CheckboxGroup.js.map +1 -1
- package/cjs/form/combobox/Input/Input.js +1 -1
- package/cjs/form/combobox/Input/Input.js.map +1 -1
- package/cjs/form/fieldset/Fieldset.d.ts +25 -5
- package/cjs/form/fieldset/Fieldset.js +19 -2
- package/cjs/form/fieldset/Fieldset.js.map +1 -1
- package/cjs/form/radio/RadioGroup.js +1 -1
- package/cjs/form/radio/RadioGroup.js.map +1 -1
- package/cjs/index.d.ts +1 -1
- package/cjs/index.js.map +1 -1
- package/cjs/inline-message/root/InlineMessage.js +2 -2
- package/cjs/inline-message/root/InlineMessage.js.map +1 -1
- package/cjs/provider/Provider.d.ts +2 -2
- package/cjs/read-more/ReadMore.d.ts +10 -0
- package/cjs/read-more/ReadMore.js +4 -6
- package/cjs/read-more/ReadMore.js.map +1 -1
- package/cjs/tooltip/Tooltip.js +1 -3
- package/cjs/tooltip/Tooltip.js.map +1 -1
- package/cjs/types/index.d.ts +1 -1
- package/cjs/types/index.js +0 -15
- package/cjs/types/index.js.map +1 -1
- package/cjs/utils/components/HighlightText/HighlightText.d.ts +8 -0
- package/cjs/utils/components/HighlightText/HighlightText.js +27 -0
- package/cjs/utils/components/HighlightText/HighlightText.js.map +1 -0
- package/cjs/utils/components/Listbox/group/ListboxGroup.d.ts +7 -0
- package/cjs/utils/components/Listbox/group/ListboxGroup.js +15 -0
- package/cjs/utils/components/Listbox/group/ListboxGroup.js.map +1 -0
- package/cjs/utils/components/Listbox/input-slot/ListboxInputSlot.d.ts +7 -0
- package/cjs/utils/components/Listbox/input-slot/ListboxInputSlot.js +15 -0
- package/cjs/utils/components/Listbox/input-slot/ListboxInputSlot.js.map +1 -0
- package/cjs/utils/components/Listbox/option/ListboxOption.d.ts +24 -0
- package/cjs/utils/components/Listbox/option/ListboxOption.js +33 -0
- package/cjs/utils/components/Listbox/option/ListboxOption.js.map +1 -0
- package/cjs/utils/components/Listbox/options/ListboxOptions.d.ts +8 -0
- package/cjs/utils/components/Listbox/options/ListboxOptions.js +32 -0
- package/cjs/utils/components/Listbox/options/ListboxOptions.js.map +1 -0
- package/cjs/utils/components/Listbox/root/ListboxRoot.d.ts +20 -0
- package/cjs/utils/components/Listbox/root/ListboxRoot.js +84 -0
- package/cjs/utils/components/Listbox/root/ListboxRoot.js.map +1 -0
- package/cjs/utils/components/Listbox/root/domHelpers.d.ts +3 -0
- package/cjs/utils/components/Listbox/root/domHelpers.js +53 -0
- package/cjs/utils/components/Listbox/root/domHelpers.js.map +1 -0
- package/cjs/utils/components/floating/Floating.d.ts +1 -1
- package/cjs/utils/components/floating/Floating.js +1 -1
- package/cjs/utils/components/floating/Floating.js.map +1 -1
- package/cjs/utils/components/focus-boundary/FocusBoundary.d.ts +0 -1
- package/cjs/utils/components/focus-boundary/FocusBoundary.js +9 -64
- package/cjs/utils/components/focus-boundary/FocusBoundary.js.map +1 -1
- package/cjs/utils/components/link-anchor/LinkAnchor.js +10 -0
- package/cjs/utils/components/link-anchor/LinkAnchor.js.map +1 -1
- package/cjs/utils/helpers/className.js +1 -1
- package/cjs/utils/helpers/className.js.map +1 -1
- package/cjs/utils/helpers/focus.d.ts +16 -0
- package/cjs/utils/helpers/focus.js +63 -0
- package/cjs/utils/helpers/focus.js.map +1 -0
- package/cjs/utils/helpers/index.d.ts +9 -9
- package/cjs/utils/helpers/index.js +22 -23
- package/cjs/utils/helpers/index.js.map +1 -1
- package/cjs/utils/hooks/index.d.ts +13 -13
- package/cjs/utils/hooks/index.js +31 -28
- package/cjs/utils/hooks/index.js.map +1 -1
- package/cjs/utils/hooks/useDeferredValue.d.ts +1 -0
- package/cjs/utils/hooks/useDeferredValue.js +14 -0
- package/cjs/utils/hooks/useDeferredValue.js.map +1 -0
- package/cjs/utils/hooks/useScrollLock.js +41 -11
- package/cjs/utils/hooks/useScrollLock.js.map +1 -1
- package/esm/alert/base-alert/root/BaseAlertRoot.js +1 -2
- package/esm/alert/base-alert/root/BaseAlertRoot.js.map +1 -1
- package/esm/alert/info-card/index.d.ts +2 -2
- package/esm/alert/info-card/index.js +1 -1
- package/esm/alert/info-card/index.js.map +1 -1
- package/esm/alert/info-card/message/InfoCardMessage.d.ts +23 -0
- package/esm/alert/info-card/message/InfoCardMessage.js +37 -0
- package/esm/alert/info-card/message/InfoCardMessage.js.map +1 -0
- package/esm/alert/info-card/root/InfoCardRoot.d.ts +15 -2
- package/esm/alert/info-card/root/InfoCardRoot.js +3 -1
- package/esm/alert/info-card/root/InfoCardRoot.js.map +1 -1
- package/esm/data/drag-and-drop/drag-handler/DataDragAndDropDragHandler.d.ts +21 -0
- package/esm/data/drag-and-drop/drag-handler/DataDragAndDropDragHandler.js +18 -0
- package/esm/data/drag-and-drop/drag-handler/DataDragAndDropDragHandler.js.map +1 -0
- package/esm/data/drag-and-drop/item/DataDragAndDropItem.d.ts +27 -0
- package/esm/data/drag-and-drop/item/DataDragAndDropItem.js +35 -0
- package/esm/data/drag-and-drop/item/DataDragAndDropItem.js.map +1 -0
- package/esm/data/drag-and-drop/root/DataDragAndDrop.context.d.ts +8 -0
- package/esm/data/drag-and-drop/root/DataDragAndDrop.context.js +6 -0
- package/esm/data/drag-and-drop/root/DataDragAndDrop.context.js.map +1 -0
- package/esm/data/drag-and-drop/root/DataDragAndDropRoot.d.ts +34 -0
- package/esm/data/drag-and-drop/root/DataDragAndDropRoot.js +21 -0
- package/esm/data/drag-and-drop/root/DataDragAndDropRoot.js.map +1 -0
- package/esm/data/drag-and-drop-old/drag-handler/DataDragAndDropDragHandler.d.ts +22 -0
- package/esm/data/drag-and-drop-old/drag-handler/DataDragAndDropDragHandler.js +29 -0
- package/esm/data/drag-and-drop-old/drag-handler/DataDragAndDropDragHandler.js.map +1 -0
- package/esm/data/drag-and-drop-old/item/DataDragAndDropItem.d.ts +27 -0
- package/esm/data/drag-and-drop-old/item/DataDragAndDropItem.js +50 -0
- package/esm/data/drag-and-drop-old/item/DataDragAndDropItem.js.map +1 -0
- package/esm/data/drag-and-drop-old/root/DataDragAndDrop.context.d.ts +5 -0
- package/esm/data/drag-and-drop-old/root/DataDragAndDrop.context.js +3 -0
- package/esm/data/drag-and-drop-old/root/DataDragAndDrop.context.js.map +1 -0
- package/esm/data/drag-and-drop-old/root/DataDragAndDropRoot.d.ts +24 -0
- package/esm/data/drag-and-drop-old/root/DataDragAndDropRoot.js +68 -0
- package/esm/data/drag-and-drop-old/root/DataDragAndDropRoot.js.map +1 -0
- package/esm/data/table/empty-state/DataTableEmptyState.d.ts +5 -0
- package/esm/data/table/empty-state/DataTableEmptyState.js +21 -0
- package/esm/data/table/empty-state/DataTableEmptyState.js.map +1 -0
- package/esm/data/table/helpers/table-focus.js +7 -1
- package/esm/data/table/helpers/table-focus.js.map +1 -1
- package/esm/data/table/helpers/table-keyboard.js +1 -1
- package/esm/data/table/helpers/table-keyboard.js.map +1 -1
- package/esm/data/table/loading-state/DataTableLoadingState.d.ts +5 -0
- package/esm/data/table/loading-state/DataTableLoadingState.js +21 -0
- package/esm/data/table/loading-state/DataTableLoadingState.js.map +1 -0
- package/esm/data/table/root/DataTable.types.d.ts +13 -0
- package/esm/data/table/root/DataTable.types.js +2 -0
- package/esm/data/table/root/DataTable.types.js.map +1 -0
- package/esm/data/table/root/DataTableAuto.d.ts +60 -0
- package/esm/data/table/root/DataTableAuto.js +63 -0
- package/esm/data/table/root/DataTableAuto.js.map +1 -0
- package/esm/data/table/root/DataTableRoot.context.d.ts +9 -0
- package/esm/data/table/root/DataTableRoot.context.js +7 -0
- package/esm/data/table/root/DataTableRoot.context.js.map +1 -0
- package/esm/data/table/root/DataTableRoot.d.ts +30 -3
- package/esm/data/table/root/DataTableRoot.js +10 -4
- package/esm/data/table/root/DataTableRoot.js.map +1 -1
- package/esm/data/table/root/useTableKeyboardNav.js +1 -0
- package/esm/data/table/root/useTableKeyboardNav.js.map +1 -1
- package/esm/data/table/root/useTableSelection.d.ts +55 -0
- package/esm/data/table/root/useTableSelection.js +77 -0
- package/esm/data/table/root/useTableSelection.js.map +1 -0
- package/esm/data/table/td/DataTableTd.d.ts +10 -0
- package/esm/data/table/td/DataTableTd.js +4 -2
- package/esm/data/table/td/DataTableTd.js.map +1 -1
- package/esm/data/table/th/DataTableTh.d.ts +27 -5
- package/esm/data/table/th/DataTableTh.js +51 -24
- package/esm/data/table/th/DataTableTh.js.map +1 -1
- package/esm/data/table/th/useTableColumnResize.d.ts +64 -0
- package/esm/data/table/th/useTableColumnResize.js +142 -0
- package/esm/data/table/th/useTableColumnResize.js.map +1 -0
- package/esm/data/table/thead/DataTableThead.context.d.ts +4 -0
- package/esm/data/table/thead/DataTableThead.context.js +8 -0
- package/esm/data/table/thead/DataTableThead.context.js.map +1 -0
- package/esm/data/table/thead/DataTableThead.js +3 -1
- package/esm/data/table/thead/DataTableThead.js.map +1 -1
- package/esm/data/table/tr/DataTableTr.js +10 -2
- package/esm/data/table/tr/DataTableTr.js.map +1 -1
- package/esm/data/token-filter/AutoSuggest.d.ts +6 -2
- package/esm/data/token-filter/AutoSuggest.js +43 -13
- package/esm/data/token-filter/AutoSuggest.js.map +1 -1
- package/esm/data/token-filter/TokenFilter.d.ts +5 -5
- package/esm/data/token-filter/TokenFilter.js +105 -42
- package/esm/data/token-filter/TokenFilter.js.map +1 -1
- package/esm/data/token-filter/TokenFilter.types.d.ts +51 -33
- package/esm/data/token-filter/helpers/generate-autocomplete-options.d.ts +2 -3
- package/esm/data/token-filter/helpers/generate-autocomplete-options.js +11 -15
- package/esm/data/token-filter/helpers/generate-autocomplete-options.js.map +1 -1
- package/esm/data/token-filter/helpers/operators.d.ts +6 -6
- package/esm/data/token-filter/helpers/operators.js +3 -4
- package/esm/data/token-filter/helpers/operators.js.map +1 -1
- package/esm/data/token-filter/helpers/parse-query-text.d.ts +2 -20
- package/esm/data/token-filter/helpers/parse-query-text.js +1 -1
- package/esm/data/token-filter/helpers/parse-query-text.js.map +1 -1
- package/esm/data/token-filter/helpers/query-builder.d.ts +2 -2
- package/esm/data/token-filter/helpers/query-builder.js.map +1 -1
- package/esm/date/Date.Dialog.d.ts +5 -1
- package/esm/date/Date.Dialog.js +6 -2
- package/esm/date/Date.Dialog.js.map +1 -1
- package/esm/date/Date.Input.js +1 -1
- package/esm/date/Date.Input.js.map +1 -1
- package/esm/date/datepicker/DatePicker.js +3 -2
- package/esm/date/datepicker/DatePicker.js.map +1 -1
- package/esm/date/datepicker/hooks/useDatepicker.d.ts +12 -1
- package/esm/date/datepicker/hooks/useDatepicker.js +5 -2
- package/esm/date/datepicker/hooks/useDatepicker.js.map +1 -1
- package/esm/date/datepicker/hooks/useRangeDatepicker.js +3 -1
- package/esm/date/datepicker/hooks/useRangeDatepicker.js.map +1 -1
- package/esm/date/datepicker/parts/DatePicker.Months.d.ts +2 -1
- package/esm/date/datepicker/parts/DatePicker.Months.js +3 -3
- package/esm/date/datepicker/parts/DatePicker.Months.js.map +1 -1
- package/esm/date/datepicker/parts/DatePicker.RDP.d.ts +5 -1
- package/esm/date/datepicker/parts/DatePicker.RDP.js +2 -2
- package/esm/date/datepicker/parts/DatePicker.RDP.js.map +1 -1
- package/esm/date/monthpicker/MonthPicker.js +3 -2
- package/esm/date/monthpicker/MonthPicker.js.map +1 -1
- package/esm/date/monthpicker/hooks/useMonthPicker.d.ts +11 -1
- package/esm/date/monthpicker/hooks/useMonthPicker.js +3 -1
- package/esm/date/monthpicker/hooks/useMonthPicker.js.map +1 -1
- package/esm/date/monthpicker/parts/MonthPicker.Caption.d.ts +4 -1
- package/esm/date/monthpicker/parts/MonthPicker.Caption.js +3 -2
- package/esm/date/monthpicker/parts/MonthPicker.Caption.js.map +1 -1
- package/esm/dropdown/Toggle.js +5 -12
- package/esm/dropdown/Toggle.js.map +1 -1
- package/esm/form/checkbox/CheckboxGroup.js +1 -1
- package/esm/form/checkbox/CheckboxGroup.js.map +1 -1
- package/esm/form/combobox/Input/Input.js +1 -1
- package/esm/form/combobox/Input/Input.js.map +1 -1
- package/esm/form/fieldset/Fieldset.d.ts +25 -5
- package/esm/form/fieldset/Fieldset.js +19 -2
- package/esm/form/fieldset/Fieldset.js.map +1 -1
- package/esm/form/radio/RadioGroup.js +1 -1
- package/esm/form/radio/RadioGroup.js.map +1 -1
- package/esm/index.d.ts +1 -1
- package/esm/index.js.map +1 -1
- package/esm/inline-message/root/InlineMessage.js +3 -3
- package/esm/inline-message/root/InlineMessage.js.map +1 -1
- package/esm/provider/Provider.d.ts +2 -2
- package/esm/read-more/ReadMore.d.ts +10 -0
- package/esm/read-more/ReadMore.js +4 -6
- package/esm/read-more/ReadMore.js.map +1 -1
- package/esm/tooltip/Tooltip.js +1 -3
- package/esm/tooltip/Tooltip.js.map +1 -1
- package/esm/types/index.d.ts +1 -1
- package/esm/types/index.js +1 -1
- package/esm/types/index.js.map +1 -1
- package/esm/utils/components/HighlightText/HighlightText.d.ts +8 -0
- package/esm/utils/components/HighlightText/HighlightText.js +21 -0
- package/esm/utils/components/HighlightText/HighlightText.js.map +1 -0
- package/esm/utils/components/Listbox/group/ListboxGroup.d.ts +7 -0
- package/esm/utils/components/Listbox/group/ListboxGroup.js +10 -0
- package/esm/utils/components/Listbox/group/ListboxGroup.js.map +1 -0
- package/esm/utils/components/Listbox/input-slot/ListboxInputSlot.d.ts +7 -0
- package/esm/utils/components/Listbox/input-slot/ListboxInputSlot.js +9 -0
- package/esm/utils/components/Listbox/input-slot/ListboxInputSlot.js.map +1 -0
- package/esm/utils/components/Listbox/option/ListboxOption.d.ts +24 -0
- package/esm/utils/components/Listbox/option/ListboxOption.js +27 -0
- package/esm/utils/components/Listbox/option/ListboxOption.js.map +1 -0
- package/esm/utils/components/Listbox/options/ListboxOptions.d.ts +8 -0
- package/esm/utils/components/Listbox/options/ListboxOptions.js +27 -0
- package/esm/utils/components/Listbox/options/ListboxOptions.js.map +1 -0
- package/esm/utils/components/Listbox/root/ListboxRoot.d.ts +20 -0
- package/esm/utils/components/Listbox/root/ListboxRoot.js +79 -0
- package/esm/utils/components/Listbox/root/ListboxRoot.js.map +1 -0
- package/esm/utils/components/Listbox/root/domHelpers.d.ts +3 -0
- package/esm/utils/components/Listbox/root/domHelpers.js +50 -0
- package/esm/utils/components/Listbox/root/domHelpers.js.map +1 -0
- package/esm/utils/components/floating/Floating.d.ts +1 -1
- package/esm/utils/components/floating/Floating.js +1 -1
- package/esm/utils/components/floating/Floating.js.map +1 -1
- package/esm/utils/components/focus-boundary/FocusBoundary.d.ts +0 -1
- package/esm/utils/components/focus-boundary/FocusBoundary.js +9 -64
- package/esm/utils/components/focus-boundary/FocusBoundary.js.map +1 -1
- package/esm/utils/components/link-anchor/LinkAnchor.js +10 -0
- package/esm/utils/components/link-anchor/LinkAnchor.js.map +1 -1
- package/esm/utils/helpers/className.js +1 -1
- package/esm/utils/helpers/className.js.map +1 -1
- package/esm/utils/helpers/focus.d.ts +16 -0
- package/esm/utils/helpers/focus.js +60 -0
- package/esm/utils/helpers/focus.js.map +1 -0
- package/esm/utils/helpers/index.d.ts +9 -9
- package/esm/utils/helpers/index.js +9 -9
- package/esm/utils/helpers/index.js.map +1 -1
- package/esm/utils/hooks/index.d.ts +13 -13
- package/esm/utils/hooks/index.js +13 -13
- package/esm/utils/hooks/index.js.map +1 -1
- package/esm/utils/hooks/useDeferredValue.d.ts +1 -0
- package/esm/utils/hooks/useDeferredValue.js +7 -0
- package/esm/utils/hooks/useDeferredValue.js.map +1 -0
- package/esm/utils/hooks/useScrollLock.js +41 -11
- package/esm/utils/hooks/useScrollLock.js.map +1 -1
- package/package.json +9 -9
- package/src/alert/base-alert/root/BaseAlertRoot.tsx +1 -1
- package/src/alert/info-card/index.ts +2 -0
- package/src/alert/info-card/message/InfoCardMessage.tsx +48 -0
- package/src/alert/info-card/root/InfoCardRoot.tsx +20 -1
- package/src/data/drag-and-drop/drag-handler/DataDragAndDropDragHandler.tsx +63 -0
- package/src/data/drag-and-drop/item/DataDragAndDropItem.tsx +54 -0
- package/src/data/drag-and-drop/root/DataDragAndDrop.context.tsx +14 -0
- package/src/data/drag-and-drop/root/DataDragAndDropRoot.tsx +54 -0
- package/src/data/drag-and-drop-old/drag-handler/DataDragAndDropDragHandler.tsx +104 -0
- package/src/data/drag-and-drop-old/item/DataDragAndDropItem.tsx +74 -0
- package/src/data/drag-and-drop-old/root/DataDragAndDrop.context.tsx +11 -0
- package/src/data/drag-and-drop-old/root/DataDragAndDropRoot.tsx +96 -0
- package/src/data/table/empty-state/DataTableEmptyState.tsx +26 -0
- package/src/data/table/helpers/table-focus.ts +10 -1
- package/src/data/table/helpers/table-keyboard.ts +1 -1
- package/src/data/table/loading-state/DataTableLoadingState.tsx +26 -0
- package/src/data/table/root/DataTable.types.ts +16 -0
- package/src/data/table/root/DataTableAuto.tsx +182 -0
- package/src/data/table/root/DataTableRoot.context.ts +14 -0
- package/src/data/table/root/DataTableRoot.tsx +60 -14
- package/src/data/table/root/useTableKeyboardNav.ts +1 -0
- package/src/data/table/root/useTableSelection.ts +126 -0
- package/src/data/table/td/DataTableTd.tsx +14 -1
- package/src/data/table/th/DataTableTh.tsx +133 -65
- package/src/data/table/th/useTableColumnResize.ts +276 -0
- package/src/data/table/thead/DataTableThead.context.ts +10 -0
- package/src/data/table/thead/DataTableThead.tsx +8 -5
- package/src/data/table/tr/DataTableTr.tsx +18 -2
- package/src/data/token-filter/AutoSuggest.tsx +141 -29
- package/src/data/token-filter/TokenFilter.tsx +174 -79
- package/src/data/token-filter/TokenFilter.types.ts +70 -42
- package/src/data/token-filter/helpers/generate-autocomplete-options.test.ts +97 -97
- package/src/data/token-filter/helpers/generate-autocomplete-options.ts +31 -38
- package/src/data/token-filter/helpers/operators.test.ts +29 -29
- package/src/data/token-filter/helpers/operators.ts +16 -16
- package/src/data/token-filter/helpers/parse-query-text.test.ts +37 -35
- package/src/data/token-filter/helpers/parse-query-text.ts +7 -26
- package/src/data/token-filter/helpers/query-builder.ts +2 -2
- package/src/date/Date.Dialog.tsx +15 -0
- package/src/date/Date.Input.tsx +1 -1
- package/src/date/datepicker/DatePicker.tsx +3 -0
- package/src/date/datepicker/hooks/useDatepicker.tsx +19 -3
- package/src/date/datepicker/hooks/useRangeDatepicker.tsx +5 -1
- package/src/date/datepicker/parts/DatePicker.Months.tsx +9 -1
- package/src/date/datepicker/parts/DatePicker.RDP.tsx +7 -1
- package/src/date/monthpicker/MonthPicker.tsx +3 -1
- package/src/date/monthpicker/hooks/useMonthPicker.tsx +16 -2
- package/src/date/monthpicker/parts/MonthPicker.Caption.tsx +20 -2
- package/src/dropdown/Toggle.tsx +6 -12
- package/src/form/checkbox/CheckboxGroup.tsx +1 -1
- package/src/form/combobox/Input/Input.tsx +2 -2
- package/src/form/fieldset/Fieldset.tsx +31 -7
- package/src/form/radio/RadioGroup.tsx +1 -1
- package/src/index.ts +1 -0
- package/src/inline-message/root/InlineMessage.tsx +5 -5
- package/src/provider/Provider.tsx +2 -2
- package/src/read-more/ReadMore.tsx +15 -16
- package/src/tooltip/Tooltip.tsx +1 -3
- package/src/types/index.ts +1 -1
- package/src/utils/components/HighlightText/HighlightText.tsx +34 -0
- package/src/utils/components/Listbox/group/ListboxGroup.tsx +26 -0
- package/src/utils/components/Listbox/input-slot/ListboxInputSlot.tsx +22 -0
- package/src/utils/components/Listbox/option/ListboxOption.tsx +57 -0
- package/src/utils/components/Listbox/options/ListboxOptions.tsx +38 -0
- package/src/utils/components/Listbox/root/ListboxRoot.tsx +104 -0
- package/src/utils/components/Listbox/root/domHelpers.ts +60 -0
- package/src/utils/components/floating/Floating.tsx +2 -2
- package/src/utils/components/focus-boundary/FocusBoundary.tsx +9 -80
- package/src/utils/components/link-anchor/LinkAnchor.tsx +11 -0
- package/src/utils/helpers/className.ts +1 -1
- package/src/utils/helpers/focus.ts +78 -0
- package/src/utils/helpers/index.ts +9 -9
- package/src/utils/hooks/index.ts +20 -13
- package/src/utils/hooks/useDeferredValue.ts +12 -0
- package/src/utils/hooks/useScrollLock.ts +57 -13
- package/cjs/data/table/th/DataTableThSortHandle.d.ts +0 -6
- package/cjs/data/table/th/DataTableThSortHandle.js +0 -82
- package/cjs/data/table/th/DataTableThSortHandle.js.map +0 -1
- package/esm/data/table/th/DataTableThSortHandle.d.ts +0 -6
- package/esm/data/table/th/DataTableThSortHandle.js +0 -47
- package/esm/data/table/th/DataTableThSortHandle.js.map +0 -1
- package/src/data/table/th/DataTableThSortHandle.tsx +0 -67
|
@@ -1,23 +1,27 @@
|
|
|
1
1
|
import React, { forwardRef, useState } from "react";
|
|
2
|
-
import {
|
|
2
|
+
import { Chips } from "../../chips";
|
|
3
|
+
import { HStack } from "../../primitives/stack";
|
|
3
4
|
import { cl } from "../../utils/helpers";
|
|
4
5
|
import { AutoSuggest } from "./AutoSuggest";
|
|
6
|
+
import { AutoCompleteOption } from "./AutoSuggest.types";
|
|
5
7
|
import type {
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
8
|
+
ExternalOptions,
|
|
9
|
+
ExternalPropertyDefinitions,
|
|
10
|
+
ExternalQuery,
|
|
11
|
+
ExternalToken,
|
|
12
|
+
InternalPropertyDefinition,
|
|
13
|
+
InternalPropertyOption,
|
|
14
|
+
OperationT,
|
|
11
15
|
} from "./TokenFilter.types";
|
|
12
16
|
import { generateAutoCompleteOptions } from "./helpers/generate-autocomplete-options";
|
|
13
17
|
import { parseQueryText } from "./helpers/parse-query-text";
|
|
14
18
|
|
|
15
19
|
type TokenFilterProps = {
|
|
16
|
-
query:
|
|
17
|
-
onChange: (newQuery:
|
|
20
|
+
query: ExternalQuery;
|
|
21
|
+
onChange: (newQuery: ExternalQuery) => void;
|
|
18
22
|
className?: string;
|
|
19
|
-
|
|
20
|
-
|
|
23
|
+
propertyDefinitions: ExternalPropertyDefinitions;
|
|
24
|
+
options: ExternalOptions;
|
|
21
25
|
};
|
|
22
26
|
|
|
23
27
|
/**
|
|
@@ -26,31 +30,76 @@ type TokenFilterProps = {
|
|
|
26
30
|
* - Handle token rendering and editing (e.g., show tokens for matched properties/operators/values, allow deleting tokens).
|
|
27
31
|
*/
|
|
28
32
|
export const TokenFilter = forwardRef<HTMLDivElement, TokenFilterProps>(
|
|
29
|
-
({ query, className,
|
|
30
|
-
const [inputAnchor, setInputAnchor] = useState<HTMLInputElement | null>(
|
|
31
|
-
null,
|
|
32
|
-
);
|
|
33
|
-
|
|
33
|
+
({ query, className, propertyDefinitions, options, onChange }, ref) => {
|
|
34
34
|
const [filterText, setFilterText] = useState<string>("");
|
|
35
|
-
const
|
|
36
|
-
filteringProperties,
|
|
37
|
-
filteringOptions,
|
|
38
|
-
);
|
|
35
|
+
const [open, setOpen] = useState(false);
|
|
39
36
|
|
|
40
|
-
const
|
|
37
|
+
const { parsedPropertyDefinitions, parsedPropertyOptions } =
|
|
38
|
+
derrivedFilterState(propertyDefinitions, options);
|
|
39
|
+
|
|
40
|
+
const queryState = parseQueryText(filterText, parsedPropertyDefinitions);
|
|
41
41
|
|
|
42
42
|
const autoCompleteOptions = generateAutoCompleteOptions(
|
|
43
43
|
queryState,
|
|
44
|
-
|
|
45
|
-
|
|
44
|
+
parsedPropertyDefinitions,
|
|
45
|
+
parsedPropertyOptions,
|
|
46
46
|
);
|
|
47
47
|
|
|
48
|
-
const
|
|
49
|
-
|
|
50
|
-
|
|
48
|
+
const { addToken, removeToken } = createActionHandlers({
|
|
49
|
+
query,
|
|
50
|
+
onChange,
|
|
51
|
+
});
|
|
52
|
+
|
|
53
|
+
const createToken = (newText: string): boolean => {
|
|
54
|
+
const newQueryState = parseQueryText(newText, parsedPropertyDefinitions);
|
|
55
|
+
|
|
56
|
+
let newToken: ExternalToken | null = null;
|
|
57
|
+
|
|
58
|
+
switch (newQueryState.step) {
|
|
59
|
+
case "property": {
|
|
60
|
+
if (newQueryState.value === "") {
|
|
61
|
+
return false;
|
|
62
|
+
}
|
|
63
|
+
newToken = {
|
|
64
|
+
propertyKey: newQueryState.property.key,
|
|
65
|
+
operator: newQueryState.operator,
|
|
66
|
+
value: newQueryState.value,
|
|
67
|
+
};
|
|
68
|
+
break;
|
|
69
|
+
}
|
|
70
|
+
case "free-text": {
|
|
71
|
+
break;
|
|
72
|
+
}
|
|
73
|
+
case "operator": {
|
|
74
|
+
break;
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
if (newToken) {
|
|
78
|
+
addToken(newToken);
|
|
79
|
+
setFilterText("");
|
|
80
|
+
return true;
|
|
81
|
+
}
|
|
82
|
+
return false;
|
|
51
83
|
};
|
|
52
84
|
|
|
53
|
-
const
|
|
85
|
+
const handleSelectOption = (option: AutoCompleteOption) => {
|
|
86
|
+
const newQueryState = parseQueryText(
|
|
87
|
+
option.value,
|
|
88
|
+
parsedPropertyDefinitions,
|
|
89
|
+
);
|
|
90
|
+
|
|
91
|
+
if (
|
|
92
|
+
(newQueryState.step === "property" && newQueryState.value === "") ||
|
|
93
|
+
newQueryState.step === "operator"
|
|
94
|
+
) {
|
|
95
|
+
/* Add space after for better formatting */
|
|
96
|
+
/* TODO: Handle this scenario better */
|
|
97
|
+
setFilterText(`${option.value} `);
|
|
98
|
+
return false;
|
|
99
|
+
}
|
|
100
|
+
setFilterText(option.value);
|
|
101
|
+
return createToken(option.value);
|
|
102
|
+
};
|
|
54
103
|
|
|
55
104
|
return (
|
|
56
105
|
<div
|
|
@@ -58,75 +107,121 @@ export const TokenFilter = forwardRef<HTMLDivElement, TokenFilterProps>(
|
|
|
58
107
|
className={cl("aksel-property-filter", className)}
|
|
59
108
|
role="search"
|
|
60
109
|
>
|
|
61
|
-
<
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
placeholder="Type to filter..."
|
|
65
|
-
ref={setInputAnchor}
|
|
110
|
+
<AutoSuggest
|
|
111
|
+
onSelect={handleSelectOption}
|
|
112
|
+
options={autoCompleteOptions.options}
|
|
66
113
|
value={filterText}
|
|
67
|
-
onChange={
|
|
68
|
-
|
|
114
|
+
onChange={setFilterText}
|
|
115
|
+
open={open}
|
|
116
|
+
setOpen={setOpen}
|
|
69
117
|
/>
|
|
70
|
-
<
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
{filteringProperties.map((prop) => (
|
|
92
|
-
<li key={prop.key}>{prop.propertyLabel}</li>
|
|
93
|
-
))}
|
|
94
|
-
</ul>
|
|
95
|
-
{/* <pre>{JSON.stringify(queryState, null, 2)}</pre> */}
|
|
96
|
-
<pre>{JSON.stringify(autoCompleteOptions, null, 2)}</pre>
|
|
118
|
+
<HStack marginBlock="space-8" gap="space-8">
|
|
119
|
+
{query.tokens.map((token, index) => {
|
|
120
|
+
return (
|
|
121
|
+
<React.Fragment
|
|
122
|
+
key={`${token.propertyKey}-${token.operator}-${token.value}-${index}`}
|
|
123
|
+
>
|
|
124
|
+
<Chips.Removable
|
|
125
|
+
key={index}
|
|
126
|
+
onClick={() => {
|
|
127
|
+
removeToken(index);
|
|
128
|
+
}}
|
|
129
|
+
>
|
|
130
|
+
{`${token.propertyKey} ${token.operator} ${token.value}`}
|
|
131
|
+
</Chips.Removable>
|
|
132
|
+
{index < query.tokens.length - 1 && (
|
|
133
|
+
<span>{query.operation}</span>
|
|
134
|
+
)}
|
|
135
|
+
</React.Fragment>
|
|
136
|
+
);
|
|
137
|
+
})}
|
|
138
|
+
</HStack>
|
|
97
139
|
</div>
|
|
98
140
|
);
|
|
99
141
|
},
|
|
100
142
|
);
|
|
101
143
|
|
|
102
144
|
function derrivedFilterState(
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
/* query: QueryFilterQuery */
|
|
145
|
+
propertyDefinitions: ExternalPropertyDefinitions,
|
|
146
|
+
propteryOptions: ExternalOptions,
|
|
106
147
|
): {
|
|
107
|
-
|
|
108
|
-
|
|
148
|
+
parsedPropertyDefinitions: InternalPropertyDefinition[];
|
|
149
|
+
parsedPropertyOptions: InternalPropertyOption[];
|
|
109
150
|
} {
|
|
110
|
-
const propertyMap = new Map<string,
|
|
151
|
+
const propertyMap = new Map<string, InternalPropertyDefinition>();
|
|
111
152
|
|
|
112
|
-
for (const property of
|
|
153
|
+
for (const property of propertyDefinitions) {
|
|
113
154
|
propertyMap.set(property.key, {
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
155
|
+
key: property.key,
|
|
156
|
+
label: property?.label ?? "",
|
|
157
|
+
groupLabel: property?.groupLabel ?? "",
|
|
158
|
+
group: property?.group ?? "",
|
|
118
159
|
operators: property?.operators ?? [],
|
|
119
|
-
/* defaultOperator: property?.defaultOperator ?? '=', */
|
|
120
160
|
externalProperty: property,
|
|
121
161
|
});
|
|
122
162
|
}
|
|
123
163
|
|
|
124
|
-
const internalOptions =
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
164
|
+
const internalOptions: InternalPropertyOption[] = [];
|
|
165
|
+
|
|
166
|
+
for (const option of propteryOptions) {
|
|
167
|
+
internalOptions.push({
|
|
168
|
+
property: propertyMap.get(option.propertyKey) ?? null,
|
|
169
|
+
value: option.value,
|
|
170
|
+
label: option.label ?? option.value ?? "",
|
|
171
|
+
tags: option.tags ?? [],
|
|
172
|
+
});
|
|
173
|
+
}
|
|
174
|
+
|
|
175
|
+
return {
|
|
176
|
+
parsedPropertyDefinitions: [...propertyMap.values()],
|
|
177
|
+
parsedPropertyOptions: internalOptions,
|
|
178
|
+
};
|
|
179
|
+
}
|
|
180
|
+
|
|
181
|
+
function createActionHandlers({
|
|
182
|
+
query,
|
|
183
|
+
onChange,
|
|
184
|
+
}: {
|
|
185
|
+
query: ExternalQuery;
|
|
186
|
+
onChange: (newQuery: ExternalQuery) => void;
|
|
187
|
+
}) {
|
|
188
|
+
const handleChange = (newQuery: ExternalQuery) => {
|
|
189
|
+
onChange(newQuery);
|
|
190
|
+
};
|
|
191
|
+
|
|
192
|
+
const addToken = (token: ExternalToken) => {
|
|
193
|
+
handleChange({ ...query, tokens: [...query.tokens, token] });
|
|
194
|
+
};
|
|
195
|
+
|
|
196
|
+
const updateToken = (updateIndex: number, updatedToken: ExternalToken) => {
|
|
197
|
+
handleChange({
|
|
198
|
+
...query,
|
|
199
|
+
tokens: query.tokens.map((token, index) =>
|
|
200
|
+
index === updateIndex ? updatedToken : token,
|
|
201
|
+
),
|
|
202
|
+
});
|
|
203
|
+
};
|
|
204
|
+
|
|
205
|
+
const updateOperation = (operation: OperationT) => {
|
|
206
|
+
handleChange({ ...query, operation });
|
|
207
|
+
};
|
|
208
|
+
|
|
209
|
+
const removeToken = (removeIndex: number) => {
|
|
210
|
+
handleChange({
|
|
211
|
+
...query,
|
|
212
|
+
tokens: query.tokens.filter((_, index) => index !== removeIndex),
|
|
213
|
+
});
|
|
214
|
+
};
|
|
215
|
+
|
|
216
|
+
const removeAllTokens = () => {
|
|
217
|
+
handleChange({ ...query, tokens: [] });
|
|
218
|
+
};
|
|
130
219
|
|
|
131
|
-
return {
|
|
220
|
+
return {
|
|
221
|
+
addToken,
|
|
222
|
+
updateToken,
|
|
223
|
+
updateOperation,
|
|
224
|
+
removeToken,
|
|
225
|
+
removeAllTokens,
|
|
226
|
+
};
|
|
132
227
|
}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
|
|
1
|
+
/* External API */
|
|
2
|
+
type OperatorT =
|
|
2
3
|
| "<"
|
|
3
4
|
| "<="
|
|
4
5
|
| ">"
|
|
@@ -11,73 +12,100 @@ type QueryFilterOperator =
|
|
|
11
12
|
| "!^"
|
|
12
13
|
| (string & {});
|
|
13
14
|
|
|
14
|
-
type
|
|
15
|
+
type OperationT = "and" | "or";
|
|
15
16
|
|
|
16
|
-
type
|
|
17
|
+
type ExternalToken = {
|
|
17
18
|
propertyKey: string;
|
|
18
|
-
operator:
|
|
19
|
-
value:
|
|
19
|
+
operator: OperatorT;
|
|
20
|
+
value: string;
|
|
20
21
|
};
|
|
21
22
|
|
|
22
|
-
type
|
|
23
|
-
tokens:
|
|
24
|
-
operation:
|
|
23
|
+
type ExternalQuery = {
|
|
24
|
+
tokens: ExternalToken[];
|
|
25
|
+
operation: OperationT;
|
|
25
26
|
};
|
|
26
27
|
|
|
27
|
-
type
|
|
28
|
+
type ExternalOption = {
|
|
28
29
|
propertyKey: string;
|
|
29
|
-
value:
|
|
30
|
+
value: string;
|
|
30
31
|
label?: string;
|
|
31
32
|
tags?: string[];
|
|
32
33
|
disabled?: boolean;
|
|
33
34
|
};
|
|
34
35
|
|
|
35
|
-
type
|
|
36
|
+
type ExternalOptions = ExternalOption[];
|
|
36
37
|
|
|
37
|
-
type
|
|
38
|
+
type ExternalPropertyGroup = {
|
|
38
39
|
label: string;
|
|
39
|
-
options:
|
|
40
|
+
options: ExternalOptions;
|
|
40
41
|
};
|
|
41
42
|
|
|
42
|
-
type
|
|
43
|
-
| string
|
|
44
|
-
| { operator: string; tokenType: "single" | "multiple" };
|
|
45
|
-
|
|
46
|
-
type QueryFilteringProperty = {
|
|
43
|
+
type ExternalPropertyDefinition = {
|
|
47
44
|
key: string;
|
|
48
|
-
|
|
49
|
-
|
|
45
|
+
label: string;
|
|
46
|
+
groupLabel?: string;
|
|
50
47
|
group?: string;
|
|
51
|
-
operators?:
|
|
48
|
+
operators?: ExternalPropertyOperator[];
|
|
52
49
|
};
|
|
53
50
|
|
|
54
|
-
type
|
|
51
|
+
type ExternalPropertyDefinitions = ExternalPropertyDefinition[];
|
|
55
52
|
|
|
56
|
-
type
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
53
|
+
type ExternalPropertyOperator =
|
|
54
|
+
| string
|
|
55
|
+
| { operator: string; type: "single" | "multiple" };
|
|
56
|
+
|
|
57
|
+
export type {
|
|
58
|
+
ExternalOption,
|
|
59
|
+
ExternalOptions,
|
|
60
|
+
ExternalPropertyDefinition,
|
|
61
|
+
ExternalPropertyDefinitions,
|
|
62
|
+
ExternalPropertyGroup,
|
|
63
|
+
ExternalQuery,
|
|
64
|
+
ExternalToken,
|
|
65
|
+
OperationT,
|
|
66
|
+
OperatorT,
|
|
67
|
+
};
|
|
68
|
+
|
|
69
|
+
/* Internal API */
|
|
70
|
+
type InternalPropertyDefinition = {
|
|
71
|
+
key: string;
|
|
72
|
+
label: string;
|
|
73
|
+
groupLabel: string;
|
|
74
|
+
group: string;
|
|
75
|
+
operators: ExternalPropertyOperator[];
|
|
76
|
+
externalProperty: ExternalPropertyDefinition;
|
|
63
77
|
};
|
|
64
78
|
|
|
65
|
-
type
|
|
66
|
-
property:
|
|
67
|
-
value:
|
|
79
|
+
type InternalPropertyOption = {
|
|
80
|
+
property: InternalPropertyDefinition | null;
|
|
81
|
+
value: string;
|
|
68
82
|
label: string;
|
|
69
83
|
tags: string[];
|
|
70
84
|
};
|
|
71
85
|
|
|
86
|
+
type InternalParsedTextState =
|
|
87
|
+
| {
|
|
88
|
+
/** User has typed property + complete operator + value (e.g., "Status != active") */
|
|
89
|
+
step: "property";
|
|
90
|
+
property: InternalPropertyDefinition;
|
|
91
|
+
operator: OperatorT;
|
|
92
|
+
value: string;
|
|
93
|
+
}
|
|
94
|
+
| {
|
|
95
|
+
/** User is typing the operator after property (e.g., "Status !") */
|
|
96
|
+
step: "operator";
|
|
97
|
+
property: InternalPropertyDefinition;
|
|
98
|
+
operatorPrefix: string;
|
|
99
|
+
}
|
|
100
|
+
| {
|
|
101
|
+
/** No property match; treat as free-text search */
|
|
102
|
+
step: "free-text";
|
|
103
|
+
value: string;
|
|
104
|
+
operator?: OperatorT;
|
|
105
|
+
};
|
|
106
|
+
|
|
72
107
|
export type {
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
QueryFilteringProperty,
|
|
77
|
-
QueryFilterOperation,
|
|
78
|
-
QueryFilteringProperties,
|
|
79
|
-
ParsedProperty,
|
|
80
|
-
ParsedOption,
|
|
81
|
-
QueryFilteringOption,
|
|
82
|
-
QueryFilteringOptionGroup,
|
|
108
|
+
InternalPropertyDefinition,
|
|
109
|
+
InternalPropertyOption,
|
|
110
|
+
InternalParsedTextState,
|
|
83
111
|
};
|