@bizdoc/core 1.16.13 → 1.16.14
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/admin/configuration-designer/cube-axes-filter.component.mjs +5 -7
- package/esm2020/lib/admin/configuration-designer/declarations.mjs +1 -1
- package/esm2020/lib/admin/configuration-designer/designer-element.component.mjs +7 -5
- package/esm2020/lib/admin/configuration-designer/designer-privileges.component.mjs +12 -9
- package/esm2020/lib/admin/configuration-designer/designer.base.mjs +55 -45
- package/esm2020/lib/admin/configuration-designer/designer.component.mjs +8 -5
- package/esm2020/lib/admin/configuration-designer/elements/analysis-view.component.mjs +5 -5
- package/esm2020/lib/admin/configuration-designer/elements/analysis-widget.component.mjs +5 -5
- package/esm2020/lib/admin/configuration-designer/elements/anomaly-rule.component.mjs +1 -1
- package/esm2020/lib/admin/configuration-designer/elements/cube-view.component.mjs +3 -3
- package/esm2020/lib/admin/configuration-designer/elements/cube.component.mjs +13 -40
- package/esm2020/lib/admin/configuration-designer/elements/documents-report.component.mjs +5 -4
- package/esm2020/lib/admin/configuration-designer/elements/documents-widget.component.mjs +15 -16
- package/esm2020/lib/admin/configuration-designer/elements/explore-view.component.mjs +7 -6
- package/esm2020/lib/admin/configuration-designer/elements/folder.component.mjs +3 -3
- package/esm2020/lib/admin/configuration-designer/elements/form.component.mjs +5 -5
- package/esm2020/lib/admin/configuration-designer/elements/guide.component.mjs +16 -18
- package/esm2020/lib/admin/configuration-designer/elements/matrix-view.component.mjs +27 -14
- package/esm2020/lib/admin/configuration-designer/elements/parallel-view.component.mjs +6 -7
- package/esm2020/lib/admin/configuration-designer/elements/performance-widget.component.mjs +5 -4
- package/esm2020/lib/admin/configuration-designer/elements/pivot-view.component.mjs +3 -3
- package/esm2020/lib/admin/configuration-designer/elements/report.component.mjs +3 -3
- package/esm2020/lib/admin/configuration-designer/elements/role.component.mjs +2 -2
- package/esm2020/lib/admin/configuration-designer/elements/sum-view.component.mjs +3 -3
- package/esm2020/lib/admin/configuration-designer/elements/tasks-report.component.mjs +5 -4
- package/esm2020/lib/admin/configuration-designer/elements/usage-report.component.mjs +3 -3
- package/esm2020/lib/admin/form/workflow/node.component.mjs +3 -3
- package/esm2020/lib/compose/action/action.pane.dialog.exp.mjs +2 -1
- package/esm2020/lib/core/layout/layout.component.mjs +10 -12
- package/esm2020/lib/core/translations.mjs +8 -1
- package/esm2020/lib/dashboard/widget-item.component.mjs +3 -4
- package/esm2020/lib/reports/arguments-component.mjs +3 -3
- package/fesm2015/bizdoc-core.mjs +237 -236
- package/fesm2015/bizdoc-core.mjs.map +1 -1
- package/fesm2020/bizdoc-core.mjs +235 -233
- package/fesm2020/bizdoc-core.mjs.map +1 -1
- package/lib/admin/configuration-designer/declarations.d.ts +1 -0
- package/lib/admin/configuration-designer/designer.base.d.ts +17 -16
- package/lib/admin/configuration-designer/designer.component.d.ts +2 -1
- package/lib/admin/configuration-designer/elements/analysis-view.component.d.ts +1 -1
- package/lib/admin/configuration-designer/elements/analysis-widget.component.d.ts +2 -2
- package/lib/admin/configuration-designer/elements/anomaly-rule.component.d.ts +1 -4
- package/lib/admin/configuration-designer/elements/cube.component.d.ts +2 -11
- package/lib/admin/configuration-designer/elements/documents-widget.component.d.ts +2 -3
- package/lib/admin/configuration-designer/elements/explore-view.component.d.ts +2 -2
- package/lib/admin/configuration-designer/elements/form.component.d.ts +6 -6
- package/lib/admin/configuration-designer/elements/guide.component.d.ts +2 -3
- package/lib/admin/configuration-designer/elements/matrix-view.component.d.ts +5 -4
- package/lib/admin/configuration-designer/elements/parallel-view.component.d.ts +2 -2
- package/lib/core/layout/layout.component.d.ts +3 -3
- package/lib/core/translations.d.ts +7 -0
- package/package.json +1 -1
@@ -1,5 +1,4 @@
|
|
1
1
|
import { Directive, Inject, ViewChild } from "@angular/core";
|
2
|
-
import { isArray } from "../../core/functions";
|
3
2
|
import { DesignerRef } from "./declarations";
|
4
3
|
import { DesignerItemComponent } from "./designer-element.component";
|
5
4
|
import * as i0 from "@angular/core";
|
@@ -7,99 +6,110 @@ import * as i1 from "@angular/forms";
|
|
7
6
|
import * as i2 from "./declarations";
|
8
7
|
/** */
|
9
8
|
export class DesignerElementComponentBase {
|
10
|
-
constructor(_fb, _ref) {
|
9
|
+
constructor(_fb, _element, _ref) {
|
11
10
|
this._fb = _fb;
|
11
|
+
this._element = _element;
|
12
12
|
this._ref = _ref;
|
13
13
|
}
|
14
14
|
get options() { return this.model.options; }
|
15
|
+
disable(...names) {
|
16
|
+
names.forEach(n => this.form.get(n).disable({ emitEvent: false }));
|
17
|
+
}
|
18
|
+
enable(...names) {
|
19
|
+
names.forEach(n => this.form.get(n).enable({ emitEvent: false }));
|
20
|
+
}
|
21
|
+
closeView(evt) {
|
22
|
+
this.view = null;
|
23
|
+
this._ref._state$.next(null);
|
24
|
+
evt?.preventDefault();
|
25
|
+
evt?.stopPropagation();
|
26
|
+
}
|
15
27
|
drop(event, collection) {
|
16
28
|
const element = collection.at(event.previousIndex);
|
17
29
|
collection.removeAt(event.previousIndex);
|
18
30
|
collection.insert(event.currentIndex, element);
|
19
31
|
}
|
20
|
-
|
21
|
-
|
32
|
+
add(collection, group, title, template) {
|
33
|
+
collection.push(group);
|
34
|
+
this.view = template;
|
35
|
+
this.context = {
|
36
|
+
title,
|
37
|
+
$implicit: group
|
38
|
+
};
|
39
|
+
this._ref._state$.next(1);
|
40
|
+
this._focus();
|
22
41
|
}
|
23
|
-
|
24
|
-
|
42
|
+
edit(group, title, template) {
|
43
|
+
this.view = template;
|
44
|
+
this.context = {
|
45
|
+
title,
|
46
|
+
$implicit: group,
|
47
|
+
};
|
48
|
+
this._ref._state$.next(1);
|
49
|
+
this._focus();
|
50
|
+
}
|
51
|
+
_focus() {
|
52
|
+
setTimeout(() => this._element.nativeElement.querySelector('input')?.focus());
|
25
53
|
}
|
26
54
|
}
|
27
|
-
DesignerElementComponentBase.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: DesignerElementComponentBase, deps: [{ token: i1.FormBuilder }, { token: DesignerRef }], target: i0.ɵɵFactoryTarget.Directive });
|
55
|
+
DesignerElementComponentBase.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: DesignerElementComponentBase, deps: [{ token: i1.FormBuilder }, { token: i0.ElementRef }, { token: DesignerRef }], target: i0.ɵɵFactoryTarget.Directive });
|
28
56
|
DesignerElementComponentBase.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.6", type: DesignerElementComponentBase, ngImport: i0 });
|
29
57
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: DesignerElementComponentBase, decorators: [{
|
30
58
|
type: Directive
|
31
|
-
}], ctorParameters: function () { return [{ type: i1.FormBuilder }, { type: i2.DesignerRef, decorators: [{
|
59
|
+
}], ctorParameters: function () { return [{ type: i1.FormBuilder }, { type: i0.ElementRef }, { type: i2.DesignerRef, decorators: [{
|
32
60
|
type: Inject,
|
33
61
|
args: [DesignerRef]
|
34
62
|
}] }]; } });
|
35
63
|
export class DesignerTypeElementComponent extends DesignerElementComponentBase {
|
36
|
-
constructor(_fb, _ref) {
|
37
|
-
super(_fb, _ref);
|
64
|
+
constructor(_fb, element, _ref) {
|
65
|
+
super(_fb, element, _ref);
|
38
66
|
this._fb = _fb;
|
39
67
|
this._ref = _ref;
|
40
68
|
this.mode = _ref.mode;
|
41
69
|
this.model = _ref.model;
|
42
70
|
}
|
43
71
|
}
|
44
|
-
DesignerTypeElementComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: DesignerTypeElementComponent, deps: [{ token: i1.FormBuilder }, { token: DesignerRef }], target: i0.ɵɵFactoryTarget.Directive });
|
72
|
+
DesignerTypeElementComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: DesignerTypeElementComponent, deps: [{ token: i1.FormBuilder }, { token: i0.ElementRef }, { token: DesignerRef }], target: i0.ɵɵFactoryTarget.Directive });
|
45
73
|
DesignerTypeElementComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.6", type: DesignerTypeElementComponent, viewQueries: [{ propertyName: "designer", first: true, predicate: DesignerItemComponent, descendants: true }], usesInheritance: true, ngImport: i0 });
|
46
74
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: DesignerTypeElementComponent, decorators: [{
|
47
75
|
type: Directive
|
48
|
-
}], ctorParameters: function () { return [{ type: i1.FormBuilder }, { type: i2.DesignerRef, decorators: [{
|
76
|
+
}], ctorParameters: function () { return [{ type: i1.FormBuilder }, { type: i0.ElementRef }, { type: i2.DesignerRef, decorators: [{
|
49
77
|
type: Inject,
|
50
78
|
args: [DesignerRef]
|
51
79
|
}] }]; }, propDecorators: { designer: [{
|
52
80
|
type: ViewChild,
|
53
81
|
args: [DesignerItemComponent]
|
54
82
|
}] } });
|
83
|
+
function applyMixins(derivedCtor, constructors) {
|
84
|
+
constructors.forEach((baseCtor) => {
|
85
|
+
Object.getOwnPropertyNames(baseCtor.prototype).forEach((name) => {
|
86
|
+
Object.defineProperty(derivedCtor.prototype, name, Object.getOwnPropertyDescriptor(baseCtor.prototype, name) ||
|
87
|
+
Object.create(null));
|
88
|
+
});
|
89
|
+
});
|
90
|
+
}
|
55
91
|
/** */
|
56
92
|
export class DesignerCubeElementComponent extends DesignerElementComponentBase {
|
57
|
-
constructor(fb, ref) {
|
58
|
-
super(fb, ref);
|
93
|
+
constructor(fb, element, ref) {
|
94
|
+
super(fb, element, ref);
|
59
95
|
this.cubes = ref.designer.cubes;
|
60
96
|
}
|
61
|
-
_secondaryAxes(axis) {
|
62
|
-
if (!axis)
|
63
|
-
return;
|
64
|
-
this.secondaryAxes = this.cube.axes.filter(a => isArray(axis) ? axis.indexOf(a.name) < 0 : axis !== a.name);
|
65
|
-
}
|
66
|
-
_thirdAxes(axis) {
|
67
|
-
if (!axis)
|
68
|
-
return;
|
69
|
-
this.thirdAxes = this.secondaryAxes.filter(a => isArray(axis) ? axis.indexOf(a.name) < 0 : a.name !== axis);
|
70
|
-
}
|
71
|
-
_forthAxes(axis) {
|
72
|
-
if (!axis)
|
73
|
-
return;
|
74
|
-
this.forthAxes = this.thirdAxes.filter(a => isArray(axis) ? axis.indexOf(a.name) < 0 : a.name !== axis);
|
75
|
-
}
|
76
97
|
cubeSelected(evt) {
|
77
98
|
this.cube = evt.value;
|
78
99
|
this.form.get('cube').setValue(evt.value.name);
|
79
100
|
}
|
80
|
-
xAxisSelected(evt) {
|
81
|
-
this._secondaryAxes(evt.value);
|
82
|
-
}
|
83
|
-
seriesSelected(evt) {
|
84
|
-
this._thirdAxes(evt.value);
|
85
|
-
}
|
86
|
-
forthSelected(evt) {
|
87
|
-
this._forthAxes(evt.value);
|
88
|
-
}
|
89
101
|
ngOnInit() {
|
90
102
|
const cubeId = this.options['cube'];
|
91
103
|
this.cube = !cubeId ? this.cubes[0] : this.cubes.find(c => c.name === cubeId);
|
92
|
-
if (this.
|
93
|
-
|
94
|
-
this.options['series'] && this._thirdAxes(this.options['series']);
|
95
|
-
}
|
104
|
+
// if (this.mode !== 'widget') {
|
105
|
+
// }
|
96
106
|
}
|
97
107
|
}
|
98
|
-
DesignerCubeElementComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: DesignerCubeElementComponent, deps: [{ token: i1.FormBuilder }, { token: DesignerRef }], target: i0.ɵɵFactoryTarget.Directive });
|
108
|
+
DesignerCubeElementComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: DesignerCubeElementComponent, deps: [{ token: i1.FormBuilder }, { token: i0.ElementRef }, { token: DesignerRef }], target: i0.ɵɵFactoryTarget.Directive });
|
99
109
|
DesignerCubeElementComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.6", type: DesignerCubeElementComponent, usesInheritance: true, ngImport: i0 });
|
100
110
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: DesignerCubeElementComponent, decorators: [{
|
101
111
|
type: Directive
|
102
|
-
}], ctorParameters: function () { return [{ type: i1.FormBuilder }, { type: i2.DesignerRef, decorators: [{
|
112
|
+
}], ctorParameters: function () { return [{ type: i1.FormBuilder }, { type: i0.ElementRef }, { type: i2.DesignerRef, decorators: [{
|
103
113
|
type: Inject,
|
104
114
|
args: [DesignerRef]
|
105
115
|
}] }]; } });
|
@@ -112,4 +122,4 @@ export function isAccum(chartType) {
|
|
112
122
|
return true;
|
113
123
|
}
|
114
124
|
}
|
115
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"designer.base.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/admin/configuration-designer/designer.base.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, Inject, OnInit, ViewChild } from \"@angular/core\";\r\nimport { FormArray, FormBuilder, FormGroup } from \"@angular/forms\";\r\nimport { CdkDragDrop } from \"@angular/cdk/drag-drop\";\r\nimport { MatSelectChange } from \"@angular/material/select\";\r\nimport { isArray } from \"../../core/functions\";\r\nimport { DesignerElementComponent, DesignMode, ElementModel, DesignerRef, CubeAxisModel } 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  get options(): T { return this.model.options }\r\n  abstract form: FormGroup;\r\n  constructor(protected _fb: FormBuilder,\r\n    @Inject(DesignerRef) protected _ref: DesignerRef<T>) {\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  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}\r\n@Directive()\r\nexport abstract class DesignerTypeElementComponent<T = any> extends DesignerElementComponentBase<T> {\r\n  @ViewChild(DesignerItemComponent) designer: DesignerItemComponent;\r\n  constructor(protected _fb: FormBuilder,\r\n    @Inject(DesignerRef) protected _ref: DesignerRef<T>) {\r\n    super(_fb, _ref);\r\n    this.mode = _ref.mode;\r\n    this.model = _ref.model as ElementModel;\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  secondaryAxes: CubeAxisModel[];\r\n  thirdAxes: CubeAxisModel[];\r\n  forthAxes: CubeAxisModel[];\r\n  protected _secondaryAxes(axis: string[] | string) {\r\n    if (!axis) return;\r\n    this.secondaryAxes = this.cube.axes.filter(a => isArray(axis) ? axis.indexOf(a.name) < 0 : axis !== a.name);\r\n  }\r\n  protected _thirdAxes(axis: string[] | string) {\r\n    if (!axis) return;\r\n    this.thirdAxes = this.secondaryAxes.filter(a => isArray(axis) ? axis.indexOf(a.name) < 0 : a.name !== axis);\r\n  }\r\n  protected _forthAxes(axis: string[] | string) {\r\n    if (!axis) return;\r\n    this.forthAxes = this.thirdAxes.filter(a => isArray(axis) ? axis.indexOf(a.name) < 0 : a.name !== axis);\r\n  }\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  xAxisSelected(evt: MatSelectChange) {\r\n    this._secondaryAxes(evt.value);\r\n  }\r\n  seriesSelected(evt: MatSelectChange) {\r\n    this._thirdAxes(evt.value);\r\n  }\r\n  forthSelected(evt: MatSelectChange) {\r\n    this._forthAxes(evt.value);\r\n  }\r\n  constructor(fb: FormBuilder,\r\n    @Inject(DesignerRef) ref: DesignerRef) {\r\n    super(fb, ref);\r\n    this.cubes = ref.designer.cubes as ElementModel[];\r\n  }\r\n  ngOnInit() {\r\n    const cubeId = this.options['cube'];\r\n    this.cube = !cubeId ? this.cubes[0] as ElementModel : this.cubes.find(c => c.name === cubeId) as ElementModel;\r\n    if (this.options['xAxis']) {\r\n      this._secondaryAxes(this.options['xAxis']);\r\n      this.options['series'] && this._thirdAxes(this.options['series']);\r\n    }\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"]}
|
125
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"designer.base.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/admin/configuration-designer/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 } 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  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._ref._state$.next(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._ref._state$.next(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._ref._state$.next(1);\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  @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  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    this.cube = !cubeId ? this.cubes[0] as ElementModel : this.cubes.find(c => c.name === cubeId) as ElementModel;\r\n  //  if (this.mode !== 'widget') {\r\n  //  }\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"]}
|
@@ -96,12 +96,15 @@ let ConfigurationDesignerComponent = class ConfigurationDesignerComponent {
|
|
96
96
|
* @param event
|
97
97
|
*/
|
98
98
|
handleKeyboardEvent(event) {
|
99
|
-
if (
|
100
|
-
this.save();
|
99
|
+
if (event.ctrlKey && (event.which === 83 || event.which === 115)) {
|
100
|
+
this.dirty && this.save();
|
101
101
|
event.preventDefault();
|
102
102
|
}
|
103
|
-
|
104
|
-
|
103
|
+
else {
|
104
|
+
clearTimeout(this._resettyping);
|
105
|
+
this._typing = this._typing ? this._typing + event.key : event.key;
|
106
|
+
this._resettyping = setTimeout(() => this._typing = null, 250);
|
107
|
+
}
|
105
108
|
}
|
106
109
|
_insert(section, element, index) {
|
107
110
|
let i = element.name.lastIndexOf('_'), j = element.title.lastIndexOf(' '), n = 0, name, title;
|
@@ -209,4 +212,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.6", ngImpor
|
|
209
212
|
type: HostListener,
|
210
213
|
args: ['document:keydown', ['$event']]
|
211
214
|
}] } });
|
212
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"designer.component.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/admin/configuration-designer/designer.component.ts","../../../../../../libraries/core/src/lib/admin/configuration-designer/designer.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkDragDrop, moveItemInArray } from \"@angular/cdk/drag-drop\";\r\nimport { ComponentType } from \"@angular/cdk/portal\";\r\nimport { Component, 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 { 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 { 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 { 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\n/** */\r\n@Component({\r\n  templateUrl: 'designer.component.html',\r\n  styleUrls: ['designer.component.scss'],\r\n  animations: [itemAnimation]\r\n})\r\n@BizDoc({ selector: 'bizdoc-configuration-designer' })\r\nexport class ConfigurationDesignerComponent implements UtilityComponent, OnInit {\r\n  loading = true;\r\n  saving = false;\r\n  dirty = false;\r\n  sections: Section[];\r\n  model: DesignerModel;\r\n  constructor(\r\n    private _panes: PanesRouter,\r\n    private _translate: TranslateService,\r\n    private _ps: PromptService,\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 = [\r\n        { elements: r.forms, type: 'Forms', comp: FormDesignComponent, templates: r.tForms, privileges: true },\r\n        { elements: r.actions, type: 'Actions', comp: ActionDesignerComponent, templates: r.tActions },\r\n        { elements: r.reports, type: 'Reports', comp: ReportDesignerComponent, templates: r.tReports, privileges: true },\r\n        { elements: r.widgets, type: 'Widgets', comp: WidgetDesignComponent, templates: r.tWidgets, privileges: true },\r\n        { elements: r.views, type: 'Views', comp: ViewDesignComponent, templates: r.tViews, privileges: true },\r\n        { elements: r.guides, type: 'Guides', comp: GuideDesignComponent, templates: [{ title: this._translate.get('Guide') }], privileges: true },\r\n        { elements: r.cubes, type: 'Cubes', comp: CubeDesignComponent, templates: r.tCubes, privileges: true },\r\n        { elements: r.folders, type: 'Folders', comp: FolderDesignComponent, templates: [{ title: this._translate.get('Folder') }], privileges: true },\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: 'Utilities', comp: UtilityDesignComponent, templates: r.tUtilities, privileges: true },\r\n        { elements: r.types, type: 'Types', comp: TypeDesignComponent, templates: r.tTypes },\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 (s.privileges && !e.privileges) e.privileges = {};\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  }\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\r\n   * @param event\r\n   */\r\n  @HostListener('document:keydown', ['$event'])\r\n  handleKeyboardEvent(event: KeyboardEvent) {\r\n    if (this.dirty && event.ctrlKey && (event.which === 83 || event.which === 115)) {\r\n      this.save();\r\n      event.preventDefault();\r\n    }\r\n\r\n  }\r\n  discard(section: Section, element: ElementModel) {\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: OpenPolicy.Dialog,\r\n      group: this._translate.get(section.type),\r\n      //title,\r\n      injector: injector\r\n    }).then(e =>\r\n      e.instance.designer.onSave.subscribe(e => {\r\n        if (e) {\r\n          Object.assign(element, e);\r\n          this.dirty = true;\r\n          resolve(e);\r\n        }\r\n        else reject();\r\n      })\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.title),\r\n      draft: true,\r\n      options: {}\r\n    } as ElementModel;\r\n    if (section.privileges) element.privileges = {};\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 { actions, cubes, folders, forms, guides, reports, roles, rules, states, types, utilities, views, widgets } = this.model;\r\n    return this._ref.execute(cleanup({ actions, cubes, folders, forms, guides, reports, roles, rules, states, types, utilities, views, widgets })).toPromise().then(() => {\r\n      this._ps.toast('ChangesSaved');\r\n      apply(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    }, () => {\r\n      this._ps.error();\r\n      this.saving = false\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  privileges?: boolean;\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</mat-toolbar>\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}}\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>\r\n            {{t.family}}\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"]}
|
215
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"designer.component.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/admin/configuration-designer/designer.component.ts","../../../../../../libraries/core/src/lib/admin/configuration-designer/designer.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkDragDrop, moveItemInArray } from \"@angular/cdk/drag-drop\";\r\nimport { ComponentType } from \"@angular/cdk/portal\";\r\nimport { Component, 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 { 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 { 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 { 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\n/** */\r\n@Component({\r\n  templateUrl: 'designer.component.html',\r\n  styleUrls: ['designer.component.scss'],\r\n  animations: [itemAnimation]\r\n})\r\n@BizDoc({ selector: 'bizdoc-configuration-designer' })\r\nexport class ConfigurationDesignerComponent implements UtilityComponent, OnInit {\r\n  loading = true;\r\n  saving = false;\r\n  dirty = false;\r\n  sections: Section[];\r\n  model: DesignerModel;\r\n  constructor(\r\n    private _panes: PanesRouter,\r\n    private _translate: TranslateService,\r\n    private _ps: PromptService,\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 = [\r\n        { elements: r.forms, type: 'Forms', comp: FormDesignComponent, templates: r.tForms, privileges: true },\r\n        { elements: r.actions, type: 'Actions', comp: ActionDesignerComponent, templates: r.tActions },\r\n        { elements: r.reports, type: 'Reports', comp: ReportDesignerComponent, templates: r.tReports, privileges: true },\r\n        { elements: r.widgets, type: 'Widgets', comp: WidgetDesignComponent, templates: r.tWidgets, privileges: true },\r\n        { elements: r.views, type: 'Views', comp: ViewDesignComponent, templates: r.tViews, privileges: true },\r\n        { elements: r.guides, type: 'Guides', comp: GuideDesignComponent, templates: [{ title: this._translate.get('Guide') }], privileges: true },\r\n        { elements: r.cubes, type: 'Cubes', comp: CubeDesignComponent, templates: r.tCubes, privileges: true },\r\n        { elements: r.folders, type: 'Folders', comp: FolderDesignComponent, templates: [{ title: this._translate.get('Folder') }], privileges: true },\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: 'Utilities', comp: UtilityDesignComponent, templates: r.tUtilities, privileges: true },\r\n        { elements: r.types, type: 'Types', comp: TypeDesignComponent, templates: r.tTypes },\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 (s.privileges && !e.privileges) e.privileges = {};\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  }\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  private _resettyping;\r\n  private _typing;\r\n  /**\r\n   * Ctrl-s save\r\n   * @param event\r\n   */\r\n  @HostListener('document: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    }\r\n    else {\r\n      clearTimeout(this._resettyping);\r\n      this._typing = this._typing ? this._typing + event.key : event.key\r\n      this._resettyping = setTimeout(()=> this._typing = null, 250);\r\n    }\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: OpenPolicy.Dialog,\r\n      group: this._translate.get(section.type),\r\n      //title,\r\n      injector: injector\r\n    }).then(e =>\r\n      e.instance.designer.onSave.subscribe(e => {\r\n        if (e) {\r\n          Object.assign(element, e);\r\n          this.dirty = true;\r\n          resolve(e);\r\n        }\r\n        else reject();\r\n      })\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.title),\r\n      draft: true,\r\n      options: {}\r\n    } as ElementModel;\r\n    if (section.privileges) element.privileges = {};\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 { actions, cubes, folders, forms, guides, reports, roles, rules, states, types, utilities, views, widgets } = this.model;\r\n    return this._ref.execute(cleanup({ actions, cubes, folders, forms, guides, reports, roles, rules, states, types, utilities, views, widgets })).toPromise().then(() => {\r\n      this._ps.toast('ChangesSaved');\r\n      apply(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    }, () => {\r\n      this._ps.error();\r\n      this.saving = false\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  privileges?: boolean;\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</mat-toolbar>\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}}\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>\r\n            {{t.family}}\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"]}
|
@@ -20,7 +20,7 @@ let ChartViewDesignComponent = class ChartViewDesignComponent extends DesignerCu
|
|
20
20
|
xAxis: this._fb.control(null, Validators.required),
|
21
21
|
series: null,
|
22
22
|
indices: null,
|
23
|
-
chartType:
|
23
|
+
chartType: 'Pie',
|
24
24
|
indicesChartType: null,
|
25
25
|
aggregate: null,
|
26
26
|
filters: this._fb.group({}),
|
@@ -29,7 +29,7 @@ let ChartViewDesignComponent = class ChartViewDesignComponent extends DesignerCu
|
|
29
29
|
}
|
30
30
|
ngOnInit() {
|
31
31
|
super.ngOnInit();
|
32
|
-
this.form.get('chartType').valueChanges.pipe(startWith(this.options.chartType)).subscribe(v => {
|
32
|
+
this.form.get('chartType').valueChanges.pipe(startWith(this.options.chartType || 'Pie')).subscribe(v => {
|
33
33
|
if (isAccum(v))
|
34
34
|
this.disable('indicesChartType', 'series', 'indices');
|
35
35
|
else
|
@@ -38,13 +38,13 @@ let ChartViewDesignComponent = class ChartViewDesignComponent extends DesignerCu
|
|
38
38
|
}
|
39
39
|
};
|
40
40
|
ChartViewDesignComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: ChartViewDesignComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
41
|
-
ChartViewDesignComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.6", type: ChartViewDesignComponent, selector: "ng-component", usesInheritance: true, ngImport: i0, template: "<ng-container *ngIf=\"mode === 'widget'; else edit\">\r\n</ng-container>\r\n<ng-template #edit>\r\n <form autocomplete=\"off\" [formGroup]=\"form\" class=\"column\">\r\n <mat-form-field *ngIf=\"cubes.length > 1\">\r\n <mat-label>{{'Cube'|translate}}</mat-label>\r\n <mat-select required (selectionChange)=\"cubeSelected($event)\">\r\n <mat-option *ngFor=\"let c of cubes\" [value]=\"c\">{{c.title}}</mat-option>\r\n </mat-select>\r\n </mat-form-field>\r\n <div class=\"row\">\r\n <mat-form-field class=\"flex\">\r\n <mat-label>{{'XAxis'|translate}}</mat-label>\r\n <mat-select formControlName=\"xAxis\" required multiple
|
41
|
+
ChartViewDesignComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.6", type: ChartViewDesignComponent, selector: "ng-component", usesInheritance: true, ngImport: i0, template: "<ng-container *ngIf=\"mode === 'widget'; else edit\">\r\n</ng-container>\r\n<ng-template #edit>\r\n <form autocomplete=\"off\" [formGroup]=\"form\" class=\"column\">\r\n <mat-form-field *ngIf=\"cubes.length > 1\">\r\n <mat-label>{{'Cube'|translate}}</mat-label>\r\n <mat-select required (selectionChange)=\"cubeSelected($event)\">\r\n <mat-option *ngFor=\"let c of cubes\" [value]=\"c\">{{c.title}}</mat-option>\r\n </mat-select>\r\n </mat-form-field>\r\n <div class=\"row\">\r\n <mat-form-field class=\"flex\">\r\n <mat-label>{{'XAxis'|translate}}</mat-label>\r\n <mat-select formControlName=\"xAxis\" required multiple>\r\n <mat-option *ngFor=\"let a of cube?.axes\" [value]=\"a.name\">{{a.title }}</mat-option>\r\n </mat-select>\r\n <mat-error *ngIf=\"form.get('xAxis').hasError('required')\" [innerHTML]=\"'RequiredErr'|translate:('XAxis'|translate)\"></mat-error>\r\n </mat-form-field>\r\n \r\n <mat-form-field class=\"flex\">\r\n <mat-label>{{'Series'|translate}}</mat-label>\r\n <mat-select formControlName=\"series\" multiple>\r\n <ng-container *ngFor=\"let a of cube.axes\">\r\n <mat-option *ngIf=\"form.get('xAxis').value?.indexOf(a.name) < 0\" [value]=\"a.name\">{{a.title }}</mat-option>\r\n </ng-container>\r\n </mat-select>\r\n </mat-form-field>\r\n </div>\r\n <mat-form-field *ngIf=\"cube?.indices?.length\">\r\n <mat-label>{{'Indices'|translate}}</mat-label>\r\n <mat-select formControlName=\"indices\" multiple>\r\n <mat-option *ngFor=\"let i of cube.indices\" [value]=\"i.name\">{{i.title}}</mat-option>\r\n </mat-select>\r\n </mat-form-field>\r\n <div class=\"row\">\r\n <mat-form-field class=\"flex\">\r\n <mat-label>{{'ChartType'|translate}}</mat-label>\r\n <mat-select formControlName=\"chartType\">\r\n <mat-option value=\"Pie\">{{'Pie'|translate}}</mat-option>\r\n <mat-option value=\"Doughnut\">{{'Doughnut'|translate}}</mat-option>\r\n <mat-option value=\"HalfDoughnut\">{{'HalfDoughnut'|translate}}</mat-option>\r\n <mat-option value=\"Column\">{{'Column'|translate}}</mat-option>\r\n <mat-option value=\"Bar\">{{'Bar'|translate}}</mat-option>\r\n <mat-option value=\"Bubble\">{{'Bubble'|translate}}</mat-option>\r\n <mat-option value=\"StackingBar\">{{'StackingBar'|translate}}</mat-option>\r\n <mat-option value=\"StackingBar100\">{{'StackingBar100'|translate}}</mat-option>\r\n <mat-option value=\"Line\">{{'Line'|translate}}</mat-option>\r\n <mat-option value=\"Spline\">{{'Spline'|translate}}</mat-option>\r\n <mat-option value=\"Area\">{{'Area'|translate}}</mat-option>\r\n <mat-option value=\"SplineArea\">{{'SplineArea'|translate}}</mat-option>\r\n <mat-option value=\"StackingArea\">{{'StackingArea'|translate}}</mat-option>\r\n <mat-option value=\"StackingArea100\">{{'StackingArea100'|translate}}</mat-option>\r\n <mat-option value=\"StackingColumn\">{{'StackingColumn'|translate}}</mat-option>\r\n <mat-option value=\"StackingColumn100\">{{'StackingColumn100'|translate}}</mat-option>\r\n <mat-option value=\"Scatter\">{{'Scatter'|translate}}</mat-option>\r\n <mat-option value=\"Polar\">{{'Polar'|translate}}</mat-option>\r\n <mat-option value=\"Radar\">{{'Radar'|translate}}</mat-option>\r\n <mat-option value=\"StepLine\">{{'StepLine'|translate}}</mat-option>\r\n <mat-option value=\"StepArea\">{{'StepArea'|translate}}</mat-option>\r\n <mat-option value=\"StackingStepArea\">{{'StackingStepArea'|translate}}</mat-option>\r\n <mat-option value=\"StackingLine\">{{'StackingLine'|translate}}</mat-option>\r\n <mat-option value=\"StackingLine100\">{{'StackingLine100'|translate}}</mat-option>\r\n <mat-option value=\"Funnel\">{{'Funnel'|translate}}</mat-option>\r\n <mat-option value=\"Pyramid\">{{'Pyramid'|translate}}</mat-option>\r\n </mat-select>\r\n </mat-form-field>\r\n <mat-form-field class=\"flex\" *ngIf=\"options.indices?.length\">\r\n <mat-label>{{'IndicesChartType'|translate}}</mat-label>\r\n <mat-select formControlName=\"indicesChartType\">\r\n <mat-option value=\"Bar\">{{'Bar'|translate}}</mat-option>\r\n <mat-option value=\"Bubble\">{{'Bubble'|translate}}</mat-option>\r\n <mat-option value=\"Line\">{{'Line'|translate}}</mat-option>\r\n <mat-option value=\"Spline\">{{'Spline'|translate}}</mat-option>\r\n <mat-option value=\"Area\">{{'Area'|translate}}</mat-option>\r\n <mat-option value=\"SplineArea\">{{'SplineArea'|translate}}</mat-option>\r\n <mat-option value=\"Scatter\">{{'Scatter'|translate}}</mat-option>\r\n <mat-option value=\"Polar\">{{'Polar'|translate}}</mat-option>\r\n <mat-option value=\"Radar\">{{'Radar'|translate}}</mat-option>\r\n <mat-option value=\"StepLine\">{{'StepLine'|translate}}</mat-option>\r\n <mat-option value=\"StepArea\">{{'StepArea'|translate}}</mat-option>\r\n </mat-select>\r\n </mat-form-field>\r\n </div>\r\n <mat-form-field>\r\n <mat-label>{{'Aggregate'|translate}}</mat-label>\r\n <mat-select formControlName=\"aggregate\" multiple>\r\n <ng-container *ngFor=\"let a of cube.axes\">\r\n <mat-option *ngIf=\"form.get('xAxis').value?.indexOf(a.name) < 0 && form.get('series').value?.indexOf(a.name) < 0\" [value]=\"a.name\">{{a.title }}</mat-option>\r\n </ng-container>\r\n </mat-select>\r\n <mat-hint></mat-hint>\r\n </mat-form-field>\r\n <bizdoc-designer-cube-filter *ngIf=\"cube\" [cube]=\"cube\" [form]=\"form.get('filters')\"></bizdoc-designer-cube-filter>\r\n </form>\r\n <!--<button mat-stroked-button (click)=\"showPreview = true\">{{'Preview'|translate}}</button>-->\r\n <!--<div *ngIf=\"options.xAxis\">\r\n <ng-container [ngSwitch]=\"isAccum\">\r\n <bizdoc-cube-accum *ngSwitchCase=\"true\"\r\n [chartType]=\"options.chartType\"\r\n [width]=\"200\"\r\n [scope]=\"options.scope\"\r\n [cube]=\"selectedCube.name\"\r\n [filters]=\"options.filters\"\r\n [xAxis]=\"options.xAxis\"></bizdoc-cube-accum>\r\n <bizdoc-cube-chart *ngSwitchDefault\r\n [cube]=\"cube.name\"\r\n [xAxis]=\"options.xAxis\"\r\n [series]=\"options.series\"\r\n [indices]=\"options.indices\"\r\n [filters]=\"options.filters\"\r\n [chartType]=\"options.chartType\"\r\n [indicesChartType]=\"options.indicesChartType\"\r\n [width]=\"200\"\r\n [scope]=\"options.scope\"></bizdoc-cube-chart>\r\n </ng-container>\r\n </div>-->\r\n</ng-template>\r\n", dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i3.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "directive", type: i4.MatError, selector: "mat-error", inputs: ["id"] }, { kind: "component", type: i4.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i4.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "directive", type: i4.MatLabel, selector: "mat-label" }, { kind: "component", type: i5.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }, { kind: "component", type: i6.DesignerCubeFilterComponent, selector: "bizdoc-designer-cube-filter", inputs: ["cube", "form"] }, { kind: "pipe", type: i7.TranslatePipe, name: "translate" }] });
|
42
42
|
ChartViewDesignComponent = __decorate([
|
43
43
|
BizDoc({ selector: 'analysis-view-designer' })
|
44
44
|
], ChartViewDesignComponent);
|
45
45
|
export { ChartViewDesignComponent };
|
46
46
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: ChartViewDesignComponent, decorators: [{
|
47
47
|
type: Component,
|
48
|
-
args: [{ template: "<ng-container *ngIf=\"mode === 'widget'; else edit\">\r\n</ng-container>\r\n<ng-template #edit>\r\n <form autocomplete=\"off\" [formGroup]=\"form\" class=\"column\">\r\n <mat-form-field *ngIf=\"cubes.length > 1\">\r\n <mat-label>{{'Cube'|translate}}</mat-label>\r\n <mat-select required (selectionChange)=\"cubeSelected($event)\">\r\n <mat-option *ngFor=\"let c of cubes\" [value]=\"c\">{{c.title}}</mat-option>\r\n </mat-select>\r\n </mat-form-field>\r\n <div class=\"row\">\r\n <mat-form-field class=\"flex\">\r\n <mat-label>{{'XAxis'|translate}}</mat-label>\r\n <mat-select formControlName=\"xAxis\" required multiple
|
48
|
+
args: [{ template: "<ng-container *ngIf=\"mode === 'widget'; else edit\">\r\n</ng-container>\r\n<ng-template #edit>\r\n <form autocomplete=\"off\" [formGroup]=\"form\" class=\"column\">\r\n <mat-form-field *ngIf=\"cubes.length > 1\">\r\n <mat-label>{{'Cube'|translate}}</mat-label>\r\n <mat-select required (selectionChange)=\"cubeSelected($event)\">\r\n <mat-option *ngFor=\"let c of cubes\" [value]=\"c\">{{c.title}}</mat-option>\r\n </mat-select>\r\n </mat-form-field>\r\n <div class=\"row\">\r\n <mat-form-field class=\"flex\">\r\n <mat-label>{{'XAxis'|translate}}</mat-label>\r\n <mat-select formControlName=\"xAxis\" required multiple>\r\n <mat-option *ngFor=\"let a of cube?.axes\" [value]=\"a.name\">{{a.title }}</mat-option>\r\n </mat-select>\r\n <mat-error *ngIf=\"form.get('xAxis').hasError('required')\" [innerHTML]=\"'RequiredErr'|translate:('XAxis'|translate)\"></mat-error>\r\n </mat-form-field>\r\n \r\n <mat-form-field class=\"flex\">\r\n <mat-label>{{'Series'|translate}}</mat-label>\r\n <mat-select formControlName=\"series\" multiple>\r\n <ng-container *ngFor=\"let a of cube.axes\">\r\n <mat-option *ngIf=\"form.get('xAxis').value?.indexOf(a.name) < 0\" [value]=\"a.name\">{{a.title }}</mat-option>\r\n </ng-container>\r\n </mat-select>\r\n </mat-form-field>\r\n </div>\r\n <mat-form-field *ngIf=\"cube?.indices?.length\">\r\n <mat-label>{{'Indices'|translate}}</mat-label>\r\n <mat-select formControlName=\"indices\" multiple>\r\n <mat-option *ngFor=\"let i of cube.indices\" [value]=\"i.name\">{{i.title}}</mat-option>\r\n </mat-select>\r\n </mat-form-field>\r\n <div class=\"row\">\r\n <mat-form-field class=\"flex\">\r\n <mat-label>{{'ChartType'|translate}}</mat-label>\r\n <mat-select formControlName=\"chartType\">\r\n <mat-option value=\"Pie\">{{'Pie'|translate}}</mat-option>\r\n <mat-option value=\"Doughnut\">{{'Doughnut'|translate}}</mat-option>\r\n <mat-option value=\"HalfDoughnut\">{{'HalfDoughnut'|translate}}</mat-option>\r\n <mat-option value=\"Column\">{{'Column'|translate}}</mat-option>\r\n <mat-option value=\"Bar\">{{'Bar'|translate}}</mat-option>\r\n <mat-option value=\"Bubble\">{{'Bubble'|translate}}</mat-option>\r\n <mat-option value=\"StackingBar\">{{'StackingBar'|translate}}</mat-option>\r\n <mat-option value=\"StackingBar100\">{{'StackingBar100'|translate}}</mat-option>\r\n <mat-option value=\"Line\">{{'Line'|translate}}</mat-option>\r\n <mat-option value=\"Spline\">{{'Spline'|translate}}</mat-option>\r\n <mat-option value=\"Area\">{{'Area'|translate}}</mat-option>\r\n <mat-option value=\"SplineArea\">{{'SplineArea'|translate}}</mat-option>\r\n <mat-option value=\"StackingArea\">{{'StackingArea'|translate}}</mat-option>\r\n <mat-option value=\"StackingArea100\">{{'StackingArea100'|translate}}</mat-option>\r\n <mat-option value=\"StackingColumn\">{{'StackingColumn'|translate}}</mat-option>\r\n <mat-option value=\"StackingColumn100\">{{'StackingColumn100'|translate}}</mat-option>\r\n <mat-option value=\"Scatter\">{{'Scatter'|translate}}</mat-option>\r\n <mat-option value=\"Polar\">{{'Polar'|translate}}</mat-option>\r\n <mat-option value=\"Radar\">{{'Radar'|translate}}</mat-option>\r\n <mat-option value=\"StepLine\">{{'StepLine'|translate}}</mat-option>\r\n <mat-option value=\"StepArea\">{{'StepArea'|translate}}</mat-option>\r\n <mat-option value=\"StackingStepArea\">{{'StackingStepArea'|translate}}</mat-option>\r\n <mat-option value=\"StackingLine\">{{'StackingLine'|translate}}</mat-option>\r\n <mat-option value=\"StackingLine100\">{{'StackingLine100'|translate}}</mat-option>\r\n <mat-option value=\"Funnel\">{{'Funnel'|translate}}</mat-option>\r\n <mat-option value=\"Pyramid\">{{'Pyramid'|translate}}</mat-option>\r\n </mat-select>\r\n </mat-form-field>\r\n <mat-form-field class=\"flex\" *ngIf=\"options.indices?.length\">\r\n <mat-label>{{'IndicesChartType'|translate}}</mat-label>\r\n <mat-select formControlName=\"indicesChartType\">\r\n <mat-option value=\"Bar\">{{'Bar'|translate}}</mat-option>\r\n <mat-option value=\"Bubble\">{{'Bubble'|translate}}</mat-option>\r\n <mat-option value=\"Line\">{{'Line'|translate}}</mat-option>\r\n <mat-option value=\"Spline\">{{'Spline'|translate}}</mat-option>\r\n <mat-option value=\"Area\">{{'Area'|translate}}</mat-option>\r\n <mat-option value=\"SplineArea\">{{'SplineArea'|translate}}</mat-option>\r\n <mat-option value=\"Scatter\">{{'Scatter'|translate}}</mat-option>\r\n <mat-option value=\"Polar\">{{'Polar'|translate}}</mat-option>\r\n <mat-option value=\"Radar\">{{'Radar'|translate}}</mat-option>\r\n <mat-option value=\"StepLine\">{{'StepLine'|translate}}</mat-option>\r\n <mat-option value=\"StepArea\">{{'StepArea'|translate}}</mat-option>\r\n </mat-select>\r\n </mat-form-field>\r\n </div>\r\n <mat-form-field>\r\n <mat-label>{{'Aggregate'|translate}}</mat-label>\r\n <mat-select formControlName=\"aggregate\" multiple>\r\n <ng-container *ngFor=\"let a of cube.axes\">\r\n <mat-option *ngIf=\"form.get('xAxis').value?.indexOf(a.name) < 0 && form.get('series').value?.indexOf(a.name) < 0\" [value]=\"a.name\">{{a.title }}</mat-option>\r\n </ng-container>\r\n </mat-select>\r\n <mat-hint></mat-hint>\r\n </mat-form-field>\r\n <bizdoc-designer-cube-filter *ngIf=\"cube\" [cube]=\"cube\" [form]=\"form.get('filters')\"></bizdoc-designer-cube-filter>\r\n </form>\r\n <!--<button mat-stroked-button (click)=\"showPreview = true\">{{'Preview'|translate}}</button>-->\r\n <!--<div *ngIf=\"options.xAxis\">\r\n <ng-container [ngSwitch]=\"isAccum\">\r\n <bizdoc-cube-accum *ngSwitchCase=\"true\"\r\n [chartType]=\"options.chartType\"\r\n [width]=\"200\"\r\n [scope]=\"options.scope\"\r\n [cube]=\"selectedCube.name\"\r\n [filters]=\"options.filters\"\r\n [xAxis]=\"options.xAxis\"></bizdoc-cube-accum>\r\n <bizdoc-cube-chart *ngSwitchDefault\r\n [cube]=\"cube.name\"\r\n [xAxis]=\"options.xAxis\"\r\n [series]=\"options.series\"\r\n [indices]=\"options.indices\"\r\n [filters]=\"options.filters\"\r\n [chartType]=\"options.chartType\"\r\n [indicesChartType]=\"options.indicesChartType\"\r\n [width]=\"200\"\r\n [scope]=\"options.scope\"></bizdoc-cube-chart>\r\n </ng-container>\r\n </div>-->\r\n</ng-template>\r\n" }]
|
49
49
|
}] });
|
50
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"analysis-view.component.js","sourceRoot":"","sources":["../../../../../../../libraries/core/src/lib/admin/configuration-designer/elements/analysis-view.component.ts","../../../../../../../libraries/core/src/lib/admin/configuration-designer/elements/analysis-view.component.html"],"names":[],"mappings":";AAAA,OAAO,EAAE,SAAS,EAAU,MAAM,eAAe,CAAC;AAClD,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAC5C,OAAO,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AACjC,OAAO,EAAE,MAAM,EAAE,MAAM,0BAA0B,CAAC;AAElD,OAAO,EAAE,4BAA4B,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAC;;;;;;;;;IAI5D,wBAAwB,SAAxB,wBAAyB,SAAQ,4BAAgD;;;QACnF,SAAI,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC;YAC7B,IAAI,EAAE,IAAI;YACV,KAAK,EAAE,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,EAAE,UAAU,CAAC,QAAQ,CAAC;YAClD,MAAM,EAAE,IAAI;YACZ,OAAO,EAAE,IAAI;YACb,SAAS,EAAE,IAAI;YACf,gBAAgB,EAAE,IAAI;YACtB,SAAS,EAAE,IAAI;YACf,OAAO,EAAE,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC;YAC3B,KAAK,EAAE,IAAI;SACZ,CAAC,CAAC;KAUJ;IATC,QAAQ;QACN,KAAK,CAAC,QAAQ,EAAE,CAAC;QACjB,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;YAC5F,IAAI,OAAO,CAAC,CAAC,CAAC;gBACZ,IAAI,CAAC,OAAO,CAAC,kBAAkB,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAC;;gBAEtD,IAAI,CAAC,MAAM,CAAC,kBAAkB,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAC;QACzD,CAAC,CAAC,CAAC;IACL,CAAC;CACF,CAAA;qHArBY,wBAAwB;yGAAxB,wBAAwB,2ECTrC,k5NAiHA;ADxGa,wBAAwB;IADlC,MAAM,CAAC,EAAE,QAAQ,EAAE,wBAAwB,EAAE,CAAC;GACpC,wBAAwB,CAqBpC;SArBY,wBAAwB;2FAAxB,wBAAwB;kBAFpC,SAAS","sourcesContent":["import { Component, OnInit } from \"@angular/core\";\r\nimport { Validators } from \"@angular/forms\";\r\nimport { startWith } from \"rxjs\";\r\nimport { BizDoc } from \"../../../core/decorators\";\r\nimport { ChartSettingsModel } from \"../../../views/cube/chart.component\";\r\nimport { DesignerCubeElementComponent, isAccum } from \"../designer.base\";\r\n\r\n@Component({ templateUrl: 'analysis-view.component.html' })\r\n  @BizDoc({ selector: 'analysis-view-designer' })\r\nexport class ChartViewDesignComponent extends DesignerCubeElementComponent<ChartSettingsModel> implements OnInit {\r\n  readonly form = this._fb.group({\r\n    cube: null,\r\n    xAxis: this._fb.control(null, Validators.required),\r\n    series: null,\r\n    indices: null,\r\n    chartType: null,\r\n    indicesChartType: null,\r\n    aggregate: null,\r\n    filters: this._fb.group({}),\r\n    scope: null\r\n  });\r\n  ngOnInit() {\r\n    super.ngOnInit();\r\n    this.form.get('chartType').valueChanges.pipe(startWith(this.options.chartType)).subscribe(v => {\r\n      if (isAccum(v))\r\n        this.disable('indicesChartType', 'series', 'indices');\r\n      else\r\n        this.enable('indicesChartType', 'series', 'indices');\r\n    });\r\n  }\r\n}\r\n","<ng-container *ngIf=\"mode === 'widget'; else edit\">\r\n</ng-container>\r\n<ng-template #edit>\r\n  <form autocomplete=\"off\" [formGroup]=\"form\" class=\"column\">\r\n    <mat-form-field *ngIf=\"cubes.length > 1\">\r\n      <mat-label>{{'Cube'|translate}}</mat-label>\r\n      <mat-select required (selectionChange)=\"cubeSelected($event)\">\r\n        <mat-option *ngFor=\"let c of cubes\" [value]=\"c\">{{c.title}}</mat-option>\r\n      </mat-select>\r\n    </mat-form-field>\r\n    <div class=\"row\">\r\n      <mat-form-field class=\"flex\">\r\n        <mat-label>{{'XAxis'|translate}}</mat-label>\r\n        <mat-select formControlName=\"xAxis\" required multiple (selectionChange)=\"xAxisSelected($event)\">\r\n          <mat-option *ngFor=\"let x of cube?.axes\" [value]=\"x.name\">{{x.title||x.name}}</mat-option>\r\n        </mat-select>\r\n        <mat-error *ngIf=\"form.get('xAxis').hasError('required')\" [innerHTML]=\"'RequiredErr'|translate:('XAxis'|translate)\"></mat-error>\r\n      </mat-form-field>\r\n      &nbsp;\r\n      <mat-form-field class=\"flex\">\r\n        <mat-label>{{'Series'|translate}}</mat-label>\r\n        <mat-select formControlName=\"series\" multiple (selectionChange)=\"seriesSelected($event)\">\r\n          <mat-option *ngFor=\"let x of secondaryAxes\" [value]=\"x.name\">{{x.title||x.name}}</mat-option>\r\n        </mat-select>\r\n      </mat-form-field>\r\n    </div>\r\n    <mat-form-field *ngIf=\"cube?.indices?.length\">\r\n      <mat-label>{{'Indices'|translate}}</mat-label>\r\n      <mat-select formControlName=\"indices\" multiple>\r\n        <mat-option *ngFor=\"let x of cube.indices\" [value]=\"x.name\">{{x.title||x.name}}</mat-option>\r\n      </mat-select>\r\n    </mat-form-field>\r\n    <div class=\"row\">\r\n      <mat-form-field class=\"flex\">\r\n        <mat-label>{{'ChartType'|translate}}</mat-label>\r\n        <mat-select formControlName=\"chartType\">\r\n          <mat-option value=\"Pie\">{{'Pie'|translate}}</mat-option>\r\n          <mat-option value=\"Doughnut\">{{'Doughnut'|translate}}</mat-option>\r\n          <mat-option value=\"HalfDoughnut\">{{'HalfDoughnut'|translate}}</mat-option>\r\n          <mat-option value=\"Column\">{{'Column'|translate}}</mat-option>\r\n          <mat-option value=\"Bar\">{{'Bar'|translate}}</mat-option>\r\n          <mat-option value=\"Bubble\">{{'Bubble'|translate}}</mat-option>\r\n          <mat-option value=\"StackingBar\">{{'StackingBar'|translate}}</mat-option>\r\n          <mat-option value=\"StackingBar100\">{{'StackingBar100'|translate}}</mat-option>\r\n          <mat-option value=\"Line\">{{'Line'|translate}}</mat-option>\r\n          <mat-option value=\"Spline\">{{'Spline'|translate}}</mat-option>\r\n          <mat-option value=\"Area\">{{'Area'|translate}}</mat-option>\r\n          <mat-option value=\"SplineArea\">{{'SplineArea'|translate}}</mat-option>\r\n          <mat-option value=\"StackingArea\">{{'StackingArea'|translate}}</mat-option>\r\n          <mat-option value=\"StackingArea100\">{{'StackingArea100'|translate}}</mat-option>\r\n          <mat-option value=\"StackingColumn\">{{'StackingColumn'|translate}}</mat-option>\r\n          <mat-option value=\"StackingColumn100\">{{'StackingColumn100'|translate}}</mat-option>\r\n          <mat-option value=\"Scatter\">{{'Scatter'|translate}}</mat-option>\r\n          <mat-option value=\"Polar\">{{'Polar'|translate}}</mat-option>\r\n          <mat-option value=\"Radar\">{{'Radar'|translate}}</mat-option>\r\n          <mat-option value=\"StepLine\">{{'StepLine'|translate}}</mat-option>\r\n          <mat-option value=\"StepArea\">{{'StepArea'|translate}}</mat-option>\r\n          <mat-option value=\"StackingStepArea\">{{'StackingStepArea'|translate}}</mat-option>\r\n          <mat-option value=\"StackingLine\">{{'StackingLine'|translate}}</mat-option>\r\n          <mat-option value=\"StackingLine100\">{{'StackingLine100'|translate}}</mat-option>\r\n          <mat-option value=\"Funnel\">{{'Funnel'|translate}}</mat-option>\r\n          <mat-option value=\"Pyramid\">{{'Pyramid'|translate}}</mat-option>\r\n        </mat-select>\r\n      </mat-form-field>\r\n      <mat-form-field class=\"flex\" *ngIf=\"options.indices?.length\">\r\n        <mat-label>{{'IndicesChartType'|translate}}</mat-label>\r\n        <mat-select formControlName=\"indicesChartType\">\r\n          <mat-option value=\"Bar\">{{'Bar'|translate}}</mat-option>\r\n          <mat-option value=\"Bubble\">{{'Bubble'|translate}}</mat-option>\r\n          <mat-option value=\"Line\">{{'Line'|translate}}</mat-option>\r\n          <mat-option value=\"Spline\">{{'Spline'|translate}}</mat-option>\r\n          <mat-option value=\"Area\">{{'Area'|translate}}</mat-option>\r\n          <mat-option value=\"SplineArea\">{{'SplineArea'|translate}}</mat-option>\r\n          <mat-option value=\"Scatter\">{{'Scatter'|translate}}</mat-option>\r\n          <mat-option value=\"Polar\">{{'Polar'|translate}}</mat-option>\r\n          <mat-option value=\"Radar\">{{'Radar'|translate}}</mat-option>\r\n          <mat-option value=\"StepLine\">{{'StepLine'|translate}}</mat-option>\r\n          <mat-option value=\"StepArea\">{{'StepArea'|translate}}</mat-option>\r\n        </mat-select>\r\n      </mat-form-field>\r\n    </div>\r\n    <mat-form-field>\r\n      <mat-label>{{'Aggregate'|translate}}</mat-label>\r\n      <mat-select formControlName=\"aggregate\" multiple [disabled]=\"!secondaryAxes || !secondaryAxes.length\">\r\n        <mat-option *ngFor=\"let x of (thirdAxes||secondaryAxes)\" [value]=\"x.name\">{{x.title || x.name}}</mat-option>\r\n      </mat-select>\r\n      <mat-hint></mat-hint>\r\n    </mat-form-field>\r\n    <bizdoc-designer-cube-filter *ngIf=\"cube\" [cube]=\"cube\" [form]=\"form.get('filters')\"></bizdoc-designer-cube-filter>\r\n  </form>\r\n  <!--<button mat-stroked-button (click)=\"showPreview = true\">{{'Preview'|translate}}</button>-->\r\n  <!--<div *ngIf=\"options.xAxis\">\r\n    <ng-container [ngSwitch]=\"isAccum\">\r\n      <bizdoc-cube-accum *ngSwitchCase=\"true\"\r\n                         [chartType]=\"options.chartType\"\r\n                         [width]=\"200\"\r\n                         [scope]=\"options.scope\"\r\n                         [cube]=\"selectedCube.name\"\r\n                         [filters]=\"options.filters\"\r\n                         [xAxis]=\"options.xAxis\"></bizdoc-cube-accum>\r\n      <bizdoc-cube-chart *ngSwitchDefault\r\n                         [cube]=\"cube.name\"\r\n                         [xAxis]=\"options.xAxis\"\r\n                         [series]=\"options.series\"\r\n                         [indices]=\"options.indices\"\r\n                         [filters]=\"options.filters\"\r\n                         [chartType]=\"options.chartType\"\r\n                         [indicesChartType]=\"options.indicesChartType\"\r\n                         [width]=\"200\"\r\n                         [scope]=\"options.scope\"></bizdoc-cube-chart>\r\n    </ng-container>\r\n  </div>-->\r\n</ng-template>\r\n"]}
|
50
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"analysis-view.component.js","sourceRoot":"","sources":["../../../../../../../libraries/core/src/lib/admin/configuration-designer/elements/analysis-view.component.ts","../../../../../../../libraries/core/src/lib/admin/configuration-designer/elements/analysis-view.component.html"],"names":[],"mappings":";AAAA,OAAO,EAAE,SAAS,EAAU,MAAM,eAAe,CAAC;AAClD,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAC5C,OAAO,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AACjC,OAAO,EAAE,MAAM,EAAE,MAAM,0BAA0B,CAAC;AAElD,OAAO,EAAE,4BAA4B,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAC;;;;;;;;;IAI5D,wBAAwB,SAAxB,wBAAyB,SAAQ,4BAAgD;;;QACnF,SAAI,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC;YAC7B,IAAI,EAAE,IAAI;YACV,KAAK,EAAE,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,EAAE,UAAU,CAAC,QAAQ,CAAC;YAClD,MAAM,EAAE,IAAI;YACZ,OAAO,EAAE,IAAI;YACb,SAAS,EAAE,KAAK;YAChB,gBAAgB,EAAE,IAAI;YACtB,SAAS,EAAE,IAAI;YACf,OAAO,EAAE,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC;YAC3B,KAAK,EAAE,IAAI;SACZ,CAAC,CAAC;KAUJ;IATC,QAAQ;QACN,KAAK,CAAC,QAAQ,EAAE,CAAC;QACjB,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,IAAI,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;YACrG,IAAI,OAAO,CAAC,CAAC,CAAC;gBACZ,IAAI,CAAC,OAAO,CAAC,kBAAkB,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAC;;gBAEtD,IAAI,CAAC,MAAM,CAAC,kBAAkB,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAC;QACzD,CAAC,CAAC,CAAC;IACL,CAAC;CACF,CAAA;qHArBY,wBAAwB;yGAAxB,wBAAwB,2ECTrC,+9NAqHA;AD5Ga,wBAAwB;IADlC,MAAM,CAAC,EAAE,QAAQ,EAAE,wBAAwB,EAAE,CAAC;GACpC,wBAAwB,CAqBpC;SArBY,wBAAwB;2FAAxB,wBAAwB;kBAFpC,SAAS","sourcesContent":["import { Component, OnInit } from \"@angular/core\";\r\nimport { Validators } from \"@angular/forms\";\r\nimport { startWith } from \"rxjs\";\r\nimport { BizDoc } from \"../../../core/decorators\";\r\nimport { ChartSettingsModel } from \"../../../views/cube/chart.component\";\r\nimport { DesignerCubeElementComponent, isAccum } from \"../designer.base\";\r\n\r\n@Component({ templateUrl: 'analysis-view.component.html' })\r\n  @BizDoc({ selector: 'analysis-view-designer' })\r\nexport class ChartViewDesignComponent extends DesignerCubeElementComponent<ChartSettingsModel> implements OnInit {\r\n  readonly form = this._fb.group({\r\n    cube: null,\r\n    xAxis: this._fb.control(null, Validators.required),\r\n    series: null,\r\n    indices: null,\r\n    chartType: 'Pie',\r\n    indicesChartType: null,\r\n    aggregate: null,\r\n    filters: this._fb.group({}),\r\n    scope: null\r\n  });\r\n  ngOnInit() {\r\n    super.ngOnInit();\r\n    this.form.get('chartType').valueChanges.pipe(startWith(this.options.chartType || 'Pie')).subscribe(v => {\r\n      if (isAccum(v))\r\n        this.disable('indicesChartType', 'series', 'indices');\r\n      else\r\n        this.enable('indicesChartType', 'series', 'indices');\r\n    });\r\n  }\r\n}\r\n","<ng-container *ngIf=\"mode === 'widget'; else edit\">\r\n</ng-container>\r\n<ng-template #edit>\r\n  <form autocomplete=\"off\" [formGroup]=\"form\" class=\"column\">\r\n    <mat-form-field *ngIf=\"cubes.length > 1\">\r\n      <mat-label>{{'Cube'|translate}}</mat-label>\r\n      <mat-select required (selectionChange)=\"cubeSelected($event)\">\r\n        <mat-option *ngFor=\"let c of cubes\" [value]=\"c\">{{c.title}}</mat-option>\r\n      </mat-select>\r\n    </mat-form-field>\r\n    <div class=\"row\">\r\n      <mat-form-field class=\"flex\">\r\n        <mat-label>{{'XAxis'|translate}}</mat-label>\r\n        <mat-select formControlName=\"xAxis\" required multiple>\r\n          <mat-option *ngFor=\"let a of cube?.axes\" [value]=\"a.name\">{{a.title }}</mat-option>\r\n        </mat-select>\r\n        <mat-error *ngIf=\"form.get('xAxis').hasError('required')\" [innerHTML]=\"'RequiredErr'|translate:('XAxis'|translate)\"></mat-error>\r\n      </mat-form-field>\r\n      &nbsp;\r\n      <mat-form-field class=\"flex\">\r\n        <mat-label>{{'Series'|translate}}</mat-label>\r\n        <mat-select formControlName=\"series\" multiple>\r\n          <ng-container *ngFor=\"let a of cube.axes\">\r\n            <mat-option *ngIf=\"form.get('xAxis').value?.indexOf(a.name) < 0\" [value]=\"a.name\">{{a.title }}</mat-option>\r\n          </ng-container>\r\n        </mat-select>\r\n      </mat-form-field>\r\n    </div>\r\n    <mat-form-field *ngIf=\"cube?.indices?.length\">\r\n      <mat-label>{{'Indices'|translate}}</mat-label>\r\n      <mat-select formControlName=\"indices\" multiple>\r\n        <mat-option *ngFor=\"let i of cube.indices\" [value]=\"i.name\">{{i.title}}</mat-option>\r\n      </mat-select>\r\n    </mat-form-field>\r\n    <div class=\"row\">\r\n      <mat-form-field class=\"flex\">\r\n        <mat-label>{{'ChartType'|translate}}</mat-label>\r\n        <mat-select formControlName=\"chartType\">\r\n          <mat-option value=\"Pie\">{{'Pie'|translate}}</mat-option>\r\n          <mat-option value=\"Doughnut\">{{'Doughnut'|translate}}</mat-option>\r\n          <mat-option value=\"HalfDoughnut\">{{'HalfDoughnut'|translate}}</mat-option>\r\n          <mat-option value=\"Column\">{{'Column'|translate}}</mat-option>\r\n          <mat-option value=\"Bar\">{{'Bar'|translate}}</mat-option>\r\n          <mat-option value=\"Bubble\">{{'Bubble'|translate}}</mat-option>\r\n          <mat-option value=\"StackingBar\">{{'StackingBar'|translate}}</mat-option>\r\n          <mat-option value=\"StackingBar100\">{{'StackingBar100'|translate}}</mat-option>\r\n          <mat-option value=\"Line\">{{'Line'|translate}}</mat-option>\r\n          <mat-option value=\"Spline\">{{'Spline'|translate}}</mat-option>\r\n          <mat-option value=\"Area\">{{'Area'|translate}}</mat-option>\r\n          <mat-option value=\"SplineArea\">{{'SplineArea'|translate}}</mat-option>\r\n          <mat-option value=\"StackingArea\">{{'StackingArea'|translate}}</mat-option>\r\n          <mat-option value=\"StackingArea100\">{{'StackingArea100'|translate}}</mat-option>\r\n          <mat-option value=\"StackingColumn\">{{'StackingColumn'|translate}}</mat-option>\r\n          <mat-option value=\"StackingColumn100\">{{'StackingColumn100'|translate}}</mat-option>\r\n          <mat-option value=\"Scatter\">{{'Scatter'|translate}}</mat-option>\r\n          <mat-option value=\"Polar\">{{'Polar'|translate}}</mat-option>\r\n          <mat-option value=\"Radar\">{{'Radar'|translate}}</mat-option>\r\n          <mat-option value=\"StepLine\">{{'StepLine'|translate}}</mat-option>\r\n          <mat-option value=\"StepArea\">{{'StepArea'|translate}}</mat-option>\r\n          <mat-option value=\"StackingStepArea\">{{'StackingStepArea'|translate}}</mat-option>\r\n          <mat-option value=\"StackingLine\">{{'StackingLine'|translate}}</mat-option>\r\n          <mat-option value=\"StackingLine100\">{{'StackingLine100'|translate}}</mat-option>\r\n          <mat-option value=\"Funnel\">{{'Funnel'|translate}}</mat-option>\r\n          <mat-option value=\"Pyramid\">{{'Pyramid'|translate}}</mat-option>\r\n        </mat-select>\r\n      </mat-form-field>\r\n      <mat-form-field class=\"flex\" *ngIf=\"options.indices?.length\">\r\n        <mat-label>{{'IndicesChartType'|translate}}</mat-label>\r\n        <mat-select formControlName=\"indicesChartType\">\r\n          <mat-option value=\"Bar\">{{'Bar'|translate}}</mat-option>\r\n          <mat-option value=\"Bubble\">{{'Bubble'|translate}}</mat-option>\r\n          <mat-option value=\"Line\">{{'Line'|translate}}</mat-option>\r\n          <mat-option value=\"Spline\">{{'Spline'|translate}}</mat-option>\r\n          <mat-option value=\"Area\">{{'Area'|translate}}</mat-option>\r\n          <mat-option value=\"SplineArea\">{{'SplineArea'|translate}}</mat-option>\r\n          <mat-option value=\"Scatter\">{{'Scatter'|translate}}</mat-option>\r\n          <mat-option value=\"Polar\">{{'Polar'|translate}}</mat-option>\r\n          <mat-option value=\"Radar\">{{'Radar'|translate}}</mat-option>\r\n          <mat-option value=\"StepLine\">{{'StepLine'|translate}}</mat-option>\r\n          <mat-option value=\"StepArea\">{{'StepArea'|translate}}</mat-option>\r\n        </mat-select>\r\n      </mat-form-field>\r\n    </div>\r\n    <mat-form-field>\r\n      <mat-label>{{'Aggregate'|translate}}</mat-label>\r\n      <mat-select formControlName=\"aggregate\" multiple>\r\n        <ng-container *ngFor=\"let a of cube.axes\">\r\n          <mat-option *ngIf=\"form.get('xAxis').value?.indexOf(a.name) < 0 && form.get('series').value?.indexOf(a.name) < 0\" [value]=\"a.name\">{{a.title }}</mat-option>\r\n        </ng-container>\r\n      </mat-select>\r\n      <mat-hint></mat-hint>\r\n    </mat-form-field>\r\n    <bizdoc-designer-cube-filter *ngIf=\"cube\" [cube]=\"cube\" [form]=\"form.get('filters')\"></bizdoc-designer-cube-filter>\r\n  </form>\r\n  <!--<button mat-stroked-button (click)=\"showPreview = true\">{{'Preview'|translate}}</button>-->\r\n  <!--<div *ngIf=\"options.xAxis\">\r\n    <ng-container [ngSwitch]=\"isAccum\">\r\n      <bizdoc-cube-accum *ngSwitchCase=\"true\"\r\n                         [chartType]=\"options.chartType\"\r\n                         [width]=\"200\"\r\n                         [scope]=\"options.scope\"\r\n                         [cube]=\"selectedCube.name\"\r\n                         [filters]=\"options.filters\"\r\n                         [xAxis]=\"options.xAxis\"></bizdoc-cube-accum>\r\n      <bizdoc-cube-chart *ngSwitchDefault\r\n                         [cube]=\"cube.name\"\r\n                         [xAxis]=\"options.xAxis\"\r\n                         [series]=\"options.series\"\r\n                         [indices]=\"options.indices\"\r\n                         [filters]=\"options.filters\"\r\n                         [chartType]=\"options.chartType\"\r\n                         [indicesChartType]=\"options.indicesChartType\"\r\n                         [width]=\"200\"\r\n                         [scope]=\"options.scope\"></bizdoc-cube-chart>\r\n    </ng-container>\r\n  </div>-->\r\n</ng-template>\r\n"]}
|