@vendure/admin-ui 2.0.4 → 2.0.6

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.
Files changed (83) hide show
  1. package/core/common/component-registry-types.d.ts +1 -1
  2. package/core/common/version.d.ts +1 -1
  3. package/core/components/app-shell/app-shell.component.d.ts +1 -0
  4. package/core/providers/dashboard-widget/dashboard-widget.service.d.ts +4 -1
  5. package/core/providers/i18n/i18n.service.d.ts +4 -0
  6. package/dashboard/components/dashboard/dashboard.component.d.ts +4 -1
  7. package/esm2022/catalog/components/collection-data-table/collection-data-table.component.mjs +3 -3
  8. package/esm2022/catalog/components/collection-detail/collection-detail.component.mjs +2 -2
  9. package/esm2022/catalog/components/product-detail/product-detail.component.mjs +4 -4
  10. package/esm2022/catalog/components/product-variant-detail/product-variant-detail.component.mjs +2 -2
  11. package/esm2022/catalog/components/product-variant-list/product-variant-list.component.mjs +7 -1
  12. package/esm2022/catalog/components/product-variants-editor/product-variants-editor.component.mjs +7 -5
  13. package/esm2022/catalog/components/stock-location-detail/stock-location-detail.component.mjs +30 -30
  14. package/esm2022/core/app.config.mjs +3 -7
  15. package/esm2022/core/common/base-list.component.mjs +1 -1
  16. package/esm2022/core/common/component-registry-types.mjs +1 -1
  17. package/esm2022/core/common/generated-types.mjs +1 -1
  18. package/esm2022/core/common/version.mjs +2 -2
  19. package/esm2022/core/components/app-shell/app-shell.component.mjs +11 -9
  20. package/esm2022/core/components/theme-switcher/theme-switcher.component.mjs +1 -1
  21. package/esm2022/core/components/user-menu/user-menu.component.mjs +3 -3
  22. package/esm2022/core/data/data.module.mjs +3 -3
  23. package/esm2022/core/data/utils/transform-relation-custom-field-inputs.mjs +1 -1
  24. package/esm2022/core/providers/bulk-action-registry/bulk-action-types.mjs +1 -1
  25. package/esm2022/core/providers/dashboard-widget/dashboard-widget-types.mjs +1 -1
  26. package/esm2022/core/providers/dashboard-widget/dashboard-widget.service.mjs +5 -5
  27. package/esm2022/core/providers/data-table/data-table-filter-collection.mjs +1 -1
  28. package/esm2022/core/providers/i18n/i18n.service.mjs +15 -1
  29. package/esm2022/core/providers/page/page.service.mjs +1 -1
  30. package/esm2022/core/shared/components/affixed-input/affixed-input.component.mjs +2 -2
  31. package/esm2022/core/shared/components/data-table-2/data-table2.component.mjs +3 -3
  32. package/esm2022/core/shared/components/data-table-filters/data-table-filters.component.mjs +1 -1
  33. package/esm2022/core/shared/components/dropdown/dropdown-menu.component.mjs +29 -29
  34. package/esm2022/core/shared/components/dropdown/dropdown.component.mjs +1 -1
  35. package/esm2022/core/shared/components/rich-text-editor/link-dialog/link-dialog.component.mjs +1 -1
  36. package/esm2022/core/shared/components/rich-text-editor/prosemirror/custom-nodes.mjs +1 -1
  37. package/esm2022/core/shared/components/rich-text-editor/prosemirror/prosemirror.service.mjs +1 -1
  38. package/esm2022/core/shared/components/tabbed-custom-fields/tabbed-custom-fields.component.mjs +1 -1
  39. package/esm2022/core/shared/dynamic-form-inputs/customer-group-form-input/customer-group-form-input.component.mjs +1 -1
  40. package/esm2022/core/shared/dynamic-form-inputs/dynamic-form-input/dynamic-form-input.component.mjs +3 -3
  41. package/esm2022/core/shared/dynamic-form-inputs/product-multi-selector-form-input/product-multi-selector-form-input.component.mjs +1 -1
  42. package/esm2022/core/shared/dynamic-form-inputs/product-selector-form-input/product-selector-form-input.component.mjs +1 -1
  43. package/esm2022/core/shared/dynamic-form-inputs/register-dynamic-input-components.mjs +1 -1
  44. package/esm2022/core/shared/dynamic-form-inputs/relation-form-input/asset/relation-asset-input.component.mjs +14 -14
  45. package/esm2022/core/shared/dynamic-form-inputs/relation-form-input/customer/relation-customer-input.component.mjs +1 -1
  46. package/esm2022/core/shared/dynamic-form-inputs/relation-form-input/product-variant/relation-product-variant-input.component.mjs +3 -3
  47. package/esm2022/core/shared/shared.module.mjs +1 -1
  48. package/esm2022/customer/components/customer-detail/customer-detail.component.mjs +27 -27
  49. package/esm2022/dashboard/components/dashboard/dashboard.component.mjs +4 -4
  50. package/esm2022/order/components/draft-order-detail/draft-order-detail.component.mjs +3 -3
  51. package/esm2022/order/components/fulfill-order-dialog/fulfill-order-dialog.component.mjs +5 -3
  52. package/esm2022/order/components/order-data-table/order-data-table.component.mjs +3 -3
  53. package/esm2022/order/components/order-detail/order-detail.component.mjs +13 -11
  54. package/esm2022/settings/components/tax-rate-detail/tax-rate-detail.component.mjs +9 -9
  55. package/fesm2022/vendure-admin-ui-catalog.mjs +48 -41
  56. package/fesm2022/vendure-admin-ui-catalog.mjs.map +1 -1
  57. package/fesm2022/vendure-admin-ui-core.mjs +79 -69
  58. package/fesm2022/vendure-admin-ui-core.mjs.map +1 -1
  59. package/fesm2022/vendure-admin-ui-customer.mjs +26 -26
  60. package/fesm2022/vendure-admin-ui-customer.mjs.map +1 -1
  61. package/fesm2022/vendure-admin-ui-dashboard.mjs +3 -3
  62. package/fesm2022/vendure-admin-ui-dashboard.mjs.map +1 -1
  63. package/fesm2022/vendure-admin-ui-order.mjs +20 -16
  64. package/fesm2022/vendure-admin-ui-order.mjs.map +1 -1
  65. package/fesm2022/vendure-admin-ui-settings.mjs +8 -8
  66. package/fesm2022/vendure-admin-ui-settings.mjs.map +1 -1
  67. package/package.json +14 -14
  68. package/static/i18n-messages/ar.json +774 -0
  69. package/static/i18n-messages/cs.json +773 -773
  70. package/static/i18n-messages/de.json +773 -773
  71. package/static/i18n-messages/en.json +774 -774
  72. package/static/i18n-messages/es.json +773 -773
  73. package/static/i18n-messages/fr.json +773 -773
  74. package/static/i18n-messages/he.json +774 -0
  75. package/static/i18n-messages/it.json +773 -773
  76. package/static/i18n-messages/pl.json +773 -773
  77. package/static/i18n-messages/pt_BR.json +773 -773
  78. package/static/i18n-messages/pt_PT.json +773 -773
  79. package/static/i18n-messages/ru.json +773 -773
  80. package/static/i18n-messages/uk.json +773 -773
  81. package/static/i18n-messages/zh_Hans.json +773 -773
  82. package/static/i18n-messages/zh_Hant.json +773 -773
  83. package/static/vendure-ui-config.json +3 -0
@@ -235,4 +235,4 @@ export class DataTableFilterCollection {
235
235
  return new FilterWithValue(filter, value, v => this.#valueChanges$.next(v));
236
236
  }
237
237
  }
