@alfresco/adf-process-services-cloud 8.1.0-15902121227 → 8.1.0-15928551305
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/app/components/app-details-cloud/app-details-cloud.component.mjs +4 -4
- package/esm2022/lib/app/components/app-list-cloud/app-list-cloud.component.mjs +8 -9
- package/esm2022/lib/common/date-range-filter/date-range-filter.component.mjs +9 -10
- package/esm2022/lib/form/components/form-cloud.component.mjs +9 -10
- package/esm2022/lib/form/components/form-definition-selector-cloud.component.mjs +7 -8
- package/esm2022/lib/form/components/spinner/form-spinner.component.mjs +5 -6
- package/esm2022/lib/form/components/widgets/attach-file/attach-file-cloud-widget.component.mjs +6 -7
- package/esm2022/lib/form/components/widgets/attach-file/file-properties-table/file-properties-table-cloud.component.mjs +9 -10
- package/esm2022/lib/form/components/widgets/data-table/data-table.widget.mjs +4 -5
- package/esm2022/lib/form/components/widgets/date/date-cloud.widget.mjs +8 -9
- package/esm2022/lib/form/components/widgets/display-external-property/display-external-property.widget.mjs +7 -8
- package/esm2022/lib/form/components/widgets/dropdown/dropdown-cloud.widget.mjs +4 -5
- package/esm2022/lib/form/components/widgets/file-viewer/file-viewer.widget.mjs +4 -5
- package/esm2022/lib/form/components/widgets/group/group-cloud.widget.mjs +4 -5
- package/esm2022/lib/form/components/widgets/people/people-cloud.widget.mjs +4 -5
- package/esm2022/lib/form/components/widgets/properties-viewer/properties-viewer.widget.mjs +4 -5
- package/esm2022/lib/form/components/widgets/radio-buttons/radio-buttons-cloud.widget.mjs +5 -6
- package/esm2022/lib/form/components/widgets/upload/upload-cloud.widget.mjs +8 -9
- package/esm2022/lib/group/components/group-cloud.component.mjs +13 -14
- package/esm2022/lib/people/components/people-cloud.component.mjs +13 -14
- package/esm2022/lib/process/process-filters/components/edit-process-filter/edit-process-filter-cloud.component.mjs +11 -12
- package/esm2022/lib/process/process-filters/components/process-filter-dialog/process-filter-dialog-cloud.component.mjs +10 -11
- package/esm2022/lib/process/process-filters/components/process-filters/process-filters-cloud.component.mjs +6 -7
- package/esm2022/lib/process/process-list/components/process-list-cloud.component.mjs +4 -5
- package/esm2022/lib/process/start-process/components/start-process-cloud.component.mjs +13 -14
- package/esm2022/lib/task/task-filters/components/edit-task-filters/edit-service-task-filter/edit-service-task-filter-cloud.component.mjs +15 -16
- package/esm2022/lib/task/task-filters/components/edit-task-filters/edit-task-filter/edit-task-filter-cloud.component.mjs +15 -16
- package/esm2022/lib/task/task-filters/components/service-task-filters/service-task-filters-cloud.component.mjs +6 -7
- package/esm2022/lib/task/task-filters/components/task-assignment-filter/task-assignment-filter.component.mjs +8 -9
- package/esm2022/lib/task/task-filters/components/task-filter-dialog/task-filter-dialog-cloud.component.mjs +8 -9
- package/esm2022/lib/task/task-filters/components/task-filters/task-filters-cloud.component.mjs +5 -6
- package/esm2022/lib/task/task-form/components/user-task-cloud/user-task-cloud.component.mjs +7 -8
- package/esm2022/lib/task/task-form/components/user-task-cloud-buttons/user-task-cloud-buttons.component.mjs +5 -6
- package/esm2022/lib/task/task-list/components/service-task-list/service-task-list-cloud.component.mjs +5 -6
- package/esm2022/lib/task/task-list/components/task-list/task-list-cloud.component.mjs +5 -6
- package/fesm2022/adf-process-services-cloud.mjs +105 -106
- package/fesm2022/adf-process-services-cloud.mjs.map +1 -1
- package/package.json +4 -4
|
@@ -22,16 +22,15 @@ import { MatDatepickerModule } from '@angular/material/datepicker';
|
|
|
22
22
|
import { addDays, parseISO } from 'date-fns';
|
|
23
23
|
import { FormControl, ReactiveFormsModule, Validators } from '@angular/forms';
|
|
24
24
|
import { NgIf } from '@angular/common';
|
|
25
|
-
import {
|
|
25
|
+
import { TranslatePipe } from '@ngx-translate/core';
|
|
26
26
|
import { MatFormFieldModule } from '@angular/material/form-field';
|
|
27
27
|
import { MatInputModule } from '@angular/material/input';
|
|
28
28
|
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
29
29
|
import * as i0 from "@angular/core";
|
|
30
|
-
import * as i1 from "@
|
|
31
|
-
import * as i2 from "@angular/material/
|
|
32
|
-
import * as i3 from "@angular/material/
|
|
33
|
-
import * as i4 from "@angular/
|
|
34
|
-
import * as i5 from "@angular/forms";
|
|
30
|
+
import * as i1 from "@angular/material/form-field";
|
|
31
|
+
import * as i2 from "@angular/material/input";
|
|
32
|
+
import * as i3 from "@angular/material/datepicker";
|
|
33
|
+
import * as i4 from "@angular/forms";
|
|
35
34
|
export class DateCloudWidgetComponent extends WidgetComponent {
|
|
36
35
|
constructor() {
|
|
37
36
|
super(...arguments);
|
|
@@ -168,11 +167,11 @@ export class DateCloudWidgetComponent extends WidgetComponent {
|
|
|
168
167
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: DateCloudWidgetComponent, isStandalone: true, selector: "date-widget", host: { listeners: { "click": "event($event)", "blur": "event($event)", "change": "event($event)", "focus": "event($event)", "focusin": "event($event)", "focusout": "event($event)", "input": "event($event)", "invalid": "event($event)", "select": "event($event)" } }, providers: [
|
|
169
168
|
{ provide: MAT_DATE_FORMATS, useValue: ADF_DATE_FORMATS },
|
|
170
169
|
{ provide: DateAdapter, useClass: AdfDateFnsAdapter }
|
|
171
|
-
], usesInheritance: true, ngImport: i0, template: "<div\n class=\"{{field.className}}\"\n id=\"data-widget\"\n [class.adf-invalid]=\"dateInputControl.invalid && dateInputControl.touched\"\n [class.adf-left-label-input-container]=\"field.leftLabels\"\n>\n <div *ngIf=\"field.leftLabels\">\n <label class=\"adf-label adf-left-label\" [attr.for]=\"field.id\"\n >{{field.name | translate }} ({{field.dateDisplayFormat}})<span\n class=\"adf-asterisk\"\n [style.visibility]=\"isRequired() ? 'visible' : 'hidden'\"\n >*</span\n ></label\n >\n </div>\n <div>\n <mat-form-field class=\"adf-date-widget adf-form-field-input\" [class.adf-left-label-input-datepicker]=\"field.leftLabels\">\n @if ( (field.name || field?.required) && !field.leftLabels) {\n <mat-label class=\"adf-label\" [attr.for]=\"field.id\">\n {{field.name | translate }} ({{field.dateDisplayFormat}})\n </mat-label>\n }\n <input\n matInput\n class=\"adf-input\"\n [matDatepicker]=\"datePicker\"\n [id]=\"field.id\"\n [formControl]=\"dateInputControl\"\n [placeholder]=\"field.placeholder\"\n [required]=\"field.required && field.isVisible\"\n [min]=\"minDate\"\n [max]=\"maxDate\"\n [title]=\"field.tooltip\"\n />\n <mat-datepicker-toggle matSuffix [for]=\"datePicker\" [disabled]=\"field.readOnly\" />\n <mat-datepicker #datePicker [startAt]=\"startAt\" [disabled]=\"field.readOnly\" />\n </mat-form-field>\n <div class=\"adf-error-messages-container\">\n <error-widget *ngIf=\"dateInputControl.invalid && dateInputControl.touched\" [error]=\"field.validationSummary\" />\n </div>\n </div>\n</div>\n", styles: [".adf-date-widget .mat-mdc-form-field-text-suffix{top:26px}.adf-date-widget .adf-label{top:20px}.adf-left-label-input-datepicker .mat-mdc-form-field-text-suffix{top:0}.adf-left-label-input-datepicker .mat-mdc-form-text-infix{width:100%}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "
|
|
170
|
+
], usesInheritance: true, ngImport: i0, template: "<div\n class=\"{{field.className}}\"\n id=\"data-widget\"\n [class.adf-invalid]=\"dateInputControl.invalid && dateInputControl.touched\"\n [class.adf-left-label-input-container]=\"field.leftLabels\"\n>\n <div *ngIf=\"field.leftLabels\">\n <label class=\"adf-label adf-left-label\" [attr.for]=\"field.id\"\n >{{field.name | translate }} ({{field.dateDisplayFormat}})<span\n class=\"adf-asterisk\"\n [style.visibility]=\"isRequired() ? 'visible' : 'hidden'\"\n >*</span\n ></label\n >\n </div>\n <div>\n <mat-form-field class=\"adf-date-widget adf-form-field-input\" [class.adf-left-label-input-datepicker]=\"field.leftLabels\">\n @if ( (field.name || field?.required) && !field.leftLabels) {\n <mat-label class=\"adf-label\" [attr.for]=\"field.id\">\n {{field.name | translate }} ({{field.dateDisplayFormat}})\n </mat-label>\n }\n <input\n matInput\n class=\"adf-input\"\n [matDatepicker]=\"datePicker\"\n [id]=\"field.id\"\n [formControl]=\"dateInputControl\"\n [placeholder]=\"field.placeholder\"\n [required]=\"field.required && field.isVisible\"\n [min]=\"minDate\"\n [max]=\"maxDate\"\n [title]=\"field.tooltip\"\n />\n <mat-datepicker-toggle matSuffix [for]=\"datePicker\" [disabled]=\"field.readOnly\" />\n <mat-datepicker #datePicker [startAt]=\"startAt\" [disabled]=\"field.readOnly\" />\n </mat-form-field>\n <div class=\"adf-error-messages-container\">\n <error-widget *ngIf=\"dateInputControl.invalid && dateInputControl.touched\" [error]=\"field.validationSummary\" />\n </div>\n </div>\n</div>\n", styles: [".adf-date-widget .mat-mdc-form-field-text-suffix{top:26px}.adf-date-widget .adf-label{top:20px}.adf-left-label-input-datepicker .mat-mdc-form-field-text-suffix{top:0}.adf-left-label-input-datepicker .mat-mdc-form-text-infix{width:100%}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i1.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i1.MatLabel, selector: "mat-label" }, { kind: "directive", type: i1.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i2.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "ngmodule", type: MatDatepickerModule }, { kind: "component", type: i3.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i3.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i3.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i4.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: ErrorWidgetComponent, selector: "error-widget", inputs: ["error", "required"] }], encapsulation: i0.ViewEncapsulation.None }); }
|
|
172
171
|
}
|
|
173
172
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DateCloudWidgetComponent, decorators: [{
|
|
174
173
|
type: Component,
|
|
175
|
-
args: [{ selector: 'date-widget', standalone: true, imports: [NgIf,
|
|
174
|
+
args: [{ selector: 'date-widget', standalone: true, imports: [NgIf, TranslatePipe, MatFormFieldModule, MatInputModule, MatDatepickerModule, ReactiveFormsModule, ErrorWidgetComponent], providers: [
|
|
176
175
|
{ provide: MAT_DATE_FORMATS, useValue: ADF_DATE_FORMATS },
|
|
177
176
|
{ provide: DateAdapter, useClass: AdfDateFnsAdapter }
|
|
178
177
|
], host: {
|
|
@@ -187,4 +186,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
187
186
|
'(select)': 'event($event)'
|
|
188
187
|
}, encapsulation: ViewEncapsulation.None, template: "<div\n class=\"{{field.className}}\"\n id=\"data-widget\"\n [class.adf-invalid]=\"dateInputControl.invalid && dateInputControl.touched\"\n [class.adf-left-label-input-container]=\"field.leftLabels\"\n>\n <div *ngIf=\"field.leftLabels\">\n <label class=\"adf-label adf-left-label\" [attr.for]=\"field.id\"\n >{{field.name | translate }} ({{field.dateDisplayFormat}})<span\n class=\"adf-asterisk\"\n [style.visibility]=\"isRequired() ? 'visible' : 'hidden'\"\n >*</span\n ></label\n >\n </div>\n <div>\n <mat-form-field class=\"adf-date-widget adf-form-field-input\" [class.adf-left-label-input-datepicker]=\"field.leftLabels\">\n @if ( (field.name || field?.required) && !field.leftLabels) {\n <mat-label class=\"adf-label\" [attr.for]=\"field.id\">\n {{field.name | translate }} ({{field.dateDisplayFormat}})\n </mat-label>\n }\n <input\n matInput\n class=\"adf-input\"\n [matDatepicker]=\"datePicker\"\n [id]=\"field.id\"\n [formControl]=\"dateInputControl\"\n [placeholder]=\"field.placeholder\"\n [required]=\"field.required && field.isVisible\"\n [min]=\"minDate\"\n [max]=\"maxDate\"\n [title]=\"field.tooltip\"\n />\n <mat-datepicker-toggle matSuffix [for]=\"datePicker\" [disabled]=\"field.readOnly\" />\n <mat-datepicker #datePicker [startAt]=\"startAt\" [disabled]=\"field.readOnly\" />\n </mat-form-field>\n <div class=\"adf-error-messages-container\">\n <error-widget *ngIf=\"dateInputControl.invalid && dateInputControl.touched\" [error]=\"field.validationSummary\" />\n </div>\n </div>\n</div>\n", styles: [".adf-date-widget .mat-mdc-form-field-text-suffix{top:26px}.adf-date-widget .adf-label{top:20px}.adf-left-label-input-datepicker .mat-mdc-form-field-text-suffix{top:0}.adf-left-label-input-datepicker .mat-mdc-form-text-infix{width:100%}\n"] }]
|
|
189
188
|
}] });
|
|
190
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-cloud.widget.js","sourceRoot":"","sources":["../../../../../../../../../lib/process-services-cloud/src/lib/form/components/widgets/date/date-cloud.widget.ts","../../../../../../../../../lib/process-services-cloud/src/lib/form/components/widgets/date/date-cloud.widget.html"],"names":[],"mappings":"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","sourcesContent":["/*!\n * @license\n * Copyright © 2005-2025 Hyland Software, Inc. and its affiliates. All rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/* eslint-disable @angular-eslint/component-selector */\n\nimport { Component, OnInit, ViewEncapsulation, DestroyRef, inject } from '@angular/core';\nimport { DateAdapter, MAT_DATE_FORMATS } from '@angular/material/core';\nimport {\n    ADF_DATE_FORMATS,\n    AdfDateFnsAdapter,\n    DateFnsUtils,\n    DEFAULT_DATE_FORMAT,\n    ErrorMessageModel,\n    ErrorWidgetComponent,\n    FormService,\n    WidgetComponent,\n    ReactiveFormWidget\n} from '@alfresco/adf-core';\nimport { MatDatepickerModule } from '@angular/material/datepicker';\nimport { addDays, parseISO } from 'date-fns';\nimport { FormControl, ReactiveFormsModule, ValidationErrors, Validators } from '@angular/forms';\nimport { NgIf } from '@angular/common';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatInputModule } from '@angular/material/input';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\n\n@Component({\n    selector: 'date-widget',\n    standalone: true,\n    imports: [NgIf, TranslateModule, MatFormFieldModule, MatInputModule, MatDatepickerModule, ReactiveFormsModule, ErrorWidgetComponent],\n    providers: [\n        { provide: MAT_DATE_FORMATS, useValue: ADF_DATE_FORMATS },\n        { provide: DateAdapter, useClass: AdfDateFnsAdapter }\n    ],\n    templateUrl: './date-cloud.widget.html',\n    styleUrls: ['./date-cloud.widget.scss'],\n    host: {\n        '(click)': 'event($event)',\n        '(blur)': 'event($event)',\n        '(change)': 'event($event)',\n        '(focus)': 'event($event)',\n        '(focusin)': 'event($event)',\n        '(focusout)': 'event($event)',\n        '(input)': 'event($event)',\n        '(invalid)': 'event($event)',\n        '(select)': 'event($event)'\n    },\n    encapsulation: ViewEncapsulation.None\n})\nexport class DateCloudWidgetComponent extends WidgetComponent implements OnInit, ReactiveFormWidget {\n    typeId = 'DateCloudWidgetComponent';\n\n    minDate: Date = null;\n    maxDate: Date = null;\n    startAt: Date = null;\n\n    dateInputControl: FormControl<Date> = new FormControl<Date>(null);\n\n    public readonly formService = inject(FormService);\n\n    private readonly destroyRef = inject(DestroyRef);\n    private readonly dateAdapter = inject(DateAdapter);\n\n    ngOnInit(): void {\n        this.setFormControlValue();\n        this.updateFormControlState();\n        this.initDateAdapter();\n        this.initRangeSelection();\n        this.initStartAt();\n        this.subscribeToDateChanges();\n        this.validateField();\n    }\n\n    updateReactiveFormControl(): void {\n        this.setFormControlValue();\n        this.updateFormControlState();\n        this.validateField();\n    }\n\n    private setFormControlValue(): void {\n        this.dateInputControl.setValue(this.field.value, { emitEvent: false });\n    }\n\n    private updateFormControlState(): void {\n        this.dateInputControl.setValidators(this.isRequired() && this.field?.isVisible ? [Validators.required] : []);\n        this.field?.readOnly || this.readOnly\n            ? this.dateInputControl.disable({ emitEvent: false })\n            : this.dateInputControl.enable({ emitEvent: false });\n\n        this.dateInputControl.updateValueAndValidity({ emitEvent: false });\n    }\n\n    private subscribeToDateChanges(): void {\n        this.dateInputControl.valueChanges.pipe(takeUntilDestroyed(this.destroyRef)).subscribe((newDate: Date) => {\n            this.field.value = newDate;\n            this.updateField();\n        });\n    }\n\n    private updateField(): void {\n        this.validateField();\n        this.onFieldChanged(this.field);\n    }\n\n    private validateField(): void {\n        if (this.dateInputControl.invalid) {\n            this.handleErrors(this.dateInputControl.errors);\n            this.field.markAsInvalid();\n        } else {\n            this.resetErrors();\n            this.field.markAsValid();\n        }\n    }\n\n    private handleErrors(errors: ValidationErrors): void {\n        const errorAttributes = new Map<string, string>();\n        switch (true) {\n            case !!errors.matDatepickerParse:\n                this.updateValidationSummary(this.field.dateDisplayFormat || this.field.defaultDateTimeFormat);\n                break;\n            case !!errors.required:\n                this.updateValidationSummary('FORM.FIELD.REQUIRED');\n                break;\n            case !!errors.matDatepickerMin: {\n                const minValue = DateFnsUtils.formatDate(errors.matDatepickerMin.min, this.field.dateDisplayFormat).toLocaleUpperCase();\n                errorAttributes.set('minValue', minValue);\n                this.updateValidationSummary('FORM.FIELD.VALIDATOR.NOT_LESS_THAN', errorAttributes);\n                break;\n            }\n            case !!errors.matDatepickerMax: {\n                const maxValue = DateFnsUtils.formatDate(errors.matDatepickerMax.max, this.field.dateDisplayFormat).toLocaleUpperCase();\n                errorAttributes.set('maxValue', maxValue);\n                this.updateValidationSummary('FORM.FIELD.VALIDATOR.NOT_GREATER_THAN', errorAttributes);\n                break;\n            }\n            default:\n                break;\n        }\n    }\n\n    private updateValidationSummary(message: string, attributes?: Map<string, string>): void {\n        this.field.validationSummary = new ErrorMessageModel({ message, attributes });\n    }\n\n    private resetErrors(): void {\n        this.updateValidationSummary('');\n    }\n\n    private initDateAdapter(): void {\n        if (this.field?.dateDisplayFormat) {\n            const adapter = this.dateAdapter as AdfDateFnsAdapter;\n            adapter.displayFormat = this.field.dateDisplayFormat;\n        }\n    }\n\n    private initStartAt(): void {\n        if (this.field?.value) {\n            this.startAt = this.dateAdapter.parse(this.field.value, DEFAULT_DATE_FORMAT);\n        }\n    }\n\n    private initRangeSelection(): void {\n        if (this.field?.dynamicDateRangeSelection) {\n            this.setDynamicRangeSelection();\n        } else {\n            this.setStaticRangeSelection();\n        }\n    }\n\n    private setDynamicRangeSelection(): void {\n        if (this.field.minDateRangeValue === null) {\n            this.minDate = null;\n            this.field.minValue = null;\n        } else {\n            this.minDate = addDays(this.dateAdapter.today(), this.field.minDateRangeValue);\n            this.field.minValue = DateFnsUtils.formatDate(this.minDate, DEFAULT_DATE_FORMAT);\n        }\n        if (this.field.maxDateRangeValue === null) {\n            this.maxDate = null;\n            this.field.maxValue = null;\n        } else {\n            this.maxDate = addDays(this.dateAdapter.today(), this.field.maxDateRangeValue);\n            this.field.maxValue = DateFnsUtils.formatDate(this.maxDate, DEFAULT_DATE_FORMAT);\n        }\n    }\n\n    private setStaticRangeSelection(): void {\n        if (this.field?.minValue) {\n            this.minDate = parseISO(this.field.minValue);\n        }\n\n        if (this.field?.maxValue) {\n            this.maxDate = parseISO(this.field.maxValue);\n        }\n    }\n}\n","<div\n    class=\"{{field.className}}\"\n    id=\"data-widget\"\n    [class.adf-invalid]=\"dateInputControl.invalid && dateInputControl.touched\"\n    [class.adf-left-label-input-container]=\"field.leftLabels\"\n>\n    <div *ngIf=\"field.leftLabels\">\n        <label class=\"adf-label adf-left-label\" [attr.for]=\"field.id\"\n            >{{field.name | translate }} ({{field.dateDisplayFormat}})<span\n                class=\"adf-asterisk\"\n                [style.visibility]=\"isRequired() ? 'visible' : 'hidden'\"\n                >*</span\n            ></label\n        >\n    </div>\n    <div>\n        <mat-form-field class=\"adf-date-widget adf-form-field-input\" [class.adf-left-label-input-datepicker]=\"field.leftLabels\">\n            @if ( (field.name || field?.required) && !field.leftLabels) {\n                <mat-label class=\"adf-label\" [attr.for]=\"field.id\">\n                    {{field.name | translate }} ({{field.dateDisplayFormat}})\n                </mat-label>\n            }\n            <input\n                matInput\n                class=\"adf-input\"\n                [matDatepicker]=\"datePicker\"\n                [id]=\"field.id\"\n                [formControl]=\"dateInputControl\"\n                [placeholder]=\"field.placeholder\"\n                [required]=\"field.required && field.isVisible\"\n                [min]=\"minDate\"\n                [max]=\"maxDate\"\n                [title]=\"field.tooltip\"\n            />\n            <mat-datepicker-toggle matSuffix [for]=\"datePicker\" [disabled]=\"field.readOnly\" />\n            <mat-datepicker #datePicker [startAt]=\"startAt\" [disabled]=\"field.readOnly\" />\n        </mat-form-field>\n        <div class=\"adf-error-messages-container\">\n            <error-widget *ngIf=\"dateInputControl.invalid && dateInputControl.touched\" [error]=\"field.validationSummary\" />\n        </div>\n    </div>\n</div>\n"]}
|
|
189
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-cloud.widget.js","sourceRoot":"","sources":["../../../../../../../../../lib/process-services-cloud/src/lib/form/components/widgets/date/date-cloud.widget.ts","../../../../../../../../../lib/process-services-cloud/src/lib/form/components/widgets/date/date-cloud.widget.html"],"names":[],"mappings":"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","sourcesContent":["/*!\n * @license\n * Copyright © 2005-2025 Hyland Software, Inc. and its affiliates. All rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/* eslint-disable @angular-eslint/component-selector */\n\nimport { Component, OnInit, ViewEncapsulation, DestroyRef, inject } from '@angular/core';\nimport { DateAdapter, MAT_DATE_FORMATS } from '@angular/material/core';\nimport {\n    ADF_DATE_FORMATS,\n    AdfDateFnsAdapter,\n    DateFnsUtils,\n    DEFAULT_DATE_FORMAT,\n    ErrorMessageModel,\n    ErrorWidgetComponent,\n    FormService,\n    WidgetComponent,\n    ReactiveFormWidget\n} from '@alfresco/adf-core';\nimport { MatDatepickerModule } from '@angular/material/datepicker';\nimport { addDays, parseISO } from 'date-fns';\nimport { FormControl, ReactiveFormsModule, ValidationErrors, Validators } from '@angular/forms';\nimport { NgIf } from '@angular/common';\nimport { TranslatePipe } from '@ngx-translate/core';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatInputModule } from '@angular/material/input';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\n\n@Component({\n    selector: 'date-widget',\n    standalone: true,\n    imports: [NgIf, TranslatePipe, MatFormFieldModule, MatInputModule, MatDatepickerModule, ReactiveFormsModule, ErrorWidgetComponent],\n    providers: [\n        { provide: MAT_DATE_FORMATS, useValue: ADF_DATE_FORMATS },\n        { provide: DateAdapter, useClass: AdfDateFnsAdapter }\n    ],\n    templateUrl: './date-cloud.widget.html',\n    styleUrls: ['./date-cloud.widget.scss'],\n    host: {\n        '(click)': 'event($event)',\n        '(blur)': 'event($event)',\n        '(change)': 'event($event)',\n        '(focus)': 'event($event)',\n        '(focusin)': 'event($event)',\n        '(focusout)': 'event($event)',\n        '(input)': 'event($event)',\n        '(invalid)': 'event($event)',\n        '(select)': 'event($event)'\n    },\n    encapsulation: ViewEncapsulation.None\n})\nexport class DateCloudWidgetComponent extends WidgetComponent implements OnInit, ReactiveFormWidget {\n    typeId = 'DateCloudWidgetComponent';\n\n    minDate: Date = null;\n    maxDate: Date = null;\n    startAt: Date = null;\n\n    dateInputControl: FormControl<Date> = new FormControl<Date>(null);\n\n    public readonly formService = inject(FormService);\n\n    private readonly destroyRef = inject(DestroyRef);\n    private readonly dateAdapter = inject(DateAdapter);\n\n    ngOnInit(): void {\n        this.setFormControlValue();\n        this.updateFormControlState();\n        this.initDateAdapter();\n        this.initRangeSelection();\n        this.initStartAt();\n        this.subscribeToDateChanges();\n        this.validateField();\n    }\n\n    updateReactiveFormControl(): void {\n        this.setFormControlValue();\n        this.updateFormControlState();\n        this.validateField();\n    }\n\n    private setFormControlValue(): void {\n        this.dateInputControl.setValue(this.field.value, { emitEvent: false });\n    }\n\n    private updateFormControlState(): void {\n        this.dateInputControl.setValidators(this.isRequired() && this.field?.isVisible ? [Validators.required] : []);\n        this.field?.readOnly || this.readOnly\n            ? this.dateInputControl.disable({ emitEvent: false })\n            : this.dateInputControl.enable({ emitEvent: false });\n\n        this.dateInputControl.updateValueAndValidity({ emitEvent: false });\n    }\n\n    private subscribeToDateChanges(): void {\n        this.dateInputControl.valueChanges.pipe(takeUntilDestroyed(this.destroyRef)).subscribe((newDate: Date) => {\n            this.field.value = newDate;\n            this.updateField();\n        });\n    }\n\n    private updateField(): void {\n        this.validateField();\n        this.onFieldChanged(this.field);\n    }\n\n    private validateField(): void {\n        if (this.dateInputControl.invalid) {\n            this.handleErrors(this.dateInputControl.errors);\n            this.field.markAsInvalid();\n        } else {\n            this.resetErrors();\n            this.field.markAsValid();\n        }\n    }\n\n    private handleErrors(errors: ValidationErrors): void {\n        const errorAttributes = new Map<string, string>();\n        switch (true) {\n            case !!errors.matDatepickerParse:\n                this.updateValidationSummary(this.field.dateDisplayFormat || this.field.defaultDateTimeFormat);\n                break;\n            case !!errors.required:\n                this.updateValidationSummary('FORM.FIELD.REQUIRED');\n                break;\n            case !!errors.matDatepickerMin: {\n                const minValue = DateFnsUtils.formatDate(errors.matDatepickerMin.min, this.field.dateDisplayFormat).toLocaleUpperCase();\n                errorAttributes.set('minValue', minValue);\n                this.updateValidationSummary('FORM.FIELD.VALIDATOR.NOT_LESS_THAN', errorAttributes);\n                break;\n            }\n            case !!errors.matDatepickerMax: {\n                const maxValue = DateFnsUtils.formatDate(errors.matDatepickerMax.max, this.field.dateDisplayFormat).toLocaleUpperCase();\n                errorAttributes.set('maxValue', maxValue);\n                this.updateValidationSummary('FORM.FIELD.VALIDATOR.NOT_GREATER_THAN', errorAttributes);\n                break;\n            }\n            default:\n                break;\n        }\n    }\n\n    private updateValidationSummary(message: string, attributes?: Map<string, string>): void {\n        this.field.validationSummary = new ErrorMessageModel({ message, attributes });\n    }\n\n    private resetErrors(): void {\n        this.updateValidationSummary('');\n    }\n\n    private initDateAdapter(): void {\n        if (this.field?.dateDisplayFormat) {\n            const adapter = this.dateAdapter as AdfDateFnsAdapter;\n            adapter.displayFormat = this.field.dateDisplayFormat;\n        }\n    }\n\n    private initStartAt(): void {\n        if (this.field?.value) {\n            this.startAt = this.dateAdapter.parse(this.field.value, DEFAULT_DATE_FORMAT);\n        }\n    }\n\n    private initRangeSelection(): void {\n        if (this.field?.dynamicDateRangeSelection) {\n            this.setDynamicRangeSelection();\n        } else {\n            this.setStaticRangeSelection();\n        }\n    }\n\n    private setDynamicRangeSelection(): void {\n        if (this.field.minDateRangeValue === null) {\n            this.minDate = null;\n            this.field.minValue = null;\n        } else {\n            this.minDate = addDays(this.dateAdapter.today(), this.field.minDateRangeValue);\n            this.field.minValue = DateFnsUtils.formatDate(this.minDate, DEFAULT_DATE_FORMAT);\n        }\n        if (this.field.maxDateRangeValue === null) {\n            this.maxDate = null;\n            this.field.maxValue = null;\n        } else {\n            this.maxDate = addDays(this.dateAdapter.today(), this.field.maxDateRangeValue);\n            this.field.maxValue = DateFnsUtils.formatDate(this.maxDate, DEFAULT_DATE_FORMAT);\n        }\n    }\n\n    private setStaticRangeSelection(): void {\n        if (this.field?.minValue) {\n            this.minDate = parseISO(this.field.minValue);\n        }\n\n        if (this.field?.maxValue) {\n            this.maxDate = parseISO(this.field.maxValue);\n        }\n    }\n}\n","<div\n    class=\"{{field.className}}\"\n    id=\"data-widget\"\n    [class.adf-invalid]=\"dateInputControl.invalid && dateInputControl.touched\"\n    [class.adf-left-label-input-container]=\"field.leftLabels\"\n>\n    <div *ngIf=\"field.leftLabels\">\n        <label class=\"adf-label adf-left-label\" [attr.for]=\"field.id\"\n            >{{field.name | translate }} ({{field.dateDisplayFormat}})<span\n                class=\"adf-asterisk\"\n                [style.visibility]=\"isRequired() ? 'visible' : 'hidden'\"\n                >*</span\n            ></label\n        >\n    </div>\n    <div>\n        <mat-form-field class=\"adf-date-widget adf-form-field-input\" [class.adf-left-label-input-datepicker]=\"field.leftLabels\">\n            @if ( (field.name || field?.required) && !field.leftLabels) {\n                <mat-label class=\"adf-label\" [attr.for]=\"field.id\">\n                    {{field.name | translate }} ({{field.dateDisplayFormat}})\n                </mat-label>\n            }\n            <input\n                matInput\n                class=\"adf-input\"\n                [matDatepicker]=\"datePicker\"\n                [id]=\"field.id\"\n                [formControl]=\"dateInputControl\"\n                [placeholder]=\"field.placeholder\"\n                [required]=\"field.required && field.isVisible\"\n                [min]=\"minDate\"\n                [max]=\"maxDate\"\n                [title]=\"field.tooltip\"\n            />\n            <mat-datepicker-toggle matSuffix [for]=\"datePicker\" [disabled]=\"field.readOnly\" />\n            <mat-datepicker #datePicker [startAt]=\"startAt\" [disabled]=\"field.readOnly\" />\n        </mat-form-field>\n        <div class=\"adf-error-messages-container\">\n            <error-widget *ngIf=\"dateInputControl.invalid && dateInputControl.touched\" [error]=\"field.validationSummary\" />\n        </div>\n    </div>\n</div>\n"]}
|
|
@@ -17,7 +17,7 @@
|
|
|
17
17
|
import { ChangeDetectionStrategy, Component, ViewEncapsulation } from '@angular/core';
|
|
18
18
|
import { WidgetComponent, FormService, FormBaseModule } from '@alfresco/adf-core';
|
|
19
19
|
import { CommonModule } from '@angular/common';
|
|
20
|
-
import {
|
|
20
|
+
import { TranslatePipe } from '@ngx-translate/core';
|
|
21
21
|
import { FormCloudService } from '../../../services/form-cloud.service';
|
|
22
22
|
import { FormControl, ReactiveFormsModule, Validators } from '@angular/forms';
|
|
23
23
|
import { MatFormFieldModule } from '@angular/material/form-field';
|
|
@@ -26,10 +26,9 @@ import * as i0 from "@angular/core";
|
|
|
26
26
|
import * as i1 from "@alfresco/adf-core";
|
|
27
27
|
import * as i2 from "../../../services/form-cloud.service";
|
|
28
28
|
import * as i3 from "@angular/common";
|
|
29
|
-
import * as i4 from "@
|
|
30
|
-
import * as i5 from "@angular/
|
|
31
|
-
import * as i6 from "@angular/material/
|
|
32
|
-
import * as i7 from "@angular/material/input";
|
|
29
|
+
import * as i4 from "@angular/forms";
|
|
30
|
+
import * as i5 from "@angular/material/form-field";
|
|
31
|
+
import * as i6 from "@angular/material/input";
|
|
33
32
|
export class DisplayExternalPropertyWidgetComponent extends WidgetComponent {
|
|
34
33
|
constructor(formService, formCloudService) {
|
|
35
34
|
super(formService);
|
|
@@ -67,11 +66,11 @@ export class DisplayExternalPropertyWidgetComponent extends WidgetComponent {
|
|
|
67
66
|
}
|
|
68
67
|
}
|
|
69
68
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DisplayExternalPropertyWidgetComponent, deps: [{ token: i1.FormService }, { token: i2.FormCloudService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
70
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: DisplayExternalPropertyWidgetComponent, isStandalone: true, selector: "adf-cloud-display-external-property", host: { listeners: { "click": "event($event)", "blur": "event($event)", "change": "event($event)", "focus": "event($event)", "focusin": "event($event)", "focusout": "event($event)", "input": "event($event)", "invalid": "event($event)", "select": "event($event)" } }, usesInheritance: true, ngImport: i0, template: "<div\n class=\"adf-textfield adf-display-external-property-widget {{ field.className }}\"\n [class.adf-invalid]=\"!field.isValid && isTouched()\"\n [class.adf-readonly]=\"field.readOnly\"\n [class.adf-left-label-input-container]=\"field.leftLabels\"\n>\n <div *ngIf=\"field.leftLabels\">\n <label class=\"adf-label adf-left-label\" [attr.for]=\"field.id\">\n {{ field.name | translate }}<span class=\"adf-asterisk\" [style.visibility]=\"isRequired() ? 'visible' : 'hidden'\">*</span>\n </label>\n </div>\n\n <div>\n <mat-form-field class=\"adf-form-field-input\" [floatLabel]=\"field.placeholder ? 'always' : null\">\n @if( (field.name || field?.required) && !field.leftLabels) {\n <mat-label class=\"adf-label\" [attr.for]=\"field.id\">\n {{ field.name | translate }}\n </mat-label>\n }\n <input matInput\n class=\"adf-input\"\n type=\"text\"\n data-automation-id=\"adf-display-external-property-widget\"\n [id]=\"field.id\"\n [formControl]=\"propertyControl\"\n [required]=\"field.required\"\n >\n\n <ng-container *ngIf=\"previewState\">\n <span class=\"adf-display-external-property-widget-preview\"\n data-automation-id=\"adf-display-external-property-widget-preview\"\n >\n {{ field.params.externalPropertyLabel }}\n </span>\n </ng-container>\n </mat-form-field>\n\n <ng-container *ngIf=\"!previewState\">\n <error-widget *ngIf=\"propertyLoadFailed\" [required]=\"'FORM.FIELD.EXTERNAL_PROPERTY_LOAD_FAILED' | translate\" />\n </ng-container>\n</div>\n", styles: [".adf-display-external-property-widget{width:100%}.adf-display-external-property-widget .adf-label{top:20px}.adf-display-external-property-widget-preview{color:var(--adf-theme-foreground-secondary-text-color);word-break:break-all}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "
|
|
69
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: DisplayExternalPropertyWidgetComponent, isStandalone: true, selector: "adf-cloud-display-external-property", host: { listeners: { "click": "event($event)", "blur": "event($event)", "change": "event($event)", "focus": "event($event)", "focusin": "event($event)", "focusout": "event($event)", "input": "event($event)", "invalid": "event($event)", "select": "event($event)" } }, usesInheritance: true, ngImport: i0, template: "<div\n class=\"adf-textfield adf-display-external-property-widget {{ field.className }}\"\n [class.adf-invalid]=\"!field.isValid && isTouched()\"\n [class.adf-readonly]=\"field.readOnly\"\n [class.adf-left-label-input-container]=\"field.leftLabels\"\n>\n <div *ngIf=\"field.leftLabels\">\n <label class=\"adf-label adf-left-label\" [attr.for]=\"field.id\">\n {{ field.name | translate }}<span class=\"adf-asterisk\" [style.visibility]=\"isRequired() ? 'visible' : 'hidden'\">*</span>\n </label>\n </div>\n\n <div>\n <mat-form-field class=\"adf-form-field-input\" [floatLabel]=\"field.placeholder ? 'always' : null\">\n @if( (field.name || field?.required) && !field.leftLabels) {\n <mat-label class=\"adf-label\" [attr.for]=\"field.id\">\n {{ field.name | translate }}\n </mat-label>\n }\n <input matInput\n class=\"adf-input\"\n type=\"text\"\n data-automation-id=\"adf-display-external-property-widget\"\n [id]=\"field.id\"\n [formControl]=\"propertyControl\"\n [required]=\"field.required\"\n >\n\n <ng-container *ngIf=\"previewState\">\n <span class=\"adf-display-external-property-widget-preview\"\n data-automation-id=\"adf-display-external-property-widget-preview\"\n >\n {{ field.params.externalPropertyLabel }}\n </span>\n </ng-container>\n </mat-form-field>\n\n <ng-container *ngIf=\"!previewState\">\n <error-widget *ngIf=\"propertyLoadFailed\" [required]=\"'FORM.FIELD.EXTERNAL_PROPERTY_LOAD_FAILED' | translate\" />\n </ng-container>\n</div>\n", styles: [".adf-display-external-property-widget{width:100%}.adf-display-external-property-widget .adf-label{top:20px}.adf-display-external-property-widget-preview{color:var(--adf-theme-foreground-secondary-text-color);word-break:break-all}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i4.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i5.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i5.MatLabel, selector: "mat-label" }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i6.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "ngmodule", type: FormBaseModule }, { kind: "component", type: i1.ErrorWidgetComponent, selector: "error-widget", inputs: ["error", "required"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
71
70
|
}
|
|
72
71
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DisplayExternalPropertyWidgetComponent, decorators: [{
|
|
73
72
|
type: Component,
|
|
74
|
-
args: [{ standalone: true, imports: [CommonModule,
|
|
73
|
+
args: [{ standalone: true, imports: [CommonModule, TranslatePipe, ReactiveFormsModule, MatFormFieldModule, MatInputModule, FormBaseModule], selector: 'adf-cloud-display-external-property', host: {
|
|
75
74
|
'(click)': 'event($event)',
|
|
76
75
|
'(blur)': 'event($event)',
|
|
77
76
|
'(change)': 'event($event)',
|
|
@@ -83,4 +82,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
83
82
|
'(select)': 'event($event)'
|
|
84
83
|
}, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n class=\"adf-textfield adf-display-external-property-widget {{ field.className }}\"\n [class.adf-invalid]=\"!field.isValid && isTouched()\"\n [class.adf-readonly]=\"field.readOnly\"\n [class.adf-left-label-input-container]=\"field.leftLabels\"\n>\n <div *ngIf=\"field.leftLabels\">\n <label class=\"adf-label adf-left-label\" [attr.for]=\"field.id\">\n {{ field.name | translate }}<span class=\"adf-asterisk\" [style.visibility]=\"isRequired() ? 'visible' : 'hidden'\">*</span>\n </label>\n </div>\n\n <div>\n <mat-form-field class=\"adf-form-field-input\" [floatLabel]=\"field.placeholder ? 'always' : null\">\n @if( (field.name || field?.required) && !field.leftLabels) {\n <mat-label class=\"adf-label\" [attr.for]=\"field.id\">\n {{ field.name | translate }}\n </mat-label>\n }\n <input matInput\n class=\"adf-input\"\n type=\"text\"\n data-automation-id=\"adf-display-external-property-widget\"\n [id]=\"field.id\"\n [formControl]=\"propertyControl\"\n [required]=\"field.required\"\n >\n\n <ng-container *ngIf=\"previewState\">\n <span class=\"adf-display-external-property-widget-preview\"\n data-automation-id=\"adf-display-external-property-widget-preview\"\n >\n {{ field.params.externalPropertyLabel }}\n </span>\n </ng-container>\n </mat-form-field>\n\n <ng-container *ngIf=\"!previewState\">\n <error-widget *ngIf=\"propertyLoadFailed\" [required]=\"'FORM.FIELD.EXTERNAL_PROPERTY_LOAD_FAILED' | translate\" />\n </ng-container>\n</div>\n", styles: [".adf-display-external-property-widget{width:100%}.adf-display-external-property-widget .adf-label{top:20px}.adf-display-external-property-widget-preview{color:var(--adf-theme-foreground-secondary-text-color);word-break:break-all}\n"] }]
|
|
85
84
|
}], ctorParameters: () => [{ type: i1.FormService }, { type: i2.FormCloudService }] });
|
|
86
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"display-external-property.widget.js","sourceRoot":"","sources":["../../../../../../../../../lib/process-services-cloud/src/lib/form/components/widgets/display-external-property/display-external-property.widget.ts","../../../../../../../../../lib/process-services-cloud/src/lib/form/components/widgets/display-external-property/display-external-property.widget.html"],"names":[],"mappings":"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","sourcesContent":["/*!\n * @license\n * Copyright © 2005-2025 Hyland Software, Inc. and its affiliates. All rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { ChangeDetectionStrategy, Component, OnInit, ViewEncapsulation } from '@angular/core';\nimport { WidgetComponent, FormService, FormBaseModule } from '@alfresco/adf-core';\nimport { CommonModule } from '@angular/common';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { FormCloudService } from '../../../services/form-cloud.service';\nimport { FormControl, ReactiveFormsModule, Validators } from '@angular/forms';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatInputModule } from '@angular/material/input';\n\n@Component({\n    standalone: true,\n    imports: [CommonModule, TranslateModule, ReactiveFormsModule, MatFormFieldModule, MatInputModule, FormBaseModule],\n    selector: 'adf-cloud-display-external-property',\n    templateUrl: './display-external-property.widget.html',\n    styleUrls: ['./display-external-property.widget.scss'],\n    host: {\n        '(click)': 'event($event)',\n        '(blur)': 'event($event)',\n        '(change)': 'event($event)',\n        '(focus)': 'event($event)',\n        '(focusin)': 'event($event)',\n        '(focusout)': 'event($event)',\n        '(input)': 'event($event)',\n        '(invalid)': 'event($event)',\n        '(select)': 'event($event)'\n    },\n    encapsulation: ViewEncapsulation.None,\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DisplayExternalPropertyWidgetComponent extends WidgetComponent implements OnInit {\n    propertyLoadFailed = false;\n    previewState = false;\n    propertyControl: FormControl;\n\n    constructor(public readonly formService: FormService, private readonly formCloudService: FormCloudService) {\n        super(formService);\n    }\n\n    ngOnInit(): void {\n        this.initFormControl();\n        this.initPreviewState();\n        this.handleFailedPropertyLoad();\n    }\n\n    private initFormControl(): void {\n        this.propertyControl = new FormControl(\n            {\n                value: this.field?.value,\n                disabled: this.field?.readOnly || this.readOnly\n            },\n            this.isRequired() ? [Validators.required] : []\n        );\n    }\n\n    private isPropertyLoadFailed(): boolean {\n        return this.field.externalProperty && !this.field.value;\n    }\n\n    private handleFailedPropertyLoad(): void {\n        if (this.isPropertyLoadFailed()) {\n            this.handleError('External property not found');\n        }\n    }\n\n    private initPreviewState(): void {\n        this.previewState = this.formCloudService.getPreviewState();\n    }\n\n    private handleError(error: any): void {\n        if (!this.previewState) {\n            this.propertyLoadFailed = true;\n            this.widgetError.emit(error);\n        }\n    }\n}\n","<div\n    class=\"adf-textfield adf-display-external-property-widget {{ field.className }}\"\n    [class.adf-invalid]=\"!field.isValid && isTouched()\"\n    [class.adf-readonly]=\"field.readOnly\"\n    [class.adf-left-label-input-container]=\"field.leftLabels\"\n>\n    <div *ngIf=\"field.leftLabels\">\n        <label class=\"adf-label adf-left-label\" [attr.for]=\"field.id\">\n            {{ field.name | translate }}<span class=\"adf-asterisk\" [style.visibility]=\"isRequired() ? 'visible' : 'hidden'\">*</span>\n        </label>\n    </div>\n\n    <div>\n        <mat-form-field class=\"adf-form-field-input\" [floatLabel]=\"field.placeholder ? 'always' : null\">\n            @if( (field.name || field?.required) && !field.leftLabels) {\n            <mat-label class=\"adf-label\" [attr.for]=\"field.id\">\n                {{ field.name | translate }}\n            </mat-label>\n                 }\n            <input matInput\n                   class=\"adf-input\"\n                   type=\"text\"\n                   data-automation-id=\"adf-display-external-property-widget\"\n                   [id]=\"field.id\"\n                   [formControl]=\"propertyControl\"\n                   [required]=\"field.required\"\n            >\n\n            <ng-container *ngIf=\"previewState\">\n                <span class=\"adf-display-external-property-widget-preview\"\n                       data-automation-id=\"adf-display-external-property-widget-preview\"\n                >\n                    {{ field.params.externalPropertyLabel }}\n                </span>\n            </ng-container>\n        </mat-form-field>\n\n        <ng-container *ngIf=\"!previewState\">\n            <error-widget *ngIf=\"propertyLoadFailed\" [required]=\"'FORM.FIELD.EXTERNAL_PROPERTY_LOAD_FAILED' | translate\" />\n        </ng-container>\n</div>\n"]}
|
|
85
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"display-external-property.widget.js","sourceRoot":"","sources":["../../../../../../../../../lib/process-services-cloud/src/lib/form/components/widgets/display-external-property/display-external-property.widget.ts","../../../../../../../../../lib/process-services-cloud/src/lib/form/components/widgets/display-external-property/display-external-property.widget.html"],"names":[],"mappings":"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","sourcesContent":["/*!\n * @license\n * Copyright © 2005-2025 Hyland Software, Inc. and its affiliates. All rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { ChangeDetectionStrategy, Component, OnInit, ViewEncapsulation } from '@angular/core';\nimport { WidgetComponent, FormService, FormBaseModule } from '@alfresco/adf-core';\nimport { CommonModule } from '@angular/common';\nimport { TranslatePipe } from '@ngx-translate/core';\nimport { FormCloudService } from '../../../services/form-cloud.service';\nimport { FormControl, ReactiveFormsModule, Validators } from '@angular/forms';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatInputModule } from '@angular/material/input';\n\n@Component({\n    standalone: true,\n    imports: [CommonModule, TranslatePipe, ReactiveFormsModule, MatFormFieldModule, MatInputModule, FormBaseModule],\n    selector: 'adf-cloud-display-external-property',\n    templateUrl: './display-external-property.widget.html',\n    styleUrls: ['./display-external-property.widget.scss'],\n    host: {\n        '(click)': 'event($event)',\n        '(blur)': 'event($event)',\n        '(change)': 'event($event)',\n        '(focus)': 'event($event)',\n        '(focusin)': 'event($event)',\n        '(focusout)': 'event($event)',\n        '(input)': 'event($event)',\n        '(invalid)': 'event($event)',\n        '(select)': 'event($event)'\n    },\n    encapsulation: ViewEncapsulation.None,\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DisplayExternalPropertyWidgetComponent extends WidgetComponent implements OnInit {\n    propertyLoadFailed = false;\n    previewState = false;\n    propertyControl: FormControl;\n\n    constructor(public readonly formService: FormService, private readonly formCloudService: FormCloudService) {\n        super(formService);\n    }\n\n    ngOnInit(): void {\n        this.initFormControl();\n        this.initPreviewState();\n        this.handleFailedPropertyLoad();\n    }\n\n    private initFormControl(): void {\n        this.propertyControl = new FormControl(\n            {\n                value: this.field?.value,\n                disabled: this.field?.readOnly || this.readOnly\n            },\n            this.isRequired() ? [Validators.required] : []\n        );\n    }\n\n    private isPropertyLoadFailed(): boolean {\n        return this.field.externalProperty && !this.field.value;\n    }\n\n    private handleFailedPropertyLoad(): void {\n        if (this.isPropertyLoadFailed()) {\n            this.handleError('External property not found');\n        }\n    }\n\n    private initPreviewState(): void {\n        this.previewState = this.formCloudService.getPreviewState();\n    }\n\n    private handleError(error: any): void {\n        if (!this.previewState) {\n            this.propertyLoadFailed = true;\n            this.widgetError.emit(error);\n        }\n    }\n}\n","<div\n    class=\"adf-textfield adf-display-external-property-widget {{ field.className }}\"\n    [class.adf-invalid]=\"!field.isValid && isTouched()\"\n    [class.adf-readonly]=\"field.readOnly\"\n    [class.adf-left-label-input-container]=\"field.leftLabels\"\n>\n    <div *ngIf=\"field.leftLabels\">\n        <label class=\"adf-label adf-left-label\" [attr.for]=\"field.id\">\n            {{ field.name | translate }}<span class=\"adf-asterisk\" [style.visibility]=\"isRequired() ? 'visible' : 'hidden'\">*</span>\n        </label>\n    </div>\n\n    <div>\n        <mat-form-field class=\"adf-form-field-input\" [floatLabel]=\"field.placeholder ? 'always' : null\">\n            @if( (field.name || field?.required) && !field.leftLabels) {\n            <mat-label class=\"adf-label\" [attr.for]=\"field.id\">\n                {{ field.name | translate }}\n            </mat-label>\n                 }\n            <input matInput\n                   class=\"adf-input\"\n                   type=\"text\"\n                   data-automation-id=\"adf-display-external-property-widget\"\n                   [id]=\"field.id\"\n                   [formControl]=\"propertyControl\"\n                   [required]=\"field.required\"\n            >\n\n            <ng-container *ngIf=\"previewState\">\n                <span class=\"adf-display-external-property-widget-preview\"\n                       data-automation-id=\"adf-display-external-property-widget-preview\"\n                >\n                    {{ field.params.externalPropertyLabel }}\n                </span>\n            </ng-container>\n        </mat-form-field>\n\n        <ng-container *ngIf=\"!previewState\">\n            <error-widget *ngIf=\"propertyLoadFailed\" [required]=\"'FORM.FIELD.EXTERNAL_PROPERTY_LOAD_FAILED' | translate\" />\n        </ng-container>\n</div>\n"]}
|