@vendure/admin-ui 2.1.0-next.4 → 2.1.0-next.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (112) hide show
  1. package/catalog/components/product-list/product-list.component.d.ts +1 -1
  2. package/catalog/components/product-variant-list/product-variant-list-bulk-actions.d.ts +1 -2
  3. package/catalog/components/product-variant-list/product-variant-list.component.d.ts +1 -1
  4. package/catalog/components/stock-location-list/stock-location-list.component.d.ts +1 -1
  5. package/catalog/providers/product-detail/product-detail.service.d.ts +1 -1
  6. package/core/common/base-detail.component.d.ts +2 -2
  7. package/core/common/base-entity-resolver.d.ts +1 -1
  8. package/core/common/version.d.ts +1 -1
  9. package/core/components/base-nav/base-nav.component.d.ts +4 -2
  10. package/core/data/providers/data.service.d.ts +3 -3
  11. package/core/data/query-result.d.ts +1 -1
  12. package/core/extension/add-action-bar-item.d.ts +8 -15
  13. package/core/extension/add-nav-menu-item.d.ts +15 -23
  14. package/core/extension/register-bulk-action.d.ts +24 -28
  15. package/core/extension/register-custom-detail-component.d.ts +45 -0
  16. package/core/extension/register-data-table-component.d.ts +3 -2
  17. package/core/extension/register-form-input-component.d.ts +14 -13
  18. package/core/extension/register-history-entry-component.d.ts +55 -0
  19. package/core/extension/register-page-tab.d.ts +23 -0
  20. package/core/extension/register-route-component.d.ts +49 -3
  21. package/core/providers/bulk-action-registry/bulk-action-types.d.ts +2 -2
  22. package/core/providers/modal/modal.service.d.ts +1 -1
  23. package/core/providers/modal/modal.types.d.ts +3 -3
  24. package/core/providers/nav-builder/nav-builder-types.d.ts +29 -4
  25. package/core/providers/nav-builder/nav-builder.service.d.ts +3 -2
  26. package/core/providers/notification/notification.service.d.ts +4 -4
  27. package/core/providers/page/page.service.d.ts +1 -23
  28. package/core/public_api.d.ts +1 -0
  29. package/core/shared/components/action-bar-items/action-bar-items.component.d.ts +8 -3
  30. package/core/shared/components/asset-picker-dialog/asset-picker-dialog.component.d.ts +1 -1
  31. package/core/shared/components/asset-preview/asset-preview.component.d.ts +9 -1
  32. package/core/shared/components/asset-preview-dialog/asset-preview-dialog.component.d.ts +2 -0
  33. package/core/shared/components/data-table-2/data-table2.component.d.ts +1 -1
  34. package/core/shared/components/extension-host/host-external-frame.d.ts +1 -1
  35. package/core/shared/components/facet-value-selector/facet-value-selector.component.d.ts +1 -1
  36. package/core/shared/components/order-state-label/order-state-label.component.d.ts +1 -1
  37. package/core/shared/dynamic-form-inputs/default-form-inputs.d.ts +1 -1
  38. package/core/shared/pipes/duration.pipe.d.ts +1 -1
  39. package/core/shared/pipes/file-size.pipe.d.ts +1 -1
  40. package/esm2022/catalog/components/asset-detail/asset-detail.component.mjs +1 -1
  41. package/esm2022/catalog/components/assets/assets.component.mjs +2 -2
  42. package/esm2022/catalog/components/product-variant-list/product-variant-list-bulk-actions.mjs +1 -1
  43. package/esm2022/core/common/base-detail.component.mjs +3 -3
  44. package/esm2022/core/common/base-entity-resolver.mjs +3 -3
  45. package/esm2022/core/common/utilities/custom-field-default-value.mjs +3 -3
  46. package/esm2022/core/common/version.mjs +2 -2
  47. package/esm2022/core/components/base-nav/base-nav.component.mjs +17 -5
  48. package/esm2022/core/data/providers/data.service.mjs +4 -4
  49. package/esm2022/core/data/query-result.mjs +2 -2
  50. package/esm2022/core/extension/add-action-bar-item.mjs +9 -16
  51. package/esm2022/core/extension/add-nav-menu-item.mjs +16 -24
  52. package/esm2022/core/extension/register-bulk-action.mjs +25 -29
  53. package/esm2022/core/extension/register-custom-detail-component.mjs +46 -1
  54. package/esm2022/core/extension/register-data-table-component.mjs +4 -3
  55. package/esm2022/core/extension/register-form-input-component.mjs +15 -14
  56. package/esm2022/core/extension/register-history-entry-component.mjs +56 -1
  57. package/esm2022/core/extension/register-page-tab.mjs +36 -0
  58. package/esm2022/core/extension/register-route-component.mjs +44 -3
  59. package/esm2022/core/providers/bulk-action-registry/bulk-action-types.mjs +1 -1
  60. package/esm2022/core/providers/modal/modal.service.mjs +2 -2
  61. package/esm2022/core/providers/modal/modal.types.mjs +1 -1
  62. package/esm2022/core/providers/nav-builder/nav-builder-types.mjs +1 -1
  63. package/esm2022/core/providers/nav-builder/nav-builder.service.mjs +3 -3
  64. package/esm2022/core/providers/notification/notification.service.mjs +3 -3
  65. package/esm2022/core/providers/page/page.service.mjs +2 -36
  66. package/esm2022/core/public_api.mjs +2 -1
  67. package/esm2022/core/shared/components/action-bar/action-bar.component.mjs +2 -2
  68. package/esm2022/core/shared/components/action-bar-items/action-bar-items.component.mjs +32 -15
  69. package/esm2022/core/shared/components/asset-gallery/asset-gallery.component.mjs +2 -2
  70. package/esm2022/core/shared/components/asset-picker-dialog/asset-picker-dialog.component.mjs +2 -2
  71. package/esm2022/core/shared/components/asset-preview/asset-preview.component.mjs +36 -3
  72. package/esm2022/core/shared/components/asset-preview-dialog/asset-preview-dialog.component.mjs +4 -3
  73. package/esm2022/core/shared/components/data-table-2/data-table2.component.mjs +2 -2
  74. package/esm2022/core/shared/components/extension-host/host-external-frame.mjs +2 -2
  75. package/esm2022/core/shared/components/facet-value-selector/facet-value-selector.component.mjs +2 -2
  76. package/esm2022/core/shared/components/form-field/form-field.component.mjs +2 -2
  77. package/esm2022/core/shared/components/page-detail-layout/page-detail-layout.component.mjs +2 -2
  78. package/esm2022/core/shared/pipes/duration.pipe.mjs +2 -2
  79. package/esm2022/core/shared/pipes/file-size.pipe.mjs +2 -2
  80. package/esm2022/react/components/react-custom-column.component.mjs +3 -3
  81. package/esm2022/react/components/react-custom-detail.component.mjs +3 -3
  82. package/esm2022/react/components/react-form-input.component.mjs +3 -3
  83. package/esm2022/react/components/react-route.component.mjs +3 -3
  84. package/esm2022/react/public_api.mjs +7 -1
  85. package/esm2022/react/react-components/ActionBar.mjs +26 -0
  86. package/esm2022/react/react-components/CdsIcon.mjs +30 -0
  87. package/esm2022/react/react-components/FormField.mjs +28 -0
  88. package/esm2022/react/react-components/PageBlock.mjs +24 -0
  89. package/esm2022/react/react-components/PageDetailLayout.mjs +26 -0
  90. package/esm2022/react/react-hooks/use-detail-component-data.mjs +1 -1
  91. package/esm2022/react/react-hooks/use-route-params.mjs +39 -0
  92. package/esm2022/react/register-react-data-table-component.mjs +3 -1
  93. package/esm2022/react/register-react-route-component.mjs +1 -1
  94. package/esm2022/settings/components/tax-category-list/tax-category-list-bulk-actions.mjs +1 -1
  95. package/fesm2022/vendure-admin-ui-catalog.mjs +2 -2
  96. package/fesm2022/vendure-admin-ui-catalog.mjs.map +1 -1
  97. package/fesm2022/vendure-admin-ui-core.mjs +350 -164
  98. package/fesm2022/vendure-admin-ui-core.mjs.map +1 -1
  99. package/fesm2022/vendure-admin-ui-react.mjs +178 -11
  100. package/fesm2022/vendure-admin-ui-react.mjs.map +1 -1
  101. package/fesm2022/vendure-admin-ui-settings.mjs.map +1 -1
  102. package/package.json +14 -14
  103. package/react/public_api.d.ts +6 -0
  104. package/react/react-components/ActionBar.d.ts +23 -0
  105. package/react/react-components/CdsIcon.d.ts +45 -0
  106. package/react/react-components/FormField.d.ts +27 -0
  107. package/react/react-components/PageBlock.d.ts +21 -0
  108. package/react/react-components/PageDetailLayout.d.ts +23 -0
  109. package/react/react-hooks/use-detail-component-data.d.ts +2 -2
  110. package/react/react-hooks/use-route-params.d.ts +22 -0
  111. package/react/register-react-data-table-component.d.ts +2 -0
  112. package/react/register-react-route-component.d.ts +6 -0