238
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table-filter-collection.js","sourceRoot":"","sources":["../../../../../src/lib/core/src/providers/data-table/data-table-filter-collection.ts"],"names":[],"mappings":"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","sourcesContent":["import { ActivatedRoute, Router } from '@angular/router';\nimport { marker as _ } from '@biesbjerg/ngx-translate-extract-marker';\nimport { CustomFieldType } from '@vendure/common/lib/shared-types';\nimport { assertNever } from '@vendure/common/lib/shared-utils';\nimport { Subject } from 'rxjs';\nimport extend from 'just-extend';\nimport {\n    CustomFieldConfig,\n    DateOperators,\n    NumberOperators,\n    StringOperators,\n} from '../../common/generated-types';\nimport {\n    DataTableFilter,\n    DataTableFilterBooleanType,\n    DataTableFilterCustomType,\n    DataTableFilterDateRangeType,\n    DataTableFilterNumberType,\n    DataTableFilterOptions,\n    DataTableFilterSelectType,\n    DataTableFilterTextType,\n    DataTableFilterType,\n    DataTableFilterValue,\n} from './data-table-filter';\n\nexport class FilterWithValue<Type extends DataTableFilterType = DataTableFilterType> {\n    private onUpdateFns = new Set<(value: DataTableFilterValue<Type>) => void>();\n    constructor(\n        public readonly filter: DataTableFilter<any, Type>,\n        public value: DataTableFilterValue<Type>,\n        onUpdate?: (value: DataTableFilterValue<Type>) => void,\n    ) {\n        if (onUpdate) {\n            this.onUpdateFns.add(onUpdate);\n        }\n    }\n\n    onUpdate(fn: (value: DataTableFilterValue<Type>) => void) {\n        this.onUpdateFns.add(fn);\n    }\n\n    updateValue(value: DataTableFilterValue<Type>) {\n        this.value = value;\n        for (const fn of this.onUpdateFns) {\n            fn(value);\n        }\n    }\n\n    isText(): this is FilterWithValue<DataTableFilterTextType> {\n        return this.filter.type.kind === 'text';\n    }\n\n    isNumber(): this is FilterWithValue<DataTableFilterNumberType> {\n        return this.filter.type.kind === 'number';\n    }\n\n    isBoolean(): this is FilterWithValue<DataTableFilterBooleanType> {\n        return this.filter.type.kind === 'boolean';\n    }\n\n    isSelect(): this is FilterWithValue<DataTableFilterSelectType> {\n        return this.filter.type.kind === 'select';\n    }\n\n    isDateRange(): this is FilterWithValue<DataTableFilterDateRangeType> {\n        return this.filter.type.kind === 'dateRange';\n    }\n\n    isCustom(): this is FilterWithValue<DataTableFilterCustomType> {\n        return this.filter.type.kind === 'custom';\n    }\n}\n\nexport class DataTableFilterCollection<FilterInput extends Record<string, any> = Record<string, any>> {\n    readonly #filters: Array<DataTableFilter<FilterInput, any>> = [];\n    #activeFilters: FilterWithValue[] = [];\n    #valueChanges$ = new Subject<FilterWithValue[]>();\n    #connectedToRouter = false;\n    valueChanges = this.#valueChanges$.asObservable();\n    readonly #filtersQueryParamName = 'filters';\n\n    constructor(private router: Router) {}\n\n    get length(): number {\n        return this.#filters.length;\n    }\n\n    get activeFilters(): FilterWithValue[] {\n        return this.#activeFilters;\n    }\n\n    addFilter<FilterType extends DataTableFilterType>(\n        config: DataTableFilterOptions<FilterInput, FilterType>,\n    ): DataTableFilterCollection<FilterInput> {\n        if (this.#connectedToRouter) {\n            throw new Error(\n                'Cannot add filter after connecting to router. Make sure to call addFilter() before connectToRoute()',\n            );\n        }\n        this.#filters.push(\n            new DataTableFilter(config, (filter, value) => this.onActivateFilter(filter, value)),\n        );\n        return this;\n    }\n\n    addFilters<FilterType extends DataTableFilterType>(\n        configs: Array<DataTableFilterOptions<FilterInput, FilterType>>,\n    ): DataTableFilterCollection<FilterInput> {\n        for (const config of configs) {\n            this.addFilter(config);\n        }\n        return this;\n    }\n\n    addDateFilters(): FilterInput extends {\n        createdAt?: DateOperators | null;\n        updatedAt?: DateOperators | null;\n    }\n        ? DataTableFilterCollection<FilterInput>\n        : never {\n        this.addFilter({\n            name: 'createdAt',\n            type: { kind: 'dateRange' },\n            label: _('common.created-at'),\n            filterField: 'createdAt',\n        });\n        this.addFilter({\n            name: 'updatedAt',\n            type: { kind: 'dateRange' },\n            label: _('common.updated-at'),\n            filterField: 'updatedAt',\n        });\n        return this as any;\n    }\n\n    addCustomFieldFilters(customFields: CustomFieldConfig[]) {\n        for (const config of customFields) {\n            const type = config.type as CustomFieldType;\n            if (config.list) {\n                continue;\n            }\n            let filterType: DataTableFilterType | undefined;\n            switch (type) {\n                case 'boolean':\n                    filterType = { kind: 'boolean' };\n                    break;\n                case 'int':\n                case 'float':\n                    filterType = { kind: 'number' };\n                    break;\n                case 'datetime':\n                    filterType = { kind: 'dateRange' };\n                    break;\n                case 'string':\n                case 'localeString':\n                case 'localeText':\n                case 'text':\n                    filterType = { kind: 'text' };\n                    break;\n                case 'relation':\n                    // Cannot sort relations\n                    break;\n                default:\n                    assertNever(type);\n            }\n            if (filterType) {\n                this.addFilter({\n                    name: config.name,\n                    type: filterType,\n                    label: config.label ?? config.name,\n                    filterField: config.name,\n                });\n            }\n        }\n        return this;\n    }\n\n    getFilter(name: string): DataTableFilter<FilterInput> | undefined {\n        return this.#filters.find(f => f.name === name);\n    }\n\n    getFilters(): Array<DataTableFilter<FilterInput>> {\n        return this.#filters;\n    }\n\n    removeActiveFilterAtIndex(index: number) {\n        this.#activeFilters.splice(index, 1);\n        this.#valueChanges$.next(this.#activeFilters);\n    }\n\n    createFilterInput(): FilterInput {\n        return this.#activeFilters.reduce((acc, { filter, value }) => {\n            const newValue = value != null ? filter.toFilterInput(value) : {};\n            const result = extend(true, acc, newValue);\n            return result as FilterInput;\n        }, {} as FilterInput);\n    }\n\n    connectToRoute(route: ActivatedRoute) {\n        this.valueChanges.subscribe(value => {\n            this.router.navigate(['./'], {\n                queryParams: { [this.#filtersQueryParamName]: this.serialize(), page: 1 },\n                relativeTo: route,\n                queryParamsHandling: 'merge',\n            });\n        });\n        const filterQueryParams = (route.snapshot.queryParamMap.get(this.#filtersQueryParamName) ?? '')\n            .split(';')\n            .map(value => value.split(':'))\n            .map(([name, value]) => ({ name, value }));\n        for (const { name, value } of filterQueryParams) {\n            const filter = this.getFilter(name);\n            if (filter) {\n                const val = this.deserializeValue(filter, value);\n                this.#activeFilters.push(this.createFacetWithValue(filter, val));\n            }\n        }\n        this.#connectedToRouter = true;\n        return this;\n    }\n\n    serializeValue<Type extends DataTableFilterType>(\n        filterWithValue: FilterWithValue<Type>,\n    ): string | undefined {\n        const valueAsType = <T extends DataTableFilter<any, any>>(\n            _filter: T,\n            _value: DataTableFilterValue<any>,\n        ): T extends DataTableFilter<any, infer R> ? DataTableFilterValue<R> : any => _value;\n\n        if (filterWithValue.isText()) {\n            const val = filterWithValue.value;\n            return `${val?.operator},${val?.term}`;\n        } else if (filterWithValue.isNumber()) {\n            const val = filterWithValue.value;\n            return `${val.operator},${val.amount}`;\n        } else if (filterWithValue.isSelect()) {\n            const val = filterWithValue.value;\n            return val.join(',');\n        } else if (filterWithValue.isBoolean()) {\n            const val = filterWithValue.value;\n            return val ? '1' : '0';\n        } else if (filterWithValue.isDateRange()) {\n            const val = filterWithValue.value;\n            const start = val.start ? new Date(val.start).getTime() : '';\n            const end = val.end ? new Date(val.end).getTime() : '';\n            return `${start},${end}`;\n        } else if (filterWithValue.isCustom()) {\n            return filterWithValue.filter.type.serializeValue(filterWithValue.value);\n        }\n    }\n\n    deserializeValue(filter: DataTableFilter, value: string): DataTableFilterValue<DataTableFilterType> {\n        switch (filter.type.kind) {\n            case 'text': {\n                const [operator, term] = value.split(',') as [keyof StringOperators, string];\n                return { operator, term };\n            }\n            case 'number': {\n                const [operator, amount] = value.split(',') as [keyof NumberOperators, string];\n                return { operator, amount: +amount };\n            }\n            case 'select':\n                return value.split(',');\n            case 'boolean':\n                return value === '1';\n            case 'dateRange':\n                const [startTimestamp, endTimestamp] = value.split(',');\n                const start = startTimestamp ? new Date(Number(startTimestamp)).toISOString() : '';\n                const end = endTimestamp ? new Date(Number(endTimestamp)).toISOString() : '';\n                return { start, end };\n            case 'custom':\n                return filter.type.deserializeValue(value);\n            default:\n                assertNever(filter.type);\n        }\n    }\n\n    private serialize(): string {\n        return this.#activeFilters\n            .map(\n                (filterWithValue, i) =>\n                    `${filterWithValue.filter.name}:${this.serializeValue(filterWithValue)}`,\n            )\n            .join(';');\n    }\n\n    private onActivateFilter(filter: DataTableFilter<any, any>, value: DataTableFilterValue<any>) {\n        this.#activeFilters.push(this.createFacetWithValue(filter, value));\n        this.#valueChanges$.next(this.#activeFilters);\n    }\n\n    private createFacetWithValue(\n        filter: DataTableFilter<any, any>,\n        value: DataTableFilterValue<DataTableFilterType>,\n    ) {\n        return new FilterWithValue(filter, value, v => this.#valueChanges$.next(v));\n    }\n}\n"]}
238
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table-filter-collection.js","sourceRoot":"","sources":["../../../../../src/lib/core/src/providers/data-table/data-table-filter-collection.ts"],"names":[],"mappings":"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","sourcesContent":["import { ActivatedRoute, Router } from '@angular/router';\r\nimport { marker as _ } from '@biesbjerg/ngx-translate-extract-marker';\r\nimport { CustomFieldType } from '@vendure/common/lib/shared-types';\r\nimport { assertNever } from '@vendure/common/lib/shared-utils';\r\nimport { Subject } from 'rxjs';\r\nimport extend from 'just-extend';\r\nimport {\r\n    CustomFieldConfig,\r\n    DateOperators,\r\n    NumberOperators,\r\n    StringOperators,\r\n} from '../../common/generated-types';\r\nimport {\r\n    DataTableFilter,\r\n    DataTableFilterBooleanType,\r\n    DataTableFilterCustomType,\r\n    DataTableFilterDateRangeType,\r\n    DataTableFilterNumberType,\r\n    DataTableFilterOptions,\r\n    DataTableFilterSelectType,\r\n    DataTableFilterTextType,\r\n    DataTableFilterType,\r\n    DataTableFilterValue,\r\n} from './data-table-filter';\r\n\r\nexport class FilterWithValue<Type extends DataTableFilterType = DataTableFilterType> {\r\n    private onUpdateFns = new Set<(value: DataTableFilterValue<Type>) => void>();\r\n    constructor(\r\n        public readonly filter: DataTableFilter<any, Type>,\r\n        public value: DataTableFilterValue<Type>,\r\n        onUpdate?: (value: DataTableFilterValue<Type>) => void,\r\n    ) {\r\n        if (onUpdate) {\r\n            this.onUpdateFns.add(onUpdate);\r\n        }\r\n    }\r\n\r\n    onUpdate(fn: (value: DataTableFilterValue<Type>) => void) {\r\n        this.onUpdateFns.add(fn);\r\n    }\r\n\r\n    updateValue(value: DataTableFilterValue<Type>) {\r\n        this.value = value;\r\n        for (const fn of this.onUpdateFns) {\r\n            fn(value);\r\n        }\r\n    }\r\n\r\n    isText(): this is FilterWithValue<DataTableFilterTextType> {\r\n        return this.filter.type.kind === 'text';\r\n    }\r\n\r\n    isNumber(): this is FilterWithValue<DataTableFilterNumberType> {\r\n        return this.filter.type.kind === 'number';\r\n    }\r\n\r\n    isBoolean(): this is FilterWithValue<DataTableFilterBooleanType> {\r\n        return this.filter.type.kind === 'boolean';\r\n    }\r\n\r\n    isSelect(): this is FilterWithValue<DataTableFilterSelectType> {\r\n        return this.filter.type.kind === 'select';\r\n    }\r\n\r\n    isDateRange(): this is FilterWithValue<DataTableFilterDateRangeType> {\r\n        return this.filter.type.kind === 'dateRange';\r\n    }\r\n\r\n    isCustom(): this is FilterWithValue<DataTableFilterCustomType> {\r\n        return this.filter.type.kind === 'custom';\r\n    }\r\n}\r\n\r\nexport class DataTableFilterCollection<FilterInput extends Record<string, any> = Record<string, any>> {\r\n    readonly #filters: Array<DataTableFilter<FilterInput, any>> = [];\r\n    #activeFilters: FilterWithValue[] = [];\r\n    #valueChanges$ = new Subject<FilterWithValue[]>();\r\n    #connectedToRouter = false;\r\n    valueChanges = this.#valueChanges$.asObservable();\r\n    readonly #filtersQueryParamName = 'filters';\r\n\r\n    constructor(private router: Router) {}\r\n\r\n    get length(): number {\r\n        return this.#filters.length;\r\n    }\r\n\r\n    get activeFilters(): FilterWithValue[] {\r\n        return this.#activeFilters;\r\n    }\r\n\r\n    addFilter<FilterType extends DataTableFilterType>(\r\n        config: DataTableFilterOptions<FilterInput, FilterType>,\r\n    ): DataTableFilterCollection<FilterInput> {\r\n        if (this.#connectedToRouter) {\r\n            throw new Error(\r\n                'Cannot add filter after connecting to router. Make sure to call addFilter() before connectToRoute()',\r\n            );\r\n        }\r\n        this.#filters.push(\r\n            new DataTableFilter(config, (filter, value) => this.onActivateFilter(filter, value)),\r\n        );\r\n        return this;\r\n    }\r\n\r\n    addFilters<FilterType extends DataTableFilterType>(\r\n        configs: Array<DataTableFilterOptions<FilterInput, FilterType>>,\r\n    ): DataTableFilterCollection<FilterInput> {\r\n        for (const config of configs) {\r\n            this.addFilter(config);\r\n        }\r\n        return this;\r\n    }\r\n\r\n    addDateFilters(): FilterInput extends {\r\n        createdAt?: DateOperators | null;\r\n        updatedAt?: DateOperators | null;\r\n    }\r\n        ? DataTableFilterCollection<FilterInput>\r\n        : never {\r\n        this.addFilter({\r\n            name: 'createdAt',\r\n            type: { kind: 'dateRange' },\r\n            label: _('common.created-at'),\r\n            filterField: 'createdAt',\r\n        });\r\n        this.addFilter({\r\n            name: 'updatedAt',\r\n            type: { kind: 'dateRange' },\r\n            label: _('common.updated-at'),\r\n            filterField: 'updatedAt',\r\n        });\r\n        return this as any;\r\n    }\r\n\r\n    addCustomFieldFilters(customFields: CustomFieldConfig[]) {\r\n        for (const config of customFields) {\r\n            const type = config.type as CustomFieldType;\r\n            if (config.list) {\r\n                continue;\r\n            }\r\n            let filterType: DataTableFilterType | undefined;\r\n            switch (type) {\r\n                case 'boolean':\r\n                    filterType = { kind: 'boolean' };\r\n                    break;\r\n                case 'int':\r\n                case 'float':\r\n                    filterType = { kind: 'number' };\r\n                    break;\r\n                case 'datetime':\r\n                    filterType = { kind: 'dateRange' };\r\n                    break;\r\n                case 'string':\r\n                case 'localeString':\r\n                case 'localeText':\r\n                case 'text':\r\n                    filterType = { kind: 'text' };\r\n                    break;\r\n                case 'relation':\r\n                    // Cannot sort relations\r\n                    break;\r\n                default:\r\n                    assertNever(type);\r\n            }\r\n            if (filterType) {\r\n                this.addFilter({\r\n                    name: config.name,\r\n                    type: filterType,\r\n                    label: config.label ?? config.name,\r\n                    filterField: config.name,\r\n                });\r\n            }\r\n        }\r\n        return this;\r\n    }\r\n\r\n    getFilter(name: string): DataTableFilter<FilterInput> | undefined {\r\n        return this.#filters.find(f => f.name === name);\r\n    }\r\n\r\n    getFilters(): Array<DataTableFilter<FilterInput>> {\r\n        return this.#filters;\r\n    }\r\n\r\n    removeActiveFilterAtIndex(index: number) {\r\n        this.#activeFilters.splice(index, 1);\r\n        this.#valueChanges$.next(this.#activeFilters);\r\n    }\r\n\r\n    createFilterInput(): FilterInput {\r\n        return this.#activeFilters.reduce((acc, { filter, value }) => {\r\n            const newValue = value != null ? filter.toFilterInput(value) : {};\r\n            const result = extend(true, acc, newValue);\r\n            return result as FilterInput;\r\n        }, {} as FilterInput);\r\n    }\r\n\r\n    connectToRoute(route: ActivatedRoute) {\r\n        this.valueChanges.subscribe(value => {\r\n            this.router.navigate(['./'], {\r\n                queryParams: { [this.#filtersQueryParamName]: this.serialize(), page: 1 },\r\n                relativeTo: route,\r\n                queryParamsHandling: 'merge',\r\n            });\r\n        });\r\n        const filterQueryParams = (route.snapshot.queryParamMap.get(this.#filtersQueryParamName) ?? '')\r\n            .split(';')\r\n            .map(value => value.split(':'))\r\n            .map(([name, value]) => ({ name, value }));\r\n        for (const { name, value } of filterQueryParams) {\r\n            const filter = this.getFilter(name);\r\n            if (filter) {\r\n                const val = this.deserializeValue(filter, value);\r\n                this.#activeFilters.push(this.createFacetWithValue(filter, val));\r\n            }\r\n        }\r\n        this.#connectedToRouter = true;\r\n        return this;\r\n    }\r\n\r\n    serializeValue<Type extends DataTableFilterType>(\r\n        filterWithValue: FilterWithValue<Type>,\r\n    ): string | undefined {\r\n        const valueAsType = <T extends DataTableFilter<any, any>>(\r\n            _filter: T,\r\n            _value: DataTableFilterValue<any>,\r\n        ): T extends DataTableFilter<any, infer R> ? DataTableFilterValue<R> : any => _value;\r\n\r\n        if (filterWithValue.isText()) {\r\n            const val = filterWithValue.value;\r\n            return `${val?.operator},${val?.term}`;\r\n        } else if (filterWithValue.isNumber()) {\r\n            const val = filterWithValue.value;\r\n            return `${val.operator},${val.amount}`;\r\n        } else if (filterWithValue.isSelect()) {\r\n            const val = filterWithValue.value;\r\n            return val.join(',');\r\n        } else if (filterWithValue.isBoolean()) {\r\n            const val = filterWithValue.value;\r\n            return val ? '1' : '0';\r\n        } else if (filterWithValue.isDateRange()) {\r\n            const val = filterWithValue.value;\r\n            const start = val.start ? new Date(val.start).getTime() : '';\r\n            const end = val.end ? new Date(val.end).getTime() : '';\r\n            return `${start},${end}`;\r\n        } else if (filterWithValue.isCustom()) {\r\n            return filterWithValue.filter.type.serializeValue(filterWithValue.value);\r\n        }\r\n    }\r\n\r\n    deserializeValue(filter: DataTableFilter, value: string): DataTableFilterValue<DataTableFilterType> {\r\n        switch (filter.type.kind) {\r\n            case 'text': {\r\n                const [operator, term] = value.split(',') as [keyof StringOperators, string];\r\n                return { operator, term };\r\n            }\r\n            case 'number': {\r\n                const [operator, amount] = value.split(',') as [keyof NumberOperators, string];\r\n                return { operator, amount: +amount };\r\n            }\r\n            case 'select':\r\n                return value.split(',');\r\n            case 'boolean':\r\n                return value === '1';\r\n            case 'dateRange':\r\n                const [startTimestamp, endTimestamp] = value.split(',');\r\n                const start = startTimestamp ? new Date(Number(startTimestamp)).toISOString() : '';\r\n                const end = endTimestamp ? new Date(Number(endTimestamp)).toISOString() : '';\r\n                return { start, end };\r\n            case 'custom':\r\n                return filter.type.deserializeValue(value);\r\n            default:\r\n                assertNever(filter.type);\r\n        }\r\n    }\r\n\r\n    private serialize(): string {\r\n        return this.#activeFilters\r\n            .map(\r\n                (filterWithValue, i) =>\r\n                    `${filterWithValue.filter.name}:${this.serializeValue(filterWithValue)}`,\r\n            )\r\n            .join(';');\r\n    }\r\n\r\n    private onActivateFilter(filter: DataTableFilter<any, any>, value: DataTableFilterValue<any>) {\r\n        this.#activeFilters.push(this.createFacetWithValue(filter, value));\r\n        this.#valueChanges$.next(this.#activeFilters);\r\n    }\r\n\r\n    private createFacetWithValue(\r\n        filter: DataTableFilter<any, any>,\r\n        value: DataTableFilterValue<DataTableFilterType>,\r\n    ) {\r\n        return new FilterWithValue(filter, value, v => this.#valueChanges$.next(v));\r\n    }\r\n}\r\n"]}
@@ -1,5 +1,6 @@
1
1
  import { DOCUMENT } from '@angular/common';
2
2
  import { Inject, Injectable } from '@angular/core';
3
+ import { LanguageCode } from '../../common/generated-types';
3
4
  import * as i0 from "@angular/core";
4
5
  import * as i1 from "@ngx-translate/core";
5
6
  /** @dynamic */
@@ -39,6 +40,19 @@ export class I18nService {
39
40
  translate(key, params) {
40
41
  return this.ngxTranslate.instant(key, params);
41
42
  }
43
+ /**
44
+ * Returns true if the given language code is a right-to-left language.
45
+ */
46
+ isRTL(languageCode) {
47
+ const rtlLanguageCodes = [
48
+ LanguageCode.ar,
49
+ LanguageCode.he,
50
+ LanguageCode.fa,
51
+ LanguageCode.ur,
52
+ LanguageCode.ps,
53
+ ];
54
+ return rtlLanguageCodes.includes(languageCode);
55
+ }
42
56
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.3", ngImport: i0, type: I18nService, deps: [{ token: i1.TranslateService }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Injectable }); }
43
57
  static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.0.3", ngImport: i0, type: I18nService, providedIn: 'root' }); }
44
58
  }
@@ -51,4 +65,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.3", ngImpor
51
65
  type: Inject,
52
66
  args: [DOCUMENT]
53
67
  }] }]; } });
