@vendure/admin-ui 2.1.3 → 2.1.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (27) hide show
  1. package/core/common/utilities/custom-field-default-value.d.ts +1 -1
  2. package/core/common/version.d.ts +1 -1
  3. package/core/providers/nav-builder/nav-builder-types.d.ts +27 -1
  4. package/core/shared/components/order-state-label/order-state-label.component.d.ts +1 -1
  5. package/core/shared/dynamic-form-inputs/default-form-inputs.d.ts +1 -1
  6. package/esm2022/core/common/utilities/configurable-operation-utils.mjs +10 -2
  7. package/esm2022/core/common/version.mjs +2 -2
  8. package/esm2022/core/providers/nav-builder/nav-builder-types.mjs +1 -1
  9. package/esm2022/core/shared/components/asset-picker-dialog/asset-picker-dialog.component.mjs +2 -2
  10. package/esm2022/core/shared/components/asset-preview/asset-preview.component.mjs +3 -3
  11. package/esm2022/core/shared/components/configurable-input/configurable-input.component.mjs +1 -1
  12. package/esm2022/core/shared/components/datetime-picker/datetime-picker.service.mjs +3 -3
  13. package/esm2022/core/shared/components/modal-dialog/modal-dialog.component.mjs +2 -2
  14. package/esm2022/core/shared/components/ui-extension-point/ui-extension-point.component.mjs +11 -11
  15. package/esm2022/core/shared/dynamic-form-inputs/code-editor-form-input/html-editor-form-input.component.mjs +2 -2
  16. package/esm2022/core/shared/dynamic-form-inputs/code-editor-form-input/json-editor-form-input.component.mjs +2 -2
  17. package/esm2022/marketing/components/promotion-detail/promotion-detail.component.mjs +2 -2
  18. package/esm2022/settings/components/payment-method-detail/payment-method-detail.component.mjs +2 -2
  19. package/fesm2022/vendure-admin-ui-core.mjs +31 -23
  20. package/fesm2022/vendure-admin-ui-core.mjs.map +1 -1
  21. package/fesm2022/vendure-admin-ui-marketing.mjs +1 -1
  22. package/fesm2022/vendure-admin-ui-marketing.mjs.map +1 -1
  23. package/fesm2022/vendure-admin-ui-settings.mjs +1 -1
  24. package/fesm2022/vendure-admin-ui-settings.mjs.map +1 -1
  25. package/package.json +2 -2
  26. package/static/styles/theme/dark.scss +2 -1
  27. package/static/theme.min.css +1 -1
@@ -153,4 +153,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.2", ngImpor
153
153
  }], remove: [{
154
154
  type: Output
155
155
  }] } });
156
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"configurable-input.component.js","sourceRoot":"","sources":["../../../../../../src/lib/core/src/shared/components/configurable-input/configurable-input.component.ts","../../../../../../src/lib/core/src/shared/components/configurable-input/configurable-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    ChangeDetectionStrategy,\r\n    Component,\r\n    EventEmitter,\r\n    forwardRef,\r\n    Input,\r\n    OnChanges,\r\n    OnDestroy,\r\n    OnInit,\r\n    Output,\r\n    SimpleChanges,\r\n} from '@angular/core';\r\nimport {\r\n    AbstractControl,\r\n    ControlValueAccessor,\r\n    NG_VALIDATORS,\r\n    NG_VALUE_ACCESSOR,\r\n    UntypedFormControl,\r\n    UntypedFormGroup,\r\n    ValidationErrors,\r\n    Validator,\r\n    Validators,\r\n} from '@angular/forms';\r\nimport { ConfigArgType } from '@vendure/common/lib/shared-types';\r\nimport { assertNever } from '@vendure/common/lib/shared-utils';\r\nimport { BehaviorSubject, Observable, Subscription } from 'rxjs';\r\n\r\nimport { InputComponentConfig } from '../../../common/component-registry-types';\r\nimport {\r\n    ConfigArg,\r\n    ConfigArgDefinition,\r\n    ConfigurableOperation,\r\n    ConfigurableOperationDefinition,\r\n} from '../../../common/generated-types';\r\nimport { getDefaultConfigArgValue } from '../../../common/utilities/configurable-operation-utils';\r\nimport { interpolateDescription } from '../../../common/utilities/interpolate-description';\r\n\r\n/**\r\n * A form input which renders a card with the internal form fields of the given ConfigurableOperation.\r\n */\r\n@Component({\r\n    selector: 'vdr-configurable-input',\r\n    templateUrl: './configurable-input.component.html',\r\n    styleUrls: ['./configurable-input.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    providers: [\r\n        {\r\n            provide: NG_VALUE_ACCESSOR,\r\n            useExisting: ConfigurableInputComponent,\r\n            multi: true,\r\n        },\r\n        {\r\n            provide: NG_VALIDATORS,\r\n            useExisting: forwardRef(() => ConfigurableInputComponent),\r\n            multi: true,\r\n        },\r\n    ],\r\n})\r\nexport class ConfigurableInputComponent\r\n    implements OnInit, OnChanges, OnDestroy, ControlValueAccessor, Validator\r\n{\r\n    @Input() operation?: ConfigurableOperation;\r\n    @Input() operationDefinition?: ConfigurableOperationDefinition;\r\n    @Input() readonly = false;\r\n    @Input() removable = true;\r\n    @Input() position = 0;\r\n    @Output() remove = new EventEmitter<ConfigurableOperation>();\r\n    argValues: { [name: string]: any } = {};\r\n    onChange: (val: any) => void;\r\n    onTouch: () => void;\r\n    form = new UntypedFormGroup({});\r\n    positionChange$: Observable<number>;\r\n    private positionChangeSubject = new BehaviorSubject<number>(0);\r\n    private subscription: Subscription;\r\n\r\n    interpolateDescription(): string {\r\n        if (this.operationDefinition) {\r\n            return interpolateDescription(this.operationDefinition, this.form.value);\r\n        } else {\r\n            return '';\r\n        }\r\n    }\r\n\r\n    ngOnInit() {\r\n        this.positionChange$ = this.positionChangeSubject.asObservable();\r\n    }\r\n\r\n    ngOnChanges(changes: SimpleChanges) {\r\n        if ('operation' in changes || 'operationDefinition' in changes) {\r\n            this.createForm();\r\n        }\r\n        if ('position' in changes) {\r\n            this.positionChangeSubject.next(this.position);\r\n        }\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        if (this.subscription) {\r\n            this.subscription.unsubscribe();\r\n        }\r\n    }\r\n\r\n    registerOnChange(fn: any) {\r\n        this.onChange = fn;\r\n    }\r\n\r\n    registerOnTouched(fn: any) {\r\n        this.onTouch = fn;\r\n    }\r\n\r\n    setDisabledState(isDisabled: boolean) {\r\n        if (isDisabled) {\r\n            this.form.disable();\r\n        } else {\r\n            this.form.enable();\r\n        }\r\n    }\r\n\r\n    writeValue(value: any): void {\r\n        if (value) {\r\n            this.form.patchValue(value);\r\n        }\r\n    }\r\n\r\n    trackByName(index: number, arg: ConfigArg): string {\r\n        return arg.name;\r\n    }\r\n\r\n    getArgDef(arg: ConfigArg): ConfigArgDefinition | undefined {\r\n        return this.operationDefinition?.args.find(a => a.name === arg.name);\r\n    }\r\n\r\n    private createForm() {\r\n        if (!this.operation) {\r\n            return;\r\n        }\r\n        if (this.subscription) {\r\n            this.subscription.unsubscribe();\r\n        }\r\n        this.form = new UntypedFormGroup({});\r\n        (this.form as any).__id = Math.random().toString(36).substr(10);\r\n\r\n        if (this.operation.args) {\r\n            for (const arg of this.operationDefinition?.args || []) {\r\n                let value: any = this.operation.args.find(a => a.name === arg.name)?.value;\r\n                if (value === undefined) {\r\n                    value = getDefaultConfigArgValue(arg);\r\n                }\r\n                const validators = arg.list ? undefined : arg.required ? Validators.required : undefined;\r\n                this.form.addControl(arg.name, new UntypedFormControl(value, validators));\r\n            }\r\n        }\r\n\r\n        this.subscription = this.form.valueChanges.subscribe(value => {\r\n            if (this.onChange) {\r\n                this.onChange({\r\n                    code: this.operation && this.operation.code,\r\n                    args: value,\r\n                });\r\n            }\r\n            if (this.onTouch) {\r\n                this.onTouch();\r\n            }\r\n        });\r\n    }\r\n\r\n    validate(c: AbstractControl): ValidationErrors | null {\r\n        if (this.form.invalid) {\r\n            return {\r\n                required: true,\r\n            };\r\n        }\r\n        return null;\r\n    }\r\n}\r\n","<div class=\"card\" *ngIf=\"operation\">\r\n    <div class=\"card-block\">{{ interpolateDescription() }}</div>\r\n    <div class=\"card-block\" *ngIf=\"operation.args?.length\">\r\n        <form [formGroup]=\"form\" *ngIf=\"operation\" class=\"operation-inputs\">\r\n            <div *ngFor=\"let arg of operation.args; trackBy: trackByName\" class=\"arg-row\">\r\n                <ng-container *ngIf=\"form.get(arg.name) && getArgDef(arg) as argDef\">\r\n                    <label class=\"clr-control-label\">{{ argDef.label || (arg.name | sentenceCase) }}</label>\r\n                    <vdr-help-tooltip\r\n                        class=\"mr3\"\r\n                        *ngIf=\"argDef.description\"\r\n                        [content]=\"argDef.description\"\r\n                    ></vdr-help-tooltip>\r\n                    <vdr-dynamic-form-input\r\n                        [def]=\"getArgDef(arg)\"\r\n                        [readonly]=\"readonly\"\r\n                        [control]=\"form.get(arg.name)\"\r\n                        [formControlName]=\"arg.name\"\r\n                    ></vdr-dynamic-form-input>\r\n                </ng-container>\r\n            </div>\r\n        </form>\r\n    </div>\r\n    <div class=\"card-footer\" *ngIf=\"!readonly && removable\">\r\n        <button class=\"button-small warning\" (click)=\"remove.emit(operation)\">\r\n            <clr-icon shape=\"times\"></clr-icon>\r\n            {{ 'common.remove' | translate }}\r\n        </button>\r\n    </div>\r\n</div>\r\n"]}
156
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"configurable-input.component.js","sourceRoot":"","sources":["../../../../../../src/lib/core/src/shared/components/configurable-input/configurable-input.component.ts","../../../../../../src/lib/core/src/shared/components/configurable-input/configurable-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    ChangeDetectionStrategy,\r\n    Component,\r\n    EventEmitter,\r\n    forwardRef,\r\n    Input,\r\n    OnChanges,\r\n    OnDestroy,\r\n    OnInit,\r\n    Output,\r\n    SimpleChanges,\r\n} from '@angular/core';\r\nimport {\r\n    AbstractControl,\r\n    ControlValueAccessor,\r\n    NG_VALIDATORS,\r\n    NG_VALUE_ACCESSOR,\r\n    UntypedFormControl,\r\n    UntypedFormGroup,\r\n    ValidationErrors,\r\n    Validator,\r\n    Validators,\r\n} from '@angular/forms';\r\nimport { BehaviorSubject, Observable, Subscription } from 'rxjs';\r\nimport {\r\n    ConfigArg,\r\n    ConfigArgDefinition,\r\n    ConfigurableOperation,\r\n    ConfigurableOperationDefinition,\r\n} from '../../../common/generated-types';\r\nimport { getDefaultConfigArgValue } from '../../../common/utilities/configurable-operation-utils';\r\nimport { interpolateDescription } from '../../../common/utilities/interpolate-description';\r\n\r\n/**\r\n * A form input which renders a card with the internal form fields of the given ConfigurableOperation.\r\n */\r\n@Component({\r\n    selector: 'vdr-configurable-input',\r\n    templateUrl: './configurable-input.component.html',\r\n    styleUrls: ['./configurable-input.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    providers: [\r\n        {\r\n            provide: NG_VALUE_ACCESSOR,\r\n            useExisting: ConfigurableInputComponent,\r\n            multi: true,\r\n        },\r\n        {\r\n            provide: NG_VALIDATORS,\r\n            useExisting: forwardRef(() => ConfigurableInputComponent),\r\n            multi: true,\r\n        },\r\n    ],\r\n})\r\nexport class ConfigurableInputComponent\r\n    implements OnInit, OnChanges, OnDestroy, ControlValueAccessor, Validator\r\n{\r\n    @Input() operation?: ConfigurableOperation;\r\n    @Input() operationDefinition?: ConfigurableOperationDefinition;\r\n    @Input() readonly = false;\r\n    @Input() removable = true;\r\n    @Input() position = 0;\r\n    @Output() remove = new EventEmitter<ConfigurableOperation>();\r\n    argValues: { [name: string]: any } = {};\r\n    onChange: (val: any) => void;\r\n    onTouch: () => void;\r\n    form = new UntypedFormGroup({});\r\n    positionChange$: Observable<number>;\r\n    private positionChangeSubject = new BehaviorSubject<number>(0);\r\n    private subscription: Subscription;\r\n\r\n    interpolateDescription(): string {\r\n        if (this.operationDefinition) {\r\n            return interpolateDescription(this.operationDefinition, this.form.value);\r\n        } else {\r\n            return '';\r\n        }\r\n    }\r\n\r\n    ngOnInit() {\r\n        this.positionChange$ = this.positionChangeSubject.asObservable();\r\n    }\r\n\r\n    ngOnChanges(changes: SimpleChanges) {\r\n        if ('operation' in changes || 'operationDefinition' in changes) {\r\n            this.createForm();\r\n        }\r\n        if ('position' in changes) {\r\n            this.positionChangeSubject.next(this.position);\r\n        }\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        if (this.subscription) {\r\n            this.subscription.unsubscribe();\r\n        }\r\n    }\r\n\r\n    registerOnChange(fn: any) {\r\n        this.onChange = fn;\r\n    }\r\n\r\n    registerOnTouched(fn: any) {\r\n        this.onTouch = fn;\r\n    }\r\n\r\n    setDisabledState(isDisabled: boolean) {\r\n        if (isDisabled) {\r\n            this.form.disable();\r\n        } else {\r\n            this.form.enable();\r\n        }\r\n    }\r\n\r\n    writeValue(value: any): void {\r\n        if (value) {\r\n            this.form.patchValue(value);\r\n        }\r\n    }\r\n\r\n    trackByName(index: number, arg: ConfigArg): string {\r\n        return arg.name;\r\n    }\r\n\r\n    getArgDef(arg: ConfigArg): ConfigArgDefinition | undefined {\r\n        return this.operationDefinition?.args.find(a => a.name === arg.name);\r\n    }\r\n\r\n    private createForm() {\r\n        if (!this.operation) {\r\n            return;\r\n        }\r\n        if (this.subscription) {\r\n            this.subscription.unsubscribe();\r\n        }\r\n        this.form = new UntypedFormGroup({});\r\n        (this.form as any).__id = Math.random().toString(36).substr(10);\r\n\r\n        if (this.operation.args) {\r\n            for (const arg of this.operationDefinition?.args || []) {\r\n                let value: any = this.operation.args.find(a => a.name === arg.name)?.value;\r\n                if (value === undefined) {\r\n                    value = getDefaultConfigArgValue(arg);\r\n                }\r\n                const validators = arg.list ? undefined : arg.required ? Validators.required : undefined;\r\n                this.form.addControl(arg.name, new UntypedFormControl(value, validators));\r\n            }\r\n        }\r\n\r\n        this.subscription = this.form.valueChanges.subscribe(value => {\r\n            if (this.onChange) {\r\n                this.onChange({\r\n                    code: this.operation && this.operation.code,\r\n                    args: value,\r\n                });\r\n            }\r\n            if (this.onTouch) {\r\n                this.onTouch();\r\n            }\r\n        });\r\n    }\r\n\r\n    validate(c: AbstractControl): ValidationErrors | null {\r\n        if (this.form.invalid) {\r\n            return {\r\n                required: true,\r\n            };\r\n        }\r\n        return null;\r\n    }\r\n}\r\n","<div class=\"card\" *ngIf=\"operation\">\r\n    <div class=\"card-block\">{{ interpolateDescription() }}</div>\r\n    <div class=\"card-block\" *ngIf=\"operation.args?.length\">\r\n        <form [formGroup]=\"form\" *ngIf=\"operation\" class=\"operation-inputs\">\r\n            <div *ngFor=\"let arg of operation.args; trackBy: trackByName\" class=\"arg-row\">\r\n                <ng-container *ngIf=\"form.get(arg.name) && getArgDef(arg) as argDef\">\r\n                    <label class=\"clr-control-label\">{{ argDef.label || (arg.name | sentenceCase) }}</label>\r\n                    <vdr-help-tooltip\r\n                        class=\"mr3\"\r\n                        *ngIf=\"argDef.description\"\r\n                        [content]=\"argDef.description\"\r\n                    ></vdr-help-tooltip>\r\n                    <vdr-dynamic-form-input\r\n                        [def]=\"getArgDef(arg)\"\r\n                        [readonly]=\"readonly\"\r\n                        [control]=\"form.get(arg.name)\"\r\n                        [formControlName]=\"arg.name\"\r\n                    ></vdr-dynamic-form-input>\r\n                </ng-container>\r\n            </div>\r\n        </form>\r\n    </div>\r\n    <div class=\"card-footer\" *ngIf=\"!readonly && removable\">\r\n        <button class=\"button-small warning\" (click)=\"remove.emit(operation)\">\r\n            <clr-icon shape=\"times\"></clr-icon>\r\n            {{ 'common.remove' | translate }}\r\n        </button>\r\n    </div>\r\n</div>\r\n"]}
@@ -1,7 +1,7 @@
1
1
  import { Injectable } from '@angular/core';
