@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.
@@ -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, _mailbox, _dialog, _sb) {
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
- const { id, version, number, model, formId } = this.model;
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 &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", 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 &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", 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 &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", 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"]}