@vendure/admin-ui 2.0.2 → 2.0.3

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 (122) hide show
  1. package/catalog/components/product-variant-list/product-variant-list-bulk-actions.d.ts +6 -0
  2. package/catalog/public_api.d.ts +1 -1
  3. package/core/common/base-detail.component.d.ts +1 -0
  4. package/core/common/component-registry-types.d.ts +2 -2
  5. package/core/common/generated-types.d.ts +13 -0
  6. package/core/common/version.d.ts +1 -1
  7. package/core/components/theme-switcher/theme-switcher.component.d.ts +1 -0
  8. package/core/data/definitions/product-definitions.d.ts +1 -0
  9. package/core/data/providers/product-data.service.d.ts +1 -0
  10. package/core/shared/components/data-table-filters/data-table-filters.component.d.ts +1 -0
  11. package/core/shared/components/dropdown/dropdown-menu.component.d.ts +2 -0
  12. package/core/shared/components/dropdown/dropdown.component.d.ts +1 -1
  13. package/core/shared/components/rich-text-editor/prosemirror/prosemirror.service.d.ts +6 -0
  14. package/core/shared/dynamic-form-inputs/customer-group-form-input/customer-group-form-input.component.d.ts +5 -2
  15. package/core/shared/dynamic-form-inputs/product-multi-selector-form-input/product-multi-selector-form-input.component.d.ts +4 -2
  16. package/core/shared/dynamic-form-inputs/product-selector-form-input/product-selector-form-input.component.d.ts +8 -5
  17. package/core/shared/dynamic-form-inputs/relation-form-input/asset/relation-asset-input.component.d.ts +1 -4
  18. package/core/shared/dynamic-form-inputs/relation-form-input/customer/relation-customer-input.component.d.ts +0 -1
  19. package/core/shared/shared.module.d.ts +2 -1
  20. package/esm2022/catalog/catalog.module.mjs +5 -1
  21. package/esm2022/catalog/components/asset-list/asset-list.component.mjs +3 -3
  22. package/esm2022/catalog/components/assign-products-to-channel-dialog/assign-products-to-channel-dialog.component.mjs +11 -14
  23. package/esm2022/catalog/components/product-list/product-list.component.mjs +3 -3
  24. package/esm2022/catalog/components/product-options-editor/product-options-editor.component.mjs +1 -1
  25. package/esm2022/catalog/components/product-variant-detail/product-variant-detail.component.mjs +4 -5
  26. package/esm2022/catalog/components/product-variant-list/product-variant-list-bulk-actions.mjs +92 -0
  27. package/esm2022/catalog/components/product-variant-list/product-variant-list.component.mjs +5 -5
  28. package/esm2022/catalog/public_api.mjs +2 -2
  29. package/esm2022/core/common/base-detail.component.mjs +3 -3
  30. package/esm2022/core/common/base-list.component.mjs +2 -2
  31. package/esm2022/core/common/component-registry-types.mjs +1 -1
  32. package/esm2022/core/common/generated-types.mjs +2 -1
  33. package/esm2022/core/common/title-setter.mjs +1 -1
  34. package/esm2022/core/common/version.mjs +2 -2
  35. package/esm2022/core/components/base-nav/base-nav.component.mjs +1 -1
  36. package/esm2022/core/components/main-nav/main-nav.component.mjs +2 -2
  37. package/esm2022/core/components/theme-switcher/theme-switcher.component.mjs +15 -5
  38. package/esm2022/core/components/user-menu/user-menu.component.mjs +3 -3
  39. package/esm2022/core/data/definitions/product-definitions.mjs +9 -1
  40. package/esm2022/core/data/providers/interceptor.mjs +1 -1
  41. package/esm2022/core/data/providers/product-data.service.mjs +7 -2
  42. package/esm2022/core/data/utils/transform-relation-custom-field-inputs.mjs +2 -2
  43. package/esm2022/core/providers/bulk-action-registry/bulk-action-types.mjs +1 -1
  44. package/esm2022/core/providers/custom-field-component/custom-field-component.service.mjs +1 -1
  45. package/esm2022/core/providers/data-table/data-table-filter-collection.mjs +2 -2
  46. package/esm2022/core/providers/local-storage/local-storage.service.mjs +1 -1
  47. package/esm2022/core/providers/page/page.service.mjs +1 -1
  48. package/esm2022/core/shared/components/action-bar-items/action-bar-items.component.mjs +1 -1
  49. package/esm2022/core/shared/components/assign-to-channel-dialog/assign-to-channel-dialog.component.mjs +1 -1
  50. package/esm2022/core/shared/components/chip/chip.component.mjs +2 -2
  51. package/esm2022/core/shared/components/currency-code-selector/currency-code-selector.component.mjs +1 -1
  52. package/esm2022/core/shared/components/data-table/data-table.component.mjs +1 -1
  53. package/esm2022/core/shared/components/data-table-filters/data-table-filters.component.mjs +24 -15
  54. package/esm2022/core/shared/components/dropdown/dropdown-menu.component.mjs +65 -24
  55. package/esm2022/core/shared/components/dropdown/dropdown.component.mjs +1 -1
  56. package/esm2022/core/shared/components/facet-value-selector/facet-value-selector.component.mjs +3 -3
  57. package/esm2022/core/shared/components/language-code-selector/language-code-selector.component.mjs +1 -1
  58. package/esm2022/core/shared/components/rich-text-editor/prosemirror/custom-nodes.mjs +4 -3
  59. package/esm2022/core/shared/components/rich-text-editor/prosemirror/prosemirror.service.mjs +16 -3
  60. package/esm2022/core/shared/components/tabbed-custom-fields/tabbed-custom-fields.component.mjs +3 -1
  61. package/esm2022/core/shared/dynamic-form-inputs/customer-group-form-input/customer-group-form-input.component.mjs +7 -4
  62. package/esm2022/core/shared/dynamic-form-inputs/dynamic-form-input/dynamic-form-input.component.mjs +9 -8
  63. package/esm2022/core/shared/dynamic-form-inputs/product-multi-selector-form-input/product-multi-selector-form-input.component.mjs +3 -2
  64. package/esm2022/core/shared/dynamic-form-inputs/product-selector-form-input/product-selector-form-input.component.mjs +10 -5
  65. package/esm2022/core/shared/dynamic-form-inputs/register-dynamic-input-components.mjs +1 -1
  66. package/esm2022/core/shared/dynamic-form-inputs/relation-form-input/asset/relation-asset-input.component.mjs +14 -15
  67. package/esm2022/core/shared/dynamic-form-inputs/relation-form-input/customer/relation-customer-input.component.mjs +1 -3
  68. package/esm2022/core/shared/dynamic-form-inputs/relation-form-input/product/relation-product-input.component.mjs +3 -3
  69. package/esm2022/core/shared/dynamic-form-inputs/relation-form-input/product-variant/relation-product-variant-input.component.mjs +3 -3
  70. package/esm2022/core/shared/dynamic-form-inputs/relation-form-input/relation-card/relation-card.component.mjs +3 -3
  71. package/esm2022/core/shared/dynamic-form-inputs/relation-form-input/relation-form-input.component.mjs +2 -2
  72. package/esm2022/core/shared/pipes/state-i18n-token.pipe.mjs +1 -1
  73. package/esm2022/core/shared/shared.module.mjs +9 -4
  74. package/esm2022/customer/components/customer-detail/customer-detail.component.mjs +27 -27
  75. package/esm2022/customer/components/customer-list/customer-list.component.mjs +24 -24
  76. package/esm2022/customer/customer.module.mjs +9 -2
  77. package/esm2022/customer/customer.routes.mjs +1 -1
  78. package/esm2022/dashboard/components/dashboard/dashboard.component.mjs +1 -1
  79. package/esm2022/dashboard/default-widgets.mjs +2 -1
  80. package/esm2022/dashboard/widgets/order-chart-widget/order-chart-widget.component.mjs +12 -12
  81. package/esm2022/marketing/marketing.module.mjs +1 -1
  82. package/esm2022/order/components/order-detail/order-detail.component.mjs +8 -8
  83. package/esm2022/order/components/order-list/order-list.component.mjs +9 -2
  84. package/esm2022/order/components/order-table/order-table.component.mjs +3 -3
  85. package/esm2022/order/order.module.mjs +1 -1
  86. package/esm2022/order/order.routes.mjs +1 -1
  87. package/esm2022/settings/components/shipping-method-detail/shipping-method-detail.component.mjs +3 -3
  88. package/esm2022/settings/components/tax-rate-detail/tax-rate-detail.component.mjs +8 -8
  89. package/esm2022/settings/settings.module.mjs +1 -1
  90. package/fesm2022/vendure-admin-ui-catalog.mjs +109 -75
  91. package/fesm2022/vendure-admin-ui-catalog.mjs.map +1 -1
  92. package/fesm2022/vendure-admin-ui-core.mjs +190 -89
  93. package/fesm2022/vendure-admin-ui-core.mjs.map +1 -1
  94. package/fesm2022/vendure-admin-ui-customer.mjs +56 -49
  95. package/fesm2022/vendure-admin-ui-customer.mjs.map +1 -1
  96. package/fesm2022/vendure-admin-ui-dashboard.mjs +12 -11
  97. package/fesm2022/vendure-admin-ui-dashboard.mjs.map +1 -1
  98. package/fesm2022/vendure-admin-ui-marketing.mjs.map +1 -1
  99. package/fesm2022/vendure-admin-ui-order.mjs +17 -10
  100. package/fesm2022/vendure-admin-ui-order.mjs.map +1 -1
  101. package/fesm2022/vendure-admin-ui-settings.mjs +9 -9
  102. package/fesm2022/vendure-admin-ui-settings.mjs.map +1 -1
  103. package/package.json +19 -19
  104. package/static/i18n-messages/cs.json +772 -770
  105. package/static/i18n-messages/de.json +773 -771
  106. package/static/i18n-messages/en.json +773 -771
  107. package/static/i18n-messages/es.json +773 -771
  108. package/static/i18n-messages/fr.json +773 -771
  109. package/static/i18n-messages/it.json +773 -771
  110. package/static/i18n-messages/pl.json +773 -771
  111. package/static/i18n-messages/pt_BR.json +773 -771
  112. package/static/i18n-messages/pt_PT.json +773 -771
  113. package/static/i18n-messages/ru.json +773 -771
  114. package/static/i18n-messages/uk.json +773 -771
  115. package/static/i18n-messages/zh_Hans.json +773 -771
  116. package/static/i18n-messages/zh_Hant.json +773 -771
  117. package/static/styles/global/_buttons.scss +63 -49
  118. package/static/styles/global/_forms.scss +5 -1
  119. package/static/styles/theme/default.scss +2 -0
  120. package/static/theme.min.css +1 -1
  121. package/catalog/components/product-variant-list/product-list-bulk-actions.d.ts +0 -3
  122. package/esm2022/catalog/components/product-variant-list/product-list-bulk-actions.mjs +0 -55
@@ -1,9 +1,10 @@
1
1
  import { TemplatePortal } from '@angular/cdk/portal';
2
- import { ChangeDetectionStrategy, Component, Input, ViewChild, } from '@angular/core';
2
+ import { ChangeDetectionStrategy, Component, HostListener, Input, ViewChild, } from '@angular/core';
3
3
  import * as i0 from "@angular/core";
4
4
  import * as i1 from "@angular/cdk/overlay";
5
5
  import * as i2 from "./dropdown.component";
6
6
  import * as i3 from "@angular/common";
7
+ import * as i4 from "@angular/cdk/a11y";
7
8
  /**
8
9
  * A dropdown menu modelled on the Clarity Dropdown component (https://v1.clarity.design/dropdowns).
9
10
  *
@@ -14,6 +15,32 @@ import * as i3 from "@angular/common";
14
15
  * albeit only a subset which is currently used in this application.
15
16
  */