2
2
  import dayjs from 'dayjs';
3
3
  import { BehaviorSubject, combineLatest } from 'rxjs';
4
- import { map } from 'rxjs/operators';
4
+ import { distinctUntilChanged, map } from 'rxjs/operators';
5
5
  import { dayOfWeekIndex } from './constants';
6
6
  import * as i0 from "@angular/core";
7
7
  export class DatetimePickerService {
@@ -11,7 +11,7 @@ export class DatetimePickerService {
11
11
  this.min = null;
12
12
  this.max = null;
13
13
  this.jumping = false;
14
- this.selected$ = this.selectedDatetime$.pipe(map(value => value && value.toDate()));
14
+ this.selected$ = this.selectedDatetime$.pipe(map(value => value && value.toDate()), distinctUntilChanged((a, b) => a?.getTime() === b?.getTime()));
15
15
  this.viewing$ = this.viewingDatetime$.pipe(map(value => value.toDate()));
16
16
  this.weekStartDayIndex = dayOfWeekIndex['mon'];
17
17
  this.calendarView$ = combineLatest(this.viewingDatetime$, this.selectedDatetime$).pipe(map(([viewing, selected]) => this.generateCalendarView(viewing, selected)));
@@ -198,4 +198,4 @@ export class DatetimePickerService {
198
198
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.2", ngImport: i0, type: DatetimePickerService, decorators: [{
199
199
  type: Injectable
200
200
  }], ctorParameters: function () { return []; } });