54
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaTE4bi5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2xpYi9jb3JlL3NyYy9wcm92aWRlcnMvaTE4bi9pMThuLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQzNDLE9BQU8sRUFBRSxNQUFNLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7QUFLbkQsZUFBZTtBQUlmLE1BQU0sT0FBTyxXQUFXO0lBR3BCLElBQUksa0JBQWtCO1FBQ2xCLE9BQU8sQ0FBQyxHQUFHLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDO0lBQ3pDLENBQUM7SUFFRCxZQUFvQixZQUE4QixFQUE0QixRQUFrQjtRQUE1RSxpQkFBWSxHQUFaLFlBQVksQ0FBa0I7UUFBNEIsYUFBUSxHQUFSLFFBQVEsQ0FBVTtRQU5oRyx3QkFBbUIsR0FBbUIsRUFBRSxDQUFDO0lBTTBELENBQUM7SUFFcEc7O09BRUc7SUFDSCxrQkFBa0IsQ0FBQyxZQUEwQjtRQUN6QyxJQUFJLENBQUMsWUFBWSxDQUFDLGNBQWMsQ0FBQyxZQUFZLENBQUMsQ0FBQztJQUNuRCxDQUFDO0lBRUQ7O09BRUc7SUFDSCxXQUFXLENBQUMsUUFBc0I7UUFDOUIsSUFBSSxDQUFDLFlBQVksQ0FBQyxHQUFHLENBQUMsUUFBUSxDQUFDLENBQUM7UUFDaEMsSUFBSSxJQUFJLENBQUMsUUFBUSxFQUFFLGVBQWUsRUFBRTtZQUNoQyxJQUFJLENBQUMsUUFBUSxDQUFDLGVBQWUsQ0FBQyxJQUFJLEdBQUcsUUFBUSxDQUFDO1NBQ2pEO0lBQ0wsQ0FBQztJQUVEOztPQUVHO0lBQ0gscUJBQXFCLENBQUMsU0FBeUI7UUFDM0MsSUFBSSxDQUFDLG1CQUFtQixHQUFHLFNBQVMsQ0FBQztJQUN6QyxDQUFDO0lBRUQ7O09BRUc7SUFDSCxTQUFTLENBQUMsR0FBc0IsRUFBRSxNQUFZO1FBQzFDLE9BQU8sSUFBSSxDQUFDLFlBQVksQ0FBQyxPQUFPLENBQUMsR0FBRyxFQUFFLE1BQU0sQ0FBQyxDQUFDO0lBQ2xELENBQUM7OEdBdENRLFdBQVcsa0RBT3dDLFFBQVE7a0hBUDNELFdBQVcsY0FGUixNQUFNOzsyRkFFVCxXQUFXO2tCQUh2QixVQUFVO21CQUFDO29CQUNSLFVBQVUsRUFBRSxNQUFNO2lCQUNyQjs7MEJBUXdELE1BQU07MkJBQUMsUUFBUSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERPQ1VNRU5UIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgSW5qZWN0LCBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFRyYW5zbGF0ZVNlcnZpY2UgfSBmcm9tICdAbmd4LXRyYW5zbGF0ZS9jb3JlJztcclxuXHJcbmltcG9ydCB7IExhbmd1YWdlQ29kZSB9IGZyb20gJy4uLy4uL2NvbW1vbi9nZW5lcmF0ZWQtdHlwZXMnO1xyXG5cclxuLyoqIEBkeW5hbWljICovXHJcbkBJbmplY3RhYmxlKHtcclxuICAgIHByb3ZpZGVkSW46ICdyb290JyxcclxufSlcclxuZXhwb3J0IGNsYXNzIEkxOG5TZXJ2aWNlIHtcclxuICAgIF9hdmFpbGFibGVMYW5ndWFnZXM6IExhbmd1YWdlQ29kZVtdID0gW107XHJcblxyXG4gICAgZ2V0IGF2YWlsYWJsZUxhbmd1YWdlcygpOiBMYW5ndWFnZUNvZGVbXSB7XHJcbiAgICAgICAgcmV0dXJuIFsuLi50aGlzLl9hdmFpbGFibGVMYW5ndWFnZXNdO1xyXG4gICAgfVxyXG5cclxuICAgIGNvbnN0cnVjdG9yKHByaXZhdGUgbmd4VHJhbnNsYXRlOiBUcmFuc2xhdGVTZXJ2aWNlLCBASW5qZWN0KERPQ1VNRU5UKSBwcml2YXRlIGRvY3VtZW50OiBEb2N1bWVudCkge31cclxuXHJcbiAgICAvKipcclxuICAgICAqIFNldCB0aGUgZGVmYXVsdCBsYW5ndWFnZVxyXG4gICAgICovXHJcbiAgICBzZXREZWZhdWx0TGFuZ3VhZ2UobGFuZ3VhZ2VDb2RlOiBMYW5ndWFnZUNvZGUpIHtcclxuICAgICAgICB0aGlzLm5neFRyYW5zbGF0ZS5zZXREZWZhdWx0TGFuZyhsYW5ndWFnZUNvZGUpO1xyXG4gICAgfVxyXG5cclxuICAgIC8qKlxyXG4gICAgICogU2V0IHRoZSBVSSBsYW5ndWFnZVxyXG4gICAgICovXHJcbiAgICBzZXRMYW5ndWFnZShsYW5ndWFnZTogTGFuZ3VhZ2VDb2RlKTogdm9pZCB7XHJcbiAgICAgICAgdGhpcy5uZ3hUcmFuc2xhdGUudXNlKGxhbmd1YWdlKTtcclxuICAgICAgICBpZiAodGhpcy5kb2N1bWVudD8uZG9jdW1lbnRFbGVtZW50KSB7XHJcbiAgICAgICAgICAgIHRoaXMuZG9jdW1lbnQuZG9jdW1lbnRFbGVtZW50LmxhbmcgPSBsYW5ndWFnZTtcclxuICAgICAgICB9XHJcbiAgICB9XHJcblxyXG4gICAgLyoqXHJcbiAgICAgKiBTZXQgdGhlIGF2YWlsYWJsZSBVSSBsYW5ndWFnZXNcclxuICAgICAqL1xyXG4gICAgc2V0QXZhaWxhYmxlTGFuZ3VhZ2VzKGxhbmd1YWdlczogTGFuZ3VhZ2VDb2RlW10pIHtcclxuICAgICAgICB0aGlzLl9hdmFpbGFibGVMYW5ndWFnZXMgPSBsYW5ndWFnZXM7XHJcbiAgICB9XHJcblxyXG4gICAgLyoqXHJcbiAgICAgKiBUcmFuc2xhdGUgdGhlIGdpdmVuIGtleS5cclxuICAgICAqL1xyXG4gICAgdHJhbnNsYXRlKGtleTogc3RyaW5nIHwgc3RyaW5nW10sIHBhcmFtcz86IGFueSk6IHN0cmluZyB7XHJcbiAgICAgICAgcmV0dXJuIHRoaXMubmd4VHJhbnNsYXRlLmluc3RhbnQoa2V5LCBwYXJhbXMpO1xyXG4gICAgfVxyXG59XHJcbiJdfQ==
68
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaTE4bi5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2xpYi9jb3JlL3NyYy9wcm92aWRlcnMvaTE4bi9pMThuLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQzNDLE9BQU8sRUFBRSxNQUFNLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBR25ELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQzs7O0FBRTVELGVBQWU7QUFJZixNQUFNLE9BQU8sV0FBVztJQUdwQixJQUFJLGtCQUFrQjtRQUNsQixPQUFPLENBQUMsR0FBRyxJQUFJLENBQUMsbUJBQW1CLENBQUMsQ0FBQztJQUN6QyxDQUFDO0lBRUQsWUFBb0IsWUFBOEIsRUFBNEIsUUFBa0I7UUFBNUUsaUJBQVksR0FBWixZQUFZLENBQWtCO1FBQTRCLGFBQVEsR0FBUixRQUFRLENBQVU7UUFOaEcsd0JBQW1CLEdBQW1CLEVBQUUsQ0FBQztJQU0wRCxDQUFDO0lBRXBHOztPQUVHO0lBQ0gsa0JBQWtCLENBQUMsWUFBMEI7UUFDekMsSUFBSSxDQUFDLFlBQVksQ0FBQyxjQUFjLENBQUMsWUFBWSxDQUFDLENBQUM7SUFDbkQsQ0FBQztJQUVEOztPQUVHO0lBQ0gsV0FBVyxDQUFDLFFBQXNCO1FBQzlCLElBQUksQ0FBQyxZQUFZLENBQUMsR0FBRyxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBQ2hDLElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRSxlQUFlLEVBQUU7WUFDaEMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxlQUFlLENBQUMsSUFBSSxHQUFHLFFBQVEsQ0FBQztTQUNqRDtJQUNMLENBQUM7SUFFRDs7T0FFRztJQUNILHFCQUFxQixDQUFDLFNBQXlCO1FBQzNDLElBQUksQ0FBQyxtQkFBbUIsR0FBRyxTQUFTLENBQUM7SUFDekMsQ0FBQztJQUVEOztPQUVHO0lBQ0gsU0FBUyxDQUFDLEdBQXNCLEVBQUUsTUFBWTtRQUMxQyxPQUFPLElBQUksQ0FBQyxZQUFZLENBQUMsT0FBTyxDQUFDLEdBQUcsRUFBRSxNQUFNLENBQUMsQ0FBQztJQUNsRCxDQUFDO0lBRUQ7O09BRUc7SUFDSCxLQUFLLENBQUMsWUFBMEI7UUFDNUIsTUFBTSxnQkFBZ0IsR0FBRztZQUNyQixZQUFZLENBQUMsRUFBRTtZQUNmLFlBQVksQ0FBQyxFQUFFO1lBQ2YsWUFBWSxDQUFDLEVBQUU7WUFDZixZQUFZLENBQUMsRUFBRTtZQUNmLFlBQVksQ0FBQyxFQUFFO1NBQ2xCLENBQUM7UUFDRixPQUFPLGdCQUFnQixDQUFDLFFBQVEsQ0FBQyxZQUFZLENBQUMsQ0FBQztJQUNuRCxDQUFDOzhHQXBEUSxXQUFXLGtEQU93QyxRQUFRO2tIQVAzRCxXQUFXLGNBRlIsTUFBTTs7MkZBRVQsV0FBVztrQkFIdkIsVUFBVTttQkFBQztvQkFDUixVQUFVLEVBQUUsTUFBTTtpQkFDckI7OzBCQVF3RCxNQUFNOzJCQUFDLFFBQVEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBET0NVTUVOVCB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7IEluamVjdCwgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBUcmFuc2xhdGVTZXJ2aWNlIH0gZnJvbSAnQG5neC10cmFuc2xhdGUvY29yZSc7XHJcblxyXG5pbXBvcnQgeyBMYW5ndWFnZUNvZGUgfSBmcm9tICcuLi8uLi9jb21tb24vZ2VuZXJhdGVkLXR5cGVzJztcclxuXHJcbi8qKiBAZHluYW1pYyAqL1xyXG5ASW5qZWN0YWJsZSh7XHJcbiAgICBwcm92aWRlZEluOiAncm9vdCcsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBJMThuU2VydmljZSB7XHJcbiAgICBfYXZhaWxhYmxlTGFuZ3VhZ2VzOiBMYW5ndWFnZUNvZGVbXSA9IFtdO1xyXG5cclxuICAgIGdldCBhdmFpbGFibGVMYW5ndWFnZXMoKTogTGFuZ3VhZ2VDb2RlW10ge1xyXG4gICAgICAgIHJldHVybiBbLi4udGhpcy5fYXZhaWxhYmxlTGFuZ3VhZ2VzXTtcclxuICAgIH1cclxuXHJcbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIG5neFRyYW5zbGF0ZTogVHJhbnNsYXRlU2VydmljZSwgQEluamVjdChET0NVTUVOVCkgcHJpdmF0ZSBkb2N1bWVudDogRG9jdW1lbnQpIHt9XHJcblxyXG4gICAgLyoqXHJcbiAgICAgKiBTZXQgdGhlIGRlZmF1bHQgbGFuZ3VhZ2VcclxuICAgICAqL1xyXG4gICAgc2V0RGVmYXVsdExhbmd1YWdlKGxhbmd1YWdlQ29kZTogTGFuZ3VhZ2VDb2RlKSB7XHJcbiAgICAgICAgdGhpcy5uZ3hUcmFuc2xhdGUuc2V0RGVmYXVsdExhbmcobGFuZ3VhZ2VDb2RlKTtcclxuICAgIH1cclxuXHJcbiAgICAvKipcclxuICAgICAqIFNldCB0aGUgVUkgbGFuZ3VhZ2VcclxuICAgICAqL1xyXG4gICAgc2V0TGFuZ3VhZ2UobGFuZ3VhZ2U6IExhbmd1YWdlQ29kZSk6IHZvaWQge1xyXG4gICAgICAgIHRoaXMubmd4VHJhbnNsYXRlLnVzZShsYW5ndWFnZSk7XHJcbiAgICAgICAgaWYgKHRoaXMuZG9jdW1lbnQ/LmRvY3VtZW50RWxlbWVudCkge1xyXG4gICAgICAgICAgICB0aGlzLmRvY3VtZW50LmRvY3VtZW50RWxlbWVudC5sYW5nID0gbGFuZ3VhZ2U7XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG5cclxuICAgIC8qKlxyXG4gICAgICogU2V0IHRoZSBhdmFpbGFibGUgVUkgbGFuZ3VhZ2VzXHJcbiAgICAgKi9cclxuICAgIHNldEF2YWlsYWJsZUxhbmd1YWdlcyhsYW5ndWFnZXM6IExhbmd1YWdlQ29kZVtdKSB7XHJcbiAgICAgICAgdGhpcy5fYXZhaWxhYmxlTGFuZ3VhZ2VzID0gbGFuZ3VhZ2VzO1xyXG4gICAgfVxyXG5cclxuICAgIC8qKlxyXG4gICAgICogVHJhbnNsYXRlIHRoZSBnaXZlbiBrZXkuXHJcbiAgICAgKi9cclxuICAgIHRyYW5zbGF0ZShrZXk6IHN0cmluZyB8IHN0cmluZ1tdLCBwYXJhbXM/OiBhbnkpOiBzdHJpbmcge1xyXG4gICAgICAgIHJldHVybiB0aGlzLm5neFRyYW5zbGF0ZS5pbnN0YW50KGtleSwgcGFyYW1zKTtcclxuICAgIH1cclxuXHJcbiAgICAvKipcclxuICAgICAqIFJldHVybnMgdHJ1ZSBpZiB0aGUgZ2l2ZW4gbGFuZ3VhZ2UgY29kZSBpcyBhIHJpZ2h0LXRvLWxlZnQgbGFuZ3VhZ2UuXHJcbiAgICAgKi9cclxuICAgIGlzUlRMKGxhbmd1YWdlQ29kZTogTGFuZ3VhZ2VDb2RlKTogYm9vbGVhbiB7XHJcbiAgICAgICAgY29uc3QgcnRsTGFuZ3VhZ2VDb2RlcyA9IFtcclxuICAgICAgICAgICAgTGFuZ3VhZ2VDb2RlLmFyLFxyXG4gICAgICAgICAgICBMYW5ndWFnZUNvZGUuaGUsXHJcbiAgICAgICAgICAgIExhbmd1YWdlQ29kZS5mYSxcclxuICAgICAgICAgICAgTGFuZ3VhZ2VDb2RlLnVyLFxyXG4gICAgICAgICAgICBMYW5ndWFnZUNvZGUucHMsXHJcbiAgICAgICAgXTtcclxuICAgICAgICByZXR1cm4gcnRsTGFuZ3VhZ2VDb2Rlcy5pbmNsdWRlcyhsYW5ndWFnZUNvZGUpO1xyXG4gICAgfVxyXG59XHJcbiJdfQ==
@@ -94,4 +94,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.3", ngImpor
94
94
  function isComponentWithResolver(input) {
95
95
  return input && input.hasOwnProperty('resolveFn');
96
96
  }
