@leaflink/stash 44.0.0-beta.10 → 44.0.0-beta.11

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/Filters.js CHANGED
@@ -236,7 +236,7 @@ const ie = {
236
236
  H.set("filter-values", G(l));
237
237
  }
238
238
  }
239
- }, se = { class: "ll-grid tw-grid-cols-4 md:tw-grid-cols-12" }, re = ["data-test"], ae = ["innerHTML"], ne = ["innerHTML"];
239
+ }, se = { class: "tw-ll-grid tw-grid-cols-4 md:tw-grid-cols-12" }, re = ["data-test"], ae = ["innerHTML"], ne = ["innerHTML"];
240
240
  function de(l, r, o, i, t, s) {
241
241
  var u;
242
242
  const p = y("ll-select"), c = y("ll-checkbox"), m = y("ll-radio"), h = y("ll-button");
@@ -1 +1 @@
1
- {"version":3,"file":"Filters.js","sources":["../src/components/Filters/Filters.vue"],"sourcesContent":["<script>\n import cloneDeep from 'lodash-es/cloneDeep';\n import merge from 'lodash-es/merge';\n import { nextTick, ref, toRefs } from 'vue';\n\n import useValidation from '../../composables/useValidation/useValidation';\n import { LLLV_CHANGE_TRIGGERS } from '../../constants';\n import { t } from '../../locale';\n import { persistentStorage } from '../../storage';\n import Button from '../Button/Button.vue';\n import Checkbox from '../Checkbox/Checkbox.vue';\n import DatePicker from '../DatePicker/DatePicker.vue';\n import Input from '../Input/Input.vue';\n import InputOptions from '../InputOptions/InputOptions.vue';\n import Radio from '../Radio/Radio.vue';\n import Select from '../Select/Select.vue';\n\n export default {\n name: 'll-filters',\n\n components: {\n 'll-button': Button,\n 'll-checkbox': Checkbox,\n 'll-input': Input,\n 'll-input-options': InputOptions,\n 'll-radio': Radio,\n 'll-select': Select,\n DatePicker,\n },\n\n props: {\n /**\n * Whether to disable the Apply button\n */\n disableApply: Boolean,\n /**\n * Whether to disable the Clear button\n */\n disableClear: Boolean,\n /**\n * Whether to disable the sticky filters\n * If disabled, a default pre-selected value(s) can be added to\n * the filter component's attributes\n */\n disablePersistency: Boolean,\n /**\n * Filters schema\n */\n schema: {\n type: Array,\n default: () => [],\n },\n /**\n * Validation schema function that returns an object\n */\n validationSchema: {\n type: Function,\n default: () => () => undefined,\n },\n },\n\n emits: ['change', 'submit', 'reset'],\n\n setup(props) {\n const { validationSchema: getValidationSchema } = toRefs(props);\n const validationSchema = getValidationSchema.value();\n const validationValues = ref({});\n\n // Without ref, `this.validation` will always evaluate to its initial value of `undefined` due to lack of reactivity.\n const validation = ref();\n\n function initValidation() {\n if (validationSchema?.toString() !== '[object Object]') {\n return;\n }\n\n validationValues.value = Object.keys(validationSchema).reduce((values, fieldName) => {\n values[fieldName] = undefined;\n\n return values;\n }, {});\n\n const validationRules = Object.entries(validationSchema).reduce((rules, [fieldName, fieldRules]) => {\n rules[fieldName] = fieldRules.map((fieldRule) => {\n return fieldRule(validationValues);\n });\n\n return rules;\n }, {});\n\n validation.value = useValidation({ rules: validationRules, values: validationValues });\n validation.value.validate();\n }\n\n return {\n validation,\n validationValues,\n initValidation,\n };\n },\n\n data() {\n return {\n applyText: t('ll.apply'),\n clearText: t('ll.clear'),\n filters: {},\n filterValues: {},\n forceRenderCount: 0,\n };\n },\n\n watch: {\n filterValues: {\n /**\n * Maps filters to a partcular object structure:\n * @param {IFilterSchemaItem} newFilterValues all selected filters\n * @returns {IFilter}\n */\n handler: function (newFilterValues) {\n const filters = Object.keys(newFilterValues).reduce((acc, i) => {\n const schema = this.schema[i];\n\n if (!schema || !schema.fieldToFilter) {\n return acc;\n }\n\n const item = newFilterValues[i];\n\n // Ignore empty string or undefined/null filter values\n if (item === '' || item == null) {\n return acc;\n }\n\n const trackBy = schema.attributes.trackBy || 'id';\n const isObject = typeof item === 'object';\n const isCustomFilterComponent = typeof schema.type === 'object';\n // TODO: remove handling of schema.attributes.multiple when we remove the vue-multiselect version of Select\n const isMultiple =\n (isCustomFilterComponent && schema.attributes.multiple) ||\n (!isCustomFilterComponent &&\n schema.type.includes('ll-select') &&\n (schema.attributes.multiple || !schema.attributes.single));\n const filterBy = isMultiple\n ? // local storage might have item stored as an object from the old Select\n (Array.isArray(item) ? item : [item]).map((v) => v[trackBy])\n : isObject\n ? [item[trackBy]]\n : [item];\n\n const groupedWith = schema.groupedWith;\n\n if (groupedWith) {\n filterBy[0] = {\n index: groupedWith,\n value: newFilterValues[groupedWith],\n };\n filterBy.push({\n index: Number(i),\n value: newFilterValues[i],\n });\n }\n\n filterBy.length &&\n (acc[schema.fieldToFilter] = {\n // don't add to `filters` if no filterBy\n filterBy,\n filterType: schema.type, // Informs the applied filter count\n isMultiple,\n ...('fn' in schema && { customFilter: schema.fn }),\n });\n\n return acc;\n }, {});\n\n this.filters = filters;\n this.$emit('change', filters);\n },\n\n deep: true,\n immediate: true,\n },\n\n filters() {\n if (this.validation) {\n this.updateValidationValues();\n }\n },\n },\n\n async created() {\n // initFilterValues updates the filterValues so using await nextTick() forces the code\n // after it to wait until nextTick is done, at which point the filterValues will\n // be done initializing. Otherwise, applyFilters sometimes applies the wrong\n // filters because filterValues is not done updating.\n this.initFilterValues();\n await nextTick();\n this.initValidation();\n this.applyFilters({ trigger: LLLV_CHANGE_TRIGGERS.LOAD });\n },\n\n methods: {\n initFilterValues() {\n if (this.disablePersistency) {\n this.filterValues = this.getDefaultFilterValues();\n\n return;\n }\n\n this.filterValues = this.getPersistentFilterValues() || this.getDefaultFilterValues();\n },\n\n /**\n * Apply the selected filters and save them to localStorage.\n * ListView calls this method using a ref to Filters.\n * The trigger option is used in ListView.\n * @param {object} [options] - optional parameters\n * @param {string} [options.trigger] - the action that triggered this function call\n */\n async applyFilters({ trigger = LLLV_CHANGE_TRIGGERS.APPLY } = {}) {\n if (this.validation) {\n await this.validation.validate();\n\n if (this.validation.hasErrors) {\n return;\n }\n }\n\n if (!this.disablePersistency) {\n this.persistFilterValues(this.filterValues);\n }\n\n this.$emit('submit', { trigger });\n },\n\n resetFilters() {\n this.filterValues = this.getDefaultFilterValues();\n\n this.forceRenderCount++;\n\n if (!this.disablePersistency) {\n this.persistFilterValues(this.filterValues);\n }\n\n // Emit after filters are updated\n this.$nextTick(() => {\n this.$emit('reset');\n });\n },\n\n /**\n * Returns pre-defined filter values to become the default values\n */\n getDefaultFilterValues() {\n return this.schema.reduce((acc, item, filterIndex) => {\n if (item.type === 'll-checkbox') {\n acc[filterIndex] = item.attributes.checked || false;\n } else if (Object.prototype.hasOwnProperty.call(item.attributes, 'modelValue')) {\n acc[filterIndex] = item.attributes.modelValue;\n }\n\n return acc;\n }, {});\n },\n\n /**\n * Intended for external use, when filter values need to be set for the user\n */\n setFilterValues(newValues) {\n this.filterValues = merge({}, this.filterValues, newValues);\n this.forceRenderCount++;\n },\n\n updateValidationValues() {\n const validatable = Object.keys(this.validationSchema());\n\n this.schema.forEach((fieldSchema, filterIndex) => {\n const fieldToFilter = fieldSchema.fieldToFilter;\n const validate = validatable.includes(fieldToFilter);\n\n if (validate) {\n const filter = this.filters[fieldToFilter];\n\n /**\n * Get all validatable fields.\n * Use parsed value of filters that are set,\n * otherwise fall back to `filterValue` value if not set.\n */\n const filterValue = filter\n ? filter.isMultiple\n ? filter.filterBy\n : filter.filterBy[0]\n : this.filterValues[filterIndex];\n\n this.validationValues[fieldToFilter] = filterValue;\n }\n });\n },\n\n /**\n * Change handler for filter fields\n */\n onChange(filter, filterValues, filterIndex) {\n if (filter.on?.change) {\n // Maps to `on.change` handlers in the filter schema.\n filter.on.change(filterValues, filterIndex);\n }\n },\n\n /**\n * Select input event handler for filter fields\n */\n onSelectInput(newValue, filter, filterIndex) {\n if (newValue === undefined) {\n delete this.filterValues[filterIndex]; // prevent undefined filterValues which cause an empty result list\n } else {\n this.filterValues[filterIndex] = newValue;\n }\n\n this.onChange(filter, this.filterValues, filterIndex);\n },\n\n /**\n * Get filter values from local storage.\n * @returns {any}\n */\n getPersistentFilterValues() {\n return persistentStorage.get('filter-values');\n },\n\n /**\n * Clone new filterValues to remove reactivity, and save them to localStorage.\n * @param {object} newValues - the filterValues to be persisted in localStorage\n */\n persistFilterValues(newValues) {\n persistentStorage.set('filter-values', cloneDeep(newValues));\n },\n },\n };\n</script>\n\n<template>\n <div class=\"ll-grid tw-grid-cols-4 md:tw-grid-cols-12\">\n <template v-for=\"(filter, filterIndex) in schema\">\n <div\n v-if=\"!filter.hidden\"\n :key=\"`${filterIndex} ${forceRenderCount}`\"\n class=\"field-wrapper tw-col-span-4 md:tw-col-span-3\"\n :class=\"{ 'max-md:tw-hidden': !filter.type, 'tw-flex tw-items-end': filter.type === 'll-checkbox' }\"\n :data-test=\"`filter|${filter.fieldToFilter}`\"\n >\n <!-- Filter component -->\n <ll-select\n v-if=\"filter.type === 'll-select'\"\n v-bind=\"filter.attributes\"\n :error=\"validation?.fields[filter.fieldToFilter] && validation?.getError(filter.fieldToFilter)\"\n :label=\"filter.label\"\n :model-value=\"filterValues[filterIndex]\"\n @update:model-value=\"(newValue) => onSelectInput(newValue, filter, filterIndex)\"\n />\n <ll-checkbox\n v-else-if=\"filter.type === 'll-checkbox'\"\n v-model:checked=\"filterValues[filterIndex]\"\n v-bind=\"filter.attributes\"\n :error-text=\"validation?.fields[filter.fieldToFilter] && validation?.getError(filter.fieldToFilter)\"\n :label=\"filter.label\"\n @update:checked=\"onChange(filter, filterValues, filterIndex)\"\n />\n <ll-radio\n v-else-if=\"filter.type === 'll-radio'\"\n v-model:checked=\"filterValues[filterIndex]\"\n v-bind=\"filter.attributes\"\n :error-text=\"validation?.fields[filter.fieldToFilter] && validation?.getError(filter.fieldToFilter)\"\n :label=\"filter.label\"\n @update:checked=\"onChange(filter, filterValues, filterIndex)\"\n />\n <component\n v-bind=\"filter.attributes\"\n :is=\"filter.type\"\n v-else-if=\"filter.type\"\n v-model=\"filterValues[filterIndex]\"\n :error-text=\"validation?.fields[filter.fieldToFilter] && validation?.getError(filter.fieldToFilter)\"\n :label=\"filter.label\"\n @update:model-value=\"onChange(filter, filterValues, filterIndex)\"\n >\n <template v-if=\"filter.slots && filter.slots.selected\" #selected=\"{ option }\">\n <component :is=\"filter.slots.selected\" v-bind=\"option.props\" />\n </template>\n <template v-if=\"filter.slots && filter.slots.option\" #option=\"{ option }\">\n <component :is=\"filter.slots.option\" v-bind=\"option.props\" />\n </template>\n <template v-if=\"filter.slots && filter.slots.prepend\" #prepend>\n <!-- eslint-disable-next-line vue/no-v-html -->\n <span v-html=\"filter.slots.prepend\"></span>\n </template>\n <template v-if=\"filter.slots && filter.slots.append\" #append>\n <!-- eslint-disable-next-line vue/no-v-html -->\n <span v-html=\"filter.slots.append\"></span>\n </template>\n </component>\n </div>\n </template>\n <div\n class=\"button-grid tw-col-span-4 tw-flex tw-items-end tw-justify-end md:tw-col-span-12\"\n :class=\"$style['filter-button-group']\"\n >\n <ll-button secondary data-test=\"button|reset-filters\" :disabled=\"disableClear\" @click=\"resetFilters\">\n {{ clearText }}\n </ll-button>\n <ll-button\n primary\n data-test=\"button|apply-filters\"\n :disabled=\"disableApply || validation?.hasErrors\"\n @click=\"applyFilters\"\n >\n {{ applyText }}\n </ll-button>\n </div>\n </div>\n</template>\n\n<style module>\n .filter-button-group {\n @media screen('max-md') {\n display: flex;\n flex-direction: column-reverse;\n }\n\n button {\n @media screen('max-md') {\n width: 100% !important;\n }\n\n &:nth-child(2) {\n @media screen('max-md') {\n margin-bottom: theme('spacing.3');\n }\n }\n }\n }\n</style>\n"],"names":["_sfc_main","Button","Checkbox","Input","InputOptions","Radio","Select","DatePicker","props","getValidationSchema","toRefs","validationSchema","validationValues","ref","validation","initValidation","values","fieldName","validationRules","rules","fieldRules","fieldRule","useValidation","t","newFilterValues","filters","acc","schema","item","trackBy","isObject","isCustomFilterComponent","isMultiple","filterBy","v","groupedWith","nextTick","LLLV_CHANGE_TRIGGERS","trigger","filterIndex","newValues","merge","validatable","fieldSchema","fieldToFilter","filter","filterValue","filterValues","_a","newValue","persistentStorage","cloneDeep","_hoisted_1","_openBlock","_createElementBlock","_Fragment","_renderList","$props","$data","_normalizeClass","_createBlock","_component_ll_select","_mergeProps","$setup","_b","$options","_component_ll_checkbox","$event","_c","_d","_component_ll_radio","_e","_f","_resolveDynamicComponent","_g","_h","_withCtx","option","_normalizeProps","_guardReactiveProps","_createElementVNode","_ctx","_createVNode","_component_ll_button"],"mappings":"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"}
1
+ {"version":3,"file":"Filters.js","sources":["../src/components/Filters/Filters.vue"],"sourcesContent":["<script>\n import cloneDeep from 'lodash-es/cloneDeep';\n import merge from 'lodash-es/merge';\n import { nextTick, ref, toRefs } from 'vue';\n\n import useValidation from '../../composables/useValidation/useValidation';\n import { LLLV_CHANGE_TRIGGERS } from '../../constants';\n import { t } from '../../locale';\n import { persistentStorage } from '../../storage';\n import Button from '../Button/Button.vue';\n import Checkbox from '../Checkbox/Checkbox.vue';\n import DatePicker from '../DatePicker/DatePicker.vue';\n import Input from '../Input/Input.vue';\n import InputOptions from '../InputOptions/InputOptions.vue';\n import Radio from '../Radio/Radio.vue';\n import Select from '../Select/Select.vue';\n\n export default {\n name: 'll-filters',\n\n components: {\n 'll-button': Button,\n 'll-checkbox': Checkbox,\n 'll-input': Input,\n 'll-input-options': InputOptions,\n 'll-radio': Radio,\n 'll-select': Select,\n DatePicker,\n },\n\n props: {\n /**\n * Whether to disable the Apply button\n */\n disableApply: Boolean,\n /**\n * Whether to disable the Clear button\n */\n disableClear: Boolean,\n /**\n * Whether to disable the sticky filters\n * If disabled, a default pre-selected value(s) can be added to\n * the filter component's attributes\n */\n disablePersistency: Boolean,\n /**\n * Filters schema\n */\n schema: {\n type: Array,\n default: () => [],\n },\n /**\n * Validation schema function that returns an object\n */\n validationSchema: {\n type: Function,\n default: () => () => undefined,\n },\n },\n\n emits: ['change', 'submit', 'reset'],\n\n setup(props) {\n const { validationSchema: getValidationSchema } = toRefs(props);\n const validationSchema = getValidationSchema.value();\n const validationValues = ref({});\n\n // Without ref, `this.validation` will always evaluate to its initial value of `undefined` due to lack of reactivity.\n const validation = ref();\n\n function initValidation() {\n if (validationSchema?.toString() !== '[object Object]') {\n return;\n }\n\n validationValues.value = Object.keys(validationSchema).reduce((values, fieldName) => {\n values[fieldName] = undefined;\n\n return values;\n }, {});\n\n const validationRules = Object.entries(validationSchema).reduce((rules, [fieldName, fieldRules]) => {\n rules[fieldName] = fieldRules.map((fieldRule) => {\n return fieldRule(validationValues);\n });\n\n return rules;\n }, {});\n\n validation.value = useValidation({ rules: validationRules, values: validationValues });\n validation.value.validate();\n }\n\n return {\n validation,\n validationValues,\n initValidation,\n };\n },\n\n data() {\n return {\n applyText: t('ll.apply'),\n clearText: t('ll.clear'),\n filters: {},\n filterValues: {},\n forceRenderCount: 0,\n };\n },\n\n watch: {\n filterValues: {\n /**\n * Maps filters to a partcular object structure:\n * @param {IFilterSchemaItem} newFilterValues all selected filters\n * @returns {IFilter}\n */\n handler: function (newFilterValues) {\n const filters = Object.keys(newFilterValues).reduce((acc, i) => {\n const schema = this.schema[i];\n\n if (!schema || !schema.fieldToFilter) {\n return acc;\n }\n\n const item = newFilterValues[i];\n\n // Ignore empty string or undefined/null filter values\n if (item === '' || item == null) {\n return acc;\n }\n\n const trackBy = schema.attributes.trackBy || 'id';\n const isObject = typeof item === 'object';\n const isCustomFilterComponent = typeof schema.type === 'object';\n // TODO: remove handling of schema.attributes.multiple when we remove the vue-multiselect version of Select\n const isMultiple =\n (isCustomFilterComponent && schema.attributes.multiple) ||\n (!isCustomFilterComponent &&\n schema.type.includes('ll-select') &&\n (schema.attributes.multiple || !schema.attributes.single));\n const filterBy = isMultiple\n ? // local storage might have item stored as an object from the old Select\n (Array.isArray(item) ? item : [item]).map((v) => v[trackBy])\n : isObject\n ? [item[trackBy]]\n : [item];\n\n const groupedWith = schema.groupedWith;\n\n if (groupedWith) {\n filterBy[0] = {\n index: groupedWith,\n value: newFilterValues[groupedWith],\n };\n filterBy.push({\n index: Number(i),\n value: newFilterValues[i],\n });\n }\n\n filterBy.length &&\n (acc[schema.fieldToFilter] = {\n // don't add to `filters` if no filterBy\n filterBy,\n filterType: schema.type, // Informs the applied filter count\n isMultiple,\n ...('fn' in schema && { customFilter: schema.fn }),\n });\n\n return acc;\n }, {});\n\n this.filters = filters;\n this.$emit('change', filters);\n },\n\n deep: true,\n immediate: true,\n },\n\n filters() {\n if (this.validation) {\n this.updateValidationValues();\n }\n },\n },\n\n async created() {\n // initFilterValues updates the filterValues so using await nextTick() forces the code\n // after it to wait until nextTick is done, at which point the filterValues will\n // be done initializing. Otherwise, applyFilters sometimes applies the wrong\n // filters because filterValues is not done updating.\n this.initFilterValues();\n await nextTick();\n this.initValidation();\n this.applyFilters({ trigger: LLLV_CHANGE_TRIGGERS.LOAD });\n },\n\n methods: {\n initFilterValues() {\n if (this.disablePersistency) {\n this.filterValues = this.getDefaultFilterValues();\n\n return;\n }\n\n this.filterValues = this.getPersistentFilterValues() || this.getDefaultFilterValues();\n },\n\n /**\n * Apply the selected filters and save them to localStorage.\n * ListView calls this method using a ref to Filters.\n * The trigger option is used in ListView.\n * @param {object} [options] - optional parameters\n * @param {string} [options.trigger] - the action that triggered this function call\n */\n async applyFilters({ trigger = LLLV_CHANGE_TRIGGERS.APPLY } = {}) {\n if (this.validation) {\n await this.validation.validate();\n\n if (this.validation.hasErrors) {\n return;\n }\n }\n\n if (!this.disablePersistency) {\n this.persistFilterValues(this.filterValues);\n }\n\n this.$emit('submit', { trigger });\n },\n\n resetFilters() {\n this.filterValues = this.getDefaultFilterValues();\n\n this.forceRenderCount++;\n\n if (!this.disablePersistency) {\n this.persistFilterValues(this.filterValues);\n }\n\n // Emit after filters are updated\n this.$nextTick(() => {\n this.$emit('reset');\n });\n },\n\n /**\n * Returns pre-defined filter values to become the default values\n */\n getDefaultFilterValues() {\n return this.schema.reduce((acc, item, filterIndex) => {\n if (item.type === 'll-checkbox') {\n acc[filterIndex] = item.attributes.checked || false;\n } else if (Object.prototype.hasOwnProperty.call(item.attributes, 'modelValue')) {\n acc[filterIndex] = item.attributes.modelValue;\n }\n\n return acc;\n }, {});\n },\n\n /**\n * Intended for external use, when filter values need to be set for the user\n */\n setFilterValues(newValues) {\n this.filterValues = merge({}, this.filterValues, newValues);\n this.forceRenderCount++;\n },\n\n updateValidationValues() {\n const validatable = Object.keys(this.validationSchema());\n\n this.schema.forEach((fieldSchema, filterIndex) => {\n const fieldToFilter = fieldSchema.fieldToFilter;\n const validate = validatable.includes(fieldToFilter);\n\n if (validate) {\n const filter = this.filters[fieldToFilter];\n\n /**\n * Get all validatable fields.\n * Use parsed value of filters that are set,\n * otherwise fall back to `filterValue` value if not set.\n */\n const filterValue = filter\n ? filter.isMultiple\n ? filter.filterBy\n : filter.filterBy[0]\n : this.filterValues[filterIndex];\n\n this.validationValues[fieldToFilter] = filterValue;\n }\n });\n },\n\n /**\n * Change handler for filter fields\n */\n onChange(filter, filterValues, filterIndex) {\n if (filter.on?.change) {\n // Maps to `on.change` handlers in the filter schema.\n filter.on.change(filterValues, filterIndex);\n }\n },\n\n /**\n * Select input event handler for filter fields\n */\n onSelectInput(newValue, filter, filterIndex) {\n if (newValue === undefined) {\n delete this.filterValues[filterIndex]; // prevent undefined filterValues which cause an empty result list\n } else {\n this.filterValues[filterIndex] = newValue;\n }\n\n this.onChange(filter, this.filterValues, filterIndex);\n },\n\n /**\n * Get filter values from local storage.\n * @returns {any}\n */\n getPersistentFilterValues() {\n return persistentStorage.get('filter-values');\n },\n\n /**\n * Clone new filterValues to remove reactivity, and save them to localStorage.\n * @param {object} newValues - the filterValues to be persisted in localStorage\n */\n persistFilterValues(newValues) {\n persistentStorage.set('filter-values', cloneDeep(newValues));\n },\n },\n };\n</script>\n\n<template>\n <div class=\"tw-ll-grid tw-grid-cols-4 md:tw-grid-cols-12\">\n <template v-for=\"(filter, filterIndex) in schema\">\n <div\n v-if=\"!filter.hidden\"\n :key=\"`${filterIndex} ${forceRenderCount}`\"\n class=\"field-wrapper tw-col-span-4 md:tw-col-span-3\"\n :class=\"{ 'max-md:tw-hidden': !filter.type, 'tw-flex tw-items-end': filter.type === 'll-checkbox' }\"\n :data-test=\"`filter|${filter.fieldToFilter}`\"\n >\n <!-- Filter component -->\n <ll-select\n v-if=\"filter.type === 'll-select'\"\n v-bind=\"filter.attributes\"\n :error=\"validation?.fields[filter.fieldToFilter] && validation?.getError(filter.fieldToFilter)\"\n :label=\"filter.label\"\n :model-value=\"filterValues[filterIndex]\"\n @update:model-value=\"(newValue) => onSelectInput(newValue, filter, filterIndex)\"\n />\n <ll-checkbox\n v-else-if=\"filter.type === 'll-checkbox'\"\n v-model:checked=\"filterValues[filterIndex]\"\n v-bind=\"filter.attributes\"\n :error-text=\"validation?.fields[filter.fieldToFilter] && validation?.getError(filter.fieldToFilter)\"\n :label=\"filter.label\"\n @update:checked=\"onChange(filter, filterValues, filterIndex)\"\n />\n <ll-radio\n v-else-if=\"filter.type === 'll-radio'\"\n v-model:checked=\"filterValues[filterIndex]\"\n v-bind=\"filter.attributes\"\n :error-text=\"validation?.fields[filter.fieldToFilter] && validation?.getError(filter.fieldToFilter)\"\n :label=\"filter.label\"\n @update:checked=\"onChange(filter, filterValues, filterIndex)\"\n />\n <component\n v-bind=\"filter.attributes\"\n :is=\"filter.type\"\n v-else-if=\"filter.type\"\n v-model=\"filterValues[filterIndex]\"\n :error-text=\"validation?.fields[filter.fieldToFilter] && validation?.getError(filter.fieldToFilter)\"\n :label=\"filter.label\"\n @update:model-value=\"onChange(filter, filterValues, filterIndex)\"\n >\n <template v-if=\"filter.slots && filter.slots.selected\" #selected=\"{ option }\">\n <component :is=\"filter.slots.selected\" v-bind=\"option.props\" />\n </template>\n <template v-if=\"filter.slots && filter.slots.option\" #option=\"{ option }\">\n <component :is=\"filter.slots.option\" v-bind=\"option.props\" />\n </template>\n <template v-if=\"filter.slots && filter.slots.prepend\" #prepend>\n <!-- eslint-disable-next-line vue/no-v-html -->\n <span v-html=\"filter.slots.prepend\"></span>\n </template>\n <template v-if=\"filter.slots && filter.slots.append\" #append>\n <!-- eslint-disable-next-line vue/no-v-html -->\n <span v-html=\"filter.slots.append\"></span>\n </template>\n </component>\n </div>\n </template>\n <div\n class=\"button-grid tw-col-span-4 tw-flex tw-items-end tw-justify-end md:tw-col-span-12\"\n :class=\"$style['filter-button-group']\"\n >\n <ll-button secondary data-test=\"button|reset-filters\" :disabled=\"disableClear\" @click=\"resetFilters\">\n {{ clearText }}\n </ll-button>\n <ll-button\n primary\n data-test=\"button|apply-filters\"\n :disabled=\"disableApply || validation?.hasErrors\"\n @click=\"applyFilters\"\n >\n {{ applyText }}\n </ll-button>\n </div>\n </div>\n</template>\n\n<style module>\n .filter-button-group {\n @media screen('max-md') {\n display: flex;\n flex-direction: column-reverse;\n }\n\n button {\n @media screen('max-md') {\n width: 100% !important;\n }\n\n &:nth-child(2) {\n @media screen('max-md') {\n margin-bottom: theme('spacing.3');\n }\n }\n }\n }\n</style>\n"],"names":["_sfc_main","Button","Checkbox","Input","InputOptions","Radio","Select","DatePicker","props","getValidationSchema","toRefs","validationSchema","validationValues","ref","validation","initValidation","values","fieldName","validationRules","rules","fieldRules","fieldRule","useValidation","t","newFilterValues","filters","acc","schema","item","trackBy","isObject","isCustomFilterComponent","isMultiple","filterBy","v","groupedWith","nextTick","LLLV_CHANGE_TRIGGERS","trigger","filterIndex","newValues","merge","validatable","fieldSchema","fieldToFilter","filter","filterValue","filterValues","_a","newValue","persistentStorage","cloneDeep","_hoisted_1","_openBlock","_createElementBlock","_Fragment","_renderList","$props","$data","_normalizeClass","_createBlock","_component_ll_select","_mergeProps","$setup","_b","$options","_component_ll_checkbox","$event","_c","_d","_component_ll_radio","_e","_f","_resolveDynamicComponent","_g","_h","_withCtx","option","_normalizeProps","_guardReactiveProps","_createElementVNode","_ctx","_createVNode","_component_ll_button"],"mappings":"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"}
package/dist/ListView.js CHANGED
@@ -351,7 +351,7 @@ function Ae(e, l, s, w, i, t) {
351
351
  class: r(e.$style["expanded-content-header"])
352
352
  }, [
353
353
  u("div", {
354
- class: r(["ll-grid tw-flex-1", e.$style["expanded-content-header-grid"]])
354
+ class: r(["tw-ll-grid tw-flex-1", e.$style["expanded-content-header-grid"]])
355
355
  }, [
356
356
  f(e.$slots, "expanded-content-list-header")
357
357
  ], 2)
@@ -1069,7 +1069,7 @@ const Ve = {
1069
1069
  return e.reduce((l, s) => this.isItemDisabled(s) ? l : [...l, s], []);
1070
1070
  }
1071
1071
  }
1072
- }, je = { class: "ll-grid tw-grid-cols-4 md:tw-grid-cols-8 lg:tw-grid-cols-12" }, Me = ["disabled"], Ge = { class: "button-grid tw-col-span-1 tw-items-end tw-justify-end lg:tw-col-span-3" }, Ue = {
1072
+ }, je = { class: "tw-ll-grid tw-grid-cols-4 md:tw-grid-cols-8 lg:tw-grid-cols-12" }, Me = ["disabled"], Ge = { class: "button-grid tw-col-span-1 tw-items-end tw-justify-end lg:tw-col-span-3" }, Ue = {
1073
1073
  key: 0,
1074
1074
  class: "tw-text-xs"
1075
1075
  };
