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,1099 @@
1
+ import { Component, Input, ViewChild, Inject, Optional, } from "@angular/core";
2
+ import { ExcelExportService, ColumnChooserService, VirtualScrollService, FilterService, ResizeService, } from "@syncfusion/ej2-angular-grids";
3
+ import { DataUtil } from "@syncfusion/ej2-data";
4
+ import { API_SERVICE_TOKEN, PBF_TOKEN } from "../../../service/InjectionToken";
5
+ import moment from "moment";
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "../../dashboardPorlets.service";
8
+ import * as i2 from "../../api";
9
+ import * as i3 from "../../dashboard.service";
10
+ import * as i4 from "@angular/common";
11
+ import * as i5 from "@syncfusion/ej2-angular-grids";
12
+ import * as i6 from "@syncfusion/ej2-angular-charts";
13
+ export class GadgetTableComponent {
14
+ dashboardPorletsService;
15
+ api;
16
+ ref;
17
+ dashboardService;
18
+ el;
19
+ pbf;
20
+ http;
21
+ portlet;
22
+ dashboard;
23
+ portlets;
24
+ grid;
25
+ pager;
26
+ config;
27
+ translation;
28
+ userInfo;
29
+ datePipeFormat;
30
+ filterSettings;
31
+ filter;
32
+ data;
33
+ tableList;
34
+ tableList_footer = [];
35
+ formatSettings = [];
36
+ toolbarOptions;
37
+ options;
38
+ aggregates;
39
+ subscriptions = [];
40
+ // 已经保存过的列数据配置
41
+ configFields = [];
42
+ quarterFormat;
43
+ formatDates = [];
44
+ ColumnChooserSettings;
45
+ millionFields = [];
46
+ // Pager
47
+ currentPage = 1; // 当前页数
48
+ pageSize = 10; // 一页显示行数
49
+ totalRecordsCount; // 总行数
50
+ filterContents; // 所有可以过滤的选项
51
+ sort; // 0表示降序 1表示升序
52
+ sortedColumn; // sort的列名
53
+ pageLoading;
54
+ currentFilterField; // 当前过滤的字段;
55
+ allFields;
56
+ hideTable;
57
+ constructor(dashboardPorletsService, api, ref, dashboardService, el, pbf, http) {
58
+ this.dashboardPorletsService = dashboardPorletsService;
59
+ this.api = api;
60
+ this.ref = ref;
61
+ this.dashboardService = dashboardService;
62
+ this.el = el;
63
+ this.pbf = pbf;
64
+ this.http = http;
65
+ }
66
+ ngOnInit() {
67
+ this.getInfo();
68
+ this.filterSettings = { type: "Menu" };
69
+ this.ColumnChooserSettings = { operator: "contains" };
70
+ this.filter = { type: "CheckBox" };
71
+ this.toolbarOptions = ["ColumnChooser"];
72
+ this.options = { pageSize: 10, pageSizes: ["10", "50", "100"] };
73
+ this.quarterFormat = this.setQuarterFormat();
74
+ this.getTableData();
75
+ }
76
+ ngAfterViewInit() {
77
+ this.subscriptions.push(this.dashboardService.getchangeTable().subscribe((updated) => {
78
+ if (updated) {
79
+ this.pageSize = 10;
80
+ this.currentPage = 1;
81
+ this.getTableData();
82
+ }
83
+ }));
84
+ this.subscriptions.push(this.dashboardService.getRefreshGadget().subscribe((e) => {
85
+ if (!e) {
86
+ return;
87
+ }
88
+ const id = e["newId"];
89
+ if (id === this.portlet.newId || id === this.portlet.id) {
90
+ this.pageSize = 10;
91
+ this.currentPage = 1;
92
+ this.getTableData();
93
+ }
94
+ }));
95
+ this.subscriptions.push(this.dashboardService.getStartRefresh().subscribe((dashboardId) => {
96
+ if (dashboardId === this.dashboard.id) {
97
+ this.pageLoading = true;
98
+ this.ref.markForCheck();
99
+ }
100
+ }));
101
+ this.subscriptions.push(this.dashboardService.getUpdated().subscribe((newId) => {
102
+ if (newId === this.portlet.newId || newId === this.portlet.id) {
103
+ this.pageSize = 10;
104
+ this.currentPage = 1;
105
+ this.getTableData();
106
+ if (this.grid) {
107
+ this.grid.columns.forEach((item) => {
108
+ this.tableList.forEach((table) => {
109
+ if (item.field === table.colName &&
110
+ table.format &&
111
+ table.format.length &&
112
+ table.format[0].formatChecked) {
113
+ item.headerText =
114
+ table.displayName ||
115
+ table.langValue ||
116
+ this.translation[table.langCode] ||
117
+ table.langCode;
118
+ if (["number", "percent"].includes(table.dataType)) {
119
+ let formatString;
120
+ if (table.dataType === "number") {
121
+ formatString =
122
+ this.pbf.formatNumber(table.format[0]
123
+ .selectedFormat);
124
+ }
125
+ else if (table.dataType === "percent") {
126
+ formatString =
127
+ this.pbf.formatPercent(table.format[0]
128
+ .selectedFormat);
129
+ }
130
+ item.format = formatString;
131
+ }
132
+ }
133
+ });
134
+ });
135
+ }
136
+ // this.grid.refreshColumns();
137
+ }
138
+ }));
139
+ this.subscriptions.push(this.dashboardService.getTableFormat().subscribe((data) => {
140
+ if (data === this.portlet.newId) {
141
+ this.getTableData();
142
+ this.grid.columns.forEach((item) => {
143
+ this.tableList.forEach((table) => {
144
+ if (item.field === table.colName &&
145
+ table.format &&
146
+ table.format.length &&
147
+ table.format[0].formatChecked) {
148
+ item.headerText =
149
+ table.displayName ||
150
+ table.langValue ||
151
+ this.translation[table.langCode] ||
152
+ table.langCode;
153
+ if (["number", "percent"].includes(table.dataType)) {
154
+ let formatString;
155
+ if (table.dataType === "number") {
156
+ formatString = this.pbf.formatNumber(table.format[0].selectedFormat);
157
+ }
158
+ else if (table.dataType === "percent") {
159
+ formatString = this.pbf.formatPercent(table.format[0].selectedFormat);
160
+ }
161
+ item.format = formatString;
162
+ }
163
+ }
164
+ });
165
+ });
166
+ this.hideTable = true;
167
+ this.pageLoading = true;
168
+ this.ref.markForCheck();
169
+ setTimeout(() => {
170
+ this.hideTable = false;
171
+ this.pageLoading = false;
172
+ this.ref.markForCheck();
173
+ }, 300);
174
+ }
175
+ }));
176
+ }
177
+ ngOnDestroy() {
178
+ this.subscriptions.forEach((sub) => sub.unsubscribe());
179
+ }
180
+ customiseCell(args) {
181
+ if (args.column.type === "date" || args.column.type === "dateTime") {
182
+ const { field } = args.column;
183
+ if (!args.data[field]) {
184
+ args.column.type = "string";
185
+ args.column.format = "";
186
+ }
187
+ }
188
+ let queryCell = this.tableList &&
189
+ this.tableList.filter((item) => item.colName === args.column.field)[0];
190
+ if (queryCell &&
191
+ queryCell.format &&
192
+ queryCell.format.length &&
193
+ queryCell.format[0].formatChecked) {
194
+ // SMP2-3416 0的format start
195
+ if ([2, 5, 8, 11, 14, 17].includes(queryCell.format[0].selectedFormat) &&
196
+ args.data[queryCell.colName] === 0)
197
+ args.cell.innerHTML = "-";
198
+ if ([3, 6, 9, 12, 15, 18].includes(queryCell.format[0].selectedFormat) &&
199
+ args.data[queryCell.colName] === 0)
200
+ args.cell.innerHTML = "";
201
+ // SMP2-3416 0的format end
202
+ }
203
+ if (queryCell &&
204
+ queryCell.format &&
205
+ queryCell.format.length &&
206
+ queryCell.format[0].fontSettingChecked) {
207
+ if (queryCell.format[0].formatChecked &&
208
+ queryCell.format[0].compareSelect) {
209
+ let cellData = args.data[args.column.field];
210
+ let condition = false;
211
+ switch (queryCell.format[0].compareSelect) {
212
+ case "LessThan":
213
+ condition =
214
+ cellData <
215
+ Number(queryCell.format[0].compareValue1);
216
+ break;
217
+ case "LessThanOrEqualTo":
218
+ condition =
219
+ cellData <=
220
+ Number(queryCell.format[0].compareValue1);
221
+ break;
222
+ case "GreaterThan":
223
+ condition =
224
+ cellData >
225
+ Number(queryCell.format[0].compareValue1);
226
+ break;
227
+ case "GreaterThanOrEqualTo":
228
+ condition =
229
+ cellData >=
230
+ Number(queryCell.format[0].compareValue1);
231
+ break;
232
+ case "Equals":
233
+ condition =
234
+ cellData ===
235
+ Number(queryCell.format[0].compareValue1);
236
+ break;
237
+ case "NotEquals":
238
+ condition =
239
+ cellData !==
240
+ Number(queryCell.format[0].compareValue1);
241
+ break;
242
+ case "Between":
243
+ condition =
244
+ cellData >=
245
+ Number(queryCell.format[0].compareValue1) &&
246
+ cellData <= queryCell.format[0].compareValue2;
247
+ break;
248
+ case "NotBetween":
249
+ condition =
250
+ cellData <
251
+ Number(queryCell.format[0].compareValue1) &&
252
+ cellData >
253
+ Number(queryCell.format[0].compareValue2);
254
+ break;
255
+ default:
256
+ break;
257
+ }
258
+ if (condition)
259
+ this.cellAddStyle(args, queryCell);
260
+ }
261
+ else
262
+ this.cellAddStyle(args, queryCell);
263
+ }
264
+ // date format about quarterly
265
+ let dateFields = this.formatDates &&
266
+ this.formatDates.map((el) => {
267
+ return el.name;
268
+ });
269
+ if (args.column.field &&
270
+ dateFields &&
271
+ dateFields.includes(args.column.field) &&
272
+ queryCell.format &&
273
+ queryCell.format.length &&
274
+ queryCell.format[0].formatChecked) {
275
+ let date = new Date(args.data[args.column.field]);
276
+ let quarter = Math.floor((date.getMonth() + 1) % 3) == 0
277
+ ? Math.floor((date.getMonth() + 1) / 3)
278
+ : Math.floor((date.getMonth() + 1) / 3) + 1;
279
+ let format;
280
+ this.formatDates.map((el) => {
281
+ if (el.name == args.column.field)
282
+ format = el.format;
283
+ });
284
+ let year;
285
+ switch (format) {
286
+ case "Q1 2021":
287
+ year = date.getFullYear();
288
+ args.cell.innerHTML = "Q" + quarter + " " + year;
289
+ break;
290
+ case "Q1 21":
291
+ year = date.getYear() - 100;
292
+ args.cell.innerHTML = "Q" + quarter + " " + year;
293
+ break;
294
+ case "2021 Q1":
295
+ year = date.getFullYear();
296
+ args.cell.innerHTML = year + " " + "Q" + quarter;
297
+ break;
298
+ case "21 Q1":
299
+ year = date.getYear() - 100;
300
+ args.cell.innerHTML = year + " " + "Q" + quarter;
301
+ break;
302
+ }
303
+ }
304
+ if (args.column.field)
305
+ if (["MOIC", "DPI", "TVPI", "RVPI", "PIC", "Multiple"].includes(args.column.field)) {
306
+ if (args.data && args.data[args.column.field]) {
307
+ // 渲染过一次后,就用原数据就好了
308
+ args.cell.innerHTML = `<div>${args.data[args.column.field].indexOf instanceof Function
309
+ ? args.data[args.column.field]
310
+ : this.getXTxt(args.column.field, args.data)}
311
+ </div>`;
312
+ }
313
+ }
314
+ if (args.column &&
315
+ args.column.format &&
316
+ args.column.format === "dd-MMM-yyyy") {
317
+ args.cell.innerHTML = `<div>${moment(args.data[args.column.field]).format("DD-MMM-yyyy")}</div>`;
318
+ }
319
+ }
320
+ cellAddStyle(args, queryCell) {
321
+ if (queryCell.format[0].fontSettingChecked) {
322
+ let formatCellData = args.data[args.column.field];
323
+ if (Math.sign(formatCellData) !== 0)
324
+ if (Math.sign(formatCellData) === -1) {
325
+ args.cell.style.cssText += `color: ${queryCell.format[0].negaFontColor} !important`;
326
+ args.cell.style.cssText += `font-size: ${queryCell.format[0].negaFontSizeValue} !important`;
327
+ args.cell.style.cssText += `font-family: ${queryCell.format[0].negaFontFamilyValue} !important`;
328
+ args.cell.style.cssText += `background-color: ${queryCell.format[0].negaBackgroundColor} !important`;
329
+ }
330
+ else {
331
+ args.cell.style.cssText += `color: ${queryCell.format[0].fontColor} !important`;
332
+ args.cell.style.cssText += `font-size: ${queryCell.format[0].fontSizeValue} !important`;
333
+ args.cell.style.cssText += `font-family: ${queryCell.format[0].fontFamilyValue} !important`;
334
+ args.cell.style.cssText += `background-color: ${queryCell.format[0].backgroundColor} !important`;
335
+ }
336
+ }
337
+ }
338
+ async getTableData() {
339
+ this.pageLoading = false;
340
+ this.config = JSON.parse(this.portlet.config);
341
+ if (this.config.fields) {
342
+ if (this.dashboardPorletsService.allFieldsObj[this.portlet.id]) {
343
+ this.config.fields =
344
+ this.dashboardPorletsService.setConfigFields(this.dashboardPorletsService.allFieldsObj[this.portlet.id], this.config.fields);
345
+ }
346
+ this.configFields = [...this.config.fields];
347
+ }
348
+ // ejs-grid 坑点:列头数据,colName中不能含有空格
349
+ // GetSchema接口中获取的所有列的dataType和GetPortletDataOrCreate接口中返回的数据类型必须保持一致,否则会导致数据总量显示,但是列表中无数据
350
+ const data = this.dashboardPorletsService.getResultByDataTable(this.portlet, false, false, this.dashboard.id);
351
+ this.data = data ? DataUtil.parse.parseJson(data) : [];
352
+ this.data = this.data.map((item) => {
353
+ const translationMap = {
354
+ Indirect: this.translation.INDIRECT || "Indirect",
355
+ Direct: this.translation.DIRECT || "Direct",
356
+ };
357
+ return {
358
+ ...item,
359
+ DirectIndirect: translationMap[item.DirectIndirect] || item.DirectIndirect,
360
+ };
361
+ });
362
+ this.totalRecordsCount =
363
+ this.dashboardPorletsService.getResultByDataTable(this.portlet, true, true, this.dashboard.id);
364
+ if (this.config &&
365
+ this.configFields &&
366
+ this.configFields.length &&
367
+ this.data &&
368
+ this.data.length) {
369
+ this.formatSettings = [];
370
+ this.formatDates = [];
371
+ this.configFields.map((el) => {
372
+ if (["number", "percent", "percentNum", "multiple"].includes(el.dataType)) {
373
+ let format = this.getNumFormat(el);
374
+ const formatData = {
375
+ name: el.colName,
376
+ format: format,
377
+ };
378
+ this.formatSettings.push(formatData);
379
+ }
380
+ if (el.dataType == "datetime" || el.dataType == "date") {
381
+ let format = "";
382
+ if (el.format &&
383
+ el.format.length &&
384
+ el.format[0].formatChecked) {
385
+ if (el.format[0].dateType == "Quarter") {
386
+ let format_ = el.format[0].selectedFormatDisplay;
387
+ let formatInfo = this.quarterFormat.filter((qur) => qur.value == format_);
388
+ if (formatInfo.length) {
389
+ format = formatInfo[0].format;
390
+ }
391
+ else {
392
+ const formatData = {
393
+ name: el.colName,
394
+ format: format_,
395
+ type: "date",
396
+ };
397
+ this.formatDates.push(formatData);
398
+ }
399
+ }
400
+ else if (el.format[0].dateType == "Date") {
401
+ let fromIdx = el.format[0].selectedFormatDisplay.indexOf("(");
402
+ let toIdx = el.format[0].selectedFormatDisplay.indexOf(")");
403
+ let format_ = el.format[0].selectedFormatDisplay.slice(fromIdx + 1, toIdx);
404
+ format = this.getDateFormat(format_);
405
+ }
406
+ }
407
+ if (!format) {
408
+ const formatData = {
409
+ name: el.colName,
410
+ format: this.datePipeFormat,
411
+ type: "date",
412
+ };
413
+ this.formatSettings.push(formatData);
414
+ }
415
+ else {
416
+ const formatData = {
417
+ name: el.colName,
418
+ format: format,
419
+ type: "date",
420
+ };
421
+ this.formatSettings.push(formatData);
422
+ }
423
+ }
424
+ });
425
+ const newTableList = [];
426
+ this.configFields.forEach((item) => {
427
+ if (!item.isHidden) {
428
+ const obj = {
429
+ ...item,
430
+ dataType: [
431
+ "MOIC",
432
+ "DPI",
433
+ "TVPI",
434
+ "RVPI",
435
+ "PIC",
436
+ "Multiple",
437
+ ].includes(item.colName)
438
+ ? "string"
439
+ : item["dataType"],
440
+ };
441
+ if (Array.isArray(item.format) &&
442
+ item.format.length > 0 &&
443
+ item.format[0].formatChecked) {
444
+ obj.displayName = item.format[0].displayName;
445
+ }
446
+ newTableList.push(obj);
447
+ }
448
+ });
449
+ this.tableList = newTableList;
450
+ const typeMap = {};
451
+ this.tableList.forEach((col) => {
452
+ if (col.dataType === "number") {
453
+ typeMap[col.colName] = true;
454
+ }
455
+ });
456
+ this.data.forEach((_data) => {
457
+ Object.keys(typeMap).forEach((key) => {
458
+ _data[key] =
459
+ _data[key] === null
460
+ ? null
461
+ : this.pbf.bankersRounding(Number(_data[key]));
462
+ });
463
+ });
464
+ }
465
+ if (this.config.filterSettings && this.config.filterSettings.length) {
466
+ this.filterSettings.columns = this.config.filterSettings;
467
+ }
468
+ this.ref.markForCheck();
469
+ // this.ref.detectChanges();
470
+ }
471
+ getFormatOptions(colName) {
472
+ let res = this.formatSettings &&
473
+ this.formatSettings.filter((el) => el.name === colName);
474
+ if (res && res.length)
475
+ return res[0].format;
476
+ }
477
+ getInfo() {
478
+ this.translation = JSON.parse(localStorage.getItem("translation"));
479
+ this.userInfo = JSON.parse(localStorage.getItem("userInfo"));
480
+ this.datePipeFormat = localStorage.getItem("datePipe");
481
+ }
482
+ actionComplete(args) {
483
+ if (args.requestType === "filtering") {
484
+ if (args.action === "filter") {
485
+ let filteredvalues = [];
486
+ for (let item of args.columns) {
487
+ // if (item.type === "datetime" || item.type === "date") {
488
+ // item.value = this.pbf.time(item.value);
489
+ // }
490
+ filteredvalues.push({
491
+ field: item.field,
492
+ matchCase: item.matchCase,
493
+ operator: item.operator,
494
+ predicate: item.predicate,
495
+ type: item.type,
496
+ value: item.value,
497
+ });
498
+ }
499
+ this.config.filterSettings = filteredvalues;
500
+ }
501
+ else {
502
+ this.currentFilterField = "";
503
+ this.config.filterSettings = [];
504
+ }
505
+ const portlet = this.portlet;
506
+ portlet.config = JSON.stringify(this.config);
507
+ const index = this.portlets.findIndex((x) => x.newId === portlet.newId);
508
+ if (index > -1)
509
+ this.portlets[index] = portlet;
510
+ this.currentPage = 1;
511
+ this.reloadTableData({
512
+ page: this.currentPage,
513
+ size: this.pageSize,
514
+ sortedColumn: this.sortedColumn === null ? undefined : this.sortedColumn,
515
+ sort: this.sort === null ? undefined : this.sort,
516
+ });
517
+ }
518
+ // 列选择事件
519
+ if (args.requestType === "columnstate") {
520
+ const hideColumns = this.grid.getHiddenColumns();
521
+ this.configFields.map((el) => (el.visible = true));
522
+ if (hideColumns.length > 0) {
523
+ for (let hideitem of hideColumns) {
524
+ if (hideitem.field)
525
+ this.configFields.filter((el) => el.colName === hideitem.field)[0].visible = false;
526
+ }
527
+ }
528
+ this.config.fields = JSON.parse(JSON.stringify(this.configFields));
529
+ this.portlet.config = JSON.stringify(this.config);
530
+ const index = this.portlets.findIndex((x) => x.newId === this.portlet.newId);
531
+ this.portlets[index].config = JSON.stringify(this.config);
532
+ this.reloadTableData({
533
+ page: this.currentPage,
534
+ size: this.pageSize,
535
+ sortedColumn: this.sortedColumn === null
536
+ ? undefined
537
+ : this.sortedColumn,
538
+ sort: this.sort === null ? undefined : this.sort,
539
+ }, true);
540
+ }
541
+ }
542
+ actionBegin(args) {
543
+ if (args.requestType === "filterchoicerequest") {
544
+ const checkboxfilter = this.el.nativeElement.querySelector(".e-checkboxfilter");
545
+ if (checkboxfilter) {
546
+ if (this.portlet.height == 1) {
547
+ args.filterModel.dlg.style.minHeight = "calc(100% - 12px)";
548
+ args.filterModel.dlg.style.maxHeight = "calc(100% - 12px)";
549
+ }
550
+ else {
551
+ args.filterModel.dlg.style.minHeight = "350px";
552
+ args.filterModel.dlg.style.maxHeight = "350px";
553
+ }
554
+ }
555
+ }
556
+ if (args.requestType == "filterchoicerequest" ||
557
+ args.requestType === "filtersearchbegin") {
558
+ args.filterChoiceCount = 3000;
559
+ }
560
+ // 显示过滤的选项
561
+ if (args.requestType === "filterbeforeopen" &&
562
+ this.currentFilterField !== args.columnName) {
563
+ args.cancel = true;
564
+ let columnFilter = [];
565
+ let field = args.columnName;
566
+ if (this.config.filterSettings.length) {
567
+ columnFilter = this.config.filterSettings.filter((x) => x.field !== field);
568
+ }
569
+ let data = {
570
+ dashboardDataTableId: this.portlet.dashboardDataTableId,
571
+ displayColumnFilter: field,
572
+ columnFilter: columnFilter,
573
+ };
574
+ this.http.post(this.api.urlList.GetDistinctColumnValsByPortletDataParam, data, (res) => {
575
+ this.pageLoading = false;
576
+ let curFomart = this.formatSettings.find((x) => x.name === field);
577
+ if (curFomart &&
578
+ ["date", "datetime"].includes(curFomart.type)) {
579
+ res = res[field].map((x) => new Date(x));
580
+ }
581
+ else {
582
+ res = res[field];
583
+ }
584
+ this.currentFilterField = args.columnName;
585
+ this.filterContents = res;
586
+ this.grid.filterModule.openMenuByField(args.columnName);
587
+ if (columnFilter.length) {
588
+ this.grid.clearFiltering();
589
+ }
590
+ });
591
+ if (args.requestType === "filterbeforeopen" &&
592
+ this.currentFilterField === args.columnName) {
593
+ let columnName = args.columnName;
594
+ if (this.filterContents) {
595
+ let curResult = this.filterContents;
596
+ let filterOptions = curResult.map((x) => {
597
+ let obj = {};
598
+ obj[columnName] = x;
599
+ return obj;
600
+ });
601
+ args.filterModel.options.dataSource = filterOptions;
602
+ }
603
+ }
604
+ // 处理排序
605
+ if (args.requestType === "sorting") {
606
+ if (args.columnName) {
607
+ this.sort = args.direction === "Ascending" ? 1 : 0;
608
+ this.sortedColumn = args.columnName;
609
+ this.reloadTableData({
610
+ page: this.currentPage,
611
+ size: this.pageSize,
612
+ sort: this.sort,
613
+ sortedColumn: this.sortedColumn,
614
+ });
615
+ }
616
+ else {
617
+ this.sort = null;
618
+ this.sortedColumn = null;
619
+ this.reloadTableData({
620
+ page: this.currentPage,
621
+ size: this.pageSize,
622
+ });
623
+ }
624
+ this.config.tableSortSetting = {
625
+ sort: this.sort,
626
+ sortedColumn: this.sortedColumn,
627
+ };
628
+ this.portlet.config = JSON.stringify(this.config);
629
+ const index = this.portlets.findIndex((x) => x.newId === this.portlet.newId);
630
+ this.portlets[index].config = JSON.stringify(this.config);
631
+ }
632
+ }
633
+ }
634
+ resizeStop(args) {
635
+ let field = this.configFields.filter((el) => el.colName === args.column.field);
636
+ if (field && field.length > 0) {
637
+ field[0].width = parseInt(args.column.width);
638
+ const portlet = this.portlet;
639
+ portlet.config = JSON.stringify(this.config);
640
+ const index = this.portlets.findIndex((x) => x.newId === portlet.newId);
641
+ this.portlets[index] = portlet;
642
+ }
643
+ }
644
+ rowDataBound(args) {
645
+ if (args.row.ariaRowIndex % 2 === 0) {
646
+ args.row.style.backgroundColor = "#f8fafb";
647
+ }
648
+ else {
649
+ args.row.style.backgroundColor = "#ffffff";
650
+ }
651
+ }
652
+ created(args) {
653
+ if (this.config.showGrandTotals) {
654
+ let el = this.grid.element.querySelector(".e-gridfooter");
655
+ if (el)
656
+ el.classList.remove("hidesummary");
657
+ }
658
+ else {
659
+ let el = this.grid.element.querySelector(".e-gridfooter");
660
+ if (el)
661
+ el.classList.add("hidesummary");
662
+ }
663
+ }
664
+ exportQueryCellInfo(args) {
665
+ let curFormat = this.formatSettings.find((x) => x.name === args.column.field);
666
+ if (curFormat) {
667
+ if (curFormat.type === "date") {
668
+ args.value = this.pbf.convertDateFormat(args.value, curFormat.format
669
+ ? curFormat.format.replace("dd", "DD")
670
+ : null);
671
+ }
672
+ }
673
+ if (args.column.field &&
674
+ this.millionFields.includes(args.column.field)) {
675
+ args.value = args.data[args.column.field] / 1000000;
676
+ }
677
+ if (this.formatDates && this.formatDates.length) {
678
+ let dateFields = this.formatDates.map((el) => {
679
+ return el.name;
680
+ });
681
+ if (args.column.field && dateFields.includes(args.column.field)) {
682
+ let date = new Date(args.data[args.column.field]);
683
+ let quarter = Math.floor((date.getMonth() + 1) % 3) == 0
684
+ ? Math.floor((date.getMonth() + 1) / 3)
685
+ : Math.floor((date.getMonth() + 1) / 3) + 1;
686
+ let format;
687
+ this.formatDates.map((el) => {
688
+ if (el.name == args.column.field)
689
+ format = el.format;
690
+ });
691
+ let year;
692
+ switch (format) {
693
+ case "Q1 2021":
694
+ year = date.getFullYear();
695
+ args.value = "Q" + quarter + " " + year;
696
+ break;
697
+ case "Q1 21":
698
+ year = date.getYear() - 100;
699
+ args.value = "Q" + quarter + " " + year;
700
+ break;
701
+ case "2021 Q1":
702
+ year = date.getFullYear();
703
+ args.value = year + " " + "Q" + quarter;
704
+ break;
705
+ case "21 Q1":
706
+ year = date.getYear() - 100;
707
+ args.value = year + " " + "Q" + quarter;
708
+ break;
709
+ }
710
+ }
711
+ }
712
+ // Excel Style Format
713
+ let queryCell = this.tableList &&
714
+ this.tableList.filter((item) => item.colName === args.column.field)[0];
715
+ if (queryCell &&
716
+ queryCell.format &&
717
+ queryCell.format.length &&
718
+ queryCell.format[0].fontSettingChecked) {
719
+ if (queryCell.format[0].formatChecked &&
720
+ queryCell.format[0].compareSelect) {
721
+ let cellData = args.data[args.column.field];
722
+ let condition = false;
723
+ switch (queryCell.format[0].compareSelect) {
724
+ case "LessThan":
725
+ condition =
726
+ cellData <
727
+ Number(queryCell.format[0].compareValue1);
728
+ break;
729
+ case "LessThanOrEqualTo":
730
+ condition =
731
+ cellData <=
732
+ Number(queryCell.format[0].compareValue1);
733
+ break;
734
+ case "GreaterThan":
735
+ condition =
736
+ cellData >
737
+ Number(queryCell.format[0].compareValue1);
738
+ break;
739
+ case "GreaterThanOrEqualTo":
740
+ condition =
741
+ cellData >=
742
+ Number(queryCell.format[0].compareValue1);
743
+ break;
744
+ case "Equals":
745
+ condition =
746
+ cellData ===
747
+ Number(queryCell.format[0].compareValue1);
748
+ break;
749
+ case "NotEquals":
750
+ condition =
751
+ cellData !==
752
+ Number(queryCell.format[0].compareValue1);
753
+ break;
754
+ case "Between":
755
+ condition =
756
+ cellData >=
757
+ Number(queryCell.format[0].compareValue1) &&
758
+ cellData <= queryCell.format[0].compareValue2;
759
+ break;
760
+ case "NotBetween":
761
+ condition =
762
+ cellData <
763
+ Number(queryCell.format[0].compareValue1) &&
764
+ cellData >
765
+ Number(queryCell.format[0].compareValue2);
766
+ break;
767
+ default:
768
+ break;
769
+ }
770
+ if (condition)
771
+ this.cellAddStyleExcel(args, queryCell);
772
+ }
773
+ else
774
+ this.cellAddStyleExcel(args, queryCell);
775
+ }
776
+ }
777
+ cellAddStyleExcel(args, queryCell) {
778
+ if (queryCell.format[0].fontSettingChecked) {
779
+ let formatCellData = args.data[args.column.field];
780
+ if (Math.sign(formatCellData) !== 0)
781
+ if (Math.sign(formatCellData) === -1) {
782
+ args.style = {
783
+ fontColor: this.pbf.rgbaToHex(`${queryCell.format[0].negaFontColor}`),
784
+ fontSize: Number(`${queryCell.format[0].negaFontSizeValue}`.replace("px", "")),
785
+ fontName: `${queryCell.format[0].negaFontFamilyValue}`,
786
+ backColor: this.pbf.rgbaToHex(`${queryCell.format[0].negaBackgroundColor}`),
787
+ };
788
+ }
789
+ else {
790
+ args.style = {
791
+ fontColor: this.pbf.rgbaToHex(`${queryCell.format[0].fontColor}`),
792
+ fontSize: Number(`${queryCell.format[0].fontSizeValue}`.replace("px", "")),
793
+ fontName: `${queryCell.format[0].fontFamilyValue}`,
794
+ backColor: this.pbf.rgbaToHex(`${queryCell.format[0].backgroundColor}`),
795
+ };
796
+ }
797
+ }
798
+ }
799
+ getLogoInfo(colName, code) {
800
+ if (this.configFields && this.configFields.length) {
801
+ let fields = this.configFields.filter((el) => el.colName == colName);
802
+ if (fields && fields.length) {
803
+ return fields[0][code];
804
+ }
805
+ else {
806
+ return false;
807
+ }
808
+ }
809
+ else {
810
+ return false;
811
+ }
812
+ }
813
+ getLogoImage(logoDocId) {
814
+ let img;
815
+ if (logoDocId !== undefined &&
816
+ logoDocId !== null &&
817
+ logoDocId !== "00000000-0000-0000-0000-000000000000") {
818
+ img =
819
+ this.api.baseurl +
820
+ this.api.urlList.FileGet +
821
+ "?username=" +
822
+ this.userInfo.username +
823
+ "&accountId=" +
824
+ this.userInfo.accountId +
825
+ "&docId=" +
826
+ logoDocId +
827
+ `&Authorization=Bearer`;
828
+ }
829
+ else {
830
+ img = "../../../../../../assets/img/default_profile_icon.png";
831
+ }
832
+ return img;
833
+ }
834
+ setQuarterFormat() {
835
+ return [
836
+ { value: "03/2021", format: "MM/yyyy" },
837
+ { value: "03/21", format: "MM/dd" },
838
+ { value: "3/2021", format: "M/yyyy" },
839
+ { value: "3/21", format: "M/yy" },
840
+ { value: "March 2021", format: "MMMM yyyy" },
841
+ { value: "Mar, 2021", format: "MMM, yyyy" },
842
+ { value: "March, 2021", format: "MMMM, yyyy" },
843
+ { value: "2021", format: "yyyy" },
844
+ ];
845
+ }
846
+ getDateFormat(format_) {
847
+ switch (format_) {
848
+ case "DD/MM/YYYY":
849
+ return "dd/MM/yyyy";
850
+ case "DD/MM/YY":
851
+ return "dd/MM/yy";
852
+ case "MM/DD/YYYY":
853
+ return "MM/dd/yyyy";
854
+ case "MM/DD/YY":
855
+ return "MM/dd/yy";
856
+ case "YYYY-MM-DD":
857
+ return "yyyy-MM-dd";
858
+ case "YY-MM-DD":
859
+ return "yy-MM-dd";
860
+ case "DD-MM-YYYY":
861
+ return "dd-MM-yyyy";
862
+ case "DD-MM-YY":
863
+ return "dd-MM-yy";
864
+ case "MM-DD-YYYY":
865
+ return "MM-dd-yyyy";
866
+ case "MM-DD-YY":
867
+ return "MM-dd-yy";
868
+ case "MMM DD, YYYY":
869
+ return "MMM dd, yyyy";
870
+ case "DD-MMM-YYYY":
871
+ return "dd-MMM-yyyy";
872
+ default:
873
+ break;
874
+ }
875
+ }
876
+ getNumFormat(el) {
877
+ //SMP2-3026
878
+ if (el.dataType === "number" &&
879
+ el.colName !== "PortInvStk" &&
880
+ el.colName !== "PortFdInvStk") {
881
+ if (el.format && el.format.length && el.format[0].formatChecked) {
882
+ if ([10, 11, 12, 13, 14, 15, 16, 17, 18].includes(el.format[0].selectedFormat))
883
+ this.millionData(el.colName);
884
+ return this.pbf.formatNumber(el.format[0].selectedFormat);
885
+ }
886
+ else
887
+ return this.dashboardPorletsService.formatNumber(el.dp);
888
+ }
889
+ if (el.dataType === "percent") {
890
+ if (el.format && el.format.length && el.format[0].formatChecked)
891
+ return this.pbf.formatPercent(el.format[0].selectedFormat);
892
+ else
893
+ return this.dashboardPorletsService.formatPercent(el.dp);
894
+ }
895
+ if (el.dataType === "percentNum")
896
+ return this.dashboardPorletsService.formatPercentNum(el.dp);
897
+ if (el.dataType === "multiple")
898
+ return this.dashboardPorletsService.formatMultiple(el.dp);
899
+ }
900
+ millionData(colName) {
901
+ this.millionFields.push(colName);
902
+ if (this.config.filterSettings && this.config.filterSettings.length) {
903
+ let filterFields = this.config.filterSettings.map((el) => {
904
+ return el.field;
905
+ });
906
+ if (filterFields.includes(colName))
907
+ this.config.filterSettings.map((el) => {
908
+ if (el.field == colName) {
909
+ el.value = Number(el.value / 1000000);
910
+ }
911
+ });
912
+ }
913
+ }
914
+ getAlign(table) {
915
+ if (table.format &&
916
+ table.format.length &&
917
+ table.format[0].formatChecked)
918
+ return table.format[0].align;
919
+ return ["date", "datetime", "string", "nvarchar", "dropdown"].includes(table.dataType) &&
920
+ !["MOIC", "DPI", "TVPI", "RVPI", "PIC", "Multiple"].includes(table.colName)
921
+ ? "Left"
922
+ : "Right";
923
+ }
924
+ pageChanged(args) {
925
+ if (args.newProp) {
926
+ // 处理分页器点击事件
927
+ let pageSize = args.newProp.pageSize;
928
+ if (pageSize) {
929
+ this.pageSize = pageSize;
930
+ this.currentPage = 1;
931
+ }
932
+ else {
933
+ this.currentPage = args.newProp.currentPage;
934
+ }
935
+ this.reloadTableData({
936
+ page: this.currentPage,
937
+ size: this.pageSize,
938
+ sortedColumn: this.sortedColumn === null
939
+ ? undefined
940
+ : this.sortedColumn,
941
+ sort: this.sort === null ? undefined : this.sort,
942
+ }, true);
943
+ }
944
+ }
945
+ reloadTableData(setting = {}, refreshFormat) {
946
+ let params = {};
947
+ if (setting.page && setting.size) {
948
+ params.currentPage = setting.page;
949
+ params.pageSize = setting.size;
950
+ }
951
+ if (setting.sortedColumn) {
952
+ params.sortedColumn = setting.sortedColumn;
953
+ params.sort = setting.sort;
954
+ }
955
+ this.pageLoading = true;
956
+ this.dashboardPorletsService.getDataByPortletsNew([this.portlet], () => {
957
+ this.pageLoading = false;
958
+ const data = DataUtil.parse.parseJson(this.dashboardPorletsService.getResultByDataTable(this.portlet, false, false, this.dashboard.id));
959
+ this.data = data.map((item) => {
960
+ return {
961
+ ...item,
962
+ MOIC: `${Number(item["MOIC"]).toFixed(2)}x`,
963
+ DPI: `${Number(item["DPI"]).toFixed(2)}x`,
964
+ TVPI: `${Number(item["TVPI"]).toFixed(2)}x`,
965
+ RVPI: `${Number(item["RVPI"]).toFixed(2)}x`,
966
+ PIC: `${Number(item["PIC"]).toFixed(2)}x`,
967
+ Multiple: `${Number(item["Multiple"]).toFixed(2)}x`,
968
+ };
969
+ });
970
+ // if (this.tableList && this.tableList.length) {
971
+ // const typeMap = {};
972
+ // this.tableList.forEach((col) => {
973
+ // if (col.dataType === "number") {
974
+ // typeMap[col.colName] = true;
975
+ // }
976
+ // });
977
+ // this.data.forEach((_data) => {
978
+ // Object.keys(typeMap).forEach((key) => {
979
+ // _data[key] =
980
+ // _data[key] === null
981
+ // ? null
982
+ // : this.pbf.bankersRounding(
983
+ // Number(_data[key])
984
+ // );
985
+ // });
986
+ // });
987
+ // }
988
+ this.totalRecordsCount =
989
+ this.dashboardPorletsService.getResultByDataTable(this.portlet, true, true, this.dashboard.id);
990
+ this.tableList = [...this.configFields];
991
+ this.tableList = this.tableList.filter((fl) => !fl.isHidden);
992
+ this.tableList = this.tableList.map((item) => {
993
+ return {
994
+ ...item,
995
+ dataType: [
996
+ "MOIC",
997
+ "DPI",
998
+ "TVPI",
999
+ "RVPI",
1000
+ "PIC",
1001
+ "Multiple",
1002
+ ].includes(item.colName)
1003
+ ? "string"
1004
+ : item["dataType"],
1005
+ };
1006
+ });
1007
+ const typeMap = {};
1008
+ this.tableList.forEach((col) => {
1009
+ if (col.dataType === "number") {
1010
+ typeMap[col.colName] = true;
1011
+ }
1012
+ });
1013
+ this.data.forEach((_data) => {
1014
+ Object.keys(typeMap).forEach((key) => {
1015
+ _data[key] =
1016
+ _data[key] === null
1017
+ ? null
1018
+ : this.pbf.bankersRounding(Number(_data[key]));
1019
+ });
1020
+ });
1021
+ if (this.grid) {
1022
+ if (refreshFormat) {
1023
+ this.grid.columns.forEach((item) => {
1024
+ item.format = this.getFormatOptions(item.field);
1025
+ });
1026
+ if (this.grid.contentModule) {
1027
+ this.grid.refreshColumns();
1028
+ }
1029
+ }
1030
+ else {
1031
+ this.grid.refresh();
1032
+ }
1033
+ }
1034
+ this.ref.markForCheck();
1035
+ this.ref.detectChanges();
1036
+ }, params, false, this.dashboard);
1037
+ }
1038
+ getXTxt(colName, item) {
1039
+ if (colName == "MOIC") {
1040
+ return `${Number(item["MOIC"]).toFixed(2)}x`;
1041
+ }
1042
+ else if (colName == "DPI") {
1043
+ return `${Number(item["DPI"]).toFixed(2)}x`;
1044
+ }
1045
+ else if (colName == "TVPI") {
1046
+ return `${Number(item["TVPI"]).toFixed(2)}x`;
1047
+ }
1048
+ else if (colName == "RVPI") {
1049
+ return `${Number(item["RVPI"]).toFixed(2)}x`;
1050
+ }
1051
+ else if (colName == "PIC") {
1052
+ return `${Number(item["PIC"]).toFixed(2)}x`;
1053
+ }
1054
+ else if (colName == "Multiple") {
1055
+ return `${Number(item["Multiple"]).toFixed(2)}x`;
1056
+ }
1057
+ }
1058
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: GadgetTableComponent, deps: [{ token: i1.DashboardPorletsService }, { token: i2.ApiList }, { token: i0.ChangeDetectorRef }, { token: i3.DashboardService }, { token: i0.ElementRef }, { token: PBF_TOKEN, optional: true }, { token: API_SERVICE_TOKEN, optional: true }], target: i0.ɵɵFactoryTarget.Component });
1059
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: GadgetTableComponent, selector: "rs-gadget-table", inputs: { portlet: "portlet", dashboard: "dashboard", portlets: "portlets" }, providers: [
1060
+ ExcelExportService,
1061
+ ColumnChooserService,
1062
+ VirtualScrollService,
1063
+ FilterService,
1064
+ ResizeService,
1065
+ ], viewQueries: [{ propertyName: "grid", first: true, predicate: ["grid"], descendants: true }, { propertyName: "pager", first: true, predicate: ["pager"], descendants: true }], ngImport: i0, template: "<div class=\"control-section gadget-table\" style=\"height: 100%\" *ngIf=\"data && data.length\">\r\n\t<ejs-grid\r\n\t\t*ngIf=\"!hideTable\"\r\n\t\t#grid\r\n\t\t[dataSource]=\"data\"\r\n\t\t[allowSorting]=\"true\"\r\n\t\twidth=\"100%\"\r\n\t\t[pageSettings]=\"options\"\r\n\t\t[resizeSettings]=\"{ mode: 'Auto' }\"\r\n\t\t[allowExcelExport]=\"true\"\r\n\t\t[filterSettings]=\"filterSettings\"\r\n\t\t[allowResizing]=\"true\"\r\n\t\tshowColumnChooser=\"true\"\r\n\t\t[columnChooserSettings]=\"ColumnChooserSettings\"\r\n\t\t[aggregates]=\"aggregates\"\r\n\t\t(queryCellInfo)=\"customiseCell($event)\"\r\n\t\t(resizeStop)=\"resizeStop($event)\"\r\n\t\t(rowDataBound)=\"rowDataBound($event)\"\r\n\t\t(created)=\"created($event)\"\r\n\t\t(actionBegin)=\"actionBegin($event)\"\r\n\t\t(actionComplete)=\"actionComplete($event)\"\r\n\t\t(excelQueryCellInfo)=\"exportQueryCellInfo($event)\"\r\n\t>\r\n\t\t<e-columns>\r\n\t\t\t<e-column\r\n\t\t\t\t*ngIf=\"getLogoInfo('logoDocId', 'langValue')\"\r\n\t\t\t\t[headerText]=\"getLogoInfo('logoDocId', 'langValue')\"\r\n\t\t\t\twidth=\"120\"\r\n\t\t\t\ttextAlign=\"Center\"\r\n\t\t\t\t[visible]=\"!getLogoInfo('logoDocId', 'isHidden')\"\r\n\t\t\t>\r\n\t\t\t\t<ng-template #template let-data>\r\n\t\t\t\t\t<div class=\"image-\">\r\n\t\t\t\t\t\t<img\r\n\t\t\t\t\t\t\t[src]=\"getLogoImage(data.logoDocId)\"\r\n\t\t\t\t\t\t\t[alt]=\"data.companyName\"\r\n\t\t\t\t\t\t/>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t</ng-template>\r\n\t\t\t</e-column>\r\n\t\t\t<e-column\r\n\t\t\t\t*ngFor=\"let table of tableList\"\r\n\t\t\t\t[field]=\"table.colName\"\r\n\t\t\t\t[filter]=\"filter\"\r\n\t\t\t\t[headerText]=\"\r\n\t\t\t\t\t(table.displayName\r\n\t\t\t\t\t\t? table.displayName\r\n\t\t\t\t\t\t: translation[table.langCode]\r\n\t\t\t\t\t\t? translation[table.langCode]\r\n\t\t\t\t\t\t: table.langValue) +\r\n\t\t\t\t\t(table.addtionName ? ' ' + table.addtionName : '')\r\n\t\t\t\t\"\r\n\t\t\t\t[width]=\"table.width ? table.width : 200\"\r\n\t\t\t\tclipMode=\"EllipsisWithTooltip\"\r\n\t\t\t\t[visible]=\"table.visible\"\r\n\t\t\t\t[type]=\"\r\n\t\t\t\t\t['number', 'percentNum', 'percent'].includes(table.dataType)\r\n\t\t\t\t\t\t? 'number'\r\n\t\t\t\t\t\t: ['date', 'datetime'].includes(table.dataType)\r\n\t\t\t\t\t\t? 'date'\r\n\t\t\t\t\t\t: null\r\n\t\t\t\t\"\r\n\t\t\t\t[format]=\"getFormatOptions(table.colName)\"\r\n\t\t\t\t[textAlign]=\"getAlign(table)\"\r\n\t\t\t>\r\n\t\t\t\t<ng-template\r\n\t\t\t\t\t#template\r\n\t\t\t\t\tlet-data\r\n\t\t\t\t\t*ngIf=\"millionFields.includes(table.colName); else elseBlock\"\r\n\t\t\t\t>\r\n\t\t\t\t\t{{ data[table.colName] / 1000000 }}\r\n\t\t\t\t</ng-template>\r\n\t\t\t\t<ng-template #elseBlock>\r\n\t\t\t\t\t{{ data[table.colName] }}\r\n\t\t\t\t</ng-template>\r\n\r\n\t\t\t\t<!-- terms\u5217 \u663E\u793A\u6362\u884C\u7B26 -->\r\n\t\t\t\t<ng-template\r\n\t\t\t\t\t#template\r\n\t\t\t\t\tlet-data\r\n\t\t\t\t\t*ngIf=\"table.colName == 'terms'\"\r\n\t\t\t\t>\r\n\t\t\t\t\t<div\r\n\t\t\t\t\t\tstyle=\"white-space: pre-line\"\r\n\t\t\t\t\t\t[innerHTML]=\"data[table.colName]\"\r\n\t\t\t\t\t></div>\r\n\t\t\t\t</ng-template>\r\n\t\t\t</e-column>\r\n\t\t</e-columns>\r\n\t</ejs-grid>\r\n\t<ejs-pager\r\n\t\t#pager\r\n\t\t[currentPage]=\"currentPage\"\r\n\t\t[pageCount]=\"5\"\r\n\t\t[pageSize]=\"pageSize\"\r\n\t\t[pageSizes]=\"[10, 50, 100]\"\r\n\t\t[totalRecordsCount]=\"totalRecordsCount\"\r\n\t\t(click)=\"pageChanged($event)\"\r\n\t>\r\n\t</ejs-pager>\r\n\t<div class=\"full-box-mask\" *ngIf=\"pageLoading\">\r\n\t\t<mat-spinner\r\n\t\t\tstyle=\"z-index: 999\"\r\n\t\t\tmode=\"indeterminate\"\r\n\t\t\t[diameter]=\"24\"\r\n\t\t></mat-spinner>\r\n\t</div>\r\n</div>\r\n", styles: [":host{display:block;height:100%}.gadget-table{display:flex;flex-direction:column;padding:0 12px}.gadget-table .e-grid{height:0;flex:1}.gadget-table .e-grid .e-gridheader{border-top:1px solid!important;border-bottom:1px solid!important;border-color:#eaedf0!important;padding-right:0!important}.gadget-table .e-grid .e-gridheader .e-headercontent{border:none!important}.gadget-table .e-grid .e-gridheader ::ng-deep .e-headercell{padding:0!important;height:22px!important}.gadget-table .e-grid .e-gridheader ::ng-deep .e-headercell:last-child .e-headercelldiv{border-right:none}.gadget-table .e-grid .e-gridheader ::ng-deep .e-headercell:first-child .e-headercelldiv{border-right:none;padding-left:0!important}.gadget-table .e-grid .e-gridheader ::ng-deep .e-headercell .e-headercelldiv{height:22px!important;padding:4px 8px!important;border-right:1px solid #eaedf0;border-radius:unset}.gadget-table .e-grid .e-gridcontent{margin-right:-5px}.gadget-table .e-grid .e-gridcontent .e-content{overflow:overlay!important}.gadget-table .e-grid .e-gridcontent .e-rowcell{padding:0 8px!important;height:22px!important;line-height:20px!important;border-right:1px solid #eaedf0}.gadget-table .e-grid .e-gridcontent .e-rowcell:first-child{padding-left:0!important}.gadget-table .e-grid .e-gridcontent .e-rowcell:last-child{border-right:none}.gadget-table .e-pager{padding:12px 0!important}\n"], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.GridComponent, selector: "ejs-grid", inputs: ["adaptiveUIMode", "aggregates", "allowExcelExport", "allowFiltering", "allowGrouping", "allowKeyboard", "allowMultiSorting", "allowPaging", "allowPdfExport", "allowReordering", "allowResizing", "allowRowDragAndDrop", "allowSelection", "allowSorting", "allowTextWrap", "autoFit", "childGrid", "clipMode", "columnChooserSettings", "columnMenuItems", "columnQueryMode", "columns", "contextMenuItems", "cssClass", "currencyCode", "currentAction", "currentViewData", "dataSource", "detailTemplate", "editSettings", "ej2StatePersistenceVersion", "emptyRecordTemplate", "enableAdaptiveUI", "enableAltRow", "enableAutoFill", "enableColumnVirtualization", "enableHeaderFocus", "enableHover", "enableHtmlSanitizer", "enableImmutableMode", "enableInfiniteScrolling", "enablePersistence", "enableRtl", "enableStickyHeader", "enableVirtualMaskRow", "enableVirtualization", "exportGrids", "filterSettings", "frozenColumns", "frozenRows", "gridLines", "groupSettings", "height", "hierarchyPrintMode", "infiniteScrollSettings", "loadingIndicator", "locale", "pageSettings", "pagerTemplate", "parentDetails", "printMode", "query", "queryString", "resizeSettings", "rowDropSettings", "rowHeight", "rowRenderingMode", "rowTemplate", "searchSettings", "selectedRowIndex", "selectionSettings", "showColumnChooser", "showColumnMenu", "showHider", "sortSettings", "textWrapSettings", "toolbar", "toolbarTemplate", "width"], outputs: ["actionBegin", "actionComplete", "actionFailure", "batchAdd", "batchCancel", "batchDelete", "beforeAutoFill", "beforeBatchAdd", "beforeBatchDelete", "beforeBatchSave", "beforeCopy", "beforeDataBound", "beforeExcelExport", "beforeOpenAdaptiveDialog", "beforeOpenColumnChooser", "beforePaste", "beforePdfExport", "beforePrint", "beginEdit", "cellDeselected", "cellDeselecting", "cellEdit", "cellSave", "cellSaved", "cellSelected", "cellSelecting", "checkBoxChange", "columnDataStateChange", "columnDeselected", "columnDeselecting", "columnDrag", "columnDragStart", "columnDrop", "columnMenuClick", "columnMenuOpen", "columnSelected", "columnSelecting", "commandClick", "contextMenuClick", "contextMenuOpen", "created", "dataBound", "dataSourceChanged", "dataStateChange", "destroyed", "detailDataBound", "excelAggregateQueryCellInfo", "excelExportComplete", "excelHeaderQueryCellInfo", "excelQueryCellInfo", "exportDetailDataBound", "exportDetailTemplate", "exportGroupCaption", "headerCellInfo", "keyPressed", "lazyLoadGroupCollapse", "lazyLoadGroupExpand", "load", "pdfAggregateQueryCellInfo", "pdfExportComplete", "pdfHeaderQueryCellInfo", "pdfQueryCellInfo", "printComplete", "queryCellInfo", "recordClick", "recordDoubleClick", "resizeStart", "resizeStop", "resizing", "rowDataBound", "rowDeselected", "rowDeselecting", "rowDrag", "rowDragStart", "rowDragStartHelper", "rowDrop", "rowSelected", "rowSelecting", "toolbarClick", "dataSourceChange"] }, { kind: "directive", type: i5.ColumnDirective, selector: "ejs-grid>e-columns>e-column", inputs: ["allowEditing", "allowFiltering", "allowGrouping", "allowReordering", "allowResizing", "allowSearching", "allowSorting", "autoFit", "clipMode", "columns", "commands", "customAttributes", "dataSource", "defaultValue", "disableHtmlEncode", "displayAsCheckBox", "edit", "editTemplate", "editType", "enableGroupByFormat", "field", "filter", "filterBarTemplate", "filterTemplate", "foreignKeyField", "foreignKeyValue", "format", "formatter", "freeze", "headerTemplate", "headerText", "headerTextAlign", "headerValueAccessor", "hideAtMedia", "index", "isFrozen", "isIdentity", "isPrimaryKey", "lockColumn", "maxWidth", "minWidth", "showColumnMenu", "showInColumnChooser", "sortComparer", "template", "textAlign", "type", "uid", "validationRules", "valueAccessor", "visible", "width"] }, { kind: "directive", type: i5.ColumnsDirective, selector: "ejs-grid>e-columns" }, { kind: "directive", type: i5.AggregateColumnDirective, selector: "ejs-grid>e-aggregates>e-aggregate>e-columns>e-column", inputs: ["columnName", "customAggregate", "field", "footerTemplate", "format", "groupCaptionTemplate", "groupFooterTemplate", "type"] }, { kind: "directive", type: i5.AggregateColumnsDirective, selector: "ejs-grid>e-aggregates>e-aggregate>e-columns" }, { kind: "component", type: i5.PagerComponent, selector: "ejs-pager", inputs: ["cssClass", "currentPage", "customText", "enableExternalMessage", "enablePagerMessage", "enablePersistence", "enableQueryString", "enableRtl", "externalMessage", "locale", "pageCount", "pageSize", "pageSizes", "template", "totalRecordsCount"], outputs: ["click", "created", "dropDownChanged", "currentPageChange", "pageSizeChange", "pageCountChange", "pageSizesChange"] }, { kind: "directive", type: i6.ColumnDirective, selector: "e-columns>e-column", inputs: ["border", "width"] }, { kind: "directive", type: i6.ColumnsDirective, selector: "ejs-chart>e-columns" }] });
1066
+ }
1067
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: GadgetTableComponent, decorators: [{
1068
+ type: Component,
1069
+ args: [{ selector: "rs-gadget-table", providers: [
1070
+ ExcelExportService,
1071
+ ColumnChooserService,
1072
+ VirtualScrollService,
1073
+ FilterService,
1074
+ ResizeService,
1075
+ ], template: "<div class=\"control-section gadget-table\" style=\"height: 100%\" *ngIf=\"data && data.length\">\r\n\t<ejs-grid\r\n\t\t*ngIf=\"!hideTable\"\r\n\t\t#grid\r\n\t\t[dataSource]=\"data\"\r\n\t\t[allowSorting]=\"true\"\r\n\t\twidth=\"100%\"\r\n\t\t[pageSettings]=\"options\"\r\n\t\t[resizeSettings]=\"{ mode: 'Auto' }\"\r\n\t\t[allowExcelExport]=\"true\"\r\n\t\t[filterSettings]=\"filterSettings\"\r\n\t\t[allowResizing]=\"true\"\r\n\t\tshowColumnChooser=\"true\"\r\n\t\t[columnChooserSettings]=\"ColumnChooserSettings\"\r\n\t\t[aggregates]=\"aggregates\"\r\n\t\t(queryCellInfo)=\"customiseCell($event)\"\r\n\t\t(resizeStop)=\"resizeStop($event)\"\r\n\t\t(rowDataBound)=\"rowDataBound($event)\"\r\n\t\t(created)=\"created($event)\"\r\n\t\t(actionBegin)=\"actionBegin($event)\"\r\n\t\t(actionComplete)=\"actionComplete($event)\"\r\n\t\t(excelQueryCellInfo)=\"exportQueryCellInfo($event)\"\r\n\t>\r\n\t\t<e-columns>\r\n\t\t\t<e-column\r\n\t\t\t\t*ngIf=\"getLogoInfo('logoDocId', 'langValue')\"\r\n\t\t\t\t[headerText]=\"getLogoInfo('logoDocId', 'langValue')\"\r\n\t\t\t\twidth=\"120\"\r\n\t\t\t\ttextAlign=\"Center\"\r\n\t\t\t\t[visible]=\"!getLogoInfo('logoDocId', 'isHidden')\"\r\n\t\t\t>\r\n\t\t\t\t<ng-template #template let-data>\r\n\t\t\t\t\t<div class=\"image-\">\r\n\t\t\t\t\t\t<img\r\n\t\t\t\t\t\t\t[src]=\"getLogoImage(data.logoDocId)\"\r\n\t\t\t\t\t\t\t[alt]=\"data.companyName\"\r\n\t\t\t\t\t\t/>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t</ng-template>\r\n\t\t\t</e-column>\r\n\t\t\t<e-column\r\n\t\t\t\t*ngFor=\"let table of tableList\"\r\n\t\t\t\t[field]=\"table.colName\"\r\n\t\t\t\t[filter]=\"filter\"\r\n\t\t\t\t[headerText]=\"\r\n\t\t\t\t\t(table.displayName\r\n\t\t\t\t\t\t? table.displayName\r\n\t\t\t\t\t\t: translation[table.langCode]\r\n\t\t\t\t\t\t? translation[table.langCode]\r\n\t\t\t\t\t\t: table.langValue) +\r\n\t\t\t\t\t(table.addtionName ? ' ' + table.addtionName : '')\r\n\t\t\t\t\"\r\n\t\t\t\t[width]=\"table.width ? table.width : 200\"\r\n\t\t\t\tclipMode=\"EllipsisWithTooltip\"\r\n\t\t\t\t[visible]=\"table.visible\"\r\n\t\t\t\t[type]=\"\r\n\t\t\t\t\t['number', 'percentNum', 'percent'].includes(table.dataType)\r\n\t\t\t\t\t\t? 'number'\r\n\t\t\t\t\t\t: ['date', 'datetime'].includes(table.dataType)\r\n\t\t\t\t\t\t? 'date'\r\n\t\t\t\t\t\t: null\r\n\t\t\t\t\"\r\n\t\t\t\t[format]=\"getFormatOptions(table.colName)\"\r\n\t\t\t\t[textAlign]=\"getAlign(table)\"\r\n\t\t\t>\r\n\t\t\t\t<ng-template\r\n\t\t\t\t\t#template\r\n\t\t\t\t\tlet-data\r\n\t\t\t\t\t*ngIf=\"millionFields.includes(table.colName); else elseBlock\"\r\n\t\t\t\t>\r\n\t\t\t\t\t{{ data[table.colName] / 1000000 }}\r\n\t\t\t\t</ng-template>\r\n\t\t\t\t<ng-template #elseBlock>\r\n\t\t\t\t\t{{ data[table.colName] }}\r\n\t\t\t\t</ng-template>\r\n\r\n\t\t\t\t<!-- terms\u5217 \u663E\u793A\u6362\u884C\u7B26 -->\r\n\t\t\t\t<ng-template\r\n\t\t\t\t\t#template\r\n\t\t\t\t\tlet-data\r\n\t\t\t\t\t*ngIf=\"table.colName == 'terms'\"\r\n\t\t\t\t>\r\n\t\t\t\t\t<div\r\n\t\t\t\t\t\tstyle=\"white-space: pre-line\"\r\n\t\t\t\t\t\t[innerHTML]=\"data[table.colName]\"\r\n\t\t\t\t\t></div>\r\n\t\t\t\t</ng-template>\r\n\t\t\t</e-column>\r\n\t\t</e-columns>\r\n\t</ejs-grid>\r\n\t<ejs-pager\r\n\t\t#pager\r\n\t\t[currentPage]=\"currentPage\"\r\n\t\t[pageCount]=\"5\"\r\n\t\t[pageSize]=\"pageSize\"\r\n\t\t[pageSizes]=\"[10, 50, 100]\"\r\n\t\t[totalRecordsCount]=\"totalRecordsCount\"\r\n\t\t(click)=\"pageChanged($event)\"\r\n\t>\r\n\t</ejs-pager>\r\n\t<div class=\"full-box-mask\" *ngIf=\"pageLoading\">\r\n\t\t<mat-spinner\r\n\t\t\tstyle=\"z-index: 999\"\r\n\t\t\tmode=\"indeterminate\"\r\n\t\t\t[diameter]=\"24\"\r\n\t\t></mat-spinner>\r\n\t</div>\r\n</div>\r\n", styles: [":host{display:block;height:100%}.gadget-table{display:flex;flex-direction:column;padding:0 12px}.gadget-table .e-grid{height:0;flex:1}.gadget-table .e-grid .e-gridheader{border-top:1px solid!important;border-bottom:1px solid!important;border-color:#eaedf0!important;padding-right:0!important}.gadget-table .e-grid .e-gridheader .e-headercontent{border:none!important}.gadget-table .e-grid .e-gridheader ::ng-deep .e-headercell{padding:0!important;height:22px!important}.gadget-table .e-grid .e-gridheader ::ng-deep .e-headercell:last-child .e-headercelldiv{border-right:none}.gadget-table .e-grid .e-gridheader ::ng-deep .e-headercell:first-child .e-headercelldiv{border-right:none;padding-left:0!important}.gadget-table .e-grid .e-gridheader ::ng-deep .e-headercell .e-headercelldiv{height:22px!important;padding:4px 8px!important;border-right:1px solid #eaedf0;border-radius:unset}.gadget-table .e-grid .e-gridcontent{margin-right:-5px}.gadget-table .e-grid .e-gridcontent .e-content{overflow:overlay!important}.gadget-table .e-grid .e-gridcontent .e-rowcell{padding:0 8px!important;height:22px!important;line-height:20px!important;border-right:1px solid #eaedf0}.gadget-table .e-grid .e-gridcontent .e-rowcell:first-child{padding-left:0!important}.gadget-table .e-grid .e-gridcontent .e-rowcell:last-child{border-right:none}.gadget-table .e-pager{padding:12px 0!important}\n"] }]
1076
+ }], ctorParameters: function () { return [{ type: i1.DashboardPorletsService }, { type: i2.ApiList }, { type: i0.ChangeDetectorRef }, { type: i3.DashboardService }, { type: i0.ElementRef }, { type: undefined, decorators: [{
1077
+ type: Optional
1078
+ }, {
1079
+ type: Inject,
1080
+ args: [PBF_TOKEN]
1081
+ }] }, { type: undefined, decorators: [{
1082
+ type: Optional
1083
+ }, {
1084
+ type: Inject,
1085
+ args: [API_SERVICE_TOKEN]
1086
+ }] }]; }, propDecorators: { portlet: [{
1087
+ type: Input
1088
+ }], dashboard: [{
1089
+ type: Input
1090
+ }], portlets: [{
1091
+ type: Input
1092
+ }], grid: [{
1093
+ type: ViewChild,
1094
+ args: ["grid", { static: false }]
1095
+ }], pager: [{
1096
+ type: ViewChild,
1097
+ args: ["pager", { static: false }]
1098
+ }] } });
1099
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gadget-table.component.js","sourceRoot":"","sources":["../../../../../../../projects/raise-common-lib/src/lib/dashboard/gadget-group/gadget-table/gadget-table.component.ts","../../../../../../../projects/raise-common-lib/src/lib/dashboard/gadget-group/gadget-table/gadget-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n\tComponent,\r\n\tOnInit,\r\n\tInput,\r\n\tChangeDetectorRef,\r\n\tViewChild,\r\n\tElementRef,\r\n\tInject,\r\n\tOptional,\r\n} from \"@angular/core\";\r\nimport {\r\n\tPageSettingsModel,\r\n\tGridComponent,\r\n\tExcelExportService,\r\n\tQueryCellInfoEventArgs,\r\n\tToolbarItems,\r\n\tColumnChooserService,\r\n\tVirtualScrollService,\r\n\tFilterService,\r\n\tFilterSettingsModel,\r\n\tResizeService,\r\n\tExcelQueryCellInfoEventArgs,\r\n\tColumnChooserSettingsModel,\r\n\tPagerComponent,\r\n} from \"@syncfusion/ej2-angular-grids\";\r\n\r\nimport { DashboardPorletsService } from \"../../dashboardPorlets.service\";\r\nimport { ApiList } from \"../../api\";\r\nimport { DashboardService } from \"../../dashboard.service\";\r\nimport { Subscription } from \"rxjs\";\r\nimport { DataUtil } from \"@syncfusion/ej2-data\";\r\nimport { API_SERVICE_TOKEN, PBF_TOKEN } from \"../../../service/InjectionToken\";\r\n\r\nimport moment from \"moment\";\r\n\r\n@Component({\r\n\tselector: \"rs-gadget-table\",\r\n\ttemplateUrl: \"./gadget-table.component.html\",\r\n\tstyleUrls: [\"./gadget-table.component.scss\"],\r\n\tproviders: [\r\n\t\tExcelExportService,\r\n\t\tColumnChooserService,\r\n\t\tVirtualScrollService,\r\n\t\tFilterService,\r\n\t\tResizeService,\r\n\t],\r\n})\r\nexport class GadgetTableComponent implements OnInit {\r\n\t@Input() portlet;\r\n\t@Input() dashboard;\r\n\t@Input() portlets;\r\n\t@ViewChild(\"grid\", { static: false }) public grid: GridComponent;\r\n\t@ViewChild(\"pager\", { static: false }) public pager: PagerComponent;\r\n\tprivate config;\r\n\tpublic translation;\r\n\tprivate userInfo;\r\n\tprivate datePipeFormat;\r\n\tpublic filterSettings: FilterSettingsModel;\r\n\tpublic filter: Object;\r\n\tpublic data;\r\n\tpublic tableList;\r\n\tprivate tableList_footer = [];\r\n\tprivate formatSettings = [];\r\n\tprivate toolbarOptions: ToolbarItems[];\r\n\tpublic options: PageSettingsModel;\r\n\tpublic aggregates: object;\r\n\tprivate subscriptions: Subscription[] = [];\r\n\t// 已经保存过的列数据配置\r\n\tprivate configFields = [];\r\n\tprivate quarterFormat;\r\n\tprivate formatDates = [];\r\n\tpublic ColumnChooserSettings: ColumnChooserSettingsModel;\r\n\tpublic millionFields = [];\r\n\t// Pager\r\n\tpublic currentPage = 1; // 当前页数\r\n\tpublic pageSize = 10; // 一页显示行数\r\n\tpublic totalRecordsCount; // 总行数\r\n\tpublic filterContents; // 所有可以过滤的选项\r\n\tpublic sort; // 0表示降序 1表示升序\r\n\tpublic sortedColumn; // sort的列名\r\n\tpublic pageLoading;\r\n\tpublic currentFilterField; // 当前过滤的字段;\r\n\tpublic allFields;\r\n\thideTable: boolean;\r\n\tconstructor(\r\n\t\tpublic dashboardPorletsService: DashboardPorletsService,\r\n\t\tprivate api: ApiList,\r\n\t\tprivate ref: ChangeDetectorRef,\r\n\t\tprivate dashboardService: DashboardService,\r\n\t\tprivate el: ElementRef,\r\n\t\t@Optional() @Inject(PBF_TOKEN) private pbf: any,\r\n\t\t@Optional() @Inject(API_SERVICE_TOKEN) private http: any,\r\n\t) {}\r\n\tngOnInit() {\r\n\t\tthis.getInfo();\r\n\t\tthis.filterSettings = { type: \"Menu\" };\r\n\t\tthis.ColumnChooserSettings = { operator: \"contains\" };\r\n\t\tthis.filter = { type: \"CheckBox\" };\r\n\t\tthis.toolbarOptions = [\"ColumnChooser\"];\r\n\t\tthis.options = { pageSize: 10, pageSizes: [\"10\", \"50\", \"100\"] };\r\n\t\tthis.quarterFormat = this.setQuarterFormat();\r\n\t\tthis.getTableData();\r\n\t}\r\n\r\n\tngAfterViewInit(): void {\r\n\t\tthis.subscriptions.push(\r\n\t\t\tthis.dashboardService.getchangeTable().subscribe((updated) => {\r\n\t\t\t\tif (updated) {\r\n\t\t\t\t\tthis.pageSize = 10;\r\n\t\t\t\t\tthis.currentPage = 1;\r\n\t\t\t\t\tthis.getTableData();\r\n\t\t\t\t}\r\n\t\t\t})\r\n\t\t);\r\n\r\n\t\tthis.subscriptions.push(\r\n\t\t\tthis.dashboardService.getRefreshGadget().subscribe((e) => {\r\n\t\t\t\tif (!e) {\r\n\t\t\t\t\treturn;\r\n\t\t\t\t}\r\n\t\t\t\tconst id = e[\"newId\"];\r\n\t\t\t\tif (id === this.portlet.newId || id === this.portlet.id) {\r\n\t\t\t\t\tthis.pageSize = 10;\r\n\t\t\t\t\tthis.currentPage = 1;\r\n\t\t\t\t\tthis.getTableData();\r\n\t\t\t\t}\r\n\t\t\t})\r\n\t\t);\r\n\r\n\t\tthis.subscriptions.push(\r\n\t\t\tthis.dashboardService.getStartRefresh().subscribe((dashboardId) => {\r\n\t\t\t\tif (dashboardId === this.dashboard.id) {\r\n\t\t\t\t\tthis.pageLoading = true;\r\n\t\t\t\t\tthis.ref.markForCheck();\r\n\t\t\t\t}\r\n\t\t\t})\r\n\t\t);\r\n\r\n\t\tthis.subscriptions.push(\r\n\t\t\tthis.dashboardService.getUpdated().subscribe((newId) => {\r\n\t\t\t\tif (newId === this.portlet.newId || newId === this.portlet.id) {\r\n\t\t\t\t\tthis.pageSize = 10;\r\n\t\t\t\t\tthis.currentPage = 1;\r\n\t\t\t\t\tthis.getTableData();\r\n\t\t\t\t\tif (this.grid) {\r\n\t\t\t\t\t\tthis.grid.columns.forEach((item) => {\r\n\t\t\t\t\t\t\tthis.tableList.forEach((table) => {\r\n\t\t\t\t\t\t\t\tif (\r\n\t\t\t\t\t\t\t\t\titem.field === table.colName &&\r\n\t\t\t\t\t\t\t\t\ttable.format &&\r\n\t\t\t\t\t\t\t\t\ttable.format.length &&\r\n\t\t\t\t\t\t\t\t\ttable.format[0].formatChecked\r\n\t\t\t\t\t\t\t\t) {\r\n\t\t\t\t\t\t\t\t\titem.headerText =\r\n\t\t\t\t\t\t\t\t\t\ttable.displayName ||\r\n\t\t\t\t\t\t\t\t\t\ttable.langValue ||\r\n\t\t\t\t\t\t\t\t\t\tthis.translation[table.langCode] ||\r\n\t\t\t\t\t\t\t\t\t\ttable.langCode;\r\n\t\t\t\t\t\t\t\t\tif (\r\n\t\t\t\t\t\t\t\t\t\t[\"number\", \"percent\"].includes(\r\n\t\t\t\t\t\t\t\t\t\t\ttable.dataType\r\n\t\t\t\t\t\t\t\t\t\t)\r\n\t\t\t\t\t\t\t\t\t) {\r\n\t\t\t\t\t\t\t\t\t\tlet formatString;\r\n\t\t\t\t\t\t\t\t\t\tif (table.dataType === \"number\") {\r\n\t\t\t\t\t\t\t\t\t\t\tformatString =\r\n\t\t\t\t\t\t\t\t\t\t\t\tthis.pbf.formatNumber(\r\n\t\t\t\t\t\t\t\t\t\t\t\t\ttable.format[0]\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t.selectedFormat\r\n\t\t\t\t\t\t\t\t\t\t\t\t);\r\n\t\t\t\t\t\t\t\t\t\t} else if (\r\n\t\t\t\t\t\t\t\t\t\t\ttable.dataType === \"percent\"\r\n\t\t\t\t\t\t\t\t\t\t) {\r\n\t\t\t\t\t\t\t\t\t\t\tformatString =\r\n\t\t\t\t\t\t\t\t\t\t\t\tthis.pbf.formatPercent(\r\n\t\t\t\t\t\t\t\t\t\t\t\t\ttable.format[0]\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t.selectedFormat\r\n\t\t\t\t\t\t\t\t\t\t\t\t);\r\n\t\t\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t\t\t\titem.format = formatString;\r\n\t\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t});\r\n\t\t\t\t\t\t});\r\n\t\t\t\t\t}\r\n\t\t\t\t\t// this.grid.refreshColumns();\r\n\t\t\t\t}\r\n\t\t\t})\r\n\t\t);\r\n\r\n\t\tthis.subscriptions.push(\r\n\t\t\tthis.dashboardService.getTableFormat().subscribe((data) => {\r\n\t\t\t\tif (data === this.portlet.newId) {\r\n\t\t\t\t\tthis.getTableData();\r\n\t\t\t\t\tthis.grid.columns.forEach((item) => {\r\n\t\t\t\t\t\tthis.tableList.forEach((table) => {\r\n\t\t\t\t\t\t\tif (\r\n\t\t\t\t\t\t\t\titem.field === table.colName &&\r\n\t\t\t\t\t\t\t\ttable.format &&\r\n\t\t\t\t\t\t\t\ttable.format.length &&\r\n\t\t\t\t\t\t\t\ttable.format[0].formatChecked\r\n\t\t\t\t\t\t\t) {\r\n\t\t\t\t\t\t\t\titem.headerText =\r\n\t\t\t\t\t\t\t\t\ttable.displayName ||\r\n\t\t\t\t\t\t\t\t\ttable.langValue ||\r\n\t\t\t\t\t\t\t\t\tthis.translation[table.langCode] ||\r\n\t\t\t\t\t\t\t\t\ttable.langCode;\r\n\t\t\t\t\t\t\t\tif (\r\n\t\t\t\t\t\t\t\t\t[\"number\", \"percent\"].includes(\r\n\t\t\t\t\t\t\t\t\t\ttable.dataType\r\n\t\t\t\t\t\t\t\t\t)\r\n\t\t\t\t\t\t\t\t) {\r\n\t\t\t\t\t\t\t\t\tlet formatString;\r\n\t\t\t\t\t\t\t\t\tif (table.dataType === \"number\") {\r\n\t\t\t\t\t\t\t\t\t\tformatString = this.pbf.formatNumber(\r\n\t\t\t\t\t\t\t\t\t\t\ttable.format[0].selectedFormat\r\n\t\t\t\t\t\t\t\t\t\t);\r\n\t\t\t\t\t\t\t\t\t} else if (table.dataType === \"percent\") {\r\n\t\t\t\t\t\t\t\t\t\tformatString = this.pbf.formatPercent(\r\n\t\t\t\t\t\t\t\t\t\t\ttable.format[0].selectedFormat\r\n\t\t\t\t\t\t\t\t\t\t);\r\n\t\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t\t\titem.format = formatString;\r\n\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t});\r\n\t\t\t\t\t});\r\n\t\t\t\t\tthis.hideTable = true;\r\n\t\t\t\t\tthis.pageLoading = true;\r\n\t\t\t\t\tthis.ref.markForCheck();\r\n\t\t\t\t\tsetTimeout(() => {\r\n\t\t\t\t\t\tthis.hideTable = false;\r\n\t\t\t\t\t\tthis.pageLoading = false;\r\n\t\t\t\t\t\tthis.ref.markForCheck();\r\n\t\t\t\t\t}, 300);\r\n\t\t\t\t}\r\n\t\t\t})\r\n\t\t);\r\n\t}\r\n\r\n\tngOnDestroy(): void {\r\n\t\tthis.subscriptions.forEach((sub) => sub.unsubscribe());\r\n\t}\r\n\r\n\tpublic customiseCell(args: QueryCellInfoEventArgs) {\r\n\t\tif (args.column.type === \"date\" || args.column.type === \"dateTime\") {\r\n\t\t\tconst { field } = args.column;\r\n\t\t\tif (!args.data[field]) {\r\n\t\t\t\targs.column.type = \"string\";\r\n\t\t\t\targs.column.format = \"\";\r\n\t\t\t}\r\n\t\t}\r\n\t\tlet queryCell =\r\n\t\t\tthis.tableList &&\r\n\t\t\tthis.tableList.filter(\r\n\t\t\t\t(item) => item.colName === args.column.field\r\n\t\t\t)[0];\r\n\r\n\t\tif (\r\n\t\t\tqueryCell &&\r\n\t\t\tqueryCell.format &&\r\n\t\t\tqueryCell.format.length &&\r\n\t\t\tqueryCell.format[0].formatChecked\r\n\t\t) {\r\n\t\t\t// SMP2-3416 0的format start\r\n\t\t\tif (\r\n\t\t\t\t[2, 5, 8, 11, 14, 17].includes(\r\n\t\t\t\t\tqueryCell.format[0].selectedFormat\r\n\t\t\t\t) &&\r\n\t\t\t\targs.data[queryCell.colName] === 0\r\n\t\t\t)\r\n\t\t\t\targs.cell.innerHTML = \"-\";\r\n\t\t\tif (\r\n\t\t\t\t[3, 6, 9, 12, 15, 18].includes(\r\n\t\t\t\t\tqueryCell.format[0].selectedFormat\r\n\t\t\t\t) &&\r\n\t\t\t\targs.data[queryCell.colName] === 0\r\n\t\t\t)\r\n\t\t\t\targs.cell.innerHTML = \"\";\r\n\t\t\t// SMP2-3416 0的format end\r\n\t\t}\r\n\r\n\t\tif (\r\n\t\t\tqueryCell &&\r\n\t\t\tqueryCell.format &&\r\n\t\t\tqueryCell.format.length &&\r\n\t\t\tqueryCell.format[0].fontSettingChecked\r\n\t\t) {\r\n\t\t\tif (\r\n\t\t\t\tqueryCell.format[0].formatChecked &&\r\n\t\t\t\tqueryCell.format[0].compareSelect\r\n\t\t\t) {\r\n\t\t\t\tlet cellData = args.data[args.column.field];\r\n\t\t\t\tlet condition: Boolean = false;\r\n\t\t\t\tswitch (queryCell.format[0].compareSelect) {\r\n\t\t\t\t\tcase \"LessThan\":\r\n\t\t\t\t\t\tcondition =\r\n\t\t\t\t\t\t\tcellData <\r\n\t\t\t\t\t\t\tNumber(queryCell.format[0].compareValue1);\r\n\t\t\t\t\t\tbreak;\r\n\t\t\t\t\tcase \"LessThanOrEqualTo\":\r\n\t\t\t\t\t\tcondition =\r\n\t\t\t\t\t\t\tcellData <=\r\n\t\t\t\t\t\t\tNumber(queryCell.format[0].compareValue1);\r\n\t\t\t\t\t\tbreak;\r\n\t\t\t\t\tcase \"GreaterThan\":\r\n\t\t\t\t\t\tcondition =\r\n\t\t\t\t\t\t\tcellData >\r\n\t\t\t\t\t\t\tNumber(queryCell.format[0].compareValue1);\r\n\t\t\t\t\t\tbreak;\r\n\t\t\t\t\tcase \"GreaterThanOrEqualTo\":\r\n\t\t\t\t\t\tcondition =\r\n\t\t\t\t\t\t\tcellData >=\r\n\t\t\t\t\t\t\tNumber(queryCell.format[0].compareValue1);\r\n\t\t\t\t\t\tbreak;\r\n\t\t\t\t\tcase \"Equals\":\r\n\t\t\t\t\t\tcondition =\r\n\t\t\t\t\t\t\tcellData ===\r\n\t\t\t\t\t\t\tNumber(queryCell.format[0].compareValue1);\r\n\t\t\t\t\t\tbreak;\r\n\t\t\t\t\tcase \"NotEquals\":\r\n\t\t\t\t\t\tcondition =\r\n\t\t\t\t\t\t\tcellData !==\r\n\t\t\t\t\t\t\tNumber(queryCell.format[0].compareValue1);\r\n\t\t\t\t\t\tbreak;\r\n\t\t\t\t\tcase \"Between\":\r\n\t\t\t\t\t\tcondition =\r\n\t\t\t\t\t\t\tcellData >=\r\n\t\t\t\t\t\t\t\tNumber(queryCell.format[0].compareValue1) &&\r\n\t\t\t\t\t\t\tcellData <= queryCell.format[0].compareValue2;\r\n\t\t\t\t\t\tbreak;\r\n\t\t\t\t\tcase \"NotBetween\":\r\n\t\t\t\t\t\tcondition =\r\n\t\t\t\t\t\t\tcellData <\r\n\t\t\t\t\t\t\t\tNumber(queryCell.format[0].compareValue1) &&\r\n\t\t\t\t\t\t\tcellData >\r\n\t\t\t\t\t\t\t\tNumber(queryCell.format[0].compareValue2);\r\n\t\t\t\t\t\tbreak;\r\n\t\t\t\t\tdefault:\r\n\t\t\t\t\t\tbreak;\r\n\t\t\t\t}\r\n\t\t\t\tif (condition) this.cellAddStyle(args, queryCell);\r\n\t\t\t} else this.cellAddStyle(args, queryCell);\r\n\t\t}\r\n\r\n\t\t// date format about quarterly\r\n\t\tlet dateFields =\r\n\t\t\tthis.formatDates &&\r\n\t\t\tthis.formatDates.map((el) => {\r\n\t\t\t\treturn el.name;\r\n\t\t\t});\r\n\t\tif (\r\n\t\t\targs.column.field &&\r\n\t\t\tdateFields &&\r\n\t\t\tdateFields.includes(args.column.field) &&\r\n\t\t\tqueryCell.format &&\r\n\t\t\tqueryCell.format.length &&\r\n\t\t\tqueryCell.format[0].formatChecked\r\n\t\t) {\r\n\t\t\tlet date = new Date(args.data[args.column.field]);\r\n\t\t\tlet quarter =\r\n\t\t\t\tMath.floor((date.getMonth() + 1) % 3) == 0\r\n\t\t\t\t\t? Math.floor((date.getMonth() + 1) / 3)\r\n\t\t\t\t\t: Math.floor((date.getMonth() + 1) / 3) + 1;\r\n\r\n\t\t\tlet format;\r\n\r\n\t\t\tthis.formatDates.map((el) => {\r\n\t\t\t\tif (el.name == args.column.field) format = el.format;\r\n\t\t\t});\r\n\t\t\tlet year: any;\r\n\t\t\tswitch (format) {\r\n\t\t\t\tcase \"Q1 2021\":\r\n\t\t\t\t\tyear = date.getFullYear();\r\n\t\t\t\t\targs.cell.innerHTML = \"Q\" + quarter + \" \" + year;\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase \"Q1 21\":\r\n\t\t\t\t\tyear = (date as any).getYear() - 100;\r\n\t\t\t\t\targs.cell.innerHTML = \"Q\" + quarter + \" \" + year;\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase \"2021 Q1\":\r\n\t\t\t\t\tyear = date.getFullYear();\r\n\t\t\t\t\targs.cell.innerHTML = year + \" \" + \"Q\" + quarter;\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase \"21 Q1\":\r\n\t\t\t\t\tyear = (date as any).getYear() - 100;\r\n\t\t\t\t\targs.cell.innerHTML = year + \" \" + \"Q\" + quarter;\r\n\t\t\t\t\tbreak;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tif (args.column.field)\r\n\t\t\tif (\r\n\t\t\t\t[\"MOIC\", \"DPI\", \"TVPI\", \"RVPI\", \"PIC\", \"Multiple\"].includes(\r\n\t\t\t\t\targs.column.field\r\n\t\t\t\t)\r\n\t\t\t) {\r\n\t\t\t\tif (args.data && args.data[args.column.field]) {\r\n\t\t\t\t\t// 渲染过一次后，就用原数据就好了\r\n\t\t\t\t\targs.cell.innerHTML = `<div>${\r\n\t\t\t\t\t\targs.data[args.column.field].indexOf instanceof Function\r\n\t\t\t\t\t\t\t? args.data[args.column.field]\r\n\t\t\t\t\t\t\t: this.getXTxt(args.column.field, args.data)\r\n\t\t\t\t\t}\r\n\t\t\t\t</div>`;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\tif (\r\n\t\t\targs.column &&\r\n\t\t\targs.column.format &&\r\n\t\t\targs.column.format === \"dd-MMM-yyyy\"\r\n\t\t) {\r\n\t\t\targs.cell.innerHTML = `<div>${moment(\r\n\t\t\t\targs.data[args.column.field]\r\n\t\t\t).format(\"DD-MMM-yyyy\")}</div>`;\r\n\t\t}\r\n\t}\r\n\r\n\tprivate cellAddStyle(args, queryCell) {\r\n\t\tif (queryCell.format[0].fontSettingChecked) {\r\n\t\t\tlet formatCellData = args.data[args.column.field];\r\n\t\t\tif (Math.sign(formatCellData) !== 0)\r\n\t\t\t\tif (Math.sign(formatCellData) === -1) {\r\n\t\t\t\t\targs.cell.style.cssText += `color: ${queryCell.format[0].negaFontColor} !important`;\r\n\t\t\t\t\targs.cell.style.cssText += `font-size: ${queryCell.format[0].negaFontSizeValue} !important`;\r\n\t\t\t\t\targs.cell.style.cssText += `font-family: ${queryCell.format[0].negaFontFamilyValue} !important`;\r\n\t\t\t\t\targs.cell.style.cssText += `background-color: ${queryCell.format[0].negaBackgroundColor} !important`;\r\n\t\t\t\t} else {\r\n\t\t\t\t\targs.cell.style.cssText += `color: ${queryCell.format[0].fontColor} !important`;\r\n\t\t\t\t\targs.cell.style.cssText += `font-size: ${queryCell.format[0].fontSizeValue} !important`;\r\n\t\t\t\t\targs.cell.style.cssText += `font-family: ${queryCell.format[0].fontFamilyValue} !important`;\r\n\t\t\t\t\targs.cell.style.cssText += `background-color: ${queryCell.format[0].backgroundColor} !important`;\r\n\t\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\tprivate async getTableData() {\r\n\t\tthis.pageLoading = false;\r\n\t\tthis.config = JSON.parse(this.portlet.config);\r\n\t\tif (this.config.fields) {\r\n\t\t\tif (this.dashboardPorletsService.allFieldsObj[this.portlet.id]) {\r\n\t\t\t\tthis.config.fields =\r\n\t\t\t\t\tthis.dashboardPorletsService.setConfigFields(\r\n\t\t\t\t\t\tthis.dashboardPorletsService.allFieldsObj[\r\n\t\t\t\t\t\t\tthis.portlet.id\r\n\t\t\t\t\t\t],\r\n\t\t\t\t\t\tthis.config.fields\r\n\t\t\t\t\t);\r\n\t\t\t}\r\n\t\t\tthis.configFields = [...this.config.fields];\r\n\t\t}\r\n\t\t// ejs-grid 坑点：列头数据，colName中不能含有空格\r\n\t\t// GetSchema接口中获取的所有列的dataType和GetPortletDataOrCreate接口中返回的数据类型必须保持一致，否则会导致数据总量显示，但是列表中无数据\r\n\t\tconst data = this.dashboardPorletsService.getResultByDataTable(\r\n\t\t\tthis.portlet,\r\n\t\t\tfalse,\r\n\t\t\tfalse,\r\n\t\t\tthis.dashboard.id\r\n\t\t);\r\n\t\tthis.data = data ? DataUtil.parse.parseJson(data) : [];\r\n\t\tthis.data = this.data.map((item) => {\r\n\t\t\tconst translationMap = {\r\n\t\t\t\tIndirect: this.translation.INDIRECT || \"Indirect\",\r\n\t\t\t\tDirect: this.translation.DIRECT || \"Direct\",\r\n\t\t\t};\r\n\t\t\treturn {\r\n\t\t\t\t...item,\r\n\t\t\t\tDirectIndirect:\r\n\t\t\t\t\ttranslationMap[item.DirectIndirect] || item.DirectIndirect,\r\n\t\t\t};\r\n\t\t});\r\n\t\tthis.totalRecordsCount =\r\n\t\t\tthis.dashboardPorletsService.getResultByDataTable(\r\n\t\t\t\tthis.portlet,\r\n\t\t\t\ttrue,\r\n\t\t\t\ttrue,\r\n\t\t\t\tthis.dashboard.id\r\n\t\t\t);\r\n\r\n\t\tif (\r\n\t\t\tthis.config &&\r\n\t\t\tthis.configFields &&\r\n\t\t\tthis.configFields.length &&\r\n\t\t\tthis.data &&\r\n\t\t\tthis.data.length\r\n\t\t) {\r\n\t\t\tthis.formatSettings = [];\r\n\t\t\tthis.formatDates = [];\r\n\t\t\tthis.configFields.map((el) => {\r\n\t\t\t\tif (\r\n\t\t\t\t\t[\"number\", \"percent\", \"percentNum\", \"multiple\"].includes(\r\n\t\t\t\t\t\tel.dataType\r\n\t\t\t\t\t)\r\n\t\t\t\t) {\r\n\t\t\t\t\tlet format = this.getNumFormat(el);\r\n\t\t\t\t\tconst formatData = {\r\n\t\t\t\t\t\tname: el.colName,\r\n\t\t\t\t\t\tformat: format,\r\n\t\t\t\t\t};\r\n\t\t\t\t\tthis.formatSettings.push(formatData);\r\n\t\t\t\t}\r\n\t\t\t\tif (el.dataType == \"datetime\" || el.dataType == \"date\") {\r\n\t\t\t\t\tlet format = \"\";\r\n\t\t\t\t\tif (\r\n\t\t\t\t\t\tel.format &&\r\n\t\t\t\t\t\tel.format.length &&\r\n\t\t\t\t\t\tel.format[0].formatChecked\r\n\t\t\t\t\t) {\r\n\t\t\t\t\t\tif (el.format[0].dateType == \"Quarter\") {\r\n\t\t\t\t\t\t\tlet format_ = el.format[0].selectedFormatDisplay;\r\n\t\t\t\t\t\t\tlet formatInfo = this.quarterFormat.filter(\r\n\t\t\t\t\t\t\t\t(qur) => qur.value == format_\r\n\t\t\t\t\t\t\t);\r\n\t\t\t\t\t\t\tif (formatInfo.length) {\r\n\t\t\t\t\t\t\t\tformat = formatInfo[0].format;\r\n\t\t\t\t\t\t\t} else {\r\n\t\t\t\t\t\t\t\tconst formatData = {\r\n\t\t\t\t\t\t\t\t\tname: el.colName,\r\n\t\t\t\t\t\t\t\t\tformat: format_,\r\n\t\t\t\t\t\t\t\t\ttype: \"date\",\r\n\t\t\t\t\t\t\t\t};\r\n\t\t\t\t\t\t\t\tthis.formatDates.push(formatData);\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t} else if (el.format[0].dateType == \"Date\") {\r\n\t\t\t\t\t\t\tlet fromIdx =\r\n\t\t\t\t\t\t\t\tel.format[0].selectedFormatDisplay.indexOf(\"(\");\r\n\t\t\t\t\t\t\tlet toIdx =\r\n\t\t\t\t\t\t\t\tel.format[0].selectedFormatDisplay.indexOf(\")\");\r\n\t\t\t\t\t\t\tlet format_ =\r\n\t\t\t\t\t\t\t\tel.format[0].selectedFormatDisplay.slice(\r\n\t\t\t\t\t\t\t\t\tfromIdx + 1,\r\n\t\t\t\t\t\t\t\t\ttoIdx\r\n\t\t\t\t\t\t\t\t);\r\n\t\t\t\t\t\t\tformat = this.getDateFormat(format_);\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}\r\n\t\t\t\t\tif (!format) {\r\n\t\t\t\t\t\tconst formatData = {\r\n\t\t\t\t\t\t\tname: el.colName,\r\n\t\t\t\t\t\t\tformat: this.datePipeFormat,\r\n\t\t\t\t\t\t\ttype: \"date\",\r\n\t\t\t\t\t\t};\r\n\t\t\t\t\t\tthis.formatSettings.push(formatData);\r\n\t\t\t\t\t} else {\r\n\t\t\t\t\t\tconst formatData = {\r\n\t\t\t\t\t\t\tname: el.colName,\r\n\t\t\t\t\t\t\tformat: format,\r\n\t\t\t\t\t\t\ttype: \"date\",\r\n\t\t\t\t\t\t};\r\n\t\t\t\t\t\tthis.formatSettings.push(formatData);\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t});\r\n\t\t\tconst newTableList = [];\r\n\t\t\tthis.configFields.forEach((item) => {\r\n\t\t\t\tif (!item.isHidden) {\r\n\t\t\t\t\tconst obj = {\r\n\t\t\t\t\t\t...item,\r\n\t\t\t\t\t\tdataType: [\r\n\t\t\t\t\t\t\t\"MOIC\",\r\n\t\t\t\t\t\t\t\"DPI\",\r\n\t\t\t\t\t\t\t\"TVPI\",\r\n\t\t\t\t\t\t\t\"RVPI\",\r\n\t\t\t\t\t\t\t\"PIC\",\r\n\t\t\t\t\t\t\t\"Multiple\",\r\n\t\t\t\t\t\t].includes(item.colName)\r\n\t\t\t\t\t\t\t? \"string\"\r\n\t\t\t\t\t\t\t: item[\"dataType\"],\r\n\t\t\t\t\t};\r\n\t\t\t\t\tif (\r\n\t\t\t\t\t\tArray.isArray(item.format) &&\r\n\t\t\t\t\t\titem.format.length > 0 &&\r\n\t\t\t\t\t\titem.format[0].formatChecked\r\n\t\t\t\t\t) {\r\n\t\t\t\t\t\tobj.displayName = item.format[0].displayName;\r\n\t\t\t\t\t}\r\n\t\t\t\t\tnewTableList.push(obj);\r\n\t\t\t\t}\r\n\t\t\t});\r\n\t\t\tthis.tableList = newTableList;\r\n\t\t\tconst typeMap = {};\r\n\t\t\tthis.tableList.forEach((col) => {\r\n\t\t\t\tif (col.dataType === \"number\") {\r\n\t\t\t\t\ttypeMap[col.colName] = true;\r\n\t\t\t\t}\r\n\t\t\t});\r\n\t\t\tthis.data.forEach((_data) => {\r\n\t\t\t\tObject.keys(typeMap).forEach((key) => {\r\n\t\t\t\t\t_data[key] =\r\n\t\t\t\t\t\t_data[key] === null\r\n\t\t\t\t\t\t\t? null\r\n\t\t\t\t\t\t\t: this.pbf.bankersRounding(Number(_data[key]));\r\n\t\t\t\t});\r\n\t\t\t});\r\n\t\t}\r\n\t\tif (this.config.filterSettings && this.config.filterSettings.length) {\r\n\t\t\tthis.filterSettings.columns = this.config.filterSettings;\r\n\t\t}\r\n\t\tthis.ref.markForCheck();\r\n\t\t// this.ref.detectChanges();\r\n\t}\r\n\r\n\tpublic getFormatOptions(colName) {\r\n\t\tlet res =\r\n\t\t\tthis.formatSettings &&\r\n\t\t\tthis.formatSettings.filter((el) => el.name === colName);\r\n\t\tif (res && res.length) return res[0].format;\r\n\t}\r\n\r\n\tprivate getInfo() {\r\n\t\tthis.translation = JSON.parse(localStorage.getItem(\"translation\"));\r\n\t\tthis.userInfo = JSON.parse(localStorage.getItem(\"userInfo\"));\r\n\t\tthis.datePipeFormat = localStorage.getItem(\"datePipe\");\r\n\t}\r\n\r\n\tpublic actionComplete(args) {\r\n\t\tif (args.requestType === \"filtering\") {\r\n\t\t\tif (args.action === \"filter\") {\r\n\t\t\t\tlet filteredvalues = [];\r\n\t\t\t\tfor (let item of args.columns) {\r\n\t\t\t\t\t// if (item.type === \"datetime\" || item.type === \"date\") {\r\n\t\t\t\t\t// \titem.value = this.pbf.time(item.value);\r\n\t\t\t\t\t// }\r\n\t\t\t\t\tfilteredvalues.push({\r\n\t\t\t\t\t\tfield: item.field,\r\n\t\t\t\t\t\tmatchCase: item.matchCase,\r\n\t\t\t\t\t\toperator: item.operator,\r\n\t\t\t\t\t\tpredicate: item.predicate,\r\n\t\t\t\t\t\ttype: item.type,\r\n\t\t\t\t\t\tvalue: item.value,\r\n\t\t\t\t\t});\r\n\t\t\t\t}\r\n\t\t\t\tthis.config.filterSettings = filteredvalues;\r\n\t\t\t} else {\r\n\t\t\t\tthis.currentFilterField = \"\";\r\n\t\t\t\tthis.config.filterSettings = [];\r\n\t\t\t}\r\n\t\t\tconst portlet = this.portlet;\r\n\t\t\tportlet.config = JSON.stringify(this.config);\r\n\t\t\tconst index = this.portlets.findIndex(\r\n\t\t\t\t(x) => x.newId === portlet.newId\r\n\t\t\t);\r\n\t\t\tif (index > -1) this.portlets[index] = portlet;\r\n\t\t\tthis.currentPage = 1;\r\n\t\t\tthis.reloadTableData({\r\n\t\t\t\tpage: this.currentPage,\r\n\t\t\t\tsize: this.pageSize,\r\n\t\t\t\tsortedColumn:\r\n\t\t\t\t\tthis.sortedColumn === null ? undefined : this.sortedColumn,\r\n\t\t\t\tsort: this.sort === null ? undefined : this.sort,\r\n\t\t\t});\r\n\t\t}\r\n\t\t// 列选择事件\r\n\t\tif (args.requestType === \"columnstate\") {\r\n\t\t\tconst hideColumns = this.grid.getHiddenColumns();\r\n\t\t\tthis.configFields.map((el) => (el.visible = true));\r\n\t\t\tif (hideColumns.length > 0) {\r\n\t\t\t\tfor (let hideitem of hideColumns) {\r\n\t\t\t\t\tif (hideitem.field)\r\n\t\t\t\t\t\tthis.configFields.filter(\r\n\t\t\t\t\t\t\t(el) => el.colName === hideitem.field\r\n\t\t\t\t\t\t)[0].visible = false;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\tthis.config.fields = JSON.parse(JSON.stringify(this.configFields));\r\n\t\t\tthis.portlet.config = JSON.stringify(this.config);\r\n\t\t\tconst index = this.portlets.findIndex(\r\n\t\t\t\t(x) => x.newId === this.portlet.newId\r\n\t\t\t);\r\n\t\t\tthis.portlets[index].config = JSON.stringify(this.config);\r\n\t\t\tthis.reloadTableData(\r\n\t\t\t\t{\r\n\t\t\t\t\tpage: this.currentPage,\r\n\t\t\t\t\tsize: this.pageSize,\r\n\t\t\t\t\tsortedColumn:\r\n\t\t\t\t\t\tthis.sortedColumn === null\r\n\t\t\t\t\t\t\t? undefined\r\n\t\t\t\t\t\t\t: this.sortedColumn,\r\n\t\t\t\t\tsort: this.sort === null ? undefined : this.sort,\r\n\t\t\t\t},\r\n\t\t\t\ttrue\r\n\t\t\t);\r\n\t\t}\r\n\t}\r\n\r\n\tpublic actionBegin(args) {\r\n\t\tif (args.requestType === \"filterchoicerequest\") {\r\n\t\t\tconst checkboxfilter = this.el.nativeElement.querySelector(\r\n\t\t\t\t\".e-checkboxfilter\"\r\n\t\t\t) as HTMLElement;\r\n\t\t\tif (checkboxfilter) {\r\n\t\t\t\tif (this.portlet.height == 1) {\r\n\t\t\t\t\targs.filterModel.dlg.style.minHeight = \"calc(100% - 12px)\";\r\n\t\t\t\t\targs.filterModel.dlg.style.maxHeight = \"calc(100% - 12px)\";\r\n\t\t\t\t} else {\r\n\t\t\t\t\targs.filterModel.dlg.style.minHeight = \"350px\";\r\n\t\t\t\t\targs.filterModel.dlg.style.maxHeight = \"350px\";\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t\tif (\r\n\t\t\targs.requestType == \"filterchoicerequest\" ||\r\n\t\t\targs.requestType === \"filtersearchbegin\"\r\n\t\t) {\r\n\t\t\targs.filterChoiceCount = 3000;\r\n\t\t}\r\n\r\n\t\t// 显示过滤的选项\r\n\t\tif (\r\n\t\t\targs.requestType === \"filterbeforeopen\" &&\r\n\t\t\tthis.currentFilterField !== args.columnName\r\n\t\t) {\r\n\t\t\targs.cancel = true;\r\n\t\t\tlet columnFilter = [];\r\n\t\t\tlet field = args.columnName;\r\n\t\t\tif (this.config.filterSettings.length) {\r\n\t\t\t\tcolumnFilter = this.config.filterSettings.filter(\r\n\t\t\t\t\t(x) => x.field !== field\r\n\t\t\t\t);\r\n\t\t\t}\r\n\t\t\tlet data = {\r\n\t\t\t\tdashboardDataTableId: this.portlet.dashboardDataTableId,\r\n\t\t\t\tdisplayColumnFilter: field,\r\n\t\t\t\tcolumnFilter: columnFilter,\r\n\t\t\t};\r\n\t\t\tthis.http.post(\r\n\t\t\t\tthis.api.urlList.GetDistinctColumnValsByPortletDataParam,\r\n\t\t\t\tdata,\r\n\t\t\t\t(res) => {\r\n\t\t\t\t\tthis.pageLoading = false;\r\n\t\t\t\t\tlet curFomart = this.formatSettings.find(\r\n\t\t\t\t\t\t(x) => x.name === field\r\n\t\t\t\t\t);\r\n\t\t\t\t\tif (\r\n\t\t\t\t\t\tcurFomart &&\r\n\t\t\t\t\t\t[\"date\", \"datetime\"].includes(curFomart.type)\r\n\t\t\t\t\t) {\r\n\t\t\t\t\t\tres = res[field].map((x) => new Date(x));\r\n\t\t\t\t\t} else {\r\n\t\t\t\t\t\tres = res[field];\r\n\t\t\t\t\t}\r\n\t\t\t\t\tthis.currentFilterField = args.columnName;\r\n\t\t\t\t\tthis.filterContents = res;\r\n\t\t\t\t\tthis.grid.filterModule.openMenuByField(args.columnName);\r\n\t\t\t\t\tif (columnFilter.length) {\r\n\t\t\t\t\t\tthis.grid.clearFiltering();\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t);\r\n\t\t\tif (\r\n\t\t\t\targs.requestType === \"filterbeforeopen\" &&\r\n\t\t\t\tthis.currentFilterField === args.columnName\r\n\t\t\t) {\r\n\t\t\t\tlet columnName = args.columnName;\r\n\t\t\t\tif (this.filterContents) {\r\n\t\t\t\t\tlet curResult = this.filterContents;\r\n\t\t\t\t\tlet filterOptions = curResult.map((x) => {\r\n\t\t\t\t\t\tlet obj: any = {};\r\n\t\t\t\t\t\tobj[columnName] = x;\r\n\t\t\t\t\t\treturn obj;\r\n\t\t\t\t\t});\r\n\t\t\t\t\targs.filterModel.options.dataSource = filterOptions;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\r\n\t\t\t// 处理排序\r\n\t\t\tif (args.requestType === \"sorting\") {\r\n\t\t\t\tif (args.columnName) {\r\n\t\t\t\t\tthis.sort = args.direction === \"Ascending\" ? 1 : 0;\r\n\t\t\t\t\tthis.sortedColumn = args.columnName;\r\n\t\t\t\t\tthis.reloadTableData({\r\n\t\t\t\t\t\tpage: this.currentPage,\r\n\t\t\t\t\t\tsize: this.pageSize,\r\n\t\t\t\t\t\tsort: this.sort,\r\n\t\t\t\t\t\tsortedColumn: this.sortedColumn,\r\n\t\t\t\t\t});\r\n\t\t\t\t} else {\r\n\t\t\t\t\tthis.sort = null;\r\n\t\t\t\t\tthis.sortedColumn = null;\r\n\t\t\t\t\tthis.reloadTableData({\r\n\t\t\t\t\t\tpage: this.currentPage,\r\n\t\t\t\t\t\tsize: this.pageSize,\r\n\t\t\t\t\t});\r\n\t\t\t\t}\r\n\r\n\t\t\t\tthis.config.tableSortSetting = {\r\n\t\t\t\t\tsort: this.sort,\r\n\t\t\t\t\tsortedColumn: this.sortedColumn,\r\n\t\t\t\t};\r\n\t\t\t\tthis.portlet.config = JSON.stringify(this.config);\r\n\t\t\t\tconst index = this.portlets.findIndex(\r\n\t\t\t\t\t(x) => x.newId === this.portlet.newId\r\n\t\t\t\t);\r\n\t\t\t\tthis.portlets[index].config = JSON.stringify(this.config);\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\tpublic resizeStop(args) {\r\n\t\tlet field = this.configFields.filter(\r\n\t\t\t(el) => el.colName === args.column.field\r\n\t\t);\r\n\t\tif (field && field.length > 0) {\r\n\t\t\tfield[0].width = parseInt(args.column.width);\r\n\t\t\tconst portlet = this.portlet;\r\n\t\t\tportlet.config = JSON.stringify(this.config);\r\n\t\t\tconst index = this.portlets.findIndex(\r\n\t\t\t\t(x) => x.newId === portlet.newId\r\n\t\t\t);\r\n\t\t\tthis.portlets[index] = portlet;\r\n\t\t}\r\n\t}\r\n\r\n\tpublic rowDataBound(args) {\r\n\t\tif (args.row.ariaRowIndex % 2 === 0) {\r\n\t\t\targs.row.style.backgroundColor = \"#f8fafb\";\r\n\t\t} else {\r\n\t\t\targs.row.style.backgroundColor = \"#ffffff\";\r\n\t\t}\r\n\t}\r\n\r\n\tpublic created(args) {\r\n\t\tif (this.config.showGrandTotals) {\r\n\t\t\tlet el = this.grid.element.querySelector(\".e-gridfooter\");\r\n\t\t\tif (el) el.classList.remove(\"hidesummary\");\r\n\t\t} else {\r\n\t\t\tlet el = this.grid.element.querySelector(\".e-gridfooter\");\r\n\t\t\tif (el) el.classList.add(\"hidesummary\");\r\n\t\t}\r\n\t}\r\n\r\n\tpublic exportQueryCellInfo(args: ExcelQueryCellInfoEventArgs): void {\r\n\t\tlet curFormat = this.formatSettings.find(\r\n\t\t\t(x) => x.name === args.column.field\r\n\t\t);\r\n\t\tif (curFormat) {\r\n\t\t\tif (curFormat.type === \"date\") {\r\n\t\t\t\targs.value = this.pbf.convertDateFormat(\r\n\t\t\t\t\targs.value,\r\n\t\t\t\t\tcurFormat.format\r\n\t\t\t\t\t\t? curFormat.format.replace(\"dd\", \"DD\")\r\n\t\t\t\t\t\t: null\r\n\t\t\t\t);\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tif (\r\n\t\t\targs.column.field &&\r\n\t\t\tthis.millionFields.includes(args.column.field)\r\n\t\t) {\r\n\t\t\targs.value = args.data[args.column.field] / 1000000;\r\n\t\t}\r\n\r\n\t\tif (this.formatDates && this.formatDates.length) {\r\n\t\t\tlet dateFields = this.formatDates.map((el) => {\r\n\t\t\t\treturn el.name;\r\n\t\t\t});\r\n\r\n\t\t\tif (args.column.field && dateFields.includes(args.column.field)) {\r\n\t\t\t\tlet date = new Date(args.data[args.column.field]);\r\n\r\n\t\t\t\tlet quarter =\r\n\t\t\t\t\tMath.floor((date.getMonth() + 1) % 3) == 0\r\n\t\t\t\t\t\t? Math.floor((date.getMonth() + 1) / 3)\r\n\t\t\t\t\t\t: Math.floor((date.getMonth() + 1) / 3) + 1;\r\n\r\n\t\t\t\tlet format;\r\n\r\n\t\t\t\tthis.formatDates.map((el) => {\r\n\t\t\t\t\tif (el.name == args.column.field) format = el.format;\r\n\t\t\t\t});\r\n\t\t\t\tlet year: any;\r\n\t\t\t\tswitch (format) {\r\n\t\t\t\t\tcase \"Q1 2021\":\r\n\t\t\t\t\t\tyear = date.getFullYear();\r\n\t\t\t\t\t\targs.value = \"Q\" + quarter + \" \" + year;\r\n\t\t\t\t\t\tbreak;\r\n\t\t\t\t\tcase \"Q1 21\":\r\n\t\t\t\t\t\tyear = (date as any).getYear() - 100;\r\n\t\t\t\t\t\targs.value = \"Q\" + quarter + \" \" + year;\r\n\t\t\t\t\t\tbreak;\r\n\t\t\t\t\tcase \"2021 Q1\":\r\n\t\t\t\t\t\tyear = date.getFullYear();\r\n\t\t\t\t\t\targs.value = year + \" \" + \"Q\" + quarter;\r\n\t\t\t\t\t\tbreak;\r\n\t\t\t\t\tcase \"21 Q1\":\r\n\t\t\t\t\t\tyear = (date as any).getYear() - 100;\r\n\t\t\t\t\t\targs.value = year + \" \" + \"Q\" + quarter;\r\n\t\t\t\t\t\tbreak;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t// Excel Style Format\r\n\t\tlet queryCell =\r\n\t\t\tthis.tableList &&\r\n\t\t\tthis.tableList.filter(\r\n\t\t\t\t(item) => item.colName === args.column.field\r\n\t\t\t)[0];\r\n\t\tif (\r\n\t\t\tqueryCell &&\r\n\t\t\tqueryCell.format &&\r\n\t\t\tqueryCell.format.length &&\r\n\t\t\tqueryCell.format[0].fontSettingChecked\r\n\t\t) {\r\n\t\t\tif (\r\n\t\t\t\tqueryCell.format[0].formatChecked &&\r\n\t\t\t\tqueryCell.format[0].compareSelect\r\n\t\t\t) {\r\n\t\t\t\tlet cellData = args.data[args.column.field];\r\n\t\t\t\tlet condition: Boolean = false;\r\n\t\t\t\tswitch (queryCell.format[0].compareSelect) {\r\n\t\t\t\t\tcase \"LessThan\":\r\n\t\t\t\t\t\tcondition =\r\n\t\t\t\t\t\t\tcellData <\r\n\t\t\t\t\t\t\tNumber(queryCell.format[0].compareValue1);\r\n\t\t\t\t\t\tbreak;\r\n\t\t\t\t\tcase \"LessThanOrEqualTo\":\r\n\t\t\t\t\t\tcondition =\r\n\t\t\t\t\t\t\tcellData <=\r\n\t\t\t\t\t\t\tNumber(queryCell.format[0].compareValue1);\r\n\t\t\t\t\t\tbreak;\r\n\t\t\t\t\tcase \"GreaterThan\":\r\n\t\t\t\t\t\tcondition =\r\n\t\t\t\t\t\t\tcellData >\r\n\t\t\t\t\t\t\tNumber(queryCell.format[0].compareValue1);\r\n\t\t\t\t\t\tbreak;\r\n\t\t\t\t\tcase \"GreaterThanOrEqualTo\":\r\n\t\t\t\t\t\tcondition =\r\n\t\t\t\t\t\t\tcellData >=\r\n\t\t\t\t\t\t\tNumber(queryCell.format[0].compareValue1);\r\n\t\t\t\t\t\tbreak;\r\n\t\t\t\t\tcase \"Equals\":\r\n\t\t\t\t\t\tcondition =\r\n\t\t\t\t\t\t\tcellData ===\r\n\t\t\t\t\t\t\tNumber(queryCell.format[0].compareValue1);\r\n\t\t\t\t\t\tbreak;\r\n\t\t\t\t\tcase \"NotEquals\":\r\n\t\t\t\t\t\tcondition =\r\n\t\t\t\t\t\t\tcellData !==\r\n\t\t\t\t\t\t\tNumber(queryCell.format[0].compareValue1);\r\n\t\t\t\t\t\tbreak;\r\n\t\t\t\t\tcase \"Between\":\r\n\t\t\t\t\t\tcondition =\r\n\t\t\t\t\t\t\tcellData >=\r\n\t\t\t\t\t\t\t\tNumber(queryCell.format[0].compareValue1) &&\r\n\t\t\t\t\t\t\tcellData <= queryCell.format[0].compareValue2;\r\n\t\t\t\t\t\tbreak;\r\n\t\t\t\t\tcase \"NotBetween\":\r\n\t\t\t\t\t\tcondition =\r\n\t\t\t\t\t\t\tcellData <\r\n\t\t\t\t\t\t\t\tNumber(queryCell.format[0].compareValue1) &&\r\n\t\t\t\t\t\t\tcellData >\r\n\t\t\t\t\t\t\t\tNumber(queryCell.format[0].compareValue2);\r\n\t\t\t\t\t\tbreak;\r\n\t\t\t\t\tdefault:\r\n\t\t\t\t\t\tbreak;\r\n\t\t\t\t}\r\n\t\t\t\tif (condition) this.cellAddStyleExcel(args, queryCell);\r\n\t\t\t} else this.cellAddStyleExcel(args, queryCell);\r\n\t\t}\r\n\t}\r\n\r\n\tprivate cellAddStyleExcel(args, queryCell) {\r\n\t\tif (queryCell.format[0].fontSettingChecked) {\r\n\t\t\tlet formatCellData = args.data[args.column.field];\r\n\t\t\tif (Math.sign(formatCellData) !== 0)\r\n\t\t\t\tif (Math.sign(formatCellData) === -1) {\r\n\t\t\t\t\targs.style = {\r\n\t\t\t\t\t\tfontColor: this.pbf.rgbaToHex(\r\n\t\t\t\t\t\t\t`${queryCell.format[0].negaFontColor}`\r\n\t\t\t\t\t\t),\r\n\t\t\t\t\t\tfontSize: Number(\r\n\t\t\t\t\t\t\t`${queryCell.format[0].negaFontSizeValue}`.replace(\r\n\t\t\t\t\t\t\t\t\"px\",\r\n\t\t\t\t\t\t\t\t\"\"\r\n\t\t\t\t\t\t\t)\r\n\t\t\t\t\t\t),\r\n\t\t\t\t\t\tfontName: `${queryCell.format[0].negaFontFamilyValue}`,\r\n\t\t\t\t\t\tbackColor: this.pbf.rgbaToHex(\r\n\t\t\t\t\t\t\t`${queryCell.format[0].negaBackgroundColor}`\r\n\t\t\t\t\t\t),\r\n\t\t\t\t\t};\r\n\t\t\t\t} else {\r\n\t\t\t\t\targs.style = {\r\n\t\t\t\t\t\tfontColor: this.pbf.rgbaToHex(\r\n\t\t\t\t\t\t\t`${queryCell.format[0].fontColor}`\r\n\t\t\t\t\t\t),\r\n\t\t\t\t\t\tfontSize: Number(\r\n\t\t\t\t\t\t\t`${queryCell.format[0].fontSizeValue}`.replace(\r\n\t\t\t\t\t\t\t\t\"px\",\r\n\t\t\t\t\t\t\t\t\"\"\r\n\t\t\t\t\t\t\t)\r\n\t\t\t\t\t\t),\r\n\t\t\t\t\t\tfontName: `${queryCell.format[0].fontFamilyValue}`,\r\n\t\t\t\t\t\tbackColor: this.pbf.rgbaToHex(\r\n\t\t\t\t\t\t\t`${queryCell.format[0].backgroundColor}`\r\n\t\t\t\t\t\t),\r\n\t\t\t\t\t};\r\n\t\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\tpublic getLogoInfo(colName, code) {\r\n\t\tif (this.configFields && this.configFields.length) {\r\n\t\t\tlet fields = this.configFields.filter(\r\n\t\t\t\t(el) => el.colName == colName\r\n\t\t\t);\r\n\t\t\tif (fields && fields.length) {\r\n\t\t\t\treturn fields[0][code];\r\n\t\t\t} else {\r\n\t\t\t\treturn false;\r\n\t\t\t}\r\n\t\t} else {\r\n\t\t\treturn false;\r\n\t\t}\r\n\t}\r\n\r\n\tpublic getLogoImage(logoDocId) {\r\n\t\tlet img;\r\n\t\tif (\r\n\t\t\tlogoDocId !== undefined &&\r\n\t\t\tlogoDocId !== null &&\r\n\t\t\tlogoDocId !== \"00000000-0000-0000-0000-000000000000\"\r\n\t\t) {\r\n\t\t\timg =\r\n\t\t\t\tthis.api.baseurl +\r\n\t\t\t\tthis.api.urlList.FileGet +\r\n\t\t\t\t\"?username=\" +\r\n\t\t\t\tthis.userInfo.username +\r\n\t\t\t\t\"&accountId=\" +\r\n\t\t\t\tthis.userInfo.accountId +\r\n\t\t\t\t\"&docId=\" +\r\n\t\t\t\tlogoDocId +\r\n\t\t\t\t`&Authorization=Bearer`;\r\n\t\t} else {\r\n\t\t\timg = \"../../../../../../assets/img/default_profile_icon.png\";\r\n\t\t}\r\n\t\treturn img;\r\n\t}\r\n\r\n\tprivate setQuarterFormat() {\r\n\t\treturn [\r\n\t\t\t{ value: \"03/2021\", format: \"MM/yyyy\" },\r\n\t\t\t{ value: \"03/21\", format: \"MM/dd\" },\r\n\t\t\t{ value: \"3/2021\", format: \"M/yyyy\" },\r\n\t\t\t{ value: \"3/21\", format: \"M/yy\" },\r\n\t\t\t{ value: \"March 2021\", format: \"MMMM yyyy\" },\r\n\t\t\t{ value: \"Mar, 2021\", format: \"MMM, yyyy\" },\r\n\t\t\t{ value: \"March, 2021\", format: \"MMMM, yyyy\" },\r\n\t\t\t{ value: \"2021\", format: \"yyyy\" },\r\n\t\t];\r\n\t}\r\n\r\n\tprivate getDateFormat(format_) {\r\n\t\tswitch (format_) {\r\n\t\t\tcase \"DD/MM/YYYY\":\r\n\t\t\t\treturn \"dd/MM/yyyy\";\r\n\t\t\tcase \"DD/MM/YY\":\r\n\t\t\t\treturn \"dd/MM/yy\";\r\n\t\t\tcase \"MM/DD/YYYY\":\r\n\t\t\t\treturn \"MM/dd/yyyy\";\r\n\t\t\tcase \"MM/DD/YY\":\r\n\t\t\t\treturn \"MM/dd/yy\";\r\n\t\t\tcase \"YYYY-MM-DD\":\r\n\t\t\t\treturn \"yyyy-MM-dd\";\r\n\t\t\tcase \"YY-MM-DD\":\r\n\t\t\t\treturn \"yy-MM-dd\";\r\n\t\t\tcase \"DD-MM-YYYY\":\r\n\t\t\t\treturn \"dd-MM-yyyy\";\r\n\t\t\tcase \"DD-MM-YY\":\r\n\t\t\t\treturn \"dd-MM-yy\";\r\n\t\t\tcase \"MM-DD-YYYY\":\r\n\t\t\t\treturn \"MM-dd-yyyy\";\r\n\t\t\tcase \"MM-DD-YY\":\r\n\t\t\t\treturn \"MM-dd-yy\";\r\n\t\t\tcase \"MMM DD, YYYY\":\r\n\t\t\t\treturn \"MMM dd, yyyy\";\r\n\t\t\tcase \"DD-MMM-YYYY\":\r\n\t\t\t\treturn \"dd-MMM-yyyy\";\r\n\t\t\tdefault:\r\n\t\t\t\tbreak;\r\n\t\t}\r\n\t}\r\n\r\n\tprivate getNumFormat(el) {\r\n\t\t//SMP2-3026\r\n\t\tif (\r\n\t\t\tel.dataType === \"number\" &&\r\n\t\t\tel.colName !== \"PortInvStk\" &&\r\n\t\t\tel.colName !== \"PortFdInvStk\"\r\n\t\t) {\r\n\t\t\tif (el.format && el.format.length && el.format[0].formatChecked) {\r\n\t\t\t\tif (\r\n\t\t\t\t\t[10, 11, 12, 13, 14, 15, 16, 17, 18].includes(\r\n\t\t\t\t\t\tel.format[0].selectedFormat\r\n\t\t\t\t\t)\r\n\t\t\t\t)\r\n\t\t\t\t\tthis.millionData(el.colName);\r\n\t\t\t\treturn this.pbf.formatNumber(el.format[0].selectedFormat);\r\n\t\t\t} else return this.dashboardPorletsService.formatNumber(el.dp);\r\n\t\t}\r\n\t\tif (el.dataType === \"percent\") {\r\n\t\t\tif (el.format && el.format.length && el.format[0].formatChecked)\r\n\t\t\t\treturn this.pbf.formatPercent(el.format[0].selectedFormat);\r\n\t\t\telse return this.dashboardPorletsService.formatPercent(el.dp);\r\n\t\t}\r\n\t\tif (el.dataType === \"percentNum\")\r\n\t\t\treturn this.dashboardPorletsService.formatPercentNum(el.dp);\r\n\t\tif (el.dataType === \"multiple\")\r\n\t\t\treturn this.dashboardPorletsService.formatMultiple(el.dp);\r\n\t}\r\n\r\n\tprivate millionData(colName) {\r\n\t\tthis.millionFields.push(colName);\r\n\t\tif (this.config.filterSettings && this.config.filterSettings.length) {\r\n\t\t\tlet filterFields = this.config.filterSettings.map((el) => {\r\n\t\t\t\treturn el.field;\r\n\t\t\t});\r\n\t\t\tif (filterFields.includes(colName))\r\n\t\t\t\tthis.config.filterSettings.map((el) => {\r\n\t\t\t\t\tif (el.field == colName) {\r\n\t\t\t\t\t\tel.value = Number(el.value / 1000000);\r\n\t\t\t\t\t}\r\n\t\t\t\t});\r\n\t\t}\r\n\t}\r\n\r\n\tpublic getAlign(table) {\r\n\t\tif (\r\n\t\t\ttable.format &&\r\n\t\t\ttable.format.length &&\r\n\t\t\ttable.format[0].formatChecked\r\n\t\t)\r\n\t\t\treturn table.format[0].align;\r\n\t\treturn [\"date\", \"datetime\", \"string\", \"nvarchar\", \"dropdown\"].includes(\r\n\t\t\ttable.dataType\r\n\t\t) &&\r\n\t\t\t![\"MOIC\", \"DPI\", \"TVPI\", \"RVPI\", \"PIC\", \"Multiple\"].includes(\r\n\t\t\t\ttable.colName\r\n\t\t\t)\r\n\t\t\t? \"Left\"\r\n\t\t\t: \"Right\";\r\n\t}\r\n\r\n\tpublic pageChanged(args: any) {\r\n\t\tif (args.newProp) {\r\n\t\t\t// 处理分页器点击事件\r\n\t\t\tlet pageSize = args.newProp.pageSize;\r\n\t\t\tif (pageSize) {\r\n\t\t\t\tthis.pageSize = pageSize;\r\n\t\t\t\tthis.currentPage = 1;\r\n\t\t\t} else {\r\n\t\t\t\tthis.currentPage = args.newProp.currentPage;\r\n\t\t\t}\r\n\t\t\tthis.reloadTableData(\r\n\t\t\t\t{\r\n\t\t\t\t\tpage: this.currentPage,\r\n\t\t\t\t\tsize: this.pageSize,\r\n\t\t\t\t\tsortedColumn:\r\n\t\t\t\t\t\tthis.sortedColumn === null\r\n\t\t\t\t\t\t\t? undefined\r\n\t\t\t\t\t\t\t: this.sortedColumn,\r\n\t\t\t\t\tsort: this.sort === null ? undefined : this.sort,\r\n\t\t\t\t},\r\n\t\t\t\ttrue\r\n\t\t\t);\r\n\t\t}\r\n\t}\r\n\r\n\tpublic reloadTableData(setting: any = {}, refreshFormat?) {\r\n\t\tlet params: any = {};\r\n\t\tif (setting.page && setting.size) {\r\n\t\t\tparams.currentPage = setting.page;\r\n\t\t\tparams.pageSize = setting.size;\r\n\t\t}\r\n\t\tif (setting.sortedColumn) {\r\n\t\t\tparams.sortedColumn = setting.sortedColumn;\r\n\t\t\tparams.sort = setting.sort;\r\n\t\t}\r\n\t\tthis.pageLoading = true;\r\n\t\tthis.dashboardPorletsService.getDataByPortletsNew(\r\n\t\t\t[this.portlet],\r\n\t\t\t() => {\r\n\t\t\t\tthis.pageLoading = false;\r\n\t\t\t\tconst data = DataUtil.parse.parseJson(\r\n\t\t\t\t\tthis.dashboardPorletsService.getResultByDataTable(\r\n\t\t\t\t\t\tthis.portlet,\r\n\t\t\t\t\t\tfalse,\r\n\t\t\t\t\t\tfalse,\r\n\t\t\t\t\t\tthis.dashboard.id\r\n\t\t\t\t\t)\r\n\t\t\t\t);\r\n\r\n\t\t\t\tthis.data = data.map((item) => {\r\n\t\t\t\t\treturn {\r\n\t\t\t\t\t\t...item,\r\n\t\t\t\t\t\tMOIC: `${Number(item[\"MOIC\"]).toFixed(2)}x`,\r\n\t\t\t\t\t\tDPI: `${Number(item[\"DPI\"]).toFixed(2)}x`,\r\n\t\t\t\t\t\tTVPI: `${Number(item[\"TVPI\"]).toFixed(2)}x`,\r\n\t\t\t\t\t\tRVPI: `${Number(item[\"RVPI\"]).toFixed(2)}x`,\r\n\t\t\t\t\t\tPIC: `${Number(item[\"PIC\"]).toFixed(2)}x`,\r\n\t\t\t\t\t\tMultiple: `${Number(item[\"Multiple\"]).toFixed(2)}x`,\r\n\t\t\t\t\t};\r\n\t\t\t\t});\r\n\r\n\t\t\t\t// if (this.tableList && this.tableList.length) {\r\n\t\t\t\t// \tconst typeMap = {};\r\n\t\t\t\t// \tthis.tableList.forEach((col) => {\r\n\t\t\t\t// \t\tif (col.dataType === \"number\") {\r\n\t\t\t\t// \t\t\ttypeMap[col.colName] = true;\r\n\t\t\t\t// \t\t}\r\n\t\t\t\t// \t});\r\n\t\t\t\t// \tthis.data.forEach((_data) => {\r\n\t\t\t\t// \t\tObject.keys(typeMap).forEach((key) => {\r\n\t\t\t\t// \t\t\t_data[key] =\r\n\t\t\t\t// \t\t\t\t_data[key] === null\r\n\t\t\t\t// \t\t\t\t\t? null\r\n\t\t\t\t// \t\t\t\t\t: this.pbf.bankersRounding(\r\n\t\t\t\t// \t\t\t\t\t\t\tNumber(_data[key])\r\n\t\t\t\t// \t\t\t\t\t  );\r\n\t\t\t\t// \t\t});\r\n\t\t\t\t// \t});\r\n\t\t\t\t// }\r\n\r\n\t\t\t\tthis.totalRecordsCount =\r\n\t\t\t\t\tthis.dashboardPorletsService.getResultByDataTable(\r\n\t\t\t\t\t\tthis.portlet,\r\n\t\t\t\t\t\ttrue,\r\n\t\t\t\t\t\ttrue,\r\n\t\t\t\t\t\tthis.dashboard.id\r\n\t\t\t\t\t);\r\n\t\t\t\tthis.tableList = [...this.configFields];\r\n\t\t\t\tthis.tableList = this.tableList.filter((fl) => !fl.isHidden);\r\n\r\n\t\t\t\tthis.tableList = this.tableList.map((item) => {\r\n\t\t\t\t\treturn {\r\n\t\t\t\t\t\t...item,\r\n\t\t\t\t\t\tdataType: [\r\n\t\t\t\t\t\t\t\"MOIC\",\r\n\t\t\t\t\t\t\t\"DPI\",\r\n\t\t\t\t\t\t\t\"TVPI\",\r\n\t\t\t\t\t\t\t\"RVPI\",\r\n\t\t\t\t\t\t\t\"PIC\",\r\n\t\t\t\t\t\t\t\"Multiple\",\r\n\t\t\t\t\t\t].includes(item.colName)\r\n\t\t\t\t\t\t\t? \"string\"\r\n\t\t\t\t\t\t\t: item[\"dataType\"],\r\n\t\t\t\t\t};\r\n\t\t\t\t});\r\n\t\t\t\tconst typeMap = {};\r\n\t\t\t\tthis.tableList.forEach((col) => {\r\n\t\t\t\t\tif (col.dataType === \"number\") {\r\n\t\t\t\t\t\ttypeMap[col.colName] = true;\r\n\t\t\t\t\t}\r\n\t\t\t\t});\r\n\t\t\t\tthis.data.forEach((_data) => {\r\n\t\t\t\t\tObject.keys(typeMap).forEach((key) => {\r\n\t\t\t\t\t\t_data[key] =\r\n\t\t\t\t\t\t\t_data[key] === null\r\n\t\t\t\t\t\t\t\t? null\r\n\t\t\t\t\t\t\t\t: this.pbf.bankersRounding(Number(_data[key]));\r\n\t\t\t\t\t});\r\n\t\t\t\t});\r\n\t\t\t\tif (this.grid) {\r\n\t\t\t\t\tif (refreshFormat) {\r\n\t\t\t\t\t\tthis.grid.columns.forEach((item) => {\r\n\t\t\t\t\t\t\titem.format = this.getFormatOptions(item.field);\r\n\t\t\t\t\t\t});\r\n\t\t\t\t\t\tif (this.grid.contentModule) {\r\n\t\t\t\t\t\t\tthis.grid.refreshColumns();\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t} else {\r\n\t\t\t\t\t\tthis.grid.refresh();\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t\tthis.ref.markForCheck();\r\n\t\t\t\tthis.ref.detectChanges();\r\n\t\t\t},\r\n\t\t\tparams,\r\n\t\t\tfalse,\r\n\t\t\tthis.dashboard\r\n\t\t);\r\n\t}\r\n\r\n\tgetXTxt(colName, item) {\r\n\t\tif (colName == \"MOIC\") {\r\n\t\t\treturn `${Number(item[\"MOIC\"]).toFixed(2)}x`;\r\n\t\t} else if (colName == \"DPI\") {\r\n\t\t\treturn `${Number(item[\"DPI\"]).toFixed(2)}x`;\r\n\t\t} else if (colName == \"TVPI\") {\r\n\t\t\treturn `${Number(item[\"TVPI\"]).toFixed(2)}x`;\r\n\t\t} else if (colName == \"RVPI\") {\r\n\t\t\treturn `${Number(item[\"RVPI\"]).toFixed(2)}x`;\r\n\t\t} else if (colName == \"PIC\") {\r\n\t\t\treturn `${Number(item[\"PIC\"]).toFixed(2)}x`;\r\n\t\t} else if (colName == \"Multiple\") {\r\n\t\t\treturn `${Number(item[\"Multiple\"]).toFixed(2)}x`;\r\n\t\t}\r\n\t}\r\n}\r\n","<div class=\"control-section gadget-table\" style=\"height: 100%\" *ngIf=\"data && data.length\">\r\n\t<ejs-grid\r\n\t\t*ngIf=\"!hideTable\"\r\n\t\t#grid\r\n\t\t[dataSource]=\"data\"\r\n\t\t[allowSorting]=\"true\"\r\n\t\twidth=\"100%\"\r\n\t\t[pageSettings]=\"options\"\r\n\t\t[resizeSettings]=\"{ mode: 'Auto' }\"\r\n\t\t[allowExcelExport]=\"true\"\r\n\t\t[filterSettings]=\"filterSettings\"\r\n\t\t[allowResizing]=\"true\"\r\n\t\tshowColumnChooser=\"true\"\r\n\t\t[columnChooserSettings]=\"ColumnChooserSettings\"\r\n\t\t[aggregates]=\"aggregates\"\r\n\t\t(queryCellInfo)=\"customiseCell($event)\"\r\n\t\t(resizeStop)=\"resizeStop($event)\"\r\n\t\t(rowDataBound)=\"rowDataBound($event)\"\r\n\t\t(created)=\"created($event)\"\r\n\t\t(actionBegin)=\"actionBegin($event)\"\r\n\t\t(actionComplete)=\"actionComplete($event)\"\r\n\t\t(excelQueryCellInfo)=\"exportQueryCellInfo($event)\"\r\n\t>\r\n\t\t<e-columns>\r\n\t\t\t<e-column\r\n\t\t\t\t*ngIf=\"getLogoInfo('logoDocId', 'langValue')\"\r\n\t\t\t\t[headerText]=\"getLogoInfo('logoDocId', 'langValue')\"\r\n\t\t\t\twidth=\"120\"\r\n\t\t\t\ttextAlign=\"Center\"\r\n\t\t\t\t[visible]=\"!getLogoInfo('logoDocId', 'isHidden')\"\r\n\t\t\t>\r\n\t\t\t\t<ng-template #template let-data>\r\n\t\t\t\t\t<div class=\"image-\">\r\n\t\t\t\t\t\t<img\r\n\t\t\t\t\t\t\t[src]=\"getLogoImage(data.logoDocId)\"\r\n\t\t\t\t\t\t\t[alt]=\"data.companyName\"\r\n\t\t\t\t\t\t/>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t</ng-template>\r\n\t\t\t</e-column>\r\n\t\t\t<e-column\r\n\t\t\t\t*ngFor=\"let table of tableList\"\r\n\t\t\t\t[field]=\"table.colName\"\r\n\t\t\t\t[filter]=\"filter\"\r\n\t\t\t\t[headerText]=\"\r\n\t\t\t\t\t(table.displayName\r\n\t\t\t\t\t\t? table.displayName\r\n\t\t\t\t\t\t: translation[table.langCode]\r\n\t\t\t\t\t\t? translation[table.langCode]\r\n\t\t\t\t\t\t: table.langValue) +\r\n\t\t\t\t\t(table.addtionName ? ' ' + table.addtionName : '')\r\n\t\t\t\t\"\r\n\t\t\t\t[width]=\"table.width ? table.width : 200\"\r\n\t\t\t\tclipMode=\"EllipsisWithTooltip\"\r\n\t\t\t\t[visible]=\"table.visible\"\r\n\t\t\t\t[type]=\"\r\n\t\t\t\t\t['number', 'percentNum', 'percent'].includes(table.dataType)\r\n\t\t\t\t\t\t? 'number'\r\n\t\t\t\t\t\t: ['date', 'datetime'].includes(table.dataType)\r\n\t\t\t\t\t\t? 'date'\r\n\t\t\t\t\t\t: null\r\n\t\t\t\t\"\r\n\t\t\t\t[format]=\"getFormatOptions(table.colName)\"\r\n\t\t\t\t[textAlign]=\"getAlign(table)\"\r\n\t\t\t>\r\n\t\t\t\t<ng-template\r\n\t\t\t\t\t#template\r\n\t\t\t\t\tlet-data\r\n\t\t\t\t\t*ngIf=\"millionFields.includes(table.colName); else elseBlock\"\r\n\t\t\t\t>\r\n\t\t\t\t\t{{ data[table.colName] / 1000000 }}\r\n\t\t\t\t</ng-template>\r\n\t\t\t\t<ng-template #elseBlock>\r\n\t\t\t\t\t{{ data[table.colName] }}\r\n\t\t\t\t</ng-template>\r\n\r\n\t\t\t\t<!-- terms列 显示换行符 -->\r\n\t\t\t\t<ng-template\r\n\t\t\t\t\t#template\r\n\t\t\t\t\tlet-data\r\n\t\t\t\t\t*ngIf=\"table.colName == 'terms'\"\r\n\t\t\t\t>\r\n\t\t\t\t\t<div\r\n\t\t\t\t\t\tstyle=\"white-space: pre-line\"\r\n\t\t\t\t\t\t[innerHTML]=\"data[table.colName]\"\r\n\t\t\t\t\t></div>\r\n\t\t\t\t</ng-template>\r\n\t\t\t</e-column>\r\n\t\t</e-columns>\r\n\t</ejs-grid>\r\n\t<ejs-pager\r\n\t\t#pager\r\n\t\t[currentPage]=\"currentPage\"\r\n\t\t[pageCount]=\"5\"\r\n\t\t[pageSize]=\"pageSize\"\r\n\t\t[pageSizes]=\"[10, 50, 100]\"\r\n\t\t[totalRecordsCount]=\"totalRecordsCount\"\r\n\t\t(click)=\"pageChanged($event)\"\r\n\t>\r\n\t</ejs-pager>\r\n\t<div class=\"full-box-mask\" *ngIf=\"pageLoading\">\r\n\t\t<mat-spinner\r\n\t\t\tstyle=\"z-index: 999\"\r\n\t\t\tmode=\"indeterminate\"\r\n\t\t\t[diameter]=\"24\"\r\n\t\t></mat-spinner>\r\n\t</div>\r\n</div>\r\n"]}