@vendure/admin-ui 2.1.0-next.6 → 2.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (43) hide show
  1. package/core/common/base-list.component.d.ts +1 -0
  2. package/core/common/version.d.ts +1 -1
  3. package/core/extension/register-route-component.d.ts +3 -3
  4. package/core/providers/data-table/data-table-filter-collection.d.ts +2 -0
  5. package/core/providers/data-table/data-table-sort-collection.d.ts +2 -0
  6. package/core/shared/components/data-table-filter-presets/data-table-filter-presets.component.d.ts +3 -2
  7. package/core/shared/components/data-table-filters/data-table-filters.component.d.ts +1 -1
  8. package/core/shared/components/order-state-label/order-state-label.component.d.ts +1 -1
  9. package/core/shared/dynamic-form-inputs/default-form-inputs.d.ts +1 -1
  10. package/esm2022/core/common/base-list.component.mjs +13 -4
  11. package/esm2022/core/common/version.mjs +2 -2
  12. package/esm2022/core/extension/register-route-component.mjs +1 -1
  13. package/esm2022/core/providers/data-table/data-table-filter-collection.mjs +19 -3
  14. package/esm2022/core/providers/data-table/data-table-sort-collection.mjs +8 -2
  15. package/esm2022/core/shared/components/affixed-input/affixed-input.component.mjs +2 -2
  16. package/esm2022/core/shared/components/asset-gallery/asset-gallery.component.mjs +1 -1
  17. package/esm2022/core/shared/components/data-table-filter-presets/data-table-filter-presets.component.mjs +7 -5
  18. package/esm2022/core/shared/components/data-table-filters/data-table-filters.component.mjs +5 -4
  19. package/esm2022/order/components/order-data-table/order-data-table.component.mjs +3 -3
  20. package/esm2022/order/components/order-table/order-table.component.mjs +3 -3
  21. package/fesm2022/vendure-admin-ui-core.mjs +47 -14
  22. package/fesm2022/vendure-admin-ui-core.mjs.map +1 -1
  23. package/fesm2022/vendure-admin-ui-order.mjs +4 -4
  24. package/fesm2022/vendure-admin-ui-order.mjs.map +1 -1
  25. package/package.json +13 -13
  26. package/static/i18n-messages/ar.json +1 -1
  27. package/static/i18n-messages/cs.json +1 -1
  28. package/static/i18n-messages/de.json +1 -1
  29. package/static/i18n-messages/en.json +1 -1
  30. package/static/i18n-messages/es.json +1 -1
  31. package/static/i18n-messages/fa.json +795 -0
  32. package/static/i18n-messages/fr.json +1 -1
  33. package/static/i18n-messages/he.json +1 -1
  34. package/static/i18n-messages/it.json +1 -1
  35. package/static/i18n-messages/ne.json +795 -0
  36. package/static/i18n-messages/pl.json +1 -1
  37. package/static/i18n-messages/pt_BR.json +1 -1
  38. package/static/i18n-messages/pt_PT.json +1 -1
  39. package/static/i18n-messages/ru.json +1 -1
  40. package/static/i18n-messages/uk.json +1 -1
  41. package/static/i18n-messages/zh_Hans.json +1 -1
  42. package/static/i18n-messages/zh_Hant.json +1 -1
  43. package/static/vendure-ui-config.json +3 -1
@@ -115,6 +115,7 @@ export declare class TypedBaseListComponent<T extends TypedDocumentNode<any, Var
115
115
  protected router: Router;
116
116
  protected serverConfigService: ServerConfigService;
117
117
  private refreshStreams;
118
+ private collections;
118
119
  constructor();
