@bizdoc/core 1.11.0 → 1.11.1
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/esm2020/lib/admin/document-trace/document-trace.component.mjs +3 -3
- package/esm2020/lib/admin/document-trace/trace-element.component.mjs +2 -2
- package/esm2020/lib/admin/form/workflow/role-node.component.mjs +5 -4
- package/esm2020/lib/compose/action/action-picker.component.mjs +7 -36
- package/esm2020/lib/compose/action/action.base.mjs +43 -0
- package/esm2020/lib/compose/action/action.pane.dialog.exp.mjs +70 -0
- package/esm2020/lib/compose/trace/flow.component.mjs +5 -4
- package/esm2020/lib/core/configuration.mjs +8 -10
- package/esm2020/lib/core/mailbox.service.mjs +1 -1
- package/esm2020/lib/core/translations.mjs +3 -1
- package/esm2020/lib/cube/matrix/matrix.pane.component.mjs +2 -4
- package/esm2020/lib/cube/matrix/table.component.mjs +3 -3
- package/esm2020/lib/desktop.module.mjs +6 -6
- package/esm2020/lib/routes.desktop.mjs +13 -7
- package/fesm2015/bizdoc-core.mjs +246 -220
- package/fesm2015/bizdoc-core.mjs.map +1 -1
- package/fesm2020/bizdoc-core.mjs +246 -220
- package/fesm2020/bizdoc-core.mjs.map +1 -1
- package/lib/compose/action/action-picker.component.d.ts +4 -6
- package/lib/compose/action/action.base.d.ts +11 -0
- package/lib/compose/action/action.pane.dialog.exp.d.ts +29 -0
- package/lib/core/configuration.d.ts +8 -10
- package/lib/core/translations.d.ts +2 -0
- package/lib/desktop.module.d.ts +2 -2
- package/package.json +1 -1
- package/esm2020/lib/compose/action/action.pane.dialog.mjs +0 -59
- package/lib/compose/action/action.pane.dialog.d.ts +0 -26
@@ -3,6 +3,7 @@ import { Component, Input } from '@angular/core';
|
|
3
3
|
import { queryParams } from '../../core/functions';
|
4
4
|
import { DOCUMENT_MODEL } from '../../core/mailbox.service';
|
5
5
|
import { ActionDialog } from './action.dialog';
|
6
|
+
import { ActionBase } from './action.base';
|
6
7
|
import * as i0 from "@angular/core";
|
7
8
|
import * as i1 from "../../core/session.service";
|
8
9
|
import * as i2 from "../../core/mailbox.service";
|
@@ -16,13 +17,12 @@ import * as i9 from "@angular/common";
|
|
16
17
|
import * as i10 from "../../core/popup/tooltip.directive";
|
17
18
|
import * as i11 from "../../core/pipes/translate.pipe";
|
18
19
|
/** action-picker component*/
|
19
|
-
export class ActionPicker {
|
20
|
-
constructor(model, _session,
|
20
|
+
export class ActionPicker extends ActionBase {
|
21
|
+
constructor(model, _session, mailbox, _dialog, sb) {
|
22
|
+
super(mailbox, sb);
|
21
23
|
this.model = model;
|
22
24
|
this._session = _session;
|
23
|
-
this._mailbox = _mailbox;
|
24
25
|
this._dialog = _dialog;
|
25
|
-
this._sb = _sb;
|
26
26
|
this.working = false;
|
27
27
|
this.workingChange = new EventEmitter();
|
28
28
|
this.actions = [];
|
@@ -54,49 +54,20 @@ export class ActionPicker {
|
|
54
54
|
const params = queryParams(args);
|
55
55
|
this.workingChange.emit(true);
|
56
56
|
this.working = true;
|
57
|
-
|
58
|
-
return this._mailbox.send(id, version, formId, model, action.name, params).
|
57
|
+
return super._ok(action, params).
|
59
58
|
subscribe(() => {
|
60
|
-
this._sb.toast('Sent', number, (action.adjective || action.past || action.title).toLowerCase());
|
61
59
|
this.working = false;
|
62
60
|
this.workingChange.emit(false);
|
63
61
|
}, e => {
|
64
62
|
this.working = false;
|
65
63
|
this.workingChange.emit(false);
|
66
|
-
this._handleError(e, 'SendErr');
|
67
64
|
});
|
68
65
|
}
|
69
66
|
});
|
70
67
|
}
|
71
|
-
_handleError(response, message, ...args) {
|
72
|
-
if (response.constructor.name === 'PositionError')
|
73
|
-
switch (response.code) {
|
74
|
-
case 1:
|
75
|
-
this._sb.error('UserDeniedGeoErr');
|
76
|
-
break;
|
77
|
-
default:
|
78
|
-
this._sb.error('GeoErr');
|
79
|
-
}
|
80
|
-
else
|
81
|
-
switch (response.status) {
|
82
|
-
case 401:
|
83
|
-
break;
|
84
|
-
case 409: // version change
|
85
|
-
{
|
86
|
-
const obj = response.error /* serialized model */;
|
87
|
-
this._sb.error('VersionErr', this.model.number);
|
88
|
-
break;
|
89
|
-
}
|
90
|
-
case 406: // validation exception
|
91
|
-
this._sb.errorString(response.error);
|
92
|
-
break;
|
93
|
-
default:
|
94
|
-
this._sb.error(message, ...args);
|
95
|
-
}
|
96
|
-
}
|
97
68
|
}
|
98
69
|
ActionPicker.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: ActionPicker, deps: [{ token: DOCUMENT_MODEL }, { token: i1.SessionService }, { token: i2.MailboxService }, { token: i3.MatDialog }, { token: i4.PromptService }], target: i0.ɵɵFactoryTarget.Component });
|
99
|
-
ActionPicker.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: ActionPicker, selector: "bizdoc-action-picker", inputs: { working: "working" }, outputs: { workingChange: "workingChange" }, usesOnChanges: true, ngImport: i0, template: "<ng-container *ngIf=\"actions.length\">\r\n <button mat-raised-button color=\"primary\" [attr.data-help]=\"'action-'+actions[0].name\" (click)=\"send(actions[0])\" [disabled]=\"working\">\r\n <span>{{actions[0].title}}</span>\r\n </button>\r\n \r\n <ng-container [ngSwitch]=\"actions.length\">\r\n <button mat-stroked-button [attr.data-help]=\"'action-'+actions[1].name\" *ngSwitchCase=\"2\" [disabled]=\"working\" (click)=\"send(actions[1])\">\r\n <span>{{actions[1].title}}</span>\r\n </button>\r\n <ng-container *ngSwitchDefault>\r\n <button mat-stroked-button data-help=\"send\" [matMenuTriggerFor]=\"actionMenu\" [disabled]=\"working\" [bizdocTooltip]=\"'Send' | translate\">\r\n <span>{{'Actions' | translate}}</span> <mat-icon>arrow_drop_down</mat-icon>\r\n </button>\r\n <!-- action -->\r\n <mat-menu #actionMenu>\r\n <ng-template matMenuContent>\r\n <ng-container *ngFor=\"let a of actions.slice(1); let i = index\">\r\n <mat-divider *ngIf=\"i > 1 && actions[i - 1].group !== a.group\"></mat-divider>\r\n <button mat-menu-item (click)=\"send(a)\">{{a.title}}</button>\r\n </ng-container>\r\n </ng-template>\r\n </mat-menu>\r\n </ng-container>\r\n </ng-container>\r\n</ng-container>\r\n", styles: [":host{display:flex;flex-direction:row}\n"], components: [{ type: i5.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i7.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { type: i8.MatDivider, selector: "mat-divider", inputs: ["vertical", "inset"] }, { type: i7.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }], directives: [{ type: i9.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i9.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i9.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i9.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { type: i7.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { type: i10.TooltipDirective, selector: "[bizdocTooltip]", inputs: ["bizdocTooltip", "bizdocTooltipTemplate", "bizdocTooltipContext", "bizdocTooltipPosition", "bizdocTooltipDuration", "bizdocTooltipDisabled"] }, { type: i7.MatMenuContent, selector: "ng-template[matMenuContent]" }, { type: i9.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "translate": i11.TranslatePipe } });
|
70
|
+
ActionPicker.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: ActionPicker, selector: "bizdoc-action-picker", inputs: { working: "working" }, outputs: { workingChange: "workingChange" }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<ng-container *ngIf=\"actions.length\">\r\n <button mat-raised-button color=\"primary\" [attr.data-help]=\"'action-'+actions[0].name\" (click)=\"send(actions[0])\" [disabled]=\"working\">\r\n <span>{{actions[0].title}}</span>\r\n </button>\r\n \r\n <ng-container [ngSwitch]=\"actions.length\">\r\n <button mat-stroked-button [attr.data-help]=\"'action-'+actions[1].name\" *ngSwitchCase=\"2\" [disabled]=\"working\" (click)=\"send(actions[1])\">\r\n <span>{{actions[1].title}}</span>\r\n </button>\r\n <ng-container *ngSwitchDefault>\r\n <button mat-stroked-button data-help=\"send\" [matMenuTriggerFor]=\"actionMenu\" [disabled]=\"working\" [bizdocTooltip]=\"'Send' | translate\">\r\n <span>{{'Actions' | translate}}</span> <mat-icon>arrow_drop_down</mat-icon>\r\n </button>\r\n <!-- action -->\r\n <mat-menu #actionMenu>\r\n <ng-template matMenuContent>\r\n <ng-container *ngFor=\"let a of actions.slice(1); let i = index\">\r\n <mat-divider *ngIf=\"i > 1 && actions[i - 1].group !== a.group\"></mat-divider>\r\n <button mat-menu-item (click)=\"send(a)\">{{a.title}}</button>\r\n </ng-container>\r\n </ng-template>\r\n </mat-menu>\r\n </ng-container>\r\n </ng-container>\r\n</ng-container>\r\n", styles: [":host{display:flex;flex-direction:row}\n"], components: [{ type: i5.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i7.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { type: i8.MatDivider, selector: "mat-divider", inputs: ["vertical", "inset"] }, { type: i7.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }], directives: [{ type: i9.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i9.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i9.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i9.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { type: i7.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { type: i10.TooltipDirective, selector: "[bizdocTooltip]", inputs: ["bizdocTooltip", "bizdocTooltipTemplate", "bizdocTooltipContext", "bizdocTooltipPosition", "bizdocTooltipDuration", "bizdocTooltipDisabled"] }, { type: i7.MatMenuContent, selector: "ng-template[matMenuContent]" }, { type: i9.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "translate": i11.TranslatePipe } });
|
100
71
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: ActionPicker, decorators: [{
|
101
72
|
type: Component,
|
102
73
|
args: [{ selector: 'bizdoc-action-picker', template: "<ng-container *ngIf=\"actions.length\">\r\n <button mat-raised-button color=\"primary\" [attr.data-help]=\"'action-'+actions[0].name\" (click)=\"send(actions[0])\" [disabled]=\"working\">\r\n <span>{{actions[0].title}}</span>\r\n </button>\r\n \r\n <ng-container [ngSwitch]=\"actions.length\">\r\n <button mat-stroked-button [attr.data-help]=\"'action-'+actions[1].name\" *ngSwitchCase=\"2\" [disabled]=\"working\" (click)=\"send(actions[1])\">\r\n <span>{{actions[1].title}}</span>\r\n </button>\r\n <ng-container *ngSwitchDefault>\r\n <button mat-stroked-button data-help=\"send\" [matMenuTriggerFor]=\"actionMenu\" [disabled]=\"working\" [bizdocTooltip]=\"'Send' | translate\">\r\n <span>{{'Actions' | translate}}</span> <mat-icon>arrow_drop_down</mat-icon>\r\n </button>\r\n <!-- action -->\r\n <mat-menu #actionMenu>\r\n <ng-template matMenuContent>\r\n <ng-container *ngFor=\"let a of actions.slice(1); let i = index\">\r\n <mat-divider *ngIf=\"i > 1 && actions[i - 1].group !== a.group\"></mat-divider>\r\n <button mat-menu-item (click)=\"send(a)\">{{a.title}}</button>\r\n </ng-container>\r\n </ng-template>\r\n </mat-menu>\r\n </ng-container>\r\n </ng-container>\r\n</ng-container>\r\n", styles: [":host{display:flex;flex-direction:row}\n"] }]
|
@@ -108,4 +79,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
|
|
108
79
|
}], workingChange: [{
|
109
80
|
type: Output
|
110
81
|
}] } });
|
111
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"action-picker.component.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/compose/action/action-picker.component.ts","../../../../../../libraries/core/src/lib/compose/action/action-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { HttpErrorResponse } from '@angular/common/http';\r\nimport { AfterViewInit, EventEmitter, Inject, OnChanges, Output, SimpleChanges } from '@angular/core';\r\nimport { Component, Input } from '@angular/core';\r\nimport { MatDialog } from '@angular/material/dialog';\r\nimport { queryParams } from '../../core/functions';\r\nimport { DOCUMENT_MODEL, MailboxService } from '../../core/mailbox.service';\r\nimport { Action, RecipientModel } from '../../core/models';\r\nimport { PromptService } from '../../core/prompt.service';\r\nimport { SessionService } from '../../core/session.service';\r\nimport { ActionDialog, ActionDialogData } from './action.dialog';\r\n\r\n@Component({\r\n  selector: 'bizdoc-action-picker',\r\n  templateUrl: './action-picker.component.html',\r\n  styleUrls: ['./action-picker.component.scss'],\r\n})\r\n/** action-picker component*/\r\nexport class ActionPicker implements OnChanges, AfterViewInit {\r\n  @Input() working = false;\r\n  @Output() readonly workingChange = new EventEmitter<boolean>();\r\n  actions: Action[] = [];\r\n  constructor(\r\n    @Inject(DOCUMENT_MODEL) public model: RecipientModel<any>,\r\n    private _session: SessionService,\r\n    private _mailbox: MailboxService,\r\n    private _dialog: MatDialog,\r\n    private _sb: PromptService\r\n  ) { }\r\n  ngAfterViewInit(): void {\r\n    const btn = (document.querySelector('[data-help=send]') as HTMLButtonElement);\r\n    if (btn) btn.style.display = 'none';\r\n  }\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['model'])\r\n      this.actions = this._session.profile.actions.filter(a => this.model.actions.indexOf(a.name) > -1).\r\n        sort(this._sortActions);\r\n  }\r\n  private _sortActions(a: Action, b: Action) {\r\n    if (a.group && b.group && a.group !== b.group)\r\n      return a.group < b.group ? -1 : 1;\r\n    return 0;\r\n  }\r\n  send(action: Action) {\r\n    this._dialog.open(ActionDialog, {\r\n      data: {\r\n        action: action.name,\r\n        item: this.model\r\n      } as ActionDialogData,\r\n      closeOnNavigation: true\r\n    }).afterClosed().subscribe(args => {\r\n      if (args) {\r\n        const params = queryParams(args);\r\n        this.workingChange.emit(true);\r\n        this.working = true;\r\n        const { id, version, number, model, formId } = this.model;\r\n        return this._mailbox.send(id, version, formId, model, action.name, params).\r\n          subscribe(() => {\r\n            this._sb.toast('Sent', number, (action.adjective || action.past || action.title).toLowerCase());\r\n            this.working = false;\r\n            this.workingChange.emit(false);\r\n          }, e => {\r\n            this.working = false;\r\n            this.workingChange.emit(false);\r\n            this._handleError(e, 'SendErr');\r\n          });\r\n      }\r\n    })\r\n  }\r\n  private _handleError(response: HttpErrorResponse | any, message: string, ...args: string[]) {\r\n    if (response.constructor.name === 'PositionError')\r\n      switch (response.code) {\r\n        case 1:\r\n          this._sb.error('UserDeniedGeoErr');\r\n          break;\r\n        default:\r\n          this._sb.error('GeoErr');\r\n      }\r\n    else\r\n      switch (response.status) {\r\n        case 401:\r\n          break;\r\n        case 409: // version change\r\n          {\r\n            const obj = response.error /* serialized model */ as RecipientModel<any>;\r\n            this._sb.error('VersionErr', this.model.number);\r\n            break;\r\n          }\r\n        case 406: // validation exception\r\n          this._sb.errorString(response.error);\r\n          break;\r\n        default:\r\n          this._sb.error(message, ...args);\r\n      }\r\n  }\r\n}\r\n","<ng-container *ngIf=\"actions.length\">\r\n  <button mat-raised-button color=\"primary\" [attr.data-help]=\"'action-'+actions[0].name\" (click)=\"send(actions[0])\" [disabled]=\"working\">\r\n    <span>{{actions[0].title}}</span>\r\n  </button>\r\n  &nbsp;\r\n  <ng-container [ngSwitch]=\"actions.length\">\r\n    <button mat-stroked-button [attr.data-help]=\"'action-'+actions[1].name\" *ngSwitchCase=\"2\" [disabled]=\"working\" (click)=\"send(actions[1])\">\r\n      <span>{{actions[1].title}}</span>\r\n    </button>\r\n    <ng-container *ngSwitchDefault>\r\n      <button mat-stroked-button data-help=\"send\" [matMenuTriggerFor]=\"actionMenu\" [disabled]=\"working\" [bizdocTooltip]=\"'Send' | translate\">\r\n        <span>{{'Actions' | translate}}</span> <mat-icon>arrow_drop_down</mat-icon>\r\n      </button>\r\n      <!-- action -->\r\n      <mat-menu #actionMenu>\r\n        <ng-template matMenuContent>\r\n          <ng-container *ngFor=\"let a of actions.slice(1); let i = index\">\r\n            <mat-divider *ngIf=\"i > 1 && actions[i - 1].group !== a.group\"></mat-divider>\r\n            <button mat-menu-item (click)=\"send(a)\">{{a.title}}</button>\r\n          </ng-container>\r\n        </ng-template>\r\n      </mat-menu>\r\n    </ng-container>\r\n  </ng-container>\r\n</ng-container>\r\n"]}
|
82
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"action-picker.component.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/compose/action/action-picker.component.ts","../../../../../../libraries/core/src/lib/compose/action/action-picker.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAiB,YAAY,EAAE,MAAM,EAAa,MAAM,EAAiB,MAAM,eAAe,CAAC;AACtG,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAEjD,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AACnD,OAAO,EAAE,cAAc,EAAkB,MAAM,4BAA4B,CAAC;AAG5E,OAAO,EAAE,YAAY,EAAoB,MAAM,iBAAiB,CAAC;AACjE,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;;;;;;;;;;;;;AAQ3C,6BAA6B;AAC7B,MAAM,OAAO,YAAa,SAAQ,UAAU;IAI1C,YACiC,KAA0B,EACjD,QAAwB,EAChC,OAAuB,EACf,OAAkB,EAC1B,EAAiB;QAEjB,KAAK,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;QANY,UAAK,GAAL,KAAK,CAAqB;QACjD,aAAQ,GAAR,QAAQ,CAAgB;QAExB,YAAO,GAAP,OAAO,CAAW;QAPnB,YAAO,GAAG,KAAK,CAAC;QACN,kBAAa,GAAG,IAAI,YAAY,EAAW,CAAC;QAC/D,YAAO,GAAa,EAAE,CAAC;IASvB,CAAC;IACD,eAAe;QACb,MAAM,GAAG,GAAI,QAAQ,CAAC,aAAa,CAAC,kBAAkB,CAAuB,CAAC;QAC9E,IAAI,GAAG;YAAE,GAAG,CAAC,KAAK,CAAC,OAAO,GAAG,MAAM,CAAC;IACtC,CAAC;IACD,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,OAAO,CAAC;YAClB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;gBAC/F,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IAC9B,CAAC;IACO,YAAY,CAAC,CAAS,EAAE,CAAS;QACvC,IAAI,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,KAAK,KAAK,CAAC,CAAC,KAAK;YAC3C,OAAO,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACpC,OAAO,CAAC,CAAC;IACX,CAAC;IACD,IAAI,CAAC,MAAc;QACjB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,YAAY,EAAE;YAC9B,IAAI,EAAE;gBACJ,MAAM,EAAE,MAAM,CAAC,IAAI;gBACnB,IAAI,EAAE,IAAI,CAAC,KAAK;aACG;YACrB,iBAAiB,EAAE,IAAI;SACxB,CAAC,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE;YAChC,IAAI,IAAI,EAAE;gBACR,MAAM,MAAM,GAAG,WAAW,CAAC,IAAI,CAAC,CAAC;gBACjC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBAC9B,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;gBACpB,OAAO,KAAK,CAAC,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC;oBAC9B,SAAS,CAAC,GAAG,EAAE;oBACb,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;oBACrB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBACjC,CAAC,EAAE,CAAC,CAAC,EAAE;oBACL,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;oBACrB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBACjC,CAAC,CAAC,CAAC;aACN;QACH,CAAC,CAAC,CAAA;IACJ,CAAC;;yGAjDU,YAAY,kBAKb,cAAc;6FALb,YAAY,qLCjBzB,iyCAyBA;2FDRa,YAAY;kBANxB,SAAS;+BACE,sBAAsB;;0BAU7B,MAAM;2BAAC,cAAc;0JAJf,OAAO;sBAAf,KAAK;gBACa,aAAa;sBAA/B,MAAM","sourcesContent":["import { AfterViewInit, EventEmitter, Inject, OnChanges, Output, SimpleChanges } from '@angular/core';\r\nimport { Component, Input } from '@angular/core';\r\nimport { MatDialog } from '@angular/material/dialog';\r\nimport { queryParams } from '../../core/functions';\r\nimport { DOCUMENT_MODEL, MailboxService } from '../../core/mailbox.service';\r\nimport { Action, RecipientModel } from '../../core/models';\r\nimport { SessionService } from '../../core/session.service';\r\nimport { ActionDialog, ActionDialogData } from './action.dialog';\r\nimport { ActionBase } from './action.base';\r\nimport { PromptService } from '../../core/prompt.service';\r\n\r\n@Component({\r\n  selector: 'bizdoc-action-picker',\r\n  templateUrl: './action-picker.component.html',\r\n  styleUrls: ['./action-picker.component.scss'],\r\n})\r\n/** action-picker component*/\r\nexport class ActionPicker extends ActionBase implements OnChanges, AfterViewInit {\r\n  @Input() working = false;\r\n  @Output() readonly workingChange = new EventEmitter<boolean>();\r\n  actions: Action[] = [];\r\n  constructor(\r\n    @Inject(DOCUMENT_MODEL) public model: RecipientModel<any>,\r\n    private _session: SessionService,\r\n    mailbox: MailboxService,\r\n    private _dialog: MatDialog,\r\n    sb: PromptService\r\n  ) {\r\n    super(mailbox, sb);\r\n  }\r\n  ngAfterViewInit(): void {\r\n    const btn = (document.querySelector('[data-help=send]') as HTMLButtonElement);\r\n    if (btn) btn.style.display = 'none';\r\n  }\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['model'])\r\n      this.actions = this._session.profile.actions.filter(a => this.model.actions.indexOf(a.name) > -1).\r\n        sort(this._sortActions);\r\n  }\r\n  private _sortActions(a: Action, b: Action) {\r\n    if (a.group && b.group && a.group !== b.group)\r\n      return a.group < b.group ? -1 : 1;\r\n    return 0;\r\n  }\r\n  send(action: Action) {\r\n    this._dialog.open(ActionDialog, {\r\n      data: {\r\n        action: action.name,\r\n        item: this.model\r\n      } as ActionDialogData,\r\n      closeOnNavigation: true\r\n    }).afterClosed().subscribe(args => {\r\n      if (args) {\r\n        const params = queryParams(args);\r\n        this.workingChange.emit(true);\r\n        this.working = true;\r\n        return super._ok(action, params).\r\n          subscribe(() => {\r\n            this.working = false;\r\n            this.workingChange.emit(false);\r\n          }, e => {\r\n            this.working = false;\r\n            this.workingChange.emit(false);\r\n          });\r\n      }\r\n    })\r\n  }\r\n}\r\n","<ng-container *ngIf=\"actions.length\">\r\n  <button mat-raised-button color=\"primary\" [attr.data-help]=\"'action-'+actions[0].name\" (click)=\"send(actions[0])\" [disabled]=\"working\">\r\n    <span>{{actions[0].title}}</span>\r\n  </button>\r\n  &nbsp;\r\n  <ng-container [ngSwitch]=\"actions.length\">\r\n    <button mat-stroked-button [attr.data-help]=\"'action-'+actions[1].name\" *ngSwitchCase=\"2\" [disabled]=\"working\" (click)=\"send(actions[1])\">\r\n      <span>{{actions[1].title}}</span>\r\n    </button>\r\n    <ng-container *ngSwitchDefault>\r\n      <button mat-stroked-button data-help=\"send\" [matMenuTriggerFor]=\"actionMenu\" [disabled]=\"working\" [bizdocTooltip]=\"'Send' | translate\">\r\n        <span>{{'Actions' | translate}}</span> <mat-icon>arrow_drop_down</mat-icon>\r\n      </button>\r\n      <!-- action -->\r\n      <mat-menu #actionMenu>\r\n        <ng-template matMenuContent>\r\n          <ng-container *ngFor=\"let a of actions.slice(1); let i = index\">\r\n            <mat-divider *ngIf=\"i > 1 && actions[i - 1].group !== a.group\"></mat-divider>\r\n            <button mat-menu-item (click)=\"send(a)\">{{a.title}}</button>\r\n          </ng-container>\r\n        </ng-template>\r\n      </mat-menu>\r\n    </ng-container>\r\n  </ng-container>\r\n</ng-container>\r\n"]}
|
@@ -0,0 +1,43 @@
|
|
1
|
+
import { tap } from 'rxjs';
|
2
|
+
export class ActionBase {
|
3
|
+
constructor(_mailbox, _sb) {
|
4
|
+
this._mailbox = _mailbox;
|
5
|
+
this._sb = _sb;
|
6
|
+
}
|
7
|
+
_ok(action, args) {
|
8
|
+
const { id, version, number, model, formId } = this.model;
|
9
|
+
return this._mailbox.send(id, version, formId, model, action.name, args).
|
10
|
+
pipe(tap(() => {
|
11
|
+
this._sb.toast('Sent', number, (action.adjective || action.past || action.title).toLowerCase());
|
12
|
+
}, e => {
|
13
|
+
this._handleError(e, 'SendErr');
|
14
|
+
}));
|
15
|
+
}
|
16
|
+
_handleError(response, message, ...args) {
|
17
|
+
if (response.constructor.name === 'PositionError')
|
18
|
+
switch (response.code) {
|
19
|
+
case 1:
|
20
|
+
this._sb.error('UserDeniedGeoErr');
|
21
|
+
break;
|
22
|
+
default:
|
23
|
+
this._sb.error('GeoErr');
|
24
|
+
}
|
25
|
+
else
|
26
|
+
switch (response.status) {
|
27
|
+
case 401:
|
28
|
+
break;
|
29
|
+
case 409: // version change
|
30
|
+
{
|
31
|
+
const obj = response.error /* serialized model */;
|
32
|
+
this._sb.error('VersionErr', this.model.number);
|
33
|
+
break;
|
34
|
+
}
|
35
|
+
case 406: // validation exception
|
36
|
+
this._sb.errorString(response.error);
|
37
|
+
break;
|
38
|
+
default:
|
39
|
+
this._sb.error(message, ...args);
|
40
|
+
}
|
41
|
+
}
|
42
|
+
}
|
43
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWN0aW9uLmJhc2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJyYXJpZXMvY29yZS9zcmMvbGliL2NvbXBvc2UvYWN0aW9uL2FjdGlvbi5iYXNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxHQUFHLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFLM0IsTUFBTSxPQUFnQixVQUFVO0lBRTVCLFlBQ1ksUUFBd0IsRUFDdEIsR0FBa0I7UUFEcEIsYUFBUSxHQUFSLFFBQVEsQ0FBZ0I7UUFDdEIsUUFBRyxHQUFILEdBQUcsQ0FBZTtJQUM1QixDQUFDO0lBQ0ssR0FBRyxDQUFDLE1BQWMsRUFBRSxJQUFJO1FBQzlCLE1BQU0sRUFBRSxFQUFFLEVBQUUsT0FBTyxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQztRQUMxRCxPQUFPLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLEVBQUUsRUFBRSxPQUFPLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQztZQUNwRSxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsRUFBRTtZQUNWLElBQUksQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLE1BQU0sRUFBRSxNQUFNLEVBQUUsQ0FBQyxNQUFNLENBQUMsU0FBUyxJQUFJLE1BQU0sQ0FBQyxJQUFJLElBQUksTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDLFdBQVcsRUFBRSxDQUFDLENBQUM7UUFDcEcsQ0FBQyxFQUFFLENBQUMsQ0FBQyxFQUFFO1lBQ0gsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDLEVBQUUsU0FBUyxDQUFDLENBQUM7UUFDcEMsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNaLENBQUM7SUFDTyxZQUFZLENBQUMsUUFBaUMsRUFBRSxPQUFlLEVBQUUsR0FBRyxJQUFjO1FBQ3RGLElBQUksUUFBUSxDQUFDLFdBQVcsQ0FBQyxJQUFJLEtBQUssZUFBZTtZQUM3QyxRQUFRLFFBQVEsQ0FBQyxJQUFJLEVBQUU7Z0JBQ25CLEtBQUssQ0FBQztvQkFDRixJQUFJLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO29CQUNuQyxNQUFNO2dCQUNWO29CQUNJLElBQUksQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxDQUFDO2FBQ2hDOztZQUdELFFBQVEsUUFBUSxDQUFDLE1BQU0sRUFBRTtnQkFDckIsS0FBSyxHQUFHO29CQUNKLE1BQU07Z0JBQ1YsS0FBSyxHQUFHLEVBQUUsaUJBQWlCO29CQUN2Qjt3QkFDSSxNQUFNLEdBQUcsR0FBRyxRQUFRLENBQUMsS0FBSyxDQUFDLHNCQUE2QyxDQUFDO3dCQUN6RSxJQUFJLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxZQUFZLEVBQUUsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQzt3QkFDaEQsTUFBTTtxQkFDVDtnQkFDTCxLQUFLLEdBQUcsRUFBRSx1QkFBdUI7b0JBQzdCLElBQUksQ0FBQyxHQUFHLENBQUMsV0FBVyxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsQ0FBQztvQkFDckMsTUFBTTtnQkFDVjtvQkFDSSxJQUFJLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxPQUFPLEVBQUUsR0FBRyxJQUFJLENBQUMsQ0FBQzthQUN4QztJQUNULENBQUM7Q0FDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEh0dHBFcnJvclJlc3BvbnNlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xyXG5pbXBvcnQgeyB0YXAgfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgTWFpbGJveFNlcnZpY2UgfSBmcm9tICcuLi8uLi9jb3JlL21haWxib3guc2VydmljZSc7XHJcbmltcG9ydCB7IEFjdGlvbiwgUmVjaXBpZW50TW9kZWwgfSBmcm9tICcuLi8uLi9jb3JlL21vZGVscyc7XHJcbmltcG9ydCB7IFByb21wdFNlcnZpY2UgfSBmcm9tICcuLi8uLi9jb3JlL3Byb21wdC5zZXJ2aWNlJztcclxuXHJcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBBY3Rpb25CYXNlIHtcclxuICAgIHB1YmxpYyBtb2RlbDogUmVjaXBpZW50TW9kZWw8YW55PjtcclxuICAgIGNvbnN0cnVjdG9yKFxyXG4gICAgICAgIHByaXZhdGUgX21haWxib3g6IE1haWxib3hTZXJ2aWNlLFxyXG4gICAgICAgIHByb3RlY3RlZCBfc2I6IFByb21wdFNlcnZpY2VcclxuICAgICkgeyB9XHJcbiAgICBwcm90ZWN0ZWQgX29rKGFjdGlvbjogQWN0aW9uLCBhcmdzKSB7XHJcbiAgICAgICAgY29uc3QgeyBpZCwgdmVyc2lvbiwgbnVtYmVyLCBtb2RlbCwgZm9ybUlkIH0gPSB0aGlzLm1vZGVsO1xyXG4gICAgICAgIHJldHVybiB0aGlzLl9tYWlsYm94LnNlbmQoaWQsIHZlcnNpb24sIGZvcm1JZCwgbW9kZWwsIGFjdGlvbi5uYW1lLCBhcmdzKS5cclxuICAgICAgICAgICAgcGlwZSh0YXAoKCkgPT4ge1xyXG4gICAgICAgICAgICAgICAgdGhpcy5fc2IudG9hc3QoJ1NlbnQnLCBudW1iZXIsIChhY3Rpb24uYWRqZWN0aXZlIHx8IGFjdGlvbi5wYXN0IHx8IGFjdGlvbi50aXRsZSkudG9Mb3dlckNhc2UoKSk7XHJcbiAgICAgICAgICAgIH0sIGUgPT4ge1xyXG4gICAgICAgICAgICAgICAgdGhpcy5faGFuZGxlRXJyb3IoZSwgJ1NlbmRFcnInKTtcclxuICAgICAgICAgICAgfSkpO1xyXG4gICAgfVxyXG4gICAgcHJpdmF0ZSBfaGFuZGxlRXJyb3IocmVzcG9uc2U6IEh0dHBFcnJvclJlc3BvbnNlIHwgYW55LCBtZXNzYWdlOiBzdHJpbmcsIC4uLmFyZ3M6IHN0cmluZ1tdKSB7XHJcbiAgICAgICAgaWYgKHJlc3BvbnNlLmNvbnN0cnVjdG9yLm5hbWUgPT09ICdQb3NpdGlvbkVycm9yJylcclxuICAgICAgICAgICAgc3dpdGNoIChyZXNwb25zZS5jb2RlKSB7XHJcbiAgICAgICAgICAgICAgICBjYXNlIDE6XHJcbiAgICAgICAgICAgICAgICAgICAgdGhpcy5fc2IuZXJyb3IoJ1VzZXJEZW5pZWRHZW9FcnInKTtcclxuICAgICAgICAgICAgICAgICAgICBicmVhaztcclxuICAgICAgICAgICAgICAgIGRlZmF1bHQ6XHJcbiAgICAgICAgICAgICAgICAgICAgdGhpcy5fc2IuZXJyb3IoJ0dlb0VycicpO1xyXG4gICAgICAgICAgICB9XHJcblxyXG4gICAgICAgIGVsc2VcclxuICAgICAgICAgICAgc3dpdGNoIChyZXNwb25zZS5zdGF0dXMpIHtcclxuICAgICAgICAgICAgICAgIGNhc2UgNDAxOlxyXG4gICAgICAgICAgICAgICAgICAgIGJyZWFrO1xyXG4gICAgICAgICAgICAgICAgY2FzZSA0MDk6IC8vIHZlcnNpb24gY2hhbmdlXHJcbiAgICAgICAgICAgICAgICAgICAge1xyXG4gICAgICAgICAgICAgICAgICAgICAgICBjb25zdCBvYmogPSByZXNwb25zZS5lcnJvciAvKiBzZXJpYWxpemVkIG1vZGVsICovIGFzIFJlY2lwaWVudE1vZGVsPGFueT47XHJcbiAgICAgICAgICAgICAgICAgICAgICAgIHRoaXMuX3NiLmVycm9yKCdWZXJzaW9uRXJyJywgdGhpcy5tb2RlbC5udW1iZXIpO1xyXG4gICAgICAgICAgICAgICAgICAgICAgICBicmVhaztcclxuICAgICAgICAgICAgICAgICAgICB9XHJcbiAgICAgICAgICAgICAgICBjYXNlIDQwNjogLy8gdmFsaWRhdGlvbiBleGNlcHRpb25cclxuICAgICAgICAgICAgICAgICAgICB0aGlzLl9zYi5lcnJvclN0cmluZyhyZXNwb25zZS5lcnJvcik7XHJcbiAgICAgICAgICAgICAgICAgICAgYnJlYWs7XHJcbiAgICAgICAgICAgICAgICBkZWZhdWx0OlxyXG4gICAgICAgICAgICAgICAgICAgIHRoaXMuX3NiLmVycm9yKG1lc3NhZ2UsIC4uLmFyZ3MpO1xyXG4gICAgICAgICAgICB9XHJcbiAgICB9XHJcbn1cclxuIl19
|
@@ -0,0 +1,70 @@
|
|
1
|
+
import { Component, EventEmitter, ViewChild } from '@angular/core';
|
2
|
+
import { Subject } from 'rxjs';
|
3
|
+
import { takeUntil } from 'rxjs/operators';
|
4
|
+
import { LayoutComponent } from '../../core/layout/layout.component';
|
5
|
+
import { ActionBase } from './action.base';
|
6
|
+
import * as i0 from "@angular/core";
|
7
|
+
import * as i1 from "../../core/slots/pane-ref";
|
8
|
+
import * as i2 from "../../core/mailbox.service";
|
9
|
+
import * as i3 from "../../core/component-factory-resolver";
|
10
|
+
import * as i4 from "../../core/prompt.service";
|
11
|
+
import * as i5 from "../../core/session.service";
|
12
|
+
import * as i6 from "@angular/material/button";
|
13
|
+
import * as i7 from "@angular/material/dialog";
|
14
|
+
import * as i8 from "@angular/common";
|
15
|
+
import * as i9 from "../../core/pipes/translate.pipe";
|
16
|
+
/** action-dialog component*/
|
17
|
+
export class ActionPaneComponent extends ActionBase {
|
18
|
+
/** action-dialog ctor */
|
19
|
+
constructor(_pane, mailbox, _fr, _fr2, sb, session) {
|
20
|
+
super(mailbox, sb);
|
21
|
+
this._pane = _pane;
|
22
|
+
this._fr = _fr;
|
23
|
+
this._fr2 = _fr2;
|
24
|
+
this.arguments = {};
|
25
|
+
this.okChange = new EventEmitter();
|
26
|
+
this._destroy = new Subject();
|
27
|
+
this.model = _pane.data.item;
|
28
|
+
this.action = session.profile.actions.find(a => a.name === _pane.params.action);
|
29
|
+
}
|
30
|
+
close() { this._pane.close(); }
|
31
|
+
ok() {
|
32
|
+
super._ok(this.action, this.arguments).subscribe(() => this.close());
|
33
|
+
}
|
34
|
+
ngOnInit() {
|
35
|
+
if (this.action.template) {
|
36
|
+
const factory = this._fr.resolve(this.action.template);
|
37
|
+
const cRef = this.container.createComponent(factory);
|
38
|
+
cRef.instance.form.valueChanges.pipe(takeUntil(this._destroy)).subscribe(v => this.arguments = v);
|
39
|
+
cRef.instance.form.statusChanges.pipe(takeUntil(this._destroy)).
|
40
|
+
subscribe(() => this.valid = cRef.instance.form.valid);
|
41
|
+
}
|
42
|
+
else {
|
43
|
+
if (this.action.arguments.length === 0)
|
44
|
+
this.valid = true;
|
45
|
+
else {
|
46
|
+
const factory = this._fr2.resolveComponentFactory(LayoutComponent);
|
47
|
+
const cRef = this.container.createComponent(factory);
|
48
|
+
cRef.instance.fields = this.action.arguments;
|
49
|
+
cRef.instance.modelChange.pipe(takeUntil(this._destroy)).subscribe(v => this.arguments = v);
|
50
|
+
cRef.instance.validChange.pipe(takeUntil(this._destroy)).subscribe(v => this.valid = v);
|
51
|
+
}
|
52
|
+
}
|
53
|
+
}
|
54
|
+
ngOnDestroy() {
|
55
|
+
this._destroy.next();
|
56
|
+
this._destroy.complete();
|
57
|
+
}
|
58
|
+
}
|
59
|
+
ActionPaneComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: ActionPaneComponent, deps: [{ token: i1.PaneRef }, { token: i2.MailboxService }, { token: i3.BizDocComponentFactoryResolver }, { token: i0.ComponentFactoryResolver }, { token: i4.PromptService }, { token: i5.SessionService }], target: i0.ɵɵFactoryTarget.Component });
|
60
|
+
ActionPaneComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: ActionPaneComponent, selector: "bizdoc-action-dialog.pane", host: { classAttribute: "pane" }, viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<h2 mat-dialog-title>{{action.title}}</h2>\r\n<mat-dialog-content>\r\n <p *ngIf=\"!action.arguments.length\">\r\n {{ 'ActionAsk' | translate : (action.verb || action.title).toLowerCase() }}\r\n </p>\r\n <ng-container #container>\r\n </ng-container>\r\n</mat-dialog-content>\r\n<mat-dialog-actions>\r\n <button mat-button type=\"submit\" [disabled]=\"!valid\" (click)=\"ok()\" color=\"primary\">{{'Yes'|translate}}</button>\r\n <button mat-button (click)='close()'>{{'No' | translate}}</button>\r\n</mat-dialog-actions>\r\n", styles: [":host ::ng-deep form{display:flex}\n"], components: [{ type: i6.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }], directives: [{ type: i7.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { type: i7.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { type: i8.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]" }], pipes: { "translate": i9.TranslatePipe } });
|
61
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: ActionPaneComponent, decorators: [{
|
62
|
+
type: Component,
|
63
|
+
args: [{ selector: 'bizdoc-action-dialog.pane', host: {
|
64
|
+
class: 'pane'
|
65
|
+
}, template: "<h2 mat-dialog-title>{{action.title}}</h2>\r\n<mat-dialog-content>\r\n <p *ngIf=\"!action.arguments.length\">\r\n {{ 'ActionAsk' | translate : (action.verb || action.title).toLowerCase() }}\r\n </p>\r\n <ng-container #container>\r\n </ng-container>\r\n</mat-dialog-content>\r\n<mat-dialog-actions>\r\n <button mat-button type=\"submit\" [disabled]=\"!valid\" (click)=\"ok()\" color=\"primary\">{{'Yes'|translate}}</button>\r\n <button mat-button (click)='close()'>{{'No' | translate}}</button>\r\n</mat-dialog-actions>\r\n", styles: [":host ::ng-deep form{display:flex}\n"] }]
|
66
|
+
}], ctorParameters: function () { return [{ type: i1.PaneRef }, { type: i2.MailboxService }, { type: i3.BizDocComponentFactoryResolver }, { type: i0.ComponentFactoryResolver }, { type: i4.PromptService }, { type: i5.SessionService }]; }, propDecorators: { container: [{
|
67
|
+
type: ViewChild,
|
68
|
+
args: ['container']
|
69
|
+
}] } });
|
70
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"action.pane.dialog.exp.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/compose/action/action.pane.dialog.exp.ts","../../../../../../libraries/core/src/lib/compose/action/action.pane.dialog.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ComponentFactoryResolver, EventEmitter, OnDestroy, OnInit, ViewChild, ViewContainerRef } from '@angular/core';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\nimport { SessionService } from '../../core/session.service';\r\nimport { Action } from '../../core/models';\r\nimport { ArgumentsComponent } from '../../core/base';\r\nimport { BizDocComponentFactoryResolver } from '../../core/component-factory-resolver';\r\nimport { LayoutComponent } from '../../core/layout/layout.component';\r\nimport { PaneRef } from '../../core/slots/pane-ref';\r\nimport { MailboxService } from '../../core/mailbox.service';\r\nimport { PromptService } from '../../core/prompt.service';\r\nimport { ParamMap } from '../../core/configuration';\r\nimport { ActionBase } from './action.base';\r\n\r\n@Component({\r\n  selector: 'bizdoc-action-dialog.pane',\r\n  templateUrl: './action.pane.dialog.html',\r\n  styleUrls: ['./action.dialog.scss'],\r\n  host: {\r\n    class: 'pane'\r\n  }\r\n})\r\n/** action-dialog component*/\r\nexport class ActionPaneComponent extends ActionBase implements OnInit, OnDestroy {\r\n  @ViewChild('container') container: ViewContainerRef;\r\n  arguments = {};\r\n  readonly action: Action;\r\n  valid: boolean;\r\n  readonly okChange = new EventEmitter<ParamMap>();\r\n  private readonly _destroy = new Subject<void>();\r\n  /** action-dialog ctor */\r\n  constructor(\r\n    private _pane: PaneRef<ActionPaneComponent>,\r\n    mailbox: MailboxService,\r\n    private _fr: BizDocComponentFactoryResolver,\r\n    private _fr2: ComponentFactoryResolver,\r\n    sb: PromptService,\r\n    session: SessionService) {\r\n    super(mailbox, sb);\r\n    this.model = _pane.data.item;\r\n    this.action = session.profile.actions.find(a => a.name === _pane.params.action);\r\n  }\r\n  close() { this._pane.close(); }\r\n  ok() {\r\n    super._ok(this.action, this.arguments).subscribe(() =>\r\n      this.close()\r\n    );\r\n  }\r\n  ngOnInit(): void {\r\n    if (this.action.template) {\r\n      const factory = this._fr.resolve(this.action.template);\r\n      const cRef = this.container.createComponent(factory);\r\n      (cRef.instance as ArgumentsComponent).form.valueChanges.pipe(takeUntil(this._destroy)).subscribe(v => this.arguments = v);\r\n      (cRef.instance as ArgumentsComponent).form.statusChanges.pipe(takeUntil(this._destroy)).\r\n        subscribe(() => this.valid = (cRef.instance as ArgumentsComponent).form.valid);\r\n    }\r\n    else {\r\n      if (this.action.arguments.length === 0)\r\n        this.valid = true;\r\n      else {\r\n        const factory = this._fr2.resolveComponentFactory(LayoutComponent);\r\n        const cRef = this.container.createComponent(factory);\r\n        cRef.instance.fields = this.action.arguments;\r\n        cRef.instance.modelChange.pipe(takeUntil(this._destroy)).subscribe(v => this.arguments = v);\r\n        cRef.instance.validChange.pipe(takeUntil(this._destroy)).subscribe(v => this.valid = v);\r\n      }\r\n    }\r\n  }\r\n  ngOnDestroy(): void {\r\n    this._destroy.next();\r\n    this._destroy.complete();\r\n  }\r\n}\r\n","<h2 mat-dialog-title>{{action.title}}</h2>\r\n<mat-dialog-content>\r\n  <p *ngIf=\"!action.arguments.length\">\r\n    {{ 'ActionAsk' | translate : (action.verb || action.title).toLowerCase() }}\r\n  </p>\r\n  <ng-container #container>\r\n  </ng-container>\r\n</mat-dialog-content>\r\n<mat-dialog-actions>\r\n  <button mat-button type=\"submit\" [disabled]=\"!valid\" (click)=\"ok()\" color=\"primary\">{{'Yes'|translate}}</button>\r\n  <button mat-button (click)='close()'>{{'No' | translate}}</button>\r\n</mat-dialog-actions>\r\n"]}
|