@mediusinc/mng-commons 2.6.0 → 3.0.0-rc.0
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/README.md +15 -4
- package/dev-scripts/version-info.js +1 -0
- package/esm2022/lib/api/models/filter-param.model.mjs +33 -0
- package/esm2022/lib/api/models/query-param.model.mjs +68 -0
- package/esm2022/lib/api/models/query-result.model.mjs +24 -0
- package/esm2022/lib/api/utils/medius-rest.util.mjs +255 -0
- package/esm2022/lib/api/utils/object-serializer.util.mjs +258 -0
- package/esm2022/lib/components/action/action.component.mjs +304 -0
- package/esm2022/lib/components/action/editor/action-editor.component.mjs +386 -0
- package/esm2022/lib/components/action/localization/data-language-dropdown.component.mjs +54 -0
- package/{esm2020 → esm2022}/lib/components/action/models/action-execution.model.mjs +1 -1
- package/esm2022/lib/components/action/models/tableview-action-default-categories.model.mjs +11 -0
- package/{esm2020 → esm2022}/lib/components/action/route/action-route.component.mjs +4 -4
- package/esm2022/lib/components/form/autocomplete/autocomplete.component.mjs +300 -0
- package/{esm2020 → esm2022}/lib/components/form/date-range/date-range.component.mjs +5 -5
- package/esm2022/lib/components/form/dropdown/dropdown.component.mjs +212 -0
- package/esm2022/lib/components/form/editor/form-editor.component.mjs +288 -0
- package/{esm2020 → esm2022}/lib/components/form/formly/fields/formly-field-action/formly-field-action.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/form/formly/fields/formly-field-autocomplete/formly-field-autocomplete.component.mjs +5 -5
- package/{esm2020 → esm2022}/lib/components/form/formly/fields/formly-field-custom/formly-custom-field-base.model.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/form/formly/fields/formly-field-custom/formly-field-custom.component.mjs +6 -6
- package/{esm2020 → esm2022}/lib/components/form/formly/fields/formly-field-dropdown/formly-field-dropdown.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/form/formly/fields/formly-field-fieldset/formly-field-fieldset.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/form/formly/fields/formly-field-input/formly-field-input.component.mjs +5 -5
- package/{esm2020 → esm2022}/lib/components/form/formly/fields/formly-field-label/formly-field-label.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/form/formly/fields/formly-field-lookup-dialog/formly-field-lookup-dialog.component.mjs +7 -7
- package/{esm2020 → esm2022}/lib/components/form/formly/fields/formly-field-table-dialog-form/formly-field-table-dialog-form.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/form/formly/fields/formly-field-table-dialog-multiselect/formly-field-table-dialog-multiselect.component.mjs +4 -4
- package/esm2022/lib/components/form/formly/fields/formly-field-tabs/formly-field-tabs.component.mjs +19 -0
- package/{esm2020 → esm2022}/lib/components/form/formly/wrappers/formly-field-no-label-wrapper/formly-field-no-label-wrapper.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/form/formly/wrappers/formly-field-wrapper/formly-field-wrapper.component.mjs +4 -4
- package/esm2022/lib/components/form/models/form-editor.event.mjs +49 -0
- package/esm2022/lib/components/layout/breadcrumb.component.mjs +34 -0
- package/{esm2020 → esm2022}/lib/components/layout/footer.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/layout/main-layout.component.mjs +4 -4
- package/esm2022/lib/components/layout/menu-item.component.mjs +297 -0
- package/{esm2020 → esm2022}/lib/components/layout/menu.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/layout/services/main-layout.component.service.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/layout/topbar-user.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/layout/topbar.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/layout/version.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/pages/error/error-page.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/pages/not-found/not-found-page.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/tableview/models/table.event.mjs +1 -1
- package/{esm2020 → esm2022}/lib/components/tableview/route/tableview-route.abstract.component.mjs +5 -5
- package/{esm2020 → esm2022}/lib/components/tableview/route/tableview-route.component.mjs +4 -4
- package/esm2022/lib/components/tableview/table/column-filter/column-filter.component.mjs +124 -0
- package/esm2022/lib/components/tableview/table/column-value/column-value.component.mjs +110 -0
- package/esm2022/lib/components/tableview/table/table.component.mjs +747 -0
- package/esm2022/lib/components/tableview/tableview.component.mjs +147 -0
- package/esm2022/lib/descriptors/action/action.descriptor.mjs +634 -0
- package/esm2022/lib/descriptors/editor/editor.descriptor.mjs +304 -0
- package/esm2022/lib/descriptors/table/table.descriptor.mjs +542 -0
- package/esm2022/lib/descriptors/tableview/tableview.descriptor.mjs +352 -0
- package/{esm2020 → esm2022}/lib/descriptors/types/table.type.mjs +1 -5
- package/{esm2020 → esm2022}/lib/directives/component.directive.mjs +5 -5
- package/{esm2020 → esm2022}/lib/directives/template.directive.mjs +5 -5
- package/esm2022/lib/mng-commons.module.mjs +465 -0
- package/{esm2020 → esm2022}/lib/pipes/boolean.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/pipes/class-map.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/pipes/enum.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/pipes/enumerate-async.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/pipes/enumerate.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/pipes/getter.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/pipes/i18n-property.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/pipes/json-path.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/pipes/locale-default-row-class.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/pipes/parametrize.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/pipes/template.pipe.mjs +4 -4
- package/esm2022/lib/router/route-builder.mjs +308 -0
- package/esm2022/lib/router/routes-builder.mjs +61 -0
- package/esm2022/lib/security/authorization.guard.mjs +15 -0
- package/{esm2020 → esm2022}/lib/security/authorization.service.mjs +4 -4
- package/esm2022/lib/services/action-executor.service.mjs +703 -0
- package/{esm2020 → esm2022}/lib/services/commons.service.mjs +4 -4
- package/esm2022/lib/services/configuration.service.mjs +150 -0
- package/{esm2020 → esm2022}/lib/services/internal/commons-init.service.mjs +4 -4
- package/{esm2020 → esm2022}/lib/services/mng-localstorage-config.service.mjs +4 -4
- package/{esm2020 → esm2022}/lib/services/navigation.service.mjs +4 -4
- package/{esm2020 → esm2022}/lib/services/router.service.mjs +4 -4
- package/{esm2020 → esm2022}/lib/services/version.service.mjs +4 -4
- package/{esm2020 → esm2022}/lib/services/view-container.component.service.mjs +4 -4
- package/esm2022/lib/styles/styles.util.mjs +42 -0
- package/esm2022/lib/types/type.model.mjs +2 -0
- package/esm2022/lib/utils/date.util.mjs +120 -0
- package/esm2022/lib/utils/tableview.util.mjs +193 -0
- package/esm2022/lib/utils/type.util.mjs +94 -0
- package/{fesm2020 → fesm2022}/mediusinc-mng-commons.mjs +930 -908
- package/fesm2022/mediusinc-mng-commons.mjs.map +1 -0
- package/lib/api/utils/medius-rest.util.d.ts +4 -3
- package/lib/components/action/action.component.d.ts +1 -1
- package/lib/components/action/editor/action-editor.component.d.ts +6 -9
- package/lib/components/action/localization/data-language-dropdown.component.d.ts +1 -1
- package/lib/components/form/autocomplete/autocomplete.component.d.ts +4 -4
- package/lib/components/form/date-range/date-range.component.d.ts +1 -1
- package/lib/components/form/dropdown/dropdown.component.d.ts +3 -3
- package/lib/components/form/editor/form-editor.component.d.ts +1 -1
- package/lib/components/form/formly/fields/formly-field-custom/formly-custom-field-base.model.d.ts +1 -1
- package/lib/components/layout/breadcrumb.component.d.ts +5 -0
- package/lib/components/layout/menu-item.component.d.ts +1 -1
- package/lib/components/layout/version.component.d.ts +1 -1
- package/lib/components/tableview/models/table.event.d.ts +2 -2
- package/lib/components/tableview/route/tableview-route.component.d.ts +1 -1
- package/lib/components/tableview/table/column-filter/column-filter.component.d.ts +2 -2
- package/lib/components/tableview/table/column-value/column-value.component.d.ts +1 -1
- package/lib/components/tableview/table/table.component.d.ts +6 -7
- package/lib/components/tableview/tableview.component.d.ts +7 -11
- package/lib/descriptors/editor/editor.descriptor.d.ts +1 -1
- package/lib/descriptors/table/table.descriptor.d.ts +7 -1
- package/lib/descriptors/tableview/tableview.descriptor.d.ts +4 -4
- package/lib/descriptors/types/table.type.d.ts +1 -5
- package/lib/directives/component.directive.d.ts +1 -1
- package/lib/directives/template.directive.d.ts +1 -1
- package/lib/router/route-builder.d.ts +6 -10
- package/lib/router/routes-builder.d.ts +0 -5
- package/lib/security/authorization.guard.d.ts +2 -11
- package/lib/services/action-executor.service.d.ts +1 -15
- package/lib/utils/route.util.d.ts +8 -19
- package/lib/utils/tableview.util.d.ts +5 -0
- package/package.json +12 -19
- package/esm2020/lib/api/models/filter-param.model.mjs +0 -33
- package/esm2020/lib/api/models/query-param.model.mjs +0 -68
- package/esm2020/lib/api/models/query-result.model.mjs +0 -24
- package/esm2020/lib/api/utils/medius-rest.util.mjs +0 -246
- package/esm2020/lib/api/utils/object-serializer.util.mjs +0 -258
- package/esm2020/lib/components/action/action.component.mjs +0 -303
- package/esm2020/lib/components/action/editor/action-editor.component.mjs +0 -390
- package/esm2020/lib/components/action/localization/data-language-dropdown.component.mjs +0 -47
- package/esm2020/lib/components/action/models/tableview-action-default-categories.model.mjs +0 -11
- package/esm2020/lib/components/form/autocomplete/autocomplete.component.mjs +0 -303
- package/esm2020/lib/components/form/dropdown/dropdown.component.mjs +0 -214
- package/esm2020/lib/components/form/editor/form-editor.component.mjs +0 -288
- package/esm2020/lib/components/form/formly/fields/formly-field-tabs/formly-field-tabs.component.mjs +0 -19
- package/esm2020/lib/components/form/models/form-editor.event.mjs +0 -49
- package/esm2020/lib/components/layout/breadcrumb.component.mjs +0 -19
- package/esm2020/lib/components/layout/menu-item.component.mjs +0 -294
- package/esm2020/lib/components/tableview/table/column-filter/column-filter.component.mjs +0 -126
- package/esm2020/lib/components/tableview/table/column-value/column-value.component.mjs +0 -108
- package/esm2020/lib/components/tableview/table/table.component.mjs +0 -749
- package/esm2020/lib/components/tableview/tableview.component.mjs +0 -146
- package/esm2020/lib/descriptors/action/action.descriptor.mjs +0 -634
- package/esm2020/lib/descriptors/editor/editor.descriptor.mjs +0 -304
- package/esm2020/lib/descriptors/table/table.descriptor.mjs +0 -521
- package/esm2020/lib/descriptors/tableview/tableview.descriptor.mjs +0 -347
- package/esm2020/lib/mng-commons.module.mjs +0 -469
- package/esm2020/lib/router/route-builder.mjs +0 -312
- package/esm2020/lib/router/routes-builder.mjs +0 -68
- package/esm2020/lib/security/authorization.guard.mjs +0 -30
- package/esm2020/lib/services/action-executor.service.mjs +0 -722
- package/esm2020/lib/services/configuration.service.mjs +0 -150
- package/esm2020/lib/styles/styles.util.mjs +0 -42
- package/esm2020/lib/types/type.model.mjs +0 -2
- package/esm2020/lib/utils/date.util.mjs +0 -120
- package/esm2020/lib/utils/tableview.util.mjs +0 -171
- package/esm2020/lib/utils/type.util.mjs +0 -94
- package/fesm2015/mediusinc-mng-commons.mjs +0 -15900
- package/fesm2015/mediusinc-mng-commons.mjs.map +0 -1
- package/fesm2020/mediusinc-mng-commons.mjs.map +0 -1
- /package/{esm2020 → esm2022}/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/api/models/builders/query-param.builder.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/api/models/filter-match-type.model.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/api/models/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/api/models/mappers.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/api/models/query-mode.model.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/api/models/serialization.model.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/api/services/api.abstract.service.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/api/services/crud-api.abstract.service.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/api/services/get-all-api.abstract.service.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/api/services/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/api/utils/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/action/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/action/models/action-component.model.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/action/models/action-confirmation-service.model.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/action/models/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/form/formly/fields/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/form/formly/formly.config.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/form/formly/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/form/formly/models/formly-config.model.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/form/formly/models/formly-field.model.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/form/formly/models/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/form/formly/wrappers/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/form/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/form/models/field-action-context.model.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/form/models/form-editor.interface.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/form/models/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/layout/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/layout/services/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/pages/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/tableview/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/tableview/models/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/tableview/table/models/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/tableview/table/models/table.interface.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/data-providers/base.data-provider.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/data-providers/editor.data-provider.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/data-providers/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/data-providers/lookup.data-provider.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/data-providers/table.data-provider.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/data-providers/tableview-crud.data-provider.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/data-providers/tableview.data-provider.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/descriptors/action/action-button.descriptor.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/descriptors/action/action-confirmation.descriptor.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/descriptors/action/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/descriptors/editor/field-validation.descriptor.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/descriptors/editor/field.descriptor.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/descriptors/editor/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/descriptors/filter/filter.descriptor.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/descriptors/filter/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/descriptors/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/descriptors/interfaces/field-config.interface.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/descriptors/interfaces/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/descriptors/interfaces/lookup-descriptor.interface.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/descriptors/model.descriptor.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/descriptors/table/column.descriptor.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/descriptors/table/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/descriptors/tableview/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/descriptors/types/action.type.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/descriptors/types/column.type.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/descriptors/types/editor.type.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/descriptors/types/field.type.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/descriptors/types/filter.type.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/descriptors/types/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/models/column-value.model.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/models/config.model.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/models/enum.model.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/models/error-internal.model.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/models/error.model.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/models/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/models/menu.model.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/models/tableview-attr.model.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/models/user.model.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/models/version.model.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/models/view-container.model.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/pipes/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/pipes/models/internal/enumrate-pipe-i18n.model.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/pipes/models/internal/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/provide-commons.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/router/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/router/models/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/router/models/router.model.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/router/tableview-route-builder.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/security/authorization.util.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/security/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/security/model/authorization.type.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/security/model/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/security/model/permission-service.interface.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/security/model/permissions.model.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/services/error-mapper.service.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/services/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/services/internal/commons-init.provider.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/services/internal/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/services/providers/config-service.provider.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/services/providers/formly-config.provider.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/services/providers/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/services/tokens/browser-storage.token.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/services/tokens/commons-init.token.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/services/tokens/default-setting.token.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/services/tokens/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/services/tokens/module-config.token.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/styles/button-style.builder.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/styles/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/styles/models/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/styles/models/style-level.enum.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/styles/models/style-size.enum.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/types/i18n.type.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/types/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/types/mng-localstorage-config-value.type.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/types/type.decorator.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/action-data-provider.util.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/editor-formly.util.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/enum.util.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/export.util.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/file.util.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/i18n.util.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/model.util.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/notification.util.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/object.util.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/route.util.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/string.util.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/validators/field.validator.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/validators/index.mjs +0 -0
- /package/{esm2020 → esm2022}/mediusinc-mng-commons.mjs +0 -0
|
@@ -0,0 +1,212 @@
|
|
|
1
|
+
import { AsyncPipe, NgIf } from '@angular/common';
|
|
2
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Injector, Input, Optional, Output, ViewChild, forwardRef } from '@angular/core';
|
|
3
|
+
import { FormControl, NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';
|
|
4
|
+
import { TranslateModule, TranslateService } from '@ngx-translate/core';
|
|
5
|
+
import { Dropdown, DropdownModule } from 'primeng/dropdown';
|
|
6
|
+
import { MultiSelectModule } from 'primeng/multiselect';
|
|
7
|
+
import { ReplaySubject, of, switchMap } from 'rxjs';
|
|
8
|
+
import { first, map } from 'rxjs/operators';
|
|
9
|
+
import { MediusQueryParamBuilder } from '../../../api/models';
|
|
10
|
+
import { MngErrorInternal } from '../../../models';
|
|
11
|
+
import { MngFormlyFieldWrapperComponent } from '../formly/wrappers';
|
|
12
|
+
import * as i0 from "@angular/core";
|
|
13
|
+
import * as i1 from "@ngx-translate/core";
|
|
14
|
+
import * as i2 from "../formly/wrappers";
|
|
15
|
+
import * as i3 from "primeng/dropdown";
|
|
16
|
+
import * as i4 from "primeng/multiselect";
|
|
17
|
+
import * as i5 from "@angular/forms";
|
|
18
|
+
export const MNG_DROPDOWN_VALUE_ACCESSOR = {
|
|
19
|
+
provide: NG_VALUE_ACCESSOR,
|
|
20
|
+
useExisting: forwardRef(() => MngDropdownComponent),
|
|
21
|
+
multi: true
|
|
22
|
+
};
|
|
23
|
+
export class MngDropdownComponent {
|
|
24
|
+
constructor(injector, translate, formlyWrapper) {
|
|
25
|
+
this.injector = injector;
|
|
26
|
+
this.translate = translate;
|
|
27
|
+
this.formlyWrapper = formlyWrapper;
|
|
28
|
+
this.itemsLabelTranslate = false;
|
|
29
|
+
this.multiselect = false;
|
|
30
|
+
this.showClear = true;
|
|
31
|
+
this.selectFirstItem = false;
|
|
32
|
+
this.changeValueOnBlur = false;
|
|
33
|
+
this.loadingSubject = new ReplaySubject(1);
|
|
34
|
+
this.$loading = this.loadingSubject.asObservable();
|
|
35
|
+
this.valueChangeEventEmitter = new EventEmitter();
|
|
36
|
+
this.itemsSubject = new ReplaySubject(1);
|
|
37
|
+
this.dataProviderService = null;
|
|
38
|
+
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
39
|
+
this.onTouchedFn = () => { };
|
|
40
|
+
this.dropdownFormControl = new FormControl();
|
|
41
|
+
this.items$ = this.itemsSubject.asObservable();
|
|
42
|
+
this.loadingSubject.next(false);
|
|
43
|
+
}
|
|
44
|
+
ngOnInit() {
|
|
45
|
+
this.itemsLabelProperty = this.itemsLabelPropertyInit;
|
|
46
|
+
this.itemsValueProperty = this.itemsValuePropertyInit;
|
|
47
|
+
this.dropdownFormControl.valueChanges.subscribe(v => {
|
|
48
|
+
if (!this.changeValueOnBlur) {
|
|
49
|
+
this.propagateValueChange(v);
|
|
50
|
+
}
|
|
51
|
+
});
|
|
52
|
+
if (this.dataProvider) {
|
|
53
|
+
this.loadingSubject.next(true);
|
|
54
|
+
this.dataProviderService = this.dataProvider.serviceType ? this.injector.get(this.dataProvider.serviceType) : null;
|
|
55
|
+
const queryParamBuilder = MediusQueryParamBuilder.create();
|
|
56
|
+
if (this.itemsLabelTranslate) {
|
|
57
|
+
// setup translation properties
|
|
58
|
+
if (this.itemsLabelPropertyInit) {
|
|
59
|
+
this.itemsLabelProperty = `${this.itemsLabelPropertyInit}_i18n`;
|
|
60
|
+
}
|
|
61
|
+
else if (!this.itemsLabelProperty && !this.itemsValuePropertyInit) {
|
|
62
|
+
this.itemsLabelProperty = 'title_i18n';
|
|
63
|
+
this.itemsValueProperty = 'value';
|
|
64
|
+
}
|
|
65
|
+
else {
|
|
66
|
+
throw new MngErrorInternal(`Invalid use with value (${this.itemsLabelPropertyInit}) and label (${this.itemsLabelPropertyInit}) property setup.`, 'MngDropdownComponent error').consoleError();
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
this.itemsSubscription = this.dataProvider
|
|
70
|
+
.lookup(queryParamBuilder.build(), this.dataProviderService)
|
|
71
|
+
.pipe(switchMap(items => {
|
|
72
|
+
if (this.itemsLabelTranslate) {
|
|
73
|
+
const translationKeys = items.map(item => (typeof item === 'object' && this.itemsLabelPropertyInit ? item[this.itemsLabelPropertyInit] : item));
|
|
74
|
+
if (translationKeys.length === 0) {
|
|
75
|
+
return of([]);
|
|
76
|
+
}
|
|
77
|
+
return this.translate.stream(translationKeys).pipe(map(translations => items.map(item => {
|
|
78
|
+
if (typeof item === 'object' && this.itemsLabelPropertyInit) {
|
|
79
|
+
const label = item[this.itemsLabelPropertyInit];
|
|
80
|
+
const translation = translations[label];
|
|
81
|
+
if (translation) {
|
|
82
|
+
return { ...item, [this.itemsLabelProperty]: translation };
|
|
83
|
+
}
|
|
84
|
+
return { ...item };
|
|
85
|
+
}
|
|
86
|
+
else {
|
|
87
|
+
const translation = translations[item];
|
|
88
|
+
return {
|
|
89
|
+
[this.itemsLabelProperty]: translation ?? item,
|
|
90
|
+
[this.itemsValueProperty]: item
|
|
91
|
+
};
|
|
92
|
+
}
|
|
93
|
+
})));
|
|
94
|
+
}
|
|
95
|
+
else {
|
|
96
|
+
return of(items);
|
|
97
|
+
}
|
|
98
|
+
}))
|
|
99
|
+
.subscribe(res => {
|
|
100
|
+
this.itemsSubject.next(res);
|
|
101
|
+
this.loadingSubject.next(false);
|
|
102
|
+
});
|
|
103
|
+
if (this.selectFirstItem && !this.dropdownFormControl?.value) {
|
|
104
|
+
this.items$.pipe(first()).subscribe(res => {
|
|
105
|
+
const value = this.itemsValueProperty ? res[0][this.itemsValueProperty] : res[0];
|
|
106
|
+
this.dropdownFormControl?.setValue(value);
|
|
107
|
+
});
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
else {
|
|
111
|
+
console.warn(`Data provider should be provided for MngDropdownComponent.`);
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
ngOnDestroy() {
|
|
115
|
+
this.itemsSubscription?.unsubscribe();
|
|
116
|
+
}
|
|
117
|
+
registerOnChange(fn) {
|
|
118
|
+
this.onChangeFn = fn;
|
|
119
|
+
}
|
|
120
|
+
registerOnTouched(fn) {
|
|
121
|
+
this.onTouchedFn = fn;
|
|
122
|
+
}
|
|
123
|
+
setDisabledState(isDisabled) {
|
|
124
|
+
if (isDisabled) {
|
|
125
|
+
this.dropdownFormControl.disable();
|
|
126
|
+
}
|
|
127
|
+
else {
|
|
128
|
+
this.dropdownFormControl.enable();
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
writeValue(obj) {
|
|
132
|
+
// this check is required because angular in some cases writes null value
|
|
133
|
+
// before value accessor is initialized
|
|
134
|
+
// if form control value is of primitive type (ex: enums) then write value is not called (we think)
|
|
135
|
+
if (!this.itemsValuePropertyInit && obj === null && !this.isValueAccessorInitialized()) {
|
|
136
|
+
return;
|
|
137
|
+
}
|
|
138
|
+
this.dropdownFormControl.setValue(obj, { emitEvent: false });
|
|
139
|
+
}
|
|
140
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
141
|
+
onDropdownBlur(event) {
|
|
142
|
+
if (this.changeValueOnBlur) {
|
|
143
|
+
this.propagateValueChange(this.dropdownFormControl.value);
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
147
|
+
onPanelHide(event) {
|
|
148
|
+
if (this.changeValueOnBlur) {
|
|
149
|
+
this.propagateValueChange(this.dropdownFormControl.value);
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
propagateValueChange(value) {
|
|
153
|
+
if (!this.isValueAccessorInitialized()) {
|
|
154
|
+
return;
|
|
155
|
+
}
|
|
156
|
+
this.formlyWrapper?.formControl?.markAsTouched();
|
|
157
|
+
this.onChangeFn(value);
|
|
158
|
+
this.valueChangeEventEmitter.next(value);
|
|
159
|
+
}
|
|
160
|
+
/**
|
|
161
|
+
* Prevents executions for writing and outputting value which is sometimes committed as null in cmp initialization stage.
|
|
162
|
+
* In dropdown (from ang. 15 and switch to standalone cmp) null value was always committed to dropdown even if default value was set (using ngModel or formControl) which is incorrect.
|
|
163
|
+
* Github issue: https://github.com/angular/angular/issues/14988
|
|
164
|
+
* @private
|
|
165
|
+
*/
|
|
166
|
+
isValueAccessorInitialized() {
|
|
167
|
+
return typeof this.onChangeFn !== 'undefined';
|
|
168
|
+
}
|
|
169
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: MngDropdownComponent, deps: [{ token: i0.Injector }, { token: i1.TranslateService }, { token: i2.MngFormlyFieldWrapperComponent, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
170
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.7", type: MngDropdownComponent, isStandalone: true, selector: "mng-dropdown", inputs: { dataProvider: "dataProvider", dataKeyProperty: "dataKeyProperty", itemsLabelPropertyInit: ["itemsLabelProperty", "itemsLabelPropertyInit"], itemsLabelTranslate: "itemsLabelTranslate", itemsValuePropertyInit: ["itemsValueProperty", "itemsValuePropertyInit"], itemsDisabledProperty: "itemsDisabledProperty", multiselect: "multiselect", placeholder: "placeholder", showClear: "showClear", selectFirstItem: "selectFirstItem", className: "className", dropdownClassName: "dropdownClassName", changeValueOnBlur: "changeValueOnBlur" }, outputs: { valueChangeEventEmitter: "valueChange" }, providers: [MNG_DROPDOWN_VALUE_ACCESSOR], viewQueries: [{ propertyName: "primeDropdown", first: true, predicate: Dropdown, descendants: true }], ngImport: i0, template: "<p-dropdown\n *ngIf=\"!multiselect; else pMultiselect\"\n [formControl]=\"dropdownFormControl\"\n [placeholder]=\"placeholder\"\n [dataKey]=\"dataKeyProperty\"\n [optionLabel]=\"itemsLabelProperty\"\n [optionValue]=\"itemsValueProperty\"\n [optionDisabled]=\"itemsDisabledProperty\"\n [options]=\"(items$ | async) ?? undefined\"\n [showClear]=\"showClear\"\n [autoDisplayFirst]=\"false\"\n [styleClass]=\"className\"\n [panelStyleClass]=\"dropdownClassName\"\n (onBlur)=\"onDropdownBlur($event)\"\n [dropdownIcon]=\"($loading | async) ?? false ? 'pi pi-spinner pi-spin' : 'pi pi-chevron-down'\"\n appendTo=\"body\">\n</p-dropdown>\n<ng-template #pMultiselect>\n <p-multiSelect\n [maxSelectedLabels]=\"1\"\n [selectedItemsLabel]=\"'mngDropdown.multiselectOverMaxDisplayLimit' | translate\"\n [formControl]=\"dropdownFormControl\"\n [defaultLabel]=\"placeholder\"\n [dataKey]=\"dataKeyProperty\"\n [optionLabel]=\"itemsLabelProperty\"\n [optionValue]=\"itemsValueProperty\"\n [optionDisabled]=\"itemsDisabledProperty\"\n [options]=\"(items$ | async) ?? []\"\n [styleClass]=\"className\"\n [panelStyleClass]=\"dropdownClassName\"\n [filter]=\"true\"\n [showToggleAll]=\"false\"\n (onPanelHide)=\"onPanelHide($event)\"\n appendTo=\"body\">\n </p-multiSelect>\n</ng-template>\n", dependencies: [{ kind: "ngmodule", type: DropdownModule }, { kind: "component", type: i3.Dropdown, selector: "p-dropdown", inputs: ["scrollHeight", "filter", "name", "style", "panelStyle", "styleClass", "panelStyleClass", "readonly", "required", "editable", "appendTo", "tabindex", "placeholder", "filterPlaceholder", "filterLocale", "inputId", "selectId", "dataKey", "filterBy", "autofocus", "resetFilterOnHide", "dropdownIcon", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "autoDisplayFirst", "group", "showClear", "emptyFilterMessage", "emptyMessage", "lazy", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "overlayOptions", "ariaFilterLabel", "ariaLabel", "ariaLabelledBy", "filterMatchMode", "maxlength", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "autofocusFilter", "overlayDirection", "disabled", "itemSize", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "filterValue", "options"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onShow", "onHide", "onClear", "onLazyLoad"] }, { kind: "ngmodule", type: MultiSelectModule }, { kind: "component", type: i4.MultiSelect, selector: "p-multiSelect", inputs: ["style", "styleClass", "panelStyle", "panelStyleClass", "inputId", "disabled", "readonly", "group", "filter", "filterPlaceHolder", "filterLocale", "overlayVisible", "tabindex", "appendTo", "dataKey", "name", "label", "ariaLabelledBy", "displaySelectedLabel", "maxSelectedLabels", "selectionLimit", "selectedItemsLabel", "showToggleAll", "emptyFilterMessage", "emptyMessage", "resetFilterOnHide", "dropdownIcon", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "showHeader", "filterBy", "scrollHeight", "lazy", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "overlayOptions", "ariaFilterLabel", "filterMatchMode", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "autofocusFilter", "display", "autocomplete", "showClear", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "defaultLabel", "placeholder", "options", "filterValue", "itemSize"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onClear", "onPanelShow", "onPanelHide", "onLazyLoad", "onRemove"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
171
|
+
}
|
|
172
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: MngDropdownComponent, decorators: [{
|
|
173
|
+
type: Component,
|
|
174
|
+
args: [{ standalone: true, selector: 'mng-dropdown', providers: [MNG_DROPDOWN_VALUE_ACCESSOR], imports: [DropdownModule, MultiSelectModule, TranslateModule, AsyncPipe, NgIf, ReactiveFormsModule], changeDetection: ChangeDetectionStrategy.OnPush, template: "<p-dropdown\n *ngIf=\"!multiselect; else pMultiselect\"\n [formControl]=\"dropdownFormControl\"\n [placeholder]=\"placeholder\"\n [dataKey]=\"dataKeyProperty\"\n [optionLabel]=\"itemsLabelProperty\"\n [optionValue]=\"itemsValueProperty\"\n [optionDisabled]=\"itemsDisabledProperty\"\n [options]=\"(items$ | async) ?? undefined\"\n [showClear]=\"showClear\"\n [autoDisplayFirst]=\"false\"\n [styleClass]=\"className\"\n [panelStyleClass]=\"dropdownClassName\"\n (onBlur)=\"onDropdownBlur($event)\"\n [dropdownIcon]=\"($loading | async) ?? false ? 'pi pi-spinner pi-spin' : 'pi pi-chevron-down'\"\n appendTo=\"body\">\n</p-dropdown>\n<ng-template #pMultiselect>\n <p-multiSelect\n [maxSelectedLabels]=\"1\"\n [selectedItemsLabel]=\"'mngDropdown.multiselectOverMaxDisplayLimit' | translate\"\n [formControl]=\"dropdownFormControl\"\n [defaultLabel]=\"placeholder\"\n [dataKey]=\"dataKeyProperty\"\n [optionLabel]=\"itemsLabelProperty\"\n [optionValue]=\"itemsValueProperty\"\n [optionDisabled]=\"itemsDisabledProperty\"\n [options]=\"(items$ | async) ?? []\"\n [styleClass]=\"className\"\n [panelStyleClass]=\"dropdownClassName\"\n [filter]=\"true\"\n [showToggleAll]=\"false\"\n (onPanelHide)=\"onPanelHide($event)\"\n appendTo=\"body\">\n </p-multiSelect>\n</ng-template>\n" }]
|
|
175
|
+
}], ctorParameters: function () { return [{ type: i0.Injector }, { type: i1.TranslateService }, { type: i2.MngFormlyFieldWrapperComponent, decorators: [{
|
|
176
|
+
type: Optional
|
|
177
|
+
}] }]; }, propDecorators: { dataProvider: [{
|
|
178
|
+
type: Input
|
|
179
|
+
}], dataKeyProperty: [{
|
|
180
|
+
type: Input
|
|
181
|
+
}], itemsLabelPropertyInit: [{
|
|
182
|
+
type: Input,
|
|
183
|
+
args: ['itemsLabelProperty']
|
|
184
|
+
}], itemsLabelTranslate: [{
|
|
185
|
+
type: Input
|
|
186
|
+
}], itemsValuePropertyInit: [{
|
|
187
|
+
type: Input,
|
|
188
|
+
args: ['itemsValueProperty']
|
|
189
|
+
}], itemsDisabledProperty: [{
|
|
190
|
+
type: Input
|
|
191
|
+
}], multiselect: [{
|
|
192
|
+
type: Input
|
|
193
|
+
}], placeholder: [{
|
|
194
|
+
type: Input
|
|
195
|
+
}], showClear: [{
|
|
196
|
+
type: Input
|
|
197
|
+
}], selectFirstItem: [{
|
|
198
|
+
type: Input
|
|
199
|
+
}], className: [{
|
|
200
|
+
type: Input
|
|
201
|
+
}], dropdownClassName: [{
|
|
202
|
+
type: Input
|
|
203
|
+
}], changeValueOnBlur: [{
|
|
204
|
+
type: Input
|
|
205
|
+
}], valueChangeEventEmitter: [{
|
|
206
|
+
type: Output,
|
|
207
|
+
args: ['valueChange']
|
|
208
|
+
}], primeDropdown: [{
|
|
209
|
+
type: ViewChild,
|
|
210
|
+
args: [Dropdown]
|
|
211
|
+
}] } });
|
|
212
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/form/dropdown/dropdown.component.ts","../../../../../../src/lib/components/form/dropdown/dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AsyncPipe, NgIf} from '@angular/common';\nimport {ChangeDetectionStrategy, Component, EventEmitter, ExistingProvider, Injector, Input, OnDestroy, OnInit, Optional, Output, ViewChild, forwardRef} from '@angular/core';\nimport {ControlValueAccessor, FormControl, NG_VALUE_ACCESSOR, ReactiveFormsModule} from '@angular/forms';\n\nimport {TranslateModule, TranslateService} from '@ngx-translate/core';\nimport {Dropdown, DropdownModule} from 'primeng/dropdown';\nimport {MultiSelectModule} from 'primeng/multiselect';\nimport {Observable, ReplaySubject, Subject, Subscription, of, switchMap} from 'rxjs';\nimport {first, map} from 'rxjs/operators';\n\nimport {MediusQueryParamBuilder} from '../../../api/models';\nimport {ILookupDataProvider} from '../../../data-providers';\nimport {MngErrorInternal} from '../../../models';\nimport {MngFormlyFieldWrapperComponent} from '../formly/wrappers';\n\nexport const MNG_DROPDOWN_VALUE_ACCESSOR: ExistingProvider = {\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => MngDropdownComponent),\n    multi: true\n};\n\n@Component({\n    standalone: true,\n    selector: 'mng-dropdown',\n    templateUrl: './dropdown.component.html',\n    providers: [MNG_DROPDOWN_VALUE_ACCESSOR],\n    imports: [DropdownModule, MultiSelectModule, TranslateModule, AsyncPipe, NgIf, ReactiveFormsModule],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class MngDropdownComponent implements OnInit, OnDestroy, ControlValueAccessor {\n    @Input() public dataProvider?: ILookupDataProvider<any, any>;\n    @Input() public dataKeyProperty?: string;\n    @Input('itemsLabelProperty') public itemsLabelPropertyInit?: string;\n    @Input() public itemsLabelTranslate = false;\n    @Input('itemsValueProperty') public itemsValuePropertyInit?: string;\n    @Input() public itemsDisabledProperty?: string;\n    @Input() public multiselect = false;\n    @Input() public placeholder?: string;\n    @Input() public showClear = true;\n    @Input() public selectFirstItem = false;\n    @Input() public className?: string;\n    @Input() public dropdownClassName?: string;\n    @Input() public changeValueOnBlur = false;\n\n    private loadingSubject = new ReplaySubject<boolean>(1);\n    public $loading: Observable<boolean> = this.loadingSubject.asObservable();\n\n    @Output('valueChange') public valueChangeEventEmitter = new EventEmitter();\n\n    @ViewChild(Dropdown) public primeDropdown?: Dropdown;\n\n    public itemsLabelProperty?: string;\n    public itemsValueProperty?: string;\n    private itemsSubject: Subject<Array<any>> = new ReplaySubject<Array<any>>(1);\n    private dataProviderService: any = null;\n    // eslint-disable-next-line @typescript-eslint/no-empty-function\n    private onChangeFn: any;\n    // eslint-disable-next-line @typescript-eslint/no-empty-function\n    private onTouchedFn: any = () => {};\n\n    public dropdownFormControl: FormControl = new FormControl();\n    public items$: Observable<Array<any>> = this.itemsSubject.asObservable();\n    private itemsSubscription?: Subscription;\n\n    constructor(private injector: Injector, private translate: TranslateService, @Optional() private formlyWrapper: MngFormlyFieldWrapperComponent) {\n        this.loadingSubject.next(false);\n    }\n\n    ngOnInit(): void {\n        this.itemsLabelProperty = this.itemsLabelPropertyInit;\n        this.itemsValueProperty = this.itemsValuePropertyInit;\n\n        this.dropdownFormControl.valueChanges.subscribe(v => {\n            if (!this.changeValueOnBlur) {\n                this.propagateValueChange(v);\n            }\n        });\n\n        if (this.dataProvider) {\n            this.loadingSubject.next(true);\n            this.dataProviderService = this.dataProvider.serviceType ? this.injector.get<any>(this.dataProvider.serviceType) : null;\n\n            const queryParamBuilder = MediusQueryParamBuilder.create();\n\n            if (this.itemsLabelTranslate) {\n                // setup translation properties\n                if (this.itemsLabelPropertyInit) {\n                    this.itemsLabelProperty = `${this.itemsLabelPropertyInit}_i18n`;\n                } else if (!this.itemsLabelProperty && !this.itemsValuePropertyInit) {\n                    this.itemsLabelProperty = 'title_i18n';\n                    this.itemsValueProperty = 'value';\n                } else {\n                    throw new MngErrorInternal(\n                        `Invalid use with value (${this.itemsLabelPropertyInit}) and label (${this.itemsLabelPropertyInit}) property setup.`,\n                        'MngDropdownComponent error'\n                    ).consoleError();\n                }\n            }\n\n            this.itemsSubscription = this.dataProvider\n                .lookup(queryParamBuilder.build(), this.dataProviderService)\n                .pipe(\n                    switchMap(items => {\n                        if (this.itemsLabelTranslate) {\n                            const translationKeys: string[] = items.map(\n                                item => (typeof item === 'object' && this.itemsLabelPropertyInit ? (item[this.itemsLabelPropertyInit as keyof object] as string) : item) as string\n                            );\n\n                            if (translationKeys.length === 0) {\n                                return of([]);\n                            }\n\n                            return this.translate.stream(translationKeys).pipe(\n                                map(translations =>\n                                    items.map(item => {\n                                        if (typeof item === 'object' && this.itemsLabelPropertyInit) {\n                                            const label = item[this.itemsLabelPropertyInit as keyof object] as string;\n                                            const translation: string | undefined = translations[label];\n                                            if (translation) {\n                                                return {...item, [this.itemsLabelProperty!]: translation};\n                                            }\n                                            return {...item};\n                                        } else {\n                                            const translation = translations[item];\n                                            return {\n                                                [this.itemsLabelProperty!]: translation ?? item,\n                                                [this.itemsValueProperty!]: item\n                                            };\n                                        }\n                                    })\n                                )\n                            );\n                        } else {\n                            return of(items);\n                        }\n                    })\n                )\n                .subscribe(res => {\n                    this.itemsSubject.next(res);\n                    this.loadingSubject.next(false);\n                });\n\n            if (this.selectFirstItem && !this.dropdownFormControl?.value) {\n                this.items$.pipe(first()).subscribe(res => {\n                    const value = this.itemsValueProperty ? res[0][this.itemsValueProperty] : res[0];\n                    this.dropdownFormControl?.setValue(value);\n                });\n            }\n        } else {\n            console.warn(`Data provider should be provided for MngDropdownComponent.`);\n        }\n    }\n\n    ngOnDestroy() {\n        this.itemsSubscription?.unsubscribe();\n    }\n\n    registerOnChange(fn: any): void {\n        this.onChangeFn = fn;\n    }\n\n    registerOnTouched(fn: any): void {\n        this.onTouchedFn = fn;\n    }\n\n    setDisabledState(isDisabled: boolean): void {\n        if (isDisabled) {\n            this.dropdownFormControl.disable();\n        } else {\n            this.dropdownFormControl.enable();\n        }\n    }\n\n    writeValue(obj: any): void {\n        // this check is required because angular in some cases writes null value\n        // before value accessor is initialized\n        // if form control value is of primitive type (ex: enums) then write value is not called (we think)\n        if (!this.itemsValuePropertyInit && obj === null && !this.isValueAccessorInitialized()) {\n            return;\n        }\n        this.dropdownFormControl.setValue(obj, {emitEvent: false});\n    }\n\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    onDropdownBlur(event: any) {\n        if (this.changeValueOnBlur) {\n            this.propagateValueChange(this.dropdownFormControl.value);\n        }\n    }\n\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    onPanelHide(event: any) {\n        if (this.changeValueOnBlur) {\n            this.propagateValueChange(this.dropdownFormControl.value);\n        }\n    }\n\n    private propagateValueChange(value: any) {\n        if (!this.isValueAccessorInitialized()) {\n            return;\n        }\n\n        this.formlyWrapper?.formControl?.markAsTouched();\n\n        this.onChangeFn(value);\n        this.valueChangeEventEmitter.next(value);\n    }\n\n    /**\n     * Prevents executions for writing and outputting value which is sometimes committed as null in cmp initialization stage.\n     * In dropdown (from ang. 15 and switch to standalone cmp) null value was always committed to dropdown even if default value was set (using ngModel or formControl) which is incorrect.\n     * Github issue: https://github.com/angular/angular/issues/14988\n     * @private\n     */\n    private isValueAccessorInitialized() {\n        return typeof this.onChangeFn !== 'undefined';\n    }\n}\n","<p-dropdown\n    *ngIf=\"!multiselect; else pMultiselect\"\n    [formControl]=\"dropdownFormControl\"\n    [placeholder]=\"placeholder\"\n    [dataKey]=\"dataKeyProperty\"\n    [optionLabel]=\"itemsLabelProperty\"\n    [optionValue]=\"itemsValueProperty\"\n    [optionDisabled]=\"itemsDisabledProperty\"\n    [options]=\"(items$ | async) ?? undefined\"\n    [showClear]=\"showClear\"\n    [autoDisplayFirst]=\"false\"\n    [styleClass]=\"className\"\n    [panelStyleClass]=\"dropdownClassName\"\n    (onBlur)=\"onDropdownBlur($event)\"\n    [dropdownIcon]=\"($loading | async) ?? false ? 'pi pi-spinner pi-spin' : 'pi pi-chevron-down'\"\n    appendTo=\"body\">\n</p-dropdown>\n<ng-template #pMultiselect>\n    <p-multiSelect\n        [maxSelectedLabels]=\"1\"\n        [selectedItemsLabel]=\"'mngDropdown.multiselectOverMaxDisplayLimit' | translate\"\n        [formControl]=\"dropdownFormControl\"\n        [defaultLabel]=\"placeholder\"\n        [dataKey]=\"dataKeyProperty\"\n        [optionLabel]=\"itemsLabelProperty\"\n        [optionValue]=\"itemsValueProperty\"\n        [optionDisabled]=\"itemsDisabledProperty\"\n        [options]=\"(items$ | async) ?? []\"\n        [styleClass]=\"className\"\n        [panelStyleClass]=\"dropdownClassName\"\n        [filter]=\"true\"\n        [showToggleAll]=\"false\"\n        (onPanelHide)=\"onPanelHide($event)\"\n        appendTo=\"body\">\n    </p-multiSelect>\n</ng-template>\n"]}
|
|
@@ -0,0 +1,288 @@
|
|
|
1
|
+
import { AsyncPipe } from '@angular/common';
|
|
2
|
+
import { ChangeDetectionStrategy, Component, ContentChildren, ElementRef, EventEmitter, Input, Output, QueryList, ViewChild } from '@angular/core';
|
|
3
|
+
import { FormArray, FormGroup, ReactiveFormsModule } from '@angular/forms';
|
|
4
|
+
import { FormlyModule } from '@ngx-formly/core';
|
|
5
|
+
import { TranslateService } from '@ngx-translate/core';
|
|
6
|
+
import { ButtonModule } from 'primeng/button';
|
|
7
|
+
import { MessagesModule } from 'primeng/messages';
|
|
8
|
+
import { Observable, ReplaySubject, debounceTime, distinctUntilChanged, of } from 'rxjs';
|
|
9
|
+
import { EditorDescriptor } from '../../../descriptors/editor';
|
|
10
|
+
import { TableviewEditorTypeEnum } from '../../../descriptors/types';
|
|
11
|
+
import { MngTemplateDirective } from '../../../directives';
|
|
12
|
+
import { MngCommonsService } from '../../../services';
|
|
13
|
+
import { EditorFormlyUtil, NotificationUtil, ObjectUtil } from '../../../utils';
|
|
14
|
+
import { MngFormEditorSubmitEvent, MngFormEventTypeEnum, MngFormFieldEventComponentSubtype } from '../models';
|
|
15
|
+
import * as i0 from "@angular/core";
|
|
16
|
+
import * as i1 from "../../../services";
|
|
17
|
+
import * as i2 from "@ngx-translate/core";
|
|
18
|
+
import * as i3 from "@ngx-formly/core";
|
|
19
|
+
import * as i4 from "@angular/forms";
|
|
20
|
+
import * as i5 from "primeng/messages";
|
|
21
|
+
import * as i6 from "primeng/button";
|
|
22
|
+
export class MngFormEditorComponent {
|
|
23
|
+
constructor(mngCommonsService, translateService) {
|
|
24
|
+
this.mngCommonsService = mngCommonsService;
|
|
25
|
+
this.translateService = translateService;
|
|
26
|
+
this.submitLoading = false;
|
|
27
|
+
this.viewContainerSubject = new ReplaySubject(1);
|
|
28
|
+
this.viewContainer$ = this.viewContainerSubject.asObservable();
|
|
29
|
+
// extra features input
|
|
30
|
+
this.isFormDisabled = false;
|
|
31
|
+
// event outputs
|
|
32
|
+
this.formSubmitEventEmitter = new EventEmitter();
|
|
33
|
+
this.form = new FormGroup({});
|
|
34
|
+
this.formOptions = {
|
|
35
|
+
formState: {
|
|
36
|
+
add: false,
|
|
37
|
+
edit: false,
|
|
38
|
+
disabled: false
|
|
39
|
+
}
|
|
40
|
+
};
|
|
41
|
+
this.formModel = {};
|
|
42
|
+
this.formMessages = [];
|
|
43
|
+
this.subscriptions = [];
|
|
44
|
+
}
|
|
45
|
+
ngOnInit() {
|
|
46
|
+
this.setInitialFormState();
|
|
47
|
+
this.resetFormModel(this.item);
|
|
48
|
+
this.submitLoading$ = this.submitLoading instanceof Observable ? this.submitLoading : of(this.submitLoading);
|
|
49
|
+
if (this.descriptor) {
|
|
50
|
+
// init fields for formly
|
|
51
|
+
this.formFields = EditorFormlyUtil.createFormlyConfigFromDescriptor(this.descriptor, this);
|
|
52
|
+
this.updateFormState();
|
|
53
|
+
// let the user know, that adding new value in table view with localizations is only supported in the default language
|
|
54
|
+
if (this.descriptor.isLocalized &&
|
|
55
|
+
(this.descriptor.tableviewEditorType === TableviewEditorTypeEnum.Add || this.descriptor.tableviewEditorType === TableviewEditorTypeEnum.Edit)) {
|
|
56
|
+
this.formMessages.push(NotificationUtil.getFormEditorInfoMessage(this.translateService, 'mngEditor.localizations.addInDefaultLanguageTitle', 'mngEditor.localizations.addInDefaultLanguageDescription', { defaultLanguage: this.mngCommonsService.defaultDataLanguage }));
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
// emit lifecycle event
|
|
60
|
+
this.descriptor?.nextEvent(MngFormEventTypeEnum.ComponentLifecycle, MngFormEditorComponent, this, {
|
|
61
|
+
eventSubtype: MngFormFieldEventComponentSubtype.ON_INIT
|
|
62
|
+
});
|
|
63
|
+
this.subscriptions.push(this.form.valueChanges.pipe(debounceTime(250), distinctUntilChanged()).subscribe(v => {
|
|
64
|
+
this.descriptor?.nextEvent(MngFormEventTypeEnum.ValueChange, MngFormEditorComponent, this, {
|
|
65
|
+
value: v,
|
|
66
|
+
formValue: () => this.getFormValue()
|
|
67
|
+
});
|
|
68
|
+
}));
|
|
69
|
+
}
|
|
70
|
+
ngOnChanges(changes) {
|
|
71
|
+
if (changes['viewContainerInit'] && !changes['viewContainerInit'].firstChange) {
|
|
72
|
+
this.viewContainerSubject.next(changes['viewContainerInit']);
|
|
73
|
+
}
|
|
74
|
+
if (changes['isFormDisabled'] && !changes['isFormDisabled'].firstChange) {
|
|
75
|
+
this.updateFormState();
|
|
76
|
+
}
|
|
77
|
+
if (changes['item'] && !changes['item'].firstChange) {
|
|
78
|
+
this.resetFormModel(this.item);
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
ngOnDestroy() {
|
|
82
|
+
this.subscriptions.forEach(s => s.unsubscribe());
|
|
83
|
+
// emit lifecycle event
|
|
84
|
+
this.descriptor?.nextEvent(MngFormEventTypeEnum.ComponentLifecycle, MngFormEditorComponent, this, {
|
|
85
|
+
eventSubtype: MngFormFieldEventComponentSubtype.ON_DESTROY
|
|
86
|
+
});
|
|
87
|
+
// complete emitting events
|
|
88
|
+
this.descriptor?.completeEvents();
|
|
89
|
+
}
|
|
90
|
+
submit() {
|
|
91
|
+
this.submitButtonElementRef?.nativeElement.click();
|
|
92
|
+
}
|
|
93
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
94
|
+
onSubmit(event) {
|
|
95
|
+
this.formOptions.formState.submittedOn = Date.now();
|
|
96
|
+
this.formMessages = [];
|
|
97
|
+
const formSubmitItem = this.getFormValue();
|
|
98
|
+
if (this.form.valid) {
|
|
99
|
+
this.formSubmitEventEmitter.next(new MngFormEditorSubmitEvent(formSubmitItem));
|
|
100
|
+
this.descriptor?.nextEvent(MngFormEventTypeEnum.Submit, MngFormEditorComponent, this, {
|
|
101
|
+
submitValid: true,
|
|
102
|
+
submitValue: formSubmitItem
|
|
103
|
+
});
|
|
104
|
+
}
|
|
105
|
+
else {
|
|
106
|
+
// find and mark invalid tabs
|
|
107
|
+
if (this.formFields[0].type === 'tabs' && this.formFields[0].fieldGroup) {
|
|
108
|
+
for (const tab of this.formFields[0].fieldGroup) {
|
|
109
|
+
const isInvalid = this.isAnyFieldInvalid(tab.fieldGroup);
|
|
110
|
+
this.formOptions.formState['tab_' + (tab.id ? tab.id : tab.props.props.label) + '_invalid'] = isInvalid;
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
const event = new MngFormEditorSubmitEvent(formSubmitItem);
|
|
114
|
+
event.success = false;
|
|
115
|
+
this.formMessages.push(NotificationUtil.getFormEditorWarningMessage(this.translateService, 'mngEditor.invalidFormToastTitle', 'mngEditor.invalidFormToastMessage'));
|
|
116
|
+
this.formSubmitEventEmitter.next(event);
|
|
117
|
+
this.descriptor?.nextEvent(MngFormEventTypeEnum.Submit, MngFormEditorComponent, this, {
|
|
118
|
+
submitValid: false,
|
|
119
|
+
submitValue: formSubmitItem
|
|
120
|
+
});
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
getFormValue() {
|
|
124
|
+
const formValue = ObjectUtil.deepCopyObject(this.form.getRawValue(), { mapGettersToProperties: true });
|
|
125
|
+
this.descriptor?.fields.forEach(field => {
|
|
126
|
+
if (field && field.setter) {
|
|
127
|
+
const splitPath = field.property.split('.');
|
|
128
|
+
let fieldValue = formValue;
|
|
129
|
+
for (let i = 0; i < splitPath.length - 1; i++) {
|
|
130
|
+
const currentSubPath = splitPath[i];
|
|
131
|
+
if (typeof fieldValue[currentSubPath] !== 'object') {
|
|
132
|
+
fieldValue[currentSubPath] = {};
|
|
133
|
+
}
|
|
134
|
+
fieldValue = fieldValue[currentSubPath];
|
|
135
|
+
}
|
|
136
|
+
fieldValue = fieldValue[splitPath[splitPath.length - 1]];
|
|
137
|
+
field.setter(formValue, fieldValue);
|
|
138
|
+
}
|
|
139
|
+
});
|
|
140
|
+
return formValue;
|
|
141
|
+
}
|
|
142
|
+
resetFormModel(item) {
|
|
143
|
+
if (typeof item !== 'undefined') {
|
|
144
|
+
this.originalItemPrototype = Object.getPrototypeOf(item);
|
|
145
|
+
}
|
|
146
|
+
const formModel = ObjectUtil.deepCopyObject(item, { mapGettersToProperties: true }) ?? {};
|
|
147
|
+
this.descriptor?.fields.forEach(field => {
|
|
148
|
+
if (field.getter && item) {
|
|
149
|
+
const splitPath = field.property.split('.');
|
|
150
|
+
let currentObject = formModel;
|
|
151
|
+
for (let i = 0; i < splitPath.length; i++) {
|
|
152
|
+
const currentSubPath = splitPath[i];
|
|
153
|
+
if (i === splitPath.length - 1) {
|
|
154
|
+
currentObject[currentSubPath] = field.getter(item);
|
|
155
|
+
}
|
|
156
|
+
else {
|
|
157
|
+
if (typeof currentObject[currentSubPath] !== 'object') {
|
|
158
|
+
currentObject[currentSubPath] = {};
|
|
159
|
+
}
|
|
160
|
+
currentObject = currentObject[currentSubPath];
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
});
|
|
165
|
+
if (typeof this.formOptions.resetModel === 'function') {
|
|
166
|
+
// could not be initiated yet
|
|
167
|
+
this.formOptions.resetModel(this.formModel);
|
|
168
|
+
}
|
|
169
|
+
this.formModel = formModel;
|
|
170
|
+
}
|
|
171
|
+
getFormField(key) {
|
|
172
|
+
return this.findFormField(this.form, key.split('.'));
|
|
173
|
+
}
|
|
174
|
+
setFormFieldValue(key, value) {
|
|
175
|
+
const control = this.getFormField(key);
|
|
176
|
+
if (control) {
|
|
177
|
+
control.setValue(value);
|
|
178
|
+
return true;
|
|
179
|
+
}
|
|
180
|
+
else {
|
|
181
|
+
console.warn(`Value was not set, because field ${key} was not found.`);
|
|
182
|
+
return false;
|
|
183
|
+
}
|
|
184
|
+
}
|
|
185
|
+
patchFormFieldValue(key, value) {
|
|
186
|
+
const control = this.getFormField(key);
|
|
187
|
+
if (control) {
|
|
188
|
+
control.patchValue(value);
|
|
189
|
+
return true;
|
|
190
|
+
}
|
|
191
|
+
else {
|
|
192
|
+
console.warn(`Value was not set, because field ${key} was not found.`);
|
|
193
|
+
return false;
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
resetFormFieldValue(key, value) {
|
|
197
|
+
const control = this.getFormField(key);
|
|
198
|
+
if (control) {
|
|
199
|
+
control.reset(value);
|
|
200
|
+
return true;
|
|
201
|
+
}
|
|
202
|
+
else {
|
|
203
|
+
console.warn(`Value was not set, because field ${key} was not found.`);
|
|
204
|
+
return false;
|
|
205
|
+
}
|
|
206
|
+
}
|
|
207
|
+
findFormField(control, keyPath) {
|
|
208
|
+
if (keyPath.length === 0) {
|
|
209
|
+
return control;
|
|
210
|
+
}
|
|
211
|
+
if (keyPath.length === 1) {
|
|
212
|
+
return control.get(keyPath[0]);
|
|
213
|
+
}
|
|
214
|
+
let nextControl = null;
|
|
215
|
+
if (control instanceof FormGroup) {
|
|
216
|
+
nextControl = control.get(keyPath[0]);
|
|
217
|
+
}
|
|
218
|
+
else if (control instanceof FormArray) {
|
|
219
|
+
const idx = +keyPath[0];
|
|
220
|
+
if (!isNaN(idx)) {
|
|
221
|
+
nextControl = control.at(idx);
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
if (!control) {
|
|
225
|
+
return null;
|
|
226
|
+
}
|
|
227
|
+
return this.findFormField(nextControl, keyPath.slice(1));
|
|
228
|
+
}
|
|
229
|
+
isAnyFieldInvalid(fields = []) {
|
|
230
|
+
for (const field of fields) {
|
|
231
|
+
let fieldInvalid = false;
|
|
232
|
+
if (Array.isArray(field.fieldGroup)) {
|
|
233
|
+
fieldInvalid = this.isAnyFieldInvalid(field.fieldGroup);
|
|
234
|
+
}
|
|
235
|
+
else if (typeof field.type !== 'undefined') {
|
|
236
|
+
fieldInvalid = !field.formControl?.valid;
|
|
237
|
+
}
|
|
238
|
+
if (fieldInvalid) {
|
|
239
|
+
return true;
|
|
240
|
+
}
|
|
241
|
+
}
|
|
242
|
+
return false;
|
|
243
|
+
}
|
|
244
|
+
updateFormState() {
|
|
245
|
+
const isDisabled = this.isFormDisabled || this.descriptor?.disabled === true || this.descriptor?.tableviewEditorType === TableviewEditorTypeEnum.Details;
|
|
246
|
+
this.formOptions.formState.disabled = isDisabled;
|
|
247
|
+
}
|
|
248
|
+
/**
|
|
249
|
+
* @private Sets form state based on editor descriptor type.
|
|
250
|
+
* Possible options are: disabled, add or edit.
|
|
251
|
+
*/
|
|
252
|
+
setInitialFormState() {
|
|
253
|
+
if (this.descriptor?.tableviewEditorType === TableviewEditorTypeEnum.Add) {
|
|
254
|
+
this.formOptions.formState.add = true;
|
|
255
|
+
}
|
|
256
|
+
else if (this.descriptor?.tableviewEditorType === TableviewEditorTypeEnum.Edit) {
|
|
257
|
+
this.formOptions.formState.edit = true;
|
|
258
|
+
}
|
|
259
|
+
this.updateFormState();
|
|
260
|
+
}
|
|
261
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: MngFormEditorComponent, deps: [{ token: i1.MngCommonsService }, { token: i2.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
262
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.7", type: MngFormEditorComponent, isStandalone: true, selector: "mng-form-editor", inputs: { descriptor: "descriptor", submitLoading: "submitLoading", item: "item", viewContainerInit: ["viewContainer", "viewContainerInit"], isFormDisabled: "isFormDisabled" }, outputs: { formSubmitEventEmitter: "formSubmit" }, queries: [{ propertyName: "templates", predicate: MngTemplateDirective }], viewQueries: [{ propertyName: "submitButtonElementRef", first: true, predicate: ["submitButton"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<form [formGroup]=\"form\" (ngSubmit)=\"onSubmit($event)\">\n <formly-form [form]=\"form\" [fields]=\"formFields\" [options]=\"formOptions\" [model]=\"formModel\"></formly-form>\n <button #submitButton pButton type=\"submit\" class=\"hidden\" [disabled]=\"form.disabled\" [loading]=\"(submitLoading$ | async) ?? false\"></button>\n</form>\n<p-messages [value]=\"formMessages\" [enableService]=\"false\"></p-messages>\n", dependencies: [{ kind: "ngmodule", type: FormlyModule }, { kind: "component", type: i3.FormlyForm, selector: "formly-form", inputs: ["form", "model", "fields", "options"], outputs: ["modelChange"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i4.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i4.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i4.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: MessagesModule }, { kind: "component", type: i5.Messages, selector: "p-messages", inputs: ["value", "closable", "style", "styleClass", "enableService", "key", "escape", "severity", "showTransitionOptions", "hideTransitionOptions"], outputs: ["valueChange"] }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "ngmodule", type: ButtonModule }, { kind: "directive", type: i6.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
263
|
+
}
|
|
264
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: MngFormEditorComponent, decorators: [{
|
|
265
|
+
type: Component,
|
|
266
|
+
args: [{ standalone: true, selector: 'mng-form-editor', imports: [FormlyModule, ReactiveFormsModule, MessagesModule, AsyncPipe, ButtonModule], changeDetection: ChangeDetectionStrategy.OnPush, template: "<form [formGroup]=\"form\" (ngSubmit)=\"onSubmit($event)\">\n <formly-form [form]=\"form\" [fields]=\"formFields\" [options]=\"formOptions\" [model]=\"formModel\"></formly-form>\n <button #submitButton pButton type=\"submit\" class=\"hidden\" [disabled]=\"form.disabled\" [loading]=\"(submitLoading$ | async) ?? false\"></button>\n</form>\n<p-messages [value]=\"formMessages\" [enableService]=\"false\"></p-messages>\n" }]
|
|
267
|
+
}], ctorParameters: function () { return [{ type: i1.MngCommonsService }, { type: i2.TranslateService }]; }, propDecorators: { descriptor: [{
|
|
268
|
+
type: Input
|
|
269
|
+
}], submitLoading: [{
|
|
270
|
+
type: Input
|
|
271
|
+
}], item: [{
|
|
272
|
+
type: Input
|
|
273
|
+
}], viewContainerInit: [{
|
|
274
|
+
type: Input,
|
|
275
|
+
args: ['viewContainer']
|
|
276
|
+
}], isFormDisabled: [{
|
|
277
|
+
type: Input
|
|
278
|
+
}], formSubmitEventEmitter: [{
|
|
279
|
+
type: Output,
|
|
280
|
+
args: ['formSubmit']
|
|
281
|
+
}], templates: [{
|
|
282
|
+
type: ContentChildren,
|
|
283
|
+
args: [MngTemplateDirective]
|
|
284
|
+
}], submitButtonElementRef: [{
|
|
285
|
+
type: ViewChild,
|
|
286
|
+
args: ['submitButton']
|
|
287
|
+
}] } });
|
|
288
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-editor.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/form/editor/form-editor.component.ts","../../../../../../src/lib/components/form/editor/form-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AsyncPipe} from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    ContentChildren,\n    ElementRef,\n    EventEmitter,\n    Input,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    Output,\n    QueryList,\n    SimpleChanges,\n    Type,\n    ViewChild\n} from '@angular/core';\nimport {AbstractControl, FormArray, FormGroup, ReactiveFormsModule} from '@angular/forms';\n\nimport {FormlyFieldConfig, FormlyFormOptions, FormlyModule} from '@ngx-formly/core';\nimport {TranslateService} from '@ngx-translate/core';\nimport {Message} from 'primeng/api';\nimport {ButtonModule} from 'primeng/button';\nimport {MessagesModule} from 'primeng/messages';\nimport {Observable, ReplaySubject, Subscription, debounceTime, distinctUntilChanged, of} from 'rxjs';\n\nimport {EditorDescriptor} from '../../../descriptors/editor';\nimport {TableviewEditorTypeEnum} from '../../../descriptors/types';\nimport {MngTemplateDirective} from '../../../directives';\nimport {IViewContainer} from '../../../models';\nimport {MngCommonsService} from '../../../services';\nimport {EditorFormlyUtil, NotificationUtil, ObjectUtil} from '../../../utils';\nimport {MngFormlyFieldConfig} from '../formly/models';\nimport {IFormEditorComponent, MngFormEditorSubmitEvent, MngFormEventTypeEnum, MngFormFieldEventComponentSubtype} from '../models';\n\n@Component({\n    standalone: true,\n    selector: 'mng-form-editor',\n    templateUrl: './form-editor.component.html',\n    imports: [FormlyModule, ReactiveFormsModule, MessagesModule, AsyncPipe, ButtonModule],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class MngFormEditorComponent<T> implements IFormEditorComponent<T>, OnInit, OnChanges, OnDestroy {\n    // metadata and editor mode input\n    @Input() public descriptor?: EditorDescriptor<T>;\n    @Input() public submitLoading: Observable<boolean> | boolean = false;\n\n    // data source inputs;\n    @Input() public item?: T;\n    @Input('viewContainer') public viewContainerInit?: IViewContainer<T, unknown>;\n    private viewContainerSubject = new ReplaySubject<IViewContainer<T, unknown>>(1);\n    public viewContainer$ = this.viewContainerSubject.asObservable();\n\n    // extra features input\n    @Input() public isFormDisabled = false;\n\n    // event outputs\n    @Output('formSubmit') public formSubmitEventEmitter = new EventEmitter<MngFormEditorSubmitEvent<T>>();\n\n    // content and view queries\n    @ContentChildren(MngTemplateDirective) public templates!: QueryList<MngTemplateDirective>;\n    @ViewChild('submitButton') public submitButtonElementRef?: ElementRef;\n\n    public form: FormGroup = new FormGroup({});\n    public formOptions: FormlyFormOptions = {\n        formState: {\n            add: false,\n            edit: false,\n            disabled: false\n        }\n    };\n    public formFields!: FormlyFieldConfig[];\n    public formModel: any = {};\n    public formMessages: Message[] = [];\n    public submitLoading$!: Observable<boolean>;\n    private originalItemPrototype?: Type<T>;\n\n    private subscriptions: Subscription[] = [];\n\n    constructor(private mngCommonsService: MngCommonsService, private translateService: TranslateService) {}\n\n    public ngOnInit() {\n        this.setInitialFormState();\n        this.resetFormModel(this.item);\n        this.submitLoading$ = this.submitLoading instanceof Observable ? this.submitLoading : of(this.submitLoading);\n\n        if (this.descriptor) {\n            // init fields for formly\n            this.formFields = EditorFormlyUtil.createFormlyConfigFromDescriptor(this.descriptor, this);\n            this.updateFormState();\n\n            // let the user know, that adding new value in table view with localizations is only supported in the default language\n            if (\n                this.descriptor.isLocalized &&\n                (this.descriptor.tableviewEditorType === TableviewEditorTypeEnum.Add || this.descriptor.tableviewEditorType === TableviewEditorTypeEnum.Edit)\n            ) {\n                this.formMessages.push(\n                    NotificationUtil.getFormEditorInfoMessage(\n                        this.translateService,\n                        'mngEditor.localizations.addInDefaultLanguageTitle',\n                        'mngEditor.localizations.addInDefaultLanguageDescription',\n                        {defaultLanguage: this.mngCommonsService.defaultDataLanguage}\n                    )\n                );\n            }\n        }\n\n        // emit lifecycle event\n        this.descriptor?.nextEvent(MngFormEventTypeEnum.ComponentLifecycle, MngFormEditorComponent, this, {\n            eventSubtype: MngFormFieldEventComponentSubtype.ON_INIT\n        });\n\n        this.subscriptions.push(\n            this.form.valueChanges.pipe(debounceTime(250), distinctUntilChanged()).subscribe(v => {\n                this.descriptor?.nextEvent(MngFormEventTypeEnum.ValueChange, MngFormEditorComponent, this, {\n                    value: v,\n                    formValue: () => this.getFormValue()\n                });\n            })\n        );\n    }\n\n    ngOnChanges(changes: SimpleChanges) {\n        if (changes['viewContainerInit'] && !changes['viewContainerInit'].firstChange) {\n            this.viewContainerSubject.next(changes['viewContainerInit'] as any);\n        }\n        if (changes['isFormDisabled'] && !changes['isFormDisabled'].firstChange) {\n            this.updateFormState();\n        }\n        if (changes['item'] && !changes['item'].firstChange) {\n            this.resetFormModel(this.item);\n        }\n    }\n\n    public ngOnDestroy() {\n        this.subscriptions.forEach(s => s.unsubscribe());\n\n        // emit lifecycle event\n        this.descriptor?.nextEvent(MngFormEventTypeEnum.ComponentLifecycle, MngFormEditorComponent, this, {\n            eventSubtype: MngFormFieldEventComponentSubtype.ON_DESTROY\n        });\n        // complete emitting events\n        this.descriptor?.completeEvents();\n    }\n\n    public submit() {\n        this.submitButtonElementRef?.nativeElement.click();\n    }\n\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    public onSubmit(event: Event) {\n        this.formOptions.formState.submittedOn = Date.now();\n        this.formMessages = [];\n\n        const formSubmitItem = this.getFormValue();\n        if (this.form.valid) {\n            this.formSubmitEventEmitter.next(new MngFormEditorSubmitEvent(formSubmitItem));\n            this.descriptor?.nextEvent(MngFormEventTypeEnum.Submit, MngFormEditorComponent, this, {\n                submitValid: true,\n                submitValue: formSubmitItem\n            });\n        } else {\n            // find and mark invalid tabs\n            if (this.formFields[0].type === 'tabs' && this.formFields[0].fieldGroup) {\n                for (const tab of this.formFields[0].fieldGroup) {\n                    const isInvalid = this.isAnyFieldInvalid(tab.fieldGroup);\n                    this.formOptions.formState['tab_' + (tab.id ? tab.id : (tab.props as MngFormlyFieldConfig).props.label) + '_invalid'] = isInvalid;\n                }\n            }\n            const event = new MngFormEditorSubmitEvent(formSubmitItem);\n            event.success = false;\n            this.formMessages.push(NotificationUtil.getFormEditorWarningMessage(this.translateService, 'mngEditor.invalidFormToastTitle', 'mngEditor.invalidFormToastMessage'));\n\n            this.formSubmitEventEmitter.next(event);\n            this.descriptor?.nextEvent(MngFormEventTypeEnum.Submit, MngFormEditorComponent, this, {\n                submitValid: false,\n                submitValue: formSubmitItem\n            });\n        }\n    }\n\n    public getFormValue(): T {\n        const formValue = ObjectUtil.deepCopyObject(this.form.getRawValue(), {mapGettersToProperties: true});\n\n        this.descriptor?.fields.forEach(field => {\n            if (field && field.setter) {\n                const splitPath = field.property.split('.');\n                let fieldValue = formValue;\n                for (let i = 0; i < splitPath.length - 1; i++) {\n                    const currentSubPath = splitPath[i];\n                    if (typeof fieldValue[currentSubPath] !== 'object') {\n                        fieldValue[currentSubPath] = {};\n                    }\n\n                    fieldValue = fieldValue[currentSubPath];\n                }\n\n                fieldValue = fieldValue[splitPath[splitPath.length - 1]];\n                field.setter(formValue, fieldValue);\n            }\n        });\n        return formValue;\n    }\n\n    public resetFormModel(item?: T) {\n        if (typeof item !== 'undefined') {\n            this.originalItemPrototype = Object.getPrototypeOf(item);\n        }\n\n        const formModel = (ObjectUtil.deepCopyObject(item, {mapGettersToProperties: true}) as Record<string, any>) ?? {};\n\n        this.descriptor?.fields.forEach(field => {\n            if (field.getter && item) {\n                const splitPath = field.property.split('.');\n                let currentObject = formModel;\n\n                for (let i = 0; i < splitPath.length; i++) {\n                    const currentSubPath = splitPath[i];\n                    if (i === splitPath.length - 1) {\n                        currentObject[currentSubPath] = field.getter(item);\n                    } else {\n                        if (typeof currentObject[currentSubPath] !== 'object') {\n                            currentObject[currentSubPath] = {};\n                        }\n\n                        currentObject = currentObject[currentSubPath];\n                    }\n                }\n            }\n        });\n        if (typeof this.formOptions.resetModel === 'function') {\n            // could not be initiated yet\n            this.formOptions.resetModel(this.formModel);\n        }\n        this.formModel = formModel;\n    }\n\n    public getFormField(key: string) {\n        return this.findFormField(this.form, key.split('.'));\n    }\n\n    public setFormFieldValue(key: string, value: any) {\n        const control = this.getFormField(key);\n        if (control) {\n            control.setValue(value);\n            return true;\n        } else {\n            console.warn(`Value was not set, because field ${key} was not found.`);\n            return false;\n        }\n    }\n\n    public patchFormFieldValue(key: string, value: any) {\n        const control = this.getFormField(key);\n        if (control) {\n            control.patchValue(value);\n            return true;\n        } else {\n            console.warn(`Value was not set, because field ${key} was not found.`);\n            return false;\n        }\n    }\n\n    public resetFormFieldValue(key: string, value?: any) {\n        const control = this.getFormField(key);\n        if (control) {\n            control.reset(value);\n            return true;\n        } else {\n            console.warn(`Value was not set, because field ${key} was not found.`);\n            return false;\n        }\n    }\n\n    private findFormField(control: AbstractControl, keyPath: string[]): AbstractControl | null {\n        if (keyPath.length === 0) {\n            return control;\n        }\n        if (keyPath.length === 1) {\n            return control.get(keyPath[0]);\n        }\n        let nextControl: AbstractControl | null = null;\n        if (control instanceof FormGroup) {\n            nextControl = control.get(keyPath[0]);\n        } else if (control instanceof FormArray) {\n            const idx = +keyPath[0];\n            if (!isNaN(idx)) {\n                nextControl = control.at(idx);\n            }\n        }\n\n        if (!control) {\n            return null;\n        }\n        return this.findFormField(nextControl!, keyPath.slice(1));\n    }\n\n    private isAnyFieldInvalid(fields: FormlyFieldConfig[] = []): boolean {\n        for (const field of fields) {\n            let fieldInvalid = false;\n            if (Array.isArray(field.fieldGroup)) {\n                fieldInvalid = this.isAnyFieldInvalid(field.fieldGroup);\n            } else if (typeof field.type !== 'undefined') {\n                fieldInvalid = !field.formControl?.valid;\n            }\n            if (fieldInvalid) {\n                return true;\n            }\n        }\n        return false;\n    }\n\n    private updateFormState() {\n        const isDisabled = this.isFormDisabled || this.descriptor?.disabled === true || this.descriptor?.tableviewEditorType === TableviewEditorTypeEnum.Details;\n        this.formOptions.formState.disabled = isDisabled;\n    }\n\n    /**\n     * @private Sets form state based on editor descriptor type.\n     * Possible options are: disabled, add or edit.\n     */\n    private setInitialFormState(): void {\n        if (this.descriptor?.tableviewEditorType === TableviewEditorTypeEnum.Add) {\n            this.formOptions.formState.add = true;\n        } else if (this.descriptor?.tableviewEditorType === TableviewEditorTypeEnum.Edit) {\n            this.formOptions.formState.edit = true;\n        }\n        this.updateFormState();\n    }\n}\n","<form [formGroup]=\"form\" (ngSubmit)=\"onSubmit($event)\">\n    <formly-form [form]=\"form\" [fields]=\"formFields\" [options]=\"formOptions\" [model]=\"formModel\"></formly-form>\n    <button #submitButton pButton type=\"submit\" class=\"hidden\" [disabled]=\"form.disabled\" [loading]=\"(submitLoading$ | async) ?? false\"></button>\n</form>\n<p-messages [value]=\"formMessages\" [enableService]=\"false\"></p-messages>\n"]}
|