@vendure/admin-ui 3.0.5 → 3.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.
- package/core/common/version.d.ts +1 -1
- package/core/shared/components/product-variant-selector/product-variant-selector.component.d.ts +1 -1
- package/esm2022/catalog/components/collection-data-table/collection-data-table.component.mjs +1 -1
- package/esm2022/catalog/components/collection-list/collection-list.component.mjs +1 -1
- package/esm2022/catalog/components/facet-list/facet-list.component.mjs +11 -11
- package/esm2022/catalog/components/product-list/product-list.component.mjs +1 -1
- package/esm2022/catalog/components/product-variant-quick-jump/product-variant-quick-jump.component.mjs +2 -2
- package/esm2022/core/common/base-list.component.mjs +1 -1
- package/esm2022/core/common/version.mjs +2 -2
- package/esm2022/core/data/data.module.mjs +1 -1
- package/esm2022/core/data/providers/base-data.service.mjs +1 -1
- package/esm2022/core/data/providers/collection-data.service.mjs +1 -1
- package/esm2022/core/data/providers/data.service.mjs +1 -1
- package/esm2022/core/data/providers/product-data.service.mjs +1 -1
- package/esm2022/core/data/utils/add-custom-fields.mjs +1 -1
- package/esm2022/core/providers/data-table/data-table-config.service.mjs +1 -1
- package/esm2022/core/shared/components/data-table-2/data-table2.component.mjs +1 -1
- package/esm2022/core/shared/components/data-table-filter-presets/filter-preset.service.mjs +1 -1
- package/esm2022/core/shared/components/product-multi-selector-dialog/product-multi-selector-dialog.component.mjs +2 -2
- package/esm2022/core/shared/components/product-variant-selector/product-variant-selector.component.mjs +2 -2
- package/esm2022/core/shared/dynamic-form-inputs/dynamic-form-input/dynamic-form-input.component.mjs +7 -1
- package/esm2022/customer/components/customer-group-list/customer-group-list.component.mjs +11 -11
- package/esm2022/customer/components/customer-list/customer-list.component.mjs +24 -24
- package/esm2022/marketing/components/promotion-list/promotion-list.component.mjs +11 -11
- package/esm2022/order/components/order-data-table/order-data-table.component.mjs +1 -1
- package/esm2022/order/components/order-list/order-list.component.mjs +1 -1
- package/esm2022/order/components/refund-order-dialog/refund-order-dialog.component.mjs +3 -3
- package/esm2022/order/order.routes.mjs +1 -2
- package/esm2022/settings/components/administrator-list/administrator-list.component.mjs +30 -30
- package/esm2022/settings/components/channel-list/channel-list.component.mjs +11 -11
- package/esm2022/settings/components/country-list/country-list.component.mjs +19 -19
- package/esm2022/settings/components/payment-method-list/payment-method-list.component.mjs +19 -19
- package/esm2022/settings/components/role-list/role-list.component.mjs +11 -11
- package/esm2022/settings/components/seller-list/seller-list.component.mjs +16 -16
- package/esm2022/settings/components/shipping-method-list/shipping-method-list.component.mjs +19 -19
- package/esm2022/settings/components/stock-location-list/stock-location-list.component.mjs +17 -17
- package/esm2022/settings/components/tax-category-list/tax-category-list.component.mjs +11 -11
- package/esm2022/settings/components/tax-rate-list/tax-rate-list.component.mjs +11 -11
- package/esm2022/settings/components/zone-list/zone-list.component.mjs +16 -16
- package/fesm2022/vendure-admin-ui-catalog.mjs +11 -11
- package/fesm2022/vendure-admin-ui-catalog.mjs.map +1 -1
- package/fesm2022/vendure-admin-ui-core.mjs +10 -4
- package/fesm2022/vendure-admin-ui-core.mjs.map +1 -1
- package/fesm2022/vendure-admin-ui-customer.mjs +33 -33
- package/fesm2022/vendure-admin-ui-customer.mjs.map +1 -1
- package/fesm2022/vendure-admin-ui-marketing.mjs +10 -10
- package/fesm2022/vendure-admin-ui-marketing.mjs.map +1 -1
- package/fesm2022/vendure-admin-ui-order.mjs +2 -3
- package/fesm2022/vendure-admin-ui-order.mjs.map +1 -1
- package/fesm2022/vendure-admin-ui-settings.mjs +169 -169
- package/fesm2022/vendure-admin-ui-settings.mjs.map +1 -1
- package/package.json +13 -13
- package/static/i18n-messages/sv.json +12 -12
|
@@ -297,4 +297,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
297
297
|
type: ContentChildren,
|
|
298
298
|
args: [TemplateRef]
|
|
299
299
|
}] } });
|
|
300
|
-
//# 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    inject,\n    Injector,\n    Input,\n    OnChanges,\n    OnDestroy,\n    Output,\n    QueryList,\n    SimpleChanges,\n    TemplateRef,\n} from '@angular/core';\nimport { ActivatedRoute } from '@angular/router';\nimport { PaginationService } from 'ngx-pagination';\nimport { Observable, Subject } from 'rxjs';\nimport { distinctUntilChanged, map, takeUntil } from 'rxjs/operators';\nimport { LanguageCode } from '../../../common/generated-types';\nimport { DataService } from '../../../data/providers/data.service';\nimport { DataTableConfigService } from '../../../providers/data-table/data-table-config.service';\nimport { DataTableFilterCollection } from '../../../providers/data-table/data-table-filter-collection';\nimport { BulkActionMenuComponent } from '../bulk-action-menu/bulk-action-menu.component';\n\nimport { FilterPresetService } from '../data-table-filter-presets/filter-preset.service';\nimport { DataTable2ColumnComponent } from './data-table-column.component';\nimport {\n    DataTableComponentConfig,\n    DataTableCustomComponentService,\n    DataTableLocationId,\n} from './data-table-custom-component.service';\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, FilterPresetService],\n})\nexport class DataTable2Component<T> implements AfterContentInit, OnChanges, OnDestroy {\n    @Input() id: DataTableLocationId;\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    @Output() visibleColumnsChange = new EventEmitter<Array<DataTable2ColumnComponent<T>>>();\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\n    injector = inject(Injector);\n    route = inject(ActivatedRoute);\n    filterPresetService = inject(FilterPresetService);\n    dataTableCustomComponentService = inject(DataTableCustomComponentService);\n    dataTableConfigService = inject(DataTableConfigService);\n    protected customComponents = new Map<string, { config: DataTableComponentConfig; injector: Injector }>();\n\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\n    protected uiLanguage$: Observable<LanguageCode>;\n    protected destroy$ = new Subject<void>();\n\n    constructor(\n        protected changeDetectorRef: ChangeDetectorRef,\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.dataTableConfigService.getConfig(this.id);\n        for (const [id, index] of Object.entries(dataTableConfig.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        this.destroy$.next();\n        this.destroy$.complete();\n        if (this.selectionManager) {\n            document.removeEventListener('keydown', this.shiftDownHandler);\n            document.removeEventListener('keyup', this.shiftUpHandler);\n        }\n    }\n\n    ngAfterContentInit(): void {\n        this.rowTemplate = this.templateRefs.last;\n        const dataTableConfig = this.dataTableConfigService.getConfig(this.id);\n\n        if (!this.id) {\n            console.warn(`No id was assigned to the data table component`);\n        }\n        const updateColumnVisibility = () => {\n            dataTableConfig.visibility = this.allColumns\n                .filter(c => (c.visible && c.hiddenByDefault) || (!c.visible && !c.hiddenByDefault))\n                .map(c => c.id);\n            this.dataTableConfigService.setConfig(this.id, dataTableConfig);\n            this.visibleColumnsChange.emit(this.visibleSortedColumns);\n        };\n\n        this.allColumns.forEach(column => {\n            if (dataTableConfig?.visibility.includes(column.id)) {\n                column.setVisibility(column.hiddenByDefault);\n            }\n            column.onColumnChange(updateColumnVisibility);\n            const config = this.dataTableCustomComponentService.getCustomComponentsFor(this.id, column.id);\n            if (config) {\n                const injector = Injector.create({\n                    parent: this.injector,\n                    providers: config.providers ?? [],\n                });\n                this.customComponents.set(column.id, { config, injector });\n            }\n        });\n        this.visibleColumnsChange.emit(this.visibleSortedColumns);\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 =\n            !!this.filters?.activeFilters.length || (dataTableConfig?.showSearchFilterRow ?? false);\n        this.columns.changes.subscribe(() => {\n            this.changeDetectorRef.markForCheck();\n        });\n\n        this.selectionManager?.selectionChanges$\n            .pipe(takeUntil(this.destroy$))\n            .subscribe(() => this.changeDetectorRef.markForCheck());\n\n        if (this.selectionManager) {\n            this.dataService.client\n                .userStatus()\n                .mapStream(({ userStatus }) => userStatus.activeChannelId)\n                .pipe(distinctUntilChanged(), takeUntil(this.destroy$))\n                .subscribe(() => {\n                    this.selectionManager?.clearSelection();\n                });\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.dataTableConfigService.getConfig(this.id);\n        if (naturalIndex === event.newIndex) {\n            delete dataTableConfig.order[event.column.id];\n        } else {\n            dataTableConfig.order[event.column.id] = event.newIndex;\n        }\n        this.dataTableConfigService.setConfig(this.id, dataTableConfig);\n    }\n\n    onColumnsReset() {\n        const dataTableConfig = this.dataTableConfigService.getConfig(this.id);\n        dataTableConfig.order = {};\n        dataTableConfig.visibility = [];\n        this.dataTableConfigService.setConfig(this.id, dataTableConfig);\n    }\n\n    toggleSearchFilterRow() {\n        this.showSearchFilterRow = !this.showSearchFilterRow;\n        const dataTableConfig = this.dataTableConfigService.getConfig(this.id);\n        dataTableConfig.showSearchFilterRow = this.showSearchFilterRow;\n        this.dataTableConfigService.setConfig(this.id, 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","<vdr-data-table-filter-presets\r\n    *ngIf=\"filters\"\r\n    [filters]=\"filters\"\r\n    [dataTableId]=\"id\"\r\n></vdr-data-table-filter-presets>\r\n<div class=\"table-wrapper\">\r\n    <div class=\"bulk-actions\">\r\n        <ng-content select=\"vdr-bulk-action-menu\"></ng-content>\r\n    </div>\r\n    <table class=\"\" [class.no-select]=\"disableSelect\">\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                        <vdr-ui-extension-point\r\n                            [locationId]=\"id\"\r\n                            [metadata]=\"column.id\"\r\n                            api=\"dataTable\"\r\n                            [topPx]=\"-6\"\r\n                            [leftPx]=\"-24\"\r\n                            display=\"block\"\r\n                        >\r\n                            <span>{{ column.heading }}</span>\r\n                        </vdr-ui-extension-point>\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                                <vdr-add-filter-preset-button\r\n                                    [filters]=\"filters\"\r\n                                    [dataTableId]=\"id\"\r\n                                ></vdr-add-filter-preset-button>\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                            *ngIf=\"customComponents.get(column.id) as componentConfig; else defaultComponent\"\r\n                        >\r\n                            <ng-container\r\n                                *ngComponentOutlet=\"\r\n                                    componentConfig.config.component;\r\n                                    inputs: { rowItem: item };\r\n                                    injector: componentConfig.injector\r\n                                \"\r\n                            ></ng-container>\r\n                        </ng-container>\r\n                        <ng-template #defaultComponent>\r\n                            <ng-container\r\n                                *ngTemplateOutlet=\"column.template; context: { item: item, index: i }\"\r\n                            ></ng-container>\r\n                        </ng-template>\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"]}
|
|
300
|
+
//# 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 {\r\n    AfterContentInit,\r\n    ChangeDetectionStrategy,\r\n    ChangeDetectorRef,\r\n    Component,\r\n    ContentChild,\r\n    ContentChildren,\r\n    EventEmitter,\r\n    inject,\r\n    Injector,\r\n    Input,\r\n    OnChanges,\r\n    OnDestroy,\r\n    Output,\r\n    QueryList,\r\n    SimpleChanges,\r\n    TemplateRef,\r\n} from '@angular/core';\r\nimport { ActivatedRoute } from '@angular/router';\r\nimport { PaginationService } from 'ngx-pagination';\r\nimport { Observable, Subject } from 'rxjs';\r\nimport { distinctUntilChanged, map, takeUntil } from 'rxjs/operators';\r\nimport { LanguageCode } from '../../../common/generated-types';\r\nimport { DataService } from '../../../data/providers/data.service';\r\nimport { DataTableConfigService } from '../../../providers/data-table/data-table-config.service';\r\nimport { DataTableFilterCollection } from '../../../providers/data-table/data-table-filter-collection';\r\nimport { BulkActionMenuComponent } from '../bulk-action-menu/bulk-action-menu.component';\r\n\r\nimport { FilterPresetService } from '../data-table-filter-presets/filter-preset.service';\r\nimport { DataTable2ColumnComponent } from './data-table-column.component';\r\nimport {\r\n    DataTableComponentConfig,\r\n    DataTableCustomComponentService,\r\n    DataTableLocationId,\r\n} from './data-table-custom-component.service';\r\nimport { DataTableCustomFieldColumnComponent } from './data-table-custom-field-column.component';\r\nimport { DataTable2SearchComponent } from './data-table-search.component';\r\n\r\n/**\r\n * @description\r\n * A table for displaying PaginatedList results. It is designed to be used inside components which\r\n * extend the {@link BaseListComponent} or {@link TypedBaseListComponent} class.\r\n *\r\n * @example\r\n * ```html\r\n * <vdr-data-table-2\r\n *     id=\"product-review-list\"\r\n *     [items]=\"items$ | async\"\r\n *     [itemsPerPage]=\"itemsPerPage$ | async\"\r\n *     [totalItems]=\"totalItems$ | async\"\r\n *     [currentPage]=\"currentPage$ | async\"\r\n *     [filters]=\"filters\"\r\n *     (pageChange)=\"setPageNumber($event)\"\r\n *     (itemsPerPageChange)=\"setItemsPerPage($event)\"\r\n * >\r\n *     <vdr-bulk-action-menu\r\n *         locationId=\"product-review-list\"\r\n *         [hostComponent]=\"this\"\r\n *         [selectionManager]=\"selectionManager\"\r\n *     />\r\n *     <vdr-dt2-search\r\n *         [searchTermControl]=\"searchTermControl\"\r\n *         searchTermPlaceholder=\"Filter by title\"\r\n *     />\r\n *     <vdr-dt2-column [heading]=\"'common.id' | translate\" [hiddenByDefault]=\"true\">\r\n *         <ng-template let-review=\"item\">\r\n *             {{ review.id }}\r\n *         </ng-template>\r\n *     </vdr-dt2-column>\r\n *     <vdr-dt2-column\r\n *         [heading]=\"'common.created-at' | translate\"\r\n *         [hiddenByDefault]=\"true\"\r\n *         [sort]=\"sorts.get('createdAt')\"\r\n *     >\r\n *         <ng-template let-review=\"item\">\r\n *             {{ review.createdAt | localeDate : 'short' }}\r\n *         </ng-template>\r\n *     </vdr-dt2-column>\r\n *     <vdr-dt2-column\r\n *         [heading]=\"'common.updated-at' | translate\"\r\n *         [hiddenByDefault]=\"true\"\r\n *         [sort]=\"sorts.get('updatedAt')\"\r\n *     >\r\n *         <ng-template let-review=\"item\">\r\n *             {{ review.updatedAt | localeDate : 'short' }}\r\n *         </ng-template>\r\n *     </vdr-dt2-column>\r\n *     <vdr-dt2-column [heading]=\"'common.name' | translate\" [optional]=\"false\" [sort]=\"sorts.get('name')\">\r\n *         <ng-template let-review=\"item\">\r\n *             <a class=\"button-ghost\" [routerLink]=\"['./', review.id]\"\r\n *                 ><span>{{ review.name }}</span>\r\n *                 <clr-icon shape=\"arrow right\"></clr-icon>\r\n *             </a>\r\n *         </ng-template>\r\n *     </vdr-dt2-column>\r\n * </vdr-data-table-2>\r\n * ```\r\n *\r\n * @docsCategory components\r\n */\r\n@Component({\r\n    selector: 'vdr-data-table-2',\r\n    templateUrl: 'data-table2.component.html',\r\n    styleUrls: ['data-table2.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    providers: [PaginationService, FilterPresetService],\r\n})\r\nexport class DataTable2Component<T> implements AfterContentInit, OnChanges, OnDestroy {\r\n    @Input() id: DataTableLocationId;\r\n    @Input() items: T[];\r\n    @Input() itemsPerPage: number;\r\n    @Input() currentPage: number;\r\n    @Input() totalItems: number;\r\n    @Input() emptyStateLabel: string;\r\n    @Input() filters: DataTableFilterCollection;\r\n    @Input() activeIndex = -1;\r\n    @Output() pageChange = new EventEmitter<number>();\r\n    @Output() itemsPerPageChange = new EventEmitter<number>();\r\n    @Output() visibleColumnsChange = new EventEmitter<Array<DataTable2ColumnComponent<T>>>();\r\n\r\n    @ContentChildren(DataTable2ColumnComponent) columns: QueryList<DataTable2ColumnComponent<T>>;\r\n    @ContentChildren(DataTableCustomFieldColumnComponent)\r\n    customFieldColumns: QueryList<DataTableCustomFieldColumnComponent<T>>;\r\n    @ContentChild(DataTable2SearchComponent) searchComponent: DataTable2SearchComponent;\r\n    @ContentChild(BulkActionMenuComponent) bulkActionMenuComponent: BulkActionMenuComponent;\r\n    @ContentChild('vdrDt2CustomSearch') customSearchTemplate: TemplateRef<any>;\r\n    @ContentChildren(TemplateRef) templateRefs: QueryList<TemplateRef<any>>;\r\n\r\n    injector = inject(Injector);\r\n    route = inject(ActivatedRoute);\r\n    filterPresetService = inject(FilterPresetService);\r\n    dataTableCustomComponentService = inject(DataTableCustomComponentService);\r\n    dataTableConfigService = inject(DataTableConfigService);\r\n    protected customComponents = new Map<string, { config: DataTableComponentConfig; injector: Injector }>();\r\n\r\n    rowTemplate: TemplateRef<any>;\r\n    currentStart: number;\r\n    currentEnd: number;\r\n    // This is used to apply a `user-select: none` CSS rule to the table,\r\n    // which allows shift-click multi-row selection\r\n    disableSelect = false;\r\n    showSearchFilterRow = false;\r\n\r\n    protected uiLanguage$: Observable<LanguageCode>;\r\n    protected destroy$ = new Subject<void>();\r\n\r\n    constructor(\r\n        protected changeDetectorRef: ChangeDetectorRef,\r\n        protected dataService: DataService,\r\n    ) {\r\n        this.uiLanguage$ = this.dataService.client\r\n            .uiState()\r\n            .stream$.pipe(map(({ uiState }) => uiState.language));\r\n    }\r\n\r\n    get selectionManager() {\r\n        return this.bulkActionMenuComponent?.selectionManager;\r\n    }\r\n\r\n    get allColumns() {\r\n        return [...(this.columns ?? []), ...(this.customFieldColumns ?? [])];\r\n    }\r\n\r\n    get visibleSortedColumns() {\r\n        return this.sortedColumns.filter(c => c.visible);\r\n    }\r\n\r\n    get sortedColumns() {\r\n        const columns = this.allColumns;\r\n        const dataTableConfig = this.dataTableConfigService.getConfig(this.id);\r\n        for (const [id, index] of Object.entries(dataTableConfig.order)) {\r\n            const column = columns.find(c => c.id === id);\r\n            const currentIndex = columns.findIndex(c => c.id === id);\r\n            if (currentIndex !== -1 && column) {\r\n                columns.splice(currentIndex, 1);\r\n                columns.splice(index, 0, column);\r\n            }\r\n        }\r\n        return columns;\r\n    }\r\n\r\n    private shiftDownHandler = (event: KeyboardEvent) => {\r\n        if (event.shiftKey && !this.disableSelect) {\r\n            this.disableSelect = true;\r\n            this.changeDetectorRef.markForCheck();\r\n        }\r\n    };\r\n\r\n    private shiftUpHandler = (event: KeyboardEvent) => {\r\n        if (this.disableSelect) {\r\n            this.disableSelect = false;\r\n            this.changeDetectorRef.markForCheck();\r\n        }\r\n    };\r\n\r\n    ngOnChanges(changes: SimpleChanges) {\r\n        if (changes.items) {\r\n            this.currentStart = this.itemsPerPage * (this.currentPage - 1);\r\n            this.currentEnd = this.currentStart + changes.items.currentValue?.length;\r\n            this.selectionManager?.setCurrentItems(this.items);\r\n        }\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        this.destroy$.next();\r\n        this.destroy$.complete();\r\n        if (this.selectionManager) {\r\n            document.removeEventListener('keydown', this.shiftDownHandler);\r\n            document.removeEventListener('keyup', this.shiftUpHandler);\r\n        }\r\n    }\r\n\r\n    ngAfterContentInit(): void {\r\n        this.rowTemplate = this.templateRefs.last;\r\n        const dataTableConfig = this.dataTableConfigService.getConfig(this.id);\r\n\r\n        if (!this.id) {\r\n            console.warn(`No id was assigned to the data table component`);\r\n        }\r\n        const updateColumnVisibility = () => {\r\n            dataTableConfig.visibility = this.allColumns\r\n                .filter(c => (c.visible && c.hiddenByDefault) || (!c.visible && !c.hiddenByDefault))\r\n                .map(c => c.id);\r\n            this.dataTableConfigService.setConfig(this.id, dataTableConfig);\r\n            this.visibleColumnsChange.emit(this.visibleSortedColumns);\r\n        };\r\n\r\n        this.allColumns.forEach(column => {\r\n            if (dataTableConfig?.visibility.includes(column.id)) {\r\n                column.setVisibility(column.hiddenByDefault);\r\n            }\r\n            column.onColumnChange(updateColumnVisibility);\r\n            const config = this.dataTableCustomComponentService.getCustomComponentsFor(this.id, column.id);\r\n            if (config) {\r\n                const injector = Injector.create({\r\n                    parent: this.injector,\r\n                    providers: config.providers ?? [],\r\n                });\r\n                this.customComponents.set(column.id, { config, injector });\r\n            }\r\n        });\r\n        this.visibleColumnsChange.emit(this.visibleSortedColumns);\r\n\r\n        if (this.selectionManager) {\r\n            document.addEventListener('keydown', this.shiftDownHandler, { passive: true });\r\n            document.addEventListener('keyup', this.shiftUpHandler, { passive: true });\r\n            this.bulkActionMenuComponent.onClearSelection(() => {\r\n                this.changeDetectorRef.markForCheck();\r\n            });\r\n            this.selectionManager.setCurrentItems(this.items);\r\n        }\r\n        this.showSearchFilterRow =\r\n            !!this.filters?.activeFilters.length || (dataTableConfig?.showSearchFilterRow ?? false);\r\n        this.columns.changes.subscribe(() => {\r\n            this.changeDetectorRef.markForCheck();\r\n        });\r\n\r\n        this.selectionManager?.selectionChanges$\r\n            .pipe(takeUntil(this.destroy$))\r\n            .subscribe(() => this.changeDetectorRef.markForCheck());\r\n\r\n        if (this.selectionManager) {\r\n            this.dataService.client\r\n                .userStatus()\r\n                .mapStream(({ userStatus }) => userStatus.activeChannelId)\r\n                .pipe(distinctUntilChanged(), takeUntil(this.destroy$))\r\n                .subscribe(() => {\r\n                    this.selectionManager?.clearSelection();\r\n                });\r\n        }\r\n    }\r\n\r\n    onColumnReorder(event: { column: DataTable2ColumnComponent<any>; newIndex: number }) {\r\n        const naturalIndex = this.allColumns.findIndex(c => c.id === event.column.id);\r\n        const dataTableConfig = this.dataTableConfigService.getConfig(this.id);\r\n        if (naturalIndex === event.newIndex) {\r\n            delete dataTableConfig.order[event.column.id];\r\n        } else {\r\n            dataTableConfig.order[event.column.id] = event.newIndex;\r\n        }\r\n        this.dataTableConfigService.setConfig(this.id, dataTableConfig);\r\n    }\r\n\r\n    onColumnsReset() {\r\n        const dataTableConfig = this.dataTableConfigService.getConfig(this.id);\r\n        dataTableConfig.order = {};\r\n        dataTableConfig.visibility = [];\r\n        this.dataTableConfigService.setConfig(this.id, dataTableConfig);\r\n    }\r\n\r\n    toggleSearchFilterRow() {\r\n        this.showSearchFilterRow = !this.showSearchFilterRow;\r\n        const dataTableConfig = this.dataTableConfigService.getConfig(this.id);\r\n        dataTableConfig.showSearchFilterRow = this.showSearchFilterRow;\r\n        this.dataTableConfigService.setConfig(this.id, dataTableConfig);\r\n    }\r\n\r\n    trackByFn(index: number, item: any) {\r\n        if ((item as any).id != null) {\r\n            return (item as any).id;\r\n        } else {\r\n            return index;\r\n        }\r\n    }\r\n\r\n    onToggleAllClick() {\r\n        this.selectionManager?.toggleSelectAll();\r\n    }\r\n\r\n    onRowClick(item: T, event: MouseEvent) {\r\n        this.selectionManager?.toggleSelection(item, event);\r\n    }\r\n}\r\n","<vdr-data-table-filter-presets\r\n    *ngIf=\"filters\"\r\n    [filters]=\"filters\"\r\n    [dataTableId]=\"id\"\r\n></vdr-data-table-filter-presets>\r\n<div class=\"table-wrapper\">\r\n    <div class=\"bulk-actions\">\r\n        <ng-content select=\"vdr-bulk-action-menu\"></ng-content>\r\n    </div>\r\n    <table class=\"\" [class.no-select]=\"disableSelect\">\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                        <vdr-ui-extension-point\r\n                            [locationId]=\"id\"\r\n                            [metadata]=\"column.id\"\r\n                            api=\"dataTable\"\r\n                            [topPx]=\"-6\"\r\n                            [leftPx]=\"-24\"\r\n                            display=\"block\"\r\n                        >\r\n                            <span>{{ column.heading }}</span>\r\n                        </vdr-ui-extension-point>\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                                <vdr-add-filter-preset-button\r\n                                    [filters]=\"filters\"\r\n                                    [dataTableId]=\"id\"\r\n                                ></vdr-add-filter-preset-button>\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                            *ngIf=\"customComponents.get(column.id) as componentConfig; else defaultComponent\"\r\n                        >\r\n                            <ng-container\r\n                                *ngComponentOutlet=\"\r\n                                    componentConfig.config.component;\r\n                                    inputs: { rowItem: item };\r\n                                    injector: componentConfig.injector\r\n                                \"\r\n                            ></ng-container>\r\n                        </ng-container>\r\n                        <ng-template #defaultComponent>\r\n                            <ng-container\r\n                                *ngTemplateOutlet=\"column.template; context: { item: item, index: i }\"\r\n                            ></ng-container>\r\n                        </ng-template>\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"]}
|
|
@@ -64,4 +64,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
64
64
|
providedIn: 'root',
|
|
65
65
|
}]
|
|
66
66
|
}], ctorParameters: () => [{ type: i1.DataTableConfigService }] });
|
|
67
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
67
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLXByZXNldC5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL2xpYi9jb3JlL3NyYy9zaGFyZWQvY29tcG9uZW50cy9kYXRhLXRhYmxlLWZpbHRlci1wcmVzZXRzL2ZpbHRlci1wcmVzZXQuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDekQsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBQWMsT0FBTyxFQUFFLE1BQU0sTUFBTSxDQUFDOzs7QUFNM0MsTUFBTSxPQUFPLG1CQUFtQjtJQUk1QixZQUFvQixzQkFBOEM7UUFBOUMsMkJBQXNCLEdBQXRCLHNCQUFzQixDQUF3QjtRQUYxRCxtQkFBYyxHQUFHLElBQUksT0FBTyxFQUEwQyxDQUFDO1FBRzNFLElBQUksQ0FBQyxjQUFjLEdBQUcsSUFBSSxDQUFDLGNBQWMsQ0FBQyxZQUFZLEVBQUUsQ0FBQztJQUM3RCxDQUFDO0lBRUQsZ0JBQWdCLENBQUMsV0FBbUI7UUFDaEMsTUFBTSxlQUFlLEdBQUcsSUFBSSxDQUFDLHNCQUFzQixDQUFDLFNBQVMsQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUMzRSxPQUFPLGVBQWUsQ0FBQyxhQUFhLElBQUksRUFBRSxDQUFDO0lBQy9DLENBQUM7SUFFRCxnQkFBZ0IsQ0FBQyxNQUE0RDtRQUN6RSxNQUFNLGVBQWUsR0FBRyxJQUFJLENBQUMsc0JBQXNCLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUNsRixNQUFNLGFBQWEsR0FBRyxlQUFlLENBQUMsYUFBYSxJQUFJLEVBQUUsQ0FBQztRQUMxRCxNQUFNLFlBQVksR0FBRyxhQUFhLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLElBQUksS0FBSyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDckUsSUFBSSxZQUFZLEVBQUUsQ0FBQztZQUNmLFlBQVksQ0FBQyxLQUFLLEdBQUcsTUFBTSxDQUFDLEtBQUssQ0FBQztRQUN0QyxDQUFDO2FBQU0sQ0FBQztZQUNKLGFBQWEsQ0FBQyxJQUFJLENBQUM7Z0JBQ2YsSUFBSSxFQUFFLE1BQU0sQ0FBQyxJQUFJO2dCQUNqQixLQUFLLEVBQUUsTUFBTSxDQUFDLEtBQUs7YUFDdEIsQ0FBQyxDQUFDO1FBQ1AsQ0FBQztRQUNELGVBQWUsQ0FBQyxhQUFhLEdBQUcsYUFBYSxDQUFDO1FBQzlDLElBQUksQ0FBQyxzQkFBc0IsQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLFdBQVcsRUFBRSxlQUFlLENBQUMsQ0FBQztRQUMzRSxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsQ0FBQztJQUM1QyxDQUFDO0lBRUQsa0JBQWtCLENBQUMsTUFBNkM7UUFDNUQsTUFBTSxlQUFlLEdBQUcsSUFBSSxDQUFDLHNCQUFzQixDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsV0FBVyxDQUFDLENBQUM7UUFDbEYsZUFBZSxDQUFDLGFBQWEsR0FBRyxlQUFlLENBQUMsYUFBYSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxJQUFJLEtBQUssTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ2xHLElBQUksQ0FBQyxzQkFBc0IsQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLFdBQVcsRUFBRSxlQUFlLENBQUMsQ0FBQztRQUMzRSxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxlQUFlLENBQUMsYUFBYSxDQUFDLENBQUM7SUFDNUQsQ0FBQztJQUVELGNBQWMsQ0FBQyxXQUFtQixFQUFFLFNBQWlCLEVBQUUsT0FBZTtRQUNsRSxNQUFNLE9BQU8sR0FBRyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsV0FBVyxDQUFDLENBQUM7UUFDbkQsZUFBZSxDQUFDLE9BQU8sRUFBRSxTQUFTLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFDN0MsTUFBTSxlQUFlLEdBQUcsSUFBSSxDQUFDLHNCQUFzQixDQUFDLFNBQVMsQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUMzRSxlQUFlLENBQUMsYUFBYSxHQUFHLE9BQU8sQ0FBQztRQUN4QyxJQUFJLENBQUMsc0JBQXNCLENBQUMsU0FBUyxDQUFDLFdBQVcsRUFBRSxlQUFlLENBQUMsQ0FBQztRQUNwRSxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUN0QyxDQUFDO0lBRUQsa0JBQWtCLENBQUMsTUFBaUU7UUFDaEYsTUFBTSxlQUFlLEdBQUcsSUFBSSxDQUFDLHNCQUFzQixDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsV0FBVyxDQUFDLENBQUM7UUFDbEYsTUFBTSxhQUFhLEdBQUcsZUFBZSxDQUFDLGFBQWEsSUFBSSxFQUFFLENBQUM7UUFDMUQsTUFBTSxZQUFZLEdBQUcsYUFBYSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxJQUFJLEtBQUssTUFBTSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ3hFLElBQUksWUFBWSxFQUFFLENBQUM7WUFDZixZQUFZLENBQUMsSUFBSSxHQUFHLE1BQU0sQ0FBQyxPQUFPLENBQUM7WUFDbkMsZUFBZSxDQUFDLGFBQWEsR0FBRyxhQUFhLENBQUM7WUFDOUMsSUFBSSxDQUFDLHNCQUFzQixDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsV0FBVyxFQUFFLGVBQWUsQ0FBQyxDQUFDO1lBQzNFLElBQUksQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxDQUFDO1FBQzVDLENBQUM7SUFDTCxDQUFDOytHQXhEUSxtQkFBbUI7bUhBQW5CLG1CQUFtQixjQUZoQixNQUFNOzs0RkFFVCxtQkFBbUI7a0JBSC9CLFVBQVU7bUJBQUM7b0JBQ1IsVUFBVSxFQUFFLE1BQU07aUJBQ3JCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgbW92ZUl0ZW1JbkFycmF5IH0gZnJvbSAnQGFuZ3VsYXIvY2RrL2RyYWctZHJvcCc7XHJcbmltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgT2JzZXJ2YWJsZSwgU3ViamVjdCB9IGZyb20gJ3J4anMnO1xyXG5pbXBvcnQgeyBEYXRhVGFibGVDb25maWdTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vLi4vcHJvdmlkZXJzL2RhdGEtdGFibGUvZGF0YS10YWJsZS1jb25maWcuc2VydmljZSc7XHJcblxyXG5ASW5qZWN0YWJsZSh7XHJcbiAgICBwcm92aWRlZEluOiAncm9vdCcsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBGaWx0ZXJQcmVzZXRTZXJ2aWNlIHtcclxuICAgIHByZXNldENoYW5nZXMkOiBPYnNlcnZhYmxlPEFycmF5PHsgbmFtZTogc3RyaW5nOyB2YWx1ZTogc3RyaW5nIH0+PjtcclxuICAgIHByaXZhdGUgX3ByZXNldENoYW5nZXMgPSBuZXcgU3ViamVjdDxBcnJheTx7IG5hbWU6IHN0cmluZzsgdmFsdWU6IHN0cmluZyB9Pj4oKTtcclxuXHJcbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIGRhdGFUYWJsZUNvbmZpZ1NlcnZpY2U6IERhdGFUYWJsZUNvbmZpZ1NlcnZpY2UpIHtcclxuICAgICAgICB0aGlzLnByZXNldENoYW5nZXMkID0gdGhpcy5fcHJlc2V0Q2hhbmdlcy5hc09ic2VydmFibGUoKTtcclxuICAgIH1cclxuXHJcbiAgICBnZXRGaWx0ZXJQcmVzZXRzKGRhdGFUYWJsZUlkOiBzdHJpbmcpOiBBcnJheTx7IG5hbWU6IHN0cmluZzsgdmFsdWU6IHN0cmluZyB9PiB7XHJcbiAgICAgICAgY29uc3QgZGF0YVRhYmxlQ29uZmlnID0gdGhpcy5kYXRhVGFibGVDb25maWdTZXJ2aWNlLmdldENvbmZpZyhkYXRhVGFibGVJZCk7XHJcbiAgICAgICAgcmV0dXJuIGRhdGFUYWJsZUNvbmZpZy5maWx0ZXJQcmVzZXRzID8/IFtdO1xyXG4gICAgfVxyXG5cclxuICAgIHNhdmVGaWx0ZXJQcmVzZXQoY29uZmlnOiB7IGRhdGFUYWJsZUlkOiBzdHJpbmc7IG5hbWU6IHN0cmluZzsgdmFsdWU6IHN0cmluZyB9KSB7XHJcbiAgICAgICAgY29uc3QgZGF0YVRhYmxlQ29uZmlnID0gdGhpcy5kYXRhVGFibGVDb25maWdTZXJ2aWNlLmdldENvbmZpZyhjb25maWcuZGF0YVRhYmxlSWQpO1xyXG4gICAgICAgIGNvbnN0IGZpbHRlclByZXNldHMgPSBkYXRhVGFibGVDb25maWcuZmlsdGVyUHJlc2V0cyA/PyBbXTtcclxuICAgICAgICBjb25zdCBleGlzdGluZ05hbWUgPSBmaWx0ZXJQcmVzZXRzLmZpbmQocCA9PiBwLm5hbWUgPT09IGNvbmZpZy5uYW1lKTtcclxuICAgICAgICBpZiAoZXhpc3RpbmdOYW1lKSB7XHJcbiAgICAgICAgICAgIGV4aXN0aW5nTmFtZS52YWx1ZSA9IGNvbmZpZy52YWx1ZTtcclxuICAgICAgICB9IGVsc2Uge1xyXG4gICAgICAgICAgICBmaWx0ZXJQcmVzZXRzLnB1c2goe1xyXG4gICAgICAgICAgICAgICAgbmFtZTogY29uZmlnLm5hbWUsXHJcbiAgICAgICAgICAgICAgICB2YWx1ZTogY29uZmlnLnZhbHVlLFxyXG4gICAgICAgICAgICB9KTtcclxuICAgICAgICB9XHJcbiAgICAgICAgZGF0YVRhYmxlQ29uZmlnLmZpbHRlclByZXNldHMgPSBmaWx0ZXJQcmVzZXRzO1xyXG4gICAgICAgIHRoaXMuZGF0YVRhYmxlQ29uZmlnU2VydmljZS5zZXRDb25maWcoY29uZmlnLmRhdGFUYWJsZUlkLCBkYXRhVGFibGVDb25maWcpO1xyXG4gICAgICAgIHRoaXMuX3ByZXNldENoYW5nZXMubmV4dChmaWx0ZXJQcmVzZXRzKTtcclxuICAgIH1cclxuXHJcbiAgICBkZWxldGVGaWx0ZXJQcmVzZXQoY29uZmlnOiB7IGRhdGFUYWJsZUlkOiBzdHJpbmc7IG5hbWU6IHN0cmluZyB9KSB7XHJcbiAgICAgICAgY29uc3QgZGF0YVRhYmxlQ29uZmlnID0gdGhpcy5kYXRhVGFibGVDb25maWdTZXJ2aWNlLmdldENvbmZpZyhjb25maWcuZGF0YVRhYmxlSWQpO1xyXG4gICAgICAgIGRhdGFUYWJsZUNvbmZpZy5maWx0ZXJQcmVzZXRzID0gZGF0YVRhYmxlQ29uZmlnLmZpbHRlclByZXNldHMuZmlsdGVyKHAgPT4gcC5uYW1lICE9PSBjb25maWcubmFtZSk7XHJcbiAgICAgICAgdGhpcy5kYXRhVGFibGVDb25maWdTZXJ2aWNlLnNldENvbmZpZyhjb25maWcuZGF0YVRhYmxlSWQsIGRhdGFUYWJsZUNvbmZpZyk7XHJcbiAgICAgICAgdGhpcy5fcHJlc2V0Q2hhbmdlcy5uZXh0KGRhdGFUYWJsZUNvbmZpZy5maWx0ZXJQcmVzZXRzKTtcclxuICAgIH1cclxuXHJcbiAgICByZW9yZGVyUHJlc2V0cyhkYXRhVGFibGVJZDogc3RyaW5nLCBmcm9tSW5kZXg6IG51bWJlciwgdG9JbmRleDogbnVtYmVyKSB7XHJcbiAgICAgICAgY29uc3QgcHJlc2V0cyA9IHRoaXMuZ2V0RmlsdGVyUHJlc2V0cyhkYXRhVGFibGVJZCk7XHJcbiAgICAgICAgbW92ZUl0ZW1JbkFycmF5KHByZXNldHMsIGZyb21JbmRleCwgdG9JbmRleCk7XHJcbiAgICAgICAgY29uc3QgZGF0YVRhYmxlQ29uZmlnID0gdGhpcy5kYXRhVGFibGVDb25maWdTZXJ2aWNlLmdldENvbmZpZyhkYXRhVGFibGVJZCk7XHJcbiAgICAgICAgZGF0YVRhYmxlQ29uZmlnLmZpbHRlclByZXNldHMgPSBwcmVzZXRzO1xyXG4gICAgICAgIHRoaXMuZGF0YVRhYmxlQ29uZmlnU2VydmljZS5zZXRDb25maWcoZGF0YVRhYmxlSWQsIGRhdGFUYWJsZUNvbmZpZyk7XHJcbiAgICAgICAgdGhpcy5fcHJlc2V0Q2hhbmdlcy5uZXh0KHByZXNldHMpO1xyXG4gICAgfVxyXG5cclxuICAgIHJlbmFtZUZpbHRlclByZXNldChjb25maWc6IHsgZGF0YVRhYmxlSWQ6IHN0cmluZzsgb2xkTmFtZTogc3RyaW5nOyBuZXdOYW1lOiBzdHJpbmcgfSkge1xyXG4gICAgICAgIGNvbnN0IGRhdGFUYWJsZUNvbmZpZyA9IHRoaXMuZGF0YVRhYmxlQ29uZmlnU2VydmljZS5nZXRDb25maWcoY29uZmlnLmRhdGFUYWJsZUlkKTtcclxuICAgICAgICBjb25zdCBmaWx0ZXJQcmVzZXRzID0gZGF0YVRhYmxlQ29uZmlnLmZpbHRlclByZXNldHMgPz8gW107XHJcbiAgICAgICAgY29uc3QgZXhpc3RpbmdOYW1lID0gZmlsdGVyUHJlc2V0cy5maW5kKHAgPT4gcC5uYW1lID09PSBjb25maWcub2xkTmFtZSk7XHJcbiAgICAgICAgaWYgKGV4aXN0aW5nTmFtZSkge1xyXG4gICAgICAgICAgICBleGlzdGluZ05hbWUubmFtZSA9IGNvbmZpZy5uZXdOYW1lO1xyXG4gICAgICAgICAgICBkYXRhVGFibGVDb25maWcuZmlsdGVyUHJlc2V0cyA9IGZpbHRlclByZXNldHM7XHJcbiAgICAgICAgICAgIHRoaXMuZGF0YVRhYmxlQ29uZmlnU2VydmljZS5zZXRDb25maWcoY29uZmlnLmRhdGFUYWJsZUlkLCBkYXRhVGFibGVDb25maWcpO1xyXG4gICAgICAgICAgICB0aGlzLl9wcmVzZXRDaGFuZ2VzLm5leHQoZmlsdGVyUHJlc2V0cyk7XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG59XHJcbiJdfQ==
|
|
@@ -129,10 +129,10 @@ export class ProductMultiSelectorDialogComponent {
|
|
|
129
129
|
this.resolveWith();
|
|
130
130
|
}
|
|
131
131
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ProductMultiSelectorDialogComponent, deps: [{ token: i1.DataService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
132
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: ProductMultiSelectorDialogComponent, selector: "vdr-product-multi-selector-dialog", ngImport: i0, template: "<ng-template vdrDialogTitle>\r\n <div class=\"title-row\">\r\n <span *ngIf=\"mode === 'product'\">{{ 'common.select-products' | translate }}</span>\r\n <span *ngIf=\"mode === 'variant'\">{{ 'common.select-variants' | translate }}</span>\r\n </div>\r\n</ng-template>\r\n<vdr-product-search-input\r\n #productSearchInputComponent\r\n [facetValueResults]=\"facetValues$ | async\"\r\n (searchTermChange)=\"setSearchTerm($event)\"\r\n (facetValueChange)=\"setFacetValueIds($event)\"\r\n></vdr-product-search-input>\r\n<div class=\"flex-wrapper\">\r\n <div class=\"gallery\">\r\n <div\r\n class=\"card\"\r\n *ngFor=\"let item of (items$ | async) || [] | paginate: paginationConfig; trackBy: trackByFn\"\r\n (click)=\"toggleSelection(item, $event)\"\r\n [class.selected]=\"isSelected(item)\"\r\n >\r\n <div class=\"card-img\">\r\n <vdr-select-toggle\r\n [selected]=\"isSelected(item)\"\r\n [disabled]=\"true\"\r\n [hiddenWhenOff]=\"true\"\r\n ></vdr-select-toggle>\r\n <img\r\n [src]=\"\r\n (mode === 'product'\r\n ? item.productAsset\r\n : item.productVariantAsset || item.productAsset\r\n ) | assetPreview: 'thumb'\r\n \"\r\n />\r\n </div>\r\n <div class=\"detail\">\r\n <span [title]=\"mode === 'product' ? item.productName : item.productVariantName\">{{\r\n mode === 'product' ? item.productName : item.productVariantName\r\n }}</span>\r\n <div *ngIf=\"mode === 'product'\">\r\n <small>\r\n <span class=\"mr-1\">{{ 'common.slug' | translate }}:</span>\r\n <code>{{ item.slug }}</code>\r\n </small>\r\n </div>\r\n <div *ngIf=\"mode === 'variant'\"><small>{{ item.sku }}</small></div>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"selection\">\r\n <div class=\"m-2 flex center\">\r\n <div>\r\n {{ 'common.items-selected-count' | translate: { count: selectionManager.selection.length } }}\r\n </div>\r\n <div class=\"flex-spacer\"></div>\r\n <button class=\"btn btn-sm btn-link\" (click)=\"clearSelection()\">\r\n <cds-icon shape=\"times\"></cds-icon> {{ 'common.clear-selection' | translate }}\r\n </button>\r\n </div>\r\n <div class=\"selected-items\">\r\n <div *ngFor=\"let item of selectionManager.selection\" class=\"flex item-row\">\r\n <div class=\"\">{{ mode === 'product' ? item.productName : item.productVariantName }}</div>\r\n <div class=\"flex-spacer\"></div>\r\n <div>\r\n <button class=\"icon-button\" (click)=\"toggleSelection(item, $event)\">\r\n <cds-icon shape=\"times\"></cds-icon>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<div class=\"paging-controls\">\r\n <vdr-items-per-page-controls\r\n [itemsPerPage]=\"paginationConfig.itemsPerPage\"\r\n (itemsPerPageChange)=\"itemsPerPageChange($event)\"\r\n ></vdr-items-per-page-controls>\r\n\r\n <vdr-pagination-controls\r\n [currentPage]=\"paginationConfig.currentPage\"\r\n [itemsPerPage]=\"paginationConfig.itemsPerPage\"\r\n [totalItems]=\"paginationConfig.totalItems\"\r\n (pageChange)=\"pageChange($event)\"\r\n ></vdr-pagination-controls>\r\n</div>\r\n\r\n<ng-template vdrDialogButtons>\r\n <button type=\"button\" class=\"btn\" (click)=\"cancel()\">{{ 'common.cancel' | translate }}</button>\r\n <button\r\n type=\"submit\"\r\n (click)=\"select()\"\r\n class=\"btn btn-primary\"\r\n [disabled]=\"selectionManager.selection.length === 0\"\r\n >\r\n {{ 'common.select-items-with-count' | translate: { count: selectionManager.selection.length } }}\r\n </button>\r\n</ng-template>\r\n", styles: [":host{display:flex;flex-direction:column;flex-direction:1;height:70vh}.flex-wrapper{display:flex;overflow-y:hidden}.gallery{flex:1;display:grid;grid-template-columns:repeat(auto-fill,125px);grid-template-rows:repeat(auto-fill,200px);grid-gap:10px 20px;padding-inline-start:12px;padding-top:12px;padding-bottom:64px;overflow-y:auto}.gallery .card:hover{box-shadow:0 .125rem 0 0 var(--color-primary-500);border:1px solid var(--color-primary-500)}.detail{margin:0 3px;font-size:12px;line-height:.8rem}vdr-select-toggle{position:absolute;top:-12px;left:-12px}vdr-select-toggle ::ng-deep .toggle{box-shadow:0 5px 5px -4px #000000bf}.card.selected{box-shadow:0 .125rem 0 0 var(--color-primary-500);border:1px solid var(--color-primary-500)}.card.selected .selected-checkbox{opacity:1}.selection{width:23vw;max-width:400px;padding:6px;display:flex;flex-direction:column}.selection .selected-items{flex:1;overflow-y:auto}.selection .selected-items .item-row{padding-inline-start:3px}.selection .selected-items .item-row:hover{background-color:var(--color-component-bg-200)}.paging-controls{display:flex;align-items:center;justify-content:space-between}\n"], dependencies: [{ kind: "directive", type: i2.CdsIconCustomTag, selector: "cds-icon" }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.ItemsPerPageControlsComponent, selector: "vdr-items-per-page-controls", inputs: ["itemsPerPage"], outputs: ["itemsPerPageChange"] }, { kind: "component", type: i5.PaginationControlsComponent, selector: "vdr-pagination-controls", inputs: ["id", "currentPage", "itemsPerPage", "totalItems"], outputs: ["pageChange"] }, { kind: "directive", type: i6.DialogButtonsDirective, selector: "[vdrDialogButtons]" }, { kind: "directive", type: i7.DialogTitleDirective, selector: "[vdrDialogTitle]" }, { kind: "component", type: i8.SelectToggleComponent, selector: "vdr-select-toggle", inputs: ["size", "selected", "hiddenWhenOff", "disabled", "label"], outputs: ["selectedChange"] }, { kind: "component", type: i9.ProductSearchInputComponent, selector: "vdr-product-search-input", inputs: ["facetValueResults"], outputs: ["searchTermChange", "facetValueChange"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i10.PaginatePipe, name: "paginate" }, { kind: "pipe", type: i11.TranslatePipe, name: "translate" }, { kind: "pipe", type: i12.AssetPreviewPipe, name: "assetPreview" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
132
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: ProductMultiSelectorDialogComponent, selector: "vdr-product-multi-selector-dialog", ngImport: i0, template: "<ng-template vdrDialogTitle>\r\n <div class=\"title-row\">\r\n <span *ngIf=\"mode === 'product'\">{{ 'common.select-products' | translate }}</span>\r\n <span *ngIf=\"mode === 'variant'\">{{ 'common.select-variants' | translate }}</span>\r\n </div>\r\n</ng-template>\r\n<vdr-product-search-input\r\n #productSearchInputComponent\r\n [facetValueResults]=\"facetValues$ | async\"\r\n (searchTermChange)=\"setSearchTerm($event)\"\r\n (facetValueChange)=\"setFacetValueIds($event)\"\r\n></vdr-product-search-input>\r\n<div class=\"flex-wrapper\">\r\n <div class=\"gallery\">\r\n <div\r\n class=\"card\"\r\n *ngFor=\"let item of (items$ | async) || [] | paginate: paginationConfig; trackBy: trackByFn\"\r\n (click)=\"toggleSelection(item, $event)\"\r\n [class.selected]=\"isSelected(item)\"\r\n >\r\n <div class=\"card-img\">\r\n <vdr-select-toggle\r\n [selected]=\"isSelected(item)\"\r\n [disabled]=\"true\"\r\n [hiddenWhenOff]=\"true\"\r\n ></vdr-select-toggle>\r\n <img\r\n [src]=\"\r\n (mode === 'product'\r\n ? item.productAsset\r\n : item.productVariantAsset || item.productAsset\r\n ) | assetPreview: 'thumb'\r\n \"\r\n />\r\n </div>\r\n <div class=\"detail\">\r\n <span [title]=\"mode === 'product' ? item.productName : item.productVariantName\">{{\r\n mode === 'product' ? item.productName : item.productVariantName\r\n }}</span>\r\n <div *ngIf=\"mode === 'product'\">\r\n <small>\r\n <span class=\"mr-1\">{{ 'common.slug' | translate }}:</span>\r\n <code>{{ item.slug }}</code>\r\n </small>\r\n </div>\r\n <div *ngIf=\"mode === 'variant'\"><small>{{ item.sku }}</small></div>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"selection\">\r\n <div class=\"m-2 flex center\">\r\n <div>\r\n {{ 'common.items-selected-count' | translate: { count: selectionManager.selection.length } }}\r\n </div>\r\n <div class=\"flex-spacer\"></div>\r\n <button class=\"btn btn-sm btn-link\" (click)=\"clearSelection()\">\r\n <cds-icon shape=\"times\"></cds-icon> {{ 'common.clear-selection' | translate }}\r\n </button>\r\n </div>\r\n <div class=\"selected-items\">\r\n <div *ngFor=\"let item of selectionManager.selection\" class=\"flex item-row\">\r\n <div class=\"\">{{ mode === 'product' ? item.productName : item.productVariantName }}</div>\r\n <div class=\"flex-spacer\"></div>\r\n <div>\r\n <button class=\"icon-button\" (click)=\"toggleSelection(item, $event)\">\r\n <cds-icon shape=\"times\"></cds-icon>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<div class=\"paging-controls\">\r\n <vdr-items-per-page-controls\r\n [itemsPerPage]=\"paginationConfig.itemsPerPage\"\r\n (itemsPerPageChange)=\"itemsPerPageChange($event)\"\r\n ></vdr-items-per-page-controls>\r\n\r\n <vdr-pagination-controls\r\n [currentPage]=\"paginationConfig.currentPage\"\r\n [itemsPerPage]=\"paginationConfig.itemsPerPage\"\r\n [totalItems]=\"paginationConfig.totalItems\"\r\n (pageChange)=\"pageChange($event)\"\r\n ></vdr-pagination-controls>\r\n</div>\r\n\r\n<ng-template vdrDialogButtons>\r\n <button type=\"button\" class=\"btn\" (click)=\"cancel()\">{{ 'common.cancel' | translate }}</button>\r\n <button\r\n type=\"submit\"\r\n (click)=\"select()\"\r\n class=\"btn btn-primary\"\r\n [disabled]=\"selectionManager.selection.length === 0\"\r\n >\r\n {{ 'common.select-items-with-count' | translate: { count: selectionManager.selection.length } }}\r\n </button>\r\n</ng-template>\r\n", styles: [":host{display:flex;flex-direction:column;flex-direction:1;height:70vh}.flex-wrapper{display:flex;overflow-y:hidden}.gallery{flex:1;display:grid;grid-template-columns:repeat(auto-fill,125px);grid-template-rows:repeat(auto-fill,200px);grid-gap:10px 20px;padding-inline-start:12px;padding-top:12px;padding-bottom:64px;overflow-y:auto}.gallery .card:hover{box-shadow:0 .125rem 0 0 var(--color-primary-500);border:1px solid var(--color-primary-500)}.detail{margin:0 3px;font-size:12px;line-height:.8rem;color:var(--color-text-100)}vdr-select-toggle{position:absolute;top:-12px;left:-12px}vdr-select-toggle ::ng-deep .toggle{box-shadow:0 5px 5px -4px #000000bf}.card.selected{box-shadow:0 .125rem 0 0 var(--color-primary-500);border:1px solid var(--color-primary-500)}.card.selected .selected-checkbox{opacity:1}.selection{width:23vw;max-width:400px;padding:6px;display:flex;flex-direction:column}.selection .selected-items{flex:1;overflow-y:auto}.selection .selected-items .item-row{padding-inline-start:3px;color:var(--color-text-100)}.selection .selected-items .item-row:hover{background-color:var(--color-component-bg-200)}.paging-controls{display:flex;align-items:center;justify-content:space-between}\n"], dependencies: [{ kind: "directive", type: i2.CdsIconCustomTag, selector: "cds-icon" }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.ItemsPerPageControlsComponent, selector: "vdr-items-per-page-controls", inputs: ["itemsPerPage"], outputs: ["itemsPerPageChange"] }, { kind: "component", type: i5.PaginationControlsComponent, selector: "vdr-pagination-controls", inputs: ["id", "currentPage", "itemsPerPage", "totalItems"], outputs: ["pageChange"] }, { kind: "directive", type: i6.DialogButtonsDirective, selector: "[vdrDialogButtons]" }, { kind: "directive", type: i7.DialogTitleDirective, selector: "[vdrDialogTitle]" }, { kind: "component", type: i8.SelectToggleComponent, selector: "vdr-select-toggle", inputs: ["size", "selected", "hiddenWhenOff", "disabled", "label"], outputs: ["selectedChange"] }, { kind: "component", type: i9.ProductSearchInputComponent, selector: "vdr-product-search-input", inputs: ["facetValueResults"], outputs: ["searchTermChange", "facetValueChange"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i10.PaginatePipe, name: "paginate" }, { kind: "pipe", type: i11.TranslatePipe, name: "translate" }, { kind: "pipe", type: i12.AssetPreviewPipe, name: "assetPreview" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
133
133
|
}
|
|
134
134
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ProductMultiSelectorDialogComponent, decorators: [{
|
|
135
135
|
type: Component,
|
|
136
|
-
args: [{ selector: 'vdr-product-multi-selector-dialog', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-template vdrDialogTitle>\r\n <div class=\"title-row\">\r\n <span *ngIf=\"mode === 'product'\">{{ 'common.select-products' | translate }}</span>\r\n <span *ngIf=\"mode === 'variant'\">{{ 'common.select-variants' | translate }}</span>\r\n </div>\r\n</ng-template>\r\n<vdr-product-search-input\r\n #productSearchInputComponent\r\n [facetValueResults]=\"facetValues$ | async\"\r\n (searchTermChange)=\"setSearchTerm($event)\"\r\n (facetValueChange)=\"setFacetValueIds($event)\"\r\n></vdr-product-search-input>\r\n<div class=\"flex-wrapper\">\r\n <div class=\"gallery\">\r\n <div\r\n class=\"card\"\r\n *ngFor=\"let item of (items$ | async) || [] | paginate: paginationConfig; trackBy: trackByFn\"\r\n (click)=\"toggleSelection(item, $event)\"\r\n [class.selected]=\"isSelected(item)\"\r\n >\r\n <div class=\"card-img\">\r\n <vdr-select-toggle\r\n [selected]=\"isSelected(item)\"\r\n [disabled]=\"true\"\r\n [hiddenWhenOff]=\"true\"\r\n ></vdr-select-toggle>\r\n <img\r\n [src]=\"\r\n (mode === 'product'\r\n ? item.productAsset\r\n : item.productVariantAsset || item.productAsset\r\n ) | assetPreview: 'thumb'\r\n \"\r\n />\r\n </div>\r\n <div class=\"detail\">\r\n <span [title]=\"mode === 'product' ? item.productName : item.productVariantName\">{{\r\n mode === 'product' ? item.productName : item.productVariantName\r\n }}</span>\r\n <div *ngIf=\"mode === 'product'\">\r\n <small>\r\n <span class=\"mr-1\">{{ 'common.slug' | translate }}:</span>\r\n <code>{{ item.slug }}</code>\r\n </small>\r\n </div>\r\n <div *ngIf=\"mode === 'variant'\"><small>{{ item.sku }}</small></div>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"selection\">\r\n <div class=\"m-2 flex center\">\r\n <div>\r\n {{ 'common.items-selected-count' | translate: { count: selectionManager.selection.length } }}\r\n </div>\r\n <div class=\"flex-spacer\"></div>\r\n <button class=\"btn btn-sm btn-link\" (click)=\"clearSelection()\">\r\n <cds-icon shape=\"times\"></cds-icon> {{ 'common.clear-selection' | translate }}\r\n </button>\r\n </div>\r\n <div class=\"selected-items\">\r\n <div *ngFor=\"let item of selectionManager.selection\" class=\"flex item-row\">\r\n <div class=\"\">{{ mode === 'product' ? item.productName : item.productVariantName }}</div>\r\n <div class=\"flex-spacer\"></div>\r\n <div>\r\n <button class=\"icon-button\" (click)=\"toggleSelection(item, $event)\">\r\n <cds-icon shape=\"times\"></cds-icon>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<div class=\"paging-controls\">\r\n <vdr-items-per-page-controls\r\n [itemsPerPage]=\"paginationConfig.itemsPerPage\"\r\n (itemsPerPageChange)=\"itemsPerPageChange($event)\"\r\n ></vdr-items-per-page-controls>\r\n\r\n <vdr-pagination-controls\r\n [currentPage]=\"paginationConfig.currentPage\"\r\n [itemsPerPage]=\"paginationConfig.itemsPerPage\"\r\n [totalItems]=\"paginationConfig.totalItems\"\r\n (pageChange)=\"pageChange($event)\"\r\n ></vdr-pagination-controls>\r\n</div>\r\n\r\n<ng-template vdrDialogButtons>\r\n <button type=\"button\" class=\"btn\" (click)=\"cancel()\">{{ 'common.cancel' | translate }}</button>\r\n <button\r\n type=\"submit\"\r\n (click)=\"select()\"\r\n class=\"btn btn-primary\"\r\n [disabled]=\"selectionManager.selection.length === 0\"\r\n >\r\n {{ 'common.select-items-with-count' | translate: { count: selectionManager.selection.length } }}\r\n </button>\r\n</ng-template>\r\n", styles: [":host{display:flex;flex-direction:column;flex-direction:1;height:70vh}.flex-wrapper{display:flex;overflow-y:hidden}.gallery{flex:1;display:grid;grid-template-columns:repeat(auto-fill,125px);grid-template-rows:repeat(auto-fill,200px);grid-gap:10px 20px;padding-inline-start:12px;padding-top:12px;padding-bottom:64px;overflow-y:auto}.gallery .card:hover{box-shadow:0 .125rem 0 0 var(--color-primary-500);border:1px solid var(--color-primary-500)}.detail{margin:0 3px;font-size:12px;line-height:.8rem}vdr-select-toggle{position:absolute;top:-12px;left:-12px}vdr-select-toggle ::ng-deep .toggle{box-shadow:0 5px 5px -4px #000000bf}.card.selected{box-shadow:0 .125rem 0 0 var(--color-primary-500);border:1px solid var(--color-primary-500)}.card.selected .selected-checkbox{opacity:1}.selection{width:23vw;max-width:400px;padding:6px;display:flex;flex-direction:column}.selection .selected-items{flex:1;overflow-y:auto}.selection .selected-items .item-row{padding-inline-start:3px}.selection .selected-items .item-row:hover{background-color:var(--color-component-bg-200)}.paging-controls{display:flex;align-items:center;justify-content:space-between}\n"] }]
|
|
136
|
+
args: [{ selector: 'vdr-product-multi-selector-dialog', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-template vdrDialogTitle>\r\n <div class=\"title-row\">\r\n <span *ngIf=\"mode === 'product'\">{{ 'common.select-products' | translate }}</span>\r\n <span *ngIf=\"mode === 'variant'\">{{ 'common.select-variants' | translate }}</span>\r\n </div>\r\n</ng-template>\r\n<vdr-product-search-input\r\n #productSearchInputComponent\r\n [facetValueResults]=\"facetValues$ | async\"\r\n (searchTermChange)=\"setSearchTerm($event)\"\r\n (facetValueChange)=\"setFacetValueIds($event)\"\r\n></vdr-product-search-input>\r\n<div class=\"flex-wrapper\">\r\n <div class=\"gallery\">\r\n <div\r\n class=\"card\"\r\n *ngFor=\"let item of (items$ | async) || [] | paginate: paginationConfig; trackBy: trackByFn\"\r\n (click)=\"toggleSelection(item, $event)\"\r\n [class.selected]=\"isSelected(item)\"\r\n >\r\n <div class=\"card-img\">\r\n <vdr-select-toggle\r\n [selected]=\"isSelected(item)\"\r\n [disabled]=\"true\"\r\n [hiddenWhenOff]=\"true\"\r\n ></vdr-select-toggle>\r\n <img\r\n [src]=\"\r\n (mode === 'product'\r\n ? item.productAsset\r\n : item.productVariantAsset || item.productAsset\r\n ) | assetPreview: 'thumb'\r\n \"\r\n />\r\n </div>\r\n <div class=\"detail\">\r\n <span [title]=\"mode === 'product' ? item.productName : item.productVariantName\">{{\r\n mode === 'product' ? item.productName : item.productVariantName\r\n }}</span>\r\n <div *ngIf=\"mode === 'product'\">\r\n <small>\r\n <span class=\"mr-1\">{{ 'common.slug' | translate }}:</span>\r\n <code>{{ item.slug }}</code>\r\n </small>\r\n </div>\r\n <div *ngIf=\"mode === 'variant'\"><small>{{ item.sku }}</small></div>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"selection\">\r\n <div class=\"m-2 flex center\">\r\n <div>\r\n {{ 'common.items-selected-count' | translate: { count: selectionManager.selection.length } }}\r\n </div>\r\n <div class=\"flex-spacer\"></div>\r\n <button class=\"btn btn-sm btn-link\" (click)=\"clearSelection()\">\r\n <cds-icon shape=\"times\"></cds-icon> {{ 'common.clear-selection' | translate }}\r\n </button>\r\n </div>\r\n <div class=\"selected-items\">\r\n <div *ngFor=\"let item of selectionManager.selection\" class=\"flex item-row\">\r\n <div class=\"\">{{ mode === 'product' ? item.productName : item.productVariantName }}</div>\r\n <div class=\"flex-spacer\"></div>\r\n <div>\r\n <button class=\"icon-button\" (click)=\"toggleSelection(item, $event)\">\r\n <cds-icon shape=\"times\"></cds-icon>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<div class=\"paging-controls\">\r\n <vdr-items-per-page-controls\r\n [itemsPerPage]=\"paginationConfig.itemsPerPage\"\r\n (itemsPerPageChange)=\"itemsPerPageChange($event)\"\r\n ></vdr-items-per-page-controls>\r\n\r\n <vdr-pagination-controls\r\n [currentPage]=\"paginationConfig.currentPage\"\r\n [itemsPerPage]=\"paginationConfig.itemsPerPage\"\r\n [totalItems]=\"paginationConfig.totalItems\"\r\n (pageChange)=\"pageChange($event)\"\r\n ></vdr-pagination-controls>\r\n</div>\r\n\r\n<ng-template vdrDialogButtons>\r\n <button type=\"button\" class=\"btn\" (click)=\"cancel()\">{{ 'common.cancel' | translate }}</button>\r\n <button\r\n type=\"submit\"\r\n (click)=\"select()\"\r\n class=\"btn btn-primary\"\r\n [disabled]=\"selectionManager.selection.length === 0\"\r\n >\r\n {{ 'common.select-items-with-count' | translate: { count: selectionManager.selection.length } }}\r\n </button>\r\n</ng-template>\r\n", styles: [":host{display:flex;flex-direction:column;flex-direction:1;height:70vh}.flex-wrapper{display:flex;overflow-y:hidden}.gallery{flex:1;display:grid;grid-template-columns:repeat(auto-fill,125px);grid-template-rows:repeat(auto-fill,200px);grid-gap:10px 20px;padding-inline-start:12px;padding-top:12px;padding-bottom:64px;overflow-y:auto}.gallery .card:hover{box-shadow:0 .125rem 0 0 var(--color-primary-500);border:1px solid var(--color-primary-500)}.detail{margin:0 3px;font-size:12px;line-height:.8rem;color:var(--color-text-100)}vdr-select-toggle{position:absolute;top:-12px;left:-12px}vdr-select-toggle ::ng-deep .toggle{box-shadow:0 5px 5px -4px #000000bf}.card.selected{box-shadow:0 .125rem 0 0 var(--color-primary-500);border:1px solid var(--color-primary-500)}.card.selected .selected-checkbox{opacity:1}.selection{width:23vw;max-width:400px;padding:6px;display:flex;flex-direction:column}.selection .selected-items{flex:1;overflow-y:auto}.selection .selected-items .item-row{padding-inline-start:3px;color:var(--color-text-100)}.selection .selected-items .item-row:hover{background-color:var(--color-component-bg-200)}.paging-controls{display:flex;align-items:center;justify-content:space-between}\n"] }]
|
|
137
137
|
}], ctorParameters: () => [{ type: i1.DataService }, { type: i0.ChangeDetectorRef }] });
|
|
138
138
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"product-multi-selector-dialog.component.js","sourceRoot":"","sources":["../../../../../../src/lib/core/src/shared/components/product-multi-selector-dialog/product-multi-selector-dialog.component.ts","../../../../../../src/lib/core/src/shared/components/product-multi-selector-dialog/product-multi-selector-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, OnInit } from '@angular/core';\r\nimport { PaginationInstance } from 'ngx-pagination';\r\nimport { BehaviorSubject, combineLatest, Observable } from 'rxjs';\r\nimport { map, tap } from 'rxjs/operators';\r\n\r\nimport {\r\n    GetProductVariantsForMultiSelectorDocument,\r\n    SearchProductsQuery,\r\n} from '../../../common/generated-types';\r\nimport { SelectionManager } from '../../../common/utilities/selection-manager';\r\nimport { DataService } from '../../../data/providers/data.service';\r\nimport { Dialog } from '../../../providers/modal/modal.types';\r\n\r\nexport type SearchItem = SearchProductsQuery['search']['items'][number];\r\n\r\n@Component({\r\n    selector: 'vdr-product-multi-selector-dialog',\r\n    templateUrl: './product-multi-selector-dialog.component.html',\r\n    styleUrls: ['./product-multi-selector-dialog.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class ProductMultiSelectorDialogComponent implements OnInit, Dialog<SearchItem[]> {\r\n    mode: 'product' | 'variant' = 'product';\r\n    initialSelectionIds: string[] = [];\r\n    items$: Observable<SearchItem[]>;\r\n    facetValues$: Observable<SearchProductsQuery['search']['facetValues']>;\r\n    searchTerm$ = new BehaviorSubject<string>('');\r\n    searchFacetValueIds$ = new BehaviorSubject<string[]>([]);\r\n    paginationConfig: PaginationInstance = {\r\n        currentPage: 1,\r\n        itemsPerPage: 25,\r\n        totalItems: 1,\r\n    };\r\n    selectionManager: SelectionManager<SearchItem>;\r\n\r\n    resolveWith: (result?: SearchItem[]) => void;\r\n    private paginationConfig$ = new BehaviorSubject<PaginationInstance>(this.paginationConfig);\r\n\r\n    constructor(private dataService: DataService, private changeDetector: ChangeDetectorRef) {}\r\n\r\n    ngOnInit(): void {\r\n        const idFn =\r\n            this.mode === 'product'\r\n                ? (a: SearchItem, b: SearchItem) => a.productId === b.productId\r\n                : (a: SearchItem, b: SearchItem) => a.productVariantId === b.productVariantId;\r\n        this.selectionManager = new SelectionManager<SearchItem>({\r\n            multiSelect: true,\r\n            itemsAreEqual: idFn,\r\n            additiveMode: true,\r\n        });\r\n        const searchQueryResult = this.dataService.product.searchProducts(\r\n            '',\r\n            this.paginationConfig.itemsPerPage,\r\n            0,\r\n        );\r\n        const result$ = combineLatest(\r\n            this.searchTerm$,\r\n            this.searchFacetValueIds$,\r\n            this.paginationConfig$,\r\n        ).subscribe(([term, facetValueIds, pagination]) => {\r\n            const take = +pagination.itemsPerPage;\r\n            const skip = (pagination.currentPage - 1) * take;\r\n            return searchQueryResult.ref.refetch({\r\n                input: { skip, take, term, facetValueIds, groupByProduct: this.mode === 'product' },\r\n            });\r\n        });\r\n\r\n        this.items$ = searchQueryResult.stream$.pipe(\r\n            tap(data => {\r\n                this.paginationConfig.totalItems = data.search.totalItems;\r\n                this.selectionManager.setCurrentItems(data.search.items);\r\n            }),\r\n            map(data => data.search.items),\r\n        );\r\n\r\n        this.facetValues$ = searchQueryResult.stream$.pipe(map(data => data.search.facetValues));\r\n\r\n        if (this.initialSelectionIds.length) {\r\n            if (this.mode === 'product') {\r\n                this.dataService.product\r\n                    .getProducts({\r\n                        filter: {\r\n                            id: {\r\n                                in: this.initialSelectionIds,\r\n                            },\r\n                        },\r\n                    })\r\n                    .single$.subscribe(({ products }) => {\r\n                        this.selectionManager.selectMultiple(\r\n                            products.items.map(\r\n                                product =>\r\n                                    ({\r\n                                        productId: product.id,\r\n                                        productName: product.name,\r\n                                    } as SearchItem),\r\n                            ),\r\n                        );\r\n                        this.changeDetector.markForCheck();\r\n                    });\r\n            } else {\r\n                this.dataService\r\n                    .query(GetProductVariantsForMultiSelectorDocument, {\r\n                        options: {\r\n                            filter: {\r\n                                id: {\r\n                                    in: this.initialSelectionIds,\r\n                                },\r\n                            },\r\n                        },\r\n                    })\r\n                    .single$.subscribe(({ productVariants }) => {\r\n                        this.selectionManager.selectMultiple(\r\n                            productVariants.items.map(\r\n                                variant =>\r\n                                    ({\r\n                                        productVariantId: variant.id,\r\n                                        productVariantName: variant.name,\r\n                                    } as SearchItem),\r\n                            ),\r\n                        );\r\n                        this.changeDetector.markForCheck();\r\n                    });\r\n            }\r\n        }\r\n    }\r\n\r\n    trackByFn(index: number, item: SearchItem) {\r\n        return item.productId;\r\n    }\r\n\r\n    setSearchTerm(term: string) {\r\n        this.searchTerm$.next(term);\r\n    }\r\n    setFacetValueIds(ids: string[]) {\r\n        this.searchFacetValueIds$.next(ids);\r\n    }\r\n\r\n    toggleSelection(item: SearchItem, event: MouseEvent) {\r\n        this.selectionManager.toggleSelection(item, event);\r\n    }\r\n\r\n    clearSelection() {\r\n        this.selectionManager.selectMultiple([]);\r\n    }\r\n\r\n    isSelected(item: SearchItem) {\r\n        return this.selectionManager.isSelected(item);\r\n    }\r\n\r\n    entityInfoClick(event: MouseEvent) {\r\n        event.preventDefault();\r\n        event.stopPropagation();\r\n    }\r\n\r\n    pageChange(page: number) {\r\n        this.paginationConfig.currentPage = page;\r\n        this.paginationConfig$.next(this.paginationConfig);\r\n    }\r\n\r\n    itemsPerPageChange(itemsPerPage: number) {\r\n        this.paginationConfig.itemsPerPage = itemsPerPage;\r\n        this.paginationConfig$.next(this.paginationConfig);\r\n    }\r\n\r\n    select() {\r\n        this.resolveWith(this.selectionManager.selection);\r\n    }\r\n\r\n    cancel() {\r\n        this.resolveWith();\r\n    }\r\n}\r\n","<ng-template vdrDialogTitle>\r\n    <div class=\"title-row\">\r\n        <span *ngIf=\"mode === 'product'\">{{ 'common.select-products' | translate }}</span>\r\n        <span *ngIf=\"mode === 'variant'\">{{ 'common.select-variants' | translate }}</span>\r\n    </div>\r\n</ng-template>\r\n<vdr-product-search-input\r\n    #productSearchInputComponent\r\n    [facetValueResults]=\"facetValues$ | async\"\r\n    (searchTermChange)=\"setSearchTerm($event)\"\r\n    (facetValueChange)=\"setFacetValueIds($event)\"\r\n></vdr-product-search-input>\r\n<div class=\"flex-wrapper\">\r\n    <div class=\"gallery\">\r\n        <div\r\n            class=\"card\"\r\n            *ngFor=\"let item of (items$ | async) || [] | paginate: paginationConfig; trackBy: trackByFn\"\r\n            (click)=\"toggleSelection(item, $event)\"\r\n            [class.selected]=\"isSelected(item)\"\r\n        >\r\n            <div class=\"card-img\">\r\n                <vdr-select-toggle\r\n                    [selected]=\"isSelected(item)\"\r\n                    [disabled]=\"true\"\r\n                    [hiddenWhenOff]=\"true\"\r\n                ></vdr-select-toggle>\r\n                <img\r\n                    [src]=\"\r\n                        (mode === 'product'\r\n                            ? item.productAsset\r\n                            : item.productVariantAsset || item.productAsset\r\n                        ) | assetPreview: 'thumb'\r\n                    \"\r\n                />\r\n            </div>\r\n            <div class=\"detail\">\r\n                <span [title]=\"mode === 'product' ? item.productName : item.productVariantName\">{{\r\n                    mode === 'product' ? item.productName : item.productVariantName\r\n                }}</span>\r\n                <div *ngIf=\"mode === 'product'\">\r\n                    <small>\r\n                        <span class=\"mr-1\">{{ 'common.slug' | translate }}:</span>\r\n                        <code>{{ item.slug }}</code>\r\n                    </small>\r\n                </div>\r\n                <div *ngIf=\"mode === 'variant'\"><small>{{ item.sku }}</small></div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n    <div class=\"selection\">\r\n        <div class=\"m-2 flex center\">\r\n            <div>\r\n                {{ 'common.items-selected-count' | translate: { count: selectionManager.selection.length } }}\r\n            </div>\r\n            <div class=\"flex-spacer\"></div>\r\n            <button class=\"btn btn-sm btn-link\" (click)=\"clearSelection()\">\r\n                <cds-icon shape=\"times\"></cds-icon> {{ 'common.clear-selection' | translate }}\r\n            </button>\r\n        </div>\r\n        <div class=\"selected-items\">\r\n            <div *ngFor=\"let item of selectionManager.selection\" class=\"flex item-row\">\r\n                <div class=\"\">{{ mode === 'product' ? item.productName : item.productVariantName }}</div>\r\n                <div class=\"flex-spacer\"></div>\r\n                <div>\r\n                    <button class=\"icon-button\" (click)=\"toggleSelection(item, $event)\">\r\n                        <cds-icon shape=\"times\"></cds-icon>\r\n                    </button>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</div>\r\n\r\n<div class=\"paging-controls\">\r\n    <vdr-items-per-page-controls\r\n        [itemsPerPage]=\"paginationConfig.itemsPerPage\"\r\n        (itemsPerPageChange)=\"itemsPerPageChange($event)\"\r\n    ></vdr-items-per-page-controls>\r\n\r\n    <vdr-pagination-controls\r\n        [currentPage]=\"paginationConfig.currentPage\"\r\n        [itemsPerPage]=\"paginationConfig.itemsPerPage\"\r\n        [totalItems]=\"paginationConfig.totalItems\"\r\n        (pageChange)=\"pageChange($event)\"\r\n    ></vdr-pagination-controls>\r\n</div>\r\n\r\n<ng-template vdrDialogButtons>\r\n    <button type=\"button\" class=\"btn\" (click)=\"cancel()\">{{ 'common.cancel' | translate }}</button>\r\n    <button\r\n        type=\"submit\"\r\n        (click)=\"select()\"\r\n        class=\"btn btn-primary\"\r\n        [disabled]=\"selectionManager.selection.length === 0\"\r\n    >\r\n        {{ 'common.select-items-with-count' | translate: { count: selectionManager.selection.length } }}\r\n    </button>\r\n</ng-template>\r\n"]}
|
|
@@ -14,7 +14,7 @@ import * as i5 from "../../pipes/asset-preview.pipe";
|
|
|
14
14
|
* @example
|
|
15
15
|
* ```HTML
|
|
16
16
|
* <vdr-product-variant-selector
|
|
17
|
-
* (productSelected)="selectResult($event)"></vdr-product-selector>
|
|
17
|
+
* (productSelected)="selectResult($event)"></vdr-product-variant-selector>
|
|
18
18
|
* ```
|
|
19
19
|
*
|
|
20
20
|
* @docsCategory components
|
|
@@ -59,4 +59,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
59
59
|
type: ViewChild,
|
|
60
60
|
args: ['autoComplete', { static: true }]
|
|
61
61
|
}] } });
|
|
62
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdC12YXJpYW50LXNlbGVjdG9yLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29yZS9zcmMvc2hhcmVkL2NvbXBvbmVudHMvcHJvZHVjdC12YXJpYW50LXNlbGVjdG9yL3Byb2R1Y3QtdmFyaWFudC1zZWxlY3Rvci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvcmUvc3JjL3NoYXJlZC9jb21wb25lbnRzL3Byb2R1Y3QtdmFyaWFudC1zZWxlY3Rvci9wcm9kdWN0LXZhcmlhbnQtc2VsZWN0b3IuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQVUsTUFBTSxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUU1RyxPQUFPLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBYyxFQUFFLEVBQUUsT0FBTyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQzlELE9BQU8sRUFBRSxZQUFZLEVBQUUsb0JBQW9CLEVBQUUsS0FBSyxFQUFFLFNBQVMsRUFBRSxHQUFHLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7Ozs7OztBQUszRjs7Ozs7Ozs7Ozs7R0FXRztBQU9ILE1BQU0sT0FBTywrQkFBK0I7SUFReEMsWUFBb0IsV0FBd0I7UUFBeEIsZ0JBQVcsR0FBWCxXQUFXLENBQWE7UUFQNUMsaUJBQVksR0FBRyxJQUFJLE9BQU8sRUFBVSxDQUFDO1FBQ3JDLGtCQUFhLEdBQUcsS0FBSyxDQUFDO1FBRVosb0JBQWUsR0FBRyxJQUFJLFlBQVksRUFBeUQsQ0FBQztJQUl2RCxDQUFDO0lBRWhELFFBQVE7UUFDSixJQUFJLENBQUMsaUJBQWlCLEVBQUUsQ0FBQztJQUM3QixDQUFDO0lBRU8saUJBQWlCO1FBQ3JCLE1BQU0sWUFBWSxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUN2QyxZQUFZLENBQUMsR0FBRyxDQUFDLEVBQ2pCLG9CQUFvQixFQUFFLEVBQ3RCLEdBQUcsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDLENBQUMsRUFDdEMsU0FBUyxDQUFDLElBQUksQ0FBQyxFQUFFO1lBQ2IsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO2dCQUNSLE9BQU8sRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDO1lBQ2xCLENBQUM7WUFDRCxPQUFPLElBQUksQ0FBQyxXQUFXLENBQUMsT0FBTztpQkFDMUIscUJBQXFCLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FBQztpQkFDL0IsU0FBUyxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUNsRCxDQUFDLENBQUMsRUFDRixHQUFHLENBQUMsR0FBRyxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsYUFBYSxHQUFHLEtBQUssQ0FBQyxDQUFDLENBQzFDLENBQUM7UUFFRixNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztRQUNwRCxJQUFJLENBQUMsY0FBYyxHQUFHLE1BQU0sQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsS0FBSyxDQUFDLFlBQVksRUFBRSxNQUFNLENBQUMsQ0FBQyxDQUFDO0lBQ3RFLENBQUM7SUFFRCxZQUFZLENBQUMsT0FBK0Q7UUFDeEUsSUFBSSxPQUFPLEVBQUUsQ0FBQztZQUNWLElBQUksQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1lBQ25DLElBQUksQ0FBQyxRQUFRLENBQUMsVUFBVSxFQUFFLENBQUM7UUFDL0IsQ0FBQztJQUNMLENBQUM7K0dBdkNRLCtCQUErQjttR0FBL0IsK0JBQStCLDZPQzFCNUMsK25CQWtCQTs7NEZEUWEsK0JBQStCO2tCQU4zQyxTQUFTOytCQUNJLDhCQUE4QixtQkFHdkIsdUJBQXVCLENBQUMsTUFBTTtnRkFNckMsZUFBZTtzQkFBeEIsTUFBTTtnQkFHQyxRQUFRO3NCQURmLFNBQVM7dUJBQUMsY0FBYyxFQUFFLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgT25Jbml0LCBPdXRwdXQsIFZpZXdDaGlsZCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBOZ1NlbGVjdENvbXBvbmVudCB9IGZyb20gJ0BuZy1zZWxlY3Qvbmctc2VsZWN0JztcclxuaW1wb3J0IHsgY29uY2F0LCBtZXJnZSwgT2JzZXJ2YWJsZSwgb2YsIFN1YmplY3QgfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgZGVib3VuY2VUaW1lLCBkaXN0aW5jdFVudGlsQ2hhbmdlZCwgbWFwVG8sIHN3aXRjaE1hcCwgdGFwIH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xyXG5cclxuaW1wb3J0IHsgUHJvZHVjdFNlbGVjdG9yU2VhcmNoUXVlcnkgfSBmcm9tICcuLi8uLi8uLi9jb21tb24vZ2VuZXJhdGVkLXR5cGVzJztcclxuaW1wb3J0IHsgRGF0YVNlcnZpY2UgfSBmcm9tICcuLi8uLi8uLi9kYXRhL3Byb3ZpZGVycy9kYXRhLnNlcnZpY2UnO1xyXG5cclxuLyoqXHJcbiAqIEBkZXNjcmlwdGlvblxyXG4gKiBBIGNvbXBvbmVudCBmb3Igc2VsZWN0aW5nIHByb2R1Y3QgdmFyaWFudHMgdmlhIGFuIGF1dG9jb21wbGV0ZS1zdHlsZSBzZWxlY3QgaW5wdXQuXHJcbiAqXHJcbiAqIEBleGFtcGxlXHJcbiAqIGBgYEhUTUxcclxuICogPHZkci1wcm9kdWN0LXZhcmlhbnQtc2VsZWN0b3JcclxuICogICAocHJvZHVjdFNlbGVjdGVkKT1cInNlbGVjdFJlc3VsdCgkZXZlbnQpXCI+
|
|
62
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdC12YXJpYW50LXNlbGVjdG9yLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29yZS9zcmMvc2hhcmVkL2NvbXBvbmVudHMvcHJvZHVjdC12YXJpYW50LXNlbGVjdG9yL3Byb2R1Y3QtdmFyaWFudC1zZWxlY3Rvci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvcmUvc3JjL3NoYXJlZC9jb21wb25lbnRzL3Byb2R1Y3QtdmFyaWFudC1zZWxlY3Rvci9wcm9kdWN0LXZhcmlhbnQtc2VsZWN0b3IuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQVUsTUFBTSxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUU1RyxPQUFPLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBYyxFQUFFLEVBQUUsT0FBTyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQzlELE9BQU8sRUFBRSxZQUFZLEVBQUUsb0JBQW9CLEVBQUUsS0FBSyxFQUFFLFNBQVMsRUFBRSxHQUFHLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7Ozs7OztBQUszRjs7Ozs7Ozs7Ozs7R0FXRztBQU9ILE1BQU0sT0FBTywrQkFBK0I7SUFReEMsWUFBb0IsV0FBd0I7UUFBeEIsZ0JBQVcsR0FBWCxXQUFXLENBQWE7UUFQNUMsaUJBQVksR0FBRyxJQUFJLE9BQU8sRUFBVSxDQUFDO1FBQ3JDLGtCQUFhLEdBQUcsS0FBSyxDQUFDO1FBRVosb0JBQWUsR0FBRyxJQUFJLFlBQVksRUFBeUQsQ0FBQztJQUl2RCxDQUFDO0lBRWhELFFBQVE7UUFDSixJQUFJLENBQUMsaUJBQWlCLEVBQUUsQ0FBQztJQUM3QixDQUFDO0lBRU8saUJBQWlCO1FBQ3JCLE1BQU0sWUFBWSxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUN2QyxZQUFZLENBQUMsR0FBRyxDQUFDLEVBQ2pCLG9CQUFvQixFQUFFLEVBQ3RCLEdBQUcsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDLENBQUMsRUFDdEMsU0FBUyxDQUFDLElBQUksQ0FBQyxFQUFFO1lBQ2IsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO2dCQUNSLE9BQU8sRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDO1lBQ2xCLENBQUM7WUFDRCxPQUFPLElBQUksQ0FBQyxXQUFXLENBQUMsT0FBTztpQkFDMUIscUJBQXFCLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FBQztpQkFDL0IsU0FBUyxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUNsRCxDQUFDLENBQUMsRUFDRixHQUFHLENBQUMsR0FBRyxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsYUFBYSxHQUFHLEtBQUssQ0FBQyxDQUFDLENBQzFDLENBQUM7UUFFRixNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztRQUNwRCxJQUFJLENBQUMsY0FBYyxHQUFHLE1BQU0sQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsS0FBSyxDQUFDLFlBQVksRUFBRSxNQUFNLENBQUMsQ0FBQyxDQUFDO0lBQ3RFLENBQUM7SUFFRCxZQUFZLENBQUMsT0FBK0Q7UUFDeEUsSUFBSSxPQUFPLEVBQUUsQ0FBQztZQUNWLElBQUksQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1lBQ25DLElBQUksQ0FBQyxRQUFRLENBQUMsVUFBVSxFQUFFLENBQUM7UUFDL0IsQ0FBQztJQUNMLENBQUM7K0dBdkNRLCtCQUErQjttR0FBL0IsK0JBQStCLDZPQzFCNUMsK25CQWtCQTs7NEZEUWEsK0JBQStCO2tCQU4zQyxTQUFTOytCQUNJLDhCQUE4QixtQkFHdkIsdUJBQXVCLENBQUMsTUFBTTtnRkFNckMsZUFBZTtzQkFBeEIsTUFBTTtnQkFHQyxRQUFRO3NCQURmLFNBQVM7dUJBQUMsY0FBYyxFQUFFLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgT25Jbml0LCBPdXRwdXQsIFZpZXdDaGlsZCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBOZ1NlbGVjdENvbXBvbmVudCB9IGZyb20gJ0BuZy1zZWxlY3Qvbmctc2VsZWN0JztcclxuaW1wb3J0IHsgY29uY2F0LCBtZXJnZSwgT2JzZXJ2YWJsZSwgb2YsIFN1YmplY3QgfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgZGVib3VuY2VUaW1lLCBkaXN0aW5jdFVudGlsQ2hhbmdlZCwgbWFwVG8sIHN3aXRjaE1hcCwgdGFwIH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xyXG5cclxuaW1wb3J0IHsgUHJvZHVjdFNlbGVjdG9yU2VhcmNoUXVlcnkgfSBmcm9tICcuLi8uLi8uLi9jb21tb24vZ2VuZXJhdGVkLXR5cGVzJztcclxuaW1wb3J0IHsgRGF0YVNlcnZpY2UgfSBmcm9tICcuLi8uLi8uLi9kYXRhL3Byb3ZpZGVycy9kYXRhLnNlcnZpY2UnO1xyXG5cclxuLyoqXHJcbiAqIEBkZXNjcmlwdGlvblxyXG4gKiBBIGNvbXBvbmVudCBmb3Igc2VsZWN0aW5nIHByb2R1Y3QgdmFyaWFudHMgdmlhIGFuIGF1dG9jb21wbGV0ZS1zdHlsZSBzZWxlY3QgaW5wdXQuXHJcbiAqXHJcbiAqIEBleGFtcGxlXHJcbiAqIGBgYEhUTUxcclxuICogPHZkci1wcm9kdWN0LXZhcmlhbnQtc2VsZWN0b3JcclxuICogICAocHJvZHVjdFNlbGVjdGVkKT1cInNlbGVjdFJlc3VsdCgkZXZlbnQpXCI+PC92ZHItcHJvZHVjdC12YXJpYW50LXNlbGVjdG9yPlxyXG4gKiBgYGBcclxuICpcclxuICogQGRvY3NDYXRlZ29yeSBjb21wb25lbnRzXHJcbiAqL1xyXG5AQ29tcG9uZW50KHtcclxuICAgIHNlbGVjdG9yOiAndmRyLXByb2R1Y3QtdmFyaWFudC1zZWxlY3RvcicsXHJcbiAgICB0ZW1wbGF0ZVVybDogJy4vcHJvZHVjdC12YXJpYW50LXNlbGVjdG9yLmNvbXBvbmVudC5odG1sJyxcclxuICAgIHN0eWxlVXJsczogWycuL3Byb2R1Y3QtdmFyaWFudC1zZWxlY3Rvci5jb21wb25lbnQuc2NzcyddLFxyXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBQcm9kdWN0VmFyaWFudFNlbGVjdG9yQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcclxuICAgIHNlYXJjaElucHV0JCA9IG5ldyBTdWJqZWN0PHN0cmluZz4oKTtcclxuICAgIHNlYXJjaExvYWRpbmcgPSBmYWxzZTtcclxuICAgIHNlYXJjaFJlc3VsdHMkOiBPYnNlcnZhYmxlPFByb2R1Y3RTZWxlY3RvclNlYXJjaFF1ZXJ5WydzZWFyY2gnXVsnaXRlbXMnXT47XHJcbiAgICBAT3V0cHV0KCkgcHJvZHVjdFNlbGVjdGVkID0gbmV3IEV2ZW50RW1pdHRlcjxQcm9kdWN0U2VsZWN0b3JTZWFyY2hRdWVyeVsnc2VhcmNoJ11bJ2l0ZW1zJ11bbnVtYmVyXT4oKTtcclxuXHJcbiAgICBAVmlld0NoaWxkKCdhdXRvQ29tcGxldGUnLCB7IHN0YXRpYzogdHJ1ZSB9KVxyXG4gICAgcHJpdmF0ZSBuZ1NlbGVjdDogTmdTZWxlY3RDb21wb25lbnQ7XHJcbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIGRhdGFTZXJ2aWNlOiBEYXRhU2VydmljZSkge31cclxuXHJcbiAgICBuZ09uSW5pdCgpOiB2b2lkIHtcclxuICAgICAgICB0aGlzLmluaXRTZWFyY2hSZXN1bHRzKCk7XHJcbiAgICB9XHJcblxyXG4gICAgcHJpdmF0ZSBpbml0U2VhcmNoUmVzdWx0cygpIHtcclxuICAgICAgICBjb25zdCBzZWFyY2hJdGVtcyQgPSB0aGlzLnNlYXJjaElucHV0JC5waXBlKFxyXG4gICAgICAgICAgICBkZWJvdW5jZVRpbWUoMjAwKSxcclxuICAgICAgICAgICAgZGlzdGluY3RVbnRpbENoYW5nZWQoKSxcclxuICAgICAgICAgICAgdGFwKCgpID0+ICh0aGlzLnNlYXJjaExvYWRpbmcgPSB0cnVlKSksXHJcbiAgICAgICAgICAgIHN3aXRjaE1hcCh0ZXJtID0+IHtcclxuICAgICAgICAgICAgICAgIGlmICghdGVybSkge1xyXG4gICAgICAgICAgICAgICAgICAgIHJldHVybiBvZihbXSk7XHJcbiAgICAgICAgICAgICAgICB9XHJcbiAgICAgICAgICAgICAgICByZXR1cm4gdGhpcy5kYXRhU2VydmljZS5wcm9kdWN0XHJcbiAgICAgICAgICAgICAgICAgICAgLnByb2R1Y3RTZWxlY3RvclNlYXJjaCh0ZXJtLCAxMClcclxuICAgICAgICAgICAgICAgICAgICAubWFwU2luZ2xlKHJlc3VsdCA9PiByZXN1bHQuc2VhcmNoLml0ZW1zKTtcclxuICAgICAgICAgICAgfSksXHJcbiAgICAgICAgICAgIHRhcCgoKSA9PiAodGhpcy5zZWFyY2hMb2FkaW5nID0gZmFsc2UpKSxcclxuICAgICAgICApO1xyXG5cclxuICAgICAgICBjb25zdCBjbGVhciQgPSB0aGlzLnByb2R1Y3RTZWxlY3RlZC5waXBlKG1hcFRvKFtdKSk7XHJcbiAgICAgICAgdGhpcy5zZWFyY2hSZXN1bHRzJCA9IGNvbmNhdChvZihbXSksIG1lcmdlKHNlYXJjaEl0ZW1zJCwgY2xlYXIkKSk7XHJcbiAgICB9XHJcblxyXG4gICAgc2VsZWN0UmVzdWx0KHByb2R1Y3Q/OiBQcm9kdWN0U2VsZWN0b3JTZWFyY2hRdWVyeVsnc2VhcmNoJ11bJ2l0ZW1zJ11bbnVtYmVyXSkge1xyXG4gICAgICAgIGlmIChwcm9kdWN0KSB7XHJcbiAgICAgICAgICAgIHRoaXMucHJvZHVjdFNlbGVjdGVkLmVtaXQocHJvZHVjdCk7XHJcbiAgICAgICAgICAgIHRoaXMubmdTZWxlY3QuY2xlYXJNb2RlbCgpO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxufVxyXG4iLCI8bmctc2VsZWN0XHJcbiAgICAjYXV0b0NvbXBsZXRlXHJcbiAgICBbaXRlbXNdPVwic2VhcmNoUmVzdWx0cyQgfCBhc3luY1wiXHJcbiAgICBbYWRkVGFnXT1cImZhbHNlXCJcclxuICAgIFttdWx0aXBsZV09XCJmYWxzZVwiXHJcbiAgICBbaGlkZVNlbGVjdGVkXT1cInRydWVcIlxyXG4gICAgW2xvYWRpbmddPVwic2VhcmNoTG9hZGluZ1wiXHJcbiAgICBbdHlwZWFoZWFkXT1cInNlYXJjaElucHV0JFwiXHJcbiAgICBbYXBwZW5kVG9dPVwiJ2JvZHknXCJcclxuICAgIFtwbGFjZWhvbGRlcl09XCInc2V0dGluZ3Muc2VhcmNoLWJ5LXByb2R1Y3QtbmFtZS1vci1za3UnIHwgdHJhbnNsYXRlXCJcclxuICAgIChjaGFuZ2UpPVwic2VsZWN0UmVzdWx0KCRldmVudClcIlxyXG4+XHJcbiAgICA8bmctdGVtcGxhdGUgbmctb3B0aW9uLXRtcCBsZXQtaXRlbT1cIml0ZW1cIj5cclxuICAgICAgICA8aW1nIFtzcmNdPVwiaXRlbS5wcm9kdWN0QXNzZXQgfCBhc3NldFByZXZpZXc6IDMyXCI+XHJcbiAgICAgICAge3sgaXRlbS5wcm9kdWN0VmFyaWFudE5hbWUgfX1cclxuICAgICAgICA8c21hbGwgY2xhc3M9XCJza3VcIj57eyBpdGVtLnNrdSB9fTwvc21hbGw+XHJcbiAgICA8L25nLXRlbXBsYXRlPlxyXG48L25nLXNlbGVjdD5cclxuIl19
|
package/esm2022/core/shared/dynamic-form-inputs/dynamic-form-input/dynamic-form-input.component.mjs
CHANGED
|
@@ -107,6 +107,12 @@ export class DynamicFormInputComponent {
|
|
|
107
107
|
if (this.listItems) {
|
|
108
108
|
for (const item of this.listItems) {
|
|
109
109
|
if (item.componentRef) {
|
|
110
|
+
const { value } = item.control;
|
|
111
|
+
const { type } = item.componentRef.instance.config || {};
|
|
112
|
+
// fix a bug where the list item of string turns into number which lead to unexpected behavior
|
|
113
|
+
if (typeof value === 'number' && type === 'string') {
|
|
114
|
+
item.control.setValue(item.control.value.toString(), { emitEvent: false });
|
|
115
|
+
}
|
|
110
116
|
this.updateBindings(changes, item.componentRef);
|
|
111
117
|
}
|
|
112
118
|
}
|
|
@@ -268,4 +274,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
268
274
|
type: ViewChildren,
|
|
269
275
|
args: ['listItem', { read: ViewContainerRef }]
|
|
270
276
|
}] } });
|
|
271
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-form-input.component.js","sourceRoot":"","sources":["../../../../../../src/lib/core/src/shared/dynamic-form-inputs/dynamic-form-input/dynamic-form-input.component.ts","../../../../../../src/lib/core/src/shared/dynamic-form-inputs/dynamic-form-input/dynamic-form-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkDragDrop, moveItemInArray } from '@angular/cdk/drag-drop';\r\nimport {\r\n    AfterViewInit,\r\n    ChangeDetectionStrategy,\r\n    ChangeDetectorRef,\r\n    Component,\r\n    ComponentRef,\r\n    Injector,\r\n    Input,\r\n    OnChanges,\r\n    OnDestroy,\r\n    OnInit,\r\n    Provider,\r\n    QueryList,\r\n    SimpleChanges,\r\n    Type,\r\n    ViewChild,\r\n    ViewChildren,\r\n    ViewContainerRef,\r\n} from '@angular/core';\r\nimport {\r\n    ControlValueAccessor,\r\n    FormArray,\r\n    FormControl,\r\n    NG_VALUE_ACCESSOR,\r\n    UntypedFormArray,\r\n    UntypedFormControl,\r\n} from '@angular/forms';\r\nimport { StringCustomFieldConfig } from '@vendure/common/lib/generated-types';\r\nimport { ConfigArgType, CustomFieldType, DefaultFormComponentId } from '@vendure/common/lib/shared-types';\r\nimport { assertNever, notNullOrUndefined } from '@vendure/common/lib/shared-utils';\r\nimport { simpleDeepClone } from '@vendure/common/lib/simple-deep-clone';\r\nimport { Subject, Subscription } from 'rxjs';\r\nimport { switchMap, take, takeUntil } from 'rxjs/operators';\r\n\r\nimport { FormInputComponent } from '../../../common/component-registry-types';\r\nimport { ConfigArgDefinition, CustomFieldConfig } from '../../../common/generated-types';\r\nimport { getConfigArgValue } from '../../../common/utilities/configurable-operation-utils';\r\nimport { ComponentRegistryService } from '../../../providers/component-registry/component-registry.service';\r\n\r\ntype InputListItem = {\r\n    id: number;\r\n    componentRef?: ComponentRef<FormInputComponent>;\r\n    control: UntypedFormControl;\r\n};\r\n\r\n/**\r\n * A host component which delegates to an instance or list of FormInputComponent components.\r\n */\r\n@Component({\r\n    selector: 'vdr-dynamic-form-input',\r\n    templateUrl: './dynamic-form-input.component.html',\r\n    styleUrls: ['./dynamic-form-input.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    providers: [\r\n        {\r\n            provide: NG_VALUE_ACCESSOR,\r\n            useExisting: DynamicFormInputComponent,\r\n            multi: true,\r\n        },\r\n    ],\r\n})\r\nexport class DynamicFormInputComponent\r\n    implements OnInit, OnChanges, AfterViewInit, OnDestroy, ControlValueAccessor\r\n{\r\n    @Input() def: ConfigArgDefinition | CustomFieldConfig;\r\n    @Input() readonly: boolean;\r\n    @Input() control: UntypedFormControl;\r\n    @ViewChild('single', { read: ViewContainerRef }) singleViewContainer: ViewContainerRef;\r\n    @ViewChildren('listItem', { read: ViewContainerRef }) listItemContainers: QueryList<ViewContainerRef>;\r\n    renderAsList = false;\r\n    listItems: InputListItem[] = [];\r\n    private singleComponentRef: ComponentRef<FormInputComponent>;\r\n    private listId = 1;\r\n    private listFormArray = new FormArray([] as Array<FormControl<any>>);\r\n    private componentType: Type<FormInputComponent>;\r\n    private componentProviders: Provider[] = [];\r\n    private onChange: (val: any) => void;\r\n    private onTouch: () => void;\r\n    private renderList$ = new Subject<void>();\r\n    private destroy$ = new Subject<void>();\r\n\r\n    constructor(\r\n        private componentRegistryService: ComponentRegistryService,\r\n        private changeDetectorRef: ChangeDetectorRef,\r\n        private injector: Injector,\r\n    ) {}\r\n\r\n    ngOnInit() {\r\n        const componentId = this.getInputComponentConfig(this.def).component;\r\n        const component = this.componentRegistryService.getInputComponent(componentId);\r\n        if (component) {\r\n            this.componentType = component.type;\r\n            this.componentProviders = component.providers;\r\n        } else {\r\n            // eslint-disable-next-line no-console\r\n            console.error(\r\n                `No form input component registered with the id \"${componentId}\". Using the default input instead.`,\r\n            );\r\n            const defaultComponentType = this.componentRegistryService.getInputComponent(\r\n                this.getInputComponentConfig({ ...this.def, ui: undefined } as any).component,\r\n            );\r\n            if (defaultComponentType) {\r\n                this.componentType = defaultComponentType.type;\r\n            }\r\n        }\r\n    }\r\n\r\n    ngAfterViewInit() {\r\n        if (this.componentType) {\r\n            const injector = Injector.create({\r\n                providers: this.componentProviders,\r\n                parent: this.injector,\r\n            });\r\n\r\n            // create a temp instance to check the value of `isListInput`\r\n            const cmpRef = this.singleViewContainer.createComponent(this.componentType, { injector });\r\n            const isListInputComponent = cmpRef.instance.isListInput ?? false;\r\n            cmpRef.destroy();\r\n\r\n            if (this.def.list === false && isListInputComponent) {\r\n                throw new Error(\r\n                    `The ${this.componentType.name} component is a list input, but the definition for ${this.def.name} does not expect a list`,\r\n                );\r\n            }\r\n            this.renderAsList = this.def.list && !isListInputComponent;\r\n            if (!this.renderAsList) {\r\n                this.singleComponentRef = this.renderInputComponent(\r\n                    injector,\r\n                    this.singleViewContainer,\r\n                    this.control,\r\n                );\r\n            } else {\r\n                let formArraySub: Subscription | undefined;\r\n                const renderListInputs = (viewContainerRefs: QueryList<ViewContainerRef>) => {\r\n                    if (viewContainerRefs.length) {\r\n                        if (formArraySub) {\r\n                            formArraySub.unsubscribe();\r\n                        }\r\n                        this.listFormArray = new UntypedFormArray([]);\r\n                        this.listItems.forEach(i => i.componentRef?.destroy());\r\n                        viewContainerRefs.forEach((ref, i) => {\r\n                            const listItem = this.listItems?.[i];\r\n                            if (listItem) {\r\n                                this.listFormArray.push(listItem.control);\r\n                                listItem.componentRef = this.renderInputComponent(\r\n                                    injector,\r\n                                    ref,\r\n                                    listItem.control,\r\n                                );\r\n                            }\r\n                        });\r\n\r\n                        formArraySub = this.listFormArray.valueChanges\r\n                            .pipe(takeUntil(this.destroy$))\r\n                            .subscribe(val => {\r\n                                this.control.markAsTouched();\r\n                                this.control.markAsDirty();\r\n                                const truthyValues = val.filter(notNullOrUndefined);\r\n                                this.onChange(truthyValues);\r\n                                this.control.patchValue(truthyValues, { emitEvent: false });\r\n                            });\r\n                        setTimeout(() => this.changeDetectorRef.markForCheck());\r\n                    }\r\n                };\r\n\r\n                // initial render\r\n                this.listItemContainers.changes\r\n                    .pipe(take(1))\r\n                    .subscribe(val => renderListInputs(this.listItemContainers));\r\n\r\n                // render on changes to the list\r\n                this.renderList$\r\n                    .pipe(\r\n                        switchMap(() => this.listItemContainers.changes.pipe(take(1))),\r\n                        takeUntil(this.destroy$),\r\n                    )\r\n                    .subscribe(() => {\r\n                        renderListInputs(this.listItemContainers);\r\n                    });\r\n            }\r\n        }\r\n        setTimeout(() => this.changeDetectorRef.markForCheck());\r\n    }\r\n\r\n    ngOnChanges(changes: SimpleChanges) {\r\n        if (this.listItems) {\r\n            for (const item of this.listItems) {\r\n                if (item.componentRef) {\r\n                    this.updateBindings(changes, item.componentRef);\r\n                }\r\n            }\r\n        }\r\n        if (this.singleComponentRef) {\r\n            this.updateBindings(changes, this.singleComponentRef);\r\n        }\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        this.destroy$.next();\r\n        this.destroy$.complete();\r\n    }\r\n\r\n    private updateBindings(changes: SimpleChanges, componentRef: ComponentRef<FormInputComponent>) {\r\n        if ('def' in changes) {\r\n            componentRef.instance.config = simpleDeepClone(this.def);\r\n        }\r\n        if ('readonly' in changes) {\r\n            componentRef.instance.readonly = this.readonly;\r\n        }\r\n        componentRef.injector.get(ChangeDetectorRef).markForCheck();\r\n    }\r\n\r\n    trackById(index: number, item: { id: number }) {\r\n        return item.id;\r\n    }\r\n\r\n    addListItem() {\r\n        if (!this.listItems) {\r\n            this.listItems = [];\r\n        }\r\n        this.listItems.push({\r\n            id: this.listId++,\r\n            control: new UntypedFormControl((this.def as ConfigArgDefinition).defaultValue ?? null),\r\n        });\r\n        this.renderList$.next();\r\n    }\r\n\r\n    moveListItem(event: CdkDragDrop<InputListItem>) {\r\n        if (this.listItems) {\r\n            moveItemInArray(this.listItems, event.previousIndex, event.currentIndex);\r\n            this.listFormArray.removeAt(event.previousIndex);\r\n            this.listFormArray.insert(event.currentIndex, event.item.data.control);\r\n            this.renderList$.next();\r\n        }\r\n    }\r\n\r\n    removeListItem(item: InputListItem) {\r\n        if (this.listItems) {\r\n            const index = this.listItems.findIndex(i => i === item);\r\n            item.componentRef?.destroy();\r\n            this.listFormArray.removeAt(index);\r\n            this.listItems = this.listItems.filter(i => i !== item);\r\n            this.renderList$.next();\r\n        }\r\n    }\r\n\r\n    private renderInputComponent(\r\n        injector: Injector,\r\n        viewContainerRef: ViewContainerRef,\r\n        formControl: UntypedFormControl,\r\n    ) {\r\n        const componentRef = viewContainerRef.createComponent(this.componentType, { injector });\r\n        const { instance } = componentRef;\r\n        instance.config = simpleDeepClone(this.def);\r\n        instance.formControl = formControl;\r\n        instance.readonly = this.readonly;\r\n        componentRef.injector.get(ChangeDetectorRef).markForCheck();\r\n        return componentRef;\r\n    }\r\n\r\n    registerOnChange(fn: any): void {\r\n        this.onChange = fn;\r\n    }\r\n\r\n    registerOnTouched(fn: any): void {\r\n        this.onTouch = fn;\r\n    }\r\n\r\n    writeValue(obj: any): void {\r\n        if (Array.isArray(obj)) {\r\n            if (obj.length === this.listItems.length) {\r\n                obj.forEach((value, index) => {\r\n                    const control = this.listItems[index]?.control;\r\n                    control.patchValue(getConfigArgValue(value), { emitEvent: false });\r\n                });\r\n            } else {\r\n                this.listItems = obj.map(\r\n                    value =>\r\n                        ({\r\n                            id: this.listId++,\r\n                            control: new UntypedFormControl(getConfigArgValue(value)),\r\n                        } as InputListItem),\r\n                );\r\n                this.renderList$.next();\r\n            }\r\n        } else {\r\n            this.listItems = [];\r\n            this.renderList$.next();\r\n        }\r\n        this.changeDetectorRef.markForCheck();\r\n    }\r\n\r\n    private getInputComponentConfig(argDef: ConfigArgDefinition | CustomFieldConfig): {\r\n        component: DefaultFormComponentId;\r\n    } {\r\n        if (this.hasUiConfig(argDef) && argDef.ui.component) {\r\n            return argDef.ui;\r\n        }\r\n        const type = argDef?.type as ConfigArgType | CustomFieldType;\r\n        switch (type) {\r\n            case 'string':\r\n            case 'localeString': {\r\n                const hasOptions =\r\n                    !!(this.isConfigArgDef(argDef) && argDef.ui?.options) ||\r\n                    !!(argDef as StringCustomFieldConfig).options;\r\n                if (hasOptions) {\r\n                    return { component: 'select-form-input' };\r\n                } else {\r\n                    return { component: 'text-form-input' };\r\n                }\r\n            }\r\n            case 'text':\r\n            case 'localeText': {\r\n                return { component: 'textarea-form-input' };\r\n            }\r\n            case 'int':\r\n            case 'float':\r\n                return { component: 'number-form-input' };\r\n            case 'boolean':\r\n                return { component: 'boolean-form-input' };\r\n            case 'datetime':\r\n                return { component: 'date-form-input' };\r\n            case 'ID':\r\n                return { component: 'text-form-input' };\r\n            case 'relation':\r\n                return { component: 'relation-form-input' };\r\n            default:\r\n                assertNever(type);\r\n        }\r\n    }\r\n\r\n    private isConfigArgDef(def: ConfigArgDefinition | CustomFieldConfig): def is ConfigArgDefinition {\r\n        return (def as ConfigArgDefinition)?.__typename === 'ConfigArgDefinition';\r\n    }\r\n\r\n    private hasUiConfig(def: unknown): def is { ui: { component: string } } {\r\n        return typeof def === 'object' && typeof (def as any)?.ui?.component === 'string';\r\n    }\r\n}\r\n","<ng-container *ngIf=\"!renderAsList; else list\">\r\n    <ng-container #single></ng-container>\r\n</ng-container>\r\n<ng-template #list>\r\n    <div class=\"list-container\" cdkDropList (cdkDropListDropped)=\"moveListItem($event)\">\r\n        <div\r\n            class=\"list-item-row\"\r\n            *ngFor=\"let item of listItems; trackBy: trackById\"\r\n            cdkDrag\r\n            [cdkDragData]=\"item\"\r\n            [cdkDragLockAxis]=\"'y'\"\r\n        >\r\n            <div class=\"flex-spacer pr-2\">\r\n                <ng-container #listItem></ng-container>\r\n            </div>\r\n            <button\r\n                class=\"button-small\"\r\n                *ngIf=\"!readonly\"\r\n                (click)=\"removeListItem(item)\"\r\n                [title]=\"'common.remove-item-from-list' | translate\"\r\n            >\r\n                <clr-icon shape=\"times\"></clr-icon>\r\n            </button>\r\n            <div class=\"drag-handle\" cdkDragHandle [class.hidden]=\"readonly\">\r\n                <clr-icon shape=\"drag-handle\" size=\"24\"></clr-icon>\r\n            </div>\r\n        </div>\r\n        <button class=\"btn btn-secondary btn-sm\" (click)=\"addListItem()\" *ngIf=\"!readonly\">\r\n            <clr-icon shape=\"plus\"></clr-icon> {{ 'common.add-item-to-list' | translate }}\r\n        </button>\r\n    </div>\r\n</ng-template>\r\n"]}
|
|
277
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-form-input.component.js","sourceRoot":"","sources":["../../../../../../src/lib/core/src/shared/dynamic-form-inputs/dynamic-form-input/dynamic-form-input.component.ts","../../../../../../src/lib/core/src/shared/dynamic-form-inputs/dynamic-form-input/dynamic-form-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkDragDrop, moveItemInArray } from '@angular/cdk/drag-drop';\r\nimport {\r\n    AfterViewInit,\r\n    ChangeDetectionStrategy,\r\n    ChangeDetectorRef,\r\n    Component,\r\n    ComponentRef,\r\n    Injector,\r\n    Input,\r\n    OnChanges,\r\n    OnDestroy,\r\n    OnInit,\r\n    Provider,\r\n    QueryList,\r\n    SimpleChanges,\r\n    Type,\r\n    ViewChild,\r\n    ViewChildren,\r\n    ViewContainerRef,\r\n} from '@angular/core';\r\nimport {\r\n    ControlValueAccessor,\r\n    FormArray,\r\n    FormControl,\r\n    NG_VALUE_ACCESSOR,\r\n    UntypedFormArray,\r\n    UntypedFormControl,\r\n} from '@angular/forms';\r\nimport { StringCustomFieldConfig } from '@vendure/common/lib/generated-types';\r\nimport { ConfigArgType, CustomFieldType, DefaultFormComponentId } from '@vendure/common/lib/shared-types';\r\nimport { assertNever, notNullOrUndefined } from '@vendure/common/lib/shared-utils';\r\nimport { simpleDeepClone } from '@vendure/common/lib/simple-deep-clone';\r\nimport { Subject, Subscription } from 'rxjs';\r\nimport { switchMap, take, takeUntil } from 'rxjs/operators';\r\n\r\nimport { FormInputComponent } from '../../../common/component-registry-types';\r\nimport { ConfigArgDefinition, CustomFieldConfig } from '../../../common/generated-types';\r\nimport { getConfigArgValue } from '../../../common/utilities/configurable-operation-utils';\r\nimport { ComponentRegistryService } from '../../../providers/component-registry/component-registry.service';\r\n\r\ntype InputListItem = {\r\n    id: number;\r\n    componentRef?: ComponentRef<FormInputComponent>;\r\n    control: UntypedFormControl;\r\n};\r\n\r\n/**\r\n * A host component which delegates to an instance or list of FormInputComponent components.\r\n */\r\n@Component({\r\n    selector: 'vdr-dynamic-form-input',\r\n    templateUrl: './dynamic-form-input.component.html',\r\n    styleUrls: ['./dynamic-form-input.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    providers: [\r\n        {\r\n            provide: NG_VALUE_ACCESSOR,\r\n            useExisting: DynamicFormInputComponent,\r\n            multi: true,\r\n        },\r\n    ],\r\n})\r\nexport class DynamicFormInputComponent\r\n    implements OnInit, OnChanges, AfterViewInit, OnDestroy, ControlValueAccessor\r\n{\r\n    @Input() def: ConfigArgDefinition | CustomFieldConfig;\r\n    @Input() readonly: boolean;\r\n    @Input() control: UntypedFormControl;\r\n    @ViewChild('single', { read: ViewContainerRef }) singleViewContainer: ViewContainerRef;\r\n    @ViewChildren('listItem', { read: ViewContainerRef }) listItemContainers: QueryList<ViewContainerRef>;\r\n    renderAsList = false;\r\n    listItems: InputListItem[] = [];\r\n    private singleComponentRef: ComponentRef<FormInputComponent>;\r\n    private listId = 1;\r\n    private listFormArray = new FormArray([] as Array<FormControl<any>>);\r\n    private componentType: Type<FormInputComponent>;\r\n    private componentProviders: Provider[] = [];\r\n    private onChange: (val: any) => void;\r\n    private onTouch: () => void;\r\n    private renderList$ = new Subject<void>();\r\n    private destroy$ = new Subject<void>();\r\n\r\n    constructor(\r\n        private componentRegistryService: ComponentRegistryService,\r\n        private changeDetectorRef: ChangeDetectorRef,\r\n        private injector: Injector,\r\n    ) {}\r\n\r\n    ngOnInit() {\r\n        const componentId = this.getInputComponentConfig(this.def).component;\r\n        const component = this.componentRegistryService.getInputComponent(componentId);\r\n        if (component) {\r\n            this.componentType = component.type;\r\n            this.componentProviders = component.providers;\r\n        } else {\r\n            // eslint-disable-next-line no-console\r\n            console.error(\r\n                `No form input component registered with the id \"${componentId}\". Using the default input instead.`,\r\n            );\r\n            const defaultComponentType = this.componentRegistryService.getInputComponent(\r\n                this.getInputComponentConfig({ ...this.def, ui: undefined } as any).component,\r\n            );\r\n            if (defaultComponentType) {\r\n                this.componentType = defaultComponentType.type;\r\n            }\r\n        }\r\n    }\r\n\r\n    ngAfterViewInit() {\r\n        if (this.componentType) {\r\n            const injector = Injector.create({\r\n                providers: this.componentProviders,\r\n                parent: this.injector,\r\n            });\r\n\r\n            // create a temp instance to check the value of `isListInput`\r\n            const cmpRef = this.singleViewContainer.createComponent(this.componentType, { injector });\r\n            const isListInputComponent = cmpRef.instance.isListInput ?? false;\r\n            cmpRef.destroy();\r\n\r\n            if (this.def.list === false && isListInputComponent) {\r\n                throw new Error(\r\n                    `The ${this.componentType.name} component is a list input, but the definition for ${this.def.name} does not expect a list`,\r\n                );\r\n            }\r\n            this.renderAsList = this.def.list && !isListInputComponent;\r\n            if (!this.renderAsList) {\r\n                this.singleComponentRef = this.renderInputComponent(\r\n                    injector,\r\n                    this.singleViewContainer,\r\n                    this.control,\r\n                );\r\n            } else {\r\n                let formArraySub: Subscription | undefined;\r\n                const renderListInputs = (viewContainerRefs: QueryList<ViewContainerRef>) => {\r\n                    if (viewContainerRefs.length) {\r\n                        if (formArraySub) {\r\n                            formArraySub.unsubscribe();\r\n                        }\r\n                        this.listFormArray = new UntypedFormArray([]);\r\n                        this.listItems.forEach(i => i.componentRef?.destroy());\r\n                        viewContainerRefs.forEach((ref, i) => {\r\n                            const listItem = this.listItems?.[i];\r\n                            if (listItem) {\r\n                                this.listFormArray.push(listItem.control);\r\n                                listItem.componentRef = this.renderInputComponent(\r\n                                    injector,\r\n                                    ref,\r\n                                    listItem.control,\r\n                                );\r\n                            }\r\n                        });\r\n\r\n                        formArraySub = this.listFormArray.valueChanges\r\n                            .pipe(takeUntil(this.destroy$))\r\n                            .subscribe(val => {\r\n                                this.control.markAsTouched();\r\n                                this.control.markAsDirty();\r\n                                const truthyValues = val.filter(notNullOrUndefined);\r\n                                this.onChange(truthyValues);\r\n                                this.control.patchValue(truthyValues, { emitEvent: false });\r\n                            });\r\n                        setTimeout(() => this.changeDetectorRef.markForCheck());\r\n                    }\r\n                };\r\n\r\n                // initial render\r\n                this.listItemContainers.changes\r\n                    .pipe(take(1))\r\n                    .subscribe(val => renderListInputs(this.listItemContainers));\r\n\r\n                // render on changes to the list\r\n                this.renderList$\r\n                    .pipe(\r\n                        switchMap(() => this.listItemContainers.changes.pipe(take(1))),\r\n                        takeUntil(this.destroy$),\r\n                    )\r\n                    .subscribe(() => {\r\n                        renderListInputs(this.listItemContainers);\r\n                    });\r\n            }\r\n        }\r\n        setTimeout(() => this.changeDetectorRef.markForCheck());\r\n    }\r\n\r\n    ngOnChanges(changes: SimpleChanges) {\r\n        if (this.listItems) {\r\n            for (const item of this.listItems) {\r\n                if (item.componentRef) {\r\n                    const { value } = item.control;\r\n                    const { type } = item.componentRef.instance.config || {};\r\n                    // fix a bug where the list item of string turns into number which lead to unexpected behavior\r\n                    if (typeof value === 'number' && type === 'string') {\r\n                        item.control.setValue(item.control.value.toString(), { emitEvent: false });\r\n                    }\r\n                    this.updateBindings(changes, item.componentRef);\r\n                }\r\n            }\r\n        }\r\n        if (this.singleComponentRef) {\r\n            this.updateBindings(changes, this.singleComponentRef);\r\n        }\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        this.destroy$.next();\r\n        this.destroy$.complete();\r\n    }\r\n\r\n    private updateBindings(changes: SimpleChanges, componentRef: ComponentRef<FormInputComponent>) {\r\n        if ('def' in changes) {\r\n            componentRef.instance.config = simpleDeepClone(this.def);\r\n        }\r\n        if ('readonly' in changes) {\r\n            componentRef.instance.readonly = this.readonly;\r\n        }\r\n        componentRef.injector.get(ChangeDetectorRef).markForCheck();\r\n    }\r\n\r\n    trackById(index: number, item: { id: number }) {\r\n        return item.id;\r\n    }\r\n\r\n    addListItem() {\r\n        if (!this.listItems) {\r\n            this.listItems = [];\r\n        }\r\n        this.listItems.push({\r\n            id: this.listId++,\r\n            control: new UntypedFormControl((this.def as ConfigArgDefinition).defaultValue ?? null),\r\n        });\r\n        this.renderList$.next();\r\n    }\r\n\r\n    moveListItem(event: CdkDragDrop<InputListItem>) {\r\n        if (this.listItems) {\r\n            moveItemInArray(this.listItems, event.previousIndex, event.currentIndex);\r\n            this.listFormArray.removeAt(event.previousIndex);\r\n            this.listFormArray.insert(event.currentIndex, event.item.data.control);\r\n            this.renderList$.next();\r\n        }\r\n    }\r\n\r\n    removeListItem(item: InputListItem) {\r\n        if (this.listItems) {\r\n            const index = this.listItems.findIndex(i => i === item);\r\n            item.componentRef?.destroy();\r\n            this.listFormArray.removeAt(index);\r\n            this.listItems = this.listItems.filter(i => i !== item);\r\n            this.renderList$.next();\r\n        }\r\n    }\r\n\r\n    private renderInputComponent(\r\n        injector: Injector,\r\n        viewContainerRef: ViewContainerRef,\r\n        formControl: UntypedFormControl,\r\n    ) {\r\n        const componentRef = viewContainerRef.createComponent(this.componentType, { injector });\r\n        const { instance } = componentRef;\r\n        instance.config = simpleDeepClone(this.def);\r\n        instance.formControl = formControl;\r\n        instance.readonly = this.readonly;\r\n        componentRef.injector.get(ChangeDetectorRef).markForCheck();\r\n        return componentRef;\r\n    }\r\n\r\n    registerOnChange(fn: any): void {\r\n        this.onChange = fn;\r\n    }\r\n\r\n    registerOnTouched(fn: any): void {\r\n        this.onTouch = fn;\r\n    }\r\n\r\n    writeValue(obj: any): void {\r\n        if (Array.isArray(obj)) {\r\n            if (obj.length === this.listItems.length) {\r\n                obj.forEach((value, index) => {\r\n                    const control = this.listItems[index]?.control;\r\n                    control.patchValue(getConfigArgValue(value), { emitEvent: false });\r\n                });\r\n            } else {\r\n                this.listItems = obj.map(\r\n                    value =>\r\n                        ({\r\n                            id: this.listId++,\r\n                            control: new UntypedFormControl(getConfigArgValue(value)),\r\n                        } as InputListItem),\r\n                );\r\n                this.renderList$.next();\r\n            }\r\n        } else {\r\n            this.listItems = [];\r\n            this.renderList$.next();\r\n        }\r\n        this.changeDetectorRef.markForCheck();\r\n    }\r\n\r\n    private getInputComponentConfig(argDef: ConfigArgDefinition | CustomFieldConfig): {\r\n        component: DefaultFormComponentId;\r\n    } {\r\n        if (this.hasUiConfig(argDef) && argDef.ui.component) {\r\n            return argDef.ui;\r\n        }\r\n        const type = argDef?.type as ConfigArgType | CustomFieldType;\r\n        switch (type) {\r\n            case 'string':\r\n            case 'localeString': {\r\n                const hasOptions =\r\n                    !!(this.isConfigArgDef(argDef) && argDef.ui?.options) ||\r\n                    !!(argDef as StringCustomFieldConfig).options;\r\n                if (hasOptions) {\r\n                    return { component: 'select-form-input' };\r\n                } else {\r\n                    return { component: 'text-form-input' };\r\n                }\r\n            }\r\n            case 'text':\r\n            case 'localeText': {\r\n                return { component: 'textarea-form-input' };\r\n            }\r\n            case 'int':\r\n            case 'float':\r\n                return { component: 'number-form-input' };\r\n            case 'boolean':\r\n                return { component: 'boolean-form-input' };\r\n            case 'datetime':\r\n                return { component: 'date-form-input' };\r\n            case 'ID':\r\n                return { component: 'text-form-input' };\r\n            case 'relation':\r\n                return { component: 'relation-form-input' };\r\n            default:\r\n                assertNever(type);\r\n        }\r\n    }\r\n\r\n    private isConfigArgDef(def: ConfigArgDefinition | CustomFieldConfig): def is ConfigArgDefinition {\r\n        return (def as ConfigArgDefinition)?.__typename === 'ConfigArgDefinition';\r\n    }\r\n\r\n    private hasUiConfig(def: unknown): def is { ui: { component: string } } {\r\n        return typeof def === 'object' && typeof (def as any)?.ui?.component === 'string';\r\n    }\r\n}\r\n","<ng-container *ngIf=\"!renderAsList; else list\">\r\n    <ng-container #single></ng-container>\r\n</ng-container>\r\n<ng-template #list>\r\n    <div class=\"list-container\" cdkDropList (cdkDropListDropped)=\"moveListItem($event)\">\r\n        <div\r\n            class=\"list-item-row\"\r\n            *ngFor=\"let item of listItems; trackBy: trackById\"\r\n            cdkDrag\r\n            [cdkDragData]=\"item\"\r\n            [cdkDragLockAxis]=\"'y'\"\r\n        >\r\n            <div class=\"flex-spacer pr-2\">\r\n                <ng-container #listItem></ng-container>\r\n            </div>\r\n            <button\r\n                class=\"button-small\"\r\n                *ngIf=\"!readonly\"\r\n                (click)=\"removeListItem(item)\"\r\n                [title]=\"'common.remove-item-from-list' | translate\"\r\n            >\r\n                <clr-icon shape=\"times\"></clr-icon>\r\n            </button>\r\n            <div class=\"drag-handle\" cdkDragHandle [class.hidden]=\"readonly\">\r\n                <clr-icon shape=\"drag-handle\" size=\"24\"></clr-icon>\r\n            </div>\r\n        </div>\r\n        <button class=\"btn btn-secondary btn-sm\" (click)=\"addListItem()\" *ngIf=\"!readonly\">\r\n            <clr-icon shape=\"plus\"></clr-icon> {{ 'common.add-item-to-list' | translate }}\r\n        </button>\r\n    </div>\r\n</ng-template>\r\n"]}
|