16
17
  export class DropdownMenuComponent {
18
+ onEscapeKeydown(event) {
19
+ if (this.dropdown.isOpen) {
20
+ if (this.overlayRef.overlayElement.contains(document.activeElement)) {
21
+ this.dropdown.toggleOpen();
22
+ }
23
+ }
24
+ }
25
+ onArrowKey(event) {
26
+ if (this.dropdown.isOpen &&
27
+ document.activeElement instanceof HTMLElement &&
28
+ (event.key === 'ArrowDown' || event.key === 'ArrowUp')) {
29
+ const dropdownItems = Array.from(this.overlayRef.overlayElement.querySelectorAll('.dropdown-item'));
30
+ const currentIndex = dropdownItems.indexOf(document.activeElement);
31
+ if (currentIndex === -1) {
32
+ return;
33
+ }
34
+ if (event.key === 'ArrowDown') {
35
+ const nextItem = dropdownItems[(currentIndex + 1) % dropdownItems.length];
36
+ nextItem.focus();
37
+ }
38
+ if (event.key === 'ArrowUp') {
39
+ const previousItem = dropdownItems[(currentIndex - 1 + dropdownItems.length) % dropdownItems.length];
40
+ previousItem.focus();
41
+ }
42
+ }
43
+ }
17
44
  constructor(overlay, viewContainerRef, dropdown) {
18
45
  this.overlay = overlay;
19
46
  this.viewContainerRef = viewContainerRef;
@@ -93,31 +120,39 @@ export class DropdownMenuComponent {
93
120
  return inverted;
94
121
  }
95
122
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.3", ngImport: i0, type: DropdownMenuComponent, deps: [{ token: i1.Overlay }, { token: i0.ViewContainerRef }, { token: i2.DropdownComponent }], target: i0.ɵɵFactoryTarget.Component }); }
96
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.3", type: DropdownMenuComponent, selector: "vdr-dropdown-menu", inputs: { position: ["vdrPosition", "position"], customClasses: "customClasses" }, viewQueries: [{ propertyName: "menuTemplate", first: true, predicate: ["menu"], descendants: true, static: true }], ngImport: i0, template: `
97
- <ng-template #menu>
98
- <div class="dropdown open">
99
- <div class="dropdown-menu" [ngClass]="customClasses">
100
- <div class="dropdown-content-wrapper">
101
- <ng-content></ng-content>
102
- </div>
103
- </div>
104
- </div>
105
- </ng-template>
106
- `, isInline: true, styles: [".clear-backdrop{background-color:#ff69b4}::ng-deep .dropdown-menu{max-width:initial}::ng-deep .dropdown-menu .dropdown-item{display:flex;align-items:center}::ng-deep .dropdown-menu .dropdown-item clr-icon{margin-right:3px}.dropdown.open>.dropdown-menu{position:relative;top:0;height:100%;overflow-y:auto}:host{opacity:1;transition:opacity .3s}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
123
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.3", type: DropdownMenuComponent, selector: "vdr-dropdown-menu", inputs: { position: ["vdrPosition", "position"], customClasses: "customClasses" }, host: { listeners: { "window:keydown.escape": "onEscapeKeydown($event)", "window:keydown": "onArrowKey($event)" } }, viewQueries: [{ propertyName: "menuTemplate", first: true, predicate: ["menu"], descendants: true, static: true }], ngImport: i0, template: `
124
+ <ng-template #menu>
125
+ <div class="dropdown open">
126
+ <div class="dropdown-menu" [ngClass]="customClasses">
127
+ <div
128
+ class="dropdown-content-wrapper"
129
+ [cdkTrapFocus]="true"
130
+ [cdkTrapFocusAutoCapture]="true"
131
+ >
132
+ <ng-content></ng-content>
133
+ </div>
134
+ </div>
135
+ </div>
136
+ </ng-template>
137
+ `, isInline: true, styles: [".clear-backdrop{background-color:#ff69b4}::ng-deep .dropdown-menu{max-width:initial}::ng-deep .dropdown-menu .dropdown-item{display:flex;align-items:center}::ng-deep .dropdown-menu .dropdown-item clr-icon{margin-right:3px}::ng-deep .dropdown-menu .dropdown-item:focus{outline:var(--color-dropdown-item-focus-outline) solid 1px;outline-offset:1px 0}.dropdown.open>.dropdown-menu{position:relative;top:0;height:100%;overflow-y:auto}:host{opacity:1;transition:opacity .3s}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.CdkTrapFocus, selector: "[cdkTrapFocus]", inputs: ["cdkTrapFocus", "cdkTrapFocusAutoCapture"], exportAs: ["cdkTrapFocus"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
107
138
  }
108
139
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.3", ngImport: i0, type: DropdownMenuComponent, decorators: [{
109
140
  type: Component,
110
- args: [{ selector: 'vdr-dropdown-menu', template: `
111
- <ng-template #menu>
112
- <div class="dropdown open">
113
- <div class="dropdown-menu" [ngClass]="customClasses">
114
- <div class="dropdown-content-wrapper">
115
- <ng-content></ng-content>
116
- </div>
117
- </div>
118
- </div>
119
- </ng-template>
120
- `, changeDetection: ChangeDetectionStrategy.OnPush, styles: [".clear-backdrop{background-color:#ff69b4}::ng-deep .dropdown-menu{max-width:initial}::ng-deep .dropdown-menu .dropdown-item{display:flex;align-items:center}::ng-deep .dropdown-menu .dropdown-item clr-icon{margin-right:3px}.dropdown.open>.dropdown-menu{position:relative;top:0;height:100%;overflow-y:auto}:host{opacity:1;transition:opacity .3s}\n"] }]
141
+ args: [{ selector: 'vdr-dropdown-menu', template: `
142
+ <ng-template #menu>
143
+ <div class="dropdown open">
144
+ <div class="dropdown-menu" [ngClass]="customClasses">
145
+ <div
146
+ class="dropdown-content-wrapper"
147
+ [cdkTrapFocus]="true"
148
+ [cdkTrapFocusAutoCapture]="true"
149
+ >
150
+ <ng-content></ng-content>
151
+ </div>
152
+ </div>
153
+ </div>
154
+ </ng-template>
155
+ `, changeDetection: ChangeDetectionStrategy.OnPush, styles: [".clear-backdrop{background-color:#ff69b4}::ng-deep .dropdown-menu{max-width:initial}::ng-deep .dropdown-menu .dropdown-item{display:flex;align-items:center}::ng-deep .dropdown-menu .dropdown-item clr-icon{margin-right:3px}::ng-deep .dropdown-menu .dropdown-item:focus{outline:var(--color-dropdown-item-focus-outline) solid 1px;outline-offset:1px 0}.dropdown.open>.dropdown-menu{position:relative;top:0;height:100%;overflow-y:auto}:host{opacity:1;transition:opacity .3s}\n"] }]
121
156
  }], ctorParameters: function () { return [{ type: i1.Overlay }, { type: i0.ViewContainerRef }, { type: i2.DropdownComponent }]; }, propDecorators: { position: [{
122
157
  type: Input,
123
158
  args: ['vdrPosition']
@@ -126,5 +161,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.3", ngImpor
126
161
  }], menuTemplate: [{
127
162
  type: ViewChild,
128
163
  args: ['menu', { static: true }]
164
+ }], onEscapeKeydown: [{
165
+ type: HostListener,
166
+ args: ['window:keydown.escape', ['$event']]
167
+ }], onArrowKey: [{
168
+ type: HostListener,
169
+ args: ['window:keydown', ['$event']]
129
170
  }] } });
130
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown-menu.component.js","sourceRoot":"","sources":["../../../../../../src/lib/core/src/shared/components/dropdown/dropdown-menu.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    ConnectedPosition,\r\n    HorizontalConnectionPos,\r\n    Overlay,\r\n    OverlayRef,\r\n    PositionStrategy,\r\n    VerticalConnectionPos,\r\n} from '@angular/cdk/overlay';\r\nimport { TemplatePortal } from '@angular/cdk/portal';\r\nimport {\r\n    AfterViewInit,\r\n    ChangeDetectionStrategy,\r\n    Component,\r\n    ContentChild,\r\n    ElementRef,\r\n    Input,\r\n    OnDestroy,\r\n    OnInit,\r\n    TemplateRef,\r\n    ViewChild,\r\n    ViewContainerRef,\r\n} from '@angular/core';\r\nimport { Subscription } from 'rxjs';\r\n\r\nimport { DropdownTriggerDirective } from './dropdown-trigger.directive';\r\nimport { DropdownComponent } from './dropdown.component';\r\n\r\nexport type DropdownPosition = 'top-left' | 'top-right' | 'bottom-left' | 'bottom-right';\r\n\r\n/**\r\n * A dropdown menu modelled on the Clarity Dropdown component (https://v1.clarity.design/dropdowns).\r\n *\r\n * This was created because the Clarity implementation (at this time) does not handle edge detection. Instead\r\n * we make use of the Angular CDK's Overlay module to manage the positioning.\r\n *\r\n * The API of this component (and its related Components & Directives) are based on the Clarity version,\r\n * albeit only a subset which is currently used in this application.\r\n */\r\n@Component({\r\n    selector: 'vdr-dropdown-menu',\r\n    template: `\r\n        <ng-template #menu>\r\n            <div class=\"dropdown open\">\r\n                <div class=\"dropdown-menu\" [ngClass]=\"customClasses\">\r\n                    <div class=\"dropdown-content-wrapper\">\r\n                        <ng-content></ng-content>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </ng-template>\r\n    `,\r\n    styleUrls: ['./dropdown-menu.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class DropdownMenuComponent implements AfterViewInit, OnInit, OnDestroy {\r\n    @Input('vdrPosition') private position: DropdownPosition = 'bottom-left';\r\n    @Input() customClasses: string;\r\n    @ViewChild('menu', { static: true }) private menuTemplate: TemplateRef<any>;\r\n    private menuPortal: TemplatePortal<any>;\r\n    private overlayRef: OverlayRef;\r\n    private backdropClickSub: Subscription;\r\n\r\n    constructor(\r\n        private overlay: Overlay,\r\n        private viewContainerRef: ViewContainerRef,\r\n        private dropdown: DropdownComponent,\r\n    ) {}\r\n\r\n    ngOnInit(): void {\r\n        this.dropdown.onOpenChange(isOpen => {\r\n            if (isOpen) {\r\n                this.overlayRef.attach(this.menuPortal);\r\n            } else {\r\n                this.overlayRef.detach();\r\n            }\r\n        });\r\n    }\r\n\r\n    ngAfterViewInit() {\r\n        this.overlayRef = this.overlay.create({\r\n            hasBackdrop: true,\r\n            backdropClass: 'clear-backdrop',\r\n            positionStrategy: this.getPositionStrategy(),\r\n            maxHeight: '70vh',\r\n        });\r\n        this.menuPortal = new TemplatePortal(this.menuTemplate, this.viewContainerRef);\r\n        this.backdropClickSub = this.overlayRef.backdropClick().subscribe(() => {\r\n            this.dropdown.toggleOpen();\r\n        });\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        if (this.overlayRef) {\r\n            this.overlayRef.dispose();\r\n        }\r\n        if (this.backdropClickSub) {\r\n            this.backdropClickSub.unsubscribe();\r\n        }\r\n    }\r\n\r\n    private getPositionStrategy(): PositionStrategy {\r\n        const position: { [K in DropdownPosition]: ConnectedPosition } = {\r\n            ['top-left']: {\r\n                originX: 'start',\r\n                originY: 'top',\r\n                overlayX: 'start',\r\n                overlayY: 'bottom',\r\n            },\r\n            ['top-right']: {\r\n                originX: 'end',\r\n                originY: 'top',\r\n                overlayX: 'end',\r\n                overlayY: 'bottom',\r\n            },\r\n            ['bottom-left']: {\r\n                originX: 'start',\r\n                originY: 'bottom',\r\n                overlayX: 'start',\r\n                overlayY: 'top',\r\n            },\r\n            ['bottom-right']: {\r\n                originX: 'end',\r\n                originY: 'bottom',\r\n                overlayX: 'end',\r\n                overlayY: 'top',\r\n            },\r\n        };\r\n\r\n        const pos = position[this.position];\r\n\r\n        return this.overlay\r\n            .position()\r\n            .flexibleConnectedTo(this.dropdown.trigger)\r\n            .withPositions([pos, this.invertPosition(pos)])\r\n            .withViewportMargin(12)\r\n            .withPush(true);\r\n    }\r\n\r\n    /** Inverts an overlay position. */\r\n    private invertPosition(pos: ConnectedPosition): ConnectedPosition {\r\n        const inverted = { ...pos };\r\n        inverted.originY = pos.originY === 'top' ? 'bottom' : 'top';\r\n        inverted.overlayY = pos.overlayY === 'top' ? 'bottom' : 'top';\r\n\r\n        return inverted;\r\n    }\r\n}\r\n"]}
171
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown-menu.component.js","sourceRoot":"","sources":["../../../../../../src/lib/core/src/shared/components/dropdown/dropdown-menu.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ConnectedPosition,\n    HorizontalConnectionPos,\n    Overlay,\n    OverlayRef,\n    PositionStrategy,\n    VerticalConnectionPos,\n} from '@angular/cdk/overlay';\nimport { TemplatePortal } from '@angular/cdk/portal';\nimport {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    Component,\n    ContentChild,\n    ElementRef,\n    HostListener,\n    Input,\n    OnDestroy,\n    OnInit,\n    TemplateRef,\n    ViewChild,\n    ViewContainerRef,\n} from '@angular/core';\nimport { Subscription } from 'rxjs';\n\nimport { DropdownTriggerDirective } from './dropdown-trigger.directive';\nimport { DropdownComponent } from './dropdown.component';\n\nexport type DropdownPosition = 'top-left' | 'top-right' | 'bottom-left' | 'bottom-right';\n\n/**\n * A dropdown menu modelled on the Clarity Dropdown component (https://v1.clarity.design/dropdowns).\n *\n * This was created because the Clarity implementation (at this time) does not handle edge detection. Instead\n * we make use of the Angular CDK's Overlay module to manage the positioning.\n *\n * The API of this component (and its related Components & Directives) are based on the Clarity version,\n * albeit only a subset which is currently used in this application.\n */\n@Component({\n    selector: 'vdr-dropdown-menu',\n    template: `\n        <ng-template #menu>\n            <div class=\"dropdown open\">\n                <div class=\"dropdown-menu\" [ngClass]=\"customClasses\">\n                    <div\n                        class=\"dropdown-content-wrapper\"\n                        [cdkTrapFocus]=\"true\"\n                        [cdkTrapFocusAutoCapture]=\"true\"\n                    >\n                        <ng-content></ng-content>\n                    </div>\n                </div>\n            </div>\n        </ng-template>\n    `,\n    styleUrls: ['./dropdown-menu.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DropdownMenuComponent implements AfterViewInit, OnInit, OnDestroy {\n    @Input('vdrPosition') private position: DropdownPosition = 'bottom-left';\n    @Input() customClasses: string;\n    @ViewChild('menu', { static: true }) private menuTemplate: TemplateRef<any>;\n    private menuPortal: TemplatePortal;\n    private overlayRef: OverlayRef;\n    private backdropClickSub: Subscription;\n\n    @HostListener('window:keydown.escape', ['$event'])\n    onEscapeKeydown(event: KeyboardEvent) {\n        if (this.dropdown.isOpen) {\n            if (this.overlayRef.overlayElement.contains(document.activeElement)) {\n                this.dropdown.toggleOpen();\n            }\n        }\n    }\n\n    @HostListener('window:keydown', ['$event'])\n    onArrowKey(event: KeyboardEvent) {\n        if (\n            this.dropdown.isOpen &&\n            document.activeElement instanceof HTMLElement &&\n            (event.key === 'ArrowDown' || event.key === 'ArrowUp')\n        ) {\n            const dropdownItems = Array.from(\n                this.overlayRef.overlayElement.querySelectorAll<HTMLElement>('.dropdown-item'),\n            );\n            const currentIndex = dropdownItems.indexOf(document.activeElement);\n            if (currentIndex === -1) {\n                return;\n            }\n            if (event.key === 'ArrowDown') {\n                const nextItem = dropdownItems[(currentIndex + 1) % dropdownItems.length];\n                nextItem.focus();\n            }\n            if (event.key === 'ArrowUp') {\n                const previousItem =\n                    dropdownItems[(currentIndex - 1 + dropdownItems.length) % dropdownItems.length];\n                previousItem.focus();\n            }\n        }\n    }\n\n    constructor(\n        private overlay: Overlay,\n        private viewContainerRef: ViewContainerRef,\n        private dropdown: DropdownComponent,\n    ) {}\n\n    ngOnInit(): void {\n        this.dropdown.onOpenChange(isOpen => {\n            if (isOpen) {\n                this.overlayRef.attach(this.menuPortal);\n            } else {\n                this.overlayRef.detach();\n            }\n        });\n    }\n\n    ngAfterViewInit() {\n        this.overlayRef = this.overlay.create({\n            hasBackdrop: true,\n            backdropClass: 'clear-backdrop',\n            positionStrategy: this.getPositionStrategy(),\n            maxHeight: '70vh',\n        });\n        this.menuPortal = new TemplatePortal(this.menuTemplate, this.viewContainerRef);\n        this.backdropClickSub = this.overlayRef.backdropClick().subscribe(() => {\n            this.dropdown.toggleOpen();\n        });\n    }\n\n    ngOnDestroy(): void {\n        if (this.overlayRef) {\n            this.overlayRef.dispose();\n        }\n        if (this.backdropClickSub) {\n            this.backdropClickSub.unsubscribe();\n        }\n    }\n\n    private getPositionStrategy(): PositionStrategy {\n        const position: { [K in DropdownPosition]: ConnectedPosition } = {\n            ['top-left']: {\n                originX: 'start',\n                originY: 'top',\n                overlayX: 'start',\n                overlayY: 'bottom',\n            },\n            ['top-right']: {\n                originX: 'end',\n                originY: 'top',\n                overlayX: 'end',\n                overlayY: 'bottom',\n            },\n            ['bottom-left']: {\n                originX: 'start',\n                originY: 'bottom',\n                overlayX: 'start',\n                overlayY: 'top',\n            },\n            ['bottom-right']: {\n                originX: 'end',\n                originY: 'bottom',\n                overlayX: 'end',\n                overlayY: 'top',\n            },\n        };\n\n        const pos = position[this.position];\n\n        return this.overlay\n            .position()\n            .flexibleConnectedTo(this.dropdown.trigger)\n            .withPositions([pos, this.invertPosition(pos)])\n            .withViewportMargin(12)\n            .withPush(true);\n    }\n\n    /** Inverts an overlay position. */\n    private invertPosition(pos: ConnectedPosition): ConnectedPosition {\n        const inverted = { ...pos };\n        inverted.originY = pos.originY === 'top' ? 'bottom' : 'top';\n        inverted.overlayY = pos.overlayY === 'top' ? 'bottom' : 'top';\n\n        return inverted;\n    }\n}\n"]}
@@ -55,4 +55,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.3", ngImpor
55
55
  }], propDecorators: { manualToggle: [{
56
56
  type: Input
57
57
  }] } });
