raise-common-lib-new 0.0.62 → 0.0.64
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/esm2022/lib/actions/toolbar/index.component.mjs +4 -3
- package/esm2022/lib/actions/toolbar-item/index.component.mjs +2 -2
- package/esm2022/lib/common-grid/grid-action/grid-action-item/grid-action-item.component.mjs +1 -1
- package/esm2022/lib/common-grid/grid-action/grid-action.component.mjs +3 -2
- package/esm2022/lib/common-grid/index.component.mjs +6 -3
- package/esm2022/lib/dashboard/api.mjs +33 -0
- package/esm2022/lib/dashboard/bar-charts/bar-charts.component.mjs +430 -0
- package/esm2022/lib/dashboard/bar-charts/utils.mjs +18 -0
- package/esm2022/lib/dashboard/dashboard-properties/data-mart-new/data-mart-new.component.mjs +442 -0
- package/esm2022/lib/dashboard/dashboard.service.mjs +295 -0
- package/esm2022/lib/dashboard/dashboardPorlets.service.mjs +2169 -0
- package/esm2022/lib/dashboard/dialog-group/download/index.component.mjs +212 -0
- package/esm2022/lib/dashboard/dialog-group/empty-icon-prompt/empty-icon-prompt.component.mjs +36 -0
- package/esm2022/lib/dashboard/gadget-group/gadget-pivot/gadget-pivot.component.mjs +3211 -0
- package/esm2022/lib/dashboard/gadget-group/gadget-pivot-chart/gadget-pivot.component.mjs +3117 -0
- package/esm2022/lib/dashboard/gadget-group/gadget-table/gadget-table.component.mjs +1099 -0
- package/esm2022/lib/dashboard/gadget-group/gadget-transpose/gadget-transpose.component.mjs +583 -0
- package/esm2022/lib/dashboard/pane-group-new.component.mjs +2031 -0
- package/esm2022/lib/dashboard/sidebar-iconlist/field-filter/field-filter.component.mjs +637 -0
- package/esm2022/lib/dashboard/sidebar-iconlist/field-format/field-format.component.mjs +753 -0
- package/esm2022/lib/dashboard/sidebar-iconlist/portlet-type-new/portlet-type-new.component.mjs +216 -0
- package/esm2022/lib/dashboard/sidebar-iconlist/sidebar-iconlist-new.component.mjs +1239 -0
- package/esm2022/lib/dialog/common-delete-dialog/index.component.mjs +1 -1
- package/esm2022/lib/dialog/common-dialog/index.component.mjs +16 -5
- package/esm2022/lib/float-box/index.component.mjs +18 -4
- package/esm2022/lib/form/checkbox-group/index.component.mjs +35 -5
- package/esm2022/lib/form/drawer-form/drawer-form.component.mjs +177 -76
- package/esm2022/lib/form/richtexteditor/index.component.mjs +7 -9
- package/esm2022/lib/layout/drawer/index.component.mjs +2 -2
- package/esm2022/lib/layout/page-list/index.component.mjs +9 -3
- package/esm2022/lib/layout/page-tab/index.component.mjs +5 -3
- package/esm2022/lib/layout/rs-stepper/constants.mjs +2 -0
- package/esm2022/lib/layout/rs-stepper/index.component.mjs +148 -0
- package/esm2022/lib/raise-common-lib.module.mjs +114 -7
- package/esm2022/lib/service/InjectionToken.mjs +5 -0
- package/esm2022/lib/service/keep-alive.service.mjs +2 -2
- package/esm2022/lib/smart-popup/index.component.mjs +1084 -0
- package/esm2022/public-api.mjs +19 -1
- package/fesm2022/raise-common-lib-new.mjs +18042 -227
- package/fesm2022/raise-common-lib-new.mjs.map +1 -1
- package/lib/common-grid/index.component.d.ts +2 -1
- package/lib/dashboard/api.d.ts +24 -0
- package/lib/dashboard/bar-charts/bar-charts.component.d.ts +63 -0
- package/lib/dashboard/bar-charts/utils.d.ts +1 -0
- package/lib/dashboard/dashboard-properties/data-mart-new/data-mart-new.component.d.ts +52 -0
- package/lib/dashboard/dashboard.service.d.ts +152 -0
- package/lib/dashboard/dashboardPorlets.service.d.ts +214 -0
- package/lib/dashboard/dialog-group/download/index.component.d.ts +36 -0
- package/lib/dashboard/dialog-group/empty-icon-prompt/empty-icon-prompt.component.d.ts +15 -0
- package/lib/dashboard/gadget-group/gadget-pivot/gadget-pivot.component.d.ts +128 -0
- package/lib/dashboard/gadget-group/gadget-pivot-chart/gadget-pivot.component.d.ts +131 -0
- package/lib/dashboard/gadget-group/gadget-table/gadget-table.component.d.ts +77 -0
- package/lib/dashboard/gadget-group/gadget-transpose/gadget-transpose.component.d.ts +47 -0
- package/lib/dashboard/pane-group-new.component.d.ts +169 -0
- package/lib/dashboard/sidebar-iconlist/field-filter/field-filter.component.d.ts +56 -0
- package/lib/dashboard/sidebar-iconlist/field-format/field-format.component.d.ts +62 -0
- package/lib/dashboard/sidebar-iconlist/portlet-type-new/portlet-type-new.component.d.ts +30 -0
- package/lib/dashboard/sidebar-iconlist/sidebar-iconlist-new.component.d.ts +150 -0
- package/lib/dialog/common-dialog/index.component.d.ts +3 -1
- package/lib/float-box/index.component.d.ts +4 -3
- package/lib/form/checkbox-group/index.component.d.ts +5 -0
- package/lib/form/drawer-form/drawer-form.component.d.ts +21 -8
- package/lib/form/richtexteditor/index.component.d.ts +1 -3
- package/lib/layout/page-list/index.component.d.ts +3 -1
- package/lib/layout/page-tab/index.component.d.ts +1 -0
- package/lib/layout/rs-stepper/constants.d.ts +5 -0
- package/lib/layout/rs-stepper/index.component.d.ts +31 -0
- package/lib/raise-common-lib.module.d.ts +61 -40
- package/lib/service/InjectionToken.d.ts +4 -0
- package/lib/smart-popup/index.component.d.ts +60 -0
- package/package.json +1 -1
- package/public-api.d.ts +18 -0
- package/src/assets/img/dashboard_icon/AddPerson.svg +4 -0
- package/src/assets/img/dashboard_icon/Angle-double-left.svg +12 -0
- package/src/assets/img/dashboard_icon/Angle-double-right.svg +12 -0
- package/src/assets/img/dashboard_icon/Arrow_collapse.svg +3 -0
- package/src/assets/img/dashboard_icon/Arrow_expand.svg +3 -0
- package/src/assets/img/dashboard_icon/Close.svg +4 -0
- package/src/assets/img/dashboard_icon/Edit_label.svg +3 -0
- package/src/assets/img/dashboard_icon/RemoveMini.svg +3 -0
- package/src/assets/img/dashboard_icon/ShareTo.svg +3 -0
- package/src/assets/img/dashboard_icon/add-dashboard.svg +4 -0
- package/src/assets/img/dashboard_icon/add-tab.svg +4 -0
- package/src/assets/img/dashboard_icon/angle-left.svg +12 -0
- package/src/assets/img/dashboard_icon/angle-right.svg +12 -0
- package/src/assets/img/dashboard_icon/area-white.svg +3 -0
- package/src/assets/img/dashboard_icon/area.svg +3 -0
- package/src/assets/img/dashboard_icon/bar-white.svg +14 -0
- package/src/assets/img/dashboard_icon/bar.svg +14 -0
- package/src/assets/img/dashboard_icon/basic-icon-filter.svg +14 -0
- package/src/assets/img/dashboard_icon/chart-combined-active.svg +7 -0
- package/src/assets/img/dashboard_icon/chart-combined.svg +7 -0
- package/src/assets/img/dashboard_icon/column-white.svg +14 -0
- package/src/assets/img/dashboard_icon/column.svg +26 -0
- package/src/assets/img/dashboard_icon/customize.png +0 -0
- package/src/assets/img/dashboard_icon/dashboard-description.svg +18 -0
- package/src/assets/img/dashboard_icon/dashboard-download.svg +18 -0
- package/src/assets/img/dashboard_icon/dashboard-drag.svg +28 -0
- package/src/assets/img/dashboard_icon/dashboard-duplicate.svg +24 -0
- package/src/assets/img/dashboard_icon/dashboard-icon.svg +12 -0
- package/src/assets/img/dashboard_icon/dashboard-properties.svg +18 -0
- package/src/assets/img/dashboard_icon/dashboard-rename.svg +18 -0
- package/src/assets/img/dashboard_icon/dashboard-share.svg +20 -0
- package/src/assets/img/dashboard_icon/dashboard-tab-delete.svg +4 -0
- package/src/assets/img/dashboard_icon/dashboard_Share.svg +3 -0
- package/src/assets/img/dashboard_icon/dashboard_ToolsHide.svg +4 -0
- package/src/assets/img/dashboard_icon/datamart_.svg +5 -0
- package/src/assets/img/dashboard_icon/datamart_Admin.svg +3 -0
- package/src/assets/img/dashboard_icon/datamart_Asset Portfolio.svg +4 -0
- package/src/assets/img/dashboard_icon/datamart_Bank.svg +3 -0
- package/src/assets/img/dashboard_icon/datamart_CRM.svg +6 -0
- package/src/assets/img/dashboard_icon/datamart_Company.svg +6 -0
- package/src/assets/img/dashboard_icon/datamart_Compliance.svg +3 -0
- package/src/assets/img/dashboard_icon/datamart_Contact.svg +3 -0
- package/src/assets/img/dashboard_icon/datamart_DASHBOARD.svg +4 -0
- package/src/assets/img/dashboard_icon/datamart_DOCX.svg +4 -0
- package/src/assets/img/dashboard_icon/datamart_ESG.svg +4 -0
- package/src/assets/img/dashboard_icon/datamart_Financials - Company.svg +3 -0
- package/src/assets/img/dashboard_icon/datamart_Fund.svg +4 -0
- package/src/assets/img/dashboard_icon/datamart_FundFinancial.svg +4 -0
- package/src/assets/img/dashboard_icon/datamart_HTML.svg +4 -0
- package/src/assets/img/dashboard_icon/datamart_Logs.svg +8 -0
- package/src/assets/img/dashboard_icon/datamart_PDF.svg +5 -0
- package/src/assets/img/dashboard_icon/datamart_Project.svg +3 -0
- package/src/assets/img/dashboard_icon/datamart_Templates.svg +7 -0
- package/src/assets/img/dashboard_icon/datamart_Track Change.svg +3 -0
- package/src/assets/img/dashboard_icon/datamart_VirtualGroup.svg +5 -0
- package/src/assets/img/dashboard_icon/datamart_XLS.svg +4 -0
- package/src/assets/img/dashboard_icon/desktop_selected.svg +10 -0
- package/src/assets/img/dashboard_icon/desktop_unselected.svg +10 -0
- package/src/assets/img/dashboard_icon/favourite-grey.svg +3 -0
- package/src/assets/img/dashboard_icon/favourite-yellow.svg +3 -0
- package/src/assets/img/dashboard_icon/forms-checkbox-square-tick.svg +3 -0
- package/src/assets/img/dashboard_icon/ftable-white.svg +24 -0
- package/src/assets/img/dashboard_icon/ftable.svg +24 -0
- package/src/assets/img/dashboard_icon/gadget-basic-arrow-down.svg +14 -0
- package/src/assets/img/dashboard_icon/gadget-basic-format.svg +21 -0
- package/src/assets/img/dashboard_icon/gadget-basic-sub-total.svg +18 -0
- package/src/assets/img/dashboard_icon/gadget-basic-total-1.svg +9 -0
- package/src/assets/img/dashboard_icon/gadget-basic-total.svg +16 -0
- package/src/assets/img/dashboard_icon/gadget-columns.svg +12 -0
- package/src/assets/img/dashboard_icon/gadget-delete.svg +18 -0
- package/src/assets/img/dashboard_icon/gadget-download.svg +18 -0
- package/src/assets/img/dashboard_icon/gadget-duplicate.svg +24 -0
- package/src/assets/img/dashboard_icon/gadget-edit.svg +18 -0
- package/src/assets/img/dashboard_icon/gadget-filters-light.svg +9 -0
- package/src/assets/img/dashboard_icon/gadget-filters.svg +9 -0
- package/src/assets/img/dashboard_icon/gadget-format-0.svg +8 -0
- package/src/assets/img/dashboard_icon/gadget-format-1.svg +8 -0
- package/src/assets/img/dashboard_icon/gadget-format.svg +19 -0
- package/src/assets/img/dashboard_icon/gadget-fullscreen.svg +30 -0
- package/src/assets/img/dashboard_icon/gadget-settings.svg +18 -0
- package/src/assets/img/dashboard_icon/gadget-sub-total-0.svg +18 -0
- package/src/assets/img/dashboard_icon/gadget-sub-total-1.svg +18 -0
- package/src/assets/img/dashboard_icon/gadget-thumbnail.svg +12 -0
- package/src/assets/img/dashboard_icon/gadget-type-light.svg +15 -0
- package/src/assets/img/dashboard_icon/gadget-type.svg +16 -0
- package/src/assets/img/dashboard_icon/geo-white.svg +14 -0
- package/src/assets/img/dashboard_icon/geo.svg +14 -0
- package/src/assets/img/dashboard_icon/historic-IRR-white.svg +9 -0
- package/src/assets/img/dashboard_icon/historic-IRR.svg +5 -0
- package/src/assets/img/dashboard_icon/information-1.png +0 -0
- package/src/assets/img/dashboard_icon/information-grey.svg +4 -0
- package/src/assets/img/dashboard_icon/menu-change-group.svg +3 -0
- package/src/assets/img/dashboard_icon/menu-close.svg +20 -0
- package/src/assets/img/dashboard_icon/menu-delete.svg +18 -0
- package/src/assets/img/dashboard_icon/menu-description.svg +19 -0
- package/src/assets/img/dashboard_icon/menu-download.svg +24 -0
- package/src/assets/img/dashboard_icon/menu-drag.svg +28 -0
- package/src/assets/img/dashboard_icon/menu-duplicate.svg +26 -0
- package/src/assets/img/dashboard_icon/menu-properties.svg +18 -0
- package/src/assets/img/dashboard_icon/menu-rename.svg +23 -0
- package/src/assets/img/dashboard_icon/menu-share.svg +20 -0
- package/src/assets/img/dashboard_icon/menu-toolbar.svg +10 -0
- package/src/assets/img/dashboard_icon/mobile_selected.svg +10 -0
- package/src/assets/img/dashboard_icon/mobile_unselected.svg +10 -0
- package/src/assets/img/dashboard_icon/more_Save.svg +3 -0
- package/src/assets/img/dashboard_icon/more_View.svg +3 -0
- package/src/assets/img/dashboard_icon/multi-series-white.svg +20 -0
- package/src/assets/img/dashboard_icon/multi-series.svg +6 -0
- package/src/assets/img/dashboard_icon/paint-bucket.svg +6 -0
- package/src/assets/img/dashboard_icon/pie-white.svg +16 -0
- package/src/assets/img/dashboard_icon/pie.svg +16 -0
- package/src/assets/img/dashboard_icon/pivot-chart-active.svg +8 -0
- package/src/assets/img/dashboard_icon/pivot-chart.svg +8 -0
- package/src/assets/img/dashboard_icon/pivot-white.svg +8 -0
- package/src/assets/img/dashboard_icon/pivot.svg +8 -0
- package/src/assets/img/dashboard_icon/pivot_column.svg +9 -0
- package/src/assets/img/dashboard_icon/pivot_column_active.svg +9 -0
- package/src/assets/img/dashboard_icon/pivot_line.svg +12 -0
- package/src/assets/img/dashboard_icon/pivot_line_active.svg +12 -0
- package/src/assets/img/dashboard_icon/print-A2.svg +3 -0
- package/src/assets/img/dashboard_icon/radar-white.svg +19 -0
- package/src/assets/img/dashboard_icon/radar.svg +19 -0
- package/src/assets/img/dashboard_icon/saveAs.svg +3 -0
- package/src/assets/img/dashboard_icon/search_input.svg +4 -0
- package/src/assets/img/dashboard_icon/table-3-white.svg +16 -0
- package/src/assets/img/dashboard_icon/table-3.svg +16 -0
- package/src/assets/img/dashboard_icon/table-filter-off.svg +5 -0
- package/src/assets/img/dashboard_icon/table-filter-on.svg +5 -0
- package/src/assets/img/dashboard_icon/tag_dashboard_selected.svg +3 -0
- package/src/assets/img/dashboard_icon/tag_dashboard_unselected.svg +3 -0
- package/src/assets/img/dashboard_icon/tag_share_selected.svg +3 -0
- package/src/assets/img/dashboard_icon/tag_share_unselected.svg +3 -0
- package/src/assets/img/dashboard_icon/tick.svg +26 -0
- package/src/assets/img/dashboard_icon/toolbar_AddDashboard.svg +5 -0
- package/src/assets/img/dashboard_icon/toolbar_AddGroup.svg +3 -0
- package/src/assets/img/dashboard_icon/toolbar_AddReport.svg +3 -0
- package/src/assets/img/dashboard_icon/toolbar_CollapseAll.svg +3 -0
- package/src/assets/img/dashboard_icon/toolbar_Customize.svg +3 -0
- package/src/assets/img/dashboard_icon/toolbar_DeleteDark.svg +3 -0
- package/src/assets/img/dashboard_icon/toolbar_Duplicate.svg +3 -0
- package/src/assets/img/dashboard_icon/toolbar_Edit.svg +3 -0
- package/src/assets/img/dashboard_icon/toolbar_ExpandAll.svg +3 -0
- package/src/assets/img/dashboard_icon/toolbar_Search.svg +3 -0
- package/src/assets/img/dashboard_icon/topbar-menu.svg +33 -0
- package/src/assets/img/dashboard_icon/topbar-refresh.svg +17 -0
- package/src/assets/img/dashboard_icon/topbar-tool-off.svg +12 -0
- package/src/assets/img/dashboard_icon/topbar-tool-on.svg +12 -0
- package/src/assets/img/dashboard_icon/trade-up-white.svg +14 -0
- package/src/assets/img/dashboard_icon/trade-up.svg +14 -0
- package/src/assets/img/dashboard_icon/transpose-white.svg +16 -0
- package/src/assets/img/dashboard_icon/transpose.svg +16 -0
|
@@ -0,0 +1,1239 @@
|
|
|
1
|
+
import { Component, ChangeDetectionStrategy, Input, Output, EventEmitter, Inject, Optional, } from "@angular/core";
|
|
2
|
+
import { API_SERVICE_TOKEN, PBF_TOKEN } from "../../service/InjectionToken";
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "../api";
|
|
5
|
+
import * as i2 from "../dashboard.service";
|
|
6
|
+
import * as i3 from "../dashboardPorlets.service";
|
|
7
|
+
import * as i4 from "@angular/common";
|
|
8
|
+
import * as i5 from "@angular/forms";
|
|
9
|
+
import * as i6 from "@angular/material/icon";
|
|
10
|
+
import * as i7 from "@angular/material/select";
|
|
11
|
+
import * as i8 from "@angular/material/core";
|
|
12
|
+
import * as i9 from "@angular/material/input";
|
|
13
|
+
import * as i10 from "@angular/material/button";
|
|
14
|
+
import * as i11 from "@syncfusion/ej2-angular-buttons";
|
|
15
|
+
import * as i12 from "@syncfusion/ej2-angular-dropdowns";
|
|
16
|
+
import * as i13 from "./portlet-type-new/portlet-type-new.component";
|
|
17
|
+
import * as i14 from "./field-filter/field-filter.component";
|
|
18
|
+
export class SidebarIconlistNewComponent {
|
|
19
|
+
api;
|
|
20
|
+
dashboardService;
|
|
21
|
+
dashboardPorletsService;
|
|
22
|
+
ref;
|
|
23
|
+
pbf;
|
|
24
|
+
http;
|
|
25
|
+
dashboard_sidebar = false;
|
|
26
|
+
dashboard;
|
|
27
|
+
dashboardId;
|
|
28
|
+
activeTabId;
|
|
29
|
+
activeTabLabel;
|
|
30
|
+
portlets = [];
|
|
31
|
+
tabactive = false;
|
|
32
|
+
portlet;
|
|
33
|
+
figureCode;
|
|
34
|
+
_selectedX = [];
|
|
35
|
+
_selectedY = [];
|
|
36
|
+
_selectedMultiples = null;
|
|
37
|
+
_selectedSecondY = [];
|
|
38
|
+
_selectTheme = null;
|
|
39
|
+
appCode;
|
|
40
|
+
closeSidebar = new EventEmitter();
|
|
41
|
+
updatePorletConfig = new EventEmitter();
|
|
42
|
+
onToggleTabactive = new EventEmitter();
|
|
43
|
+
updatePorlet = new EventEmitter();
|
|
44
|
+
updatePushBtn = new EventEmitter();
|
|
45
|
+
chartUpdate = new EventEmitter();
|
|
46
|
+
updateTheme = new EventEmitter();
|
|
47
|
+
translation = JSON.parse(localStorage.getItem("translation"));
|
|
48
|
+
lang;
|
|
49
|
+
dataMartTableList = [];
|
|
50
|
+
hasChanged = false;
|
|
51
|
+
//config;
|
|
52
|
+
gadgetTitle;
|
|
53
|
+
subscriptions = [];
|
|
54
|
+
portletType;
|
|
55
|
+
expandArray = [
|
|
56
|
+
false,
|
|
57
|
+
false,
|
|
58
|
+
false,
|
|
59
|
+
false,
|
|
60
|
+
false,
|
|
61
|
+
false,
|
|
62
|
+
false,
|
|
63
|
+
];
|
|
64
|
+
selectedDataTable = "";
|
|
65
|
+
selectedDatamart;
|
|
66
|
+
chartSettings = {
|
|
67
|
+
legendSettings: {
|
|
68
|
+
visible: false,
|
|
69
|
+
},
|
|
70
|
+
enableMultipleAxis: false,
|
|
71
|
+
showMultiLevelLabels: false,
|
|
72
|
+
chartSeries: {
|
|
73
|
+
type: "Column",
|
|
74
|
+
width: 2,
|
|
75
|
+
},
|
|
76
|
+
multipleAxisMode: "Stacked",
|
|
77
|
+
primaryXAxis: {
|
|
78
|
+
title: " ",
|
|
79
|
+
majorGridLines: { width: 0 },
|
|
80
|
+
},
|
|
81
|
+
chartArea: {
|
|
82
|
+
opacity: 0,
|
|
83
|
+
border: {
|
|
84
|
+
width: 0,
|
|
85
|
+
},
|
|
86
|
+
},
|
|
87
|
+
palettes: [
|
|
88
|
+
"#594bb9",
|
|
89
|
+
"#f1af32",
|
|
90
|
+
"#4688ed",
|
|
91
|
+
"#e0563e",
|
|
92
|
+
"#803a63",
|
|
93
|
+
"#6dd8b5",
|
|
94
|
+
"#e87225",
|
|
95
|
+
"#c5df42",
|
|
96
|
+
"#c6437d",
|
|
97
|
+
],
|
|
98
|
+
primaryYAxis: {
|
|
99
|
+
// Y轴标题设置为空
|
|
100
|
+
title: " ",
|
|
101
|
+
},
|
|
102
|
+
zoomSettings: {
|
|
103
|
+
enableMouseWheelZooming: false,
|
|
104
|
+
enablePinchZooming: false,
|
|
105
|
+
enableSelectionZooming: false,
|
|
106
|
+
enableDeferredZooming: false,
|
|
107
|
+
toolbarItems: [],
|
|
108
|
+
enableScrollbar: false,
|
|
109
|
+
enableZooming: false,
|
|
110
|
+
},
|
|
111
|
+
};
|
|
112
|
+
displayOption = { view: "Both", primary: "Chart" };
|
|
113
|
+
config;
|
|
114
|
+
currentTab = "tab1";
|
|
115
|
+
yList = [];
|
|
116
|
+
chartTypeList = [
|
|
117
|
+
"Column",
|
|
118
|
+
"Bar",
|
|
119
|
+
"Line",
|
|
120
|
+
"Spline",
|
|
121
|
+
"Area",
|
|
122
|
+
"Scatter",
|
|
123
|
+
"Polar",
|
|
124
|
+
"Pie",
|
|
125
|
+
"Doughnut",
|
|
126
|
+
"Stacked Column",
|
|
127
|
+
"Radar",
|
|
128
|
+
];
|
|
129
|
+
multipleAxisModeList = ["Stacked", "Single", "Combined"];
|
|
130
|
+
themeData = [
|
|
131
|
+
{
|
|
132
|
+
id: "theme13",
|
|
133
|
+
value: ["#1C3484", "#35B9FC"],
|
|
134
|
+
},
|
|
135
|
+
{
|
|
136
|
+
id: "theme14",
|
|
137
|
+
value: ["#04578F", "#3EBBCE"],
|
|
138
|
+
},
|
|
139
|
+
{
|
|
140
|
+
id: "theme15",
|
|
141
|
+
value: ["#1C3484", "#136BBB", "#35B9FC"],
|
|
142
|
+
},
|
|
143
|
+
{
|
|
144
|
+
id: "theme16",
|
|
145
|
+
value: ["#04578F", "#0082AF", "#3EBBCE"],
|
|
146
|
+
},
|
|
147
|
+
{
|
|
148
|
+
id: "theme17",
|
|
149
|
+
value: ["#1C3484", "#1659A9", "#1D97E1", "#35B9FC"],
|
|
150
|
+
},
|
|
151
|
+
{
|
|
152
|
+
id: "theme18",
|
|
153
|
+
value: ["#04578F", "#0070A3", "#16A2C2", "#3EBBCE"],
|
|
154
|
+
},
|
|
155
|
+
{
|
|
156
|
+
id: "theme19",
|
|
157
|
+
value: ["#1C3484", "#1659A9", "#1375C4", "#1D97E1", "#35B9FC"],
|
|
158
|
+
},
|
|
159
|
+
{
|
|
160
|
+
id: "theme20",
|
|
161
|
+
value: ["#04578F", "#0070A3", "#0089B4", "#16A2C2", "#3EBBCE"],
|
|
162
|
+
},
|
|
163
|
+
{
|
|
164
|
+
id: "theme21",
|
|
165
|
+
value: ["#1C3484", "#1659A9", "#1368B8", "#1375C4", "#1D97E1", "#35B9FC"],
|
|
166
|
+
},
|
|
167
|
+
{
|
|
168
|
+
id: "theme22",
|
|
169
|
+
value: ["#04578F", "#0070A3", "#007FAD", "#0089B4", "#16A2C2", "#3EBBCE"],
|
|
170
|
+
},
|
|
171
|
+
{
|
|
172
|
+
id: "theme23",
|
|
173
|
+
value: [
|
|
174
|
+
"#1C3484",
|
|
175
|
+
"#1659A9",
|
|
176
|
+
"#145FAF",
|
|
177
|
+
"#1368B8",
|
|
178
|
+
"#1375C4",
|
|
179
|
+
"#1D97E1",
|
|
180
|
+
"#35B9FC",
|
|
181
|
+
],
|
|
182
|
+
},
|
|
183
|
+
{
|
|
184
|
+
id: "theme24",
|
|
185
|
+
value: [
|
|
186
|
+
"#04578F",
|
|
187
|
+
"#0070A3",
|
|
188
|
+
"#0078A9",
|
|
189
|
+
"#007FAD",
|
|
190
|
+
"#0089B4",
|
|
191
|
+
"#16A2C2",
|
|
192
|
+
"#3EBBCE",
|
|
193
|
+
],
|
|
194
|
+
},
|
|
195
|
+
{
|
|
196
|
+
id: "theme11",
|
|
197
|
+
value: [
|
|
198
|
+
"#1C3484",
|
|
199
|
+
"#194697",
|
|
200
|
+
"#1659A9",
|
|
201
|
+
"#136BBB",
|
|
202
|
+
"#147ECC",
|
|
203
|
+
"#1B92DD",
|
|
204
|
+
"#26A5ED",
|
|
205
|
+
"#35B9FC",
|
|
206
|
+
],
|
|
207
|
+
},
|
|
208
|
+
{
|
|
209
|
+
id: "theme12",
|
|
210
|
+
value: [
|
|
211
|
+
"#04578F",
|
|
212
|
+
"#00659B",
|
|
213
|
+
"#0073A6",
|
|
214
|
+
"#0082AF",
|
|
215
|
+
"#0090B8",
|
|
216
|
+
"#0F9EC0",
|
|
217
|
+
"#29ADC7",
|
|
218
|
+
"#3EBBCE",
|
|
219
|
+
],
|
|
220
|
+
},
|
|
221
|
+
{
|
|
222
|
+
id: "theme1",
|
|
223
|
+
value: [
|
|
224
|
+
"#594bb9",
|
|
225
|
+
"#f1af32",
|
|
226
|
+
"#4688ed",
|
|
227
|
+
"#e0563e",
|
|
228
|
+
"#803a63",
|
|
229
|
+
"#6dd8b5",
|
|
230
|
+
"#e87225",
|
|
231
|
+
"#c5df42",
|
|
232
|
+
"#c6437d",
|
|
233
|
+
],
|
|
234
|
+
},
|
|
235
|
+
{
|
|
236
|
+
id: "theme2",
|
|
237
|
+
value: [
|
|
238
|
+
"#4688ed",
|
|
239
|
+
"#f1af32",
|
|
240
|
+
"#e0563e",
|
|
241
|
+
"#803a63",
|
|
242
|
+
"#6dd8b5",
|
|
243
|
+
"#e87225",
|
|
244
|
+
"#c5df42",
|
|
245
|
+
"#c6437d",
|
|
246
|
+
"#594bb9",
|
|
247
|
+
],
|
|
248
|
+
},
|
|
249
|
+
{
|
|
250
|
+
id: "theme3",
|
|
251
|
+
value: [
|
|
252
|
+
"#c6437d",
|
|
253
|
+
"#c5df42",
|
|
254
|
+
"#e87225",
|
|
255
|
+
"#6dd8b5",
|
|
256
|
+
"#e0563e",
|
|
257
|
+
"#803a63",
|
|
258
|
+
"#f1af32",
|
|
259
|
+
"#594bb9",
|
|
260
|
+
"#4688ed",
|
|
261
|
+
],
|
|
262
|
+
},
|
|
263
|
+
{
|
|
264
|
+
id: "theme4",
|
|
265
|
+
value: [
|
|
266
|
+
"#2f499f",
|
|
267
|
+
"#8d1d2e",
|
|
268
|
+
"#e9bf35",
|
|
269
|
+
"#51772f",
|
|
270
|
+
"#469bd8",
|
|
271
|
+
"#5c448f",
|
|
272
|
+
"#da732f",
|
|
273
|
+
"#245353",
|
|
274
|
+
"#43a245",
|
|
275
|
+
],
|
|
276
|
+
},
|
|
277
|
+
{
|
|
278
|
+
id: "theme5",
|
|
279
|
+
value: [
|
|
280
|
+
"#383839",
|
|
281
|
+
"#446ec6",
|
|
282
|
+
"#cf6384",
|
|
283
|
+
"#ebb37e",
|
|
284
|
+
"#71a249",
|
|
285
|
+
"#4bb1a5",
|
|
286
|
+
"#e87225",
|
|
287
|
+
"#c5df42",
|
|
288
|
+
"#c6437d",
|
|
289
|
+
],
|
|
290
|
+
},
|
|
291
|
+
{
|
|
292
|
+
id: "theme6",
|
|
293
|
+
value: [
|
|
294
|
+
"#517ae1",
|
|
295
|
+
"#6386e5",
|
|
296
|
+
"#7491e9",
|
|
297
|
+
"#849dec",
|
|
298
|
+
"#94a9ef",
|
|
299
|
+
"#a4b6f2",
|
|
300
|
+
"#b4c3f6",
|
|
301
|
+
"#c4cff9",
|
|
302
|
+
"#d4ddfd",
|
|
303
|
+
],
|
|
304
|
+
},
|
|
305
|
+
{
|
|
306
|
+
id: "theme7",
|
|
307
|
+
value: [
|
|
308
|
+
"#39828e",
|
|
309
|
+
"#488e99",
|
|
310
|
+
"#579aa5",
|
|
311
|
+
"#66a6b0",
|
|
312
|
+
"#75b3bd",
|
|
313
|
+
"#85bfc9",
|
|
314
|
+
"#95cdd6",
|
|
315
|
+
"#a4dae2",
|
|
316
|
+
"#b5e8f0",
|
|
317
|
+
],
|
|
318
|
+
},
|
|
319
|
+
{
|
|
320
|
+
id: "theme8",
|
|
321
|
+
value: [
|
|
322
|
+
"#e7963d",
|
|
323
|
+
"#ea9e4b",
|
|
324
|
+
"#eea659",
|
|
325
|
+
"#f0ae68",
|
|
326
|
+
"#f2b678",
|
|
327
|
+
"#f3bf87",
|
|
328
|
+
"#f5c798",
|
|
329
|
+
"#f6d0aa",
|
|
330
|
+
"#f7d9bb",
|
|
331
|
+
],
|
|
332
|
+
},
|
|
333
|
+
{
|
|
334
|
+
id: "theme9",
|
|
335
|
+
value: [
|
|
336
|
+
"#64a8b4",
|
|
337
|
+
"#7ebec0",
|
|
338
|
+
"#9cc9ca",
|
|
339
|
+
"#b8d4d4",
|
|
340
|
+
"#d9d6cd",
|
|
341
|
+
"#d8b7a7",
|
|
342
|
+
"#ce8f93",
|
|
343
|
+
"#c1627f",
|
|
344
|
+
"#ad2458",
|
|
345
|
+
],
|
|
346
|
+
},
|
|
347
|
+
{
|
|
348
|
+
id: "theme10",
|
|
349
|
+
value: [
|
|
350
|
+
"#4176ba",
|
|
351
|
+
"#559ae8",
|
|
352
|
+
"#70b3e8",
|
|
353
|
+
"#a7cce7",
|
|
354
|
+
"#dfdfdf",
|
|
355
|
+
"#d2a08b",
|
|
356
|
+
"#c76a50",
|
|
357
|
+
"#ca4e34",
|
|
358
|
+
"#aa3c29",
|
|
359
|
+
],
|
|
360
|
+
},
|
|
361
|
+
];
|
|
362
|
+
themeFields = { text: "value", value: "id" };
|
|
363
|
+
constructor(api, dashboardService, dashboardPorletsService, ref, pbf, http) {
|
|
364
|
+
this.api = api;
|
|
365
|
+
this.dashboardService = dashboardService;
|
|
366
|
+
this.dashboardPorletsService = dashboardPorletsService;
|
|
367
|
+
this.ref = ref;
|
|
368
|
+
this.pbf = pbf;
|
|
369
|
+
this.http = http;
|
|
370
|
+
}
|
|
371
|
+
ngOnInit() {
|
|
372
|
+
this.currentTab = this.tabactive ? "tab1" : "tab2";
|
|
373
|
+
this.getInfo();
|
|
374
|
+
this.setDatabind();
|
|
375
|
+
this.initHistoricalIRROptions();
|
|
376
|
+
this.getmultiplesList();
|
|
377
|
+
}
|
|
378
|
+
ngOnChanges() {
|
|
379
|
+
this.ref.markForCheck(); // 标记为需要检测
|
|
380
|
+
}
|
|
381
|
+
ngAfterViewInit() {
|
|
382
|
+
this.subscriptions.push(this.dashboardService.getPushbtn().subscribe((id) => {
|
|
383
|
+
if (this.dashboard && this.dashboard.id === id) {
|
|
384
|
+
this.config = this.getConfig([]);
|
|
385
|
+
this.selectedDatamart = "";
|
|
386
|
+
this.selectedX = null;
|
|
387
|
+
this.selectedY = [];
|
|
388
|
+
this.selectedSecondY = [];
|
|
389
|
+
this.selectedMultiples = null;
|
|
390
|
+
this.ref.markForCheck();
|
|
391
|
+
this.ref.detectChanges();
|
|
392
|
+
}
|
|
393
|
+
}));
|
|
394
|
+
this.subscriptions.push(this.dashboardService.getportletEdit().subscribe((dashboardId) => {
|
|
395
|
+
if (dashboardId === this.dashboardId) {
|
|
396
|
+
this.setDatabind();
|
|
397
|
+
}
|
|
398
|
+
}));
|
|
399
|
+
this.initDataMartTableList();
|
|
400
|
+
}
|
|
401
|
+
initDataMartTableList() {
|
|
402
|
+
this.dataMartTableList = [...this.dashboard.dataMartTables].filter((item) => !item.isHide);
|
|
403
|
+
this.dashboardPorletsService.renameDataMartTables(this.dataMartTableList, this.dashboard.id, this.dashboard.entityType);
|
|
404
|
+
this.dashboardPorletsService.sortDataMartTables(this.dataMartTableList);
|
|
405
|
+
if (!this.portlet) {
|
|
406
|
+
return;
|
|
407
|
+
}
|
|
408
|
+
let figureCode = this.portlet.figureCode;
|
|
409
|
+
this.dashboard.dataMartTables.forEach((item) => {
|
|
410
|
+
if (item.datamartCode === figureCode && item.prefix) {
|
|
411
|
+
figureCode = item.prefix;
|
|
412
|
+
}
|
|
413
|
+
});
|
|
414
|
+
if (!this.dataMartTableList.find((item) => item.datamartCode === figureCode)) {
|
|
415
|
+
this.dataMartTableList.forEach((data) => {
|
|
416
|
+
if (data.prefix === figureCode) {
|
|
417
|
+
figureCode = data.datamartCode;
|
|
418
|
+
}
|
|
419
|
+
});
|
|
420
|
+
}
|
|
421
|
+
this.selectedDatamart = figureCode;
|
|
422
|
+
}
|
|
423
|
+
ngOnDestroy() {
|
|
424
|
+
this.subscriptions.forEach((sb) => sb.unsubscribe());
|
|
425
|
+
}
|
|
426
|
+
nextWizard(wizard) {
|
|
427
|
+
if (!this.expandArray[wizard]) {
|
|
428
|
+
this.expandArray = [
|
|
429
|
+
false,
|
|
430
|
+
false,
|
|
431
|
+
false,
|
|
432
|
+
false,
|
|
433
|
+
false,
|
|
434
|
+
false,
|
|
435
|
+
false,
|
|
436
|
+
false,
|
|
437
|
+
];
|
|
438
|
+
this.expandArray[wizard] = true;
|
|
439
|
+
}
|
|
440
|
+
else {
|
|
441
|
+
this.expandArray[wizard] = false;
|
|
442
|
+
}
|
|
443
|
+
}
|
|
444
|
+
getInfo() {
|
|
445
|
+
this.translation = JSON.parse(localStorage.getItem("translation"));
|
|
446
|
+
this.lang = this.pbf.getLanguageParams();
|
|
447
|
+
}
|
|
448
|
+
clear() {
|
|
449
|
+
this.dashboardService.clearSidebar.next(true);
|
|
450
|
+
}
|
|
451
|
+
close() {
|
|
452
|
+
this.updatePushBtn.emit(false);
|
|
453
|
+
this.updatePorlet.emit(null);
|
|
454
|
+
this.closeSidebar.emit(false);
|
|
455
|
+
}
|
|
456
|
+
getFigurecode() {
|
|
457
|
+
let codeArr = ["Tasks", "FundList", "IRR", "Notes"];
|
|
458
|
+
let i = codeArr.indexOf(this.figureCode);
|
|
459
|
+
return i > -1 ? false : true;
|
|
460
|
+
}
|
|
461
|
+
// 图表类型更改event
|
|
462
|
+
getPortletType($event) {
|
|
463
|
+
this.portletType = $event;
|
|
464
|
+
this.hasChanged = this.config.portletType !== this.portletType;
|
|
465
|
+
const prevType = this.config.portletType;
|
|
466
|
+
this.config.portletType = this.portletType;
|
|
467
|
+
if (!$event) {
|
|
468
|
+
return;
|
|
469
|
+
}
|
|
470
|
+
if (["newcolumn", "newline", "newcolumnline"].includes($event)) {
|
|
471
|
+
this.selectedX = null;
|
|
472
|
+
this.selectedY = [];
|
|
473
|
+
this.selectedSecondY = [];
|
|
474
|
+
this.selectedMultiples = null;
|
|
475
|
+
this.expandArray[2] = false;
|
|
476
|
+
this.expandArray[7] = true;
|
|
477
|
+
// 修复有时选择 xy 轴时没有数据的问题
|
|
478
|
+
if (this.portlet && this.portlet.figureCode) {
|
|
479
|
+
this.getData(this.portlet.figureCode, false, this.portletType);
|
|
480
|
+
}
|
|
481
|
+
return;
|
|
482
|
+
}
|
|
483
|
+
if (this.portletType === "newchart") {
|
|
484
|
+
if (this.config.pvtableChartSetting &&
|
|
485
|
+
this.config.pvtableChartSetting.chartSettings) {
|
|
486
|
+
this.chartSettings = {
|
|
487
|
+
...this.config.pvtableChartSetting.chartSettings,
|
|
488
|
+
};
|
|
489
|
+
}
|
|
490
|
+
else {
|
|
491
|
+
this.chartSettings = {
|
|
492
|
+
legendSettings: {
|
|
493
|
+
visible: false,
|
|
494
|
+
},
|
|
495
|
+
enableMultipleAxis: false,
|
|
496
|
+
showMultiLevelLabels: false,
|
|
497
|
+
chartSeries: {
|
|
498
|
+
type: "Column",
|
|
499
|
+
width: 2,
|
|
500
|
+
},
|
|
501
|
+
multipleAxisMode: "Stacked",
|
|
502
|
+
primaryXAxis: {
|
|
503
|
+
title: " ",
|
|
504
|
+
majorGridLines: { width: 0 },
|
|
505
|
+
},
|
|
506
|
+
chartArea: {
|
|
507
|
+
opacity: 0,
|
|
508
|
+
border: {
|
|
509
|
+
width: 0,
|
|
510
|
+
},
|
|
511
|
+
},
|
|
512
|
+
palettes: [
|
|
513
|
+
"#594bb9",
|
|
514
|
+
"#f1af32",
|
|
515
|
+
"#4688ed",
|
|
516
|
+
"#e0563e",
|
|
517
|
+
"#803a63",
|
|
518
|
+
"#6dd8b5",
|
|
519
|
+
"#e87225",
|
|
520
|
+
"#c5df42",
|
|
521
|
+
"#c6437d",
|
|
522
|
+
],
|
|
523
|
+
primaryYAxis: {
|
|
524
|
+
// Y轴标题设置为空
|
|
525
|
+
title: " ",
|
|
526
|
+
},
|
|
527
|
+
zoomSettings: {
|
|
528
|
+
enableMouseWheelZooming: false,
|
|
529
|
+
enablePinchZooming: false,
|
|
530
|
+
enableSelectionZooming: false,
|
|
531
|
+
enableDeferredZooming: false,
|
|
532
|
+
toolbarItems: [],
|
|
533
|
+
enableScrollbar: false,
|
|
534
|
+
enableZooming: false,
|
|
535
|
+
},
|
|
536
|
+
};
|
|
537
|
+
}
|
|
538
|
+
}
|
|
539
|
+
if ($event === "historicalIRR") {
|
|
540
|
+
this.onSelectedHistoricalIRRPortlet();
|
|
541
|
+
this.expandArray[2] = false;
|
|
542
|
+
this.expandArray[7] = true;
|
|
543
|
+
return;
|
|
544
|
+
}
|
|
545
|
+
this.expandArray[2] = false;
|
|
546
|
+
this.expandArray[3] = true;
|
|
547
|
+
if (this.portletType) {
|
|
548
|
+
this.AddOrEditPortlet();
|
|
549
|
+
}
|
|
550
|
+
}
|
|
551
|
+
changeDataTable(value) {
|
|
552
|
+
this.selectedDataTable = this.dataMartTableList.filter((el) => el.datamartCode === value)[0].id;
|
|
553
|
+
this.selectedDatamart = value;
|
|
554
|
+
if (this.portlet) {
|
|
555
|
+
this.portlet.figureCode = value;
|
|
556
|
+
this.portlet.dashboardDataTableId = this.getSelectDatamartId();
|
|
557
|
+
}
|
|
558
|
+
if (this.portlet) {
|
|
559
|
+
this.dashboardService.clearFieldList.next(this.portlet.newId);
|
|
560
|
+
}
|
|
561
|
+
if (this.portlet) {
|
|
562
|
+
this.dashboardPorletsService.clearFieldsObj(this.portlet);
|
|
563
|
+
}
|
|
564
|
+
this.getData(value);
|
|
565
|
+
this.expandArray[0] = false;
|
|
566
|
+
this.expandArray[2] = true;
|
|
567
|
+
}
|
|
568
|
+
_updatePorletConfig(e) {
|
|
569
|
+
this.updatePorletConfig.emit(e);
|
|
570
|
+
}
|
|
571
|
+
getData(code, edit = true, portletType = "") {
|
|
572
|
+
const dataObj = {
|
|
573
|
+
dataMartCode: code,
|
|
574
|
+
language: this.lang,
|
|
575
|
+
};
|
|
576
|
+
this.dashboardPorletsService.setSchemaParams(dataObj, code, this.dashboard);
|
|
577
|
+
this.http.post(this.api.urlList.GetSchema, dataObj, (res) => {
|
|
578
|
+
if (res) {
|
|
579
|
+
if ([
|
|
580
|
+
"SeeThroughQuarterly",
|
|
581
|
+
"SeeThroughYearly",
|
|
582
|
+
"SeeThroughMonthly",
|
|
583
|
+
].includes(code)) {
|
|
584
|
+
res = res.filter((item) => ![
|
|
585
|
+
"CI_MTD",
|
|
586
|
+
"CI_QTD",
|
|
587
|
+
"CI_YTD",
|
|
588
|
+
"CTWR_MTD",
|
|
589
|
+
"CTWR_QTD",
|
|
590
|
+
"CTWR_YTD",
|
|
591
|
+
"CVAR_MTD_95",
|
|
592
|
+
"CVAR_MTD_99",
|
|
593
|
+
"CVAR_QTD_95",
|
|
594
|
+
"CVAR_QTD_99",
|
|
595
|
+
"CVAR_YTD_95",
|
|
596
|
+
"CVAR_YTD_99",
|
|
597
|
+
].includes(item.colName));
|
|
598
|
+
}
|
|
599
|
+
if (!this.dashboardPorletsService.fieldsArr[this.dashboard.id]) {
|
|
600
|
+
this.dashboardPorletsService.fieldsArr[this.dashboard.id] = {};
|
|
601
|
+
}
|
|
602
|
+
this.dashboardPorletsService.fieldsArr[this.dashboard.id][this.selectedDatamart] = res;
|
|
603
|
+
if (this.portlet) {
|
|
604
|
+
if (this.portlet.config) {
|
|
605
|
+
this.config = JSON.parse(this.portlet.config);
|
|
606
|
+
}
|
|
607
|
+
else {
|
|
608
|
+
this.config = {};
|
|
609
|
+
}
|
|
610
|
+
if (portletType) {
|
|
611
|
+
this.config.portletType = portletType;
|
|
612
|
+
}
|
|
613
|
+
this.config.fields = res;
|
|
614
|
+
// TO DO 过滤Y轴的数据
|
|
615
|
+
this.yList = res;
|
|
616
|
+
this.portlet.config = this.config ? JSON.stringify(this.config) : "";
|
|
617
|
+
edit && this.AddOrEditPortlet();
|
|
618
|
+
}
|
|
619
|
+
else {
|
|
620
|
+
this.config.fields = res;
|
|
621
|
+
setTimeout(() => {
|
|
622
|
+
const portlet = Object.assign({}, this.portlet);
|
|
623
|
+
portlet.config = this.config;
|
|
624
|
+
this.updatePorlet.emit(portlet);
|
|
625
|
+
// TO DO 过滤Y轴的数据
|
|
626
|
+
this.yList = res;
|
|
627
|
+
});
|
|
628
|
+
}
|
|
629
|
+
}
|
|
630
|
+
});
|
|
631
|
+
}
|
|
632
|
+
setMultipleAxis(e) {
|
|
633
|
+
setTimeout(() => {
|
|
634
|
+
if (!this.chartSettings.enableMultipleAxis) {
|
|
635
|
+
this.chartSettings.legendSettings.visible = false;
|
|
636
|
+
this.ref.markForCheck();
|
|
637
|
+
}
|
|
638
|
+
this.dashboardService.enableMultipleAxisChange.next({
|
|
639
|
+
newId: this.portlet.newId,
|
|
640
|
+
enableMultipleAxis: this.chartSettings.enableMultipleAxis,
|
|
641
|
+
visible: this.chartSettings.legendSettings.visible,
|
|
642
|
+
multipleAxisMode: this.chartSettings.multipleAxisMode,
|
|
643
|
+
});
|
|
644
|
+
});
|
|
645
|
+
}
|
|
646
|
+
setChartType() {
|
|
647
|
+
const portlet = Object.assign({}, this.portlet);
|
|
648
|
+
if (portlet.config) {
|
|
649
|
+
const config = JSON.parse(portlet.config);
|
|
650
|
+
config.pvtableChartSetting = config.pvtableChartSetting
|
|
651
|
+
? {
|
|
652
|
+
...config.pvtableChartSetting,
|
|
653
|
+
chartSettings: this.chartSettings,
|
|
654
|
+
}
|
|
655
|
+
: { chartSettings: this.chartSettings };
|
|
656
|
+
portlet.config = JSON.stringify(config);
|
|
657
|
+
}
|
|
658
|
+
this.updatePorlet.emit(portlet);
|
|
659
|
+
setTimeout(() => {
|
|
660
|
+
this.dashboardService.chartTypeChange.next({
|
|
661
|
+
newId: this.portlet.newId,
|
|
662
|
+
chartSettings: this.chartSettings,
|
|
663
|
+
});
|
|
664
|
+
});
|
|
665
|
+
}
|
|
666
|
+
getThemeData(e) {
|
|
667
|
+
const id = e.value;
|
|
668
|
+
const portlet = this.portlet;
|
|
669
|
+
const theme = this.themeData.find((item) => item.id === id);
|
|
670
|
+
if (!theme) {
|
|
671
|
+
return;
|
|
672
|
+
}
|
|
673
|
+
this.dashboardService.setTheme.next({
|
|
674
|
+
newId: portlet.newId,
|
|
675
|
+
theme: theme.value,
|
|
676
|
+
});
|
|
677
|
+
}
|
|
678
|
+
AddOrEditPortlet() {
|
|
679
|
+
const portletType = this.config.portletType === "historicalIRR"
|
|
680
|
+
? this.config.selectedVisualType
|
|
681
|
+
: this.config.portletType;
|
|
682
|
+
if (this.portlet && this.portlet.newId) {
|
|
683
|
+
// SMP2-17654 需要将选择的 frequency、investor、visual type 保存到 config 中用来拿取后端数据
|
|
684
|
+
// 但是如果直接保存 this.config 会出现 SMP2-18837 这个 BUG
|
|
685
|
+
const config = JSON.parse(this.portlet.config);
|
|
686
|
+
if (this.hasChanged) {
|
|
687
|
+
if (["newcolumn", "newline", "newcolumnline"].includes(portletType) &&
|
|
688
|
+
(this.selectedY.length > 0 || this.selectedSecondY.length > 0)) {
|
|
689
|
+
config["selectedX"] = this.selectedX;
|
|
690
|
+
config["selectedY"] = this.selectedY;
|
|
691
|
+
config["selectedSecondY"] = this.selectedSecondY;
|
|
692
|
+
config["selectedMultiples"] = this.selectedMultiples;
|
|
693
|
+
config["selectTheme"] = this.selectTheme;
|
|
694
|
+
}
|
|
695
|
+
if (config.portletType === "newchart") {
|
|
696
|
+
config.pvtableChartSetting = {
|
|
697
|
+
chartSettings: this.chartSettings,
|
|
698
|
+
displayOption: this.displayOption,
|
|
699
|
+
};
|
|
700
|
+
}
|
|
701
|
+
}
|
|
702
|
+
config.selectedMultiples = this.config.selectedMultiples;
|
|
703
|
+
config.selectedInvestor = this.config.selectedInvestor;
|
|
704
|
+
config.selectedVisualType = this.config.selectedVisualType;
|
|
705
|
+
const portlet = Object.assign({}, this.portlet);
|
|
706
|
+
portlet.config = JSON.stringify(config);
|
|
707
|
+
// 新增DataTable类型, 编辑Porlet
|
|
708
|
+
this.dashboardPorletsService.setDataManager([this.getTrueSelectedDatamart()], (res) => {
|
|
709
|
+
this.pbf.pageLoading = false;
|
|
710
|
+
this.pbf.pageLoading_.next(true);
|
|
711
|
+
this.editPortlet();
|
|
712
|
+
}, [portletType], this.dashboard.id, portlet);
|
|
713
|
+
}
|
|
714
|
+
else {
|
|
715
|
+
this.config.fields.map((el) => {
|
|
716
|
+
el.visible = true;
|
|
717
|
+
});
|
|
718
|
+
if (["newcolumn", "newline", "newcolumnline"].includes(portletType) &&
|
|
719
|
+
(this.selectedY.length > 0 || this.selectedSecondY.length > 0)) {
|
|
720
|
+
this.config["selectedX"] = this.selectedX;
|
|
721
|
+
this.config["selectedY"] = this.selectedY;
|
|
722
|
+
this.config["selectedSecondY"] = this.selectedSecondY;
|
|
723
|
+
this.config["selectedMultiples"] = this.selectedMultiples;
|
|
724
|
+
this.config["selectTheme"] = this.selectTheme;
|
|
725
|
+
}
|
|
726
|
+
if (this.config.portletType === "newchart") {
|
|
727
|
+
this.config.pvtableChartSetting = {
|
|
728
|
+
chartSettings: this.chartSettings,
|
|
729
|
+
displayOption: this.displayOption,
|
|
730
|
+
};
|
|
731
|
+
}
|
|
732
|
+
this.getSelectDatamartId();
|
|
733
|
+
const portletdata = {
|
|
734
|
+
id: "00000000-0000-0000-0000-000000000000",
|
|
735
|
+
newId: "portlet_" + this.pbf.Guid(),
|
|
736
|
+
dashboardDataTableId: this.getSelectDatamartId(),
|
|
737
|
+
figureCode: this.getTrueSelectedDatamart(),
|
|
738
|
+
col: 0,
|
|
739
|
+
row: 0,
|
|
740
|
+
sizeX: 2,
|
|
741
|
+
sizeY: 1,
|
|
742
|
+
posX: 0,
|
|
743
|
+
posY: 0,
|
|
744
|
+
height: 1,
|
|
745
|
+
width: 2,
|
|
746
|
+
config: JSON.stringify(this.config),
|
|
747
|
+
};
|
|
748
|
+
this.updatePorlet.emit(portletdata);
|
|
749
|
+
this.portlets.forEach((portlet) => {
|
|
750
|
+
portlet.row += 1;
|
|
751
|
+
});
|
|
752
|
+
// 新增DataTable类型, 新增Porlet
|
|
753
|
+
this.dashboardPorletsService.setDataManager([this.getTrueSelectedDatamart()], (res) => {
|
|
754
|
+
setTimeout(() => {
|
|
755
|
+
this.dashboardService.addOrdelPortlet.next(this.dashboard.id);
|
|
756
|
+
this.pbf.pageLoading = false;
|
|
757
|
+
this.pbf.pageLoading_.next(true);
|
|
758
|
+
}, 200);
|
|
759
|
+
}, [portletType], this.dashboard.id, portletdata);
|
|
760
|
+
}
|
|
761
|
+
}
|
|
762
|
+
editPortlet() {
|
|
763
|
+
if (this.portlet) {
|
|
764
|
+
const portletType = this.config.portletType === "historicalIRR"
|
|
765
|
+
? this.config.selectedVisualType
|
|
766
|
+
: this.config.portletType;
|
|
767
|
+
if (["table", "transpose", "financialTable"].includes(portletType)) {
|
|
768
|
+
this.config.filterSettings = [];
|
|
769
|
+
this.config.fields.map((el) => {
|
|
770
|
+
el.visible = true;
|
|
771
|
+
});
|
|
772
|
+
}
|
|
773
|
+
const index = this.portlets.findIndex((x) => x.newId === this.portlet.newId);
|
|
774
|
+
if (index > -1) {
|
|
775
|
+
this.portlets[index].config = JSON.stringify(this.config);
|
|
776
|
+
if (["newcolumn", "newline", "newcolumnline"].includes(portletType)) {
|
|
777
|
+
this.portlets[index].figureCode = this.getTrueSelectedDatamart();
|
|
778
|
+
}
|
|
779
|
+
const portlet = Object.assign({}, this.portlet);
|
|
780
|
+
portlet.config = JSON.stringify(this.config);
|
|
781
|
+
portlet.dashboardDataTableId = this.getSelectDatamartId();
|
|
782
|
+
this.updatePorlet.emit(portlet);
|
|
783
|
+
}
|
|
784
|
+
const id = this.portlet.id || this.portlet.newId;
|
|
785
|
+
this.chartUpdate.emit(id);
|
|
786
|
+
}
|
|
787
|
+
}
|
|
788
|
+
switchTab(type) {
|
|
789
|
+
this.currentTab = type;
|
|
790
|
+
this.onToggleTabactive.emit(!this.tabactive);
|
|
791
|
+
this.dashboardService.portletEdit.next(this.dashboardId);
|
|
792
|
+
}
|
|
793
|
+
gadgetTitleChange(newObj) {
|
|
794
|
+
if (!this.portlet || !this.portlet.config) {
|
|
795
|
+
return;
|
|
796
|
+
}
|
|
797
|
+
this.config = JSON.parse(this.portlet.config);
|
|
798
|
+
this.config.gadgetTitle = newObj;
|
|
799
|
+
const index = this.portlets.findIndex((x) => x.newId === this.portlet.newId);
|
|
800
|
+
if (index > -1)
|
|
801
|
+
this.portlets[index].config = JSON.stringify(this.config);
|
|
802
|
+
this.portlet.config = JSON.stringify(this.config);
|
|
803
|
+
this.dashboardService.portletTitle.next(true);
|
|
804
|
+
}
|
|
805
|
+
setDatabind() {
|
|
806
|
+
if (this.portlet) {
|
|
807
|
+
const { dataMartTables = {} } = this.dashboardPorletsService;
|
|
808
|
+
let figureCode = this.portlet.figureCode;
|
|
809
|
+
dataMartTables[this.dashboard.id].forEach((item) => {
|
|
810
|
+
if (item.datamartCode === figureCode && item.prefix) {
|
|
811
|
+
figureCode = item.prefix;
|
|
812
|
+
}
|
|
813
|
+
});
|
|
814
|
+
if (this.dataMartTableList &&
|
|
815
|
+
this.dataMartTableList.length &&
|
|
816
|
+
!this.dataMartTableList.find((item) => item.datamartCode === figureCode)) {
|
|
817
|
+
this.dataMartTableList.forEach((data) => {
|
|
818
|
+
if (data.prefix === figureCode) {
|
|
819
|
+
figureCode = data.datamartCode;
|
|
820
|
+
}
|
|
821
|
+
});
|
|
822
|
+
}
|
|
823
|
+
this.selectedDatamart = figureCode;
|
|
824
|
+
this.config = {};
|
|
825
|
+
if (this.portlet.config)
|
|
826
|
+
this.config = JSON.parse(this.portlet.config);
|
|
827
|
+
this.hasMarker = this.config.hasMarker;
|
|
828
|
+
this.markerFormat = this.config.markerFormat || "";
|
|
829
|
+
if (this.config.portletType === "historicalIRR") {
|
|
830
|
+
this.selectedMultiples = this.config.selectedMultiples;
|
|
831
|
+
this.selectedInvestor = this.config.selectedInvestor;
|
|
832
|
+
this.selectedVisualType = this.config.selectedVisualType;
|
|
833
|
+
this.portletType = this.config.portletType;
|
|
834
|
+
}
|
|
835
|
+
const portletType = this.config.portletType === "historicalIRR"
|
|
836
|
+
? this.config.selectedVisualType
|
|
837
|
+
: this.config.portletType;
|
|
838
|
+
if (["newcolumn", "newline", "newcolumnline"].includes(portletType)) {
|
|
839
|
+
this.selectedX = this._selectedX;
|
|
840
|
+
this.selectedY = this._selectedY;
|
|
841
|
+
this.selectedSecondY = this._selectedSecondY;
|
|
842
|
+
this.selectedMultiples = this._selectedMultiples;
|
|
843
|
+
this.selectTheme = this._selectTheme;
|
|
844
|
+
this.portletType = this.config.portletType;
|
|
845
|
+
this.getData(this.portlet.figureCode, false);
|
|
846
|
+
}
|
|
847
|
+
if (this.config.portletType === "newchart") {
|
|
848
|
+
this.portletType = "newchart";
|
|
849
|
+
if (this.config.pvtableChartSetting) {
|
|
850
|
+
this.chartSettings = {
|
|
851
|
+
...this.config.pvtableChartSetting.chartSettings,
|
|
852
|
+
};
|
|
853
|
+
if (this.config.pvtableChartSetting.chartSettings.palettes) {
|
|
854
|
+
const { palettes } = this.config.pvtableChartSetting.chartSettings;
|
|
855
|
+
if (palettes && palettes.length) {
|
|
856
|
+
this.selectTheme = this.themeData.find((item) =>
|
|
857
|
+
// 用于判断两个
|
|
858
|
+
JSON.stringify(item.value) === JSON.stringify(palettes)).id;
|
|
859
|
+
}
|
|
860
|
+
}
|
|
861
|
+
}
|
|
862
|
+
else {
|
|
863
|
+
this.config.pvtableChartSetting = {
|
|
864
|
+
displayOption: this.displayOption,
|
|
865
|
+
chartSettings: this.chartSettings,
|
|
866
|
+
};
|
|
867
|
+
}
|
|
868
|
+
}
|
|
869
|
+
}
|
|
870
|
+
else {
|
|
871
|
+
this.selectedDatamart = "";
|
|
872
|
+
this.config = this.getConfig([]);
|
|
873
|
+
}
|
|
874
|
+
this.ref.markForCheck();
|
|
875
|
+
this.ref.detectChanges();
|
|
876
|
+
}
|
|
877
|
+
getConfig(fields) {
|
|
878
|
+
return {
|
|
879
|
+
tabId: this.activeTabId,
|
|
880
|
+
tabLabel: this.activeTabLabel,
|
|
881
|
+
portletType: "",
|
|
882
|
+
gadgetTitle: "",
|
|
883
|
+
isUpToDate: false,
|
|
884
|
+
period: 3,
|
|
885
|
+
pagebreak: false,
|
|
886
|
+
timeMeasure: "MTD",
|
|
887
|
+
series: [],
|
|
888
|
+
sSeries: [],
|
|
889
|
+
trendsOrder: 1,
|
|
890
|
+
showTrends: true,
|
|
891
|
+
numberFormat: "#,##0",
|
|
892
|
+
showCurrentData: false,
|
|
893
|
+
fields: fields,
|
|
894
|
+
allFields: [
|
|
895
|
+
{
|
|
896
|
+
colName: "ALL_TEXT_FIELDS",
|
|
897
|
+
langValue: "All text fields",
|
|
898
|
+
dataType: "string",
|
|
899
|
+
},
|
|
900
|
+
{
|
|
901
|
+
colName: "ALL_DATE_FIELDS",
|
|
902
|
+
langValue: "All date fields",
|
|
903
|
+
dataType: "date",
|
|
904
|
+
},
|
|
905
|
+
{
|
|
906
|
+
colName: "ALL_NUMBER_FIELDS",
|
|
907
|
+
langValue: "All number fields",
|
|
908
|
+
dataType: "number",
|
|
909
|
+
},
|
|
910
|
+
{
|
|
911
|
+
colName: "ALL_INTEGER_FIELDS",
|
|
912
|
+
langValue: "All integer fields",
|
|
913
|
+
dataType: "integer",
|
|
914
|
+
},
|
|
915
|
+
{
|
|
916
|
+
colName: "ALL_PERCENTAGE_FIELDS",
|
|
917
|
+
langValue: "All percentage fields",
|
|
918
|
+
dataType: "percent",
|
|
919
|
+
},
|
|
920
|
+
{
|
|
921
|
+
colName: "ALL_MULTIPLE_FIELDS",
|
|
922
|
+
langValue: "All multiple fields",
|
|
923
|
+
dataType: "multiple",
|
|
924
|
+
},
|
|
925
|
+
],
|
|
926
|
+
filters: [],
|
|
927
|
+
filterSettings: [],
|
|
928
|
+
columnGroup: [],
|
|
929
|
+
listOfInvesteeId: [],
|
|
930
|
+
investeeId: "00000000-0000-0000-0000-000000000000",
|
|
931
|
+
groupBy: "",
|
|
932
|
+
groups: [],
|
|
933
|
+
asOfDate: "",
|
|
934
|
+
currencyCode: "",
|
|
935
|
+
fundId: "00000000-0000-0000-0000-000000000000",
|
|
936
|
+
xaxis: { groups: [] },
|
|
937
|
+
yaxis: {
|
|
938
|
+
series: [{ portletType: "", colName: "", calMethod: "" }],
|
|
939
|
+
},
|
|
940
|
+
calculatedFieldSettings: [],
|
|
941
|
+
columnsWidth: [],
|
|
942
|
+
sortSettings: [],
|
|
943
|
+
groupSettings: [],
|
|
944
|
+
valueSortSettings: {},
|
|
945
|
+
showGrandTotals: true,
|
|
946
|
+
showRowGrandTotals: true,
|
|
947
|
+
showColumnGrandTotals: true,
|
|
948
|
+
showSubTotals: true,
|
|
949
|
+
showRowSubTotals: true,
|
|
950
|
+
showColumnSubTotals: true,
|
|
951
|
+
};
|
|
952
|
+
}
|
|
953
|
+
selectedInvestor = null;
|
|
954
|
+
investorList = [];
|
|
955
|
+
selectedVisualType = null;
|
|
956
|
+
visualTypeList = [];
|
|
957
|
+
// historical IRR frequency 不需要 Daily
|
|
958
|
+
get frequencyOptions() {
|
|
959
|
+
return this.multiplesList.filter((i) => i.langCode !== "DAILY");
|
|
960
|
+
}
|
|
961
|
+
initHistoricalIRROptions() {
|
|
962
|
+
const chartText = this.translation.COMPANY_CHART || ".COMPANY_CHART";
|
|
963
|
+
this.investorList = [
|
|
964
|
+
{
|
|
965
|
+
code: "All",
|
|
966
|
+
text: this.translation.ALL,
|
|
967
|
+
},
|
|
968
|
+
{
|
|
969
|
+
code: "ExcludeGP&SLP",
|
|
970
|
+
text: this.translation["EXCLUDE_GP&SLP"] || ".Exclude GP&SLP",
|
|
971
|
+
},
|
|
972
|
+
];
|
|
973
|
+
this.visualTypeList = [
|
|
974
|
+
{
|
|
975
|
+
code: "newline",
|
|
976
|
+
text: `${this.translation.LINE || ".LINE"} ${chartText}`,
|
|
977
|
+
},
|
|
978
|
+
{
|
|
979
|
+
code: "newcolumn",
|
|
980
|
+
text: `${this.translation.COLUMN} ${chartText}`,
|
|
981
|
+
},
|
|
982
|
+
{
|
|
983
|
+
code: "table",
|
|
984
|
+
text: this.translation.TABLE || ".TABLE",
|
|
985
|
+
},
|
|
986
|
+
];
|
|
987
|
+
}
|
|
988
|
+
onSelectedHistoricalIRRPortlet() {
|
|
989
|
+
this.selectedInvestor = "All";
|
|
990
|
+
this.selectedMultiples = "QUARTERLY";
|
|
991
|
+
this.selectedVisualType = "newline";
|
|
992
|
+
this.setHistoricalIRRChart(false);
|
|
993
|
+
}
|
|
994
|
+
setHistoricalIRRChart(opened) {
|
|
995
|
+
if (opened) {
|
|
996
|
+
return;
|
|
997
|
+
}
|
|
998
|
+
if (this.selectedVisualType !== "table" &&
|
|
999
|
+
this.config.selectedVisualType === "table") {
|
|
1000
|
+
this.hasMarker = false;
|
|
1001
|
+
}
|
|
1002
|
+
this.config.selectedVisualType = this.selectedVisualType;
|
|
1003
|
+
this.config.selectedInvestor = this.selectedInvestor;
|
|
1004
|
+
if (this.selectedVisualType !== "table") {
|
|
1005
|
+
// 这里确定 x、y 轴字段名称
|
|
1006
|
+
this.selectedX = "Date";
|
|
1007
|
+
this.selectedY = ["IRR"];
|
|
1008
|
+
return this.xyChange(false);
|
|
1009
|
+
}
|
|
1010
|
+
else {
|
|
1011
|
+
this.config.selectedMultiples = this.selectedMultiples;
|
|
1012
|
+
this.AddOrEditPortlet();
|
|
1013
|
+
}
|
|
1014
|
+
}
|
|
1015
|
+
selectedX = null;
|
|
1016
|
+
selectedY = [];
|
|
1017
|
+
selectedSecondY = [];
|
|
1018
|
+
selectedMultiples = null;
|
|
1019
|
+
markerFormat = "";
|
|
1020
|
+
markerFormatList = [
|
|
1021
|
+
{
|
|
1022
|
+
value: "",
|
|
1023
|
+
label: this.translation.NONE || ".None",
|
|
1024
|
+
},
|
|
1025
|
+
{
|
|
1026
|
+
value: "K",
|
|
1027
|
+
label: this.translation.THOUSANDS || ".Thousands",
|
|
1028
|
+
},
|
|
1029
|
+
{
|
|
1030
|
+
value: "M",
|
|
1031
|
+
label: this.translation.MILLIONS || ".Millions",
|
|
1032
|
+
},
|
|
1033
|
+
{
|
|
1034
|
+
value: "bn",
|
|
1035
|
+
label: this.translation.BILLIONS || ".Billions",
|
|
1036
|
+
},
|
|
1037
|
+
{
|
|
1038
|
+
value: "T",
|
|
1039
|
+
label: this.translation.TRILLIONS || ".Trillions",
|
|
1040
|
+
},
|
|
1041
|
+
];
|
|
1042
|
+
hasMarker = false;
|
|
1043
|
+
labelConfigChange(e) {
|
|
1044
|
+
this.config.hasMarker = e;
|
|
1045
|
+
this.updatePorletConfig.emit({
|
|
1046
|
+
newId: this.portlet.newId,
|
|
1047
|
+
config: Object.assign({}, this.config),
|
|
1048
|
+
});
|
|
1049
|
+
this.dashboardService.switchLabelConfig.next({
|
|
1050
|
+
checked: e,
|
|
1051
|
+
id: this.portlet.newId,
|
|
1052
|
+
});
|
|
1053
|
+
}
|
|
1054
|
+
xyChange(e) {
|
|
1055
|
+
if (e) {
|
|
1056
|
+
return;
|
|
1057
|
+
}
|
|
1058
|
+
setTimeout(() => {
|
|
1059
|
+
this.updateTheme.emit({
|
|
1060
|
+
selectedX: this.selectedX,
|
|
1061
|
+
selectedY: this.selectedY,
|
|
1062
|
+
selectedMultiples: this.selectedMultiples,
|
|
1063
|
+
selectedSecondY: this.selectedSecondY,
|
|
1064
|
+
selectTheme: this.selectTheme,
|
|
1065
|
+
hasMarker: this.hasMarker,
|
|
1066
|
+
markerFormat: this.markerFormat,
|
|
1067
|
+
});
|
|
1068
|
+
this.config["markerFormat"] = this.markerFormat;
|
|
1069
|
+
this.config["hasMarker"] = this.hasMarker;
|
|
1070
|
+
this.config["selectedX"] = this.selectedX;
|
|
1071
|
+
this.config["selectedY"] = this.selectedY;
|
|
1072
|
+
this.config["selectedSecondY"] = this.selectedSecondY;
|
|
1073
|
+
this.config["selectedMultiples"] = this.selectedMultiples;
|
|
1074
|
+
this.config["selectTheme"] = this.selectTheme;
|
|
1075
|
+
this.updatePorletConfig.emit({
|
|
1076
|
+
newId: this.portlet.newId,
|
|
1077
|
+
config: Object.assign({}, this.config),
|
|
1078
|
+
});
|
|
1079
|
+
this.showEdit();
|
|
1080
|
+
}, 500);
|
|
1081
|
+
}
|
|
1082
|
+
showEdit() {
|
|
1083
|
+
if (this.portletType == "newcolumnline" &&
|
|
1084
|
+
this.selectedY.length > 0 &&
|
|
1085
|
+
this.selectedSecondY.length > 0) {
|
|
1086
|
+
this.AddOrEditPortlet();
|
|
1087
|
+
}
|
|
1088
|
+
if (this.portletType != "newcolumnline" && this.selectedY.length > 0) {
|
|
1089
|
+
this.AddOrEditPortlet();
|
|
1090
|
+
}
|
|
1091
|
+
}
|
|
1092
|
+
multiplesList = [];
|
|
1093
|
+
getmultiplesList() {
|
|
1094
|
+
const url = this.appCode === "PMS"
|
|
1095
|
+
? this.api.urlList.LPGetPropertyList
|
|
1096
|
+
: this.api.urlList.GetPropertyList;
|
|
1097
|
+
this.http.post(url, { scope: "DASHBOARD_FREQUENCY", langIdx: 2 }, (res) => {
|
|
1098
|
+
this.multiplesList = res;
|
|
1099
|
+
});
|
|
1100
|
+
}
|
|
1101
|
+
capitalize(str) {
|
|
1102
|
+
// 将字符串转换为小写,并使用正则表达式将每个单词的第一个字符转换为大写
|
|
1103
|
+
if (!str) {
|
|
1104
|
+
return;
|
|
1105
|
+
}
|
|
1106
|
+
return str.toLowerCase().replace(/\b\w/g, function (char) {
|
|
1107
|
+
return char.toUpperCase();
|
|
1108
|
+
});
|
|
1109
|
+
}
|
|
1110
|
+
getSelectDatamartId() {
|
|
1111
|
+
// 获取真正的DatamartID
|
|
1112
|
+
const code = this.getTrueSelectedDatamart();
|
|
1113
|
+
let dataMartTables = this.dashboardPorletsService.dataMartTables[this.dashboard.id].filter((el) => code == el.datamartCode);
|
|
1114
|
+
if (dataMartTables.length > 0) {
|
|
1115
|
+
return dataMartTables[0].id;
|
|
1116
|
+
}
|
|
1117
|
+
}
|
|
1118
|
+
getTrueSelectedDatamart() {
|
|
1119
|
+
const portletType = this.config.portletType === "historicalIRR"
|
|
1120
|
+
? this.config.selectedVisualType
|
|
1121
|
+
: this.config.portletType;
|
|
1122
|
+
// 获取真正的DatamartCode
|
|
1123
|
+
if (["newcolumn", "newline", "newcolumnline"].includes(portletType)) {
|
|
1124
|
+
return this.getSelectDatamartCode();
|
|
1125
|
+
}
|
|
1126
|
+
else {
|
|
1127
|
+
return this.selectedDatamart;
|
|
1128
|
+
}
|
|
1129
|
+
}
|
|
1130
|
+
getSelectDatamartCode() {
|
|
1131
|
+
const item = this.dashboardPorletsService.dataMartTables[this.dashboard.id].filter((e) => {
|
|
1132
|
+
return e["datamartCode"] == this.selectedDatamart;
|
|
1133
|
+
});
|
|
1134
|
+
if (item.length > 0) {
|
|
1135
|
+
if (item[0]["prefix"]) {
|
|
1136
|
+
return `${item[0]["prefix"]}${this.capitalize(this.selectedMultiples) || ""}`;
|
|
1137
|
+
}
|
|
1138
|
+
else {
|
|
1139
|
+
return item[0]["datamartCode"];
|
|
1140
|
+
}
|
|
1141
|
+
}
|
|
1142
|
+
else {
|
|
1143
|
+
return "";
|
|
1144
|
+
}
|
|
1145
|
+
}
|
|
1146
|
+
selectTheme = "theme1";
|
|
1147
|
+
changeTheme(e, type) {
|
|
1148
|
+
this.selectTheme = e.value;
|
|
1149
|
+
this.config["selectTheme"] = this.selectTheme;
|
|
1150
|
+
this.updateTheme.emit({
|
|
1151
|
+
selectedX: this.selectedX,
|
|
1152
|
+
selectedY: this.selectedY,
|
|
1153
|
+
selectedMultiples: this.selectedMultiples,
|
|
1154
|
+
selectedSecondY: this.selectedSecondY,
|
|
1155
|
+
selectTheme: this.selectTheme,
|
|
1156
|
+
});
|
|
1157
|
+
this.showEdit();
|
|
1158
|
+
}
|
|
1159
|
+
sortDataMartTables(data) {
|
|
1160
|
+
data.sort((a, b) => {
|
|
1161
|
+
const langValueA = a.langValue.toLowerCase();
|
|
1162
|
+
const langValueB = b.langValue.toLowerCase();
|
|
1163
|
+
if (langValueA < langValueB) {
|
|
1164
|
+
return -1;
|
|
1165
|
+
}
|
|
1166
|
+
if (langValueA > langValueB) {
|
|
1167
|
+
return 1;
|
|
1168
|
+
}
|
|
1169
|
+
return 0;
|
|
1170
|
+
});
|
|
1171
|
+
}
|
|
1172
|
+
onChangeFormat() {
|
|
1173
|
+
this.dashboardService.markerFormat.next({
|
|
1174
|
+
newId: this.portlet.newId,
|
|
1175
|
+
markerFormat: this.markerFormat,
|
|
1176
|
+
});
|
|
1177
|
+
}
|
|
1178
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SidebarIconlistNewComponent, deps: [{ token: i1.ApiList }, { token: i2.DashboardService }, { token: i3.DashboardPorletsService }, { token: i0.ChangeDetectorRef }, { token: PBF_TOKEN, optional: true }, { token: API_SERVICE_TOKEN, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
1179
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: SidebarIconlistNewComponent, selector: "rs-sidebar-iconlist-new", inputs: { dashboard_sidebar: "dashboard_sidebar", dashboard: "dashboard", dashboardId: "dashboardId", activeTabId: "activeTabId", activeTabLabel: "activeTabLabel", portlets: "portlets", tabactive: "tabactive", portlet: "portlet", figureCode: "figureCode", _selectedX: "_selectedX", _selectedY: "_selectedY", _selectedMultiples: "_selectedMultiples", _selectedSecondY: "_selectedSecondY", _selectTheme: "_selectTheme", appCode: "appCode" }, outputs: { closeSidebar: "closeSidebar", updatePorletConfig: "updatePorletConfig", onToggleTabactive: "onToggleTabactive", updatePorlet: "updatePorlet", updatePushBtn: "updatePushBtn", chartUpdate: "chartUpdate", updateTheme: "updateTheme" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"sidebar-iconlist\" *ngIf=\"config\">\r\n <ul class=\"nav-tabs\">\r\n <li class=\"nav-item\">\r\n <a\r\n class=\"nav-link\"\r\n [ngClass]=\"{ active: currentTab === 'tab1' }\"\r\n data-toggle=\"tab\"\r\n (click)=\"switchTab('tab1')\"\r\n >\r\n <img\r\n style=\"margin-right: 8px\"\r\n src=\"../../../assets/img/dashboard_icon/basic-icon-filter.svg\"\r\n />\r\n <div class=\"tab-name\">\r\n {{ translation.FILTER ? translation.FILTER : \".FILTER\" }}\r\n </div>\r\n </a>\r\n </li>\r\n <li class=\"nav-item\">\r\n <a\r\n class=\"nav-link\"\r\n [ngClass]=\"{ active: currentTab === 'tab2' }\"\r\n data-toggle=\"tab\"\r\n (click)=\"switchTab('tab2')\"\r\n >\r\n <img\r\n style=\"margin-right: 8px\"\r\n src=\"../../../assets/img/dashboard_icon/dashboard-icon.svg\"\r\n />\r\n <div class=\"tab-name\">\r\n {{ translation.PROPERTIES ? translation.PROPERTIES : \".PROPERTIES\" }}\r\n </div>\r\n </a>\r\n </li>\r\n </ul>\r\n <div class=\"sidebar-iconlist-content\">\r\n <!-- <form action=\"\" method=\"\"> -->\r\n <div\r\n class=\"tab-content\"\r\n style=\"height: calc(100% - 140px); overflow-y: scroll\"\r\n >\r\n <div class=\"tab-pane\" *ngIf=\"currentTab === 'tab1'\" style=\"height: 100%\">\r\n <rs-field-filter\r\n [portlet]=\"portlet\"\r\n [dashboard]=\"dashboard\"\r\n [portlets]=\"portlets\"\r\n (updatePorletConfig)=\"_updatePorletConfig($event)\"\r\n ></rs-field-filter>\r\n </div>\r\n <div class=\"tab-pane\" *ngIf=\"currentTab === 'tab2'\">\r\n <div>\r\n <div (click)=\"nextWizard(0)\" class=\"wizard\">\r\n <span class=\"wizard-name\">\r\n {{\r\n translation.DATA_TABLE ? translation.DATA_TABLE : \"Data Table\"\r\n }}*\r\n </span>\r\n <mat-icon style=\"position: absolute; right: 0\">\r\n {{ !expandArray[0] ? \"expand_more\" : \"expand_less\" }}\r\n </mat-icon>\r\n </div>\r\n <div\r\n [ngStyle]=\"{ height: expandArray[0] ? '100px' : '0' }\"\r\n [ngClass]=\"{ collapsed: !expandArray[0] }\"\r\n class=\"wizard-expanded\"\r\n >\r\n <div class=\"data-source add-pdding\">\r\n <div style=\"margin-bottom: 10px\" class=\"twelvepx\">\r\n {{\r\n translation.FIRST_CHOOSE_THE_DATA_TABLE_TO_CUSTOMIZE_YOUR_DASHBOARD\r\n ? translation.FIRST_CHOOSE_THE_DATA_TABLE_TO_CUSTOMIZE_YOUR_DASHBOARD\r\n : \"Firstly, choose the data table to customize your dashboard\"\r\n }}\r\n </div>\r\n <div class=\"twelvepx\">\r\n <mat-select\r\n class=\"datamart-select\"\r\n [(ngModel)]=\"selectedDatamart\"\r\n (selectionChange)=\"changeDataTable($event.value)\"\r\n >\r\n <ng-container *ngFor=\"let datatable of dataMartTableList\">\r\n <!-- *ngIf=\"!datatable.isHide\" -->\r\n <mat-option [value]=\"datatable.datamartCode\">\r\n {{\r\n translation[datatable.langCode] || datatable.langCode\r\n }}\r\n </mat-option>\r\n </ng-container>\r\n </mat-select>\r\n </div>\r\n </div>\r\n </div>\r\n <div *ngIf=\"getFigurecode()\" (click)=\"nextWizard(2)\" class=\"wizard\">\r\n <span class=\"wizard-name\"\r\n >{{\r\n translation.PORTLET_TYPE\r\n ? translation.PORTLET_TYPE\r\n : \".PORTLET_TYPE\"\r\n }}*</span\r\n >\r\n <mat-icon class=\"wizard-icon\">{{\r\n !expandArray[2] ? \"expand_more\" : \"expand_less\"\r\n }}</mat-icon>\r\n </div>\r\n <!-- \u56FE\u8868\u7C7B\u578B\u9009\u62E9 -->\r\n <div\r\n *ngIf=\"getFigurecode()\"\r\n [ngClass]=\"{ collapsed: !expandArray[2] }\"\r\n class=\"wizard-expanded portlets\"\r\n >\r\n <rs-portlet-type-new\r\n [portlet]=\"portlet\"\r\n [dashboard]=\"dashboard\"\r\n [dataMartCode]=\"selectedDatamart\"\r\n (portletType)=\"getPortletType($event)\"\r\n >\r\n </rs-portlet-type-new>\r\n </div>\r\n\r\n <!-- new dashboard \u5E76\u4E14\u9009\u62E9\u56FE\u6807\u7C7B\u578B \u624D\u6709\u7684\u4F9B\u4E09\u4E2A\u56FE\u8868\u9009\u62E9\u7684X\u8F74Y\u8F74 -->\r\n <ng-container\r\n *ngIf=\"\r\n ['newcolumn', 'newline', 'newcolumnline'].includes(portletType)\r\n \"\r\n >\r\n <div class=\"wizard\" (click)=\"nextWizard(7)\">\r\n <span class=\"wizard-name\"\r\n >{{ translation.CONFIGURATIONS || \".CONFIGURATIONS\" }}*</span\r\n >\r\n <mat-icon class=\"wizard-icon\">{{\r\n !expandArray[7] ? \"expand_more\" : \"expand_less\"\r\n }}</mat-icon>\r\n </div>\r\n\r\n <!-- \u56FE\u6807\u914D\u7F6E\u9879 configuration -->\r\n <div\r\n [ngClass]=\"{ collapsed: !expandArray[7] }\"\r\n class=\"wizard-expanded config\"\r\n >\r\n <div style=\"padding-left: 18px\">\r\n <div style=\"margin-bottom: 10px\" class=\"twelvepx\">\r\n {{ translation.COLORS || \".COLORS\" }}\r\n </div>\r\n\r\n <ejs-dropdownlist\r\n style=\"margin-bottom: 10px\"\r\n id=\"employees\"\r\n [dataSource]=\"themeData\"\r\n [allowFiltering]=\"true\"\r\n [filterType]=\"'Contains'\"\r\n [itemTemplate]=\"itemTemplate\"\r\n [valueTemplate]=\"valueTemplate\"\r\n [fields]=\"themeFields\"\r\n [value]=\"selectTheme\"\r\n (change)=\"changeTheme($event, 'theme')\"\r\n class=\"color-ipt\"\r\n >\r\n <ng-template #itemTemplate let-data>\r\n <div class=\"color-box\">\r\n <div\r\n *ngFor=\"let i of data.value\"\r\n class=\"color-item\"\r\n [ngStyle]=\"{\r\n 'background-color': i\r\n }\"\r\n ></div>\r\n </div>\r\n </ng-template>\r\n <ng-template #valueTemplate let-data>\r\n <div class=\"color-box\">\r\n <div\r\n *ngFor=\"let item of data.value\"\r\n class=\"color-item\"\r\n [ngStyle]=\"{\r\n 'background-color': item\r\n }\"\r\n ></div>\r\n </div>\r\n </ng-template>\r\n </ejs-dropdownlist>\r\n\r\n <div style=\"margin-bottom: 10px\" class=\"twelvepx\">\r\n {{ translation.X_AXIS || \".X-AXIS\" }}\r\n </div>\r\n\r\n <mat-select\r\n [(value)]=\"selectedX\"\r\n (openedChange)=\"xyChange($event)\"\r\n class=\"datamart-select\"\r\n >\r\n <ng-container *ngFor=\"let i of yList\">\r\n <mat-option\r\n *ngIf=\"!i.isCalculatedField\"\r\n [value]=\"i.colName\"\r\n >{{\r\n (translation[i.langCode]\r\n ? translation[i.langCode]\r\n : \".\" + i.langCode) +\r\n (i.addtionName ? \" \" + i.addtionName : \"\")\r\n }}</mat-option\r\n >\r\n </ng-container>\r\n </mat-select>\r\n\r\n <ng-container *ngIf=\"selectedX\">\r\n <div style=\"margin-bottom: 10px\" class=\"twelvepx\">\r\n {{ translation.FREQUENCY || \".FREQUENCY\" }}\r\n </div>\r\n\r\n <mat-select\r\n [(value)]=\"selectedMultiples\"\r\n (openedChange)=\"xyChange($event)\"\r\n class=\"datamart-select\"\r\n >\r\n <mat-option\r\n *ngFor=\"let i of multiplesList\"\r\n [value]=\"i.langCode\"\r\n >{{\r\n i.addtionName\r\n ? i.addtionName + \"\" + translation[i.langCode]\r\n : translation[i.langCode]\r\n }}</mat-option\r\n >\r\n </mat-select>\r\n </ng-container>\r\n\r\n <div style=\"margin-bottom: 10px\" class=\"twelvepx\">\r\n {{\r\n portletType === \"newcolumnline\"\r\n ? (translation.COLUMN ? translation.COLUMN + \" \" : \"\") +\r\n (translation.Y_AXIS || \".COLUMN Y-AXIS\")\r\n : translation.Y_AXIS || \".Y-AXIS\"\r\n }}\r\n </div>\r\n\r\n <mat-select\r\n multiple\r\n [(value)]=\"selectedY\"\r\n (openedChange)=\"xyChange($event)\"\r\n class=\"datamart-select\"\r\n >\r\n <ng-container *ngFor=\"let i of yList\">\r\n <mat-option\r\n *ngIf=\"!i.isCalculatedField\"\r\n [value]=\"i.colName\"\r\n >{{\r\n (translation[i.langCode]\r\n ? translation[i.langCode]\r\n : \".\" + i.langCode) +\r\n (i.addtionName ? \" \" + i.addtionName : \"\")\r\n }}</mat-option\r\n >\r\n </ng-container>\r\n </mat-select>\r\n\r\n <div\r\n style=\"margin-bottom: 10px\"\r\n class=\"twelvepx\"\r\n *ngIf=\"portletType == 'newcolumnline'\"\r\n >\r\n {{\r\n (translation.LINE ? translation.LINE + \" \" : \"\") +\r\n (translation.Y_AXIS || \".LINE Y-AXIS\")\r\n }}\r\n </div>\r\n\r\n <mat-select\r\n multiple\r\n class=\"datamart-select\"\r\n [(value)]=\"selectedSecondY\"\r\n (openedChange)=\"xyChange($event)\"\r\n panelClass=\"mat-select-multi-panel\"\r\n *ngIf=\"portletType == 'newcolumnline'\"\r\n >\r\n <ng-container *ngFor=\"let i of yList\">\r\n <mat-option\r\n *ngIf=\"!i.isCalculatedField\"\r\n [value]=\"i.colName\"\r\n >{{\r\n (translation[i.langCode]\r\n ? translation[i.langCode]\r\n : \".\" + i.langCode) +\r\n (i.addtionName ? \" \" + i.addtionName : \"\")\r\n }}</mat-option\r\n >\r\n </ng-container>\r\n </mat-select>\r\n\r\n <div class=\"data-label-content\">\r\n <div class=\"label\">\r\n {{ translation.DATA_LABEL || \".Data labels\" }}\r\n </div>\r\n <ejs-switch\r\n [(ngModel)]=\"hasMarker\"\r\n (ngModelChange)=\"labelConfigChange($event)\"\r\n ></ejs-switch>\r\n </div>\r\n\r\n <div style=\"margin: 10px 0\" class=\"twelvepx\">\r\n {{ translation.DISPLAY_UNITS || \".Display Units\" }}\r\n </div>\r\n\r\n <mat-select\r\n class=\"datamart-select\"\r\n [(ngModel)]=\"markerFormat\"\r\n (ngModelChange)=\"onChangeFormat()\"\r\n >\r\n <ng-container *ngFor=\"let format of markerFormatList\">\r\n <mat-option [value]=\"format.value\">{{\r\n format.label\r\n }}</mat-option>\r\n </ng-container>\r\n </mat-select>\r\n </div>\r\n </div>\r\n </ng-container>\r\n\r\n <!-- historical IRR \u4E13\u7528 -->\r\n <ng-container *ngIf=\"['historicalIRR'].includes(portletType)\">\r\n <div class=\"wizard\" (click)=\"nextWizard(7)\">\r\n <span class=\"wizard-name\"\r\n >{{ translation.CONFIGURATIONS || \"CONFIGURATIONS\" }}*</span\r\n >\r\n <mat-icon class=\"wizard-icon\">{{\r\n !expandArray[7] ? \"expand_more\" : \"expand_less\"\r\n }}</mat-icon>\r\n </div>\r\n\r\n <!-- \u56FE\u6807\u914D\u7F6E\u9879 configuration -->\r\n <div\r\n [ngClass]=\"{ collapsed: !expandArray[7] }\"\r\n class=\"wizard-expanded config\"\r\n >\r\n <div style=\"padding-left: 18px\">\r\n <div style=\"margin-bottom: 10px\" class=\"twelvepx\">\r\n {{ translation.COLORS || \".COLORS\" }}\r\n </div>\r\n\r\n <ejs-dropdownlist\r\n style=\"margin-bottom: 10px\"\r\n id=\"employees\"\r\n [dataSource]=\"themeData\"\r\n [allowFiltering]=\"true\"\r\n [filterType]=\"'Contains'\"\r\n [itemTemplate]=\"itemTemplate\"\r\n [valueTemplate]=\"valueTemplate\"\r\n [fields]=\"themeFields\"\r\n [value]=\"selectTheme\"\r\n (change)=\"changeTheme($event, 'theme')\"\r\n class=\"color-ipt\"\r\n >\r\n <ng-template #itemTemplate let-data>\r\n <div class=\"color-box\">\r\n <div\r\n *ngFor=\"let i of data.value\"\r\n class=\"color-item\"\r\n [ngStyle]=\"{\r\n 'background-color': i\r\n }\"\r\n ></div>\r\n </div>\r\n </ng-template>\r\n <ng-template #valueTemplate let-data>\r\n <div class=\"color-box\">\r\n <div\r\n *ngFor=\"let item of data.value\"\r\n class=\"color-item\"\r\n [ngStyle]=\"{\r\n 'background-color': item\r\n }\"\r\n ></div>\r\n </div>\r\n </ng-template>\r\n </ejs-dropdownlist>\r\n\r\n <div style=\"margin-bottom: 10px\" class=\"twelvepx\">\r\n {{ translation.FREQUENCY || \".FREQUENCY\" }}\r\n </div>\r\n\r\n <!-- Frequency: Yearly/Quarterly(default)/Monthly -->\r\n <mat-select\r\n [(value)]=\"selectedMultiples\"\r\n (openedChange)=\"setHistoricalIRRChart($event)\"\r\n class=\"datamart-select\"\r\n >\r\n <mat-option\r\n *ngFor=\"let i of frequencyOptions\"\r\n [value]=\"i.langCode\"\r\n >\r\n {{ (i.addtionName || \"\") + translation[i.langCode] }}\r\n </mat-option>\r\n </mat-select>\r\n\r\n <!-- Fund cashflow IRR ( fund ops settlement) \u53EF\u9009\u62E9 -->\r\n <ng-container\r\n *ngIf=\"\r\n ['FundHistoricalCashflowIRR'].includes(selectedDatamart)\r\n \"\r\n >\r\n <div style=\"margin-bottom: 10px\" class=\"twelvepx\">\r\n Investors\r\n </div>\r\n <!-- Investors: All/exclude GP&SLP -->\r\n <mat-select\r\n [(value)]=\"selectedInvestor\"\r\n (openedChange)=\"setHistoricalIRRChart($event)\"\r\n class=\"datamart-select\"\r\n >\r\n <mat-option\r\n *ngFor=\"let item of investorList\"\r\n [value]=\"item.code\"\r\n >\r\n {{ item.text }}\r\n </mat-option>\r\n </mat-select>\r\n </ng-container>\r\n\r\n <!-- line \u548C bar \u56FE x \u8F74\u4E3A date\uFF0Cy \u8F74\u4E3A IRR \u767E\u5206\u6570 -->\r\n <div style=\"margin-bottom: 10px\" class=\"twelvepx\">\r\n {{ translation.VISUAL_TYPE || \".VISUAL_TYPE\" }}\r\n </div>\r\n <!-- Visual Type: Line(default)/Column Chart/Table -->\r\n <mat-select\r\n [(value)]=\"selectedVisualType\"\r\n (openedChange)=\"setHistoricalIRRChart($event)\"\r\n class=\"datamart-select\"\r\n >\r\n <mat-option\r\n *ngFor=\"let item of visualTypeList\"\r\n [value]=\"item.code\"\r\n >\r\n {{ item.text }}\r\n </mat-option>\r\n </mat-select>\r\n <div\r\n class=\"data-label-content\"\r\n *ngIf=\"selectedVisualType !== 'table'\"\r\n >\r\n <div class=\"label\">\r\n {{ translation.DATA_LABEL || \".Data labels\" }}\r\n </div>\r\n <ejs-switch\r\n [checked]=\"true\"\r\n [(ngModel)]=\"hasMarker\"\r\n (ngModelChange)=\"labelConfigChange($event)\"\r\n ></ejs-switch>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-container>\r\n\r\n <div class=\"wizard\" (click)=\"nextWizard(3)\">\r\n <span class=\"wizard-name\"\r\n >{{\r\n translation.GENERAL_OPTIONS\r\n ? translation.GENERAL_OPTIONS\r\n : \".GENERAL_OPTIONS\"\r\n }}*</span\r\n >\r\n <mat-icon class=\"wizard-icon\">{{\r\n !expandArray[3] ? \"expand_more\" : \"expand_less\"\r\n }}</mat-icon>\r\n </div>\r\n <div\r\n class=\"dialog-content\"\r\n [ngClass]=\"{ collapsed: !expandArray[3] }\"\r\n *ngIf=\"portletType !== 'newchart'\"\r\n >\r\n <div class=\"condition-item\">\r\n <div class=\"title\">\r\n {{ translation.GADGET_TITLE || \".GADGET_TITLE\" }}\r\n </div>\r\n <input\r\n matInput\r\n #message\r\n maxlength=\"256\"\r\n (ngModelChange)=\"gadgetTitleChange($event)\"\r\n [(ngModel)]=\"config.gadgetTitle\"\r\n autocomplete=\"off\"\r\n />\r\n </div>\r\n </div>\r\n <div\r\n class=\"dialog-content\"\r\n [ngClass]=\"{ collapsed: !expandArray[3] }\"\r\n *ngIf=\"portletType === 'newchart'\"\r\n >\r\n <div class=\"condition-item\">\r\n <div class=\"title\">\r\n {{ translation.GADGET_TITLE || \".GADGET_TITLE\" }}\r\n </div>\r\n <input\r\n matInput\r\n #message\r\n maxlength=\"256\"\r\n (ngModelChange)=\"gadgetTitleChange($event)\"\r\n [(ngModel)]=\"config.gadgetTitle\"\r\n autocomplete=\"off\"\r\n />\r\n </div>\r\n <div class=\"condition-item\">\r\n <div class=\"title\">\r\n {{ translation.CHARTTYPE || \".CHARTTYPE\" }}\r\n </div>\r\n <mat-select\r\n [placeholder]=\"translation.SELECT_A_TYPE || 'Select a type'\"\r\n [(ngModel)]=\"chartSettings.chartSeries.type\"\r\n (selectionChange)=\"setChartType()\"\r\n >\r\n <mat-option *ngFor=\"let item of chartTypeList\" [value]=\"item\">\r\n {{ translation[\"chart_\" + item] || item }}\r\n </mat-option>\r\n </mat-select>\r\n </div>\r\n <div class=\"condition-item flex\">\r\n <ejs-checkbox\r\n [label]=\"translation.MULTIPLE_AXIS || '.MULTIPLE_AXIS'\"\r\n [(ngModel)]=\"chartSettings.enableMultipleAxis\"\r\n (change)=\"setMultipleAxis($event)\"\r\n ></ejs-checkbox>\r\n <ejs-checkbox\r\n [disabled]=\"!chartSettings.enableMultipleAxis\"\r\n [label]=\"translation.SHOW_LEGEND || '.SHOW_LEGEND'\"\r\n (change)=\"setMultipleAxis($event)\"\r\n [(ngModel)]=\"chartSettings.legendSettings.visible\"\r\n ></ejs-checkbox>\r\n </div>\r\n <div class=\"condition-item\">\r\n <div class=\"title\">\r\n {{ translation.MULTIPLE_AXIS_MODE || \".MULTIPLE_AXIS_MODE\" }}\r\n </div>\r\n <mat-select\r\n [placeholder]=\"translation.SELECT_A_MODE || '.SELECT_A_MODE'\"\r\n (selectionChange)=\"setMultipleAxis($event.value)\"\r\n [(ngModel)]=\"chartSettings.multipleAxisMode\"\r\n [disabled]=\"!chartSettings.enableMultipleAxis\"\r\n >\r\n <mat-option\r\n *ngFor=\"let item of multipleAxisModeList\"\r\n [value]=\"item\"\r\n >\r\n {{ translation[\"chart_\" + item] || item }}\r\n </mat-option>\r\n </mat-select>\r\n </div>\r\n <div class=\"condition-item\">\r\n <div class=\"title\">\r\n {{ translation.COLORS || \".COLORS\" }}\r\n </div>\r\n\r\n <ejs-dropdownlist\r\n id=\"employees\"\r\n [dataSource]=\"themeData\"\r\n [allowFiltering]=\"true\"\r\n [filterType]=\"'Contains'\"\r\n [itemTemplate]=\"itemTemplate\"\r\n [valueTemplate]=\"valueTemplate\"\r\n [fields]=\"themeFields\"\r\n [value]=\"selectTheme\"\r\n (change)=\"getThemeData($event)\"\r\n class=\"color-ipt\"\r\n >\r\n <ng-template #itemTemplate let-data>\r\n <div class=\"color-box\">\r\n <div\r\n *ngFor=\"let i of data.value\"\r\n class=\"color-item\"\r\n [ngStyle]=\"{\r\n 'background-color': i\r\n }\"\r\n ></div>\r\n </div>\r\n </ng-template>\r\n <ng-template #valueTemplate let-data>\r\n <div class=\"color-box\">\r\n <div\r\n *ngFor=\"let item of data.value\"\r\n class=\"color-item\"\r\n [ngStyle]=\"{\r\n 'background-color': item\r\n }\"\r\n ></div>\r\n </div>\r\n </ng-template>\r\n </ejs-dropdownlist>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <!-- </form> -->\r\n <div class=\"footer-btn\">\r\n <button type=\"button\" mat-flat-button class=\"btn-close\" (click)=\"clear()\">\r\n {{ translation.CLEAR ? translation.CLEAR : \"Clear\" }}\r\n </button>\r\n <button type=\"button\" mat-flat-button class=\"btn-save\" (click)=\"close()\">\r\n {{ translation.CLOSE ? translation.CLOSE : \".CLOSE\" }}\r\n </button>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: ["@charset \"UTF-8\";.sidebar-iconlist{display:flex;flex-direction:column;height:100%}.sidebar-iconlist .nav-tabs{width:100%;display:flex;justify-content:center}.sidebar-iconlist .nav-tabs .nav-item{width:40%;padding:15px 10px 0}.sidebar-iconlist .nav-tabs .nav-item .nav-link{padding:12px 0;display:flex;justify-content:center}.sidebar-iconlist .nav-tabs .nav-item .tab-name{font-size:13px;font-weight:700;color:#48465a}.sidebar-iconlist .sidebar-iconlist-content{background-color:#fff;flex:1;height:0}.nav-tabs .nav-link:hover,.nav-tabs .nav-link.active{border-bottom:2px solid #5d78ff}.tab-content{padding:0 25px}.wizard{position:relative;width:100%;height:40px;background-color:#f7f9fb;padding:12px;margin-bottom:10px;cursor:pointer}.wizard .wizard-name{font-size:16px;color:#6c7293;font-weight:600}.wizard .wizard-icon{position:absolute;right:0}.wizard.slide-out{transform:translate(100%);transition:transform .5s}.wizard.slide-out.slide-in{transform:translate(0);transition:transform .5s}.wizard.chart{margin-top:-50px}.edit-dashboard-container{height:250px;transition:height .5s;overflow-y:hidden}.edit-dashboard-container.collapsed{height:0;transition:height .5s}.wizard-expanded{background-color:#fff;font-size:15px;overflow-y:auto}.wizard-expanded::-webkit-scrollbar{display:none}.wizard-expanded.datasource{height:500px;transition:height .5s}.wizard-expanded.datasource.extended{height:225px;transition:height .5s}.wizard-expanded.datasource.collapsed{height:0;transition:height .5s}.wizard-expanded.portlets{height:370px;transition:height .5s}.wizard-expanded.portlets.collapsed{height:0;transition:height .5s}.wizard-expanded.general{height:100px;transition:height .5s}.wizard-expanded.general.collapsed{height:0;transition:height .5s}.wizard-expanded.config{height:436px;transition:height .5s}.wizard-expanded.config.collapsed{height:0;transition:height .5s}.wizard-expanded.fields{height:300px;overflow-y:scroll;display:flex;flex-direction:column;transition:height .5s;transform:translate(0);padding-bottom:50px}.wizard-expanded.fields.collapsed{height:0;transition:height .5s;transform:translate(16px)}.wizard-expanded.fields.extended{height:400px;transition:height .5s}.wizard-expanded.series{height:auto;display:flex;flex-direction:column;transition:height .5s}.wizard-expanded.series.collapsed{height:0;transition:height .5s}.wizard-expanded.series .series-card{border:.33px solid #6c7293;margin-top:5px;margin-bottom:5px;width:98%}.wizard-expanded.series .series-card .select{height:40px;background-color:#eff1fe80;padding-left:10px;padding-top:10px;margin-top:5px;margin-bottom:5px}.wizard-expanded.xaxis{height:auto;transition:height .5s}.wizard-expanded.xaxis.collapsed{height:0;transition:height .5s}.wizard-expanded.xaxis .select{height:40px;background-color:#eff1fe80;padding-left:10px;padding-top:10px;margin-top:5px;margin-bottom:5px}.wizard-expanded.yaxis{height:auto;transition:height .5s}.wizard-expanded.yaxis.collapsed{height:0;transition:height .5s}.wizard-expanded.yaxis .select{height:40px;background-color:#eff1fe80;padding-left:10px;padding-top:10px;margin-top:5px;margin-bottom:5px}.wizard-expanded .datamart-type-btn{border-radius:20px;height:40px;border:solid 2px #606ede;background-color:#fff;color:#606ede;margin-right:10px;padding-left:10px;padding-right:10px;margin-bottom:10px}.wizard-expanded .datamart-type-btn.selected{color:#fff;background-color:#606ede}.wizard-expanded .datamart-select{height:40px;background-color:#eff1fe80;width:95%;padding-left:10px;padding-top:10px;margin-bottom:10px}.wizard-expanded .twelvepx{font-size:12px}.footer-btn{margin-top:-20px;margin-bottom:20px;z-index:998;background:#fff;padding-top:15px;position:absolute;bottom:30px}.btn-save{width:150px;height:40px;border-radius:5px;color:#5d78ff;background-color:#eff1fe;border-style:none;font-size:15px;font-weight:700;font-family:Arial;margin-left:13px}.btn-save:hover{color:#fff;background:#606ede}.btn-close{width:150px;height:40px;border-radius:5px;background-color:#f2f3f7;border-style:none;font-size:15px;font-weight:700;font-family:Arial;color:#979cb4;margin-left:44px}.scroll-body::-webkit-scrollbar{display:none}::ng-deep kt-sidebar-iconlist .fields-title{margin-bottom:0!important;background:#f7f8fa!important;padding-left:0!important}::ng-deep kt-sidebar-iconlist .fields-data{background:#f7f8fa!important}::ng-deep kt-sidebar-iconlist .fields-data .mat-checkbox-frame{background:#fff!important;border:solid 1px #d6d6d6!important}::ng-deep kt-sidebar-iconlist .fields-data .mat-checkbox-inner-container{margin-right:10px!important}.cdk-drag-preview{box-sizing:border-box;border-radius:4px;box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f}.cdk-drag-placeholder{opacity:0}.cdk-drag-animating{transition:transform .25s cubic-bezier(0,0,.2,1)}.add-pdding{padding:0 16px}.data-source{background:#fff}.wizard-expanded.datasource{background:#f7f8fa}button.btn.prompt-btn{display:inline-block;width:20px!important;height:22px;margin-top:-6px;margin-left:3px}.prompt-btn{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABQAAAAUCAYAAACNiR0NAAABYWlDQ1BrQ0dDb2xvclNwYWNlRGlzcGxheVAzAAAokWNgYFJJLCjIYWFgYMjNKykKcndSiIiMUmB/yMAOhLwMYgwKicnFBY4BAT5AJQwwGhV8u8bACKIv64LMOiU1tUm1XsDXYqbw1YuvRJsw1aMArpTU4mQg/QeIU5MLikoYGBhTgGzl8pICELsDyBYpAjoKyJ4DYqdD2BtA7CQI+whYTUiQM5B9A8hWSM5IBJrB+API1klCEk9HYkPtBQFul8zigpzESoUAYwKuJQOUpFaUgGjn/ILKosz0jBIFR2AopSp45iXr6SgYGRiaMzCAwhyi+nMgOCwZxc4gxJrvMzDY7v////9uhJjXfgaGjUCdXDsRYhoWDAyC3AwMJ3YWJBYlgoWYgZgpLY2B4dNyBgbeSAYG4QtAPdHFacZGYHlGHicGBtZ7//9/VmNgYJ/MwPB3wv//vxf9//93MVDzHQaGA3kAFSFl7jXH0fsAAAA4ZVhJZk1NACoAAAAIAAGHaQAEAAAAAQAAABoAAAAAAAKgAgAEAAAAAQAAABSgAwAEAAAAAQAAABQAAAAAkRXSxwAAAdNJREFUOBGtVT1LA0EQfbsoCh62SkCL2FhYpsqfSLQRBAs/0M7KYJWASSWxsrMQG2MZtbaOlaWFFqZRQrQRJIWiZH2zl+OSyyZEuIHJzc6+eTt3szNRcMmpGUcTWSiqQYqQRAfWoO+evmvMUnfVTzRcRR0omRW0UaY/SW2R4I4ELxanMEc7Tduj1qGRQ15V7V7nJyQ0RqOEIwbsk+SZ4DymUcWe+u4OwImZwCfk0BKxC8QeE3kApdqCCwmLptwhu2QeW9hQXz1E0cW5mWTeZ4xZs6QFlQsh8pqHxlAvQueIVtFUbKxwUBT8AjzSMsxsyZlZ0dwS20RBrfcd42f6wGjFQi1qvGGZoKT9ZoNfs0nMex+ZOCRGvrdw8GaM0chQW7YANJziYQdT+HXuiVOK92FvRFYz1RSTrfVVszu6hSe+Sa3b1WPLTfCvV0pzI0HS1x5AdCFfV3SY+Hc1IYSxihBKOw0/fZQjfY6GJpn0Ztp2wCiBLox0j3CQSzK8oXq2nVxg3ycVHlxlaUXh4NDQmMEVF3Xbm3JJXaKxSvemawsSI30tHDKBrMTaesGxwXAAKpjHtrMFA6w8BwyHcNrEPr6C02MbsAGhPGUC+UMjw8r96y/gDxmsxDtcS0RvAAAAAElFTkSuQmCC);background-position:0 0;background-size:20px;background-repeat:no-repeat}.prompt-btn ngb-tooltip-window .tooltip{width:189px!important;height:58px!important;border-radius:2px!important;box-shadow:0 8px 16px #a9c2d140!important;background-color:#a9c2d140!important;font-family:Arial!important;font-size:13px!important;color:#fff!important}.content-title{font-size:10px;font-weight:400;color:#a2a3b5}.icon-list mat-icon.mat-icon{width:30px;height:30px;line-height:30px;background:#eff1fe;margin-right:12px;color:#44566c;text-align:center;border-radius:5px;cursor:pointer;margin-top:6px}.icon-list mat-icon.mat-icon.selected{color:#fff;background-color:#606ede}.data-label-content{margin-top:8px;display:flex;align-items:center}.data-label-content .label{margin-right:8px}input.field-name{border-bottom:1px #eaedf0 solid}.display-total{color:#fdbf5e}.scroll-body{padding-bottom:1vh}::ng-deep kt-sidebar-iconlist input,::ng-deep kt-sidebar-iconlist mat-select{color:#4a4a4a!important}::ng-deep kt-sidebar-iconlist span.mat-slide-toggle-content{font-family:Arial!important;font-size:15px!important;font-weight:700!important;color:#4a4a4a!important}::ng-deep kt-sidebar-iconlist .mat-form-field-flex{border-bottom:1px #e9edef solid;border-radius:0!important}.footer-btn{margin:0}.state-selector{width:360px;height:36px;border:2px #5867dd solid;border-radius:5px;display:inline-block;margin-left:15px;margin-bottom:20px}.state-selector .state{display:inline-block;width:33.3%;padding-top:1px;text-align:center;background-color:#fff;height:32px;line-height:32px;font-size:15px;cursor:pointer;color:#606ede}.state-selector .state.investment{border-left:solid 2px #5867dd;border-right:solid 2px #5867dd}.state-selector .state.selected{background-color:#5867dd;color:#fff}:host ::ng-deep .kt-margin-bottom-10-mobile{height:40px;margin-bottom:20px}:host ::ng-deep .kt-margin-bottom-10-mobile .mat-form-field-flex{height:40px;background:#f8fafb;border:none!important}:host ::ng-deep .field-icon-filter .filter .kt-margin-bottom-10-mobile .mat-form-field-flex{height:40px;background:#f8fafb;border:none!important}:host ::ng-deep .box{position:absolute;top:364px;background:#fff;width:100%;z-index:999;height:auto}:host ::ng-deep .box .mat-checkbox-inner-container{background:#f8fafb}:host ::ng-deep .box .box-header{position:relative;height:40px;width:100%;border-radius:5px;background-color:#eff1fe80}:host ::ng-deep .box .box-header .title-icon{position:absolute;top:10px;left:10px}:host ::ng-deep .box .box-header .close-icon{position:absolute;top:10px;right:10px}:host ::ng-deep .box .box-header .title{position:absolute;top:0;padding-left:42px;width:100%;font-family:Arial}:host ::ng-deep .box .box-header .close{position:absolute;top:10px;right:10px}:host ::ng-deep .box .box-content{display:flex;flex-direction:column;padding:10px;max-height:210px;overflow:auto!important}:host ::ng-deep .box .buttons{font-family:Arial;display:flex;width:100%;justify-content:center;margin-bottom:10px;margin-top:15px}:host ::ng-deep .box .buttons .noki-btn{width:110px;border-radius:6px;color:#5d78ff;background-color:#eff1fe;box-shadow:none;border:none;font-size:1.25rem;font-weight:400;margin-left:15px;margin-right:15px;height:40px;line-height:40px}:host ::ng-deep .box .buttons .noki-btn:hover{color:#fff;background-color:#5d78ff}.format .box-content{max-height:150px}:host::ng-deep .datamart-select .mat-select-value-text{font-size:15px!important;font-weight:400!important;color:#44566c!important}.fields-row{height:40px!important;line-height:40px;position:relative}.fields-row mat-checkbox.fields-{display:inline-block}.fields-row .field-icon-filter,.fields-row .field-icon-format{cursor:pointer;margin:0 6px}.fields-row .field-icon-filter mat-icon,.fields-row .field-icon-format mat-icon{transform:translateY(2px)!important}.fields-row .field-icon-filter .box,.fields-row .field-icon-format .box{position:absolute;top:40px;z-index:99;border:solid 1px #eaedf0;border-radius:5px;height:auto;width:367px;cursor:default;background-color:#fff}.fields-row .field-icon-filter .box .mat-checkbox-inner-container,.fields-row .field-icon-format .box .mat-checkbox-inner-container{cursor:pointer}.fields-row .field-icon-filter .box .box-header,.fields-row .field-icon-format .box .box-header{position:relative;height:40px;width:100%;border-radius:5px;background-color:#eff1fe80}.fields-row .field-icon-filter .box .box-header .title-icon,.fields-row .field-icon-format .box .box-header .title-icon{position:absolute;top:10px;left:10px}.fields-row .field-icon-filter .box .box-header .close-icon,.fields-row .field-icon-format .box .box-header .close-icon{position:absolute;top:10px;right:10px}.fields-row .field-icon-filter .box .box-header .title,.fields-row .field-icon-format .box .box-header .title{position:absolute;top:0;padding-left:42px;width:100%;font-family:Arial}.fields-row .field-icon-filter .box .box-header .close,.fields-row .field-icon-format .box .box-header .close{position:absolute;top:10px;right:10px}.fields-row .field-icon-filter .box .box-content,.fields-row .field-icon-format .box .box-content{display:flex;flex-direction:column;padding:10px;overflow-y:hidden}.fields-row .field-icon-filter .box{transform:translate(-302px)}.fields-row .field-icon-format .box{transform:translate(-338px)}.fields-row .field-icon-total{width:36px;text-align:center;font-weight:500;cursor:pointer;margin:0 5px}:host::ng-deep .fields-row mat-checkbox.fields- label.mat-checkbox-layout{width:100%}:host::ng-deep .fields-row mat-checkbox.fields- span.mat-checkbox-label{width:calc(100% - 26px);overflow:hidden;white-space:nowrap;text-overflow:ellipsis}:host::ng-deep .fields-row .box-content label.mat-checkbox-layout{width:100%}:host::ng-deep .fields-row .box-content span.mat-checkbox-label{width:calc(100% - 26px);overflow:hidden;white-space:nowrap;text-overflow:ellipsis}:host::ng-deep .search-select-all{position:absolute;background:#fff;top:40px;z-index:9;width:calc(100% - 10px)}:host::ng-deep .search-select-all .search- .mat-form-field-flex{display:inline-flex;align-items:baseline;box-sizing:border-box;width:calc(100% - 10px);border:1px solid #e9edef;border-radius:5px!important}.tab-content{padding:0!important}ul.nav.nav-tabs.nav-tabs-line{width:100%;padding-right:0;margin-bottom:25px}ul.nav.nav-tabs.nav-tabs-line li{width:40%;padding:15px 10px 0}ul.nav.nav-tabs.nav-tabs-line li .tab-name{display:inline-block;font-size:13px;font-weight:700;color:#48465a}.color-ipt{width:95%}.color-ipt .e-list-item{background-color:#fff!important}.color-ipt .e-input-group{background-color:#eff1fe80!important}::ng-deep .e-dropdownlist .e-list-item.e-active{background:red!important}.color-box{width:100%;display:flex;height:40px;align-items:center;justify-content:center}.color-box .color-item{width:10%;height:16px}.dialog-content{padding:16px 24px}.dialog-content .condition-item{margin-bottom:18px}.dialog-content .condition-item.flex{display:flex}.dialog-content .condition-item.flex .e-checkbox-wrapper{flex:1;height:20px}.dialog-content .condition-item.flex .e-checkbox-wrapper .e-icons{height:18px;width:18px}.dialog-content .condition-item.flex .e-checkbox-wrapper .e-icons:before{font-size:12px}.dialog-content .condition-item .title{margin-bottom:6px;font-size:13px;color:#646c9a}.dialog-content .condition-item .mat-select,.dialog-content .condition-item .mat-input-element{border-bottom:1px solid rgba(0,0,0,.42);height:30px;line-height:30px;width:100%}.dialog-content .condition-item .mat-select.mat-select-disabled,.dialog-content .condition-item .mat-input-element.mat-select-disabled{opacity:.3}::ng-deep .cdk-overlay-pane{transform:translate(-16px)!important}::ng-deep .cdk-overlay-pane .mat-select-panel-wrap{max-width:380px!important}::ng-deep .cdk-overlay-pane .mat-select-panel-wrap .mat-select-panel{min-width:calc(100% + 32px)!important}\n"], dependencies: [{ kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i7.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex", "panelWidth", "hideSingleSelectionIndicator"], exportAs: ["matSelect"] }, { kind: "component", type: i8.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "directive", type: i9.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i10.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i11.SwitchComponent, selector: "ejs-switch", inputs: ["checked", "cssClass", "disabled", "enablePersistence", "enableRtl", "htmlAttributes", "locale", "name", "offLabel", "onLabel", "value"], outputs: ["focus", "blur", "change", "created", "checkedChange"] }, { kind: "component", type: i11.CheckBoxComponent, selector: "ejs-checkbox", inputs: ["checked", "cssClass", "disabled", "enableHtmlSanitizer", "enablePersistence", "enableRtl", "htmlAttributes", "indeterminate", "label", "labelPosition", "locale", "name", "value"], outputs: ["focus", "blur", "change", "created", "checkedChange", "indeterminateChange"] }, { kind: "component", type: i12.DropDownListComponent, selector: "ejs-dropdownlist", inputs: ["actionFailureTemplate", "allowFiltering", "allowObjectBinding", "cssClass", "dataSource", "enablePersistence", "enableRtl", "enableVirtualization", "enabled", "fields", "filterBarPlaceholder", "filterType", "floatLabelType", "footerTemplate", "groupTemplate", "headerTemplate", "htmlAttributes", "ignoreAccent", "ignoreCase", "index", "isDeviceFullScreen", "itemTemplate", "locale", "noRecordsTemplate", "placeholder", "popupHeight", "popupWidth", "query", "readonly", "showClearButton", "sortOrder", "text", "value", "valueTemplate", "width", "zIndex"], outputs: ["actionBegin", "actionComplete", "actionFailure", "beforeOpen", "blur", "change", "close", "created", "dataBound", "destroyed", "filtering", "focus", "open", "select", "valueChange"] }, { kind: "component", type: i13.PortletTypeNewComponent, selector: "rs-portlet-type-new", inputs: ["dataMartCode", "portlet", "dashboard"], outputs: ["portletType"] }, { kind: "component", type: i14.FieldFilterComponent, selector: "rs-field-filter", inputs: ["figureCode", "portlet", "dashboard", "portlets"], outputs: ["updatePorletConfig"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
1180
|
+
}
|
|
1181
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SidebarIconlistNewComponent, decorators: [{
|
|
1182
|
+
type: Component,
|
|
1183
|
+
args: [{ selector: "rs-sidebar-iconlist-new", changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"sidebar-iconlist\" *ngIf=\"config\">\r\n <ul class=\"nav-tabs\">\r\n <li class=\"nav-item\">\r\n <a\r\n class=\"nav-link\"\r\n [ngClass]=\"{ active: currentTab === 'tab1' }\"\r\n data-toggle=\"tab\"\r\n (click)=\"switchTab('tab1')\"\r\n >\r\n <img\r\n style=\"margin-right: 8px\"\r\n src=\"../../../assets/img/dashboard_icon/basic-icon-filter.svg\"\r\n />\r\n <div class=\"tab-name\">\r\n {{ translation.FILTER ? translation.FILTER : \".FILTER\" }}\r\n </div>\r\n </a>\r\n </li>\r\n <li class=\"nav-item\">\r\n <a\r\n class=\"nav-link\"\r\n [ngClass]=\"{ active: currentTab === 'tab2' }\"\r\n data-toggle=\"tab\"\r\n (click)=\"switchTab('tab2')\"\r\n >\r\n <img\r\n style=\"margin-right: 8px\"\r\n src=\"../../../assets/img/dashboard_icon/dashboard-icon.svg\"\r\n />\r\n <div class=\"tab-name\">\r\n {{ translation.PROPERTIES ? translation.PROPERTIES : \".PROPERTIES\" }}\r\n </div>\r\n </a>\r\n </li>\r\n </ul>\r\n <div class=\"sidebar-iconlist-content\">\r\n <!-- <form action=\"\" method=\"\"> -->\r\n <div\r\n class=\"tab-content\"\r\n style=\"height: calc(100% - 140px); overflow-y: scroll\"\r\n >\r\n <div class=\"tab-pane\" *ngIf=\"currentTab === 'tab1'\" style=\"height: 100%\">\r\n <rs-field-filter\r\n [portlet]=\"portlet\"\r\n [dashboard]=\"dashboard\"\r\n [portlets]=\"portlets\"\r\n (updatePorletConfig)=\"_updatePorletConfig($event)\"\r\n ></rs-field-filter>\r\n </div>\r\n <div class=\"tab-pane\" *ngIf=\"currentTab === 'tab2'\">\r\n <div>\r\n <div (click)=\"nextWizard(0)\" class=\"wizard\">\r\n <span class=\"wizard-name\">\r\n {{\r\n translation.DATA_TABLE ? translation.DATA_TABLE : \"Data Table\"\r\n }}*\r\n </span>\r\n <mat-icon style=\"position: absolute; right: 0\">\r\n {{ !expandArray[0] ? \"expand_more\" : \"expand_less\" }}\r\n </mat-icon>\r\n </div>\r\n <div\r\n [ngStyle]=\"{ height: expandArray[0] ? '100px' : '0' }\"\r\n [ngClass]=\"{ collapsed: !expandArray[0] }\"\r\n class=\"wizard-expanded\"\r\n >\r\n <div class=\"data-source add-pdding\">\r\n <div style=\"margin-bottom: 10px\" class=\"twelvepx\">\r\n {{\r\n translation.FIRST_CHOOSE_THE_DATA_TABLE_TO_CUSTOMIZE_YOUR_DASHBOARD\r\n ? translation.FIRST_CHOOSE_THE_DATA_TABLE_TO_CUSTOMIZE_YOUR_DASHBOARD\r\n : \"Firstly, choose the data table to customize your dashboard\"\r\n }}\r\n </div>\r\n <div class=\"twelvepx\">\r\n <mat-select\r\n class=\"datamart-select\"\r\n [(ngModel)]=\"selectedDatamart\"\r\n (selectionChange)=\"changeDataTable($event.value)\"\r\n >\r\n <ng-container *ngFor=\"let datatable of dataMartTableList\">\r\n <!-- *ngIf=\"!datatable.isHide\" -->\r\n <mat-option [value]=\"datatable.datamartCode\">\r\n {{\r\n translation[datatable.langCode] || datatable.langCode\r\n }}\r\n </mat-option>\r\n </ng-container>\r\n </mat-select>\r\n </div>\r\n </div>\r\n </div>\r\n <div *ngIf=\"getFigurecode()\" (click)=\"nextWizard(2)\" class=\"wizard\">\r\n <span class=\"wizard-name\"\r\n >{{\r\n translation.PORTLET_TYPE\r\n ? translation.PORTLET_TYPE\r\n : \".PORTLET_TYPE\"\r\n }}*</span\r\n >\r\n <mat-icon class=\"wizard-icon\">{{\r\n !expandArray[2] ? \"expand_more\" : \"expand_less\"\r\n }}</mat-icon>\r\n </div>\r\n <!-- \u56FE\u8868\u7C7B\u578B\u9009\u62E9 -->\r\n <div\r\n *ngIf=\"getFigurecode()\"\r\n [ngClass]=\"{ collapsed: !expandArray[2] }\"\r\n class=\"wizard-expanded portlets\"\r\n >\r\n <rs-portlet-type-new\r\n [portlet]=\"portlet\"\r\n [dashboard]=\"dashboard\"\r\n [dataMartCode]=\"selectedDatamart\"\r\n (portletType)=\"getPortletType($event)\"\r\n >\r\n </rs-portlet-type-new>\r\n </div>\r\n\r\n <!-- new dashboard \u5E76\u4E14\u9009\u62E9\u56FE\u6807\u7C7B\u578B \u624D\u6709\u7684\u4F9B\u4E09\u4E2A\u56FE\u8868\u9009\u62E9\u7684X\u8F74Y\u8F74 -->\r\n <ng-container\r\n *ngIf=\"\r\n ['newcolumn', 'newline', 'newcolumnline'].includes(portletType)\r\n \"\r\n >\r\n <div class=\"wizard\" (click)=\"nextWizard(7)\">\r\n <span class=\"wizard-name\"\r\n >{{ translation.CONFIGURATIONS || \".CONFIGURATIONS\" }}*</span\r\n >\r\n <mat-icon class=\"wizard-icon\">{{\r\n !expandArray[7] ? \"expand_more\" : \"expand_less\"\r\n }}</mat-icon>\r\n </div>\r\n\r\n <!-- \u56FE\u6807\u914D\u7F6E\u9879 configuration -->\r\n <div\r\n [ngClass]=\"{ collapsed: !expandArray[7] }\"\r\n class=\"wizard-expanded config\"\r\n >\r\n <div style=\"padding-left: 18px\">\r\n <div style=\"margin-bottom: 10px\" class=\"twelvepx\">\r\n {{ translation.COLORS || \".COLORS\" }}\r\n </div>\r\n\r\n <ejs-dropdownlist\r\n style=\"margin-bottom: 10px\"\r\n id=\"employees\"\r\n [dataSource]=\"themeData\"\r\n [allowFiltering]=\"true\"\r\n [filterType]=\"'Contains'\"\r\n [itemTemplate]=\"itemTemplate\"\r\n [valueTemplate]=\"valueTemplate\"\r\n [fields]=\"themeFields\"\r\n [value]=\"selectTheme\"\r\n (change)=\"changeTheme($event, 'theme')\"\r\n class=\"color-ipt\"\r\n >\r\n <ng-template #itemTemplate let-data>\r\n <div class=\"color-box\">\r\n <div\r\n *ngFor=\"let i of data.value\"\r\n class=\"color-item\"\r\n [ngStyle]=\"{\r\n 'background-color': i\r\n }\"\r\n ></div>\r\n </div>\r\n </ng-template>\r\n <ng-template #valueTemplate let-data>\r\n <div class=\"color-box\">\r\n <div\r\n *ngFor=\"let item of data.value\"\r\n class=\"color-item\"\r\n [ngStyle]=\"{\r\n 'background-color': item\r\n }\"\r\n ></div>\r\n </div>\r\n </ng-template>\r\n </ejs-dropdownlist>\r\n\r\n <div style=\"margin-bottom: 10px\" class=\"twelvepx\">\r\n {{ translation.X_AXIS || \".X-AXIS\" }}\r\n </div>\r\n\r\n <mat-select\r\n [(value)]=\"selectedX\"\r\n (openedChange)=\"xyChange($event)\"\r\n class=\"datamart-select\"\r\n >\r\n <ng-container *ngFor=\"let i of yList\">\r\n <mat-option\r\n *ngIf=\"!i.isCalculatedField\"\r\n [value]=\"i.colName\"\r\n >{{\r\n (translation[i.langCode]\r\n ? translation[i.langCode]\r\n : \".\" + i.langCode) +\r\n (i.addtionName ? \" \" + i.addtionName : \"\")\r\n }}</mat-option\r\n >\r\n </ng-container>\r\n </mat-select>\r\n\r\n <ng-container *ngIf=\"selectedX\">\r\n <div style=\"margin-bottom: 10px\" class=\"twelvepx\">\r\n {{ translation.FREQUENCY || \".FREQUENCY\" }}\r\n </div>\r\n\r\n <mat-select\r\n [(value)]=\"selectedMultiples\"\r\n (openedChange)=\"xyChange($event)\"\r\n class=\"datamart-select\"\r\n >\r\n <mat-option\r\n *ngFor=\"let i of multiplesList\"\r\n [value]=\"i.langCode\"\r\n >{{\r\n i.addtionName\r\n ? i.addtionName + \"\" + translation[i.langCode]\r\n : translation[i.langCode]\r\n }}</mat-option\r\n >\r\n </mat-select>\r\n </ng-container>\r\n\r\n <div style=\"margin-bottom: 10px\" class=\"twelvepx\">\r\n {{\r\n portletType === \"newcolumnline\"\r\n ? (translation.COLUMN ? translation.COLUMN + \" \" : \"\") +\r\n (translation.Y_AXIS || \".COLUMN Y-AXIS\")\r\n : translation.Y_AXIS || \".Y-AXIS\"\r\n }}\r\n </div>\r\n\r\n <mat-select\r\n multiple\r\n [(value)]=\"selectedY\"\r\n (openedChange)=\"xyChange($event)\"\r\n class=\"datamart-select\"\r\n >\r\n <ng-container *ngFor=\"let i of yList\">\r\n <mat-option\r\n *ngIf=\"!i.isCalculatedField\"\r\n [value]=\"i.colName\"\r\n >{{\r\n (translation[i.langCode]\r\n ? translation[i.langCode]\r\n : \".\" + i.langCode) +\r\n (i.addtionName ? \" \" + i.addtionName : \"\")\r\n }}</mat-option\r\n >\r\n </ng-container>\r\n </mat-select>\r\n\r\n <div\r\n style=\"margin-bottom: 10px\"\r\n class=\"twelvepx\"\r\n *ngIf=\"portletType == 'newcolumnline'\"\r\n >\r\n {{\r\n (translation.LINE ? translation.LINE + \" \" : \"\") +\r\n (translation.Y_AXIS || \".LINE Y-AXIS\")\r\n }}\r\n </div>\r\n\r\n <mat-select\r\n multiple\r\n class=\"datamart-select\"\r\n [(value)]=\"selectedSecondY\"\r\n (openedChange)=\"xyChange($event)\"\r\n panelClass=\"mat-select-multi-panel\"\r\n *ngIf=\"portletType == 'newcolumnline'\"\r\n >\r\n <ng-container *ngFor=\"let i of yList\">\r\n <mat-option\r\n *ngIf=\"!i.isCalculatedField\"\r\n [value]=\"i.colName\"\r\n >{{\r\n (translation[i.langCode]\r\n ? translation[i.langCode]\r\n : \".\" + i.langCode) +\r\n (i.addtionName ? \" \" + i.addtionName : \"\")\r\n }}</mat-option\r\n >\r\n </ng-container>\r\n </mat-select>\r\n\r\n <div class=\"data-label-content\">\r\n <div class=\"label\">\r\n {{ translation.DATA_LABEL || \".Data labels\" }}\r\n </div>\r\n <ejs-switch\r\n [(ngModel)]=\"hasMarker\"\r\n (ngModelChange)=\"labelConfigChange($event)\"\r\n ></ejs-switch>\r\n </div>\r\n\r\n <div style=\"margin: 10px 0\" class=\"twelvepx\">\r\n {{ translation.DISPLAY_UNITS || \".Display Units\" }}\r\n </div>\r\n\r\n <mat-select\r\n class=\"datamart-select\"\r\n [(ngModel)]=\"markerFormat\"\r\n (ngModelChange)=\"onChangeFormat()\"\r\n >\r\n <ng-container *ngFor=\"let format of markerFormatList\">\r\n <mat-option [value]=\"format.value\">{{\r\n format.label\r\n }}</mat-option>\r\n </ng-container>\r\n </mat-select>\r\n </div>\r\n </div>\r\n </ng-container>\r\n\r\n <!-- historical IRR \u4E13\u7528 -->\r\n <ng-container *ngIf=\"['historicalIRR'].includes(portletType)\">\r\n <div class=\"wizard\" (click)=\"nextWizard(7)\">\r\n <span class=\"wizard-name\"\r\n >{{ translation.CONFIGURATIONS || \"CONFIGURATIONS\" }}*</span\r\n >\r\n <mat-icon class=\"wizard-icon\">{{\r\n !expandArray[7] ? \"expand_more\" : \"expand_less\"\r\n }}</mat-icon>\r\n </div>\r\n\r\n <!-- \u56FE\u6807\u914D\u7F6E\u9879 configuration -->\r\n <div\r\n [ngClass]=\"{ collapsed: !expandArray[7] }\"\r\n class=\"wizard-expanded config\"\r\n >\r\n <div style=\"padding-left: 18px\">\r\n <div style=\"margin-bottom: 10px\" class=\"twelvepx\">\r\n {{ translation.COLORS || \".COLORS\" }}\r\n </div>\r\n\r\n <ejs-dropdownlist\r\n style=\"margin-bottom: 10px\"\r\n id=\"employees\"\r\n [dataSource]=\"themeData\"\r\n [allowFiltering]=\"true\"\r\n [filterType]=\"'Contains'\"\r\n [itemTemplate]=\"itemTemplate\"\r\n [valueTemplate]=\"valueTemplate\"\r\n [fields]=\"themeFields\"\r\n [value]=\"selectTheme\"\r\n (change)=\"changeTheme($event, 'theme')\"\r\n class=\"color-ipt\"\r\n >\r\n <ng-template #itemTemplate let-data>\r\n <div class=\"color-box\">\r\n <div\r\n *ngFor=\"let i of data.value\"\r\n class=\"color-item\"\r\n [ngStyle]=\"{\r\n 'background-color': i\r\n }\"\r\n ></div>\r\n </div>\r\n </ng-template>\r\n <ng-template #valueTemplate let-data>\r\n <div class=\"color-box\">\r\n <div\r\n *ngFor=\"let item of data.value\"\r\n class=\"color-item\"\r\n [ngStyle]=\"{\r\n 'background-color': item\r\n }\"\r\n ></div>\r\n </div>\r\n </ng-template>\r\n </ejs-dropdownlist>\r\n\r\n <div style=\"margin-bottom: 10px\" class=\"twelvepx\">\r\n {{ translation.FREQUENCY || \".FREQUENCY\" }}\r\n </div>\r\n\r\n <!-- Frequency: Yearly/Quarterly(default)/Monthly -->\r\n <mat-select\r\n [(value)]=\"selectedMultiples\"\r\n (openedChange)=\"setHistoricalIRRChart($event)\"\r\n class=\"datamart-select\"\r\n >\r\n <mat-option\r\n *ngFor=\"let i of frequencyOptions\"\r\n [value]=\"i.langCode\"\r\n >\r\n {{ (i.addtionName || \"\") + translation[i.langCode] }}\r\n </mat-option>\r\n </mat-select>\r\n\r\n <!-- Fund cashflow IRR ( fund ops settlement) \u53EF\u9009\u62E9 -->\r\n <ng-container\r\n *ngIf=\"\r\n ['FundHistoricalCashflowIRR'].includes(selectedDatamart)\r\n \"\r\n >\r\n <div style=\"margin-bottom: 10px\" class=\"twelvepx\">\r\n Investors\r\n </div>\r\n <!-- Investors: All/exclude GP&SLP -->\r\n <mat-select\r\n [(value)]=\"selectedInvestor\"\r\n (openedChange)=\"setHistoricalIRRChart($event)\"\r\n class=\"datamart-select\"\r\n >\r\n <mat-option\r\n *ngFor=\"let item of investorList\"\r\n [value]=\"item.code\"\r\n >\r\n {{ item.text }}\r\n </mat-option>\r\n </mat-select>\r\n </ng-container>\r\n\r\n <!-- line \u548C bar \u56FE x \u8F74\u4E3A date\uFF0Cy \u8F74\u4E3A IRR \u767E\u5206\u6570 -->\r\n <div style=\"margin-bottom: 10px\" class=\"twelvepx\">\r\n {{ translation.VISUAL_TYPE || \".VISUAL_TYPE\" }}\r\n </div>\r\n <!-- Visual Type: Line(default)/Column Chart/Table -->\r\n <mat-select\r\n [(value)]=\"selectedVisualType\"\r\n (openedChange)=\"setHistoricalIRRChart($event)\"\r\n class=\"datamart-select\"\r\n >\r\n <mat-option\r\n *ngFor=\"let item of visualTypeList\"\r\n [value]=\"item.code\"\r\n >\r\n {{ item.text }}\r\n </mat-option>\r\n </mat-select>\r\n <div\r\n class=\"data-label-content\"\r\n *ngIf=\"selectedVisualType !== 'table'\"\r\n >\r\n <div class=\"label\">\r\n {{ translation.DATA_LABEL || \".Data labels\" }}\r\n </div>\r\n <ejs-switch\r\n [checked]=\"true\"\r\n [(ngModel)]=\"hasMarker\"\r\n (ngModelChange)=\"labelConfigChange($event)\"\r\n ></ejs-switch>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-container>\r\n\r\n <div class=\"wizard\" (click)=\"nextWizard(3)\">\r\n <span class=\"wizard-name\"\r\n >{{\r\n translation.GENERAL_OPTIONS\r\n ? translation.GENERAL_OPTIONS\r\n : \".GENERAL_OPTIONS\"\r\n }}*</span\r\n >\r\n <mat-icon class=\"wizard-icon\">{{\r\n !expandArray[3] ? \"expand_more\" : \"expand_less\"\r\n }}</mat-icon>\r\n </div>\r\n <div\r\n class=\"dialog-content\"\r\n [ngClass]=\"{ collapsed: !expandArray[3] }\"\r\n *ngIf=\"portletType !== 'newchart'\"\r\n >\r\n <div class=\"condition-item\">\r\n <div class=\"title\">\r\n {{ translation.GADGET_TITLE || \".GADGET_TITLE\" }}\r\n </div>\r\n <input\r\n matInput\r\n #message\r\n maxlength=\"256\"\r\n (ngModelChange)=\"gadgetTitleChange($event)\"\r\n [(ngModel)]=\"config.gadgetTitle\"\r\n autocomplete=\"off\"\r\n />\r\n </div>\r\n </div>\r\n <div\r\n class=\"dialog-content\"\r\n [ngClass]=\"{ collapsed: !expandArray[3] }\"\r\n *ngIf=\"portletType === 'newchart'\"\r\n >\r\n <div class=\"condition-item\">\r\n <div class=\"title\">\r\n {{ translation.GADGET_TITLE || \".GADGET_TITLE\" }}\r\n </div>\r\n <input\r\n matInput\r\n #message\r\n maxlength=\"256\"\r\n (ngModelChange)=\"gadgetTitleChange($event)\"\r\n [(ngModel)]=\"config.gadgetTitle\"\r\n autocomplete=\"off\"\r\n />\r\n </div>\r\n <div class=\"condition-item\">\r\n <div class=\"title\">\r\n {{ translation.CHARTTYPE || \".CHARTTYPE\" }}\r\n </div>\r\n <mat-select\r\n [placeholder]=\"translation.SELECT_A_TYPE || 'Select a type'\"\r\n [(ngModel)]=\"chartSettings.chartSeries.type\"\r\n (selectionChange)=\"setChartType()\"\r\n >\r\n <mat-option *ngFor=\"let item of chartTypeList\" [value]=\"item\">\r\n {{ translation[\"chart_\" + item] || item }}\r\n </mat-option>\r\n </mat-select>\r\n </div>\r\n <div class=\"condition-item flex\">\r\n <ejs-checkbox\r\n [label]=\"translation.MULTIPLE_AXIS || '.MULTIPLE_AXIS'\"\r\n [(ngModel)]=\"chartSettings.enableMultipleAxis\"\r\n (change)=\"setMultipleAxis($event)\"\r\n ></ejs-checkbox>\r\n <ejs-checkbox\r\n [disabled]=\"!chartSettings.enableMultipleAxis\"\r\n [label]=\"translation.SHOW_LEGEND || '.SHOW_LEGEND'\"\r\n (change)=\"setMultipleAxis($event)\"\r\n [(ngModel)]=\"chartSettings.legendSettings.visible\"\r\n ></ejs-checkbox>\r\n </div>\r\n <div class=\"condition-item\">\r\n <div class=\"title\">\r\n {{ translation.MULTIPLE_AXIS_MODE || \".MULTIPLE_AXIS_MODE\" }}\r\n </div>\r\n <mat-select\r\n [placeholder]=\"translation.SELECT_A_MODE || '.SELECT_A_MODE'\"\r\n (selectionChange)=\"setMultipleAxis($event.value)\"\r\n [(ngModel)]=\"chartSettings.multipleAxisMode\"\r\n [disabled]=\"!chartSettings.enableMultipleAxis\"\r\n >\r\n <mat-option\r\n *ngFor=\"let item of multipleAxisModeList\"\r\n [value]=\"item\"\r\n >\r\n {{ translation[\"chart_\" + item] || item }}\r\n </mat-option>\r\n </mat-select>\r\n </div>\r\n <div class=\"condition-item\">\r\n <div class=\"title\">\r\n {{ translation.COLORS || \".COLORS\" }}\r\n </div>\r\n\r\n <ejs-dropdownlist\r\n id=\"employees\"\r\n [dataSource]=\"themeData\"\r\n [allowFiltering]=\"true\"\r\n [filterType]=\"'Contains'\"\r\n [itemTemplate]=\"itemTemplate\"\r\n [valueTemplate]=\"valueTemplate\"\r\n [fields]=\"themeFields\"\r\n [value]=\"selectTheme\"\r\n (change)=\"getThemeData($event)\"\r\n class=\"color-ipt\"\r\n >\r\n <ng-template #itemTemplate let-data>\r\n <div class=\"color-box\">\r\n <div\r\n *ngFor=\"let i of data.value\"\r\n class=\"color-item\"\r\n [ngStyle]=\"{\r\n 'background-color': i\r\n }\"\r\n ></div>\r\n </div>\r\n </ng-template>\r\n <ng-template #valueTemplate let-data>\r\n <div class=\"color-box\">\r\n <div\r\n *ngFor=\"let item of data.value\"\r\n class=\"color-item\"\r\n [ngStyle]=\"{\r\n 'background-color': item\r\n }\"\r\n ></div>\r\n </div>\r\n </ng-template>\r\n </ejs-dropdownlist>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <!-- </form> -->\r\n <div class=\"footer-btn\">\r\n <button type=\"button\" mat-flat-button class=\"btn-close\" (click)=\"clear()\">\r\n {{ translation.CLEAR ? translation.CLEAR : \"Clear\" }}\r\n </button>\r\n <button type=\"button\" mat-flat-button class=\"btn-save\" (click)=\"close()\">\r\n {{ translation.CLOSE ? translation.CLOSE : \".CLOSE\" }}\r\n </button>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: ["@charset \"UTF-8\";.sidebar-iconlist{display:flex;flex-direction:column;height:100%}.sidebar-iconlist .nav-tabs{width:100%;display:flex;justify-content:center}.sidebar-iconlist .nav-tabs .nav-item{width:40%;padding:15px 10px 0}.sidebar-iconlist .nav-tabs .nav-item .nav-link{padding:12px 0;display:flex;justify-content:center}.sidebar-iconlist .nav-tabs .nav-item .tab-name{font-size:13px;font-weight:700;color:#48465a}.sidebar-iconlist .sidebar-iconlist-content{background-color:#fff;flex:1;height:0}.nav-tabs .nav-link:hover,.nav-tabs .nav-link.active{border-bottom:2px solid #5d78ff}.tab-content{padding:0 25px}.wizard{position:relative;width:100%;height:40px;background-color:#f7f9fb;padding:12px;margin-bottom:10px;cursor:pointer}.wizard .wizard-name{font-size:16px;color:#6c7293;font-weight:600}.wizard .wizard-icon{position:absolute;right:0}.wizard.slide-out{transform:translate(100%);transition:transform .5s}.wizard.slide-out.slide-in{transform:translate(0);transition:transform .5s}.wizard.chart{margin-top:-50px}.edit-dashboard-container{height:250px;transition:height .5s;overflow-y:hidden}.edit-dashboard-container.collapsed{height:0;transition:height .5s}.wizard-expanded{background-color:#fff;font-size:15px;overflow-y:auto}.wizard-expanded::-webkit-scrollbar{display:none}.wizard-expanded.datasource{height:500px;transition:height .5s}.wizard-expanded.datasource.extended{height:225px;transition:height .5s}.wizard-expanded.datasource.collapsed{height:0;transition:height .5s}.wizard-expanded.portlets{height:370px;transition:height .5s}.wizard-expanded.portlets.collapsed{height:0;transition:height .5s}.wizard-expanded.general{height:100px;transition:height .5s}.wizard-expanded.general.collapsed{height:0;transition:height .5s}.wizard-expanded.config{height:436px;transition:height .5s}.wizard-expanded.config.collapsed{height:0;transition:height .5s}.wizard-expanded.fields{height:300px;overflow-y:scroll;display:flex;flex-direction:column;transition:height .5s;transform:translate(0);padding-bottom:50px}.wizard-expanded.fields.collapsed{height:0;transition:height .5s;transform:translate(16px)}.wizard-expanded.fields.extended{height:400px;transition:height .5s}.wizard-expanded.series{height:auto;display:flex;flex-direction:column;transition:height .5s}.wizard-expanded.series.collapsed{height:0;transition:height .5s}.wizard-expanded.series .series-card{border:.33px solid #6c7293;margin-top:5px;margin-bottom:5px;width:98%}.wizard-expanded.series .series-card .select{height:40px;background-color:#eff1fe80;padding-left:10px;padding-top:10px;margin-top:5px;margin-bottom:5px}.wizard-expanded.xaxis{height:auto;transition:height .5s}.wizard-expanded.xaxis.collapsed{height:0;transition:height .5s}.wizard-expanded.xaxis .select{height:40px;background-color:#eff1fe80;padding-left:10px;padding-top:10px;margin-top:5px;margin-bottom:5px}.wizard-expanded.yaxis{height:auto;transition:height .5s}.wizard-expanded.yaxis.collapsed{height:0;transition:height .5s}.wizard-expanded.yaxis .select{height:40px;background-color:#eff1fe80;padding-left:10px;padding-top:10px;margin-top:5px;margin-bottom:5px}.wizard-expanded .datamart-type-btn{border-radius:20px;height:40px;border:solid 2px #606ede;background-color:#fff;color:#606ede;margin-right:10px;padding-left:10px;padding-right:10px;margin-bottom:10px}.wizard-expanded .datamart-type-btn.selected{color:#fff;background-color:#606ede}.wizard-expanded .datamart-select{height:40px;background-color:#eff1fe80;width:95%;padding-left:10px;padding-top:10px;margin-bottom:10px}.wizard-expanded .twelvepx{font-size:12px}.footer-btn{margin-top:-20px;margin-bottom:20px;z-index:998;background:#fff;padding-top:15px;position:absolute;bottom:30px}.btn-save{width:150px;height:40px;border-radius:5px;color:#5d78ff;background-color:#eff1fe;border-style:none;font-size:15px;font-weight:700;font-family:Arial;margin-left:13px}.btn-save:hover{color:#fff;background:#606ede}.btn-close{width:150px;height:40px;border-radius:5px;background-color:#f2f3f7;border-style:none;font-size:15px;font-weight:700;font-family:Arial;color:#979cb4;margin-left:44px}.scroll-body::-webkit-scrollbar{display:none}::ng-deep kt-sidebar-iconlist .fields-title{margin-bottom:0!important;background:#f7f8fa!important;padding-left:0!important}::ng-deep kt-sidebar-iconlist .fields-data{background:#f7f8fa!important}::ng-deep kt-sidebar-iconlist .fields-data .mat-checkbox-frame{background:#fff!important;border:solid 1px #d6d6d6!important}::ng-deep kt-sidebar-iconlist .fields-data .mat-checkbox-inner-container{margin-right:10px!important}.cdk-drag-preview{box-sizing:border-box;border-radius:4px;box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f}.cdk-drag-placeholder{opacity:0}.cdk-drag-animating{transition:transform .25s cubic-bezier(0,0,.2,1)}.add-pdding{padding:0 16px}.data-source{background:#fff}.wizard-expanded.datasource{background:#f7f8fa}button.btn.prompt-btn{display:inline-block;width:20px!important;height:22px;margin-top:-6px;margin-left:3px}.prompt-btn{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABQAAAAUCAYAAACNiR0NAAABYWlDQ1BrQ0dDb2xvclNwYWNlRGlzcGxheVAzAAAokWNgYFJJLCjIYWFgYMjNKykKcndSiIiMUmB/yMAOhLwMYgwKicnFBY4BAT5AJQwwGhV8u8bACKIv64LMOiU1tUm1XsDXYqbw1YuvRJsw1aMArpTU4mQg/QeIU5MLikoYGBhTgGzl8pICELsDyBYpAjoKyJ4DYqdD2BtA7CQI+whYTUiQM5B9A8hWSM5IBJrB+API1klCEk9HYkPtBQFul8zigpzESoUAYwKuJQOUpFaUgGjn/ILKosz0jBIFR2AopSp45iXr6SgYGRiaMzCAwhyi+nMgOCwZxc4gxJrvMzDY7v////9uhJjXfgaGjUCdXDsRYhoWDAyC3AwMJ3YWJBYlgoWYgZgpLY2B4dNyBgbeSAYG4QtAPdHFacZGYHlGHicGBtZ7//9/VmNgYJ/MwPB3wv//vxf9//93MVDzHQaGA3kAFSFl7jXH0fsAAAA4ZVhJZk1NACoAAAAIAAGHaQAEAAAAAQAAABoAAAAAAAKgAgAEAAAAAQAAABSgAwAEAAAAAQAAABQAAAAAkRXSxwAAAdNJREFUOBGtVT1LA0EQfbsoCh62SkCL2FhYpsqfSLQRBAs/0M7KYJWASSWxsrMQG2MZtbaOlaWFFqZRQrQRJIWiZH2zl+OSyyZEuIHJzc6+eTt3szNRcMmpGUcTWSiqQYqQRAfWoO+evmvMUnfVTzRcRR0omRW0UaY/SW2R4I4ELxanMEc7Tduj1qGRQ15V7V7nJyQ0RqOEIwbsk+SZ4DymUcWe+u4OwImZwCfk0BKxC8QeE3kApdqCCwmLptwhu2QeW9hQXz1E0cW5mWTeZ4xZs6QFlQsh8pqHxlAvQueIVtFUbKxwUBT8AjzSMsxsyZlZ0dwS20RBrfcd42f6wGjFQi1qvGGZoKT9ZoNfs0nMex+ZOCRGvrdw8GaM0chQW7YANJziYQdT+HXuiVOK92FvRFYz1RSTrfVVszu6hSe+Sa3b1WPLTfCvV0pzI0HS1x5AdCFfV3SY+Hc1IYSxihBKOw0/fZQjfY6GJpn0Ztp2wCiBLox0j3CQSzK8oXq2nVxg3ycVHlxlaUXh4NDQmMEVF3Xbm3JJXaKxSvemawsSI30tHDKBrMTaesGxwXAAKpjHtrMFA6w8BwyHcNrEPr6C02MbsAGhPGUC+UMjw8r96y/gDxmsxDtcS0RvAAAAAElFTkSuQmCC);background-position:0 0;background-size:20px;background-repeat:no-repeat}.prompt-btn ngb-tooltip-window .tooltip{width:189px!important;height:58px!important;border-radius:2px!important;box-shadow:0 8px 16px #a9c2d140!important;background-color:#a9c2d140!important;font-family:Arial!important;font-size:13px!important;color:#fff!important}.content-title{font-size:10px;font-weight:400;color:#a2a3b5}.icon-list mat-icon.mat-icon{width:30px;height:30px;line-height:30px;background:#eff1fe;margin-right:12px;color:#44566c;text-align:center;border-radius:5px;cursor:pointer;margin-top:6px}.icon-list mat-icon.mat-icon.selected{color:#fff;background-color:#606ede}.data-label-content{margin-top:8px;display:flex;align-items:center}.data-label-content .label{margin-right:8px}input.field-name{border-bottom:1px #eaedf0 solid}.display-total{color:#fdbf5e}.scroll-body{padding-bottom:1vh}::ng-deep kt-sidebar-iconlist input,::ng-deep kt-sidebar-iconlist mat-select{color:#4a4a4a!important}::ng-deep kt-sidebar-iconlist span.mat-slide-toggle-content{font-family:Arial!important;font-size:15px!important;font-weight:700!important;color:#4a4a4a!important}::ng-deep kt-sidebar-iconlist .mat-form-field-flex{border-bottom:1px #e9edef solid;border-radius:0!important}.footer-btn{margin:0}.state-selector{width:360px;height:36px;border:2px #5867dd solid;border-radius:5px;display:inline-block;margin-left:15px;margin-bottom:20px}.state-selector .state{display:inline-block;width:33.3%;padding-top:1px;text-align:center;background-color:#fff;height:32px;line-height:32px;font-size:15px;cursor:pointer;color:#606ede}.state-selector .state.investment{border-left:solid 2px #5867dd;border-right:solid 2px #5867dd}.state-selector .state.selected{background-color:#5867dd;color:#fff}:host ::ng-deep .kt-margin-bottom-10-mobile{height:40px;margin-bottom:20px}:host ::ng-deep .kt-margin-bottom-10-mobile .mat-form-field-flex{height:40px;background:#f8fafb;border:none!important}:host ::ng-deep .field-icon-filter .filter .kt-margin-bottom-10-mobile .mat-form-field-flex{height:40px;background:#f8fafb;border:none!important}:host ::ng-deep .box{position:absolute;top:364px;background:#fff;width:100%;z-index:999;height:auto}:host ::ng-deep .box .mat-checkbox-inner-container{background:#f8fafb}:host ::ng-deep .box .box-header{position:relative;height:40px;width:100%;border-radius:5px;background-color:#eff1fe80}:host ::ng-deep .box .box-header .title-icon{position:absolute;top:10px;left:10px}:host ::ng-deep .box .box-header .close-icon{position:absolute;top:10px;right:10px}:host ::ng-deep .box .box-header .title{position:absolute;top:0;padding-left:42px;width:100%;font-family:Arial}:host ::ng-deep .box .box-header .close{position:absolute;top:10px;right:10px}:host ::ng-deep .box .box-content{display:flex;flex-direction:column;padding:10px;max-height:210px;overflow:auto!important}:host ::ng-deep .box .buttons{font-family:Arial;display:flex;width:100%;justify-content:center;margin-bottom:10px;margin-top:15px}:host ::ng-deep .box .buttons .noki-btn{width:110px;border-radius:6px;color:#5d78ff;background-color:#eff1fe;box-shadow:none;border:none;font-size:1.25rem;font-weight:400;margin-left:15px;margin-right:15px;height:40px;line-height:40px}:host ::ng-deep .box .buttons .noki-btn:hover{color:#fff;background-color:#5d78ff}.format .box-content{max-height:150px}:host::ng-deep .datamart-select .mat-select-value-text{font-size:15px!important;font-weight:400!important;color:#44566c!important}.fields-row{height:40px!important;line-height:40px;position:relative}.fields-row mat-checkbox.fields-{display:inline-block}.fields-row .field-icon-filter,.fields-row .field-icon-format{cursor:pointer;margin:0 6px}.fields-row .field-icon-filter mat-icon,.fields-row .field-icon-format mat-icon{transform:translateY(2px)!important}.fields-row .field-icon-filter .box,.fields-row .field-icon-format .box{position:absolute;top:40px;z-index:99;border:solid 1px #eaedf0;border-radius:5px;height:auto;width:367px;cursor:default;background-color:#fff}.fields-row .field-icon-filter .box .mat-checkbox-inner-container,.fields-row .field-icon-format .box .mat-checkbox-inner-container{cursor:pointer}.fields-row .field-icon-filter .box .box-header,.fields-row .field-icon-format .box .box-header{position:relative;height:40px;width:100%;border-radius:5px;background-color:#eff1fe80}.fields-row .field-icon-filter .box .box-header .title-icon,.fields-row .field-icon-format .box .box-header .title-icon{position:absolute;top:10px;left:10px}.fields-row .field-icon-filter .box .box-header .close-icon,.fields-row .field-icon-format .box .box-header .close-icon{position:absolute;top:10px;right:10px}.fields-row .field-icon-filter .box .box-header .title,.fields-row .field-icon-format .box .box-header .title{position:absolute;top:0;padding-left:42px;width:100%;font-family:Arial}.fields-row .field-icon-filter .box .box-header .close,.fields-row .field-icon-format .box .box-header .close{position:absolute;top:10px;right:10px}.fields-row .field-icon-filter .box .box-content,.fields-row .field-icon-format .box .box-content{display:flex;flex-direction:column;padding:10px;overflow-y:hidden}.fields-row .field-icon-filter .box{transform:translate(-302px)}.fields-row .field-icon-format .box{transform:translate(-338px)}.fields-row .field-icon-total{width:36px;text-align:center;font-weight:500;cursor:pointer;margin:0 5px}:host::ng-deep .fields-row mat-checkbox.fields- label.mat-checkbox-layout{width:100%}:host::ng-deep .fields-row mat-checkbox.fields- span.mat-checkbox-label{width:calc(100% - 26px);overflow:hidden;white-space:nowrap;text-overflow:ellipsis}:host::ng-deep .fields-row .box-content label.mat-checkbox-layout{width:100%}:host::ng-deep .fields-row .box-content span.mat-checkbox-label{width:calc(100% - 26px);overflow:hidden;white-space:nowrap;text-overflow:ellipsis}:host::ng-deep .search-select-all{position:absolute;background:#fff;top:40px;z-index:9;width:calc(100% - 10px)}:host::ng-deep .search-select-all .search- .mat-form-field-flex{display:inline-flex;align-items:baseline;box-sizing:border-box;width:calc(100% - 10px);border:1px solid #e9edef;border-radius:5px!important}.tab-content{padding:0!important}ul.nav.nav-tabs.nav-tabs-line{width:100%;padding-right:0;margin-bottom:25px}ul.nav.nav-tabs.nav-tabs-line li{width:40%;padding:15px 10px 0}ul.nav.nav-tabs.nav-tabs-line li .tab-name{display:inline-block;font-size:13px;font-weight:700;color:#48465a}.color-ipt{width:95%}.color-ipt .e-list-item{background-color:#fff!important}.color-ipt .e-input-group{background-color:#eff1fe80!important}::ng-deep .e-dropdownlist .e-list-item.e-active{background:red!important}.color-box{width:100%;display:flex;height:40px;align-items:center;justify-content:center}.color-box .color-item{width:10%;height:16px}.dialog-content{padding:16px 24px}.dialog-content .condition-item{margin-bottom:18px}.dialog-content .condition-item.flex{display:flex}.dialog-content .condition-item.flex .e-checkbox-wrapper{flex:1;height:20px}.dialog-content .condition-item.flex .e-checkbox-wrapper .e-icons{height:18px;width:18px}.dialog-content .condition-item.flex .e-checkbox-wrapper .e-icons:before{font-size:12px}.dialog-content .condition-item .title{margin-bottom:6px;font-size:13px;color:#646c9a}.dialog-content .condition-item .mat-select,.dialog-content .condition-item .mat-input-element{border-bottom:1px solid rgba(0,0,0,.42);height:30px;line-height:30px;width:100%}.dialog-content .condition-item .mat-select.mat-select-disabled,.dialog-content .condition-item .mat-input-element.mat-select-disabled{opacity:.3}::ng-deep .cdk-overlay-pane{transform:translate(-16px)!important}::ng-deep .cdk-overlay-pane .mat-select-panel-wrap{max-width:380px!important}::ng-deep .cdk-overlay-pane .mat-select-panel-wrap .mat-select-panel{min-width:calc(100% + 32px)!important}\n"] }]
|
|
1184
|
+
}], ctorParameters: function () { return [{ type: i1.ApiList }, { type: i2.DashboardService }, { type: i3.DashboardPorletsService }, { type: i0.ChangeDetectorRef }, { type: undefined, decorators: [{
|
|
1185
|
+
type: Optional
|
|
1186
|
+
}, {
|
|
1187
|
+
type: Inject,
|
|
1188
|
+
args: [PBF_TOKEN]
|
|
1189
|
+
}] }, { type: undefined, decorators: [{
|
|
1190
|
+
type: Optional
|
|
1191
|
+
}, {
|
|
1192
|
+
type: Inject,
|
|
1193
|
+
args: [API_SERVICE_TOKEN]
|
|
1194
|
+
}] }]; }, propDecorators: { dashboard_sidebar: [{
|
|
1195
|
+
type: Input
|
|
1196
|
+
}], dashboard: [{
|
|
1197
|
+
type: Input
|
|
1198
|
+
}], dashboardId: [{
|
|
1199
|
+
type: Input
|
|
1200
|
+
}], activeTabId: [{
|
|
1201
|
+
type: Input
|
|
1202
|
+
}], activeTabLabel: [{
|
|
1203
|
+
type: Input
|
|
1204
|
+
}], portlets: [{
|
|
1205
|
+
type: Input
|
|
1206
|
+
}], tabactive: [{
|
|
1207
|
+
type: Input
|
|
1208
|
+
}], portlet: [{
|
|
1209
|
+
type: Input
|
|
1210
|
+
}], figureCode: [{
|
|
1211
|
+
type: Input
|
|
1212
|
+
}], _selectedX: [{
|
|
1213
|
+
type: Input
|
|
1214
|
+
}], _selectedY: [{
|
|
1215
|
+
type: Input
|
|
1216
|
+
}], _selectedMultiples: [{
|
|
1217
|
+
type: Input
|
|
1218
|
+
}], _selectedSecondY: [{
|
|
1219
|
+
type: Input
|
|
1220
|
+
}], _selectTheme: [{
|
|
1221
|
+
type: Input
|
|
1222
|
+
}], appCode: [{
|
|
1223
|
+
type: Input
|
|
1224
|
+
}], closeSidebar: [{
|
|
1225
|
+
type: Output
|
|
1226
|
+
}], updatePorletConfig: [{
|
|
1227
|
+
type: Output
|
|
1228
|
+
}], onToggleTabactive: [{
|
|
1229
|
+
type: Output
|
|
1230
|
+
}], updatePorlet: [{
|
|
1231
|
+
type: Output
|
|
1232
|
+
}], updatePushBtn: [{
|
|
1233
|
+
type: Output
|
|
1234
|
+
}], chartUpdate: [{
|
|
1235
|
+
type: Output
|
|
1236
|
+
}], updateTheme: [{
|
|
1237
|
+
type: Output
|
|
1238
|
+
}] } });
|
|
1239
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sidebar-iconlist-new.component.js","sourceRoot":"","sources":["../../../../../../projects/raise-common-lib/src/lib/dashboard/sidebar-iconlist/sidebar-iconlist-new.component.ts","../../../../../../projects/raise-common-lib/src/lib/dashboard/sidebar-iconlist/sidebar-iconlist-new.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  OnInit,\r\n  ChangeDetectorRef,\r\n  ChangeDetectionStrategy,\r\n  Input,\r\n  Output,\r\n  EventEmitter,\r\n  Inject,\r\n  Optional,\r\n} from \"@angular/core\";\r\nimport { ApiList } from \"../api\";\r\nimport { API_SERVICE_TOKEN, PBF_TOKEN } from \"../../service/InjectionToken\";\r\nimport { DashboardService } from \"../dashboard.service\";\r\nimport { DashboardPorletsService } from \"../dashboardPorlets.service\";\r\nimport { Subscription } from \"rxjs\";\r\n\r\n@Component({\r\n  selector: \"rs-sidebar-iconlist-new\",\r\n  templateUrl: \"./sidebar-iconlist-new.component.html\",\r\n  styleUrls: [\"./sidebar-iconlist-new.component.scss\"],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class SidebarIconlistNewComponent implements OnInit {\r\n  @Input() dashboard_sidebar: boolean = false;\r\n  @Input() dashboard;\r\n  @Input() dashboardId;\r\n  @Input() activeTabId;\r\n  @Input() activeTabLabel;\r\n  @Input() portlets = [];\r\n  @Input() tabactive = false;\r\n  @Input() portlet;\r\n  @Input() figureCode;\r\n  @Input() _selectedX: any = [];\r\n  @Input() _selectedY: any = [];\r\n  @Input() _selectedMultiples: any = null;\r\n  @Input() _selectedSecondY: any = [];\r\n  @Input() _selectTheme: any = null;\r\n  @Input() appCode;\r\n  @Output() closeSidebar = new EventEmitter();\r\n  @Output() updatePorletConfig = new EventEmitter();\r\n  @Output() onToggleTabactive = new EventEmitter();\r\n  @Output() updatePorlet = new EventEmitter();\r\n  @Output() updatePushBtn = new EventEmitter();\r\n  @Output() chartUpdate = new EventEmitter();\r\n  @Output() updateTheme = new EventEmitter();\r\n  public translation = JSON.parse(localStorage.getItem(\"translation\"));\r\n  private lang;\r\n  public dataMartTableList = [];\r\n  hasChanged = false;\r\n  //config;\r\n  public gadgetTitle;\r\n  private subscriptions: Subscription[] = [];\r\n  public portletType;\r\n  public expandArray: Array<boolean> = [\r\n    false,\r\n    false,\r\n    false,\r\n    false,\r\n    false,\r\n    false,\r\n    false,\r\n  ];\r\n  public selectedDataTable: any = \"\";\r\n  public selectedDatamart;\r\n  public chartSettings = {\r\n    legendSettings: {\r\n      visible: false,\r\n    },\r\n    enableMultipleAxis: false,\r\n    showMultiLevelLabels: false,\r\n    chartSeries: {\r\n      type: \"Column\",\r\n      width: 2,\r\n    },\r\n    multipleAxisMode: \"Stacked\",\r\n    primaryXAxis: {\r\n      title: \" \",\r\n      majorGridLines: { width: 0 },\r\n    },\r\n    chartArea: {\r\n      opacity: 0,\r\n      border: {\r\n        width: 0,\r\n      },\r\n    },\r\n    palettes: [\r\n      \"#594bb9\",\r\n      \"#f1af32\",\r\n      \"#4688ed\",\r\n      \"#e0563e\",\r\n      \"#803a63\",\r\n      \"#6dd8b5\",\r\n      \"#e87225\",\r\n      \"#c5df42\",\r\n      \"#c6437d\",\r\n    ],\r\n    primaryYAxis: {\r\n      // Y轴标题设置为空\r\n      title: \" \",\r\n    },\r\n    zoomSettings: {\r\n      enableMouseWheelZooming: false, // 禁用鼠标滚轮缩放\r\n      enablePinchZooming: false, // 禁用触摸缩放\r\n      enableSelectionZooming: false, // 禁用选择区域缩放\r\n      enableDeferredZooming: false, // 禁用延迟缩放\r\n      toolbarItems: [],\r\n      enableScrollbar: false,\r\n      enableZooming: false,\r\n    },\r\n  };\r\n  public displayOption = { view: \"Both\", primary: \"Chart\" };\r\n  public config;\r\n  public currentTab: string = \"tab1\";\r\n  public yList: any = [];\r\n  public chartTypeList = [\r\n    \"Column\",\r\n    \"Bar\",\r\n    \"Line\",\r\n    \"Spline\",\r\n    \"Area\",\r\n    \"Scatter\",\r\n    \"Polar\",\r\n    \"Pie\",\r\n    \"Doughnut\",\r\n    \"Stacked Column\",\r\n    \"Radar\",\r\n  ];\r\n  public multipleAxisModeList = [\"Stacked\", \"Single\", \"Combined\"];\r\n  themeData: any = [\r\n    {\r\n      id: \"theme13\",\r\n      value: [\"#1C3484\", \"#35B9FC\"],\r\n    },\r\n    {\r\n      id: \"theme14\",\r\n      value: [\"#04578F\", \"#3EBBCE\"],\r\n    },\r\n    {\r\n      id: \"theme15\",\r\n      value: [\"#1C3484\", \"#136BBB\", \"#35B9FC\"],\r\n    },\r\n    {\r\n      id: \"theme16\",\r\n      value: [\"#04578F\", \"#0082AF\", \"#3EBBCE\"],\r\n    },\r\n    {\r\n      id: \"theme17\",\r\n      value: [\"#1C3484\", \"#1659A9\", \"#1D97E1\", \"#35B9FC\"],\r\n    },\r\n    {\r\n      id: \"theme18\",\r\n      value: [\"#04578F\", \"#0070A3\", \"#16A2C2\", \"#3EBBCE\"],\r\n    },\r\n    {\r\n      id: \"theme19\",\r\n      value: [\"#1C3484\", \"#1659A9\", \"#1375C4\", \"#1D97E1\", \"#35B9FC\"],\r\n    },\r\n    {\r\n      id: \"theme20\",\r\n      value: [\"#04578F\", \"#0070A3\", \"#0089B4\", \"#16A2C2\", \"#3EBBCE\"],\r\n    },\r\n    {\r\n      id: \"theme21\",\r\n      value: [\"#1C3484\", \"#1659A9\", \"#1368B8\", \"#1375C4\", \"#1D97E1\", \"#35B9FC\"],\r\n    },\r\n    {\r\n      id: \"theme22\",\r\n      value: [\"#04578F\", \"#0070A3\", \"#007FAD\", \"#0089B4\", \"#16A2C2\", \"#3EBBCE\"],\r\n    },\r\n    {\r\n      id: \"theme23\",\r\n      value: [\r\n        \"#1C3484\",\r\n        \"#1659A9\",\r\n        \"#145FAF\",\r\n        \"#1368B8\",\r\n        \"#1375C4\",\r\n        \"#1D97E1\",\r\n        \"#35B9FC\",\r\n      ],\r\n    },\r\n    {\r\n      id: \"theme24\",\r\n      value: [\r\n        \"#04578F\",\r\n        \"#0070A3\",\r\n        \"#0078A9\",\r\n        \"#007FAD\",\r\n        \"#0089B4\",\r\n        \"#16A2C2\",\r\n        \"#3EBBCE\",\r\n      ],\r\n    },\r\n    {\r\n      id: \"theme11\",\r\n      value: [\r\n        \"#1C3484\",\r\n        \"#194697\",\r\n        \"#1659A9\",\r\n        \"#136BBB\",\r\n        \"#147ECC\",\r\n        \"#1B92DD\",\r\n        \"#26A5ED\",\r\n        \"#35B9FC\",\r\n      ],\r\n    },\r\n    {\r\n      id: \"theme12\",\r\n      value: [\r\n        \"#04578F\",\r\n        \"#00659B\",\r\n        \"#0073A6\",\r\n        \"#0082AF\",\r\n        \"#0090B8\",\r\n        \"#0F9EC0\",\r\n        \"#29ADC7\",\r\n        \"#3EBBCE\",\r\n      ],\r\n    },\r\n    {\r\n      id: \"theme1\",\r\n      value: [\r\n        \"#594bb9\",\r\n        \"#f1af32\",\r\n        \"#4688ed\",\r\n        \"#e0563e\",\r\n        \"#803a63\",\r\n        \"#6dd8b5\",\r\n        \"#e87225\",\r\n        \"#c5df42\",\r\n        \"#c6437d\",\r\n      ],\r\n    },\r\n    {\r\n      id: \"theme2\",\r\n      value: [\r\n        \"#4688ed\",\r\n        \"#f1af32\",\r\n        \"#e0563e\",\r\n        \"#803a63\",\r\n        \"#6dd8b5\",\r\n        \"#e87225\",\r\n        \"#c5df42\",\r\n        \"#c6437d\",\r\n        \"#594bb9\",\r\n      ],\r\n    },\r\n    {\r\n      id: \"theme3\",\r\n      value: [\r\n        \"#c6437d\",\r\n        \"#c5df42\",\r\n        \"#e87225\",\r\n        \"#6dd8b5\",\r\n        \"#e0563e\",\r\n        \"#803a63\",\r\n        \"#f1af32\",\r\n        \"#594bb9\",\r\n        \"#4688ed\",\r\n      ],\r\n    },\r\n    {\r\n      id: \"theme4\",\r\n      value: [\r\n        \"#2f499f\",\r\n        \"#8d1d2e\",\r\n        \"#e9bf35\",\r\n        \"#51772f\",\r\n        \"#469bd8\",\r\n        \"#5c448f\",\r\n        \"#da732f\",\r\n        \"#245353\",\r\n        \"#43a245\",\r\n      ],\r\n    },\r\n    {\r\n      id: \"theme5\",\r\n      value: [\r\n        \"#383839\",\r\n        \"#446ec6\",\r\n        \"#cf6384\",\r\n        \"#ebb37e\",\r\n        \"#71a249\",\r\n        \"#4bb1a5\",\r\n        \"#e87225\",\r\n        \"#c5df42\",\r\n        \"#c6437d\",\r\n      ],\r\n    },\r\n    {\r\n      id: \"theme6\",\r\n      value: [\r\n        \"#517ae1\",\r\n        \"#6386e5\",\r\n        \"#7491e9\",\r\n        \"#849dec\",\r\n        \"#94a9ef\",\r\n        \"#a4b6f2\",\r\n        \"#b4c3f6\",\r\n        \"#c4cff9\",\r\n        \"#d4ddfd\",\r\n      ],\r\n    },\r\n    {\r\n      id: \"theme7\",\r\n      value: [\r\n        \"#39828e\",\r\n        \"#488e99\",\r\n        \"#579aa5\",\r\n        \"#66a6b0\",\r\n        \"#75b3bd\",\r\n        \"#85bfc9\",\r\n        \"#95cdd6\",\r\n        \"#a4dae2\",\r\n        \"#b5e8f0\",\r\n      ],\r\n    },\r\n    {\r\n      id: \"theme8\",\r\n      value: [\r\n        \"#e7963d\",\r\n        \"#ea9e4b\",\r\n        \"#eea659\",\r\n        \"#f0ae68\",\r\n        \"#f2b678\",\r\n        \"#f3bf87\",\r\n        \"#f5c798\",\r\n        \"#f6d0aa\",\r\n        \"#f7d9bb\",\r\n      ],\r\n    },\r\n    {\r\n      id: \"theme9\",\r\n      value: [\r\n        \"#64a8b4\",\r\n        \"#7ebec0\",\r\n        \"#9cc9ca\",\r\n        \"#b8d4d4\",\r\n        \"#d9d6cd\",\r\n        \"#d8b7a7\",\r\n        \"#ce8f93\",\r\n        \"#c1627f\",\r\n        \"#ad2458\",\r\n      ],\r\n    },\r\n    {\r\n      id: \"theme10\",\r\n      value: [\r\n        \"#4176ba\",\r\n        \"#559ae8\",\r\n        \"#70b3e8\",\r\n        \"#a7cce7\",\r\n        \"#dfdfdf\",\r\n        \"#d2a08b\",\r\n        \"#c76a50\",\r\n        \"#ca4e34\",\r\n        \"#aa3c29\",\r\n      ],\r\n    },\r\n  ];\r\n\r\n  public themeFields: Object = { text: \"value\", value: \"id\" };\r\n\r\n  constructor(\r\n    private api: ApiList,\r\n    public dashboardService: DashboardService,\r\n    public dashboardPorletsService: DashboardPorletsService,\r\n    private ref: ChangeDetectorRef,\r\n    @Optional() @Inject(PBF_TOKEN) private pbf: any,\r\n    @Optional() @Inject(API_SERVICE_TOKEN) private http: any\r\n  ) {}\r\n  ngOnInit() {\r\n    this.currentTab = this.tabactive ? \"tab1\" : \"tab2\";\r\n    this.getInfo();\r\n    this.setDatabind();\r\n    this.initHistoricalIRROptions();\r\n    this.getmultiplesList();\r\n  }\r\n\r\n  ngOnChanges() {\r\n    this.ref.markForCheck(); // 标记为需要检测\r\n  }\r\n  ngAfterViewInit(): void {\r\n    this.subscriptions.push(\r\n      this.dashboardService.getPushbtn().subscribe((id) => {\r\n        if (this.dashboard && this.dashboard.id === id) {\r\n          this.config = this.getConfig([]);\r\n          this.selectedDatamart = \"\";\r\n          this.selectedX = null;\r\n          this.selectedY = [];\r\n          this.selectedSecondY = [];\r\n          this.selectedMultiples = null;\r\n          this.ref.markForCheck();\r\n          this.ref.detectChanges();\r\n        }\r\n      })\r\n    );\r\n\r\n    this.subscriptions.push(\r\n      this.dashboardService.getportletEdit().subscribe((dashboardId) => {\r\n        if (dashboardId === this.dashboardId) {\r\n          this.setDatabind();\r\n        }\r\n      })\r\n    );\r\n    this.initDataMartTableList();\r\n  }\r\n\r\n  private initDataMartTableList() {\r\n    this.dataMartTableList = [...this.dashboard.dataMartTables].filter(\r\n      (item) => !item.isHide\r\n    );\r\n\r\n    this.dashboardPorletsService.renameDataMartTables(\r\n      this.dataMartTableList,\r\n      this.dashboard.id,\r\n      this.dashboard.entityType\r\n    );\r\n    this.dashboardPorletsService.sortDataMartTables(this.dataMartTableList);\r\n    if (!this.portlet) {\r\n      return;\r\n    }\r\n    let figureCode = this.portlet.figureCode;\r\n    this.dashboard.dataMartTables.forEach((item) => {\r\n      if (item.datamartCode === figureCode && item.prefix) {\r\n        figureCode = item.prefix;\r\n      }\r\n    });\r\n    if (\r\n      !this.dataMartTableList.find((item) => item.datamartCode === figureCode)\r\n    ) {\r\n      this.dataMartTableList.forEach((data) => {\r\n        if (data.prefix === figureCode) {\r\n          figureCode = data.datamartCode;\r\n        }\r\n      });\r\n    }\r\n\r\n    this.selectedDatamart = figureCode;\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.subscriptions.forEach((sb) => sb.unsubscribe());\r\n  }\r\n\r\n  public nextWizard(wizard: number) {\r\n    if (!this.expandArray[wizard]) {\r\n      this.expandArray = [\r\n        false,\r\n        false,\r\n        false,\r\n        false,\r\n        false,\r\n        false,\r\n        false,\r\n        false,\r\n      ];\r\n      this.expandArray[wizard] = true;\r\n    } else {\r\n      this.expandArray[wizard] = false;\r\n    }\r\n  }\r\n\r\n  private getInfo() {\r\n    this.translation = JSON.parse(localStorage.getItem(\"translation\"));\r\n    this.lang = this.pbf.getLanguageParams();\r\n  }\r\n\r\n  public clear() {\r\n    this.dashboardService.clearSidebar.next(true);\r\n  }\r\n  public close() {\r\n    this.updatePushBtn.emit(false);\r\n    this.updatePorlet.emit(null);\r\n    this.closeSidebar.emit(false);\r\n  }\r\n\r\n  public getFigurecode() {\r\n    let codeArr = [\"Tasks\", \"FundList\", \"IRR\", \"Notes\"];\r\n    let i = codeArr.indexOf(this.figureCode);\r\n    return i > -1 ? false : true;\r\n  }\r\n\r\n  // 图表类型更改event\r\n  public getPortletType($event) {\r\n    this.portletType = $event;\r\n    this.hasChanged = this.config.portletType !== this.portletType;\r\n    const prevType = this.config.portletType;\r\n    this.config.portletType = this.portletType;\r\n    if (!$event) {\r\n      return;\r\n    }\r\n    if ([\"newcolumn\", \"newline\", \"newcolumnline\"].includes($event)) {\r\n      this.selectedX = null;\r\n      this.selectedY = [];\r\n      this.selectedSecondY = [];\r\n      this.selectedMultiples = null;\r\n      this.expandArray[2] = false;\r\n      this.expandArray[7] = true;\r\n      // 修复有时选择 xy 轴时没有数据的问题\r\n      if (this.portlet && this.portlet.figureCode) {\r\n        this.getData(this.portlet.figureCode, false, this.portletType);\r\n      }\r\n      return;\r\n    }\r\n    if (this.portletType === \"newchart\") {\r\n      if (\r\n        this.config.pvtableChartSetting &&\r\n        this.config.pvtableChartSetting.chartSettings\r\n      ) {\r\n        this.chartSettings = {\r\n          ...this.config.pvtableChartSetting.chartSettings,\r\n        };\r\n      } else {\r\n        this.chartSettings = {\r\n          legendSettings: {\r\n            visible: false,\r\n          },\r\n          enableMultipleAxis: false,\r\n          showMultiLevelLabels: false,\r\n          chartSeries: {\r\n            type: \"Column\",\r\n            width: 2,\r\n          },\r\n          multipleAxisMode: \"Stacked\",\r\n          primaryXAxis: {\r\n            title: \" \",\r\n            majorGridLines: { width: 0 },\r\n          },\r\n          chartArea: {\r\n            opacity: 0,\r\n            border: {\r\n              width: 0,\r\n            },\r\n          },\r\n          palettes: [\r\n            \"#594bb9\",\r\n            \"#f1af32\",\r\n            \"#4688ed\",\r\n            \"#e0563e\",\r\n            \"#803a63\",\r\n            \"#6dd8b5\",\r\n            \"#e87225\",\r\n            \"#c5df42\",\r\n            \"#c6437d\",\r\n          ],\r\n          primaryYAxis: {\r\n            // Y轴标题设置为空\r\n            title: \" \",\r\n          },\r\n          zoomSettings: {\r\n            enableMouseWheelZooming: false, // 禁用鼠标滚轮缩放\r\n            enablePinchZooming: false, // 禁用触摸缩放\r\n            enableSelectionZooming: false, // 禁用选择区域缩放\r\n            enableDeferredZooming: false, // 禁用延迟缩放\r\n            toolbarItems: [],\r\n            enableScrollbar: false,\r\n            enableZooming: false,\r\n          },\r\n        };\r\n      }\r\n    }\r\n    if ($event === \"historicalIRR\") {\r\n      this.onSelectedHistoricalIRRPortlet();\r\n      this.expandArray[2] = false;\r\n      this.expandArray[7] = true;\r\n      return;\r\n    }\r\n    this.expandArray[2] = false;\r\n    this.expandArray[3] = true;\r\n    if (this.portletType) {\r\n      this.AddOrEditPortlet();\r\n    }\r\n  }\r\n  public changeDataTable(value) {\r\n    this.selectedDataTable = this.dataMartTableList.filter(\r\n      (el) => el.datamartCode === value\r\n    )[0].id;\r\n    this.selectedDatamart = value;\r\n    if (this.portlet) {\r\n      this.portlet.figureCode = value;\r\n\r\n      this.portlet.dashboardDataTableId = this.getSelectDatamartId();\r\n    }\r\n    if (this.portlet) {\r\n      this.dashboardService.clearFieldList.next(this.portlet.newId);\r\n    }\r\n    if (this.portlet) {\r\n      this.dashboardPorletsService.clearFieldsObj(this.portlet);\r\n    }\r\n    this.getData(value);\r\n    this.expandArray[0] = false;\r\n    this.expandArray[2] = true;\r\n  }\r\n\r\n  _updatePorletConfig(e) {\r\n    this.updatePorletConfig.emit(e);\r\n  }\r\n\r\n  private getData(code, edit: boolean = true, portletType = \"\") {\r\n    const dataObj = {\r\n      dataMartCode: code,\r\n      language: this.lang,\r\n    };\r\n    this.dashboardPorletsService.setSchemaParams(dataObj, code, this.dashboard);\r\n    this.http.post(this.api.urlList.GetSchema, dataObj, (res) => {\r\n      if (res) {\r\n        if (\r\n          [\r\n            \"SeeThroughQuarterly\",\r\n            \"SeeThroughYearly\",\r\n            \"SeeThroughMonthly\",\r\n          ].includes(code)\r\n        ) {\r\n          res = res.filter(\r\n            (item) =>\r\n              ![\r\n                \"CI_MTD\",\r\n                \"CI_QTD\",\r\n                \"CI_YTD\",\r\n                \"CTWR_MTD\",\r\n                \"CTWR_QTD\",\r\n                \"CTWR_YTD\",\r\n                \"CVAR_MTD_95\",\r\n                \"CVAR_MTD_99\",\r\n                \"CVAR_QTD_95\",\r\n                \"CVAR_QTD_99\",\r\n                \"CVAR_YTD_95\",\r\n                \"CVAR_YTD_99\",\r\n              ].includes(item.colName)\r\n          );\r\n        }\r\n        if (!this.dashboardPorletsService.fieldsArr[this.dashboard.id]) {\r\n          this.dashboardPorletsService.fieldsArr[this.dashboard.id] = {};\r\n        }\r\n        this.dashboardPorletsService.fieldsArr[this.dashboard.id][\r\n          this.selectedDatamart\r\n        ] = res;\r\n        if (this.portlet) {\r\n          if (this.portlet.config) {\r\n            this.config = JSON.parse(this.portlet.config);\r\n          } else {\r\n            this.config = {};\r\n          }\r\n          if (portletType) {\r\n            this.config.portletType = portletType;\r\n          }\r\n          this.config.fields = res;\r\n\r\n          // TO DO 过滤Y轴的数据\r\n          this.yList = res;\r\n          this.portlet.config = this.config ? JSON.stringify(this.config) : \"\";\r\n\r\n          edit && this.AddOrEditPortlet();\r\n        } else {\r\n          this.config.fields = res;\r\n          setTimeout(() => {\r\n            const portlet = Object.assign({}, this.portlet);\r\n            portlet.config = this.config;\r\n            this.updatePorlet.emit(portlet);\r\n            // TO DO 过滤Y轴的数据\r\n            this.yList = res;\r\n          });\r\n        }\r\n      }\r\n    });\r\n  }\r\n\r\n  public setMultipleAxis(e) {\r\n    setTimeout(() => {\r\n      if (!this.chartSettings.enableMultipleAxis) {\r\n        this.chartSettings.legendSettings.visible = false;\r\n        this.ref.markForCheck();\r\n      }\r\n      this.dashboardService.enableMultipleAxisChange.next({\r\n        newId: this.portlet.newId,\r\n        enableMultipleAxis: this.chartSettings.enableMultipleAxis,\r\n        visible: this.chartSettings.legendSettings.visible,\r\n        multipleAxisMode: this.chartSettings.multipleAxisMode,\r\n      });\r\n    });\r\n  }\r\n\r\n  public setChartType() {\r\n    const portlet = Object.assign({}, this.portlet);\r\n    if (portlet.config) {\r\n      const config = JSON.parse(portlet.config);\r\n      config.pvtableChartSetting = config.pvtableChartSetting\r\n        ? {\r\n            ...config.pvtableChartSetting,\r\n            chartSettings: this.chartSettings,\r\n          }\r\n        : { chartSettings: this.chartSettings };\r\n      portlet.config = JSON.stringify(config);\r\n    }\r\n    this.updatePorlet.emit(portlet);\r\n    setTimeout(() => {\r\n      this.dashboardService.chartTypeChange.next({\r\n        newId: this.portlet.newId,\r\n        chartSettings: this.chartSettings,\r\n      });\r\n    });\r\n  }\r\n\r\n  public getThemeData(e) {\r\n    const id = e.value;\r\n    const portlet = this.portlet;\r\n    const theme = this.themeData.find((item) => item.id === id);\r\n    if (!theme) {\r\n      return;\r\n    }\r\n    this.dashboardService.setTheme.next({\r\n      newId: portlet.newId,\r\n      theme: theme.value,\r\n    });\r\n  }\r\n\r\n  public AddOrEditPortlet() {\r\n    const portletType =\r\n      this.config.portletType === \"historicalIRR\"\r\n        ? this.config.selectedVisualType\r\n        : this.config.portletType;\r\n    if (this.portlet && this.portlet.newId) {\r\n      // SMP2-17654 需要将选择的 frequency、investor、visual type 保存到 config 中用来拿取后端数据\r\n      // 但是如果直接保存 this.config 会出现 SMP2-18837 这个 BUG\r\n      const config = JSON.parse(this.portlet.config);\r\n      if (this.hasChanged) {\r\n        if (\r\n          [\"newcolumn\", \"newline\", \"newcolumnline\"].includes(portletType) &&\r\n          (this.selectedY.length > 0 || this.selectedSecondY.length > 0)\r\n        ) {\r\n          config[\"selectedX\"] = this.selectedX;\r\n          config[\"selectedY\"] = this.selectedY;\r\n          config[\"selectedSecondY\"] = this.selectedSecondY;\r\n          config[\"selectedMultiples\"] = this.selectedMultiples;\r\n          config[\"selectTheme\"] = this.selectTheme;\r\n        }\r\n\r\n        if (config.portletType === \"newchart\") {\r\n          config.pvtableChartSetting = {\r\n            chartSettings: this.chartSettings,\r\n            displayOption: this.displayOption,\r\n          };\r\n        }\r\n      }\r\n      config.selectedMultiples = this.config.selectedMultiples;\r\n      config.selectedInvestor = this.config.selectedInvestor;\r\n      config.selectedVisualType = this.config.selectedVisualType;\r\n      const portlet = Object.assign({}, this.portlet);\r\n      portlet.config = JSON.stringify(config);\r\n      // 新增DataTable类型， 编辑Porlet\r\n      this.dashboardPorletsService.setDataManager(\r\n        [this.getTrueSelectedDatamart()],\r\n        (res) => {\r\n          this.pbf.pageLoading = false;\r\n          this.pbf.pageLoading_.next(true);\r\n          this.editPortlet();\r\n        },\r\n        [portletType],\r\n        this.dashboard.id,\r\n        portlet\r\n      );\r\n    } else {\r\n      this.config.fields.map((el) => {\r\n        el.visible = true;\r\n      });\r\n      if (\r\n        [\"newcolumn\", \"newline\", \"newcolumnline\"].includes(portletType) &&\r\n        (this.selectedY.length > 0 || this.selectedSecondY.length > 0)\r\n      ) {\r\n        this.config[\"selectedX\"] = this.selectedX;\r\n        this.config[\"selectedY\"] = this.selectedY;\r\n        this.config[\"selectedSecondY\"] = this.selectedSecondY;\r\n        this.config[\"selectedMultiples\"] = this.selectedMultiples;\r\n        this.config[\"selectTheme\"] = this.selectTheme;\r\n      }\r\n\r\n      if (this.config.portletType === \"newchart\") {\r\n        this.config.pvtableChartSetting = {\r\n          chartSettings: this.chartSettings,\r\n          displayOption: this.displayOption,\r\n        };\r\n      }\r\n\r\n      this.getSelectDatamartId();\r\n      const portletdata = {\r\n        id: \"00000000-0000-0000-0000-000000000000\",\r\n        newId: \"portlet_\" + this.pbf.Guid(),\r\n        dashboardDataTableId: this.getSelectDatamartId(),\r\n        figureCode: this.getTrueSelectedDatamart(),\r\n        col: 0,\r\n        row: 0,\r\n        sizeX: 2,\r\n        sizeY: 1,\r\n        posX: 0,\r\n        posY: 0,\r\n        height: 1,\r\n        width: 2,\r\n        config: JSON.stringify(this.config),\r\n      };\r\n      this.updatePorlet.emit(portletdata);\r\n      this.portlets.forEach((portlet) => {\r\n        portlet.row += 1;\r\n      });\r\n      // 新增DataTable类型， 新增Porlet\r\n      this.dashboardPorletsService.setDataManager(\r\n        [this.getTrueSelectedDatamart()],\r\n        (res) => {\r\n          setTimeout(() => {\r\n            this.dashboardService.addOrdelPortlet.next(this.dashboard.id);\r\n            this.pbf.pageLoading = false;\r\n            this.pbf.pageLoading_.next(true);\r\n          }, 200);\r\n        },\r\n        [portletType],\r\n        this.dashboard.id,\r\n        portletdata\r\n      );\r\n    }\r\n  }\r\n  private editPortlet() {\r\n    if (this.portlet) {\r\n      const portletType =\r\n        this.config.portletType === \"historicalIRR\"\r\n          ? this.config.selectedVisualType\r\n          : this.config.portletType;\r\n      if ([\"table\", \"transpose\", \"financialTable\"].includes(portletType)) {\r\n        this.config.filterSettings = [];\r\n        this.config.fields.map((el) => {\r\n          el.visible = true;\r\n        });\r\n      }\r\n      const index = this.portlets.findIndex(\r\n        (x) => x.newId === this.portlet.newId\r\n      );\r\n      if (index > -1) {\r\n        this.portlets[index].config = JSON.stringify(this.config);\r\n\r\n        if ([\"newcolumn\", \"newline\", \"newcolumnline\"].includes(portletType)) {\r\n          this.portlets[index].figureCode = this.getTrueSelectedDatamart();\r\n        }\r\n\r\n        const portlet = Object.assign({}, this.portlet);\r\n        portlet.config = JSON.stringify(this.config);\r\n        portlet.dashboardDataTableId = this.getSelectDatamartId();\r\n        this.updatePorlet.emit(portlet);\r\n      }\r\n      const id = this.portlet.id || this.portlet.newId;\r\n      this.chartUpdate.emit(id);\r\n    }\r\n  }\r\n\r\n  switchTab(type) {\r\n    this.currentTab = type;\r\n    this.onToggleTabactive.emit(!this.tabactive);\r\n    this.dashboardService.portletEdit.next(this.dashboardId);\r\n  }\r\n\r\n  gadgetTitleChange(newObj) {\r\n    if (!this.portlet || !this.portlet.config) {\r\n      return;\r\n    }\r\n    this.config = JSON.parse(this.portlet.config);\r\n    this.config.gadgetTitle = newObj;\r\n    const index = this.portlets.findIndex(\r\n      (x) => x.newId === this.portlet.newId\r\n    );\r\n    if (index > -1) this.portlets[index].config = JSON.stringify(this.config);\r\n    this.portlet.config = JSON.stringify(this.config);\r\n    this.dashboardService.portletTitle.next(true);\r\n  }\r\n\r\n  setDatabind() {\r\n    if (this.portlet) {\r\n      const { dataMartTables = {} } = this.dashboardPorletsService;\r\n      let figureCode = this.portlet.figureCode;\r\n      dataMartTables[this.dashboard.id].forEach((item) => {\r\n        if (item.datamartCode === figureCode && item.prefix) {\r\n          figureCode = item.prefix;\r\n        }\r\n      });\r\n      if (\r\n        this.dataMartTableList &&\r\n        this.dataMartTableList.length &&\r\n        !this.dataMartTableList.find((item) => item.datamartCode === figureCode)\r\n      ) {\r\n        this.dataMartTableList.forEach((data) => {\r\n          if (data.prefix === figureCode) {\r\n            figureCode = data.datamartCode;\r\n          }\r\n        });\r\n      }\r\n\r\n      this.selectedDatamart = figureCode;\r\n      this.config = {};\r\n      if (this.portlet.config) this.config = JSON.parse(this.portlet.config);\r\n      this.hasMarker = this.config.hasMarker;\r\n      this.markerFormat = this.config.markerFormat || \"\";\r\n\r\n      if (this.config.portletType === \"historicalIRR\") {\r\n        this.selectedMultiples = this.config.selectedMultiples;\r\n        this.selectedInvestor = this.config.selectedInvestor;\r\n        this.selectedVisualType = this.config.selectedVisualType;\r\n        this.portletType = this.config.portletType;\r\n      }\r\n      const portletType =\r\n        this.config.portletType === \"historicalIRR\"\r\n          ? this.config.selectedVisualType\r\n          : this.config.portletType;\r\n      if ([\"newcolumn\", \"newline\", \"newcolumnline\"].includes(portletType)) {\r\n        this.selectedX = this._selectedX;\r\n        this.selectedY = this._selectedY;\r\n        this.selectedSecondY = this._selectedSecondY;\r\n        this.selectedMultiples = this._selectedMultiples;\r\n        this.selectTheme = this._selectTheme;\r\n        this.portletType = this.config.portletType;\r\n        this.getData(this.portlet.figureCode, false);\r\n      }\r\n\r\n      if (this.config.portletType === \"newchart\") {\r\n        this.portletType = \"newchart\";\r\n        if (this.config.pvtableChartSetting) {\r\n          this.chartSettings = {\r\n            ...this.config.pvtableChartSetting.chartSettings,\r\n          };\r\n          if (this.config.pvtableChartSetting.chartSettings.palettes) {\r\n            const { palettes } = this.config.pvtableChartSetting.chartSettings;\r\n            if (palettes && palettes.length) {\r\n              this.selectTheme = this.themeData.find(\r\n                (item) =>\r\n                  // 用于判断两个\r\n                  JSON.stringify(item.value) === JSON.stringify(palettes)\r\n              ).id;\r\n            }\r\n          }\r\n        } else {\r\n          this.config.pvtableChartSetting = {\r\n            displayOption: this.displayOption,\r\n            chartSettings: this.chartSettings,\r\n          };\r\n        }\r\n      }\r\n    } else {\r\n      this.selectedDatamart = \"\";\r\n      this.config = this.getConfig([]);\r\n    }\r\n    this.ref.markForCheck();\r\n    this.ref.detectChanges();\r\n  }\r\n  private getConfig(fields) {\r\n    return {\r\n      tabId: this.activeTabId,\r\n      tabLabel: this.activeTabLabel,\r\n      portletType: \"\",\r\n      gadgetTitle: \"\",\r\n      isUpToDate: false,\r\n      period: 3,\r\n      pagebreak: false,\r\n      timeMeasure: \"MTD\",\r\n      series: [],\r\n      sSeries: [],\r\n      trendsOrder: 1,\r\n      showTrends: true,\r\n      numberFormat: \"#,##0\",\r\n      showCurrentData: false,\r\n      fields: fields,\r\n      allFields: [\r\n        {\r\n          colName: \"ALL_TEXT_FIELDS\",\r\n          langValue: \"All text fields\",\r\n          dataType: \"string\",\r\n        },\r\n        {\r\n          colName: \"ALL_DATE_FIELDS\",\r\n          langValue: \"All date fields\",\r\n          dataType: \"date\",\r\n        },\r\n        {\r\n          colName: \"ALL_NUMBER_FIELDS\",\r\n          langValue: \"All number fields\",\r\n          dataType: \"number\",\r\n        },\r\n        {\r\n          colName: \"ALL_INTEGER_FIELDS\",\r\n          langValue: \"All integer fields\",\r\n          dataType: \"integer\",\r\n        },\r\n        {\r\n          colName: \"ALL_PERCENTAGE_FIELDS\",\r\n          langValue: \"All percentage fields\",\r\n          dataType: \"percent\",\r\n        },\r\n        {\r\n          colName: \"ALL_MULTIPLE_FIELDS\",\r\n          langValue: \"All multiple fields\",\r\n          dataType: \"multiple\",\r\n        },\r\n      ],\r\n      filters: [],\r\n      filterSettings: [],\r\n      columnGroup: [],\r\n      listOfInvesteeId: [],\r\n      investeeId: \"00000000-0000-0000-0000-000000000000\",\r\n      groupBy: \"\",\r\n      groups: [],\r\n      asOfDate: \"\",\r\n      currencyCode: \"\",\r\n      fundId: \"00000000-0000-0000-0000-000000000000\",\r\n      xaxis: { groups: [] },\r\n      yaxis: {\r\n        series: [{ portletType: \"\", colName: \"\", calMethod: \"\" }],\r\n      },\r\n      calculatedFieldSettings: [],\r\n      columnsWidth: [],\r\n      sortSettings: [],\r\n      groupSettings: [],\r\n      valueSortSettings: {},\r\n      showGrandTotals: true,\r\n      showRowGrandTotals: true,\r\n      showColumnGrandTotals: true,\r\n      showSubTotals: true,\r\n      showRowSubTotals: true,\r\n      showColumnSubTotals: true,\r\n    };\r\n  }\r\n\r\n  public selectedInvestor = null;\r\n  public investorList = [];\r\n  public selectedVisualType = null;\r\n  public visualTypeList = [];\r\n\r\n  // historical IRR frequency 不需要 Daily\r\n  get frequencyOptions() {\r\n    return this.multiplesList.filter((i) => i.langCode !== \"DAILY\");\r\n  }\r\n\r\n  initHistoricalIRROptions() {\r\n    const chartText = this.translation.COMPANY_CHART || \".COMPANY_CHART\";\r\n    this.investorList = [\r\n      {\r\n        code: \"All\",\r\n        text: this.translation.ALL,\r\n      },\r\n      {\r\n        code: \"ExcludeGP&SLP\",\r\n        text: this.translation[\"EXCLUDE_GP&SLP\"] || \".Exclude GP&SLP\",\r\n      },\r\n    ];\r\n    this.visualTypeList = [\r\n      {\r\n        code: \"newline\",\r\n        text: `${this.translation.LINE || \".LINE\"} ${chartText}`,\r\n      },\r\n      {\r\n        code: \"newcolumn\",\r\n        text: `${this.translation.COLUMN} ${chartText}`,\r\n      },\r\n      {\r\n        code: \"table\",\r\n        text: this.translation.TABLE || \".TABLE\",\r\n      },\r\n    ];\r\n  }\r\n\r\n  onSelectedHistoricalIRRPortlet() {\r\n    this.selectedInvestor = \"All\";\r\n    this.selectedMultiples = \"QUARTERLY\";\r\n    this.selectedVisualType = \"newline\";\r\n    this.setHistoricalIRRChart(false);\r\n  }\r\n\r\n  setHistoricalIRRChart(opened: boolean) {\r\n    if (opened) {\r\n      return;\r\n    }\r\n    if (\r\n      this.selectedVisualType !== \"table\" &&\r\n      this.config.selectedVisualType === \"table\"\r\n    ) {\r\n      this.hasMarker = false;\r\n    }\r\n\r\n    this.config.selectedVisualType = this.selectedVisualType;\r\n    this.config.selectedInvestor = this.selectedInvestor;\r\n    if (this.selectedVisualType !== \"table\") {\r\n      // 这里确定 x、y 轴字段名称\r\n      this.selectedX = \"Date\";\r\n      this.selectedY = [\"IRR\"];\r\n      return this.xyChange(false);\r\n    } else {\r\n      this.config.selectedMultiples = this.selectedMultiples;\r\n      this.AddOrEditPortlet();\r\n    }\r\n  }\r\n\r\n  selectedX: any = null;\r\n  selectedY: any = [];\r\n  selectedSecondY: any = [];\r\n  selectedMultiples: any = null;\r\n  markerFormat = \"\";\r\n  markerFormatList = [\r\n    {\r\n      value: \"\",\r\n      label: this.translation.NONE || \".None\",\r\n    },\r\n    {\r\n      value: \"K\",\r\n      label: this.translation.THOUSANDS || \".Thousands\",\r\n    },\r\n    {\r\n      value: \"M\",\r\n      label: this.translation.MILLIONS || \".Millions\",\r\n    },\r\n    {\r\n      value: \"bn\",\r\n      label: this.translation.BILLIONS || \".Billions\",\r\n    },\r\n    {\r\n      value: \"T\",\r\n      label: this.translation.TRILLIONS || \".Trillions\",\r\n    },\r\n  ];\r\n  hasMarker = false;\r\n\r\n  labelConfigChange(e) {\r\n    this.config.hasMarker = e;\r\n    this.updatePorletConfig.emit({\r\n      newId: this.portlet.newId,\r\n      config: Object.assign({}, this.config),\r\n    });\r\n    this.dashboardService.switchLabelConfig.next({\r\n      checked: e,\r\n      id: this.portlet.newId,\r\n    });\r\n  }\r\n\r\n  xyChange(e) {\r\n    if (e) {\r\n      return;\r\n    }\r\n\r\n    setTimeout(() => {\r\n      this.updateTheme.emit({\r\n        selectedX: this.selectedX,\r\n        selectedY: this.selectedY,\r\n        selectedMultiples: this.selectedMultiples,\r\n        selectedSecondY: this.selectedSecondY,\r\n        selectTheme: this.selectTheme,\r\n        hasMarker: this.hasMarker,\r\n        markerFormat: this.markerFormat,\r\n      });\r\n\r\n      this.config[\"markerFormat\"] = this.markerFormat;\r\n      this.config[\"hasMarker\"] = this.hasMarker;\r\n      this.config[\"selectedX\"] = this.selectedX;\r\n      this.config[\"selectedY\"] = this.selectedY;\r\n      this.config[\"selectedSecondY\"] = this.selectedSecondY;\r\n      this.config[\"selectedMultiples\"] = this.selectedMultiples;\r\n      this.config[\"selectTheme\"] = this.selectTheme;\r\n\r\n      this.updatePorletConfig.emit({\r\n        newId: this.portlet.newId,\r\n        config: Object.assign({}, this.config),\r\n      });\r\n\r\n      this.showEdit();\r\n    }, 500);\r\n  }\r\n\r\n  showEdit() {\r\n    if (\r\n      this.portletType == \"newcolumnline\" &&\r\n      this.selectedY.length > 0 &&\r\n      this.selectedSecondY.length > 0\r\n    ) {\r\n      this.AddOrEditPortlet();\r\n    }\r\n    if (this.portletType != \"newcolumnline\" && this.selectedY.length > 0) {\r\n      this.AddOrEditPortlet();\r\n    }\r\n  }\r\n\r\n  multiplesList: any = [];\r\n  getmultiplesList() {\r\n    const url =\r\n      this.appCode === \"PMS\"\r\n        ? this.api.urlList.LPGetPropertyList\r\n        : this.api.urlList.GetPropertyList;\r\n    this.http.post(url, { scope: \"DASHBOARD_FREQUENCY\", langIdx: 2 }, (res) => {\r\n      this.multiplesList = res;\r\n    });\r\n  }\r\n\r\n  capitalize(str) {\r\n    // 将字符串转换为小写，并使用正则表达式将每个单词的第一个字符转换为大写\r\n    if (!str) {\r\n      return;\r\n    }\r\n    return str.toLowerCase().replace(/\\b\\w/g, function (char) {\r\n      return char.toUpperCase();\r\n    });\r\n  }\r\n\r\n  getSelectDatamartId() {\r\n    // 获取真正的DatamartID\r\n    const code = this.getTrueSelectedDatamart();\r\n    let dataMartTables = this.dashboardPorletsService.dataMartTables[\r\n      this.dashboard.id\r\n    ].filter((el) => code == el.datamartCode);\r\n    if (dataMartTables.length > 0) {\r\n      return dataMartTables[0].id;\r\n    }\r\n  }\r\n\r\n  getTrueSelectedDatamart() {\r\n    const portletType =\r\n      this.config.portletType === \"historicalIRR\"\r\n        ? this.config.selectedVisualType\r\n        : this.config.portletType;\r\n    // 获取真正的DatamartCode\r\n    if ([\"newcolumn\", \"newline\", \"newcolumnline\"].includes(portletType)) {\r\n      return this.getSelectDatamartCode();\r\n    } else {\r\n      return this.selectedDatamart;\r\n    }\r\n  }\r\n\r\n  getSelectDatamartCode() {\r\n    const item = this.dashboardPorletsService.dataMartTables[\r\n      this.dashboard.id\r\n    ].filter((e) => {\r\n      return e[\"datamartCode\"] == this.selectedDatamart;\r\n    });\r\n    if (item.length > 0) {\r\n      if (item[0][\"prefix\"]) {\r\n        return `${item[0][\"prefix\"]}${\r\n          this.capitalize(this.selectedMultiples) || \"\"\r\n        }`;\r\n      } else {\r\n        return item[0][\"datamartCode\"];\r\n      }\r\n    } else {\r\n      return \"\";\r\n    }\r\n  }\r\n\r\n  selectTheme: any = \"theme1\";\r\n  changeTheme(e, type) {\r\n    this.selectTheme = e.value;\r\n    this.config[\"selectTheme\"] = this.selectTheme;\r\n    this.updateTheme.emit({\r\n      selectedX: this.selectedX,\r\n      selectedY: this.selectedY,\r\n      selectedMultiples: this.selectedMultiples,\r\n      selectedSecondY: this.selectedSecondY,\r\n      selectTheme: this.selectTheme,\r\n    });\r\n    this.showEdit();\r\n  }\r\n\r\n  sortDataMartTables(data) {\r\n    data.sort((a, b) => {\r\n      const langValueA = a.langValue.toLowerCase();\r\n      const langValueB = b.langValue.toLowerCase();\r\n\r\n      if (langValueA < langValueB) {\r\n        return -1;\r\n      }\r\n      if (langValueA > langValueB) {\r\n        return 1;\r\n      }\r\n      return 0;\r\n    });\r\n  }\r\n\r\n  onChangeFormat() {\r\n    this.dashboardService.markerFormat.next({\r\n      newId: this.portlet.newId,\r\n      markerFormat: this.markerFormat,\r\n    });\r\n  }\r\n}\r\n","<div class=\"sidebar-iconlist\" *ngIf=\"config\">\r\n  <ul class=\"nav-tabs\">\r\n    <li class=\"nav-item\">\r\n      <a\r\n        class=\"nav-link\"\r\n        [ngClass]=\"{ active: currentTab === 'tab1' }\"\r\n        data-toggle=\"tab\"\r\n        (click)=\"switchTab('tab1')\"\r\n      >\r\n        <img\r\n          style=\"margin-right: 8px\"\r\n          src=\"../../../assets/img/dashboard_icon/basic-icon-filter.svg\"\r\n        />\r\n        <div class=\"tab-name\">\r\n          {{ translation.FILTER ? translation.FILTER : \".FILTER\" }}\r\n        </div>\r\n      </a>\r\n    </li>\r\n    <li class=\"nav-item\">\r\n      <a\r\n        class=\"nav-link\"\r\n        [ngClass]=\"{ active: currentTab === 'tab2' }\"\r\n        data-toggle=\"tab\"\r\n        (click)=\"switchTab('tab2')\"\r\n      >\r\n        <img\r\n          style=\"margin-right: 8px\"\r\n          src=\"../../../assets/img/dashboard_icon/dashboard-icon.svg\"\r\n        />\r\n        <div class=\"tab-name\">\r\n          {{ translation.PROPERTIES ? translation.PROPERTIES : \".PROPERTIES\" }}\r\n        </div>\r\n      </a>\r\n    </li>\r\n  </ul>\r\n  <div class=\"sidebar-iconlist-content\">\r\n    <!-- <form action=\"\" method=\"\"> -->\r\n    <div\r\n      class=\"tab-content\"\r\n      style=\"height: calc(100% - 140px); overflow-y: scroll\"\r\n    >\r\n      <div class=\"tab-pane\" *ngIf=\"currentTab === 'tab1'\" style=\"height: 100%\">\r\n        <rs-field-filter\r\n          [portlet]=\"portlet\"\r\n          [dashboard]=\"dashboard\"\r\n          [portlets]=\"portlets\"\r\n          (updatePorletConfig)=\"_updatePorletConfig($event)\"\r\n        ></rs-field-filter>\r\n      </div>\r\n      <div class=\"tab-pane\" *ngIf=\"currentTab === 'tab2'\">\r\n        <div>\r\n          <div (click)=\"nextWizard(0)\" class=\"wizard\">\r\n            <span class=\"wizard-name\">\r\n              {{\r\n                translation.DATA_TABLE ? translation.DATA_TABLE : \"Data Table\"\r\n              }}*\r\n            </span>\r\n            <mat-icon style=\"position: absolute; right: 0\">\r\n              {{ !expandArray[0] ? \"expand_more\" : \"expand_less\" }}\r\n            </mat-icon>\r\n          </div>\r\n          <div\r\n            [ngStyle]=\"{ height: expandArray[0] ? '100px' : '0' }\"\r\n            [ngClass]=\"{ collapsed: !expandArray[0] }\"\r\n            class=\"wizard-expanded\"\r\n          >\r\n            <div class=\"data-source add-pdding\">\r\n              <div style=\"margin-bottom: 10px\" class=\"twelvepx\">\r\n                {{\r\n                  translation.FIRST_CHOOSE_THE_DATA_TABLE_TO_CUSTOMIZE_YOUR_DASHBOARD\r\n                    ? translation.FIRST_CHOOSE_THE_DATA_TABLE_TO_CUSTOMIZE_YOUR_DASHBOARD\r\n                    : \"Firstly, choose the data table to customize your dashboard\"\r\n                }}\r\n              </div>\r\n              <div class=\"twelvepx\">\r\n                <mat-select\r\n                  class=\"datamart-select\"\r\n                  [(ngModel)]=\"selectedDatamart\"\r\n                  (selectionChange)=\"changeDataTable($event.value)\"\r\n                >\r\n                  <ng-container *ngFor=\"let datatable of dataMartTableList\">\r\n                    <!-- *ngIf=\"!datatable.isHide\" -->\r\n                    <mat-option [value]=\"datatable.datamartCode\">\r\n                      {{\r\n                        translation[datatable.langCode] || datatable.langCode\r\n                      }}\r\n                    </mat-option>\r\n                  </ng-container>\r\n                </mat-select>\r\n              </div>\r\n            </div>\r\n          </div>\r\n          <div *ngIf=\"getFigurecode()\" (click)=\"nextWizard(2)\" class=\"wizard\">\r\n            <span class=\"wizard-name\"\r\n              >{{\r\n                translation.PORTLET_TYPE\r\n                  ? translation.PORTLET_TYPE\r\n                  : \".PORTLET_TYPE\"\r\n              }}*</span\r\n            >\r\n            <mat-icon class=\"wizard-icon\">{{\r\n              !expandArray[2] ? \"expand_more\" : \"expand_less\"\r\n            }}</mat-icon>\r\n          </div>\r\n          <!-- 图表类型选择 -->\r\n          <div\r\n            *ngIf=\"getFigurecode()\"\r\n            [ngClass]=\"{ collapsed: !expandArray[2] }\"\r\n            class=\"wizard-expanded portlets\"\r\n          >\r\n            <rs-portlet-type-new\r\n              [portlet]=\"portlet\"\r\n              [dashboard]=\"dashboard\"\r\n              [dataMartCode]=\"selectedDatamart\"\r\n              (portletType)=\"getPortletType($event)\"\r\n            >\r\n            </rs-portlet-type-new>\r\n          </div>\r\n\r\n          <!-- new dashboard 并且选择图标类型 才有的供三个图表选择的X轴Y轴 -->\r\n          <ng-container\r\n            *ngIf=\"\r\n              ['newcolumn', 'newline', 'newcolumnline'].includes(portletType)\r\n            \"\r\n          >\r\n            <div class=\"wizard\" (click)=\"nextWizard(7)\">\r\n              <span class=\"wizard-name\"\r\n                >{{ translation.CONFIGURATIONS || \".CONFIGURATIONS\" }}*</span\r\n              >\r\n              <mat-icon class=\"wizard-icon\">{{\r\n                !expandArray[7] ? \"expand_more\" : \"expand_less\"\r\n              }}</mat-icon>\r\n            </div>\r\n\r\n            <!-- 图标配置项 configuration -->\r\n            <div\r\n              [ngClass]=\"{ collapsed: !expandArray[7] }\"\r\n              class=\"wizard-expanded config\"\r\n            >\r\n              <div style=\"padding-left: 18px\">\r\n                <div style=\"margin-bottom: 10px\" class=\"twelvepx\">\r\n                  {{ translation.COLORS || \".COLORS\" }}\r\n                </div>\r\n\r\n                <ejs-dropdownlist\r\n                  style=\"margin-bottom: 10px\"\r\n                  id=\"employees\"\r\n                  [dataSource]=\"themeData\"\r\n                  [allowFiltering]=\"true\"\r\n                  [filterType]=\"'Contains'\"\r\n                  [itemTemplate]=\"itemTemplate\"\r\n                  [valueTemplate]=\"valueTemplate\"\r\n                  [fields]=\"themeFields\"\r\n                  [value]=\"selectTheme\"\r\n                  (change)=\"changeTheme($event, 'theme')\"\r\n                  class=\"color-ipt\"\r\n                >\r\n                  <ng-template #itemTemplate let-data>\r\n                    <div class=\"color-box\">\r\n                      <div\r\n                        *ngFor=\"let i of data.value\"\r\n                        class=\"color-item\"\r\n                        [ngStyle]=\"{\r\n                          'background-color': i\r\n                        }\"\r\n                      ></div>\r\n                    </div>\r\n                  </ng-template>\r\n                  <ng-template #valueTemplate let-data>\r\n                    <div class=\"color-box\">\r\n                      <div\r\n                        *ngFor=\"let item of data.value\"\r\n                        class=\"color-item\"\r\n                        [ngStyle]=\"{\r\n                          'background-color': item\r\n                        }\"\r\n                      ></div>\r\n                    </div>\r\n                  </ng-template>\r\n                </ejs-dropdownlist>\r\n\r\n                <div style=\"margin-bottom: 10px\" class=\"twelvepx\">\r\n                  {{ translation.X_AXIS || \".X-AXIS\" }}\r\n                </div>\r\n\r\n                <mat-select\r\n                  [(value)]=\"selectedX\"\r\n                  (openedChange)=\"xyChange($event)\"\r\n                  class=\"datamart-select\"\r\n                >\r\n                  <ng-container *ngFor=\"let i of yList\">\r\n                    <mat-option\r\n                      *ngIf=\"!i.isCalculatedField\"\r\n                      [value]=\"i.colName\"\r\n                      >{{\r\n                        (translation[i.langCode]\r\n                          ? translation[i.langCode]\r\n                          : \".\" + i.langCode) +\r\n                          (i.addtionName ? \" \" + i.addtionName : \"\")\r\n                      }}</mat-option\r\n                    >\r\n                  </ng-container>\r\n                </mat-select>\r\n\r\n                <ng-container *ngIf=\"selectedX\">\r\n                  <div style=\"margin-bottom: 10px\" class=\"twelvepx\">\r\n                    {{ translation.FREQUENCY || \".FREQUENCY\" }}\r\n                  </div>\r\n\r\n                  <mat-select\r\n                    [(value)]=\"selectedMultiples\"\r\n                    (openedChange)=\"xyChange($event)\"\r\n                    class=\"datamart-select\"\r\n                  >\r\n                    <mat-option\r\n                      *ngFor=\"let i of multiplesList\"\r\n                      [value]=\"i.langCode\"\r\n                      >{{\r\n                        i.addtionName\r\n                          ? i.addtionName + \"\" + translation[i.langCode]\r\n                          : translation[i.langCode]\r\n                      }}</mat-option\r\n                    >\r\n                  </mat-select>\r\n                </ng-container>\r\n\r\n                <div style=\"margin-bottom: 10px\" class=\"twelvepx\">\r\n                  {{\r\n                    portletType === \"newcolumnline\"\r\n                      ? (translation.COLUMN ? translation.COLUMN + \" \" : \"\") +\r\n                        (translation.Y_AXIS || \".COLUMN Y-AXIS\")\r\n                      : translation.Y_AXIS || \".Y-AXIS\"\r\n                  }}\r\n                </div>\r\n\r\n                <mat-select\r\n                  multiple\r\n                  [(value)]=\"selectedY\"\r\n                  (openedChange)=\"xyChange($event)\"\r\n                  class=\"datamart-select\"\r\n                >\r\n                  <ng-container *ngFor=\"let i of yList\">\r\n                    <mat-option\r\n                      *ngIf=\"!i.isCalculatedField\"\r\n                      [value]=\"i.colName\"\r\n                      >{{\r\n                        (translation[i.langCode]\r\n                          ? translation[i.langCode]\r\n                          : \".\" + i.langCode) +\r\n                          (i.addtionName ? \" \" + i.addtionName : \"\")\r\n                      }}</mat-option\r\n                    >\r\n                  </ng-container>\r\n                </mat-select>\r\n\r\n                <div\r\n                  style=\"margin-bottom: 10px\"\r\n                  class=\"twelvepx\"\r\n                  *ngIf=\"portletType == 'newcolumnline'\"\r\n                >\r\n                  {{\r\n                    (translation.LINE ? translation.LINE + \" \" : \"\") +\r\n                      (translation.Y_AXIS || \".LINE Y-AXIS\")\r\n                  }}\r\n                </div>\r\n\r\n                <mat-select\r\n                  multiple\r\n                  class=\"datamart-select\"\r\n                  [(value)]=\"selectedSecondY\"\r\n                  (openedChange)=\"xyChange($event)\"\r\n                  panelClass=\"mat-select-multi-panel\"\r\n                  *ngIf=\"portletType == 'newcolumnline'\"\r\n                >\r\n                  <ng-container *ngFor=\"let i of yList\">\r\n                    <mat-option\r\n                      *ngIf=\"!i.isCalculatedField\"\r\n                      [value]=\"i.colName\"\r\n                      >{{\r\n                        (translation[i.langCode]\r\n                          ? translation[i.langCode]\r\n                          : \".\" + i.langCode) +\r\n                          (i.addtionName ? \" \" + i.addtionName : \"\")\r\n                      }}</mat-option\r\n                    >\r\n                  </ng-container>\r\n                </mat-select>\r\n\r\n                <div class=\"data-label-content\">\r\n                  <div class=\"label\">\r\n                    {{ translation.DATA_LABEL || \".Data labels\" }}\r\n                  </div>\r\n                  <ejs-switch\r\n                    [(ngModel)]=\"hasMarker\"\r\n                    (ngModelChange)=\"labelConfigChange($event)\"\r\n                  ></ejs-switch>\r\n                </div>\r\n\r\n                <div style=\"margin: 10px 0\" class=\"twelvepx\">\r\n                  {{ translation.DISPLAY_UNITS || \".Display Units\" }}\r\n                </div>\r\n\r\n                <mat-select\r\n                  class=\"datamart-select\"\r\n                  [(ngModel)]=\"markerFormat\"\r\n                  (ngModelChange)=\"onChangeFormat()\"\r\n                >\r\n                  <ng-container *ngFor=\"let format of markerFormatList\">\r\n                    <mat-option [value]=\"format.value\">{{\r\n                      format.label\r\n                    }}</mat-option>\r\n                  </ng-container>\r\n                </mat-select>\r\n              </div>\r\n            </div>\r\n          </ng-container>\r\n\r\n          <!-- historical IRR 专用 -->\r\n          <ng-container *ngIf=\"['historicalIRR'].includes(portletType)\">\r\n            <div class=\"wizard\" (click)=\"nextWizard(7)\">\r\n              <span class=\"wizard-name\"\r\n                >{{ translation.CONFIGURATIONS || \"CONFIGURATIONS\" }}*</span\r\n              >\r\n              <mat-icon class=\"wizard-icon\">{{\r\n                !expandArray[7] ? \"expand_more\" : \"expand_less\"\r\n              }}</mat-icon>\r\n            </div>\r\n\r\n            <!-- 图标配置项 configuration -->\r\n            <div\r\n              [ngClass]=\"{ collapsed: !expandArray[7] }\"\r\n              class=\"wizard-expanded config\"\r\n            >\r\n              <div style=\"padding-left: 18px\">\r\n                <div style=\"margin-bottom: 10px\" class=\"twelvepx\">\r\n                  {{ translation.COLORS || \".COLORS\" }}\r\n                </div>\r\n\r\n                <ejs-dropdownlist\r\n                  style=\"margin-bottom: 10px\"\r\n                  id=\"employees\"\r\n                  [dataSource]=\"themeData\"\r\n                  [allowFiltering]=\"true\"\r\n                  [filterType]=\"'Contains'\"\r\n                  [itemTemplate]=\"itemTemplate\"\r\n                  [valueTemplate]=\"valueTemplate\"\r\n                  [fields]=\"themeFields\"\r\n                  [value]=\"selectTheme\"\r\n                  (change)=\"changeTheme($event, 'theme')\"\r\n                  class=\"color-ipt\"\r\n                >\r\n                  <ng-template #itemTemplate let-data>\r\n                    <div class=\"color-box\">\r\n                      <div\r\n                        *ngFor=\"let i of data.value\"\r\n                        class=\"color-item\"\r\n                        [ngStyle]=\"{\r\n                          'background-color': i\r\n                        }\"\r\n                      ></div>\r\n                    </div>\r\n                  </ng-template>\r\n                  <ng-template #valueTemplate let-data>\r\n                    <div class=\"color-box\">\r\n                      <div\r\n                        *ngFor=\"let item of data.value\"\r\n                        class=\"color-item\"\r\n                        [ngStyle]=\"{\r\n                          'background-color': item\r\n                        }\"\r\n                      ></div>\r\n                    </div>\r\n                  </ng-template>\r\n                </ejs-dropdownlist>\r\n\r\n                <div style=\"margin-bottom: 10px\" class=\"twelvepx\">\r\n                  {{ translation.FREQUENCY || \".FREQUENCY\" }}\r\n                </div>\r\n\r\n                <!-- Frequency: Yearly/Quarterly(default)/Monthly -->\r\n                <mat-select\r\n                  [(value)]=\"selectedMultiples\"\r\n                  (openedChange)=\"setHistoricalIRRChart($event)\"\r\n                  class=\"datamart-select\"\r\n                >\r\n                  <mat-option\r\n                    *ngFor=\"let i of frequencyOptions\"\r\n                    [value]=\"i.langCode\"\r\n                  >\r\n                    {{ (i.addtionName || \"\") + translation[i.langCode] }}\r\n                  </mat-option>\r\n                </mat-select>\r\n\r\n                <!-- Fund cashflow IRR ( fund ops settlement) 可选择 -->\r\n                <ng-container\r\n                  *ngIf=\"\r\n                    ['FundHistoricalCashflowIRR'].includes(selectedDatamart)\r\n                  \"\r\n                >\r\n                  <div style=\"margin-bottom: 10px\" class=\"twelvepx\">\r\n                    Investors\r\n                  </div>\r\n                  <!-- Investors: All/exclude GP&SLP -->\r\n                  <mat-select\r\n                    [(value)]=\"selectedInvestor\"\r\n                    (openedChange)=\"setHistoricalIRRChart($event)\"\r\n                    class=\"datamart-select\"\r\n                  >\r\n                    <mat-option\r\n                      *ngFor=\"let item of investorList\"\r\n                      [value]=\"item.code\"\r\n                    >\r\n                      {{ item.text }}\r\n                    </mat-option>\r\n                  </mat-select>\r\n                </ng-container>\r\n\r\n                <!-- line 和 bar 图 x 轴为 date，y 轴为 IRR 百分数 -->\r\n                <div style=\"margin-bottom: 10px\" class=\"twelvepx\">\r\n                  {{ translation.VISUAL_TYPE || \".VISUAL_TYPE\" }}\r\n                </div>\r\n                <!-- Visual Type: Line(default)/Column Chart/Table -->\r\n                <mat-select\r\n                  [(value)]=\"selectedVisualType\"\r\n                  (openedChange)=\"setHistoricalIRRChart($event)\"\r\n                  class=\"datamart-select\"\r\n                >\r\n                  <mat-option\r\n                    *ngFor=\"let item of visualTypeList\"\r\n                    [value]=\"item.code\"\r\n                  >\r\n                    {{ item.text }}\r\n                  </mat-option>\r\n                </mat-select>\r\n                <div\r\n                  class=\"data-label-content\"\r\n                  *ngIf=\"selectedVisualType !== 'table'\"\r\n                >\r\n                  <div class=\"label\">\r\n                    {{ translation.DATA_LABEL || \".Data labels\" }}\r\n                  </div>\r\n                  <ejs-switch\r\n                    [checked]=\"true\"\r\n                    [(ngModel)]=\"hasMarker\"\r\n                    (ngModelChange)=\"labelConfigChange($event)\"\r\n                  ></ejs-switch>\r\n                </div>\r\n              </div>\r\n            </div>\r\n          </ng-container>\r\n\r\n          <div class=\"wizard\" (click)=\"nextWizard(3)\">\r\n            <span class=\"wizard-name\"\r\n              >{{\r\n                translation.GENERAL_OPTIONS\r\n                  ? translation.GENERAL_OPTIONS\r\n                  : \".GENERAL_OPTIONS\"\r\n              }}*</span\r\n            >\r\n            <mat-icon class=\"wizard-icon\">{{\r\n              !expandArray[3] ? \"expand_more\" : \"expand_less\"\r\n            }}</mat-icon>\r\n          </div>\r\n          <div\r\n            class=\"dialog-content\"\r\n            [ngClass]=\"{ collapsed: !expandArray[3] }\"\r\n            *ngIf=\"portletType !== 'newchart'\"\r\n          >\r\n            <div class=\"condition-item\">\r\n              <div class=\"title\">\r\n                {{ translation.GADGET_TITLE || \".GADGET_TITLE\" }}\r\n              </div>\r\n              <input\r\n                matInput\r\n                #message\r\n                maxlength=\"256\"\r\n                (ngModelChange)=\"gadgetTitleChange($event)\"\r\n                [(ngModel)]=\"config.gadgetTitle\"\r\n                autocomplete=\"off\"\r\n              />\r\n            </div>\r\n          </div>\r\n          <div\r\n            class=\"dialog-content\"\r\n            [ngClass]=\"{ collapsed: !expandArray[3] }\"\r\n            *ngIf=\"portletType === 'newchart'\"\r\n          >\r\n            <div class=\"condition-item\">\r\n              <div class=\"title\">\r\n                {{ translation.GADGET_TITLE || \".GADGET_TITLE\" }}\r\n              </div>\r\n              <input\r\n                matInput\r\n                #message\r\n                maxlength=\"256\"\r\n                (ngModelChange)=\"gadgetTitleChange($event)\"\r\n                [(ngModel)]=\"config.gadgetTitle\"\r\n                autocomplete=\"off\"\r\n              />\r\n            </div>\r\n            <div class=\"condition-item\">\r\n              <div class=\"title\">\r\n                {{ translation.CHARTTYPE || \".CHARTTYPE\" }}\r\n              </div>\r\n              <mat-select\r\n                [placeholder]=\"translation.SELECT_A_TYPE || 'Select a type'\"\r\n                [(ngModel)]=\"chartSettings.chartSeries.type\"\r\n                (selectionChange)=\"setChartType()\"\r\n              >\r\n                <mat-option *ngFor=\"let item of chartTypeList\" [value]=\"item\">\r\n                  {{ translation[\"chart_\" + item] || item }}\r\n                </mat-option>\r\n              </mat-select>\r\n            </div>\r\n            <div class=\"condition-item flex\">\r\n              <ejs-checkbox\r\n                [label]=\"translation.MULTIPLE_AXIS || '.MULTIPLE_AXIS'\"\r\n                [(ngModel)]=\"chartSettings.enableMultipleAxis\"\r\n                (change)=\"setMultipleAxis($event)\"\r\n              ></ejs-checkbox>\r\n              <ejs-checkbox\r\n                [disabled]=\"!chartSettings.enableMultipleAxis\"\r\n                [label]=\"translation.SHOW_LEGEND || '.SHOW_LEGEND'\"\r\n                (change)=\"setMultipleAxis($event)\"\r\n                [(ngModel)]=\"chartSettings.legendSettings.visible\"\r\n              ></ejs-checkbox>\r\n            </div>\r\n            <div class=\"condition-item\">\r\n              <div class=\"title\">\r\n                {{ translation.MULTIPLE_AXIS_MODE || \".MULTIPLE_AXIS_MODE\" }}\r\n              </div>\r\n              <mat-select\r\n                [placeholder]=\"translation.SELECT_A_MODE || '.SELECT_A_MODE'\"\r\n                (selectionChange)=\"setMultipleAxis($event.value)\"\r\n                [(ngModel)]=\"chartSettings.multipleAxisMode\"\r\n                [disabled]=\"!chartSettings.enableMultipleAxis\"\r\n              >\r\n                <mat-option\r\n                  *ngFor=\"let item of multipleAxisModeList\"\r\n                  [value]=\"item\"\r\n                >\r\n                  {{ translation[\"chart_\" + item] || item }}\r\n                </mat-option>\r\n              </mat-select>\r\n            </div>\r\n            <div class=\"condition-item\">\r\n              <div class=\"title\">\r\n                {{ translation.COLORS || \".COLORS\" }}\r\n              </div>\r\n\r\n              <ejs-dropdownlist\r\n                id=\"employees\"\r\n                [dataSource]=\"themeData\"\r\n                [allowFiltering]=\"true\"\r\n                [filterType]=\"'Contains'\"\r\n                [itemTemplate]=\"itemTemplate\"\r\n                [valueTemplate]=\"valueTemplate\"\r\n                [fields]=\"themeFields\"\r\n                [value]=\"selectTheme\"\r\n                (change)=\"getThemeData($event)\"\r\n                class=\"color-ipt\"\r\n              >\r\n                <ng-template #itemTemplate let-data>\r\n                  <div class=\"color-box\">\r\n                    <div\r\n                      *ngFor=\"let i of data.value\"\r\n                      class=\"color-item\"\r\n                      [ngStyle]=\"{\r\n                        'background-color': i\r\n                      }\"\r\n                    ></div>\r\n                  </div>\r\n                </ng-template>\r\n                <ng-template #valueTemplate let-data>\r\n                  <div class=\"color-box\">\r\n                    <div\r\n                      *ngFor=\"let item of data.value\"\r\n                      class=\"color-item\"\r\n                      [ngStyle]=\"{\r\n                        'background-color': item\r\n                      }\"\r\n                    ></div>\r\n                  </div>\r\n                </ng-template>\r\n              </ejs-dropdownlist>\r\n            </div>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </div>\r\n    <!-- </form> -->\r\n    <div class=\"footer-btn\">\r\n      <button type=\"button\" mat-flat-button class=\"btn-close\" (click)=\"clear()\">\r\n        {{ translation.CLEAR ? translation.CLEAR : \"Clear\" }}\r\n      </button>\r\n      <button type=\"button\" mat-flat-button class=\"btn-save\" (click)=\"close()\">\r\n        {{ translation.CLOSE ? translation.CLOSE : \".CLOSE\" }}\r\n      </button>\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}
|