201
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datetime-picker.service.js","sourceRoot":"","sources":["../../../../../../src/lib/core/src/shared/components/datetime-picker/datetime-picker.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport dayjs from 'dayjs';\r\nimport { BehaviorSubject, combineLatest, Observable } from 'rxjs';\r\nimport { map } from 'rxjs/operators';\r\n\r\nimport { dayOfWeekIndex } from './constants';\r\nimport { CalendarView, DayCell, DayOfWeek } from './types';\r\n\r\n@Injectable()\r\nexport class DatetimePickerService {\r\n    calendarView$: Observable<CalendarView>;\r\n    selected$: Observable<Date | null>;\r\n    viewing$: Observable<Date>;\r\n    private selectedDatetime$ = new BehaviorSubject<dayjs.Dayjs | null>(null);\r\n    private viewingDatetime$ = new BehaviorSubject<dayjs.Dayjs>(dayjs());\r\n    private weekStartDayIndex: number;\r\n    private min: dayjs.Dayjs | null = null;\r\n    private max: dayjs.Dayjs | null = null;\r\n    private jumping = false;\r\n\r\n    constructor() {\r\n        this.selected$ = this.selectedDatetime$.pipe(map(value => value && value.toDate()));\r\n        this.viewing$ = this.viewingDatetime$.pipe(map(value => value.toDate()));\r\n        this.weekStartDayIndex = dayOfWeekIndex['mon'];\r\n        this.calendarView$ = combineLatest(this.viewingDatetime$, this.selectedDatetime$).pipe(\r\n            map(([viewing, selected]) => this.generateCalendarView(viewing, selected)),\r\n        );\r\n    }\r\n\r\n    setWeekStartingDay(weekStartDay: DayOfWeek) {\r\n        this.weekStartDayIndex = dayOfWeekIndex[weekStartDay];\r\n    }\r\n\r\n    setMin(min?: string | null) {\r\n        if (typeof min === 'string') {\r\n            this.min = dayjs(min);\r\n        }\r\n    }\r\n\r\n    setMax(max?: string | null) {\r\n        if (typeof max === 'string') {\r\n            this.max = dayjs(max);\r\n        }\r\n    }\r\n\r\n    selectDatetime(date: Date | string | dayjs.Dayjs | null) {\r\n        let viewingValue: dayjs.Dayjs;\r\n        let selectedValue: dayjs.Dayjs | null = null;\r\n        if (date == null || date === '') {\r\n            viewingValue = dayjs();\r\n        } else {\r\n            viewingValue = dayjs(date);\r\n            selectedValue = dayjs(date);\r\n        }\r\n\r\n        this.selectedDatetime$.next(selectedValue);\r\n        this.viewingDatetime$.next(viewingValue);\r\n    }\r\n\r\n    selectHour(hourOfDay: number) {\r\n        const current = this.selectedDatetime$.value || dayjs();\r\n        const next = current.hour(hourOfDay);\r\n        this.selectedDatetime$.next(next);\r\n        this.viewingDatetime$.next(next);\r\n    }\r\n\r\n    selectMinute(minutePastHour: number) {\r\n        const current = this.selectedDatetime$.value || dayjs();\r\n        const next = current.minute(minutePastHour);\r\n        this.selectedDatetime$.next(next);\r\n        this.viewingDatetime$.next(next);\r\n    }\r\n\r\n    viewNextMonth() {\r\n        this.jumping = false;\r\n        const current = this.viewingDatetime$.value;\r\n        this.viewingDatetime$.next(current.add(1, 'month'));\r\n    }\r\n\r\n    viewPrevMonth() {\r\n        this.jumping = false;\r\n        const current = this.viewingDatetime$.value;\r\n        this.viewingDatetime$.next(current.subtract(1, 'month'));\r\n    }\r\n\r\n    viewToday() {\r\n        this.jumping = false;\r\n        this.viewingDatetime$.next(dayjs());\r\n    }\r\n\r\n    viewJumpDown() {\r\n        this.jumping = true;\r\n        const current = this.viewingDatetime$.value;\r\n        this.viewingDatetime$.next(current.add(1, 'week'));\r\n    }\r\n\r\n    viewJumpUp() {\r\n        this.jumping = true;\r\n        const current = this.viewingDatetime$.value;\r\n        this.viewingDatetime$.next(current.subtract(1, 'week'));\r\n    }\r\n\r\n    viewJumpRight() {\r\n        this.jumping = true;\r\n        const current = this.viewingDatetime$.value;\r\n        this.viewingDatetime$.next(current.add(1, 'day'));\r\n    }\r\n\r\n    viewJumpLeft() {\r\n        this.jumping = true;\r\n        const current = this.viewingDatetime$.value;\r\n        this.viewingDatetime$.next(current.subtract(1, 'day'));\r\n    }\r\n\r\n    selectToday() {\r\n        this.jumping = false;\r\n        this.selectDatetime(dayjs());\r\n    }\r\n\r\n    selectViewed() {\r\n        this.jumping = false;\r\n        this.selectDatetime(this.viewingDatetime$.value);\r\n    }\r\n\r\n    viewMonth(month: number) {\r\n        this.jumping = false;\r\n        const current = this.viewingDatetime$.value;\r\n        this.viewingDatetime$.next(current.month(month - 1));\r\n    }\r\n\r\n    viewYear(year: number) {\r\n        this.jumping = false;\r\n        const current = this.viewingDatetime$.value;\r\n        this.viewingDatetime$.next(current.year(year));\r\n    }\r\n\r\n    private generateCalendarView(viewing: dayjs.Dayjs, selected: dayjs.Dayjs | null): CalendarView {\r\n        if (!viewing.isValid() || (selected && !selected.isValid())) {\r\n            return [];\r\n        }\r\n        const start = viewing.startOf('month');\r\n        const end = viewing.endOf('month');\r\n        const today = dayjs();\r\n        const daysInMonth = viewing.daysInMonth();\r\n        const selectedDayOfMonth = selected && selected.get('date');\r\n\r\n        const startDayOfWeek = start.day();\r\n        const startIndex = (7 + (startDayOfWeek - this.weekStartDayIndex)) % 7;\r\n\r\n        const calendarView: CalendarView = [];\r\n        let week: DayCell[] = [];\r\n\r\n        // Add the days at the tail of the previous month\r\n        if (0 < startIndex) {\r\n            const prevMonth = viewing.subtract(1, 'month');\r\n            const daysInPrevMonth = prevMonth.daysInMonth();\r\n            const prevIsCurrentMonth = prevMonth.isSame(today, 'month');\r\n            for (let i = daysInPrevMonth - startIndex + 1; i <= daysInPrevMonth; i++) {\r\n                const thisDay = viewing.subtract(1, 'month').date(i);\r\n                week.push({\r\n                    dayOfMonth: i,\r\n                    selected: false,\r\n                    inCurrentMonth: false,\r\n                    isToday: prevIsCurrentMonth && today.get('date') === i,\r\n                    isViewing: false,\r\n                    disabled: !this.isInBounds(thisDay),\r\n                    select: () => {\r\n                        this.selectDatetime(thisDay);\r\n                    },\r\n                });\r\n            }\r\n        }\r\n\r\n        // Add this month's days\r\n        const isCurrentMonth = viewing.isSame(today, 'month');\r\n        for (let i = 1; i <= daysInMonth; i++) {\r\n            if ((i + startIndex - 1) % 7 === 0) {\r\n                calendarView.push(week);\r\n                week = [];\r\n            }\r\n            const thisDay = start.add(i - 1, 'day');\r\n            const isViewingThisMonth =\r\n                !!selected && selected.isSame(viewing, 'month') && selected.isSame(viewing, 'year');\r\n            week.push({\r\n                dayOfMonth: i,\r\n                selected: i === selectedDayOfMonth && isViewingThisMonth,\r\n                inCurrentMonth: true,\r\n                isToday: isCurrentMonth && today.get('date') === i,\r\n                isViewing: this.jumping && viewing.date() === i,\r\n                disabled: !this.isInBounds(thisDay),\r\n                select: () => {\r\n                    this.selectDatetime(thisDay);\r\n                },\r\n            });\r\n        }\r\n\r\n        // Add the days at the start of the next month\r\n        const emptyCellsEnd = 7 - ((startIndex + daysInMonth) % 7);\r\n        if (emptyCellsEnd !== 7) {\r\n            const nextMonth = viewing.add(1, 'month');\r\n            const nextIsCurrentMonth = nextMonth.isSame(today, 'month');\r\n\r\n            for (let i = 1; i <= emptyCellsEnd; i++) {\r\n                const thisDay = end.add(i, 'day');\r\n                week.push({\r\n                    dayOfMonth: i,\r\n                    selected: false,\r\n                    inCurrentMonth: false,\r\n                    isToday: nextIsCurrentMonth && today.get('date') === i,\r\n                    isViewing: false,\r\n                    disabled: !this.isInBounds(thisDay),\r\n                    select: () => {\r\n                        this.selectDatetime(thisDay);\r\n                    },\r\n                });\r\n            }\r\n        }\r\n        calendarView.push(week);\r\n        return calendarView;\r\n    }\r\n\r\n    private isInBounds(date: dayjs.Dayjs): boolean {\r\n        if (this.min && this.min.isAfter(date)) {\r\n            return false;\r\n        }\r\n        if (this.max && this.max.isBefore(date)) {\r\n            return false;\r\n        }\r\n        return true;\r\n    }\r\n}\r\n"]}
201
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datetime-picker.service.js","sourceRoot":"","sources":["../../../../../../src/lib/core/src/shared/components/datetime-picker/datetime-picker.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport dayjs from 'dayjs';\r\nimport { BehaviorSubject, combineLatest, Observable } from 'rxjs';\r\nimport { distinctUntilChanged, map } from 'rxjs/operators';\r\n\r\nimport { dayOfWeekIndex } from './constants';\r\nimport { CalendarView, DayCell, DayOfWeek } from './types';\r\n\r\n@Injectable()\r\nexport class DatetimePickerService {\r\n    calendarView$: Observable<CalendarView>;\r\n    selected$: Observable<Date | null>;\r\n    viewing$: Observable<Date>;\r\n    private selectedDatetime$ = new BehaviorSubject<dayjs.Dayjs | null>(null);\r\n    private viewingDatetime$ = new BehaviorSubject<dayjs.Dayjs>(dayjs());\r\n    private weekStartDayIndex: number;\r\n    private min: dayjs.Dayjs | null = null;\r\n    private max: dayjs.Dayjs | null = null;\r\n    private jumping = false;\r\n\r\n    constructor() {\r\n        this.selected$ = this.selectedDatetime$.pipe(\r\n            map(value => value && value.toDate()),\r\n            distinctUntilChanged((a, b) => a?.getTime() === b?.getTime()),\r\n        );\r\n        this.viewing$ = this.viewingDatetime$.pipe(map(value => value.toDate()));\r\n        this.weekStartDayIndex = dayOfWeekIndex['mon'];\r\n        this.calendarView$ = combineLatest(this.viewingDatetime$, this.selectedDatetime$).pipe(\r\n            map(([viewing, selected]) => this.generateCalendarView(viewing, selected)),\r\n        );\r\n    }\r\n\r\n    setWeekStartingDay(weekStartDay: DayOfWeek) {\r\n        this.weekStartDayIndex = dayOfWeekIndex[weekStartDay];\r\n    }\r\n\r\n    setMin(min?: string | null) {\r\n        if (typeof min === 'string') {\r\n            this.min = dayjs(min);\r\n        }\r\n    }\r\n\r\n    setMax(max?: string | null) {\r\n        if (typeof max === 'string') {\r\n            this.max = dayjs(max);\r\n        }\r\n    }\r\n\r\n    selectDatetime(date: Date | string | dayjs.Dayjs | null) {\r\n        let viewingValue: dayjs.Dayjs;\r\n        let selectedValue: dayjs.Dayjs | null = null;\r\n        if (date == null || date === '') {\r\n            viewingValue = dayjs();\r\n        } else {\r\n            viewingValue = dayjs(date);\r\n            selectedValue = dayjs(date);\r\n        }\r\n\r\n        this.selectedDatetime$.next(selectedValue);\r\n        this.viewingDatetime$.next(viewingValue);\r\n    }\r\n\r\n    selectHour(hourOfDay: number) {\r\n        const current = this.selectedDatetime$.value || dayjs();\r\n        const next = current.hour(hourOfDay);\r\n        this.selectedDatetime$.next(next);\r\n        this.viewingDatetime$.next(next);\r\n    }\r\n\r\n    selectMinute(minutePastHour: number) {\r\n        const current = this.selectedDatetime$.value || dayjs();\r\n        const next = current.minute(minutePastHour);\r\n        this.selectedDatetime$.next(next);\r\n        this.viewingDatetime$.next(next);\r\n    }\r\n\r\n    viewNextMonth() {\r\n        this.jumping = false;\r\n        const current = this.viewingDatetime$.value;\r\n        this.viewingDatetime$.next(current.add(1, 'month'));\r\n    }\r\n\r\n    viewPrevMonth() {\r\n        this.jumping = false;\r\n        const current = this.viewingDatetime$.value;\r\n        this.viewingDatetime$.next(current.subtract(1, 'month'));\r\n    }\r\n\r\n    viewToday() {\r\n        this.jumping = false;\r\n        this.viewingDatetime$.next(dayjs());\r\n    }\r\n\r\n    viewJumpDown() {\r\n        this.jumping = true;\r\n        const current = this.viewingDatetime$.value;\r\n        this.viewingDatetime$.next(current.add(1, 'week'));\r\n    }\r\n\r\n    viewJumpUp() {\r\n        this.jumping = true;\r\n        const current = this.viewingDatetime$.value;\r\n        this.viewingDatetime$.next(current.subtract(1, 'week'));\r\n    }\r\n\r\n    viewJumpRight() {\r\n        this.jumping = true;\r\n        const current = this.viewingDatetime$.value;\r\n        this.viewingDatetime$.next(current.add(1, 'day'));\r\n    }\r\n\r\n    viewJumpLeft() {\r\n        this.jumping = true;\r\n        const current = this.viewingDatetime$.value;\r\n        this.viewingDatetime$.next(current.subtract(1, 'day'));\r\n    }\r\n\r\n    selectToday() {\r\n        this.jumping = false;\r\n        this.selectDatetime(dayjs());\r\n    }\r\n\r\n    selectViewed() {\r\n        this.jumping = false;\r\n        this.selectDatetime(this.viewingDatetime$.value);\r\n    }\r\n\r\n    viewMonth(month: number) {\r\n        this.jumping = false;\r\n        const current = this.viewingDatetime$.value;\r\n        this.viewingDatetime$.next(current.month(month - 1));\r\n    }\r\n\r\n    viewYear(year: number) {\r\n        this.jumping = false;\r\n        const current = this.viewingDatetime$.value;\r\n        this.viewingDatetime$.next(current.year(year));\r\n    }\r\n\r\n    private generateCalendarView(viewing: dayjs.Dayjs, selected: dayjs.Dayjs | null): CalendarView {\r\n        if (!viewing.isValid() || (selected && !selected.isValid())) {\r\n            return [];\r\n        }\r\n        const start = viewing.startOf('month');\r\n        const end = viewing.endOf('month');\r\n        const today = dayjs();\r\n        const daysInMonth = viewing.daysInMonth();\r\n        const selectedDayOfMonth = selected && selected.get('date');\r\n\r\n        const startDayOfWeek = start.day();\r\n        const startIndex = (7 + (startDayOfWeek - this.weekStartDayIndex)) % 7;\r\n\r\n        const calendarView: CalendarView = [];\r\n        let week: DayCell[] = [];\r\n\r\n        // Add the days at the tail of the previous month\r\n        if (0 < startIndex) {\r\n            const prevMonth = viewing.subtract(1, 'month');\r\n            const daysInPrevMonth = prevMonth.daysInMonth();\r\n            const prevIsCurrentMonth = prevMonth.isSame(today, 'month');\r\n            for (let i = daysInPrevMonth - startIndex + 1; i <= daysInPrevMonth; i++) {\r\n                const thisDay = viewing.subtract(1, 'month').date(i);\r\n                week.push({\r\n                    dayOfMonth: i,\r\n                    selected: false,\r\n                    inCurrentMonth: false,\r\n                    isToday: prevIsCurrentMonth && today.get('date') === i,\r\n                    isViewing: false,\r\n                    disabled: !this.isInBounds(thisDay),\r\n                    select: () => {\r\n                        this.selectDatetime(thisDay);\r\n                    },\r\n                });\r\n            }\r\n        }\r\n\r\n        // Add this month's days\r\n        const isCurrentMonth = viewing.isSame(today, 'month');\r\n        for (let i = 1; i <= daysInMonth; i++) {\r\n            if ((i + startIndex - 1) % 7 === 0) {\r\n                calendarView.push(week);\r\n                week = [];\r\n            }\r\n            const thisDay = start.add(i - 1, 'day');\r\n            const isViewingThisMonth =\r\n                !!selected && selected.isSame(viewing, 'month') && selected.isSame(viewing, 'year');\r\n            week.push({\r\n                dayOfMonth: i,\r\n                selected: i === selectedDayOfMonth && isViewingThisMonth,\r\n                inCurrentMonth: true,\r\n                isToday: isCurrentMonth && today.get('date') === i,\r\n                isViewing: this.jumping && viewing.date() === i,\r\n                disabled: !this.isInBounds(thisDay),\r\n                select: () => {\r\n                    this.selectDatetime(thisDay);\r\n                },\r\n            });\r\n        }\r\n\r\n        // Add the days at the start of the next month\r\n        const emptyCellsEnd = 7 - ((startIndex + daysInMonth) % 7);\r\n        if (emptyCellsEnd !== 7) {\r\n            const nextMonth = viewing.add(1, 'month');\r\n            const nextIsCurrentMonth = nextMonth.isSame(today, 'month');\r\n\r\n            for (let i = 1; i <= emptyCellsEnd; i++) {\r\n                const thisDay = end.add(i, 'day');\r\n                week.push({\r\n                    dayOfMonth: i,\r\n                    selected: false,\r\n                    inCurrentMonth: false,\r\n                    isToday: nextIsCurrentMonth && today.get('date') === i,\r\n                    isViewing: false,\r\n                    disabled: !this.isInBounds(thisDay),\r\n                    select: () => {\r\n                        this.selectDatetime(thisDay);\r\n                    },\r\n                });\r\n            }\r\n        }\r\n        calendarView.push(week);\r\n        return calendarView;\r\n    }\r\n\r\n    private isInBounds(date: dayjs.Dayjs): boolean {\r\n        if (this.min && this.min.isAfter(date)) {\r\n            return false;\r\n        }\r\n        if (this.max && this.max.isBefore(date)) {\r\n            return false;\r\n        }\r\n        return true;\r\n    }\r\n}\r\n"]}
@@ -60,10 +60,10 @@ export class ModalDialogComponent {
60
60
  }
61
61
  }
62
62
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.2", ngImport: i0, type: ModalDialogComponent, deps: [{ token: i1.LocalizationService }], target: i0.ɵɵFactoryTarget.Component }); }
63
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.2", type: ModalDialogComponent, selector: "vdr-modal-dialog", ngImport: i0, template: "<div [dir]=\"direction$ | async\">\r\n <clr-modal [clrModalOpen]=\"true\" (clrModalOpenChange)=\"modalOpenChange($event)\"\r\n [clrModalClosable]=\"options?.closable\" [clrModalSize]=\"options?.size\"\r\n [ngClass]=\"'modal-valign-' + (options?.verticalAlign || 'center')\">\r\n <h3 class=\"modal-title\"><ng-container *ngTemplateOutlet=\"(titleTemplateRef$ | async)\"></ng-container></h3>\r\n <div class=\"modal-body\">\r\n <vdr-dialog-component-outlet [component]=\"childComponentType\"\r\n (create)=\"onCreate($event)\"></vdr-dialog-component-outlet>\r\n </div>\r\n <div class=\"modal-footer\">\r\n <ng-container *ngTemplateOutlet=\"(buttonsTemplateRef$ | async)\"></ng-container>\r\n </div>\r\n </clr-modal>\r\n</div>", styles: ["::ng-deep clr-modal.modal-valign-top .modal{justify-content:flex-start}::ng-deep clr-modal.modal-valign-bottom .modal{justify-content:flex-end}.modal-body{display:flex;flex-direction:column;container-type:inline-size}\n"], dependencies: [{ kind: "component", type: i2.ClrModal, selector: "clr-modal", inputs: ["clrModalOpen", "clrModalClosable", "clrModalCloseButtonAriaLabel", "clrModalSize", "clrModalStaticBackdrop", "clrModalSkipAnimation", "clrModalPreventClose", "clrModalLabelledById"], outputs: ["clrModalOpenChange", "clrModalAlternateClose"] }, { kind: "directive", type: i2.ClrModalBody, selector: ".modal-body" }, { kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i4.Dir, selector: "[dir]", inputs: ["dir"], outputs: ["dirChange"], exportAs: ["dir"] }, { kind: "component", type: i5.DialogComponentOutletComponent, selector: "vdr-dialog-component-outlet", inputs: ["component"], outputs: ["create"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }] }); }
63
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.2", type: ModalDialogComponent, selector: "vdr-modal-dialog", ngImport: i0, template: "<div [dir]=\"direction$ | async\">\r\n <clr-modal [clrModalOpen]=\"true\" (clrModalOpenChange)=\"modalOpenChange($event)\"\r\n [clrModalClosable]=\"options?.closable\" [clrModalSize]=\"options?.size\"\r\n [ngClass]=\"'modal-valign-' + (options?.verticalAlign || 'center')\">\r\n <h3 class=\"modal-title\"><ng-container *ngTemplateOutlet=\"(titleTemplateRef$ | async)\"></ng-container></h3>\r\n <div class=\"modal-body\">\r\n <vdr-dialog-component-outlet [component]=\"childComponentType\"\r\n (create)=\"onCreate($event)\"></vdr-dialog-component-outlet>\r\n </div>\r\n <div class=\"modal-footer\">\r\n <ng-container *ngTemplateOutlet=\"(buttonsTemplateRef$ | async)\"></ng-container>\r\n </div>\r\n </clr-modal>\r\n</div>", styles: ["::ng-deep clr-modal.modal-valign-top .modal{justify-content:flex-start}::ng-deep clr-modal.modal-valign-bottom .modal{justify-content:flex-end}::ng-deep clr-modal .modal-dialog{display:flex}::ng-deep clr-modal .modal-content-wrapper{flex:1;display:flex}::ng-deep clr-modal .modal-dialog .modal-content{flex:1;display:flex;flex-direction:column}@media screen and (max-height: 700px){::ng-deep clr-modal .modal-dialog .modal-content{padding:.8rem}::ng-deep clr-modal .modal-header,::ng-deep clr-modal .modal-header--accessible{padding-bottom:.8rem}::ng-deep clr-modal .modal-footer{padding-top:.8rem}}.modal-body{display:flex;flex-direction:column;container-type:inline-size}\n"], dependencies: [{ kind: "component", type: i2.ClrModal, selector: "clr-modal", inputs: ["clrModalOpen", "clrModalClosable", "clrModalCloseButtonAriaLabel", "clrModalSize", "clrModalStaticBackdrop", "clrModalSkipAnimation", "clrModalPreventClose", "clrModalLabelledById"], outputs: ["clrModalOpenChange", "clrModalAlternateClose"] }, { kind: "directive", type: i2.ClrModalBody, selector: ".modal-body" }, { kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i4.Dir, selector: "[dir]", inputs: ["dir"], outputs: ["dirChange"], exportAs: ["dir"] }, { kind: "component", type: i5.DialogComponentOutletComponent, selector: "vdr-dialog-component-outlet", inputs: ["component"], outputs: ["create"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }] }); }
64
64
  }