58
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL2xpYi9jb3JlL3NyYy9zaGFyZWQvY29tcG9uZW50cy9kcm9wZG93bi9kcm9wZG93bi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvcmUvc3JjL3NoYXJlZC9jb21wb25lbnRzL2Ryb3Bkb3duL2Ryb3Bkb3duLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQWMsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUV0Rjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBd0JHO0FBT0gsTUFBTSxPQUFPLGlCQUFpQjtJQU45QjtRQU9ZLFdBQU0sR0FBRyxLQUFLLENBQUM7UUFDZiwwQkFBcUIsR0FBcUMsRUFBRSxDQUFDO1FBRTVELGlCQUFZLEdBQUcsS0FBSyxDQUFDO0tBb0JqQztJQWxCRyxPQUFPO1FBQ0gsSUFBSSxDQUFDLElBQUksQ0FBQyxZQUFZLEVBQUU7WUFDcEIsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO1NBQ3JCO0lBQ0wsQ0FBQztJQUVELFVBQVU7UUFDTixJQUFJLENBQUMsTUFBTSxHQUFHLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQztRQUMzQixJQUFJLENBQUMscUJBQXFCLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDO0lBQzlELENBQUM7SUFFRCxZQUFZLENBQUMsUUFBbUM7UUFDNUMsSUFBSSxDQUFDLHFCQUFxQixDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQztJQUM5QyxDQUFDO0lBRUQsaUJBQWlCLENBQUMsVUFBc0I7UUFDcEMsSUFBSSxDQUFDLE9BQU8sR0FBRyxVQUFVLENBQUM7SUFDOUIsQ0FBQzs4R0F2QlEsaUJBQWlCO2tHQUFqQixpQkFBaUIsOEZDakM5QiwrQkFDQTs7MkZEZ0NhLGlCQUFpQjtrQkFON0IsU0FBUzsrQkFDSSxjQUFjLG1CQUdQLHVCQUF1QixDQUFDLE1BQU07OEJBTXRDLFlBQVk7c0JBQXBCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBFbGVtZW50UmVmLCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG4vKipcbiAqIEBkZXNjcmlwdGlvblxuICogVXNlZCBmb3IgYnVpbGRpbmcgZHJvcGRvd24gbWVudXMuXG4gKlxuICogQGV4YW1wbGVcbiAqIGBgYEhUTUxcbiAqIDx2ZHItZHJvcGRvd24+XG4gKiAgIDxidXR0b24gY2xhc3M9XCJidG4gYnRuLW91dGxpbmVcIiB2ZHJEcm9wZG93blRyaWdnZXI+XG4gKiAgICAgICA8Y2xyLWljb24gc2hhcGU9XCJwbHVzXCI+PC9jbHItaWNvbj5cbiAqICAgICAgIFNlbGVjdCB0eXBlXG4gKiAgIDwvYnV0dG9uPlxuICogICA8dmRyLWRyb3Bkb3duLW1lbnUgdmRyUG9zaXRpb249XCJib3R0b20tbGVmdFwiPlxuICogICAgIDxidXR0b25cbiAqICAgICAgICpuZ0Zvcj1cImxldCB0eXBlTmFtZSBvZiBhbGxUeXBlc1wiXG4gKiAgICAgICB0eXBlPVwiYnV0dG9uXCJcbiAqICAgICAgIHZkckRyb3Bkb3duSXRlbVxuICogICAgICAgKGNsaWNrKT1cInNlbGVjdFR5cGUodHlwZU5hbWUpXCJcbiAqICAgICA+XG4gKiAgICAgICB0eXBlTmFtZVxuICogICAgIDwvYnV0dG9uPlxuICogICA8L3Zkci1kcm9wZG93bi1tZW51PlxuICogPC92ZHItZHJvcGRvd24+XG4gKiBgYGBcbiAqIEBkb2NzQ2F0ZWdvcnkgY29tcG9uZW50c1xuICovXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ3Zkci1kcm9wZG93bicsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2Ryb3Bkb3duLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9kcm9wZG93bi5jb21wb25lbnQuc2NzcyddLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBEcm9wZG93bkNvbXBvbmVudCB7XG4gICAgcHJpdmF0ZSBpc09wZW4gPSBmYWxzZTtcbiAgICBwcml2YXRlIG9uT3BlbkNoYW5nZUNhbGxiYWNrczogQXJyYXk8KGlzT3BlbjogYm9vbGVhbikgPT4gdm9pZD4gPSBbXTtcbiAgICBwdWJsaWMgdHJpZ2dlcjogRWxlbWVudFJlZjtcbiAgICBASW5wdXQoKSBtYW51YWxUb2dnbGUgPSBmYWxzZTtcblxuICAgIG9uQ2xpY2soKSB7XG4gICAgICAgIGlmICghdGhpcy5tYW51YWxUb2dnbGUpIHtcbiAgICAgICAgICAgIHRoaXMudG9nZ2xlT3BlbigpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgdG9nZ2xlT3BlbigpIHtcbiAgICAgICAgdGhpcy5pc09wZW4gPSAhdGhpcy5pc09wZW47XG4gICAgICAgIHRoaXMub25PcGVuQ2hhbmdlQ2FsbGJhY2tzLmZvckVhY2goZm4gPT4gZm4odGhpcy5pc09wZW4pKTtcbiAgICB9XG5cbiAgICBvbk9wZW5DaGFuZ2UoY2FsbGJhY2s6IChpc09wZW46IGJvb2xlYW4pID0+IHZvaWQpIHtcbiAgICAgICAgdGhpcy5vbk9wZW5DaGFuZ2VDYWxsYmFja3MucHVzaChjYWxsYmFjayk7XG4gICAgfVxuXG4gICAgc2V0VHJpZ2dlckVsZW1lbnQoZWxlbWVudFJlZjogRWxlbWVudFJlZikge1xuICAgICAgICB0aGlzLnRyaWdnZXIgPSBlbGVtZW50UmVmO1xuICAgIH1cbn1cbiIsIjxuZy1jb250ZW50PjwvbmctY29udGVudD5cclxuIl19
58
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL2xpYi9jb3JlL3NyYy9zaGFyZWQvY29tcG9uZW50cy9kcm9wZG93bi9kcm9wZG93bi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvcmUvc3JjL3NoYXJlZC9jb21wb25lbnRzL2Ryb3Bkb3duL2Ryb3Bkb3duLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQWMsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUV0Rjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBd0JHO0FBT0gsTUFBTSxPQUFPLGlCQUFpQjtJQU45QjtRQU9JLFdBQU0sR0FBRyxLQUFLLENBQUM7UUFDUCwwQkFBcUIsR0FBcUMsRUFBRSxDQUFDO1FBRTVELGlCQUFZLEdBQUcsS0FBSyxDQUFDO0tBb0JqQztJQWxCRyxPQUFPO1FBQ0gsSUFBSSxDQUFDLElBQUksQ0FBQyxZQUFZLEVBQUU7WUFDcEIsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO1NBQ3JCO0lBQ0wsQ0FBQztJQUVELFVBQVU7UUFDTixJQUFJLENBQUMsTUFBTSxHQUFHLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQztRQUMzQixJQUFJLENBQUMscUJBQXFCLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDO0lBQzlELENBQUM7SUFFRCxZQUFZLENBQUMsUUFBbUM7UUFDNUMsSUFBSSxDQUFDLHFCQUFxQixDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQztJQUM5QyxDQUFDO0lBRUQsaUJBQWlCLENBQUMsVUFBc0I7UUFDcEMsSUFBSSxDQUFDLE9BQU8sR0FBRyxVQUFVLENBQUM7SUFDOUIsQ0FBQzs4R0F2QlEsaUJBQWlCO2tHQUFqQixpQkFBaUIsOEZDakM5QiwrQkFDQTs7MkZEZ0NhLGlCQUFpQjtrQkFON0IsU0FBUzsrQkFDSSxjQUFjLG1CQUdQLHVCQUF1QixDQUFDLE1BQU07OEJBTXRDLFlBQVk7c0JBQXBCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBFbGVtZW50UmVmLCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG4vKipcbiAqIEBkZXNjcmlwdGlvblxuICogVXNlZCBmb3IgYnVpbGRpbmcgZHJvcGRvd24gbWVudXMuXG4gKlxuICogQGV4YW1wbGVcbiAqIGBgYEhUTUxcbiAqIDx2ZHItZHJvcGRvd24+XG4gKiAgIDxidXR0b24gY2xhc3M9XCJidG4gYnRuLW91dGxpbmVcIiB2ZHJEcm9wZG93blRyaWdnZXI+XG4gKiAgICAgICA8Y2xyLWljb24gc2hhcGU9XCJwbHVzXCI+PC9jbHItaWNvbj5cbiAqICAgICAgIFNlbGVjdCB0eXBlXG4gKiAgIDwvYnV0dG9uPlxuICogICA8dmRyLWRyb3Bkb3duLW1lbnUgdmRyUG9zaXRpb249XCJib3R0b20tbGVmdFwiPlxuICogICAgIDxidXR0b25cbiAqICAgICAgICpuZ0Zvcj1cImxldCB0eXBlTmFtZSBvZiBhbGxUeXBlc1wiXG4gKiAgICAgICB0eXBlPVwiYnV0dG9uXCJcbiAqICAgICAgIHZkckRyb3Bkb3duSXRlbVxuICogICAgICAgKGNsaWNrKT1cInNlbGVjdFR5cGUodHlwZU5hbWUpXCJcbiAqICAgICA+XG4gKiAgICAgICB0eXBlTmFtZVxuICogICAgIDwvYnV0dG9uPlxuICogICA8L3Zkci1kcm9wZG93bi1tZW51PlxuICogPC92ZHItZHJvcGRvd24+XG4gKiBgYGBcbiAqIEBkb2NzQ2F0ZWdvcnkgY29tcG9uZW50c1xuICovXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ3Zkci1kcm9wZG93bicsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2Ryb3Bkb3duLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9kcm9wZG93bi5jb21wb25lbnQuc2NzcyddLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBEcm9wZG93bkNvbXBvbmVudCB7XG4gICAgaXNPcGVuID0gZmFsc2U7XG4gICAgcHJpdmF0ZSBvbk9wZW5DaGFuZ2VDYWxsYmFja3M6IEFycmF5PChpc09wZW46IGJvb2xlYW4pID0+IHZvaWQ+ID0gW107XG4gICAgcHVibGljIHRyaWdnZXI6IEVsZW1lbnRSZWY7XG4gICAgQElucHV0KCkgbWFudWFsVG9nZ2xlID0gZmFsc2U7XG5cbiAgICBvbkNsaWNrKCkge1xuICAgICAgICBpZiAoIXRoaXMubWFudWFsVG9nZ2xlKSB7XG4gICAgICAgICAgICB0aGlzLnRvZ2dsZU9wZW4oKTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIHRvZ2dsZU9wZW4oKSB7XG4gICAgICAgIHRoaXMuaXNPcGVuID0gIXRoaXMuaXNPcGVuO1xuICAgICAgICB0aGlzLm9uT3BlbkNoYW5nZUNhbGxiYWNrcy5mb3JFYWNoKGZuID0+IGZuKHRoaXMuaXNPcGVuKSk7XG4gICAgfVxuXG4gICAgb25PcGVuQ2hhbmdlKGNhbGxiYWNrOiAoaXNPcGVuOiBib29sZWFuKSA9PiB2b2lkKSB7XG4gICAgICAgIHRoaXMub25PcGVuQ2hhbmdlQ2FsbGJhY2tzLnB1c2goY2FsbGJhY2spO1xuICAgIH1cblxuICAgIHNldFRyaWdnZXJFbGVtZW50KGVsZW1lbnRSZWY6IEVsZW1lbnRSZWYpIHtcbiAgICAgICAgdGhpcy50cmlnZ2VyID0gZWxlbWVudFJlZjtcbiAgICB9XG59XG4iLCI8bmctY29udGVudD48L25nLWNvbnRlbnQ+XHJcbiJdfQ==
@@ -54,7 +54,7 @@ export class FacetValueSelectorComponent {
54
54
  return of([]);
55
55
  }
56
56
  return this.dataService.facet
57
- .getFacetValues({ take: 10, filter: { name: { contains: term } } })
57
+ .getFacetValues({ take: 100, filter: { name: { contains: term } } })
58
58
  .mapSingle(result => result.facetValues.items);
59
59
  }), tap(() => (this.searchLoading = false)));
60
60
  this.subscription = this.selectedIds$
@@ -63,7 +63,7 @@ export class FacetValueSelectorComponent {
63
63
  return of([]);
64
64
  }
65
65
  return this.dataService.facet
66
- .getFacetValues({ take: 10, filter: { id: { in: ids } } }, 'cache-first')
66
+ .getFacetValues({ take: 100, filter: { id: { in: ids } } }, 'cache-first')
67
67
  .mapSingle(result => result.facetValues.items);
68
68
  }))
69
69
  .subscribe(val => {
@@ -152,4 +152,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.3", ngImpor
152
152
  type: ViewChild,
153
153
  args: [NgSelectComponent]
154
154
  }] } });
155
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"facet-value-selector.component.js","sourceRoot":"","sources":["../../../../../../src/lib/core/src/shared/components/facet-value-selector/facet-value-selector.component.ts","../../../../../../src/lib/core/src/shared/components/facet-value-selector/facet-value-selector.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    ChangeDetectionStrategy,\r\n    ChangeDetectorRef,\r\n    Component,\r\n    EventEmitter,\r\n    Input,\r\n    OnDestroy,\r\n    OnInit,\r\n    Output,\r\n    ViewChild,\r\n} from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { NgSelectComponent } from '@ng-select/ng-select';\r\nimport { concat, merge, Observable, of, Subject, Subscription } from 'rxjs';\r\nimport { debounceTime, distinctUntilChanged, mapTo, switchMap, tap } from 'rxjs/operators';\r\n\r\nimport { FacetValue, FacetValueFragment } from '../../../common/generated-types';\r\nimport { DataService } from '../../../data/providers/data.service';\r\n\r\n/**\r\n * @description\r\n * A form control for selecting facet values.\r\n *\r\n * @example\r\n * ```HTML\r\n * <vdr-facet-value-selector\r\n *   [facets]=\"facets\"\r\n *   (selectedValuesChange)=\"selectedValues = $event\"\r\n * ></vdr-facet-value-selector>\r\n * ```\r\n * The `facets` input should be provided from the parent component\r\n * like this:\r\n *\r\n * @example\r\n * ```TypeScript\r\n * this.facets = this.dataService\r\n *   .facet.getAllFacets()\r\n *   .mapSingle(data => data.facets.items);\r\n * ```\r\n * @docsCategory components\r\n */\r\n@Component({\r\n    selector: 'vdr-facet-value-selector',\r\n    templateUrl: './facet-value-selector.component.html',\r\n    styleUrls: ['./facet-value-selector.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    providers: [\r\n        {\r\n            provide: NG_VALUE_ACCESSOR,\r\n            useExisting: FacetValueSelectorComponent,\r\n            multi: true,\r\n        },\r\n    ],\r\n})\r\nexport class FacetValueSelectorComponent implements OnInit, OnDestroy, ControlValueAccessor {\r\n    @Output() selectedValuesChange = new EventEmitter<FacetValueFragment[]>();\r\n    @Input() readonly = false;\r\n    @Input() transformControlValueAccessorValue: (value: FacetValueFragment[]) => any[] = value => value;\r\n    searchInput$ = new Subject<string>();\r\n    searchLoading = false;\r\n    searchResults$: Observable<FacetValueFragment[]>;\r\n    selectedIds$ = new Subject<string[]>();\r\n\r\n    @ViewChild(NgSelectComponent) private ngSelect: NgSelectComponent;\r\n\r\n    onChangeFn: (val: any) => void;\r\n    onTouchFn: () => void;\r\n    disabled = false;\r\n    value: Array<string | FacetValueFragment>;\r\n    private subscription: Subscription;\r\n    constructor(private dataService: DataService, private changeDetectorRef: ChangeDetectorRef) {}\r\n\r\n    ngOnInit(): void {\r\n        this.initSearchResults();\r\n    }\r\n\r\n    private initSearchResults() {\r\n        const searchItems$ = this.searchInput$.pipe(\r\n            debounceTime(200),\r\n            distinctUntilChanged(),\r\n            tap(() => (this.searchLoading = true)),\r\n            switchMap(term => {\r\n                if (!term) {\r\n                    return of([]);\r\n                }\r\n                return this.dataService.facet\r\n                    .getFacetValues({ take: 10, filter: { name: { contains: term } } })\r\n                    .mapSingle(result => result.facetValues.items);\r\n            }),\r\n            tap(() => (this.searchLoading = false)),\r\n        );\r\n        this.subscription = this.selectedIds$\r\n            .pipe(\r\n                switchMap(ids => {\r\n                    if (!ids.length) {\r\n                        return of([]);\r\n                    }\r\n                    return this.dataService.facet\r\n                        .getFacetValues({ take: 10, filter: { id: { in: ids } } }, 'cache-first')\r\n                        .mapSingle(result => result.facetValues.items);\r\n                }),\r\n            )\r\n            .subscribe(val => {\r\n                this.value = val;\r\n                this.changeDetectorRef.markForCheck();\r\n            });\r\n\r\n        const clear$ = this.selectedValuesChange.pipe(mapTo([]));\r\n        this.searchResults$ = concat(of([]), merge(searchItems$, clear$));\r\n    }\r\n    ngOnDestroy() {\r\n        this.subscription?.unsubscribe();\r\n    }\r\n\r\n    onChange(selected: FacetValueFragment[]) {\r\n        if (this.readonly) {\r\n            return;\r\n        }\r\n        this.selectedValuesChange.emit(selected);\r\n        if (this.onChangeFn) {\r\n            const transformedValue = this.transformControlValueAccessorValue(selected);\r\n            this.onChangeFn(transformedValue);\r\n        }\r\n    }\r\n\r\n    registerOnChange(fn: any) {\r\n        this.onChangeFn = fn;\r\n    }\r\n\r\n    registerOnTouched(fn: any) {\r\n        this.onTouchFn = fn;\r\n    }\r\n\r\n    setDisabledState(isDisabled: boolean): void {\r\n        this.disabled = isDisabled;\r\n    }\r\n\r\n    focus() {\r\n        this.ngSelect.focus();\r\n    }\r\n\r\n    writeValue(obj: string | FacetValueFragment[] | Array<string | number> | null): void {\r\n        let valueIds: string[] | undefined;\r\n        if (typeof obj === 'string') {\r\n            try {\r\n                const facetValueIds = JSON.parse(obj) as string[];\r\n                valueIds = facetValueIds;\r\n            } catch (err) {\r\n                // TODO: log error\r\n                throw err;\r\n            }\r\n        } else if (Array.isArray(obj)) {\r\n            const isIdArray = (input: unknown[]): input is Array<string | number> =>\r\n                input.every(i => typeof i === 'number' || typeof i === 'string');\r\n            if (isIdArray(obj)) {\r\n                valueIds = obj.map(fv => fv.toString());\r\n            } else {\r\n                valueIds = obj.map(fv => fv.id);\r\n            }\r\n        }\r\n        if (valueIds) {\r\n            // this.value = valueIds;\r\n            this.selectedIds$.next(valueIds);\r\n        }\r\n    }\r\n}\r\n","<ng-select\r\n    [items]=\"searchResults$ | async\"\r\n    [addTag]=\"false\"\r\n    [hideSelected]=\"true\"\r\n    [loading]=\"searchLoading\"\r\n    [typeahead]=\"searchInput$\"\r\n    multiple=\"true\"\r\n    appendTo=\"body\"\r\n    bindLabel=\"name\"\r\n    [disabled]=\"disabled || readonly\"\r\n    [ngModel]=\"value\"\r\n    (change)=\"onChange($event)\"\r\n>\r\n    <ng-template ng-label-tmp let-item=\"item\" let-clear=\"clear\">\r\n        <vdr-facet-value-chip\r\n            *ngIf=\"item; else facetNotFound\"\r\n            [facetValue]=\"item\"\r\n            [removable]=\"!readonly\"\r\n            (remove)=\"clear(item)\"\r\n        ></vdr-facet-value-chip>\r\n        <ng-template #facetNotFound>\r\n            <vdr-chip colorType=\"error\" icon=\"times\" (iconClick)=\"clear(item)\">{{\r\n                'catalog.facet-value-not-available' | translate: { id: item.id }\r\n            }}</vdr-chip>\r\n        </ng-template>\r\n    </ng-template>\r\n    <ng-template ng-option-tmp let-item=\"item\">\r\n        <vdr-facet-value-chip [facetValue]=\"item\" [removable]=\"false\"></vdr-facet-value-chip>\r\n    </ng-template>\r\n</ng-select>\r\n"]}
155
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"facet-value-selector.component.js","sourceRoot":"","sources":["../../../../../../src/lib/core/src/shared/components/facet-value-selector/facet-value-selector.component.ts","../../../../../../src/lib/core/src/shared/components/facet-value-selector/facet-value-selector.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    ChangeDetectionStrategy,\r\n    ChangeDetectorRef,\r\n    Component,\r\n    EventEmitter,\r\n    Input,\r\n    OnDestroy,\r\n    OnInit,\r\n    Output,\r\n    ViewChild,\r\n} from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { NgSelectComponent } from '@ng-select/ng-select';\r\nimport { concat, merge, Observable, of, Subject, Subscription } from 'rxjs';\r\nimport { debounceTime, distinctUntilChanged, mapTo, switchMap, tap } from 'rxjs/operators';\r\n\r\nimport { FacetValue, FacetValueFragment } from '../../../common/generated-types';\r\nimport { DataService } from '../../../data/providers/data.service';\r\n\r\n/**\r\n * @description\r\n * A form control for selecting facet values.\r\n *\r\n * @example\r\n * ```HTML\r\n * <vdr-facet-value-selector\r\n *   [facets]=\"facets\"\r\n *   (selectedValuesChange)=\"selectedValues = $event\"\r\n * ></vdr-facet-value-selector>\r\n * ```\r\n * The `facets` input should be provided from the parent component\r\n * like this:\r\n *\r\n * @example\r\n * ```TypeScript\r\n * this.facets = this.dataService\r\n *   .facet.getAllFacets()\r\n *   .mapSingle(data => data.facets.items);\r\n * ```\r\n * @docsCategory components\r\n */\r\n@Component({\r\n    selector: 'vdr-facet-value-selector',\r\n    templateUrl: './facet-value-selector.component.html',\r\n    styleUrls: ['./facet-value-selector.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    providers: [\r\n        {\r\n            provide: NG_VALUE_ACCESSOR,\r\n            useExisting: FacetValueSelectorComponent,\r\n            multi: true,\r\n        },\r\n    ],\r\n})\r\nexport class FacetValueSelectorComponent implements OnInit, OnDestroy, ControlValueAccessor {\r\n    @Output() selectedValuesChange = new EventEmitter<FacetValueFragment[]>();\r\n    @Input() readonly = false;\r\n    @Input() transformControlValueAccessorValue: (value: FacetValueFragment[]) => any[] = value => value;\r\n    searchInput$ = new Subject<string>();\r\n    searchLoading = false;\r\n    searchResults$: Observable<FacetValueFragment[]>;\r\n    selectedIds$ = new Subject<string[]>();\r\n\r\n    @ViewChild(NgSelectComponent) private ngSelect: NgSelectComponent;\r\n\r\n    onChangeFn: (val: any) => void;\r\n    onTouchFn: () => void;\r\n    disabled = false;\r\n    value: Array<string | FacetValueFragment>;\r\n    private subscription: Subscription;\r\n    constructor(private dataService: DataService, private changeDetectorRef: ChangeDetectorRef) {}\r\n\r\n    ngOnInit(): void {\r\n        this.initSearchResults();\r\n    }\r\n\r\n    private initSearchResults() {\r\n        const searchItems$ = this.searchInput$.pipe(\r\n            debounceTime(200),\r\n            distinctUntilChanged(),\r\n            tap(() => (this.searchLoading = true)),\r\n            switchMap(term => {\r\n                if (!term) {\r\n                    return of([]);\r\n                }\r\n                return this.dataService.facet\r\n                    .getFacetValues({ take: 100, filter: { name: { contains: term } } })\r\n                    .mapSingle(result => result.facetValues.items);\r\n            }),\r\n            tap(() => (this.searchLoading = false)),\r\n        );\r\n        this.subscription = this.selectedIds$\r\n            .pipe(\r\n                switchMap(ids => {\r\n                    if (!ids.length) {\r\n                        return of([]);\r\n                    }\r\n                    return this.dataService.facet\r\n                        .getFacetValues({ take: 100, filter: { id: { in: ids } } }, 'cache-first')\r\n                        .mapSingle(result => result.facetValues.items);\r\n                }),\r\n            )\r\n            .subscribe(val => {\r\n                this.value = val;\r\n                this.changeDetectorRef.markForCheck();\r\n            });\r\n\r\n        const clear$ = this.selectedValuesChange.pipe(mapTo([]));\r\n        this.searchResults$ = concat(of([]), merge(searchItems$, clear$));\r\n    }\r\n    ngOnDestroy() {\r\n        this.subscription?.unsubscribe();\r\n    }\r\n\r\n    onChange(selected: FacetValueFragment[]) {\r\n        if (this.readonly) {\r\n            return;\r\n        }\r\n        this.selectedValuesChange.emit(selected);\r\n        if (this.onChangeFn) {\r\n            const transformedValue = this.transformControlValueAccessorValue(selected);\r\n            this.onChangeFn(transformedValue);\r\n        }\r\n    }\r\n\r\n    registerOnChange(fn: any) {\r\n        this.onChangeFn = fn;\r\n    }\r\n\r\n    registerOnTouched(fn: any) {\r\n        this.onTouchFn = fn;\r\n    }\r\n\r\n    setDisabledState(isDisabled: boolean): void {\r\n        this.disabled = isDisabled;\r\n    }\r\n\r\n    focus() {\r\n        this.ngSelect.focus();\r\n    }\r\n\r\n    writeValue(obj: string | FacetValueFragment[] | Array<string | number> | null): void {\r\n        let valueIds: string[] | undefined;\r\n        if (typeof obj === 'string') {\r\n            try {\r\n                const facetValueIds = JSON.parse(obj) as string[];\r\n                valueIds = facetValueIds;\r\n            } catch (err) {\r\n                // TODO: log error\r\n                throw err;\r\n            }\r\n        } else if (Array.isArray(obj)) {\r\n            const isIdArray = (input: unknown[]): input is Array<string | number> =>\r\n                input.every(i => typeof i === 'number' || typeof i === 'string');\r\n            if (isIdArray(obj)) {\r\n                valueIds = obj.map(fv => fv.toString());\r\n            } else {\r\n                valueIds = obj.map(fv => fv.id);\r\n            }\r\n        }\r\n        if (valueIds) {\r\n            // this.value = valueIds;\r\n            this.selectedIds$.next(valueIds);\r\n        }\r\n    }\r\n}\r\n","<ng-select\r\n    [items]=\"searchResults$ | async\"\r\n    [addTag]=\"false\"\r\n    [hideSelected]=\"true\"\r\n    [loading]=\"searchLoading\"\r\n    [typeahead]=\"searchInput$\"\r\n    multiple=\"true\"\r\n    appendTo=\"body\"\r\n    bindLabel=\"name\"\r\n    [disabled]=\"disabled || readonly\"\r\n    [ngModel]=\"value\"\r\n    (change)=\"onChange($event)\"\r\n>\r\n    <ng-template ng-label-tmp let-item=\"item\" let-clear=\"clear\">\r\n        <vdr-facet-value-chip\r\n            *ngIf=\"item; else facetNotFound\"\r\n            [facetValue]=\"item\"\r\n            [removable]=\"!readonly\"\r\n            (remove)=\"clear(item)\"\r\n        ></vdr-facet-value-chip>\r\n        <ng-template #facetNotFound>\r\n            <vdr-chip colorType=\"error\" icon=\"times\" (iconClick)=\"clear(item)\">{{\r\n                'catalog.facet-value-not-available' | translate: { id: item.id }\r\n            }}</vdr-chip>\r\n        </ng-template>\r\n    </ng-template>\r\n    <ng-template ng-option-tmp let-item=\"item\">\r\n        <vdr-facet-value-chip [facetValue]=\"item\" [removable]=\"false\"></vdr-facet-value-chip>\r\n    </ng-template>\r\n</ng-select>\r\n"]}
@@ -69,4 +69,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.3", ngImpor
69
69
  }], ctorParameters: function () { return [{ type: i1.DataService }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { languageCodes: [{
70
70
  type: Input
71
71
  }] } });
