@axinom/mosaic-ui 0.69.0-rc.2 → 0.69.0-rc.21
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/dist/components/Buttons/Button/Button.d.ts +3 -3
- package/dist/components/Buttons/Button/Button.d.ts.map +1 -1
- package/dist/components/Buttons/Button.model.d.ts +2 -1
- package/dist/components/Buttons/Button.model.d.ts.map +1 -1
- package/dist/components/ConfirmDialog/ConfirmDialog.d.ts.map +1 -1
- package/dist/components/ConfirmDialog/ConfirmDialog.models.d.ts +0 -1
- package/dist/components/ConfirmDialog/ConfirmDialog.models.d.ts.map +1 -1
- package/dist/components/DateTime/TimePicker/ScrollColumn/ScrollColumn.d.ts +2 -2
- package/dist/components/DateTime/TimePicker/ScrollColumn/ScrollColumn.d.ts.map +1 -1
- package/dist/components/DynamicDataList/DynamicDataList.d.ts +1 -1
- package/dist/components/DynamicDataList/DynamicDataList.d.ts.map +1 -1
- package/dist/components/DynamicDataList/DynamicDataList.model.d.ts +0 -1
- package/dist/components/DynamicDataList/DynamicDataList.model.d.ts.map +1 -1
- package/dist/components/DynamicDataList/DynamicListDataEntry/DynamicListDataEntry.d.ts +2 -2
- package/dist/components/DynamicDataList/DynamicListDataEntry/DynamicListDataEntry.d.ts.map +1 -1
- package/dist/components/DynamicDataList/DynamicListDataEntry/Renderers/createInputRenderer/createInputRenderer.d.ts +1 -1
- package/dist/components/DynamicDataList/DynamicListDataEntry/Renderers/createInputRenderer/createInputRenderer.d.ts.map +1 -1
- package/dist/components/DynamicDataList/DynamicListDataEntry/Renderers/createSelectRenderer/createSelectRenderer.d.ts +1 -1
- package/dist/components/DynamicDataList/DynamicListDataEntry/Renderers/createSelectRenderer/createSelectRenderer.d.ts.map +1 -1
- package/dist/components/DynamicDataList/DynamicListDataEntry/Renderers/renderers.model.d.ts +2 -0
- package/dist/components/DynamicDataList/DynamicListDataEntry/Renderers/renderers.model.d.ts.map +1 -1
- package/dist/components/DynamicDataList/DynamicListHeader/DynamicListHeader.d.ts +2 -2
- package/dist/components/DynamicDataList/DynamicListHeader/DynamicListHeader.d.ts.map +1 -1
- package/dist/components/DynamicDataList/DynamicListRow/DynamicListRow.d.ts +2 -2
- package/dist/components/DynamicDataList/DynamicListRow/DynamicListRow.d.ts.map +1 -1
- package/dist/components/DynamicDataList/helpers/DynamicListReducer/DynamicListReducer.actions.d.ts +2 -2
- package/dist/components/DynamicDataList/helpers/DynamicListReducer/DynamicListReducer.actions.d.ts.map +1 -1
- package/dist/components/DynamicDataList/helpers/DynamicListReducer/DynamicListReducer.d.ts.map +1 -1
- package/dist/components/DynamicDataList/helpers/DynamicListReducer/DynamicListReducer.init.d.ts.map +1 -1
- package/dist/components/DynamicDataList/helpers/useColumnDefs.d.ts +1 -1
- package/dist/components/DynamicDataList/helpers/useColumnDefs.d.ts.map +1 -1
- package/dist/components/DynamicDataList/helpers/useDataHandler.d.ts +1 -1
- package/dist/components/DynamicDataList/helpers/useDataHandler.d.ts.map +1 -1
- package/dist/components/DynamicDataList/helpers/useRowAnimation.d.ts.map +1 -1
- package/dist/components/DynamicDataList/helpers/useRowEditing.d.ts.map +1 -1
- package/dist/components/EmptyStation/EmptyStation.d.ts.map +1 -1
- package/dist/components/Explorer/BulkEdit/FormFieldsConfigConverter.d.ts.map +1 -1
- package/dist/components/Explorer/BulkEdit/GenerateMutation.d.ts.map +1 -1
- package/dist/components/Explorer/BulkEdit/helpers/FieldWrapper.d.ts.map +1 -1
- package/dist/components/Explorer/BulkEdit/useBulkEdit.d.ts.map +1 -1
- package/dist/components/Explorer/Explorer.d.ts +1 -1
- package/dist/components/Explorer/Explorer.d.ts.map +1 -1
- package/dist/components/Explorer/Explorer.model.d.ts +0 -1
- package/dist/components/Explorer/Explorer.model.d.ts.map +1 -1
- package/dist/components/Explorer/NavigationExplorer/NavigationExplorer.d.ts +1 -1
- package/dist/components/Explorer/NavigationExplorer/NavigationExplorer.d.ts.map +1 -1
- package/dist/components/Explorer/QuickEdit/useQuickEdit.d.ts.map +1 -1
- package/dist/components/Explorer/SelectionExplorer/SelectionExplorer.d.ts +1 -1
- package/dist/components/Explorer/SelectionExplorer/SelectionExplorer.d.ts.map +1 -1
- package/dist/components/Explorer/helpers/useActions.d.ts +0 -1
- package/dist/components/Explorer/helpers/useActions.d.ts.map +1 -1
- package/dist/components/Explorer/helpers/useDataProvider.d.ts +0 -1
- package/dist/components/Explorer/helpers/useDataProvider.d.ts.map +1 -1
- package/dist/components/Explorer/helpers/useFilters.d.ts +0 -1
- package/dist/components/Explorer/helpers/useFilters.d.ts.map +1 -1
- package/dist/components/FieldSelection/FieldSelection.d.ts +1 -0
- package/dist/components/FieldSelection/FieldSelection.d.ts.map +1 -1
- package/dist/components/Filters/Filter/Filter.d.ts +2 -2
- package/dist/components/Filters/Filter/Filter.d.ts.map +1 -1
- package/dist/components/Filters/Filters.d.ts +2 -2
- package/dist/components/Filters/Filters.d.ts.map +1 -1
- package/dist/components/Filters/Filters.model.d.ts +0 -1
- package/dist/components/Filters/Filters.model.d.ts.map +1 -1
- package/dist/components/Filters/Validators/DateRangeFilterValidator.d.ts.map +1 -1
- package/dist/components/Filters/Validators/NumberRangeFilterValidator.d.ts.map +1 -1
- package/dist/components/FormElements/DynamicDataListControl/DynamicDataListControl.d.ts +0 -1
- package/dist/components/FormElements/DynamicDataListControl/DynamicDataListControl.d.ts.map +1 -1
- package/dist/components/FormElements/DynamicDataListControl/DynamicDataListField.d.ts +2 -2
- package/dist/components/FormElements/DynamicDataListControl/DynamicDataListField.d.ts.map +1 -1
- package/dist/components/FormElements/FormGroup/FormGroup.d.ts +12 -0
- package/dist/components/FormElements/FormGroup/FormGroup.d.ts.map +1 -0
- package/dist/components/FormElements/FormGroupTitle/FormGroupTitle.d.ts +5 -0
- package/dist/components/FormElements/FormGroupTitle/FormGroupTitle.d.ts.map +1 -1
- package/dist/components/FormElements/FormikDebug/FormikDebug.d.ts +0 -1
- package/dist/components/FormElements/FormikDebug/FormikDebug.d.ts.map +1 -1
- package/dist/components/FormElements/ReadOnly/ReadOnlyField.d.ts +2 -2
- package/dist/components/FormElements/ReadOnly/ReadOnlyField.d.ts.map +1 -1
- package/dist/components/FormElements/ReadOnlyText/ReadOnlyTextField.d.ts +2 -2
- package/dist/components/FormElements/ReadOnlyText/ReadOnlyTextField.d.ts.map +1 -1
- package/dist/components/FormElements/Tags/Tags.d.ts +2 -2
- package/dist/components/FormElements/Tags/Tags.d.ts.map +1 -1
- package/dist/components/FormElements/Tags/TagsField.d.ts +2 -2
- package/dist/components/FormElements/Tags/TagsField.d.ts.map +1 -1
- package/dist/components/FormElements/formStoryHelper.d.ts.map +1 -1
- package/dist/components/FormElements/index.d.ts +1 -0
- package/dist/components/FormElements/index.d.ts.map +1 -1
- package/dist/components/FormElements/useFormikError.d.ts.map +1 -1
- package/dist/components/FormStation/Create/Create.d.ts +2 -2
- package/dist/components/FormStation/Create/Create.d.ts.map +1 -1
- package/dist/components/FormStation/Details/Details.d.ts +2 -2
- package/dist/components/FormStation/Details/Details.d.ts.map +1 -1
- package/dist/components/FormStation/FormStation.d.ts +2 -2
- package/dist/components/FormStation/FormStation.d.ts.map +1 -1
- package/dist/components/FormStation/FormStationActions/FormStationActions.d.ts +1 -1
- package/dist/components/FormStation/FormStationActions/FormStationActions.d.ts.map +1 -1
- package/dist/components/FormStation/FormStationHeader/FormStationHeader.d.ts.map +1 -1
- package/dist/components/FormStation/SaveOnDemand/SaveOnDemand.d.ts +0 -1
- package/dist/components/FormStation/SaveOnDemand/SaveOnDemand.d.ts.map +1 -1
- package/dist/components/FormStation/SaveOnNavigate/handleNavigationAttempt.d.ts.map +1 -1
- package/dist/components/FormStation/helpers/useTitle.d.ts.map +1 -1
- package/dist/components/InfoPanel/hooks/useCollapse.d.ts +0 -1
- package/dist/components/InfoPanel/hooks/useCollapse.d.ts.map +1 -1
- package/dist/components/InlineMenu/InlineMenu.d.ts.map +1 -1
- package/dist/components/List/List.d.ts +2 -2
- package/dist/components/List/List.d.ts.map +1 -1
- package/dist/components/List/List.model.d.ts +0 -1
- package/dist/components/List/List.model.d.ts.map +1 -1
- package/dist/components/List/List.stories.helper.d.ts.map +1 -1
- package/dist/components/List/ListHeader/ColumnLabel/ColumnLabel.d.ts +2 -2
- package/dist/components/List/ListHeader/ColumnLabel/ColumnLabel.d.ts.map +1 -1
- package/dist/components/List/ListHeader/ListHeader.d.ts +2 -2
- package/dist/components/List/ListHeader/ListHeader.d.ts.map +1 -1
- package/dist/components/List/ListRow/ListRow.d.ts +2 -4
- package/dist/components/List/ListRow/ListRow.d.ts.map +1 -1
- package/dist/components/List/ListRow/ListRowCell/ListRowCell.d.ts +0 -1
- package/dist/components/List/ListRow/ListRowCell/ListRowCell.d.ts.map +1 -1
- package/dist/components/List/ListRow/ListRowCell/renderData.d.ts.map +1 -1
- package/dist/components/List/ListRow/ListRowLoader.d.ts +2 -2
- package/dist/components/List/ListRow/ListRowLoader.d.ts.map +1 -1
- package/dist/components/List/ListRow/Renderers/BooleanDotRenderer/BooleanDotRenderer.d.ts +0 -1
- package/dist/components/List/ListRow/Renderers/BooleanDotRenderer/BooleanDotRenderer.d.ts.map +1 -1
- package/dist/components/List/ListRow/Renderers/DateRenderer/DateRenderer.d.ts.map +1 -1
- package/dist/components/List/ListRow/Renderers/ExternalLinkRenderer/ExternalLinkRenderer.d.ts.map +1 -1
- package/dist/components/List/ListRow/Renderers/StateRenderer/StateRenderer.d.ts +1 -1
- package/dist/components/List/ListRow/Renderers/StateRenderer/StateRenderer.d.ts.map +1 -1
- package/dist/components/List/ListRow/Renderers/TagsRenderer/TagsRenderer.d.ts +0 -1
- package/dist/components/List/ListRow/Renderers/TagsRenderer/TagsRenderer.d.ts.map +1 -1
- package/dist/components/List/ListRow/Renderers/TimestampRenderer/TimestampRenderer.d.ts.map +1 -1
- package/dist/components/List/ListRowRenderer/ListRowRenderer.d.ts.map +1 -1
- package/dist/components/List/helpers.d.ts.map +1 -1
- package/dist/components/List/useColumnsSize.d.ts +0 -2
- package/dist/components/List/useColumnsSize.d.ts.map +1 -1
- package/dist/components/Loaders/skeletons.d.ts +0 -1
- package/dist/components/Loaders/skeletons.d.ts.map +1 -1
- package/dist/components/Modal/useModal.d.ts.map +1 -1
- package/dist/components/PageHeader/PageHeaderActionsGroup/PageHeaderActionsGroupsContext.d.ts +0 -1
- package/dist/components/PageHeader/PageHeaderActionsGroup/PageHeaderActionsGroupsContext.d.ts.map +1 -1
- package/dist/components/PageHeader/helpers/useElementWidthObserver.d.ts +1 -2
- package/dist/components/PageHeader/helpers/useElementWidthObserver.d.ts.map +1 -1
- package/dist/components/Tabs/TabList/ScrollContainer/useScroll.d.ts.map +1 -1
- package/dist/components/Utils/Postgraphile/FilterTransformer.d.ts.map +1 -1
- package/dist/components/Utils/Postgraphile/SortTransformer.d.ts.map +1 -1
- package/dist/components/Utils/State/GlobalState.d.ts.map +1 -1
- package/dist/helpers/idleCallbackHelpers.d.ts +0 -1
- package/dist/helpers/idleCallbackHelpers.d.ts.map +1 -1
- package/dist/helpers/storybook.d.ts.map +1 -1
- package/dist/helpers/testing.d.ts +6 -21
- package/dist/helpers/testing.d.ts.map +1 -1
- package/dist/helpers/utils.d.ts +1 -2
- package/dist/helpers/utils.d.ts.map +1 -1
- package/dist/hooks/useDEBUGDetectChanges/useDEBUGDetectChanges.d.ts.map +1 -1
- package/dist/hooks/useDEBUGRenderCount/useDEBUGRenderCount.d.ts.map +1 -1
- package/dist/hooks/useDebounce/useDebounce.d.ts +1 -2
- package/dist/hooks/useDebounce/useDebounce.d.ts.map +1 -1
- package/dist/hooks/useExpand/useExpand.d.ts.map +1 -1
- package/dist/hooks/useReactRouterPause/utils.d.ts.map +1 -1
- package/dist/hooks/useResize/useResize.d.ts +0 -1
- package/dist/hooks/useResize/useResize.d.ts.map +1 -1
- package/dist/hooks/useTabTitle/useTabTitle.d.ts.map +1 -1
- package/dist/hooks/useValueOrOnDemand/useValueOrOnDemand.d.ts +1 -1
- package/dist/hooks/useValueOrOnDemand/useValueOrOnDemand.d.ts.map +1 -1
- package/dist/index.es.js +4 -4
- package/dist/index.es.js.map +1 -1
- package/dist/index.js +4 -4
- package/dist/index.js.map +1 -1
- package/dist/utils/ErrorMapper/ErrorMapper.d.ts.map +1 -1
- package/dist/utils/ErrorTypeToStationError.d.ts.map +1 -1
- package/dist/utils/ToolTipHelpers.d.ts.map +1 -1
- package/dist/validators/timestamp/timestamp.d.ts.map +1 -1
- package/package.json +11 -10
- package/src/components/Accordion/Accordion.spec.tsx +1 -1
- package/src/components/Accordion/AccordionItem/AccordionItem.spec.tsx +2 -2
- package/src/components/Actions/Action/Action.spec.tsx +189 -228
- package/src/components/Actions/Actions.spec.tsx +42 -32
- package/src/components/Buttons/Button/Button.spec.tsx +110 -115
- package/src/components/Buttons/Button/Button.tsx +4 -0
- package/src/components/Buttons/Button.model.ts +2 -0
- package/src/components/Buttons/CompositeButton/CompositeButton.spec.tsx +122 -121
- package/src/components/Buttons/TextButton/TextButton.spec.tsx +85 -90
- package/src/components/ConfirmDialog/ConfirmDialog.spec.tsx +75 -79
- package/src/components/DateTime/DatePicker/DatePicker.spec.tsx +8 -7
- package/src/components/DateTime/DateTimePicker.spec.tsx +43 -62
- package/src/components/DateTime/TimePicker/ScrollColumn/ScrollColumn.spec.tsx +19 -16
- package/src/components/DateTime/TimePicker/TimePicker.spec.tsx +44 -73
- package/src/components/DynamicDataList/DynamicDataList.spec.tsx +112 -107
- package/src/components/DynamicDataList/DynamicListDataEntry/DynamicListDataEntry.spec.tsx +91 -144
- package/src/components/DynamicDataList/DynamicListDataEntry/DynamicListDataEntry.tsx +38 -20
- package/src/components/DynamicDataList/DynamicListDataEntry/Renderers/createInputRenderer/createInputRenderer.spec.tsx +18 -15
- package/src/components/DynamicDataList/DynamicListDataEntry/Renderers/createInputRenderer/createInputRenderer.tsx +2 -0
- package/src/components/DynamicDataList/DynamicListDataEntry/Renderers/createSelectRenderer/createSelectRenderer.spec.tsx +53 -28
- package/src/components/DynamicDataList/DynamicListDataEntry/Renderers/createSelectRenderer/createSelectRenderer.tsx +2 -0
- package/src/components/DynamicDataList/DynamicListDataEntry/Renderers/renderers.model.ts +2 -0
- package/src/components/DynamicDataList/DynamicListHeader/DynamicListHeader.scss +19 -5
- package/src/components/DynamicDataList/DynamicListHeader/DynamicListHeader.spec.tsx +72 -76
- package/src/components/DynamicDataList/DynamicListRow/DynamicListRow.scss +9 -2
- package/src/components/DynamicDataList/DynamicListRow/DynamicListRow.spec.tsx +86 -113
- package/src/components/DynamicDataList/helpers/DynamicListReducer/DynamicListReducer.actions.spec.ts +1 -0
- package/src/components/DynamicDataList/helpers/DynamicListReducer/DynamicListReducer.init.spec.ts +1 -0
- package/src/components/DynamicDataList/helpers/DynamicListReducer/DynamicListReducer.spec.ts +6 -5
- package/src/components/EmptyStation/EmptyStation.spec.tsx +41 -37
- package/src/components/Explorer/BulkEdit/FormFieldsConfigConverter.spec.tsx +29 -28
- package/src/components/Explorer/BulkEdit/FormFieldsConfigConverter.tsx +1 -0
- package/src/components/Explorer/BulkEdit/GenerateMutation.spec.tsx +1 -0
- package/src/components/Explorer/BulkEdit/helpers/FieldWrapper.scss +1 -0
- package/src/components/Explorer/BulkEdit/helpers/FieldWrapper.tsx +1 -0
- package/src/components/Explorer/Explorer.spec.tsx +513 -825
- package/src/components/Explorer/NavigationExplorer/NavigationExplorer.spec.tsx +90 -131
- package/src/components/Explorer/QuickEdit/useQuickEdit.spec.tsx +36 -56
- package/src/components/Explorer/SelectionExplorer/SelectionExplorer.spec.tsx +59 -65
- package/src/components/Explorer/helpers/InMemoryDataProvider.spec.ts +1 -0
- package/src/components/Explorer/helpers/useFilters.spec.tsx +13 -11
- package/src/components/Explorer/helpers/useStationMessage.spec.tsx +4 -3
- package/src/components/Explorer/helpers/useSubtitle.spec.tsx +1 -0
- package/src/components/FieldSelection/FieldSelection.scss +1 -1
- package/src/components/FieldSelection/FieldSelection.spec.tsx +1 -1
- package/src/components/FieldSelection/FieldSelection.tsx +6 -2
- package/src/components/Filters/Filter/Filter.spec.tsx +78 -47
- package/src/components/Filters/Filters.spec.tsx +56 -58
- package/src/components/Filters/SelectionTypes/DateTimeFilter/DateTimeFilter.spec.tsx +45 -46
- package/src/components/Filters/SelectionTypes/FreeTextFilter/FreeTextFilter.spec.tsx +23 -23
- package/src/components/Filters/SelectionTypes/NumericTextFilter/NumericTextFilter.spec.tsx +37 -28
- package/src/components/Filters/SelectionTypes/OptionsFilter/OptionsFilter.spec.tsx +14 -12
- package/src/components/Filters/Validators/DateRangeFilterValidator.spec.ts +1 -0
- package/src/components/Filters/Validators/NumberRangeFilterValidator.spec.ts +1 -0
- package/src/components/FormElements/BooleanView/BooleanViewField.spec.tsx +34 -31
- package/src/components/FormElements/Checkbox/Checkbox.spec.tsx +129 -128
- package/src/components/FormElements/CustomTags/CustomTags.spec.tsx +312 -446
- package/src/components/FormElements/DateTimeField/DateTimeText.spec.tsx +61 -52
- package/src/components/FormElements/DynamicDataListControl/DynamicDataListControl.spec.tsx +19 -24
- package/src/components/FormElements/FileUploadControl/FileUploadControl.spec.tsx +67 -60
- package/src/components/FormElements/FormElementContainer/FormElementContainer.spec.tsx +13 -12
- package/src/components/FormElements/FormGroup/FormGroup.scss +62 -0
- package/src/components/FormElements/FormGroup/FormGroup.stories.tsx +25 -0
- package/src/components/FormElements/FormGroup/FormGroup.tsx +60 -0
- package/src/components/FormElements/FormGroupTitle/FormGroupTitle.tsx +5 -0
- package/src/components/FormElements/Link/LinkField.spec.tsx +24 -23
- package/src/components/FormElements/MaskedSingleLineText/MaskedSingleLineText.spec.tsx +4 -3
- package/src/components/FormElements/Radio/Radio.spec.tsx +170 -172
- package/src/components/FormElements/ReadOnly/ReadOnlyField.spec.tsx +23 -22
- package/src/components/FormElements/ReadOnlyText/ReadOnlyTextField.spec.tsx +23 -22
- package/src/components/FormElements/Select/Select.spec.tsx +30 -29
- package/src/components/FormElements/SingleLineText/SingleLineText.spec.tsx +46 -42
- package/src/components/FormElements/Tags/Tags.spec.tsx +59 -53
- package/src/components/FormElements/TextArea/TextArea.spec.tsx +44 -29
- package/src/components/FormElements/ToggleButton/ToggleButton.spec.tsx +188 -165
- package/src/components/FormElements/index.ts +1 -0
- package/src/components/FormStation/FormStation.spec.tsx +273 -198
- package/src/components/FormStation/FormStation.stories.tsx +15 -13
- package/src/components/FormStation/FormStationHeader/FormStationHeader.tsx +5 -3
- package/src/components/FormStation/SaveOnNavigate/SaveOnNavigate.spec.tsx +23 -20
- package/src/components/FormStation/SaveOnNavigate/handleNavigationAttempt.spec.ts +25 -24
- package/src/components/FormStation/helpers/useTitle.spec.ts +9 -7
- package/src/components/Hub/Hub.spec.tsx +13 -10
- package/src/components/Hub/Tile/Tile.spec.tsx +29 -25
- package/src/components/Icons/Icons.spec.tsx +25 -27
- package/src/components/Icons/Icons.tsx +1 -1
- package/src/components/InfoPanel/InfoImage/InfoImage.spec.tsx +4 -3
- package/src/components/InfoPanel/InfoPanel.scss +2 -0
- package/src/components/InfoPanel/InfoPanel.spec.tsx +4 -3
- package/src/components/InfoPanel/Paragraph/Paragraph.spec.tsx +4 -3
- package/src/components/InfoPanel/Section/Section.spec.tsx +39 -46
- package/src/components/InfoPanel/hooks/useCollapse.ts +9 -7
- package/src/components/InlineMenu/InlineMenu.spec.tsx +24 -23
- package/src/components/InlineMenu/InlineMenu.tsx +3 -0
- package/src/components/LandingPageHeader/LandingPageHeader.spec.tsx +9 -8
- package/src/components/LandingPageTiles/LandingPageTiles.spec.tsx +29 -28
- package/src/components/LandingPageTiles/TileLarge/TileLarge.spec.tsx +68 -61
- package/src/components/LandingPageTiles/TileSmall/TileSmall.spec.tsx +50 -32
- package/src/components/List/List.spec.tsx +337 -241
- package/src/components/List/ListCheckBox/ListCheckBox.spec.tsx +54 -48
- package/src/components/List/ListHeader/ColumnLabel/ColumnLabel.scss +4 -1
- package/src/components/List/ListHeader/ColumnLabel/ColumnLabel.spec.tsx +46 -43
- package/src/components/List/ListHeader/ListHeader.spec.tsx +82 -66
- package/src/components/List/ListRow/ListRow.spec.tsx +125 -130
- package/src/components/List/ListRow/ListRowCell/ListRowCell.spec.tsx +57 -100
- package/src/components/List/ListRow/ListRowLoader.spec.tsx +16 -12
- package/src/components/List/ListRow/Renderers/BooleanDotRenderer/BooleanDotRenderer.spec.tsx +12 -9
- package/src/components/List/ListRow/Renderers/ExternalLinkRenderer/ExternalLinkRenderer.spec.tsx +40 -35
- package/src/components/List/ListRow/Renderers/StateRenderer/StateRenderer.spec.tsx +14 -17
- package/src/components/List/ListRow/Renderers/TagsRenderer/TagsRenderer.spec.tsx +18 -17
- package/src/components/List/ListRow/Renderers/TagsRenderer/TagsRenderer.tsx +2 -2
- package/src/components/List/ListRowRenderer/ListRowRenderer.spec.tsx +82 -68
- package/src/components/Loaders/ImageLoader/ImageLoader.spec.tsx +88 -96
- package/src/components/Loaders/Loader/Loader.spec.tsx +51 -24
- package/src/components/Message/Message.spec.tsx +56 -44
- package/src/components/MessageBar/MessageBar.scss +3 -0
- package/src/components/MessageBar/MessageBar.spec.tsx +88 -85
- package/src/components/Modal/Modal.spec.tsx +92 -87
- package/src/components/NavigationAwareStation/NavigationAwareStation.spec.tsx +23 -22
- package/src/components/PageHeader/PageHeader.spec.tsx +22 -21
- package/src/components/PageHeader/PageHeaderAction/PageHeaderAction.spec.tsx +275 -193
- package/src/components/PageHeader/PageHeaderActionsGroup/PageHeaderActionsGroup.spec.tsx +39 -34
- package/src/components/ProgressBar/ProgressBar.spec.tsx +18 -15
- package/src/components/Utils/Postgraphile/CreateConnectionRenderer.spec.ts +1 -0
- package/src/components/Utils/Postgraphile/FilterTransformer.spec.ts +1 -0
- package/src/components/Utils/Postgraphile/RangeTransformer.spec.ts +1 -0
- package/src/components/Utils/Postgraphile/SortTransformer.spec.ts +1 -0
- package/src/components/Utils/Postgraphile/UpdateGQLFragmentGenerator.spec.ts +1 -0
- package/src/components/Utils/Postgraphile/generateArrayMutations.spec.ts +1 -0
- package/src/components/Utils/Postgraphile/getArrayDiff.spec.ts +1 -0
- package/src/components/Utils/Postgraphile/getFormDiff.spec.ts +1 -0
- package/src/components/Utils/State/GlobalState.spec.ts +4 -2
- package/src/components/Utils/Transformers/Boolean.spec.ts +1 -0
- package/src/components/Utils/Transformers/DateTime.spec.ts +2 -1
- package/src/components/Utils/Transformers/FileSize.spec.ts +1 -0
- package/src/components/Utils/Transformers/SortArray.spec.ts +1 -0
- package/src/components/Utils/Transformers/Timestamp.spec.ts +3 -2
- package/src/components/Utils/Transformers/TitleCase.spec.ts +1 -0
- package/src/components/VisualElements/ImgElement.spec.tsx +34 -35
- package/src/components/VisualElements/SvgElement.spec.tsx +72 -69
- package/src/helpers/testing.ts +9 -76
- package/src/hooks/useBusy/useBusy.spec.tsx +8 -9
- package/src/hooks/useClickOutside/useClickOutside.spec.tsx +19 -51
- package/src/hooks/useDebounce/useDebounce.spec.tsx +31 -26
- package/src/hooks/useExpand/useExpand.spec.tsx +30 -21
- package/src/hooks/useTabTitle/useTabTitle.spec.tsx +18 -18
- package/src/hooks/useValueOrOnDemand/useValueOrOnDemand.spec.tsx +31 -52
- package/src/styles/variables.scss +3 -1
- package/src/utils/ErrorMapper/ApolloClient/ApolloErrorMapper.spec.ts +1 -0
- package/src/utils/ErrorMapper/ErrorMapper.spec.ts +1 -0
- package/src/utils/ErrorTypeToStationError.spec.tsx +12 -11
- package/src/utils/ToolTipHelpers.spec.ts +1 -0
- package/src/validators/timestamp/timestamp.spec.ts +1 -0
- package/dist/helpers/hooksTestingHelpers.d.ts +0 -7
- package/dist/helpers/hooksTestingHelpers.d.ts.map +0 -1
- package/src/helpers/hooksTestingHelpers.tsx +0 -22
|
@@ -1,11 +1,9 @@
|
|
|
1
1
|
/* eslint-disable @typescript-eslint/no-non-null-assertion */
|
|
2
|
-
import {
|
|
2
|
+
import { fireEvent, render } from '@testing-library/react';
|
|
3
3
|
import React from 'react';
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
6
|
-
import { IconName } from '../../Icons';
|
|
4
|
+
import { BrowserRouter } from 'react-router-dom';
|
|
5
|
+
import { describe, expect, it, vi } from 'vitest';
|
|
7
6
|
import { Column, ListSelectMode } from '../List.model';
|
|
8
|
-
import { ListCheckBox } from '../ListCheckBox/ListCheckBox';
|
|
9
7
|
import { ListRow, ListRowProps, setLocale } from './ListRow';
|
|
10
8
|
|
|
11
9
|
interface TestExplorerData {
|
|
@@ -30,14 +28,14 @@ const mockProps: ListRowProps<TestExplorerData> = {
|
|
|
30
28
|
actionSize: '50px',
|
|
31
29
|
horizontalTextAlign: 'left',
|
|
32
30
|
verticalTextAlign: 'center',
|
|
33
|
-
onItemClicked:
|
|
31
|
+
onItemClicked: vi.fn() as (data: TestExplorerData) => void,
|
|
34
32
|
};
|
|
35
33
|
|
|
36
34
|
describe('ListRow', () => {
|
|
37
35
|
it('renders the component without crashing', () => {
|
|
38
|
-
const
|
|
36
|
+
const { container } = render(<ListRow {...mockProps} />);
|
|
39
37
|
|
|
40
|
-
expect(
|
|
38
|
+
expect(container).toBeTruthy();
|
|
41
39
|
});
|
|
42
40
|
|
|
43
41
|
it.each`
|
|
@@ -47,20 +45,20 @@ describe('ListRow', () => {
|
|
|
47
45
|
`(
|
|
48
46
|
'renders the defined columns in the defined order -> $name',
|
|
49
47
|
({ expectedColumns }: { expectedColumns: Column<TestExplorerData>[] }) => {
|
|
50
|
-
const
|
|
48
|
+
const { container } = render(
|
|
51
49
|
<ListRow {...mockProps} columns={expectedColumns} />,
|
|
52
50
|
);
|
|
53
51
|
|
|
54
|
-
const actualColumns =
|
|
52
|
+
const actualColumns = container.querySelectorAll('.cellWrapper');
|
|
55
53
|
|
|
56
54
|
// Check amount of rendered columns
|
|
57
55
|
expect(actualColumns).toHaveLength(expectedColumns.length);
|
|
58
56
|
|
|
59
57
|
actualColumns.forEach((column, idx) => {
|
|
60
58
|
const expectedPropertyName = expectedColumns[idx].propertyName!;
|
|
61
|
-
expect(column.
|
|
62
|
-
|
|
63
|
-
|
|
59
|
+
expect(column.textContent).toEqual(
|
|
60
|
+
mockExplorerData[expectedPropertyName],
|
|
61
|
+
);
|
|
64
62
|
});
|
|
65
63
|
},
|
|
66
64
|
);
|
|
@@ -74,7 +72,7 @@ describe('ListRow', () => {
|
|
|
74
72
|
|
|
75
73
|
setLocale('en-US');
|
|
76
74
|
|
|
77
|
-
const
|
|
75
|
+
const { container } = render(
|
|
78
76
|
<ListRow
|
|
79
77
|
data={rowData}
|
|
80
78
|
columns={expectedColumns}
|
|
@@ -87,12 +85,12 @@ describe('ListRow', () => {
|
|
|
87
85
|
/>,
|
|
88
86
|
);
|
|
89
87
|
|
|
90
|
-
const actualColumns =
|
|
88
|
+
const actualColumns = container.querySelectorAll('.cellWrapper');
|
|
91
89
|
// Check amount of rendered columns
|
|
92
90
|
expect(actualColumns).toHaveLength(2);
|
|
93
91
|
|
|
94
92
|
// see https://stackoverflow.com/questions/23199909/using-tolocalestring-in-node-js/23200062
|
|
95
|
-
expect(actualColumns
|
|
93
|
+
expect(actualColumns[0].textContent).toEqual(
|
|
96
94
|
new Intl.DateTimeFormat('en-US', {
|
|
97
95
|
year: 'numeric',
|
|
98
96
|
month: 'numeric',
|
|
@@ -102,7 +100,7 @@ describe('ListRow', () => {
|
|
|
102
100
|
second: 'numeric',
|
|
103
101
|
}).format(rowData.date),
|
|
104
102
|
);
|
|
105
|
-
expect(actualColumns
|
|
103
|
+
expect(actualColumns[1].textContent).toBe('123,456.12');
|
|
106
104
|
});
|
|
107
105
|
|
|
108
106
|
it('uses custom renderer', () => {
|
|
@@ -115,12 +113,12 @@ describe('ListRow', () => {
|
|
|
115
113
|
];
|
|
116
114
|
const rowData = { value: 'something' };
|
|
117
115
|
|
|
118
|
-
const
|
|
116
|
+
const { container } = render(
|
|
119
117
|
// @ts-expect-error Typings to not match up
|
|
120
118
|
<ListRow {...mockProps} data={rowData} columns={expectedColumns} />,
|
|
121
119
|
);
|
|
122
|
-
const actualColumns =
|
|
123
|
-
expect(actualColumns
|
|
120
|
+
const actualColumns = container.querySelectorAll('.cellWrapper');
|
|
121
|
+
expect(actualColumns[0].textContent).toBe('Changed: something');
|
|
124
122
|
});
|
|
125
123
|
|
|
126
124
|
it('shows empty field if a value required in a column is not present on the data object', () => {
|
|
@@ -129,42 +127,41 @@ describe('ListRow', () => {
|
|
|
129
127
|
{ propertyName: "doesn't exist", size: '1fr', label: 'desc' },
|
|
130
128
|
];
|
|
131
129
|
|
|
132
|
-
const
|
|
130
|
+
const { container } = render(
|
|
131
|
+
<ListRow {...mockProps} columns={expectedColumns} />,
|
|
132
|
+
);
|
|
133
133
|
|
|
134
|
-
const actualColumns =
|
|
134
|
+
const actualColumns = container.querySelectorAll('.cellWrapper');
|
|
135
135
|
|
|
136
136
|
// Check amount of rendered columns
|
|
137
137
|
expect(actualColumns).toHaveLength(1);
|
|
138
138
|
|
|
139
|
-
expect(actualColumns.
|
|
140
|
-
expectedColumns[0].propertyName,
|
|
141
|
-
);
|
|
142
|
-
expect(actualColumns.first().text()).toBe('');
|
|
139
|
+
expect(actualColumns[0].textContent).toBe('');
|
|
143
140
|
});
|
|
144
141
|
|
|
145
142
|
it('renders a action button by default', () => {
|
|
146
|
-
const
|
|
143
|
+
const { container } = render(
|
|
147
144
|
<ListRow
|
|
148
145
|
{...mockProps}
|
|
149
146
|
columns={[{ propertyName: 'id', size: '1fr', label: 'id' }]}
|
|
150
147
|
/>,
|
|
151
148
|
);
|
|
152
149
|
|
|
153
|
-
const actionButton =
|
|
150
|
+
const actionButton = container.querySelector('button');
|
|
154
151
|
|
|
155
|
-
expect(actionButton
|
|
152
|
+
expect(actionButton).toBeInTheDocument();
|
|
156
153
|
});
|
|
157
154
|
|
|
158
155
|
it('renders no action button if told', () => {
|
|
159
|
-
const
|
|
156
|
+
const { container } = render(
|
|
160
157
|
<ListRow {...mockProps} showActionButton={false} />,
|
|
161
158
|
);
|
|
162
159
|
|
|
163
|
-
expect(
|
|
160
|
+
expect(container.querySelector('button')).not.toBeInTheDocument();
|
|
164
161
|
});
|
|
165
162
|
|
|
166
163
|
it('renders a checkmark button', () => {
|
|
167
|
-
const
|
|
164
|
+
const { container } = render(
|
|
168
165
|
<ListRow
|
|
169
166
|
{...mockProps}
|
|
170
167
|
columns={[{ propertyName: 'id', size: '1fr', label: 'id' }]}
|
|
@@ -173,27 +170,26 @@ describe('ListRow', () => {
|
|
|
173
170
|
/>,
|
|
174
171
|
);
|
|
175
172
|
|
|
176
|
-
const checkMark =
|
|
173
|
+
const checkMark = container.querySelector('.selectionCheckMark');
|
|
177
174
|
|
|
178
|
-
expect(checkMark
|
|
179
|
-
expect(checkMark.hasClass('selectionCheckMark')).toBe(true);
|
|
175
|
+
expect(checkMark).toBeInTheDocument();
|
|
180
176
|
});
|
|
181
177
|
|
|
182
178
|
it(`'actionSize' sets navigation action height and width`, () => {
|
|
183
179
|
const mockActionSize = '10px';
|
|
184
|
-
const
|
|
180
|
+
const { container } = render(
|
|
185
181
|
<ListRow {...mockProps} actionSize={mockActionSize} />,
|
|
186
182
|
);
|
|
187
183
|
|
|
188
|
-
const actionButton =
|
|
184
|
+
const actionButton = container.querySelector('button') as HTMLElement;
|
|
189
185
|
|
|
190
|
-
expect(actionButton.
|
|
191
|
-
expect(actionButton.
|
|
186
|
+
expect(actionButton.style.height).toBe(mockActionSize);
|
|
187
|
+
expect(actionButton.style.width).toBe(mockActionSize);
|
|
192
188
|
});
|
|
193
189
|
|
|
194
190
|
it(`'actionSize' sets checkmark action height and width`, () => {
|
|
195
191
|
const mockActionSize = '10px';
|
|
196
|
-
const
|
|
192
|
+
const { container } = render(
|
|
197
193
|
<ListRow
|
|
198
194
|
{...mockProps}
|
|
199
195
|
actionSize={mockActionSize}
|
|
@@ -202,15 +198,15 @@ describe('ListRow', () => {
|
|
|
202
198
|
/>,
|
|
203
199
|
);
|
|
204
200
|
|
|
205
|
-
const actionButton =
|
|
201
|
+
const actionButton = container.querySelector('button') as HTMLElement;
|
|
206
202
|
|
|
207
|
-
expect(actionButton.
|
|
208
|
-
expect(actionButton.
|
|
203
|
+
expect(actionButton.style.height).toBe(mockActionSize);
|
|
204
|
+
expect(actionButton.style.width).toBe(mockActionSize);
|
|
209
205
|
});
|
|
210
206
|
|
|
211
207
|
it(`'actionSize' sets action checkbox height and width`, () => {
|
|
212
208
|
const mockActionSize = '10px';
|
|
213
|
-
const
|
|
209
|
+
const { container } = render(
|
|
214
210
|
<ListRow
|
|
215
211
|
{...mockProps}
|
|
216
212
|
actionSize={mockActionSize}
|
|
@@ -218,30 +214,34 @@ describe('ListRow', () => {
|
|
|
218
214
|
/>,
|
|
219
215
|
);
|
|
220
216
|
|
|
221
|
-
const checkbox =
|
|
217
|
+
const checkbox = container.querySelector(
|
|
218
|
+
'.list-checkbox-container',
|
|
219
|
+
) as HTMLElement;
|
|
222
220
|
|
|
223
|
-
expect(checkbox
|
|
224
|
-
expect(checkbox.props().width).toBe(mockActionSize);
|
|
221
|
+
expect(checkbox).toBeInTheDocument();
|
|
225
222
|
});
|
|
226
223
|
|
|
227
224
|
it('calls the "onItemClicked" event with data', () => {
|
|
228
|
-
const spy =
|
|
229
|
-
const
|
|
230
|
-
|
|
225
|
+
const spy = vi.fn();
|
|
226
|
+
const { container } = render(
|
|
227
|
+
<ListRow {...mockProps} onItemClicked={spy} />,
|
|
228
|
+
);
|
|
229
|
+
const content = container.querySelector('.content') as HTMLElement;
|
|
230
|
+
fireEvent.click(content);
|
|
231
231
|
expect(spy).toHaveBeenCalledTimes(1);
|
|
232
232
|
expect(spy).toHaveBeenCalledWith(mockExplorerData);
|
|
233
233
|
});
|
|
234
234
|
|
|
235
235
|
it('does not render a checkbox by default', () => {
|
|
236
|
-
const
|
|
236
|
+
const { container } = render(<ListRow {...mockProps} />);
|
|
237
237
|
|
|
238
|
-
const checkbox =
|
|
238
|
+
const checkbox = container.querySelector('.list-checkbox-container');
|
|
239
239
|
|
|
240
|
-
expect(checkbox
|
|
240
|
+
expect(checkbox).not.toBeInTheDocument();
|
|
241
241
|
});
|
|
242
242
|
|
|
243
243
|
it('renders a checkbox button', () => {
|
|
244
|
-
const
|
|
244
|
+
const { container } = render(
|
|
245
245
|
<ListRow
|
|
246
246
|
{...mockProps}
|
|
247
247
|
columns={[{ propertyName: 'id', size: '1fr', label: 'id' }]}
|
|
@@ -250,14 +250,14 @@ describe('ListRow', () => {
|
|
|
250
250
|
/>,
|
|
251
251
|
);
|
|
252
252
|
|
|
253
|
-
const checkbox =
|
|
253
|
+
const checkbox = container.querySelector('.list-checkbox-container');
|
|
254
254
|
|
|
255
|
-
expect(checkbox
|
|
255
|
+
expect(checkbox).toBeInTheDocument();
|
|
256
256
|
});
|
|
257
257
|
|
|
258
258
|
it('raises checkBoxHandler', () => {
|
|
259
|
-
const spy =
|
|
260
|
-
const
|
|
259
|
+
const spy = vi.fn().mockImplementation(() => null);
|
|
260
|
+
const { container } = render(
|
|
261
261
|
<ListRow
|
|
262
262
|
{...mockProps}
|
|
263
263
|
onItemSelected={spy}
|
|
@@ -266,36 +266,37 @@ describe('ListRow', () => {
|
|
|
266
266
|
/>,
|
|
267
267
|
);
|
|
268
268
|
|
|
269
|
-
const
|
|
270
|
-
|
|
269
|
+
const checkbox = container.querySelector(
|
|
270
|
+
'.list-checkbox-container button',
|
|
271
|
+
) as HTMLButtonElement;
|
|
272
|
+
fireEvent.click(checkbox);
|
|
271
273
|
|
|
272
274
|
expect(spy).toHaveBeenCalledTimes(1);
|
|
273
|
-
expect(spy).toHaveBeenCalledWith(true);
|
|
274
275
|
});
|
|
275
276
|
|
|
276
277
|
it(`does not have the 'selected' class by default`, () => {
|
|
277
|
-
const
|
|
278
|
+
const { container } = render(<ListRow {...mockProps} />);
|
|
278
279
|
|
|
279
|
-
const row =
|
|
280
|
+
const row = container.querySelector('.columnsRoot');
|
|
280
281
|
|
|
281
|
-
expect(row.
|
|
282
|
+
expect(row?.classList.contains('selected')).toBe(false);
|
|
282
283
|
});
|
|
283
284
|
|
|
284
285
|
it(`only has the 'selected' class if both itemSelect and showItemCheckbox props are true`, () => {
|
|
285
|
-
const
|
|
286
|
+
const { container } = render(
|
|
286
287
|
<ListRow {...mockProps} itemSelected={true} showItemCheckbox={true} />,
|
|
287
288
|
);
|
|
288
289
|
|
|
289
|
-
const row =
|
|
290
|
+
const row = container.querySelector('.columnsRoot');
|
|
290
291
|
|
|
291
|
-
expect(row.
|
|
292
|
+
expect(row?.classList.contains('selected')).toBe(true);
|
|
292
293
|
});
|
|
293
294
|
|
|
294
295
|
it(`raises onItemClicked if list selectionMode is set to None(the default mode)`, () => {
|
|
295
|
-
const onItemClickedSpy =
|
|
296
|
-
const onItemSelectedSpy =
|
|
296
|
+
const onItemClickedSpy = vi.fn();
|
|
297
|
+
const onItemSelectedSpy = vi.fn();
|
|
297
298
|
|
|
298
|
-
const
|
|
299
|
+
const { container } = render(
|
|
299
300
|
<ListRow
|
|
300
301
|
{...mockProps}
|
|
301
302
|
showItemCheckbox={true}
|
|
@@ -304,19 +305,19 @@ describe('ListRow', () => {
|
|
|
304
305
|
/>,
|
|
305
306
|
);
|
|
306
307
|
|
|
307
|
-
const row =
|
|
308
|
+
const row = container.querySelector('.content') as HTMLElement;
|
|
308
309
|
|
|
309
|
-
|
|
310
|
+
fireEvent.click(row);
|
|
310
311
|
|
|
311
312
|
expect(onItemClickedSpy).toHaveBeenCalledTimes(1);
|
|
312
313
|
expect(onItemSelectedSpy).not.toHaveBeenCalled();
|
|
313
314
|
});
|
|
314
315
|
|
|
315
316
|
it(`raises onItemClicked if list selectionMode is set to Single`, () => {
|
|
316
|
-
const onItemClickedSpy =
|
|
317
|
-
const onItemSelectedSpy =
|
|
317
|
+
const onItemClickedSpy = vi.fn();
|
|
318
|
+
const onItemSelectedSpy = vi.fn();
|
|
318
319
|
|
|
319
|
-
const
|
|
320
|
+
const { container } = render(
|
|
320
321
|
<ListRow
|
|
321
322
|
{...mockProps}
|
|
322
323
|
showItemCheckbox={true}
|
|
@@ -326,20 +327,20 @@ describe('ListRow', () => {
|
|
|
326
327
|
/>,
|
|
327
328
|
);
|
|
328
329
|
|
|
329
|
-
const row =
|
|
330
|
+
const row = container.querySelector('.content') as HTMLElement;
|
|
330
331
|
|
|
331
|
-
|
|
332
|
+
fireEvent.click(row);
|
|
332
333
|
|
|
333
334
|
expect(onItemClickedSpy).toHaveBeenCalledTimes(1);
|
|
334
335
|
expect(onItemSelectedSpy).not.toHaveBeenCalled();
|
|
335
336
|
});
|
|
336
337
|
|
|
337
338
|
it(`raises onItemSelected and toggles item selection if list selectionMode is set to Multi and checkbox is not disabled`, async () => {
|
|
338
|
-
const onItemClickedSpy =
|
|
339
|
-
const onItemSelectedSpy =
|
|
339
|
+
const onItemClickedSpy = vi.fn();
|
|
340
|
+
const onItemSelectedSpy = vi.fn();
|
|
340
341
|
const mockChecked = false;
|
|
341
342
|
|
|
342
|
-
const
|
|
343
|
+
const { container } = render(
|
|
343
344
|
<ListRow
|
|
344
345
|
{...mockProps}
|
|
345
346
|
showItemCheckbox={true}
|
|
@@ -349,11 +350,9 @@ describe('ListRow', () => {
|
|
|
349
350
|
/>,
|
|
350
351
|
);
|
|
351
352
|
|
|
352
|
-
const row =
|
|
353
|
-
|
|
354
|
-
row.simulate('click');
|
|
353
|
+
const row = container.querySelector('.content') as HTMLElement;
|
|
355
354
|
|
|
356
|
-
|
|
355
|
+
fireEvent.click(row);
|
|
357
356
|
|
|
358
357
|
expect(onItemSelectedSpy).toHaveBeenCalledTimes(1);
|
|
359
358
|
expect(onItemSelectedSpy).toHaveBeenCalledWith(!mockChecked);
|
|
@@ -361,9 +360,9 @@ describe('ListRow', () => {
|
|
|
361
360
|
});
|
|
362
361
|
|
|
363
362
|
it(`does not raise onItemSelected if the row is disabled`, async () => {
|
|
364
|
-
const onItemSelectedSpy =
|
|
363
|
+
const onItemSelectedSpy = vi.fn();
|
|
365
364
|
|
|
366
|
-
const
|
|
365
|
+
const { container } = render(
|
|
367
366
|
<ListRow
|
|
368
367
|
{...mockProps}
|
|
369
368
|
showItemCheckbox={true}
|
|
@@ -373,20 +372,18 @@ describe('ListRow', () => {
|
|
|
373
372
|
/>,
|
|
374
373
|
);
|
|
375
374
|
|
|
376
|
-
const row =
|
|
375
|
+
const row = container.querySelector('.columnsRoot') as HTMLElement;
|
|
377
376
|
|
|
378
|
-
|
|
379
|
-
|
|
380
|
-
wrapper.update();
|
|
377
|
+
fireEvent.click(row);
|
|
381
378
|
|
|
382
379
|
expect(onItemSelectedSpy).not.toHaveBeenCalled();
|
|
383
|
-
expect(row.
|
|
380
|
+
expect(row.classList.contains('disabled')).toBe(true);
|
|
384
381
|
});
|
|
385
382
|
|
|
386
383
|
it(`does not onItemClicked if the row is disabled`, async () => {
|
|
387
|
-
const onItemClickedSpy =
|
|
384
|
+
const onItemClickedSpy = vi.fn();
|
|
388
385
|
|
|
389
|
-
const
|
|
386
|
+
const { container } = render(
|
|
390
387
|
<ListRow
|
|
391
388
|
{...mockProps}
|
|
392
389
|
showItemCheckbox={true}
|
|
@@ -395,33 +392,33 @@ describe('ListRow', () => {
|
|
|
395
392
|
/>,
|
|
396
393
|
);
|
|
397
394
|
|
|
398
|
-
const row =
|
|
399
|
-
|
|
400
|
-
row.simulate('click');
|
|
395
|
+
const row = container.querySelector('.columnsRoot') as HTMLElement;
|
|
401
396
|
|
|
402
|
-
|
|
397
|
+
fireEvent.click(row);
|
|
403
398
|
|
|
404
399
|
expect(onItemClickedSpy).not.toHaveBeenCalled();
|
|
405
|
-
expect(row.
|
|
400
|
+
expect(row.classList.contains('disabled')).toBe(true);
|
|
406
401
|
});
|
|
407
402
|
|
|
408
403
|
describe('linking', () => {
|
|
409
404
|
it('does render a link if not in select mode and got a string as "onItemClicked"', () => {
|
|
410
|
-
const
|
|
411
|
-
<
|
|
412
|
-
|
|
413
|
-
|
|
414
|
-
|
|
415
|
-
|
|
405
|
+
const { container } = render(
|
|
406
|
+
<BrowserRouter>
|
|
407
|
+
<ListRow
|
|
408
|
+
{...mockProps}
|
|
409
|
+
onItemClicked="http://this.is.a.test.url"
|
|
410
|
+
selectionMode={ListSelectMode.None}
|
|
411
|
+
/>
|
|
412
|
+
</BrowserRouter>,
|
|
416
413
|
);
|
|
417
414
|
|
|
418
|
-
const link =
|
|
415
|
+
const link = container.querySelector('a');
|
|
419
416
|
|
|
420
|
-
expect(link
|
|
417
|
+
expect(link).toBeInTheDocument();
|
|
421
418
|
});
|
|
422
419
|
|
|
423
420
|
it('does not render a link if in select mode and got a string as "onItemClicked"', () => {
|
|
424
|
-
const
|
|
421
|
+
const { container } = render(
|
|
425
422
|
<ListRow
|
|
426
423
|
{...mockProps}
|
|
427
424
|
onItemClicked="http://this.is.a.test.url"
|
|
@@ -429,13 +426,13 @@ describe('ListRow', () => {
|
|
|
429
426
|
/>,
|
|
430
427
|
);
|
|
431
428
|
|
|
432
|
-
const link =
|
|
429
|
+
const link = container.querySelector('.link');
|
|
433
430
|
|
|
434
|
-
expect(link
|
|
431
|
+
expect(link).not.toBeInTheDocument();
|
|
435
432
|
});
|
|
436
433
|
|
|
437
434
|
it('does not render a link if it got a function as "onItemClicked"', () => {
|
|
438
|
-
const
|
|
435
|
+
const { container } = render(
|
|
439
436
|
<ListRow
|
|
440
437
|
{...mockProps}
|
|
441
438
|
onItemClicked={() => {
|
|
@@ -445,19 +442,19 @@ describe('ListRow', () => {
|
|
|
445
442
|
/>,
|
|
446
443
|
);
|
|
447
444
|
|
|
448
|
-
const link =
|
|
445
|
+
const link = container.querySelector('.link');
|
|
449
446
|
|
|
450
|
-
expect(link
|
|
447
|
+
expect(link).not.toBeInTheDocument();
|
|
451
448
|
});
|
|
452
449
|
});
|
|
453
450
|
|
|
454
451
|
describe('tooltip', () => {
|
|
455
452
|
it(`renders a tooltip using the 'title' html attribute by default`, () => {
|
|
456
|
-
const
|
|
457
|
-
const cells =
|
|
453
|
+
const { container } = render(<ListRow {...mockProps} />);
|
|
454
|
+
const cells = container.querySelectorAll('.cell');
|
|
458
455
|
|
|
459
456
|
cells.forEach((cell) => {
|
|
460
|
-
expect(cell.
|
|
457
|
+
expect((cell as HTMLElement).title).toBe(cell.textContent);
|
|
461
458
|
});
|
|
462
459
|
});
|
|
463
460
|
|
|
@@ -466,12 +463,14 @@ describe('ListRow', () => {
|
|
|
466
463
|
...obj,
|
|
467
464
|
tooltip: false,
|
|
468
465
|
}));
|
|
469
|
-
const
|
|
466
|
+
const { container } = render(
|
|
467
|
+
<ListRow {...mockProps} columns={mockColumns} />,
|
|
468
|
+
);
|
|
470
469
|
|
|
471
|
-
const cells =
|
|
470
|
+
const cells = container.querySelectorAll('.cell');
|
|
472
471
|
|
|
473
472
|
cells.forEach((cell) => {
|
|
474
|
-
expect(cell.
|
|
473
|
+
expect((cell as HTMLElement).title).toBe('');
|
|
475
474
|
});
|
|
476
475
|
});
|
|
477
476
|
|
|
@@ -486,18 +485,14 @@ describe('ListRow', () => {
|
|
|
486
485
|
];
|
|
487
486
|
const rowData = { value: mockValue };
|
|
488
487
|
|
|
489
|
-
const
|
|
488
|
+
const { container } = render(
|
|
490
489
|
// @ts-expect-error Typings to not match up
|
|
491
490
|
<ListRow {...mockProps} data={rowData} columns={expectedColumns} />,
|
|
492
491
|
);
|
|
493
492
|
|
|
494
|
-
|
|
495
|
-
const span = wrapper
|
|
496
|
-
.find('span[data-test-id="list-entry-property:value"]')
|
|
497
|
-
.first();
|
|
498
|
-
const cell = span.closest('.cell');
|
|
493
|
+
const cell = container.querySelector('.cell') as HTMLElement;
|
|
499
494
|
|
|
500
|
-
expect(cell.
|
|
495
|
+
expect(cell.title).toBe(mockValue);
|
|
501
496
|
});
|
|
502
497
|
});
|
|
503
498
|
|
|
@@ -513,7 +508,7 @@ describe('ListRow', () => {
|
|
|
513
508
|
|
|
514
509
|
alignments.forEach(({ horizontal, vertical }) => {
|
|
515
510
|
it(`should apply the correct styles for textAlign: ${horizontal}, alignSelf: ${vertical}`, () => {
|
|
516
|
-
const
|
|
511
|
+
const { container } = render(
|
|
517
512
|
<ListRow
|
|
518
513
|
{...mockProps}
|
|
519
514
|
columns={[{ propertyName: 'id', size: '1fr', label: 'id' }]}
|
|
@@ -522,13 +517,13 @@ describe('ListRow', () => {
|
|
|
522
517
|
/>,
|
|
523
518
|
);
|
|
524
519
|
|
|
525
|
-
const wrapperDivs =
|
|
520
|
+
const wrapperDivs = container.querySelectorAll('.cell');
|
|
526
521
|
|
|
527
522
|
wrapperDivs.forEach((node) => {
|
|
528
|
-
const
|
|
523
|
+
const element = node as HTMLElement;
|
|
529
524
|
|
|
530
|
-
expect(style).
|
|
531
|
-
expect(style).
|
|
525
|
+
expect(element.style.textAlign).toBe(horizontal);
|
|
526
|
+
expect(element.style.alignSelf).toBe(vertical);
|
|
532
527
|
});
|
|
533
528
|
});
|
|
534
529
|
});
|