@vendure/admin-ui 2.0.6 → 2.0.7
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/catalog/components/collection-detail/collection-detail.component.d.ts +3 -1
- package/catalog/components/create-product-variant-dialog/create-product-variant-dialog.component.d.ts +6 -4
- package/catalog/components/facet-detail/facet-detail.component.d.ts +3 -1
- package/catalog/components/product-detail/product-detail.component.d.ts +3 -1
- package/catalog/components/stock-location-detail/stock-location-detail.component.d.ts +3 -1
- package/core/common/utilities/custom-field-default-value.d.ts +6 -0
- package/core/common/version.d.ts +1 -1
- package/core/providers/data-table/data-table-filter-collection.d.ts +10 -6
- package/core/providers/data-table/data-table-filter.d.ts +13 -2
- package/core/public_api.d.ts +1 -0
- package/customer/components/customer-detail/customer-detail.component.d.ts +3 -1
- package/customer/components/customer-group-detail/customer-group-detail.component.d.ts +3 -1
- package/customer/components/customer-list/customer-list.component.d.ts +1 -0
- package/esm2022/catalog/components/asset-detail/asset-detail.component.mjs +3 -3
- package/esm2022/catalog/components/collection-detail/collection-detail.component.mjs +3 -3
- package/esm2022/catalog/components/collection-list/collection-list.component.mjs +2 -1
- package/esm2022/catalog/components/create-product-variant-dialog/create-product-variant-dialog.component.mjs +8 -5
- package/esm2022/catalog/components/facet-detail/facet-detail.component.mjs +3 -3
- package/esm2022/catalog/components/facet-list/facet-list.component.mjs +2 -1
- package/esm2022/catalog/components/product-detail/product-detail.component.mjs +3 -3
- package/esm2022/catalog/components/product-list/product-list.component.mjs +2 -7
- package/esm2022/catalog/components/product-variant-detail/product-variant-detail.component.mjs +3 -3
- package/esm2022/catalog/components/product-variant-list/product-variant-list.component.mjs +2 -7
- package/esm2022/catalog/components/product-variants-editor/product-variants-editor.component.mjs +1 -1
- package/esm2022/catalog/components/stock-location-detail/stock-location-detail.component.mjs +3 -3
- package/esm2022/catalog/components/stock-location-list/stock-location-list.component.mjs +2 -7
- package/esm2022/core/common/utilities/create-updated-translatable.mjs +5 -23
- package/esm2022/core/common/utilities/custom-field-default-value.mjs +28 -0
- package/esm2022/core/common/version.mjs +2 -2
- package/esm2022/core/components/channel-switcher/channel-switcher.component.mjs +3 -3
- package/esm2022/core/providers/dashboard-widget/register-dashboard-widget.mjs +1 -1
- package/esm2022/core/providers/data-table/data-table-filter-collection.mjs +51 -22
- package/esm2022/core/providers/data-table/data-table-filter.mjs +8 -1
- package/esm2022/core/providers/local-storage/local-storage.service.mjs +1 -1
- package/esm2022/core/public_api.mjs +2 -1
- package/esm2022/core/shared/components/asset-gallery/asset-gallery.component.mjs +3 -3
- package/esm2022/core/shared/components/card/card.component.mjs +1 -1
- package/esm2022/core/shared/components/chip/chip.component.mjs +2 -2
- package/esm2022/core/shared/components/data-table-2/data-table2.component.mjs +1 -1
- package/esm2022/core/shared/components/data-table-filter-label/data-table-filter-label.component.mjs +3 -3
- package/esm2022/core/shared/components/data-table-filters/data-table-filters.component.mjs +23 -4
- package/esm2022/core/shared/components/facet-value-chip/facet-value-chip.component.mjs +2 -2
- package/esm2022/core/shared/components/tabbed-custom-fields/tabbed-custom-fields.component.mjs +2 -2
- package/esm2022/customer/components/customer-detail/customer-detail.component.mjs +3 -3
- package/esm2022/customer/components/customer-group-detail/customer-group-detail.component.mjs +3 -3
- package/esm2022/customer/components/customer-group-detail-dialog/customer-group-detail-dialog.component.mjs +3 -2
- package/esm2022/customer/components/customer-group-list/customer-group-list.component.mjs +2 -1
- package/esm2022/customer/components/customer-list/customer-list.component.mjs +34 -30
- package/esm2022/dashboard/components/dashboard-widget/dashboard-widget.component.mjs +1 -1
- package/esm2022/marketing/components/promotion-detail/promotion-detail.component.mjs +3 -3
- package/esm2022/marketing/components/promotion-list/promotion-list.component.mjs +2 -1
- package/esm2022/order/components/order-detail/order-detail.component.mjs +3 -3
- package/esm2022/order/components/order-list/order-list.component.mjs +2 -1
- package/esm2022/settings/components/admin-detail/admin-detail.component.mjs +3 -3
- package/esm2022/settings/components/administrator-list/administrator-list.component.mjs +2 -1
- package/esm2022/settings/components/channel-detail/channel-detail.component.mjs +10 -10
- package/esm2022/settings/components/channel-list/channel-list.component.mjs +2 -1
- package/esm2022/settings/components/country-detail/country-detail.component.mjs +3 -3
- package/esm2022/settings/components/country-list/country-list.component.mjs +3 -2
- package/esm2022/settings/components/global-settings/global-settings.component.mjs +3 -3
- package/esm2022/settings/components/payment-method-detail/payment-method-detail.component.mjs +3 -3
- package/esm2022/settings/components/payment-method-list/payment-method-list.component.mjs +2 -1
- package/esm2022/settings/components/profile/profile.component.mjs +3 -3
- package/esm2022/settings/components/role-list/role-list.component.mjs +2 -1
- package/esm2022/settings/components/seller-detail/seller-detail.component.mjs +3 -3
- package/esm2022/settings/components/seller-list/seller-list.component.mjs +2 -1
- package/esm2022/settings/components/shipping-method-detail/shipping-method-detail.component.mjs +3 -3
- package/esm2022/settings/components/shipping-method-list/shipping-method-list.component.mjs +2 -1
- package/esm2022/settings/components/tax-category-detail/tax-category-detail.component.mjs +3 -3
- package/esm2022/settings/components/tax-category-list/tax-category-list.component.mjs +2 -1
- package/esm2022/settings/components/tax-rate-detail/tax-rate-detail.component.mjs +3 -3
- package/esm2022/settings/components/tax-rate-list/tax-rate-list.component.mjs +2 -1
- package/esm2022/settings/components/zone-detail/zone-detail.component.mjs +3 -3
- package/esm2022/settings/components/zone-list/zone-list.component.mjs +2 -1
- package/fesm2022/vendure-admin-ui-catalog.mjs +19 -29
- package/fesm2022/vendure-admin-ui-catalog.mjs.map +1 -1
- package/fesm2022/vendure-admin-ui-core.mjs +121 -58
- package/fesm2022/vendure-admin-ui-core.mjs.map +1 -1
- package/fesm2022/vendure-admin-ui-customer.mjs +34 -29
- package/fesm2022/vendure-admin-ui-customer.mjs.map +1 -1
- package/fesm2022/vendure-admin-ui-dashboard.mjs.map +1 -1
- package/fesm2022/vendure-admin-ui-marketing.mjs +3 -2
- package/fesm2022/vendure-admin-ui-marketing.mjs.map +1 -1
- package/fesm2022/vendure-admin-ui-order.mjs +3 -2
- package/fesm2022/vendure-admin-ui-order.mjs.map +1 -1
- package/fesm2022/vendure-admin-ui-settings.mjs +30 -20
- package/fesm2022/vendure-admin-ui-settings.mjs.map +1 -1
- package/marketing/components/promotion-detail/promotion-detail.component.d.ts +3 -1
- package/order/components/order-detail/order-detail.component.d.ts +3 -1
- package/package.json +8 -8
- package/settings/components/admin-detail/admin-detail.component.d.ts +3 -1
- package/settings/components/channel-detail/channel-detail.component.d.ts +5 -3
- package/settings/components/country-detail/country-detail.component.d.ts +3 -1
- package/settings/components/global-settings/global-settings.component.d.ts +3 -1
- package/settings/components/payment-method-detail/payment-method-detail.component.d.ts +3 -1
- package/settings/components/profile/profile.component.d.ts +3 -1
- package/settings/components/seller-detail/seller-detail.component.d.ts +3 -1
- package/settings/components/shipping-method-detail/shipping-method-detail.component.d.ts +3 -1
- package/settings/components/tax-category-detail/tax-category-detail.component.d.ts +3 -1
- package/settings/components/tax-rate-detail/tax-rate-detail.component.d.ts +3 -1
- package/settings/components/zone-detail/zone-detail.component.d.ts +3 -1
- package/static/i18n-messages/it.json +169 -169
|
@@ -41,10 +41,10 @@ export class ChannelSwitcherComponent {
|
|
|
41
41
|
this.channelService.setActiveChannel(channelId).subscribe(() => this.filterControl.patchValue(''));
|
|
42
42
|
}
|
|
43
43
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.3", ngImport: i0, type: ChannelSwitcherComponent, deps: [{ token: i1.DataService }, { token: i2.ChannelService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
44
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.3", type: ChannelSwitcherComponent, selector: "vdr-channel-switcher", ngImport: i0, template: "<ng-container>\r\n <vdr-dropdown>\r\n <button class=\"active-channel m-auto\" vdrDropdownTrigger>\r\n <vdr-channel-badge [channelCode]=\"activeChannelCode$ | async\"></vdr-channel-badge>\r\n <span class=\"channel-label\">{{\r\n activeChannelCode$ | async | channelCodeToLabel | translate\r\n }}</span>\r\n <span class=\"trigger\"><clr-icon shape=\"ellipsis-vertical\"></clr-icon></span>\r\n </button>\r\n <vdr-dropdown-menu vdrPosition=\"bottom-right\">\r\n <input\r\n *ngIf=\"((channelCount$ | async) || 0) >= displayFilterThreshold\"\r\n [formControl]=\"filterControl\"\r\n type=\"text\"\r\n class=\"ml2 mr2\"\r\n [placeholder]=\"'common.filter' | translate\"\r\n />\r\n <button\r\n *ngFor=\"let channel of channels$ | async\"\r\n type=\"button\"\r\n vdrDropdownItem\r\n (click)=\"setActiveChannel(channel.id)\"\r\n >\r\n <vdr-channel-badge [channelCode]=\"channel.code\"></vdr-channel-badge>\r\n {{ channel.code | channelCodeToLabel | translate }}\r\n </button>\r\n </vdr-dropdown-menu>\r\n </vdr-dropdown>\r\n</ng-container>\r\n", styles: [":host{display:block;align-items:center;height:2.5rem}.active-channel{display:flex;justify-content:space-between;align-items:center;font-size:var(--font-size-xs);color:var(--color-left-nav-text);background-color:var(--color-channel-switcher-bg);border:none;cursor:pointer;width:100%;border-radius:var(--border-radius-lg);padding:var(--space-unit) calc(var(--space-unit) * 2);transition:background-color .1s,color .1s}.active-channel:hover{background-color:var(--color-channel-switcher-hover-bg);color:var(--color-left-nav-text-hover)}.active-channel clr-icon{color:var(--color-left-nav-text)}.channel-label{margin:0 3px;overflow:hidden;flex:1;white-space:nowrap;text-overflow:ellipsis}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.ClrIconCustomTag, selector: "clr-icon" }, { kind: "directive", type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i6.FormFieldControlDirective, selector: "input, textarea, select" }, { kind: "component", type: i7.DropdownComponent, selector: "vdr-dropdown", inputs: ["manualToggle"] }, { kind: "component", type: i8.DropdownMenuComponent, selector: "vdr-dropdown-menu", inputs: ["vdrPosition", "customClasses"] }, { kind: "directive", type: i9.DropdownTriggerDirective, selector: "[vdrDropdownTrigger]" }, { kind: "directive", type: i10.DropdownItemDirective, selector: "[vdrDropdownItem]" }, { kind: "component", type: i11.ChannelBadgeComponent, selector: "vdr-channel-badge", inputs: ["channelCode"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i12.TranslatePipe, name: "translate" }, { kind: "pipe", type: i13.ChannelLabelPipe, name: "channelCodeToLabel" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
44
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.3", type: ChannelSwitcherComponent, selector: "vdr-channel-switcher", ngImport: i0, template: "<ng-container>\r\n <vdr-dropdown>\r\n <button class=\"active-channel m-auto\" vdrDropdownTrigger>\r\n <vdr-channel-badge [channelCode]=\"activeChannelCode$ | async\"></vdr-channel-badge>\r\n <span class=\"channel-label\">{{\r\n activeChannelCode$ | async | channelCodeToLabel | translate\r\n }}</span>\r\n <span class=\"trigger\"><clr-icon shape=\"ellipsis-vertical\" size=\"12\"></clr-icon></span>\r\n </button>\r\n <vdr-dropdown-menu vdrPosition=\"bottom-right\">\r\n <input\r\n *ngIf=\"((channelCount$ | async) || 0) >= displayFilterThreshold\"\r\n [formControl]=\"filterControl\"\r\n type=\"text\"\r\n class=\"ml2 mr2\"\r\n [placeholder]=\"'common.filter' | translate\"\r\n />\r\n <button\r\n *ngFor=\"let channel of channels$ | async\"\r\n type=\"button\"\r\n vdrDropdownItem\r\n (click)=\"setActiveChannel(channel.id)\"\r\n >\r\n <vdr-channel-badge [channelCode]=\"channel.code\"></vdr-channel-badge>\r\n {{ channel.code | channelCodeToLabel | translate }}\r\n </button>\r\n </vdr-dropdown-menu>\r\n </vdr-dropdown>\r\n</ng-container>\r\n", styles: [":host{display:block;align-items:center;height:2.5rem}.active-channel{display:flex;justify-content:space-between;align-items:center;font-size:var(--font-size-xs);color:var(--color-left-nav-text);background-color:var(--color-channel-switcher-bg);border:none;cursor:pointer;width:100%;border-radius:var(--border-radius-lg);padding:var(--space-unit) calc(var(--space-unit) * 2);transition:background-color .1s,color .1s}.active-channel:hover{background-color:var(--color-channel-switcher-hover-bg);color:var(--color-left-nav-text-hover)}.active-channel clr-icon{color:var(--color-left-nav-text)}.channel-label{margin:0 3px;overflow:hidden;flex:1;white-space:nowrap;text-overflow:ellipsis}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.ClrIconCustomTag, selector: "clr-icon" }, { kind: "directive", type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i6.FormFieldControlDirective, selector: "input, textarea, select" }, { kind: "component", type: i7.DropdownComponent, selector: "vdr-dropdown", inputs: ["manualToggle"] }, { kind: "component", type: i8.DropdownMenuComponent, selector: "vdr-dropdown-menu", inputs: ["vdrPosition", "customClasses"] }, { kind: "directive", type: i9.DropdownTriggerDirective, selector: "[vdrDropdownTrigger]" }, { kind: "directive", type: i10.DropdownItemDirective, selector: "[vdrDropdownItem]" }, { kind: "component", type: i11.ChannelBadgeComponent, selector: "vdr-channel-badge", inputs: ["channelCode"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i12.TranslatePipe, name: "translate" }, { kind: "pipe", type: i13.ChannelLabelPipe, name: "channelCodeToLabel" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
45
45
|
}
|
|
46
46
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.3", ngImport: i0, type: ChannelSwitcherComponent, decorators: [{
|
|
47
47
|
type: Component,
|
|
48
|
-
args: [{ selector: 'vdr-channel-switcher', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container>\r\n <vdr-dropdown>\r\n <button class=\"active-channel m-auto\" vdrDropdownTrigger>\r\n <vdr-channel-badge [channelCode]=\"activeChannelCode$ | async\"></vdr-channel-badge>\r\n <span class=\"channel-label\">{{\r\n activeChannelCode$ | async | channelCodeToLabel | translate\r\n }}</span>\r\n <span class=\"trigger\"><clr-icon shape=\"ellipsis-vertical\"></clr-icon></span>\r\n </button>\r\n <vdr-dropdown-menu vdrPosition=\"bottom-right\">\r\n <input\r\n *ngIf=\"((channelCount$ | async) || 0) >= displayFilterThreshold\"\r\n [formControl]=\"filterControl\"\r\n type=\"text\"\r\n class=\"ml2 mr2\"\r\n [placeholder]=\"'common.filter' | translate\"\r\n />\r\n <button\r\n *ngFor=\"let channel of channels$ | async\"\r\n type=\"button\"\r\n vdrDropdownItem\r\n (click)=\"setActiveChannel(channel.id)\"\r\n >\r\n <vdr-channel-badge [channelCode]=\"channel.code\"></vdr-channel-badge>\r\n {{ channel.code | channelCodeToLabel | translate }}\r\n </button>\r\n </vdr-dropdown-menu>\r\n </vdr-dropdown>\r\n</ng-container>\r\n", styles: [":host{display:block;align-items:center;height:2.5rem}.active-channel{display:flex;justify-content:space-between;align-items:center;font-size:var(--font-size-xs);color:var(--color-left-nav-text);background-color:var(--color-channel-switcher-bg);border:none;cursor:pointer;width:100%;border-radius:var(--border-radius-lg);padding:var(--space-unit) calc(var(--space-unit) * 2);transition:background-color .1s,color .1s}.active-channel:hover{background-color:var(--color-channel-switcher-hover-bg);color:var(--color-left-nav-text-hover)}.active-channel clr-icon{color:var(--color-left-nav-text)}.channel-label{margin:0 3px;overflow:hidden;flex:1;white-space:nowrap;text-overflow:ellipsis}\n"] }]
|
|
48
|
+
args: [{ selector: 'vdr-channel-switcher', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container>\r\n <vdr-dropdown>\r\n <button class=\"active-channel m-auto\" vdrDropdownTrigger>\r\n <vdr-channel-badge [channelCode]=\"activeChannelCode$ | async\"></vdr-channel-badge>\r\n <span class=\"channel-label\">{{\r\n activeChannelCode$ | async | channelCodeToLabel | translate\r\n }}</span>\r\n <span class=\"trigger\"><clr-icon shape=\"ellipsis-vertical\" size=\"12\"></clr-icon></span>\r\n </button>\r\n <vdr-dropdown-menu vdrPosition=\"bottom-right\">\r\n <input\r\n *ngIf=\"((channelCount$ | async) || 0) >= displayFilterThreshold\"\r\n [formControl]=\"filterControl\"\r\n type=\"text\"\r\n class=\"ml2 mr2\"\r\n [placeholder]=\"'common.filter' | translate\"\r\n />\r\n <button\r\n *ngFor=\"let channel of channels$ | async\"\r\n type=\"button\"\r\n vdrDropdownItem\r\n (click)=\"setActiveChannel(channel.id)\"\r\n >\r\n <vdr-channel-badge [channelCode]=\"channel.code\"></vdr-channel-badge>\r\n {{ channel.code | channelCodeToLabel | translate }}\r\n </button>\r\n </vdr-dropdown-menu>\r\n </vdr-dropdown>\r\n</ng-container>\r\n", styles: [":host{display:block;align-items:center;height:2.5rem}.active-channel{display:flex;justify-content:space-between;align-items:center;font-size:var(--font-size-xs);color:var(--color-left-nav-text);background-color:var(--color-channel-switcher-bg);border:none;cursor:pointer;width:100%;border-radius:var(--border-radius-lg);padding:var(--space-unit) calc(var(--space-unit) * 2);transition:background-color .1s,color .1s}.active-channel:hover{background-color:var(--color-channel-switcher-hover-bg);color:var(--color-left-nav-text-hover)}.active-channel clr-icon{color:var(--color-left-nav-text)}.channel-label{margin:0 3px;overflow:hidden;flex:1;white-space:nowrap;text-overflow:ellipsis}\n"] }]
|
|
49
49
|
}], ctorParameters: function () { return [{ type: i1.DataService }, { type: i2.ChannelService }]; } });
|
|
50
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
50
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhbm5lbC1zd2l0Y2hlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvcmUvc3JjL2NvbXBvbmVudHMvY2hhbm5lbC1zd2l0Y2hlci9jaGFubmVsLXN3aXRjaGVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29yZS9zcmMvY29tcG9uZW50cy9jaGFubmVsLXN3aXRjaGVyL2NoYW5uZWwtc3dpdGNoZXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUMzRSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNwRCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUN0RSxPQUFPLEVBQUUsYUFBYSxFQUFjLE1BQU0sTUFBTSxDQUFDO0FBQ2pELE9BQU8sRUFBRSxNQUFNLEVBQUUsR0FBRyxFQUFFLFNBQVMsRUFBRSxNQUFNLGdCQUFnQixDQUFDOzs7Ozs7Ozs7Ozs7Ozs7QUFZeEQsTUFBTSxPQUFPLHdCQUF3QjtJQU1qQyxZQUFvQixXQUF3QixFQUFVLGNBQThCO1FBQWhFLGdCQUFXLEdBQVgsV0FBVyxDQUFhO1FBQVUsbUJBQWMsR0FBZCxjQUFjLENBQWdCO1FBTDNFLDJCQUFzQixHQUFHLEVBQUUsQ0FBQztRQUdyQyxrQkFBYSxHQUFHLElBQUksa0JBQWtCLENBQUMsRUFBRSxDQUFDLENBQUM7SUFFNEMsQ0FBQztJQUV4RixRQUFRO1FBQ0osTUFBTSxTQUFTLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxNQUFNLENBQUMsVUFBVSxFQUFFLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUNuRyxNQUFNLFdBQVcsR0FBRyxJQUFJLENBQUMsYUFBYSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQVMsU0FBUyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDaEYsSUFBSSxDQUFDLFNBQVMsR0FBRyxhQUFhLENBQUMsU0FBUyxFQUFFLFdBQVcsQ0FBQyxDQUFDLElBQUksQ0FDdkQsR0FBRyxDQUFDLENBQUMsQ0FBQyxRQUFRLEVBQUUsVUFBVSxDQUFDLEVBQUUsRUFBRSxDQUFDLFVBQVU7WUFDbEMsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FDaEIsQ0FBQyxDQUFDLElBQUksQ0FBQyxpQkFBaUIsRUFBRSxDQUFDLFFBQVEsQ0FBQyxVQUFVLENBQUMsaUJBQWlCLEVBQUUsQ0FBQyxDQUN0RTtZQUNILENBQUMsQ0FBQyxRQUFRLENBQUMsQ0FDdEIsQ0FBQztRQUNGLElBQUksQ0FBQyxhQUFhLEdBQUcsU0FBUyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsUUFBUSxDQUFDLEVBQUUsQ0FBQyxRQUFRLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQztRQUN0RSxNQUFNLGNBQWMsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLE1BQU07YUFDekMsVUFBVSxFQUFFO2FBQ1osU0FBUyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLEVBQUUsS0FBSyxJQUFJLENBQUMsVUFBVSxDQUFDLGVBQWUsQ0FBQyxDQUFDO2FBQy9GLElBQUksQ0FBQyxNQUFNLENBQUMsa0JBQWtCLENBQUMsQ0FBQyxDQUFDO1FBQ3RDLElBQUksQ0FBQyxrQkFBa0IsR0FBRyxjQUFjLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO0lBQ2hGLENBQUM7SUFFRCxnQkFBZ0IsQ0FBQyxTQUFpQjtRQUM5QixJQUFJLENBQUMsY0FBYyxDQUFDLGdCQUFnQixDQUFDLFNBQVMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLFVBQVUsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO0lBQ3ZHLENBQUM7OEdBNUJRLHdCQUF3QjtrR0FBeEIsd0JBQXdCLDREQ2hCckMsKzBDQTZCQTs7MkZEYmEsd0JBQXdCO2tCQU5wQyxTQUFTOytCQUNJLHNCQUFzQixtQkFHZix1QkFBdUIsQ0FBQyxNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFVudHlwZWRGb3JtQ29udHJvbCB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IHsgbm90TnVsbE9yVW5kZWZpbmVkIH0gZnJvbSAnQHZlbmR1cmUvY29tbW9uL2xpYi9zaGFyZWQtdXRpbHMnO1xyXG5pbXBvcnQgeyBjb21iaW5lTGF0ZXN0LCBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcyc7XHJcbmltcG9ydCB7IGZpbHRlciwgbWFwLCBzdGFydFdpdGggfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XHJcblxyXG5pbXBvcnQgeyBDdXJyZW50VXNlckNoYW5uZWwgfSBmcm9tICcuLi8uLi9jb21tb24vZ2VuZXJhdGVkLXR5cGVzJztcclxuaW1wb3J0IHsgRGF0YVNlcnZpY2UgfSBmcm9tICcuLi8uLi9kYXRhL3Byb3ZpZGVycy9kYXRhLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBDaGFubmVsU2VydmljZSB9IGZyb20gJy4uLy4uL3Byb3ZpZGVycy9jaGFubmVsL2NoYW5uZWwuc2VydmljZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICAgIHNlbGVjdG9yOiAndmRyLWNoYW5uZWwtc3dpdGNoZXInLFxyXG4gICAgdGVtcGxhdGVVcmw6ICcuL2NoYW5uZWwtc3dpdGNoZXIuY29tcG9uZW50Lmh0bWwnLFxyXG4gICAgc3R5bGVVcmxzOiBbJy4vY2hhbm5lbC1zd2l0Y2hlci5jb21wb25lbnQuc2NzcyddLFxyXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDaGFubmVsU3dpdGNoZXJDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xyXG4gICAgcmVhZG9ubHkgZGlzcGxheUZpbHRlclRocmVzaG9sZCA9IDEwO1xyXG4gICAgY2hhbm5lbHMkOiBPYnNlcnZhYmxlPEN1cnJlbnRVc2VyQ2hhbm5lbFtdPjtcclxuICAgIGNoYW5uZWxDb3VudCQ6IE9ic2VydmFibGU8bnVtYmVyPjtcclxuICAgIGZpbHRlckNvbnRyb2wgPSBuZXcgVW50eXBlZEZvcm1Db250cm9sKCcnKTtcclxuICAgIGFjdGl2ZUNoYW5uZWxDb2RlJDogT2JzZXJ2YWJsZTxzdHJpbmc+O1xyXG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSBkYXRhU2VydmljZTogRGF0YVNlcnZpY2UsIHByaXZhdGUgY2hhbm5lbFNlcnZpY2U6IENoYW5uZWxTZXJ2aWNlKSB7fVxyXG5cclxuICAgIG5nT25Jbml0KCkge1xyXG4gICAgICAgIGNvbnN0IGNoYW5uZWxzJCA9IHRoaXMuZGF0YVNlcnZpY2UuY2xpZW50LnVzZXJTdGF0dXMoKS5tYXBTdHJlYW0oZGF0YSA9PiBkYXRhLnVzZXJTdGF0dXMuY2hhbm5lbHMpO1xyXG4gICAgICAgIGNvbnN0IGZpbHRlclRlcm0kID0gdGhpcy5maWx0ZXJDb250cm9sLnZhbHVlQ2hhbmdlcy5waXBlPHN0cmluZz4oc3RhcnRXaXRoKCcnKSk7XHJcbiAgICAgICAgdGhpcy5jaGFubmVscyQgPSBjb21iaW5lTGF0ZXN0KGNoYW5uZWxzJCwgZmlsdGVyVGVybSQpLnBpcGUoXHJcbiAgICAgICAgICAgIG1hcCgoW2NoYW5uZWxzLCBmaWx0ZXJUZXJtXSkgPT4gZmlsdGVyVGVybVxyXG4gICAgICAgICAgICAgICAgICAgID8gY2hhbm5lbHMuZmlsdGVyKGMgPT5cclxuICAgICAgICAgICAgICAgICAgICAgICAgICBjLmNvZGUudG9Mb2NhbGVMb3dlckNhc2UoKS5pbmNsdWRlcyhmaWx0ZXJUZXJtLnRvTG9jYWxlTG93ZXJDYXNlKCkpLFxyXG4gICAgICAgICAgICAgICAgICAgICAgKVxyXG4gICAgICAgICAgICAgICAgICAgIDogY2hhbm5lbHMpLFxyXG4gICAgICAgICk7XHJcbiAgICAgICAgdGhpcy5jaGFubmVsQ291bnQkID0gY2hhbm5lbHMkLnBpcGUobWFwKGNoYW5uZWxzID0+IGNoYW5uZWxzLmxlbmd0aCkpO1xyXG4gICAgICAgIGNvbnN0IGFjdGl2ZUNoYW5uZWwkID0gdGhpcy5kYXRhU2VydmljZS5jbGllbnRcclxuICAgICAgICAgICAgLnVzZXJTdGF0dXMoKVxyXG4gICAgICAgICAgICAubWFwU3RyZWFtKGRhdGEgPT4gZGF0YS51c2VyU3RhdHVzLmNoYW5uZWxzLmZpbmQoYyA9PiBjLmlkID09PSBkYXRhLnVzZXJTdGF0dXMuYWN0aXZlQ2hhbm5lbElkKSlcclxuICAgICAgICAgICAgLnBpcGUoZmlsdGVyKG5vdE51bGxPclVuZGVmaW5lZCkpO1xyXG4gICAgICAgIHRoaXMuYWN0aXZlQ2hhbm5lbENvZGUkID0gYWN0aXZlQ2hhbm5lbCQucGlwZShtYXAoY2hhbm5lbCA9PiBjaGFubmVsLmNvZGUpKTtcclxuICAgIH1cclxuXHJcbiAgICBzZXRBY3RpdmVDaGFubmVsKGNoYW5uZWxJZDogc3RyaW5nKSB7XHJcbiAgICAgICAgdGhpcy5jaGFubmVsU2VydmljZS5zZXRBY3RpdmVDaGFubmVsKGNoYW5uZWxJZCkuc3Vic2NyaWJlKCgpID0+IHRoaXMuZmlsdGVyQ29udHJvbC5wYXRjaFZhbHVlKCcnKSk7XHJcbiAgICB9XHJcbn1cclxuIiwiPG5nLWNvbnRhaW5lcj5cclxuICAgIDx2ZHItZHJvcGRvd24+XHJcbiAgICAgICAgPGJ1dHRvbiBjbGFzcz1cImFjdGl2ZS1jaGFubmVsIG0tYXV0b1wiIHZkckRyb3Bkb3duVHJpZ2dlcj5cclxuICAgICAgICAgICAgPHZkci1jaGFubmVsLWJhZGdlIFtjaGFubmVsQ29kZV09XCJhY3RpdmVDaGFubmVsQ29kZSQgfCBhc3luY1wiPjwvdmRyLWNoYW5uZWwtYmFkZ2U+XHJcbiAgICAgICAgICAgIDxzcGFuIGNsYXNzPVwiY2hhbm5lbC1sYWJlbFwiPnt7XHJcbiAgICAgICAgICAgICAgICBhY3RpdmVDaGFubmVsQ29kZSQgfCBhc3luYyB8IGNoYW5uZWxDb2RlVG9MYWJlbCB8IHRyYW5zbGF0ZVxyXG4gICAgICAgICAgICB9fTwvc3Bhbj5cclxuICAgICAgICAgICAgPHNwYW4gY2xhc3M9XCJ0cmlnZ2VyXCI+PGNsci1pY29uIHNoYXBlPVwiZWxsaXBzaXMtdmVydGljYWxcIiBzaXplPVwiMTJcIj48L2Nsci1pY29uPjwvc3Bhbj5cclxuICAgICAgICA8L2J1dHRvbj5cclxuICAgICAgICA8dmRyLWRyb3Bkb3duLW1lbnUgdmRyUG9zaXRpb249XCJib3R0b20tcmlnaHRcIj5cclxuICAgICAgICAgICAgPGlucHV0XHJcbiAgICAgICAgICAgICAgICAqbmdJZj1cIigoY2hhbm5lbENvdW50JCB8IGFzeW5jKSB8fCAwKSA+PSBkaXNwbGF5RmlsdGVyVGhyZXNob2xkXCJcclxuICAgICAgICAgICAgICAgIFtmb3JtQ29udHJvbF09XCJmaWx0ZXJDb250cm9sXCJcclxuICAgICAgICAgICAgICAgIHR5cGU9XCJ0ZXh0XCJcclxuICAgICAgICAgICAgICAgIGNsYXNzPVwibWwyIG1yMlwiXHJcbiAgICAgICAgICAgICAgICBbcGxhY2Vob2xkZXJdPVwiJ2NvbW1vbi5maWx0ZXInIHwgdHJhbnNsYXRlXCJcclxuICAgICAgICAgICAgLz5cclxuICAgICAgICAgICAgPGJ1dHRvblxyXG4gICAgICAgICAgICAgICAgKm5nRm9yPVwibGV0IGNoYW5uZWwgb2YgY2hhbm5lbHMkIHwgYXN5bmNcIlxyXG4gICAgICAgICAgICAgICAgdHlwZT1cImJ1dHRvblwiXHJcbiAgICAgICAgICAgICAgICB2ZHJEcm9wZG93bkl0ZW1cclxuICAgICAgICAgICAgICAgIChjbGljayk9XCJzZXRBY3RpdmVDaGFubmVsKGNoYW5uZWwuaWQpXCJcclxuICAgICAgICAgICAgPlxyXG4gICAgICAgICAgICAgICAgPHZkci1jaGFubmVsLWJhZGdlIFtjaGFubmVsQ29kZV09XCJjaGFubmVsLmNvZGVcIj48L3Zkci1jaGFubmVsLWJhZGdlPlxyXG4gICAgICAgICAgICAgICAge3sgY2hhbm5lbC5jb2RlIHwgY2hhbm5lbENvZGVUb0xhYmVsIHwgdHJhbnNsYXRlIH19XHJcbiAgICAgICAgICAgIDwvYnV0dG9uPlxyXG4gICAgICAgIDwvdmRyLWRyb3Bkb3duLW1lbnU+XHJcbiAgICA8L3Zkci1kcm9wZG93bj5cclxuPC9uZy1jb250YWluZXI+XHJcbiJdfQ==
|
|
@@ -29,4 +29,4 @@ export function setDashboardWidgetLayout(layoutDef) {
|
|
|
29
29
|
deps: [DashboardWidgetService],
|
|
30
30
|
};
|
|
31
31
|
}
|
|
32
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
32
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVnaXN0ZXItZGFzaGJvYXJkLXdpZGdldC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29yZS9zcmMvcHJvdmlkZXJzL2Rhc2hib2FyZC13aWRnZXQvcmVnaXN0ZXItZGFzaGJvYXJkLXdpZGdldC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZUFBZSxFQUFtQixNQUFNLGVBQWUsQ0FBQztBQUdqRSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUVwRTs7OztHQUlHO0FBQ0gsTUFBTSxVQUFVLHVCQUF1QixDQUFDLEVBQVUsRUFBRSxNQUE2QjtJQUM3RSxPQUFPO1FBQ0gsT0FBTyxFQUFFLGVBQWU7UUFDeEIsS0FBSyxFQUFFLElBQUk7UUFDWCxVQUFVLEVBQUUsQ0FBQyxzQkFBOEMsRUFBRSxFQUFFLENBQUMsR0FBRyxFQUFFO1lBQ2pFLHNCQUFzQixDQUFDLGNBQWMsQ0FBQyxFQUFFLEVBQUUsTUFBTSxDQUFDLENBQUM7UUFDdEQsQ0FBQztRQUNELElBQUksRUFBRSxDQUFDLHNCQUFzQixDQUFDO0tBQ2pDLENBQUM7QUFDTixDQUFDO0FBRUQ7OztHQUdHO0FBQ0gsTUFBTSxVQUFVLHdCQUF3QixDQUFDLFNBQWlDO0lBQ3RFLE9BQU87UUFDSCxPQUFPLEVBQUUsZUFBZTtRQUN4QixLQUFLLEVBQUUsSUFBSTtRQUNYLFVBQVUsRUFBRSxDQUFDLHNCQUE4QyxFQUFFLEVBQUUsQ0FBQyxHQUFHLEVBQUU7WUFDakUsc0JBQXNCLENBQUMsZ0JBQWdCLENBQUMsU0FBUyxDQUFDLENBQUM7UUFDdkQsQ0FBQztRQUNELElBQUksRUFBRSxDQUFDLHNCQUFzQixDQUFDO0tBQ2pDLENBQUM7QUFDTixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQVBQX0lOSVRJQUxJWkVSLCBGYWN0b3J5UHJvdmlkZXIgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbmltcG9ydCB7IERhc2hib2FyZFdpZGdldENvbmZpZywgV2lkZ2V0TGF5b3V0RGVmaW5pdGlvbiB9IGZyb20gJy4vZGFzaGJvYXJkLXdpZGdldC10eXBlcyc7XHJcbmltcG9ydCB7IERhc2hib2FyZFdpZGdldFNlcnZpY2UgfSBmcm9tICcuL2Rhc2hib2FyZC13aWRnZXQuc2VydmljZSc7XHJcblxyXG4vKipcclxuICogQGRlc2NyaXB0aW9uXHJcbiAqIFJlZ2lzdGVycyBhIGRhc2hib2FyZCB3aWRnZXQuIE9uY2UgcmVnaXN0ZXJlZCwgdGhlIHdpZGdldCBjYW4gYmUgc2V0IGFzIHBhcnQgb2YgdGhlIGRlZmF1bHRcclxuICogKHVzaW5nIHtAbGluayBzZXREYXNoYm9hcmRXaWRnZXRMYXlvdXR9KS5cclxuICovXHJcbmV4cG9ydCBmdW5jdGlvbiByZWdpc3RlckRhc2hib2FyZFdpZGdldChpZDogc3RyaW5nLCBjb25maWc6IERhc2hib2FyZFdpZGdldENvbmZpZyk6IEZhY3RvcnlQcm92aWRlciB7XHJcbiAgICByZXR1cm4ge1xyXG4gICAgICAgIHByb3ZpZGU6IEFQUF9JTklUSUFMSVpFUixcclxuICAgICAgICBtdWx0aTogdHJ1ZSxcclxuICAgICAgICB1c2VGYWN0b3J5OiAoZGFzaGJvYXJkV2lkZ2V0U2VydmljZTogRGFzaGJvYXJkV2lkZ2V0U2VydmljZSkgPT4gKCkgPT4ge1xyXG4gICAgICAgICAgICBkYXNoYm9hcmRXaWRnZXRTZXJ2aWNlLnJlZ2lzdGVyV2lkZ2V0KGlkLCBjb25maWcpO1xyXG4gICAgICAgIH0sXHJcbiAgICAgICAgZGVwczogW0Rhc2hib2FyZFdpZGdldFNlcnZpY2VdLFxyXG4gICAgfTtcclxufVxyXG5cclxuLyoqXHJcbiAqIEBkZXNjcmlwdGlvblxyXG4gKiBTZXRzIHRoZSBkZWZhdWx0IHdpZGdldCBsYXlvdXQgZm9yIHRoZSBBZG1pbiBVSSBkYXNoYm9hcmQuXHJcbiAqL1xyXG5leHBvcnQgZnVuY3Rpb24gc2V0RGFzaGJvYXJkV2lkZ2V0TGF5b3V0KGxheW91dERlZjogV2lkZ2V0TGF5b3V0RGVmaW5pdGlvbik6IEZhY3RvcnlQcm92aWRlciB7XHJcbiAgICByZXR1cm4ge1xyXG4gICAgICAgIHByb3ZpZGU6IEFQUF9JTklUSUFMSVpFUixcclxuICAgICAgICBtdWx0aTogdHJ1ZSxcclxuICAgICAgICB1c2VGYWN0b3J5OiAoZGFzaGJvYXJkV2lkZ2V0U2VydmljZTogRGFzaGJvYXJkV2lkZ2V0U2VydmljZSkgPT4gKCkgPT4ge1xyXG4gICAgICAgICAgICBkYXNoYm9hcmRXaWRnZXRTZXJ2aWNlLnNldERlZmF1bHRMYXlvdXQobGF5b3V0RGVmKTtcclxuICAgICAgICB9LFxyXG4gICAgICAgIGRlcHM6IFtEYXNoYm9hcmRXaWRnZXRTZXJ2aWNlXSxcclxuICAgIH07XHJcbn1cclxuIl19
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import { marker as _ } from '@biesbjerg/ngx-translate-extract-marker';
|
|
2
2
|
import { assertNever } from '@vendure/common/lib/shared-utils';
|
|
3
|
-
import { Subject } from 'rxjs';
|
|
4
3
|
import extend from 'just-extend';
|
|
4
|
+
import { Subject } from 'rxjs';
|
|
5
|
+
import { debounceTime, distinctUntilChanged, map, startWith } from 'rxjs/operators';
|
|
5
6
|
import { DataTableFilter, } from './data-table-filter';
|
|
6
7
|
export class FilterWithValue {
|
|
7
8
|
constructor(filter, value, onUpdate) {
|
|
@@ -21,6 +22,9 @@ export class FilterWithValue {
|
|
|
21
22
|
fn(value);
|
|
22
23
|
}
|
|
23
24
|
}
|
|
25
|
+
isId() {
|
|
26
|
+
return this.filter.type.kind === 'id';
|
|
27
|
+
}
|
|
24
28
|
isText() {
|
|
25
29
|
return this.filter.type.kind === 'text';
|
|
26
30
|
}
|
|
@@ -52,7 +56,7 @@ export class DataTableFilterCollection {
|
|
|
52
56
|
this.#activeFilters = [];
|
|
53
57
|
this.#valueChanges$ = new Subject();
|
|
54
58
|
this.#connectedToRouter = false;
|
|
55
|
-
this.valueChanges = this.#valueChanges$.asObservable();
|
|
59
|
+
this.valueChanges = this.#valueChanges$.asObservable().pipe(debounceTime(10));
|
|
56
60
|
this.#filtersQueryParamName = 'filters';
|
|
57
61
|
}
|
|
58
62
|
get length() {
|
|
@@ -74,6 +78,15 @@ export class DataTableFilterCollection {
|
|
|
74
78
|
}
|
|
75
79
|
return this;
|
|
76
80
|
}
|
|
81
|
+
addIdFilter() {
|
|
82
|
+
this.addFilter({
|
|
83
|
+
name: 'id',
|
|
84
|
+
type: { kind: 'id' },
|
|
85
|
+
label: _('common.id'),
|
|
86
|
+
filterField: 'id',
|
|
87
|
+
});
|
|
88
|
+
return this;
|
|
89
|
+
}
|
|
77
90
|
addDateFilters() {
|
|
78
91
|
this.addFilter({
|
|
79
92
|
name: 'createdAt',
|
|
@@ -148,29 +161,46 @@ export class DataTableFilterCollection {
|
|
|
148
161
|
}, {});
|
|
149
162
|
}
|
|
150
163
|
connectToRoute(route) {
|
|
151
|
-
this.valueChanges.subscribe(
|
|
164
|
+
this.valueChanges.subscribe(() => {
|
|
152
165
|
this.router.navigate(['./'], {
|
|
153
166
|
queryParams: { [this.#filtersQueryParamName]: this.serialize(), page: 1 },
|
|
154
167
|
relativeTo: route,
|
|
155
168
|
queryParamsHandling: 'merge',
|
|
156
169
|
});
|
|
157
170
|
});
|
|
158
|
-
|
|
159
|
-
.
|
|
160
|
-
.
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
const val = this.deserializeValue(filter, value);
|
|
166
|
-
this.#activeFilters.push(this.createFacetWithValue(filter, val));
|
|
171
|
+
route.queryParamMap
|
|
172
|
+
.pipe(map(params => params.get(this.#filtersQueryParamName)), distinctUntilChanged(), startWith(route.snapshot.queryParamMap.get(this.#filtersQueryParamName) ?? ''))
|
|
173
|
+
.subscribe(value => {
|
|
174
|
+
this.#activeFilters = [];
|
|
175
|
+
if (value === '') {
|
|
176
|
+
this.#valueChanges$.next(this.#activeFilters);
|
|
177
|
+
return;
|
|
167
178
|
}
|
|
168
|
-
|
|
179
|
+
const filterQueryParams = (value ?? '')
|
|
180
|
+
.split(';')
|
|
181
|
+
.map(value => value.split(':'))
|
|
182
|
+
.map(([name, value]) => ({ name, value }));
|
|
183
|
+
for (const { name, value } of filterQueryParams) {
|
|
184
|
+
const filter = this.getFilter(name);
|
|
185
|
+
if (filter) {
|
|
186
|
+
const val = this.deserializeValue(filter, value);
|
|
187
|
+
filter.activate(val);
|
|
188
|
+
}
|
|
189
|
+
}
|
|
190
|
+
});
|
|
169
191
|
this.#connectedToRouter = true;
|
|
170
192
|
return this;
|
|
171
193
|
}
|
|
194
|
+
serialize() {
|
|
195
|
+
return this.#activeFilters
|
|
196
|
+
.map((filterWithValue, i) => `${filterWithValue.filter.name}:${this.serializeValue(filterWithValue)}`)
|
|
197
|
+
.join(';');
|
|
198
|
+
}
|
|
172
199
|
serializeValue(filterWithValue) {
|
|
173
|
-
|
|
200
|
+
if (filterWithValue.isId()) {
|
|
201
|
+
const val = filterWithValue.value;
|
|
202
|
+
return `${val?.operator},${val?.term}`;
|
|
203
|
+
}
|
|
174
204
|
if (filterWithValue.isText()) {
|
|
175
205
|
const val = filterWithValue.value;
|
|
176
206
|
return `${val?.operator},${val?.term}`;
|
|
@@ -199,6 +229,10 @@ export class DataTableFilterCollection {
|
|
|
199
229
|
}
|
|
200
230
|
deserializeValue(filter, value) {
|
|
201
231
|
switch (filter.type.kind) {
|
|
232
|
+
case 'id': {
|
|
233
|
+
const [operator, term] = value.split(',');
|
|
234
|
+
return { operator, term };
|
|
235
|
+
}
|
|
202
236
|
case 'text': {
|
|
203
237
|
const [operator, term] = value.split(',');
|
|
204
238
|
return { operator, term };
|
|
@@ -222,17 +256,12 @@ export class DataTableFilterCollection {
|
|
|
222
256
|
assertNever(filter.type);
|
|
223
257
|
}
|
|
224
258
|
}
|
|
225
|
-
serialize() {
|
|
226
|
-
return this.#activeFilters
|
|
227
|
-
.map((filterWithValue, i) => `${filterWithValue.filter.name}:${this.serializeValue(filterWithValue)}`)
|
|
228
|
-
.join(';');
|
|
229
|
-
}
|
|
230
259
|
onActivateFilter(filter, value) {
|
|
231
|
-
this.#activeFilters.push(this.
|
|
260
|
+
this.#activeFilters.push(this.createFilterWithValue(filter, value));
|
|
232
261
|
this.#valueChanges$.next(this.#activeFilters);
|
|
233
262
|
}
|
|
234
|
-
|
|
263
|
+
createFilterWithValue(filter, value) {
|
|
235
264
|
return new FilterWithValue(filter, value, v => this.#valueChanges$.next(v));
|
|
236
265
|
}
|
|
237
266
|
}
|
|
238
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table-filter-collection.js","sourceRoot":"","sources":["../../../../../src/lib/core/src/providers/data-table/data-table-filter-collection.ts"],"names":[],"mappings":"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","sourcesContent":["import { ActivatedRoute, Router } from '@angular/router';\r\nimport { marker as _ } from '@biesbjerg/ngx-translate-extract-marker';\r\nimport { CustomFieldType } from '@vendure/common/lib/shared-types';\r\nimport { assertNever } from '@vendure/common/lib/shared-utils';\r\nimport { Subject } from 'rxjs';\r\nimport extend from 'just-extend';\r\nimport {\r\n    CustomFieldConfig,\r\n    DateOperators,\r\n    NumberOperators,\r\n    StringOperators,\r\n} from '../../common/generated-types';\r\nimport {\r\n    DataTableFilter,\r\n    DataTableFilterBooleanType,\r\n    DataTableFilterCustomType,\r\n    DataTableFilterDateRangeType,\r\n    DataTableFilterNumberType,\r\n    DataTableFilterOptions,\r\n    DataTableFilterSelectType,\r\n    DataTableFilterTextType,\r\n    DataTableFilterType,\r\n    DataTableFilterValue,\r\n} from './data-table-filter';\r\n\r\nexport class FilterWithValue<Type extends DataTableFilterType = DataTableFilterType> {\r\n    private onUpdateFns = new Set<(value: DataTableFilterValue<Type>) => void>();\r\n    constructor(\r\n        public readonly filter: DataTableFilter<any, Type>,\r\n        public value: DataTableFilterValue<Type>,\r\n        onUpdate?: (value: DataTableFilterValue<Type>) => void,\r\n    ) {\r\n        if (onUpdate) {\r\n            this.onUpdateFns.add(onUpdate);\r\n        }\r\n    }\r\n\r\n    onUpdate(fn: (value: DataTableFilterValue<Type>) => void) {\r\n        this.onUpdateFns.add(fn);\r\n    }\r\n\r\n    updateValue(value: DataTableFilterValue<Type>) {\r\n        this.value = value;\r\n        for (const fn of this.onUpdateFns) {\r\n            fn(value);\r\n        }\r\n    }\r\n\r\n    isText(): this is FilterWithValue<DataTableFilterTextType> {\r\n        return this.filter.type.kind === 'text';\r\n    }\r\n\r\n    isNumber(): this is FilterWithValue<DataTableFilterNumberType> {\r\n        return this.filter.type.kind === 'number';\r\n    }\r\n\r\n    isBoolean(): this is FilterWithValue<DataTableFilterBooleanType> {\r\n        return this.filter.type.kind === 'boolean';\r\n    }\r\n\r\n    isSelect(): this is FilterWithValue<DataTableFilterSelectType> {\r\n        return this.filter.type.kind === 'select';\r\n    }\r\n\r\n    isDateRange(): this is FilterWithValue<DataTableFilterDateRangeType> {\r\n        return this.filter.type.kind === 'dateRange';\r\n    }\r\n\r\n    isCustom(): this is FilterWithValue<DataTableFilterCustomType> {\r\n        return this.filter.type.kind === 'custom';\r\n    }\r\n}\r\n\r\nexport class DataTableFilterCollection<FilterInput extends Record<string, any> = Record<string, any>> {\r\n    readonly #filters: Array<DataTableFilter<FilterInput, any>> = [];\r\n    #activeFilters: FilterWithValue[] = [];\r\n    #valueChanges$ = new Subject<FilterWithValue[]>();\r\n    #connectedToRouter = false;\r\n    valueChanges = this.#valueChanges$.asObservable();\r\n    readonly #filtersQueryParamName = 'filters';\r\n\r\n    constructor(private router: Router) {}\r\n\r\n    get length(): number {\r\n        return this.#filters.length;\r\n    }\r\n\r\n    get activeFilters(): FilterWithValue[] {\r\n        return this.#activeFilters;\r\n    }\r\n\r\n    addFilter<FilterType extends DataTableFilterType>(\r\n        config: DataTableFilterOptions<FilterInput, FilterType>,\r\n    ): DataTableFilterCollection<FilterInput> {\r\n        if (this.#connectedToRouter) {\r\n            throw new Error(\r\n                'Cannot add filter after connecting to router. Make sure to call addFilter() before connectToRoute()',\r\n            );\r\n        }\r\n        this.#filters.push(\r\n            new DataTableFilter(config, (filter, value) => this.onActivateFilter(filter, value)),\r\n        );\r\n        return this;\r\n    }\r\n\r\n    addFilters<FilterType extends DataTableFilterType>(\r\n        configs: Array<DataTableFilterOptions<FilterInput, FilterType>>,\r\n    ): DataTableFilterCollection<FilterInput> {\r\n        for (const config of configs) {\r\n            this.addFilter(config);\r\n        }\r\n        return this;\r\n    }\r\n\r\n    addDateFilters(): FilterInput extends {\r\n        createdAt?: DateOperators | null;\r\n        updatedAt?: DateOperators | null;\r\n    }\r\n        ? DataTableFilterCollection<FilterInput>\r\n        : never {\r\n        this.addFilter({\r\n            name: 'createdAt',\r\n            type: { kind: 'dateRange' },\r\n            label: _('common.created-at'),\r\n            filterField: 'createdAt',\r\n        });\r\n        this.addFilter({\r\n            name: 'updatedAt',\r\n            type: { kind: 'dateRange' },\r\n            label: _('common.updated-at'),\r\n            filterField: 'updatedAt',\r\n        });\r\n        return this as any;\r\n    }\r\n\r\n    addCustomFieldFilters(customFields: CustomFieldConfig[]) {\r\n        for (const config of customFields) {\r\n            const type = config.type as CustomFieldType;\r\n            if (config.list) {\r\n                continue;\r\n            }\r\n            let filterType: DataTableFilterType | undefined;\r\n            switch (type) {\r\n                case 'boolean':\r\n                    filterType = { kind: 'boolean' };\r\n                    break;\r\n                case 'int':\r\n                case 'float':\r\n                    filterType = { kind: 'number' };\r\n                    break;\r\n                case 'datetime':\r\n                    filterType = { kind: 'dateRange' };\r\n                    break;\r\n                case 'string':\r\n                case 'localeString':\r\n                case 'localeText':\r\n                case 'text':\r\n                    filterType = { kind: 'text' };\r\n                    break;\r\n                case 'relation':\r\n                    // Cannot sort relations\r\n                    break;\r\n                default:\r\n                    assertNever(type);\r\n            }\r\n            if (filterType) {\r\n                this.addFilter({\r\n                    name: config.name,\r\n                    type: filterType,\r\n                    label: config.label ?? config.name,\r\n                    filterField: config.name,\r\n                });\r\n            }\r\n        }\r\n        return this;\r\n    }\r\n\r\n    getFilter(name: string): DataTableFilter<FilterInput> | undefined {\r\n        return this.#filters.find(f => f.name === name);\r\n    }\r\n\r\n    getFilters(): Array<DataTableFilter<FilterInput>> {\r\n        return this.#filters;\r\n    }\r\n\r\n    removeActiveFilterAtIndex(index: number) {\r\n        this.#activeFilters.splice(index, 1);\r\n        this.#valueChanges$.next(this.#activeFilters);\r\n    }\r\n\r\n    createFilterInput(): FilterInput {\r\n        return this.#activeFilters.reduce((acc, { filter, value }) => {\r\n            const newValue = value != null ? filter.toFilterInput(value) : {};\r\n            const result = extend(true, acc, newValue);\r\n            return result as FilterInput;\r\n        }, {} as FilterInput);\r\n    }\r\n\r\n    connectToRoute(route: ActivatedRoute) {\r\n        this.valueChanges.subscribe(value => {\r\n            this.router.navigate(['./'], {\r\n                queryParams: { [this.#filtersQueryParamName]: this.serialize(), page: 1 },\r\n                relativeTo: route,\r\n                queryParamsHandling: 'merge',\r\n            });\r\n        });\r\n        const filterQueryParams = (route.snapshot.queryParamMap.get(this.#filtersQueryParamName) ?? '')\r\n            .split(';')\r\n            .map(value => value.split(':'))\r\n            .map(([name, value]) => ({ name, value }));\r\n        for (const { name, value } of filterQueryParams) {\r\n            const filter = this.getFilter(name);\r\n            if (filter) {\r\n                const val = this.deserializeValue(filter, value);\r\n                this.#activeFilters.push(this.createFacetWithValue(filter, val));\r\n            }\r\n        }\r\n        this.#connectedToRouter = true;\r\n        return this;\r\n    }\r\n\r\n    serializeValue<Type extends DataTableFilterType>(\r\n        filterWithValue: FilterWithValue<Type>,\r\n    ): string | undefined {\r\n        const valueAsType = <T extends DataTableFilter<any, any>>(\r\n            _filter: T,\r\n            _value: DataTableFilterValue<any>,\r\n        ): T extends DataTableFilter<any, infer R> ? DataTableFilterValue<R> : any => _value;\r\n\r\n        if (filterWithValue.isText()) {\r\n            const val = filterWithValue.value;\r\n            return `${val?.operator},${val?.term}`;\r\n        } else if (filterWithValue.isNumber()) {\r\n            const val = filterWithValue.value;\r\n            return `${val.operator},${val.amount}`;\r\n        } else if (filterWithValue.isSelect()) {\r\n            const val = filterWithValue.value;\r\n            return val.join(',');\r\n        } else if (filterWithValue.isBoolean()) {\r\n            const val = filterWithValue.value;\r\n            return val ? '1' : '0';\r\n        } else if (filterWithValue.isDateRange()) {\r\n            const val = filterWithValue.value;\r\n            const start = val.start ? new Date(val.start).getTime() : '';\r\n            const end = val.end ? new Date(val.end).getTime() : '';\r\n            return `${start},${end}`;\r\n        } else if (filterWithValue.isCustom()) {\r\n            return filterWithValue.filter.type.serializeValue(filterWithValue.value);\r\n        }\r\n    }\r\n\r\n    deserializeValue(filter: DataTableFilter, value: string): DataTableFilterValue<DataTableFilterType> {\r\n        switch (filter.type.kind) {\r\n            case 'text': {\r\n                const [operator, term] = value.split(',') as [keyof StringOperators, string];\r\n                return { operator, term };\r\n            }\r\n            case 'number': {\r\n                const [operator, amount] = value.split(',') as [keyof NumberOperators, string];\r\n                return { operator, amount: +amount };\r\n            }\r\n            case 'select':\r\n                return value.split(',');\r\n            case 'boolean':\r\n                return value === '1';\r\n            case 'dateRange':\r\n                const [startTimestamp, endTimestamp] = value.split(',');\r\n                const start = startTimestamp ? new Date(Number(startTimestamp)).toISOString() : '';\r\n                const end = endTimestamp ? new Date(Number(endTimestamp)).toISOString() : '';\r\n                return { start, end };\r\n            case 'custom':\r\n                return filter.type.deserializeValue(value);\r\n            default:\r\n                assertNever(filter.type);\r\n        }\r\n    }\r\n\r\n    private serialize(): string {\r\n        return this.#activeFilters\r\n            .map(\r\n                (filterWithValue, i) =>\r\n                    `${filterWithValue.filter.name}:${this.serializeValue(filterWithValue)}`,\r\n            )\r\n            .join(';');\r\n    }\r\n\r\n    private onActivateFilter(filter: DataTableFilter<any, any>, value: DataTableFilterValue<any>) {\r\n        this.#activeFilters.push(this.createFacetWithValue(filter, value));\r\n        this.#valueChanges$.next(this.#activeFilters);\r\n    }\r\n\r\n    private createFacetWithValue(\r\n        filter: DataTableFilter<any, any>,\r\n        value: DataTableFilterValue<DataTableFilterType>,\r\n    ) {\r\n        return new FilterWithValue(filter, value, v => this.#valueChanges$.next(v));\r\n    }\r\n}\r\n"]}
|
|
267
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table-filter-collection.js","sourceRoot":"","sources":["../../../../../src/lib/core/src/providers/data-table/data-table-filter-collection.ts"],"names":[],"mappings":"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","sourcesContent":["import { ActivatedRoute, Router } from '@angular/router';\r\nimport { marker as _ } from '@biesbjerg/ngx-translate-extract-marker';\r\nimport { CustomFieldType } from '@vendure/common/lib/shared-types';\r\nimport { assertNever } from '@vendure/common/lib/shared-utils';\r\nimport extend from 'just-extend';\r\nimport { Subject } from 'rxjs';\r\nimport { debounceTime, distinctUntilChanged, map, startWith } from 'rxjs/operators';\r\nimport {\r\n    CustomFieldConfig,\r\n    DateOperators,\r\n    IdOperators,\r\n    NumberOperators,\r\n    StringOperators,\r\n} from '../../common/generated-types';\r\nimport {\r\n    DataTableFilter,\r\n    DataTableFilterBooleanType,\r\n    DataTableFilterCustomType,\r\n    DataTableFilterDateRangeType,\r\n    DataTableFilterIDType,\r\n    DataTableFilterNumberType,\r\n    DataTableFilterOptions,\r\n    DataTableFilterSelectType,\r\n    DataTableFilterTextType,\r\n    DataTableFilterType,\r\n    DataTableFilterValue,\r\n} from './data-table-filter';\r\n\r\nexport class FilterWithValue<Type extends DataTableFilterType = DataTableFilterType> {\r\n    private onUpdateFns = new Set<(value: DataTableFilterValue<Type>) => void>();\r\n    constructor(\r\n        public readonly filter: DataTableFilter<any, Type>,\r\n        public value: DataTableFilterValue<Type>,\r\n        onUpdate?: (value: DataTableFilterValue<Type>) => void,\r\n    ) {\r\n        if (onUpdate) {\r\n            this.onUpdateFns.add(onUpdate);\r\n        }\r\n    }\r\n\r\n    onUpdate(fn: (value: DataTableFilterValue<Type>) => void) {\r\n        this.onUpdateFns.add(fn);\r\n    }\r\n\r\n    updateValue(value: DataTableFilterValue<Type>) {\r\n        this.value = value;\r\n        for (const fn of this.onUpdateFns) {\r\n            fn(value);\r\n        }\r\n    }\r\n\r\n    isId(): this is FilterWithValue<DataTableFilterIDType> {\r\n        return this.filter.type.kind === 'id';\r\n    }\r\n\r\n    isText(): this is FilterWithValue<DataTableFilterTextType> {\r\n        return this.filter.type.kind === 'text';\r\n    }\r\n\r\n    isNumber(): this is FilterWithValue<DataTableFilterNumberType> {\r\n        return this.filter.type.kind === 'number';\r\n    }\r\n\r\n    isBoolean(): this is FilterWithValue<DataTableFilterBooleanType> {\r\n        return this.filter.type.kind === 'boolean';\r\n    }\r\n\r\n    isSelect(): this is FilterWithValue<DataTableFilterSelectType> {\r\n        return this.filter.type.kind === 'select';\r\n    }\r\n\r\n    isDateRange(): this is FilterWithValue<DataTableFilterDateRangeType> {\r\n        return this.filter.type.kind === 'dateRange';\r\n    }\r\n\r\n    isCustom(): this is FilterWithValue<DataTableFilterCustomType> {\r\n        return this.filter.type.kind === 'custom';\r\n    }\r\n}\r\n\r\nexport class DataTableFilterCollection<FilterInput extends Record<string, any> = Record<string, any>> {\r\n    readonly #filters: Array<DataTableFilter<FilterInput, any>> = [];\r\n    #activeFilters: FilterWithValue[] = [];\r\n    #valueChanges$ = new Subject<FilterWithValue[]>();\r\n    #connectedToRouter = false;\r\n    valueChanges = this.#valueChanges$.asObservable().pipe(debounceTime(10));\r\n    readonly #filtersQueryParamName = 'filters';\r\n\r\n    constructor(private router: Router) {}\r\n\r\n    get length(): number {\r\n        return this.#filters.length;\r\n    }\r\n\r\n    get activeFilters(): FilterWithValue[] {\r\n        return this.#activeFilters;\r\n    }\r\n\r\n    addFilter<FilterType extends DataTableFilterType>(\r\n        config: DataTableFilterOptions<FilterInput, FilterType>,\r\n    ): DataTableFilterCollection<FilterInput> {\r\n        if (this.#connectedToRouter) {\r\n            throw new Error(\r\n                'Cannot add filter after connecting to router. Make sure to call addFilter() before connectToRoute()',\r\n            );\r\n        }\r\n        this.#filters.push(\r\n            new DataTableFilter(config, (filter, value) => this.onActivateFilter(filter, value)),\r\n        );\r\n        return this;\r\n    }\r\n\r\n    addFilters<FilterType extends DataTableFilterType>(\r\n        configs: Array<DataTableFilterOptions<FilterInput, FilterType>>,\r\n    ): DataTableFilterCollection<FilterInput> {\r\n        for (const config of configs) {\r\n            this.addFilter(config);\r\n        }\r\n        return this;\r\n    }\r\n\r\n    addIdFilter(): FilterInput extends {\r\n        id?: IdOperators | null;\r\n    }\r\n        ? DataTableFilterCollection<FilterInput>\r\n        : never {\r\n        this.addFilter({\r\n            name: 'id',\r\n            type: { kind: 'id' },\r\n            label: _('common.id'),\r\n            filterField: 'id',\r\n        });\r\n        return this as any;\r\n    }\r\n\r\n    addDateFilters(): FilterInput extends {\r\n        createdAt?: DateOperators | null;\r\n        updatedAt?: DateOperators | null;\r\n    }\r\n        ? DataTableFilterCollection<FilterInput>\r\n        : never {\r\n        this.addFilter({\r\n            name: 'createdAt',\r\n            type: { kind: 'dateRange' },\r\n            label: _('common.created-at'),\r\n            filterField: 'createdAt',\r\n        });\r\n        this.addFilter({\r\n            name: 'updatedAt',\r\n            type: { kind: 'dateRange' },\r\n            label: _('common.updated-at'),\r\n            filterField: 'updatedAt',\r\n        });\r\n        return this as any;\r\n    }\r\n\r\n    addCustomFieldFilters(customFields: CustomFieldConfig[]) {\r\n        for (const config of customFields) {\r\n            const type = config.type as CustomFieldType;\r\n            if (config.list) {\r\n                continue;\r\n            }\r\n            let filterType: DataTableFilterType | undefined;\r\n            switch (type) {\r\n                case 'boolean':\r\n                    filterType = { kind: 'boolean' };\r\n                    break;\r\n                case 'int':\r\n                case 'float':\r\n                    filterType = { kind: 'number' };\r\n                    break;\r\n                case 'datetime':\r\n                    filterType = { kind: 'dateRange' };\r\n                    break;\r\n                case 'string':\r\n                case 'localeString':\r\n                case 'localeText':\r\n                case 'text':\r\n                    filterType = { kind: 'text' };\r\n                    break;\r\n                case 'relation':\r\n                    // Cannot sort relations\r\n                    break;\r\n                default:\r\n                    assertNever(type);\r\n            }\r\n            if (filterType) {\r\n                this.addFilter({\r\n                    name: config.name,\r\n                    type: filterType,\r\n                    label: config.label ?? config.name,\r\n                    filterField: config.name,\r\n                });\r\n            }\r\n        }\r\n        return this;\r\n    }\r\n\r\n    getFilter(name: string): DataTableFilter<FilterInput> | undefined {\r\n        return this.#filters.find(f => f.name === name);\r\n    }\r\n\r\n    getFilters(): Array<DataTableFilter<FilterInput>> {\r\n        return this.#filters;\r\n    }\r\n\r\n    removeActiveFilterAtIndex(index: number) {\r\n        this.#activeFilters.splice(index, 1);\r\n        this.#valueChanges$.next(this.#activeFilters);\r\n    }\r\n\r\n    createFilterInput(): FilterInput {\r\n        return this.#activeFilters.reduce((acc, { filter, value }) => {\r\n            const newValue = value != null ? filter.toFilterInput(value) : {};\r\n            const result = extend(true, acc, newValue);\r\n            return result as FilterInput;\r\n        }, {} as FilterInput);\r\n    }\r\n\r\n    connectToRoute(route: ActivatedRoute) {\r\n        this.valueChanges.subscribe(() => {\r\n            this.router.navigate(['./'], {\r\n                queryParams: { [this.#filtersQueryParamName]: this.serialize(), page: 1 },\r\n                relativeTo: route,\r\n                queryParamsHandling: 'merge',\r\n            });\r\n        });\r\n\r\n        route.queryParamMap\r\n            .pipe(\r\n                map(params => params.get(this.#filtersQueryParamName)),\r\n                distinctUntilChanged(),\r\n                startWith(route.snapshot.queryParamMap.get(this.#filtersQueryParamName) ?? ''),\r\n            )\r\n            .subscribe(value => {\r\n                this.#activeFilters = [];\r\n                if (value === '') {\r\n                    this.#valueChanges$.next(this.#activeFilters);\r\n                    return;\r\n                }\r\n                const filterQueryParams = (value ?? '')\r\n                    .split(';')\r\n                    .map(value => value.split(':'))\r\n                    .map(([name, value]) => ({ name, value }));\r\n                for (const { name, value } of filterQueryParams) {\r\n                    const filter = this.getFilter(name);\r\n                    if (filter) {\r\n                        const val = this.deserializeValue(filter, value);\r\n                        filter.activate(val);\r\n                    }\r\n                }\r\n            });\r\n\r\n        this.#connectedToRouter = true;\r\n\r\n        return this;\r\n    }\r\n\r\n    serialize(): string {\r\n        return this.#activeFilters\r\n            .map(\r\n                (filterWithValue, i) =>\r\n                    `${filterWithValue.filter.name}:${this.serializeValue(filterWithValue)}`,\r\n            )\r\n            .join(';');\r\n    }\r\n\r\n    private serializeValue<Type extends DataTableFilterType>(\r\n        filterWithValue: FilterWithValue<Type>,\r\n    ): string | undefined {\r\n        if (filterWithValue.isId()) {\r\n            const val = filterWithValue.value;\r\n            return `${val?.operator},${val?.term}`;\r\n        }\r\n        if (filterWithValue.isText()) {\r\n            const val = filterWithValue.value;\r\n            return `${val?.operator},${val?.term}`;\r\n        } else if (filterWithValue.isNumber()) {\r\n            const val = filterWithValue.value;\r\n            return `${val.operator},${val.amount}`;\r\n        } else if (filterWithValue.isSelect()) {\r\n            const val = filterWithValue.value;\r\n            return val.join(',');\r\n        } else if (filterWithValue.isBoolean()) {\r\n            const val = filterWithValue.value;\r\n            return val ? '1' : '0';\r\n        } else if (filterWithValue.isDateRange()) {\r\n            const val = filterWithValue.value;\r\n            const start = val.start ? new Date(val.start).getTime() : '';\r\n            const end = val.end ? new Date(val.end).getTime() : '';\r\n            return `${start},${end}`;\r\n        } else if (filterWithValue.isCustom()) {\r\n            return filterWithValue.filter.type.serializeValue(filterWithValue.value);\r\n        }\r\n    }\r\n\r\n    private deserializeValue(\r\n        filter: DataTableFilter,\r\n        value: string,\r\n    ): DataTableFilterValue<DataTableFilterType> {\r\n        switch (filter.type.kind) {\r\n            case 'id': {\r\n                const [operator, term] = value.split(',') as [keyof StringOperators, string];\r\n                return { operator, term };\r\n            }\r\n            case 'text': {\r\n                const [operator, term] = value.split(',') as [keyof StringOperators, string];\r\n                return { operator, term };\r\n            }\r\n            case 'number': {\r\n                const [operator, amount] = value.split(',') as [keyof NumberOperators, string];\r\n                return { operator, amount: +amount };\r\n            }\r\n            case 'select':\r\n                return value.split(',');\r\n            case 'boolean':\r\n                return value === '1';\r\n            case 'dateRange':\r\n                const [startTimestamp, endTimestamp] = value.split(',');\r\n                const start = startTimestamp ? new Date(Number(startTimestamp)).toISOString() : '';\r\n                const end = endTimestamp ? new Date(Number(endTimestamp)).toISOString() : '';\r\n                return { start, end };\r\n            case 'custom':\r\n                return filter.type.deserializeValue(value);\r\n            default:\r\n                assertNever(filter.type);\r\n        }\r\n    }\r\n\r\n    private onActivateFilter(filter: DataTableFilter<any, any>, value: DataTableFilterValue<any>) {\r\n        this.#activeFilters.push(this.createFilterWithValue(filter, value));\r\n        this.#valueChanges$.next(this.#activeFilters);\r\n    }\r\n\r\n    private createFilterWithValue(\r\n        filter: DataTableFilter<any, any>,\r\n        value: DataTableFilterValue<DataTableFilterType>,\r\n    ) {\r\n        return new FilterWithValue(filter, value, v => this.#valueChanges$.next(v));\r\n    }\r\n}\r\n"]}
|
|
@@ -51,6 +51,10 @@ export class DataTableFilter {
|
|
|
51
51
|
return {
|
|
52
52
|
[value.operator]: value.term,
|
|
53
53
|
};
|
|
54
|
+
case 'id':
|
|
55
|
+
return {
|
|
56
|
+
[value.operator]: value.term,
|
|
57
|
+
};
|
|
54
58
|
case 'custom': {
|
|
55
59
|
return value;
|
|
56
60
|
}
|
|
@@ -74,6 +78,9 @@ export class DataTableFilter {
|
|
|
74
78
|
this.onActivate(this, value);
|
|
75
79
|
}
|
|
76
80
|
}
|
|
81
|
+
isId() {
|
|
82
|
+
return this.type.kind === 'id';
|
|
83
|
+
}
|
|
77
84
|
isText() {
|
|
78
85
|
return this.type.kind === 'text';
|
|
79
86
|
}
|
|
@@ -93,4 +100,4 @@ export class DataTableFilter {
|
|
|
93
100
|
return this.type.kind === 'custom';
|
|
94
101
|
}
|
|
95
102
|
}
|
|
96
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table-filter.js","sourceRoot":"","sources":["../../../../../src/lib/core/src/providers/data-table/data-table-filter.ts"],"names":[],"mappings":"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","sourcesContent":["import { Type as ComponentType } from '@angular/core';\r\nimport { LocalizedString } from '@vendure/common/lib/generated-types';\r\nimport { assertNever } from '@vendure/common/lib/shared-utils';\r\nimport { FormInputComponent } from '../../common/component-registry-types';\r\nimport {\r\n    BooleanOperators,\r\n    DateOperators,\r\n    NumberOperators,\r\n    StringOperators,\r\n} from '../../common/generated-types';\r\n\r\nexport interface DataTableFilterTextType {\r\n    kind: 'text';\r\n    placeholder?: string;\r\n}\r\n\r\nexport interface DataTableFilterSelectType {\r\n    kind: 'select';\r\n    options: Array<{ value: any; label: string }>;\r\n}\r\n\r\nexport interface DataTableFilterBooleanType {\r\n    kind: 'boolean';\r\n}\r\n\r\nexport interface DataTableFilterNumberType {\r\n    kind: 'number';\r\n    inputType?: 'number' | 'currency';\r\n}\r\n\r\nexport interface DataTableFilterDateRangeType {\r\n    kind: 'dateRange';\r\n}\r\n\r\nexport interface DataTableFilterCustomType {\r\n    kind: 'custom';\r\n    component: ComponentType<FormInputComponent>;\r\n    serializeValue: (value: any) => string;\r\n    deserializeValue: (serialized: string) => any;\r\n    getLabel(value: any): string | Promise<string>;\r\n}\r\n\r\nexport type KindValueMap = {\r\n    text: {\r\n        raw: {\r\n            operator: keyof StringOperators;\r\n            term: string;\r\n        };\r\n        input: StringOperators;\r\n    };\r\n    select: { raw: string[]; input: StringOperators };\r\n    boolean: { raw: boolean; input: BooleanOperators };\r\n    dateRange: { raw: { start?: string; end?: string }; input: DateOperators };\r\n    number: { raw: { operator: keyof NumberOperators; amount: number }; input: NumberOperators };\r\n    custom: { raw: any; input: any };\r\n};\r\nexport type DataTableFilterType =\r\n    | DataTableFilterTextType\r\n    | DataTableFilterSelectType\r\n    | DataTableFilterBooleanType\r\n    | DataTableFilterDateRangeType\r\n    | DataTableFilterNumberType\r\n    | DataTableFilterCustomType;\r\n\r\nexport interface DataTableFilterOptions<\r\n    FilterInput extends Record<string, any> = any,\r\n    Type extends DataTableFilterType = DataTableFilterType,\r\n> {\r\n    readonly name: string;\r\n    readonly type: Type;\r\n    readonly label: string | LocalizedString[];\r\n    readonly filterField?: keyof FilterInput;\r\n    readonly toFilterInput?: (value: DataTableFilterValue<Type>) => Partial<FilterInput>;\r\n}\r\n\r\nexport type DataTableFilterValue<Type extends DataTableFilterType> = KindValueMap[Type['kind']]['raw'];\r\nexport type DataTableFilterOperator<Type extends DataTableFilterType> = KindValueMap[Type['kind']]['input'];\r\n\r\nexport class DataTableFilter<\r\n    FilterInput extends Record<string, any> = any,\r\n    Type extends DataTableFilterType = DataTableFilterType,\r\n> {\r\n    constructor(\r\n        private readonly options: DataTableFilterOptions<FilterInput, Type>,\r\n        private onActivate?: (\r\n            filter: DataTableFilter<FilterInput, Type>,\r\n            value: DataTableFilterValue<Type> | undefined,\r\n        ) => void,\r\n    ) {}\r\n\r\n    get name(): string {\r\n        return this.options.name;\r\n    }\r\n\r\n    get type(): Type {\r\n        return this.options.type;\r\n    }\r\n\r\n    get label(): string | LocalizedString[] {\r\n        return this.options.label;\r\n    }\r\n\r\n    getFilterOperator(value: any): DataTableFilterOperator<Type> {\r\n        const type = this.options.type;\r\n        switch (type.kind) {\r\n            case 'boolean':\r\n                return {\r\n                    eq: !!value,\r\n                };\r\n            case 'dateRange': {\r\n                let dateOperators: DateOperators;\r\n                const start = value.start ?? undefined;\r\n                const end = value.end ?? undefined;\r\n                if (start && end) {\r\n                    dateOperators = {\r\n                        between: { start, end },\r\n                    };\r\n                } else if (start) {\r\n                    dateOperators = {\r\n                        after: start,\r\n                    };\r\n                } else {\r\n                    dateOperators = {\r\n                        before: end,\r\n                    };\r\n                }\r\n                return dateOperators;\r\n            }\r\n            case 'number':\r\n                return {\r\n                    [value.operator]: Number(value.amount),\r\n                };\r\n\r\n            case 'select':\r\n                return { in: value };\r\n            case 'text':\r\n                return {\r\n                    [value.operator]: value.term,\r\n                };\r\n            case 'custom': {\r\n                return value;\r\n            }\r\n            default:\r\n                assertNever(type);\r\n        }\r\n    }\r\n\r\n    toFilterInput(value: DataTableFilterValue<Type>): Partial<FilterInput> {\r\n        if (this.options.toFilterInput) {\r\n            return this.options.toFilterInput(value);\r\n        }\r\n        if (this.options.filterField) {\r\n            return { [this.options.filterField]: this.getFilterOperator(value) } as Partial<FilterInput>;\r\n        } else {\r\n            throw new Error(\r\n                `Either \"filterField\" or \"toFilterInput\" must be provided (for filter \"${this.name}\"))`,\r\n            );\r\n        }\r\n    }\r\n\r\n    activate(value: DataTableFilterValue<Type>) {\r\n        if (this.onActivate) {\r\n            this.onActivate(this, value);\r\n        }\r\n    }\r\n\r\n    isText(): this is DataTableFilter<FilterInput, DataTableFilterTextType> {\r\n        return this.type.kind === 'text';\r\n    }\r\n\r\n    isNumber(): this is DataTableFilter<FilterInput, DataTableFilterNumberType> {\r\n        return this.type.kind === 'number';\r\n    }\r\n\r\n    isBoolean(): this is DataTableFilter<FilterInput, DataTableFilterBooleanType> {\r\n        return this.type.kind === 'boolean';\r\n    }\r\n\r\n    isSelect(): this is DataTableFilter<FilterInput, DataTableFilterSelectType> {\r\n        return this.type.kind === 'select';\r\n    }\r\n\r\n    isDateRange(): this is DataTableFilter<FilterInput, DataTableFilterDateRangeType> {\r\n        return this.type.kind === 'dateRange';\r\n    }\r\n\r\n    isCustom(): this is DataTableFilter<FilterInput, DataTableFilterCustomType> {\r\n        return this.type.kind === 'custom';\r\n    }\r\n}\r\n"]}
|
|
103
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table-filter.js","sourceRoot":"","sources":["../../../../../src/lib/core/src/providers/data-table/data-table-filter.ts"],"names":[],"mappings":"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","sourcesContent":["import { Type as ComponentType } from '@angular/core';\r\nimport { LocalizedString } from '@vendure/common/lib/generated-types';\r\nimport { assertNever } from '@vendure/common/lib/shared-utils';\r\nimport { FormInputComponent } from '../../common/component-registry-types';\r\nimport {\r\n    BooleanOperators,\r\n    DateOperators,\r\n    IdOperators,\r\n    NumberOperators,\r\n    StringOperators,\r\n} from '../../common/generated-types';\r\n\r\nexport interface DataTableFilterIDType {\r\n    kind: 'id';\r\n}\r\n\r\nexport interface DataTableFilterTextType {\r\n    kind: 'text';\r\n    placeholder?: string;\r\n}\r\n\r\nexport interface DataTableFilterSelectType {\r\n    kind: 'select';\r\n    options: Array<{ value: any; label: string }>;\r\n}\r\n\r\nexport interface DataTableFilterBooleanType {\r\n    kind: 'boolean';\r\n}\r\n\r\nexport interface DataTableFilterNumberType {\r\n    kind: 'number';\r\n    inputType?: 'number' | 'currency';\r\n}\r\n\r\nexport interface DataTableFilterDateRangeType {\r\n    kind: 'dateRange';\r\n}\r\n\r\nexport interface DataTableFilterCustomType {\r\n    kind: 'custom';\r\n    component: ComponentType<FormInputComponent>;\r\n    serializeValue: (value: any) => string;\r\n    deserializeValue: (serialized: string) => any;\r\n    getLabel(value: any): string | Promise<string>;\r\n}\r\n\r\nexport type KindValueMap = {\r\n    id: {\r\n        raw: {\r\n            operator: keyof IdOperators;\r\n            term: string;\r\n        };\r\n        input: IdOperators;\r\n    };\r\n    text: {\r\n        raw: {\r\n            operator: keyof StringOperators;\r\n            term: string;\r\n        };\r\n        input: StringOperators;\r\n    };\r\n    select: { raw: string[]; input: StringOperators };\r\n    boolean: { raw: boolean; input: BooleanOperators };\r\n    dateRange: { raw: { start?: string; end?: string }; input: DateOperators };\r\n    number: { raw: { operator: keyof NumberOperators; amount: number }; input: NumberOperators };\r\n    custom: { raw: any; input: any };\r\n};\r\nexport type DataTableFilterType =\r\n    | DataTableFilterIDType\r\n    | DataTableFilterTextType\r\n    | DataTableFilterSelectType\r\n    | DataTableFilterBooleanType\r\n    | DataTableFilterDateRangeType\r\n    | DataTableFilterNumberType\r\n    | DataTableFilterCustomType;\r\n\r\nexport interface DataTableFilterOptions<\r\n    FilterInput extends Record<string, any> = any,\r\n    Type extends DataTableFilterType = DataTableFilterType,\r\n> {\r\n    readonly name: string;\r\n    readonly type: Type;\r\n    readonly label: string | LocalizedString[];\r\n    readonly filterField?: keyof FilterInput;\r\n    readonly toFilterInput?: (value: DataTableFilterValue<Type>) => Partial<FilterInput>;\r\n}\r\n\r\nexport type DataTableFilterValue<Type extends DataTableFilterType> = KindValueMap[Type['kind']]['raw'];\r\nexport type DataTableFilterOperator<Type extends DataTableFilterType> = KindValueMap[Type['kind']]['input'];\r\n\r\nexport class DataTableFilter<\r\n    FilterInput extends Record<string, any> = any,\r\n    Type extends DataTableFilterType = DataTableFilterType,\r\n> {\r\n    constructor(\r\n        private readonly options: DataTableFilterOptions<FilterInput, Type>,\r\n        private onActivate?: (\r\n            filter: DataTableFilter<FilterInput, Type>,\r\n            value: DataTableFilterValue<Type> | undefined,\r\n        ) => void,\r\n    ) {}\r\n\r\n    get name(): string {\r\n        return this.options.name;\r\n    }\r\n\r\n    get type(): Type {\r\n        return this.options.type;\r\n    }\r\n\r\n    get label(): string | LocalizedString[] {\r\n        return this.options.label;\r\n    }\r\n\r\n    getFilterOperator(value: any): DataTableFilterOperator<Type> {\r\n        const type = this.options.type;\r\n        switch (type.kind) {\r\n            case 'boolean':\r\n                return {\r\n                    eq: !!value,\r\n                };\r\n            case 'dateRange': {\r\n                let dateOperators: DateOperators;\r\n                const start = value.start ?? undefined;\r\n                const end = value.end ?? undefined;\r\n                if (start && end) {\r\n                    dateOperators = {\r\n                        between: { start, end },\r\n                    };\r\n                } else if (start) {\r\n                    dateOperators = {\r\n                        after: start,\r\n                    };\r\n                } else {\r\n                    dateOperators = {\r\n                        before: end,\r\n                    };\r\n                }\r\n                return dateOperators;\r\n            }\r\n            case 'number':\r\n                return {\r\n                    [value.operator]: Number(value.amount),\r\n                };\r\n\r\n            case 'select':\r\n                return { in: value };\r\n            case 'text':\r\n                return {\r\n                    [value.operator]: value.term,\r\n                };\r\n            case 'id':\r\n                return {\r\n                    [value.operator]: value.term,\r\n                };\r\n            case 'custom': {\r\n                return value;\r\n            }\r\n            default:\r\n                assertNever(type);\r\n        }\r\n    }\r\n\r\n    toFilterInput(value: DataTableFilterValue<Type>): Partial<FilterInput> {\r\n        if (this.options.toFilterInput) {\r\n            return this.options.toFilterInput(value);\r\n        }\r\n        if (this.options.filterField) {\r\n            return { [this.options.filterField]: this.getFilterOperator(value) } as Partial<FilterInput>;\r\n        } else {\r\n            throw new Error(\r\n                `Either \"filterField\" or \"toFilterInput\" must be provided (for filter \"${this.name}\"))`,\r\n            );\r\n        }\r\n    }\r\n\r\n    activate(value: DataTableFilterValue<Type>) {\r\n        if (this.onActivate) {\r\n            this.onActivate(this, value);\r\n        }\r\n    }\r\n\r\n    isId(): this is DataTableFilter<FilterInput, DataTableFilterIDType> {\r\n        return this.type.kind === 'id';\r\n    }\r\n\r\n    isText(): this is DataTableFilter<FilterInput, DataTableFilterTextType> {\r\n        return this.type.kind === 'text';\r\n    }\r\n\r\n    isNumber(): this is DataTableFilter<FilterInput, DataTableFilterNumberType> {\r\n        return this.type.kind === 'number';\r\n    }\r\n\r\n    isBoolean(): this is DataTableFilter<FilterInput, DataTableFilterBooleanType> {\r\n        return this.type.kind === 'boolean';\r\n    }\r\n\r\n    isSelect(): this is DataTableFilter<FilterInput, DataTableFilterSelectType> {\r\n        return this.type.kind === 'select';\r\n    }\r\n\r\n    isDateRange(): this is DataTableFilter<FilterInput, DataTableFilterDateRangeType> {\r\n        return this.type.kind === 'dateRange';\r\n    }\r\n\r\n    isCustom(): this is DataTableFilter<FilterInput, DataTableFilterCustomType> {\r\n        return this.type.kind === 'custom';\r\n    }\r\n}\r\n"]}
|
|
@@ -94,4 +94,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.3", ngImpor
|
|
|
94
94
|
providedIn: 'root',
|
|
95
95
|
}]
|
|
96
96
|
}], ctorParameters: function () { return [{ type: i1.Location }]; } });
|
|
97
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
97
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"local-storage.service.js","sourceRoot":"","sources":["../../../../../src/lib/core/src/providers/local-storage/local-storage.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Location } from '@angular/common';\r\nimport { Injectable, Injector } from '@angular/core';\r\n\r\nimport { LanguageCode } from '../../common/generated-types';\r\nimport { DataService } from '../../data/providers/data.service';\r\nimport { WidgetLayoutDefinition } from '../dashboard-widget/dashboard-widget-types';\r\n\r\nexport type DataTableConfig = {\r\n    [id: string]: {\r\n        visibility: string[];\r\n        order: { [id: string]: number };\r\n        showSearchFilterRow: boolean;\r\n    };\r\n};\r\n\r\nexport type LocalStorageTypeMap = {\r\n    activeChannelToken: string;\r\n    authToken: string;\r\n    uiLanguageCode: LanguageCode;\r\n    uiLocale: string | undefined;\r\n    contentLanguageCode: LanguageCode;\r\n    dashboardWidgetLayout: WidgetLayoutDefinition;\r\n    activeTheme: string;\r\n    livePreviewCollectionContents: boolean;\r\n    dataTableConfig: DataTableConfig;\r\n};\r\n\r\nexport type LocalStorageLocationBasedTypeMap = {\r\n    shippingTestOrder: any;\r\n    shippingTestAddress: any;\r\n};\r\n\r\n/**\r\n * These keys are stored specific to a particular AdminId, so that multiple\r\n * admins can use the same browser without interfering with each other's data.\r\n */\r\nconst ADMIN_SPECIFIC_KEYS: Array<keyof LocalStorageTypeMap> = [\r\n    'activeTheme',\r\n    'dashboardWidgetLayout',\r\n    'activeTheme',\r\n    'livePreviewCollectionContents',\r\n    'dataTableConfig',\r\n];\r\n\r\nconst PREFIX = 'vnd_';\r\n\r\n/**\r\n * Wrapper around the browser's LocalStorage / SessionStorage object, for persisting data to the browser.\r\n */\r\n@Injectable({\r\n    providedIn: 'root',\r\n})\r\nexport class LocalStorageService {\r\n    private adminId = '__global__';\r\n    constructor(private location: Location) {}\r\n\r\n    public setAdminId(adminId?: string | null) {\r\n        this.adminId = adminId ?? '__global__';\r\n    }\r\n\r\n    /**\r\n     * Set a key-value pair in the browser's LocalStorage\r\n     */\r\n    public set<K extends keyof LocalStorageTypeMap>(key: K, value: LocalStorageTypeMap[K]): void {\r\n        const keyName = this.keyName(key);\r\n        localStorage.setItem(keyName, JSON.stringify(value));\r\n    }\r\n\r\n    /**\r\n     * Set a key-value pair specific to the current location (url)\r\n     */\r\n    public setForCurrentLocation<K extends keyof LocalStorageLocationBasedTypeMap>(\r\n        key: K,\r\n        value: LocalStorageLocationBasedTypeMap[K],\r\n    ) {\r\n        const compositeKey = this.getLocationBasedKey(key);\r\n        this.set(compositeKey as any, value);\r\n    }\r\n\r\n    /**\r\n     * Set a key-value pair in the browser's SessionStorage\r\n     */\r\n    public setForSession<K extends keyof LocalStorageTypeMap>(key: K, value: LocalStorageTypeMap[K]): void {\r\n        const keyName = this.keyName(key);\r\n        sessionStorage.setItem(keyName, JSON.stringify(value));\r\n    }\r\n\r\n    /**\r\n     * Get the value of the given key from the SessionStorage or LocalStorage.\r\n     */\r\n    public get<K extends keyof LocalStorageTypeMap>(key: K): LocalStorageTypeMap[K] | null {\r\n        const keyName = this.keyName(key);\r\n        const item = sessionStorage.getItem(keyName) || localStorage.getItem(keyName);\r\n        let result: any;\r\n        try {\r\n            result = JSON.parse(item || 'null');\r\n        } catch (e: any) {\r\n            // eslint-disable-next-line no-console\r\n            console.error(`Could not parse the localStorage value for \"${key}\" (${item})`);\r\n        }\r\n        return result;\r\n    }\r\n\r\n    /**\r\n     * Get the value of the given key for the current location (url)\r\n     */\r\n    public getForCurrentLocation<K extends keyof LocalStorageLocationBasedTypeMap>(\r\n        key: K,\r\n    ): LocalStorageLocationBasedTypeMap[K] {\r\n        const compositeKey = this.getLocationBasedKey(key);\r\n        return this.get(compositeKey as any);\r\n    }\r\n\r\n    public remove(key: keyof LocalStorageTypeMap): void {\r\n        const keyName = this.keyName(key);\r\n        sessionStorage.removeItem(keyName);\r\n        localStorage.removeItem(keyName);\r\n    }\r\n\r\n    private getLocationBasedKey(key: string) {\r\n        const path = this.location.path();\r\n        return key + path;\r\n    }\r\n\r\n    private keyName(key: keyof LocalStorageTypeMap): string {\r\n        if (ADMIN_SPECIFIC_KEYS.includes(key)) {\r\n            return `${PREFIX}_${this.adminId}_${key}`;\r\n        } else {\r\n            return `${PREFIX}_${key}`;\r\n        }\r\n    }\r\n}\r\n"]}
|