72
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGFuZ3VhZ2UtY29kZS1zZWxlY3Rvci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvcmUvc3JjL3NoYXJlZC9jb21wb25lbnRzL2xhbmd1YWdlLWNvZGUtc2VsZWN0b3IvbGFuZ3VhZ2UtY29kZS1zZWxlY3Rvci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvcmUvc3JjL3NoYXJlZC9jb21wb25lbnRzL2xhbmd1YWdlLWNvZGUtc2VsZWN0b3IvbGFuZ3VhZ2UtY29kZS1zZWxlY3Rvci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0gsdUJBQXVCLEVBRXZCLFNBQVMsRUFDVCxVQUFVLEVBQ1YsS0FBSyxHQUVSLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBd0IsaUJBQWlCLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7Ozs7O0FBaUJ6RSxNQUFNLE9BQU8sNkJBQTZCO0lBc0J0QyxZQUFZLFdBQXlCLEVBQUUsaUJBQXFDO1FBZDVFLHdCQUFtQixHQUFHLENBQUMsSUFBWSxFQUFFLElBQVksRUFBRSxFQUFFO1lBQ2pELElBQUksZ0JBQWdCLEdBQUcsSUFBSSxDQUFDO1lBQzVCLE1BQU0sWUFBWSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDeEMsSUFBSTtnQkFDQSxnQkFBZ0I7b0JBQ1osSUFBSSxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxFQUFFO3dCQUNqQyxJQUFJLEVBQUUsVUFBVTtxQkFDbkIsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxZQUFZLENBQUMsSUFBSSxJQUFJLENBQUM7YUFDbkM7WUFBQyxPQUFPLENBQUMsRUFBRTtnQkFDUixTQUFTO2FBQ1o7WUFDRCxPQUFPLGdCQUFnQixFQUFFLFdBQVcsRUFBRSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUMsQ0FBQztRQUN4RSxDQUFDLENBQUM7UUFHRSxJQUFJLFdBQVcsSUFBSSxpQkFBaUIsRUFBRTtZQUNsQyxJQUFJLENBQUMsWUFBWSxHQUFHLFdBQVcsQ0FBQyxNQUFNO2lCQUNqQyxPQUFPLEVBQUU7aUJBQ1QsU0FBUyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQztpQkFDL0IsU0FBUyxDQUFDLENBQUMsRUFBRSxRQUFRLEVBQUUsTUFBTSxFQUFFLEVBQUUsRUFBRTtnQkFDaEMsSUFBSSxDQUFDLE1BQU0sR0FBRyxRQUFRLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxHQUFHLENBQUMsQ0FBQztnQkFDMUMsSUFBSSxNQUFNLEVBQUU7b0JBQ1IsSUFBSSxDQUFDLE1BQU0sSUFBSSxJQUFJLE1BQU0sRUFBRSxDQUFDO2lCQUMvQjtnQkFDRCxpQkFBaUIsQ0FBQyxZQUFZLEVBQUUsQ0FBQztZQUNyQyxDQUFDLENBQUMsQ0FBQztTQUNWO0lBQ0wsQ0FBQztJQUVELFVBQVUsQ0FBQyxHQUFRO1FBQ2YsSUFBSSxDQUFDLEtBQUssR0FBRyxHQUFHLENBQUM7SUFDckIsQ0FBQztJQUVELGdCQUFnQixDQUFDLEVBQU87UUFDcEIsSUFBSSxDQUFDLFVBQVUsR0FBRyxFQUFFLENBQUM7SUFDekIsQ0FBQztJQUVELGlCQUFpQixDQUFDLEVBQU87UUFDckIsSUFBSSxDQUFDLFNBQVMsR0FBRyxFQUFFLENBQUM7SUFDeEIsQ0FBQztJQUVELFdBQVc7UUFDUCxJQUFJLElBQUksQ0FBQyxZQUFZLEVBQUU7WUFDbkIsSUFBSSxDQUFDLFlBQVksQ0FBQyxXQUFXLEVBQUUsQ0FBQztTQUNuQztJQUNMLENBQUM7OEdBckRRLDZCQUE2QjtrR0FBN0IsNkJBQTZCLGlHQVIzQjtZQUNQO2dCQUNJLE9BQU8sRUFBRSxpQkFBaUI7Z0JBQzFCLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsNkJBQTZCLENBQUM7Z0JBQzVELEtBQUssRUFBRSxJQUFJO2FBQ2Q7U0FDSiwwQkN2QkwsMnNCQWlCQTs7MkZEUWEsNkJBQTZCO2tCQWJ6QyxTQUFTOytCQUNJLDRCQUE0QixtQkFHckIsdUJBQXVCLENBQUMsTUFBTSxhQUNwQzt3QkFDUDs0QkFDSSxPQUFPLEVBQUUsaUJBQWlCOzRCQUMxQixXQUFXLEVBQUUsVUFBVSxDQUFDLEdBQUcsRUFBRSw4QkFBOEIsQ0FBQzs0QkFDNUQsS0FBSyxFQUFFLElBQUk7eUJBQ2Q7cUJBQ0o7a0lBR1EsYUFBYTtzQkFBckIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XHJcbiAgICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcclxuICAgIENoYW5nZURldGVjdG9yUmVmLFxyXG4gICAgQ29tcG9uZW50LFxyXG4gICAgZm9yd2FyZFJlZixcclxuICAgIElucHV0LFxyXG4gICAgT25EZXN0cm95LFxyXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBDb250cm9sVmFsdWVBY2Nlc3NvciwgTkdfVkFMVUVfQUNDRVNTT1IgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcbmltcG9ydCB7IFN1YnNjcmlwdGlvbiB9IGZyb20gJ3J4anMnO1xyXG5pbXBvcnQgeyBEYXRhU2VydmljZSB9IGZyb20gJy4uLy4uLy4uL2RhdGEvcHJvdmlkZXJzL2RhdGEuc2VydmljZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICAgIHNlbGVjdG9yOiAndmRyLWxhbmd1YWdlLWNvZGUtc2VsZWN0b3InLFxyXG4gICAgdGVtcGxhdGVVcmw6ICcuL2xhbmd1YWdlLWNvZGUtc2VsZWN0b3IuY29tcG9uZW50Lmh0bWwnLFxyXG4gICAgc3R5bGVVcmxzOiBbJy4vbGFuZ3VhZ2UtY29kZS1zZWxlY3Rvci5jb21wb25lbnQuY3NzJ10sXHJcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcclxuICAgIHByb3ZpZGVyczogW1xyXG4gICAgICAgIHtcclxuICAgICAgICAgICAgcHJvdmlkZTogTkdfVkFMVUVfQUNDRVNTT1IsXHJcbiAgICAgICAgICAgIHVzZUV4aXN0aW5nOiBmb3J3YXJkUmVmKCgpID0+IExhbmd1YWdlQ29kZVNlbGVjdG9yQ29tcG9uZW50KSxcclxuICAgICAgICAgICAgbXVsdGk6IHRydWUsXHJcbiAgICAgICAgfSxcclxuICAgIF0sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBMYW5ndWFnZUNvZGVTZWxlY3RvckNvbXBvbmVudCBpbXBsZW1lbnRzIENvbnRyb2xWYWx1ZUFjY2Vzc29yLCBPbkRlc3Ryb3kge1xyXG4gICAgQElucHV0KCkgbGFuZ3VhZ2VDb2Rlczogc3RyaW5nW107XHJcbiAgICBwcml2YXRlIHN1YnNjcmlwdGlvbjogU3Vic2NyaXB0aW9uO1xyXG4gICAgcHJpdmF0ZSBsb2NhbGU6IHN0cmluZztcclxuICAgIHByb3RlY3RlZCB2YWx1ZTogc3RyaW5nIHwgdW5kZWZpbmVkO1xyXG4gICAgb25DaGFuZ2VGbjogKHZhbHVlOiBhbnkpID0+IHZvaWQ7XHJcbiAgICBvblRvdWNoRm46ICh2YWx1ZTogYW55KSA9PiB2b2lkO1xyXG5cclxuICAgIHNlYXJjaExhbmd1YWdlQ29kZXMgPSAodGVybTogc3RyaW5nLCBpdGVtOiBzdHJpbmcpID0+IHtcclxuICAgICAgICBsZXQgbGFuZ3VhZ2VDb2RlTmFtZSA9IGl0ZW07XHJcbiAgICAgICAgY29uc3QgbGFuZ3VhZ2VQYXJ0ID0gaXRlbS5zcGxpdCgnXycpWzBdO1xyXG4gICAgICAgIHRyeSB7XHJcbiAgICAgICAgICAgIGxhbmd1YWdlQ29kZU5hbWUgPVxyXG4gICAgICAgICAgICAgICAgbmV3IEludGwuRGlzcGxheU5hbWVzKFt0aGlzLmxvY2FsZV0sIHtcclxuICAgICAgICAgICAgICAgICAgICB0eXBlOiAnbGFuZ3VhZ2UnLFxyXG4gICAgICAgICAgICAgICAgfSkub2YobGFuZ3VhZ2VQYXJ0KSA/PyBpdGVtO1xyXG4gICAgICAgIH0gY2F0Y2ggKGUpIHtcclxuICAgICAgICAgICAgLy8gaWdub3JlXHJcbiAgICAgICAgfVxyXG4gICAgICAgIHJldHVybiBsYW5ndWFnZUNvZGVOYW1lPy50b0xvd2VyQ2FzZSgpLmluY2x1ZGVzKHRlcm0udG9Mb3dlckNhc2UoKSk7XHJcbiAgICB9O1xyXG5cclxuICAgIGNvbnN0cnVjdG9yKGRhdGFTZXJ2aWNlPzogRGF0YVNlcnZpY2UsIGNoYW5nZURldGVjdG9yUmVmPzogQ2hhbmdlRGV0ZWN0b3JSZWYpIHtcclxuICAgICAgICBpZiAoZGF0YVNlcnZpY2UgJiYgY2hhbmdlRGV0ZWN0b3JSZWYpIHtcclxuICAgICAgICAgICAgdGhpcy5zdWJzY3JpcHRpb24gPSBkYXRhU2VydmljZS5jbGllbnRcclxuICAgICAgICAgICAgICAgIC51aVN0YXRlKClcclxuICAgICAgICAgICAgICAgIC5tYXBTdHJlYW0oZGF0YSA9PiBkYXRhLnVpU3RhdGUpXHJcbiAgICAgICAgICAgICAgICAuc3Vic2NyaWJlKCh7IGxhbmd1YWdlLCBsb2NhbGUgfSkgPT4ge1xyXG4gICAgICAgICAgICAgICAgICAgIHRoaXMubG9jYWxlID0gbGFuZ3VhZ2UucmVwbGFjZSgvXy9nLCAnLScpO1xyXG4gICAgICAgICAgICAgICAgICAgIGlmIChsb2NhbGUpIHtcclxuICAgICAgICAgICAgICAgICAgICAgICAgdGhpcy5sb2NhbGUgKz0gYC0ke2xvY2FsZX1gO1xyXG4gICAgICAgICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgICAgICAgICBjaGFuZ2VEZXRlY3RvclJlZi5tYXJrRm9yQ2hlY2soKTtcclxuICAgICAgICAgICAgICAgIH0pO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuXHJcbiAgICB3cml0ZVZhbHVlKG9iajogYW55KTogdm9pZCB7XHJcbiAgICAgICAgdGhpcy52YWx1ZSA9IG9iajtcclxuICAgIH1cclxuXHJcbiAgICByZWdpc3Rlck9uQ2hhbmdlKGZuOiBhbnkpOiB2b2lkIHtcclxuICAgICAgICB0aGlzLm9uQ2hhbmdlRm4gPSBmbjtcclxuICAgIH1cclxuXHJcbiAgICByZWdpc3Rlck9uVG91Y2hlZChmbjogYW55KTogdm9pZCB7XHJcbiAgICAgICAgdGhpcy5vblRvdWNoRm4gPSBmbjtcclxuICAgIH1cclxuXHJcbiAgICBuZ09uRGVzdHJveSgpOiB2b2lkIHtcclxuICAgICAgICBpZiAodGhpcy5zdWJzY3JpcHRpb24pIHtcclxuICAgICAgICAgICAgdGhpcy5zdWJzY3JpcHRpb24udW5zdWJzY3JpYmUoKTtcclxuICAgICAgICB9XHJcbiAgICB9XHJcbn1cclxuIiwiPG5nLXNlbGVjdFxyXG4gICAgW2l0ZW1zXT1cImxhbmd1YWdlQ29kZXNcIlxyXG4gICAgW2FkZFRhZ109XCJmYWxzZVwiXHJcbiAgICBbaGlkZVNlbGVjdGVkXT1cInRydWVcIlxyXG4gICAgW3NlYXJjaEZuXT1cInNlYXJjaExhbmd1YWdlQ29kZXNcIlxyXG4gICAgbXVsdGlwbGU9XCJ0cnVlXCJcclxuICAgIGFwcGVuZFRvPVwiYm9keVwiXHJcbiAgICBbKG5nTW9kZWwpXT1cInZhbHVlXCJcclxuICAgIChuZ01vZGVsQ2hhbmdlKT1cIm9uQ2hhbmdlRm4oJGV2ZW50KVwiXHJcbj5cclxuICAgIDxuZy10ZW1wbGF0ZSBuZy1sYWJlbC10bXAgbGV0LWl0ZW09XCJpdGVtXCIgbGV0LWNsZWFyPVwiY2xlYXJcIj5cclxuICAgICAgICA8c3BhbiBjbGFzcz1cIm5nLXZhbHVlLWljb24gbGVmdFwiIChjbGljayk9XCJjbGVhci5jYWxsKG51bGwsIGl0ZW0pXCIgYXJpYS1oaWRkZW49XCJ0cnVlXCI+IMOXIDwvc3Bhbj5cclxuICAgICAgICA8c3BhbiBjbGFzcz1cIm5nLXZhbHVlLWxhYmVsXCI+e3sgaXRlbSB8IGxvY2FsZUxhbmd1YWdlTmFtZSB9fSAoe3sgaXRlbSB9fSk8L3NwYW4+XHJcbiAgICA8L25nLXRlbXBsYXRlPlxyXG4gICAgPG5nLXRlbXBsYXRlIG5nLW9wdGlvbi10bXAgbGV0LWl0ZW09XCJpdGVtXCI+e3sgaXRlbSB8IGxvY2FsZUxhbmd1YWdlTmFtZSB9fSAoe3sgaXRlbSB9fSk8L25nLXRlbXBsYXRlPlxyXG48L25nLXNlbGVjdD5cclxuXHJcbiJdfQ==
72
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGFuZ3VhZ2UtY29kZS1zZWxlY3Rvci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvcmUvc3JjL3NoYXJlZC9jb21wb25lbnRzL2xhbmd1YWdlLWNvZGUtc2VsZWN0b3IvbGFuZ3VhZ2UtY29kZS1zZWxlY3Rvci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvcmUvc3JjL3NoYXJlZC9jb21wb25lbnRzL2xhbmd1YWdlLWNvZGUtc2VsZWN0b3IvbGFuZ3VhZ2UtY29kZS1zZWxlY3Rvci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0gsdUJBQXVCLEVBRXZCLFNBQVMsRUFDVCxVQUFVLEVBQ1YsS0FBSyxHQUVSLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBd0IsaUJBQWlCLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7Ozs7O0FBaUJ6RSxNQUFNLE9BQU8sNkJBQTZCO0lBc0J0QyxZQUFZLFdBQXlCLEVBQUUsaUJBQXFDO1FBZDVFLHdCQUFtQixHQUFHLENBQUMsSUFBWSxFQUFFLElBQVksRUFBRSxFQUFFO1lBQ2pELElBQUksZ0JBQWdCLEdBQUcsSUFBSSxDQUFDO1lBQzVCLE1BQU0sWUFBWSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDeEMsSUFBSTtnQkFDQSxnQkFBZ0I7b0JBQ1osSUFBSSxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxFQUFFO3dCQUNqQyxJQUFJLEVBQUUsVUFBVTtxQkFDbkIsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxZQUFZLENBQUMsSUFBSSxJQUFJLENBQUM7YUFDbkM7WUFBQyxPQUFPLENBQUMsRUFBRTtnQkFDUixTQUFTO2FBQ1o7WUFDRCxPQUFPLGdCQUFnQixFQUFFLFdBQVcsRUFBRSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUMsQ0FBQztRQUN4RSxDQUFDLENBQUM7UUFHRSxJQUFJLFdBQVcsSUFBSSxpQkFBaUIsRUFBRTtZQUNsQyxJQUFJLENBQUMsWUFBWSxHQUFHLFdBQVcsQ0FBQyxNQUFNO2lCQUNqQyxPQUFPLEVBQUU7aUJBQ1QsU0FBUyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQztpQkFDL0IsU0FBUyxDQUFDLENBQUMsRUFBRSxRQUFRLEVBQUUsTUFBTSxFQUFFLEVBQUUsRUFBRTtnQkFDaEMsSUFBSSxDQUFDLE1BQU0sR0FBRyxRQUFRLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxHQUFHLENBQUMsQ0FBQztnQkFDMUMsSUFBSSxNQUFNLEVBQUU7b0JBQ1IsSUFBSSxDQUFDLE1BQU0sSUFBSSxJQUFJLE1BQU0sRUFBRSxDQUFDO2lCQUMvQjtnQkFDRCxpQkFBaUIsQ0FBQyxZQUFZLEVBQUUsQ0FBQztZQUNyQyxDQUFDLENBQUMsQ0FBQztTQUNWO0lBQ0wsQ0FBQztJQUVELFVBQVUsQ0FBQyxHQUFRO1FBQ2YsSUFBSSxDQUFDLEtBQUssR0FBRyxHQUFHLENBQUM7SUFDckIsQ0FBQztJQUVELGdCQUFnQixDQUFDLEVBQU87UUFDcEIsSUFBSSxDQUFDLFVBQVUsR0FBRyxFQUFFLENBQUM7SUFDekIsQ0FBQztJQUVELGlCQUFpQixDQUFDLEVBQU87UUFDckIsSUFBSSxDQUFDLFNBQVMsR0FBRyxFQUFFLENBQUM7SUFDeEIsQ0FBQztJQUVELFdBQVc7UUFDUCxJQUFJLElBQUksQ0FBQyxZQUFZLEVBQUU7WUFDbkIsSUFBSSxDQUFDLFlBQVksQ0FBQyxXQUFXLEVBQUUsQ0FBQztTQUNuQztJQUNMLENBQUM7OEdBckRRLDZCQUE2QjtrR0FBN0IsNkJBQTZCLGlHQVIzQjtZQUNQO2dCQUNJLE9BQU8sRUFBRSxpQkFBaUI7Z0JBQzFCLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsNkJBQTZCLENBQUM7Z0JBQzVELEtBQUssRUFBRSxJQUFJO2FBQ2Q7U0FDSiwwQkN2QkwsMnNCQWlCQTs7MkZEUWEsNkJBQTZCO2tCQWJ6QyxTQUFTOytCQUNJLDRCQUE0QixtQkFHckIsdUJBQXVCLENBQUMsTUFBTSxhQUNwQzt3QkFDUDs0QkFDSSxPQUFPLEVBQUUsaUJBQWlCOzRCQUMxQixXQUFXLEVBQUUsVUFBVSxDQUFDLEdBQUcsRUFBRSw4QkFBOEIsQ0FBQzs0QkFDNUQsS0FBSyxFQUFFLElBQUk7eUJBQ2Q7cUJBQ0o7a0lBR1EsYUFBYTtzQkFBckIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gICAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gICAgQ2hhbmdlRGV0ZWN0b3JSZWYsXG4gICAgQ29tcG9uZW50LFxuICAgIGZvcndhcmRSZWYsXG4gICAgSW5wdXQsXG4gICAgT25EZXN0cm95LFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbnRyb2xWYWx1ZUFjY2Vzc29yLCBOR19WQUxVRV9BQ0NFU1NPUiB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IFN1YnNjcmlwdGlvbiB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgRGF0YVNlcnZpY2UgfSBmcm9tICcuLi8uLi8uLi9kYXRhL3Byb3ZpZGVycy9kYXRhLnNlcnZpY2UnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ3Zkci1sYW5ndWFnZS1jb2RlLXNlbGVjdG9yJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vbGFuZ3VhZ2UtY29kZS1zZWxlY3Rvci5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vbGFuZ3VhZ2UtY29kZS1zZWxlY3Rvci5jb21wb25lbnQuY3NzJ10sXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gICAgcHJvdmlkZXJzOiBbXG4gICAgICAgIHtcbiAgICAgICAgICAgIHByb3ZpZGU6IE5HX1ZBTFVFX0FDQ0VTU09SLFxuICAgICAgICAgICAgdXNlRXhpc3Rpbmc6IGZvcndhcmRSZWYoKCkgPT4gTGFuZ3VhZ2VDb2RlU2VsZWN0b3JDb21wb25lbnQpLFxuICAgICAgICAgICAgbXVsdGk6IHRydWUsXG4gICAgICAgIH0sXG4gICAgXSxcbn0pXG5leHBvcnQgY2xhc3MgTGFuZ3VhZ2VDb2RlU2VsZWN0b3JDb21wb25lbnQgaW1wbGVtZW50cyBDb250cm9sVmFsdWVBY2Nlc3NvciwgT25EZXN0cm95IHtcbiAgICBASW5wdXQoKSBsYW5ndWFnZUNvZGVzOiBzdHJpbmdbXTtcbiAgICBwcml2YXRlIHN1YnNjcmlwdGlvbjogU3Vic2NyaXB0aW9uO1xuICAgIHByaXZhdGUgbG9jYWxlOiBzdHJpbmc7XG4gICAgcHJvdGVjdGVkIHZhbHVlOiBzdHJpbmcgfCB1bmRlZmluZWQ7XG4gICAgb25DaGFuZ2VGbjogKHZhbHVlOiBhbnkpID0+IHZvaWQ7XG4gICAgb25Ub3VjaEZuOiAodmFsdWU6IGFueSkgPT4gdm9pZDtcblxuICAgIHNlYXJjaExhbmd1YWdlQ29kZXMgPSAodGVybTogc3RyaW5nLCBpdGVtOiBzdHJpbmcpID0+IHtcbiAgICAgICAgbGV0IGxhbmd1YWdlQ29kZU5hbWUgPSBpdGVtO1xuICAgICAgICBjb25zdCBsYW5ndWFnZVBhcnQgPSBpdGVtLnNwbGl0KCdfJylbMF07XG4gICAgICAgIHRyeSB7XG4gICAgICAgICAgICBsYW5ndWFnZUNvZGVOYW1lID1cbiAgICAgICAgICAgICAgICBuZXcgSW50bC5EaXNwbGF5TmFtZXMoW3RoaXMubG9jYWxlXSwge1xuICAgICAgICAgICAgICAgICAgICB0eXBlOiAnbGFuZ3VhZ2UnLFxuICAgICAgICAgICAgICAgIH0pLm9mKGxhbmd1YWdlUGFydCkgPz8gaXRlbTtcbiAgICAgICAgfSBjYXRjaCAoZSkge1xuICAgICAgICAgICAgLy8gaWdub3JlXG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIGxhbmd1YWdlQ29kZU5hbWU/LnRvTG93ZXJDYXNlKCkuaW5jbHVkZXModGVybS50b0xvd2VyQ2FzZSgpKTtcbiAgICB9O1xuXG4gICAgY29uc3RydWN0b3IoZGF0YVNlcnZpY2U/OiBEYXRhU2VydmljZSwgY2hhbmdlRGV0ZWN0b3JSZWY/OiBDaGFuZ2VEZXRlY3RvclJlZikge1xuICAgICAgICBpZiAoZGF0YVNlcnZpY2UgJiYgY2hhbmdlRGV0ZWN0b3JSZWYpIHtcbiAgICAgICAgICAgIHRoaXMuc3Vic2NyaXB0aW9uID0gZGF0YVNlcnZpY2UuY2xpZW50XG4gICAgICAgICAgICAgICAgLnVpU3RhdGUoKVxuICAgICAgICAgICAgICAgIC5tYXBTdHJlYW0oZGF0YSA9PiBkYXRhLnVpU3RhdGUpXG4gICAgICAgICAgICAgICAgLnN1YnNjcmliZSgoeyBsYW5ndWFnZSwgbG9jYWxlIH0pID0+IHtcbiAgICAgICAgICAgICAgICAgICAgdGhpcy5sb2NhbGUgPSBsYW5ndWFnZS5yZXBsYWNlKC9fL2csICctJyk7XG4gICAgICAgICAgICAgICAgICAgIGlmIChsb2NhbGUpIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIHRoaXMubG9jYWxlICs9IGAtJHtsb2NhbGV9YDtcbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgICBjaGFuZ2VEZXRlY3RvclJlZi5tYXJrRm9yQ2hlY2soKTtcbiAgICAgICAgICAgICAgICB9KTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIHdyaXRlVmFsdWUob2JqOiBhbnkpOiB2b2lkIHtcbiAgICAgICAgdGhpcy52YWx1ZSA9IG9iajtcbiAgICB9XG5cbiAgICByZWdpc3Rlck9uQ2hhbmdlKGZuOiBhbnkpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5vbkNoYW5nZUZuID0gZm47XG4gICAgfVxuXG4gICAgcmVnaXN0ZXJPblRvdWNoZWQoZm46IGFueSk6IHZvaWQge1xuICAgICAgICB0aGlzLm9uVG91Y2hGbiA9IGZuO1xuICAgIH1cblxuICAgIG5nT25EZXN0cm95KCk6IHZvaWQge1xuICAgICAgICBpZiAodGhpcy5zdWJzY3JpcHRpb24pIHtcbiAgICAgICAgICAgIHRoaXMuc3Vic2NyaXB0aW9uLnVuc3Vic2NyaWJlKCk7XG4gICAgICAgIH1cbiAgICB9XG59XG4iLCI8bmctc2VsZWN0XHJcbiAgICBbaXRlbXNdPVwibGFuZ3VhZ2VDb2Rlc1wiXHJcbiAgICBbYWRkVGFnXT1cImZhbHNlXCJcclxuICAgIFtoaWRlU2VsZWN0ZWRdPVwidHJ1ZVwiXHJcbiAgICBbc2VhcmNoRm5dPVwic2VhcmNoTGFuZ3VhZ2VDb2Rlc1wiXHJcbiAgICBtdWx0aXBsZT1cInRydWVcIlxyXG4gICAgYXBwZW5kVG89XCJib2R5XCJcclxuICAgIFsobmdNb2RlbCldPVwidmFsdWVcIlxyXG4gICAgKG5nTW9kZWxDaGFuZ2UpPVwib25DaGFuZ2VGbigkZXZlbnQpXCJcclxuPlxyXG4gICAgPG5nLXRlbXBsYXRlIG5nLWxhYmVsLXRtcCBsZXQtaXRlbT1cIml0ZW1cIiBsZXQtY2xlYXI9XCJjbGVhclwiPlxyXG4gICAgICAgIDxzcGFuIGNsYXNzPVwibmctdmFsdWUtaWNvbiBsZWZ0XCIgKGNsaWNrKT1cImNsZWFyLmNhbGwobnVsbCwgaXRlbSlcIiBhcmlhLWhpZGRlbj1cInRydWVcIj4gw5cgPC9zcGFuPlxyXG4gICAgICAgIDxzcGFuIGNsYXNzPVwibmctdmFsdWUtbGFiZWxcIj57eyBpdGVtIHwgbG9jYWxlTGFuZ3VhZ2VOYW1lIH19ICh7eyBpdGVtIH19KTwvc3Bhbj5cclxuICAgIDwvbmctdGVtcGxhdGU+XHJcbiAgICA8bmctdGVtcGxhdGUgbmctb3B0aW9uLXRtcCBsZXQtaXRlbT1cIml0ZW1cIj57eyBpdGVtIHwgbG9jYWxlTGFuZ3VhZ2VOYW1lIH19ICh7eyBpdGVtIH19KTwvbmctdGVtcGxhdGU+XHJcbjwvbmctc2VsZWN0PlxyXG5cclxuIl19
@@ -27,9 +27,10 @@ export const iframeNode = {
27
27
  name: node.name,
28
28
  referrerpolicy: node.referrerPolicy,
29
29
  src: node.src,
30
- srcdoc: node.srcdoc || undefined,
31
30
  title: node.title ?? '',
32
31
  width: node.width,
32
+ // Note: we do not allow the `srcdoc` attribute to be
33
+ // set as it presents an XSS attack vector
33
34
  };