@@ -1,7 +1,7 @@
1
1
  import { ChangeDetectionStrategy, Component, HostBinding, Input, } from '@angular/core';
2
2
  import { assertNever } from '@vendure/common/lib/shared-utils';
3
- import { BehaviorSubject, combineLatest } from 'rxjs';
4
- import { map } from 'rxjs/operators';
3
+ import { BehaviorSubject, combineLatest, of } from 'rxjs';
4
+ import { map, tap } from 'rxjs/operators';
5
5
  import * as i0 from "@angular/core";
6
6
  import * as i1 from "../../../providers/nav-builder/nav-builder.service";
7
7
  import * as i2 from "@angular/router";
@@ -13,15 +13,28 @@ import * as i7 from "../../directives/if-permissions.directive";
13
13
  import * as i8 from "../ui-extension-point/ui-extension-point.component";
14
14
  import * as i9 from "@ngx-translate/core";
15
15
  export class ActionBarItemsComponent {
16
- constructor(navBuilderService, route, dataService, notificationService) {
16
+ constructor(navBuilderService, route, dataService, notificationService, injector) {
17
17
  this.navBuilderService = navBuilderService;
18
18
  this.route = route;
19
19
  this.dataService = dataService;
20
20
  this.notificationService = notificationService;
21
+ this.injector = injector;
22
+ this.buttonStates = {};
21
23
  this.locationId$ = new BehaviorSubject('');
22
24
  }
23
25
  ngOnInit() {
24
- this.items$ = combineLatest(this.navBuilderService.actionBarConfig$, this.locationId$).pipe(map(([items, locationId]) => items.filter(config => config.locationId === locationId)));
26
+ this.items$ = combineLatest(this.navBuilderService.actionBarConfig$, this.locationId$).pipe(map(([items, locationId]) => items.filter(config => config.locationId === locationId)), tap(items => {
27
+ const context = this.createContext();
28
+ for (const item of items) {
29
+ const buttonState$ = typeof item.buttonState === 'function'
30
+ ? item.buttonState(context)
31
+ : of({
32
+ disabled: false,
33
+ visible: true,
34
+ });
35
+ this.buttonStates[item.id] = buttonState$;
36
+ }
37
+ }));
25
38
  }
26
39
  ngOnChanges(changes) {
27
40
  if ('locationId' in changes) {
@@ -30,15 +43,11 @@ export class ActionBarItemsComponent {
30
43
  }
31
44
  handleClick(event, item) {
32
45
  if (typeof item.onClick === 'function') {
33
- item.onClick(event, {
34
- route: this.route,
35
- dataService: this.dataService,
36
- notificationService: this.notificationService,
37
- });
46
+ item.onClick(event, this.createContext());
38
47
  }
39
48
  }
40
49
  getRouterLink(item) {
41
- return this.navBuilderService.getRouterLink(item, this.route);
50
+ return this.navBuilderService.getRouterLink({ routerLink: item.routerLink, context: this.createContext() }, this.route);
42
51
  }
43
52
  getButtonStyles(item) {
44
53
  const styles = ['button'];
@@ -64,16 +73,24 @@ export class ActionBarItemsComponent {
64
73
  return '';
65
74
  }
66
75
  }
67
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.2", ngImport: i0, type: ActionBarItemsComponent, deps: [{ token: i1.NavBuilderService }, { token: i2.ActivatedRoute }, { token: i3.DataService }, { token: i4.NotificationService }], target: i0.ɵɵFactoryTarget.Component }); }
68
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.2", type: ActionBarItemsComponent, selector: "vdr-action-bar-items", inputs: { locationId: "locationId" }, host: { properties: { "attr.data-location-id": "this.locationId" } }, usesOnChanges: true, ngImport: i0, template: "<vdr-ui-extension-point [locationId]=\"locationId\" api=\"actionBar\" [leftPx]=\"-24\">\r\n <ng-container *ngFor=\"let item of items$ | async\">\r\n <button\r\n *vdrIfPermissions=\"item.requiresPermission\"\r\n [routerLink]=\"getRouterLink(item)\"\r\n [disabled]=\"item.disabled ? (item.disabled | async) : false\"\r\n (click)=\"handleClick($event, item)\"\r\n [ngClass]=\"getButtonStyles(item)\"\r\n class=\"mr-2\"\r\n >\r\n <clr-icon *ngIf=\"item.icon\" [attr.shape]=\"item.icon\"></clr-icon>\r\n {{ item.label | translate }}\r\n </button>\r\n </ng-container>\r\n</vdr-ui-extension-point>\r\n", styles: [":host{display:inline-block}\n"], dependencies: [{ kind: "directive", type: i5.ClrIconCustomTag, selector: "clr-icon" }, { kind: "directive", type: i6.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: i7.IfPermissionsDirective, selector: "[vdrIfPermissions]", inputs: ["vdrIfPermissions", "vdrIfPermissionsElse"] }, { kind: "component", type: i8.UiExtensionPointComponent, selector: "vdr-ui-extension-point", inputs: ["locationId", "metadata", "topPx", "leftPx", "display", "api"] }, { kind: "pipe", type: i6.AsyncPipe, name: "async" }, { kind: "pipe", type: i9.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
76
+ createContext() {
77
+ return {
78
+ route: this.route,
79
+ injector: this.injector,
80
+ dataService: this.dataService,
81
+ notificationService: this.notificationService,
82
+ };
83
+ }
84
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.2", ngImport: i0, type: ActionBarItemsComponent, deps: [{ token: i1.NavBuilderService }, { token: i2.ActivatedRoute }, { token: i3.DataService }, { token: i4.NotificationService }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component }); }
85
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.2", type: ActionBarItemsComponent, selector: "vdr-action-bar-items", inputs: { locationId: "locationId" }, host: { properties: { "attr.data-location-id": "this.locationId" } }, usesOnChanges: true, ngImport: i0, template: "<vdr-ui-extension-point [locationId]=\"locationId\" api=\"actionBar\" [leftPx]=\"-24\">\r\n <ng-container *ngFor=\"let item of items$ | async\">\r\n <ng-container *ngIf=\"buttonStates[item.id] | async as buttonState\">\r\n <button\r\n *vdrIfPermissions=\"item.requiresPermission\"\r\n [routerLink]=\"getRouterLink(item)\"\r\n [class.hidden]=\"buttonState.visible === false\"\r\n [disabled]=\"buttonState.disabled || (item.disabled ? (item.disabled | async) : false)\"\r\n (click)=\"handleClick($event, item)\"\r\n [ngClass]=\"getButtonStyles(item)\"\r\n class=\"mr-2\"\r\n >\r\n <clr-icon *ngIf=\"item.icon\" [attr.shape]=\"item.icon\"></clr-icon>\r\n {{ item.label | translate }}\r\n </button>\r\n </ng-container>\r\n </ng-container>\r\n</vdr-ui-extension-point>\r\n", styles: [":host{display:inline-block}button.hidden{display:none}\n"], dependencies: [{ kind: "directive", type: i5.ClrIconCustomTag, selector: "clr-icon" }, { kind: "directive", type: i6.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: i7.IfPermissionsDirective, selector: "[vdrIfPermissions]", inputs: ["vdrIfPermissions", "vdrIfPermissionsElse"] }, { kind: "component", type: i8.UiExtensionPointComponent, selector: "vdr-ui-extension-point", inputs: ["locationId", "metadata", "topPx", "leftPx", "display", "api"] }, { kind: "pipe", type: i6.AsyncPipe, name: "async" }, { kind: "pipe", type: i9.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
69
86
  }
70
87
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.2", ngImport: i0, type: ActionBarItemsComponent, decorators: [{
71
88
  type: Component,
72
- args: [{ selector: 'vdr-action-bar-items', changeDetection: ChangeDetectionStrategy.OnPush, template: "<vdr-ui-extension-point [locationId]=\"locationId\" api=\"actionBar\" [leftPx]=\"-24\">\r\n <ng-container *ngFor=\"let item of items$ | async\">\r\n <button\r\n *vdrIfPermissions=\"item.requiresPermission\"\r\n [routerLink]=\"getRouterLink(item)\"\r\n [disabled]=\"item.disabled ? (item.disabled | async) : false\"\r\n (click)=\"handleClick($event, item)\"\r\n [ngClass]=\"getButtonStyles(item)\"\r\n class=\"mr-2\"\r\n >\r\n <clr-icon *ngIf=\"item.icon\" [attr.shape]=\"item.icon\"></clr-icon>\r\n {{ item.label | translate }}\r\n </button>\r\n </ng-container>\r\n</vdr-ui-extension-point>\r\n", styles: [":host{display:inline-block}\n"] }]
73
- }], ctorParameters: function () { return [{ type: i1.NavBuilderService }, { type: i2.ActivatedRoute }, { type: i3.DataService }, { type: i4.NotificationService }]; }, propDecorators: { locationId: [{
89
+ args: [{ selector: 'vdr-action-bar-items', changeDetection: ChangeDetectionStrategy.OnPush, template: "<vdr-ui-extension-point [locationId]=\"locationId\" api=\"actionBar\" [leftPx]=\"-24\">\r\n <ng-container *ngFor=\"let item of items$ | async\">\r\n <ng-container *ngIf=\"buttonStates[item.id] | async as buttonState\">\r\n <button\r\n *vdrIfPermissions=\"item.requiresPermission\"\r\n [routerLink]=\"getRouterLink(item)\"\r\n [class.hidden]=\"buttonState.visible === false\"\r\n [disabled]=\"buttonState.disabled || (item.disabled ? (item.disabled | async) : false)\"\r\n (click)=\"handleClick($event, item)\"\r\n [ngClass]=\"getButtonStyles(item)\"\r\n class=\"mr-2\"\r\n >\r\n <clr-icon *ngIf=\"item.icon\" [attr.shape]=\"item.icon\"></clr-icon>\r\n {{ item.label | translate }}\r\n </button>\r\n </ng-container>\r\n </ng-container>\r\n</vdr-ui-extension-point>\r\n", styles: [":host{display:inline-block}button.hidden{display:none}\n"] }]
90
+ }], ctorParameters: function () { return [{ type: i1.NavBuilderService }, { type: i2.ActivatedRoute }, { type: i3.DataService }, { type: i4.NotificationService }, { type: i0.Injector }]; }, propDecorators: { locationId: [{
74
91
  type: HostBinding,
75
92
  args: ['attr.data-location-id']
76
93
  }, {
77
94
  type: Input
78
95
  }] } });
79
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"action-bar-items.component.js","sourceRoot":"","sources":["../../../../../../src/lib/core/src/shared/components/action-bar-items/action-bar-items.component.ts","../../../../../../src/lib/core/src/shared/components/action-bar-items/action-bar-items.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    HostBinding,\n    Input,\n    OnChanges,\n    OnInit,\n    SimpleChanges,\n} from '@angular/core';\nimport { ActivatedRoute } from '@angular/router';\nimport { assertNever } from '@vendure/common/lib/shared-utils';\nimport { BehaviorSubject, combineLatest, Observable, of } from 'rxjs';\nimport { filter, map } from 'rxjs/operators';\n\nimport { ActionBarLocationId } from '../../../common/component-registry-types';\nimport { DataService } from '../../../data/providers/data.service';\nimport { ActionBarItem } from '../../../providers/nav-builder/nav-builder-types';\nimport { NavBuilderService } from '../../../providers/nav-builder/nav-builder.service';\nimport { NotificationService } from '../../../providers/notification/notification.service';\n\n@Component({\n    selector: 'vdr-action-bar-items',\n    templateUrl: './action-bar-items.component.html',\n    styleUrls: ['./action-bar-items.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ActionBarItemsComponent implements OnInit, OnChanges {\n    @HostBinding('attr.data-location-id')\n    @Input()\n    locationId: ActionBarLocationId;\n\n    items$: Observable<ActionBarItem[]>;\n    private locationId$ = new BehaviorSubject<string>('');\n\n    constructor(\n        private navBuilderService: NavBuilderService,\n        private route: ActivatedRoute,\n        private dataService: DataService,\n        private notificationService: NotificationService,\n    ) {}\n\n    ngOnInit() {\n        this.items$ = combineLatest(this.navBuilderService.actionBarConfig$, this.locationId$).pipe(\n            map(([items, locationId]) => items.filter(config => config.locationId === locationId)),\n        );\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if ('locationId' in changes) {\n            this.locationId$.next(changes['locationId'].currentValue);\n        }\n    }\n\n    handleClick(event: MouseEvent, item: ActionBarItem) {\n        if (typeof item.onClick === 'function') {\n            item.onClick(event, {\n                route: this.route,\n                dataService: this.dataService,\n                notificationService: this.notificationService,\n            });\n        }\n    }\n\n    getRouterLink(item: ActionBarItem): any[] | null {\n        return this.navBuilderService.getRouterLink(item, this.route);\n    }\n\n    getButtonStyles(item: ActionBarItem): string[] {\n        const styles = ['button'];\n        if (item.buttonStyle && item.buttonStyle === 'link') {\n            styles.push('btn-link');\n            return styles;\n        }\n        styles.push(this.getButtonColorClass(item));\n        return styles;\n    }\n\n    private getButtonColorClass(item: ActionBarItem): string {\n        switch (item.buttonColor) {\n            case undefined:\n                return '';\n            case 'primary':\n                return item.buttonStyle === 'outline' ? 'btn-outline' : 'primary';\n            case 'success':\n                return item.buttonStyle === 'outline' ? 'btn-success-outline' : 'success';\n            case 'warning':\n                return item.buttonStyle === 'outline' ? 'btn-warning-outline' : 'warning';\n            default:\n                assertNever(item.buttonColor);\n                return '';\n        }\n    }\n}\n","<vdr-ui-extension-point [locationId]=\"locationId\" api=\"actionBar\" [leftPx]=\"-24\">\r\n    <ng-container *ngFor=\"let item of items$ | async\">\r\n        <button\r\n            *vdrIfPermissions=\"item.requiresPermission\"\r\n            [routerLink]=\"getRouterLink(item)\"\r\n            [disabled]=\"item.disabled ? (item.disabled | async) : false\"\r\n            (click)=\"handleClick($event, item)\"\r\n            [ngClass]=\"getButtonStyles(item)\"\r\n            class=\"mr-2\"\r\n        >\r\n            <clr-icon *ngIf=\"item.icon\" [attr.shape]=\"item.icon\"></clr-icon>\r\n            {{ item.label | translate }}\r\n        </button>\r\n    </ng-container>\r\n</vdr-ui-extension-point>\r\n"]}
96
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"action-bar-items.component.js","sourceRoot":"","sources":["../../../../../../src/lib/core/src/shared/components/action-bar-items/action-bar-items.component.ts","../../../../../../src/lib/core/src/shared/components/action-bar-items/action-bar-items.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    ChangeDetectionStrategy,\r\n    Component,\r\n    HostBinding,\r\n    Injector,\r\n    Input,\r\n    OnChanges,\r\n    OnInit,\r\n    SimpleChanges,\r\n} from '@angular/core';\r\nimport { ActivatedRoute } from '@angular/router';\r\nimport { assertNever } from '@vendure/common/lib/shared-utils';\r\nimport { BehaviorSubject, combineLatest, mergeAll, Observable, of } from 'rxjs';\r\nimport { map, tap } from 'rxjs/operators';\r\n\r\nimport { ActionBarLocationId } from '../../../common/component-registry-types';\r\nimport { DataService } from '../../../data/providers/data.service';\r\nimport {\r\n    ActionBarButtonState,\r\n    ActionBarContext,\r\n    ActionBarItem,\r\n} from '../../../providers/nav-builder/nav-builder-types';\r\nimport { NavBuilderService } from '../../../providers/nav-builder/nav-builder.service';\r\nimport { NotificationService } from '../../../providers/notification/notification.service';\r\n\r\n@Component({\r\n    selector: 'vdr-action-bar-items',\r\n    templateUrl: './action-bar-items.component.html',\r\n    styleUrls: ['./action-bar-items.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class ActionBarItemsComponent implements OnInit, OnChanges {\r\n    @HostBinding('attr.data-location-id')\r\n    @Input()\r\n    locationId: ActionBarLocationId;\r\n\r\n    items$: Observable<ActionBarItem[]>;\r\n    buttonStates: { [id: string]: Observable<ActionBarButtonState> } = {};\r\n    private locationId$ = new BehaviorSubject<string>('');\r\n\r\n    constructor(\r\n        private navBuilderService: NavBuilderService,\r\n        private route: ActivatedRoute,\r\n        private dataService: DataService,\r\n        private notificationService: NotificationService,\r\n        private injector: Injector,\r\n    ) {}\r\n\r\n    ngOnInit() {\r\n        this.items$ = combineLatest(this.navBuilderService.actionBarConfig$, this.locationId$).pipe(\r\n            map(([items, locationId]) => items.filter(config => config.locationId === locationId)),\r\n            tap(items => {\r\n                const context = this.createContext();\r\n                for (const item of items) {\r\n                    const buttonState$ =\r\n                        typeof item.buttonState === 'function'\r\n                            ? item.buttonState(context)\r\n                            : of({\r\n                                  disabled: false,\r\n                                  visible: true,\r\n                              });\r\n                    this.buttonStates[item.id] = buttonState$;\r\n                }\r\n            }),\r\n        );\r\n    }\r\n\r\n    ngOnChanges(changes: SimpleChanges): void {\r\n        if ('locationId' in changes) {\r\n            this.locationId$.next(changes['locationId'].currentValue);\r\n        }\r\n    }\r\n\r\n    handleClick(event: MouseEvent, item: ActionBarItem) {\r\n        if (typeof item.onClick === 'function') {\r\n            item.onClick(event, this.createContext());\r\n        }\r\n    }\r\n\r\n    getRouterLink(item: ActionBarItem): any[] | null {\r\n        return this.navBuilderService.getRouterLink(\r\n            { routerLink: item.routerLink, context: this.createContext() },\r\n            this.route,\r\n        );\r\n    }\r\n\r\n    getButtonStyles(item: ActionBarItem): string[] {\r\n        const styles = ['button'];\r\n        if (item.buttonStyle && item.buttonStyle === 'link') {\r\n            styles.push('btn-link');\r\n            return styles;\r\n        }\r\n        styles.push(this.getButtonColorClass(item));\r\n        return styles;\r\n    }\r\n\r\n    private getButtonColorClass(item: ActionBarItem): string {\r\n        switch (item.buttonColor) {\r\n            case undefined:\r\n                return '';\r\n            case 'primary':\r\n                return item.buttonStyle === 'outline' ? 'btn-outline' : 'primary';\r\n            case 'success':\r\n                return item.buttonStyle === 'outline' ? 'btn-success-outline' : 'success';\r\n            case 'warning':\r\n                return item.buttonStyle === 'outline' ? 'btn-warning-outline' : 'warning';\r\n            default:\r\n                assertNever(item.buttonColor);\r\n                return '';\r\n        }\r\n    }\r\n\r\n    private createContext(): ActionBarContext {\r\n        return {\r\n            route: this.route,\r\n            injector: this.injector,\r\n            dataService: this.dataService,\r\n            notificationService: this.notificationService,\r\n        };\r\n    }\r\n}\r\n","<vdr-ui-extension-point [locationId]=\"locationId\" api=\"actionBar\" [leftPx]=\"-24\">\r\n    <ng-container *ngFor=\"let item of items$ | async\">\r\n        <ng-container *ngIf=\"buttonStates[item.id] | async as buttonState\">\r\n            <button\r\n                *vdrIfPermissions=\"item.requiresPermission\"\r\n                [routerLink]=\"getRouterLink(item)\"\r\n                [class.hidden]=\"buttonState.visible === false\"\r\n                [disabled]=\"buttonState.disabled || (item.disabled ? (item.disabled | async) : false)\"\r\n                (click)=\"handleClick($event, item)\"\r\n                [ngClass]=\"getButtonStyles(item)\"\r\n                class=\"mr-2\"\r\n            >\r\n                <clr-icon *ngIf=\"item.icon\" [attr.shape]=\"item.icon\"></clr-icon>\r\n                {{ item.label | translate }}\r\n            </button>\r\n        </ng-container>\r\n    </ng-container>\r\n</vdr-ui-extension-point>\r\n"]}
@@ -65,7 +65,7 @@ export class AssetGalleryComponent {
65
65
  .fromComponent(AssetPreviewDialogComponent, {
66
66
  size: 'xl',
67
67
  closable: true,
68
- locals: { asset },
68
+ locals: { asset, assets: this.assets },
69
69
  })
70
70
  .subscribe();
71
71
  }
@@ -90,4 +90,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.2", ngImpor
90
90
  }], deleteAssets: [{
91
91
  type: Output
92
92
  }] } });