65
65
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.2", ngImport: i0, type: ModalDialogComponent, decorators: [{
66
66
  type: Component,
67
- args: [{ selector: 'vdr-modal-dialog', template: "<div [dir]=\"direction$ | async\">\r\n <clr-modal [clrModalOpen]=\"true\" (clrModalOpenChange)=\"modalOpenChange($event)\"\r\n [clrModalClosable]=\"options?.closable\" [clrModalSize]=\"options?.size\"\r\n [ngClass]=\"'modal-valign-' + (options?.verticalAlign || 'center')\">\r\n <h3 class=\"modal-title\"><ng-container *ngTemplateOutlet=\"(titleTemplateRef$ | async)\"></ng-container></h3>\r\n <div class=\"modal-body\">\r\n <vdr-dialog-component-outlet [component]=\"childComponentType\"\r\n (create)=\"onCreate($event)\"></vdr-dialog-component-outlet>\r\n </div>\r\n <div class=\"modal-footer\">\r\n <ng-container *ngTemplateOutlet=\"(buttonsTemplateRef$ | async)\"></ng-container>\r\n </div>\r\n </clr-modal>\r\n</div>", styles: ["::ng-deep clr-modal.modal-valign-top .modal{justify-content:flex-start}::ng-deep clr-modal.modal-valign-bottom .modal{justify-content:flex-end}.modal-body{display:flex;flex-direction:column;container-type:inline-size}\n"] }]
67
+ args: [{ selector: 'vdr-modal-dialog', template: "<div [dir]=\"direction$ | async\">\r\n <clr-modal [clrModalOpen]=\"true\" (clrModalOpenChange)=\"modalOpenChange($event)\"\r\n [clrModalClosable]=\"options?.closable\" [clrModalSize]=\"options?.size\"\r\n [ngClass]=\"'modal-valign-' + (options?.verticalAlign || 'center')\">\r\n <h3 class=\"modal-title\"><ng-container *ngTemplateOutlet=\"(titleTemplateRef$ | async)\"></ng-container></h3>\r\n <div class=\"modal-body\">\r\n <vdr-dialog-component-outlet [component]=\"childComponentType\"\r\n (create)=\"onCreate($event)\"></vdr-dialog-component-outlet>\r\n </div>\r\n <div class=\"modal-footer\">\r\n <ng-container *ngTemplateOutlet=\"(buttonsTemplateRef$ | async)\"></ng-container>\r\n </div>\r\n </clr-modal>\r\n</div>", styles: ["::ng-deep clr-modal.modal-valign-top .modal{justify-content:flex-start}::ng-deep clr-modal.modal-valign-bottom .modal{justify-content:flex-end}::ng-deep clr-modal .modal-dialog{display:flex}::ng-deep clr-modal .modal-content-wrapper{flex:1;display:flex}::ng-deep clr-modal .modal-dialog .modal-content{flex:1;display:flex;flex-direction:column}@media screen and (max-height: 700px){::ng-deep clr-modal .modal-dialog .modal-content{padding:.8rem}::ng-deep clr-modal .modal-header,::ng-deep clr-modal .modal-header--accessible{padding-bottom:.8rem}::ng-deep clr-modal .modal-footer{padding-top:.8rem}}.modal-body{display:flex;flex-direction:column;container-type:inline-size}\n"] }]
68
68
  }], ctorParameters: function () { return [{ type: i1.LocalizationService }]; } });