34
35
  if (node.sandbox.length) {
35
36
  attrs.sandbox = node.sandbox;
@@ -41,7 +42,7 @@ export const iframeNode = {
41
42
  },
42
43
  ],
43
44
  toDOM(node) {
44
- return ['iframe', { ...node.attrs }];
45
+ return ['iframe', { ...node.attrs, sandbox: 'allow-scripts allow-same-origin' }];
45
46
  },
46
47
  };
47
48
  export const iframeNodeView = (node, view, getPos, decorations) => {
@@ -54,4 +55,4 @@ export const iframeNodeView = (node, view, getPos, decorations) => {
54
55
  dom: wrapper,
55
56
  };
56
57
  };
57
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLW5vZGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vc3JjL2xpYi9jb3JlL3NyYy9zaGFyZWQvY29tcG9uZW50cy9yaWNoLXRleHQtZWRpdG9yL3Byb3NlbWlycm9yL2N1c3RvbS1ub2Rlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQW9CLGFBQWEsRUFBa0IsTUFBTSxtQkFBbUIsQ0FBQztBQUdwRixNQUFNLENBQUMsTUFBTSxVQUFVLEdBQWE7SUFDaEMsS0FBSyxFQUFFLE9BQU87SUFDZCxLQUFLLEVBQUU7UUFDSCxLQUFLLEVBQUUsRUFBRTtRQUNULGdCQUFnQixFQUFFLEVBQUU7UUFDcEIsV0FBVyxFQUFFLEVBQUU7UUFDZixNQUFNLEVBQUUsRUFBRSxPQUFPLEVBQUUsU0FBUyxFQUFFO1FBQzlCLElBQUksRUFBRSxFQUFFLE9BQU8sRUFBRSxFQUFFLEVBQUU7UUFDckIsY0FBYyxFQUFFLEVBQUU7UUFDbEIsT0FBTyxFQUFFLEVBQUUsT0FBTyxFQUFFLFNBQVMsRUFBRTtRQUMvQixHQUFHLEVBQUUsRUFBRTtRQUNQLE1BQU0sRUFBRSxFQUFFLE9BQU8sRUFBRSxTQUFTLEVBQUU7UUFDOUIsS0FBSyxFQUFFLEVBQUUsT0FBTyxFQUFFLFNBQVMsRUFBRTtRQUM3QixLQUFLLEVBQUUsRUFBRSxPQUFPLEVBQUUsU0FBUyxFQUFFO0tBQ2hDO0lBQ0QsUUFBUSxFQUFFO1FBQ047WUFDSSxHQUFHLEVBQUUsUUFBUTtZQUNiLFFBQVEsRUFBRSxJQUFJLENBQUMsRUFBRTtnQkFDYixJQUFJLElBQUksWUFBWSxpQkFBaUIsRUFBRTtvQkFDbkMsTUFBTSxLQUFLLEdBQXdCO3dCQUMvQixLQUFLLEVBQUUsSUFBSSxDQUFDLEtBQUs7d0JBQ2pCLGdCQUFnQixFQUFFLElBQUksQ0FBQyxlQUFlLElBQUksSUFBSTt3QkFDOUMsV0FBVyxFQUFFLElBQUksQ0FBQyxZQUFZLENBQUMsYUFBYSxDQUFDO3dCQUM3QyxNQUFNLEVBQUUsSUFBSSxDQUFDLE1BQU07d0JBQ25CLElBQUksRUFBRSxJQUFJLENBQUMsSUFBSTt3QkFDZixjQUFjLEVBQUUsSUFBSSxDQUFDLGNBQWM7d0JBQ25DLEdBQUcsRUFBRSxJQUFJLENBQUMsR0FBRzt3QkFDYixNQUFNLEVBQUUsSUFBSSxDQUFDLE1BQU0sSUFBSSxTQUFTO3dCQUNoQyxLQUFLLEVBQUUsSUFBSSxDQUFDLEtBQUssSUFBSSxFQUFFO3dCQUN2QixLQUFLLEVBQUUsSUFBSSxDQUFDLEtBQUs7cUJBQ3BCLENBQUM7b0JBQ0YsSUFBSSxJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sRUFBRTt3QkFDckIsS0FBSyxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDO3FCQUNoQztvQkFDRCxPQUFPLEtBQUssQ0FBQztpQkFDaEI7Z0JBQ0QsT0FBTyxJQUFJLENBQUM7WUFDaEIsQ0FBQztTQUNKO0tBQ0o7SUFDRCxLQUFLLENBQUMsSUFBSTtRQUNOLE9BQU8sQ0FBQyxRQUFRLEVBQUUsRUFBRSxHQUFHLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDO0lBQ3pDLENBQUM7Q0FDSixDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sY0FBYyxHQUF3QixDQUFDLElBQUksRUFBRSxJQUFJLEVBQUUsTUFBTSxFQUFFLFdBQVcsRUFBRSxFQUFFO0lBQ25GLE1BQU0sYUFBYSxHQUFHLGFBQWEsQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUNsRSxNQUFNLE9BQU8sR0FBRyxRQUFRLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzlDLE9BQU8sQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLGdCQUFnQixDQUFDLENBQUM7SUFDeEMsTUFBTSxNQUFNLEdBQUcsYUFBYSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNqRCxPQUFPLENBQUMsV0FBVyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQzVCLE9BQU87UUFDSCxHQUFHLEVBQUUsT0FBTztLQUNmLENBQUM7QUFDTixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBdHRycywgRE9NUGFyc2VyLCBET01TZXJpYWxpemVyLCBOb2RlLCBOb2RlU3BlYyB9IGZyb20gJ3Byb3NlbWlycm9yLW1vZGVsJztcclxuaW1wb3J0IHsgTm9kZVZpZXdDb25zdHJ1Y3RvciB9IGZyb20gJ3Byb3NlbWlycm9yLXZpZXcnO1xyXG5cclxuZXhwb3J0IGNvbnN0IGlmcmFtZU5vZGU6IE5vZGVTcGVjID0ge1xyXG4gICAgZ3JvdXA6ICdibG9jaycsXHJcbiAgICBhdHRyczoge1xyXG4gICAgICAgIGFsbG93OiB7fSxcclxuICAgICAgICBhbGxvd2Z1bGxzY3JlZWVuOiB7fSxcclxuICAgICAgICBmcmFtZWJvcmRlcjoge30sXHJcbiAgICAgICAgaGVpZ2h0OiB7IGRlZmF1bHQ6IHVuZGVmaW5lZCB9LFxyXG4gICAgICAgIG5hbWU6IHsgZGVmYXVsdDogJycgfSxcclxuICAgICAgICByZWZlcnJlcnBvbGljeToge30sXHJcbiAgICAgICAgc2FuZGJveDogeyBkZWZhdWx0OiB1bmRlZmluZWQgfSxcclxuICAgICAgICBzcmM6IHt9LFxyXG4gICAgICAgIHNyY2RvYzogeyBkZWZhdWx0OiB1bmRlZmluZWQgfSxcclxuICAgICAgICB0aXRsZTogeyBkZWZhdWx0OiB1bmRlZmluZWQgfSxcclxuICAgICAgICB3aWR0aDogeyBkZWZhdWx0OiB1bmRlZmluZWQgfSxcclxuICAgIH0sXHJcbiAgICBwYXJzZURPTTogW1xyXG4gICAgICAgIHtcclxuICAgICAgICAgICAgdGFnOiAnaWZyYW1lJyxcclxuICAgICAgICAgICAgZ2V0QXR0cnM6IG5vZGUgPT4ge1xyXG4gICAgICAgICAgICAgICAgaWYgKG5vZGUgaW5zdGFuY2VvZiBIVE1MSUZyYW1lRWxlbWVudCkge1xyXG4gICAgICAgICAgICAgICAgICAgIGNvbnN0IGF0dHJzOiBSZWNvcmQ8c3RyaW5nLCBhbnk+ID0ge1xyXG4gICAgICAgICAgICAgICAgICAgICAgICBhbGxvdzogbm9kZS5hbGxvdyxcclxuICAgICAgICAgICAgICAgICAgICAgICAgYWxsb3dmdWxsc2NyZWVlbjogbm9kZS5hbGxvd0Z1bGxzY3JlZW4gPz8gdHJ1ZSxcclxuICAgICAgICAgICAgICAgICAgICAgICAgZnJhbWVib3JkZXI6IG5vZGUuZ2V0QXR0cmlidXRlKCdmcmFtZWJvcmRlcicpLFxyXG4gICAgICAgICAgICAgICAgICAgICAgICBoZWlnaHQ6IG5vZGUuaGVpZ2h0LFxyXG4gICAgICAgICAgICAgICAgICAgICAgICBuYW1lOiBub2RlLm5hbWUsXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIHJlZmVycmVycG9saWN5OiBub2RlLnJlZmVycmVyUG9saWN5LFxyXG4gICAgICAgICAgICAgICAgICAgICAgICBzcmM6IG5vZGUuc3JjLFxyXG4gICAgICAgICAgICAgICAgICAgICAgICBzcmNkb2M6IG5vZGUuc3JjZG9jIHx8IHVuZGVmaW5lZCxcclxuICAgICAgICAgICAgICAgICAgICAgICAgdGl0bGU6IG5vZGUudGl0bGUgPz8gJycsXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIHdpZHRoOiBub2RlLndpZHRoLFxyXG4gICAgICAgICAgICAgICAgICAgIH07XHJcbiAgICAgICAgICAgICAgICAgICAgaWYgKG5vZGUuc2FuZGJveC5sZW5ndGgpIHtcclxuICAgICAgICAgICAgICAgICAgICAgICAgYXR0cnMuc2FuZGJveCA9IG5vZGUuc2FuZGJveDtcclxuICAgICAgICAgICAgICAgICAgICB9XHJcbiAgICAgICAgICAgICAgICAgICAgcmV0dXJuIGF0dHJzO1xyXG4gICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICAgICAgcmV0dXJuIG51bGw7XHJcbiAgICAgICAgICAgIH0sXHJcbiAgICAgICAgfSxcclxuICAgIF0sXHJcbiAgICB0b0RPTShub2RlKSB7XHJcbiAgICAgICAgcmV0dXJuIFsnaWZyYW1lJywgeyAuLi5ub2RlLmF0dHJzIH1dO1xyXG4gICAgfSxcclxufTtcclxuXHJcbmV4cG9ydCBjb25zdCBpZnJhbWVOb2RlVmlldzogTm9kZVZpZXdDb25zdHJ1Y3RvciA9IChub2RlLCB2aWV3LCBnZXRQb3MsIGRlY29yYXRpb25zKSA9PiB7XHJcbiAgICBjb25zdCBkb21TZXJpYWxpemVyID0gRE9NU2VyaWFsaXplci5mcm9tU2NoZW1hKHZpZXcuc3RhdGUuc2NoZW1hKTtcclxuICAgIGNvbnN0IHdyYXBwZXIgPSBkb2N1bWVudC5jcmVhdGVFbGVtZW50KCdkaXYnKTtcclxuICAgIHdyYXBwZXIuY2xhc3NMaXN0LmFkZCgnaWZyYW1lLXdyYXBwZXInKTtcclxuICAgIGNvbnN0IGlmcmFtZSA9IGRvbVNlcmlhbGl6ZXIuc2VyaWFsaXplTm9kZShub2RlKTtcclxuICAgIHdyYXBwZXIuYXBwZW5kQ2hpbGQoaWZyYW1lKTtcclxuICAgIHJldHVybiB7XHJcbiAgICAgICAgZG9tOiB3cmFwcGVyLFxyXG4gICAgfTtcclxufTtcclxuIl19
58
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLW5vZGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vc3JjL2xpYi9jb3JlL3NyYy9zaGFyZWQvY29tcG9uZW50cy9yaWNoLXRleHQtZWRpdG9yL3Byb3NlbWlycm9yL2N1c3RvbS1ub2Rlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQW9CLGFBQWEsRUFBa0IsTUFBTSxtQkFBbUIsQ0FBQztBQUdwRixNQUFNLENBQUMsTUFBTSxVQUFVLEdBQWE7SUFDaEMsS0FBSyxFQUFFLE9BQU87SUFDZCxLQUFLLEVBQUU7UUFDSCxLQUFLLEVBQUUsRUFBRTtRQUNULGdCQUFnQixFQUFFLEVBQUU7UUFDcEIsV0FBVyxFQUFFLEVBQUU7UUFDZixNQUFNLEVBQUUsRUFBRSxPQUFPLEVBQUUsU0FBUyxFQUFFO1FBQzlCLElBQUksRUFBRSxFQUFFLE9BQU8sRUFBRSxFQUFFLEVBQUU7UUFDckIsY0FBYyxFQUFFLEVBQUU7UUFDbEIsT0FBTyxFQUFFLEVBQUUsT0FBTyxFQUFFLFNBQVMsRUFBRTtRQUMvQixHQUFHLEVBQUUsRUFBRTtRQUNQLE1BQU0sRUFBRSxFQUFFLE9BQU8sRUFBRSxTQUFTLEVBQUU7UUFDOUIsS0FBSyxFQUFFLEVBQUUsT0FBTyxFQUFFLFNBQVMsRUFBRTtRQUM3QixLQUFLLEVBQUUsRUFBRSxPQUFPLEVBQUUsU0FBUyxFQUFFO0tBQ2hDO0lBQ0QsUUFBUSxFQUFFO1FBQ047WUFDSSxHQUFHLEVBQUUsUUFBUTtZQUNiLFFBQVEsRUFBRSxJQUFJLENBQUMsRUFBRTtnQkFDYixJQUFJLElBQUksWUFBWSxpQkFBaUIsRUFBRTtvQkFDbkMsTUFBTSxLQUFLLEdBQXdCO3dCQUMvQixLQUFLLEVBQUUsSUFBSSxDQUFDLEtBQUs7d0JBQ2pCLGdCQUFnQixFQUFFLElBQUksQ0FBQyxlQUFlLElBQUksSUFBSTt3QkFDOUMsV0FBVyxFQUFFLElBQUksQ0FBQyxZQUFZLENBQUMsYUFBYSxDQUFDO3dCQUM3QyxNQUFNLEVBQUUsSUFBSSxDQUFDLE1BQU07d0JBQ25CLElBQUksRUFBRSxJQUFJLENBQUMsSUFBSTt3QkFDZixjQUFjLEVBQUUsSUFBSSxDQUFDLGNBQWM7d0JBQ25DLEdBQUcsRUFBRSxJQUFJLENBQUMsR0FBRzt3QkFDYixLQUFLLEVBQUUsSUFBSSxDQUFDLEtBQUssSUFBSSxFQUFFO3dCQUN2QixLQUFLLEVBQUUsSUFBSSxDQUFDLEtBQUs7d0JBQ2pCLHFEQUFxRDt3QkFDckQsMENBQTBDO3FCQUM3QyxDQUFDO29CQUNGLElBQUksSUFBSSxDQUFDLE9BQU8sQ0FBQyxNQUFNLEVBQUU7d0JBQ3JCLEtBQUssQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQztxQkFDaEM7b0JBQ0QsT0FBTyxLQUFLLENBQUM7aUJBQ2hCO2dCQUNELE9BQU8sSUFBSSxDQUFDO1lBQ2hCLENBQUM7U0FDSjtLQUNKO0lBQ0QsS0FBSyxDQUFDLElBQUk7UUFDTixPQUFPLENBQUMsUUFBUSxFQUFFLEVBQUUsR0FBRyxJQUFJLENBQUMsS0FBSyxFQUFFLE9BQU8sRUFBRSxpQ0FBaUMsRUFBRSxDQUFDLENBQUM7SUFDckYsQ0FBQztDQUNKLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxjQUFjLEdBQXdCLENBQUMsSUFBSSxFQUFFLElBQUksRUFBRSxNQUFNLEVBQUUsV0FBVyxFQUFFLEVBQUU7SUFDbkYsTUFBTSxhQUFhLEdBQUcsYUFBYSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQ2xFLE1BQU0sT0FBTyxHQUFHLFFBQVEsQ0FBQyxhQUFhLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDOUMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztJQUN4QyxNQUFNLE1BQU0sR0FBRyxhQUFhLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ2pELE9BQU8sQ0FBQyxXQUFXLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDNUIsT0FBTztRQUNILEdBQUcsRUFBRSxPQUFPO0tBQ2YsQ0FBQztBQUNOLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEF0dHJzLCBET01QYXJzZXIsIERPTVNlcmlhbGl6ZXIsIE5vZGUsIE5vZGVTcGVjIH0gZnJvbSAncHJvc2VtaXJyb3ItbW9kZWwnO1xyXG5pbXBvcnQgeyBOb2RlVmlld0NvbnN0cnVjdG9yIH0gZnJvbSAncHJvc2VtaXJyb3Itdmlldyc7XHJcblxyXG5leHBvcnQgY29uc3QgaWZyYW1lTm9kZTogTm9kZVNwZWMgPSB7XHJcbiAgICBncm91cDogJ2Jsb2NrJyxcclxuICAgIGF0dHJzOiB7XHJcbiAgICAgICAgYWxsb3c6IHt9LFxyXG4gICAgICAgIGFsbG93ZnVsbHNjcmVlZW46IHt9LFxyXG4gICAgICAgIGZyYW1lYm9yZGVyOiB7fSxcclxuICAgICAgICBoZWlnaHQ6IHsgZGVmYXVsdDogdW5kZWZpbmVkIH0sXHJcbiAgICAgICAgbmFtZTogeyBkZWZhdWx0OiAnJyB9LFxyXG4gICAgICAgIHJlZmVycmVycG9saWN5OiB7fSxcclxuICAgICAgICBzYW5kYm94OiB7IGRlZmF1bHQ6IHVuZGVmaW5lZCB9LFxyXG4gICAgICAgIHNyYzoge30sXHJcbiAgICAgICAgc3JjZG9jOiB7IGRlZmF1bHQ6IHVuZGVmaW5lZCB9LFxyXG4gICAgICAgIHRpdGxlOiB7IGRlZmF1bHQ6IHVuZGVmaW5lZCB9LFxyXG4gICAgICAgIHdpZHRoOiB7IGRlZmF1bHQ6IHVuZGVmaW5lZCB9LFxyXG4gICAgfSxcclxuICAgIHBhcnNlRE9NOiBbXHJcbiAgICAgICAge1xyXG4gICAgICAgICAgICB0YWc6ICdpZnJhbWUnLFxyXG4gICAgICAgICAgICBnZXRBdHRyczogbm9kZSA9PiB7XHJcbiAgICAgICAgICAgICAgICBpZiAobm9kZSBpbnN0YW5jZW9mIEhUTUxJRnJhbWVFbGVtZW50KSB7XHJcbiAgICAgICAgICAgICAgICAgICAgY29uc3QgYXR0cnM6IFJlY29yZDxzdHJpbmcsIGFueT4gPSB7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgIGFsbG93OiBub2RlLmFsbG93LFxyXG4gICAgICAgICAgICAgICAgICAgICAgICBhbGxvd2Z1bGxzY3JlZWVuOiBub2RlLmFsbG93RnVsbHNjcmVlbiA/PyB0cnVlLFxyXG4gICAgICAgICAgICAgICAgICAgICAgICBmcmFtZWJvcmRlcjogbm9kZS5nZXRBdHRyaWJ1dGUoJ2ZyYW1lYm9yZGVyJyksXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIGhlaWdodDogbm9kZS5oZWlnaHQsXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIG5hbWU6IG5vZGUubmFtZSxcclxuICAgICAgICAgICAgICAgICAgICAgICAgcmVmZXJyZXJwb2xpY3k6IG5vZGUucmVmZXJyZXJQb2xpY3ksXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIHNyYzogbm9kZS5zcmMsXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIHRpdGxlOiBub2RlLnRpdGxlID8/ICcnLFxyXG4gICAgICAgICAgICAgICAgICAgICAgICB3aWR0aDogbm9kZS53aWR0aCxcclxuICAgICAgICAgICAgICAgICAgICAgICAgLy8gTm90ZTogd2UgZG8gbm90IGFsbG93IHRoZSBgc3JjZG9jYCBhdHRyaWJ1dGUgdG8gYmVcclxuICAgICAgICAgICAgICAgICAgICAgICAgLy8gc2V0IGFzIGl0IHByZXNlbnRzIGFuIFhTUyBhdHRhY2sgdmVjdG9yXHJcbiAgICAgICAgICAgICAgICAgICAgfTtcclxuICAgICAgICAgICAgICAgICAgICBpZiAobm9kZS5zYW5kYm94Lmxlbmd0aCkge1xyXG4gICAgICAgICAgICAgICAgICAgICAgICBhdHRycy5zYW5kYm94ID0gbm9kZS5zYW5kYm94O1xyXG4gICAgICAgICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgICAgICAgICByZXR1cm4gYXR0cnM7XHJcbiAgICAgICAgICAgICAgICB9XHJcbiAgICAgICAgICAgICAgICByZXR1cm4gbnVsbDtcclxuICAgICAgICAgICAgfSxcclxuICAgICAgICB9LFxyXG4gICAgXSxcclxuICAgIHRvRE9NKG5vZGUpIHtcclxuICAgICAgICByZXR1cm4gWydpZnJhbWUnLCB7IC4uLm5vZGUuYXR0cnMsIHNhbmRib3g6ICdhbGxvdy1zY3JpcHRzIGFsbG93LXNhbWUtb3JpZ2luJyB9XTtcclxuICAgIH0sXHJcbn07XHJcblxyXG5leHBvcnQgY29uc3QgaWZyYW1lTm9kZVZpZXc6IE5vZGVWaWV3Q29uc3RydWN0b3IgPSAobm9kZSwgdmlldywgZ2V0UG9zLCBkZWNvcmF0aW9ucykgPT4ge1xyXG4gICAgY29uc3QgZG9tU2VyaWFsaXplciA9IERPTVNlcmlhbGl6ZXIuZnJvbVNjaGVtYSh2aWV3LnN0YXRlLnNjaGVtYSk7XHJcbiAgICBjb25zdCB3cmFwcGVyID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudCgnZGl2Jyk7XHJcbiAgICB3cmFwcGVyLmNsYXNzTGlzdC5hZGQoJ2lmcmFtZS13cmFwcGVyJyk7XHJcbiAgICBjb25zdCBpZnJhbWUgPSBkb21TZXJpYWxpemVyLnNlcmlhbGl6ZU5vZGUobm9kZSk7XHJcbiAgICB3cmFwcGVyLmFwcGVuZENoaWxkKGlmcmFtZSk7XHJcbiAgICByZXR1cm4ge1xyXG4gICAgICAgIGRvbTogd3JhcHBlcixcclxuICAgIH07XHJcbn07XHJcbiJdfQ==
@@ -34,6 +34,11 @@ export class ProsemirrorService {
34
34
  marks: schema.spec.marks,
35
35
  });
