@datarailsshared/datarailsshared 1.6.145 → 1.6.147

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.
@@ -257,7 +257,10 @@ export class DialogModalWrapperComponent {
257
257
  }), tap(() => this.fieldsItemsLoading[currentValue.name].next(false)), finalize(() => this.fieldsItemsLoading[currentValue.name].next(false)));
258
258
  }
259
259
  const currentFormControl = {};
260
- currentFormControl[currentValue.name] = new FormControl(currentValue.default || null, currentValue.validators || [], currentValue.asyncValidators || []);
260
+ currentFormControl[currentValue.name] = new FormControl(currentValue.default || null, {
261
+ validators: currentValue.validators || [],
262
+ asyncValidators: currentValue.asyncValidators || [],
263
+ });
261
264
  return Object.assign(accumulator, currentFormControl);
262
265
  }, {}));
263
266
  }
@@ -342,4 +345,4 @@ export class DialogModalWrapperComponent {
342
345
  type: HostBinding,
343
346
  args: ['class']
344
347
  }] }); })();
345
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog-modal-wrapper.component.js","sourceRoot":"","sources":["../../../../../../../projects/datarailsshared/src/lib/dr-dialog/components/dialog-modal-wrapper/dialog-modal-wrapper.component.ts","../../../../../../../projects/datarailsshared/src/lib/dr-dialog/components/dialog-modal-wrapper/dialog-modal-wrapper.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, HostBinding, Inject, OnDestroy, OnInit } from '@angular/core';\nimport { FormControl, FormGroup } from '@angular/forms';\nimport { MAT_LEGACY_DIALOG_DATA as MAT_DIALOG_DATA, MatLegacyDialogRef as MatDialogRef } from '@angular/material/legacy-dialog';\nimport { DataProp, DIALOG_FIELD_TYPE } from '../../interfaces/dialog-data';\nimport { BehaviorSubject, Subject, throwError } from 'rxjs';\nimport { catchError, finalize, takeUntil, tap } from 'rxjs/operators';\n\n@Component({\n    selector: 'dr-dialog-modal-wrapper',\n    templateUrl: './dialog-modal-wrapper.component.html',\n    styleUrls: ['./dialog-modal-wrapper.component.scss'],\n})\nexport class DialogModalWrapperComponent implements OnInit, OnDestroy {\n    readonly dialogFieldType = DIALOG_FIELD_TYPE;\n    readonly destroy$ = new Subject<void>();\n\n    form: FormGroup;\n    saving$ = new BehaviorSubject(false);\n    isLoading = false;\n    showServerErrorMessage = false;\n    fieldsItemsLoading: Record<string, BehaviorSubject<boolean>> = {};\n\n    @HostBinding('class') class = this?.dialogData?.theme?.themeSize;\n\n    constructor(\n        public dialogRef: MatDialogRef<DialogModalWrapperComponent>,\n        @Inject(MAT_DIALOG_DATA) public dialogData: DataProp,\n    ) {}\n\n    ngOnInit(): void {\n        if (!this.dialogData.fields) this.dialogData.fields = [];\n\n        this.form = new FormGroup(\n            this.dialogData.fields.reduce((accumulator, currentValue) => {\n                if (currentValue.items$) {\n                    this.fieldsItemsLoading[currentValue.name] = new BehaviorSubject<boolean>(true);\n                    currentValue.items$ = (currentValue.items$ as any).pipe(\n                        catchError((err) => {\n                            this.fieldsItemsLoading[currentValue.name].next(false);\n                            return throwError(() => err);\n                        }),\n                        tap(() => this.fieldsItemsLoading[currentValue.name].next(false)),\n                        finalize(() => this.fieldsItemsLoading[currentValue.name].next(false)),\n                    );\n                }\n\n                const currentFormControl = {};\n                currentFormControl[currentValue.name] = new FormControl(\n                    currentValue.default || null,\n                    currentValue.validators || [],\n                    currentValue.asyncValidators || [],\n                );\n                return Object.assign(accumulator, currentFormControl);\n            }, {}),\n        );\n    }\n\n    onAccept() {\n        if (!this.dialogData.confirmFn) return this.dialogRef.close(this.form.value || true);\n\n        this.isLoading = true;\n        this.saving$.next(true);\n        this.dialogData\n            .confirmFn(this.form.value)\n            .pipe(\n                finalize(() => {\n                    this.isLoading = false;\n                    this.saving$.next(false);\n                }),\n                takeUntil(this.destroy$),\n                catchError((err) => {\n                    this.showServerErrorMessage = true;\n                    this.isLoading = false;\n                    this.saving$.next(false);\n                    return throwError(() => err);\n                }),\n            )\n            .subscribe(() => {\n                this.saving$.next(false);\n                this.dialogRef.close(this.form.value || true);\n            });\n    }\n\n    onDecline() {\n        this.dialogRef.close(undefined);\n    }\n\n    onCancel() {\n        const functions = this.dialogData?.cancelButton?.functions;\n        if (functions) functions();\n\n        this.dialogRef.close(false);\n    }\n\n    footerAction(): void {\n        this.dialogData.footerTemplateData.action(this.form.value);\n    }\n\n    closeDialog() {\n        this.dialogRef.close(false);\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n}\n","<div header class=\"header-dialog\">\n    <h1 class=\"title-dialog\" data-test=\"modalTitle\">\n        <i\n            *ngIf=\"dialogData.headerIconClass\"\n            (click)=\"closeDialog()\"\n            class=\"title-dialog__icon\"\n            [class]=\"dialogData.headerIconClass\"\n            data-test=\"dialogTitleIcon\"></i>\n        <span class=\"title-dialog__text\">{{ dialogData.title }}</span>\n    </h1>\n    <i *ngIf=\"!dialogData.hideCloseBtn\" (click)=\"closeDialog()\" class=\"dr-icon-exit icon-close\" data-test=\"xBtn\"></i>\n</div>\n<div *ngIf=\"dialogData.content\" class=\"content-dialog\" [innerHTML]=\"dialogData.content\">\n    <span #content class=\"content-anchor\"></span>\n</div>\n<form *ngIf=\"dialogData.fields\" [formGroup]=\"form\" class=\"dr-smart-from\">\n    <div [class]=\"dialogData.formWrapperClass || 'dr-smart-form_wrapper'\">\n        <div\n            *ngFor=\"let field of dialogData.fields\"\n            class=\"dr-smart-form_group\"\n            [class]=\"field.formGroupClass\"\n            [ngStyle]=\"{ display: field.isLabelFullWidth ? 'block' : 'flex' }\">\n            <label\n                *ngIf=\"field.label && field.type !== dialogFieldType.CHECKBOX\"\n                [ngClass]=\"field.isLabelFullWidth ? 'col-md-12 mb-2' : 'col-md-2'\"\n                class=\"label p-0 d-flex align-items-center\"\n                >{{ field.label }}</label\n            >\n            <div\n                class=\"input-group p-0\"\n                [ngClass]=\"{\n                    'col-md-10': field.label && !field.isLabelFullWidth,\n                    'col-md-12': !field.label || field.isLabelFullWidth,\n                }\">\n                <dr-select\n                    *ngIf=\"field.type === dialogFieldType.SELECT\"\n                    [searchable]=\"dialogData.searchable\"\n                    [clearable]=\"dialogData.clearable\"\n                    [formControlName]=\"field.name\"\n                    [addTag]=\"field.addTag\"\n                    [bindLabel]=\"field.bindLabel || null\"\n                    [bindValue]=\"field.bindValue || null\"\n                    [selectedItem]=\"field.default\"\n                    [items]=\"field.items || (field.items$ | async)\"\n                    [loading]=\"fieldsItemsLoading[field.name] | async\"\n                    [required]=\"!field.isOptional\"\n                    [placeholder]=\"field.placeholder\">\n                    <ng-template *ngIf=\"dialogData?.footerTemplateData\" #optionFooterTemplate let-item=\"item\" let-close=\"close\">\n                        <button (click)=\"footerAction(); close()\" class=\"dr-select-footer__btn\">\n                            <i *ngIf=\"dialogData.footerTemplateData.icon\" class=\"{{ dialogData.footerTemplateData.icon }}\"></i>\n                            {{ dialogData.footerTemplateData.label }}\n                        </button>\n                    </ng-template>\n                </dr-select>\n                <dr-input\n                    *ngIf=\"field.type === dialogFieldType.INPUT\"\n                    data-test=\"modalInput\"\n                    class=\"form-control\"\n                    [formControlName]=\"field.name\"\n                    [placeholder]=\"field.placeholder\"></dr-input>\n                <dr-date-picker\n                    *ngIf=\"field.type === dialogFieldType.DATE_PICKER\"\n                    [formControlName]=\"field.name\"\n                    [format]=\"field.datePickerFormat\"\n                    [placeholder]=\"field.placeholder\"></dr-date-picker>\n                <dr-checkbox *ngIf=\"field.type === dialogFieldType.CHECKBOX\" [formControlName]=\"field.name\">\n                    {{ field.label }}\n                </dr-checkbox>\n                <label\n                    class=\"form-field-error-alert\"\n                    *ngIf=\"form.invalid && form.controls[field.name]?.dirty && form.controls[field.name]?.errors\">\n                    {{ form.controls[field.name].errors.errorString }}\n                </label>\n                <label class=\"form-error-alert\" *ngIf=\"dialogData.errorMessage && !form.pristine && form.invalid\">\n                    {{ dialogData.errorMessage }}\n                </label>\n                <label class=\"form-error-alert\" *ngIf=\"form.valid && showServerErrorMessage && dialogData.serverErrorMessage\">\n                    {{ dialogData.serverErrorMessage }}\n                </label>\n            </div>\n        </div>\n    </div>\n</form>\n\n<div footer class=\"footer-dialog\">\n    <div class=\"buttons-wrapper\" *ngIf=\"dialogData.cancelButton || dialogData.acceptButton\">\n        <dr-button\n            (click)=\"onDecline()\"\n            *ngIf=\"dialogData.customButton\"\n            [theme]=\"dialogData.customButton?.theme || 'secondary'\"\n            class=\"buttons-wrapper--custom-btn\"\n            data-test=\"declineBtn\"\n            >{{ dialogData.customButton.label }}</dr-button\n        >\n        <dr-button *ngIf=\"dialogData.cancelButton\" data-test=\"modalCloseBtn\" (click)=\"onCancel()\" [theme]=\"'secondary'\">{{\n            dialogData.cancelButton.label\n        }}</dr-button>\n        <dr-button\n            *ngIf=\"dialogData.acceptButton\"\n            data-test=\"modalAddBtn\"\n            (click)=\"onAccept()\"\n            [theme]=\"'primary'\"\n            [isLoading]=\"isLoading\"\n            [disabled]=\"form.invalid\"\n            >{{ dialogData.acceptButton.label }}</dr-button\n        >\n    </div>\n</div>\n"]}
348
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog-modal-wrapper.component.js","sourceRoot":"","sources":["../../../../../../../projects/datarailsshared/src/lib/dr-dialog/components/dialog-modal-wrapper/dialog-modal-wrapper.component.ts","../../../../../../../projects/datarailsshared/src/lib/dr-dialog/components/dialog-modal-wrapper/dialog-modal-wrapper.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, HostBinding, Inject, OnDestroy, OnInit } from '@angular/core';\nimport { FormControl, FormGroup } from '@angular/forms';\nimport { MAT_LEGACY_DIALOG_DATA as MAT_DIALOG_DATA, MatLegacyDialogRef as MatDialogRef } from '@angular/material/legacy-dialog';\nimport { DataProp, DIALOG_FIELD_TYPE } from '../../interfaces/dialog-data';\nimport { BehaviorSubject, Subject, throwError } from 'rxjs';\nimport { catchError, finalize, takeUntil, tap } from 'rxjs/operators';\n\n@Component({\n    selector: 'dr-dialog-modal-wrapper',\n    templateUrl: './dialog-modal-wrapper.component.html',\n    styleUrls: ['./dialog-modal-wrapper.component.scss'],\n})\nexport class DialogModalWrapperComponent implements OnInit, OnDestroy {\n    readonly dialogFieldType = DIALOG_FIELD_TYPE;\n    readonly destroy$ = new Subject<void>();\n\n    form: FormGroup;\n    saving$ = new BehaviorSubject(false);\n    isLoading = false;\n    showServerErrorMessage = false;\n    fieldsItemsLoading: Record<string, BehaviorSubject<boolean>> = {};\n\n    @HostBinding('class') class = this?.dialogData?.theme?.themeSize;\n\n    constructor(\n        public dialogRef: MatDialogRef<DialogModalWrapperComponent>,\n        @Inject(MAT_DIALOG_DATA) public dialogData: DataProp,\n    ) {}\n\n    ngOnInit(): void {\n        if (!this.dialogData.fields) this.dialogData.fields = [];\n\n        this.form = new FormGroup(\n            this.dialogData.fields.reduce((accumulator, currentValue) => {\n                if (currentValue.items$) {\n                    this.fieldsItemsLoading[currentValue.name] = new BehaviorSubject<boolean>(true);\n                    currentValue.items$ = (currentValue.items$ as any).pipe(\n                        catchError((err) => {\n                            this.fieldsItemsLoading[currentValue.name].next(false);\n                            return throwError(() => err);\n                        }),\n                        tap(() => this.fieldsItemsLoading[currentValue.name].next(false)),\n                        finalize(() => this.fieldsItemsLoading[currentValue.name].next(false)),\n                    );\n                }\n\n                const currentFormControl = {};\n                currentFormControl[currentValue.name] = new FormControl(currentValue.default || null, {\n                    validators: currentValue.validators || [],\n                    asyncValidators: currentValue.asyncValidators || [],\n                });\n                return Object.assign(accumulator, currentFormControl);\n            }, {}),\n        );\n    }\n\n    onAccept() {\n        if (!this.dialogData.confirmFn) return this.dialogRef.close(this.form.value || true);\n\n        this.isLoading = true;\n        this.saving$.next(true);\n        this.dialogData\n            .confirmFn(this.form.value)\n            .pipe(\n                finalize(() => {\n                    this.isLoading = false;\n                    this.saving$.next(false);\n                }),\n                takeUntil(this.destroy$),\n                catchError((err) => {\n                    this.showServerErrorMessage = true;\n                    this.isLoading = false;\n                    this.saving$.next(false);\n                    return throwError(() => err);\n                }),\n            )\n            .subscribe(() => {\n                this.saving$.next(false);\n                this.dialogRef.close(this.form.value || true);\n            });\n    }\n\n    onDecline() {\n        this.dialogRef.close(undefined);\n    }\n\n    onCancel() {\n        const functions = this.dialogData?.cancelButton?.functions;\n        if (functions) functions();\n\n        this.dialogRef.close(false);\n    }\n\n    footerAction(): void {\n        this.dialogData.footerTemplateData.action(this.form.value);\n    }\n\n    closeDialog() {\n        this.dialogRef.close(false);\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n}\n","<div header class=\"header-dialog\">\n    <h1 class=\"title-dialog\" data-test=\"modalTitle\">\n        <i\n            *ngIf=\"dialogData.headerIconClass\"\n            (click)=\"closeDialog()\"\n            class=\"title-dialog__icon\"\n            [class]=\"dialogData.headerIconClass\"\n            data-test=\"dialogTitleIcon\"></i>\n        <span class=\"title-dialog__text\">{{ dialogData.title }}</span>\n    </h1>\n    <i *ngIf=\"!dialogData.hideCloseBtn\" (click)=\"closeDialog()\" class=\"dr-icon-exit icon-close\" data-test=\"xBtn\"></i>\n</div>\n<div *ngIf=\"dialogData.content\" class=\"content-dialog\" [innerHTML]=\"dialogData.content\">\n    <span #content class=\"content-anchor\"></span>\n</div>\n<form *ngIf=\"dialogData.fields\" [formGroup]=\"form\" class=\"dr-smart-from\">\n    <div [class]=\"dialogData.formWrapperClass || 'dr-smart-form_wrapper'\">\n        <div\n            *ngFor=\"let field of dialogData.fields\"\n            class=\"dr-smart-form_group\"\n            [class]=\"field.formGroupClass\"\n            [ngStyle]=\"{ display: field.isLabelFullWidth ? 'block' : 'flex' }\">\n            <label\n                *ngIf=\"field.label && field.type !== dialogFieldType.CHECKBOX\"\n                [ngClass]=\"field.isLabelFullWidth ? 'col-md-12 mb-2' : 'col-md-2'\"\n                class=\"label p-0 d-flex align-items-center\"\n                >{{ field.label }}</label\n            >\n            <div\n                class=\"input-group p-0\"\n                [ngClass]=\"{\n                    'col-md-10': field.label && !field.isLabelFullWidth,\n                    'col-md-12': !field.label || field.isLabelFullWidth,\n                }\">\n                <dr-select\n                    *ngIf=\"field.type === dialogFieldType.SELECT\"\n                    [searchable]=\"dialogData.searchable\"\n                    [clearable]=\"dialogData.clearable\"\n                    [formControlName]=\"field.name\"\n                    [addTag]=\"field.addTag\"\n                    [bindLabel]=\"field.bindLabel || null\"\n                    [bindValue]=\"field.bindValue || null\"\n                    [selectedItem]=\"field.default\"\n                    [items]=\"field.items || (field.items$ | async)\"\n                    [loading]=\"fieldsItemsLoading[field.name] | async\"\n                    [required]=\"!field.isOptional\"\n                    [placeholder]=\"field.placeholder\">\n                    <ng-template *ngIf=\"dialogData?.footerTemplateData\" #optionFooterTemplate let-item=\"item\" let-close=\"close\">\n                        <button (click)=\"footerAction(); close()\" class=\"dr-select-footer__btn\">\n                            <i *ngIf=\"dialogData.footerTemplateData.icon\" class=\"{{ dialogData.footerTemplateData.icon }}\"></i>\n                            {{ dialogData.footerTemplateData.label }}\n                        </button>\n                    </ng-template>\n                </dr-select>\n                <dr-input\n                    *ngIf=\"field.type === dialogFieldType.INPUT\"\n                    data-test=\"modalInput\"\n                    class=\"form-control\"\n                    [formControlName]=\"field.name\"\n                    [placeholder]=\"field.placeholder\"></dr-input>\n                <dr-date-picker\n                    *ngIf=\"field.type === dialogFieldType.DATE_PICKER\"\n                    [formControlName]=\"field.name\"\n                    [format]=\"field.datePickerFormat\"\n                    [placeholder]=\"field.placeholder\"></dr-date-picker>\n                <dr-checkbox *ngIf=\"field.type === dialogFieldType.CHECKBOX\" [formControlName]=\"field.name\">\n                    {{ field.label }}\n                </dr-checkbox>\n                <label\n                    class=\"form-field-error-alert\"\n                    *ngIf=\"form.invalid && form.controls[field.name]?.dirty && form.controls[field.name]?.errors\">\n                    {{ form.controls[field.name].errors.errorString }}\n                </label>\n                <label class=\"form-error-alert\" *ngIf=\"dialogData.errorMessage && !form.pristine && form.invalid\">\n                    {{ dialogData.errorMessage }}\n                </label>\n                <label class=\"form-error-alert\" *ngIf=\"form.valid && showServerErrorMessage && dialogData.serverErrorMessage\">\n                    {{ dialogData.serverErrorMessage }}\n                </label>\n            </div>\n        </div>\n    </div>\n</form>\n\n<div footer class=\"footer-dialog\">\n    <div class=\"buttons-wrapper\" *ngIf=\"dialogData.cancelButton || dialogData.acceptButton\">\n        <dr-button\n            (click)=\"onDecline()\"\n            *ngIf=\"dialogData.customButton\"\n            [theme]=\"dialogData.customButton?.theme || 'secondary'\"\n            class=\"buttons-wrapper--custom-btn\"\n            data-test=\"declineBtn\"\n            >{{ dialogData.customButton.label }}</dr-button\n        >\n        <dr-button *ngIf=\"dialogData.cancelButton\" data-test=\"modalCloseBtn\" (click)=\"onCancel()\" [theme]=\"'secondary'\">{{\n            dialogData.cancelButton.label\n        }}</dr-button>\n        <dr-button\n            *ngIf=\"dialogData.acceptButton\"\n            data-test=\"modalAddBtn\"\n            (click)=\"onAccept()\"\n            [theme]=\"'primary'\"\n            [isLoading]=\"isLoading\"\n            [disabled]=\"form.invalid\"\n            >{{ dialogData.acceptButton.label }}</dr-button\n        >\n    </div>\n</div>\n"]}
@@ -11852,7 +11852,10 @@ class DialogModalWrapperComponent {
11852
11852
  }), tap(() => this.fieldsItemsLoading[currentValue.name].next(false)), finalize(() => this.fieldsItemsLoading[currentValue.name].next(false)));
11853
11853
  }
11854
11854
  const currentFormControl = {};
11855
- currentFormControl[currentValue.name] = new FormControl(currentValue.default || null, currentValue.validators || [], currentValue.asyncValidators || []);
11855
+ currentFormControl[currentValue.name] = new FormControl(currentValue.default || null, {
11856
+ validators: currentValue.validators || [],
11857
+ asyncValidators: currentValue.asyncValidators || [],
11858
+ });
11856
11859
  return Object.assign(accumulator, currentFormControl);
11857
11860
  }, {}));
11858
11861
  }