93
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"asset-gallery.component.js","sourceRoot":"","sources":["../../../../../../src/lib/core/src/shared/components/asset-gallery/asset-gallery.component.ts","../../../../../../src/lib/core/src/shared/components/asset-gallery/asset-gallery.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, Input, OnChanges, Output, SimpleChanges } from '@angular/core';\r\n\r\nimport { SelectionManager } from '../../../common/utilities/selection-manager';\r\nimport { ModalService } from '../../../providers/modal/modal.service';\r\nimport { AssetPreviewDialogComponent } from '../asset-preview-dialog/asset-preview-dialog.component';\r\n\r\nimport { AssetLike } from './asset-gallery.types';\r\n\r\n@Component({\r\n    selector: 'vdr-asset-gallery',\r\n    templateUrl: './asset-gallery.component.html',\r\n    styleUrls: ['./asset-gallery.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class AssetGalleryComponent implements OnChanges {\r\n    @Input() assets: AssetLike[];\r\n    /**\r\n     * If true, allows multiple assets to be selected by ctrl+clicking.\r\n     */\r\n    @Input() multiSelect = false;\r\n    @Input() canDelete = false;\r\n    @Output() selectionChange = new EventEmitter<AssetLike[]>();\r\n    @Output() deleteAssets = new EventEmitter<AssetLike[]>();\r\n\r\n    selectionManager = new SelectionManager<AssetLike>({\r\n        multiSelect: this.multiSelect,\r\n        itemsAreEqual: (a, b) => a.id === b.id,\r\n        additiveMode: false,\r\n    });\r\n\r\n    constructor(private modalService: ModalService) {}\r\n\r\n    ngOnChanges(changes: SimpleChanges) {\r\n        if (this.assets) {\r\n            for (const asset of this.selectionManager.selection) {\r\n                // Update any selected assets with any changes\r\n                const match = this.assets.find(a => a.id === asset.id);\r\n                if (match) {\r\n                    Object.assign(asset, match);\r\n                }\r\n            }\r\n        }\r\n        if (changes['assets']) {\r\n            this.selectionManager.setCurrentItems(this.assets);\r\n        }\r\n        if (changes['multiSelect']) {\r\n            this.selectionManager.setMultiSelect(this.multiSelect);\r\n        }\r\n    }\r\n\r\n    toggleSelection(asset: AssetLike, event?: MouseEvent) {\r\n        this.selectionManager.toggleSelection(asset, event);\r\n        this.selectionChange.emit(this.selectionManager.selection);\r\n    }\r\n\r\n    selectMultiple(assets: AssetLike[]) {\r\n        this.selectionManager.selectMultiple(assets);\r\n        this.selectionChange.emit(this.selectionManager.selection);\r\n    }\r\n\r\n    isSelected(asset: AssetLike): boolean {\r\n        return this.selectionManager.isSelected(asset);\r\n    }\r\n\r\n    lastSelected(): AssetLike {\r\n        return this.selectionManager.lastSelected();\r\n    }\r\n\r\n    previewAsset(asset: AssetLike) {\r\n        this.modalService\r\n            .fromComponent(AssetPreviewDialogComponent, {\r\n                size: 'xl',\r\n                closable: true,\r\n                locals: { asset },\r\n            })\r\n            .subscribe();\r\n    }\r\n\r\n    entityInfoClick(event: MouseEvent) {\r\n        event.preventDefault();\r\n        event.stopPropagation();\r\n    }\r\n}\r\n","<div class=\"gallery\">\r\n    <div\r\n        class=\"card\"\r\n        *ngFor=\"let asset of assets\"\r\n        (click)=\"toggleSelection(asset, $event)\"\r\n        [class.selected]=\"isSelected(asset)\"\r\n    >\r\n        <div class=\"card-img\">\r\n            <vdr-select-toggle\r\n                [selected]=\"isSelected(asset)\"\r\n                [disabled]=\"true\"\r\n                [hiddenWhenOff]=\"true\"\r\n            ></vdr-select-toggle>\r\n            <img class=\"asset-thumb\" [src]=\"asset | assetPreview : 'thumb'\" />\r\n        </div>\r\n        <div class=\"detail\">\r\n            <vdr-entity-info\r\n                [entity]=\"asset\"\r\n                [small]=\"true\"\r\n                (click)=\"entityInfoClick($event)\"\r\n            ></vdr-entity-info>\r\n            <span [title]=\"asset.name\">{{ asset.name }}</span>\r\n        </div>\r\n    </div>\r\n</div>\r\n<div class=\"info-bar\">\r\n    <div class=\"card\">\r\n        <div class=\"card-img\">\r\n            <div class=\"placeholder\" *ngIf=\"selectionManager.selection.length === 0\">\r\n                <clr-icon shape=\"image\" size=\"128\"></clr-icon>\r\n                <div>{{ 'catalog.no-selection' | translate }}</div>\r\n            </div>\r\n            <img\r\n                class=\"preview\"\r\n                *ngIf=\"selectionManager.selection.length >= 1\"\r\n                [src]=\"lastSelected().preview + '?preset=medium'\"\r\n            />\r\n        </div>\r\n        <div class=\"card-block details\" *ngIf=\"selectionManager.selection.length >= 1\">\r\n            <div class=\"name\">{{ lastSelected().name }}</div>\r\n            <div>{{ 'asset.original-asset-size' | translate }}: {{ lastSelected().fileSize | filesize }}</div>\r\n\r\n            <ng-container *ngIf=\"selectionManager.selection.length === 1\">\r\n                <vdr-chip *ngFor=\"let tag of lastSelected().tags\" [colorFrom]=\"tag.value\"\r\n                    ><clr-icon shape=\"tag\" class=\"mr2\"></clr-icon> {{ tag.value }}</vdr-chip\r\n                >\r\n            </ng-container>\r\n            <div *ngIf=\"selectionManager.selection.length === 1\">\r\n                <a [routerLink]=\"['./', lastSelected().id]\" class=\"button-ghost\">\r\n                    <clr-icon shape=\"pencil\"></clr-icon> {{ 'common.edit' | translate }}\r\n                    <clr-icon shape=\"arrow right\"></clr-icon>\r\n                </a>\r\n            </div>\r\n            <div *ngIf=\"selectionManager.selection.length === 1\">\r\n                <button (click)=\"previewAsset(lastSelected())\" class=\"button-small mt-1\">\r\n                    <clr-icon shape=\"eye\"></clr-icon> {{ 'asset.preview' | translate }}\r\n                </button>\r\n            </div>\r\n            <div *ngIf=\"canDelete\">\r\n                <button (click)=\"deleteAssets.emit(selectionManager.selection)\" class=\"button-small mt-1\">\r\n                    <clr-icon shape=\"trash\" class=\"is-danger\"></clr-icon>\r\n                    {{ 'common.delete' | translate }}\r\n                </button>\r\n            </div>\r\n            <div class=\"mt-1\" *ngIf=\"selectionManager.selection.length === 1\">\r\n                <vdr-asset-preview-links class=\"\" [asset]=\"lastSelected()\"></vdr-asset-preview-links>\r\n            </div>\r\n        </div>\r\n    </div>\r\n    <div class=\"card stack\" [class.visible]=\"selectionManager.selection.length > 1\"></div>\r\n    <div class=\"selection-count\" [class.visible]=\"selectionManager.selection.length > 1\">\r\n        {{ 'asset.assets-selected-count' | translate : { count: selectionManager.selection.length } }}\r\n        <ul>\r\n            <li *ngFor=\"let asset of selectionManager.selection\">{{ asset.name }}</li>\r\n        </ul>\r\n    </div>\r\n</div>\r\n"]}
93
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"asset-gallery.component.js","sourceRoot":"","sources":["../../../../../../src/lib/core/src/shared/components/asset-gallery/asset-gallery.component.ts","../../../../../../src/lib/core/src/shared/components/asset-gallery/asset-gallery.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, Input, OnChanges, Output, SimpleChanges } from '@angular/core';\r\n\r\nimport { SelectionManager } from '../../../common/utilities/selection-manager';\r\nimport { ModalService } from '../../../providers/modal/modal.service';\r\nimport { AssetPreviewDialogComponent } from '../asset-preview-dialog/asset-preview-dialog.component';\r\n\r\nimport { AssetLike } from './asset-gallery.types';\r\n\r\n@Component({\r\n    selector: 'vdr-asset-gallery',\r\n    templateUrl: './asset-gallery.component.html',\r\n    styleUrls: ['./asset-gallery.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class AssetGalleryComponent implements OnChanges {\r\n    @Input() assets: AssetLike[];\r\n    /**\r\n     * If true, allows multiple assets to be selected by ctrl+clicking.\r\n     */\r\n    @Input() multiSelect = false;\r\n    @Input() canDelete = false;\r\n    @Output() selectionChange = new EventEmitter<AssetLike[]>();\r\n    @Output() deleteAssets = new EventEmitter<AssetLike[]>();\r\n\r\n    selectionManager = new SelectionManager<AssetLike>({\r\n        multiSelect: this.multiSelect,\r\n        itemsAreEqual: (a, b) => a.id === b.id,\r\n        additiveMode: false,\r\n    });\r\n\r\n    constructor(private modalService: ModalService) {}\r\n\r\n    ngOnChanges(changes: SimpleChanges) {\r\n        if (this.assets) {\r\n            for (const asset of this.selectionManager.selection) {\r\n                // Update any selected assets with any changes\r\n                const match = this.assets.find(a => a.id === asset.id);\r\n                if (match) {\r\n                    Object.assign(asset, match);\r\n                }\r\n            }\r\n        }\r\n        if (changes['assets']) {\r\n            this.selectionManager.setCurrentItems(this.assets);\r\n        }\r\n        if (changes['multiSelect']) {\r\n            this.selectionManager.setMultiSelect(this.multiSelect);\r\n        }\r\n    }\r\n\r\n    toggleSelection(asset: AssetLike, event?: MouseEvent) {\r\n        this.selectionManager.toggleSelection(asset, event);\r\n        this.selectionChange.emit(this.selectionManager.selection);\r\n    }\r\n\r\n    selectMultiple(assets: AssetLike[]) {\r\n        this.selectionManager.selectMultiple(assets);\r\n        this.selectionChange.emit(this.selectionManager.selection);\r\n    }\r\n\r\n    isSelected(asset: AssetLike): boolean {\r\n        return this.selectionManager.isSelected(asset);\r\n    }\r\n\r\n    lastSelected(): AssetLike {\r\n        return this.selectionManager.lastSelected();\r\n    }\r\n\r\n    previewAsset(asset: AssetLike) {\r\n        this.modalService\r\n            .fromComponent(AssetPreviewDialogComponent, {\r\n                size: 'xl',\r\n                closable: true,\r\n                locals: { asset, assets: this.assets },\r\n            })\r\n            .subscribe();\r\n    }\r\n\r\n    entityInfoClick(event: MouseEvent) {\r\n        event.preventDefault();\r\n        event.stopPropagation();\r\n    }\r\n}\r\n","<div class=\"gallery\">\r\n    <div\r\n        class=\"card\"\r\n        *ngFor=\"let asset of assets\"\r\n        (click)=\"toggleSelection(asset, $event)\"\r\n        [class.selected]=\"isSelected(asset)\"\r\n    >\r\n        <div class=\"card-img\">\r\n            <vdr-select-toggle\r\n                [selected]=\"isSelected(asset)\"\r\n                [disabled]=\"true\"\r\n                [hiddenWhenOff]=\"true\"\r\n            ></vdr-select-toggle>\r\n            <img class=\"asset-thumb\" [src]=\"asset | assetPreview : 'thumb'\" />\r\n        </div>\r\n        <div class=\"detail\">\r\n            <vdr-entity-info\r\n                [entity]=\"asset\"\r\n                [small]=\"true\"\r\n                (click)=\"entityInfoClick($event)\"\r\n            ></vdr-entity-info>\r\n            <span [title]=\"asset.name\">{{ asset.name }}</span>\r\n        </div>\r\n    </div>\r\n</div>\r\n<div class=\"info-bar\">\r\n    <div class=\"card\">\r\n        <div class=\"card-img\">\r\n            <div class=\"placeholder\" *ngIf=\"selectionManager.selection.length === 0\">\r\n                <clr-icon shape=\"image\" size=\"128\"></clr-icon>\r\n                <div>{{ 'catalog.no-selection' | translate }}</div>\r\n            </div>\r\n            <img\r\n                class=\"preview\"\r\n                *ngIf=\"selectionManager.selection.length >= 1\"\r\n                [src]=\"lastSelected().preview + '?preset=medium'\"\r\n            />\r\n        </div>\r\n        <div class=\"card-block details\" *ngIf=\"selectionManager.selection.length >= 1\">\r\n            <div class=\"name\">{{ lastSelected().name }}</div>\r\n            <div>{{ 'asset.original-asset-size' | translate }}: {{ lastSelected().fileSize | filesize }}</div>\r\n\r\n            <ng-container *ngIf=\"selectionManager.selection.length === 1\">\r\n                <vdr-chip *ngFor=\"let tag of lastSelected().tags\" [colorFrom]=\"tag.value\"\r\n                    ><clr-icon shape=\"tag\" class=\"mr2\"></clr-icon> {{ tag.value }}</vdr-chip\r\n                >\r\n            </ng-container>\r\n            <div *ngIf=\"selectionManager.selection.length === 1\">\r\n                <a [routerLink]=\"['./', lastSelected().id]\" class=\"button-ghost\">\r\n                    <clr-icon shape=\"pencil\"></clr-icon> {{ 'common.edit' | translate }}\r\n                    <clr-icon shape=\"arrow right\"></clr-icon>\r\n                </a>\r\n            </div>\r\n            <div *ngIf=\"selectionManager.selection.length === 1\">\r\n                <button (click)=\"previewAsset(lastSelected())\" class=\"button-small mt-1\">\r\n                    <clr-icon shape=\"eye\"></clr-icon> {{ 'asset.preview' | translate }}\r\n                </button>\r\n            </div>\r\n            <div *ngIf=\"canDelete\">\r\n                <button (click)=\"deleteAssets.emit(selectionManager.selection)\" class=\"button-small mt-1\">\r\n                    <clr-icon shape=\"trash\" class=\"is-danger\"></clr-icon>\r\n                    {{ 'common.delete' | translate }}\r\n                </button>\r\n            </div>\r\n            <div class=\"mt-1\" *ngIf=\"selectionManager.selection.length === 1\">\r\n                <vdr-asset-preview-links class=\"\" [asset]=\"lastSelected()\"></vdr-asset-preview-links>\r\n            </div>\r\n        </div>\r\n    </div>\r\n    <div class=\"card stack\" [class.visible]=\"selectionManager.selection.length > 1\"></div>\r\n    <div class=\"selection-count\" [class.visible]=\"selectionManager.selection.length > 1\">\r\n        {{ 'asset.assets-selected-count' | translate : { count: selectionManager.selection.length } }}\r\n        <ul>\r\n            <li *ngFor=\"let asset of selectionManager.selection\">{{ asset.name }}</li>\r\n        </ul>\r\n    </div>\r\n</div>\r\n"]}
@@ -21,7 +21,7 @@ import * as i12 from "@ngx-translate/core";
21
21
  * A dialog which allows the creation and selection of assets.