69
69
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwtZGlhbG9nLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29yZS9zcmMvc2hhcmVkL2NvbXBvbmVudHMvbW9kYWwtZGlhbG9nL21vZGFsLWRpYWxvZy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvcmUvc3JjL3NoYXJlZC9jb21wb25lbnRzL21vZGFsLWRpYWxvZy9tb2RhbC1kaWFsb2cuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBNkIsTUFBTSxlQUFlLENBQUM7QUFDckUsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLE1BQU0sQ0FBQzs7Ozs7OztBQVUvQjs7O0dBR0c7QUFNSCxNQUFNLE9BQU8sb0JBQW9CO0lBUzdCOztPQUVHO0lBQ0gsWUFBb0IsbUJBQXdDO1FBQXhDLHdCQUFtQixHQUFuQixtQkFBbUIsQ0FBcUI7UUFQNUQsc0JBQWlCLEdBQUcsSUFBSSxPQUFPLEVBQW9CLENBQUM7UUFDcEQsd0JBQW1CLEdBQUcsSUFBSSxPQUFPLEVBQW9CLENBQUM7SUFNUyxDQUFDO0lBRWhFLFFBQVE7UUFDSixJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxVQUFVLENBQUM7SUFDMUQsQ0FBQztJQUVEOzs7OztPQUtHO0lBQ0gsUUFBUSxDQUFDLGlCQUFvQjtRQUN6QixpQkFBaUIsQ0FBQyxXQUFXLEdBQUcsQ0FBQyxNQUFZLEVBQUUsRUFBRTtZQUM3QyxJQUFJLENBQUMsVUFBVSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQzVCLENBQUMsQ0FBQztRQUNGLElBQUksSUFBSSxDQUFDLE9BQU8sSUFBSSxJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sRUFBRTtZQUNyQywyQkFBMkI7WUFDM0IsS0FBSyxNQUFNLEdBQUcsSUFBSSxJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sRUFBRTtnQkFDbkMsaUJBQWlCLENBQUMsR0FBRyxDQUFDLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFnQyxDQUFDO2FBQ3BGO1NBQ0o7SUFDTCxDQUFDO0lBRUQ7O09BRUc7SUFDSCxxQkFBcUIsQ0FBQyxnQkFBa0M7UUFDcEQsSUFBSSxDQUFDLGlCQUFpQixDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO0lBQ2xELENBQUM7SUFFRDs7T0FFRztJQUNILHVCQUF1QixDQUFDLGtCQUFvQztRQUN4RCxJQUFJLENBQUMsbUJBQW1CLENBQUMsSUFBSSxDQUFDLGtCQUFrQixDQUFDLENBQUM7SUFDdEQsQ0FBQztJQUVEOztPQUVHO0lBQ0gsZUFBZSxDQUFDLE1BQVc7UUFDdkIsSUFBSSxNQUFNLEtBQUssS0FBSyxFQUFFO1lBQ2xCLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztTQUNyQjtJQUNMLENBQUM7OEdBekRRLG9CQUFvQjtrR0FBcEIsb0JBQW9CLHdEQ3BCakMsK3lCQWFNOzsyRkRPTyxvQkFBb0I7a0JBTGhDLFNBQVM7K0JBQ0ksa0JBQWtCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBPbkluaXQsIFRlbXBsYXRlUmVmLCBUeXBlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFN1YmplY3QgfSBmcm9tICdyeGpzJztcclxuXHJcbmltcG9ydCB7XHJcbiAgICBMb2NhbGl6YXRpb25EaXJlY3Rpb25UeXBlLFxyXG4gICAgTG9jYWxpemF0aW9uU2VydmljZSxcclxufSBmcm9tICcuLi8uLi8uLi9wcm92aWRlcnMvbG9jYWxpemF0aW9uL2xvY2FsaXphdGlvbi5zZXJ2aWNlJztcclxuaW1wb3J0IHsgRGlhbG9nLCBNb2RhbE9wdGlvbnMgfSBmcm9tICcuLi8uLi8uLi9wcm92aWRlcnMvbW9kYWwvbW9kYWwudHlwZXMnO1xyXG5cclxuaW1wb3J0IHsgRGlhbG9nQnV0dG9uc0RpcmVjdGl2ZSB9IGZyb20gJy4vZGlhbG9nLWJ1dHRvbnMuZGlyZWN0aXZlJztcclxuXHJcbi8qKlxyXG4gKiBUaGlzIGNvbXBvbmVudCBzaG91bGQgb25seSBiZSBpbnN0YW50aWF0ZWQgZHluYW1pY2FsbHkgYnkgdGhlIE1vZGFsU2VydmljZS4gSXQgc2hvdWxkIG5vdCBiZSB1c2VkXHJcbiAqIGRpcmVjdGx5IGluIHRlbXBsYXRlcy4gU2VlIHtAbGluayBNb2RhbFNlcnZpY2UuZnJvbUNvbXBvbmVudH0gbWV0aG9kIGZvciBtb3JlIGRldGFpbC5cclxuICovXHJcbkBDb21wb25lbnQoe1xyXG4gICAgc2VsZWN0b3I6ICd2ZHItbW9kYWwtZGlhbG9nJyxcclxuICAgIHRlbXBsYXRlVXJsOiAnLi9tb2RhbC1kaWFsb2cuY29tcG9uZW50Lmh0bWwnLFxyXG4gICAgc3R5bGVVcmxzOiBbJy4vbW9kYWwtZGlhbG9nLmNvbXBvbmVudC5zY3NzJ10sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBNb2RhbERpYWxvZ0NvbXBvbmVudDxUIGV4dGVuZHMgRGlhbG9nPGFueT4+IGltcGxlbWVudHMgT25Jbml0IHtcclxuICAgIGRpcmVjdGlvbiQ6IExvY2FsaXphdGlvbkRpcmVjdGlvblR5cGU7XHJcblxyXG4gICAgY2hpbGRDb21wb25lbnRUeXBlOiBUeXBlPFQ+O1xyXG4gICAgY2xvc2VNb2RhbDogKHJlc3VsdD86IGFueSkgPT4gdm9pZDtcclxuICAgIHRpdGxlVGVtcGxhdGVSZWYkID0gbmV3IFN1YmplY3Q8VGVtcGxhdGVSZWY8YW55Pj4oKTtcclxuICAgIGJ1dHRvbnNUZW1wbGF0ZVJlZiQgPSBuZXcgU3ViamVjdDxUZW1wbGF0ZVJlZjxhbnk+PigpO1xyXG4gICAgb3B0aW9ucz86IE1vZGFsT3B0aW9uczxUPjtcclxuXHJcbiAgICAvKipcclxuICAgICAqXHJcbiAgICAgKi9cclxuICAgIGNvbnN0cnVjdG9yKHByaXZhdGUgbG9jYWxpemF0aW9uU2VydmljZTogTG9jYWxpemF0aW9uU2VydmljZSkge31cclxuXHJcbiAgICBuZ09uSW5pdCgpOiB2b2lkIHtcclxuICAgICAgICB0aGlzLmRpcmVjdGlvbiQgPSB0aGlzLmxvY2FsaXphdGlvblNlcnZpY2UuZGlyZWN0aW9uJDtcclxuICAgIH1cclxuXHJcbiAgICAvKipcclxuICAgICAqIFRoaXMgY2FsbGJhY2sgaXMgaW52b2tlZCB3aGVuIHRoZSBjaGlsZENvbXBvbmVudFR5cGUgaXMgaW5zdGFudGlhdGVkIGluIHRoZVxyXG4gICAgICogdGVtcGxhdGUgYnkgdGhlIHtAbGluayBEaWFsb2dDb21wb25lbnRPdXRsZXRDb21wb25lbnR9LlxyXG4gICAgICogT25jZSB3ZSBoYXZlIHRoZSBpbnN0YW5jZSwgd2UgY2FuIHNldCB0aGUgcmVzb2x2ZVdpdGggZnVuY3Rpb24gYW5kIGFueVxyXG4gICAgICogbG9jYWxzIHdoaWNoIHdlcmUgc3BlY2lmaWVkIGluIHRoZSBjb25maWcuXHJcbiAgICAgKi9cclxuICAgIG9uQ3JlYXRlKGNvbXBvbmVudEluc3RhbmNlOiBUKSB7XHJcbiAgICAgICAgY29tcG9uZW50SW5zdGFuY2UucmVzb2x2ZVdpdGggPSAocmVzdWx0PzogYW55KSA9PiB7XHJcbiAgICAgICAgICAgIHRoaXMuY2xvc2VNb2RhbChyZXN1bHQpO1xyXG4gICAgICAgIH07XHJcbiAgICAgICAgaWYgKHRoaXMub3B0aW9ucyAmJiB0aGlzLm9wdGlvbnMubG9jYWxzKSB7XHJcbiAgICAgICAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZVxyXG4gICAgICAgICAgICBmb3IgKGNvbnN0IGtleSBpbiB0aGlzLm9wdGlvbnMubG9jYWxzKSB7XHJcbiAgICAgICAgICAgICAgICBjb21wb25lbnRJbnN0YW5jZVtrZXldID0gdGhpcy5vcHRpb25zLmxvY2Fsc1trZXldIGFzIFRbRXh0cmFjdDxrZXlvZiBULCBzdHJpbmc+XTtcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgIH1cclxuICAgIH1cclxuXHJcbiAgICAvKipcclxuICAgICAqIFRoaXMgc2hvdWxkIGJlIGNhbGxlZCBieSB0aGUge0BsaW5rIERpYWxvZ1RpdGxlRGlyZWN0aXZlfSBvbmx5XHJcbiAgICAgKi9cclxuICAgIHJlZ2lzdGVyVGl0bGVUZW1wbGF0ZSh0aXRsZVRlbXBsYXRlUmVmOiBUZW1wbGF0ZVJlZjxhbnk+KSB7XHJcbiAgICAgICAgdGhpcy50aXRsZVRlbXBsYXRlUmVmJC5uZXh0KHRpdGxlVGVtcGxhdGVSZWYpO1xyXG4gICAgfVxyXG5cclxuICAgIC8qKlxyXG4gICAgICogVGhpcyBzaG91bGQgYmUgY2FsbGVkIGJ5IHRoZSB7QGxpbmsgRGlhbG9nQnV0dG9uc0RpcmVjdGl2ZX0gb25seVxyXG4gICAgICovXHJcbiAgICByZWdpc3RlckJ1dHRvbnNUZW1wbGF0ZShidXR0b25zVGVtcGxhdGVSZWY6IFRlbXBsYXRlUmVmPGFueT4pIHtcclxuICAgICAgICB0aGlzLmJ1dHRvbnNUZW1wbGF0ZVJlZiQubmV4dChidXR0b25zVGVtcGxhdGVSZWYpO1xyXG4gICAgfVxyXG5cclxuICAgIC8qKlxyXG4gICAgICogQ2FsbGVkIHdoZW4gdGhlIG1vZGFsIGlzIGNsb3NlZCBieSBjbGlja2luZyB0aGUgWCBvciB0aGUgbWFzay5cclxuICAgICAqL1xyXG4gICAgbW9kYWxPcGVuQ2hhbmdlKHN0YXR1czogYW55KSB7XHJcbiAgICAgICAgaWYgKHN0YXR1cyA9PT0gZmFsc2UpIHtcclxuICAgICAgICAgICAgdGhpcy5jbG9zZU1vZGFsKCk7XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG59XHJcbiIsIjxkaXYgW2Rpcl09XCJkaXJlY3Rpb24kIHwgYXN5bmNcIj5cclxuICAgIDxjbHItbW9kYWwgW2Nsck1vZGFsT3Blbl09XCJ0cnVlXCIgKGNsck1vZGFsT3BlbkNoYW5nZSk9XCJtb2RhbE9wZW5DaGFuZ2UoJGV2ZW50KVwiXHJcbiAgICAgICAgW2Nsck1vZGFsQ2xvc2FibGVdPVwib3B0aW9ucz8uY2xvc2FibGVcIiBbY2xyTW9kYWxTaXplXT1cIm9wdGlvbnM/LnNpemVcIlxyXG4gICAgICAgIFtuZ0NsYXNzXT1cIidtb2RhbC12YWxpZ24tJyArIChvcHRpb25zPy52ZXJ0aWNhbEFsaWduIHx8ICdjZW50ZXInKVwiPlxyXG4gICAgICAgIDxoMyBjbGFzcz1cIm1vZGFsLXRpdGxlXCI+PG5nLWNvbnRhaW5lciAqbmdUZW1wbGF0ZU91dGxldD1cIih0aXRsZVRlbXBsYXRlUmVmJCB8IGFzeW5jKVwiPjwvbmctY29udGFpbmVyPjwvaDM+XHJcbiAgICAgICAgPGRpdiBjbGFzcz1cIm1vZGFsLWJvZHlcIj5cclxuICAgICAgICAgICAgPHZkci1kaWFsb2ctY29tcG9uZW50LW91dGxldCBbY29tcG9uZW50XT1cImNoaWxkQ29tcG9uZW50VHlwZVwiXHJcbiAgICAgICAgICAgICAgICAoY3JlYXRlKT1cIm9uQ3JlYXRlKCRldmVudClcIj48L3Zkci1kaWFsb2ctY29tcG9uZW50LW91dGxldD5cclxuICAgICAgICA8L2Rpdj5cclxuICAgICAgICA8ZGl2IGNsYXNzPVwibW9kYWwtZm9vdGVyXCI+XHJcbiAgICAgICAgICAgIDxuZy1jb250YWluZXIgKm5nVGVtcGxhdGVPdXRsZXQ9XCIoYnV0dG9uc1RlbXBsYXRlUmVmJCB8IGFzeW5jKVwiPjwvbmctY29udGFpbmVyPlxyXG4gICAgICAgIDwvZGl2PlxyXG4gICAgPC9jbHItbW9kYWw+XHJcbjwvZGl2PiJdfQ==
@@ -95,8 +95,8 @@ export default [
95
95
  id: 'my-button',
96
96
  label: 'My Action',
97
97
  locationId: '${locationId}',
98
- });
99
- ]`,
98
+ }),
99
+ ];`,
100
100
  navMenu: locationId => `
101
101
  import { addNavMenuSection } from '@vendure/admin-ui/core';
102
102
 
@@ -105,10 +105,10 @@ export default [
105
105
  id: 'my-menu-item',
106
106
  label: 'My Menu Item',
107
107
  routerLink: ['/extensions/my-plugin'],
108
- }
109
- '${locationId}'
110
- );
111
- ]`,
108
+ },
109
+ '${locationId}',
110
+ ),
111
+ ];`,
112
112
  detailComponent: locationId => `
113
113
  import { registerCustomDetailComponent } from '@vendure/admin-ui/core';
114
114
 
