@leaflink/stash 49.5.0 → 50.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/Accordion.js +25 -28
- package/dist/Accordion.js.map +1 -1
- package/dist/Accordion.vue.d.ts +16 -16
- package/dist/ActionsDropdown.js +14 -26
- package/dist/ActionsDropdown.js.map +1 -1
- package/dist/ActionsDropdown.vue.d.ts +12 -12
- package/dist/AddressSelect.js +22 -47
- package/dist/AddressSelect.js.map +1 -1
- package/dist/AddressSelect.vue.d.ts +45 -45
- package/dist/Alert.js +4 -6
- package/dist/Alert.js.map +1 -1
- package/dist/Alert.vue.d.ts +18 -18
- package/dist/AppNavigationItem.js +16 -19
- package/dist/AppNavigationItem.js.map +1 -1
- package/dist/AppNavigationItem.vue.d.ts +4 -4
- package/dist/AppSidebar.js +27 -28
- package/dist/AppSidebar.js.map +1 -1
- package/dist/AppSidebar.vue.d.ts +7 -7
- package/dist/AppTopbar.js +12 -17
- package/dist/AppTopbar.js.map +1 -1
- package/dist/AppTopbar.vue.d.ts +8 -8
- package/dist/Avatar.js +1 -1
- package/dist/Avatar.vue.d.ts +22 -22
- package/dist/Backdrop.js +1 -1
- package/dist/Backdrop.vue.d.ts +1 -1
- package/dist/Badge.js +1 -1
- package/dist/Badge.js.map +1 -1
- package/dist/Badge.vue.d.ts +36 -36
- package/dist/Box.js +2 -3
- package/dist/Box.js.map +1 -1
- package/dist/Box.vue.d.ts +12 -12
- package/dist/{Box.vue_vue_type_script_setup_true_lang-69e5176b.js → Box.vue_vue_type_script_setup_true_lang-DgJHq-09.js} +1 -1
- package/dist/{Box.vue_vue_type_script_setup_true_lang-69e5176b.js.map → Box.vue_vue_type_script_setup_true_lang-DgJHq-09.js.map} +1 -1
- package/dist/Button.js +40 -27
- package/dist/Button.js.map +1 -1
- package/dist/Button.vue.d.ts +34 -27
- package/dist/ButtonGroup.js +1 -1
- package/dist/ButtonGroup.vue.d.ts +14 -14
- package/dist/Card.vue.d.ts +3 -3
- package/dist/CardContent.js +1 -1
- package/dist/CardContent.vue.d.ts +1 -1
- package/dist/CardFooter.js +1 -1
- package/dist/CardFooter.vue.d.ts +1 -1
- package/dist/CardMedia.js +11 -14
- package/dist/CardMedia.js.map +1 -1
- package/dist/Carousel.js +179 -180
- package/dist/Carousel.js.map +1 -1
- package/dist/Carousel.vue.d.ts +33 -11
- package/dist/Checkbox.js +38 -35
- package/dist/Checkbox.js.map +1 -1
- package/dist/Checkbox.vue.d.ts +31 -31
- package/dist/ChevronToggle.js +2 -10
- package/dist/ChevronToggle.js.map +1 -1
- package/dist/ChevronToggle.vue.d.ts +5 -5
- package/dist/{ChevronToggle.vue_vue_type_script_setup_true_lang-fcdf0c19.js → ChevronToggle.vue_vue_type_script_setup_true_lang-DuvluoTi.js} +1 -1
- package/dist/{ChevronToggle.vue_vue_type_script_setup_true_lang-fcdf0c19.js.map → ChevronToggle.vue_vue_type_script_setup_true_lang-DuvluoTi.js.map} +1 -1
- package/dist/Chip.js +17 -20
- package/dist/Chip.js.map +1 -1
- package/dist/Chip.vue.d.ts +32 -32
- package/dist/ConfirmationCodeInput.js +1 -1
- package/dist/ConfirmationCodeInput.js.map +1 -1
- package/dist/ConfirmationCodeInput.vue.d.ts +29 -29
- package/dist/ContextSwitcher.js +8 -14
- package/dist/ContextSwitcher.js.map +1 -1
- package/dist/ContextSwitcher.vue.d.ts +32 -32
- package/dist/Copy.js +23 -34
- package/dist/Copy.js.map +1 -1
- package/dist/Copy.vue.d.ts +9 -9
- package/dist/CurrencyInput.js +117 -128
- package/dist/CurrencyInput.js.map +1 -1
- package/dist/CurrencyInput.vue.d.ts +26 -21
- package/dist/CustomRender.vue.d.ts +12 -1
- package/dist/DataView.js +70 -73
- package/dist/DataView.js.map +1 -1
- package/dist/{DataView.vue_used_vue_type_style_index_0_lang.module-5c180dba.js → DataView.keys-C7eaZg2G.js} +5 -8
- package/dist/DataView.keys-C7eaZg2G.js.map +1 -0
- package/dist/DataView.vue.d.ts +51 -51
- package/dist/DataViewFilters.js +76 -90
- package/dist/DataViewFilters.js.map +1 -1
- package/dist/{DataViewFilters.keys-c80ffabe.js → DataViewFilters.keys-BLu07FiP.js} +1 -1
- package/dist/{DataViewFilters.keys-c80ffabe.js.map → DataViewFilters.keys-BLu07FiP.js.map} +1 -1
- package/dist/DataViewFilters.vue.d.ts +39 -39
- package/dist/DataViewSortButton.js +30 -43
- package/dist/DataViewSortButton.js.map +1 -1
- package/dist/DataViewSortButton.vue.d.ts +3 -3
- package/dist/DataViewToolbar.js +27 -36
- package/dist/DataViewToolbar.js.map +1 -1
- package/dist/DataViewToolbar.vue.d.ts +17 -17
- package/dist/DatePicker.js +649 -662
- package/dist/DatePicker.js.map +1 -1
- package/dist/DatePicker.vue.d.ts +73 -73
- package/dist/DescriptionList.js +1 -1
- package/dist/{DescriptionList.keys-c906ce05.js → DescriptionList.keys-BHlHYV6b.js} +1 -1
- package/dist/{DescriptionList.keys-c906ce05.js.map → DescriptionList.keys-BHlHYV6b.js.map} +1 -1
- package/dist/DescriptionList.vue.d.ts +6 -6
- package/dist/DescriptionListDetail.js +1 -1
- package/dist/DescriptionListDetail.vue.d.ts +1 -1
- package/dist/DescriptionListGroup.js +1 -1
- package/dist/DescriptionListGroup.vue.d.ts +1 -1
- package/dist/DescriptionListTerm.js +1 -1
- package/dist/DescriptionListTerm.vue.d.ts +1 -1
- package/dist/Dialog.js +26 -30
- package/dist/Dialog.js.map +1 -1
- package/dist/Dialog.vue.d.ts +34 -34
- package/dist/Divider.js +1 -1
- package/dist/Divider.js.map +1 -1
- package/dist/Divider.vue.d.ts +1 -1
- package/dist/Dropdown.js +21 -28
- package/dist/Dropdown.js.map +1 -1
- package/dist/Dropdown.vue.d.ts +28 -28
- package/dist/EmptyState.js +32 -33
- package/dist/EmptyState.js.map +1 -1
- package/dist/EmptyState.vue.d.ts +36 -36
- package/dist/Expand.js +2 -3
- package/dist/Expand.js.map +1 -1
- package/dist/Expand.vue.d.ts +14 -14
- package/dist/{Expand.vue_vue_type_script_setup_true_lang-0f236267.js → Expand.vue_vue_type_script_setup_true_lang-D0fSAtHr.js} +1 -1
- package/dist/{Expand.vue_vue_type_script_setup_true_lang-0f236267.js.map → Expand.vue_vue_type_script_setup_true_lang-D0fSAtHr.js.map} +1 -1
- package/dist/Field.js +2 -7
- package/dist/Field.js.map +1 -1
- package/dist/Field.vue.d.ts +30 -30
- package/dist/{Field.vue_vue_type_script_setup_true_lang-fded4f75.js → Field.vue_vue_type_script_setup_true_lang-DjxUvSRF.js} +2 -2
- package/dist/{Field.vue_vue_type_script_setup_true_lang-fded4f75.js.map → Field.vue_vue_type_script_setup_true_lang-DjxUvSRF.js.map} +1 -1
- package/dist/FileUpload.js +58 -57
- package/dist/FileUpload.js.map +1 -1
- package/dist/FileUpload.vue.d.ts +28 -28
- package/dist/FilterChip.js +12 -17
- package/dist/FilterChip.js.map +1 -1
- package/dist/FilterChip.vue.d.ts +19 -19
- package/dist/FilterDrawerItem.js +24 -30
- package/dist/FilterDrawerItem.js.map +1 -1
- package/dist/FilterDrawerItem.vue.d.ts +2 -2
- package/dist/FilterDropdown.js +41 -57
- package/dist/FilterDropdown.js.map +1 -1
- package/dist/FilterDropdown.vue.d.ts +9 -9
- package/dist/FilterSelect.js +36 -45
- package/dist/FilterSelect.js.map +1 -1
- package/dist/FilterSelect.vue.d.ts +5 -5
- package/dist/Filters.js +60 -96
- package/dist/Filters.js.map +1 -1
- package/dist/Filters.vue.d.ts +2005 -2294
- package/dist/HttpError.js +16 -23
- package/dist/HttpError.js.map +1 -1
- package/dist/HttpError.vue.d.ts +18 -18
- package/dist/Icon.js +27 -22
- package/dist/Icon.js.map +1 -1
- package/dist/Icon.vue.d.ts +13 -13
- package/dist/IconLabel.js +9 -12
- package/dist/IconLabel.js.map +1 -1
- package/dist/IconLabel.vue.d.ts +17 -17
- package/dist/Illustration.js +8 -11
- package/dist/Illustration.js.map +1 -1
- package/dist/Illustration.vue.d.ts +21 -21
- package/dist/{Illustration.vue_vue_type_script_setup_true_lang-e26c3841.js → Illustration.vue_vue_type_script_setup_true_lang-C3qG3Ty6.js} +2 -2
- package/dist/{Illustration.vue_vue_type_script_setup_true_lang-e26c3841.js.map → Illustration.vue_vue_type_script_setup_true_lang-C3qG3Ty6.js.map} +1 -1
- package/dist/Image.js.map +1 -1
- package/dist/Image.vue.d.ts +18 -18
- package/dist/InlineEdit.js +19 -30
- package/dist/InlineEdit.js.map +1 -1
- package/dist/InlineEdit.vue.d.ts +26 -26
- package/dist/Input.js +58 -64
- package/dist/Input.js.map +1 -1
- package/dist/Input.vue.d.ts +44 -36
- package/dist/InputOptions.js +66 -93
- package/dist/InputOptions.js.map +1 -1
- package/dist/InputOptions.vue.d.ts +66 -58
- package/dist/IntegrationIcon.js +2 -2
- package/dist/IntegrationIcon.js.map +1 -1
- package/dist/IntegrationIcon.vue.d.ts +12 -12
- package/dist/Label.js +2 -5
- package/dist/Label.js.map +1 -1
- package/dist/Label.vue.d.ts +17 -17
- package/dist/{Label.vue_vue_type_script_setup_true_lang-b6ba2f02.js → Label.vue_vue_type_script_setup_true_lang-C4JKdqvC.js} +1 -1
- package/dist/{Label.vue_vue_type_script_setup_true_lang-b6ba2f02.js.map → Label.vue_vue_type_script_setup_true_lang-C4JKdqvC.js.map} +1 -1
- package/dist/LicenseChip.js +10 -16
- package/dist/LicenseChip.js.map +1 -1
- package/dist/LicenseChip.vue.d.ts +3 -3
- package/dist/ListItem.js +5 -8
- package/dist/ListItem.js.map +1 -1
- package/dist/ListItem.vue.d.ts +275 -225
- package/dist/ListItemCell.js +1 -1
- package/dist/ListItemCell.js.map +1 -1
- package/dist/ListItemCell.vue.d.ts +13 -2
- package/dist/ListView.js +57 -101
- package/dist/ListView.js.map +1 -1
- package/dist/ListView.vue.d.ts +5185 -5430
- package/dist/Loading.js +12 -10
- package/dist/Loading.js.map +1 -1
- package/dist/Loading.vue.d.ts +1 -1
- package/dist/Logo.js +2 -4
- package/dist/Logo.js.map +1 -1
- package/dist/Logo.vue.d.ts +17 -17
- package/dist/{Logo.vue_vue_type_script_setup_true_lang-2a2597cb.js → Logo.vue_vue_type_script_setup_true_lang-BfUU9J9O.js} +1 -1
- package/dist/{Logo.vue_vue_type_script_setup_true_lang-2a2597cb.js.map → Logo.vue_vue_type_script_setup_true_lang-BfUU9J9O.js.map} +1 -1
- package/dist/Menu.js +1 -1
- package/dist/Menu.vue.d.ts +1 -1
- package/dist/MenuItem.js +1 -1
- package/dist/MenuItem.vue.d.ts +1 -1
- package/dist/{MenusPlugin-9288029a.js → MenusPlugin-Bk6UW6o9.js} +1 -1
- package/dist/{MenusPlugin-9288029a.js.map → MenusPlugin-Bk6UW6o9.js.map} +1 -1
- package/dist/Metric.vue.d.ts +10 -10
- package/dist/Modal.js +27 -32
- package/dist/Modal.js.map +1 -1
- package/dist/Modal.vue.d.ts +42 -42
- package/dist/Modals.js +14 -16
- package/dist/Modals.js.map +1 -1
- package/dist/Modals.vue.d.ts +1 -1
- package/dist/ModalsPlugin.js +9 -12
- package/dist/ModalsPlugin.js.map +1 -1
- package/dist/Module.js +3 -3
- package/dist/{Module.keys-2cc7d830.js → Module.keys-CEsrW2f0.js} +1 -1
- package/dist/{Module.keys-2cc7d830.js.map → Module.keys-CEsrW2f0.js.map} +1 -1
- package/dist/{Module.types-3f78f2a0.js → Module.types-B1FfGGac.js} +1 -1
- package/dist/{Module.types-3f78f2a0.js.map → Module.types-B1FfGGac.js.map} +1 -1
- package/dist/Module.vue.d.ts +3 -3
- package/dist/ModuleContent.js +2 -2
- package/dist/ModuleContent.vue.d.ts +1 -1
- package/dist/ModuleFooter.js +2 -2
- package/dist/ModuleFooter.vue.d.ts +1 -1
- package/dist/ModuleHeader.js +3 -3
- package/dist/ModuleHeader.vue.d.ts +15 -15
- package/dist/ObfuscateText.js +8 -13
- package/dist/ObfuscateText.js.map +1 -1
- package/dist/ObfuscateText.vue.d.ts +18 -18
- package/dist/PageContent.js +1 -1
- package/dist/PageContent.vue.d.ts +1 -1
- package/dist/PageHeader.js +26 -23
- package/dist/PageHeader.js.map +1 -1
- package/dist/PageHeader.vue.d.ts +7 -4
- package/dist/PageNavigation.js +41 -64
- package/dist/PageNavigation.js.map +1 -1
- package/dist/PageNavigation.vue.d.ts +10 -10
- package/dist/Paginate.js +36 -34
- package/dist/Paginate.js.map +1 -1
- package/dist/Paginate.vue.d.ts +11 -11
- package/dist/PlaidLink.js +3 -5
- package/dist/PlaidLink.js.map +1 -1
- package/dist/PlaidLink.vue.d.ts +29 -29
- package/dist/QuickAction.js +12 -15
- package/dist/QuickAction.js.map +1 -1
- package/dist/QuickAction.vue.d.ts +1 -1
- package/dist/Radio.js +1 -1
- package/dist/Radio.js.map +1 -1
- package/dist/Radio.vue.d.ts +83 -12
- package/dist/RadioGroup.js +41 -45
- package/dist/RadioGroup.js.map +1 -1
- package/dist/{RadioGroup.keys-974818d6.js → RadioGroup.keys-CqfiKkNz.js} +1 -1
- package/dist/{RadioGroup.keys-974818d6.js.map → RadioGroup.keys-CqfiKkNz.js.map} +1 -1
- package/dist/RadioGroup.vue.d.ts +30 -30
- package/dist/RadioNew.js +2 -2
- package/dist/RadioNew.js.map +1 -1
- package/dist/RadioNew.vue.d.ts +26 -26
- package/dist/RangeInput.js +10 -14
- package/dist/RangeInput.js.map +1 -1
- package/dist/RangeInput.vue.d.ts +1 -1
- package/dist/SearchBar.js +31 -41
- package/dist/SearchBar.js.map +1 -1
- package/dist/SearchBar.vue.d.ts +22 -22
- package/dist/Select.js +66 -78
- package/dist/Select.js.map +1 -1
- package/dist/Select.vue.d.ts +123 -123
- package/dist/SelectStatus.js +47 -69
- package/dist/SelectStatus.js.map +1 -1
- package/dist/SelectStatus.vue.d.ts +33 -26
- package/dist/Skeleton.js +1 -1
- package/dist/Skeleton.js.map +1 -1
- package/dist/Skeleton.vue.d.ts +9 -9
- package/dist/Step.js +10 -14
- package/dist/Step.js.map +1 -1
- package/dist/Step.vue.d.ts +21 -21
- package/dist/Stepper.js +37 -40
- package/dist/Stepper.js.map +1 -1
- package/dist/Stepper.vue.d.ts +34 -29
- package/dist/Switch.js +1 -1
- package/dist/Switch.vue.d.ts +23 -23
- package/dist/Tab.js +21 -36
- package/dist/Tab.js.map +1 -1
- package/dist/Table.js +38 -55
- package/dist/Table.js.map +1 -1
- package/dist/Table.keys-LHQf6FEH.js +7 -0
- package/dist/{Table.keys-83e4f09b.js.map → Table.keys-LHQf6FEH.js.map} +1 -1
- package/dist/Table.vue.d.ts +36 -36
- package/dist/TableCell.js +26 -26
- package/dist/TableCell.js.map +1 -1
- package/dist/TableCell.vue.d.ts +6 -6
- package/dist/TableHeaderCell.js +6 -13
- package/dist/TableHeaderCell.js.map +1 -1
- package/dist/TableHeaderCell.vue.d.ts +3 -3
- package/dist/TableHeaderRow.js +22 -32
- package/dist/TableHeaderRow.js.map +1 -1
- package/dist/TableHeaderRow.vue.d.ts +8 -8
- package/dist/TableRow.js +59 -59
- package/dist/TableRow.js.map +1 -1
- package/dist/TableRow.vue.d.ts +26 -26
- package/dist/Tabs.js +10 -24
- package/dist/Tabs.js.map +1 -1
- package/dist/Tabs.vue.d.ts +5 -5
- package/dist/{Tabs.vue_used_vue_type_style_index_0_lang.module-d7530989.js → Tabs.vue_vue_type_script_setup_true_lang-l41hWkV4.js} +31 -34
- package/dist/Tabs.vue_vue_type_script_setup_true_lang-l41hWkV4.js.map +1 -0
- package/dist/TextEditor.js +1269 -1364
- package/dist/TextEditor.js.map +1 -1
- package/dist/TextEditor.vue.d.ts +46 -46
- package/dist/Textarea.js +30 -31
- package/dist/Textarea.js.map +1 -1
- package/dist/Textarea.vue.d.ts +34 -26
- package/dist/Timeline.js +9 -10
- package/dist/Timeline.js.map +1 -1
- package/dist/Timeline.vue.d.ts +6 -6
- package/dist/TimelineItem.js +1 -1
- package/dist/TimelineItem.vue.d.ts +1 -1
- package/dist/Toast.js +5 -9
- package/dist/Toast.js.map +1 -1
- package/dist/Toast.vue.d.ts +3 -3
- package/dist/Toasts.js +15 -25
- package/dist/Toasts.js.map +1 -1
- package/dist/Toasts.vue.d.ts +1 -1
- package/dist/ToastsPlugin.js +11 -23
- package/dist/ToastsPlugin.js.map +1 -1
- package/dist/Tooltip.js +1 -1
- package/dist/Tooltip.js.map +1 -1
- package/dist/Tooltip.vue.d.ts +15 -15
- package/dist/{_commonjsHelpers-10dfc225.js → _commonjsHelpers-DaMA6jEr.js} +1 -1
- package/dist/_commonjsHelpers-DaMA6jEr.js.map +1 -0
- package/dist/{_plugin-vue_export-helper-dad06003.js → _plugin-vue_export-helper-CHgC5LLL.js} +1 -1
- package/dist/_plugin-vue_export-helper-CHgC5LLL.js.map +1 -0
- package/dist/{colors-8d9b9429.js → colors-DDDVvqfQ.js} +1 -1
- package/dist/{colors-8d9b9429.js.map → colors-DDDVvqfQ.js.map} +1 -1
- package/dist/components.css +2 -2
- package/dist/directives/observe.js.map +1 -1
- package/dist/directives/sticky.js.map +1 -1
- package/dist/directives/tooltip.js +21 -27
- package/dist/directives/tooltip.js.map +1 -1
- package/dist/directives/viewable.js +1 -1
- package/dist/directives/viewable.js.map +1 -1
- package/dist/{floating-ui.vue-8d7f7932.js → floating-ui.vue-BmfQDqE-.js} +2 -3
- package/dist/{floating-ui.vue-8d7f7932.js.map → floating-ui.vue-BmfQDqE-.js.map} +1 -1
- package/dist/{formatDateTime-a5e70901.js → formatDateTime-C8CYECpd.js} +8 -12
- package/dist/{formatDateTime-a5e70901.js.map → formatDateTime-C8CYECpd.js.map} +1 -1
- package/dist/{index-9e1095ef.js → index-D6bxWkZ1.js} +2 -3
- package/dist/{index-9e1095ef.js.map → index-D6bxWkZ1.js.map} +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/index.js +90 -112
- package/dist/index.js.map +1 -1
- package/dist/{isDefined-2ce6cde4.js → isDefined-DzVx0B6k.js} +1 -1
- package/dist/{isDefined-2ce6cde4.js.map → isDefined-DzVx0B6k.js.map} +1 -1
- package/dist/{isValid-4b2b7a54.js → isValid-DN-HkCoi.js} +1 -1
- package/dist/{isValid-4b2b7a54.js.map → isValid-DN-HkCoi.js.map} +1 -1
- package/dist/{keys-241d03b7.js → keys-BEdEsanp.js} +1 -1
- package/dist/{keys-241d03b7.js.map → keys-BEdEsanp.js.map} +1 -1
- package/dist/{keys-7ecef029.js → keys-C8Zfr_By.js} +1 -1
- package/dist/{keys-7ecef029.js.map → keys-C8Zfr_By.js.map} +1 -1
- package/dist/{misc-76697f61.js → misc-CHQs-G03.js} +1 -1
- package/dist/{misc-76697f61.js.map → misc-CHQs-G03.js.map} +1 -1
- package/dist/{parseISO-ed4094c1.js → parseISO-wlfIB_QJ.js} +12 -18
- package/dist/{parseISO-ed4094c1.js.map → parseISO-wlfIB_QJ.js.map} +1 -1
- package/dist/{searchFuzzy-9b74ec4e.js → searchFuzzy-DKooyZM8.js} +110 -149
- package/dist/{searchFuzzy-9b74ec4e.js.map → searchFuzzy-DKooyZM8.js.map} +1 -1
- package/dist/{statusLevels-a8b041f4.js → statusLevels-D8EgtE_L.js} +1 -1
- package/dist/{statusLevels-a8b041f4.js.map → statusLevels-D8EgtE_L.js.map} +1 -1
- package/dist/storage.js +8 -15
- package/dist/storage.js.map +1 -1
- package/dist/tailwind-base.js.map +1 -1
- package/dist/{toTimeZone-a2ed6470.js → toTimeZone-CVE1ZmsS.js} +1 -1
- package/dist/{toTimeZone-a2ed6470.js.map → toTimeZone-CVE1ZmsS.js.map} +1 -1
- package/dist/useDialog.js +7 -7
- package/dist/useGoogleMaps.js +18 -28
- package/dist/useGoogleMaps.js.map +1 -1
- package/dist/useModals.js +1 -2
- package/dist/useModals.js.map +1 -1
- package/dist/useScriptTag.js.map +1 -1
- package/dist/useSearch.js +14 -19
- package/dist/useSearch.js.map +1 -1
- package/dist/useStepper.js.map +1 -1
- package/dist/useValidation.js +1 -1
- package/dist/useValidation.js.map +1 -1
- package/dist/utils/calculateElementOverflow.js +9 -13
- package/dist/utils/calculateElementOverflow.js.map +1 -1
- package/dist/utils/colorScheme.js.map +1 -1
- package/dist/utils/createQueryString.js +4 -5
- package/dist/utils/createQueryString.js.map +1 -1
- package/dist/utils/createValidDate.js +2 -2
- package/dist/utils/formatDateTime.js +4 -5
- package/dist/utils/formatDateTime.js.map +1 -1
- package/dist/utils/getContrastingTextColor.js +1 -1
- package/dist/utils/getContrastingTextColor.js.map +1 -1
- package/dist/utils/helpers.js.map +1 -1
- package/dist/utils/i18n.js +25 -26
- package/dist/utils/i18n.js.map +1 -1
- package/dist/utils/normalizeDate.js +1 -1
- package/dist/utils/searchFuzzy.js +3 -10
- package/dist/utils/searchFuzzy.js.map +1 -1
- package/dist/utils/storage.js +6 -11
- package/dist/utils/storage.js.map +1 -1
- package/dist/utils/toTimeZone.js +2 -3
- package/dist/utils/toTimeZone.js.map +1 -1
- package/package.json +13 -14
- package/dist/Button.vue_used_vue_type_style_index_0_lang.module-4dabc2a9.js +0 -17
- package/dist/Button.vue_used_vue_type_style_index_0_lang.module-4dabc2a9.js.map +0 -1
- package/dist/Carousel.types.d.ts +0 -33
- package/dist/Carousel.types.js +0 -2
- package/dist/Carousel.types.js.map +0 -1
- package/dist/Checkbox.vue_used_vue_type_style_index_0_lang.module-fa8d9c06.js +0 -9
- package/dist/Checkbox.vue_used_vue_type_style_index_0_lang.module-fa8d9c06.js.map +0 -1
- package/dist/DataView.vue_used_vue_type_style_index_0_lang.module-5c180dba.js.map +0 -1
- package/dist/EmptyState.vue_used_vue_type_style_index_0_lang.module-f5d89366.js +0 -8
- package/dist/EmptyState.vue_used_vue_type_style_index_0_lang.module-f5d89366.js.map +0 -1
- package/dist/Icon.vue_used_vue_type_style_index_0_lang.module-eb359559.js +0 -11
- package/dist/Icon.vue_used_vue_type_style_index_0_lang.module-eb359559.js.map +0 -1
- package/dist/Loading.vue_used_vue_type_style_index_0_lang.module-ef5a3bc6.js +0 -8
- package/dist/Loading.vue_used_vue_type_style_index_0_lang.module-ef5a3bc6.js.map +0 -1
- package/dist/Paginate.vue_used_vue_type_style_index_0_lang.module-18343da7.js +0 -11
- package/dist/Paginate.vue_used_vue_type_style_index_0_lang.module-18343da7.js.map +0 -1
- package/dist/Table.keys-83e4f09b.js +0 -27
- package/dist/Tabs.vue_used_vue_type_style_index_0_lang.module-d7530989.js.map +0 -1
- package/dist/_commonjsHelpers-10dfc225.js.map +0 -1
- package/dist/_plugin-vue_export-helper-dad06003.js.map +0 -1
package/dist/ListView.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ListView.js","sources":["../src/components/ListView/components/BulkActions.vue","../src/components/ListView/components/LoadingManager.vue","../src/components/ListView/components/ListGroup.vue","../src/components/ListView/components/ListHeader.vue","../src/components/ListView/ListView.vue"],"sourcesContent":["<script>\n import { t } from '../../../locale';\n import Button from '../../Button/Button.vue';\n import Checkbox from '../../Checkbox/Checkbox.vue';\n\n export default {\n name: 'bulk-actions',\n\n components: {\n 'll-button': Button,\n 'll-checkbox': Checkbox,\n },\n\n props: {\n allowSelectAll: Boolean,\n isAllPageChecked: Boolean,\n isSomePageChecked: Boolean,\n hideBulkActionOptions: Boolean,\n hideNumberOfTotalSelected: Boolean,\n totalCount: {\n type: Number,\n default: 0,\n },\n totalSelectedCount: {\n type: Number,\n default: 0,\n },\n },\n\n emits: ['change:select-current', 'change:select-all', 'change:clear-selected'],\n\n data: function () {\n return {\n selectAllText: t('ll.listView.selectAll'),\n };\n },\n\n computed: {\n clearSelectedText() {\n if (this.allowSelectAll) {\n return t('ll.listView.deselectAllCount', { count: this.totalCount });\n }\n\n return t('ll.listView.clearSelection');\n },\n\n showSelectAll() {\n return [this.totalSelectedCount !== this.totalCount, this.allowSelectAll].every(Boolean);\n },\n\n numberOfTotalSelectedText() {\n return t('ll.listView.numberOfTotalSelected', {\n num: this.totalSelectedCount,\n total: this.totalCount,\n });\n },\n\n selectAllCountText() {\n return t('ll.listView.selectAllCount', { count: this.totalCount });\n },\n\n numItemsSelectedText() {\n return t('ll.listView.numItemsSelected', {\n totalSelectedCount: this.totalSelectedCount,\n totalCount: this.totalCount,\n });\n },\n },\n\n methods: {\n onSelectPage(value) {\n this.$emit('change:select-current', value);\n },\n\n selectAll() {\n this.$emit('change:select-all');\n },\n\n clearSelected() {\n this.$emit('change:clear-selected');\n },\n },\n };\n</script>\n\n<template>\n <div\n class=\"lg:tw-flex\"\n :class=\"[\n $style['select-bar'],\n {\n 'lg:tw-hidden': hideBulkActionOptions,\n },\n 'tw-p-3',\n ]\"\n >\n <div\n class=\"tw-flex tw-items-center\"\n :class=\"{\n 'tw-justify-between': !hideBulkActionOptions,\n }\"\n >\n <ll-checkbox\n data-test=\"checkbox|bulk-actions\"\n :class=\"$style.checkbox\"\n class=\"tw-m-0 lg:tw-hidden\"\n :checked=\"isSomePageChecked && !!totalCount\"\n :indeterminate=\"isSomePageChecked && !isAllPageChecked\"\n :label=\"!totalSelectedCount ? selectAllText : ''\"\n @update:checked=\"onSelectPage\"\n />\n <div\n v-if=\"!!totalSelectedCount && !hideBulkActionOptions\"\n class=\"tw-flex tw-flex-1 tw-items-center tw-justify-between\"\n >\n <div v-if=\"!hideNumberOfTotalSelected\" class=\"tw-text-xs\">\n {{ numberOfTotalSelectedText }}\n </div>\n <div :class=\"{ 'tw-ml-3': !hideNumberOfTotalSelected }\">\n <ll-button v-if=\"showSelectAll\" inline @click=\"selectAll\">{{ selectAllCountText }}</ll-button>\n <ll-button v-else inline @click=\"clearSelected\">\n {{ clearSelectedText }}\n </ll-button>\n </div>\n </div>\n <div v-else-if=\"hideBulkActionOptions && !!totalSelectedCount\" class=\"tw-ml-1.5 lg:tw-hidden\">\n <h4>{{ numItemsSelectedText }}</h4>\n </div>\n </div>\n <div v-if=\"!!totalSelectedCount && !hideBulkActionOptions\" :class=\"$style.actions\">\n <slot name=\"bulk-actions-content\"></slot>\n </div>\n </div>\n</template>\n\n<style module>\n .select-bar {\n @media screen('lg') {\n border-bottom: 1px solid var(--color-ice-200);\n justify-content: center;\n vertical-align: middle;\n }\n }\n\n .checkbox {\n flex: 0 0 auto;\n }\n\n .actions > * {\n margin-top: theme('spacing.6');\n width: 100%;\n\n @media screen('lg') {\n margin-left: theme('spacing.3');\n margin-top: 0;\n width: auto;\n }\n }\n</style>\n","<script>\n import EmptyState from '../../EmptyState/EmptyState.vue';\n import Loading from '../../Loading/Loading.vue';\n\n export default {\n name: 'loading-manager',\n\n components: {\n EmptyState,\n Loading,\n },\n\n props: {\n emptyStateText: {\n type: String,\n default: '',\n },\n\n loading: Boolean,\n\n results: {\n type: Array,\n default: () => [],\n },\n },\n };\n</script>\n\n<template>\n <Loading v-if=\"loading\" class=\"tw-bg-white\" />\n <transition-group v-else-if=\"results.length\" name=\"slide-y\" tag=\"ul\">\n <slot></slot>\n </transition-group>\n <EmptyState v-else class=\"tw-bg-white\" :class=\"$style['empty-state']\" :text=\"emptyStateText\" />\n</template>\n\n<style module>\n .empty-state {\n max-width: 100%;\n }\n</style>\n","<script>\n import { CSS_VARS } from '../../../constants';\n import sticky from '../../../directives/sticky/sticky';\n import { getCssVar } from '../../../utils/helpers';\n import Button from '../../Button/Button.vue';\n import Expand from '../../Expand/Expand.vue';\n import Icon from '../../Icon/Icon.vue';\n\n export default {\n name: 'list-group',\n\n components: {\n Expand,\n 'll-button': Button,\n Icon,\n },\n\n directives: {\n sticky,\n },\n\n props: {\n /**\n * Disables the gutters between adjacent ListGroup components.\n */\n disableExternalGutters: {\n type: Boolean,\n default: false,\n },\n\n /**\n * Allows the list items to be collapsed\n */\n isCollapsible: {\n type: Boolean,\n default: false,\n },\n\n /**\n * Allows the expanded content to be collapsed by default.\n * Note: has no effect unless the `isCollapsible` prop is `true`.\n */\n isCollapsedByDefault: {\n type: Boolean,\n default: false,\n },\n },\n\n data() {\n const isExpanded = !this.isCollapsible || !this.isCollapsedByDefault;\n\n return {\n isExpanded,\n isDoneExpanding: isExpanded,\n };\n },\n\n computed: {\n headerOffset() {\n return parseFloat(getCssVar(CSS_VARS.TOP_HEADER_HEIGHT));\n },\n },\n\n methods: {\n toggleExpand() {\n if (!this.isCollapsible) {\n return;\n }\n\n this.isExpanded = !this.isExpanded;\n\n if (!this.isExpanded) {\n this.isDoneExpanding = false;\n } // else wait for Expand to emit @after-expand\n },\n\n onHeaderClick(e) {\n // toggle the ListGroup, except when clicking the actions\n if (!this.$refs.actionsContainer.contains(e.target)) {\n this.toggleExpand();\n }\n },\n },\n };\n</script>\n\n<template>\n <div\n :class=\"[\n $style['list-group'],\n {\n 'disable-external-gutters': disableExternalGutters,\n 'is-collapsed': !isExpanded,\n },\n ]\"\n >\n <header\n class=\"tw-flex tw-items-center\"\n :class=\"[$style['main-header'], { 'tw-cursor-pointer': isCollapsible }]\"\n @click=\"onHeaderClick\"\n >\n <ll-button v-if=\"isCollapsible\" :class=\"['tw-mr-1.5 tw-text-ice-900', $style['expansion-toggle-button']]\" icon>\n <Icon :class=\"[isExpanded ? 'tw-rotate-270' : 'rotate-180']\" name=\"chevron-left\" />\n </ll-button>\n\n <div class=\"tw-flex-auto\">\n <slot name=\"title\"></slot>\n </div>\n\n <div ref=\"actionsContainer\">\n <slot name=\"actions\"></slot>\n </div>\n </header>\n\n <Expand :is-expanded=\"isExpanded\" @after-expand=\"isDoneExpanding = true\">\n <div :class=\"$style['expanded-content-wrapper']\">\n <header\n v-if=\"$slots['expanded-content-list-header']\"\n v-sticky=\"isExpanded && isDoneExpanding ? headerOffset : 0\"\n :class=\"$style['expanded-content-header']\"\n >\n <div class=\"tw-ll-grid tw-flex-1\" :class=\"$style['expanded-content-header-grid']\">\n <slot name=\"expanded-content-list-header\"></slot>\n </div>\n </header>\n <div :class=\"$style['expanded-content-list-items-wrapper']\">\n <transition-group name=\"fade\" mode=\"out-in\">\n <slot name=\"expanded-content-list-items\"></slot>\n </transition-group>\n </div>\n </div>\n </Expand>\n </div>\n</template>\n\n<style module>\n .main-header {\n @apply tw-shadow;\n\n background-color: var(--color-white);\n border-radius: theme('borderRadius.DEFAULT');\n margin-bottom: theme('spacing.6');\n padding: var(--grid-gutter);\n\n @media screen('lg') {\n border-bottom: theme('borderWidth.DEFAULT') solid var(--color-ice-200);\n border-bottom-left-radius: 0;\n border-bottom-right-radius: 0;\n margin-bottom: 0;\n }\n }\n\n .expanded-content-wrapper {\n position: relative;\n width: 100%;\n }\n\n @media screen('lg') {\n .expanded-content-wrapper {\n @apply tw-shadow;\n }\n }\n\n .expanded-content-header {\n background-color: var(--color-white);\n border-bottom: theme('borderWidth.DEFAULT') solid var(--color-ice-200);\n color: var(--color-ice-900);\n display: none;\n font-weight: 500;\n padding: 0 theme('spacing.3');\n transition: padding theme('transitionDuration.150') theme('transitionTimingFunction.swing');\n z-index: 1;\n\n @media screen('lg') {\n align-items: center;\n display: flex;\n }\n\n &:global(.is-sticky) {\n @apply tw-shadow;\n\n border-radius: 0;\n z-index: calc(theme('zIndex.control') + 1);\n }\n }\n\n .expanded-content-header-grid {\n column-gap: 0;\n grid-column-gap: 0;\n\n > div {\n align-items: center;\n border-right: theme('borderWidth.DEFAULT') solid var(--color-ice-200);\n display: flex;\n font-size: theme('fontSize.xs');\n justify-content: space-between;\n padding: theme('spacing.3');\n\n &:last-of-type {\n border-right: 0;\n }\n }\n }\n\n .expansion-toggle-button:focus {\n box-shadow: none;\n }\n\n .list-group:global(.disable-external-gutters) {\n .main-header {\n @media screen('lg') {\n border-radius: 0;\n }\n }\n\n .expanded-content-list-items-wrapper > * {\n @media screen('lg') {\n border-bottom: theme('borderWidth.DEFAULT') solid var(--color-ice-200);\n border-radius: 0;\n }\n }\n\n &:last-of-type {\n &:global(.is-collapsed) .main-header,\n .expanded-content-list-items-wrapper > *:last-child {\n @media screen('lg') {\n border-bottom: none;\n border-bottom-left-radius: theme('borderRadius.DEFAULT');\n border-bottom-right-radius: theme('borderRadius.DEFAULT');\n }\n }\n }\n }\n</style>\n","<script>\n import Icon from '../../Icon/Icon.vue';\n\n export default {\n name: 'list-header',\n\n components: {\n 'll-icon': Icon,\n },\n\n props: {\n /**\n * keys to be sorted for the column\n * the first key should be the default sort value\n */\n sortKeys: {\n type: Array,\n required: true,\n validator: (value) => value.length === 2,\n },\n\n listViewRef: {\n type: Object,\n default: null,\n },\n },\n\n data() {\n return {\n isAscending: null,\n };\n },\n\n computed: {\n listViewInstance() {\n return this.listViewRef || this.$parent;\n },\n /**\n * Is the column currently sorted\n */\n isSorted() {\n return this.sortKeys.includes(this.listViewInstance.sortTerm);\n },\n\n /**\n * Show the top icon if it's not sorted or if the current sortTerm matches\n */\n showCaretUp() {\n return this.isAscending === null || this.sortKeys[0] === this.listViewInstance.sortTerm;\n },\n\n /**\n * Show the bottom icon if it's not sorted or if the current sortTerm matches\n */\n showCaretDown() {\n return this.isAscending === null || this.sortKeys[1] === this.listViewInstance.sortTerm;\n },\n },\n\n watch: {\n isSorted: {\n handler(value) {\n this.isAscending = value ? true : null;\n },\n immediate: true,\n },\n },\n\n methods: {\n /**\n * Sorts the column by the sort field\n */\n sort() {\n this.listViewInstance.onSort(this.sortKeys[this.isAscending ? 1 : 0]);\n this.isAscending = !this.isAscending;\n },\n },\n };\n</script>\n\n<template>\n <div :class=\"['tw-cursor-pointer', { 'tw-bg-blue-100': isSorted }]\" @click=\"sort\">\n <slot></slot>\n <div class=\"h-4 w-3 tw-relative tw-text-ice-700\" :class=\"{ 'is-active-sort': isSorted }\">\n <ll-icon\n v-if=\"showCaretUp\"\n name=\"caret-up\"\n class=\"tw-absolute\"\n :class=\"[$style.caret, $style['caret-up']]\"\n size=\"dense\"\n />\n <ll-icon\n v-if=\"showCaretDown\"\n name=\"caret-down\"\n class=\"tw-absolute\"\n :class=\"[$style.caret, $style['caret-down']]\"\n size=\"dense\"\n />\n </div>\n </div>\n</template>\n\n<style module>\n .caret-up {\n top: -5px;\n }\n\n .caret-down {\n top: 2px;\n }\n\n :global(.is-active-sort) .caret {\n top: -2px; /* vertically center the caret icon */\n }\n</style>\n","<script>\n import cloneDeep from 'lodash-es/cloneDeep';\n import { computed } from 'vue';\n\n import useSearch from '../../composables/useSearch/useSearch';\n import { CSS_VARS, LLLV_CHANGE_TRIGGERS } from '../../constants';\n import sticky from '../../directives/sticky/sticky';\n import { t } from '../../locale';\n import { persistentStorage } from '../../storage';\n import { filterItems as _filterItems, getCssVar, sortItems as _sortItems } from '../../utils/helpers';\n import Badge from '../Badge/Badge.vue';\n import Button from '../Button/Button.vue';\n import Checkbox from '../Checkbox/Checkbox.vue';\n import Dropdown from '../Dropdown/Dropdown.vue';\n import Expand from '../Expand/Expand.vue';\n import Filters from '../Filters/Filters.vue';\n import Icon from '../Icon/Icon.vue';\n import Input from '../Input/Input.vue';\n import Paginate from '../Paginate/Paginate.vue';\n import BulkActions from './components/BulkActions.vue';\n import LoadingManager from './components/LoadingManager.vue';\n\n export { default as BulkActions } from './components/BulkActions.vue';\n export { default as ListGroup } from './components/ListGroup.vue';\n export { default as ListHeader } from './components/ListHeader.vue';\n export { default as LoadingManager } from './components/LoadingManager.vue';\n\n const DEFAULT_SEARCH_SCHEMA = {\n isSearchable: true,\n placeholder: 'Search',\n searchBy: ['name'],\n };\n\n export default {\n name: 'll-list-view',\n\n components: {\n BulkActions,\n Filters,\n Paginate,\n LoadingManager,\n Badge,\n Button,\n Icon,\n Dropdown,\n Expand,\n Checkbox,\n Input,\n },\n\n directives: {\n sticky,\n },\n\n inject: {\n trackSearch: { default: () => () => {} },\n trackFilters: { default: () => () => {} },\n trackSort: { default: () => () => {} },\n trackResults: { default: () => () => {} },\n },\n\n props: {\n /**\n * Hide the '{number} of {total} selected' text for bulk actions\n */\n hideNumberOfTotalSelected: {\n type: Boolean,\n default: false,\n },\n /**\n * Hide the Select All checkbox for bulk actions\n */\n hideSelectAll: {\n type: Boolean,\n default: false,\n },\n /**\n * Text to render in EmptyState component if there are no results\n */\n emptyStateText: {\n type: String,\n default: '',\n },\n filterSchema: {\n type: Array,\n default: () => [],\n },\n /**\n * Make search fuzzy. Only for client side search.\n */\n fuzzySearch: {\n type: Boolean,\n default: false,\n },\n hideTotal: Boolean,\n initialPage: {\n type: Number,\n default: undefined,\n },\n /**\n * Can items on the page be selected for bulk actions\n */\n isSelectable: Boolean,\n /**\n * For loading data already paginated, filtered (including search), and sorted from a backend.\n * Defining this prop will disable the built-in search, filtering, sorting and pagination.\n * You will instead need to use the available events (`@change`, and `@change:` prefixed)\n * to know when to request new pages from your backend.\n * This requires providing `totalItemCount`.\n * Use the loading prop to indicate when data is being loaded.\n */\n isServerSide: Boolean,\n /**\n * The data for each row. Used in this file as this.internalItems (a copy) to allow mutation;\n */\n items: {\n type: Array,\n default: () => [],\n },\n /**\n * Default field to track selected items by\n */\n itemTrackBy: {\n type: String,\n default: 'id',\n },\n loading: Boolean,\n // Number of items to display per page\n pageSize: {\n type: Number,\n default: 50,\n },\n searchSchema: {\n type: Object,\n default: () => ({}),\n },\n // Provide an optional custom 'Sort by' label\n sortLabel: {\n type: String,\n default: () => t('ll.listView.sortBy'),\n },\n sortOnLoad: Boolean,\n sorts: {\n type: Object,\n default: () => ({}),\n },\n /**\n * Total number of unpaginated results\n * Required when `isServerSide` is `true`\n */\n totalItemCount: {\n type: Number,\n default: undefined,\n },\n /**\n * Validation schema function that returns an object\n */\n validationSchema: {\n type: Function,\n default: () => () => undefined,\n },\n /**\n * Whether to disable the sticky filters\n * if disabled, the following will happen\n * 1. pre-selected value(s) can be added to\n * the filter component's attributes to overwrite the sticky filters\n * 2. users will not have sticky filters on the page\n */\n disablePersistency: Boolean,\n /**\n * Whether to disable the ability of saving 'show-filters'\n * in local storage\n */\n disableShowFilter: Boolean,\n /**\n * Whether to disable the stickiness of the header.\n * Default is false. When true, neither the list headers nor\n * the bulk actions (when applicable) will be sticky.\n */\n disableStickyHeader: Boolean,\n /**\n * Whether to expand the filters section by default on load.\n */\n showFiltersOnLoad: Boolean,\n\n /**\n * Do not use the LoadingManager, and instead render the default slot as passed\n */\n disableLoader: {\n type: Boolean,\n default: false,\n },\n\n /**\n * Override the header offset used to position the sticky header\n */\n stickyHeaderOffset: {\n type: Number,\n default: null,\n },\n /**\n * Prevent bulk actions dropdown from rendering\n */\n hideBulkActionOptions: {\n type: Boolean,\n default: false,\n },\n\n /**\n * If initial search term is provided, the list will be filtered on load.\n */\n initialSearchTerm: {\n type: String,\n default: '',\n },\n\n /**\n * Function that determines whether the item checkbox is disabled or not (default: false)\n */\n isItemDisabled: {\n type: Function,\n default: () => false,\n },\n },\n\n emits: [\n 'change',\n 'change:filter',\n 'change:page',\n 'change:search',\n 'change:sort',\n 'change:reset',\n 'filters-toggle-click',\n 'select-all',\n 'deselect-all',\n 'update-filters',\n 'updateResults',\n ],\n\n data() {\n return {\n internalItems: [],\n currentPage: this.initialPage || 1, // TODO: fetch from query params\n previousPage: null,\n sortOptionsWidth: 0,\n filters: {},\n filterText: t('ll.filter'),\n searchFor: () => {}, // initialized in the watch handler for internalItems\n searchTerm: this.initialSearchTerm,\n searchText: t('ll.search'),\n sortTerm: '',\n isLoadingSearchSchemaAction: false,\n isShowingFilters: !!(\n this.filterSchema?.length &&\n (this.showFiltersOnLoad || persistentStorage.get('show-filters'))\n ),\n isFiltering: false,\n results: [],\n selectedItems: [],\n };\n },\n\n computed: {\n /**\n * Returns true if any of its list items are truthy; otherwise returns false.\n * @returns {boolean}\n */\n isLoading() {\n return [this.loading, this.isLoadingSearchSchemaAction, this.isFiltering].some(Boolean);\n },\n\n totalCount() {\n return this.isServerSide ? this.totalItemCount : this.results.length;\n },\n\n /**\n * Helps determine if the list is filtered or not when there is an incomplete\n * result list, such as when isServerSide is true.\n */\n isFiltered() {\n return !!(this.numberOfFilters || this.searchTerm);\n },\n\n /**\n * Merges the searchSchema with the default value since all attributes are optional\n */\n internalSearchSchema() {\n return {\n ...DEFAULT_SEARCH_SCHEMA,\n searchBy: !this.searchSchema.isSearchable && DEFAULT_SEARCH_SCHEMA.searchBy,\n ...this.searchSchema,\n };\n },\n\n /**\n * Start of page\n */\n startIndex() {\n return this.pageSize * (this.currentPage - 1);\n },\n\n /**\n * End of page\n */\n endIndex() {\n return this.startIndex + this.pageSize;\n },\n\n /**\n * Slices the results set into a paginated segment.\n * @returns One page in the paginated set of results\n */\n paginated() {\n // Disables the built-in client-side pagination\n let paginated;\n\n if (this.isServerSide) {\n paginated = this.results;\n } else {\n const { endIndex, totalCount, results, startIndex } = this;\n\n paginated = results.slice(startIndex, Math.min(endIndex, totalCount));\n }\n\n this.$emit('updateResults', paginated);\n\n return paginated;\n },\n\n /**\n * Displays a visual indication for the number of results, or \"working\" if the\n * results are being determined.\n */\n total() {\n const current = this.pageSize * (this.currentPage - 1);\n const range = this.paginated.length ? `${current + 1} - ${current + this.paginated.length}` : 0;\n\n return this.isLoading\n ? t('ll.listView.calculating')\n : t('ll.listView.totalResults', { num: String(range), total: String(this.totalCount) });\n },\n\n /**\n * Determines if both #list-header and #list-items slots are used.\n * @returns {boolean}\n */\n useDefinedSlots() {\n return !!this.$slots['list-header'] && !!this.$slots['list-items'];\n },\n\n /**\n * Don't show total count if list items are selected and total is not hidden\n */\n shouldShowTotal() {\n return !this.totalSelectedCount && !this.hideTotal;\n },\n\n /**\n * Returns a list of the selected items' track by field\n */\n selectedItemIds() {\n return this.selectedItems.map((item) => item[this.itemTrackBy]);\n },\n\n /**\n * Returns a list of the paginated items' track by field\n */\n paginatedIds() {\n return this.paginated.map((item) => item[this.itemTrackBy]);\n },\n\n isAllPageChecked() {\n if (this.isServerSide) {\n return this.totalCount > 0 && this.totalCount === this.selectedItemIds.length;\n }\n\n return this.totalCount > 0 && this.paginatedIds.every((id) => this.selectedItemIds.includes(id));\n },\n\n isSomePageChecked() {\n if (this.isServerSide) {\n return this.totalCount > 0 && this.selectedItemIds.length > 0;\n }\n\n return this.totalCount > 0 && this.paginatedIds.some((id) => this.selectedItemIds.includes(id));\n },\n\n numberOfFilters() {\n return Object.keys(this.filters).reduce((acc, item) => {\n const filterBy = this.filters[item].filterBy;\n const isBoolean = typeof filterBy[0] === 'boolean';\n const isToggle = this.filters[item].filterType === 'll-checkbox';\n const isEmpty = !this.filters[item].filterType.length;\n const isInputOptionsIncomplete = this.filters[item].filterType === 'll-input-options' && filterBy[0] === '';\n\n /**\n * Don't include hidden or incomplete fields in the count:\n * - Hidden filter populated via another filter's onChange callback\n * - InputOptions with incomplete/missing values\n */\n if (isEmpty || isInputOptionsIncomplete) {\n return acc;\n }\n\n if (isBoolean || typeof filterBy[0] === 'string') {\n // Do not count toggle filters (eg. checkbox) with a `false` value\n return acc + (filterBy[0] || !isToggle ? 1 : 0);\n }\n\n return acc + (filterBy.length || 0);\n }, 0);\n },\n\n isSelectBarVisible() {\n return !!this.totalSelectedCount;\n },\n\n showPrimaryControls() {\n return this.internalSearchSchema.isSearchable || this.filterSchema.length;\n },\n\n showSecondaryControls() {\n return !!this.$slots['secondary-controls'];\n },\n\n isSortable() {\n return Object.keys(this.sorts).length > 0;\n },\n\n totalSelectedCount() {\n return this.selectedItems.length;\n },\n\n headerOffset() {\n // passing null to the v-sticky directive will prevent it from being attached to the node\n if (this.disableStickyHeader) {\n return null;\n }\n\n return this.stickyHeaderOffset ?? parseFloat(getCssVar(CSS_VARS.TOP_HEADER_HEIGHT));\n },\n },\n\n watch: {\n isShowingFilters(value) {\n if (!this.disableShowFilter) {\n persistentStorage.set('show-filters', value);\n }\n },\n\n items: {\n handler() {\n this.internalItems = cloneDeep(this.items);\n },\n immediate: true,\n deep: true,\n },\n\n internalItems: {\n handler() {\n if (this.isServerSide) {\n this.results = this.internalItems;\n\n this.trackResults({\n page: this.currentPage,\n results: this.results,\n search: this.searchTerm,\n });\n\n return;\n }\n\n const { searchFor } = useSearch({\n items: computed(() => this.internalItems),\n fieldNames: this.internalSearchSchema.searchBy.length\n ? this.internalSearchSchema.searchBy\n : [this.displayBy],\n trackBy: this.itemTrackBy,\n });\n\n this.searchFor = (searchTerm) => searchFor(searchTerm, { fuzzy: this.fuzzySearch });\n\n this.processResults();\n },\n immediate: true,\n },\n\n sortTerm() {\n if (this.isServerSide) {\n return;\n }\n\n this.processResults();\n },\n\n sorts: {\n handler(value) {\n const sortTerms = Object.keys(value);\n\n this.sortTerm = this.sortOnLoad && sortTerms.length ? sortTerms[0] : '';\n },\n immediate: true,\n },\n },\n\n created() {\n if (this.isServerSide) {\n if (this.totalItemCount === undefined) {\n throw new Error('`totalItemCount` is required when `isServerSide` is `true`.');\n }\n\n return;\n }\n\n if (this.searchSchema.action && this.internalItems.length) {\n throw new Error('You must pass either `action` or `items`, not both.');\n }\n\n if (this.searchTerm) {\n this.onSearch();\n }\n },\n\n methods: {\n /**\n * Processes the results with searchFor, filterItems, and/or sortItems.\n * Skipped when isServerSide is true because results are pre-processed.\n * @returns {Promise<void>}\n */\n async processResults() {\n if (this.searchSchema.action) {\n this.isLoadingSearchSchemaAction = true;\n let actionResponse;\n\n try {\n actionResponse = await this.searchSchema.action({ search: this.searchTerm });\n } finally {\n this.isLoadingSearchSchemaAction = false;\n }\n\n this.results = this.sortItems(this.filterItems(actionResponse?.results || []));\n } else {\n this.results = this.sortItems(this.filterItems(this.searchFor(this.searchTerm)));\n }\n\n this.trackResults({\n page: this.currentPage,\n results: this.results,\n search: this.searchTerm,\n });\n },\n\n /**\n * Filters the list of `items` based on options selected in the `filters` object\n * @param {array} items A list of items to filter.\n * @returns list of items filtered by the applied filters\n */\n filterItems(items) {\n return _filterItems(items, this.filters);\n },\n\n /**\n * Sorts a list of items based on options selected in the `sorts` object\n * @param {array} items A list of items to sort.\n * @returns list of items sorted according to the sort term.\n */\n sortItems(items) {\n return this.sortTerm ? _sortItems(items, this.sorts[this.sortTerm]) : items;\n },\n\n change({ trigger = '' } = {}) {\n const { currentPage, filters, isFiltered, pageSize, searchTerm, sortTerm } = this;\n\n const params = {\n filters,\n isFiltered,\n page: {\n number: currentPage,\n previousNumber: this.previousPage,\n size: pageSize,\n },\n search: searchTerm,\n sort: sortTerm,\n trigger,\n };\n\n this.$emit('change', params);\n },\n\n /**\n * Clear search term and reset results to their initial state\n */\n async clearSearchTerm() {\n this.searchTerm = '';\n await this.$attrs.onSearchTermClear?.();\n this.onSearch();\n },\n\n /**\n * Resets the results to their initial state on page load\n */\n reset() {\n this.$emit('change:reset');\n\n this.searchTerm = '';\n\n this.setPage({ pageNumber: 1 });\n\n if (this.isServerSide) {\n this.change({ trigger: LLLV_CHANGE_TRIGGERS.RESET });\n\n return;\n }\n\n this.processResults();\n },\n\n onSearchTermChange() {\n this.$attrs.onSearchTermChange?.(this.searchTerm);\n },\n\n /**\n * Event handler for when the user:\n * - clicks the Search button\n * - presses the enter key while focused on the search input\n * Calls a method in Filters that triggers `this.onFilter`. This is necessary\n * in order to persist the filters in local storage, which is handled internally\n * by Filters.\n */\n onSearch() {\n this.$refs.llFilters.applyFilters({ trigger: LLLV_CHANGE_TRIGGERS.SEARCH });\n },\n\n /**\n * Event handler for when the user:\n * - clicks the Apply button\n * - clicks the Search button (from `this.onSearch`)\n * - presses the enter key while focused on the search input (from `this.onSearch`)\n * @see: SELL-350\n * @param {object} [options] - optional parameters\n * @param {string} [options.trigger] - what caused the changes\n * @returns {Promise<void>}\n */\n async onFilter({ trigger = LLLV_CHANGE_TRIGGERS.APPLY } = {}) {\n this.setPage({ pageNumber: 1 });\n this.change({ trigger });\n this.trackSearch(this.searchTerm);\n this.trackFilters(this.filters);\n this.selectedItems = [];\n\n if (this.isServerSide) {\n return;\n }\n\n try {\n this.isFiltering = true;\n await this.processResults({ trigger });\n } finally {\n this.isFiltering = false;\n }\n\n this.$emit('change:search', this.searchTerm);\n this.$emit('change:filter', this.filters);\n this.$emit('update-filters', this.filters); // deprecated; replaced by change:filter\n this.clearSelected();\n },\n\n onFiltersToggleClick() {\n this.isShowingFilters = !this.isShowingFilters;\n\n this.$emit('filters-toggle-click', {\n isShowingFilters: this.isShowingFilters,\n });\n },\n\n /**\n * Extend the dropdown list so it does not shift when\n * the options drawer is open\n */\n onSortToggle() {\n // spacing added to the width of the dropdown container\n const spacing = 36;\n\n this.$nextTick(() => {\n this.sortOptionsWidth = `${this.$refs.sortOptions.clientWidth + spacing}px`;\n });\n },\n\n /**\n * Executes any side-effects when the sort `term` is changed\n * Always fires `change` automatically.\n * @param {string} term The updated sort term\n */\n onSort(term) {\n if (term === this.sortTerm) {\n return;\n }\n\n this.sortTerm = term;\n\n this.$emit('change:sort', term);\n this.trackSort(term);\n this.clearSelected();\n this.setPage({ pageNumber: 1 });\n this.change({ trigger: LLLV_CHANGE_TRIGGERS.SORT });\n },\n\n /**\n * Sets current page for the Paginator.\n * @param {Object} data\n * @param {number} data.pageNumber - the page number\n * @param {boolean} data.forceChange - flag to force the change\n */\n setPage({ pageNumber, forceChange = false } = {}) {\n this.previousPage = this.currentPage;\n\n this.currentPage = pageNumber;\n\n if (!this.isServerSide) {\n this.$emit('change:page', pageNumber);\n }\n\n if (forceChange) {\n this.change({ trigger: LLLV_CHANGE_TRIGGERS.PAGE });\n }\n },\n\n /**\n * Set the scroll position to the top of the list view.\n */\n scrollToTop() {\n this.$refs.scrollTarget && this.$refs.scrollTarget.scrollIntoView({ behavior: 'smooth', block: 'center' });\n },\n\n onPaginateSetPage(pageNumber) {\n this.setPage({ pageNumber, forceChange: true });\n this.scrollToTop();\n },\n\n /**\n * Selects or deselects all items on a page\n */\n onSelectPage(value) {\n this.$emit('select-all', value);\n\n if (value) {\n const items = Array.from(new Set([...this.selectedItems, ...this.paginated]));\n\n this.selectedItems = this.selectItems(items);\n } else {\n this.selectedItems = this.selectedItems.filter((item) => !this.paginatedIds.includes(item[this.itemTrackBy]));\n }\n },\n\n selectAll() {\n this.selectedItems = this.selectItems(this.results);\n },\n\n /**\n * Selects one item\n */\n onSelectItem({ item, value }) {\n if (this.isItemDisabled(item)) {\n return;\n }\n\n if (value) {\n this.selectedItems.push(item);\n } else {\n this.selectedItems = this.selectedItems.filter(\n (selectedItem) => selectedItem[this.itemTrackBy] !== item[this.itemTrackBy],\n );\n }\n },\n\n /**\n * Clears current selected items\n */\n clearSelected() {\n this.$emit('deselect-all');\n this.selectedItems = [];\n },\n\n selectItems(items) {\n return items.reduce((acc, item) => (this.isItemDisabled(item) ? acc : [...acc, item]), []);\n },\n },\n };\n</script>\n\n<template>\n <div>\n <div\n v-if=\"showPrimaryControls || showSecondaryControls\"\n ref=\"scrollTarget\"\n class=\"tw-mb-6\"\n :class=\"{ 'tw-ll-grid': showPrimaryControls && showSecondaryControls }\"\n >\n <div\n v-if=\"showPrimaryControls\"\n class=\"controls\"\n :class=\"[$style['legacy-box'], { 'tw-col-span-12 lg:tw-col-span-6': showSecondaryControls }]\"\n data-test=\"filters|controls\"\n >\n <div class=\"tw-ll-grid tw-grid-cols-4 md:tw-grid-cols-8 lg:tw-grid-cols-12\">\n <!-- Search -->\n <Input\n v-if=\"internalSearchSchema.isSearchable\"\n ref=\"search-input\"\n v-model=\"searchTerm\"\n class=\"tw-col-span-3 md:tw-col-span-4\"\n data-test=\"input|search-input\"\n :class=\"[$style['search-input'], { 'lg:tw-col-span-8': showSecondaryControls }]\"\n :hint-text=\"internalSearchSchema.hintText\"\n :label=\"searchText\"\n :placeholder=\"internalSearchSchema.placeholder\"\n @keyup.enter=\"!isLoading && onSearch()\"\n @change=\"onSearchTermChange\"\n >\n <template #append>\n <button\n v-if=\"searchTerm\"\n data-test=\"button|clear-search\"\n :class=\"$style['clear-button']\"\n :disabled=\"isLoading\"\n @click=\"clearSearchTerm\"\n >\n <Icon name=\"close\" />\n </button>\n <Button\n data-test=\"button|search-button\"\n :disabled=\"isLoading\"\n :class=\"$style['search-button']\"\n @click=\"onSearch\"\n >\n <Icon\n :class=\"{ 'tw-animate-spin tw-text-teal-500': isFiltering }\"\n :name=\"isFiltering ? 'working' : 'search'\"\n />\n </Button>\n </template>\n </Input>\n\n <!-- Filter Toggle -->\n <div\n v-if=\"filterSchema.length\"\n class=\"tw-col-span-1 tw-flex tw-items-end\"\n :class=\"[\n $style['filter-toggle-btn'],\n { [$style['filter-toggle-btn-with-hint-text']]: !!internalSearchSchema.hintText },\n ]\"\n >\n <Badge :content=\"numberOfFilters\">\n <Button\n secondary\n class=\"tw-relative tw-w-full tw-min-w-auto\"\n color=\"blue\"\n data-test=\"button|toggle-filters\"\n :disabled=\"isFiltering\"\n @click=\"onFiltersToggleClick\"\n >\n <Icon\n v-if=\"isFiltering\"\n name=\"working\"\n :class=\"[\n { 'tw-animate-spin': isFiltering },\n isShowingFilters ? 'tw-text-teal-500' : 'tw-text-ice-700',\n ]\"\n />\n <Icon v-else name=\"filter-line\" />\n {{ filterText }}\n </Button>\n </Badge>\n </div>\n\n <!-- Actions -->\n <div class=\"button-grid tw-col-span-1 tw-items-end tw-justify-end lg:tw-col-span-3\">\n <slot name=\"actions\"> </slot>\n </div>\n </div>\n\n <!-- Filters -->\n <Expand data-test=\"filters|content\" :class=\"$style['filters-expand']\" :is-expanded=\"isShowingFilters\">\n <div class=\"tw-relative tw-pt-12\" :class=\"$style['filters-wrapper']\">\n <Filters\n ref=\"llFilters\"\n :class=\"{ [$style['filters-half-width']]: showPrimaryControls && showSecondaryControls }\"\n :disable-apply=\"isLoading\"\n :disable-clear=\"isLoading || !numberOfFilters\"\n :disable-persistency=\"disablePersistency\"\n :schema=\"filterSchema\"\n :validation-schema=\"validationSchema\"\n @change=\"filters = $event\"\n @reset=\"reset\"\n @submit=\"onFilter\"\n />\n </div>\n </Expand>\n </div>\n\n <div\n v-if=\"showSecondaryControls\"\n class=\"secondary-controls\"\n :class=\"[$style['legacy-box'], { 'tw-col-span-12 tw-mt-0 lg:tw-col-span-6': showPrimaryControls }]\"\n >\n <slot name=\"secondary-controls\"></slot>\n </div>\n </div>\n\n <!-- @slot Renders custom content in the space below the filters and above the list -->\n <slot name=\"eyebrow\"></slot>\n\n <div\n v-if=\"shouldShowTotal || Object.keys(sorts).length\"\n class=\"tw-mb-1.5\"\n :class=\"shouldShowTotal ? $style['total-sort'] : 'tw-text-right'\"\n >\n <div v-if=\"shouldShowTotal\" class=\"tw-text-xs\">{{ total }}</div>\n\n <!-- Sort -->\n <Dropdown\n v-if=\"Object.keys(sorts).length\"\n :class=\"$style.dropdown\"\n :label=\"`${sortLabel} ${sortTerm}`\"\n @toggle.once=\"onSortToggle\"\n >\n <ul ref=\"sortOptions\" class=\"dropdown__list\" :style=\"{ minWidth: sortOptionsWidth }\">\n <li\n v-for=\"(sortOption, index) in Object.keys(sorts)\"\n :key=\"index\"\n :class=\"{ 'tw-bg-blue-100 tw-text-ice-700': sortOption === sortTerm }\"\n class=\"dropdown__item tw-rounded\"\n >\n <Button inline class=\"tw-items-center\" :class=\"$style['sort-option']\" @click=\"onSort(sortOption)\">\n {{ sortOption }}\n <Icon v-if=\"sortOption === sortTerm\" name=\"check\" class=\"tw-ml-auto tw-text-blue-500\" />\n </Button>\n </li>\n </ul>\n </Dropdown>\n </div>\n\n <!-- Defined Slots -->\n <div v-if=\"useDefinedSlots\" :class=\"$style['list-items']\">\n <header\n v-sticky=\"headerOffset\"\n data-test=\"header|defined-slot\"\n :class=\"[\n $style.header,\n {\n 'tw-m-0': !isSelectable,\n },\n ]\"\n class=\"tw-rounded\"\n >\n <div :class=\"$style['header-grid-container']\" class=\"tw-border-b tw-border-ice-200 tw-px-3\">\n <Checkbox\n v-if=\"isSelectable\"\n class=\"tw-ml-3\"\n :checked=\"isSomePageChecked\"\n :class=\"$style['select-all']\"\n :indeterminate=\"isSomePageChecked && !isAllPageChecked\"\n @update:checked=\"onSelectPage\"\n />\n <div class=\"tw-ll-grid tw-flex-1\" :class=\"$style['header-grid']\">\n <slot name=\"list-header\"> </slot>\n </div>\n </div>\n\n <!-- Select Bar -->\n <BulkActions\n v-if=\"isSelectable\"\n v-bind=\"{\n allowSelectAll: !hideSelectAll && !isServerSide,\n isAllPageChecked,\n isSomePageChecked,\n totalCount,\n totalSelectedCount,\n hideBulkActionOptions,\n hideNumberOfTotalSelected,\n }\"\n :class=\"!isSelectBarVisible && 'lg:tw-hidden'\"\n @change:clear-selected=\"clearSelected\"\n @change:select-current=\"onSelectPage\"\n @change:select-all=\"selectAll\"\n >\n <template #bulk-actions-content>\n <slot name=\"bulk-actions\" :selected-items=\"selectedItems\"> </slot>\n </template>\n </BulkActions>\n </header>\n\n <component\n :is=\"disableLoader ? 'div' : 'LoadingManager'\"\n :empty-state-text=\"emptyStateText\"\n :loading=\"isLoading\"\n :results=\"paginated\"\n >\n <slot\n name=\"list-items\"\n :clear-all=\"clearSelected\"\n :display-items=\"results\"\n :is-filtered=\"isFiltered\"\n :is-item-disabled=\"isItemDisabled\"\n :results=\"paginated\"\n :on-select=\"onSelectItem\"\n :selected-items=\"selectedItems\"\n ></slot>\n </component>\n </div>\n\n <!-- Default Slot -->\n <slot\n :current-page=\"currentPage\"\n :display-items=\"results\"\n :filters=\"filters\"\n :is-filtered=\"isFiltered\"\n :is-item-disabled=\"isItemDisabled\"\n :results=\"paginated\"\n :search-term=\"searchTerm\"\n :total=\"totalCount\"\n ></slot>\n\n <!-- Pagination -->\n <Paginate\n v-if=\"totalCount > pageSize\"\n :current-page=\"currentPage\"\n :list-length=\"totalCount\"\n :page-size=\"pageSize\"\n @set-page=\"onPaginateSetPage\"\n />\n </div>\n</template>\n\n<style module>\n .list-items {\n background-color: var(--color-ice-200);\n border-bottom-left-radius: theme('borderRadius.DEFAULT');\n border-bottom-right-radius: theme('borderRadius.DEFAULT');\n min-width: 100%;\n position: relative;\n }\n\n @media screen('lg') {\n .list-items {\n @apply tw-shadow;\n }\n }\n\n /* the .legacy-box styles are copied from .box in _box.scss */\n .legacy-box {\n @apply tw-shadow;\n\n background: var(--color-white);\n border-radius: theme('borderRadius.DEFAULT');\n padding: theme('spacing.6') var(--grid-gutter);\n }\n\n .header {\n background-color: var(--color-white);\n color: var(--color-ice-900);\n font-weight: 500;\n margin-bottom: theme('spacing.3');\n overflow: hidden;\n z-index: 1;\n\n &:global(.is-sticky) {\n @apply tw-shadow;\n\n border-radius: 0;\n overflow: visible;\n z-index: calc(theme('zIndex.control') + 1);\n\n &::before,\n &::after {\n background-color: var(--color-white);\n content: '';\n height: 100%;\n overflow-x: hidden;\n position: absolute;\n right: 100%;\n top: 0;\n width: theme('spacing.3');\n\n @media screen('lg') {\n content: none;\n }\n }\n\n &::after {\n left: 100%;\n right: auto;\n }\n }\n\n :global(.input--checkbox) {\n label {\n min-height: theme('spacing.6');\n }\n }\n\n @media screen('lg') {\n border-bottom-left-radius: 0;\n border-bottom-right-radius: 0;\n margin-bottom: 0;\n }\n }\n\n .header-grid-container {\n display: none;\n transition: padding theme('transitionDuration.150') theme('transitionTimingFunction.swing');\n\n @media screen('lg') {\n align-items: center;\n display: flex;\n }\n }\n\n .header-grid {\n column-gap: 0 !important;\n grid-column-gap: 0 !important;\n\n > div {\n align-items: center;\n border-right: 1px solid var(--color-ice-200);\n display: flex;\n font-size: theme('fontSize.xs');\n justify-content: space-between;\n padding: theme('spacing.3');\n\n &:first-of-type {\n margin-left: calc(-1 * theme('spacing.3'));\n padding-left: theme('spacing.6');\n }\n\n &:last-of-type {\n border-right: 0;\n margin-right: calc(-1 * theme('spacing.3'));\n }\n }\n }\n\n .search-input {\n :global(input) {\n /* to prevent search text from overlapping the \"Clear\" button */\n padding-right: calc(theme('height.input') * 2) !important;\n }\n\n :global(.stash-input-append) {\n display: flex;\n justify-content: flex-end;\n width: 72px; /* double the the default width of 36px */\n\n .clear-button {\n color: var(--color-ice-700);\n height: 36px;\n margin: 0;\n min-width: 36px;\n padding: 0;\n width: 36px;\n\n &:disabled {\n color: var(--color-ice-500);\n cursor: default;\n }\n }\n\n .search-button {\n border-bottom-left-radius: 0;\n border-color: var(--color-blue-500);\n border-left: none;\n border-top-left-radius: 0;\n min-width: 36px;\n padding: 0 theme('spacing[1.5]');\n width: 36px;\n\n &:disabled {\n border-color: var(--color-ice-500);\n }\n }\n }\n }\n\n @media screen('md') {\n .total-sort {\n align-items: baseline;\n display: flex;\n justify-content: space-between;\n }\n }\n\n .filter-toggle-btn {\n min-width: fit-content !important; /* ensure this overrides the grid min-width applied */\n }\n\n .filter-toggle-btn-with-hint-text {\n /* search hint text has 16px of height and has 4px of margin top. Adding here directly to compensate that */\n margin-bottom: 20px;\n }\n\n @keyframes separator {\n 0% {\n opacity: 0;\n }\n\n 100% {\n opacity: 1;\n }\n }\n\n .filters-expand:global(.stash-expand--expanded) {\n .filters-wrapper::before {\n animation: separator theme('transitionDuration.300') theme('transitionTimingFunction.ease-in-out') 0.5s 1 forwards;\n background: var(--color-ice-200);\n content: '';\n height: theme('borderWidth.DEFAULT');\n left: calc(var(--grid-gutter) * -1);\n opacity: 0;\n position: absolute;\n right: calc(var(--grid-gutter) * -1);\n top: theme('spacing.6');\n }\n }\n\n .filters-half-width {\n @media screen('lg') {\n :global(.field-wrapper) {\n grid-column: span 6 / span 6; /* col-span-6 */\n }\n }\n }\n\n .dropdown :global(.tw-text-blue-500) {\n font-size: theme('fontSize.xs');\n }\n\n .sort-option {\n height: theme('spacing.9');\n }\n\n .select-all {\n width: theme('spacing.6');\n }\n</style>\n"],"names":["_sfc_main","Button","Checkbox","t","value","_createElementBlock","_ctx","$props","_createElementVNode","_createVNode","_component_ll_checkbox","_normalizeClass","$options","_openBlock","_hoisted_1","_hoisted_2","_toDisplayString","_createBlock","_component_ll_button","_hoisted_3","_renderSlot","EmptyState","Loading","_component_Loading","_TransitionGroup","_component_EmptyState","Expand","Icon","sticky","isExpanded","getCssVar","CSS_VARS","$data","args","_component_Icon","_component_Expand","_component_ll_icon","DEFAULT_SEARCH_SCHEMA","BulkActions","Filters","Paginate","LoadingManager","Badge","Dropdown","Input","_a","persistentStorage","paginated","endIndex","totalCount","results","startIndex","current","range","item","id","acc","filterBy","isBoolean","isToggle","isEmpty","isInputOptionsIncomplete","cloneDeep","searchFor","useSearch","computed","searchTerm","sortTerms","actionResponse","items","_filterItems","_sortItems","trigger","currentPage","filters","isFiltered","pageSize","sortTerm","params","_b","LLLV_CHANGE_TRIGGERS","term","pageNumber","forceChange","selectedItem","_component_Input","$event","_cache","_withKeys","_component_Button","_component_Badge","_createTextVNode","_component_Filters","_hoisted_4","_component_Dropdown","_Fragment","_renderList","sortOption","index","_component_Checkbox","_component_BulkActions","_mergeProps","_resolveDynamicComponent","_component_Paginate"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"ListView.js","sources":["../src/components/ListView/components/BulkActions.vue","../src/components/ListView/components/LoadingManager.vue","../src/components/ListView/components/ListGroup.vue","../src/components/ListView/components/ListHeader.vue","../src/components/ListView/ListView.vue"],"sourcesContent":["<script>\n import { t } from '../../../locale';\n import Button from '../../Button/Button.vue';\n import Checkbox from '../../Checkbox/Checkbox.vue';\n\n export default {\n name: 'bulk-actions',\n\n components: {\n 'll-button': Button,\n 'll-checkbox': Checkbox,\n },\n\n props: {\n allowSelectAll: Boolean,\n isAllPageChecked: Boolean,\n isSomePageChecked: Boolean,\n hideBulkActionOptions: Boolean,\n hideNumberOfTotalSelected: Boolean,\n totalCount: {\n type: Number,\n default: 0,\n },\n totalSelectedCount: {\n type: Number,\n default: 0,\n },\n },\n\n emits: ['change:select-current', 'change:select-all', 'change:clear-selected'],\n\n data: function () {\n return {\n selectAllText: t('ll.listView.selectAll'),\n };\n },\n\n computed: {\n clearSelectedText() {\n if (this.allowSelectAll) {\n return t('ll.listView.deselectAllCount', { count: this.totalCount });\n }\n\n return t('ll.listView.clearSelection');\n },\n\n showSelectAll() {\n return [this.totalSelectedCount !== this.totalCount, this.allowSelectAll].every(Boolean);\n },\n\n numberOfTotalSelectedText() {\n return t('ll.listView.numberOfTotalSelected', {\n num: this.totalSelectedCount,\n total: this.totalCount,\n });\n },\n\n selectAllCountText() {\n return t('ll.listView.selectAllCount', { count: this.totalCount });\n },\n\n numItemsSelectedText() {\n return t('ll.listView.numItemsSelected', {\n totalSelectedCount: this.totalSelectedCount,\n totalCount: this.totalCount,\n });\n },\n },\n\n methods: {\n onSelectPage(value) {\n this.$emit('change:select-current', value);\n },\n\n selectAll() {\n this.$emit('change:select-all');\n },\n\n clearSelected() {\n this.$emit('change:clear-selected');\n },\n },\n };\n</script>\n\n<template>\n <div\n class=\"lg:tw-flex\"\n :class=\"[\n $style['select-bar'],\n {\n 'lg:tw-hidden': hideBulkActionOptions,\n },\n 'tw-p-3',\n ]\"\n >\n <div\n class=\"tw-flex tw-items-center\"\n :class=\"{\n 'tw-justify-between': !hideBulkActionOptions,\n }\"\n >\n <ll-checkbox\n data-test=\"checkbox|bulk-actions\"\n :class=\"$style.checkbox\"\n class=\"tw-m-0 lg:tw-hidden\"\n :checked=\"isSomePageChecked && !!totalCount\"\n :indeterminate=\"isSomePageChecked && !isAllPageChecked\"\n :label=\"!totalSelectedCount ? selectAllText : ''\"\n @update:checked=\"onSelectPage\"\n />\n <div\n v-if=\"!!totalSelectedCount && !hideBulkActionOptions\"\n class=\"tw-flex tw-flex-1 tw-items-center tw-justify-between\"\n >\n <div v-if=\"!hideNumberOfTotalSelected\" class=\"tw-text-xs\">\n {{ numberOfTotalSelectedText }}\n </div>\n <div :class=\"{ 'tw-ml-3': !hideNumberOfTotalSelected }\">\n <ll-button v-if=\"showSelectAll\" inline @click=\"selectAll\">{{ selectAllCountText }}</ll-button>\n <ll-button v-else inline @click=\"clearSelected\">\n {{ clearSelectedText }}\n </ll-button>\n </div>\n </div>\n <div v-else-if=\"hideBulkActionOptions && !!totalSelectedCount\" class=\"tw-ml-1.5 lg:tw-hidden\">\n <h4>{{ numItemsSelectedText }}</h4>\n </div>\n </div>\n <div v-if=\"!!totalSelectedCount && !hideBulkActionOptions\" :class=\"$style.actions\">\n <slot name=\"bulk-actions-content\"></slot>\n </div>\n </div>\n</template>\n\n<style module>\n .select-bar {\n @media screen('lg') {\n border-bottom: 1px solid var(--color-ice-200);\n justify-content: center;\n vertical-align: middle;\n }\n }\n\n .checkbox {\n flex: 0 0 auto;\n }\n\n .actions > * {\n margin-top: theme('spacing.6');\n width: 100%;\n\n @media screen('lg') {\n margin-left: theme('spacing.3');\n margin-top: 0;\n width: auto;\n }\n }\n</style>\n","<script>\n import EmptyState from '../../EmptyState/EmptyState.vue';\n import Loading from '../../Loading/Loading.vue';\n\n export default {\n name: 'loading-manager',\n\n components: {\n EmptyState,\n Loading,\n },\n\n props: {\n emptyStateText: {\n type: String,\n default: '',\n },\n\n loading: Boolean,\n\n results: {\n type: Array,\n default: () => [],\n },\n },\n };\n</script>\n\n<template>\n <Loading v-if=\"loading\" class=\"tw-bg-white\" />\n <transition-group v-else-if=\"results.length\" name=\"slide-y\" tag=\"ul\">\n <slot></slot>\n </transition-group>\n <EmptyState v-else class=\"tw-bg-white\" :class=\"$style['empty-state']\" :text=\"emptyStateText\" />\n</template>\n\n<style module>\n .empty-state {\n max-width: 100%;\n }\n</style>\n","<script>\n import { CSS_VARS } from '../../../constants';\n import sticky from '../../../directives/sticky/sticky';\n import { getCssVar } from '../../../utils/helpers';\n import Button from '../../Button/Button.vue';\n import Expand from '../../Expand/Expand.vue';\n import Icon from '../../Icon/Icon.vue';\n\n export default {\n name: 'list-group',\n\n components: {\n Expand,\n 'll-button': Button,\n Icon,\n },\n\n directives: {\n sticky,\n },\n\n props: {\n /**\n * Disables the gutters between adjacent ListGroup components.\n */\n disableExternalGutters: {\n type: Boolean,\n default: false,\n },\n\n /**\n * Allows the list items to be collapsed\n */\n isCollapsible: {\n type: Boolean,\n default: false,\n },\n\n /**\n * Allows the expanded content to be collapsed by default.\n * Note: has no effect unless the `isCollapsible` prop is `true`.\n */\n isCollapsedByDefault: {\n type: Boolean,\n default: false,\n },\n },\n\n data() {\n const isExpanded = !this.isCollapsible || !this.isCollapsedByDefault;\n\n return {\n isExpanded,\n isDoneExpanding: isExpanded,\n };\n },\n\n computed: {\n headerOffset() {\n return parseFloat(getCssVar(CSS_VARS.TOP_HEADER_HEIGHT));\n },\n },\n\n methods: {\n toggleExpand() {\n if (!this.isCollapsible) {\n return;\n }\n\n this.isExpanded = !this.isExpanded;\n\n if (!this.isExpanded) {\n this.isDoneExpanding = false;\n } // else wait for Expand to emit @after-expand\n },\n\n onHeaderClick(e) {\n // toggle the ListGroup, except when clicking the actions\n if (!this.$refs.actionsContainer.contains(e.target)) {\n this.toggleExpand();\n }\n },\n },\n };\n</script>\n\n<template>\n <div\n :class=\"[\n $style['list-group'],\n {\n 'disable-external-gutters': disableExternalGutters,\n 'is-collapsed': !isExpanded,\n },\n ]\"\n >\n <header\n class=\"tw-flex tw-items-center\"\n :class=\"[$style['main-header'], { 'tw-cursor-pointer': isCollapsible }]\"\n @click=\"onHeaderClick\"\n >\n <ll-button v-if=\"isCollapsible\" :class=\"['tw-mr-1.5 tw-text-ice-900', $style['expansion-toggle-button']]\" icon>\n <Icon :class=\"[isExpanded ? 'tw-rotate-270' : 'rotate-180']\" name=\"chevron-left\" />\n </ll-button>\n\n <div class=\"tw-flex-auto\">\n <slot name=\"title\"></slot>\n </div>\n\n <div ref=\"actionsContainer\">\n <slot name=\"actions\"></slot>\n </div>\n </header>\n\n <Expand :is-expanded=\"isExpanded\" @after-expand=\"isDoneExpanding = true\">\n <div :class=\"$style['expanded-content-wrapper']\">\n <header\n v-if=\"$slots['expanded-content-list-header']\"\n v-sticky=\"isExpanded && isDoneExpanding ? headerOffset : 0\"\n :class=\"$style['expanded-content-header']\"\n >\n <div class=\"tw-ll-grid tw-flex-1\" :class=\"$style['expanded-content-header-grid']\">\n <slot name=\"expanded-content-list-header\"></slot>\n </div>\n </header>\n <div :class=\"$style['expanded-content-list-items-wrapper']\">\n <transition-group name=\"fade\" mode=\"out-in\">\n <slot name=\"expanded-content-list-items\"></slot>\n </transition-group>\n </div>\n </div>\n </Expand>\n </div>\n</template>\n\n<style module>\n .main-header {\n @apply tw-shadow;\n\n background-color: var(--color-white);\n border-radius: theme('borderRadius.DEFAULT');\n margin-bottom: theme('spacing.6');\n padding: var(--grid-gutter);\n\n @media screen('lg') {\n border-bottom: theme('borderWidth.DEFAULT') solid var(--color-ice-200);\n border-bottom-left-radius: 0;\n border-bottom-right-radius: 0;\n margin-bottom: 0;\n }\n }\n\n .expanded-content-wrapper {\n position: relative;\n width: 100%;\n }\n\n @media screen('lg') {\n .expanded-content-wrapper {\n @apply tw-shadow;\n }\n }\n\n .expanded-content-header {\n background-color: var(--color-white);\n border-bottom: theme('borderWidth.DEFAULT') solid var(--color-ice-200);\n color: var(--color-ice-900);\n display: none;\n font-weight: 500;\n padding: 0 theme('spacing.3');\n transition: padding theme('transitionDuration.150') theme('transitionTimingFunction.swing');\n z-index: 1;\n\n @media screen('lg') {\n align-items: center;\n display: flex;\n }\n\n &:global(.is-sticky) {\n @apply tw-shadow;\n\n border-radius: 0;\n z-index: calc(theme('zIndex.control') + 1);\n }\n }\n\n .expanded-content-header-grid {\n column-gap: 0;\n grid-column-gap: 0;\n\n > div {\n align-items: center;\n border-right: theme('borderWidth.DEFAULT') solid var(--color-ice-200);\n display: flex;\n font-size: theme('fontSize.xs');\n justify-content: space-between;\n padding: theme('spacing.3');\n\n &:last-of-type {\n border-right: 0;\n }\n }\n }\n\n .expansion-toggle-button:focus {\n box-shadow: none;\n }\n\n .list-group:global(.disable-external-gutters) {\n .main-header {\n @media screen('lg') {\n border-radius: 0;\n }\n }\n\n .expanded-content-list-items-wrapper > * {\n @media screen('lg') {\n border-bottom: theme('borderWidth.DEFAULT') solid var(--color-ice-200);\n border-radius: 0;\n }\n }\n\n &:last-of-type {\n &:global(.is-collapsed) .main-header,\n .expanded-content-list-items-wrapper > *:last-child {\n @media screen('lg') {\n border-bottom: none;\n border-bottom-left-radius: theme('borderRadius.DEFAULT');\n border-bottom-right-radius: theme('borderRadius.DEFAULT');\n }\n }\n }\n }\n</style>\n","<script>\n import Icon from '../../Icon/Icon.vue';\n\n export default {\n name: 'list-header',\n\n components: {\n 'll-icon': Icon,\n },\n\n props: {\n /**\n * keys to be sorted for the column\n * the first key should be the default sort value\n */\n sortKeys: {\n type: Array,\n required: true,\n validator: (value) => value.length === 2,\n },\n\n listViewRef: {\n type: Object,\n default: null,\n },\n },\n\n data() {\n return {\n isAscending: null,\n };\n },\n\n computed: {\n listViewInstance() {\n return this.listViewRef || this.$parent;\n },\n /**\n * Is the column currently sorted\n */\n isSorted() {\n return this.sortKeys.includes(this.listViewInstance.sortTerm);\n },\n\n /**\n * Show the top icon if it's not sorted or if the current sortTerm matches\n */\n showCaretUp() {\n return this.isAscending === null || this.sortKeys[0] === this.listViewInstance.sortTerm;\n },\n\n /**\n * Show the bottom icon if it's not sorted or if the current sortTerm matches\n */\n showCaretDown() {\n return this.isAscending === null || this.sortKeys[1] === this.listViewInstance.sortTerm;\n },\n },\n\n watch: {\n isSorted: {\n handler(value) {\n this.isAscending = value ? true : null;\n },\n immediate: true,\n },\n },\n\n methods: {\n /**\n * Sorts the column by the sort field\n */\n sort() {\n this.listViewInstance.onSort(this.sortKeys[this.isAscending ? 1 : 0]);\n this.isAscending = !this.isAscending;\n },\n },\n };\n</script>\n\n<template>\n <div :class=\"['tw-cursor-pointer', { 'tw-bg-blue-100': isSorted }]\" @click=\"sort\">\n <slot></slot>\n <div class=\"h-4 w-3 tw-relative tw-text-ice-700\" :class=\"{ 'is-active-sort': isSorted }\">\n <ll-icon\n v-if=\"showCaretUp\"\n name=\"caret-up\"\n class=\"tw-absolute\"\n :class=\"[$style.caret, $style['caret-up']]\"\n size=\"dense\"\n />\n <ll-icon\n v-if=\"showCaretDown\"\n name=\"caret-down\"\n class=\"tw-absolute\"\n :class=\"[$style.caret, $style['caret-down']]\"\n size=\"dense\"\n />\n </div>\n </div>\n</template>\n\n<style module>\n .caret-up {\n top: -5px;\n }\n\n .caret-down {\n top: 2px;\n }\n\n :global(.is-active-sort) .caret {\n top: -2px; /* vertically center the caret icon */\n }\n</style>\n","<script>\n import cloneDeep from 'lodash-es/cloneDeep';\n import { computed } from 'vue';\n\n import useSearch from '../../composables/useSearch/useSearch';\n import { CSS_VARS, LLLV_CHANGE_TRIGGERS } from '../../constants';\n import sticky from '../../directives/sticky/sticky';\n import { t } from '../../locale';\n import { persistentStorage } from '../../storage';\n import { filterItems as _filterItems, getCssVar, sortItems as _sortItems } from '../../utils/helpers';\n import Badge from '../Badge/Badge.vue';\n import Button from '../Button/Button.vue';\n import Checkbox from '../Checkbox/Checkbox.vue';\n import Dropdown from '../Dropdown/Dropdown.vue';\n import Expand from '../Expand/Expand.vue';\n import Filters from '../Filters/Filters.vue';\n import Icon from '../Icon/Icon.vue';\n import Input from '../Input/Input.vue';\n import Paginate from '../Paginate/Paginate.vue';\n import BulkActions from './components/BulkActions.vue';\n import LoadingManager from './components/LoadingManager.vue';\n\n export { default as BulkActions } from './components/BulkActions.vue';\n export { default as ListGroup } from './components/ListGroup.vue';\n export { default as ListHeader } from './components/ListHeader.vue';\n export { default as LoadingManager } from './components/LoadingManager.vue';\n\n const DEFAULT_SEARCH_SCHEMA = {\n isSearchable: true,\n placeholder: 'Search',\n searchBy: ['name'],\n };\n\n export default {\n name: 'll-list-view',\n\n components: {\n BulkActions,\n Filters,\n Paginate,\n LoadingManager,\n Badge,\n Button,\n Icon,\n Dropdown,\n Expand,\n Checkbox,\n Input,\n },\n\n directives: {\n sticky,\n },\n\n inject: {\n trackSearch: { default: () => () => {} },\n trackFilters: { default: () => () => {} },\n trackSort: { default: () => () => {} },\n trackResults: { default: () => () => {} },\n },\n\n props: {\n /**\n * Hide the '{number} of {total} selected' text for bulk actions\n */\n hideNumberOfTotalSelected: {\n type: Boolean,\n default: false,\n },\n /**\n * Hide the Select All checkbox for bulk actions\n */\n hideSelectAll: {\n type: Boolean,\n default: false,\n },\n /**\n * Text to render in EmptyState component if there are no results\n */\n emptyStateText: {\n type: String,\n default: '',\n },\n filterSchema: {\n type: Array,\n default: () => [],\n },\n /**\n * Make search fuzzy. Only for client side search.\n */\n fuzzySearch: {\n type: Boolean,\n default: false,\n },\n hideTotal: Boolean,\n initialPage: {\n type: Number,\n default: undefined,\n },\n /**\n * Can items on the page be selected for bulk actions\n */\n isSelectable: Boolean,\n /**\n * For loading data already paginated, filtered (including search), and sorted from a backend.\n * Defining this prop will disable the built-in search, filtering, sorting and pagination.\n * You will instead need to use the available events (`@change`, and `@change:` prefixed)\n * to know when to request new pages from your backend.\n * This requires providing `totalItemCount`.\n * Use the loading prop to indicate when data is being loaded.\n */\n isServerSide: Boolean,\n /**\n * The data for each row. Used in this file as this.internalItems (a copy) to allow mutation;\n */\n items: {\n type: Array,\n default: () => [],\n },\n /**\n * Default field to track selected items by\n */\n itemTrackBy: {\n type: String,\n default: 'id',\n },\n loading: Boolean,\n // Number of items to display per page\n pageSize: {\n type: Number,\n default: 50,\n },\n searchSchema: {\n type: Object,\n default: () => ({}),\n },\n // Provide an optional custom 'Sort by' label\n sortLabel: {\n type: String,\n default: () => t('ll.listView.sortBy'),\n },\n sortOnLoad: Boolean,\n sorts: {\n type: Object,\n default: () => ({}),\n },\n /**\n * Total number of unpaginated results\n * Required when `isServerSide` is `true`\n */\n totalItemCount: {\n type: Number,\n default: undefined,\n },\n /**\n * Validation schema function that returns an object\n */\n validationSchema: {\n type: Function,\n default: () => () => undefined,\n },\n /**\n * Whether to disable the sticky filters\n * if disabled, the following will happen\n * 1. pre-selected value(s) can be added to\n * the filter component's attributes to overwrite the sticky filters\n * 2. users will not have sticky filters on the page\n */\n disablePersistency: Boolean,\n /**\n * Whether to disable the ability of saving 'show-filters'\n * in local storage\n */\n disableShowFilter: Boolean,\n /**\n * Whether to disable the stickiness of the header.\n * Default is false. When true, neither the list headers nor\n * the bulk actions (when applicable) will be sticky.\n */\n disableStickyHeader: Boolean,\n /**\n * Whether to expand the filters section by default on load.\n */\n showFiltersOnLoad: Boolean,\n\n /**\n * Do not use the LoadingManager, and instead render the default slot as passed\n */\n disableLoader: {\n type: Boolean,\n default: false,\n },\n\n /**\n * Override the header offset used to position the sticky header\n */\n stickyHeaderOffset: {\n type: Number,\n default: null,\n },\n /**\n * Prevent bulk actions dropdown from rendering\n */\n hideBulkActionOptions: {\n type: Boolean,\n default: false,\n },\n\n /**\n * If initial search term is provided, the list will be filtered on load.\n */\n initialSearchTerm: {\n type: String,\n default: '',\n },\n\n /**\n * Function that determines whether the item checkbox is disabled or not (default: false)\n */\n isItemDisabled: {\n type: Function,\n default: () => false,\n },\n },\n\n emits: [\n 'change',\n 'change:filter',\n 'change:page',\n 'change:search',\n 'change:sort',\n 'change:reset',\n 'filters-toggle-click',\n 'select-all',\n 'deselect-all',\n 'update-filters',\n 'updateResults',\n ],\n\n data() {\n return {\n internalItems: [],\n currentPage: this.initialPage || 1, // TODO: fetch from query params\n previousPage: null,\n sortOptionsWidth: 0,\n filters: {},\n filterText: t('ll.filter'),\n searchFor: () => {}, // initialized in the watch handler for internalItems\n searchTerm: this.initialSearchTerm,\n searchText: t('ll.search'),\n sortTerm: '',\n isLoadingSearchSchemaAction: false,\n isShowingFilters: !!(\n this.filterSchema?.length &&\n (this.showFiltersOnLoad || persistentStorage.get('show-filters'))\n ),\n isFiltering: false,\n results: [],\n selectedItems: [],\n };\n },\n\n computed: {\n /**\n * Returns true if any of its list items are truthy; otherwise returns false.\n * @returns {boolean}\n */\n isLoading() {\n return [this.loading, this.isLoadingSearchSchemaAction, this.isFiltering].some(Boolean);\n },\n\n totalCount() {\n return this.isServerSide ? this.totalItemCount : this.results.length;\n },\n\n /**\n * Helps determine if the list is filtered or not when there is an incomplete\n * result list, such as when isServerSide is true.\n */\n isFiltered() {\n return !!(this.numberOfFilters || this.searchTerm);\n },\n\n /**\n * Merges the searchSchema with the default value since all attributes are optional\n */\n internalSearchSchema() {\n return {\n ...DEFAULT_SEARCH_SCHEMA,\n searchBy: !this.searchSchema.isSearchable && DEFAULT_SEARCH_SCHEMA.searchBy,\n ...this.searchSchema,\n };\n },\n\n /**\n * Start of page\n */\n startIndex() {\n return this.pageSize * (this.currentPage - 1);\n },\n\n /**\n * End of page\n */\n endIndex() {\n return this.startIndex + this.pageSize;\n },\n\n /**\n * Slices the results set into a paginated segment.\n * @returns One page in the paginated set of results\n */\n paginated() {\n // Disables the built-in client-side pagination\n let paginated;\n\n if (this.isServerSide) {\n paginated = this.results;\n } else {\n const { endIndex, totalCount, results, startIndex } = this;\n\n paginated = results.slice(startIndex, Math.min(endIndex, totalCount));\n }\n\n this.$emit('updateResults', paginated);\n\n return paginated;\n },\n\n /**\n * Displays a visual indication for the number of results, or \"working\" if the\n * results are being determined.\n */\n total() {\n const current = this.pageSize * (this.currentPage - 1);\n const range = this.paginated.length ? `${current + 1} - ${current + this.paginated.length}` : 0;\n\n return this.isLoading\n ? t('ll.listView.calculating')\n : t('ll.listView.totalResults', { num: String(range), total: String(this.totalCount) });\n },\n\n /**\n * Determines if both #list-header and #list-items slots are used.\n * @returns {boolean}\n */\n useDefinedSlots() {\n return !!this.$slots['list-header'] && !!this.$slots['list-items'];\n },\n\n /**\n * Don't show total count if list items are selected and total is not hidden\n */\n shouldShowTotal() {\n return !this.totalSelectedCount && !this.hideTotal;\n },\n\n /**\n * Returns a list of the selected items' track by field\n */\n selectedItemIds() {\n return this.selectedItems.map((item) => item[this.itemTrackBy]);\n },\n\n /**\n * Returns a list of the paginated items' track by field\n */\n paginatedIds() {\n return this.paginated.map((item) => item[this.itemTrackBy]);\n },\n\n isAllPageChecked() {\n if (this.isServerSide) {\n return this.totalCount > 0 && this.totalCount === this.selectedItemIds.length;\n }\n\n return this.totalCount > 0 && this.paginatedIds.every((id) => this.selectedItemIds.includes(id));\n },\n\n isSomePageChecked() {\n if (this.isServerSide) {\n return this.totalCount > 0 && this.selectedItemIds.length > 0;\n }\n\n return this.totalCount > 0 && this.paginatedIds.some((id) => this.selectedItemIds.includes(id));\n },\n\n numberOfFilters() {\n return Object.keys(this.filters).reduce((acc, item) => {\n const filterBy = this.filters[item].filterBy;\n const isBoolean = typeof filterBy[0] === 'boolean';\n const isToggle = this.filters[item].filterType === 'll-checkbox';\n const isEmpty = !this.filters[item].filterType.length;\n const isInputOptionsIncomplete = this.filters[item].filterType === 'll-input-options' && filterBy[0] === '';\n\n /**\n * Don't include hidden or incomplete fields in the count:\n * - Hidden filter populated via another filter's onChange callback\n * - InputOptions with incomplete/missing values\n */\n if (isEmpty || isInputOptionsIncomplete) {\n return acc;\n }\n\n if (isBoolean || typeof filterBy[0] === 'string') {\n // Do not count toggle filters (eg. checkbox) with a `false` value\n return acc + (filterBy[0] || !isToggle ? 1 : 0);\n }\n\n return acc + (filterBy.length || 0);\n }, 0);\n },\n\n isSelectBarVisible() {\n return !!this.totalSelectedCount;\n },\n\n showPrimaryControls() {\n return this.internalSearchSchema.isSearchable || this.filterSchema.length;\n },\n\n showSecondaryControls() {\n return !!this.$slots['secondary-controls'];\n },\n\n isSortable() {\n return Object.keys(this.sorts).length > 0;\n },\n\n totalSelectedCount() {\n return this.selectedItems.length;\n },\n\n headerOffset() {\n // passing null to the v-sticky directive will prevent it from being attached to the node\n if (this.disableStickyHeader) {\n return null;\n }\n\n return this.stickyHeaderOffset ?? parseFloat(getCssVar(CSS_VARS.TOP_HEADER_HEIGHT));\n },\n },\n\n watch: {\n isShowingFilters(value) {\n if (!this.disableShowFilter) {\n persistentStorage.set('show-filters', value);\n }\n },\n\n items: {\n handler() {\n this.internalItems = cloneDeep(this.items);\n },\n immediate: true,\n deep: true,\n },\n\n internalItems: {\n handler() {\n if (this.isServerSide) {\n this.results = this.internalItems;\n\n this.trackResults({\n page: this.currentPage,\n results: this.results,\n search: this.searchTerm,\n });\n\n return;\n }\n\n const { searchFor } = useSearch({\n items: computed(() => this.internalItems),\n fieldNames: this.internalSearchSchema.searchBy.length\n ? this.internalSearchSchema.searchBy\n : [this.displayBy],\n trackBy: this.itemTrackBy,\n });\n\n this.searchFor = (searchTerm) => searchFor(searchTerm, { fuzzy: this.fuzzySearch });\n\n this.processResults();\n },\n immediate: true,\n },\n\n sortTerm() {\n if (this.isServerSide) {\n return;\n }\n\n this.processResults();\n },\n\n sorts: {\n handler(value) {\n const sortTerms = Object.keys(value);\n\n this.sortTerm = this.sortOnLoad && sortTerms.length ? sortTerms[0] : '';\n },\n immediate: true,\n },\n },\n\n created() {\n if (this.isServerSide) {\n if (this.totalItemCount === undefined) {\n throw new Error('`totalItemCount` is required when `isServerSide` is `true`.');\n }\n\n return;\n }\n\n if (this.searchSchema.action && this.internalItems.length) {\n throw new Error('You must pass either `action` or `items`, not both.');\n }\n\n if (this.searchTerm) {\n this.onSearch();\n }\n },\n\n methods: {\n /**\n * Processes the results with searchFor, filterItems, and/or sortItems.\n * Skipped when isServerSide is true because results are pre-processed.\n * @returns {Promise<void>}\n */\n async processResults() {\n if (this.searchSchema.action) {\n this.isLoadingSearchSchemaAction = true;\n let actionResponse;\n\n try {\n actionResponse = await this.searchSchema.action({ search: this.searchTerm });\n } finally {\n this.isLoadingSearchSchemaAction = false;\n }\n\n this.results = this.sortItems(this.filterItems(actionResponse?.results || []));\n } else {\n this.results = this.sortItems(this.filterItems(this.searchFor(this.searchTerm)));\n }\n\n this.trackResults({\n page: this.currentPage,\n results: this.results,\n search: this.searchTerm,\n });\n },\n\n /**\n * Filters the list of `items` based on options selected in the `filters` object\n * @param {array} items A list of items to filter.\n * @returns list of items filtered by the applied filters\n */\n filterItems(items) {\n return _filterItems(items, this.filters);\n },\n\n /**\n * Sorts a list of items based on options selected in the `sorts` object\n * @param {array} items A list of items to sort.\n * @returns list of items sorted according to the sort term.\n */\n sortItems(items) {\n return this.sortTerm ? _sortItems(items, this.sorts[this.sortTerm]) : items;\n },\n\n change({ trigger = '' } = {}) {\n const { currentPage, filters, isFiltered, pageSize, searchTerm, sortTerm } = this;\n\n const params = {\n filters,\n isFiltered,\n page: {\n number: currentPage,\n previousNumber: this.previousPage,\n size: pageSize,\n },\n search: searchTerm,\n sort: sortTerm,\n trigger,\n };\n\n this.$emit('change', params);\n },\n\n /**\n * Clear search term and reset results to their initial state\n */\n async clearSearchTerm() {\n this.searchTerm = '';\n await this.$attrs.onSearchTermClear?.();\n this.onSearch();\n },\n\n /**\n * Resets the results to their initial state on page load\n */\n reset() {\n this.$emit('change:reset');\n\n this.searchTerm = '';\n\n this.setPage({ pageNumber: 1 });\n\n if (this.isServerSide) {\n this.change({ trigger: LLLV_CHANGE_TRIGGERS.RESET });\n\n return;\n }\n\n this.processResults();\n },\n\n onSearchTermChange() {\n this.$attrs.onSearchTermChange?.(this.searchTerm);\n },\n\n /**\n * Event handler for when the user:\n * - clicks the Search button\n * - presses the enter key while focused on the search input\n * Calls a method in Filters that triggers `this.onFilter`. This is necessary\n * in order to persist the filters in local storage, which is handled internally\n * by Filters.\n */\n onSearch() {\n this.$refs.llFilters.applyFilters({ trigger: LLLV_CHANGE_TRIGGERS.SEARCH });\n },\n\n /**\n * Event handler for when the user:\n * - clicks the Apply button\n * - clicks the Search button (from `this.onSearch`)\n * - presses the enter key while focused on the search input (from `this.onSearch`)\n * @see: SELL-350\n * @param {object} [options] - optional parameters\n * @param {string} [options.trigger] - what caused the changes\n * @returns {Promise<void>}\n */\n async onFilter({ trigger = LLLV_CHANGE_TRIGGERS.APPLY } = {}) {\n this.setPage({ pageNumber: 1 });\n this.change({ trigger });\n this.trackSearch(this.searchTerm);\n this.trackFilters(this.filters);\n this.selectedItems = [];\n\n if (this.isServerSide) {\n return;\n }\n\n try {\n this.isFiltering = true;\n await this.processResults({ trigger });\n } finally {\n this.isFiltering = false;\n }\n\n this.$emit('change:search', this.searchTerm);\n this.$emit('change:filter', this.filters);\n this.$emit('update-filters', this.filters); // deprecated; replaced by change:filter\n this.clearSelected();\n },\n\n onFiltersToggleClick() {\n this.isShowingFilters = !this.isShowingFilters;\n\n this.$emit('filters-toggle-click', {\n isShowingFilters: this.isShowingFilters,\n });\n },\n\n /**\n * Extend the dropdown list so it does not shift when\n * the options drawer is open\n */\n onSortToggle() {\n // spacing added to the width of the dropdown container\n const spacing = 36;\n\n this.$nextTick(() => {\n this.sortOptionsWidth = `${this.$refs.sortOptions.clientWidth + spacing}px`;\n });\n },\n\n /**\n * Executes any side-effects when the sort `term` is changed\n * Always fires `change` automatically.\n * @param {string} term The updated sort term\n */\n onSort(term) {\n if (term === this.sortTerm) {\n return;\n }\n\n this.sortTerm = term;\n\n this.$emit('change:sort', term);\n this.trackSort(term);\n this.clearSelected();\n this.setPage({ pageNumber: 1 });\n this.change({ trigger: LLLV_CHANGE_TRIGGERS.SORT });\n },\n\n /**\n * Sets current page for the Paginator.\n * @param {Object} data\n * @param {number} data.pageNumber - the page number\n * @param {boolean} data.forceChange - flag to force the change\n */\n setPage({ pageNumber, forceChange = false } = {}) {\n this.previousPage = this.currentPage;\n\n this.currentPage = pageNumber;\n\n if (!this.isServerSide) {\n this.$emit('change:page', pageNumber);\n }\n\n if (forceChange) {\n this.change({ trigger: LLLV_CHANGE_TRIGGERS.PAGE });\n }\n },\n\n /**\n * Set the scroll position to the top of the list view.\n */\n scrollToTop() {\n this.$refs.scrollTarget && this.$refs.scrollTarget.scrollIntoView({ behavior: 'smooth', block: 'center' });\n },\n\n onPaginateSetPage(pageNumber) {\n this.setPage({ pageNumber, forceChange: true });\n this.scrollToTop();\n },\n\n /**\n * Selects or deselects all items on a page\n */\n onSelectPage(value) {\n this.$emit('select-all', value);\n\n if (value) {\n const items = Array.from(new Set([...this.selectedItems, ...this.paginated]));\n\n this.selectedItems = this.selectItems(items);\n } else {\n this.selectedItems = this.selectedItems.filter((item) => !this.paginatedIds.includes(item[this.itemTrackBy]));\n }\n },\n\n selectAll() {\n this.selectedItems = this.selectItems(this.results);\n },\n\n /**\n * Selects one item\n */\n onSelectItem({ item, value }) {\n if (this.isItemDisabled(item)) {\n return;\n }\n\n if (value) {\n this.selectedItems.push(item);\n } else {\n this.selectedItems = this.selectedItems.filter(\n (selectedItem) => selectedItem[this.itemTrackBy] !== item[this.itemTrackBy],\n );\n }\n },\n\n /**\n * Clears current selected items\n */\n clearSelected() {\n this.$emit('deselect-all');\n this.selectedItems = [];\n },\n\n selectItems(items) {\n return items.reduce((acc, item) => (this.isItemDisabled(item) ? acc : [...acc, item]), []);\n },\n },\n };\n</script>\n\n<template>\n <div>\n <div\n v-if=\"showPrimaryControls || showSecondaryControls\"\n ref=\"scrollTarget\"\n class=\"tw-mb-6\"\n :class=\"{ 'tw-ll-grid': showPrimaryControls && showSecondaryControls }\"\n >\n <div\n v-if=\"showPrimaryControls\"\n class=\"controls\"\n :class=\"[$style['legacy-box'], { 'tw-col-span-12 lg:tw-col-span-6': showSecondaryControls }]\"\n data-test=\"filters|controls\"\n >\n <div class=\"tw-ll-grid tw-grid-cols-4 md:tw-grid-cols-8 lg:tw-grid-cols-12\">\n <!-- Search -->\n <Input\n v-if=\"internalSearchSchema.isSearchable\"\n ref=\"search-input\"\n v-model=\"searchTerm\"\n class=\"tw-col-span-3 md:tw-col-span-4\"\n data-test=\"input|search-input\"\n :class=\"[$style['search-input'], { 'lg:tw-col-span-8': showSecondaryControls }]\"\n :hint-text=\"internalSearchSchema.hintText\"\n :label=\"searchText\"\n :placeholder=\"internalSearchSchema.placeholder\"\n @keyup.enter=\"!isLoading && onSearch()\"\n @change=\"onSearchTermChange\"\n >\n <template #append>\n <button\n v-if=\"searchTerm\"\n data-test=\"button|clear-search\"\n :class=\"$style['clear-button']\"\n :disabled=\"isLoading\"\n @click=\"clearSearchTerm\"\n >\n <Icon name=\"close\" />\n </button>\n <Button\n data-test=\"button|search-button\"\n :disabled=\"isLoading\"\n :class=\"$style['search-button']\"\n @click=\"onSearch\"\n >\n <Icon\n :class=\"{ 'tw-animate-spin tw-text-teal-500': isFiltering }\"\n :name=\"isFiltering ? 'working' : 'search'\"\n />\n </Button>\n </template>\n </Input>\n\n <!-- Filter Toggle -->\n <div\n v-if=\"filterSchema.length\"\n class=\"tw-col-span-1 tw-flex tw-items-end\"\n :class=\"[\n $style['filter-toggle-btn'],\n { [$style['filter-toggle-btn-with-hint-text']]: !!internalSearchSchema.hintText },\n ]\"\n >\n <Badge :content=\"numberOfFilters\">\n <Button\n secondary\n class=\"tw-relative tw-w-full tw-min-w-auto\"\n color=\"blue\"\n data-test=\"button|toggle-filters\"\n :disabled=\"isFiltering\"\n @click=\"onFiltersToggleClick\"\n >\n <Icon\n v-if=\"isFiltering\"\n name=\"working\"\n :class=\"[\n { 'tw-animate-spin': isFiltering },\n isShowingFilters ? 'tw-text-teal-500' : 'tw-text-ice-700',\n ]\"\n />\n <Icon v-else name=\"filter-line\" />\n {{ filterText }}\n </Button>\n </Badge>\n </div>\n\n <!-- Actions -->\n <div class=\"button-grid tw-col-span-1 tw-items-end tw-justify-end lg:tw-col-span-3\">\n <slot name=\"actions\"> </slot>\n </div>\n </div>\n\n <!-- Filters -->\n <Expand data-test=\"filters|content\" :class=\"$style['filters-expand']\" :is-expanded=\"isShowingFilters\">\n <div class=\"tw-relative tw-pt-12\" :class=\"$style['filters-wrapper']\">\n <Filters\n ref=\"llFilters\"\n :class=\"{ [$style['filters-half-width']]: showPrimaryControls && showSecondaryControls }\"\n :disable-apply=\"isLoading\"\n :disable-clear=\"isLoading || !numberOfFilters\"\n :disable-persistency=\"disablePersistency\"\n :schema=\"filterSchema\"\n :validation-schema=\"validationSchema\"\n @change=\"filters = $event\"\n @reset=\"reset\"\n @submit=\"onFilter\"\n />\n </div>\n </Expand>\n </div>\n\n <div\n v-if=\"showSecondaryControls\"\n class=\"secondary-controls\"\n :class=\"[$style['legacy-box'], { 'tw-col-span-12 tw-mt-0 lg:tw-col-span-6': showPrimaryControls }]\"\n >\n <slot name=\"secondary-controls\"></slot>\n </div>\n </div>\n\n <!-- @slot Renders custom content in the space below the filters and above the list -->\n <slot name=\"eyebrow\"></slot>\n\n <div\n v-if=\"shouldShowTotal || Object.keys(sorts).length\"\n class=\"tw-mb-1.5\"\n :class=\"shouldShowTotal ? $style['total-sort'] : 'tw-text-right'\"\n >\n <div v-if=\"shouldShowTotal\" class=\"tw-text-xs\">{{ total }}</div>\n\n <!-- Sort -->\n <Dropdown\n v-if=\"Object.keys(sorts).length\"\n :class=\"$style.dropdown\"\n :label=\"`${sortLabel} ${sortTerm}`\"\n @toggle.once=\"onSortToggle\"\n >\n <ul ref=\"sortOptions\" class=\"dropdown__list\" :style=\"{ minWidth: sortOptionsWidth }\">\n <li\n v-for=\"(sortOption, index) in Object.keys(sorts)\"\n :key=\"index\"\n :class=\"{ 'tw-bg-blue-100 tw-text-ice-700': sortOption === sortTerm }\"\n class=\"dropdown__item tw-rounded\"\n >\n <Button inline class=\"tw-items-center\" :class=\"$style['sort-option']\" @click=\"onSort(sortOption)\">\n {{ sortOption }}\n <Icon v-if=\"sortOption === sortTerm\" name=\"check\" class=\"tw-ml-auto tw-text-blue-500\" />\n </Button>\n </li>\n </ul>\n </Dropdown>\n </div>\n\n <!-- Defined Slots -->\n <div v-if=\"useDefinedSlots\" :class=\"$style['list-items']\">\n <header\n v-sticky=\"headerOffset\"\n data-test=\"header|defined-slot\"\n :class=\"[\n $style.header,\n {\n 'tw-m-0': !isSelectable,\n },\n ]\"\n class=\"tw-rounded\"\n >\n <div :class=\"$style['header-grid-container']\" class=\"tw-border-b tw-border-ice-200 tw-px-3\">\n <Checkbox\n v-if=\"isSelectable\"\n class=\"tw-ml-3\"\n :checked=\"isSomePageChecked\"\n :class=\"$style['select-all']\"\n :indeterminate=\"isSomePageChecked && !isAllPageChecked\"\n @update:checked=\"onSelectPage\"\n />\n <div class=\"tw-ll-grid tw-flex-1\" :class=\"$style['header-grid']\">\n <slot name=\"list-header\"> </slot>\n </div>\n </div>\n\n <!-- Select Bar -->\n <BulkActions\n v-if=\"isSelectable\"\n v-bind=\"{\n allowSelectAll: !hideSelectAll && !isServerSide,\n isAllPageChecked,\n isSomePageChecked,\n totalCount,\n totalSelectedCount,\n hideBulkActionOptions,\n hideNumberOfTotalSelected,\n }\"\n :class=\"!isSelectBarVisible && 'lg:tw-hidden'\"\n @change:clear-selected=\"clearSelected\"\n @change:select-current=\"onSelectPage\"\n @change:select-all=\"selectAll\"\n >\n <template #bulk-actions-content>\n <slot name=\"bulk-actions\" :selected-items=\"selectedItems\"> </slot>\n </template>\n </BulkActions>\n </header>\n\n <component\n :is=\"disableLoader ? 'div' : 'LoadingManager'\"\n :empty-state-text=\"emptyStateText\"\n :loading=\"isLoading\"\n :results=\"paginated\"\n >\n <slot\n name=\"list-items\"\n :clear-all=\"clearSelected\"\n :display-items=\"results\"\n :is-filtered=\"isFiltered\"\n :is-item-disabled=\"isItemDisabled\"\n :results=\"paginated\"\n :on-select=\"onSelectItem\"\n :selected-items=\"selectedItems\"\n ></slot>\n </component>\n </div>\n\n <!-- Default Slot -->\n <slot\n :current-page=\"currentPage\"\n :display-items=\"results\"\n :filters=\"filters\"\n :is-filtered=\"isFiltered\"\n :is-item-disabled=\"isItemDisabled\"\n :results=\"paginated\"\n :search-term=\"searchTerm\"\n :total=\"totalCount\"\n ></slot>\n\n <!-- Pagination -->\n <Paginate\n v-if=\"totalCount > pageSize\"\n :current-page=\"currentPage\"\n :list-length=\"totalCount\"\n :page-size=\"pageSize\"\n @set-page=\"onPaginateSetPage\"\n />\n </div>\n</template>\n\n<style module>\n .list-items {\n background-color: var(--color-ice-200);\n border-bottom-left-radius: theme('borderRadius.DEFAULT');\n border-bottom-right-radius: theme('borderRadius.DEFAULT');\n min-width: 100%;\n position: relative;\n }\n\n @media screen('lg') {\n .list-items {\n @apply tw-shadow;\n }\n }\n\n /* the .legacy-box styles are copied from .box in _box.scss */\n .legacy-box {\n @apply tw-shadow;\n\n background: var(--color-white);\n border-radius: theme('borderRadius.DEFAULT');\n padding: theme('spacing.6') var(--grid-gutter);\n }\n\n .header {\n background-color: var(--color-white);\n color: var(--color-ice-900);\n font-weight: 500;\n margin-bottom: theme('spacing.3');\n overflow: hidden;\n z-index: 1;\n\n &:global(.is-sticky) {\n @apply tw-shadow;\n\n border-radius: 0;\n overflow: visible;\n z-index: calc(theme('zIndex.control') + 1);\n\n &::before,\n &::after {\n background-color: var(--color-white);\n content: '';\n height: 100%;\n overflow-x: hidden;\n position: absolute;\n right: 100%;\n top: 0;\n width: theme('spacing.3');\n\n @media screen('lg') {\n content: none;\n }\n }\n\n &::after {\n left: 100%;\n right: auto;\n }\n }\n\n :global(.input--checkbox) {\n label {\n min-height: theme('spacing.6');\n }\n }\n\n @media screen('lg') {\n border-bottom-left-radius: 0;\n border-bottom-right-radius: 0;\n margin-bottom: 0;\n }\n }\n\n .header-grid-container {\n display: none;\n transition: padding theme('transitionDuration.150') theme('transitionTimingFunction.swing');\n\n @media screen('lg') {\n align-items: center;\n display: flex;\n }\n }\n\n .header-grid {\n column-gap: 0 !important;\n grid-column-gap: 0 !important;\n\n > div {\n align-items: center;\n border-right: 1px solid var(--color-ice-200);\n display: flex;\n font-size: theme('fontSize.xs');\n justify-content: space-between;\n padding: theme('spacing.3');\n\n &:first-of-type {\n margin-left: calc(-1 * theme('spacing.3'));\n padding-left: theme('spacing.6');\n }\n\n &:last-of-type {\n border-right: 0;\n margin-right: calc(-1 * theme('spacing.3'));\n }\n }\n }\n\n .search-input {\n :global(input) {\n /* to prevent search text from overlapping the \"Clear\" button */\n padding-right: calc(theme('height.input') * 2) !important;\n }\n\n :global(.stash-input-append) {\n display: flex;\n justify-content: flex-end;\n width: 72px; /* double the the default width of 36px */\n\n .clear-button {\n color: var(--color-ice-700);\n height: 36px;\n margin: 0;\n min-width: 36px;\n padding: 0;\n width: 36px;\n\n &:disabled {\n color: var(--color-ice-500);\n cursor: default;\n }\n }\n\n .search-button {\n border-bottom-left-radius: 0;\n border-color: var(--color-blue-500);\n border-left: none;\n border-top-left-radius: 0;\n min-width: 36px;\n padding: 0 theme('spacing[1.5]');\n width: 36px;\n\n &:disabled {\n border-color: var(--color-ice-500);\n }\n }\n }\n }\n\n @media screen('md') {\n .total-sort {\n align-items: baseline;\n display: flex;\n justify-content: space-between;\n }\n }\n\n .filter-toggle-btn {\n min-width: fit-content !important; /* ensure this overrides the grid min-width applied */\n }\n\n .filter-toggle-btn-with-hint-text {\n /* search hint text has 16px of height and has 4px of margin top. Adding here directly to compensate that */\n margin-bottom: 20px;\n }\n\n @keyframes separator {\n 0% {\n opacity: 0;\n }\n\n 100% {\n opacity: 1;\n }\n }\n\n .filters-expand:global(.stash-expand--expanded) {\n .filters-wrapper::before {\n animation: separator theme('transitionDuration.300') theme('transitionTimingFunction.ease-in-out') 0.5s 1 forwards;\n background: var(--color-ice-200);\n content: '';\n height: theme('borderWidth.DEFAULT');\n left: calc(var(--grid-gutter) * -1);\n opacity: 0;\n position: absolute;\n right: calc(var(--grid-gutter) * -1);\n top: theme('spacing.6');\n }\n }\n\n .filters-half-width {\n @media screen('lg') {\n :global(.field-wrapper) {\n grid-column: span 6 / span 6; /* col-span-6 */\n }\n }\n }\n\n .dropdown :global(.tw-text-blue-500) {\n font-size: theme('fontSize.xs');\n }\n\n .sort-option {\n height: theme('spacing.9');\n }\n\n .select-all {\n width: theme('spacing.6');\n }\n</style>\n"],"names":["_sfc_main","Button","Checkbox","t","value","_createElementBlock","_normalizeClass","_ctx","$props","_createElementVNode","_createVNode","_component_ll_checkbox","$options","_openBlock","_hoisted_1","_createCommentVNode","_hoisted_2","_toDisplayString","_createBlock","_component_ll_button","_withCtx","_createTextVNode","_hoisted_3","_renderSlot","EmptyState","Loading","_component_Loading","_TransitionGroup","_component_EmptyState","Expand","Icon","sticky","isExpanded","getCssVar","CSS_VARS","$data","args","_component_Icon","_component_Expand","_component_ll_icon","DEFAULT_SEARCH_SCHEMA","BulkActions","Filters","Paginate","LoadingManager","Badge","Dropdown","Input","_a","persistentStorage","paginated","endIndex","totalCount","results","startIndex","current","range","item","id","acc","filterBy","isBoolean","isToggle","isEmpty","isInputOptionsIncomplete","cloneDeep","searchFor","useSearch","computed","searchTerm","sortTerms","actionResponse","items","_filterItems","_sortItems","trigger","currentPage","filters","isFiltered","pageSize","sortTerm","params","_b","LLLV_CHANGE_TRIGGERS","term","pageNumber","forceChange","selectedItem","_component_Input","_cache","$event","_withKeys","_component_Button","_component_Badge","_component_Filters","_hoisted_4","_component_Dropdown","_normalizeStyle","_Fragment","_renderList","sortOption","index","_component_Checkbox","_component_BulkActions","_mergeProps","_resolveDynamicComponent","_component_Paginate"],"mappings":"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"}
|