@@ -1079,7 +1079,7 @@ function Ke(e, l, s, w, i, t) {
1079
1079
  t.showPrimaryControls || t.showSecondaryControls ? (a(), o("div", {
1080
1080
  key: 0,
1081
1081
  ref: "scrollTarget",
1082
- class: r(["tw-mb-6", { "ll-grid": t.showPrimaryControls && t.showSecondaryControls }])
1082
+ class: r(["tw-mb-6", { "tw-ll-grid": t.showPrimaryControls && t.showSecondaryControls }])
1083
1083
  }, [
1084
1084
  t.showPrimaryControls ? (a(), o("div", {
1085
1085
  key: 0,
@@ -1268,7 +1268,7 @@ function Ke(e, l, s, w, i, t) {
1268
1268
  "onUpdate:checked": t.onSelectPage
1269
1269
  }, null, 8, ["checked", "class", "indeterminate", "onUpdate:checked"])) : n("", !0),
1270
1270
  u("div", {
1271
- class: r(["ll-grid tw-flex-1", e.$style["header-grid"]])
1271
+ class: r(["tw-ll-grid tw-flex-1", e.$style["header-grid"]])
1272
1272
  }, [
1273
1273
  f(e.$slots, "list-header")
1274
1274
  ], 2)
@@ -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=\"ll-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=\"ll-bg-white\" :class=\"$style['empty-state']\" :text=\"emptyStateText\" />\n</template>\n\n<style module>\n .empty-state {\n max-width: 100%;\n }\n</style>\n","<script>\n import { CSS_VARS } from '../../../constants';\n import sticky from '../../../directives/sticky/sticky';\n import { getCssVar } from '../../../utils/helpers';\n import Button from '../../Button/Button.vue';\n import Expand from '../../Expand/Expand.vue';\n import Icon from '../../Icon/Icon.vue';\n\n export default {\n name: 'list-group',\n\n components: {\n Expand,\n 'll-button': Button,\n Icon,\n },\n\n directives: {\n sticky,\n },\n\n props: {\n /**\n * Disables the gutters between adjacent ListGroup components.\n */\n disableExternalGutters: {\n type: Boolean,\n default: false,\n },\n\n /**\n * Allows the list items to be collapsed\n */\n isCollapsible: {\n type: Boolean,\n default: false,\n },\n\n /**\n * Allows the expanded content to be collapsed by default.\n * Note: has no effect unless the `isCollapsible` prop is `true`.\n */\n isCollapsedByDefault: {\n type: Boolean,\n default: false,\n },\n },\n\n data() {\n const isExpanded = !this.isCollapsible || !this.isCollapsedByDefault;\n\n return {\n isExpanded,\n isDoneExpanding: isExpanded,\n };\n },\n\n computed: {\n headerOffset() {\n return parseFloat(getCssVar(CSS_VARS.TOP_HEADER_HEIGHT));\n },\n },\n\n methods: {\n toggleExpand() {\n if (!this.isCollapsible) {\n return;\n }\n\n this.isExpanded = !this.isExpanded;\n\n if (!this.isExpanded) {\n this.isDoneExpanding = false;\n } // else wait for Expand to emit @after-expand\n },\n\n onHeaderClick(e) {\n // toggle the ListGroup, except when clicking the actions\n if (!this.$refs.actionsContainer.contains(e.target)) {\n this.toggleExpand();\n }\n },\n },\n };\n</script>\n\n<template>\n <div\n :class=\"[\n $style['list-group'],\n {\n 'disable-external-gutters': disableExternalGutters,\n 'is-collapsed': !isExpanded,\n },\n ]\"\n >\n <header\n class=\"tw-flex tw-items-center\"\n :class=\"[$style['main-header'], { 'tw-cursor-pointer': isCollapsible }]\"\n @click=\"onHeaderClick\"\n >\n <ll-button v-if=\"isCollapsible\" :class=\"['tw-mr-1.5 tw-text-ice-900', $style['expansion-toggle-button']]\" icon>\n <Icon :class=\"[isExpanded ? 'tw-rotate-270' : 'rotate-180']\" name=\"chevron-left\" />\n </ll-button>\n\n <div class=\"tw-flex-auto\">\n <slot name=\"title\"></slot>\n </div>\n\n <div ref=\"actionsContainer\">\n <slot name=\"actions\"></slot>\n </div>\n </header>\n\n <Expand :is-expanded=\"isExpanded\" @after-expand=\"isDoneExpanding = true\">\n <div :class=\"$style['expanded-content-wrapper']\">\n <header\n v-if=\"$slots['expanded-content-list-header']\"\n v-sticky=\"isExpanded && isDoneExpanding ? headerOffset : 0\"\n :class=\"$style['expanded-content-header']\"\n >\n <div class=\"ll-grid tw-flex-1\" :class=\"$style['expanded-content-header-grid']\">\n <slot name=\"expanded-content-list-header\"></slot>\n </div>\n </header>\n <div :class=\"$style['expanded-content-list-items-wrapper']\">\n <transition-group name=\"fade\" mode=\"out-in\">\n <slot name=\"expanded-content-list-items\"></slot>\n </transition-group>\n </div>\n </div>\n </Expand>\n </div>\n</template>\n\n<style module>\n .main-header {\n @apply tw-shadow;\n\n background-color: var(--color-white);\n border-radius: theme('borderRadius.DEFAULT');\n margin-bottom: theme('spacing.6');\n padding: var(--grid-gutter);\n\n @media screen('lg') {\n border-bottom: theme('borderWidth.DEFAULT') solid var(--color-ice-200);\n border-bottom-left-radius: 0;\n border-bottom-right-radius: 0;\n margin-bottom: 0;\n }\n }\n\n .expanded-content-wrapper {\n position: relative;\n width: 100%;\n }\n\n @media screen('lg') {\n .expanded-content-wrapper {\n @apply tw-shadow;\n }\n }\n\n .expanded-content-header {\n background-color: var(--color-white);\n border-bottom: theme('borderWidth.DEFAULT') solid var(--color-ice-200);\n color: var(--color-ice-900);\n display: none;\n font-weight: 500;\n padding: 0 theme('spacing.3');\n transition: padding theme('transitionDuration.150') theme('transitionTimingFunction.swing');\n z-index: 1;\n\n @media screen('lg') {\n align-items: center;\n display: flex;\n }\n\n &:global(.is-sticky) {\n @apply tw-shadow;\n\n border-radius: 0;\n z-index: calc(theme('zIndex.control') + 1);\n }\n }\n\n .expanded-content-header-grid {\n column-gap: 0;\n grid-column-gap: 0;\n\n > div {\n align-items: center;\n border-right: theme('borderWidth.DEFAULT') solid var(--color-ice-200);\n display: flex;\n font-size: theme('fontSize.xs');\n justify-content: space-between;\n padding: theme('spacing.3');\n\n &:last-of-type {\n border-right: 0;\n }\n }\n }\n\n .expansion-toggle-button:focus {\n box-shadow: none;\n }\n\n .list-group:global(.disable-external-gutters) {\n .main-header {\n @media screen('lg') {\n border-radius: 0;\n }\n }\n\n .expanded-content-list-items-wrapper > * {\n @media screen('lg') {\n border-bottom: theme('borderWidth.DEFAULT') solid var(--color-ice-200);\n border-radius: 0;\n }\n }\n\n &:last-of-type {\n &:global(.is-collapsed) .main-header,\n .expanded-content-list-items-wrapper > *:last-child {\n @media screen('lg') {\n border-bottom: none;\n border-bottom-left-radius: theme('borderRadius.DEFAULT');\n border-bottom-right-radius: theme('borderRadius.DEFAULT');\n }\n }\n }\n }\n</style>\n","<script>\n import Icon from '../../Icon/Icon.vue';\n\n export default {\n name: 'list-header',\n\n components: {\n 'll-icon': Icon,\n },\n\n props: {\n /**\n * keys to be sorted for the column\n * the first key should be the default sort value\n */\n sortKeys: {\n type: Array,\n required: true,\n validator: (value) => value.length === 2,\n },\n\n listViewRef: {\n type: Object,\n default: null,\n },\n },\n\n data() {\n return {\n isAscending: null,\n };\n },\n\n computed: {\n listViewInstance() {\n return this.listViewRef || this.$parent;\n },\n /**\n * Is the column currently sorted\n */\n isSorted() {\n return this.sortKeys.includes(this.listViewInstance.sortTerm);\n },\n\n /**\n * Show the top icon if it's not sorted or if the current sortTerm matches\n */\n showCaretUp() {\n return this.isAscending === null || this.sortKeys[0] === this.listViewInstance.sortTerm;\n },\n\n /**\n * Show the bottom icon if it's not sorted or if the current sortTerm matches\n */\n showCaretDown() {\n return this.isAscending === null || this.sortKeys[1] === this.listViewInstance.sortTerm;\n },\n },\n\n watch: {\n isSorted: {\n handler(value) {\n this.isAscending = value ? true : null;\n },\n immediate: true,\n },\n },\n\n methods: {\n /**\n * Sorts the column by the sort field\n */\n sort() {\n this.listViewInstance.onSort(this.sortKeys[this.isAscending ? 1 : 0]);\n this.isAscending = !this.isAscending;\n },\n },\n };\n</script>\n\n<template>\n <div :class=\"['tw-cursor-pointer', { 'tw-bg-blue-100': isSorted }]\" @click=\"sort\">\n <slot></slot>\n <div class=\"h-4 w-3 tw-relative tw-text-ice-700\" :class=\"{ 'is-active-sort': isSorted }\">\n <ll-icon\n v-if=\"showCaretUp\"\n name=\"caret-up\"\n class=\"tw-absolute\"\n :class=\"[$style.caret, $style['caret-up']]\"\n size=\"dense\"\n />\n <ll-icon\n v-if=\"showCaretDown\"\n name=\"caret-down\"\n class=\"tw-absolute\"\n :class=\"[$style.caret, $style['caret-down']]\"\n size=\"dense\"\n />\n </div>\n </div>\n</template>\n\n<style module>\n .caret-up {\n top: -5px;\n }\n\n .caret-down {\n top: 2px;\n }\n\n :global(.is-active-sort) .caret {\n top: -2px; /* vertically center the caret icon */\n }\n</style>\n","<script>\n import cloneDeep from 'lodash-es/cloneDeep';\n import { computed } from 'vue';\n\n import useSearch from '../../composables/useSearch/useSearch';\n import { CSS_VARS, LLLV_CHANGE_TRIGGERS } from '../../constants';\n import sticky from '../../directives/sticky/sticky';\n import { t } from '../../locale';\n import { persistentStorage } from '../../storage';\n import { filterItems as _filterItems, getCssVar, sortItems as _sortItems } from '../../utils/helpers';\n import Badge from '../Badge/Badge.vue';\n import Button from '../Button/Button.vue';\n import Checkbox from '../Checkbox/Checkbox.vue';\n import Dropdown from '../Dropdown/Dropdown.vue';\n import Expand from '../Expand/Expand.vue';\n import Filters from '../Filters/Filters.vue';\n import Icon from '../Icon/Icon.vue';\n import Input from '../Input/Input.vue';\n import Paginate from '../Paginate/Paginate.vue';\n import BulkActions from './components/BulkActions.vue';\n import LoadingManager from './components/LoadingManager.vue';\n\n export { default as BulkActions } from './components/BulkActions.vue';\n export { default as ListGroup } from './components/ListGroup.vue';\n export { default as ListHeader } from './components/ListHeader.vue';\n export { default as LoadingManager } from './components/LoadingManager.vue';\n\n const DEFAULT_SEARCH_SCHEMA = {\n isSearchable: true,\n placeholder: 'Search',\n searchBy: ['name'],\n };\n\n export default {\n name: 'll-list-view',\n\n components: {\n BulkActions,\n Filters,\n Paginate,\n LoadingManager,\n Badge,\n Button,\n Icon,\n Dropdown,\n Expand,\n Checkbox,\n Input,\n },\n\n directives: {\n sticky,\n },\n\n inject: {\n trackSearch: { default: () => () => {} },\n trackFilters: { default: () => () => {} },\n trackSort: { default: () => () => {} },\n trackResults: { default: () => () => {} },\n },\n\n props: {\n /**\n * Hide the '{number} of {total} selected' text for bulk actions\n */\n hideNumberOfTotalSelected: {\n type: Boolean,\n default: false,\n },\n /**\n * Hide the Select All checkbox for bulk actions\n */\n hideSelectAll: {\n type: Boolean,\n default: false,\n },\n /**\n * Text to render in EmptyState component if there are no results\n */\n emptyStateText: {\n type: String,\n default: '',\n },\n filterSchema: {\n type: Array,\n default: () => [],\n },\n /**\n * Make search fuzzy. Only for client side search.\n */\n fuzzySearch: {\n type: Boolean,\n default: false,\n },\n hideTotal: Boolean,\n initialPage: {\n type: Number,\n default: undefined,\n },\n /**\n * Can items on the page be selected for bulk actions\n */\n isSelectable: Boolean,\n /**\n * For loading data already paginated, filtered (including search), and sorted from a backend.\n * Defining this prop will disable the built-in search, filtering, sorting and pagination.\n * You will instead need to use the available events (`@change`, and `@change:` prefixed)\n * to know when to request new pages from your backend.\n * This requires providing `totalItemCount`.\n * Use the loading prop to indicate when data is being loaded.\n */\n isServerSide: Boolean,\n /**\n * The data for each row. Used in this file as this.internalItems (a copy) to allow mutation;\n */\n items: {\n type: Array,\n default: () => [],\n },\n /**\n * Default field to track selected items by\n */\n itemTrackBy: {\n type: String,\n default: 'id',\n },\n loading: Boolean,\n // Number of items to display per page\n pageSize: {\n type: Number,\n default: 50,\n },\n searchSchema: {\n type: Object,\n default: () => ({}),\n },\n // Provide an optional custom 'Sort by' label\n sortLabel: {\n type: String,\n default: () => t('ll.listView.sortBy'),\n },\n sortOnLoad: Boolean,\n sorts: {\n type: Object,\n default: () => ({}),\n },\n /**\n * Total number of unpaginated results\n * Required when `isServerSide` is `true`\n */\n totalItemCount: {\n type: Number,\n default: undefined,\n },\n /**\n * Validation schema function that returns an object\n */\n validationSchema: {\n type: Function,\n default: () => () => undefined,\n },\n /**\n * Whether to disable the sticky filters\n * if disabled, the following will happen\n * 1. pre-selected value(s) can be added to\n * the filter component's attributes to overwrite the sticky filters\n * 2. users will not have sticky filters on the page\n */\n disablePersistency: Boolean,\n /**\n * Whether to disable the ability of saving 'show-filters'\n * in local storage\n */\n disableShowFilter: Boolean,\n /**\n * Whether to disable the stickiness of the header.\n * Default is false. When true, neither the list headers nor\n * the bulk actions (when applicable) will be sticky.\n */\n disableStickyHeader: Boolean,\n /**\n * Whether to expand the filters section by default on load.\n */\n showFiltersOnLoad: Boolean,\n\n /**\n * Do not use the LoadingManager, and instead render the default slot as passed\n */\n disableLoader: {\n type: Boolean,\n default: false,\n },\n\n /**\n * Override the header offset used to position the sticky header\n */\n stickyHeaderOffset: {\n type: Number,\n default: null,\n },\n /**\n * Prevent bulk actions dropdown from rendering\n */\n hideBulkActionOptions: {\n type: Boolean,\n default: false,\n },\n\n /**\n * If initial search term is provided, the list will be filtered on load.\n */\n initialSearchTerm: {\n type: String,\n default: '',\n },\n\n /**\n * Function that determines whether the item checkbox is disabled or not (default: false)\n */\n isItemDisabled: {\n type: Function,\n default: () => false,\n },\n },\n\n emits: [\n 'change',\n 'change:filter',\n 'change:page',\n 'change:search',\n 'change:sort',\n 'change:reset',\n 'filters-toggle-click',\n 'select-all',\n 'deselect-all',\n 'update-filters',\n 'updateResults',\n ],\n\n data() {\n return {\n internalItems: [],\n currentPage: this.initialPage || 1, // TODO: fetch from query params\n previousPage: null,\n sortOptionsWidth: 0,\n filters: {},\n filterText: t('ll.filter'),\n searchFor: () => {}, // initialized in the watch handler for internalItems\n searchTerm: this.initialSearchTerm,\n searchText: t('ll.search'),\n sortTerm: '',\n isLoadingSearchSchemaAction: false,\n isShowingFilters: !!(\n this.filterSchema?.length &&\n (this.showFiltersOnLoad || persistentStorage.get('show-filters'))\n ),\n isFiltering: false,\n results: [],\n selectedItems: [],\n };\n },\n\n computed: {\n /**\n * Returns true if any of its list items are truthy; otherwise returns false.\n * @returns {boolean}\n */\n isLoading() {\n return [this.loading, this.isLoadingSearchSchemaAction, this.isFiltering].some(Boolean);\n },\n\n totalCount() {\n return this.isServerSide ? this.totalItemCount : this.results.length;\n },\n\n /**\n * Helps determine if the list is filtered or not when there is an incomplete\n * result list, such as when isServerSide is true.\n */\n isFiltered() {\n return !!(this.numberOfFilters || this.searchTerm);\n },\n\n /**\n * Merges the searchSchema with the default value since all attributes are optional\n */\n internalSearchSchema() {\n return {\n ...DEFAULT_SEARCH_SCHEMA,\n searchBy: !this.searchSchema.isSearchable && DEFAULT_SEARCH_SCHEMA.searchBy,\n ...this.searchSchema,\n };\n },\n\n /**\n * Start of page\n */\n startIndex() {\n return this.pageSize * (this.currentPage - 1);\n },\n\n /**\n * End of page\n */\n endIndex() {\n return this.startIndex + this.pageSize;\n },\n\n /**\n * Slices the results set into a paginated segment.\n * @returns One page in the paginated set of results\n */\n paginated() {\n // Disables the built-in client-side pagination\n let paginated;\n\n if (this.isServerSide) {\n paginated = this.results;\n } else {\n const { endIndex, totalCount, results, startIndex } = this;\n\n paginated = results.slice(startIndex, Math.min(endIndex, totalCount));\n }\n\n this.$emit('updateResults', paginated);\n\n return paginated;\n },\n\n /**\n * Displays a visual indication for the number of results, or \"working\" if the\n * results are being determined.\n */\n total() {\n const current = this.pageSize * (this.currentPage - 1);\n const range = this.paginated.length ? `${current + 1} - ${current + this.paginated.length}` : 0;\n\n return this.isLoading\n ? t('ll.listView.calculating')\n : t('ll.listView.totalResults', { num: String(range), total: String(this.totalCount) });\n },\n\n /**\n * Determines if both #list-header and #list-items slots are used.\n * @returns {boolean}\n */\n useDefinedSlots() {\n return !!this.$slots['list-header'] && !!this.$slots['list-items'];\n },\n\n /**\n * Don't show total count if list items are selected and total is not hidden\n */\n shouldShowTotal() {\n return !this.totalSelectedCount && !this.hideTotal;\n },\n\n /**\n * Returns a list of the selected items' track by field\n */\n selectedItemIds() {\n return this.selectedItems.map((item) => item[this.itemTrackBy]);\n },\n\n /**\n * Returns a list of the paginated items' track by field\n */\n paginatedIds() {\n return this.paginated.map((item) => item[this.itemTrackBy]);\n },\n\n isAllPageChecked() {\n if (this.isServerSide) {\n return this.totalCount > 0 && this.totalCount === this.selectedItemIds.length;\n }\n\n return this.totalCount > 0 && this.paginatedIds.every((id) => this.selectedItemIds.includes(id));\n },\n\n isSomePageChecked() {\n if (this.isServerSide) {\n return this.totalCount > 0 && this.selectedItemIds.length > 0;\n }\n\n return this.totalCount > 0 && this.paginatedIds.some((id) => this.selectedItemIds.includes(id));\n },\n\n numberOfFilters() {\n return Object.keys(this.filters).reduce((acc, item) => {\n const filterBy = this.filters[item].filterBy;\n const isBoolean = typeof filterBy[0] === 'boolean';\n const isToggle = this.filters[item].filterType === 'll-checkbox';\n const isEmpty = !this.filters[item].filterType.length;\n const isInputOptionsIncomplete = this.filters[item].filterType === 'll-input-options' && filterBy[0] === '';\n\n /**\n * Don't include hidden or incomplete fields in the count:\n * - Hidden filter populated via another filter's onChange callback\n * - InputOptions with incomplete/missing values\n */\n if (isEmpty || isInputOptionsIncomplete) {\n return acc;\n }\n\n if (isBoolean || typeof filterBy[0] === 'string') {\n // Do not count toggle filters (eg. checkbox) with a `false` value\n return acc + (filterBy[0] || !isToggle ? 1 : 0);\n }\n\n return acc + (filterBy.length || 0);\n }, 0);\n },\n\n isSelectBarVisible() {\n return !!this.totalSelectedCount;\n },\n\n showPrimaryControls() {\n return this.internalSearchSchema.isSearchable || this.filterSchema.length;\n },\n\n showSecondaryControls() {\n return !!this.$slots['secondary-controls'];\n },\n\n isSortable() {\n return Object.keys(this.sorts).length > 0;\n },\n\n totalSelectedCount() {\n return this.selectedItems.length;\n },\n\n headerOffset() {\n // passing null to the v-sticky directive will prevent it from being attached to the node\n if (this.disableStickyHeader) {\n return null;\n }\n\n return this.stickyHeaderOffset ?? parseFloat(getCssVar(CSS_VARS.TOP_HEADER_HEIGHT));\n },\n },\n\n watch: {\n isShowingFilters(value) {\n if (!this.disableShowFilter) {\n persistentStorage.set('show-filters', value);\n }\n },\n\n items: {\n handler() {\n this.internalItems = cloneDeep(this.items);\n },\n immediate: true,\n deep: true,\n },\n\n internalItems: {\n handler() {\n if (this.isServerSide) {\n this.results = this.internalItems;\n\n this.trackResults({\n page: this.currentPage,\n results: this.results,\n search: this.searchTerm,\n });\n\n return;\n }\n\n const { searchFor } = useSearch({\n items: computed(() => this.internalItems),\n fieldNames: this.internalSearchSchema.searchBy.length\n ? this.internalSearchSchema.searchBy\n : [this.displayBy],\n trackBy: this.itemTrackBy,\n });\n\n this.searchFor = (searchTerm) => searchFor(searchTerm, { fuzzy: this.fuzzySearch });\n\n this.processResults();\n },\n immediate: true,\n },\n\n sortTerm() {\n if (this.isServerSide) {\n return;\n }\n\n this.processResults();\n },\n\n sorts: {\n handler(value) {\n const sortTerms = Object.keys(value);\n\n this.sortTerm = this.sortOnLoad && sortTerms.length ? sortTerms[0] : '';\n },\n immediate: true,\n },\n },\n\n created() {\n if (this.isServerSide) {\n if (this.totalItemCount === undefined) {\n throw new Error('`totalItemCount` is required when `isServerSide` is `true`.');\n }\n\n return;\n }\n\n if (this.searchSchema.action && this.internalItems.length) {\n throw new Error('You must pass either `action` or `items`, not both.');\n }\n\n if (this.searchTerm) {\n this.onSearch();\n }\n },\n\n methods: {\n /**\n * Processes the results with searchFor, filterItems, and/or sortItems.\n * Skipped when isServerSide is true because results are pre-processed.\n * @returns {Promise<void>}\n */\n async processResults() {\n if (this.searchSchema.action) {\n this.isLoadingSearchSchemaAction = true;\n let actionResponse;\n\n try {\n actionResponse = await this.searchSchema.action({ search: this.searchTerm });\n } finally {\n this.isLoadingSearchSchemaAction = false;\n }\n\n this.results = this.sortItems(this.filterItems(actionResponse?.results || []));\n } else {\n this.results = this.sortItems(this.filterItems(this.searchFor(this.searchTerm)));\n }\n\n this.trackResults({\n page: this.currentPage,\n results: this.results,\n search: this.searchTerm,\n });\n },\n\n /**\n * Filters the list of `items` based on options selected in the `filters` object\n * @param {array} items A list of items to filter.\n * @returns list of items filtered by the applied filters\n */\n filterItems(items) {\n return _filterItems(items, this.filters);\n },\n\n /**\n * Sorts a list of items based on options selected in the `sorts` object\n * @param {array} items A list of items to sort.\n * @returns list of items sorted according to the sort term.\n */\n sortItems(items) {\n return this.sortTerm ? _sortItems(items, this.sorts[this.sortTerm]) : items;\n },\n\n change({ trigger = '' } = {}) {\n const { currentPage, filters, isFiltered, pageSize, searchTerm, sortTerm } = this;\n\n const params = {\n filters,\n isFiltered,\n page: {\n number: currentPage,\n previousNumber: this.previousPage,\n size: pageSize,\n },\n search: searchTerm,\n sort: sortTerm,\n trigger,\n };\n\n this.$emit('change', params);\n },\n\n /**\n * Clear search term and reset results to their initial state\n */\n async clearSearchTerm() {\n this.searchTerm = '';\n await this.$attrs.onSearchTermClear?.();\n this.onSearch();\n },\n\n /**\n * Resets the results to their initial state on page load\n */\n reset() {\n this.$emit('change:reset');\n\n this.searchTerm = '';\n\n this.setPage({ pageNumber: 1 });\n\n if (this.isServerSide) {\n this.change({ trigger: LLLV_CHANGE_TRIGGERS.RESET });\n\n return;\n }\n\n this.processResults();\n },\n\n onSearchTermChange() {\n this.$attrs.onSearchTermChange?.(this.searchTerm);\n },\n\n /**\n * Event handler for when the user:\n * - clicks the Search button\n * - presses the enter key while focused on the search input\n * Calls a method in Filters that triggers `this.onFilter`. This is necessary\n * in order to persist the filters in local storage, which is handled internally\n * by Filters.\n */\n onSearch() {\n this.$refs.llFilters.applyFilters({ trigger: LLLV_CHANGE_TRIGGERS.SEARCH });\n },\n\n /**\n * Event handler for when the user:\n * - clicks the Apply button\n * - clicks the Search button (from `this.onSearch`)\n * - presses the enter key while focused on the search input (from `this.onSearch`)\n * @see: SELL-350\n * @param {object} [options] - optional parameters\n * @param {string} [options.trigger] - what caused the changes\n * @returns {Promise<void>}\n */\n async onFilter({ trigger = LLLV_CHANGE_TRIGGERS.APPLY } = {}) {\n this.setPage({ pageNumber: 1 });\n this.change({ trigger });\n this.trackSearch(this.searchTerm);\n this.trackFilters(this.filters);\n this.selectedItems = [];\n\n if (this.isServerSide) {\n return;\n }\n\n try {\n this.isFiltering = true;\n await this.processResults({ trigger });\n } finally {\n this.isFiltering = false;\n }\n\n this.$emit('change:search', this.searchTerm);\n this.$emit('change:filter', this.filters);\n this.$emit('update-filters', this.filters); // deprecated; replaced by change:filter\n this.clearSelected();\n },\n\n onFiltersToggleClick() {\n this.isShowingFilters = !this.isShowingFilters;\n\n this.$emit('filters-toggle-click', {\n isShowingFilters: this.isShowingFilters,\n });\n },\n\n /**\n * Extend the dropdown list so it does not shift when\n * the options drawer is open\n */\n onSortToggle() {\n // spacing added to the width of the dropdown container\n const spacing = 36;\n\n this.$nextTick(() => {\n this.sortOptionsWidth = `${this.$refs.sortOptions.clientWidth + spacing}px`;\n });\n },\n\n /**\n * Executes any side-effects when the sort `term` is changed\n * Always fires `change` automatically.\n * @param {string} term The updated sort term\n */\n onSort(term) {\n if (term === this.sortTerm) {\n return;\n }\n\n this.sortTerm = term;\n\n this.$emit('change:sort', term);\n this.trackSort(term);\n this.clearSelected();\n this.setPage({ pageNumber: 1 });\n this.change({ trigger: LLLV_CHANGE_TRIGGERS.SORT });\n },\n\n /**\n * Sets current page for the Paginator.\n * @param {Object} data\n * @param {number} data.pageNumber - the page number\n * @param {boolean} data.forceChange - flag to force the change\n */\n setPage({ pageNumber, forceChange = false } = {}) {\n this.previousPage = this.currentPage;\n\n this.currentPage = pageNumber;\n\n if (!this.isServerSide) {\n this.$emit('change:page', pageNumber);\n }\n\n if (forceChange) {\n this.change({ trigger: LLLV_CHANGE_TRIGGERS.PAGE });\n }\n },\n\n /**\n * Set the scroll position to the top of the list view.\n */\n scrollToTop() {\n this.$refs.scrollTarget && this.$refs.scrollTarget.scrollIntoView({ behavior: 'smooth', block: 'center' });\n },\n\n onPaginateSetPage(pageNumber) {\n this.setPage({ pageNumber, forceChange: true });\n this.scrollToTop();\n },\n\n /**\n * Selects or deselects all items on a page\n */\n onSelectPage(value) {\n this.$emit('select-all', value);\n\n if (value) {\n const items = Array.from(new Set([...this.selectedItems, ...this.paginated]));\n\n this.selectedItems = this.selectItems(items);\n } else {\n this.selectedItems = this.selectedItems.filter((item) => !this.paginatedIds.includes(item[this.itemTrackBy]));\n }\n },\n\n selectAll() {\n this.selectedItems = this.selectItems(this.results);\n },\n\n /**\n * Selects one item\n */\n onSelectItem({ item, value }) {\n if (this.isItemDisabled(item)) {\n return;\n }\n\n if (value) {\n this.selectedItems.push(item);\n } else {\n this.selectedItems = this.selectedItems.filter(\n (selectedItem) => selectedItem[this.itemTrackBy] !== item[this.itemTrackBy],\n );\n }\n },\n\n /**\n * Clears current selected items\n */\n clearSelected() {\n this.$emit('deselect-all');\n this.selectedItems = [];\n },\n\n selectItems(items) {\n return items.reduce((acc, item) => (this.isItemDisabled(item) ? acc : [...acc, item]), []);\n },\n },\n };\n</script>\n\n<template>\n <div>\n <div\n v-if=\"showPrimaryControls || showSecondaryControls\"\n ref=\"scrollTarget\"\n class=\"tw-mb-6\"\n :class=\"{ '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=\"ll-grid tw-grid-cols-4 md:tw-grid-cols-8 lg:tw-grid-cols-12\">\n <!-- Search -->\n <Input\n v-if=\"internalSearchSchema.isSearchable\"\n ref=\"search-input\"\n v-model=\"searchTerm\"\n class=\"tw-col-span-3 md:tw-col-span-4\"\n data-test=\"input|search-input\"\n :class=\"[$style['search-input'], { 'lg:tw-col-span-8': showSecondaryControls }]\"\n :hint-text=\"internalSearchSchema.hintText\"\n :label=\"searchText\"\n :placeholder=\"internalSearchSchema.placeholder\"\n @keyup.enter=\"!isLoading && onSearch()\"\n @change=\"onSearchTermChange\"\n >\n <template #append>\n <button\n v-if=\"searchTerm\"\n data-test=\"button|clear-search\"\n :class=\"$style['clear-button']\"\n :disabled=\"isLoading\"\n @click=\"clearSearchTerm\"\n >\n <Icon name=\"close\" />\n </button>\n <Button\n data-test=\"button|search-button\"\n :disabled=\"isLoading\"\n :class=\"$style['search-button']\"\n @click=\"onSearch\"\n >\n <Icon\n :class=\"{ 'tw-animate-spin tw-text-teal-500': isFiltering }\"\n :name=\"isFiltering ? 'working' : 'search'\"\n />\n </Button>\n </template>\n </Input>\n\n <!-- Filter Toggle -->\n <div\n v-if=\"filterSchema.length\"\n class=\"tw-col-span-1 tw-flex tw-items-end\"\n :class=\"[\n $style['filter-toggle-btn'],\n { [$style['filter-toggle-btn-with-hint-text']]: !!internalSearchSchema.hintText },\n ]\"\n >\n <Badge :content=\"numberOfFilters\">\n <Button\n secondary\n class=\"tw-relative tw-w-full tw-min-w-auto\"\n color=\"blue\"\n data-test=\"button|toggle-filters\"\n :disabled=\"isFiltering\"\n @click=\"onFiltersToggleClick\"\n >\n <Icon\n v-if=\"isFiltering\"\n name=\"working\"\n :class=\"[\n { 'tw-animate-spin': isFiltering },\n isShowingFilters ? 'tw-text-teal-500' : 'tw-text-ice-700',\n ]\"\n />\n <Icon v-else name=\"filter-line\" />\n {{ filterText }}\n </Button>\n </Badge>\n </div>\n\n <!-- Actions -->\n <div class=\"button-grid tw-col-span-1 tw-items-end tw-justify-end lg:tw-col-span-3\">\n <slot name=\"actions\"> </slot>\n </div>\n </div>\n\n <!-- Filters -->\n <Expand data-test=\"filters|content\" :class=\"$style['filters-expand']\" :is-expanded=\"isShowingFilters\">\n <div class=\"tw-relative tw-pt-12\" :class=\"$style['filters-wrapper']\">\n <Filters\n ref=\"llFilters\"\n :class=\"{ [$style['filters-half-width']]: showPrimaryControls && showSecondaryControls }\"\n :disable-apply=\"isLoading\"\n :disable-clear=\"isLoading || !numberOfFilters\"\n :disable-persistency=\"disablePersistency\"\n :schema=\"filterSchema\"\n :validation-schema=\"validationSchema\"\n @change=\"filters = $event\"\n @reset=\"reset\"\n @submit=\"onFilter\"\n />\n </div>\n </Expand>\n </div>\n\n <div\n v-if=\"showSecondaryControls\"\n class=\"secondary-controls\"\n :class=\"[$style['legacy-box'], { 'tw-col-span-12 tw-mt-0 lg:tw-col-span-6': showPrimaryControls }]\"\n >\n <slot name=\"secondary-controls\"></slot>\n </div>\n </div>\n\n <!-- @slot Renders custom content in the space below the filters and above the list -->\n <slot name=\"eyebrow\"></slot>\n\n <div\n v-if=\"shouldShowTotal || Object.keys(sorts).length\"\n class=\"tw-mb-1.5\"\n :class=\"shouldShowTotal ? $style['total-sort'] : 'tw-text-right'\"\n >\n <div v-if=\"shouldShowTotal\" class=\"tw-text-xs\">{{ total }}</div>\n\n <!-- Sort -->\n <Dropdown\n v-if=\"Object.keys(sorts).length\"\n :class=\"$style.dropdown\"\n :label=\"`${sortLabel} ${sortTerm}`\"\n @toggle.once=\"onSortToggle\"\n >\n <ul ref=\"sortOptions\" class=\"dropdown__list\" :style=\"{ minWidth: sortOptionsWidth }\">\n <li\n v-for=\"(sortOption, index) in Object.keys(sorts)\"\n :key=\"index\"\n :class=\"{ 'tw-bg-blue-100 tw-text-ice-700': sortOption === sortTerm }\"\n class=\"dropdown__item tw-rounded\"\n >\n <Button inline class=\"tw-items-center\" :class=\"$style['sort-option']\" @click=\"onSort(sortOption)\">\n {{ sortOption }}\n <Icon v-if=\"sortOption === sortTerm\" name=\"check\" class=\"tw-ml-auto tw-text-blue-500\" />\n </Button>\n </li>\n </ul>\n </Dropdown>\n </div>\n\n <!-- Defined Slots -->\n <div v-if=\"useDefinedSlots\" :class=\"$style['list-items']\">\n <header\n v-sticky=\"headerOffset\"\n data-test=\"header|defined-slot\"\n :class=\"[\n $style.header,\n {\n 'tw-m-0': !isSelectable,\n },\n ]\"\n class=\"tw-rounded\"\n >\n <div :class=\"$style['header-grid-container']\" class=\"tw-border-b tw-border-ice-200 tw-px-3\">\n <Checkbox\n v-if=\"isSelectable\"\n class=\"tw-ml-3\"\n :checked=\"isSomePageChecked\"\n :class=\"$style['select-all']\"\n :indeterminate=\"isSomePageChecked && !isAllPageChecked\"\n @update:checked=\"onSelectPage\"\n />\n <div class=\"ll-grid tw-flex-1\" :class=\"$style['header-grid']\">\n <slot name=\"list-header\"> </slot>\n </div>\n </div>\n\n <!-- Select Bar -->\n <BulkActions\n v-if=\"isSelectable\"\n v-bind=\"{\n allowSelectAll: !hideSelectAll && !isServerSide,\n isAllPageChecked,\n isSomePageChecked,\n totalCount,\n totalSelectedCount,\n hideBulkActionOptions,\n hideNumberOfTotalSelected,\n }\"\n :class=\"!isSelectBarVisible && 'lg:tw-hidden'\"\n @change:clear-selected=\"clearSelected\"\n @change:select-current=\"onSelectPage\"\n @change:select-all=\"selectAll\"\n >\n <template #bulk-actions-content>\n <slot name=\"bulk-actions\" :selected-items=\"selectedItems\"> </slot>\n </template>\n </BulkActions>\n </header>\n\n <component\n :is=\"disableLoader ? 'div' : 'LoadingManager'\"\n :empty-state-text=\"emptyStateText\"\n :loading=\"isLoading\"\n :results=\"paginated\"\n >\n <slot\n name=\"list-items\"\n :clear-all=\"clearSelected\"\n :display-items=\"results\"\n :is-filtered=\"isFiltered\"\n :is-item-disabled=\"isItemDisabled\"\n :results=\"paginated\"\n :on-select=\"onSelectItem\"\n :selected-items=\"selectedItems\"\n ></slot>\n </component>\n </div>\n\n <!-- Default Slot -->\n <slot\n :current-page=\"currentPage\"\n :display-items=\"results\"\n :filters=\"filters\"\n :is-filtered=\"isFiltered\"\n :is-item-disabled=\"isItemDisabled\"\n :results=\"paginated\"\n :search-term=\"searchTerm\"\n :total=\"totalCount\"\n ></slot>\n\n <!-- Pagination -->\n <Paginate\n v-if=\"totalCount > pageSize\"\n :current-page=\"currentPage\"\n :list-length=\"totalCount\"\n :page-size=\"pageSize\"\n @set-page=\"onPaginateSetPage\"\n />\n </div>\n</template>\n\n<style module>\n .list-items {\n background-color: var(--color-ice-200);\n border-bottom-left-radius: theme('borderRadius.DEFAULT');\n border-bottom-right-radius: theme('borderRadius.DEFAULT');\n min-width: 100%;\n position: relative;\n }\n\n @media screen('lg') {\n .list-items {\n @apply tw-shadow;\n }\n }\n\n /* the .legacy-box styles are copied from .box in _box.scss */\n .legacy-box {\n @apply tw-shadow;\n\n background: var(--color-white);\n border-radius: theme('borderRadius.DEFAULT');\n padding: theme('spacing.6') var(--grid-gutter);\n }\n\n .header {\n background-color: var(--color-white);\n color: var(--color-ice-900);\n font-weight: 500;\n margin-bottom: theme('spacing.3');\n overflow: hidden;\n z-index: 1;\n\n &:global(.is-sticky) {\n @apply tw-shadow;\n\n border-radius: 0;\n overflow: visible;\n z-index: calc(theme('zIndex.control') + 1);\n\n &::before,\n &::after {\n background-color: var(--color-white);\n content: '';\n height: 100%;\n overflow-x: hidden;\n position: absolute;\n right: 100%;\n top: 0;\n width: theme('spacing.3');\n\n @media screen('lg') {\n content: none;\n }\n }\n\n &::after {\n left: 100%;\n right: auto;\n }\n }\n\n :global(.input--checkbox) {\n label {\n min-height: theme('spacing.6');\n }\n }\n\n @media screen('lg') {\n border-bottom-left-radius: 0;\n border-bottom-right-radius: 0;\n margin-bottom: 0;\n }\n }\n\n .header-grid-container {\n display: none;\n transition: padding theme('transitionDuration.150') theme('transitionTimingFunction.swing');\n\n @media screen('lg') {\n align-items: center;\n display: flex;\n }\n }\n\n .header-grid {\n column-gap: 0 !important;\n grid-column-gap: 0 !important;\n\n > div {\n align-items: center;\n border-right: 1px solid var(--color-ice-200);\n display: flex;\n font-size: theme('fontSize.xs');\n justify-content: space-between;\n padding: theme('spacing.3');\n\n &:first-of-type {\n margin-left: calc(-1 * theme('spacing.3'));\n padding-left: theme('spacing.6');\n }\n\n &:last-of-type {\n border-right: 0;\n margin-right: calc(-1 * theme('spacing.3'));\n }\n }\n }\n\n .search-input {\n :global(input) {\n /* to prevent search text from overlapping the \"Clear\" button */\n padding-right: calc(theme('height.input') * 2) !important;\n }\n\n :global(.stash-input-append) {\n display: flex;\n justify-content: flex-end;\n width: 72px; /* double the the default width of 36px */\n\n .clear-button {\n color: var(--color-ice-700);\n height: 36px;\n margin: 0;\n min-width: 36px;\n padding: 0;\n width: 36px;\n\n &:disabled {\n color: var(--color-ice-500);\n cursor: default;\n }\n }\n\n .search-button {\n border-bottom-left-radius: 0;\n border-color: var(--color-blue-500);\n border-left: none;\n border-top-left-radius: 0;\n min-width: 36px;\n padding: 0 theme('spacing[1.5]');\n width: 36px;\n\n &:disabled {\n border-color: var(--color-ice-500);\n }\n }\n }\n }\n\n @media screen('md') {\n .total-sort {\n align-items: baseline;\n display: flex;\n justify-content: space-between;\n }\n }\n\n .filter-toggle-btn {\n min-width: fit-content !important; /* ensure this overrides the grid min-width applied */\n }\n\n .filter-toggle-btn-with-hint-text {\n /* search hint text has 16px of height and has 4px of margin top. Adding here directly to compensate that */\n margin-bottom: 20px;\n }\n\n @keyframes separator {\n 0% {\n opacity: 0;\n }\n\n 100% {\n opacity: 1;\n }\n }\n\n .filters-expand:global(.stash-expand--expanded) {\n .filters-wrapper::before {\n animation: separator theme('transitionDuration.300') theme('transitionTimingFunction.ease-in-out') 0.5s 1 forwards;\n background: var(--color-ice-200);\n content: '';\n height: theme('borderWidth.DEFAULT');\n left: calc(var(--grid-gutter) * -1);\n opacity: 0;\n position: absolute;\n right: calc(var(--grid-gutter) * -1);\n top: theme('spacing.6');\n }\n }\n\n .filters-half-width {\n @media screen('lg') {\n :global(.field-wrapper) {\n grid-column: span 6 / span 6; /* col-span-6 */\n }\n }\n }\n\n .dropdown :global(.tw-text-blue-500) {\n font-size: theme('fontSize.xs');\n }\n\n .sort-option {\n height: theme('spacing.9');\n }\n\n .select-all {\n width: theme('spacing.6');\n }\n</style>\n"],"names":["_sfc_main","Button","Checkbox","t","value","_createElementBlock","_ctx","$props","_createElementVNode","_createVNode","_component_ll_checkbox","_normalizeClass","$options","_openBlock","_hoisted_1","_hoisted_2","_toDisplayString","_createBlock","_component_ll_button","_hoisted_3","_renderSlot","EmptyState","Loading","_component_Loading","_TransitionGroup","_component_EmptyState","Expand","Icon","sticky","isExpanded","getCssVar","CSS_VARS","$data","args","_component_Icon","_component_Expand","_component_ll_icon","DEFAULT_SEARCH_SCHEMA","BulkActions","Filters","Paginate","LoadingManager","Badge","Dropdown","Input","_a","persistentStorage","paginated","endIndex","totalCount","results","startIndex","current","range","item","id","acc","filterBy","isBoolean","isToggle","isEmpty","isInputOptionsIncomplete","cloneDeep","searchFor","useSearch","computed","searchTerm","sortTerms","actionResponse","items","_filterItems","_sortItems","trigger","currentPage","filters","isFiltered","pageSize","sortTerm","params","_b","LLLV_CHANGE_TRIGGERS","term","pageNumber","forceChange","selectedItem","_component_Input","$event","_cache","_withKeys","_component_Button","_component_Badge","_createTextVNode","_component_Filters","_hoisted_4","_component_Dropdown","_Fragment","_renderList","sortOption","index","_component_Checkbox","_component_BulkActions","_mergeProps","_resolveDynamicComponent","_component_Paginate"],"mappings":"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"}
1
+ {"version":3,"file":"ListView.js","sources":["../src/components/ListView/components/BulkActions.vue","../src/components/ListView/components/LoadingManager.vue","../src/components/ListView/components/ListGroup.vue","../src/components/ListView/components/ListHeader.vue","../src/components/ListView/ListView.vue"],"sourcesContent":["<script>\n import { t } from '../../../locale';\n import Button from '../../Button/Button.vue';\n import Checkbox from '../../Checkbox/Checkbox.vue';\n\n export default {\n name: 'bulk-actions',\n\n components: {\n 'll-button': Button,\n 'll-checkbox': Checkbox,\n },\n\n props: {\n allowSelectAll: Boolean,\n isAllPageChecked: Boolean,\n isSomePageChecked: Boolean,\n hideBulkActionOptions: Boolean,\n hideNumberOfTotalSelected: Boolean,\n totalCount: {\n type: Number,\n default: 0,\n },\n totalSelectedCount: {\n type: Number,\n default: 0,\n },\n },\n\n emits: ['change:select-current', 'change:select-all', 'change:clear-selected'],\n\n data: function () {\n return {\n selectAllText: t('ll.listView.selectAll'),\n };\n },\n\n computed: {\n clearSelectedText() {\n if (this.allowSelectAll) {\n return t('ll.listView.deselectAllCount', { count: this.totalCount });\n }\n\n return t('ll.listView.clearSelection');\n },\n\n showSelectAll() {\n return [this.totalSelectedCount !== this.totalCount, this.allowSelectAll].every(Boolean);\n },\n\n numberOfTotalSelectedText() {\n return t('ll.listView.numberOfTotalSelected', {\n num: this.totalSelectedCount,\n total: this.totalCount,\n });\n },\n\n selectAllCountText() {\n return t('ll.listView.selectAllCount', { count: this.totalCount });\n },\n\n numItemsSelectedText() {\n return t('ll.listView.numItemsSelected', {\n totalSelectedCount: this.totalSelectedCount,\n totalCount: this.totalCount,\n });\n },\n },\n\n methods: {\n onSelectPage(value) {\n this.$emit('change:select-current', value);\n },\n\n selectAll() {\n this.$emit('change:select-all');\n },\n\n clearSelected() {\n this.$emit('change:clear-selected');\n },\n },\n };\n</script>\n\n<template>\n <div\n class=\"lg:tw-flex\"\n :class=\"[\n $style['select-bar'],\n {\n 'lg:tw-hidden': hideBulkActionOptions,\n },\n 'tw-p-3',\n ]\"\n >\n <div\n class=\"tw-flex tw-items-center\"\n :class=\"{\n 'tw-justify-between': !hideBulkActionOptions,\n }\"\n >\n <ll-checkbox\n data-test=\"checkbox|bulk-actions\"\n :class=\"$style.checkbox\"\n class=\"tw-m-0 lg:tw-hidden\"\n :checked=\"isSomePageChecked && !!totalCount\"\n :indeterminate=\"isSomePageChecked && !isAllPageChecked\"\n :label=\"!totalSelectedCount ? selectAllText : ''\"\n @update:checked=\"onSelectPage\"\n />\n <div\n v-if=\"!!totalSelectedCount && !hideBulkActionOptions\"\n class=\"tw-flex tw-flex-1 tw-items-center tw-justify-between\"\n >\n <div v-if=\"!hideNumberOfTotalSelected\" class=\"tw-text-xs\">\n {{ numberOfTotalSelectedText }}\n </div>\n <div :class=\"{ 'tw-ml-3': !hideNumberOfTotalSelected }\">\n <ll-button v-if=\"showSelectAll\" inline @click=\"selectAll\">{{ selectAllCountText }}</ll-button>\n <ll-button v-else inline @click=\"clearSelected\">\n {{ clearSelectedText }}\n </ll-button>\n </div>\n </div>\n <div v-else-if=\"hideBulkActionOptions && !!totalSelectedCount\" class=\"tw-ml-1.5 lg:tw-hidden\">\n <h4>{{ numItemsSelectedText }}</h4>\n </div>\n </div>\n <div v-if=\"!!totalSelectedCount && !hideBulkActionOptions\" :class=\"$style.actions\">\n <slot name=\"bulk-actions-content\"></slot>\n </div>\n </div>\n</template>\n\n<style module>\n .select-bar {\n @media screen('lg') {\n border-bottom: 1px solid var(--color-ice-200);\n justify-content: center;\n vertical-align: middle;\n }\n }\n\n .checkbox {\n flex: 0 0 auto;\n }\n\n .actions > * {\n margin-top: theme('spacing.6');\n width: 100%;\n\n @media screen('lg') {\n margin-left: theme('spacing.3');\n margin-top: 0;\n width: auto;\n }\n }\n</style>\n","<script>\n import EmptyState from '../../EmptyState/EmptyState.vue';\n import Loading from '../../Loading/Loading.vue';\n\n export default {\n name: 'loading-manager',\n\n components: {\n EmptyState,\n Loading,\n },\n\n props: {\n emptyStateText: {\n type: String,\n default: '',\n },\n\n loading: Boolean,\n\n results: {\n type: Array,\n default: () => [],\n },\n },\n };\n</script>\n\n<template>\n <Loading v-if=\"loading\" class=\"ll-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=\"ll-bg-white\" :class=\"$style['empty-state']\" :text=\"emptyStateText\" />\n</template>\n\n<style module>\n .empty-state {\n max-width: 100%;\n }\n</style>\n","<script>\n import { CSS_VARS } from '../../../constants';\n import sticky from '../../../directives/sticky/sticky';\n import { getCssVar } from '../../../utils/helpers';\n import Button from '../../Button/Button.vue';\n import Expand from '../../Expand/Expand.vue';\n import Icon from '../../Icon/Icon.vue';\n\n export default {\n name: 'list-group',\n\n components: {\n Expand,\n 'll-button': Button,\n Icon,\n },\n\n directives: {\n sticky,\n },\n\n props: {\n /**\n * Disables the gutters between adjacent ListGroup components.\n */\n disableExternalGutters: {\n type: Boolean,\n default: false,\n },\n\n /**\n * Allows the list items to be collapsed\n */\n isCollapsible: {\n type: Boolean,\n default: false,\n },\n\n /**\n * Allows the expanded content to be collapsed by default.\n * Note: has no effect unless the `isCollapsible` prop is `true`.\n */\n isCollapsedByDefault: {\n type: Boolean,\n default: false,\n },\n },\n\n data() {\n const isExpanded = !this.isCollapsible || !this.isCollapsedByDefault;\n\n return {\n isExpanded,\n isDoneExpanding: isExpanded,\n };\n },\n\n computed: {\n headerOffset() {\n return parseFloat(getCssVar(CSS_VARS.TOP_HEADER_HEIGHT));\n },\n },\n\n methods: {\n toggleExpand() {\n if (!this.isCollapsible) {\n return;\n }\n\n this.isExpanded = !this.isExpanded;\n\n if (!this.isExpanded) {\n this.isDoneExpanding = false;\n } // else wait for Expand to emit @after-expand\n },\n\n onHeaderClick(e) {\n // toggle the ListGroup, except when clicking the actions\n if (!this.$refs.actionsContainer.contains(e.target)) {\n this.toggleExpand();\n }\n },\n },\n };\n</script>\n\n<template>\n <div\n :class=\"[\n $style['list-group'],\n {\n 'disable-external-gutters': disableExternalGutters,\n 'is-collapsed': !isExpanded,\n },\n ]\"\n >\n <header\n class=\"tw-flex tw-items-center\"\n :class=\"[$style['main-header'], { 'tw-cursor-pointer': isCollapsible }]\"\n @click=\"onHeaderClick\"\n >\n <ll-button v-if=\"isCollapsible\" :class=\"['tw-mr-1.5 tw-text-ice-900', $style['expansion-toggle-button']]\" icon>\n <Icon :class=\"[isExpanded ? 'tw-rotate-270' : 'rotate-180']\" name=\"chevron-left\" />\n </ll-button>\n\n <div class=\"tw-flex-auto\">\n <slot name=\"title\"></slot>\n </div>\n\n <div ref=\"actionsContainer\">\n <slot name=\"actions\"></slot>\n </div>\n </header>\n\n <Expand :is-expanded=\"isExpanded\" @after-expand=\"isDoneExpanding = true\">\n <div :class=\"$style['expanded-content-wrapper']\">\n <header\n v-if=\"$slots['expanded-content-list-header']\"\n v-sticky=\"isExpanded && isDoneExpanding ? headerOffset : 0\"\n :class=\"$style['expanded-content-header']\"\n >\n <div class=\"tw-ll-grid tw-flex-1\" :class=\"$style['expanded-content-header-grid']\">\n <slot name=\"expanded-content-list-header\"></slot>\n </div>\n </header>\n <div :class=\"$style['expanded-content-list-items-wrapper']\">\n <transition-group name=\"fade\" mode=\"out-in\">\n <slot name=\"expanded-content-list-items\"></slot>\n </transition-group>\n </div>\n </div>\n </Expand>\n </div>\n</template>\n\n<style module>\n .main-header {\n @apply tw-shadow;\n\n background-color: var(--color-white);\n border-radius: theme('borderRadius.DEFAULT');\n margin-bottom: theme('spacing.6');\n padding: var(--grid-gutter);\n\n @media screen('lg') {\n border-bottom: theme('borderWidth.DEFAULT') solid var(--color-ice-200);\n border-bottom-left-radius: 0;\n border-bottom-right-radius: 0;\n margin-bottom: 0;\n }\n }\n\n .expanded-content-wrapper {\n position: relative;\n width: 100%;\n }\n\n @media screen('lg') {\n .expanded-content-wrapper {\n @apply tw-shadow;\n }\n }\n\n .expanded-content-header {\n background-color: var(--color-white);\n border-bottom: theme('borderWidth.DEFAULT') solid var(--color-ice-200);\n color: var(--color-ice-900);\n display: none;\n font-weight: 500;\n padding: 0 theme('spacing.3');\n transition: padding theme('transitionDuration.150') theme('transitionTimingFunction.swing');\n z-index: 1;\n\n @media screen('lg') {\n align-items: center;\n display: flex;\n }\n\n &:global(.is-sticky) {\n @apply tw-shadow;\n\n border-radius: 0;\n z-index: calc(theme('zIndex.control') + 1);\n }\n }\n\n .expanded-content-header-grid {\n column-gap: 0;\n grid-column-gap: 0;\n\n > div {\n align-items: center;\n border-right: theme('borderWidth.DEFAULT') solid var(--color-ice-200);\n display: flex;\n font-size: theme('fontSize.xs');\n justify-content: space-between;\n padding: theme('spacing.3');\n\n &:last-of-type {\n border-right: 0;\n }\n }\n }\n\n .expansion-toggle-button:focus {\n box-shadow: none;\n }\n\n .list-group:global(.disable-external-gutters) {\n .main-header {\n @media screen('lg') {\n border-radius: 0;\n }\n }\n\n .expanded-content-list-items-wrapper > * {\n @media screen('lg') {\n border-bottom: theme('borderWidth.DEFAULT') solid var(--color-ice-200);\n border-radius: 0;\n }\n }\n\n &:last-of-type {\n &:global(.is-collapsed) .main-header,\n .expanded-content-list-items-wrapper > *:last-child {\n @media screen('lg') {\n border-bottom: none;\n border-bottom-left-radius: theme('borderRadius.DEFAULT');\n border-bottom-right-radius: theme('borderRadius.DEFAULT');\n }\n }\n }\n }\n</style>\n","<script>\n import Icon from '../../Icon/Icon.vue';\n\n export default {\n name: 'list-header',\n\n components: {\n 'll-icon': Icon,\n },\n\n props: {\n /**\n * keys to be sorted for the column\n * the first key should be the default sort value\n */\n sortKeys: {\n type: Array,\n required: true,\n validator: (value) => value.length === 2,\n },\n\n listViewRef: {\n type: Object,\n default: null,\n },\n },\n\n data() {\n return {\n isAscending: null,\n };\n },\n\n computed: {\n listViewInstance() {\n return this.listViewRef || this.$parent;\n },\n /**\n * Is the column currently sorted\n */\n isSorted() {\n return this.sortKeys.includes(this.listViewInstance.sortTerm);\n },\n\n /**\n * Show the top icon if it's not sorted or if the current sortTerm matches\n */\n showCaretUp() {\n return this.isAscending === null || this.sortKeys[0] === this.listViewInstance.sortTerm;\n },\n\n /**\n * Show the bottom icon if it's not sorted or if the current sortTerm matches\n */\n showCaretDown() {\n return this.isAscending === null || this.sortKeys[1] === this.listViewInstance.sortTerm;\n },\n },\n\n watch: {\n isSorted: {\n handler(value) {\n this.isAscending = value ? true : null;\n },\n immediate: true,\n },\n },\n\n methods: {\n /**\n * Sorts the column by the sort field\n */\n sort() {\n this.listViewInstance.onSort(this.sortKeys[this.isAscending ? 1 : 0]);\n this.isAscending = !this.isAscending;\n },\n },\n };\n</script>\n\n<template>\n <div :class=\"['tw-cursor-pointer', { 'tw-bg-blue-100': isSorted }]\" @click=\"sort\">\n <slot></slot>\n <div class=\"h-4 w-3 tw-relative tw-text-ice-700\" :class=\"{ 'is-active-sort': isSorted }\">\n <ll-icon\n v-if=\"showCaretUp\"\n name=\"caret-up\"\n class=\"tw-absolute\"\n :class=\"[$style.caret, $style['caret-up']]\"\n size=\"dense\"\n />\n <ll-icon\n v-if=\"showCaretDown\"\n name=\"caret-down\"\n class=\"tw-absolute\"\n :class=\"[$style.caret, $style['caret-down']]\"\n size=\"dense\"\n />\n </div>\n </div>\n</template>\n\n<style module>\n .caret-up {\n top: -5px;\n }\n\n .caret-down {\n top: 2px;\n }\n\n :global(.is-active-sort) .caret {\n top: -2px; /* vertically center the caret icon */\n }\n</style>\n","<script>\n import cloneDeep from 'lodash-es/cloneDeep';\n import { computed } from 'vue';\n\n import useSearch from '../../composables/useSearch/useSearch';\n import { CSS_VARS, LLLV_CHANGE_TRIGGERS } from '../../constants';\n import sticky from '../../directives/sticky/sticky';\n import { t } from '../../locale';\n import { persistentStorage } from '../../storage';\n import { filterItems as _filterItems, getCssVar, sortItems as _sortItems } from '../../utils/helpers';\n import Badge from '../Badge/Badge.vue';\n import Button from '../Button/Button.vue';\n import Checkbox from '../Checkbox/Checkbox.vue';\n import Dropdown from '../Dropdown/Dropdown.vue';\n import Expand from '../Expand/Expand.vue';\n import Filters from '../Filters/Filters.vue';\n import Icon from '../Icon/Icon.vue';\n import Input from '../Input/Input.vue';\n import Paginate from '../Paginate/Paginate.vue';\n import BulkActions from './components/BulkActions.vue';\n import LoadingManager from './components/LoadingManager.vue';\n\n export { default as BulkActions } from './components/BulkActions.vue';\n export { default as ListGroup } from './components/ListGroup.vue';\n export { default as ListHeader } from './components/ListHeader.vue';\n export { default as LoadingManager } from './components/LoadingManager.vue';\n\n const DEFAULT_SEARCH_SCHEMA = {\n isSearchable: true,\n placeholder: 'Search',\n searchBy: ['name'],\n };\n\n export default {\n name: 'll-list-view',\n\n components: {\n BulkActions,\n Filters,\n Paginate,\n LoadingManager,\n Badge,\n Button,\n Icon,\n Dropdown,\n Expand,\n Checkbox,\n Input,\n },\n\n directives: {\n sticky,\n },\n\n inject: {\n trackSearch: { default: () => () => {} },\n trackFilters: { default: () => () => {} },\n trackSort: { default: () => () => {} },\n trackResults: { default: () => () => {} },\n },\n\n props: {\n /**\n * Hide the '{number} of {total} selected' text for bulk actions\n */\n hideNumberOfTotalSelected: {\n type: Boolean,\n default: false,\n },\n /**\n * Hide the Select All checkbox for bulk actions\n */\n hideSelectAll: {\n type: Boolean,\n default: false,\n },\n /**\n * Text to render in EmptyState component if there are no results\n */\n emptyStateText: {\n type: String,\n default: '',\n },\n filterSchema: {\n type: Array,\n default: () => [],\n },\n /**\n * Make search fuzzy. Only for client side search.\n */\n fuzzySearch: {\n type: Boolean,\n default: false,\n },\n hideTotal: Boolean,\n initialPage: {\n type: Number,\n default: undefined,\n },\n /**\n * Can items on the page be selected for bulk actions\n */\n isSelectable: Boolean,\n /**\n * For loading data already paginated, filtered (including search), and sorted from a backend.\n * Defining this prop will disable the built-in search, filtering, sorting and pagination.\n * You will instead need to use the available events (`@change`, and `@change:` prefixed)\n * to know when to request new pages from your backend.\n * This requires providing `totalItemCount`.\n * Use the loading prop to indicate when data is being loaded.\n */\n isServerSide: Boolean,\n /**\n * The data for each row. Used in this file as this.internalItems (a copy) to allow mutation;\n */\n items: {\n type: Array,\n default: () => [],\n },\n /**\n * Default field to track selected items by\n */\n itemTrackBy: {\n type: String,\n default: 'id',\n },\n loading: Boolean,\n // Number of items to display per page\n pageSize: {\n type: Number,\n default: 50,\n },\n searchSchema: {\n type: Object,\n default: () => ({}),\n },\n // Provide an optional custom 'Sort by' label\n sortLabel: {\n type: String,\n default: () => t('ll.listView.sortBy'),\n },\n sortOnLoad: Boolean,\n sorts: {\n type: Object,\n default: () => ({}),\n },\n /**\n * Total number of unpaginated results\n * Required when `isServerSide` is `true`\n */\n totalItemCount: {\n type: Number,\n default: undefined,\n },\n /**\n * Validation schema function that returns an object\n */\n validationSchema: {\n type: Function,\n default: () => () => undefined,\n },\n /**\n * Whether to disable the sticky filters\n * if disabled, the following will happen\n * 1. pre-selected value(s) can be added to\n * the filter component's attributes to overwrite the sticky filters\n * 2. users will not have sticky filters on the page\n */\n disablePersistency: Boolean,\n /**\n * Whether to disable the ability of saving 'show-filters'\n * in local storage\n */\n disableShowFilter: Boolean,\n /**\n * Whether to disable the stickiness of the header.\n * Default is false. When true, neither the list headers nor\n * the bulk actions (when applicable) will be sticky.\n */\n disableStickyHeader: Boolean,\n /**\n * Whether to expand the filters section by default on load.\n */\n showFiltersOnLoad: Boolean,\n\n /**\n * Do not use the LoadingManager, and instead render the default slot as passed\n */\n disableLoader: {\n type: Boolean,\n default: false,\n },\n\n /**\n * Override the header offset used to position the sticky header\n */\n stickyHeaderOffset: {\n type: Number,\n default: null,\n },\n /**\n * Prevent bulk actions dropdown from rendering\n */\n hideBulkActionOptions: {\n type: Boolean,\n default: false,\n },\n\n /**\n * If initial search term is provided, the list will be filtered on load.\n */\n initialSearchTerm: {\n type: String,\n default: '',\n },\n\n /**\n * Function that determines whether the item checkbox is disabled or not (default: false)\n */\n isItemDisabled: {\n type: Function,\n default: () => false,\n },\n },\n\n emits: [\n 'change',\n 'change:filter',\n 'change:page',\n 'change:search',\n 'change:sort',\n 'change:reset',\n 'filters-toggle-click',\n 'select-all',\n 'deselect-all',\n 'update-filters',\n 'updateResults',\n ],\n\n data() {\n return {\n internalItems: [],\n currentPage: this.initialPage || 1, // TODO: fetch from query params\n previousPage: null,\n sortOptionsWidth: 0,\n filters: {},\n filterText: t('ll.filter'),\n searchFor: () => {}, // initialized in the watch handler for internalItems\n searchTerm: this.initialSearchTerm,\n searchText: t('ll.search'),\n sortTerm: '',\n isLoadingSearchSchemaAction: false,\n isShowingFilters: !!(\n this.filterSchema?.length &&\n (this.showFiltersOnLoad || persistentStorage.get('show-filters'))\n ),\n isFiltering: false,\n results: [],\n selectedItems: [],\n };\n },\n\n computed: {\n /**\n * Returns true if any of its list items are truthy; otherwise returns false.\n * @returns {boolean}\n */\n isLoading() {\n return [this.loading, this.isLoadingSearchSchemaAction, this.isFiltering].some(Boolean);\n },\n\n totalCount() {\n return this.isServerSide ? this.totalItemCount : this.results.length;\n },\n\n /**\n * Helps determine if the list is filtered or not when there is an incomplete\n * result list, such as when isServerSide is true.\n */\n isFiltered() {\n return !!(this.numberOfFilters || this.searchTerm);\n },\n\n /**\n * Merges the searchSchema with the default value since all attributes are optional\n */\n internalSearchSchema() {\n return {\n ...DEFAULT_SEARCH_SCHEMA,\n searchBy: !this.searchSchema.isSearchable && DEFAULT_SEARCH_SCHEMA.searchBy,\n ...this.searchSchema,\n };\n },\n\n /**\n * Start of page\n */\n startIndex() {\n return this.pageSize * (this.currentPage - 1);\n },\n\n /**\n * End of page\n */\n endIndex() {\n return this.startIndex + this.pageSize;\n },\n\n /**\n * Slices the results set into a paginated segment.\n * @returns One page in the paginated set of results\n */\n paginated() {\n // Disables the built-in client-side pagination\n let paginated;\n\n if (this.isServerSide) {\n paginated = this.results;\n } else {\n const { endIndex, totalCount, results, startIndex } = this;\n\n paginated = results.slice(startIndex, Math.min(endIndex, totalCount));\n }\n\n this.$emit('updateResults', paginated);\n\n return paginated;\n },\n\n /**\n * Displays a visual indication for the number of results, or \"working\" if the\n * results are being determined.\n */\n total() {\n const current = this.pageSize * (this.currentPage - 1);\n const range = this.paginated.length ? `${current + 1} - ${current + this.paginated.length}` : 0;\n\n return this.isLoading\n ? t('ll.listView.calculating')\n : t('ll.listView.totalResults', { num: String(range), total: String(this.totalCount) });\n },\n\n /**\n * Determines if both #list-header and #list-items slots are used.\n * @returns {boolean}\n */\n useDefinedSlots() {\n return !!this.$slots['list-header'] && !!this.$slots['list-items'];\n },\n\n /**\n * Don't show total count if list items are selected and total is not hidden\n */\n shouldShowTotal() {\n return !this.totalSelectedCount && !this.hideTotal;\n },\n\n /**\n * Returns a list of the selected items' track by field\n */\n selectedItemIds() {\n return this.selectedItems.map((item) => item[this.itemTrackBy]);\n },\n\n /**\n * Returns a list of the paginated items' track by field\n */\n paginatedIds() {\n return this.paginated.map((item) => item[this.itemTrackBy]);\n },\n\n isAllPageChecked() {\n if (this.isServerSide) {\n return this.totalCount > 0 && this.totalCount === this.selectedItemIds.length;\n }\n\n return this.totalCount > 0 && this.paginatedIds.every((id) => this.selectedItemIds.includes(id));\n },\n\n isSomePageChecked() {\n if (this.isServerSide) {\n return this.totalCount > 0 && this.selectedItemIds.length > 0;\n }\n\n return this.totalCount > 0 && this.paginatedIds.some((id) => this.selectedItemIds.includes(id));\n },\n\n numberOfFilters() {\n return Object.keys(this.filters).reduce((acc, item) => {\n const filterBy = this.filters[item].filterBy;\n const isBoolean = typeof filterBy[0] === 'boolean';\n const isToggle = this.filters[item].filterType === 'll-checkbox';\n const isEmpty = !this.filters[item].filterType.length;\n const isInputOptionsIncomplete = this.filters[item].filterType === 'll-input-options' && filterBy[0] === '';\n\n /**\n * Don't include hidden or incomplete fields in the count:\n * - Hidden filter populated via another filter's onChange callback\n * - InputOptions with incomplete/missing values\n */\n if (isEmpty || isInputOptionsIncomplete) {\n return acc;\n }\n\n if (isBoolean || typeof filterBy[0] === 'string') {\n // Do not count toggle filters (eg. checkbox) with a `false` value\n return acc + (filterBy[0] || !isToggle ? 1 : 0);\n }\n\n return acc + (filterBy.length || 0);\n }, 0);\n },\n\n isSelectBarVisible() {\n return !!this.totalSelectedCount;\n },\n\n showPrimaryControls() {\n return this.internalSearchSchema.isSearchable || this.filterSchema.length;\n },\n\n showSecondaryControls() {\n return !!this.$slots['secondary-controls'];\n },\n\n isSortable() {\n return Object.keys(this.sorts).length > 0;\n },\n\n totalSelectedCount() {\n return this.selectedItems.length;\n },\n\n headerOffset() {\n // passing null to the v-sticky directive will prevent it from being attached to the node\n if (this.disableStickyHeader) {\n return null;\n }\n\n return this.stickyHeaderOffset ?? parseFloat(getCssVar(CSS_VARS.TOP_HEADER_HEIGHT));\n },\n },\n\n watch: {\n isShowingFilters(value) {\n if (!this.disableShowFilter) {\n persistentStorage.set('show-filters', value);\n }\n },\n\n items: {\n handler() {\n this.internalItems = cloneDeep(this.items);\n },\n immediate: true,\n deep: true,\n },\n\n internalItems: {\n handler() {\n if (this.isServerSide) {\n this.results = this.internalItems;\n\n this.trackResults({\n page: this.currentPage,\n results: this.results,\n search: this.searchTerm,\n });\n\n return;\n }\n\n const { searchFor } = useSearch({\n items: computed(() => this.internalItems),\n fieldNames: this.internalSearchSchema.searchBy.length\n ? this.internalSearchSchema.searchBy\n : [this.displayBy],\n trackBy: this.itemTrackBy,\n });\n\n this.searchFor = (searchTerm) => searchFor(searchTerm, { fuzzy: this.fuzzySearch });\n\n this.processResults();\n },\n immediate: true,\n },\n\n sortTerm() {\n if (this.isServerSide) {\n return;\n }\n\n this.processResults();\n },\n\n sorts: {\n handler(value) {\n const sortTerms = Object.keys(value);\n\n this.sortTerm = this.sortOnLoad && sortTerms.length ? sortTerms[0] : '';\n },\n immediate: true,\n },\n },\n\n created() {\n if (this.isServerSide) {\n if (this.totalItemCount === undefined) {\n throw new Error('`totalItemCount` is required when `isServerSide` is `true`.');\n }\n\n return;\n }\n\n if (this.searchSchema.action && this.internalItems.length) {\n throw new Error('You must pass either `action` or `items`, not both.');\n }\n\n if (this.searchTerm) {\n this.onSearch();\n }\n },\n\n methods: {\n /**\n * Processes the results with searchFor, filterItems, and/or sortItems.\n * Skipped when isServerSide is true because results are pre-processed.\n * @returns {Promise<void>}\n */\n async processResults() {\n if (this.searchSchema.action) {\n this.isLoadingSearchSchemaAction = true;\n let actionResponse;\n\n try {\n actionResponse = await this.searchSchema.action({ search: this.searchTerm });\n } finally {\n this.isLoadingSearchSchemaAction = false;\n }\n\n this.results = this.sortItems(this.filterItems(actionResponse?.results || []));\n } else {\n this.results = this.sortItems(this.filterItems(this.searchFor(this.searchTerm)));\n }\n\n this.trackResults({\n page: this.currentPage,\n results: this.results,\n search: this.searchTerm,\n });\n },\n\n /**\n * Filters the list of `items` based on options selected in the `filters` object\n * @param {array} items A list of items to filter.\n * @returns list of items filtered by the applied filters\n */\n filterItems(items) {\n return _filterItems(items, this.filters);\n },\n\n /**\n * Sorts a list of items based on options selected in the `sorts` object\n * @param {array} items A list of items to sort.\n * @returns list of items sorted according to the sort term.\n */\n sortItems(items) {\n return this.sortTerm ? _sortItems(items, this.sorts[this.sortTerm]) : items;\n },\n\n change({ trigger = '' } = {}) {\n const { currentPage, filters, isFiltered, pageSize, searchTerm, sortTerm } = this;\n\n const params = {\n filters,\n isFiltered,\n page: {\n number: currentPage,\n previousNumber: this.previousPage,\n size: pageSize,\n },\n search: searchTerm,\n sort: sortTerm,\n trigger,\n };\n\n this.$emit('change', params);\n },\n\n /**\n * Clear search term and reset results to their initial state\n */\n async clearSearchTerm() {\n this.searchTerm = '';\n await this.$attrs.onSearchTermClear?.();\n this.onSearch();\n },\n\n /**\n * Resets the results to their initial state on page load\n */\n reset() {\n this.$emit('change:reset');\n\n this.searchTerm = '';\n\n this.setPage({ pageNumber: 1 });\n\n if (this.isServerSide) {\n this.change({ trigger: LLLV_CHANGE_TRIGGERS.RESET });\n\n return;\n }\n\n this.processResults();\n },\n\n onSearchTermChange() {\n this.$attrs.onSearchTermChange?.(this.searchTerm);\n },\n\n /**\n * Event handler for when the user:\n * - clicks the Search button\n * - presses the enter key while focused on the search input\n * Calls a method in Filters that triggers `this.onFilter`. This is necessary\n * in order to persist the filters in local storage, which is handled internally\n * by Filters.\n */\n onSearch() {\n this.$refs.llFilters.applyFilters({ trigger: LLLV_CHANGE_TRIGGERS.SEARCH });\n },\n\n /**\n * Event handler for when the user:\n * - clicks the Apply button\n * - clicks the Search button (from `this.onSearch`)\n * - presses the enter key while focused on the search input (from `this.onSearch`)\n * @see: SELL-350\n * @param {object} [options] - optional parameters\n * @param {string} [options.trigger] - what caused the changes\n * @returns {Promise<void>}\n */\n async onFilter({ trigger = LLLV_CHANGE_TRIGGERS.APPLY } = {}) {\n this.setPage({ pageNumber: 1 });\n this.change({ trigger });\n this.trackSearch(this.searchTerm);\n this.trackFilters(this.filters);\n this.selectedItems = [];\n\n if (this.isServerSide) {\n return;\n }\n\n try {\n this.isFiltering = true;\n await this.processResults({ trigger });\n } finally {\n this.isFiltering = false;\n }\n\n this.$emit('change:search', this.searchTerm);\n this.$emit('change:filter', this.filters);\n this.$emit('update-filters', this.filters); // deprecated; replaced by change:filter\n this.clearSelected();\n },\n\n onFiltersToggleClick() {\n this.isShowingFilters = !this.isShowingFilters;\n\n this.$emit('filters-toggle-click', {\n isShowingFilters: this.isShowingFilters,\n });\n },\n\n /**\n * Extend the dropdown list so it does not shift when\n * the options drawer is open\n */\n onSortToggle() {\n // spacing added to the width of the dropdown container\n const spacing = 36;\n\n this.$nextTick(() => {\n this.sortOptionsWidth = `${this.$refs.sortOptions.clientWidth + spacing}px`;\n });\n },\n\n /**\n * Executes any side-effects when the sort `term` is changed\n * Always fires `change` automatically.\n * @param {string} term The updated sort term\n */\n onSort(term) {\n if (term === this.sortTerm) {\n return;\n }\n\n this.sortTerm = term;\n\n this.$emit('change:sort', term);\n this.trackSort(term);\n this.clearSelected();\n this.setPage({ pageNumber: 1 });\n this.change({ trigger: LLLV_CHANGE_TRIGGERS.SORT });\n },\n\n /**\n * Sets current page for the Paginator.\n * @param {Object} data\n * @param {number} data.pageNumber - the page number\n * @param {boolean} data.forceChange - flag to force the change\n */\n setPage({ pageNumber, forceChange = false } = {}) {\n this.previousPage = this.currentPage;\n\n this.currentPage = pageNumber;\n\n if (!this.isServerSide) {\n this.$emit('change:page', pageNumber);\n }\n\n if (forceChange) {\n this.change({ trigger: LLLV_CHANGE_TRIGGERS.PAGE });\n }\n },\n\n /**\n * Set the scroll position to the top of the list view.\n */\n scrollToTop() {\n this.$refs.scrollTarget && this.$refs.scrollTarget.scrollIntoView({ behavior: 'smooth', block: 'center' });\n },\n\n onPaginateSetPage(pageNumber) {\n this.setPage({ pageNumber, forceChange: true });\n this.scrollToTop();\n },\n\n /**\n * Selects or deselects all items on a page\n */\n onSelectPage(value) {\n this.$emit('select-all', value);\n\n if (value) {\n const items = Array.from(new Set([...this.selectedItems, ...this.paginated]));\n\n this.selectedItems = this.selectItems(items);\n } else {\n this.selectedItems = this.selectedItems.filter((item) => !this.paginatedIds.includes(item[this.itemTrackBy]));\n }\n },\n\n selectAll() {\n this.selectedItems = this.selectItems(this.results);\n },\n\n /**\n * Selects one item\n */\n onSelectItem({ item, value }) {\n if (this.isItemDisabled(item)) {\n return;\n }\n\n if (value) {\n this.selectedItems.push(item);\n } else {\n this.selectedItems = this.selectedItems.filter(\n (selectedItem) => selectedItem[this.itemTrackBy] !== item[this.itemTrackBy],\n );\n }\n },\n\n /**\n * Clears current selected items\n */\n clearSelected() {\n this.$emit('deselect-all');\n this.selectedItems = [];\n },\n\n selectItems(items) {\n return items.reduce((acc, item) => (this.isItemDisabled(item) ? acc : [...acc, item]), []);\n },\n },\n };\n</script>\n\n<template>\n <div>\n <div\n v-if=\"showPrimaryControls || showSecondaryControls\"\n ref=\"scrollTarget\"\n class=\"tw-mb-6\"\n :class=\"{ 'tw-ll-grid': showPrimaryControls && showSecondaryControls }\"\n >\n <div\n v-if=\"showPrimaryControls\"\n class=\"controls\"\n :class=\"[$style['legacy-box'], { 'tw-col-span-12 lg:tw-col-span-6': showSecondaryControls }]\"\n data-test=\"filters|controls\"\n >\n <div class=\"tw-ll-grid tw-grid-cols-4 md:tw-grid-cols-8 lg:tw-grid-cols-12\">\n <!-- Search -->\n <Input\n v-if=\"internalSearchSchema.isSearchable\"\n ref=\"search-input\"\n v-model=\"searchTerm\"\n class=\"tw-col-span-3 md:tw-col-span-4\"\n data-test=\"input|search-input\"\n :class=\"[$style['search-input'], { 'lg:tw-col-span-8': showSecondaryControls }]\"\n :hint-text=\"internalSearchSchema.hintText\"\n :label=\"searchText\"\n :placeholder=\"internalSearchSchema.placeholder\"\n @keyup.enter=\"!isLoading && onSearch()\"\n @change=\"onSearchTermChange\"\n >\n <template #append>\n <button\n v-if=\"searchTerm\"\n data-test=\"button|clear-search\"\n :class=\"$style['clear-button']\"\n :disabled=\"isLoading\"\n @click=\"clearSearchTerm\"\n >\n <Icon name=\"close\" />\n </button>\n <Button\n data-test=\"button|search-button\"\n :disabled=\"isLoading\"\n :class=\"$style['search-button']\"\n @click=\"onSearch\"\n >\n <Icon\n :class=\"{ 'tw-animate-spin tw-text-teal-500': isFiltering }\"\n :name=\"isFiltering ? 'working' : 'search'\"\n />\n </Button>\n </template>\n </Input>\n\n <!-- Filter Toggle -->\n <div\n v-if=\"filterSchema.length\"\n class=\"tw-col-span-1 tw-flex tw-items-end\"\n :class=\"[\n $style['filter-toggle-btn'],\n { [$style['filter-toggle-btn-with-hint-text']]: !!internalSearchSchema.hintText },\n ]\"\n >\n <Badge :content=\"numberOfFilters\">\n <Button\n secondary\n class=\"tw-relative tw-w-full tw-min-w-auto\"\n color=\"blue\"\n data-test=\"button|toggle-filters\"\n :disabled=\"isFiltering\"\n @click=\"onFiltersToggleClick\"\n >\n <Icon\n v-if=\"isFiltering\"\n name=\"working\"\n :class=\"[\n { 'tw-animate-spin': isFiltering },\n isShowingFilters ? 'tw-text-teal-500' : 'tw-text-ice-700',\n ]\"\n />\n <Icon v-else name=\"filter-line\" />\n {{ filterText }}\n </Button>\n </Badge>\n </div>\n\n <!-- Actions -->\n <div class=\"button-grid tw-col-span-1 tw-items-end tw-justify-end lg:tw-col-span-3\">\n <slot name=\"actions\"> </slot>\n </div>\n </div>\n\n <!-- Filters -->\n <Expand data-test=\"filters|content\" :class=\"$style['filters-expand']\" :is-expanded=\"isShowingFilters\">\n <div class=\"tw-relative tw-pt-12\" :class=\"$style['filters-wrapper']\">\n <Filters\n ref=\"llFilters\"\n :class=\"{ [$style['filters-half-width']]: showPrimaryControls && showSecondaryControls }\"\n :disable-apply=\"isLoading\"\n :disable-clear=\"isLoading || !numberOfFilters\"\n :disable-persistency=\"disablePersistency\"\n :schema=\"filterSchema\"\n :validation-schema=\"validationSchema\"\n @change=\"filters = $event\"\n @reset=\"reset\"\n @submit=\"onFilter\"\n />\n </div>\n </Expand>\n </div>\n\n <div\n v-if=\"showSecondaryControls\"\n class=\"secondary-controls\"\n :class=\"[$style['legacy-box'], { 'tw-col-span-12 tw-mt-0 lg:tw-col-span-6': showPrimaryControls }]\"\n >\n <slot name=\"secondary-controls\"></slot>\n </div>\n </div>\n\n <!-- @slot Renders custom content in the space below the filters and above the list -->\n <slot name=\"eyebrow\"></slot>\n\n <div\n v-if=\"shouldShowTotal || Object.keys(sorts).length\"\n class=\"tw-mb-1.5\"\n :class=\"shouldShowTotal ? $style['total-sort'] : 'tw-text-right'\"\n >\n <div v-if=\"shouldShowTotal\" class=\"tw-text-xs\">{{ total }}</div>\n\n <!-- Sort -->\n <Dropdown\n v-if=\"Object.keys(sorts).length\"\n :class=\"$style.dropdown\"\n :label=\"`${sortLabel} ${sortTerm}`\"\n @toggle.once=\"onSortToggle\"\n >\n <ul ref=\"sortOptions\" class=\"dropdown__list\" :style=\"{ minWidth: sortOptionsWidth }\">\n <li\n v-for=\"(sortOption, index) in Object.keys(sorts)\"\n :key=\"index\"\n :class=\"{ 'tw-bg-blue-100 tw-text-ice-700': sortOption === sortTerm }\"\n class=\"dropdown__item tw-rounded\"\n >\n <Button inline class=\"tw-items-center\" :class=\"$style['sort-option']\" @click=\"onSort(sortOption)\">\n {{ sortOption }}\n <Icon v-if=\"sortOption === sortTerm\" name=\"check\" class=\"tw-ml-auto tw-text-blue-500\" />\n </Button>\n </li>\n </ul>\n </Dropdown>\n </div>\n\n <!-- Defined Slots -->\n <div v-if=\"useDefinedSlots\" :class=\"$style['list-items']\">\n <header\n v-sticky=\"headerOffset\"\n data-test=\"header|defined-slot\"\n :class=\"[\n $style.header,\n {\n 'tw-m-0': !isSelectable,\n },\n ]\"\n class=\"tw-rounded\"\n >\n <div :class=\"$style['header-grid-container']\" class=\"tw-border-b tw-border-ice-200 tw-px-3\">\n <Checkbox\n v-if=\"isSelectable\"\n class=\"tw-ml-3\"\n :checked=\"isSomePageChecked\"\n :class=\"$style['select-all']\"\n :indeterminate=\"isSomePageChecked && !isAllPageChecked\"\n @update:checked=\"onSelectPage\"\n />\n <div class=\"tw-ll-grid tw-flex-1\" :class=\"$style['header-grid']\">\n <slot name=\"list-header\"> </slot>\n </div>\n </div>\n\n <!-- Select Bar -->\n <BulkActions\n v-if=\"isSelectable\"\n v-bind=\"{\n allowSelectAll: !hideSelectAll && !isServerSide,\n isAllPageChecked,\n isSomePageChecked,\n totalCount,\n totalSelectedCount,\n hideBulkActionOptions,\n hideNumberOfTotalSelected,\n }\"\n :class=\"!isSelectBarVisible && 'lg:tw-hidden'\"\n @change:clear-selected=\"clearSelected\"\n @change:select-current=\"onSelectPage\"\n @change:select-all=\"selectAll\"\n >\n <template #bulk-actions-content>\n <slot name=\"bulk-actions\" :selected-items=\"selectedItems\"> </slot>\n </template>\n </BulkActions>\n </header>\n\n <component\n :is=\"disableLoader ? 'div' : 'LoadingManager'\"\n :empty-state-text=\"emptyStateText\"\n :loading=\"isLoading\"\n :results=\"paginated\"\n >\n <slot\n name=\"list-items\"\n :clear-all=\"clearSelected\"\n :display-items=\"results\"\n :is-filtered=\"isFiltered\"\n :is-item-disabled=\"isItemDisabled\"\n :results=\"paginated\"\n :on-select=\"onSelectItem\"\n :selected-items=\"selectedItems\"\n ></slot>\n </component>\n </div>\n\n <!-- Default Slot -->\n <slot\n :current-page=\"currentPage\"\n :display-items=\"results\"\n :filters=\"filters\"\n :is-filtered=\"isFiltered\"\n :is-item-disabled=\"isItemDisabled\"\n :results=\"paginated\"\n :search-term=\"searchTerm\"\n :total=\"totalCount\"\n ></slot>\n\n <!-- Pagination -->\n <Paginate\n v-if=\"totalCount > pageSize\"\n :current-page=\"currentPage\"\n :list-length=\"totalCount\"\n :page-size=\"pageSize\"\n @set-page=\"onPaginateSetPage\"\n />\n </div>\n</template>\n\n<style module>\n .list-items {\n background-color: var(--color-ice-200);\n border-bottom-left-radius: theme('borderRadius.DEFAULT');\n border-bottom-right-radius: theme('borderRadius.DEFAULT');\n min-width: 100%;\n position: relative;\n }\n\n @media screen('lg') {\n .list-items {\n @apply tw-shadow;\n }\n }\n\n /* the .legacy-box styles are copied from .box in _box.scss */\n .legacy-box {\n @apply tw-shadow;\n\n background: var(--color-white);\n border-radius: theme('borderRadius.DEFAULT');\n padding: theme('spacing.6') var(--grid-gutter);\n }\n\n .header {\n background-color: var(--color-white);\n color: var(--color-ice-900);\n font-weight: 500;\n margin-bottom: theme('spacing.3');\n overflow: hidden;\n z-index: 1;\n\n &:global(.is-sticky) {\n @apply tw-shadow;\n\n border-radius: 0;\n overflow: visible;\n z-index: calc(theme('zIndex.control') + 1);\n\n &::before,\n &::after {\n background-color: var(--color-white);\n content: '';\n height: 100%;\n overflow-x: hidden;\n position: absolute;\n right: 100%;\n top: 0;\n width: theme('spacing.3');\n\n @media screen('lg') {\n content: none;\n }\n }\n\n &::after {\n left: 100%;\n right: auto;\n }\n }\n\n :global(.input--checkbox) {\n label {\n min-height: theme('spacing.6');\n }\n }\n\n @media screen('lg') {\n border-bottom-left-radius: 0;\n border-bottom-right-radius: 0;\n margin-bottom: 0;\n }\n }\n\n .header-grid-container {\n display: none;\n transition: padding theme('transitionDuration.150') theme('transitionTimingFunction.swing');\n\n @media screen('lg') {\n align-items: center;\n display: flex;\n }\n }\n\n .header-grid {\n column-gap: 0 !important;\n grid-column-gap: 0 !important;\n\n > div {\n align-items: center;\n border-right: 1px solid var(--color-ice-200);\n display: flex;\n font-size: theme('fontSize.xs');\n justify-content: space-between;\n padding: theme('spacing.3');\n\n &:first-of-type {\n margin-left: calc(-1 * theme('spacing.3'));\n padding-left: theme('spacing.6');\n }\n\n &:last-of-type {\n border-right: 0;\n margin-right: calc(-1 * theme('spacing.3'));\n }\n }\n }\n\n .search-input {\n :global(input) {\n /* to prevent search text from overlapping the \"Clear\" button */\n padding-right: calc(theme('height.input') * 2) !important;\n }\n\n :global(.stash-input-append) {\n display: flex;\n justify-content: flex-end;\n width: 72px; /* double the the default width of 36px */\n\n .clear-button {\n color: var(--color-ice-700);\n height: 36px;\n margin: 0;\n min-width: 36px;\n padding: 0;\n width: 36px;\n\n &:disabled {\n color: var(--color-ice-500);\n cursor: default;\n }\n }\n\n .search-button {\n border-bottom-left-radius: 0;\n border-color: var(--color-blue-500);\n border-left: none;\n border-top-left-radius: 0;\n min-width: 36px;\n padding: 0 theme('spacing[1.5]');\n width: 36px;\n\n &:disabled {\n border-color: var(--color-ice-500);\n }\n }\n }\n }\n\n @media screen('md') {\n .total-sort {\n align-items: baseline;\n display: flex;\n justify-content: space-between;\n }\n }\n\n .filter-toggle-btn {\n min-width: fit-content !important; /* ensure this overrides the grid min-width applied */\n }\n\n .filter-toggle-btn-with-hint-text {\n /* search hint text has 16px of height and has 4px of margin top. Adding here directly to compensate that */\n margin-bottom: 20px;\n }\n\n @keyframes separator {\n 0% {\n opacity: 0;\n }\n\n 100% {\n opacity: 1;\n }\n }\n\n .filters-expand:global(.stash-expand--expanded) {\n .filters-wrapper::before {\n animation: separator theme('transitionDuration.300') theme('transitionTimingFunction.ease-in-out') 0.5s 1 forwards;\n background: var(--color-ice-200);\n content: '';\n height: theme('borderWidth.DEFAULT');\n left: calc(var(--grid-gutter) * -1);\n opacity: 0;\n position: absolute;\n right: calc(var(--grid-gutter) * -1);\n top: theme('spacing.6');\n }\n }\n\n .filters-half-width {\n @media screen('lg') {\n :global(.field-wrapper) {\n grid-column: span 6 / span 6; /* col-span-6 */\n }\n }\n }\n\n .dropdown :global(.tw-text-blue-500) {\n font-size: theme('fontSize.xs');\n }\n\n .sort-option {\n height: theme('spacing.9');\n }\n\n .select-all {\n width: theme('spacing.6');\n }\n</style>\n"],"names":["_sfc_main","Button","Checkbox","t","value","_createElementBlock","_ctx","$props","_createElementVNode","_createVNode","_component_ll_checkbox","_normalizeClass","$options","_openBlock","_hoisted_1","_hoisted_2","_toDisplayString","_createBlock","_component_ll_button","_hoisted_3","_renderSlot","EmptyState","Loading","_component_Loading","_TransitionGroup","_component_EmptyState","Expand","Icon","sticky","isExpanded","getCssVar","CSS_VARS","$data","args","_component_Icon","_component_Expand","_component_ll_icon","DEFAULT_SEARCH_SCHEMA","BulkActions","Filters","Paginate","LoadingManager","Badge","Dropdown","Input","_a","persistentStorage","paginated","endIndex","totalCount","results","startIndex","current","range","item","id","acc","filterBy","isBoolean","isToggle","isEmpty","isInputOptionsIncomplete","cloneDeep","searchFor","useSearch","computed","searchTerm","sortTerms","actionResponse","items","_filterItems","_sortItems","trigger","currentPage","filters","isFiltered","pageSize","sortTerm","params","_b","LLLV_CHANGE_TRIGGERS","term","pageNumber","forceChange","selectedItem","_component_Input","$event","_cache","_withKeys","_component_Button","_component_Badge","_createTextVNode","_component_Filters","_hoisted_4","_component_Dropdown","_Fragment","_renderList","sortOption","index","_component_Checkbox","_component_BulkActions","_mergeProps","_resolveDynamicComponent","_component_Paginate"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@leaflink/stash",
3
- "version": "44.0.0-beta.10",
3
+ "version": "44.0.0-beta.11",
4
4
  "description": "LeafLink's design system.",
5
5
  "homepage": "https://stash.leaflink.com",
6
6
  "main": "./dist/index.ts",
package/styles/base.css CHANGED
@@ -9,6 +9,32 @@
9
9
  @tailwind utilities;
10
10
  */
11
11
 
12
+ @layer components {
13
+ /**
14
+ * ll-grid is a legacy grid class that conflicts with tailwinds out of the box grid class.
15
+ * It's quite hard to replace it with a 1-1 swap, because there's so many default styles included in ll-grid, but it's
16
+ * also used in conjunction with other grid classes. For example:
17
+ * <div class="ll-grid ll-grid-cols-4 md:ll-grid-cols-8 lg:ll-grid-cols-12">
18
+ *
19
+ * In this example, ll-grid has default grid-cols styles, but the dev is overriding those defaults. If we were to
20
+ * replace ll-grid with tw-grid in a simple find/replace, we would HAVE to include
21
+ * `tw-grid-cols-1 tw-gap-x-gutter tw-gap-y-6 md:tw-grid-cols-12` as well, and then in examples like the one above,
22
+ * you'd have weird conflicts and specificity issues.
23
+ *
24
+ * Conclusion: So, for now,
25
+ * - `.ll-grid` & `.grid` will continue to exist in backwards-compat.css as is.
26
+ * - `.tw-grid` will behave as expected and is a simple utility with no baked in defaults.
27
+ * - We're creating a custom .tw-ll-grid class that will have the same styles but won't cause weird issues downstream.
28
+ * In the future we can remove this class OR keep it around if we decide we want to keep a grid utility with
29
+ * some baked in defaults.
30
+ */
31
+ .tw-ll-grid {
32
+ @apply tw-grid tw-grid-cols-1 tw-gap-x-gutter tw-gap-y-6 md:tw-grid-cols-12;
33
+
34
+ --deprecated: "WARNING: Use `tw-grid` instead";
35
+ }
36
+ }
37
+
12
38
  /**
13
39
  * This is a custom .container class that conflicts with tailwinds out of the box container class.
14
40
  * Placed here before tw utilities, and specifically not within @layer components, so that it is
@@ -22,20 +48,6 @@
22
48
  width: 100%;
23
49
  }
24
50
 
25
- /**
26
- * This is a legacy grid class that conflicts with tailwinds out of the box grid class.
27
- * Placed here before tw utilities, and specifically not within @layer components, so that it is
28
- * always included in the output css.
29
- *
30
- * @deprecated - Todo: Migrate to tailwind grid classes. Too tricky to do in one find/replace cause you may have
31
- * conflicts with other grid classes meant to override ll-grid.
32
- */
33
- .ll-grid {
34
- @apply tw-grid tw-grid-cols-1 tw-gap-x-gutter tw-gap-y-6 md:tw-grid-cols-12;
35
-
36
- --deprecated: "WARNING: Use `tw-grid` instead";
37
- }
38
-
39
51
  /**
40
52
  * Variables
41
53
  */