@@ -116,8 +116,8 @@ export default [
116
116
  registerCustomDetailComponent({
117
117
  locationId: '${locationId}',
118
118
  component: MyCustomComponent,
119
- });
120
- ]`,
119
+ }),
120
+ ];`,
121
121
  dataTable: (locationId, metadata) => `
122
122
  import { registerDataTableComponent } from '@vendure/admin-ui/core';
123
123
 
@@ -126,7 +126,7 @@ export default [
126
126
  tableId: '${locationId}',
127
127
  columnId: '${metadata}',
128
128
  component: MyCustomComponent,
129
- });
130
- ]`,
129
+ }),
130
+ ];`,
131
131
  };
132
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-extension-point.component.js","sourceRoot":"","sources":["../../../../../../src/lib/core/src/shared/components/ui-extension-point/ui-extension-point.component.ts","../../../../../../src/lib/core/src/shared/components/ui-extension-point/ui-extension-point.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    AfterViewInit,\r\n    ChangeDetectionStrategy,\r\n    Component,\r\n    ElementRef,\r\n    HostBinding,\r\n    Input,\r\n    isDevMode,\r\n    OnInit,\r\n    ViewChild,\r\n} from '@angular/core';\r\nimport { Observable } from 'rxjs';\r\nimport { CodeJar } from 'codejar';\r\nimport { tap } from 'rxjs/operators';\r\n\r\nimport { UIExtensionLocationId } from '../../../common/component-registry-types';\r\nimport { DataService } from '../../../data/providers/data.service';\r\nimport { DropdownComponent } from '../dropdown/dropdown.component';\r\n\r\ntype UiExtensionType = 'actionBar' | 'navMenu' | 'detailComponent' | 'dataTable';\r\n\r\n@Component({\r\n    selector: 'vdr-ui-extension-point',\r\n    templateUrl: './ui-extension-point.component.html',\r\n    styleUrls: ['./ui-extension-point.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class UiExtensionPointComponent implements OnInit, AfterViewInit {\r\n    @Input() locationId: UIExtensionLocationId;\r\n    @Input() metadata?: any;\r\n    @Input() topPx: number;\r\n    @Input() leftPx: number;\r\n    @HostBinding('style.display')\r\n    @Input()\r\n    display: 'block' | 'inline-block' = 'inline-block';\r\n    @Input() api: UiExtensionType;\r\n    @ViewChild('editor') private editorElementRef: ElementRef<HTMLDivElement>;\r\n    @ViewChild('dropdownComponent') private dropdownComponent: DropdownComponent;\r\n    display$: Observable<boolean>;\r\n    jar: CodeJar;\r\n    readonly isDevMode = isDevMode();\r\n\r\n    constructor(private dataService: DataService) {}\r\n\r\n    getCodeTemplate(api: UiExtensionType): string {\r\n        return codeTemplates[api](this.locationId, this.metadata).trim();\r\n    }\r\n\r\n    ngOnInit(): void {\r\n        this.display$ = this.dataService.client\r\n            .uiState()\r\n            .mapStream(({ uiState }) => uiState.displayUiExtensionPoints)\r\n            .pipe(\r\n                tap(display => {\r\n                    if (display) {\r\n                        setTimeout(() => {\r\n                            const highlight = (editor: HTMLElement) => {\r\n                                const code = editor.textContent ?? '';\r\n                                editor.innerHTML = highlightTsCode(this.getCodeTemplate(this.api));\r\n                            };\r\n                            this.editorElementRef.nativeElement.contentEditable = 'false';\r\n                            this.jar = CodeJar(this.editorElementRef.nativeElement, highlight);\r\n                            this.jar.updateCode(this.getCodeTemplate(this.api));\r\n                        });\r\n                    }\r\n                }),\r\n            );\r\n    }\r\n\r\n    ngAfterViewInit() {\r\n        // this.dropdownComponent.onOpenChange(isOpen => {\r\n        //     if (isOpen) {\r\n        //     }\r\n        // });\r\n    }\r\n}\r\n\r\nfunction highlightTsCode(tsCode: string) {\r\n    tsCode = tsCode.replace(/&/g, '&amp;').replace(/</g, '&lt;').replace(/>/g, '&gt;');\r\n\r\n    return tsCode.replace(\r\n        /\\b(abstract|any|as|boolean|break|case|catch|class|const|continue|default|do|else|enum|export|extends|false|finally|for|from|function|get|if|implements|import|in|instanceof|interface|is|keyof|let|module|namespace|never|new|null|number|object|of|private|protected|public|readonly|require|return|set|static|string|super|switch|symbol|this|throw|true|try|type|typeof|undefined|var|void|while|with|yield)\\b|\\/\\/.*|\\/\\*[\\s\\S]*?\\*\\/|\"(?:\\\\[\\s\\S]|[^\\\\\"])*\"|'[^']*'/g,\r\n        (match, ...args) => {\r\n            if (/^\"/.test(match) || /^'/.test(match)) {\r\n                return '<span class=\"ts-string\">' + match + '</span>';\r\n            } else if (/\\/\\/.*|\\/\\*[\\s\\S]*?\\*\\//.test(match)) {\r\n                return '<span class=\"ts-comment\">' + match + '</span>';\r\n            } else if (\r\n                /\\b(abstract|any|as|boolean|break|case|catch|class|const|continue|default|do|else|enum|export|extends|false|finally|for|from|function|get|if|implements|import|in|instanceof|interface|is|keyof|let|module|namespace|never|new|null|number|object|of|private|protected|public|readonly|require|return|set|static|string|super|switch|symbol|this|throw|true|try|type|typeof|undefined|var|void|while|with|yield)\\b/.test(\r\n                    match,\r\n                )\r\n            ) {\r\n                return '<span class=\"ts-keyword\">' + match + '</span>';\r\n            } else {\r\n                return '<span class=\"ts-default\">' + match + '</span>';\r\n            }\r\n        },\r\n    );\r\n}\r\n\r\nconst codeTemplates: Record<UiExtensionType, (locationId: UIExtensionLocationId, metadata: any) => string> = {\r\n    actionBar: locationId => `\r\nimport { addActionBarItem } from '@vendure/admin-ui/core';\r\n\r\nexport default [\r\n  addActionBarItem({\r\n    id: 'my-button',\r\n    label: 'My Action',\r\n    locationId: '${locationId}',\r\n  });\r\n]`,\r\n    navMenu: locationId => `\r\nimport { addNavMenuSection } from '@vendure/admin-ui/core';\r\n\r\nexport default [\r\n  addNavMenuSection({\r\n      id: 'my-menu-item',\r\n      label: 'My Menu Item',\r\n      routerLink: ['/extensions/my-plugin'],\r\n    }\r\n    '${locationId}'\r\n  );\r\n]`,\r\n    detailComponent: locationId => `\r\nimport { registerCustomDetailComponent } from '@vendure/admin-ui/core';\r\n\r\nexport default [\r\n  registerCustomDetailComponent({\r\n    locationId: '${locationId}',\r\n    component: MyCustomComponent,\r\n  });\r\n]`,\r\n    dataTable: (locationId, metadata) => `\r\nimport { registerDataTableComponent } from '@vendure/admin-ui/core';\r\n\r\nexport default [\r\n  registerDataTableComponent({\r\n    tableId: '${locationId}',\r\n    columnId: '${metadata}',\r\n    component: MyCustomComponent,\r\n  });\r\n]`,\r\n};\r\n","<div [class.highlight]=\"isDevMode && (display$ | async)\" class=\"wrapper\" [style.display]=\"display\">\r\n    <vdr-dropdown *ngIf=\"isDevMode && (display$ | async)\" #dropdownComponent>\r\n        <button class=\"extension-point-info-trigger\"\r\n                [style.top.px]=\"topPx ?? 0\"\r\n                [style.left.px]=\"leftPx ?? 0\"\r\n                vdrDropdownTrigger>\r\n            <clr-icon shape=\"plugin\" class=\"\" size=\"12\"></clr-icon>\r\n        </button>\r\n        <vdr-dropdown-menu>\r\n            <div #editor contenteditable=\"false\" class=\"highlighted\"></div>\r\n        </vdr-dropdown-menu>\r\n    </vdr-dropdown>\r\n    <ng-content></ng-content>\r\n</div>\r\n"]}
132
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-extension-point.component.js","sourceRoot":"","sources":["../../../../../../src/lib/core/src/shared/components/ui-extension-point/ui-extension-point.component.ts","../../../../../../src/lib/core/src/shared/components/ui-extension-point/ui-extension-point.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    AfterViewInit,\r\n    ChangeDetectionStrategy,\r\n    Component,\r\n    ElementRef,\r\n    HostBinding,\r\n    Input,\r\n    isDevMode,\r\n    OnInit,\r\n    ViewChild,\r\n} from '@angular/core';\r\nimport { Observable } from 'rxjs';\r\nimport { CodeJar } from 'codejar';\r\nimport { tap } from 'rxjs/operators';\r\n\r\nimport { UIExtensionLocationId } from '../../../common/component-registry-types';\r\nimport { DataService } from '../../../data/providers/data.service';\r\nimport { DropdownComponent } from '../dropdown/dropdown.component';\r\n\r\ntype UiExtensionType = 'actionBar' | 'navMenu' | 'detailComponent' | 'dataTable';\r\n\r\n@Component({\r\n    selector: 'vdr-ui-extension-point',\r\n    templateUrl: './ui-extension-point.component.html',\r\n    styleUrls: ['./ui-extension-point.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class UiExtensionPointComponent implements OnInit, AfterViewInit {\r\n    @Input() locationId: UIExtensionLocationId;\r\n    @Input() metadata?: any;\r\n    @Input() topPx: number;\r\n    @Input() leftPx: number;\r\n    @HostBinding('style.display')\r\n    @Input()\r\n    display: 'block' | 'inline-block' = 'inline-block';\r\n    @Input() api: UiExtensionType;\r\n    @ViewChild('editor') private editorElementRef: ElementRef<HTMLDivElement>;\r\n    @ViewChild('dropdownComponent') private dropdownComponent: DropdownComponent;\r\n    display$: Observable<boolean>;\r\n    jar: CodeJar;\r\n    readonly isDevMode = isDevMode();\r\n\r\n    constructor(private dataService: DataService) {}\r\n\r\n    getCodeTemplate(api: UiExtensionType): string {\r\n        return codeTemplates[api](this.locationId, this.metadata).trim();\r\n    }\r\n\r\n    ngOnInit(): void {\r\n        this.display$ = this.dataService.client\r\n            .uiState()\r\n            .mapStream(({ uiState }) => uiState.displayUiExtensionPoints)\r\n            .pipe(\r\n                tap(display => {\r\n                    if (display) {\r\n                        setTimeout(() => {\r\n                            const highlight = (editor: HTMLElement) => {\r\n                                const code = editor.textContent ?? '';\r\n                                editor.innerHTML = highlightTsCode(this.getCodeTemplate(this.api));\r\n                            };\r\n                            this.editorElementRef.nativeElement.contentEditable = 'false';\r\n                            this.jar = CodeJar(this.editorElementRef.nativeElement, highlight);\r\n                            this.jar.updateCode(this.getCodeTemplate(this.api));\r\n                        });\r\n                    }\r\n                }),\r\n            );\r\n    }\r\n\r\n    ngAfterViewInit() {\r\n        // this.dropdownComponent.onOpenChange(isOpen => {\r\n        //     if (isOpen) {\r\n        //     }\r\n        // });\r\n    }\r\n}\r\n\r\nfunction highlightTsCode(tsCode: string) {\r\n    tsCode = tsCode.replace(/&/g, '&amp;').replace(/</g, '&lt;').replace(/>/g, '&gt;');\r\n\r\n    return tsCode.replace(\r\n        /\\b(abstract|any|as|boolean|break|case|catch|class|const|continue|default|do|else|enum|export|extends|false|finally|for|from|function|get|if|implements|import|in|instanceof|interface|is|keyof|let|module|namespace|never|new|null|number|object|of|private|protected|public|readonly|require|return|set|static|string|super|switch|symbol|this|throw|true|try|type|typeof|undefined|var|void|while|with|yield)\\b|\\/\\/.*|\\/\\*[\\s\\S]*?\\*\\/|\"(?:\\\\[\\s\\S]|[^\\\\\"])*\"|'[^']*'/g,\r\n        (match, ...args) => {\r\n            if (/^\"/.test(match) || /^'/.test(match)) {\r\n                return '<span class=\"ts-string\">' + match + '</span>';\r\n            } else if (/\\/\\/.*|\\/\\*[\\s\\S]*?\\*\\//.test(match)) {\r\n                return '<span class=\"ts-comment\">' + match + '</span>';\r\n            } else if (\r\n                /\\b(abstract|any|as|boolean|break|case|catch|class|const|continue|default|do|else|enum|export|extends|false|finally|for|from|function|get|if|implements|import|in|instanceof|interface|is|keyof|let|module|namespace|never|new|null|number|object|of|private|protected|public|readonly|require|return|set|static|string|super|switch|symbol|this|throw|true|try|type|typeof|undefined|var|void|while|with|yield)\\b/.test(\r\n                    match,\r\n                )\r\n            ) {\r\n                return '<span class=\"ts-keyword\">' + match + '</span>';\r\n            } else {\r\n                return '<span class=\"ts-default\">' + match + '</span>';\r\n            }\r\n        },\r\n    );\r\n}\r\n\r\nconst codeTemplates: Record<UiExtensionType, (locationId: UIExtensionLocationId, metadata: any) => string> = {\r\n    actionBar: locationId => `\r\nimport { addActionBarItem } from '@vendure/admin-ui/core';\r\n\r\nexport default [\r\n  addActionBarItem({\r\n    id: 'my-button',\r\n    label: 'My Action',\r\n    locationId: '${locationId}',\r\n  }),\r\n];`,\r\n    navMenu: locationId => `\r\nimport { addNavMenuSection } from '@vendure/admin-ui/core';\r\n\r\nexport default [\r\n  addNavMenuSection({\r\n      id: 'my-menu-item',\r\n      label: 'My Menu Item',\r\n      routerLink: ['/extensions/my-plugin'],\r\n    },\r\n    '${locationId}',\r\n  ),\r\n];`,\r\n    detailComponent: locationId => `\r\nimport { registerCustomDetailComponent } from '@vendure/admin-ui/core';\r\n\r\nexport default [\r\n  registerCustomDetailComponent({\r\n    locationId: '${locationId}',\r\n    component: MyCustomComponent,\r\n  }),\r\n];`,\r\n    dataTable: (locationId, metadata) => `\r\nimport { registerDataTableComponent } from '@vendure/admin-ui/core';\r\n\r\nexport default [\r\n  registerDataTableComponent({\r\n    tableId: '${locationId}',\r\n    columnId: '${metadata}',\r\n    component: MyCustomComponent,\r\n  }),\r\n];`,\r\n};\r\n","<div [class.highlight]=\"isDevMode && (display$ | async)\" class=\"wrapper\" [style.display]=\"display\">\r\n    <vdr-dropdown *ngIf=\"isDevMode && (display$ | async)\" #dropdownComponent>\r\n        <button class=\"extension-point-info-trigger\"\r\n                [style.top.px]=\"topPx ?? 0\"\r\n                [style.left.px]=\"leftPx ?? 0\"\r\n                vdrDropdownTrigger>\r\n            <clr-icon shape=\"plugin\" class=\"\" size=\"12\"></clr-icon>\r\n        </button>\r\n        <vdr-dropdown-menu>\r\n            <div #editor contenteditable=\"false\" class=\"highlighted\"></div>\r\n        </vdr-dropdown-menu>\r\n    </vdr-dropdown>\r\n    <ng-content></ng-content>\r\n</div>\r\n"]}
@@ -50,10 +50,10 @@ export class HtmlEditorFormInputComponent extends BaseCodeEditorFormInputCompone
50
50
  return html.replace(/&/g, '&amp;').replace(/</g, '&lt;').replace(/>/g, '&gt;');
51
51
  }
52
52
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.2", ngImport: i0, type: HtmlEditorFormInputComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
53
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.2", type: HtmlEditorFormInputComponent, selector: "vdr-html-editor-form-input", usesInheritance: true, ngImport: i0, template: "<div #editor class=\"code-editor html-editor\" [class.invalid]=\"!isValid\" [style.height]=\"height || '300px'\"></div>\r\n<div class=\"error-message\">\r\n <span *ngIf=\"errorMessage\">{{ errorMessage }}</span>\r\n</div>\r\n", styles: [".code-editor{min-height:6rem;background-color:var(--color-json-editor-background-color);color:var(--color-json-editor-text);border:1px solid var(--color-component-border-200);border-radius:3px;padding:6px;tab-size:4;font-family:Source Code Pro,Lucida Console,Monaco,monospace;font-size:14px;font-weight:400;height:340px;letter-spacing:normal;line-height:20px;resize:both;text-align:initial;min-width:200px}.code-editor:focus{border-color:var(--color-primary-500)}.code-editor.invalid{border-color:var(--clr-forms-invalid-color)}.error-message{min-height:1rem;color:var(--color-json-editor-error)}.code-editor ::ng-deep .he-tag{color:var(--color-json-editor-key)}.code-editor ::ng-deep .he-attr{color:var(--color-json-editor-number)}.code-editor ::ng-deep .he-error{text-decoration-line:underline;text-decoration-style:wavy;text-decoration-color:var(--color-json-editor-error)}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
53
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.2", type: HtmlEditorFormInputComponent, selector: "vdr-html-editor-form-input", usesInheritance: true, ngImport: i0, template: "<div #editor class=\"code-editor html-editor\" [class.invalid]=\"!isValid\" [style.height]=\"height || '300px'\"></div>\r\n<div class=\"error-message\">\r\n <span *ngIf=\"errorMessage\">{{ errorMessage }}</span>\r\n</div>\r\n", styles: [".code-editor{min-height:6rem;background-color:var(--color-json-editor-background-color);color:var(--color-json-editor-text);border:1px solid var(--color-weight-200);border-radius:3px;padding:6px;tab-size:4;font-family:Source Code Pro,Lucida Console,Monaco,monospace;font-size:14px;font-weight:400;height:340px;letter-spacing:normal;line-height:20px;resize:both;text-align:initial;min-width:200px}.code-editor:focus{border-color:var(--color-primary-500)}.code-editor.invalid{border-color:var(--clr-forms-invalid-color)}.error-message{min-height:1rem;color:var(--color-json-editor-error)}.code-editor ::ng-deep .he-tag{color:var(--color-json-editor-key)}.code-editor ::ng-deep .he-attr{color:var(--color-json-editor-number)}.code-editor ::ng-deep .he-error{text-decoration-line:underline;text-decoration-style:wavy;text-decoration-color:var(--color-json-editor-error)}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
54
54
  }
55
55
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.2", ngImport: i0, type: HtmlEditorFormInputComponent, decorators: [{
56
56
  type: Component,
57
- args: [{ selector: 'vdr-html-editor-form-input', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div #editor class=\"code-editor html-editor\" [class.invalid]=\"!isValid\" [style.height]=\"height || '300px'\"></div>\r\n<div class=\"error-message\">\r\n <span *ngIf=\"errorMessage\">{{ errorMessage }}</span>\r\n</div>\r\n", styles: [".code-editor{min-height:6rem;background-color:var(--color-json-editor-background-color);color:var(--color-json-editor-text);border:1px solid var(--color-component-border-200);border-radius:3px;padding:6px;tab-size:4;font-family:Source Code Pro,Lucida Console,Monaco,monospace;font-size:14px;font-weight:400;height:340px;letter-spacing:normal;line-height:20px;resize:both;text-align:initial;min-width:200px}.code-editor:focus{border-color:var(--color-primary-500)}.code-editor.invalid{border-color:var(--clr-forms-invalid-color)}.error-message{min-height:1rem;color:var(--color-json-editor-error)}.code-editor ::ng-deep .he-tag{color:var(--color-json-editor-key)}.code-editor ::ng-deep .he-attr{color:var(--color-json-editor-number)}.code-editor ::ng-deep .he-error{text-decoration-line:underline;text-decoration-style:wavy;text-decoration-color:var(--color-json-editor-error)}\n"] }]
57
+ args: [{ selector: 'vdr-html-editor-form-input', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div #editor class=\"code-editor html-editor\" [class.invalid]=\"!isValid\" [style.height]=\"height || '300px'\"></div>\r\n<div class=\"error-message\">\r\n <span *ngIf=\"errorMessage\">{{ errorMessage }}</span>\r\n</div>\r\n", styles: [".code-editor{min-height:6rem;background-color:var(--color-json-editor-background-color);color:var(--color-json-editor-text);border:1px solid var(--color-weight-200);border-radius:3px;padding:6px;tab-size:4;font-family:Source Code Pro,Lucida Console,Monaco,monospace;font-size:14px;font-weight:400;height:340px;letter-spacing:normal;line-height:20px;resize:both;text-align:initial;min-width:200px}.code-editor:focus{border-color:var(--color-primary-500)}.code-editor.invalid{border-color:var(--clr-forms-invalid-color)}.error-message{min-height:1rem;color:var(--color-json-editor-error)}.code-editor ::ng-deep .he-tag{color:var(--color-json-editor-key)}.code-editor ::ng-deep .he-attr{color:var(--color-json-editor-number)}.code-editor ::ng-deep .he-error{text-decoration-line:underline;text-decoration-style:wavy;text-decoration-color:var(--color-json-editor-error)}\n"] }]
58
58
  }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; } });
59
59
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaHRtbC1lZGl0b3ItZm9ybS1pbnB1dC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvcmUvc3JjL3NoYXJlZC9keW5hbWljLWZvcm0taW5wdXRzL2NvZGUtZWRpdG9yLWZvcm0taW5wdXQvaHRtbC1lZGl0b3ItZm9ybS1pbnB1dC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvcmUvc3JjL3NoYXJlZC9keW5hbWljLWZvcm0taW5wdXRzL2NvZGUtZWRpdG9yLWZvcm0taW5wdXQvaHRtbC1lZGl0b3ItZm9ybS1pbnB1dC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQWlCLHVCQUF1QixFQUFxQixTQUFTLEVBQVUsTUFBTSxlQUFlLENBQUM7QUFNN0csT0FBTyxFQUFFLGdDQUFnQyxFQUFFLE1BQU0seUNBQXlDLENBQUM7OztBQUUzRixTQUFTLGFBQWE7SUFDbEIsT0FBTyxDQUFDLE9BQXdCLEVBQTJCLEVBQUUsQ0FBQyxJQUFJLENBQUM7QUFDdkUsQ0FBQztBQUVELE1BQU0sV0FBVyxHQUFHLGNBQWMsQ0FBQztBQUVuQzs7Ozs7OztHQU9HO0FBT0gsTUFBTSxPQUFPLDRCQUNULFNBQVEsZ0NBQWdDO2FBR3hCLE9BQUUsR0FBMkIsd0JBQXdCLENBQUM7SUFFdEUsWUFBc0IsY0FBaUM7UUFDbkQsS0FBSyxDQUFDLGNBQWMsQ0FBQyxDQUFDO1FBREosbUJBQWMsR0FBZCxjQUFjLENBQW1CO0lBRXZELENBQUM7SUFFRCxRQUFRO1FBQ0osSUFBSSxDQUFDLFNBQVMsQ0FBQztZQUNYLFNBQVMsRUFBRSxhQUFhO1lBQ3hCLFNBQVMsRUFBRSxDQUFDLElBQVksRUFBRSxRQUE0QixFQUFFLEVBQUU7Z0JBQ3RELElBQUksY0FBYyxHQUFHLEtBQUssQ0FBQztnQkFDM0IsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLFdBQVcsRUFBRSxDQUFDLEtBQUssRUFBRSxHQUFHLElBQUksRUFBRSxFQUFFO29CQUNoRCxJQUFJLFVBQVUsR0FBRyxFQUFFLENBQUM7b0JBQ3BCLElBQUksUUFBUSxJQUFJLENBQUMsY0FBYyxFQUFFO3dCQUM3QixNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDO3dCQUM5QixNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7d0JBQ3ZCLElBQUksUUFBUSxJQUFJLE1BQU0sR0FBRyxNQUFNLEVBQUU7NEJBQzdCLFVBQVUsR0FBRyxVQUFVLENBQUM7NEJBQ3hCLGNBQWMsR0FBRyxJQUFJLENBQUM7eUJBQ3pCO3FCQUNKO29CQUNELE9BQU8sQ0FDSCxxQkFBcUI7d0JBQ3JCLEdBQUc7d0JBQ0gsVUFBVTt3QkFDVixJQUFJO3dCQUNKLElBQUksQ0FBQyxlQUFlLENBQUMsS0FBSyxDQUFDLENBQUMsT0FBTyxDQUMvQixtQ0FBbUMsRUFDbkMsQ0FBQyxNQUFNLEVBQUUsR0FBRyxLQUFLLEVBQUUsRUFBRSxDQUFDLEdBQUcsS0FBSyxDQUFDLENBQUMsQ0FBQyx5QkFBeUIsS0FBSyxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQzlFO3dCQUNELFNBQVMsQ0FDWixDQUFDO2dCQUNOLENBQUMsQ0FBQyxDQUFDO1lBQ1AsQ0FBQztZQUNELGVBQWUsRUFBRSxDQUFDLElBQVksRUFBc0IsRUFBRSxDQUFDLFNBQVM7U0FDbkUsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVPLGVBQWUsQ0FBQyxJQUFZO1FBQ2hDLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLEVBQUUsT0FBTyxDQUFDLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxNQUFNLENBQUMsQ0FBQyxPQUFPLENBQUMsSUFBSSxFQUFFLE1BQU0sQ0FBQyxDQUFDO0lBQ25GLENBQUM7OEdBNUNRLDRCQUE0QjtrR0FBNUIsNEJBQTRCLHlGQzVCekMsc09BSUE7OzJGRHdCYSw0QkFBNEI7a0JBTnhDLFNBQVM7K0JBQ0ksNEJBQTRCLG1CQUdyQix1QkFBdUIsQ0FBQyxNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQWZ0ZXJWaWV3SW5pdCwgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENoYW5nZURldGVjdG9yUmVmLCBDb21wb25lbnQsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBBYnN0cmFjdENvbnRyb2wsIFZhbGlkYXRpb25FcnJvcnMsIFZhbGlkYXRvckZuIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5pbXBvcnQgeyBEZWZhdWx0Rm9ybUNvbXBvbmVudElkIH0gZnJvbSAnQHZlbmR1cmUvY29tbW9uL2xpYi9zaGFyZWQtdHlwZXMnO1xyXG5cclxuaW1wb3J0IHsgRm9ybUlucHV0Q29tcG9uZW50IH0gZnJvbSAnLi4vLi4vLi4vY29tbW9uL2NvbXBvbmVudC1yZWdpc3RyeS10eXBlcyc7XHJcblxyXG5pbXBvcnQgeyBCYXNlQ29kZUVkaXRvckZvcm1JbnB1dENvbXBvbmVudCB9IGZyb20gJy4vYmFzZS1jb2RlLWVkaXRvci1mb3JtLWlucHV0LmNvbXBvbmVudCc7XHJcblxyXG5mdW5jdGlvbiBodG1sVmFsaWRhdG9yKCk6IFZhbGlkYXRvckZuIHtcclxuICAgIHJldHVybiAoY29udHJvbDogQWJzdHJhY3RDb250cm9sKTogVmFsaWRhdGlvbkVycm9ycyB8IG51bGwgPT4gbnVsbDtcclxufVxyXG5cclxuY29uc3QgSFRNTF9UQUdfUkUgPSAvPFxcLz9bXj5dKz4/L2c7XHJcblxyXG4vKipcclxuICogQGRlc2NyaXB0aW9uXHJcbiAqIEEgSlNPTiBlZGl0b3IgaW5wdXQgd2l0aCBzeW50YXggaGlnaGxpZ2h0aW5nIGFuZCBlcnJvciBkZXRlY3Rpb24uIFdvcmtzIHdlbGxcclxuICogd2l0aCBgdGV4dGAgdHlwZSBmaWVsZHMuXHJcbiAqXHJcbiAqIEBkb2NzQ2F0ZWdvcnkgY3VzdG9tLWlucHV0LWNvbXBvbmVudHNcclxuICogQGRvY3NQYWdlIGRlZmF1bHQtaW5wdXRzXHJcbiAqL1xyXG5AQ29tcG9uZW50KHtcclxuICAgIHNlbGVjdG9yOiAndmRyLWh0bWwtZWRpdG9yLWZvcm0taW5wdXQnLFxyXG4gICAgdGVtcGxhdGVVcmw6ICcuL2h0bWwtZWRpdG9yLWZvcm0taW5wdXQuY29tcG9uZW50Lmh0bWwnLFxyXG4gICAgc3R5bGVVcmxzOiBbJy4vaHRtbC1lZGl0b3ItZm9ybS1pbnB1dC5jb21wb25lbnQuc2NzcyddLFxyXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBIdG1sRWRpdG9yRm9ybUlucHV0Q29tcG9uZW50XHJcbiAgICBleHRlbmRzIEJhc2VDb2RlRWRpdG9yRm9ybUlucHV0Q29tcG9uZW50XHJcbiAgICBpbXBsZW1lbnRzIEZvcm1JbnB1dENvbXBvbmVudCwgQWZ0ZXJWaWV3SW5pdCwgT25Jbml0XHJcbntcclxuICAgIHN0YXRpYyByZWFkb25seSBpZDogRGVmYXVsdEZvcm1Db21wb25lbnRJZCA9ICdodG1sLWVkaXRvci1mb3JtLWlucHV0JztcclxuXHJcbiAgICBjb25zdHJ1Y3Rvcihwcm90ZWN0ZWQgY2hhbmdlRGV0ZWN0b3I6IENoYW5nZURldGVjdG9yUmVmKSB7XHJcbiAgICAgICAgc3VwZXIoY2hhbmdlRGV0ZWN0b3IpO1xyXG4gICAgfVxyXG5cclxuICAgIG5nT25Jbml0KCkge1xyXG4gICAgICAgIHRoaXMuY29uZmlndXJlKHtcclxuICAgICAgICAgICAgdmFsaWRhdG9yOiBodG1sVmFsaWRhdG9yLFxyXG4gICAgICAgICAgICBoaWdobGlnaHQ6IChodG1sOiBzdHJpbmcsIGVycm9yUG9zOiBudW1iZXIgfCB1bmRlZmluZWQpID0+IHtcclxuICAgICAgICAgICAgICAgIGxldCBoYXNNYXJrZWRFcnJvciA9IGZhbHNlO1xyXG4gICAgICAgICAgICAgICAgcmV0dXJuIGh0bWwucmVwbGFjZShIVE1MX1RBR19SRSwgKG1hdGNoLCAuLi5hcmdzKSA9PiB7XHJcbiAgICAgICAgICAgICAgICAgICAgbGV0IGVycm9yQ2xhc3MgPSAnJztcclxuICAgICAgICAgICAgICAgICAgICBpZiAoZXJyb3JQb3MgJiYgIWhhc01hcmtlZEVycm9yKSB7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgIGNvbnN0IGxlbmd0aCA9IGFyZ3NbMF0ubGVuZ3RoO1xyXG4gICAgICAgICAgICAgICAgICAgICAgICBjb25zdCBvZmZzZXQgPSBhcmdzWzRdO1xyXG4gICAgICAgICAgICAgICAgICAgICAgICBpZiAoZXJyb3JQb3MgPD0gbGVuZ3RoICsgb2Zmc2V0KSB7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBlcnJvckNsYXNzID0gJ2plLWVycm9yJztcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIGhhc01hcmtlZEVycm9yID0gdHJ1ZTtcclxuICAgICAgICAgICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgICAgICAgICByZXR1cm4gKFxyXG4gICAgICAgICAgICAgICAgICAgICAgICAnPHNwYW4gY2xhc3M9XCJoZS10YWcnICtcclxuICAgICAgICAgICAgICAgICAgICAgICAgJyAnICtcclxuICAgICAgICAgICAgICAgICAgICAgICAgZXJyb3JDbGFzcyArXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICdcIj4nICtcclxuICAgICAgICAgICAgICAgICAgICAgICAgdGhpcy5lbmNvZGVIdG1sQ2hhcnMobWF0Y2gpLnJlcGxhY2UoXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAvKFthLXpBLVowLTktXSs9KShbXCInXVteJ1wiXSpbXCInXSkvZyxcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIChfbWF0Y2gsIC4uLl9hcmdzKSA9PiBgJHtfYXJnc1swXX08c3BhbiBjbGFzcz1cImhlLWF0dHJcIj4ke19hcmdzWzFdfTwvc3Bhbj5gLFxyXG4gICAgICAgICAgICAgICAgICAgICAgICApICtcclxuICAgICAgICAgICAgICAgICAgICAgICAgJzwvc3Bhbj4nXHJcbiAgICAgICAgICAgICAgICAgICAgKTtcclxuICAgICAgICAgICAgICAgIH0pO1xyXG4gICAgICAgICAgICB9LFxyXG4gICAgICAgICAgICBnZXRFcnJvck1lc3NhZ2U6IChqc29uOiBzdHJpbmcpOiBzdHJpbmcgfCB1bmRlZmluZWQgPT4gdW5kZWZpbmVkLFxyXG4gICAgICAgIH0pO1xyXG4gICAgfVxyXG5cclxuICAgIHByaXZhdGUgZW5jb2RlSHRtbENoYXJzKGh0bWw6IHN0cmluZyk6IHN0cmluZyB7XHJcbiAgICAgICAgcmV0dXJuIGh0bWwucmVwbGFjZSgvJi9nLCAnJmFtcDsnKS5yZXBsYWNlKC88L2csICcmbHQ7JykucmVwbGFjZSgvPi9nLCAnJmd0OycpO1xyXG4gICAgfVxyXG59XHJcbiIsIjxkaXYgI2VkaXRvciBjbGFzcz1cImNvZGUtZWRpdG9yIGh0bWwtZWRpdG9yXCIgW2NsYXNzLmludmFsaWRdPVwiIWlzVmFsaWRcIiBbc3R5bGUuaGVpZ2h0XT1cImhlaWdodCB8fCAnMzAwcHgnXCI+PC9kaXY+XHJcbjxkaXYgY2xhc3M9XCJlcnJvci1tZXNzYWdlXCI+XHJcbiAgICA8c3BhbiAqbmdJZj1cImVycm9yTWVzc2FnZVwiPnt7IGVycm9yTWVzc2FnZSB9fTwvc3Bhbj5cclxuPC9kaXY+XHJcbiJdfQ==
@@ -76,10 +76,10 @@ export class JsonEditorFormInputComponent extends BaseCodeEditorFormInputCompone
76
76
  });
77
77
  }
78
78
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.2", ngImport: i0, type: JsonEditorFormInputComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
79
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.2", type: JsonEditorFormInputComponent, selector: "vdr-json-editor-form-input", usesInheritance: true, ngImport: i0, template: "<div #editor class=\"code-editor json-editor\" [class.invalid]=\"!isValid\" [style.height]=\"height || '300px'\"></div>\r\n<div class=\"error-message\">\r\n <span *ngIf=\"errorMessage\">{{ errorMessage }}</span>\r\n</div>\r\n", styles: [".code-editor{min-height:6rem;background-color:var(--color-json-editor-background-color);color:var(--color-json-editor-text);border:1px solid var(--color-component-border-200);border-radius:3px;padding:6px;tab-size:4;font-family:Source Code Pro,Lucida Console,Monaco,monospace;font-size:14px;font-weight:400;height:340px;letter-spacing:normal;line-height:20px;resize:both;text-align:initial;min-width:200px}.code-editor:focus{border-color:var(--color-primary-500)}.code-editor.invalid{border-color:var(--clr-forms-invalid-color)}.error-message{min-height:1rem;color:var(--color-json-editor-error)}.code-editor ::ng-deep .je-string{color:var(--color-json-editor-string)}.code-editor ::ng-deep .je-number{color:var(--color-json-editor-number)}.code-editor ::ng-deep .je-boolean{color:var(--color-json-editor-boolean)}.code-editor ::ng-deep .je-null{color:var(--color-json-editor-null)}.code-editor ::ng-deep .je-key{color:var(--color-json-editor-key)}.code-editor ::ng-deep .je-error{text-decoration-line:underline;text-decoration-style:wavy;text-decoration-color:var(--color-json-editor-error)}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
79
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.2", type: JsonEditorFormInputComponent, selector: "vdr-json-editor-form-input", usesInheritance: true, ngImport: i0, template: "<div #editor class=\"code-editor json-editor\" [class.invalid]=\"!isValid\" [style.height]=\"height || '300px'\"></div>\r\n<div class=\"error-message\">\r\n <span *ngIf=\"errorMessage\">{{ errorMessage }}</span>\r\n</div>\r\n", styles: [".code-editor{min-height:6rem;background-color:var(--color-json-editor-background-color);color:var(--color-json-editor-text);border:1px solid var(--color-weight-200);border-radius:3px;padding:6px;tab-size:4;font-family:Source Code Pro,Lucida Console,Monaco,monospace;font-size:14px;font-weight:400;height:340px;letter-spacing:normal;line-height:20px;resize:both;text-align:initial;min-width:200px}.code-editor:focus{border-color:var(--color-primary-500)}.code-editor.invalid{border-color:var(--clr-forms-invalid-color)}.error-message{min-height:1rem;color:var(--color-json-editor-error)}.code-editor ::ng-deep .je-string{color:var(--color-json-editor-string)}.code-editor ::ng-deep .je-number{color:var(--color-json-editor-number)}.code-editor ::ng-deep .je-boolean{color:var(--color-json-editor-boolean)}.code-editor ::ng-deep .je-null{color:var(--color-json-editor-null)}.code-editor ::ng-deep .je-key{color:var(--color-json-editor-key)}.code-editor ::ng-deep .je-error{text-decoration-line:underline;text-decoration-style:wavy;text-decoration-color:var(--color-json-editor-error)}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
80
80
  }
81
81
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.2", ngImport: i0, type: JsonEditorFormInputComponent, decorators: [{
82
82
  type: Component,
83
- args: [{ selector: 'vdr-json-editor-form-input', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div #editor class=\"code-editor json-editor\" [class.invalid]=\"!isValid\" [style.height]=\"height || '300px'\"></div>\r\n<div class=\"error-message\">\r\n <span *ngIf=\"errorMessage\">{{ errorMessage }}</span>\r\n</div>\r\n", styles: [".code-editor{min-height:6rem;background-color:var(--color-json-editor-background-color);color:var(--color-json-editor-text);border:1px solid var(--color-component-border-200);border-radius:3px;padding:6px;tab-size:4;font-family:Source Code Pro,Lucida Console,Monaco,monospace;font-size:14px;font-weight:400;height:340px;letter-spacing:normal;line-height:20px;resize:both;text-align:initial;min-width:200px}.code-editor:focus{border-color:var(--color-primary-500)}.code-editor.invalid{border-color:var(--clr-forms-invalid-color)}.error-message{min-height:1rem;color:var(--color-json-editor-error)}.code-editor ::ng-deep .je-string{color:var(--color-json-editor-string)}.code-editor ::ng-deep .je-number{color:var(--color-json-editor-number)}.code-editor ::ng-deep .je-boolean{color:var(--color-json-editor-boolean)}.code-editor ::ng-deep .je-null{color:var(--color-json-editor-null)}.code-editor ::ng-deep .je-key{color:var(--color-json-editor-key)}.code-editor ::ng-deep .je-error{text-decoration-line:underline;text-decoration-style:wavy;text-decoration-color:var(--color-json-editor-error)}\n"] }]
83
+ args: [{ selector: 'vdr-json-editor-form-input', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div #editor class=\"code-editor json-editor\" [class.invalid]=\"!isValid\" [style.height]=\"height || '300px'\"></div>\r\n<div class=\"error-message\">\r\n <span *ngIf=\"errorMessage\">{{ errorMessage }}</span>\r\n</div>\r\n", styles: [".code-editor{min-height:6rem;background-color:var(--color-json-editor-background-color);color:var(--color-json-editor-text);border:1px solid var(--color-weight-200);border-radius:3px;padding:6px;tab-size:4;font-family:Source Code Pro,Lucida Console,Monaco,monospace;font-size:14px;font-weight:400;height:340px;letter-spacing:normal;line-height:20px;resize:both;text-align:initial;min-width:200px}.code-editor:focus{border-color:var(--color-primary-500)}.code-editor.invalid{border-color:var(--clr-forms-invalid-color)}.error-message{min-height:1rem;color:var(--color-json-editor-error)}.code-editor ::ng-deep .je-string{color:var(--color-json-editor-string)}.code-editor ::ng-deep .je-number{color:var(--color-json-editor-number)}.code-editor ::ng-deep .je-boolean{color:var(--color-json-editor-boolean)}.code-editor ::ng-deep .je-null{color:var(--color-json-editor-null)}.code-editor ::ng-deep .je-key{color:var(--color-json-editor-key)}.code-editor ::ng-deep .je-error{text-decoration-line:underline;text-decoration-style:wavy;text-decoration-color:var(--color-json-editor-error)}\n"] }]
84
84
  }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; } });
85
85
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"json-editor-form-input.component.js","sourceRoot":"","sources":["../../../../../../src/lib/core/src/shared/dynamic-form-inputs/code-editor-form-input/json-editor-form-input.component.ts","../../../../../../src/lib/core/src/shared/dynamic-form-inputs/code-editor-form-input/json-editor-form-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, ChangeDetectionStrategy, ChangeDetectorRef, Component, OnInit } from '@angular/core';\r\nimport { AbstractControl, ValidationErrors, ValidatorFn } from '@angular/forms';\r\nimport { DefaultFormComponentId } from '@vendure/common/lib/shared-types';\r\n\r\nimport { FormInputComponent } from '../../../common/component-registry-types';\r\n\r\nimport { BaseCodeEditorFormInputComponent } from './base-code-editor-form-input.component';\r\n\r\nexport function jsonValidator(): ValidatorFn {\r\n    return (control: AbstractControl): ValidationErrors | null => {\r\n        const error: ValidationErrors = { jsonInvalid: true };\r\n\r\n        try {\r\n            JSON.parse(control.value);\r\n        } catch (e: any) {\r\n            control.setErrors(error);\r\n            return error;\r\n        }\r\n\r\n        control.setErrors(null);\r\n        return null;\r\n    };\r\n}\r\n\r\n/**\r\n * @description\r\n * A JSON editor input with syntax highlighting and error detection. Works well\r\n * with `text` type fields.\r\n *\r\n * @docsCategory custom-input-components\r\n * @docsPage default-inputs\r\n */\r\n@Component({\r\n    selector: 'vdr-json-editor-form-input',\r\n    templateUrl: './json-editor-form-input.component.html',\r\n    styleUrls: ['./json-editor-form-input.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class JsonEditorFormInputComponent\r\n    extends BaseCodeEditorFormInputComponent\r\n    implements FormInputComponent, AfterViewInit, OnInit\r\n{\r\n    static readonly id: DefaultFormComponentId = 'json-editor-form-input';\r\n\r\n    constructor(protected changeDetector: ChangeDetectorRef) {\r\n        super(changeDetector);\r\n    }\r\n\r\n    ngOnInit() {\r\n        this.configure({\r\n            validator: jsonValidator,\r\n            highlight: (json: string, errorPos: number | undefined) => {\r\n                json = json.replace(/&/g, '&amp;').replace(/</g, '&lt;').replace(/>/g, '&gt;');\r\n                let hasMarkedError = false;\r\n                return json.replace(\r\n                    /(\"(\\\\u[a-zA-Z0-9]{4}|\\\\[^u]|[^\\\\\"])*\"(\\s*:)?|\\b(true|false|null)\\b|-?\\d+(?:\\.\\d*)?(?:[eE][+\\-]?\\d+)?)/g,\r\n                    (match, ...args) => {\r\n                        let cls = 'number';\r\n                        if (/^\"/.test(match)) {\r\n                            if (/:$/.test(match)) {\r\n                                cls = 'key';\r\n                            } else {\r\n                                cls = 'string';\r\n                            }\r\n                        } else if (/true|false/.test(match)) {\r\n                            cls = 'boolean';\r\n                        } else if (/null/.test(match)) {\r\n                            cls = 'null';\r\n                        }\r\n                        let errorClass = '';\r\n                        if (errorPos && !hasMarkedError) {\r\n                            const length = args[0].length;\r\n                            const offset = args[4];\r\n                            if (errorPos <= length + offset) {\r\n                                errorClass = 'je-error';\r\n                                hasMarkedError = true;\r\n                            }\r\n                        }\r\n                        return '<span class=\"je-' + cls + ' ' + errorClass + '\">' + match + '</span>';\r\n                    },\r\n                );\r\n            },\r\n            getErrorMessage: (json: string): string | undefined => {\r\n                try {\r\n                    JSON.parse(json);\r\n                } catch (e: any) {\r\n                    return e.message;\r\n                }\r\n                return;\r\n            },\r\n        });\r\n    }\r\n}\r\n","<div #editor class=\"code-editor json-editor\" [class.invalid]=\"!isValid\" [style.height]=\"height || '300px'\"></div>\r\n<div class=\"error-message\">\r\n    <span *ngIf=\"errorMessage\">{{ errorMessage }}</span>\r\n</div>\r\n"]}