36
36
  this.enabled = true;
37
+ /**
38
+ * This is a Document used for processing incoming text. It ensures that malicious HTML is not executed by the
39
+ * actual document that is attached to the browser DOM, which could cause XSS attacks.
40
+ */
41
+ this.detachedDoc = null;
37
42
  }
38
43
  createEditorView(options) {
39
44
  this.editorView = new EditorView(options.element, {
@@ -92,7 +97,8 @@ export class ProsemirrorService {
92
97
  }
93
98
  }
94
99
  getStateFromText(text) {
95
- const div = document.createElement('div');
100
+ const doc = this.getDetachedDoc();
101
+ const div = doc.createElement('div');
96
102
  div.innerHTML = text ?? '';
97
103
  return EditorState.create({
98
104
  doc: DOMParser.fromSchema(this.mySchema).parse(div),
@@ -100,7 +106,8 @@ export class ProsemirrorService {
100
106
  });
101
107
  }
102
108
  getTextFromState(state) {
103
- const div = document.createElement('div');
109
+ const doc = this.getDetachedDoc();
110
+ const div = doc.createElement('div');
104
111
  const fragment = DOMSerializer.fromSchema(this.mySchema).serializeFragment(state.doc.content);
105
112
  div.appendChild(fragment);
106
113
  return div.innerHTML;
@@ -133,10 +140,16 @@ export class ProsemirrorService {
133
140
  },
134
141
  }));
135
142
  }