22
22
  *
23
23
  * @example
24
- * ```TypeScript
24
+ * ```ts
25
25
  * selectAssets() {
26
26
  * this.modalService
27
27
  * .fromComponent(AssetPickerDialogComponent, {
@@ -141,4 +141,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.2", ngImpor
141
141
  type: ViewChild,
142
142
  args: ['assetGalleryComponent']
143
143
  }] } });
144
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"asset-picker-dialog.component.js","sourceRoot":"","sources":["../../../../../../src/lib/core/src/shared/components/asset-picker-dialog/asset-picker-dialog.component.ts","../../../../../../src/lib/core/src/shared/components/asset-picker-dialog/asset-picker-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    AfterViewInit,\r\n    ChangeDetectionStrategy,\r\n    Component,\r\n    OnDestroy,\r\n    OnInit,\r\n    ViewChild,\r\n} from '@angular/core';\r\nimport { marker as _ } from '@biesbjerg/ngx-translate-extract-marker';\r\nimport { PaginationInstance } from 'ngx-pagination';\r\nimport { BehaviorSubject, Observable, Subject } from 'rxjs';\r\nimport { debounceTime, delay, finalize, map, take as rxjsTake, takeUntil, tap } from 'rxjs/operators';\r\n\r\nimport {\r\n    Asset,\r\n    CreateAssetsMutation,\r\n    GetAssetListQuery,\r\n    GetAssetListQueryVariables,\r\n    LogicalOperator,\r\n    SortOrder,\r\n    TagFragment,\r\n} from '../../../common/generated-types';\r\nimport { DataService } from '../../../data/providers/data.service';\r\nimport { QueryResult } from '../../../data/query-result';\r\nimport { Dialog } from '../../../providers/modal/modal.types';\r\nimport { NotificationService } from '../../../providers/notification/notification.service';\r\nimport { AssetGalleryComponent } from '../asset-gallery/asset-gallery.component';\r\nimport { AssetLike } from '../asset-gallery/asset-gallery.types';\r\nimport { AssetSearchInputComponent } from '../asset-search-input/asset-search-input.component';\r\n\r\n/**\r\n * @description\r\n * A dialog which allows the creation and selection of assets.\r\n *\r\n * @example\r\n * ```TypeScript\r\n * selectAssets() {\r\n *   this.modalService\r\n *     .fromComponent(AssetPickerDialogComponent, {\r\n *         size: 'xl',\r\n *     })\r\n *     .subscribe(result => {\r\n *         if (result && result.length) {\r\n *             // ...\r\n *         }\r\n *     });\r\n * }\r\n * ```\r\n *\r\n * @docsCategory components\r\n */\r\n@Component({\r\n    selector: 'vdr-asset-picker-dialog',\r\n    templateUrl: './asset-picker-dialog.component.html',\r\n    styleUrls: ['./asset-picker-dialog.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class AssetPickerDialogComponent implements OnInit, AfterViewInit, OnDestroy, Dialog<Asset[]> {\r\n    assets$: Observable<AssetLike[]>;\r\n    allTags$: Observable<TagFragment[]>;\r\n    paginationConfig: PaginationInstance = {\r\n        currentPage: 1,\r\n        itemsPerPage: 25,\r\n        totalItems: 1,\r\n    };\r\n    @ViewChild('assetSearchInputComponent')\r\n    private assetSearchInputComponent: AssetSearchInputComponent;\r\n    @ViewChild('assetGalleryComponent')\r\n    private assetGalleryComponent: AssetGalleryComponent;\r\n\r\n    multiSelect = true;\r\n    initialTags: string[] = [];\r\n\r\n    resolveWith: (result?: Asset[]) => void;\r\n    selection: Asset[] = [];\r\n    searchTerm$ = new BehaviorSubject<string | undefined>(undefined);\r\n    filterByTags$ = new BehaviorSubject<TagFragment[] | undefined>(undefined);\r\n    uploading = false;\r\n    private listQuery: QueryResult<GetAssetListQuery, GetAssetListQueryVariables>;\r\n    private destroy$ = new Subject<void>();\r\n\r\n    constructor(private dataService: DataService, private notificationService: NotificationService) {}\r\n\r\n    ngOnInit() {\r\n        this.listQuery = this.dataService.product.getAssetList(this.paginationConfig.itemsPerPage, 0);\r\n        this.allTags$ = this.dataService.product.getTagList().mapSingle(data => data.tags.items);\r\n        this.assets$ = this.listQuery.stream$.pipe(\r\n            tap(result => (this.paginationConfig.totalItems = result.assets.totalItems)),\r\n            map(result => result.assets.items),\r\n        );\r\n        this.searchTerm$.pipe(debounceTime(250), takeUntil(this.destroy$)).subscribe(() => {\r\n            this.fetchPage(this.paginationConfig.currentPage, this.paginationConfig.itemsPerPage);\r\n        });\r\n        this.filterByTags$.pipe(debounceTime(100), takeUntil(this.destroy$)).subscribe(() => {\r\n            this.fetchPage(this.paginationConfig.currentPage, this.paginationConfig.itemsPerPage);\r\n        });\r\n    }\r\n\r\n    ngAfterViewInit() {\r\n        if (0 < this.initialTags.length) {\r\n            this.allTags$\r\n                .pipe(\r\n                    rxjsTake(1),\r\n                    map(allTags => allTags.filter(tag => this.initialTags.includes(tag.value))),\r\n                    tap(tags => this.filterByTags$.next(tags)),\r\n                    delay(1),\r\n                )\r\n                .subscribe(tags => this.assetSearchInputComponent.setTags(tags));\r\n        }\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        this.destroy$.next();\r\n        this.destroy$.complete();\r\n    }\r\n\r\n    pageChange(page: number) {\r\n        this.paginationConfig.currentPage = page;\r\n        this.fetchPage(this.paginationConfig.currentPage, this.paginationConfig.itemsPerPage);\r\n    }\r\n\r\n    itemsPerPageChange(itemsPerPage: number) {\r\n        this.paginationConfig.itemsPerPage = itemsPerPage;\r\n        this.fetchPage(this.paginationConfig.currentPage, this.paginationConfig.itemsPerPage);\r\n    }\r\n\r\n    cancel() {\r\n        this.resolveWith();\r\n    }\r\n\r\n    select() {\r\n        this.resolveWith(this.selection);\r\n    }\r\n\r\n    createAssets(files: File[]) {\r\n        if (files.length) {\r\n            this.uploading = true;\r\n            this.dataService.product\r\n                .createAssets(files)\r\n                .pipe(finalize(() => (this.uploading = false)))\r\n                .subscribe(res => {\r\n                    this.fetchPage(this.paginationConfig.currentPage, this.paginationConfig.itemsPerPage);\r\n                    this.notificationService.success(_('asset.notify-create-assets-success'), {\r\n                        count: files.length,\r\n                    });\r\n                    const assets = res.createAssets.filter(a => a.__typename === 'Asset') as AssetLike[];\r\n                    this.assetGalleryComponent.selectMultiple(assets);\r\n                });\r\n        }\r\n    }\r\n\r\n    private fetchPage(currentPage: number, itemsPerPage: number) {\r\n        const take = +itemsPerPage;\r\n        const skip = (currentPage - 1) * +itemsPerPage;\r\n        const searchTerm = this.searchTerm$.value;\r\n        const tags = this.filterByTags$.value?.map(t => t.value);\r\n        this.listQuery.ref.refetch({\r\n            options: {\r\n                skip,\r\n                take,\r\n                filter: {\r\n                    name: {\r\n                        contains: searchTerm,\r\n                    },\r\n                },\r\n                sort: {\r\n                    createdAt: SortOrder.DESC,\r\n                },\r\n                tags,\r\n                tagsOperator: LogicalOperator.AND,\r\n            },\r\n        });\r\n    }\r\n}\r\n","<ng-template vdrDialogTitle>\r\n    <div class=\"title-row\">\r\n        <span>{{ 'asset.select-assets' | translate }}</span>\r\n        <div class=\"flex-spacer\"></div>\r\n        <vdr-asset-file-input\r\n            class=\"ml3\"\r\n            (selectFiles)=\"createAssets($event)\"\r\n            [uploading]=\"uploading\"\r\n            dropZoneTarget=\".modal-content\"\r\n        ></vdr-asset-file-input>\r\n    </div>\r\n</ng-template>\r\n<vdr-asset-search-input\r\n    class=\"mb-2\"\r\n    [tags]=\"allTags$ | async\"\r\n    (searchTermChange)=\"searchTerm$.next($event)\"\r\n    (tagsChange)=\"filterByTags$.next($event)\"\r\n    #assetSearchInputComponent\r\n></vdr-asset-search-input>\r\n<vdr-asset-gallery\r\n    [assets]=\"(assets$ | async)! | paginate: paginationConfig\"\r\n    [multiSelect]=\"multiSelect\"\r\n    (selectionChange)=\"selection = $event\"\r\n    #assetGalleryComponent\r\n></vdr-asset-gallery>\r\n\r\n<div class=\"paging-controls\">\r\n    <vdr-items-per-page-controls\r\n        [itemsPerPage]=\"paginationConfig.itemsPerPage\"\r\n        (itemsPerPageChange)=\"itemsPerPageChange($event)\"\r\n    ></vdr-items-per-page-controls>\r\n\r\n    <vdr-pagination-controls\r\n        [currentPage]=\"paginationConfig.currentPage\"\r\n        [itemsPerPage]=\"paginationConfig.itemsPerPage\"\r\n        [totalItems]=\"paginationConfig.totalItems\"\r\n        (pageChange)=\"pageChange($event)\"\r\n    ></vdr-pagination-controls>\r\n</div>\r\n\r\n<ng-template vdrDialogButtons>\r\n    <button type=\"button\" class=\"btn\" (click)=\"cancel()\">{{ 'common.cancel' | translate }}</button>\r\n    <button type=\"submit\" (click)=\"select()\" class=\"btn btn-primary\" [disabled]=\"selection.length === 0\">\r\n        {{ 'asset.add-asset-with-count' | translate: { count: selection.length } }}\r\n    </button>\r\n</ng-template>\r\n"]}
144
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"asset-picker-dialog.component.js","sourceRoot":"","sources":["../../../../../../src/lib/core/src/shared/components/asset-picker-dialog/asset-picker-dialog.component.ts","../../../../../../src/lib/core/src/shared/components/asset-picker-dialog/asset-picker-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    AfterViewInit,\r\n    ChangeDetectionStrategy,\r\n    Component,\r\n    OnDestroy,\r\n    OnInit,\r\n    ViewChild,\r\n} from '@angular/core';\r\nimport { marker as _ } from '@biesbjerg/ngx-translate-extract-marker';\r\nimport { PaginationInstance } from 'ngx-pagination';\r\nimport { BehaviorSubject, Observable, Subject } from 'rxjs';\r\nimport { debounceTime, delay, finalize, map, take as rxjsTake, takeUntil, tap } from 'rxjs/operators';\r\n\r\nimport {\r\n    Asset,\r\n    CreateAssetsMutation,\r\n    GetAssetListQuery,\r\n    GetAssetListQueryVariables,\r\n    LogicalOperator,\r\n    SortOrder,\r\n    TagFragment,\r\n} from '../../../common/generated-types';\r\nimport { DataService } from '../../../data/providers/data.service';\r\nimport { QueryResult } from '../../../data/query-result';\r\nimport { Dialog } from '../../../providers/modal/modal.types';\r\nimport { NotificationService } from '../../../providers/notification/notification.service';\r\nimport { AssetGalleryComponent } from '../asset-gallery/asset-gallery.component';\r\nimport { AssetLike } from '../asset-gallery/asset-gallery.types';\r\nimport { AssetSearchInputComponent } from '../asset-search-input/asset-search-input.component';\r\n\r\n/**\r\n * @description\r\n * A dialog which allows the creation and selection of assets.\r\n *\r\n * @example\r\n * ```ts\r\n * selectAssets() {\r\n *   this.modalService\r\n *     .fromComponent(AssetPickerDialogComponent, {\r\n *         size: 'xl',\r\n *     })\r\n *     .subscribe(result => {\r\n *         if (result && result.length) {\r\n *             // ...\r\n *         }\r\n *     });\r\n * }\r\n * ```\r\n *\r\n * @docsCategory components\r\n */\r\n@Component({\r\n    selector: 'vdr-asset-picker-dialog',\r\n    templateUrl: './asset-picker-dialog.component.html',\r\n    styleUrls: ['./asset-picker-dialog.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class AssetPickerDialogComponent implements OnInit, AfterViewInit, OnDestroy, Dialog<Asset[]> {\r\n    assets$: Observable<AssetLike[]>;\r\n    allTags$: Observable<TagFragment[]>;\r\n    paginationConfig: PaginationInstance = {\r\n        currentPage: 1,\r\n        itemsPerPage: 25,\r\n        totalItems: 1,\r\n    };\r\n    @ViewChild('assetSearchInputComponent')\r\n    private assetSearchInputComponent: AssetSearchInputComponent;\r\n    @ViewChild('assetGalleryComponent')\r\n    private assetGalleryComponent: AssetGalleryComponent;\r\n\r\n    multiSelect = true;\r\n    initialTags: string[] = [];\r\n\r\n    resolveWith: (result?: Asset[]) => void;\r\n    selection: Asset[] = [];\r\n    searchTerm$ = new BehaviorSubject<string | undefined>(undefined);\r\n    filterByTags$ = new BehaviorSubject<TagFragment[] | undefined>(undefined);\r\n    uploading = false;\r\n    private listQuery: QueryResult<GetAssetListQuery, GetAssetListQueryVariables>;\r\n    private destroy$ = new Subject<void>();\r\n\r\n    constructor(private dataService: DataService, private notificationService: NotificationService) {}\r\n\r\n    ngOnInit() {\r\n        this.listQuery = this.dataService.product.getAssetList(this.paginationConfig.itemsPerPage, 0);\r\n        this.allTags$ = this.dataService.product.getTagList().mapSingle(data => data.tags.items);\r\n        this.assets$ = this.listQuery.stream$.pipe(\r\n            tap(result => (this.paginationConfig.totalItems = result.assets.totalItems)),\r\n            map(result => result.assets.items),\r\n        );\r\n        this.searchTerm$.pipe(debounceTime(250), takeUntil(this.destroy$)).subscribe(() => {\r\n            this.fetchPage(this.paginationConfig.currentPage, this.paginationConfig.itemsPerPage);\r\n        });\r\n        this.filterByTags$.pipe(debounceTime(100), takeUntil(this.destroy$)).subscribe(() => {\r\n            this.fetchPage(this.paginationConfig.currentPage, this.paginationConfig.itemsPerPage);\r\n        });\r\n    }\r\n\r\n    ngAfterViewInit() {\r\n        if (0 < this.initialTags.length) {\r\n            this.allTags$\r\n                .pipe(\r\n                    rxjsTake(1),\r\n                    map(allTags => allTags.filter(tag => this.initialTags.includes(tag.value))),\r\n                    tap(tags => this.filterByTags$.next(tags)),\r\n                    delay(1),\r\n                )\r\n                .subscribe(tags => this.assetSearchInputComponent.setTags(tags));\r\n        }\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        this.destroy$.next();\r\n        this.destroy$.complete();\r\n    }\r\n\r\n    pageChange(page: number) {\r\n        this.paginationConfig.currentPage = page;\r\n        this.fetchPage(this.paginationConfig.currentPage, this.paginationConfig.itemsPerPage);\r\n    }\r\n\r\n    itemsPerPageChange(itemsPerPage: number) {\r\n        this.paginationConfig.itemsPerPage = itemsPerPage;\r\n        this.fetchPage(this.paginationConfig.currentPage, this.paginationConfig.itemsPerPage);\r\n    }\r\n\r\n    cancel() {\r\n        this.resolveWith();\r\n    }\r\n\r\n    select() {\r\n        this.resolveWith(this.selection);\r\n    }\r\n\r\n    createAssets(files: File[]) {\r\n        if (files.length) {\r\n            this.uploading = true;\r\n            this.dataService.product\r\n                .createAssets(files)\r\n                .pipe(finalize(() => (this.uploading = false)))\r\n                .subscribe(res => {\r\n                    this.fetchPage(this.paginationConfig.currentPage, this.paginationConfig.itemsPerPage);\r\n                    this.notificationService.success(_('asset.notify-create-assets-success'), {\r\n                        count: files.length,\r\n                    });\r\n                    const assets = res.createAssets.filter(a => a.__typename === 'Asset') as AssetLike[];\r\n                    this.assetGalleryComponent.selectMultiple(assets);\r\n                });\r\n        }\r\n    }\r\n\r\n    private fetchPage(currentPage: number, itemsPerPage: number) {\r\n        const take = +itemsPerPage;\r\n        const skip = (currentPage - 1) * +itemsPerPage;\r\n        const searchTerm = this.searchTerm$.value;\r\n        const tags = this.filterByTags$.value?.map(t => t.value);\r\n        this.listQuery.ref.refetch({\r\n            options: {\r\n                skip,\r\n                take,\r\n                filter: {\r\n                    name: {\r\n                        contains: searchTerm,\r\n                    },\r\n                },\r\n                sort: {\r\n                    createdAt: SortOrder.DESC,\r\n                },\r\n                tags,\r\n                tagsOperator: LogicalOperator.AND,\r\n            },\r\n        });\r\n    }\r\n}\r\n","<ng-template vdrDialogTitle>\r\n    <div class=\"title-row\">\r\n        <span>{{ 'asset.select-assets' | translate }}</span>\r\n        <div class=\"flex-spacer\"></div>\r\n        <vdr-asset-file-input\r\n            class=\"ml3\"\r\n            (selectFiles)=\"createAssets($event)\"\r\n            [uploading]=\"uploading\"\r\n            dropZoneTarget=\".modal-content\"\r\n        ></vdr-asset-file-input>\r\n    </div>\r\n</ng-template>\r\n<vdr-asset-search-input\r\n    class=\"mb-2\"\r\n    [tags]=\"allTags$ | async\"\r\n    (searchTermChange)=\"searchTerm$.next($event)\"\r\n    (tagsChange)=\"filterByTags$.next($event)\"\r\n    #assetSearchInputComponent\r\n></vdr-asset-search-input>\r\n<vdr-asset-gallery\r\n    [assets]=\"(assets$ | async)! | paginate: paginationConfig\"\r\n    [multiSelect]=\"multiSelect\"\r\n    (selectionChange)=\"selection = $event\"\r\n    #assetGalleryComponent\r\n></vdr-asset-gallery>\r\n\r\n<div class=\"paging-controls\">\r\n    <vdr-items-per-page-controls\r\n        [itemsPerPage]=\"paginationConfig.itemsPerPage\"\r\n        (itemsPerPageChange)=\"itemsPerPageChange($event)\"\r\n    ></vdr-items-per-page-controls>\r\n\r\n    <vdr-pagination-controls\r\n        [currentPage]=\"paginationConfig.currentPage\"\r\n        [itemsPerPage]=\"paginationConfig.itemsPerPage\"\r\n        [totalItems]=\"paginationConfig.totalItems\"\r\n        (pageChange)=\"pageChange($event)\"\r\n    ></vdr-pagination-controls>\r\n</div>\r\n\r\n<ng-template vdrDialogButtons>\r\n    <button type=\"button\" class=\"btn\" (click)=\"cancel()\">{{ 'common.cancel' | translate }}</button>\r\n    <button type=\"submit\" (click)=\"select()\" class=\"btn btn-primary\" [disabled]=\"selection.length === 0\">\r\n        {{ 'asset.add-asset-with-count' | translate: { count: selection.length } }}\r\n    </button>\r\n</ng-template>\r\n"]}