@vendure/admin-ui 2.1.0-next.7 → 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.
- package/core/common/base-list.component.d.ts +1 -0
- package/core/common/version.d.ts +1 -1
- package/core/extension/register-route-component.d.ts +2 -2
- package/core/providers/data-table/data-table-filter-collection.d.ts +2 -0
- package/core/providers/data-table/data-table-sort-collection.d.ts +2 -0
- package/core/shared/components/data-table-filter-presets/data-table-filter-presets.component.d.ts +3 -2
- package/core/shared/components/data-table-filters/data-table-filters.component.d.ts +1 -1
- package/esm2022/core/common/base-list.component.mjs +13 -4
- package/esm2022/core/common/version.mjs +2 -2
- package/esm2022/core/extension/register-route-component.mjs +1 -1
- package/esm2022/core/providers/data-table/data-table-filter-collection.mjs +19 -3
- package/esm2022/core/providers/data-table/data-table-sort-collection.mjs +8 -2
- package/esm2022/core/shared/components/affixed-input/affixed-input.component.mjs +2 -2
- package/esm2022/core/shared/components/data-table-filter-presets/data-table-filter-presets.component.mjs +7 -5
- package/esm2022/core/shared/components/data-table-filters/data-table-filters.component.mjs +5 -4
- package/esm2022/order/components/order-data-table/order-data-table.component.mjs +3 -3
- package/esm2022/order/components/order-table/order-table.component.mjs +3 -3
- package/fesm2022/vendure-admin-ui-core.mjs +47 -14
- package/fesm2022/vendure-admin-ui-core.mjs.map +1 -1
- package/fesm2022/vendure-admin-ui-order.mjs +4 -4
- package/fesm2022/vendure-admin-ui-order.mjs.map +1 -1
- package/package.json +13 -13
- package/static/i18n-messages/ar.json +1 -1
- package/static/i18n-messages/cs.json +1 -1
- package/static/i18n-messages/de.json +1 -1
- package/static/i18n-messages/en.json +1 -1
- package/static/i18n-messages/es.json +1 -1
- package/static/i18n-messages/fa.json +29 -8
- package/static/i18n-messages/fr.json +1 -1
- package/static/i18n-messages/he.json +1 -1
- package/static/i18n-messages/it.json +1 -1
- package/static/i18n-messages/ne.json +795 -0
- package/static/i18n-messages/pl.json +1 -1
- package/static/i18n-messages/pt_BR.json +1 -1
- package/static/i18n-messages/pt_PT.json +1 -1
- package/static/i18n-messages/ru.json +1 -1
- package/static/i18n-messages/uk.json +1 -1
- package/static/i18n-messages/zh_Hans.json +1 -1
- package/static/i18n-messages/zh_Hant.json +1 -1
- package/static/vendure-ui-config.json +2 -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;
|
package/core/common/version.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
export declare const ADMIN_UI_VERSION = "2.1.0
|
|
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<
|
|
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<
|
|
30
|
+
} & (Component extends BaseDetailComponent<any> ? {
|
|
31
31
|
entityKey: R;
|
|
32
32
|
} : unknown);
|
|
33
33
|
/**
|
|
@@ -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;
|
package/core/shared/components/data-table-filter-presets/data-table-filter-presets.component.d.ts
CHANGED
|
@@ -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>;
|
|
@@ -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
|
-
|
|
159
|
+
const collection = new DataTableFilterCollection(this.router);
|
|
160
|
+
this.collections.push(collection);
|
|
161
|
+
return collection;
|
|
155
162
|
}
|
|
156
163
|
createSortCollection() {
|
|
157
|
-
|
|
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
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVnaXN0ZXItcm91dGUtY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2xpYi9jb3JlL3NyYy9leHRlbnNpb24vcmVnaXN0ZXItcm91dGUtY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUlBLE9BQU8sRUFBRSxlQUFlLEVBQWMsTUFBTSxNQUFNLENBQUM7QUFDbkQsT0FBTyxFQUFFLEdBQUcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ3JDLE9BQU8sRUFBdUIseUJBQXlCLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUVqRyxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQztBQUM3RSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQTJCdkU7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQXVDRztBQUNILE1BQU0sVUFBVSxzQkFBc0IsQ0FNcEMsT0FBc0U7SUFDcEUsTUFBTSxFQUFFLEtBQUssRUFBRSxTQUFTLEVBQUUsU0FBUyxFQUFFLGNBQWMsRUFBRSxHQUFHLE9BQU8sQ0FBQztJQUVoRSxNQUFNLGtCQUFrQixHQUFHLElBQUksZUFBZSxDQUFrQixPQUFPLENBQUMsVUFBVSxJQUFJLEVBQUUsQ0FBQyxDQUFDO0lBQzFGLE1BQU0sYUFBYSxHQUFHLElBQUksZUFBZSxDQUFxQixPQUFPLENBQUMsS0FBSyxDQUFDLENBQUM7SUFFN0UsTUFBTSxTQUFTLEdBTVgsS0FBSyxJQUFJLFNBQVM7UUFDZCxDQUFDLENBQUMseUJBQXlCLENBQUM7WUFDdEIsS0FBSztZQUNMLFNBQVM7WUFDVCxTQUFTO1NBQ1osQ0FBQztRQUNKLENBQUMsQ0FBQyxTQUFTLENBQUM7SUFFcEIsT0FBTztRQUNILElBQUksRUFBRSxPQUFPLENBQUMsSUFBSSxJQUFJLEVBQUU7UUFDeEIsU0FBUyxFQUFFO1lBQ1A7Z0JBQ0ksT0FBTyxFQUFFLHVCQUF1QjtnQkFDaEMsUUFBUSxFQUFFO29CQUNOLFNBQVMsRUFBRSxPQUFPLENBQUMsU0FBUztvQkFDNUIsTUFBTSxFQUFFLGFBQWE7b0JBQ3JCLFdBQVcsRUFBRSxrQkFBa0I7aUJBQ0Y7YUFDcEM7WUFDRCxHQUFHLENBQUMsT0FBTyxDQUFDLFdBQVcsRUFBRSxTQUFTLElBQUksRUFBRSxDQUFDO1NBQzVDO1FBQ0QsR0FBRyxDQUFDLE9BQU8sQ0FBQyxXQUFXLElBQUksRUFBRSxDQUFDO1FBQzlCLE9BQU8sRUFBRSxFQUFFLEdBQUcsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBRSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFBRSxHQUFHLENBQUMsT0FBTyxDQUFDLFdBQVcsRUFBRSxPQUFPLElBQUksRUFBRSxDQUFDLEVBQUU7UUFDakcsSUFBSSxFQUFFO1lBQ0YsVUFBVSxFQUFFLGtCQUFrQjtZQUM5QixHQUFHLENBQUMsT0FBTyxDQUFDLFdBQVcsRUFBRSxJQUFJLElBQUksRUFBRSxDQUFDO1lBQ3BDLEdBQUcsQ0FBQyxjQUFjO2dCQUNkLENBQUMsQ0FBQztvQkFDSSxVQUFVLEVBQUUsSUFBSSxDQUFDLEVBQUUsQ0FDZixJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsTUFBVyxFQUFFLEVBQUUsQ0FBQyxjQUFjLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQztpQkFDNUU7Z0JBQ0gsQ0FBQyxDQUFDLEVBQUUsQ0FBQztZQUNULEdBQUcsQ0FBQyxPQUFPLENBQUMsV0FBVyxFQUFFLElBQUksSUFBSSxFQUFFLENBQUM7U0FDdkM7UUFDRCxTQUFTLEVBQUUscUJBQXFCO0tBQ25CLENBQUM7QUFDdEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFR5cGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgUmVzb2x2ZUZuLCBSb3V0ZSB9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XHJcbmltcG9ydCB7IFJlc3VsdE9mLCBUeXBlZERvY3VtZW50Tm9kZSB9IGZyb20gJ0BncmFwaHFsLXR5cGVkLWRvY3VtZW50LW5vZGUvY29yZSc7XHJcbmltcG9ydCB7IERvY3VtZW50Tm9kZSB9IGZyb20gJ2dyYXBocWwnO1xyXG5pbXBvcnQgeyBCZWhhdmlvclN1YmplY3QsIE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgbWFwIH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xyXG5pbXBvcnQgeyBCYXNlRGV0YWlsQ29tcG9uZW50LCBjcmVhdGVCYXNlRGV0YWlsUmVzb2x2ZUZuIH0gZnJvbSAnLi4vY29tbW9uL2Jhc2UtZGV0YWlsLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IEJyZWFkY3J1bWJWYWx1ZSB9IGZyb20gJy4uL3Byb3ZpZGVycy9icmVhZGNydW1iL2JyZWFkY3J1bWIuc2VydmljZSc7XHJcbmltcG9ydCB7IEFuZ3VsYXJSb3V0ZUNvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9hbmd1bGFyLXJvdXRlLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IFJPVVRFX0NPTVBPTkVOVF9PUFRJT05TIH0gZnJvbSAnLi9jb21wb25lbnRzL3JvdXRlLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IFJvdXRlQ29tcG9uZW50T3B0aW9ucyB9IGZyb20gJy4vdHlwZXMnO1xyXG5cclxuLyoqXHJcbiAqIEBkZXNjcmlwdGlvblxyXG4gKiBDb25maWd1cmF0aW9uIGZvciBhIHJvdXRlIGNvbXBvbmVudC5cclxuICpcclxuICogQGRvY3NDYXRlZ29yeSByb3V0ZXNcclxuICovXHJcbmV4cG9ydCB0eXBlIFJlZ2lzdGVyUm91dGVDb21wb25lbnRPcHRpb25zPFxyXG4gICAgQ29tcG9uZW50IGV4dGVuZHMgYW55IHwgQmFzZURldGFpbENvbXBvbmVudDxFbnRpdHk+LFxyXG4gICAgRW50aXR5IGV4dGVuZHMgeyBpZDogc3RyaW5nOyB1cGRhdGVkQXQ/OiBzdHJpbmcgfSxcclxuICAgIFQgZXh0ZW5kcyBEb2N1bWVudE5vZGUgfCBUeXBlZERvY3VtZW50Tm9kZTxhbnksIHsgaWQ6IHN0cmluZyB9PixcclxuICAgIEZpZWxkIGV4dGVuZHMga2V5b2YgUmVzdWx0T2Y8VD4sXHJcbiAgICBSIGV4dGVuZHMgRmllbGQsXHJcbj4gPSB7XHJcbiAgICBjb21wb25lbnQ6IFR5cGU8Q29tcG9uZW50PiB8IENvbXBvbmVudDtcclxuICAgIHRpdGxlPzogc3RyaW5nO1xyXG4gICAgYnJlYWRjcnVtYj86IEJyZWFkY3J1bWJWYWx1ZTtcclxuICAgIHBhdGg/OiBzdHJpbmc7XHJcbiAgICBxdWVyeT86IFQ7XHJcbiAgICBnZXRCcmVhZGNydW1icz86IChlbnRpdHk6IEV4Y2x1ZGU8UmVzdWx0T2Y8VD5bUl0sICdRdWVyeSc+KSA9PiBCcmVhZGNydW1iVmFsdWU7XHJcbiAgICBlbnRpdHlLZXk/
|
|
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":"AACA,OAAO,EAAE,MAAM,IAAI,CAAC,EAAE,MAAM,yCAAyC,CAAC;AAEtE,OAAO,EAAE,WAAW,EAAE,MAAM,kCAAkC,CAAC;AAC/D,OAAO,MAAM,MAAM,aAAa,CAAC;AACjC,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,YAAY,EAAE,oBAAoB,EAAE,GAAG,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAQpF,OAAO,EACH,eAAe,GAWlB,MAAM,qBAAqB,CAAC;AAE7B,MAAM,OAAO,eAAe;IAExB,YACoB,MAAkC,EAC3C,KAAiC,EACxC,QAAsD;QAFtC,WAAM,GAAN,MAAM,CAA4B;QAC3C,UAAK,GAAL,KAAK,CAA4B;QAHpC,gBAAW,GAAG,IAAI,GAAG,EAA+C,CAAC;QAMzE,IAAI,QAAQ,EAAE;YACV,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;SAClC;IACL,CAAC;IAED,QAAQ,CAAC,EAA+C;QACpD,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IAC7B,CAAC;IAED,WAAW,CAAC,KAAiC;QACzC,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,KAAK,MAAM,EAAE,IAAI,IAAI,CAAC,WAAW,EAAE;YAC/B,EAAE,CAAC,KAAK,CAAC,CAAC;SACb;IACL,CAAC;IAED,IAAI;QACA,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,KAAK,IAAI,CAAC;IAC1C,CAAC;IAED,MAAM;QACF,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,KAAK,MAAM,CAAC;IAC5C,CAAC;IAED,QAAQ;QACJ,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,KAAK,QAAQ,CAAC;IAC9C,CAAC;IAED,SAAS;QACL,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,KAAK,SAAS,CAAC;IAC/C,CAAC;IAED,QAAQ;QACJ,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,KAAK,QAAQ,CAAC;IAC9C,CAAC;IAED,WAAW;QACP,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,KAAK,WAAW,CAAC;IACjD,CAAC;IAED,QAAQ;QACJ,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,KAAK,QAAQ,CAAC;IAC9C,CAAC;CACJ;AAED,MAAM,OAAO,yBAAyB;IACzB,QAAQ,CAAgD;IACjE,cAAc,CAAyB;IACvC,cAAc,CAAoC;IAClD,kBAAkB,CAAS;IAElB,sBAAsB,CAAa;IAE5C,YAAoB,MAAc;QAAd,WAAM,GAAN,MAAM,CAAQ;QAPzB,aAAQ,GAA6C,EAAE,CAAC;QACjE,mBAAc,GAAsB,EAAE,CAAC;QACvC,mBAAc,GAAG,IAAI,OAAO,EAAqB,CAAC;QAClD,uBAAkB,GAAG,KAAK,CAAC;QAC3B,iBAAY,GAAG,IAAI,CAAC,cAAc,CAAC,YAAY,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC,CAAC;QAChE,2BAAsB,GAAG,SAAS,CAAC;IAEP,CAAC;IAEtC,IAAI,MAAM;QACN,OAAO,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC;IAChC,CAAC;IAED,IAAI,aAAa;QACb,OAAO,IAAI,CAAC,cAAc,CAAC;IAC/B,CAAC;IAED,SAAS,CACL,MAAuD;QAEvD,IAAI,IAAI,CAAC,kBAAkB,EAAE;YACzB,MAAM,IAAI,KAAK,CACX,qGAAqG,CACxG,CAAC;SACL;QACD,IAAI,CAAC,QAAQ,CAAC,IAAI,CACd,IAAI,eAAe,CAAC,MAAM,EAAE,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,gBAAgB,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,CACvF,CAAC;QACF,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,UAAU,CACN,OAA+D;QAE/D,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE;YAC1B,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;SAC1B;QACD,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,WAAW;QAKP,IAAI,CAAC,SAAS,CAAC;YACX,IAAI,EAAE,IAAI;YACV,IAAI,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE;YACpB,KAAK,EAAE,CAAC,CAAC,WAAW,CAAC;YACrB,WAAW,EAAE,IAAI;SACpB,CAAC,CAAC;QACH,OAAO,IAAW,CAAC;IACvB,CAAC;IAED,cAAc;QAMV,IAAI,CAAC,SAAS,CAAC;YACX,IAAI,EAAE,WAAW;YACjB,IAAI,EAAE,EAAE,IAAI,EAAE,WAAW,EAAE;YAC3B,KAAK,EAAE,CAAC,CAAC,mBAAmB,CAAC;YAC7B,WAAW,EAAE,WAAW;SAC3B,CAAC,CAAC;QACH,IAAI,CAAC,SAAS,CAAC;YACX,IAAI,EAAE,WAAW;YACjB,IAAI,EAAE,EAAE,IAAI,EAAE,WAAW,EAAE;YAC3B,KAAK,EAAE,CAAC,CAAC,mBAAmB,CAAC;YAC7B,WAAW,EAAE,WAAW;SAC3B,CAAC,CAAC;QACH,OAAO,IAAW,CAAC;IACvB,CAAC;IAED,qBAAqB,CAAC,YAAiC;QACnD,KAAK,MAAM,MAAM,IAAI,YAAY,EAAE;YAC/B,MAAM,IAAI,GAAG,MAAM,CAAC,IAAuB,CAAC;YAC5C,IAAI,MAAM,CAAC,IAAI,EAAE;gBACb,SAAS;aACZ;YACD,IAAI,UAA2C,CAAC;YAChD,QAAQ,IAAI,EAAE;gBACV,KAAK,SAAS;oBACV,UAAU,GAAG,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC;oBACjC,MAAM;gBACV,KAAK,KAAK,CAAC;gBACX,KAAK,OAAO;oBACR,UAAU,GAAG,EAAE,IAAI,EAAE,QAAQ,EAAE,CAAC;oBAChC,MAAM;gBACV,KAAK,UAAU;oBACX,UAAU,GAAG,EAAE,IAAI,EAAE,WAAW,EAAE,CAAC;oBACnC,MAAM;gBACV,KAAK,QAAQ,CAAC;gBACd,KAAK,cAAc,CAAC;gBACpB,KAAK,YAAY,CAAC;gBAClB,KAAK,MAAM;oBACP,UAAU,GAAG,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;oBAC9B,MAAM;gBACV,KAAK,UAAU;oBACX,wBAAwB;oBACxB,MAAM;gBACV;oBACI,WAAW,CAAC,IAAI,CAAC,CAAC;aACzB;YACD,IAAI,UAAU,EAAE;gBACZ,IAAI,CAAC,SAAS,CAAC;oBACX,IAAI,EAAE,MAAM,CAAC,IAAI;oBACjB,IAAI,EAAE,UAAU;oBAChB,KAAK,EAAE,MAAM,CAAC,KAAK,IAAI,MAAM,CAAC,IAAI;oBAClC,WAAW,EAAE,MAAM,CAAC,IAAI;iBAC3B,CAAC,CAAC;aACN;SACJ;QACD,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,SAAS,CAAC,IAAY;QAClB,OAAO,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,IAAI,CAAC,CAAC;IACpD,CAAC;IAED,UAAU;QACN,OAAO,IAAI,CAAC,QAAQ,CAAC;IACzB,CAAC;IAED,yBAAyB,CAAC,KAAa;QACnC,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;QACrC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;IAClD,CAAC;IAED,iBAAiB;QACb,OAAO,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,EAAE,EAAE;YACzD,MAAM,QAAQ,GAAG,KAAK,IAAI,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;YAClE,MAAM,MAAM,GAAG,MAAM,CAAC,IAAI,EAAE,GAAG,EAAE,QAAQ,CAAC,CAAC;YAC3C,OAAO,MAAqB,CAAC;QACjC,CAAC,EAAE,EAAiB,CAAC,CAAC;IAC1B,CAAC;IAED,cAAc,CAAC,KAAqB;QAChC,KAAK,CAAC,aAAa;aACd,IAAI,CACD,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC,EACtD,oBAAoB,EAAE,EACtB,SAAS,CAAC,KAAK,CAAC,QAAQ,CAAC,aAAa,CAAC,GAAG,CAAC,IAAI,CAAC,sBAAsB,CAAC,IAAI,EAAE,CAAC,CACjF;aACA,SAAS,CAAC,KAAK,CAAC,EAAE;YACf,IAAI,CAAC,cAAc,GAAG,EAAE,CAAC;YACzB,IAAI,KAAK,KAAK,EAAE,IAAI,KAAK,KAAK,IAAI,EAAE;gBAChC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;gBAC9C,OAAO;aACV;YACD,MAAM,iBAAiB,GAAG,CAAC,KAAK,IAAI,EAAE,CAAC;iBAClC,KAAK,CAAC,GAAG,CAAC;iBACV,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;iBAC9B,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC;YAC/C,KAAK,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,iBAAiB,EAAE;gBAC7C,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;gBACpC,IAAI,MAAM,EAAE;oBACR,MAAM,GAAG,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;oBACjD,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;iBACxB;aACJ;QACL,CAAC,CAAC,CAAC;QAEP,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;QAE/B,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,SAAS;QACL,OAAO,IAAI,CAAC,cAAc;aACrB,GAAG,CACA,CAAC,eAAe,EAAE,CAAC,EAAE,EAAE,CACnB,GAAG,eAAe,CAAC,MAAM,CAAC,IAAI,IAAI,IAAI,CAAC,cAAc,CAAC,eAAe,CAAC,EAAE,CAC/E;aACA,IAAI,CAAC,GAAG,CAAC,CAAC;IACnB,CAAC;IAEO,cAAc,CAClB,eAAsC;QAEtC,IAAI,eAAe,CAAC,IAAI,EAAE,EAAE;YACxB,MAAM,GAAG,GAAG,eAAe,CAAC,KAAK,CAAC;YAClC,OAAO,GAAG,GAAG,EAAE,QAAQ,IAAI,GAAG,EAAE,IAAI,EAAE,CAAC;SAC1C;QACD,IAAI,eAAe,CAAC,MAAM,EAAE,EAAE;YAC1B,MAAM,GAAG,GAAG,eAAe,CAAC,KAAK,CAAC;YAClC,OAAO,GAAG,GAAG,EAAE,QAAQ,IAAI,GAAG,EAAE,IAAI,EAAE,CAAC;SAC1C;aAAM,IAAI,eAAe,CAAC,QAAQ,EAAE,EAAE;YACnC,MAAM,GAAG,GAAG,eAAe,CAAC,KAAK,CAAC;YAClC,OAAO,GAAG,GAAG,CAAC,QAAQ,IAAI,GAAG,CAAC,MAAM,EAAE,CAAC;SAC1C;aAAM,IAAI,eAAe,CAAC,QAAQ,EAAE,EAAE;YACnC,MAAM,GAAG,GAAG,eAAe,CAAC,KAAK,CAAC;YAClC,OAAO,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;SACxB;aAAM,IAAI,eAAe,CAAC,SAAS,EAAE,EAAE;YACpC,MAAM,GAAG,GAAG,eAAe,CAAC,KAAK,CAAC;YAClC,OAAO,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;SAC1B;aAAM,IAAI,eAAe,CAAC,WAAW,EAAE,EAAE;YACtC,MAAM,GAAG,GAAG,eAAe,CAAC,KAAK,CAAC;YAClC,IAAI,GAAG,CAAC,IAAI,KAAK,UAAU,EAAE;gBACzB,OAAO,GAAG,GAAG,CAAC,IAAI,IAAI,GAAG,CAAC,aAAa,IAAI,GAAG,CAAC,YAAY,EAAE,CAAC;aACjE;iBAAM;gBACH,MAAM,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;gBAC7D,MAAM,GAAG,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;gBACvD,OAAO,GAAG,KAAK,IAAI,GAAG,EAAE,CAAC;aAC5B;SACJ;aAAM,IAAI,eAAe,CAAC,QAAQ,EAAE,EAAE;YACnC,OAAO,eAAe,CAAC,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;SAC5E;IACL,CAAC;IAEO,gBAAgB,CACpB,MAAuB,EACvB,KAAa;QAEb,QAAQ,MAAM,CAAC,IAAI,CAAC,IAAI,EAAE;YACtB,KAAK,IAAI,CAAC,CAAC;gBACP,MAAM,CAAC,QAAQ,EAAE,IAAI,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,GAAG,CAAoC,CAAC;gBAC7E,OAAO,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;aAC7B;YACD,KAAK,MAAM,CAAC,CAAC;gBACT,MAAM,CAAC,QAAQ,EAAE,IAAI,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,GAAG,CAAoC,CAAC;gBAC7E,OAAO,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;aAC7B;YACD,KAAK,QAAQ,CAAC,CAAC;gBACX,MAAM,CAAC,QAAQ,EAAE,MAAM,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,GAAG,CAAoC,CAAC;gBAC/E,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,CAAC,MAAM,EAAE,CAAC;aACxC;YACD,KAAK,QAAQ;gBACT,OAAO,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;YAC5B,KAAK,SAAS;gBACV,OAAO,KAAK,KAAK,GAAG,CAAC;YACzB,KAAK,WAAW;gBACZ,IAAI,IAAI,GAAG,UAAU,CAAC;gBACtB,IAAI,aAAiC,CAAC;gBACtC,IAAI,YAAkD,CAAC;gBACvD,IAAI,KAAyB,CAAC;gBAC9B,IAAI,GAAuB,CAAC;gBAC5B,IAAI,KAAK,CAAC,UAAU,CAAC,UAAU,CAAC,EAAE;oBAC9B,IAAI,GAAG,UAAU,CAAC;oBAClB,MAAM,CAAC,CAAC,EAAE,gBAAgB,EAAE,eAAe,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;oBAChE,aAAa,GAAG,MAAM,CAAC,gBAAgB,CAAC,CAAC;oBACzC,YAAY,GAAG,eAA2C,CAAC;iBAC9D;qBAAM;oBACH,IAAI,GAAG,OAAO,CAAC;oBACf,MAAM,CAAC,cAAc,EAAE,YAAY,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;oBACxD,KAAK,GAAG,cAAc,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;oBAC7E,GAAG,GAAG,YAAY,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;iBAC1E;gBACD,OAAO,EAAE,IAAI,EAAE,aAAa,EAAE,YAAY,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC;YAC7D,KAAK,QAAQ;gBACT,OAAO,MAAM,CAAC,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;YAC/C;gBACI,WAAW,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;SAChC;IACL,CAAC;IAEO,gBAAgB,CAAC,MAAiC,EAAE,KAAgC;QACxF,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,qBAAqB,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,CAAC;QACpE,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;IAClD,CAAC;IAEO,qBAAqB,CACzB,MAAiC,EACjC,KAAgD;QAEhD,OAAO,IAAI,eAAe,CAAC,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;IAChF,CAAC;CACJ","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"]}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { assertNever } from '@vendure/common/lib/shared-utils';
|
|
2
2
|
import { Subject } from 'rxjs';
|
|
3
|
+
import { takeUntil } from 'rxjs/operators';
|
|
3
4
|
import { DataTableSort } from './data-table-sort';
|
|
4
5
|
export class DataTableSortCollection {
|
|
5
6
|
#sorts;
|
|
@@ -14,10 +15,15 @@ export class DataTableSortCollection {
|
|
|
14
15
|
this.#connectedToRouter = false;
|
|
15
16
|
this.valueChanges = this.#valueChanges$.asObservable();
|
|
16
17
|
this.#sortQueryParamName = 'sort';
|
|
18
|
+
this.destroy$ = new Subject();
|
|
17
19
|
}
|
|
18
20
|
get length() {
|
|
19
21
|
return this.#sorts.length;
|
|
20
22
|
}
|
|
23
|
+
destroy() {
|
|
24
|
+
this.destroy$.next();
|
|
25
|
+
this.destroy$.complete();
|
|
26
|
+
}
|
|
21
27
|
addSort(config) {
|
|
22
28
|
if (this.#connectedToRouter) {
|
|
23
29
|
throw new Error('Cannot add sort after connecting to router. Make sure to call addSort() before connectToRoute()');
|
|
@@ -65,7 +71,7 @@ export class DataTableSortCollection {
|
|
|
65
71
|
return this.#sorts.find(s => s.name === name);
|
|
66
72
|
}
|
|
67
73
|
connectToRoute(route) {
|
|
68
|
-
this.valueChanges.subscribe(
|
|
74
|
+
this.valueChanges.pipe(takeUntil(this.destroy$)).subscribe(() => {
|
|
69
75
|
this.router.navigate(['./'], {
|
|
70
76
|
queryParams: { [this.#sortQueryParamName]: this.serialize() },
|
|
71
77
|
relativeTo: route,
|
|
@@ -106,4 +112,4 @@ export class DataTableSortCollection {
|
|
|
106
112
|
.map(s => ({ name: s.name, sortOrder: s.sortOrder })));
|
|
107
113
|
}
|
|
108
114
|
}
|
|
109
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table-sort-collection.js","sourceRoot":"","sources":["../../../../../src/lib/core/src/providers/data-table/data-table-sort-collection.ts"],"names":[],"mappings":"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","sourcesContent":["import { ActivatedRoute, Router } from '@angular/router';\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 { CustomFieldConfig } from '../../common/generated-types';\r\nimport { DataTableSort, DataTableSortOptions, DataTableSortOrder } from './data-table-sort';\r\n\r\nexport class DataTableSortCollection<\r\n    SortInput extends Record<string, 'ASC' | 'DESC'>,\r\n    Names extends [...Array<keyof SortInput>] = [],\r\n> {\r\n    readonly #sorts: Array<DataTableSort<SortInput>> = [];\r\n    #valueChanges$ = new Subject<Array<{ name: string; sortOrder: DataTableSortOrder | undefined }>>();\r\n    #connectedToRouter = false;\r\n    valueChanges = this.#valueChanges$.asObservable();\r\n    readonly #sortQueryParamName = 'sort';\r\n    #defaultSort: { name: keyof SortInput; sortOrder: DataTableSortOrder } | undefined;\r\n\r\n    constructor(private router: Router) {}\r\n\r\n    get length(): number {\r\n        return this.#sorts.length;\r\n    }\r\n\r\n    addSort<Name extends keyof SortInput>(\r\n        config: DataTableSortOptions<SortInput, Name>,\r\n    ): DataTableSortCollection<SortInput, [...Names, Name]> {\r\n        if (this.#connectedToRouter) {\r\n            throw new Error(\r\n                'Cannot add sort after connecting to router. Make sure to call addSort() before connectToRoute()',\r\n            );\r\n        }\r\n        this.#sorts.push(new DataTableSort<SortInput>(config, () => this.onSetValue()));\r\n        return this as unknown as DataTableSortCollection<SortInput, [...Names, Name]>;\r\n    }\r\n\r\n    addSorts<Name extends keyof SortInput>(\r\n        configs: Array<DataTableSortOptions<SortInput, Name>>,\r\n    ): DataTableSortCollection<SortInput, [...Names, Name]> {\r\n        for (const config of configs) {\r\n            this.addSort(config);\r\n        }\r\n        return this as unknown as DataTableSortCollection<SortInput, [...Names, Name]>;\r\n    }\r\n\r\n    addCustomFieldSorts(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            switch (type) {\r\n                case 'string':\r\n                case 'localeString':\r\n                case 'boolean':\r\n                case 'int':\r\n                case 'float':\r\n                case 'datetime':\r\n                case 'localeText':\r\n                case 'text':\r\n                    this.addSort({ name: config.name });\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        }\r\n        return this;\r\n    }\r\n\r\n    defaultSort(name: keyof SortInput, sortOrder: DataTableSortOrder) {\r\n        this.#defaultSort = { name, sortOrder };\r\n        return this;\r\n    }\r\n\r\n    get(name: Names[number]): DataTableSort<SortInput> | undefined {\r\n        return this.#sorts.find(s => s.name === name);\r\n    }\r\n\r\n    connectToRoute(route: ActivatedRoute) {\r\n        this.valueChanges.subscribe(value => {\r\n            this.router.navigate(['./'], {\r\n                queryParams: { [this.#sortQueryParamName]: this.serialize() },\r\n                relativeTo: route,\r\n                queryParamsHandling: 'merge',\r\n            });\r\n        });\r\n        const filterQueryParams = (route.snapshot.queryParamMap.get(this.#sortQueryParamName) ?? '')\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 sort = this.get(name);\r\n            if (sort) {\r\n                sort.setSortOrder(value as any);\r\n            }\r\n        }\r\n        this.#connectedToRouter = true;\r\n        return this;\r\n    }\r\n\r\n    createSortInput(): SortInput {\r\n        const activeSorts = this.#sorts.filter(s => s.sortOrder !== undefined);\r\n        let sortInput = {} as SortInput;\r\n        if (activeSorts.length === 0 && this.#defaultSort) {\r\n            return { [this.#defaultSort.name]: this.#defaultSort.sortOrder } as SortInput;\r\n        }\r\n        for (const sort of activeSorts) {\r\n            sortInput = { ...sortInput, [sort.name]: sort.sortOrder };\r\n        }\r\n        return sortInput;\r\n    }\r\n\r\n    private serialize(): string {\r\n        const activeSorts = this.#sorts.filter(s => s.sortOrder !== undefined);\r\n        return activeSorts.map(s => `${s.name as string}:${s.sortOrder}`).join(';');\r\n    }\r\n\r\n    private onSetValue() {\r\n        this.#valueChanges$.next(\r\n            this.#sorts\r\n                .filter(f => f.sortOrder !== undefined)\r\n                .map(s => ({ name: s.name as any, sortOrder: s.sortOrder })),\r\n        );\r\n    }\r\n}\r\n"]}
|
|
115
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table-sort-collection.js","sourceRoot":"","sources":["../../../../../src/lib/core/src/providers/data-table/data-table-sort-collection.ts"],"names":[],"mappings":"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","sourcesContent":["import { ActivatedRoute, Router } from '@angular/router';\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 { takeUntil } from 'rxjs/operators';\r\nimport { CustomFieldConfig } from '../../common/generated-types';\r\nimport { DataTableSort, DataTableSortOptions, DataTableSortOrder } from './data-table-sort';\r\n\r\nexport class DataTableSortCollection<\r\n    SortInput extends Record<string, 'ASC' | 'DESC'>,\r\n    Names extends [...Array<keyof SortInput>] = [],\r\n> {\r\n    readonly #sorts: Array<DataTableSort<SortInput>> = [];\r\n    #valueChanges$ = new Subject<Array<{ name: string; sortOrder: DataTableSortOrder | undefined }>>();\r\n    #connectedToRouter = false;\r\n    valueChanges = this.#valueChanges$.asObservable();\r\n    readonly #sortQueryParamName = 'sort';\r\n    #defaultSort: { name: keyof SortInput; sortOrder: DataTableSortOrder } | undefined;\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.#sorts.length;\r\n    }\r\n\r\n    destroy() {\r\n        this.destroy$.next();\r\n        this.destroy$.complete();\r\n    }\r\n\r\n    addSort<Name extends keyof SortInput>(\r\n        config: DataTableSortOptions<SortInput, Name>,\r\n    ): DataTableSortCollection<SortInput, [...Names, Name]> {\r\n        if (this.#connectedToRouter) {\r\n            throw new Error(\r\n                'Cannot add sort after connecting to router. Make sure to call addSort() before connectToRoute()',\r\n            );\r\n        }\r\n        this.#sorts.push(new DataTableSort<SortInput>(config, () => this.onSetValue()));\r\n        return this as unknown as DataTableSortCollection<SortInput, [...Names, Name]>;\r\n    }\r\n\r\n    addSorts<Name extends keyof SortInput>(\r\n        configs: Array<DataTableSortOptions<SortInput, Name>>,\r\n    ): DataTableSortCollection<SortInput, [...Names, Name]> {\r\n        for (const config of configs) {\r\n            this.addSort(config);\r\n        }\r\n        return this as unknown as DataTableSortCollection<SortInput, [...Names, Name]>;\r\n    }\r\n\r\n    addCustomFieldSorts(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            switch (type) {\r\n                case 'string':\r\n                case 'localeString':\r\n                case 'boolean':\r\n                case 'int':\r\n                case 'float':\r\n                case 'datetime':\r\n                case 'localeText':\r\n                case 'text':\r\n                    this.addSort({ name: config.name });\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        }\r\n        return this;\r\n    }\r\n\r\n    defaultSort(name: keyof SortInput, sortOrder: DataTableSortOrder) {\r\n        this.#defaultSort = { name, sortOrder };\r\n        return this;\r\n    }\r\n\r\n    get(name: Names[number]): DataTableSort<SortInput> | undefined {\r\n        return this.#sorts.find(s => s.name === name);\r\n    }\r\n\r\n    connectToRoute(route: ActivatedRoute) {\r\n        this.valueChanges.pipe(takeUntil(this.destroy$)).subscribe(() => {\r\n            this.router.navigate(['./'], {\r\n                queryParams: { [this.#sortQueryParamName]: this.serialize() },\r\n                relativeTo: route,\r\n                queryParamsHandling: 'merge',\r\n            });\r\n        });\r\n        const filterQueryParams = (route.snapshot.queryParamMap.get(this.#sortQueryParamName) ?? '')\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 sort = this.get(name);\r\n            if (sort) {\r\n                sort.setSortOrder(value as any);\r\n            }\r\n        }\r\n        this.#connectedToRouter = true;\r\n        return this;\r\n    }\r\n\r\n    createSortInput(): SortInput {\r\n        const activeSorts = this.#sorts.filter(s => s.sortOrder !== undefined);\r\n        let sortInput = {} as SortInput;\r\n        if (activeSorts.length === 0 && this.#defaultSort) {\r\n            return { [this.#defaultSort.name]: this.#defaultSort.sortOrder } as SortInput;\r\n        }\r\n        for (const sort of activeSorts) {\r\n            sortInput = { ...sortInput, [sort.name]: sort.sortOrder };\r\n        }\r\n        return sortInput;\r\n    }\r\n\r\n    private serialize(): string {\r\n        const activeSorts = this.#sorts.filter(s => s.sortOrder !== undefined);\r\n        return activeSorts.map(s => `${s.name as string}:${s.sortOrder}`).join(';');\r\n    }\r\n\r\n    private onSetValue() {\r\n        this.#valueChanges$.next(\r\n            this.#sorts\r\n                .filter(f => f.sortOrder !== undefined)\r\n                .map(s => ({ name: s.name as any, sortOrder: s.sortOrder })),\r\n        );\r\n    }\r\n}\r\n"]}
|
|
@@ -6,11 +6,11 @@ import * as i1 from "@angular/common";
|
|
|
6
6
|
*/
|
|
7
7
|
export class AffixedInputComponent {
|
|
8
8
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.2", ngImport: i0, type: AffixedInputComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
9
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.2", type: AffixedInputComponent, selector: "vdr-affixed-input", inputs: { prefix: "prefix", suffix: "suffix" }, ngImport: i0, template: "<div [class.has-prefix]=\"!!prefix\" [class.has-suffix]=\"!!suffix\" class=\"input-wrapper\">\r\n <ng-content></ng-content>\r\n</div>\r\n<div class=\"affix prefix\" *ngIf=\"prefix\">{{ prefix }}</div>\r\n<div class=\"affix suffix\" *ngIf=\"suffix\">{{ suffix }}</div>\r\n", styles: [":host{display:flex}.input-wrapper{flex:1}.affix{color:var(--color-grey-800);display:flex;align-items:center;background-color:var(--color-component-bg-200);color:var(--color-text-200);border:1px solid var(--color-
|
|
9
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.2", type: AffixedInputComponent, selector: "vdr-affixed-input", inputs: { prefix: "prefix", suffix: "suffix" }, ngImport: i0, template: "<div [class.has-prefix]=\"!!prefix\" [class.has-suffix]=\"!!suffix\" class=\"input-wrapper\">\r\n <ng-content></ng-content>\r\n</div>\r\n<div class=\"affix prefix\" *ngIf=\"prefix\">{{ prefix }}</div>\r\n<div class=\"affix suffix\" *ngIf=\"suffix\">{{ suffix }}</div>\r\n", styles: [":host{display:flex}.input-wrapper{flex:1}.affix{color:var(--color-grey-800);display:flex;align-items:center;background-color:var(--color-component-bg-200);color:var(--color-text-200);border:1px solid var(--color-weight-200);top:1px;padding:3px;line-height:.58333rem;transition:border .2s}::ng-deep .has-prefix>input[type=text],::ng-deep .has-prefix>input[type=number]{border-top-left-radius:0!important;border-bottom-left-radius:0!important;width:100%}.prefix{order:-1;border-radius:3px 0 0 3px;border-inline-end:none}::ng-deep .has-suffix>input[type=text],::ng-deep .has-suffix>input[type=number]{border-top-right-radius:0!important;border-bottom-right-radius:0!important;width:100%}.suffix{border-radius:0 3px 3px 0;border-inline-start:none}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
10
10
|
}
|
|
11
11
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.2", ngImport: i0, type: AffixedInputComponent, decorators: [{
|
|
12
12
|
type: Component,
|
|
13
|
-
args: [{ selector: 'vdr-affixed-input', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div [class.has-prefix]=\"!!prefix\" [class.has-suffix]=\"!!suffix\" class=\"input-wrapper\">\r\n <ng-content></ng-content>\r\n</div>\r\n<div class=\"affix prefix\" *ngIf=\"prefix\">{{ prefix }}</div>\r\n<div class=\"affix suffix\" *ngIf=\"suffix\">{{ suffix }}</div>\r\n", styles: [":host{display:flex}.input-wrapper{flex:1}.affix{color:var(--color-grey-800);display:flex;align-items:center;background-color:var(--color-component-bg-200);color:var(--color-text-200);border:1px solid var(--color-
|
|
13
|
+
args: [{ selector: 'vdr-affixed-input', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div [class.has-prefix]=\"!!prefix\" [class.has-suffix]=\"!!suffix\" class=\"input-wrapper\">\r\n <ng-content></ng-content>\r\n</div>\r\n<div class=\"affix prefix\" *ngIf=\"prefix\">{{ prefix }}</div>\r\n<div class=\"affix suffix\" *ngIf=\"suffix\">{{ suffix }}</div>\r\n", styles: [":host{display:flex}.input-wrapper{flex:1}.affix{color:var(--color-grey-800);display:flex;align-items:center;background-color:var(--color-component-bg-200);color:var(--color-text-200);border:1px solid var(--color-weight-200);top:1px;padding:3px;line-height:.58333rem;transition:border .2s}::ng-deep .has-prefix>input[type=text],::ng-deep .has-prefix>input[type=number]{border-top-left-radius:0!important;border-bottom-left-radius:0!important;width:100%}.prefix{order:-1;border-radius:3px 0 0 3px;border-inline-end:none}::ng-deep .has-suffix>input[type=text],::ng-deep .has-suffix>input[type=number]{border-top-right-radius:0!important;border-bottom-right-radius:0!important;width:100%}.suffix{border-radius:0 3px 3px 0;border-inline-start:none}\n"] }]
|
|
14
14
|
}], propDecorators: { prefix: [{
|
|
15
15
|
type: Input
|
|
16
16
|
}], suffix: [{
|