119
120
  protected configure(config: {
120
121
  document: T;
@@ -1 +1 @@
1
- export declare const ADMIN_UI_VERSION = "2.1.0-next.6";
1
+ export declare const ADMIN_UI_VERSION = "2.1.0";
@@ -24,10 +24,10 @@ export type RegisterRouteComponentOptions<Component extends any | BaseDetailComp
24
24
  path?: string;
25
25
  query?: T;
26
26
  getBreadcrumbs?: (entity: Exclude<ResultOf<T>[R], 'Query'>) => BreadcrumbValue;
27
- entityKey?: Component extends BaseDetailComponent<Entity> ? R : undefined;
27
+ entityKey?: Component extends BaseDetailComponent<any> ? R : undefined;
28
28
  variables?: T extends TypedDocumentNode<any, infer V> ? Omit<V, 'id'> : never;
29
29
  routeConfig?: Route;
30
- } & (Component extends BaseDetailComponent<Entity> ? {
30
+ } & (Component extends BaseDetailComponent<any> ? {
31
31
  entityKey: R;
32
32
  } : unknown);
33
33
  /**
@@ -88,7 +88,7 @@ export declare function registerRouteComponent<Component extends any | BaseDetai
88
88
  component: typeof AngularRouteComponent;
89
89
  title?: string | Type<import("@angular/router").Resolve<string>> | ResolveFn<string> | undefined;
90
90
  path: string;
91
- pathMatch?: "full" | "prefix" | undefined;
91
+ pathMatch?: "prefix" | "full" | undefined;
92
92
  matcher?: import("@angular/router").UrlMatcher | undefined;
93
93
  loadComponent?: (() => Type<unknown> | Observable<Type<unknown> | import("@angular/router").DefaultExport<Type<unknown>>> | Promise<Type<unknown> | import("@angular/router").DefaultExport<Type<unknown>>>) | undefined;
94
94
  redirectTo?: string | undefined;
@@ -20,9 +20,11 @@ export declare class DataTableFilterCollection<FilterInput extends Record<string
20
20
  #private;
21
21
  private router;
22
22
  valueChanges: import("rxjs").Observable<FilterWithValue<DataTableFilterType>[]>;
23
+ private readonly destroy$;
23
24
  constructor(router: Router);
24
25
  get length(): number;
25
26
  get activeFilters(): FilterWithValue[];
27
+ destroy(): void;
26
28
  addFilter<FilterType extends DataTableFilterType>(config: DataTableFilterOptions<FilterInput, FilterType>): DataTableFilterCollection<FilterInput>;
27
29
  addFilters<FilterType extends DataTableFilterType>(configs: Array<DataTableFilterOptions<FilterInput, FilterType>>): DataTableFilterCollection<FilterInput>;
28
30
  addIdFilter(): FilterInput extends {
@@ -8,8 +8,10 @@ export declare class DataTableSortCollection<SortInput extends Record<string, 'A
8
8
  name: string;
9
9
  sortOrder: DataTableSortOrder | undefined;
10
10
  }[]>;
11
+ private readonly destroy$;
11
12
  constructor(router: Router);
12
13
  get length(): number;
14
+ destroy(): void;
13
15
  addSort<Name extends keyof SortInput>(config: DataTableSortOptions<SortInput, Name>): DataTableSortCollection<SortInput, [...Names, Name]>;
14
16
  addSorts<Name extends keyof SortInput>(configs: Array<DataTableSortOptions<SortInput, Name>>): DataTableSortCollection<SortInput, [...Names, Name]>;
15
17
  addCustomFieldSorts(customFields: CustomFieldConfig[]): this;
@@ -1,5 +1,5 @@
1
1
  import { CdkDragDrop } from '@angular/cdk/drag-drop';
2
- import { OnDestroy, OnInit } from '@angular/core';
2
+ import { ChangeDetectorRef, OnDestroy, OnInit } from '@angular/core';
3
3
  import { ActivatedRoute } from '@angular/router';
4
4
  import { Observable } from 'rxjs';
5
5
  import { DataTableFilterCollection } from '../../../providers/data-table/data-table-filter-collection';
@@ -10,6 +10,7 @@ export declare class DataTableFilterPresetsComponent implements OnInit, OnDestro
10
10
  private route;
11
11
  private filterPresetService;
12
12
  private modalService;
13
+ private changeDetectorRef;
13
14
  dataTableId: string;
14
15
  filters: DataTableFilterCollection;
15
16
  serializedActiveFilters: string;
@@ -18,7 +19,7 @@ export declare class DataTableFilterPresetsComponent implements OnInit, OnDestro
18
19
  value: string;
19
20
  }>>;
20
21
  private destroy$;
21
- constructor(route: ActivatedRoute, filterPresetService: FilterPresetService, modalService: ModalService);
22
+ constructor(route: ActivatedRoute, filterPresetService: FilterPresetService, modalService: ModalService, changeDetectorRef: ChangeDetectorRef);
22
23
  ngOnInit(): void;
23
24
  ngOnDestroy(): void;
24
25
  deleteFilterPreset(name: string): void;
@@ -23,7 +23,7 @@ export declare class DataTableFiltersComponent implements AfterViewInit {
23
23
  constructor(i18nService: I18nService, changeDetectorRef: ChangeDetectorRef);
24
24
  ngAfterViewInit(): void;
25
25
  selectFilter(filter: DataTableFilter, value?: any): void;
26
- activate(): void;
26
+ activate(event: Event): void;
27
27
  deactivate(): void;
28
28
  static ɵfac: i0.ɵɵFactoryDeclaration<DataTableFiltersComponent, never>;
29
29
  static ɵcmp: i0.ɵɵComponentDeclaration<DataTableFiltersComponent, "vdr-data-table-filters", never, { "filters": { "alias": "filters"; "required": false; }; "filterWithValue": { "alias": "filterWithValue"; "required": false; }; }, {}, never, never, false, never>;
@@ -11,7 +11,7 @@ import * as i0 from "@angular/core";
11
11
  */
12
12
  export declare class OrderStateLabelComponent {
13
13
  state: string;
14
- get chipColorType(): "" | "error" | "success" | "warning";
14
+ get chipColorType(): "error" | "success" | "" | "warning";
15
15
  static ɵfac: i0.ɵɵFactoryDeclaration<OrderStateLabelComponent, never>;
16
16
  static ɵcmp: i0.ɵɵComponentDeclaration<OrderStateLabelComponent, "vdr-order-state-label", never, { "state": { "alias": "state"; "required": false; }; }, {}, never, ["*"], false, never>;
17
17
  }
@@ -8,7 +8,7 @@ import { PasswordFormInputComponent } from './password-form-input/password-form-
8
8
  import { ProductMultiSelectorFormInputComponent } from './product-multi-selector-form-input/product-multi-selector-form-input.component';
9
9
  import { ProductSelectorFormInputComponent } from './product-selector-form-input/product-selector-form-input.component';
10
10
  import { SelectFormInputComponent } from './select-form-input/select-form-input.component';
11
- export declare const defaultFormInputs: (typeof ProductSelectorFormInputComponent | typeof CustomerGroupFormInputComponent | typeof PasswordFormInputComponent | typeof CurrencyFormInputComponent | typeof SelectFormInputComponent | typeof JsonEditorFormInputComponent | typeof HtmlEditorFormInputComponent | typeof ProductMultiSelectorFormInputComponent | typeof CombinationModeFormInputComponent)[];
11
+ export declare const defaultFormInputs: (typeof HtmlEditorFormInputComponent | typeof JsonEditorFormInputComponent | typeof CombinationModeFormInputComponent | typeof CurrencyFormInputComponent | typeof CustomerGroupFormInputComponent | typeof PasswordFormInputComponent | typeof ProductMultiSelectorFormInputComponent | typeof ProductSelectorFormInputComponent | typeof SelectFormInputComponent)[];
12
12
  /**
13
13
  * Registers the default form input components.
14
14
  */
@@ -1,4 +1,4 @@
1
- import { Directive, inject } from '@angular/core';
1
+ import { DestroyRef, Directive, inject } from '@angular/core';
2
2
  import { FormControl } from '@angular/forms';
3
3
  import { ActivatedRoute, Router } from '@angular/router';
4
4
  import { BehaviorSubject, combineLatest, merge, Subject } from 'rxjs';
@@ -136,6 +136,11 @@ export class TypedBaseListComponent extends BaseListComponent {
136
136
  this.router = inject(Router);
137
137
  this.serverConfigService = inject(ServerConfigService);
138
138
  this.refreshStreams = [];
139
+ this.collections = [];
140
+ const destroyRef = inject(DestroyRef);
141
+ destroyRef.onDestroy(() => {
142
+ this.collections.forEach(c => c.destroy());
143
+ });
139
144
  }
140
145
  configure(config) {
141
146
  super.setQueryFn((args) => this.dataService.query(config.document).refetchOnChannelChange(), data => config.getItems(data), (skip, take) => config.setVariables?.(skip, take) ?? {});
@@ -151,10 +156,14 @@ export class TypedBaseListComponent extends BaseListComponent {
151
156
  super.refreshListOnChanges(this.contentLanguage$, ...this.refreshStreams);
152
157
  }
153
158
  createFilterCollection() {
154
- return new DataTableFilterCollection(this.router);
159
+ const collection = new DataTableFilterCollection(this.router);
160
+ this.collections.push(collection);
161
+ return collection;
155
162
  }
156
163
  createSortCollection() {
157
- return new DataTableSortCollection(this.router);
164
+ const collection = new DataTableSortCollection(this.router);
165
+ this.collections.push(collection);
166
+ return collection;
158
167
  }
159
168
  setLanguage(code) {
160
169
  this.dataService.client.setContentLanguage(code).subscribe();
@@ -168,4 +177,4 @@ export class TypedBaseListComponent extends BaseListComponent {
168
177
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.2", ngImport: i0, type: TypedBaseListComponent, decorators: [{
169
178
  type: Directive
170
179
  }], ctorParameters: function () { return []; } });
171
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-list.component.js","sourceRoot":"","sources":["../../../../src/lib/core/src/common/base-list.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, inject, OnDestroy, OnInit } from '@angular/core';\r\nimport { FormControl } from '@angular/forms';\r\nimport { ActivatedRoute, QueryParamsHandling, Router } from '@angular/router';\r\nimport { ResultOf, TypedDocumentNode, VariablesOf } from '@graphql-typed-document-node/core';\r\nimport { BehaviorSubject, combineLatest, merge, Observable, Subject } from 'rxjs';\r\nimport { debounceTime, distinctUntilChanged, filter, map, shareReplay, takeUntil, tap } from 'rxjs/operators';\r\nimport { DataService } from '../data/providers/data.service';\r\n\r\nimport { QueryResult } from '../data/query-result';\r\nimport { ServerConfigService } from '../data/server-config';\r\nimport { DataTableFilterCollection } from '../providers/data-table/data-table-filter-collection';\r\nimport { DataTableSortCollection } from '../providers/data-table/data-table-sort-collection';\r\nimport { CustomFieldConfig, CustomFields, LanguageCode } from './generated-types';\r\nimport { SelectionManager } from './utilities/selection-manager';\r\n\r\nexport type ListQueryFn<R> = (take: number, skip: number, ...args: any[]) => QueryResult<R, any>;\r\nexport type MappingFn<T, R> = (result: R) => { items: T[]; totalItems: number };\r\nexport type OnPageChangeFn<V> = (skip: number, take: number) => V;\r\n\r\n/**\r\n * Unwraps a query that returns a paginated list with an \"items\" property,\r\n * returning the type of one of the items in the array.\r\n */\r\nexport type ItemOf<T, K extends keyof T> = T[K] extends { items: infer R }\r\n    ? R extends any[]\r\n        ? R[number]\r\n        : R\r\n    : never;\r\n\r\n/**\r\n * @description\r\n * This is a base class which implements the logic required to fetch and manipulate\r\n * a list of data from a query which returns a PaginatedList type.\r\n *\r\n * It is normally used in combination with the {@link DataTable2Component}.\r\n *\r\n * @docsCategory list-detail-views\r\n */\r\n@Directive()\r\n// eslint-disable-next-line @angular-eslint/directive-class-suffix\r\nexport class BaseListComponent<ResultType, ItemType, VariableType extends Record<string, any> = any>\r\n    implements OnInit, OnDestroy\r\n{\r\n    searchTermControl = new FormControl('');\r\n    selectionManager = new SelectionManager<any>({\r\n        multiSelect: true,\r\n        itemsAreEqual: (a, b) => a.id === b.id,\r\n        additiveMode: true,\r\n    });\r\n    result$: Observable<ResultType>;\r\n    items$: Observable<ItemType[]>;\r\n    totalItems$: Observable<number>;\r\n    itemsPerPage$: Observable<number>;\r\n    currentPage$: Observable<number>;\r\n    protected destroy$ = new Subject<void>();\r\n    private listQuery: QueryResult<ResultType, VariableType>;\r\n    private listQueryFn: ListQueryFn<ResultType>;\r\n    private mappingFn: MappingFn<ItemType, ResultType>;\r\n    private onPageChangeFn: OnPageChangeFn<VariableType> = (skip, take) =>\r\n        ({ options: { skip, take } } as any);\r\n    protected refresh$ = new BehaviorSubject<undefined>(undefined);\r\n    private defaults: { take: number; skip: number } = { take: 10, skip: 0 };\r\n\r\n    constructor(protected router: Router, protected route: ActivatedRoute) {}\r\n\r\n    /**\r\n     * @description\r\n     * Sets the fetch function for the list being implemented.\r\n     */\r\n    setQueryFn(\r\n        listQueryFn: ListQueryFn<ResultType>,\r\n        mappingFn: MappingFn<ItemType, ResultType>,\r\n        onPageChangeFn?: OnPageChangeFn<VariableType>,\r\n        defaults?: { take: number; skip: number },\r\n    ) {\r\n        this.listQueryFn = listQueryFn;\r\n        this.mappingFn = mappingFn;\r\n        if (onPageChangeFn) {\r\n            this.onPageChangeFn = onPageChangeFn;\r\n        }\r\n        if (defaults) {\r\n            this.defaults = defaults;\r\n        }\r\n    }\r\n\r\n    /** @internal */\r\n    ngOnInit() {\r\n        if (!this.listQueryFn) {\r\n            throw new Error(\r\n                `No listQueryFn has been defined. Please call super.setQueryFn() in the constructor.`,\r\n            );\r\n        }\r\n        this.listQuery = this.listQueryFn(this.defaults.take, this.defaults.skip);\r\n\r\n        const fetchPage = ([currentPage, itemsPerPage, _]: [number, number, undefined]) => {\r\n            const take = itemsPerPage;\r\n            const skip = (currentPage - 1) * itemsPerPage;\r\n            this.listQuery.ref.refetch(this.onPageChangeFn(skip, take));\r\n        };\r\n\r\n        this.result$ = this.listQuery.stream$.pipe(shareReplay(1));\r\n        this.items$ = this.result$.pipe(map(data => this.mappingFn(data).items));\r\n        this.totalItems$ = this.result$.pipe(map(data => this.mappingFn(data).totalItems));\r\n        this.currentPage$ = this.route.queryParamMap.pipe(\r\n            map(qpm => qpm.get('page')),\r\n            map(page => (!page ? 1 : +page)),\r\n            distinctUntilChanged(),\r\n        );\r\n        this.itemsPerPage$ = this.route.queryParamMap.pipe(\r\n            map(qpm => qpm.get('perPage')),\r\n            map(perPage => (!perPage ? this.defaults.take : +perPage)),\r\n            distinctUntilChanged(),\r\n        );\r\n\r\n        combineLatest(this.currentPage$, this.itemsPerPage$, this.refresh$)\r\n            .pipe(takeUntil(this.destroy$))\r\n            .subscribe(fetchPage);\r\n    }\r\n\r\n    /**\r\n     * @description\r\n     * Accepts a list of Observables which will trigger a refresh of the list when any of them emit.\r\n     */\r\n    protected refreshListOnChanges(...streams: Array<Observable<any>>) {\r\n        const searchTerm$ = this.searchTermControl.valueChanges.pipe(\r\n            filter(value => value !== null && (2 < value.length || value.length === 0)),\r\n            debounceTime(250),\r\n            tap(() => this.setPageNumber(1)),\r\n        );\r\n\r\n        merge(searchTerm$, ...streams)\r\n            .pipe(takeUntil(this.destroy$))\r\n            .subscribe(() => this.refresh$.next(undefined));\r\n    }\r\n\r\n    /** @internal */\r\n    ngOnDestroy() {\r\n        this.destroy$.next();\r\n        this.destroy$.complete();\r\n        this.listQuery.completed$.next();\r\n    }\r\n\r\n    /**\r\n     * @description\r\n     * Sets the current page number in the url.\r\n     */\r\n    setPageNumber(page: number) {\r\n        this.setQueryParam('page', page, { replaceUrl: true });\r\n    }\r\n\r\n    /**\r\n     * @description\r\n     * Sets the number of items per page in the url.\r\n     */\r\n    setItemsPerPage(perPage: number) {\r\n        this.setQueryParam('perPage', perPage, { replaceUrl: true });\r\n    }\r\n\r\n    /**\r\n     * @description\r\n     * Re-fetch the current page of results.\r\n     */\r\n    refresh() {\r\n        this.refresh$.next(undefined);\r\n    }\r\n\r\n    protected setQueryParam(\r\n        hash: { [key: string]: any },\r\n        options?: { replaceUrl?: boolean; queryParamsHandling?: QueryParamsHandling },\r\n    );\r\n    protected setQueryParam(\r\n        key: string,\r\n        value: any,\r\n        options?: { replaceUrl?: boolean; queryParamsHandling?: QueryParamsHandling },\r\n    );\r\n    protected setQueryParam(\r\n        keyOrHash: string | { [key: string]: any },\r\n        valueOrOptions?: any,\r\n        maybeOptions?: { replaceUrl?: boolean; queryParamsHandling?: QueryParamsHandling },\r\n    ) {\r\n        const paramsObject = typeof keyOrHash === 'string' ? { [keyOrHash]: valueOrOptions } : keyOrHash;\r\n        const options = (typeof keyOrHash === 'string' ? maybeOptions : valueOrOptions) ?? {};\r\n        this.router.navigate(['./'], {\r\n            queryParams: typeof keyOrHash === 'string' ? { [keyOrHash]: valueOrOptions } : keyOrHash,\r\n            relativeTo: this.route,\r\n            queryParamsHandling: 'merge',\r\n            ...options,\r\n        });\r\n    }\r\n}\r\n\r\n/**\r\n * @description\r\n * A version of the {@link BaseListComponent} which is designed to be used with a\r\n * [TypedDocumentNode](https://the-guild.dev/graphql/codegen/plugins/typescript/typed-document-node).\r\n *\r\n * @docsCategory list-detail-views\r\n */\r\n@Directive()\r\nexport class TypedBaseListComponent<\r\n        T extends TypedDocumentNode<any, Vars>,\r\n        Field extends keyof ResultOf<T>,\r\n        Vars extends { options: { filter: any; sort: any } } = VariablesOf<T>,\r\n    >\r\n    extends BaseListComponent<ResultOf<T>, ItemOf<ResultOf<T>, Field>, VariablesOf<T>>\r\n    implements OnInit\r\n{\r\n    availableLanguages$: Observable<LanguageCode[]>;\r\n    contentLanguage$: Observable<LanguageCode>;\r\n\r\n    protected dataService = inject(DataService);\r\n    protected router = inject(Router);\r\n    protected serverConfigService = inject(ServerConfigService);\r\n    private refreshStreams: Array<Observable<any>> = [];\r\n    constructor() {\r\n        super(inject(Router), inject(ActivatedRoute));\r\n    }\r\n\r\n    protected configure(config: {\r\n        document: T;\r\n        getItems: (data: ResultOf<T>) => { items: Array<ItemOf<ResultOf<T>, Field>>; totalItems: number };\r\n        setVariables?: (skip: number, take: number) => VariablesOf<T>;\r\n        refreshListOnChanges?: Array<Observable<any>>;\r\n    }) {\r\n        super.setQueryFn(\r\n            (args: any) => this.dataService.query(config.document).refetchOnChannelChange(),\r\n            data => config.getItems(data),\r\n            (skip, take) => config.setVariables?.(skip, take) ?? ({} as any),\r\n        );\r\n        this.availableLanguages$ = this.serverConfigService.getAvailableLanguages();\r\n        this.contentLanguage$ = this.dataService.client\r\n            .uiState()\r\n            .mapStream(({ uiState }) => uiState.contentLanguage)\r\n            .pipe(tap(() => this.refresh()));\r\n        this.refreshStreams = config.refreshListOnChanges ?? [];\r\n    }\r\n\r\n    ngOnInit() {\r\n        super.ngOnInit();\r\n        super.refreshListOnChanges(this.contentLanguage$, ...this.refreshStreams);\r\n    }\r\n\r\n    createFilterCollection(): DataTableFilterCollection<NonNullable<NonNullable<Vars['options']>['filter']>> {\r\n        return new DataTableFilterCollection<NonNullable<Vars['options']['filter']>>(this.router);\r\n    }\r\n\r\n    createSortCollection(): DataTableSortCollection<NonNullable<NonNullable<Vars['options']>['sort']>> {\r\n        return new DataTableSortCollection<NonNullable<Vars['options']['sort']>>(this.router);\r\n    }\r\n\r\n    setLanguage(code: LanguageCode) {\r\n        this.dataService.client.setContentLanguage(code).subscribe();\r\n    }\r\n\r\n    getCustomFieldConfig(key: Exclude<keyof CustomFields, '__typename'>): CustomFieldConfig[] {\r\n        return this.serverConfigService.getCustomFieldsFor(key);\r\n    }\r\n}\r\n"]}
180
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-list.component.js","sourceRoot":"","sources":["../../../../src/lib/core/src/common/base-list.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { DestroyRef, Directive, inject, OnDestroy, OnInit } from '@angular/core';\r\nimport { FormControl } from '@angular/forms';\r\nimport { ActivatedRoute, QueryParamsHandling, Router } from '@angular/router';\r\nimport { ResultOf, TypedDocumentNode, VariablesOf } from '@graphql-typed-document-node/core';\r\nimport { BehaviorSubject, combineLatest, merge, Observable, Subject } from 'rxjs';\r\nimport { debounceTime, distinctUntilChanged, filter, map, shareReplay, takeUntil, tap } from 'rxjs/operators';\r\nimport { DataService } from '../data/providers/data.service';\r\n\r\nimport { QueryResult } from '../data/query-result';\r\nimport { ServerConfigService } from '../data/server-config';\r\nimport { DataTableFilterCollection } from '../providers/data-table/data-table-filter-collection';\r\nimport { DataTableSortCollection } from '../providers/data-table/data-table-sort-collection';\r\nimport { CustomFieldConfig, CustomFields, LanguageCode } from './generated-types';\r\nimport { SelectionManager } from './utilities/selection-manager';\r\n\r\nexport type ListQueryFn<R> = (take: number, skip: number, ...args: any[]) => QueryResult<R, any>;\r\nexport type MappingFn<T, R> = (result: R) => { items: T[]; totalItems: number };\r\nexport type OnPageChangeFn<V> = (skip: number, take: number) => V;\r\n\r\n/**\r\n * Unwraps a query that returns a paginated list with an \"items\" property,\r\n * returning the type of one of the items in the array.\r\n */\r\nexport type ItemOf<T, K extends keyof T> = T[K] extends { items: infer R }\r\n    ? R extends any[]\r\n        ? R[number]\r\n        : R\r\n    : never;\r\n\r\n/**\r\n * @description\r\n * This is a base class which implements the logic required to fetch and manipulate\r\n * a list of data from a query which returns a PaginatedList type.\r\n *\r\n * It is normally used in combination with the {@link DataTable2Component}.\r\n *\r\n * @docsCategory list-detail-views\r\n */\r\n@Directive()\r\n// eslint-disable-next-line @angular-eslint/directive-class-suffix\r\nexport class BaseListComponent<ResultType, ItemType, VariableType extends Record<string, any> = any>\r\n    implements OnInit, OnDestroy\r\n{\r\n    searchTermControl = new FormControl('');\r\n    selectionManager = new SelectionManager<any>({\r\n        multiSelect: true,\r\n        itemsAreEqual: (a, b) => a.id === b.id,\r\n        additiveMode: true,\r\n    });\r\n    result$: Observable<ResultType>;\r\n    items$: Observable<ItemType[]>;\r\n    totalItems$: Observable<number>;\r\n    itemsPerPage$: Observable<number>;\r\n    currentPage$: Observable<number>;\r\n    protected destroy$ = new Subject<void>();\r\n    private listQuery: QueryResult<ResultType, VariableType>;\r\n    private listQueryFn: ListQueryFn<ResultType>;\r\n    private mappingFn: MappingFn<ItemType, ResultType>;\r\n    private onPageChangeFn: OnPageChangeFn<VariableType> = (skip, take) =>\r\n        ({ options: { skip, take } } as any);\r\n    protected refresh$ = new BehaviorSubject<undefined>(undefined);\r\n    private defaults: { take: number; skip: number } = { take: 10, skip: 0 };\r\n\r\n    constructor(protected router: Router, protected route: ActivatedRoute) {}\r\n\r\n    /**\r\n     * @description\r\n     * Sets the fetch function for the list being implemented.\r\n     */\r\n    setQueryFn(\r\n        listQueryFn: ListQueryFn<ResultType>,\r\n        mappingFn: MappingFn<ItemType, ResultType>,\r\n        onPageChangeFn?: OnPageChangeFn<VariableType>,\r\n        defaults?: { take: number; skip: number },\r\n    ) {\r\n        this.listQueryFn = listQueryFn;\r\n        this.mappingFn = mappingFn;\r\n        if (onPageChangeFn) {\r\n            this.onPageChangeFn = onPageChangeFn;\r\n        }\r\n        if (defaults) {\r\n            this.defaults = defaults;\r\n        }\r\n    }\r\n\r\n    /** @internal */\r\n    ngOnInit() {\r\n        if (!this.listQueryFn) {\r\n            throw new Error(\r\n                `No listQueryFn has been defined. Please call super.setQueryFn() in the constructor.`,\r\n            );\r\n        }\r\n        this.listQuery = this.listQueryFn(this.defaults.take, this.defaults.skip);\r\n\r\n        const fetchPage = ([currentPage, itemsPerPage, _]: [number, number, undefined]) => {\r\n            const take = itemsPerPage;\r\n            const skip = (currentPage - 1) * itemsPerPage;\r\n            this.listQuery.ref.refetch(this.onPageChangeFn(skip, take));\r\n        };\r\n\r\n        this.result$ = this.listQuery.stream$.pipe(shareReplay(1));\r\n        this.items$ = this.result$.pipe(map(data => this.mappingFn(data).items));\r\n        this.totalItems$ = this.result$.pipe(map(data => this.mappingFn(data).totalItems));\r\n        this.currentPage$ = this.route.queryParamMap.pipe(\r\n            map(qpm => qpm.get('page')),\r\n            map(page => (!page ? 1 : +page)),\r\n            distinctUntilChanged(),\r\n        );\r\n        this.itemsPerPage$ = this.route.queryParamMap.pipe(\r\n            map(qpm => qpm.get('perPage')),\r\n            map(perPage => (!perPage ? this.defaults.take : +perPage)),\r\n            distinctUntilChanged(),\r\n        );\r\n\r\n        combineLatest(this.currentPage$, this.itemsPerPage$, this.refresh$)\r\n            .pipe(takeUntil(this.destroy$))\r\n            .subscribe(fetchPage);\r\n    }\r\n\r\n    /**\r\n     * @description\r\n     * Accepts a list of Observables which will trigger a refresh of the list when any of them emit.\r\n     */\r\n    protected refreshListOnChanges(...streams: Array<Observable<any>>) {\r\n        const searchTerm$ = this.searchTermControl.valueChanges.pipe(\r\n            filter(value => value !== null && (2 < value.length || value.length === 0)),\r\n            debounceTime(250),\r\n            tap(() => this.setPageNumber(1)),\r\n        );\r\n\r\n        merge(searchTerm$, ...streams)\r\n            .pipe(takeUntil(this.destroy$))\r\n            .subscribe(() => this.refresh$.next(undefined));\r\n    }\r\n\r\n    /** @internal */\r\n    ngOnDestroy() {\r\n        this.destroy$.next();\r\n        this.destroy$.complete();\r\n        this.listQuery.completed$.next();\r\n    }\r\n\r\n    /**\r\n     * @description\r\n     * Sets the current page number in the url.\r\n     */\r\n    setPageNumber(page: number) {\r\n        this.setQueryParam('page', page, { replaceUrl: true });\r\n    }\r\n\r\n    /**\r\n     * @description\r\n     * Sets the number of items per page in the url.\r\n     */\r\n    setItemsPerPage(perPage: number) {\r\n        this.setQueryParam('perPage', perPage, { replaceUrl: true });\r\n    }\r\n\r\n    /**\r\n     * @description\r\n     * Re-fetch the current page of results.\r\n     */\r\n    refresh() {\r\n        this.refresh$.next(undefined);\r\n    }\r\n\r\n    protected setQueryParam(\r\n        hash: { [key: string]: any },\r\n        options?: { replaceUrl?: boolean; queryParamsHandling?: QueryParamsHandling },\r\n    );\r\n    protected setQueryParam(\r\n        key: string,\r\n        value: any,\r\n        options?: { replaceUrl?: boolean; queryParamsHandling?: QueryParamsHandling },\r\n    );\r\n    protected setQueryParam(\r\n        keyOrHash: string | { [key: string]: any },\r\n        valueOrOptions?: any,\r\n        maybeOptions?: { replaceUrl?: boolean; queryParamsHandling?: QueryParamsHandling },\r\n    ) {\r\n        const paramsObject = typeof keyOrHash === 'string' ? { [keyOrHash]: valueOrOptions } : keyOrHash;\r\n        const options = (typeof keyOrHash === 'string' ? maybeOptions : valueOrOptions) ?? {};\r\n        this.router.navigate(['./'], {\r\n            queryParams: typeof keyOrHash === 'string' ? { [keyOrHash]: valueOrOptions } : keyOrHash,\r\n            relativeTo: this.route,\r\n            queryParamsHandling: 'merge',\r\n            ...options,\r\n        });\r\n    }\r\n}\r\n\r\n/**\r\n * @description\r\n * A version of the {@link BaseListComponent} which is designed to be used with a\r\n * [TypedDocumentNode](https://the-guild.dev/graphql/codegen/plugins/typescript/typed-document-node).\r\n *\r\n * @docsCategory list-detail-views\r\n */\r\n@Directive()\r\nexport class TypedBaseListComponent<\r\n        T extends TypedDocumentNode<any, Vars>,\r\n        Field extends keyof ResultOf<T>,\r\n        Vars extends { options: { filter: any; sort: any } } = VariablesOf<T>,\r\n    >\r\n    extends BaseListComponent<ResultOf<T>, ItemOf<ResultOf<T>, Field>, VariablesOf<T>>\r\n    implements OnInit\r\n{\r\n    availableLanguages$: Observable<LanguageCode[]>;\r\n    contentLanguage$: Observable<LanguageCode>;\r\n\r\n    protected dataService = inject(DataService);\r\n    protected router = inject(Router);\r\n    protected serverConfigService = inject(ServerConfigService);\r\n    private refreshStreams: Array<Observable<any>> = [];\r\n    private collections: Array<DataTableFilterCollection | DataTableSortCollection<any>> = [];\r\n    constructor() {\r\n        super(inject(Router), inject(ActivatedRoute));\r\n\r\n        const destroyRef = inject(DestroyRef);\r\n        destroyRef.onDestroy(() => {\r\n            this.collections.forEach(c => c.destroy());\r\n        });\r\n    }\r\n\r\n    protected configure(config: {\r\n        document: T;\r\n        getItems: (data: ResultOf<T>) => { items: Array<ItemOf<ResultOf<T>, Field>>; totalItems: number };\r\n        setVariables?: (skip: number, take: number) => VariablesOf<T>;\r\n        refreshListOnChanges?: Array<Observable<any>>;\r\n    }) {\r\n        super.setQueryFn(\r\n            (args: any) => this.dataService.query(config.document).refetchOnChannelChange(),\r\n            data => config.getItems(data),\r\n            (skip, take) => config.setVariables?.(skip, take) ?? ({} as any),\r\n        );\r\n        this.availableLanguages$ = this.serverConfigService.getAvailableLanguages();\r\n        this.contentLanguage$ = this.dataService.client\r\n            .uiState()\r\n            .mapStream(({ uiState }) => uiState.contentLanguage)\r\n            .pipe(tap(() => this.refresh()));\r\n        this.refreshStreams = config.refreshListOnChanges ?? [];\r\n    }\r\n\r\n    ngOnInit() {\r\n        super.ngOnInit();\r\n        super.refreshListOnChanges(this.contentLanguage$, ...this.refreshStreams);\r\n    }\r\n\r\n    createFilterCollection(): DataTableFilterCollection<NonNullable<NonNullable<Vars['options']>['filter']>> {\r\n        const collection = new DataTableFilterCollection<NonNullable<Vars['options']['filter']>>(this.router);\r\n        this.collections.push(collection);\r\n        return collection;\r\n    }\r\n\r\n    createSortCollection(): DataTableSortCollection<NonNullable<NonNullable<Vars['options']>['sort']>> {\r\n        const collection = new DataTableSortCollection<NonNullable<Vars['options']['sort']>>(this.router);\r\n        this.collections.push(collection);\r\n        return collection;\r\n    }\r\n\r\n    setLanguage(code: LanguageCode) {\r\n        this.dataService.client.setContentLanguage(code).subscribe();\r\n    }\r\n\r\n    getCustomFieldConfig(key: Exclude<keyof CustomFields, '__typename'>): CustomFieldConfig[] {\r\n        return this.serverConfigService.getCustomFieldsFor(key);\r\n    }\r\n}\r\n"]}
@@ -1,3 +1,3 @@
1
1
  // Auto-generated by the set-version.js script.
