@mediusinc/mng-commons 5.0.0-rc.1 → 5.0.0-rc.3
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/core/data-providers/base-data-provider.factory.d.ts +13 -0
- package/core/data-providers/base.data-provider.d.ts +2 -14
- package/core/descriptors/editor.descriptor.d.ts +1 -1
- package/core/descriptors/tableview.descriptor.d.ts +5 -5
- package/core/directives/component.directive.d.ts +2 -2
- package/core/index.d.ts +1 -0
- package/core/router/route-builder.d.ts +149 -26
- package/core/router/routes-builder.d.ts +28 -13
- package/core/security/permission.service.d.ts +1 -0
- package/core/services/commons-router.service.d.ts +3 -3
- package/core/services/commons.service.d.ts +31 -42
- package/core/services/tokens/module-config.token.d.ts +2 -2
- package/esm2022/core/components/notification/notification-wrapper.component.mjs +5 -5
- package/esm2022/core/components/pages/error/error.page.component.mjs +5 -5
- package/esm2022/core/components/pages/not-found/not-found.page.component.mjs +5 -5
- package/esm2022/core/data-providers/base-data-provider.factory.mjs +28 -0
- package/esm2022/core/data-providers/base.data-provider.mjs +1 -31
- package/esm2022/core/descriptors/editor.descriptor.mjs +1 -1
- package/esm2022/core/descriptors/tableview.descriptor.mjs +1 -1
- package/esm2022/core/directives/component.directive.mjs +12 -9
- package/esm2022/core/directives/dialog-keydown-handler.directive.mjs +3 -3
- package/esm2022/core/directives/template.directive.mjs +3 -3
- package/esm2022/core/index.mjs +2 -1
- package/esm2022/core/pipes/boolean.pipe.mjs +3 -3
- package/esm2022/core/pipes/class-map.pipe.mjs +3 -3
- package/esm2022/core/pipes/enum.pipe.mjs +3 -3
- package/esm2022/core/pipes/enumerate-async.pipe.mjs +3 -3
- package/esm2022/core/pipes/enumerate.pipe.mjs +3 -3
- package/esm2022/core/pipes/getter.pipe.mjs +3 -3
- package/esm2022/core/pipes/i18n-property.pipe.mjs +3 -3
- package/esm2022/core/pipes/json-path.pipe.mjs +3 -3
- package/esm2022/core/pipes/parametrize.pipe.mjs +3 -3
- package/esm2022/core/pipes/template.pipe.mjs +3 -3
- package/esm2022/core/router/route-builder.mjs +211 -84
- package/esm2022/core/router/routes-builder.mjs +41 -43
- package/esm2022/core/security/permission.service.mjs +7 -5
- package/esm2022/core/services/commons-init.service.mjs +5 -5
- package/esm2022/core/services/commons-router.service.mjs +18 -17
- package/esm2022/core/services/commons.service.mjs +112 -169
- package/esm2022/core/services/local-storage-config.service.mjs +3 -3
- package/esm2022/core/services/tokens/module-config.token.mjs +1 -1
- package/esm2022/filter/descriptors/filter-lookup.descriptor.mjs +4 -4
- package/esm2022/form/api/data-providers/lookup-data-provider.factory.mjs +31 -0
- package/esm2022/form/api/data-providers/lookup.data-provider.mjs +1 -31
- package/esm2022/form/api/index.mjs +2 -1
- package/esm2022/form/components/autocomplete/autocomplete.component.mjs +105 -102
- package/esm2022/form/components/date-range/date-range.component.mjs +3 -3
- package/esm2022/form/components/dropdown/dropdown.component.mjs +148 -90
- package/esm2022/form/directives/input-trim.directive.mjs +3 -3
- package/esm2022/model/data-providers/base-from-type-data-provider.factory.mjs +8 -0
- package/esm2022/model/descriptors/enum.descriptor.mjs +3 -6
- package/esm2022/model/descriptors/model.descriptor.mjs +22 -9
- package/esm2022/model/descriptors/type.descriptor.mjs +3 -9
- package/esm2022/model/index.mjs +3 -1
- package/esm2022/table/api/data-providers/table-data-provider.factory.mjs +33 -0
- package/esm2022/table/api/data-providers/table.data-provider.mjs +1 -31
- package/esm2022/table/api/descriptors/sort.descriptor.mjs +2 -2
- package/esm2022/table/api/descriptors/table-descriptor.factory.mjs +89 -0
- package/esm2022/table/api/descriptors/table.descriptor.mjs +4 -139
- package/esm2022/table/api/helpers/table-descriptor-helpers.mjs +97 -0
- package/esm2022/table/api/index.mjs +4 -1
- package/esm2022/table/components/column-filter-full/column-filter-full.component.mjs +8 -9
- package/esm2022/table/components/column-value/column-value.component.mjs +4 -4
- package/esm2022/table/components/table/table.component.mjs +7 -7
- package/esm2022/table/pipes/locale-default-row-class.pipe.mjs +5 -5
- package/esm2022/table/pipes/table-column-filter-class.pipe.mjs +3 -3
- package/esm2022/table/services/data-list.service.mjs +4 -4
- package/esm2022/tableview/action/components/action/action.component.mjs +142 -190
- package/esm2022/tableview/action/components/editor/action-editor.component.mjs +58 -68
- package/esm2022/tableview/action/components/editor/injector-context/action-editor-injector-context.component.mjs +133 -154
- package/esm2022/tableview/action/components/localization/data-language-dropdown.component.mjs +22 -40
- package/esm2022/tableview/action/components/route/action-route.component.mjs +21 -26
- package/esm2022/tableview/action/components/table/action-table.component.mjs +4 -4
- package/esm2022/tableview/action/models/execution/action-instance.model.mjs +1 -1
- package/esm2022/tableview/action/services/action-executor.service.mjs +10 -10
- package/esm2022/tableview/action/services/component-action-executor.service.mjs +3 -3
- package/esm2022/tableview/action/services/data-provider-executor.service.mjs +3 -3
- package/esm2022/tableview/action/services/navigation.service.mjs +6 -5
- package/esm2022/tableview/action/services/root-action-executor.service.mjs +3 -3
- package/esm2022/tableview/action/services/view-container.service.mjs +8 -24
- package/esm2022/tableview/api/action/descriptors/action-descriptor.factory.mjs +119 -0
- package/esm2022/tableview/api/action/descriptors/action-editor-descriptor.factory.mjs +77 -0
- package/esm2022/tableview/api/action/descriptors/action-editor.descriptor.mjs +28 -80
- package/esm2022/tableview/api/action/descriptors/action-link-descriptor.factory.mjs +45 -0
- package/esm2022/tableview/api/action/descriptors/action-link.descriptor.mjs +1 -32
- package/esm2022/tableview/api/action/descriptors/action.descriptor.mjs +3 -69
- package/esm2022/tableview/api/action/models/action-component.model.mjs +1 -1
- package/esm2022/tableview/api/action/models/execution/action-instance.model.mjs +1 -1
- package/esm2022/tableview/api/action/models/execution/view-container.model.mjs +1 -1
- package/esm2022/tableview/api/editor/data-providers/editor-data-provider.factory.mjs +33 -0
- package/esm2022/tableview/api/editor/data-providers/editor.data-provider.mjs +1 -31
- package/esm2022/tableview/api/editor/descriptors/editor-descriptor.factory.mjs +81 -0
- package/esm2022/tableview/api/editor/descriptors/editor.descriptor.mjs +24 -161
- package/esm2022/tableview/api/editor/descriptors/field-action.descriptor.mjs +1 -1
- package/esm2022/tableview/api/editor/descriptors/field-base.descriptor.mjs +13 -5
- package/esm2022/tableview/api/editor/descriptors/field-group.descriptor.mjs +3 -3
- package/esm2022/tableview/api/editor/descriptors/field-lookup.descriptor.mjs +4 -4
- package/esm2022/tableview/api/editor/descriptors/field-many.descriptor.mjs +3 -3
- package/esm2022/tableview/api/editor/descriptors/field-validation.descriptor.mjs +1 -1
- package/esm2022/tableview/api/editor/descriptors/field.descriptor.mjs +36 -7
- package/esm2022/tableview/api/editor/helpers/editor-descriptor-helpers.mjs +95 -0
- package/esm2022/tableview/api/editor/helpers/field-validators.mjs +17 -27
- package/esm2022/tableview/api/editor/models/editor-fields.model.mjs +1 -1
- package/esm2022/tableview/api/editor/models/field-action-context.model.mjs +1 -1
- package/esm2022/tableview/api/editor/models/field-validation.model.mjs +2 -0
- package/esm2022/tableview/api/editor/models/field.model.mjs +1 -1
- package/esm2022/tableview/api/editor/models/form-editor.event.mjs +1 -1
- package/esm2022/tableview/api/editor/models/form-editor.interface.mjs +1 -1
- package/esm2022/tableview/api/editor/models/formly-custom-field.model.mjs +3 -3
- package/esm2022/tableview/api/editor/models/formly-field.model.mjs +1 -1
- package/esm2022/tableview/api/index.mjs +11 -1
- package/esm2022/tableview/api/tableview/data-providers/tableview-data-provider.factory.mjs +47 -0
- package/esm2022/tableview/api/tableview/data-providers/tableview.data-provider.mjs +5 -46
- package/esm2022/tableview/api/tableview/descriptors/tableview-descriptor.factory.mjs +111 -0
- package/esm2022/tableview/api/tableview/descriptors/tableview.descriptor.mjs +26 -186
- package/esm2022/tableview/api/tableview/helpers/files-export.mjs +2 -2
- package/esm2022/tableview/api/tableview/helpers/tableview-create.mjs +5 -5
- package/esm2022/tableview/api/tableview/helpers/tableview-default-actions.mjs +53 -18
- package/esm2022/tableview/api/tableview/helpers/tableview-descriptor-helpers.mjs +110 -0
- package/esm2022/tableview/api/tableview/helpers/tableview-input-builder.mjs +2 -2
- package/esm2022/tableview/editor/components/editor/form-editor.component.mjs +163 -138
- package/esm2022/tableview/editor/components/formly/fields/formly-field-action/formly-field-action.component.mjs +9 -5
- package/esm2022/tableview/editor/components/formly/fields/formly-field-autocomplete/formly-field-autocomplete.component.mjs +13 -16
- package/esm2022/tableview/editor/components/formly/fields/formly-field-custom/formly-field-custom.component.mjs +3 -3
- package/esm2022/tableview/editor/components/formly/fields/formly-field-datepicker/formly-field-datepicker.component.mjs +103 -0
- package/esm2022/tableview/editor/components/formly/fields/formly-field-dropdown/formly-field-dropdown.component.mjs +12 -16
- package/esm2022/tableview/editor/components/formly/fields/formly-field-fieldset/formly-field-fieldset.component.mjs +3 -3
- package/esm2022/tableview/editor/components/formly/fields/formly-field-input/formly-field-input.component.mjs +36 -53
- package/esm2022/tableview/editor/components/formly/fields/formly-field-label/formly-field-label.component.mjs +3 -3
- package/esm2022/tableview/editor/components/formly/fields/formly-field-lookup-dialog/formly-field-lookup-dialog.component.mjs +20 -24
- package/esm2022/tableview/editor/components/formly/fields/formly-field-table-dialog-form/formly-field-table-dialog-form.component.mjs +24 -28
- package/esm2022/tableview/editor/components/formly/fields/formly-field-table-dialog-multiselect/formly-field-table-dialog-multiselect.component.mjs +30 -31
- package/esm2022/tableview/editor/components/formly/fields/formly-field-tabs/formly-field-tabs.component.mjs +3 -3
- package/esm2022/tableview/editor/components/formly/wrappers/formly-field-no-label-wrapper/formly-field-no-label-wrapper.component.mjs +3 -3
- package/esm2022/tableview/editor/components/formly/wrappers/formly-field-wrapper/formly-field-wrapper.component.mjs +3 -3
- package/esm2022/tableview/editor/helpers/editor-formly.mjs +85 -56
- package/esm2022/tableview/editor/helpers/formly-config.mjs +5 -3
- package/esm2022/tableview/editor/models/formly-config.model.mjs +1 -1
- package/esm2022/tableview/editor/services/form-editor.service.mjs +96 -0
- package/esm2022/tableview/index.mjs +2 -1
- package/esm2022/tableview/tableview/components/route/tableview-route.component.mjs +10 -10
- package/esm2022/tableview/tableview/components/tableview/tableview.component.mjs +26 -43
- package/esm2022/tableview/tableview/router/tableview-route-builder.mjs +17 -43
- package/fesm2022/mediusinc-mng-commons-core.mjs +460 -390
- package/fesm2022/mediusinc-mng-commons-core.mjs.map +1 -1
- package/fesm2022/mediusinc-mng-commons-filter.mjs +3 -3
- package/fesm2022/mediusinc-mng-commons-filter.mjs.map +1 -1
- package/fesm2022/mediusinc-mng-commons-form-api.mjs +18 -18
- package/fesm2022/mediusinc-mng-commons-form-api.mjs.map +1 -1
- package/fesm2022/mediusinc-mng-commons-form.mjs +257 -195
- package/fesm2022/mediusinc-mng-commons-form.mjs.map +1 -1
- package/fesm2022/mediusinc-mng-commons-model.mjs +43 -33
- package/fesm2022/mediusinc-mng-commons-model.mjs.map +1 -1
- package/fesm2022/mediusinc-mng-commons-table-api.mjs +192 -146
- package/fesm2022/mediusinc-mng-commons-table-api.mjs.map +1 -1
- package/fesm2022/mediusinc-mng-commons-table.mjs +26 -27
- package/fesm2022/mediusinc-mng-commons-table.mjs.map +1 -1
- package/fesm2022/mediusinc-mng-commons-tableview-api.mjs +906 -665
- package/fesm2022/mediusinc-mng-commons-tableview-api.mjs.map +1 -1
- package/fesm2022/mediusinc-mng-commons-tableview.mjs +1015 -960
- package/fesm2022/mediusinc-mng-commons-tableview.mjs.map +1 -1
- package/form/api/data-providers/lookup-data-provider.factory.d.ts +18 -0
- package/form/api/data-providers/lookup.data-provider.d.ts +2 -14
- package/form/api/index.d.ts +1 -0
- package/form/components/autocomplete/autocomplete.component.d.ts +33 -24
- package/form/components/dropdown/dropdown.component.d.ts +38 -25
- package/model/data-providers/base-from-type-data-provider.factory.d.ts +8 -0
- package/model/descriptors/enum.descriptor.d.ts +1 -2
- package/model/descriptors/model.descriptor.d.ts +11 -4
- package/model/descriptors/type.descriptor.d.ts +2 -4
- package/model/index.d.ts +1 -0
- package/package.json +1 -1
- package/table/api/data-providers/table-data-provider.factory.d.ts +18 -0
- package/table/api/data-providers/table.data-provider.d.ts +2 -14
- package/table/api/descriptors/table-descriptor.factory.d.ts +44 -0
- package/table/api/descriptors/table.descriptor.d.ts +4 -65
- package/table/api/helpers/table-descriptor-helpers.d.ts +44 -0
- package/table/api/index.d.ts +3 -0
- package/table/components/column-filter-full/column-filter-full.component.d.ts +5 -4
- package/table/components/table/table.component.d.ts +11 -11
- package/table/services/data-list.service.d.ts +9 -10
- package/tableview/action/components/action/action.component.d.ts +37 -44
- package/tableview/action/components/editor/action-editor.component.d.ts +20 -18
- package/tableview/action/components/editor/injector-context/action-editor-injector-context.component.d.ts +24 -26
- package/tableview/action/components/localization/data-language-dropdown.component.d.ts +11 -14
- package/tableview/action/components/route/action-route.component.d.ts +7 -12
- package/tableview/action/components/table/action-table.component.d.ts +3 -3
- package/tableview/action/models/execution/action-instance.model.d.ts +2 -1
- package/tableview/action/services/view-container.service.d.ts +3 -9
- package/tableview/api/action/descriptors/action-descriptor.factory.d.ts +36 -0
- package/tableview/api/action/descriptors/action-editor-descriptor.factory.d.ts +31 -0
- package/tableview/api/action/descriptors/action-editor.descriptor.d.ts +25 -37
- package/tableview/api/action/descriptors/action-link-descriptor.factory.d.ts +15 -0
- package/tableview/api/action/descriptors/action-link.descriptor.d.ts +1 -9
- package/tableview/api/action/descriptors/action.descriptor.d.ts +4 -27
- package/tableview/api/action/models/action-component.model.d.ts +8 -8
- package/tableview/api/action/models/execution/action-instance.model.d.ts +2 -1
- package/tableview/api/action/models/execution/view-container.model.d.ts +4 -3
- package/tableview/api/editor/data-providers/editor-data-provider.factory.d.ts +18 -0
- package/tableview/api/editor/data-providers/editor.data-provider.d.ts +2 -14
- package/tableview/api/editor/descriptors/editor-descriptor.factory.d.ts +44 -0
- package/tableview/api/editor/descriptors/editor.descriptor.d.ts +44 -105
- package/tableview/api/editor/descriptors/field-action.descriptor.d.ts +3 -3
- package/tableview/api/editor/descriptors/field-base.descriptor.d.ts +35 -33
- package/tableview/api/editor/descriptors/field-group.descriptor.d.ts +8 -7
- package/tableview/api/editor/descriptors/field-lookup.descriptor.d.ts +2 -2
- package/tableview/api/editor/descriptors/field-many.descriptor.d.ts +8 -8
- package/tableview/api/editor/descriptors/field-validation.descriptor.d.ts +10 -13
- package/tableview/api/editor/descriptors/field.descriptor.d.ts +16 -1
- package/tableview/api/editor/helpers/editor-descriptor-helpers.d.ts +43 -0
- package/tableview/api/editor/helpers/field-validators.d.ts +7 -3
- package/tableview/api/editor/models/editor-fields.model.d.ts +25 -21
- package/tableview/api/editor/models/field-action-context.model.d.ts +10 -8
- package/tableview/api/editor/models/field-validation.model.d.ts +26 -0
- package/tableview/api/editor/models/field.model.d.ts +0 -10
- package/tableview/api/editor/models/form-editor.event.d.ts +26 -16
- package/tableview/api/editor/models/form-editor.interface.d.ts +38 -8
- package/tableview/api/editor/models/formly-custom-field.model.d.ts +1 -1
- package/tableview/api/editor/models/formly-field.model.d.ts +9 -7
- package/tableview/api/index.d.ts +10 -0
- package/tableview/api/tableview/data-providers/tableview-data-provider.factory.d.ts +25 -0
- package/tableview/api/tableview/data-providers/tableview.data-provider.d.ts +3 -20
- package/tableview/api/tableview/descriptors/tableview-descriptor.factory.d.ts +49 -0
- package/tableview/api/tableview/descriptors/tableview.descriptor.d.ts +41 -102
- package/tableview/api/tableview/helpers/tableview-create.d.ts +2 -2
- package/tableview/api/tableview/helpers/tableview-default-actions.d.ts +4 -2
- package/tableview/api/tableview/helpers/tableview-descriptor-helpers.d.ts +42 -0
- package/tableview/api/tableview/helpers/tableview-input-builder.d.ts +1 -1
- package/tableview/editor/components/editor/form-editor.component.d.ts +54 -36
- package/tableview/editor/components/formly/fields/formly-field-action/formly-field-action.component.d.ts +5 -3
- package/tableview/editor/components/formly/fields/formly-field-autocomplete/formly-field-autocomplete.component.d.ts +1 -0
- package/tableview/editor/components/formly/fields/formly-field-datepicker/formly-field-datepicker.component.d.ts +22 -0
- package/tableview/editor/components/formly/fields/formly-field-dropdown/formly-field-dropdown.component.d.ts +1 -1
- package/tableview/editor/components/formly/fields/formly-field-input/formly-field-input.component.d.ts +5 -7
- package/tableview/editor/components/formly/fields/formly-field-lookup-dialog/formly-field-lookup-dialog.component.d.ts +1 -1
- package/tableview/editor/components/formly/fields/formly-field-table-dialog-form/formly-field-table-dialog-form.component.d.ts +3 -4
- package/tableview/editor/components/formly/fields/formly-field-table-dialog-multiselect/formly-field-table-dialog-multiselect.component.d.ts +3 -5
- package/tableview/editor/helpers/editor-formly.d.ts +11 -10
- package/tableview/editor/models/formly-config.model.d.ts +1 -1
- package/tableview/editor/services/form-editor.service.d.ts +39 -0
- package/tableview/index.d.ts +1 -0
- package/tableview/tableview/components/route/tableview-route.component.d.ts +2 -2
- package/tableview/tableview/components/tableview/tableview.component.d.ts +11 -10
- package/tableview/tableview/router/tableview-route-builder.d.ts +7 -13
- package/version-info.json +11 -0
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { AsyncPipe } from '@angular/common';
|
|
2
|
-
import { ChangeDetectionStrategy, Component,
|
|
2
|
+
import { ChangeDetectionStrategy, Component, DestroyRef, Optional, booleanAttribute, computed, effect, inject, input, output, signal, viewChild } from '@angular/core';
|
|
3
|
+
import { toSignal } from '@angular/core/rxjs-interop';
|
|
3
4
|
import { ActivatedRoute } from '@angular/router';
|
|
4
5
|
import { TranslateService } from '@ngx-translate/core';
|
|
5
6
|
import { ButtonModule } from 'primeng/button';
|
|
@@ -7,9 +8,9 @@ import { Menu, MenuModule } from 'primeng/menu';
|
|
|
7
8
|
import { RippleModule } from 'primeng/ripple';
|
|
8
9
|
import { SplitButtonModule } from 'primeng/splitbutton';
|
|
9
10
|
import { TooltipModule } from 'primeng/tooltip';
|
|
10
|
-
import {
|
|
11
|
-
import { ComponentDirective, ParametrizePipe, PermissionService, Permissions,
|
|
12
|
-
import {
|
|
11
|
+
import { combineLatest } from 'rxjs';
|
|
12
|
+
import { ComponentDirective, ParametrizePipe, PermissionService, Permissions, toObservable } from '@mediusinc/mng-commons/core';
|
|
13
|
+
import { ActionLinkDescriptorInst, ActionTypeEnum } from '@mediusinc/mng-commons/tableview/api';
|
|
13
14
|
import { getI18nForActionAsync } from '../../helpers/i18n';
|
|
14
15
|
import { ActionInstanceStateEnum } from '../../models/execution/action-instance-state.model';
|
|
15
16
|
import { ActionExecutorService } from '../../services/action-executor.service';
|
|
@@ -32,68 +33,51 @@ export class ActionComponent {
|
|
|
32
33
|
this.authorization = authorization;
|
|
33
34
|
this.actionExecutor = actionExecutor;
|
|
34
35
|
this.viewContainer = viewContainer;
|
|
35
|
-
this.
|
|
36
|
-
|
|
37
|
-
this.
|
|
38
|
-
this.
|
|
39
|
-
this.
|
|
40
|
-
this.
|
|
41
|
-
this.
|
|
42
|
-
this
|
|
43
|
-
this.
|
|
44
|
-
this
|
|
45
|
-
this.
|
|
46
|
-
this
|
|
47
|
-
this.
|
|
48
|
-
this
|
|
49
|
-
this.
|
|
50
|
-
this
|
|
51
|
-
this.
|
|
52
|
-
this
|
|
53
|
-
this.
|
|
54
|
-
this.
|
|
55
|
-
this.
|
|
56
|
-
this.
|
|
57
|
-
this.
|
|
58
|
-
this.
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
this.
|
|
63
|
-
this.
|
|
64
|
-
this.
|
|
65
|
-
this.
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
if (this.action.tableviewCategory && routeData.tableviewPermissions) {
|
|
74
|
-
if (routeData.tableviewPermissions[this.action.tableviewCategory]) {
|
|
75
|
-
this.routePermissions = routeData.tableviewPermissions[this.action.tableviewCategory];
|
|
36
|
+
this.destroyRef = inject(DestroyRef);
|
|
37
|
+
// metadata and editor mode input
|
|
38
|
+
this.action = input.required();
|
|
39
|
+
this.item = input();
|
|
40
|
+
this.itemId = input();
|
|
41
|
+
this.actionData = input();
|
|
42
|
+
this.dataListParams = input();
|
|
43
|
+
this.dataProvider = input();
|
|
44
|
+
this.hostComponent = input();
|
|
45
|
+
this.routeInit = input(undefined, { alias: 'route' });
|
|
46
|
+
this.inputDisabled = input(false, { alias: 'disabled', transform: booleanAttribute });
|
|
47
|
+
this.inputLoading = input(false, { alias: 'loading', transform: booleanAttribute });
|
|
48
|
+
this.selectedItems = input([]);
|
|
49
|
+
this.finish = output();
|
|
50
|
+
this.subactionsMenu = viewChild(Menu);
|
|
51
|
+
this.hostClass = computed(() => this.action().className ?? 'mng-action-button');
|
|
52
|
+
this.isHostHidden = computed(() => !this.isVisible() || !this.isPermitted());
|
|
53
|
+
this.loading = signal(false);
|
|
54
|
+
this.isVisible = signal(true);
|
|
55
|
+
this.isPermitted = signal(true);
|
|
56
|
+
this.isEnabled = signal(true);
|
|
57
|
+
this.label = signal('');
|
|
58
|
+
this.tooltip = signal('');
|
|
59
|
+
this.actionLink = computed(() => {
|
|
60
|
+
const action = this.action();
|
|
61
|
+
return action instanceof ActionLinkDescriptorInst ? action : undefined;
|
|
62
|
+
});
|
|
63
|
+
this.hasNoTitle = computed(() => this.action().button.label === null);
|
|
64
|
+
this.route = computed(() => this.routeInit() ?? this.routeService);
|
|
65
|
+
this.routeData = toSignal(this.route().data);
|
|
66
|
+
this.routePermissions = computed(() => {
|
|
67
|
+
const routeData = this.routeData();
|
|
68
|
+
const action = this.action();
|
|
69
|
+
if (action.tableviewCategory && routeData && routeData['tableviewPermissions']) {
|
|
70
|
+
const tableviewPermissions = routeData['tableviewPermissions'];
|
|
71
|
+
if (tableviewPermissions[action.tableviewCategory]) {
|
|
72
|
+
return tableviewPermissions[action.tableviewCategory];
|
|
73
|
+
}
|
|
76
74
|
}
|
|
77
|
-
|
|
78
|
-
this.processSubscriptions();
|
|
79
|
-
if (this.action.className) {
|
|
80
|
-
this.hostClass = this.action.className;
|
|
81
|
-
}
|
|
82
|
-
const hostVisibilitySubscription = combineLatest([this.$isVisible, this.$isPermitted]).subscribe(([isVisible, isPermitted]) => {
|
|
83
|
-
this.isHostHidden = !isVisible || !isPermitted;
|
|
75
|
+
return undefined;
|
|
84
76
|
});
|
|
85
|
-
this.
|
|
86
|
-
this.
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
}
|
|
90
|
-
ngOnChanges(changes) {
|
|
91
|
-
if (!(changes['item']?.firstChange ?? true) ||
|
|
92
|
-
!(changes['itemId']?.firstChange ?? true) ||
|
|
93
|
-
!(changes['actionData']?.firstChange ?? true) ||
|
|
94
|
-
(this.action.hasItemsSelection && !(changes['selectedItems']?.firstChange ?? true))) {
|
|
95
|
-
this.processSubscriptions();
|
|
96
|
-
}
|
|
77
|
+
this.buttonClass = computed(() => this.action().button.styleClass.build(this.hasNoTitle()));
|
|
78
|
+
this.subactions = signal([]);
|
|
79
|
+
this.subactionSubscriptions = [];
|
|
80
|
+
effect(() => this.processSubscriptions(), { allowSignalWrites: true });
|
|
97
81
|
}
|
|
98
82
|
ngOnDestroy() {
|
|
99
83
|
this.actionExecutor.onActionDestroy(this.instance);
|
|
@@ -102,24 +86,27 @@ export class ActionComponent {
|
|
|
102
86
|
this.isEnabledSubscription?.unsubscribe();
|
|
103
87
|
this.labelSubscription?.unsubscribe();
|
|
104
88
|
this.tooltipSubscription?.unsubscribe();
|
|
105
|
-
this.
|
|
89
|
+
this.resultSubscription?.unsubscribe();
|
|
90
|
+
this.errorSubscription?.unsubscribe();
|
|
91
|
+
this.stateSubscription?.unsubscribe();
|
|
92
|
+
this.cmpInstSubscription?.unsubscribe();
|
|
106
93
|
this.subactionSubscriptions.forEach(s => s.unsubscribe());
|
|
107
94
|
}
|
|
108
95
|
triggerAction(action, parameters, event) {
|
|
109
96
|
if (action.subactionsAsMenu) {
|
|
110
|
-
this.subactionsMenu?.toggle(event ?? new Event('trigger'));
|
|
97
|
+
this.subactionsMenu()?.toggle(event ?? new Event('trigger'));
|
|
111
98
|
return;
|
|
112
99
|
}
|
|
113
|
-
const actionData = this.actionData ? this.actionData : {};
|
|
100
|
+
const actionData = this.actionData() ? this.actionData() : {};
|
|
114
101
|
parameters ??= {
|
|
115
|
-
itemId: this.itemId,
|
|
116
|
-
item: this.item,
|
|
102
|
+
itemId: this.itemId(),
|
|
103
|
+
item: this.item(),
|
|
117
104
|
actionData: actionData,
|
|
118
|
-
dataListParams: this.dataListParams,
|
|
119
|
-
route: this.route,
|
|
105
|
+
dataListParams: this.dataListParams(),
|
|
106
|
+
route: this.route(),
|
|
120
107
|
sourceComponent: this,
|
|
121
|
-
hostComponent: this.hostComponent,
|
|
122
|
-
selectedItems: this.selectedItems
|
|
108
|
+
hostComponent: this.hostComponent(),
|
|
109
|
+
selectedItems: this.selectedItems()
|
|
123
110
|
};
|
|
124
111
|
const instance = this.actionExecutor.triggerAction(action, parameters);
|
|
125
112
|
this.instance = instance;
|
|
@@ -129,79 +116,128 @@ export class ActionComponent {
|
|
|
129
116
|
// it is in another component jurisdiction to handle contexts
|
|
130
117
|
return;
|
|
131
118
|
}
|
|
132
|
-
this.
|
|
119
|
+
this.resultSubscription?.unsubscribe();
|
|
120
|
+
this.resultSubscription = instance.result$.subscribe({
|
|
133
121
|
next: () => {
|
|
134
|
-
this.
|
|
122
|
+
this.finish.emit(instance);
|
|
135
123
|
if (action.hasItemsSelection) {
|
|
136
124
|
this.viewContainer?.reloadTable({ data: { event: event } });
|
|
137
125
|
}
|
|
138
126
|
}
|
|
139
|
-
})
|
|
140
|
-
this.
|
|
127
|
+
});
|
|
128
|
+
this.errorSubscription?.unsubscribe();
|
|
129
|
+
this.errorSubscription = instance.error$.subscribe({
|
|
141
130
|
next: () => {
|
|
142
|
-
this.
|
|
131
|
+
this.finish.emit(instance);
|
|
143
132
|
}
|
|
144
|
-
})
|
|
145
|
-
this.
|
|
133
|
+
});
|
|
134
|
+
this.stateSubscription?.unsubscribe();
|
|
135
|
+
this.stateSubscription = this.instance.state$.subscribe(s => {
|
|
146
136
|
switch (s) {
|
|
147
137
|
case ActionInstanceStateEnum.RunStart:
|
|
148
|
-
this.
|
|
138
|
+
this.loading.set(true);
|
|
149
139
|
break;
|
|
150
140
|
case ActionInstanceStateEnum.RunEnd:
|
|
151
141
|
case ActionInstanceStateEnum.RunError:
|
|
152
|
-
this.
|
|
142
|
+
this.loading.set(false);
|
|
153
143
|
break;
|
|
154
144
|
case ActionInstanceStateEnum.NextActionStart:
|
|
155
145
|
if (this.instance?.nextActionInstance?.action.type === ActionTypeEnum.Direct) {
|
|
156
|
-
this.
|
|
146
|
+
this.loading.set(true);
|
|
157
147
|
}
|
|
158
148
|
break;
|
|
159
149
|
case ActionInstanceStateEnum.NextActionEnd:
|
|
160
150
|
if (this.instance?.nextActionInstance?.action.type === ActionTypeEnum.Direct) {
|
|
161
|
-
this.
|
|
151
|
+
this.loading.set(false);
|
|
162
152
|
}
|
|
163
153
|
break;
|
|
164
154
|
case ActionInstanceStateEnum.ErrorActionStart:
|
|
165
155
|
if (this.instance?.errorActionInstance?.action.type === ActionTypeEnum.Direct) {
|
|
166
|
-
this.
|
|
156
|
+
this.loading.set(true);
|
|
167
157
|
}
|
|
168
158
|
break;
|
|
169
159
|
case ActionInstanceStateEnum.ErrorActionEnd:
|
|
170
160
|
if (this.instance?.errorActionInstance?.action.type === ActionTypeEnum.Direct) {
|
|
171
|
-
this.
|
|
161
|
+
this.loading.set(false);
|
|
172
162
|
}
|
|
173
163
|
break;
|
|
174
164
|
}
|
|
175
|
-
})
|
|
165
|
+
});
|
|
176
166
|
this.actionExecutor.run(context);
|
|
177
167
|
}
|
|
178
168
|
onCustomActionCmpInst(instance) {
|
|
179
|
-
|
|
180
|
-
this.
|
|
169
|
+
this.cmpInstSubscription?.unsubscribe();
|
|
170
|
+
this.cmpInstSubscription = instance.trigger.subscribe(params => this.triggerAction(this.action(), params));
|
|
171
|
+
}
|
|
172
|
+
processSubscriptions() {
|
|
173
|
+
const parameters = {
|
|
174
|
+
itemId: this.itemId(),
|
|
175
|
+
item: this.item(),
|
|
176
|
+
actionData: this.actionData(),
|
|
177
|
+
sourceComponent: this
|
|
178
|
+
};
|
|
179
|
+
const action = this.action();
|
|
180
|
+
if (action.hasItemsSelection) {
|
|
181
|
+
parameters.selectedItems = this.selectedItems();
|
|
182
|
+
}
|
|
183
|
+
const context = this.actionExecutor.prepareActionContextValidation(action, parameters, this.dataProvider());
|
|
184
|
+
if (typeof action.isVisibleFunction === 'function') {
|
|
185
|
+
this.isVisibleSubscription?.unsubscribe();
|
|
186
|
+
this.isVisibleSubscription = toObservable(action.isVisibleFunction(context)).subscribe({
|
|
187
|
+
next: res => this.isVisible.set(res)
|
|
188
|
+
});
|
|
189
|
+
}
|
|
190
|
+
const routePermissions = this.routePermissions();
|
|
191
|
+
if (typeof action.permissions !== 'undefined' || typeof routePermissions !== 'undefined') {
|
|
192
|
+
this.isPermittedSubscription?.unsubscribe();
|
|
193
|
+
const permissions = action.permissions && routePermissions ? Permissions.All.of(routePermissions, action.permissions) : routePermissions ?? action.permissions;
|
|
194
|
+
this.isVisibleSubscription = this.authorization.isPermitted(permissions, this.route().snapshot, context).subscribe({
|
|
195
|
+
next: res => this.isPermitted.set(res)
|
|
196
|
+
});
|
|
197
|
+
}
|
|
198
|
+
if (typeof action.isEnabledFunction === 'function') {
|
|
199
|
+
this.isEnabledSubscription?.unsubscribe();
|
|
200
|
+
this.isEnabledSubscription = toObservable(action.isEnabledFunction(context)).subscribe({
|
|
201
|
+
next: res => this.isEnabled.set(res)
|
|
202
|
+
});
|
|
203
|
+
}
|
|
204
|
+
if (!this.hasNoTitle()) {
|
|
205
|
+
this.labelSubscription?.unsubscribe();
|
|
206
|
+
this.labelSubscription = getI18nForActionAsync(this.translate, action, 'title', action.button.label ?? undefined, this.item()).subscribe({
|
|
207
|
+
next: i18n => this.label.set(i18n ?? '')
|
|
208
|
+
});
|
|
209
|
+
}
|
|
210
|
+
this.tooltipSubscription?.unsubscribe();
|
|
211
|
+
if (action.button.tooltip) {
|
|
212
|
+
this.tooltipSubscription = getI18nForActionAsync(this.translate, action, 'tooltip', action.button.tooltip, this.item(), undefined, undefined).subscribe({
|
|
213
|
+
next: i18n => this.tooltip.set(i18n ?? '')
|
|
214
|
+
});
|
|
215
|
+
}
|
|
216
|
+
this.subactions.set(this.processSubactions());
|
|
181
217
|
}
|
|
182
218
|
processSubactions() {
|
|
183
219
|
this.subactionSubscriptions.forEach(s => s.unsubscribe());
|
|
184
220
|
this.subactionSubscriptions = [];
|
|
185
221
|
const menuItems = [];
|
|
186
|
-
for (const subaction of this.action.subactions) {
|
|
222
|
+
for (const subaction of this.action().subactions) {
|
|
187
223
|
const menuItem = {};
|
|
188
224
|
menuItem.icon = subaction.button.icon ?? undefined;
|
|
189
|
-
this.subactionSubscriptions.push(getI18nForActionAsync(this.translate, subaction, 'title', subaction.button.label ?? undefined, this.item).subscribe({
|
|
225
|
+
this.subactionSubscriptions.push(getI18nForActionAsync(this.translate, subaction, 'title', subaction.button.label ?? undefined, this.item()).subscribe({
|
|
190
226
|
next: res => (menuItem.label = res)
|
|
191
227
|
}));
|
|
192
|
-
this.subactionSubscriptions.push(getI18nForActionAsync(this.translate, subaction, 'tooltip', this.action.button.tooltip, this.item).subscribe({
|
|
228
|
+
this.subactionSubscriptions.push(getI18nForActionAsync(this.translate, subaction, 'tooltip', this.action().button.tooltip, this.item()).subscribe({
|
|
193
229
|
next: res => (menuItem.tooltip = res)
|
|
194
230
|
}));
|
|
195
231
|
const parameters = {
|
|
196
|
-
itemId: this.itemId,
|
|
197
|
-
item: this.item,
|
|
198
|
-
actionData: this.actionData,
|
|
232
|
+
itemId: this.itemId(),
|
|
233
|
+
item: this.item(),
|
|
234
|
+
actionData: this.actionData(),
|
|
199
235
|
sourceComponent: this
|
|
200
236
|
};
|
|
201
237
|
if (subaction.hasItemsSelection) {
|
|
202
|
-
parameters.selectedItems = this.selectedItems;
|
|
238
|
+
parameters.selectedItems = this.selectedItems();
|
|
203
239
|
}
|
|
204
|
-
const context = this.actionExecutor.prepareActionContextValidation(subaction, parameters, this.dataProvider);
|
|
240
|
+
const context = this.actionExecutor.prepareActionContextValidation(subaction, parameters, this.dataProvider());
|
|
205
241
|
if (typeof subaction.isEnabledFunction === 'function') {
|
|
206
242
|
this.subactionSubscriptions.push(toObservable(subaction.isEnabledFunction(context)).subscribe({
|
|
207
243
|
next: res => (menuItem.disabled = !res)
|
|
@@ -212,12 +248,12 @@ export class ActionComponent {
|
|
|
212
248
|
visibilityObservables.push(toObservable(subaction.isVisibleFunction(context)));
|
|
213
249
|
}
|
|
214
250
|
if (typeof subaction.permissions !== 'undefined') {
|
|
215
|
-
visibilityObservables.push(this.authorization.isPermitted(subaction.permissions, this.route.snapshot, context));
|
|
251
|
+
visibilityObservables.push(this.authorization.isPermitted(subaction.permissions, this.route().snapshot, context));
|
|
216
252
|
}
|
|
217
|
-
const routeData = this.route.snapshot.data;
|
|
253
|
+
const routeData = this.route().snapshot.data;
|
|
218
254
|
if (subaction.tableviewCategory && routeData.tableviewPermissions && routeData.tableviewPermissions[subaction.tableviewCategory]) {
|
|
219
255
|
const routePermissions = routeData.tableviewPermissions[subaction.tableviewCategory];
|
|
220
|
-
visibilityObservables.push(this.authorization.isPermitted(routePermissions, this.route.snapshot, context));
|
|
256
|
+
visibilityObservables.push(this.authorization.isPermitted(routePermissions, this.route().snapshot, context));
|
|
221
257
|
}
|
|
222
258
|
this.subactionSubscriptions.push(combineLatest(visibilityObservables).subscribe(visibilities => {
|
|
223
259
|
menuItem.visible = visibilities.every(value => value);
|
|
@@ -227,97 +263,13 @@ export class ActionComponent {
|
|
|
227
263
|
}
|
|
228
264
|
return menuItems;
|
|
229
265
|
}
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
itemId: this.itemId,
|
|
233
|
-
item: this.item,
|
|
234
|
-
actionData: this.actionData,
|
|
235
|
-
sourceComponent: this
|
|
236
|
-
};
|
|
237
|
-
if (this.action.hasItemsSelection) {
|
|
238
|
-
parameters.selectedItems = this.selectedItems;
|
|
239
|
-
}
|
|
240
|
-
const context = this.actionExecutor.prepareActionContextValidation(this.action, parameters, this.dataProvider);
|
|
241
|
-
if (typeof this.action.isVisibleFunction === 'function') {
|
|
242
|
-
this.isVisibleSubscription?.unsubscribe();
|
|
243
|
-
this.isVisibleSubscription = toObservable(this.action.isVisibleFunction(context)).subscribe({
|
|
244
|
-
next: res => this.isVisibleSubject.next(res)
|
|
245
|
-
});
|
|
246
|
-
}
|
|
247
|
-
if (typeof this.action.permissions !== 'undefined' || typeof this.routePermissions !== 'undefined') {
|
|
248
|
-
this.isPermittedSubscription?.unsubscribe();
|
|
249
|
-
const permissions = this.action.permissions && this.routePermissions
|
|
250
|
-
? Permissions.All.of(this.routePermissions, this.action.permissions)
|
|
251
|
-
: this.routePermissions ?? this.action.permissions;
|
|
252
|
-
this.isVisibleSubscription = this.authorization.isPermitted(permissions, this.route.snapshot, context).subscribe({
|
|
253
|
-
next: res => this.isPermittedSubject.next(res)
|
|
254
|
-
});
|
|
255
|
-
}
|
|
256
|
-
if (typeof this.action.isEnabledFunction === 'function') {
|
|
257
|
-
this.isEnabledSubscription?.unsubscribe();
|
|
258
|
-
this.isEnabledSubscription = toObservable(this.action.isEnabledFunction(context)).subscribe({
|
|
259
|
-
next: res => this.isEnabledSubject.next(res)
|
|
260
|
-
});
|
|
261
|
-
}
|
|
262
|
-
if (!this.hasNoTitle) {
|
|
263
|
-
this.labelSubscription?.unsubscribe();
|
|
264
|
-
this.labelSubscription = getI18nForActionAsync(this.translate, this.action, 'title', this.action.button.label ?? undefined, this.item).subscribe({
|
|
265
|
-
next: i18n => this.labelSubject.next(i18n)
|
|
266
|
-
});
|
|
267
|
-
}
|
|
268
|
-
this.tooltipSubscription?.unsubscribe();
|
|
269
|
-
if (this.action.button.tooltip) {
|
|
270
|
-
this.tooltipSubscription = getI18nForActionAsync(this.translate, this.action, 'tooltip', this.action.button.tooltip, this.item, undefined, undefined).subscribe({
|
|
271
|
-
next: i18n => this.tooltipSubject.next(i18n)
|
|
272
|
-
});
|
|
273
|
-
}
|
|
274
|
-
this.subactions = this.processSubactions();
|
|
275
|
-
}
|
|
276
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.2", ngImport: i0, type: ActionComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.TranslateService }, { token: i3.PermissionService }, { token: i4.ActionExecutorService }, { token: i5.ViewContainer, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
277
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.2", type: ActionComponent, isStandalone: true, selector: "mng-action", inputs: { action: "action", item: "item", itemId: "itemId", actionData: "actionData", dataListParams: "dataListParams", dataProvider: "dataProvider", hostComponent: "hostComponent", routeInit: ["route", "routeInit"], inputDisabled: ["disabled", "inputDisabled", boolean$Attribute], inputLoading: ["loading", "inputLoading", boolean$Attribute], selectedItems: "selectedItems" }, outputs: { finishEventEmitter: "finish" }, host: { properties: { "class": "this.hostClass", "class.m-0": "this.isHostHidden" } }, providers: [provideActionExecutor()], viewQueries: [{ propertyName: "subactionsMenu", first: true, predicate: ["subactionsMenu"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "@if (($isVisible | async) && ($isPermitted | async)) {\n @if (actionLink && actionLink.url !== '') {\n <a\n pButton\n pRipple\n [label]=\"($label | async) ?? ''\"\n [icon]=\"$any(action.button.icon)\"\n [iconPos]=\"action.button.iconPosition\"\n [href]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false) ? null : (actionLink.url | mngParametrize: itemId : item : actionData)\"\n [target]=\"actionLink.target\"\n [class.disabled]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false)\"\n [pTooltip]=\"($tooltip | async) ?? undefined\"\n [tooltipPosition]=\"action.button.tooltipPosition ?? undefined\"\n [class]=\"buttonClass\"></a>\n } @else if (actionLink) {\n <a\n pButton\n pRipple\n [icon]=\"$any(action.button.icon)\"\n [iconPos]=\"action.button.iconPosition\"\n [label]=\"($label | async) ?? ''\"\n [target]=\"actionLink.target\"\n [replaceUrl]=\"actionLink.replaceUrl\"\n [routerLink]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false) ? null : (actionLink.pathSegments | mngParametrize: itemId : item : actionData)\"\n [relativeTo]=\"route\"\n [queryParams]=\"actionLink.queryParams | mngParametrize: itemId : item : actionData\"\n [queryParamsHandling]=\"actionLink.queryParamsHandling\"\n [class.disabled]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false)\"\n [pTooltip]=\"($tooltip | async) ?? undefined\"\n [tooltipPosition]=\"action.button.tooltipPosition ?? undefined\"\n [class]=\"buttonClass\"></a>\n } @else if (action.component || action.componentFromDi) {\n <ng-container\n [mngComponent]=\"action.component\"\n [injectionToken]=\"action.componentFromDi\"\n [inputs]=\"{\n action: action,\n item: item,\n itemId: itemId,\n actionData: actionData,\n enabled: $isEnabled,\n loading: $loading\n }\"\n (instanceCreated)=\"onCustomActionCmpInst($event)\">\n </ng-container>\n } @else if (action.subactions.length > 0 && !action.subactionsAsMenu) {\n <p-splitButton\n [icon]=\"action.button.icon ?? undefined\"\n [iconPos]=\"action.button.iconPosition\"\n [label]=\"($label | async) ?? ''\"\n [pTooltip]=\"($tooltip | async) ?? undefined\"\n [tooltipPosition]=\"action.button.tooltipPosition ?? undefined\"\n [disabled]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false)\"\n (onClick)=\"triggerAction(action)\"\n [class]=\"buttonClass\"\n [model]=\"subactions\">\n </p-splitButton>\n } @else {\n <button\n pButton\n pRipple\n type=\"button\"\n [icon]=\"$any(action.button.icon)\"\n [iconPos]=\"action.button.iconPosition\"\n [label]=\"($label | async) ?? ''\"\n [pTooltip]=\"($tooltip | async) ?? undefined\"\n [tooltipPosition]=\"action.button.tooltipPosition ?? undefined\"\n [loading]=\"(($loading | async) ?? false) || ((inputLoading | async) ?? false)\"\n loadingIcon=\"pi pi-spin pi-spinner\"\n [disabled]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false)\"\n (click)=\"triggerAction(action, undefined, $event)\"\n [class]=\"buttonClass\"></button>\n <p-menu #subactionsMenu [model]=\"subactions\" [popup]=\"true\" appendTo=\"body\" styleClass=\"mng-action-menu\"></p-menu>\n }\n}\n", styles: [":host{display:inline-block}\n"], dependencies: [{ kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "ngmodule", type: ButtonModule }, { kind: "directive", type: i6.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { kind: "ngmodule", type: RippleModule }, { kind: "directive", type: i7.Ripple, selector: "[pRipple]" }, { kind: "ngmodule", type: TooltipModule }, { kind: "directive", type: i8.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "autoHide", "fitContent", "hideOnEscape", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "pipe", type: ParametrizePipe, name: "mngParametrize" }, { kind: "directive", type: ComponentDirective, selector: "[mngComponent]", inputs: ["mngComponent", "injectionToken", "inputs", "attachToHost", "nodeInjector"], outputs: ["instanceCreated"] }, { kind: "ngmodule", type: SplitButtonModule }, { kind: "component", type: i9.SplitButton, selector: "p-splitButton", inputs: ["model", "icon", "iconPos", "label", "style", "styleClass", "menuStyle", "menuStyleClass", "disabled", "tabindex", "appendTo", "dir", "expandAriaLabel", "showTransitionOptions", "hideTransitionOptions", "buttonProps", "menuButtonProps"], outputs: ["onClick", "onDropdownClick"] }, { kind: "directive", type: i1.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "ngmodule", type: MenuModule }, { kind: "component", type: i10.Menu, selector: "p-menu", inputs: ["model", "popup", "style", "styleClass", "appendTo", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "ariaLabel", "ariaLabelledBy", "id", "tabindex"], outputs: ["onShow", "onHide", "onBlur", "onFocus"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
266
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: ActionComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.TranslateService }, { token: i3.PermissionService }, { token: i4.ActionExecutorService }, { token: i5.ViewContainer, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
267
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.4", type: ActionComponent, isStandalone: true, selector: "mng-action", inputs: { action: { classPropertyName: "action", publicName: "action", isSignal: true, isRequired: true, transformFunction: null }, item: { classPropertyName: "item", publicName: "item", isSignal: true, isRequired: false, transformFunction: null }, itemId: { classPropertyName: "itemId", publicName: "itemId", isSignal: true, isRequired: false, transformFunction: null }, actionData: { classPropertyName: "actionData", publicName: "actionData", isSignal: true, isRequired: false, transformFunction: null }, dataListParams: { classPropertyName: "dataListParams", publicName: "dataListParams", isSignal: true, isRequired: false, transformFunction: null }, dataProvider: { classPropertyName: "dataProvider", publicName: "dataProvider", isSignal: true, isRequired: false, transformFunction: null }, hostComponent: { classPropertyName: "hostComponent", publicName: "hostComponent", isSignal: true, isRequired: false, transformFunction: null }, routeInit: { classPropertyName: "routeInit", publicName: "route", isSignal: true, isRequired: false, transformFunction: null }, inputDisabled: { classPropertyName: "inputDisabled", publicName: "disabled", isSignal: true, isRequired: false, transformFunction: null }, inputLoading: { classPropertyName: "inputLoading", publicName: "loading", isSignal: true, isRequired: false, transformFunction: null }, selectedItems: { classPropertyName: "selectedItems", publicName: "selectedItems", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { finish: "finish" }, host: { properties: { "class": "hostClass()", "class.m-0": "isHostHidden()" } }, providers: [provideActionExecutor()], viewQueries: [{ propertyName: "subactionsMenu", first: true, predicate: Menu, descendants: true, isSignal: true }], ngImport: i0, template: "@if (isVisible() && isPermitted()) {\n @if(actionLink(); as actionLink) {\n @if(actionLink.url !== '') {\n <a\n pButton\n pRipple\n [label]=\"label()\"\n [icon]=\"$any(action().button.icon)\"\n [iconPos]=\"action().button.iconPosition\"\n [href]=\"!isEnabled() || inputDisabled() ? null : (actionLink.url | mngParametrize: itemId() : item() : actionData())\"\n [target]=\"actionLink.target\"\n [class.disabled]=\"!isEnabled() || inputDisabled()\"\n [pTooltip]=\"tooltip()\"\n [tooltipPosition]=\"action().button.tooltipPosition ?? undefined\"\n [class]=\"buttonClass()\"></a>\n } @else {\n <a\n pButton\n pRipple\n [icon]=\"$any(action().button.icon)\"\n [iconPos]=\"action().button.iconPosition\"\n [label]=\"label()\"\n [target]=\"actionLink.target\"\n [replaceUrl]=\"actionLink.replaceUrl\"\n [routerLink]=\"!isEnabled() || inputDisabled() ? null : (actionLink.pathSegments | mngParametrize: itemId() : item() : actionData())\"\n [relativeTo]=\"route()\"\n [queryParams]=\"actionLink.queryParams | mngParametrize: itemId() : item() : actionData()\"\n [queryParamsHandling]=\"actionLink.queryParamsHandling\"\n [class.disabled]=\"!isEnabled() || inputDisabled()\"\n [pTooltip]=\"tooltip()\"\n [tooltipPosition]=\"action().button.tooltipPosition ?? undefined\"\n [class]=\"buttonClass()\"></a>\n }\n }\n @else if (action().component || action().componentFromDi) {\n <ng-container\n [mngComponent]=\"action().component\"\n [injectionToken]=\"action().componentFromDi\"\n [inputs]=\"{\n action: action(),\n item: item(),\n itemId: itemId(),\n actionData: actionData(),\n enabled: isEnabled(),\n loading: loading()\n }\"\n (instanceCreated)=\"onCustomActionCmpInst($event)\">\n </ng-container>\n }\n\n @else if (action().subactions.length > 0 && !action().subactionsAsMenu) {\n <p-splitButton\n [icon]=\"action().button.icon ?? undefined\"\n [iconPos]=\"action().button.iconPosition\"\n [label]=\"label()\"\n [pTooltip]=\"tooltip()\"\n [tooltipPosition]=\"action().button.tooltipPosition ?? undefined\"\n [disabled]=\"!isEnabled() || inputDisabled()\"\n (onClick)=\"triggerAction(action())\"\n [class]=\"buttonClass()\"\n [model]=\"subactions()\">\n </p-splitButton>\n } @else {\n <button\n pButton\n pRipple\n type=\"button\"\n [icon]=\"$any(action().button.icon)\"\n [iconPos]=\"action().button.iconPosition\"\n [label]=\"label()\"\n [pTooltip]=\"tooltip()\"\n [tooltipPosition]=\"action().button.tooltipPosition ?? undefined\"\n [loading]=\"loading() || inputLoading()\"\n loadingIcon=\"pi pi-spin pi-spinner\"\n [disabled]=\"!isEnabled() || inputDisabled()\"\n (click)=\"triggerAction(action(), undefined, $event)\"\n [class]=\"buttonClass()\"></button>\n <p-menu #subactionsMenu [model]=\"subactions()\" [popup]=\"true\" appendTo=\"body\" styleClass=\"mng-action-menu\"></p-menu>\n }\n}\n", styles: [":host{display:inline-block}\n"], dependencies: [{ kind: "ngmodule", type: ButtonModule }, { kind: "directive", type: i6.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { kind: "ngmodule", type: RippleModule }, { kind: "directive", type: i7.Ripple, selector: "[pRipple]" }, { kind: "ngmodule", type: TooltipModule }, { kind: "directive", type: i8.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "autoHide", "fitContent", "hideOnEscape", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "pipe", type: ParametrizePipe, name: "mngParametrize" }, { kind: "directive", type: ComponentDirective, selector: "[mngComponent]", inputs: ["mngComponent", "injectionToken", "inputs", "attachToHost", "parentInjector"], outputs: ["instanceCreated"] }, { kind: "ngmodule", type: SplitButtonModule }, { kind: "component", type: i9.SplitButton, selector: "p-splitButton", inputs: ["model", "icon", "iconPos", "label", "style", "styleClass", "menuStyle", "menuStyleClass", "disabled", "tabindex", "appendTo", "dir", "expandAriaLabel", "showTransitionOptions", "hideTransitionOptions", "buttonProps", "menuButtonProps"], outputs: ["onClick", "onDropdownClick"] }, { kind: "directive", type: i1.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "ngmodule", type: MenuModule }, { kind: "component", type: i10.Menu, selector: "p-menu", inputs: ["model", "popup", "style", "styleClass", "appendTo", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "ariaLabel", "ariaLabelledBy", "id", "tabindex"], outputs: ["onShow", "onHide", "onBlur", "onFocus"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
278
268
|
}
|
|
279
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.
|
|
269
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: ActionComponent, decorators: [{
|
|
280
270
|
type: Component,
|
|
281
|
-
args: [{ standalone: true, selector: 'mng-action', changeDetection: ChangeDetectionStrategy.OnPush, imports: [AsyncPipe, ButtonModule, RippleModule, TooltipModule, ParametrizePipe, ComponentDirective, SplitButtonModule, MenuModule], providers: [provideActionExecutor()], template: "@if ((
|
|
271
|
+
args: [{ standalone: true, selector: 'mng-action', changeDetection: ChangeDetectionStrategy.OnPush, imports: [AsyncPipe, ButtonModule, RippleModule, TooltipModule, ParametrizePipe, ComponentDirective, SplitButtonModule, MenuModule], providers: [provideActionExecutor()], host: { '[class]': 'hostClass()', '[class.m-0]': 'isHostHidden()' }, template: "@if (isVisible() && isPermitted()) {\n @if(actionLink(); as actionLink) {\n @if(actionLink.url !== '') {\n <a\n pButton\n pRipple\n [label]=\"label()\"\n [icon]=\"$any(action().button.icon)\"\n [iconPos]=\"action().button.iconPosition\"\n [href]=\"!isEnabled() || inputDisabled() ? null : (actionLink.url | mngParametrize: itemId() : item() : actionData())\"\n [target]=\"actionLink.target\"\n [class.disabled]=\"!isEnabled() || inputDisabled()\"\n [pTooltip]=\"tooltip()\"\n [tooltipPosition]=\"action().button.tooltipPosition ?? undefined\"\n [class]=\"buttonClass()\"></a>\n } @else {\n <a\n pButton\n pRipple\n [icon]=\"$any(action().button.icon)\"\n [iconPos]=\"action().button.iconPosition\"\n [label]=\"label()\"\n [target]=\"actionLink.target\"\n [replaceUrl]=\"actionLink.replaceUrl\"\n [routerLink]=\"!isEnabled() || inputDisabled() ? null : (actionLink.pathSegments | mngParametrize: itemId() : item() : actionData())\"\n [relativeTo]=\"route()\"\n [queryParams]=\"actionLink.queryParams | mngParametrize: itemId() : item() : actionData()\"\n [queryParamsHandling]=\"actionLink.queryParamsHandling\"\n [class.disabled]=\"!isEnabled() || inputDisabled()\"\n [pTooltip]=\"tooltip()\"\n [tooltipPosition]=\"action().button.tooltipPosition ?? undefined\"\n [class]=\"buttonClass()\"></a>\n }\n }\n @else if (action().component || action().componentFromDi) {\n <ng-container\n [mngComponent]=\"action().component\"\n [injectionToken]=\"action().componentFromDi\"\n [inputs]=\"{\n action: action(),\n item: item(),\n itemId: itemId(),\n actionData: actionData(),\n enabled: isEnabled(),\n loading: loading()\n }\"\n (instanceCreated)=\"onCustomActionCmpInst($event)\">\n </ng-container>\n }\n\n @else if (action().subactions.length > 0 && !action().subactionsAsMenu) {\n <p-splitButton\n [icon]=\"action().button.icon ?? undefined\"\n [iconPos]=\"action().button.iconPosition\"\n [label]=\"label()\"\n [pTooltip]=\"tooltip()\"\n [tooltipPosition]=\"action().button.tooltipPosition ?? undefined\"\n [disabled]=\"!isEnabled() || inputDisabled()\"\n (onClick)=\"triggerAction(action())\"\n [class]=\"buttonClass()\"\n [model]=\"subactions()\">\n </p-splitButton>\n } @else {\n <button\n pButton\n pRipple\n type=\"button\"\n [icon]=\"$any(action().button.icon)\"\n [iconPos]=\"action().button.iconPosition\"\n [label]=\"label()\"\n [pTooltip]=\"tooltip()\"\n [tooltipPosition]=\"action().button.tooltipPosition ?? undefined\"\n [loading]=\"loading() || inputLoading()\"\n loadingIcon=\"pi pi-spin pi-spinner\"\n [disabled]=\"!isEnabled() || inputDisabled()\"\n (click)=\"triggerAction(action(), undefined, $event)\"\n [class]=\"buttonClass()\"></button>\n <p-menu #subactionsMenu [model]=\"subactions()\" [popup]=\"true\" appendTo=\"body\" styleClass=\"mng-action-menu\"></p-menu>\n }\n}\n", styles: [":host{display:inline-block}\n"] }]
|
|
282
272
|
}], ctorParameters: () => [{ type: i1.ActivatedRoute }, { type: i2.TranslateService }, { type: i3.PermissionService }, { type: i4.ActionExecutorService }, { type: i5.ViewContainer, decorators: [{
|
|
283
273
|
type: Optional
|
|
284
|
-
}] }]
|
|
285
|
-
type: HostBinding,
|
|
286
|
-
args: ['class']
|
|
287
|
-
}], isHostHidden: [{
|
|
288
|
-
type: HostBinding,
|
|
289
|
-
args: ['class.m-0']
|
|
290
|
-
}], action: [{
|
|
291
|
-
type: Input,
|
|
292
|
-
args: [{ required: true }]
|
|
293
|
-
}], item: [{
|
|
294
|
-
type: Input
|
|
295
|
-
}], itemId: [{
|
|
296
|
-
type: Input
|
|
297
|
-
}], actionData: [{
|
|
298
|
-
type: Input
|
|
299
|
-
}], dataListParams: [{
|
|
300
|
-
type: Input
|
|
301
|
-
}], dataProvider: [{
|
|
302
|
-
type: Input
|
|
303
|
-
}], hostComponent: [{
|
|
304
|
-
type: Input
|
|
305
|
-
}], routeInit: [{
|
|
306
|
-
type: Input,
|
|
307
|
-
args: ['route']
|
|
308
|
-
}], inputDisabled: [{
|
|
309
|
-
type: Input,
|
|
310
|
-
args: [{ alias: 'disabled', transform: boolean$Attribute }]
|
|
311
|
-
}], inputLoading: [{
|
|
312
|
-
type: Input,
|
|
313
|
-
args: [{ alias: 'loading', transform: boolean$Attribute }]
|
|
314
|
-
}], selectedItems: [{
|
|
315
|
-
type: Input
|
|
316
|
-
}], finishEventEmitter: [{
|
|
317
|
-
type: Output,
|
|
318
|
-
args: ['finish']
|
|
319
|
-
}], subactionsMenu: [{
|
|
320
|
-
type: ViewChild,
|
|
321
|
-
args: ['subactionsMenu']
|
|
322
|
-
}] } });
|
|
323
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"action.component.js","sourceRoot":"","sources":["../../../../../../tableview/src/action/components/action/action.component.ts","../../../../../../tableview/src/action/components/action/action.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AsyncPipe} from '@angular/common';\nimport {ChangeDetectionStrategy, Component, EventEmitter, HostBinding, Input, OnChanges, OnDestroy, OnInit, Optional, Output, SimpleChanges, ViewChild} from '@angular/core';\nimport {ActivatedRoute} from '@angular/router';\n\nimport {TranslateService} from '@ngx-translate/core';\nimport {MenuItem} from 'primeng/api';\nimport {ButtonModule} from 'primeng/button';\nimport {Menu, MenuModule} from 'primeng/menu';\nimport {RippleModule} from 'primeng/ripple';\nimport {SplitButtonModule} from 'primeng/splitbutton';\nimport {TooltipModule} from 'primeng/tooltip';\nimport {Observable, ReplaySubject, Subscription, combineLatest, distinctUntilChanged, of} from 'rxjs';\n\nimport {\n    APermissions,\n    ActionData,\n    ActionParameters,\n    ComponentDirective,\n    DataListParams,\n    IDataProvider,\n    IdType,\n    ParametrizePipe,\n    PermissionService,\n    Permissions,\n    boolean$Attribute,\n    toObservable\n} from '@mediusinc/mng-commons/core';\nimport {ActionContextValidation, ActionDescriptorInst, ActionLinkDescriptorInst, ActionTypeEnum, IActionComponent, TableviewRouteData} from '@mediusinc/mng-commons/tableview/api';\n\nimport {getI18nForActionAsync} from '../../helpers/i18n';\nimport {ActionInstanceStateEnum} from '../../models/execution/action-instance-state.model';\nimport {ActionInstance} from '../../models/execution/action-instance.model';\nimport {ActionExecutorService} from '../../services/action-executor.service';\nimport {provideActionExecutor} from '../../services/providers/provide-action-executor';\nimport {ViewContainer} from '../../services/view-container.service';\n\n@Component({\n    standalone: true,\n    selector: 'mng-action',\n    templateUrl: './action.component.html',\n    styleUrls: ['./action.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    imports: [AsyncPipe, ButtonModule, RippleModule, TooltipModule, ParametrizePipe, ComponentDirective, SplitButtonModule, MenuModule],\n    providers: [provideActionExecutor()]\n})\nexport class ActionComponent<Item = any, Service = undefined> implements OnInit, OnChanges, OnDestroy {\n    @HostBinding('class') hostClass = 'mng-action-button';\n    @HostBinding('class.m-0') isHostHidden = false;\n\n    // metadata and editor mode input\n    @Input({required: true}) public action!: ActionDescriptorInst<Item, Service>;\n    @Input() public item?: Item;\n    @Input() public itemId?: IdType;\n    @Input() public actionData?: ActionData;\n    @Input() public dataListParams?: DataListParams;\n    @Input() public dataProvider?: IDataProvider<Item, Service>;\n    @Input() public hostComponent?: unknown;\n    @Input('route') public routeInit?: ActivatedRoute;\n    @Input({alias: 'disabled', transform: boolean$Attribute}) public inputDisabled: Observable<boolean> = of(false);\n    @Input({alias: 'loading', transform: boolean$Attribute}) public inputLoading: Observable<boolean> = of(false);\n    @Input() public selectedItems: Array<Item> = [];\n\n    @Output('finish') public finishEventEmitter = new EventEmitter<ActionInstance<Item, Service>>();\n\n    @ViewChild('subactionsMenu') public subactionsMenu?: Menu;\n\n    private loadingSubject = new ReplaySubject<boolean>(1);\n    public $loading: Observable<boolean> = this.loadingSubject.asObservable();\n\n    private isVisibleSubject = new ReplaySubject<boolean>(1);\n    private isVisibleSubscription?: Subscription;\n    public $isVisible = this.isVisibleSubject.asObservable().pipe(distinctUntilChanged());\n    private isPermittedSubject = new ReplaySubject<boolean>(1);\n    private isPermittedSubscription?: Subscription;\n    public $isPermitted = this.isPermittedSubject.asObservable().pipe(distinctUntilChanged());\n    private isEnabledSubject = new ReplaySubject<boolean>(1);\n    private isEnabledSubscription?: Subscription;\n    public $isEnabled = this.isEnabledSubject.asObservable().pipe(distinctUntilChanged());\n    private labelSubject = new ReplaySubject<string | null>(1);\n    private labelSubscription?: Subscription;\n    public $label = this.labelSubject.asObservable().pipe(distinctUntilChanged());\n    private tooltipSubject = new ReplaySubject<string | null>(1);\n    private tooltipSubscription?: Subscription;\n    public $tooltip = this.tooltipSubject.asObservable().pipe(distinctUntilChanged());\n\n    public actionLink?: ActionLinkDescriptorInst<Item>;\n    public hasNoTitle = false;\n\n    private subscriptions: Subscription[] = [];\n\n    public route!: ActivatedRoute; // value will be determined in ngOnInit\n    private routePermissions?: APermissions;\n\n    public buttonClass = 'p-button-primary';\n    public subactions: MenuItem[] = [];\n    private subactionSubscriptions: Subscription[] = [];\n    public actionOrSubactionHasRunConfirmation = false;\n\n    private instance?: ActionInstance<Item, Service>;\n\n    constructor(\n        private routeService: ActivatedRoute,\n        private translate: TranslateService,\n        private authorization: PermissionService,\n        private actionExecutor: ActionExecutorService,\n        @Optional() private viewContainer: ViewContainer<Item, Service> | null\n    ) {\n        this.loadingSubject.next(false);\n    }\n\n    public ngOnInit() {\n        this.route = this.routeInit ?? this.routeService;\n\n        this.hasNoTitle = this.action.button.label === null;\n        this.isEnabledSubject.next(true);\n        this.isVisibleSubject.next(true);\n        this.isPermittedSubject.next(true);\n        this.labelSubject.next(null);\n        this.tooltipSubject.next(null);\n\n        const routeData = this.route.snapshot.data as TableviewRouteData;\n        if (this.action instanceof ActionLinkDescriptorInst) {\n            this.actionLink = this.action;\n        }\n\n        if (this.action.tableviewCategory && routeData.tableviewPermissions) {\n            if (routeData.tableviewPermissions[this.action.tableviewCategory]) {\n                this.routePermissions = routeData.tableviewPermissions[this.action.tableviewCategory];\n            }\n        }\n        this.processSubscriptions();\n\n        if (this.action.className) {\n            this.hostClass = this.action.className;\n        }\n        const hostVisibilitySubscription = combineLatest([this.$isVisible, this.$isPermitted]).subscribe(([isVisible, isPermitted]) => {\n            this.isHostHidden = !isVisible || !isPermitted;\n        });\n        this.subscriptions.push(hostVisibilitySubscription);\n\n        this.buttonClass = this.action.button.styleClass.build(this.hasNoTitle);\n\n        // Here we check if an action or any subaction has confirmation dialog\n        this.actionOrSubactionHasRunConfirmation = this.action.subactions.some(sub => sub.hasRunConfirmation) || this.action.hasRunConfirmation;\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (\n            !(changes['item']?.firstChange ?? true) ||\n            !(changes['itemId']?.firstChange ?? true) ||\n            !(changes['actionData']?.firstChange ?? true) ||\n            (this.action.hasItemsSelection && !(changes['selectedItems']?.firstChange ?? true))\n        ) {\n            this.processSubscriptions();\n        }\n    }\n\n    ngOnDestroy(): void {\n        this.actionExecutor.onActionDestroy(this.instance);\n        this.isVisibleSubscription?.unsubscribe();\n        this.isPermittedSubscription?.unsubscribe();\n        this.isEnabledSubscription?.unsubscribe();\n        this.labelSubscription?.unsubscribe();\n        this.tooltipSubscription?.unsubscribe();\n        this.subscriptions.forEach(s => s.unsubscribe());\n        this.subactionSubscriptions.forEach(s => s.unsubscribe());\n    }\n\n    public triggerAction(action: ActionDescriptorInst<Item, Service>, parameters?: ActionParameters<Item>, event?: Event) {\n        if (action.subactionsAsMenu) {\n            this.subactionsMenu?.toggle(event ?? new Event('trigger'));\n            return;\n        }\n\n        const actionData = this.actionData ? this.actionData : {};\n\n        parameters ??= {\n            itemId: this.itemId,\n            item: this.item,\n            actionData: actionData,\n            dataListParams: this.dataListParams,\n            route: this.route,\n            sourceComponent: this,\n            hostComponent: this.hostComponent,\n            selectedItems: this.selectedItems\n        };\n\n        const instance = this.actionExecutor.triggerAction<Item, Service>(action, parameters);\n        this.instance = instance;\n        const context = instance.context;\n        if (!context) {\n            // no context is provided if routing is triggered or editor is opened via dialog\n            // it is in another component jurisdiction to handle contexts\n            return;\n        }\n\n        this.subscriptions.push(\n            instance.result$.subscribe({\n                next: () => {\n                    this.finishEventEmitter.next(instance);\n                    if (action.hasItemsSelection) {\n                        this.viewContainer?.reloadTable({data: {event: event}});\n                    }\n                }\n            })\n        );\n        this.subscriptions.push(\n            instance.error$.subscribe({\n                next: () => {\n                    this.finishEventEmitter.next(instance);\n                }\n            })\n        );\n\n        this.subscriptions.push(\n            this.instance.state$.subscribe(s => {\n                switch (s) {\n                    case ActionInstanceStateEnum.RunStart:\n                        this.loadingSubject.next(true);\n                        break;\n                    case ActionInstanceStateEnum.RunEnd:\n                    case ActionInstanceStateEnum.RunError:\n                        this.loadingSubject.next(false);\n                        break;\n                    case ActionInstanceStateEnum.NextActionStart:\n                        if (this.instance?.nextActionInstance?.action.type === ActionTypeEnum.Direct) {\n                            this.loadingSubject.next(true);\n                        }\n                        break;\n                    case ActionInstanceStateEnum.NextActionEnd:\n                        if (this.instance?.nextActionInstance?.action.type === ActionTypeEnum.Direct) {\n                            this.loadingSubject.next(false);\n                        }\n                        break;\n                    case ActionInstanceStateEnum.ErrorActionStart:\n                        if (this.instance?.errorActionInstance?.action.type === ActionTypeEnum.Direct) {\n                            this.loadingSubject.next(true);\n                        }\n                        break;\n                    case ActionInstanceStateEnum.ErrorActionEnd:\n                        if (this.instance?.errorActionInstance?.action.type === ActionTypeEnum.Direct) {\n                            this.loadingSubject.next(false);\n                        }\n                        break;\n                }\n            })\n        );\n\n        this.actionExecutor.run(context);\n    }\n\n    public onCustomActionCmpInst(instance: IActionComponent<Item>) {\n        const cmpInstSubscription = instance.triggerActionEventEmitter.subscribe(params => this.triggerAction(this.action, params));\n        this.subscriptions.push(cmpInstSubscription);\n    }\n\n    private processSubactions(): MenuItem[] {\n        this.subactionSubscriptions.forEach(s => s.unsubscribe());\n        this.subactionSubscriptions = [];\n\n        const menuItems: MenuItem[] = [];\n        for (const subaction of this.action.subactions) {\n            const menuItem = {} as MenuItem;\n\n            menuItem.icon = subaction.button.icon ?? undefined;\n            this.subactionSubscriptions.push(\n                getI18nForActionAsync(this.translate, subaction, 'title', subaction.button.label ?? undefined, this.item).subscribe({\n                    next: res => (menuItem.label = res!)\n                })\n            );\n            this.subactionSubscriptions.push(\n                getI18nForActionAsync(this.translate, subaction, 'tooltip', this.action.button.tooltip, this.item).subscribe({\n                    next: res => (menuItem.tooltip = res!)\n                })\n            );\n\n            const parameters: ActionParameters<Item> = {\n                itemId: this.itemId,\n                item: this.item,\n                actionData: this.actionData,\n                sourceComponent: this\n            };\n\n            if (subaction.hasItemsSelection) {\n                parameters.selectedItems = this.selectedItems;\n            }\n\n            const context = this.actionExecutor.prepareActionContextValidation(subaction, parameters, this.dataProvider);\n\n            if (typeof subaction.isEnabledFunction === 'function') {\n                this.subactionSubscriptions.push(\n                    toObservable(subaction.isEnabledFunction(context)).subscribe({\n                        next: res => (menuItem.disabled = !res)\n                    })\n                );\n            }\n\n            const visibilityObservables: Observable<boolean>[] = [];\n            if (typeof subaction.isVisibleFunction === 'function') {\n                visibilityObservables.push(toObservable(subaction.isVisibleFunction(context)));\n            }\n            if (typeof subaction.permissions !== 'undefined') {\n                visibilityObservables.push(this.authorization.isPermitted(subaction.permissions, this.route.snapshot, context as ActionContextValidation<unknown, unknown>));\n            }\n\n            const routeData = this.route.snapshot.data as TableviewRouteData;\n            if (subaction.tableviewCategory && routeData.tableviewPermissions && routeData.tableviewPermissions[subaction.tableviewCategory]) {\n                const routePermissions = routeData.tableviewPermissions[subaction.tableviewCategory];\n                visibilityObservables.push(this.authorization.isPermitted(routePermissions, this.route.snapshot, context as ActionContextValidation<unknown, unknown>));\n            }\n\n            this.subactionSubscriptions.push(\n                combineLatest(visibilityObservables).subscribe(visibilities => {\n                    menuItem.visible = visibilities.every(value => value);\n                })\n            );\n\n            menuItem.command = () => this.triggerAction(subaction);\n\n            menuItems.push(menuItem);\n        }\n        return menuItems;\n    }\n\n    private processSubscriptions() {\n        const parameters: ActionParameters<Item> = {\n            itemId: this.itemId,\n            item: this.item,\n            actionData: this.actionData,\n            sourceComponent: this\n        };\n\n        if (this.action.hasItemsSelection) {\n            parameters.selectedItems = this.selectedItems;\n        }\n\n        const context = this.actionExecutor.prepareActionContextValidation(this.action, parameters, this.dataProvider);\n\n        if (typeof this.action.isVisibleFunction === 'function') {\n            this.isVisibleSubscription?.unsubscribe();\n            this.isVisibleSubscription = toObservable(this.action.isVisibleFunction(context)).subscribe({\n                next: res => this.isVisibleSubject.next(res)\n            });\n        }\n        if (typeof this.action.permissions !== 'undefined' || typeof this.routePermissions !== 'undefined') {\n            this.isPermittedSubscription?.unsubscribe();\n            const permissions =\n                this.action.permissions && this.routePermissions\n                    ? Permissions.All.of(this.routePermissions, this.action.permissions)\n                    : this.routePermissions ?? this.action.permissions!;\n            this.isVisibleSubscription = this.authorization.isPermitted(permissions, this.route.snapshot, context as ActionContextValidation<unknown, unknown>).subscribe({\n                next: res => this.isPermittedSubject.next(res)\n            });\n        }\n        if (typeof this.action.isEnabledFunction === 'function') {\n            this.isEnabledSubscription?.unsubscribe();\n            this.isEnabledSubscription = toObservable(this.action.isEnabledFunction(context)).subscribe({\n                next: res => this.isEnabledSubject.next(res)\n            });\n        }\n\n        if (!this.hasNoTitle) {\n            this.labelSubscription?.unsubscribe();\n            this.labelSubscription = getI18nForActionAsync(this.translate, this.action, 'title', this.action.button.label ?? undefined, this.item).subscribe({\n                next: i18n => this.labelSubject.next(i18n)\n            });\n        }\n\n        this.tooltipSubscription?.unsubscribe();\n        if (this.action.button.tooltip) {\n            this.tooltipSubscription = getI18nForActionAsync(this.translate, this.action, 'tooltip', this.action.button.tooltip, this.item, undefined, undefined).subscribe({\n                next: i18n => this.tooltipSubject.next(i18n)\n            });\n        }\n\n        this.subactions = this.processSubactions();\n    }\n}\n","@if (($isVisible | async) && ($isPermitted | async)) {\n    @if (actionLink && actionLink.url !== '') {\n        <a\n            pButton\n            pRipple\n            [label]=\"($label | async) ?? ''\"\n            [icon]=\"$any(action.button.icon)\"\n            [iconPos]=\"action.button.iconPosition\"\n            [href]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false) ? null : (actionLink.url | mngParametrize: itemId : item : actionData)\"\n            [target]=\"actionLink.target\"\n            [class.disabled]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false)\"\n            [pTooltip]=\"($tooltip | async) ?? undefined\"\n            [tooltipPosition]=\"action.button.tooltipPosition ?? undefined\"\n            [class]=\"buttonClass\"></a>\n    } @else if (actionLink) {\n        <a\n            pButton\n            pRipple\n            [icon]=\"$any(action.button.icon)\"\n            [iconPos]=\"action.button.iconPosition\"\n            [label]=\"($label | async) ?? ''\"\n            [target]=\"actionLink.target\"\n            [replaceUrl]=\"actionLink.replaceUrl\"\n            [routerLink]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false) ? null : (actionLink.pathSegments | mngParametrize: itemId : item : actionData)\"\n            [relativeTo]=\"route\"\n            [queryParams]=\"actionLink.queryParams | mngParametrize: itemId : item : actionData\"\n            [queryParamsHandling]=\"actionLink.queryParamsHandling\"\n            [class.disabled]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false)\"\n            [pTooltip]=\"($tooltip | async) ?? undefined\"\n            [tooltipPosition]=\"action.button.tooltipPosition ?? undefined\"\n            [class]=\"buttonClass\"></a>\n    } @else if (action.component || action.componentFromDi) {\n        <ng-container\n            [mngComponent]=\"action.component\"\n            [injectionToken]=\"action.componentFromDi\"\n            [inputs]=\"{\n                action: action,\n                item: item,\n                itemId: itemId,\n                actionData: actionData,\n                enabled: $isEnabled,\n                loading: $loading\n            }\"\n            (instanceCreated)=\"onCustomActionCmpInst($event)\">\n        </ng-container>\n    } @else if (action.subactions.length > 0 && !action.subactionsAsMenu) {\n        <p-splitButton\n            [icon]=\"action.button.icon ?? undefined\"\n            [iconPos]=\"action.button.iconPosition\"\n            [label]=\"($label | async) ?? ''\"\n            [pTooltip]=\"($tooltip | async) ?? undefined\"\n            [tooltipPosition]=\"action.button.tooltipPosition ?? undefined\"\n            [disabled]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false)\"\n            (onClick)=\"triggerAction(action)\"\n            [class]=\"buttonClass\"\n            [model]=\"subactions\">\n        </p-splitButton>\n    } @else {\n        <button\n            pButton\n            pRipple\n            type=\"button\"\n            [icon]=\"$any(action.button.icon)\"\n            [iconPos]=\"action.button.iconPosition\"\n            [label]=\"($label | async) ?? ''\"\n            [pTooltip]=\"($tooltip | async) ?? undefined\"\n            [tooltipPosition]=\"action.button.tooltipPosition ?? undefined\"\n            [loading]=\"(($loading | async) ?? false) || ((inputLoading | async) ?? false)\"\n            loadingIcon=\"pi pi-spin pi-spinner\"\n            [disabled]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false)\"\n            (click)=\"triggerAction(action, undefined, $event)\"\n            [class]=\"buttonClass\"></button>\n        <p-menu #subactionsMenu [model]=\"subactions\" [popup]=\"true\" appendTo=\"body\" styleClass=\"mng-action-menu\"></p-menu>\n    }\n}\n"]}
|
|
274
|
+
}] }] });
|
|
275
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"action.component.js","sourceRoot":"","sources":["../../../../../../tableview/src/action/components/action/action.component.ts","../../../../../../tableview/src/action/components/action/action.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAC,MAAM,iBAAiB,CAAC;AAC1C,OAAO,EACH,uBAAuB,EACvB,SAAS,EACT,UAAU,EAEV,QAAQ,EAER,gBAAgB,EAChB,QAAQ,EACR,MAAM,EACN,MAAM,EACN,KAAK,EACL,MAAM,EACN,MAAM,EACN,SAAS,EACZ,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,QAAQ,EAAC,MAAM,4BAA4B,CAAC;AACpD,OAAO,EAAC,cAAc,EAAC,MAAM,iBAAiB,CAAC;AAE/C,OAAO,EAAC,gBAAgB,EAAC,MAAM,qBAAqB,CAAC;AAErD,OAAO,EAAC,YAAY,EAAC,MAAM,gBAAgB,CAAC;AAC5C,OAAO,EAAC,IAAI,EAAE,UAAU,EAAC,MAAM,cAAc,CAAC;AAC9C,OAAO,EAAC,YAAY,EAAC,MAAM,gBAAgB,CAAC;AAC5C,OAAO,EAAC,iBAAiB,EAAC,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAC,aAAa,EAAC,MAAM,iBAAiB,CAAC;AAC9C,OAAO,EAA2B,aAAa,EAAC,MAAM,MAAM,CAAC;AAE7D,OAAO,EAIH,kBAAkB,EAIlB,eAAe,EACf,iBAAiB,EACjB,WAAW,EACX,YAAY,EACf,MAAM,6BAA6B,CAAC;AACrC,OAAO,EAAgD,wBAAwB,EAAE,cAAc,EAAuC,MAAM,sCAAsC,CAAC;AAEnL,OAAO,EAAC,qBAAqB,EAAC,MAAM,oBAAoB,CAAC;AACzD,OAAO,EAAC,uBAAuB,EAAC,MAAM,oDAAoD,CAAC;AAE3F,OAAO,EAAC,qBAAqB,EAAC,MAAM,wCAAwC,CAAC;AAC7E,OAAO,EAAC,qBAAqB,EAAC,MAAM,kDAAkD,CAAC;;;;;;;;;;;;AAcvF,MAAM,OAAO,eAAe;IAoExB,YACY,YAA4B,EAC5B,SAA2B,EAC3B,aAAgC,EAChC,cAAqC,EACzB,aAAkD;QAJ9D,iBAAY,GAAZ,YAAY,CAAgB;QAC5B,cAAS,GAAT,SAAS,CAAkB;QAC3B,kBAAa,GAAb,aAAa,CAAmB;QAChC,mBAAc,GAAd,cAAc,CAAuB;QACzB,kBAAa,GAAb,aAAa,CAAqC;QAxEzD,eAAU,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;QAEjD,iCAAiC;QAC1B,WAAM,GAAG,KAAK,CAAC,QAAQ,EAAuC,CAAC;QAC/D,SAAI,GAAG,KAAK,EAAQ,CAAC;QACrB,WAAM,GAAG,KAAK,EAAU,CAAC;QACzB,eAAU,GAAG,KAAK,EAAc,CAAC;QACjC,mBAAc,GAAG,KAAK,EAAkB,CAAC;QACzC,iBAAY,GAAG,KAAK,EAAgC,CAAC;QACrD,kBAAa,GAAG,KAAK,EAAO,CAAC;QAC7B,cAAS,GAAG,KAAK,CAA6B,SAAS,EAAE,EAAC,KAAK,EAAE,OAAO,EAAC,CAAC,CAAC;QAC3E,kBAAa,GAAG,KAAK,CAAmB,KAAK,EAAE,EAAC,KAAK,EAAE,UAAU,EAAE,SAAS,EAAE,gBAAgB,EAAC,CAAC,CAAC;QACjG,iBAAY,GAAG,KAAK,CAAmB,KAAK,EAAE,EAAC,KAAK,EAAE,SAAS,EAAE,SAAS,EAAE,gBAAgB,EAAC,CAAC,CAAC;QAC/F,kBAAa,GAAG,KAAK,CAAc,EAAE,CAAC,CAAC;QAEvC,WAAM,GAAG,MAAM,EAAiC,CAAC;QAEjD,mBAAc,GAAG,SAAS,CAAC,IAAI,CAAC,CAAC;QAEjC,cAAS,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,SAAS,IAAI,mBAAmB,CAAC,CAAC;QAC3E,iBAAY,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;QAExE,YAAO,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;QAGxB,cAAS,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC;QAEzB,gBAAW,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC;QAE3B,cAAS,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC;QAEzB,UAAK,GAAG,MAAM,CAAS,EAAE,CAAC,CAAC;QAE3B,YAAO,GAAG,MAAM,CAAS,EAAE,CAAC,CAAC;QAE7B,eAAU,GAAG,QAAQ,CAA6C,GAAG,EAAE;YAC1E,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;YAC7B,OAAO,MAAM,YAAY,wBAAwB,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,CAAC;QAC3E,CAAC,CAAC,CAAC;QAEI,eAAU,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,MAAM,CAAC,KAAK,KAAK,IAAI,CAAC,CAAC;QAOjE,UAAK,GAAG,QAAQ,CAAiB,GAAG,EAAE,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,IAAI,CAAC,YAAY,CAAC,CAAC;QAC9E,cAAS,GAAG,QAAQ,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,IAAI,CAAC,CAAC;QACvC,qBAAgB,GAAG,QAAQ,CAA2B,GAAG,EAAE;YAC/D,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;YACnC,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;YAC7B,IAAI,MAAM,CAAC,iBAAiB,IAAI,SAAS,IAAI,SAAS,CAAC,sBAAsB,CAAC,EAAE,CAAC;gBAC7E,MAAM,oBAAoB,GAAG,SAAS,CAAC,sBAAsB,CAAC,CAAC;gBAC/D,IAAI,oBAAoB,CAAC,MAAM,CAAC,iBAAiB,CAAC,EAAE,CAAC;oBACjD,OAAO,oBAAoB,CAAC,MAAM,CAAC,iBAAiB,CAAC,CAAC;gBAC1D,CAAC;YACL,CAAC;YACD,OAAO,SAAS,CAAC;QACrB,CAAC,CAAC,CAAC;QAEI,gBAAW,GAAG,QAAQ,CAAS,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC;QAC/F,eAAU,GAAG,MAAM,CAAa,EAAE,CAAC,CAAC;QACnC,2BAAsB,GAAmB,EAAE,CAAC;QAWhD,MAAM,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,oBAAoB,EAAE,EAAE,EAAC,iBAAiB,EAAE,IAAI,EAAC,CAAC,CAAC;IACzE,CAAC;IAED,WAAW;QACP,IAAI,CAAC,cAAc,CAAC,eAAe,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACnD,IAAI,CAAC,qBAAqB,EAAE,WAAW,EAAE,CAAC;QAC1C,IAAI,CAAC,uBAAuB,EAAE,WAAW,EAAE,CAAC;QAC5C,IAAI,CAAC,qBAAqB,EAAE,WAAW,EAAE,CAAC;QAC1C,IAAI,CAAC,iBAAiB,EAAE,WAAW,EAAE,CAAC;QACtC,IAAI,CAAC,mBAAmB,EAAE,WAAW,EAAE,CAAC;QACxC,IAAI,CAAC,kBAAkB,EAAE,WAAW,EAAE,CAAC;QACvC,IAAI,CAAC,iBAAiB,EAAE,WAAW,EAAE,CAAC;QACtC,IAAI,CAAC,iBAAiB,EAAE,WAAW,EAAE,CAAC;QACtC,IAAI,CAAC,mBAAmB,EAAE,WAAW,EAAE,CAAC;QACxC,IAAI,CAAC,sBAAsB,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC;IAC9D,CAAC;IAEM,aAAa,CAAC,MAA2C,EAAE,UAAmC,EAAE,KAAa;QAChH,IAAI,MAAM,CAAC,gBAAgB,EAAE,CAAC;YAC1B,IAAI,CAAC,cAAc,EAAE,EAAE,MAAM,CAAC,KAAK,IAAI,IAAI,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC;YAC7D,OAAO;QACX,CAAC;QAED,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QAE9D,UAAU,KAAK;YACX,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE;YACrB,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE;YACjB,UAAU,EAAE,UAAU;YACtB,cAAc,EAAE,IAAI,CAAC,cAAc,EAAE;YACrC,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE;YACnB,eAAe,EAAE,IAAI;YACrB,aAAa,EAAE,IAAI,CAAC,aAAa,EAAE;YACnC,aAAa,EAAE,IAAI,CAAC,aAAa,EAAE;SACtC,CAAC;QAEF,MAAM,QAAQ,GAAG,IAAI,CAAC,cAAc,CAAC,aAAa,CAAgB,MAAM,EAAE,UAAU,CAAC,CAAC;QACtF,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,MAAM,OAAO,GAAG,QAAQ,CAAC,OAAO,CAAC;QACjC,IAAI,CAAC,OAAO,EAAE,CAAC;YACX,gFAAgF;YAChF,6DAA6D;YAC7D,OAAO;QACX,CAAC;QAED,IAAI,CAAC,kBAAkB,EAAE,WAAW,EAAE,CAAC;QACvC,IAAI,CAAC,kBAAkB,GAAG,QAAQ,CAAC,OAAO,CAAC,SAAS,CAAC;YACjD,IAAI,EAAE,GAAG,EAAE;gBACP,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;gBAC3B,IAAI,MAAM,CAAC,iBAAiB,EAAE,CAAC;oBAC3B,IAAI,CAAC,aAAa,EAAE,WAAW,CAAC,EAAC,IAAI,EAAE,EAAC,KAAK,EAAE,KAAK,EAAC,EAAC,CAAC,CAAC;gBAC5D,CAAC;YACL,CAAC;SACJ,CAAC,CAAC;QAEH,IAAI,CAAC,iBAAiB,EAAE,WAAW,EAAE,CAAC;QACtC,IAAI,CAAC,iBAAiB,GAAG,QAAQ,CAAC,MAAM,CAAC,SAAS,CAAC;YAC/C,IAAI,EAAE,GAAG,EAAE;gBACP,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YAC/B,CAAC;SACJ,CAAC,CAAC;QAEH,IAAI,CAAC,iBAAiB,EAAE,WAAW,EAAE,CAAC;QACtC,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;YACxD,QAAQ,CAAC,EAAE,CAAC;gBACR,KAAK,uBAAuB,CAAC,QAAQ;oBACjC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;oBACvB,MAAM;gBACV,KAAK,uBAAuB,CAAC,MAAM,CAAC;gBACpC,KAAK,uBAAuB,CAAC,QAAQ;oBACjC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;oBACxB,MAAM;gBACV,KAAK,uBAAuB,CAAC,eAAe;oBACxC,IAAI,IAAI,CAAC,QAAQ,EAAE,kBAAkB,EAAE,MAAM,CAAC,IAAI,KAAK,cAAc,CAAC,MAAM,EAAE,CAAC;wBAC3E,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;oBAC3B,CAAC;oBACD,MAAM;gBACV,KAAK,uBAAuB,CAAC,aAAa;oBACtC,IAAI,IAAI,CAAC,QAAQ,EAAE,kBAAkB,EAAE,MAAM,CAAC,IAAI,KAAK,cAAc,CAAC,MAAM,EAAE,CAAC;wBAC3E,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;oBAC5B,CAAC;oBACD,MAAM;gBACV,KAAK,uBAAuB,CAAC,gBAAgB;oBACzC,IAAI,IAAI,CAAC,QAAQ,EAAE,mBAAmB,EAAE,MAAM,CAAC,IAAI,KAAK,cAAc,CAAC,MAAM,EAAE,CAAC;wBAC5E,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;oBAC3B,CAAC;oBACD,MAAM;gBACV,KAAK,uBAAuB,CAAC,cAAc;oBACvC,IAAI,IAAI,CAAC,QAAQ,EAAE,mBAAmB,EAAE,MAAM,CAAC,IAAI,KAAK,cAAc,CAAC,MAAM,EAAE,CAAC;wBAC5E,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;oBAC5B,CAAC;oBACD,MAAM;YACd,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;IACrC,CAAC;IAEM,qBAAqB,CAAC,QAAgC;QACzD,IAAI,CAAC,mBAAmB,EAAE,WAAW,EAAE,CAAC;QACxC,IAAI,CAAC,mBAAmB,GAAG,QAAQ,CAAC,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,EAAE,EAAE,MAAM,CAAC,CAAC,CAAC;IAC/G,CAAC;IAEO,oBAAoB;QACxB,MAAM,UAAU,GAA2B;YACvC,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE;YACrB,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE;YACjB,UAAU,EAAE,IAAI,CAAC,UAAU,EAAE;YAC7B,eAAe,EAAE,IAAI;SACxB,CAAC;QACF,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;QAC7B,IAAI,MAAM,CAAC,iBAAiB,EAAE,CAAC;YAC3B,UAAU,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC;QACpD,CAAC;QAED,MAAM,OAAO,GAAG,IAAI,CAAC,cAAc,CAAC,8BAA8B,CAAC,MAAM,EAAE,UAAU,EAAE,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC;QAE5G,IAAI,OAAO,MAAM,CAAC,iBAAiB,KAAK,UAAU,EAAE,CAAC;YACjD,IAAI,CAAC,qBAAqB,EAAE,WAAW,EAAE,CAAC;YAC1C,IAAI,CAAC,qBAAqB,GAAG,YAAY,CAAC,MAAM,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS,CAAC;gBACnF,IAAI,EAAE,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,GAAG,CAAC;aACvC,CAAC,CAAC;QACP,CAAC;QAED,MAAM,gBAAgB,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAEjD,IAAI,OAAO,MAAM,CAAC,WAAW,KAAK,WAAW,IAAI,OAAO,gBAAgB,KAAK,WAAW,EAAE,CAAC;YACvF,IAAI,CAAC,uBAAuB,EAAE,WAAW,EAAE,CAAC;YAC5C,MAAM,WAAW,GAAG,MAAM,CAAC,WAAW,IAAI,gBAAgB,CAAC,CAAC,CAAC,WAAW,CAAC,GAAG,CAAC,EAAE,CAAC,gBAAgB,EAAE,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,gBAAgB,IAAI,MAAM,CAAC,WAAY,CAAC;YAChK,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC,WAAW,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC,QAAQ,EAAE,OAAoD,CAAC,CAAC,SAAS,CAAC;gBAC5J,IAAI,EAAE,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,GAAG,CAAC;aACzC,CAAC,CAAC;QACP,CAAC;QACD,IAAI,OAAO,MAAM,CAAC,iBAAiB,KAAK,UAAU,EAAE,CAAC;YACjD,IAAI,CAAC,qBAAqB,EAAE,WAAW,EAAE,CAAC;YAC1C,IAAI,CAAC,qBAAqB,GAAG,YAAY,CAAC,MAAM,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS,CAAC;gBACnF,IAAI,EAAE,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,GAAG,CAAC;aACvC,CAAC,CAAC;QACP,CAAC;QAED,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,EAAE,CAAC;YACrB,IAAI,CAAC,iBAAiB,EAAE,WAAW,EAAE,CAAC;YACtC,IAAI,CAAC,iBAAiB,GAAG,qBAAqB,CAAC,IAAI,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,CAAC,MAAM,CAAC,KAAK,IAAI,SAAS,EAAE,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,SAAS,CAAC;gBACrI,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,IAAI,EAAE,CAAC;aAC3C,CAAC,CAAC;QACP,CAAC;QAED,IAAI,CAAC,mBAAmB,EAAE,WAAW,EAAE,CAAC;QACxC,IAAI,MAAM,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;YACxB,IAAI,CAAC,mBAAmB,GAAG,qBAAqB,CAAC,IAAI,CAAC,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,CAAC,MAAM,CAAC,OAAO,EAAE,IAAI,CAAC,IAAI,EAAE,EAAE,SAAS,EAAE,SAAS,CAAC,CAAC,SAAS,CAAC;gBACpJ,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,IAAI,EAAE,CAAC;aAC7C,CAAC,CAAC;QACP,CAAC;QAED,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC,CAAC;IAClD,CAAC;IAEO,iBAAiB;QACrB,IAAI,CAAC,sBAAsB,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC;QAC1D,IAAI,CAAC,sBAAsB,GAAG,EAAE,CAAC;QAEjC,MAAM,SAAS,GAAe,EAAE,CAAC;QACjC,KAAK,MAAM,SAAS,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC,UAAU,EAAE,CAAC;YAC/C,MAAM,QAAQ,GAAG,EAAc,CAAC;YAEhC,QAAQ,CAAC,IAAI,GAAG,SAAS,CAAC,MAAM,CAAC,IAAI,IAAI,SAAS,CAAC;YACnD,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAC5B,qBAAqB,CAAC,IAAI,CAAC,SAAS,EAAE,SAAS,EAAE,OAAO,EAAE,SAAS,CAAC,MAAM,CAAC,KAAK,IAAI,SAAS,EAAE,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,SAAS,CAAC;gBAClH,IAAI,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,GAAG,GAAI,CAAC;aACvC,CAAC,CACL,CAAC;YACF,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAC5B,qBAAqB,CAAC,IAAI,CAAC,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,MAAM,CAAC,OAAO,EAAE,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,SAAS,CAAC;gBAC7G,IAAI,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,OAAO,GAAG,GAAI,CAAC;aACzC,CAAC,CACL,CAAC;YAEF,MAAM,UAAU,GAA2B;gBACvC,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE;gBACrB,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE;gBACjB,UAAU,EAAE,IAAI,CAAC,UAAU,EAAE;gBAC7B,eAAe,EAAE,IAAI;aACxB,CAAC;YAEF,IAAI,SAAS,CAAC,iBAAiB,EAAE,CAAC;gBAC9B,UAAU,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC;YACpD,CAAC;YAED,MAAM,OAAO,GAAG,IAAI,CAAC,cAAc,CAAC,8BAA8B,CAAC,SAAS,EAAE,UAAU,EAAE,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC;YAE/G,IAAI,OAAO,SAAS,CAAC,iBAAiB,KAAK,UAAU,EAAE,CAAC;gBACpD,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAC5B,YAAY,CAAC,SAAS,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS,CAAC;oBACzD,IAAI,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,QAAQ,GAAG,CAAC,GAAG,CAAC;iBAC1C,CAAC,CACL,CAAC;YACN,CAAC;YAED,MAAM,qBAAqB,GAA0B,EAAE,CAAC;YACxD,IAAI,OAAO,SAAS,CAAC,iBAAiB,KAAK,UAAU,EAAE,CAAC;gBACpD,qBAAqB,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;YACnF,CAAC;YACD,IAAI,OAAO,SAAS,CAAC,WAAW,KAAK,WAAW,EAAE,CAAC;gBAC/C,qBAAqB,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC,SAAS,CAAC,WAAW,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC,QAAQ,EAAE,OAAoD,CAAC,CAAC,CAAC;YACnK,CAAC;YAED,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC,QAAQ,CAAC,IAA0B,CAAC;YACnE,IAAI,SAAS,CAAC,iBAAiB,IAAI,SAAS,CAAC,oBAAoB,IAAI,SAAS,CAAC,oBAAoB,CAAC,SAAS,CAAC,iBAAiB,CAAC,EAAE,CAAC;gBAC/H,MAAM,gBAAgB,GAAG,SAAS,CAAC,oBAAoB,CAAC,SAAS,CAAC,iBAAiB,CAAC,CAAC;gBACrF,qBAAqB,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC,gBAAgB,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC,QAAQ,EAAE,OAAoD,CAAC,CAAC,CAAC;YAC9J,CAAC;YAED,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAC5B,aAAa,CAAC,qBAAqB,CAAC,CAAC,SAAS,CAAC,YAAY,CAAC,EAAE;gBAC1D,QAAQ,CAAC,OAAO,GAAG,YAAY,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC;YAC1D,CAAC,CAAC,CACL,CAAC;YAEF,QAAQ,CAAC,OAAO,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC;YAEvD,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC7B,CAAC;QACD,OAAO,SAAS,CAAC;IACrB,CAAC;8GA1SQ,eAAe;kGAAf,eAAe,ynDAJb,CAAC,qBAAqB,EAAE,CAAC,0EAsBF,IAAI,gEChF1C,ynHAgFA,sFDvByB,YAAY,sKAAE,YAAY,6FAAE,aAAa,iXAAE,eAAe,uDAAE,kBAAkB,gLAAE,iBAAiB,unBAAE,UAAU;;2FAKzH,eAAe;kBAX3B,SAAS;iCACM,IAAI,YACN,YAAY,mBAGL,uBAAuB,CAAC,MAAM,WACtC,CAAC,SAAS,EAAE,YAAY,EAAE,YAAY,EAAE,aAAa,EAAE,eAAe,EAAE,kBAAkB,EAAE,iBAAiB,EAAE,UAAU,CAAC,aACxH,CAAC,qBAAqB,EAAE,CAAC,QAE9B,EAAC,SAAS,EAAE,aAAa,EAAE,aAAa,EAAE,gBAAgB,EAAC;;0BA2E5D,QAAQ","sourcesContent":["import {AsyncPipe} from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    DestroyRef,\n    OnDestroy,\n    Optional,\n    OutputRefSubscription,\n    booleanAttribute,\n    computed,\n    effect,\n    inject,\n    input,\n    output,\n    signal,\n    viewChild\n} from '@angular/core';\nimport {toSignal} from '@angular/core/rxjs-interop';\nimport {ActivatedRoute} from '@angular/router';\n\nimport {TranslateService} from '@ngx-translate/core';\nimport {MenuItem} from 'primeng/api';\nimport {ButtonModule} from 'primeng/button';\nimport {Menu, MenuModule} from 'primeng/menu';\nimport {RippleModule} from 'primeng/ripple';\nimport {SplitButtonModule} from 'primeng/splitbutton';\nimport {TooltipModule} from 'primeng/tooltip';\nimport {Observable, Subscription, combineLatest} from 'rxjs';\n\nimport {\n    APermissions,\n    ActionData,\n    ActionParameters,\n    ComponentDirective,\n    DataListParams,\n    IDataProvider,\n    IdType,\n    ParametrizePipe,\n    PermissionService,\n    Permissions,\n    toObservable\n} from '@mediusinc/mng-commons/core';\nimport {ActionContextValidation, ActionDescriptorInst, ActionLinkDescriptorInst, ActionTypeEnum, IActionComponent, TableviewRouteData} from '@mediusinc/mng-commons/tableview/api';\n\nimport {getI18nForActionAsync} from '../../helpers/i18n';\nimport {ActionInstanceStateEnum} from '../../models/execution/action-instance-state.model';\nimport {ActionInstance} from '../../models/execution/action-instance.model';\nimport {ActionExecutorService} from '../../services/action-executor.service';\nimport {provideActionExecutor} from '../../services/providers/provide-action-executor';\nimport {ViewContainer} from '../../services/view-container.service';\n\n@Component({\n    standalone: true,\n    selector: 'mng-action',\n    templateUrl: './action.component.html',\n    styleUrls: ['./action.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    imports: [AsyncPipe, ButtonModule, RippleModule, TooltipModule, ParametrizePipe, ComponentDirective, SplitButtonModule, MenuModule],\n    providers: [provideActionExecutor()],\n    // eslint-disable-next-line @angular-eslint/no-host-metadata-property\n    host: {'[class]': 'hostClass()', '[class.m-0]': 'isHostHidden()'}\n})\nexport class ActionComponent<Item = any, Service = undefined> implements OnDestroy {\n    private readonly destroyRef = inject(DestroyRef);\n\n    // metadata and editor mode input\n    public action = input.required<ActionDescriptorInst<Item, Service>>();\n    public item = input<Item>();\n    public itemId = input<IdType>();\n    public actionData = input<ActionData>();\n    public dataListParams = input<DataListParams>();\n    public dataProvider = input<IDataProvider<Item, Service>>();\n    public hostComponent = input<any>();\n    public routeInit = input<ActivatedRoute | undefined>(undefined, {alias: 'route'});\n    public inputDisabled = input<boolean, unknown>(false, {alias: 'disabled', transform: booleanAttribute});\n    public inputLoading = input<boolean, unknown>(false, {alias: 'loading', transform: booleanAttribute});\n    public selectedItems = input<Array<Item>>([]);\n\n    public finish = output<ActionInstance<Item, Service>>();\n\n    public subactionsMenu = viewChild(Menu);\n\n    public hostClass = computed(() => this.action().className ?? 'mng-action-button');\n    public isHostHidden = computed(() => !this.isVisible() || !this.isPermitted());\n\n    public loading = signal(false);\n\n    private isVisibleSubscription?: Subscription;\n    public isVisible = signal(true);\n    private isPermittedSubscription?: Subscription;\n    public isPermitted = signal(true);\n    private isEnabledSubscription?: Subscription;\n    public isEnabled = signal(true);\n    private labelSubscription?: Subscription;\n    public label = signal<string>('');\n    private tooltipSubscription?: Subscription;\n    public tooltip = signal<string>('');\n\n    public actionLink = computed<ActionLinkDescriptorInst<Item> | undefined>(() => {\n        const action = this.action();\n        return action instanceof ActionLinkDescriptorInst ? action : undefined;\n    });\n\n    public hasNoTitle = computed(() => this.action().button.label === null);\n\n    private resultSubscription?: Subscription;\n    private errorSubscription?: Subscription;\n    private stateSubscription?: Subscription;\n    private cmpInstSubscription?: OutputRefSubscription;\n\n    public route = computed<ActivatedRoute>(() => this.routeInit() ?? this.routeService);\n    public routeData = toSignal(this.route().data);\n    private routePermissions = computed<APermissions | undefined>(() => {\n        const routeData = this.routeData();\n        const action = this.action();\n        if (action.tableviewCategory && routeData && routeData['tableviewPermissions']) {\n            const tableviewPermissions = routeData['tableviewPermissions'];\n            if (tableviewPermissions[action.tableviewCategory]) {\n                return tableviewPermissions[action.tableviewCategory];\n            }\n        }\n        return undefined;\n    });\n\n    public buttonClass = computed<string>(() => this.action().button.styleClass.build(this.hasNoTitle()));\n    public subactions = signal<MenuItem[]>([]);\n    private subactionSubscriptions: Subscription[] = [];\n\n    private instance?: ActionInstance<Item, Service>;\n\n    constructor(\n        private routeService: ActivatedRoute,\n        private translate: TranslateService,\n        private authorization: PermissionService,\n        private actionExecutor: ActionExecutorService,\n        @Optional() private viewContainer: ViewContainer<Item, Service> | null\n    ) {\n        effect(() => this.processSubscriptions(), {allowSignalWrites: true});\n    }\n\n    ngOnDestroy(): void {\n        this.actionExecutor.onActionDestroy(this.instance);\n        this.isVisibleSubscription?.unsubscribe();\n        this.isPermittedSubscription?.unsubscribe();\n        this.isEnabledSubscription?.unsubscribe();\n        this.labelSubscription?.unsubscribe();\n        this.tooltipSubscription?.unsubscribe();\n        this.resultSubscription?.unsubscribe();\n        this.errorSubscription?.unsubscribe();\n        this.stateSubscription?.unsubscribe();\n        this.cmpInstSubscription?.unsubscribe();\n        this.subactionSubscriptions.forEach(s => s.unsubscribe());\n    }\n\n    public triggerAction(action: ActionDescriptorInst<Item, Service>, parameters?: ActionParameters<Item>, event?: Event) {\n        if (action.subactionsAsMenu) {\n            this.subactionsMenu()?.toggle(event ?? new Event('trigger'));\n            return;\n        }\n\n        const actionData = this.actionData() ? this.actionData() : {};\n\n        parameters ??= {\n            itemId: this.itemId(),\n            item: this.item(),\n            actionData: actionData,\n            dataListParams: this.dataListParams(),\n            route: this.route(),\n            sourceComponent: this,\n            hostComponent: this.hostComponent(),\n            selectedItems: this.selectedItems()\n        };\n\n        const instance = this.actionExecutor.triggerAction<Item, Service>(action, parameters);\n        this.instance = instance;\n        const context = instance.context;\n        if (!context) {\n            // no context is provided if routing is triggered or editor is opened via dialog\n            // it is in another component jurisdiction to handle contexts\n            return;\n        }\n\n        this.resultSubscription?.unsubscribe();\n        this.resultSubscription = instance.result$.subscribe({\n            next: () => {\n                this.finish.emit(instance);\n                if (action.hasItemsSelection) {\n                    this.viewContainer?.reloadTable({data: {event: event}});\n                }\n            }\n        });\n\n        this.errorSubscription?.unsubscribe();\n        this.errorSubscription = instance.error$.subscribe({\n            next: () => {\n                this.finish.emit(instance);\n            }\n        });\n\n        this.stateSubscription?.unsubscribe();\n        this.stateSubscription = this.instance.state$.subscribe(s => {\n            switch (s) {\n                case ActionInstanceStateEnum.RunStart:\n                    this.loading.set(true);\n                    break;\n                case ActionInstanceStateEnum.RunEnd:\n                case ActionInstanceStateEnum.RunError:\n                    this.loading.set(false);\n                    break;\n                case ActionInstanceStateEnum.NextActionStart:\n                    if (this.instance?.nextActionInstance?.action.type === ActionTypeEnum.Direct) {\n                        this.loading.set(true);\n                    }\n                    break;\n                case ActionInstanceStateEnum.NextActionEnd:\n                    if (this.instance?.nextActionInstance?.action.type === ActionTypeEnum.Direct) {\n                        this.loading.set(false);\n                    }\n                    break;\n                case ActionInstanceStateEnum.ErrorActionStart:\n                    if (this.instance?.errorActionInstance?.action.type === ActionTypeEnum.Direct) {\n                        this.loading.set(true);\n                    }\n                    break;\n                case ActionInstanceStateEnum.ErrorActionEnd:\n                    if (this.instance?.errorActionInstance?.action.type === ActionTypeEnum.Direct) {\n                        this.loading.set(false);\n                    }\n                    break;\n            }\n        });\n\n        this.actionExecutor.run(context);\n    }\n\n    public onCustomActionCmpInst(instance: IActionComponent<Item>) {\n        this.cmpInstSubscription?.unsubscribe();\n        this.cmpInstSubscription = instance.trigger.subscribe(params => this.triggerAction(this.action(), params));\n    }\n\n    private processSubscriptions() {\n        const parameters: ActionParameters<Item> = {\n            itemId: this.itemId(),\n            item: this.item(),\n            actionData: this.actionData(),\n            sourceComponent: this\n        };\n        const action = this.action();\n        if (action.hasItemsSelection) {\n            parameters.selectedItems = this.selectedItems();\n        }\n\n        const context = this.actionExecutor.prepareActionContextValidation(action, parameters, this.dataProvider());\n\n        if (typeof action.isVisibleFunction === 'function') {\n            this.isVisibleSubscription?.unsubscribe();\n            this.isVisibleSubscription = toObservable(action.isVisibleFunction(context)).subscribe({\n                next: res => this.isVisible.set(res)\n            });\n        }\n\n        const routePermissions = this.routePermissions();\n\n        if (typeof action.permissions !== 'undefined' || typeof routePermissions !== 'undefined') {\n            this.isPermittedSubscription?.unsubscribe();\n            const permissions = action.permissions && routePermissions ? Permissions.All.of(routePermissions, action.permissions) : routePermissions ?? action.permissions!;\n            this.isVisibleSubscription = this.authorization.isPermitted(permissions, this.route().snapshot, context as ActionContextValidation<unknown, unknown>).subscribe({\n                next: res => this.isPermitted.set(res)\n            });\n        }\n        if (typeof action.isEnabledFunction === 'function') {\n            this.isEnabledSubscription?.unsubscribe();\n            this.isEnabledSubscription = toObservable(action.isEnabledFunction(context)).subscribe({\n                next: res => this.isEnabled.set(res)\n            });\n        }\n\n        if (!this.hasNoTitle()) {\n            this.labelSubscription?.unsubscribe();\n            this.labelSubscription = getI18nForActionAsync(this.translate, action, 'title', action.button.label ?? undefined, this.item()).subscribe({\n                next: i18n => this.label.set(i18n ?? '')\n            });\n        }\n\n        this.tooltipSubscription?.unsubscribe();\n        if (action.button.tooltip) {\n            this.tooltipSubscription = getI18nForActionAsync(this.translate, action, 'tooltip', action.button.tooltip, this.item(), undefined, undefined).subscribe({\n                next: i18n => this.tooltip.set(i18n ?? '')\n            });\n        }\n\n        this.subactions.set(this.processSubactions());\n    }\n\n    private processSubactions(): MenuItem[] {\n        this.subactionSubscriptions.forEach(s => s.unsubscribe());\n        this.subactionSubscriptions = [];\n\n        const menuItems: MenuItem[] = [];\n        for (const subaction of this.action().subactions) {\n            const menuItem = {} as MenuItem;\n\n            menuItem.icon = subaction.button.icon ?? undefined;\n            this.subactionSubscriptions.push(\n                getI18nForActionAsync(this.translate, subaction, 'title', subaction.button.label ?? undefined, this.item()).subscribe({\n                    next: res => (menuItem.label = res!)\n                })\n            );\n            this.subactionSubscriptions.push(\n                getI18nForActionAsync(this.translate, subaction, 'tooltip', this.action().button.tooltip, this.item()).subscribe({\n                    next: res => (menuItem.tooltip = res!)\n                })\n            );\n\n            const parameters: ActionParameters<Item> = {\n                itemId: this.itemId(),\n                item: this.item(),\n                actionData: this.actionData(),\n                sourceComponent: this\n            };\n\n            if (subaction.hasItemsSelection) {\n                parameters.selectedItems = this.selectedItems();\n            }\n\n            const context = this.actionExecutor.prepareActionContextValidation(subaction, parameters, this.dataProvider());\n\n            if (typeof subaction.isEnabledFunction === 'function') {\n                this.subactionSubscriptions.push(\n                    toObservable(subaction.isEnabledFunction(context)).subscribe({\n                        next: res => (menuItem.disabled = !res)\n                    })\n                );\n            }\n\n            const visibilityObservables: Observable<boolean>[] = [];\n            if (typeof subaction.isVisibleFunction === 'function') {\n                visibilityObservables.push(toObservable(subaction.isVisibleFunction(context)));\n            }\n            if (typeof subaction.permissions !== 'undefined') {\n                visibilityObservables.push(this.authorization.isPermitted(subaction.permissions, this.route().snapshot, context as ActionContextValidation<unknown, unknown>));\n            }\n\n            const routeData = this.route().snapshot.data as TableviewRouteData;\n            if (subaction.tableviewCategory && routeData.tableviewPermissions && routeData.tableviewPermissions[subaction.tableviewCategory]) {\n                const routePermissions = routeData.tableviewPermissions[subaction.tableviewCategory];\n                visibilityObservables.push(this.authorization.isPermitted(routePermissions, this.route().snapshot, context as ActionContextValidation<unknown, unknown>));\n            }\n\n            this.subactionSubscriptions.push(\n                combineLatest(visibilityObservables).subscribe(visibilities => {\n                    menuItem.visible = visibilities.every(value => value);\n                })\n            );\n\n            menuItem.command = () => this.triggerAction(subaction);\n\n            menuItems.push(menuItem);\n        }\n        return menuItems;\n    }\n}\n","@if (isVisible() && isPermitted()) {\n    @if(actionLink(); as actionLink) {\n        @if(actionLink.url !== '') {\n            <a\n                pButton\n                pRipple\n                [label]=\"label()\"\n                [icon]=\"$any(action().button.icon)\"\n                [iconPos]=\"action().button.iconPosition\"\n                [href]=\"!isEnabled() || inputDisabled() ? null : (actionLink.url | mngParametrize: itemId() : item() : actionData())\"\n                [target]=\"actionLink.target\"\n                [class.disabled]=\"!isEnabled() || inputDisabled()\"\n                [pTooltip]=\"tooltip()\"\n                [tooltipPosition]=\"action().button.tooltipPosition ?? undefined\"\n                [class]=\"buttonClass()\"></a>\n        } @else {\n            <a\n                pButton\n                pRipple\n                [icon]=\"$any(action().button.icon)\"\n                [iconPos]=\"action().button.iconPosition\"\n                [label]=\"label()\"\n                [target]=\"actionLink.target\"\n                [replaceUrl]=\"actionLink.replaceUrl\"\n                [routerLink]=\"!isEnabled() || inputDisabled() ? null : (actionLink.pathSegments | mngParametrize: itemId() : item() : actionData())\"\n                [relativeTo]=\"route()\"\n                [queryParams]=\"actionLink.queryParams | mngParametrize: itemId() : item() : actionData()\"\n                [queryParamsHandling]=\"actionLink.queryParamsHandling\"\n                [class.disabled]=\"!isEnabled() || inputDisabled()\"\n                [pTooltip]=\"tooltip()\"\n                [tooltipPosition]=\"action().button.tooltipPosition ?? undefined\"\n                [class]=\"buttonClass()\"></a>\n        }\n    }\n    @else if (action().component || action().componentFromDi) {\n            <ng-container\n                [mngComponent]=\"action().component\"\n                [injectionToken]=\"action().componentFromDi\"\n                [inputs]=\"{\n                action: action(),\n                item: item(),\n                itemId: itemId(),\n                actionData: actionData(),\n                enabled: isEnabled(),\n                loading: loading()\n            }\"\n                (instanceCreated)=\"onCustomActionCmpInst($event)\">\n            </ng-container>\n        }\n\n     @else if (action().subactions.length > 0 && !action().subactionsAsMenu) {\n        <p-splitButton\n            [icon]=\"action().button.icon ?? undefined\"\n            [iconPos]=\"action().button.iconPosition\"\n            [label]=\"label()\"\n            [pTooltip]=\"tooltip()\"\n            [tooltipPosition]=\"action().button.tooltipPosition ?? undefined\"\n            [disabled]=\"!isEnabled() || inputDisabled()\"\n            (onClick)=\"triggerAction(action())\"\n            [class]=\"buttonClass()\"\n            [model]=\"subactions()\">\n        </p-splitButton>\n    } @else {\n        <button\n            pButton\n            pRipple\n            type=\"button\"\n            [icon]=\"$any(action().button.icon)\"\n            [iconPos]=\"action().button.iconPosition\"\n            [label]=\"label()\"\n            [pTooltip]=\"tooltip()\"\n            [tooltipPosition]=\"action().button.tooltipPosition ?? undefined\"\n            [loading]=\"loading() || inputLoading()\"\n            loadingIcon=\"pi pi-spin pi-spinner\"\n            [disabled]=\"!isEnabled() || inputDisabled()\"\n            (click)=\"triggerAction(action(), undefined, $event)\"\n            [class]=\"buttonClass()\"></button>\n        <p-menu #subactionsMenu [model]=\"subactions()\" [popup]=\"true\" appendTo=\"body\" styleClass=\"mng-action-menu\"></p-menu>\n    }\n}\n"]}
|