@mediusinc/mng-commons 1.3.0-1c14fa2b → 1.5.0-rc.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/assets/i18n/en.json +9 -0
- package/assets/i18n/sl.json +9 -0
- package/esm2020/lib/components/action/action.component.mjs +68 -16
- package/esm2020/lib/components/form/formly/fields/formly-field-lookup-dialog/formly-field-lookup-dialog.component.mjs +6 -1
- package/esm2020/lib/components/form/formly/fields/formly-field-table-dialog-form/formly-field-table-dialog-form.component.mjs +21 -2
- package/esm2020/lib/components/form/formly/fields/formly-field-table-dialog-multiselect/formly-field-table-dialog-multiselect.component.mjs +6 -1
- package/esm2020/lib/components/tableview/route/tableview-route.abstract.component.mjs +31 -6
- package/esm2020/lib/components/tableview/table/table.component.mjs +3 -3
- package/esm2020/lib/descriptors/action.descriptor.mjs +18 -1
- package/esm2020/lib/descriptors/table.descriptor.mjs +16 -1
- package/esm2020/lib/mng-commons.module.mjs +15 -5
- package/esm2020/lib/services/action-executor.service.mjs +5 -2
- package/esm2020/lib/services/commons.service.mjs +6 -4
- package/esm2020/lib/types/i18n.type.mjs +2 -0
- package/esm2020/lib/types/index.mjs +2 -1
- package/esm2020/lib/utils/export.util.mjs +20 -0
- package/esm2020/lib/utils/i18n.util.mjs +49 -6
- package/esm2020/lib/utils/index.mjs +2 -1
- package/fesm2015/mediusinc-mng-commons.mjs +248 -33
- package/fesm2015/mediusinc-mng-commons.mjs.map +1 -1
- package/fesm2020/mediusinc-mng-commons.mjs +249 -34
- package/fesm2020/mediusinc-mng-commons.mjs.map +1 -1
- package/lib/components/action/action.component.d.ts +8 -3
- package/lib/components/tableview/route/tableview-route.abstract.component.d.ts +4 -0
- package/lib/descriptors/action.descriptor.d.ts +6 -0
- package/lib/descriptors/table.descriptor.d.ts +5 -0
- package/lib/mng-commons.module.d.ts +16 -14
- package/lib/types/i18n.type.d.ts +1 -0
- package/lib/types/index.d.ts +1 -0
- package/lib/utils/export.util.d.ts +5 -0
- package/lib/utils/i18n.util.d.ts +31 -2
- package/lib/utils/index.d.ts +1 -0
- package/package.json +1 -1
- package/scss/common/theme/designer/_components.scss +4 -4
- package/scss/mng-overrides/_layout_menu.scss +4 -0
- package/version-info.json +6 -6
package/assets/i18n/en.json
CHANGED
|
@@ -140,6 +140,15 @@
|
|
|
140
140
|
"export": {
|
|
141
141
|
"title": "Export"
|
|
142
142
|
},
|
|
143
|
+
"exportJson": {
|
|
144
|
+
"title": "JSON"
|
|
145
|
+
},
|
|
146
|
+
"exportCsv": {
|
|
147
|
+
"title": "CSV"
|
|
148
|
+
},
|
|
149
|
+
"refresh": {
|
|
150
|
+
"title": "Refresh"
|
|
151
|
+
},
|
|
143
152
|
"localization-details": {
|
|
144
153
|
"title": "Translations: {{fieldName}}"
|
|
145
154
|
},
|
package/assets/i18n/sl.json
CHANGED
|
@@ -139,6 +139,15 @@
|
|
|
139
139
|
"export": {
|
|
140
140
|
"title": "Izvozi"
|
|
141
141
|
},
|
|
142
|
+
"exportJson": {
|
|
143
|
+
"title": "JSON"
|
|
144
|
+
},
|
|
145
|
+
"exportCsv": {
|
|
146
|
+
"title": "CSV"
|
|
147
|
+
},
|
|
148
|
+
"refresh": {
|
|
149
|
+
"title": "Osveži"
|
|
150
|
+
},
|
|
142
151
|
"localization-details": {
|
|
143
152
|
"title": "Prevodi: {{fieldName}}"
|
|
144
153
|
},
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, EventEmitter, HostBinding, Input, Optional, Output } from '@angular/core';
|
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, HostBinding, Input, Optional, Output, ViewChild } from '@angular/core';
|
|
2
2
|
import { ConfirmationService } from 'primeng/api';
|
|
3
3
|
import { ReplaySubject, combineLatest, distinctUntilChanged, of } from 'rxjs';
|
|
4
4
|
import { ActionLinkDescriptor } from '../../descriptors';
|
|
@@ -16,8 +16,10 @@ import * as i7 from "primeng/tooltip";
|
|
|
16
16
|
import * as i8 from "primeng/button";
|
|
17
17
|
import * as i9 from "primeng/confirmdialog";
|
|
18
18
|
import * as i10 from "primeng/ripple";
|
|
19
|
-
import * as i11 from "
|
|
20
|
-
import * as i12 from "
|
|
19
|
+
import * as i11 from "primeng/splitbutton";
|
|
20
|
+
import * as i12 from "primeng/slidemenu";
|
|
21
|
+
import * as i13 from "../../directives/component.directive";
|
|
22
|
+
import * as i14 from "../../pipes/parametrize.pipe";
|
|
21
23
|
export class MngActionComponent {
|
|
22
24
|
constructor(routeService, translate, authorization, actionExecutor, confirmationService, viewContainerService) {
|
|
23
25
|
this.routeService = routeService;
|
|
@@ -48,6 +50,8 @@ export class MngActionComponent {
|
|
|
48
50
|
this.hasNoTitle = false;
|
|
49
51
|
this.subscriptions = [];
|
|
50
52
|
this.buttonClass = 'p-button-primary';
|
|
53
|
+
this.subactions = [];
|
|
54
|
+
this.subactionSubscriptions = [];
|
|
51
55
|
this.loadingSubject.next(false);
|
|
52
56
|
}
|
|
53
57
|
ngOnInit() {
|
|
@@ -93,8 +97,13 @@ export class MngActionComponent {
|
|
|
93
97
|
this.labelSubscription?.unsubscribe();
|
|
94
98
|
this.tooltipSubscription?.unsubscribe();
|
|
95
99
|
this.subscriptions.forEach(s => s.unsubscribe());
|
|
100
|
+
this.subactionSubscriptions.forEach(s => s.unsubscribe());
|
|
96
101
|
}
|
|
97
|
-
triggerAction(parameters) {
|
|
102
|
+
triggerAction(action, parameters, event) {
|
|
103
|
+
if (action.subactionsAsMenu) {
|
|
104
|
+
this.subactionsMenu?.toggle(event);
|
|
105
|
+
return;
|
|
106
|
+
}
|
|
98
107
|
const actionData = this.actionData ? this.actionData : {};
|
|
99
108
|
actionData['cmpId'] = this.cmpId;
|
|
100
109
|
parameters ?? (parameters = new ActionParameters(this.itemId, this.item)
|
|
@@ -105,11 +114,11 @@ export class MngActionComponent {
|
|
|
105
114
|
.withSourceComponent(this)
|
|
106
115
|
.withHostComponent(this.hostComponent)
|
|
107
116
|
.withSelectedItems(this.selectedItems));
|
|
108
|
-
const instance = this.actionExecutor.triggerAction(
|
|
117
|
+
const instance = this.actionExecutor.triggerAction(action, parameters);
|
|
109
118
|
this.subscriptions.push(instance.result$.subscribe({
|
|
110
119
|
next: () => {
|
|
111
120
|
this.finishEventEmitter.next(instance);
|
|
112
|
-
if (
|
|
121
|
+
if (action.hasItemsSelection) {
|
|
113
122
|
this.viewContainer?.reloadTable?.({ data: { event: event } });
|
|
114
123
|
}
|
|
115
124
|
}
|
|
@@ -131,6 +140,47 @@ export class MngActionComponent {
|
|
|
131
140
|
getConfirmationServiceInstanceKey(action) {
|
|
132
141
|
return `${action.actionName}_${this.cmpId}`;
|
|
133
142
|
}
|
|
143
|
+
onCustomActionCmpInst(instance) {
|
|
144
|
+
const cmpInstSubscription = instance.triggerActionEventEmitter.subscribe(params => this.triggerAction(this.action, params));
|
|
145
|
+
this.subscriptions.push(cmpInstSubscription);
|
|
146
|
+
}
|
|
147
|
+
processSubactions() {
|
|
148
|
+
this.subactionSubscriptions.forEach(s => s.unsubscribe());
|
|
149
|
+
this.subactionSubscriptions = [];
|
|
150
|
+
const menuItems = [];
|
|
151
|
+
this.action.subactions;
|
|
152
|
+
for (const subaction of this.action.subactions) {
|
|
153
|
+
const menuItem = {};
|
|
154
|
+
menuItem.icon = subaction.button.icon ?? undefined;
|
|
155
|
+
this.subactionSubscriptions.push(I18nUtils.Action.getAsync(this.translate, subaction, 'title', subaction.button.label ?? undefined, this.item).subscribe({
|
|
156
|
+
next: res => (menuItem.label = res)
|
|
157
|
+
}));
|
|
158
|
+
this.subactionSubscriptions.push(I18nUtils.Action.getAsync(this.translate, subaction, 'tooltip', this.action.button.tooltip, this.item).subscribe({
|
|
159
|
+
next: res => (menuItem.tooltip = res)
|
|
160
|
+
}));
|
|
161
|
+
const parameters = new ActionParameters(this.itemId, this.item)
|
|
162
|
+
.withActionData(this.actionData)
|
|
163
|
+
.withViewContainer(this.viewContainer ?? undefined)
|
|
164
|
+
.withSourceComponent(this);
|
|
165
|
+
if (subaction.hasItemsSelection) {
|
|
166
|
+
parameters.withSelectedItems(this.selectedItems);
|
|
167
|
+
}
|
|
168
|
+
const context = this.actionExecutor.prepareActionContextValidation(subaction, parameters, this.dataProvider);
|
|
169
|
+
if (typeof subaction.isEnabledFunction === 'function') {
|
|
170
|
+
this.subactionSubscriptions.push(subaction.isEnabledFunction(context).subscribe({
|
|
171
|
+
next: res => (menuItem.disabled = !res)
|
|
172
|
+
}));
|
|
173
|
+
}
|
|
174
|
+
if (typeof subaction.isVisibleFunction === 'function') {
|
|
175
|
+
this.subactionSubscriptions.push(subaction.isVisibleFunction(context).subscribe({
|
|
176
|
+
next: res => (menuItem.visible = res)
|
|
177
|
+
}));
|
|
178
|
+
}
|
|
179
|
+
menuItem.command = () => this.triggerAction(subaction);
|
|
180
|
+
menuItems.push(menuItem);
|
|
181
|
+
}
|
|
182
|
+
return menuItems;
|
|
183
|
+
}
|
|
134
184
|
processSubscriptions() {
|
|
135
185
|
const parameters = new ActionParameters(this.itemId, this.item)
|
|
136
186
|
.withActionData(this.actionData)
|
|
@@ -168,20 +218,19 @@ export class MngActionComponent {
|
|
|
168
218
|
});
|
|
169
219
|
}
|
|
170
220
|
this.tooltipSubscription?.unsubscribe();
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
this.subscriptions.push(cmpInstSubscription);
|
|
221
|
+
if (this.action.button.tooltip) {
|
|
222
|
+
this.tooltipSubscription = I18nUtils.Action.getAsync(this.translate, this.action, 'tooltip', this.action.button.tooltip, this.item, undefined, undefined).subscribe({
|
|
223
|
+
next: i18n => this.tooltipSubject.next(i18n)
|
|
224
|
+
});
|
|
225
|
+
}
|
|
226
|
+
this.subactions = this.processSubactions();
|
|
178
227
|
}
|
|
179
228
|
}
|
|
180
229
|
MngActionComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: MngActionComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.TranslateService }, { token: i3.MngAuthorizationService }, { token: i4.MngActionExecutorService }, { token: i5.ConfirmationService }, { token: i4.MngViewContainerComponentService, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
181
|
-
MngActionComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.0", type: MngActionComponent, selector: "mng-action", inputs: { action: "action", item: "item", itemId: "itemId", actionData: "actionData", queryParam: "queryParam", dataProvider: "dataProvider", hostComponent: "hostComponent", routeInit: ["route", "routeInit"], inputDisabled: ["disabled", "inputDisabled"], inputLoading: ["loading", "inputLoading"], viewContainerInit: ["viewContainer", "viewContainerInit"], selectedItems: "selectedItems" }, outputs: { finishEventEmitter: "finish" }, host: { properties: { "class": "this.hostClass", "class.m-0": "this.isHostHidden" } }, providers: [ConfirmationService], usesOnChanges: true, ngImport: i0, template: "<ng-container *ngIf=\"($isVisible | async) && ($isPermitted | async)\">\n <a\n *ngIf=\"actionLink && actionLink.url !== ''; else routerLink\"\n pButton\n pRipple\n [label]=\"($label | async) ?? ''\"\n [icon]=\"$any(action.button.icon)\"\n [href]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false) ? null : (actionLink.url | parametrize: itemId:item:actionData)\"\n [target]=\"actionLink.target\"\n [class.disabled]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false)\"\n [pTooltip]=\"$any($tooltip | async)\"\n [class]=\"buttonClass\"></a>\n <ng-template #routerLink>\n <a\n *ngIf=\"actionLink; else customComponent\"\n pButton\n pRipple\n [icon]=\"$any(action.button.icon)\"\n [label]=\"($label | async) ?? ''\"\n [target]=\"actionLink.target\"\n [replaceUrl]=\"actionLink.replaceUrl\"\n [routerLink]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false) ? null : (actionLink.pathSegments | parametrize: itemId:item:actionData)\"\n [relativeTo]=\"route\"\n [queryParams]=\"actionLink.queryParams | parametrize: itemId:item:actionData\"\n [queryParamsHandling]=\"actionLink.queryParamsHandling\"\n [class.disabled]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false)\"\n [pTooltip]=\"$any($tooltip | async)\"\n [class]=\"buttonClass\"></a>\n </ng-template>\n <ng-template #customComponent>\n <ng-container\n *ngIf=\"action.component; else
|
|
230
|
+
MngActionComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.0", type: MngActionComponent, selector: "mng-action", inputs: { action: "action", item: "item", itemId: "itemId", actionData: "actionData", queryParam: "queryParam", dataProvider: "dataProvider", hostComponent: "hostComponent", routeInit: ["route", "routeInit"], inputDisabled: ["disabled", "inputDisabled"], inputLoading: ["loading", "inputLoading"], viewContainerInit: ["viewContainer", "viewContainerInit"], selectedItems: "selectedItems" }, outputs: { finishEventEmitter: "finish" }, host: { properties: { "class": "this.hostClass", "class.m-0": "this.isHostHidden" } }, providers: [ConfirmationService], viewQueries: [{ propertyName: "subactionsMenu", first: true, predicate: ["subactionsMenu"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<ng-container *ngIf=\"($isVisible | async) && ($isPermitted | async)\">\n <a\n *ngIf=\"actionLink && actionLink.url !== ''; else routerLink\"\n pButton\n pRipple\n [label]=\"($label | async) ?? ''\"\n [icon]=\"$any(action.button.icon)\"\n [href]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false) ? null : (actionLink.url | parametrize: itemId:item:actionData)\"\n [target]=\"actionLink.target\"\n [class.disabled]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false)\"\n [pTooltip]=\"$any($tooltip | async)\"\n [class]=\"buttonClass\"></a>\n <ng-template #routerLink>\n <a\n *ngIf=\"actionLink; else customComponent\"\n pButton\n pRipple\n [icon]=\"$any(action.button.icon)\"\n [label]=\"($label | async) ?? ''\"\n [target]=\"actionLink.target\"\n [replaceUrl]=\"actionLink.replaceUrl\"\n [routerLink]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false) ? null : (actionLink.pathSegments | parametrize: itemId:item:actionData)\"\n [relativeTo]=\"route\"\n [queryParams]=\"actionLink.queryParams | parametrize: itemId:item:actionData\"\n [queryParamsHandling]=\"actionLink.queryParamsHandling\"\n [class.disabled]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false)\"\n [pTooltip]=\"$any($tooltip | async)\"\n [class]=\"buttonClass\"></a>\n </ng-template>\n <ng-template #customComponent>\n <ng-container\n *ngIf=\"action.component; else splitButton\"\n [mngComponent]=\"action.component\"\n [inputs]=\"{\n action: action,\n item: item,\n itemId: itemId,\n actionData: actionData,\n enabled: $isEnabled,\n loading: $loading,\n viewContainer: viewContainer\n }\"\n (instanceCreated)=\"onCustomActionCmpInst($event)\">\n </ng-container>\n </ng-template>\n <ng-template #splitButton>\n <p-splitButton\n *ngIf=\"action.subactions.length > 0 && !action.subactionsAsMenu; else button\"\n [icon]=\"$any(action.button.icon)\"\n [label]=\"($label | async) ?? ''\"\n [pTooltip]=\"$any($tooltip | async)\"\n [disabled]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false)\"\n (onClick)=\"triggerAction(action)\"\n [class]=\"buttonClass\"\n [model]=\"subactions\">\n </p-splitButton>\n </ng-template>\n <ng-template #button>\n <button\n pButton\n pRipple\n type=\"button\"\n [icon]=\"$any(action.button.icon)\"\n [label]=\"($label | async) ?? ''\"\n [pTooltip]=\"$any($tooltip | async)\"\n [loading]=\"(($loading | async) ?? false) || ((inputLoading | async) ?? false)\"\n [disabled]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false)\"\n (click)=\"triggerAction(action, undefined, $event)\"\n [class]=\"buttonClass\"></button>\n <p-slideMenu #subactionsMenu [model]=\"subactions\" [popup]=\"true\" [viewportHeight]=\"100\"></p-slideMenu>\n </ng-template>\n <p-confirmDialog\n *ngIf=\"action.runConfirmationDialogDescriptor\"\n [key]=\"action.actionName + '_' + cmpId\"\n [baseZIndex]=\"50\"\n appendTo=\"body\"\n [closable]=\"action.runConfirmationDialogDescriptor.closable\"></p-confirmDialog>\n</ng-container>\n", styles: [":host{display:inline-block}\n"], dependencies: [{ kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.RouterLinkWithHref, selector: "a[routerLink],area[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "preserveFragment", "skipLocationChange", "replaceUrl", "state", "relativeTo", "routerLink"] }, { kind: "directive", type: i7.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "fitContent", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "directive", type: i8.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { kind: "component", type: i9.ConfirmDialog, selector: "p-confirmDialog", inputs: ["header", "icon", "message", "style", "styleClass", "maskStyleClass", "acceptIcon", "acceptLabel", "acceptAriaLabel", "acceptVisible", "rejectIcon", "rejectLabel", "rejectAriaLabel", "rejectVisible", "acceptButtonStyleClass", "rejectButtonStyleClass", "closeOnEscape", "dismissableMask", "blockScroll", "rtl", "closable", "appendTo", "key", "autoZIndex", "baseZIndex", "transitionOptions", "focusTrap", "defaultFocus", "breakpoints", "visible", "position"], outputs: ["onHide"] }, { kind: "directive", type: i10.Ripple, selector: "[pRipple]" }, { kind: "component", type: i11.SplitButton, selector: "p-splitButton", inputs: ["model", "icon", "iconPos", "label", "style", "styleClass", "menuStyle", "menuStyleClass", "disabled", "tabindex", "appendTo", "dir", "expandAriaLabel", "showTransitionOptions", "hideTransitionOptions"], outputs: ["onClick", "onDropdownClick"] }, { kind: "component", type: i12.SlideMenu, selector: "p-slideMenu", inputs: ["model", "popup", "style", "styleClass", "menuWidth", "viewportHeight", "effectDuration", "easing", "backLabel", "appendTo", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions"], outputs: ["onShow", "onHide"] }, { kind: "directive", type: i13.MngComponentDirective, selector: "[mngComponent]", inputs: ["mngComponent", "inputs"], outputs: ["instanceCreated"] }, { kind: "pipe", type: i6.AsyncPipe, name: "async" }, { kind: "pipe", type: i14.MngParametrizePipe, name: "parametrize" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
182
231
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: MngActionComponent, decorators: [{
|
|
183
232
|
type: Component,
|
|
184
|
-
args: [{ selector: 'mng-action', changeDetection: ChangeDetectionStrategy.OnPush, providers: [ConfirmationService], template: "<ng-container *ngIf=\"($isVisible | async) && ($isPermitted | async)\">\n <a\n *ngIf=\"actionLink && actionLink.url !== ''; else routerLink\"\n pButton\n pRipple\n [label]=\"($label | async) ?? ''\"\n [icon]=\"$any(action.button.icon)\"\n [href]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false) ? null : (actionLink.url | parametrize: itemId:item:actionData)\"\n [target]=\"actionLink.target\"\n [class.disabled]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false)\"\n [pTooltip]=\"$any($tooltip | async)\"\n [class]=\"buttonClass\"></a>\n <ng-template #routerLink>\n <a\n *ngIf=\"actionLink; else customComponent\"\n pButton\n pRipple\n [icon]=\"$any(action.button.icon)\"\n [label]=\"($label | async) ?? ''\"\n [target]=\"actionLink.target\"\n [replaceUrl]=\"actionLink.replaceUrl\"\n [routerLink]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false) ? null : (actionLink.pathSegments | parametrize: itemId:item:actionData)\"\n [relativeTo]=\"route\"\n [queryParams]=\"actionLink.queryParams | parametrize: itemId:item:actionData\"\n [queryParamsHandling]=\"actionLink.queryParamsHandling\"\n [class.disabled]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false)\"\n [pTooltip]=\"$any($tooltip | async)\"\n [class]=\"buttonClass\"></a>\n </ng-template>\n <ng-template #customComponent>\n <ng-container\n *ngIf=\"action.component; else
|
|
233
|
+
args: [{ selector: 'mng-action', changeDetection: ChangeDetectionStrategy.OnPush, providers: [ConfirmationService], template: "<ng-container *ngIf=\"($isVisible | async) && ($isPermitted | async)\">\n <a\n *ngIf=\"actionLink && actionLink.url !== ''; else routerLink\"\n pButton\n pRipple\n [label]=\"($label | async) ?? ''\"\n [icon]=\"$any(action.button.icon)\"\n [href]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false) ? null : (actionLink.url | parametrize: itemId:item:actionData)\"\n [target]=\"actionLink.target\"\n [class.disabled]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false)\"\n [pTooltip]=\"$any($tooltip | async)\"\n [class]=\"buttonClass\"></a>\n <ng-template #routerLink>\n <a\n *ngIf=\"actionLink; else customComponent\"\n pButton\n pRipple\n [icon]=\"$any(action.button.icon)\"\n [label]=\"($label | async) ?? ''\"\n [target]=\"actionLink.target\"\n [replaceUrl]=\"actionLink.replaceUrl\"\n [routerLink]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false) ? null : (actionLink.pathSegments | parametrize: itemId:item:actionData)\"\n [relativeTo]=\"route\"\n [queryParams]=\"actionLink.queryParams | parametrize: itemId:item:actionData\"\n [queryParamsHandling]=\"actionLink.queryParamsHandling\"\n [class.disabled]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false)\"\n [pTooltip]=\"$any($tooltip | async)\"\n [class]=\"buttonClass\"></a>\n </ng-template>\n <ng-template #customComponent>\n <ng-container\n *ngIf=\"action.component; else splitButton\"\n [mngComponent]=\"action.component\"\n [inputs]=\"{\n action: action,\n item: item,\n itemId: itemId,\n actionData: actionData,\n enabled: $isEnabled,\n loading: $loading,\n viewContainer: viewContainer\n }\"\n (instanceCreated)=\"onCustomActionCmpInst($event)\">\n </ng-container>\n </ng-template>\n <ng-template #splitButton>\n <p-splitButton\n *ngIf=\"action.subactions.length > 0 && !action.subactionsAsMenu; else button\"\n [icon]=\"$any(action.button.icon)\"\n [label]=\"($label | async) ?? ''\"\n [pTooltip]=\"$any($tooltip | async)\"\n [disabled]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false)\"\n (onClick)=\"triggerAction(action)\"\n [class]=\"buttonClass\"\n [model]=\"subactions\">\n </p-splitButton>\n </ng-template>\n <ng-template #button>\n <button\n pButton\n pRipple\n type=\"button\"\n [icon]=\"$any(action.button.icon)\"\n [label]=\"($label | async) ?? ''\"\n [pTooltip]=\"$any($tooltip | async)\"\n [loading]=\"(($loading | async) ?? false) || ((inputLoading | async) ?? false)\"\n [disabled]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false)\"\n (click)=\"triggerAction(action, undefined, $event)\"\n [class]=\"buttonClass\"></button>\n <p-slideMenu #subactionsMenu [model]=\"subactions\" [popup]=\"true\" [viewportHeight]=\"100\"></p-slideMenu>\n </ng-template>\n <p-confirmDialog\n *ngIf=\"action.runConfirmationDialogDescriptor\"\n [key]=\"action.actionName + '_' + cmpId\"\n [baseZIndex]=\"50\"\n appendTo=\"body\"\n [closable]=\"action.runConfirmationDialogDescriptor.closable\"></p-confirmDialog>\n</ng-container>\n", styles: [":host{display:inline-block}\n"] }]
|
|
185
234
|
}], ctorParameters: function () { return [{ type: i1.ActivatedRoute }, { type: i2.TranslateService }, { type: i3.MngAuthorizationService }, { type: i4.MngActionExecutorService }, { type: i5.ConfirmationService }, { type: i4.MngViewContainerComponentService, decorators: [{
|
|
186
235
|
type: Optional
|
|
187
236
|
}] }]; }, propDecorators: { hostClass: [{
|
|
@@ -221,5 +270,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.0", ngImpor
|
|
|
221
270
|
}], finishEventEmitter: [{
|
|
222
271
|
type: Output,
|
|
223
272
|
args: ['finish']
|
|
273
|
+
}], subactionsMenu: [{
|
|
274
|
+
type: ViewChild,
|
|
275
|
+
args: ['subactionsMenu']
|
|
224
276
|
}] } });
|
|
225
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"action.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/action/action.component.ts","../../../../../src/lib/components/action/action.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, EventEmitter, HostBinding, Input, OnChanges, OnDestroy, OnInit, Optional, Output, SimpleChanges} from '@angular/core';\nimport {ActivatedRoute} from '@angular/router';\n\nimport {TranslateService} from '@ngx-translate/core';\nimport {ConfirmationService} from 'primeng/api';\nimport {Observable, ReplaySubject, Subscription, combineLatest, distinctUntilChanged, of} from 'rxjs';\n\nimport {MediusQueryParam} from '../../api/models';\nimport {IDataProvider} from '../../data-providers';\nimport {ActionDescriptor, ActionLinkDescriptor} from '../../descriptors';\nimport {IViewContainer, IViewContainerTable} from '../../models';\nimport {MngRouterData} from '../../router/models';\nimport {MngAuthorizationService} from '../../security';\nimport {APermissions, Permissions} from '../../security/model';\nimport {MngActionExecutorService, MngViewContainerComponentService} from '../../services';\nimport {IdType} from '../../types';\nimport {I18nUtils} from '../../utils';\nimport {ActionContextValidation, ActionData, ActionInstance, ActionParameters, IActionConfirmationService} from './models';\nimport {IActionComponent} from './models/action-component.model';\n\n@Component({\n    selector: 'mng-action',\n    templateUrl: './action.component.html',\n    styleUrls: ['./action.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [ConfirmationService]\n})\nexport class MngActionComponent<T, S> implements OnInit, OnChanges, OnDestroy, IActionConfirmationService {\n    @HostBinding('class') hostClass = 'mng-action-button';\n    @HostBinding('class.m-0') isHostHidden = false;\n\n    // metadata and editor mode input\n    @Input() public action!: ActionDescriptor<T>;\n    @Input() public item?: T;\n    @Input() public itemId?: IdType;\n    @Input() public actionData?: ActionData;\n    @Input() public queryParam?: MediusQueryParam;\n    @Input() public dataProvider?: IDataProvider<T, S>;\n    @Input() public hostComponent?: unknown;\n    @Input('route') public routeInit?: ActivatedRoute;\n    @Input('disabled') public inputDisabled: Observable<boolean> = of(false);\n    @Input('loading') public inputLoading: Observable<boolean> = of(false);\n    @Input('viewContainer') public viewContainerInit?: IViewContainer<T, S>;\n    @Input() public selectedItems: Array<T> = [];\n\n    @Output('finish') public finishEventEmitter = new EventEmitter<ActionInstance<T, S>>();\n\n    private loadingSubject = new ReplaySubject<boolean>(1);\n    public $loading: Observable<boolean> = this.loadingSubject.asObservable();\n\n    public cmpId: string = Math.random().toString(36).substring(2);\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 viewContainer?: IViewContainer<T, S>;\n\n    public actionLink?: ActionLinkDescriptor<T>;\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\n    constructor(\n        private routeService: ActivatedRoute,\n        private translate: TranslateService,\n        private authorization: MngAuthorizationService,\n        private actionExecutor: MngActionExecutorService,\n        private confirmationService: ConfirmationService,\n        @Optional() private viewContainerService: MngViewContainerComponentService<T, S> | null\n    ) {\n        this.loadingSubject.next(false);\n    }\n\n    public ngOnInit() {\n        this.viewContainer = this.viewContainerInit ?? this.viewContainerService ?? undefined;\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 MngRouterData;\n        if (this.action instanceof ActionLinkDescriptor) {\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\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\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.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    }\n\n    public triggerAction(parameters?: ActionParameters<T>) {\n        const actionData = this.actionData ? this.actionData : {};\n        actionData['cmpId'] = this.cmpId;\n\n        parameters ??= new ActionParameters(this.itemId, this.item)\n            .withActionData(actionData)\n            .withQueryParam(this.queryParam)\n            .withRoute(this.route)\n            .withViewContainer(this.viewContainer)\n            .withSourceComponent(this)\n            .withHostComponent(this.hostComponent)\n            .withSelectedItems(this.selectedItems);\n\n        const instance = this.actionExecutor.triggerAction(this.action, parameters);\n\n        this.subscriptions.push(\n            instance.result$.subscribe({\n                next: () => {\n                    this.finishEventEmitter.next(instance);\n                    if (this.action.hasItemsSelection) {\n                        (this.viewContainer as IViewContainerTable<T, S>)?.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        this.subscriptions.push(\n            instance.isRunLoading$.subscribe({\n                next: res => {\n                    this.loadingSubject.next(res);\n                }\n            })\n        );\n    }\n\n    public getConfirmationService() {\n        return this.confirmationService;\n    }\n\n    public getConfirmationServiceInstanceKey(action: ActionDescriptor<any>) {\n        return `${action.actionName}_${this.cmpId}`;\n    }\n\n    private processSubscriptions() {\n        const parameters = new ActionParameters(this.itemId, this.item)\n            .withActionData(this.actionData)\n            .withViewContainer(this.viewContainer ?? undefined)\n            .withSourceComponent(this);\n\n        if (this.action.hasItemsSelection) {\n            parameters.withSelectedItems(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 = 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 = 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 = I18nUtils.Action.getAsync(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        this.tooltipSubscription = I18nUtils.Action.getAsync(this.translate, this.action, 'tooltip', this.action.button.tooltip, this.item).subscribe({\n            next: i18n => this.tooltipSubject.next(i18n)\n        });\n    }\n\n    public onCustomActionCmpInst(instance: IActionComponent<T>) {\n        const cmpInstSubscription = instance.triggerActionEventEmitter.subscribe(params => this.triggerAction(params));\n        this.subscriptions.push(cmpInstSubscription);\n    }\n}\n","<ng-container *ngIf=\"($isVisible | async) && ($isPermitted | async)\">\n    <a\n        *ngIf=\"actionLink && actionLink.url !== ''; else routerLink\"\n        pButton\n        pRipple\n        [label]=\"($label | async) ?? ''\"\n        [icon]=\"$any(action.button.icon)\"\n        [href]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false) ? null : (actionLink.url | parametrize: itemId:item:actionData)\"\n        [target]=\"actionLink.target\"\n        [class.disabled]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false)\"\n        [pTooltip]=\"$any($tooltip | async)\"\n        [class]=\"buttonClass\"></a>\n    <ng-template #routerLink>\n        <a\n            *ngIf=\"actionLink; else customComponent\"\n            pButton\n            pRipple\n            [icon]=\"$any(action.button.icon)\"\n            [label]=\"($label | async) ?? ''\"\n            [target]=\"actionLink.target\"\n            [replaceUrl]=\"actionLink.replaceUrl\"\n            [routerLink]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false) ? null : (actionLink.pathSegments | parametrize: itemId:item:actionData)\"\n            [relativeTo]=\"route\"\n            [queryParams]=\"actionLink.queryParams | parametrize: itemId:item:actionData\"\n            [queryParamsHandling]=\"actionLink.queryParamsHandling\"\n            [class.disabled]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false)\"\n            [pTooltip]=\"$any($tooltip | async)\"\n            [class]=\"buttonClass\"></a>\n    </ng-template>\n    <ng-template #customComponent>\n        <ng-container\n            *ngIf=\"action.component; else button\"\n            [mngComponent]=\"action.component\"\n            [inputs]=\"{\n                action: action,\n                item: item,\n                itemId: itemId,\n                actionData: actionData,\n                enabled: $isEnabled,\n                loading: $loading,\n                viewContainer: viewContainer\n            }\"\n            (instanceCreated)=\"onCustomActionCmpInst($event)\">\n        </ng-container>\n    </ng-template>\n    <ng-template #button>\n        <button\n            type=\"button\"\n            pButton\n            pRipple\n            [icon]=\"$any(action.button.icon)\"\n            [label]=\"($label | async) ?? ''\"\n            [pTooltip]=\"$any($tooltip | async)\"\n            [loading]=\"(($loading | async) ?? false) || ((inputLoading | async) ?? false)\"\n            [disabled]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false)\"\n            (click)=\"triggerAction()\"\n            [class]=\"buttonClass\"></button>\n    </ng-template>\n    <p-confirmDialog\n        *ngIf=\"action.runConfirmationDialogDescriptor\"\n        [key]=\"action.actionName + '_' + cmpId\"\n        [baseZIndex]=\"50\"\n        appendTo=\"body\"\n        [closable]=\"action.runConfirmationDialogDescriptor.closable\"></p-confirmDialog>\n</ng-container>\n"]}
|
|
277
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"action.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/action/action.component.ts","../../../../../src/lib/components/action/action.component.html"],"names":[],"mappings":"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","sourcesContent":["import {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 {ConfirmationService, MenuItem} from 'primeng/api';\nimport {SlideMenu} from 'primeng/slidemenu';\nimport {Observable, ReplaySubject, Subscription, combineLatest, distinctUntilChanged, of} from 'rxjs';\n\nimport {MediusQueryParam} from '../../api/models';\nimport {IDataProvider} from '../../data-providers';\nimport {ActionDescriptor, ActionLinkDescriptor} from '../../descriptors';\nimport {IViewContainer, IViewContainerTable} from '../../models';\nimport {MngRouterData} from '../../router/models';\nimport {MngAuthorizationService} from '../../security';\nimport {APermissions, Permissions} from '../../security/model';\nimport {MngActionExecutorService, MngViewContainerComponentService} from '../../services';\nimport {IdType} from '../../types';\nimport {I18nUtils} from '../../utils';\nimport {ActionContextValidation, ActionData, ActionInstance, ActionParameters, IActionConfirmationService} from './models';\nimport {IActionComponent} from './models/action-component.model';\n\n@Component({\n    selector: 'mng-action',\n    templateUrl: './action.component.html',\n    styleUrls: ['./action.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [ConfirmationService]\n})\nexport class MngActionComponent<T, S> implements OnInit, OnChanges, OnDestroy, IActionConfirmationService {\n    @HostBinding('class') hostClass = 'mng-action-button';\n    @HostBinding('class.m-0') isHostHidden = false;\n\n    // metadata and editor mode input\n    @Input() public action!: ActionDescriptor<T>;\n    @Input() public item?: T;\n    @Input() public itemId?: IdType;\n    @Input() public actionData?: ActionData;\n    @Input() public queryParam?: MediusQueryParam;\n    @Input() public dataProvider?: IDataProvider<T, S>;\n    @Input() public hostComponent?: unknown;\n    @Input('route') public routeInit?: ActivatedRoute;\n    @Input('disabled') public inputDisabled: Observable<boolean> = of(false);\n    @Input('loading') public inputLoading: Observable<boolean> = of(false);\n    @Input('viewContainer') public viewContainerInit?: IViewContainer<T, S>;\n    @Input() public selectedItems: Array<T> = [];\n\n    @Output('finish') public finishEventEmitter = new EventEmitter<ActionInstance<T, S>>();\n\n    @ViewChild('subactionsMenu') public subactionsMenu?: SlideMenu;\n\n    private loadingSubject = new ReplaySubject<boolean>(1);\n    public $loading: Observable<boolean> = this.loadingSubject.asObservable();\n\n    public cmpId: string = Math.random().toString(36).substring(2);\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 viewContainer?: IViewContainer<T, S>;\n\n    public actionLink?: ActionLinkDescriptor<T>;\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\n    constructor(\n        private routeService: ActivatedRoute,\n        private translate: TranslateService,\n        private authorization: MngAuthorizationService,\n        private actionExecutor: MngActionExecutorService,\n        private confirmationService: ConfirmationService,\n        @Optional() private viewContainerService: MngViewContainerComponentService<T, S> | null\n    ) {\n        this.loadingSubject.next(false);\n    }\n\n    public ngOnInit() {\n        this.viewContainer = this.viewContainerInit ?? this.viewContainerService ?? undefined;\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 MngRouterData;\n        if (this.action instanceof ActionLinkDescriptor) {\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\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.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: ActionDescriptor<T>, parameters?: ActionParameters<T>, event?: Event) {\n        if (action.subactionsAsMenu) {\n            this.subactionsMenu?.toggle(event);\n            return;\n        }\n\n        const actionData = this.actionData ? this.actionData : {};\n        actionData['cmpId'] = this.cmpId;\n\n        parameters ??= new ActionParameters(this.itemId, this.item)\n            .withActionData(actionData)\n            .withQueryParam(this.queryParam)\n            .withRoute(this.route)\n            .withViewContainer(this.viewContainer)\n            .withSourceComponent(this)\n            .withHostComponent(this.hostComponent)\n            .withSelectedItems(this.selectedItems);\n\n        const instance = this.actionExecutor.triggerAction(action, parameters);\n\n        this.subscriptions.push(\n            instance.result$.subscribe({\n                next: () => {\n                    this.finishEventEmitter.next(instance);\n                    if (action.hasItemsSelection) {\n                        (this.viewContainer as IViewContainerTable<T, S>)?.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        this.subscriptions.push(\n            instance.isRunLoading$.subscribe({\n                next: res => {\n                    this.loadingSubject.next(res);\n                }\n            })\n        );\n    }\n\n    public getConfirmationService() {\n        return this.confirmationService;\n    }\n\n    public getConfirmationServiceInstanceKey(action: ActionDescriptor<any>) {\n        return `${action.actionName}_${this.cmpId}`;\n    }\n\n    public onCustomActionCmpInst(instance: IActionComponent<T>) {\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        this.action.subactions;\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                I18nUtils.Action.getAsync(this.translate, subaction, 'title', subaction.button.label ?? undefined, this.item).subscribe({\n                    next: res => (menuItem.label = res!)\n                })\n            );\n            this.subactionSubscriptions.push(\n                I18nUtils.Action.getAsync(this.translate, subaction, 'tooltip', this.action.button.tooltip, this.item).subscribe({\n                    next: res => (menuItem.tooltip = res!)\n                })\n            );\n\n            const parameters = new ActionParameters(this.itemId, this.item)\n                .withActionData(this.actionData)\n                .withViewContainer(this.viewContainer ?? undefined)\n                .withSourceComponent(this);\n\n            if (subaction.hasItemsSelection) {\n                parameters.withSelectedItems(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                    subaction.isEnabledFunction(context).subscribe({\n                        next: res => (menuItem.disabled = !res)\n                    })\n                );\n            }\n            if (typeof subaction.isVisibleFunction === 'function') {\n                this.subactionSubscriptions.push(\n                    subaction.isVisibleFunction(context).subscribe({\n                        next: res => (menuItem.visible = res)\n                    })\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 = new ActionParameters(this.itemId, this.item)\n            .withActionData(this.actionData)\n            .withViewContainer(this.viewContainer ?? undefined)\n            .withSourceComponent(this);\n\n        if (this.action.hasItemsSelection) {\n            parameters.withSelectedItems(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 = 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 = 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 = I18nUtils.Action.getAsync(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 = I18nUtils.Action.getAsync(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","<ng-container *ngIf=\"($isVisible | async) && ($isPermitted | async)\">\n    <a\n        *ngIf=\"actionLink && actionLink.url !== ''; else routerLink\"\n        pButton\n        pRipple\n        [label]=\"($label | async) ?? ''\"\n        [icon]=\"$any(action.button.icon)\"\n        [href]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false) ? null : (actionLink.url | parametrize: itemId:item:actionData)\"\n        [target]=\"actionLink.target\"\n        [class.disabled]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false)\"\n        [pTooltip]=\"$any($tooltip | async)\"\n        [class]=\"buttonClass\"></a>\n    <ng-template #routerLink>\n        <a\n            *ngIf=\"actionLink; else customComponent\"\n            pButton\n            pRipple\n            [icon]=\"$any(action.button.icon)\"\n            [label]=\"($label | async) ?? ''\"\n            [target]=\"actionLink.target\"\n            [replaceUrl]=\"actionLink.replaceUrl\"\n            [routerLink]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false) ? null : (actionLink.pathSegments | parametrize: itemId:item:actionData)\"\n            [relativeTo]=\"route\"\n            [queryParams]=\"actionLink.queryParams | parametrize: itemId:item:actionData\"\n            [queryParamsHandling]=\"actionLink.queryParamsHandling\"\n            [class.disabled]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false)\"\n            [pTooltip]=\"$any($tooltip | async)\"\n            [class]=\"buttonClass\"></a>\n    </ng-template>\n    <ng-template #customComponent>\n        <ng-container\n            *ngIf=\"action.component; else splitButton\"\n            [mngComponent]=\"action.component\"\n            [inputs]=\"{\n                action: action,\n                item: item,\n                itemId: itemId,\n                actionData: actionData,\n                enabled: $isEnabled,\n                loading: $loading,\n                viewContainer: viewContainer\n            }\"\n            (instanceCreated)=\"onCustomActionCmpInst($event)\">\n        </ng-container>\n    </ng-template>\n    <ng-template #splitButton>\n        <p-splitButton\n            *ngIf=\"action.subactions.length > 0 && !action.subactionsAsMenu; else button\"\n            [icon]=\"$any(action.button.icon)\"\n            [label]=\"($label | async) ?? ''\"\n            [pTooltip]=\"$any($tooltip | async)\"\n            [disabled]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false)\"\n            (onClick)=\"triggerAction(action)\"\n            [class]=\"buttonClass\"\n            [model]=\"subactions\">\n        </p-splitButton>\n    </ng-template>\n    <ng-template #button>\n        <button\n            pButton\n            pRipple\n            type=\"button\"\n            [icon]=\"$any(action.button.icon)\"\n            [label]=\"($label | async) ?? ''\"\n            [pTooltip]=\"$any($tooltip | async)\"\n            [loading]=\"(($loading | async) ?? false) || ((inputLoading | async) ?? false)\"\n            [disabled]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false)\"\n            (click)=\"triggerAction(action, undefined, $event)\"\n            [class]=\"buttonClass\"></button>\n        <p-slideMenu #subactionsMenu [model]=\"subactions\" [popup]=\"true\" [viewportHeight]=\"100\"></p-slideMenu>\n    </ng-template>\n    <p-confirmDialog\n        *ngIf=\"action.runConfirmationDialogDescriptor\"\n        [key]=\"action.actionName + '_' + cmpId\"\n        [baseZIndex]=\"50\"\n        appendTo=\"body\"\n        [closable]=\"action.runConfirmationDialogDescriptor.closable\"></p-confirmDialog>\n</ng-container>\n"]}
|
|
@@ -113,6 +113,7 @@ export class MngFormlyFieldLookupDialogComponent extends FieldType {
|
|
|
113
113
|
}
|
|
114
114
|
this.dialogSelectedItem = null;
|
|
115
115
|
this.isDialogVisible = true;
|
|
116
|
+
this.formControl.markAsTouched();
|
|
116
117
|
this.descriptor.nextEvent(MngFormFieldEventTypeEnum.DialogLifecycle, MngFormlyFieldLookupDialogComponent, this, {
|
|
117
118
|
eventSubtype: MngFormFieldEventDialogSubtype.VISIBILITY,
|
|
118
119
|
dialogVisible: true
|
|
@@ -135,6 +136,8 @@ export class MngFormlyFieldLookupDialogComponent extends FieldType {
|
|
|
135
136
|
}
|
|
136
137
|
clear() {
|
|
137
138
|
this.formControl.setValue(undefined);
|
|
139
|
+
this.formControl.markAsTouched();
|
|
140
|
+
this.formControl.markAsDirty();
|
|
138
141
|
this.dialogSelectedItem = null;
|
|
139
142
|
this.dialogAreItemsLoaded = false;
|
|
140
143
|
this.hideDialog();
|
|
@@ -148,6 +151,8 @@ export class MngFormlyFieldLookupDialogComponent extends FieldType {
|
|
|
148
151
|
}
|
|
149
152
|
addItem() {
|
|
150
153
|
this.formControl.setValue(this.dialogSelectedItem);
|
|
154
|
+
this.formControl.markAsDirty();
|
|
155
|
+
this.formControl.markAsTouched();
|
|
151
156
|
this.dialogSelectedItem = null;
|
|
152
157
|
this.dialogAreItemsLoaded = false;
|
|
153
158
|
this.hideDialog();
|
|
@@ -178,4 +183,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.0", ngImpor
|
|
|
178
183
|
type: ViewChild,
|
|
179
184
|
args: [MngTableComponent]
|
|
180
185
|
}] } });
|
|
181
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"formly-field-lookup-dialog.component.js","sourceRoot":"","sources":["../../../../../../../../src/lib/components/form/formly/fields/formly-field-lookup-dialog/formly-field-lookup-dialog.component.ts","../../../../../../../../src/lib/components/form/formly/fields/formly-field-lookup-dialog/formly-field-lookup-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, ChangeDetectionStrategy, Component, Injector, OnDestroy, OnInit, ViewChild} from '@angular/core';\nimport {FormControl} from '@angular/forms';\n\nimport {FieldType} from '@ngx-formly/core';\nimport {Message} from 'primeng/api';\nimport {Observable, ReplaySubject, Subject, Subscription, distinctUntilChanged} from 'rxjs';\nimport {startWith} from 'rxjs/operators';\n\nimport {MediusQueryParamBuilder, MediusQueryResult} from '../../../../../api/models';\nimport {FieldLookupDescriptor} from '../../../../../descriptors';\nimport {FieldLookupConfig} from '../../../../../descriptors/interfaces';\nimport {MngTableComponent} from '../../../../tableview';\nimport {MngFormFieldEventComponentSubtype, MngFormFieldEventDialogSubtype, MngFormFieldEventTypeEnum} from '../../../models';\nimport {MngFormlyFieldConfig} from '../../models';\n\n@Component({\n    selector: 'mng-formly-field-lookup-dialog',\n    templateUrl: 'formly-field-lookup-dialog.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class MngFormlyFieldLookupDialogComponent<T, ET> extends FieldType<MngFormlyFieldConfig> implements OnInit, AfterViewInit, OnDestroy {\n    @ViewChild(MngTableComponent) public mngTable?: MngTableComponent<any, any>;\n\n    public descriptor!: FieldLookupDescriptor<T, ET>;\n    public config!: FieldLookupConfig;\n    public fieldLabelFormControl: FormControl = new FormControl();\n\n    public itemsSubject: Subject<T> = new ReplaySubject(1);\n    public itemsAsync: Observable<T> = this.itemsSubject.asObservable();\n    public addItemsSubject: Subject<MediusQueryResult<T>> = new ReplaySubject(1);\n    public addItemsAsync: Observable<MediusQueryResult<T>> = this.addItemsSubject.asObservable();\n\n    public dialogUseDataProvider = false;\n    private dialogDataProviderService: any = null;\n    private dialogIsLoadingSubject = new ReplaySubject<boolean>(1);\n\n    public isDialogVisible = false;\n    public dialogAreItemsLoaded = false;\n    public dialogSelectedItem: any = null;\n    public dialogMessages: Message[] = [];\n    public dialogIsLoading$ = this.dialogIsLoadingSubject.asObservable();\n\n    private lookupDataProviderSubscription?: Subscription;\n    private subscriptions: Subscription[] = [];\n\n    constructor(private injector: Injector) {\n        super();\n    }\n\n    ngOnInit(): void {\n        this.descriptor = this.props.descriptor as FieldLookupDescriptor<T, ET>;\n        this.props.fieldComponent = this;\n\n        // emit lifecycle event\n        this.descriptor.nextEvent(MngFormFieldEventTypeEnum.ComponentLifecycle, MngFormlyFieldLookupDialogComponent, this, {\n            eventSubtype: MngFormFieldEventComponentSubtype.ON_INIT\n        });\n\n        this.config = this.descriptor.config as FieldLookupConfig;\n        if (!this.descriptor.dialogTableDataProvider && this.descriptor.dataProvider?.serviceType) {\n            this.dialogUseDataProvider = true;\n            this.dialogDataProviderService = this.injector.get<any>(this.descriptor.dataProvider.serviceType);\n        }\n\n        // init values\n        this.setFieldLabelValue(this.formControl!.value);\n        const subscription = this.formControl!.valueChanges.pipe(\n            startWith(this.formControl!.value),\n            distinctUntilChanged((prev, curr) => {\n                const compareProp = this.descriptor.dialogTableDescriptor!.dataKeyProperty ?? this.descriptor.dialogTableDescriptor!.model.idPropertyName;\n                if (compareProp && typeof prev === 'object' && typeof curr === 'object') {\n                    return prev[compareProp] === curr[compareProp];\n                } else {\n                    return prev === curr;\n                }\n            })\n        ).subscribe(v => {\n            this.setFieldLabelValue(v);\n            this.itemsSubject.next(v);\n            this.descriptor.nextEvent(MngFormFieldEventTypeEnum.ValueChange, MngFormlyFieldLookupDialogComponent, this, {\n                value: v\n            });\n        });\n        this.subscriptions.push(subscription);\n    }\n\n    ngAfterViewInit() {\n        this.descriptor.nextEvent(MngFormFieldEventTypeEnum.ComponentLifecycle, MngFormlyFieldLookupDialogComponent, this, {\n            eventSubtype: MngFormFieldEventComponentSubtype.ON_VIEW_INIT\n        });\n    }\n\n    ngOnDestroy(): void {\n        // warning: formly calls on destroy before on init\n\n        this.lookupDataProviderSubscription?.unsubscribe();\n        this.subscriptions.forEach(s => s.unsubscribe());\n\n        // emit lifecycle event\n        this.descriptor?.nextEvent(MngFormFieldEventTypeEnum.ComponentLifecycle, MngFormlyFieldLookupDialogComponent, this, {\n            eventSubtype: MngFormFieldEventComponentSubtype.ON_DESTROY\n        });\n    }\n\n    openSelectDialog() {\n        if (!this.dialogAreItemsLoaded && this.dialogUseDataProvider) {\n            this.dialogIsLoadingSubject.next(true);\n            const queryParamBuilder = MediusQueryParamBuilder.create(50);\n            if (this.descriptor.dialogTableDescriptor!.hasDefaultSort) {\n                this.descriptor.dialogTableDescriptor!.defaultSortProperty.forEach((p, idx) =>\n                    queryParamBuilder.withSort(p, this.descriptor.dialogTableDescriptor!.defaultSortAsc[idx])\n                );\n            }\n            this.lookupDataProviderSubscription = this.descriptor.dataProvider?.lookup(queryParamBuilder.build(), this.dialogDataProviderService).subscribe({\n                next: res => {\n                    const mqr = new MediusQueryResult<T>();\n                    mqr.pageData = res;\n                    mqr.allDataCount = res.length;\n                    this.addItemsSubject.next(mqr);\n                    this.dialogAreItemsLoaded = true;\n                    this.dialogIsLoadingSubject.next(false);\n\n                    this.descriptor.nextEvent(MngFormFieldEventTypeEnum.DataProvider, MngFormlyFieldLookupDialogComponent, this, {\n                        eventSubtype: 'LookupNext',\n                        queryResult: mqr\n                    });\n                },\n                error: err => {\n                    this.dialogIsLoadingSubject.next(false);\n                    this.descriptor.nextEvent(MngFormFieldEventTypeEnum.DataProvider, MngFormlyFieldLookupDialogComponent, this, {\n                        eventSubtype: 'LookupError',\n                        queryResult: err\n                    });\n                }\n            });\n        }\n        this.dialogSelectedItem = null;\n        this.isDialogVisible = true;\n\n        this.descriptor.nextEvent(MngFormFieldEventTypeEnum.DialogLifecycle, MngFormlyFieldLookupDialogComponent, this, {\n            eventSubtype: MngFormFieldEventDialogSubtype.VISIBILITY,\n            dialogVisible: true\n        });\n    }\n\n    onSelectionChange(item: any) {\n        this.dialogSelectedItem = item;\n    }\n\n    onCaptionCmpInst(instance: any) {\n        this.descriptor.nextEvent(MngFormFieldEventTypeEnum.DialogLifecycle, MngFormlyFieldLookupDialogComponent, this, {\n            eventSubtype: MngFormFieldEventDialogSubtype.TABLE_CAPTION_COMPONENT_INSTANCE,\n            captionComponentInstance: instance\n        });\n    }\n\n    onColumnActionCmpInst(instance: any) {\n        this.descriptor.nextEvent(MngFormFieldEventTypeEnum.DialogLifecycle, MngFormlyFieldLookupDialogComponent, this, {\n            eventSubtype: MngFormFieldEventDialogSubtype.TABLE_COLUMN_ACTIONS_COMPONENT_INSTANCE,\n            captionComponentInstance: instance\n        });\n    }\n\n    clear() {\n        this.formControl!.setValue(undefined);\n        this.dialogSelectedItem = null;\n        this.dialogAreItemsLoaded = false;\n        this.hideDialog();\n    }\n\n    hideDialog() {\n        this.isDialogVisible = false;\n\n        this.descriptor.nextEvent(MngFormFieldEventTypeEnum.DialogLifecycle, MngFormlyFieldLookupDialogComponent, this, {\n            eventSubtype: MngFormFieldEventDialogSubtype.VISIBILITY,\n            dialogVisible: false\n        });\n    }\n\n    addItem() {\n        this.formControl!.setValue(this.dialogSelectedItem);\n        this.dialogSelectedItem = null;\n        this.dialogAreItemsLoaded = false;\n        this.hideDialog();\n    }\n\n    private setFieldLabelValue(value: T) {\n        if (!value) {\n            this.fieldLabelFormControl.setValue('');\n            return;\n        }\n        if (typeof value === 'object') {\n            const labelProperty = this.descriptor.itemsLabelProperty ?? this.descriptor.dialogTableDescriptor?.model.titlePropertyName;\n            if (!labelProperty) {\n                throw new Error('Could not determine label property.');\n            }\n            this.fieldLabelFormControl.setValue(value[labelProperty as keyof object]);\n        } else {\n            this.fieldLabelFormControl.setValue(value);\n        }\n    }\n}\n","<div [class]=\"'p-inputgroup mng-dropdown-dialog' + descriptor.inputClassName\" [class.p-inputtext-sm]=\"descriptor.isSizeSmall\" [class.p-inputtext-lg]=\"descriptor.isSizeLarge\">\n    <input pInputText type=\"text\" [id]=\"$any(key)\" [readonly]=\"true\" [formlyAttributes]=\"field\" [formControl]=\"fieldLabelFormControl\" />\n    <i class=\"mng-dropdown-clear-icon pi pi-times\" (click)=\"clear()\" *ngIf=\"!props.required && formControl?.value && !formControl?.disabled\"></i>\n    <button\n        pButton\n        pRipple\n        class=\"mng-dropdown-dialog-search-button\"\n        type=\"button\"\n        [label]=\"'general.search' | translate: {item: ''}\"\n        [disabled]=\"formControl?.disabled\"\n        (click)=\"openSelectDialog()\"></button>\n</div>\n\n<p-dialog\n    [(visible)]=\"isDialogVisible\"\n    [draggable]=\"false\"\n    [header]=\"'general.search' | translate: {item: props?.label!}\"\n    [modal]=\"true\"\n    appendTo=\"body\"\n    styleClass=\"p-fluid mng-dialog mng-formly-field-lookup-dialog\">\n    <ng-template pTemplate=\"content\">\n        <mng-table\n            [descriptor]=\"descriptor.dialogTableDescriptor!\"\n            [dataProvider]=\"descriptor.dialogTableDataProvider\"\n            [queryResult]=\"addItemsAsync\"\n            [selectionEnabled]=\"true\"\n            [selectionMode]=\"'single'\"\n            [loading]=\"dialogIsLoading$\"\n            [captionComponent]=\"config?.table?.captionComponent\"\n            [columnActionComponent]=\"config?.table?.columnActionComponent\"\n            (selectionChange)=\"onSelectionChange($event)\"\n            (captionComponentInstance)=\"onCaptionCmpInst($event)\"\n            (columnActionComponentInstance)=\"onColumnActionCmpInst($event)\">\n        </mng-table>\n        <p-messages [value]=\"dialogMessages\"></p-messages>\n    </ng-template>\n\n    <ng-template pTemplate=\"footer\">\n        <button pButton pRipple type=\"button\" [label]=\"'general.cancel' | translate\" icon=\"pi pi-times\" class=\"p-button-text\" (click)=\"hideDialog()\"></button>\n        <button\n            pButton\n            pRipple\n            type=\"button\"\n            [label]=\"'general.select' | translate\"\n            icon=\"pi pi-check\"\n            class=\"p-button-text\"\n            (click)=\"addItem()\"\n            [loading]=\"(dialogIsLoading$ | async) ?? false\"\n            [disabled]=\"form.disabled\"></button>\n    </ng-template>\n</p-dialog>\n"]}
|
|
186
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"formly-field-lookup-dialog.component.js","sourceRoot":"","sources":["../../../../../../../../src/lib/components/form/formly/fields/formly-field-lookup-dialog/formly-field-lookup-dialog.component.ts","../../../../../../../../src/lib/components/form/formly/fields/formly-field-lookup-dialog/formly-field-lookup-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, ChangeDetectionStrategy, Component, Injector, OnDestroy, OnInit, ViewChild} from '@angular/core';\nimport {FormControl} from '@angular/forms';\n\nimport {FieldType} from '@ngx-formly/core';\nimport {Message} from 'primeng/api';\nimport {Observable, ReplaySubject, Subject, Subscription, distinctUntilChanged} from 'rxjs';\nimport {startWith} from 'rxjs/operators';\n\nimport {MediusQueryParamBuilder, MediusQueryResult} from '../../../../../api/models';\nimport {FieldLookupDescriptor} from '../../../../../descriptors';\nimport {FieldLookupConfig} from '../../../../../descriptors/interfaces';\nimport {MngTableComponent} from '../../../../tableview';\nimport {MngFormFieldEventComponentSubtype, MngFormFieldEventDialogSubtype, MngFormFieldEventTypeEnum} from '../../../models';\nimport {MngFormlyFieldConfig} from '../../models';\n\n@Component({\n    selector: 'mng-formly-field-lookup-dialog',\n    templateUrl: 'formly-field-lookup-dialog.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class MngFormlyFieldLookupDialogComponent<T, ET> extends FieldType<MngFormlyFieldConfig> implements OnInit, AfterViewInit, OnDestroy {\n    @ViewChild(MngTableComponent) public mngTable?: MngTableComponent<any, any>;\n\n    public descriptor!: FieldLookupDescriptor<T, ET>;\n    public config!: FieldLookupConfig;\n    public fieldLabelFormControl: FormControl = new FormControl();\n\n    public itemsSubject: Subject<T> = new ReplaySubject(1);\n    public itemsAsync: Observable<T> = this.itemsSubject.asObservable();\n    public addItemsSubject: Subject<MediusQueryResult<T>> = new ReplaySubject(1);\n    public addItemsAsync: Observable<MediusQueryResult<T>> = this.addItemsSubject.asObservable();\n\n    public dialogUseDataProvider = false;\n    private dialogDataProviderService: any = null;\n    private dialogIsLoadingSubject = new ReplaySubject<boolean>(1);\n\n    public isDialogVisible = false;\n    public dialogAreItemsLoaded = false;\n    public dialogSelectedItem: any = null;\n    public dialogMessages: Message[] = [];\n    public dialogIsLoading$ = this.dialogIsLoadingSubject.asObservable();\n\n    private lookupDataProviderSubscription?: Subscription;\n    private subscriptions: Subscription[] = [];\n\n    constructor(private injector: Injector) {\n        super();\n    }\n\n    ngOnInit(): void {\n        this.descriptor = this.props.descriptor as FieldLookupDescriptor<T, ET>;\n        this.props.fieldComponent = this;\n\n        // emit lifecycle event\n        this.descriptor.nextEvent(MngFormFieldEventTypeEnum.ComponentLifecycle, MngFormlyFieldLookupDialogComponent, this, {\n            eventSubtype: MngFormFieldEventComponentSubtype.ON_INIT\n        });\n\n        this.config = this.descriptor.config as FieldLookupConfig;\n        if (!this.descriptor.dialogTableDataProvider && this.descriptor.dataProvider?.serviceType) {\n            this.dialogUseDataProvider = true;\n            this.dialogDataProviderService = this.injector.get<any>(this.descriptor.dataProvider.serviceType);\n        }\n\n        // init values\n        this.setFieldLabelValue(this.formControl!.value);\n        const subscription = this.formControl!.valueChanges.pipe(\n            startWith(this.formControl!.value),\n            distinctUntilChanged((prev, curr) => {\n                const compareProp = this.descriptor.dialogTableDescriptor!.dataKeyProperty ?? this.descriptor.dialogTableDescriptor!.model.idPropertyName;\n                if (compareProp && typeof prev === 'object' && typeof curr === 'object') {\n                    return prev[compareProp] === curr[compareProp];\n                } else {\n                    return prev === curr;\n                }\n            })\n        ).subscribe(v => {\n            this.setFieldLabelValue(v);\n            this.itemsSubject.next(v);\n            this.descriptor.nextEvent(MngFormFieldEventTypeEnum.ValueChange, MngFormlyFieldLookupDialogComponent, this, {\n                value: v\n            });\n        });\n        this.subscriptions.push(subscription);\n    }\n\n    ngAfterViewInit() {\n        this.descriptor.nextEvent(MngFormFieldEventTypeEnum.ComponentLifecycle, MngFormlyFieldLookupDialogComponent, this, {\n            eventSubtype: MngFormFieldEventComponentSubtype.ON_VIEW_INIT\n        });\n    }\n\n    ngOnDestroy(): void {\n        // warning: formly calls on destroy before on init\n\n        this.lookupDataProviderSubscription?.unsubscribe();\n        this.subscriptions.forEach(s => s.unsubscribe());\n\n        // emit lifecycle event\n        this.descriptor?.nextEvent(MngFormFieldEventTypeEnum.ComponentLifecycle, MngFormlyFieldLookupDialogComponent, this, {\n            eventSubtype: MngFormFieldEventComponentSubtype.ON_DESTROY\n        });\n    }\n\n    openSelectDialog() {\n        if (!this.dialogAreItemsLoaded && this.dialogUseDataProvider) {\n            this.dialogIsLoadingSubject.next(true);\n            const queryParamBuilder = MediusQueryParamBuilder.create(50);\n            if (this.descriptor.dialogTableDescriptor!.hasDefaultSort) {\n                this.descriptor.dialogTableDescriptor!.defaultSortProperty.forEach((p, idx) =>\n                    queryParamBuilder.withSort(p, this.descriptor.dialogTableDescriptor!.defaultSortAsc[idx])\n                );\n            }\n            this.lookupDataProviderSubscription = this.descriptor.dataProvider?.lookup(queryParamBuilder.build(), this.dialogDataProviderService).subscribe({\n                next: res => {\n                    const mqr = new MediusQueryResult<T>();\n                    mqr.pageData = res;\n                    mqr.allDataCount = res.length;\n                    this.addItemsSubject.next(mqr);\n                    this.dialogAreItemsLoaded = true;\n                    this.dialogIsLoadingSubject.next(false);\n\n                    this.descriptor.nextEvent(MngFormFieldEventTypeEnum.DataProvider, MngFormlyFieldLookupDialogComponent, this, {\n                        eventSubtype: 'LookupNext',\n                        queryResult: mqr\n                    });\n                },\n                error: err => {\n                    this.dialogIsLoadingSubject.next(false);\n                    this.descriptor.nextEvent(MngFormFieldEventTypeEnum.DataProvider, MngFormlyFieldLookupDialogComponent, this, {\n                        eventSubtype: 'LookupError',\n                        queryResult: err\n                    });\n                }\n            });\n        }\n        this.dialogSelectedItem = null;\n        this.isDialogVisible = true;\n\n        this.formControl.markAsTouched();\n\n        this.descriptor.nextEvent(MngFormFieldEventTypeEnum.DialogLifecycle, MngFormlyFieldLookupDialogComponent, this, {\n            eventSubtype: MngFormFieldEventDialogSubtype.VISIBILITY,\n            dialogVisible: true\n        });\n    }\n\n    onSelectionChange(item: any) {\n        this.dialogSelectedItem = item;\n    }\n\n    onCaptionCmpInst(instance: any) {\n        this.descriptor.nextEvent(MngFormFieldEventTypeEnum.DialogLifecycle, MngFormlyFieldLookupDialogComponent, this, {\n            eventSubtype: MngFormFieldEventDialogSubtype.TABLE_CAPTION_COMPONENT_INSTANCE,\n            captionComponentInstance: instance\n        });\n    }\n\n    onColumnActionCmpInst(instance: any) {\n        this.descriptor.nextEvent(MngFormFieldEventTypeEnum.DialogLifecycle, MngFormlyFieldLookupDialogComponent, this, {\n            eventSubtype: MngFormFieldEventDialogSubtype.TABLE_COLUMN_ACTIONS_COMPONENT_INSTANCE,\n            captionComponentInstance: instance\n        });\n    }\n\n    clear() {\n        this.formControl.setValue(undefined);\n        this.formControl.markAsTouched();\n        this.formControl.markAsDirty();\n        this.dialogSelectedItem = null;\n        this.dialogAreItemsLoaded = false;\n        this.hideDialog();\n    }\n\n    hideDialog() {\n        this.isDialogVisible = false;\n\n        this.descriptor.nextEvent(MngFormFieldEventTypeEnum.DialogLifecycle, MngFormlyFieldLookupDialogComponent, this, {\n            eventSubtype: MngFormFieldEventDialogSubtype.VISIBILITY,\n            dialogVisible: false\n        });\n    }\n\n    addItem() {\n        this.formControl.setValue(this.dialogSelectedItem);\n        this.formControl.markAsDirty();\n        this.formControl.markAsTouched();\n        this.dialogSelectedItem = null;\n        this.dialogAreItemsLoaded = false;\n        this.hideDialog();\n    }\n\n    private setFieldLabelValue(value: T) {\n        if (!value) {\n            this.fieldLabelFormControl.setValue('');\n            return;\n        }\n        if (typeof value === 'object') {\n            const labelProperty = this.descriptor.itemsLabelProperty ?? this.descriptor.dialogTableDescriptor?.model.titlePropertyName;\n            if (!labelProperty) {\n                throw new Error('Could not determine label property.');\n            }\n            this.fieldLabelFormControl.setValue(value[labelProperty as keyof object]);\n        } else {\n            this.fieldLabelFormControl.setValue(value);\n        }\n    }\n}\n","<div [class]=\"'p-inputgroup mng-dropdown-dialog' + descriptor.inputClassName\" [class.p-inputtext-sm]=\"descriptor.isSizeSmall\" [class.p-inputtext-lg]=\"descriptor.isSizeLarge\">\n    <input pInputText type=\"text\" [id]=\"$any(key)\" [readonly]=\"true\" [formlyAttributes]=\"field\" [formControl]=\"fieldLabelFormControl\" />\n    <i class=\"mng-dropdown-clear-icon pi pi-times\" (click)=\"clear()\" *ngIf=\"!props.required && formControl?.value && !formControl?.disabled\"></i>\n    <button\n        pButton\n        pRipple\n        class=\"mng-dropdown-dialog-search-button\"\n        type=\"button\"\n        [label]=\"'general.search' | translate: {item: ''}\"\n        [disabled]=\"formControl?.disabled\"\n        (click)=\"openSelectDialog()\"></button>\n</div>\n\n<p-dialog\n    [(visible)]=\"isDialogVisible\"\n    [draggable]=\"false\"\n    [header]=\"'general.search' | translate: {item: props?.label!}\"\n    [modal]=\"true\"\n    appendTo=\"body\"\n    styleClass=\"p-fluid mng-dialog mng-formly-field-lookup-dialog\">\n    <ng-template pTemplate=\"content\">\n        <mng-table\n            [descriptor]=\"descriptor.dialogTableDescriptor!\"\n            [dataProvider]=\"descriptor.dialogTableDataProvider\"\n            [queryResult]=\"addItemsAsync\"\n            [selectionEnabled]=\"true\"\n            [selectionMode]=\"'single'\"\n            [loading]=\"dialogIsLoading$\"\n            [captionComponent]=\"config?.table?.captionComponent\"\n            [columnActionComponent]=\"config?.table?.columnActionComponent\"\n            (selectionChange)=\"onSelectionChange($event)\"\n            (captionComponentInstance)=\"onCaptionCmpInst($event)\"\n            (columnActionComponentInstance)=\"onColumnActionCmpInst($event)\">\n        </mng-table>\n        <p-messages [value]=\"dialogMessages\"></p-messages>\n    </ng-template>\n\n    <ng-template pTemplate=\"footer\">\n        <button pButton pRipple type=\"button\" [label]=\"'general.cancel' | translate\" icon=\"pi pi-times\" class=\"p-button-text\" (click)=\"hideDialog()\"></button>\n        <button\n            pButton\n            pRipple\n            type=\"button\"\n            [label]=\"'general.select' | translate\"\n            icon=\"pi pi-check\"\n            class=\"p-button-text\"\n            (click)=\"addItem()\"\n            [loading]=\"(dialogIsLoading$ | async) ?? false\"\n            [disabled]=\"form.disabled\"></button>\n    </ng-template>\n</p-dialog>\n"]}
|