2
- export const ADMIN_UI_VERSION = '2.1.0-next.6';
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9saWIvY29yZS9zcmMvY29tbW9uL3ZlcnNpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsK0NBQStDO0FBQy9DLE1BQU0sQ0FBQyxNQUFNLGdCQUFnQixHQUFHLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8vIEF1dG8tZ2VuZXJhdGVkIGJ5IHRoZSBzZXQtdmVyc2lvbi5qcyBzY3JpcHQuXG5leHBvcnQgY29uc3QgQURNSU5fVUlfVkVSU0lPTiA9ICcyLjEuMC1uZXh0LjYnO1xuIl19
2
+ export const ADMIN_UI_VERSION = '2.1.0';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9saWIvY29yZS9zcmMvY29tbW9uL3ZlcnNpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsK0NBQStDO0FBQy9DLE1BQU0sQ0FBQyxNQUFNLGdCQUFnQixHQUFHLE9BQU8sQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8vIEF1dG8tZ2VuZXJhdGVkIGJ5IHRoZSBzZXQtdmVyc2lvbi5qcyBzY3JpcHQuXG5leHBvcnQgY29uc3QgQURNSU5fVUlfVkVSU0lPTiA9ICcyLjEuMCc7XG4iXX0=
@@ -82,4 +82,4 @@ export function registerRouteComponent(options) {
82
82
  component: AngularRouteComponent,
83
83
  };
