@unifylib/ui-lib 1.1.3 → 1.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.
- package/esm2022/iq-ui-lib.mjs +5 -0
- package/esm2022/lib/base-model/SearchStrConfig.mjs +11 -0
- package/esm2022/lib/base-model/api-response.mjs +2 -0
- package/esm2022/lib/base-model/audit-log-entry.mjs +3 -0
- package/esm2022/lib/base-model/button-action-settings.mjs +16 -0
- package/esm2022/lib/base-model/column-def.model.mjs +28 -0
- package/esm2022/lib/base-model/do-action-request.mjs +8 -0
- package/esm2022/lib/base-model/field-action.mjs +6 -0
- package/esm2022/lib/base-model/field-filter.model.mjs +3 -0
- package/esm2022/lib/base-model/field-info.mjs +57 -0
- package/esm2022/lib/base-model/field-predicate.model.mjs +10 -0
- package/esm2022/lib/base-model/filter-request.mjs +13 -0
- package/esm2022/lib/base-model/filter.model.mjs +25 -0
- package/esm2022/lib/base-model/get-items-list.mjs +10 -0
- package/esm2022/lib/base-model/index.mjs +12 -0
- package/esm2022/lib/base-model/items-total.model.mjs +8 -0
- package/esm2022/lib/base-model/line-item.model.mjs +11 -0
- package/esm2022/lib/base-model/lookupItem.mjs +16 -0
- package/esm2022/lib/base-model/page-info.mjs +17 -0
- package/esm2022/lib/base-model/report-request.model.mjs +17 -0
- package/esm2022/lib/base-model/response-envelop.model.mjs +10 -0
- package/esm2022/lib/base-model/snack-message.model.mjs +11 -0
- package/esm2022/lib/base-model/table-column.interface.mjs +2 -0
- package/esm2022/lib/base-model/table-page-user-action.interface.mjs +21 -0
- package/esm2022/lib/base-model/workflow/workflow-steps.model.mjs +9 -0
- package/esm2022/lib/base-model/workflow/workflow.model.mjs +42 -0
- package/esm2022/lib/components/action-comment/action-comment.component.mjs +101 -0
- package/esm2022/lib/components/action-confirmation/action-confirmation.component.mjs +55 -0
- package/esm2022/lib/components/activity-report-form/activity-report-form.component.mjs +499 -0
- package/esm2022/lib/components/advanced-filter/field-filter/field-filter.component.mjs +41 -0
- package/esm2022/lib/components/advanced-filter/filter-builder/filter-builder.component.mjs +162 -0
- package/esm2022/lib/components/audit-log-details-dialog/audit-log-details-dialog.component.mjs +70 -0
- package/esm2022/lib/components/audit-log-list/audit-log.component.mjs +99 -0
- package/esm2022/lib/components/auto-complete/auto-complete.component.mjs +292 -0
- package/esm2022/lib/components/base-form/base-form.component.mjs +297 -0
- package/esm2022/lib/components/base-form-canvas/base-form-canvas.component.mjs +591 -0
- package/esm2022/lib/components/base-input-dialog/base-input-dialog.component.mjs +72 -0
- package/esm2022/lib/components/base-table/base-table.component.mjs +514 -0
- package/esm2022/lib/components/button-actions/button-actions.component.mjs +70 -0
- package/esm2022/lib/components/editable-base-table/editable-base-table.component.mjs +496 -0
- package/esm2022/lib/components/equation-builder/equation-builder.component.mjs +112 -0
- package/esm2022/lib/components/item-line-editor/item-line-editor.component.mjs +299 -0
- package/esm2022/lib/components/multi-auto-complete/multi-auto-complete.component.mjs +278 -0
- package/esm2022/lib/components/paginator/paginator.component.mjs +91 -0
- package/esm2022/lib/components/report-details-dialog/report-details-dialog.component.mjs +102 -0
- package/esm2022/lib/components/report-form/report-form.component.mjs +498 -0
- package/esm2022/lib/components/search-bar/search-bar.component.mjs +62 -0
- package/esm2022/lib/components/section-form-canvas/section-form-canvas.component.mjs +81 -0
- package/esm2022/lib/components/shared/action-button/action-button.component.mjs +59 -0
- package/esm2022/lib/components/shared/action-card/action-card.component.mjs +93 -0
- package/esm2022/lib/components/shared/attachment-uploader/attachment-uploader.component.mjs +70 -0
- package/esm2022/lib/components/shared-list/shared-list.component.mjs +47 -0
- package/esm2022/lib/components/snackbar-static/snackbar-static.component.mjs +43 -0
- package/esm2022/lib/components/title-bar/title-bar.component.mjs +119 -0
- package/esm2022/lib/services/backend-service.mjs +240 -0
- package/esm2022/lib/services/index.mjs +4 -0
- package/esm2022/lib/services/top-panel.mjs +22 -0
- package/esm2022/lib/services/trigger-form.service.mjs +17 -0
- package/esm2022/lib/utils/base-utils.mjs +97 -0
- package/esm2022/lib/validators/date-range-validator.mjs +27 -0
- package/esm2022/lib/validators/index.mjs +4 -0
- package/esm2022/lib/validators/match-list.validator.mjs +9 -0
- package/esm2022/lib/validators/multi-email-validator.mjs +13 -0
- package/esm2022/public-api.mjs +29 -0
- package/esm2022/q-btech-ui-lib.mjs +5 -0
- package/esm2022/unifylib-ui-lib.mjs +5 -0
- package/fesm2022/iq-ui-lib.mjs +5625 -0
- package/fesm2022/iq-ui-lib.mjs.map +1 -0
- package/fesm2022/q-btech-ui-lib.mjs +5619 -0
- package/fesm2022/q-btech-ui-lib.mjs.map +1 -0
- package/fesm2022/unifylib-ui-lib.mjs +5625 -0
- package/fesm2022/unifylib-ui-lib.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/base-model/SearchStrConfig.d.ts +8 -0
- package/{src/lib/base-model/api-response.ts → lib/base-model/api-response.d.ts} +21 -23
- package/lib/base-model/audit-log-entry.d.ts +7 -0
- package/lib/base-model/button-action-settings.d.ts +15 -0
- package/lib/base-model/column-def.model.d.ts +11 -0
- package/lib/base-model/do-action-request.d.ts +10 -0
- package/lib/base-model/field-action.d.ts +6 -0
- package/lib/base-model/field-filter.model.d.ts +7 -0
- package/lib/base-model/field-info.d.ts +53 -0
- package/lib/base-model/field-predicate.model.d.ts +7 -0
- package/lib/base-model/filter-request.d.ts +15 -0
- package/lib/base-model/filter.model.d.ts +22 -0
- package/lib/base-model/get-items-list.d.ts +21 -0
- package/lib/base-model/index.d.ts +11 -0
- package/lib/base-model/items-total.model.d.ts +6 -0
- package/lib/base-model/line-item.model.d.ts +9 -0
- package/lib/base-model/lookupItem.d.ts +13 -0
- package/lib/base-model/page-info.d.ts +52 -0
- package/lib/base-model/report-request.model.d.ts +18 -0
- package/lib/base-model/response-envelop.model.d.ts +8 -0
- package/lib/base-model/snack-message.model.d.ts +7 -0
- package/lib/base-model/table-column.interface.d.ts +28 -0
- package/lib/base-model/table-page-user-action.interface.d.ts +14 -0
- package/lib/base-model/workflow/workflow-steps.model.d.ts +7 -0
- package/lib/base-model/workflow/workflow.model.d.ts +13 -0
- package/lib/components/action-comment/action-comment.component.d.ts +32 -0
- package/lib/components/action-confirmation/action-confirmation.component.d.ts +19 -0
- package/lib/components/activity-report-form/activity-report-form.component.d.ts +93 -0
- package/lib/components/advanced-filter/field-filter/field-filter.component.d.ts +20 -0
- package/lib/components/advanced-filter/filter-builder/filter-builder.component.d.ts +28 -0
- package/lib/components/audit-log-details-dialog/audit-log-details-dialog.component.d.ts +25 -0
- package/lib/components/audit-log-list/audit-log.component.d.ts +36 -0
- package/lib/components/auto-complete/auto-complete.component.d.ts +51 -0
- package/lib/components/base-form/base-form.component.d.ts +59 -0
- package/lib/components/base-form-canvas/base-form-canvas.component.d.ts +124 -0
- package/lib/components/base-input-dialog/base-input-dialog.component.d.ts +23 -0
- package/lib/components/base-table/base-table.component.d.ts +128 -0
- package/lib/components/button-actions/button-actions.component.d.ts +17 -0
- package/lib/components/editable-base-table/editable-base-table.component.d.ts +106 -0
- package/lib/components/equation-builder/equation-builder.component.d.ts +23 -0
- package/lib/components/item-line-editor/item-line-editor.component.d.ts +64 -0
- package/lib/components/multi-auto-complete/multi-auto-complete.component.d.ts +51 -0
- package/lib/components/paginator/paginator.component.d.ts +26 -0
- package/lib/components/report-details-dialog/report-details-dialog.component.d.ts +34 -0
- package/lib/components/report-form/report-form.component.d.ts +92 -0
- package/lib/components/search-bar/search-bar.component.d.ts +29 -0
- package/lib/components/section-form-canvas/section-form-canvas.component.d.ts +27 -0
- package/lib/components/shared/action-button/action-button.component.d.ts +17 -0
- package/lib/components/shared/action-card/action-card.component.d.ts +37 -0
- package/lib/components/shared/attachment-uploader/attachment-uploader.component.d.ts +16 -0
- package/lib/components/shared-list/shared-list.component.d.ts +21 -0
- package/lib/components/snackbar-static/snackbar-static.component.d.ts +15 -0
- package/lib/components/title-bar/title-bar.component.d.ts +42 -0
- package/lib/services/backend-service.d.ts +59 -0
- package/{src/lib/services/index.ts → lib/services/index.d.ts} +3 -3
- package/lib/services/top-panel.d.ts +8 -0
- package/lib/services/trigger-form.service.d.ts +7 -0
- package/lib/utils/base-utils.d.ts +13 -0
- package/lib/validators/date-range-validator.d.ts +2 -0
- package/{src/lib/validators/index.ts → lib/validators/index.d.ts} +3 -3
- package/lib/validators/match-list.validator.d.ts +4 -0
- package/lib/validators/multi-email-validator.d.ts +6 -0
- package/package.json +27 -14
- package/{src/public-api.ts → public-api.d.ts} +25 -29
- package/ng-package.json +0 -7
- package/src/lib/base-model/SearchStrConfig.ts +0 -12
- package/src/lib/base-model/audit-log-entry.ts +0 -7
- package/src/lib/base-model/button-action-settings.ts +0 -29
- package/src/lib/base-model/column-def.model.ts +0 -34
- package/src/lib/base-model/do-action-request.ts +0 -11
- package/src/lib/base-model/feature-item.ts +0 -9
- package/src/lib/base-model/field-action.ts +0 -7
- package/src/lib/base-model/field-filter.model.ts +0 -7
- package/src/lib/base-model/field-info.ts +0 -102
- package/src/lib/base-model/field-predicate.model.ts +0 -7
- package/src/lib/base-model/filter-request.ts +0 -27
- package/src/lib/base-model/filter.model.ts +0 -49
- package/src/lib/base-model/get-items-list.ts +0 -24
- package/src/lib/base-model/index.ts +0 -11
- package/src/lib/base-model/items-total.model.ts +0 -12
- package/src/lib/base-model/line-item.model.ts +0 -18
- package/src/lib/base-model/lookupItem.ts +0 -21
- package/src/lib/base-model/null-snackmessage.ts +0 -9
- package/src/lib/base-model/page-info.ts +0 -54
- package/src/lib/base-model/report-request.model.ts +0 -33
- package/src/lib/base-model/response-envelop.model.ts +0 -15
- package/src/lib/base-model/snack-message.model.ts +0 -14
- package/src/lib/base-model/snackmessage-interface.ts +0 -7
- package/src/lib/base-model/table-column.interface.ts +0 -29
- package/src/lib/base-model/table-page-user-action.interface.ts +0 -33
- package/src/lib/base-model/workflow/workflow-steps.model.ts +0 -9
- package/src/lib/base-model/workflow/workflow.model.ts +0 -52
- package/src/lib/components/action-comment/action-comment.component.css +0 -52
- package/src/lib/components/action-comment/action-comment.component.html +0 -47
- package/src/lib/components/action-comment/action-comment.component.spec.ts +0 -23
- package/src/lib/components/action-comment/action-comment.component.ts +0 -102
- package/src/lib/components/action-confirmation/action-confirmation.component.css +0 -46
- package/src/lib/components/action-confirmation/action-confirmation.component.html +0 -32
- package/src/lib/components/action-confirmation/action-confirmation.component.spec.ts +0 -23
- package/src/lib/components/action-confirmation/action-confirmation.component.ts +0 -58
- package/src/lib/components/activity-report-form/activity-report-form.component.html +0 -110
- package/src/lib/components/activity-report-form/activity-report-form.component.scss +0 -69
- package/src/lib/components/activity-report-form/activity-report-form.component.spec.ts +0 -25
- package/src/lib/components/activity-report-form/activity-report-form.component.ts +0 -616
- package/src/lib/components/advanced-filter/field-filter/field-filter.component.html +0 -8
- package/src/lib/components/advanced-filter/field-filter/field-filter.component.scss +0 -0
- package/src/lib/components/advanced-filter/field-filter/field-filter.component.spec.ts +0 -25
- package/src/lib/components/advanced-filter/field-filter/field-filter.component.ts +0 -55
- package/src/lib/components/advanced-filter/filter-builder/filter-builder.component.html +0 -36
- package/src/lib/components/advanced-filter/filter-builder/filter-builder.component.scss +0 -130
- package/src/lib/components/advanced-filter/filter-builder/filter-builder.component.spec.ts +0 -25
- package/src/lib/components/advanced-filter/filter-builder/filter-builder.component.ts +0 -186
- package/src/lib/components/audit-log-details-dialog/audit-log-details-dialog.component.css +0 -51
- package/src/lib/components/audit-log-details-dialog/audit-log-details-dialog.component.html +0 -23
- package/src/lib/components/audit-log-details-dialog/audit-log-details-dialog.component.spec.ts +0 -23
- package/src/lib/components/audit-log-details-dialog/audit-log-details-dialog.component.ts +0 -69
- package/src/lib/components/audit-log-list/audit-log.component.html +0 -26
- package/src/lib/components/audit-log-list/audit-log.component.scss +0 -50
- package/src/lib/components/audit-log-list/audit-log.component.spec.ts +0 -25
- package/src/lib/components/audit-log-list/audit-log.component.ts +0 -114
- package/src/lib/components/auto-complete/auto-complete.component.css +0 -55
- package/src/lib/components/auto-complete/auto-complete.component.html +0 -45
- package/src/lib/components/auto-complete/auto-complete.component.spec.ts +0 -23
- package/src/lib/components/auto-complete/auto-complete.component.ts +0 -331
- package/src/lib/components/base-form/base-form.component.html +0 -59
- package/src/lib/components/base-form/base-form.component.scss +0 -68
- package/src/lib/components/base-form/base-form.component.spec.ts +0 -25
- package/src/lib/components/base-form/base-form.component.ts +0 -323
- package/src/lib/components/base-form-canvas/base-form-canvas.component.css +0 -196
- package/src/lib/components/base-form-canvas/base-form-canvas.component.html +0 -1095
- package/src/lib/components/base-form-canvas/base-form-canvas.component.spec.ts +0 -23
- package/src/lib/components/base-form-canvas/base-form-canvas.component.ts +0 -680
- package/src/lib/components/base-input-dialog/base-input-dialog.component.css +0 -67
- package/src/lib/components/base-input-dialog/base-input-dialog.component.html +0 -47
- package/src/lib/components/base-input-dialog/base-input-dialog.component.spec.ts +0 -23
- package/src/lib/components/base-input-dialog/base-input-dialog.component.ts +0 -77
- package/src/lib/components/base-table/base-table.component.html +0 -268
- package/src/lib/components/base-table/base-table.component.scss +0 -140
- package/src/lib/components/base-table/base-table.component.spec.ts +0 -25
- package/src/lib/components/base-table/base-table.component.ts +0 -621
- package/src/lib/components/button-actions/button-actions.component.html +0 -27
- package/src/lib/components/button-actions/button-actions.component.scss +0 -101
- package/src/lib/components/button-actions/button-actions.component.spec.ts +0 -23
- package/src/lib/components/button-actions/button-actions.component.ts +0 -70
- package/src/lib/components/editable-base-table/editable-base-table.component.html +0 -337
- package/src/lib/components/editable-base-table/editable-base-table.component.scss +0 -126
- package/src/lib/components/editable-base-table/editable-base-table.component.spec.ts +0 -25
- package/src/lib/components/editable-base-table/editable-base-table.component.ts +0 -579
- package/src/lib/components/equation-builder/equation-builder.component.css +0 -39
- package/src/lib/components/equation-builder/equation-builder.component.html +0 -31
- package/src/lib/components/equation-builder/equation-builder.component.spec.ts +0 -23
- package/src/lib/components/equation-builder/equation-builder.component.ts +0 -119
- package/src/lib/components/item-line-editor/item-line-editor.component.html +0 -102
- package/src/lib/components/item-line-editor/item-line-editor.component.scss +0 -152
- package/src/lib/components/item-line-editor/item-line-editor.component.spec.ts +0 -23
- package/src/lib/components/item-line-editor/item-line-editor.component.ts +0 -306
- package/src/lib/components/multi-auto-complete/multi-auto-complete.component.css +0 -19
- package/src/lib/components/multi-auto-complete/multi-auto-complete.component.html +0 -38
- package/src/lib/components/multi-auto-complete/multi-auto-complete.component.spec.ts +0 -23
- package/src/lib/components/multi-auto-complete/multi-auto-complete.component.ts +0 -315
- package/src/lib/components/paginator/paginator.component.css +0 -65
- package/src/lib/components/paginator/paginator.component.html +0 -30
- package/src/lib/components/paginator/paginator.component.ts +0 -87
- package/src/lib/components/report-details-dialog/report-details-dialog.component.css +0 -17
- package/src/lib/components/report-details-dialog/report-details-dialog.component.html +0 -16
- package/src/lib/components/report-details-dialog/report-details-dialog.component.spec.ts +0 -23
- package/src/lib/components/report-details-dialog/report-details-dialog.component.ts +0 -111
- package/src/lib/components/report-form/report-form.component.html +0 -92
- package/src/lib/components/report-form/report-form.component.scss +0 -51
- package/src/lib/components/report-form/report-form.component.spec.ts +0 -25
- package/src/lib/components/report-form/report-form.component.ts +0 -599
- package/src/lib/components/search-bar/search-bar.component.html +0 -51
- package/src/lib/components/search-bar/search-bar.component.scss +0 -63
- package/src/lib/components/search-bar/search-bar.component.spec.ts +0 -25
- package/src/lib/components/search-bar/search-bar.component.ts +0 -68
- package/src/lib/components/section-form-canvas/section-form-canvas.component.html +0 -43
- package/src/lib/components/section-form-canvas/section-form-canvas.component.scss +0 -81
- package/src/lib/components/section-form-canvas/section-form-canvas.component.spec.ts +0 -23
- package/src/lib/components/section-form-canvas/section-form-canvas.component.ts +0 -67
- package/src/lib/components/shared/action-button/action-button.component.html +0 -12
- package/src/lib/components/shared/action-button/action-button.component.scss +0 -45
- package/src/lib/components/shared/action-button/action-button.component.ts +0 -51
- package/src/lib/components/shared/action-card/action-card.component.html +0 -78
- package/src/lib/components/shared/action-card/action-card.component.scss +0 -238
- package/src/lib/components/shared/action-card/action-card.component.ts +0 -56
- package/src/lib/components/shared/attachment-uploader/attachment-uploader.component.css +0 -135
- package/src/lib/components/shared/attachment-uploader/attachment-uploader.component.html +0 -36
- package/src/lib/components/shared/attachment-uploader/attachment-uploader.component.spec.ts +0 -23
- package/src/lib/components/shared/attachment-uploader/attachment-uploader.component.ts +0 -71
- package/src/lib/components/shared-list/shared-list.component.css +0 -0
- package/src/lib/components/shared-list/shared-list.component.html +0 -17
- package/src/lib/components/shared-list/shared-list.component.spec.ts +0 -23
- package/src/lib/components/shared-list/shared-list.component.ts +0 -53
- package/src/lib/components/snackbar-static/snackbar-static.component.html +0 -20
- package/src/lib/components/snackbar-static/snackbar-static.component.scss +0 -135
- package/src/lib/components/snackbar-static/snackbar-static.component.ts +0 -26
- package/src/lib/components/title-bar/title-bar.component.css +0 -0
- package/src/lib/components/title-bar/title-bar.component.css.map +0 -1
- package/src/lib/components/title-bar/title-bar.component.html +0 -35
- package/src/lib/components/title-bar/title-bar.component.scss +0 -126
- package/src/lib/components/title-bar/title-bar.component.spec.ts +0 -23
- package/src/lib/components/title-bar/title-bar.component.ts +0 -126
- package/src/lib/services/backend-service.ts +0 -287
- package/src/lib/services/top-panel.ts +0 -17
- package/src/lib/services/trigger-form.service.ts +0 -11
- package/src/lib/share-module/shared-module.ts +0 -10
- package/src/lib/utils/base-utils.ts +0 -102
- package/src/lib/validators/date-range-validator.ts +0 -31
- package/src/lib/validators/match-list.validator.ts +0 -10
- package/src/lib/validators/multi-email-validator.ts +0 -15
- package/tsconfig.lib.json +0 -15
- package/tsconfig.lib.prod.json +0 -11
- package/tsconfig.spec.json +0 -15
|
@@ -0,0 +1,591 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output, ViewChild, computed, model, signal } from '@angular/core';
|
|
2
|
+
import { ReactiveFormsModule, FormsModule, FormControl } from "@angular/forms";
|
|
3
|
+
import { MatChip, MatChipGrid, MatChipInput, MatChipListbox, MatChipOption, MatChipRemove, MatChipRow } from "@angular/material/chips";
|
|
4
|
+
import { TranslateModule } from "@ngx-translate/core";
|
|
5
|
+
import { COMMA, ENTER, SEMICOLON } from "@angular/cdk/keycodes";
|
|
6
|
+
import { AsyncPipe, CurrencyPipe, DatePipe, KeyValuePipe, NgForOf, NgIf, NgStyle, NgSwitch, NgSwitchCase, NgTemplateOutlet } from "@angular/common";
|
|
7
|
+
import { MatError, MatFormFieldModule, MatLabel } from "@angular/material/form-field";
|
|
8
|
+
import { MatInputModule } from "@angular/material/input";
|
|
9
|
+
import { MatDatepicker, MatDatepickerInput, MatDatepickerToggle, MatDateRangeInput } from "@angular/material/datepicker";
|
|
10
|
+
import { MatIcon } from "@angular/material/icon";
|
|
11
|
+
import { CdkTextareaAutosize } from "@angular/cdk/text-field";
|
|
12
|
+
import { MatRadioButton, MatRadioGroup } from "@angular/material/radio";
|
|
13
|
+
import { MatCheckbox } from "@angular/material/checkbox";
|
|
14
|
+
import { MatOption, MatSelect } from "@angular/material/select";
|
|
15
|
+
import { MatDivider } from "@angular/material/divider";
|
|
16
|
+
import { NgxJsonViewerModule } from "ngx-json-viewer";
|
|
17
|
+
import { CKEditorModule } from "@ckeditor/ckeditor5-angular";
|
|
18
|
+
import { NgxMatIntlTelInputComponent } from "ngx-mat-intl-tel-input";
|
|
19
|
+
import { MultiAutoCompleteComponent } from "../multi-auto-complete/multi-auto-complete.component";
|
|
20
|
+
import { AutoCompleteComponent } from "../auto-complete/auto-complete.component";
|
|
21
|
+
import { MatAutocomplete, MatAutocompleteTrigger } from "@angular/material/autocomplete";
|
|
22
|
+
import { BehaviorSubject, map } from "rxjs";
|
|
23
|
+
import { buildFormFields, extractFieldName } from "../../utils/base-utils";
|
|
24
|
+
import ClassicEditor from "@ckeditor/ckeditor5-build-classic";
|
|
25
|
+
import moment from "moment/moment";
|
|
26
|
+
import { MatCell, MatCellDef, MatHeaderCell, MatHeaderCellDef } from "@angular/material/table";
|
|
27
|
+
import { DateAdapter, MAT_DATE_FORMATS, MAT_DATE_LOCALE } from "@angular/material/core";
|
|
28
|
+
import { MAT_MOMENT_DATE_ADAPTER_OPTIONS, MomentDateAdapter } from "@angular/material-moment-adapter";
|
|
29
|
+
import * as i0 from "@angular/core";
|
|
30
|
+
import * as i1 from "@ngx-translate/core";
|
|
31
|
+
import * as i2 from "@angular/router";
|
|
32
|
+
import * as i3 from "../../services/backend-service";
|
|
33
|
+
import * as i4 from "@angular/forms";
|
|
34
|
+
import * as i5 from "@angular/cdk/a11y";
|
|
35
|
+
import * as i6 from "@angular/material/form-field";
|
|
36
|
+
import * as i7 from "@angular/cdk/bidi";
|
|
37
|
+
import * as i8 from "@angular/material/input";
|
|
38
|
+
import * as i9 from "@angular/cdk/text-field";
|
|
39
|
+
import * as i10 from "ngx-json-viewer";
|
|
40
|
+
export const DD_MM_YYYY_Format = {
|
|
41
|
+
parse: { dateInput: 'DD/MM/YYYY' },
|
|
42
|
+
display: {
|
|
43
|
+
dateInput: 'DD/MM/YYYY',
|
|
44
|
+
monthYearLabel: 'MMM YYYY',
|
|
45
|
+
dateA11yLabel: 'DD/MM/YYYY',
|
|
46
|
+
monthYearA11yLabel: 'MMMM YYYY',
|
|
47
|
+
},
|
|
48
|
+
};
|
|
49
|
+
export class BaseFormCanvasComponent {
|
|
50
|
+
set defaults(value) {
|
|
51
|
+
// this.backendService._defaults = value;
|
|
52
|
+
this._defaults = value;
|
|
53
|
+
this.buildForm();
|
|
54
|
+
// this.myCallback = value;
|
|
55
|
+
}
|
|
56
|
+
get defaults() {
|
|
57
|
+
// this.myCallback;
|
|
58
|
+
return this._defaults;
|
|
59
|
+
// return this.backendService._defaults;
|
|
60
|
+
}
|
|
61
|
+
constructor(translateService, activatedRoute, backendService, fb, announcer) {
|
|
62
|
+
this.translateService = translateService;
|
|
63
|
+
this.activatedRoute = activatedRoute;
|
|
64
|
+
this.backendService = backendService;
|
|
65
|
+
this.fb = fb;
|
|
66
|
+
this.announcer = announcer;
|
|
67
|
+
this.Editor = ClassicEditor;
|
|
68
|
+
this.hide = true;
|
|
69
|
+
this.dateViewMode = 'month';
|
|
70
|
+
this.fields = [];
|
|
71
|
+
this.errors = [];
|
|
72
|
+
this.workflowEditableFields = [];
|
|
73
|
+
this.isWorkflowEditableManaged = false;
|
|
74
|
+
this.editable = false;
|
|
75
|
+
// When true, emit formUpdated on every value change. Default is false to avoid
|
|
76
|
+
// noisy emissions for all consumers. Item-line-editor will enable this explicitly.
|
|
77
|
+
this.emitOnValueChanges = false;
|
|
78
|
+
this.item = {};
|
|
79
|
+
this._defaults = {};
|
|
80
|
+
this.attachmentEmitter = new EventEmitter();
|
|
81
|
+
this.actionEmitter = new EventEmitter();
|
|
82
|
+
this.formUpdated = new EventEmitter();
|
|
83
|
+
this.hyperTextEvent = new EventEmitter();
|
|
84
|
+
this.screenFields = new Map();
|
|
85
|
+
this.removable = true;
|
|
86
|
+
this.selectable = true;
|
|
87
|
+
this.addOnBlur = true;
|
|
88
|
+
this.separatorKeysCodes = [ENTER, COMMA, SEMICOLON];
|
|
89
|
+
this.isPending = false;
|
|
90
|
+
this.isNew = false;
|
|
91
|
+
this.equationOperators = ['+', '-', '('];
|
|
92
|
+
this.equationSuggestedFields = [];
|
|
93
|
+
this.equationValues = signal([]);
|
|
94
|
+
this.currentEquationValue = model('');
|
|
95
|
+
this.equationFilteredFields = computed(() => {
|
|
96
|
+
const currentEquationValue = this.currentEquationValue().toLowerCase();
|
|
97
|
+
return this.allEquationFields.pipe(map(fields => currentEquationValue ? fields?.filter(field => field.toLowerCase().includes(currentEquationValue)) : fields?.slice()));
|
|
98
|
+
});
|
|
99
|
+
ClassicEditor.defaultConfig = {
|
|
100
|
+
toolbar: {
|
|
101
|
+
items: ['heading', '|', 'bold', 'italic', '|', 'bulletedList', 'numberedList']
|
|
102
|
+
},
|
|
103
|
+
image: {
|
|
104
|
+
toolbar: ['imageStyle:side', '|', 'imageTextAlternative']
|
|
105
|
+
},
|
|
106
|
+
table: {
|
|
107
|
+
contentToolbar: ['tableColumn', 'tableRow', 'mergeTableCells']
|
|
108
|
+
},
|
|
109
|
+
language: 'en'
|
|
110
|
+
};
|
|
111
|
+
}
|
|
112
|
+
ngOnInit() {
|
|
113
|
+
if (this.item && this.item.fieldValue) {
|
|
114
|
+
this.equationValues.update(value => this.item.fieldValue);
|
|
115
|
+
}
|
|
116
|
+
this.defaults = this.item;
|
|
117
|
+
this.extractLables();
|
|
118
|
+
this.buildForm();
|
|
119
|
+
this.activatedRoute.data.subscribe(data => {
|
|
120
|
+
this.isPending = data['mode'] === 'pending';
|
|
121
|
+
this.isNew = data['mode'] === 'new';
|
|
122
|
+
});
|
|
123
|
+
// this.authService.summaryPanelState$.next(Constants.SUMMARY_PANEL_CLOSED);
|
|
124
|
+
// this.defaults = {};
|
|
125
|
+
// this.invoiceQInit();
|
|
126
|
+
this.allEquationFields = new BehaviorSubject([]);
|
|
127
|
+
this.updateEquationOptions();
|
|
128
|
+
}
|
|
129
|
+
formatTimeToDate(v) {
|
|
130
|
+
const fromTime = new Date();
|
|
131
|
+
if (v) {
|
|
132
|
+
let split = v.split(":");
|
|
133
|
+
fromTime.setHours(split[0], split[1]);
|
|
134
|
+
}
|
|
135
|
+
return new Date(fromTime.getTime());
|
|
136
|
+
}
|
|
137
|
+
patchLookupValue($event, fieldName) {
|
|
138
|
+
if ($event?.id !== -1 && this.defaults) {
|
|
139
|
+
// @ts-ignore
|
|
140
|
+
this.defaults[fieldName] = this.formParam.get(fieldName).value;
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
getBankName(fieldName) {
|
|
144
|
+
//TODO Batool do we need this here ?
|
|
145
|
+
if (this.formParam.get(fieldName).value?.length > 10 && !isNaN(this.formParam.get(fieldName).value)) {
|
|
146
|
+
return ' / ' + this.translateService.instant('BANK.' + this.formParam.get(fieldName).value?.substr(4, 4));
|
|
147
|
+
}
|
|
148
|
+
else {
|
|
149
|
+
return '';
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
patchMultiSelectValue($event, fieldName) {
|
|
153
|
+
if ($event?.length >= 0 && this.defaults) {
|
|
154
|
+
this.defaults[fieldName] = this.formParam.get(fieldName).value;
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
ngOnChanges({ item, errors, fields }) {
|
|
158
|
+
errors?.currentValue?.forEach((msg) => {
|
|
159
|
+
this.formParam.get(msg.fieldName)?.setErrors({ serverError: msg.message });
|
|
160
|
+
});
|
|
161
|
+
if (item?.currentValue && !item.isFirstChange()) {
|
|
162
|
+
this.defaults = item.currentValue;
|
|
163
|
+
}
|
|
164
|
+
if (fields?.currentValue && !fields.isFirstChange()) {
|
|
165
|
+
this.buildForm();
|
|
166
|
+
}
|
|
167
|
+
}
|
|
168
|
+
showField(item, field) {
|
|
169
|
+
return (item.id || (!item.id && !field.updateOnly)) && field.visible;
|
|
170
|
+
}
|
|
171
|
+
workflowEditableField(field) {
|
|
172
|
+
const x = this.isWorkflowEditableManaged ? this.workflowEditableFields?.findIndex(d => d === field.property) > -1 : true;
|
|
173
|
+
return x;
|
|
174
|
+
}
|
|
175
|
+
showMultiSelectValuesAsReadonly(field) {
|
|
176
|
+
const viewProp = this.translateService.getDefaultLang() === 'en' ? 'englishName' : 'arabicName';
|
|
177
|
+
return this.extractFieldName(this.defaults, field.property)?.map((a) => a[viewProp]);
|
|
178
|
+
}
|
|
179
|
+
splitReadonly(values) {
|
|
180
|
+
return !values || values === '' ? [] : values.split(';');
|
|
181
|
+
}
|
|
182
|
+
referenceAttributeTrue(fieldName, attribute) {
|
|
183
|
+
// return this.authService.referenceAttributeTrue(fieldName, this.pageInfo.processId, attribute);
|
|
184
|
+
}
|
|
185
|
+
translateLable(itemElement) {
|
|
186
|
+
return this.translateService.instant(itemElement);
|
|
187
|
+
}
|
|
188
|
+
buildForm() {
|
|
189
|
+
if (!this.fields || this.fields.length === 0 || !this.defaults)
|
|
190
|
+
return;
|
|
191
|
+
if (!this.formParam) {
|
|
192
|
+
this.formParam = this.fb.group(buildFormFields(this.fields, this.defaults));
|
|
193
|
+
// Emit initial form reference
|
|
194
|
+
this.formUpdated.next(this.formParam);
|
|
195
|
+
// Emit on every value change so parent components can react live
|
|
196
|
+
if (this.emitOnValueChanges) {
|
|
197
|
+
this.formParam.valueChanges.subscribe(() => {
|
|
198
|
+
this.formUpdated.emit(this.formParam);
|
|
199
|
+
});
|
|
200
|
+
}
|
|
201
|
+
return;
|
|
202
|
+
}
|
|
203
|
+
const patchValues = {};
|
|
204
|
+
for (const field of this.fields) {
|
|
205
|
+
if (field.readonly) {
|
|
206
|
+
this.formParam.get(field.property)?.disable({ emitEvent: false });
|
|
207
|
+
}
|
|
208
|
+
else {
|
|
209
|
+
this.formParam.get(field.property)?.enable({ emitEvent: false });
|
|
210
|
+
}
|
|
211
|
+
if (field.type !== 'spacer') {
|
|
212
|
+
patchValues[field.property] = extractFieldName(this.defaults, field.property);
|
|
213
|
+
}
|
|
214
|
+
}
|
|
215
|
+
this.formParam.patchValue(patchValues, { emitEvent: false });
|
|
216
|
+
}
|
|
217
|
+
labelKey(column) {
|
|
218
|
+
const configuredKey = column.label ? column.label : column.property;
|
|
219
|
+
return configuredKey.startsWith(this.pageInfo.labelsSection) ? `${configuredKey}` : `${this.pageInfo.labelsSection}.${configuredKey}`;
|
|
220
|
+
}
|
|
221
|
+
labelKeyPlaceHolder(column) {
|
|
222
|
+
const configuredKey = column.placeholder ? column.placeholder : column.property;
|
|
223
|
+
return configuredKey.startsWith(this.pageInfo.labelsSection) ? `${configuredKey}` : `${this.pageInfo.labelsSection}.${configuredKey}`;
|
|
224
|
+
}
|
|
225
|
+
getErrors(prop) {
|
|
226
|
+
const control = this.formParam.get(prop);
|
|
227
|
+
if (!control || control.disabled)
|
|
228
|
+
return '';
|
|
229
|
+
const field = this.fields.find(f => f.property === prop);
|
|
230
|
+
if (!field?.validationMessages) {
|
|
231
|
+
if (control.value && control.status !== 'VALID' && this.getFirstErrorKey) {
|
|
232
|
+
return this.getFirstErrorKey(prop);
|
|
233
|
+
}
|
|
234
|
+
return '';
|
|
235
|
+
}
|
|
236
|
+
if (control.invalid) {
|
|
237
|
+
const errors = control.errors || {};
|
|
238
|
+
const prefix = this.pageInfo.labelsSection + ".";
|
|
239
|
+
if (errors['required'])
|
|
240
|
+
return prefix + 'REQUIRED';
|
|
241
|
+
if (errors['min'])
|
|
242
|
+
return prefix + (field.validationMessages?.min || 'NUMBER_MIN');
|
|
243
|
+
if (errors['max'])
|
|
244
|
+
return prefix + (field.validationMessages?.max || 'NUMBER_MAX');
|
|
245
|
+
if (errors['maxlength'])
|
|
246
|
+
return prefix + (field.validationMessages?.maxlength || 'MAX_LENGTH');
|
|
247
|
+
if (errors['decimalMin'])
|
|
248
|
+
return prefix + (field.validationMessages?.decimalMin || 'DECIMAL_MIN');
|
|
249
|
+
if (errors['decimalMax'])
|
|
250
|
+
return prefix + (field.validationMessages?.decimalMax || 'DECIMAL_MAX');
|
|
251
|
+
if (errors['pattern'])
|
|
252
|
+
return prefix + (field.validationMessages?.pattern || 'INVALID_FORMAT');
|
|
253
|
+
if (errors['invalidMathExpression'])
|
|
254
|
+
return prefix + 'INVALID_MATH';
|
|
255
|
+
if (errors['serverError'])
|
|
256
|
+
return prefix + errors['serverError'];
|
|
257
|
+
return prefix + 'INVALID_VALUE';
|
|
258
|
+
}
|
|
259
|
+
return '';
|
|
260
|
+
}
|
|
261
|
+
getFirstErrorKey(prop) {
|
|
262
|
+
const errors = this.formParam.get(prop)?.errors;
|
|
263
|
+
if (!errors || Object.keys(errors).length === 0) {
|
|
264
|
+
return errors?.['serverError'] || 'INVALID_FORMAT';
|
|
265
|
+
}
|
|
266
|
+
return Object.keys(errors)[0];
|
|
267
|
+
}
|
|
268
|
+
getCountryCodeList() {
|
|
269
|
+
return ['af', 'ax', 'al', 'dz', 'as', 'ad', 'ao', 'ai', 'aq', 'ag', 'ar', 'am', 'aw', 'au', 'at', 'az',
|
|
270
|
+
'bs', 'bh', 'bd', 'bb', 'by', 'be', 'bz', 'bj', 'bm', 'bt', 'bo', 'ba', 'bw', 'bv', 'br', 'io', 'bn',
|
|
271
|
+
'bg', 'bf', 'bi', 'kh', 'cm', 'ca', 'cv', 'ky', 'cf', 'td', 'cl', 'cn', 'cx', 'cc', 'co', 'km', 'cg',
|
|
272
|
+
'cd', 'ck', 'cr', 'ci', 'hr', 'cu', 'cy', 'cz', 'dk', 'dj', 'dm', 'do', 'ec', 'eg', 'sv', 'gq', 'er',
|
|
273
|
+
'ee', 'et', 'fk', 'fo', 'fj', 'fi', 'fr', 'gf', 'pf', 'tf', 'ga', 'gm', 'ge', 'de', 'gh', 'gi', 'gr',
|
|
274
|
+
'gl', 'gd', 'gp', 'gu', 'gt', 'gg', 'gn', 'gw', 'gy', 'ht', 'hm', 'va', 'hn', 'hk', 'hu', 'is', 'in',
|
|
275
|
+
'id', 'ir', 'iq', 'ie', 'im', 'it', 'jm', 'jp', 'je', 'jo', 'kz', 'ke', 'ki', 'kr', 'kw', 'kg', 'la',
|
|
276
|
+
'lv', 'lb', 'ls', 'lr', 'ly', 'li', 'lt', 'lu', 'mo', 'mk', 'mg', 'mw', 'my', 'mv', 'ml', 'mt', 'mh',
|
|
277
|
+
'mq', 'mr', 'mu', 'yt', 'mx', 'fm', 'md', 'mc', 'mn', 'me', 'ms', 'ma', 'mz', 'mm', 'na', 'nr', 'np',
|
|
278
|
+
'nl', 'an', 'nc', 'nz', 'ni', 'ne', 'ng', 'nu', 'nf', 'mp', 'no', 'om', 'pk', 'pw', 'ps', 'pa', 'pg',
|
|
279
|
+
'py', 'pe', 'ph', 'pn', 'pl', 'pt', 'pr', 'qa', 're', 'ro', 'ru', 'rw', 'bl', 'sh', 'kn', 'lc', 'mf',
|
|
280
|
+
'pm', 'vc', 'ws', 'sm', 'st', 'sa', 'sn', 'rs', 'sc', 'sl', 'sg', 'sk', 'si', 'sb', 'so', 'za', 'gs',
|
|
281
|
+
'es', 'lk', 'sd', 'sr', 'sj', 'sz', 'se', 'ch', 'sy', 'tw', 'tj', 'tz', 'th', 'tl', 'tg', 'tk', 'to',
|
|
282
|
+
'tt', 'tn', 'tr', 'tm', 'tc', 'tv', 'ug', 'ua', 'ae', 'gb', 'us', 'um', 'uy', 'uz', 'vu', 've', 'vn',
|
|
283
|
+
'vg', 'vi', 'wf', 'eh', 'ye', 'zm', 'zw'];
|
|
284
|
+
}
|
|
285
|
+
friendlyName(fullPath, subPath, item) {
|
|
286
|
+
return fullPath.substring(0, fullPath.indexOf(subPath)) + item;
|
|
287
|
+
}
|
|
288
|
+
showValue(defaults, field) {
|
|
289
|
+
return this.friendlyName(field.label, field.property, defaults[field.property]);
|
|
290
|
+
}
|
|
291
|
+
showError(prop) {
|
|
292
|
+
return (this.formParam?.get(prop)?.value || this.formParam?.get(prop)?.value == 0)
|
|
293
|
+
&& this.formParam.get(prop).status === 'INVALID';
|
|
294
|
+
}
|
|
295
|
+
ngOnDestroy() {
|
|
296
|
+
this.defaults = null;
|
|
297
|
+
}
|
|
298
|
+
extractLables() {
|
|
299
|
+
this.fields.forEach(f => {
|
|
300
|
+
if (f.visible) {
|
|
301
|
+
f.label = this.labelKey(f);
|
|
302
|
+
if (!this.screenFields.has(f.row)) {
|
|
303
|
+
this.screenFields.set(f.row, []);
|
|
304
|
+
}
|
|
305
|
+
this.screenFields.get(f.row).push(f);
|
|
306
|
+
if (f.cascadedBy) {
|
|
307
|
+
this.formParam?.get(f.cascadedBy)?.valueChanges.subscribe(() => {
|
|
308
|
+
this.formParam?.get(f.property)?.patchValue(null);
|
|
309
|
+
});
|
|
310
|
+
}
|
|
311
|
+
}
|
|
312
|
+
});
|
|
313
|
+
for (let i = 1; i < this.screenFields.size; i++) {
|
|
314
|
+
this.calcFlexSize(i);
|
|
315
|
+
}
|
|
316
|
+
// console.log(this.screenFields)
|
|
317
|
+
}
|
|
318
|
+
calcFlexSize(i) {
|
|
319
|
+
// Preserve explicit fieldSize values only. For fields without fieldSize, allow
|
|
320
|
+
// the layout to auto-size via flex (handled in the template/CSS).
|
|
321
|
+
// Intentionally do nothing here so that unspecified fields remain flexible.
|
|
322
|
+
return;
|
|
323
|
+
}
|
|
324
|
+
getCurrencyPattern(field) {
|
|
325
|
+
// const decimalPlaces = this.authService?.myCurrencies?.find(c => c.key === this.formParam.get(field.currency)?.value)?.currencyNumOfDecimalPattern || 3;
|
|
326
|
+
const decimalPlaces = 3;
|
|
327
|
+
return '^\\d*(?:[.,]\\d{1,' + decimalPlaces + '})?$';
|
|
328
|
+
}
|
|
329
|
+
splittedChips(form, fieldName) {
|
|
330
|
+
return form.get(fieldName).value === '' ? [] : form.get(fieldName).value.trim().split(';');
|
|
331
|
+
}
|
|
332
|
+
fixArabicNumbers(str) {
|
|
333
|
+
// if(typeof str === 'string') {
|
|
334
|
+
// str = str.replace(/([٠١٢٣٤٥٦٧٨٩])|([۰۱۲۳۴۵۶۷۸۹])/g, (m, $1, $2) => m.charCodeAt(0) - ($1 ? 1632 : 1776));
|
|
335
|
+
// }
|
|
336
|
+
// console.log(str);
|
|
337
|
+
}
|
|
338
|
+
listShowValue(defaults, field) {
|
|
339
|
+
return defaults[field.property] ? this.showValue(defaults, field) : '';
|
|
340
|
+
}
|
|
341
|
+
removeChipsItem(form, fieldName, idx) {
|
|
342
|
+
const emails = this.splittedChips(form, fieldName);
|
|
343
|
+
if (emails.length >= 1) {
|
|
344
|
+
emails.splice(idx, 1);
|
|
345
|
+
}
|
|
346
|
+
let cleanedEmails = emails.join(";");
|
|
347
|
+
form.get(fieldName).setValue(cleanedEmails);
|
|
348
|
+
}
|
|
349
|
+
extractFieldName(element, property) {
|
|
350
|
+
if (property?.includes('.')) {
|
|
351
|
+
return property.split('.').reduce((acc, part) => acc && acc[part], element);
|
|
352
|
+
}
|
|
353
|
+
else {
|
|
354
|
+
return element[property];
|
|
355
|
+
}
|
|
356
|
+
}
|
|
357
|
+
getMultiValue(field) {
|
|
358
|
+
return this.formParam.get(field.property)?.value;
|
|
359
|
+
}
|
|
360
|
+
validateEmail(email) {
|
|
361
|
+
var re = /^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/;
|
|
362
|
+
return re.test(String(email).toLowerCase());
|
|
363
|
+
}
|
|
364
|
+
addEmailToChips(event, form, fieldName) {
|
|
365
|
+
const input = event.input;
|
|
366
|
+
const value = event.value;
|
|
367
|
+
const items = value.split(';');
|
|
368
|
+
// value.split(' ');
|
|
369
|
+
items.forEach(itm => {
|
|
370
|
+
if (this.validateEmail((itm || '').trim())) {
|
|
371
|
+
const x = this.splittedChips(form, fieldName);
|
|
372
|
+
x.push(itm);
|
|
373
|
+
form.get(fieldName).patchValue(x.join(';'));
|
|
374
|
+
if (input) {
|
|
375
|
+
input.value = '';
|
|
376
|
+
}
|
|
377
|
+
}
|
|
378
|
+
});
|
|
379
|
+
}
|
|
380
|
+
extractJsonFieldName(defaults, property) {
|
|
381
|
+
const x = this.extractFieldName(defaults, property);
|
|
382
|
+
if (x?.length > 0)
|
|
383
|
+
return JSON.parse(x);
|
|
384
|
+
else
|
|
385
|
+
return '{}';
|
|
386
|
+
}
|
|
387
|
+
getOptionValue(item) {
|
|
388
|
+
const value = typeof item === 'object' ?
|
|
389
|
+
this.translateService.getDefaultLang() === 'en' ? item.englishName : item.arabicName
|
|
390
|
+
: item;
|
|
391
|
+
return value;
|
|
392
|
+
}
|
|
393
|
+
getHyperTextEvent() {
|
|
394
|
+
this.hyperTextEvent.emit(true);
|
|
395
|
+
}
|
|
396
|
+
add(event) {
|
|
397
|
+
const value = (event.value || '').trim();
|
|
398
|
+
if (value) {
|
|
399
|
+
if (this.equationOperators.includes(value) || !this.equationValues().includes(value)) {
|
|
400
|
+
this.equationValues.update(equationValues => [...equationValues, value]);
|
|
401
|
+
}
|
|
402
|
+
}
|
|
403
|
+
this.fieldsInput.nativeElement.value = '';
|
|
404
|
+
this.currentEquationValue.set('');
|
|
405
|
+
this.updateEquationOptions();
|
|
406
|
+
}
|
|
407
|
+
remove(item, index) {
|
|
408
|
+
this.equationValues.update(equationValues => {
|
|
409
|
+
if (index < 0) {
|
|
410
|
+
return equationValues;
|
|
411
|
+
}
|
|
412
|
+
equationValues.splice(index, 1);
|
|
413
|
+
this.announcer.announce(`Removed ${item}`);
|
|
414
|
+
return [...equationValues];
|
|
415
|
+
});
|
|
416
|
+
this.updateEquationOptions();
|
|
417
|
+
}
|
|
418
|
+
selected(event) {
|
|
419
|
+
const selectedValue = event.option.viewValue.trim();
|
|
420
|
+
if (!this.equationOperators.includes(selectedValue) && !this.equationValues().includes(selectedValue)) {
|
|
421
|
+
this.equationValues.update(equationValues => [...equationValues, selectedValue]);
|
|
422
|
+
}
|
|
423
|
+
else if (this.equationOperators.includes(selectedValue)) {
|
|
424
|
+
this.equationValues.update(equationValues => [...equationValues, selectedValue]);
|
|
425
|
+
}
|
|
426
|
+
this.currentEquationValue.set('');
|
|
427
|
+
event.option.deselect();
|
|
428
|
+
this.fieldsInput.nativeElement.value = '';
|
|
429
|
+
this.updateEquationOptions();
|
|
430
|
+
}
|
|
431
|
+
updateEquationOptions() {
|
|
432
|
+
this.reflectEquationValueOnForm();
|
|
433
|
+
let updatedFields;
|
|
434
|
+
if (this.equationValues().length === 0) {
|
|
435
|
+
updatedFields = this.getNamesFromSuggestedEquationFields();
|
|
436
|
+
}
|
|
437
|
+
else {
|
|
438
|
+
let lastElement = this.equationValues()[this.equationValues().length - 1];
|
|
439
|
+
if (this.equationOperators.includes(lastElement)) {
|
|
440
|
+
updatedFields = this.getNamesFromSuggestedEquationFields();
|
|
441
|
+
}
|
|
442
|
+
else {
|
|
443
|
+
updatedFields = this.equationOperators;
|
|
444
|
+
}
|
|
445
|
+
}
|
|
446
|
+
// console.log('*****', updatedFields);
|
|
447
|
+
this.allEquationFields.next(updatedFields);
|
|
448
|
+
}
|
|
449
|
+
getNamesFromSuggestedEquationFields() {
|
|
450
|
+
return this.equationSuggestedFields?.map(field => field.name);
|
|
451
|
+
}
|
|
452
|
+
reflectEquationValueOnForm() {
|
|
453
|
+
if (this.formParam && this.formParam.get('fieldValue')) {
|
|
454
|
+
this.formParam.get('fieldValue').setValue(this.equationValues());
|
|
455
|
+
}
|
|
456
|
+
else {
|
|
457
|
+
// console.log('Form or fieldValue is not available.');
|
|
458
|
+
}
|
|
459
|
+
}
|
|
460
|
+
checkEquation(field, $event) {
|
|
461
|
+
// console.log('$event', $event);
|
|
462
|
+
// try {
|
|
463
|
+
// evaluate(equation.replace(/[a-zA-Z0-9]+/g, '1')); // Replace variables with dummy values
|
|
464
|
+
// this.formGroups[index].get('xyz').setErrors(null);
|
|
465
|
+
// console.log('valid ', equation)
|
|
466
|
+
// } catch (e) {
|
|
467
|
+
// this.formGroups[index].get('xyz').setErrors({serverError: 'incomplete '});
|
|
468
|
+
// console.log('bad ', equation)
|
|
469
|
+
// }
|
|
470
|
+
}
|
|
471
|
+
getView(field) {
|
|
472
|
+
return field.pattern || 'month';
|
|
473
|
+
}
|
|
474
|
+
setMonthAndYear(normalizedMonthAndYear, picker, field) {
|
|
475
|
+
console.log('field.pattern', field.pattern);
|
|
476
|
+
if (field.pattern === 'multi-year') {
|
|
477
|
+
console.log('hi');
|
|
478
|
+
const date = new FormControl(moment());
|
|
479
|
+
const ctrlValue = date.value;
|
|
480
|
+
ctrlValue.year(normalizedMonthAndYear.year());
|
|
481
|
+
ctrlValue.month(1);
|
|
482
|
+
ctrlValue.dayOfYear(1);
|
|
483
|
+
this.formParam.get(field.property).setValue(ctrlValue);
|
|
484
|
+
picker.close();
|
|
485
|
+
}
|
|
486
|
+
}
|
|
487
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: BaseFormCanvasComponent, deps: [{ token: i1.TranslateService }, { token: i2.ActivatedRoute }, { token: i3.BackendService }, { token: i4.FormBuilder }, { token: i5.LiveAnnouncer }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
488
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.3.12", type: BaseFormCanvasComponent, isStandalone: true, selector: "app-base-form-canvas", inputs: { pageInfo: { classPropertyName: "pageInfo", publicName: "pageInfo", isSignal: false, isRequired: false, transformFunction: null }, currency: { classPropertyName: "currency", publicName: "currency", isSignal: false, isRequired: false, transformFunction: null }, fields: { classPropertyName: "fields", publicName: "fields", isSignal: false, isRequired: false, transformFunction: null }, errors: { classPropertyName: "errors", publicName: "errors", isSignal: false, isRequired: false, transformFunction: null }, workflowEditableFields: { classPropertyName: "workflowEditableFields", publicName: "workflowEditableFields", isSignal: false, isRequired: false, transformFunction: null }, isWorkflowEditableManaged: { classPropertyName: "isWorkflowEditableManaged", publicName: "isWorkflowEditableManaged", isSignal: false, isRequired: false, transformFunction: null }, supportingAttributes: { classPropertyName: "supportingAttributes", publicName: "supportingAttributes", isSignal: false, isRequired: false, transformFunction: null }, editable: { classPropertyName: "editable", publicName: "editable", isSignal: false, isRequired: false, transformFunction: null }, emitOnValueChanges: { classPropertyName: "emitOnValueChanges", publicName: "emitOnValueChanges", isSignal: false, isRequired: false, transformFunction: null }, item: { classPropertyName: "item", publicName: "item", isSignal: false, isRequired: false, transformFunction: null }, equationSuggestedFields: { classPropertyName: "equationSuggestedFields", publicName: "equationSuggestedFields", isSignal: false, isRequired: false, transformFunction: null }, currentEquationValue: { classPropertyName: "currentEquationValue", publicName: "currentEquationValue", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { attachmentEmitter: "attachmentEmitter", actionEmitter: "actionEmitter", formUpdated: "formUpdated", hyperTextEvent: "hyperTextEvent", currentEquationValue: "currentEquationValueChange" }, providers: [
|
|
489
|
+
{
|
|
490
|
+
provide: DateAdapter,
|
|
491
|
+
useClass: MomentDateAdapter,
|
|
492
|
+
deps: [MAT_DATE_LOCALE, MAT_MOMENT_DATE_ADAPTER_OPTIONS]
|
|
493
|
+
},
|
|
494
|
+
{ provide: MAT_DATE_FORMATS, useValue: DD_MM_YYYY_Format },
|
|
495
|
+
{ provide: MAT_DATE_LOCALE, useValue: 'en-GB' }
|
|
496
|
+
], viewQueries: [{ propertyName: "fieldsInput", first: true, predicate: ["EquationValueInput"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"main-form-canvas\">\r\n <div class=\"form-wrapper\">\r\n <ng-container *ngIf=\"defaults\">\r\n <ng-container *ngIf=\"editable; else readonlyView\" class=\"form-container\">\r\n <form [formGroup]=\"formParam\" class=\"form-content\">\r\n <div class=\"form-row\">\r\n <div class=\"form-column\">\r\n <ng-container *ngFor=\"let row of screenFields | keyvalue\">\r\n <div class=\"row-container\">\r\n <ng-container *ngFor=\"let field of row.value\">\r\n <div class=\"field-column\" [style.flex]=\"field.fieldSize ? ('0 0 ' + field.fieldSize + '%') : '1 1 0'\">\r\n <ng-container [ngSwitch]=\"field.type\">\r\n <ng-container *ngSwitchCase=\"'date'\">\r\n <ng-container *ngIf=\"showField(defaults, field)\">\r\n <ng-container *ngIf=\"workflowEditableField(field)\">\r\n <div class=\"label-and-asterisk-container\">\r\n <span *ngIf=\"!field.hideLabel\" class=\"custom-label\" id=\"label-{{field.property}}\">\r\n {{ field.label! | translate }}\r\n </span>\r\n <span *ngIf=\"field.required\" class=\"required-asterisk\"> * </span>\r\n </div>\r\n\r\n <mat-form-field appearance=\"outline\">\r\n <input matInput\r\n [matDatepicker]=\"picker\"\r\n [value]=\"formParam.get(field.property)?.value\"\r\n (dateChange)=\"formParam.get(field.property).setValue($event.value)\"\r\n [placeholder]=\"field.placeholder ? (labelKeyPlaceHolder(field) | translate) : ''\"\r\n [readonly]=\"field.readonly\"\r\n formControlName=\"{{field.property}}\"\r\n [required]=\"field.required\"\r\n [attr.aria-invalid]=\"showError(field.property)\"\r\n [attr.aria-labelledby]=\"'label-' + field.property\"\r\n [attr.aria-describedby]=\"'error-' + field.property\">\r\n\r\n <mat-datepicker-toggle matSuffix [for]=\"picker\"></mat-datepicker-toggle>\r\n\r\n <mat-datepicker #picker\r\n [startView]=\"getView(field)\"\r\n (yearSelected)=\"setMonthAndYear($event, picker, field)\"\r\n panelClass=\"example-month-picker\">\r\n </mat-datepicker>\r\n\r\n <mat-error *ngIf=\"showError(field.property)\" aria-live=\"assertive\">\r\n {{ getErrors(field.property) | translate }}\r\n </mat-error>\r\n </mat-form-field>\r\n\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'phone-number'\">\r\n <ng-container *ngIf=\"showField(defaults, field)\">\r\n <ng-container class=\"custom-ngx-mat-intl-tel-input\" *ngIf=\"workflowEditableField(field)\">\r\n <div class=\"label-and-asterisk-container\">\r\n <span *ngIf=\"!field.hideLabel\" class=\"custom-label\" id=\"label-{{field.property}}\">\r\n {{ field.label! | translate }}\r\n </span>\r\n <span *ngIf=\"field.required\" class=\"required-asterisk\"> * </span>\r\n </div>\r\n <mat-form-field appearance=\"outline\">\r\n <div class=\"phone-input-wrapper\">\r\n <ngx-mat-intl-tel-input\r\n formControlName=\"{{ field.property }}\"\r\n [inputPlaceholder]=\"field.placeholder ? (labelKeyPlaceHolder(field) | translate) : ''\"\r\n [preferredCountries]=\"['qa']\"\r\n [enablePlaceholder]=\"true\"\r\n [enableSearch]=\"true\"\r\n [onlyCountries]=\"getCountryCodeList()\"\r\n [required]=\"field.required\"\r\n [attr.aria-required]=\"field.required\"\r\n [attr.aria-invalid]=\"showError(field.property)\"\r\n [attr.aria-labelledby]=\"'label-' + field.property\"\r\n [attr.aria-describedby]=\"'error-' + field.property\">\r\n </ngx-mat-intl-tel-input>\r\n </div>\r\n\r\n <mat-error\r\n id=\"error-{{ field.property }}\"\r\n *ngIf=\"showError(field.property)\"\r\n aria-live=\"assertive\">\r\n {{ getErrors(field.property) | translate }}\r\n </mat-error>\r\n </mat-form-field>\r\n\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n\r\n\r\n <ng-container *ngSwitchCase=\"'iban-text'\">\r\n <ng-container *ngIf=\"showField(defaults, field)\">\r\n <ng-container *ngIf=\"!workflowEditableField(field)\">\r\n <ng-container\r\n [ngTemplateOutlet]=\"textReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\">\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"workflowEditableField(field)\">\r\n <div class=\"label-and-asterisk-container\">\r\n <span *ngIf=\"!field.hideLabel\" class=\"custom-label\" id=\"label-{{field.property}}\">\r\n {{ field.label! | translate }}\r\n </span>\r\n <span *ngIf=\"field.required\" class=\"required-asterisk\"> * </span>\r\n </div>\r\n <mat-form-field appearance=\"outline\">\r\n <input class=\"app-input\"\r\n formControlName=\"{{ field.property }}\"\r\n matInput\r\n [placeholder]=\"field.placeholder ? (labelKeyPlaceHolder(field) | translate) : ''\"\r\n [readonly]=\"field.readonly\"\r\n [required]=\"field.required\"\r\n [attr.aria-required]=\"field.required\"\r\n [attr.aria-invalid]=\"showError(field.property)\"\r\n [attr.aria-labelledby]=\"'label-' + field.property\"\r\n [attr.aria-describedby]=\"'error-' + field.property\">\r\n <mat-error\r\n id=\"error-{{ field.property }}\"\r\n *ngIf=\"showError(field.property)\"\r\n aria-live=\"assertive\">\r\n {{ getErrors(field.property) | translate }}\r\n </mat-error>\r\n </mat-form-field>\r\n\r\n\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'password'\">\r\n <ng-container *ngIf=\"showField(defaults, field)\">\r\n <div class=\"label-and-asterisk-container\">\r\n <span *ngIf=\"!field.hideLabel\" class=\"custom-label\" id=\"label-{{field.property}}\">\r\n {{ field.label! | translate }}\r\n </span>\r\n <span *ngIf=\"field.required\" class=\"required-asterisk\"> * </span>\r\n </div>\r\n <mat-form-field appearance=\"outline\">\r\n <input matInput\r\n class=\"app-input\"\r\n formControlName=\"{{ field.property }}\"\r\n [type]=\"hide && !field.disabled ? 'password' : 'text'\"\r\n [readonly]=\"field.readonly\"\r\n [required]=\"field.required\"\r\n [placeholder]=\"field.placeholder ? (labelKeyPlaceHolder(field) | translate) : ''\"\r\n [attr.aria-required]=\"field.required\"\r\n [attr.aria-invalid]=\"showError(field.property)\"\r\n [attr.aria-labelledby]=\"'label-' + field.property\"\r\n [attr.aria-describedby]=\"'error-' + field.property\">\r\n <!-- <mat-icon matSuffix-->\r\n <!-- (click)=\"hide = !hide\">-->\r\n <!-- {{ hide ? 'visibility_off' : 'visibility' }}-->\r\n <!-- </mat-icon>-->\r\n <mat-error\r\n id=\"error-{{ field.property }}\"\r\n *ngIf=\"showError(field.property)\"\r\n aria-live=\"assertive\">\r\n {{ getErrors(field.property) | translate }}\r\n </mat-error>\r\n </mat-form-field>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'text'\">\r\n <ng-container *ngIf=\"showField(defaults, field)\">\r\n <ng-container *ngIf=\"!workflowEditableField(field)\">\r\n <ng-container\r\n [ngTemplateOutlet]=\"textReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\">\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"workflowEditableField(field)\">\r\n <div class=\"label-and-asterisk-container\">\r\n <span *ngIf=\"!field.hideLabel\" class=\"custom-label\" id=\"label-{{field.property}}\">\r\n {{ field.label! | translate }}\r\n </span>\r\n <span *ngIf=\"field.required\" class=\"required-asterisk\"> * </span>\r\n </div>\r\n <mat-form-field appearance=\"outline\">\r\n <input class=\"app-input\"\r\n formControlName=\"{{ field.property }}\"\r\n matInput\r\n [placeholder]=\"field.placeholder ? (labelKeyPlaceHolder(field) | translate) : ''\"\r\n [readonly]=\"field.readonly\"\r\n [required]=\"field.required\"\r\n (keyup)=\"fixArabicNumbers($event.target)\"\r\n [attr.aria-required]=\"field.required\"\r\n [attr.aria-invalid]=\"showError(field.property)\"\r\n [attr.aria-labelledby]=\"'label-' + field.property\"\r\n [attr.aria-describedby]=\"'error-' + field.property\">\r\n <mat-error\r\n id=\"error-{{ field.property }}\"\r\n *ngIf=\"showError(field.property)\"\r\n aria-live=\"assertive\">\r\n {{ getErrors(field.property) | translate }}\r\n </mat-error>\r\n </mat-form-field>\r\n\r\n\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'chip-list'\">\r\n <ng-container *ngIf=\"showField(defaults, field)\">\r\n <div class=\"label-and-asterisk-container\">\r\n <span *ngIf=\"!field.hideLabel\" class=\"custom-label\" id=\"label-{{field.property}}\">\r\n {{ field.label! | translate }}\r\n </span>\r\n <span *ngIf=\"field.required\" class=\"required-asterisk\"> * </span>\r\n </div>\r\n <mat-form-field appearance=\"outline\">\r\n\r\n <mat-chip-grid [attr.aria-labelledby]=\"'label-' + field.property\"\r\n formControlName=\"{{ field.property }}\">\r\n <mat-chip-row\r\n *ngFor=\"let mail of splittedChips(formParam, field.property); let idx = index\"\r\n [removable]=\"removable\"\r\n (removed)=\"removeChipsItem(formParam, field.property, idx)\">\r\n {{ mail }}\r\n <mat-icon matChipRemove *ngIf=\"removable\">cancel</mat-icon>\r\n </mat-chip-row>\r\n\r\n <input [attr.aria-labelledby]=\"'label-' + field.property\" [matChipInputFor]=\"null\"\r\n [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\"\r\n [matChipInputAddOnBlur]=\"addOnBlur\"\r\n (matChipInputTokenEnd)=\"addEmailToChips($event, formParam, field.property)\">\r\n </mat-chip-grid>\r\n <mat-error id=\"error-{{ field.property }}\" *ngIf=\"showError(field.property)\"\r\n aria-live=\"assertive\">\r\n {{ getErrors(field.property) | translate }}\r\n </mat-error>\r\n </mat-form-field>\r\n\r\n\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'amount'\">\r\n <ng-container *ngIf=\"showField(defaults, field)\">\r\n <ng-container *ngIf=\"!workflowEditableField(field)\">\r\n <ng-container\r\n [ngTemplateOutlet]=\"amountReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\">\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"workflowEditableField(field)\">\r\n <div class=\"label-and-asterisk-container\">\r\n <span *ngIf=\"!field.hideLabel\" class=\"custom-label\" id=\"label-{{field.property}}\">\r\n {{ field.label! | translate }}\r\n </span>\r\n <span *ngIf=\"field.required\" class=\"required-asterisk\"> * </span>\r\n </div>\r\n <mat-form-field appearance=\"outline\">\r\n <input class=\"app-input\"\r\n formControlName=\"{{ field.property }}\"\r\n matInput\r\n type=\"number\"\r\n [placeholder]=\"field.placeholder ? (labelKeyPlaceHolder(field) | translate) : ''\"\r\n [readonly]=\"field.readonly\"\r\n [required]=\"field.required\"\r\n [attr.aria-required]=\"field.required\"\r\n [attr.aria-invalid]=\"showError(field.property)\"\r\n [attr.aria-labelledby]=\"'label-' + field.property\"\r\n [attr.aria-describedby]=\"'error-' + field.property\">\r\n <mat-error\r\n id=\"error-{{ field.property }}\"\r\n *ngIf=\"showError(field.property)\"\r\n aria-live=\"assertive\">\r\n {{ getErrors(field.property) | translate }}\r\n </mat-error>\r\n </mat-form-field>\r\n\r\n\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'sequence'\">\r\n <ng-container\r\n *ngIf=\"referenceAttributeTrue(field.property, 'autoGenerated'); else noSequence\">\r\n <div class=\"label-and-asterisk-container\">\r\n <span *ngIf=\"!field.hideLabel\" class=\"custom-label\" id=\"label-{{field.property}}\">\r\n {{ field.label! | translate }}\r\n </span>\r\n <span *ngIf=\"field.required\" class=\"required-asterisk\"> * </span>\r\n </div>\r\n <mat-form-field appearance=\"outline\">\r\n <input class=\"app-input\"\r\n formControlName=\"{{ field.property }}\"\r\n matInput\r\n [placeholder]=\"field.placeholder ? (labelKeyPlaceHolder(field) | translate) : ''\"\r\n [readonly]=\"true\"\r\n [disabled]=\"true\"\r\n [attr.aria-labelledby]=\"'label-' + field.property\">\r\n <mat-error\r\n id=\"error-{{ field.property }}\"\r\n *ngIf=\"showError(field.property)\"\r\n aria-live=\"assertive\">\r\n {{ getErrors(field.property) | translate }}\r\n </mat-error>\r\n </mat-form-field>\r\n\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-template #noSequence>\r\n <div class=\"label-and-asterisk-container\">\r\n <span *ngIf=\"!field.hideLabel\" class=\"custom-label\" id=\"label-{{field.property}}\">\r\n {{ field.label! | translate }}\r\n </span>\r\n <span *ngIf=\"field.required\" class=\"required-asterisk\"> * </span>\r\n </div>\r\n <mat-form-field appearance=\"outline\">\r\n <input class=\"app-input\"\r\n formControlName=\"{{ field.property }}\"\r\n matInput\r\n [readonly]=\"false\"\r\n [disabled]=\"false\"\r\n [placeholder]=\"field.placeholder ? (labelKeyPlaceHolder(field) | translate) : ''\"\r\n [required]=\"field.required\"\r\n [attr.aria-labelledby]=\"'label-' + field.property\"\r\n [attr.aria-required]=\"field.required\"\r\n [attr.aria-invalid]=\"showError(field.property)\"\r\n [attr.aria-describedby]=\"'error-' + field.property\">\r\n <mat-error\r\n id=\"error-{{ field.property }}\"\r\n *ngIf=\"showError(field.property)\"\r\n aria-live=\"assertive\">\r\n {{ getErrors(field.property) | translate }}\r\n </mat-error>\r\n </mat-form-field>\r\n\r\n </ng-template>\r\n\r\n <ng-container *ngSwitchCase=\"'textarea'\">\r\n <ng-container *ngIf=\"showField(defaults, field)\">\r\n <ng-container *ngIf=\"!workflowEditableField(field)\">\r\n <ng-container\r\n [ngTemplateOutlet]=\"textareaReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\">\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"workflowEditableField(field)\">\r\n <div class=\"label-and-asterisk-container\">\r\n <span *ngIf=\"!field.hideLabel\" class=\"custom-label\" id=\"label-{{field.property}}\">\r\n {{ field.label! | translate }}\r\n </span>\r\n <span *ngIf=\"field.required\" class=\"required-asterisk\"> * </span>\r\n </div>\r\n <mat-form-field appearance=\"outline\">\r\n <textarea cdkFocusInitial\r\n formControlName=\"{{ field.property }}\"\r\n matInput\r\n cdkTextareaAutosize\r\n cdkAutosizeMinRows=\"3\"\r\n [placeholder]=\"field.placeholder ? (labelKeyPlaceHolder(field) | translate) : ''\"\r\n [attr.aria-labelledby]=\"'label-' + field.property\"\r\n [attr.aria-required]=\"field.required\"\r\n [attr.aria-invalid]=\"showError(field.property)\"\r\n [attr.aria-describedby]=\"'error-' + field.property\"\r\n [readonly]=\"field.readonly\"\r\n [required]=\"field.required\"></textarea>\r\n <mat-error\r\n id=\"error-{{ field.property }}\"\r\n *ngIf=\"showError(field.property)\"\r\n aria-live=\"assertive\">\r\n {{ getErrors(field.property) | translate }}\r\n </mat-error>\r\n </mat-form-field>\r\n\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'number'\">\r\n <ng-container *ngIf=\"showField(defaults, field)\">\r\n <ng-container *ngIf=\"!workflowEditableField(field)\">\r\n <ng-container\r\n [ngTemplateOutlet]=\"numberReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\">\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"workflowEditableField(field)\">\r\n <div class=\"label-and-asterisk-container\">\r\n <span *ngIf=\"!field.hideLabel\" class=\"custom-label\" id=\"label-{{field.property}}\">\r\n {{ field.label! | translate }}\r\n </span>\r\n <span *ngIf=\"field.required\" class=\"required-asterisk\"> * </span>\r\n </div>\r\n <mat-form-field appearance=\"outline\">\r\n <input class=\"app-input\"\r\n formControlName=\"{{ field.property }}\"\r\n matInput\r\n type=\"number\"\r\n [placeholder]=\"field.placeholder ? (labelKeyPlaceHolder(field) | translate) : ''\"\r\n [attr.aria-labelledby]=\"'label-' + field.property\"\r\n [attr.aria-required]=\"field.required\"\r\n [attr.aria-invalid]=\"showError(field.property)\"\r\n [attr.aria-describedby]=\"'error-' + field.property\"\r\n [required]=\"field.readonly ? false : field.required\"\r\n [readonly]=\"field.readonly\"\r\n [pattern]=\"field.pattern\">\r\n <mat-error id=\"error-{{ field.property }}\" *ngIf=\"showError(field.property)\"\r\n aria-live=\"assertive\">\r\n {{ getErrors(field.property) | translate }}\r\n </mat-error>\r\n </mat-form-field>\r\n\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n\r\n\r\n <ng-container *ngSwitchCase=\"'time'\">\r\n <ng-container *ngIf=\"showField(defaults, field)\">\r\n <ng-container *ngIf=\"!workflowEditableField(field)\">\r\n <ng-container\r\n [ngTemplateOutlet]=\"timeReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\">\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"workflowEditableField(field)\">\r\n <div class=\"label-and-asterisk-container\">\r\n <span *ngIf=\"!field.hideLabel\" class=\"custom-label\" id=\"label-{{field.property}}\">\r\n {{ field.label! | translate }}\r\n </span>\r\n <span *ngIf=\"field.required\" class=\"required-asterisk\"> * </span>\r\n </div>\r\n <mat-form-field appearance=\"outline\">\r\n <input\r\n matInput\r\n class=\"app-input\"\r\n formControlName=\"{{ field.property }}\"\r\n type=\"time\"\r\n [placeholder]=\"field.placeholder ? (labelKeyPlaceHolder(field) | translate) : ''\"\r\n [readonly]=\"field.readonly\"\r\n [attr.aria-labelledby]=\"'label-' + field.property\"\r\n [attr.aria-required]=\"field.required\"\r\n [attr.aria-invalid]=\"showError(field.property)\"\r\n [attr.aria-describedby]=\"'error-' + field.property\"\r\n [required]=\"field.required\">\r\n <mat-error\r\n id=\"error-{{ field.property }}\"\r\n *ngIf=\"showError(field.property)\"\r\n aria-live=\"assertive\">\r\n {{ getErrors(field.property) | translate }}\r\n </mat-error>\r\n </mat-form-field>\r\n\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'checkbox'\">\r\n <ng-container *ngIf=\"showField(defaults, field)\">\r\n <ng-container *ngIf=\"!workflowEditableField(field)\">\r\n <ng-container\r\n [ngTemplateOutlet]=\"checkboxReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\">\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"workflowEditableField(field)\">\r\n <mat-checkbox\r\n appearance=\"outline\"\r\n style=\"padding-bottom: 14px; padding-top: 14px;\"\r\n [disabled]=\"field.readonly\"\r\n [attr.aria-required]=\"field.required\"\r\n [attr.aria-invalid]=\"showError(field.property)\"\r\n formControlName=\"{{ field.property }}\">\r\n {{ field.label! | translate }}\r\n <mat-error *ngIf=\"showError(field.property)\" aria-live=\"assertive\">\r\n {{ getErrors(field.property) | translate }}\r\n </mat-error>\r\n </mat-checkbox>\r\n\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'color-picker'\">\r\n <ng-container *ngIf=\"showField(defaults, field)\">\r\n <div fxLayout=\"row\" fxLayoutAlign=\"center\">\r\n <h4 style=\"margin-right: 10px\">{{ field.label! | translate }}</h4>\r\n <input\r\n ejs-colorpicker\r\n type=\"color\"\r\n id=\"colorpicker\"\r\n formControlName=\"{{ field.property }}\"\r\n [attr.aria-label]=\"field.label! | translate\"\r\n [attr.aria-required]=\"field.required\"\r\n [attr.aria-invalid]=\"showError(field.property)\"\r\n />\r\n </div>\r\n <mat-error *ngIf=\"showError(field.property)\" aria-live=\"assertive\">\r\n {{ getErrors(field.property) | translate }}\r\n </mat-error>\r\n </ng-container>\r\n </ng-container>\r\n\r\n\r\n <ng-container *ngSwitchCase=\"'radio-button'\">\r\n <ng-container *ngIf=\"showField(defaults, field)\">\r\n <ng-container *ngIf=\"!workflowEditableField(field)\">\r\n <ng-container\r\n [ngTemplateOutlet]=\"radioButtonReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\">\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"workflowEditableField(field)\">\r\n <mat-radio-group\r\n formControlName=\"{{field.property}}\"\r\n class=\"app-radio\"\r\n [attr.aria-label]=\"field.label! | translate\"\r\n [attr.aria-required]=\"field.required\"\r\n [attr.aria-invalid]=\"showError(field.property)\">\r\n <div class=\"field-row\">\r\n <div class=\"field-label\">\r\n <span class=\"custom-label\">{{ field.label! | translate }}</span>\r\n </div>\r\n <div class=\"field-input\">\r\n <div class=\"radio-group-custom\">\r\n <mat-radio-button\r\n *ngFor=\"let option of field.listOptions\"\r\n [value]=\"option\"\r\n [attr.aria-labelledby]=\"option\">\r\n {{ option | translate }}\r\n </mat-radio-button>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <mat-error\r\n *ngIf=\"showError(field.property)\"\r\n aria-live=\"assertive\">\r\n {{ getErrors(field.property) | translate }}\r\n </mat-error>\r\n </mat-radio-group>\r\n\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'list'\">\r\n <ng-container *ngIf=\"showField(defaults, field)\">\r\n <ng-container *ngIf=\"!workflowEditableField(field)\">\r\n <ng-container\r\n [ngTemplateOutlet]=\"listReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\">\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"workflowEditableField(field)\">\r\n <div class=\"label-and-asterisk-container\">\r\n <span *ngIf=\"!field.hideLabel\" class=\"custom-label\" id=\"label-{{field.property}}\">\r\n {{ field.label! | translate }}\r\n </span>\r\n <span *ngIf=\"field.required\" class=\"required-asterisk\"> * </span>\r\n </div>\r\n <mat-form-field appearance=\"outline\" style=\"width: 100%\">\r\n <mat-select\r\n formControlName=\"{{field.property}}\"\r\n [attr.aria-label]=\"field.label! | translate\"\r\n [attr.aria-required]=\"field.required\"\r\n [placeholder]=\"field.placeholder ? (labelKeyPlaceHolder(field) | translate) : ''\"\r\n [attr.aria-invalid]=\"showError(field.property)\"\r\n [disabled]=\"field.readonly\"\r\n [multiple]=\"field.multi || false\"\r\n [required]=\"field.readonly ? false : field.required\"\r\n [(value)]=\"field.defaultListOption\">\r\n <ng-container *ngIf=\"field.translate; else lookup_no_translation\">\r\n <mat-option\r\n *ngFor=\"let item of field.listOptions; let i = index\"\r\n [value]=\"item\">\r\n {{ friendlyName(field.label, field.property, item) | translate }}\r\n </mat-option>\r\n </ng-container>\r\n <ng-template #lookup_no_translation>\r\n <mat-option\r\n *ngFor=\"let item of field.listOptions\"\r\n [value]=\"item\">\r\n {{ getOptionValue(item) }}\r\n </mat-option>\r\n </ng-template>\r\n </mat-select>\r\n <mat-error\r\n *ngIf=\"showError(field.property)\"\r\n aria-live=\"assertive\">\r\n {{ getErrors(field.property) | translate }}\r\n </mat-error>\r\n </mat-form-field>\r\n\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'attachment'\" [formGroup]=\"formParam\">\r\n <ng-container *ngIf=\"showField(defaults, field)\">\r\n <!-- Uncomment and use the attachment control when ready -->\r\n <!-- <ag-attachment-control\r\n [allowMulti]=\"field.multi\"\r\n [attachmentDefaultExternal]=\"pageInfo?.attachmentDefaultExternal\"\r\n [supportedTypes]=\"field.supportedTypes\"\r\n [buttonType]=\"field.buttonType\"\r\n [hideListOfFiles]=\"field.hideFiles\"\r\n (filesList)=\"updateFilesList($event, field)\"\r\n (actionExecuted)=\"actionExecuted($event, field)\"\r\n style=\"margin-top: 5px\"\r\n label=\"{{field.label! | translate}}\">\r\n </ag-attachment-control> -->\r\n <mat-error class=\"iq-error\"\r\n *ngIf=\"showError(field.property)\"\r\n aria-live=\"assertive\">\r\n {{ getErrors(field.property) | translate }}\r\n </mat-error>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'lookup'\" [formGroup]=\"formParam\">\r\n <ng-container *ngIf=\"showField(defaults, field)\">\r\n <ng-container *ngIf=\"!workflowEditableField(field)\">\r\n <ng-container\r\n [ngTemplateOutlet]=\"lookupReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\">\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"workflowEditableField(field)\">\r\n <app-auto-complete\r\n [form]=\"formParam\"\r\n [field]=\"field\"\r\n [supportingAttributes]=\"supportingAttributes\"\r\n [defaultValue]=\"this.formParam.get(field.property)?.value\"\r\n (selectedValue)=\"patchLookupValue($event, field.property)\">\r\n <mat-error\r\n *ngIf=\"showError(field.property)\"\r\n aria-live=\"assertive\">\r\n {{ getErrors(field.property) | translate }}\r\n </mat-error>\r\n </app-auto-complete>\r\n\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'currency'\" [formGroup]=\"formParam\">\r\n <ng-container *ngIf=\"showField(defaults, field)\">\r\n <ng-container *ngIf=\"!workflowEditableField(field)\">\r\n <ng-container\r\n [ngTemplateOutlet]=\"currencyReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\">\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"workflowEditableField(field)\">\r\n <!-- Uncomment and use the currency control when ready -->\r\n <!-- <app-currency\r\n [form]=\"formParam\"\r\n [field]=\"field\"\r\n [defaultValue]=\"this.formParam.get(field.property)?.value\"\r\n (selectedValue)=\"patchCurrencyValue($event, field.property)\">\r\n </app-currency> -->\r\n <mat-error\r\n *ngIf=\"showError(field.property)\"\r\n aria-live=\"assertive\">\r\n {{ getErrors(field.property) | translate }}\r\n </mat-error>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'multi-select'\" [formGroup]=\"formParam\">\r\n <ng-container *ngIf=\"showField(defaults, field)\">\r\n <ng-container *ngIf=\"!workflowEditableField(field)\">\r\n <ng-container\r\n [ngTemplateOutlet]=\"multiSelectReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\">\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"workflowEditableField(field)\">\r\n <app-multi-auto-complete\r\n [form]=\"formParam\"\r\n [field]=\"field\"\r\n [defaultValue]=\"getMultiValue(field)\"\r\n (selectedValue)=\"patchMultiSelectValue($event, field.property)\">\r\n <mat-error\r\n *ngIf=\"showError(field.property)\"\r\n aria-live=\"assertive\">\r\n {{ getErrors(field.property) | translate }}\r\n </mat-error>\r\n </app-multi-auto-complete>\r\n\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n\r\n\r\n <ng-container *ngSwitchCase=\"'rich-text'\" [formGroup]=\"formParam\">\r\n <ng-container *ngIf=\"showField(defaults, field)\">\r\n <!-- Uncomment and use the rich text editor when ready -->\r\n <!-- <ckeditor\r\n [editor]=\"Editor\"\r\n [disabled]=\"field.readonly\"\r\n formControlName=\"{{field.property}}\">\r\n </ckeditor> -->\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'divider'\">\r\n <mat-divider></mat-divider>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'hyper-text'\">\r\n <div>\r\n <mat-label\r\n (click)=\"getHyperTextEvent()\"\r\n class=\"hyper-link\">\r\n {{ field.label! | translate }}\r\n </mat-label>\r\n </div>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'section-title'\">\r\n <ng-container *ngIf=\"showField(defaults, field)\">\r\n <div class=\"hrdivider-mid\">\r\n <span>{{ field.label | translate }}</span>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'equation-builder'\">\r\n <ng-container *ngIf=\"showField(defaults, field)\">\r\n <ng-container *ngIf=\"!workflowEditableField(field)\">\r\n <ng-container\r\n [ngTemplateOutlet]=\"textReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\">\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"workflowEditableField(field)\">\r\n <div class=\"label-and-asterisk-container\">\r\n <span *ngIf=\"!field.hideLabel\" class=\"custom-label\" id=\"label-{{field.property}}\">\r\n {{ field.label! | translate }}\r\n </span>\r\n <span *ngIf=\"field.required\" class=\"required-asterisk\"> * </span>\r\n </div>\r\n <mat-form-field appearance=\"outline\">\r\n <input class=\"app-input\" dir=\"ltr\"\r\n formControlName=\"{{ field.property }}\"\r\n matInput\r\n [placeholder]=\"field.placeholder ? (labelKeyPlaceHolder(field) | translate) : ''\"\r\n [readonly]=\"field.readonly\"\r\n [required]=\"field.required\"\r\n [attr.aria-required]=\"field.required\"\r\n [attr.aria-invalid]=\"showError(field.property)\"\r\n [attr.aria-labelledby]=\"'label-' + field.property\"\r\n [attr.aria-describedby]=\"'error-' + field.property\">\r\n <mat-error\r\n id=\"error-{{ field.property }}\"\r\n *ngIf=\"showError(field.property)\"\r\n aria-live=\"assertive\">\r\n {{ getErrors(field.property) | translate }}\r\n </mat-error>\r\n </mat-form-field>\r\n\r\n\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n <!-- <ng-container *ngSwitchCase=\"'equation-builder'\" [formGroup]=\"formParam\">-->\r\n <!-- <ng-container *ngIf=\"showField(defaults, field)\">-->\r\n <!-- <ng-container *ngIf=\"!workflowEditableField(field)\">-->\r\n <!-- <ng-container-->\r\n <!-- [ngTemplateOutlet]=\"dateReadonly\"-->\r\n <!-- [ngTemplateOutletContext]=\"{ field: field }\">-->\r\n <!-- </ng-container>-->\r\n <!-- </ng-container>-->\r\n <!-- <ng-container *ngIf=\"workflowEditableField(field)\">-->\r\n <!-- <div style=\"display: flex; width: 350%\">-->\r\n <!-- <mat-label>{{ field.label! | translate }}</mat-label>-->\r\n <!-- <mat-form-field style=\"width: 400%\" appearance=\"outline\">-->\r\n <!-- <mat-chip-grid #chipGrid>-->\r\n <!-- <ng-container *ngFor=\"let equationValue of equationValues(); let i = index\">-->\r\n <!-- <mat-chip-row (removed)=\"remove(equationValue, i)\">-->\r\n <!-- {{ equationValue }}-->\r\n <!-- <button-->\r\n <!-- matChipRemove-->\r\n <!-- [attr.aria-label]=\"'remove ' + equationValue\">-->\r\n <!-- <mat-icon>cancel</mat-icon>-->\r\n <!-- </button>-->\r\n <!-- </mat-chip-row>-->\r\n <!-- </ng-container>-->\r\n <!-- </mat-chip-grid>-->\r\n <!-- <input-->\r\n <!-- [(ngModel)]=\"currentEquationValue\"-->\r\n <!-- [matChipInputFor]=\"chipGrid\"-->\r\n <!-- [matAutocomplete]=\"auto\"-->\r\n <!-- [ngModelOptions]=\"{ standalone: true }\"-->\r\n <!-- [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\"-->\r\n <!-- (matChipInputTokenEnd)=\"add($event)\"-->\r\n <!-- aria-label=\"Add equation value\" />-->\r\n <!-- <mat-autocomplete #auto=\"matAutocomplete\" (optionSelected)=\"selected($event)\">-->\r\n <!-- <ng-container *ngFor=\"let filteredField of (equationFilteredFields() | async)\">-->\r\n <!-- <mat-option [value]=\"filteredField\">{{ filteredField }}</mat-option>-->\r\n <!-- </ng-container>-->\r\n <!-- </mat-autocomplete>-->\r\n <!-- </mat-form-field>-->\r\n <!-- </div>-->\r\n <!-- <mat-error class=\"iq-error\" *ngIf=\"showError(field.property)\" aria-live=\"assertive\">-->\r\n <!-- {{ getErrors(field.property) | translate }}-->\r\n <!-- </mat-error>-->\r\n <!-- </ng-container>-->\r\n <!-- </ng-container>-->\r\n <!-- </ng-container>-->\r\n\r\n </ng-container>\r\n </div>\r\n </ng-container>\r\n </div>\r\n </ng-container>\r\n </div>\r\n </div>\r\n </form>\r\n </ng-container>\r\n </ng-container>\r\n </div>\r\n\r\n</div>\r\n<ng-template #dateReadonly let-field=\"field\">\r\n <div class=\"readonly-item\">\r\n <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n <span class=\"readonly-value\">{{ extractFieldName(defaults, field.property) | date: 'dd/MM/yyyy' }}</span>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #timeReadonly let-field=\"field\">\r\n <div class=\"readonly-item\">\r\n <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n <span class=\"readonly-value\">{{ formatTimeToDate(defaults[field.property]) | date: 'shortTime' }}</span>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #phoneNumberReadonly let-field=\"field\">\r\n <div class=\"readonly-item\">\r\n <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n <span class=\"readonly-value\">{{ extractFieldName(defaults, field.property) }}</span>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #textReadonly let-field=\"field\">\r\n <div class=\"readonly-item\">\r\n <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\" *ngIf=\"!field.advancedFilter\"></label>\r\n <span class=\"readonly-value\">{{ extractFieldName(defaults, field.property) }}</span>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #textareaReadonly let-field=\"field\">\r\n <ng-container *ngIf=\"field.textFormat === 'json'; else normalText\">\r\n <div class=\"readonly-item\">\r\n <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n <div class=\"readonly-value json-viewer\">\r\n <ngx-json-viewer [json]=\"extractJsonFieldName(defaults, field.property)\" [expanded]=\"true\"></ngx-json-viewer>\r\n </div>\r\n </div>\r\n </ng-container>\r\n <ng-template #normalText>\r\n <div class=\"readonly-item\">\r\n <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n <span class=\"readonly-value\">{{ extractFieldName(defaults, field.property) }}</span>\r\n </div>\r\n </ng-template>\r\n</ng-template>\r\n\r\n<ng-template #numberReadonly let-field=\"field\">\r\n <div class=\"readonly-item\">\r\n <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n <span class=\"readonly-value\">{{ extractFieldName(defaults, field.property) }}</span>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #currencyReadonly let-field=\"field\">\r\n <div class=\"readonly-item\">\r\n <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n <span class=\"readonly-value\">{{ extractFieldName(defaults, field.property) }}</span>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #radioButtonReadonly let-field=\"field\">\r\n <div class=\"readonly-item\">\r\n <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n <span class=\"readonly-value\">{{ translateLable(defaults[field.property]) }}</span>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #richTextReadonly let-field=\"field\">\r\n <div class=\"readonly-item\">\r\n <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n <span class=\"readonly-value\" [innerHtml]=\"extractFieldName(defaults, field.property)\"></span>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #checkboxReadonly let-field=\"field\">\r\n <div class=\"readonly-item\">\r\n <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n <span class=\"readonly-value\">\r\n <mat-icon color=\"warn\" *ngIf=\"extractFieldName(defaults, field.property); else showNo\">done</mat-icon>\r\n <ng-template #showNo>\r\n <mat-icon color=\"warn\">close</mat-icon>\r\n </ng-template>\r\n </span>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #listReadonly let-field=\"field\">\r\n <div class=\"readonly-item\">\r\n <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n <span class=\"readonly-value\" *ngIf=\"field.translate; else noTranslate\">\r\n {{ listShowValue(defaults, field) | translate }}\r\n </span>\r\n <ng-template #noTranslate>\r\n <span class=\"readonly-value\">{{ extractFieldName(defaults, field.property) }}</span>\r\n </ng-template>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #sequenceReadonly let-field=\"field\">\r\n <div class=\"readonly-item\">\r\n <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n <span class=\"readonly-value\">{{ extractFieldName(defaults, field.property) }}</span>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #lookupReadonly let-field=\"field\">\r\n <div class=\"readonly-item\">\r\n <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n <span class=\"readonly-value\">\r\n {{ extractFieldName(defaults, field.property)?.[translateService.getDefaultLang() === 'en' ? 'englishName' : 'arabicName'] }}\r\n </span>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #amountReadonly let-field=\"field\">\r\n <div class=\"readonly-item\">\r\n <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n <span class=\"readonly-value\">\r\n {{ extractFieldName(defaults, field.property) | currency: currency }}\r\n </span>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #multiSelectReadonly let-field=\"field\">\r\n <div class=\"readonly-item\">\r\n <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n <mat-chip-grid class=\"readonly-value chipList\">\r\n <mat-chip *ngFor=\"let filedProp of showMultiSelectValuesAsReadonly(field)\">\r\n {{ filedProp }}\r\n </mat-chip>\r\n </mat-chip-grid>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #chipListReadonly let-field=\"field\">\r\n <div class=\"readonly-item\">\r\n <label class=\"readonly-label\" [innerHTML]=\"field.label | translate\"></label>\r\n <mat-chip-listbox class=\"readonly-value chipList\">\r\n <mat-chip-option *ngFor=\"let loc of splitReadonly(extractFieldName(defaults, field.property))\"\r\n [selectable]=\"true\"\r\n color=\"warn\"\r\n [removable]=\"false\">\r\n {{ loc }}\r\n </mat-chip-option>\r\n </mat-chip-listbox>\r\n </div>\r\n</ng-template>\r\n\r\n\r\n<ng-template #readonlyView>\r\n <div class=\"row-wrapper\">\r\n <div class=\"column-wrapper\">\r\n <ng-container *ngFor=\"let row of screenFields | keyvalue\">\r\n <div class=\"row-container\">\r\n <ng-container *ngFor=\"let field of row.value\">\r\n <div class=\"field-column readonly-item\" [style.flex]=\"field.fieldSize ? ('0 0 ' + field.fieldSize + '%') : '1 1 0'\">\r\n\r\n <ng-container [ngSwitch]=\"field.type\">\r\n\r\n <ng-container *ngSwitchCase=\"'date'\">\r\n <ng-container [ngTemplateOutlet]=\"dateReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'time'\">\r\n <ng-container [ngTemplateOutlet]=\"timeReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'phone-number'\">\r\n <ng-container [ngTemplateOutlet]=\"phoneNumberReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'text'\">\r\n <ng-container [ngTemplateOutlet]=\"textReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'textarea'\">\r\n <ng-container [ngTemplateOutlet]=\"textareaReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'number'\">\r\n <ng-container [ngTemplateOutlet]=\"numberReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'currency'\">\r\n <ng-container [ngTemplateOutlet]=\"currencyReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'radio-button'\">\r\n <ng-container [ngTemplateOutlet]=\"radioButtonReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'checkbox'\">\r\n <ng-container [ngTemplateOutlet]=\"checkboxReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'status'\">\r\n <ng-container [ngTemplateOutlet]=\"checkboxReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'lookup'\">\r\n <ng-container [ngTemplateOutlet]=\"lookupReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'amount'\">\r\n <ng-container [ngTemplateOutlet]=\"amountReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'multi-select'\">\r\n <ng-container [ngTemplateOutlet]=\"multiSelectReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'chip-list'\">\r\n <ng-container [ngTemplateOutlet]=\"chipListReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'sequence'\">\r\n <ng-container [ngTemplateOutlet]=\"sequenceReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'list'\">\r\n <ng-container [ngTemplateOutlet]=\"listReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'iban-text'\">\r\n <p class=\"label\">\r\n <span [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></span>\r\n <span> : </span>\r\n <span class=\"value\" [innerHtml]=\"extractFieldName(defaults, field.property)\"></span>\r\n </p>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'section-title'\">\r\n <div class=\"hrdivider-mid\">\r\n <span>{{ field.label | translate }}</span>\r\n </div>\r\n </ng-container>\r\n\r\n </ng-container>\r\n </div>\r\n </ng-container>\r\n </div>\r\n </ng-container>\r\n </div>\r\n </div>\r\n</ng-template>\r\n\r\n\r\n", styles: [".main-form-canvas{display:flex;flex-direction:row;gap:10px;align-items:flex-start;justify-content:flex-start;margin-top:3vh;width:100%;flex-wrap:wrap}.form-wrapper{display:flex;flex-direction:column;flex:1}.form-container{display:flex;flex-direction:column;width:100%}.row-container{display:flex;flex-direction:row;gap:20px;flex-wrap:wrap;width:100%}.field-column{display:flex;flex-direction:column;flex:1}.label-and-asterisk-container{display:flex;align-items:center;gap:2px}.full-width{width:100%}.readonly-item{display:flex;flex-direction:column;align-items:flex-start;gap:2px;font-size:14px;padding:4px 0;width:100%}.readonly-item .readonly-label{font-weight:500;color:#9b9b9b;font-size:14px}.readonly-item .readonly-value{font-weight:500;color:#222;word-break:break-word;font-size:14px}.readonly-item .json-viewer{width:100%}.readonly-item .chipList{display:flex;flex-wrap:wrap;gap:4px}.readonly-item mat-icon{font-size:18px;vertical-align:middle}.row-wrapper{display:flex;flex-direction:row;gap:20px;width:100%;flex-wrap:wrap}.column-wrapper{display:flex;flex-direction:column;width:100%;align-items:flex-start}.row-container{display:flex;flex-direction:row;gap:20px;width:100%;flex-wrap:wrap}.field-column{display:flex;flex-direction:column;min-width:50px!important}.field-row{display:flex;flex-direction:row;gap:10px;width:100%;align-items:flex-start}.field-label{flex:0 0 40%;display:flex;flex-direction:column;justify-content:center}.field-input{flex:0 0 60%;display:flex;flex-direction:column}.radio-group-custom{display:flex;flex-direction:row;flex-wrap:wrap;gap:10px}@media (max-width: 600px){.main-form-canvas{flex-direction:column;align-items:center}.row-container{flex-direction:column;gap:10px}.field-column{width:100%;flex:1 1 100%!important}.column-wrapper{align-items:center}.field-row{flex-direction:column}.field-label,.field-input{flex:1 1 100%}.radio-group-custom{flex-direction:column;gap:5px}}.custom-ngx-mat-intl-tel-input[readonly] input,.custom-ngx-mat-intl-tel-input.ngx-mat-intl-tel-input input[disabled]{pointer-events:none!important;background-color:#f5f5f5!important;color:#444!important}.custom-ngx-mat-intl-tel-input .iti__flag-container,.custom-ngx-mat-intl-tel-input .iti__selected-flag{pointer-events:none!important;opacity:.6}.custom-ngx-mat-intl-tel-input{pointer-events:none!important}@media (max-width: 960px){.row-wrapper,.row-container{flex-direction:column}.row-container{gap:15px}.field-column{flex:1 1 100%!important}}\n"], dependencies: [{ kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i4.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { 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.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { 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.PatternValidator, selector: "[pattern][formControlName],[pattern][formControl],[pattern][ngModel]", inputs: ["pattern"] }, { kind: "directive", type: i4.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i4.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "pipe", type: KeyValuePipe, name: "keyvalue" }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: MatLabel, selector: "mat-label" }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i6.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i6.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i6.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "directive", type: i7.Dir, selector: "[dir]", inputs: ["dir"], outputs: ["dirChange"], exportAs: ["dir"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i8.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: "directive", type: i9.CdkTextareaAutosize, selector: "textarea[cdkTextareaAutosize]", inputs: ["cdkAutosizeMinRows", "cdkAutosizeMaxRows", "cdkTextareaAutosize", "placeholder"], exportAs: ["cdkTextareaAutosize"] }, { kind: "directive", type: MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "component", type: MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { kind: "directive", type: NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "component", type: MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: MatChip, selector: "mat-basic-chip, [mat-basic-chip], mat-chip, [mat-chip]", inputs: ["role", "id", "aria-label", "aria-description", "value", "color", "removable", "highlighted", "disableRipple", "disabled", "tabIndex"], outputs: ["removed", "destroyed"], exportAs: ["matChip"] }, { kind: "directive", type: MatRadioGroup, selector: "mat-radio-group", inputs: ["color", "name", "labelPosition", "value", "selected", "disabled", "required"], outputs: ["change"], exportAs: ["matRadioGroup"] }, { kind: "component", type: MatCheckbox, selector: "mat-checkbox", inputs: ["aria-label", "aria-labelledby", "aria-describedby", "id", "required", "labelPosition", "name", "value", "disableRipple", "tabIndex", "color", "checked", "disabled", "indeterminate"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }, { kind: "component", type: MatRadioButton, selector: "mat-radio-button", inputs: ["id", "name", "aria-label", "aria-labelledby", "aria-describedby", "disableRipple", "tabIndex", "checked", "value", "labelPosition", "disabled", "required", "color"], outputs: ["change"], exportAs: ["matRadioButton"] }, { kind: "component", type: MatSelect, selector: "mat-select", inputs: ["aria-describedby", "panelClass", "disabled", "disableRipple", "tabIndex", "hideSingleSelectionIndicator", "placeholder", "required", "multiple", "disableOptionCentering", "compareWith", "value", "aria-label", "aria-labelledby", "errorStateMatcher", "typeaheadDebounceInterval", "sortComparator", "id", "panelWidth"], outputs: ["openedChange", "opened", "closed", "selectionChange", "valueChange"], exportAs: ["matSelect"] }, { kind: "component", type: MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "component", type: MatDivider, selector: "mat-divider", inputs: ["vertical", "inset"] }, { kind: "pipe", type: DatePipe, name: "date" }, { kind: "ngmodule", type: NgxJsonViewerModule }, { kind: "component", type: i10.NgxJsonViewerComponent, selector: "ngx-json-viewer", inputs: ["json", "expanded", "depth", "_currentDepth"] }, { kind: "pipe", type: CurrencyPipe, name: "currency" }, { kind: "ngmodule", type: CKEditorModule }, { kind: "component", type: NgxMatIntlTelInputComponent, selector: "ngx-mat-intl-tel-input", inputs: ["preferredCountries", "enablePlaceholder", "inputPlaceholder", "cssClass", "name", "onlyCountries", "errorStateMatcher", "enableSearch", "searchPlaceholder", "describedBy", "format", "placeholder", "required", "disabled"], outputs: ["countryChanged"] }, { kind: "component", type: MatChipGrid, selector: "mat-chip-grid", inputs: ["disabled", "placeholder", "required", "value", "errorStateMatcher"], outputs: ["change", "valueChange"] }, { kind: "directive", type: MatChipInput, selector: "input[matChipInputFor]", inputs: ["matChipInputFor", "matChipInputAddOnBlur", "matChipInputSeparatorKeyCodes", "placeholder", "id", "disabled"], outputs: ["matChipInputTokenEnd"], exportAs: ["matChipInput", "matChipInputFor"] }, { kind: "component", type: MatChipRow, selector: "mat-chip-row, [mat-chip-row], mat-basic-chip-row, [mat-basic-chip-row]", inputs: ["editable"], outputs: ["edited"] }, { kind: "component", type: MatChipListbox, selector: "mat-chip-listbox", inputs: ["multiple", "aria-orientation", "selectable", "compareWith", "required", "hideSingleSelectionIndicator", "value"], outputs: ["change"] }, { kind: "component", type: MatChipOption, selector: "mat-basic-chip-option, [mat-basic-chip-option], mat-chip-option, [mat-chip-option]", inputs: ["selectable", "selected"], outputs: ["selectionChange"] }, { kind: "component", type: MultiAutoCompleteComponent, selector: "app-multi-auto-complete", inputs: ["field", "form", "defaultValue", "pathParam", "readonly"], outputs: ["selectedValue"] }, { kind: "component", type: AutoCompleteComponent, selector: "app-auto-complete", inputs: ["field", "form", "defaultValue", "readonly", "supportingAttributes"], outputs: ["selectedValue"] }, { kind: "directive", type: MatChipRemove, selector: "[matChipRemove]" }] }); }
|
|
497
|
+
}
|
|
498
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: BaseFormCanvasComponent, decorators: [{
|
|
499
|
+
type: Component,
|
|
500
|
+
args: [{ selector: 'app-base-form-canvas', standalone: true, imports: [
|
|
501
|
+
ReactiveFormsModule,
|
|
502
|
+
NgSwitch,
|
|
503
|
+
FormsModule,
|
|
504
|
+
NgForOf,
|
|
505
|
+
NgTemplateOutlet,
|
|
506
|
+
KeyValuePipe,
|
|
507
|
+
NgIf,
|
|
508
|
+
MatLabel,
|
|
509
|
+
MatFormFieldModule,
|
|
510
|
+
TranslateModule,
|
|
511
|
+
MatInputModule,
|
|
512
|
+
MatDatepickerInput,
|
|
513
|
+
MatDatepicker,
|
|
514
|
+
MatDatepickerToggle,
|
|
515
|
+
MatError,
|
|
516
|
+
NgSwitchCase,
|
|
517
|
+
MatIcon,
|
|
518
|
+
MatAutocomplete,
|
|
519
|
+
MatAutocompleteTrigger,
|
|
520
|
+
MatChip,
|
|
521
|
+
CdkTextareaAutosize,
|
|
522
|
+
MatRadioGroup,
|
|
523
|
+
MatCheckbox,
|
|
524
|
+
MatRadioButton,
|
|
525
|
+
MatSelect,
|
|
526
|
+
MatOption,
|
|
527
|
+
MatDivider,
|
|
528
|
+
DatePipe,
|
|
529
|
+
NgxJsonViewerModule,
|
|
530
|
+
CurrencyPipe,
|
|
531
|
+
CKEditorModule,
|
|
532
|
+
NgxMatIntlTelInputComponent,
|
|
533
|
+
MatChipGrid,
|
|
534
|
+
MatChipInput,
|
|
535
|
+
MatChipRow,
|
|
536
|
+
MatChipListbox,
|
|
537
|
+
MatChipOption,
|
|
538
|
+
MultiAutoCompleteComponent,
|
|
539
|
+
AutoCompleteComponent,
|
|
540
|
+
MatDateRangeInput,
|
|
541
|
+
AsyncPipe,
|
|
542
|
+
MatChipRemove,
|
|
543
|
+
MatCell,
|
|
544
|
+
MatCellDef,
|
|
545
|
+
MatHeaderCell,
|
|
546
|
+
MatHeaderCellDef,
|
|
547
|
+
NgStyle
|
|
548
|
+
], providers: [
|
|
549
|
+
{
|
|
550
|
+
provide: DateAdapter,
|
|
551
|
+
useClass: MomentDateAdapter,
|
|
552
|
+
deps: [MAT_DATE_LOCALE, MAT_MOMENT_DATE_ADAPTER_OPTIONS]
|
|
553
|
+
},
|
|
554
|
+
{ provide: MAT_DATE_FORMATS, useValue: DD_MM_YYYY_Format },
|
|
555
|
+
{ provide: MAT_DATE_LOCALE, useValue: 'en-GB' }
|
|
556
|
+
], template: "<div class=\"main-form-canvas\">\r\n <div class=\"form-wrapper\">\r\n <ng-container *ngIf=\"defaults\">\r\n <ng-container *ngIf=\"editable; else readonlyView\" class=\"form-container\">\r\n <form [formGroup]=\"formParam\" class=\"form-content\">\r\n <div class=\"form-row\">\r\n <div class=\"form-column\">\r\n <ng-container *ngFor=\"let row of screenFields | keyvalue\">\r\n <div class=\"row-container\">\r\n <ng-container *ngFor=\"let field of row.value\">\r\n <div class=\"field-column\" [style.flex]=\"field.fieldSize ? ('0 0 ' + field.fieldSize + '%') : '1 1 0'\">\r\n <ng-container [ngSwitch]=\"field.type\">\r\n <ng-container *ngSwitchCase=\"'date'\">\r\n <ng-container *ngIf=\"showField(defaults, field)\">\r\n <ng-container *ngIf=\"workflowEditableField(field)\">\r\n <div class=\"label-and-asterisk-container\">\r\n <span *ngIf=\"!field.hideLabel\" class=\"custom-label\" id=\"label-{{field.property}}\">\r\n {{ field.label! | translate }}\r\n </span>\r\n <span *ngIf=\"field.required\" class=\"required-asterisk\"> * </span>\r\n </div>\r\n\r\n <mat-form-field appearance=\"outline\">\r\n <input matInput\r\n [matDatepicker]=\"picker\"\r\n [value]=\"formParam.get(field.property)?.value\"\r\n (dateChange)=\"formParam.get(field.property).setValue($event.value)\"\r\n [placeholder]=\"field.placeholder ? (labelKeyPlaceHolder(field) | translate) : ''\"\r\n [readonly]=\"field.readonly\"\r\n formControlName=\"{{field.property}}\"\r\n [required]=\"field.required\"\r\n [attr.aria-invalid]=\"showError(field.property)\"\r\n [attr.aria-labelledby]=\"'label-' + field.property\"\r\n [attr.aria-describedby]=\"'error-' + field.property\">\r\n\r\n <mat-datepicker-toggle matSuffix [for]=\"picker\"></mat-datepicker-toggle>\r\n\r\n <mat-datepicker #picker\r\n [startView]=\"getView(field)\"\r\n (yearSelected)=\"setMonthAndYear($event, picker, field)\"\r\n panelClass=\"example-month-picker\">\r\n </mat-datepicker>\r\n\r\n <mat-error *ngIf=\"showError(field.property)\" aria-live=\"assertive\">\r\n {{ getErrors(field.property) | translate }}\r\n </mat-error>\r\n </mat-form-field>\r\n\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'phone-number'\">\r\n <ng-container *ngIf=\"showField(defaults, field)\">\r\n <ng-container class=\"custom-ngx-mat-intl-tel-input\" *ngIf=\"workflowEditableField(field)\">\r\n <div class=\"label-and-asterisk-container\">\r\n <span *ngIf=\"!field.hideLabel\" class=\"custom-label\" id=\"label-{{field.property}}\">\r\n {{ field.label! | translate }}\r\n </span>\r\n <span *ngIf=\"field.required\" class=\"required-asterisk\"> * </span>\r\n </div>\r\n <mat-form-field appearance=\"outline\">\r\n <div class=\"phone-input-wrapper\">\r\n <ngx-mat-intl-tel-input\r\n formControlName=\"{{ field.property }}\"\r\n [inputPlaceholder]=\"field.placeholder ? (labelKeyPlaceHolder(field) | translate) : ''\"\r\n [preferredCountries]=\"['qa']\"\r\n [enablePlaceholder]=\"true\"\r\n [enableSearch]=\"true\"\r\n [onlyCountries]=\"getCountryCodeList()\"\r\n [required]=\"field.required\"\r\n [attr.aria-required]=\"field.required\"\r\n [attr.aria-invalid]=\"showError(field.property)\"\r\n [attr.aria-labelledby]=\"'label-' + field.property\"\r\n [attr.aria-describedby]=\"'error-' + field.property\">\r\n </ngx-mat-intl-tel-input>\r\n </div>\r\n\r\n <mat-error\r\n id=\"error-{{ field.property }}\"\r\n *ngIf=\"showError(field.property)\"\r\n aria-live=\"assertive\">\r\n {{ getErrors(field.property) | translate }}\r\n </mat-error>\r\n </mat-form-field>\r\n\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n\r\n\r\n <ng-container *ngSwitchCase=\"'iban-text'\">\r\n <ng-container *ngIf=\"showField(defaults, field)\">\r\n <ng-container *ngIf=\"!workflowEditableField(field)\">\r\n <ng-container\r\n [ngTemplateOutlet]=\"textReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\">\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"workflowEditableField(field)\">\r\n <div class=\"label-and-asterisk-container\">\r\n <span *ngIf=\"!field.hideLabel\" class=\"custom-label\" id=\"label-{{field.property}}\">\r\n {{ field.label! | translate }}\r\n </span>\r\n <span *ngIf=\"field.required\" class=\"required-asterisk\"> * </span>\r\n </div>\r\n <mat-form-field appearance=\"outline\">\r\n <input class=\"app-input\"\r\n formControlName=\"{{ field.property }}\"\r\n matInput\r\n [placeholder]=\"field.placeholder ? (labelKeyPlaceHolder(field) | translate) : ''\"\r\n [readonly]=\"field.readonly\"\r\n [required]=\"field.required\"\r\n [attr.aria-required]=\"field.required\"\r\n [attr.aria-invalid]=\"showError(field.property)\"\r\n [attr.aria-labelledby]=\"'label-' + field.property\"\r\n [attr.aria-describedby]=\"'error-' + field.property\">\r\n <mat-error\r\n id=\"error-{{ field.property }}\"\r\n *ngIf=\"showError(field.property)\"\r\n aria-live=\"assertive\">\r\n {{ getErrors(field.property) | translate }}\r\n </mat-error>\r\n </mat-form-field>\r\n\r\n\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'password'\">\r\n <ng-container *ngIf=\"showField(defaults, field)\">\r\n <div class=\"label-and-asterisk-container\">\r\n <span *ngIf=\"!field.hideLabel\" class=\"custom-label\" id=\"label-{{field.property}}\">\r\n {{ field.label! | translate }}\r\n </span>\r\n <span *ngIf=\"field.required\" class=\"required-asterisk\"> * </span>\r\n </div>\r\n <mat-form-field appearance=\"outline\">\r\n <input matInput\r\n class=\"app-input\"\r\n formControlName=\"{{ field.property }}\"\r\n [type]=\"hide && !field.disabled ? 'password' : 'text'\"\r\n [readonly]=\"field.readonly\"\r\n [required]=\"field.required\"\r\n [placeholder]=\"field.placeholder ? (labelKeyPlaceHolder(field) | translate) : ''\"\r\n [attr.aria-required]=\"field.required\"\r\n [attr.aria-invalid]=\"showError(field.property)\"\r\n [attr.aria-labelledby]=\"'label-' + field.property\"\r\n [attr.aria-describedby]=\"'error-' + field.property\">\r\n <!-- <mat-icon matSuffix-->\r\n <!-- (click)=\"hide = !hide\">-->\r\n <!-- {{ hide ? 'visibility_off' : 'visibility' }}-->\r\n <!-- </mat-icon>-->\r\n <mat-error\r\n id=\"error-{{ field.property }}\"\r\n *ngIf=\"showError(field.property)\"\r\n aria-live=\"assertive\">\r\n {{ getErrors(field.property) | translate }}\r\n </mat-error>\r\n </mat-form-field>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'text'\">\r\n <ng-container *ngIf=\"showField(defaults, field)\">\r\n <ng-container *ngIf=\"!workflowEditableField(field)\">\r\n <ng-container\r\n [ngTemplateOutlet]=\"textReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\">\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"workflowEditableField(field)\">\r\n <div class=\"label-and-asterisk-container\">\r\n <span *ngIf=\"!field.hideLabel\" class=\"custom-label\" id=\"label-{{field.property}}\">\r\n {{ field.label! | translate }}\r\n </span>\r\n <span *ngIf=\"field.required\" class=\"required-asterisk\"> * </span>\r\n </div>\r\n <mat-form-field appearance=\"outline\">\r\n <input class=\"app-input\"\r\n formControlName=\"{{ field.property }}\"\r\n matInput\r\n [placeholder]=\"field.placeholder ? (labelKeyPlaceHolder(field) | translate) : ''\"\r\n [readonly]=\"field.readonly\"\r\n [required]=\"field.required\"\r\n (keyup)=\"fixArabicNumbers($event.target)\"\r\n [attr.aria-required]=\"field.required\"\r\n [attr.aria-invalid]=\"showError(field.property)\"\r\n [attr.aria-labelledby]=\"'label-' + field.property\"\r\n [attr.aria-describedby]=\"'error-' + field.property\">\r\n <mat-error\r\n id=\"error-{{ field.property }}\"\r\n *ngIf=\"showError(field.property)\"\r\n aria-live=\"assertive\">\r\n {{ getErrors(field.property) | translate }}\r\n </mat-error>\r\n </mat-form-field>\r\n\r\n\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'chip-list'\">\r\n <ng-container *ngIf=\"showField(defaults, field)\">\r\n <div class=\"label-and-asterisk-container\">\r\n <span *ngIf=\"!field.hideLabel\" class=\"custom-label\" id=\"label-{{field.property}}\">\r\n {{ field.label! | translate }}\r\n </span>\r\n <span *ngIf=\"field.required\" class=\"required-asterisk\"> * </span>\r\n </div>\r\n <mat-form-field appearance=\"outline\">\r\n\r\n <mat-chip-grid [attr.aria-labelledby]=\"'label-' + field.property\"\r\n formControlName=\"{{ field.property }}\">\r\n <mat-chip-row\r\n *ngFor=\"let mail of splittedChips(formParam, field.property); let idx = index\"\r\n [removable]=\"removable\"\r\n (removed)=\"removeChipsItem(formParam, field.property, idx)\">\r\n {{ mail }}\r\n <mat-icon matChipRemove *ngIf=\"removable\">cancel</mat-icon>\r\n </mat-chip-row>\r\n\r\n <input [attr.aria-labelledby]=\"'label-' + field.property\" [matChipInputFor]=\"null\"\r\n [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\"\r\n [matChipInputAddOnBlur]=\"addOnBlur\"\r\n (matChipInputTokenEnd)=\"addEmailToChips($event, formParam, field.property)\">\r\n </mat-chip-grid>\r\n <mat-error id=\"error-{{ field.property }}\" *ngIf=\"showError(field.property)\"\r\n aria-live=\"assertive\">\r\n {{ getErrors(field.property) | translate }}\r\n </mat-error>\r\n </mat-form-field>\r\n\r\n\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'amount'\">\r\n <ng-container *ngIf=\"showField(defaults, field)\">\r\n <ng-container *ngIf=\"!workflowEditableField(field)\">\r\n <ng-container\r\n [ngTemplateOutlet]=\"amountReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\">\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"workflowEditableField(field)\">\r\n <div class=\"label-and-asterisk-container\">\r\n <span *ngIf=\"!field.hideLabel\" class=\"custom-label\" id=\"label-{{field.property}}\">\r\n {{ field.label! | translate }}\r\n </span>\r\n <span *ngIf=\"field.required\" class=\"required-asterisk\"> * </span>\r\n </div>\r\n <mat-form-field appearance=\"outline\">\r\n <input class=\"app-input\"\r\n formControlName=\"{{ field.property }}\"\r\n matInput\r\n type=\"number\"\r\n [placeholder]=\"field.placeholder ? (labelKeyPlaceHolder(field) | translate) : ''\"\r\n [readonly]=\"field.readonly\"\r\n [required]=\"field.required\"\r\n [attr.aria-required]=\"field.required\"\r\n [attr.aria-invalid]=\"showError(field.property)\"\r\n [attr.aria-labelledby]=\"'label-' + field.property\"\r\n [attr.aria-describedby]=\"'error-' + field.property\">\r\n <mat-error\r\n id=\"error-{{ field.property }}\"\r\n *ngIf=\"showError(field.property)\"\r\n aria-live=\"assertive\">\r\n {{ getErrors(field.property) | translate }}\r\n </mat-error>\r\n </mat-form-field>\r\n\r\n\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'sequence'\">\r\n <ng-container\r\n *ngIf=\"referenceAttributeTrue(field.property, 'autoGenerated'); else noSequence\">\r\n <div class=\"label-and-asterisk-container\">\r\n <span *ngIf=\"!field.hideLabel\" class=\"custom-label\" id=\"label-{{field.property}}\">\r\n {{ field.label! | translate }}\r\n </span>\r\n <span *ngIf=\"field.required\" class=\"required-asterisk\"> * </span>\r\n </div>\r\n <mat-form-field appearance=\"outline\">\r\n <input class=\"app-input\"\r\n formControlName=\"{{ field.property }}\"\r\n matInput\r\n [placeholder]=\"field.placeholder ? (labelKeyPlaceHolder(field) | translate) : ''\"\r\n [readonly]=\"true\"\r\n [disabled]=\"true\"\r\n [attr.aria-labelledby]=\"'label-' + field.property\">\r\n <mat-error\r\n id=\"error-{{ field.property }}\"\r\n *ngIf=\"showError(field.property)\"\r\n aria-live=\"assertive\">\r\n {{ getErrors(field.property) | translate }}\r\n </mat-error>\r\n </mat-form-field>\r\n\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-template #noSequence>\r\n <div class=\"label-and-asterisk-container\">\r\n <span *ngIf=\"!field.hideLabel\" class=\"custom-label\" id=\"label-{{field.property}}\">\r\n {{ field.label! | translate }}\r\n </span>\r\n <span *ngIf=\"field.required\" class=\"required-asterisk\"> * </span>\r\n </div>\r\n <mat-form-field appearance=\"outline\">\r\n <input class=\"app-input\"\r\n formControlName=\"{{ field.property }}\"\r\n matInput\r\n [readonly]=\"false\"\r\n [disabled]=\"false\"\r\n [placeholder]=\"field.placeholder ? (labelKeyPlaceHolder(field) | translate) : ''\"\r\n [required]=\"field.required\"\r\n [attr.aria-labelledby]=\"'label-' + field.property\"\r\n [attr.aria-required]=\"field.required\"\r\n [attr.aria-invalid]=\"showError(field.property)\"\r\n [attr.aria-describedby]=\"'error-' + field.property\">\r\n <mat-error\r\n id=\"error-{{ field.property }}\"\r\n *ngIf=\"showError(field.property)\"\r\n aria-live=\"assertive\">\r\n {{ getErrors(field.property) | translate }}\r\n </mat-error>\r\n </mat-form-field>\r\n\r\n </ng-template>\r\n\r\n <ng-container *ngSwitchCase=\"'textarea'\">\r\n <ng-container *ngIf=\"showField(defaults, field)\">\r\n <ng-container *ngIf=\"!workflowEditableField(field)\">\r\n <ng-container\r\n [ngTemplateOutlet]=\"textareaReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\">\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"workflowEditableField(field)\">\r\n <div class=\"label-and-asterisk-container\">\r\n <span *ngIf=\"!field.hideLabel\" class=\"custom-label\" id=\"label-{{field.property}}\">\r\n {{ field.label! | translate }}\r\n </span>\r\n <span *ngIf=\"field.required\" class=\"required-asterisk\"> * </span>\r\n </div>\r\n <mat-form-field appearance=\"outline\">\r\n <textarea cdkFocusInitial\r\n formControlName=\"{{ field.property }}\"\r\n matInput\r\n cdkTextareaAutosize\r\n cdkAutosizeMinRows=\"3\"\r\n [placeholder]=\"field.placeholder ? (labelKeyPlaceHolder(field) | translate) : ''\"\r\n [attr.aria-labelledby]=\"'label-' + field.property\"\r\n [attr.aria-required]=\"field.required\"\r\n [attr.aria-invalid]=\"showError(field.property)\"\r\n [attr.aria-describedby]=\"'error-' + field.property\"\r\n [readonly]=\"field.readonly\"\r\n [required]=\"field.required\"></textarea>\r\n <mat-error\r\n id=\"error-{{ field.property }}\"\r\n *ngIf=\"showError(field.property)\"\r\n aria-live=\"assertive\">\r\n {{ getErrors(field.property) | translate }}\r\n </mat-error>\r\n </mat-form-field>\r\n\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'number'\">\r\n <ng-container *ngIf=\"showField(defaults, field)\">\r\n <ng-container *ngIf=\"!workflowEditableField(field)\">\r\n <ng-container\r\n [ngTemplateOutlet]=\"numberReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\">\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"workflowEditableField(field)\">\r\n <div class=\"label-and-asterisk-container\">\r\n <span *ngIf=\"!field.hideLabel\" class=\"custom-label\" id=\"label-{{field.property}}\">\r\n {{ field.label! | translate }}\r\n </span>\r\n <span *ngIf=\"field.required\" class=\"required-asterisk\"> * </span>\r\n </div>\r\n <mat-form-field appearance=\"outline\">\r\n <input class=\"app-input\"\r\n formControlName=\"{{ field.property }}\"\r\n matInput\r\n type=\"number\"\r\n [placeholder]=\"field.placeholder ? (labelKeyPlaceHolder(field) | translate) : ''\"\r\n [attr.aria-labelledby]=\"'label-' + field.property\"\r\n [attr.aria-required]=\"field.required\"\r\n [attr.aria-invalid]=\"showError(field.property)\"\r\n [attr.aria-describedby]=\"'error-' + field.property\"\r\n [required]=\"field.readonly ? false : field.required\"\r\n [readonly]=\"field.readonly\"\r\n [pattern]=\"field.pattern\">\r\n <mat-error id=\"error-{{ field.property }}\" *ngIf=\"showError(field.property)\"\r\n aria-live=\"assertive\">\r\n {{ getErrors(field.property) | translate }}\r\n </mat-error>\r\n </mat-form-field>\r\n\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n\r\n\r\n <ng-container *ngSwitchCase=\"'time'\">\r\n <ng-container *ngIf=\"showField(defaults, field)\">\r\n <ng-container *ngIf=\"!workflowEditableField(field)\">\r\n <ng-container\r\n [ngTemplateOutlet]=\"timeReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\">\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"workflowEditableField(field)\">\r\n <div class=\"label-and-asterisk-container\">\r\n <span *ngIf=\"!field.hideLabel\" class=\"custom-label\" id=\"label-{{field.property}}\">\r\n {{ field.label! | translate }}\r\n </span>\r\n <span *ngIf=\"field.required\" class=\"required-asterisk\"> * </span>\r\n </div>\r\n <mat-form-field appearance=\"outline\">\r\n <input\r\n matInput\r\n class=\"app-input\"\r\n formControlName=\"{{ field.property }}\"\r\n type=\"time\"\r\n [placeholder]=\"field.placeholder ? (labelKeyPlaceHolder(field) | translate) : ''\"\r\n [readonly]=\"field.readonly\"\r\n [attr.aria-labelledby]=\"'label-' + field.property\"\r\n [attr.aria-required]=\"field.required\"\r\n [attr.aria-invalid]=\"showError(field.property)\"\r\n [attr.aria-describedby]=\"'error-' + field.property\"\r\n [required]=\"field.required\">\r\n <mat-error\r\n id=\"error-{{ field.property }}\"\r\n *ngIf=\"showError(field.property)\"\r\n aria-live=\"assertive\">\r\n {{ getErrors(field.property) | translate }}\r\n </mat-error>\r\n </mat-form-field>\r\n\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'checkbox'\">\r\n <ng-container *ngIf=\"showField(defaults, field)\">\r\n <ng-container *ngIf=\"!workflowEditableField(field)\">\r\n <ng-container\r\n [ngTemplateOutlet]=\"checkboxReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\">\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"workflowEditableField(field)\">\r\n <mat-checkbox\r\n appearance=\"outline\"\r\n style=\"padding-bottom: 14px; padding-top: 14px;\"\r\n [disabled]=\"field.readonly\"\r\n [attr.aria-required]=\"field.required\"\r\n [attr.aria-invalid]=\"showError(field.property)\"\r\n formControlName=\"{{ field.property }}\">\r\n {{ field.label! | translate }}\r\n <mat-error *ngIf=\"showError(field.property)\" aria-live=\"assertive\">\r\n {{ getErrors(field.property) | translate }}\r\n </mat-error>\r\n </mat-checkbox>\r\n\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'color-picker'\">\r\n <ng-container *ngIf=\"showField(defaults, field)\">\r\n <div fxLayout=\"row\" fxLayoutAlign=\"center\">\r\n <h4 style=\"margin-right: 10px\">{{ field.label! | translate }}</h4>\r\n <input\r\n ejs-colorpicker\r\n type=\"color\"\r\n id=\"colorpicker\"\r\n formControlName=\"{{ field.property }}\"\r\n [attr.aria-label]=\"field.label! | translate\"\r\n [attr.aria-required]=\"field.required\"\r\n [attr.aria-invalid]=\"showError(field.property)\"\r\n />\r\n </div>\r\n <mat-error *ngIf=\"showError(field.property)\" aria-live=\"assertive\">\r\n {{ getErrors(field.property) | translate }}\r\n </mat-error>\r\n </ng-container>\r\n </ng-container>\r\n\r\n\r\n <ng-container *ngSwitchCase=\"'radio-button'\">\r\n <ng-container *ngIf=\"showField(defaults, field)\">\r\n <ng-container *ngIf=\"!workflowEditableField(field)\">\r\n <ng-container\r\n [ngTemplateOutlet]=\"radioButtonReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\">\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"workflowEditableField(field)\">\r\n <mat-radio-group\r\n formControlName=\"{{field.property}}\"\r\n class=\"app-radio\"\r\n [attr.aria-label]=\"field.label! | translate\"\r\n [attr.aria-required]=\"field.required\"\r\n [attr.aria-invalid]=\"showError(field.property)\">\r\n <div class=\"field-row\">\r\n <div class=\"field-label\">\r\n <span class=\"custom-label\">{{ field.label! | translate }}</span>\r\n </div>\r\n <div class=\"field-input\">\r\n <div class=\"radio-group-custom\">\r\n <mat-radio-button\r\n *ngFor=\"let option of field.listOptions\"\r\n [value]=\"option\"\r\n [attr.aria-labelledby]=\"option\">\r\n {{ option | translate }}\r\n </mat-radio-button>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <mat-error\r\n *ngIf=\"showError(field.property)\"\r\n aria-live=\"assertive\">\r\n {{ getErrors(field.property) | translate }}\r\n </mat-error>\r\n </mat-radio-group>\r\n\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'list'\">\r\n <ng-container *ngIf=\"showField(defaults, field)\">\r\n <ng-container *ngIf=\"!workflowEditableField(field)\">\r\n <ng-container\r\n [ngTemplateOutlet]=\"listReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\">\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"workflowEditableField(field)\">\r\n <div class=\"label-and-asterisk-container\">\r\n <span *ngIf=\"!field.hideLabel\" class=\"custom-label\" id=\"label-{{field.property}}\">\r\n {{ field.label! | translate }}\r\n </span>\r\n <span *ngIf=\"field.required\" class=\"required-asterisk\"> * </span>\r\n </div>\r\n <mat-form-field appearance=\"outline\" style=\"width: 100%\">\r\n <mat-select\r\n formControlName=\"{{field.property}}\"\r\n [attr.aria-label]=\"field.label! | translate\"\r\n [attr.aria-required]=\"field.required\"\r\n [placeholder]=\"field.placeholder ? (labelKeyPlaceHolder(field) | translate) : ''\"\r\n [attr.aria-invalid]=\"showError(field.property)\"\r\n [disabled]=\"field.readonly\"\r\n [multiple]=\"field.multi || false\"\r\n [required]=\"field.readonly ? false : field.required\"\r\n [(value)]=\"field.defaultListOption\">\r\n <ng-container *ngIf=\"field.translate; else lookup_no_translation\">\r\n <mat-option\r\n *ngFor=\"let item of field.listOptions; let i = index\"\r\n [value]=\"item\">\r\n {{ friendlyName(field.label, field.property, item) | translate }}\r\n </mat-option>\r\n </ng-container>\r\n <ng-template #lookup_no_translation>\r\n <mat-option\r\n *ngFor=\"let item of field.listOptions\"\r\n [value]=\"item\">\r\n {{ getOptionValue(item) }}\r\n </mat-option>\r\n </ng-template>\r\n </mat-select>\r\n <mat-error\r\n *ngIf=\"showError(field.property)\"\r\n aria-live=\"assertive\">\r\n {{ getErrors(field.property) | translate }}\r\n </mat-error>\r\n </mat-form-field>\r\n\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'attachment'\" [formGroup]=\"formParam\">\r\n <ng-container *ngIf=\"showField(defaults, field)\">\r\n <!-- Uncomment and use the attachment control when ready -->\r\n <!-- <ag-attachment-control\r\n [allowMulti]=\"field.multi\"\r\n [attachmentDefaultExternal]=\"pageInfo?.attachmentDefaultExternal\"\r\n [supportedTypes]=\"field.supportedTypes\"\r\n [buttonType]=\"field.buttonType\"\r\n [hideListOfFiles]=\"field.hideFiles\"\r\n (filesList)=\"updateFilesList($event, field)\"\r\n (actionExecuted)=\"actionExecuted($event, field)\"\r\n style=\"margin-top: 5px\"\r\n label=\"{{field.label! | translate}}\">\r\n </ag-attachment-control> -->\r\n <mat-error class=\"iq-error\"\r\n *ngIf=\"showError(field.property)\"\r\n aria-live=\"assertive\">\r\n {{ getErrors(field.property) | translate }}\r\n </mat-error>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'lookup'\" [formGroup]=\"formParam\">\r\n <ng-container *ngIf=\"showField(defaults, field)\">\r\n <ng-container *ngIf=\"!workflowEditableField(field)\">\r\n <ng-container\r\n [ngTemplateOutlet]=\"lookupReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\">\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"workflowEditableField(field)\">\r\n <app-auto-complete\r\n [form]=\"formParam\"\r\n [field]=\"field\"\r\n [supportingAttributes]=\"supportingAttributes\"\r\n [defaultValue]=\"this.formParam.get(field.property)?.value\"\r\n (selectedValue)=\"patchLookupValue($event, field.property)\">\r\n <mat-error\r\n *ngIf=\"showError(field.property)\"\r\n aria-live=\"assertive\">\r\n {{ getErrors(field.property) | translate }}\r\n </mat-error>\r\n </app-auto-complete>\r\n\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'currency'\" [formGroup]=\"formParam\">\r\n <ng-container *ngIf=\"showField(defaults, field)\">\r\n <ng-container *ngIf=\"!workflowEditableField(field)\">\r\n <ng-container\r\n [ngTemplateOutlet]=\"currencyReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\">\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"workflowEditableField(field)\">\r\n <!-- Uncomment and use the currency control when ready -->\r\n <!-- <app-currency\r\n [form]=\"formParam\"\r\n [field]=\"field\"\r\n [defaultValue]=\"this.formParam.get(field.property)?.value\"\r\n (selectedValue)=\"patchCurrencyValue($event, field.property)\">\r\n </app-currency> -->\r\n <mat-error\r\n *ngIf=\"showError(field.property)\"\r\n aria-live=\"assertive\">\r\n {{ getErrors(field.property) | translate }}\r\n </mat-error>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'multi-select'\" [formGroup]=\"formParam\">\r\n <ng-container *ngIf=\"showField(defaults, field)\">\r\n <ng-container *ngIf=\"!workflowEditableField(field)\">\r\n <ng-container\r\n [ngTemplateOutlet]=\"multiSelectReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\">\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"workflowEditableField(field)\">\r\n <app-multi-auto-complete\r\n [form]=\"formParam\"\r\n [field]=\"field\"\r\n [defaultValue]=\"getMultiValue(field)\"\r\n (selectedValue)=\"patchMultiSelectValue($event, field.property)\">\r\n <mat-error\r\n *ngIf=\"showError(field.property)\"\r\n aria-live=\"assertive\">\r\n {{ getErrors(field.property) | translate }}\r\n </mat-error>\r\n </app-multi-auto-complete>\r\n\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n\r\n\r\n <ng-container *ngSwitchCase=\"'rich-text'\" [formGroup]=\"formParam\">\r\n <ng-container *ngIf=\"showField(defaults, field)\">\r\n <!-- Uncomment and use the rich text editor when ready -->\r\n <!-- <ckeditor\r\n [editor]=\"Editor\"\r\n [disabled]=\"field.readonly\"\r\n formControlName=\"{{field.property}}\">\r\n </ckeditor> -->\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'divider'\">\r\n <mat-divider></mat-divider>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'hyper-text'\">\r\n <div>\r\n <mat-label\r\n (click)=\"getHyperTextEvent()\"\r\n class=\"hyper-link\">\r\n {{ field.label! | translate }}\r\n </mat-label>\r\n </div>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'section-title'\">\r\n <ng-container *ngIf=\"showField(defaults, field)\">\r\n <div class=\"hrdivider-mid\">\r\n <span>{{ field.label | translate }}</span>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'equation-builder'\">\r\n <ng-container *ngIf=\"showField(defaults, field)\">\r\n <ng-container *ngIf=\"!workflowEditableField(field)\">\r\n <ng-container\r\n [ngTemplateOutlet]=\"textReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\">\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"workflowEditableField(field)\">\r\n <div class=\"label-and-asterisk-container\">\r\n <span *ngIf=\"!field.hideLabel\" class=\"custom-label\" id=\"label-{{field.property}}\">\r\n {{ field.label! | translate }}\r\n </span>\r\n <span *ngIf=\"field.required\" class=\"required-asterisk\"> * </span>\r\n </div>\r\n <mat-form-field appearance=\"outline\">\r\n <input class=\"app-input\" dir=\"ltr\"\r\n formControlName=\"{{ field.property }}\"\r\n matInput\r\n [placeholder]=\"field.placeholder ? (labelKeyPlaceHolder(field) | translate) : ''\"\r\n [readonly]=\"field.readonly\"\r\n [required]=\"field.required\"\r\n [attr.aria-required]=\"field.required\"\r\n [attr.aria-invalid]=\"showError(field.property)\"\r\n [attr.aria-labelledby]=\"'label-' + field.property\"\r\n [attr.aria-describedby]=\"'error-' + field.property\">\r\n <mat-error\r\n id=\"error-{{ field.property }}\"\r\n *ngIf=\"showError(field.property)\"\r\n aria-live=\"assertive\">\r\n {{ getErrors(field.property) | translate }}\r\n </mat-error>\r\n </mat-form-field>\r\n\r\n\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n <!-- <ng-container *ngSwitchCase=\"'equation-builder'\" [formGroup]=\"formParam\">-->\r\n <!-- <ng-container *ngIf=\"showField(defaults, field)\">-->\r\n <!-- <ng-container *ngIf=\"!workflowEditableField(field)\">-->\r\n <!-- <ng-container-->\r\n <!-- [ngTemplateOutlet]=\"dateReadonly\"-->\r\n <!-- [ngTemplateOutletContext]=\"{ field: field }\">-->\r\n <!-- </ng-container>-->\r\n <!-- </ng-container>-->\r\n <!-- <ng-container *ngIf=\"workflowEditableField(field)\">-->\r\n <!-- <div style=\"display: flex; width: 350%\">-->\r\n <!-- <mat-label>{{ field.label! | translate }}</mat-label>-->\r\n <!-- <mat-form-field style=\"width: 400%\" appearance=\"outline\">-->\r\n <!-- <mat-chip-grid #chipGrid>-->\r\n <!-- <ng-container *ngFor=\"let equationValue of equationValues(); let i = index\">-->\r\n <!-- <mat-chip-row (removed)=\"remove(equationValue, i)\">-->\r\n <!-- {{ equationValue }}-->\r\n <!-- <button-->\r\n <!-- matChipRemove-->\r\n <!-- [attr.aria-label]=\"'remove ' + equationValue\">-->\r\n <!-- <mat-icon>cancel</mat-icon>-->\r\n <!-- </button>-->\r\n <!-- </mat-chip-row>-->\r\n <!-- </ng-container>-->\r\n <!-- </mat-chip-grid>-->\r\n <!-- <input-->\r\n <!-- [(ngModel)]=\"currentEquationValue\"-->\r\n <!-- [matChipInputFor]=\"chipGrid\"-->\r\n <!-- [matAutocomplete]=\"auto\"-->\r\n <!-- [ngModelOptions]=\"{ standalone: true }\"-->\r\n <!-- [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\"-->\r\n <!-- (matChipInputTokenEnd)=\"add($event)\"-->\r\n <!-- aria-label=\"Add equation value\" />-->\r\n <!-- <mat-autocomplete #auto=\"matAutocomplete\" (optionSelected)=\"selected($event)\">-->\r\n <!-- <ng-container *ngFor=\"let filteredField of (equationFilteredFields() | async)\">-->\r\n <!-- <mat-option [value]=\"filteredField\">{{ filteredField }}</mat-option>-->\r\n <!-- </ng-container>-->\r\n <!-- </mat-autocomplete>-->\r\n <!-- </mat-form-field>-->\r\n <!-- </div>-->\r\n <!-- <mat-error class=\"iq-error\" *ngIf=\"showError(field.property)\" aria-live=\"assertive\">-->\r\n <!-- {{ getErrors(field.property) | translate }}-->\r\n <!-- </mat-error>-->\r\n <!-- </ng-container>-->\r\n <!-- </ng-container>-->\r\n <!-- </ng-container>-->\r\n\r\n </ng-container>\r\n </div>\r\n </ng-container>\r\n </div>\r\n </ng-container>\r\n </div>\r\n </div>\r\n </form>\r\n </ng-container>\r\n </ng-container>\r\n </div>\r\n\r\n</div>\r\n<ng-template #dateReadonly let-field=\"field\">\r\n <div class=\"readonly-item\">\r\n <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n <span class=\"readonly-value\">{{ extractFieldName(defaults, field.property) | date: 'dd/MM/yyyy' }}</span>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #timeReadonly let-field=\"field\">\r\n <div class=\"readonly-item\">\r\n <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n <span class=\"readonly-value\">{{ formatTimeToDate(defaults[field.property]) | date: 'shortTime' }}</span>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #phoneNumberReadonly let-field=\"field\">\r\n <div class=\"readonly-item\">\r\n <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n <span class=\"readonly-value\">{{ extractFieldName(defaults, field.property) }}</span>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #textReadonly let-field=\"field\">\r\n <div class=\"readonly-item\">\r\n <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\" *ngIf=\"!field.advancedFilter\"></label>\r\n <span class=\"readonly-value\">{{ extractFieldName(defaults, field.property) }}</span>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #textareaReadonly let-field=\"field\">\r\n <ng-container *ngIf=\"field.textFormat === 'json'; else normalText\">\r\n <div class=\"readonly-item\">\r\n <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n <div class=\"readonly-value json-viewer\">\r\n <ngx-json-viewer [json]=\"extractJsonFieldName(defaults, field.property)\" [expanded]=\"true\"></ngx-json-viewer>\r\n </div>\r\n </div>\r\n </ng-container>\r\n <ng-template #normalText>\r\n <div class=\"readonly-item\">\r\n <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n <span class=\"readonly-value\">{{ extractFieldName(defaults, field.property) }}</span>\r\n </div>\r\n </ng-template>\r\n</ng-template>\r\n\r\n<ng-template #numberReadonly let-field=\"field\">\r\n <div class=\"readonly-item\">\r\n <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n <span class=\"readonly-value\">{{ extractFieldName(defaults, field.property) }}</span>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #currencyReadonly let-field=\"field\">\r\n <div class=\"readonly-item\">\r\n <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n <span class=\"readonly-value\">{{ extractFieldName(defaults, field.property) }}</span>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #radioButtonReadonly let-field=\"field\">\r\n <div class=\"readonly-item\">\r\n <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n <span class=\"readonly-value\">{{ translateLable(defaults[field.property]) }}</span>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #richTextReadonly let-field=\"field\">\r\n <div class=\"readonly-item\">\r\n <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n <span class=\"readonly-value\" [innerHtml]=\"extractFieldName(defaults, field.property)\"></span>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #checkboxReadonly let-field=\"field\">\r\n <div class=\"readonly-item\">\r\n <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n <span class=\"readonly-value\">\r\n <mat-icon color=\"warn\" *ngIf=\"extractFieldName(defaults, field.property); else showNo\">done</mat-icon>\r\n <ng-template #showNo>\r\n <mat-icon color=\"warn\">close</mat-icon>\r\n </ng-template>\r\n </span>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #listReadonly let-field=\"field\">\r\n <div class=\"readonly-item\">\r\n <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n <span class=\"readonly-value\" *ngIf=\"field.translate; else noTranslate\">\r\n {{ listShowValue(defaults, field) | translate }}\r\n </span>\r\n <ng-template #noTranslate>\r\n <span class=\"readonly-value\">{{ extractFieldName(defaults, field.property) }}</span>\r\n </ng-template>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #sequenceReadonly let-field=\"field\">\r\n <div class=\"readonly-item\">\r\n <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n <span class=\"readonly-value\">{{ extractFieldName(defaults, field.property) }}</span>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #lookupReadonly let-field=\"field\">\r\n <div class=\"readonly-item\">\r\n <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n <span class=\"readonly-value\">\r\n {{ extractFieldName(defaults, field.property)?.[translateService.getDefaultLang() === 'en' ? 'englishName' : 'arabicName'] }}\r\n </span>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #amountReadonly let-field=\"field\">\r\n <div class=\"readonly-item\">\r\n <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n <span class=\"readonly-value\">\r\n {{ extractFieldName(defaults, field.property) | currency: currency }}\r\n </span>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #multiSelectReadonly let-field=\"field\">\r\n <div class=\"readonly-item\">\r\n <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n <mat-chip-grid class=\"readonly-value chipList\">\r\n <mat-chip *ngFor=\"let filedProp of showMultiSelectValuesAsReadonly(field)\">\r\n {{ filedProp }}\r\n </mat-chip>\r\n </mat-chip-grid>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #chipListReadonly let-field=\"field\">\r\n <div class=\"readonly-item\">\r\n <label class=\"readonly-label\" [innerHTML]=\"field.label | translate\"></label>\r\n <mat-chip-listbox class=\"readonly-value chipList\">\r\n <mat-chip-option *ngFor=\"let loc of splitReadonly(extractFieldName(defaults, field.property))\"\r\n [selectable]=\"true\"\r\n color=\"warn\"\r\n [removable]=\"false\">\r\n {{ loc }}\r\n </mat-chip-option>\r\n </mat-chip-listbox>\r\n </div>\r\n</ng-template>\r\n\r\n\r\n<ng-template #readonlyView>\r\n <div class=\"row-wrapper\">\r\n <div class=\"column-wrapper\">\r\n <ng-container *ngFor=\"let row of screenFields | keyvalue\">\r\n <div class=\"row-container\">\r\n <ng-container *ngFor=\"let field of row.value\">\r\n <div class=\"field-column readonly-item\" [style.flex]=\"field.fieldSize ? ('0 0 ' + field.fieldSize + '%') : '1 1 0'\">\r\n\r\n <ng-container [ngSwitch]=\"field.type\">\r\n\r\n <ng-container *ngSwitchCase=\"'date'\">\r\n <ng-container [ngTemplateOutlet]=\"dateReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'time'\">\r\n <ng-container [ngTemplateOutlet]=\"timeReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'phone-number'\">\r\n <ng-container [ngTemplateOutlet]=\"phoneNumberReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'text'\">\r\n <ng-container [ngTemplateOutlet]=\"textReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'textarea'\">\r\n <ng-container [ngTemplateOutlet]=\"textareaReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'number'\">\r\n <ng-container [ngTemplateOutlet]=\"numberReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'currency'\">\r\n <ng-container [ngTemplateOutlet]=\"currencyReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'radio-button'\">\r\n <ng-container [ngTemplateOutlet]=\"radioButtonReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'checkbox'\">\r\n <ng-container [ngTemplateOutlet]=\"checkboxReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'status'\">\r\n <ng-container [ngTemplateOutlet]=\"checkboxReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'lookup'\">\r\n <ng-container [ngTemplateOutlet]=\"lookupReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'amount'\">\r\n <ng-container [ngTemplateOutlet]=\"amountReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'multi-select'\">\r\n <ng-container [ngTemplateOutlet]=\"multiSelectReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'chip-list'\">\r\n <ng-container [ngTemplateOutlet]=\"chipListReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'sequence'\">\r\n <ng-container [ngTemplateOutlet]=\"sequenceReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'list'\">\r\n <ng-container [ngTemplateOutlet]=\"listReadonly\"\r\n [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'iban-text'\">\r\n <p class=\"label\">\r\n <span [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></span>\r\n <span> : </span>\r\n <span class=\"value\" [innerHtml]=\"extractFieldName(defaults, field.property)\"></span>\r\n </p>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'section-title'\">\r\n <div class=\"hrdivider-mid\">\r\n <span>{{ field.label | translate }}</span>\r\n </div>\r\n </ng-container>\r\n\r\n </ng-container>\r\n </div>\r\n </ng-container>\r\n </div>\r\n </ng-container>\r\n </div>\r\n </div>\r\n</ng-template>\r\n\r\n\r\n", styles: [".main-form-canvas{display:flex;flex-direction:row;gap:10px;align-items:flex-start;justify-content:flex-start;margin-top:3vh;width:100%;flex-wrap:wrap}.form-wrapper{display:flex;flex-direction:column;flex:1}.form-container{display:flex;flex-direction:column;width:100%}.row-container{display:flex;flex-direction:row;gap:20px;flex-wrap:wrap;width:100%}.field-column{display:flex;flex-direction:column;flex:1}.label-and-asterisk-container{display:flex;align-items:center;gap:2px}.full-width{width:100%}.readonly-item{display:flex;flex-direction:column;align-items:flex-start;gap:2px;font-size:14px;padding:4px 0;width:100%}.readonly-item .readonly-label{font-weight:500;color:#9b9b9b;font-size:14px}.readonly-item .readonly-value{font-weight:500;color:#222;word-break:break-word;font-size:14px}.readonly-item .json-viewer{width:100%}.readonly-item .chipList{display:flex;flex-wrap:wrap;gap:4px}.readonly-item mat-icon{font-size:18px;vertical-align:middle}.row-wrapper{display:flex;flex-direction:row;gap:20px;width:100%;flex-wrap:wrap}.column-wrapper{display:flex;flex-direction:column;width:100%;align-items:flex-start}.row-container{display:flex;flex-direction:row;gap:20px;width:100%;flex-wrap:wrap}.field-column{display:flex;flex-direction:column;min-width:50px!important}.field-row{display:flex;flex-direction:row;gap:10px;width:100%;align-items:flex-start}.field-label{flex:0 0 40%;display:flex;flex-direction:column;justify-content:center}.field-input{flex:0 0 60%;display:flex;flex-direction:column}.radio-group-custom{display:flex;flex-direction:row;flex-wrap:wrap;gap:10px}@media (max-width: 600px){.main-form-canvas{flex-direction:column;align-items:center}.row-container{flex-direction:column;gap:10px}.field-column{width:100%;flex:1 1 100%!important}.column-wrapper{align-items:center}.field-row{flex-direction:column}.field-label,.field-input{flex:1 1 100%}.radio-group-custom{flex-direction:column;gap:5px}}.custom-ngx-mat-intl-tel-input[readonly] input,.custom-ngx-mat-intl-tel-input.ngx-mat-intl-tel-input input[disabled]{pointer-events:none!important;background-color:#f5f5f5!important;color:#444!important}.custom-ngx-mat-intl-tel-input .iti__flag-container,.custom-ngx-mat-intl-tel-input .iti__selected-flag{pointer-events:none!important;opacity:.6}.custom-ngx-mat-intl-tel-input{pointer-events:none!important}@media (max-width: 960px){.row-wrapper,.row-container{flex-direction:column}.row-container{gap:15px}.field-column{flex:1 1 100%!important}}\n"] }]
|
|
557
|
+
}], ctorParameters: () => [{ type: i1.TranslateService }, { type: i2.ActivatedRoute }, { type: i3.BackendService }, { type: i4.FormBuilder }, { type: i5.LiveAnnouncer }], propDecorators: { pageInfo: [{
|
|
558
|
+
type: Input
|
|
559
|
+
}], currency: [{
|
|
560
|
+
type: Input
|
|
561
|
+
}], fields: [{
|
|
562
|
+
type: Input
|
|
563
|
+
}], errors: [{
|
|
564
|
+
type: Input
|
|
565
|
+
}], workflowEditableFields: [{
|
|
566
|
+
type: Input
|
|
567
|
+
}], isWorkflowEditableManaged: [{
|
|
568
|
+
type: Input
|
|
569
|
+
}], supportingAttributes: [{
|
|
570
|
+
type: Input
|
|
571
|
+
}], editable: [{
|
|
572
|
+
type: Input
|
|
573
|
+
}], emitOnValueChanges: [{
|
|
574
|
+
type: Input
|
|
575
|
+
}], item: [{
|
|
576
|
+
type: Input
|
|
577
|
+
}], attachmentEmitter: [{
|
|
578
|
+
type: Output
|
|
579
|
+
}], actionEmitter: [{
|
|
580
|
+
type: Output
|
|
581
|
+
}], formUpdated: [{
|
|
582
|
+
type: Output
|
|
583
|
+
}], hyperTextEvent: [{
|
|
584
|
+
type: Output
|
|
585
|
+
}], equationSuggestedFields: [{
|
|
586
|
+
type: Input
|
|
587
|
+
}], fieldsInput: [{
|
|
588
|
+
type: ViewChild,
|
|
589
|
+
args: ['EquationValueInput']
|
|
590
|
+
}] } });
|
|
591
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-form-canvas.component.js","sourceRoot":"","sources":["../../../../../../../projects/invoiceq/ui-lib/src/lib/components/base-form-canvas/base-form-canvas.component.ts","../../../../../../../projects/invoiceq/ui-lib/src/lib/components/base-form-canvas/base-form-canvas.component.html"],"names":[],"mappings":"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AE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI;YACpG,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI;YACpG,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI;YACpG,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI;YACpG,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI;YACpG,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI;YACpG,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI;YACpG,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI;YACpG,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI;YACpG,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI;YACpG,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI;YACpG,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI;YACpG,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI;YACpG,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI;YACpG,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;IAC9C,CAAC;IAGD,YA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","sourcesContent":["import {\r\n  Component, ElementRef,\r\n  EventEmitter,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  SimpleChanges,\r\n  ViewChild,\r\n  computed,\r\n  model,\r\n  signal\r\n} from '@angular/core';\r\nimport {FormBuilder, FormGroup, ReactiveFormsModule, FormsModule, FormControl} from \"@angular/forms\";\r\nimport {\r\n  MatChip,\r\n  MatChipGrid,\r\n  MatChipInput,\r\n  MatChipInputEvent,\r\n  MatChipListbox, MatChipOption, MatChipRemove,\r\n  MatChipRow\r\n} from \"@angular/material/chips\";\r\nimport {FieldInfo} from \"../../base-model/field-info\";\r\nimport {ActivatedRoute} from \"@angular/router\";\r\nimport {BackendService} from \"../../services/backend-service\";\r\nimport {TranslateModule, TranslateService} from \"@ngx-translate/core\";\r\nimport {PageInfo} from \"../../base-model/page-info\";\r\nimport {COMMA, ENTER, SEMICOLON} from \"@angular/cdk/keycodes\";\r\nimport {LookupItem} from \"../../base-model/lookupItem\";\r\nimport {FieldMessage} from \"../../base-model/api-response\";\r\nimport {\r\n  AsyncPipe,\r\n  CurrencyPipe,\r\n  DatePipe,\r\n  KeyValuePipe,\r\n  NgForOf,\r\n  NgIf, NgStyle,\r\n  NgSwitch,\r\n  NgSwitchCase,\r\n  NgTemplateOutlet\r\n} from \"@angular/common\";\r\nimport {MatError, MatFormFieldModule, MatLabel} from \"@angular/material/form-field\";\r\nimport {MatInputModule} from \"@angular/material/input\";\r\nimport {MatDatepicker, MatDatepickerInput, MatDatepickerToggle, MatDateRangeInput} from \"@angular/material/datepicker\";\r\nimport {MatIcon} from \"@angular/material/icon\";\r\nimport {CdkTextareaAutosize} from \"@angular/cdk/text-field\";\r\nimport {MatRadioButton, MatRadioGroup} from \"@angular/material/radio\";\r\nimport {MatCheckbox} from \"@angular/material/checkbox\";\r\nimport {MatOption, MatSelect} from \"@angular/material/select\";\r\nimport {MatDivider} from \"@angular/material/divider\";\r\nimport {NgxJsonViewerModule} from \"ngx-json-viewer\";\r\nimport {CKEditorModule} from \"@ckeditor/ckeditor5-angular\";\r\nimport {NgxMatIntlTelInputComponent} from \"ngx-mat-intl-tel-input\";\r\nimport {MultiAutoCompleteComponent} from \"../multi-auto-complete/multi-auto-complete.component\";\r\nimport {AutoCompleteComponent} from \"../auto-complete/auto-complete.component\";\r\nimport {MatAutocomplete, MatAutocompleteSelectedEvent, MatAutocompleteTrigger} from \"@angular/material/autocomplete\";\r\nimport {BehaviorSubject, map} from \"rxjs\";\r\nimport {LiveAnnouncer} from \"@angular/cdk/a11y\";\r\nimport {buildFormFields, extractFieldName} from \"../../utils/base-utils\";\r\nimport ClassicEditor from \"@ckeditor/ckeditor5-build-classic\"\r\nimport moment, {Moment} from \"moment/moment\";\r\nimport {MatCell, MatCellDef, MatHeaderCell, MatHeaderCellDef} from \"@angular/material/table\";\r\nimport {DateAdapter, MAT_DATE_FORMATS, MAT_DATE_LOCALE} from \"@angular/material/core\";\r\nimport {MAT_MOMENT_DATE_ADAPTER_OPTIONS, MomentDateAdapter} from \"@angular/material-moment-adapter\";\r\nexport const DD_MM_YYYY_Format = {\r\n  parse: { dateInput: 'DD/MM/YYYY' },\r\n  display: {\r\n    dateInput: 'DD/MM/YYYY',\r\n    monthYearLabel: 'MMM YYYY',\r\n    dateA11yLabel: 'DD/MM/YYYY',\r\n    monthYearA11yLabel: 'MMMM YYYY',\r\n  },\r\n};\r\n@Component({\r\n  selector: 'app-base-form-canvas',\r\n  standalone: true,\r\n  imports: [\r\n    ReactiveFormsModule,\r\n    NgSwitch,\r\n    FormsModule,\r\n    NgForOf,\r\n    NgTemplateOutlet,\r\n    KeyValuePipe,\r\n    NgIf,\r\n    MatLabel,\r\n    MatFormFieldModule,\r\n    TranslateModule,\r\n    MatInputModule,\r\n    MatDatepickerInput,\r\n    MatDatepicker,\r\n    MatDatepickerToggle,\r\n    MatError,\r\n    NgSwitchCase,\r\n    MatIcon,\r\n    MatAutocomplete,\r\n    MatAutocompleteTrigger,\r\n    MatChip,\r\n    CdkTextareaAutosize,\r\n    MatRadioGroup,\r\n    MatCheckbox,\r\n    MatRadioButton,\r\n    MatSelect,\r\n    MatOption,\r\n    MatDivider,\r\n    DatePipe,\r\n    NgxJsonViewerModule,\r\n    CurrencyPipe,\r\n    CKEditorModule,\r\n    NgxMatIntlTelInputComponent,\r\n    MatChipGrid,\r\n    MatChipInput,\r\n    MatChipRow,\r\n    MatChipListbox,\r\n    MatChipOption,\r\n    MultiAutoCompleteComponent,\r\n    AutoCompleteComponent,\r\n    MatDateRangeInput,\r\n    AsyncPipe,\r\n    MatChipRemove,\r\n    MatCell,\r\n    MatCellDef,\r\n    MatHeaderCell,\r\n    MatHeaderCellDef,\r\n    NgStyle\r\n  ],\r\n  templateUrl: './base-form-canvas.component.html',\r\n  styleUrl: './base-form-canvas.component.css',\r\n  providers: [\r\n    {\r\n      provide: DateAdapter,\r\n      useClass: MomentDateAdapter,\r\n      deps: [MAT_DATE_LOCALE, MAT_MOMENT_DATE_ADAPTER_OPTIONS]\r\n    },\r\n    { provide: MAT_DATE_FORMATS, useValue: DD_MM_YYYY_Format },\r\n    { provide: MAT_DATE_LOCALE, useValue: 'en-GB' }\r\n  ]\r\n\r\n})\r\nexport class BaseFormCanvasComponent implements OnInit, OnChanges, OnDestroy {\r\n  public Editor = ClassicEditor;\r\n  public hide: boolean = true;\r\n  dateViewMode: 'month' | 'year' | 'multi-year' = 'month';\r\n  @Input()\r\n  pageInfo!: PageInfo;\r\n\r\n\r\n  @Input()\r\n  currency: string;\r\n\r\n  @Input()// @ts-ignore\r\n  fields: FieldInfo[] = [];\r\n\r\n  @Input()// @ts-ignore\r\n  errors: FieldMessage[] = [];\r\n\r\n  @Input()\r\n  workflowEditableFields: string[]=[];\r\n  @Input()\r\n  isWorkflowEditableManaged: boolean = false;\r\n\r\n  @Input()\r\n  supportingAttributes: any;\r\n\r\n  @Input()\r\n  editable: boolean = false;\r\n\r\n  // When true, emit formUpdated on every value change. Default is false to avoid\r\n  // noisy emissions for all consumers. Item-line-editor will enable this explicitly.\r\n  @Input()\r\n  emitOnValueChanges: boolean = false;\r\n\r\n  @Input()\r\n  item: any = {};\r\n\r\n  _defaults: any = {};\r\n\r\n  @Output() attachmentEmitter: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  @Output() actionEmitter: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n\r\n  @Output()\r\n  formUpdated: EventEmitter<FormGroup> = new EventEmitter<FormGroup>();\r\n\r\n  @Output()\r\n  hyperTextEvent: EventEmitter<boolean> = new EventEmitter();\r\n\r\n\r\n  formParam!: FormGroup;\r\n  screenFields = new Map<number, FieldInfo[]>();\r\n  removable = true;\r\n  selectable = true;\r\n  addOnBlur = true;\r\n\r\n  readonly separatorKeysCodes: number[] = [ENTER, COMMA, SEMICOLON];\r\n\r\n\r\n  public isPending: boolean = false;\r\n  public isNew: boolean = false;\r\n  itemId: number | undefined;\r\n\r\n  equationOperators : string[] = ['+','-','(' ];\r\n  @Input() equationSuggestedFields: { name: string, id: string }[] = [];\r\n  allEquationFields: BehaviorSubject<string[]>;\r\n  readonly equationValues = signal<string[]>([]);\r\n  currentEquationValue = model<string>('');\r\n\r\n  readonly equationFilteredFields = computed(() => {\r\n    const currentEquationValue = this.currentEquationValue().toLowerCase();\r\n    return this.allEquationFields.pipe(\r\n        map(fields =>\r\n            currentEquationValue ? fields?.filter(field => field.toLowerCase().includes(currentEquationValue)) : fields?.slice()\r\n        )\r\n    );\r\n  });\r\n  @ViewChild('EquationValueInput') fieldsInput: ElementRef<HTMLInputElement>;\r\n\r\n  set defaults(value: any | undefined) {\r\n    // this.backendService._defaults = value;\r\n    this._defaults = value;\r\n    this.buildForm();\r\n    // this.myCallback = value;\r\n  }\r\n\r\n  get defaults(): any | undefined {\r\n    // this.myCallback;\r\n    return this._defaults;\r\n    // return this.backendService._defaults;\r\n  }\r\n\r\n  constructor(protected translateService: TranslateService,\r\n              protected activatedRoute: ActivatedRoute,\r\n              protected backendService: BackendService,\r\n              private fb: FormBuilder,\r\n              private announcer: LiveAnnouncer) {\r\n    ClassicEditor.defaultConfig = {\r\n      toolbar: {\r\n        items: ['heading', '|', 'bold', 'italic', '|', 'bulletedList', 'numberedList']\r\n      },\r\n      image: {\r\n        toolbar: ['imageStyle:side', '|', 'imageTextAlternative']\r\n      },\r\n      table: {\r\n        contentToolbar: [ 'tableColumn', 'tableRow', 'mergeTableCells' ]\r\n      },\r\n      language: 'en'\r\n    };\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    if(this.item && this.item.fieldValue){\r\n      this.equationValues.update(value => this.item.fieldValue)\r\n    }\r\n    this.defaults = this.item;\r\n    this.extractLables();\r\n    this.buildForm();\r\n    this.activatedRoute.data.subscribe(data => {\r\n      this.isPending = data['mode'] === 'pending';\r\n      this.isNew = data['mode'] === 'new';\r\n    });\r\n    // this.authService.summaryPanelState$.next(Constants.SUMMARY_PANEL_CLOSED);\r\n    // this.defaults = {};\r\n    // this.invoiceQInit();\r\n    this.allEquationFields = new BehaviorSubject<string[]>([]);\r\n\r\n    this.updateEquationOptions();\r\n  }\r\n\r\n  formatTimeToDate(v: any){\r\n    const fromTime: Date = new Date();\r\n    if (v) {\r\n      let split = v.split(\":\");\r\n      fromTime.setHours(split[0], split[1]);\r\n    }\r\n    return new Date(fromTime.getTime());\r\n  }\r\n\r\n  patchLookupValue($event: LookupItem, fieldName: string) {\r\n    if ($event?.id !== -1 && this.defaults) {\r\n      // @ts-ignore\r\n      this.defaults[fieldName] = this.formParam.get(fieldName).value;\r\n    }\r\n  }\r\n  getBankName(fieldName: string) {\r\n    //TODO Batool do we need this here ?\r\n    if (this.formParam.get(fieldName).value?.length > 10 && !isNaN(this.formParam.get(fieldName).value) ) {\r\n      return ' / ' + this.translateService.instant('BANK.' + this.formParam.get(fieldName).value?.substr(4, 4));\r\n    } else {\r\n      return '';\r\n    }\r\n  }\r\n\r\n  patchMultiSelectValue($event: LookupItem[], fieldName: string) {\r\n    if ($event?.length >= 0 && this.defaults) {\r\n      this.defaults[fieldName] = this.formParam.get(fieldName).value;\r\n    }\r\n  }\r\n\r\n  ngOnChanges({item, errors, fields}: SimpleChanges): void {\r\n    errors?.currentValue?.forEach((msg: FieldMessage) => {\r\n      this.formParam.get(msg.fieldName)?.setErrors({serverError: msg.message});\r\n    });\r\n\r\n    if (item?.currentValue && !item.isFirstChange()){\r\n      this.defaults = item.currentValue;\r\n    }\r\n\r\n    if (fields?.currentValue && !fields.isFirstChange()){\r\n      this.buildForm();\r\n    }\r\n  }\r\n\r\n  showField(item: any, field: any) {\r\n    return (item.id || (!item.id && !field.updateOnly)) && field.visible\r\n  }\r\n\r\n  workflowEditableField(field: { property: string; }) {\r\n    const x = this.isWorkflowEditableManaged ? this.workflowEditableFields?.findIndex(d => d === field.property) > -1 : true;\r\n    return x;\r\n  }\r\n\r\n  showMultiSelectValuesAsReadonly(field: FieldInfo) {\r\n    const viewProp = this.translateService.getDefaultLang() === 'en' ? 'englishName' : 'arabicName';\r\n    return this.extractFieldName(this.defaults,field.property)?.map((a: { [x: string]: any; }) => a[viewProp]);\r\n  }\r\n\r\n  splitReadonly(values: any) {\r\n    return !values || values === '' ? []: values.split(';');\r\n  }\r\n\r\n\r\n  referenceAttributeTrue(fieldName: string, attribute: any) {\r\n    // return this.authService.referenceAttributeTrue(fieldName, this.pageInfo.processId, attribute);\r\n  }\r\n\r\n  translateLable(itemElement: any) {\r\n    return this.translateService.instant(itemElement)\r\n  }\r\n\r\n  buildForm() {\r\n    if (!this.fields || this.fields.length === 0 || !this.defaults) return;\r\n\r\n    if (!this.formParam) {\r\n      this.formParam = this.fb.group(buildFormFields(this.fields, this.defaults));\r\n      // Emit initial form reference\r\n      this.formUpdated.next(this.formParam);\r\n      // Emit on every value change so parent components can react live\r\n      if (this.emitOnValueChanges) {\r\n        this.formParam.valueChanges.subscribe(() => {\r\n          this.formUpdated.emit(this.formParam);\r\n        });\r\n      }\r\n      return;\r\n    }\r\n\r\n    const patchValues: any = {};\r\n    for (const field of this.fields) {\r\n      if (field.readonly) {\r\n        this.formParam.get(field.property)?.disable({ emitEvent: false });\r\n      } else {\r\n        this.formParam.get(field.property)?.enable({ emitEvent: false });\r\n      }\r\n      if (field.type !== 'spacer') {\r\n        patchValues[field.property] = extractFieldName(this.defaults, field.property);\r\n      }\r\n    }\r\n\r\n    this.formParam.patchValue(patchValues, { emitEvent: false });\r\n  }\r\n\r\n  labelKey(column: any) {\r\n    const configuredKey = column.label ? column.label : column.property\r\n    return configuredKey.startsWith(this.pageInfo.labelsSection) ? `${configuredKey}` : `${this.pageInfo.labelsSection}.${configuredKey}`;\r\n  }\r\n\r\n  labelKeyPlaceHolder(column: any) {\r\n    const configuredKey = column.placeholder ? column.placeholder : column.property\r\n    return configuredKey.startsWith(this.pageInfo.labelsSection) ? `${configuredKey}` : `${this.pageInfo.labelsSection}.${configuredKey}`;\r\n  }\r\n\r\n  getErrors(prop: string): string {\r\n    const control = this.formParam.get(prop);\r\n    if (!control || control.disabled) return '';\r\n\r\n    const field = this.fields.find(f => f.property === prop);\r\n\r\n    if (!field?.validationMessages) {\r\n      if (control.value && control.status !== 'VALID' && this.getFirstErrorKey) {\r\n        return this.getFirstErrorKey(prop);\r\n      }\r\n      return '';\r\n    }\r\n\r\n    if (control.invalid) {\r\n      const errors = control.errors || {};\r\n      const prefix = this.pageInfo.labelsSection + \".\";\r\n\r\n      if (errors['required']) return prefix + 'REQUIRED';\r\n      if (errors['min']) return prefix + (field.validationMessages?.min || 'NUMBER_MIN');\r\n      if (errors['max']) return prefix + (field.validationMessages?.max || 'NUMBER_MAX');\r\n      if (errors['maxlength']) return prefix + (field.validationMessages?.maxlength || 'MAX_LENGTH');\r\n      if (errors['decimalMin']) return prefix + (field.validationMessages?.decimalMin || 'DECIMAL_MIN');\r\n      if (errors['decimalMax']) return prefix + (field.validationMessages?.decimalMax || 'DECIMAL_MAX');\r\n      if (errors['pattern']) return prefix + (field.validationMessages?.pattern || 'INVALID_FORMAT');\r\n      if (errors['invalidMathExpression']) return prefix + 'INVALID_MATH';\r\n      if (errors['serverError']) return prefix + errors['serverError'];\r\n\r\n      return prefix + 'INVALID_VALUE';\r\n    }\r\n\r\n    return '';\r\n  }\r\n\r\n\r\n  getFirstErrorKey(prop: string): string {\r\n    const errors = this.formParam.get(prop)?.errors;\r\n\r\n    if (!errors || Object.keys(errors).length === 0) {\r\n      return errors?.['serverError'] || 'INVALID_FORMAT';\r\n    }\r\n\r\n    return Object.keys(errors)[0];\r\n  }\r\n\r\n  public getCountryCodeList() {\r\n    return ['af', 'ax', 'al', 'dz', 'as', 'ad', 'ao', 'ai', 'aq', 'ag', 'ar', 'am', 'aw', 'au', 'at', 'az',\r\n      'bs', 'bh', 'bd', 'bb', 'by', 'be', 'bz', 'bj', 'bm', 'bt', 'bo', 'ba', 'bw', 'bv', 'br', 'io', 'bn',\r\n      'bg', 'bf', 'bi', 'kh', 'cm', 'ca', 'cv', 'ky', 'cf', 'td', 'cl', 'cn', 'cx', 'cc', 'co', 'km', 'cg',\r\n      'cd', 'ck', 'cr', 'ci', 'hr', 'cu', 'cy', 'cz', 'dk', 'dj', 'dm', 'do', 'ec', 'eg', 'sv', 'gq', 'er',\r\n      'ee', 'et', 'fk', 'fo', 'fj', 'fi', 'fr', 'gf', 'pf', 'tf', 'ga', 'gm', 'ge', 'de', 'gh', 'gi', 'gr',\r\n      'gl', 'gd', 'gp', 'gu', 'gt', 'gg', 'gn', 'gw', 'gy', 'ht', 'hm', 'va', 'hn', 'hk', 'hu', 'is', 'in',\r\n      'id', 'ir', 'iq', 'ie', 'im', 'it', 'jm', 'jp', 'je', 'jo', 'kz', 'ke', 'ki', 'kr', 'kw', 'kg', 'la',\r\n      'lv', 'lb', 'ls', 'lr', 'ly', 'li', 'lt', 'lu', 'mo', 'mk', 'mg', 'mw', 'my', 'mv', 'ml', 'mt', 'mh',\r\n      'mq', 'mr', 'mu', 'yt', 'mx', 'fm', 'md', 'mc', 'mn', 'me', 'ms', 'ma', 'mz', 'mm', 'na', 'nr', 'np',\r\n      'nl', 'an', 'nc', 'nz', 'ni', 'ne', 'ng', 'nu', 'nf', 'mp', 'no', 'om', 'pk', 'pw', 'ps', 'pa', 'pg',\r\n      'py', 'pe', 'ph', 'pn', 'pl', 'pt', 'pr', 'qa', 're', 'ro', 'ru', 'rw', 'bl', 'sh', 'kn', 'lc', 'mf',\r\n      'pm', 'vc', 'ws', 'sm', 'st', 'sa', 'sn', 'rs', 'sc', 'sl', 'sg', 'sk', 'si', 'sb', 'so', 'za', 'gs',\r\n      'es', 'lk', 'sd', 'sr', 'sj', 'sz', 'se', 'ch', 'sy', 'tw', 'tj', 'tz', 'th', 'tl', 'tg', 'tk', 'to',\r\n      'tt', 'tn', 'tr', 'tm', 'tc', 'tv', 'ug', 'ua', 'ae', 'gb', 'us', 'um', 'uy', 'uz', 'vu', 've', 'vn',\r\n      'vg', 'vi', 'wf', 'eh', 'ye', 'zm', 'zw'];\r\n  }\r\n\r\n\r\n  friendlyName(fullPath: string , subPath: string , item: string){\r\n    return  fullPath.substring(0, fullPath.indexOf(subPath)) + item ;\r\n  }\r\n\r\n  showValue(defaults, field){\r\n    return  this.friendlyName(field.label , field.property , defaults[field.property]);\r\n  }\r\n\r\n  showError(prop: string) {\r\n    return (this.formParam?.get(prop)?.value || this.formParam?.get(prop)?.value == 0)\r\n      && this.formParam.get(prop).status  === 'INVALID';\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.defaults = null;\r\n  }\r\n\r\n  private extractLables() {\r\n    this.fields.forEach(f => {\r\n      if (f.visible) {\r\n        f.label = this.labelKey(f);\r\n\r\n        if (!this.screenFields.has(f.row)) {\r\n          this.screenFields.set(f.row, []);\r\n        }\r\n        this.screenFields.get(f.row)!.push(f);\r\n\r\n        if (f.cascadedBy) {\r\n          this.formParam?.get(f.cascadedBy)?.valueChanges.subscribe(() => {\r\n            this.formParam?.get(f.property)?.patchValue(null);\r\n          })\r\n        }\r\n      }\r\n    });\r\n\r\n    for (let i = 1; i < this.screenFields.size; i++) {\r\n      this.calcFlexSize(i);\r\n    }\r\n    // console.log(this.screenFields)\r\n  }\r\n\r\n  private calcFlexSize(i: number){\r\n    // Preserve explicit fieldSize values only. For fields without fieldSize, allow\r\n    // the layout to auto-size via flex (handled in the template/CSS).\r\n    // Intentionally do nothing here so that unspecified fields remain flexible.\r\n    return;\r\n  }\r\n\r\n  getCurrencyPattern(field: FieldInfo) {\r\n    // const decimalPlaces  = this.authService?.myCurrencies?.find(c => c.key === this.formParam.get(field.currency)?.value)?.currencyNumOfDecimalPattern || 3;\r\n    const decimalPlaces  = 3;\r\n    return '^\\\\d*(?:[.,]\\\\d{1,' + decimalPlaces + '})?$';\r\n  }\r\n\r\n  splittedChips(form: FormGroup, fieldName: string):string[] {\r\n    return form.get(fieldName).value === '' ? []: form.get(fieldName).value.trim().split(';');\r\n  }\r\n\r\n\r\n  fixArabicNumbers(str: any) {\r\n    // if(typeof str === 'string') {\r\n    //     str = str.replace(/([٠١٢٣٤٥٦٧٨٩])|([۰۱۲۳۴۵۶۷۸۹])/g, (m, $1, $2) => m.charCodeAt(0) - ($1 ? 1632 : 1776));\r\n    // }\r\n    // console.log(str);\r\n  }\r\n\r\n  listShowValue(defaults: any, field: FieldInfo) {\r\n    return defaults[field.property] ? this.showValue(defaults, field) : '';\r\n  }\r\n\r\n  removeChipsItem(form: FormGroup, fieldName: string, idx: number) {\r\n    const emails = this.splittedChips(form, fieldName);\r\n    if (emails.length >= 1){\r\n      emails.splice(idx,1);\r\n    }\r\n    let cleanedEmails = emails.join(\";\");\r\n    form.get(fieldName).setValue(cleanedEmails);\r\n  }\r\n\r\n  extractFieldName(element: any, property: string) {\r\n    if (property?.includes('.')) {\r\n      return property.split('.').reduce((acc, part) => acc && acc[part], element);\r\n    } else {\r\n      return element[property];\r\n    }\r\n  }\r\n\r\n  getMultiValue(field: FieldInfo) {\r\n    return this.formParam.get(field.property)?.value;\r\n  }\r\n\r\n  private validateEmail(email) {\r\n    var re = /^(([^<>()\\[\\]\\\\.,;:\\s@\"]+(\\.[^<>()\\[\\]\\\\.,;:\\s@\"]+)*)|(\".+\"))@((\\[[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}\\])|(([a-zA-Z\\-0-9]+\\.)+[a-zA-Z]{2,}))$/;\r\n    return re.test(String(email).toLowerCase());\r\n  }\r\n\r\n  addEmailToChips(event: MatChipInputEvent, form: FormGroup, fieldName: string) {\r\n\r\n    const input = event.input;\r\n    const value = event.value;\r\n    const items = value.split(';');\r\n    // value.split(' ');\r\n    items.forEach(itm => {\r\n      if (this.validateEmail((itm || '').trim())) {\r\n        const x = this.splittedChips(form, fieldName);\r\n        x.push(itm);\r\n        form.get(fieldName).patchValue(x.join(';'));\r\n        if (input) {\r\n          input.value = '';\r\n        }\r\n      }\r\n    });\r\n\r\n  }\r\n\r\n  extractJsonFieldName(defaults: any, property: string) {\r\n    const x= this.extractFieldName(defaults, property);\r\n    if (x?.length > 0)\r\n      return JSON.parse(x);\r\n    else return '{}';\r\n  }\r\n\r\n  getOptionValue(item: any) {\r\n    const value = typeof item === 'object' ?\r\n        this.translateService.getDefaultLang() === 'en' ? item.englishName : item.arabicName\r\n        : item;\r\n    return value;\r\n  }\r\n\r\n  getHyperTextEvent() {\r\n    this.hyperTextEvent.emit(true);\r\n  }\r\n\r\n  add(event: MatChipInputEvent): void {\r\n    const value = (event.value || '').trim();\r\n    if (value) {\r\n      if (this.equationOperators.includes(value) || !this.equationValues().includes(value)) {\r\n        this.equationValues.update(equationValues => [...equationValues, value]);\r\n      }\r\n    }\r\n\r\n    this.fieldsInput.nativeElement.value = '';\r\n    this.currentEquationValue.set('');\r\n    this.updateEquationOptions();\r\n\r\n  }\r\n\r\n  remove(item: string, index: number): void {\r\n    this.equationValues.update(equationValues => {\r\n      if (index < 0) {\r\n        return equationValues;\r\n      }\r\n\r\n      equationValues.splice(index, 1);\r\n      this.announcer.announce(`Removed ${item}`);\r\n      return [...equationValues];\r\n    });\r\n    this.updateEquationOptions();\r\n  }\r\n\r\n  selected(event: MatAutocompleteSelectedEvent): void{\r\n    const selectedValue = event.option.viewValue.trim();\r\n\r\n    if (!this.equationOperators.includes(selectedValue) && !this.equationValues().includes(selectedValue)) {\r\n      this.equationValues.update(equationValues => [...equationValues, selectedValue]);\r\n    } else if (this.equationOperators.includes(selectedValue)) {\r\n      this.equationValues.update(equationValues => [...equationValues, selectedValue]);\r\n    }\r\n\r\n    this.currentEquationValue.set('');\r\n    event.option.deselect();\r\n    this.fieldsInput.nativeElement.value = '';\r\n    this.updateEquationOptions();\r\n  }\r\n\r\n  updateEquationOptions(){\r\n    this.reflectEquationValueOnForm();\r\n\r\n    let updatedFields: string[];\r\n    if (this.equationValues().length === 0) {\r\n      updatedFields = this.getNamesFromSuggestedEquationFields();\r\n    } else {\r\n      let lastElement = this.equationValues()[this.equationValues().length - 1];\r\n      if (this.equationOperators.includes(lastElement)) {\r\n        updatedFields = this.getNamesFromSuggestedEquationFields();\r\n      } else {\r\n        updatedFields = this.equationOperators;\r\n      }\r\n    }\r\n    // console.log('*****', updatedFields);\r\n    this.allEquationFields.next(updatedFields);\r\n  }\r\n\r\n  getNamesFromSuggestedEquationFields(): string[] {\r\n    return this.equationSuggestedFields?.map(field => field.name);\r\n  }\r\n\r\n  reflectEquationValueOnForm() {\r\n    if (this.formParam && this.formParam.get('fieldValue')) {\r\n      this.formParam.get('fieldValue').setValue(this.equationValues());\r\n    } else {\r\n      // console.log('Form or fieldValue is not available.');\r\n    }\r\n  }\r\n\r\n  checkEquation(field: FieldInfo, $event: Event) {\r\n    // console.log('$event', $event);\r\n    // try {\r\n    //   evaluate(equation.replace(/[a-zA-Z0-9]+/g, '1')); // Replace variables with dummy values\r\n    //   this.formGroups[index].get('xyz').setErrors(null);\r\n    //   console.log('valid ', equation)\r\n    // } catch (e) {\r\n    //   this.formGroups[index].get('xyz').setErrors({serverError: 'incomplete '});\r\n    //   console.log('bad ', equation)\r\n    // }\r\n  }\r\n\r\n  getView(field): 'month' | 'year' | 'multi-year' {\r\n    return field.pattern || 'month';\r\n  }\r\n\r\n  setMonthAndYear(normalizedMonthAndYear: Moment, picker: MatDatepicker<Moment>, field) {\r\n    console.log('field.pattern', field.pattern)\r\n    if (field.pattern === 'multi-year') {\r\n      console.log('hi')\r\n      const date = new FormControl(moment());\r\n      const ctrlValue = date.value;\r\n      ctrlValue.year(normalizedMonthAndYear.year());\r\n      ctrlValue.month(1);\r\n      ctrlValue.dayOfYear(1);\r\n      this.formParam.get(field.property).setValue(ctrlValue)\r\n      picker.close();\r\n    }\r\n  }\r\n}\r\n\r\n","<div class=\"main-form-canvas\">\r\n  <div class=\"form-wrapper\">\r\n    <ng-container *ngIf=\"defaults\">\r\n      <ng-container *ngIf=\"editable; else readonlyView\" class=\"form-container\">\r\n        <form [formGroup]=\"formParam\" class=\"form-content\">\r\n          <div class=\"form-row\">\r\n            <div class=\"form-column\">\r\n              <ng-container *ngFor=\"let row of screenFields | keyvalue\">\r\n                <div class=\"row-container\">\r\n                  <ng-container *ngFor=\"let field of row.value\">\r\n                    <div class=\"field-column\" [style.flex]=\"field.fieldSize ? ('0 0 ' + field.fieldSize + '%') : '1 1 0'\">\r\n                      <ng-container [ngSwitch]=\"field.type\">\r\n                        <ng-container *ngSwitchCase=\"'date'\">\r\n                          <ng-container *ngIf=\"showField(defaults, field)\">\r\n                            <ng-container *ngIf=\"workflowEditableField(field)\">\r\n                              <div class=\"label-and-asterisk-container\">\r\n        <span *ngIf=\"!field.hideLabel\" class=\"custom-label\" id=\"label-{{field.property}}\">\r\n          {{ field.label! | translate }}\r\n        </span>\r\n                                <span *ngIf=\"field.required\" class=\"required-asterisk\"> * </span>\r\n                              </div>\r\n\r\n                              <mat-form-field appearance=\"outline\">\r\n                                <input matInput\r\n                                       [matDatepicker]=\"picker\"\r\n                                       [value]=\"formParam.get(field.property)?.value\"\r\n                                       (dateChange)=\"formParam.get(field.property).setValue($event.value)\"\r\n                                       [placeholder]=\"field.placeholder ? (labelKeyPlaceHolder(field) | translate) : ''\"\r\n                                       [readonly]=\"field.readonly\"\r\n                                       formControlName=\"{{field.property}}\"\r\n                                       [required]=\"field.required\"\r\n                                       [attr.aria-invalid]=\"showError(field.property)\"\r\n                                       [attr.aria-labelledby]=\"'label-' + field.property\"\r\n                                       [attr.aria-describedby]=\"'error-' + field.property\">\r\n\r\n                                <mat-datepicker-toggle matSuffix [for]=\"picker\"></mat-datepicker-toggle>\r\n\r\n                                <mat-datepicker #picker\r\n                                                [startView]=\"getView(field)\"\r\n                                                (yearSelected)=\"setMonthAndYear($event, picker, field)\"\r\n                                                panelClass=\"example-month-picker\">\r\n                                </mat-datepicker>\r\n\r\n                                <mat-error *ngIf=\"showError(field.property)\" aria-live=\"assertive\">\r\n                                  {{ getErrors(field.property) | translate }}\r\n                                </mat-error>\r\n                              </mat-form-field>\r\n\r\n                            </ng-container>\r\n                          </ng-container>\r\n                        </ng-container>\r\n\r\n                        <ng-container *ngSwitchCase=\"'phone-number'\">\r\n                          <ng-container *ngIf=\"showField(defaults, field)\">\r\n                            <ng-container class=\"custom-ngx-mat-intl-tel-input\" *ngIf=\"workflowEditableField(field)\">\r\n                              <div class=\"label-and-asterisk-container\">\r\n                                                      <span *ngIf=\"!field.hideLabel\" class=\"custom-label\" id=\"label-{{field.property}}\">\r\n                                                        {{ field.label! | translate }}\r\n                                                      </span>\r\n                                <span *ngIf=\"field.required\" class=\"required-asterisk\"> * </span>\r\n                              </div>\r\n                              <mat-form-field appearance=\"outline\">\r\n                                <div class=\"phone-input-wrapper\">\r\n                                  <ngx-mat-intl-tel-input\r\n                                    formControlName=\"{{ field.property }}\"\r\n                                    [inputPlaceholder]=\"field.placeholder ? (labelKeyPlaceHolder(field) | translate) : ''\"\r\n                                    [preferredCountries]=\"['qa']\"\r\n                                    [enablePlaceholder]=\"true\"\r\n                                    [enableSearch]=\"true\"\r\n                                    [onlyCountries]=\"getCountryCodeList()\"\r\n                                    [required]=\"field.required\"\r\n                                    [attr.aria-required]=\"field.required\"\r\n                                    [attr.aria-invalid]=\"showError(field.property)\"\r\n                                    [attr.aria-labelledby]=\"'label-' + field.property\"\r\n                                    [attr.aria-describedby]=\"'error-' + field.property\">\r\n                                  </ngx-mat-intl-tel-input>\r\n                                </div>\r\n\r\n                                <mat-error\r\n                                  id=\"error-{{ field.property }}\"\r\n                                  *ngIf=\"showError(field.property)\"\r\n                                  aria-live=\"assertive\">\r\n                                  {{ getErrors(field.property) | translate }}\r\n                                </mat-error>\r\n                              </mat-form-field>\r\n\r\n                            </ng-container>\r\n                          </ng-container>\r\n                        </ng-container>\r\n\r\n\r\n                        <ng-container *ngSwitchCase=\"'iban-text'\">\r\n                          <ng-container *ngIf=\"showField(defaults, field)\">\r\n                            <ng-container *ngIf=\"!workflowEditableField(field)\">\r\n                              <ng-container\r\n                                [ngTemplateOutlet]=\"textReadonly\"\r\n                                [ngTemplateOutletContext]=\"{ field: field }\">\r\n                              </ng-container>\r\n                            </ng-container>\r\n\r\n                            <ng-container *ngIf=\"workflowEditableField(field)\">\r\n                              <div class=\"label-and-asterisk-container\">\r\n                                                      <span *ngIf=\"!field.hideLabel\" class=\"custom-label\" id=\"label-{{field.property}}\">\r\n                                                        {{ field.label! | translate }}\r\n                                                      </span>\r\n                                <span *ngIf=\"field.required\" class=\"required-asterisk\"> * </span>\r\n                              </div>\r\n                              <mat-form-field appearance=\"outline\">\r\n                                <input class=\"app-input\"\r\n                                       formControlName=\"{{ field.property }}\"\r\n                                       matInput\r\n                                       [placeholder]=\"field.placeholder ? (labelKeyPlaceHolder(field) | translate) : ''\"\r\n                                       [readonly]=\"field.readonly\"\r\n                                       [required]=\"field.required\"\r\n                                       [attr.aria-required]=\"field.required\"\r\n                                       [attr.aria-invalid]=\"showError(field.property)\"\r\n                                       [attr.aria-labelledby]=\"'label-' + field.property\"\r\n                                       [attr.aria-describedby]=\"'error-' + field.property\">\r\n                                <mat-error\r\n                                  id=\"error-{{ field.property }}\"\r\n                                  *ngIf=\"showError(field.property)\"\r\n                                  aria-live=\"assertive\">\r\n                                  {{ getErrors(field.property) | translate }}\r\n                                </mat-error>\r\n                              </mat-form-field>\r\n\r\n\r\n                            </ng-container>\r\n                          </ng-container>\r\n                        </ng-container>\r\n\r\n                        <ng-container *ngSwitchCase=\"'password'\">\r\n                          <ng-container *ngIf=\"showField(defaults, field)\">\r\n                            <div class=\"label-and-asterisk-container\">\r\n                                                      <span *ngIf=\"!field.hideLabel\" class=\"custom-label\" id=\"label-{{field.property}}\">\r\n                                                        {{ field.label! | translate }}\r\n                                                      </span>\r\n                              <span *ngIf=\"field.required\" class=\"required-asterisk\"> * </span>\r\n                            </div>\r\n                            <mat-form-field appearance=\"outline\">\r\n                              <input matInput\r\n                                     class=\"app-input\"\r\n                                     formControlName=\"{{ field.property }}\"\r\n                                     [type]=\"hide && !field.disabled ? 'password' : 'text'\"\r\n                                     [readonly]=\"field.readonly\"\r\n                                     [required]=\"field.required\"\r\n                                     [placeholder]=\"field.placeholder ? (labelKeyPlaceHolder(field) | translate) : ''\"\r\n                                     [attr.aria-required]=\"field.required\"\r\n                                     [attr.aria-invalid]=\"showError(field.property)\"\r\n                                     [attr.aria-labelledby]=\"'label-' + field.property\"\r\n                                     [attr.aria-describedby]=\"'error-' + field.property\">\r\n                              <!--                                                    <mat-icon matSuffix-->\r\n                              <!--                                                              (click)=\"hide = !hide\">-->\r\n                              <!--                                                      {{ hide ? 'visibility_off' : 'visibility' }}-->\r\n                              <!--                                                    </mat-icon>-->\r\n                              <mat-error\r\n                                id=\"error-{{ field.property }}\"\r\n                                *ngIf=\"showError(field.property)\"\r\n                                aria-live=\"assertive\">\r\n                                {{ getErrors(field.property) | translate }}\r\n                              </mat-error>\r\n                            </mat-form-field>\r\n                          </ng-container>\r\n                        </ng-container>\r\n\r\n                        <ng-container *ngSwitchCase=\"'text'\">\r\n                          <ng-container *ngIf=\"showField(defaults, field)\">\r\n                            <ng-container *ngIf=\"!workflowEditableField(field)\">\r\n                              <ng-container\r\n                                [ngTemplateOutlet]=\"textReadonly\"\r\n                                [ngTemplateOutletContext]=\"{ field: field }\">\r\n                              </ng-container>\r\n                            </ng-container>\r\n\r\n                            <ng-container *ngIf=\"workflowEditableField(field)\">\r\n                              <div class=\"label-and-asterisk-container\">\r\n                                                      <span *ngIf=\"!field.hideLabel\" class=\"custom-label\" id=\"label-{{field.property}}\">\r\n                                                        {{ field.label! | translate }}\r\n                                                      </span>\r\n                                <span *ngIf=\"field.required\" class=\"required-asterisk\"> * </span>\r\n                              </div>\r\n                              <mat-form-field appearance=\"outline\">\r\n                                <input class=\"app-input\"\r\n                                       formControlName=\"{{ field.property }}\"\r\n                                       matInput\r\n                                       [placeholder]=\"field.placeholder ? (labelKeyPlaceHolder(field) | translate) : ''\"\r\n                                       [readonly]=\"field.readonly\"\r\n                                       [required]=\"field.required\"\r\n                                       (keyup)=\"fixArabicNumbers($event.target)\"\r\n                                       [attr.aria-required]=\"field.required\"\r\n                                       [attr.aria-invalid]=\"showError(field.property)\"\r\n                                       [attr.aria-labelledby]=\"'label-' + field.property\"\r\n                                       [attr.aria-describedby]=\"'error-' + field.property\">\r\n                                <mat-error\r\n                                  id=\"error-{{ field.property }}\"\r\n                                  *ngIf=\"showError(field.property)\"\r\n                                  aria-live=\"assertive\">\r\n                                  {{ getErrors(field.property) | translate }}\r\n                                </mat-error>\r\n                              </mat-form-field>\r\n\r\n\r\n                            </ng-container>\r\n                          </ng-container>\r\n                        </ng-container>\r\n\r\n                        <ng-container *ngSwitchCase=\"'chip-list'\">\r\n                          <ng-container *ngIf=\"showField(defaults, field)\">\r\n                            <div class=\"label-and-asterisk-container\">\r\n                                                      <span *ngIf=\"!field.hideLabel\" class=\"custom-label\" id=\"label-{{field.property}}\">\r\n                                                        {{ field.label! | translate }}\r\n                                                      </span>\r\n                              <span *ngIf=\"field.required\" class=\"required-asterisk\"> * </span>\r\n                            </div>\r\n                            <mat-form-field appearance=\"outline\">\r\n\r\n                              <mat-chip-grid [attr.aria-labelledby]=\"'label-' + field.property\"\r\n                                             formControlName=\"{{ field.property }}\">\r\n                                <mat-chip-row\r\n                                  *ngFor=\"let mail of splittedChips(formParam, field.property); let idx = index\"\r\n                                  [removable]=\"removable\"\r\n                                  (removed)=\"removeChipsItem(formParam, field.property, idx)\">\r\n                                  {{ mail }}\r\n                                  <mat-icon matChipRemove *ngIf=\"removable\">cancel</mat-icon>\r\n                                </mat-chip-row>\r\n\r\n                                <input [attr.aria-labelledby]=\"'label-' + field.property\" [matChipInputFor]=\"null\"\r\n                                       [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\"\r\n                                       [matChipInputAddOnBlur]=\"addOnBlur\"\r\n                                       (matChipInputTokenEnd)=\"addEmailToChips($event, formParam, field.property)\">\r\n                              </mat-chip-grid>\r\n                              <mat-error id=\"error-{{ field.property }}\" *ngIf=\"showError(field.property)\"\r\n                                         aria-live=\"assertive\">\r\n                                {{ getErrors(field.property) | translate }}\r\n                              </mat-error>\r\n                            </mat-form-field>\r\n\r\n\r\n                          </ng-container>\r\n                        </ng-container>\r\n\r\n                        <ng-container *ngSwitchCase=\"'amount'\">\r\n                          <ng-container *ngIf=\"showField(defaults, field)\">\r\n                            <ng-container *ngIf=\"!workflowEditableField(field)\">\r\n                              <ng-container\r\n                                [ngTemplateOutlet]=\"amountReadonly\"\r\n                                [ngTemplateOutletContext]=\"{ field: field }\">\r\n                              </ng-container>\r\n                            </ng-container>\r\n\r\n                            <ng-container *ngIf=\"workflowEditableField(field)\">\r\n                              <div class=\"label-and-asterisk-container\">\r\n                                                      <span *ngIf=\"!field.hideLabel\" class=\"custom-label\" id=\"label-{{field.property}}\">\r\n                                                        {{ field.label! | translate }}\r\n                                                      </span>\r\n                                <span *ngIf=\"field.required\" class=\"required-asterisk\"> * </span>\r\n                              </div>\r\n                              <mat-form-field appearance=\"outline\">\r\n                                <input class=\"app-input\"\r\n                                       formControlName=\"{{ field.property }}\"\r\n                                       matInput\r\n                                       type=\"number\"\r\n                                       [placeholder]=\"field.placeholder ? (labelKeyPlaceHolder(field) | translate) : ''\"\r\n                                       [readonly]=\"field.readonly\"\r\n                                       [required]=\"field.required\"\r\n                                       [attr.aria-required]=\"field.required\"\r\n                                       [attr.aria-invalid]=\"showError(field.property)\"\r\n                                       [attr.aria-labelledby]=\"'label-' + field.property\"\r\n                                       [attr.aria-describedby]=\"'error-' + field.property\">\r\n                                <mat-error\r\n                                  id=\"error-{{ field.property }}\"\r\n                                  *ngIf=\"showError(field.property)\"\r\n                                  aria-live=\"assertive\">\r\n                                  {{ getErrors(field.property) | translate }}\r\n                                </mat-error>\r\n                              </mat-form-field>\r\n\r\n\r\n                            </ng-container>\r\n                          </ng-container>\r\n                        </ng-container>\r\n\r\n                        <ng-container *ngSwitchCase=\"'sequence'\">\r\n                          <ng-container\r\n                            *ngIf=\"referenceAttributeTrue(field.property, 'autoGenerated'); else noSequence\">\r\n                            <div class=\"label-and-asterisk-container\">\r\n                                                      <span *ngIf=\"!field.hideLabel\" class=\"custom-label\" id=\"label-{{field.property}}\">\r\n                                                        {{ field.label! | translate }}\r\n                                                      </span>\r\n                              <span *ngIf=\"field.required\" class=\"required-asterisk\"> * </span>\r\n                            </div>\r\n                            <mat-form-field appearance=\"outline\">\r\n                              <input class=\"app-input\"\r\n                                     formControlName=\"{{ field.property }}\"\r\n                                     matInput\r\n                                     [placeholder]=\"field.placeholder ? (labelKeyPlaceHolder(field) | translate) : ''\"\r\n                                     [readonly]=\"true\"\r\n                                     [disabled]=\"true\"\r\n                                     [attr.aria-labelledby]=\"'label-' + field.property\">\r\n                              <mat-error\r\n                                id=\"error-{{ field.property }}\"\r\n                                *ngIf=\"showError(field.property)\"\r\n                                aria-live=\"assertive\">\r\n                                {{ getErrors(field.property) | translate }}\r\n                              </mat-error>\r\n                            </mat-form-field>\r\n\r\n                          </ng-container>\r\n                        </ng-container>\r\n\r\n                        <ng-template #noSequence>\r\n                          <div class=\"label-and-asterisk-container\">\r\n                                                      <span *ngIf=\"!field.hideLabel\" class=\"custom-label\" id=\"label-{{field.property}}\">\r\n                                                        {{ field.label! | translate }}\r\n                                                      </span>\r\n                            <span *ngIf=\"field.required\" class=\"required-asterisk\"> * </span>\r\n                          </div>\r\n                          <mat-form-field appearance=\"outline\">\r\n                            <input class=\"app-input\"\r\n                                   formControlName=\"{{ field.property }}\"\r\n                                   matInput\r\n                                   [readonly]=\"false\"\r\n                                   [disabled]=\"false\"\r\n                                   [placeholder]=\"field.placeholder ? (labelKeyPlaceHolder(field) | translate) : ''\"\r\n                                   [required]=\"field.required\"\r\n                                   [attr.aria-labelledby]=\"'label-' + field.property\"\r\n                                   [attr.aria-required]=\"field.required\"\r\n                                   [attr.aria-invalid]=\"showError(field.property)\"\r\n                                   [attr.aria-describedby]=\"'error-' + field.property\">\r\n                            <mat-error\r\n                              id=\"error-{{ field.property }}\"\r\n                              *ngIf=\"showError(field.property)\"\r\n                              aria-live=\"assertive\">\r\n                              {{ getErrors(field.property) | translate }}\r\n                            </mat-error>\r\n                          </mat-form-field>\r\n\r\n                        </ng-template>\r\n\r\n                        <ng-container *ngSwitchCase=\"'textarea'\">\r\n                          <ng-container *ngIf=\"showField(defaults, field)\">\r\n                            <ng-container *ngIf=\"!workflowEditableField(field)\">\r\n                              <ng-container\r\n                                [ngTemplateOutlet]=\"textareaReadonly\"\r\n                                [ngTemplateOutletContext]=\"{ field: field }\">\r\n                              </ng-container>\r\n                            </ng-container>\r\n\r\n                            <ng-container *ngIf=\"workflowEditableField(field)\">\r\n                              <div class=\"label-and-asterisk-container\">\r\n                                                      <span *ngIf=\"!field.hideLabel\" class=\"custom-label\" id=\"label-{{field.property}}\">\r\n                                                        {{ field.label! | translate }}\r\n                                                      </span>\r\n                                <span *ngIf=\"field.required\" class=\"required-asterisk\"> * </span>\r\n                              </div>\r\n                              <mat-form-field appearance=\"outline\">\r\n                                                      <textarea cdkFocusInitial\r\n                                                                formControlName=\"{{ field.property }}\"\r\n                                                                matInput\r\n                                                                cdkTextareaAutosize\r\n                                                                cdkAutosizeMinRows=\"3\"\r\n                                                                [placeholder]=\"field.placeholder ? (labelKeyPlaceHolder(field) | translate) : ''\"\r\n                                                                [attr.aria-labelledby]=\"'label-' + field.property\"\r\n                                                                [attr.aria-required]=\"field.required\"\r\n                                                                [attr.aria-invalid]=\"showError(field.property)\"\r\n                                                                [attr.aria-describedby]=\"'error-' + field.property\"\r\n                                                                [readonly]=\"field.readonly\"\r\n                                                                [required]=\"field.required\"></textarea>\r\n                                <mat-error\r\n                                  id=\"error-{{ field.property }}\"\r\n                                  *ngIf=\"showError(field.property)\"\r\n                                  aria-live=\"assertive\">\r\n                                  {{ getErrors(field.property) | translate }}\r\n                                </mat-error>\r\n                              </mat-form-field>\r\n\r\n                            </ng-container>\r\n                          </ng-container>\r\n                        </ng-container>\r\n\r\n                        <ng-container *ngSwitchCase=\"'number'\">\r\n                          <ng-container *ngIf=\"showField(defaults, field)\">\r\n                            <ng-container *ngIf=\"!workflowEditableField(field)\">\r\n                              <ng-container\r\n                                [ngTemplateOutlet]=\"numberReadonly\"\r\n                                [ngTemplateOutletContext]=\"{ field: field }\">\r\n                              </ng-container>\r\n                            </ng-container>\r\n\r\n                            <ng-container *ngIf=\"workflowEditableField(field)\">\r\n                              <div class=\"label-and-asterisk-container\">\r\n                                                      <span *ngIf=\"!field.hideLabel\" class=\"custom-label\" id=\"label-{{field.property}}\">\r\n                                                        {{ field.label! | translate }}\r\n                                                      </span>\r\n                                <span *ngIf=\"field.required\" class=\"required-asterisk\"> * </span>\r\n                              </div>\r\n                              <mat-form-field appearance=\"outline\">\r\n                                <input class=\"app-input\"\r\n                                       formControlName=\"{{ field.property }}\"\r\n                                       matInput\r\n                                       type=\"number\"\r\n                                       [placeholder]=\"field.placeholder ? (labelKeyPlaceHolder(field) | translate) : ''\"\r\n                                       [attr.aria-labelledby]=\"'label-' + field.property\"\r\n                                       [attr.aria-required]=\"field.required\"\r\n                                       [attr.aria-invalid]=\"showError(field.property)\"\r\n                                       [attr.aria-describedby]=\"'error-' + field.property\"\r\n                                       [required]=\"field.readonly ? false : field.required\"\r\n                                       [readonly]=\"field.readonly\"\r\n                                       [pattern]=\"field.pattern\">\r\n                                <mat-error id=\"error-{{ field.property }}\" *ngIf=\"showError(field.property)\"\r\n                                           aria-live=\"assertive\">\r\n                                  {{ getErrors(field.property) | translate }}\r\n                                </mat-error>\r\n                              </mat-form-field>\r\n\r\n                            </ng-container>\r\n                          </ng-container>\r\n                        </ng-container>\r\n\r\n\r\n                        <ng-container *ngSwitchCase=\"'time'\">\r\n                          <ng-container *ngIf=\"showField(defaults, field)\">\r\n                            <ng-container *ngIf=\"!workflowEditableField(field)\">\r\n                              <ng-container\r\n                                [ngTemplateOutlet]=\"timeReadonly\"\r\n                                [ngTemplateOutletContext]=\"{ field: field }\">\r\n                              </ng-container>\r\n                            </ng-container>\r\n\r\n                            <ng-container *ngIf=\"workflowEditableField(field)\">\r\n                              <div class=\"label-and-asterisk-container\">\r\n                                                      <span *ngIf=\"!field.hideLabel\" class=\"custom-label\" id=\"label-{{field.property}}\">\r\n                                                        {{ field.label! | translate }}\r\n                                                      </span>\r\n                                <span *ngIf=\"field.required\" class=\"required-asterisk\"> * </span>\r\n                              </div>\r\n                              <mat-form-field appearance=\"outline\">\r\n                                <input\r\n                                  matInput\r\n                                  class=\"app-input\"\r\n                                  formControlName=\"{{ field.property }}\"\r\n                                  type=\"time\"\r\n                                  [placeholder]=\"field.placeholder ? (labelKeyPlaceHolder(field) | translate) : ''\"\r\n                                  [readonly]=\"field.readonly\"\r\n                                  [attr.aria-labelledby]=\"'label-' + field.property\"\r\n                                  [attr.aria-required]=\"field.required\"\r\n                                  [attr.aria-invalid]=\"showError(field.property)\"\r\n                                  [attr.aria-describedby]=\"'error-' + field.property\"\r\n                                  [required]=\"field.required\">\r\n                                <mat-error\r\n                                  id=\"error-{{ field.property }}\"\r\n                                  *ngIf=\"showError(field.property)\"\r\n                                  aria-live=\"assertive\">\r\n                                  {{ getErrors(field.property) | translate }}\r\n                                </mat-error>\r\n                              </mat-form-field>\r\n\r\n                            </ng-container>\r\n                          </ng-container>\r\n                        </ng-container>\r\n\r\n                        <ng-container *ngSwitchCase=\"'checkbox'\">\r\n                          <ng-container *ngIf=\"showField(defaults, field)\">\r\n                            <ng-container *ngIf=\"!workflowEditableField(field)\">\r\n                              <ng-container\r\n                                [ngTemplateOutlet]=\"checkboxReadonly\"\r\n                                [ngTemplateOutletContext]=\"{ field: field }\">\r\n                              </ng-container>\r\n                            </ng-container>\r\n\r\n                            <ng-container *ngIf=\"workflowEditableField(field)\">\r\n                              <mat-checkbox\r\n                                appearance=\"outline\"\r\n                                style=\"padding-bottom: 14px; padding-top: 14px;\"\r\n                                [disabled]=\"field.readonly\"\r\n                                [attr.aria-required]=\"field.required\"\r\n                                [attr.aria-invalid]=\"showError(field.property)\"\r\n                                formControlName=\"{{ field.property }}\">\r\n                                {{ field.label! | translate }}\r\n                                <mat-error *ngIf=\"showError(field.property)\" aria-live=\"assertive\">\r\n                                  {{ getErrors(field.property) | translate }}\r\n                                </mat-error>\r\n                              </mat-checkbox>\r\n\r\n                            </ng-container>\r\n                          </ng-container>\r\n                        </ng-container>\r\n\r\n                        <ng-container *ngSwitchCase=\"'color-picker'\">\r\n                          <ng-container *ngIf=\"showField(defaults, field)\">\r\n                            <div fxLayout=\"row\" fxLayoutAlign=\"center\">\r\n                              <h4 style=\"margin-right: 10px\">{{ field.label! | translate }}</h4>\r\n                              <input\r\n                                ejs-colorpicker\r\n                                type=\"color\"\r\n                                id=\"colorpicker\"\r\n                                formControlName=\"{{ field.property }}\"\r\n                                [attr.aria-label]=\"field.label! | translate\"\r\n                                [attr.aria-required]=\"field.required\"\r\n                                [attr.aria-invalid]=\"showError(field.property)\"\r\n                              />\r\n                            </div>\r\n                            <mat-error *ngIf=\"showError(field.property)\" aria-live=\"assertive\">\r\n                              {{ getErrors(field.property) | translate }}\r\n                            </mat-error>\r\n                          </ng-container>\r\n                        </ng-container>\r\n\r\n\r\n                        <ng-container *ngSwitchCase=\"'radio-button'\">\r\n                          <ng-container *ngIf=\"showField(defaults, field)\">\r\n                            <ng-container *ngIf=\"!workflowEditableField(field)\">\r\n                              <ng-container\r\n                                [ngTemplateOutlet]=\"radioButtonReadonly\"\r\n                                [ngTemplateOutletContext]=\"{ field: field }\">\r\n                              </ng-container>\r\n                            </ng-container>\r\n                            <ng-container *ngIf=\"workflowEditableField(field)\">\r\n                              <mat-radio-group\r\n                                formControlName=\"{{field.property}}\"\r\n                                class=\"app-radio\"\r\n                                [attr.aria-label]=\"field.label! | translate\"\r\n                                [attr.aria-required]=\"field.required\"\r\n                                [attr.aria-invalid]=\"showError(field.property)\">\r\n                                <div class=\"field-row\">\r\n                                  <div class=\"field-label\">\r\n                                    <span class=\"custom-label\">{{ field.label! | translate }}</span>\r\n                                  </div>\r\n                                  <div class=\"field-input\">\r\n                                    <div class=\"radio-group-custom\">\r\n                                      <mat-radio-button\r\n                                        *ngFor=\"let option of field.listOptions\"\r\n                                        [value]=\"option\"\r\n                                        [attr.aria-labelledby]=\"option\">\r\n                                        {{ option | translate }}\r\n                                      </mat-radio-button>\r\n                                    </div>\r\n                                  </div>\r\n                                </div>\r\n\r\n                                <mat-error\r\n                                  *ngIf=\"showError(field.property)\"\r\n                                  aria-live=\"assertive\">\r\n                                  {{ getErrors(field.property) | translate }}\r\n                                </mat-error>\r\n                              </mat-radio-group>\r\n\r\n                            </ng-container>\r\n                          </ng-container>\r\n                        </ng-container>\r\n\r\n                        <ng-container *ngSwitchCase=\"'list'\">\r\n                          <ng-container *ngIf=\"showField(defaults, field)\">\r\n                            <ng-container *ngIf=\"!workflowEditableField(field)\">\r\n                              <ng-container\r\n                                [ngTemplateOutlet]=\"listReadonly\"\r\n                                [ngTemplateOutletContext]=\"{ field: field }\">\r\n                              </ng-container>\r\n                            </ng-container>\r\n                            <ng-container *ngIf=\"workflowEditableField(field)\">\r\n                              <div class=\"label-and-asterisk-container\">\r\n                                                      <span *ngIf=\"!field.hideLabel\" class=\"custom-label\" id=\"label-{{field.property}}\">\r\n                                                        {{ field.label! | translate }}\r\n                                                      </span>\r\n                                <span *ngIf=\"field.required\" class=\"required-asterisk\"> * </span>\r\n                              </div>\r\n                              <mat-form-field appearance=\"outline\" style=\"width: 100%\">\r\n                                <mat-select\r\n                                  formControlName=\"{{field.property}}\"\r\n                                  [attr.aria-label]=\"field.label! | translate\"\r\n                                  [attr.aria-required]=\"field.required\"\r\n                                  [placeholder]=\"field.placeholder ? (labelKeyPlaceHolder(field) | translate) : ''\"\r\n                                  [attr.aria-invalid]=\"showError(field.property)\"\r\n                                  [disabled]=\"field.readonly\"\r\n                                  [multiple]=\"field.multi || false\"\r\n                                  [required]=\"field.readonly ? false : field.required\"\r\n                                  [(value)]=\"field.defaultListOption\">\r\n                                  <ng-container *ngIf=\"field.translate; else lookup_no_translation\">\r\n                                    <mat-option\r\n                                      *ngFor=\"let item of field.listOptions; let i = index\"\r\n                                      [value]=\"item\">\r\n                                      {{ friendlyName(field.label, field.property, item) | translate }}\r\n                                    </mat-option>\r\n                                  </ng-container>\r\n                                  <ng-template #lookup_no_translation>\r\n                                    <mat-option\r\n                                      *ngFor=\"let item of field.listOptions\"\r\n                                      [value]=\"item\">\r\n                                      {{ getOptionValue(item) }}\r\n                                    </mat-option>\r\n                                  </ng-template>\r\n                                </mat-select>\r\n                                <mat-error\r\n                                  *ngIf=\"showError(field.property)\"\r\n                                  aria-live=\"assertive\">\r\n                                  {{ getErrors(field.property) | translate }}\r\n                                </mat-error>\r\n                              </mat-form-field>\r\n\r\n                            </ng-container>\r\n                          </ng-container>\r\n                        </ng-container>\r\n\r\n                        <ng-container *ngSwitchCase=\"'attachment'\" [formGroup]=\"formParam\">\r\n                          <ng-container *ngIf=\"showField(defaults, field)\">\r\n                            <!-- Uncomment and use the attachment control when ready -->\r\n                            <!-- <ag-attachment-control\r\n                                  [allowMulti]=\"field.multi\"\r\n                                  [attachmentDefaultExternal]=\"pageInfo?.attachmentDefaultExternal\"\r\n                                  [supportedTypes]=\"field.supportedTypes\"\r\n                                  [buttonType]=\"field.buttonType\"\r\n                                  [hideListOfFiles]=\"field.hideFiles\"\r\n                                  (filesList)=\"updateFilesList($event, field)\"\r\n                                  (actionExecuted)=\"actionExecuted($event, field)\"\r\n                                  style=\"margin-top: 5px\"\r\n                                  label=\"{{field.label! | translate}}\">\r\n                            </ag-attachment-control> -->\r\n                            <mat-error class=\"iq-error\"\r\n                                       *ngIf=\"showError(field.property)\"\r\n                                       aria-live=\"assertive\">\r\n                              {{ getErrors(field.property) | translate }}\r\n                            </mat-error>\r\n                          </ng-container>\r\n                        </ng-container>\r\n\r\n                        <ng-container *ngSwitchCase=\"'lookup'\" [formGroup]=\"formParam\">\r\n                          <ng-container *ngIf=\"showField(defaults, field)\">\r\n                            <ng-container *ngIf=\"!workflowEditableField(field)\">\r\n                              <ng-container\r\n                                [ngTemplateOutlet]=\"lookupReadonly\"\r\n                                [ngTemplateOutletContext]=\"{ field: field }\">\r\n                              </ng-container>\r\n                            </ng-container>\r\n                            <ng-container *ngIf=\"workflowEditableField(field)\">\r\n                              <app-auto-complete\r\n                                [form]=\"formParam\"\r\n                                [field]=\"field\"\r\n                                [supportingAttributes]=\"supportingAttributes\"\r\n                                [defaultValue]=\"this.formParam.get(field.property)?.value\"\r\n                                (selectedValue)=\"patchLookupValue($event, field.property)\">\r\n                                <mat-error\r\n                                  *ngIf=\"showError(field.property)\"\r\n                                  aria-live=\"assertive\">\r\n                                  {{ getErrors(field.property) | translate }}\r\n                                </mat-error>\r\n                              </app-auto-complete>\r\n\r\n                            </ng-container>\r\n                          </ng-container>\r\n                        </ng-container>\r\n\r\n                        <ng-container *ngSwitchCase=\"'currency'\" [formGroup]=\"formParam\">\r\n                          <ng-container *ngIf=\"showField(defaults, field)\">\r\n                            <ng-container *ngIf=\"!workflowEditableField(field)\">\r\n                              <ng-container\r\n                                [ngTemplateOutlet]=\"currencyReadonly\"\r\n                                [ngTemplateOutletContext]=\"{ field: field }\">\r\n                              </ng-container>\r\n                            </ng-container>\r\n                            <ng-container *ngIf=\"workflowEditableField(field)\">\r\n                              <!-- Uncomment and use the currency control when ready -->\r\n                              <!-- <app-currency\r\n                                    [form]=\"formParam\"\r\n                                    [field]=\"field\"\r\n                                    [defaultValue]=\"this.formParam.get(field.property)?.value\"\r\n                                    (selectedValue)=\"patchCurrencyValue($event, field.property)\">\r\n                              </app-currency> -->\r\n                              <mat-error\r\n                                *ngIf=\"showError(field.property)\"\r\n                                aria-live=\"assertive\">\r\n                                {{ getErrors(field.property) | translate }}\r\n                              </mat-error>\r\n                            </ng-container>\r\n                          </ng-container>\r\n                        </ng-container>\r\n\r\n                        <ng-container *ngSwitchCase=\"'multi-select'\" [formGroup]=\"formParam\">\r\n                          <ng-container *ngIf=\"showField(defaults, field)\">\r\n                            <ng-container *ngIf=\"!workflowEditableField(field)\">\r\n                              <ng-container\r\n                                [ngTemplateOutlet]=\"multiSelectReadonly\"\r\n                                [ngTemplateOutletContext]=\"{ field: field }\">\r\n                              </ng-container>\r\n                            </ng-container>\r\n                            <ng-container *ngIf=\"workflowEditableField(field)\">\r\n                              <app-multi-auto-complete\r\n                                [form]=\"formParam\"\r\n                                [field]=\"field\"\r\n                                [defaultValue]=\"getMultiValue(field)\"\r\n                                (selectedValue)=\"patchMultiSelectValue($event, field.property)\">\r\n                                <mat-error\r\n                                  *ngIf=\"showError(field.property)\"\r\n                                  aria-live=\"assertive\">\r\n                                  {{ getErrors(field.property) | translate }}\r\n                                </mat-error>\r\n                              </app-multi-auto-complete>\r\n\r\n                            </ng-container>\r\n                          </ng-container>\r\n                        </ng-container>\r\n\r\n\r\n                        <ng-container *ngSwitchCase=\"'rich-text'\" [formGroup]=\"formParam\">\r\n                          <ng-container *ngIf=\"showField(defaults, field)\">\r\n                            <!-- Uncomment and use the rich text editor when ready -->\r\n                            <!-- <ckeditor\r\n                                  [editor]=\"Editor\"\r\n                                  [disabled]=\"field.readonly\"\r\n                                  formControlName=\"{{field.property}}\">\r\n                            </ckeditor> -->\r\n                          </ng-container>\r\n                        </ng-container>\r\n\r\n                        <ng-container *ngSwitchCase=\"'divider'\">\r\n                          <mat-divider></mat-divider>\r\n                        </ng-container>\r\n\r\n                        <ng-container *ngSwitchCase=\"'hyper-text'\">\r\n                          <div>\r\n                            <mat-label\r\n                              (click)=\"getHyperTextEvent()\"\r\n                              class=\"hyper-link\">\r\n                              {{ field.label! | translate }}\r\n                            </mat-label>\r\n                          </div>\r\n                        </ng-container>\r\n\r\n                        <ng-container *ngSwitchCase=\"'section-title'\">\r\n                          <ng-container *ngIf=\"showField(defaults, field)\">\r\n                            <div class=\"hrdivider-mid\">\r\n                              <span>{{ field.label | translate }}</span>\r\n                            </div>\r\n                          </ng-container>\r\n                        </ng-container>\r\n\r\n                        <ng-container *ngSwitchCase=\"'equation-builder'\">\r\n                          <ng-container *ngIf=\"showField(defaults, field)\">\r\n                            <ng-container *ngIf=\"!workflowEditableField(field)\">\r\n                              <ng-container\r\n                                [ngTemplateOutlet]=\"textReadonly\"\r\n                                [ngTemplateOutletContext]=\"{ field: field }\">\r\n                              </ng-container>\r\n                            </ng-container>\r\n\r\n                            <ng-container *ngIf=\"workflowEditableField(field)\">\r\n                              <div class=\"label-and-asterisk-container\">\r\n                                                      <span *ngIf=\"!field.hideLabel\" class=\"custom-label\" id=\"label-{{field.property}}\">\r\n                                                        {{ field.label! | translate }}\r\n                                                      </span>\r\n                                <span *ngIf=\"field.required\" class=\"required-asterisk\"> * </span>\r\n                              </div>\r\n                              <mat-form-field appearance=\"outline\">\r\n                                <input class=\"app-input\" dir=\"ltr\"\r\n                                       formControlName=\"{{ field.property }}\"\r\n                                       matInput\r\n                                       [placeholder]=\"field.placeholder ? (labelKeyPlaceHolder(field) | translate) : ''\"\r\n                                       [readonly]=\"field.readonly\"\r\n                                       [required]=\"field.required\"\r\n                                       [attr.aria-required]=\"field.required\"\r\n                                       [attr.aria-invalid]=\"showError(field.property)\"\r\n                                       [attr.aria-labelledby]=\"'label-' + field.property\"\r\n                                       [attr.aria-describedby]=\"'error-' + field.property\">\r\n                                <mat-error\r\n                                  id=\"error-{{ field.property }}\"\r\n                                  *ngIf=\"showError(field.property)\"\r\n                                  aria-live=\"assertive\">\r\n                                  {{ getErrors(field.property) | translate }}\r\n                                </mat-error>\r\n                              </mat-form-field>\r\n\r\n\r\n                            </ng-container>\r\n                          </ng-container>\r\n                        </ng-container>\r\n                        <!--                                              <ng-container *ngSwitchCase=\"'equation-builder'\" [formGroup]=\"formParam\">-->\r\n                        <!--                                                <ng-container *ngIf=\"showField(defaults, field)\">-->\r\n                        <!--                                                  <ng-container *ngIf=\"!workflowEditableField(field)\">-->\r\n                        <!--                                                    <ng-container-->\r\n                        <!--                                                      [ngTemplateOutlet]=\"dateReadonly\"-->\r\n                        <!--                                                      [ngTemplateOutletContext]=\"{ field: field }\">-->\r\n                        <!--                                                    </ng-container>-->\r\n                        <!--                                                  </ng-container>-->\r\n                        <!--                                                  <ng-container *ngIf=\"workflowEditableField(field)\">-->\r\n                        <!--                                                    <div style=\"display: flex; width: 350%\">-->\r\n                        <!--                                                      <mat-label>{{ field.label! | translate }}</mat-label>-->\r\n                        <!--                                                      <mat-form-field style=\"width: 400%\" appearance=\"outline\">-->\r\n                        <!--                                                        <mat-chip-grid #chipGrid>-->\r\n                        <!--                                                          <ng-container *ngFor=\"let equationValue of equationValues(); let i = index\">-->\r\n                        <!--                                                            <mat-chip-row (removed)=\"remove(equationValue, i)\">-->\r\n                        <!--                                                              {{ equationValue }}-->\r\n                        <!--                                                              <button-->\r\n                        <!--                                                                matChipRemove-->\r\n                        <!--                                                                [attr.aria-label]=\"'remove ' + equationValue\">-->\r\n                        <!--                                                                <mat-icon>cancel</mat-icon>-->\r\n                        <!--                                                              </button>-->\r\n                        <!--                                                            </mat-chip-row>-->\r\n                        <!--                                                          </ng-container>-->\r\n                        <!--                                                        </mat-chip-grid>-->\r\n                        <!--                                                        <input-->\r\n                        <!--                                                          [(ngModel)]=\"currentEquationValue\"-->\r\n                        <!--                                                          [matChipInputFor]=\"chipGrid\"-->\r\n                        <!--                                                          [matAutocomplete]=\"auto\"-->\r\n                        <!--                                                          [ngModelOptions]=\"{ standalone: true }\"-->\r\n                        <!--                                                          [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\"-->\r\n                        <!--                                                          (matChipInputTokenEnd)=\"add($event)\"-->\r\n                        <!--                                                          aria-label=\"Add equation value\" />-->\r\n                        <!--                                                        <mat-autocomplete #auto=\"matAutocomplete\" (optionSelected)=\"selected($event)\">-->\r\n                        <!--                                                          <ng-container *ngFor=\"let filteredField of (equationFilteredFields() | async)\">-->\r\n                        <!--                                                            <mat-option [value]=\"filteredField\">{{ filteredField }}</mat-option>-->\r\n                        <!--                                                          </ng-container>-->\r\n                        <!--                                                        </mat-autocomplete>-->\r\n                        <!--                                                      </mat-form-field>-->\r\n                        <!--                                                    </div>-->\r\n                        <!--                                                    <mat-error class=\"iq-error\" *ngIf=\"showError(field.property)\" aria-live=\"assertive\">-->\r\n                        <!--                                                      {{ getErrors(field.property) | translate }}-->\r\n                        <!--                                                    </mat-error>-->\r\n                        <!--                                                  </ng-container>-->\r\n                        <!--                                                </ng-container>-->\r\n                        <!--                                              </ng-container>-->\r\n\r\n                      </ng-container>\r\n                    </div>\r\n                  </ng-container>\r\n                </div>\r\n              </ng-container>\r\n            </div>\r\n          </div>\r\n        </form>\r\n      </ng-container>\r\n    </ng-container>\r\n  </div>\r\n\r\n</div>\r\n<ng-template #dateReadonly let-field=\"field\">\r\n  <div class=\"readonly-item\">\r\n    <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n    <span class=\"readonly-value\">{{ extractFieldName(defaults, field.property) | date: 'dd/MM/yyyy' }}</span>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #timeReadonly let-field=\"field\">\r\n  <div class=\"readonly-item\">\r\n    <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n    <span class=\"readonly-value\">{{ formatTimeToDate(defaults[field.property]) | date: 'shortTime' }}</span>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #phoneNumberReadonly let-field=\"field\">\r\n  <div class=\"readonly-item\">\r\n    <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n    <span class=\"readonly-value\">{{ extractFieldName(defaults, field.property) }}</span>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #textReadonly let-field=\"field\">\r\n  <div class=\"readonly-item\">\r\n    <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\" *ngIf=\"!field.advancedFilter\"></label>\r\n    <span class=\"readonly-value\">{{ extractFieldName(defaults, field.property) }}</span>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #textareaReadonly let-field=\"field\">\r\n  <ng-container *ngIf=\"field.textFormat === 'json'; else normalText\">\r\n    <div class=\"readonly-item\">\r\n      <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n      <div class=\"readonly-value json-viewer\">\r\n        <ngx-json-viewer [json]=\"extractJsonFieldName(defaults, field.property)\" [expanded]=\"true\"></ngx-json-viewer>\r\n      </div>\r\n    </div>\r\n  </ng-container>\r\n  <ng-template #normalText>\r\n    <div class=\"readonly-item\">\r\n      <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n      <span class=\"readonly-value\">{{ extractFieldName(defaults, field.property) }}</span>\r\n    </div>\r\n  </ng-template>\r\n</ng-template>\r\n\r\n<ng-template #numberReadonly let-field=\"field\">\r\n  <div class=\"readonly-item\">\r\n    <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n    <span class=\"readonly-value\">{{ extractFieldName(defaults, field.property) }}</span>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #currencyReadonly let-field=\"field\">\r\n  <div class=\"readonly-item\">\r\n    <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n    <span class=\"readonly-value\">{{ extractFieldName(defaults, field.property) }}</span>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #radioButtonReadonly let-field=\"field\">\r\n  <div class=\"readonly-item\">\r\n    <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n    <span class=\"readonly-value\">{{ translateLable(defaults[field.property]) }}</span>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #richTextReadonly let-field=\"field\">\r\n  <div class=\"readonly-item\">\r\n    <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n    <span class=\"readonly-value\" [innerHtml]=\"extractFieldName(defaults, field.property)\"></span>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #checkboxReadonly let-field=\"field\">\r\n  <div class=\"readonly-item\">\r\n    <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n    <span class=\"readonly-value\">\r\n      <mat-icon color=\"warn\" *ngIf=\"extractFieldName(defaults, field.property); else showNo\">done</mat-icon>\r\n      <ng-template #showNo>\r\n        <mat-icon color=\"warn\">close</mat-icon>\r\n      </ng-template>\r\n    </span>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #listReadonly let-field=\"field\">\r\n  <div class=\"readonly-item\">\r\n    <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n    <span class=\"readonly-value\" *ngIf=\"field.translate; else noTranslate\">\r\n      {{ listShowValue(defaults, field) | translate }}\r\n    </span>\r\n    <ng-template #noTranslate>\r\n      <span class=\"readonly-value\">{{ extractFieldName(defaults, field.property) }}</span>\r\n    </ng-template>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #sequenceReadonly let-field=\"field\">\r\n  <div class=\"readonly-item\">\r\n    <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n    <span class=\"readonly-value\">{{ extractFieldName(defaults, field.property) }}</span>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #lookupReadonly let-field=\"field\">\r\n  <div class=\"readonly-item\">\r\n    <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n    <span class=\"readonly-value\">\r\n      {{ extractFieldName(defaults, field.property)?.[translateService.getDefaultLang() === 'en' ? 'englishName' : 'arabicName'] }}\r\n    </span>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #amountReadonly let-field=\"field\">\r\n  <div class=\"readonly-item\">\r\n    <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n    <span class=\"readonly-value\">\r\n      {{ extractFieldName(defaults, field.property) | currency: currency }}\r\n    </span>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #multiSelectReadonly let-field=\"field\">\r\n  <div class=\"readonly-item\">\r\n    <label class=\"readonly-label\" [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></label>\r\n    <mat-chip-grid class=\"readonly-value chipList\">\r\n      <mat-chip *ngFor=\"let filedProp of showMultiSelectValuesAsReadonly(field)\">\r\n        {{ filedProp }}\r\n      </mat-chip>\r\n    </mat-chip-grid>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #chipListReadonly let-field=\"field\">\r\n  <div class=\"readonly-item\">\r\n    <label class=\"readonly-label\" [innerHTML]=\"field.label | translate\"></label>\r\n    <mat-chip-listbox class=\"readonly-value chipList\">\r\n      <mat-chip-option *ngFor=\"let loc of splitReadonly(extractFieldName(defaults, field.property))\"\r\n                       [selectable]=\"true\"\r\n                       color=\"warn\"\r\n                       [removable]=\"false\">\r\n        {{ loc }}\r\n      </mat-chip-option>\r\n    </mat-chip-listbox>\r\n  </div>\r\n</ng-template>\r\n\r\n\r\n<ng-template #readonlyView>\r\n  <div class=\"row-wrapper\">\r\n    <div class=\"column-wrapper\">\r\n      <ng-container *ngFor=\"let row of screenFields | keyvalue\">\r\n        <div class=\"row-container\">\r\n          <ng-container *ngFor=\"let field of row.value\">\r\n            <div class=\"field-column readonly-item\" [style.flex]=\"field.fieldSize ? ('0 0 ' + field.fieldSize + '%') : '1 1 0'\">\r\n\r\n              <ng-container [ngSwitch]=\"field.type\">\r\n\r\n                <ng-container *ngSwitchCase=\"'date'\">\r\n                  <ng-container [ngTemplateOutlet]=\"dateReadonly\"\r\n                                [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n                </ng-container>\r\n\r\n                <ng-container *ngSwitchCase=\"'time'\">\r\n                  <ng-container [ngTemplateOutlet]=\"timeReadonly\"\r\n                                [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n                </ng-container>\r\n\r\n                <ng-container *ngSwitchCase=\"'phone-number'\">\r\n                  <ng-container [ngTemplateOutlet]=\"phoneNumberReadonly\"\r\n                                [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n                </ng-container>\r\n\r\n                <ng-container *ngSwitchCase=\"'text'\">\r\n                  <ng-container [ngTemplateOutlet]=\"textReadonly\"\r\n                                [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n                </ng-container>\r\n\r\n                <ng-container *ngSwitchCase=\"'textarea'\">\r\n                  <ng-container [ngTemplateOutlet]=\"textareaReadonly\"\r\n                                [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n                </ng-container>\r\n\r\n                <ng-container *ngSwitchCase=\"'number'\">\r\n                  <ng-container [ngTemplateOutlet]=\"numberReadonly\"\r\n                                [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n                </ng-container>\r\n\r\n                <ng-container *ngSwitchCase=\"'currency'\">\r\n                  <ng-container [ngTemplateOutlet]=\"currencyReadonly\"\r\n                                [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n                </ng-container>\r\n\r\n                <ng-container *ngSwitchCase=\"'radio-button'\">\r\n                  <ng-container [ngTemplateOutlet]=\"radioButtonReadonly\"\r\n                                [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n                </ng-container>\r\n\r\n                <ng-container *ngSwitchCase=\"'checkbox'\">\r\n                  <ng-container [ngTemplateOutlet]=\"checkboxReadonly\"\r\n                                [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n                </ng-container>\r\n\r\n                <ng-container *ngSwitchCase=\"'status'\">\r\n                  <ng-container [ngTemplateOutlet]=\"checkboxReadonly\"\r\n                                [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n                </ng-container>\r\n\r\n                <ng-container *ngSwitchCase=\"'lookup'\">\r\n                  <ng-container [ngTemplateOutlet]=\"lookupReadonly\"\r\n                                [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n                </ng-container>\r\n\r\n                <ng-container *ngSwitchCase=\"'amount'\">\r\n                  <ng-container [ngTemplateOutlet]=\"amountReadonly\"\r\n                                [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n                </ng-container>\r\n\r\n                <ng-container *ngSwitchCase=\"'multi-select'\">\r\n                  <ng-container [ngTemplateOutlet]=\"multiSelectReadonly\"\r\n                                [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n                </ng-container>\r\n\r\n                <ng-container *ngSwitchCase=\"'chip-list'\">\r\n                  <ng-container [ngTemplateOutlet]=\"chipListReadonly\"\r\n                                [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n                </ng-container>\r\n\r\n                <ng-container *ngSwitchCase=\"'sequence'\">\r\n                  <ng-container [ngTemplateOutlet]=\"sequenceReadonly\"\r\n                                [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n                </ng-container>\r\n\r\n                <ng-container *ngSwitchCase=\"'list'\">\r\n                  <ng-container [ngTemplateOutlet]=\"listReadonly\"\r\n                                [ngTemplateOutletContext]=\"{ field: field }\"></ng-container>\r\n                </ng-container>\r\n\r\n                <ng-container *ngSwitchCase=\"'iban-text'\">\r\n                  <p class=\"label\">\r\n                    <span [innerHtml]=\"!field.hideLabel ? (field.label | translate) : ''\"></span>\r\n                    <span> : </span>\r\n                    <span class=\"value\" [innerHtml]=\"extractFieldName(defaults, field.property)\"></span>\r\n                  </p>\r\n                </ng-container>\r\n\r\n                <ng-container *ngSwitchCase=\"'section-title'\">\r\n                  <div class=\"hrdivider-mid\">\r\n                    <span>{{ field.label | translate }}</span>\r\n                  </div>\r\n                </ng-container>\r\n\r\n              </ng-container>\r\n            </div>\r\n          </ng-container>\r\n        </div>\r\n      </ng-container>\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n\r\n\r\n"]}
|