@leaflink/stash 52.0.2 → 53.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/README.md +50 -49
- package/dist/Accordion.js +16 -16
- package/dist/Accordion.js.map +1 -1
- package/dist/AccordionGroup.js +7 -7
- package/dist/AccordionGroup.js.map +1 -1
- package/dist/ActionsDropdown.js +16 -16
- package/dist/ActionsDropdown.js.map +1 -1
- package/dist/AddressSelect.js.map +1 -1
- package/dist/AddressSelect.vue.d.ts +1 -1
- package/dist/Alert.js +34 -34
- package/dist/Alert.js.map +1 -1
- package/dist/AppNavigationItem.js +31 -31
- package/dist/AppNavigationItem.js.map +1 -1
- package/dist/AppSidebar.js +19 -19
- package/dist/AppSidebar.js.map +1 -1
- package/dist/AppTopbar.js +32 -32
- package/dist/AppTopbar.js.map +1 -1
- package/dist/Avatar.js +18 -18
- package/dist/Avatar.js.map +1 -1
- package/dist/Backdrop.js +5 -5
- package/dist/Backdrop.js.map +1 -1
- package/dist/Badge.js +38 -38
- package/dist/Badge.js.map +1 -1
- package/dist/Box.js +1 -1
- package/dist/{Box.vue_vue_type_script_setup_true_lang-rFnvwLVY.js → Box.vue_vue_type_script_setup_true_lang-dFFZN40_.js} +6 -6
- package/dist/{Box.vue_vue_type_script_setup_true_lang-rFnvwLVY.js.map → Box.vue_vue_type_script_setup_true_lang-dFFZN40_.js.map} +1 -1
- package/dist/Button.js +21 -21
- package/dist/Button.js.map +1 -1
- package/dist/ButtonGroup.js +26 -26
- package/dist/ButtonGroup.js.map +1 -1
- package/dist/Card.js +14 -14
- package/dist/Card.js.map +1 -1
- package/dist/CardContent.js +1 -1
- package/dist/CardContent.js.map +1 -1
- package/dist/CardFooter.js +1 -1
- package/dist/CardFooter.js.map +1 -1
- package/dist/CardHeader.js +4 -4
- package/dist/CardHeader.js.map +1 -1
- package/dist/CardMedia.js +20 -20
- package/dist/CardMedia.js.map +1 -1
- package/dist/Carousel.js +88 -93
- package/dist/Carousel.js.map +1 -1
- package/dist/Checkbox.js +30 -30
- package/dist/Checkbox.js.map +1 -1
- package/dist/Checkbox.vue.d.ts +0 -3
- package/dist/Chip.js +33 -33
- package/dist/Chip.js.map +1 -1
- package/dist/ConfirmationCodeInput.js +72 -72
- package/dist/ConfirmationCodeInput.js.map +1 -1
- package/dist/ContextSwitcher.js +27 -27
- package/dist/ContextSwitcher.js.map +1 -1
- package/dist/Copy.js +47 -48
- package/dist/Copy.js.map +1 -1
- package/dist/CurrencyInput.js +1 -1
- package/dist/CurrencyInput.js.map +1 -1
- package/dist/CurrencyInput.vue.d.ts +5 -5
- package/dist/DataView.js +23 -23
- package/dist/DataView.js.map +1 -1
- package/dist/DataViewFilters.js +26 -26
- package/dist/DataViewFilters.js.map +1 -1
- package/dist/DataViewSortButton.js +22 -22
- package/dist/DataViewSortButton.js.map +1 -1
- package/dist/DataViewToolbar.js +52 -52
- package/dist/DataViewToolbar.js.map +1 -1
- package/dist/DatePicker.js +10 -10
- package/dist/DatePicker.js.map +1 -1
- package/dist/DescriptionList.js +2 -2
- package/dist/DescriptionList.js.map +1 -1
- package/dist/DescriptionListDetail.js +2 -2
- package/dist/DescriptionListDetail.js.map +1 -1
- package/dist/DescriptionListGroup.js +9 -9
- package/dist/DescriptionListGroup.js.map +1 -1
- package/dist/DescriptionListTerm.js +8 -8
- package/dist/DescriptionListTerm.js.map +1 -1
- package/dist/Dialog.js +47 -47
- package/dist/Dialog.js.map +1 -1
- package/dist/Divider.js +6 -6
- package/dist/Divider.js.map +1 -1
- package/dist/Dropdown.js +20 -20
- package/dist/Dropdown.js.map +1 -1
- package/dist/EmptyState.js +26 -26
- package/dist/EmptyState.js.map +1 -1
- package/dist/Field.js +1 -1
- package/dist/{Field.vue_vue_type_script_setup_true_lang-DI6z3AE9.js → Field.vue_vue_type_script_setup_true_lang-dAGKfjf5.js} +17 -17
- package/dist/Field.vue_vue_type_script_setup_true_lang-dAGKfjf5.js.map +1 -0
- package/dist/FileUpload.js +47 -49
- package/dist/FileUpload.js.map +1 -1
- package/dist/FilterChip.js +20 -20
- package/dist/FilterChip.js.map +1 -1
- package/dist/FilterDrawerItem.js +13 -13
- package/dist/FilterDrawerItem.js.map +1 -1
- package/dist/FilterDropdown.js +27 -27
- package/dist/FilterDropdown.js.map +1 -1
- package/dist/FilterSelect.js +33 -33
- package/dist/FilterSelect.js.map +1 -1
- package/dist/Filters.js +29 -29
- package/dist/Filters.js.map +1 -1
- package/dist/Filters.vue.d.ts +2 -8
- package/dist/HttpError.js +29 -29
- package/dist/HttpError.js.map +1 -1
- package/dist/HttpError.vue.d.ts +0 -3
- package/dist/Icon.js +12 -12
- package/dist/Icon.js.map +1 -1
- package/dist/IconLabel.js +19 -19
- package/dist/IconLabel.js.map +1 -1
- package/dist/IconLabel.vue.d.ts +1 -1
- package/dist/Illustration.js +2 -2
- package/dist/{Illustration.vue_vue_type_script_setup_true_lang-BrqEF8xe.js → Illustration.vue_vue_type_script_setup_true_lang-C1bPkWZZ.js} +4 -4
- package/dist/{Illustration.vue_vue_type_script_setup_true_lang-BrqEF8xe.js.map → Illustration.vue_vue_type_script_setup_true_lang-C1bPkWZZ.js.map} +1 -1
- package/dist/Image.js +2 -2
- package/dist/Image.vue.d.ts +0 -3
- package/dist/{Image.vue_vue_type_script_setup_true_lang-D5u4av0_.js → Image.vue_vue_type_script_setup_true_lang-CAj0FH9h.js} +11 -11
- package/dist/Image.vue_vue_type_script_setup_true_lang-CAj0FH9h.js.map +1 -0
- package/dist/InlineEdit.js +8 -8
- package/dist/InlineEdit.js.map +1 -1
- package/dist/Input.js +29 -29
- package/dist/Input.js.map +1 -1
- package/dist/InputOptions.js +87 -84
- package/dist/InputOptions.js.map +1 -1
- package/dist/InputOptions.vue.d.ts +2 -2
- package/dist/IntegrationIcon.js +11 -11
- package/dist/IntegrationIcon.js.map +1 -1
- package/dist/Label.js +1 -1
- package/dist/{Label.vue_vue_type_script_setup_true_lang-CNquF3AP.js → Label.vue_vue_type_script_setup_true_lang-xwY3X-iV.js} +16 -16
- package/dist/{Label.vue_vue_type_script_setup_true_lang-CNquF3AP.js.map → Label.vue_vue_type_script_setup_true_lang-xwY3X-iV.js.map} +1 -1
- package/dist/ListItem.js +14 -14
- package/dist/ListItem.js.map +1 -1
- package/dist/ListItem.vue.d.ts +0 -6
- package/dist/ListItemCell.js +9 -9
- package/dist/ListItemCell.js.map +1 -1
- package/dist/ListView.js +138 -141
- package/dist/ListView.js.map +1 -1
- package/dist/ListView.vue.d.ts +2 -26
- package/dist/Loading.js +8 -8
- package/dist/Loading.js.map +1 -1
- package/dist/Logo.js +1 -1
- package/dist/{Logo.vue_vue_type_script_setup_true_lang-Dz8c98sc.js → Logo.vue_vue_type_script_setup_true_lang-DghNC_k6.js} +3 -3
- package/dist/{Logo.vue_vue_type_script_setup_true_lang-Dz8c98sc.js.map → Logo.vue_vue_type_script_setup_true_lang-DghNC_k6.js.map} +1 -1
- package/dist/Menu.js +5 -5
- package/dist/Menu.js.map +1 -1
- package/dist/MenuItem.js +12 -12
- package/dist/MenuItem.js.map +1 -1
- package/dist/Metric.js +24 -24
- package/dist/Metric.js.map +1 -1
- package/dist/Modal.js +60 -60
- package/dist/Modal.js.map +1 -1
- package/dist/Modals.js +1 -1
- package/dist/Modals.js.map +1 -1
- package/dist/Module.js +6 -6
- package/dist/Module.js.map +1 -1
- package/dist/ModuleContent.js +16 -16
- package/dist/ModuleContent.js.map +1 -1
- package/dist/ModuleFooter.js +13 -13
- package/dist/ModuleFooter.js.map +1 -1
- package/dist/ModuleHeader.js +29 -29
- package/dist/ModuleHeader.js.map +1 -1
- package/dist/MoreActions.js +81 -84
- package/dist/MoreActions.js.map +1 -1
- package/dist/ObfuscateText.js +4 -4
- package/dist/ObfuscateText.js.map +1 -1
- package/dist/PageContent.js +13 -13
- package/dist/PageContent.js.map +1 -1
- package/dist/PageHeader.js +28 -28
- package/dist/PageHeader.js.map +1 -1
- package/dist/PageNavigation.js +1 -1
- package/dist/Paginate.js +45 -45
- package/dist/Paginate.js.map +1 -1
- package/dist/QuickAction.js +18 -18
- package/dist/QuickAction.js.map +1 -1
- package/dist/Radio.js +17 -17
- package/dist/Radio.js.map +1 -1
- package/dist/RadioGroup.js +158 -154
- package/dist/RadioGroup.js.map +1 -1
- package/dist/RadioNew.js +80 -80
- package/dist/RadioNew.js.map +1 -1
- package/dist/RadioNew.vue.d.ts +0 -3
- package/dist/RangeInput.js +2 -2
- package/dist/RangeInput.js.map +1 -1
- package/dist/SearchBar.js +9 -9
- package/dist/SearchBar.js.map +1 -1
- package/dist/SectionHeader.js +14 -14
- package/dist/SectionHeader.js.map +1 -1
- package/dist/Select.js +369 -366
- package/dist/Select.js.map +1 -1
- package/dist/SelectStatus.js +26 -27
- package/dist/SelectStatus.js.map +1 -1
- package/dist/Skeleton.js +20 -20
- package/dist/Skeleton.js.map +1 -1
- package/dist/Step.js +37 -40
- package/dist/Step.js.map +1 -1
- package/dist/Stepper.js +17 -17
- package/dist/Stepper.js.map +1 -1
- package/dist/Switch.js +57 -57
- package/dist/Switch.js.map +1 -1
- package/dist/Tab.js +17 -19
- package/dist/Tab.js.map +1 -1
- package/dist/TabPanel.js +1 -1
- package/dist/TabPanel.js.map +1 -1
- package/dist/Table.js +22 -22
- package/dist/Table.js.map +1 -1
- package/dist/TableCell.js +32 -32
- package/dist/TableCell.js.map +1 -1
- package/dist/TableHeaderCell.js +35 -35
- package/dist/TableHeaderCell.js.map +1 -1
- package/dist/TableHeaderRow.js +10 -10
- package/dist/TableHeaderRow.js.map +1 -1
- package/dist/TableRow.js +51 -51
- package/dist/TableRow.js.map +1 -1
- package/dist/Tabs.js +2 -2
- package/dist/{Tabs.vue_vue_type_script_setup_true_lang-B3Irnlcd.js → Tabs.vue_vue_type_script_setup_true_lang-BVTCcK6M.js} +33 -33
- package/dist/Tabs.vue_vue_type_script_setup_true_lang-BVTCcK6M.js.map +1 -0
- package/dist/TextEditor.js +8 -8
- package/dist/TextEditor.js.map +1 -1
- package/dist/Textarea.js +15 -15
- package/dist/Textarea.js.map +1 -1
- package/dist/Thumbnail.js +41 -41
- package/dist/Thumbnail.js.map +1 -1
- package/dist/ThumbnailEmpty.js +3 -3
- package/dist/ThumbnailEmpty.js.map +1 -1
- package/dist/ThumbnailGroup.js +22 -22
- package/dist/ThumbnailGroup.js.map +1 -1
- package/dist/Timeline.js +3 -3
- package/dist/Timeline.js.map +1 -1
- package/dist/TimelineItem.js +22 -22
- package/dist/TimelineItem.js.map +1 -1
- package/dist/Toast.js +29 -29
- package/dist/Toast.js.map +1 -1
- package/dist/Toast.vue.d.ts +3 -0
- package/dist/Toasts.js +11 -11
- package/dist/Toasts.js.map +1 -1
- package/dist/Tooltip.js +2 -81
- package/dist/Tooltip.js.map +1 -1
- package/dist/Tooltip.vue.d.ts +1 -1
- package/dist/Tooltip.vue_vue_type_script_setup_true_lang-mzBLSXy3.js +84 -0
- package/dist/Tooltip.vue_vue_type_script_setup_true_lang-mzBLSXy3.js.map +1 -0
- package/dist/components.css +2 -2
- package/dist/constants.d.ts +9 -9
- package/dist/constants.js +17 -17
- package/dist/constants.js.map +1 -1
- package/dist/directives/tooltip.js +2 -2
- package/dist/directives/tooltip.js.map +1 -1
- package/dist/{index-C14LhAwV.js → index-DBV9Uz0C.js} +3 -3
- package/dist/{index-C14LhAwV.js.map → index-DBV9Uz0C.js.map} +1 -1
- package/dist/tailwind-base.js.d.ts +12 -0
- package/dist/tailwind-base.js.map +1 -1
- package/dist/useSortable.js +1 -1
- package/dist/utils/helpers.js +15 -15
- package/dist/utils/helpers.js.map +1 -1
- package/package.json +15 -15
- package/styles/backwards-compat.css +373 -2851
- package/styles/main.css +8 -0
- package/styles/sofia-font.css +23 -27
- package/styles/theme.css +1033 -0
- package/dist/Field.vue_vue_type_script_setup_true_lang-DI6z3AE9.js.map +0 -1
- package/dist/Image.vue_vue_type_script_setup_true_lang-D5u4av0_.js.map +0 -1
- package/dist/Tabs.vue_vue_type_script_setup_true_lang-B3Irnlcd.js.map +0 -1
- package/dist/tailwind-base.d.ts +0 -333
- package/styles/base.css +0 -902
- package/tailwind-base.ts +0 -455
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-max-w-full tw-bg-white\" :text=\"emptyStateText\" />\n</template>\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 [$style['disable-external-gutters']]: disableExternalGutters,\n [$style['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=\"tw-relative tw-w-full lg:tw-shadow\">\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-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=\"tw-relative tw-h-4 tw-w-3 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 if (this.$refs.scrollTarget) {\n this.$refs.scrollTarget.scrollIntoView({ behavior: 'smooth', block: 'center' });\n }\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-6 lg:tw-col-span-4\"\n data-test=\"input|search-input\"\n :class=\"[\n $style['search-input'],\n {\n 'lg:tw-col-span-8': showSecondaryControls,\n 'tw-col-span-4 md:tw-col-span-8 lg:tw-col-span-6': !filterSchema.length,\n },\n ]\"\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 md:tw-col-span-2 lg:tw-col-span-1\"\n :class=\"[\n $style['filter-toggle-btn'],\n { [$style['filter-toggle-btn-with-hint-text']]: !!internalSearchSchema.hintText },\n ]\"\n >\n <Badge class=\"tw-w-full lg:tw-w-auto\" :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 md:tw-col-span-6 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":";;;;;;;;;;;;;;;;;;;;;;;;GAKOA,KAAU;AAAA,EACb,MAAM;AAAA,EAEN,YAAY;AAAA,IACV,aAAaC;AAAA,IACb,eAAeC;AAAA;EAGjB,OAAO;AAAA,IACL,gBAAgB;AAAA,IAChB,kBAAkB;AAAA,IAClB,mBAAmB;AAAA,IACnB,uBAAuB;AAAA,IACvB,2BAA2B;AAAA,IAC3B,YAAY;AAAA,MACV,MAAM;AAAA,MACN,SAAS;AAAA;IAEX,oBAAoB;AAAA,MAClB,MAAM;AAAA,MACN,SAAS;AAAA;;EAIb,OAAO,CAAC,yBAAyB,qBAAqB,uBAAuB;AAAA,EAE7E,MAAM,WAAY;AAChB,WAAO;AAAA,MACL,eAAeC,EAAE,uBAAuB;AAAA;EAE5C;AAAA,EAEA,UAAU;AAAA,IACR,oBAAoB;AAClB,aAAI,KAAK,iBACAA,EAAE,gCAAgC,EAAE,OAAO,KAAK,WAAS,CAAG,IAG9DA,EAAE,4BAA4B;AAAA,IACvC;AAAA,IAEA,gBAAgB;AACd,aAAO,CAAC,KAAK,uBAAuB,KAAK,YAAY,KAAK,cAAc,EAAE,MAAM,OAAO;AAAA,IACzF;AAAA,IAEA,4BAA4B;AAC1B,aAAOA,EAAE,qCAAqC;AAAA,QAC5C,KAAK,KAAK;AAAA,QACV,OAAO,KAAK;AAAA,MACd,CAAC;AAAA,IACH;AAAA,IAEA,qBAAqB;AACnB,aAAOA,EAAE,8BAA8B,EAAE,OAAO,KAAK,WAAS,CAAG;AAAA,IACnE;AAAA,IAEA,uBAAuB;AACrB,aAAOA,EAAE,gCAAgC;AAAA,QACvC,oBAAoB,KAAK;AAAA,QACzB,YAAY,KAAK;AAAA,MACnB,CAAC;AAAA,IACH;AAAA;EAGF,SAAS;AAAA,IACP,aAAaC,GAAO;AAClB,WAAK,MAAM,yBAAyBA,CAAK;AAAA,IAC3C;AAAA,IAEA,YAAY;AACV,WAAK,MAAM,mBAAmB;AAAA,IAChC;AAAA,IAEA,gBAAgB;AACd,WAAK,MAAM,uBAAuB;AAAA,IACpC;AAAA;;EAhFN,KAAA;AAAA,EAiHQ,OAAM;;EAjHd,KAAA;AAAA,EAmH+C,OAAM;;EAnHrD,KAAA;AAAA,EA6HqE,OAAM;;;;cAvCzEC,EA8CM,OAAA;AAAA,IA7CJ,OAvFJC,GAuFU,cAAY;AAAA,MACFC,EAAA,OAAM,YAAA;AAAA;wBAAgDC,EAAA;AAAA;;;;IAQtEC,EAgCM,OAAA;AAAA,MA/BJ,OAjGNH,GAiGY,2BAAyB;AAAA,+BACUE,EAAA;AAAA;;MAIzCE,EAQEC,GAAA;AAAA,QAPA,aAAU;AAAA,QACT,OAxGTL,EAAA,CAwGgBC,EAAA,OAAO,UACT,qBAAqB,CAAA;AAAA,QAC1B,SAASC,EAAA,qBAAiB,CAAA,CAAMA,EAAA;AAAA,QAChC,eAAeA,EAAA,qBAAiB,CAAKA,EAAA;AAAA,QACrC,OAAQA,EAAA,qBAAkC,KAAbD,EAAA;AAAA,QAC7B,oBAAgBK,EAAA;AAAA;MAGTJ,EAAA,uBAAuBA,EAAA,yBADjCK,KAAAR,EAaM,OAbNS,IAaM;AAAA,QATQN,EAAA,4BAnHpBO,EAAA,IAAA,EAAA,UAmHQV,EAEM,OAFNW,IAEMC,EADDL,EAAA,yBAAyB,GAAA,CAAA;AAAA,QAE9BH,EAKM,OAAA;AAAA,UALA,OAtHdH,gBAsHmCE,EAAA,0BAAyB,CAAA;AAAA;UACjCI,EAAA,sBAAjBM,EAA8FC,GAAA;AAAA,YAvHxG,KAAA;AAAA,YAuH0C,QAAA;AAAA,YAAQ,SAAOP,EAAA;AAAA;YAvHzD,SAAAQ,EAuHoE,MAAwB;AAAA,cAvH5FC,EAAAJ,EAuHuEL,EAAA,kBAAkB,GAAA,CAAA;AAAA;YAvHzF,GAAA;AAAA,sCAwHUM,EAEYC,GAAA;AAAA,YA1HtB,KAAA;AAAA,YAwH4B,QAAA;AAAA,YAAQ,SAAOP,EAAA;AAAA;YAxH3C,SAAAQ,EAyHY,MAAuB;AAAA,cAzHnCC,EAAAJ,EAyHeL,EAAA,iBAAiB,GAAA,CAAA;AAAA;YAzHhC,GAAA;AAAA;;YA6HsBJ,EAAA,yBAA2BA,EAAA,sBAA3CK,KAAAR,EAEM,OAFNiB,IAEM;AAAA,QADJb,EAAmC,cAA5BG,EAAA,oBAAoB,GAAA,CAAA;AAAA,YA9HnCG,EAAA,IAAA,EAAA;AAAA;IAiIiBP,EAAA,uBAAuBA,EAAA,8BAApCH,EAEM,OAAA;AAAA,MAnIV,KAAA;AAAA,MAiIgE,OAjIhEC,EAiIuEC,EAAA,OAAO,OAAO;AAAA;MAC/EgB,EAAyChB,EAAA,QAAA,sBAAA;AAAA,aAlI/CQ,EAAA,IAAA,EAAA;AAAA;;;;uECIOf,KAAU;AAAA,EACb,MAAM;AAAA,EAEN,YAAY;AAAA,IACV,YAAAwB;AAAA,IACA,SAAAC;AAAA;EAGF,OAAO;AAAA,IACL,gBAAgB;AAAA,MACd,MAAM;AAAA,MACN,SAAS;AAAA;IAGX,SAAS;AAAA,IAET,SAAS;AAAA,MACP,MAAM;AAAA,MACN,SAAS,MAAM,CAAA;AAAA;;;;;SAONjB,EAAA,gBAAfU,EAA8CQ,GAAA;AAAA,IA7BhD,KAAA;AAAA,IA6B0B,OAAM;AAAA,QACDlB,EAAA,QAAQ,eAArCU,EAEmBS,GAAA;AAAA,IAhCrB,KAAA;AAAA,IA8B+C,MAAK;AAAA,IAAU,KAAI;AAAA;IA9BlE,SAAAP,EA+BI,MAAa;AAAA,MAAbG,EAAahB,EAAA,QAAA,SAAA;AAAA;IA/BjB,GAAA;AAAA,cAiCEW,EAA8EU,GAAA;AAAA,IAjChF,KAAA;AAAA,IAiCqB,OAAM;AAAA,IAA6B,MAAMpB,EAAA;AAAA;;;;;;;;;GCzBvDR,KAAU;AAAA,EACb,MAAM;AAAA,EAEN,YAAY;AAAA,IACV,QAAA6B;AAAAA,IACA,aAAa5B;AAAA,IACb,MAAA6B;AAAA;EAGF,YAAY;AAAA,IACV,QAAAC;AAAA;EAGF,OAAO;AAAA;AAAA;AAAA;AAAA,IAIL,wBAAwB;AAAA,MACtB,MAAM;AAAA,MACN,SAAS;AAAA;;;;IAMX,eAAe;AAAA,MACb,MAAM;AAAA,MACN,SAAS;AAAA;;;;;IAOX,sBAAsB;AAAA,MACpB,MAAM;AAAA,MACN,SAAS;AAAA;;EAIb,OAAO;AACL,UAAMC,IAAa,CAAC,KAAK,iBAAiB,CAAC,KAAK;AAEhD,WAAO;AAAA,MACL,YAAAA;AAAA,MACA,iBAAiBA;AAAA;EAErB;AAAA,EAEA,UAAU;AAAA,IACR,eAAe;AACb,aAAO,WAAWC,EAAUC,EAAS,iBAAiB,CAAC;AAAA,IACzD;AAAA;EAGF,SAAS;AAAA,IACP,eAAe;AACb,MAAK,KAAK,kBAIV,KAAK,aAAa,CAAC,KAAK,YAEnB,KAAK,eACR,KAAK,kBAAkB;AAAA,IAE3B;AAAA,IAEA,cAAc,GAAG;AAEf,MAAK,KAAK,MAAM,iBAAiB,SAAS,EAAE,MAAM,KAChD,KAAK,aAAY;AAAA,IAErB;AAAA;GAwBKpB,KAAA,EAAA,OAAM,eAAc,GAIpBE,KAAA,EAAA,KAAI,mBAAkB,GAMtBM,KAAA,EAAA,OAAM,qCAAoC;;;cA5BnDjB,EA6CM,OAAA;AAAA,IA5CH,OAxFLC,EAAA;AAAA,MAwFoBC,EAAA,OAAM,YAAA;AAAA;QAAiC,CAAAA,EAAA,qCAAqCC,EAAA;AAAA,QAAiC,CAAAD,EAAA,0BAA0B4B,EAAA;AAAA;;;IAQvJ1B,EAgBS,UAAA;AAAA,MAfP,OAjGNH,EAAA,CAiGY,2BAAyB,CACtBC,EAAA,8CAA8CC,EAAA,cAAa,CAAA,CAAA,CAAA;AAAA,MACnE,mCAAOI,EAAA,iBAAAA,EAAA,cAAA,GAAAwB,CAAA;AAAA;MAES5B,EAAA,sBAAjBU,EAEYC,GAAA;AAAA,QAvGlB,KAAA;AAAA,QAqGuC,OArGvCb,gCAqG4EC,EAAA,OAAM,yBAAA,CAAA,CAAA;AAAA,QAA8B,MAAA;AAAA;QArGhH,SAAAa,EAsGQ,MAAmF;AAAA,UAAnFV,EAAmF2B,GAAA;AAAA,YAA5E,OAtGf/B,GAsGuB6B,EAAA,aAAU,kBAAA,YAAA,CAAA;AAAA,YAAoC,MAAK;AAAA;;QAtG1E,GAAA;AAAA,0BAAApB,EAAA,IAAA,EAAA;AAAA,MAyGMN,EAEM,OAFNK,IAEM;AAAA,QADJS,EAA0BhB,EAAA,QAAA,OAAA;AAAA;MAG5BE,EAEM,OAFNO,IAEM;AAAA,QADJO,EAA4BhB,EAAA,QAAA,SAAA;AAAA;;IAIhCG,EAiBS4B,GAAA;AAAA,MAjBA,eAAaH,EAAA;AAAA,MAAa,sCAAcA,EAAA,kBAAe;AAAA;MAlHpE,SAAAf,EAmHM,MAeM;AAAA,QAfNX,EAeM,OAfNa,IAeM;AAAA,UAbIf,EAAA,OAAM,8BAAA,YADdF,EAQS,UAAA;AAAA,YA5HjB,KAAA;AAAA,YAuHW,OAvHXC,EAuHkBC,EAAA,OAAM,yBAAA,CAAA;AAAA;YAEdE,EAEM,OAAA;AAAA,cAFD,OAzHfH,EAAA,CAyHqB,wBAA+BC,EAAA,OAAM,8BAAA,CAAA,CAAA;AAAA;cAC9CgB,EAAiDhB,EAAA,QAAA,8BAAA;AAAA;;gBAJzC4B,EAAA,cAAcA,EAAA,kBAAkBvB,EAAA,eAAY,CAAA;AAAA,eAtHhEG,EAAA,IAAA,EAAA;AAAA,UA6HQN,EAIM,OAAA;AAAA,YAJA,OA7HdH,EA6HqBC,EAAA,OAAM,qCAAA,CAAA;AAAA;YACjBG,EAEmBiB,GAAA;AAAA,cAFD,MAAK;AAAA,cAAO,MAAK;AAAA;cA9H7C,SAAAP,EA+HY,MAAgD;AAAA,gBAAhDG,EAAgDhB,EAAA,QAAA,6BAAA;AAAA;cA/H5D,GAAA;AAAA;;;;MAAA,GAAA;AAAA;;;;;;;;;GCGOP,KAAU;AAAA,EACb,MAAM;AAAA,EAEN,YAAY;AAAA,IACV,WAAW8B;AAAA;EAGb,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA,IAKL,UAAU;AAAA,MACR,MAAM;AAAA,MACN,UAAU;AAAA,MACV,WAAW,CAAC1B,MAAUA,EAAM,WAAW;AAAA;IAGzC,aAAa;AAAA,MACX,MAAM;AAAA,MACN,SAAS;AAAA;;EAIb,OAAO;AACL,WAAO;AAAA,MACL,aAAa;AAAA;EAEjB;AAAA,EAEA,UAAU;AAAA,IACR,mBAAmB;AACjB,aAAO,KAAK,eAAe,KAAK;AAAA,IAClC;AAAA;AAAA;AAAA;AAAA,IAIA,WAAW;AACT,aAAO,KAAK,SAAS,SAAS,KAAK,iBAAiB,QAAQ;AAAA,IAC9D;AAAA;AAAA;AAAA;AAAA,IAKA,cAAc;AACZ,aAAO,KAAK,gBAAgB,QAAQ,KAAK,SAAS,CAAC,MAAM,KAAK,iBAAiB;AAAA,IACjF;AAAA;AAAA;AAAA;AAAA,IAKA,gBAAgB;AACd,aAAO,KAAK,gBAAgB,QAAQ,KAAK,SAAS,CAAC,MAAM,KAAK,iBAAiB;AAAA,IACjF;AAAA;EAGF,OAAO;AAAA,IACL,UAAU;AAAA,MACR,QAAQA,GAAO;AACb,aAAK,cAAcA,IAAQ,KAAO;AAAA,MACpC;AAAA,MACA,WAAW;AAAA;;EAIf,SAAS;AAAA;AAAA;AAAA;AAAA,IAIP,OAAO;AACL,WAAK,iBAAiB,OAAO,KAAK,SAAS,KAAK,cAAc,IAAI,CAAC,CAAC,GACpE,KAAK,cAAc,CAAC,KAAK;AAAA,IAC3B;AAAA;;;;cAMJC,EAkBM,OAAA;AAAA,IAlBA,OAjFRC,4CAiFyDM,EAAA,SAAQ,CAAA,CAAA;AAAA,IAAM,mCAAOA,EAAA,QAAAA,EAAA,KAAA,GAAAwB,CAAA;AAAA;IAC1Eb,EAAahB,EAAA,QAAA,SAAA;AAAA,IACbE,EAeM,OAAA;AAAA,MAfD,OAnFTH,EAAA,CAmFe,6CAA2C,EAAA,kBAA6BM,EAAA,UAAQ,CAAA;AAAA;MAEjFA,EAAA,oBADRM,EAMEqB,GAAA;AAAA,QA1FR,KAAA;AAAA,QAsFQ,MAAK;AAAA,QACL,OAvFRjC,GAuFc,eAAa,CACVC,SAAO,OAAOA,EAAA,OAAM,UAAA,CAAA,CAAA,CAAA;AAAA,QAC7B,MAAK;AAAA,gCAzFbQ,EAAA,IAAA,EAAA;AAAA,MA4FcH,EAAA,sBADRM,EAMEqB,GAAA;AAAA,QAjGR,KAAA;AAAA,QA6FQ,MAAK;AAAA,QACL,OA9FRjC,GA8Fc,eAAa,CACVC,SAAO,OAAOA,EAAA,OAAM,YAAA,CAAA,CAAA,CAAA;AAAA,QAC7B,MAAK;AAAA,gCAhGbQ,EAAA,IAAA,EAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;;GC2BQyB,IAAwB;AAAA,EAC5B,cAAc;AAAA,EACd,aAAa;AAAA,EACb,UAAU,CAAC,MAAM;GAGdxC,KAAU;AAAA,EACb,MAAM;AAAA,EAEN,YAAY;AAAA,IACV,aAAAyC;AAAA,IACA,SAAAC;AAAA,IACA,UAAAC;AAAA,IACA,gBAAAC;AAAA,IACA,OAAAC;AAAA,IACA,QAAA5C;AAAA,IACA,MAAA6B;AAAA,IACA,UAAAgB;AAAA,IACA,QAAAjB;AAAAA,IACA,UAAA3B;AAAA,IACA,OAAA6C;AAAA;EAGF,YAAY;AAAA,IACV,QAAAhB;AAAA;EAGF,QAAQ;AAAA,IACN,aAAa,EAAE,SAAS,MAAM,MAAM;AAAA,IAAC;IACrC,cAAc,EAAE,SAAS,MAAM,MAAM;AAAA,IAAC;IACtC,WAAW,EAAE,SAAS,MAAM,MAAM;AAAA,IAAC,EAAA;AAAA,IACnC,cAAc,EAAE,SAAS,MAAM,MAAM;AAAA,IAAC;;EAGxC,OAAO;AAAA;AAAA;AAAA;AAAA,IAIL,2BAA2B;AAAA,MACzB,MAAM;AAAA,MACN,SAAS;AAAA;;;;IAKX,eAAe;AAAA,MACb,MAAM;AAAA,MACN,SAAS;AAAA;;;;IAKX,gBAAgB;AAAA,MACd,MAAM;AAAA,MACN,SAAS;AAAA;IAEX,cAAc;AAAA,MACZ,MAAM;AAAA,MACN,SAAS,MAAM,CAAA;AAAA;;;;IAKjB,aAAa;AAAA,MACX,MAAM;AAAA,MACN,SAAS;AAAA;IAEX,WAAW;AAAA,IACX,aAAa;AAAA,MACX,MAAM;AAAA,MACN,SAAS;AAAA;;;;IAKX,cAAc;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IASd,cAAc;AAAA;AAAA;AAAA;AAAA,IAId,OAAO;AAAA,MACL,MAAM;AAAA,MACN,SAAS,MAAM,CAAA;AAAA;;;;IAKjB,aAAa;AAAA,MACX,MAAM;AAAA,MACN,SAAS;AAAA;IAEX,SAAS;AAAA;AAAA,IAET,UAAU;AAAA,MACR,MAAM;AAAA,MACN,SAAS;AAAA;IAEX,cAAc;AAAA,MACZ,MAAM;AAAA,MACN,SAAS,OAAO,CAAA;AAAA;;IAGlB,WAAW;AAAA,MACT,MAAM;AAAA,MACN,SAAS,MAAM5B,EAAE,oBAAoB;AAAA;IAEvC,YAAY;AAAA,IACZ,OAAO;AAAA,MACL,MAAM;AAAA,MACN,SAAS,OAAO,CAAA;AAAA;;;;;IAMlB,gBAAgB;AAAA,MACd,MAAM;AAAA,MACN,SAAS;AAAA;;;;IAKX,kBAAkB;AAAA,MAChB,MAAM;AAAA,MACN,SAAS,MAAM,MAAA;AAAA;AAAA;;;;;;;;IASjB,oBAAoB;AAAA;AAAA;AAAA;AAAA;AAAA,IAKpB,mBAAmB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAMnB,qBAAqB;AAAA;AAAA;AAAA;AAAA,IAIrB,mBAAmB;AAAA;AAAA;AAAA;AAAA,IAKnB,eAAe;AAAA,MACb,MAAM;AAAA,MACN,SAAS;AAAA;;;;IAMX,oBAAoB;AAAA,MAClB,MAAM;AAAA,MACN,SAAS;AAAA;;;;IAKX,uBAAuB;AAAA,MACrB,MAAM;AAAA,MACN,SAAS;AAAA;;;;IAMX,mBAAmB;AAAA,MACjB,MAAM;AAAA,MACN,SAAS;AAAA;;;;IAMX,gBAAgB;AAAA,MACd,MAAM;AAAA,MACN,SAAS,MAAM;AAAA;;EAInB,OAAO;AAAA,IACL;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA;EAGF,OAAO;;AACL,WAAO;AAAA,MACL,eAAe,CAAA;AAAA,MACf,aAAa,KAAK,eAAe;AAAA;AAAA,MACjC,cAAc;AAAA,MACd,kBAAkB;AAAA,MAClB,SAAS,CAAA;AAAA,MACT,YAAYA,EAAE,WAAW;AAAA,MACzB,WAAW,MAAM;AAAA,MAAC;AAAA;AAAA,MAClB,YAAY,KAAK;AAAA,MACjB,YAAYA,EAAE,WAAW;AAAA,MACzB,UAAU;AAAA,MACV,6BAA6B;AAAA,MAC7B,kBAAkB,CAAC,GACjB6C,IAAA,KAAK,iBAAL,QAAAA,EAAmB,WAClB,KAAK,qBAAqBC,EAAkB,IAAI,cAAc;AAAA,MAEjE,aAAa;AAAA,MACb,SAAS,CAAA;AAAA,MACT,eAAe,CAAA;AAAA;EAEnB;AAAA,EAEA,UAAU;AAAA;AAAA;AAAA;AAAA;AAAA,IAKR,YAAY;AACV,aAAO,CAAC,KAAK,SAAS,KAAK,6BAA6B,KAAK,WAAW,EAAE,KAAK,OAAO;AAAA,IACxF;AAAA,IAEA,aAAa;AACX,aAAO,KAAK,eAAe,KAAK,iBAAiB,KAAK,QAAQ;AAAA,IAChE;AAAA;AAAA;AAAA;AAAA;AAAA,IAMA,aAAa;AACX,aAAO,CAAC,EAAE,KAAK,mBAAmB,KAAK;AAAA,IACzC;AAAA;AAAA;AAAA;AAAA,IAKA,uBAAuB;AACrB,aAAO;AAAA,QACL,GAAGT;AAAA,QACH,UAAU,CAAC,KAAK,aAAa,gBAAgBA,EAAsB;AAAA,QACnE,GAAG,KAAK;AAAA;IAEZ;AAAA;AAAA;AAAA;AAAA,IAKA,aAAa;AACX,aAAO,KAAK,YAAY,KAAK,cAAc;AAAA,IAC7C;AAAA;AAAA;AAAA;AAAA,IAKA,WAAW;AACT,aAAO,KAAK,aAAa,KAAK;AAAA,IAChC;AAAA;AAAA;AAAA;AAAA;AAAA,IAMA,YAAY;AAEV,UAAIU;AAEJ,UAAI,KAAK;AACP,QAAAA,IAAY,KAAK;AAAA,WACZ;AACL,cAAM,EAAE,UAAAC,GAAU,YAAAC,GAAY,SAAAC,GAAS,YAAAC,EAAS,IAAM;AAEtD,QAAAJ,IAAYG,EAAQ,MAAMC,GAAY,KAAK,IAAIH,GAAUC,CAAU,CAAC;AAAA,MACtE;AAEA,kBAAK,MAAM,iBAAiBF,CAAS,GAE9BA;AAAA,IACT;AAAA;AAAA;AAAA;AAAA;AAAA,IAMA,QAAQ;AACN,YAAMK,IAAU,KAAK,YAAY,KAAK,cAAc,IAC9CC,IAAQ,KAAK,UAAU,SAAS,GAAGD,IAAU,CAAC,MAAMA,IAAU,KAAK,UAAU,MAAM,KAAK;AAE9F,aAAO,KAAK,YACRpD,EAAE,yBAAyB,IAC3BA,EAAE,4BAA4B,EAAE,KAAK,OAAOqD,CAAK,GAAG,OAAO,OAAO,KAAK,UAAU,EAAA,CAAG;AAAA,IAC1F;AAAA;AAAA;AAAA;AAAA;AAAA,IAMA,kBAAkB;AAChB,aAAO,CAAC,CAAC,KAAK,OAAO,aAAa,KAAK,CAAC,CAAC,KAAK,OAAO,YAAY;AAAA,IACnE;AAAA;AAAA;AAAA;AAAA,IAKA,kBAAkB;AAChB,aAAO,CAAC,KAAK,sBAAsB,CAAC,KAAK;AAAA,IAC3C;AAAA;AAAA;AAAA;AAAA,IAKA,kBAAkB;AAChB,aAAO,KAAK,cAAc,IAAI,CAACC,MAASA,EAAK,KAAK,WAAW,CAAC;AAAA,IAChE;AAAA;AAAA;AAAA;AAAA,IAKA,eAAe;AACb,aAAO,KAAK,UAAU,IAAI,CAACA,MAASA,EAAK,KAAK,WAAW,CAAC;AAAA,IAC5D;AAAA,IAEA,mBAAmB;AACjB,aAAI,KAAK,eACA,KAAK,aAAa,KAAK,KAAK,eAAe,KAAK,gBAAgB,SAGlE,KAAK,aAAa,KAAK,KAAK,aAAa,MAAM,CAACC,MAAO,KAAK,gBAAgB,SAASA,CAAE,CAAC;AAAA,IACjG;AAAA,IAEA,oBAAoB;AAClB,aAAI,KAAK,eACA,KAAK,aAAa,KAAK,KAAK,gBAAgB,SAAS,IAGvD,KAAK,aAAa,KAAK,KAAK,aAAa,KAAK,CAACA,MAAO,KAAK,gBAAgB,SAASA,CAAE,CAAC;AAAA,IAChG;AAAA,IAEA,kBAAkB;AAChB,aAAO,OAAO,KAAK,KAAK,OAAO,EAAE,OAAO,CAACC,GAAKF,MAAS;AACrD,cAAMG,IAAW,KAAK,QAAQH,CAAI,EAAE,UAC9BI,IAAY,OAAOD,EAAS,CAAC,KAAM,WACnCE,IAAW,KAAK,QAAQL,CAAI,EAAE,eAAe,eAC7CM,IAAU,CAAC,KAAK,QAAQN,CAAI,EAAE,WAAW,QACzCO,IAA2B,KAAK,QAAQP,CAAI,EAAE,eAAe,sBAAsBG,EAAS,CAAC,MAAM;AAOzG,eAAIG,KAAWC,IACNL,IAGLE,KAAa,OAAOD,EAAS,CAAC,KAAM,WAE/BD,KAAOC,EAAS,CAAC,KAAK,CAACE,IAAW,IAAI,KAGxCH,KAAOC,EAAS,UAAU;AAAA,MACnC,GAAG,CAAC;AAAA,IACN;AAAA,IAEA,qBAAqB;AACnB,aAAO,CAAC,CAAC,KAAK;AAAA,IAChB;AAAA,IAEA,sBAAsB;AACpB,aAAO,KAAK,qBAAqB,gBAAgB,KAAK,aAAa;AAAA,IACrE;AAAA,IAEA,wBAAwB;AACtB,aAAO,CAAC,CAAC,KAAK,OAAO,oBAAoB;AAAA,IAC3C;AAAA,IAEA,aAAa;AACX,aAAO,OAAO,KAAK,KAAK,KAAK,EAAE,SAAS;AAAA,IAC1C;AAAA,IAEA,qBAAqB;AACnB,aAAO,KAAK,cAAc;AAAA,IAC5B;AAAA,IAEA,eAAe;AAEb,aAAI,KAAK,sBACA,OAGF,KAAK,sBAAsB,WAAW3B,EAAUC,EAAS,iBAAiB,CAAC;AAAA,IACpF;AAAA;EAGF,OAAO;AAAA,IACL,iBAAiB9B,GAAO;AACtB,MAAK,KAAK,qBACR6C,EAAkB,IAAI,gBAAgB7C,CAAK;AAAA,IAE/C;AAAA,IAEA,OAAO;AAAA,MACL,UAAU;AACR,aAAK,gBAAgB6D,EAAU,KAAK,KAAK;AAAA,MAC3C;AAAA,MACA,WAAW;AAAA,MACX,MAAM;AAAA;IAGR,eAAe;AAAA,MACb,UAAU;AACR,YAAI,KAAK,cAAc;AACrB,eAAK,UAAU,KAAK,eAEpB,KAAK,aAAa;AAAA,YAChB,MAAM,KAAK;AAAA,YACX,SAAS,KAAK;AAAA,YACd,QAAQ,KAAK;AAAA,UACf,CAAC;AAED;AAAA,QACF;AAEA,cAAM,EAAE,WAAAC,EAAQ,IAAMC,GAAU;AAAA,UAC9B,OAAOC,EAAS,MAAM,KAAK,aAAa;AAAA,UACxC,YAAY,KAAK,qBAAqB,SAAS,SAC3C,KAAK,qBAAqB,WAC1B,CAAC,KAAK,SAAS;AAAA,UACnB,SAAS,KAAK;AAAA,QAChB,CAAC;AAED,aAAK,YAAY,CAACC,MAAeH,EAAUG,GAAY,EAAE,OAAO,KAAK,aAAa,GAElF,KAAK,eAAc;AAAA,MACrB;AAAA,MACA,WAAW;AAAA;IAGb,WAAW;AACT,MAAI,KAAK,gBAIT,KAAK,eAAc;AAAA,IACrB;AAAA,IAEA,OAAO;AAAA,MACL,QAAQjE,GAAO;AACb,cAAMkE,IAAY,OAAO,KAAKlE,CAAK;AAEnC,aAAK,WAAW,KAAK,cAAckE,EAAU,SAASA,EAAU,CAAC,IAAI;AAAA,MACvE;AAAA,MACA,WAAW;AAAA;;EAIf,UAAU;AACR,QAAI,KAAK,cAAc;AACrB,UAAI,KAAK,mBAAmB;AAC1B,cAAM,IAAI,MAAM,6DAA6D;AAG/E;AAAA,IACF;AAEA,QAAI,KAAK,aAAa,UAAU,KAAK,cAAc;AACjD,YAAM,IAAI,MAAM,qDAAqD;AAGvE,IAAI,KAAK,cACP,KAAK,SAAQ;AAAA,EAEjB;AAAA,EAEA,SAAS;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAMP,MAAM,iBAAiB;AACrB,UAAI,KAAK,aAAa,QAAQ;AAC5B,aAAK,8BAA8B;AACnC,YAAIC;AAEJ,YAAI;AACF,UAAAA,IAAiB,MAAM,KAAK,aAAa,OAAO,EAAE,QAAQ,KAAK,YAAY;AAAA,QAC7E,UAAA;AACE,eAAK,8BAA8B;AAAA,QACrC;AAEA,aAAK,UAAU,KAAK,UAAU,KAAK,aAAYA,KAAA,gBAAAA,EAAgB,YAAW,CAAA,CAAE,CAAC;AAAA,MAC/E;AACE,aAAK,UAAU,KAAK,UAAU,KAAK,YAAY,KAAK,UAAU,KAAK,UAAU,CAAC,CAAC;AAGjF,WAAK,aAAa;AAAA,QAChB,MAAM,KAAK;AAAA,QACX,SAAS,KAAK;AAAA,QACd,QAAQ,KAAK;AAAA,MACf,CAAC;AAAA,IACH;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOA,YAAYC,GAAO;AACjB,aAAOC,GAAaD,GAAO,KAAK,OAAO;AAAA,IACzC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOA,UAAUA,GAAO;AACf,aAAO,KAAK,WAAWE,GAAWF,GAAO,KAAK,MAAM,KAAK,QAAQ,CAAC,IAAIA;AAAA,IACxE;AAAA,IAEA,OAAO,EAAE,SAAAG,IAAU,OAAO,CAAA,GAAI;AAC5B,YAAM,EAAE,aAAAC,GAAa,SAAAC,GAAS,YAAAC,GAAY,UAAAC,GAAU,YAAAV,GAAY,UAAAW,MAAa,MAEvEC,IAAS;AAAA,QACb,SAAAJ;AAAA,QACA,YAAAC;AAAA,QACA,MAAM;AAAA,UACJ,QAAQF;AAAA,UACR,gBAAgB,KAAK;AAAA,UACrB,MAAMG;AAAA;QAER,QAAQV;AAAA,QACR,MAAMW;AAAA,QACN,SAAAL;AAAA;AAGF,WAAK,MAAM,UAAUM,CAAM;AAAA,IAC7B;AAAA;AAAA;AAAA;AAAA,IAKA,MAAM,kBAAkB;;AACtB,WAAK,aAAa,IAClB,QAAMC,KAAAlC,IAAA,KAAK,QAAO,sBAAZ,gBAAAkC,EAAA,KAAAlC,KACN,KAAK,SAAQ;AAAA,IACf;AAAA;AAAA;AAAA;AAAA,IAKA,QAAQ;AAON,UANA,KAAK,MAAM,cAAc,GAEzB,KAAK,aAAa,IAElB,KAAK,QAAQ,EAAE,YAAY,EAAA,CAAG,GAE1B,KAAK,cAAc;AACrB,aAAK,OAAO,EAAE,SAASmC,EAAqB,MAAI,CAAG;AAEnD;AAAA,MACF;AAEA,WAAK,eAAc;AAAA,IACrB;AAAA,IAEA,qBAAqB;;AACnB,OAAAD,KAAAlC,IAAA,KAAK,QAAO,uBAAZ,QAAAkC,EAAA,KAAAlC,GAAiC,KAAK;AAAA,IACxC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAUA,WAAW;AACT,WAAK,MAAM,UAAU,aAAa,EAAE,SAASmC,EAAqB,QAAQ;AAAA,IAC5E;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAYA,MAAM,SAAS,EAAE,SAAAR,IAAUQ,EAAqB,UAAU,CAAA,GAAI;AAO5D,UANA,KAAK,QAAQ,EAAE,YAAY,EAAA,CAAG,GAC9B,KAAK,OAAO,EAAE,SAAAR,GAAS,GACvB,KAAK,YAAY,KAAK,UAAU,GAChC,KAAK,aAAa,KAAK,OAAO,GAC9B,KAAK,gBAAgB,CAAA,GAEjB,MAAK,cAIT;AAAA,YAAI;AACF,eAAK,cAAc,IACnB,MAAM,KAAK,eAAe,EAAE,SAAAA,GAAS;AAAA,QACvC,UAAA;AACE,eAAK,cAAc;AAAA,QACrB;AAEA,aAAK,MAAM,iBAAiB,KAAK,UAAU,GAC3C,KAAK,MAAM,iBAAiB,KAAK,OAAO,GACxC,KAAK,MAAM,kBAAkB,KAAK,OAAO,GACzC,KAAK,cAAa;AAAA;AAAA,IACpB;AAAA,IAEA,uBAAuB;AACrB,WAAK,mBAAmB,CAAC,KAAK,kBAE9B,KAAK,MAAM,wBAAwB;AAAA,QACjC,kBAAkB,KAAK;AAAA,MACzB,CAAC;AAAA,IACH;AAAA;AAAA;AAAA;AAAA;AAAA,IAMA,eAAe;AAIb,WAAK,UAAU,MAAM;AACnB,aAAK,mBAAmB,GAAG,KAAK,MAAM,YAAY,cAAc,EAAO;AAAA,MACzE,CAAC;AAAA,IACH;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOA,OAAOS,GAAM;AACX,MAAIA,MAAS,KAAK,aAIlB,KAAK,WAAWA,GAEhB,KAAK,MAAM,eAAeA,CAAI,GAC9B,KAAK,UAAUA,CAAI,GACnB,KAAK,cAAa,GAClB,KAAK,QAAQ,EAAE,YAAY,EAAA,CAAG,GAC9B,KAAK,OAAO,EAAE,SAASD,EAAqB,KAAG,CAAG;AAAA,IACpD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAQA,QAAQ,EAAE,YAAAE,GAAY,aAAAC,IAAc,GAAI,IAAM,CAAA,GAAI;AAChD,WAAK,eAAe,KAAK,aAEzB,KAAK,cAAcD,GAEd,KAAK,gBACR,KAAK,MAAM,eAAeA,CAAU,GAGlCC,KACF,KAAK,OAAO,EAAE,SAASH,EAAqB,KAAG,CAAG;AAAA,IAEtD;AAAA;AAAA;AAAA;AAAA,IAKA,cAAc;AACZ,MAAI,KAAK,MAAM,gBACb,KAAK,MAAM,aAAa,eAAe,EAAE,UAAU,UAAU,OAAO,UAAU;AAAA,IAElF;AAAA,IAEA,kBAAkBE,GAAY;AAC5B,WAAK,QAAQ,EAAE,YAAAA,GAAY,aAAa,GAAG,CAAG,GAC9C,KAAK,YAAW;AAAA,IAClB;AAAA;AAAA;AAAA;AAAA,IAKA,aAAajF,GAAO;AAGlB,UAFA,KAAK,MAAM,cAAcA,CAAK,GAE1BA,GAAO;AACT,cAAMoE,IAAQ,MAAM,KAAK,oBAAI,IAAI,CAAC,GAAG,KAAK,eAAe,GAAG,KAAK,SAAS,CAAC,CAAC;AAE5E,aAAK,gBAAgB,KAAK,YAAYA,CAAK;AAAA,MAC7C;AACE,aAAK,gBAAgB,KAAK,cAAc,OAAO,CAACf,MAAS,CAAC,KAAK,aAAa,SAASA,EAAK,KAAK,WAAW,CAAC,CAAC;AAAA,IAEhH;AAAA,IAEA,YAAY;AACV,WAAK,gBAAgB,KAAK,YAAY,KAAK,OAAO;AAAA,IACpD;AAAA;AAAA;AAAA;AAAA,IAKA,aAAa,EAAE,MAAAA,GAAM,OAAArD,KAAS;AAC5B,MAAI,KAAK,eAAeqD,CAAI,MAIxBrD,IACF,KAAK,cAAc,KAAKqD,CAAI,IAE5B,KAAK,gBAAgB,KAAK,cAAc;AAAA,QACtC,CAAC8B,MAAiBA,EAAa,KAAK,WAAW,MAAM9B,EAAK,KAAK,WAAW;AAAA;IAGhF;AAAA;AAAA;AAAA;AAAA,IAKA,gBAAgB;AACd,WAAK,MAAM,cAAc,GACzB,KAAK,gBAAgB,CAAA;AAAA,IACvB;AAAA,IAEA,YAAYe,GAAO;AACjB,aAAOA,EAAM,OAAO,CAACb,GAAKF,MAAU,KAAK,eAAeA,CAAI,IAAIE,IAAM,CAAC,GAAGA,GAAKF,CAAI,GAAI,CAAA,CAAE;AAAA,IAC3F;AAAA;GAmBO3C,KAAA,EAAA,OAAM,iEAAgE,GAtyBnFE,KAAA,CAAA,UAAA,GAo3BeM,KAAA,EAAA,OAAM,0FAAyF;EAp3B9G,KAAA;AAAA,EA65BkC,OAAM;;;;cApItCjB,EAsPM,OAAA,MAAA;AAAA,IApPIO,EAAA,uBAAuBA,EAAA,8BAD/BP,EAyHM,OAAA;AAAA,MAn5BV,KAAA;AAAA,MA4xBM,KAAI;AAAA,MACJ,OA7xBNC,EAAA,CA6xBY,WAAS,EAAA,cACSM,EAAA,uBAAuBA,EAAA,uBAAqB,CAAA;AAAA;MAG5DA,EAAA,4BADRP,EA0GM,OAAA;AAAA,QA14BZ,KAAA;AAAA,QAkyBQ,OAlyBRC,EAAA,CAkyBc,YAAU,CACPC,EAAA,2DAA2DK,EAAA,sBAAqB,CAAA,CAAA,CAAA;AAAA,QACzF,aAAU;AAAA;QAEVH,EAiFM,OAjFNK,IAiFM;AAAA,UA9EIF,EAAA,qBAAqB,qBAD7BM,EAyCQsE,GAAA;AAAA,YAj1BlB,KAAA;AAAA,YA0yBY,KAAI;AAAA,YA1yBhB,YA2yBqBrD,EAAA;AAAA,YA3yBrB,uBAAAsD,EAAA,CAAA,MAAAA,EAAA,CAAA,IAAA,CAAAC,MA2yBqBvD,EAAA,aAAUuD;AAAA,YACnB,OA5yBZpF,GA4yBkB,mDAAiD;AAAA,cAE/BC,EAAA,OAAM,cAAA;AAAA;oCAAsEK,EAAA;AAAA,gBAA2F,mDAAA,CAAAJ,EAAA,aAAa;AAAA;;YAD5M,aAAU;AAAA,YAQT,aAAWI,EAAA,qBAAqB;AAAA,YAChC,OAAOuB,EAAA;AAAA,YACP,aAAavB,EAAA,qBAAqB;AAAA,YAClC,SAAK6E,EAAA,CAAA,MAAAA,EAAA,CAAA,IAxzBlBE,EAAA,CAAAD,MAAA,CAwzB2B9E,EAAA,aAAaA,EAAA,SAAQ,GAAA,CAAA,OAAA,CAAA;AAAA,YACnC,UAAQA,EAAA;AAAA;YAEE,UACT,MAQS;AAAA,cAPDuB,EAAA,mBADR9B,EAQS,UAAA;AAAA,gBAp0BvB,KAAA;AAAA,gBA8zBgB,aAAU;AAAA,gBACT,OA/zBjBC,EA+zBwBC,EAAA,OAAM,cAAA,CAAA;AAAA,gBACb,UAAUK,EAAA;AAAA,gBACV,mCAAOA,EAAA,mBAAAA,EAAA,gBAAA,GAAAwB,CAAA;AAAA;gBAER1B,EAAqB2B,GAAA,EAAf,MAAK,QAAO,CAAA;AAAA,cAn0BlC,GAAA,IAAArB,EAAA,KAAAD,EAAA,IAAA,EAAA;AAAA,cAq0BcL,EAUSkF,GAAA;AAAA,gBATP,aAAU;AAAA,gBACT,UAAUhF,EAAA;AAAA,gBACV,OAx0BjBN,EAw0BwBC,EAAA,OAAM,eAAA,CAAA;AAAA,gBACb,SAAOK,EAAA;AAAA;gBAz0BxB,SAAAQ,EA20BgB,MAGE;AAAA,kBAHFV,EAGE2B,GAAA;AAAA,oBAFC,OA50BnB/B,wCA40BgE6B,EAAA,YAAW,CAAA;AAAA,oBACxD,MAAMA,EAAA,cAAW,YAAA;AAAA;;gBA70BpC,GAAA;AAAA;;YAAA,GAAA;AAAA,6FAAApB,EAAA,IAAA,EAAA;AAAA,UAq1BkBP,EAAA,aAAa,eADrBH,EA6BM,OAAA;AAAA,YAj3BhB,KAAA;AAAA,YAs1BY,OAt1BZC,GAs1BkB,wEAAsE;AAAA,cACpDC,EAAA,OAAM,mBAAA;AAAA,iBAAwCA,EAAA,OAAM,kCAAA,CAAA,GAAA,CAAA,CAAyCK,EAAA,qBAAqB,SAAQ;AAAA;;YAKlJF,EAoBQmF,GAAA;AAAA,cApBD,OAAM;AAAA,cAA0B,SAASjF,EAAA;AAAA;cA51B5D,SAAAQ,EA61Bc,MAkBS;AAAA,gBAlBTV,EAkBSkF,GAAA;AAAA,kBAjBP,WAAA;AAAA,kBACA,OAAM;AAAA,kBACN,OAAM;AAAA,kBACN,aAAU;AAAA,kBACT,UAAUzD,EAAA;AAAA,kBACV,SAAOvB,EAAA;AAAA;kBAn2BxB,SAAAQ,EAq2BgB,MAOE;AAAA,oBANMe,EAAA,oBADRjB,EAOEmB,GAAA;AAAA,sBA52BlB,KAAA;AAAA,sBAu2BkB,MAAK;AAAA,sBACJ,OAx2BnB/B,EAAA;AAAA,6CAw2BqE6B,EAAA,YAAW;AAAA,wBAAwBA,EAAA,mBAAgB,qBAAA;AAAA;oDAKxGjB,EAAkCmB,GAAA;AAAA,sBA72BlD,KAAA;AAAA,sBA62B6B,MAAK;AAAA;oBA72BlChB,EA62BkD,QAC/Bc,EAAA,UAAU,GAAA,CAAA;AAAA;kBA92B7B,GAAA;AAAA;;cAAA,GAAA;AAAA;mBAAApB,EAAA,IAAA,EAAA;AAAA,UAo3BUN,EAEM,OAFNa,IAEM;AAAA,YADJC,EAA6BhB,EAAA,QAAA,SAAA;AAAA;;QAKjCG,EAeS4B,GAAA;AAAA,UAfD,aAAU;AAAA,UAAmB,OA13B7ChC,EA03BoDC,EAAA,OAAM,gBAAA,CAAA;AAAA,UAAqB,eAAa4B,EAAA;AAAA;UA13B5F,SAAAf,EA23BU,MAaM;AAAA,YAbNX,EAaM,OAAA;AAAA,cAbD,OA33BfH,EAAA,CA23BqB,wBAA+BC,EAAA,OAAM,iBAAA,CAAA,CAAA;AAAA;cAC9CG,EAWEoF,GAAA;AAAA,gBAVA,KAAI;AAAA,gBACH,OA93BfxF,EAAA,EAAA,CA83ByBC,EAAA,OAAM,oBAAA,CAAA,GAAyBK,EAAA,uBAAuBA,EAAA,sBAAqB,CAAA;AAAA,gBACrF,iBAAeA,EAAA;AAAA,gBACf,iBAAeA,EAAA,aAAS,CAAKA,EAAA;AAAA,gBAC7B,uBAAqBJ,EAAA;AAAA,gBACrB,QAAQA,EAAA;AAAA,gBACR,qBAAmBA,EAAA;AAAA,gBACnB,UAAMiF,EAAA,CAAA,MAAAA,EAAA,CAAA,IAAA,CAAAC,MAAEvD,EAAA,UAAUuD;AAAA,gBAClB,SAAO9E,EAAA;AAAA,gBACP,UAAQA,EAAA;AAAA;;;UAt4BvB,GAAA;AAAA;eAAAG,EAAA,IAAA,EAAA;AAAA,MA64BcH,EAAA,8BADRP,EAMM,OAAA;AAAA,QAl5BZ,KAAA;AAAA,QA84BQ,OA94BRC,EAAA,CA84Bc,sBAAoB,CACjBC,EAAA,mEAAmEK,EAAA,oBAAmB,CAAA,CAAA,CAAA;AAAA;QAE/FW,EAAuChB,EAAA,QAAA,oBAAA;AAAA,eAj5B/CQ,EAAA,IAAA,EAAA;AAAA,aAAAA,EAAA,IAAA,EAAA;AAAA,IAs5BIQ,EAA4BhB,EAAA,QAAA,SAAA;AAAA,IAGpBK,EAAA,mBAAmB,OAAO,KAAKJ,EAAA,KAAK,EAAE,eAD9CH,EA4BM,OAAA;AAAA,MAp7BV,KAAA;AAAA,MA05BM,OA15BNC,EAAA,CA05BY,aACEM,EAAA,kBAAkBL,EAAA,OAAM,YAAA,IAAA,eAAA,CAAA;AAAA;MAErBK,EAAA,wBAAXP,EAAgE,OAAhE0F,IAAgE9E,EAAdL,EAAA,KAAK,GAAA,CAAA,KA75B7DG,EAAA,IAAA,EAAA;AAAA,MAi6Bc,OAAO,KAAKP,EAAA,KAAK,EAAE,eAD3BU,EAmBW8E,GAAA;AAAA,QAn7BjB,KAAA;AAAA,QAk6BS,OAl6BT1F,EAk6BgBC,EAAA,OAAO,QAAQ;AAAA,QACtB,OAAK,GAAKC,EAAA,SAAS,IAAI2B,EAAA,QAAQ;AAAA,QAn6BxC,cAo6BsBvB,EAAA;AAAA;QAp6BtB,SAAAQ,EAs6BQ,MAYK;AAAA,UAZLX,EAYK,MAAA;AAAA,YAZD,KAAI;AAAA,YAAc,OAAM;AAAA,YAAkB,OAt6BtDwF,cAs6ByE9D,EAAA,iBAAgB,CAAA;AAAA;oBAC/E9B,EAUK6F,GAAA,MAj7BfC,EAw6B0C,OAAO,KAAK3F,EAAA,KAAK,GAx6B3D,CAw6BoB4F,GAAYC,YADtBhG,EAUK,MAAA;AAAA,cARF,KAAKgG;AAAA,cACL,OA16Bb/F,EAAA,CAAA,EAAA,kCA06BwD8F,MAAejE,EAAA,SAAQ,GAC7D,2BAA2B,CAAA;AAAA;cAEjCzB,EAGSkF,GAAA;AAAA,gBAHD,QAAA;AAAA,gBAAO,OA76B3BtF,EAAA,CA66BiC,mBAA0BC,EAAA,OAAM,aAAA,CAAA,CAAA;AAAA,gBAAkB,SAAK,CAAAmF,OAAE9E,EAAA,OAAOwF,CAAU;AAAA;gBA76B3G,SAAAhF,EA86Bc,MAAgB;AAAA,kBA96B9BC,EAAAJ,EA86BiBmF,CAAU,IAAG,KAChB,CAAA;AAAA,kBAAYA,MAAejE,EAAA,iBAA3BjB,EAAwFmB,GAAA;AAAA,oBA/6BtG,KAAA;AAAA,oBA+6BmD,MAAK;AAAA,oBAAQ,OAAM;AAAA,wBA/6BtEtB,EAAA,IAAA,EAAA;AAAA;gBAAA,GAAA;AAAA;;;;QAAA,GAAA;AAAA,mDAAAA,EAAA,IAAA,EAAA;AAAA,aAAAA,EAAA,IAAA,EAAA;AAAA,IAu7BeH,EAAA,wBAAXP,EAkEM,OAAA;AAAA,MAz/BV,KAAA;AAAA,MAu7BiC,OAv7BjCC,EAu7BwCC,EAAA,OAAM,YAAA,CAAA;AAAA;cACxCF,EA8CS,UAAA;AAAA,QA5CP,aAAU;AAAA,QACT,OA37BTC,EAAA,CAAA;AAAA,UA27B4BC,EAAA,OAAO;AAAA;uBAA2CC,EAAA;AAAA;WAMhE,YAAY,CAAA;AAAA;QAElBC,EAYM,OAAA;AAAA,UAZA,OAn8BdH,EAAA,CAm8BqBC,EAAA,OAAM,uBAAA,GAAiC,uCAAuC,CAAA;AAAA;UAEjFC,EAAA,qBADRU,EAOEoF,GAAA;AAAA,YA38BZ,KAAA;AAAA,YAs8BY,OAt8BZhG,EAAA,CAs8BkB,WAEEC,EAAA,OAAM,YAAA,CAAA,CAAA;AAAA,YADb,SAASK,EAAA;AAAA,YAET,eAAeA,EAAA,qBAAiB,CAAKA,EAAA;AAAA,YACrC,oBAAgBA,EAAA;AAAA,oFA18B7BG,EAAA,IAAA,EAAA;AAAA,UA48BUN,EAEM,OAAA;AAAA,YAFD,OA58BfH,EAAA,CA48BqB,wBAA+BC,EAAA,OAAM,aAAA,CAAA,CAAA;AAAA;YAC9CgB,EAAiChB,EAAA,QAAA,aAAA;AAAA;;QAM7BC,EAAA,qBADRU,EAmBcqF,GAnBdC,EAmBc,EAr+BtB,KAAA,KAAA;AAAA,UAo9BiD,gBAAA,CAAAhG,EAAA,kBAAkBA,EAAA;AAAA,4BAA0BI,EAAA;AAAA,6BAA8BA,EAAA;AAAA,sBAA+BA,EAAA;AAAA,8BAAwBA,EAAA;AAAA,iCAAgCJ,EAAA;AAAA,qCAAmCA,EAAA;AAAA;UAS1O,QAAQI,EAAA,sBAAkB;AAAA,UAC1B,0BAAuBA,EAAA;AAAA,UACvB,0BAAuBA,EAAA;AAAA,UACvB,sBAAmBA,EAAA;AAAA;UAET,0BACT,MAAkE;AAAA,YAAlEW,EAAkEhB,EAAA,QAAA,gBAAA,EAAvC,eAAgB4B,EAAA,cAAa,CAAA;AAAA;UAn+BpE,GAAA;AAAA,uGAAApB,EAAA,IAAA,EAAA;AAAA;YAy7BkBH,EAAA,YAAY;AAAA;YA+CxBM,EAx+BNuF,EAy+BajG,EAAA,gBAAa,QAAA,gBAAA,GAAA;AAAA,QACjB,oBAAkBA,EAAA;AAAA,QAClB,SAASI,EAAA;AAAA,QACT,SAASA,EAAA;AAAA;QA5+BlB,SAAAQ,EA8+BQ,MASQ;AAAA,UATRG,EASQhB,EAAA,QAAA,cAAA;AAAA,YAPL,UAAWK,EAAA;AAAA,YACX,cAAeuB,EAAA;AAAA,YACf,YAAavB,EAAA;AAAA,YACb,gBAAkBJ,EAAA;AAAA,YAClB,SAASI,EAAA;AAAA,YACT,UAAWA,EAAA;AAAA,YACX,eAAgBuB,EAAA;AAAA;;QAt/B3B,GAAA;AAAA;aAAApB,EAAA,IAAA,EAAA;AAAA,IA4/BIQ,EASQhB,EAAA,QAAA,WAAA;AAAA,MARL,aAAc4B,EAAA;AAAA,MACd,cAAeA,EAAA;AAAA,MACf,SAASA,EAAA;AAAA,MACT,YAAavB,EAAA;AAAA,MACb,gBAAkBJ,EAAA;AAAA,MAClB,SAASI,EAAA;AAAA,MACT,YAAauB,EAAA;AAAA,MACb,OAAOvB,EAAA;AAAA;IAKFA,EAAA,aAAaJ,EAAA,iBADrBU,EAMEwF,GAAA;AAAA,MA9gCN,KAAA;AAAA,MA0gCO,gBAAcvE,EAAA;AAAA,MACd,eAAavB,EAAA;AAAA,MACb,aAAWJ,EAAA;AAAA,MACX,WAAUI,EAAA;AAAA,8EA7gCjBG,EAAA,IAAA,EAAA;AAAA;;;;;"}
|
|
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:flex\"\n :class=\"[\n $style['select-bar'],\n {\n 'lg:hidden': hideBulkActionOptions,\n },\n 'p-3',\n ]\"\n >\n <div\n class=\"flex items-center\"\n :class=\"{\n 'justify-between': !hideBulkActionOptions,\n }\"\n >\n <ll-checkbox\n data-test=\"checkbox|bulk-actions\"\n :class=\"$style.checkbox\"\n class=\"m-0 lg:hidden\"\n :checked=\"isSomePageChecked && !!totalCount\"\n :indeterminate=\"isSomePageChecked && !isAllPageChecked\"\n :label=\"!totalSelectedCount ? selectAllText : ''\"\n @update:checked=\"onSelectPage\"\n />\n <div v-if=\"!!totalSelectedCount && !hideBulkActionOptions\" class=\"flex flex-1 items-center justify-between\">\n <div v-if=\"!hideNumberOfTotalSelected\" class=\"text-xs\">\n {{ numberOfTotalSelectedText }}\n </div>\n <div :class=\"{ '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=\"ml-1.5 lg: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 @reference \"../../../../styles/main.css\";\n\n @layer utilities {\n .select-bar {\n @media (width >= theme(--breakpoint-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: --spacing(6);\n width: 100%;\n\n @media (width >= theme(--breakpoint-lg)) {\n margin-left: --spacing(3);\n margin-top: 0;\n width: auto;\n }\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=\"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=\"max-w-full bg-white\" :text=\"emptyStateText\" />\n</template>\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 [$style['disable-external-gutters']]: disableExternalGutters,\n [$style['is-collapsed']]: !isExpanded,\n },\n ]\"\n >\n <header\n class=\"flex items-center\"\n :class=\"[$style['main-header'], { 'cursor-pointer': isCollapsible }]\"\n @click=\"onHeaderClick\"\n >\n <ll-button v-if=\"isCollapsible\" :class=\"['mr-1.5 text-ice-900', $style['expansion-toggle-button']]\" icon>\n <Icon :class=\"[isExpanded ? 'rotate-270' : 'rotate-180']\" name=\"chevron-left\" />\n </ll-button>\n\n <div class=\"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=\"relative w-full lg:shadow\">\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=\"ll-grid 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 @reference \"../../../../styles/main.css\";\n\n @layer utilities {\n .main-header {\n @apply shadow;\n\n background-color: var(--color-white);\n border-radius: var(--radius-sm);\n margin-bottom: --spacing(6);\n padding: var(--grid-gutter);\n\n @media (width >= theme(--breakpoint-lg)) {\n border-bottom: var(--border-width) 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-header {\n background-color: var(--color-white);\n border-bottom: var(--border-width) solid var(--color-ice-200);\n color: var(--color-ice-900);\n display: none;\n font-weight: 500;\n padding: 0 --spacing(3);\n transition: padding 150 var(--ease-swing);\n z-index: 1;\n\n @media (width >= theme(--breakpoint-lg)) {\n align-items: center;\n display: flex;\n }\n\n &:global(.is-sticky) {\n @apply shadow;\n\n border-radius: 0;\n z-index: calc(var(--z-index-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: var(--border-width) solid var(--color-ice-200);\n display: flex;\n font-size: var(--text-xs);\n justify-content: space-between;\n padding: --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 (width >= theme(--breakpoint-lg)) {\n border-radius: 0;\n }\n }\n\n .expanded-content-list-items-wrapper > * {\n @media (width >= theme(--breakpoint-lg)) {\n border-bottom: var(--border-width) 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 (width >= theme(--breakpoint-lg)) {\n border-bottom: none;\n border-bottom-left-radius: var(--radius-sm);\n border-bottom-right-radius: var(--radius-sm);\n }\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=\"['cursor-pointer', { 'bg-blue-100': isSorted }]\" @click=\"sort\">\n <slot></slot>\n <div class=\"relative h-4 w-3 text-ice-700\" :class=\"{ 'is-active-sort': isSorted }\">\n <ll-icon\n v-if=\"showCaretUp\"\n name=\"caret-up\"\n class=\"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=\"absolute\"\n :class=\"[$style.caret, $style['caret-down']]\"\n size=\"dense\"\n />\n </div>\n </div>\n</template>\n\n<style module>\n @layer utilities {\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 }\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 if (this.$refs.scrollTarget) {\n this.$refs.scrollTarget.scrollIntoView({ behavior: 'smooth', block: 'center' });\n }\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=\"mb-6\"\n :class=\"{ 'll-grid': showPrimaryControls && showSecondaryControls }\"\n >\n <div\n v-if=\"showPrimaryControls\"\n class=\"controls\"\n :class=\"[$style['legacy-box'], { 'col-span-12 lg:col-span-6': showSecondaryControls }]\"\n data-test=\"filters|controls\"\n >\n <div class=\"ll-grid grid-cols-4 md:grid-cols-8 lg:grid-cols-12\">\n <!-- Search -->\n <Input\n v-if=\"internalSearchSchema.isSearchable\"\n ref=\"search-input\"\n v-model=\"searchTerm\"\n class=\"col-span-3 md:col-span-6 lg:col-span-4\"\n data-test=\"input|search-input\"\n :class=\"[\n $style['search-input'],\n {\n 'lg:col-span-8': showSecondaryControls,\n 'col-span-4 md:col-span-8 lg:col-span-6': !filterSchema.length,\n },\n ]\"\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=\"{ 'animate-spin 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=\"col-span-1 flex items-end md:col-span-2 lg:col-span-1\"\n :class=\"[\n $style['filter-toggle-btn'],\n { [$style['filter-toggle-btn-with-hint-text']]: !!internalSearchSchema.hintText },\n ]\"\n >\n <Badge class=\"w-full lg:w-auto\" :content=\"numberOfFilters\">\n <Button\n secondary\n class=\"relative w-full 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=\"[{ 'animate-spin': isFiltering }, isShowingFilters ? 'text-teal-500' : 'text-ice-700']\"\n />\n <Icon v-else name=\"filter-line\" />\n {{ filterText }}\n </Button>\n </Badge>\n </div>\n\n <!-- Actions -->\n <div class=\"button-grid col-span-1 items-end justify-end md:col-span-6 lg: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=\"relative 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'], { 'col-span-12 mt-0 lg: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=\"mb-1.5\"\n :class=\"shouldShowTotal ? $style['total-sort'] : 'text-right'\"\n >\n <div v-if=\"shouldShowTotal\" class=\"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=\"{ 'bg-blue-100 text-ice-700': sortOption === sortTerm }\"\n class=\"dropdown__item rounded\"\n >\n <Button inline class=\"items-center\" :class=\"$style['sort-option']\" @click=\"onSort(sortOption)\">\n {{ sortOption }}\n <Icon v-if=\"sortOption === sortTerm\" name=\"check\" class=\"ml-auto 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 'm-0': !isSelectable,\n },\n ]\"\n class=\"rounded\"\n >\n <div :class=\"$style['header-grid-container']\" class=\"border-b border-ice-200 px-3\">\n <Checkbox\n v-if=\"isSelectable\"\n class=\"ml-3\"\n :checked=\"isSomePageChecked\"\n :class=\"$style['select-all']\"\n :indeterminate=\"isSomePageChecked && !isAllPageChecked\"\n @update:checked=\"onSelectPage\"\n />\n <div class=\"ll-grid 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: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 @reference \"../../../styles/main.css\";\n\n @layer utilities {\n .list-items {\n background-color: var(--color-ice-200);\n border-bottom-left-radius: var(--radius-sm);\n border-bottom-right-radius: var(--radius-sm);\n min-width: 100%;\n position: relative;\n }\n\n @media (width >= theme(--breakpoint-lg)) {\n .list-items {\n @apply shadow;\n }\n }\n\n /* the .legacy-box styles are copied from .box in _box.scss */\n .legacy-box {\n @apply shadow;\n\n background: var(--color-white);\n border-radius: var(--radius-sm);\n padding: --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: --spacing(3);\n overflow: hidden;\n z-index: 1;\n\n &:global(.is-sticky) {\n @apply shadow;\n\n border-radius: 0;\n overflow: visible;\n z-index: calc(var(--z-index-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: --spacing(3);\n\n @media (width >= theme(--breakpoint-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: --spacing(6);\n }\n }\n\n @media (width >= theme(--breakpoint-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 150 var(--ease-swing);\n\n @media (width >= theme(--breakpoint-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: var(--text-xs);\n justify-content: space-between;\n padding: --spacing(3);\n\n &:first-of-type {\n margin-left: calc(-1 * --spacing(3));\n padding-left: --spacing(6);\n }\n\n &:last-of-type {\n border-right: 0;\n margin-right: calc(-1 * --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(var(--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 --spacing(1.5);\n width: 36px;\n\n &:disabled {\n border-color: var(--color-ice-500);\n }\n }\n }\n }\n\n @media (width >= theme(--breakpoint-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 300 var(--ease-in-out) 0.5s 1 forwards;\n background: var(--color-ice-200);\n content: '';\n height: var(--border-width);\n left: calc(var(--grid-gutter) * -1);\n opacity: 0;\n position: absolute;\n right: calc(var(--grid-gutter) * -1);\n top: --spacing(6);\n }\n }\n\n .filters-half-width {\n @media (width >= theme(--breakpoint-lg)) {\n :global(.field-wrapper) {\n grid-column: span 6 / span 6; /* col-span-6 */\n }\n }\n }\n\n .dropdown :global(.text-blue-500) {\n font-size: var(--text-xs);\n }\n\n .sort-option {\n height: --spacing(9);\n }\n\n .select-all {\n width: --spacing(6);\n }\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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"}
|
package/dist/ListView.vue.d.ts
CHANGED
|
@@ -282,7 +282,6 @@ default: undefined;
|
|
|
282
282
|
checked: {
|
|
283
283
|
type: PropType<boolean | (string | number)[]>;
|
|
284
284
|
required: true;
|
|
285
|
-
default: boolean;
|
|
286
285
|
};
|
|
287
286
|
}>> & Readonly<{
|
|
288
287
|
"onUpdate:checked"?: ((value: boolean | (string | number)[]) => any) | undefined;
|
|
@@ -297,7 +296,6 @@ errorText: string;
|
|
|
297
296
|
hintText: string;
|
|
298
297
|
modelValue: boolean | (string | number)[];
|
|
299
298
|
value: string | number;
|
|
300
|
-
checked: boolean | (string | number)[];
|
|
301
299
|
}, true, {}, {}, GlobalComponents, GlobalDirectives, string, {}, any, ComponentProvideOptions, {
|
|
302
300
|
P: {};
|
|
303
301
|
B: {};
|
|
@@ -341,7 +339,6 @@ default: undefined;
|
|
|
341
339
|
checked: {
|
|
342
340
|
type: PropType<boolean | (string | number)[]>;
|
|
343
341
|
required: true;
|
|
344
|
-
default: boolean;
|
|
345
342
|
};
|
|
346
343
|
}>> & Readonly<{
|
|
347
344
|
"onUpdate:checked"?: ((value: boolean | (string | number)[]) => any) | undefined;
|
|
@@ -354,7 +351,6 @@ errorText: string;
|
|
|
354
351
|
hintText: string;
|
|
355
352
|
modelValue: boolean | (string | number)[];
|
|
356
353
|
value: string | number;
|
|
357
|
-
checked: boolean | (string | number)[];
|
|
358
354
|
}>;
|
|
359
355
|
__isFragment?: undefined;
|
|
360
356
|
__isTeleport?: undefined;
|
|
@@ -395,7 +391,6 @@ default: undefined;
|
|
|
395
391
|
checked: {
|
|
396
392
|
type: PropType<boolean | (string | number)[]>;
|
|
397
393
|
required: true;
|
|
398
|
-
default: boolean;
|
|
399
394
|
};
|
|
400
395
|
}>> & Readonly<{
|
|
401
396
|
"onUpdate:checked"?: ((value: boolean | (string | number)[]) => any) | undefined;
|
|
@@ -410,7 +405,6 @@ errorText: string;
|
|
|
410
405
|
hintText: string;
|
|
411
406
|
modelValue: boolean | (string | number)[];
|
|
412
407
|
value: string | number;
|
|
413
|
-
checked: boolean | (string | number)[];
|
|
414
408
|
}, {}, string, {}, GlobalComponents, GlobalDirectives, string, ComponentProvideOptions> & VNodeProps & AllowedComponentProps & ComponentCustomProps & (new () => {
|
|
415
409
|
$slots: {
|
|
416
410
|
default?(_: {}): any;
|
|
@@ -1217,7 +1211,6 @@ default: undefined;
|
|
|
1217
1211
|
checked: {
|
|
1218
1212
|
type: PropType<boolean | (string | number)[]>;
|
|
1219
1213
|
required: true;
|
|
1220
|
-
default: boolean;
|
|
1221
1214
|
};
|
|
1222
1215
|
}>> & Readonly<{
|
|
1223
1216
|
"onUpdate:checked"?: ((value: boolean | (string | number)[]) => any) | undefined;
|
|
@@ -1232,7 +1225,6 @@ errorText: string;
|
|
|
1232
1225
|
hintText: string;
|
|
1233
1226
|
modelValue: boolean | (string | number)[];
|
|
1234
1227
|
value: string | number;
|
|
1235
|
-
checked: boolean | (string | number)[];
|
|
1236
1228
|
}, true, {}, {}, GlobalComponents, GlobalDirectives, string, {}, any, ComponentProvideOptions, {
|
|
1237
1229
|
P: {};
|
|
1238
1230
|
B: {};
|
|
@@ -1276,7 +1268,6 @@ default: undefined;
|
|
|
1276
1268
|
checked: {
|
|
1277
1269
|
type: PropType<boolean | (string | number)[]>;
|
|
1278
1270
|
required: true;
|
|
1279
|
-
default: boolean;
|
|
1280
1271
|
};
|
|
1281
1272
|
}>> & Readonly<{
|
|
1282
1273
|
"onUpdate:checked"?: ((value: boolean | (string | number)[]) => any) | undefined;
|
|
@@ -1289,7 +1280,6 @@ errorText: string;
|
|
|
1289
1280
|
hintText: string;
|
|
1290
1281
|
modelValue: boolean | (string | number)[];
|
|
1291
1282
|
value: string | number;
|
|
1292
|
-
checked: boolean | (string | number)[];
|
|
1293
1283
|
}>;
|
|
1294
1284
|
__isFragment?: undefined;
|
|
1295
1285
|
__isTeleport?: undefined;
|
|
@@ -1330,7 +1320,6 @@ default: undefined;
|
|
|
1330
1320
|
checked: {
|
|
1331
1321
|
type: PropType<boolean | (string | number)[]>;
|
|
1332
1322
|
required: true;
|
|
1333
|
-
default: boolean;
|
|
1334
1323
|
};
|
|
1335
1324
|
}>> & Readonly<{
|
|
1336
1325
|
"onUpdate:checked"?: ((value: boolean | (string | number)[]) => any) | undefined;
|
|
@@ -1345,7 +1334,6 @@ errorText: string;
|
|
|
1345
1334
|
hintText: string;
|
|
1346
1335
|
modelValue: boolean | (string | number)[];
|
|
1347
1336
|
value: string | number;
|
|
1348
|
-
checked: boolean | (string | number)[];
|
|
1349
1337
|
}, {}, string, {}, GlobalComponents, GlobalDirectives, string, ComponentProvideOptions> & VNodeProps & AllowedComponentProps & ComponentCustomProps & (new () => {
|
|
1350
1338
|
$slots: {
|
|
1351
1339
|
default?(_: {}): any;
|
|
@@ -1621,7 +1609,6 @@ default: undefined;
|
|
|
1621
1609
|
checked: {
|
|
1622
1610
|
type: PropType<boolean | (string | number)[]>;
|
|
1623
1611
|
required: true;
|
|
1624
|
-
default: boolean;
|
|
1625
1612
|
};
|
|
1626
1613
|
}>> & Readonly<{
|
|
1627
1614
|
"onUpdate:checked"?: ((value: boolean | (string | number)[]) => any) | undefined;
|
|
@@ -1636,7 +1623,6 @@ errorText: string;
|
|
|
1636
1623
|
hintText: string;
|
|
1637
1624
|
modelValue: boolean | (string | number)[];
|
|
1638
1625
|
value: string | number;
|
|
1639
|
-
checked: boolean | (string | number)[];
|
|
1640
1626
|
}, true, {}, {}, GlobalComponents, GlobalDirectives, string, {}, any, ComponentProvideOptions, {
|
|
1641
1627
|
P: {};
|
|
1642
1628
|
B: {};
|
|
@@ -1680,7 +1666,6 @@ default: undefined;
|
|
|
1680
1666
|
checked: {
|
|
1681
1667
|
type: PropType<boolean | (string | number)[]>;
|
|
1682
1668
|
required: true;
|
|
1683
|
-
default: boolean;
|
|
1684
1669
|
};
|
|
1685
1670
|
}>> & Readonly<{
|
|
1686
1671
|
"onUpdate:checked"?: ((value: boolean | (string | number)[]) => any) | undefined;
|
|
@@ -1693,7 +1678,6 @@ errorText: string;
|
|
|
1693
1678
|
hintText: string;
|
|
1694
1679
|
modelValue: boolean | (string | number)[];
|
|
1695
1680
|
value: string | number;
|
|
1696
|
-
checked: boolean | (string | number)[];
|
|
1697
1681
|
}>;
|
|
1698
1682
|
__isFragment?: undefined;
|
|
1699
1683
|
__isTeleport?: undefined;
|
|
@@ -1734,7 +1718,6 @@ default: undefined;
|
|
|
1734
1718
|
checked: {
|
|
1735
1719
|
type: PropType<boolean | (string | number)[]>;
|
|
1736
1720
|
required: true;
|
|
1737
|
-
default: boolean;
|
|
1738
1721
|
};
|
|
1739
1722
|
}>> & Readonly<{
|
|
1740
1723
|
"onUpdate:checked"?: ((value: boolean | (string | number)[]) => any) | undefined;
|
|
@@ -1749,7 +1732,6 @@ errorText: string;
|
|
|
1749
1732
|
hintText: string;
|
|
1750
1733
|
modelValue: boolean | (string | number)[];
|
|
1751
1734
|
value: string | number;
|
|
1752
|
-
checked: boolean | (string | number)[];
|
|
1753
1735
|
}, {}, string, {}, GlobalComponents, GlobalDirectives, string, ComponentProvideOptions> & VNodeProps & AllowedComponentProps & ComponentCustomProps & (new () => {
|
|
1754
1736
|
$slots: {
|
|
1755
1737
|
default?(_: {}): any;
|
|
@@ -2343,14 +2325,14 @@ fieldId: string;
|
|
|
2343
2325
|
}) => void; /**
|
|
2344
2326
|
* Make search fuzzy. Only for client side search.
|
|
2345
2327
|
*/
|
|
2346
|
-
hint: () =>
|
|
2328
|
+
hint: () => unknown;
|
|
2347
2329
|
}> & {
|
|
2348
2330
|
default: (props: {
|
|
2349
2331
|
fieldId: string;
|
|
2350
2332
|
}) => void; /**
|
|
2351
2333
|
* Make search fuzzy. Only for client side search.
|
|
2352
2334
|
*/
|
|
2353
|
-
hint: () =>
|
|
2335
|
+
hint: () => unknown;
|
|
2354
2336
|
};
|
|
2355
2337
|
});
|
|
2356
2338
|
'll-radio': DefineComponent<ExtractPropTypes< {
|
|
@@ -4399,7 +4381,6 @@ default: undefined;
|
|
|
4399
4381
|
checked: {
|
|
4400
4382
|
type: PropType<boolean | (string | number)[]>;
|
|
4401
4383
|
required: true;
|
|
4402
|
-
default: boolean;
|
|
4403
4384
|
};
|
|
4404
4385
|
}>> & Readonly<{
|
|
4405
4386
|
"onUpdate:checked"?: ((value: boolean | (string | number)[]) => any) | undefined;
|
|
@@ -4414,7 +4395,6 @@ errorText: string;
|
|
|
4414
4395
|
hintText: string;
|
|
4415
4396
|
modelValue: boolean | (string | number)[];
|
|
4416
4397
|
value: string | number;
|
|
4417
|
-
checked: boolean | (string | number)[];
|
|
4418
4398
|
}, true, {}, {}, GlobalComponents, GlobalDirectives, string, {}, any, ComponentProvideOptions, {
|
|
4419
4399
|
P: {};
|
|
4420
4400
|
B: {};
|
|
@@ -4458,7 +4438,6 @@ default: undefined;
|
|
|
4458
4438
|
checked: {
|
|
4459
4439
|
type: PropType<boolean | (string | number)[]>;
|
|
4460
4440
|
required: true;
|
|
4461
|
-
default: boolean;
|
|
4462
4441
|
};
|
|
4463
4442
|
}>> & Readonly<{
|
|
4464
4443
|
"onUpdate:checked"?: ((value: boolean | (string | number)[]) => any) | undefined;
|
|
@@ -4471,7 +4450,6 @@ errorText: string;
|
|
|
4471
4450
|
hintText: string;
|
|
4472
4451
|
modelValue: boolean | (string | number)[];
|
|
4473
4452
|
value: string | number;
|
|
4474
|
-
checked: boolean | (string | number)[];
|
|
4475
4453
|
}>;
|
|
4476
4454
|
__isFragment?: undefined;
|
|
4477
4455
|
__isTeleport?: undefined;
|
|
@@ -4512,7 +4490,6 @@ default: undefined;
|
|
|
4512
4490
|
checked: {
|
|
4513
4491
|
type: PropType<boolean | (string | number)[]>;
|
|
4514
4492
|
required: true;
|
|
4515
|
-
default: boolean;
|
|
4516
4493
|
};
|
|
4517
4494
|
}>> & Readonly<{
|
|
4518
4495
|
"onUpdate:checked"?: ((value: boolean | (string | number)[]) => any) | undefined;
|
|
@@ -4527,7 +4504,6 @@ errorText: string;
|
|
|
4527
4504
|
hintText: string;
|
|
4528
4505
|
modelValue: boolean | (string | number)[];
|
|
4529
4506
|
value: string | number;
|
|
4530
|
-
checked: boolean | (string | number)[];
|
|
4531
4507
|
}, {}, string, {}, GlobalComponents, GlobalDirectives, string, ComponentProvideOptions> & VNodeProps & AllowedComponentProps & ComponentCustomProps & (new () => {
|
|
4532
4508
|
$slots: {
|
|
4533
4509
|
default?(_: {}): any;
|
package/dist/Loading.js
CHANGED
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
import { defineComponent as t, useCssModule as s, createElementBlock as e, openBlock as n, createElementVNode as o, normalizeClass as r, unref as c, createStaticVNode as i } from "vue";
|
|
2
|
-
import { _ as
|
|
3
|
-
const
|
|
4
|
-
class: "stash-loading
|
|
2
|
+
import { _ as p } from "./_plugin-vue_export-helper-CHgC5LLL.js";
|
|
3
|
+
const d = {
|
|
4
|
+
class: "stash-loading flex justify-center py-12",
|
|
5
5
|
"data-test": "ll-loading"
|
|
6
6
|
}, h = /* @__PURE__ */ t({
|
|
7
7
|
name: "ll-loading",
|
|
8
8
|
__name: "Loading",
|
|
9
|
-
setup(
|
|
9
|
+
setup(M) {
|
|
10
10
|
const l = s();
|
|
11
|
-
return (
|
|
11
|
+
return (g, a) => (n(), e("div", d, [
|
|
12
12
|
o("div", {
|
|
13
13
|
class: r(["stash-loading__spinner", c(l).spinner])
|
|
14
14
|
}, a[0] || (a[0] = [
|
|
@@ -16,12 +16,12 @@ const p = {
|
|
|
16
16
|
]), 2)
|
|
17
17
|
]));
|
|
18
18
|
}
|
|
19
|
-
}), m = "
|
|
19
|
+
}), m = "_spinner_mrep5_15", _ = "_loading_mrep5_1", f = {
|
|
20
20
|
spinner: m,
|
|
21
21
|
loading: _
|
|
22
|
-
},
|
|
22
|
+
}, Z = {
|
|
23
23
|
$style: f
|
|
24
|
-
}, y = /* @__PURE__ */
|
|
24
|
+
}, y = /* @__PURE__ */ p(h, [["__cssModules", Z]]);
|
|
25
25
|
export {
|
|
26
26
|
y as default
|
|
27
27
|
};
|