84
84
  }
85
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"register-route-component.js","sourceRoot":"","sources":["../../../../src/lib/core/src/extension/register-route-component.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,eAAe,EAAc,MAAM,MAAM,CAAC;AACnD,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACrC,OAAO,EAAuB,yBAAyB,EAAE,MAAM,iCAAiC,CAAC;AAEjG,OAAO,EAAE,qBAAqB,EAAE,MAAM,sCAAsC,CAAC;AAC7E,OAAO,EAAE,uBAAuB,EAAE,MAAM,8BAA8B,CAAC;AA2BvE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAuCG;AACH,MAAM,UAAU,sBAAsB,CAMpC,OAAsE;IACpE,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,SAAS,EAAE,cAAc,EAAE,GAAG,OAAO,CAAC;IAEhE,MAAM,kBAAkB,GAAG,IAAI,eAAe,CAAkB,OAAO,CAAC,UAAU,IAAI,EAAE,CAAC,CAAC;IAC1F,MAAM,aAAa,GAAG,IAAI,eAAe,CAAqB,OAAO,CAAC,KAAK,CAAC,CAAC;IAE7E,MAAM,SAAS,GAMX,KAAK,IAAI,SAAS;QACd,CAAC,CAAC,yBAAyB,CAAC;YACtB,KAAK;YACL,SAAS;YACT,SAAS;SACZ,CAAC;QACJ,CAAC,CAAC,SAAS,CAAC;IAEpB,OAAO;QACH,IAAI,EAAE,OAAO,CAAC,IAAI,IAAI,EAAE;QACxB,SAAS,EAAE;YACP;gBACI,OAAO,EAAE,uBAAuB;gBAChC,QAAQ,EAAE;oBACN,SAAS,EAAE,OAAO,CAAC,SAAS;oBAC5B,MAAM,EAAE,aAAa;oBACrB,WAAW,EAAE,kBAAkB;iBACF;aACpC;YACD,GAAG,CAAC,OAAO,CAAC,WAAW,EAAE,SAAS,IAAI,EAAE,CAAC;SAC5C;QACD,GAAG,CAAC,OAAO,CAAC,WAAW,IAAI,EAAE,CAAC;QAC9B,OAAO,EAAE,EAAE,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,GAAG,CAAC,OAAO,CAAC,WAAW,EAAE,OAAO,IAAI,EAAE,CAAC,EAAE;QACjG,IAAI,EAAE;YACF,UAAU,EAAE,kBAAkB;YAC9B,GAAG,CAAC,OAAO,CAAC,WAAW,EAAE,IAAI,IAAI,EAAE,CAAC;YACpC,GAAG,CAAC,cAAc;gBACd,CAAC,CAAC;oBACI,UAAU,EAAE,IAAI,CAAC,EAAE,CACf,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,MAAW,EAAE,EAAE,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC;iBAC5E;gBACH,CAAC,CAAC,EAAE,CAAC;YACT,GAAG,CAAC,OAAO,CAAC,WAAW,EAAE,IAAI,IAAI,EAAE,CAAC;SACvC;QACD,SAAS,EAAE,qBAAqB;KACnB,CAAC;AACtB,CAAC","sourcesContent":["import { Type } from '@angular/core';\r\nimport { ResolveFn, Route } from '@angular/router';\r\nimport { ResultOf, TypedDocumentNode } from '@graphql-typed-document-node/core';\r\nimport { DocumentNode } from 'graphql';\r\nimport { BehaviorSubject, Observable } from 'rxjs';\r\nimport { map } from 'rxjs/operators';\r\nimport { BaseDetailComponent, createBaseDetailResolveFn } from '../common/base-detail.component';\r\nimport { BreadcrumbValue } from '../providers/breadcrumb/breadcrumb.service';\r\nimport { AngularRouteComponent } from './components/angular-route.component';\r\nimport { ROUTE_COMPONENT_OPTIONS } from './components/route.component';\r\nimport { RouteComponentOptions } from './types';\r\n\r\n/**\r\n * @description\r\n * Configuration for a route component.\r\n *\r\n * @docsCategory routes\r\n */\r\nexport type RegisterRouteComponentOptions<\r\n    Component extends any | BaseDetailComponent<Entity>,\r\n    Entity extends { id: string; updatedAt?: string },\r\n    T extends DocumentNode | TypedDocumentNode<any, { id: string }>,\r\n    Field extends keyof ResultOf<T>,\r\n    R extends Field,\r\n> = {\r\n    component: Type<Component> | Component;\r\n    title?: string;\r\n    breadcrumb?: BreadcrumbValue;\r\n    path?: string;\r\n    query?: T;\r\n    getBreadcrumbs?: (entity: Exclude<ResultOf<T>[R], 'Query'>) => BreadcrumbValue;\r\n    entityKey?: Component extends BaseDetailComponent<Entity> ? R : undefined;\r\n    variables?: T extends TypedDocumentNode<any, infer V> ? Omit<V, 'id'> : never;\r\n    routeConfig?: Route;\r\n} & (Component extends BaseDetailComponent<Entity> ? { entityKey: R } : unknown);\r\n\r\n/**\r\n * @description\r\n * Registers an Angular standalone component to be rendered in a route.\r\n *\r\n * @example\r\n * ```ts title=\"routes.ts\"\r\n * import { registerRouteComponent } from '\\@vendure/admin-ui/core';\r\n * import { registerReactRouteComponent } from '\\@vendure/admin-ui/react';\r\n *\r\n * import { ProductReviewDetailComponent } from './components/product-review-detail/product-review-detail.component';\r\n * import { AllProductReviewsList } from './components/all-product-reviews-list/all-product-reviews-list.component';\r\n * import { GetReviewDetailDocument } from './generated-types';\r\n *\r\n * export default [\r\n *     registerRouteComponent({\r\n *         path: '',\r\n *         component: AllProductReviewsList,\r\n *         breadcrumb: 'Product reviews',\r\n *     }),\r\n *     registerRouteComponent({\r\n *         path: ':id',\r\n *         component: ProductReviewDetailComponent,\r\n *         query: GetReviewDetailDocument,\r\n *         entityKey: 'productReview',\r\n *         getBreadcrumbs: entity => [\r\n *             {\r\n *                 label: 'Product reviews',\r\n *                 link: ['/extensions', 'product-reviews'],\r\n *             },\r\n *             {\r\n *                 label: `#${entity?.id} (${entity?.product.name})`,\r\n *                 link: [],\r\n *             },\r\n *         ],\r\n *     }),\r\n * ];\r\n * ```\r\n *\r\n * @docsCategory routes\r\n */\r\nexport function registerRouteComponent<\r\n    Component extends any | BaseDetailComponent<Entity>,\r\n    Entity extends { id: string; updatedAt?: string },\r\n    T extends DocumentNode | TypedDocumentNode<any, { id: string }>,\r\n    Field extends keyof ResultOf<T>,\r\n    R extends Field,\r\n>(options: RegisterRouteComponentOptions<Component, Entity, T, Field, R>) {\r\n    const { query, entityKey, variables, getBreadcrumbs } = options;\r\n\r\n    const breadcrumbSubject$ = new BehaviorSubject<BreadcrumbValue>(options.breadcrumb ?? '');\r\n    const titleSubject$ = new BehaviorSubject<string | undefined>(options.title);\r\n\r\n    const resolveFn:\r\n        | ResolveFn<{\r\n              entity: Observable<ResultOf<T>[Field] | null>;\r\n              result?: ResultOf<T>;\r\n          }>\r\n        | undefined =\r\n        query && entityKey\r\n            ? createBaseDetailResolveFn({\r\n                  query,\r\n                  entityKey,\r\n                  variables,\r\n              })\r\n            : undefined;\r\n\r\n    return {\r\n        path: options.path ?? '',\r\n        providers: [\r\n            {\r\n                provide: ROUTE_COMPONENT_OPTIONS,\r\n                useValue: {\r\n                    component: options.component,\r\n                    title$: titleSubject$,\r\n                    breadcrumb$: breadcrumbSubject$,\r\n                } satisfies RouteComponentOptions,\r\n            },\r\n            ...(options.routeConfig?.providers ?? []),\r\n        ],\r\n        ...(options.routeConfig ?? {}),\r\n        resolve: { ...(resolveFn ? { detail: resolveFn } : {}), ...(options.routeConfig?.resolve ?? {}) },\r\n        data: {\r\n            breadcrumb: breadcrumbSubject$,\r\n            ...(options.routeConfig?.data ?? {}),\r\n            ...(getBreadcrumbs\r\n                ? {\r\n                      breadcrumb: data =>\r\n                          data.detail.entity.pipe(map((entity: any) => getBreadcrumbs(entity))),\r\n                  }\r\n                : {}),\r\n            ...(options.routeConfig?.data ?? {}),\r\n        },\r\n        component: AngularRouteComponent,\r\n    } satisfies Route;\r\n}\r\n"]}
85
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"register-route-component.js","sourceRoot":"","sources":["../../../../src/lib/core/src/extension/register-route-component.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,eAAe,EAAc,MAAM,MAAM,CAAC;AACnD,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACrC,OAAO,EAAuB,yBAAyB,EAAE,MAAM,iCAAiC,CAAC;AAEjG,OAAO,EAAE,qBAAqB,EAAE,MAAM,sCAAsC,CAAC;AAC7E,OAAO,EAAE,uBAAuB,EAAE,MAAM,8BAA8B,CAAC;AA2BvE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAuCG;AACH,MAAM,UAAU,sBAAsB,CAMpC,OAAsE;IACpE,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,SAAS,EAAE,cAAc,EAAE,GAAG,OAAO,CAAC;IAEhE,MAAM,kBAAkB,GAAG,IAAI,eAAe,CAAkB,OAAO,CAAC,UAAU,IAAI,EAAE,CAAC,CAAC;IAC1F,MAAM,aAAa,GAAG,IAAI,eAAe,CAAqB,OAAO,CAAC,KAAK,CAAC,CAAC;IAE7E,MAAM,SAAS,GAMX,KAAK,IAAI,SAAS;QACd,CAAC,CAAC,yBAAyB,CAAC;YACtB,KAAK;YACL,SAAS;YACT,SAAS;SACZ,CAAC;QACJ,CAAC,CAAC,SAAS,CAAC;IAEpB,OAAO;QACH,IAAI,EAAE,OAAO,CAAC,IAAI,IAAI,EAAE;QACxB,SAAS,EAAE;YACP;gBACI,OAAO,EAAE,uBAAuB;gBAChC,QAAQ,EAAE;oBACN,SAAS,EAAE,OAAO,CAAC,SAAS;oBAC5B,MAAM,EAAE,aAAa;oBACrB,WAAW,EAAE,kBAAkB;iBACF;aACpC;YACD,GAAG,CAAC,OAAO,CAAC,WAAW,EAAE,SAAS,IAAI,EAAE,CAAC;SAC5C;QACD,GAAG,CAAC,OAAO,CAAC,WAAW,IAAI,EAAE,CAAC;QAC9B,OAAO,EAAE,EAAE,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,GAAG,CAAC,OAAO,CAAC,WAAW,EAAE,OAAO,IAAI,EAAE,CAAC,EAAE;QACjG,IAAI,EAAE;YACF,UAAU,EAAE,kBAAkB;YAC9B,GAAG,CAAC,OAAO,CAAC,WAAW,EAAE,IAAI,IAAI,EAAE,CAAC;YACpC,GAAG,CAAC,cAAc;gBACd,CAAC,CAAC;oBACI,UAAU,EAAE,IAAI,CAAC,EAAE,CACf,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,MAAW,EAAE,EAAE,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC;iBAC5E;gBACH,CAAC,CAAC,EAAE,CAAC;YACT,GAAG,CAAC,OAAO,CAAC,WAAW,EAAE,IAAI,IAAI,EAAE,CAAC;SACvC;QACD,SAAS,EAAE,qBAAqB;KACnB,CAAC;AACtB,CAAC","sourcesContent":["import { Type } from '@angular/core';\r\nimport { ResolveFn, Route } from '@angular/router';\r\nimport { ResultOf, TypedDocumentNode } from '@graphql-typed-document-node/core';\r\nimport { DocumentNode } from 'graphql';\r\nimport { BehaviorSubject, Observable } from 'rxjs';\r\nimport { map } from 'rxjs/operators';\r\nimport { BaseDetailComponent, createBaseDetailResolveFn } from '../common/base-detail.component';\r\nimport { BreadcrumbValue } from '../providers/breadcrumb/breadcrumb.service';\r\nimport { AngularRouteComponent } from './components/angular-route.component';\r\nimport { ROUTE_COMPONENT_OPTIONS } from './components/route.component';\r\nimport { RouteComponentOptions } from './types';\r\n\r\n/**\r\n * @description\r\n * Configuration for a route component.\r\n *\r\n * @docsCategory routes\r\n */\r\nexport type RegisterRouteComponentOptions<\r\n    Component extends any | BaseDetailComponent<Entity>,\r\n    Entity extends { id: string; updatedAt?: string },\r\n    T extends DocumentNode | TypedDocumentNode<any, { id: string }>,\r\n    Field extends keyof ResultOf<T>,\r\n    R extends Field,\r\n> = {\r\n    component: Type<Component> | Component;\r\n    title?: string;\r\n    breadcrumb?: BreadcrumbValue;\r\n    path?: string;\r\n    query?: T;\r\n    getBreadcrumbs?: (entity: Exclude<ResultOf<T>[R], 'Query'>) => BreadcrumbValue;\r\n    entityKey?: Component extends BaseDetailComponent<any> ? R : undefined;\r\n    variables?: T extends TypedDocumentNode<any, infer V> ? Omit<V, 'id'> : never;\r\n    routeConfig?: Route;\r\n} & (Component extends BaseDetailComponent<any> ? { entityKey: R } : unknown);\r\n\r\n/**\r\n * @description\r\n * Registers an Angular standalone component to be rendered in a route.\r\n *\r\n * @example\r\n * ```ts title=\"routes.ts\"\r\n * import { registerRouteComponent } from '\\@vendure/admin-ui/core';\r\n * import { registerReactRouteComponent } from '\\@vendure/admin-ui/react';\r\n *\r\n * import { ProductReviewDetailComponent } from './components/product-review-detail/product-review-detail.component';\r\n * import { AllProductReviewsList } from './components/all-product-reviews-list/all-product-reviews-list.component';\r\n * import { GetReviewDetailDocument } from './generated-types';\r\n *\r\n * export default [\r\n *     registerRouteComponent({\r\n *         path: '',\r\n *         component: AllProductReviewsList,\r\n *         breadcrumb: 'Product reviews',\r\n *     }),\r\n *     registerRouteComponent({\r\n *         path: ':id',\r\n *         component: ProductReviewDetailComponent,\r\n *         query: GetReviewDetailDocument,\r\n *         entityKey: 'productReview',\r\n *         getBreadcrumbs: entity => [\r\n *             {\r\n *                 label: 'Product reviews',\r\n *                 link: ['/extensions', 'product-reviews'],\r\n *             },\r\n *             {\r\n *                 label: `#${entity?.id} (${entity?.product.name})`,\r\n *                 link: [],\r\n *             },\r\n *         ],\r\n *     }),\r\n * ];\r\n * ```\r\n *\r\n * @docsCategory routes\r\n */\r\nexport function registerRouteComponent<\r\n    Component extends any | BaseDetailComponent<Entity>,\r\n    Entity extends { id: string; updatedAt?: string },\r\n    T extends DocumentNode | TypedDocumentNode<any, { id: string }>,\r\n    Field extends keyof ResultOf<T>,\r\n    R extends Field,\r\n>(options: RegisterRouteComponentOptions<Component, Entity, T, Field, R>) {\r\n    const { query, entityKey, variables, getBreadcrumbs } = options;\r\n\r\n    const breadcrumbSubject$ = new BehaviorSubject<BreadcrumbValue>(options.breadcrumb ?? '');\r\n    const titleSubject$ = new BehaviorSubject<string | undefined>(options.title);\r\n\r\n    const resolveFn:\r\n        | ResolveFn<{\r\n              entity: Observable<ResultOf<T>[Field] | null>;\r\n              result?: ResultOf<T>;\r\n          }>\r\n        | undefined =\r\n        query && entityKey\r\n            ? createBaseDetailResolveFn({\r\n                  query,\r\n                  entityKey,\r\n                  variables,\r\n              })\r\n            : undefined;\r\n\r\n    return {\r\n        path: options.path ?? '',\r\n        providers: [\r\n            {\r\n                provide: ROUTE_COMPONENT_OPTIONS,\r\n                useValue: {\r\n                    component: options.component,\r\n                    title$: titleSubject$,\r\n                    breadcrumb$: breadcrumbSubject$,\r\n                } satisfies RouteComponentOptions,\r\n            },\r\n            ...(options.routeConfig?.providers ?? []),\r\n        ],\r\n        ...(options.routeConfig ?? {}),\r\n        resolve: { ...(resolveFn ? { detail: resolveFn } : {}), ...(options.routeConfig?.resolve ?? {}) },\r\n        data: {\r\n            breadcrumb: breadcrumbSubject$,\r\n            ...(options.routeConfig?.data ?? {}),\r\n            ...(getBreadcrumbs\r\n                ? {\r\n                      breadcrumb: data =>\r\n                          data.detail.entity.pipe(map((entity: any) => getBreadcrumbs(entity))),\r\n                  }\r\n                : {}),\r\n            ...(options.routeConfig?.data ?? {}),\r\n        },\r\n        component: AngularRouteComponent,\r\n    } satisfies Route;\r\n}\r\n"]}
@@ -2,7 +2,7 @@ import { marker as _ } from '@biesbjerg/ngx-translate-extract-marker';
2
2
  import { assertNever } from '@vendure/common/lib/shared-utils';
