@vendure/admin-ui 2.2.6 → 2.2.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/core/common/version.d.ts +1 -1
- package/core/extension/components/angular-route.component.d.ts +20 -0
- package/core/shared/components/order-state-label/order-state-label.component.d.ts +1 -1
- package/core/shared/providers/routing/can-deactivate-detail-guard.d.ts +2 -4
- package/esm2022/catalog/components/create-product-variant-dialog/create-product-variant-dialog.component.mjs +2 -2
- package/esm2022/catalog/components/facet-detail/facet-detail.component.mjs +8 -8
- package/esm2022/catalog/components/generate-product-variants/generate-product-variants.component.mjs +2 -1
- package/esm2022/core/common/version.mjs +2 -2
- package/esm2022/core/extension/components/angular-route.component.mjs +51 -6
- package/esm2022/core/shared/components/facet-value-selector/facet-value-selector.component.mjs +1 -1
- package/esm2022/core/shared/components/rich-text-editor/rich-text-editor.component.mjs +2 -2
- package/esm2022/core/shared/providers/routing/can-deactivate-detail-guard.mjs +6 -8
- package/esm2022/react/react-components/RichTextEditor.mjs +8 -4
- package/fesm2022/vendure-admin-ui-catalog.mjs +9 -8
- package/fesm2022/vendure-admin-ui-catalog.mjs.map +1 -1
- package/fesm2022/vendure-admin-ui-core.mjs +58 -13
- package/fesm2022/vendure-admin-ui-core.mjs.map +1 -1
- package/fesm2022/vendure-admin-ui-react.mjs +7 -3
- package/fesm2022/vendure-admin-ui-react.mjs.map +1 -1
- package/package.json +18 -18
- package/react/react-components/RichTextEditor.d.ts +2 -0
- package/static/styles/component/prosemirror.scss +511 -0
- package/static/styles/styles.scss +2 -0
|
@@ -1,22 +1,67 @@
|
|
|
1
|
-
import { Component, inject } from '@angular/core';
|
|
1
|
+
import { Component, EventEmitter, inject, Input, Output, } from '@angular/core';
|
|
2
2
|
import { SharedModule } from '../../shared/shared.module';
|
|
3
3
|
import { ROUTE_COMPONENT_OPTIONS, RouteComponent } from './route.component';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
|
-
|
|
5
|
+
/**
|
|
6
|
+
* @description
|
|
7
|
+
* This component is used internally to allow us to dynamically load a component
|
|
8
|
+
* like with `*ngComponentOutlet`, but with the ability to get a reference to the
|
|
9
|
+
* created ComponentRef. This can then be used to delegate lifecycle events like
|
|
10
|
+
* `canDeactivate` to the loaded component.
|
|
11
|
+
*/
|
|
12
|
+
export class DynamicComponentLoaderComponent {
|
|
13
|
+
constructor(viewContainer) {
|
|
14
|
+
this.viewContainer = viewContainer;
|
|
15
|
+
this.loaded = new EventEmitter();
|
|
16
|
+
}
|
|
17
|
+
ngOnInit() {
|
|
18
|
+
const componentRef = this.viewContainer.createComponent(this.componentType);
|
|
19
|
+
this.loaded.emit(componentRef);
|
|
20
|
+
}
|
|
21
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: DynamicComponentLoaderComponent, deps: [{ token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
22
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.4", type: DynamicComponentLoaderComponent, isStandalone: true, selector: "vdr-dynamic-component-loader", inputs: { componentType: "componentType" }, outputs: { loaded: "loaded" }, ngImport: i0, template: ``, isInline: true, dependencies: [{ kind: "ngmodule", type: SharedModule }] }); }
|
|
23
|
+
}
|
|
24
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: DynamicComponentLoaderComponent, decorators: [{
|
|
25
|
+
type: Component,
|
|
26
|
+
args: [{
|
|
27
|
+
selector: 'vdr-dynamic-component-loader',
|
|
28
|
+
template: ``,
|
|
29
|
+
standalone: true,
|
|
30
|
+
imports: [SharedModule],
|
|
31
|
+
}]
|
|
32
|
+
}], ctorParameters: () => [{ type: i0.ViewContainerRef }], propDecorators: { componentType: [{
|
|
33
|
+
type: Input
|
|
34
|
+
}], loaded: [{
|
|
35
|
+
type: Output
|
|
36
|
+
}] } });
|
|
6
37
|
export class AngularRouteComponent {
|
|
7
38
|
constructor() {
|
|
8
39
|
this.component = inject(ROUTE_COMPONENT_OPTIONS).component;
|
|
9
40
|
}
|
|
41
|
+
componentLoaded(componentRef) {
|
|
42
|
+
this.componentRef = componentRef;
|
|
43
|
+
}
|
|
44
|
+
canDeactivate() {
|
|
45
|
+
return this.componentRef?.instance?.canDeactivate?.();
|
|
46
|
+
}
|
|
10
47
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: AngularRouteComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
11
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.4", type: AngularRouteComponent, isStandalone: true, selector: "vdr-angular-route-component", ngImport: i0, template: `
|
|
48
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.4", type: AngularRouteComponent, isStandalone: true, selector: "vdr-angular-route-component", ngImport: i0, template: `
|
|
49
|
+
<vdr-route-component>
|
|
50
|
+
<vdr-dynamic-component-loader [componentType]="component" (loaded)="componentLoaded($event)" />
|
|
51
|
+
</vdr-route-component>
|
|
52
|
+
`, isInline: true, dependencies: [{ kind: "ngmodule", type: SharedModule }, { kind: "component", type: RouteComponent, selector: "vdr-route-component" }, { kind: "component", type: DynamicComponentLoaderComponent, selector: "vdr-dynamic-component-loader", inputs: ["componentType"], outputs: ["loaded"] }] }); }
|
|
12
53
|
}
|
|
13
54
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: AngularRouteComponent, decorators: [{
|
|
14
55
|
type: Component,
|
|
15
56
|
args: [{
|
|
16
57
|
selector: 'vdr-angular-route-component',
|
|
17
|
-
template: `
|
|
58
|
+
template: `
|
|
59
|
+
<vdr-route-component>
|
|
60
|
+
<vdr-dynamic-component-loader [componentType]="component" (loaded)="componentLoaded($event)" />
|
|
61
|
+
</vdr-route-component>
|
|
62
|
+
`,
|
|
18
63
|
standalone: true,
|
|
19
|
-
imports: [SharedModule, RouteComponent],
|
|
64
|
+
imports: [SharedModule, RouteComponent, DynamicComponentLoaderComponent],
|
|
20
65
|
}]
|
|
21
66
|
}] });
|
|
22
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
67
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhci1yb3V0ZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvcmUvc3JjL2V4dGVuc2lvbi9jb21wb25lbnRzL2FuZ3VsYXItcm91dGUuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDSCxTQUFTLEVBRVQsWUFBWSxFQUNaLE1BQU0sRUFDTixLQUFLLEVBRUwsTUFBTSxHQUVULE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUMxRCxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsY0FBYyxFQUFFLE1BQU0sbUJBQW1CLENBQUM7O0FBRTVFOzs7Ozs7R0FNRztBQU9ILE1BQU0sT0FBTywrQkFBK0I7SUFHeEMsWUFBb0IsYUFBK0I7UUFBL0Isa0JBQWEsR0FBYixhQUFhLENBQWtCO1FBRHpDLFdBQU0sR0FBRyxJQUFJLFlBQVksRUFBcUIsQ0FBQztJQUNILENBQUM7SUFFdkQsUUFBUTtRQUNKLE1BQU0sWUFBWSxHQUFHLElBQUksQ0FBQyxhQUFhLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUM1RSxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQztJQUNuQyxDQUFDOzhHQVJRLCtCQUErQjtrR0FBL0IsK0JBQStCLG1LQUo5QixFQUFFLDJEQUVGLFlBQVk7OzJGQUViLCtCQUErQjtrQkFOM0MsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsOEJBQThCO29CQUN4QyxRQUFRLEVBQUUsRUFBRTtvQkFDWixVQUFVLEVBQUUsSUFBSTtvQkFDaEIsT0FBTyxFQUFFLENBQUMsWUFBWSxDQUFDO2lCQUMxQjtxRkFFWSxhQUFhO3NCQUFyQixLQUFLO2dCQUNJLE1BQU07c0JBQWYsTUFBTTs7QUFtQlgsTUFBTSxPQUFPLHFCQUFxQjtJQVZsQztRQVdjLGNBQVMsR0FBRyxNQUFNLENBQUMsdUJBQXVCLENBQUMsQ0FBQyxTQUFTLENBQUM7S0FVbkU7SUFQRyxlQUFlLENBQUMsWUFBK0I7UUFDM0MsSUFBSSxDQUFDLFlBQVksR0FBRyxZQUFZLENBQUM7SUFDckMsQ0FBQztJQUVELGFBQWE7UUFDVCxPQUFPLElBQUksQ0FBQyxZQUFZLEVBQUUsUUFBUSxFQUFFLGFBQWEsRUFBRSxFQUFFLENBQUM7SUFDMUQsQ0FBQzs4R0FWUSxxQkFBcUI7a0dBQXJCLHFCQUFxQix1RkFScEI7Ozs7S0FJVCwyREFFUyxZQUFZLCtCQUFFLGNBQWMsZ0VBbkI3QiwrQkFBK0I7OzJGQXFCL0IscUJBQXFCO2tCQVZqQyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSw2QkFBNkI7b0JBQ3ZDLFFBQVEsRUFBRTs7OztLQUlUO29CQUNELFVBQVUsRUFBRSxJQUFJO29CQUNoQixPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsY0FBYyxFQUFFLCtCQUErQixDQUFDO2lCQUMzRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gICAgQ29tcG9uZW50LFxuICAgIENvbXBvbmVudFJlZixcbiAgICBFdmVudEVtaXR0ZXIsXG4gICAgaW5qZWN0LFxuICAgIElucHV0LFxuICAgIE9uSW5pdCxcbiAgICBPdXRwdXQsXG4gICAgVmlld0NvbnRhaW5lclJlZixcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTaGFyZWRNb2R1bGUgfSBmcm9tICcuLi8uLi9zaGFyZWQvc2hhcmVkLm1vZHVsZSc7XG5pbXBvcnQgeyBST1VURV9DT01QT05FTlRfT1BUSU9OUywgUm91dGVDb21wb25lbnQgfSBmcm9tICcuL3JvdXRlLmNvbXBvbmVudCc7XG5cbi8qKlxuICogQGRlc2NyaXB0aW9uXG4gKiBUaGlzIGNvbXBvbmVudCBpcyB1c2VkIGludGVybmFsbHkgdG8gYWxsb3cgdXMgdG8gZHluYW1pY2FsbHkgbG9hZCBhIGNvbXBvbmVudFxuICogbGlrZSB3aXRoIGAqbmdDb21wb25lbnRPdXRsZXRgLCBidXQgd2l0aCB0aGUgYWJpbGl0eSB0byBnZXQgYSByZWZlcmVuY2UgdG8gdGhlXG4gKiBjcmVhdGVkIENvbXBvbmVudFJlZi4gVGhpcyBjYW4gdGhlbiBiZSB1c2VkIHRvIGRlbGVnYXRlIGxpZmVjeWNsZSBldmVudHMgbGlrZVxuICogYGNhbkRlYWN0aXZhdGVgIHRvIHRoZSBsb2FkZWQgY29tcG9uZW50LlxuICovXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ3Zkci1keW5hbWljLWNvbXBvbmVudC1sb2FkZXInLFxuICAgIHRlbXBsYXRlOiBgYCxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIGltcG9ydHM6IFtTaGFyZWRNb2R1bGVdLFxufSlcbmV4cG9ydCBjbGFzcyBEeW5hbWljQ29tcG9uZW50TG9hZGVyQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgICBASW5wdXQoKSBjb21wb25lbnRUeXBlOiBhbnk7XG4gICAgQE91dHB1dCgpIGxvYWRlZCA9IG5ldyBFdmVudEVtaXR0ZXI8Q29tcG9uZW50UmVmPGFueT4+KCk7XG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSB2aWV3Q29udGFpbmVyOiBWaWV3Q29udGFpbmVyUmVmKSB7fVxuXG4gICAgbmdPbkluaXQoKSB7XG4gICAgICAgIGNvbnN0IGNvbXBvbmVudFJlZiA9IHRoaXMudmlld0NvbnRhaW5lci5jcmVhdGVDb21wb25lbnQodGhpcy5jb21wb25lbnRUeXBlKTtcbiAgICAgICAgdGhpcy5sb2FkZWQuZW1pdChjb21wb25lbnRSZWYpO1xuICAgIH1cbn1cblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICd2ZHItYW5ndWxhci1yb3V0ZS1jb21wb25lbnQnLFxuICAgIHRlbXBsYXRlOiBgXG4gICAgICAgIDx2ZHItcm91dGUtY29tcG9uZW50PlxuICAgICAgICAgICAgPHZkci1keW5hbWljLWNvbXBvbmVudC1sb2FkZXIgW2NvbXBvbmVudFR5cGVdPVwiY29tcG9uZW50XCIgKGxvYWRlZCk9XCJjb21wb25lbnRMb2FkZWQoJGV2ZW50KVwiIC8+XG4gICAgICAgIDwvdmRyLXJvdXRlLWNvbXBvbmVudD5cbiAgICBgLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaW1wb3J0czogW1NoYXJlZE1vZHVsZSwgUm91dGVDb21wb25lbnQsIER5bmFtaWNDb21wb25lbnRMb2FkZXJDb21wb25lbnRdLFxufSlcbmV4cG9ydCBjbGFzcyBBbmd1bGFyUm91dGVDb21wb25lbnQge1xuICAgIHByb3RlY3RlZCBjb21wb25lbnQgPSBpbmplY3QoUk9VVEVfQ09NUE9ORU5UX09QVElPTlMpLmNvbXBvbmVudDtcbiAgICBwcm90ZWN0ZWQgY29tcG9uZW50UmVmOiBDb21wb25lbnRSZWY8YW55PjtcblxuICAgIGNvbXBvbmVudExvYWRlZChjb21wb25lbnRSZWY6IENvbXBvbmVudFJlZjxhbnk+KSB7XG4gICAgICAgIHRoaXMuY29tcG9uZW50UmVmID0gY29tcG9uZW50UmVmO1xuICAgIH1cblxuICAgIGNhbkRlYWN0aXZhdGUoKSB7XG4gICAgICAgIHJldHVybiB0aGlzLmNvbXBvbmVudFJlZj8uaW5zdGFuY2U/LmNhbkRlYWN0aXZhdGU/LigpO1xuICAgIH1cbn1cbiJdfQ==
|
package/esm2022/core/shared/components/facet-value-selector/facet-value-selector.component.mjs
CHANGED
|
@@ -147,4 +147,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImpor
|
|
|
147
147
|
type: ViewChild,
|
|
148
148
|
args: [NgSelectComponent]
|
|
149
149
|
}] } });
|
|
150
|
-
//# 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 {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    EventEmitter,\n    Input,\n    OnDestroy,\n    OnInit,\n    Output,\n    ViewChild,\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { NgSelectComponent } from '@ng-select/ng-select';\nimport { concat, merge, Observable, of, Subject, Subscription } from 'rxjs';\nimport { debounceTime, distinctUntilChanged, mapTo, switchMap, tap } from 'rxjs/operators';\n\nimport { FacetValue, FacetValueFragment } from '../../../common/generated-types';\nimport { DataService } from '../../../data/providers/data.service';\n\n/**\n * @description\n * A form control for selecting facet values.\n *\n * @example\n * ```HTML\n * <vdr-facet-value-selector\n *   (selectedValuesChange)=\"selectedValues = $event\"\n * ></vdr-facet-value-selector>\n * ```\n * The `selectedValuesChange` event will emit an array of `FacetValue` objects.\n *\n * @docsCategory components\n */\n@Component({\n    selector: 'vdr-facet-value-selector',\n    templateUrl: './facet-value-selector.component.html',\n    styleUrls: ['./facet-value-selector.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: FacetValueSelectorComponent,\n            multi: true,\n        },\n    ],\n})\nexport class FacetValueSelectorComponent implements OnInit, OnDestroy, ControlValueAccessor {\n    @Output() selectedValuesChange = new EventEmitter<FacetValueFragment[]>();\n    @Input() readonly = false;\n    @Input() transformControlValueAccessorValue: (value: FacetValueFragment[]) => any[] = value => value;\n    searchInput$ = new Subject<string>();\n    searchLoading = false;\n    searchResults$: Observable<FacetValueFragment[]>;\n    selectedIds$ = new Subject<string[]>();\n\n    @ViewChild(NgSelectComponent) private ngSelect: NgSelectComponent;\n\n    onChangeFn: (val: any) => void;\n    onTouchFn: () => void;\n    disabled = false;\n    value: Array<string | FacetValueFragment>;\n    private subscription: Subscription;\n    constructor(\n        private dataService: DataService,\n        private changeDetectorRef: ChangeDetectorRef,\n    ) {}\n\n    ngOnInit(): void {\n        this.initSearchResults();\n    }\n\n    private initSearchResults() {\n        const searchItems$ = this.searchInput$.pipe(\n            debounceTime(200),\n            distinctUntilChanged(),\n            tap(() => (this.searchLoading = true)),\n            switchMap(term => {\n                if (!term) {\n                    return of([]);\n                }\n                return this.dataService.facet\n                    .getFacetValues({ take: 100, filter: { name: { contains: term } } })\n                    .mapSingle(result => result.facetValues.items);\n            }),\n            tap(() => (this.searchLoading = false)),\n        );\n        this.subscription = this.selectedIds$\n            .pipe(\n                switchMap(ids => {\n                    if (!ids.length) {\n                        return of([]);\n                    }\n                    return this.dataService.facet\n                        .getFacetValues({ take: 100, filter: { id: { in: ids } } }, 'cache-first')\n                        .mapSingle(result => result.facetValues.items);\n                }),\n            )\n            .subscribe(val => {\n                this.value = val;\n                this.changeDetectorRef.markForCheck();\n            });\n\n        const clear$ = this.selectedValuesChange.pipe(mapTo([]));\n        this.searchResults$ = concat(of([]), merge(searchItems$, clear$));\n    }\n    ngOnDestroy() {\n        this.subscription?.unsubscribe();\n    }\n\n    onChange(selected: FacetValueFragment[]) {\n        if (this.readonly) {\n            return;\n        }\n        for (const sel of selected) {\n            console.log(`selected: ${sel.facet.name}:${sel.code}`);\n        }\n        this.selectedValuesChange.emit(selected);\n        if (this.onChangeFn) {\n            const transformedValue = this.transformControlValueAccessorValue(selected);\n            this.onChangeFn(transformedValue);\n        }\n    }\n\n    registerOnChange(fn: any) {\n        this.onChangeFn = fn;\n    }\n\n    registerOnTouched(fn: any) {\n        this.onTouchFn = fn;\n    }\n\n    setDisabledState(isDisabled: boolean): void {\n        this.disabled = isDisabled;\n    }\n\n    focus() {\n        this.ngSelect.focus();\n    }\n\n    writeValue(obj: string | FacetValueFragment[] | Array<string | number> | null): void {\n        let valueIds: string[] | undefined;\n        if (typeof obj === 'string') {\n            try {\n                const facetValueIds = JSON.parse(obj) as string[];\n                valueIds = facetValueIds;\n            } catch (err) {\n                // TODO: log error\n                throw err;\n            }\n        } else if (Array.isArray(obj)) {\n            const isIdArray = (input: unknown[]): input is Array<string | number> =>\n                input.every(i => typeof i === 'number' || typeof i === 'string');\n            if (isIdArray(obj)) {\n                valueIds = obj.map(fv => fv.toString());\n            } else {\n                valueIds = obj.map(fv => fv.id);\n            }\n        }\n        if (valueIds) {\n            // this.value = valueIds;\n            this.selectedIds$.next(valueIds);\n        }\n    }\n}\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=\"id\"\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"]}
|
|
150
|
+
//# 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 *   (selectedValuesChange)=\"selectedValues = $event\"\r\n * ></vdr-facet-value-selector>\r\n * ```\r\n * The `selectedValuesChange` event will emit an array of `FacetValue` objects.\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(\r\n        private dataService: DataService,\r\n        private changeDetectorRef: ChangeDetectorRef,\r\n    ) {}\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        for (const sel of selected) {\r\n            console.log(`selected: ${sel.facet.name}:${sel.code}`);\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=\"id\"\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"]}
|
|
@@ -79,7 +79,7 @@ export class RichTextEditorComponent {
|
|
|
79
79
|
},
|
|
80
80
|
ProsemirrorService,
|
|
81
81
|
ContextMenuService,
|
|
82
|
-
], viewQueries: [{ propertyName: "editorEl", first: true, predicate: ["editor"], descendants: true, static: true }], ngImport: i0, template: "<label *ngIf=\"label\" class=\"rich-text-label\">{{ label }}</label>\r\n<div #editor></div>\r\n<vdr-context-menu [editorMenuElement]=\"menuElement\"></vdr-context-menu>\r\n", styles: ["
|
|
82
|
+
], viewQueries: [{ propertyName: "editorEl", first: true, predicate: ["editor"], descendants: true, static: true }], ngImport: i0, template: "<label *ngIf=\"label\" class=\"rich-text-label\">{{ label }}</label>\r\n<div #editor></div>\r\n<vdr-context-menu [editorMenuElement]=\"menuElement\"></vdr-context-menu>\r\n", styles: [":host{display:block;margin-bottom:.5rem}:host.readonly ::ng-deep .ProseMirror-menubar{display:none}.context-menu{position:fixed}\n"], dependencies: [{ kind: "directive", type: i3.ClrLabel, selector: "label", inputs: ["for"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.ContextMenuComponent, selector: "vdr-context-menu", inputs: ["editorMenuElement"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
83
83
|
}
|
|
84
84
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: RichTextEditorComponent, decorators: [{
|
|
85
85
|
type: Component,
|
|
@@ -91,7 +91,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImpor
|
|
|
91
91
|
},
|
|
92
92
|
ProsemirrorService,
|
|
93
93
|
ContextMenuService,
|
|
94
|
-
], template: "<label *ngIf=\"label\" class=\"rich-text-label\">{{ label }}</label>\r\n<div #editor></div>\r\n<vdr-context-menu [editorMenuElement]=\"menuElement\"></vdr-context-menu>\r\n", styles: ["
|
|
94
|
+
], template: "<label *ngIf=\"label\" class=\"rich-text-label\">{{ label }}</label>\r\n<div #editor></div>\r\n<vdr-context-menu [editorMenuElement]=\"menuElement\"></vdr-context-menu>\r\n", styles: [":host{display:block;margin-bottom:.5rem}:host.readonly ::ng-deep .ProseMirror-menubar{display:none}.context-menu{position:fixed}\n"] }]
|
|
95
95
|
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.ProsemirrorService }, { type: i0.ViewContainerRef }, { type: i2.ContextMenuService }], propDecorators: { label: [{
|
|
96
96
|
type: Input
|
|
97
97
|
}], readonly: [{
|
|
@@ -3,14 +3,12 @@ import { marker as _ } from '@biesbjerg/ngx-translate-extract-marker';
|
|
|
3
3
|
import { map } from 'rxjs/operators';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
import * as i1 from "../../../providers/modal/modal.service";
|
|
6
|
-
import * as i2 from "@angular/router";
|
|
7
6
|
export class CanDeactivateDetailGuard {
|
|
8
|
-
constructor(modalService
|
|
7
|
+
constructor(modalService) {
|
|
9
8
|
this.modalService = modalService;
|
|
10
|
-
this.router = router;
|
|
11
9
|
}
|
|
12
|
-
canDeactivate(component
|
|
13
|
-
if (!component.canDeactivate()) {
|
|
10
|
+
canDeactivate(component) {
|
|
11
|
+
if (typeof component.canDeactivate === 'function' && !component.canDeactivate()) {
|
|
14
12
|
return this.modalService
|
|
15
13
|
.dialog({
|
|
16
14
|
title: _('common.confirm-navigation'),
|
|
@@ -26,10 +24,10 @@ export class CanDeactivateDetailGuard {
|
|
|
26
24
|
return true;
|
|
27
25
|
}
|
|
28
26
|
}
|
|
29
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: CanDeactivateDetailGuard, deps: [{ token: i1.ModalService }
|
|
27
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: CanDeactivateDetailGuard, deps: [{ token: i1.ModalService }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
30
28
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: CanDeactivateDetailGuard }); }
|
|
31
29
|
}
|
|
32
30
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: CanDeactivateDetailGuard, decorators: [{
|
|
33
31
|
type: Injectable
|
|
34
|
-
}], ctorParameters: () => [{ type: i1.ModalService }
|
|
35
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
32
|
+
}], ctorParameters: () => [{ type: i1.ModalService }] });
|
|
33
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FuLWRlYWN0aXZhdGUtZGV0YWlsLWd1YXJkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL2xpYi9jb3JlL3NyYy9zaGFyZWQvcHJvdmlkZXJzL3JvdXRpbmcvY2FuLWRlYWN0aXZhdGUtZGV0YWlsLWd1YXJkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0MsT0FBTyxFQUFFLE1BQU0sSUFBSSxDQUFDLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQztBQUV0RSxPQUFPLEVBQUUsR0FBRyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7OztBQU1yQyxNQUFNLE9BQU8sd0JBQXdCO0lBQ2pDLFlBQW9CLFlBQTBCO1FBQTFCLGlCQUFZLEdBQVosWUFBWSxDQUFjO0lBQUcsQ0FBQztJQUVsRCxhQUFhLENBQUMsU0FBMEI7UUFDcEMsSUFBSSxPQUFPLFNBQVMsQ0FBQyxhQUFhLEtBQUssVUFBVSxJQUFJLENBQUMsU0FBUyxDQUFDLGFBQWEsRUFBRSxFQUFFLENBQUM7WUFDOUUsT0FBTyxJQUFJLENBQUMsWUFBWTtpQkFDbkIsTUFBTSxDQUFDO2dCQUNKLEtBQUssRUFBRSxDQUFDLENBQUMsMkJBQTJCLENBQUM7Z0JBQ3JDLElBQUksRUFBRSxDQUFDLENBQUMsa0NBQWtDLENBQUM7Z0JBQzNDLE9BQU8sRUFBRTtvQkFDTCxFQUFFLElBQUksRUFBRSxRQUFRLEVBQUUsS0FBSyxFQUFFLENBQUMsQ0FBQyx3QkFBd0IsQ0FBQyxFQUFFLFdBQVcsRUFBRSxJQUFJLEVBQUU7b0JBQ3pFLEVBQUUsSUFBSSxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsQ0FBQyxDQUFDLDBCQUEwQixDQUFDLEVBQUUsV0FBVyxFQUFFLEtBQUssRUFBRTtpQkFDaEY7YUFDSixDQUFDO2lCQUNELElBQUksQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQztRQUN2QyxDQUFDO2FBQU0sQ0FBQztZQUNKLE9BQU8sSUFBSSxDQUFDO1FBQ2hCLENBQUM7SUFDTCxDQUFDOzhHQWxCUSx3QkFBd0I7a0hBQXhCLHdCQUF3Qjs7MkZBQXhCLHdCQUF3QjtrQkFEcEMsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IG1hcmtlciBhcyBfIH0gZnJvbSAnQGJpZXNiamVyZy9uZ3gtdHJhbnNsYXRlLWV4dHJhY3QtbWFya2VyJztcbmltcG9ydCB7IE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IG1hcCB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcblxuaW1wb3J0IHsgRGVhY3RpdmF0ZUF3YXJlIH0gZnJvbSAnLi4vLi4vLi4vY29tbW9uL2RlYWN0aXZhdGUtYXdhcmUnO1xuaW1wb3J0IHsgTW9kYWxTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vLi4vcHJvdmlkZXJzL21vZGFsL21vZGFsLnNlcnZpY2UnO1xuXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgQ2FuRGVhY3RpdmF0ZURldGFpbEd1YXJkIHtcbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIG1vZGFsU2VydmljZTogTW9kYWxTZXJ2aWNlKSB7fVxuXG4gICAgY2FuRGVhY3RpdmF0ZShjb21wb25lbnQ6IERlYWN0aXZhdGVBd2FyZSk6IGJvb2xlYW4gfCBPYnNlcnZhYmxlPGJvb2xlYW4+IHtcbiAgICAgICAgaWYgKHR5cGVvZiBjb21wb25lbnQuY2FuRGVhY3RpdmF0ZSA9PT0gJ2Z1bmN0aW9uJyAmJiAhY29tcG9uZW50LmNhbkRlYWN0aXZhdGUoKSkge1xuICAgICAgICAgICAgcmV0dXJuIHRoaXMubW9kYWxTZXJ2aWNlXG4gICAgICAgICAgICAgICAgLmRpYWxvZyh7XG4gICAgICAgICAgICAgICAgICAgIHRpdGxlOiBfKCdjb21tb24uY29uZmlybS1uYXZpZ2F0aW9uJyksXG4gICAgICAgICAgICAgICAgICAgIGJvZHk6IF8oJ2NvbW1vbi50aGVyZS1hcmUtdW5zYXZlZC1jaGFuZ2VzJyksXG4gICAgICAgICAgICAgICAgICAgIGJ1dHRvbnM6IFtcbiAgICAgICAgICAgICAgICAgICAgICAgIHsgdHlwZTogJ2RhbmdlcicsIGxhYmVsOiBfKCdjb21tb24uZGlzY2FyZC1jaGFuZ2VzJyksIHJldHVyblZhbHVlOiB0cnVlIH0sXG4gICAgICAgICAgICAgICAgICAgICAgICB7IHR5cGU6ICdwcmltYXJ5JywgbGFiZWw6IF8oJ2NvbW1vbi5jYW5jZWwtbmF2aWdhdGlvbicpLCByZXR1cm5WYWx1ZTogZmFsc2UgfSxcbiAgICAgICAgICAgICAgICAgICAgXSxcbiAgICAgICAgICAgICAgICB9KVxuICAgICAgICAgICAgICAgIC5waXBlKG1hcChyZXN1bHQgPT4gISFyZXN1bHQpKTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIHJldHVybiB0cnVlO1xuICAgICAgICB9XG4gICAgfVxufVxuIl19
|
|
@@ -36,7 +36,7 @@ import { useRichTextEditor } from '../react-hooks/use-rich-text-editor';
|
|
|
36
36
|
*/
|
|
37
37
|
export const RichTextEditor = forwardRef((props, ref) => {
|
|
38
38
|
const [data, setData] = useState('');
|
|
39
|
-
const { readOnly, ...rest } = props;
|
|
39
|
+
const { readOnly, label, ...rest } = props;
|
|
40
40
|
const { ref: _ref, editor } = useRichTextEditor({
|
|
41
41
|
attributes: props.attributes,
|
|
42
42
|
isReadOnly: () => readOnly || false,
|
|
@@ -58,12 +58,16 @@ export const RichTextEditor = forwardRef((props, ref) => {
|
|
|
58
58
|
},
|
|
59
59
|
});
|
|
60
60
|
useEffect(() => {
|
|
61
|
-
if (props.onMount && editor)
|
|
61
|
+
if (props.onMount && editor) {
|
|
62
62
|
props.onMount(editor);
|
|
63
|
+
}
|
|
64
|
+
if (typeof props.defaultValue === 'string') {
|
|
65
|
+
editor.update(props.defaultValue);
|
|
66
|
+
}
|
|
63
67
|
}, []);
|
|
64
68
|
return (React.createElement(React.Fragment, null,
|
|
65
|
-
React.createElement("div", { ref: _ref, ...rest }),
|
|
69
|
+
React.createElement("div", { ref: _ref, ...rest }, label && React.createElement("label", { className: "rich-text-label" }, label)),
|
|
66
70
|
React.createElement("input", { type: "hidden", value: data, ref: ref })));
|
|
67
71
|
});
|
|
68
72
|
RichTextEditor.displayName = 'RichTextEditor';
|
|
69
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
73
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUmljaFRleHRFZGl0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvbGliL3JlYWN0L3NyYy9yZWFjdC1jb21wb25lbnRzL1JpY2hUZXh0RWRpdG9yLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEtBQUssRUFBRSxFQUlWLFVBQVUsRUFDVixTQUFTLEVBQ1QsUUFBUSxHQUNYLE1BQU0sT0FBTyxDQUFDO0FBRWYsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0scUNBQXFDLENBQUM7QUFnQnhFOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FpQ0c7QUFDSCxNQUFNLENBQUMsTUFBTSxjQUFjLEdBQUcsVUFBVSxDQUFDLENBQUMsS0FBeUIsRUFBRSxHQUFtQyxFQUFFLEVBQUU7SUFDeEcsTUFBTSxDQUFDLElBQUksRUFBRSxPQUFPLENBQUMsR0FBRyxRQUFRLENBQVMsRUFBRSxDQUFDLENBQUM7SUFDN0MsTUFBTSxFQUFFLFFBQVEsRUFBRSxLQUFLLEVBQUUsR0FBRyxJQUFJLEVBQUUsR0FBRyxLQUFLLENBQUM7SUFDM0MsTUFBTSxFQUFFLEdBQUcsRUFBRSxJQUFJLEVBQUUsTUFBTSxFQUFFLEdBQUcsaUJBQWlCLENBQUM7UUFDNUMsVUFBVSxFQUFFLEtBQUssQ0FBQyxVQUFVO1FBQzVCLFVBQVUsRUFBRSxHQUFHLEVBQUUsQ0FBQyxRQUFRLElBQUksS0FBSztRQUNuQyxXQUFXLEVBQUUsSUFBSSxDQUFDLEVBQUU7WUFDaEIsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDO1lBQ2QsSUFBSSxLQUFLLENBQUMsUUFBUSxFQUFFLENBQUM7Z0JBQ2pCLEtBQUssQ0FBQyxRQUFRLENBQUM7b0JBQ1gsTUFBTSxFQUFFLEVBQUUsS0FBSyxFQUFFLElBQUksRUFBRTtpQkFDTyxDQUFDLENBQUM7WUFDeEMsQ0FBQztZQUNELElBQUksR0FBRyxJQUFJLFNBQVMsSUFBSSxHQUFHLElBQUksR0FBRyxDQUFDLE9BQU8sRUFBRSxDQUFDO2dCQUN6QyxHQUFHLENBQUMsT0FBTyxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUM7Z0JBQ3pCLE1BQU0sS0FBSyxHQUFHLElBQUksS0FBSyxDQUFDLE9BQU8sRUFBRTtvQkFDN0IsT0FBTyxFQUFFLElBQUk7b0JBQ2IsVUFBVSxFQUFFLElBQUk7aUJBQ25CLENBQUMsQ0FBQztnQkFDSCxHQUFHLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUNyQyxDQUFDO1FBQ0wsQ0FBQztLQUNKLENBQUMsQ0FBQztJQUVILFNBQVMsQ0FBQyxHQUFHLEVBQUU7UUFDWCxJQUFJLEtBQUssQ0FBQyxPQUFPLElBQUksTUFBTSxFQUFFLENBQUM7WUFDMUIsS0FBSyxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUMxQixDQUFDO1FBQ0QsSUFBSSxPQUFPLEtBQUssQ0FBQyxZQUFZLEtBQUssUUFBUSxFQUFFLENBQUM7WUFDekMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsWUFBWSxDQUFDLENBQUM7UUFDdEMsQ0FBQztJQUNMLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztJQUNQLE9BQU8sQ0FDSDtRQUNJLDZCQUFLLEdBQUcsRUFBRSxJQUFJLEtBQU0sSUFBSSxJQUNuQixLQUFLLElBQUksK0JBQU8sU0FBUyxFQUFDLGlCQUFpQixJQUFFLEtBQUssQ0FBUyxDQUMxRDtRQUNOLCtCQUFPLElBQUksRUFBQyxRQUFRLEVBQUMsS0FBSyxFQUFFLElBQUksRUFBRSxHQUFHLEVBQUUsR0FBRyxHQUFJLENBQy9DLENBQ04sQ0FBQztBQUNOLENBQUMsQ0FBQyxDQUFDO0FBRUgsY0FBYyxDQUFDLFdBQVcsR0FBRyxnQkFBZ0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCwge1xuICAgIENoYW5nZUV2ZW50LFxuICAgIEZvcndhcmRlZFJlZixcbiAgICBJbnB1dEhUTUxBdHRyaWJ1dGVzLFxuICAgIGZvcndhcmRSZWYsXG4gICAgdXNlRWZmZWN0LFxuICAgIHVzZVN0YXRlLFxufSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBQcm9zZW1pcnJvclNlcnZpY2UgfSBmcm9tICdAdmVuZHVyZS9hZG1pbi11aS9jb3JlJztcbmltcG9ydCB7IHVzZVJpY2hUZXh0RWRpdG9yIH0gZnJvbSAnLi4vcmVhY3QtaG9va3MvdXNlLXJpY2gtdGV4dC1lZGl0b3InO1xuXG5leHBvcnQgdHlwZSBSaWNoVGV4dEVkaXRvclR5cGUgPSBJbnB1dEhUTUxBdHRyaWJ1dGVzPEhUTUxJbnB1dEVsZW1lbnQ+ICYge1xuICAgIC8qKlxuICAgICAqIEBkZXNjcmlwdGlvblxuICAgICAqIENvbnRyb2wgdGhlIERPTSBhdHRyaWJ1dGVzIG9mIHRoZSBlZGl0YWJsZSBlbGVtZW50LiBNYXkgYmUgZWl0aGVyIGFuIG9iamVjdCBvciBhIGZ1bmN0aW9uIGdvaW5nIGZyb20gYW4gZWRpdG9yIHN0YXRlIHRvIGFuIG9iamVjdC5cbiAgICAgKiBCeSBkZWZhdWx0LCB0aGUgZWxlbWVudCB3aWxsIGdldCBhIGNsYXNzIFwiUHJvc2VNaXJyb3JcIiwgYW5kIHdpbGwgaGF2ZSBpdHMgY29udGVudEVkaXRhYmxlIGF0dHJpYnV0ZSBkZXRlcm1pbmVkIGJ5IHRoZSBlZGl0YWJsZSBwcm9wLlxuICAgICAqIEFkZGl0aW9uYWwgY2xhc3NlcyBwcm92aWRlZCBoZXJlIHdpbGwgYmUgYWRkZWQgdG8gdGhlIGNsYXNzLiBGb3Igb3RoZXIgYXR0cmlidXRlcywgdGhlIHZhbHVlIHByb3ZpZGVkIGZpcnN0IChhcyBpbiBzb21lUHJvcCkgd2lsbCBiZSB1c2VkLlxuICAgICAqIENvcGllZCBmcm9tIHJlYWwgcHJvcGVydHkgZGVzY3JpcHRpb24uXG4gICAgICovXG4gICAgYXR0cmlidXRlcz86IFJlY29yZDxzdHJpbmcsIHN0cmluZz47XG4gICAgbGFiZWw/OiBzdHJpbmc7XG4gICAgcmVhZE9ubHk/OiBib29sZWFuO1xuICAgIG9uTW91bnQ/OiAoZWRpdG9yOiBQcm9zZW1pcnJvclNlcnZpY2UpID0+IHZvaWQ7XG59O1xuXG4vKipcbiAqIEBkZXNjcmlwdGlvblxuICogQSByaWNoIHRleHQgZWRpdG9yIGNvbXBvbmVudCB3aGljaCB1c2VzIFByb3NlTWlycm9yIChyaWNoIHRleHQgZWRpdG9yKSB1bmRlciB0aGUgaG9vZC5cbiAqXG4gKiBAZXhhbXBsZVxuICogYGBgdHNcbiAqIGltcG9ydCB7IFJpY2hUZXh0RWRpdG9yIH0gZnJvbSAnQHZlbmR1cmUvYWRtaW4tdWkvcmVhY3QnO1xuICogaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbiAqXG4gKiBleHBvcnQgZnVuY3Rpb24gTXlDb21wb25lbnQoKSB7XG4gKiAgIGNvbnN0IG9uU3VibWl0ID0gYXN5bmMgKGU6IFJlYWN0LkZvcm1FdmVudCkgPT4ge1xuICogICAgIGUucHJldmVudERlZmF1bHQoKTtcbiAqICAgICBjb25zdCBmb3JtID0gbmV3IEZvcm1EYXRhKGUudGFyZ2V0IGFzIEhUTUxGb3JtRWxlbWVudCk7XG4gKiAgICAgY29uc3QgY29udGVudCA9IGZvcm0uZ2V0KFwiY29udGVudFwiKTtcbiAqICAgICBjb25zb2xlLmxvZyhjb250ZW50KTtcbiAqICAgfTtcbiAqXG4gKiAgIHJldHVybiAoXG4gKiAgICAgPGZvcm0gY2xhc3NOYW1lPVwidy1mdWxsXCIgb25TdWJtaXQ9e29uU3VibWl0fT5cbiAqICAgICAgIDxSaWNoVGV4dEVkaXRvclxuICogICAgICAgICBuYW1lPVwiY29udGVudFwiXG4gKiAgICAgICAgIHJlYWRPbmx5PXtmYWxzZX1cbiAqICAgICAgICAgb25Nb3VudD17KGUpID0+IGNvbnNvbGUubG9nKFwiTW91bnRlZFwiLCBlKX1cbiAqICAgICAgIC8+XG4gKiAgICAgICA8YnV0dG9uIHR5cGU9XCJzdWJtaXRcIiBjbGFzc05hbWU9XCJidG4gYnRuLXByaW1hcnlcIj5cbiAqICAgICAgICAgU3VibWl0XG4gKiAgICAgICA8L2J1dHRvbj5cbiAqICAgICA8L2Zvcm0+XG4gKiAgICk7XG4gKiB9XG4gKiBgYGBcbiAqXG4gKiBAZG9jc0NhdGVnb3J5IHJlYWN0LWNvbXBvbmVudHNcbiAqL1xuZXhwb3J0IGNvbnN0IFJpY2hUZXh0RWRpdG9yID0gZm9yd2FyZFJlZigocHJvcHM6IFJpY2hUZXh0RWRpdG9yVHlwZSwgcmVmOiBGb3J3YXJkZWRSZWY8SFRNTElucHV0RWxlbWVudD4pID0+IHtcbiAgICBjb25zdCBbZGF0YSwgc2V0RGF0YV0gPSB1c2VTdGF0ZTxzdHJpbmc+KCcnKTtcbiAgICBjb25zdCB7IHJlYWRPbmx5LCBsYWJlbCwgLi4ucmVzdCB9ID0gcHJvcHM7XG4gICAgY29uc3QgeyByZWY6IF9yZWYsIGVkaXRvciB9ID0gdXNlUmljaFRleHRFZGl0b3Ioe1xuICAgICAgICBhdHRyaWJ1dGVzOiBwcm9wcy5hdHRyaWJ1dGVzLFxuICAgICAgICBpc1JlYWRPbmx5OiAoKSA9PiByZWFkT25seSB8fCBmYWxzZSxcbiAgICAgICAgb25UZXh0SW5wdXQ6IHRleHQgPT4ge1xuICAgICAgICAgICAgc2V0RGF0YSh0ZXh0KTtcbiAgICAgICAgICAgIGlmIChwcm9wcy5vbkNoYW5nZSkge1xuICAgICAgICAgICAgICAgIHByb3BzLm9uQ2hhbmdlKHtcbiAgICAgICAgICAgICAgICAgICAgdGFyZ2V0OiB7IHZhbHVlOiB0ZXh0IH0sXG4gICAgICAgICAgICAgICAgfSBhcyBDaGFuZ2VFdmVudDxIVE1MSW5wdXRFbGVtZW50Pik7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBpZiAocmVmICYmICdjdXJyZW50JyBpbiByZWYgJiYgcmVmLmN1cnJlbnQpIHtcbiAgICAgICAgICAgICAgICByZWYuY3VycmVudC52YWx1ZSA9IHRleHQ7XG4gICAgICAgICAgICAgICAgY29uc3QgZXZlbnQgPSBuZXcgRXZlbnQoJ2lucHV0Jywge1xuICAgICAgICAgICAgICAgICAgICBidWJibGVzOiB0cnVlLFxuICAgICAgICAgICAgICAgICAgICBjYW5jZWxhYmxlOiB0cnVlLFxuICAgICAgICAgICAgICAgIH0pO1xuICAgICAgICAgICAgICAgIHJlZi5jdXJyZW50LmRpc3BhdGNoRXZlbnQoZXZlbnQpO1xuICAgICAgICAgICAgfVxuICAgICAgICB9LFxuICAgIH0pO1xuXG4gICAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICAgICAgaWYgKHByb3BzLm9uTW91bnQgJiYgZWRpdG9yKSB7XG4gICAgICAgICAgICBwcm9wcy5vbk1vdW50KGVkaXRvcik7XG4gICAgICAgIH1cbiAgICAgICAgaWYgKHR5cGVvZiBwcm9wcy5kZWZhdWx0VmFsdWUgPT09ICdzdHJpbmcnKSB7XG4gICAgICAgICAgICBlZGl0b3IudXBkYXRlKHByb3BzLmRlZmF1bHRWYWx1ZSk7XG4gICAgICAgIH1cbiAgICB9LCBbXSk7XG4gICAgcmV0dXJuIChcbiAgICAgICAgPD5cbiAgICAgICAgICAgIDxkaXYgcmVmPXtfcmVmfSB7Li4ucmVzdH0+XG4gICAgICAgICAgICAgICAge2xhYmVsICYmIDxsYWJlbCBjbGFzc05hbWU9XCJyaWNoLXRleHQtbGFiZWxcIj57bGFiZWx9PC9sYWJlbD59XG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgIDxpbnB1dCB0eXBlPVwiaGlkZGVuXCIgdmFsdWU9e2RhdGF9IHJlZj17cmVmfSAvPlxuICAgICAgICA8Lz5cbiAgICApO1xufSk7XG5cblJpY2hUZXh0RWRpdG9yLmRpc3BsYXlOYW1lID0gJ1JpY2hUZXh0RWRpdG9yJztcbiJdfQ==
|
|
@@ -535,7 +535,7 @@ class CreateProductVariantDialogComponent {
|
|
|
535
535
|
}
|
|
536
536
|
confirm() {
|
|
537
537
|
const { name, sku, options, price } = this.form.value;
|
|
538
|
-
if (!name || !sku || !options ||
|
|
538
|
+
if (!name || !sku || !options || price == null) {
|
|
539
539
|
return;
|
|
540
540
|
}
|
|
541
541
|
const optionIds = Object.values(options).filter(notNullOrUndefined);
|
|
@@ -2702,13 +2702,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImpor
|
|
|
2702
2702
|
args: [{ selector: 'vdr-create-facet-value-dialog', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-template vdrDialogTitle>\r\n {{ 'catalog.create-facet-value' | translate }}\r\n</ng-template>\r\n<div class=\"form-grid\" [formGroup]=\"form\">\r\n <vdr-form-field [label]=\"'common.name' | translate\" for=\"name\">\r\n <input id=\"name\" type=\"text\" formControlName=\"name\" (input)=\"updateCode()\" />\r\n </vdr-form-field>\r\n <vdr-form-field\r\n [label]=\"'common.code' | translate\"\r\n for=\"code\"\r\n >\r\n <input\r\n id=\"code\"\r\n type=\"text\"\r\n formControlName=\"code\"\r\n />\r\n </vdr-form-field>\r\n</div>\r\n<ng-template vdrDialogButtons>\r\n <button type=\"button\" class=\"btn\" (click)=\"cancel()\">{{ 'common.cancel' | translate }}</button>\r\n <button type=\"submit\" (click)=\"confirm()\" class=\"btn btn-primary\" [disabled]=\"form.invalid\">\r\n {{ 'common.confirm' | translate }}\r\n </button>\r\n</ng-template>\r\n" }]
|
|
2703
2703
|
}], ctorParameters: () => [{ type: i2.FormBuilder }] });
|
|
2704
2704
|
|
|
2705
|
-
const FACET_DETAIL_QUERY = gql `
|
|
2706
|
-
query GetFacetDetail($id: ID!, $facetValueListOptions: FacetValueListOptions) {
|
|
2707
|
-
facet(id: $id) {
|
|
2708
|
-
...FacetWithValueList
|
|
2709
|
-
}
|
|
2710
|
-
}
|
|
2711
|
-
${FACET_WITH_VALUE_LIST_FRAGMENT}
|
|
2705
|
+
const FACET_DETAIL_QUERY = gql `
|
|
2706
|
+
query GetFacetDetail($id: ID!, $facetValueListOptions: FacetValueListOptions) {
|
|
2707
|
+
facet(id: $id) {
|
|
2708
|
+
...FacetWithValueList
|
|
2709
|
+
}
|
|
2710
|
+
}
|
|
2711
|
+
${FACET_WITH_VALUE_LIST_FRAGMENT}
|
|
2712
2712
|
`;
|
|
2713
2713
|
class FacetDetailComponent extends TypedBaseDetailComponent {
|
|
2714
2714
|
constructor(changeDetector, dataService, formBuilder, notificationService, modalService) {
|
|
@@ -3271,6 +3271,7 @@ class GenerateProductVariantsComponent {
|
|
|
3271
3271
|
.pipe(tap(items => {
|
|
3272
3272
|
if (items.length) {
|
|
3273
3273
|
this.selectedStockLocationId = items[0].id;
|
|
3274
|
+
this.onFormChange();
|
|
3274
3275
|
}
|
|
3275
3276
|
}));
|
|
3276
3277
|
this.generateVariants();
|