@koalarx/ui 14.0.7 → 14.0.9
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/alert/esm2020/index.mjs +6 -6
- package/alert/esm2020/koalarx-ui-alert.mjs +4 -4
- package/alert/esm2020/lib/dialog-alert.component.mjs +48 -48
- package/alert/esm2020/lib/koala.alert-config.interface.mjs +1 -1
- package/alert/esm2020/lib/koala.alert.enum.mjs +8 -8
- package/alert/esm2020/lib/koala.alert.module.mjs +46 -46
- package/alert/esm2020/lib/koala.alert.service.mjs +19 -19
- package/alert/esm2020/lib/koala.request-code-to-alert-enum.translate.mjs +17 -17
- package/alert/fesm2015/koalarx-ui-alert.mjs +111 -111
- package/alert/fesm2015/koalarx-ui-alert.mjs.map +1 -1
- package/alert/fesm2020/koalarx-ui-alert.mjs +109 -109
- package/alert/fesm2020/koalarx-ui-alert.mjs.map +1 -1
- package/alert/index.d.ts +6 -6
- package/alert/lib/dialog-alert.component.d.ts +10 -10
- package/alert/lib/koala.alert-config.interface.d.ts +14 -14
- package/alert/lib/koala.alert.enum.d.ts +7 -7
- package/alert/lib/koala.alert.module.d.ts +12 -12
- package/alert/lib/koala.alert.service.d.ts +10 -10
- package/alert/lib/koala.request-code-to-alert-enum.translate.d.ts +4 -4
- package/button/esm2020/index.mjs +2 -2
- package/button/esm2020/koalarx-ui-button.mjs +4 -4
- package/button/esm2020/lib/button.component.mjs +44 -44
- package/button/esm2020/lib/koala.button.module.mjs +40 -40
- package/button/fesm2015/koalarx-ui-button.mjs +67 -67
- package/button/fesm2015/koalarx-ui-button.mjs.map +1 -1
- package/button/fesm2020/koalarx-ui-button.mjs +67 -67
- package/button/fesm2020/koalarx-ui-button.mjs.map +1 -1
- package/button/index.d.ts +2 -2
- package/button/lib/button.component.d.ts +18 -18
- package/button/lib/koala.button.module.d.ts +12 -12
- package/common/esm2020/index.mjs +4 -4
- package/common/esm2020/koalarx-ui-common.mjs +4 -4
- package/common/esm2020/lib/mask-options.mjs +3 -3
- package/common/esm2020/lib/services/csv/koala.csv.service.mjs +36 -36
- package/common/esm2020/lib/services/xlsx/koala.xlsx-config.interface.mjs +1 -1
- package/common/esm2020/lib/services/xlsx/koala.xlsx.service.mjs +127 -127
- package/common/fesm2015/koalarx-ui-common.mjs +160 -160
- package/common/fesm2015/koalarx-ui-common.mjs.map +1 -1
- package/common/fesm2020/koalarx-ui-common.mjs +155 -155
- package/common/fesm2020/koalarx-ui-common.mjs.map +1 -1
- package/common/index.d.ts +4 -4
- package/common/lib/mask-options.d.ts +2 -2
- package/common/lib/services/csv/koala.csv.service.d.ts +10 -10
- package/common/lib/services/xlsx/koala.xlsx-config.interface.d.ts +11 -11
- package/common/lib/services/xlsx/koala.xlsx.service.d.ts +12 -12
- package/core/esm2020/index.mjs +36 -36
- package/core/esm2020/koalarx-ui-core.mjs +4 -4
- package/core/esm2020/lib/environments/koalaEnvironment.mjs +3 -3
- package/core/esm2020/lib/helpers/mat-form-field.helper.mjs +16 -16
- package/core/esm2020/lib/loader/loader-bar-page.component.mjs +24 -24
- package/core/esm2020/lib/loader/loader-bar-page.interface.mjs +1 -1
- package/core/esm2020/lib/loader/loader-config.interface.mjs +1 -1
- package/core/esm2020/lib/ngx-koala.module.mjs +47 -47
- package/core/esm2020/lib/page/koala-language.helper.mjs +113 -113
- package/core/esm2020/lib/page/koala-page-pallet-colors.interface.mjs +1 -1
- package/core/esm2020/lib/page/koala.page.module.mjs +76 -76
- package/core/esm2020/lib/page/koala.user-menu-options.interface.mjs +1 -1
- package/core/esm2020/lib/page/notifications/koala.notification.interface.mjs +1 -1
- package/core/esm2020/lib/page/notifications/notification.component.mjs +43 -43
- package/core/esm2020/lib/page/page.component.mjs +302 -302
- package/core/esm2020/lib/router/koala.parameter-hash-location-stategy.mjs +18 -18
- package/core/esm2020/lib/services/api-requester/factory/koala.response.factory.mjs +43 -43
- package/core/esm2020/lib/services/api-requester/helpers/error/koala.client.error.mjs +2 -2
- package/core/esm2020/lib/services/api-requester/helpers/error/koala.errors.helper.mjs +45 -45
- package/core/esm2020/lib/services/api-requester/helpers/error/koala.not-found.error.mjs +2 -2
- package/core/esm2020/lib/services/api-requester/helpers/error/koala.success.error.mjs +2 -2
- package/core/esm2020/lib/services/api-requester/helpers/error/koala.unhautorized.error.mjs +2 -2
- package/core/esm2020/lib/services/api-requester/helpers/service/koala.request-header.helper.mjs +14 -14
- package/core/esm2020/lib/services/api-requester/koala.api-requester.base.mjs +86 -86
- package/core/esm2020/lib/services/api-requester/koala.api-requester.cache.mjs +37 -37
- package/core/esm2020/lib/services/api-requester/koala.api-requester.service.mjs +158 -158
- package/core/esm2020/lib/services/loader/koala.loader.service.mjs +34 -34
- package/core/esm2020/lib/services/openid/koala-oauth2-config.interface.mjs +1 -1
- package/core/esm2020/lib/services/openid/koala.oauth.config.mjs +29 -29
- package/core/esm2020/lib/services/openid/koala.oauth2.service.mjs +188 -188
- package/core/esm2020/lib/services/request/koala.request.service.mjs +52 -52
- package/core/esm2020/lib/services/token/koala.token.service.mjs +55 -55
- package/core/esm2020/lib/services/token/token.factory.mjs +26 -26
- package/core/fesm2015/koalarx-ui-core.mjs +1294 -1294
- package/core/fesm2015/koalarx-ui-core.mjs.map +1 -1
- package/core/fesm2020/koalarx-ui-core.mjs +1256 -1256
- package/core/fesm2020/koalarx-ui-core.mjs.map +1 -1
- package/core/index.d.ts +30 -30
- package/core/lib/environments/koalaEnvironment.d.ts +15 -15
- package/core/lib/helpers/mat-form-field.helper.d.ts +3 -3
- package/core/lib/loader/loader-bar-page.component.d.ts +9 -9
- package/core/lib/loader/loader-bar-page.interface.d.ts +5 -5
- package/core/lib/loader/loader-config.interface.d.ts +7 -7
- package/core/lib/ngx-koala.module.d.ts +12 -12
- package/core/lib/page/koala-language.helper.d.ts +19 -19
- package/core/lib/page/koala-page-pallet-colors.interface.d.ts +38 -38
- package/core/lib/page/koala.page.module.d.ts +21 -21
- package/core/lib/page/koala.user-menu-options.interface.d.ts +5 -5
- package/core/lib/page/notifications/koala.notification.interface.d.ts +6 -6
- package/core/lib/page/notifications/notification.component.d.ts +15 -15
- package/core/lib/page/page.component.d.ts +58 -58
- package/core/lib/router/koala.parameter-hash-location-stategy.d.ts +7 -7
- package/core/lib/services/api-requester/factory/koala.response.factory.d.ts +5 -5
- package/core/lib/services/api-requester/helpers/error/koala.client.error.d.ts +2 -2
- package/core/lib/services/api-requester/helpers/error/koala.errors.helper.d.ts +13 -13
- package/core/lib/services/api-requester/helpers/error/koala.not-found.error.d.ts +2 -2
- package/core/lib/services/api-requester/helpers/error/koala.success.error.d.ts +2 -2
- package/core/lib/services/api-requester/helpers/error/koala.unhautorized.error.d.ts +2 -2
- package/core/lib/services/api-requester/helpers/service/koala.request-header.helper.d.ts +4 -4
- package/core/lib/services/api-requester/koala.api-requester.base.d.ts +19 -19
- package/core/lib/services/api-requester/koala.api-requester.cache.d.ts +13 -13
- package/core/lib/services/api-requester/koala.api-requester.service.d.ts +24 -24
- package/core/lib/services/loader/koala.loader.service.d.ts +14 -14
- package/core/lib/services/openid/koala-oauth2-config.interface.d.ts +11 -11
- package/core/lib/services/openid/koala.oauth.config.d.ts +9 -9
- package/core/lib/services/openid/koala.oauth2.service.d.ts +82 -82
- package/core/lib/services/request/koala.request.service.d.ts +11 -11
- package/core/lib/services/token/koala.token.service.d.ts +26 -26
- package/core/lib/services/token/token.factory.d.ts +9 -9
- package/dialog/esm2020/index.mjs +3 -3
- package/dialog/esm2020/koalarx-ui-dialog.mjs +4 -4
- package/dialog/esm2020/lib/dialog.component.mjs +25 -25
- package/dialog/esm2020/lib/koala.dialog-template.interface.mjs +1 -1
- package/dialog/esm2020/lib/koala.dialog.module.mjs +36 -36
- package/dialog/esm2020/lib/koala.dialog.service.mjs +57 -57
- package/dialog/fesm2015/koalarx-ui-dialog.mjs +96 -96
- package/dialog/fesm2015/koalarx-ui-dialog.mjs.map +1 -1
- package/dialog/fesm2020/koalarx-ui-dialog.mjs +96 -96
- package/dialog/fesm2020/koalarx-ui-dialog.mjs.map +1 -1
- package/dialog/index.d.ts +3 -3
- package/dialog/lib/dialog.component.d.ts +11 -11
- package/dialog/lib/koala.dialog-template.interface.d.ts +9 -9
- package/dialog/lib/koala.dialog.module.d.ts +11 -11
- package/dialog/lib/koala.dialog.service.d.ts +14 -14
- package/dynamic-component/esm2020/index.mjs +5 -5
- package/dynamic-component/esm2020/koalarx-ui-dynamic-component.mjs +4 -4
- package/dynamic-component/esm2020/lib/koala-dynamic-component.component.mjs +1 -1
- package/dynamic-component/esm2020/lib/koala-dynamic-component.directive.mjs +16 -16
- package/dynamic-component/esm2020/lib/koala-dynamic-component.factory.mjs +40 -40
- package/dynamic-component/esm2020/lib/koala-dynamic-component.mjs +6 -6
- package/dynamic-component/esm2020/lib/koala-dynamic-component.module.mjs +23 -23
- package/dynamic-component/fesm2015/koalarx-ui-dynamic-component.mjs +71 -71
- package/dynamic-component/fesm2015/koalarx-ui-dynamic-component.mjs.map +1 -1
- package/dynamic-component/fesm2020/koalarx-ui-dynamic-component.mjs +70 -70
- package/dynamic-component/fesm2020/koalarx-ui-dynamic-component.mjs.map +1 -1
- package/dynamic-component/index.d.ts +5 -5
- package/dynamic-component/lib/koala-dynamic-component.component.d.ts +3 -3
- package/dynamic-component/lib/koala-dynamic-component.d.ts +6 -6
- package/dynamic-component/lib/koala-dynamic-component.directive.d.ts +8 -8
- package/dynamic-component/lib/koala-dynamic-component.factory.d.ts +14 -14
- package/dynamic-component/lib/koala-dynamic-component.module.d.ts +8 -8
- package/file-button/esm2020/index.mjs +4 -4
- package/file-button/esm2020/koalarx-ui-file-button.mjs +4 -4
- package/file-button/esm2020/lib/file-button.component.mjs +125 -125
- package/file-button/esm2020/lib/koala.btn-file.service.mjs +25 -25
- package/file-button/esm2020/lib/koala.file-button.module.mjs +36 -36
- package/file-button/esm2020/lib/koala.file.interface.mjs +1 -1
- package/file-button/fesm2015/koalarx-ui-file-button.mjs +174 -174
- package/file-button/fesm2015/koalarx-ui-file-button.mjs.map +1 -1
- package/file-button/fesm2020/koalarx-ui-file-button.mjs +165 -165
- package/file-button/fesm2020/koalarx-ui-file-button.mjs.map +1 -1
- package/file-button/index.d.ts +4 -4
- package/file-button/lib/file-button.component.d.ts +29 -29
- package/file-button/lib/koala.btn-file.service.d.ts +11 -11
- package/file-button/lib/koala.file-button.module.d.ts +11 -11
- package/file-button/lib/koala.file.interface.d.ts +5 -5
- package/folder-page/esm2020/index.mjs +3 -3
- package/folder-page/esm2020/koalarx-ui-folder-page.mjs +4 -4
- package/folder-page/esm2020/lib/folder.component.mjs +70 -70
- package/folder-page/esm2020/lib/koala-navigate-history.interface.mjs +1 -1
- package/folder-page/esm2020/lib/koala.folder-page.module.mjs +40 -40
- package/folder-page/fesm2015/koalarx-ui-folder-page.mjs +95 -95
- package/folder-page/fesm2015/koalarx-ui-folder-page.mjs.map +1 -1
- package/folder-page/fesm2020/koalarx-ui-folder-page.mjs +94 -94
- package/folder-page/fesm2020/koalarx-ui-folder-page.mjs.map +1 -1
- package/folder-page/index.d.ts +3 -3
- package/folder-page/lib/folder.component.d.ts +21 -21
- package/folder-page/lib/koala-navigate-history.interface.d.ts +4 -4
- package/folder-page/lib/koala.folder-page.module.d.ts +12 -12
- package/form/esm2020/index.mjs +19 -19
- package/form/esm2020/koalarx-ui-form.mjs +4 -4
- package/form/esm2020/lib/btn-submit/btn-submit.component.mjs +49 -49
- package/form/esm2020/lib/directives/koala-autofocus.directive.mjs +25 -25
- package/form/esm2020/lib/dynamic-form/builder/dynamic-form.builder.mjs +139 -138
- package/form/esm2020/lib/dynamic-form/builder/fields/autocomplete.builder.mjs +37 -37
- package/form/esm2020/lib/dynamic-form/builder/fields/field.base.mjs +147 -147
- package/form/esm2020/lib/dynamic-form/builder/fields/field.builder.mjs +6 -6
- package/form/esm2020/lib/dynamic-form/builder/fields/more-items.builder.mjs +56 -56
- package/form/esm2020/lib/dynamic-form/dynamic-form.component.mjs +598 -598
- package/form/esm2020/lib/dynamic-form/enums/dynamic-form-type-field.enum.mjs +34 -34
- package/form/esm2020/lib/dynamic-form/interfaces/koala-custom-validator-fn.interface.mjs +1 -1
- package/form/esm2020/lib/dynamic-form/interfaces/koala.dynamic-autocomplete-options.interface.mjs +1 -1
- package/form/esm2020/lib/dynamic-form/interfaces/koala.dynamic-form-autocomplete-multiple-config.interface.mjs +1 -1
- package/form/esm2020/lib/dynamic-form/interfaces/koala.dynamic-form-config.interface.mjs +2 -2
- package/form/esm2020/lib/dynamic-form/interfaces/koala.dynamic-form-field.interface.mjs +1 -1
- package/form/esm2020/lib/dynamic-form/interfaces/koala.dynamic-form-more-itens-show-field-config.interface.mjs +1 -1
- package/form/esm2020/lib/dynamic-form/interfaces/koala.dynamic-form-show-field.interface.mjs +1 -1
- package/form/esm2020/lib/dynamic-form/interfaces/koala.dynamic-set-value.interface.mjs +1 -1
- package/form/esm2020/lib/dynamic-form/koala.dynamic-form.service.mjs +212 -212
- package/form/esm2020/lib/dynamic-form/validators/autocomplete-selected.validator.mjs +9 -9
- package/form/esm2020/lib/dynamic-form/validators/cnpj.validator.mjs +9 -9
- package/form/esm2020/lib/dynamic-form/validators/cpf.validator.mjs +9 -9
- package/form/esm2020/lib/dynamic-form/validators/date-max.validator.mjs +10 -10
- package/form/esm2020/lib/dynamic-form/validators/date-min.validator.mjs +10 -10
- package/form/esm2020/lib/dynamic-form/validators/koala-dynamic-form-validator-result.helper.mjs +9 -9
- package/form/esm2020/lib/dynamic-form/validators/validation.helper.mjs +85 -85
- package/form/esm2020/lib/form.abstract.mjs +41 -41
- package/form/esm2020/lib/koala.form.module.mjs +132 -132
- package/form/esm2020/lib/show-invalid-fields/show-invalid-fields.mjs +8 -8
- package/form/fesm2015/koalarx-ui-form.mjs +1517 -1516
- package/form/fesm2015/koalarx-ui-form.mjs.map +1 -1
- package/form/fesm2020/koalarx-ui-form.mjs +1499 -1498
- package/form/fesm2020/koalarx-ui-form.mjs.map +1 -1
- package/form/index.d.ts +19 -19
- package/form/lib/btn-submit/btn-submit.component.d.ts +20 -20
- package/form/lib/directives/koala-autofocus.directive.d.ts +10 -10
- package/form/lib/dynamic-form/builder/dynamic-form.builder.d.ts +21 -21
- package/form/lib/dynamic-form/builder/fields/autocomplete.builder.d.ts +16 -16
- package/form/lib/dynamic-form/builder/fields/field.base.d.ts +42 -42
- package/form/lib/dynamic-form/builder/fields/field.builder.d.ts +8 -8
- package/form/lib/dynamic-form/builder/fields/more-items.builder.d.ts +17 -17
- package/form/lib/dynamic-form/dynamic-form.component.d.ts +54 -54
- package/form/lib/dynamic-form/enums/dynamic-form-type-field.enum.d.ts +33 -33
- package/form/lib/dynamic-form/interfaces/koala-custom-validator-fn.interface.d.ts +4 -4
- package/form/lib/dynamic-form/interfaces/koala.dynamic-autocomplete-options.interface.d.ts +4 -4
- package/form/lib/dynamic-form/interfaces/koala.dynamic-form-autocomplete-multiple-config.interface.d.ts +4 -4
- package/form/lib/dynamic-form/interfaces/koala.dynamic-form-config.interface.d.ts +12 -11
- package/form/lib/dynamic-form/interfaces/koala.dynamic-form-field.interface.d.ts +69 -69
- package/form/lib/dynamic-form/interfaces/koala.dynamic-form-more-itens-show-field-config.interface.d.ts +8 -8
- package/form/lib/dynamic-form/interfaces/koala.dynamic-form-show-field.interface.d.ts +5 -5
- package/form/lib/dynamic-form/interfaces/koala.dynamic-set-value.interface.d.ts +4 -4
- package/form/lib/dynamic-form/koala.dynamic-form.service.d.ts +28 -28
- package/form/lib/dynamic-form/validators/autocomplete-selected.validator.d.ts +4 -4
- package/form/lib/dynamic-form/validators/cnpj.validator.d.ts +4 -4
- package/form/lib/dynamic-form/validators/cpf.validator.d.ts +4 -4
- package/form/lib/dynamic-form/validators/date-max.validator.d.ts +2 -2
- package/form/lib/dynamic-form/validators/date-min.validator.d.ts +2 -2
- package/form/lib/dynamic-form/validators/koala-dynamic-form-validator-result.helper.d.ts +7 -7
- package/form/lib/dynamic-form/validators/validation.helper.d.ts +4 -4
- package/form/lib/form.abstract.d.ts +16 -16
- package/form/lib/koala.form.module.d.ts +25 -25
- package/form/lib/show-invalid-fields/show-invalid-fields.d.ts +6 -6
- package/icon/esm2020/index.mjs +3 -3
- package/icon/esm2020/koalarx-ui-icon.mjs +4 -4
- package/icon/esm2020/lib/icon.component.mjs +41 -41
- package/icon/esm2020/lib/koala.icon.module.mjs +24 -24
- package/icon/esm2020/lib/koala.icon.type.mjs +1 -1
- package/icon/fesm2015/koalarx-ui-icon.mjs +56 -56
- package/icon/fesm2015/koalarx-ui-icon.mjs.map +1 -1
- package/icon/fesm2020/koalarx-ui-icon.mjs +55 -55
- package/icon/fesm2020/koalarx-ui-icon.mjs.map +1 -1
- package/icon/index.d.ts +3 -3
- package/icon/lib/icon.component.d.ts +14 -14
- package/icon/lib/koala.icon.module.d.ts +8 -8
- package/icon/lib/koala.icon.type.d.ts +1 -1
- package/icons-animated/esm2020/index.mjs +4 -4
- package/icons-animated/esm2020/koalarx-ui-icons-animated.mjs +4 -4
- package/icons-animated/esm2020/lib/icons/downloading/downloading-icon-animated.component.mjs +23 -23
- package/icons-animated/esm2020/lib/icons/loading/loading-icon-animated.component.mjs +23 -23
- package/icons-animated/esm2020/lib/icons-animated.component.mjs +20 -20
- package/icons-animated/esm2020/lib/icons-animated.service.mjs +27 -27
- package/icons-animated/esm2020/lib/koala-icons-animated.module.mjs +30 -30
- package/icons-animated/fesm2015/koalarx-ui-icons-animated.mjs +95 -95
- package/icons-animated/fesm2015/koalarx-ui-icons-animated.mjs.map +1 -1
- package/icons-animated/fesm2020/koalarx-ui-icons-animated.mjs +93 -93
- package/icons-animated/fesm2020/koalarx-ui-icons-animated.mjs.map +1 -1
- package/icons-animated/index.d.ts +4 -4
- package/icons-animated/lib/icons/downloading/downloading-icon-animated.component.d.ts +12 -12
- package/icons-animated/lib/icons/loading/loading-icon-animated.component.d.ts +12 -12
- package/icons-animated/lib/icons-animated.component.d.ts +8 -8
- package/icons-animated/lib/icons-animated.service.d.ts +9 -9
- package/icons-animated/lib/koala-icons-animated.module.d.ts +10 -10
- package/list/esm2020/index.mjs +11 -11
- package/list/esm2020/koalarx-ui-list.mjs +4 -4
- package/list/esm2020/lib/koala-list-btn-collapse-sub-list-config.interface.mjs +1 -1
- package/list/esm2020/lib/koala-list-filter.interface.mjs +1 -1
- package/list/esm2020/lib/koala-list-form-filter.interface.mjs +1 -1
- package/list/esm2020/lib/koala-list-item-menu-option.interface.mjs +1 -1
- package/list/esm2020/lib/koala-list-item.interface.mjs +1 -1
- package/list/esm2020/lib/koala.list-config.interface.mjs +1 -1
- package/list/esm2020/lib/koala.list.module.mjs +68 -68
- package/list/esm2020/lib/koala.list.service.mjs +15 -15
- package/list/esm2020/lib/list-builder/list.builder.mjs +104 -104
- package/list/esm2020/lib/list.abstract.mjs +163 -163
- package/list/esm2020/lib/list.component.mjs +172 -172
- package/list/esm2020/lib/providers/pagination/pagination.provider.mjs +32 -32
- package/list/fesm2015/koalarx-ui-list.mjs +521 -521
- package/list/fesm2015/koalarx-ui-list.mjs.map +1 -1
- package/list/fesm2020/koalarx-ui-list.mjs +491 -491
- package/list/fesm2020/koalarx-ui-list.mjs.map +1 -1
- package/list/index.d.ts +11 -11
- package/list/lib/koala-list-btn-collapse-sub-list-config.interface.d.ts +8 -8
- package/list/lib/koala-list-filter.interface.d.ts +10 -10
- package/list/lib/koala-list-form-filter.interface.d.ts +8 -8
- package/list/lib/koala-list-item-menu-option.interface.d.ts +7 -7
- package/list/lib/koala-list-item.interface.d.ts +13 -13
- package/list/lib/koala.list-config.interface.d.ts +37 -37
- package/list/lib/koala.list.module.d.ts +17 -17
- package/list/lib/koala.list.service.d.ts +7 -7
- package/list/lib/list-builder/list.builder.d.ts +32 -32
- package/list/lib/list.abstract.d.ts +44 -44
- package/list/lib/list.component.d.ts +54 -54
- package/list/lib/providers/pagination/pagination.provider.d.ts +9 -9
- package/menu/esm2020/index.mjs +5 -5
- package/menu/esm2020/koalarx-ui-menu.mjs +4 -4
- package/menu/esm2020/lib/koala.menu-module.interface.mjs +1 -1
- package/menu/esm2020/lib/koala.menu-tool.interface.mjs +1 -1
- package/menu/esm2020/lib/koala.menu.module.mjs +36 -36
- package/menu/esm2020/lib/koala.menu.service.mjs +24 -24
- package/menu/esm2020/lib/menu.component.mjs +100 -100
- package/menu/fesm2015/koalarx-ui-menu.mjs +139 -139
- package/menu/fesm2015/koalarx-ui-menu.mjs.map +1 -1
- package/menu/fesm2020/koalarx-ui-menu.mjs +135 -135
- package/menu/fesm2020/koalarx-ui-menu.mjs.map +1 -1
- package/menu/index.d.ts +5 -5
- package/menu/lib/koala.menu-module.interface.d.ts +12 -12
- package/menu/lib/koala.menu-tool.interface.d.ts +6 -6
- package/menu/lib/koala.menu.module.d.ts +11 -11
- package/menu/lib/koala.menu.service.d.ts +10 -10
- package/menu/lib/menu.component.d.ts +22 -22
- package/package.json +1 -1
- package/question/esm2020/index.mjs +4 -4
- package/question/esm2020/koalarx-ui-question.mjs +4 -4
- package/question/esm2020/lib/dialog-question.component.mjs +25 -25
- package/question/esm2020/lib/koala-question-config.interface.mjs +1 -1
- package/question/esm2020/lib/koala.question.module.mjs +40 -40
- package/question/esm2020/lib/koala.question.service.mjs +26 -26
- package/question/fesm2015/koalarx-ui-question.mjs +68 -68
- package/question/fesm2015/koalarx-ui-question.mjs.map +1 -1
- package/question/fesm2020/koalarx-ui-question.mjs +66 -66
- package/question/fesm2020/koalarx-ui-question.mjs.map +1 -1
- package/question/index.d.ts +4 -4
- package/question/lib/dialog-question.component.d.ts +10 -10
- package/question/lib/koala-question-config.interface.d.ts +5 -5
- package/question/lib/koala.question.module.d.ts +12 -12
- package/question/lib/koala.question.service.d.ts +10 -10
- package/snackbar/esm2020/index.mjs +4 -4
- package/snackbar/esm2020/koalarx-ui-snackbar.mjs +4 -4
- package/snackbar/esm2020/lib/koala.snackbar.component.mjs +22 -22
- package/snackbar/esm2020/lib/koala.snackbar.interface.mjs +1 -1
- package/snackbar/esm2020/lib/koala.snackbar.module.mjs +36 -36
- package/snackbar/esm2020/lib/koala.snackbar.service.mjs +35 -35
- package/snackbar/fesm2015/koalarx-ui-snackbar.mjs +74 -74
- package/snackbar/fesm2015/koalarx-ui-snackbar.mjs.map +1 -1
- package/snackbar/fesm2020/koalarx-ui-snackbar.mjs +72 -72
- package/snackbar/fesm2020/koalarx-ui-snackbar.mjs.map +1 -1
- package/snackbar/index.d.ts +4 -4
- package/snackbar/lib/koala.snackbar.component.d.ts +10 -10
- package/snackbar/lib/koala.snackbar.interface.d.ts +4 -4
- package/snackbar/lib/koala.snackbar.module.d.ts +10 -10
- package/snackbar/lib/koala.snackbar.service.d.ts +12 -12
|
@@ -1,598 +1,598 @@
|
|
|
1
|
-
import { Validators } from '@angular/forms';
|
|
2
|
-
import { DynamicFormTypeFieldEnum } from './enums/dynamic-form-type-field.enum';
|
|
3
|
-
import { CpfValidator } from './validators/cpf.validator';
|
|
4
|
-
import { CnpjValidator } from './validators/cnpj.validator';
|
|
5
|
-
import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
|
|
6
|
-
import { FormAbstract } from '../form.abstract';
|
|
7
|
-
import { debounceTime } from 'rxjs/operators';
|
|
8
|
-
import { BehaviorSubject } from 'rxjs';
|
|
9
|
-
import { AutocompleteSelectedValidator } from './validators/autocomplete-selected.validator';
|
|
10
|
-
import { delay } from "@koalarx/utils/operators/delay";
|
|
11
|
-
import { koala } from "@koalarx/utils";
|
|
12
|
-
import { DateMinValidator } from "./validators/date-min.validator";
|
|
13
|
-
import { DateMaxValidator } from "./validators/date-max.validator";
|
|
14
|
-
import { KoalaLanguageHelper } from "@koalarx/ui/core";
|
|
15
|
-
import { randomString } from "@koalarx/utils/operators/string";
|
|
16
|
-
import * as i0 from "@angular/core";
|
|
17
|
-
import * as i1 from "@angular/forms";
|
|
18
|
-
import * as i2 from "./koala.dynamic-form.service";
|
|
19
|
-
import * as i3 from "@angular/common";
|
|
20
|
-
import * as i4 from "ng2-currency-mask";
|
|
21
|
-
import * as i5 from "ngx-mask";
|
|
22
|
-
import * as i6 from "@koalarx/ui/file-button";
|
|
23
|
-
import * as i7 from "@angular/cdk/text-field";
|
|
24
|
-
import * as i8 from "@angular/material/form-field";
|
|
25
|
-
import * as i9 from "@angular/material/input";
|
|
26
|
-
import * as i10 from "@angular/material/select";
|
|
27
|
-
import * as i11 from "@angular/material/core";
|
|
28
|
-
import * as i12 from "@angular/material/radio";
|
|
29
|
-
import * as i13 from "@angular/material/checkbox";
|
|
30
|
-
import * as i14 from "@angular/material/autocomplete";
|
|
31
|
-
import * as i15 from "@angular/material/button";
|
|
32
|
-
import * as i16 from "@angular/material/icon";
|
|
33
|
-
import * as i17 from "@angular/material/expansion";
|
|
34
|
-
import * as i18 from "@angular/material/chips";
|
|
35
|
-
import * as i19 from "@koalarx/ui/button";
|
|
36
|
-
import * as i20 from "@angular/material/progress-spinner";
|
|
37
|
-
import * as i21 from "../directives/koala-autofocus.directive";
|
|
38
|
-
export class DynamicFormComponent extends FormAbstract {
|
|
39
|
-
constructor(fb, dynamicFormService) {
|
|
40
|
-
super(() => this.form);
|
|
41
|
-
this.fb = fb;
|
|
42
|
-
this.dynamicFormService = dynamicFormService;
|
|
43
|
-
this.tabIndexStart = 1;
|
|
44
|
-
this.typeField = DynamicFormTypeFieldEnum;
|
|
45
|
-
this.hoursAndMinutesMask = '00:000';
|
|
46
|
-
this.errorMessage = KoalaLanguageHelper;
|
|
47
|
-
this.formId = randomString(25, {
|
|
48
|
-
lowercase: true,
|
|
49
|
-
uppercase: true,
|
|
50
|
-
numbers: false,
|
|
51
|
-
specialCharacters: false
|
|
52
|
-
});
|
|
53
|
-
}
|
|
54
|
-
ngOnInit() {
|
|
55
|
-
if (!this.form.get('formData')) {
|
|
56
|
-
this.form.addControl('formData', this.fb.array([]));
|
|
57
|
-
}
|
|
58
|
-
this.controls = this.form.get('formData');
|
|
59
|
-
this.formConfig?.forEach((config, indexConfig) => {
|
|
60
|
-
const newFormGroup = this.newControl(config);
|
|
61
|
-
if (config.asyncValidators) {
|
|
62
|
-
newFormGroup.get('value').setAsyncValidators(config.asyncValidators);
|
|
63
|
-
}
|
|
64
|
-
newFormGroup.get('value').updateValueAndValidity();
|
|
65
|
-
if (config.type === DynamicFormTypeFieldEnum.dynamicForm) {
|
|
66
|
-
const formGroupDynamicFormsSubject = newFormGroup.get('dynamicFormConfig').value;
|
|
67
|
-
formGroupDynamicFormsSubject.subscribe(formGroupConfig => {
|
|
68
|
-
if (formGroupConfig) {
|
|
69
|
-
formGroupConfig.form.valueChanges.subscribe(() => {
|
|
70
|
-
if (formGroupConfig.form.valid && (config.valueChanges || this.showFieldsMoreItensConfig)) {
|
|
71
|
-
const value = this.dynamicFormService.emitData(formGroupConfig.form);
|
|
72
|
-
newFormGroup.get('value').setValue(value);
|
|
73
|
-
}
|
|
74
|
-
});
|
|
75
|
-
}
|
|
76
|
-
});
|
|
77
|
-
}
|
|
78
|
-
if (config.valueChanges ||
|
|
79
|
-
config.type === DynamicFormTypeFieldEnum.autocomplete ||
|
|
80
|
-
config.type === DynamicFormTypeFieldEnum.dynamicForm ||
|
|
81
|
-
this.showFieldsMoreItensConfig) {
|
|
82
|
-
if (config.type === DynamicFormTypeFieldEnum.autocomplete) {
|
|
83
|
-
const autocompleteOptionsSubject = newFormGroup.get('autocompleteOptions').value;
|
|
84
|
-
if (autocompleteOptionsSubject) {
|
|
85
|
-
autocompleteOptionsSubject.subscribe(options => newFormGroup.get('autocompleteOptionsFiltered').value.next(options));
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
newFormGroup.get('value')
|
|
89
|
-
.valueChanges
|
|
90
|
-
.pipe(debounceTime(300))
|
|
91
|
-
.subscribe(async (value) => {
|
|
92
|
-
await this.setConfigDynamicForm(newFormGroup);
|
|
93
|
-
if (config.type === DynamicFormTypeFieldEnum.autocomplete) {
|
|
94
|
-
if (value && (value.hasOwnProperty('value') &&
|
|
95
|
-
value.hasOwnProperty('name') &&
|
|
96
|
-
Object.keys(value).length === 2) || (Array.isArray(value) &&
|
|
97
|
-
newFormGroup.get('multiple').value)) {
|
|
98
|
-
if (newFormGroup.get('multiple').value) {
|
|
99
|
-
if (Array.isArray(value)) {
|
|
100
|
-
newFormGroup.get('autocompleteSelectedValue').setValue(value);
|
|
101
|
-
newFormGroup.get('value').setValue(value[value.length - 1], { emitEvent: false });
|
|
102
|
-
}
|
|
103
|
-
else {
|
|
104
|
-
if (this.validateAutocompleteSelect(newFormGroup.get('autocompleteSelectedValue').value, value)) {
|
|
105
|
-
newFormGroup.get('autocompleteSelectedValue').value.push(value);
|
|
106
|
-
}
|
|
107
|
-
}
|
|
108
|
-
const autocompleteInput = document.querySelector(`#${this.formId} input#autocomplete-${newFormGroup.get('name')?.value}`);
|
|
109
|
-
if (autocompleteInput) {
|
|
110
|
-
autocompleteInput.value = '';
|
|
111
|
-
}
|
|
112
|
-
}
|
|
113
|
-
else {
|
|
114
|
-
newFormGroup.get('autocompleteSelectedValue').setValue(value);
|
|
115
|
-
}
|
|
116
|
-
}
|
|
117
|
-
else if (!newFormGroup.get('multiple').value) {
|
|
118
|
-
newFormGroup.get('autocompleteSelectedValue').setValue(koala(this.formConfig)
|
|
119
|
-
.array()
|
|
120
|
-
.filter(newFormGroup.get('name').value, 'name')
|
|
121
|
-
.getValue()[0]?.autocompleteDefaultValueOnClear ?? null);
|
|
122
|
-
}
|
|
123
|
-
if (config.type === DynamicFormTypeFieldEnum.autocomplete) {
|
|
124
|
-
if (config.autocompleteType === 'all') {
|
|
125
|
-
const autocompleteOptionsSubject = newFormGroup.get('autocompleteOptions').value;
|
|
126
|
-
newFormGroup.get('autocompleteOptionsFiltered').value.next(this.autocompleteFilter(autocompleteOptionsSubject.value, value));
|
|
127
|
-
}
|
|
128
|
-
else if (config.autocompleteType === 'onDemand' && typeof value !== "object") {
|
|
129
|
-
const loader = newFormGroup.get('autocompleteLoading').value;
|
|
130
|
-
loader.next(true);
|
|
131
|
-
config.autocompleteFilter(value).subscribe(options => {
|
|
132
|
-
newFormGroup.get('autocompleteOptionsFiltered').value.next(options);
|
|
133
|
-
loader.next(false);
|
|
134
|
-
});
|
|
135
|
-
}
|
|
136
|
-
}
|
|
137
|
-
}
|
|
138
|
-
if (config.valueChanges) {
|
|
139
|
-
if (config.type === DynamicFormTypeFieldEnum.autocomplete) {
|
|
140
|
-
config.valueChanges((newFormGroup.get('multiple').value ?
|
|
141
|
-
newFormGroup.get('autocompleteSelectedValue').value.map(item => item.value) :
|
|
142
|
-
newFormGroup.get('autocompleteSelectedValue').value?.value));
|
|
143
|
-
}
|
|
144
|
-
else {
|
|
145
|
-
config.valueChanges(value);
|
|
146
|
-
}
|
|
147
|
-
}
|
|
148
|
-
});
|
|
149
|
-
}
|
|
150
|
-
this.controls.push(newFormGroup);
|
|
151
|
-
if (config.moreItemsConfig) {
|
|
152
|
-
if (config.moreItemsMinItems > 0) {
|
|
153
|
-
for (let min = 0; min < config.moreItemsMinItems; min++) {
|
|
154
|
-
if (min <= config.moreItemsMaxItems) {
|
|
155
|
-
this.addMoreItem(indexConfig);
|
|
156
|
-
}
|
|
157
|
-
}
|
|
158
|
-
}
|
|
159
|
-
if (config.moreItemsConfig.setValues) {
|
|
160
|
-
config.moreItemsConfig
|
|
161
|
-
.setValues
|
|
162
|
-
.subscribe(async (values) => {
|
|
163
|
-
if (values.length > 0) {
|
|
164
|
-
values.forEach((itemValue, indexValue) => {
|
|
165
|
-
if (!this.controls.controls[indexConfig].get('moreItemsConfig').value[indexValue]) {
|
|
166
|
-
this.addMoreItem(indexConfig);
|
|
167
|
-
}
|
|
168
|
-
setTimeout(() => {
|
|
169
|
-
this.setValuesOnFields(itemValue, this.controls.controls[indexConfig].get('moreItemsConfig').value[indexValue].form);
|
|
170
|
-
}, 300);
|
|
171
|
-
});
|
|
172
|
-
}
|
|
173
|
-
});
|
|
174
|
-
}
|
|
175
|
-
}
|
|
176
|
-
});
|
|
177
|
-
if (this.showFields) {
|
|
178
|
-
this.changeVisibilityFields(this.showFields, this.form);
|
|
179
|
-
}
|
|
180
|
-
if (this.setValues) {
|
|
181
|
-
this.setValuesOnFields(this.setValues, this.form);
|
|
182
|
-
}
|
|
183
|
-
}
|
|
184
|
-
isValidNewAutocompleteOption(value) {
|
|
185
|
-
return !!value && typeof value === 'string';
|
|
186
|
-
}
|
|
187
|
-
hoursAndMinutesApplyMask(index, event) {
|
|
188
|
-
const control = this.controls?.controls[index];
|
|
189
|
-
const type = control?.get('type').value;
|
|
190
|
-
if (type === DynamicFormTypeFieldEnum.hoursAndMinutes) {
|
|
191
|
-
const value = control?.get('value').value;
|
|
192
|
-
if (event.key == 'Backspace' && value.length < 6) {
|
|
193
|
-
this.hoursAndMinutesMask = '00:000';
|
|
194
|
-
}
|
|
195
|
-
else if (event.key != 'Backspace' && value.length >= 6) {
|
|
196
|
-
this.hoursAndMinutesMask = '000:00';
|
|
197
|
-
}
|
|
198
|
-
}
|
|
199
|
-
}
|
|
200
|
-
passwordView(index) {
|
|
201
|
-
const control = this.controls?.controls[index];
|
|
202
|
-
const hidePassword = !control?.get('hidePassword').value;
|
|
203
|
-
control?.get('hidePassword').setValue(hidePassword);
|
|
204
|
-
control?.get('type').setValue(hidePassword ?
|
|
205
|
-
DynamicFormTypeFieldEnum.password :
|
|
206
|
-
DynamicFormTypeFieldEnum.text);
|
|
207
|
-
}
|
|
208
|
-
addMoreItem(propIndex) {
|
|
209
|
-
if (this.controls.controls[propIndex].get('moreItemsConfig').value.length < this.controls.controls[propIndex].get('moreItemsMaxItems').value) {
|
|
210
|
-
const formGroup = this.fb.group({});
|
|
211
|
-
this.controls.controls[propIndex].get('moreItemsConfig').value.push({
|
|
212
|
-
form: formGroup,
|
|
213
|
-
formConfig: this.formConfig[propIndex].moreItemsConfig.formConfig,
|
|
214
|
-
showFields: new BehaviorSubject([]),
|
|
215
|
-
showFieldsMoreItensConfig: this.formConfig[propIndex].moreItemsConfig.showFieldsConfig
|
|
216
|
-
});
|
|
217
|
-
this.controls.controls[propIndex].get('moreItemsExpanded').setValue(this.controls.controls[propIndex].get('moreItemsConfig').value.length - 1);
|
|
218
|
-
const formArrayMoreItems = this.controls.controls[propIndex].get('moreItemsFormGroup');
|
|
219
|
-
formArrayMoreItems.push(formGroup);
|
|
220
|
-
}
|
|
221
|
-
}
|
|
222
|
-
removeMoreItem(propIndex, removeIndex) {
|
|
223
|
-
const expandedItemIndex = removeIndex - 1;
|
|
224
|
-
this.controls.controls[propIndex].get('moreItemsConfig').value.splice(removeIndex, 1);
|
|
225
|
-
setTimeout(() => {
|
|
226
|
-
this.controls.controls[propIndex].get('moreItemsExpanded').setValue((expandedItemIndex < 0) ? 0 : expandedItemIndex);
|
|
227
|
-
}, 50);
|
|
228
|
-
}
|
|
229
|
-
clearAutocomplete(propIndex) {
|
|
230
|
-
if (this.controls.controls[propIndex].get('multiple').value) {
|
|
231
|
-
this.controls.controls[propIndex].get('autocompleteSelectedValue').setValue([]);
|
|
232
|
-
this.controls.controls[propIndex].get('value').setValue(null);
|
|
233
|
-
}
|
|
234
|
-
else {
|
|
235
|
-
this.controls.controls[propIndex].get('autocompleteSelectedValue').setValue(this.formConfig[propIndex].autocompleteDefaultValueOnClear ?? null);
|
|
236
|
-
this.controls.controls[propIndex].get('value').setValue(this.formConfig[propIndex].autocompleteDefaultValueOnClear ?? null);
|
|
237
|
-
}
|
|
238
|
-
}
|
|
239
|
-
display(option) {
|
|
240
|
-
return option ? option.name : undefined;
|
|
241
|
-
}
|
|
242
|
-
removeOptionOnAutocomplete(propIndex, option) {
|
|
243
|
-
const value = this.controls.controls[propIndex].get('autocompleteSelectedValue').value.filter(item => item !== option);
|
|
244
|
-
this.controls.controls[propIndex].get('autocompleteSelectedValue').setValue(value);
|
|
245
|
-
if (value.length === 0) {
|
|
246
|
-
this.controls.controls[propIndex].get('autocompleteSelectedValue').setValue([]);
|
|
247
|
-
this.controls.controls[propIndex].get('value').setValue(null);
|
|
248
|
-
}
|
|
249
|
-
else if (this.formConfig[propIndex].valueChanges) {
|
|
250
|
-
this.formConfig[propIndex].valueChanges(value.map(item => item.value));
|
|
251
|
-
}
|
|
252
|
-
}
|
|
253
|
-
getColorChip(config) {
|
|
254
|
-
return config.color;
|
|
255
|
-
}
|
|
256
|
-
getAutocompleteOptions(propriedade) {
|
|
257
|
-
return propriedade.get('autocompleteOptionsFiltered').value;
|
|
258
|
-
}
|
|
259
|
-
getDynamicFormConfig(propriedade) {
|
|
260
|
-
return propriedade.get('dynamicFormConfig').value;
|
|
261
|
-
}
|
|
262
|
-
getRandomString() {
|
|
263
|
-
return randomString(20, {
|
|
264
|
-
lowercase: true,
|
|
265
|
-
numbers: true,
|
|
266
|
-
specialCharacters: false,
|
|
267
|
-
uppercase: true
|
|
268
|
-
});
|
|
269
|
-
}
|
|
270
|
-
newControl(config) {
|
|
271
|
-
let validators = config.syncValidators ?? [];
|
|
272
|
-
let value = config.value ?? '';
|
|
273
|
-
let valueSelectedAutocomplete = (config.multiple ? [] : (config.autocompleteDefaultValueOnClear ?? null));
|
|
274
|
-
if (config.required === true)
|
|
275
|
-
validators.push(Validators.required);
|
|
276
|
-
if (config.min && typeof config.min === "number")
|
|
277
|
-
validators.push(Validators.min(config.min));
|
|
278
|
-
if (config.max && typeof config.max === "number")
|
|
279
|
-
validators.push(Validators.max(config.max));
|
|
280
|
-
if (config.type === DynamicFormTypeFieldEnum.date ||
|
|
281
|
-
config.type === DynamicFormTypeFieldEnum.datetime ||
|
|
282
|
-
config.type === DynamicFormTypeFieldEnum.time) {
|
|
283
|
-
if (config.min && typeof config.min === "string") {
|
|
284
|
-
validators.push(DateMinValidator(config.min));
|
|
285
|
-
}
|
|
286
|
-
if (config.max && typeof config.max === "string") {
|
|
287
|
-
validators.push(DateMaxValidator(config.max));
|
|
288
|
-
}
|
|
289
|
-
}
|
|
290
|
-
if (config.minLength)
|
|
291
|
-
validators.push(Validators.minLength(config.minLength));
|
|
292
|
-
if (config.maxLength)
|
|
293
|
-
validators.push(Validators.maxLength(config.maxLength));
|
|
294
|
-
if (config.type === DynamicFormTypeFieldEnum.cpf) {
|
|
295
|
-
validators.push(CpfValidator);
|
|
296
|
-
}
|
|
297
|
-
else if (config.type === DynamicFormTypeFieldEnum.cnpj) {
|
|
298
|
-
validators.push(CnpjValidator);
|
|
299
|
-
}
|
|
300
|
-
else if (config.type === DynamicFormTypeFieldEnum.email) {
|
|
301
|
-
validators.push(Validators.email);
|
|
302
|
-
}
|
|
303
|
-
else if (config.type === DynamicFormTypeFieldEnum.autocomplete) {
|
|
304
|
-
if (value) {
|
|
305
|
-
valueSelectedAutocomplete = value;
|
|
306
|
-
value = (config.multiple ? valueSelectedAutocomplete[0] : value);
|
|
307
|
-
}
|
|
308
|
-
if (config.required === true) {
|
|
309
|
-
validators.push(AutocompleteSelectedValidator);
|
|
310
|
-
}
|
|
311
|
-
}
|
|
312
|
-
else if (config.type === DynamicFormTypeFieldEnum.checkbox) {
|
|
313
|
-
value = config.value ?? false;
|
|
314
|
-
}
|
|
315
|
-
if (config.type === DynamicFormTypeFieldEnum.hoursAndMinutes &&
|
|
316
|
-
value.length >= 6) {
|
|
317
|
-
this.hoursAndMinutesMask = '000:00';
|
|
318
|
-
}
|
|
319
|
-
if (config.dynamicFormConfig) {
|
|
320
|
-
const cloneDynamicFormConfig = {};
|
|
321
|
-
Object.assign(cloneDynamicFormConfig, config.dynamicFormConfig);
|
|
322
|
-
cloneDynamicFormConfig.form = config.dynamicFormConfig.form;
|
|
323
|
-
config.dynamicFormConfig = cloneDynamicFormConfig;
|
|
324
|
-
}
|
|
325
|
-
if (config.show === false) {
|
|
326
|
-
validators = [];
|
|
327
|
-
}
|
|
328
|
-
const field = this.fb.group({
|
|
329
|
-
show: [new BehaviorSubject(config.show ?? true)],
|
|
330
|
-
label: [config.label],
|
|
331
|
-
name: [config.name],
|
|
332
|
-
type: [config.type],
|
|
333
|
-
fileButtonConfig: [{
|
|
334
|
-
icon: config?.fileButtonConfig?.icon ?? 'attach_file',
|
|
335
|
-
text: config?.fileButtonConfig?.text ?? 'Clique para anexar arquivos',
|
|
336
|
-
backgroundColor: config?.fileButtonConfig?.backgroundColor ?? 'white',
|
|
337
|
-
color: config?.fileButtonConfig?.color ?? 'blue',
|
|
338
|
-
accept: config?.fileButtonConfig?.accept ?? '*'
|
|
339
|
-
}],
|
|
340
|
-
dynamicFormConfig: [new BehaviorSubject(config.dynamicFormConfig)],
|
|
341
|
-
dynamicFormGroup: this.fb.array([]),
|
|
342
|
-
appearance: [config.appearance],
|
|
343
|
-
floatLabel: [config.floatLabel],
|
|
344
|
-
placeholder: [config.placeholder],
|
|
345
|
-
class: [config.class],
|
|
346
|
-
fieldClass: [config.fieldClass],
|
|
347
|
-
textHint: [config.textHint],
|
|
348
|
-
required: [config.required ?? false],
|
|
349
|
-
min: [config.min ?? 0],
|
|
350
|
-
max: [config.max ?? 99999999999],
|
|
351
|
-
minLength: [config.minLength ?? 0],
|
|
352
|
-
maxLength: [config.maxLength ?? 255],
|
|
353
|
-
disabled: [config.disabled ?? false],
|
|
354
|
-
focus: [config.focus ?? false],
|
|
355
|
-
multiple: [config.multiple ?? false],
|
|
356
|
-
opcoesSelect: [config.opcoesSelect ?? []],
|
|
357
|
-
hidePassword: config.type === DynamicFormTypeFieldEnum.password ? true : null,
|
|
358
|
-
moreItemsButtonIconAddlabel: [config.moreItemsButtonIconAddlabel],
|
|
359
|
-
moreItemsMinItems: [config.moreItemsMinItems ?? 0],
|
|
360
|
-
moreItemsMaxItems: [config.moreItemsMaxItems ?? 100],
|
|
361
|
-
moreItemsIcon: [config.moreItemsIcon],
|
|
362
|
-
moreItemsIconFontColor: [config.moreItemsIconFontColor],
|
|
363
|
-
moreItemsIconBackgroundColor: [config.moreItemsIconBackgroundColor],
|
|
364
|
-
moreItemsExpanded: [''],
|
|
365
|
-
moreItemsConfig: [[]],
|
|
366
|
-
moreItemsFormGroup: this.fb.array([]),
|
|
367
|
-
autocompleteLoading: [new BehaviorSubject(false)],
|
|
368
|
-
autocompleteOptions: [config.autocompleteOptions],
|
|
369
|
-
autocompleteMultipleConfig: [config.autocompleteMultipleConfig],
|
|
370
|
-
autocompleteOptionsFiltered: [new BehaviorSubject([])],
|
|
371
|
-
autocompleteSelectedValue: [valueSelectedAutocomplete],
|
|
372
|
-
autocompleteAddOption: [config.autocompleteAddOption],
|
|
373
|
-
textLogs: [config?.textObs],
|
|
374
|
-
customMasc: [config?.customMasc],
|
|
375
|
-
customMascThousandSeparator: [config?.customMascThousandSeparator ?? ''],
|
|
376
|
-
customMascSuffix: [config?.customMascSuffix ?? ''],
|
|
377
|
-
customMascPrefix: [config?.customMascPrefix ?? ''],
|
|
378
|
-
value: [{ value, disabled: config.disabled }, validators, config.asyncValidators]
|
|
379
|
-
});
|
|
380
|
-
if (config.autocompleteType === "onDemand") {
|
|
381
|
-
const loader = field.get('autocompleteLoading').value;
|
|
382
|
-
loader.next(true);
|
|
383
|
-
config.autocompleteFilter('').subscribe(options => {
|
|
384
|
-
field.get('autocompleteOptionsFiltered').value.next(options);
|
|
385
|
-
loader.next(false);
|
|
386
|
-
});
|
|
387
|
-
}
|
|
388
|
-
return field;
|
|
389
|
-
}
|
|
390
|
-
setValuesOnFields(subject, form) {
|
|
391
|
-
subject.subscribe(item => {
|
|
392
|
-
if (item) {
|
|
393
|
-
const formArray = form.get('formData');
|
|
394
|
-
for (const prop of item.values()) {
|
|
395
|
-
this.setValueByProp(formArray, prop);
|
|
396
|
-
}
|
|
397
|
-
}
|
|
398
|
-
});
|
|
399
|
-
}
|
|
400
|
-
changeVisibilityFields(subject, form) {
|
|
401
|
-
subject.pipe(debounceTime(5)).subscribe(item => {
|
|
402
|
-
if (item) {
|
|
403
|
-
const formArray = form.get('formData');
|
|
404
|
-
for (const prop of item.values()) {
|
|
405
|
-
for (const [indexControl, control] of formArray.controls.entries()) {
|
|
406
|
-
if (control.get('name').value === prop.name) {
|
|
407
|
-
control.get('show').value.next(prop.show);
|
|
408
|
-
const config = this.formConfig[indexControl] ?? null;
|
|
409
|
-
if (prop.show) {
|
|
410
|
-
let validators = [];
|
|
411
|
-
if (config) {
|
|
412
|
-
if (config.type === DynamicFormTypeFieldEnum.dynamicForm) {
|
|
413
|
-
const formArrayMoreItems = control.get('dynamicFormGroup');
|
|
414
|
-
formArrayMoreItems.push(config?.dynamicFormConfig?.form);
|
|
415
|
-
}
|
|
416
|
-
else {
|
|
417
|
-
validators = config.syncValidators ?? [];
|
|
418
|
-
if (config.required === true) {
|
|
419
|
-
validators.push(Validators.required);
|
|
420
|
-
}
|
|
421
|
-
if (config.type === DynamicFormTypeFieldEnum.cpf) {
|
|
422
|
-
validators.push(CpfValidator);
|
|
423
|
-
}
|
|
424
|
-
else if (config.type === DynamicFormTypeFieldEnum.cnpj) {
|
|
425
|
-
validators.push(CnpjValidator);
|
|
426
|
-
}
|
|
427
|
-
else if (config.type === DynamicFormTypeFieldEnum.email) {
|
|
428
|
-
validators.push(Validators.email);
|
|
429
|
-
}
|
|
430
|
-
else if (config.required === true &&
|
|
431
|
-
config.type === DynamicFormTypeFieldEnum.autocomplete) {
|
|
432
|
-
validators.push(AutocompleteSelectedValidator);
|
|
433
|
-
}
|
|
434
|
-
if (config.min && typeof config.min === "number")
|
|
435
|
-
validators.push(Validators.min(config.min));
|
|
436
|
-
if (config.max && typeof config.max === "number")
|
|
437
|
-
validators.push(Validators.max(config.max));
|
|
438
|
-
if (config.type === DynamicFormTypeFieldEnum.date ||
|
|
439
|
-
config.type === DynamicFormTypeFieldEnum.datetime ||
|
|
440
|
-
config.type === DynamicFormTypeFieldEnum.time) {
|
|
441
|
-
if (config.min && typeof config.min === "string") {
|
|
442
|
-
validators.push(DateMinValidator(config.min));
|
|
443
|
-
}
|
|
444
|
-
if (config.max && typeof config.max === "string") {
|
|
445
|
-
validators.push(DateMaxValidator(config.max));
|
|
446
|
-
}
|
|
447
|
-
}
|
|
448
|
-
if (config.minLength)
|
|
449
|
-
validators.push(Validators.minLength(config.minLength));
|
|
450
|
-
if (config.maxLength)
|
|
451
|
-
validators.push(Validators.maxLength(config.maxLength));
|
|
452
|
-
control.get('value').setValidators(validators);
|
|
453
|
-
if (config.asyncValidators) {
|
|
454
|
-
control.get('value').setAsyncValidators(config.asyncValidators);
|
|
455
|
-
}
|
|
456
|
-
}
|
|
457
|
-
control.get('value').updateValueAndValidity();
|
|
458
|
-
if (prop.clearCurrentValue) {
|
|
459
|
-
control.get('value').setValue(null);
|
|
460
|
-
}
|
|
461
|
-
}
|
|
462
|
-
}
|
|
463
|
-
else {
|
|
464
|
-
control.get('value').clearValidators();
|
|
465
|
-
control.get('value').clearAsyncValidators();
|
|
466
|
-
control.setErrors(null);
|
|
467
|
-
control.get('value').setValue(null);
|
|
468
|
-
control.get('value').updateValueAndValidity();
|
|
469
|
-
if (config.type === DynamicFormTypeFieldEnum.dynamicForm) {
|
|
470
|
-
const formGroup = control;
|
|
471
|
-
formGroup.removeControl('dynamicFormGroup');
|
|
472
|
-
formGroup.addControl('dynamicFormGroup', this.fb.array([]));
|
|
473
|
-
}
|
|
474
|
-
}
|
|
475
|
-
break;
|
|
476
|
-
}
|
|
477
|
-
}
|
|
478
|
-
}
|
|
479
|
-
}
|
|
480
|
-
});
|
|
481
|
-
}
|
|
482
|
-
autocompleteFilter(arr, value) {
|
|
483
|
-
return arr.filter(filter => {
|
|
484
|
-
if (typeof value === 'string') {
|
|
485
|
-
if (filter) {
|
|
486
|
-
let find = true;
|
|
487
|
-
value.toLowerCase()
|
|
488
|
-
.split(' ')
|
|
489
|
-
.forEach(part => {
|
|
490
|
-
if (filter.name.toLowerCase().indexOf(part) < 0) {
|
|
491
|
-
find = false;
|
|
492
|
-
return false;
|
|
493
|
-
}
|
|
494
|
-
});
|
|
495
|
-
return find;
|
|
496
|
-
}
|
|
497
|
-
}
|
|
498
|
-
else {
|
|
499
|
-
return true;
|
|
500
|
-
}
|
|
501
|
-
});
|
|
502
|
-
}
|
|
503
|
-
setValueByProp(formArray, prop) {
|
|
504
|
-
if (formArray) {
|
|
505
|
-
if (prop.name.indexOf(' > ') >= 0) {
|
|
506
|
-
let dynamicFormSubject;
|
|
507
|
-
const arrPropName = prop.name.split(' > ');
|
|
508
|
-
let indexPropName = 0;
|
|
509
|
-
do {
|
|
510
|
-
const control = formArray.controls.find(control => control.get('name').value === arrPropName[indexPropName]);
|
|
511
|
-
if (indexPropName === arrPropName.length - 2) {
|
|
512
|
-
dynamicFormSubject = control.get('dynamicFormConfig').value;
|
|
513
|
-
const dynamicForm = dynamicFormSubject.getValue();
|
|
514
|
-
if (dynamicForm.formConfig.find(fc => fc.name === arrPropName[arrPropName.length - 1])) {
|
|
515
|
-
if (dynamicForm.setValues) {
|
|
516
|
-
dynamicForm.setValues.next(koala(dynamicForm.setValues.getValue()).array().merge([{
|
|
517
|
-
name: arrPropName[arrPropName.length - 1],
|
|
518
|
-
value: prop.value
|
|
519
|
-
}]).getValue());
|
|
520
|
-
}
|
|
521
|
-
else {
|
|
522
|
-
dynamicForm.setValues = new BehaviorSubject([{
|
|
523
|
-
name: arrPropName[arrPropName.length - 1],
|
|
524
|
-
value: prop.value
|
|
525
|
-
}]);
|
|
526
|
-
}
|
|
527
|
-
}
|
|
528
|
-
}
|
|
529
|
-
indexPropName++;
|
|
530
|
-
} while (indexPropName < arrPropName.length - 1);
|
|
531
|
-
}
|
|
532
|
-
else {
|
|
533
|
-
for (const control of formArray.controls.values()) {
|
|
534
|
-
if (control.get('name').value === prop.name) {
|
|
535
|
-
control.get('value').setValue(prop.value);
|
|
536
|
-
break;
|
|
537
|
-
}
|
|
538
|
-
}
|
|
539
|
-
}
|
|
540
|
-
}
|
|
541
|
-
}
|
|
542
|
-
async setConfigDynamicForm(newFormGroup) {
|
|
543
|
-
if (this.showFieldsMoreItensConfig) {
|
|
544
|
-
const value = newFormGroup.get('value').value;
|
|
545
|
-
const configs = this.showFieldsMoreItensConfig
|
|
546
|
-
.filter(config => config.nameField === newFormGroup.get('name').value)
|
|
547
|
-
.sort(config => {
|
|
548
|
-
if (config.fnShow(value)) {
|
|
549
|
-
return 1;
|
|
550
|
-
}
|
|
551
|
-
return -1;
|
|
552
|
-
});
|
|
553
|
-
for (const config of configs) {
|
|
554
|
-
if (config) {
|
|
555
|
-
if (config.dynamicFormConfig && config.fnShow(value)) {
|
|
556
|
-
const controlDynamicFormConfig = this.controls
|
|
557
|
-
.controls
|
|
558
|
-
.find(control => config.fieldsToShow.indexOf(control.get('name').value) >= 0);
|
|
559
|
-
const dynamicFormConfigSubject = controlDynamicFormConfig.get('dynamicFormConfig').value;
|
|
560
|
-
dynamicFormConfigSubject.next(null);
|
|
561
|
-
await delay(1);
|
|
562
|
-
dynamicFormConfigSubject.next(config.dynamicFormConfig(value));
|
|
563
|
-
}
|
|
564
|
-
this.dynamicFormService.showFields(this.showFields, config.fieldsToShow, config.fnShow(value), config.clearCurrentValue);
|
|
565
|
-
}
|
|
566
|
-
}
|
|
567
|
-
}
|
|
568
|
-
}
|
|
569
|
-
validateAutocompleteSelect(selectedValues, value) {
|
|
570
|
-
let isValid = true;
|
|
571
|
-
for (const selectedItem of selectedValues.values()) {
|
|
572
|
-
if (selectedItem.name === value.name) {
|
|
573
|
-
isValid = false;
|
|
574
|
-
break;
|
|
575
|
-
}
|
|
576
|
-
}
|
|
577
|
-
return isValid;
|
|
578
|
-
}
|
|
579
|
-
}
|
|
580
|
-
DynamicFormComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.
|
|
581
|
-
DynamicFormComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.11", type: DynamicFormComponent, selector: "koala-dynamic-form", inputs: { form: "form", formConfig: "formConfig", showFields: "showFields", showFieldsMoreItensConfig: "showFieldsMoreItensConfig", setValues: "setValues", tabIndexStart: "tabIndexStart" }, usesInheritance: true, ngImport: i0, template: "<div [formGroup]=\"form\" class=\"p-relative w-100\" [id]=\"formId\">\n <div *ngFor=\"let propriedade of controls?.controls; let i = index;\"\n [ngClass]=\"(propriedade.get('show').value | async) ? propriedade.get('class').value : 'd-none'\"\n formArrayName=\"formData\">\n\t <div *ngIf=\"propriedade.get('show').value | async\">\n\t <mat-form-field\n\t\t *ngIf=\"propriedade.get('type').value == typeField.text ||\n\t propriedade.get('type').value == typeField.password ||\n\t propriedade.get('type').value == typeField.cpf ||\n\t propriedade.get('type').value == typeField.cnpj ||\n\t propriedade.get('type').value == typeField.datetime ||\n\t propriedade.get('type').value == typeField.email ||\n\t propriedade.get('type').value == typeField.number ||\n\t propriedade.get('type').value == typeField.stringNumber ||\n\t propriedade.get('type').value == typeField.time ||\n\t propriedade.get('type').value == typeField.date ||\n\t propriedade.get('type').value == typeField.hoursAndMinutes ||\n\t propriedade.get('type').value == typeField.phone ||\n\t propriedade.get('type').value == typeField.percent ||\n\t propriedade.get('type').value == typeField.color ||\n\t propriedade.get('type').value == typeField.month ||\n\t propriedade.get('type').value == typeField.competenceDate ||\n propriedade.get('type').value == typeField.stringWithCustomMasc\"\n\t\t [appearance]=\"propriedade.get('appearance').value\"\n\t\t [floatLabel]=\"propriedade.get('floatLabel').value\"\n\t\t [formGroupName]=\"i\"\n\t\t [ngClass]=\"propriedade.get('fieldClass').value\">\n\t <mat-label>{{propriedade.get('label').value}}</mat-label>\n\t <input\n\t\t [dropSpecialCharacters]=\"false\"\n\t\t [koalaAutoFocus]=\"propriedade.get('focus').value\"\n\t\t (keyup)=\"hoursAndMinutesApplyMask(i, $event)\"\n\t\t [required]=\"propriedade.get('required').value\"\n\t\t [tabIndex]=\"tabIndexStart + i\"\n\t\t [mask]=\"((propriedade.get('type').value == typeField.competenceDate) ? '00/0000' : null) ||\n\t\t ((propriedade.get('type').value == typeField.phone) ? '(00)0000-0000?0' : null) ||\n\t\t ((propriedade.get('type').value == typeField.stringNumber) ? '0{'+propriedade.get('maxLength').value+'}' : null) ||\n ((propriedade.get('type').value == typeField.cpf) ? '000.000.000-00' : null) ||\n ((propriedade.get('type').value == typeField.cnpj) ? '00.000.000/0000-00' : null) ||\n ((propriedade.get('type').value == typeField.percent) ? 'percent' : null) ||\n\t\t\t\t\t\t\t\t\t((propriedade.get('type').value == typeField.hoursAndMinutes) ? hoursAndMinutesMask : null) ||\n\t\t\t\t\t\t\t\t\t((propriedade.get('type').value == typeField.stringWithCustomMasc) ? propriedade.get('customMasc').value : null)\"\n\t\t [validation]=\"\n\t (propriedade.get('type').value == typeField.cpf && propriedade.get('value').errors?.cpfInvalid) ||\n\t (propriedade.get('type').value == typeField.cnpj && propriedade.get('value').errors?.cnpjInvalid)\"\n\t\t [type]=\"((propriedade.get('type').value == typeField.cpf ||\n propriedade.get('type').value == typeField.cnpj ||\n propriedade.get('type').value == typeField.phone ||\n propriedade.get('type').value == typeField.percent\n )) ? 'tel' : (\n propriedade.get('type').value == typeField.month ?\n 'month' : (\n propriedade.get('type').value == typeField.date ?\n 'date' : (\n propriedade.get('type').value == typeField.datetime ?\n 'datetime-local' : (\n propriedade.get('type').value == typeField.email ?\n 'email' : (\n propriedade.get('type').value == typeField.number ?\n 'number' : (\n propriedade.get('type').value == typeField.time ?\n 'time' : (\n propriedade.get('type').value == typeField.password ?\n 'password' : (\n propriedade.get('type').value == typeField.color ?\n 'color' : 'text'))))))))\"\n [min]=\"propriedade.get('min').value\"\n [max]=\"propriedade.get('max').value\"\n [minLength]=\"propriedade.get('minLength').value\"\n [maxLength]=\"propriedade.get('maxLength').value\"\n [thousandSeparator]=\"propriedade.get('customMascThousandSeparator').value\"\n [suffix]=\"propriedade.get('customMascSuffix').value\"\n [prefix]=\"propriedade.get('customMascPrefix').value\"\n separatorLimit=\"0\"\n [autocomplete]=\"getRandomString()\"\n\t\t formControlName=\"value\"\n\t\t matInput/>\n\t <button\n\t\t (click)=\"passwordView(i)\"\n\t\t *ngIf=\"propriedade.get('hidePassword').value !== null\"\n\t\t [attr.aria-label]=\"'Hide password'\"\n\t\t [attr.aria-pressed]=\"propriedade.get('hidePassword').value\"\n\t\t mat-icon-button matSuffix tabindex=\"-1\" type=\"button\">\n\t <mat-icon>{{propriedade.get('hidePassword').value ? 'visibility_off' : 'visibility'}}</mat-icon>\n\t </button>\n\t <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n\t <mat-icon>info</mat-icon>\n\t\t {{propriedade.get('textHint').value}}\n\t </mat-hint>\n\t <mat-error *ngIf=\"propriedade.get('value').errors?.required\">\n\t <mat-icon>error</mat-icon>\n {{errorMessage.getRequiredMessage(propriedade.get('label').value)}}\n\t </mat-error>\n\t <mat-error *ngIf=\"propriedade.get('value').errors?.cpfInvalid\">\n\t <mat-icon>error</mat-icon>\n {{errorMessage.getInvalidMessage(propriedade.get('label').value)}}\n\t </mat-error>\n\t <mat-error *ngIf=\"propriedade.get('value').errors?.cnpjInvalid\">\n\t <mat-icon>error</mat-icon>\n {{errorMessage.getInvalidMessage(propriedade.get('label').value)}}\n\t </mat-error>\n\t <mat-error *ngIf=\"propriedade.get('value').errors?.email\">\n\t <mat-icon>error</mat-icon>\n {{errorMessage.getInvalidMessage(propriedade.get('label').value)}}\n\t </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.min\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMinMessage(propriedade.get('min').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.max\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMaxMessage(propriedade.get('max').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.minLength\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMinLengthMessage(propriedade.get('minLength').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.maxLength\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMaxLengthMessage(propriedade.get('maxLength').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.dateMin\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getDateMinMessage()}}\n {{propriedade.get('min').value | date:\"shortDate\"}}.\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.dateMax\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getDateMaxMessage()}}\n {{propriedade.get('max').value | date:\"shortDate\"}}.\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n <mat-icon>error</mat-icon>\n {{propriedade.get('value').errors?.customError.message}}.\n </mat-error>\n\t </mat-form-field>\n\t <mat-form-field\n\t\t *ngIf=\"propriedade.get('type').value == typeField.coin\"\n\t\t [appearance]=\"propriedade.get('appearance').value\"\n\t\t [floatLabel]=\"propriedade.get('floatLabel').value\"\n\t\t [formGroupName]=\"i\"\n\t\t [ngClass]=\"propriedade.get('fieldClass').value\">\n\t <mat-label>{{propriedade.get('label').value}}</mat-label>\n\t <input\n\t\t [koalaAutoFocus]=\"propriedade.get('focus').value\"\n\t\t [required]=\"propriedade.get('required').value\"\n [tabIndex]=\"tabIndexStart + i\"\n [min]=\"propriedade.get('min').value\"\n [max]=\"propriedade.get('max').value\"\n [minLength]=\"propriedade.get('minLength').value\"\n [maxLength]=\"propriedade.get('maxLength').value\"\n [autocomplete]=\"getRandomString()\"\n\t\t currencyMask\n\t\t formControlName=\"value\"\n\t\t matInput\n\t\t type=\"tel\"/>\n\t <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n\t <mat-icon>info</mat-icon>\n\t\t {{propriedade.get('textHint').value}}\n\t </mat-hint>\n <mat-error *ngIf=\"propriedade.get('value').errors?.min\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMinMessage(propriedade.get('min').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.max\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMaxMessage(propriedade.get('max').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.minLength\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMinLengthMessage(propriedade.get('minLength').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.maxLength\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMaxLengthMessage(propriedade.get('maxLength').value)}}\n </mat-error>\n\t <mat-error *ngIf=\"propriedade.get('value').errors?.required\">\n\t <mat-icon>error</mat-icon>\n {{errorMessage.getRequiredMessage(propriedade.get('label').value)}}\n\t </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n <mat-icon>error</mat-icon>\n {{propriedade.get('value').errors?.customError.message}}.\n </mat-error>\n\t </mat-form-field>\n <mat-form-field\n *ngIf=\"propriedade.get('type').value == typeField.float\"\n [appearance]=\"propriedade.get('appearance').value\"\n [floatLabel]=\"propriedade.get('floatLabel').value\"\n [formGroupName]=\"i\"\n [ngClass]=\"propriedade.get('fieldClass').value\">\n <mat-label>{{propriedade.get('label').value}}</mat-label>\n <input\n [koalaAutoFocus]=\"propriedade.get('focus').value\"\n [required]=\"propriedade.get('required').value\"\n [tabIndex]=\"tabIndexStart + i\"\n [min]=\"propriedade.get('min').value\"\n [max]=\"propriedade.get('max').value\"\n [minLength]=\"propriedade.get('minLength').value\"\n [maxLength]=\"propriedade.get('maxLength').value\"\n [autocomplete]=\"getRandomString()\"\n currencyMask\n [options]=\"{prefix: ''}\"\n formControlName=\"value\"\n matInput\n type=\"tel\"/>\n <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n <mat-icon>info</mat-icon>\n {{propriedade.get('textHint').value}}\n </mat-hint>\n <mat-error *ngIf=\"propriedade.get('value').errors?.min\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMinMessage(propriedade.get('min').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.max\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMaxMessage(propriedade.get('max').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.minLength\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMinLengthMessage(propriedade.get('minLength').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.maxLength\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMaxLengthMessage(propriedade.get('maxLength').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.required\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getRequiredMessage(propriedade.get('label').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n <mat-icon>error</mat-icon>\n {{propriedade.get('value').errors?.customError.message}}.\n </mat-error>\n </mat-form-field>\n\t <mat-form-field\n\t\t *ngIf=\"propriedade.get('type').value == typeField.valueList ||\n\t propriedade.get('type').value == typeField.textarea\"\n\t\t [appearance]=\"propriedade.get('appearance').value\"\n\t\t [floatLabel]=\"propriedade.get('floatLabel').value\"\n\t\t [formGroupName]=\"i\"\n\t\t [ngClass]=\"propriedade.get('fieldClass').value\">\n\t <mat-label>{{propriedade.get('label').value}}</mat-label>\n\t <textarea\n #textarea\n\t\t [koalaAutoFocus]=\"propriedade.get('focus').value\"\n cdkTextareaAutosize\n #autosize=\"cdkTextareaAutosize\"\n\t\t [cdkAutosizeMaxRows]=\"8\"\n\t\t [cdkAutosizeMinRows]=\"3\"\n\t\t [required]=\"propriedade.get('required').value\"\n [tabIndex]=\"tabIndexStart + i\"\n [minLength]=\"propriedade.get('minLength').value\"\n [maxLength]=\"propriedade.get('maxLength').value\"\n\t\t formControlName=\"value\"\n\t\t matInput>\n </textarea>\n\t <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n\t <mat-icon>info</mat-icon>\n\t\t {{propriedade.get('textHint').value}}\n\t </mat-hint>\n <mat-hint align=\"end\" *ngIf=\"propriedade.get('maxLength').value\">\n {{textarea.value.length}}/{{propriedade.get('maxLength').value}}\n </mat-hint>\n <mat-error *ngIf=\"propriedade.get('value').errors?.minLength\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMinLengthMessage(propriedade.get('minLength').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.maxLength\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMaxLengthMessage(propriedade.get('maxLength').value)}}\n </mat-error>\n\t <mat-error *ngIf=\"propriedade.get('value').errors?.required\">\n\t <mat-icon>error</mat-icon>\n {{errorMessage.getRequiredMessage(propriedade.get('label').value)}}\n\t </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n <mat-icon>error</mat-icon>\n {{propriedade.get('value').errors?.customError.message}}.\n </mat-error>\n\t </mat-form-field>\n\t\t <mat-form-field\n\t\t\t *ngIf=\"propriedade.get('type').value == typeField.textLogs\"\n\t\t\t [appearance]=\"propriedade.get('appearance').value\"\n\t\t\t [floatLabel]=\"propriedade.get('floatLabel').value\"\n\t\t\t [formGroupName]=\"i\"\n\t\t\t [ngClass]=\"propriedade.get('fieldClass').value\">\n\t <mat-label>{{propriedade.get('label').value}}</mat-label>\n\t <div [innerHTML]=\"propriedade.get('textLogs').value\" class=\"text-obs\"></div>\n\t <textarea\n #textarea\n\t\t [koalaAutoFocus]=\"propriedade.get('focus').value\"\n cdkTextareaAutosize\n #autosize=\"cdkTextareaAutosize\"\n\t\t [cdkAutosizeMaxRows]=\"8\"\n\t\t [cdkAutosizeMinRows]=\"3\"\n\t\t [required]=\"propriedade.get('required').value\"\n [tabIndex]=\"tabIndexStart + i\"\n [minLength]=\"propriedade.get('minLength').value\"\n [maxLength]=\"propriedade.get('maxLength').value\"\n\t\t formControlName=\"value\"\n\t\t matInput>\n\t </textarea>\n\t <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n\t <mat-icon>info</mat-icon>\n\t\t {{propriedade.get('textHint').value}}\n\t </mat-hint>\n <mat-hint align=\"end\" *ngIf=\"propriedade.get('maxLength').value\">\n {{textarea.value.length}}/{{propriedade.get('maxLength').value}}\n </mat-hint>\n <mat-error *ngIf=\"propriedade.get('value').errors?.minLength\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMinLengthMessage(propriedade.get('minLength').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.maxLength\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMaxLengthMessage(propriedade.get('maxLength').value)}}\n </mat-error>\n\t <mat-error *ngIf=\"propriedade.get('value').errors?.required\">\n\t <mat-icon>error</mat-icon>\n {{errorMessage.getRequiredMessage(propriedade.get('label').value)}}\n\t </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n <mat-icon>error</mat-icon>\n {{propriedade.get('value').errors?.customError.message}}.\n </mat-error>\n\t </mat-form-field>\n\t <mat-form-field\n\t\t *ngIf=\"propriedade.get('type').value == typeField.select\"\n\t\t [appearance]=\"propriedade.get('appearance').value\"\n\t\t [floatLabel]=\"propriedade.get('floatLabel').value\"\n\t\t [formGroupName]=\"i\"\n\t\t [ngClass]=\"propriedade.get('fieldClass').value\">\n\t <mat-label>{{propriedade.get('label').value}}</mat-label>\n\t <mat-select [multiple]=\"propriedade.get('multiple').value\" [required]=\"propriedade.get('required').value\"\n [tabIndex]=\"tabIndexStart + i\" formControlName=\"value\">\n\t <mat-option *ngFor=\"let options of propriedade.get('opcoesSelect').value\" [value]=\"options.value\">\n\t {{options.name}}\n\t </mat-option>\n\t </mat-select>\n\t <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n\t <mat-icon>info</mat-icon>\n\t\t {{propriedade.get('textHint').value}}\n\t </mat-hint>\n\t <mat-error *ngIf=\"propriedade.get('value').errors?.required\">\n\t <mat-icon>error</mat-icon>\n {{errorMessage.getRequiredMessage(propriedade.get('label').value)}}\n\t </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n <mat-icon>error</mat-icon>\n {{propriedade.get('value').errors?.customError.message}}.\n </mat-error>\n\t </mat-form-field>\n <mat-form-field\n class=\"select-multiple-native\"\n *ngIf=\"propriedade.get('type').value == typeField.selectMultipleNative\"\n [appearance]=\"propriedade.get('appearance').value\"\n [floatLabel]=\"propriedade.get('floatLabel').value\"\n [formGroupName]=\"i\"\n [ngClass]=\"propriedade.get('fieldClass').value\">\n <mat-label>{{propriedade.get('label').value}}</mat-label>\n <select\n matNativeControl\n formControlName=\"value\"\n multiple\n [tabIndex]=\"tabIndexStart + i\"\n [required]=\"propriedade.get('required').value\">\n <option *ngFor=\"let options of propriedade.get('opcoesSelect').value\" [value]=\"options.value\">\n {{options.name}}\n </option>\n </select>\n <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n <mat-icon>info</mat-icon>\n {{propriedade.get('textHint').value}}\n </mat-hint>\n <mat-error *ngIf=\"propriedade.get('value').errors?.required\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getRequiredMessage(propriedade.get('label').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n <mat-icon>error</mat-icon>\n {{propriedade.get('value').errors?.customError.message}}.\n </mat-error>\n </mat-form-field>\n\t <div\n\t\t *ngIf=\"propriedade.get('type').value == typeField.checkbox\"\n\t\t [formGroupName]=\"i\"\n\t\t [ngClass]=\"propriedade.get('fieldClass').value\">\n\t <mat-checkbox\n [tabIndex]=\"tabIndexStart + i\"\n\t\t formControlName=\"value\"\n\t\t value=\"true\">\n\t {{propriedade.get('label').value}}\n\t </mat-checkbox>\n\t </div>\n\t\t <div\n\t\t\t *ngIf=\"propriedade.get('type').value == typeField.moreItems\"\n\t\t\t [formGroupName]=\"i\"\n\t\t\t [ngClass]=\"propriedade.get('fieldClass').value\"\n\t\t\t class=\"more-items-content\">\n\t\t\t <fieldset>\n\t\t\t\t <legend>\n\t\t\t\t\t <koala-button\n\t\t\t\t\t\t (click)=\"addMoreItem(i)\"\n\t\t\t\t\t\t [disabled]=\"propriedade.get('moreItemsConfig').value.length === propriedade.get('moreItemsMaxItems').value\"\n\t\t\t\t\t\t [tooltip]=\"propriedade.get('moreItemsButtonIconAddlabel').value\"\n\t\t\t\t\t\t [backgroundColor]=\"propriedade.get('moreItemsIconBackgroundColor').value\"\n [color]=\"propriedade.get('moreItemsIconFontColor').value\"\n\t\t\t\t\t\t class=\"btn-add-more-items\"\n\t\t\t\t\t\t icon=\"add\">\n\t\t\t\t\t </koala-button>\n\t\t\t\t\t {{propriedade.get('label').value}} (Min.: {{propriedade.get('moreItemsMinItems').value}}\n\t\t\t\t\t | M\u00E1x.: {{propriedade.get('moreItemsMaxItems').value}})\n\t\t\t\t </legend>\n\t\t\t\t <mat-accordion class=\"items\" multi>\n\t\t\t\t\t <mat-expansion-panel\n\t\t\t\t\t\t *ngFor=\"let item of propriedade.get('moreItemsConfig').value.slice().reverse(); index as indexMoreItems\"\n\t\t\t\t\t\t expanded>\n\t\t\t\t\t\t <mat-expansion-panel-header>\n\t\t\t\t\t\t\t\t<mat-panel-title class=\"titleForm\">#\n\t\t\t\t\t\t\t\t\t{{propriedade.get('moreItemsConfig').value.length - 1 - indexMoreItems + 1}}</mat-panel-title>\n\t\t\t\t\t\t\t\t<mat-panel-description class=\"titleForm\">\n\t\t\t\t\t\t\t\t\t{{propriedade.get('label').value}}\n\t\t\t\t\t\t\t\t\t<mat-icon>{{propriedade.get('moreItemsIcon').value}}</mat-icon>\n\t\t\t\t\t\t\t\t</mat-panel-description>\n\t\t\t\t\t\t\t</mat-expansion-panel-header>\n\t\t\t\t\t\t <koala-dynamic-form\n\t\t\t\t\t\t\t [showFieldsMoreItensConfig]=\"item.showFieldsMoreItensConfig\"\n\t\t\t\t\t\t\t [showFields]=\"item.showFields\"\n\t\t\t\t\t\t\t [formConfig]=\"item.formConfig\"\n\t\t\t\t\t\t\t [form]=\"item.form\"\n [tabIndexStart]=\"tabIndexStart + i\">\n\t\t\t\t\t\t </koala-dynamic-form>\n\t\t\t\t\t <mat-action-row\n\t\t\t\t\t\t *ngIf=\"propriedade.get('moreItemsConfig').value.length > propriedade.get('moreItemsMinItems').value\">\n\t\t\t\t\t <button\n\t\t\t\t\t\t (click)=\"removeMoreItem(i, propriedade.get('moreItemsConfig').value.length - 1 - indexMoreItems)\"\n\t\t\t\t\t\t mat-icon-button>\n\t\t\t\t\t\t <mat-icon>delete</mat-icon>\n\t\t\t\t\t </button>\n\t\t\t\t\t </mat-action-row>\n\t\t\t\t\t </mat-expansion-panel>\n\t\t\t\t </mat-accordion>\n\t\t\t </fieldset>\n\t\t </div>\n\t\t <mat-form-field\n\t\t\t *ngIf=\"propriedade.get('type').value == typeField.autocomplete\"\n\t\t\t [appearance]=\"propriedade.get('appearance').value\"\n\t\t\t [floatLabel]=\"propriedade.get('floatLabel').value\"\n\t\t\t [formGroupName]=\"i\"\n\t\t\t [ngClass]=\"propriedade.get('fieldClass').value\">\n\t <mat-label>{{propriedade.get('label').value}} {{propriedade.get('multiple').value &&\n\t propriedade.get('required').value ? '*' : ''}}</mat-label>\n\t\t\t <div *ngIf=\"propriedade.get('multiple').value else single\">\n\t <mat-chip-list #chipList>\n <mat-chip\n (removed)=\"removeOptionOnAutocomplete(i, option)\"\n *ngFor=\"let option of propriedade.get('autocompleteSelectedValue').value\"\n [color]=\"getColorChip(propriedade.get('autocompleteMultipleConfig').value | async)\"\n [removable]=\"true\"\n [selectable]=\"true\">\n {{display(option)}}\n <mat-icon *ngIf=\"!propriedade.get('disabled').value\" matChipRemove>cancel</mat-icon>\n </mat-chip>\n\t <input\n [id]=\"'autocomplete-' + propriedade.get('name').value\"\n [koalaAutoFocus]=\"propriedade.get('focus').value\"\n\t\t [required]=\"propriedade.get('required').value\"\n\t\t [matAutocomplete]=\"auto\"\n\t\t [matChipInputFor]=\"chipList\"\n [tabIndex]=\"tabIndexStart + i\"\n [autocomplete]=\"getRandomString()\"\n\t\t formControlName=\"value\"\n\t\t matInput\n\t\t type=\"text\"\n\t\t placeholder=\"Selecione um ou mais op\u00E7\u00F5es...\">\n\t </mat-chip-list>\n\t </div>\n\t <ng-template #single>\n\t\t <input\n\t\t\t [matAutocomplete]=\"auto\"\n [koalaAutoFocus]=\"propriedade.get('focus').value\"\n\t\t\t [required]=\"propriedade.get('required').value\"\n [tabIndex]=\"tabIndexStart + i\"\n [autocomplete]=\"getRandomString()\"\n\t\t\t formControlName=\"value\"\n\t\t\t matInput\n\t\t\t placeholder=\"Selecione uma op\u00E7\u00E3o...\"\n\t\t\t type=\"text\">\n\t </ng-template>\n\t <mat-spinner *ngIf=\"propriedade.get('autocompleteLoading').value | async\" color=\"primary\"\n\t matSuffix></mat-spinner>\n\t <button\n\t\t (click)=\"clearAutocomplete(i)\"\n\t\t *ngIf=\"\n\t !(propriedade.get('autocompleteLoading').value | async) &&\n\t !propriedade.get('disabled').value\"\n\t\t color=\"warn\"\n\t\t mat-icon-button\n\t\t matSuffix\n\t\t type=\"button\">\n\t <mat-icon>close</mat-icon>\n\t </button>\n\t <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n\t <mat-icon>info</mat-icon>\n\t\t {{propriedade.get('textHint').value}}\n\t </mat-hint>\n\t <mat-error *ngIf=\"propriedade.get('value').errors?.required || propriedade.get('value').errors?.autocompleteSelected\">\n\t <mat-icon>error</mat-icon>\n {{errorMessage.getAutocompleteMessage(propriedade.get('label').value)}}\n\t </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n <mat-icon>error</mat-icon>\n {{propriedade.get('value').errors?.customError.message}}.\n </mat-error>\n\t <mat-autocomplete\n\t\t #auto=\"matAutocomplete\"\n\t\t [displayWith]=\"display\" autoActiveFirstOption>\n <mat-option\n *ngIf=\"propriedade.get('autocompleteAddOption').value && isValidNewAutocompleteOption(propriedade.get('value').value)\"\n [value]=\"{\n value: {id: 0, name: propriedade.get('value').value},\n name: propriedade.get('value').value\n }\">\n Add <b>{{propriedade.get('value').value}}</b>...\n </mat-option>\n\t\t <div *ngIf=\"(getAutocompleteOptions(propriedade) | async) as options\">\n\t\t <mat-option *ngFor=\"let option of options\" [value]=\"option\">\n\t\t {{option.name}}\n\t\t </mat-option>\n\t\t </div>\n\t </mat-autocomplete>\n\t </mat-form-field>\n\t\t <div *ngIf=\"propriedade.get('type').value == typeField.file\">\n\t\t\t <koala-file-button\n\t\t\t\t (getFiles)=\"propriedade.get('value').setValue($event)\"\n\t\t\t\t [accept]=\"propriedade.get('fileButtonConfig').value.accept\"\n\t\t\t\t [backgroundColor]=\"propriedade.get('fileButtonConfig').value.backgroundColor\"\n\t\t\t\t [color]=\"propriedade.get('fileButtonConfig').value.color\"\n\t\t\t\t [disabled]=\"propriedade.get('disabled').value\"\n\t\t\t\t [icon]=\"propriedade.get('fileButtonConfig').value.icon\"\n\t\t\t\t [multiple]=\"propriedade.get('multiple').value\"\n\t\t\t\t [text]=\"propriedade.get('fileButtonConfig').value.text\">\n\t\t\t </koala-file-button>\n\t\t </div>\n\t\t <div *ngIf=\"\n\t\t propriedade.get('type').value == typeField.dynamicForm &&\n\t\t\t\t(getDynamicFormConfig(propriedade) | async) as dynamicFormConfig\">\n\t\t\t <fieldset *ngIf=\"propriedade.get('label').value else dynamicFormWithoutLabel\">\n\t\t\t\t <legend>{{propriedade.get('label').value}}</legend>\n\t\t\t\t <koala-dynamic-form\n\t\t\t\t\t [formConfig]=\"dynamicFormConfig.formConfig\"\n\t\t\t\t\t [form]=\"dynamicFormConfig.form\"\n\t\t\t\t\t [setValues]=\"dynamicFormConfig.setValues\"\n\t\t\t\t\t [showFields]=\"dynamicFormConfig.showFields\"\n [tabIndexStart]=\"tabIndexStart + i\">\n\t\t\t\t </koala-dynamic-form>\n\t\t\t </fieldset>\n\t\t\t <ng-template #dynamicFormWithoutLabel>\n\t\t\t\t <koala-dynamic-form\n\t\t\t\t\t [formConfig]=\"dynamicFormConfig.formConfig\"\n\t\t\t\t\t [form]=\"dynamicFormConfig.form\"\n\t\t\t\t\t [setValues]=\"dynamicFormConfig.setValues\"\n\t\t\t\t\t [showFields]=\"dynamicFormConfig.showFields\"\n [tabIndexStart]=\"tabIndexStart + i\">\n\t\t\t\t </koala-dynamic-form>\n\t\t\t </ng-template>\n\t\t </div>\n <div\n class=\"radio-btn-group\"\n *ngIf=\"propriedade.get('type').value == typeField.radio\"\n [formGroupName]=\"i\"\n [ngClass]=\"propriedade.get('fieldClass').value\">\n <mat-radio-group formControlName=\"value\">\n <label *ngIf=\"propriedade.get('label').value\">{{propriedade.get('label').value}}</label>\n <mat-radio-button\n [tabIndex]=\"tabIndexStart + i\"\n *ngFor=\"let options of propriedade.get('opcoesSelect').value\"\n [value]=\"options.value\">\n {{options.name}}\n </mat-radio-button>\n </mat-radio-group>\n </div>\n\t </div>\n </div>\n <ng-content select=\"[btn-submit]\"></ng-content>\n</div>\n", styles: [".more-items-content fieldset{border:1px solid #cccccc;padding:16px}.more-items-content fieldset legend{font-family:Josefin Sans,sans-serif;font-size:11px;font-weight:700;padding:0 8px}.more-items-content .items .titleForm{color:#616161}.more-items-content .items .mat-expansion-panel-header-title,.more-items-content .items .mat-expansion-panel-header-description{flex-basis:0}.more-items-content .items .mat-expansion-panel-header-description{align-items:center;justify-content:space-between}.more-items-content .items .mat-form-field+.mat-form-field{margin-left:8px}.radio-btn-group label{position:relative;display:block;padding:10px 0}.text-obs{background:#eeeeee;border-radius:5px;color:#212121;font-family:OpenSansLight,sans-serif;height:150px;margin:0 auto 10px;overflow-y:auto;padding:10px;position:relative;width:calc(100% - 27px)}.select-multiple-native{margin-bottom:15px}.select-multiple-native select{width:100%;height:150px;background:transparent;border:none}.select-multiple-native select:focus,.select-multiple-native select:active{outline:none}.select-multiple-native select option{padding:5px 10px;font-family:JosefinSans,sans-serif}.select-multiple-native select option:checked{background:#f1f1f1!important}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i1.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i1.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: i1.SelectMultipleControlValueAccessor, selector: "select[multiple][formControlName],select[multiple][formControl],select[multiple][ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i1.FormGroupName, selector: "[formGroupName]", inputs: ["formGroupName"] }, { kind: "directive", type: i1.FormArrayName, selector: "[formArrayName]", inputs: ["formArrayName"] }, { kind: "directive", type: i4.CurrencyMaskDirective, selector: "[currencyMask]", inputs: ["max", "min", "options"] }, { kind: "directive", type: i5.MaskDirective, selector: "input[mask], textarea[mask]", inputs: ["mask", "specialCharacters", "patterns", "prefix", "suffix", "thousandSeparator", "decimalMarker", "dropSpecialCharacters", "hiddenInput", "showMaskTyped", "placeHolderCharacter", "shownMaskExpression", "showTemplate", "clearIfNotMatch", "validation", "separatorLimit", "allowNegativeNumbers", "leadZeroDateTime", "triggerOnMaskChange"], outputs: ["maskFilled"], exportAs: ["mask", "ngxMask"] }, { kind: "component", type: i6.FileButtonComponent, selector: "koala-file-button", inputs: ["color", "backgroundColor", "icon", "text", "tooltip", "disabled", "multiple", "accept", "setFile", "updateFileList", "autoclear"], outputs: ["getFiles"] }, { kind: "directive", type: i7.CdkTextareaAutosize, selector: "textarea[cdkTextareaAutosize]", inputs: ["cdkAutosizeMinRows", "cdkAutosizeMaxRows", "cdkTextareaAutosize", "placeholder"], exportAs: ["cdkTextareaAutosize"] }, { kind: "directive", type: i8.MatError, selector: "mat-error", inputs: ["id"] }, { kind: "component", type: i8.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i8.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "directive", type: i8.MatLabel, selector: "mat-label" }, { kind: "directive", type: i8.MatSuffix, selector: "[matSuffix]" }, { kind: "directive", type: i9.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: "component", type: i10.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }, { kind: "component", type: i11.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "directive", type: i12.MatRadioGroup, selector: "mat-radio-group", exportAs: ["matRadioGroup"] }, { kind: "component", type: i12.MatRadioButton, selector: "mat-radio-button", inputs: ["disableRipple", "tabIndex"], exportAs: ["matRadioButton"] }, { kind: "component", type: i13.MatCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex"], exportAs: ["matCheckbox"] }, { kind: "component", type: i14.MatAutocomplete, selector: "mat-autocomplete", inputs: ["disableRipple"], exportAs: ["matAutocomplete"] }, { kind: "directive", type: i14.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", exportAs: ["matAutocompleteTrigger"] }, { kind: "component", type: i15.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i16.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i17.MatAccordion, selector: "mat-accordion", inputs: ["multi", "hideToggle", "displayMode", "togglePosition"], exportAs: ["matAccordion"] }, { kind: "component", type: i17.MatExpansionPanel, selector: "mat-expansion-panel", inputs: ["disabled", "expanded", "hideToggle", "togglePosition"], outputs: ["opened", "closed", "expandedChange", "afterExpand", "afterCollapse"], exportAs: ["matExpansionPanel"] }, { kind: "directive", type: i17.MatExpansionPanelActionRow, selector: "mat-action-row" }, { kind: "component", type: i17.MatExpansionPanelHeader, selector: "mat-expansion-panel-header", inputs: ["tabIndex", "expandedHeight", "collapsedHeight"] }, { kind: "directive", type: i17.MatExpansionPanelTitle, selector: "mat-panel-title" }, { kind: "directive", type: i17.MatExpansionPanelDescription, selector: "mat-panel-description" }, { kind: "component", type: i18.MatChipList, selector: "mat-chip-list", inputs: ["role", "aria-describedby", "errorStateMatcher", "multiple", "compareWith", "value", "required", "placeholder", "disabled", "aria-orientation", "selectable", "tabIndex"], outputs: ["change", "valueChange"], exportAs: ["matChipList"] }, { kind: "directive", type: i18.MatChip, selector: "mat-basic-chip, [mat-basic-chip], mat-chip, [mat-chip]", inputs: ["color", "disableRipple", "tabIndex", "role", "selected", "value", "selectable", "disabled", "removable"], outputs: ["selectionChange", "destroyed", "removed"], exportAs: ["matChip"] }, { kind: "directive", type: i18.MatChipInput, selector: "input[matChipInputFor]", inputs: ["matChipInputFor", "matChipInputAddOnBlur", "matChipInputSeparatorKeyCodes", "placeholder", "id", "disabled"], outputs: ["matChipInputTokenEnd"], exportAs: ["matChipInput", "matChipInputFor"] }, { kind: "directive", type: i18.MatChipRemove, selector: "[matChipRemove]" }, { kind: "component", type: i19.ButtonComponent, selector: "koala-button", inputs: ["color", "backgroundColor", "icon", "text", "tooltip", "disabled", "koalaIcon", "koalaIconSize"] }, { kind: "component", type: i20.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "diameter", "strokeWidth", "mode", "value"], exportAs: ["matProgressSpinner"] }, { kind: "component", type: DynamicFormComponent, selector: "koala-dynamic-form", inputs: ["form", "formConfig", "showFields", "showFieldsMoreItensConfig", "setValues", "tabIndexStart"] }, { kind: "directive", type: i21.KoalaAutofocusDirective, selector: "[koalaAutoFocus]", inputs: ["koalaAutoFocus"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i3.DatePipe, name: "date" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
582
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.
|
|
583
|
-
type: Component,
|
|
584
|
-
args: [{ selector: 'koala-dynamic-form', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div [formGroup]=\"form\" class=\"p-relative w-100\" [id]=\"formId\">\n <div *ngFor=\"let propriedade of controls?.controls; let i = index;\"\n [ngClass]=\"(propriedade.get('show').value | async) ? propriedade.get('class').value : 'd-none'\"\n formArrayName=\"formData\">\n\t <div *ngIf=\"propriedade.get('show').value | async\">\n\t <mat-form-field\n\t\t *ngIf=\"propriedade.get('type').value == typeField.text ||\n\t propriedade.get('type').value == typeField.password ||\n\t propriedade.get('type').value == typeField.cpf ||\n\t propriedade.get('type').value == typeField.cnpj ||\n\t propriedade.get('type').value == typeField.datetime ||\n\t propriedade.get('type').value == typeField.email ||\n\t propriedade.get('type').value == typeField.number ||\n\t propriedade.get('type').value == typeField.stringNumber ||\n\t propriedade.get('type').value == typeField.time ||\n\t propriedade.get('type').value == typeField.date ||\n\t propriedade.get('type').value == typeField.hoursAndMinutes ||\n\t propriedade.get('type').value == typeField.phone ||\n\t propriedade.get('type').value == typeField.percent ||\n\t propriedade.get('type').value == typeField.color ||\n\t propriedade.get('type').value == typeField.month ||\n\t propriedade.get('type').value == typeField.competenceDate ||\n propriedade.get('type').value == typeField.stringWithCustomMasc\"\n\t\t [appearance]=\"propriedade.get('appearance').value\"\n\t\t [floatLabel]=\"propriedade.get('floatLabel').value\"\n\t\t [formGroupName]=\"i\"\n\t\t [ngClass]=\"propriedade.get('fieldClass').value\">\n\t <mat-label>{{propriedade.get('label').value}}</mat-label>\n\t <input\n\t\t [dropSpecialCharacters]=\"false\"\n\t\t [koalaAutoFocus]=\"propriedade.get('focus').value\"\n\t\t (keyup)=\"hoursAndMinutesApplyMask(i, $event)\"\n\t\t [required]=\"propriedade.get('required').value\"\n\t\t [tabIndex]=\"tabIndexStart + i\"\n\t\t [mask]=\"((propriedade.get('type').value == typeField.competenceDate) ? '00/0000' : null) ||\n\t\t ((propriedade.get('type').value == typeField.phone) ? '(00)0000-0000?0' : null) ||\n\t\t ((propriedade.get('type').value == typeField.stringNumber) ? '0{'+propriedade.get('maxLength').value+'}' : null) ||\n ((propriedade.get('type').value == typeField.cpf) ? '000.000.000-00' : null) ||\n ((propriedade.get('type').value == typeField.cnpj) ? '00.000.000/0000-00' : null) ||\n ((propriedade.get('type').value == typeField.percent) ? 'percent' : null) ||\n\t\t\t\t\t\t\t\t\t((propriedade.get('type').value == typeField.hoursAndMinutes) ? hoursAndMinutesMask : null) ||\n\t\t\t\t\t\t\t\t\t((propriedade.get('type').value == typeField.stringWithCustomMasc) ? propriedade.get('customMasc').value : null)\"\n\t\t [validation]=\"\n\t (propriedade.get('type').value == typeField.cpf && propriedade.get('value').errors?.cpfInvalid) ||\n\t (propriedade.get('type').value == typeField.cnpj && propriedade.get('value').errors?.cnpjInvalid)\"\n\t\t [type]=\"((propriedade.get('type').value == typeField.cpf ||\n propriedade.get('type').value == typeField.cnpj ||\n propriedade.get('type').value == typeField.phone ||\n propriedade.get('type').value == typeField.percent\n )) ? 'tel' : (\n propriedade.get('type').value == typeField.month ?\n 'month' : (\n propriedade.get('type').value == typeField.date ?\n 'date' : (\n propriedade.get('type').value == typeField.datetime ?\n 'datetime-local' : (\n propriedade.get('type').value == typeField.email ?\n 'email' : (\n propriedade.get('type').value == typeField.number ?\n 'number' : (\n propriedade.get('type').value == typeField.time ?\n 'time' : (\n propriedade.get('type').value == typeField.password ?\n 'password' : (\n propriedade.get('type').value == typeField.color ?\n 'color' : 'text'))))))))\"\n [min]=\"propriedade.get('min').value\"\n [max]=\"propriedade.get('max').value\"\n [minLength]=\"propriedade.get('minLength').value\"\n [maxLength]=\"propriedade.get('maxLength').value\"\n [thousandSeparator]=\"propriedade.get('customMascThousandSeparator').value\"\n [suffix]=\"propriedade.get('customMascSuffix').value\"\n [prefix]=\"propriedade.get('customMascPrefix').value\"\n separatorLimit=\"0\"\n [autocomplete]=\"getRandomString()\"\n\t\t formControlName=\"value\"\n\t\t matInput/>\n\t <button\n\t\t (click)=\"passwordView(i)\"\n\t\t *ngIf=\"propriedade.get('hidePassword').value !== null\"\n\t\t [attr.aria-label]=\"'Hide password'\"\n\t\t [attr.aria-pressed]=\"propriedade.get('hidePassword').value\"\n\t\t mat-icon-button matSuffix tabindex=\"-1\" type=\"button\">\n\t <mat-icon>{{propriedade.get('hidePassword').value ? 'visibility_off' : 'visibility'}}</mat-icon>\n\t </button>\n\t <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n\t <mat-icon>info</mat-icon>\n\t\t {{propriedade.get('textHint').value}}\n\t </mat-hint>\n\t <mat-error *ngIf=\"propriedade.get('value').errors?.required\">\n\t <mat-icon>error</mat-icon>\n {{errorMessage.getRequiredMessage(propriedade.get('label').value)}}\n\t </mat-error>\n\t <mat-error *ngIf=\"propriedade.get('value').errors?.cpfInvalid\">\n\t <mat-icon>error</mat-icon>\n {{errorMessage.getInvalidMessage(propriedade.get('label').value)}}\n\t </mat-error>\n\t <mat-error *ngIf=\"propriedade.get('value').errors?.cnpjInvalid\">\n\t <mat-icon>error</mat-icon>\n {{errorMessage.getInvalidMessage(propriedade.get('label').value)}}\n\t </mat-error>\n\t <mat-error *ngIf=\"propriedade.get('value').errors?.email\">\n\t <mat-icon>error</mat-icon>\n {{errorMessage.getInvalidMessage(propriedade.get('label').value)}}\n\t </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.min\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMinMessage(propriedade.get('min').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.max\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMaxMessage(propriedade.get('max').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.minLength\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMinLengthMessage(propriedade.get('minLength').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.maxLength\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMaxLengthMessage(propriedade.get('maxLength').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.dateMin\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getDateMinMessage()}}\n {{propriedade.get('min').value | date:\"shortDate\"}}.\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.dateMax\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getDateMaxMessage()}}\n {{propriedade.get('max').value | date:\"shortDate\"}}.\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n <mat-icon>error</mat-icon>\n {{propriedade.get('value').errors?.customError.message}}.\n </mat-error>\n\t </mat-form-field>\n\t <mat-form-field\n\t\t *ngIf=\"propriedade.get('type').value == typeField.coin\"\n\t\t [appearance]=\"propriedade.get('appearance').value\"\n\t\t [floatLabel]=\"propriedade.get('floatLabel').value\"\n\t\t [formGroupName]=\"i\"\n\t\t [ngClass]=\"propriedade.get('fieldClass').value\">\n\t <mat-label>{{propriedade.get('label').value}}</mat-label>\n\t <input\n\t\t [koalaAutoFocus]=\"propriedade.get('focus').value\"\n\t\t [required]=\"propriedade.get('required').value\"\n [tabIndex]=\"tabIndexStart + i\"\n [min]=\"propriedade.get('min').value\"\n [max]=\"propriedade.get('max').value\"\n [minLength]=\"propriedade.get('minLength').value\"\n [maxLength]=\"propriedade.get('maxLength').value\"\n [autocomplete]=\"getRandomString()\"\n\t\t currencyMask\n\t\t formControlName=\"value\"\n\t\t matInput\n\t\t type=\"tel\"/>\n\t <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n\t <mat-icon>info</mat-icon>\n\t\t {{propriedade.get('textHint').value}}\n\t </mat-hint>\n <mat-error *ngIf=\"propriedade.get('value').errors?.min\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMinMessage(propriedade.get('min').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.max\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMaxMessage(propriedade.get('max').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.minLength\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMinLengthMessage(propriedade.get('minLength').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.maxLength\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMaxLengthMessage(propriedade.get('maxLength').value)}}\n </mat-error>\n\t <mat-error *ngIf=\"propriedade.get('value').errors?.required\">\n\t <mat-icon>error</mat-icon>\n {{errorMessage.getRequiredMessage(propriedade.get('label').value)}}\n\t </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n <mat-icon>error</mat-icon>\n {{propriedade.get('value').errors?.customError.message}}.\n </mat-error>\n\t </mat-form-field>\n <mat-form-field\n *ngIf=\"propriedade.get('type').value == typeField.float\"\n [appearance]=\"propriedade.get('appearance').value\"\n [floatLabel]=\"propriedade.get('floatLabel').value\"\n [formGroupName]=\"i\"\n [ngClass]=\"propriedade.get('fieldClass').value\">\n <mat-label>{{propriedade.get('label').value}}</mat-label>\n <input\n [koalaAutoFocus]=\"propriedade.get('focus').value\"\n [required]=\"propriedade.get('required').value\"\n [tabIndex]=\"tabIndexStart + i\"\n [min]=\"propriedade.get('min').value\"\n [max]=\"propriedade.get('max').value\"\n [minLength]=\"propriedade.get('minLength').value\"\n [maxLength]=\"propriedade.get('maxLength').value\"\n [autocomplete]=\"getRandomString()\"\n currencyMask\n [options]=\"{prefix: ''}\"\n formControlName=\"value\"\n matInput\n type=\"tel\"/>\n <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n <mat-icon>info</mat-icon>\n {{propriedade.get('textHint').value}}\n </mat-hint>\n <mat-error *ngIf=\"propriedade.get('value').errors?.min\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMinMessage(propriedade.get('min').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.max\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMaxMessage(propriedade.get('max').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.minLength\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMinLengthMessage(propriedade.get('minLength').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.maxLength\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMaxLengthMessage(propriedade.get('maxLength').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.required\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getRequiredMessage(propriedade.get('label').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n <mat-icon>error</mat-icon>\n {{propriedade.get('value').errors?.customError.message}}.\n </mat-error>\n </mat-form-field>\n\t <mat-form-field\n\t\t *ngIf=\"propriedade.get('type').value == typeField.valueList ||\n\t propriedade.get('type').value == typeField.textarea\"\n\t\t [appearance]=\"propriedade.get('appearance').value\"\n\t\t [floatLabel]=\"propriedade.get('floatLabel').value\"\n\t\t [formGroupName]=\"i\"\n\t\t [ngClass]=\"propriedade.get('fieldClass').value\">\n\t <mat-label>{{propriedade.get('label').value}}</mat-label>\n\t <textarea\n #textarea\n\t\t [koalaAutoFocus]=\"propriedade.get('focus').value\"\n cdkTextareaAutosize\n #autosize=\"cdkTextareaAutosize\"\n\t\t [cdkAutosizeMaxRows]=\"8\"\n\t\t [cdkAutosizeMinRows]=\"3\"\n\t\t [required]=\"propriedade.get('required').value\"\n [tabIndex]=\"tabIndexStart + i\"\n [minLength]=\"propriedade.get('minLength').value\"\n [maxLength]=\"propriedade.get('maxLength').value\"\n\t\t formControlName=\"value\"\n\t\t matInput>\n </textarea>\n\t <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n\t <mat-icon>info</mat-icon>\n\t\t {{propriedade.get('textHint').value}}\n\t </mat-hint>\n <mat-hint align=\"end\" *ngIf=\"propriedade.get('maxLength').value\">\n {{textarea.value.length}}/{{propriedade.get('maxLength').value}}\n </mat-hint>\n <mat-error *ngIf=\"propriedade.get('value').errors?.minLength\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMinLengthMessage(propriedade.get('minLength').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.maxLength\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMaxLengthMessage(propriedade.get('maxLength').value)}}\n </mat-error>\n\t <mat-error *ngIf=\"propriedade.get('value').errors?.required\">\n\t <mat-icon>error</mat-icon>\n {{errorMessage.getRequiredMessage(propriedade.get('label').value)}}\n\t </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n <mat-icon>error</mat-icon>\n {{propriedade.get('value').errors?.customError.message}}.\n </mat-error>\n\t </mat-form-field>\n\t\t <mat-form-field\n\t\t\t *ngIf=\"propriedade.get('type').value == typeField.textLogs\"\n\t\t\t [appearance]=\"propriedade.get('appearance').value\"\n\t\t\t [floatLabel]=\"propriedade.get('floatLabel').value\"\n\t\t\t [formGroupName]=\"i\"\n\t\t\t [ngClass]=\"propriedade.get('fieldClass').value\">\n\t <mat-label>{{propriedade.get('label').value}}</mat-label>\n\t <div [innerHTML]=\"propriedade.get('textLogs').value\" class=\"text-obs\"></div>\n\t <textarea\n #textarea\n\t\t [koalaAutoFocus]=\"propriedade.get('focus').value\"\n cdkTextareaAutosize\n #autosize=\"cdkTextareaAutosize\"\n\t\t [cdkAutosizeMaxRows]=\"8\"\n\t\t [cdkAutosizeMinRows]=\"3\"\n\t\t [required]=\"propriedade.get('required').value\"\n [tabIndex]=\"tabIndexStart + i\"\n [minLength]=\"propriedade.get('minLength').value\"\n [maxLength]=\"propriedade.get('maxLength').value\"\n\t\t formControlName=\"value\"\n\t\t matInput>\n\t </textarea>\n\t <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n\t <mat-icon>info</mat-icon>\n\t\t {{propriedade.get('textHint').value}}\n\t </mat-hint>\n <mat-hint align=\"end\" *ngIf=\"propriedade.get('maxLength').value\">\n {{textarea.value.length}}/{{propriedade.get('maxLength').value}}\n </mat-hint>\n <mat-error *ngIf=\"propriedade.get('value').errors?.minLength\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMinLengthMessage(propriedade.get('minLength').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.maxLength\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMaxLengthMessage(propriedade.get('maxLength').value)}}\n </mat-error>\n\t <mat-error *ngIf=\"propriedade.get('value').errors?.required\">\n\t <mat-icon>error</mat-icon>\n {{errorMessage.getRequiredMessage(propriedade.get('label').value)}}\n\t </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n <mat-icon>error</mat-icon>\n {{propriedade.get('value').errors?.customError.message}}.\n </mat-error>\n\t </mat-form-field>\n\t <mat-form-field\n\t\t *ngIf=\"propriedade.get('type').value == typeField.select\"\n\t\t [appearance]=\"propriedade.get('appearance').value\"\n\t\t [floatLabel]=\"propriedade.get('floatLabel').value\"\n\t\t [formGroupName]=\"i\"\n\t\t [ngClass]=\"propriedade.get('fieldClass').value\">\n\t <mat-label>{{propriedade.get('label').value}}</mat-label>\n\t <mat-select [multiple]=\"propriedade.get('multiple').value\" [required]=\"propriedade.get('required').value\"\n [tabIndex]=\"tabIndexStart + i\" formControlName=\"value\">\n\t <mat-option *ngFor=\"let options of propriedade.get('opcoesSelect').value\" [value]=\"options.value\">\n\t {{options.name}}\n\t </mat-option>\n\t </mat-select>\n\t <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n\t <mat-icon>info</mat-icon>\n\t\t {{propriedade.get('textHint').value}}\n\t </mat-hint>\n\t <mat-error *ngIf=\"propriedade.get('value').errors?.required\">\n\t <mat-icon>error</mat-icon>\n {{errorMessage.getRequiredMessage(propriedade.get('label').value)}}\n\t </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n <mat-icon>error</mat-icon>\n {{propriedade.get('value').errors?.customError.message}}.\n </mat-error>\n\t </mat-form-field>\n <mat-form-field\n class=\"select-multiple-native\"\n *ngIf=\"propriedade.get('type').value == typeField.selectMultipleNative\"\n [appearance]=\"propriedade.get('appearance').value\"\n [floatLabel]=\"propriedade.get('floatLabel').value\"\n [formGroupName]=\"i\"\n [ngClass]=\"propriedade.get('fieldClass').value\">\n <mat-label>{{propriedade.get('label').value}}</mat-label>\n <select\n matNativeControl\n formControlName=\"value\"\n multiple\n [tabIndex]=\"tabIndexStart + i\"\n [required]=\"propriedade.get('required').value\">\n <option *ngFor=\"let options of propriedade.get('opcoesSelect').value\" [value]=\"options.value\">\n {{options.name}}\n </option>\n </select>\n <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n <mat-icon>info</mat-icon>\n {{propriedade.get('textHint').value}}\n </mat-hint>\n <mat-error *ngIf=\"propriedade.get('value').errors?.required\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getRequiredMessage(propriedade.get('label').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n <mat-icon>error</mat-icon>\n {{propriedade.get('value').errors?.customError.message}}.\n </mat-error>\n </mat-form-field>\n\t <div\n\t\t *ngIf=\"propriedade.get('type').value == typeField.checkbox\"\n\t\t [formGroupName]=\"i\"\n\t\t [ngClass]=\"propriedade.get('fieldClass').value\">\n\t <mat-checkbox\n [tabIndex]=\"tabIndexStart + i\"\n\t\t formControlName=\"value\"\n\t\t value=\"true\">\n\t {{propriedade.get('label').value}}\n\t </mat-checkbox>\n\t </div>\n\t\t <div\n\t\t\t *ngIf=\"propriedade.get('type').value == typeField.moreItems\"\n\t\t\t [formGroupName]=\"i\"\n\t\t\t [ngClass]=\"propriedade.get('fieldClass').value\"\n\t\t\t class=\"more-items-content\">\n\t\t\t <fieldset>\n\t\t\t\t <legend>\n\t\t\t\t\t <koala-button\n\t\t\t\t\t\t (click)=\"addMoreItem(i)\"\n\t\t\t\t\t\t [disabled]=\"propriedade.get('moreItemsConfig').value.length === propriedade.get('moreItemsMaxItems').value\"\n\t\t\t\t\t\t [tooltip]=\"propriedade.get('moreItemsButtonIconAddlabel').value\"\n\t\t\t\t\t\t [backgroundColor]=\"propriedade.get('moreItemsIconBackgroundColor').value\"\n [color]=\"propriedade.get('moreItemsIconFontColor').value\"\n\t\t\t\t\t\t class=\"btn-add-more-items\"\n\t\t\t\t\t\t icon=\"add\">\n\t\t\t\t\t </koala-button>\n\t\t\t\t\t {{propriedade.get('label').value}} (Min.: {{propriedade.get('moreItemsMinItems').value}}\n\t\t\t\t\t | M\u00E1x.: {{propriedade.get('moreItemsMaxItems').value}})\n\t\t\t\t </legend>\n\t\t\t\t <mat-accordion class=\"items\" multi>\n\t\t\t\t\t <mat-expansion-panel\n\t\t\t\t\t\t *ngFor=\"let item of propriedade.get('moreItemsConfig').value.slice().reverse(); index as indexMoreItems\"\n\t\t\t\t\t\t expanded>\n\t\t\t\t\t\t <mat-expansion-panel-header>\n\t\t\t\t\t\t\t\t<mat-panel-title class=\"titleForm\">#\n\t\t\t\t\t\t\t\t\t{{propriedade.get('moreItemsConfig').value.length - 1 - indexMoreItems + 1}}</mat-panel-title>\n\t\t\t\t\t\t\t\t<mat-panel-description class=\"titleForm\">\n\t\t\t\t\t\t\t\t\t{{propriedade.get('label').value}}\n\t\t\t\t\t\t\t\t\t<mat-icon>{{propriedade.get('moreItemsIcon').value}}</mat-icon>\n\t\t\t\t\t\t\t\t</mat-panel-description>\n\t\t\t\t\t\t\t</mat-expansion-panel-header>\n\t\t\t\t\t\t <koala-dynamic-form\n\t\t\t\t\t\t\t [showFieldsMoreItensConfig]=\"item.showFieldsMoreItensConfig\"\n\t\t\t\t\t\t\t [showFields]=\"item.showFields\"\n\t\t\t\t\t\t\t [formConfig]=\"item.formConfig\"\n\t\t\t\t\t\t\t [form]=\"item.form\"\n [tabIndexStart]=\"tabIndexStart + i\">\n\t\t\t\t\t\t </koala-dynamic-form>\n\t\t\t\t\t <mat-action-row\n\t\t\t\t\t\t *ngIf=\"propriedade.get('moreItemsConfig').value.length > propriedade.get('moreItemsMinItems').value\">\n\t\t\t\t\t <button\n\t\t\t\t\t\t (click)=\"removeMoreItem(i, propriedade.get('moreItemsConfig').value.length - 1 - indexMoreItems)\"\n\t\t\t\t\t\t mat-icon-button>\n\t\t\t\t\t\t <mat-icon>delete</mat-icon>\n\t\t\t\t\t </button>\n\t\t\t\t\t </mat-action-row>\n\t\t\t\t\t </mat-expansion-panel>\n\t\t\t\t </mat-accordion>\n\t\t\t </fieldset>\n\t\t </div>\n\t\t <mat-form-field\n\t\t\t *ngIf=\"propriedade.get('type').value == typeField.autocomplete\"\n\t\t\t [appearance]=\"propriedade.get('appearance').value\"\n\t\t\t [floatLabel]=\"propriedade.get('floatLabel').value\"\n\t\t\t [formGroupName]=\"i\"\n\t\t\t [ngClass]=\"propriedade.get('fieldClass').value\">\n\t <mat-label>{{propriedade.get('label').value}} {{propriedade.get('multiple').value &&\n\t propriedade.get('required').value ? '*' : ''}}</mat-label>\n\t\t\t <div *ngIf=\"propriedade.get('multiple').value else single\">\n\t <mat-chip-list #chipList>\n <mat-chip\n (removed)=\"removeOptionOnAutocomplete(i, option)\"\n *ngFor=\"let option of propriedade.get('autocompleteSelectedValue').value\"\n [color]=\"getColorChip(propriedade.get('autocompleteMultipleConfig').value | async)\"\n [removable]=\"true\"\n [selectable]=\"true\">\n {{display(option)}}\n <mat-icon *ngIf=\"!propriedade.get('disabled').value\" matChipRemove>cancel</mat-icon>\n </mat-chip>\n\t <input\n [id]=\"'autocomplete-' + propriedade.get('name').value\"\n [koalaAutoFocus]=\"propriedade.get('focus').value\"\n\t\t [required]=\"propriedade.get('required').value\"\n\t\t [matAutocomplete]=\"auto\"\n\t\t [matChipInputFor]=\"chipList\"\n [tabIndex]=\"tabIndexStart + i\"\n [autocomplete]=\"getRandomString()\"\n\t\t formControlName=\"value\"\n\t\t matInput\n\t\t type=\"text\"\n\t\t placeholder=\"Selecione um ou mais op\u00E7\u00F5es...\">\n\t </mat-chip-list>\n\t </div>\n\t <ng-template #single>\n\t\t <input\n\t\t\t [matAutocomplete]=\"auto\"\n [koalaAutoFocus]=\"propriedade.get('focus').value\"\n\t\t\t [required]=\"propriedade.get('required').value\"\n [tabIndex]=\"tabIndexStart + i\"\n [autocomplete]=\"getRandomString()\"\n\t\t\t formControlName=\"value\"\n\t\t\t matInput\n\t\t\t placeholder=\"Selecione uma op\u00E7\u00E3o...\"\n\t\t\t type=\"text\">\n\t </ng-template>\n\t <mat-spinner *ngIf=\"propriedade.get('autocompleteLoading').value | async\" color=\"primary\"\n\t matSuffix></mat-spinner>\n\t <button\n\t\t (click)=\"clearAutocomplete(i)\"\n\t\t *ngIf=\"\n\t !(propriedade.get('autocompleteLoading').value | async) &&\n\t !propriedade.get('disabled').value\"\n\t\t color=\"warn\"\n\t\t mat-icon-button\n\t\t matSuffix\n\t\t type=\"button\">\n\t <mat-icon>close</mat-icon>\n\t </button>\n\t <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n\t <mat-icon>info</mat-icon>\n\t\t {{propriedade.get('textHint').value}}\n\t </mat-hint>\n\t <mat-error *ngIf=\"propriedade.get('value').errors?.required || propriedade.get('value').errors?.autocompleteSelected\">\n\t <mat-icon>error</mat-icon>\n {{errorMessage.getAutocompleteMessage(propriedade.get('label').value)}}\n\t </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n <mat-icon>error</mat-icon>\n {{propriedade.get('value').errors?.customError.message}}.\n </mat-error>\n\t <mat-autocomplete\n\t\t #auto=\"matAutocomplete\"\n\t\t [displayWith]=\"display\" autoActiveFirstOption>\n <mat-option\n *ngIf=\"propriedade.get('autocompleteAddOption').value && isValidNewAutocompleteOption(propriedade.get('value').value)\"\n [value]=\"{\n value: {id: 0, name: propriedade.get('value').value},\n name: propriedade.get('value').value\n }\">\n Add <b>{{propriedade.get('value').value}}</b>...\n </mat-option>\n\t\t <div *ngIf=\"(getAutocompleteOptions(propriedade) | async) as options\">\n\t\t <mat-option *ngFor=\"let option of options\" [value]=\"option\">\n\t\t {{option.name}}\n\t\t </mat-option>\n\t\t </div>\n\t </mat-autocomplete>\n\t </mat-form-field>\n\t\t <div *ngIf=\"propriedade.get('type').value == typeField.file\">\n\t\t\t <koala-file-button\n\t\t\t\t (getFiles)=\"propriedade.get('value').setValue($event)\"\n\t\t\t\t [accept]=\"propriedade.get('fileButtonConfig').value.accept\"\n\t\t\t\t [backgroundColor]=\"propriedade.get('fileButtonConfig').value.backgroundColor\"\n\t\t\t\t [color]=\"propriedade.get('fileButtonConfig').value.color\"\n\t\t\t\t [disabled]=\"propriedade.get('disabled').value\"\n\t\t\t\t [icon]=\"propriedade.get('fileButtonConfig').value.icon\"\n\t\t\t\t [multiple]=\"propriedade.get('multiple').value\"\n\t\t\t\t [text]=\"propriedade.get('fileButtonConfig').value.text\">\n\t\t\t </koala-file-button>\n\t\t </div>\n\t\t <div *ngIf=\"\n\t\t propriedade.get('type').value == typeField.dynamicForm &&\n\t\t\t\t(getDynamicFormConfig(propriedade) | async) as dynamicFormConfig\">\n\t\t\t <fieldset *ngIf=\"propriedade.get('label').value else dynamicFormWithoutLabel\">\n\t\t\t\t <legend>{{propriedade.get('label').value}}</legend>\n\t\t\t\t <koala-dynamic-form\n\t\t\t\t\t [formConfig]=\"dynamicFormConfig.formConfig\"\n\t\t\t\t\t [form]=\"dynamicFormConfig.form\"\n\t\t\t\t\t [setValues]=\"dynamicFormConfig.setValues\"\n\t\t\t\t\t [showFields]=\"dynamicFormConfig.showFields\"\n [tabIndexStart]=\"tabIndexStart + i\">\n\t\t\t\t </koala-dynamic-form>\n\t\t\t </fieldset>\n\t\t\t <ng-template #dynamicFormWithoutLabel>\n\t\t\t\t <koala-dynamic-form\n\t\t\t\t\t [formConfig]=\"dynamicFormConfig.formConfig\"\n\t\t\t\t\t [form]=\"dynamicFormConfig.form\"\n\t\t\t\t\t [setValues]=\"dynamicFormConfig.setValues\"\n\t\t\t\t\t [showFields]=\"dynamicFormConfig.showFields\"\n [tabIndexStart]=\"tabIndexStart + i\">\n\t\t\t\t </koala-dynamic-form>\n\t\t\t </ng-template>\n\t\t </div>\n <div\n class=\"radio-btn-group\"\n *ngIf=\"propriedade.get('type').value == typeField.radio\"\n [formGroupName]=\"i\"\n [ngClass]=\"propriedade.get('fieldClass').value\">\n <mat-radio-group formControlName=\"value\">\n <label *ngIf=\"propriedade.get('label').value\">{{propriedade.get('label').value}}</label>\n <mat-radio-button\n [tabIndex]=\"tabIndexStart + i\"\n *ngFor=\"let options of propriedade.get('opcoesSelect').value\"\n [value]=\"options.value\">\n {{options.name}}\n </mat-radio-button>\n </mat-radio-group>\n </div>\n\t </div>\n </div>\n <ng-content select=\"[btn-submit]\"></ng-content>\n</div>\n", styles: [".more-items-content fieldset{border:1px solid #cccccc;padding:16px}.more-items-content fieldset legend{font-family:Josefin Sans,sans-serif;font-size:11px;font-weight:700;padding:0 8px}.more-items-content .items .titleForm{color:#616161}.more-items-content .items .mat-expansion-panel-header-title,.more-items-content .items .mat-expansion-panel-header-description{flex-basis:0}.more-items-content .items .mat-expansion-panel-header-description{align-items:center;justify-content:space-between}.more-items-content .items .mat-form-field+.mat-form-field{margin-left:8px}.radio-btn-group label{position:relative;display:block;padding:10px 0}.text-obs{background:#eeeeee;border-radius:5px;color:#212121;font-family:OpenSansLight,sans-serif;height:150px;margin:0 auto 10px;overflow-y:auto;padding:10px;position:relative;width:calc(100% - 27px)}.select-multiple-native{margin-bottom:15px}.select-multiple-native select{width:100%;height:150px;background:transparent;border:none}.select-multiple-native select:focus,.select-multiple-native select:active{outline:none}.select-multiple-native select option{padding:5px 10px;font-family:JosefinSans,sans-serif}.select-multiple-native select option:checked{background:#f1f1f1!important}\n"] }]
|
|
585
|
-
}], ctorParameters: function () { return [{ type: i1.UntypedFormBuilder }, { type: i2.KoalaDynamicFormService }]; }, propDecorators: { form: [{
|
|
586
|
-
type: Input
|
|
587
|
-
}], formConfig: [{
|
|
588
|
-
type: Input
|
|
589
|
-
}], showFields: [{
|
|
590
|
-
type: Input
|
|
591
|
-
}], showFieldsMoreItensConfig: [{
|
|
592
|
-
type: Input
|
|
593
|
-
}], setValues: [{
|
|
594
|
-
type: Input
|
|
595
|
-
}], tabIndexStart: [{
|
|
596
|
-
type: Input
|
|
597
|
-
}] } });
|
|
598
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-form.component.js","sourceRoot":"","sources":["../../../../../projects/form/src/lib/dynamic-form/dynamic-form.component.ts","../../../../../projects/form/src/lib/dynamic-form/dynamic-form.component.html"],"names":[],"mappings":"AAAA,OAAO,EAA0D,UAAU,EAAmB,MAAM,gBAAgB,CAAC;AAErH,OAAO,EAAE,wBAAwB,EAAE,MAAM,sCAAsC,CAAC;AAChF,OAAO,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;AAC1D,OAAO,EAAE,aAAa,EAAE,MAAM,6BAA6B,CAAC;AAC5D,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAc,KAAK,EAAqB,MAAM,eAAe,CAAC;AACzG,OAAO,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAC;AAChD,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAC9C,OAAO,EAAE,eAAe,EAAE,MAAM,MAAM,CAAC;AAEvC,OAAO,EAAE,6BAA6B,EAAE,MAAM,8CAA8C,CAAC;AAQ7F,OAAO,EAAE,KAAK,EAAE,MAAM,gCAAgC,CAAC;AACvD,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AACvC,OAAO,EAAE,gBAAgB,EAAE,MAAM,iCAAiC,CAAC;AACnE,OAAO,EAAE,gBAAgB,EAAE,MAAM,iCAAiC,CAAC;AACnE,OAAO,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAC;AACvD,OAAO,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAC;;;;;;;;;;;;;;;;;;;;;;;AAQ/D,MAAM,OAAO,oBAAqB,SAAQ,YAAY;IAmBpD,YACU,EAAsB,EACtB,kBAA2C;QAEnD,KAAK,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAHf,OAAE,GAAF,EAAE,CAAoB;QACtB,uBAAkB,GAAlB,kBAAkB,CAAyB;QAf5C,kBAAa,GAAW,CAAC,CAAC;QAG5B,cAAS,GAAG,wBAAwB,CAAC;QACrC,wBAAmB,GAAG,QAAQ,CAAC;QAC/B,iBAAY,GAAG,mBAAmB,CAAC;QACnC,WAAM,GAAG,YAAY,CAAC,EAAE,EAAE;YAC/B,SAAS,EAAE,IAAI;YACf,SAAS,EAAE,IAAI;YACf,OAAO,EAAE,KAAK;YACd,iBAAiB,EAAE,KAAK;SACzB,CAAC,CAAC;IAOH,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,EAAE;YAC9B,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,UAAU,EAAE,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC;SACrD;QACD,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,UAAU,CAAqB,CAAC;QAC9D,IAAI,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC,MAAM,EAAE,WAAW,EAAE,EAAE;YAC/C,MAAM,YAAY,GAAG,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;YAC7C,IAAI,MAAM,CAAC,eAAe,EAAE;gBAC1B,YAAY,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,kBAAkB,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC;aACtE;YACD,YAAY,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,sBAAsB,EAAE,CAAC;YACnD,IAAI,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,WAAW,EAAE;gBACxD,MAAM,4BAA4B,GAAG,YAAY,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC,KAAyD,CAAC;gBACrI,4BAA4B,CAAC,SAAS,CAAC,eAAe,CAAC,EAAE;oBACvD,IAAI,eAAe,EAAE;wBACnB,eAAe,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,GAAG,EAAE;4BAC/C,IAAI,eAAe,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC,MAAM,CAAC,YAAY,IAAI,IAAI,CAAC,yBAAyB,CAAC,EAAE;gCACzF,MAAM,KAAK,GAAG,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;gCACrE,YAAY,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;6BAC3C;wBACH,CAAC,CAAC,CAAC;qBACJ;gBACH,CAAC,CAAC,CAAC;aACJ;YACD,IACE,MAAM,CAAC,YAAY;gBACnB,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,YAAY;gBACrD,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,WAAW;gBACpD,IAAI,CAAC,yBAAyB,EAC9B;gBACA,IAAI,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,YAAY,EAAE;oBACzD,MAAM,0BAA0B,GAAG,YAAY,CAAC,GAAG,CAAC,qBAAqB,CAAC,CAAC,KAAoE,CAAC;oBAChJ,IAAI,0BAA0B,EAAE;wBAC9B,0BAA0B,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE,CAAC,YAAY,CAAC,GAAG,CAAC,6BAA6B,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC;qBACtH;iBACF;gBACD,YAAY,CAAC,GAAG,CAAC,OAAO,CAAC;qBACZ,YAAY;qBACZ,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC;qBACvB,SAAS,CAAC,KAAK,EAAC,KAAK,EAAC,EAAE;oBACvB,MAAM,IAAI,CAAC,oBAAoB,CAAC,YAAY,CAAC,CAAC;oBAC9C,IAAI,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,YAAY,EAAE;wBACzD,IACE,KAAK,IAAI,CACP,KAAK,CAAC,cAAc,CAAC,OAAO,CAAC;4BAC7B,KAAK,CAAC,cAAc,CAAC,MAAM,CAAC;4BAC5B,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,MAAM,KAAK,CAAC,CAChC,IAAI,CACH,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC;4BACpB,YAAY,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,KAAK,CACnC,EAAE;4BACH,IAAI,YAAY,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,KAAK,EAAE;gCACtC,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;oCACxB,YAAY,CAAC,GAAG,CAAC,2BAA2B,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;oCAC9D,YAAY,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,EAAE,EAAC,SAAS,EAAE,KAAK,EAAC,CAAC,CAAC;iCACjF;qCAAM;oCACL,IAAI,IAAI,CAAC,0BAA0B,CAAC,YAAY,CAAC,GAAG,CAAC,2BAA2B,CAAC,CAAC,KAAK,EAAE,KAAK,CAAC,EAAE;wCAC/F,YAAY,CAAC,GAAG,CAAC,2BAA2B,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;qCACjE;iCACF;gCAED,MAAM,iBAAiB,GAAG,QAAQ,CAAC,aAAa,CAAmB,IAAI,IAAI,CAAC,MAAM,uBAAuB,YAAY,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC;gCAC5I,IAAI,iBAAiB,EAAE;oCACrB,iBAAiB,CAAC,KAAK,GAAG,EAAE,CAAC;iCAC9B;6BACF;iCAAM;gCACL,YAAY,CAAC,GAAG,CAAC,2BAA2B,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;6BAC/D;yBACF;6BAAM,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,KAAK,EAAE;4BAC9C,YAAY,CAAC,GAAG,CAAC,2BAA2B,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC;iCAC1E,KAAK,EAAkC;iCACvC,MAAM,CAAC,YAAY,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,MAAM,CAAC;iCAC9C,QAAQ,EAAE,CAAC,CAAC,CAAC,EAAE,+BAA+B,IAAI,IAAI,CAAC,CAAC;yBAC5D;wBAED,IAAI,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,YAAY,EAAE;4BACzD,IAAI,MAAM,CAAC,gBAAgB,KAAK,KAAK,EAAE;gCACrC,MAAM,0BAA0B,GAAG,YAAY,CAAC,GAAG,CAAC,qBAAqB,CAAC,CAAC,KAAoE,CAAC;gCAChJ,YAAY,CAAC,GAAG,CAAC,6BAA6B,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,kBAAkB,CAChF,0BAA0B,CAAC,KAAK,EAChC,KAAK,CACN,CAAC,CAAC;6BACJ;iCAAM,IAAI,MAAM,CAAC,gBAAgB,KAAK,UAAU,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;gCAC9E,MAAM,MAAM,GAAG,YAAY,CAAC,GAAG,CAAC,qBAAqB,CAAC,CAAC,KAAiC,CAAC;gCACzF,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gCAClB,MAAM,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE;oCACnD,YAAY,CAAC,GAAG,CAAC,6BAA6B,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;oCACpE,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gCACrB,CAAC,CAAC,CAAC;6BACJ;yBACF;qBACF;oBACD,IAAI,MAAM,CAAC,YAAY,EAAE;wBACvB,IAAI,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,YAAY,EAAE;4BACzD,MAAM,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,KAAK,CAAC,CAAC;gCACpC,YAAY,CAAC,GAAG,CAAC,2BAA2B,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;gCAC7E,YAAY,CAAC,GAAG,CAAC,2BAA2B,CAAC,CAAC,KAAK,EAAE,KAAK,CAC9E,CAAC,CAAC;yBACJ;6BAAM;4BACL,MAAM,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;yBAC5B;qBACF;gBACH,CAAC,CAAC,CAAC;aAChB;YACD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YACjC,IAAI,MAAM,CAAC,eAAe,EAAE;gBAC1B,IAAI,MAAM,CAAC,iBAAiB,GAAG,CAAC,EAAE;oBAChC,KAAK,IAAI,GAAG,GAAG,CAAC,EAAE,GAAG,GAAG,MAAM,CAAC,iBAAiB,EAAE,GAAG,EAAE,EAAE;wBACvD,IAAI,GAAG,IAAI,MAAM,CAAC,iBAAiB,EAAE;4BACnC,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC;yBAC/B;qBACF;iBACF;gBACD,IAAI,MAAM,CAAC,eAAe,CAAC,SAAS,EAAE;oBACpC,MAAM,CAAC,eAAe;yBACf,SAAS;yBACT,SAAS,CAAC,KAAK,EAAC,MAAM,EAAC,EAAE;wBACxB,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE;4BACrB,MAAM,CAAC,OAAO,CAAC,CAAC,SAAS,EAAE,UAAU,EAAE,EAAE;gCACvC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC,KAAK,CAAC,UAAU,CAAC,EAAE;oCACjF,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC;iCAC/B;gCACD,UAAU,CAAC,GAAG,EAAE;oCACd,IAAI,CAAC,iBAAiB,CACpB,SAAS,EACT,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,IAAI,CAClF,CAAC;gCACJ,CAAC,EAAE,GAAG,CAAC,CAAC;4BACV,CAAC,CAAC,CAAC;yBACJ;oBACH,CAAC,CAAC,CAAC;iBACV;aACF;QACH,CAAC,CAAC,CAAC;QACH,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;SACzD;QACD,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;SACnD;IACH,CAAC;IAEM,4BAA4B,CAAC,KAAU;QAC5C,OAAO,CAAC,CAAC,KAAK,IAAI,OAAO,KAAK,KAAK,QAAQ,CAAC;IAC9C,CAAC;IAEM,wBAAwB,CAAC,KAAa,EAAE,KAAoB;QACjE,MAAM,OAAO,GAAG,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,KAAK,CAAC,CAAC;QAC/C,MAAM,IAAI,GAAG,OAAO,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC,KAAiC,CAAC;QACpE,IAAI,IAAI,KAAK,wBAAwB,CAAC,eAAe,EAAE;YACrD,MAAM,KAAK,GAAG,OAAO,EAAE,GAAG,CAAC,OAAO,CAAC,CAAC,KAAK,CAAC;YAC1C,IAAI,KAAK,CAAC,GAAG,IAAI,WAAW,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE;gBAChD,IAAI,CAAC,mBAAmB,GAAG,QAAQ,CAAC;aACrC;iBAAM,IAAI,KAAK,CAAC,GAAG,IAAI,WAAW,IAAI,KAAK,CAAC,MAAM,IAAI,CAAC,EAAE;gBACxD,IAAI,CAAC,mBAAmB,GAAG,QAAQ,CAAC;aACrC;SACF;IACH,CAAC;IAEM,YAAY,CAAC,KAAa;QAC/B,MAAM,OAAO,GAAG,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,KAAK,CAAC,CAAC;QAC/C,MAAM,YAAY,GAAG,CAAC,OAAO,EAAE,GAAG,CAAC,cAAc,CAAC,CAAC,KAAK,CAAC;QACzD,OAAO,EAAE,GAAG,CAAC,cAAc,CAAC,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC;QACpD,OAAO,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC;YACd,wBAAwB,CAAC,QAAQ,CAAC,CAAC;YACnC,wBAAwB,CAAC,IAAI,CAC1D,CAAC;IACJ,CAAC;IAEM,WAAW,CAAC,SAAiB;QAClC,IAAI,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC,KAAK,EAAE;YAC5I,MAAM,SAAS,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;YACpC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC;gBAClE,IAAI,EAAE,SAAS;gBACf,UAAU,EAAE,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,eAAe,CAAC,UAAU;gBACjE,UAAU,EAAE,IAAI,eAAe,CAAqD,EAAE,CAAC;gBACvF,yBAAyB,EAAE,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,eAAe,CAAC,gBAAgB;aACvF,CAAC,CAAC;YACH,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC,QAAQ,CACjE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAC1E,CAAC;YACF,MAAM,kBAAkB,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,oBAAoB,CAAqB,CAAC;YAC3G,kBAAkB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;SACpC;IACH,CAAC;IAEM,cAAc,CAAC,SAAiB,EAAE,WAAW;QAClD,MAAM,iBAAiB,GAAG,WAAW,GAAG,CAAC,CAAC;QAC1C,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC;QACtF,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC,QAAQ,CAAC,CAAC,iBAAiB,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC;QACvH,CAAC,EAAE,EAAE,CAAC,CAAC;IACT,CAAC;IAEM,iBAAiB,CAAC,SAAiB;QACxC,IAAI,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,KAAK,EAAE;YAC3D,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,2BAA2B,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;YAChF,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;SAC/D;aAAM;YACL,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,2BAA2B,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,+BAA+B,IAAI,IAAI,CAAC,CAAC;YAChJ,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,+BAA+B,IAAI,IAAI,CAAC,CAAC;SAC7H;IACH,CAAC;IAEM,OAAO,CAAC,MAAiD;QAC9D,OAAO,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC;IAC1C,CAAC;IAEM,0BAA0B,CAAC,SAAiB,EAAE,MAAgD;QACnG,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,2BAA2B,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,KAAK,MAAM,CAA+C,CAAC;QACrK,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,2BAA2B,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QACnF,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE;YACtB,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,2BAA2B,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;YAChF,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;SAC/D;aAAM,IAAI,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,YAAY,EAAE;YAClD,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,YAAY,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;SACxE;IACH,CAAC;IAEM,YAAY,CAAC,MAA2D;QAC7E,OAAO,MAAM,CAAC,KAAK,CAAC;IACtB,CAAC;IAEM,sBAAsB,CAAC,WAA4B;QACxD,OAAO,WAAW,CAAC,GAAG,CAAC,6BAA6B,CAAC,CAAC,KAA+B,CAAC;IACxF,CAAC;IAEM,oBAAoB,CAAC,WAA4B;QACtD,OAAO,WAAW,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC,KAAyD,CAAC;IACxG,CAAC;IAEM,eAAe;QACpB,OAAO,YAAY,CAAC,EAAE,EAAE;YACtB,SAAS,EAAE,IAAI;YACf,OAAO,EAAE,IAAI;YACb,iBAAiB,EAAE,KAAK;YACxB,SAAS,EAAE,IAAI;SAChB,CAAC,CAAC;IACL,CAAC;IAEO,UAAU,CAAC,MAAsC;QACvD,IAAI,UAAU,GAAG,MAAM,CAAC,cAAc,IAAI,EAAE,CAAC;QAC7C,IAAI,KAAK,GAAQ,MAAM,CAAC,KAAK,IAAI,EAAE,CAAC;QACpC,IAAI,yBAAyB,GAA0F,CACrH,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,+BAA+B,IAAI,IAAI,CAAC,CACxE,CAAC;QAEF,IAAI,MAAM,CAAC,QAAQ,KAAK,IAAI;YAAE,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;QACnE,IAAI,MAAM,CAAC,GAAG,IAAI,OAAO,MAAM,CAAC,GAAG,KAAK,QAAQ;YAAE,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;QAC9F,IAAI,MAAM,CAAC,GAAG,IAAI,OAAO,MAAM,CAAC,GAAG,KAAK,QAAQ;YAAE,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;QAC9F,IACE,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,IAAI;YAC7C,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,QAAQ;YACjD,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,IAAI,EAC7C;YACA,IAAI,MAAM,CAAC,GAAG,IAAI,OAAO,MAAM,CAAC,GAAG,KAAK,QAAQ,EAAE;gBAAE,UAAU,CAAC,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;aAAE;YACpG,IAAI,MAAM,CAAC,GAAG,IAAI,OAAO,MAAM,CAAC,GAAG,KAAK,QAAQ,EAAE;gBAAE,UAAU,CAAC,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;aAAE;SACrG;QACD,IAAI,MAAM,CAAC,SAAS;YAAE,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC;QAC9E,IAAI,MAAM,CAAC,SAAS;YAAE,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC;QAE9E,IAAI,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,GAAG,EAAE;YAChD,UAAU,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;SAC/B;aAAM,IAAI,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,IAAI,EAAE;YACxD,UAAU,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;SAChC;aAAM,IAAI,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,KAAK,EAAE;YACzD,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;SACnC;aAAM,IAAI,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,YAAY,EAAE;YAChE,IAAI,KAAK,EAAE;gBACT,yBAAyB,GAAG,KAAK,CAAC;gBAClC,KAAK,GAAG,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,yBAAyB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;aAClE;YACD,IAAI,MAAM,CAAC,QAAQ,KAAK,IAAI,EAAE;gBAC5B,UAAU,CAAC,IAAI,CAAC,6BAA6B,CAAC,CAAC;aAChD;SACF;aAAM,IAAI,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,QAAQ,EAAE;YAC5D,KAAK,GAAG,MAAM,CAAC,KAAK,IAAI,KAAK,CAAC;SAC/B;QAED,IACE,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,eAAe;YACxD,KAAK,CAAC,MAAM,IAAI,CAAC,EACjB;YACA,IAAI,CAAC,mBAAmB,GAAG,QAAQ,CAAC;SACrC;QAED,IAAI,MAAM,CAAC,iBAAiB,EAAE;YAC5B,MAAM,sBAAsB,GAAG,EAAqC,CAAC;YACrE,MAAM,CAAC,MAAM,CAAC,sBAAsB,EAAE,MAAM,CAAC,iBAAiB,CAAC,CAAC;YAChE,sBAAsB,CAAC,IAAI,GAAG,MAAM,CAAC,iBAAiB,CAAC,IAAI,CAAC;YAC5D,MAAM,CAAC,iBAAiB,GAAG,sBAAsB,CAAC;SACnD;QAED,IAAI,MAAM,CAAC,IAAI,KAAK,KAAK,EAAE;YACzB,UAAU,GAAG,EAAE,CAAC;SACjB;QAED,MAAM,KAAK,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC;YAC1B,IAAI,EAAE,CAAC,IAAI,eAAe,CAAU,MAAM,CAAC,IAAI,IAAI,IAAI,CAAC,CAAC;YACzD,KAAK,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC;YACrB,IAAI,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC;YACnB,IAAI,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC;YACnB,gBAAgB,EAAE,CAAC;oBACjB,IAAI,EAAE,MAAM,EAAE,gBAAgB,EAAE,IAAI,IAAI,aAAa;oBACrD,IAAI,EAAE,MAAM,EAAE,gBAAgB,EAAE,IAAI,IAAI,6BAA6B;oBACrE,eAAe,EAAE,MAAM,EAAE,gBAAgB,EAAE,eAAe,IAAI,OAAO;oBACrE,KAAK,EAAE,MAAM,EAAE,gBAAgB,EAAE,KAAK,IAAI,MAAM;oBAChD,MAAM,EAAE,MAAM,EAAE,gBAAgB,EAAE,MAAM,IAAI,GAAG;iBAChD,CAAC;YACF,iBAAiB,EAAE,CAAC,IAAI,eAAe,CAAkC,MAAM,CAAC,iBAAiB,CAAC,CAAC;YACnG,gBAAgB,EAAE,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC;YACnC,UAAU,EAAE,CAAC,MAAM,CAAC,UAAU,CAAC;YAC/B,UAAU,EAAE,CAAC,MAAM,CAAC,UAAU,CAAC;YAC/B,WAAW,EAAE,CAAC,MAAM,CAAC,WAAW,CAAC;YACjC,KAAK,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC;YACrB,UAAU,EAAE,CAAC,MAAM,CAAC,UAAU,CAAC;YAC/B,QAAQ,EAAE,CAAC,MAAM,CAAC,QAAQ,CAAC;YAC3B,QAAQ,EAAE,CAAC,MAAM,CAAC,QAAQ,IAAI,KAAK,CAAC;YACpC,GAAG,EAAE,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC,CAAC;YACtB,GAAG,EAAE,CAAC,MAAM,CAAC,GAAG,IAAI,WAAW,CAAC;YAChC,SAAS,EAAE,CAAC,MAAM,CAAC,SAAS,IAAI,CAAC,CAAC;YAClC,SAAS,EAAE,CAAC,MAAM,CAAC,SAAS,IAAI,GAAG,CAAC;YACpC,QAAQ,EAAE,CAAC,MAAM,CAAC,QAAQ,IAAI,KAAK,CAAC;YACpC,KAAK,EAAE,CAAC,MAAM,CAAC,KAAK,IAAI,KAAK,CAAC;YAC9B,QAAQ,EAAE,CAAC,MAAM,CAAC,QAAQ,IAAI,KAAK,CAAC;YACpC,YAAY,EAAE,CAAC,MAAM,CAAC,YAAY,IAAI,EAAE,CAAC;YACzC,YAAY,EAAE,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI;YAC7E,2BAA2B,EAAE,CAAC,MAAM,CAAC,2BAA2B,CAAC;YACjE,iBAAiB,EAAE,CAAC,MAAM,CAAC,iBAAiB,IAAI,CAAC,CAAC;YAClD,iBAAiB,EAAE,CAAC,MAAM,CAAC,iBAAiB,IAAI,GAAG,CAAC;YACpD,aAAa,EAAE,CAAC,MAAM,CAAC,aAAa,CAAC;YACrC,sBAAsB,EAAE,CAAC,MAAM,CAAC,sBAAsB,CAAC;YACvD,4BAA4B,EAAE,CAAC,MAAM,CAAC,4BAA4B,CAAC;YACnE,iBAAiB,EAAE,CAAC,EAAE,CAAC;YACvB,eAAe,EAAE,CAAC,EAAE,CAAC;YACrB,kBAAkB,EAAE,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC;YACrC,mBAAmB,EAAE,CAAC,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;YAC1D,mBAAmB,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAAC;YACjD,0BAA0B,EAAE,CAAC,MAAM,CAAC,0BAA0B,CAAC;YAC/D,2BAA2B,EAAE,CAAC,IAAI,eAAe,CAAM,EAAE,CAAC,CAAC;YAC3D,yBAAyB,EAAE,CAAC,yBAAyB,CAAC;YACtD,qBAAqB,EAAE,CAAC,MAAM,CAAC,qBAAqB,CAAC;YACrD,QAAQ,EAAE,CAAC,MAAM,EAAE,OAAO,CAAC;YAC3B,UAAU,EAAE,CAAC,MAAM,EAAE,UAAU,CAAC;YAChC,2BAA2B,EAAE,CAAC,MAAM,EAAE,2BAA2B,IAAI,EAAE,CAAC;YACxE,gBAAgB,EAAE,CAAC,MAAM,EAAE,gBAAgB,IAAI,EAAE,CAAC;YAClD,gBAAgB,EAAE,CAAC,MAAM,EAAE,gBAAgB,IAAI,EAAE,CAAC;YAClD,KAAK,EAAE,CAAC,EAAC,KAAK,EAAE,QAAQ,EAAE,MAAM,CAAC,QAAQ,EAAC,EAAE,UAAU,EAAE,MAAM,CAAC,eAAe,CAAC;SAChF,CAAC,CAAC;QAEH,IAAI,MAAM,CAAC,gBAAgB,KAAK,UAAU,EAAE;YAC1C,MAAM,MAAM,GAAG,KAAK,CAAC,GAAG,CAAC,qBAAqB,CAAC,CAAC,KAAiC,CAAC;YAClF,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAClB,MAAM,CAAC,kBAAkB,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE;gBAChD,KAAK,CAAC,GAAG,CAAC,6BAA6B,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;gBAC7D,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACrB,CAAC,CAAC,CAAC;SACJ;QAED,OAAO,KAAK,CAAC;IACf,CAAC;IAEO,iBAAiB,CAAC,OAAyD,EAAE,IAAsB;QACzG,OAAO,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE;YACvB,IAAI,IAAI,EAAE;gBACR,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,UAAU,CAAqB,CAAC;gBAC3D,KAAK,MAAM,IAAI,IAAI,IAAI,CAAC,MAAM,EAAE,EAAE;oBAChC,IAAI,CAAC,cAAc,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;iBACtC;aACF;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,sBAAsB,CAAC,OAA8D,EAAE,IAAsB;QACnH,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE;YAC7C,IAAI,IAAI,EAAE;gBACR,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,UAAU,CAAqB,CAAC;gBAC3D,KAAK,MAAM,IAAI,IAAI,IAAI,CAAC,MAAM,EAAE,EAAE;oBAChC,KAAK,MAAM,CAAC,YAAY,EAAE,OAAO,CAAC,IAAI,SAAS,CAAC,QAAQ,CAAC,OAAO,EAAE,EAAE;wBAClE,IAAI,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,KAAK,KAAK,IAAI,CAAC,IAAI,EAAE;4BAC3C,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;4BAC1C,MAAM,MAAM,GAAmC,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC,IAAI,IAAI,CAAC;4BACrF,IAAI,IAAI,CAAC,IAAI,EAAE;gCACb,IAAI,UAAU,GAAG,EAAE,CAAC;gCACpB,IAAI,MAAM,EAAE;oCACV,IAAI,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,WAAW,EAAE;wCACxD,MAAM,kBAAkB,GAAG,OAAO,CAAC,GAAG,CAAC,kBAAkB,CAAqB,CAAC;wCAC/E,kBAAkB,CAAC,IAAI,CAAC,MAAM,EAAE,iBAAiB,EAAE,IAAI,CAAC,CAAC;qCAC1D;yCAAM;wCACL,UAAU,GAAG,MAAM,CAAC,cAAc,IAAI,EAAE,CAAC;wCACzC,IAAI,MAAM,CAAC,QAAQ,KAAK,IAAI,EAAE;4CAC5B,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;yCACtC;wCACD,IAAI,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,GAAG,EAAE;4CAChD,UAAU,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;yCAC/B;6CAAM,IAAI,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,IAAI,EAAE;4CACxD,UAAU,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;yCAChC;6CAAM,IAAI,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,KAAK,EAAE;4CACzD,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;yCACnC;6CAAM,IACL,MAAM,CAAC,QAAQ,KAAK,IAAI;4CACxB,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,YAAY,EACrD;4CACA,UAAU,CAAC,IAAI,CAAC,6BAA6B,CAAC,CAAC;yCAChD;wCAED,IAAI,MAAM,CAAC,GAAG,IAAI,OAAO,MAAM,CAAC,GAAG,KAAK,QAAQ;4CAAE,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;wCAC9F,IAAI,MAAM,CAAC,GAAG,IAAI,OAAO,MAAM,CAAC,GAAG,KAAK,QAAQ;4CAAE,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;wCAC9F,IACE,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,IAAI;4CAC7C,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,QAAQ;4CACjD,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,IAAI,EAC7C;4CACA,IAAI,MAAM,CAAC,GAAG,IAAI,OAAO,MAAM,CAAC,GAAG,KAAK,QAAQ,EAAE;gDAAE,UAAU,CAAC,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;6CAAE;4CACpG,IAAI,MAAM,CAAC,GAAG,IAAI,OAAO,MAAM,CAAC,GAAG,KAAK,QAAQ,EAAE;gDAAE,UAAU,CAAC,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;6CAAE;yCACrG;wCACD,IAAI,MAAM,CAAC,SAAS;4CAAE,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC;wCAC9E,IAAI,MAAM,CAAC,SAAS;4CAAE,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC;wCAE9E,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;wCAC/C,IAAI,MAAM,CAAC,eAAe,EAAE;4CAC1B,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,kBAAkB,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC;yCACjE;qCACF;oCAED,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,sBAAsB,EAAE,CAAC;oCAC9C,IAAI,IAAI,CAAC,iBAAiB,EAAE;wCAC1B,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;qCACrC;iCACF;6BACF;iCAAM;gCACL,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,eAAe,EAAE,CAAC;gCACvC,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,oBAAoB,EAAE,CAAC;gCAC5C,OAAO,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;gCACxB,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;gCACpC,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,sBAAsB,EAAE,CAAC;gCAE9C,IAAI,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,WAAW,EAAE;oCACxD,MAAM,SAAS,GAAG,OAA2B,CAAC;oCAC9C,SAAS,CAAC,aAAa,CAAC,kBAAkB,CAAC,CAAC;oCAC5C,SAAS,CAAC,UAAU,CAAC,kBAAkB,EAAE,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC;iCAC7D;6BACF;4BACD,MAAM;yBACP;qBACF;iBACF;aACF;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,kBAAkB,CAAC,GAA+C,EAAE,KAAa;QACvF,OAAO,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE;YACzB,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;gBAC7B,IAAI,MAAM,EAAE;oBACV,IAAI,IAAI,GAAG,IAAI,CAAC;oBAChB,KAAK,CAAC,WAAW,EAAE;yBACb,KAAK,CAAC,GAAG,CAAC;yBACV,OAAO,CAAC,IAAI,CAAC,EAAE;wBACd,IAAI,MAAM,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE;4BAC/C,IAAI,GAAG,KAAK,CAAC;4BACb,OAAO,KAAK,CAAC;yBACd;oBACH,CAAC,CAAC,CAAC;oBAER,OAAO,IAAI,CAAC;iBACb;aACF;iBAAM;gBACL,OAAO,IAAI,CAAC;aACb;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,cAAc,CAAC,SAA2B,EAAE,IAAmC;QACrF,IAAI,SAAS,EAAE;YACb,IAAI,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE;gBACjC,IAAI,kBAAoE,CAAC;gBACzE,MAAM,WAAW,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;gBAC3C,IAAI,aAAa,GAAG,CAAC,CAAC;gBACtB,GAAG;oBACD,MAAM,OAAO,GAAG,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,KAAK,KAAK,WAAW,CAAC,aAAa,CAAC,CAAC,CAAC;oBAC7G,IAAI,aAAa,KAAK,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE;wBAC5C,kBAAkB,GAAG,OAAO,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC,KAAK,CAAC;wBAC5D,MAAM,WAAW,GAAG,kBAAkB,CAAC,QAAQ,EAAE,CAAC;wBAClD,IAAI,WAAW,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,IAAI,KAAK,WAAW,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,EAAE;4BACtF,IAAI,WAAW,CAAC,SAAS,EAAE;gCACzB,WAAW,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC,CAAC,KAAK,EAAO,CAAC,KAAK,CAAC,CAAC;wCACrF,IAAI,EAAE,WAAW,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,CAAC;wCACzC,KAAK,EAAE,IAAI,CAAC,KAAK;qCAClB,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC;6BACjB;iCAAM;gCACL,WAAW,CAAC,SAAS,GAAG,IAAI,eAAe,CAAkC,CAAC;wCAC5E,IAAI,EAAE,WAAW,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,CAAC;wCACzC,KAAK,EAAE,IAAI,CAAC,KAAK;qCAClB,CAAC,CAAC,CAAC;6BACL;yBACF;qBACF;oBACD,aAAa,EAAE,CAAC;iBACjB,QAAQ,aAAa,GAAG,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE;aAClD;iBAAM;gBACL,KAAK,MAAM,OAAO,IAAI,SAAS,CAAC,QAAQ,CAAC,MAAM,EAAE,EAAE;oBACjD,IAAI,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,KAAK,KAAK,IAAI,CAAC,IAAI,EAAE;wBAC3C,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;wBAC1C,MAAM;qBACP;iBACF;aACF;SACF;IACH,CAAC;IAEO,KAAK,CAAC,oBAAoB,CAAC,YAA8B;QAC/D,IAAI,IAAI,CAAC,yBAAyB,EAAE;YAClC,MAAM,KAAK,GAAG,YAAY,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,KAAK,CAAC;YAC9C,MAAM,OAAO,GAAG,IAAI,CAAC,yBAAyB;iBACzB,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,SAAS,KAAK,YAAY,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,KAAK,CAAC;iBACrE,IAAI,CAAC,MAAM,CAAC,EAAE;gBACb,IAAI,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE;oBACxB,OAAO,CAAC,CAAC;iBACV;gBACD,OAAO,CAAC,CAAC,CAAC;YACZ,CAAC,CAAC,CAAC;YACvB,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE;gBAC5B,IAAI,MAAM,EAAE;oBACV,IAAI,MAAM,CAAC,iBAAiB,IAAI,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE;wBACpD,MAAM,wBAAwB,GAAG,IAAI,CAAC,QAAQ;6BACR,QAAQ;6BACR,IAAI,CAAC,OAAO,CAAC,EAAE,CACd,MAAM,CAAC,YAAY,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAC5D,CAAC;wBACvC,MAAM,wBAAwB,GAAG,wBAAwB,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC,KAAyD,CAAC;wBAC7I,wBAAwB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;wBACpC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC;wBACf,wBAAwB,CAAC,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC,CAAC;qBAChE;oBACD,IAAI,CAAC,kBAAkB,CAAC,UAAU,CAChC,IAAI,CAAC,UAAU,EACf,MAAM,CAAC,YAAY,EACnB,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,EACpB,MAAM,CAAC,iBAAiB,CACzB,CAAC;iBACH;aACF;SACF;IACH,CAAC;IAEO,0BAA0B,CAAC,cAA0D,EAAE,KAA+C;QAC5I,IAAI,OAAO,GAAG,IAAI,CAAC;QAEnB,KAAK,MAAM,YAAY,IAAI,cAAc,CAAC,MAAM,EAAE,EAAE;YAClD,IAAI,YAAY,CAAC,IAAI,KAAK,KAAK,CAAC,IAAI,EAAE;gBACpC,OAAO,GAAG,KAAK,CAAC;gBAChB,MAAM;aACP;SACF;QAED,OAAO,OAAO,CAAC;IACjB,CAAC;;kHAvkBU,oBAAoB;sGAApB,oBAAoB,+QC/BjC,ix6BA2kBA,wlRD5iBa,oBAAoB;4FAApB,oBAAoB;kBANhC,SAAS;+BACE,oBAAoB,mBAGb,uBAAuB,CAAC,MAAM;+IAGtC,IAAI;sBAAZ,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,yBAAyB;sBAAjC,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,aAAa;sBAArB,KAAK","sourcesContent":["import { UntypedFormArray, UntypedFormBuilder, UntypedFormGroup, Validators, AbstractControl } from '@angular/forms';\nimport { KoalaDynamicFormFieldInterface } from './interfaces/koala.dynamic-form-field.interface';\nimport { DynamicFormTypeFieldEnum } from './enums/dynamic-form-type-field.enum';\nimport { CpfValidator } from './validators/cpf.validator';\nimport { CnpjValidator } from './validators/cnpj.validator';\nimport { ChangeDetectionStrategy, Component, ElementRef, Input, OnInit, ViewChild } from '@angular/core';\nimport { FormAbstract } from '../form.abstract';\nimport { debounceTime } from 'rxjs/operators';\nimport { BehaviorSubject } from 'rxjs';\nimport { KoalaDynamicSetValueInterface } from './interfaces/koala.dynamic-set-value.interface';\nimport { AutocompleteSelectedValidator } from './validators/autocomplete-selected.validator';\nimport { KoalaDynamicAutocompleteOptionsInterface } from './interfaces/koala.dynamic-autocomplete-options.interface';\nimport { KoalaDynamicFormShowFieldInterface } from './interfaces/koala.dynamic-form-show-field.interface';\nimport { KoalaDynamicFormService } from './koala.dynamic-form.service';\nimport { KoalaDynamicFormMoreItensShowFieldConfigInterface } from './interfaces/koala.dynamic-form-more-itens-show-field-config.interface';\nimport { ThemePalette } from '@angular/material/core';\nimport { KoalaDynamicFormAutocompleteMultipleConfigInterface } from './interfaces/koala.dynamic-form-autocomplete-multiple-config.interface';\nimport { KoalaDynamicFormConfigInterface } from './interfaces/koala.dynamic-form-config.interface';\nimport { delay } from \"@koalarx/utils/operators/delay\";\nimport { koala } from \"@koalarx/utils\";\nimport { DateMinValidator } from \"./validators/date-min.validator\";\nimport { DateMaxValidator } from \"./validators/date-max.validator\";\nimport { KoalaLanguageHelper } from \"@koalarx/ui/core\";\nimport { randomString } from \"@koalarx/utils/operators/string\";\n\n@Component({\n  selector: 'koala-dynamic-form',\n  templateUrl: 'dynamic-form.component.html',\n  styleUrls: ['dynamic-form.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DynamicFormComponent extends FormAbstract implements OnInit {\n  @Input() form: UntypedFormGroup;\n  @Input() formConfig: KoalaDynamicFormFieldInterface[];\n  @Input() showFields: BehaviorSubject<KoalaDynamicFormShowFieldInterface[]>;\n  @Input() showFieldsMoreItensConfig: KoalaDynamicFormMoreItensShowFieldConfigInterface[];\n  @Input() setValues: BehaviorSubject<KoalaDynamicSetValueInterface[]>;\n  @Input() tabIndexStart: number = 1;\n\n  public controls: UntypedFormArray;\n  public typeField = DynamicFormTypeFieldEnum;\n  public hoursAndMinutesMask = '00:000';\n  public errorMessage = KoalaLanguageHelper;\n  public formId = randomString(25, {\n    lowercase: true,\n    uppercase: true,\n    numbers: false,\n    specialCharacters: false\n  });\n\n  constructor(\n    private fb: UntypedFormBuilder,\n    private dynamicFormService: KoalaDynamicFormService\n  ) {\n    super(() => this.form);\n  }\n\n  ngOnInit() {\n    if (!this.form.get('formData')) {\n      this.form.addControl('formData', this.fb.array([]));\n    }\n    this.controls = this.form.get('formData') as UntypedFormArray;\n    this.formConfig?.forEach((config, indexConfig) => {\n      const newFormGroup = this.newControl(config);\n      if (config.asyncValidators) {\n        newFormGroup.get('value').setAsyncValidators(config.asyncValidators);\n      }\n      newFormGroup.get('value').updateValueAndValidity();\n      if (config.type === DynamicFormTypeFieldEnum.dynamicForm) {\n        const formGroupDynamicFormsSubject = newFormGroup.get('dynamicFormConfig').value as BehaviorSubject<KoalaDynamicFormConfigInterface>;\n        formGroupDynamicFormsSubject.subscribe(formGroupConfig => {\n          if (formGroupConfig) {\n            formGroupConfig.form.valueChanges.subscribe(() => {\n              if (formGroupConfig.form.valid && (config.valueChanges || this.showFieldsMoreItensConfig)) {\n                const value = this.dynamicFormService.emitData(formGroupConfig.form);\n                newFormGroup.get('value').setValue(value);\n              }\n            });\n          }\n        });\n      }\n      if (\n        config.valueChanges ||\n        config.type === DynamicFormTypeFieldEnum.autocomplete ||\n        config.type === DynamicFormTypeFieldEnum.dynamicForm ||\n        this.showFieldsMoreItensConfig\n      ) {\n        if (config.type === DynamicFormTypeFieldEnum.autocomplete) {\n          const autocompleteOptionsSubject = newFormGroup.get('autocompleteOptions').value as BehaviorSubject<KoalaDynamicAutocompleteOptionsInterface[]>;\n          if (autocompleteOptionsSubject) {\n            autocompleteOptionsSubject.subscribe(options => newFormGroup.get('autocompleteOptionsFiltered').value.next(options));\n          }\n        }\n        newFormGroup.get('value')\n                    .valueChanges\n                    .pipe(debounceTime(300))\n                    .subscribe(async value => {\n                      await this.setConfigDynamicForm(newFormGroup);\n                      if (config.type === DynamicFormTypeFieldEnum.autocomplete) {\n                        if (\n                          value && (\n                            value.hasOwnProperty('value') &&\n                            value.hasOwnProperty('name') &&\n                            Object.keys(value).length === 2\n                          ) || (\n                            Array.isArray(value) &&\n                            newFormGroup.get('multiple').value\n                          )) {\n                          if (newFormGroup.get('multiple').value) {\n                            if (Array.isArray(value)) {\n                              newFormGroup.get('autocompleteSelectedValue').setValue(value);\n                              newFormGroup.get('value').setValue(value[value.length - 1], {emitEvent: false});\n                            } else {\n                              if (this.validateAutocompleteSelect(newFormGroup.get('autocompleteSelectedValue').value, value)) {\n                                newFormGroup.get('autocompleteSelectedValue').value.push(value);\n                              }\n                            }\n\n                            const autocompleteInput = document.querySelector<HTMLInputElement>(`#${this.formId} input#autocomplete-${newFormGroup.get('name')?.value}`);\n                            if (autocompleteInput) {\n                              autocompleteInput.value = '';\n                            }\n                          } else {\n                            newFormGroup.get('autocompleteSelectedValue').setValue(value);\n                          }\n                        } else if (!newFormGroup.get('multiple').value) {\n                          newFormGroup.get('autocompleteSelectedValue').setValue(koala(this.formConfig)\n                            .array<KoalaDynamicFormFieldInterface>()\n                            .filter(newFormGroup.get('name').value, 'name')\n                            .getValue()[0]?.autocompleteDefaultValueOnClear ?? null);\n                        }\n\n                        if (config.type === DynamicFormTypeFieldEnum.autocomplete) {\n                          if (config.autocompleteType === 'all') {\n                            const autocompleteOptionsSubject = newFormGroup.get('autocompleteOptions').value as BehaviorSubject<KoalaDynamicAutocompleteOptionsInterface[]>;\n                            newFormGroup.get('autocompleteOptionsFiltered').value.next(this.autocompleteFilter(\n                              autocompleteOptionsSubject.value,\n                              value\n                            ));\n                          } else if (config.autocompleteType === 'onDemand' && typeof value !== \"object\") {\n                            const loader = newFormGroup.get('autocompleteLoading').value as BehaviorSubject<boolean>;\n                            loader.next(true);\n                            config.autocompleteFilter(value).subscribe(options => {\n                              newFormGroup.get('autocompleteOptionsFiltered').value.next(options);\n                              loader.next(false);\n                            });\n                          }\n                        }\n                      }\n                      if (config.valueChanges) {\n                        if (config.type === DynamicFormTypeFieldEnum.autocomplete) {\n                          config.valueChanges((newFormGroup.get('multiple').value ?\n                                               newFormGroup.get('autocompleteSelectedValue').value.map(item => item.value) :\n                                               newFormGroup.get('autocompleteSelectedValue').value?.value\n                          ));\n                        } else {\n                          config.valueChanges(value);\n                        }\n                      }\n                    });\n      }\n      this.controls.push(newFormGroup);\n      if (config.moreItemsConfig) {\n        if (config.moreItemsMinItems > 0) {\n          for (let min = 0; min < config.moreItemsMinItems; min++) {\n            if (min <= config.moreItemsMaxItems) {\n              this.addMoreItem(indexConfig);\n            }\n          }\n        }\n        if (config.moreItemsConfig.setValues) {\n          config.moreItemsConfig\n                .setValues\n                .subscribe(async values => {\n                  if (values.length > 0) {\n                    values.forEach((itemValue, indexValue) => {\n                      if (!this.controls.controls[indexConfig].get('moreItemsConfig').value[indexValue]) {\n                        this.addMoreItem(indexConfig);\n                      }\n                      setTimeout(() => {\n                        this.setValuesOnFields(\n                          itemValue,\n                          this.controls.controls[indexConfig].get('moreItemsConfig').value[indexValue].form\n                        );\n                      }, 300);\n                    });\n                  }\n                });\n        }\n      }\n    });\n    if (this.showFields) {\n      this.changeVisibilityFields(this.showFields, this.form);\n    }\n    if (this.setValues) {\n      this.setValuesOnFields(this.setValues, this.form);\n    }\n  }\n\n  public isValidNewAutocompleteOption(value: any) {\n    return !!value && typeof value === 'string';\n  }\n\n  public hoursAndMinutesApplyMask(index: number, event: KeyboardEvent) {\n    const control = this.controls?.controls[index];\n    const type = control?.get('type').value as DynamicFormTypeFieldEnum;\n    if (type === DynamicFormTypeFieldEnum.hoursAndMinutes) {\n      const value = control?.get('value').value;\n      if (event.key == 'Backspace' && value.length < 6) {\n        this.hoursAndMinutesMask = '00:000';\n      } else if (event.key != 'Backspace' && value.length >= 6) {\n        this.hoursAndMinutesMask = '000:00';\n      }\n    }\n  }\n\n  public passwordView(index: number) {\n    const control = this.controls?.controls[index];\n    const hidePassword = !control?.get('hidePassword').value;\n    control?.get('hidePassword').setValue(hidePassword);\n    control?.get('type').setValue(hidePassword ?\n                                  DynamicFormTypeFieldEnum.password :\n                                  DynamicFormTypeFieldEnum.text\n    );\n  }\n\n  public addMoreItem(propIndex: number) {\n    if (this.controls.controls[propIndex].get('moreItemsConfig').value.length < this.controls.controls[propIndex].get('moreItemsMaxItems').value) {\n      const formGroup = this.fb.group({});\n      this.controls.controls[propIndex].get('moreItemsConfig').value.push({\n        form: formGroup,\n        formConfig: this.formConfig[propIndex].moreItemsConfig.formConfig,\n        showFields: new BehaviorSubject<BehaviorSubject<KoalaDynamicSetValueInterface[]>[]>([]),\n        showFieldsMoreItensConfig: this.formConfig[propIndex].moreItemsConfig.showFieldsConfig\n      });\n      this.controls.controls[propIndex].get('moreItemsExpanded').setValue(\n        this.controls.controls[propIndex].get('moreItemsConfig').value.length - 1\n      );\n      const formArrayMoreItems = this.controls.controls[propIndex].get('moreItemsFormGroup') as UntypedFormArray;\n      formArrayMoreItems.push(formGroup);\n    }\n  }\n\n  public removeMoreItem(propIndex: number, removeIndex) {\n    const expandedItemIndex = removeIndex - 1;\n    this.controls.controls[propIndex].get('moreItemsConfig').value.splice(removeIndex, 1);\n    setTimeout(() => {\n      this.controls.controls[propIndex].get('moreItemsExpanded').setValue((expandedItemIndex < 0) ? 0 : expandedItemIndex);\n    }, 50);\n  }\n\n  public clearAutocomplete(propIndex: number) {\n    if (this.controls.controls[propIndex].get('multiple').value) {\n      this.controls.controls[propIndex].get('autocompleteSelectedValue').setValue([]);\n      this.controls.controls[propIndex].get('value').setValue(null);\n    } else {\n      this.controls.controls[propIndex].get('autocompleteSelectedValue').setValue(this.formConfig[propIndex].autocompleteDefaultValueOnClear ?? null);\n      this.controls.controls[propIndex].get('value').setValue(this.formConfig[propIndex].autocompleteDefaultValueOnClear ?? null);\n    }\n  }\n\n  public display(option?: KoalaDynamicAutocompleteOptionsInterface): string | undefined {\n    return option ? option.name : undefined;\n  }\n\n  public removeOptionOnAutocomplete(propIndex: number, option: KoalaDynamicAutocompleteOptionsInterface) {\n    const value = this.controls.controls[propIndex].get('autocompleteSelectedValue').value.filter(item => item !== option) as KoalaDynamicAutocompleteOptionsInterface[];\n    this.controls.controls[propIndex].get('autocompleteSelectedValue').setValue(value);\n    if (value.length === 0) {\n      this.controls.controls[propIndex].get('autocompleteSelectedValue').setValue([]);\n      this.controls.controls[propIndex].get('value').setValue(null);\n    } else if (this.formConfig[propIndex].valueChanges) {\n      this.formConfig[propIndex].valueChanges(value.map(item => item.value));\n    }\n  }\n\n  public getColorChip(config: KoalaDynamicFormAutocompleteMultipleConfigInterface): ThemePalette {\n    return config.color;\n  }\n\n  public getAutocompleteOptions(propriedade: AbstractControl) {\n    return propriedade.get('autocompleteOptionsFiltered').value as BehaviorSubject<any[]>;\n  }\n\n  public getDynamicFormConfig(propriedade: AbstractControl) {\n    return propriedade.get('dynamicFormConfig').value as BehaviorSubject<KoalaDynamicFormConfigInterface>;\n  }\n\n  public getRandomString() {\n    return randomString(20, {\n      lowercase: true,\n      numbers: true,\n      specialCharacters: false,\n      uppercase: true\n    });\n  }\n\n  private newControl(config: KoalaDynamicFormFieldInterface): UntypedFormGroup {\n    let validators = config.syncValidators ?? [];\n    let value: any = config.value ?? '';\n    let valueSelectedAutocomplete: KoalaDynamicAutocompleteOptionsInterface | KoalaDynamicAutocompleteOptionsInterface[] = (\n      config.multiple ? [] : (config.autocompleteDefaultValueOnClear ?? null)\n    );\n\n    if (config.required === true) validators.push(Validators.required);\n    if (config.min && typeof config.min === \"number\") validators.push(Validators.min(config.min));\n    if (config.max && typeof config.max === \"number\") validators.push(Validators.max(config.max));\n    if (\n      config.type === DynamicFormTypeFieldEnum.date ||\n      config.type === DynamicFormTypeFieldEnum.datetime ||\n      config.type === DynamicFormTypeFieldEnum.time\n    ) {\n      if (config.min && typeof config.min === \"string\") { validators.push(DateMinValidator(config.min)); }\n      if (config.max && typeof config.max === \"string\") { validators.push(DateMaxValidator(config.max)); }\n    }\n    if (config.minLength) validators.push(Validators.minLength(config.minLength));\n    if (config.maxLength) validators.push(Validators.maxLength(config.maxLength));\n\n    if (config.type === DynamicFormTypeFieldEnum.cpf) {\n      validators.push(CpfValidator);\n    } else if (config.type === DynamicFormTypeFieldEnum.cnpj) {\n      validators.push(CnpjValidator);\n    } else if (config.type === DynamicFormTypeFieldEnum.email) {\n      validators.push(Validators.email);\n    } else if (config.type === DynamicFormTypeFieldEnum.autocomplete) {\n      if (value) {\n        valueSelectedAutocomplete = value;\n        value = (config.multiple ? valueSelectedAutocomplete[0] : value);\n      }\n      if (config.required === true) {\n        validators.push(AutocompleteSelectedValidator);\n      }\n    } else if (config.type === DynamicFormTypeFieldEnum.checkbox) {\n      value = config.value ?? false;\n    }\n\n    if (\n      config.type === DynamicFormTypeFieldEnum.hoursAndMinutes &&\n      value.length >= 6\n    ) {\n      this.hoursAndMinutesMask = '000:00';\n    }\n\n    if (config.dynamicFormConfig) {\n      const cloneDynamicFormConfig = {} as KoalaDynamicFormConfigInterface;\n      Object.assign(cloneDynamicFormConfig, config.dynamicFormConfig);\n      cloneDynamicFormConfig.form = config.dynamicFormConfig.form;\n      config.dynamicFormConfig = cloneDynamicFormConfig;\n    }\n\n    if (config.show === false) {\n      validators = [];\n    }\n\n    const field = this.fb.group({\n      show: [new BehaviorSubject<boolean>(config.show ?? true)],\n      label: [config.label],\n      name: [config.name],\n      type: [config.type],\n      fileButtonConfig: [{\n        icon: config?.fileButtonConfig?.icon ?? 'attach_file',\n        text: config?.fileButtonConfig?.text ?? 'Clique para anexar arquivos',\n        backgroundColor: config?.fileButtonConfig?.backgroundColor ?? 'white',\n        color: config?.fileButtonConfig?.color ?? 'blue',\n        accept: config?.fileButtonConfig?.accept ?? '*'\n      }],\n      dynamicFormConfig: [new BehaviorSubject<KoalaDynamicFormConfigInterface>(config.dynamicFormConfig)],\n      dynamicFormGroup: this.fb.array([]),\n      appearance: [config.appearance],\n      floatLabel: [config.floatLabel],\n      placeholder: [config.placeholder],\n      class: [config.class],\n      fieldClass: [config.fieldClass],\n      textHint: [config.textHint],\n      required: [config.required ?? false],\n      min: [config.min ?? 0],\n      max: [config.max ?? 99999999999],\n      minLength: [config.minLength ?? 0],\n      maxLength: [config.maxLength ?? 255],\n      disabled: [config.disabled ?? false],\n      focus: [config.focus ?? false],\n      multiple: [config.multiple ?? false],\n      opcoesSelect: [config.opcoesSelect ?? []],\n      hidePassword: config.type === DynamicFormTypeFieldEnum.password ? true : null,\n      moreItemsButtonIconAddlabel: [config.moreItemsButtonIconAddlabel],\n      moreItemsMinItems: [config.moreItemsMinItems ?? 0],\n      moreItemsMaxItems: [config.moreItemsMaxItems ?? 100],\n      moreItemsIcon: [config.moreItemsIcon],\n      moreItemsIconFontColor: [config.moreItemsIconFontColor],\n      moreItemsIconBackgroundColor: [config.moreItemsIconBackgroundColor],\n      moreItemsExpanded: [''],\n      moreItemsConfig: [[]],\n      moreItemsFormGroup: this.fb.array([]),\n      autocompleteLoading: [new BehaviorSubject<boolean>(false)],\n      autocompleteOptions: [config.autocompleteOptions],\n      autocompleteMultipleConfig: [config.autocompleteMultipleConfig],\n      autocompleteOptionsFiltered: [new BehaviorSubject<any>([])],\n      autocompleteSelectedValue: [valueSelectedAutocomplete],\n      autocompleteAddOption: [config.autocompleteAddOption],\n      textLogs: [config?.textObs],\n      customMasc: [config?.customMasc],\n      customMascThousandSeparator: [config?.customMascThousandSeparator ?? ''],\n      customMascSuffix: [config?.customMascSuffix ?? ''],\n      customMascPrefix: [config?.customMascPrefix ?? ''],\n      value: [{value, disabled: config.disabled}, validators, config.asyncValidators]\n    });\n\n    if (config.autocompleteType === \"onDemand\") {\n      const loader = field.get('autocompleteLoading').value as BehaviorSubject<boolean>;\n      loader.next(true);\n      config.autocompleteFilter('').subscribe(options => {\n        field.get('autocompleteOptionsFiltered').value.next(options);\n        loader.next(false);\n      });\n    }\n\n    return field;\n  }\n\n  private setValuesOnFields(subject: BehaviorSubject<KoalaDynamicSetValueInterface[]>, form: UntypedFormGroup) {\n    subject.subscribe(item => {\n      if (item) {\n        const formArray = form.get('formData') as UntypedFormArray;\n        for (const prop of item.values()) {\n          this.setValueByProp(formArray, prop);\n        }\n      }\n    });\n  }\n\n  private changeVisibilityFields(subject: BehaviorSubject<KoalaDynamicFormShowFieldInterface[]>, form: UntypedFormGroup) {\n    subject.pipe(debounceTime(5)).subscribe(item => {\n      if (item) {\n        const formArray = form.get('formData') as UntypedFormArray;\n        for (const prop of item.values()) {\n          for (const [indexControl, control] of formArray.controls.entries()) {\n            if (control.get('name').value === prop.name) {\n              control.get('show').value.next(prop.show);\n              const config: KoalaDynamicFormFieldInterface = this.formConfig[indexControl] ?? null;\n              if (prop.show) {\n                let validators = [];\n                if (config) {\n                  if (config.type === DynamicFormTypeFieldEnum.dynamicForm) {\n                    const formArrayMoreItems = control.get('dynamicFormGroup') as UntypedFormArray;\n                    formArrayMoreItems.push(config?.dynamicFormConfig?.form);\n                  } else {\n                    validators = config.syncValidators ?? [];\n                    if (config.required === true) {\n                      validators.push(Validators.required);\n                    }\n                    if (config.type === DynamicFormTypeFieldEnum.cpf) {\n                      validators.push(CpfValidator);\n                    } else if (config.type === DynamicFormTypeFieldEnum.cnpj) {\n                      validators.push(CnpjValidator);\n                    } else if (config.type === DynamicFormTypeFieldEnum.email) {\n                      validators.push(Validators.email);\n                    } else if (\n                      config.required === true &&\n                      config.type === DynamicFormTypeFieldEnum.autocomplete\n                    ) {\n                      validators.push(AutocompleteSelectedValidator);\n                    }\n\n                    if (config.min && typeof config.min === \"number\") validators.push(Validators.min(config.min));\n                    if (config.max && typeof config.max === \"number\") validators.push(Validators.max(config.max));\n                    if (\n                      config.type === DynamicFormTypeFieldEnum.date ||\n                      config.type === DynamicFormTypeFieldEnum.datetime ||\n                      config.type === DynamicFormTypeFieldEnum.time\n                    ) {\n                      if (config.min && typeof config.min === \"string\") { validators.push(DateMinValidator(config.min)); }\n                      if (config.max && typeof config.max === \"string\") { validators.push(DateMaxValidator(config.max)); }\n                    }\n                    if (config.minLength) validators.push(Validators.minLength(config.minLength));\n                    if (config.maxLength) validators.push(Validators.maxLength(config.maxLength));\n\n                    control.get('value').setValidators(validators);\n                    if (config.asyncValidators) {\n                      control.get('value').setAsyncValidators(config.asyncValidators);\n                    }\n                  }\n\n                  control.get('value').updateValueAndValidity();\n                  if (prop.clearCurrentValue) {\n                    control.get('value').setValue(null);\n                  }\n                }\n              } else {\n                control.get('value').clearValidators();\n                control.get('value').clearAsyncValidators();\n                control.setErrors(null);\n                control.get('value').setValue(null);\n                control.get('value').updateValueAndValidity();\n\n                if (config.type === DynamicFormTypeFieldEnum.dynamicForm) {\n                  const formGroup = control as UntypedFormGroup;\n                  formGroup.removeControl('dynamicFormGroup');\n                  formGroup.addControl('dynamicFormGroup', this.fb.array([]));\n                }\n              }\n              break;\n            }\n          }\n        }\n      }\n    });\n  }\n\n  private autocompleteFilter(arr: KoalaDynamicAutocompleteOptionsInterface[], value: string): KoalaDynamicAutocompleteOptionsInterface[] {\n    return arr.filter(filter => {\n      if (typeof value === 'string') {\n        if (filter) {\n          let find = true;\n          value.toLowerCase()\n               .split(' ')\n               .forEach(part => {\n                 if (filter.name.toLowerCase().indexOf(part) < 0) {\n                   find = false;\n                   return false;\n                 }\n               });\n\n          return find;\n        }\n      } else {\n        return true;\n      }\n    });\n  }\n\n  private setValueByProp(formArray: UntypedFormArray, prop: KoalaDynamicSetValueInterface) {\n    if (formArray) {\n      if (prop.name.indexOf(' > ') >= 0) {\n        let dynamicFormSubject: BehaviorSubject<KoalaDynamicFormConfigInterface>;\n        const arrPropName = prop.name.split(' > ');\n        let indexPropName = 0;\n        do {\n          const control = formArray.controls.find(control => control.get('name').value === arrPropName[indexPropName]);\n          if (indexPropName === arrPropName.length - 2) {\n            dynamicFormSubject = control.get('dynamicFormConfig').value;\n            const dynamicForm = dynamicFormSubject.getValue();\n            if (dynamicForm.formConfig.find(fc => fc.name === arrPropName[arrPropName.length - 1])) {\n              if (dynamicForm.setValues) {\n                dynamicForm.setValues.next(koala(dynamicForm.setValues.getValue()).array<any>().merge([{\n                  name: arrPropName[arrPropName.length - 1],\n                  value: prop.value\n                }]).getValue());\n              } else {\n                dynamicForm.setValues = new BehaviorSubject<KoalaDynamicSetValueInterface[]>([{\n                  name: arrPropName[arrPropName.length - 1],\n                  value: prop.value\n                }]);\n              }\n            }\n          }\n          indexPropName++;\n        } while (indexPropName < arrPropName.length - 1);\n      } else {\n        for (const control of formArray.controls.values()) {\n          if (control.get('name').value === prop.name) {\n            control.get('value').setValue(prop.value);\n            break;\n          }\n        }\n      }\n    }\n  }\n\n  private async setConfigDynamicForm(newFormGroup: UntypedFormGroup) {\n    if (this.showFieldsMoreItensConfig) {\n      const value = newFormGroup.get('value').value;\n      const configs = this.showFieldsMoreItensConfig\n                          .filter(config => config.nameField === newFormGroup.get('name').value)\n                          .sort(config => {\n                            if (config.fnShow(value)) {\n                              return 1;\n                            }\n                            return -1;\n                          });\n      for (const config of configs) {\n        if (config) {\n          if (config.dynamicFormConfig && config.fnShow(value)) {\n            const controlDynamicFormConfig = this.controls\n                                                 .controls\n                                                 .find(control =>\n                                                   config.fieldsToShow.indexOf(control.get('name').value) >= 0\n                                                 );\n            const dynamicFormConfigSubject = controlDynamicFormConfig.get('dynamicFormConfig').value as BehaviorSubject<KoalaDynamicFormConfigInterface>;\n            dynamicFormConfigSubject.next(null);\n            await delay(1);\n            dynamicFormConfigSubject.next(config.dynamicFormConfig(value));\n          }\n          this.dynamicFormService.showFields(\n            this.showFields,\n            config.fieldsToShow,\n            config.fnShow(value),\n            config.clearCurrentValue\n          );\n        }\n      }\n    }\n  }\n\n  private validateAutocompleteSelect(selectedValues: KoalaDynamicAutocompleteOptionsInterface[], value: KoalaDynamicAutocompleteOptionsInterface) {\n    let isValid = true;\n\n    for (const selectedItem of selectedValues.values()) {\n      if (selectedItem.name === value.name) {\n        isValid = false;\n        break;\n      }\n    }\n\n    return isValid;\n  }\n}\n","<div [formGroup]=\"form\" class=\"p-relative w-100\" [id]=\"formId\">\n  <div *ngFor=\"let propriedade of controls?.controls; let i = index;\"\n       [ngClass]=\"(propriedade.get('show').value | async) ? propriedade.get('class').value : 'd-none'\"\n       formArrayName=\"formData\">\n\t  <div *ngIf=\"propriedade.get('show').value | async\">\n\t    <mat-form-field\n\t\t    *ngIf=\"propriedade.get('type').value == typeField.text ||\n\t             propriedade.get('type').value == typeField.password ||\n\t             propriedade.get('type').value == typeField.cpf ||\n\t             propriedade.get('type').value == typeField.cnpj ||\n\t             propriedade.get('type').value == typeField.datetime ||\n\t             propriedade.get('type').value == typeField.email ||\n\t             propriedade.get('type').value == typeField.number ||\n\t             propriedade.get('type').value == typeField.stringNumber ||\n\t             propriedade.get('type').value == typeField.time ||\n\t             propriedade.get('type').value == typeField.date ||\n\t             propriedade.get('type').value == typeField.hoursAndMinutes ||\n\t             propriedade.get('type').value == typeField.phone ||\n\t             propriedade.get('type').value == typeField.percent ||\n\t             propriedade.get('type').value == typeField.color ||\n\t             propriedade.get('type').value == typeField.month ||\n\t             propriedade.get('type').value == typeField.competenceDate ||\n               propriedade.get('type').value == typeField.stringWithCustomMasc\"\n\t\t    [appearance]=\"propriedade.get('appearance').value\"\n\t\t    [floatLabel]=\"propriedade.get('floatLabel').value\"\n\t\t    [formGroupName]=\"i\"\n\t\t    [ngClass]=\"propriedade.get('fieldClass').value\">\n\t      <mat-label>{{propriedade.get('label').value}}</mat-label>\n\t      <input\n\t\t      [dropSpecialCharacters]=\"false\"\n\t\t      [koalaAutoFocus]=\"propriedade.get('focus').value\"\n\t\t      (keyup)=\"hoursAndMinutesApplyMask(i, $event)\"\n\t\t      [required]=\"propriedade.get('required').value\"\n\t\t      [tabIndex]=\"tabIndexStart + i\"\n\t\t      [mask]=\"((propriedade.get('type').value == typeField.competenceDate) ? '00/0000' : null) ||\n\t\t              ((propriedade.get('type').value == typeField.phone) ? '(00)0000-0000?0' : null) ||\n\t\t              ((propriedade.get('type').value == typeField.stringNumber) ? '0{'+propriedade.get('maxLength').value+'}' : null) ||\n                  ((propriedade.get('type').value == typeField.cpf) ? '000.000.000-00' : null) ||\n                  ((propriedade.get('type').value == typeField.cnpj) ? '00.000.000/0000-00' : null) ||\n                  ((propriedade.get('type').value == typeField.percent) ? 'percent' : null) ||\n\t\t\t\t\t\t\t\t\t((propriedade.get('type').value == typeField.hoursAndMinutes) ? hoursAndMinutesMask : null) ||\n\t\t\t\t\t\t\t\t\t((propriedade.get('type').value == typeField.stringWithCustomMasc) ? propriedade.get('customMasc').value : null)\"\n\t\t      [validation]=\"\n\t                    (propriedade.get('type').value == typeField.cpf && propriedade.get('value').errors?.cpfInvalid) ||\n\t                    (propriedade.get('type').value == typeField.cnpj && propriedade.get('value').errors?.cnpjInvalid)\"\n\t\t      [type]=\"((propriedade.get('type').value == typeField.cpf ||\n                    propriedade.get('type').value == typeField.cnpj ||\n                    propriedade.get('type').value == typeField.phone ||\n                    propriedade.get('type').value == typeField.percent\n                  )) ? 'tel' : (\n                    propriedade.get('type').value == typeField.month ?\n                    'month' : (\n                    propriedade.get('type').value == typeField.date ?\n                    'date' : (\n                    propriedade.get('type').value == typeField.datetime ?\n                    'datetime-local' : (\n                    propriedade.get('type').value == typeField.email ?\n                    'email' : (\n                    propriedade.get('type').value == typeField.number ?\n                    'number' : (\n                    propriedade.get('type').value == typeField.time ?\n                    'time' : (\n                    propriedade.get('type').value == typeField.password ?\n                    'password' : (\n                    propriedade.get('type').value == typeField.color ?\n                    'color' : 'text'))))))))\"\n          [min]=\"propriedade.get('min').value\"\n          [max]=\"propriedade.get('max').value\"\n          [minLength]=\"propriedade.get('minLength').value\"\n          [maxLength]=\"propriedade.get('maxLength').value\"\n          [thousandSeparator]=\"propriedade.get('customMascThousandSeparator').value\"\n          [suffix]=\"propriedade.get('customMascSuffix').value\"\n          [prefix]=\"propriedade.get('customMascPrefix').value\"\n          separatorLimit=\"0\"\n          [autocomplete]=\"getRandomString()\"\n\t\t      formControlName=\"value\"\n\t\t      matInput/>\n\t      <button\n\t\t      (click)=\"passwordView(i)\"\n\t\t      *ngIf=\"propriedade.get('hidePassword').value !== null\"\n\t\t      [attr.aria-label]=\"'Hide password'\"\n\t\t      [attr.aria-pressed]=\"propriedade.get('hidePassword').value\"\n\t\t      mat-icon-button matSuffix tabindex=\"-1\" type=\"button\">\n\t        <mat-icon>{{propriedade.get('hidePassword').value ? 'visibility_off' : 'visibility'}}</mat-icon>\n\t      </button>\n\t      <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n\t        <mat-icon>info</mat-icon>\n\t\t      {{propriedade.get('textHint').value}}\n\t      </mat-hint>\n\t      <mat-error *ngIf=\"propriedade.get('value').errors?.required\">\n\t        <mat-icon>error</mat-icon>\n          {{errorMessage.getRequiredMessage(propriedade.get('label').value)}}\n\t      </mat-error>\n\t      <mat-error *ngIf=\"propriedade.get('value').errors?.cpfInvalid\">\n\t        <mat-icon>error</mat-icon>\n          {{errorMessage.getInvalidMessage(propriedade.get('label').value)}}\n\t      </mat-error>\n\t      <mat-error *ngIf=\"propriedade.get('value').errors?.cnpjInvalid\">\n\t        <mat-icon>error</mat-icon>\n          {{errorMessage.getInvalidMessage(propriedade.get('label').value)}}\n\t      </mat-error>\n\t      <mat-error *ngIf=\"propriedade.get('value').errors?.email\">\n\t        <mat-icon>error</mat-icon>\n          {{errorMessage.getInvalidMessage(propriedade.get('label').value)}}\n\t      </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.min\">\n          <mat-icon>error</mat-icon>\n          {{errorMessage.getMinMessage(propriedade.get('min').value)}}\n        </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.max\">\n          <mat-icon>error</mat-icon>\n          {{errorMessage.getMaxMessage(propriedade.get('max').value)}}\n        </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.minLength\">\n          <mat-icon>error</mat-icon>\n          {{errorMessage.getMinLengthMessage(propriedade.get('minLength').value)}}\n        </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.maxLength\">\n          <mat-icon>error</mat-icon>\n          {{errorMessage.getMaxLengthMessage(propriedade.get('maxLength').value)}}\n        </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.dateMin\">\n          <mat-icon>error</mat-icon>\n          {{errorMessage.getDateMinMessage()}}\n          {{propriedade.get('min').value | date:\"shortDate\"}}.\n        </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.dateMax\">\n          <mat-icon>error</mat-icon>\n          {{errorMessage.getDateMaxMessage()}}\n          {{propriedade.get('max').value | date:\"shortDate\"}}.\n        </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n          <mat-icon>error</mat-icon>\n          {{propriedade.get('value').errors?.customError.message}}.\n        </mat-error>\n\t    </mat-form-field>\n\t    <mat-form-field\n\t\t    *ngIf=\"propriedade.get('type').value == typeField.coin\"\n\t\t    [appearance]=\"propriedade.get('appearance').value\"\n\t\t    [floatLabel]=\"propriedade.get('floatLabel').value\"\n\t\t    [formGroupName]=\"i\"\n\t\t    [ngClass]=\"propriedade.get('fieldClass').value\">\n\t      <mat-label>{{propriedade.get('label').value}}</mat-label>\n\t      <input\n\t\t      [koalaAutoFocus]=\"propriedade.get('focus').value\"\n\t\t      [required]=\"propriedade.get('required').value\"\n          [tabIndex]=\"tabIndexStart + i\"\n          [min]=\"propriedade.get('min').value\"\n          [max]=\"propriedade.get('max').value\"\n          [minLength]=\"propriedade.get('minLength').value\"\n          [maxLength]=\"propriedade.get('maxLength').value\"\n          [autocomplete]=\"getRandomString()\"\n\t\t      currencyMask\n\t\t      formControlName=\"value\"\n\t\t      matInput\n\t\t      type=\"tel\"/>\n\t      <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n\t        <mat-icon>info</mat-icon>\n\t\t      {{propriedade.get('textHint').value}}\n\t      </mat-hint>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.min\">\n          <mat-icon>error</mat-icon>\n          {{errorMessage.getMinMessage(propriedade.get('min').value)}}\n        </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.max\">\n          <mat-icon>error</mat-icon>\n          {{errorMessage.getMaxMessage(propriedade.get('max').value)}}\n        </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.minLength\">\n          <mat-icon>error</mat-icon>\n          {{errorMessage.getMinLengthMessage(propriedade.get('minLength').value)}}\n        </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.maxLength\">\n          <mat-icon>error</mat-icon>\n          {{errorMessage.getMaxLengthMessage(propriedade.get('maxLength').value)}}\n        </mat-error>\n\t      <mat-error *ngIf=\"propriedade.get('value').errors?.required\">\n\t        <mat-icon>error</mat-icon>\n          {{errorMessage.getRequiredMessage(propriedade.get('label').value)}}\n\t      </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n          <mat-icon>error</mat-icon>\n          {{propriedade.get('value').errors?.customError.message}}.\n        </mat-error>\n\t    </mat-form-field>\n      <mat-form-field\n        *ngIf=\"propriedade.get('type').value == typeField.float\"\n        [appearance]=\"propriedade.get('appearance').value\"\n        [floatLabel]=\"propriedade.get('floatLabel').value\"\n        [formGroupName]=\"i\"\n        [ngClass]=\"propriedade.get('fieldClass').value\">\n        <mat-label>{{propriedade.get('label').value}}</mat-label>\n        <input\n          [koalaAutoFocus]=\"propriedade.get('focus').value\"\n          [required]=\"propriedade.get('required').value\"\n          [tabIndex]=\"tabIndexStart + i\"\n          [min]=\"propriedade.get('min').value\"\n          [max]=\"propriedade.get('max').value\"\n          [minLength]=\"propriedade.get('minLength').value\"\n          [maxLength]=\"propriedade.get('maxLength').value\"\n          [autocomplete]=\"getRandomString()\"\n          currencyMask\n          [options]=\"{prefix: ''}\"\n          formControlName=\"value\"\n          matInput\n          type=\"tel\"/>\n        <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n          <mat-icon>info</mat-icon>\n          {{propriedade.get('textHint').value}}\n        </mat-hint>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.min\">\n          <mat-icon>error</mat-icon>\n          {{errorMessage.getMinMessage(propriedade.get('min').value)}}\n        </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.max\">\n          <mat-icon>error</mat-icon>\n          {{errorMessage.getMaxMessage(propriedade.get('max').value)}}\n        </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.minLength\">\n          <mat-icon>error</mat-icon>\n          {{errorMessage.getMinLengthMessage(propriedade.get('minLength').value)}}\n        </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.maxLength\">\n          <mat-icon>error</mat-icon>\n          {{errorMessage.getMaxLengthMessage(propriedade.get('maxLength').value)}}\n        </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.required\">\n          <mat-icon>error</mat-icon>\n          {{errorMessage.getRequiredMessage(propriedade.get('label').value)}}\n        </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n          <mat-icon>error</mat-icon>\n          {{propriedade.get('value').errors?.customError.message}}.\n        </mat-error>\n      </mat-form-field>\n\t    <mat-form-field\n\t\t    *ngIf=\"propriedade.get('type').value == typeField.valueList ||\n\t             propriedade.get('type').value == typeField.textarea\"\n\t\t    [appearance]=\"propriedade.get('appearance').value\"\n\t\t    [floatLabel]=\"propriedade.get('floatLabel').value\"\n\t\t    [formGroupName]=\"i\"\n\t\t    [ngClass]=\"propriedade.get('fieldClass').value\">\n\t      <mat-label>{{propriedade.get('label').value}}</mat-label>\n\t      <textarea\n          #textarea\n\t\t      [koalaAutoFocus]=\"propriedade.get('focus').value\"\n          cdkTextareaAutosize\n          #autosize=\"cdkTextareaAutosize\"\n\t\t      [cdkAutosizeMaxRows]=\"8\"\n\t\t      [cdkAutosizeMinRows]=\"3\"\n\t\t      [required]=\"propriedade.get('required').value\"\n          [tabIndex]=\"tabIndexStart + i\"\n          [minLength]=\"propriedade.get('minLength').value\"\n          [maxLength]=\"propriedade.get('maxLength').value\"\n\t\t      formControlName=\"value\"\n\t\t      matInput>\n        </textarea>\n\t      <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n\t        <mat-icon>info</mat-icon>\n\t\t      {{propriedade.get('textHint').value}}\n\t      </mat-hint>\n        <mat-hint align=\"end\" *ngIf=\"propriedade.get('maxLength').value\">\n          {{textarea.value.length}}/{{propriedade.get('maxLength').value}}\n        </mat-hint>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.minLength\">\n          <mat-icon>error</mat-icon>\n          {{errorMessage.getMinLengthMessage(propriedade.get('minLength').value)}}\n        </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.maxLength\">\n          <mat-icon>error</mat-icon>\n          {{errorMessage.getMaxLengthMessage(propriedade.get('maxLength').value)}}\n        </mat-error>\n\t      <mat-error *ngIf=\"propriedade.get('value').errors?.required\">\n\t        <mat-icon>error</mat-icon>\n          {{errorMessage.getRequiredMessage(propriedade.get('label').value)}}\n\t      </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n          <mat-icon>error</mat-icon>\n          {{propriedade.get('value').errors?.customError.message}}.\n        </mat-error>\n\t    </mat-form-field>\n\t\t  <mat-form-field\n\t\t\t  *ngIf=\"propriedade.get('type').value == typeField.textLogs\"\n\t\t\t  [appearance]=\"propriedade.get('appearance').value\"\n\t\t\t  [floatLabel]=\"propriedade.get('floatLabel').value\"\n\t\t\t  [formGroupName]=\"i\"\n\t\t\t  [ngClass]=\"propriedade.get('fieldClass').value\">\n\t      <mat-label>{{propriedade.get('label').value}}</mat-label>\n\t      <div [innerHTML]=\"propriedade.get('textLogs').value\" class=\"text-obs\"></div>\n\t      <textarea\n          #textarea\n\t\t      [koalaAutoFocus]=\"propriedade.get('focus').value\"\n          cdkTextareaAutosize\n          #autosize=\"cdkTextareaAutosize\"\n\t\t      [cdkAutosizeMaxRows]=\"8\"\n\t\t      [cdkAutosizeMinRows]=\"3\"\n\t\t      [required]=\"propriedade.get('required').value\"\n          [tabIndex]=\"tabIndexStart + i\"\n          [minLength]=\"propriedade.get('minLength').value\"\n          [maxLength]=\"propriedade.get('maxLength').value\"\n\t\t      formControlName=\"value\"\n\t\t      matInput>\n\t      </textarea>\n\t      <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n\t        <mat-icon>info</mat-icon>\n\t\t      {{propriedade.get('textHint').value}}\n\t      </mat-hint>\n        <mat-hint align=\"end\" *ngIf=\"propriedade.get('maxLength').value\">\n          {{textarea.value.length}}/{{propriedade.get('maxLength').value}}\n        </mat-hint>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.minLength\">\n          <mat-icon>error</mat-icon>\n          {{errorMessage.getMinLengthMessage(propriedade.get('minLength').value)}}\n        </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.maxLength\">\n          <mat-icon>error</mat-icon>\n          {{errorMessage.getMaxLengthMessage(propriedade.get('maxLength').value)}}\n        </mat-error>\n\t      <mat-error *ngIf=\"propriedade.get('value').errors?.required\">\n\t        <mat-icon>error</mat-icon>\n          {{errorMessage.getRequiredMessage(propriedade.get('label').value)}}\n\t      </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n          <mat-icon>error</mat-icon>\n          {{propriedade.get('value').errors?.customError.message}}.\n        </mat-error>\n\t    </mat-form-field>\n\t    <mat-form-field\n\t\t    *ngIf=\"propriedade.get('type').value == typeField.select\"\n\t\t    [appearance]=\"propriedade.get('appearance').value\"\n\t\t    [floatLabel]=\"propriedade.get('floatLabel').value\"\n\t\t    [formGroupName]=\"i\"\n\t\t    [ngClass]=\"propriedade.get('fieldClass').value\">\n\t      <mat-label>{{propriedade.get('label').value}}</mat-label>\n\t      <mat-select [multiple]=\"propriedade.get('multiple').value\" [required]=\"propriedade.get('required').value\"\n                    [tabIndex]=\"tabIndexStart + i\" formControlName=\"value\">\n\t        <mat-option *ngFor=\"let options of propriedade.get('opcoesSelect').value\" [value]=\"options.value\">\n\t          {{options.name}}\n\t        </mat-option>\n\t      </mat-select>\n\t      <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n\t        <mat-icon>info</mat-icon>\n\t\t      {{propriedade.get('textHint').value}}\n\t      </mat-hint>\n\t      <mat-error *ngIf=\"propriedade.get('value').errors?.required\">\n\t        <mat-icon>error</mat-icon>\n          {{errorMessage.getRequiredMessage(propriedade.get('label').value)}}\n\t      </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n          <mat-icon>error</mat-icon>\n          {{propriedade.get('value').errors?.customError.message}}.\n        </mat-error>\n\t    </mat-form-field>\n      <mat-form-field\n        class=\"select-multiple-native\"\n        *ngIf=\"propriedade.get('type').value == typeField.selectMultipleNative\"\n        [appearance]=\"propriedade.get('appearance').value\"\n        [floatLabel]=\"propriedade.get('floatLabel').value\"\n        [formGroupName]=\"i\"\n        [ngClass]=\"propriedade.get('fieldClass').value\">\n        <mat-label>{{propriedade.get('label').value}}</mat-label>\n        <select\n          matNativeControl\n          formControlName=\"value\"\n          multiple\n          [tabIndex]=\"tabIndexStart + i\"\n          [required]=\"propriedade.get('required').value\">\n          <option *ngFor=\"let options of propriedade.get('opcoesSelect').value\" [value]=\"options.value\">\n            {{options.name}}\n          </option>\n        </select>\n        <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n          <mat-icon>info</mat-icon>\n          {{propriedade.get('textHint').value}}\n        </mat-hint>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.required\">\n          <mat-icon>error</mat-icon>\n          {{errorMessage.getRequiredMessage(propriedade.get('label').value)}}\n        </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n          <mat-icon>error</mat-icon>\n          {{propriedade.get('value').errors?.customError.message}}.\n        </mat-error>\n      </mat-form-field>\n\t    <div\n\t\t    *ngIf=\"propriedade.get('type').value == typeField.checkbox\"\n\t\t    [formGroupName]=\"i\"\n\t\t    [ngClass]=\"propriedade.get('fieldClass').value\">\n\t      <mat-checkbox\n          [tabIndex]=\"tabIndexStart + i\"\n\t\t      formControlName=\"value\"\n\t\t      value=\"true\">\n\t        {{propriedade.get('label').value}}\n\t      </mat-checkbox>\n\t    </div>\n\t\t  <div\n\t\t\t  *ngIf=\"propriedade.get('type').value == typeField.moreItems\"\n\t\t\t  [formGroupName]=\"i\"\n\t\t\t  [ngClass]=\"propriedade.get('fieldClass').value\"\n\t\t\t  class=\"more-items-content\">\n\t\t\t  <fieldset>\n\t\t\t\t  <legend>\n\t\t\t\t\t  <koala-button\n\t\t\t\t\t\t  (click)=\"addMoreItem(i)\"\n\t\t\t\t\t\t  [disabled]=\"propriedade.get('moreItemsConfig').value.length === propriedade.get('moreItemsMaxItems').value\"\n\t\t\t\t\t\t  [tooltip]=\"propriedade.get('moreItemsButtonIconAddlabel').value\"\n\t\t\t\t\t\t  [backgroundColor]=\"propriedade.get('moreItemsIconBackgroundColor').value\"\n              [color]=\"propriedade.get('moreItemsIconFontColor').value\"\n\t\t\t\t\t\t  class=\"btn-add-more-items\"\n\t\t\t\t\t\t  icon=\"add\">\n\t\t\t\t\t  </koala-button>\n\t\t\t\t\t  {{propriedade.get('label').value}} (Min.: {{propriedade.get('moreItemsMinItems').value}}\n\t\t\t\t\t                                     | Máx.: {{propriedade.get('moreItemsMaxItems').value}})\n\t\t\t\t  </legend>\n\t\t\t\t  <mat-accordion class=\"items\" multi>\n\t\t\t\t\t  <mat-expansion-panel\n\t\t\t\t\t\t  *ngFor=\"let item of propriedade.get('moreItemsConfig').value.slice().reverse(); index as indexMoreItems\"\n\t\t\t\t\t\t  expanded>\n\t\t\t\t\t\t  <mat-expansion-panel-header>\n\t\t\t\t\t\t\t\t<mat-panel-title class=\"titleForm\">#\n\t\t\t\t\t\t\t\t\t{{propriedade.get('moreItemsConfig').value.length - 1 - indexMoreItems + 1}}</mat-panel-title>\n\t\t\t\t\t\t\t\t<mat-panel-description class=\"titleForm\">\n\t\t\t\t\t\t\t\t\t{{propriedade.get('label').value}}\n\t\t\t\t\t\t\t\t\t<mat-icon>{{propriedade.get('moreItemsIcon').value}}</mat-icon>\n\t\t\t\t\t\t\t\t</mat-panel-description>\n\t\t\t\t\t\t\t</mat-expansion-panel-header>\n\t\t\t\t\t\t  <koala-dynamic-form\n\t\t\t\t\t\t\t  [showFieldsMoreItensConfig]=\"item.showFieldsMoreItensConfig\"\n\t\t\t\t\t\t\t  [showFields]=\"item.showFields\"\n\t\t\t\t\t\t\t  [formConfig]=\"item.formConfig\"\n\t\t\t\t\t\t\t  [form]=\"item.form\"\n                [tabIndexStart]=\"tabIndexStart + i\">\n\t\t\t\t\t\t  </koala-dynamic-form>\n\t\t\t\t\t    <mat-action-row\n\t\t\t\t\t\t    *ngIf=\"propriedade.get('moreItemsConfig').value.length > propriedade.get('moreItemsMinItems').value\">\n\t\t\t\t\t      <button\n\t\t\t\t\t\t      (click)=\"removeMoreItem(i, propriedade.get('moreItemsConfig').value.length - 1 - indexMoreItems)\"\n\t\t\t\t\t\t      mat-icon-button>\n\t\t\t\t\t\t      <mat-icon>delete</mat-icon>\n\t\t\t\t\t      </button>\n\t\t\t\t\t    </mat-action-row>\n\t\t\t\t\t  </mat-expansion-panel>\n\t\t\t\t  </mat-accordion>\n\t\t\t  </fieldset>\n\t\t  </div>\n\t\t  <mat-form-field\n\t\t\t  *ngIf=\"propriedade.get('type').value == typeField.autocomplete\"\n\t\t\t  [appearance]=\"propriedade.get('appearance').value\"\n\t\t\t  [floatLabel]=\"propriedade.get('floatLabel').value\"\n\t\t\t  [formGroupName]=\"i\"\n\t\t\t  [ngClass]=\"propriedade.get('fieldClass').value\">\n\t      <mat-label>{{propriedade.get('label').value}} {{propriedade.get('multiple').value &&\n\t      propriedade.get('required').value ? '*' : ''}}</mat-label>\n\t\t\t  <div *ngIf=\"propriedade.get('multiple').value else single\">\n\t        <mat-chip-list #chipList>\n            <mat-chip\n              (removed)=\"removeOptionOnAutocomplete(i, option)\"\n              *ngFor=\"let option of propriedade.get('autocompleteSelectedValue').value\"\n              [color]=\"getColorChip(propriedade.get('autocompleteMultipleConfig').value | async)\"\n              [removable]=\"true\"\n              [selectable]=\"true\">\n              {{display(option)}}\n              <mat-icon *ngIf=\"!propriedade.get('disabled').value\" matChipRemove>cancel</mat-icon>\n            </mat-chip>\n\t          <input\n              [id]=\"'autocomplete-' + propriedade.get('name').value\"\n              [koalaAutoFocus]=\"propriedade.get('focus').value\"\n\t\t          [required]=\"propriedade.get('required').value\"\n\t\t          [matAutocomplete]=\"auto\"\n\t\t          [matChipInputFor]=\"chipList\"\n              [tabIndex]=\"tabIndexStart + i\"\n              [autocomplete]=\"getRandomString()\"\n\t\t          formControlName=\"value\"\n\t\t          matInput\n\t\t          type=\"text\"\n\t\t          placeholder=\"Selecione um ou mais opções...\">\n\t        </mat-chip-list>\n\t      </div>\n\t      <ng-template #single>\n\t\t      <input\n\t\t\t      [matAutocomplete]=\"auto\"\n            [koalaAutoFocus]=\"propriedade.get('focus').value\"\n\t\t\t      [required]=\"propriedade.get('required').value\"\n            [tabIndex]=\"tabIndexStart + i\"\n            [autocomplete]=\"getRandomString()\"\n\t\t\t      formControlName=\"value\"\n\t\t\t      matInput\n\t\t\t      placeholder=\"Selecione uma opção...\"\n\t\t\t      type=\"text\">\n\t      </ng-template>\n\t      <mat-spinner *ngIf=\"propriedade.get('autocompleteLoading').value | async\" color=\"primary\"\n\t                   matSuffix></mat-spinner>\n\t      <button\n\t\t      (click)=\"clearAutocomplete(i)\"\n\t\t      *ngIf=\"\n\t          !(propriedade.get('autocompleteLoading').value | async) &&\n\t          !propriedade.get('disabled').value\"\n\t\t      color=\"warn\"\n\t\t      mat-icon-button\n\t\t      matSuffix\n\t\t      type=\"button\">\n\t        <mat-icon>close</mat-icon>\n\t      </button>\n\t      <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n\t        <mat-icon>info</mat-icon>\n\t\t      {{propriedade.get('textHint').value}}\n\t      </mat-hint>\n\t      <mat-error *ngIf=\"propriedade.get('value').errors?.required || propriedade.get('value').errors?.autocompleteSelected\">\n\t        <mat-icon>error</mat-icon>\n          {{errorMessage.getAutocompleteMessage(propriedade.get('label').value)}}\n\t      </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n          <mat-icon>error</mat-icon>\n          {{propriedade.get('value').errors?.customError.message}}.\n        </mat-error>\n\t      <mat-autocomplete\n\t\t      #auto=\"matAutocomplete\"\n\t\t      [displayWith]=\"display\" autoActiveFirstOption>\n          <mat-option\n            *ngIf=\"propriedade.get('autocompleteAddOption').value && isValidNewAutocompleteOption(propriedade.get('value').value)\"\n            [value]=\"{\n              value: {id: 0, name: propriedade.get('value').value},\n              name: propriedade.get('value').value\n            }\">\n            Add <b>{{propriedade.get('value').value}}</b>...\n          </mat-option>\n\t\t      <div *ngIf=\"(getAutocompleteOptions(propriedade) | async) as options\">\n\t\t        <mat-option *ngFor=\"let option of options\" [value]=\"option\">\n\t\t          {{option.name}}\n\t\t        </mat-option>\n\t\t      </div>\n\t      </mat-autocomplete>\n\t    </mat-form-field>\n\t\t  <div *ngIf=\"propriedade.get('type').value == typeField.file\">\n\t\t\t  <koala-file-button\n\t\t\t\t  (getFiles)=\"propriedade.get('value').setValue($event)\"\n\t\t\t\t  [accept]=\"propriedade.get('fileButtonConfig').value.accept\"\n\t\t\t\t  [backgroundColor]=\"propriedade.get('fileButtonConfig').value.backgroundColor\"\n\t\t\t\t  [color]=\"propriedade.get('fileButtonConfig').value.color\"\n\t\t\t\t  [disabled]=\"propriedade.get('disabled').value\"\n\t\t\t\t  [icon]=\"propriedade.get('fileButtonConfig').value.icon\"\n\t\t\t\t  [multiple]=\"propriedade.get('multiple').value\"\n\t\t\t\t  [text]=\"propriedade.get('fileButtonConfig').value.text\">\n\t\t\t  </koala-file-button>\n\t\t  </div>\n\t\t  <div *ngIf=\"\n\t\t    propriedade.get('type').value == typeField.dynamicForm &&\n\t\t\t\t(getDynamicFormConfig(propriedade) | async) as dynamicFormConfig\">\n\t\t\t  <fieldset *ngIf=\"propriedade.get('label').value else dynamicFormWithoutLabel\">\n\t\t\t\t  <legend>{{propriedade.get('label').value}}</legend>\n\t\t\t\t  <koala-dynamic-form\n\t\t\t\t\t  [formConfig]=\"dynamicFormConfig.formConfig\"\n\t\t\t\t\t  [form]=\"dynamicFormConfig.form\"\n\t\t\t\t\t  [setValues]=\"dynamicFormConfig.setValues\"\n\t\t\t\t\t  [showFields]=\"dynamicFormConfig.showFields\"\n            [tabIndexStart]=\"tabIndexStart + i\">\n\t\t\t\t  </koala-dynamic-form>\n\t\t\t  </fieldset>\n\t\t\t  <ng-template #dynamicFormWithoutLabel>\n\t\t\t\t  <koala-dynamic-form\n\t\t\t\t\t  [formConfig]=\"dynamicFormConfig.formConfig\"\n\t\t\t\t\t  [form]=\"dynamicFormConfig.form\"\n\t\t\t\t\t  [setValues]=\"dynamicFormConfig.setValues\"\n\t\t\t\t\t  [showFields]=\"dynamicFormConfig.showFields\"\n            [tabIndexStart]=\"tabIndexStart + i\">\n\t\t\t\t  </koala-dynamic-form>\n\t\t\t  </ng-template>\n\t\t  </div>\n      <div\n        class=\"radio-btn-group\"\n        *ngIf=\"propriedade.get('type').value == typeField.radio\"\n        [formGroupName]=\"i\"\n        [ngClass]=\"propriedade.get('fieldClass').value\">\n        <mat-radio-group formControlName=\"value\">\n          <label *ngIf=\"propriedade.get('label').value\">{{propriedade.get('label').value}}</label>\n          <mat-radio-button\n            [tabIndex]=\"tabIndexStart + i\"\n            *ngFor=\"let options of propriedade.get('opcoesSelect').value\"\n            [value]=\"options.value\">\n            {{options.name}}\n          </mat-radio-button>\n        </mat-radio-group>\n      </div>\n\t  </div>\n  </div>\n  <ng-content select=\"[btn-submit]\"></ng-content>\n</div>\n"]}
|
|
1
|
+
import { Validators } from '@angular/forms';
|
|
2
|
+
import { DynamicFormTypeFieldEnum } from './enums/dynamic-form-type-field.enum';
|
|
3
|
+
import { CpfValidator } from './validators/cpf.validator';
|
|
4
|
+
import { CnpjValidator } from './validators/cnpj.validator';
|
|
5
|
+
import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
|
|
6
|
+
import { FormAbstract } from '../form.abstract';
|
|
7
|
+
import { debounceTime } from 'rxjs/operators';
|
|
8
|
+
import { BehaviorSubject } from 'rxjs';
|
|
9
|
+
import { AutocompleteSelectedValidator } from './validators/autocomplete-selected.validator';
|
|
10
|
+
import { delay } from "@koalarx/utils/operators/delay";
|
|
11
|
+
import { koala } from "@koalarx/utils";
|
|
12
|
+
import { DateMinValidator } from "./validators/date-min.validator";
|
|
13
|
+
import { DateMaxValidator } from "./validators/date-max.validator";
|
|
14
|
+
import { KoalaLanguageHelper } from "@koalarx/ui/core";
|
|
15
|
+
import { randomString } from "@koalarx/utils/operators/string";
|
|
16
|
+
import * as i0 from "@angular/core";
|
|
17
|
+
import * as i1 from "@angular/forms";
|
|
18
|
+
import * as i2 from "./koala.dynamic-form.service";
|
|
19
|
+
import * as i3 from "@angular/common";
|
|
20
|
+
import * as i4 from "ng2-currency-mask";
|
|
21
|
+
import * as i5 from "ngx-mask";
|
|
22
|
+
import * as i6 from "@koalarx/ui/file-button";
|
|
23
|
+
import * as i7 from "@angular/cdk/text-field";
|
|
24
|
+
import * as i8 from "@angular/material/form-field";
|
|
25
|
+
import * as i9 from "@angular/material/input";
|
|
26
|
+
import * as i10 from "@angular/material/select";
|
|
27
|
+
import * as i11 from "@angular/material/core";
|
|
28
|
+
import * as i12 from "@angular/material/radio";
|
|
29
|
+
import * as i13 from "@angular/material/checkbox";
|
|
30
|
+
import * as i14 from "@angular/material/autocomplete";
|
|
31
|
+
import * as i15 from "@angular/material/button";
|
|
32
|
+
import * as i16 from "@angular/material/icon";
|
|
33
|
+
import * as i17 from "@angular/material/expansion";
|
|
34
|
+
import * as i18 from "@angular/material/chips";
|
|
35
|
+
import * as i19 from "@koalarx/ui/button";
|
|
36
|
+
import * as i20 from "@angular/material/progress-spinner";
|
|
37
|
+
import * as i21 from "../directives/koala-autofocus.directive";
|
|
38
|
+
export class DynamicFormComponent extends FormAbstract {
|
|
39
|
+
constructor(fb, dynamicFormService) {
|
|
40
|
+
super(() => this.form);
|
|
41
|
+
this.fb = fb;
|
|
42
|
+
this.dynamicFormService = dynamicFormService;
|
|
43
|
+
this.tabIndexStart = 1;
|
|
44
|
+
this.typeField = DynamicFormTypeFieldEnum;
|
|
45
|
+
this.hoursAndMinutesMask = '00:000';
|
|
46
|
+
this.errorMessage = KoalaLanguageHelper;
|
|
47
|
+
this.formId = randomString(25, {
|
|
48
|
+
lowercase: true,
|
|
49
|
+
uppercase: true,
|
|
50
|
+
numbers: false,
|
|
51
|
+
specialCharacters: false
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
ngOnInit() {
|
|
55
|
+
if (!this.form.get('formData')) {
|
|
56
|
+
this.form.addControl('formData', this.fb.array([]));
|
|
57
|
+
}
|
|
58
|
+
this.controls = this.form.get('formData');
|
|
59
|
+
this.formConfig?.forEach((config, indexConfig) => {
|
|
60
|
+
const newFormGroup = this.newControl(config);
|
|
61
|
+
if (config.asyncValidators) {
|
|
62
|
+
newFormGroup.get('value').setAsyncValidators(config.asyncValidators);
|
|
63
|
+
}
|
|
64
|
+
newFormGroup.get('value').updateValueAndValidity();
|
|
65
|
+
if (config.type === DynamicFormTypeFieldEnum.dynamicForm) {
|
|
66
|
+
const formGroupDynamicFormsSubject = newFormGroup.get('dynamicFormConfig').value;
|
|
67
|
+
formGroupDynamicFormsSubject.subscribe(formGroupConfig => {
|
|
68
|
+
if (formGroupConfig) {
|
|
69
|
+
formGroupConfig.form.valueChanges.subscribe(() => {
|
|
70
|
+
if (formGroupConfig.form.valid && (config.valueChanges || this.showFieldsMoreItensConfig)) {
|
|
71
|
+
const value = this.dynamicFormService.emitData(formGroupConfig.form);
|
|
72
|
+
newFormGroup.get('value').setValue(value);
|
|
73
|
+
}
|
|
74
|
+
});
|
|
75
|
+
}
|
|
76
|
+
});
|
|
77
|
+
}
|
|
78
|
+
if (config.valueChanges ||
|
|
79
|
+
config.type === DynamicFormTypeFieldEnum.autocomplete ||
|
|
80
|
+
config.type === DynamicFormTypeFieldEnum.dynamicForm ||
|
|
81
|
+
this.showFieldsMoreItensConfig) {
|
|
82
|
+
if (config.type === DynamicFormTypeFieldEnum.autocomplete) {
|
|
83
|
+
const autocompleteOptionsSubject = newFormGroup.get('autocompleteOptions').value;
|
|
84
|
+
if (autocompleteOptionsSubject) {
|
|
85
|
+
autocompleteOptionsSubject.subscribe(options => newFormGroup.get('autocompleteOptionsFiltered').value.next(options));
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
newFormGroup.get('value')
|
|
89
|
+
.valueChanges
|
|
90
|
+
.pipe(debounceTime(300))
|
|
91
|
+
.subscribe(async (value) => {
|
|
92
|
+
await this.setConfigDynamicForm(newFormGroup);
|
|
93
|
+
if (config.type === DynamicFormTypeFieldEnum.autocomplete) {
|
|
94
|
+
if (value && (value.hasOwnProperty('value') &&
|
|
95
|
+
value.hasOwnProperty('name') &&
|
|
96
|
+
Object.keys(value).length === 2) || (Array.isArray(value) &&
|
|
97
|
+
newFormGroup.get('multiple').value)) {
|
|
98
|
+
if (newFormGroup.get('multiple').value) {
|
|
99
|
+
if (Array.isArray(value)) {
|
|
100
|
+
newFormGroup.get('autocompleteSelectedValue').setValue(value);
|
|
101
|
+
newFormGroup.get('value').setValue(value[value.length - 1], { emitEvent: false });
|
|
102
|
+
}
|
|
103
|
+
else {
|
|
104
|
+
if (this.validateAutocompleteSelect(newFormGroup.get('autocompleteSelectedValue').value, value)) {
|
|
105
|
+
newFormGroup.get('autocompleteSelectedValue').value.push(value);
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
const autocompleteInput = document.querySelector(`#${this.formId} input#autocomplete-${newFormGroup.get('name')?.value}`);
|
|
109
|
+
if (autocompleteInput) {
|
|
110
|
+
autocompleteInput.value = '';
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
else {
|
|
114
|
+
newFormGroup.get('autocompleteSelectedValue').setValue(value);
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
else if (!newFormGroup.get('multiple').value) {
|
|
118
|
+
newFormGroup.get('autocompleteSelectedValue').setValue(koala(this.formConfig)
|
|
119
|
+
.array()
|
|
120
|
+
.filter(newFormGroup.get('name').value, 'name')
|
|
121
|
+
.getValue()[0]?.autocompleteDefaultValueOnClear ?? null);
|
|
122
|
+
}
|
|
123
|
+
if (config.type === DynamicFormTypeFieldEnum.autocomplete) {
|
|
124
|
+
if (config.autocompleteType === 'all') {
|
|
125
|
+
const autocompleteOptionsSubject = newFormGroup.get('autocompleteOptions').value;
|
|
126
|
+
newFormGroup.get('autocompleteOptionsFiltered').value.next(this.autocompleteFilter(autocompleteOptionsSubject.value, value));
|
|
127
|
+
}
|
|
128
|
+
else if (config.autocompleteType === 'onDemand' && typeof value !== "object") {
|
|
129
|
+
const loader = newFormGroup.get('autocompleteLoading').value;
|
|
130
|
+
loader.next(true);
|
|
131
|
+
config.autocompleteFilter(value).subscribe(options => {
|
|
132
|
+
newFormGroup.get('autocompleteOptionsFiltered').value.next(options);
|
|
133
|
+
loader.next(false);
|
|
134
|
+
});
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
if (config.valueChanges) {
|
|
139
|
+
if (config.type === DynamicFormTypeFieldEnum.autocomplete) {
|
|
140
|
+
config.valueChanges((newFormGroup.get('multiple').value ?
|
|
141
|
+
newFormGroup.get('autocompleteSelectedValue').value.map(item => item.value) :
|
|
142
|
+
newFormGroup.get('autocompleteSelectedValue').value?.value));
|
|
143
|
+
}
|
|
144
|
+
else {
|
|
145
|
+
config.valueChanges(value);
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
});
|
|
149
|
+
}
|
|
150
|
+
this.controls.push(newFormGroup);
|
|
151
|
+
if (config.moreItemsConfig) {
|
|
152
|
+
if (config.moreItemsMinItems > 0) {
|
|
153
|
+
for (let min = 0; min < config.moreItemsMinItems; min++) {
|
|
154
|
+
if (min <= config.moreItemsMaxItems) {
|
|
155
|
+
this.addMoreItem(indexConfig);
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
if (config.moreItemsConfig.setValues) {
|
|
160
|
+
config.moreItemsConfig
|
|
161
|
+
.setValues
|
|
162
|
+
.subscribe(async (values) => {
|
|
163
|
+
if (values.length > 0) {
|
|
164
|
+
values.forEach((itemValue, indexValue) => {
|
|
165
|
+
if (!this.controls.controls[indexConfig].get('moreItemsConfig').value[indexValue]) {
|
|
166
|
+
this.addMoreItem(indexConfig);
|
|
167
|
+
}
|
|
168
|
+
setTimeout(() => {
|
|
169
|
+
this.setValuesOnFields(itemValue, this.controls.controls[indexConfig].get('moreItemsConfig').value[indexValue].form);
|
|
170
|
+
}, 300);
|
|
171
|
+
});
|
|
172
|
+
}
|
|
173
|
+
});
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
});
|
|
177
|
+
if (this.showFields) {
|
|
178
|
+
this.changeVisibilityFields(this.showFields, this.form);
|
|
179
|
+
}
|
|
180
|
+
if (this.setValues) {
|
|
181
|
+
this.setValuesOnFields(this.setValues, this.form);
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
isValidNewAutocompleteOption(value) {
|
|
185
|
+
return !!value && typeof value === 'string';
|
|
186
|
+
}
|
|
187
|
+
hoursAndMinutesApplyMask(index, event) {
|
|
188
|
+
const control = this.controls?.controls[index];
|
|
189
|
+
const type = control?.get('type').value;
|
|
190
|
+
if (type === DynamicFormTypeFieldEnum.hoursAndMinutes) {
|
|
191
|
+
const value = control?.get('value').value;
|
|
192
|
+
if (event.key == 'Backspace' && value.length < 6) {
|
|
193
|
+
this.hoursAndMinutesMask = '00:000';
|
|
194
|
+
}
|
|
195
|
+
else if (event.key != 'Backspace' && value.length >= 6) {
|
|
196
|
+
this.hoursAndMinutesMask = '000:00';
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
passwordView(index) {
|
|
201
|
+
const control = this.controls?.controls[index];
|
|
202
|
+
const hidePassword = !control?.get('hidePassword').value;
|
|
203
|
+
control?.get('hidePassword').setValue(hidePassword);
|
|
204
|
+
control?.get('type').setValue(hidePassword ?
|
|
205
|
+
DynamicFormTypeFieldEnum.password :
|
|
206
|
+
DynamicFormTypeFieldEnum.text);
|
|
207
|
+
}
|
|
208
|
+
addMoreItem(propIndex) {
|
|
209
|
+
if (this.controls.controls[propIndex].get('moreItemsConfig').value.length < this.controls.controls[propIndex].get('moreItemsMaxItems').value) {
|
|
210
|
+
const formGroup = this.fb.group({});
|
|
211
|
+
this.controls.controls[propIndex].get('moreItemsConfig').value.push({
|
|
212
|
+
form: formGroup,
|
|
213
|
+
formConfig: this.formConfig[propIndex].moreItemsConfig.formConfig,
|
|
214
|
+
showFields: new BehaviorSubject([]),
|
|
215
|
+
showFieldsMoreItensConfig: this.formConfig[propIndex].moreItemsConfig.showFieldsConfig
|
|
216
|
+
});
|
|
217
|
+
this.controls.controls[propIndex].get('moreItemsExpanded').setValue(this.controls.controls[propIndex].get('moreItemsConfig').value.length - 1);
|
|
218
|
+
const formArrayMoreItems = this.controls.controls[propIndex].get('moreItemsFormGroup');
|
|
219
|
+
formArrayMoreItems.push(formGroup);
|
|
220
|
+
}
|
|
221
|
+
}
|
|
222
|
+
removeMoreItem(propIndex, removeIndex) {
|
|
223
|
+
const expandedItemIndex = removeIndex - 1;
|
|
224
|
+
this.controls.controls[propIndex].get('moreItemsConfig').value.splice(removeIndex, 1);
|
|
225
|
+
setTimeout(() => {
|
|
226
|
+
this.controls.controls[propIndex].get('moreItemsExpanded').setValue((expandedItemIndex < 0) ? 0 : expandedItemIndex);
|
|
227
|
+
}, 50);
|
|
228
|
+
}
|
|
229
|
+
clearAutocomplete(propIndex) {
|
|
230
|
+
if (this.controls.controls[propIndex].get('multiple').value) {
|
|
231
|
+
this.controls.controls[propIndex].get('autocompleteSelectedValue').setValue([]);
|
|
232
|
+
this.controls.controls[propIndex].get('value').setValue(null);
|
|
233
|
+
}
|
|
234
|
+
else {
|
|
235
|
+
this.controls.controls[propIndex].get('autocompleteSelectedValue').setValue(this.formConfig[propIndex].autocompleteDefaultValueOnClear ?? null);
|
|
236
|
+
this.controls.controls[propIndex].get('value').setValue(this.formConfig[propIndex].autocompleteDefaultValueOnClear ?? null);
|
|
237
|
+
}
|
|
238
|
+
}
|
|
239
|
+
display(option) {
|
|
240
|
+
return option ? option.name : undefined;
|
|
241
|
+
}
|
|
242
|
+
removeOptionOnAutocomplete(propIndex, option) {
|
|
243
|
+
const value = this.controls.controls[propIndex].get('autocompleteSelectedValue').value.filter(item => item !== option);
|
|
244
|
+
this.controls.controls[propIndex].get('autocompleteSelectedValue').setValue(value);
|
|
245
|
+
if (value.length === 0) {
|
|
246
|
+
this.controls.controls[propIndex].get('autocompleteSelectedValue').setValue([]);
|
|
247
|
+
this.controls.controls[propIndex].get('value').setValue(null);
|
|
248
|
+
}
|
|
249
|
+
else if (this.formConfig[propIndex].valueChanges) {
|
|
250
|
+
this.formConfig[propIndex].valueChanges(value.map(item => item.value));
|
|
251
|
+
}
|
|
252
|
+
}
|
|
253
|
+
getColorChip(config) {
|
|
254
|
+
return config.color;
|
|
255
|
+
}
|
|
256
|
+
getAutocompleteOptions(propriedade) {
|
|
257
|
+
return propriedade.get('autocompleteOptionsFiltered').value;
|
|
258
|
+
}
|
|
259
|
+
getDynamicFormConfig(propriedade) {
|
|
260
|
+
return propriedade.get('dynamicFormConfig').value;
|
|
261
|
+
}
|
|
262
|
+
getRandomString() {
|
|
263
|
+
return randomString(20, {
|
|
264
|
+
lowercase: true,
|
|
265
|
+
numbers: true,
|
|
266
|
+
specialCharacters: false,
|
|
267
|
+
uppercase: true
|
|
268
|
+
});
|
|
269
|
+
}
|
|
270
|
+
newControl(config) {
|
|
271
|
+
let validators = config.syncValidators ?? [];
|
|
272
|
+
let value = config.value ?? '';
|
|
273
|
+
let valueSelectedAutocomplete = (config.multiple ? [] : (config.autocompleteDefaultValueOnClear ?? null));
|
|
274
|
+
if (config.required === true)
|
|
275
|
+
validators.push(Validators.required);
|
|
276
|
+
if (config.min && typeof config.min === "number")
|
|
277
|
+
validators.push(Validators.min(config.min));
|
|
278
|
+
if (config.max && typeof config.max === "number")
|
|
279
|
+
validators.push(Validators.max(config.max));
|
|
280
|
+
if (config.type === DynamicFormTypeFieldEnum.date ||
|
|
281
|
+
config.type === DynamicFormTypeFieldEnum.datetime ||
|
|
282
|
+
config.type === DynamicFormTypeFieldEnum.time) {
|
|
283
|
+
if (config.min && typeof config.min === "string") {
|
|
284
|
+
validators.push(DateMinValidator(config.min));
|
|
285
|
+
}
|
|
286
|
+
if (config.max && typeof config.max === "string") {
|
|
287
|
+
validators.push(DateMaxValidator(config.max));
|
|
288
|
+
}
|
|
289
|
+
}
|
|
290
|
+
if (config.minLength)
|
|
291
|
+
validators.push(Validators.minLength(config.minLength));
|
|
292
|
+
if (config.maxLength)
|
|
293
|
+
validators.push(Validators.maxLength(config.maxLength));
|
|
294
|
+
if (config.type === DynamicFormTypeFieldEnum.cpf) {
|
|
295
|
+
validators.push(CpfValidator);
|
|
296
|
+
}
|
|
297
|
+
else if (config.type === DynamicFormTypeFieldEnum.cnpj) {
|
|
298
|
+
validators.push(CnpjValidator);
|
|
299
|
+
}
|
|
300
|
+
else if (config.type === DynamicFormTypeFieldEnum.email) {
|
|
301
|
+
validators.push(Validators.email);
|
|
302
|
+
}
|
|
303
|
+
else if (config.type === DynamicFormTypeFieldEnum.autocomplete) {
|
|
304
|
+
if (value) {
|
|
305
|
+
valueSelectedAutocomplete = value;
|
|
306
|
+
value = (config.multiple ? valueSelectedAutocomplete[0] : value);
|
|
307
|
+
}
|
|
308
|
+
if (config.required === true) {
|
|
309
|
+
validators.push(AutocompleteSelectedValidator);
|
|
310
|
+
}
|
|
311
|
+
}
|
|
312
|
+
else if (config.type === DynamicFormTypeFieldEnum.checkbox) {
|
|
313
|
+
value = config.value ?? false;
|
|
314
|
+
}
|
|
315
|
+
if (config.type === DynamicFormTypeFieldEnum.hoursAndMinutes &&
|
|
316
|
+
value.length >= 6) {
|
|
317
|
+
this.hoursAndMinutesMask = '000:00';
|
|
318
|
+
}
|
|
319
|
+
if (config.dynamicFormConfig) {
|
|
320
|
+
const cloneDynamicFormConfig = {};
|
|
321
|
+
Object.assign(cloneDynamicFormConfig, config.dynamicFormConfig);
|
|
322
|
+
cloneDynamicFormConfig.form = config.dynamicFormConfig.form;
|
|
323
|
+
config.dynamicFormConfig = cloneDynamicFormConfig;
|
|
324
|
+
}
|
|
325
|
+
if (config.show === false) {
|
|
326
|
+
validators = [];
|
|
327
|
+
}
|
|
328
|
+
const field = this.fb.group({
|
|
329
|
+
show: [new BehaviorSubject(config.show ?? true)],
|
|
330
|
+
label: [config.label],
|
|
331
|
+
name: [config.name],
|
|
332
|
+
type: [config.type],
|
|
333
|
+
fileButtonConfig: [{
|
|
334
|
+
icon: config?.fileButtonConfig?.icon ?? 'attach_file',
|
|
335
|
+
text: config?.fileButtonConfig?.text ?? 'Clique para anexar arquivos',
|
|
336
|
+
backgroundColor: config?.fileButtonConfig?.backgroundColor ?? 'white',
|
|
337
|
+
color: config?.fileButtonConfig?.color ?? 'blue',
|
|
338
|
+
accept: config?.fileButtonConfig?.accept ?? '*'
|
|
339
|
+
}],
|
|
340
|
+
dynamicFormConfig: [new BehaviorSubject(config.dynamicFormConfig)],
|
|
341
|
+
dynamicFormGroup: this.fb.array([]),
|
|
342
|
+
appearance: [config.appearance],
|
|
343
|
+
floatLabel: [config.floatLabel],
|
|
344
|
+
placeholder: [config.placeholder],
|
|
345
|
+
class: [config.class],
|
|
346
|
+
fieldClass: [config.fieldClass],
|
|
347
|
+
textHint: [config.textHint],
|
|
348
|
+
required: [config.required ?? false],
|
|
349
|
+
min: [config.min ?? 0],
|
|
350
|
+
max: [config.max ?? 99999999999],
|
|
351
|
+
minLength: [config.minLength ?? 0],
|
|
352
|
+
maxLength: [config.maxLength ?? 255],
|
|
353
|
+
disabled: [config.disabled ?? false],
|
|
354
|
+
focus: [config.focus ?? false],
|
|
355
|
+
multiple: [config.multiple ?? false],
|
|
356
|
+
opcoesSelect: [config.opcoesSelect ?? []],
|
|
357
|
+
hidePassword: config.type === DynamicFormTypeFieldEnum.password ? true : null,
|
|
358
|
+
moreItemsButtonIconAddlabel: [config.moreItemsButtonIconAddlabel],
|
|
359
|
+
moreItemsMinItems: [config.moreItemsMinItems ?? 0],
|
|
360
|
+
moreItemsMaxItems: [config.moreItemsMaxItems ?? 100],
|
|
361
|
+
moreItemsIcon: [config.moreItemsIcon],
|
|
362
|
+
moreItemsIconFontColor: [config.moreItemsIconFontColor],
|
|
363
|
+
moreItemsIconBackgroundColor: [config.moreItemsIconBackgroundColor],
|
|
364
|
+
moreItemsExpanded: [''],
|
|
365
|
+
moreItemsConfig: [[]],
|
|
366
|
+
moreItemsFormGroup: this.fb.array([]),
|
|
367
|
+
autocompleteLoading: [new BehaviorSubject(false)],
|
|
368
|
+
autocompleteOptions: [config.autocompleteOptions],
|
|
369
|
+
autocompleteMultipleConfig: [config.autocompleteMultipleConfig],
|
|
370
|
+
autocompleteOptionsFiltered: [new BehaviorSubject([])],
|
|
371
|
+
autocompleteSelectedValue: [valueSelectedAutocomplete],
|
|
372
|
+
autocompleteAddOption: [config.autocompleteAddOption],
|
|
373
|
+
textLogs: [config?.textObs],
|
|
374
|
+
customMasc: [config?.customMasc],
|
|
375
|
+
customMascThousandSeparator: [config?.customMascThousandSeparator ?? ''],
|
|
376
|
+
customMascSuffix: [config?.customMascSuffix ?? ''],
|
|
377
|
+
customMascPrefix: [config?.customMascPrefix ?? ''],
|
|
378
|
+
value: [{ value, disabled: config.disabled }, validators, config.asyncValidators]
|
|
379
|
+
});
|
|
380
|
+
if (config.autocompleteType === "onDemand") {
|
|
381
|
+
const loader = field.get('autocompleteLoading').value;
|
|
382
|
+
loader.next(true);
|
|
383
|
+
config.autocompleteFilter('').subscribe(options => {
|
|
384
|
+
field.get('autocompleteOptionsFiltered').value.next(options);
|
|
385
|
+
loader.next(false);
|
|
386
|
+
});
|
|
387
|
+
}
|
|
388
|
+
return field;
|
|
389
|
+
}
|
|
390
|
+
setValuesOnFields(subject, form) {
|
|
391
|
+
subject.subscribe(item => {
|
|
392
|
+
if (item) {
|
|
393
|
+
const formArray = form.get('formData');
|
|
394
|
+
for (const prop of item.values()) {
|
|
395
|
+
this.setValueByProp(formArray, prop);
|
|
396
|
+
}
|
|
397
|
+
}
|
|
398
|
+
});
|
|
399
|
+
}
|
|
400
|
+
changeVisibilityFields(subject, form) {
|
|
401
|
+
subject.pipe(debounceTime(5)).subscribe(item => {
|
|
402
|
+
if (item) {
|
|
403
|
+
const formArray = form.get('formData');
|
|
404
|
+
for (const prop of item.values()) {
|
|
405
|
+
for (const [indexControl, control] of formArray.controls.entries()) {
|
|
406
|
+
if (control.get('name').value === prop.name) {
|
|
407
|
+
control.get('show').value.next(prop.show);
|
|
408
|
+
const config = this.formConfig[indexControl] ?? null;
|
|
409
|
+
if (prop.show) {
|
|
410
|
+
let validators = [];
|
|
411
|
+
if (config) {
|
|
412
|
+
if (config.type === DynamicFormTypeFieldEnum.dynamicForm) {
|
|
413
|
+
const formArrayMoreItems = control.get('dynamicFormGroup');
|
|
414
|
+
formArrayMoreItems.push(config?.dynamicFormConfig?.form);
|
|
415
|
+
}
|
|
416
|
+
else {
|
|
417
|
+
validators = config.syncValidators ?? [];
|
|
418
|
+
if (config.required === true) {
|
|
419
|
+
validators.push(Validators.required);
|
|
420
|
+
}
|
|
421
|
+
if (config.type === DynamicFormTypeFieldEnum.cpf) {
|
|
422
|
+
validators.push(CpfValidator);
|
|
423
|
+
}
|
|
424
|
+
else if (config.type === DynamicFormTypeFieldEnum.cnpj) {
|
|
425
|
+
validators.push(CnpjValidator);
|
|
426
|
+
}
|
|
427
|
+
else if (config.type === DynamicFormTypeFieldEnum.email) {
|
|
428
|
+
validators.push(Validators.email);
|
|
429
|
+
}
|
|
430
|
+
else if (config.required === true &&
|
|
431
|
+
config.type === DynamicFormTypeFieldEnum.autocomplete) {
|
|
432
|
+
validators.push(AutocompleteSelectedValidator);
|
|
433
|
+
}
|
|
434
|
+
if (config.min && typeof config.min === "number")
|
|
435
|
+
validators.push(Validators.min(config.min));
|
|
436
|
+
if (config.max && typeof config.max === "number")
|
|
437
|
+
validators.push(Validators.max(config.max));
|
|
438
|
+
if (config.type === DynamicFormTypeFieldEnum.date ||
|
|
439
|
+
config.type === DynamicFormTypeFieldEnum.datetime ||
|
|
440
|
+
config.type === DynamicFormTypeFieldEnum.time) {
|
|
441
|
+
if (config.min && typeof config.min === "string") {
|
|
442
|
+
validators.push(DateMinValidator(config.min));
|
|
443
|
+
}
|
|
444
|
+
if (config.max && typeof config.max === "string") {
|
|
445
|
+
validators.push(DateMaxValidator(config.max));
|
|
446
|
+
}
|
|
447
|
+
}
|
|
448
|
+
if (config.minLength)
|
|
449
|
+
validators.push(Validators.minLength(config.minLength));
|
|
450
|
+
if (config.maxLength)
|
|
451
|
+
validators.push(Validators.maxLength(config.maxLength));
|
|
452
|
+
control.get('value').setValidators(validators);
|
|
453
|
+
if (config.asyncValidators) {
|
|
454
|
+
control.get('value').setAsyncValidators(config.asyncValidators);
|
|
455
|
+
}
|
|
456
|
+
}
|
|
457
|
+
control.get('value').updateValueAndValidity();
|
|
458
|
+
if (prop.clearCurrentValue) {
|
|
459
|
+
control.get('value').setValue(null);
|
|
460
|
+
}
|
|
461
|
+
}
|
|
462
|
+
}
|
|
463
|
+
else {
|
|
464
|
+
control.get('value').clearValidators();
|
|
465
|
+
control.get('value').clearAsyncValidators();
|
|
466
|
+
control.setErrors(null);
|
|
467
|
+
control.get('value').setValue(null);
|
|
468
|
+
control.get('value').updateValueAndValidity();
|
|
469
|
+
if (config.type === DynamicFormTypeFieldEnum.dynamicForm) {
|
|
470
|
+
const formGroup = control;
|
|
471
|
+
formGroup.removeControl('dynamicFormGroup');
|
|
472
|
+
formGroup.addControl('dynamicFormGroup', this.fb.array([]));
|
|
473
|
+
}
|
|
474
|
+
}
|
|
475
|
+
break;
|
|
476
|
+
}
|
|
477
|
+
}
|
|
478
|
+
}
|
|
479
|
+
}
|
|
480
|
+
});
|
|
481
|
+
}
|
|
482
|
+
autocompleteFilter(arr, value) {
|
|
483
|
+
return arr.filter(filter => {
|
|
484
|
+
if (typeof value === 'string') {
|
|
485
|
+
if (filter) {
|
|
486
|
+
let find = true;
|
|
487
|
+
value.toLowerCase()
|
|
488
|
+
.split(' ')
|
|
489
|
+
.forEach(part => {
|
|
490
|
+
if (filter.name.toLowerCase().indexOf(part) < 0) {
|
|
491
|
+
find = false;
|
|
492
|
+
return false;
|
|
493
|
+
}
|
|
494
|
+
});
|
|
495
|
+
return find;
|
|
496
|
+
}
|
|
497
|
+
}
|
|
498
|
+
else {
|
|
499
|
+
return true;
|
|
500
|
+
}
|
|
501
|
+
});
|
|
502
|
+
}
|
|
503
|
+
setValueByProp(formArray, prop) {
|
|
504
|
+
if (formArray) {
|
|
505
|
+
if (prop.name.indexOf(' > ') >= 0) {
|
|
506
|
+
let dynamicFormSubject;
|
|
507
|
+
const arrPropName = prop.name.split(' > ');
|
|
508
|
+
let indexPropName = 0;
|
|
509
|
+
do {
|
|
510
|
+
const control = formArray.controls.find(control => control.get('name').value === arrPropName[indexPropName]);
|
|
511
|
+
if (indexPropName === arrPropName.length - 2) {
|
|
512
|
+
dynamicFormSubject = control.get('dynamicFormConfig').value;
|
|
513
|
+
const dynamicForm = dynamicFormSubject.getValue();
|
|
514
|
+
if (dynamicForm.formConfig.find(fc => fc.name === arrPropName[arrPropName.length - 1])) {
|
|
515
|
+
if (dynamicForm.setValues) {
|
|
516
|
+
dynamicForm.setValues.next(koala(dynamicForm.setValues.getValue()).array().merge([{
|
|
517
|
+
name: arrPropName[arrPropName.length - 1],
|
|
518
|
+
value: prop.value
|
|
519
|
+
}]).getValue());
|
|
520
|
+
}
|
|
521
|
+
else {
|
|
522
|
+
dynamicForm.setValues = new BehaviorSubject([{
|
|
523
|
+
name: arrPropName[arrPropName.length - 1],
|
|
524
|
+
value: prop.value
|
|
525
|
+
}]);
|
|
526
|
+
}
|
|
527
|
+
}
|
|
528
|
+
}
|
|
529
|
+
indexPropName++;
|
|
530
|
+
} while (indexPropName < arrPropName.length - 1);
|
|
531
|
+
}
|
|
532
|
+
else {
|
|
533
|
+
for (const control of formArray.controls.values()) {
|
|
534
|
+
if (control.get('name').value === prop.name) {
|
|
535
|
+
control.get('value').setValue(prop.value);
|
|
536
|
+
break;
|
|
537
|
+
}
|
|
538
|
+
}
|
|
539
|
+
}
|
|
540
|
+
}
|
|
541
|
+
}
|
|
542
|
+
async setConfigDynamicForm(newFormGroup) {
|
|
543
|
+
if (this.showFieldsMoreItensConfig) {
|
|
544
|
+
const value = newFormGroup.get('value').value;
|
|
545
|
+
const configs = this.showFieldsMoreItensConfig
|
|
546
|
+
.filter(config => config.nameField === newFormGroup.get('name').value)
|
|
547
|
+
.sort(config => {
|
|
548
|
+
if (config.fnShow(value)) {
|
|
549
|
+
return 1;
|
|
550
|
+
}
|
|
551
|
+
return -1;
|
|
552
|
+
});
|
|
553
|
+
for (const config of configs) {
|
|
554
|
+
if (config) {
|
|
555
|
+
if (config.dynamicFormConfig && config.fnShow(value)) {
|
|
556
|
+
const controlDynamicFormConfig = this.controls
|
|
557
|
+
.controls
|
|
558
|
+
.find(control => config.fieldsToShow.indexOf(control.get('name').value) >= 0);
|
|
559
|
+
const dynamicFormConfigSubject = controlDynamicFormConfig.get('dynamicFormConfig').value;
|
|
560
|
+
dynamicFormConfigSubject.next(null);
|
|
561
|
+
await delay(1);
|
|
562
|
+
dynamicFormConfigSubject.next(config.dynamicFormConfig(value));
|
|
563
|
+
}
|
|
564
|
+
this.dynamicFormService.showFields(this.showFields, config.fieldsToShow, config.fnShow(value), config.clearCurrentValue);
|
|
565
|
+
}
|
|
566
|
+
}
|
|
567
|
+
}
|
|
568
|
+
}
|
|
569
|
+
validateAutocompleteSelect(selectedValues, value) {
|
|
570
|
+
let isValid = true;
|
|
571
|
+
for (const selectedItem of selectedValues.values()) {
|
|
572
|
+
if (selectedItem.name === value.name) {
|
|
573
|
+
isValid = false;
|
|
574
|
+
break;
|
|
575
|
+
}
|
|
576
|
+
}
|
|
577
|
+
return isValid;
|
|
578
|
+
}
|
|
579
|
+
}
|
|
580
|
+
DynamicFormComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: DynamicFormComponent, deps: [{ token: i1.UntypedFormBuilder }, { token: i2.KoalaDynamicFormService }], target: i0.ɵɵFactoryTarget.Component });
|
|
581
|
+
DynamicFormComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: DynamicFormComponent, selector: "koala-dynamic-form", inputs: { form: "form", formConfig: "formConfig", showFields: "showFields", showFieldsMoreItensConfig: "showFieldsMoreItensConfig", setValues: "setValues", tabIndexStart: "tabIndexStart" }, usesInheritance: true, ngImport: i0, template: "<div [formGroup]=\"form\" class=\"p-relative w-100\" [id]=\"formId\">\n <div *ngFor=\"let propriedade of controls?.controls; let i = index;\"\n [ngClass]=\"(propriedade.get('show').value | async) ? propriedade.get('class').value : 'd-none'\"\n formArrayName=\"formData\">\n\t <div *ngIf=\"propriedade.get('show').value | async\">\n\t <mat-form-field\n\t\t *ngIf=\"propriedade.get('type').value == typeField.text ||\n\t propriedade.get('type').value == typeField.password ||\n\t propriedade.get('type').value == typeField.cpf ||\n\t propriedade.get('type').value == typeField.cnpj ||\n\t propriedade.get('type').value == typeField.datetime ||\n\t propriedade.get('type').value == typeField.email ||\n\t propriedade.get('type').value == typeField.number ||\n\t propriedade.get('type').value == typeField.stringNumber ||\n\t propriedade.get('type').value == typeField.time ||\n\t propriedade.get('type').value == typeField.date ||\n\t propriedade.get('type').value == typeField.hoursAndMinutes ||\n\t propriedade.get('type').value == typeField.phone ||\n\t propriedade.get('type').value == typeField.percent ||\n\t propriedade.get('type').value == typeField.color ||\n\t propriedade.get('type').value == typeField.month ||\n\t propriedade.get('type').value == typeField.competenceDate ||\n propriedade.get('type').value == typeField.stringWithCustomMasc\"\n\t\t [appearance]=\"propriedade.get('appearance').value\"\n\t\t [floatLabel]=\"propriedade.get('floatLabel').value\"\n\t\t [formGroupName]=\"i\"\n\t\t [ngClass]=\"propriedade.get('fieldClass').value\">\n\t <mat-label>{{propriedade.get('label').value}}</mat-label>\n\t <input\n\t\t [dropSpecialCharacters]=\"false\"\n\t\t [koalaAutoFocus]=\"propriedade.get('focus').value\"\n\t\t (keyup)=\"hoursAndMinutesApplyMask(i, $event)\"\n\t\t [required]=\"propriedade.get('required').value\"\n\t\t [tabIndex]=\"tabIndexStart + i\"\n\t\t [mask]=\"((propriedade.get('type').value == typeField.competenceDate) ? '00/0000' : null) ||\n\t\t ((propriedade.get('type').value == typeField.phone) ? '(00)0000-0000?0' : null) ||\n\t\t ((propriedade.get('type').value == typeField.stringNumber) ? '0{'+propriedade.get('maxLength').value+'}' : null) ||\n ((propriedade.get('type').value == typeField.cpf) ? '000.000.000-00' : null) ||\n ((propriedade.get('type').value == typeField.cnpj) ? '00.000.000/0000-00' : null) ||\n ((propriedade.get('type').value == typeField.percent) ? 'percent' : null) ||\n\t\t\t\t\t\t\t\t\t((propriedade.get('type').value == typeField.hoursAndMinutes) ? hoursAndMinutesMask : null) ||\n\t\t\t\t\t\t\t\t\t((propriedade.get('type').value == typeField.stringWithCustomMasc) ? propriedade.get('customMasc').value : null)\"\n\t\t [validation]=\"\n\t (propriedade.get('type').value == typeField.cpf && propriedade.get('value').errors?.cpfInvalid) ||\n\t (propriedade.get('type').value == typeField.cnpj && propriedade.get('value').errors?.cnpjInvalid)\"\n\t\t [type]=\"((propriedade.get('type').value == typeField.cpf ||\n propriedade.get('type').value == typeField.cnpj ||\n propriedade.get('type').value == typeField.phone ||\n propriedade.get('type').value == typeField.percent\n )) ? 'tel' : (\n propriedade.get('type').value == typeField.month ?\n 'month' : (\n propriedade.get('type').value == typeField.date ?\n 'date' : (\n propriedade.get('type').value == typeField.datetime ?\n 'datetime-local' : (\n propriedade.get('type').value == typeField.email ?\n 'email' : (\n propriedade.get('type').value == typeField.number ?\n 'number' : (\n propriedade.get('type').value == typeField.time ?\n 'time' : (\n propriedade.get('type').value == typeField.password ?\n 'password' : (\n propriedade.get('type').value == typeField.color ?\n 'color' : 'text'))))))))\"\n [min]=\"propriedade.get('min').value\"\n [max]=\"propriedade.get('max').value\"\n [minLength]=\"propriedade.get('minLength').value\"\n [maxLength]=\"propriedade.get('maxLength').value\"\n [thousandSeparator]=\"propriedade.get('customMascThousandSeparator').value\"\n [suffix]=\"propriedade.get('customMascSuffix').value\"\n [prefix]=\"propriedade.get('customMascPrefix').value\"\n separatorLimit=\"0\"\n [autocomplete]=\"getRandomString()\"\n\t\t formControlName=\"value\"\n\t\t matInput/>\n\t <button\n\t\t (click)=\"passwordView(i)\"\n\t\t *ngIf=\"propriedade.get('hidePassword').value !== null\"\n\t\t [attr.aria-label]=\"'Hide password'\"\n\t\t [attr.aria-pressed]=\"propriedade.get('hidePassword').value\"\n\t\t mat-icon-button matSuffix tabindex=\"-1\" type=\"button\">\n\t <mat-icon>{{propriedade.get('hidePassword').value ? 'visibility_off' : 'visibility'}}</mat-icon>\n\t </button>\n\t <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n\t <mat-icon>info</mat-icon>\n\t\t {{propriedade.get('textHint').value}}\n\t </mat-hint>\n\t <mat-error *ngIf=\"propriedade.get('value').errors?.required\">\n\t <mat-icon>error</mat-icon>\n {{errorMessage.getRequiredMessage(propriedade.get('label').value)}}\n\t </mat-error>\n\t <mat-error *ngIf=\"propriedade.get('value').errors?.cpfInvalid\">\n\t <mat-icon>error</mat-icon>\n {{errorMessage.getInvalidMessage(propriedade.get('label').value)}}\n\t </mat-error>\n\t <mat-error *ngIf=\"propriedade.get('value').errors?.cnpjInvalid\">\n\t <mat-icon>error</mat-icon>\n {{errorMessage.getInvalidMessage(propriedade.get('label').value)}}\n\t </mat-error>\n\t <mat-error *ngIf=\"propriedade.get('value').errors?.email\">\n\t <mat-icon>error</mat-icon>\n {{errorMessage.getInvalidMessage(propriedade.get('label').value)}}\n\t </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.min\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMinMessage(propriedade.get('min').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.max\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMaxMessage(propriedade.get('max').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.minLength\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMinLengthMessage(propriedade.get('minLength').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.maxLength\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMaxLengthMessage(propriedade.get('maxLength').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.dateMin\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getDateMinMessage()}}\n {{propriedade.get('min').value | date:\"shortDate\"}}.\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.dateMax\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getDateMaxMessage()}}\n {{propriedade.get('max').value | date:\"shortDate\"}}.\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n <mat-icon>error</mat-icon>\n {{propriedade.get('value').errors?.customError.message}}.\n </mat-error>\n\t </mat-form-field>\n\t <mat-form-field\n\t\t *ngIf=\"propriedade.get('type').value == typeField.coin\"\n\t\t [appearance]=\"propriedade.get('appearance').value\"\n\t\t [floatLabel]=\"propriedade.get('floatLabel').value\"\n\t\t [formGroupName]=\"i\"\n\t\t [ngClass]=\"propriedade.get('fieldClass').value\">\n\t <mat-label>{{propriedade.get('label').value}}</mat-label>\n\t <input\n\t\t [koalaAutoFocus]=\"propriedade.get('focus').value\"\n\t\t [required]=\"propriedade.get('required').value\"\n [tabIndex]=\"tabIndexStart + i\"\n [min]=\"propriedade.get('min').value\"\n [max]=\"propriedade.get('max').value\"\n [minLength]=\"propriedade.get('minLength').value\"\n [maxLength]=\"propriedade.get('maxLength').value\"\n [autocomplete]=\"getRandomString()\"\n\t\t currencyMask\n\t\t formControlName=\"value\"\n\t\t matInput\n\t\t type=\"tel\"/>\n\t <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n\t <mat-icon>info</mat-icon>\n\t\t {{propriedade.get('textHint').value}}\n\t </mat-hint>\n <mat-error *ngIf=\"propriedade.get('value').errors?.min\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMinMessage(propriedade.get('min').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.max\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMaxMessage(propriedade.get('max').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.minLength\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMinLengthMessage(propriedade.get('minLength').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.maxLength\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMaxLengthMessage(propriedade.get('maxLength').value)}}\n </mat-error>\n\t <mat-error *ngIf=\"propriedade.get('value').errors?.required\">\n\t <mat-icon>error</mat-icon>\n {{errorMessage.getRequiredMessage(propriedade.get('label').value)}}\n\t </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n <mat-icon>error</mat-icon>\n {{propriedade.get('value').errors?.customError.message}}.\n </mat-error>\n\t </mat-form-field>\n <mat-form-field\n *ngIf=\"propriedade.get('type').value == typeField.float\"\n [appearance]=\"propriedade.get('appearance').value\"\n [floatLabel]=\"propriedade.get('floatLabel').value\"\n [formGroupName]=\"i\"\n [ngClass]=\"propriedade.get('fieldClass').value\">\n <mat-label>{{propriedade.get('label').value}}</mat-label>\n <input\n [koalaAutoFocus]=\"propriedade.get('focus').value\"\n [required]=\"propriedade.get('required').value\"\n [tabIndex]=\"tabIndexStart + i\"\n [min]=\"propriedade.get('min').value\"\n [max]=\"propriedade.get('max').value\"\n [minLength]=\"propriedade.get('minLength').value\"\n [maxLength]=\"propriedade.get('maxLength').value\"\n [autocomplete]=\"getRandomString()\"\n currencyMask\n [options]=\"{prefix: ''}\"\n formControlName=\"value\"\n matInput\n type=\"tel\"/>\n <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n <mat-icon>info</mat-icon>\n {{propriedade.get('textHint').value}}\n </mat-hint>\n <mat-error *ngIf=\"propriedade.get('value').errors?.min\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMinMessage(propriedade.get('min').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.max\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMaxMessage(propriedade.get('max').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.minLength\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMinLengthMessage(propriedade.get('minLength').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.maxLength\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMaxLengthMessage(propriedade.get('maxLength').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.required\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getRequiredMessage(propriedade.get('label').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n <mat-icon>error</mat-icon>\n {{propriedade.get('value').errors?.customError.message}}.\n </mat-error>\n </mat-form-field>\n\t <mat-form-field\n\t\t *ngIf=\"propriedade.get('type').value == typeField.valueList ||\n\t propriedade.get('type').value == typeField.textarea\"\n\t\t [appearance]=\"propriedade.get('appearance').value\"\n\t\t [floatLabel]=\"propriedade.get('floatLabel').value\"\n\t\t [formGroupName]=\"i\"\n\t\t [ngClass]=\"propriedade.get('fieldClass').value\">\n\t <mat-label>{{propriedade.get('label').value}}</mat-label>\n\t <textarea\n #textarea\n\t\t [koalaAutoFocus]=\"propriedade.get('focus').value\"\n cdkTextareaAutosize\n #autosize=\"cdkTextareaAutosize\"\n\t\t [cdkAutosizeMaxRows]=\"8\"\n\t\t [cdkAutosizeMinRows]=\"3\"\n\t\t [required]=\"propriedade.get('required').value\"\n [tabIndex]=\"tabIndexStart + i\"\n [minLength]=\"propriedade.get('minLength').value\"\n [maxLength]=\"propriedade.get('maxLength').value\"\n\t\t formControlName=\"value\"\n\t\t matInput>\n </textarea>\n\t <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n\t <mat-icon>info</mat-icon>\n\t\t {{propriedade.get('textHint').value}}\n\t </mat-hint>\n <mat-hint align=\"end\" *ngIf=\"propriedade.get('maxLength').value\">\n {{textarea.value.length}}/{{propriedade.get('maxLength').value}}\n </mat-hint>\n <mat-error *ngIf=\"propriedade.get('value').errors?.minLength\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMinLengthMessage(propriedade.get('minLength').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.maxLength\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMaxLengthMessage(propriedade.get('maxLength').value)}}\n </mat-error>\n\t <mat-error *ngIf=\"propriedade.get('value').errors?.required\">\n\t <mat-icon>error</mat-icon>\n {{errorMessage.getRequiredMessage(propriedade.get('label').value)}}\n\t </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n <mat-icon>error</mat-icon>\n {{propriedade.get('value').errors?.customError.message}}.\n </mat-error>\n\t </mat-form-field>\n\t\t <mat-form-field\n\t\t\t *ngIf=\"propriedade.get('type').value == typeField.textLogs\"\n\t\t\t [appearance]=\"propriedade.get('appearance').value\"\n\t\t\t [floatLabel]=\"propriedade.get('floatLabel').value\"\n\t\t\t [formGroupName]=\"i\"\n\t\t\t [ngClass]=\"propriedade.get('fieldClass').value\">\n\t <mat-label>{{propriedade.get('label').value}}</mat-label>\n\t <div [innerHTML]=\"propriedade.get('textLogs').value\" class=\"text-obs\"></div>\n\t <textarea\n #textarea\n\t\t [koalaAutoFocus]=\"propriedade.get('focus').value\"\n cdkTextareaAutosize\n #autosize=\"cdkTextareaAutosize\"\n\t\t [cdkAutosizeMaxRows]=\"8\"\n\t\t [cdkAutosizeMinRows]=\"3\"\n\t\t [required]=\"propriedade.get('required').value\"\n [tabIndex]=\"tabIndexStart + i\"\n [minLength]=\"propriedade.get('minLength').value\"\n [maxLength]=\"propriedade.get('maxLength').value\"\n\t\t formControlName=\"value\"\n\t\t matInput>\n\t </textarea>\n\t <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n\t <mat-icon>info</mat-icon>\n\t\t {{propriedade.get('textHint').value}}\n\t </mat-hint>\n <mat-hint align=\"end\" *ngIf=\"propriedade.get('maxLength').value\">\n {{textarea.value.length}}/{{propriedade.get('maxLength').value}}\n </mat-hint>\n <mat-error *ngIf=\"propriedade.get('value').errors?.minLength\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMinLengthMessage(propriedade.get('minLength').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.maxLength\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMaxLengthMessage(propriedade.get('maxLength').value)}}\n </mat-error>\n\t <mat-error *ngIf=\"propriedade.get('value').errors?.required\">\n\t <mat-icon>error</mat-icon>\n {{errorMessage.getRequiredMessage(propriedade.get('label').value)}}\n\t </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n <mat-icon>error</mat-icon>\n {{propriedade.get('value').errors?.customError.message}}.\n </mat-error>\n\t </mat-form-field>\n\t <mat-form-field\n\t\t *ngIf=\"propriedade.get('type').value == typeField.select\"\n\t\t [appearance]=\"propriedade.get('appearance').value\"\n\t\t [floatLabel]=\"propriedade.get('floatLabel').value\"\n\t\t [formGroupName]=\"i\"\n\t\t [ngClass]=\"propriedade.get('fieldClass').value\">\n\t <mat-label>{{propriedade.get('label').value}}</mat-label>\n\t <mat-select [multiple]=\"propriedade.get('multiple').value\" [required]=\"propriedade.get('required').value\"\n [tabIndex]=\"tabIndexStart + i\" formControlName=\"value\">\n\t <mat-option *ngFor=\"let options of propriedade.get('opcoesSelect').value\" [value]=\"options.value\">\n\t {{options.name}}\n\t </mat-option>\n\t </mat-select>\n\t <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n\t <mat-icon>info</mat-icon>\n\t\t {{propriedade.get('textHint').value}}\n\t </mat-hint>\n\t <mat-error *ngIf=\"propriedade.get('value').errors?.required\">\n\t <mat-icon>error</mat-icon>\n {{errorMessage.getRequiredMessage(propriedade.get('label').value)}}\n\t </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n <mat-icon>error</mat-icon>\n {{propriedade.get('value').errors?.customError.message}}.\n </mat-error>\n\t </mat-form-field>\n <mat-form-field\n class=\"select-multiple-native\"\n *ngIf=\"propriedade.get('type').value == typeField.selectMultipleNative\"\n [appearance]=\"propriedade.get('appearance').value\"\n [floatLabel]=\"propriedade.get('floatLabel').value\"\n [formGroupName]=\"i\"\n [ngClass]=\"propriedade.get('fieldClass').value\">\n <mat-label>{{propriedade.get('label').value}}</mat-label>\n <select\n matNativeControl\n formControlName=\"value\"\n multiple\n [tabIndex]=\"tabIndexStart + i\"\n [required]=\"propriedade.get('required').value\">\n <option *ngFor=\"let options of propriedade.get('opcoesSelect').value\" [value]=\"options.value\">\n {{options.name}}\n </option>\n </select>\n <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n <mat-icon>info</mat-icon>\n {{propriedade.get('textHint').value}}\n </mat-hint>\n <mat-error *ngIf=\"propriedade.get('value').errors?.required\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getRequiredMessage(propriedade.get('label').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n <mat-icon>error</mat-icon>\n {{propriedade.get('value').errors?.customError.message}}.\n </mat-error>\n </mat-form-field>\n\t <div\n\t\t *ngIf=\"propriedade.get('type').value == typeField.checkbox\"\n\t\t [formGroupName]=\"i\"\n\t\t [ngClass]=\"propriedade.get('fieldClass').value\">\n\t <mat-checkbox\n [tabIndex]=\"tabIndexStart + i\"\n\t\t formControlName=\"value\"\n\t\t value=\"true\">\n\t {{propriedade.get('label').value}}\n\t </mat-checkbox>\n\t </div>\n\t\t <div\n\t\t\t *ngIf=\"propriedade.get('type').value == typeField.moreItems\"\n\t\t\t [formGroupName]=\"i\"\n\t\t\t [ngClass]=\"propriedade.get('fieldClass').value\"\n\t\t\t class=\"more-items-content\">\n\t\t\t <fieldset>\n\t\t\t\t <legend>\n\t\t\t\t\t <koala-button\n\t\t\t\t\t\t (click)=\"addMoreItem(i)\"\n\t\t\t\t\t\t [disabled]=\"propriedade.get('moreItemsConfig').value.length === propriedade.get('moreItemsMaxItems').value\"\n\t\t\t\t\t\t [tooltip]=\"propriedade.get('moreItemsButtonIconAddlabel').value\"\n\t\t\t\t\t\t [backgroundColor]=\"propriedade.get('moreItemsIconBackgroundColor').value\"\n [color]=\"propriedade.get('moreItemsIconFontColor').value\"\n\t\t\t\t\t\t class=\"btn-add-more-items\"\n\t\t\t\t\t\t icon=\"add\">\n\t\t\t\t\t </koala-button>\n\t\t\t\t\t {{propriedade.get('label').value}} (Min.: {{propriedade.get('moreItemsMinItems').value}}\n\t\t\t\t\t | M\u00E1x.: {{propriedade.get('moreItemsMaxItems').value}})\n\t\t\t\t </legend>\n\t\t\t\t <mat-accordion class=\"items\" multi>\n\t\t\t\t\t <mat-expansion-panel\n\t\t\t\t\t\t *ngFor=\"let item of propriedade.get('moreItemsConfig').value.slice().reverse(); index as indexMoreItems\"\n\t\t\t\t\t\t expanded>\n\t\t\t\t\t\t <mat-expansion-panel-header>\n\t\t\t\t\t\t\t\t<mat-panel-title class=\"titleForm\">#\n\t\t\t\t\t\t\t\t\t{{propriedade.get('moreItemsConfig').value.length - 1 - indexMoreItems + 1}}</mat-panel-title>\n\t\t\t\t\t\t\t\t<mat-panel-description class=\"titleForm\">\n\t\t\t\t\t\t\t\t\t{{propriedade.get('label').value}}\n\t\t\t\t\t\t\t\t\t<mat-icon>{{propriedade.get('moreItemsIcon').value}}</mat-icon>\n\t\t\t\t\t\t\t\t</mat-panel-description>\n\t\t\t\t\t\t\t</mat-expansion-panel-header>\n\t\t\t\t\t\t <koala-dynamic-form\n\t\t\t\t\t\t\t [showFieldsMoreItensConfig]=\"item.showFieldsMoreItensConfig\"\n\t\t\t\t\t\t\t [showFields]=\"item.showFields\"\n\t\t\t\t\t\t\t [formConfig]=\"item.formConfig\"\n\t\t\t\t\t\t\t [form]=\"item.form\"\n [tabIndexStart]=\"tabIndexStart + i\">\n\t\t\t\t\t\t </koala-dynamic-form>\n\t\t\t\t\t <mat-action-row\n\t\t\t\t\t\t *ngIf=\"propriedade.get('moreItemsConfig').value.length > propriedade.get('moreItemsMinItems').value\">\n\t\t\t\t\t <button\n\t\t\t\t\t\t (click)=\"removeMoreItem(i, propriedade.get('moreItemsConfig').value.length - 1 - indexMoreItems)\"\n\t\t\t\t\t\t mat-icon-button>\n\t\t\t\t\t\t <mat-icon>delete</mat-icon>\n\t\t\t\t\t </button>\n\t\t\t\t\t </mat-action-row>\n\t\t\t\t\t </mat-expansion-panel>\n\t\t\t\t </mat-accordion>\n\t\t\t </fieldset>\n\t\t </div>\n\t\t <mat-form-field\n\t\t\t *ngIf=\"propriedade.get('type').value == typeField.autocomplete\"\n\t\t\t [appearance]=\"propriedade.get('appearance').value\"\n\t\t\t [floatLabel]=\"propriedade.get('floatLabel').value\"\n\t\t\t [formGroupName]=\"i\"\n\t\t\t [ngClass]=\"propriedade.get('fieldClass').value\">\n\t <mat-label>{{propriedade.get('label').value}} {{propriedade.get('multiple').value &&\n\t propriedade.get('required').value ? '*' : ''}}</mat-label>\n\t\t\t <div *ngIf=\"propriedade.get('multiple').value else single\">\n\t <mat-chip-list #chipList>\n <mat-chip\n (removed)=\"removeOptionOnAutocomplete(i, option)\"\n *ngFor=\"let option of propriedade.get('autocompleteSelectedValue').value\"\n [color]=\"getColorChip(propriedade.get('autocompleteMultipleConfig').value | async)\"\n [removable]=\"true\"\n [selectable]=\"true\">\n {{display(option)}}\n <mat-icon *ngIf=\"!propriedade.get('disabled').value\" matChipRemove>cancel</mat-icon>\n </mat-chip>\n\t <input\n [id]=\"'autocomplete-' + propriedade.get('name').value\"\n [koalaAutoFocus]=\"propriedade.get('focus').value\"\n\t\t [required]=\"propriedade.get('required').value\"\n\t\t [matAutocomplete]=\"auto\"\n\t\t [matChipInputFor]=\"chipList\"\n [tabIndex]=\"tabIndexStart + i\"\n [autocomplete]=\"getRandomString()\"\n\t\t formControlName=\"value\"\n\t\t matInput\n\t\t type=\"text\"\n\t\t placeholder=\"Selecione um ou mais op\u00E7\u00F5es...\">\n\t </mat-chip-list>\n\t </div>\n\t <ng-template #single>\n\t\t <input\n\t\t\t [matAutocomplete]=\"auto\"\n [koalaAutoFocus]=\"propriedade.get('focus').value\"\n\t\t\t [required]=\"propriedade.get('required').value\"\n [tabIndex]=\"tabIndexStart + i\"\n [autocomplete]=\"getRandomString()\"\n\t\t\t formControlName=\"value\"\n\t\t\t matInput\n\t\t\t placeholder=\"Selecione uma op\u00E7\u00E3o...\"\n\t\t\t type=\"text\">\n\t </ng-template>\n\t <mat-spinner *ngIf=\"propriedade.get('autocompleteLoading').value | async\" color=\"primary\"\n\t matSuffix></mat-spinner>\n\t <button\n\t\t (click)=\"clearAutocomplete(i)\"\n\t\t *ngIf=\"\n\t !(propriedade.get('autocompleteLoading').value | async) &&\n\t !propriedade.get('disabled').value\"\n\t\t color=\"warn\"\n\t\t mat-icon-button\n\t\t matSuffix\n\t\t type=\"button\">\n\t <mat-icon>close</mat-icon>\n\t </button>\n\t <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n\t <mat-icon>info</mat-icon>\n\t\t {{propriedade.get('textHint').value}}\n\t </mat-hint>\n\t <mat-error *ngIf=\"propriedade.get('value').errors?.required || propriedade.get('value').errors?.autocompleteSelected\">\n\t <mat-icon>error</mat-icon>\n {{errorMessage.getAutocompleteMessage(propriedade.get('label').value)}}\n\t </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n <mat-icon>error</mat-icon>\n {{propriedade.get('value').errors?.customError.message}}.\n </mat-error>\n\t <mat-autocomplete\n\t\t #auto=\"matAutocomplete\"\n\t\t [displayWith]=\"display\" autoActiveFirstOption>\n <mat-option\n *ngIf=\"propriedade.get('autocompleteAddOption').value && isValidNewAutocompleteOption(propriedade.get('value').value)\"\n [value]=\"{\n value: {id: 0, name: propriedade.get('value').value},\n name: propriedade.get('value').value\n }\">\n Add <b>{{propriedade.get('value').value}}</b>...\n </mat-option>\n\t\t <div *ngIf=\"(getAutocompleteOptions(propriedade) | async) as options\">\n\t\t <mat-option *ngFor=\"let option of options\" [value]=\"option\">\n\t\t {{option.name}}\n\t\t </mat-option>\n\t\t </div>\n\t </mat-autocomplete>\n\t </mat-form-field>\n\t\t <div *ngIf=\"propriedade.get('type').value == typeField.file\">\n\t\t\t <koala-file-button\n\t\t\t\t (getFiles)=\"propriedade.get('value').setValue($event)\"\n\t\t\t\t [accept]=\"propriedade.get('fileButtonConfig').value.accept\"\n\t\t\t\t [backgroundColor]=\"propriedade.get('fileButtonConfig').value.backgroundColor\"\n\t\t\t\t [color]=\"propriedade.get('fileButtonConfig').value.color\"\n\t\t\t\t [disabled]=\"propriedade.get('disabled').value\"\n\t\t\t\t [icon]=\"propriedade.get('fileButtonConfig').value.icon\"\n\t\t\t\t [multiple]=\"propriedade.get('multiple').value\"\n\t\t\t\t [text]=\"propriedade.get('fileButtonConfig').value.text\">\n\t\t\t </koala-file-button>\n\t\t </div>\n\t\t <div *ngIf=\"\n\t\t propriedade.get('type').value == typeField.dynamicForm &&\n\t\t\t\t(getDynamicFormConfig(propriedade) | async) as dynamicFormConfig\">\n\t\t\t <fieldset *ngIf=\"propriedade.get('label').value else dynamicFormWithoutLabel\">\n\t\t\t\t <legend>{{propriedade.get('label').value}}</legend>\n\t\t\t\t <koala-dynamic-form\n\t\t\t\t\t [formConfig]=\"dynamicFormConfig.formConfig\"\n\t\t\t\t\t [form]=\"dynamicFormConfig.form\"\n\t\t\t\t\t [setValues]=\"dynamicFormConfig.setValues\"\n\t\t\t\t\t [showFields]=\"dynamicFormConfig.showFields\"\n [tabIndexStart]=\"tabIndexStart + i\">\n\t\t\t\t </koala-dynamic-form>\n\t\t\t </fieldset>\n\t\t\t <ng-template #dynamicFormWithoutLabel>\n\t\t\t\t <koala-dynamic-form\n\t\t\t\t\t [formConfig]=\"dynamicFormConfig.formConfig\"\n\t\t\t\t\t [form]=\"dynamicFormConfig.form\"\n\t\t\t\t\t [setValues]=\"dynamicFormConfig.setValues\"\n\t\t\t\t\t [showFields]=\"dynamicFormConfig.showFields\"\n [tabIndexStart]=\"tabIndexStart + i\">\n\t\t\t\t </koala-dynamic-form>\n\t\t\t </ng-template>\n\t\t </div>\n <div\n class=\"radio-btn-group\"\n *ngIf=\"propriedade.get('type').value == typeField.radio\"\n [formGroupName]=\"i\"\n [ngClass]=\"propriedade.get('fieldClass').value\">\n <mat-radio-group formControlName=\"value\">\n <label *ngIf=\"propriedade.get('label').value\">{{propriedade.get('label').value}}</label>\n <mat-radio-button\n [tabIndex]=\"tabIndexStart + i\"\n *ngFor=\"let options of propriedade.get('opcoesSelect').value\"\n [value]=\"options.value\">\n {{options.name}}\n </mat-radio-button>\n </mat-radio-group>\n </div>\n\t </div>\n </div>\n <ng-content select=\"[btn-submit]\"></ng-content>\n</div>\n", styles: [".more-items-content fieldset{border:1px solid #cccccc;padding:16px}.more-items-content fieldset legend{font-family:Josefin Sans,sans-serif;font-size:11px;font-weight:700;padding:0 8px}.more-items-content .items .titleForm{color:#616161}.more-items-content .items .mat-expansion-panel-header-title,.more-items-content .items .mat-expansion-panel-header-description{flex-basis:0}.more-items-content .items .mat-expansion-panel-header-description{align-items:center;justify-content:space-between}.more-items-content .items .mat-form-field+.mat-form-field{margin-left:8px}.radio-btn-group label{position:relative;display:block;padding:10px 0}.text-obs{background:#eeeeee;border-radius:5px;color:#212121;font-family:OpenSansLight,sans-serif;height:150px;margin:0 auto 10px;overflow-y:auto;padding:10px;position:relative;width:calc(100% - 27px)}.select-multiple-native{margin-bottom:15px}.select-multiple-native select{width:100%;height:150px;background:transparent;border:none}.select-multiple-native select:focus,.select-multiple-native select:active{outline:none}.select-multiple-native select option{padding:5px 10px;font-family:JosefinSans,sans-serif}.select-multiple-native select option:checked{background:#f1f1f1!important}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i1.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i1.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: i1.SelectMultipleControlValueAccessor, selector: "select[multiple][formControlName],select[multiple][formControl],select[multiple][ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i1.FormGroupName, selector: "[formGroupName]", inputs: ["formGroupName"] }, { kind: "directive", type: i1.FormArrayName, selector: "[formArrayName]", inputs: ["formArrayName"] }, { kind: "directive", type: i4.CurrencyMaskDirective, selector: "[currencyMask]", inputs: ["max", "min", "options"] }, { kind: "directive", type: i5.MaskDirective, selector: "input[mask], textarea[mask]", inputs: ["mask", "specialCharacters", "patterns", "prefix", "suffix", "thousandSeparator", "decimalMarker", "dropSpecialCharacters", "hiddenInput", "showMaskTyped", "placeHolderCharacter", "shownMaskExpression", "showTemplate", "clearIfNotMatch", "validation", "separatorLimit", "allowNegativeNumbers", "leadZeroDateTime", "triggerOnMaskChange"], outputs: ["maskFilled"], exportAs: ["mask", "ngxMask"] }, { kind: "component", type: i6.FileButtonComponent, selector: "koala-file-button", inputs: ["color", "backgroundColor", "icon", "text", "tooltip", "disabled", "multiple", "accept", "setFile", "updateFileList", "autoclear"], outputs: ["getFiles"] }, { kind: "directive", type: i7.CdkTextareaAutosize, selector: "textarea[cdkTextareaAutosize]", inputs: ["cdkAutosizeMinRows", "cdkAutosizeMaxRows", "cdkTextareaAutosize", "placeholder"], exportAs: ["cdkTextareaAutosize"] }, { kind: "directive", type: i8.MatError, selector: "mat-error", inputs: ["id"] }, { kind: "component", type: i8.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i8.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "directive", type: i8.MatLabel, selector: "mat-label" }, { kind: "directive", type: i8.MatSuffix, selector: "[matSuffix]" }, { kind: "directive", type: i9.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: "component", type: i10.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }, { kind: "component", type: i11.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "directive", type: i12.MatRadioGroup, selector: "mat-radio-group", exportAs: ["matRadioGroup"] }, { kind: "component", type: i12.MatRadioButton, selector: "mat-radio-button", inputs: ["disableRipple", "tabIndex"], exportAs: ["matRadioButton"] }, { kind: "component", type: i13.MatCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex"], exportAs: ["matCheckbox"] }, { kind: "component", type: i14.MatAutocomplete, selector: "mat-autocomplete", inputs: ["disableRipple"], exportAs: ["matAutocomplete"] }, { kind: "directive", type: i14.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", exportAs: ["matAutocompleteTrigger"] }, { kind: "component", type: i15.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i16.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i17.MatAccordion, selector: "mat-accordion", inputs: ["multi", "hideToggle", "displayMode", "togglePosition"], exportAs: ["matAccordion"] }, { kind: "component", type: i17.MatExpansionPanel, selector: "mat-expansion-panel", inputs: ["disabled", "expanded", "hideToggle", "togglePosition"], outputs: ["opened", "closed", "expandedChange", "afterExpand", "afterCollapse"], exportAs: ["matExpansionPanel"] }, { kind: "directive", type: i17.MatExpansionPanelActionRow, selector: "mat-action-row" }, { kind: "component", type: i17.MatExpansionPanelHeader, selector: "mat-expansion-panel-header", inputs: ["tabIndex", "expandedHeight", "collapsedHeight"] }, { kind: "directive", type: i17.MatExpansionPanelTitle, selector: "mat-panel-title" }, { kind: "directive", type: i17.MatExpansionPanelDescription, selector: "mat-panel-description" }, { kind: "component", type: i18.MatChipList, selector: "mat-chip-list", inputs: ["role", "aria-describedby", "errorStateMatcher", "multiple", "compareWith", "value", "required", "placeholder", "disabled", "aria-orientation", "selectable", "tabIndex"], outputs: ["change", "valueChange"], exportAs: ["matChipList"] }, { kind: "directive", type: i18.MatChip, selector: "mat-basic-chip, [mat-basic-chip], mat-chip, [mat-chip]", inputs: ["color", "disableRipple", "tabIndex", "role", "selected", "value", "selectable", "disabled", "removable"], outputs: ["selectionChange", "destroyed", "removed"], exportAs: ["matChip"] }, { kind: "directive", type: i18.MatChipInput, selector: "input[matChipInputFor]", inputs: ["matChipInputFor", "matChipInputAddOnBlur", "matChipInputSeparatorKeyCodes", "placeholder", "id", "disabled"], outputs: ["matChipInputTokenEnd"], exportAs: ["matChipInput", "matChipInputFor"] }, { kind: "directive", type: i18.MatChipRemove, selector: "[matChipRemove]" }, { kind: "component", type: i19.ButtonComponent, selector: "koala-button", inputs: ["color", "backgroundColor", "icon", "text", "tooltip", "disabled", "koalaIcon", "koalaIconSize"] }, { kind: "component", type: i20.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "diameter", "strokeWidth", "mode", "value"], exportAs: ["matProgressSpinner"] }, { kind: "component", type: DynamicFormComponent, selector: "koala-dynamic-form", inputs: ["form", "formConfig", "showFields", "showFieldsMoreItensConfig", "setValues", "tabIndexStart"] }, { kind: "directive", type: i21.KoalaAutofocusDirective, selector: "[koalaAutoFocus]", inputs: ["koalaAutoFocus"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i3.DatePipe, name: "date" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
582
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: DynamicFormComponent, decorators: [{
|
|
583
|
+
type: Component,
|
|
584
|
+
args: [{ selector: 'koala-dynamic-form', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div [formGroup]=\"form\" class=\"p-relative w-100\" [id]=\"formId\">\n <div *ngFor=\"let propriedade of controls?.controls; let i = index;\"\n [ngClass]=\"(propriedade.get('show').value | async) ? propriedade.get('class').value : 'd-none'\"\n formArrayName=\"formData\">\n\t <div *ngIf=\"propriedade.get('show').value | async\">\n\t <mat-form-field\n\t\t *ngIf=\"propriedade.get('type').value == typeField.text ||\n\t propriedade.get('type').value == typeField.password ||\n\t propriedade.get('type').value == typeField.cpf ||\n\t propriedade.get('type').value == typeField.cnpj ||\n\t propriedade.get('type').value == typeField.datetime ||\n\t propriedade.get('type').value == typeField.email ||\n\t propriedade.get('type').value == typeField.number ||\n\t propriedade.get('type').value == typeField.stringNumber ||\n\t propriedade.get('type').value == typeField.time ||\n\t propriedade.get('type').value == typeField.date ||\n\t propriedade.get('type').value == typeField.hoursAndMinutes ||\n\t propriedade.get('type').value == typeField.phone ||\n\t propriedade.get('type').value == typeField.percent ||\n\t propriedade.get('type').value == typeField.color ||\n\t propriedade.get('type').value == typeField.month ||\n\t propriedade.get('type').value == typeField.competenceDate ||\n propriedade.get('type').value == typeField.stringWithCustomMasc\"\n\t\t [appearance]=\"propriedade.get('appearance').value\"\n\t\t [floatLabel]=\"propriedade.get('floatLabel').value\"\n\t\t [formGroupName]=\"i\"\n\t\t [ngClass]=\"propriedade.get('fieldClass').value\">\n\t <mat-label>{{propriedade.get('label').value}}</mat-label>\n\t <input\n\t\t [dropSpecialCharacters]=\"false\"\n\t\t [koalaAutoFocus]=\"propriedade.get('focus').value\"\n\t\t (keyup)=\"hoursAndMinutesApplyMask(i, $event)\"\n\t\t [required]=\"propriedade.get('required').value\"\n\t\t [tabIndex]=\"tabIndexStart + i\"\n\t\t [mask]=\"((propriedade.get('type').value == typeField.competenceDate) ? '00/0000' : null) ||\n\t\t ((propriedade.get('type').value == typeField.phone) ? '(00)0000-0000?0' : null) ||\n\t\t ((propriedade.get('type').value == typeField.stringNumber) ? '0{'+propriedade.get('maxLength').value+'}' : null) ||\n ((propriedade.get('type').value == typeField.cpf) ? '000.000.000-00' : null) ||\n ((propriedade.get('type').value == typeField.cnpj) ? '00.000.000/0000-00' : null) ||\n ((propriedade.get('type').value == typeField.percent) ? 'percent' : null) ||\n\t\t\t\t\t\t\t\t\t((propriedade.get('type').value == typeField.hoursAndMinutes) ? hoursAndMinutesMask : null) ||\n\t\t\t\t\t\t\t\t\t((propriedade.get('type').value == typeField.stringWithCustomMasc) ? propriedade.get('customMasc').value : null)\"\n\t\t [validation]=\"\n\t (propriedade.get('type').value == typeField.cpf && propriedade.get('value').errors?.cpfInvalid) ||\n\t (propriedade.get('type').value == typeField.cnpj && propriedade.get('value').errors?.cnpjInvalid)\"\n\t\t [type]=\"((propriedade.get('type').value == typeField.cpf ||\n propriedade.get('type').value == typeField.cnpj ||\n propriedade.get('type').value == typeField.phone ||\n propriedade.get('type').value == typeField.percent\n )) ? 'tel' : (\n propriedade.get('type').value == typeField.month ?\n 'month' : (\n propriedade.get('type').value == typeField.date ?\n 'date' : (\n propriedade.get('type').value == typeField.datetime ?\n 'datetime-local' : (\n propriedade.get('type').value == typeField.email ?\n 'email' : (\n propriedade.get('type').value == typeField.number ?\n 'number' : (\n propriedade.get('type').value == typeField.time ?\n 'time' : (\n propriedade.get('type').value == typeField.password ?\n 'password' : (\n propriedade.get('type').value == typeField.color ?\n 'color' : 'text'))))))))\"\n [min]=\"propriedade.get('min').value\"\n [max]=\"propriedade.get('max').value\"\n [minLength]=\"propriedade.get('minLength').value\"\n [maxLength]=\"propriedade.get('maxLength').value\"\n [thousandSeparator]=\"propriedade.get('customMascThousandSeparator').value\"\n [suffix]=\"propriedade.get('customMascSuffix').value\"\n [prefix]=\"propriedade.get('customMascPrefix').value\"\n separatorLimit=\"0\"\n [autocomplete]=\"getRandomString()\"\n\t\t formControlName=\"value\"\n\t\t matInput/>\n\t <button\n\t\t (click)=\"passwordView(i)\"\n\t\t *ngIf=\"propriedade.get('hidePassword').value !== null\"\n\t\t [attr.aria-label]=\"'Hide password'\"\n\t\t [attr.aria-pressed]=\"propriedade.get('hidePassword').value\"\n\t\t mat-icon-button matSuffix tabindex=\"-1\" type=\"button\">\n\t <mat-icon>{{propriedade.get('hidePassword').value ? 'visibility_off' : 'visibility'}}</mat-icon>\n\t </button>\n\t <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n\t <mat-icon>info</mat-icon>\n\t\t {{propriedade.get('textHint').value}}\n\t </mat-hint>\n\t <mat-error *ngIf=\"propriedade.get('value').errors?.required\">\n\t <mat-icon>error</mat-icon>\n {{errorMessage.getRequiredMessage(propriedade.get('label').value)}}\n\t </mat-error>\n\t <mat-error *ngIf=\"propriedade.get('value').errors?.cpfInvalid\">\n\t <mat-icon>error</mat-icon>\n {{errorMessage.getInvalidMessage(propriedade.get('label').value)}}\n\t </mat-error>\n\t <mat-error *ngIf=\"propriedade.get('value').errors?.cnpjInvalid\">\n\t <mat-icon>error</mat-icon>\n {{errorMessage.getInvalidMessage(propriedade.get('label').value)}}\n\t </mat-error>\n\t <mat-error *ngIf=\"propriedade.get('value').errors?.email\">\n\t <mat-icon>error</mat-icon>\n {{errorMessage.getInvalidMessage(propriedade.get('label').value)}}\n\t </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.min\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMinMessage(propriedade.get('min').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.max\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMaxMessage(propriedade.get('max').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.minLength\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMinLengthMessage(propriedade.get('minLength').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.maxLength\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMaxLengthMessage(propriedade.get('maxLength').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.dateMin\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getDateMinMessage()}}\n {{propriedade.get('min').value | date:\"shortDate\"}}.\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.dateMax\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getDateMaxMessage()}}\n {{propriedade.get('max').value | date:\"shortDate\"}}.\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n <mat-icon>error</mat-icon>\n {{propriedade.get('value').errors?.customError.message}}.\n </mat-error>\n\t </mat-form-field>\n\t <mat-form-field\n\t\t *ngIf=\"propriedade.get('type').value == typeField.coin\"\n\t\t [appearance]=\"propriedade.get('appearance').value\"\n\t\t [floatLabel]=\"propriedade.get('floatLabel').value\"\n\t\t [formGroupName]=\"i\"\n\t\t [ngClass]=\"propriedade.get('fieldClass').value\">\n\t <mat-label>{{propriedade.get('label').value}}</mat-label>\n\t <input\n\t\t [koalaAutoFocus]=\"propriedade.get('focus').value\"\n\t\t [required]=\"propriedade.get('required').value\"\n [tabIndex]=\"tabIndexStart + i\"\n [min]=\"propriedade.get('min').value\"\n [max]=\"propriedade.get('max').value\"\n [minLength]=\"propriedade.get('minLength').value\"\n [maxLength]=\"propriedade.get('maxLength').value\"\n [autocomplete]=\"getRandomString()\"\n\t\t currencyMask\n\t\t formControlName=\"value\"\n\t\t matInput\n\t\t type=\"tel\"/>\n\t <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n\t <mat-icon>info</mat-icon>\n\t\t {{propriedade.get('textHint').value}}\n\t </mat-hint>\n <mat-error *ngIf=\"propriedade.get('value').errors?.min\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMinMessage(propriedade.get('min').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.max\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMaxMessage(propriedade.get('max').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.minLength\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMinLengthMessage(propriedade.get('minLength').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.maxLength\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMaxLengthMessage(propriedade.get('maxLength').value)}}\n </mat-error>\n\t <mat-error *ngIf=\"propriedade.get('value').errors?.required\">\n\t <mat-icon>error</mat-icon>\n {{errorMessage.getRequiredMessage(propriedade.get('label').value)}}\n\t </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n <mat-icon>error</mat-icon>\n {{propriedade.get('value').errors?.customError.message}}.\n </mat-error>\n\t </mat-form-field>\n <mat-form-field\n *ngIf=\"propriedade.get('type').value == typeField.float\"\n [appearance]=\"propriedade.get('appearance').value\"\n [floatLabel]=\"propriedade.get('floatLabel').value\"\n [formGroupName]=\"i\"\n [ngClass]=\"propriedade.get('fieldClass').value\">\n <mat-label>{{propriedade.get('label').value}}</mat-label>\n <input\n [koalaAutoFocus]=\"propriedade.get('focus').value\"\n [required]=\"propriedade.get('required').value\"\n [tabIndex]=\"tabIndexStart + i\"\n [min]=\"propriedade.get('min').value\"\n [max]=\"propriedade.get('max').value\"\n [minLength]=\"propriedade.get('minLength').value\"\n [maxLength]=\"propriedade.get('maxLength').value\"\n [autocomplete]=\"getRandomString()\"\n currencyMask\n [options]=\"{prefix: ''}\"\n formControlName=\"value\"\n matInput\n type=\"tel\"/>\n <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n <mat-icon>info</mat-icon>\n {{propriedade.get('textHint').value}}\n </mat-hint>\n <mat-error *ngIf=\"propriedade.get('value').errors?.min\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMinMessage(propriedade.get('min').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.max\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMaxMessage(propriedade.get('max').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.minLength\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMinLengthMessage(propriedade.get('minLength').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.maxLength\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMaxLengthMessage(propriedade.get('maxLength').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.required\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getRequiredMessage(propriedade.get('label').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n <mat-icon>error</mat-icon>\n {{propriedade.get('value').errors?.customError.message}}.\n </mat-error>\n </mat-form-field>\n\t <mat-form-field\n\t\t *ngIf=\"propriedade.get('type').value == typeField.valueList ||\n\t propriedade.get('type').value == typeField.textarea\"\n\t\t [appearance]=\"propriedade.get('appearance').value\"\n\t\t [floatLabel]=\"propriedade.get('floatLabel').value\"\n\t\t [formGroupName]=\"i\"\n\t\t [ngClass]=\"propriedade.get('fieldClass').value\">\n\t <mat-label>{{propriedade.get('label').value}}</mat-label>\n\t <textarea\n #textarea\n\t\t [koalaAutoFocus]=\"propriedade.get('focus').value\"\n cdkTextareaAutosize\n #autosize=\"cdkTextareaAutosize\"\n\t\t [cdkAutosizeMaxRows]=\"8\"\n\t\t [cdkAutosizeMinRows]=\"3\"\n\t\t [required]=\"propriedade.get('required').value\"\n [tabIndex]=\"tabIndexStart + i\"\n [minLength]=\"propriedade.get('minLength').value\"\n [maxLength]=\"propriedade.get('maxLength').value\"\n\t\t formControlName=\"value\"\n\t\t matInput>\n </textarea>\n\t <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n\t <mat-icon>info</mat-icon>\n\t\t {{propriedade.get('textHint').value}}\n\t </mat-hint>\n <mat-hint align=\"end\" *ngIf=\"propriedade.get('maxLength').value\">\n {{textarea.value.length}}/{{propriedade.get('maxLength').value}}\n </mat-hint>\n <mat-error *ngIf=\"propriedade.get('value').errors?.minLength\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMinLengthMessage(propriedade.get('minLength').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.maxLength\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMaxLengthMessage(propriedade.get('maxLength').value)}}\n </mat-error>\n\t <mat-error *ngIf=\"propriedade.get('value').errors?.required\">\n\t <mat-icon>error</mat-icon>\n {{errorMessage.getRequiredMessage(propriedade.get('label').value)}}\n\t </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n <mat-icon>error</mat-icon>\n {{propriedade.get('value').errors?.customError.message}}.\n </mat-error>\n\t </mat-form-field>\n\t\t <mat-form-field\n\t\t\t *ngIf=\"propriedade.get('type').value == typeField.textLogs\"\n\t\t\t [appearance]=\"propriedade.get('appearance').value\"\n\t\t\t [floatLabel]=\"propriedade.get('floatLabel').value\"\n\t\t\t [formGroupName]=\"i\"\n\t\t\t [ngClass]=\"propriedade.get('fieldClass').value\">\n\t <mat-label>{{propriedade.get('label').value}}</mat-label>\n\t <div [innerHTML]=\"propriedade.get('textLogs').value\" class=\"text-obs\"></div>\n\t <textarea\n #textarea\n\t\t [koalaAutoFocus]=\"propriedade.get('focus').value\"\n cdkTextareaAutosize\n #autosize=\"cdkTextareaAutosize\"\n\t\t [cdkAutosizeMaxRows]=\"8\"\n\t\t [cdkAutosizeMinRows]=\"3\"\n\t\t [required]=\"propriedade.get('required').value\"\n [tabIndex]=\"tabIndexStart + i\"\n [minLength]=\"propriedade.get('minLength').value\"\n [maxLength]=\"propriedade.get('maxLength').value\"\n\t\t formControlName=\"value\"\n\t\t matInput>\n\t </textarea>\n\t <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n\t <mat-icon>info</mat-icon>\n\t\t {{propriedade.get('textHint').value}}\n\t </mat-hint>\n <mat-hint align=\"end\" *ngIf=\"propriedade.get('maxLength').value\">\n {{textarea.value.length}}/{{propriedade.get('maxLength').value}}\n </mat-hint>\n <mat-error *ngIf=\"propriedade.get('value').errors?.minLength\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMinLengthMessage(propriedade.get('minLength').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.maxLength\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getMaxLengthMessage(propriedade.get('maxLength').value)}}\n </mat-error>\n\t <mat-error *ngIf=\"propriedade.get('value').errors?.required\">\n\t <mat-icon>error</mat-icon>\n {{errorMessage.getRequiredMessage(propriedade.get('label').value)}}\n\t </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n <mat-icon>error</mat-icon>\n {{propriedade.get('value').errors?.customError.message}}.\n </mat-error>\n\t </mat-form-field>\n\t <mat-form-field\n\t\t *ngIf=\"propriedade.get('type').value == typeField.select\"\n\t\t [appearance]=\"propriedade.get('appearance').value\"\n\t\t [floatLabel]=\"propriedade.get('floatLabel').value\"\n\t\t [formGroupName]=\"i\"\n\t\t [ngClass]=\"propriedade.get('fieldClass').value\">\n\t <mat-label>{{propriedade.get('label').value}}</mat-label>\n\t <mat-select [multiple]=\"propriedade.get('multiple').value\" [required]=\"propriedade.get('required').value\"\n [tabIndex]=\"tabIndexStart + i\" formControlName=\"value\">\n\t <mat-option *ngFor=\"let options of propriedade.get('opcoesSelect').value\" [value]=\"options.value\">\n\t {{options.name}}\n\t </mat-option>\n\t </mat-select>\n\t <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n\t <mat-icon>info</mat-icon>\n\t\t {{propriedade.get('textHint').value}}\n\t </mat-hint>\n\t <mat-error *ngIf=\"propriedade.get('value').errors?.required\">\n\t <mat-icon>error</mat-icon>\n {{errorMessage.getRequiredMessage(propriedade.get('label').value)}}\n\t </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n <mat-icon>error</mat-icon>\n {{propriedade.get('value').errors?.customError.message}}.\n </mat-error>\n\t </mat-form-field>\n <mat-form-field\n class=\"select-multiple-native\"\n *ngIf=\"propriedade.get('type').value == typeField.selectMultipleNative\"\n [appearance]=\"propriedade.get('appearance').value\"\n [floatLabel]=\"propriedade.get('floatLabel').value\"\n [formGroupName]=\"i\"\n [ngClass]=\"propriedade.get('fieldClass').value\">\n <mat-label>{{propriedade.get('label').value}}</mat-label>\n <select\n matNativeControl\n formControlName=\"value\"\n multiple\n [tabIndex]=\"tabIndexStart + i\"\n [required]=\"propriedade.get('required').value\">\n <option *ngFor=\"let options of propriedade.get('opcoesSelect').value\" [value]=\"options.value\">\n {{options.name}}\n </option>\n </select>\n <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n <mat-icon>info</mat-icon>\n {{propriedade.get('textHint').value}}\n </mat-hint>\n <mat-error *ngIf=\"propriedade.get('value').errors?.required\">\n <mat-icon>error</mat-icon>\n {{errorMessage.getRequiredMessage(propriedade.get('label').value)}}\n </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n <mat-icon>error</mat-icon>\n {{propriedade.get('value').errors?.customError.message}}.\n </mat-error>\n </mat-form-field>\n\t <div\n\t\t *ngIf=\"propriedade.get('type').value == typeField.checkbox\"\n\t\t [formGroupName]=\"i\"\n\t\t [ngClass]=\"propriedade.get('fieldClass').value\">\n\t <mat-checkbox\n [tabIndex]=\"tabIndexStart + i\"\n\t\t formControlName=\"value\"\n\t\t value=\"true\">\n\t {{propriedade.get('label').value}}\n\t </mat-checkbox>\n\t </div>\n\t\t <div\n\t\t\t *ngIf=\"propriedade.get('type').value == typeField.moreItems\"\n\t\t\t [formGroupName]=\"i\"\n\t\t\t [ngClass]=\"propriedade.get('fieldClass').value\"\n\t\t\t class=\"more-items-content\">\n\t\t\t <fieldset>\n\t\t\t\t <legend>\n\t\t\t\t\t <koala-button\n\t\t\t\t\t\t (click)=\"addMoreItem(i)\"\n\t\t\t\t\t\t [disabled]=\"propriedade.get('moreItemsConfig').value.length === propriedade.get('moreItemsMaxItems').value\"\n\t\t\t\t\t\t [tooltip]=\"propriedade.get('moreItemsButtonIconAddlabel').value\"\n\t\t\t\t\t\t [backgroundColor]=\"propriedade.get('moreItemsIconBackgroundColor').value\"\n [color]=\"propriedade.get('moreItemsIconFontColor').value\"\n\t\t\t\t\t\t class=\"btn-add-more-items\"\n\t\t\t\t\t\t icon=\"add\">\n\t\t\t\t\t </koala-button>\n\t\t\t\t\t {{propriedade.get('label').value}} (Min.: {{propriedade.get('moreItemsMinItems').value}}\n\t\t\t\t\t | M\u00E1x.: {{propriedade.get('moreItemsMaxItems').value}})\n\t\t\t\t </legend>\n\t\t\t\t <mat-accordion class=\"items\" multi>\n\t\t\t\t\t <mat-expansion-panel\n\t\t\t\t\t\t *ngFor=\"let item of propriedade.get('moreItemsConfig').value.slice().reverse(); index as indexMoreItems\"\n\t\t\t\t\t\t expanded>\n\t\t\t\t\t\t <mat-expansion-panel-header>\n\t\t\t\t\t\t\t\t<mat-panel-title class=\"titleForm\">#\n\t\t\t\t\t\t\t\t\t{{propriedade.get('moreItemsConfig').value.length - 1 - indexMoreItems + 1}}</mat-panel-title>\n\t\t\t\t\t\t\t\t<mat-panel-description class=\"titleForm\">\n\t\t\t\t\t\t\t\t\t{{propriedade.get('label').value}}\n\t\t\t\t\t\t\t\t\t<mat-icon>{{propriedade.get('moreItemsIcon').value}}</mat-icon>\n\t\t\t\t\t\t\t\t</mat-panel-description>\n\t\t\t\t\t\t\t</mat-expansion-panel-header>\n\t\t\t\t\t\t <koala-dynamic-form\n\t\t\t\t\t\t\t [showFieldsMoreItensConfig]=\"item.showFieldsMoreItensConfig\"\n\t\t\t\t\t\t\t [showFields]=\"item.showFields\"\n\t\t\t\t\t\t\t [formConfig]=\"item.formConfig\"\n\t\t\t\t\t\t\t [form]=\"item.form\"\n [tabIndexStart]=\"tabIndexStart + i\">\n\t\t\t\t\t\t </koala-dynamic-form>\n\t\t\t\t\t <mat-action-row\n\t\t\t\t\t\t *ngIf=\"propriedade.get('moreItemsConfig').value.length > propriedade.get('moreItemsMinItems').value\">\n\t\t\t\t\t <button\n\t\t\t\t\t\t (click)=\"removeMoreItem(i, propriedade.get('moreItemsConfig').value.length - 1 - indexMoreItems)\"\n\t\t\t\t\t\t mat-icon-button>\n\t\t\t\t\t\t <mat-icon>delete</mat-icon>\n\t\t\t\t\t </button>\n\t\t\t\t\t </mat-action-row>\n\t\t\t\t\t </mat-expansion-panel>\n\t\t\t\t </mat-accordion>\n\t\t\t </fieldset>\n\t\t </div>\n\t\t <mat-form-field\n\t\t\t *ngIf=\"propriedade.get('type').value == typeField.autocomplete\"\n\t\t\t [appearance]=\"propriedade.get('appearance').value\"\n\t\t\t [floatLabel]=\"propriedade.get('floatLabel').value\"\n\t\t\t [formGroupName]=\"i\"\n\t\t\t [ngClass]=\"propriedade.get('fieldClass').value\">\n\t <mat-label>{{propriedade.get('label').value}} {{propriedade.get('multiple').value &&\n\t propriedade.get('required').value ? '*' : ''}}</mat-label>\n\t\t\t <div *ngIf=\"propriedade.get('multiple').value else single\">\n\t <mat-chip-list #chipList>\n <mat-chip\n (removed)=\"removeOptionOnAutocomplete(i, option)\"\n *ngFor=\"let option of propriedade.get('autocompleteSelectedValue').value\"\n [color]=\"getColorChip(propriedade.get('autocompleteMultipleConfig').value | async)\"\n [removable]=\"true\"\n [selectable]=\"true\">\n {{display(option)}}\n <mat-icon *ngIf=\"!propriedade.get('disabled').value\" matChipRemove>cancel</mat-icon>\n </mat-chip>\n\t <input\n [id]=\"'autocomplete-' + propriedade.get('name').value\"\n [koalaAutoFocus]=\"propriedade.get('focus').value\"\n\t\t [required]=\"propriedade.get('required').value\"\n\t\t [matAutocomplete]=\"auto\"\n\t\t [matChipInputFor]=\"chipList\"\n [tabIndex]=\"tabIndexStart + i\"\n [autocomplete]=\"getRandomString()\"\n\t\t formControlName=\"value\"\n\t\t matInput\n\t\t type=\"text\"\n\t\t placeholder=\"Selecione um ou mais op\u00E7\u00F5es...\">\n\t </mat-chip-list>\n\t </div>\n\t <ng-template #single>\n\t\t <input\n\t\t\t [matAutocomplete]=\"auto\"\n [koalaAutoFocus]=\"propriedade.get('focus').value\"\n\t\t\t [required]=\"propriedade.get('required').value\"\n [tabIndex]=\"tabIndexStart + i\"\n [autocomplete]=\"getRandomString()\"\n\t\t\t formControlName=\"value\"\n\t\t\t matInput\n\t\t\t placeholder=\"Selecione uma op\u00E7\u00E3o...\"\n\t\t\t type=\"text\">\n\t </ng-template>\n\t <mat-spinner *ngIf=\"propriedade.get('autocompleteLoading').value | async\" color=\"primary\"\n\t matSuffix></mat-spinner>\n\t <button\n\t\t (click)=\"clearAutocomplete(i)\"\n\t\t *ngIf=\"\n\t !(propriedade.get('autocompleteLoading').value | async) &&\n\t !propriedade.get('disabled').value\"\n\t\t color=\"warn\"\n\t\t mat-icon-button\n\t\t matSuffix\n\t\t type=\"button\">\n\t <mat-icon>close</mat-icon>\n\t </button>\n\t <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n\t <mat-icon>info</mat-icon>\n\t\t {{propriedade.get('textHint').value}}\n\t </mat-hint>\n\t <mat-error *ngIf=\"propriedade.get('value').errors?.required || propriedade.get('value').errors?.autocompleteSelected\">\n\t <mat-icon>error</mat-icon>\n {{errorMessage.getAutocompleteMessage(propriedade.get('label').value)}}\n\t </mat-error>\n <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n <mat-icon>error</mat-icon>\n {{propriedade.get('value').errors?.customError.message}}.\n </mat-error>\n\t <mat-autocomplete\n\t\t #auto=\"matAutocomplete\"\n\t\t [displayWith]=\"display\" autoActiveFirstOption>\n <mat-option\n *ngIf=\"propriedade.get('autocompleteAddOption').value && isValidNewAutocompleteOption(propriedade.get('value').value)\"\n [value]=\"{\n value: {id: 0, name: propriedade.get('value').value},\n name: propriedade.get('value').value\n }\">\n Add <b>{{propriedade.get('value').value}}</b>...\n </mat-option>\n\t\t <div *ngIf=\"(getAutocompleteOptions(propriedade) | async) as options\">\n\t\t <mat-option *ngFor=\"let option of options\" [value]=\"option\">\n\t\t {{option.name}}\n\t\t </mat-option>\n\t\t </div>\n\t </mat-autocomplete>\n\t </mat-form-field>\n\t\t <div *ngIf=\"propriedade.get('type').value == typeField.file\">\n\t\t\t <koala-file-button\n\t\t\t\t (getFiles)=\"propriedade.get('value').setValue($event)\"\n\t\t\t\t [accept]=\"propriedade.get('fileButtonConfig').value.accept\"\n\t\t\t\t [backgroundColor]=\"propriedade.get('fileButtonConfig').value.backgroundColor\"\n\t\t\t\t [color]=\"propriedade.get('fileButtonConfig').value.color\"\n\t\t\t\t [disabled]=\"propriedade.get('disabled').value\"\n\t\t\t\t [icon]=\"propriedade.get('fileButtonConfig').value.icon\"\n\t\t\t\t [multiple]=\"propriedade.get('multiple').value\"\n\t\t\t\t [text]=\"propriedade.get('fileButtonConfig').value.text\">\n\t\t\t </koala-file-button>\n\t\t </div>\n\t\t <div *ngIf=\"\n\t\t propriedade.get('type').value == typeField.dynamicForm &&\n\t\t\t\t(getDynamicFormConfig(propriedade) | async) as dynamicFormConfig\">\n\t\t\t <fieldset *ngIf=\"propriedade.get('label').value else dynamicFormWithoutLabel\">\n\t\t\t\t <legend>{{propriedade.get('label').value}}</legend>\n\t\t\t\t <koala-dynamic-form\n\t\t\t\t\t [formConfig]=\"dynamicFormConfig.formConfig\"\n\t\t\t\t\t [form]=\"dynamicFormConfig.form\"\n\t\t\t\t\t [setValues]=\"dynamicFormConfig.setValues\"\n\t\t\t\t\t [showFields]=\"dynamicFormConfig.showFields\"\n [tabIndexStart]=\"tabIndexStart + i\">\n\t\t\t\t </koala-dynamic-form>\n\t\t\t </fieldset>\n\t\t\t <ng-template #dynamicFormWithoutLabel>\n\t\t\t\t <koala-dynamic-form\n\t\t\t\t\t [formConfig]=\"dynamicFormConfig.formConfig\"\n\t\t\t\t\t [form]=\"dynamicFormConfig.form\"\n\t\t\t\t\t [setValues]=\"dynamicFormConfig.setValues\"\n\t\t\t\t\t [showFields]=\"dynamicFormConfig.showFields\"\n [tabIndexStart]=\"tabIndexStart + i\">\n\t\t\t\t </koala-dynamic-form>\n\t\t\t </ng-template>\n\t\t </div>\n <div\n class=\"radio-btn-group\"\n *ngIf=\"propriedade.get('type').value == typeField.radio\"\n [formGroupName]=\"i\"\n [ngClass]=\"propriedade.get('fieldClass').value\">\n <mat-radio-group formControlName=\"value\">\n <label *ngIf=\"propriedade.get('label').value\">{{propriedade.get('label').value}}</label>\n <mat-radio-button\n [tabIndex]=\"tabIndexStart + i\"\n *ngFor=\"let options of propriedade.get('opcoesSelect').value\"\n [value]=\"options.value\">\n {{options.name}}\n </mat-radio-button>\n </mat-radio-group>\n </div>\n\t </div>\n </div>\n <ng-content select=\"[btn-submit]\"></ng-content>\n</div>\n", styles: [".more-items-content fieldset{border:1px solid #cccccc;padding:16px}.more-items-content fieldset legend{font-family:Josefin Sans,sans-serif;font-size:11px;font-weight:700;padding:0 8px}.more-items-content .items .titleForm{color:#616161}.more-items-content .items .mat-expansion-panel-header-title,.more-items-content .items .mat-expansion-panel-header-description{flex-basis:0}.more-items-content .items .mat-expansion-panel-header-description{align-items:center;justify-content:space-between}.more-items-content .items .mat-form-field+.mat-form-field{margin-left:8px}.radio-btn-group label{position:relative;display:block;padding:10px 0}.text-obs{background:#eeeeee;border-radius:5px;color:#212121;font-family:OpenSansLight,sans-serif;height:150px;margin:0 auto 10px;overflow-y:auto;padding:10px;position:relative;width:calc(100% - 27px)}.select-multiple-native{margin-bottom:15px}.select-multiple-native select{width:100%;height:150px;background:transparent;border:none}.select-multiple-native select:focus,.select-multiple-native select:active{outline:none}.select-multiple-native select option{padding:5px 10px;font-family:JosefinSans,sans-serif}.select-multiple-native select option:checked{background:#f1f1f1!important}\n"] }]
|
|
585
|
+
}], ctorParameters: function () { return [{ type: i1.UntypedFormBuilder }, { type: i2.KoalaDynamicFormService }]; }, propDecorators: { form: [{
|
|
586
|
+
type: Input
|
|
587
|
+
}], formConfig: [{
|
|
588
|
+
type: Input
|
|
589
|
+
}], showFields: [{
|
|
590
|
+
type: Input
|
|
591
|
+
}], showFieldsMoreItensConfig: [{
|
|
592
|
+
type: Input
|
|
593
|
+
}], setValues: [{
|
|
594
|
+
type: Input
|
|
595
|
+
}], tabIndexStart: [{
|
|
596
|
+
type: Input
|
|
597
|
+
}] } });
|
|
598
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-form.component.js","sourceRoot":"","sources":["../../../../../projects/form/src/lib/dynamic-form/dynamic-form.component.ts","../../../../../projects/form/src/lib/dynamic-form/dynamic-form.component.html"],"names":[],"mappings":"AAAA,OAAO,EAA0D,UAAU,EAAmB,MAAM,gBAAgB,CAAC;AAErH,OAAO,EAAE,wBAAwB,EAAE,MAAM,sCAAsC,CAAC;AAChF,OAAO,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;AAC1D,OAAO,EAAE,aAAa,EAAE,MAAM,6BAA6B,CAAC;AAC5D,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAc,KAAK,EAAqB,MAAM,eAAe,CAAC;AACzG,OAAO,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAC;AAChD,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAC9C,OAAO,EAAE,eAAe,EAAE,MAAM,MAAM,CAAC;AAEvC,OAAO,EAAE,6BAA6B,EAAE,MAAM,8CAA8C,CAAC;AAQ7F,OAAO,EAAE,KAAK,EAAE,MAAM,gCAAgC,CAAC;AACvD,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AACvC,OAAO,EAAE,gBAAgB,EAAE,MAAM,iCAAiC,CAAC;AACnE,OAAO,EAAE,gBAAgB,EAAE,MAAM,iCAAiC,CAAC;AACnE,OAAO,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAC;AACvD,OAAO,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAC;;;;;;;;;;;;;;;;;;;;;;;AAQ/D,MAAM,OAAO,oBAAqB,SAAQ,YAAY;IAmBpD,YACU,EAAsB,EACtB,kBAA2C;QAEnD,KAAK,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAHf,OAAE,GAAF,EAAE,CAAoB;QACtB,uBAAkB,GAAlB,kBAAkB,CAAyB;QAf5C,kBAAa,GAAW,CAAC,CAAC;QAG5B,cAAS,GAAG,wBAAwB,CAAC;QACrC,wBAAmB,GAAG,QAAQ,CAAC;QAC/B,iBAAY,GAAG,mBAAmB,CAAC;QACnC,WAAM,GAAG,YAAY,CAAC,EAAE,EAAE;YAC/B,SAAS,EAAE,IAAI;YACf,SAAS,EAAE,IAAI;YACf,OAAO,EAAE,KAAK;YACd,iBAAiB,EAAE,KAAK;SACzB,CAAC,CAAC;IAOH,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,EAAE;YAC9B,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,UAAU,EAAE,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC;SACrD;QACD,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,UAAU,CAAqB,CAAC;QAC9D,IAAI,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC,MAAM,EAAE,WAAW,EAAE,EAAE;YAC/C,MAAM,YAAY,GAAG,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;YAC7C,IAAI,MAAM,CAAC,eAAe,EAAE;gBAC1B,YAAY,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,kBAAkB,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC;aACtE;YACD,YAAY,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,sBAAsB,EAAE,CAAC;YACnD,IAAI,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,WAAW,EAAE;gBACxD,MAAM,4BAA4B,GAAG,YAAY,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC,KAAyD,CAAC;gBACrI,4BAA4B,CAAC,SAAS,CAAC,eAAe,CAAC,EAAE;oBACvD,IAAI,eAAe,EAAE;wBACnB,eAAe,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,GAAG,EAAE;4BAC/C,IAAI,eAAe,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC,MAAM,CAAC,YAAY,IAAI,IAAI,CAAC,yBAAyB,CAAC,EAAE;gCACzF,MAAM,KAAK,GAAG,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;gCACrE,YAAY,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;6BAC3C;wBACH,CAAC,CAAC,CAAC;qBACJ;gBACH,CAAC,CAAC,CAAC;aACJ;YACD,IACE,MAAM,CAAC,YAAY;gBACnB,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,YAAY;gBACrD,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,WAAW;gBACpD,IAAI,CAAC,yBAAyB,EAC9B;gBACA,IAAI,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,YAAY,EAAE;oBACzD,MAAM,0BAA0B,GAAG,YAAY,CAAC,GAAG,CAAC,qBAAqB,CAAC,CAAC,KAAoE,CAAC;oBAChJ,IAAI,0BAA0B,EAAE;wBAC9B,0BAA0B,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE,CAAC,YAAY,CAAC,GAAG,CAAC,6BAA6B,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC;qBACtH;iBACF;gBACD,YAAY,CAAC,GAAG,CAAC,OAAO,CAAC;qBACZ,YAAY;qBACZ,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC;qBACvB,SAAS,CAAC,KAAK,EAAC,KAAK,EAAC,EAAE;oBACvB,MAAM,IAAI,CAAC,oBAAoB,CAAC,YAAY,CAAC,CAAC;oBAC9C,IAAI,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,YAAY,EAAE;wBACzD,IACE,KAAK,IAAI,CACP,KAAK,CAAC,cAAc,CAAC,OAAO,CAAC;4BAC7B,KAAK,CAAC,cAAc,CAAC,MAAM,CAAC;4BAC5B,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,MAAM,KAAK,CAAC,CAChC,IAAI,CACH,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC;4BACpB,YAAY,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,KAAK,CACnC,EAAE;4BACH,IAAI,YAAY,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,KAAK,EAAE;gCACtC,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;oCACxB,YAAY,CAAC,GAAG,CAAC,2BAA2B,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;oCAC9D,YAAY,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,EAAE,EAAC,SAAS,EAAE,KAAK,EAAC,CAAC,CAAC;iCACjF;qCAAM;oCACL,IAAI,IAAI,CAAC,0BAA0B,CAAC,YAAY,CAAC,GAAG,CAAC,2BAA2B,CAAC,CAAC,KAAK,EAAE,KAAK,CAAC,EAAE;wCAC/F,YAAY,CAAC,GAAG,CAAC,2BAA2B,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;qCACjE;iCACF;gCAED,MAAM,iBAAiB,GAAG,QAAQ,CAAC,aAAa,CAAmB,IAAI,IAAI,CAAC,MAAM,uBAAuB,YAAY,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC;gCAC5I,IAAI,iBAAiB,EAAE;oCACrB,iBAAiB,CAAC,KAAK,GAAG,EAAE,CAAC;iCAC9B;6BACF;iCAAM;gCACL,YAAY,CAAC,GAAG,CAAC,2BAA2B,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;6BAC/D;yBACF;6BAAM,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,KAAK,EAAE;4BAC9C,YAAY,CAAC,GAAG,CAAC,2BAA2B,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC;iCAC1E,KAAK,EAAkC;iCACvC,MAAM,CAAC,YAAY,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,MAAM,CAAC;iCAC9C,QAAQ,EAAE,CAAC,CAAC,CAAC,EAAE,+BAA+B,IAAI,IAAI,CAAC,CAAC;yBAC5D;wBAED,IAAI,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,YAAY,EAAE;4BACzD,IAAI,MAAM,CAAC,gBAAgB,KAAK,KAAK,EAAE;gCACrC,MAAM,0BAA0B,GAAG,YAAY,CAAC,GAAG,CAAC,qBAAqB,CAAC,CAAC,KAAoE,CAAC;gCAChJ,YAAY,CAAC,GAAG,CAAC,6BAA6B,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,kBAAkB,CAChF,0BAA0B,CAAC,KAAK,EAChC,KAAK,CACN,CAAC,CAAC;6BACJ;iCAAM,IAAI,MAAM,CAAC,gBAAgB,KAAK,UAAU,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;gCAC9E,MAAM,MAAM,GAAG,YAAY,CAAC,GAAG,CAAC,qBAAqB,CAAC,CAAC,KAAiC,CAAC;gCACzF,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gCAClB,MAAM,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE;oCACnD,YAAY,CAAC,GAAG,CAAC,6BAA6B,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;oCACpE,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gCACrB,CAAC,CAAC,CAAC;6BACJ;yBACF;qBACF;oBACD,IAAI,MAAM,CAAC,YAAY,EAAE;wBACvB,IAAI,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,YAAY,EAAE;4BACzD,MAAM,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,KAAK,CAAC,CAAC;gCACpC,YAAY,CAAC,GAAG,CAAC,2BAA2B,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;gCAC7E,YAAY,CAAC,GAAG,CAAC,2BAA2B,CAAC,CAAC,KAAK,EAAE,KAAK,CAC9E,CAAC,CAAC;yBACJ;6BAAM;4BACL,MAAM,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;yBAC5B;qBACF;gBACH,CAAC,CAAC,CAAC;aAChB;YACD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YACjC,IAAI,MAAM,CAAC,eAAe,EAAE;gBAC1B,IAAI,MAAM,CAAC,iBAAiB,GAAG,CAAC,EAAE;oBAChC,KAAK,IAAI,GAAG,GAAG,CAAC,EAAE,GAAG,GAAG,MAAM,CAAC,iBAAiB,EAAE,GAAG,EAAE,EAAE;wBACvD,IAAI,GAAG,IAAI,MAAM,CAAC,iBAAiB,EAAE;4BACnC,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC;yBAC/B;qBACF;iBACF;gBACD,IAAI,MAAM,CAAC,eAAe,CAAC,SAAS,EAAE;oBACpC,MAAM,CAAC,eAAe;yBACf,SAAS;yBACT,SAAS,CAAC,KAAK,EAAC,MAAM,EAAC,EAAE;wBACxB,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE;4BACrB,MAAM,CAAC,OAAO,CAAC,CAAC,SAAS,EAAE,UAAU,EAAE,EAAE;gCACvC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC,KAAK,CAAC,UAAU,CAAC,EAAE;oCACjF,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC;iCAC/B;gCACD,UAAU,CAAC,GAAG,EAAE;oCACd,IAAI,CAAC,iBAAiB,CACpB,SAAS,EACT,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,IAAI,CAClF,CAAC;gCACJ,CAAC,EAAE,GAAG,CAAC,CAAC;4BACV,CAAC,CAAC,CAAC;yBACJ;oBACH,CAAC,CAAC,CAAC;iBACV;aACF;QACH,CAAC,CAAC,CAAC;QACH,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;SACzD;QACD,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;SACnD;IACH,CAAC;IAEM,4BAA4B,CAAC,KAAU;QAC5C,OAAO,CAAC,CAAC,KAAK,IAAI,OAAO,KAAK,KAAK,QAAQ,CAAC;IAC9C,CAAC;IAEM,wBAAwB,CAAC,KAAa,EAAE,KAAoB;QACjE,MAAM,OAAO,GAAG,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,KAAK,CAAC,CAAC;QAC/C,MAAM,IAAI,GAAG,OAAO,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC,KAAiC,CAAC;QACpE,IAAI,IAAI,KAAK,wBAAwB,CAAC,eAAe,EAAE;YACrD,MAAM,KAAK,GAAG,OAAO,EAAE,GAAG,CAAC,OAAO,CAAC,CAAC,KAAK,CAAC;YAC1C,IAAI,KAAK,CAAC,GAAG,IAAI,WAAW,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE;gBAChD,IAAI,CAAC,mBAAmB,GAAG,QAAQ,CAAC;aACrC;iBAAM,IAAI,KAAK,CAAC,GAAG,IAAI,WAAW,IAAI,KAAK,CAAC,MAAM,IAAI,CAAC,EAAE;gBACxD,IAAI,CAAC,mBAAmB,GAAG,QAAQ,CAAC;aACrC;SACF;IACH,CAAC;IAEM,YAAY,CAAC,KAAa;QAC/B,MAAM,OAAO,GAAG,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,KAAK,CAAC,CAAC;QAC/C,MAAM,YAAY,GAAG,CAAC,OAAO,EAAE,GAAG,CAAC,cAAc,CAAC,CAAC,KAAK,CAAC;QACzD,OAAO,EAAE,GAAG,CAAC,cAAc,CAAC,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC;QACpD,OAAO,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC;YACd,wBAAwB,CAAC,QAAQ,CAAC,CAAC;YACnC,wBAAwB,CAAC,IAAI,CAC1D,CAAC;IACJ,CAAC;IAEM,WAAW,CAAC,SAAiB;QAClC,IAAI,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC,KAAK,EAAE;YAC5I,MAAM,SAAS,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;YACpC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC;gBAClE,IAAI,EAAE,SAAS;gBACf,UAAU,EAAE,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,eAAe,CAAC,UAAU;gBACjE,UAAU,EAAE,IAAI,eAAe,CAAqD,EAAE,CAAC;gBACvF,yBAAyB,EAAE,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,eAAe,CAAC,gBAAgB;aACvF,CAAC,CAAC;YACH,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC,QAAQ,CACjE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAC1E,CAAC;YACF,MAAM,kBAAkB,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,oBAAoB,CAAqB,CAAC;YAC3G,kBAAkB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;SACpC;IACH,CAAC;IAEM,cAAc,CAAC,SAAiB,EAAE,WAAW;QAClD,MAAM,iBAAiB,GAAG,WAAW,GAAG,CAAC,CAAC;QAC1C,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC;QACtF,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC,QAAQ,CAAC,CAAC,iBAAiB,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC;QACvH,CAAC,EAAE,EAAE,CAAC,CAAC;IACT,CAAC;IAEM,iBAAiB,CAAC,SAAiB;QACxC,IAAI,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,KAAK,EAAE;YAC3D,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,2BAA2B,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;YAChF,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;SAC/D;aAAM;YACL,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,2BAA2B,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,+BAA+B,IAAI,IAAI,CAAC,CAAC;YAChJ,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,+BAA+B,IAAI,IAAI,CAAC,CAAC;SAC7H;IACH,CAAC;IAEM,OAAO,CAAC,MAAiD;QAC9D,OAAO,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC;IAC1C,CAAC;IAEM,0BAA0B,CAAC,SAAiB,EAAE,MAAgD;QACnG,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,2BAA2B,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,KAAK,MAAM,CAA+C,CAAC;QACrK,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,2BAA2B,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QACnF,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE;YACtB,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,2BAA2B,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;YAChF,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;SAC/D;aAAM,IAAI,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,YAAY,EAAE;YAClD,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,YAAY,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;SACxE;IACH,CAAC;IAEM,YAAY,CAAC,MAA2D;QAC7E,OAAO,MAAM,CAAC,KAAK,CAAC;IACtB,CAAC;IAEM,sBAAsB,CAAC,WAA4B;QACxD,OAAO,WAAW,CAAC,GAAG,CAAC,6BAA6B,CAAC,CAAC,KAA+B,CAAC;IACxF,CAAC;IAEM,oBAAoB,CAAC,WAA4B;QACtD,OAAO,WAAW,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC,KAAyD,CAAC;IACxG,CAAC;IAEM,eAAe;QACpB,OAAO,YAAY,CAAC,EAAE,EAAE;YACtB,SAAS,EAAE,IAAI;YACf,OAAO,EAAE,IAAI;YACb,iBAAiB,EAAE,KAAK;YACxB,SAAS,EAAE,IAAI;SAChB,CAAC,CAAC;IACL,CAAC;IAEO,UAAU,CAAC,MAAsC;QACvD,IAAI,UAAU,GAAG,MAAM,CAAC,cAAc,IAAI,EAAE,CAAC;QAC7C,IAAI,KAAK,GAAQ,MAAM,CAAC,KAAK,IAAI,EAAE,CAAC;QACpC,IAAI,yBAAyB,GAA0F,CACrH,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,+BAA+B,IAAI,IAAI,CAAC,CACxE,CAAC;QAEF,IAAI,MAAM,CAAC,QAAQ,KAAK,IAAI;YAAE,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;QACnE,IAAI,MAAM,CAAC,GAAG,IAAI,OAAO,MAAM,CAAC,GAAG,KAAK,QAAQ;YAAE,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;QAC9F,IAAI,MAAM,CAAC,GAAG,IAAI,OAAO,MAAM,CAAC,GAAG,KAAK,QAAQ;YAAE,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;QAC9F,IACE,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,IAAI;YAC7C,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,QAAQ;YACjD,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,IAAI,EAC7C;YACA,IAAI,MAAM,CAAC,GAAG,IAAI,OAAO,MAAM,CAAC,GAAG,KAAK,QAAQ,EAAE;gBAAE,UAAU,CAAC,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;aAAE;YACpG,IAAI,MAAM,CAAC,GAAG,IAAI,OAAO,MAAM,CAAC,GAAG,KAAK,QAAQ,EAAE;gBAAE,UAAU,CAAC,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;aAAE;SACrG;QACD,IAAI,MAAM,CAAC,SAAS;YAAE,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC;QAC9E,IAAI,MAAM,CAAC,SAAS;YAAE,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC;QAE9E,IAAI,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,GAAG,EAAE;YAChD,UAAU,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;SAC/B;aAAM,IAAI,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,IAAI,EAAE;YACxD,UAAU,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;SAChC;aAAM,IAAI,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,KAAK,EAAE;YACzD,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;SACnC;aAAM,IAAI,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,YAAY,EAAE;YAChE,IAAI,KAAK,EAAE;gBACT,yBAAyB,GAAG,KAAK,CAAC;gBAClC,KAAK,GAAG,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,yBAAyB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;aAClE;YACD,IAAI,MAAM,CAAC,QAAQ,KAAK,IAAI,EAAE;gBAC5B,UAAU,CAAC,IAAI,CAAC,6BAA6B,CAAC,CAAC;aAChD;SACF;aAAM,IAAI,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,QAAQ,EAAE;YAC5D,KAAK,GAAG,MAAM,CAAC,KAAK,IAAI,KAAK,CAAC;SAC/B;QAED,IACE,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,eAAe;YACxD,KAAK,CAAC,MAAM,IAAI,CAAC,EACjB;YACA,IAAI,CAAC,mBAAmB,GAAG,QAAQ,CAAC;SACrC;QAED,IAAI,MAAM,CAAC,iBAAiB,EAAE;YAC5B,MAAM,sBAAsB,GAAG,EAAqC,CAAC;YACrE,MAAM,CAAC,MAAM,CAAC,sBAAsB,EAAE,MAAM,CAAC,iBAAiB,CAAC,CAAC;YAChE,sBAAsB,CAAC,IAAI,GAAG,MAAM,CAAC,iBAAiB,CAAC,IAAI,CAAC;YAC5D,MAAM,CAAC,iBAAiB,GAAG,sBAAsB,CAAC;SACnD;QAED,IAAI,MAAM,CAAC,IAAI,KAAK,KAAK,EAAE;YACzB,UAAU,GAAG,EAAE,CAAC;SACjB;QAED,MAAM,KAAK,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC;YAC1B,IAAI,EAAE,CAAC,IAAI,eAAe,CAAU,MAAM,CAAC,IAAI,IAAI,IAAI,CAAC,CAAC;YACzD,KAAK,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC;YACrB,IAAI,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC;YACnB,IAAI,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC;YACnB,gBAAgB,EAAE,CAAC;oBACjB,IAAI,EAAE,MAAM,EAAE,gBAAgB,EAAE,IAAI,IAAI,aAAa;oBACrD,IAAI,EAAE,MAAM,EAAE,gBAAgB,EAAE,IAAI,IAAI,6BAA6B;oBACrE,eAAe,EAAE,MAAM,EAAE,gBAAgB,EAAE,eAAe,IAAI,OAAO;oBACrE,KAAK,EAAE,MAAM,EAAE,gBAAgB,EAAE,KAAK,IAAI,MAAM;oBAChD,MAAM,EAAE,MAAM,EAAE,gBAAgB,EAAE,MAAM,IAAI,GAAG;iBAChD,CAAC;YACF,iBAAiB,EAAE,CAAC,IAAI,eAAe,CAAkC,MAAM,CAAC,iBAAiB,CAAC,CAAC;YACnG,gBAAgB,EAAE,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC;YACnC,UAAU,EAAE,CAAC,MAAM,CAAC,UAAU,CAAC;YAC/B,UAAU,EAAE,CAAC,MAAM,CAAC,UAAU,CAAC;YAC/B,WAAW,EAAE,CAAC,MAAM,CAAC,WAAW,CAAC;YACjC,KAAK,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC;YACrB,UAAU,EAAE,CAAC,MAAM,CAAC,UAAU,CAAC;YAC/B,QAAQ,EAAE,CAAC,MAAM,CAAC,QAAQ,CAAC;YAC3B,QAAQ,EAAE,CAAC,MAAM,CAAC,QAAQ,IAAI,KAAK,CAAC;YACpC,GAAG,EAAE,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC,CAAC;YACtB,GAAG,EAAE,CAAC,MAAM,CAAC,GAAG,IAAI,WAAW,CAAC;YAChC,SAAS,EAAE,CAAC,MAAM,CAAC,SAAS,IAAI,CAAC,CAAC;YAClC,SAAS,EAAE,CAAC,MAAM,CAAC,SAAS,IAAI,GAAG,CAAC;YACpC,QAAQ,EAAE,CAAC,MAAM,CAAC,QAAQ,IAAI,KAAK,CAAC;YACpC,KAAK,EAAE,CAAC,MAAM,CAAC,KAAK,IAAI,KAAK,CAAC;YAC9B,QAAQ,EAAE,CAAC,MAAM,CAAC,QAAQ,IAAI,KAAK,CAAC;YACpC,YAAY,EAAE,CAAC,MAAM,CAAC,YAAY,IAAI,EAAE,CAAC;YACzC,YAAY,EAAE,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI;YAC7E,2BAA2B,EAAE,CAAC,MAAM,CAAC,2BAA2B,CAAC;YACjE,iBAAiB,EAAE,CAAC,MAAM,CAAC,iBAAiB,IAAI,CAAC,CAAC;YAClD,iBAAiB,EAAE,CAAC,MAAM,CAAC,iBAAiB,IAAI,GAAG,CAAC;YACpD,aAAa,EAAE,CAAC,MAAM,CAAC,aAAa,CAAC;YACrC,sBAAsB,EAAE,CAAC,MAAM,CAAC,sBAAsB,CAAC;YACvD,4BAA4B,EAAE,CAAC,MAAM,CAAC,4BAA4B,CAAC;YACnE,iBAAiB,EAAE,CAAC,EAAE,CAAC;YACvB,eAAe,EAAE,CAAC,EAAE,CAAC;YACrB,kBAAkB,EAAE,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC;YACrC,mBAAmB,EAAE,CAAC,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;YAC1D,mBAAmB,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAAC;YACjD,0BAA0B,EAAE,CAAC,MAAM,CAAC,0BAA0B,CAAC;YAC/D,2BAA2B,EAAE,CAAC,IAAI,eAAe,CAAM,EAAE,CAAC,CAAC;YAC3D,yBAAyB,EAAE,CAAC,yBAAyB,CAAC;YACtD,qBAAqB,EAAE,CAAC,MAAM,CAAC,qBAAqB,CAAC;YACrD,QAAQ,EAAE,CAAC,MAAM,EAAE,OAAO,CAAC;YAC3B,UAAU,EAAE,CAAC,MAAM,EAAE,UAAU,CAAC;YAChC,2BAA2B,EAAE,CAAC,MAAM,EAAE,2BAA2B,IAAI,EAAE,CAAC;YACxE,gBAAgB,EAAE,CAAC,MAAM,EAAE,gBAAgB,IAAI,EAAE,CAAC;YAClD,gBAAgB,EAAE,CAAC,MAAM,EAAE,gBAAgB,IAAI,EAAE,CAAC;YAClD,KAAK,EAAE,CAAC,EAAC,KAAK,EAAE,QAAQ,EAAE,MAAM,CAAC,QAAQ,EAAC,EAAE,UAAU,EAAE,MAAM,CAAC,eAAe,CAAC;SAChF,CAAC,CAAC;QAEH,IAAI,MAAM,CAAC,gBAAgB,KAAK,UAAU,EAAE;YAC1C,MAAM,MAAM,GAAG,KAAK,CAAC,GAAG,CAAC,qBAAqB,CAAC,CAAC,KAAiC,CAAC;YAClF,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAClB,MAAM,CAAC,kBAAkB,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE;gBAChD,KAAK,CAAC,GAAG,CAAC,6BAA6B,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;gBAC7D,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACrB,CAAC,CAAC,CAAC;SACJ;QAED,OAAO,KAAK,CAAC;IACf,CAAC;IAEO,iBAAiB,CAAC,OAAyD,EAAE,IAAsB;QACzG,OAAO,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE;YACvB,IAAI,IAAI,EAAE;gBACR,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,UAAU,CAAqB,CAAC;gBAC3D,KAAK,MAAM,IAAI,IAAI,IAAI,CAAC,MAAM,EAAE,EAAE;oBAChC,IAAI,CAAC,cAAc,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;iBACtC;aACF;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,sBAAsB,CAAC,OAA8D,EAAE,IAAsB;QACnH,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE;YAC7C,IAAI,IAAI,EAAE;gBACR,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,UAAU,CAAqB,CAAC;gBAC3D,KAAK,MAAM,IAAI,IAAI,IAAI,CAAC,MAAM,EAAE,EAAE;oBAChC,KAAK,MAAM,CAAC,YAAY,EAAE,OAAO,CAAC,IAAI,SAAS,CAAC,QAAQ,CAAC,OAAO,EAAE,EAAE;wBAClE,IAAI,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,KAAK,KAAK,IAAI,CAAC,IAAI,EAAE;4BAC3C,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;4BAC1C,MAAM,MAAM,GAAmC,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC,IAAI,IAAI,CAAC;4BACrF,IAAI,IAAI,CAAC,IAAI,EAAE;gCACb,IAAI,UAAU,GAAG,EAAE,CAAC;gCACpB,IAAI,MAAM,EAAE;oCACV,IAAI,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,WAAW,EAAE;wCACxD,MAAM,kBAAkB,GAAG,OAAO,CAAC,GAAG,CAAC,kBAAkB,CAAqB,CAAC;wCAC/E,kBAAkB,CAAC,IAAI,CAAC,MAAM,EAAE,iBAAiB,EAAE,IAAI,CAAC,CAAC;qCAC1D;yCAAM;wCACL,UAAU,GAAG,MAAM,CAAC,cAAc,IAAI,EAAE,CAAC;wCACzC,IAAI,MAAM,CAAC,QAAQ,KAAK,IAAI,EAAE;4CAC5B,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;yCACtC;wCACD,IAAI,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,GAAG,EAAE;4CAChD,UAAU,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;yCAC/B;6CAAM,IAAI,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,IAAI,EAAE;4CACxD,UAAU,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;yCAChC;6CAAM,IAAI,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,KAAK,EAAE;4CACzD,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;yCACnC;6CAAM,IACL,MAAM,CAAC,QAAQ,KAAK,IAAI;4CACxB,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,YAAY,EACrD;4CACA,UAAU,CAAC,IAAI,CAAC,6BAA6B,CAAC,CAAC;yCAChD;wCAED,IAAI,MAAM,CAAC,GAAG,IAAI,OAAO,MAAM,CAAC,GAAG,KAAK,QAAQ;4CAAE,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;wCAC9F,IAAI,MAAM,CAAC,GAAG,IAAI,OAAO,MAAM,CAAC,GAAG,KAAK,QAAQ;4CAAE,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;wCAC9F,IACE,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,IAAI;4CAC7C,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,QAAQ;4CACjD,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,IAAI,EAC7C;4CACA,IAAI,MAAM,CAAC,GAAG,IAAI,OAAO,MAAM,CAAC,GAAG,KAAK,QAAQ,EAAE;gDAAE,UAAU,CAAC,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;6CAAE;4CACpG,IAAI,MAAM,CAAC,GAAG,IAAI,OAAO,MAAM,CAAC,GAAG,KAAK,QAAQ,EAAE;gDAAE,UAAU,CAAC,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;6CAAE;yCACrG;wCACD,IAAI,MAAM,CAAC,SAAS;4CAAE,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC;wCAC9E,IAAI,MAAM,CAAC,SAAS;4CAAE,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC;wCAE9E,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;wCAC/C,IAAI,MAAM,CAAC,eAAe,EAAE;4CAC1B,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,kBAAkB,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC;yCACjE;qCACF;oCAED,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,sBAAsB,EAAE,CAAC;oCAC9C,IAAI,IAAI,CAAC,iBAAiB,EAAE;wCAC1B,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;qCACrC;iCACF;6BACF;iCAAM;gCACL,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,eAAe,EAAE,CAAC;gCACvC,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,oBAAoB,EAAE,CAAC;gCAC5C,OAAO,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;gCACxB,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;gCACpC,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,sBAAsB,EAAE,CAAC;gCAE9C,IAAI,MAAM,CAAC,IAAI,KAAK,wBAAwB,CAAC,WAAW,EAAE;oCACxD,MAAM,SAAS,GAAG,OAA2B,CAAC;oCAC9C,SAAS,CAAC,aAAa,CAAC,kBAAkB,CAAC,CAAC;oCAC5C,SAAS,CAAC,UAAU,CAAC,kBAAkB,EAAE,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC;iCAC7D;6BACF;4BACD,MAAM;yBACP;qBACF;iBACF;aACF;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,kBAAkB,CAAC,GAA+C,EAAE,KAAa;QACvF,OAAO,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE;YACzB,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;gBAC7B,IAAI,MAAM,EAAE;oBACV,IAAI,IAAI,GAAG,IAAI,CAAC;oBAChB,KAAK,CAAC,WAAW,EAAE;yBACb,KAAK,CAAC,GAAG,CAAC;yBACV,OAAO,CAAC,IAAI,CAAC,EAAE;wBACd,IAAI,MAAM,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE;4BAC/C,IAAI,GAAG,KAAK,CAAC;4BACb,OAAO,KAAK,CAAC;yBACd;oBACH,CAAC,CAAC,CAAC;oBAER,OAAO,IAAI,CAAC;iBACb;aACF;iBAAM;gBACL,OAAO,IAAI,CAAC;aACb;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,cAAc,CAAC,SAA2B,EAAE,IAAmC;QACrF,IAAI,SAAS,EAAE;YACb,IAAI,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE;gBACjC,IAAI,kBAAoE,CAAC;gBACzE,MAAM,WAAW,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;gBAC3C,IAAI,aAAa,GAAG,CAAC,CAAC;gBACtB,GAAG;oBACD,MAAM,OAAO,GAAG,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,KAAK,KAAK,WAAW,CAAC,aAAa,CAAC,CAAC,CAAC;oBAC7G,IAAI,aAAa,KAAK,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE;wBAC5C,kBAAkB,GAAG,OAAO,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC,KAAK,CAAC;wBAC5D,MAAM,WAAW,GAAG,kBAAkB,CAAC,QAAQ,EAAE,CAAC;wBAClD,IAAI,WAAW,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,IAAI,KAAK,WAAW,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,EAAE;4BACtF,IAAI,WAAW,CAAC,SAAS,EAAE;gCACzB,WAAW,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC,CAAC,KAAK,EAAO,CAAC,KAAK,CAAC,CAAC;wCACrF,IAAI,EAAE,WAAW,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,CAAC;wCACzC,KAAK,EAAE,IAAI,CAAC,KAAK;qCAClB,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC;6BACjB;iCAAM;gCACL,WAAW,CAAC,SAAS,GAAG,IAAI,eAAe,CAAkC,CAAC;wCAC5E,IAAI,EAAE,WAAW,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,CAAC;wCACzC,KAAK,EAAE,IAAI,CAAC,KAAK;qCAClB,CAAC,CAAC,CAAC;6BACL;yBACF;qBACF;oBACD,aAAa,EAAE,CAAC;iBACjB,QAAQ,aAAa,GAAG,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE;aAClD;iBAAM;gBACL,KAAK,MAAM,OAAO,IAAI,SAAS,CAAC,QAAQ,CAAC,MAAM,EAAE,EAAE;oBACjD,IAAI,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,KAAK,KAAK,IAAI,CAAC,IAAI,EAAE;wBAC3C,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;wBAC1C,MAAM;qBACP;iBACF;aACF;SACF;IACH,CAAC;IAEO,KAAK,CAAC,oBAAoB,CAAC,YAA8B;QAC/D,IAAI,IAAI,CAAC,yBAAyB,EAAE;YAClC,MAAM,KAAK,GAAG,YAAY,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,KAAK,CAAC;YAC9C,MAAM,OAAO,GAAG,IAAI,CAAC,yBAAyB;iBACzB,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,SAAS,KAAK,YAAY,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,KAAK,CAAC;iBACrE,IAAI,CAAC,MAAM,CAAC,EAAE;gBACb,IAAI,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE;oBACxB,OAAO,CAAC,CAAC;iBACV;gBACD,OAAO,CAAC,CAAC,CAAC;YACZ,CAAC,CAAC,CAAC;YACvB,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE;gBAC5B,IAAI,MAAM,EAAE;oBACV,IAAI,MAAM,CAAC,iBAAiB,IAAI,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE;wBACpD,MAAM,wBAAwB,GAAG,IAAI,CAAC,QAAQ;6BACR,QAAQ;6BACR,IAAI,CAAC,OAAO,CAAC,EAAE,CACd,MAAM,CAAC,YAAY,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAC5D,CAAC;wBACvC,MAAM,wBAAwB,GAAG,wBAAwB,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC,KAAyD,CAAC;wBAC7I,wBAAwB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;wBACpC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC;wBACf,wBAAwB,CAAC,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC,CAAC;qBAChE;oBACD,IAAI,CAAC,kBAAkB,CAAC,UAAU,CAChC,IAAI,CAAC,UAAU,EACf,MAAM,CAAC,YAAY,EACnB,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,EACpB,MAAM,CAAC,iBAAiB,CACzB,CAAC;iBACH;aACF;SACF;IACH,CAAC;IAEO,0BAA0B,CAAC,cAA0D,EAAE,KAA+C;QAC5I,IAAI,OAAO,GAAG,IAAI,CAAC;QAEnB,KAAK,MAAM,YAAY,IAAI,cAAc,CAAC,MAAM,EAAE,EAAE;YAClD,IAAI,YAAY,CAAC,IAAI,KAAK,KAAK,CAAC,IAAI,EAAE;gBACpC,OAAO,GAAG,KAAK,CAAC;gBAChB,MAAM;aACP;SACF;QAED,OAAO,OAAO,CAAC;IACjB,CAAC;;iHAvkBU,oBAAoB;qGAApB,oBAAoB,+QC/BjC,ix6BA2kBA,wlRD5iBa,oBAAoB;2FAApB,oBAAoB;kBANhC,SAAS;+BACE,oBAAoB,mBAGb,uBAAuB,CAAC,MAAM;+IAGtC,IAAI;sBAAZ,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,yBAAyB;sBAAjC,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,aAAa;sBAArB,KAAK","sourcesContent":["import { UntypedFormArray, UntypedFormBuilder, UntypedFormGroup, Validators, AbstractControl } from '@angular/forms';\nimport { KoalaDynamicFormFieldInterface } from './interfaces/koala.dynamic-form-field.interface';\nimport { DynamicFormTypeFieldEnum } from './enums/dynamic-form-type-field.enum';\nimport { CpfValidator } from './validators/cpf.validator';\nimport { CnpjValidator } from './validators/cnpj.validator';\nimport { ChangeDetectionStrategy, Component, ElementRef, Input, OnInit, ViewChild } from '@angular/core';\nimport { FormAbstract } from '../form.abstract';\nimport { debounceTime } from 'rxjs/operators';\nimport { BehaviorSubject } from 'rxjs';\nimport { KoalaDynamicSetValueInterface } from './interfaces/koala.dynamic-set-value.interface';\nimport { AutocompleteSelectedValidator } from './validators/autocomplete-selected.validator';\nimport { KoalaDynamicAutocompleteOptionsInterface } from './interfaces/koala.dynamic-autocomplete-options.interface';\nimport { KoalaDynamicFormShowFieldInterface } from './interfaces/koala.dynamic-form-show-field.interface';\nimport { KoalaDynamicFormService } from './koala.dynamic-form.service';\nimport { KoalaDynamicFormMoreItensShowFieldConfigInterface } from './interfaces/koala.dynamic-form-more-itens-show-field-config.interface';\nimport { ThemePalette } from '@angular/material/core';\nimport { KoalaDynamicFormAutocompleteMultipleConfigInterface } from './interfaces/koala.dynamic-form-autocomplete-multiple-config.interface';\nimport { KoalaDynamicFormConfigInterface } from './interfaces/koala.dynamic-form-config.interface';\nimport { delay } from \"@koalarx/utils/operators/delay\";\nimport { koala } from \"@koalarx/utils\";\nimport { DateMinValidator } from \"./validators/date-min.validator\";\nimport { DateMaxValidator } from \"./validators/date-max.validator\";\nimport { KoalaLanguageHelper } from \"@koalarx/ui/core\";\nimport { randomString } from \"@koalarx/utils/operators/string\";\n\n@Component({\n  selector: 'koala-dynamic-form',\n  templateUrl: 'dynamic-form.component.html',\n  styleUrls: ['dynamic-form.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DynamicFormComponent extends FormAbstract implements OnInit {\n  @Input() form: UntypedFormGroup;\n  @Input() formConfig: KoalaDynamicFormFieldInterface[];\n  @Input() showFields: BehaviorSubject<KoalaDynamicFormShowFieldInterface[]>;\n  @Input() showFieldsMoreItensConfig: KoalaDynamicFormMoreItensShowFieldConfigInterface[];\n  @Input() setValues: BehaviorSubject<KoalaDynamicSetValueInterface[]>;\n  @Input() tabIndexStart: number = 1;\n\n  public controls: UntypedFormArray;\n  public typeField = DynamicFormTypeFieldEnum;\n  public hoursAndMinutesMask = '00:000';\n  public errorMessage = KoalaLanguageHelper;\n  public formId = randomString(25, {\n    lowercase: true,\n    uppercase: true,\n    numbers: false,\n    specialCharacters: false\n  });\n\n  constructor(\n    private fb: UntypedFormBuilder,\n    private dynamicFormService: KoalaDynamicFormService\n  ) {\n    super(() => this.form);\n  }\n\n  ngOnInit() {\n    if (!this.form.get('formData')) {\n      this.form.addControl('formData', this.fb.array([]));\n    }\n    this.controls = this.form.get('formData') as UntypedFormArray;\n    this.formConfig?.forEach((config, indexConfig) => {\n      const newFormGroup = this.newControl(config);\n      if (config.asyncValidators) {\n        newFormGroup.get('value').setAsyncValidators(config.asyncValidators);\n      }\n      newFormGroup.get('value').updateValueAndValidity();\n      if (config.type === DynamicFormTypeFieldEnum.dynamicForm) {\n        const formGroupDynamicFormsSubject = newFormGroup.get('dynamicFormConfig').value as BehaviorSubject<KoalaDynamicFormConfigInterface>;\n        formGroupDynamicFormsSubject.subscribe(formGroupConfig => {\n          if (formGroupConfig) {\n            formGroupConfig.form.valueChanges.subscribe(() => {\n              if (formGroupConfig.form.valid && (config.valueChanges || this.showFieldsMoreItensConfig)) {\n                const value = this.dynamicFormService.emitData(formGroupConfig.form);\n                newFormGroup.get('value').setValue(value);\n              }\n            });\n          }\n        });\n      }\n      if (\n        config.valueChanges ||\n        config.type === DynamicFormTypeFieldEnum.autocomplete ||\n        config.type === DynamicFormTypeFieldEnum.dynamicForm ||\n        this.showFieldsMoreItensConfig\n      ) {\n        if (config.type === DynamicFormTypeFieldEnum.autocomplete) {\n          const autocompleteOptionsSubject = newFormGroup.get('autocompleteOptions').value as BehaviorSubject<KoalaDynamicAutocompleteOptionsInterface[]>;\n          if (autocompleteOptionsSubject) {\n            autocompleteOptionsSubject.subscribe(options => newFormGroup.get('autocompleteOptionsFiltered').value.next(options));\n          }\n        }\n        newFormGroup.get('value')\n                    .valueChanges\n                    .pipe(debounceTime(300))\n                    .subscribe(async value => {\n                      await this.setConfigDynamicForm(newFormGroup);\n                      if (config.type === DynamicFormTypeFieldEnum.autocomplete) {\n                        if (\n                          value && (\n                            value.hasOwnProperty('value') &&\n                            value.hasOwnProperty('name') &&\n                            Object.keys(value).length === 2\n                          ) || (\n                            Array.isArray(value) &&\n                            newFormGroup.get('multiple').value\n                          )) {\n                          if (newFormGroup.get('multiple').value) {\n                            if (Array.isArray(value)) {\n                              newFormGroup.get('autocompleteSelectedValue').setValue(value);\n                              newFormGroup.get('value').setValue(value[value.length - 1], {emitEvent: false});\n                            } else {\n                              if (this.validateAutocompleteSelect(newFormGroup.get('autocompleteSelectedValue').value, value)) {\n                                newFormGroup.get('autocompleteSelectedValue').value.push(value);\n                              }\n                            }\n\n                            const autocompleteInput = document.querySelector<HTMLInputElement>(`#${this.formId} input#autocomplete-${newFormGroup.get('name')?.value}`);\n                            if (autocompleteInput) {\n                              autocompleteInput.value = '';\n                            }\n                          } else {\n                            newFormGroup.get('autocompleteSelectedValue').setValue(value);\n                          }\n                        } else if (!newFormGroup.get('multiple').value) {\n                          newFormGroup.get('autocompleteSelectedValue').setValue(koala(this.formConfig)\n                            .array<KoalaDynamicFormFieldInterface>()\n                            .filter(newFormGroup.get('name').value, 'name')\n                            .getValue()[0]?.autocompleteDefaultValueOnClear ?? null);\n                        }\n\n                        if (config.type === DynamicFormTypeFieldEnum.autocomplete) {\n                          if (config.autocompleteType === 'all') {\n                            const autocompleteOptionsSubject = newFormGroup.get('autocompleteOptions').value as BehaviorSubject<KoalaDynamicAutocompleteOptionsInterface[]>;\n                            newFormGroup.get('autocompleteOptionsFiltered').value.next(this.autocompleteFilter(\n                              autocompleteOptionsSubject.value,\n                              value\n                            ));\n                          } else if (config.autocompleteType === 'onDemand' && typeof value !== \"object\") {\n                            const loader = newFormGroup.get('autocompleteLoading').value as BehaviorSubject<boolean>;\n                            loader.next(true);\n                            config.autocompleteFilter(value).subscribe(options => {\n                              newFormGroup.get('autocompleteOptionsFiltered').value.next(options);\n                              loader.next(false);\n                            });\n                          }\n                        }\n                      }\n                      if (config.valueChanges) {\n                        if (config.type === DynamicFormTypeFieldEnum.autocomplete) {\n                          config.valueChanges((newFormGroup.get('multiple').value ?\n                                               newFormGroup.get('autocompleteSelectedValue').value.map(item => item.value) :\n                                               newFormGroup.get('autocompleteSelectedValue').value?.value\n                          ));\n                        } else {\n                          config.valueChanges(value);\n                        }\n                      }\n                    });\n      }\n      this.controls.push(newFormGroup);\n      if (config.moreItemsConfig) {\n        if (config.moreItemsMinItems > 0) {\n          for (let min = 0; min < config.moreItemsMinItems; min++) {\n            if (min <= config.moreItemsMaxItems) {\n              this.addMoreItem(indexConfig);\n            }\n          }\n        }\n        if (config.moreItemsConfig.setValues) {\n          config.moreItemsConfig\n                .setValues\n                .subscribe(async values => {\n                  if (values.length > 0) {\n                    values.forEach((itemValue, indexValue) => {\n                      if (!this.controls.controls[indexConfig].get('moreItemsConfig').value[indexValue]) {\n                        this.addMoreItem(indexConfig);\n                      }\n                      setTimeout(() => {\n                        this.setValuesOnFields(\n                          itemValue,\n                          this.controls.controls[indexConfig].get('moreItemsConfig').value[indexValue].form\n                        );\n                      }, 300);\n                    });\n                  }\n                });\n        }\n      }\n    });\n    if (this.showFields) {\n      this.changeVisibilityFields(this.showFields, this.form);\n    }\n    if (this.setValues) {\n      this.setValuesOnFields(this.setValues, this.form);\n    }\n  }\n\n  public isValidNewAutocompleteOption(value: any) {\n    return !!value && typeof value === 'string';\n  }\n\n  public hoursAndMinutesApplyMask(index: number, event: KeyboardEvent) {\n    const control = this.controls?.controls[index];\n    const type = control?.get('type').value as DynamicFormTypeFieldEnum;\n    if (type === DynamicFormTypeFieldEnum.hoursAndMinutes) {\n      const value = control?.get('value').value;\n      if (event.key == 'Backspace' && value.length < 6) {\n        this.hoursAndMinutesMask = '00:000';\n      } else if (event.key != 'Backspace' && value.length >= 6) {\n        this.hoursAndMinutesMask = '000:00';\n      }\n    }\n  }\n\n  public passwordView(index: number) {\n    const control = this.controls?.controls[index];\n    const hidePassword = !control?.get('hidePassword').value;\n    control?.get('hidePassword').setValue(hidePassword);\n    control?.get('type').setValue(hidePassword ?\n                                  DynamicFormTypeFieldEnum.password :\n                                  DynamicFormTypeFieldEnum.text\n    );\n  }\n\n  public addMoreItem(propIndex: number) {\n    if (this.controls.controls[propIndex].get('moreItemsConfig').value.length < this.controls.controls[propIndex].get('moreItemsMaxItems').value) {\n      const formGroup = this.fb.group({});\n      this.controls.controls[propIndex].get('moreItemsConfig').value.push({\n        form: formGroup,\n        formConfig: this.formConfig[propIndex].moreItemsConfig.formConfig,\n        showFields: new BehaviorSubject<BehaviorSubject<KoalaDynamicSetValueInterface[]>[]>([]),\n        showFieldsMoreItensConfig: this.formConfig[propIndex].moreItemsConfig.showFieldsConfig\n      });\n      this.controls.controls[propIndex].get('moreItemsExpanded').setValue(\n        this.controls.controls[propIndex].get('moreItemsConfig').value.length - 1\n      );\n      const formArrayMoreItems = this.controls.controls[propIndex].get('moreItemsFormGroup') as UntypedFormArray;\n      formArrayMoreItems.push(formGroup);\n    }\n  }\n\n  public removeMoreItem(propIndex: number, removeIndex) {\n    const expandedItemIndex = removeIndex - 1;\n    this.controls.controls[propIndex].get('moreItemsConfig').value.splice(removeIndex, 1);\n    setTimeout(() => {\n      this.controls.controls[propIndex].get('moreItemsExpanded').setValue((expandedItemIndex < 0) ? 0 : expandedItemIndex);\n    }, 50);\n  }\n\n  public clearAutocomplete(propIndex: number) {\n    if (this.controls.controls[propIndex].get('multiple').value) {\n      this.controls.controls[propIndex].get('autocompleteSelectedValue').setValue([]);\n      this.controls.controls[propIndex].get('value').setValue(null);\n    } else {\n      this.controls.controls[propIndex].get('autocompleteSelectedValue').setValue(this.formConfig[propIndex].autocompleteDefaultValueOnClear ?? null);\n      this.controls.controls[propIndex].get('value').setValue(this.formConfig[propIndex].autocompleteDefaultValueOnClear ?? null);\n    }\n  }\n\n  public display(option?: KoalaDynamicAutocompleteOptionsInterface): string | undefined {\n    return option ? option.name : undefined;\n  }\n\n  public removeOptionOnAutocomplete(propIndex: number, option: KoalaDynamicAutocompleteOptionsInterface) {\n    const value = this.controls.controls[propIndex].get('autocompleteSelectedValue').value.filter(item => item !== option) as KoalaDynamicAutocompleteOptionsInterface[];\n    this.controls.controls[propIndex].get('autocompleteSelectedValue').setValue(value);\n    if (value.length === 0) {\n      this.controls.controls[propIndex].get('autocompleteSelectedValue').setValue([]);\n      this.controls.controls[propIndex].get('value').setValue(null);\n    } else if (this.formConfig[propIndex].valueChanges) {\n      this.formConfig[propIndex].valueChanges(value.map(item => item.value));\n    }\n  }\n\n  public getColorChip(config: KoalaDynamicFormAutocompleteMultipleConfigInterface): ThemePalette {\n    return config.color;\n  }\n\n  public getAutocompleteOptions(propriedade: AbstractControl) {\n    return propriedade.get('autocompleteOptionsFiltered').value as BehaviorSubject<any[]>;\n  }\n\n  public getDynamicFormConfig(propriedade: AbstractControl) {\n    return propriedade.get('dynamicFormConfig').value as BehaviorSubject<KoalaDynamicFormConfigInterface>;\n  }\n\n  public getRandomString() {\n    return randomString(20, {\n      lowercase: true,\n      numbers: true,\n      specialCharacters: false,\n      uppercase: true\n    });\n  }\n\n  private newControl(config: KoalaDynamicFormFieldInterface): UntypedFormGroup {\n    let validators = config.syncValidators ?? [];\n    let value: any = config.value ?? '';\n    let valueSelectedAutocomplete: KoalaDynamicAutocompleteOptionsInterface | KoalaDynamicAutocompleteOptionsInterface[] = (\n      config.multiple ? [] : (config.autocompleteDefaultValueOnClear ?? null)\n    );\n\n    if (config.required === true) validators.push(Validators.required);\n    if (config.min && typeof config.min === \"number\") validators.push(Validators.min(config.min));\n    if (config.max && typeof config.max === \"number\") validators.push(Validators.max(config.max));\n    if (\n      config.type === DynamicFormTypeFieldEnum.date ||\n      config.type === DynamicFormTypeFieldEnum.datetime ||\n      config.type === DynamicFormTypeFieldEnum.time\n    ) {\n      if (config.min && typeof config.min === \"string\") { validators.push(DateMinValidator(config.min)); }\n      if (config.max && typeof config.max === \"string\") { validators.push(DateMaxValidator(config.max)); }\n    }\n    if (config.minLength) validators.push(Validators.minLength(config.minLength));\n    if (config.maxLength) validators.push(Validators.maxLength(config.maxLength));\n\n    if (config.type === DynamicFormTypeFieldEnum.cpf) {\n      validators.push(CpfValidator);\n    } else if (config.type === DynamicFormTypeFieldEnum.cnpj) {\n      validators.push(CnpjValidator);\n    } else if (config.type === DynamicFormTypeFieldEnum.email) {\n      validators.push(Validators.email);\n    } else if (config.type === DynamicFormTypeFieldEnum.autocomplete) {\n      if (value) {\n        valueSelectedAutocomplete = value;\n        value = (config.multiple ? valueSelectedAutocomplete[0] : value);\n      }\n      if (config.required === true) {\n        validators.push(AutocompleteSelectedValidator);\n      }\n    } else if (config.type === DynamicFormTypeFieldEnum.checkbox) {\n      value = config.value ?? false;\n    }\n\n    if (\n      config.type === DynamicFormTypeFieldEnum.hoursAndMinutes &&\n      value.length >= 6\n    ) {\n      this.hoursAndMinutesMask = '000:00';\n    }\n\n    if (config.dynamicFormConfig) {\n      const cloneDynamicFormConfig = {} as KoalaDynamicFormConfigInterface;\n      Object.assign(cloneDynamicFormConfig, config.dynamicFormConfig);\n      cloneDynamicFormConfig.form = config.dynamicFormConfig.form;\n      config.dynamicFormConfig = cloneDynamicFormConfig;\n    }\n\n    if (config.show === false) {\n      validators = [];\n    }\n\n    const field = this.fb.group({\n      show: [new BehaviorSubject<boolean>(config.show ?? true)],\n      label: [config.label],\n      name: [config.name],\n      type: [config.type],\n      fileButtonConfig: [{\n        icon: config?.fileButtonConfig?.icon ?? 'attach_file',\n        text: config?.fileButtonConfig?.text ?? 'Clique para anexar arquivos',\n        backgroundColor: config?.fileButtonConfig?.backgroundColor ?? 'white',\n        color: config?.fileButtonConfig?.color ?? 'blue',\n        accept: config?.fileButtonConfig?.accept ?? '*'\n      }],\n      dynamicFormConfig: [new BehaviorSubject<KoalaDynamicFormConfigInterface>(config.dynamicFormConfig)],\n      dynamicFormGroup: this.fb.array([]),\n      appearance: [config.appearance],\n      floatLabel: [config.floatLabel],\n      placeholder: [config.placeholder],\n      class: [config.class],\n      fieldClass: [config.fieldClass],\n      textHint: [config.textHint],\n      required: [config.required ?? false],\n      min: [config.min ?? 0],\n      max: [config.max ?? 99999999999],\n      minLength: [config.minLength ?? 0],\n      maxLength: [config.maxLength ?? 255],\n      disabled: [config.disabled ?? false],\n      focus: [config.focus ?? false],\n      multiple: [config.multiple ?? false],\n      opcoesSelect: [config.opcoesSelect ?? []],\n      hidePassword: config.type === DynamicFormTypeFieldEnum.password ? true : null,\n      moreItemsButtonIconAddlabel: [config.moreItemsButtonIconAddlabel],\n      moreItemsMinItems: [config.moreItemsMinItems ?? 0],\n      moreItemsMaxItems: [config.moreItemsMaxItems ?? 100],\n      moreItemsIcon: [config.moreItemsIcon],\n      moreItemsIconFontColor: [config.moreItemsIconFontColor],\n      moreItemsIconBackgroundColor: [config.moreItemsIconBackgroundColor],\n      moreItemsExpanded: [''],\n      moreItemsConfig: [[]],\n      moreItemsFormGroup: this.fb.array([]),\n      autocompleteLoading: [new BehaviorSubject<boolean>(false)],\n      autocompleteOptions: [config.autocompleteOptions],\n      autocompleteMultipleConfig: [config.autocompleteMultipleConfig],\n      autocompleteOptionsFiltered: [new BehaviorSubject<any>([])],\n      autocompleteSelectedValue: [valueSelectedAutocomplete],\n      autocompleteAddOption: [config.autocompleteAddOption],\n      textLogs: [config?.textObs],\n      customMasc: [config?.customMasc],\n      customMascThousandSeparator: [config?.customMascThousandSeparator ?? ''],\n      customMascSuffix: [config?.customMascSuffix ?? ''],\n      customMascPrefix: [config?.customMascPrefix ?? ''],\n      value: [{value, disabled: config.disabled}, validators, config.asyncValidators]\n    });\n\n    if (config.autocompleteType === \"onDemand\") {\n      const loader = field.get('autocompleteLoading').value as BehaviorSubject<boolean>;\n      loader.next(true);\n      config.autocompleteFilter('').subscribe(options => {\n        field.get('autocompleteOptionsFiltered').value.next(options);\n        loader.next(false);\n      });\n    }\n\n    return field;\n  }\n\n  private setValuesOnFields(subject: BehaviorSubject<KoalaDynamicSetValueInterface[]>, form: UntypedFormGroup) {\n    subject.subscribe(item => {\n      if (item) {\n        const formArray = form.get('formData') as UntypedFormArray;\n        for (const prop of item.values()) {\n          this.setValueByProp(formArray, prop);\n        }\n      }\n    });\n  }\n\n  private changeVisibilityFields(subject: BehaviorSubject<KoalaDynamicFormShowFieldInterface[]>, form: UntypedFormGroup) {\n    subject.pipe(debounceTime(5)).subscribe(item => {\n      if (item) {\n        const formArray = form.get('formData') as UntypedFormArray;\n        for (const prop of item.values()) {\n          for (const [indexControl, control] of formArray.controls.entries()) {\n            if (control.get('name').value === prop.name) {\n              control.get('show').value.next(prop.show);\n              const config: KoalaDynamicFormFieldInterface = this.formConfig[indexControl] ?? null;\n              if (prop.show) {\n                let validators = [];\n                if (config) {\n                  if (config.type === DynamicFormTypeFieldEnum.dynamicForm) {\n                    const formArrayMoreItems = control.get('dynamicFormGroup') as UntypedFormArray;\n                    formArrayMoreItems.push(config?.dynamicFormConfig?.form);\n                  } else {\n                    validators = config.syncValidators ?? [];\n                    if (config.required === true) {\n                      validators.push(Validators.required);\n                    }\n                    if (config.type === DynamicFormTypeFieldEnum.cpf) {\n                      validators.push(CpfValidator);\n                    } else if (config.type === DynamicFormTypeFieldEnum.cnpj) {\n                      validators.push(CnpjValidator);\n                    } else if (config.type === DynamicFormTypeFieldEnum.email) {\n                      validators.push(Validators.email);\n                    } else if (\n                      config.required === true &&\n                      config.type === DynamicFormTypeFieldEnum.autocomplete\n                    ) {\n                      validators.push(AutocompleteSelectedValidator);\n                    }\n\n                    if (config.min && typeof config.min === \"number\") validators.push(Validators.min(config.min));\n                    if (config.max && typeof config.max === \"number\") validators.push(Validators.max(config.max));\n                    if (\n                      config.type === DynamicFormTypeFieldEnum.date ||\n                      config.type === DynamicFormTypeFieldEnum.datetime ||\n                      config.type === DynamicFormTypeFieldEnum.time\n                    ) {\n                      if (config.min && typeof config.min === \"string\") { validators.push(DateMinValidator(config.min)); }\n                      if (config.max && typeof config.max === \"string\") { validators.push(DateMaxValidator(config.max)); }\n                    }\n                    if (config.minLength) validators.push(Validators.minLength(config.minLength));\n                    if (config.maxLength) validators.push(Validators.maxLength(config.maxLength));\n\n                    control.get('value').setValidators(validators);\n                    if (config.asyncValidators) {\n                      control.get('value').setAsyncValidators(config.asyncValidators);\n                    }\n                  }\n\n                  control.get('value').updateValueAndValidity();\n                  if (prop.clearCurrentValue) {\n                    control.get('value').setValue(null);\n                  }\n                }\n              } else {\n                control.get('value').clearValidators();\n                control.get('value').clearAsyncValidators();\n                control.setErrors(null);\n                control.get('value').setValue(null);\n                control.get('value').updateValueAndValidity();\n\n                if (config.type === DynamicFormTypeFieldEnum.dynamicForm) {\n                  const formGroup = control as UntypedFormGroup;\n                  formGroup.removeControl('dynamicFormGroup');\n                  formGroup.addControl('dynamicFormGroup', this.fb.array([]));\n                }\n              }\n              break;\n            }\n          }\n        }\n      }\n    });\n  }\n\n  private autocompleteFilter(arr: KoalaDynamicAutocompleteOptionsInterface[], value: string): KoalaDynamicAutocompleteOptionsInterface[] {\n    return arr.filter(filter => {\n      if (typeof value === 'string') {\n        if (filter) {\n          let find = true;\n          value.toLowerCase()\n               .split(' ')\n               .forEach(part => {\n                 if (filter.name.toLowerCase().indexOf(part) < 0) {\n                   find = false;\n                   return false;\n                 }\n               });\n\n          return find;\n        }\n      } else {\n        return true;\n      }\n    });\n  }\n\n  private setValueByProp(formArray: UntypedFormArray, prop: KoalaDynamicSetValueInterface) {\n    if (formArray) {\n      if (prop.name.indexOf(' > ') >= 0) {\n        let dynamicFormSubject: BehaviorSubject<KoalaDynamicFormConfigInterface>;\n        const arrPropName = prop.name.split(' > ');\n        let indexPropName = 0;\n        do {\n          const control = formArray.controls.find(control => control.get('name').value === arrPropName[indexPropName]);\n          if (indexPropName === arrPropName.length - 2) {\n            dynamicFormSubject = control.get('dynamicFormConfig').value;\n            const dynamicForm = dynamicFormSubject.getValue();\n            if (dynamicForm.formConfig.find(fc => fc.name === arrPropName[arrPropName.length - 1])) {\n              if (dynamicForm.setValues) {\n                dynamicForm.setValues.next(koala(dynamicForm.setValues.getValue()).array<any>().merge([{\n                  name: arrPropName[arrPropName.length - 1],\n                  value: prop.value\n                }]).getValue());\n              } else {\n                dynamicForm.setValues = new BehaviorSubject<KoalaDynamicSetValueInterface[]>([{\n                  name: arrPropName[arrPropName.length - 1],\n                  value: prop.value\n                }]);\n              }\n            }\n          }\n          indexPropName++;\n        } while (indexPropName < arrPropName.length - 1);\n      } else {\n        for (const control of formArray.controls.values()) {\n          if (control.get('name').value === prop.name) {\n            control.get('value').setValue(prop.value);\n            break;\n          }\n        }\n      }\n    }\n  }\n\n  private async setConfigDynamicForm(newFormGroup: UntypedFormGroup) {\n    if (this.showFieldsMoreItensConfig) {\n      const value = newFormGroup.get('value').value;\n      const configs = this.showFieldsMoreItensConfig\n                          .filter(config => config.nameField === newFormGroup.get('name').value)\n                          .sort(config => {\n                            if (config.fnShow(value)) {\n                              return 1;\n                            }\n                            return -1;\n                          });\n      for (const config of configs) {\n        if (config) {\n          if (config.dynamicFormConfig && config.fnShow(value)) {\n            const controlDynamicFormConfig = this.controls\n                                                 .controls\n                                                 .find(control =>\n                                                   config.fieldsToShow.indexOf(control.get('name').value) >= 0\n                                                 );\n            const dynamicFormConfigSubject = controlDynamicFormConfig.get('dynamicFormConfig').value as BehaviorSubject<KoalaDynamicFormConfigInterface>;\n            dynamicFormConfigSubject.next(null);\n            await delay(1);\n            dynamicFormConfigSubject.next(config.dynamicFormConfig(value));\n          }\n          this.dynamicFormService.showFields(\n            this.showFields,\n            config.fieldsToShow,\n            config.fnShow(value),\n            config.clearCurrentValue\n          );\n        }\n      }\n    }\n  }\n\n  private validateAutocompleteSelect(selectedValues: KoalaDynamicAutocompleteOptionsInterface[], value: KoalaDynamicAutocompleteOptionsInterface) {\n    let isValid = true;\n\n    for (const selectedItem of selectedValues.values()) {\n      if (selectedItem.name === value.name) {\n        isValid = false;\n        break;\n      }\n    }\n\n    return isValid;\n  }\n}\n","<div [formGroup]=\"form\" class=\"p-relative w-100\" [id]=\"formId\">\n  <div *ngFor=\"let propriedade of controls?.controls; let i = index;\"\n       [ngClass]=\"(propriedade.get('show').value | async) ? propriedade.get('class').value : 'd-none'\"\n       formArrayName=\"formData\">\n\t  <div *ngIf=\"propriedade.get('show').value | async\">\n\t    <mat-form-field\n\t\t    *ngIf=\"propriedade.get('type').value == typeField.text ||\n\t             propriedade.get('type').value == typeField.password ||\n\t             propriedade.get('type').value == typeField.cpf ||\n\t             propriedade.get('type').value == typeField.cnpj ||\n\t             propriedade.get('type').value == typeField.datetime ||\n\t             propriedade.get('type').value == typeField.email ||\n\t             propriedade.get('type').value == typeField.number ||\n\t             propriedade.get('type').value == typeField.stringNumber ||\n\t             propriedade.get('type').value == typeField.time ||\n\t             propriedade.get('type').value == typeField.date ||\n\t             propriedade.get('type').value == typeField.hoursAndMinutes ||\n\t             propriedade.get('type').value == typeField.phone ||\n\t             propriedade.get('type').value == typeField.percent ||\n\t             propriedade.get('type').value == typeField.color ||\n\t             propriedade.get('type').value == typeField.month ||\n\t             propriedade.get('type').value == typeField.competenceDate ||\n               propriedade.get('type').value == typeField.stringWithCustomMasc\"\n\t\t    [appearance]=\"propriedade.get('appearance').value\"\n\t\t    [floatLabel]=\"propriedade.get('floatLabel').value\"\n\t\t    [formGroupName]=\"i\"\n\t\t    [ngClass]=\"propriedade.get('fieldClass').value\">\n\t      <mat-label>{{propriedade.get('label').value}}</mat-label>\n\t      <input\n\t\t      [dropSpecialCharacters]=\"false\"\n\t\t      [koalaAutoFocus]=\"propriedade.get('focus').value\"\n\t\t      (keyup)=\"hoursAndMinutesApplyMask(i, $event)\"\n\t\t      [required]=\"propriedade.get('required').value\"\n\t\t      [tabIndex]=\"tabIndexStart + i\"\n\t\t      [mask]=\"((propriedade.get('type').value == typeField.competenceDate) ? '00/0000' : null) ||\n\t\t              ((propriedade.get('type').value == typeField.phone) ? '(00)0000-0000?0' : null) ||\n\t\t              ((propriedade.get('type').value == typeField.stringNumber) ? '0{'+propriedade.get('maxLength').value+'}' : null) ||\n                  ((propriedade.get('type').value == typeField.cpf) ? '000.000.000-00' : null) ||\n                  ((propriedade.get('type').value == typeField.cnpj) ? '00.000.000/0000-00' : null) ||\n                  ((propriedade.get('type').value == typeField.percent) ? 'percent' : null) ||\n\t\t\t\t\t\t\t\t\t((propriedade.get('type').value == typeField.hoursAndMinutes) ? hoursAndMinutesMask : null) ||\n\t\t\t\t\t\t\t\t\t((propriedade.get('type').value == typeField.stringWithCustomMasc) ? propriedade.get('customMasc').value : null)\"\n\t\t      [validation]=\"\n\t                    (propriedade.get('type').value == typeField.cpf && propriedade.get('value').errors?.cpfInvalid) ||\n\t                    (propriedade.get('type').value == typeField.cnpj && propriedade.get('value').errors?.cnpjInvalid)\"\n\t\t      [type]=\"((propriedade.get('type').value == typeField.cpf ||\n                    propriedade.get('type').value == typeField.cnpj ||\n                    propriedade.get('type').value == typeField.phone ||\n                    propriedade.get('type').value == typeField.percent\n                  )) ? 'tel' : (\n                    propriedade.get('type').value == typeField.month ?\n                    'month' : (\n                    propriedade.get('type').value == typeField.date ?\n                    'date' : (\n                    propriedade.get('type').value == typeField.datetime ?\n                    'datetime-local' : (\n                    propriedade.get('type').value == typeField.email ?\n                    'email' : (\n                    propriedade.get('type').value == typeField.number ?\n                    'number' : (\n                    propriedade.get('type').value == typeField.time ?\n                    'time' : (\n                    propriedade.get('type').value == typeField.password ?\n                    'password' : (\n                    propriedade.get('type').value == typeField.color ?\n                    'color' : 'text'))))))))\"\n          [min]=\"propriedade.get('min').value\"\n          [max]=\"propriedade.get('max').value\"\n          [minLength]=\"propriedade.get('minLength').value\"\n          [maxLength]=\"propriedade.get('maxLength').value\"\n          [thousandSeparator]=\"propriedade.get('customMascThousandSeparator').value\"\n          [suffix]=\"propriedade.get('customMascSuffix').value\"\n          [prefix]=\"propriedade.get('customMascPrefix').value\"\n          separatorLimit=\"0\"\n          [autocomplete]=\"getRandomString()\"\n\t\t      formControlName=\"value\"\n\t\t      matInput/>\n\t      <button\n\t\t      (click)=\"passwordView(i)\"\n\t\t      *ngIf=\"propriedade.get('hidePassword').value !== null\"\n\t\t      [attr.aria-label]=\"'Hide password'\"\n\t\t      [attr.aria-pressed]=\"propriedade.get('hidePassword').value\"\n\t\t      mat-icon-button matSuffix tabindex=\"-1\" type=\"button\">\n\t        <mat-icon>{{propriedade.get('hidePassword').value ? 'visibility_off' : 'visibility'}}</mat-icon>\n\t      </button>\n\t      <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n\t        <mat-icon>info</mat-icon>\n\t\t      {{propriedade.get('textHint').value}}\n\t      </mat-hint>\n\t      <mat-error *ngIf=\"propriedade.get('value').errors?.required\">\n\t        <mat-icon>error</mat-icon>\n          {{errorMessage.getRequiredMessage(propriedade.get('label').value)}}\n\t      </mat-error>\n\t      <mat-error *ngIf=\"propriedade.get('value').errors?.cpfInvalid\">\n\t        <mat-icon>error</mat-icon>\n          {{errorMessage.getInvalidMessage(propriedade.get('label').value)}}\n\t      </mat-error>\n\t      <mat-error *ngIf=\"propriedade.get('value').errors?.cnpjInvalid\">\n\t        <mat-icon>error</mat-icon>\n          {{errorMessage.getInvalidMessage(propriedade.get('label').value)}}\n\t      </mat-error>\n\t      <mat-error *ngIf=\"propriedade.get('value').errors?.email\">\n\t        <mat-icon>error</mat-icon>\n          {{errorMessage.getInvalidMessage(propriedade.get('label').value)}}\n\t      </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.min\">\n          <mat-icon>error</mat-icon>\n          {{errorMessage.getMinMessage(propriedade.get('min').value)}}\n        </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.max\">\n          <mat-icon>error</mat-icon>\n          {{errorMessage.getMaxMessage(propriedade.get('max').value)}}\n        </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.minLength\">\n          <mat-icon>error</mat-icon>\n          {{errorMessage.getMinLengthMessage(propriedade.get('minLength').value)}}\n        </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.maxLength\">\n          <mat-icon>error</mat-icon>\n          {{errorMessage.getMaxLengthMessage(propriedade.get('maxLength').value)}}\n        </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.dateMin\">\n          <mat-icon>error</mat-icon>\n          {{errorMessage.getDateMinMessage()}}\n          {{propriedade.get('min').value | date:\"shortDate\"}}.\n        </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.dateMax\">\n          <mat-icon>error</mat-icon>\n          {{errorMessage.getDateMaxMessage()}}\n          {{propriedade.get('max').value | date:\"shortDate\"}}.\n        </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n          <mat-icon>error</mat-icon>\n          {{propriedade.get('value').errors?.customError.message}}.\n        </mat-error>\n\t    </mat-form-field>\n\t    <mat-form-field\n\t\t    *ngIf=\"propriedade.get('type').value == typeField.coin\"\n\t\t    [appearance]=\"propriedade.get('appearance').value\"\n\t\t    [floatLabel]=\"propriedade.get('floatLabel').value\"\n\t\t    [formGroupName]=\"i\"\n\t\t    [ngClass]=\"propriedade.get('fieldClass').value\">\n\t      <mat-label>{{propriedade.get('label').value}}</mat-label>\n\t      <input\n\t\t      [koalaAutoFocus]=\"propriedade.get('focus').value\"\n\t\t      [required]=\"propriedade.get('required').value\"\n          [tabIndex]=\"tabIndexStart + i\"\n          [min]=\"propriedade.get('min').value\"\n          [max]=\"propriedade.get('max').value\"\n          [minLength]=\"propriedade.get('minLength').value\"\n          [maxLength]=\"propriedade.get('maxLength').value\"\n          [autocomplete]=\"getRandomString()\"\n\t\t      currencyMask\n\t\t      formControlName=\"value\"\n\t\t      matInput\n\t\t      type=\"tel\"/>\n\t      <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n\t        <mat-icon>info</mat-icon>\n\t\t      {{propriedade.get('textHint').value}}\n\t      </mat-hint>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.min\">\n          <mat-icon>error</mat-icon>\n          {{errorMessage.getMinMessage(propriedade.get('min').value)}}\n        </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.max\">\n          <mat-icon>error</mat-icon>\n          {{errorMessage.getMaxMessage(propriedade.get('max').value)}}\n        </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.minLength\">\n          <mat-icon>error</mat-icon>\n          {{errorMessage.getMinLengthMessage(propriedade.get('minLength').value)}}\n        </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.maxLength\">\n          <mat-icon>error</mat-icon>\n          {{errorMessage.getMaxLengthMessage(propriedade.get('maxLength').value)}}\n        </mat-error>\n\t      <mat-error *ngIf=\"propriedade.get('value').errors?.required\">\n\t        <mat-icon>error</mat-icon>\n          {{errorMessage.getRequiredMessage(propriedade.get('label').value)}}\n\t      </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n          <mat-icon>error</mat-icon>\n          {{propriedade.get('value').errors?.customError.message}}.\n        </mat-error>\n\t    </mat-form-field>\n      <mat-form-field\n        *ngIf=\"propriedade.get('type').value == typeField.float\"\n        [appearance]=\"propriedade.get('appearance').value\"\n        [floatLabel]=\"propriedade.get('floatLabel').value\"\n        [formGroupName]=\"i\"\n        [ngClass]=\"propriedade.get('fieldClass').value\">\n        <mat-label>{{propriedade.get('label').value}}</mat-label>\n        <input\n          [koalaAutoFocus]=\"propriedade.get('focus').value\"\n          [required]=\"propriedade.get('required').value\"\n          [tabIndex]=\"tabIndexStart + i\"\n          [min]=\"propriedade.get('min').value\"\n          [max]=\"propriedade.get('max').value\"\n          [minLength]=\"propriedade.get('minLength').value\"\n          [maxLength]=\"propriedade.get('maxLength').value\"\n          [autocomplete]=\"getRandomString()\"\n          currencyMask\n          [options]=\"{prefix: ''}\"\n          formControlName=\"value\"\n          matInput\n          type=\"tel\"/>\n        <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n          <mat-icon>info</mat-icon>\n          {{propriedade.get('textHint').value}}\n        </mat-hint>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.min\">\n          <mat-icon>error</mat-icon>\n          {{errorMessage.getMinMessage(propriedade.get('min').value)}}\n        </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.max\">\n          <mat-icon>error</mat-icon>\n          {{errorMessage.getMaxMessage(propriedade.get('max').value)}}\n        </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.minLength\">\n          <mat-icon>error</mat-icon>\n          {{errorMessage.getMinLengthMessage(propriedade.get('minLength').value)}}\n        </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.maxLength\">\n          <mat-icon>error</mat-icon>\n          {{errorMessage.getMaxLengthMessage(propriedade.get('maxLength').value)}}\n        </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.required\">\n          <mat-icon>error</mat-icon>\n          {{errorMessage.getRequiredMessage(propriedade.get('label').value)}}\n        </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n          <mat-icon>error</mat-icon>\n          {{propriedade.get('value').errors?.customError.message}}.\n        </mat-error>\n      </mat-form-field>\n\t    <mat-form-field\n\t\t    *ngIf=\"propriedade.get('type').value == typeField.valueList ||\n\t             propriedade.get('type').value == typeField.textarea\"\n\t\t    [appearance]=\"propriedade.get('appearance').value\"\n\t\t    [floatLabel]=\"propriedade.get('floatLabel').value\"\n\t\t    [formGroupName]=\"i\"\n\t\t    [ngClass]=\"propriedade.get('fieldClass').value\">\n\t      <mat-label>{{propriedade.get('label').value}}</mat-label>\n\t      <textarea\n          #textarea\n\t\t      [koalaAutoFocus]=\"propriedade.get('focus').value\"\n          cdkTextareaAutosize\n          #autosize=\"cdkTextareaAutosize\"\n\t\t      [cdkAutosizeMaxRows]=\"8\"\n\t\t      [cdkAutosizeMinRows]=\"3\"\n\t\t      [required]=\"propriedade.get('required').value\"\n          [tabIndex]=\"tabIndexStart + i\"\n          [minLength]=\"propriedade.get('minLength').value\"\n          [maxLength]=\"propriedade.get('maxLength').value\"\n\t\t      formControlName=\"value\"\n\t\t      matInput>\n        </textarea>\n\t      <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n\t        <mat-icon>info</mat-icon>\n\t\t      {{propriedade.get('textHint').value}}\n\t      </mat-hint>\n        <mat-hint align=\"end\" *ngIf=\"propriedade.get('maxLength').value\">\n          {{textarea.value.length}}/{{propriedade.get('maxLength').value}}\n        </mat-hint>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.minLength\">\n          <mat-icon>error</mat-icon>\n          {{errorMessage.getMinLengthMessage(propriedade.get('minLength').value)}}\n        </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.maxLength\">\n          <mat-icon>error</mat-icon>\n          {{errorMessage.getMaxLengthMessage(propriedade.get('maxLength').value)}}\n        </mat-error>\n\t      <mat-error *ngIf=\"propriedade.get('value').errors?.required\">\n\t        <mat-icon>error</mat-icon>\n          {{errorMessage.getRequiredMessage(propriedade.get('label').value)}}\n\t      </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n          <mat-icon>error</mat-icon>\n          {{propriedade.get('value').errors?.customError.message}}.\n        </mat-error>\n\t    </mat-form-field>\n\t\t  <mat-form-field\n\t\t\t  *ngIf=\"propriedade.get('type').value == typeField.textLogs\"\n\t\t\t  [appearance]=\"propriedade.get('appearance').value\"\n\t\t\t  [floatLabel]=\"propriedade.get('floatLabel').value\"\n\t\t\t  [formGroupName]=\"i\"\n\t\t\t  [ngClass]=\"propriedade.get('fieldClass').value\">\n\t      <mat-label>{{propriedade.get('label').value}}</mat-label>\n\t      <div [innerHTML]=\"propriedade.get('textLogs').value\" class=\"text-obs\"></div>\n\t      <textarea\n          #textarea\n\t\t      [koalaAutoFocus]=\"propriedade.get('focus').value\"\n          cdkTextareaAutosize\n          #autosize=\"cdkTextareaAutosize\"\n\t\t      [cdkAutosizeMaxRows]=\"8\"\n\t\t      [cdkAutosizeMinRows]=\"3\"\n\t\t      [required]=\"propriedade.get('required').value\"\n          [tabIndex]=\"tabIndexStart + i\"\n          [minLength]=\"propriedade.get('minLength').value\"\n          [maxLength]=\"propriedade.get('maxLength').value\"\n\t\t      formControlName=\"value\"\n\t\t      matInput>\n\t      </textarea>\n\t      <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n\t        <mat-icon>info</mat-icon>\n\t\t      {{propriedade.get('textHint').value}}\n\t      </mat-hint>\n        <mat-hint align=\"end\" *ngIf=\"propriedade.get('maxLength').value\">\n          {{textarea.value.length}}/{{propriedade.get('maxLength').value}}\n        </mat-hint>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.minLength\">\n          <mat-icon>error</mat-icon>\n          {{errorMessage.getMinLengthMessage(propriedade.get('minLength').value)}}\n        </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.maxLength\">\n          <mat-icon>error</mat-icon>\n          {{errorMessage.getMaxLengthMessage(propriedade.get('maxLength').value)}}\n        </mat-error>\n\t      <mat-error *ngIf=\"propriedade.get('value').errors?.required\">\n\t        <mat-icon>error</mat-icon>\n          {{errorMessage.getRequiredMessage(propriedade.get('label').value)}}\n\t      </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n          <mat-icon>error</mat-icon>\n          {{propriedade.get('value').errors?.customError.message}}.\n        </mat-error>\n\t    </mat-form-field>\n\t    <mat-form-field\n\t\t    *ngIf=\"propriedade.get('type').value == typeField.select\"\n\t\t    [appearance]=\"propriedade.get('appearance').value\"\n\t\t    [floatLabel]=\"propriedade.get('floatLabel').value\"\n\t\t    [formGroupName]=\"i\"\n\t\t    [ngClass]=\"propriedade.get('fieldClass').value\">\n\t      <mat-label>{{propriedade.get('label').value}}</mat-label>\n\t      <mat-select [multiple]=\"propriedade.get('multiple').value\" [required]=\"propriedade.get('required').value\"\n                    [tabIndex]=\"tabIndexStart + i\" formControlName=\"value\">\n\t        <mat-option *ngFor=\"let options of propriedade.get('opcoesSelect').value\" [value]=\"options.value\">\n\t          {{options.name}}\n\t        </mat-option>\n\t      </mat-select>\n\t      <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n\t        <mat-icon>info</mat-icon>\n\t\t      {{propriedade.get('textHint').value}}\n\t      </mat-hint>\n\t      <mat-error *ngIf=\"propriedade.get('value').errors?.required\">\n\t        <mat-icon>error</mat-icon>\n          {{errorMessage.getRequiredMessage(propriedade.get('label').value)}}\n\t      </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n          <mat-icon>error</mat-icon>\n          {{propriedade.get('value').errors?.customError.message}}.\n        </mat-error>\n\t    </mat-form-field>\n      <mat-form-field\n        class=\"select-multiple-native\"\n        *ngIf=\"propriedade.get('type').value == typeField.selectMultipleNative\"\n        [appearance]=\"propriedade.get('appearance').value\"\n        [floatLabel]=\"propriedade.get('floatLabel').value\"\n        [formGroupName]=\"i\"\n        [ngClass]=\"propriedade.get('fieldClass').value\">\n        <mat-label>{{propriedade.get('label').value}}</mat-label>\n        <select\n          matNativeControl\n          formControlName=\"value\"\n          multiple\n          [tabIndex]=\"tabIndexStart + i\"\n          [required]=\"propriedade.get('required').value\">\n          <option *ngFor=\"let options of propriedade.get('opcoesSelect').value\" [value]=\"options.value\">\n            {{options.name}}\n          </option>\n        </select>\n        <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n          <mat-icon>info</mat-icon>\n          {{propriedade.get('textHint').value}}\n        </mat-hint>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.required\">\n          <mat-icon>error</mat-icon>\n          {{errorMessage.getRequiredMessage(propriedade.get('label').value)}}\n        </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n          <mat-icon>error</mat-icon>\n          {{propriedade.get('value').errors?.customError.message}}.\n        </mat-error>\n      </mat-form-field>\n\t    <div\n\t\t    *ngIf=\"propriedade.get('type').value == typeField.checkbox\"\n\t\t    [formGroupName]=\"i\"\n\t\t    [ngClass]=\"propriedade.get('fieldClass').value\">\n\t      <mat-checkbox\n          [tabIndex]=\"tabIndexStart + i\"\n\t\t      formControlName=\"value\"\n\t\t      value=\"true\">\n\t        {{propriedade.get('label').value}}\n\t      </mat-checkbox>\n\t    </div>\n\t\t  <div\n\t\t\t  *ngIf=\"propriedade.get('type').value == typeField.moreItems\"\n\t\t\t  [formGroupName]=\"i\"\n\t\t\t  [ngClass]=\"propriedade.get('fieldClass').value\"\n\t\t\t  class=\"more-items-content\">\n\t\t\t  <fieldset>\n\t\t\t\t  <legend>\n\t\t\t\t\t  <koala-button\n\t\t\t\t\t\t  (click)=\"addMoreItem(i)\"\n\t\t\t\t\t\t  [disabled]=\"propriedade.get('moreItemsConfig').value.length === propriedade.get('moreItemsMaxItems').value\"\n\t\t\t\t\t\t  [tooltip]=\"propriedade.get('moreItemsButtonIconAddlabel').value\"\n\t\t\t\t\t\t  [backgroundColor]=\"propriedade.get('moreItemsIconBackgroundColor').value\"\n              [color]=\"propriedade.get('moreItemsIconFontColor').value\"\n\t\t\t\t\t\t  class=\"btn-add-more-items\"\n\t\t\t\t\t\t  icon=\"add\">\n\t\t\t\t\t  </koala-button>\n\t\t\t\t\t  {{propriedade.get('label').value}} (Min.: {{propriedade.get('moreItemsMinItems').value}}\n\t\t\t\t\t                                     | Máx.: {{propriedade.get('moreItemsMaxItems').value}})\n\t\t\t\t  </legend>\n\t\t\t\t  <mat-accordion class=\"items\" multi>\n\t\t\t\t\t  <mat-expansion-panel\n\t\t\t\t\t\t  *ngFor=\"let item of propriedade.get('moreItemsConfig').value.slice().reverse(); index as indexMoreItems\"\n\t\t\t\t\t\t  expanded>\n\t\t\t\t\t\t  <mat-expansion-panel-header>\n\t\t\t\t\t\t\t\t<mat-panel-title class=\"titleForm\">#\n\t\t\t\t\t\t\t\t\t{{propriedade.get('moreItemsConfig').value.length - 1 - indexMoreItems + 1}}</mat-panel-title>\n\t\t\t\t\t\t\t\t<mat-panel-description class=\"titleForm\">\n\t\t\t\t\t\t\t\t\t{{propriedade.get('label').value}}\n\t\t\t\t\t\t\t\t\t<mat-icon>{{propriedade.get('moreItemsIcon').value}}</mat-icon>\n\t\t\t\t\t\t\t\t</mat-panel-description>\n\t\t\t\t\t\t\t</mat-expansion-panel-header>\n\t\t\t\t\t\t  <koala-dynamic-form\n\t\t\t\t\t\t\t  [showFieldsMoreItensConfig]=\"item.showFieldsMoreItensConfig\"\n\t\t\t\t\t\t\t  [showFields]=\"item.showFields\"\n\t\t\t\t\t\t\t  [formConfig]=\"item.formConfig\"\n\t\t\t\t\t\t\t  [form]=\"item.form\"\n                [tabIndexStart]=\"tabIndexStart + i\">\n\t\t\t\t\t\t  </koala-dynamic-form>\n\t\t\t\t\t    <mat-action-row\n\t\t\t\t\t\t    *ngIf=\"propriedade.get('moreItemsConfig').value.length > propriedade.get('moreItemsMinItems').value\">\n\t\t\t\t\t      <button\n\t\t\t\t\t\t      (click)=\"removeMoreItem(i, propriedade.get('moreItemsConfig').value.length - 1 - indexMoreItems)\"\n\t\t\t\t\t\t      mat-icon-button>\n\t\t\t\t\t\t      <mat-icon>delete</mat-icon>\n\t\t\t\t\t      </button>\n\t\t\t\t\t    </mat-action-row>\n\t\t\t\t\t  </mat-expansion-panel>\n\t\t\t\t  </mat-accordion>\n\t\t\t  </fieldset>\n\t\t  </div>\n\t\t  <mat-form-field\n\t\t\t  *ngIf=\"propriedade.get('type').value == typeField.autocomplete\"\n\t\t\t  [appearance]=\"propriedade.get('appearance').value\"\n\t\t\t  [floatLabel]=\"propriedade.get('floatLabel').value\"\n\t\t\t  [formGroupName]=\"i\"\n\t\t\t  [ngClass]=\"propriedade.get('fieldClass').value\">\n\t      <mat-label>{{propriedade.get('label').value}} {{propriedade.get('multiple').value &&\n\t      propriedade.get('required').value ? '*' : ''}}</mat-label>\n\t\t\t  <div *ngIf=\"propriedade.get('multiple').value else single\">\n\t        <mat-chip-list #chipList>\n            <mat-chip\n              (removed)=\"removeOptionOnAutocomplete(i, option)\"\n              *ngFor=\"let option of propriedade.get('autocompleteSelectedValue').value\"\n              [color]=\"getColorChip(propriedade.get('autocompleteMultipleConfig').value | async)\"\n              [removable]=\"true\"\n              [selectable]=\"true\">\n              {{display(option)}}\n              <mat-icon *ngIf=\"!propriedade.get('disabled').value\" matChipRemove>cancel</mat-icon>\n            </mat-chip>\n\t          <input\n              [id]=\"'autocomplete-' + propriedade.get('name').value\"\n              [koalaAutoFocus]=\"propriedade.get('focus').value\"\n\t\t          [required]=\"propriedade.get('required').value\"\n\t\t          [matAutocomplete]=\"auto\"\n\t\t          [matChipInputFor]=\"chipList\"\n              [tabIndex]=\"tabIndexStart + i\"\n              [autocomplete]=\"getRandomString()\"\n\t\t          formControlName=\"value\"\n\t\t          matInput\n\t\t          type=\"text\"\n\t\t          placeholder=\"Selecione um ou mais opções...\">\n\t        </mat-chip-list>\n\t      </div>\n\t      <ng-template #single>\n\t\t      <input\n\t\t\t      [matAutocomplete]=\"auto\"\n            [koalaAutoFocus]=\"propriedade.get('focus').value\"\n\t\t\t      [required]=\"propriedade.get('required').value\"\n            [tabIndex]=\"tabIndexStart + i\"\n            [autocomplete]=\"getRandomString()\"\n\t\t\t      formControlName=\"value\"\n\t\t\t      matInput\n\t\t\t      placeholder=\"Selecione uma opção...\"\n\t\t\t      type=\"text\">\n\t      </ng-template>\n\t      <mat-spinner *ngIf=\"propriedade.get('autocompleteLoading').value | async\" color=\"primary\"\n\t                   matSuffix></mat-spinner>\n\t      <button\n\t\t      (click)=\"clearAutocomplete(i)\"\n\t\t      *ngIf=\"\n\t          !(propriedade.get('autocompleteLoading').value | async) &&\n\t          !propriedade.get('disabled').value\"\n\t\t      color=\"warn\"\n\t\t      mat-icon-button\n\t\t      matSuffix\n\t\t      type=\"button\">\n\t        <mat-icon>close</mat-icon>\n\t      </button>\n\t      <mat-hint *ngIf=\"propriedade.get('textHint').value\">\n\t        <mat-icon>info</mat-icon>\n\t\t      {{propriedade.get('textHint').value}}\n\t      </mat-hint>\n\t      <mat-error *ngIf=\"propriedade.get('value').errors?.required || propriedade.get('value').errors?.autocompleteSelected\">\n\t        <mat-icon>error</mat-icon>\n          {{errorMessage.getAutocompleteMessage(propriedade.get('label').value)}}\n\t      </mat-error>\n        <mat-error *ngIf=\"propriedade.get('value').errors?.customError\">\n          <mat-icon>error</mat-icon>\n          {{propriedade.get('value').errors?.customError.message}}.\n        </mat-error>\n\t      <mat-autocomplete\n\t\t      #auto=\"matAutocomplete\"\n\t\t      [displayWith]=\"display\" autoActiveFirstOption>\n          <mat-option\n            *ngIf=\"propriedade.get('autocompleteAddOption').value && isValidNewAutocompleteOption(propriedade.get('value').value)\"\n            [value]=\"{\n              value: {id: 0, name: propriedade.get('value').value},\n              name: propriedade.get('value').value\n            }\">\n            Add <b>{{propriedade.get('value').value}}</b>...\n          </mat-option>\n\t\t      <div *ngIf=\"(getAutocompleteOptions(propriedade) | async) as options\">\n\t\t        <mat-option *ngFor=\"let option of options\" [value]=\"option\">\n\t\t          {{option.name}}\n\t\t        </mat-option>\n\t\t      </div>\n\t      </mat-autocomplete>\n\t    </mat-form-field>\n\t\t  <div *ngIf=\"propriedade.get('type').value == typeField.file\">\n\t\t\t  <koala-file-button\n\t\t\t\t  (getFiles)=\"propriedade.get('value').setValue($event)\"\n\t\t\t\t  [accept]=\"propriedade.get('fileButtonConfig').value.accept\"\n\t\t\t\t  [backgroundColor]=\"propriedade.get('fileButtonConfig').value.backgroundColor\"\n\t\t\t\t  [color]=\"propriedade.get('fileButtonConfig').value.color\"\n\t\t\t\t  [disabled]=\"propriedade.get('disabled').value\"\n\t\t\t\t  [icon]=\"propriedade.get('fileButtonConfig').value.icon\"\n\t\t\t\t  [multiple]=\"propriedade.get('multiple').value\"\n\t\t\t\t  [text]=\"propriedade.get('fileButtonConfig').value.text\">\n\t\t\t  </koala-file-button>\n\t\t  </div>\n\t\t  <div *ngIf=\"\n\t\t    propriedade.get('type').value == typeField.dynamicForm &&\n\t\t\t\t(getDynamicFormConfig(propriedade) | async) as dynamicFormConfig\">\n\t\t\t  <fieldset *ngIf=\"propriedade.get('label').value else dynamicFormWithoutLabel\">\n\t\t\t\t  <legend>{{propriedade.get('label').value}}</legend>\n\t\t\t\t  <koala-dynamic-form\n\t\t\t\t\t  [formConfig]=\"dynamicFormConfig.formConfig\"\n\t\t\t\t\t  [form]=\"dynamicFormConfig.form\"\n\t\t\t\t\t  [setValues]=\"dynamicFormConfig.setValues\"\n\t\t\t\t\t  [showFields]=\"dynamicFormConfig.showFields\"\n            [tabIndexStart]=\"tabIndexStart + i\">\n\t\t\t\t  </koala-dynamic-form>\n\t\t\t  </fieldset>\n\t\t\t  <ng-template #dynamicFormWithoutLabel>\n\t\t\t\t  <koala-dynamic-form\n\t\t\t\t\t  [formConfig]=\"dynamicFormConfig.formConfig\"\n\t\t\t\t\t  [form]=\"dynamicFormConfig.form\"\n\t\t\t\t\t  [setValues]=\"dynamicFormConfig.setValues\"\n\t\t\t\t\t  [showFields]=\"dynamicFormConfig.showFields\"\n            [tabIndexStart]=\"tabIndexStart + i\">\n\t\t\t\t  </koala-dynamic-form>\n\t\t\t  </ng-template>\n\t\t  </div>\n      <div\n        class=\"radio-btn-group\"\n        *ngIf=\"propriedade.get('type').value == typeField.radio\"\n        [formGroupName]=\"i\"\n        [ngClass]=\"propriedade.get('fieldClass').value\">\n        <mat-radio-group formControlName=\"value\">\n          <label *ngIf=\"propriedade.get('label').value\">{{propriedade.get('label').value}}</label>\n          <mat-radio-button\n            [tabIndex]=\"tabIndexStart + i\"\n            *ngFor=\"let options of propriedade.get('opcoesSelect').value\"\n            [value]=\"options.value\">\n            {{options.name}}\n          </mat-radio-button>\n        </mat-radio-group>\n      </div>\n\t  </div>\n  </div>\n  <ng-content select=\"[btn-submit]\"></ng-content>\n</div>\n"]}
|