143
+ getDetachedDoc() {
144
+ if (!this.detachedDoc) {
145
+ this.detachedDoc = document.implementation.createHTMLDocument();
146
+ }
147
+ return this.detachedDoc;
148
+ }
136
149
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.3", ngImport: i0, type: ProsemirrorService, deps: [{ token: i0.Injector }, { token: i1.ContextMenuService }], target: i0.ɵɵFactoryTarget.Injectable }); }
137
150
  static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.0.3", ngImport: i0, type: ProsemirrorService }); }
138
151
  }
139
152
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.3", ngImport: i0, type: ProsemirrorService, decorators: [{
140
153
  type: Injectable
141
154
  }], ctorParameters: function () { return [{ type: i0.Injector }, { type: i1.ContextMenuService }]; } });
142
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"prosemirror.service.js","sourceRoot":"","sources":["../../../../../../../src/lib/core/src/shared/components/rich-text-editor/prosemirror/prosemirror.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Injector } from '@angular/core';\r\nimport { baseKeymap } from 'prosemirror-commands';\r\nimport { dropCursor } from 'prosemirror-dropcursor';\r\nimport { gapCursor } from 'prosemirror-gapcursor';\r\nimport { history } from 'prosemirror-history';\r\nimport { keymap } from 'prosemirror-keymap';\r\nimport { DOMParser, DOMSerializer, Schema } from 'prosemirror-model';\r\nimport { schema } from 'prosemirror-schema-basic';\r\nimport { addListNodes } from 'prosemirror-schema-list';\r\nimport { EditorState, Plugin } from 'prosemirror-state';\r\nimport { columnResizing, fixTables, tableEditing } from 'prosemirror-tables';\r\nimport { EditorView } from 'prosemirror-view';\r\nimport { Observable } from 'rxjs';\r\n\r\nimport { ModalService } from '../../../../providers/modal/modal.service';\r\n\r\nimport { ContextMenuService } from './context-menu/context-menu.service';\r\nimport { iframeNode, iframeNodeView } from './custom-nodes';\r\nimport { buildInputRules } from './inputrules';\r\nimport { buildKeymap } from './keymap';\r\nimport { customMenuPlugin } from './menu/menu-plugin';\r\nimport { imageContextMenuPlugin } from './plugins/image-plugin';\r\nimport { linkSelectPlugin } from './plugins/link-select-plugin';\r\nimport { rawEditorPlugin } from './plugins/raw-editor-plugin';\r\nimport { getTableNodes, tableContextMenuPlugin } from './plugins/tables-plugin';\r\nimport { SetupOptions } from './types';\r\n\r\nexport interface CreateEditorViewOptions {\r\n    onTextInput: (content: string) => void;\r\n    element: HTMLElement;\r\n    isReadOnly: () => boolean;\r\n}\r\n\r\n@Injectable()\r\nexport class ProsemirrorService {\r\n    editorView: EditorView;\r\n\r\n    // Mix the nodes from prosemirror-schema-list into the basic schema to\r\n    // create a schema with list support.\r\n    private mySchema = new Schema({\r\n        nodes: addListNodes(schema.spec.nodes, 'paragraph block*', 'block')\r\n            .append(getTableNodes() as any)\r\n            .addToEnd('iframe', iframeNode),\r\n        marks: schema.spec.marks,\r\n    });\r\n    private enabled = true;\r\n\r\n    constructor(private injector: Injector, private contextMenuService: ContextMenuService) {}\r\n\r\n    contextMenuItems$: Observable<string>;\r\n\r\n    createEditorView(options: CreateEditorViewOptions) {\r\n        this.editorView = new EditorView(options.element, {\r\n            state: this.getStateFromText(''),\r\n            dispatchTransaction: tr => {\r\n                if (!this.enabled) {\r\n                    return;\r\n                }\r\n                this.editorView.updateState(this.editorView.state.apply(tr));\r\n                if (tr.docChanged) {\r\n                    const content = this.getTextFromState(this.editorView.state);\r\n                    options.onTextInput(content);\r\n                }\r\n            },\r\n            editable: () => options.isReadOnly(),\r\n            handleDOMEvents: {\r\n                focus: view => {\r\n                    this.contextMenuService.setVisibility(true);\r\n                },\r\n                blur: view => {\r\n                    this.contextMenuService.setVisibility(false);\r\n                },\r\n            },\r\n            nodeViews: {\r\n                iframe: iframeNodeView,\r\n            },\r\n        });\r\n    }\r\n\r\n    update(text: string) {\r\n        if (this.editorView) {\r\n            const currentText = this.getTextFromState(this.editorView.state);\r\n            if (text !== currentText) {\r\n                let state = this.getStateFromText(text);\r\n                if (document.body.contains(this.editorView.dom)) {\r\n                    const fix = fixTables(state);\r\n                    if (fix) {\r\n                        state = state.apply(fix.setMeta('addToHistory', false));\r\n                    }\r\n                    this.editorView.updateState(state);\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    destroy() {\r\n        if (this.editorView) {\r\n            this.editorView.destroy();\r\n        }\r\n    }\r\n\r\n    setEnabled(enabled: boolean) {\r\n        if (this.editorView) {\r\n            this.enabled = enabled;\r\n            // Updating the state causes ProseMirror to check the\r\n            // `editable()` function from the contructor config object\r\n            // newly.\r\n            this.editorView.updateState(this.editorView.state);\r\n        }\r\n    }\r\n\r\n    private getStateFromText(text: string | null | undefined): EditorState {\r\n        const div = document.createElement('div');\r\n        div.innerHTML = text ?? '';\r\n        return EditorState.create({\r\n            doc: DOMParser.fromSchema(this.mySchema).parse(div),\r\n            plugins: this.configurePlugins({ schema: this.mySchema, floatingMenu: false }),\r\n        });\r\n    }\r\n\r\n    private getTextFromState(state: EditorState): string {\r\n        const div = document.createElement('div');\r\n        const fragment = DOMSerializer.fromSchema(this.mySchema).serializeFragment(state.doc.content);\r\n\r\n        div.appendChild(fragment);\r\n\r\n        return div.innerHTML;\r\n    }\r\n\r\n    private configurePlugins(options: SetupOptions) {\r\n        const plugins = [\r\n            buildInputRules(options.schema),\r\n            keymap(buildKeymap(options.schema, options.mapKeys)),\r\n            keymap(baseKeymap),\r\n            dropCursor(),\r\n            gapCursor(),\r\n            linkSelectPlugin,\r\n            columnResizing({}),\r\n            tableEditing({ allowTableNodeSelection: true }),\r\n            tableContextMenuPlugin(this.contextMenuService),\r\n            imageContextMenuPlugin(this.contextMenuService, this.injector.get(ModalService)),\r\n            rawEditorPlugin(this.contextMenuService, this.injector.get(ModalService)),\r\n            customMenuPlugin({\r\n                floatingMenu: options.floatingMenu,\r\n                injector: this.injector,\r\n                schema: options.schema,\r\n            }),\r\n        ];\r\n        if (options.history !== false) {\r\n            plugins.push(history());\r\n        }\r\n\r\n        return plugins.concat(\r\n            new Plugin({\r\n                props: {\r\n                    attributes: { class: 'vdr-prosemirror' },\r\n                },\r\n            }),\r\n        );\r\n    }\r\n}\r\n"]}
155
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"prosemirror.service.js","sourceRoot":"","sources":["../../../../../../../src/lib/core/src/shared/components/rich-text-editor/prosemirror/prosemirror.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Injector } from '@angular/core';\r\nimport { baseKeymap } from 'prosemirror-commands';\r\nimport { dropCursor } from 'prosemirror-dropcursor';\r\nimport { gapCursor } from 'prosemirror-gapcursor';\r\nimport { history } from 'prosemirror-history';\r\nimport { keymap } from 'prosemirror-keymap';\r\nimport { DOMParser, DOMSerializer, Schema } from 'prosemirror-model';\r\nimport { schema } from 'prosemirror-schema-basic';\r\nimport { addListNodes } from 'prosemirror-schema-list';\r\nimport { EditorState, Plugin } from 'prosemirror-state';\r\nimport { columnResizing, fixTables, tableEditing } from 'prosemirror-tables';\r\nimport { EditorView } from 'prosemirror-view';\r\nimport { Observable } from 'rxjs';\r\n\r\nimport { ModalService } from '../../../../providers/modal/modal.service';\r\n\r\nimport { ContextMenuService } from './context-menu/context-menu.service';\r\nimport { iframeNode, iframeNodeView } from './custom-nodes';\r\nimport { buildInputRules } from './inputrules';\r\nimport { buildKeymap } from './keymap';\r\nimport { customMenuPlugin } from './menu/menu-plugin';\r\nimport { imageContextMenuPlugin } from './plugins/image-plugin';\r\nimport { linkSelectPlugin } from './plugins/link-select-plugin';\r\nimport { rawEditorPlugin } from './plugins/raw-editor-plugin';\r\nimport { getTableNodes, tableContextMenuPlugin } from './plugins/tables-plugin';\r\nimport { SetupOptions } from './types';\r\n\r\nexport interface CreateEditorViewOptions {\r\n    onTextInput: (content: string) => void;\r\n    element: HTMLElement;\r\n    isReadOnly: () => boolean;\r\n}\r\n\r\n@Injectable()\r\nexport class ProsemirrorService {\r\n    editorView: EditorView;\r\n\r\n    // Mix the nodes from prosemirror-schema-list into the basic schema to\r\n    // create a schema with list support.\r\n    private mySchema = new Schema({\r\n        nodes: addListNodes(schema.spec.nodes, 'paragraph block*', 'block')\r\n            .append(getTableNodes() as any)\r\n            .addToEnd('iframe', iframeNode),\r\n        marks: schema.spec.marks,\r\n    });\r\n    private enabled = true;\r\n    /**\r\n     * This is a Document used for processing incoming text. It ensures that malicious HTML is not executed by the\r\n     * actual document that is attached to the browser DOM, which could cause XSS attacks.\r\n     */\r\n    private detachedDoc: Document | null = null;\r\n\r\n    constructor(private injector: Injector, private contextMenuService: ContextMenuService) {}\r\n\r\n    contextMenuItems$: Observable<string>;\r\n\r\n    createEditorView(options: CreateEditorViewOptions) {\r\n        this.editorView = new EditorView(options.element, {\r\n            state: this.getStateFromText(''),\r\n            dispatchTransaction: tr => {\r\n                if (!this.enabled) {\r\n                    return;\r\n                }\r\n                this.editorView.updateState(this.editorView.state.apply(tr));\r\n                if (tr.docChanged) {\r\n                    const content = this.getTextFromState(this.editorView.state);\r\n                    options.onTextInput(content);\r\n                }\r\n            },\r\n            editable: () => options.isReadOnly(),\r\n            handleDOMEvents: {\r\n                focus: view => {\r\n                    this.contextMenuService.setVisibility(true);\r\n                },\r\n                blur: view => {\r\n                    this.contextMenuService.setVisibility(false);\r\n                },\r\n            },\r\n            nodeViews: {\r\n                iframe: iframeNodeView,\r\n            },\r\n        });\r\n    }\r\n\r\n    update(text: string) {\r\n        if (this.editorView) {\r\n            const currentText = this.getTextFromState(this.editorView.state);\r\n            if (text !== currentText) {\r\n                let state = this.getStateFromText(text);\r\n                if (document.body.contains(this.editorView.dom)) {\r\n                    const fix = fixTables(state);\r\n                    if (fix) {\r\n                        state = state.apply(fix.setMeta('addToHistory', false));\r\n                    }\r\n                    this.editorView.updateState(state);\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    destroy() {\r\n        if (this.editorView) {\r\n            this.editorView.destroy();\r\n        }\r\n    }\r\n\r\n    setEnabled(enabled: boolean) {\r\n        if (this.editorView) {\r\n            this.enabled = enabled;\r\n            // Updating the state causes ProseMirror to check the\r\n            // `editable()` function from the contructor config object\r\n            // newly.\r\n            this.editorView.updateState(this.editorView.state);\r\n        }\r\n    }\r\n\r\n    private getStateFromText(text: string | null | undefined): EditorState {\r\n        const doc = this.getDetachedDoc();\r\n        const div = doc.createElement('div');\r\n        div.innerHTML = text ?? '';\r\n        return EditorState.create({\r\n            doc: DOMParser.fromSchema(this.mySchema).parse(div),\r\n            plugins: this.configurePlugins({ schema: this.mySchema, floatingMenu: false }),\r\n        });\r\n    }\r\n\r\n    private getTextFromState(state: EditorState): string {\r\n        const doc = this.getDetachedDoc();\r\n        const div = doc.createElement('div');\r\n        const fragment = DOMSerializer.fromSchema(this.mySchema).serializeFragment(state.doc.content);\r\n\r\n        div.appendChild(fragment);\r\n\r\n        return div.innerHTML;\r\n    }\r\n\r\n    private configurePlugins(options: SetupOptions) {\r\n        const plugins = [\r\n            buildInputRules(options.schema),\r\n            keymap(buildKeymap(options.schema, options.mapKeys)),\r\n            keymap(baseKeymap),\r\n            dropCursor(),\r\n            gapCursor(),\r\n            linkSelectPlugin,\r\n            columnResizing({}),\r\n            tableEditing({ allowTableNodeSelection: true }),\r\n            tableContextMenuPlugin(this.contextMenuService),\r\n            imageContextMenuPlugin(this.contextMenuService, this.injector.get(ModalService)),\r\n            rawEditorPlugin(this.contextMenuService, this.injector.get(ModalService)),\r\n            customMenuPlugin({\r\n                floatingMenu: options.floatingMenu,\r\n                injector: this.injector,\r\n                schema: options.schema,\r\n            }),\r\n        ];\r\n        if (options.history !== false) {\r\n            plugins.push(history());\r\n        }\r\n\r\n        return plugins.concat(\r\n            new Plugin({\r\n                props: {\r\n                    attributes: { class: 'vdr-prosemirror' },\r\n                },\r\n            }),\r\n        );\r\n    }\r\n\r\n    private getDetachedDoc() {\r\n        if (!this.detachedDoc) {\r\n            this.detachedDoc = document.implementation.createHTMLDocument();\r\n        }\r\n        return this.detachedDoc;\r\n    }\r\n}\r\n"]}
@@ -26,9 +26,11 @@ export class TabbedCustomFieldsComponent {
26
26
  'password-form-input',
27
27
  'select-form-input',
28
28
  'text-form-input',
29
+ 'relation-form-input',
29
30
  ];