97
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page.service.js","sourceRoot":"","sources":["../../../../../src/lib/core/src/providers/page/page.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { APP_INITIALIZER, Injectable, Provider, Type } from '@angular/core';\nimport { Route } from '@angular/router';\nimport { map } from 'rxjs/operators';\nimport { detailComponentWithResolver } from '../../common/base-detail.component';\nimport { PageLocationId } from '../../common/component-registry-types';\nimport { CanDeactivateDetailGuard } from '../../shared/providers/routing/can-deactivate-detail-guard';\n\n/**\n * @description\n * The object used to configure a new page tab.\n *\n * @docsCategory tabs\n */\nexport interface PageTabConfig {\n    /**\n     * @description\n     * A valid location representing a list or detail page.\n     */\n    location: PageLocationId;\n    /**\n     * @description\n     * An optional icon to display in the tab. The icon\n     * should be a valid shape name from the [Clarity Icons](https://core.clarity.design/foundation/icons/shapes/)\n     * set.\n     */\n    tabIcon?: string;\n    /**\n     * @description\n     * The route path to the tab. This will be appended to the\n     * route of the parent page.\n     */\n    route: string;\n    /**\n     * @description\n     * The name of the tab to display in the UI.\n     */\n    tab: string;\n    /**\n     * @description\n     * The priority of the tab. Tabs with a lower priority will be displayed first.\n     */\n    priority?: number;\n    /**\n     * @description\n     * The component to render at the route of the tab.\n     */\n    component: Type<any> | ReturnType<typeof detailComponentWithResolver>;\n    /**\n     * @description\n     * You can optionally provide any native Angular route configuration options here.\n     * Any values provided here will take precedence over the values generated\n     * by the `route` and `component` properties.\n     */\n    routeConfig?: Route;\n}\n\n/**\n * @description\n * Add a tab to an existing list or detail page.\n *\n * @example\n * ```TypeScript\n * \\@NgModule({\n *   imports: [SharedModule],\n *   providers: [\n *     registerPageTab({\n *       location: 'product-list',\n *       tab: 'Deleted Products',\n *       route: 'deleted',\n *       component: DeletedProductListComponent,\n *     }),\n *   ],\n * })\n * export class MyUiExtensionModule {}\n * ```\n * @docsCategory tabs\n */\nexport function registerPageTab(config: PageTabConfig): Provider {\n    return {\n        provide: APP_INITIALIZER,\n        multi: true,\n        useFactory: (pageService: PageService) => () => {\n            pageService.registerPageTab({\n                ...config,\n                priority: config.priority || 1,\n            });\n        },\n        deps: [PageService],\n    };\n}\n\n@Injectable({\n    providedIn: 'root',\n})\nexport class PageService {\n    private registry = new Map<PageLocationId, PageTabConfig[]>();\n\n    registerPageTab(config: PageTabConfig) {\n        if (!this.registry.has(config.location)) {\n            this.registry.set(config.location, []);\n        }\n        // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n        const pages = this.registry.get(config.location)!;\n        if (pages.find(p => p.tab === config.tab)) {\n            throw new Error(`A page with the tab \"${config.tab}\" has already been registered`);\n        }\n        pages.push(config);\n    }\n\n    getPageTabRoutes(location: PageLocationId): Route[] {\n        const configs = this.registry.get(location) || [];\n        return configs.map(config => {\n            const route: Route = {\n                path: config.route || '',\n                pathMatch: config.route ? 'prefix' : 'full',\n            };\n\n            let component: Type<any>;\n            if (isComponentWithResolver(config.component)) {\n                const { component: cmp, breadcrumbFn, resolveFn } = config.component;\n                component = cmp;\n                route.resolve = { detail: resolveFn };\n                route.data = {\n                    breadcrumb: data => data.detail.entity.pipe(map(entity => breadcrumbFn(entity))),\n                };\n            } else {\n                component = config.component;\n            }\n            const guards =\n                typeof component.prototype.canDeactivate === 'function' ? [CanDeactivateDetailGuard] : [];\n            route.component = component;\n            route.canDeactivate = guards;\n            if (config.routeConfig) {\n                Object.assign(route, config.routeConfig);\n            }\n\n            return route;\n        });\n    }\n\n    getPageTabs(location: PageLocationId): PageTabConfig[] {\n        return this.registry.get(location)?.sort((a, b) => (a.priority ?? 0) - (b.priority ?? 0)) || [];\n    }\n}\n\nfunction isComponentWithResolver(input: any): input is ReturnType<typeof detailComponentWithResolver> {\n    return input && input.hasOwnProperty('resolveFn');\n}\n"]}
97
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page.service.js","sourceRoot":"","sources":["../../../../../src/lib/core/src/providers/page/page.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { APP_INITIALIZER, Injectable, Provider, Type } from '@angular/core';\r\nimport { Route } from '@angular/router';\r\nimport { map } from 'rxjs/operators';\r\nimport { detailComponentWithResolver } from '../../common/base-detail.component';\r\nimport { PageLocationId } from '../../common/component-registry-types';\r\nimport { CanDeactivateDetailGuard } from '../../shared/providers/routing/can-deactivate-detail-guard';\r\n\r\n/**\r\n * @description\r\n * The object used to configure a new page tab.\r\n *\r\n * @docsCategory tabs\r\n */\r\nexport interface PageTabConfig {\r\n    /**\r\n     * @description\r\n     * A valid location representing a list or detail page.\r\n     */\r\n    location: PageLocationId;\r\n    /**\r\n     * @description\r\n     * An optional icon to display in the tab. The icon\r\n     * should be a valid shape name from the [Clarity Icons](https://core.clarity.design/foundation/icons/shapes/)\r\n     * set.\r\n     */\r\n    tabIcon?: string;\r\n    /**\r\n     * @description\r\n     * The route path to the tab. This will be appended to the\r\n     * route of the parent page.\r\n     */\r\n    route: string;\r\n    /**\r\n     * @description\r\n     * The name of the tab to display in the UI.\r\n     */\r\n    tab: string;\r\n    /**\r\n     * @description\r\n     * The priority of the tab. Tabs with a lower priority will be displayed first.\r\n     */\r\n    priority?: number;\r\n    /**\r\n     * @description\r\n     * The component to render at the route of the tab.\r\n     */\r\n    component: Type<any> | ReturnType<typeof detailComponentWithResolver>;\r\n    /**\r\n     * @description\r\n     * You can optionally provide any native Angular route configuration options here.\r\n     * Any values provided here will take precedence over the values generated\r\n     * by the `route` and `component` properties.\r\n     */\r\n    routeConfig?: Route;\r\n}\r\n\r\n/**\r\n * @description\r\n * Add a tab to an existing list or detail page.\r\n *\r\n * @example\r\n * ```TypeScript\r\n * \\@NgModule({\r\n *   imports: [SharedModule],\r\n *   providers: [\r\n *     registerPageTab({\r\n *       location: 'product-list',\r\n *       tab: 'Deleted Products',\r\n *       route: 'deleted',\r\n *       component: DeletedProductListComponent,\r\n *     }),\r\n *   ],\r\n * })\r\n * export class MyUiExtensionModule {}\r\n * ```\r\n * @docsCategory tabs\r\n */\r\nexport function registerPageTab(config: PageTabConfig): Provider {\r\n    return {\r\n        provide: APP_INITIALIZER,\r\n        multi: true,\r\n        useFactory: (pageService: PageService) => () => {\r\n            pageService.registerPageTab({\r\n                ...config,\r\n                priority: config.priority || 1,\r\n            });\r\n        },\r\n        deps: [PageService],\r\n    };\r\n}\r\n\r\n@Injectable({\r\n    providedIn: 'root',\r\n})\r\nexport class PageService {\r\n    private registry = new Map<PageLocationId, PageTabConfig[]>();\r\n\r\n    registerPageTab(config: PageTabConfig) {\r\n        if (!this.registry.has(config.location)) {\r\n            this.registry.set(config.location, []);\r\n        }\r\n        // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\r\n        const pages = this.registry.get(config.location)!;\r\n        if (pages.find(p => p.tab === config.tab)) {\r\n            throw new Error(`A page with the tab \"${config.tab}\" has already been registered`);\r\n        }\r\n        pages.push(config);\r\n    }\r\n\r\n    getPageTabRoutes(location: PageLocationId): Route[] {\r\n        const configs = this.registry.get(location) || [];\r\n        return configs.map(config => {\r\n            const route: Route = {\r\n                path: config.route || '',\r\n                pathMatch: config.route ? 'prefix' : 'full',\r\n            };\r\n\r\n            let component: Type<any>;\r\n            if (isComponentWithResolver(config.component)) {\r\n                const { component: cmp, breadcrumbFn, resolveFn } = config.component;\r\n                component = cmp;\r\n                route.resolve = { detail: resolveFn };\r\n                route.data = {\r\n                    breadcrumb: data => data.detail.entity.pipe(map(entity => breadcrumbFn(entity))),\r\n                };\r\n            } else {\r\n                component = config.component;\r\n            }\r\n            const guards =\r\n                typeof component.prototype.canDeactivate === 'function' ? [CanDeactivateDetailGuard] : [];\r\n            route.component = component;\r\n            route.canDeactivate = guards;\r\n            if (config.routeConfig) {\r\n                Object.assign(route, config.routeConfig);\r\n            }\r\n\r\n            return route;\r\n        });\r\n    }\r\n\r\n    getPageTabs(location: PageLocationId): PageTabConfig[] {\r\n        return this.registry.get(location)?.sort((a, b) => (a.priority ?? 0) - (b.priority ?? 0)) || [];\r\n    }\r\n}\r\n\r\nfunction isComponentWithResolver(input: any): input is ReturnType<typeof detailComponentWithResolver> {\r\n    return input && input.hasOwnProperty('resolveFn');\r\n}\r\n"]}
@@ -6,11 +6,11 @@ import * as i1 from "@angular/common";
6
6
  */
7
7
  export class AffixedInputComponent {
8
8
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.3", ngImport: i0, type: AffixedInputComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
9
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.3", type: AffixedInputComponent, selector: "vdr-affixed-input", inputs: { prefix: "prefix", suffix: "suffix" }, ngImport: i0, template: "<div [class.has-prefix]=\"!!prefix\" [class.has-suffix]=\"!!suffix\" class=\"input-wrapper\">\r\n <ng-content></ng-content>\r\n</div>\r\n<div class=\"affix prefix\" *ngIf=\"prefix\">{{ prefix }}</div>\r\n<div class=\"affix suffix\" *ngIf=\"suffix\">{{ suffix }}</div>\r\n", styles: [":host{display:flex}.input-wrapper{flex:1}.affix{color:var(--color-grey-800);display:flex;align-items:center;background-color:var(--color-component-bg-200);color:var(--color-text-200);border:1px solid var(--color-component-border-300);top:1px;padding:3px;line-height:.58333rem;transition:border .2s}::ng-deep .has-prefix>input[type=text],::ng-deep .has-prefix>input[type=number]{border-top-left-radius:0!important;border-bottom-left-radius:0!important}.prefix{order:-1;border-radius:3px 0 0 3px;border-right:none}::ng-deep .has-suffix>input[type=text],::ng-deep .has-suffix>input[type=number]{border-top-right-radius:0!important;border-bottom-right-radius:0!important}.suffix{border-radius:0 3px 3px 0;border-left:none}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
9
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.3", type: AffixedInputComponent, selector: "vdr-affixed-input", inputs: { prefix: "prefix", suffix: "suffix" }, ngImport: i0, template: "<div [class.has-prefix]=\"!!prefix\" [class.has-suffix]=\"!!suffix\" class=\"input-wrapper\">\r\n <ng-content></ng-content>\r\n</div>\r\n<div class=\"affix prefix\" *ngIf=\"prefix\">{{ prefix }}</div>\r\n<div class=\"affix suffix\" *ngIf=\"suffix\">{{ suffix }}</div>\r\n", styles: [":host{display:flex}.input-wrapper{flex:1}.affix{color:var(--color-grey-800);display:flex;align-items:center;background-color:var(--color-component-bg-200);color:var(--color-text-200);border:1px solid var(--color-component-border-300);top:1px;padding:3px;line-height:.58333rem;transition:border .2s}::ng-deep .has-prefix>input[type=text],::ng-deep .has-prefix>input[type=number]{border-top-left-radius:0!important;border-bottom-left-radius:0!important;width:100%}.prefix{order:-1;border-radius:3px 0 0 3px;border-right:none}::ng-deep .has-suffix>input[type=text],::ng-deep .has-suffix>input[type=number]{border-top-right-radius:0!important;border-bottom-right-radius:0!important;width:100%}.suffix{border-radius:0 3px 3px 0;border-left:none}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
10
10
  }
11
11
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.3", ngImport: i0, type: AffixedInputComponent, decorators: [{
12
12
  type: Component,
13
- args: [{ selector: 'vdr-affixed-input', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div [class.has-prefix]=\"!!prefix\" [class.has-suffix]=\"!!suffix\" class=\"input-wrapper\">\r\n <ng-content></ng-content>\r\n</div>\r\n<div class=\"affix prefix\" *ngIf=\"prefix\">{{ prefix }}</div>\r\n<div class=\"affix suffix\" *ngIf=\"suffix\">{{ suffix }}</div>\r\n", styles: [":host{display:flex}.input-wrapper{flex:1}.affix{color:var(--color-grey-800);display:flex;align-items:center;background-color:var(--color-component-bg-200);color:var(--color-text-200);border:1px solid var(--color-component-border-300);top:1px;padding:3px;line-height:.58333rem;transition:border .2s}::ng-deep .has-prefix>input[type=text],::ng-deep .has-prefix>input[type=number]{border-top-left-radius:0!important;border-bottom-left-radius:0!important}.prefix{order:-1;border-radius:3px 0 0 3px;border-right:none}::ng-deep .has-suffix>input[type=text],::ng-deep .has-suffix>input[type=number]{border-top-right-radius:0!important;border-bottom-right-radius:0!important}.suffix{border-radius:0 3px 3px 0;border-left:none}\n"] }]
13
+ args: [{ selector: 'vdr-affixed-input', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div [class.has-prefix]=\"!!prefix\" [class.has-suffix]=\"!!suffix\" class=\"input-wrapper\">\r\n <ng-content></ng-content>\r\n</div>\r\n<div class=\"affix prefix\" *ngIf=\"prefix\">{{ prefix }}</div>\r\n<div class=\"affix suffix\" *ngIf=\"suffix\">{{ suffix }}</div>\r\n", styles: [":host{display:flex}.input-wrapper{flex:1}.affix{color:var(--color-grey-800);display:flex;align-items:center;background-color:var(--color-component-bg-200);color:var(--color-text-200);border:1px solid var(--color-component-border-300);top:1px;padding:3px;line-height:.58333rem;transition:border .2s}::ng-deep .has-prefix>input[type=text],::ng-deep .has-prefix>input[type=number]{border-top-left-radius:0!important;border-bottom-left-radius:0!important;width:100%}.prefix{order:-1;border-radius:3px 0 0 3px;border-right:none}::ng-deep .has-suffix>input[type=text],::ng-deep .has-suffix>input[type=number]{border-top-right-radius:0!important;border-bottom-right-radius:0!important;width:100%}.suffix{border-radius:0 3px 3px 0;border-left:none}\n"] }]
14
14
  }], propDecorators: { prefix: [{
15
15
  type: Input
16
16
  }], suffix: [{
@@ -234,11 +234,11 @@ export class DataTable2Component {
234
234
  return dataTableConfig;
235
235
  }
236
236
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.3", ngImport: i0, type: DataTable2Component, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.LocalStorageService }, { token: i2.DataService }], target: i0.ɵɵFactoryTarget.Component }); }
237
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.3", type: DataTable2Component, selector: "vdr-data-table-2", inputs: { id: "id", items: "items", itemsPerPage: "itemsPerPage", currentPage: "currentPage", totalItems: "totalItems", emptyStateLabel: "emptyStateLabel", filters: "filters", activeIndex: "activeIndex" }, outputs: { pageChange: "pageChange", itemsPerPageChange: "itemsPerPageChange" }, providers: [PaginationService], queries: [{ propertyName: "searchComponent", first: true, predicate: DataTable2SearchComponent, descendants: true }, { propertyName: "bulkActionMenuComponent", first: true, predicate: BulkActionMenuComponent, descendants: true }, { propertyName: "customSearchTemplate", first: true, predicate: ["vdrDt2CustomSearch"], descendants: true }, { propertyName: "columns", predicate: DataTable2ColumnComponent }, { propertyName: "customFieldColumns", predicate: DataTableCustomFieldColumnComponent }, { propertyName: "templateRefs", predicate: TemplateRef }], usesOnChanges: true, ngImport: i0, template: "<div class=\"bulk-actions\">\r\n <ng-content select=\"vdr-bulk-action-menu\"></ng-content>\r\n</div>\r\n<div class=\"table-wrapper\">\r\n <table\r\n class=\"\"\r\n [class.no-select]=\"disableSelect\"\r\n [style.table-layout]=\"!items?.length ? 'fixed' : 'inherit'\"\r\n >\r\n <thead [class.items-selected]=\"selectionManager?.selection.length\">\r\n <tr class=\"heading-row\">\r\n <th *ngIf=\"selectionManager\" class=\"selection-col\">\r\n <input\r\n type=\"checkbox\"\r\n clrCheckbox\r\n [checked]=\"selectionManager?.areAllCurrentItemsSelected()\"\r\n (change)=\"onToggleAllClick()\"\r\n />\r\n </th>\r\n <th\r\n *ngFor=\"let column of visibleSortedColumns; last as isLast\"\r\n [class.expand]=\"column.expand\"\r\n >\r\n <div class=\"cell-content\" [ngClass]=\"column.align\">\r\n <span>{{ column.heading }}</span>\r\n <div *ngIf=\"column.sort as sort\" class=\"sort-toggle\">\r\n <button (click)=\"sort.toggleSortOrder()\" [class.active]=\"sort.sortOrder\">\r\n <clr-icon *ngIf=\"!sort.sortOrder\" shape=\"two-way-arrows left\"></clr-icon>\r\n <clr-icon *ngIf=\"sort.sortOrder === 'ASC'\" shape=\"arrow up\"></clr-icon>\r\n <clr-icon *ngIf=\"sort.sortOrder === 'DESC'\" shape=\"arrow down\"></clr-icon>\r\n </button>\r\n <div class=\"sort-label\" *ngIf=\"sort.sortOrder\">{{ sort.sortOrder }}</div>\r\n </div>\r\n </div>\r\n </th>\r\n <th>\r\n <div class=\"column-picker\">\r\n <vdr-data-table-colum-picker\r\n [uiLanguage]=\"uiLanguage$ | async\"\r\n [columns]=\"sortedColumns\"\r\n (reorder)=\"onColumnReorder($event)\"\r\n (resetColumns)=\"onColumnsReset()\"\r\n ></vdr-data-table-colum-picker>\r\n </div>\r\n </th>\r\n </tr>\r\n <tr *ngIf=\"searchComponent || customSearchTemplate || filters?.length\">\r\n <th\r\n [attr.colspan]=\"visibleSortedColumns.length + (selectionManager ? 2 : 1)\"\r\n class=\"filter-row\"\r\n [class.active]=\"showSearchFilterRow\"\r\n >\r\n <button\r\n class=\"button-ghost toggle-search-filter-row\"\r\n [class.active]=\"showSearchFilterRow\"\r\n (click)=\"toggleSearchFilterRow()\"\r\n [title]=\"'common.search-and-filter-list' | translate\"\r\n >\r\n <clr-icon shape=\"search\"></clr-icon>\r\n </button>\r\n <div class=\"filter-row-wrapper\" [class.hidden]=\"!showSearchFilterRow\">\r\n <ng-container *ngTemplateOutlet=\"searchComponent?.template\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"customSearchTemplate\"></ng-container>\r\n <ng-container *ngIf=\"filters\">\r\n <div class=\"filters\">\r\n <vdr-data-table-filters\r\n *ngFor=\"let activeFilter of filters.activeFilters\"\r\n [filterWithValue]=\"activeFilter\"\r\n [filters]=\"filters\"\r\n class=\"mt-1\"\r\n ></vdr-data-table-filters>\r\n <vdr-data-table-filters\r\n *ngIf=\"filters.length\"\r\n [filters]=\"filters\"\r\n class=\"mt-1\"\r\n ></vdr-data-table-filters>\r\n </div>\r\n </ng-container>\r\n </div>\r\n </th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr\r\n *ngFor=\"\r\n let item of items\r\n | paginate\r\n : {\r\n id: id,\r\n itemsPerPage: itemsPerPage,\r\n currentPage: currentPage,\r\n totalItems: totalItems\r\n };\r\n index as i;\r\n trackBy: trackByFn\r\n \"\r\n >\r\n <td *ngIf=\"selectionManager\" class=\"selection-col\" [class.active]=\"activeIndex === i\">\r\n <input\r\n type=\"checkbox\"\r\n clrCheckbox\r\n [checked]=\"selectionManager?.isSelected(item)\"\r\n (click)=\"onRowClick(item, $event)\"\r\n />\r\n </td>\r\n <td *ngFor=\"let column of visibleSortedColumns\" [class.active]=\"activeIndex === i\">\r\n <div class=\"cell-content\" [ngClass]=\"column.align\">\r\n <ng-container\r\n *ngTemplateOutlet=\"column.template; context: { item: item, index: i }\"\r\n ></ng-container>\r\n </div>\r\n </td>\r\n <td [class.active]=\"activeIndex === i\"><!-- column select --></td>\r\n </tr>\r\n <ng-container>\r\n <tr *ngIf=\"!items?.length\">\r\n <td [attr.colspan]=\"visibleSortedColumns.length + (selectionManager ? 2 : 1)\">\r\n <vdr-empty-placeholder [emptyStateLabel]=\"emptyStateLabel\"></vdr-empty-placeholder>\r\n </td>\r\n </tr>\r\n </ng-container>\r\n </tbody>\r\n </table>\r\n</div>\r\n<div class=\"table-footer\">\r\n <vdr-items-per-page-controls\r\n *ngIf=\"totalItems\"\r\n [itemsPerPage]=\"itemsPerPage\"\r\n (itemsPerPageChange)=\"itemsPerPageChange.emit($event)\"\r\n ></vdr-items-per-page-controls>\r\n <div *ngIf=\"totalItems\" class=\"total-items-count\">\r\n {{ 'common.total-items' | translate : { currentStart, currentEnd, totalItems } }}\r\n </div>\r\n\r\n <vdr-pagination-controls\r\n *ngIf=\"totalItems\"\r\n [id]=\"id\"\r\n [currentPage]=\"currentPage\"\r\n [itemsPerPage]=\"itemsPerPage\"\r\n [totalItems]=\"totalItems\"\r\n (pageChange)=\"pageChange.emit($event)\"\r\n ></vdr-pagination-controls>\r\n</div>\r\n", styles: [":host{display:block;max-width:100%;position:relative;margin-bottom:calc(var(--space-unit) * 4);container-type:inline-size}th{border-bottom:1px solid var(--color-weight-200);font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;position:relative;white-space:nowrap}th,td{padding:calc(var(--space-unit) * 1.5) calc(var(--space-unit) * 1)}tr td:first-of-type,tr th:first-of-type{text-align:center}@media screen and (min-width: 992px){tr td:first-of-type,tr th:first-of-type{padding-left:var(--surface-margin-left);text-align:left}}th:last-of-type,td:last-of-type{border-right:1px solid var(--color-weight-200)}tr:first-of-type th:last-of-type{border-image:linear-gradient(0deg,var(--color-weight-200),transparent) 1}tr:last-of-type td:last-of-type{border-image:linear-gradient(180deg,var(--color-weight-200),transparent) 1}tbody td{border-bottom:1px solid var(--color-table-row-separator)}tbody tr:hover{background-color:var(--color-table-row-hover-bg)}.bulk-actions{margin-left:calc(var(--space-unit) * 5);background-color:var(--color-surface-bg);z-index:10;display:flex;position:absolute;top:5px;height:40px}@media screen and (min-width: 992px){.bulk-actions{margin-left:calc(var(--space-unit) * 8.5)}}@media screen and (min-width: 1280px){.bulk-actions{margin-left:calc(var(--space-unit) * 10.5)}}.table-wrapper{display:block;overflow-y:hidden;overflow-x:auto;width:100%;max-width:var(--surface-width)}table{width:100%}table.no-select{-webkit-user-select:none;user-select:none}.column-picker{width:24px}.sort-toggle{display:flex;align-items:center;margin-left:calc(var(--space-unit) * .5)}.sort-toggle button{border:0;border-radius:var(--border-radius-lg);color:var(--color-weight-500);padding:0 2px;cursor:pointer;background-color:transparent}.sort-toggle button.active{color:var(--color-primary-700)}.sort-toggle .sort-label{margin-left:calc(var(--space-unit) * .5);font-size:10px;color:var(--color-primary-600);font-weight:400}.toggle-search-filter-row{position:absolute;top:-12px;left:4px}@media screen and (min-width: 1280px){.toggle-search-filter-row{left:8px}}.toggle-search-filter-row.active{background-color:var(--color-primary-700);color:var(--color-primary-100);border-color:var(--color-primary-700)}th.filter-row{position:relative;font-size:var(--font-size-base);font-weight:400;background-color:var(--color-weight-100);box-shadow:var(--data-table-filter-box-shadow);border-left-width:0;border-right-width:0;text-align:initial;padding:0}th.filter-row input{width:100%}th.filter-row.active{border-bottom:1px solid var(--color-weight-200)}th.filter-row .filters{margin-top:calc(var(--space-unit) * 1);display:flex;flex-wrap:wrap;gap:calc(var(--space-unit) * .5)}.filter-row-wrapper{padding:calc(var(--space-unit) * 4);padding-left:0;max-height:150px;transition:max-height .2s,padding .2s,opacity .2s}.filter-row-wrapper.hidden{max-height:0px;padding-top:0;padding-bottom:0;overflow:hidden;opacity:0}.cell-link{display:block;width:100%;height:100%}td.active{background-color:var(--color-table-row-active-bg)}.cell-content{display:flex;align-items:center;line-height:var(--font-size-sm);color:var(--color-weight-700)}.cell-content.left{justify-content:flex-start}.cell-content.center{justify-content:center}.cell-content.right{justify-content:flex-end}.selection-col{width:calc(var(--space-unit) * 8)}vdr-empty-placeholder{width:100%}.table-footer{display:flex;align-items:baseline;justify-content:space-between;margin-top:var(--space-unit);margin-left:var(--surface-margin-left);margin-right:var(--space-unit)}.total-items-count{font-size:var(--font-size-xs)}@container (max-width: 500px){.total-items-count{display:none}}\n"], dependencies: [{ kind: "directive", type: i3.ClrDatagridItemsTrackBy, selector: "[ngForTrackBy]", inputs: ["ngForTrackBy"] }, { kind: "directive", type: i3.ClrIconCustomTag, selector: "clr-icon" }, { kind: "directive", type: i3.ClrCheckbox, selector: "[clrCheckbox],[clrToggle]" }, { kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i5.ItemsPerPageControlsComponent, selector: "vdr-items-per-page-controls", inputs: ["itemsPerPage"], outputs: ["itemsPerPageChange"] }, { kind: "component", type: i6.PaginationControlsComponent, selector: "vdr-pagination-controls", inputs: ["id", "currentPage", "itemsPerPage", "totalItems"], outputs: ["pageChange"] }, { kind: "directive", type: i7.FormFieldControlDirective, selector: "input, textarea, select" }, { kind: "component", type: i8.EmptyPlaceholderComponent, selector: "vdr-empty-placeholder", inputs: ["emptyStateLabel"] }, { kind: "component", type: i9.DataTableFiltersComponent, selector: "vdr-data-table-filters", inputs: ["filters", "filterWithValue"] }, { kind: "component", type: i10.DataTableColumnPickerComponent, selector: "vdr-data-table-colum-picker", inputs: ["columns", "uiLanguage"], outputs: ["reorder", "resetColumns"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "pipe", type: i11.PaginatePipe, name: "paginate" }, { kind: "pipe", type: i12.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
237
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.3", type: DataTable2Component, selector: "vdr-data-table-2", inputs: { id: "id", items: "items", itemsPerPage: "itemsPerPage", currentPage: "currentPage", totalItems: "totalItems", emptyStateLabel: "emptyStateLabel", filters: "filters", activeIndex: "activeIndex" }, outputs: { pageChange: "pageChange", itemsPerPageChange: "itemsPerPageChange" }, providers: [PaginationService], queries: [{ propertyName: "searchComponent", first: true, predicate: DataTable2SearchComponent, descendants: true }, { propertyName: "bulkActionMenuComponent", first: true, predicate: BulkActionMenuComponent, descendants: true }, { propertyName: "customSearchTemplate", first: true, predicate: ["vdrDt2CustomSearch"], descendants: true }, { propertyName: "columns", predicate: DataTable2ColumnComponent }, { propertyName: "customFieldColumns", predicate: DataTableCustomFieldColumnComponent }, { propertyName: "templateRefs", predicate: TemplateRef }], usesOnChanges: true, ngImport: i0, template: "<div class=\"bulk-actions\">\r\n <ng-content select=\"vdr-bulk-action-menu\"></ng-content>\r\n</div>\r\n<div class=\"table-wrapper\">\r\n <table\r\n class=\"\"\r\n [class.no-select]=\"disableSelect\"\r\n >\r\n <thead [class.items-selected]=\"selectionManager?.selection.length\">\r\n <tr class=\"heading-row\">\r\n <th *ngIf=\"selectionManager\" class=\"selection-col\">\r\n <input\r\n type=\"checkbox\"\r\n clrCheckbox\r\n [checked]=\"selectionManager?.areAllCurrentItemsSelected()\"\r\n (change)=\"onToggleAllClick()\"\r\n />\r\n </th>\r\n <th\r\n *ngFor=\"let column of visibleSortedColumns; last as isLast\"\r\n [class.expand]=\"column.expand\"\r\n >\r\n <div class=\"cell-content\" [ngClass]=\"column.align\">\r\n <span>{{ column.heading }}</span>\r\n <div *ngIf=\"column.sort as sort\" class=\"sort-toggle\">\r\n <button (click)=\"sort.toggleSortOrder()\" [class.active]=\"sort.sortOrder\">\r\n <clr-icon *ngIf=\"!sort.sortOrder\" shape=\"two-way-arrows left\"></clr-icon>\r\n <clr-icon *ngIf=\"sort.sortOrder === 'ASC'\" shape=\"arrow up\"></clr-icon>\r\n <clr-icon *ngIf=\"sort.sortOrder === 'DESC'\" shape=\"arrow down\"></clr-icon>\r\n </button>\r\n <div class=\"sort-label\" *ngIf=\"sort.sortOrder\">{{ sort.sortOrder }}</div>\r\n </div>\r\n </div>\r\n </th>\r\n <th>\r\n <div class=\"column-picker\">\r\n <vdr-data-table-colum-picker\r\n [uiLanguage]=\"uiLanguage$ | async\"\r\n [columns]=\"sortedColumns\"\r\n (reorder)=\"onColumnReorder($event)\"\r\n (resetColumns)=\"onColumnsReset()\"\r\n ></vdr-data-table-colum-picker>\r\n </div>\r\n </th>\r\n </tr>\r\n <tr *ngIf=\"searchComponent || customSearchTemplate || filters?.length\">\r\n <th\r\n [attr.colspan]=\"visibleSortedColumns.length + (selectionManager ? 2 : 1)\"\r\n class=\"filter-row\"\r\n [class.active]=\"showSearchFilterRow\"\r\n >\r\n <button\r\n class=\"button-ghost toggle-search-filter-row\"\r\n [class.active]=\"showSearchFilterRow\"\r\n (click)=\"toggleSearchFilterRow()\"\r\n [title]=\"'common.search-and-filter-list' | translate\"\r\n >\r\n <clr-icon shape=\"search\"></clr-icon>\r\n </button>\r\n <div class=\"filter-row-wrapper\" [class.hidden]=\"!showSearchFilterRow\">\r\n <ng-container *ngTemplateOutlet=\"searchComponent?.template\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"customSearchTemplate\"></ng-container>\r\n <ng-container *ngIf=\"filters\">\r\n <div class=\"filters\">\r\n <vdr-data-table-filters\r\n *ngFor=\"let activeFilter of filters.activeFilters\"\r\n [filterWithValue]=\"activeFilter\"\r\n [filters]=\"filters\"\r\n class=\"mt-1\"\r\n ></vdr-data-table-filters>\r\n <vdr-data-table-filters\r\n *ngIf=\"filters.length\"\r\n [filters]=\"filters\"\r\n class=\"mt-1\"\r\n ></vdr-data-table-filters>\r\n </div>\r\n </ng-container>\r\n </div>\r\n </th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr\r\n *ngFor=\"\r\n let item of items\r\n | paginate\r\n : {\r\n id: id,\r\n itemsPerPage: itemsPerPage,\r\n currentPage: currentPage,\r\n totalItems: totalItems\r\n };\r\n index as i;\r\n trackBy: trackByFn\r\n \"\r\n >\r\n <td *ngIf=\"selectionManager\" class=\"selection-col\" [class.active]=\"activeIndex === i\">\r\n <input\r\n type=\"checkbox\"\r\n clrCheckbox\r\n [checked]=\"selectionManager?.isSelected(item)\"\r\n (click)=\"onRowClick(item, $event)\"\r\n />\r\n </td>\r\n <td *ngFor=\"let column of visibleSortedColumns\" [class.active]=\"activeIndex === i\">\r\n <div class=\"cell-content\" [ngClass]=\"column.align\">\r\n <ng-container\r\n *ngTemplateOutlet=\"column.template; context: { item: item, index: i }\"\r\n ></ng-container>\r\n </div>\r\n </td>\r\n <td [class.active]=\"activeIndex === i\"><!-- column select --></td>\r\n </tr>\r\n <ng-container>\r\n <tr *ngIf=\"!items?.length\">\r\n <td [attr.colspan]=\"visibleSortedColumns.length + (selectionManager ? 2 : 1)\">\r\n <vdr-empty-placeholder [emptyStateLabel]=\"emptyStateLabel\"></vdr-empty-placeholder>\r\n </td>\r\n </tr>\r\n </ng-container>\r\n </tbody>\r\n </table>\r\n</div>\r\n<div class=\"table-footer\">\r\n <vdr-items-per-page-controls\r\n *ngIf=\"totalItems\"\r\n [itemsPerPage]=\"itemsPerPage\"\r\n (itemsPerPageChange)=\"itemsPerPageChange.emit($event)\"\r\n ></vdr-items-per-page-controls>\r\n <div *ngIf=\"totalItems\" class=\"total-items-count\">\r\n {{ 'common.total-items' | translate : { currentStart, currentEnd, totalItems } }}\r\n </div>\r\n\r\n <vdr-pagination-controls\r\n *ngIf=\"totalItems\"\r\n [id]=\"id\"\r\n [currentPage]=\"currentPage\"\r\n [itemsPerPage]=\"itemsPerPage\"\r\n [totalItems]=\"totalItems\"\r\n (pageChange)=\"pageChange.emit($event)\"\r\n ></vdr-pagination-controls>\r\n</div>\r\n", styles: [":host{display:block;max-width:100%;position:relative;margin-bottom:calc(var(--space-unit) * 4);container-type:inline-size}th{border-bottom:1px solid var(--color-weight-200);font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;position:relative;white-space:nowrap}th,td{padding:calc(var(--space-unit) * 1.5) calc(var(--space-unit) * 1)}tr td:first-of-type,tr th:first-of-type{text-align:center}@media screen and (min-width: 992px){tr td:first-of-type,tr th:first-of-type{padding-left:var(--surface-margin-left);text-align:left}}th:last-of-type,td:last-of-type{border-right:1px solid var(--color-weight-200)}tr:first-of-type th:last-of-type{border-image:linear-gradient(0deg,var(--color-weight-200),transparent) 1}tr:last-of-type td:last-of-type{border-image:linear-gradient(180deg,var(--color-weight-200),transparent) 1}tbody td{border-bottom:1px solid var(--color-table-row-separator)}tbody tr:hover{background-color:var(--color-table-row-hover-bg)}.bulk-actions{margin-left:calc(var(--space-unit) * 5);background-color:var(--color-surface-bg);z-index:10;display:flex;position:absolute;top:5px;height:40px}@media screen and (min-width: 992px){.bulk-actions{margin-left:calc(var(--space-unit) * 8.5)}}@media screen and (min-width: 1280px){.bulk-actions{margin-left:calc(var(--space-unit) * 10.5)}}.table-wrapper{display:block;overflow-y:hidden;overflow-x:auto;width:100%;max-width:var(--surface-width)}table{width:100%}table.no-select{-webkit-user-select:none;user-select:none}.column-picker{width:24px}.sort-toggle{display:flex;align-items:center;margin-left:calc(var(--space-unit) * .5)}.sort-toggle button{border:0;border-radius:var(--border-radius-lg);color:var(--color-weight-500);padding:0 2px;cursor:pointer;background-color:transparent}.sort-toggle button.active{color:var(--color-primary-700)}.sort-toggle .sort-label{margin-left:calc(var(--space-unit) * .5);font-size:10px;color:var(--color-primary-600);font-weight:400}.toggle-search-filter-row{position:absolute;top:-12px;left:4px}@media screen and (min-width: 1280px){.toggle-search-filter-row{left:8px}}.toggle-search-filter-row.active{background-color:var(--color-primary-700);color:var(--color-primary-100);border-color:var(--color-primary-700)}th.filter-row{position:relative;font-size:var(--font-size-base);font-weight:400;background-color:var(--color-weight-100);box-shadow:var(--data-table-filter-box-shadow);border-left-width:0;border-right-width:0;text-align:initial;padding:0}th.filter-row input{width:100%}th.filter-row.active{border-bottom:1px solid var(--color-weight-200)}th.filter-row .filters{margin-top:calc(var(--space-unit) * 1);display:flex;flex-wrap:wrap;gap:calc(var(--space-unit) * .5)}.filter-row-wrapper{padding:calc(var(--space-unit) * 4);padding-left:0;max-height:150px;transition:max-height .2s,padding .2s,opacity .2s}.filter-row-wrapper.hidden{max-height:0px;padding-top:0;padding-bottom:0;overflow:hidden;opacity:0}.cell-link{display:block;width:100%;height:100%}td.active{background-color:var(--color-table-row-active-bg)}.cell-content{display:flex;align-items:center;line-height:var(--font-size-sm);color:var(--color-weight-700)}.cell-content.left{justify-content:flex-start}.cell-content.center{justify-content:center}.cell-content.right{justify-content:flex-end}.selection-col{width:calc(var(--space-unit) * 8)}vdr-empty-placeholder{width:100%}.table-footer{display:flex;align-items:baseline;justify-content:space-between;margin-top:var(--space-unit);margin-left:var(--surface-margin-left);margin-right:var(--space-unit)}.total-items-count{font-size:var(--font-size-xs)}@container (max-width: 500px){.total-items-count{display:none}}\n"], dependencies: [{ kind: "directive", type: i3.ClrDatagridItemsTrackBy, selector: "[ngForTrackBy]", inputs: ["ngForTrackBy"] }, { kind: "directive", type: i3.ClrIconCustomTag, selector: "clr-icon" }, { kind: "directive", type: i3.ClrCheckbox, selector: "[clrCheckbox],[clrToggle]" }, { kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i5.ItemsPerPageControlsComponent, selector: "vdr-items-per-page-controls", inputs: ["itemsPerPage"], outputs: ["itemsPerPageChange"] }, { kind: "component", type: i6.PaginationControlsComponent, selector: "vdr-pagination-controls", inputs: ["id", "currentPage", "itemsPerPage", "totalItems"], outputs: ["pageChange"] }, { kind: "directive", type: i7.FormFieldControlDirective, selector: "input, textarea, select" }, { kind: "component", type: i8.EmptyPlaceholderComponent, selector: "vdr-empty-placeholder", inputs: ["emptyStateLabel"] }, { kind: "component", type: i9.DataTableFiltersComponent, selector: "vdr-data-table-filters", inputs: ["filters", "filterWithValue"] }, { kind: "component", type: i10.DataTableColumnPickerComponent, selector: "vdr-data-table-colum-picker", inputs: ["columns", "uiLanguage"], outputs: ["reorder", "resetColumns"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "pipe", type: i11.PaginatePipe, name: "paginate" }, { kind: "pipe", type: i12.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
238
238
  }
239
239
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.3", ngImport: i0, type: DataTable2Component, decorators: [{
240
240
  type: Component,
241
- args: [{ selector: 'vdr-data-table-2', changeDetection: ChangeDetectionStrategy.OnPush, providers: [PaginationService], template: "<div class=\"bulk-actions\">\r\n <ng-content select=\"vdr-bulk-action-menu\"></ng-content>\r\n</div>\r\n<div class=\"table-wrapper\">\r\n <table\r\n class=\"\"\r\n [class.no-select]=\"disableSelect\"\r\n [style.table-layout]=\"!items?.length ? 'fixed' : 'inherit'\"\r\n >\r\n <thead [class.items-selected]=\"selectionManager?.selection.length\">\r\n <tr class=\"heading-row\">\r\n <th *ngIf=\"selectionManager\" class=\"selection-col\">\r\n <input\r\n type=\"checkbox\"\r\n clrCheckbox\r\n [checked]=\"selectionManager?.areAllCurrentItemsSelected()\"\r\n (change)=\"onToggleAllClick()\"\r\n />\r\n </th>\r\n <th\r\n *ngFor=\"let column of visibleSortedColumns; last as isLast\"\r\n [class.expand]=\"column.expand\"\r\n >\r\n <div class=\"cell-content\" [ngClass]=\"column.align\">\r\n <span>{{ column.heading }}</span>\r\n <div *ngIf=\"column.sort as sort\" class=\"sort-toggle\">\r\n <button (click)=\"sort.toggleSortOrder()\" [class.active]=\"sort.sortOrder\">\r\n <clr-icon *ngIf=\"!sort.sortOrder\" shape=\"two-way-arrows left\"></clr-icon>\r\n <clr-icon *ngIf=\"sort.sortOrder === 'ASC'\" shape=\"arrow up\"></clr-icon>\r\n <clr-icon *ngIf=\"sort.sortOrder === 'DESC'\" shape=\"arrow down\"></clr-icon>\r\n </button>\r\n <div class=\"sort-label\" *ngIf=\"sort.sortOrder\">{{ sort.sortOrder }}</div>\r\n </div>\r\n </div>\r\n </th>\r\n <th>\r\n <div class=\"column-picker\">\r\n <vdr-data-table-colum-picker\r\n [uiLanguage]=\"uiLanguage$ | async\"\r\n [columns]=\"sortedColumns\"\r\n (reorder)=\"onColumnReorder($event)\"\r\n (resetColumns)=\"onColumnsReset()\"\r\n ></vdr-data-table-colum-picker>\r\n </div>\r\n </th>\r\n </tr>\r\n <tr *ngIf=\"searchComponent || customSearchTemplate || filters?.length\">\r\n <th\r\n [attr.colspan]=\"visibleSortedColumns.length + (selectionManager ? 2 : 1)\"\r\n class=\"filter-row\"\r\n [class.active]=\"showSearchFilterRow\"\r\n >\r\n <button\r\n class=\"button-ghost toggle-search-filter-row\"\r\n [class.active]=\"showSearchFilterRow\"\r\n (click)=\"toggleSearchFilterRow()\"\r\n [title]=\"'common.search-and-filter-list' | translate\"\r\n >\r\n <clr-icon shape=\"search\"></clr-icon>\r\n </button>\r\n <div class=\"filter-row-wrapper\" [class.hidden]=\"!showSearchFilterRow\">\r\n <ng-container *ngTemplateOutlet=\"searchComponent?.template\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"customSearchTemplate\"></ng-container>\r\n <ng-container *ngIf=\"filters\">\r\n <div class=\"filters\">\r\n <vdr-data-table-filters\r\n *ngFor=\"let activeFilter of filters.activeFilters\"\r\n [filterWithValue]=\"activeFilter\"\r\n [filters]=\"filters\"\r\n class=\"mt-1\"\r\n ></vdr-data-table-filters>\r\n <vdr-data-table-filters\r\n *ngIf=\"filters.length\"\r\n [filters]=\"filters\"\r\n class=\"mt-1\"\r\n ></vdr-data-table-filters>\r\n </div>\r\n </ng-container>\r\n </div>\r\n </th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr\r\n *ngFor=\"\r\n let item of items\r\n | paginate\r\n : {\r\n id: id,\r\n itemsPerPage: itemsPerPage,\r\n currentPage: currentPage,\r\n totalItems: totalItems\r\n };\r\n index as i;\r\n trackBy: trackByFn\r\n \"\r\n >\r\n <td *ngIf=\"selectionManager\" class=\"selection-col\" [class.active]=\"activeIndex === i\">\r\n <input\r\n type=\"checkbox\"\r\n clrCheckbox\r\n [checked]=\"selectionManager?.isSelected(item)\"\r\n (click)=\"onRowClick(item, $event)\"\r\n />\r\n </td>\r\n <td *ngFor=\"let column of visibleSortedColumns\" [class.active]=\"activeIndex === i\">\r\n <div class=\"cell-content\" [ngClass]=\"column.align\">\r\n <ng-container\r\n *ngTemplateOutlet=\"column.template; context: { item: item, index: i }\"\r\n ></ng-container>\r\n </div>\r\n </td>\r\n <td [class.active]=\"activeIndex === i\"><!-- column select --></td>\r\n </tr>\r\n <ng-container>\r\n <tr *ngIf=\"!items?.length\">\r\n <td [attr.colspan]=\"visibleSortedColumns.length + (selectionManager ? 2 : 1)\">\r\n <vdr-empty-placeholder [emptyStateLabel]=\"emptyStateLabel\"></vdr-empty-placeholder>\r\n </td>\r\n </tr>\r\n </ng-container>\r\n </tbody>\r\n </table>\r\n</div>\r\n<div class=\"table-footer\">\r\n <vdr-items-per-page-controls\r\n *ngIf=\"totalItems\"\r\n [itemsPerPage]=\"itemsPerPage\"\r\n (itemsPerPageChange)=\"itemsPerPageChange.emit($event)\"\r\n ></vdr-items-per-page-controls>\r\n <div *ngIf=\"totalItems\" class=\"total-items-count\">\r\n {{ 'common.total-items' | translate : { currentStart, currentEnd, totalItems } }}\r\n </div>\r\n\r\n <vdr-pagination-controls\r\n *ngIf=\"totalItems\"\r\n [id]=\"id\"\r\n [currentPage]=\"currentPage\"\r\n [itemsPerPage]=\"itemsPerPage\"\r\n [totalItems]=\"totalItems\"\r\n (pageChange)=\"pageChange.emit($event)\"\r\n ></vdr-pagination-controls>\r\n</div>\r\n", styles: [":host{display:block;max-width:100%;position:relative;margin-bottom:calc(var(--space-unit) * 4);container-type:inline-size}th{border-bottom:1px solid var(--color-weight-200);font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;position:relative;white-space:nowrap}th,td{padding:calc(var(--space-unit) * 1.5) calc(var(--space-unit) * 1)}tr td:first-of-type,tr th:first-of-type{text-align:center}@media screen and (min-width: 992px){tr td:first-of-type,tr th:first-of-type{padding-left:var(--surface-margin-left);text-align:left}}th:last-of-type,td:last-of-type{border-right:1px solid var(--color-weight-200)}tr:first-of-type th:last-of-type{border-image:linear-gradient(0deg,var(--color-weight-200),transparent) 1}tr:last-of-type td:last-of-type{border-image:linear-gradient(180deg,var(--color-weight-200),transparent) 1}tbody td{border-bottom:1px solid var(--color-table-row-separator)}tbody tr:hover{background-color:var(--color-table-row-hover-bg)}.bulk-actions{margin-left:calc(var(--space-unit) * 5);background-color:var(--color-surface-bg);z-index:10;display:flex;position:absolute;top:5px;height:40px}@media screen and (min-width: 992px){.bulk-actions{margin-left:calc(var(--space-unit) * 8.5)}}@media screen and (min-width: 1280px){.bulk-actions{margin-left:calc(var(--space-unit) * 10.5)}}.table-wrapper{display:block;overflow-y:hidden;overflow-x:auto;width:100%;max-width:var(--surface-width)}table{width:100%}table.no-select{-webkit-user-select:none;user-select:none}.column-picker{width:24px}.sort-toggle{display:flex;align-items:center;margin-left:calc(var(--space-unit) * .5)}.sort-toggle button{border:0;border-radius:var(--border-radius-lg);color:var(--color-weight-500);padding:0 2px;cursor:pointer;background-color:transparent}.sort-toggle button.active{color:var(--color-primary-700)}.sort-toggle .sort-label{margin-left:calc(var(--space-unit) * .5);font-size:10px;color:var(--color-primary-600);font-weight:400}.toggle-search-filter-row{position:absolute;top:-12px;left:4px}@media screen and (min-width: 1280px){.toggle-search-filter-row{left:8px}}.toggle-search-filter-row.active{background-color:var(--color-primary-700);color:var(--color-primary-100);border-color:var(--color-primary-700)}th.filter-row{position:relative;font-size:var(--font-size-base);font-weight:400;background-color:var(--color-weight-100);box-shadow:var(--data-table-filter-box-shadow);border-left-width:0;border-right-width:0;text-align:initial;padding:0}th.filter-row input{width:100%}th.filter-row.active{border-bottom:1px solid var(--color-weight-200)}th.filter-row .filters{margin-top:calc(var(--space-unit) * 1);display:flex;flex-wrap:wrap;gap:calc(var(--space-unit) * .5)}.filter-row-wrapper{padding:calc(var(--space-unit) * 4);padding-left:0;max-height:150px;transition:max-height .2s,padding .2s,opacity .2s}.filter-row-wrapper.hidden{max-height:0px;padding-top:0;padding-bottom:0;overflow:hidden;opacity:0}.cell-link{display:block;width:100%;height:100%}td.active{background-color:var(--color-table-row-active-bg)}.cell-content{display:flex;align-items:center;line-height:var(--font-size-sm);color:var(--color-weight-700)}.cell-content.left{justify-content:flex-start}.cell-content.center{justify-content:center}.cell-content.right{justify-content:flex-end}.selection-col{width:calc(var(--space-unit) * 8)}vdr-empty-placeholder{width:100%}.table-footer{display:flex;align-items:baseline;justify-content:space-between;margin-top:var(--space-unit);margin-left:var(--surface-margin-left);margin-right:var(--space-unit)}.total-items-count{font-size:var(--font-size-xs)}@container (max-width: 500px){.total-items-count{display:none}}\n"] }]
241
+ args: [{ selector: 'vdr-data-table-2', changeDetection: ChangeDetectionStrategy.OnPush, providers: [PaginationService], template: "<div class=\"bulk-actions\">\r\n <ng-content select=\"vdr-bulk-action-menu\"></ng-content>\r\n</div>\r\n<div class=\"table-wrapper\">\r\n <table\r\n class=\"\"\r\n [class.no-select]=\"disableSelect\"\r\n >\r\n <thead [class.items-selected]=\"selectionManager?.selection.length\">\r\n <tr class=\"heading-row\">\r\n <th *ngIf=\"selectionManager\" class=\"selection-col\">\r\n <input\r\n type=\"checkbox\"\r\n clrCheckbox\r\n [checked]=\"selectionManager?.areAllCurrentItemsSelected()\"\r\n (change)=\"onToggleAllClick()\"\r\n />\r\n </th>\r\n <th\r\n *ngFor=\"let column of visibleSortedColumns; last as isLast\"\r\n [class.expand]=\"column.expand\"\r\n >\r\n <div class=\"cell-content\" [ngClass]=\"column.align\">\r\n <span>{{ column.heading }}</span>\r\n <div *ngIf=\"column.sort as sort\" class=\"sort-toggle\">\r\n <button (click)=\"sort.toggleSortOrder()\" [class.active]=\"sort.sortOrder\">\r\n <clr-icon *ngIf=\"!sort.sortOrder\" shape=\"two-way-arrows left\"></clr-icon>\r\n <clr-icon *ngIf=\"sort.sortOrder === 'ASC'\" shape=\"arrow up\"></clr-icon>\r\n <clr-icon *ngIf=\"sort.sortOrder === 'DESC'\" shape=\"arrow down\"></clr-icon>\r\n </button>\r\n <div class=\"sort-label\" *ngIf=\"sort.sortOrder\">{{ sort.sortOrder }}</div>\r\n </div>\r\n </div>\r\n </th>\r\n <th>\r\n <div class=\"column-picker\">\r\n <vdr-data-table-colum-picker\r\n [uiLanguage]=\"uiLanguage$ | async\"\r\n [columns]=\"sortedColumns\"\r\n (reorder)=\"onColumnReorder($event)\"\r\n (resetColumns)=\"onColumnsReset()\"\r\n ></vdr-data-table-colum-picker>\r\n </div>\r\n </th>\r\n </tr>\r\n <tr *ngIf=\"searchComponent || customSearchTemplate || filters?.length\">\r\n <th\r\n [attr.colspan]=\"visibleSortedColumns.length + (selectionManager ? 2 : 1)\"\r\n class=\"filter-row\"\r\n [class.active]=\"showSearchFilterRow\"\r\n >\r\n <button\r\n class=\"button-ghost toggle-search-filter-row\"\r\n [class.active]=\"showSearchFilterRow\"\r\n (click)=\"toggleSearchFilterRow()\"\r\n [title]=\"'common.search-and-filter-list' | translate\"\r\n >\r\n <clr-icon shape=\"search\"></clr-icon>\r\n </button>\r\n <div class=\"filter-row-wrapper\" [class.hidden]=\"!showSearchFilterRow\">\r\n <ng-container *ngTemplateOutlet=\"searchComponent?.template\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"customSearchTemplate\"></ng-container>\r\n <ng-container *ngIf=\"filters\">\r\n <div class=\"filters\">\r\n <vdr-data-table-filters\r\n *ngFor=\"let activeFilter of filters.activeFilters\"\r\n [filterWithValue]=\"activeFilter\"\r\n [filters]=\"filters\"\r\n class=\"mt-1\"\r\n ></vdr-data-table-filters>\r\n <vdr-data-table-filters\r\n *ngIf=\"filters.length\"\r\n [filters]=\"filters\"\r\n class=\"mt-1\"\r\n ></vdr-data-table-filters>\r\n </div>\r\n </ng-container>\r\n </div>\r\n </th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr\r\n *ngFor=\"\r\n let item of items\r\n | paginate\r\n : {\r\n id: id,\r\n itemsPerPage: itemsPerPage,\r\n currentPage: currentPage,\r\n totalItems: totalItems\r\n };\r\n index as i;\r\n trackBy: trackByFn\r\n \"\r\n >\r\n <td *ngIf=\"selectionManager\" class=\"selection-col\" [class.active]=\"activeIndex === i\">\r\n <input\r\n type=\"checkbox\"\r\n clrCheckbox\r\n [checked]=\"selectionManager?.isSelected(item)\"\r\n (click)=\"onRowClick(item, $event)\"\r\n />\r\n </td>\r\n <td *ngFor=\"let column of visibleSortedColumns\" [class.active]=\"activeIndex === i\">\r\n <div class=\"cell-content\" [ngClass]=\"column.align\">\r\n <ng-container\r\n *ngTemplateOutlet=\"column.template; context: { item: item, index: i }\"\r\n ></ng-container>\r\n </div>\r\n </td>\r\n <td [class.active]=\"activeIndex === i\"><!-- column select --></td>\r\n </tr>\r\n <ng-container>\r\n <tr *ngIf=\"!items?.length\">\r\n <td [attr.colspan]=\"visibleSortedColumns.length + (selectionManager ? 2 : 1)\">\r\n <vdr-empty-placeholder [emptyStateLabel]=\"emptyStateLabel\"></vdr-empty-placeholder>\r\n </td>\r\n </tr>\r\n </ng-container>\r\n </tbody>\r\n </table>\r\n</div>\r\n<div class=\"table-footer\">\r\n <vdr-items-per-page-controls\r\n *ngIf=\"totalItems\"\r\n [itemsPerPage]=\"itemsPerPage\"\r\n (itemsPerPageChange)=\"itemsPerPageChange.emit($event)\"\r\n ></vdr-items-per-page-controls>\r\n <div *ngIf=\"totalItems\" class=\"total-items-count\">\r\n {{ 'common.total-items' | translate : { currentStart, currentEnd, totalItems } }}\r\n </div>\r\n\r\n <vdr-pagination-controls\r\n *ngIf=\"totalItems\"\r\n [id]=\"id\"\r\n [currentPage]=\"currentPage\"\r\n [itemsPerPage]=\"itemsPerPage\"\r\n [totalItems]=\"totalItems\"\r\n (pageChange)=\"pageChange.emit($event)\"\r\n ></vdr-pagination-controls>\r\n</div>\r\n", styles: [":host{display:block;max-width:100%;position:relative;margin-bottom:calc(var(--space-unit) * 4);container-type:inline-size}th{border-bottom:1px solid var(--color-weight-200);font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;position:relative;white-space:nowrap}th,td{padding:calc(var(--space-unit) * 1.5) calc(var(--space-unit) * 1)}tr td:first-of-type,tr th:first-of-type{text-align:center}@media screen and (min-width: 992px){tr td:first-of-type,tr th:first-of-type{padding-left:var(--surface-margin-left);text-align:left}}th:last-of-type,td:last-of-type{border-right:1px solid var(--color-weight-200)}tr:first-of-type th:last-of-type{border-image:linear-gradient(0deg,var(--color-weight-200),transparent) 1}tr:last-of-type td:last-of-type{border-image:linear-gradient(180deg,var(--color-weight-200),transparent) 1}tbody td{border-bottom:1px solid var(--color-table-row-separator)}tbody tr:hover{background-color:var(--color-table-row-hover-bg)}.bulk-actions{margin-left:calc(var(--space-unit) * 5);background-color:var(--color-surface-bg);z-index:10;display:flex;position:absolute;top:5px;height:40px}@media screen and (min-width: 992px){.bulk-actions{margin-left:calc(var(--space-unit) * 8.5)}}@media screen and (min-width: 1280px){.bulk-actions{margin-left:calc(var(--space-unit) * 10.5)}}.table-wrapper{display:block;overflow-y:hidden;overflow-x:auto;width:100%;max-width:var(--surface-width)}table{width:100%}table.no-select{-webkit-user-select:none;user-select:none}.column-picker{width:24px}.sort-toggle{display:flex;align-items:center;margin-left:calc(var(--space-unit) * .5)}.sort-toggle button{border:0;border-radius:var(--border-radius-lg);color:var(--color-weight-500);padding:0 2px;cursor:pointer;background-color:transparent}.sort-toggle button.active{color:var(--color-primary-700)}.sort-toggle .sort-label{margin-left:calc(var(--space-unit) * .5);font-size:10px;color:var(--color-primary-600);font-weight:400}.toggle-search-filter-row{position:absolute;top:-12px;left:4px}@media screen and (min-width: 1280px){.toggle-search-filter-row{left:8px}}.toggle-search-filter-row.active{background-color:var(--color-primary-700);color:var(--color-primary-100);border-color:var(--color-primary-700)}th.filter-row{position:relative;font-size:var(--font-size-base);font-weight:400;background-color:var(--color-weight-100);box-shadow:var(--data-table-filter-box-shadow);border-left-width:0;border-right-width:0;text-align:initial;padding:0}th.filter-row input{width:100%}th.filter-row.active{border-bottom:1px solid var(--color-weight-200)}th.filter-row .filters{margin-top:calc(var(--space-unit) * 1);display:flex;flex-wrap:wrap;gap:calc(var(--space-unit) * .5)}.filter-row-wrapper{padding:calc(var(--space-unit) * 4);padding-left:0;max-height:150px;transition:max-height .2s,padding .2s,opacity .2s}.filter-row-wrapper.hidden{max-height:0px;padding-top:0;padding-bottom:0;overflow:hidden;opacity:0}.cell-link{display:block;width:100%;height:100%}td.active{background-color:var(--color-table-row-active-bg)}.cell-content{display:flex;align-items:center;line-height:var(--font-size-sm);color:var(--color-weight-700)}.cell-content.left{justify-content:flex-start}.cell-content.center{justify-content:center}.cell-content.right{justify-content:flex-end}.selection-col{width:calc(var(--space-unit) * 8)}vdr-empty-placeholder{width:100%}.table-footer{display:flex;align-items:baseline;justify-content:space-between;margin-top:var(--space-unit);margin-left:var(--surface-margin-left);margin-right:var(--space-unit)}.total-items-count{font-size:var(--font-size-xs)}@container (max-width: 500px){.total-items-count{display:none}}\n"] }]
242
242
  }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.LocalStorageService }, { type: i2.DataService }]; }, propDecorators: { id: [{
243
243
  type: Input
244
244
  }], items: [{
@@ -278,4 +278,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.3", ngImpor
278
278
  type: ContentChildren,
279
279
  args: [TemplateRef]
280
280
  }] } });
281
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table2.component.js","sourceRoot":"","sources":["../../../../../../src/lib/core/src/shared/components/data-table-2/data-table2.component.ts","../../../../../../src/lib/core/src/shared/components/data-table-2/data-table2.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterContentInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChild,\n    ContentChildren,\n    EventEmitter,\n    Input,\n    OnChanges,\n    OnDestroy,\n    Output,\n    QueryList,\n    SimpleChanges,\n    TemplateRef,\n} from '@angular/core';\nimport { PaginationService } from 'ngx-pagination';\nimport { Observable, Subscription } from 'rxjs';\nimport { distinctUntilChanged, map } from 'rxjs/operators';\nimport { LanguageCode } from '../../../common/generated-types';\nimport { DataService } from '../../../data/providers/data.service';\nimport { DataTableFilterCollection } from '../../../providers/data-table/data-table-filter-collection';\nimport { DataTableConfig, LocalStorageService } from '../../../providers/local-storage/local-storage.service';\nimport { BulkActionMenuComponent } from '../bulk-action-menu/bulk-action-menu.component';\n\nimport { DataTable2ColumnComponent } from './data-table-column.component';\nimport { DataTableCustomFieldColumnComponent } from './data-table-custom-field-column.component';\nimport { DataTable2SearchComponent } from './data-table-search.component';\n\n/**\n * @description\n * A table for displaying PaginatedList results. It is designed to be used inside components which\n * extend the {@link BaseListComponent} or {@link TypedBaseListComponent} class.\n *\n * @example\n * ```HTML\n * <vdr-data-table-2\n *     id=\"product-review-list\"\n *     [items]=\"items$ | async\"\n *     [itemsPerPage]=\"itemsPerPage$ | async\"\n *     [totalItems]=\"totalItems$ | async\"\n *     [currentPage]=\"currentPage$ | async\"\n *     [filters]=\"filters\"\n *     (pageChange)=\"setPageNumber($event)\"\n *     (itemsPerPageChange)=\"setItemsPerPage($event)\"\n * >\n *     <vdr-bulk-action-menu\n *         locationId=\"product-review-list\"\n *         [hostComponent]=\"this\"\n *         [selectionManager]=\"selectionManager\"\n *     />\n *     <vdr-dt2-search\n *         [searchTermControl]=\"searchTermControl\"\n *         searchTermPlaceholder=\"Filter by title\"\n *     />\n *     <vdr-dt2-column [heading]=\"'common.id' | translate\" [hiddenByDefault]=\"true\">\n *         <ng-template let-review=\"item\">\n *             {{ review.id }}\n *         </ng-template>\n *     </vdr-dt2-column>\n *     <vdr-dt2-column\n *         [heading]=\"'common.created-at' | translate\"\n *         [hiddenByDefault]=\"true\"\n *         [sort]=\"sorts.get('createdAt')\"\n *     >\n *         <ng-template let-review=\"item\">\n *             {{ review.createdAt | localeDate : 'short' }}\n *         </ng-template>\n *     </vdr-dt2-column>\n *     <vdr-dt2-column\n *         [heading]=\"'common.updated-at' | translate\"\n *         [hiddenByDefault]=\"true\"\n *         [sort]=\"sorts.get('updatedAt')\"\n *     >\n *         <ng-template let-review=\"item\">\n *             {{ review.updatedAt | localeDate : 'short' }}\n *         </ng-template>\n *     </vdr-dt2-column>\n *     <vdr-dt2-column [heading]=\"'common.name' | translate\" [optional]=\"false\" [sort]=\"sorts.get('name')\">\n *         <ng-template let-review=\"item\">\n *             <a class=\"button-ghost\" [routerLink]=\"['./', review.id]\"\n *                 ><span>{{ review.name }}</span>\n *                 <clr-icon shape=\"arrow right\"></clr-icon>\n *             </a>\n *         </ng-template>\n *     </vdr-dt2-column>\n * </vdr-data-table-2>\n * ```\n *\n * @docsCategory components\n */\n@Component({\n    selector: 'vdr-data-table-2',\n    templateUrl: 'data-table2.component.html',\n    styleUrls: ['data-table2.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [PaginationService],\n})\nexport class DataTable2Component<T> implements AfterContentInit, OnChanges, OnDestroy {\n    @Input() id: string;\n    @Input() items: T[];\n    @Input() itemsPerPage: number;\n    @Input() currentPage: number;\n    @Input() totalItems: number;\n    @Input() emptyStateLabel: string;\n    @Input() filters: DataTableFilterCollection;\n    @Input() activeIndex = -1;\n    @Output() pageChange = new EventEmitter<number>();\n    @Output() itemsPerPageChange = new EventEmitter<number>();\n\n    @ContentChildren(DataTable2ColumnComponent) columns: QueryList<DataTable2ColumnComponent<T>>;\n    @ContentChildren(DataTableCustomFieldColumnComponent)\n    customFieldColumns: QueryList<DataTableCustomFieldColumnComponent<T>>;\n    @ContentChild(DataTable2SearchComponent) searchComponent: DataTable2SearchComponent;\n    @ContentChild(BulkActionMenuComponent) bulkActionMenuComponent: BulkActionMenuComponent;\n    @ContentChild('vdrDt2CustomSearch') customSearchTemplate: TemplateRef<any>;\n    @ContentChildren(TemplateRef) templateRefs: QueryList<TemplateRef<any>>;\n    rowTemplate: TemplateRef<any>;\n    currentStart: number;\n    currentEnd: number;\n    // This is used to apply a `user-select: none` CSS rule to the table,\n    // which allows shift-click multi-row selection\n    disableSelect = false;\n    showSearchFilterRow = false;\n    protected uiLanguage$: Observable<LanguageCode>;\n    private subscription: Subscription | undefined;\n\n    constructor(\n        protected changeDetectorRef: ChangeDetectorRef,\n        protected localStorageService: LocalStorageService,\n        protected dataService: DataService,\n    ) {\n        this.uiLanguage$ = this.dataService.client\n            .uiState()\n            .stream$.pipe(map(({ uiState }) => uiState.language));\n    }\n\n    get selectionManager() {\n        return this.bulkActionMenuComponent?.selectionManager;\n    }\n\n    get allColumns() {\n        return [...(this.columns ?? []), ...(this.customFieldColumns ?? [])];\n    }\n\n    get visibleSortedColumns() {\n        return this.sortedColumns.filter(c => c.visible);\n    }\n\n    get sortedColumns() {\n        const columns = this.allColumns;\n        const dataTableConfig = this.getDataTableConfig();\n        for (const [id, index] of Object.entries(dataTableConfig[this.id].order)) {\n            const column = columns.find(c => c.id === id);\n            const currentIndex = columns.findIndex(c => c.id === id);\n            if (currentIndex !== -1 && column) {\n                columns.splice(currentIndex, 1);\n                columns.splice(index, 0, column);\n            }\n        }\n        return columns;\n    }\n\n    private shiftDownHandler = (event: KeyboardEvent) => {\n        if (event.shiftKey && !this.disableSelect) {\n            this.disableSelect = true;\n            this.changeDetectorRef.markForCheck();\n        }\n    };\n\n    private shiftUpHandler = (event: KeyboardEvent) => {\n        if (this.disableSelect) {\n            this.disableSelect = false;\n            this.changeDetectorRef.markForCheck();\n        }\n    };\n\n    ngOnChanges(changes: SimpleChanges) {\n        if (changes.items) {\n            this.currentStart = this.itemsPerPage * (this.currentPage - 1);\n            this.currentEnd = this.currentStart + changes.items.currentValue?.length;\n            this.selectionManager?.setCurrentItems(this.items);\n        }\n    }\n\n    ngOnDestroy() {\n        if (this.selectionManager) {\n            document.removeEventListener('keydown', this.shiftDownHandler);\n            document.removeEventListener('keyup', this.shiftUpHandler);\n        }\n        this.subscription?.unsubscribe();\n    }\n\n    ngAfterContentInit(): void {\n        this.rowTemplate = this.templateRefs.last;\n        const dataTableConfig = this.localStorageService.get('dataTableConfig') ?? {};\n\n        if (!this.id) {\n            console.warn(`No id was assigned to the data table component`);\n        }\n        const updateColumnVisibility = () => {\n            if (!dataTableConfig[this.id]) {\n                dataTableConfig[this.id] = { visibility: [], order: {}, showSearchFilterRow: false };\n            }\n            dataTableConfig[this.id].visibility = this.allColumns\n                .filter(c => (c.visible && c.hiddenByDefault) || (!c.visible && !c.hiddenByDefault))\n                .map(c => c.id);\n            this.localStorageService.set('dataTableConfig', dataTableConfig);\n        };\n\n        this.allColumns.forEach(column => {\n            if (dataTableConfig?.[this.id]?.visibility.includes(column.id)) {\n                column.setVisibility(column.hiddenByDefault);\n            }\n            column.onColumnChange(updateColumnVisibility);\n        });\n\n        if (this.selectionManager) {\n            document.addEventListener('keydown', this.shiftDownHandler, { passive: true });\n            document.addEventListener('keyup', this.shiftUpHandler, { passive: true });\n            this.bulkActionMenuComponent.onClearSelection(() => {\n                this.changeDetectorRef.markForCheck();\n            });\n            this.selectionManager.setCurrentItems(this.items);\n        }\n        this.showSearchFilterRow = dataTableConfig?.[this.id]?.showSearchFilterRow ?? false;\n        this.columns.changes.subscribe(() => {\n            this.changeDetectorRef.markForCheck();\n        });\n\n        this.subscription = this.selectionManager?.selectionChanges$.subscribe(() =>\n            this.changeDetectorRef.markForCheck(),\n        );\n\n        if (this.selectionManager && this.subscription) {\n            const channelSub = this.dataService.client\n                .userStatus()\n                .mapStream(({ userStatus }) => userStatus.activeChannelId)\n                .pipe(distinctUntilChanged())\n                .subscribe(activeChannelId => {\n                    this.selectionManager?.clearSelection();\n                });\n            this.subscription?.add(channelSub);\n        }\n    }\n\n    onColumnReorder(event: { column: DataTable2ColumnComponent<any>; newIndex: number }) {\n        const naturalIndex = this.allColumns.findIndex(c => c.id === event.column.id);\n        const dataTableConfig = this.getDataTableConfig();\n        if (naturalIndex === event.newIndex) {\n            delete dataTableConfig[this.id].order[event.column.id];\n        } else {\n            dataTableConfig[this.id].order[event.column.id] = event.newIndex;\n        }\n        this.localStorageService.set('dataTableConfig', dataTableConfig);\n    }\n\n    onColumnsReset() {\n        const dataTableConfig = this.getDataTableConfig();\n        dataTableConfig[this.id].order = {};\n        dataTableConfig[this.id].visibility = [];\n        this.localStorageService.set('dataTableConfig', dataTableConfig);\n    }\n\n    toggleSearchFilterRow() {\n        this.showSearchFilterRow = !this.showSearchFilterRow;\n        const dataTableConfig = this.getDataTableConfig();\n        dataTableConfig[this.id].showSearchFilterRow = this.showSearchFilterRow;\n        this.localStorageService.set('dataTableConfig', dataTableConfig);\n    }\n\n    trackByFn(index: number, item: any) {\n        if ((item as any).id != null) {\n            return (item as any).id;\n        } else {\n            return index;\n        }\n    }\n\n    onToggleAllClick() {\n        this.selectionManager?.toggleSelectAll();\n    }\n\n    onRowClick(item: T, event: MouseEvent) {\n        this.selectionManager?.toggleSelection(item, event);\n    }\n\n    protected getDataTableConfig(): DataTableConfig {\n        const dataTableConfig = this.localStorageService.get('dataTableConfig') ?? {};\n        if (!dataTableConfig[this.id]) {\n            dataTableConfig[this.id] = { visibility: [], order: {}, showSearchFilterRow: false };\n        }\n        return dataTableConfig;\n    }\n}\n","<div class=\"bulk-actions\">\r\n    <ng-content select=\"vdr-bulk-action-menu\"></ng-content>\r\n</div>\r\n<div class=\"table-wrapper\">\r\n    <table\r\n        class=\"\"\r\n        [class.no-select]=\"disableSelect\"\r\n        [style.table-layout]=\"!items?.length ? 'fixed' : 'inherit'\"\r\n    >\r\n        <thead [class.items-selected]=\"selectionManager?.selection.length\">\r\n            <tr class=\"heading-row\">\r\n                <th *ngIf=\"selectionManager\" class=\"selection-col\">\r\n                    <input\r\n                        type=\"checkbox\"\r\n                        clrCheckbox\r\n                        [checked]=\"selectionManager?.areAllCurrentItemsSelected()\"\r\n                        (change)=\"onToggleAllClick()\"\r\n                    />\r\n                </th>\r\n                <th\r\n                    *ngFor=\"let column of visibleSortedColumns; last as isLast\"\r\n                    [class.expand]=\"column.expand\"\r\n                >\r\n                    <div class=\"cell-content\" [ngClass]=\"column.align\">\r\n                        <span>{{ column.heading }}</span>\r\n                        <div *ngIf=\"column.sort as sort\" class=\"sort-toggle\">\r\n                            <button (click)=\"sort.toggleSortOrder()\" [class.active]=\"sort.sortOrder\">\r\n                                <clr-icon *ngIf=\"!sort.sortOrder\" shape=\"two-way-arrows left\"></clr-icon>\r\n                                <clr-icon *ngIf=\"sort.sortOrder === 'ASC'\" shape=\"arrow up\"></clr-icon>\r\n                                <clr-icon *ngIf=\"sort.sortOrder === 'DESC'\" shape=\"arrow down\"></clr-icon>\r\n                            </button>\r\n                            <div class=\"sort-label\" *ngIf=\"sort.sortOrder\">{{ sort.sortOrder }}</div>\r\n                        </div>\r\n                    </div>\r\n                </th>\r\n                <th>\r\n                    <div class=\"column-picker\">\r\n                        <vdr-data-table-colum-picker\r\n                            [uiLanguage]=\"uiLanguage$ | async\"\r\n                            [columns]=\"sortedColumns\"\r\n                            (reorder)=\"onColumnReorder($event)\"\r\n                            (resetColumns)=\"onColumnsReset()\"\r\n                        ></vdr-data-table-colum-picker>\r\n                    </div>\r\n                </th>\r\n            </tr>\r\n            <tr *ngIf=\"searchComponent || customSearchTemplate || filters?.length\">\r\n                <th\r\n                    [attr.colspan]=\"visibleSortedColumns.length + (selectionManager ? 2 : 1)\"\r\n                    class=\"filter-row\"\r\n                    [class.active]=\"showSearchFilterRow\"\r\n                >\r\n                    <button\r\n                        class=\"button-ghost toggle-search-filter-row\"\r\n                        [class.active]=\"showSearchFilterRow\"\r\n                        (click)=\"toggleSearchFilterRow()\"\r\n                        [title]=\"'common.search-and-filter-list' | translate\"\r\n                    >\r\n                        <clr-icon shape=\"search\"></clr-icon>\r\n                    </button>\r\n                    <div class=\"filter-row-wrapper\" [class.hidden]=\"!showSearchFilterRow\">\r\n                        <ng-container *ngTemplateOutlet=\"searchComponent?.template\"></ng-container>\r\n                        <ng-container *ngTemplateOutlet=\"customSearchTemplate\"></ng-container>\r\n                        <ng-container *ngIf=\"filters\">\r\n                            <div class=\"filters\">\r\n                                <vdr-data-table-filters\r\n                                    *ngFor=\"let activeFilter of filters.activeFilters\"\r\n                                    [filterWithValue]=\"activeFilter\"\r\n                                    [filters]=\"filters\"\r\n                                    class=\"mt-1\"\r\n                                ></vdr-data-table-filters>\r\n                                <vdr-data-table-filters\r\n                                    *ngIf=\"filters.length\"\r\n                                    [filters]=\"filters\"\r\n                                    class=\"mt-1\"\r\n                                ></vdr-data-table-filters>\r\n                            </div>\r\n                        </ng-container>\r\n                    </div>\r\n                </th>\r\n            </tr>\r\n        </thead>\r\n        <tbody>\r\n            <tr\r\n                *ngFor=\"\r\n                    let item of items\r\n                        | paginate\r\n                            : {\r\n                                  id: id,\r\n                                  itemsPerPage: itemsPerPage,\r\n                                  currentPage: currentPage,\r\n                                  totalItems: totalItems\r\n                              };\r\n                    index as i;\r\n                    trackBy: trackByFn\r\n                \"\r\n            >\r\n                <td *ngIf=\"selectionManager\" class=\"selection-col\" [class.active]=\"activeIndex === i\">\r\n                    <input\r\n                        type=\"checkbox\"\r\n                        clrCheckbox\r\n                        [checked]=\"selectionManager?.isSelected(item)\"\r\n                        (click)=\"onRowClick(item, $event)\"\r\n                    />\r\n                </td>\r\n                <td *ngFor=\"let column of visibleSortedColumns\" [class.active]=\"activeIndex === i\">\r\n                    <div class=\"cell-content\" [ngClass]=\"column.align\">\r\n                        <ng-container\r\n                            *ngTemplateOutlet=\"column.template; context: { item: item, index: i }\"\r\n                        ></ng-container>\r\n                    </div>\r\n                </td>\r\n                <td [class.active]=\"activeIndex === i\"><!-- column select --></td>\r\n            </tr>\r\n            <ng-container>\r\n                <tr *ngIf=\"!items?.length\">\r\n                    <td [attr.colspan]=\"visibleSortedColumns.length + (selectionManager ? 2 : 1)\">\r\n                        <vdr-empty-placeholder [emptyStateLabel]=\"emptyStateLabel\"></vdr-empty-placeholder>\r\n                    </td>\r\n                </tr>\r\n            </ng-container>\r\n        </tbody>\r\n    </table>\r\n</div>\r\n<div class=\"table-footer\">\r\n    <vdr-items-per-page-controls\r\n        *ngIf=\"totalItems\"\r\n        [itemsPerPage]=\"itemsPerPage\"\r\n        (itemsPerPageChange)=\"itemsPerPageChange.emit($event)\"\r\n    ></vdr-items-per-page-controls>\r\n    <div *ngIf=\"totalItems\" class=\"total-items-count\">\r\n        {{ 'common.total-items' | translate : { currentStart, currentEnd, totalItems } }}\r\n    </div>\r\n\r\n    <vdr-pagination-controls\r\n        *ngIf=\"totalItems\"\r\n        [id]=\"id\"\r\n        [currentPage]=\"currentPage\"\r\n        [itemsPerPage]=\"itemsPerPage\"\r\n        [totalItems]=\"totalItems\"\r\n        (pageChange)=\"pageChange.emit($event)\"\r\n    ></vdr-pagination-controls>\r\n</div>\r\n"]}
281
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table2.component.js","sourceRoot":"","sources":["../../../../../../src/lib/core/src/shared/components/data-table-2/data-table2.component.ts","../../../../../../src/lib/core/src/shared/components/data-table-2/data-table2.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterContentInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChild,\n    ContentChildren,\n    EventEmitter,\n    Input,\n    OnChanges,\n    OnDestroy,\n    Output,\n    QueryList,\n    SimpleChanges,\n    TemplateRef,\n} from '@angular/core';\nimport { PaginationService } from 'ngx-pagination';\nimport { Observable, Subscription } from 'rxjs';\nimport { distinctUntilChanged, map } from 'rxjs/operators';\nimport { LanguageCode } from '../../../common/generated-types';\nimport { DataService } from '../../../data/providers/data.service';\nimport { DataTableFilterCollection } from '../../../providers/data-table/data-table-filter-collection';\nimport { DataTableConfig, LocalStorageService } from '../../../providers/local-storage/local-storage.service';\nimport { BulkActionMenuComponent } from '../bulk-action-menu/bulk-action-menu.component';\n\nimport { DataTable2ColumnComponent } from './data-table-column.component';\nimport { DataTableCustomFieldColumnComponent } from './data-table-custom-field-column.component';\nimport { DataTable2SearchComponent } from './data-table-search.component';\n\n/**\n * @description\n * A table for displaying PaginatedList results. It is designed to be used inside components which\n * extend the {@link BaseListComponent} or {@link TypedBaseListComponent} class.\n *\n * @example\n * ```HTML\n * <vdr-data-table-2\n *     id=\"product-review-list\"\n *     [items]=\"items$ | async\"\n *     [itemsPerPage]=\"itemsPerPage$ | async\"\n *     [totalItems]=\"totalItems$ | async\"\n *     [currentPage]=\"currentPage$ | async\"\n *     [filters]=\"filters\"\n *     (pageChange)=\"setPageNumber($event)\"\n *     (itemsPerPageChange)=\"setItemsPerPage($event)\"\n * >\n *     <vdr-bulk-action-menu\n *         locationId=\"product-review-list\"\n *         [hostComponent]=\"this\"\n *         [selectionManager]=\"selectionManager\"\n *     />\n *     <vdr-dt2-search\n *         [searchTermControl]=\"searchTermControl\"\n *         searchTermPlaceholder=\"Filter by title\"\n *     />\n *     <vdr-dt2-column [heading]=\"'common.id' | translate\" [hiddenByDefault]=\"true\">\n *         <ng-template let-review=\"item\">\n *             {{ review.id }}\n *         </ng-template>\n *     </vdr-dt2-column>\n *     <vdr-dt2-column\n *         [heading]=\"'common.created-at' | translate\"\n *         [hiddenByDefault]=\"true\"\n *         [sort]=\"sorts.get('createdAt')\"\n *     >\n *         <ng-template let-review=\"item\">\n *             {{ review.createdAt | localeDate : 'short' }}\n *         </ng-template>\n *     </vdr-dt2-column>\n *     <vdr-dt2-column\n *         [heading]=\"'common.updated-at' | translate\"\n *         [hiddenByDefault]=\"true\"\n *         [sort]=\"sorts.get('updatedAt')\"\n *     >\n *         <ng-template let-review=\"item\">\n *             {{ review.updatedAt | localeDate : 'short' }}\n *         </ng-template>\n *     </vdr-dt2-column>\n *     <vdr-dt2-column [heading]=\"'common.name' | translate\" [optional]=\"false\" [sort]=\"sorts.get('name')\">\n *         <ng-template let-review=\"item\">\n *             <a class=\"button-ghost\" [routerLink]=\"['./', review.id]\"\n *                 ><span>{{ review.name }}</span>\n *                 <clr-icon shape=\"arrow right\"></clr-icon>\n *             </a>\n *         </ng-template>\n *     </vdr-dt2-column>\n * </vdr-data-table-2>\n * ```\n *\n * @docsCategory components\n */\n@Component({\n    selector: 'vdr-data-table-2',\n    templateUrl: 'data-table2.component.html',\n    styleUrls: ['data-table2.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [PaginationService],\n})\nexport class DataTable2Component<T> implements AfterContentInit, OnChanges, OnDestroy {\n    @Input() id: string;\n    @Input() items: T[];\n    @Input() itemsPerPage: number;\n    @Input() currentPage: number;\n    @Input() totalItems: number;\n    @Input() emptyStateLabel: string;\n    @Input() filters: DataTableFilterCollection;\n    @Input() activeIndex = -1;\n    @Output() pageChange = new EventEmitter<number>();\n    @Output() itemsPerPageChange = new EventEmitter<number>();\n\n    @ContentChildren(DataTable2ColumnComponent) columns: QueryList<DataTable2ColumnComponent<T>>;\n    @ContentChildren(DataTableCustomFieldColumnComponent)\n    customFieldColumns: QueryList<DataTableCustomFieldColumnComponent<T>>;\n    @ContentChild(DataTable2SearchComponent) searchComponent: DataTable2SearchComponent;\n    @ContentChild(BulkActionMenuComponent) bulkActionMenuComponent: BulkActionMenuComponent;\n    @ContentChild('vdrDt2CustomSearch') customSearchTemplate: TemplateRef<any>;\n    @ContentChildren(TemplateRef) templateRefs: QueryList<TemplateRef<any>>;\n    rowTemplate: TemplateRef<any>;\n    currentStart: number;\n    currentEnd: number;\n    // This is used to apply a `user-select: none` CSS rule to the table,\n    // which allows shift-click multi-row selection\n    disableSelect = false;\n    showSearchFilterRow = false;\n    protected uiLanguage$: Observable<LanguageCode>;\n    private subscription: Subscription | undefined;\n\n    constructor(\n        protected changeDetectorRef: ChangeDetectorRef,\n        protected localStorageService: LocalStorageService,\n        protected dataService: DataService,\n    ) {\n        this.uiLanguage$ = this.dataService.client\n            .uiState()\n            .stream$.pipe(map(({ uiState }) => uiState.language));\n    }\n\n    get selectionManager() {\n        return this.bulkActionMenuComponent?.selectionManager;\n    }\n\n    get allColumns() {\n        return [...(this.columns ?? []), ...(this.customFieldColumns ?? [])];\n    }\n\n    get visibleSortedColumns() {\n        return this.sortedColumns.filter(c => c.visible);\n    }\n\n    get sortedColumns() {\n        const columns = this.allColumns;\n        const dataTableConfig = this.getDataTableConfig();\n        for (const [id, index] of Object.entries(dataTableConfig[this.id].order)) {\n            const column = columns.find(c => c.id === id);\n            const currentIndex = columns.findIndex(c => c.id === id);\n            if (currentIndex !== -1 && column) {\n                columns.splice(currentIndex, 1);\n                columns.splice(index, 0, column);\n            }\n        }\n        return columns;\n    }\n\n    private shiftDownHandler = (event: KeyboardEvent) => {\n        if (event.shiftKey && !this.disableSelect) {\n            this.disableSelect = true;\n            this.changeDetectorRef.markForCheck();\n        }\n    };\n\n    private shiftUpHandler = (event: KeyboardEvent) => {\n        if (this.disableSelect) {\n            this.disableSelect = false;\n            this.changeDetectorRef.markForCheck();\n        }\n    };\n\n    ngOnChanges(changes: SimpleChanges) {\n        if (changes.items) {\n            this.currentStart = this.itemsPerPage * (this.currentPage - 1);\n            this.currentEnd = this.currentStart + changes.items.currentValue?.length;\n            this.selectionManager?.setCurrentItems(this.items);\n        }\n    }\n\n    ngOnDestroy() {\n        if (this.selectionManager) {\n            document.removeEventListener('keydown', this.shiftDownHandler);\n            document.removeEventListener('keyup', this.shiftUpHandler);\n        }\n        this.subscription?.unsubscribe();\n    }\n\n    ngAfterContentInit(): void {\n        this.rowTemplate = this.templateRefs.last;\n        const dataTableConfig = this.localStorageService.get('dataTableConfig') ?? {};\n\n        if (!this.id) {\n            console.warn(`No id was assigned to the data table component`);\n        }\n        const updateColumnVisibility = () => {\n            if (!dataTableConfig[this.id]) {\n                dataTableConfig[this.id] = { visibility: [], order: {}, showSearchFilterRow: false };\n            }\n            dataTableConfig[this.id].visibility = this.allColumns\n                .filter(c => (c.visible && c.hiddenByDefault) || (!c.visible && !c.hiddenByDefault))\n                .map(c => c.id);\n            this.localStorageService.set('dataTableConfig', dataTableConfig);\n        };\n\n        this.allColumns.forEach(column => {\n            if (dataTableConfig?.[this.id]?.visibility.includes(column.id)) {\n                column.setVisibility(column.hiddenByDefault);\n            }\n            column.onColumnChange(updateColumnVisibility);\n        });\n\n        if (this.selectionManager) {\n            document.addEventListener('keydown', this.shiftDownHandler, { passive: true });\n            document.addEventListener('keyup', this.shiftUpHandler, { passive: true });\n            this.bulkActionMenuComponent.onClearSelection(() => {\n                this.changeDetectorRef.markForCheck();\n            });\n            this.selectionManager.setCurrentItems(this.items);\n        }\n        this.showSearchFilterRow = dataTableConfig?.[this.id]?.showSearchFilterRow ?? false;\n        this.columns.changes.subscribe(() => {\n            this.changeDetectorRef.markForCheck();\n        });\n\n        this.subscription = this.selectionManager?.selectionChanges$.subscribe(() =>\n            this.changeDetectorRef.markForCheck(),\n        );\n\n        if (this.selectionManager && this.subscription) {\n            const channelSub = this.dataService.client\n                .userStatus()\n                .mapStream(({ userStatus }) => userStatus.activeChannelId)\n                .pipe(distinctUntilChanged())\n                .subscribe(activeChannelId => {\n                    this.selectionManager?.clearSelection();\n                });\n            this.subscription?.add(channelSub);\n        }\n    }\n\n    onColumnReorder(event: { column: DataTable2ColumnComponent<any>; newIndex: number }) {\n        const naturalIndex = this.allColumns.findIndex(c => c.id === event.column.id);\n        const dataTableConfig = this.getDataTableConfig();\n        if (naturalIndex === event.newIndex) {\n            delete dataTableConfig[this.id].order[event.column.id];\n        } else {\n            dataTableConfig[this.id].order[event.column.id] = event.newIndex;\n        }\n        this.localStorageService.set('dataTableConfig', dataTableConfig);\n    }\n\n    onColumnsReset() {\n        const dataTableConfig = this.getDataTableConfig();\n        dataTableConfig[this.id].order = {};\n        dataTableConfig[this.id].visibility = [];\n        this.localStorageService.set('dataTableConfig', dataTableConfig);\n    }\n\n    toggleSearchFilterRow() {\n        this.showSearchFilterRow = !this.showSearchFilterRow;\n        const dataTableConfig = this.getDataTableConfig();\n        dataTableConfig[this.id].showSearchFilterRow = this.showSearchFilterRow;\n        this.localStorageService.set('dataTableConfig', dataTableConfig);\n    }\n\n    trackByFn(index: number, item: any) {\n        if ((item as any).id != null) {\n            return (item as any).id;\n        } else {\n            return index;\n        }\n    }\n\n    onToggleAllClick() {\n        this.selectionManager?.toggleSelectAll();\n    }\n\n    onRowClick(item: T, event: MouseEvent) {\n        this.selectionManager?.toggleSelection(item, event);\n    }\n\n    protected getDataTableConfig(): DataTableConfig {\n        const dataTableConfig = this.localStorageService.get('dataTableConfig') ?? {};\n        if (!dataTableConfig[this.id]) {\n            dataTableConfig[this.id] = { visibility: [], order: {}, showSearchFilterRow: false };\n        }\n        return dataTableConfig;\n    }\n}\n","<div class=\"bulk-actions\">\r\n    <ng-content select=\"vdr-bulk-action-menu\"></ng-content>\r\n</div>\r\n<div class=\"table-wrapper\">\r\n    <table\r\n        class=\"\"\r\n        [class.no-select]=\"disableSelect\"\r\n    >\r\n        <thead [class.items-selected]=\"selectionManager?.selection.length\">\r\n            <tr class=\"heading-row\">\r\n                <th *ngIf=\"selectionManager\" class=\"selection-col\">\r\n                    <input\r\n                        type=\"checkbox\"\r\n                        clrCheckbox\r\n                        [checked]=\"selectionManager?.areAllCurrentItemsSelected()\"\r\n                        (change)=\"onToggleAllClick()\"\r\n                    />\r\n                </th>\r\n                <th\r\n                    *ngFor=\"let column of visibleSortedColumns; last as isLast\"\r\n                    [class.expand]=\"column.expand\"\r\n                >\r\n                    <div class=\"cell-content\" [ngClass]=\"column.align\">\r\n                        <span>{{ column.heading }}</span>\r\n                        <div *ngIf=\"column.sort as sort\" class=\"sort-toggle\">\r\n                            <button (click)=\"sort.toggleSortOrder()\" [class.active]=\"sort.sortOrder\">\r\n                                <clr-icon *ngIf=\"!sort.sortOrder\" shape=\"two-way-arrows left\"></clr-icon>\r\n                                <clr-icon *ngIf=\"sort.sortOrder === 'ASC'\" shape=\"arrow up\"></clr-icon>\r\n                                <clr-icon *ngIf=\"sort.sortOrder === 'DESC'\" shape=\"arrow down\"></clr-icon>\r\n                            </button>\r\n                            <div class=\"sort-label\" *ngIf=\"sort.sortOrder\">{{ sort.sortOrder }}</div>\r\n                        </div>\r\n                    </div>\r\n                </th>\r\n                <th>\r\n                    <div class=\"column-picker\">\r\n                        <vdr-data-table-colum-picker\r\n                            [uiLanguage]=\"uiLanguage$ | async\"\r\n                            [columns]=\"sortedColumns\"\r\n                            (reorder)=\"onColumnReorder($event)\"\r\n                            (resetColumns)=\"onColumnsReset()\"\r\n                        ></vdr-data-table-colum-picker>\r\n                    </div>\r\n                </th>\r\n            </tr>\r\n            <tr *ngIf=\"searchComponent || customSearchTemplate || filters?.length\">\r\n                <th\r\n                    [attr.colspan]=\"visibleSortedColumns.length + (selectionManager ? 2 : 1)\"\r\n                    class=\"filter-row\"\r\n                    [class.active]=\"showSearchFilterRow\"\r\n                >\r\n                    <button\r\n                        class=\"button-ghost toggle-search-filter-row\"\r\n                        [class.active]=\"showSearchFilterRow\"\r\n                        (click)=\"toggleSearchFilterRow()\"\r\n                        [title]=\"'common.search-and-filter-list' | translate\"\r\n                    >\r\n                        <clr-icon shape=\"search\"></clr-icon>\r\n                    </button>\r\n                    <div class=\"filter-row-wrapper\" [class.hidden]=\"!showSearchFilterRow\">\r\n                        <ng-container *ngTemplateOutlet=\"searchComponent?.template\"></ng-container>\r\n                        <ng-container *ngTemplateOutlet=\"customSearchTemplate\"></ng-container>\r\n                        <ng-container *ngIf=\"filters\">\r\n                            <div class=\"filters\">\r\n                                <vdr-data-table-filters\r\n                                    *ngFor=\"let activeFilter of filters.activeFilters\"\r\n                                    [filterWithValue]=\"activeFilter\"\r\n                                    [filters]=\"filters\"\r\n                                    class=\"mt-1\"\r\n                                ></vdr-data-table-filters>\r\n                                <vdr-data-table-filters\r\n                                    *ngIf=\"filters.length\"\r\n                                    [filters]=\"filters\"\r\n                                    class=\"mt-1\"\r\n                                ></vdr-data-table-filters>\r\n                            </div>\r\n                        </ng-container>\r\n                    </div>\r\n                </th>\r\n            </tr>\r\n        </thead>\r\n        <tbody>\r\n            <tr\r\n                *ngFor=\"\r\n                    let item of items\r\n                        | paginate\r\n                            : {\r\n                                  id: id,\r\n                                  itemsPerPage: itemsPerPage,\r\n                                  currentPage: currentPage,\r\n                                  totalItems: totalItems\r\n                              };\r\n                    index as i;\r\n                    trackBy: trackByFn\r\n                \"\r\n            >\r\n                <td *ngIf=\"selectionManager\" class=\"selection-col\" [class.active]=\"activeIndex === i\">\r\n                    <input\r\n                        type=\"checkbox\"\r\n                        clrCheckbox\r\n                        [checked]=\"selectionManager?.isSelected(item)\"\r\n                        (click)=\"onRowClick(item, $event)\"\r\n                    />\r\n                </td>\r\n                <td *ngFor=\"let column of visibleSortedColumns\" [class.active]=\"activeIndex === i\">\r\n                    <div class=\"cell-content\" [ngClass]=\"column.align\">\r\n                        <ng-container\r\n                            *ngTemplateOutlet=\"column.template; context: { item: item, index: i }\"\r\n                        ></ng-container>\r\n                    </div>\r\n                </td>\r\n                <td [class.active]=\"activeIndex === i\"><!-- column select --></td>\r\n            </tr>\r\n            <ng-container>\r\n                <tr *ngIf=\"!items?.length\">\r\n                    <td [attr.colspan]=\"visibleSortedColumns.length + (selectionManager ? 2 : 1)\">\r\n                        <vdr-empty-placeholder [emptyStateLabel]=\"emptyStateLabel\"></vdr-empty-placeholder>\r\n                    </td>\r\n                </tr>\r\n            </ng-container>\r\n        </tbody>\r\n    </table>\r\n</div>\r\n<div class=\"table-footer\">\r\n    <vdr-items-per-page-controls\r\n        *ngIf=\"totalItems\"\r\n        [itemsPerPage]=\"itemsPerPage\"\r\n        (itemsPerPageChange)=\"itemsPerPageChange.emit($event)\"\r\n    ></vdr-items-per-page-controls>\r\n    <div *ngIf=\"totalItems\" class=\"total-items-count\">\r\n        {{ 'common.total-items' | translate : { currentStart, currentEnd, totalItems } }}\r\n    </div>\r\n\r\n    <vdr-pagination-controls\r\n        *ngIf=\"totalItems\"\r\n        [id]=\"id\"\r\n        [currentPage]=\"currentPage\"\r\n        [itemsPerPage]=\"itemsPerPage\"\r\n        [totalItems]=\"totalItems\"\r\n        (pageChange)=\"pageChange.emit($event)\"\r\n    ></vdr-pagination-controls>\r\n</div>\r\n"]}