@bizdoc/core 1.17.1 → 1.17.5
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/themes/brown.min.css +1 -1
- package/assets/themes/dark.min.css +1 -1
- package/assets/themes/deep-purple-light-blue.min.css +1 -1
- package/assets/themes/deep-purple-teal.min.css +1 -1
- package/assets/themes/default.min.css +1 -1
- package/assets/themes/green.min.css +1 -1
- package/assets/themes/indigo.min.css +1 -1
- package/esm2020/lib/admin/architecture/cube-axes-filter.component.mjs +3 -3
- package/esm2020/lib/admin/architecture/declarations.mjs +11 -4
- package/esm2020/lib/admin/architecture/designer-element.component.mjs +3 -3
- package/esm2020/lib/admin/architecture/designer-privileges.component.mjs +12 -8
- package/esm2020/lib/admin/architecture/designer.base.mjs +2 -1
- package/esm2020/lib/admin/architecture/designer.component.mjs +12 -6
- package/esm2020/lib/admin/architecture/elements/action.component.mjs +2 -2
- package/esm2020/lib/admin/architecture/elements/analysis-view.component.mjs +5 -4
- package/esm2020/lib/admin/architecture/elements/analysis-widget.component.mjs +5 -4
- package/esm2020/lib/admin/architecture/elements/attribute.component.mjs +5 -4
- package/esm2020/lib/admin/architecture/elements/control.component.mjs +7 -5
- package/esm2020/lib/admin/architecture/elements/cube-index-utility.component.mjs +5 -4
- package/esm2020/lib/admin/architecture/elements/cube-view.component.mjs +5 -4
- package/esm2020/lib/admin/architecture/elements/cube.component.mjs +3 -3
- package/esm2020/lib/admin/architecture/elements/documents-report.component.mjs +5 -4
- package/esm2020/lib/admin/architecture/elements/documents-widget.component.mjs +5 -4
- package/esm2020/lib/admin/architecture/elements/explore-view.component.mjs +5 -4
- package/esm2020/lib/admin/architecture/elements/feedback-widget.component.mjs +7 -6
- package/esm2020/lib/admin/architecture/elements/folder.component.mjs +5 -4
- package/esm2020/lib/admin/architecture/elements/form-invite.dialog.mjs +44 -33
- package/esm2020/lib/admin/architecture/elements/form.component.mjs +10 -8
- package/esm2020/lib/admin/architecture/elements/matrix-view.component.mjs +5 -4
- package/esm2020/lib/admin/architecture/elements/parallel-view.component.mjs +5 -4
- package/esm2020/lib/admin/architecture/elements/performance-report.component.mjs +5 -4
- package/esm2020/lib/admin/architecture/elements/performance-widget.component.mjs +5 -4
- package/esm2020/lib/admin/architecture/elements/pivot-view.component.mjs +5 -4
- package/esm2020/lib/admin/architecture/elements/report.component.mjs +5 -4
- package/esm2020/lib/admin/architecture/elements/rule.component.mjs +1 -1
- package/esm2020/lib/admin/architecture/elements/state.component.mjs +2 -2
- package/esm2020/lib/admin/architecture/elements/sum-view.component.mjs +5 -4
- package/esm2020/lib/admin/architecture/elements/tasks-report.component.mjs +5 -4
- package/esm2020/lib/admin/architecture/elements/usage-report.component.mjs +5 -4
- package/esm2020/lib/admin/architecture/elements/widget.component.mjs +5 -4
- package/esm2020/lib/admin/core/localized-string.component.mjs +1 -1
- package/esm2020/lib/admin/form/designer/box-designer.component.mjs +4 -5
- package/esm2020/lib/admin/form/designer/properties.component.mjs +3 -2
- package/esm2020/lib/admin/form/designer/section.component.mjs +3 -3
- package/esm2020/lib/admin/patterns/patterns.component.mjs +3 -3
- package/esm2020/lib/admin/system.service.mjs +1 -1
- package/esm2020/lib/compose/box/box.component.mjs +5 -5
- package/esm2020/lib/core/fields/autocomplete.field.mjs +4 -4
- package/esm2020/lib/core/fields/checklist.designer.mjs +11 -11
- package/esm2020/lib/core/fields/checklist.field.mjs +17 -24
- package/esm2020/lib/core/fields/localized-string.field.mjs +21 -0
- package/esm2020/lib/core/fields/options.base.mjs +41 -0
- package/esm2020/lib/core/fields/options.component.mjs +3 -3
- package/esm2020/lib/core/fields/radio-button.designer.mjs +13 -10
- package/esm2020/lib/core/fields/radio-button.field.mjs +16 -23
- package/esm2020/lib/core/fields/select.designer.mjs +16 -15
- package/esm2020/lib/core/fields/select.field.mjs +18 -31
- package/esm2020/lib/core/fields/signature.designer.mjs +3 -1
- package/esm2020/lib/core/fields/signature.field.mjs +3 -3
- package/esm2020/lib/core/fields/yesno.designer.mjs +6 -5
- package/esm2020/lib/core/layout.component.mjs +5 -1
- package/esm2020/lib/core/models.mjs +2 -1
- package/esm2020/lib/core/slots/slots.component.mjs +3 -3
- package/esm2020/lib/core/translations.mjs +28 -108
- package/esm2020/lib/cube/filter/filter.component.mjs +3 -3
- package/esm2020/lib/dashboard/cube/cube-analysis.base.mjs +36 -13
- package/esm2020/lib/dashboard/cube/cube-analysis.widget.mjs +1 -1
- package/esm2020/lib/notifications/types/commented.notification.mjs +1 -1
- package/esm2020/lib/notifications/types/escalated.notification.mjs +1 -1
- package/esm2020/lib/notifications/types/invite.notification.mjs +11 -3
- package/esm2020/lib/notifications/types/liked.notification.mjs +1 -1
- package/esm2020/lib/notifications/types/long-running-task.notification.mjs +3 -3
- package/esm2020/lib/notifications/types/nudge.notification.mjs +1 -1
- package/esm2020/lib/notifications/types/state-changed.notification.mjs +2 -2
- package/esm2020/lib/notifications/types/tagged.notification.mjs +2 -2
- package/esm2020/lib/notifications/types/upcoming-event.notification.mjs +1 -1
- package/esm2020/lib/reports/arguments-component.mjs +1 -1
- package/esm2020/lib/reports/report-ref.mjs +4 -2
- package/esm2020/lib/reports/report-viewer.component.mjs +4 -2
- package/esm2020/lib/system.module.mjs +110 -9
- package/fesm2015/bizdoc-core.mjs +1133 -1016
- package/fesm2015/bizdoc-core.mjs.map +1 -1
- package/fesm2020/bizdoc-core.mjs +1127 -1010
- package/fesm2020/bizdoc-core.mjs.map +1 -1
- package/lib/admin/architecture/declarations.d.ts +4 -3
- package/lib/admin/architecture/designer.component.d.ts +1 -0
- package/lib/admin/architecture/elements/control.component.d.ts +1 -0
- package/lib/admin/architecture/elements/cube.component.d.ts +1 -1
- package/lib/admin/architecture/elements/form-invite.dialog.d.ts +6 -5
- package/lib/admin/architecture/elements/rule.component.d.ts +1 -2
- package/lib/admin/core/localized-string.component.d.ts +2 -2
- package/lib/admin/system.service.d.ts +7 -1
- package/lib/core/fields/checklist.designer.d.ts +7 -10
- package/lib/core/fields/checklist.field.d.ts +2 -13
- package/lib/core/fields/localized-string.field.d.ts +16 -0
- package/lib/core/fields/options.base.d.ts +28 -0
- package/lib/core/fields/radio-button.designer.d.ts +6 -6
- package/lib/core/fields/radio-button.field.d.ts +2 -13
- package/lib/core/fields/select.designer.d.ts +5 -6
- package/lib/core/fields/select.field.d.ts +2 -16
- package/lib/core/models.d.ts +4 -0
- package/lib/core/translations.d.ts +19 -99
- package/lib/dashboard/cube/cube-analysis.widget.d.ts +2 -1
- package/lib/notifications/types/commented.notification.d.ts +0 -1
- package/lib/notifications/types/escalated.notification.d.ts +0 -1
- package/lib/notifications/types/invite.notification.d.ts +4 -5
- package/lib/notifications/types/liked.notification.d.ts +0 -1
- package/lib/notifications/types/long-running-task.notification.d.ts +1 -1
- package/lib/notifications/types/nudge.notification.d.ts +0 -1
- package/lib/notifications/types/state-changed.notification.d.ts +0 -2
- package/lib/notifications/types/tagged.notification.d.ts +0 -2
- package/lib/notifications/types/upcoming-event.notification.d.ts +0 -1
- package/lib/reports/report-ref.d.ts +3 -1
- package/lib/system.module.d.ts +35 -34
- package/package.json +1 -1
@@ -146,7 +146,7 @@ export class DesignerItemComponent {
|
|
146
146
|
}
|
147
147
|
_form() {
|
148
148
|
const name = this._fb.control(null, Validators.required), title = this._fb.control(null, Validators.required);
|
149
|
-
this.model.
|
149
|
+
this.model.resourceType && title.disable();
|
150
150
|
if (this.model.draft)
|
151
151
|
title.valueChanges.
|
152
152
|
pipe( /*takeUntil(this._destroy)*/).subscribe((t) => t && name.setValue(programName(t)));
|
@@ -169,7 +169,7 @@ export class DesignerItemComponent {
|
|
169
169
|
unlock(evt) {
|
170
170
|
if (evt.srcElement.tagName !== 'A')
|
171
171
|
return;
|
172
|
-
this.model.
|
172
|
+
this.model.resourceType = null;
|
173
173
|
this.form.get('title').enable();
|
174
174
|
this._ref._unlock$.next(false);
|
175
175
|
}
|
@@ -233,4 +233,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.5", ngImpor
|
|
233
233
|
type: ContentChild,
|
234
234
|
args: [WidgetContentDirective]
|
235
235
|
}] } });
|
236
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"designer-element.component.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/admin/architecture/designer-element.component.ts","../../../../../../libraries/core/src/lib/admin/architecture/designer-element.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ComponentRef, ContentChild, Directive, ElementRef, EventEmitter, Host, Inject, Input, OnChanges, OnDestroy, OnInit, Output, SimpleChanges, TemplateRef, ViewChild, ViewEncapsulation } from \"@angular/core\";\r\nimport { FormBuilder, FormGroup, Validators } from \"@angular/forms\";\r\nimport { ComponentPortal, Portal } from \"@angular/cdk/portal\";\r\nimport { Subject, takeUntil } from \"rxjs\";\r\nimport { BizDocComponentFactoryResolver } from \"../../core/component-factory-resolver\";\r\nimport { DesignerRef, ElementModel, programName, DesignMode, FAMILY_SVG, DesignerElementComponent } from \"./declarations\";\r\nimport { LayoutComponent } from \"../../core/layout.component\";\r\nimport { DomSanitizer } from \"@angular/platform-browser\";\r\nimport { LocalizedStringComponent } from \"../core/localized-string.component\";\r\n\r\n@Directive({\r\n  selector: '[bizdocEditContent]'\r\n})\r\nexport class EditContentDirective {\r\n  constructor(public templateRef: TemplateRef<unknown>) { }\r\n}\r\n@Directive({\r\n  selector: '[bizdocContent]'\r\n})\r\nexport class WidgetContentDirective {\r\n  constructor(public templateRef: TemplateRef<unknown>) { }\r\n}\r\n@Directive({\r\n  selector: '[bizdocAddContent]'\r\n})\r\nexport class AddContentDirective {\r\n  constructor(public templateRef: TemplateRef<unknown>) { }\r\n}\r\n@Directive({\r\n  selector: 'bizdoc-designer-options'\r\n})\r\nexport class DesignerItemOptionsComponent implements OnInit {\r\n  ngOnInit(): void {\r\n    switch (this._elemetDesigner.mode) {\r\n      case 'edit':\r\n      default:\r\n    }\r\n  }\r\n  constructor(@Host() private _elemetDesigner: DesignerItemComponent) { }\r\n}\r\n/**\r\n*/\r\n@Component({\r\n  //encapsulation: ViewEncapsulation.None,\r\n  selector: 'bizdoc-designer-element',\r\n  templateUrl: 'designer-element.component.html',\r\n  styleUrls: ['designer-element.component.scss'],\r\n})\r\nexport\r\n  class DesignerItemComponent implements AfterViewInit, OnChanges, OnDestroy {\r\n  readonly svg = FAMILY_SVG;\r\n  @Input() privileges: boolean;\r\n  @Input() icon: boolean;\r\n  @Input() form: FormGroup;\r\n  @Input() state?: any;\r\n  @Output('continue') readonly onContinue = new EventEmitter();\r\n  @Output('save') readonly onSave = new EventEmitter<ElementModel>();\r\n  //@ViewChild('title', { read: LocalizedStringComponent }) title: LocalizedStringComponent;\r\n  @ContentChild(EditContentDirective) editContent: EditContentDirective;\r\n  @ContentChild(WidgetContentDirective) widgetContent: WidgetContentDirective;\r\n  options: Portal<any>;\r\n  arguments: Portal<any>;\r\n  mode: DesignMode;\r\n  model: ElementModel<any>;\r\n  private _customDesignerInstance: DesignerElementComponent<any>;\r\n  private readonly _destroy = new Subject<void>();\r\n  optionsstate: any;\r\n  constructor(\r\n    private _element: ElementRef<HTMLDivElement>,\r\n    private _fb: FormBuilder,\r\n    private _sanitizer: DomSanitizer,\r\n    @Inject(DesignerRef) private _ref: DesignerRef<any>,\r\n    private _cfr: BizDocComponentFactoryResolver,\r\n  ) {\r\n    this.mode = _ref.mode;\r\n    this.model = _ref.model as ElementModel;\r\n  }\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['state'] && !changes['state'].firstChange) {\r\n    }\r\n  }\r\n  resource(image: string) {\r\n    return this._sanitizer.bypassSecurityTrustResourceUrl(`/assets/system/${image}`);\r\n  }\r\n  optionsattached(componentRef: ComponentRef<DesignerElementComponent<any>>) {\r\n    const { instance } = componentRef;\r\n    this._customDesignerInstance = instance as DesignerElementComponent<any>;\r\n    instance.model = this.model;\r\n    if (this.mode === 'add' && !instance.onContinue) {\r\n      this.onContinue.emit();\r\n      this.mode = 'edit';\r\n      this._form();\r\n    }\r\n    instance.mode = this.mode;\r\n    if (this.mode !== 'widget') {\r\n      this.form.addControl('options', instance.form, { emitEvent: false });\r\n      instance.form.patchValue(this.model.options, { emitEvent: false });\r\n    }\r\n  }\r\n  argumentsattached(componentRef: ComponentRef<LayoutComponent>) {\r\n    const { instance } = componentRef;\r\n    instance.fields = this.model.arguments;\r\n    instance.model = this.model.options;\r\n    instance.layout();\r\n    this.mode !== 'widget' &&\r\n      this.form.addControl('options', instance.form, { emitEvent: false });\r\n  }\r\n  ngOnInit() {\r\n    if (this.mode == 'add') {\r\n      this.form.markAsDirty();\r\n      this.form.patchValue({});\r\n      if (this.model.copyOf)\r\n        this.mode = 'edit';\r\n    }\r\n    if (this.model.template) {\r\n      const comp = this._cfr.component(this.model.template);\r\n      this.options = new ComponentPortal<DesignerElementComponent<any>>(comp);\r\n    }\r\n    else if (this.mode !== 'widget' && this.model.arguments?.length)\r\n      this.arguments = new ComponentPortal(LayoutComponent);\r\n    else if (this.mode === 'add')\r\n      this.mode = 'edit';\r\n\r\n    this.mode === 'edit' && this._form();\r\n  }\r\n  private _form() {\r\n    const name = this._fb.control(null, Validators.required),\r\n      title = this._fb.control(null, Validators.required);\r\n    this.model.resource && title.disable();\r\n    if (this.model.draft) title.valueChanges.\r\n      pipe(/*takeUntil(this._destroy)*/).subscribe((t: string) =>\r\n        t && name.setValue(programName(t))\r\n      );\r\n    else\r\n      name.disable();\r\n    this.form.addControl('name', name, { emitEvent: false });\r\n    this.form.addControl('title', title, { emitEvent: false });\r\n    this.icon && this.form.addControl('icon', this._fb.control(null), { emitEvent: false });\r\n    this.privileges && this.form.addControl('privileges', this._fb.group({\r\n      rule: null,\r\n      roles: []\r\n    }));\r\n    this.form.patchValue(this.model, { emitEvent: false });\r\n  }\r\n  ngAfterViewInit() {\r\n    (this.mode === 'edit' || (this.mode === 'add' && !this.options)) &&\r\n      //this.title?.focus();\r\n      setTimeout(() =>\r\n        this._element.nativeElement.querySelector('textarea')?.focus());\r\n  }\r\n  unlock(evt: Event) {\r\n    if ((evt.srcElement as HTMLElement).tagName !== 'A') return;\r\n    this.model.resource = null;\r\n    this.form.get('title').enable();\r\n    this._ref._unlock$.next(false);\r\n  }\r\n  continue() {\r\n    if (this._customDesignerInstance?.onContinue) {\r\n      this._customDesignerInstance.onContinue();\r\n      Object.assign(this.options, this._customDesignerInstance.form.getRawValue());\r\n    }\r\n    this.onContinue.emit();\r\n    if (this._customDesignerInstance)\r\n      this._customDesignerInstance.mode = 'edit';\r\n    this.mode = 'edit';\r\n    this._form();\r\n  }\r\n  save() {\r\n    Object.assign(this.model, this.form.getRawValue());\r\n    this._customDesignerInstance?.onFinish && this._customDesignerInstance.onFinish();\r\n    this.onSave.emit(this.model);\r\n  }\r\n  /**\r\n   * Ctrl-s save\r\n   * @param event\r\n   */\r\n  handleKeyboardEvent(event: KeyboardEvent) {\r\n    if (event.ctrlKey && (event.which === 83 || event.which === 115)) {\r\n      this.form.valid && this.save();\r\n      event.preventDefault();\r\n    }\r\n  }\r\n  ngOnDestroy(): void {\r\n    this._destroy?.next();\r\n    this._destroy?.complete();\r\n  }\r\n}\r\n","  <!--widget mode -->\r\n<ng-container *ngIf=\"mode === 'widget'; else editing\">\r\n  <ng-container *ngIf=\"model.family\">\r\n    <img *ngIf=\"svg[model.family]\" class=\"logo\" [src]=\"resource(svg[model.family])\" [bizdocTooltip]=\"model.family\" />\r\n    <div *ngIf=\"!svg[model.family]\">{{model.family}}</div>\r\n  </ng-container>\r\n  <!--options-->\r\n  <ng-container (attached)=\"optionsattached($event)\" [cdkPortalOutlet]=\"options\"></ng-container>\r\n  <ng-container [ngTemplateOutlet]=\"widgetContent?.templateRef\"></ng-container>\r\n</ng-container>\r\n<!--add or edit mode-->\r\n<ng-template #editing>\r\n  <ng-container *ngIf=\"mode === 'edit'\">\r\n    <mat-toolbar>\r\n      <button mat-icon-button (click)=\"save()\" [disabled]=\"!form.valid || !form.dirty\"><mat-icon>save</mat-icon></button>\r\n    </mat-toolbar>\r\n    <p *ngIf=\"model.resource\" class=\"message\" (click)=\"unlock($event)\" [innerHTML]=\"'UnlockMultilang'|translate\"></p>\r\n  </ng-container>\r\n  <form autocomplete=\"off\" [formGroup]=\"form\" class=\"column\" (keydown)=\"handleKeyboardEvent($event)\">\r\n    <ng-container *ngIf=\"!state\">\r\n      <ng-container *ngIf=\"mode === 'edit'\">\r\n        <div class=\"row\">\r\n          <bizdoc-localized-string #title formControlName=\"title\" [placeholder]=\"'Title'|translate\" required class=\"flex column\"></bizdoc-localized-string>\r\n          &nbsp;\r\n          <mat-form-field class=\"flex\">\r\n            <mat-label>{{'Name'|translate}}</mat-label>\r\n            <input matInput formControlName=\"name\" required />\r\n            <mat-error *ngIf=\"form.get('name').hasError('required')\" [innerHTML]=\"'RequiredErr'|translate:('Name'|translate)\"></mat-error>\r\n          </mat-form-field>\r\n        </div>\r\n        <bizdoc-icon-picker *ngIf=\"icon\" formControlName=\"icon\" required></bizdoc-icon-picker>\r\n      </ng-container>\r\n      <!--arguments-->\r\n      <ng-container *ngIf=\"arguments\" (attached)=\"argumentsattached($event)\" [cdkPortalOutlet]=\"arguments\"></ng-container>\r\n      <!--options-->\r\n      <ng-container *ngIf=\"options\" (attached)=\"optionsattached($event)\" [cdkPortalOutlet]=\"options\"></ng-container>\r\n    </ng-container>\r\n    <ng-container *ngIf=\"mode === 'edit'\" [ngTemplateOutlet]=\"editContent?.templateRef\"></ng-container>\r\n    <!--privileges-->\r\n    <bizdoc-designer-privileges *ngIf=\"form.contains('privileges') && !state\" [form]=\"form.get('privileges')\"></bizdoc-designer-privileges>\r\n  </form>\r\n  <div class=\"row actions\" *ngIf=\"mode === 'add'\">\r\n    <span class=\"divider\"></span>\r\n    <button mat-stroked-button [disabled]=\"!form.valid\" (click)=\"continue()\" type=\"button\">{{'Continue'|translate}}&nbsp;<mat-icon class=\"mat-icon-rtl-mirror\">double_arrow</mat-icon></button>\r\n  </div>\r\n</ng-template>\r\n"]}
|
236
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"designer-element.component.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/admin/architecture/designer-element.component.ts","../../../../../../libraries/core/src/lib/admin/architecture/designer-element.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ComponentRef, ContentChild, Directive, ElementRef, EventEmitter, Host, Inject, Input, OnChanges, OnDestroy, OnInit, Output, SimpleChanges, TemplateRef, ViewChild, ViewEncapsulation } from \"@angular/core\";\r\nimport { FormBuilder, FormGroup, Validators } from \"@angular/forms\";\r\nimport { ComponentPortal, Portal } from \"@angular/cdk/portal\";\r\nimport { Subject, takeUntil } from \"rxjs\";\r\nimport { BizDocComponentFactoryResolver } from \"../../core/component-factory-resolver\";\r\nimport { DesignerRef, ElementModel, programName, DesignMode, FAMILY_SVG, DesignerElementComponent } from \"./declarations\";\r\nimport { LayoutComponent } from \"../../core/layout.component\";\r\nimport { DomSanitizer } from \"@angular/platform-browser\";\r\n\r\n@Directive({\r\n  selector: '[bizdocEditContent]'\r\n})\r\nexport class EditContentDirective {\r\n  constructor(public templateRef: TemplateRef<unknown>) { }\r\n}\r\n@Directive({\r\n  selector: '[bizdocContent]'\r\n})\r\nexport class WidgetContentDirective {\r\n  constructor(public templateRef: TemplateRef<unknown>) { }\r\n}\r\n@Directive({\r\n  selector: '[bizdocAddContent]'\r\n})\r\nexport class AddContentDirective {\r\n  constructor(public templateRef: TemplateRef<unknown>) { }\r\n}\r\n@Directive({\r\n  selector: 'bizdoc-designer-options'\r\n})\r\nexport class DesignerItemOptionsComponent implements OnInit {\r\n  ngOnInit(): void {\r\n    switch (this._elemetDesigner.mode) {\r\n      case 'edit':\r\n      default:\r\n    }\r\n  }\r\n  constructor(@Host() private _elemetDesigner: DesignerItemComponent) { }\r\n}\r\n/**\r\n*/\r\n@Component({\r\n  //encapsulation: ViewEncapsulation.None,\r\n  selector: 'bizdoc-designer-element',\r\n  templateUrl: 'designer-element.component.html',\r\n  styleUrls: ['designer-element.component.scss'],\r\n})\r\nexport\r\n  class DesignerItemComponent implements AfterViewInit, OnChanges, OnDestroy {\r\n  readonly svg = FAMILY_SVG;\r\n  @Input() privileges: boolean;\r\n  @Input() icon: boolean;\r\n  @Input() form: FormGroup;\r\n  @Input() state?: any;\r\n  @Output('continue') readonly onContinue = new EventEmitter();\r\n  @Output('save') readonly onSave = new EventEmitter<ElementModel>();\r\n  //@ViewChild('title', { read: LocalizedStringComponent }) title: LocalizedStringComponent;\r\n  @ContentChild(EditContentDirective) editContent: EditContentDirective;\r\n  @ContentChild(WidgetContentDirective) widgetContent: WidgetContentDirective;\r\n  options: Portal<any>;\r\n  arguments: Portal<any>;\r\n  mode: DesignMode;\r\n  model: ElementModel<any>;\r\n  private _customDesignerInstance: DesignerElementComponent<any>;\r\n  private readonly _destroy = new Subject<void>();\r\n  optionsstate: any;\r\n  constructor(\r\n    private _element: ElementRef<HTMLDivElement>,\r\n    private _fb: FormBuilder,\r\n    private _sanitizer: DomSanitizer,\r\n    @Inject(DesignerRef) private _ref: DesignerRef<any>,\r\n    private _cfr: BizDocComponentFactoryResolver,\r\n  ) {\r\n    this.mode = _ref.mode;\r\n    this.model = _ref.model as ElementModel;\r\n  }\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['state'] && !changes['state'].firstChange) {\r\n    }\r\n  }\r\n  resource(image: string) {\r\n    return this._sanitizer.bypassSecurityTrustResourceUrl(`/assets/system/${image}`);\r\n  }\r\n  optionsattached(componentRef: ComponentRef<DesignerElementComponent<any>>) {\r\n    const { instance } = componentRef;\r\n    this._customDesignerInstance = instance as DesignerElementComponent<any>;\r\n    instance.model = this.model;\r\n    if (this.mode === 'add' && !instance.onContinue) {\r\n      this.onContinue.emit();\r\n      this.mode = 'edit';\r\n      this._form();\r\n    }\r\n    instance.mode = this.mode;\r\n    if (this.mode !== 'widget') {\r\n      this.form.addControl('options', instance.form, { emitEvent: false });\r\n      instance.form.patchValue(this.model.options, { emitEvent: false });\r\n    }\r\n  }\r\n  argumentsattached(componentRef: ComponentRef<LayoutComponent>) {\r\n    const { instance } = componentRef;\r\n    instance.fields = this.model.arguments;\r\n    instance.model = this.model.options;\r\n    instance.layout();\r\n    this.mode !== 'widget' &&\r\n      this.form.addControl('options', instance.form, { emitEvent: false });\r\n  }\r\n  ngOnInit() {\r\n    if (this.mode == 'add') {\r\n      this.form.markAsDirty();\r\n      this.form.patchValue({});\r\n      if (this.model.copyOf)\r\n        this.mode = 'edit';\r\n    }\r\n    if (this.model.template) {\r\n      const comp = this._cfr.component(this.model.template);\r\n      this.options = new ComponentPortal<DesignerElementComponent<any>>(comp);\r\n    }\r\n    else if (this.mode !== 'widget' && this.model.arguments?.length)\r\n      this.arguments = new ComponentPortal(LayoutComponent);\r\n    else if (this.mode === 'add')\r\n      this.mode = 'edit';\r\n\r\n    this.mode === 'edit' && this._form();\r\n  }\r\n  private _form() {\r\n    const name = this._fb.control(null, Validators.required),\r\n      title = this._fb.control(null, Validators.required);\r\n    this.model.resourceType && title.disable();\r\n    if (this.model.draft) title.valueChanges.\r\n      pipe(/*takeUntil(this._destroy)*/).subscribe((t: string) =>\r\n        t && name.setValue(programName(t))\r\n      );\r\n    else\r\n      name.disable();\r\n    this.form.addControl('name', name, { emitEvent: false });\r\n    this.form.addControl('title', title, { emitEvent: false });\r\n    this.icon && this.form.addControl('icon', this._fb.control(null), { emitEvent: false });\r\n    this.privileges && this.form.addControl('privileges', this._fb.group({\r\n      rule: null,\r\n      roles: []\r\n    }));\r\n    this.form.patchValue(this.model, { emitEvent: false });\r\n  }\r\n  ngAfterViewInit() {\r\n    (this.mode === 'edit' || (this.mode === 'add' && !this.options)) &&\r\n      //this.title?.focus();\r\n      setTimeout(() =>\r\n        this._element.nativeElement.querySelector('textarea')?.focus());\r\n  }\r\n  unlock(evt: Event) {\r\n    if ((evt.srcElement as HTMLElement).tagName !== 'A') return;\r\n    this.model.resourceType = null;\r\n    this.form.get('title').enable();\r\n    this._ref._unlock$.next(false);\r\n  }\r\n  continue() {\r\n    if (this._customDesignerInstance?.onContinue) {\r\n      this._customDesignerInstance.onContinue();\r\n      Object.assign(this.options, this._customDesignerInstance.form.getRawValue());\r\n    }\r\n    this.onContinue.emit();\r\n    if (this._customDesignerInstance)\r\n      this._customDesignerInstance.mode = 'edit';\r\n    this.mode = 'edit';\r\n    this._form();\r\n  }\r\n  save() {\r\n    Object.assign(this.model, this.form.getRawValue());\r\n    this._customDesignerInstance?.onFinish && this._customDesignerInstance.onFinish();\r\n    this.onSave.emit(this.model);\r\n  }\r\n  /**\r\n   * Ctrl-s save\r\n   * @param event\r\n   */\r\n  handleKeyboardEvent(event: KeyboardEvent) {\r\n    if (event.ctrlKey && (event.which === 83 || event.which === 115)) {\r\n      this.form.valid && this.save();\r\n      event.preventDefault();\r\n    }\r\n  }\r\n  ngOnDestroy(): void {\r\n    this._destroy?.next();\r\n    this._destroy?.complete();\r\n  }\r\n}\r\n","  <!--widget mode -->\r\n<ng-container *ngIf=\"mode === 'widget'; else editing\">\r\n  <ng-container *ngIf=\"model.family\">\r\n    <img *ngIf=\"svg[model.family]\" class=\"logo\" [src]=\"resource(svg[model.family])\" [bizdocTooltip]=\"model.family\" />\r\n    <div *ngIf=\"!svg[model.family]\">{{model.family}}</div>\r\n  </ng-container>\r\n  <!--options-->\r\n  <ng-container (attached)=\"optionsattached($event)\" [cdkPortalOutlet]=\"options\"></ng-container>\r\n  <ng-container [ngTemplateOutlet]=\"widgetContent?.templateRef\"></ng-container>\r\n</ng-container>\r\n<!--add or edit mode-->\r\n<ng-template #editing>\r\n  <ng-container *ngIf=\"mode === 'edit'\">\r\n    <mat-toolbar>\r\n      <button mat-icon-button (click)=\"save()\" [disabled]=\"!form.valid || !form.dirty\"><mat-icon>save</mat-icon></button>\r\n    </mat-toolbar>\r\n    <p *ngIf=\"model.resource\" class=\"message\" (click)=\"unlock($event)\" [innerHTML]=\"'UnlockMultilang'|translate\"></p>\r\n  </ng-container>\r\n  <form autocomplete=\"off\" [formGroup]=\"form\" class=\"column\" (keydown)=\"handleKeyboardEvent($event)\">\r\n    <ng-container *ngIf=\"!state\">\r\n      <ng-container *ngIf=\"mode === 'edit'\">\r\n        <div class=\"row\">\r\n          <bizdoc-localized-string #title formControlName=\"title\" [placeholder]=\"'Title'|translate\" required class=\"flex column\"></bizdoc-localized-string>\r\n          &nbsp;\r\n          <mat-form-field class=\"flex\">\r\n            <mat-label>{{'Name'|translate}}</mat-label>\r\n            <input matInput formControlName=\"name\" required />\r\n            <mat-error *ngIf=\"form.get('name').hasError('required')\" [innerHTML]=\"'RequiredErr'|translate:('Name'|translate)\"></mat-error>\r\n          </mat-form-field>\r\n        </div>\r\n        <bizdoc-icon-picker *ngIf=\"icon\" formControlName=\"icon\" required></bizdoc-icon-picker>\r\n      </ng-container>\r\n      <!--arguments-->\r\n      <ng-container *ngIf=\"arguments\" (attached)=\"argumentsattached($event)\" [cdkPortalOutlet]=\"arguments\"></ng-container>\r\n      <!--options-->\r\n      <ng-container *ngIf=\"options\" (attached)=\"optionsattached($event)\" [cdkPortalOutlet]=\"options\"></ng-container>\r\n    </ng-container>\r\n    <ng-container *ngIf=\"mode === 'edit'\" [ngTemplateOutlet]=\"editContent?.templateRef\"></ng-container>\r\n    <!--privileges-->\r\n    <bizdoc-designer-privileges *ngIf=\"form.contains('privileges') && !state\" [form]=\"form.get('privileges')\"></bizdoc-designer-privileges>\r\n  </form>\r\n  <div class=\"row actions\" *ngIf=\"mode === 'add'\">\r\n    <span class=\"divider\"></span>\r\n    <button mat-stroked-button [disabled]=\"!form.valid\" (click)=\"continue()\" type=\"button\">{{'Continue'|translate}}&nbsp;<mat-icon class=\"mat-icon-rtl-mirror\">double_arrow</mat-icon></button>\r\n  </div>\r\n</ng-template>\r\n"]}
|
@@ -1,6 +1,6 @@
|
|
1
1
|
import { Component, Inject, Input } from "@angular/core";
|
2
2
|
import { ENTER, COMMA, SEMICOLON } from "@angular/cdk/keycodes";
|
3
|
-
import { DesignerRef } from "./declarations";
|
3
|
+
import { DesignerRef, localizeString } from "./declarations";
|
4
4
|
import { debounceTime } from "rxjs/operators";
|
5
5
|
import * as i0 from "@angular/core";
|
6
6
|
import * as i1 from "@angular/forms";
|
@@ -34,12 +34,13 @@ export class DesignerPrivilegesComponent {
|
|
34
34
|
this.roles = this._roles.slice();
|
35
35
|
});
|
36
36
|
this._service.roles().subscribe(r => {
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
});
|
42
|
-
this.
|
37
|
+
const roles = this._ref.designer.roles.filter(r => !r.disabled).
|
38
|
+
map(r => ({
|
39
|
+
name: r.name,
|
40
|
+
title: localizeString(r.title)
|
41
|
+
}));
|
42
|
+
this._roles = r.concat(roles);
|
43
|
+
this._roles.forEach(r => {
|
43
44
|
this._roles[r.name] = r;
|
44
45
|
r['_index'] = (r.title || r.name).toLowerCase();
|
45
46
|
});
|
@@ -47,6 +48,8 @@ export class DesignerPrivilegesComponent {
|
|
47
48
|
});
|
48
49
|
}
|
49
50
|
titleOf(name) {
|
51
|
+
if (!this._roles)
|
52
|
+
return name;
|
50
53
|
const role = this._roles[name];
|
51
54
|
return role?.title || name;
|
52
55
|
}
|
@@ -77,6 +80,7 @@ export class DesignerPrivilegesComponent {
|
|
77
80
|
this.form.get('roles').setValue(roles);
|
78
81
|
}
|
79
82
|
inp.value = '';
|
83
|
+
this.search.setValue(null);
|
80
84
|
}
|
81
85
|
}
|
82
86
|
DesignerPrivilegesComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: DesignerPrivilegesComponent, deps: [{ token: i1.FormBuilder }, { token: i2.SystemService }, { token: DesignerRef }], target: i0.ɵɵFactoryTarget.Component });
|
@@ -90,4 +94,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.5", ngImpor
|
|
90
94
|
}] }]; }, propDecorators: { form: [{
|
91
95
|
type: Input
|
92
96
|
}] } });
|
93
|
-
//# sourceMappingURL=data:application/json;base64,
|
97
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"designer-privileges.component.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/admin/architecture/designer-privileges.component.ts","../../../../../../libraries/core/src/lib/admin/architecture/designer-privileges.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Inject, Input, OnInit } from \"@angular/core\";\r\nimport { ENTER, COMMA, SEMICOLON } from \"@angular/cdk/keycodes\";\r\nimport { MatAutocompleteSelectedEvent } from \"@angular/material/autocomplete\";\r\nimport { FormBuilder, FormGroup } from \"@angular/forms\";\r\nimport { SystemService, Role } from \"../system.service\";\r\nimport { DesignerRef ,localizeString} from \"./declarations\";\r\nimport { debounceTime } from \"rxjs/operators\";\r\n/** */\r\n@Component({\r\n  selector: 'bizdoc-designer-privileges',\r\n  templateUrl: 'designer-privileges.component.html',\r\n})\r\nexport class DesignerPrivilegesComponent implements OnInit {\r\n  readonly separatorKeysCodes: number[] = [ENTER, COMMA, SEMICOLON];\r\n  @Input() form!: FormGroup;\r\n  private _roles: Role[];\r\n  roles: Role[] = [];\r\n  readonly search = this._fb.control(null);\r\n  constructor(\r\n    private _fb: FormBuilder,\r\n    private _service: SystemService,\r\n    @Inject(DesignerRef) private _ref: DesignerRef<any>,\r\n  ) {\r\n  }\r\n  ngOnInit(): void {\r\n    this.search.valueChanges.pipe(debounceTime(150)).subscribe((v: string) => {\r\n      if (v) {\r\n        const val = v.toLowerCase();\r\n        this.roles = this._roles.filter(r => r['_index'].indexOf(val) > -1);\r\n      }\r\n      else\r\n        this.roles = this._roles.slice();\r\n    });\r\n    this._service.roles().subscribe(r => {\r\n      const roles = this._ref.designer.roles.filter(r => !r.disabled).\r\n        map(r => ({\r\n          name: r.name,\r\n          title: localizeString(r.title)\r\n        }));\r\n      this._roles = r.concat(roles);\r\n      this._roles.forEach(r => {\r\n        this._roles[r.name] = r;\r\n        r['_index'] = (r.title || r.name).toLowerCase();\r\n      });\r\n      this.roles = this._roles.slice();\r\n    });\r\n  }\r\n  titleOf(name: string) {\r\n    if (!this._roles) return name;\r\n    const role = this._roles[name];\r\n    return role?.title || name;\r\n  }\r\n  /**\r\n   * \r\n   * @param id\r\n   */\r\n  remove(id: string): void {\r\n    const roles = this.form.value.roles;\r\n    const index = roles.indexOf(id);\r\n\r\n    if (index >= 0) {\r\n      roles.splice(index, 1);\r\n      this.form.get('roles').setValue(roles);\r\n    }\r\n  }\r\n  /**\r\n   * \r\n   * @param inp\r\n   * @param event\r\n   */\r\n  add(inp: HTMLInputElement, event: MatAutocompleteSelectedEvent): void {\r\n    const roles = this.form.value.roles;\r\n    const id = event.option.value as string;\r\n    if (!roles)\r\n      this.form.get('roles').setValue([id]);\r\n    else {\r\n      roles.push(id);\r\n      this.form.get('roles').setValue(roles);\r\n    }\r\n    inp.value = '';\r\n    this.search.setValue(null);\r\n  }\r\n}\r\n","<h2 class=\"mat-title\">{{'Privileges'|translate}}</h2>\r\n<div [formGroup]=\"form\" class=\"column\">\r\n  <mat-form-field class=\"flex\">\r\n    <mat-chip-list #chips [attr.aria-label]=\"''\">\r\n      <mat-chip *ngFor=\"let r of form.get('roles').value\"\r\n                [removable]=\"true\"\r\n                (removed)=\"remove(r)\">\r\n        {{titleOf(r)}}\r\n        <mat-icon matChipRemove>cancel</mat-icon>\r\n      </mat-chip>\r\n      <input [placeholder]=\"'Roles'|translate\"\r\n             [formControl]=search\r\n             #inputrole\r\n             [matAutocomplete]=\"nametype\"\r\n             [matChipInputFor]=\"chips\"\r\n             [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\">\r\n    </mat-chip-list>\r\n    <mat-autocomplete #nametype=\"matAutocomplete\" (optionSelected)=\"add(inputrole, $event)\">\r\n      <ng-container *ngFor=\"let r of roles\">\r\n        <mat-option *ngIf=\"!form.get('roles').value || form.get('roles').value.indexOf(r.name)<0\" [value]=\"r.name\">\r\n          {{r.title || r.name}}\r\n        </mat-option>\r\n      </ng-container>\r\n    </mat-autocomplete>\r\n  </mat-form-field>\r\n  <mat-form-field>\r\n    <bizdoc-ace-input [placeholder]=\"'Condition'|translate\" formControlName=\"rule\"></bizdoc-ace-input>\r\n    <mat-hint> {{ 'ProgrammableExpression'|translate }}</mat-hint>\r\n  </mat-form-field>\r\n</div>\r\n"]}
|
@@ -41,6 +41,7 @@ export class DesignerElementComponentBase {
|
|
41
41
|
}
|
42
42
|
edit(group, title, template) {
|
43
43
|
this.view = template;
|
44
|
+
this.state = 2;
|
44
45
|
this.context = {
|
45
46
|
title,
|
46
47
|
$implicit: group,
|
@@ -125,4 +126,4 @@ export function isAccum(chartType) {
|
|
125
126
|
return true;
|
126
127
|
}
|
127
128
|
}
|
128
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"designer.base.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/admin/architecture/designer.base.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, Inject, OnInit, TemplateRef, ViewChild } from \"@angular/core\";\r\nimport { FormArray, FormBuilder, FormGroup, Validators } from \"@angular/forms\";\r\nimport { CdkDragDrop } from \"@angular/cdk/drag-drop\";\r\nimport { MatSelectChange } from \"@angular/material/select\";\r\nimport { DesignerElementComponent, DesignMode, ElementModel, DesignerRef } from \"./declarations\";\r\nimport { DesignerItemComponent } from \"./designer-element.component\";\r\n/** */\r\n@Directive()\r\nexport abstract class DesignerElementComponentBase<T = any> implements DesignerElementComponent<T> {\r\n  mode: DesignMode;\r\n  model: ElementModel<T>;\r\n  view: TemplateRef<any>;\r\n  context: {\r\n    title: string;\r\n    $implicit: FormGroup;\r\n  };\r\n    state: any;\r\n  get options(): T { return this.model.options }\r\n  abstract form: FormGroup;\r\n  constructor(protected _fb: FormBuilder,\r\n    private _element: ElementRef<any>,\r\n    @Inject(DesignerRef) protected _ref: DesignerRef<T>) {\r\n  }\r\n  disable(...names: string[]) {\r\n    names.forEach(n => this.form.get(n).disable({ emitEvent: false }));\r\n  }\r\n  enable(...names: string[]) {\r\n    names.forEach(n => this.form.get(n).enable({ emitEvent: false }));\r\n  }\r\n  closeView(evt?: Event) {\r\n    this.view = null;\r\n    this.state = null;\r\n    evt?.preventDefault();\r\n    evt?.stopPropagation();\r\n  }\r\n  drop(event: CdkDragDrop<FormGroup>, collection: FormArray) {\r\n    const element = collection.at(event.previousIndex);\r\n    collection.removeAt(event.previousIndex);\r\n    collection.insert(event.currentIndex, element);\r\n  }\r\n  add(collection: FormArray, group: FormGroup, title: string, template: TemplateRef<any>) {\r\n    collection.push(group);\r\n    this.view = template;\r\n    this.context = {\r\n      title,\r\n      $implicit: group\r\n    };\r\n    this.state = 1;\r\n    this._focus();\r\n  }\r\n  edit(group: FormGroup, title: string, template: TemplateRef<any>) {\r\n    this.view = template;\r\n    this.context = {\r\n      title,\r\n      $implicit: group,\r\n    };\r\n    this._focus();\r\n  }\r\n  private _focus() {\r\n    setTimeout(() => this._element.nativeElement.querySelector('input')?.focus());\r\n  }\r\n}\r\n@Directive()\r\nexport abstract class DesignerTypeElementComponent<T = any> extends DesignerElementComponentBase {\r\n  ngOnInit() {\r\n  }\r\n  @ViewChild(DesignerItemComponent) designer: DesignerItemComponent;\r\n  constructor(protected _fb: FormBuilder,\r\n    element: ElementRef<any>,\r\n    @Inject(DesignerRef) protected _ref: DesignerRef<T>) {\r\n    super(_fb, element, _ref)\r\n    this.mode = _ref.mode;\r\n    this.model = _ref.model as ElementModel;\r\n  }\r\n}\r\nfunction applyMixins(derivedCtor: any, constructors: any[]) {\r\n  constructors.forEach((baseCtor) => {\r\n    Object.getOwnPropertyNames(baseCtor.prototype).forEach((name) => {\r\n      Object.defineProperty(\r\n        derivedCtor.prototype,\r\n        name,\r\n        Object.getOwnPropertyDescriptor(baseCtor.prototype, name) ||\r\n        Object.create(null)\r\n      );\r\n    });\r\n  });\r\n}\r\n/** */\r\n@Directive()\r\nexport abstract class DesignerCubeElementComponent<T = any> extends DesignerElementComponentBase<T> implements OnInit {\r\n  readonly cubes: ElementModel[];\r\n  cube: ElementModel;\r\n  sortComparator = (a, b) => 0;\r\n  cubeSelected(evt: MatSelectChange) {\r\n    this.cube = evt.value;\r\n    this.form.get('cube').setValue((evt.value as ElementModel).name);\r\n  }\r\n  constructor(fb: FormBuilder,\r\n    element: ElementRef<any>,\r\n    @Inject(DesignerRef) ref: DesignerRef) {\r\n    super(fb, element, ref);\r\n    this.cubes = ref.designer.cubes as ElementModel[];\r\n  }\r\n  ngOnInit() {\r\n    const cubeId = this.options['cube'];\r\n    if (cubeId) this.cube = this.cubes.find(c => c.name === cubeId) as ElementModel;\r\n    else\r\n      if (this.cubes.length === 1) this.cube = this.cubes[0] as ElementModel;\r\n  }\r\n}\r\nexport function isAccum(chartType) {\r\n  switch (chartType) {\r\n    case 'Pie':\r\n    case 'Doughnut':\r\n    case 'HalfDoughnut':\r\n    case 'Funnel':\r\n      return true;\r\n  }\r\n}\r\n"]}
|
129
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"designer.base.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/admin/architecture/designer.base.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, Inject, OnInit, TemplateRef, ViewChild } from \"@angular/core\";\r\nimport { FormArray, FormBuilder, FormGroup, Validators } from \"@angular/forms\";\r\nimport { CdkDragDrop } from \"@angular/cdk/drag-drop\";\r\nimport { MatSelectChange } from \"@angular/material/select\";\r\nimport { DesignerElementComponent, DesignMode, ElementModel, DesignerRef } from \"./declarations\";\r\nimport { DesignerItemComponent } from \"./designer-element.component\";\r\nimport { LocalizedString } from \"../../core/models\";\r\nimport { isString } from \"../../core/functions\";\r\n/** */\r\n@Directive()\r\nexport abstract class DesignerElementComponentBase<T = any> implements DesignerElementComponent<T> {\r\n  mode: DesignMode;\r\n  model: ElementModel<T>;\r\n  view: TemplateRef<any>;\r\n  context: {\r\n    title: string;\r\n    $implicit: FormGroup;\r\n  };\r\n  state: any;\r\n  get options(): T { return this.model.options }\r\n  abstract form: FormGroup;\r\n  constructor(protected _fb: FormBuilder,\r\n    private _element: ElementRef<any>,\r\n    @Inject(DesignerRef) protected _ref: DesignerRef<T>) {\r\n  }\r\n  disable(...names: string[]) {\r\n    names.forEach(n => this.form.get(n).disable({ emitEvent: false }));\r\n  }\r\n  enable(...names: string[]) {\r\n    names.forEach(n => this.form.get(n).enable({ emitEvent: false }));\r\n  }\r\n  closeView(evt?: Event) {\r\n    this.view = null;\r\n    this.state = null;\r\n    evt?.preventDefault();\r\n    evt?.stopPropagation();\r\n  }\r\n  drop(event: CdkDragDrop<FormGroup>, collection: FormArray) {\r\n    const element = collection.at(event.previousIndex);\r\n    collection.removeAt(event.previousIndex);\r\n    collection.insert(event.currentIndex, element);\r\n  }\r\n  add(collection: FormArray, group: FormGroup, title: string, template: TemplateRef<any>) {\r\n    collection.push(group);\r\n    this.view = template;\r\n    this.context = {\r\n      title,\r\n      $implicit: group\r\n    };\r\n    this.state = 1;\r\n    this._focus();\r\n  }\r\n  edit(group: FormGroup, title: string, template: TemplateRef<any>) {\r\n    this.view = template;\r\n    this.state = 2;\r\n    this.context = {\r\n      title,\r\n      $implicit: group,\r\n    };\r\n    this._focus();\r\n  }\r\n  private _focus() {\r\n    setTimeout(() => this._element.nativeElement.querySelector('input')?.focus());\r\n  }\r\n}\r\n@Directive()\r\nexport abstract class DesignerTypeElementComponent<T = any> extends DesignerElementComponentBase {\r\n  ngOnInit() {\r\n  }\r\n  @ViewChild(DesignerItemComponent) designer: DesignerItemComponent;\r\n  constructor(protected _fb: FormBuilder,\r\n    element: ElementRef<any>,\r\n    @Inject(DesignerRef) protected _ref: DesignerRef<T>) {\r\n    super(_fb, element, _ref)\r\n    this.mode = _ref.mode;\r\n    this.model = _ref.model as ElementModel;\r\n  }\r\n}\r\nfunction applyMixins(derivedCtor: any, constructors: any[]) {\r\n  constructors.forEach((baseCtor) => {\r\n    Object.getOwnPropertyNames(baseCtor.prototype).forEach((name) => {\r\n      Object.defineProperty(\r\n        derivedCtor.prototype,\r\n        name,\r\n        Object.getOwnPropertyDescriptor(baseCtor.prototype, name) ||\r\n        Object.create(null)\r\n      );\r\n    });\r\n  });\r\n}\r\n/** */\r\n@Directive()\r\nexport abstract class DesignerCubeElementComponent<T = any> extends DesignerElementComponentBase<T> implements OnInit {\r\n  readonly cubes: ElementModel[];\r\n  cube: ElementModel;\r\n  sortComparator = (a, b) => 0;\r\n  cubeSelected(evt: MatSelectChange) {\r\n    this.cube = evt.value;\r\n    this.form.get('cube').setValue((evt.value as ElementModel).name);\r\n  }\r\n  constructor(fb: FormBuilder,\r\n    element: ElementRef<any>,\r\n    @Inject(DesignerRef) ref: DesignerRef) {\r\n    super(fb, element, ref);\r\n    this.cubes = ref.designer.cubes as ElementModel[];\r\n  }\r\n  ngOnInit() {\r\n    const cubeId = this.options['cube'];\r\n    if (cubeId) this.cube = this.cubes.find(c => c.name === cubeId) as ElementModel;\r\n    else\r\n      if (this.cubes.length === 1) this.cube = this.cubes[0] as ElementModel;\r\n  }\r\n}\r\nexport function isAccum(chartType) {\r\n  switch (chartType) {\r\n    case 'Pie':\r\n    case 'Doughnut':\r\n    case 'HalfDoughnut':\r\n    case 'Funnel':\r\n      return true;\r\n  }\r\n}\r\n"]}
|
@@ -204,6 +204,10 @@ let ConfigurationDesignerComponent = class ConfigurationDesignerComponent {
|
|
204
204
|
};
|
205
205
|
this._insert(section, element, section.elements.length);
|
206
206
|
}
|
207
|
+
remove(section, element) {
|
208
|
+
section.elements.remove(element);
|
209
|
+
this.dirty = true;
|
210
|
+
}
|
207
211
|
copy(section, element) {
|
208
212
|
let eclone = {
|
209
213
|
...element,
|
@@ -211,7 +215,7 @@ let ConfigurationDesignerComponent = class ConfigurationDesignerComponent {
|
|
211
215
|
draft: true
|
212
216
|
};
|
213
217
|
delete eclone.injector;
|
214
|
-
delete eclone.
|
218
|
+
delete eclone.resourceType;
|
215
219
|
eclone = clone(eclone); // deep
|
216
220
|
this._insert(section, eclone, section.elements.indexOf(element));
|
217
221
|
}
|
@@ -224,7 +228,7 @@ let ConfigurationDesignerComponent = class ConfigurationDesignerComponent {
|
|
224
228
|
}
|
225
229
|
save() {
|
226
230
|
this.saving = true;
|
227
|
-
const { policies, actions, cubes, folders, forms, guides, reports, roles, rules, states, types, utilities, views, widgets, nodes } = this.model;
|
231
|
+
const { controls, attributes, policies, actions, cubes, folders, forms, guides, reports, roles, rules, states, types, utilities, views, widgets, nodes } = this.model;
|
228
232
|
const model = {
|
229
233
|
actions: strip(actions),
|
230
234
|
cubes: strip(cubes),
|
@@ -240,7 +244,9 @@ let ConfigurationDesignerComponent = class ConfigurationDesignerComponent {
|
|
240
244
|
utilities: strip(utilities),
|
241
245
|
views: strip(views),
|
242
246
|
nodes: strip(nodes),
|
243
|
-
widgets: strip(widgets)
|
247
|
+
widgets: strip(widgets),
|
248
|
+
controls: strip(controls),
|
249
|
+
attributes: strip(attributes)
|
244
250
|
};
|
245
251
|
return this._ref.execute(model).toPromise().then(() => {
|
246
252
|
this._ps.toast('ChangesSaved');
|
@@ -265,16 +271,16 @@ let ConfigurationDesignerComponent = class ConfigurationDesignerComponent {
|
|
265
271
|
}
|
266
272
|
};
|
267
273
|
ConfigurationDesignerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: ConfigurationDesignerComponent, deps: [{ token: i1.PanesRouter }, { token: i2.TranslateService }, { token: i3.PromptService }, { token: i4.SessionService }, { token: i0.ElementRef }, { token: i0.Injector }, { token: i5.UtilityRef }], target: i0.ɵɵFactoryTarget.Component });
|
268
|
-
ConfigurationDesignerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.5", type: ConfigurationDesignerComponent, selector: "ng-component", host: { attributes: { "tabindex": "0" }, listeners: { "keydown": "handleKeyboardEvent($event)" } }, ngImport: i0, template: "<mat-toolbar>\r\n <button mat-icon-button (click)=\"save()\" [disabled]=\"!dirty || loading || saving\" [bizdocTooltip]=\"'Save'|translate\"><mat-icon>save</mat-icon></button>\r\n <span class=\"divider\"></span>\r\n <button mat-icon-button (click)=\"clearSearch()\" [disabled]=\"!searchBy\" [bizdocTooltip]=\"'Clear'|translate\"><mat-icon>search_off</mat-icon></button>\r\n</mat-toolbar>\r\n<mat-progress-bar [mode]=\"loading ? 'buffer' : 'indeterminate'\" [style.visibility]=\"loading ? 'visible':'hidden'\"></mat-progress-bar>\r\n<bizdoc-none *ngIf=\"loading\" title=\"SettingThingsUp\" [subtitle]=\"PleaseWait\" icon=\"architecture\"></bizdoc-none>\r\n<section *ngFor=\"let s of sections\">\r\n <h2 class=\"mat-title\">{{s.type | translate}}</h2>\r\n <div class=\"elements\" cdkDropList cdkDropListOrientation=\"horizontal\" [cdkDropListData]=\"s.elements\" (cdkDropListDropped)=\"drop($event)\">\r\n <mat-card *ngFor=\"let e of s.elements\" [class.disabled]=\"e.disabled\" cdkDrag cdkDragRootElement=\".mat-card-title\">\r\n <!-- @item-->\r\n <mat-card-title>\r\n {{e.title|localizedString}}\r\n <span class=\"divider\"></span>\r\n <mat-icon [bizdocTooltip]=\"e.help\" [bizdocTooltipDuration]=\"6000\" *ngIf=\"e.help\">help_outline</mat-icon>\r\n </mat-card-title>\r\n <mat-card-subtitle>\r\n {{e.name}}\r\n </mat-card-subtitle>\r\n <mat-card-content>\r\n <ng-container *ngComponentOutlet=\"s.comp; injector: e.injector\"></ng-container>\r\n </mat-card-content>\r\n <mat-card-actions fxLayout=\"row\">\r\n <button mat-icon-button (click)=\"copy(s, e)\" *ngIf=\"!e.copyOf\" [bizdocTooltip]=\"'Copy'|translate\"><mat-icon>file_copy</mat-icon></button>\r\n <button mat-icon-button (click)=\"
|
274
|
+
ConfigurationDesignerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.5", type: ConfigurationDesignerComponent, selector: "ng-component", host: { attributes: { "tabindex": "0" }, listeners: { "keydown": "handleKeyboardEvent($event)" } }, ngImport: i0, template: "<mat-toolbar>\r\n <button mat-icon-button (click)=\"save()\" [disabled]=\"!dirty || loading || saving\" [bizdocTooltip]=\"'Save'|translate\"><mat-icon>save</mat-icon></button>\r\n <span class=\"divider\"></span>\r\n <button mat-icon-button (click)=\"clearSearch()\" [disabled]=\"!searchBy\" [bizdocTooltip]=\"'Clear'|translate\"><mat-icon>search_off</mat-icon></button>\r\n</mat-toolbar>\r\n<mat-progress-bar [mode]=\"loading ? 'buffer' : 'indeterminate'\" [style.visibility]=\"loading ? 'visible':'hidden'\"></mat-progress-bar>\r\n<bizdoc-none *ngIf=\"loading\" title=\"SettingThingsUp\" [subtitle]=\"PleaseWait\" icon=\"architecture\"></bizdoc-none>\r\n<section *ngFor=\"let s of sections\">\r\n <h2 class=\"mat-title\">{{s.type | translate}}</h2>\r\n <div class=\"elements\" cdkDropList cdkDropListOrientation=\"horizontal\" [cdkDropListData]=\"s.elements\" (cdkDropListDropped)=\"drop($event)\">\r\n <mat-card *ngFor=\"let e of s.elements\" [class.disabled]=\"e.disabled\" cdkDrag cdkDragRootElement=\".mat-card-title\">\r\n <!-- @item-->\r\n <mat-card-title>\r\n {{e.title|localizedString}}\r\n <span class=\"divider\"></span>\r\n <mat-icon [bizdocTooltip]=\"e.help\" [bizdocTooltipDuration]=\"6000\" *ngIf=\"e.help\">help_outline</mat-icon>\r\n </mat-card-title>\r\n <mat-card-subtitle>\r\n {{e.name}}\r\n </mat-card-subtitle>\r\n <mat-card-content>\r\n <ng-container *ngComponentOutlet=\"s.comp; injector: e.injector\"></ng-container>\r\n </mat-card-content>\r\n <mat-card-actions fxLayout=\"row\">\r\n <button mat-icon-button (click)=\"copy(s, e)\" *ngIf=\"!e.copyOf\" [bizdocTooltip]=\"'Copy'|translate\"><mat-icon>file_copy</mat-icon></button>\r\n <button mat-icon-button (click)=\"remove(s, e)\" *ngIf=\"e.draft || e.empty\" [bizdocTooltip]=\"'Discard'|translate\"><mat-icon>delete</mat-icon></button>\r\n <button mat-icon-button (click)=\"toggleDisabled(e)\" [bizdocTooltip]=\"(e.disabled ? 'Enable' : 'Disable')|translate\"><mat-icon>{{e.disabled ? 'visibility' : 'visibility_off'}}</mat-icon></button>\r\n <span class=\"divider\"></span>\r\n <button mat-icon-button (click)=\"edit(e, s)\" [bizdocTooltip]=\"'Settings'|translate\"><mat-icon>settings</mat-icon></button>\r\n </mat-card-actions>\r\n </mat-card>\r\n <div class=\"add-element\" matRipple (click)=\"add(s, menuTrigger, $event)\" *ngIf=\"s.templates?.length\">\r\n <span [matMenuTriggerFor]=\"templateMenu\" #menuTrigger=\"matMenuTrigger\"></span>\r\n <button mat-icon-button><mat-icon [bizdocTooltip]=\"'New'|translate\" disableRipple=\"true\">add</mat-icon></button>\r\n <mat-menu #templateMenu>\r\n <button mat-menu-item *ngFor=\"let t of s.templates\" (click)=\"create(s, t)\">\r\n <span *ngIf=\"t.family\">\r\n {{t.family}}\r\n - \r\n </span>\r\n <span>\r\n {{t.title}}\r\n </span>\r\n </button>\r\n </mat-menu>\r\n </div>\r\n </div>\r\n</section>\r\n", styles: [":host{outline:none}section h2{margin:0 8px;position:sticky}section .elements{display:flex;flex-wrap:wrap}section .elements .disabled{opacity:.5;background-color:transparent}section .add-element{border:2px dashed gray;min-width:126px;min-height:126px;border-radius:3px;margin:1px 0 6px;text-align:center}section .add-element button{top:50%;transform:translateY(-50%)}:host ::ng-deep .mat-card{margin:0 6px 6px;display:flex;flex-direction:column}:host ::ng-deep .mat-card button{opacity:.1}:host ::ng-deep .mat-card:hover button{opacity:1}:host ::ng-deep .mat-card-header-text{width:100%}:host ::ng-deep .mat-card-title{display:flex;flex-direction:row;align-items:center}.divider{min-width:3px}:host ::ng-deep .mat-card-content{flex:1}\n"], dependencies: [{ kind: "directive", type: i6.NgComponentOutlet, selector: "[ngComponentOutlet]", inputs: ["ngComponentOutlet", "ngComponentOutletInjector", "ngComponentOutletContent", "ngComponentOutletNgModule", "ngComponentOutletNgModuleFactory"] }, { kind: "directive", type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i7.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { kind: "directive", type: i8.CdkDropList, selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "cdkDropListData", "cdkDropListOrientation", "id", "cdkDropListLockAxis", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListAutoScrollDisabled", "cdkDropListAutoScrollStep"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { kind: "directive", type: i8.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "component", type: i9.MatCard, selector: "mat-card", exportAs: ["matCard"] }, { kind: "directive", type: i9.MatCardContent, selector: "mat-card-content, [mat-card-content], [matCardContent]" }, { kind: "directive", type: i9.MatCardTitle, selector: "mat-card-title, [mat-card-title], [matCardTitle]" }, { kind: "directive", type: i9.MatCardSubtitle, selector: "mat-card-subtitle, [mat-card-subtitle], [matCardSubtitle]" }, { kind: "directive", type: i9.MatCardActions, selector: "mat-card-actions", inputs: ["align"], exportAs: ["matCardActions"] }, { kind: "directive", type: i10.MatRipple, selector: "[mat-ripple], [matRipple]", inputs: ["matRippleColor", "matRippleUnbounded", "matRippleCentered", "matRippleRadius", "matRippleAnimation", "matRippleDisabled", "matRippleTrigger"], exportAs: ["matRipple"] }, { kind: "component", type: i11.MatProgressBar, selector: "mat-progress-bar", inputs: ["color", "value", "bufferValue", "mode"], outputs: ["animationEnd"], exportAs: ["matProgressBar"] }, { kind: "component", type: i12.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }, { kind: "component", type: i13.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"] }, { kind: "component", type: i14.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i15.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { kind: "component", type: i15.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i15.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { kind: "directive", type: i16.TooltipDirective, selector: "[bizdocTooltip]", inputs: ["bizdocTooltip", "bizdocTooltipTemplate", "bizdocTooltipContext", "bizdocTooltipPosition", "bizdocTooltipDuration", "bizdocTooltipDisabled"] }, { kind: "pipe", type: i17.LocalizedStringPipe, name: "localizedString" }, { kind: "pipe", type: i18.TranslatePipe, name: "translate" }], animations: [itemAnimation] });
|
269
275
|
ConfigurationDesignerComponent = __decorate([
|
270
276
|
BizDoc({ selector: 'bizdoc-configuration-designer' })
|
271
277
|
], ConfigurationDesignerComponent);
|
272
278
|
export { ConfigurationDesignerComponent };
|
273
279
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.5", ngImport: i0, type: ConfigurationDesignerComponent, decorators: [{
|
274
280
|
type: Component,
|
275
|
-
args: [{ animations: [itemAnimation], host: { tabindex: '0' }, template: "<mat-toolbar>\r\n <button mat-icon-button (click)=\"save()\" [disabled]=\"!dirty || loading || saving\" [bizdocTooltip]=\"'Save'|translate\"><mat-icon>save</mat-icon></button>\r\n <span class=\"divider\"></span>\r\n <button mat-icon-button (click)=\"clearSearch()\" [disabled]=\"!searchBy\" [bizdocTooltip]=\"'Clear'|translate\"><mat-icon>search_off</mat-icon></button>\r\n</mat-toolbar>\r\n<mat-progress-bar [mode]=\"loading ? 'buffer' : 'indeterminate'\" [style.visibility]=\"loading ? 'visible':'hidden'\"></mat-progress-bar>\r\n<bizdoc-none *ngIf=\"loading\" title=\"SettingThingsUp\" [subtitle]=\"PleaseWait\" icon=\"architecture\"></bizdoc-none>\r\n<section *ngFor=\"let s of sections\">\r\n <h2 class=\"mat-title\">{{s.type | translate}}</h2>\r\n <div class=\"elements\" cdkDropList cdkDropListOrientation=\"horizontal\" [cdkDropListData]=\"s.elements\" (cdkDropListDropped)=\"drop($event)\">\r\n <mat-card *ngFor=\"let e of s.elements\" [class.disabled]=\"e.disabled\" cdkDrag cdkDragRootElement=\".mat-card-title\">\r\n <!-- @item-->\r\n <mat-card-title>\r\n {{e.title|localizedString}}\r\n <span class=\"divider\"></span>\r\n <mat-icon [bizdocTooltip]=\"e.help\" [bizdocTooltipDuration]=\"6000\" *ngIf=\"e.help\">help_outline</mat-icon>\r\n </mat-card-title>\r\n <mat-card-subtitle>\r\n {{e.name}}\r\n </mat-card-subtitle>\r\n <mat-card-content>\r\n <ng-container *ngComponentOutlet=\"s.comp; injector: e.injector\"></ng-container>\r\n </mat-card-content>\r\n <mat-card-actions fxLayout=\"row\">\r\n <button mat-icon-button (click)=\"copy(s, e)\" *ngIf=\"!e.copyOf\" [bizdocTooltip]=\"'Copy'|translate\"><mat-icon>file_copy</mat-icon></button>\r\n <button mat-icon-button (click)=\"
|
281
|
+
args: [{ animations: [itemAnimation], host: { tabindex: '0' }, template: "<mat-toolbar>\r\n <button mat-icon-button (click)=\"save()\" [disabled]=\"!dirty || loading || saving\" [bizdocTooltip]=\"'Save'|translate\"><mat-icon>save</mat-icon></button>\r\n <span class=\"divider\"></span>\r\n <button mat-icon-button (click)=\"clearSearch()\" [disabled]=\"!searchBy\" [bizdocTooltip]=\"'Clear'|translate\"><mat-icon>search_off</mat-icon></button>\r\n</mat-toolbar>\r\n<mat-progress-bar [mode]=\"loading ? 'buffer' : 'indeterminate'\" [style.visibility]=\"loading ? 'visible':'hidden'\"></mat-progress-bar>\r\n<bizdoc-none *ngIf=\"loading\" title=\"SettingThingsUp\" [subtitle]=\"PleaseWait\" icon=\"architecture\"></bizdoc-none>\r\n<section *ngFor=\"let s of sections\">\r\n <h2 class=\"mat-title\">{{s.type | translate}}</h2>\r\n <div class=\"elements\" cdkDropList cdkDropListOrientation=\"horizontal\" [cdkDropListData]=\"s.elements\" (cdkDropListDropped)=\"drop($event)\">\r\n <mat-card *ngFor=\"let e of s.elements\" [class.disabled]=\"e.disabled\" cdkDrag cdkDragRootElement=\".mat-card-title\">\r\n <!-- @item-->\r\n <mat-card-title>\r\n {{e.title|localizedString}}\r\n <span class=\"divider\"></span>\r\n <mat-icon [bizdocTooltip]=\"e.help\" [bizdocTooltipDuration]=\"6000\" *ngIf=\"e.help\">help_outline</mat-icon>\r\n </mat-card-title>\r\n <mat-card-subtitle>\r\n {{e.name}}\r\n </mat-card-subtitle>\r\n <mat-card-content>\r\n <ng-container *ngComponentOutlet=\"s.comp; injector: e.injector\"></ng-container>\r\n </mat-card-content>\r\n <mat-card-actions fxLayout=\"row\">\r\n <button mat-icon-button (click)=\"copy(s, e)\" *ngIf=\"!e.copyOf\" [bizdocTooltip]=\"'Copy'|translate\"><mat-icon>file_copy</mat-icon></button>\r\n <button mat-icon-button (click)=\"remove(s, e)\" *ngIf=\"e.draft || e.empty\" [bizdocTooltip]=\"'Discard'|translate\"><mat-icon>delete</mat-icon></button>\r\n <button mat-icon-button (click)=\"toggleDisabled(e)\" [bizdocTooltip]=\"(e.disabled ? 'Enable' : 'Disable')|translate\"><mat-icon>{{e.disabled ? 'visibility' : 'visibility_off'}}</mat-icon></button>\r\n <span class=\"divider\"></span>\r\n <button mat-icon-button (click)=\"edit(e, s)\" [bizdocTooltip]=\"'Settings'|translate\"><mat-icon>settings</mat-icon></button>\r\n </mat-card-actions>\r\n </mat-card>\r\n <div class=\"add-element\" matRipple (click)=\"add(s, menuTrigger, $event)\" *ngIf=\"s.templates?.length\">\r\n <span [matMenuTriggerFor]=\"templateMenu\" #menuTrigger=\"matMenuTrigger\"></span>\r\n <button mat-icon-button><mat-icon [bizdocTooltip]=\"'New'|translate\" disableRipple=\"true\">add</mat-icon></button>\r\n <mat-menu #templateMenu>\r\n <button mat-menu-item *ngFor=\"let t of s.templates\" (click)=\"create(s, t)\">\r\n <span *ngIf=\"t.family\">\r\n {{t.family}}\r\n - \r\n </span>\r\n <span>\r\n {{t.title}}\r\n </span>\r\n </button>\r\n </mat-menu>\r\n </div>\r\n </div>\r\n</section>\r\n", styles: [":host{outline:none}section h2{margin:0 8px;position:sticky}section .elements{display:flex;flex-wrap:wrap}section .elements .disabled{opacity:.5;background-color:transparent}section .add-element{border:2px dashed gray;min-width:126px;min-height:126px;border-radius:3px;margin:1px 0 6px;text-align:center}section .add-element button{top:50%;transform:translateY(-50%)}:host ::ng-deep .mat-card{margin:0 6px 6px;display:flex;flex-direction:column}:host ::ng-deep .mat-card button{opacity:.1}:host ::ng-deep .mat-card:hover button{opacity:1}:host ::ng-deep .mat-card-header-text{width:100%}:host ::ng-deep .mat-card-title{display:flex;flex-direction:row;align-items:center}.divider{min-width:3px}:host ::ng-deep .mat-card-content{flex:1}\n"] }]
|
276
282
|
}], ctorParameters: function () { return [{ type: i1.PanesRouter }, { type: i2.TranslateService }, { type: i3.PromptService }, { type: i4.SessionService }, { type: i0.ElementRef }, { type: i0.Injector }, { type: i5.UtilityRef }]; }, propDecorators: { handleKeyboardEvent: [{
|
277
283
|
type: HostListener,
|
278
284
|
args: ['keydown', ['$event']]
|
279
285
|
}] } });
|
280
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"designer.component.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/admin/architecture/designer.component.ts","../../../../../../libraries/core/src/lib/admin/architecture/designer.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkDragDrop, moveItemInArray } from \"@angular/cdk/drag-drop\";\r\nimport { ESCAPE, SPACE } from \"@angular/cdk/keycodes\";\r\nimport { ComponentType } from \"@angular/cdk/portal\";\r\nimport { Component, ElementRef, HostListener, Injector, OnInit } from \"@angular/core\";\r\nimport { MatMenuTrigger } from \"@angular/material/menu\";\r\nimport { itemAnimation } from \"../../core/animations\";\r\nimport { UtilityComponent } from \"../../core/base\";\r\nimport { OpenPolicy } from \"../../core/configuration\";\r\nimport { BizDoc } from \"../../core/decorators\";\r\nimport { cleanup } from \"../../core/functions\";\r\nimport { PromptService } from \"../../core/prompt.service\";\r\nimport { SessionService } from \"../../core/session.service\";\r\nimport { PanesRouter } from \"../../core/slots/router.service\";\r\nimport { TranslateService } from \"../../core/translate.service\";\r\nimport { UtilityRef } from \"../utility-ref\";\r\nimport { ElementModel, DesignerModel, TemplateInfo, programName, DesignerRef, clone, DesignMode } from \"./declarations\";\r\nimport { DesignerTypeElementComponent } from \"./designer.base\";\r\nimport { ActionDesignerComponent } from \"./elements/action.component\";\r\nimport { AttributeDesignComponent } from \"./elements/attribute.component\";\r\nimport { ControlDesignComponent } from \"./elements/control.component\";\r\nimport { CubeDesignComponent } from \"./elements/cube.component\";\r\nimport { FolderDesignComponent } from \"./elements/folder.component\";\r\nimport { FormDesignComponent } from \"./elements/form.component\";\r\nimport { GuideDesignComponent } from \"./elements/guide.component\";\r\nimport { NodeDesignerComponent } from \"./elements/node.component\";\r\nimport { PolicyDesignComponent } from \"./elements/policy.component\";\r\nimport { ReportDesignerComponent } from \"./elements/report.component\";\r\nimport { RoleDesignComponent } from \"./elements/role.component\";\r\nimport { RuleDesignComponent } from \"./elements/rule.component\";\r\nimport { StateDesignComponent } from \"./elements/state.component\";\r\nimport { TypeDesignComponent } from \"./elements/type.component\";\r\nimport { UtilityDesignComponent } from \"./elements/utility.component\";\r\nimport { ViewDesignComponent } from \"./elements/view.component\";\r\nimport { WidgetDesignComponent } from \"./elements/widget.component\";\r\nconst CHARACTER = /[\\w]|Spacebar/;\r\n/** */\r\n@Component({\r\n  templateUrl: 'designer.component.html',\r\n  styleUrls: ['designer.component.scss'],\r\n  animations: [itemAnimation],\r\n  host: { tabindex: '0' }\r\n})\r\n@BizDoc({ selector: 'bizdoc-configuration-designer' })\r\nexport class ConfigurationDesignerComponent implements UtilityComponent, OnInit {\r\n  searchBy: string;\r\n  loading = true;\r\n  saving = false;\r\n  dirty = false;\r\n  sections: Section[];\r\n  model: DesignerModel;\r\n  private _typingTimer: any;\r\n  private _clearTimer: any;\r\n  private _sections: Section[];\r\n  constructor(\r\n    private _panes: PanesRouter,\r\n    private _translate: TranslateService,\r\n    private _ps: PromptService,\r\n    private _session: SessionService,\r\n    private _element: ElementRef<HTMLDivElement>,\r\n    private _injector: Injector,\r\n    private _ref: UtilityRef<boolean, DesignerModel, DesignerModel>) { }\r\n  ngOnInit(): void {\r\n    this._ref.populate().subscribe(r => {\r\n      this.model = r;\r\n      this.sections = this._sections = [\r\n        { elements: r.forms, type: 'Forms', comp: FormDesignComponent, templates: r.tForms },\r\n        { elements: r.actions, type: 'Actions', comp: ActionDesignerComponent, templates: r.tActions },\r\n        { elements: r.reports, type: 'Reports', comp: ReportDesignerComponent, templates: r.tReports },\r\n        { elements: r.widgets, type: 'Widgets', comp: WidgetDesignComponent, templates: r.tWidgets },\r\n        { elements: r.views, type: 'Views', comp: ViewDesignComponent, templates: r.tViews },\r\n        { elements: r.guides, type: 'Guides', comp: GuideDesignComponent, templates: [{ title: this._translate.get('Guide') }] },\r\n        { elements: r.cubes, type: 'Cubes', comp: CubeDesignComponent, templates: r.tCubes },\r\n        { elements: r.folders, type: 'Folders', comp: FolderDesignComponent, templates: [{ title: this._translate.get('Folder') }] },\r\n        { elements: r.roles, type: 'Roles', comp: RoleDesignComponent, templates: [{ title: this._translate.get('Role') }] },\r\n        { elements: r.states, type: 'States', comp: StateDesignComponent, templates: [{ title: this._translate.get('State') }] },\r\n        { elements: r.utilities, type: 'Tools', comp: UtilityDesignComponent, templates: r.tUtilities },\r\n        { elements: r.types, type: 'Types', comp: TypeDesignComponent, templates: r.tTypes },\r\n        { elements: r.nodes, type: 'Nodes', comp: NodeDesignerComponent, templates: r.tNodes },\r\n        { elements: r.attributes, type: 'Attributes', comp: AttributeDesignComponent, templates: r.tAttributes },\r\n        { elements: r.policies, type: 'Policies', comp: PolicyDesignComponent, templates: r.tPolicies },\r\n        { elements: r.controls, type: 'Controls', comp: ControlDesignComponent, templates: [] },\r\n        { elements: r.rules, type: 'Rules', comp: RuleDesignComponent, templates: r.tRules },\r\n      ];\r\n      this.sections.forEach(s =>\r\n        s.elements.forEach(e => {\r\n          if (!e.options) e.options = {};\r\n\r\n          e.injector = this._createInjector(e, 'widget');\r\n        })\r\n      );\r\n      this.loading = false;\r\n    });\r\n    // typing keydown listener\r\n    this._element.nativeElement.focus();\r\n  }\r\n  drop(event: CdkDragDrop<ElementModel[]>) {\r\n    const range = event.container.data.slice(\r\n      Math.min(event.previousIndex, event.currentIndex),\r\n      Math.max(event.previousIndex, event.currentIndex)\r\n    ), file = range[0].configurationFile;\r\n    if\r\n      // across files\r\n      (range.slice(1).some(e => e.configurationFile !== file)) {\r\n      // start ordinal\r\n      let i = event.container.data[event.currentIndex].ordinal || -1;\r\n      // set ordinal to items in range\r\n      range.forEach(e => e.ordinal = i++);\r\n      // increase other higher than last in range\r\n      event.container.data.filter(e => e.ordinal && e.ordinal > i).forEach(e => e.ordinal += 1);\r\n    } else // native order in collection\r\n      range.forEach(e => e.ordinal = null);\r\n    moveItemInArray(event.container.data, event.previousIndex, event.currentIndex);\r\n  }\r\n  /**\r\n   * Ctrl-s save, search\r\n   * @param event\r\n   */\r\n  @HostListener('keydown', ['$event'])\r\n  handleKeyboardEvent(event: KeyboardEvent) {\r\n    if (event.ctrlKey && (event.which === 83 || event.which === 115)) {\r\n      this.dirty && this.save();\r\n      event.preventDefault();\r\n      event.stopPropagation();\r\n    } else if (this.searchBy && event.which === ESCAPE) this.clearSearch();\r\n    else if (event.code.startsWith('Key') || event.which == SPACE) {\r\n      clearTimeout(this._typingTimer);\r\n      //clearTimeout(this._clearTimer);\r\n      this.searchBy = this.searchBy ? this.searchBy + event.key : event.key;\r\n      this._typingTimer = setTimeout(() =>\r\n        this.sections = this._search(this.searchBy), 150);\r\n    }\r\n  }\r\n  clearSearch() {\r\n    this.searchBy = null;\r\n    this.sections = this._sections;\r\n    clearTimeout(this._typingTimer);\r\n  }\r\n  private _search(value: string) {\r\n    const sections: Section[] = [];\r\n    this._sections.forEach(s => {\r\n      const elements = s.elements.\r\n        filter(e => (e.title || e.name).toLowerCase().\r\n          indexOf(value) > -1);\r\n      if (elements.length) {\r\n        const { comp, templates, type } = s;\r\n        sections.push({ elements, comp, templates, type });\r\n      }\r\n    });\r\n    //this._clearTimer = setTimeout(() => this.searchBy = null, 5000);\r\n    return sections;\r\n  }\r\n  private _insert(section: Section, element: ElementModel, index: number) {\r\n    let i = element.name.lastIndexOf('_'),\r\n      j = element.title.lastIndexOf(' '),\r\n      n = 0, name, title;\r\n    do {\r\n      n++;\r\n      name = (i < 0 || isNaN(parseInt(element.name.substr(i + 1))) ? element.name : element.name.substr(0, i)) + '_' + n;\r\n      title = (j < 0 || isNaN(parseInt(element.title.substr(j + 1))) ? element.title : element.title.substr(0, j)) + ' ' + n;\r\n    }\r\n    while (section.elements.find(e => e.name === name || e.title === title));\r\n    element.name = name, element.title = title;\r\n\r\n    const injector = this._createInjector(element, 'widget');\r\n    element.injector = injector;\r\n    this._open(element, section, 'add').then(() =>\r\n      section.elements.splice(index + 1, 0, element)\r\n    );\r\n  }\r\n  private _open(element: ElementModel,\r\n    section: Section,\r\n    mode: DesignMode, title?: string) {\r\n    let eclone = { ...element };\r\n    delete eclone.injector;\r\n    eclone = clone(eclone); // deep\r\n    const injector = this._createInjector(eclone, mode);\r\n    return new Promise((resolve, reject) => this._panes.navigate<DesignerTypeElementComponent>(section.comp, {\r\n      policy: mode === 'add' ? OpenPolicy.Dialog | OpenPolicy.Stretch : OpenPolicy.Tab | OpenPolicy.Toggle,\r\n      group: this._translate.get(section.type),\r\n      //title,\r\n      injector: injector\r\n    }).then(pane => {\r\n      pane.instance.designer.onSave.subscribe(el => {\r\n        if (el) {\r\n          Object.assign(element, el);\r\n          this.dirty = true;\r\n          resolve(el);\r\n        }\r\n        else reject();\r\n        pane.close();\r\n      });\r\n      pane.closed().subscribe(() => this._element.nativeElement.focus());\r\n    }));\r\n  }\r\n  private _createInjector(element: ElementModel<any>, mode: DesignMode) {\r\n    const ref = new DesignerRef(this.model, element, mode);\r\n\r\n    const injector = Injector.create([{\r\n      provide: DesignerRef, useValue: ref\r\n    }], this._injector);\r\n    return injector;\r\n  }\r\n  add(section: Section, menu: MatMenuTrigger, evt: Event) {\r\n    if (section.templates.length > 1)\r\n      menu.openMenu();\r\n    else {\r\n      this.create(section, section.templates[0]);\r\n    }\r\n    evt.preventDefault();\r\n  }\r\n  create(section: Section, template: TemplateInfo) {\r\n    const element = {\r\n      ...template,\r\n      name: programName(template.key || template.title),\r\n      draft: true,\r\n      options: {}\r\n    } as ElementModel;\r\n    this._insert(section, element, section.elements.length);\r\n  }\r\n  copy(section: Section, element: ElementModel) {\r\n    let eclone = {\r\n      ...element,\r\n      copyOf: element.name,\r\n      draft: true\r\n    };\r\n    delete eclone.injector;\r\n    delete eclone.resource;\r\n    eclone = clone(eclone); // deep\r\n    this._insert(section, eclone, section.elements.indexOf(element));\r\n  }\r\n  edit(element: ElementModel, section: Section) {\r\n    this._open(element, section, 'edit');\r\n  }\r\n  toggleDisabled(element: ElementModel) {\r\n    element.disabled = !element.disabled;\r\n    this.dirty = true;\r\n  }\r\n  save() {\r\n    this.saving = true;\r\n    const { policies, actions, cubes, folders, forms, guides, reports, roles, rules, states, types, utilities, views, widgets, nodes } = this.model;\r\n    const model = {\r\n      actions: strip(actions),\r\n      cubes: strip(cubes),\r\n      folders: strip(folders),\r\n      forms: strip(forms),\r\n      guides: strip(guides),\r\n      reports: strip(reports),\r\n      roles: strip(roles),\r\n      rules: strip(rules),\r\n      policies: strip(policies),\r\n      states: strip(states),\r\n      types: strip(types),\r\n      utilities: strip(utilities),\r\n      views: strip(views),\r\n      nodes: strip(nodes),\r\n      widgets: strip(widgets)\r\n    };\r\n    return this._ref.execute(\r\n      model as any).toPromise().then(() => {\r\n        this._ps.toast('ChangesSaved');\r\n        apply(policies, actions, cubes, folders, forms, guides, reports, roles, rules, states, types, utilities, views, widgets);\r\n        this.saving = false;\r\n        this.dirty = false\r\n        this._session.refresh().subscribe();\r\n      }, () => {\r\n        this._ps.error();\r\n        this.saving = false\r\n      });\r\n    function strip(elements: ElementModel[]) {\r\n      return elements.map(e => {\r\n        const element = { ...e };\r\n        delete element.injector;\r\n        return cleanup(element);\r\n      });\r\n    }\r\n    function apply(...collection: ElementModel[][]) {\r\n      collection.forEach(s => s.forEach(e => delete e.draft));\r\n    }\r\n  }\r\n}\r\ninterface Section {\r\n  comp: ComponentType<any>;\r\n  type: string;\r\n  elements: ElementModel[];\r\n  templates: TemplateInfo[];\r\n}\r\n","<mat-toolbar>\r\n  <button mat-icon-button (click)=\"save()\" [disabled]=\"!dirty || loading || saving\" [bizdocTooltip]=\"'Save'|translate\"><mat-icon>save</mat-icon></button>\r\n  <span class=\"divider\"></span>\r\n  <button mat-icon-button (click)=\"clearSearch()\" [disabled]=\"!searchBy\" [bizdocTooltip]=\"'Clear'|translate\"><mat-icon>search_off</mat-icon></button>\r\n</mat-toolbar>\r\n<mat-progress-bar [mode]=\"loading ? 'buffer' : 'indeterminate'\" [style.visibility]=\"loading ? 'visible':'hidden'\"></mat-progress-bar>\r\n<bizdoc-none *ngIf=\"loading\" title=\"SettingThingsUp\" [subtitle]=\"PleaseWait\" icon=\"architecture\"></bizdoc-none>\r\n<section *ngFor=\"let s of sections\">\r\n  <h2 class=\"mat-title\">{{s.type | translate}}</h2>\r\n  <div class=\"elements\" cdkDropList cdkDropListOrientation=\"horizontal\" [cdkDropListData]=\"s.elements\" (cdkDropListDropped)=\"drop($event)\">\r\n    <mat-card *ngFor=\"let e of s.elements\" [class.disabled]=\"e.disabled\" cdkDrag cdkDragRootElement=\".mat-card-title\">\r\n      <!-- @item-->\r\n      <mat-card-title>\r\n        {{e.title|localizedString}}\r\n        <span class=\"divider\"></span>\r\n        <mat-icon [bizdocTooltip]=\"e.help\" [bizdocTooltipDuration]=\"6000\" *ngIf=\"e.help\">help_outline</mat-icon>\r\n      </mat-card-title>\r\n      <mat-card-subtitle>\r\n        {{e.name}}\r\n      </mat-card-subtitle>\r\n      <mat-card-content>\r\n        <ng-container *ngComponentOutlet=\"s.comp; injector: e.injector\"></ng-container>\r\n      </mat-card-content>\r\n      <mat-card-actions fxLayout=\"row\">\r\n        <button mat-icon-button (click)=\"copy(s, e)\" *ngIf=\"!e.copyOf\" [bizdocTooltip]=\"'Copy'|translate\"><mat-icon>file_copy</mat-icon></button>\r\n        <button mat-icon-button (click)=\"s.elements.remove(e)\" *ngIf=\"e.draft || e.empty\" [bizdocTooltip]=\"'Discard'|translate\"><mat-icon>delete</mat-icon></button>\r\n        <button mat-icon-button (click)=\"toggleDisabled(e)\" [bizdocTooltip]=\"(e.disabled ? 'Enable' : 'Disable')|translate\"><mat-icon>{{e.disabled ? 'visibility' : 'visibility_off'}}</mat-icon></button>\r\n        <span class=\"divider\"></span>\r\n        <button mat-icon-button (click)=\"edit(e, s)\" [bizdocTooltip]=\"'Settings'|translate\"><mat-icon>settings</mat-icon></button>\r\n      </mat-card-actions>\r\n    </mat-card>\r\n    <div class=\"add-element\" matRipple (click)=\"add(s, menuTrigger, $event)\" *ngIf=\"s.templates?.length\">\r\n      <span [matMenuTriggerFor]=\"templateMenu\" #menuTrigger=\"matMenuTrigger\"></span>\r\n      <button mat-icon-button><mat-icon [bizdocTooltip]=\"'New'|translate\" disableRipple=\"true\">add</mat-icon></button>\r\n      <mat-menu #templateMenu>\r\n        <button mat-menu-item *ngFor=\"let t of s.templates\" (click)=\"create(s, t)\">\r\n          <span *ngIf=\"t.family\">\r\n            {{t.family}}\r\n            &nbsp;-&nbsp;\r\n          </span>\r\n          <span>\r\n            {{t.title}}\r\n          </span>\r\n        </button>\r\n      </mat-menu>\r\n    </div>\r\n  </div>\r\n</section>\r\n"]}
|
286
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"designer.component.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/admin/architecture/designer.component.ts","../../../../../../libraries/core/src/lib/admin/architecture/designer.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkDragDrop, moveItemInArray } from \"@angular/cdk/drag-drop\";\r\nimport { ESCAPE, SPACE } from \"@angular/cdk/keycodes\";\r\nimport { ComponentType } from \"@angular/cdk/portal\";\r\nimport { Component, ElementRef, HostListener, Injector, OnInit } from \"@angular/core\";\r\nimport { MatMenuTrigger } from \"@angular/material/menu\";\r\nimport { itemAnimation } from \"../../core/animations\";\r\nimport { UtilityComponent } from \"../../core/base\";\r\nimport { OpenPolicy } from \"../../core/configuration\";\r\nimport { BizDoc } from \"../../core/decorators\";\r\nimport { cleanup } from \"../../core/functions\";\r\nimport { PromptService } from \"../../core/prompt.service\";\r\nimport { SessionService } from \"../../core/session.service\";\r\nimport { PanesRouter } from \"../../core/slots/router.service\";\r\nimport { TranslateService } from \"../../core/translate.service\";\r\nimport { UtilityRef } from \"../utility-ref\";\r\nimport { ElementModel, DesignerModel, TemplateInfo, programName, DesignerRef, clone, DesignMode } from \"./declarations\";\r\nimport { DesignerTypeElementComponent } from \"./designer.base\";\r\nimport { ActionDesignerComponent } from \"./elements/action.component\";\r\nimport { AttributeDesignComponent } from \"./elements/attribute.component\";\r\nimport { ControlDesignComponent } from \"./elements/control.component\";\r\nimport { CubeDesignComponent } from \"./elements/cube.component\";\r\nimport { FolderDesignComponent } from \"./elements/folder.component\";\r\nimport { FormDesignComponent } from \"./elements/form.component\";\r\nimport { GuideDesignComponent } from \"./elements/guide.component\";\r\nimport { NodeDesignerComponent } from \"./elements/node.component\";\r\nimport { PolicyDesignComponent } from \"./elements/policy.component\";\r\nimport { ReportDesignerComponent } from \"./elements/report.component\";\r\nimport { RoleDesignComponent } from \"./elements/role.component\";\r\nimport { RuleDesignComponent } from \"./elements/rule.component\";\r\nimport { StateDesignComponent } from \"./elements/state.component\";\r\nimport { TypeDesignComponent } from \"./elements/type.component\";\r\nimport { UtilityDesignComponent } from \"./elements/utility.component\";\r\nimport { ViewDesignComponent } from \"./elements/view.component\";\r\nimport { WidgetDesignComponent } from \"./elements/widget.component\";\r\nconst CHARACTER = /[\\w]|Spacebar/;\r\n/** */\r\n@Component({\r\n  templateUrl: 'designer.component.html',\r\n  styleUrls: ['designer.component.scss'],\r\n  animations: [itemAnimation],\r\n  host: { tabindex: '0' }\r\n})\r\n@BizDoc({ selector: 'bizdoc-configuration-designer' })\r\nexport class ConfigurationDesignerComponent implements UtilityComponent, OnInit {\r\n  searchBy: string;\r\n  loading = true;\r\n  saving = false;\r\n  dirty = false;\r\n  sections: Section[];\r\n  model: DesignerModel;\r\n  private _typingTimer: any;\r\n  private _clearTimer: any;\r\n  private _sections: Section[];\r\n  constructor(\r\n    private _panes: PanesRouter,\r\n    private _translate: TranslateService,\r\n    private _ps: PromptService,\r\n    private _session: SessionService,\r\n    private _element: ElementRef<HTMLDivElement>,\r\n    private _injector: Injector,\r\n    private _ref: UtilityRef<boolean, DesignerModel, DesignerModel>) { }\r\n  ngOnInit(): void {\r\n    this._ref.populate().subscribe(r => {\r\n      this.model = r;\r\n      this.sections = this._sections = [\r\n        { elements: r.forms, type: 'Forms', comp: FormDesignComponent, templates: r.tForms },\r\n        { elements: r.actions, type: 'Actions', comp: ActionDesignerComponent, templates: r.tActions },\r\n        { elements: r.reports, type: 'Reports', comp: ReportDesignerComponent, templates: r.tReports },\r\n        { elements: r.widgets, type: 'Widgets', comp: WidgetDesignComponent, templates: r.tWidgets },\r\n        { elements: r.views, type: 'Views', comp: ViewDesignComponent, templates: r.tViews },\r\n        { elements: r.guides, type: 'Guides', comp: GuideDesignComponent, templates: [{ title: this._translate.get('Guide') }] },\r\n        { elements: r.cubes, type: 'Cubes', comp: CubeDesignComponent, templates: r.tCubes },\r\n        { elements: r.folders, type: 'Folders', comp: FolderDesignComponent, templates: [{ title: this._translate.get('Folder') }] },\r\n        { elements: r.roles, type: 'Roles', comp: RoleDesignComponent, templates: [{ title: this._translate.get('Role') }] },\r\n        { elements: r.states, type: 'States', comp: StateDesignComponent, templates: [{ title: this._translate.get('State') }] },\r\n        { elements: r.utilities, type: 'Tools', comp: UtilityDesignComponent, templates: r.tUtilities },\r\n        { elements: r.types, type: 'Types', comp: TypeDesignComponent, templates: r.tTypes },\r\n        { elements: r.nodes, type: 'Nodes', comp: NodeDesignerComponent, templates: r.tNodes },\r\n        { elements: r.attributes, type: 'Attributes', comp: AttributeDesignComponent, templates: r.tAttributes },\r\n        { elements: r.policies, type: 'Policies', comp: PolicyDesignComponent, templates: r.tPolicies },\r\n        { elements: r.controls, type: 'Controls', comp: ControlDesignComponent, templates: [] },\r\n        { elements: r.rules, type: 'Rules', comp: RuleDesignComponent, templates: r.tRules },\r\n      ];\r\n      this.sections.forEach(s =>\r\n        s.elements.forEach(e => {\r\n          if (!e.options) e.options = {};\r\n\r\n          e.injector = this._createInjector(e, 'widget');\r\n        })\r\n      );\r\n      this.loading = false;\r\n    });\r\n    // typing keydown listener\r\n    this._element.nativeElement.focus();\r\n  }\r\n  drop(event: CdkDragDrop<ElementModel[]>) {\r\n    const range = event.container.data.slice(\r\n      Math.min(event.previousIndex, event.currentIndex),\r\n      Math.max(event.previousIndex, event.currentIndex)\r\n    ), file = range[0].configurationFile;\r\n    if\r\n      // across files\r\n      (range.slice(1).some(e => e.configurationFile !== file)) {\r\n      // start ordinal\r\n      let i = event.container.data[event.currentIndex].ordinal || -1;\r\n      // set ordinal to items in range\r\n      range.forEach(e => e.ordinal = i++);\r\n      // increase other higher than last in range\r\n      event.container.data.filter(e => e.ordinal && e.ordinal > i).forEach(e => e.ordinal += 1);\r\n    } else // native order in collection\r\n      range.forEach(e => e.ordinal = null);\r\n    moveItemInArray(event.container.data, event.previousIndex, event.currentIndex);\r\n  }\r\n  /**\r\n   * Ctrl-s save, search\r\n   * @param event\r\n   */\r\n  @HostListener('keydown', ['$event'])\r\n  handleKeyboardEvent(event: KeyboardEvent) {\r\n    if (event.ctrlKey && (event.which === 83 || event.which === 115)) {\r\n      this.dirty && this.save();\r\n      event.preventDefault();\r\n      event.stopPropagation();\r\n    } else if (this.searchBy && event.which === ESCAPE) this.clearSearch();\r\n    else if (event.code.startsWith('Key') || event.which == SPACE) {\r\n      clearTimeout(this._typingTimer);\r\n      //clearTimeout(this._clearTimer);\r\n      this.searchBy = this.searchBy ? this.searchBy + event.key : event.key;\r\n      this._typingTimer = setTimeout(() =>\r\n        this.sections = this._search(this.searchBy), 150);\r\n    }\r\n  }\r\n  clearSearch() {\r\n    this.searchBy = null;\r\n    this.sections = this._sections;\r\n    clearTimeout(this._typingTimer);\r\n  }\r\n  private _search(value: string) {\r\n    const sections: Section[] = [];\r\n    this._sections.forEach(s => {\r\n      const elements = s.elements.\r\n        filter(e => (e.title || e.name).toLowerCase().\r\n          indexOf(value) > -1);\r\n      if (elements.length) {\r\n        const { comp, templates, type } = s;\r\n        sections.push({ elements, comp, templates, type });\r\n      }\r\n    });\r\n    //this._clearTimer = setTimeout(() => this.searchBy = null, 5000);\r\n    return sections;\r\n  }\r\n  private _insert(section: Section, element: ElementModel, index: number) {\r\n    let i = element.name.lastIndexOf('_'),\r\n      j = element.title.lastIndexOf(' '),\r\n      n = 0, name, title;\r\n    do {\r\n      n++;\r\n      name = (i < 0 || isNaN(parseInt(element.name.substr(i + 1))) ? element.name : element.name.substr(0, i)) + '_' + n;\r\n      title = (j < 0 || isNaN(parseInt(element.title.substr(j + 1))) ? element.title : element.title.substr(0, j)) + ' ' + n;\r\n    }\r\n    while (section.elements.find(e => e.name === name || e.title === title));\r\n    element.name = name, element.title = title;\r\n\r\n    const injector = this._createInjector(element, 'widget');\r\n    element.injector = injector;\r\n    this._open(element, section, 'add').then(() =>\r\n      section.elements.splice(index + 1, 0, element)\r\n    );\r\n  }\r\n  private _open(element: ElementModel,\r\n    section: Section,\r\n    mode: DesignMode, title?: string) {\r\n    let eclone = { ...element };\r\n    delete eclone.injector;\r\n    eclone = clone(eclone); // deep\r\n    const injector = this._createInjector(eclone, mode);\r\n    return new Promise((resolve, reject) => this._panes.navigate<DesignerTypeElementComponent>(section.comp, {\r\n      policy: mode === 'add' ? OpenPolicy.Dialog | OpenPolicy.Stretch : OpenPolicy.Tab | OpenPolicy.Toggle,\r\n      group: this._translate.get(section.type),\r\n      //title,\r\n      injector: injector\r\n    }).then(pane => {\r\n      pane.instance.designer.onSave.subscribe(el => {\r\n        if (el) {\r\n          Object.assign(element, el);\r\n          this.dirty = true;\r\n          resolve(el);\r\n        }\r\n        else reject();\r\n        pane.close();\r\n      });\r\n      pane.closed().subscribe(() => this._element.nativeElement.focus());\r\n    }));\r\n  }\r\n  private _createInjector(element: ElementModel<any>, mode: DesignMode) {\r\n    const ref = new DesignerRef(this.model, element, mode);\r\n\r\n    const injector = Injector.create([{\r\n      provide: DesignerRef, useValue: ref\r\n    }], this._injector);\r\n    return injector;\r\n  }\r\n  add(section: Section, menu: MatMenuTrigger, evt: Event) {\r\n    if (section.templates.length > 1)\r\n      menu.openMenu();\r\n    else {\r\n      this.create(section, section.templates[0]);\r\n    }\r\n    evt.preventDefault();\r\n  }\r\n  create(section: Section, template: TemplateInfo) {\r\n    const element = {\r\n      ...template,\r\n      name: programName(template.key || template.title),\r\n      draft: true,\r\n      options: {}\r\n    } as ElementModel;\r\n    this._insert(section, element, section.elements.length);\r\n  }\r\n  remove(section: Section, element: ElementModel) {\r\n    section.elements.remove(element);\r\n    this.dirty = true;\r\n  }\r\n  copy(section: Section, element: ElementModel) {\r\n    let eclone = {\r\n      ...element,\r\n      copyOf: element.name,\r\n      draft: true\r\n    };\r\n    delete eclone.injector;\r\n    delete eclone.resourceType;\r\n    eclone = clone(eclone); // deep\r\n    this._insert(section, eclone, section.elements.indexOf(element));\r\n  }\r\n  edit(element: ElementModel, section: Section) {\r\n    this._open(element, section, 'edit');\r\n  }\r\n  toggleDisabled(element: ElementModel) {\r\n    element.disabled = !element.disabled;\r\n    this.dirty = true;\r\n  }\r\n  save() {\r\n    this.saving = true;\r\n    const { controls, attributes, policies, actions, cubes, folders, forms, guides, reports, roles, rules, states, types, utilities, views, widgets, nodes } = this.model;\r\n    const model = {\r\n      actions: strip(actions),\r\n      cubes: strip(cubes),\r\n      folders: strip(folders),\r\n      forms: strip(forms),\r\n      guides: strip(guides),\r\n      reports: strip(reports),\r\n      roles: strip(roles),\r\n      rules: strip(rules),\r\n      policies: strip(policies),\r\n      states: strip(states),\r\n      types: strip(types),\r\n      utilities: strip(utilities),\r\n      views: strip(views),\r\n      nodes: strip(nodes),\r\n      widgets: strip(widgets),\r\n      controls: strip(controls),\r\n      attributes: strip(attributes)\r\n    };\r\n    return this._ref.execute(\r\n      model as any).toPromise().then(() => {\r\n        this._ps.toast('ChangesSaved');\r\n        apply(policies, actions, cubes, folders, forms, guides, reports, roles, rules, states, types, utilities, views, widgets);\r\n        this.saving = false;\r\n        this.dirty = false\r\n        this._session.refresh().subscribe();\r\n      }, () => {\r\n        this._ps.error();\r\n        this.saving = false\r\n      });\r\n    function strip(elements: ElementModel[]) {\r\n      return elements.map(e => {\r\n        const element = { ...e };\r\n        delete element.injector;\r\n        return cleanup(element);\r\n      });\r\n    }\r\n    function apply(...collection: ElementModel[][]) {\r\n      collection.forEach(s => s.forEach(e => delete e.draft));\r\n    }\r\n  }\r\n}\r\ninterface Section {\r\n  comp: ComponentType<any>;\r\n  type: string;\r\n  elements: ElementModel[];\r\n  templates: TemplateInfo[];\r\n}\r\n","<mat-toolbar>\r\n  <button mat-icon-button (click)=\"save()\" [disabled]=\"!dirty || loading || saving\" [bizdocTooltip]=\"'Save'|translate\"><mat-icon>save</mat-icon></button>\r\n  <span class=\"divider\"></span>\r\n  <button mat-icon-button (click)=\"clearSearch()\" [disabled]=\"!searchBy\" [bizdocTooltip]=\"'Clear'|translate\"><mat-icon>search_off</mat-icon></button>\r\n</mat-toolbar>\r\n<mat-progress-bar [mode]=\"loading ? 'buffer' : 'indeterminate'\" [style.visibility]=\"loading ? 'visible':'hidden'\"></mat-progress-bar>\r\n<bizdoc-none *ngIf=\"loading\" title=\"SettingThingsUp\" [subtitle]=\"PleaseWait\" icon=\"architecture\"></bizdoc-none>\r\n<section *ngFor=\"let s of sections\">\r\n  <h2 class=\"mat-title\">{{s.type | translate}}</h2>\r\n  <div class=\"elements\" cdkDropList cdkDropListOrientation=\"horizontal\" [cdkDropListData]=\"s.elements\" (cdkDropListDropped)=\"drop($event)\">\r\n    <mat-card *ngFor=\"let e of s.elements\" [class.disabled]=\"e.disabled\" cdkDrag cdkDragRootElement=\".mat-card-title\">\r\n      <!-- @item-->\r\n      <mat-card-title>\r\n        {{e.title|localizedString}}\r\n        <span class=\"divider\"></span>\r\n        <mat-icon [bizdocTooltip]=\"e.help\" [bizdocTooltipDuration]=\"6000\" *ngIf=\"e.help\">help_outline</mat-icon>\r\n      </mat-card-title>\r\n      <mat-card-subtitle>\r\n        {{e.name}}\r\n      </mat-card-subtitle>\r\n      <mat-card-content>\r\n        <ng-container *ngComponentOutlet=\"s.comp; injector: e.injector\"></ng-container>\r\n      </mat-card-content>\r\n      <mat-card-actions fxLayout=\"row\">\r\n        <button mat-icon-button (click)=\"copy(s, e)\" *ngIf=\"!e.copyOf\" [bizdocTooltip]=\"'Copy'|translate\"><mat-icon>file_copy</mat-icon></button>\r\n        <button mat-icon-button (click)=\"remove(s, e)\" *ngIf=\"e.draft || e.empty\" [bizdocTooltip]=\"'Discard'|translate\"><mat-icon>delete</mat-icon></button>\r\n        <button mat-icon-button (click)=\"toggleDisabled(e)\" [bizdocTooltip]=\"(e.disabled ? 'Enable' : 'Disable')|translate\"><mat-icon>{{e.disabled ? 'visibility' : 'visibility_off'}}</mat-icon></button>\r\n        <span class=\"divider\"></span>\r\n        <button mat-icon-button (click)=\"edit(e, s)\" [bizdocTooltip]=\"'Settings'|translate\"><mat-icon>settings</mat-icon></button>\r\n      </mat-card-actions>\r\n    </mat-card>\r\n    <div class=\"add-element\" matRipple (click)=\"add(s, menuTrigger, $event)\" *ngIf=\"s.templates?.length\">\r\n      <span [matMenuTriggerFor]=\"templateMenu\" #menuTrigger=\"matMenuTrigger\"></span>\r\n      <button mat-icon-button><mat-icon [bizdocTooltip]=\"'New'|translate\" disableRipple=\"true\">add</mat-icon></button>\r\n      <mat-menu #templateMenu>\r\n        <button mat-menu-item *ngFor=\"let t of s.templates\" (click)=\"create(s, t)\">\r\n          <span *ngIf=\"t.family\">\r\n            {{t.family}}\r\n            &nbsp;-&nbsp;\r\n          </span>\r\n          <span>\r\n            {{t.title}}\r\n          </span>\r\n        </button>\r\n      </mat-menu>\r\n    </div>\r\n  </div>\r\n</section>\r\n"]}
|