@osdk/react-components 0.2.0-beta.9 → 0.2.1-main-20260407074313
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/AGENTS.md +26 -0
- package/CHANGELOG.md +356 -0
- package/README.md +166 -7
- package/build/browser/action-form/ActionForm.js +117 -0
- package/build/browser/action-form/ActionForm.js.map +1 -0
- package/build/browser/action-form/ActionFormApi.js.map +1 -1
- package/build/browser/action-form/BaseForm.js +83 -0
- package/build/browser/action-form/BaseForm.js.map +1 -0
- package/build/browser/action-form/BaseForm.module.css +38 -0
- package/build/browser/action-form/BaseForm.module.css.js +8 -0
- package/build/browser/action-form/FormField.js +42 -0
- package/build/browser/action-form/FormField.js.map +1 -0
- package/build/browser/action-form/FormField.module.css +41 -0
- package/build/browser/action-form/FormField.module.css.js +10 -0
- package/build/browser/action-form/FormFieldApi.js.map +1 -1
- package/build/browser/action-form/FormHeader.js +26 -0
- package/build/browser/action-form/FormHeader.js.map +1 -0
- package/build/browser/action-form/FormHeader.module.css +26 -0
- package/build/browser/action-form/FormHeader.module.css.js +6 -0
- package/build/browser/action-form/fields/BaseInput.module.css +56 -0
- package/build/browser/action-form/fields/BaseInput.module.css.js +6 -0
- package/build/browser/action-form/fields/CustomField.js +30 -0
- package/build/browser/action-form/fields/CustomField.js.map +1 -0
- package/build/browser/action-form/fields/DateCalendar.js +70 -0
- package/build/browser/action-form/fields/DateCalendar.js.map +1 -0
- package/build/browser/action-form/fields/DateCalendar.module.css +136 -0
- package/build/browser/action-form/fields/DateCalendar.module.css.js +22 -0
- package/build/browser/action-form/fields/DatetimePickerField.js +98 -0
- package/build/browser/action-form/fields/DatetimePickerField.js.map +1 -0
- package/build/browser/action-form/fields/DatetimePickerField.module.css +66 -0
- package/build/browser/action-form/fields/DatetimePickerField.module.css.js +10 -0
- package/build/browser/action-form/fields/DropdownField.js +104 -0
- package/build/browser/action-form/fields/DropdownField.js.map +1 -0
- package/build/browser/action-form/fields/FieldBridge.js +45 -0
- package/build/browser/action-form/fields/FieldBridge.js.map +1 -0
- package/build/browser/action-form/fields/FilePickerField.js +119 -0
- package/build/browser/action-form/fields/FilePickerField.js.map +1 -0
- package/build/browser/action-form/fields/FilePickerField.module.css +132 -0
- package/build/browser/action-form/fields/FilePickerField.module.css.js +11 -0
- package/build/browser/action-form/fields/FormFieldRenderer.js +128 -0
- package/build/browser/action-form/fields/FormFieldRenderer.js.map +1 -0
- package/build/browser/action-form/fields/LazyDateCalendar.js +27 -0
- package/build/browser/action-form/fields/LazyDateCalendar.js.map +1 -0
- package/build/browser/action-form/fields/NumberInputField.js +130 -0
- package/build/browser/action-form/fields/NumberInputField.js.map +1 -0
- package/build/browser/action-form/fields/NumberInputField.module.css +96 -0
- package/build/browser/action-form/fields/NumberInputField.module.css.js +9 -0
- package/build/browser/action-form/fields/RadioButtonsField.js +57 -0
- package/build/browser/action-form/fields/RadioButtonsField.js.map +1 -0
- package/build/browser/action-form/fields/RadioButtonsField.module.css +83 -0
- package/build/browser/action-form/fields/RadioButtonsField.module.css.js +10 -0
- package/build/browser/action-form/fields/TextAreaField.js +50 -0
- package/build/browser/action-form/fields/TextAreaField.js.map +1 -0
- package/build/browser/action-form/fields/TextInputField.js +39 -0
- package/build/browser/action-form/fields/TextInputField.js.map +1 -0
- package/build/browser/action-form/utils/coerceFieldValue.js +93 -0
- package/build/browser/action-form/utils/coerceFieldValue.js.map +1 -0
- package/build/browser/action-form/utils/getDefaultFieldDefinitions.js +120 -0
- package/build/browser/action-form/utils/getDefaultFieldDefinitions.js.map +1 -0
- package/build/browser/base-components/action-button/ActionButton.module.css +0 -4
- package/build/browser/base-components/checkbox/Checkbox.js +8 -4
- package/build/browser/base-components/checkbox/Checkbox.js.map +1 -1
- package/build/browser/base-components/checkbox/Checkbox.module.css +13 -8
- package/build/browser/base-components/combobox/Combobox.js +154 -0
- package/build/browser/base-components/combobox/Combobox.js.map +1 -0
- package/build/browser/base-components/combobox/Combobox.module.css +364 -0
- package/build/browser/base-components/combobox/Combobox.module.css.js +18 -0
- package/build/browser/base-components/dialog/Dialog.js +4 -2
- package/build/browser/base-components/dialog/Dialog.js.map +1 -1
- package/build/browser/base-components/dialog/Dialog.module.css +0 -8
- package/build/browser/base-components/draggable-list/DraggableList.module.css +2 -10
- package/build/browser/base-components/search-bar/SearchBar.module.css +2 -2
- package/build/browser/base-components/searchable-menu/SearchableMenu.js +86 -0
- package/build/browser/base-components/searchable-menu/SearchableMenu.js.map +1 -0
- package/build/browser/base-components/searchable-menu/SearchableMenu.module.css +80 -0
- package/build/browser/base-components/searchable-menu/SearchableMenu.module.css.js +10 -0
- package/build/browser/base-components/select/Select.js +93 -0
- package/build/browser/base-components/select/Select.js.map +1 -0
- package/build/browser/base-components/select/Select.module.css +233 -0
- package/build/browser/base-components/select/Select.module.css.js +13 -0
- package/build/browser/base-components/skeleton/SkeletonBar.js +36 -0
- package/build/browser/base-components/skeleton/SkeletonBar.js.map +1 -0
- package/build/browser/base-components/skeleton/SkeletonBar.module.css +39 -0
- package/build/browser/base-components/skeleton/SkeletonBar.module.css.js +7 -0
- package/build/browser/base-components/switch/Switch.module.css +14 -15
- package/build/browser/base-components/tooltip/Tooltip.js +91 -0
- package/build/browser/base-components/tooltip/Tooltip.js.map +1 -0
- package/build/browser/base-components/tooltip/Tooltip.module.css +70 -0
- package/build/browser/base-components/tooltip/Tooltip.module.css.js +11 -0
- package/build/browser/base-components/tooltip/index.js +18 -0
- package/build/browser/base-components/tooltip/index.js.map +1 -0
- package/build/browser/filter-list/FilterInput.js +141 -0
- package/build/browser/filter-list/FilterInput.js.map +1 -0
- package/build/browser/filter-list/FilterList.js +142 -0
- package/build/browser/filter-list/FilterList.js.map +1 -0
- package/build/browser/filter-list/FilterListApi.js.map +1 -1
- package/build/browser/filter-list/FilterListItemApi.js.map +1 -1
- package/build/browser/filter-list/base/AddFilterPopover.js +35 -0
- package/build/browser/filter-list/base/AddFilterPopover.js.map +1 -0
- package/build/browser/filter-list/base/AddFilterPopover.module.css +49 -0
- package/build/browser/filter-list/base/AddFilterPopover.module.css.js +6 -0
- package/build/browser/filter-list/base/BaseFilterList.js +94 -0
- package/build/browser/filter-list/base/BaseFilterList.js.map +1 -0
- package/build/browser/filter-list/base/BaseFilterListApi.js +2 -0
- package/build/browser/filter-list/base/BaseFilterListApi.js.map +1 -0
- package/build/browser/filter-list/base/DragHandleIcon.js +51 -0
- package/build/browser/filter-list/base/DragHandleIcon.js.map +1 -0
- package/build/browser/filter-list/base/ExcludeDropdown.js +62 -0
- package/build/browser/filter-list/base/ExcludeDropdown.js.map +1 -0
- package/build/browser/filter-list/base/ExcludeDropdown.module.css +96 -0
- package/build/browser/filter-list/base/ExcludeDropdown.module.css.js +12 -0
- package/build/browser/filter-list/base/FilterIcons.js +65 -0
- package/build/browser/filter-list/base/FilterIcons.js.map +1 -0
- package/build/browser/filter-list/base/FilterInputExcludeRow.js +67 -0
- package/build/browser/filter-list/base/FilterInputExcludeRow.js.map +1 -0
- package/build/browser/filter-list/base/FilterList.module.css +84 -6
- package/build/browser/filter-list/base/FilterList.module.css.js +6 -0
- package/build/browser/filter-list/base/FilterListContent.js +172 -6
- package/build/browser/filter-list/base/FilterListContent.js.map +1 -1
- package/build/browser/filter-list/base/FilterListContent.module.css +6 -0
- package/build/browser/filter-list/base/FilterListContent.module.css.js +2 -1
- package/build/browser/filter-list/base/FilterListHeader.js +14 -13
- package/build/browser/filter-list/base/FilterListHeader.js.map +1 -1
- package/build/browser/filter-list/base/FilterListHeader.module.css +22 -21
- package/build/browser/filter-list/base/FilterListHeader.module.css.js +1 -1
- package/build/browser/filter-list/base/FilterListItem.js +124 -27
- package/build/browser/filter-list/base/FilterListItem.js.map +1 -1
- package/build/browser/filter-list/base/FilterListItem.module.css +173 -0
- package/build/browser/filter-list/base/FilterListItem.module.css.js +11 -1
- package/build/browser/filter-list/base/SortableFilterListItem.js +64 -0
- package/build/browser/filter-list/base/SortableFilterListItem.js.map +1 -0
- package/build/browser/filter-list/base/index.js +1 -2
- package/build/browser/filter-list/base/index.js.map +1 -1
- package/build/browser/filter-list/base/inputs/ContainsTextInput.js +5 -7
- package/build/browser/filter-list/base/inputs/ContainsTextInput.js.map +1 -1
- package/build/browser/filter-list/base/inputs/DateRangeInput.js +37 -0
- package/build/browser/filter-list/base/inputs/DateRangeInput.js.map +1 -0
- package/build/browser/filter-list/base/inputs/LinkedPropertyInput.module.css +20 -0
- package/build/browser/filter-list/base/inputs/LinkedPropertyInput.module.css.js +6 -0
- package/build/browser/filter-list/base/inputs/ListogramInput.js +118 -0
- package/build/browser/filter-list/base/inputs/ListogramInput.js.map +1 -0
- package/build/browser/filter-list/base/inputs/ListogramInput.module.css +137 -0
- package/build/browser/filter-list/base/inputs/ListogramInput.module.css.js +14 -0
- package/build/browser/filter-list/base/inputs/ListogramSkeleton.js +45 -0
- package/build/browser/filter-list/base/inputs/ListogramSkeleton.js.map +1 -0
- package/build/browser/filter-list/base/inputs/ListogramSkeleton.module.css +32 -0
- package/build/browser/filter-list/base/inputs/ListogramSkeleton.module.css.js +8 -0
- package/build/browser/filter-list/base/inputs/MultiDateInput.js +1 -1
- package/build/browser/filter-list/base/inputs/MultiDateInput.js.map +1 -1
- package/build/browser/filter-list/base/inputs/MultiDateInput.module.css +6 -6
- package/build/browser/filter-list/base/inputs/MultiSelectInput.js +76 -0
- package/build/browser/filter-list/base/inputs/MultiSelectInput.js.map +1 -0
- package/build/browser/filter-list/base/inputs/MultiSelectInput.module.css +37 -0
- package/build/browser/filter-list/base/inputs/MultiSelectInput.module.css.js +8 -0
- package/build/browser/filter-list/base/inputs/NullValueWrapper.js +57 -0
- package/build/browser/filter-list/base/inputs/NullValueWrapper.js.map +1 -0
- package/build/browser/filter-list/base/inputs/NullValueWrapper.module.css +50 -0
- package/build/browser/filter-list/base/inputs/NullValueWrapper.module.css.js +10 -0
- package/build/browser/filter-list/base/inputs/NumberRangeInput.js +48 -0
- package/build/browser/filter-list/base/inputs/NumberRangeInput.js.map +1 -0
- package/build/browser/filter-list/base/inputs/RangeInput.js +159 -0
- package/build/browser/filter-list/base/inputs/RangeInput.js.map +1 -0
- package/build/browser/filter-list/base/inputs/RangeInput.module.css +106 -0
- package/build/browser/filter-list/base/inputs/RangeInput.module.css.js +13 -0
- package/build/browser/filter-list/base/inputs/SingleDateInput.js +1 -1
- package/build/browser/filter-list/base/inputs/SingleDateInput.js.map +1 -1
- package/build/browser/filter-list/base/inputs/SingleDateInput.module.css +2 -2
- package/build/browser/filter-list/base/inputs/SingleSelectInput.js +77 -0
- package/build/browser/filter-list/base/inputs/SingleSelectInput.js.map +1 -0
- package/build/browser/filter-list/base/inputs/SingleSelectInput.module.css +45 -0
- package/build/browser/filter-list/base/inputs/SingleSelectInput.module.css.js +10 -0
- package/build/browser/filter-list/base/inputs/TextTagsInput.js +133 -0
- package/build/browser/filter-list/base/inputs/TextTagsInput.js.map +1 -0
- package/build/browser/filter-list/base/inputs/TextTagsInput.module.css +25 -0
- package/build/browser/filter-list/base/inputs/TextTagsInput.module.css.js +7 -0
- package/build/browser/filter-list/base/inputs/TimelineInput.js +74 -0
- package/build/browser/filter-list/base/inputs/TimelineInput.js.map +1 -0
- package/build/browser/filter-list/base/inputs/TimelineInput.module.css +75 -0
- package/build/browser/filter-list/base/inputs/TimelineInput.module.css.js +10 -0
- package/build/browser/filter-list/base/inputs/createHistogramBuckets.js +53 -0
- package/build/browser/filter-list/base/inputs/createHistogramBuckets.js.map +1 -0
- package/build/browser/filter-list/base/inputs/index.js +5 -1
- package/build/browser/filter-list/base/inputs/index.js.map +1 -1
- package/build/browser/filter-list/base/inputs/shared.module.css +5 -5
- package/build/browser/filter-list/base/inputs/useStableData.js +29 -0
- package/build/browser/filter-list/base/inputs/useStableData.js.map +1 -0
- package/build/browser/filter-list/hooks/useFilterListState.js +56 -10
- package/build/browser/filter-list/hooks/useFilterListState.js.map +1 -1
- package/build/browser/filter-list/hooks/useFilterVisibility.js +74 -0
- package/build/browser/filter-list/hooks/useFilterVisibility.js.map +1 -0
- package/build/browser/filter-list/hooks/usePropertyAggregation.js +98 -0
- package/build/browser/filter-list/hooks/usePropertyAggregation.js.map +1 -0
- package/build/browser/filter-list/inputs/ContainsTextFilterInput.js +38 -0
- package/build/browser/filter-list/inputs/ContainsTextFilterInput.js.map +1 -0
- package/build/browser/filter-list/inputs/DateRangeFilterInput.js +109 -0
- package/build/browser/filter-list/inputs/DateRangeFilterInput.js.map +1 -0
- package/build/browser/filter-list/inputs/LinkedPropertyInput.js +496 -0
- package/build/browser/filter-list/inputs/LinkedPropertyInput.js.map +1 -0
- package/build/browser/filter-list/inputs/ListogramFilterInput.js +83 -0
- package/build/browser/filter-list/inputs/ListogramFilterInput.js.map +1 -0
- package/build/browser/filter-list/inputs/MultiDateFilterInput.js +38 -0
- package/build/browser/filter-list/inputs/MultiDateFilterInput.js.map +1 -0
- package/build/browser/filter-list/inputs/MultiSelectFilterInput.js +71 -0
- package/build/browser/filter-list/inputs/MultiSelectFilterInput.js.map +1 -0
- package/build/browser/filter-list/inputs/NumberRangeFilterInput.js +109 -0
- package/build/browser/filter-list/inputs/NumberRangeFilterInput.js.map +1 -0
- package/build/browser/filter-list/inputs/PropertyFilterInput.js +142 -0
- package/build/browser/filter-list/inputs/PropertyFilterInput.js.map +1 -0
- package/build/browser/filter-list/inputs/SingleDateFilterInput.js +38 -0
- package/build/browser/filter-list/inputs/SingleDateFilterInput.js.map +1 -0
- package/build/browser/filter-list/inputs/SingleSelectFilterInput.js +71 -0
- package/build/browser/filter-list/inputs/SingleSelectFilterInput.js.map +1 -0
- package/build/browser/filter-list/inputs/TextTagsFilterInput.js +70 -0
- package/build/browser/filter-list/inputs/TextTagsFilterInput.js.map +1 -0
- package/build/browser/filter-list/inputs/TimelineFilterInput.js +49 -0
- package/build/browser/filter-list/inputs/TimelineFilterInput.js.map +1 -0
- package/build/browser/filter-list/inputs/ToggleFilterInput.js +36 -0
- package/build/browser/filter-list/inputs/ToggleFilterInput.js.map +1 -0
- package/build/browser/filter-list/types/AggregationTypes.js +2 -0
- package/build/browser/filter-list/types/AggregationTypes.js.map +1 -0
- package/build/browser/filter-list/types/CustomRendererTypes.js.map +1 -1
- package/build/browser/filter-list/types/LinkedFilterTypes.js.map +1 -1
- package/build/browser/filter-list/types/index.js +0 -2
- package/build/browser/filter-list/types/index.js.map +1 -1
- package/build/browser/filter-list/utils/aggregationHelpers.js +44 -0
- package/build/browser/filter-list/utils/aggregationHelpers.js.map +1 -0
- package/build/browser/filter-list/utils/filterStateSerialization.js +42 -0
- package/build/browser/filter-list/utils/filterStateSerialization.js.map +1 -0
- package/build/browser/filter-list/utils/filterStateToWhereClause.js +124 -91
- package/build/browser/filter-list/utils/filterStateToWhereClause.js.map +1 -1
- package/build/browser/filter-list/utils/filterValues.js +55 -1
- package/build/browser/filter-list/utils/filterValues.js.map +1 -1
- package/build/browser/filter-list/utils/getFilterKey.js +1 -1
- package/build/browser/filter-list/utils/getFilterKey.js.map +1 -1
- package/build/browser/filter-list/utils/getFilterLabel.js +36 -0
- package/build/browser/filter-list/utils/getFilterLabel.js.map +1 -0
- package/build/browser/object-table/ColumnConfigDialog.module.css +1 -11
- package/build/browser/object-table/DefaultCellRenderer.js +23 -5
- package/build/browser/object-table/DefaultCellRenderer.js.map +1 -1
- package/build/browser/object-table/EditableCell.js +87 -10
- package/build/browser/object-table/EditableCell.js.map +1 -1
- package/build/browser/object-table/EditableCell.module.css +69 -2
- package/build/browser/object-table/EditableCell.module.css.js +6 -1
- package/build/browser/object-table/LoadingCell.js +7 -3
- package/build/browser/object-table/LoadingCell.js.map +1 -1
- package/build/browser/object-table/LoadingCell.module.css +3 -21
- package/build/browser/object-table/LoadingCell.module.css.js +1 -2
- package/build/browser/object-table/LoadingRow.js +2 -1
- package/build/browser/object-table/LoadingRow.js.map +1 -1
- package/build/browser/object-table/LoadingStateTable.js +2 -1
- package/build/browser/object-table/LoadingStateTable.js.map +1 -1
- package/build/browser/object-table/MultiColumnSortDialog.js +22 -58
- package/build/browser/object-table/MultiColumnSortDialog.js.map +1 -1
- package/build/browser/object-table/MultiColumnSortDialog.module.css +0 -69
- package/build/browser/object-table/MultiColumnSortDialog.module.css.js +0 -5
- package/build/browser/object-table/ObjectTable.js +16 -23
- package/build/browser/object-table/ObjectTable.js.map +1 -1
- package/build/browser/object-table/ObjectTableApi.js.map +1 -1
- package/build/browser/object-table/SelectionCells.js +1 -0
- package/build/browser/object-table/SelectionCells.js.map +1 -1
- package/build/browser/object-table/Table.js +23 -15
- package/build/browser/object-table/Table.js.map +1 -1
- package/build/browser/object-table/Table.module.css +0 -8
- package/build/browser/object-table/Table.module.css.js +1 -2
- package/build/browser/object-table/TableBody.js +8 -2
- package/build/browser/object-table/TableBody.js.map +1 -1
- package/build/browser/object-table/TableCell.module.css +2 -9
- package/build/browser/object-table/TableEditContainer.js +90 -0
- package/build/browser/object-table/TableEditContainer.js.map +1 -0
- package/build/browser/object-table/TableEditContainer.module.css +71 -0
- package/build/browser/object-table/TableEditContainer.module.css.js +13 -0
- package/build/browser/object-table/TableHeader.js +4 -1
- package/build/browser/object-table/TableHeader.js.map +1 -1
- package/build/browser/object-table/TableHeader.module.css +4 -3
- package/build/browser/object-table/TableHeader.module.css.js +1 -0
- package/build/browser/object-table/TableHeaderWithPopover.js +2 -4
- package/build/browser/object-table/TableHeaderWithPopover.js.map +1 -1
- package/build/browser/object-table/TableHeaderWithPopover.module.css +1 -12
- package/build/browser/object-table/TableRow.js +10 -3
- package/build/browser/object-table/TableRow.js.map +1 -1
- package/build/browser/object-table/TableRow.module.css +2 -1
- package/build/browser/object-table/components/AsyncValueCell.js +35 -0
- package/build/browser/object-table/components/AsyncValueCell.js.map +1 -0
- package/build/browser/object-table/hooks/useColumnDefs.js +5 -2
- package/build/browser/object-table/hooks/useColumnDefs.js.map +1 -1
- package/build/browser/object-table/hooks/useEditableTable.js +39 -11
- package/build/browser/object-table/hooks/useEditableTable.js.map +1 -1
- package/build/browser/object-table/hooks/useFunctionColumnsData.js +135 -0
- package/build/browser/object-table/hooks/useFunctionColumnsData.js.map +1 -0
- package/build/browser/object-table/hooks/useObjectTableData.js +33 -17
- package/build/browser/object-table/hooks/useObjectTableData.js.map +1 -1
- package/build/browser/object-table/hooks/useRowSelection.js +11 -8
- package/build/browser/object-table/hooks/useRowSelection.js.map +1 -1
- package/build/browser/object-table/utils/AsyncCellData.js +30 -0
- package/build/browser/object-table/utils/AsyncCellData.js.map +1 -0
- package/build/browser/object-table/utils/constants.js +1 -0
- package/build/browser/object-table/utils/constants.js.map +1 -1
- package/build/browser/object-table/utils/getCellId.js +0 -7
- package/build/browser/object-table/utils/getCellId.js.map +1 -1
- package/build/browser/object-table/utils/types.js.map +1 -1
- package/build/browser/pdf-viewer/PdfRenderer.js +88 -0
- package/build/browser/pdf-viewer/PdfRenderer.js.map +1 -0
- package/build/browser/pdf-viewer/PdfViewer.js +179 -0
- package/build/browser/pdf-viewer/PdfViewer.js.map +1 -0
- package/build/browser/pdf-viewer/PdfViewer.module.css +95 -0
- package/build/browser/pdf-viewer/PdfViewer.module.css.js +16 -0
- package/build/browser/pdf-viewer/PdfViewerContext.js +108 -0
- package/build/browser/pdf-viewer/PdfViewerContext.js.map +1 -0
- package/build/browser/pdf-viewer/components/PdfViewerAnnotationLayer.js +141 -0
- package/build/browser/pdf-viewer/components/PdfViewerAnnotationLayer.js.map +1 -0
- package/build/browser/pdf-viewer/components/PdfViewerAnnotationLayer.module.css +82 -0
- package/build/browser/pdf-viewer/components/PdfViewerAnnotationLayer.module.css.js +12 -0
- package/build/browser/pdf-viewer/components/PdfViewerContent.js +125 -0
- package/build/browser/pdf-viewer/components/PdfViewerContent.js.map +1 -0
- package/build/browser/pdf-viewer/components/PdfViewerOutlineSidebar.js +98 -0
- package/build/browser/pdf-viewer/components/PdfViewerOutlineSidebar.js.map +1 -0
- package/build/browser/pdf-viewer/components/PdfViewerOutlineSidebar.module.css +89 -0
- package/build/browser/pdf-viewer/components/PdfViewerOutlineSidebar.module.css.js +15 -0
- package/build/browser/pdf-viewer/components/PdfViewerSearchBar.js +84 -0
- package/build/browser/pdf-viewer/components/PdfViewerSearchBar.js.map +1 -0
- package/build/browser/pdf-viewer/components/PdfViewerSearchBar.module.css +65 -0
- package/build/browser/pdf-viewer/components/PdfViewerSearchBar.module.css.js +10 -0
- package/build/browser/pdf-viewer/components/PdfViewerSidebar.js +78 -0
- package/build/browser/pdf-viewer/components/PdfViewerSidebar.js.map +1 -0
- package/build/browser/pdf-viewer/components/PdfViewerSidebar.module.css +37 -0
- package/build/browser/pdf-viewer/components/PdfViewerSidebar.module.css.js +10 -0
- package/build/browser/pdf-viewer/components/PdfViewerSidebarHeader.js +54 -0
- package/build/browser/pdf-viewer/components/PdfViewerSidebarHeader.js.map +1 -0
- package/build/browser/pdf-viewer/components/PdfViewerSidebarHeader.module.css +70 -0
- package/build/browser/pdf-viewer/components/PdfViewerSidebarHeader.module.css.js +8 -0
- package/build/browser/pdf-viewer/components/PdfViewerThumbnail.js +100 -0
- package/build/browser/pdf-viewer/components/PdfViewerThumbnail.js.map +1 -0
- package/build/browser/pdf-viewer/components/PdfViewerThumbnail.module.css +26 -0
- package/build/browser/pdf-viewer/components/PdfViewerThumbnail.module.css.js +8 -0
- package/build/browser/pdf-viewer/components/PdfViewerToolbar.js +221 -0
- package/build/browser/pdf-viewer/components/PdfViewerToolbar.js.map +1 -0
- package/build/browser/pdf-viewer/components/PdfViewerToolbar.module.css +91 -0
- package/build/browser/pdf-viewer/components/PdfViewerToolbar.module.css.js +13 -0
- package/build/browser/pdf-viewer/constants.js +46 -0
- package/build/browser/pdf-viewer/constants.js.map +1 -0
- package/build/browser/pdf-viewer/hooks/usePdfAnnotationPortals.js +54 -0
- package/build/browser/pdf-viewer/hooks/usePdfAnnotationPortals.js.map +1 -0
- package/build/browser/pdf-viewer/hooks/usePdfAnnotationsByPage.js +30 -0
- package/build/browser/pdf-viewer/hooks/usePdfAnnotationsByPage.js.map +1 -0
- package/build/browser/pdf-viewer/hooks/usePdfDocument.js +66 -0
- package/build/browser/pdf-viewer/hooks/usePdfDocument.js.map +1 -0
- package/build/browser/pdf-viewer/hooks/usePdfFormFields.js +341 -0
- package/build/browser/pdf-viewer/hooks/usePdfFormFields.js.map +1 -0
- package/build/browser/pdf-viewer/hooks/usePdfHighlightMode.js +227 -0
- package/build/browser/pdf-viewer/hooks/usePdfHighlightMode.js.map +1 -0
- package/build/browser/pdf-viewer/hooks/usePdfOutline.js +268 -0
- package/build/browser/pdf-viewer/hooks/usePdfOutline.js.map +1 -0
- package/build/browser/pdf-viewer/hooks/usePdfViewer.js +86 -0
- package/build/browser/pdf-viewer/hooks/usePdfViewer.js.map +1 -0
- package/build/browser/pdf-viewer/hooks/usePdfViewerCore.js +80 -0
- package/build/browser/pdf-viewer/hooks/usePdfViewerCore.js.map +1 -0
- package/build/browser/pdf-viewer/hooks/usePdfViewerSearch.js +106 -0
- package/build/browser/pdf-viewer/hooks/usePdfViewerSearch.js.map +1 -0
- package/build/browser/pdf-viewer/hooks/usePdfViewerState.js +135 -0
- package/build/browser/pdf-viewer/hooks/usePdfViewerState.js.map +1 -0
- package/build/browser/pdf-viewer/hooks/usePdfViewerSync.js +71 -0
- package/build/browser/pdf-viewer/hooks/usePdfViewerSync.js.map +1 -0
- package/build/browser/pdf-viewer/types.js +2 -0
- package/build/browser/pdf-viewer/types.js.map +1 -0
- package/build/browser/public/experimental.js +34 -0
- package/build/browser/public/experimental.js.map +1 -1
- package/build/browser/public/primitives.js +20 -0
- package/build/browser/public/primitives.js.map +1 -0
- package/build/browser/shared/ErrorBoundary.module.css +14 -14
- package/build/browser/{filter-list/utils → shared}/assertUnreachable.js +1 -1
- package/build/browser/{filter-list/utils → shared}/assertUnreachable.js.map +1 -1
- package/build/{esm/filter-list/base/inputs → browser/shared}/dateUtils.js +38 -2
- package/build/browser/shared/dateUtils.js.map +1 -0
- package/build/browser/shared/typedMemo.js +25 -0
- package/build/browser/shared/typedMemo.js.map +1 -0
- package/build/browser/styles.css +4452 -1405
- package/build/cjs/DateCalendar-QWGFKD6J.css +113 -0
- package/build/cjs/DateCalendar-QWGFKD6J.css.map +1 -0
- package/build/cjs/DateCalendar-R44GMN3O.cjs +67 -0
- package/build/cjs/DateCalendar-R44GMN3O.cjs.map +1 -0
- package/build/cjs/chunk-HMQTYQEX.cjs +9 -0
- package/build/cjs/chunk-HMQTYQEX.cjs.map +1 -0
- package/build/cjs/chunk-MRRRZN44.cjs +165 -0
- package/build/cjs/chunk-MRRRZN44.cjs.map +1 -0
- package/build/cjs/chunk-UZ2E5NRX.cjs +8 -0
- package/build/cjs/chunk-UZ2E5NRX.cjs.map +1 -0
- package/build/cjs/index.cjs +2 -0
- package/build/cjs/public/experimental.cjs +9514 -2011
- package/build/cjs/public/experimental.cjs.map +1 -1
- package/build/cjs/public/experimental.css +3230 -736
- package/build/cjs/public/experimental.css.map +1 -1
- package/build/cjs/public/experimental.d.cts +1182 -125
- package/build/cjs/public/primitives.cjs +25 -0
- package/build/cjs/public/primitives.cjs.map +1 -0
- package/build/cjs/public/primitives.css +154 -0
- package/build/cjs/public/primitives.css.map +1 -0
- package/build/cjs/public/primitives.d.cts +50 -0
- package/build/esm/action-form/ActionForm.js +117 -0
- package/build/esm/action-form/ActionForm.js.map +1 -0
- package/build/esm/action-form/ActionFormApi.js.map +1 -1
- package/build/esm/action-form/BaseForm.js +83 -0
- package/build/esm/action-form/BaseForm.js.map +1 -0
- package/build/esm/action-form/BaseForm.module.css +38 -0
- package/build/esm/action-form/FormField.js +42 -0
- package/build/esm/action-form/FormField.js.map +1 -0
- package/build/esm/action-form/FormField.module.css +41 -0
- package/build/esm/action-form/FormFieldApi.js.map +1 -1
- package/build/esm/action-form/FormHeader.js +26 -0
- package/build/esm/action-form/FormHeader.js.map +1 -0
- package/build/esm/action-form/FormHeader.module.css +26 -0
- package/build/esm/action-form/fields/BaseInput.module.css +56 -0
- package/build/esm/action-form/fields/CustomField.js +30 -0
- package/build/esm/action-form/fields/CustomField.js.map +1 -0
- package/build/esm/action-form/fields/DateCalendar.js +70 -0
- package/build/esm/action-form/fields/DateCalendar.js.map +1 -0
- package/build/esm/action-form/fields/DateCalendar.module.css +136 -0
- package/build/esm/action-form/fields/DatetimePickerField.js +98 -0
- package/build/esm/action-form/fields/DatetimePickerField.js.map +1 -0
- package/build/esm/action-form/fields/DatetimePickerField.module.css +66 -0
- package/build/esm/action-form/fields/DropdownField.js +104 -0
- package/build/esm/action-form/fields/DropdownField.js.map +1 -0
- package/build/esm/action-form/fields/FieldBridge.js +45 -0
- package/build/esm/action-form/fields/FieldBridge.js.map +1 -0
- package/build/esm/action-form/fields/FilePickerField.js +119 -0
- package/build/esm/action-form/fields/FilePickerField.js.map +1 -0
- package/build/esm/action-form/fields/FilePickerField.module.css +132 -0
- package/build/esm/action-form/fields/FormFieldRenderer.js +128 -0
- package/build/esm/action-form/fields/FormFieldRenderer.js.map +1 -0
- package/build/esm/action-form/fields/LazyDateCalendar.js +27 -0
- package/build/esm/action-form/fields/LazyDateCalendar.js.map +1 -0
- package/build/esm/action-form/fields/NumberInputField.js +130 -0
- package/build/esm/action-form/fields/NumberInputField.js.map +1 -0
- package/build/esm/action-form/fields/NumberInputField.module.css +96 -0
- package/build/esm/action-form/fields/RadioButtonsField.js +57 -0
- package/build/esm/action-form/fields/RadioButtonsField.js.map +1 -0
- package/build/esm/action-form/fields/RadioButtonsField.module.css +83 -0
- package/build/esm/action-form/fields/TextAreaField.js +50 -0
- package/build/esm/action-form/fields/TextAreaField.js.map +1 -0
- package/build/esm/action-form/fields/TextInputField.js +39 -0
- package/build/esm/action-form/fields/TextInputField.js.map +1 -0
- package/build/esm/action-form/utils/coerceFieldValue.js +93 -0
- package/build/esm/action-form/utils/coerceFieldValue.js.map +1 -0
- package/build/esm/action-form/utils/getDefaultFieldDefinitions.js +120 -0
- package/build/esm/action-form/utils/getDefaultFieldDefinitions.js.map +1 -0
- package/build/esm/base-components/action-button/ActionButton.module.css +0 -4
- package/build/esm/base-components/checkbox/Checkbox.js +8 -4
- package/build/esm/base-components/checkbox/Checkbox.js.map +1 -1
- package/build/esm/base-components/checkbox/Checkbox.module.css +13 -8
- package/build/esm/base-components/combobox/Combobox.js +154 -0
- package/build/esm/base-components/combobox/Combobox.js.map +1 -0
- package/build/esm/base-components/combobox/Combobox.module.css +364 -0
- package/build/esm/base-components/dialog/Dialog.js +4 -2
- package/build/esm/base-components/dialog/Dialog.js.map +1 -1
- package/build/esm/base-components/dialog/Dialog.module.css +0 -8
- package/build/esm/base-components/draggable-list/DraggableList.module.css +2 -10
- package/build/esm/base-components/search-bar/SearchBar.module.css +2 -2
- package/build/esm/base-components/searchable-menu/SearchableMenu.js +86 -0
- package/build/esm/base-components/searchable-menu/SearchableMenu.js.map +1 -0
- package/build/esm/base-components/searchable-menu/SearchableMenu.module.css +80 -0
- package/build/esm/base-components/select/Select.js +93 -0
- package/build/esm/base-components/select/Select.js.map +1 -0
- package/build/esm/base-components/select/Select.module.css +233 -0
- package/build/esm/base-components/skeleton/SkeletonBar.js +36 -0
- package/build/esm/base-components/skeleton/SkeletonBar.js.map +1 -0
- package/build/esm/base-components/skeleton/SkeletonBar.module.css +39 -0
- package/build/esm/base-components/switch/Switch.module.css +14 -15
- package/build/esm/base-components/tooltip/Tooltip.js +91 -0
- package/build/esm/base-components/tooltip/Tooltip.js.map +1 -0
- package/build/esm/base-components/tooltip/Tooltip.module.css +70 -0
- package/build/esm/base-components/tooltip/index.js +18 -0
- package/build/esm/base-components/tooltip/index.js.map +1 -0
- package/build/esm/filter-list/FilterInput.js +141 -0
- package/build/esm/filter-list/FilterInput.js.map +1 -0
- package/build/esm/filter-list/FilterList.js +142 -0
- package/build/esm/filter-list/FilterList.js.map +1 -0
- package/build/esm/filter-list/FilterListApi.js.map +1 -1
- package/build/esm/filter-list/FilterListItemApi.js.map +1 -1
- package/build/esm/filter-list/base/AddFilterPopover.js +35 -0
- package/build/esm/filter-list/base/AddFilterPopover.js.map +1 -0
- package/build/esm/filter-list/base/AddFilterPopover.module.css +49 -0
- package/build/esm/filter-list/base/BaseFilterList.js +94 -0
- package/build/esm/filter-list/base/BaseFilterList.js.map +1 -0
- package/build/esm/filter-list/base/BaseFilterListApi.js +2 -0
- package/build/esm/filter-list/base/BaseFilterListApi.js.map +1 -0
- package/build/esm/filter-list/base/DragHandleIcon.js +51 -0
- package/build/esm/filter-list/base/DragHandleIcon.js.map +1 -0
- package/build/esm/filter-list/base/ExcludeDropdown.js +62 -0
- package/build/esm/filter-list/base/ExcludeDropdown.js.map +1 -0
- package/build/esm/filter-list/base/ExcludeDropdown.module.css +96 -0
- package/build/esm/filter-list/base/FilterIcons.js +65 -0
- package/build/esm/filter-list/base/FilterIcons.js.map +1 -0
- package/build/esm/filter-list/base/FilterInputExcludeRow.js +67 -0
- package/build/esm/filter-list/base/FilterInputExcludeRow.js.map +1 -0
- package/build/esm/filter-list/base/FilterList.module.css +84 -6
- package/build/esm/filter-list/base/FilterListContent.js +172 -6
- package/build/esm/filter-list/base/FilterListContent.js.map +1 -1
- package/build/esm/filter-list/base/FilterListContent.module.css +6 -0
- package/build/esm/filter-list/base/FilterListHeader.js +14 -13
- package/build/esm/filter-list/base/FilterListHeader.js.map +1 -1
- package/build/esm/filter-list/base/FilterListHeader.module.css +22 -21
- package/build/esm/filter-list/base/FilterListItem.js +124 -27
- package/build/esm/filter-list/base/FilterListItem.js.map +1 -1
- package/build/esm/filter-list/base/FilterListItem.module.css +173 -0
- package/build/esm/filter-list/base/SortableFilterListItem.js +64 -0
- package/build/esm/filter-list/base/SortableFilterListItem.js.map +1 -0
- package/build/esm/filter-list/base/index.js +1 -2
- package/build/esm/filter-list/base/index.js.map +1 -1
- package/build/esm/filter-list/base/inputs/ContainsTextInput.js +5 -7
- package/build/esm/filter-list/base/inputs/ContainsTextInput.js.map +1 -1
- package/build/esm/filter-list/base/inputs/DateRangeInput.js +37 -0
- package/build/esm/filter-list/base/inputs/DateRangeInput.js.map +1 -0
- package/build/esm/filter-list/base/inputs/LinkedPropertyInput.module.css +20 -0
- package/build/esm/filter-list/base/inputs/ListogramInput.js +118 -0
- package/build/esm/filter-list/base/inputs/ListogramInput.js.map +1 -0
- package/build/esm/filter-list/base/inputs/ListogramInput.module.css +137 -0
- package/build/esm/filter-list/base/inputs/ListogramSkeleton.js +45 -0
- package/build/esm/filter-list/base/inputs/ListogramSkeleton.js.map +1 -0
- package/build/esm/filter-list/base/inputs/ListogramSkeleton.module.css +32 -0
- package/build/esm/filter-list/base/inputs/MultiDateInput.js +1 -1
- package/build/esm/filter-list/base/inputs/MultiDateInput.js.map +1 -1
- package/build/esm/filter-list/base/inputs/MultiDateInput.module.css +6 -6
- package/build/esm/filter-list/base/inputs/MultiSelectInput.js +76 -0
- package/build/esm/filter-list/base/inputs/MultiSelectInput.js.map +1 -0
- package/build/esm/filter-list/base/inputs/MultiSelectInput.module.css +37 -0
- package/build/esm/filter-list/base/inputs/NullValueWrapper.js +57 -0
- package/build/esm/filter-list/base/inputs/NullValueWrapper.js.map +1 -0
- package/build/esm/filter-list/base/inputs/NullValueWrapper.module.css +50 -0
- package/build/esm/filter-list/base/inputs/NumberRangeInput.js +48 -0
- package/build/esm/filter-list/base/inputs/NumberRangeInput.js.map +1 -0
- package/build/esm/filter-list/base/inputs/RangeInput.js +159 -0
- package/build/esm/filter-list/base/inputs/RangeInput.js.map +1 -0
- package/build/esm/filter-list/base/inputs/RangeInput.module.css +106 -0
- package/build/esm/filter-list/base/inputs/SingleDateInput.js +1 -1
- package/build/esm/filter-list/base/inputs/SingleDateInput.js.map +1 -1
- package/build/esm/filter-list/base/inputs/SingleDateInput.module.css +2 -2
- package/build/esm/filter-list/base/inputs/SingleSelectInput.js +77 -0
- package/build/esm/filter-list/base/inputs/SingleSelectInput.js.map +1 -0
- package/build/esm/filter-list/base/inputs/SingleSelectInput.module.css +45 -0
- package/build/esm/filter-list/base/inputs/TextTagsInput.js +133 -0
- package/build/esm/filter-list/base/inputs/TextTagsInput.js.map +1 -0
- package/build/esm/filter-list/base/inputs/TextTagsInput.module.css +25 -0
- package/build/esm/filter-list/base/inputs/TimelineInput.js +74 -0
- package/build/esm/filter-list/base/inputs/TimelineInput.js.map +1 -0
- package/build/esm/filter-list/base/inputs/TimelineInput.module.css +75 -0
- package/build/esm/filter-list/base/inputs/createHistogramBuckets.js +53 -0
- package/build/esm/filter-list/base/inputs/createHistogramBuckets.js.map +1 -0
- package/build/esm/filter-list/base/inputs/index.js +5 -1
- package/build/esm/filter-list/base/inputs/index.js.map +1 -1
- package/build/esm/filter-list/base/inputs/shared.module.css +5 -5
- package/build/esm/filter-list/base/inputs/useStableData.js +29 -0
- package/build/esm/filter-list/base/inputs/useStableData.js.map +1 -0
- package/build/esm/filter-list/hooks/useFilterListState.js +56 -10
- package/build/esm/filter-list/hooks/useFilterListState.js.map +1 -1
- package/build/esm/filter-list/hooks/useFilterVisibility.js +74 -0
- package/build/esm/filter-list/hooks/useFilterVisibility.js.map +1 -0
- package/build/esm/filter-list/hooks/usePropertyAggregation.js +98 -0
- package/build/esm/filter-list/hooks/usePropertyAggregation.js.map +1 -0
- package/build/esm/filter-list/inputs/ContainsTextFilterInput.js +38 -0
- package/build/esm/filter-list/inputs/ContainsTextFilterInput.js.map +1 -0
- package/build/esm/filter-list/inputs/DateRangeFilterInput.js +109 -0
- package/build/esm/filter-list/inputs/DateRangeFilterInput.js.map +1 -0
- package/build/esm/filter-list/inputs/LinkedPropertyInput.js +496 -0
- package/build/esm/filter-list/inputs/LinkedPropertyInput.js.map +1 -0
- package/build/esm/filter-list/inputs/ListogramFilterInput.js +83 -0
- package/build/esm/filter-list/inputs/ListogramFilterInput.js.map +1 -0
- package/build/esm/filter-list/inputs/MultiDateFilterInput.js +38 -0
- package/build/esm/filter-list/inputs/MultiDateFilterInput.js.map +1 -0
- package/build/esm/filter-list/inputs/MultiSelectFilterInput.js +71 -0
- package/build/esm/filter-list/inputs/MultiSelectFilterInput.js.map +1 -0
- package/build/esm/filter-list/inputs/NumberRangeFilterInput.js +109 -0
- package/build/esm/filter-list/inputs/NumberRangeFilterInput.js.map +1 -0
- package/build/esm/filter-list/inputs/PropertyFilterInput.js +142 -0
- package/build/esm/filter-list/inputs/PropertyFilterInput.js.map +1 -0
- package/build/esm/filter-list/inputs/SingleDateFilterInput.js +38 -0
- package/build/esm/filter-list/inputs/SingleDateFilterInput.js.map +1 -0
- package/build/esm/filter-list/inputs/SingleSelectFilterInput.js +71 -0
- package/build/esm/filter-list/inputs/SingleSelectFilterInput.js.map +1 -0
- package/build/esm/filter-list/inputs/TextTagsFilterInput.js +70 -0
- package/build/esm/filter-list/inputs/TextTagsFilterInput.js.map +1 -0
- package/build/esm/filter-list/inputs/TimelineFilterInput.js +49 -0
- package/build/esm/filter-list/inputs/TimelineFilterInput.js.map +1 -0
- package/build/esm/filter-list/inputs/ToggleFilterInput.js +36 -0
- package/build/esm/filter-list/inputs/ToggleFilterInput.js.map +1 -0
- package/build/esm/filter-list/types/AggregationTypes.js +2 -0
- package/build/esm/filter-list/types/AggregationTypes.js.map +1 -0
- package/build/esm/filter-list/types/CustomRendererTypes.js.map +1 -1
- package/build/esm/filter-list/types/LinkedFilterTypes.js.map +1 -1
- package/build/esm/filter-list/types/index.js +0 -2
- package/build/esm/filter-list/types/index.js.map +1 -1
- package/build/esm/filter-list/utils/aggregationHelpers.js +44 -0
- package/build/esm/filter-list/utils/aggregationHelpers.js.map +1 -0
- package/build/esm/filter-list/utils/filterStateSerialization.js +42 -0
- package/build/esm/filter-list/utils/filterStateSerialization.js.map +1 -0
- package/build/esm/filter-list/utils/filterStateToWhereClause.js +124 -91
- package/build/esm/filter-list/utils/filterStateToWhereClause.js.map +1 -1
- package/build/esm/filter-list/utils/filterValues.js +55 -1
- package/build/esm/filter-list/utils/filterValues.js.map +1 -1
- package/build/esm/filter-list/utils/getFilterKey.js +1 -1
- package/build/esm/filter-list/utils/getFilterKey.js.map +1 -1
- package/build/esm/filter-list/utils/getFilterLabel.js +36 -0
- package/build/esm/filter-list/utils/getFilterLabel.js.map +1 -0
- package/build/esm/object-table/ColumnConfigDialog.module.css +1 -11
- package/build/esm/object-table/DefaultCellRenderer.js +23 -5
- package/build/esm/object-table/DefaultCellRenderer.js.map +1 -1
- package/build/esm/object-table/EditableCell.js +87 -10
- package/build/esm/object-table/EditableCell.js.map +1 -1
- package/build/esm/object-table/EditableCell.module.css +69 -2
- package/build/esm/object-table/LoadingCell.js +7 -3
- package/build/esm/object-table/LoadingCell.js.map +1 -1
- package/build/esm/object-table/LoadingCell.module.css +3 -21
- package/build/esm/object-table/LoadingRow.js +2 -1
- package/build/esm/object-table/LoadingRow.js.map +1 -1
- package/build/esm/object-table/LoadingStateTable.js +2 -1
- package/build/esm/object-table/LoadingStateTable.js.map +1 -1
- package/build/esm/object-table/MultiColumnSortDialog.js +22 -58
- package/build/esm/object-table/MultiColumnSortDialog.js.map +1 -1
- package/build/esm/object-table/MultiColumnSortDialog.module.css +0 -69
- package/build/esm/object-table/ObjectTable.js +16 -23
- package/build/esm/object-table/ObjectTable.js.map +1 -1
- package/build/esm/object-table/ObjectTableApi.js.map +1 -1
- package/build/esm/object-table/SelectionCells.js +1 -0
- package/build/esm/object-table/SelectionCells.js.map +1 -1
- package/build/esm/object-table/Table.js +23 -15
- package/build/esm/object-table/Table.js.map +1 -1
- package/build/esm/object-table/Table.module.css +0 -8
- package/build/esm/object-table/TableBody.js +8 -2
- package/build/esm/object-table/TableBody.js.map +1 -1
- package/build/esm/object-table/TableCell.module.css +2 -9
- package/build/esm/object-table/TableEditContainer.js +90 -0
- package/build/esm/object-table/TableEditContainer.js.map +1 -0
- package/build/esm/object-table/TableEditContainer.module.css +71 -0
- package/build/esm/object-table/TableHeader.js +4 -1
- package/build/esm/object-table/TableHeader.js.map +1 -1
- package/build/esm/object-table/TableHeader.module.css +4 -3
- package/build/esm/object-table/TableHeaderWithPopover.js +2 -4
- package/build/esm/object-table/TableHeaderWithPopover.js.map +1 -1
- package/build/esm/object-table/TableHeaderWithPopover.module.css +1 -12
- package/build/esm/object-table/TableRow.js +10 -3
- package/build/esm/object-table/TableRow.js.map +1 -1
- package/build/esm/object-table/TableRow.module.css +2 -1
- package/build/esm/object-table/components/AsyncValueCell.js +35 -0
- package/build/esm/object-table/components/AsyncValueCell.js.map +1 -0
- package/build/esm/object-table/hooks/useColumnDefs.js +5 -2
- package/build/esm/object-table/hooks/useColumnDefs.js.map +1 -1
- package/build/esm/object-table/hooks/useEditableTable.js +39 -11
- package/build/esm/object-table/hooks/useEditableTable.js.map +1 -1
- package/build/esm/object-table/hooks/useFunctionColumnsData.js +135 -0
- package/build/esm/object-table/hooks/useFunctionColumnsData.js.map +1 -0
- package/build/esm/object-table/hooks/useObjectTableData.js +33 -17
- package/build/esm/object-table/hooks/useObjectTableData.js.map +1 -1
- package/build/esm/object-table/hooks/useRowSelection.js +11 -8
- package/build/esm/object-table/hooks/useRowSelection.js.map +1 -1
- package/build/esm/object-table/utils/AsyncCellData.js +30 -0
- package/build/esm/object-table/utils/AsyncCellData.js.map +1 -0
- package/build/esm/object-table/utils/constants.js +1 -0
- package/build/esm/object-table/utils/constants.js.map +1 -1
- package/build/esm/object-table/utils/getCellId.js +0 -7
- package/build/esm/object-table/utils/getCellId.js.map +1 -1
- package/build/esm/object-table/utils/types.js.map +1 -1
- package/build/esm/pdf-viewer/PdfRenderer.js +88 -0
- package/build/esm/pdf-viewer/PdfRenderer.js.map +1 -0
- package/build/esm/pdf-viewer/PdfViewer.js +179 -0
- package/build/esm/pdf-viewer/PdfViewer.js.map +1 -0
- package/build/esm/pdf-viewer/PdfViewer.module.css +95 -0
- package/build/esm/pdf-viewer/PdfViewerContext.js +108 -0
- package/build/esm/pdf-viewer/PdfViewerContext.js.map +1 -0
- package/build/esm/pdf-viewer/components/PdfViewerAnnotationLayer.js +141 -0
- package/build/esm/pdf-viewer/components/PdfViewerAnnotationLayer.js.map +1 -0
- package/build/esm/pdf-viewer/components/PdfViewerAnnotationLayer.module.css +82 -0
- package/build/esm/pdf-viewer/components/PdfViewerContent.js +125 -0
- package/build/esm/pdf-viewer/components/PdfViewerContent.js.map +1 -0
- package/build/esm/pdf-viewer/components/PdfViewerOutlineSidebar.js +98 -0
- package/build/esm/pdf-viewer/components/PdfViewerOutlineSidebar.js.map +1 -0
- package/build/esm/pdf-viewer/components/PdfViewerOutlineSidebar.module.css +89 -0
- package/build/esm/pdf-viewer/components/PdfViewerSearchBar.js +84 -0
- package/build/esm/pdf-viewer/components/PdfViewerSearchBar.js.map +1 -0
- package/build/esm/pdf-viewer/components/PdfViewerSearchBar.module.css +65 -0
- package/build/esm/pdf-viewer/components/PdfViewerSidebar.js +78 -0
- package/build/esm/pdf-viewer/components/PdfViewerSidebar.js.map +1 -0
- package/build/esm/pdf-viewer/components/PdfViewerSidebar.module.css +37 -0
- package/build/esm/pdf-viewer/components/PdfViewerSidebarHeader.js +54 -0
- package/build/esm/pdf-viewer/components/PdfViewerSidebarHeader.js.map +1 -0
- package/build/esm/pdf-viewer/components/PdfViewerSidebarHeader.module.css +70 -0
- package/build/esm/pdf-viewer/components/PdfViewerThumbnail.js +100 -0
- package/build/esm/pdf-viewer/components/PdfViewerThumbnail.js.map +1 -0
- package/build/esm/pdf-viewer/components/PdfViewerThumbnail.module.css +26 -0
- package/build/esm/pdf-viewer/components/PdfViewerToolbar.js +221 -0
- package/build/esm/pdf-viewer/components/PdfViewerToolbar.js.map +1 -0
- package/build/esm/pdf-viewer/components/PdfViewerToolbar.module.css +91 -0
- package/build/esm/pdf-viewer/constants.js +46 -0
- package/build/esm/pdf-viewer/constants.js.map +1 -0
- package/build/esm/pdf-viewer/hooks/usePdfAnnotationPortals.js +54 -0
- package/build/esm/pdf-viewer/hooks/usePdfAnnotationPortals.js.map +1 -0
- package/build/esm/pdf-viewer/hooks/usePdfAnnotationsByPage.js +30 -0
- package/build/esm/pdf-viewer/hooks/usePdfAnnotationsByPage.js.map +1 -0
- package/build/esm/pdf-viewer/hooks/usePdfDocument.js +66 -0
- package/build/esm/pdf-viewer/hooks/usePdfDocument.js.map +1 -0
- package/build/esm/pdf-viewer/hooks/usePdfFormFields.js +341 -0
- package/build/esm/pdf-viewer/hooks/usePdfFormFields.js.map +1 -0
- package/build/esm/pdf-viewer/hooks/usePdfHighlightMode.js +227 -0
- package/build/esm/pdf-viewer/hooks/usePdfHighlightMode.js.map +1 -0
- package/build/esm/pdf-viewer/hooks/usePdfOutline.js +268 -0
- package/build/esm/pdf-viewer/hooks/usePdfOutline.js.map +1 -0
- package/build/esm/pdf-viewer/hooks/usePdfViewer.js +86 -0
- package/build/esm/pdf-viewer/hooks/usePdfViewer.js.map +1 -0
- package/build/esm/pdf-viewer/hooks/usePdfViewerCore.js +80 -0
- package/build/esm/pdf-viewer/hooks/usePdfViewerCore.js.map +1 -0
- package/build/esm/pdf-viewer/hooks/usePdfViewerSearch.js +106 -0
- package/build/esm/pdf-viewer/hooks/usePdfViewerSearch.js.map +1 -0
- package/build/esm/pdf-viewer/hooks/usePdfViewerState.js +135 -0
- package/build/esm/pdf-viewer/hooks/usePdfViewerState.js.map +1 -0
- package/build/esm/pdf-viewer/hooks/usePdfViewerSync.js +71 -0
- package/build/esm/pdf-viewer/hooks/usePdfViewerSync.js.map +1 -0
- package/build/esm/pdf-viewer/types.js +2 -0
- package/build/esm/pdf-viewer/types.js.map +1 -0
- package/build/esm/public/experimental.js +34 -0
- package/build/esm/public/experimental.js.map +1 -1
- package/build/esm/public/primitives.js +20 -0
- package/build/esm/public/primitives.js.map +1 -0
- package/build/esm/shared/ErrorBoundary.module.css +14 -14
- package/build/esm/{filter-list/utils → shared}/assertUnreachable.js +1 -1
- package/build/esm/{filter-list/utils → shared}/assertUnreachable.js.map +1 -1
- package/build/{browser/filter-list/base/inputs → esm/shared}/dateUtils.js +38 -2
- package/build/esm/shared/dateUtils.js.map +1 -0
- package/build/esm/shared/typedMemo.js +25 -0
- package/build/esm/shared/typedMemo.js.map +1 -0
- package/build/types/action-form/ActionForm.d.ts +4 -0
- package/build/types/action-form/ActionForm.d.ts.map +1 -0
- package/build/types/action-form/ActionFormApi.d.ts +49 -32
- package/build/types/action-form/ActionFormApi.d.ts.map +1 -1
- package/build/types/action-form/BaseForm.d.ts +3 -0
- package/build/types/action-form/BaseForm.d.ts.map +1 -0
- package/build/types/action-form/FormField.d.ts +11 -0
- package/build/types/action-form/FormField.d.ts.map +1 -0
- package/build/types/action-form/FormFieldApi.d.ts +152 -51
- package/build/types/action-form/FormFieldApi.d.ts.map +1 -1
- package/build/types/action-form/FormHeader.d.ts +6 -0
- package/build/types/action-form/FormHeader.d.ts.map +1 -0
- package/build/types/action-form/fields/CustomField.d.ts +9 -0
- package/build/types/action-form/fields/CustomField.d.ts.map +1 -0
- package/build/types/action-form/fields/DateCalendar.d.ts +9 -0
- package/build/types/action-form/fields/DateCalendar.d.ts.map +1 -0
- package/build/types/action-form/fields/DatetimePickerField.d.ts +3 -0
- package/build/types/action-form/fields/DatetimePickerField.d.ts.map +1 -0
- package/build/types/action-form/fields/DropdownField.d.ts +6 -0
- package/build/types/action-form/fields/DropdownField.d.ts.map +1 -0
- package/build/types/action-form/fields/FieldBridge.d.ts +9 -0
- package/build/types/action-form/fields/FieldBridge.d.ts.map +1 -0
- package/build/types/action-form/fields/FilePickerField.d.ts +3 -0
- package/build/types/action-form/fields/FilePickerField.d.ts.map +1 -0
- package/build/types/action-form/fields/FormFieldRenderer.d.ts +8 -0
- package/build/types/action-form/fields/FormFieldRenderer.d.ts.map +1 -0
- package/build/types/action-form/fields/LazyDateCalendar.d.ts +3 -0
- package/build/types/action-form/fields/LazyDateCalendar.d.ts.map +1 -0
- package/build/types/action-form/fields/NumberInputField.d.ts +3 -0
- package/build/types/action-form/fields/NumberInputField.d.ts.map +1 -0
- package/build/types/action-form/fields/RadioButtonsField.d.ts +3 -0
- package/build/types/action-form/fields/RadioButtonsField.d.ts.map +1 -0
- package/build/types/action-form/fields/TextAreaField.d.ts +3 -0
- package/build/types/action-form/fields/TextAreaField.d.ts.map +1 -0
- package/build/types/action-form/fields/TextInputField.d.ts +5 -0
- package/build/types/action-form/fields/TextInputField.d.ts.map +1 -0
- package/build/types/action-form/utils/coerceFieldValue.d.ts +10 -0
- package/build/types/action-form/utils/coerceFieldValue.d.ts.map +1 -0
- package/build/types/action-form/utils/getDefaultFieldDefinitions.d.ts +9 -0
- package/build/types/action-form/utils/getDefaultFieldDefinitions.d.ts.map +1 -0
- package/build/types/base-components/checkbox/Checkbox.d.ts +2 -1
- package/build/types/base-components/checkbox/Checkbox.d.ts.map +1 -1
- package/build/types/base-components/combobox/Combobox.d.ts +65 -0
- package/build/types/base-components/combobox/Combobox.d.ts.map +1 -0
- package/build/types/base-components/dialog/Dialog.d.ts +3 -2
- package/build/types/base-components/dialog/Dialog.d.ts.map +1 -1
- package/build/types/base-components/searchable-menu/SearchableMenu.d.ts +18 -0
- package/build/types/base-components/searchable-menu/SearchableMenu.d.ts.map +1 -0
- package/build/types/base-components/select/Select.d.ts +40 -0
- package/build/types/base-components/select/Select.d.ts.map +1 -0
- package/build/types/base-components/skeleton/SkeletonBar.d.ts +9 -0
- package/build/types/base-components/skeleton/SkeletonBar.d.ts.map +1 -0
- package/build/types/base-components/tooltip/Tooltip.d.ts +31 -0
- package/build/types/base-components/tooltip/Tooltip.d.ts.map +1 -0
- package/build/types/base-components/tooltip/index.d.ts +1 -0
- package/build/types/base-components/tooltip/index.d.ts.map +1 -0
- package/build/types/filter-list/FilterInput.d.ts +17 -0
- package/build/types/filter-list/FilterInput.d.ts.map +1 -0
- package/build/types/filter-list/{base/FilterList.d.ts → FilterList.d.ts} +1 -1
- package/build/types/filter-list/FilterList.d.ts.map +1 -0
- package/build/types/filter-list/FilterListApi.d.ts +49 -33
- package/build/types/filter-list/FilterListApi.d.ts.map +1 -1
- package/build/types/filter-list/FilterListItemApi.d.ts +22 -6
- package/build/types/filter-list/FilterListItemApi.d.ts.map +1 -1
- package/build/types/filter-list/base/AddFilterPopover.d.ts +13 -0
- package/build/types/filter-list/base/AddFilterPopover.d.ts.map +1 -0
- package/build/types/filter-list/base/BaseFilterList.d.ts +3 -0
- package/build/types/filter-list/base/BaseFilterList.d.ts.map +1 -0
- package/build/types/filter-list/base/BaseFilterListApi.d.ts +32 -0
- package/build/types/filter-list/base/BaseFilterListApi.d.ts.map +1 -0
- package/build/types/filter-list/base/DragHandleIcon.d.ts +2 -0
- package/build/types/filter-list/base/DragHandleIcon.d.ts.map +1 -0
- package/build/types/filter-list/base/ExcludeDropdown.d.ts +8 -0
- package/build/types/filter-list/base/ExcludeDropdown.d.ts.map +1 -0
- package/build/types/filter-list/base/FilterIcons.d.ts +10 -0
- package/build/types/filter-list/base/FilterIcons.d.ts.map +1 -0
- package/build/types/filter-list/base/FilterInputExcludeRow.d.ts +13 -0
- package/build/types/filter-list/base/FilterInputExcludeRow.d.ts.map +1 -0
- package/build/types/filter-list/base/FilterListContent.d.ts +9 -6
- package/build/types/filter-list/base/FilterListContent.d.ts.map +1 -1
- package/build/types/filter-list/base/FilterListHeader.d.ts +3 -2
- package/build/types/filter-list/base/FilterListHeader.d.ts.map +1 -1
- package/build/types/filter-list/base/FilterListItem.d.ts +10 -6
- package/build/types/filter-list/base/FilterListItem.d.ts.map +1 -1
- package/build/types/filter-list/base/SortableFilterListItem.d.ts +16 -0
- package/build/types/filter-list/base/SortableFilterListItem.d.ts.map +1 -0
- package/build/types/filter-list/base/index.d.ts +2 -2
- package/build/types/filter-list/base/index.d.ts.map +1 -1
- package/build/types/filter-list/base/inputs/ContainsTextInput.d.ts.map +1 -1
- package/build/types/filter-list/base/inputs/DateRangeInput.d.ts +17 -0
- package/build/types/filter-list/base/inputs/DateRangeInput.d.ts.map +1 -0
- package/build/types/filter-list/base/inputs/ListogramInput.d.ts +21 -0
- package/build/types/filter-list/base/inputs/ListogramInput.d.ts.map +1 -0
- package/build/types/filter-list/base/inputs/ListogramSkeleton.d.ts +2 -0
- package/build/types/filter-list/base/inputs/ListogramSkeleton.d.ts.map +1 -0
- package/build/types/filter-list/base/inputs/MultiSelectInput.d.ts +16 -0
- package/build/types/filter-list/base/inputs/MultiSelectInput.d.ts.map +1 -0
- package/build/types/filter-list/base/inputs/NullValueWrapper.d.ts +15 -0
- package/build/types/filter-list/base/inputs/NullValueWrapper.d.ts.map +1 -0
- package/build/types/filter-list/base/inputs/NumberRangeInput.d.ts +17 -0
- package/build/types/filter-list/base/inputs/NumberRangeInput.d.ts.map +1 -0
- package/build/types/filter-list/base/inputs/RangeInput.d.ts +30 -0
- package/build/types/filter-list/base/inputs/RangeInput.d.ts.map +1 -0
- package/build/types/filter-list/base/inputs/SingleDateInput.d.ts.map +1 -1
- package/build/types/filter-list/base/inputs/SingleSelectInput.d.ts +18 -0
- package/build/types/filter-list/base/inputs/SingleSelectInput.d.ts.map +1 -0
- package/build/types/filter-list/base/inputs/TextTagsInput.d.ts +18 -0
- package/build/types/filter-list/base/inputs/TextTagsInput.d.ts.map +1 -0
- package/build/types/filter-list/base/inputs/TimelineInput.d.ts +11 -0
- package/build/types/filter-list/base/inputs/TimelineInput.d.ts.map +1 -0
- package/build/types/filter-list/base/inputs/createHistogramBuckets.d.ts +16 -0
- package/build/types/filter-list/base/inputs/createHistogramBuckets.d.ts.map +1 -0
- package/build/types/filter-list/base/inputs/index.d.ts +5 -1
- package/build/types/filter-list/base/inputs/index.d.ts.map +1 -1
- package/build/types/filter-list/base/inputs/useStableData.d.ts +1 -0
- package/build/types/filter-list/base/inputs/useStableData.d.ts.map +1 -0
- package/build/types/filter-list/hooks/useFilterListState.d.ts +2 -0
- package/build/types/filter-list/hooks/useFilterListState.d.ts.map +1 -1
- package/build/types/filter-list/hooks/useFilterVisibility.d.ts +10 -0
- package/build/types/filter-list/hooks/useFilterVisibility.d.ts.map +1 -0
- package/build/types/filter-list/hooks/usePropertyAggregation.d.ts +18 -0
- package/build/types/filter-list/hooks/usePropertyAggregation.d.ts.map +1 -0
- package/build/types/filter-list/inputs/ContainsTextFilterInput.d.ts +10 -0
- package/build/types/filter-list/inputs/ContainsTextFilterInput.d.ts.map +1 -0
- package/build/types/filter-list/inputs/DateRangeFilterInput.d.ts +13 -0
- package/build/types/filter-list/inputs/DateRangeFilterInput.d.ts.map +1 -0
- package/build/types/filter-list/inputs/LinkedPropertyInput.d.ts +22 -0
- package/build/types/filter-list/inputs/LinkedPropertyInput.d.ts.map +1 -0
- package/build/types/filter-list/inputs/ListogramFilterInput.d.ts +19 -0
- package/build/types/filter-list/inputs/ListogramFilterInput.d.ts.map +1 -0
- package/build/types/filter-list/inputs/MultiDateFilterInput.d.ts +9 -0
- package/build/types/filter-list/inputs/MultiDateFilterInput.d.ts.map +1 -0
- package/build/types/filter-list/inputs/MultiSelectFilterInput.d.ts +15 -0
- package/build/types/filter-list/inputs/MultiSelectFilterInput.d.ts.map +1 -0
- package/build/types/filter-list/inputs/NumberRangeFilterInput.d.ts +13 -0
- package/build/types/filter-list/inputs/NumberRangeFilterInput.d.ts.map +1 -0
- package/build/types/filter-list/inputs/PropertyFilterInput.d.ts +19 -0
- package/build/types/filter-list/inputs/PropertyFilterInput.d.ts.map +1 -0
- package/build/types/filter-list/inputs/SingleDateFilterInput.d.ts +9 -0
- package/build/types/filter-list/inputs/SingleDateFilterInput.d.ts.map +1 -0
- package/build/types/filter-list/inputs/SingleSelectFilterInput.d.ts +15 -0
- package/build/types/filter-list/inputs/SingleSelectFilterInput.d.ts.map +1 -0
- package/build/types/filter-list/inputs/TextTagsFilterInput.d.ts +15 -0
- package/build/types/filter-list/inputs/TextTagsFilterInput.d.ts.map +1 -0
- package/build/types/filter-list/inputs/TimelineFilterInput.d.ts +9 -0
- package/build/types/filter-list/inputs/TimelineFilterInput.d.ts.map +1 -0
- package/build/types/filter-list/inputs/ToggleFilterInput.d.ts +9 -0
- package/build/types/filter-list/inputs/ToggleFilterInput.d.ts.map +1 -0
- package/build/types/filter-list/types/AggregationTypes.d.ts +5 -0
- package/build/types/filter-list/types/AggregationTypes.d.ts.map +1 -0
- package/build/types/filter-list/types/CustomRendererTypes.d.ts +2 -1
- package/build/types/filter-list/types/CustomRendererTypes.d.ts.map +1 -1
- package/build/types/filter-list/types/LinkedFilterTypes.d.ts +0 -19
- package/build/types/filter-list/types/LinkedFilterTypes.d.ts.map +1 -1
- package/build/types/filter-list/types/index.d.ts +0 -2
- package/build/types/filter-list/types/index.d.ts.map +1 -1
- package/build/types/filter-list/utils/aggregationHelpers.d.ts +9 -0
- package/build/types/filter-list/utils/aggregationHelpers.d.ts.map +1 -0
- package/build/types/filter-list/utils/filterStateSerialization.d.ts +3 -0
- package/build/types/filter-list/utils/filterStateSerialization.d.ts.map +1 -0
- package/build/types/filter-list/utils/filterStateToWhereClause.d.ts +5 -1
- package/build/types/filter-list/utils/filterStateToWhereClause.d.ts.map +1 -1
- package/build/types/filter-list/utils/filterValues.d.ts +4 -0
- package/build/types/filter-list/utils/filterValues.d.ts.map +1 -1
- package/build/types/filter-list/utils/getFilterKey.d.ts.map +1 -1
- package/build/types/filter-list/utils/getFilterLabel.d.ts +3 -0
- package/build/types/filter-list/utils/getFilterLabel.d.ts.map +1 -0
- package/build/types/object-table/DefaultCellRenderer.d.ts +2 -2
- package/build/types/object-table/DefaultCellRenderer.d.ts.map +1 -1
- package/build/types/object-table/EditableCell.d.ts +22 -6
- package/build/types/object-table/EditableCell.d.ts.map +1 -1
- package/build/types/object-table/LoadingCell.d.ts +1 -0
- package/build/types/object-table/LoadingCell.d.ts.map +1 -1
- package/build/types/object-table/LoadingRow.d.ts.map +1 -1
- package/build/types/object-table/LoadingStateTable.d.ts.map +1 -1
- package/build/types/object-table/MultiColumnSortDialog.d.ts.map +1 -1
- package/build/types/object-table/ObjectTable.d.ts +1 -9
- package/build/types/object-table/ObjectTable.d.ts.map +1 -1
- package/build/types/object-table/ObjectTableApi.d.ts +82 -22
- package/build/types/object-table/ObjectTableApi.d.ts.map +1 -1
- package/build/types/object-table/Table.d.ts +10 -10
- package/build/types/object-table/Table.d.ts.map +1 -1
- package/build/types/object-table/TableBody.d.ts +4 -1
- package/build/types/object-table/TableBody.d.ts.map +1 -1
- package/build/types/object-table/TableEditContainer.d.ts +9 -0
- package/build/types/object-table/TableEditContainer.d.ts.map +1 -0
- package/build/types/object-table/TableHeader.d.ts.map +1 -1
- package/build/types/object-table/TableRow.d.ts +4 -1
- package/build/types/object-table/TableRow.d.ts.map +1 -1
- package/build/types/object-table/components/AsyncValueCell.d.ts +5 -0
- package/build/types/object-table/components/AsyncValueCell.d.ts.map +1 -0
- package/build/types/object-table/hooks/useEditableTable.d.ts +4 -9
- package/build/types/object-table/hooks/useEditableTable.d.ts.map +1 -1
- package/build/types/object-table/hooks/useFunctionColumnsData.d.ts +13 -0
- package/build/types/object-table/hooks/useFunctionColumnsData.d.ts.map +1 -0
- package/build/types/object-table/hooks/useObjectTableData.d.ts +6 -1
- package/build/types/object-table/hooks/useObjectTableData.d.ts.map +1 -1
- package/build/types/object-table/hooks/useRowSelection.d.ts +3 -2
- package/build/types/object-table/hooks/useRowSelection.d.ts.map +1 -1
- package/build/types/object-table/utils/AsyncCellData.d.ts +8 -0
- package/build/types/object-table/utils/AsyncCellData.d.ts.map +1 -0
- package/build/types/object-table/utils/constants.d.ts +1 -0
- package/build/types/object-table/utils/constants.d.ts.map +1 -1
- package/build/types/object-table/utils/getCellId.d.ts +0 -1
- package/build/types/object-table/utils/getCellId.d.ts.map +1 -1
- package/build/types/object-table/utils/types.d.ts +28 -3
- package/build/types/object-table/utils/types.d.ts.map +1 -1
- package/build/types/pdf-viewer/PdfRenderer.d.ts +8 -0
- package/build/types/pdf-viewer/PdfRenderer.d.ts.map +1 -0
- package/build/types/pdf-viewer/PdfViewer.d.ts +4 -0
- package/build/types/pdf-viewer/PdfViewer.d.ts.map +1 -0
- package/build/types/pdf-viewer/PdfViewerContext.d.ts +64 -0
- package/build/types/pdf-viewer/PdfViewerContext.d.ts.map +1 -0
- package/build/types/pdf-viewer/components/PdfViewerAnnotationLayer.d.ts +9 -0
- package/build/types/pdf-viewer/components/PdfViewerAnnotationLayer.d.ts.map +1 -0
- package/build/types/pdf-viewer/components/PdfViewerContent.d.ts +26 -0
- package/build/types/pdf-viewer/components/PdfViewerContent.d.ts.map +1 -0
- package/build/types/pdf-viewer/components/PdfViewerOutlineSidebar.d.ts +11 -0
- package/build/types/pdf-viewer/components/PdfViewerOutlineSidebar.d.ts.map +1 -0
- package/build/types/pdf-viewer/components/PdfViewerSearchBar.d.ts +11 -0
- package/build/types/pdf-viewer/components/PdfViewerSearchBar.d.ts.map +1 -0
- package/build/types/pdf-viewer/components/PdfViewerSidebar.d.ts +12 -0
- package/build/types/pdf-viewer/components/PdfViewerSidebar.d.ts.map +1 -0
- package/build/types/pdf-viewer/components/PdfViewerSidebarHeader.d.ts +7 -0
- package/build/types/pdf-viewer/components/PdfViewerSidebarHeader.d.ts.map +1 -0
- package/build/types/pdf-viewer/components/PdfViewerThumbnail.d.ts +10 -0
- package/build/types/pdf-viewer/components/PdfViewerThumbnail.d.ts.map +1 -0
- package/build/types/pdf-viewer/components/PdfViewerToolbar.d.ts +21 -0
- package/build/types/pdf-viewer/components/PdfViewerToolbar.d.ts.map +1 -0
- package/build/types/pdf-viewer/constants.d.ts +22 -0
- package/build/types/pdf-viewer/constants.d.ts.map +1 -0
- package/build/types/pdf-viewer/hooks/usePdfAnnotationPortals.d.ts +10 -0
- package/build/types/pdf-viewer/hooks/usePdfAnnotationPortals.d.ts.map +1 -0
- package/build/types/pdf-viewer/hooks/usePdfAnnotationsByPage.d.ts +5 -0
- package/build/types/pdf-viewer/hooks/usePdfAnnotationsByPage.d.ts.map +1 -0
- package/build/types/pdf-viewer/hooks/usePdfDocument.d.ts +9 -0
- package/build/types/pdf-viewer/hooks/usePdfDocument.d.ts.map +1 -0
- package/build/types/pdf-viewer/hooks/usePdfFormFields.d.ts +24 -0
- package/build/types/pdf-viewer/hooks/usePdfFormFields.d.ts.map +1 -0
- package/build/types/pdf-viewer/hooks/usePdfHighlightMode.d.ts +36 -0
- package/build/types/pdf-viewer/hooks/usePdfHighlightMode.d.ts.map +1 -0
- package/build/types/pdf-viewer/hooks/usePdfOutline.d.ts +3 -0
- package/build/types/pdf-viewer/hooks/usePdfOutline.d.ts.map +1 -0
- package/build/types/pdf-viewer/hooks/usePdfViewer.d.ts +9 -0
- package/build/types/pdf-viewer/hooks/usePdfViewer.d.ts.map +1 -0
- package/build/types/pdf-viewer/hooks/usePdfViewerCore.d.ts +43 -0
- package/build/types/pdf-viewer/hooks/usePdfViewerCore.d.ts.map +1 -0
- package/build/types/pdf-viewer/hooks/usePdfViewerSearch.d.ts +15 -0
- package/build/types/pdf-viewer/hooks/usePdfViewerSearch.d.ts.map +1 -0
- package/build/types/pdf-viewer/hooks/usePdfViewerState.d.ts +39 -0
- package/build/types/pdf-viewer/hooks/usePdfViewerState.d.ts.map +1 -0
- package/build/types/pdf-viewer/hooks/usePdfViewerSync.d.ts +15 -0
- package/build/types/pdf-viewer/hooks/usePdfViewerSync.d.ts.map +1 -0
- package/build/types/pdf-viewer/types.d.ts +210 -0
- package/build/types/pdf-viewer/types.d.ts.map +1 -0
- package/build/types/public/experimental.d.ts +33 -2
- package/build/types/public/experimental.d.ts.map +1 -1
- package/build/types/public/primitives.d.ts +3 -0
- package/build/types/public/primitives.d.ts.map +1 -0
- package/build/types/shared/assertUnreachable.d.ts.map +1 -0
- package/build/types/shared/dateUtils.d.ts +31 -0
- package/build/types/shared/dateUtils.d.ts.map +1 -0
- package/build/types/shared/typedMemo.d.ts +6 -0
- package/build/types/shared/typedMemo.d.ts.map +1 -0
- package/package.json +23 -10
- package/primitives.d.ts +17 -0
- package/build/browser/filter-list/__tests__/dateUtils.test.js +0 -55
- package/build/browser/filter-list/__tests__/dateUtils.test.js.map +0 -1
- package/build/browser/filter-list/__tests__/filterStateToWhereClause.test.js +0 -296
- package/build/browser/filter-list/__tests__/filterStateToWhereClause.test.js.map +0 -1
- package/build/browser/filter-list/__tests__/getFilterKey.test.js +0 -53
- package/build/browser/filter-list/__tests__/getFilterKey.test.js.map +0 -1
- package/build/browser/filter-list/__tests__/testUtils.js +0 -203
- package/build/browser/filter-list/__tests__/testUtils.js.map +0 -1
- package/build/browser/filter-list/base/FilterInput.js +0 -225
- package/build/browser/filter-list/base/FilterInput.js.map +0 -1
- package/build/browser/filter-list/base/FilterList.js +0 -73
- package/build/browser/filter-list/base/FilterList.js.map +0 -1
- package/build/browser/filter-list/base/inputs/dateUtils.js.map +0 -1
- package/build/browser/filter-list/hooks/__tests__/useFilterListState.test.js +0 -128
- package/build/browser/filter-list/hooks/__tests__/useFilterListState.test.js.map +0 -1
- package/build/browser/filter-list/types/AddFilterMenuTypes.js +0 -2
- package/build/browser/filter-list/types/AddFilterMenuTypes.js.map +0 -1
- package/build/browser/filter-list/types/FilterPanelTypes.js +0 -2
- package/build/browser/filter-list/types/FilterPanelTypes.js.map +0 -1
- package/build/browser/object-table/__tests__/useEditableTable.test.js +0 -197
- package/build/browser/object-table/__tests__/useEditableTable.test.js.map +0 -1
- package/build/browser/object-table/hooks/__tests__/useCellContextMenu.test.js +0 -147
- package/build/browser/object-table/hooks/__tests__/useCellContextMenu.test.js.map +0 -1
- package/build/browser/object-table/hooks/__tests__/useColumnDefs.test.js +0 -520
- package/build/browser/object-table/hooks/__tests__/useColumnDefs.test.js.map +0 -1
- package/build/browser/object-table/hooks/__tests__/useColumnPinning.test.js +0 -266
- package/build/browser/object-table/hooks/__tests__/useColumnPinning.test.js.map +0 -1
- package/build/browser/object-table/hooks/__tests__/useColumnVisibility.test.js +0 -200
- package/build/browser/object-table/hooks/__tests__/useColumnVisibility.test.js.map +0 -1
- package/build/browser/object-table/hooks/__tests__/useObjectTableData.test.js +0 -315
- package/build/browser/object-table/hooks/__tests__/useObjectTableData.test.js.map +0 -1
- package/build/browser/object-table/hooks/__tests__/useRowSelection.test.js +0 -596
- package/build/browser/object-table/hooks/__tests__/useRowSelection.test.js.map +0 -1
- package/build/browser/object-table/hooks/__tests__/useSelectionColumn.test.js +0 -220
- package/build/browser/object-table/hooks/__tests__/useSelectionColumn.test.js.map +0 -1
- package/build/browser/object-table/hooks/__tests__/useTableSorting.test.js +0 -501
- package/build/browser/object-table/hooks/__tests__/useTableSorting.test.js.map +0 -1
- package/build/esm/filter-list/__tests__/dateUtils.test.js +0 -55
- package/build/esm/filter-list/__tests__/dateUtils.test.js.map +0 -1
- package/build/esm/filter-list/__tests__/filterStateToWhereClause.test.js +0 -296
- package/build/esm/filter-list/__tests__/filterStateToWhereClause.test.js.map +0 -1
- package/build/esm/filter-list/__tests__/getFilterKey.test.js +0 -53
- package/build/esm/filter-list/__tests__/getFilterKey.test.js.map +0 -1
- package/build/esm/filter-list/__tests__/testUtils.js +0 -203
- package/build/esm/filter-list/__tests__/testUtils.js.map +0 -1
- package/build/esm/filter-list/base/FilterInput.js +0 -225
- package/build/esm/filter-list/base/FilterInput.js.map +0 -1
- package/build/esm/filter-list/base/FilterList.js +0 -73
- package/build/esm/filter-list/base/FilterList.js.map +0 -1
- package/build/esm/filter-list/base/inputs/dateUtils.js.map +0 -1
- package/build/esm/filter-list/hooks/__tests__/useFilterListState.test.js +0 -128
- package/build/esm/filter-list/hooks/__tests__/useFilterListState.test.js.map +0 -1
- package/build/esm/filter-list/types/AddFilterMenuTypes.js +0 -2
- package/build/esm/filter-list/types/AddFilterMenuTypes.js.map +0 -1
- package/build/esm/filter-list/types/FilterPanelTypes.js +0 -2
- package/build/esm/filter-list/types/FilterPanelTypes.js.map +0 -1
- package/build/esm/object-table/__tests__/useEditableTable.test.js +0 -197
- package/build/esm/object-table/__tests__/useEditableTable.test.js.map +0 -1
- package/build/esm/object-table/hooks/__tests__/useCellContextMenu.test.js +0 -147
- package/build/esm/object-table/hooks/__tests__/useCellContextMenu.test.js.map +0 -1
- package/build/esm/object-table/hooks/__tests__/useColumnDefs.test.js +0 -520
- package/build/esm/object-table/hooks/__tests__/useColumnDefs.test.js.map +0 -1
- package/build/esm/object-table/hooks/__tests__/useColumnPinning.test.js +0 -266
- package/build/esm/object-table/hooks/__tests__/useColumnPinning.test.js.map +0 -1
- package/build/esm/object-table/hooks/__tests__/useColumnVisibility.test.js +0 -200
- package/build/esm/object-table/hooks/__tests__/useColumnVisibility.test.js.map +0 -1
- package/build/esm/object-table/hooks/__tests__/useObjectTableData.test.js +0 -315
- package/build/esm/object-table/hooks/__tests__/useObjectTableData.test.js.map +0 -1
- package/build/esm/object-table/hooks/__tests__/useRowSelection.test.js +0 -596
- package/build/esm/object-table/hooks/__tests__/useRowSelection.test.js.map +0 -1
- package/build/esm/object-table/hooks/__tests__/useSelectionColumn.test.js +0 -220
- package/build/esm/object-table/hooks/__tests__/useSelectionColumn.test.js.map +0 -1
- package/build/esm/object-table/hooks/__tests__/useTableSorting.test.js +0 -501
- package/build/esm/object-table/hooks/__tests__/useTableSorting.test.js.map +0 -1
- package/build/types/filter-list/__tests__/dateUtils.test.d.ts +0 -1
- package/build/types/filter-list/__tests__/dateUtils.test.d.ts.map +0 -1
- package/build/types/filter-list/__tests__/filterStateToWhereClause.test.d.ts +0 -1
- package/build/types/filter-list/__tests__/filterStateToWhereClause.test.d.ts.map +0 -1
- package/build/types/filter-list/__tests__/getFilterKey.test.d.ts +0 -1
- package/build/types/filter-list/__tests__/getFilterKey.test.d.ts.map +0 -1
- package/build/types/filter-list/__tests__/testUtils.d.ts +0 -65
- package/build/types/filter-list/__tests__/testUtils.d.ts.map +0 -1
- package/build/types/filter-list/base/FilterInput.d.ts +0 -13
- package/build/types/filter-list/base/FilterInput.d.ts.map +0 -1
- package/build/types/filter-list/base/FilterList.d.ts.map +0 -1
- package/build/types/filter-list/base/inputs/dateUtils.d.ts +0 -17
- package/build/types/filter-list/base/inputs/dateUtils.d.ts.map +0 -1
- package/build/types/filter-list/hooks/__tests__/useFilterListState.test.d.ts +0 -1
- package/build/types/filter-list/hooks/__tests__/useFilterListState.test.d.ts.map +0 -1
- package/build/types/filter-list/types/AddFilterMenuTypes.d.ts +0 -77
- package/build/types/filter-list/types/AddFilterMenuTypes.d.ts.map +0 -1
- package/build/types/filter-list/types/FilterPanelTypes.d.ts +0 -18
- package/build/types/filter-list/types/FilterPanelTypes.d.ts.map +0 -1
- package/build/types/filter-list/utils/assertUnreachable.d.ts.map +0 -1
- package/build/types/object-table/__tests__/useEditableTable.test.d.ts +0 -1
- package/build/types/object-table/__tests__/useEditableTable.test.d.ts.map +0 -1
- package/build/types/object-table/hooks/__tests__/useCellContextMenu.test.d.ts +0 -1
- package/build/types/object-table/hooks/__tests__/useCellContextMenu.test.d.ts.map +0 -1
- package/build/types/object-table/hooks/__tests__/useColumnDefs.test.d.ts +0 -1
- package/build/types/object-table/hooks/__tests__/useColumnDefs.test.d.ts.map +0 -1
- package/build/types/object-table/hooks/__tests__/useColumnPinning.test.d.ts +0 -1
- package/build/types/object-table/hooks/__tests__/useColumnPinning.test.d.ts.map +0 -1
- package/build/types/object-table/hooks/__tests__/useColumnVisibility.test.d.ts +0 -1
- package/build/types/object-table/hooks/__tests__/useColumnVisibility.test.d.ts.map +0 -1
- package/build/types/object-table/hooks/__tests__/useObjectTableData.test.d.ts +0 -1
- package/build/types/object-table/hooks/__tests__/useObjectTableData.test.d.ts.map +0 -1
- package/build/types/object-table/hooks/__tests__/useRowSelection.test.d.ts +0 -1
- package/build/types/object-table/hooks/__tests__/useRowSelection.test.d.ts.map +0 -1
- package/build/types/object-table/hooks/__tests__/useSelectionColumn.test.d.ts +0 -1
- package/build/types/object-table/hooks/__tests__/useSelectionColumn.test.d.ts.map +0 -1
- package/build/types/object-table/hooks/__tests__/useTableSorting.test.d.ts +0 -1
- package/build/types/object-table/hooks/__tests__/useTableSorting.test.d.ts.map +0 -1
- /package/build/types/{filter-list/utils → shared}/assertUnreachable.d.ts +0 -0
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@osdk/react-components",
|
|
3
|
-
"version": "0.2.
|
|
3
|
+
"version": "0.2.1-main-20260407074313",
|
|
4
4
|
"license": "Apache-2.0",
|
|
5
5
|
"repository": {
|
|
6
6
|
"type": "git",
|
|
@@ -25,6 +25,15 @@
|
|
|
25
25
|
"require": "./build/cjs/public/experimental.cjs",
|
|
26
26
|
"default": "./build/browser/public/experimental.js"
|
|
27
27
|
},
|
|
28
|
+
"./primitives": {
|
|
29
|
+
"browser": "./build/browser/public/primitives.js",
|
|
30
|
+
"import": {
|
|
31
|
+
"types": "./build/types/public/primitives.d.ts",
|
|
32
|
+
"default": "./build/esm/public/primitives.js"
|
|
33
|
+
},
|
|
34
|
+
"require": "./build/cjs/public/primitives.cjs",
|
|
35
|
+
"default": "./build/browser/public/primitives.js"
|
|
36
|
+
},
|
|
28
37
|
"./styles.css": "./build/browser/styles.css",
|
|
29
38
|
"./*": {
|
|
30
39
|
"browser": "./build/browser/public/*.js",
|
|
@@ -44,12 +53,15 @@
|
|
|
44
53
|
"@dnd-kit/utilities": "^3.2.2",
|
|
45
54
|
"@tanstack/react-table": "^8.21.3",
|
|
46
55
|
"@tanstack/react-virtual": "^3.13.13",
|
|
47
|
-
"lodash-es": "^4.17.21"
|
|
56
|
+
"lodash-es": "^4.17.21",
|
|
57
|
+
"pdfjs-dist": "^4.9.155",
|
|
58
|
+
"react-day-picker": "9.1.0",
|
|
59
|
+
"react-hook-form": "^7.54.0"
|
|
48
60
|
},
|
|
49
61
|
"peerDependencies": {
|
|
50
|
-
"@osdk/api": "
|
|
51
|
-
"@osdk/client": "
|
|
52
|
-
"@osdk/react": "
|
|
62
|
+
"@osdk/api": "^2.8.0 || >=2.8.1-beta.0",
|
|
63
|
+
"@osdk/client": "^2.8.0 || >=2.8.1-beta.0",
|
|
64
|
+
"@osdk/react": "^0.10.0 || >=0.10.1-beta.0",
|
|
53
65
|
"@types/react": "^17 || ^18 || ^19",
|
|
54
66
|
"classnames": "^2.0.0",
|
|
55
67
|
"react": "^17 || ^18 || ^19",
|
|
@@ -66,16 +78,17 @@
|
|
|
66
78
|
"react": "^18.3.1",
|
|
67
79
|
"react-dom": "^18.3.1",
|
|
68
80
|
"typescript": "~5.5.4",
|
|
69
|
-
"@osdk/api": "2.8.
|
|
70
|
-
"@osdk/client": "2.8.
|
|
71
|
-
"@osdk/monorepo.
|
|
72
|
-
"@osdk/monorepo.
|
|
73
|
-
"@osdk/react": "0.10.
|
|
81
|
+
"@osdk/api": "2.8.1-main-20260407074313",
|
|
82
|
+
"@osdk/client": "2.8.1-main-20260407074313",
|
|
83
|
+
"@osdk/monorepo.api-extractor": "~0.7.0",
|
|
84
|
+
"@osdk/monorepo.tsconfig": "~0.7.0",
|
|
85
|
+
"@osdk/react": "0.10.1-main-20260407074313"
|
|
74
86
|
},
|
|
75
87
|
"publishConfig": {
|
|
76
88
|
"access": "public"
|
|
77
89
|
},
|
|
78
90
|
"files": [
|
|
91
|
+
"AGENTS.md",
|
|
79
92
|
"build/cjs",
|
|
80
93
|
"build/esm",
|
|
81
94
|
"build/browser",
|
package/primitives.d.ts
ADDED
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Copyright 2024 Palantir Technologies, Inc. All rights reserved.
|
|
3
|
+
*
|
|
4
|
+
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
5
|
+
* you may not use this file except in compliance with the License.
|
|
6
|
+
* You may obtain a copy of the License at
|
|
7
|
+
*
|
|
8
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
9
|
+
*
|
|
10
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
11
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
12
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
+
* See the License for the specific language governing permissions and
|
|
14
|
+
* limitations under the License.
|
|
15
|
+
*/
|
|
16
|
+
|
|
17
|
+
export * from "./build/types/public/primitives.js";
|
|
@@ -1,55 +0,0 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* Copyright 2025 Palantir Technologies, Inc. All rights reserved.
|
|
3
|
-
*
|
|
4
|
-
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
5
|
-
* you may not use this file except in compliance with the License.
|
|
6
|
-
* You may obtain a copy of the License at
|
|
7
|
-
*
|
|
8
|
-
* http://www.apache.org/licenses/LICENSE-2.0
|
|
9
|
-
*
|
|
10
|
-
* Unless required by applicable law or agreed to in writing, software
|
|
11
|
-
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
12
|
-
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
-
* See the License for the specific language governing permissions and
|
|
14
|
-
* limitations under the License.
|
|
15
|
-
*/
|
|
16
|
-
|
|
17
|
-
import { describe, expect, it } from "vitest";
|
|
18
|
-
import { formatDateForDisplay, formatDateForInput, parseDateFromInput, parseDateFromISO } from "../base/inputs/dateUtils.js";
|
|
19
|
-
describe("formatDateForInput", () => {
|
|
20
|
-
it("formats a date to YYYY-MM-DD", () => {
|
|
21
|
-
expect(formatDateForInput(new Date(2024, 0, 3))).toBe("2024-01-03");
|
|
22
|
-
expect(formatDateForInput(undefined)).toBe("");
|
|
23
|
-
});
|
|
24
|
-
});
|
|
25
|
-
describe("parseDateFromInput", () => {
|
|
26
|
-
it("parses YYYY-MM-DD to local midnight", () => {
|
|
27
|
-
const date = parseDateFromInput("2024-06-15");
|
|
28
|
-
expect(date.getFullYear()).toBe(2024);
|
|
29
|
-
expect(date.getMonth()).toBe(5);
|
|
30
|
-
expect(date.getDate()).toBe(15);
|
|
31
|
-
expect(date.getHours()).toBe(0);
|
|
32
|
-
});
|
|
33
|
-
it("returns undefined for empty or invalid input", () => {
|
|
34
|
-
expect(parseDateFromInput("")).toBeUndefined();
|
|
35
|
-
expect(parseDateFromInput("not-a-date")).toBeUndefined();
|
|
36
|
-
});
|
|
37
|
-
});
|
|
38
|
-
describe("formatDateForDisplay", () => {
|
|
39
|
-
it("returns fallback for undefined, formats date otherwise", () => {
|
|
40
|
-
expect(formatDateForDisplay(undefined, "N/A")).toBe("N/A");
|
|
41
|
-
expect(formatDateForDisplay(undefined)).toBe("");
|
|
42
|
-
expect(formatDateForDisplay(new Date(2024, 5, 15))).toContain("2024");
|
|
43
|
-
});
|
|
44
|
-
});
|
|
45
|
-
describe("parseDateFromISO", () => {
|
|
46
|
-
it("parses ISO strings and passes through Date objects", () => {
|
|
47
|
-
const existing = new Date(2024, 5, 15);
|
|
48
|
-
expect(parseDateFromISO(existing)).toBe(existing);
|
|
49
|
-
expect(parseDateFromISO("2024-06-15T12:00:00Z")).toBeInstanceOf(Date);
|
|
50
|
-
expect(parseDateFromISO(undefined)).toBeUndefined();
|
|
51
|
-
expect(parseDateFromISO(null)).toBeUndefined();
|
|
52
|
-
expect(parseDateFromISO("not-a-date")).toBeUndefined();
|
|
53
|
-
});
|
|
54
|
-
});
|
|
55
|
-
//# sourceMappingURL=dateUtils.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"dateUtils.test.js","names":["describe","expect","it","formatDateForDisplay","formatDateForInput","parseDateFromInput","parseDateFromISO","Date","toBe","undefined","date","getFullYear","getMonth","getDate","getHours","toBeUndefined","toContain","existing","toBeInstanceOf"],"sources":["dateUtils.test.ts"],"sourcesContent":["/*\n * Copyright 2025 Palantir Technologies, Inc. All rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { describe, expect, it } from \"vitest\";\nimport {\n formatDateForDisplay,\n formatDateForInput,\n parseDateFromInput,\n parseDateFromISO,\n} from \"../base/inputs/dateUtils.js\";\n\ndescribe(\"formatDateForInput\", () => {\n it(\"formats a date to YYYY-MM-DD\", () => {\n expect(formatDateForInput(new Date(2024, 0, 3))).toBe(\"2024-01-03\");\n expect(formatDateForInput(undefined)).toBe(\"\");\n });\n});\n\ndescribe(\"parseDateFromInput\", () => {\n it(\"parses YYYY-MM-DD to local midnight\", () => {\n const date = parseDateFromInput(\"2024-06-15\")!;\n expect(date.getFullYear()).toBe(2024);\n expect(date.getMonth()).toBe(5);\n expect(date.getDate()).toBe(15);\n expect(date.getHours()).toBe(0);\n });\n\n it(\"returns undefined for empty or invalid input\", () => {\n expect(parseDateFromInput(\"\")).toBeUndefined();\n expect(parseDateFromInput(\"not-a-date\")).toBeUndefined();\n });\n});\n\ndescribe(\"formatDateForDisplay\", () => {\n it(\"returns fallback for undefined, formats date otherwise\", () => {\n expect(formatDateForDisplay(undefined, \"N/A\")).toBe(\"N/A\");\n expect(formatDateForDisplay(undefined)).toBe(\"\");\n expect(formatDateForDisplay(new Date(2024, 5, 15))).toContain(\"2024\");\n });\n});\n\ndescribe(\"parseDateFromISO\", () => {\n it(\"parses ISO strings and passes through Date objects\", () => {\n const existing = new Date(2024, 5, 15);\n expect(parseDateFromISO(existing)).toBe(existing);\n expect(parseDateFromISO(\"2024-06-15T12:00:00Z\")).toBeInstanceOf(Date);\n expect(parseDateFromISO(undefined)).toBeUndefined();\n expect(parseDateFromISO(null)).toBeUndefined();\n expect(parseDateFromISO(\"not-a-date\")).toBeUndefined();\n });\n});\n"],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,SAASA,QAAQ,EAAEC,MAAM,EAAEC,EAAE,QAAQ,QAAQ;AAC7C,SACEC,oBAAoB,EACpBC,kBAAkB,EAClBC,kBAAkB,EAClBC,gBAAgB,QACX,6BAA6B;AAEpCN,QAAQ,CAAC,oBAAoB,EAAE,MAAM;EACnCE,EAAE,CAAC,8BAA8B,EAAE,MAAM;IACvCD,MAAM,CAACG,kBAAkB,CAAC,IAAIG,IAAI,CAAC,IAAI,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAACC,IAAI,CAAC,YAAY,CAAC;IACnEP,MAAM,CAACG,kBAAkB,CAACK,SAAS,CAAC,CAAC,CAACD,IAAI,CAAC,EAAE,CAAC;EAChD,CAAC,CAAC;AACJ,CAAC,CAAC;AAEFR,QAAQ,CAAC,oBAAoB,EAAE,MAAM;EACnCE,EAAE,CAAC,qCAAqC,EAAE,MAAM;IAC9C,MAAMQ,IAAI,GAAGL,kBAAkB,CAAC,YAAY,CAAE;IAC9CJ,MAAM,CAACS,IAAI,CAACC,WAAW,CAAC,CAAC,CAAC,CAACH,IAAI,CAAC,IAAI,CAAC;IACrCP,MAAM,CAACS,IAAI,CAACE,QAAQ,CAAC,CAAC,CAAC,CAACJ,IAAI,CAAC,CAAC,CAAC;IAC/BP,MAAM,CAACS,IAAI,CAACG,OAAO,CAAC,CAAC,CAAC,CAACL,IAAI,CAAC,EAAE,CAAC;IAC/BP,MAAM,CAACS,IAAI,CAACI,QAAQ,CAAC,CAAC,CAAC,CAACN,IAAI,CAAC,CAAC,CAAC;EACjC,CAAC,CAAC;EAEFN,EAAE,CAAC,8CAA8C,EAAE,MAAM;IACvDD,MAAM,CAACI,kBAAkB,CAAC,EAAE,CAAC,CAAC,CAACU,aAAa,CAAC,CAAC;IAC9Cd,MAAM,CAACI,kBAAkB,CAAC,YAAY,CAAC,CAAC,CAACU,aAAa,CAAC,CAAC;EAC1D,CAAC,CAAC;AACJ,CAAC,CAAC;AAEFf,QAAQ,CAAC,sBAAsB,EAAE,MAAM;EACrCE,EAAE,CAAC,wDAAwD,EAAE,MAAM;IACjED,MAAM,CAACE,oBAAoB,CAACM,SAAS,EAAE,KAAK,CAAC,CAAC,CAACD,IAAI,CAAC,KAAK,CAAC;IAC1DP,MAAM,CAACE,oBAAoB,CAACM,SAAS,CAAC,CAAC,CAACD,IAAI,CAAC,EAAE,CAAC;IAChDP,MAAM,CAACE,oBAAoB,CAAC,IAAII,IAAI,CAAC,IAAI,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAACS,SAAS,CAAC,MAAM,CAAC;EACvE,CAAC,CAAC;AACJ,CAAC,CAAC;AAEFhB,QAAQ,CAAC,kBAAkB,EAAE,MAAM;EACjCE,EAAE,CAAC,oDAAoD,EAAE,MAAM;IAC7D,MAAMe,QAAQ,GAAG,IAAIV,IAAI,CAAC,IAAI,EAAE,CAAC,EAAE,EAAE,CAAC;IACtCN,MAAM,CAACK,gBAAgB,CAACW,QAAQ,CAAC,CAAC,CAACT,IAAI,CAACS,QAAQ,CAAC;IACjDhB,MAAM,CAACK,gBAAgB,CAAC,sBAAsB,CAAC,CAAC,CAACY,cAAc,CAACX,IAAI,CAAC;IACrEN,MAAM,CAACK,gBAAgB,CAACG,SAAS,CAAC,CAAC,CAACM,aAAa,CAAC,CAAC;IACnDd,MAAM,CAACK,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAACS,aAAa,CAAC,CAAC;IAC9Cd,MAAM,CAACK,gBAAgB,CAAC,YAAY,CAAC,CAAC,CAACS,aAAa,CAAC,CAAC;EACxD,CAAC,CAAC;AACJ,CAAC,CAAC","ignoreList":[]}
|
|
@@ -1,296 +0,0 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* Copyright 2025 Palantir Technologies, Inc. All rights reserved.
|
|
3
|
-
*
|
|
4
|
-
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
5
|
-
* you may not use this file except in compliance with the License.
|
|
6
|
-
* You may obtain a copy of the License at
|
|
7
|
-
*
|
|
8
|
-
* http://www.apache.org/licenses/LICENSE-2.0
|
|
9
|
-
*
|
|
10
|
-
* Unless required by applicable law or agreed to in writing, software
|
|
11
|
-
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
12
|
-
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
-
* See the License for the specific language governing permissions and
|
|
14
|
-
* limitations under the License.
|
|
15
|
-
*/
|
|
16
|
-
|
|
17
|
-
import { describe, expect, it } from "vitest";
|
|
18
|
-
import { buildWhereClause } from "../utils/filterStateToWhereClause.js";
|
|
19
|
-
import { getFilterKey } from "../utils/getFilterKey.js";
|
|
20
|
-
import { createContainsTextState, createCustomFilterDef, createDateRangeState, createHasLinkFilterDef, createKeywordSearchFilterDef, createNumberRangeState, createPropertyFilterDef, createSelectState, createToggleState } from "./testUtils.js";
|
|
21
|
-
function stateMap(...entries) {
|
|
22
|
-
return new Map(entries.map(([def, state]) => [getFilterKey(def), state]));
|
|
23
|
-
}
|
|
24
|
-
describe("buildWhereClause", () => {
|
|
25
|
-
it("returns empty object for undefined definitions", () => {
|
|
26
|
-
const result = buildWhereClause(undefined, new Map(), "and");
|
|
27
|
-
expect(result).toEqual({});
|
|
28
|
-
});
|
|
29
|
-
it("builds $in clause for CHECKBOX_LIST", () => {
|
|
30
|
-
const def = createPropertyFilterDef("name", "CHECKBOX_LIST", createSelectState(["a", "b"]));
|
|
31
|
-
const filterStates = stateMap([def, createSelectState(["a", "b"])]);
|
|
32
|
-
const result = buildWhereClause([def], filterStates, "and");
|
|
33
|
-
expect(result).toEqual({
|
|
34
|
-
name: {
|
|
35
|
-
$in: ["a", "b"]
|
|
36
|
-
}
|
|
37
|
-
});
|
|
38
|
-
});
|
|
39
|
-
it("wraps with $not when CHECKBOX_LIST isExcluding", () => {
|
|
40
|
-
const def = createPropertyFilterDef("name", "CHECKBOX_LIST", createSelectState(["a"], {
|
|
41
|
-
isExcluding: true
|
|
42
|
-
}));
|
|
43
|
-
const filterStates = stateMap([def, createSelectState(["a"], {
|
|
44
|
-
isExcluding: true
|
|
45
|
-
})]);
|
|
46
|
-
const result = buildWhereClause([def], filterStates, "and");
|
|
47
|
-
expect(result).toEqual({
|
|
48
|
-
name: {
|
|
49
|
-
$not: "a"
|
|
50
|
-
}
|
|
51
|
-
});
|
|
52
|
-
});
|
|
53
|
-
it("builds $containsAnyTerm for CONTAINS_TEXT", () => {
|
|
54
|
-
const def = createPropertyFilterDef("name", "CONTAINS_TEXT", createContainsTextState("test"));
|
|
55
|
-
const filterStates = stateMap([def, createContainsTextState("test")]);
|
|
56
|
-
const result = buildWhereClause([def], filterStates, "and");
|
|
57
|
-
expect(result).toEqual({
|
|
58
|
-
name: {
|
|
59
|
-
$containsAnyTerm: "test"
|
|
60
|
-
}
|
|
61
|
-
});
|
|
62
|
-
});
|
|
63
|
-
it("returns boolean for TOGGLE", () => {
|
|
64
|
-
const def = createPropertyFilterDef("active", "TOGGLE", createToggleState(true));
|
|
65
|
-
const filterStates = stateMap([def, createToggleState(true)]);
|
|
66
|
-
const result = buildWhereClause([def], filterStates, "and");
|
|
67
|
-
expect(result).toEqual({
|
|
68
|
-
active: true
|
|
69
|
-
});
|
|
70
|
-
});
|
|
71
|
-
it("builds $gte for NUMBER_RANGE min", () => {
|
|
72
|
-
const def = createPropertyFilterDef("age", "NUMBER_RANGE", createNumberRangeState(18, undefined));
|
|
73
|
-
const filterStates = stateMap([def, createNumberRangeState(18, undefined)]);
|
|
74
|
-
const result = buildWhereClause([def], filterStates, "and");
|
|
75
|
-
expect(result).toEqual({
|
|
76
|
-
age: {
|
|
77
|
-
$gte: 18
|
|
78
|
-
}
|
|
79
|
-
});
|
|
80
|
-
});
|
|
81
|
-
it("builds $and for NUMBER_RANGE min+max", () => {
|
|
82
|
-
const def = createPropertyFilterDef("age", "NUMBER_RANGE", createNumberRangeState(18, 65));
|
|
83
|
-
const filterStates = stateMap([def, createNumberRangeState(18, 65)]);
|
|
84
|
-
const result = buildWhereClause([def], filterStates, "and");
|
|
85
|
-
expect(result).toEqual({
|
|
86
|
-
age: {
|
|
87
|
-
$and: [{
|
|
88
|
-
$gte: 18
|
|
89
|
-
}, {
|
|
90
|
-
$lte: 65
|
|
91
|
-
}]
|
|
92
|
-
}
|
|
93
|
-
});
|
|
94
|
-
});
|
|
95
|
-
it("includes $isNull with $or when includeNull", () => {
|
|
96
|
-
const def = createPropertyFilterDef("age", "NUMBER_RANGE", createNumberRangeState(18, undefined, {
|
|
97
|
-
includeNull: true
|
|
98
|
-
}));
|
|
99
|
-
const filterStates = stateMap([def, createNumberRangeState(18, undefined, {
|
|
100
|
-
includeNull: true
|
|
101
|
-
})]);
|
|
102
|
-
const result = buildWhereClause([def], filterStates, "and");
|
|
103
|
-
expect(result).toEqual({
|
|
104
|
-
age: {
|
|
105
|
-
$or: [{
|
|
106
|
-
$gte: 18
|
|
107
|
-
}, {
|
|
108
|
-
$isNull: true
|
|
109
|
-
}]
|
|
110
|
-
}
|
|
111
|
-
});
|
|
112
|
-
});
|
|
113
|
-
it("builds date comparison for DATE_RANGE", () => {
|
|
114
|
-
const minDate = new Date("2024-01-01T00:00:00.000Z");
|
|
115
|
-
const maxDate = new Date("2024-12-31T23:59:59.999Z");
|
|
116
|
-
const def = createPropertyFilterDef("createdAt", "DATE_RANGE", createDateRangeState(minDate, maxDate));
|
|
117
|
-
const filterStates = stateMap([def, createDateRangeState(minDate, maxDate)]);
|
|
118
|
-
const result = buildWhereClause([def], filterStates, "and");
|
|
119
|
-
expect(result).toEqual({
|
|
120
|
-
createdAt: {
|
|
121
|
-
$and: [{
|
|
122
|
-
$gte: minDate.toISOString()
|
|
123
|
-
}, {
|
|
124
|
-
$lte: maxDate.toISOString()
|
|
125
|
-
}]
|
|
126
|
-
}
|
|
127
|
-
});
|
|
128
|
-
});
|
|
129
|
-
it("combines multiple filters with $and", () => {
|
|
130
|
-
const nameDef = createPropertyFilterDef("name", "CHECKBOX_LIST", createSelectState(["John"]));
|
|
131
|
-
const activeDef = createPropertyFilterDef("active", "TOGGLE", createToggleState(true));
|
|
132
|
-
const filterStates = stateMap([nameDef, createSelectState(["John"])], [activeDef, createToggleState(true)]);
|
|
133
|
-
const result = buildWhereClause([nameDef, activeDef], filterStates, "and");
|
|
134
|
-
expect(result).toEqual({
|
|
135
|
-
$and: [{
|
|
136
|
-
name: "John"
|
|
137
|
-
}, {
|
|
138
|
-
active: true
|
|
139
|
-
}]
|
|
140
|
-
});
|
|
141
|
-
});
|
|
142
|
-
it("combines multiple filters with $or", () => {
|
|
143
|
-
const nameDef = createPropertyFilterDef("name", "CHECKBOX_LIST", createSelectState(["John"]));
|
|
144
|
-
const activeDef = createPropertyFilterDef("active", "TOGGLE", createToggleState(true));
|
|
145
|
-
const filterStates = stateMap([nameDef, createSelectState(["John"])], [activeDef, createToggleState(true)]);
|
|
146
|
-
const result = buildWhereClause([nameDef, activeDef], filterStates, "or");
|
|
147
|
-
expect(result).toEqual({
|
|
148
|
-
$or: [{
|
|
149
|
-
name: "John"
|
|
150
|
-
}, {
|
|
151
|
-
active: true
|
|
152
|
-
}]
|
|
153
|
-
});
|
|
154
|
-
});
|
|
155
|
-
it("returns single clause without wrapper for one filter", () => {
|
|
156
|
-
const nameDef = createPropertyFilterDef("name", "CHECKBOX_LIST", createSelectState(["John"]));
|
|
157
|
-
const activeDef = createPropertyFilterDef("active", "TOGGLE", createToggleState(false));
|
|
158
|
-
const filterStates = stateMap([nameDef, createSelectState(["John"])]);
|
|
159
|
-
const result = buildWhereClause([nameDef, activeDef], filterStates, "and");
|
|
160
|
-
expect(result).toEqual({
|
|
161
|
-
name: "John"
|
|
162
|
-
});
|
|
163
|
-
});
|
|
164
|
-
it("builds $isNotNull for hasLink filter", () => {
|
|
165
|
-
const def = createHasLinkFilterDef("employees");
|
|
166
|
-
const filterStates = stateMap([def, {
|
|
167
|
-
type: "hasLink",
|
|
168
|
-
hasLink: true
|
|
169
|
-
}]);
|
|
170
|
-
const result = buildWhereClause([def], filterStates, "and");
|
|
171
|
-
expect(result).toEqual({
|
|
172
|
-
employees: {
|
|
173
|
-
$isNotNull: true
|
|
174
|
-
}
|
|
175
|
-
});
|
|
176
|
-
});
|
|
177
|
-
it("emits no clause for hasLink filter when hasLink is false", () => {
|
|
178
|
-
const def = createHasLinkFilterDef("employees");
|
|
179
|
-
const filterStates = stateMap([def, {
|
|
180
|
-
type: "hasLink",
|
|
181
|
-
hasLink: false
|
|
182
|
-
}]);
|
|
183
|
-
const result = buildWhereClause([def], filterStates, "and");
|
|
184
|
-
expect(result).toEqual({});
|
|
185
|
-
});
|
|
186
|
-
it("builds $containsAllTerms for keywordSearch filter with AND operator", () => {
|
|
187
|
-
const def = createKeywordSearchFilterDef(["name"]);
|
|
188
|
-
const filterStates = stateMap([def, {
|
|
189
|
-
type: "keywordSearch",
|
|
190
|
-
searchTerm: "test",
|
|
191
|
-
operator: "AND"
|
|
192
|
-
}]);
|
|
193
|
-
const result = buildWhereClause([def], filterStates, "and");
|
|
194
|
-
expect(result).toEqual({
|
|
195
|
-
name: {
|
|
196
|
-
$containsAllTerms: "test"
|
|
197
|
-
}
|
|
198
|
-
});
|
|
199
|
-
});
|
|
200
|
-
it("builds $containsAnyTerm for keywordSearch filter with OR operator", () => {
|
|
201
|
-
const def = createKeywordSearchFilterDef(["name"]);
|
|
202
|
-
const filterStates = stateMap([def, {
|
|
203
|
-
type: "keywordSearch",
|
|
204
|
-
searchTerm: "test",
|
|
205
|
-
operator: "OR"
|
|
206
|
-
}]);
|
|
207
|
-
const result = buildWhereClause([def], filterStates, "and");
|
|
208
|
-
expect(result).toEqual({
|
|
209
|
-
name: {
|
|
210
|
-
$containsAnyTerm: "test"
|
|
211
|
-
}
|
|
212
|
-
});
|
|
213
|
-
});
|
|
214
|
-
it("builds $or for multi-property keywordSearch filter", () => {
|
|
215
|
-
const def = createKeywordSearchFilterDef(["name", "email"]);
|
|
216
|
-
const filterStates = stateMap([def, {
|
|
217
|
-
type: "keywordSearch",
|
|
218
|
-
searchTerm: "test",
|
|
219
|
-
operator: "OR"
|
|
220
|
-
}]);
|
|
221
|
-
const result = buildWhereClause([def], filterStates, "and");
|
|
222
|
-
expect(result).toEqual({
|
|
223
|
-
$or: [{
|
|
224
|
-
name: {
|
|
225
|
-
$containsAnyTerm: "test"
|
|
226
|
-
}
|
|
227
|
-
}, {
|
|
228
|
-
email: {
|
|
229
|
-
$containsAnyTerm: "test"
|
|
230
|
-
}
|
|
231
|
-
}]
|
|
232
|
-
});
|
|
233
|
-
});
|
|
234
|
-
it("builds $not wrapper for keywordSearch filter with isExcluding", () => {
|
|
235
|
-
const def = createKeywordSearchFilterDef(["name"]);
|
|
236
|
-
const filterStates = stateMap([def, {
|
|
237
|
-
type: "keywordSearch",
|
|
238
|
-
searchTerm: "test",
|
|
239
|
-
operator: "AND",
|
|
240
|
-
isExcluding: true
|
|
241
|
-
}]);
|
|
242
|
-
const result = buildWhereClause([def], filterStates, "and");
|
|
243
|
-
expect(result).toEqual({
|
|
244
|
-
name: {
|
|
245
|
-
$not: {
|
|
246
|
-
$containsAllTerms: "test"
|
|
247
|
-
}
|
|
248
|
-
}
|
|
249
|
-
});
|
|
250
|
-
});
|
|
251
|
-
it("calls toWhereClause for custom filter", () => {
|
|
252
|
-
const baseDef = createCustomFilterDef("myFilter");
|
|
253
|
-
const def = {
|
|
254
|
-
...baseDef,
|
|
255
|
-
toWhereClause: () => ({
|
|
256
|
-
customProp: {
|
|
257
|
-
$eq: "test"
|
|
258
|
-
}
|
|
259
|
-
})
|
|
260
|
-
};
|
|
261
|
-
const filterStates = stateMap([def, {
|
|
262
|
-
type: "custom",
|
|
263
|
-
customState: {
|
|
264
|
-
value: "test"
|
|
265
|
-
}
|
|
266
|
-
}]);
|
|
267
|
-
const result = buildWhereClause([def], filterStates, "and");
|
|
268
|
-
expect(result).toEqual({
|
|
269
|
-
customProp: {
|
|
270
|
-
$eq: "test"
|
|
271
|
-
}
|
|
272
|
-
});
|
|
273
|
-
});
|
|
274
|
-
it("preserves state when filters are reordered", () => {
|
|
275
|
-
const nameDef = createPropertyFilterDef("name", "CHECKBOX_LIST", createSelectState(["John"]));
|
|
276
|
-
const activeDef = createPropertyFilterDef("active", "TOGGLE", createToggleState(true));
|
|
277
|
-
const filterStates = stateMap([nameDef, createSelectState(["John"])], [activeDef, createToggleState(true)]);
|
|
278
|
-
const result1 = buildWhereClause([nameDef, activeDef], filterStates, "and");
|
|
279
|
-
const result2 = buildWhereClause([activeDef, nameDef], filterStates, "and");
|
|
280
|
-
expect(result1).toEqual({
|
|
281
|
-
$and: [{
|
|
282
|
-
name: "John"
|
|
283
|
-
}, {
|
|
284
|
-
active: true
|
|
285
|
-
}]
|
|
286
|
-
});
|
|
287
|
-
expect(result2).toEqual({
|
|
288
|
-
$and: [{
|
|
289
|
-
active: true
|
|
290
|
-
}, {
|
|
291
|
-
name: "John"
|
|
292
|
-
}]
|
|
293
|
-
});
|
|
294
|
-
});
|
|
295
|
-
});
|
|
296
|
-
//# sourceMappingURL=filterStateToWhereClause.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"filterStateToWhereClause.test.js","names":["describe","expect","it","buildWhereClause","getFilterKey","createContainsTextState","createCustomFilterDef","createDateRangeState","createHasLinkFilterDef","createKeywordSearchFilterDef","createNumberRangeState","createPropertyFilterDef","createSelectState","createToggleState","stateMap","entries","Map","map","def","state","result","undefined","toEqual","filterStates","name","$in","isExcluding","$not","$containsAnyTerm","active","age","$gte","$and","$lte","includeNull","$or","$isNull","minDate","Date","maxDate","createdAt","toISOString","nameDef","activeDef","type","hasLink","employees","$isNotNull","searchTerm","operator","$containsAllTerms","email","baseDef","toWhereClause","customProp","$eq","customState","value","result1","result2"],"sources":["filterStateToWhereClause.test.ts"],"sourcesContent":["/*\n * Copyright 2025 Palantir Technologies, Inc. All rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { describe, expect, it } from \"vitest\";\nimport type { FilterDefinitionUnion } from \"../FilterListApi.js\";\nimport type { FilterState } from \"../FilterListItemApi.js\";\nimport { buildWhereClause } from \"../utils/filterStateToWhereClause.js\";\nimport { getFilterKey } from \"../utils/getFilterKey.js\";\nimport type { MockObjectType } from \"./testUtils.js\";\nimport {\n createContainsTextState,\n createCustomFilterDef,\n createDateRangeState,\n createHasLinkFilterDef,\n createKeywordSearchFilterDef,\n createNumberRangeState,\n createPropertyFilterDef,\n createSelectState,\n createToggleState,\n} from \"./testUtils.js\";\n\ntype TestFilterDef = FilterDefinitionUnion<typeof MockObjectType>;\n\nfunction stateMap(\n ...entries: [TestFilterDef, FilterState][]\n): Map<string, FilterState> {\n return new Map(entries.map(([def, state]) => [getFilterKey(def), state]));\n}\n\ndescribe(\"buildWhereClause\", () => {\n it(\"returns empty object for undefined definitions\", () => {\n const result = buildWhereClause(\n undefined,\n new Map<string, FilterState>(),\n \"and\",\n );\n expect(result).toEqual({});\n });\n\n it(\"builds $in clause for CHECKBOX_LIST\", () => {\n const def = createPropertyFilterDef(\n \"name\",\n \"CHECKBOX_LIST\",\n createSelectState([\"a\", \"b\"]),\n );\n const filterStates = stateMap(\n [def, createSelectState([\"a\", \"b\"])],\n );\n const result = buildWhereClause([def], filterStates, \"and\");\n expect(result).toEqual({ name: { $in: [\"a\", \"b\"] } });\n });\n\n it(\"wraps with $not when CHECKBOX_LIST isExcluding\", () => {\n const def = createPropertyFilterDef(\n \"name\",\n \"CHECKBOX_LIST\",\n createSelectState([\"a\"], { isExcluding: true }),\n );\n const filterStates = stateMap(\n [def, createSelectState([\"a\"], { isExcluding: true })],\n );\n const result = buildWhereClause([def], filterStates, \"and\");\n expect(result).toEqual({ name: { $not: \"a\" } });\n });\n\n it(\"builds $containsAnyTerm for CONTAINS_TEXT\", () => {\n const def = createPropertyFilterDef(\n \"name\",\n \"CONTAINS_TEXT\",\n createContainsTextState(\"test\"),\n );\n const filterStates = stateMap(\n [def, createContainsTextState(\"test\")],\n );\n const result = buildWhereClause([def], filterStates, \"and\");\n expect(result).toEqual({ name: { $containsAnyTerm: \"test\" } });\n });\n\n it(\"returns boolean for TOGGLE\", () => {\n const def = createPropertyFilterDef(\n \"active\",\n \"TOGGLE\",\n createToggleState(true),\n );\n const filterStates = stateMap(\n [def, createToggleState(true)],\n );\n const result = buildWhereClause([def], filterStates, \"and\");\n expect(result).toEqual({ active: true });\n });\n\n it(\"builds $gte for NUMBER_RANGE min\", () => {\n const def = createPropertyFilterDef(\n \"age\",\n \"NUMBER_RANGE\",\n createNumberRangeState(18, undefined),\n );\n const filterStates = stateMap(\n [def, createNumberRangeState(18, undefined)],\n );\n const result = buildWhereClause([def], filterStates, \"and\");\n expect(result).toEqual({ age: { $gte: 18 } });\n });\n\n it(\"builds $and for NUMBER_RANGE min+max\", () => {\n const def = createPropertyFilterDef(\n \"age\",\n \"NUMBER_RANGE\",\n createNumberRangeState(18, 65),\n );\n const filterStates = stateMap(\n [def, createNumberRangeState(18, 65)],\n );\n const result = buildWhereClause([def], filterStates, \"and\");\n expect(result).toEqual({ age: { $and: [{ $gte: 18 }, { $lte: 65 }] } });\n });\n\n it(\"includes $isNull with $or when includeNull\", () => {\n const def = createPropertyFilterDef(\n \"age\",\n \"NUMBER_RANGE\",\n createNumberRangeState(18, undefined, { includeNull: true }),\n );\n const filterStates = stateMap(\n [def, createNumberRangeState(18, undefined, { includeNull: true })],\n );\n const result = buildWhereClause([def], filterStates, \"and\");\n expect(result).toEqual({ age: { $or: [{ $gte: 18 }, { $isNull: true }] } });\n });\n\n it(\"builds date comparison for DATE_RANGE\", () => {\n const minDate = new Date(\"2024-01-01T00:00:00.000Z\");\n const maxDate = new Date(\"2024-12-31T23:59:59.999Z\");\n const def = createPropertyFilterDef(\n \"createdAt\",\n \"DATE_RANGE\",\n createDateRangeState(minDate, maxDate),\n );\n const filterStates = stateMap(\n [def, createDateRangeState(minDate, maxDate)],\n );\n const result = buildWhereClause([def], filterStates, \"and\");\n expect(result).toEqual({\n createdAt: {\n $and: [\n { $gte: minDate.toISOString() },\n { $lte: maxDate.toISOString() },\n ],\n },\n });\n });\n\n it(\"combines multiple filters with $and\", () => {\n const nameDef = createPropertyFilterDef(\n \"name\",\n \"CHECKBOX_LIST\",\n createSelectState([\"John\"]),\n );\n const activeDef = createPropertyFilterDef(\n \"active\",\n \"TOGGLE\",\n createToggleState(true),\n );\n const filterStates = stateMap(\n [nameDef, createSelectState([\"John\"])],\n [activeDef, createToggleState(true)],\n );\n const result = buildWhereClause([nameDef, activeDef], filterStates, \"and\");\n expect(result).toEqual({\n $and: [{ name: \"John\" }, { active: true }],\n });\n });\n\n it(\"combines multiple filters with $or\", () => {\n const nameDef = createPropertyFilterDef(\n \"name\",\n \"CHECKBOX_LIST\",\n createSelectState([\"John\"]),\n );\n const activeDef = createPropertyFilterDef(\n \"active\",\n \"TOGGLE\",\n createToggleState(true),\n );\n const filterStates = stateMap(\n [nameDef, createSelectState([\"John\"])],\n [activeDef, createToggleState(true)],\n );\n const result = buildWhereClause([nameDef, activeDef], filterStates, \"or\");\n expect(result).toEqual({\n $or: [{ name: \"John\" }, { active: true }],\n });\n });\n\n it(\"returns single clause without wrapper for one filter\", () => {\n const nameDef = createPropertyFilterDef(\n \"name\",\n \"CHECKBOX_LIST\",\n createSelectState([\"John\"]),\n );\n const activeDef = createPropertyFilterDef(\n \"active\",\n \"TOGGLE\",\n createToggleState(false),\n );\n const filterStates = stateMap(\n [nameDef, createSelectState([\"John\"])],\n );\n const result = buildWhereClause([nameDef, activeDef], filterStates, \"and\");\n expect(result).toEqual({ name: \"John\" });\n });\n\n it(\"builds $isNotNull for hasLink filter\", () => {\n const def = createHasLinkFilterDef(\"employees\");\n const filterStates = stateMap(\n [def, { type: \"hasLink\", hasLink: true }],\n );\n const result = buildWhereClause([def], filterStates, \"and\");\n expect(result).toEqual({ employees: { $isNotNull: true } });\n });\n\n it(\"emits no clause for hasLink filter when hasLink is false\", () => {\n const def = createHasLinkFilterDef(\"employees\");\n const filterStates = stateMap(\n [def, { type: \"hasLink\", hasLink: false }],\n );\n const result = buildWhereClause([def], filterStates, \"and\");\n expect(result).toEqual({});\n });\n\n it(\"builds $containsAllTerms for keywordSearch filter with AND operator\", () => {\n const def = createKeywordSearchFilterDef([\"name\"]);\n const filterStates = stateMap(\n [def, { type: \"keywordSearch\", searchTerm: \"test\", operator: \"AND\" }],\n );\n const result = buildWhereClause([def], filterStates, \"and\");\n expect(result).toEqual({ name: { $containsAllTerms: \"test\" } });\n });\n\n it(\"builds $containsAnyTerm for keywordSearch filter with OR operator\", () => {\n const def = createKeywordSearchFilterDef([\"name\"]);\n const filterStates = stateMap(\n [def, { type: \"keywordSearch\", searchTerm: \"test\", operator: \"OR\" }],\n );\n const result = buildWhereClause([def], filterStates, \"and\");\n expect(result).toEqual({ name: { $containsAnyTerm: \"test\" } });\n });\n\n it(\"builds $or for multi-property keywordSearch filter\", () => {\n const def = createKeywordSearchFilterDef([\"name\", \"email\"]);\n const filterStates = stateMap(\n [def, { type: \"keywordSearch\", searchTerm: \"test\", operator: \"OR\" }],\n );\n const result = buildWhereClause([def], filterStates, \"and\");\n expect(result).toEqual({\n $or: [\n { name: { $containsAnyTerm: \"test\" } },\n { email: { $containsAnyTerm: \"test\" } },\n ],\n });\n });\n\n it(\"builds $not wrapper for keywordSearch filter with isExcluding\", () => {\n const def = createKeywordSearchFilterDef([\"name\"]);\n const filterStates = stateMap(\n [\n def,\n {\n type: \"keywordSearch\",\n searchTerm: \"test\",\n operator: \"AND\",\n isExcluding: true,\n },\n ],\n );\n const result = buildWhereClause([def], filterStates, \"and\");\n expect(result).toEqual({ name: { $not: { $containsAllTerms: \"test\" } } });\n });\n\n it(\"calls toWhereClause for custom filter\", () => {\n const baseDef = createCustomFilterDef(\"myFilter\");\n const def = {\n ...baseDef,\n toWhereClause: () => ({ customProp: { $eq: \"test\" } }),\n };\n const filterStates = stateMap(\n [def, { type: \"custom\", customState: { value: \"test\" } }],\n );\n const result = buildWhereClause([def], filterStates, \"and\");\n expect(result).toEqual({ customProp: { $eq: \"test\" } });\n });\n\n it(\"preserves state when filters are reordered\", () => {\n const nameDef = createPropertyFilterDef(\n \"name\",\n \"CHECKBOX_LIST\",\n createSelectState([\"John\"]),\n );\n const activeDef = createPropertyFilterDef(\n \"active\",\n \"TOGGLE\",\n createToggleState(true),\n );\n const filterStates = stateMap(\n [nameDef, createSelectState([\"John\"])],\n [activeDef, createToggleState(true)],\n );\n\n const result1 = buildWhereClause([nameDef, activeDef], filterStates, \"and\");\n const result2 = buildWhereClause([activeDef, nameDef], filterStates, \"and\");\n\n expect(result1).toEqual({\n $and: [{ name: \"John\" }, { active: true }],\n });\n expect(result2).toEqual({\n $and: [{ active: true }, { name: \"John\" }],\n });\n });\n});\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -1,53 +0,0 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* Copyright 2025 Palantir Technologies, Inc. All rights reserved.
|
|
3
|
-
*
|
|
4
|
-
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
5
|
-
* you may not use this file except in compliance with the License.
|
|
6
|
-
* You may obtain a copy of the License at
|
|
7
|
-
*
|
|
8
|
-
* http://www.apache.org/licenses/LICENSE-2.0
|
|
9
|
-
*
|
|
10
|
-
* Unless required by applicable law or agreed to in writing, software
|
|
11
|
-
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
12
|
-
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
-
* See the License for the specific language governing permissions and
|
|
14
|
-
* limitations under the License.
|
|
15
|
-
*/
|
|
16
|
-
|
|
17
|
-
import { describe, expect, it } from "vitest";
|
|
18
|
-
import { getFilterKey } from "../utils/getFilterKey.js";
|
|
19
|
-
import { createCustomFilterDef, createHasLinkFilterDef, createKeywordSearchFilterDef, createLinkedPropertyFilterDef, createPropertyFilterDef, createSelectState } from "./testUtils.js";
|
|
20
|
-
describe("getFilterKey", () => {
|
|
21
|
-
it("returns key for property filter", () => {
|
|
22
|
-
const definition = createPropertyFilterDef("name", "CHECKBOX_LIST", createSelectState([]));
|
|
23
|
-
expect(getFilterKey(definition)).toBe("name");
|
|
24
|
-
});
|
|
25
|
-
it("returns id over key for property filter when id is set", () => {
|
|
26
|
-
const definition = {
|
|
27
|
-
...createPropertyFilterDef("name", "CHECKBOX_LIST", createSelectState([])),
|
|
28
|
-
id: "name-filter-1"
|
|
29
|
-
};
|
|
30
|
-
expect(getFilterKey(definition)).toBe("name-filter-1");
|
|
31
|
-
});
|
|
32
|
-
it("returns hasLink:{linkName} for hasLink filter", () => {
|
|
33
|
-
const definition = createHasLinkFilterDef("employees");
|
|
34
|
-
expect(getFilterKey(definition)).toBe("hasLink:employees");
|
|
35
|
-
});
|
|
36
|
-
it("returns linkedProperty:{link}:{prop} for linkedProperty filter", () => {
|
|
37
|
-
const definition = createLinkedPropertyFilterDef("department", "name");
|
|
38
|
-
expect(getFilterKey(definition)).toBe("linkedProperty:department:name");
|
|
39
|
-
});
|
|
40
|
-
it("returns keywordSearch-{props} for array properties", () => {
|
|
41
|
-
const definition = createKeywordSearchFilterDef(["name", "email"]);
|
|
42
|
-
expect(getFilterKey(definition)).toBe("keywordSearch-name-email");
|
|
43
|
-
});
|
|
44
|
-
it("returns keywordSearch-all for 'all' properties", () => {
|
|
45
|
-
const definition = createKeywordSearchFilterDef("all");
|
|
46
|
-
expect(getFilterKey(definition)).toBe("keywordSearch-all");
|
|
47
|
-
});
|
|
48
|
-
it("returns key for custom filter", () => {
|
|
49
|
-
const definition = createCustomFilterDef("myCustomFilter");
|
|
50
|
-
expect(getFilterKey(definition)).toBe("myCustomFilter");
|
|
51
|
-
});
|
|
52
|
-
});
|
|
53
|
-
//# sourceMappingURL=getFilterKey.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"getFilterKey.test.js","names":["describe","expect","it","getFilterKey","createCustomFilterDef","createHasLinkFilterDef","createKeywordSearchFilterDef","createLinkedPropertyFilterDef","createPropertyFilterDef","createSelectState","definition","toBe","id"],"sources":["getFilterKey.test.ts"],"sourcesContent":["/*\n * Copyright 2025 Palantir Technologies, Inc. All rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { describe, expect, it } from \"vitest\";\nimport type { FilterDefinitionUnion } from \"../FilterListApi.js\";\nimport { getFilterKey } from \"../utils/getFilterKey.js\";\nimport type { MockObjectType } from \"./testUtils.js\";\nimport {\n createCustomFilterDef,\n createHasLinkFilterDef,\n createKeywordSearchFilterDef,\n createLinkedPropertyFilterDef,\n createPropertyFilterDef,\n createSelectState,\n} from \"./testUtils.js\";\n\ndescribe(\"getFilterKey\", () => {\n it(\"returns key for property filter\", () => {\n const definition = createPropertyFilterDef(\n \"name\",\n \"CHECKBOX_LIST\",\n createSelectState([]),\n );\n expect(getFilterKey(definition)).toBe(\"name\");\n });\n\n it(\"returns id over key for property filter when id is set\", () => {\n const definition = {\n ...createPropertyFilterDef(\n \"name\",\n \"CHECKBOX_LIST\",\n createSelectState([]),\n ),\n id: \"name-filter-1\",\n } as FilterDefinitionUnion<typeof MockObjectType>;\n expect(getFilterKey(definition)).toBe(\"name-filter-1\");\n });\n\n it(\"returns hasLink:{linkName} for hasLink filter\", () => {\n const definition = createHasLinkFilterDef(\"employees\");\n expect(getFilterKey(definition)).toBe(\"hasLink:employees\");\n });\n\n it(\"returns linkedProperty:{link}:{prop} for linkedProperty filter\", () => {\n const definition = createLinkedPropertyFilterDef(\"department\", \"name\");\n expect(getFilterKey(definition)).toBe(\"linkedProperty:department:name\");\n });\n\n it(\"returns keywordSearch-{props} for array properties\", () => {\n const definition = createKeywordSearchFilterDef([\"name\", \"email\"]);\n expect(getFilterKey(definition)).toBe(\"keywordSearch-name-email\");\n });\n\n it(\"returns keywordSearch-all for 'all' properties\", () => {\n const definition = createKeywordSearchFilterDef(\"all\");\n expect(getFilterKey(definition)).toBe(\"keywordSearch-all\");\n });\n\n it(\"returns key for custom filter\", () => {\n const definition = createCustomFilterDef(\"myCustomFilter\");\n expect(getFilterKey(definition)).toBe(\"myCustomFilter\");\n });\n});\n"],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,SAASA,QAAQ,EAAEC,MAAM,EAAEC,EAAE,QAAQ,QAAQ;AAE7C,SAASC,YAAY,QAAQ,0BAA0B;AAEvD,SACEC,qBAAqB,EACrBC,sBAAsB,EACtBC,4BAA4B,EAC5BC,6BAA6B,EAC7BC,uBAAuB,EACvBC,iBAAiB,QACZ,gBAAgB;AAEvBT,QAAQ,CAAC,cAAc,EAAE,MAAM;EAC7BE,EAAE,CAAC,iCAAiC,EAAE,MAAM;IAC1C,MAAMQ,UAAU,GAAGF,uBAAuB,CACxC,MAAM,EACN,eAAe,EACfC,iBAAiB,CAAC,EAAE,CACtB,CAAC;IACDR,MAAM,CAACE,YAAY,CAACO,UAAU,CAAC,CAAC,CAACC,IAAI,CAAC,MAAM,CAAC;EAC/C,CAAC,CAAC;EAEFT,EAAE,CAAC,wDAAwD,EAAE,MAAM;IACjE,MAAMQ,UAAU,GAAG;MACjB,GAAGF,uBAAuB,CACxB,MAAM,EACN,eAAe,EACfC,iBAAiB,CAAC,EAAE,CACtB,CAAC;MACDG,EAAE,EAAE;IACN,CAAiD;IACjDX,MAAM,CAACE,YAAY,CAACO,UAAU,CAAC,CAAC,CAACC,IAAI,CAAC,eAAe,CAAC;EACxD,CAAC,CAAC;EAEFT,EAAE,CAAC,+CAA+C,EAAE,MAAM;IACxD,MAAMQ,UAAU,GAAGL,sBAAsB,CAAC,WAAW,CAAC;IACtDJ,MAAM,CAACE,YAAY,CAACO,UAAU,CAAC,CAAC,CAACC,IAAI,CAAC,mBAAmB,CAAC;EAC5D,CAAC,CAAC;EAEFT,EAAE,CAAC,gEAAgE,EAAE,MAAM;IACzE,MAAMQ,UAAU,GAAGH,6BAA6B,CAAC,YAAY,EAAE,MAAM,CAAC;IACtEN,MAAM,CAACE,YAAY,CAACO,UAAU,CAAC,CAAC,CAACC,IAAI,CAAC,gCAAgC,CAAC;EACzE,CAAC,CAAC;EAEFT,EAAE,CAAC,oDAAoD,EAAE,MAAM;IAC7D,MAAMQ,UAAU,GAAGJ,4BAA4B,CAAC,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAClEL,MAAM,CAACE,YAAY,CAACO,UAAU,CAAC,CAAC,CAACC,IAAI,CAAC,0BAA0B,CAAC;EACnE,CAAC,CAAC;EAEFT,EAAE,CAAC,gDAAgD,EAAE,MAAM;IACzD,MAAMQ,UAAU,GAAGJ,4BAA4B,CAAC,KAAK,CAAC;IACtDL,MAAM,CAACE,YAAY,CAACO,UAAU,CAAC,CAAC,CAACC,IAAI,CAAC,mBAAmB,CAAC;EAC5D,CAAC,CAAC;EAEFT,EAAE,CAAC,+BAA+B,EAAE,MAAM;IACxC,MAAMQ,UAAU,GAAGN,qBAAqB,CAAC,gBAAgB,CAAC;IAC1DH,MAAM,CAACE,YAAY,CAACO,UAAU,CAAC,CAAC,CAACC,IAAI,CAAC,gBAAgB,CAAC;EACzD,CAAC,CAAC;AACJ,CAAC,CAAC","ignoreList":[]}
|