30
31
  return (customField.type === 'text' ||
31
32
  customField.type === 'localeText' ||
33
+ customField.type === 'relation' ||
32
34
  (customField.ui?.component && !smallComponents.includes(customField.ui?.component)));
33
35
  }
34
36
  groupByTabs(customFieldConfigs) {
@@ -65,4 +67,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.3", ngImpor
65
67
  }], showLabel: [{
66
68
  type: Input
67
69
  }] } });
68
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tabbed-custom-fields.component.js","sourceRoot":"","sources":["../../../../../../src/lib/core/src/shared/components/tabbed-custom-fields/tabbed-custom-fields.component.ts","../../../../../../src/lib/core/src/shared/components/tabbed-custom-fields/tabbed-custom-fields.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,KAAK,EAAU,MAAM,eAAe,CAAC;;;;;;AAelF,MAAM,OAAO,2BAA2B;IANxC;QAUa,aAAQ,GAAG,KAAK,CAAC;QACjB,YAAO,GAAG,KAAK,CAAC;QAChB,cAAS,GAAG,IAAI,CAAC;QACjB,mBAAc,GAAG,iBAAiB,CAAC;KA0C/C;IAvCG,QAAQ;QACJ,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IAClE,CAAC;IAED,gBAAgB,CAAC,IAAY;QACzB,OAAO,CAAC,CAAC,IAAI,CAAC,qBAAqB,EAAE,GAAG,CAAC,IAAI,CAAC,CAAC;IACnD,CAAC;IAED,uBAAuB,CAAC,WAA8B;QAClD,MAAM,eAAe,GAA6B;YAC9C,oBAAoB;YACpB,qBAAqB;YACrB,iBAAiB;YACjB,mBAAmB;YACnB,qBAAqB;YACrB,mBAAmB;YACnB,iBAAiB;SACpB,CAAC;QACF,OAAO,CACH,WAAW,CAAC,IAAI,KAAK,MAAM;YAC3B,WAAW,CAAC,IAAI,KAAK,YAAY;YACjC,CAAC,WAAW,CAAC,EAAE,EAAE,SAAS,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,WAAW,CAAC,EAAE,EAAE,SAAS,CAAC,CAAC,CACtF,CAAC;IACN,CAAC;IAEO,WAAW,CAAC,kBAAuC;QACvD,MAAM,MAAM,GAAG,IAAI,GAAG,EAA+B,CAAC;QACtD,KAAK,MAAM,KAAK,IAAI,kBAAkB,EAAE;YACpC,MAAM,OAAO,GAAG,KAAK,CAAC,EAAE,EAAE,GAAG,IAAI,IAAI,CAAC,cAAc,CAAC;YACrD,IAAI,MAAM,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE;gBACrB,MAAM,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;aACpC;iBAAM;gBACH,MAAM,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC;aAChC;SACJ;QACD,OAAO,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;aAC9B,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;aACvD,GAAG,CAAC,CAAC,CAAC,OAAO,EAAE,YAAY,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,OAAO,EAAE,YAAY,EAAE,CAAC,CAAC,CAAC;IACvE,CAAC;8GAhDQ,2BAA2B;kGAA3B,2BAA2B,sPCfxC,qnEA6CA;;2FD9Ba,2BAA2B;kBANvC,SAAS;+BACI,0BAA0B,mBAGnB,uBAAuB,CAAC,MAAM;8BAGtC,UAAU;sBAAlB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,qBAAqB;sBAA7B,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,SAAS;sBAAjB,KAAK","sourcesContent":["import { ChangeDetectionStrategy, Component, Input, OnInit } from '@angular/core';\r\nimport { AbstractControl, FormGroup } from '@angular/forms';\r\nimport { DefaultFormComponentId } from '@vendure/common/lib/shared-types';\r\n\r\nimport { CustomFieldConfig } from '../../../common/generated-types';\r\nimport { CustomFieldEntityName } from '../../../providers/custom-field-component/custom-field-component.service';\r\n\r\nexport type GroupedCustomFields = Array<{ tabName: string; customFields: CustomFieldConfig[] }>;\r\n\r\n@Component({\r\n    selector: 'vdr-tabbed-custom-fields',\r\n    templateUrl: './tabbed-custom-fields.component.html',\r\n    styleUrls: ['./tabbed-custom-fields.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class TabbedCustomFieldsComponent implements OnInit {\r\n    @Input() entityName: CustomFieldEntityName;\r\n    @Input() customFields: CustomFieldConfig[];\r\n    @Input() customFieldsFormGroup: AbstractControl;\r\n    @Input() readonly = false;\r\n    @Input() compact = false;\r\n    @Input() showLabel = true;\r\n    readonly defaultTabName = '__default_tab__';\r\n    tabbedCustomFields: GroupedCustomFields;\r\n\r\n    ngOnInit(): void {\r\n        this.tabbedCustomFields = this.groupByTabs(this.customFields);\r\n    }\r\n\r\n    customFieldIsSet(name: string): boolean {\r\n        return !!this.customFieldsFormGroup?.get(name);\r\n    }\r\n\r\n    componentShouldSpanGrid(customField: CustomFieldConfig): boolean {\r\n        const smallComponents: DefaultFormComponentId[] = [\r\n            'boolean-form-input',\r\n            'currency-form-input',\r\n            'date-form-input',\r\n            'number-form-input',\r\n            'password-form-input',\r\n            'select-form-input',\r\n            'text-form-input',\r\n        ];\r\n        return (\r\n            customField.type === 'text' ||\r\n            customField.type === 'localeText' ||\r\n            (customField.ui?.component && !smallComponents.includes(customField.ui?.component))\r\n        );\r\n    }\r\n\r\n    private groupByTabs(customFieldConfigs: CustomFieldConfig[]): GroupedCustomFields {\r\n        const tabMap = new Map<string, CustomFieldConfig[]>();\r\n        for (const field of customFieldConfigs) {\r\n            const tabName = field.ui?.tab ?? this.defaultTabName;\r\n            if (tabMap.has(tabName)) {\r\n                tabMap.get(tabName)?.push(field);\r\n            } else {\r\n                tabMap.set(tabName, [field]);\r\n            }\r\n        }\r\n        return Array.from(tabMap.entries())\r\n            .sort((a, b) => (a[0] === this.defaultTabName ? -1 : 1))\r\n            .map(([tabName, customFields]) => ({ tabName, customFields }));\r\n    }\r\n}\r\n","<ng-container *ngIf=\"1 < tabbedCustomFields.length; else singleGroup\">\r\n    <clr-tabs>\r\n        <clr-tab *ngFor=\"let group of tabbedCustomFields\">\r\n            <button clrTabLink>\r\n                {{\r\n                    group.tabName === defaultTabName\r\n                        ? ('common.general' | translate)\r\n                        : (group.tabName | translate)\r\n                }}\r\n            </button>\r\n            <clr-tab-content *clrIfActive>\r\n                <div class=\"mt-2 form-grid\">\r\n                    <ng-container *ngFor=\"let customField of group.customFields\">\r\n                        <vdr-custom-field-control\r\n                            *ngIf=\"customFieldIsSet(customField.name)\"\r\n                            [entityName]=\"entityName\"\r\n                            [class.form-grid-span]=\"componentShouldSpanGrid(customField)\"\r\n                            [customFieldsFormGroup]=\"customFieldsFormGroup\"\r\n                            [customField]=\"customField\"\r\n                            [readonly]=\"readonly\"\r\n                            [compact]=\"compact\"\r\n                            [showLabel]=\"showLabel\"\r\n                        ></vdr-custom-field-control>\r\n                    </ng-container>\r\n                </div>\r\n            </clr-tab-content>\r\n        </clr-tab>\r\n    </clr-tabs>\r\n</ng-container>\r\n<ng-template #singleGroup>\r\n    <div class=\"form-grid\">\r\n        <ng-container *ngFor=\"let customField of tabbedCustomFields[0]?.customFields\">\r\n            <vdr-custom-field-control\r\n                *ngIf=\"customFieldIsSet(customField.name)\"\r\n                [entityName]=\"entityName\"\r\n                [class.form-grid-span]=\"componentShouldSpanGrid(customField)\"\r\n                [customFieldsFormGroup]=\"customFieldsFormGroup\"\r\n                [customField]=\"customField\"\r\n                [readonly]=\"readonly\"\r\n                [compact]=\"compact\"\r\n                [showLabel]=\"showLabel\"\r\n            ></vdr-custom-field-control>\r\n        </ng-container>\r\n    </div>\r\n</ng-template>\r\n"]}
70
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tabbed-custom-fields.component.js","sourceRoot":"","sources":["../../../../../../src/lib/core/src/shared/components/tabbed-custom-fields/tabbed-custom-fields.component.ts","../../../../../../src/lib/core/src/shared/components/tabbed-custom-fields/tabbed-custom-fields.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,KAAK,EAAU,MAAM,eAAe,CAAC;;;;;;AAelF,MAAM,OAAO,2BAA2B;IANxC;QAUa,aAAQ,GAAG,KAAK,CAAC;QACjB,YAAO,GAAG,KAAK,CAAC;QAChB,cAAS,GAAG,IAAI,CAAC;QACjB,mBAAc,GAAG,iBAAiB,CAAC;KA4C/C;IAzCG,QAAQ;QACJ,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IAClE,CAAC;IAED,gBAAgB,CAAC,IAAY;QACzB,OAAO,CAAC,CAAC,IAAI,CAAC,qBAAqB,EAAE,GAAG,CAAC,IAAI,CAAC,CAAC;IACnD,CAAC;IAED,uBAAuB,CAAC,WAA8B;QAClD,MAAM,eAAe,GAA6B;YAC9C,oBAAoB;YACpB,qBAAqB;YACrB,iBAAiB;YACjB,mBAAmB;YACnB,qBAAqB;YACrB,mBAAmB;YACnB,iBAAiB;YACjB,qBAAqB;SACxB,CAAC;QACF,OAAO,CACH,WAAW,CAAC,IAAI,KAAK,MAAM;YAC3B,WAAW,CAAC,IAAI,KAAK,YAAY;YACjC,WAAW,CAAC,IAAI,KAAK,UAAU;YAC/B,CAAC,WAAW,CAAC,EAAE,EAAE,SAAS,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,WAAW,CAAC,EAAE,EAAE,SAAS,CAAC,CAAC,CACtF,CAAC;IACN,CAAC;IAEO,WAAW,CAAC,kBAAuC;QACvD,MAAM,MAAM,GAAG,IAAI,GAAG,EAA+B,CAAC;QACtD,KAAK,MAAM,KAAK,IAAI,kBAAkB,EAAE;YACpC,MAAM,OAAO,GAAG,KAAK,CAAC,EAAE,EAAE,GAAG,IAAI,IAAI,CAAC,cAAc,CAAC;YACrD,IAAI,MAAM,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE;gBACrB,MAAM,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;aACpC;iBAAM;gBACH,MAAM,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC;aAChC;SACJ;QACD,OAAO,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;aAC9B,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;aACvD,GAAG,CAAC,CAAC,CAAC,OAAO,EAAE,YAAY,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,OAAO,EAAE,YAAY,EAAE,CAAC,CAAC,CAAC;IACvE,CAAC;8GAlDQ,2BAA2B;kGAA3B,2BAA2B,sPCfxC,qnEA6CA;;2FD9Ba,2BAA2B;kBANvC,SAAS;+BACI,0BAA0B,mBAGnB,uBAAuB,CAAC,MAAM;8BAGtC,UAAU;sBAAlB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,qBAAqB;sBAA7B,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,SAAS;sBAAjB,KAAK","sourcesContent":["import { ChangeDetectionStrategy, Component, Input, OnInit } from '@angular/core';\nimport { AbstractControl, FormGroup } from '@angular/forms';\nimport { DefaultFormComponentId } from '@vendure/common/lib/shared-types';\n\nimport { CustomFieldConfig } from '../../../common/generated-types';\nimport { CustomFieldEntityName } from '../../../providers/custom-field-component/custom-field-component.service';\n\nexport type GroupedCustomFields = Array<{ tabName: string; customFields: CustomFieldConfig[] }>;\n\n@Component({\n    selector: 'vdr-tabbed-custom-fields',\n    templateUrl: './tabbed-custom-fields.component.html',\n    styleUrls: ['./tabbed-custom-fields.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TabbedCustomFieldsComponent implements OnInit {\n    @Input() entityName: CustomFieldEntityName;\n    @Input() customFields: CustomFieldConfig[];\n    @Input() customFieldsFormGroup: AbstractControl;\n    @Input() readonly = false;\n    @Input() compact = false;\n    @Input() showLabel = true;\n    readonly defaultTabName = '__default_tab__';\n    tabbedCustomFields: GroupedCustomFields;\n\n    ngOnInit(): void {\n        this.tabbedCustomFields = this.groupByTabs(this.customFields);\n    }\n\n    customFieldIsSet(name: string): boolean {\n        return !!this.customFieldsFormGroup?.get(name);\n    }\n\n    componentShouldSpanGrid(customField: CustomFieldConfig): boolean {\n        const smallComponents: DefaultFormComponentId[] = [\n            'boolean-form-input',\n            'currency-form-input',\n            'date-form-input',\n            'number-form-input',\n            'password-form-input',\n            'select-form-input',\n            'text-form-input',\n            'relation-form-input',\n        ];\n        return (\n            customField.type === 'text' ||\n            customField.type === 'localeText' ||\n            customField.type === 'relation' ||\n            (customField.ui?.component && !smallComponents.includes(customField.ui?.component))\n        );\n    }\n\n    private groupByTabs(customFieldConfigs: CustomFieldConfig[]): GroupedCustomFields {\n        const tabMap = new Map<string, CustomFieldConfig[]>();\n        for (const field of customFieldConfigs) {\n            const tabName = field.ui?.tab ?? this.defaultTabName;\n            if (tabMap.has(tabName)) {\n                tabMap.get(tabName)?.push(field);\n            } else {\n                tabMap.set(tabName, [field]);\n            }\n        }\n        return Array.from(tabMap.entries())\n            .sort((a, b) => (a[0] === this.defaultTabName ? -1 : 1))\n            .map(([tabName, customFields]) => ({ tabName, customFields }));\n    }\n}\n","<ng-container *ngIf=\"1 < tabbedCustomFields.length; else singleGroup\">\r\n    <clr-tabs>\r\n        <clr-tab *ngFor=\"let group of tabbedCustomFields\">\r\n            <button clrTabLink>\r\n                {{\r\n                    group.tabName === defaultTabName\r\n                        ? ('common.general' | translate)\r\n                        : (group.tabName | translate)\r\n                }}\r\n            </button>\r\n            <clr-tab-content *clrIfActive>\r\n                <div class=\"mt-2 form-grid\">\r\n                    <ng-container *ngFor=\"let customField of group.customFields\">\r\n                        <vdr-custom-field-control\r\n                            *ngIf=\"customFieldIsSet(customField.name)\"\r\n                            [entityName]=\"entityName\"\r\n                            [class.form-grid-span]=\"componentShouldSpanGrid(customField)\"\r\n                            [customFieldsFormGroup]=\"customFieldsFormGroup\"\r\n                            [customField]=\"customField\"\r\n                            [readonly]=\"readonly\"\r\n                            [compact]=\"compact\"\r\n                            [showLabel]=\"showLabel\"\r\n                        ></vdr-custom-field-control>\r\n                    </ng-container>\r\n                </div>\r\n            </clr-tab-content>\r\n        </clr-tab>\r\n    </clr-tabs>\r\n</ng-container>\r\n<ng-template #singleGroup>\r\n    <div class=\"form-grid\">\r\n        <ng-container *ngFor=\"let customField of tabbedCustomFields[0]?.customFields\">\r\n            <vdr-custom-field-control\r\n                *ngIf=\"customFieldIsSet(customField.name)\"\r\n                [entityName]=\"entityName\"\r\n                [class.form-grid-span]=\"componentShouldSpanGrid(customField)\"\r\n                [customFieldsFormGroup]=\"customFieldsFormGroup\"\r\n                [customField]=\"customField\"\r\n                [readonly]=\"readonly\"\r\n                [compact]=\"compact\"\r\n                [showLabel]=\"showLabel\"\r\n            ></vdr-custom-field-control>\r\n        </ng-container>\r\n    </div>\r\n</ng-template>\r\n"]}