raise-common-lib-new 0.0.63 → 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.
Files changed (221) hide show
  1. package/esm2022/lib/actions/toolbar/index.component.mjs +4 -3
  2. package/esm2022/lib/actions/toolbar-item/index.component.mjs +2 -2
  3. package/esm2022/lib/common-grid/grid-action/grid-action-item/grid-action-item.component.mjs +1 -1
  4. package/esm2022/lib/common-grid/grid-action/grid-action.component.mjs +3 -2
  5. package/esm2022/lib/common-grid/index.component.mjs +6 -3
  6. package/esm2022/lib/dashboard/api.mjs +33 -0
  7. package/esm2022/lib/dashboard/bar-charts/bar-charts.component.mjs +430 -0
  8. package/esm2022/lib/dashboard/bar-charts/utils.mjs +18 -0
  9. package/esm2022/lib/dashboard/dashboard-properties/data-mart-new/data-mart-new.component.mjs +442 -0
  10. package/esm2022/lib/dashboard/dashboard.service.mjs +295 -0
  11. package/esm2022/lib/dashboard/dashboardPorlets.service.mjs +2169 -0
  12. package/esm2022/lib/dashboard/dialog-group/download/index.component.mjs +212 -0
  13. package/esm2022/lib/dashboard/dialog-group/empty-icon-prompt/empty-icon-prompt.component.mjs +36 -0
  14. package/esm2022/lib/dashboard/gadget-group/gadget-pivot/gadget-pivot.component.mjs +3211 -0
  15. package/esm2022/lib/dashboard/gadget-group/gadget-pivot-chart/gadget-pivot.component.mjs +3117 -0
  16. package/esm2022/lib/dashboard/gadget-group/gadget-table/gadget-table.component.mjs +1099 -0
  17. package/esm2022/lib/dashboard/gadget-group/gadget-transpose/gadget-transpose.component.mjs +583 -0
  18. package/esm2022/lib/dashboard/pane-group-new.component.mjs +2031 -0
  19. package/esm2022/lib/dashboard/sidebar-iconlist/field-filter/field-filter.component.mjs +637 -0
  20. package/esm2022/lib/dashboard/sidebar-iconlist/field-format/field-format.component.mjs +753 -0
  21. package/esm2022/lib/dashboard/sidebar-iconlist/portlet-type-new/portlet-type-new.component.mjs +216 -0
  22. package/esm2022/lib/dashboard/sidebar-iconlist/sidebar-iconlist-new.component.mjs +1239 -0
  23. package/esm2022/lib/dialog/common-delete-dialog/index.component.mjs +1 -1
  24. package/esm2022/lib/dialog/common-dialog/index.component.mjs +16 -5
  25. package/esm2022/lib/float-box/index.component.mjs +18 -4
  26. package/esm2022/lib/form/checkbox-group/index.component.mjs +35 -5
  27. package/esm2022/lib/form/drawer-form/drawer-form.component.mjs +177 -76
  28. package/esm2022/lib/layout/drawer/index.component.mjs +2 -2
  29. package/esm2022/lib/layout/page-list/index.component.mjs +9 -3
  30. package/esm2022/lib/layout/page-tab/index.component.mjs +5 -3
  31. package/esm2022/lib/layout/rs-stepper/constants.mjs +2 -0
  32. package/esm2022/lib/layout/rs-stepper/index.component.mjs +148 -0
  33. package/esm2022/lib/raise-common-lib.module.mjs +114 -7
  34. package/esm2022/lib/service/InjectionToken.mjs +5 -0
  35. package/esm2022/lib/service/keep-alive.service.mjs +2 -2
  36. package/esm2022/lib/smart-popup/index.component.mjs +1084 -0
  37. package/esm2022/public-api.mjs +19 -1
  38. package/fesm2022/raise-common-lib-new.mjs +18037 -220
  39. package/fesm2022/raise-common-lib-new.mjs.map +1 -1
  40. package/lib/common-grid/index.component.d.ts +2 -1
  41. package/lib/dashboard/api.d.ts +24 -0
  42. package/lib/dashboard/bar-charts/bar-charts.component.d.ts +63 -0
  43. package/lib/dashboard/bar-charts/utils.d.ts +1 -0
  44. package/lib/dashboard/dashboard-properties/data-mart-new/data-mart-new.component.d.ts +52 -0
  45. package/lib/dashboard/dashboard.service.d.ts +152 -0
  46. package/lib/dashboard/dashboardPorlets.service.d.ts +214 -0
  47. package/lib/dashboard/dialog-group/download/index.component.d.ts +36 -0
  48. package/lib/dashboard/dialog-group/empty-icon-prompt/empty-icon-prompt.component.d.ts +15 -0
  49. package/lib/dashboard/gadget-group/gadget-pivot/gadget-pivot.component.d.ts +128 -0
  50. package/lib/dashboard/gadget-group/gadget-pivot-chart/gadget-pivot.component.d.ts +131 -0
  51. package/lib/dashboard/gadget-group/gadget-table/gadget-table.component.d.ts +77 -0
  52. package/lib/dashboard/gadget-group/gadget-transpose/gadget-transpose.component.d.ts +47 -0
  53. package/lib/dashboard/pane-group-new.component.d.ts +169 -0
  54. package/lib/dashboard/sidebar-iconlist/field-filter/field-filter.component.d.ts +56 -0
  55. package/lib/dashboard/sidebar-iconlist/field-format/field-format.component.d.ts +62 -0
  56. package/lib/dashboard/sidebar-iconlist/portlet-type-new/portlet-type-new.component.d.ts +30 -0
  57. package/lib/dashboard/sidebar-iconlist/sidebar-iconlist-new.component.d.ts +150 -0
  58. package/lib/dialog/common-dialog/index.component.d.ts +3 -1
  59. package/lib/float-box/index.component.d.ts +4 -3
  60. package/lib/form/checkbox-group/index.component.d.ts +5 -0
  61. package/lib/form/drawer-form/drawer-form.component.d.ts +21 -8
  62. package/lib/layout/page-list/index.component.d.ts +3 -1
  63. package/lib/layout/page-tab/index.component.d.ts +1 -0
  64. package/lib/layout/rs-stepper/constants.d.ts +5 -0
  65. package/lib/layout/rs-stepper/index.component.d.ts +31 -0
  66. package/lib/raise-common-lib.module.d.ts +61 -40
  67. package/lib/service/InjectionToken.d.ts +4 -0
  68. package/lib/smart-popup/index.component.d.ts +60 -0
  69. package/package.json +1 -1
  70. package/public-api.d.ts +18 -0
  71. package/src/assets/img/dashboard_icon/AddPerson.svg +4 -0
  72. package/src/assets/img/dashboard_icon/Angle-double-left.svg +12 -0
  73. package/src/assets/img/dashboard_icon/Angle-double-right.svg +12 -0
  74. package/src/assets/img/dashboard_icon/Arrow_collapse.svg +3 -0
  75. package/src/assets/img/dashboard_icon/Arrow_expand.svg +3 -0
  76. package/src/assets/img/dashboard_icon/Close.svg +4 -0
  77. package/src/assets/img/dashboard_icon/Edit_label.svg +3 -0
  78. package/src/assets/img/dashboard_icon/RemoveMini.svg +3 -0
  79. package/src/assets/img/dashboard_icon/ShareTo.svg +3 -0
  80. package/src/assets/img/dashboard_icon/add-dashboard.svg +4 -0
  81. package/src/assets/img/dashboard_icon/add-tab.svg +4 -0
  82. package/src/assets/img/dashboard_icon/angle-left.svg +12 -0
  83. package/src/assets/img/dashboard_icon/angle-right.svg +12 -0
  84. package/src/assets/img/dashboard_icon/area-white.svg +3 -0
  85. package/src/assets/img/dashboard_icon/area.svg +3 -0
  86. package/src/assets/img/dashboard_icon/bar-white.svg +14 -0
  87. package/src/assets/img/dashboard_icon/bar.svg +14 -0
  88. package/src/assets/img/dashboard_icon/basic-icon-filter.svg +14 -0
  89. package/src/assets/img/dashboard_icon/chart-combined-active.svg +7 -0
  90. package/src/assets/img/dashboard_icon/chart-combined.svg +7 -0
  91. package/src/assets/img/dashboard_icon/column-white.svg +14 -0
  92. package/src/assets/img/dashboard_icon/column.svg +26 -0
  93. package/src/assets/img/dashboard_icon/customize.png +0 -0
  94. package/src/assets/img/dashboard_icon/dashboard-description.svg +18 -0
  95. package/src/assets/img/dashboard_icon/dashboard-download.svg +18 -0
  96. package/src/assets/img/dashboard_icon/dashboard-drag.svg +28 -0
  97. package/src/assets/img/dashboard_icon/dashboard-duplicate.svg +24 -0
  98. package/src/assets/img/dashboard_icon/dashboard-icon.svg +12 -0
  99. package/src/assets/img/dashboard_icon/dashboard-properties.svg +18 -0
  100. package/src/assets/img/dashboard_icon/dashboard-rename.svg +18 -0
  101. package/src/assets/img/dashboard_icon/dashboard-share.svg +20 -0
  102. package/src/assets/img/dashboard_icon/dashboard-tab-delete.svg +4 -0
  103. package/src/assets/img/dashboard_icon/dashboard_Share.svg +3 -0
  104. package/src/assets/img/dashboard_icon/dashboard_ToolsHide.svg +4 -0
  105. package/src/assets/img/dashboard_icon/datamart_.svg +5 -0
  106. package/src/assets/img/dashboard_icon/datamart_Admin.svg +3 -0
  107. package/src/assets/img/dashboard_icon/datamart_Asset Portfolio.svg +4 -0
  108. package/src/assets/img/dashboard_icon/datamart_Bank.svg +3 -0
  109. package/src/assets/img/dashboard_icon/datamart_CRM.svg +6 -0
  110. package/src/assets/img/dashboard_icon/datamart_Company.svg +6 -0
  111. package/src/assets/img/dashboard_icon/datamart_Compliance.svg +3 -0
  112. package/src/assets/img/dashboard_icon/datamart_Contact.svg +3 -0
  113. package/src/assets/img/dashboard_icon/datamart_DASHBOARD.svg +4 -0
  114. package/src/assets/img/dashboard_icon/datamart_DOCX.svg +4 -0
  115. package/src/assets/img/dashboard_icon/datamart_ESG.svg +4 -0
  116. package/src/assets/img/dashboard_icon/datamart_Financials - Company.svg +3 -0
  117. package/src/assets/img/dashboard_icon/datamart_Fund.svg +4 -0
  118. package/src/assets/img/dashboard_icon/datamart_FundFinancial.svg +4 -0
  119. package/src/assets/img/dashboard_icon/datamart_HTML.svg +4 -0
  120. package/src/assets/img/dashboard_icon/datamart_Logs.svg +8 -0
  121. package/src/assets/img/dashboard_icon/datamart_PDF.svg +5 -0
  122. package/src/assets/img/dashboard_icon/datamart_Project.svg +3 -0
  123. package/src/assets/img/dashboard_icon/datamart_Templates.svg +7 -0
  124. package/src/assets/img/dashboard_icon/datamart_Track Change.svg +3 -0
  125. package/src/assets/img/dashboard_icon/datamart_VirtualGroup.svg +5 -0
  126. package/src/assets/img/dashboard_icon/datamart_XLS.svg +4 -0
  127. package/src/assets/img/dashboard_icon/desktop_selected.svg +10 -0
  128. package/src/assets/img/dashboard_icon/desktop_unselected.svg +10 -0
  129. package/src/assets/img/dashboard_icon/favourite-grey.svg +3 -0
  130. package/src/assets/img/dashboard_icon/favourite-yellow.svg +3 -0
  131. package/src/assets/img/dashboard_icon/forms-checkbox-square-tick.svg +3 -0
  132. package/src/assets/img/dashboard_icon/ftable-white.svg +24 -0
  133. package/src/assets/img/dashboard_icon/ftable.svg +24 -0
  134. package/src/assets/img/dashboard_icon/gadget-basic-arrow-down.svg +14 -0
  135. package/src/assets/img/dashboard_icon/gadget-basic-format.svg +21 -0
  136. package/src/assets/img/dashboard_icon/gadget-basic-sub-total.svg +18 -0
  137. package/src/assets/img/dashboard_icon/gadget-basic-total-1.svg +9 -0
  138. package/src/assets/img/dashboard_icon/gadget-basic-total.svg +16 -0
  139. package/src/assets/img/dashboard_icon/gadget-columns.svg +12 -0
  140. package/src/assets/img/dashboard_icon/gadget-delete.svg +18 -0
  141. package/src/assets/img/dashboard_icon/gadget-download.svg +18 -0
  142. package/src/assets/img/dashboard_icon/gadget-duplicate.svg +24 -0
  143. package/src/assets/img/dashboard_icon/gadget-edit.svg +18 -0
  144. package/src/assets/img/dashboard_icon/gadget-filters-light.svg +9 -0
  145. package/src/assets/img/dashboard_icon/gadget-filters.svg +9 -0
  146. package/src/assets/img/dashboard_icon/gadget-format-0.svg +8 -0
  147. package/src/assets/img/dashboard_icon/gadget-format-1.svg +8 -0
  148. package/src/assets/img/dashboard_icon/gadget-format.svg +19 -0
  149. package/src/assets/img/dashboard_icon/gadget-fullscreen.svg +30 -0
  150. package/src/assets/img/dashboard_icon/gadget-settings.svg +18 -0
  151. package/src/assets/img/dashboard_icon/gadget-sub-total-0.svg +18 -0
  152. package/src/assets/img/dashboard_icon/gadget-sub-total-1.svg +18 -0
  153. package/src/assets/img/dashboard_icon/gadget-thumbnail.svg +12 -0
  154. package/src/assets/img/dashboard_icon/gadget-type-light.svg +15 -0
  155. package/src/assets/img/dashboard_icon/gadget-type.svg +16 -0
  156. package/src/assets/img/dashboard_icon/geo-white.svg +14 -0
  157. package/src/assets/img/dashboard_icon/geo.svg +14 -0
  158. package/src/assets/img/dashboard_icon/historic-IRR-white.svg +9 -0
  159. package/src/assets/img/dashboard_icon/historic-IRR.svg +5 -0
  160. package/src/assets/img/dashboard_icon/information-1.png +0 -0
  161. package/src/assets/img/dashboard_icon/information-grey.svg +4 -0
  162. package/src/assets/img/dashboard_icon/menu-change-group.svg +3 -0
  163. package/src/assets/img/dashboard_icon/menu-close.svg +20 -0
  164. package/src/assets/img/dashboard_icon/menu-delete.svg +18 -0
  165. package/src/assets/img/dashboard_icon/menu-description.svg +19 -0
  166. package/src/assets/img/dashboard_icon/menu-download.svg +24 -0
  167. package/src/assets/img/dashboard_icon/menu-drag.svg +28 -0
  168. package/src/assets/img/dashboard_icon/menu-duplicate.svg +26 -0
  169. package/src/assets/img/dashboard_icon/menu-properties.svg +18 -0
  170. package/src/assets/img/dashboard_icon/menu-rename.svg +23 -0
  171. package/src/assets/img/dashboard_icon/menu-share.svg +20 -0
  172. package/src/assets/img/dashboard_icon/menu-toolbar.svg +10 -0
  173. package/src/assets/img/dashboard_icon/mobile_selected.svg +10 -0
  174. package/src/assets/img/dashboard_icon/mobile_unselected.svg +10 -0
  175. package/src/assets/img/dashboard_icon/more_Save.svg +3 -0
  176. package/src/assets/img/dashboard_icon/more_View.svg +3 -0
  177. package/src/assets/img/dashboard_icon/multi-series-white.svg +20 -0
  178. package/src/assets/img/dashboard_icon/multi-series.svg +6 -0
  179. package/src/assets/img/dashboard_icon/paint-bucket.svg +6 -0
  180. package/src/assets/img/dashboard_icon/pie-white.svg +16 -0
  181. package/src/assets/img/dashboard_icon/pie.svg +16 -0
  182. package/src/assets/img/dashboard_icon/pivot-chart-active.svg +8 -0
  183. package/src/assets/img/dashboard_icon/pivot-chart.svg +8 -0
  184. package/src/assets/img/dashboard_icon/pivot-white.svg +8 -0
  185. package/src/assets/img/dashboard_icon/pivot.svg +8 -0
  186. package/src/assets/img/dashboard_icon/pivot_column.svg +9 -0
  187. package/src/assets/img/dashboard_icon/pivot_column_active.svg +9 -0
  188. package/src/assets/img/dashboard_icon/pivot_line.svg +12 -0
  189. package/src/assets/img/dashboard_icon/pivot_line_active.svg +12 -0
  190. package/src/assets/img/dashboard_icon/print-A2.svg +3 -0
  191. package/src/assets/img/dashboard_icon/radar-white.svg +19 -0
  192. package/src/assets/img/dashboard_icon/radar.svg +19 -0
  193. package/src/assets/img/dashboard_icon/saveAs.svg +3 -0
  194. package/src/assets/img/dashboard_icon/search_input.svg +4 -0
  195. package/src/assets/img/dashboard_icon/table-3-white.svg +16 -0
  196. package/src/assets/img/dashboard_icon/table-3.svg +16 -0
  197. package/src/assets/img/dashboard_icon/table-filter-off.svg +5 -0
  198. package/src/assets/img/dashboard_icon/table-filter-on.svg +5 -0
  199. package/src/assets/img/dashboard_icon/tag_dashboard_selected.svg +3 -0
  200. package/src/assets/img/dashboard_icon/tag_dashboard_unselected.svg +3 -0
  201. package/src/assets/img/dashboard_icon/tag_share_selected.svg +3 -0
  202. package/src/assets/img/dashboard_icon/tag_share_unselected.svg +3 -0
  203. package/src/assets/img/dashboard_icon/tick.svg +26 -0
  204. package/src/assets/img/dashboard_icon/toolbar_AddDashboard.svg +5 -0
  205. package/src/assets/img/dashboard_icon/toolbar_AddGroup.svg +3 -0
  206. package/src/assets/img/dashboard_icon/toolbar_AddReport.svg +3 -0
  207. package/src/assets/img/dashboard_icon/toolbar_CollapseAll.svg +3 -0
  208. package/src/assets/img/dashboard_icon/toolbar_Customize.svg +3 -0
  209. package/src/assets/img/dashboard_icon/toolbar_DeleteDark.svg +3 -0
  210. package/src/assets/img/dashboard_icon/toolbar_Duplicate.svg +3 -0
  211. package/src/assets/img/dashboard_icon/toolbar_Edit.svg +3 -0
  212. package/src/assets/img/dashboard_icon/toolbar_ExpandAll.svg +3 -0
  213. package/src/assets/img/dashboard_icon/toolbar_Search.svg +3 -0
  214. package/src/assets/img/dashboard_icon/topbar-menu.svg +33 -0
  215. package/src/assets/img/dashboard_icon/topbar-refresh.svg +17 -0
  216. package/src/assets/img/dashboard_icon/topbar-tool-off.svg +12 -0
  217. package/src/assets/img/dashboard_icon/topbar-tool-on.svg +12 -0
  218. package/src/assets/img/dashboard_icon/trade-up-white.svg +14 -0
  219. package/src/assets/img/dashboard_icon/trade-up.svg +14 -0
  220. package/src/assets/img/dashboard_icon/transpose-white.svg +16 -0
  221. 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"]}