3
3
  import extend from 'just-extend';
4
4
  import { Subject } from 'rxjs';
5
- import { debounceTime, distinctUntilChanged, map, startWith } from 'rxjs/operators';
5
+ import { debounceTime, distinctUntilChanged, map, startWith, takeUntil } from 'rxjs/operators';
6
6
  import { DataTableFilter, } from './data-table-filter';
7
7
  export class FilterWithValue {
8
8
  constructor(filter, value, onUpdate) {
@@ -58,6 +58,7 @@ export class DataTableFilterCollection {
58
58
  this.#connectedToRouter = false;
59
59
  this.valueChanges = this.#valueChanges$.asObservable().pipe(debounceTime(10));
60
60
  this.#filtersQueryParamName = 'filters';
61
+ this.destroy$ = new Subject();
61
62
  }
62
63
  get length() {
63
64
  return this.#filters.length;
@@ -65,6 +66,10 @@ export class DataTableFilterCollection {
65
66
  get activeFilters() {
66
67
  return this.#activeFilters;
67
68
  }
69
+ destroy() {
70
+ this.destroy$.next();
71
+ this.destroy$.complete();
72
+ }
68
73
  addFilter(config) {
69
74
  if (this.#connectedToRouter) {
70
75
  throw new Error('Cannot add filter after connecting to router. Make sure to call addFilter() before connectToRoute()');
@@ -161,8 +166,19 @@ export class DataTableFilterCollection {
161
166
  }, {});
162
167
  }
163
168
  connectToRoute(route) {
169
+ this.valueChanges.pipe(takeUntil(this.destroy$)).subscribe(val => {
170
+ const currentFilters = route.snapshot.queryParamMap.get(this.#filtersQueryParamName);
171
+ if (val.length === 0 && !currentFilters) {
172
+ return;
173
+ }
174
+ this.router.navigate(['./'], {
175
+ queryParams: { [this.#filtersQueryParamName]: this.serialize(), page: 1 },
176
+ relativeTo: route,
177
+ queryParamsHandling: 'merge',
178
+ });
179
+ });
164
180
  route.queryParamMap
165
- .pipe(map(params => params.get(this.#filtersQueryParamName)), distinctUntilChanged(), startWith(route.snapshot.queryParamMap.get(this.#filtersQueryParamName) ?? ''))
181
+ .pipe(map(params => params.get(this.#filtersQueryParamName)), distinctUntilChanged(), startWith(route.snapshot.queryParamMap.get(this.#filtersQueryParamName) ?? ''), takeUntil(this.destroy$))
166
182
  .subscribe(value => {
167
183
  this.#activeFilters = [];
168
184
  if (value === '' || value === null) {
@@ -276,4 +292,4 @@ export class DataTableFilterCollection {
276
292
  return new FilterWithValue(filter, value, v => this.#valueChanges$.next(v));
277
293
  }
278
294
  }
279
- //# 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        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 === '' || value === null) {\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            if (val.mode === 'relative') {\r\n                return `${val.mode},${val.relativeValue},${val.relativeUnit}`;\r\n            } else {\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            }\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                let mode = 'relative';\r\n                let relativeValue: number | undefined;\r\n                let relativeUnit: 'day' | 'month' | 'year' | undefined;\r\n                let start: string | undefined;\r\n                let end: string | undefined;\r\n                if (value.startsWith('relative')) {\r\n                    mode = 'relative';\r\n                    const [_, relativeValueStr, relativeUnitStr] = value.split(',');\r\n                    relativeValue = Number(relativeValueStr);\r\n                    relativeUnit = relativeUnitStr as 'day' | 'month' | 'year';\r\n                } else {\r\n                    mode = 'range';\r\n                    const [startTimestamp, endTimestamp] = value.split(',');\r\n                    start = startTimestamp ? new Date(Number(startTimestamp)).toISOString() : '';\r\n                    end = endTimestamp ? new Date(Number(endTimestamp)).toISOString() : '';\r\n                }\r\n                return { mode, relativeValue, relativeUnit, 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"]}
295
+ //# 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, takeUntil } 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\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    private readonly destroy$ = new Subject<void>();\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    destroy() {\r\n        this.destroy$.next();\r\n        this.destroy$.complete();\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.pipe(takeUntil(this.destroy$)).subscribe(val => {\r\n            const currentFilters = route.snapshot.queryParamMap.get(this.#filtersQueryParamName);\r\n            if (val.length === 0 && !currentFilters) {\r\n                return;\r\n            }\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        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                takeUntil(this.destroy$),\r\n            )\r\n            .subscribe(value => {\r\n                this.#activeFilters = [];\r\n                if (value === '' || value === null) {\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            if (val.mode === 'relative') {\r\n                return `${val.mode},${val.relativeValue},${val.relativeUnit}`;\r\n            } else {\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            }\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                let mode = 'relative';\r\n                let relativeValue: number | undefined;\r\n                let relativeUnit: 'day' | 'month' | 'year' | undefined;\r\n                let start: string | undefined;\r\n                let end: string | undefined;\r\n                if (value.startsWith('relative')) {\r\n                    mode = 'relative';\r\n                    const [_, relativeValueStr, relativeUnitStr] = value.split(',');\r\n                    relativeValue = Number(relativeValueStr);\r\n                    relativeUnit = relativeUnitStr as 'day' | 'month' | 'year';\r\n                } else {\r\n                    mode = 'range';\r\n                    const [startTimestamp, endTimestamp] = value.split(',');\r\n                    start = startTimestamp ? new Date(Number(startTimestamp)).toISOString() : '';\r\n                    end = endTimestamp ? new Date(Number(endTimestamp)).toISOString() : '';\r\n                }\r\n                return { mode, relativeValue, relativeUnit, 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"]}