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,3211 @@
1
+ import { Component, Input, ViewChild, ChangeDetectionStrategy, Inject, Optional, } from "@angular/core";
2
+ import { ToolbarService, FieldListService, NumberFormattingService, CalculatedFieldService, GroupingBarService, VirtualScrollService, DrillThroughService, } from "@syncfusion/ej2-angular-pivotview";
3
+ import { L10n, enableRipple, Browser, } from "@syncfusion/ej2-base";
4
+ import { sortBy, differenceWith, startsWith, cloneDeep, uniqBy, filter as _filter, maxBy, minBy, sumBy, meanBy, } from "lodash";
5
+ import { AGGREGATE_TYPES_TEXT, ALL_AGGREGATE_TYPES, } from "../../dashboardPorlets.service";
6
+ import { Observable } from "rxjs";
7
+ import { MaskedTextBox } from "@syncfusion/ej2-inputs/src/maskedtextbox/maskedtextbox";
8
+ import { DataManager } from "@syncfusion/ej2-data/src/manager";
9
+ import { Predicate, Query } from "@syncfusion/ej2-data/src/query";
10
+ import { DataUtil } from "@syncfusion/ej2-data";
11
+ import moment from "moment";
12
+ import { PBF_TOKEN } from "../../../service/InjectionToken";
13
+ import * as i0 from "@angular/core";
14
+ import * as i1 from "../../dashboardPorlets.service";
15
+ import * as i2 from "../../dashboard.service";
16
+ import * as i3 from "@angular/common";
17
+ import * as i4 from "@syncfusion/ej2-angular-pivotview";
18
+ enableRipple(false);
19
+ export class GadgetPivotComponent {
20
+ dashboardPorletsService;
21
+ dashboardService;
22
+ ref;
23
+ pbf;
24
+ portlet;
25
+ dashboard;
26
+ portlets;
27
+ Pivot_Data;
28
+ config;
29
+ dataSourceSettings;
30
+ gridSettings;
31
+ excludeFields = [];
32
+ filterSettings = [];
33
+ datePipeFormat;
34
+ translation;
35
+ pivotObj;
36
+ fieldlistObj;
37
+ observable = new Observable();
38
+ grandTotals = {};
39
+ subTotals = {};
40
+ flag = false;
41
+ previousSort;
42
+ subscriptions = [];
43
+ allDataValue;
44
+ // private calculatedFieldSettings;
45
+ isInit = true;
46
+ pivotSearchBox;
47
+ tooltipSettings = {
48
+ enable: false,
49
+ };
50
+ columnTexts = [];
51
+ configFields = [];
52
+ quarterFormat = [
53
+ { value: "03/2021", format: "MM/yyyy" },
54
+ { value: "03/21", format: "MM/dd" },
55
+ { value: "3/2021", format: "M/yyyy" },
56
+ { value: "3/21", format: "M/yy" },
57
+ { value: "March 2021", format: "MMMM yyyy" },
58
+ { value: "Mar, 2021", format: "MMM, yyyy" },
59
+ { value: "March, 2021", format: "MMMM, yyyy" },
60
+ { value: "2021", format: "yyyy" },
61
+ ];
62
+ zoomSettings = {
63
+ enable: false,
64
+ };
65
+ itemDataTypeSortArr = [
66
+ "Assets",
67
+ "Liabilities",
68
+ "Equity",
69
+ "P&L",
70
+ "Cashflow",
71
+ ];
72
+ formatDates = [];
73
+ customCalculatedFields = []; // 自定义计算列
74
+ allowedCalculatedFields = []; // 允许自定义算法的字段
75
+ zeroFormatData = {
76
+ emptyList: [],
77
+ hgList: [],
78
+ };
79
+ millionFields = [];
80
+ tempSubtotals = [];
81
+ orderByColumns; // Eg: "DueDate, Sequence"
82
+ isApplyIRR = false;
83
+ calcIRRData;
84
+ percentNumFields = [];
85
+ pageLoading;
86
+ constructor(dashboardPorletsService, dashboardService, ref, pbf) {
87
+ this.dashboardPorletsService = dashboardPorletsService;
88
+ this.dashboardService = dashboardService;
89
+ this.ref = ref;
90
+ this.pbf = pbf;
91
+ }
92
+ ngOnInit() {
93
+ this.getInfo();
94
+ L10n.load({
95
+ "en-US": {
96
+ pivotview: AGGREGATE_TYPES_TEXT,
97
+ pivotfieldlist: AGGREGATE_TYPES_TEXT,
98
+ },
99
+ zh: {
100
+ pivotview: AGGREGATE_TYPES_TEXT,
101
+ pivotfieldlist: AGGREGATE_TYPES_TEXT,
102
+ },
103
+ "zh-Hant-HK": {
104
+ pivotview: AGGREGATE_TYPES_TEXT,
105
+ pivotfieldlist: AGGREGATE_TYPES_TEXT,
106
+ },
107
+ ja: {
108
+ pivotview: AGGREGATE_TYPES_TEXT,
109
+ pivotfieldlist: AGGREGATE_TYPES_TEXT,
110
+ },
111
+ ko: {
112
+ pivotview: AGGREGATE_TYPES_TEXT,
113
+ pivotfieldlist: AGGREGATE_TYPES_TEXT,
114
+ },
115
+ fr: {
116
+ pivotview: AGGREGATE_TYPES_TEXT,
117
+ pivotfieldlist: AGGREGATE_TYPES_TEXT,
118
+ },
119
+ });
120
+ this.getData();
121
+ }
122
+ ngAfterViewInit() {
123
+ this.subscriptions.push(this.dashboardService.getchangePivot().subscribe((updated) => {
124
+ if (updated === this.portlet.newId) {
125
+ this.getData();
126
+ }
127
+ }));
128
+ this.subscriptions.push(this.dashboardService.getStartRefresh().subscribe((dashboardId) => {
129
+ if (dashboardId === this.dashboard.id) {
130
+ this.pageLoading = true;
131
+ this.ref.markForCheck();
132
+ }
133
+ }));
134
+ this.subscriptions.push(this.dashboardService.getUpdated().subscribe((newId) => {
135
+ if (newId === this.portlet.newId || newId === this.portlet.id) {
136
+ this.getData();
137
+ if (this.pivotObj)
138
+ this.pivotObj.refreshData();
139
+ }
140
+ }));
141
+ this.subscriptions.push(this.dashboardService.getRefreshGadget().subscribe((e) => {
142
+ if (!e) {
143
+ return;
144
+ }
145
+ const id = e["newId"];
146
+ if (id === this.portlet.newId || id === this.portlet.id) {
147
+ this.pageLoading = false;
148
+ this.getData();
149
+ }
150
+ }));
151
+ this.subscriptions.push(this.dashboardService.getTableFormat().subscribe((updated) => {
152
+ if (updated === this.portlet.newId) {
153
+ this.getData();
154
+ if (this.pivotObj)
155
+ this.pivotObj.refreshData();
156
+ }
157
+ }));
158
+ this.subscriptions.push(this.dashboardService
159
+ .clearFieldListObservable()
160
+ .subscribe((updated) => {
161
+ if (updated === this.portlet.newId) {
162
+ this.pivotObj.dataSourceSettings.dataSource = [];
163
+ if (this.pivotObj)
164
+ this.pivotObj.refreshData();
165
+ if (this.fieldlistObj)
166
+ this.fieldlistObj.updateDataSource();
167
+ this.ref.markForCheck();
168
+ this.ref.detectChanges();
169
+ }
170
+ }));
171
+ // title change
172
+ this.subscriptions.push(this.dashboardService.updatePortletTitle().subscribe((updated) => {
173
+ if (updated) {
174
+ this.config = JSON.parse(this.portlet.config);
175
+ }
176
+ }));
177
+ }
178
+ ngOnDestroy() {
179
+ this.subscriptions.forEach((sub) => sub.unsubscribe());
180
+ }
181
+ onMemberEditorOpen(args) {
182
+ // 你可以在这里根据需要修改args来自定义过滤窗口的行为
183
+ // 11247 专门为item data type而设置
184
+ if (args.fieldName === "AccountTypeCode") {
185
+ let res = new Array(5).fill(null);
186
+ const fieldMembers = [...args.fieldMembers];
187
+ for (let i = fieldMembers.length - 1; i >= 0; i--) {
188
+ let index = -1;
189
+ const item = this.itemDataTypeSortArr.find((name, ind) => {
190
+ if (fieldMembers[i].actualText === name) {
191
+ index = ind;
192
+ }
193
+ return fieldMembers[i].actualText === name;
194
+ });
195
+ if (!item) {
196
+ continue;
197
+ }
198
+ const fillItem = fieldMembers.splice(i, 1);
199
+ res[index] = fillItem[0];
200
+ }
201
+ res = res.filter((item) => item) || [];
202
+ args.fieldMembers = [...res, ...fieldMembers];
203
+ setTimeout(() => {
204
+ const ele = document.querySelector(".e-member-editor-dialog");
205
+ if (ele) {
206
+ ele.querySelector(".e-filter-sort").setAttribute("style", "display: none");
207
+ }
208
+ });
209
+ }
210
+ }
211
+ setGridSettings() {
212
+ this.gridSettings = {
213
+ columnWidth: 140,
214
+ rowHeight: 40,
215
+ allowSelection: true,
216
+ selectionSettings: {
217
+ mode: "Cell",
218
+ type: "Multiple",
219
+ cellSelectionMode: "Box",
220
+ },
221
+ columnRender: this.observable.subscribe((args) => {
222
+ this.setColumnsRender(args);
223
+ }),
224
+ // 升级后 默认会有导出样式覆盖,需要手动设置导出标题样式
225
+ excelHeaderQueryCellInfo: this.observable.subscribe((args) => {
226
+ // args.style是个ExcelStyle类型
227
+ args.style = {
228
+ bold: true,
229
+ vAlign: "Center",
230
+ wrapText: false,
231
+ indent: 0,
232
+ borders: null, // 不需要border
233
+ };
234
+ }),
235
+ // 升级后 默认会有导出样式覆盖,需要手动设置导出内容样式
236
+ excelQueryCellInfo: this.observable.subscribe((args) => {
237
+ // #f486cfff 这里输出的是RGBA 颜色格式, xlsx里不需要透明度,去掉尾部ff
238
+ if (args.style && args.style.backColor) {
239
+ args.style.backColor = args.style.backColor.substring(0, 7);
240
+ }
241
+ let _style = {
242
+ bold: false,
243
+ wrapText: false,
244
+ borders: null,
245
+ fontColor: args.style.fontColor,
246
+ backColor: args.style.backColor,
247
+ };
248
+ let colIndex = args.cell.colIndex;
249
+ let rowIndex = args.cell.rowIndex;
250
+ if (this.config.showGrandTotals) {
251
+ // GrandTotal不需要颜色
252
+ if (args.data.length === rowIndex + 1) {
253
+ delete _style.fontColor;
254
+ delete _style.backColor;
255
+ }
256
+ }
257
+ if (args.data[rowIndex][colIndex].formattedText == "") {
258
+ args.value = "";
259
+ }
260
+ args.style = Object.assign(args.style, _style);
261
+ if (args.value === "" && args.style.numberFormat) {
262
+ args.style.numberFormat = null;
263
+ }
264
+ if (this.formatDates && this.formatDates.length) {
265
+ let dateFields = this.formatDates.map((el) => {
266
+ return el.name;
267
+ });
268
+ if (args.value &&
269
+ (args.cell.colIndex === 0
270
+ ? dateFields.includes(args.cell.valueSort.axis)
271
+ : dateFields.includes(args.cell.actualText))) {
272
+ //Customize the Row headers/Column headers based on your needs
273
+ let headers;
274
+ if (args.cell.colIndex === 0) {
275
+ headers = args.cell.actualText;
276
+ }
277
+ else {
278
+ // headers = pivotValues[k][j].formattedText;
279
+ headers = args.value;
280
+ }
281
+ if (headers) {
282
+ let date = new Date(headers);
283
+ let quarter = Math.floor(date.getMonth() / 3) + 1;
284
+ let format;
285
+ this.formatDates.map((el) => {
286
+ if (args.cell.colIndex == 0) {
287
+ if (el.name ==
288
+ args.cell.valueSort.axis)
289
+ format = el.format;
290
+ }
291
+ else {
292
+ if (el.name == args.cell.actualText)
293
+ format = el.format;
294
+ }
295
+ });
296
+ args.value = this.getQuarterValue(format, date, quarter);
297
+ }
298
+ }
299
+ }
300
+ }),
301
+ };
302
+ }
303
+ beforeExport(exportData) {
304
+ if (exportData) {
305
+ const keyMap = {};
306
+ this.dataSourceSettings.formatSettings.forEach((data) => {
307
+ if (data.format === "#,###,,.0;(#,###,,.0)" ||
308
+ data.format === "#,###,,;(#,###,,)" ||
309
+ data.format === "#,###,,.00;(#,###,,.00)") {
310
+ keyMap[data.name] = true;
311
+ }
312
+ });
313
+ if (exportData.dataCollections &&
314
+ exportData.dataCollections.length) {
315
+ exportData.dataCollections[0].forEach((row) => {
316
+ row.forEach((cell) => {
317
+ if (keyMap[cell.actualText]) {
318
+ cell.value = cell.actualValue;
319
+ }
320
+ if (typeof cell.value === "object" &&
321
+ typeof cell.formattedText === "string") {
322
+ cell.value = cell.formattedText;
323
+ }
324
+ });
325
+ });
326
+ }
327
+ }
328
+ }
329
+ async getData() {
330
+ this.pageLoading = false;
331
+ let columns = [];
332
+ let values = [];
333
+ let formatSettings = [];
334
+ let rows = [];
335
+ let fieldMapping = [];
336
+ // 清空grandTotals和subTotals
337
+ this.grandTotals = {};
338
+ this.subTotals = {};
339
+ this.config = JSON.parse(this.portlet.config);
340
+ this.setGridSettings();
341
+ if (this.config.fields) {
342
+ if (this.dashboardPorletsService.allFieldsObj[this.portlet.id]) {
343
+ this.configFields =
344
+ this.dashboardPorletsService.setConfigFields(this.dashboardPorletsService.allFieldsObj[this.portlet.id], this.config.fields);
345
+ }
346
+ else {
347
+ this.configFields = [...this.config.fields];
348
+ }
349
+ }
350
+ this.Pivot_Data = this.dashboardPorletsService.getResultByDataTable(this.portlet, false, false, this.dashboard.id);
351
+ this.orderByColumns = this.dashboardPorletsService.getOrderByColumnsNew(this.portlet.figureCode, this.dashboard);
352
+ this.Pivot_Data = DataUtil.parse.parseJson(this.Pivot_Data);
353
+ if (this.Pivot_Data && this.Pivot_Data.length > 0) {
354
+ // 移除列名和数据key不匹配的项
355
+ this.getexcludeFields(this.configFields, this.Pivot_Data[0]);
356
+ if (!this.allowedCalculatedFields.length) {
357
+ this.allowedCalculatedFields = Object.keys(this.Pivot_Data[0]);
358
+ }
359
+ for (let item of this.configFields) {
360
+ // 字段分组 https://ej2.syncfusion.com/angular/documentation/pivotview/field-list?search=fieldMapping#group-fields-under-desired-folder-name
361
+ fieldMapping.push({
362
+ name: item.colName,
363
+ caption: item.addtionName
364
+ ? `${item.langValue} ${item.addtionName}`
365
+ : item.langValue
366
+ ? item.langValue
367
+ : this.translation[item.langCode] || item.langCode,
368
+ dataType: item.dataType,
369
+ });
370
+ }
371
+ }
372
+ if (this.configFields) {
373
+ this.percentNumFields = [];
374
+ this.formatDates = [];
375
+ this.zeroFormatData.hgList = [];
376
+ this.zeroFormatData.emptyList = [];
377
+ this.millionFields = [];
378
+ this.configFields.map((el) => {
379
+ // SMP2-2486 & percentNum的format问题
380
+ if (el.dataType == "percentNum") {
381
+ this.percentNumFields.push(el.colName);
382
+ }
383
+ if (el.format &&
384
+ el.format.length &&
385
+ el.format[0].formatChecked &&
386
+ [2, 5, 8, 11, 14, 17].includes(el.format[0].selectedFormat))
387
+ this.zeroFormatData.hgList.push(el.colName);
388
+ if (el.format &&
389
+ el.format.length &&
390
+ el.format[0].formatChecked &&
391
+ [3, 6, 9, 12, 15, 18].includes(el.format[0].selectedFormat))
392
+ this.zeroFormatData.emptyList.push(el.colName);
393
+ // pivotTableformatPercent 百分比也有10,11,12 但是它是显示0.00x的格式,所以得排除
394
+ if (el.dataType !== "percent" &&
395
+ el.format &&
396
+ el.format.length &&
397
+ el.format[0].formatChecked &&
398
+ [10, 11, 12, 13, 14, 15, 16, 17, 18].includes(el.format[0].selectedFormat))
399
+ this.millionFields.push(el.colName);
400
+ if (el.dataType === "number" &&
401
+ (!el.format ||
402
+ (el.format &&
403
+ el.format.length &&
404
+ !el.format[0].formatChecked))) {
405
+ const formatData = {
406
+ name: el.colName,
407
+ //SMP2-3026 and SMP2-3059
408
+ format: el.colName !== "PortInvStk" &&
409
+ el.colName !== "PortFdInvStk"
410
+ ? this.dashboardPorletsService.formatNumber(el.dp)
411
+ : "##0.#######0",
412
+ useGrouping: true,
413
+ };
414
+ formatSettings.push(formatData);
415
+ }
416
+ if ((el.dataType === "percent" ||
417
+ el.dataType === "percentNum") &&
418
+ (!el.format ||
419
+ (el.format &&
420
+ el.format.length &&
421
+ !el.format[0].formatChecked))) {
422
+ const formatData = {
423
+ name: el.colName,
424
+ format: this.dashboardPorletsService.formatPercent(el.dp),
425
+ };
426
+ formatSettings.push(formatData);
427
+ }
428
+ if (el.dataType === "multiple" &&
429
+ (!el.format ||
430
+ (el.format &&
431
+ el.format.length &&
432
+ !el.format[0].formatChecked))) {
433
+ const formatData = {
434
+ name: el.colName,
435
+ format: this.dashboardPorletsService.formatMultiple(el.dp),
436
+ };
437
+ formatSettings.push(formatData);
438
+ }
439
+ if (el.dataType === "datetime" || el.dataType === "date") {
440
+ let format = "";
441
+ if (el.format &&
442
+ el.format.length &&
443
+ el.format[0].formatChecked) {
444
+ if (el.format[0].dateType == "Quarter") {
445
+ let format_ = el.format[0].selectedFormatDisplay;
446
+ let formatInfo = this.quarterFormat.filter((qur) => qur.value == format_);
447
+ if (formatInfo.length) {
448
+ format = formatInfo[0].format;
449
+ }
450
+ else {
451
+ const formatData = {
452
+ name: el.colName,
453
+ format: format_,
454
+ type: "date",
455
+ };
456
+ this.formatDates.push(formatData);
457
+ }
458
+ }
459
+ else if (el.format[0].dateType == "Date") {
460
+ let fromIdx = el.format[0].selectedFormatDisplay.indexOf("(");
461
+ let toIdx = el.format[0].selectedFormatDisplay.indexOf(")");
462
+ let format_ = el.format[0].selectedFormatDisplay.slice(fromIdx + 1, toIdx);
463
+ switch (format_) {
464
+ case "DD/MM/YYYY":
465
+ format = "dd/MM/yyyy";
466
+ break;
467
+ case "DD/MM/YY":
468
+ format = "dd/MM/yy";
469
+ break;
470
+ case "MM/DD/YYYY":
471
+ format = "MM/dd/yyyy";
472
+ break;
473
+ case "MM/DD/YY":
474
+ format = "MM/dd/yy";
475
+ break;
476
+ case "YYYY-MM-DD":
477
+ format = "yyyy-MM-dd";
478
+ break;
479
+ case "YY-MM-DD":
480
+ format = "yy-MM-dd";
481
+ break;
482
+ case "DD-MM-YYYY":
483
+ format = "dd-MM-yyyy";
484
+ break;
485
+ case "DD-MM-YY":
486
+ format = "dd-MM-yy";
487
+ break;
488
+ case "MM-DD-YYYY":
489
+ format = "MM-dd-yyyy";
490
+ break;
491
+ case "MM-DD-YY":
492
+ format = "MM-dd-yy";
493
+ break;
494
+ case "MMM DD, YYYY":
495
+ format = "MMM dd, yyyy";
496
+ break;
497
+ case "DD-MMM-YYYY":
498
+ format = "dd-MMM-yyyy";
499
+ break;
500
+ default:
501
+ break;
502
+ }
503
+ }
504
+ }
505
+ if (!format) {
506
+ const formatData = {
507
+ name: el.colName,
508
+ format: this.datePipeFormat,
509
+ type: "date",
510
+ };
511
+ formatSettings.push(formatData);
512
+ }
513
+ else {
514
+ const formatData = {
515
+ name: el.colName,
516
+ format: format,
517
+ type: "date",
518
+ };
519
+ formatSettings.push(formatData);
520
+ }
521
+ }
522
+ });
523
+ }
524
+ //calculatedFieldSettings format push to formatSettings
525
+ if (this.config.calculatedFieldSettings &&
526
+ this.config.calculatedFieldSettings.length > 0) {
527
+ this.config.calculatedFieldSettings.map((el) => {
528
+ if (el.formatString !== "") {
529
+ for (let i = formatSettings.length - 1; i >= 0; i--) {
530
+ if (formatSettings[i].name === el.name) {
531
+ formatSettings.splice(i, 1);
532
+ }
533
+ }
534
+ formatSettings.push({
535
+ name: el.name,
536
+ format: el.formatString,
537
+ });
538
+ }
539
+ });
540
+ }
541
+ let series = this.config.yaxis.series;
542
+ if (series) {
543
+ for (let item of series) {
544
+ const value = {
545
+ name: item.colName,
546
+ caption: this.getCaptionByName(item.colName) || item.title,
547
+ type: item.calMethod,
548
+ };
549
+ values.push(value);
550
+ }
551
+ }
552
+ let groups = this.config.xaxis.groups;
553
+ if (groups) {
554
+ for (let gitem of groups) {
555
+ const field = this.configFields.filter((el) => el.colName === gitem.name);
556
+ if (field.length > 0) {
557
+ gitem.showSubTotals = field[0].showSubTotals;
558
+ gitem.caption =
559
+ field[0].langValue ||
560
+ this.translation[field[0].langCode] ||
561
+ gitem.caption ||
562
+ field[0].langCode;
563
+ }
564
+ rows.push(gitem);
565
+ }
566
+ }
567
+ if (this.config.columnGroup && this.config.columnGroup.length) {
568
+ for (let item of this.config.columnGroup) {
569
+ const field = this.configFields.filter((el) => el.colName === item.name);
570
+ if (field.length > 0) {
571
+ item.showSubTotals = field[0].showSubTotals;
572
+ item.caption =
573
+ field[0].langValue ||
574
+ this.translation[field[0].langCode] ||
575
+ field[0].langCode ||
576
+ item.caption;
577
+ }
578
+ columns.push(item);
579
+ }
580
+ }
581
+ let conditionalFormatSettings = [];
582
+ this.configFields.forEach((field) => {
583
+ if (field.format && field.format.length) {
584
+ if (field.format[0].fontSettingChecked) {
585
+ let conditionalFormatObj = {
586
+ applyGrandTotals: true,
587
+ measure: "",
588
+ value1: null,
589
+ value2: null,
590
+ conditions: "",
591
+ style: {
592
+ backgroundColor: "",
593
+ color: "",
594
+ fontFamily: "",
595
+ fontSize: "",
596
+ },
597
+ };
598
+ let negaConditionalFormatObj = {
599
+ applyGrandTotals: true,
600
+ measure: "",
601
+ value1: null,
602
+ value2: null,
603
+ conditions: "",
604
+ style: {
605
+ backgroundColor: "",
606
+ color: "",
607
+ fontFamily: "",
608
+ fontSize: "",
609
+ },
610
+ };
611
+ // font setting start
612
+ negaConditionalFormatObj.measure =
613
+ field.format[0].selectedField;
614
+ conditionalFormatObj.measure =
615
+ field.format[0].selectedField;
616
+ if (field.format[0].formatChecked &&
617
+ field.format[0].compareSelect) {
618
+ this.setCompareConditional(negaConditionalFormatObj, conditionalFormatObj, field.format[0]);
619
+ }
620
+ else {
621
+ delete conditionalFormatObj.value2;
622
+ delete negaConditionalFormatObj.value2;
623
+ negaConditionalFormatObj.value1 = 0;
624
+ negaConditionalFormatObj.conditions = "LessThan";
625
+ conditionalFormatObj.value1 = 0;
626
+ conditionalFormatObj.conditions = "GreaterThan";
627
+ this.setFontSettingConditional(negaConditionalFormatObj, field.format[0], -1);
628
+ this.setFontSettingConditional(conditionalFormatObj, field.format[0], 1);
629
+ }
630
+ conditionalFormatSettings.push(negaConditionalFormatObj);
631
+ conditionalFormatSettings.unshift(conditionalFormatObj);
632
+ // font setting end
633
+ }
634
+ let formatSettingsObj = {
635
+ name: "",
636
+ format: "",
637
+ };
638
+ if (field.format[0].formatChecked) {
639
+ formatSettingsObj.name = field.format[0].selectedField;
640
+ formatSettingsObj.format =
641
+ this.dashboardPorletsService.pivotTableformatNumber(field.format[0].selectedFormat);
642
+ switch (field.format[0].dataType) {
643
+ case "number":
644
+ formatSettingsObj.format =
645
+ this.dashboardPorletsService.pivotTableformatNumber(field.format[0].selectedFormat);
646
+ break;
647
+ case "integer":
648
+ formatSettingsObj.format =
649
+ this.dashboardPorletsService.pivotTableformatInteger(field.format[0].selectedFormat);
650
+ break;
651
+ case "percentNum":
652
+ case "percent":
653
+ formatSettingsObj.format =
654
+ this.dashboardPorletsService.pivotTableformatPercent(field.format[0].selectedFormat);
655
+ break;
656
+ case "multiple":
657
+ formatSettingsObj.format =
658
+ this.dashboardPorletsService.pivotTableformatMultiple(field.format[0].selectedFormat);
659
+ break;
660
+ case "date":
661
+ case "datetime":
662
+ let format = "";
663
+ if (field.format && field.format.length) {
664
+ if (field.format[0].dateType == "Quarter") {
665
+ format =
666
+ field.format[0].selectedFormatDisplay;
667
+ }
668
+ else if (field.format[0].dateType == "Date") {
669
+ let fromIdx = field.format[0].selectedFormatDisplay.indexOf("(");
670
+ let toIdx = field.format[0].selectedFormatDisplay.indexOf(")");
671
+ format =
672
+ field.format[0].selectedFormatDisplay.slice(fromIdx + 1, toIdx);
673
+ }
674
+ }
675
+ if (format) {
676
+ formatSettingsObj = {
677
+ name: field.colName,
678
+ format: "",
679
+ };
680
+ // field.dataType = "string";
681
+ }
682
+ else {
683
+ formatSettingsObj.format = this.datePipeFormat;
684
+ formatSettingsObj["type"] = "date";
685
+ }
686
+ break;
687
+ default:
688
+ break;
689
+ }
690
+ }
691
+ if (field.format[0].dataType !== "string" &&
692
+ formatSettingsObj.format) {
693
+ formatSettings.push(formatSettingsObj);
694
+ }
695
+ }
696
+ });
697
+ this.customCalculatedFields = this.config.customCalculatedFields
698
+ ? this.config.customCalculatedFields
699
+ : [];
700
+ // SMP2-4582 AGIC - Dashboard item sequence
701
+ let isExistSeq = false;
702
+ let sortSettings = this.config.sortSettings || [];
703
+ if (this.Pivot_Data &&
704
+ this.Pivot_Data[0] &&
705
+ this.Pivot_Data[0].Seq !== null) {
706
+ // 取消Name的默认排序,根据Seq来排序
707
+ sortSettings.push({ name: "Name", order: "None" });
708
+ isExistSeq = true;
709
+ }
710
+ let filterSettings = this.dashboardPorletsService.checkFilterSettings(this.config, this.configFields, this.Pivot_Data);
711
+ let nameFilter = filterSettings.find((x) => x.name === "Name");
712
+ // 存在 Name的filter时,会按照默认排序,需要对Name进行Seq排序处理
713
+ if (isExistSeq && nameFilter && rows.some((x) => x.name === "Name")) {
714
+ let items = nameFilter.items; // 拿到当前排序,默认A-Z
715
+ let seqArr = [];
716
+ items.forEach((name) => {
717
+ let obj = this.Pivot_Data.find((x) => x.Name === name);
718
+ let item = {
719
+ name: name,
720
+ seq: obj.Seq,
721
+ };
722
+ seqArr.push(item);
723
+ });
724
+ seqArr.sort((a, b) => a.seq - b.seq);
725
+ nameFilter.items = seqArr.map((x) => x.name);
726
+ }
727
+ const allFields = this.dashboardPorletsService.allFieldsObj[this.portlet.id];
728
+ if (allFields) {
729
+ values.forEach((value) => {
730
+ const item = allFields.find((field) => field.colName === value.name);
731
+ if (item) {
732
+ value.caption =
733
+ (item.format &&
734
+ item.format.length &&
735
+ item.format[0].displayName) ||
736
+ item.langValue ||
737
+ this.translation[item.langCode] ||
738
+ item.langCode;
739
+ }
740
+ });
741
+ }
742
+ let hasItemDataType = false;
743
+ if (this.Pivot_Data) {
744
+ this.Pivot_Data.map((data) => {
745
+ if (data["AccountTypeCode"]) {
746
+ hasItemDataType = true;
747
+ }
748
+ rows.forEach((row) => {
749
+ if (data[row.name] === "") {
750
+ data[row.name] = "null";
751
+ }
752
+ });
753
+ });
754
+ }
755
+ if (hasItemDataType) {
756
+ sortSettings.push({
757
+ name: "AccountTypeCode",
758
+ order: "Ascending",
759
+ membersOrder: [...this.itemDataTypeSortArr],
760
+ });
761
+ }
762
+ this.config.filters.forEach((filter) => {
763
+ filter.caption =
764
+ this.getCaptionByName(filter.name) || filter.caption;
765
+ });
766
+ this.dataSourceSettings = {
767
+ dataSource: this.Pivot_Data || [],
768
+ rows: rows || [],
769
+ columns: columns || [],
770
+ values: values || [],
771
+ filters: this.config.filters,
772
+ filterSettings: filterSettings,
773
+ excludeFields: this.excludeFields,
774
+ formatSettings: formatSettings,
775
+ conditionalFormatSettings: conditionalFormatSettings,
776
+ // 用于收起展开指定层级, 这玩意只能展开第一层,
777
+ // 必须设定expandAll 为false(默认是false), 这样子才能实现只展开两层
778
+ // drilledMembers,
779
+ expandAll: true,
780
+ enableSorting: true,
781
+ fieldMapping: fieldMapping,
782
+ calculatedFieldSettings: this.config.calculatedFieldSettings,
783
+ sortSettings: sortSettings,
784
+ // groupSettings: this.config.groupSettings,
785
+ valueSortSettings: this.config.valueSortSettings,
786
+ showGrandTotals: this.config.showGrandTotals,
787
+ showRowGrandTotals: this.config.showRowGrandTotals,
788
+ showColumnGrandTotals: this.config.showColumnGrandTotals,
789
+ showSubTotals: this.config.showSubTotals,
790
+ showRowSubTotals: this.config.showRowSubTotals,
791
+ showColumnSubTotals: this.config.showColumnSubTotals,
792
+ };
793
+ console.log("this.dataSourceSettings", this.dataSourceSettings);
794
+ this.ref.markForCheck();
795
+ }
796
+ getCaptionByName(nameString) {
797
+ if (!nameString)
798
+ return "";
799
+ const field = this.configFields.find((el) => el.colName === nameString);
800
+ return field
801
+ ? field.langValue ||
802
+ this.translation[field && field.langCode] ||
803
+ field.langCode
804
+ : "";
805
+ }
806
+ afterPopulate(args) {
807
+ this.tempSubtotals = [];
808
+ this.grandTotals = {};
809
+ this.subTotals = {};
810
+ let tempshowArray = [];
811
+ this.config.yaxis.series.forEach((item) => {
812
+ if (item.hasOwnProperty("showSubTotals") &&
813
+ item.hasOwnProperty("showGrandTotals")) {
814
+ tempshowArray.push({
815
+ name: item.colName,
816
+ calMethod: item.calMethod,
817
+ showSubTotals: item.showSubTotals,
818
+ showGrandTotals: item.showGrandTotals,
819
+ });
820
+ }
821
+ else {
822
+ if (item.hasOwnProperty("showGrandTotals")) {
823
+ tempshowArray.push({
824
+ name: item.colName,
825
+ calMethod: item.calMethod,
826
+ showGrandTotals: item.showGrandTotals,
827
+ });
828
+ }
829
+ if (item.hasOwnProperty("showSubTotals")) {
830
+ tempshowArray.push({
831
+ name: item.colName,
832
+ calMethod: item.calMethod,
833
+ showSubTotals: item.showSubTotals,
834
+ });
835
+ }
836
+ }
837
+ });
838
+ if (this.fieldlistObj && this.pivotObj) {
839
+ this.config.columnGroup = [];
840
+ this.config.xaxis.groups = [];
841
+ this.config.yaxis.series = [];
842
+ this.config.filters = [];
843
+ this.config.filterSettings = [];
844
+ this.config.calculatedFieldSettings = [];
845
+ let groupSettings = this.getDataSourceSettingsProp(this.fieldlistObj, "groupSettings");
846
+ let columns = this.getDataSourceSettingsProp(this.fieldlistObj, "columns");
847
+ let rows = this.getDataSourceSettingsProp(this.fieldlistObj, "rows");
848
+ let filters = this.getDataSourceSettingsProp(this.fieldlistObj, "filters");
849
+ let filterSettings = this.getDataSourceSettingsProp(this.fieldlistObj, "filterSettings");
850
+ let values = this.getDataSourceSettingsProp(this.fieldlistObj, "values");
851
+ let sortSettings = this.getDataSourceSettingsProp(this.fieldlistObj, "sortSettings");
852
+ let calculatedFieldSettings = this.getDataSourceSettingsProp(this.fieldlistObj, "calculatedFieldSettings");
853
+ if (groupSettings.length === 0) {
854
+ for (let column of columns) {
855
+ this.config.columnGroup.push({
856
+ name: column.name,
857
+ caption: this.getCaptionByName(column.name) ||
858
+ column.caption,
859
+ });
860
+ }
861
+ }
862
+ else {
863
+ //If there is a group, first filter the columns of the group field, and then only save the last one
864
+ for (let column of columns) {
865
+ if (!startsWith(column.name, groupSettings[0].name + "_")) {
866
+ this.config.columnGroup.push({
867
+ name: column.name,
868
+ caption: column.name === groupSettings[0].name
869
+ ? ""
870
+ : this.getCaptionByName(column.name) ||
871
+ column.caption,
872
+ });
873
+ }
874
+ }
875
+ }
876
+ for (let row of rows) {
877
+ this.config.xaxis.groups.push({
878
+ name: row.name,
879
+ caption: this.getCaptionByName(row.name) || row.caption,
880
+ });
881
+ }
882
+ for (let filter of filters) {
883
+ this.config.filters.push({
884
+ name: filter.name,
885
+ caption: this.getCaptionByName(filter.name) || filter.caption,
886
+ });
887
+ }
888
+ if (this.filterSettings && this.filterSettings.length > 0) {
889
+ args.dataSourceSettings.filterSettings = this.filterSettings;
890
+ this.config.filterSettings = this.filterSettings;
891
+ delete this.filterSettings;
892
+ }
893
+ else {
894
+ this.config.filterSettings = filterSettings;
895
+ }
896
+ for (let value of values) {
897
+ let seriesData;
898
+ let tempShowObj;
899
+ let filterTempshowArray = [];
900
+ if (tempshowArray.length) {
901
+ filterTempshowArray = tempshowArray.filter((item) => item.name === value.name &&
902
+ item.calMethod === value.type);
903
+ if (filterTempshowArray.length) {
904
+ tempShowObj = filterTempshowArray[0];
905
+ if (tempShowObj.hasOwnProperty("showSubTotals") &&
906
+ tempShowObj.hasOwnProperty("showGrandTotals")) {
907
+ seriesData = {
908
+ colName: value.name,
909
+ calMethod: value.type,
910
+ title: value.caption,
911
+ showSubTotals: tempShowObj.showSubTotals,
912
+ showGrandTotals: tempShowObj.showGrandTotals,
913
+ };
914
+ }
915
+ else {
916
+ if (tempShowObj.hasOwnProperty("showGrandTotals")) {
917
+ seriesData = {
918
+ colName: value.name,
919
+ calMethod: value.type,
920
+ title: value.caption,
921
+ showGrandTotals: tempShowObj.showGrandTotals,
922
+ };
923
+ }
924
+ if (tempShowObj.hasOwnProperty("showSubTotals")) {
925
+ seriesData = {
926
+ colName: value.name,
927
+ calMethod: value.type,
928
+ title: value.caption,
929
+ showSubTotals: tempShowObj.showSubTotals,
930
+ };
931
+ }
932
+ }
933
+ }
934
+ }
935
+ if (!seriesData) {
936
+ seriesData = {
937
+ colName: value.name,
938
+ title: value.caption,
939
+ calMethod: value.type,
940
+ };
941
+ }
942
+ this.config.yaxis.series.push(seriesData);
943
+ }
944
+ for (let calculate of calculatedFieldSettings) {
945
+ const calculateData = {
946
+ name: calculate.name,
947
+ formula: calculate.formula,
948
+ formatString: calculate.formatString === ""
949
+ ? "N2"
950
+ : calculate.formatString,
951
+ };
952
+ this.config.calculatedFieldSettings.push(calculateData);
953
+ }
954
+ this.config.customCalculatedFields = this.customCalculatedFields;
955
+ this.config.sortSettings = sortSettings;
956
+ this.config.groupSettings = groupSettings;
957
+ this.fieldlistObj.updateView(this.pivotObj);
958
+ }
959
+ this.portlet.config = JSON.stringify(this.config);
960
+ //remove the sort
961
+ if (this.pivotObj.dataSourceSettings.sortSettings.length > 0) {
962
+ this.previousSort = this.fieldlistObj.lastSortInfo;
963
+ this.fieldlistObj.lastSortInfo = [];
964
+ }
965
+ }
966
+ afterEnginePopulate(args) {
967
+ if (!Browser.isDevice && this.fieldlistObj && this.pivotObj) {
968
+ this.config.groupSettings = this.getDataSourceSettingsProp(this.pivotObj, "groupSettings");
969
+ this.portlet.config = JSON.stringify(this.config);
970
+ if (this.fieldlistObj)
971
+ this.fieldlistObj.update(this.pivotObj);
972
+ this.pivotObj.grid.queryCellInfo = this.queryCell.bind(this);
973
+ this.pivotObj.grid.headerCellInfo = this.headerCell.bind(this);
974
+ // SMP2-3929 rollback
975
+ // if (!this.isApplyIRR)
976
+ // this.getCalculationResultByDashboardDataTableId();
977
+ }
978
+ if (this.Pivot_Data && this.Pivot_Data.length) {
979
+ setTimeout(() => {
980
+ this.enginePopulated(args);
981
+ }, 1500);
982
+ }
983
+ }
984
+ getDataSourceSettingsProp(obj, key) {
985
+ let prop = null;
986
+ if (obj && obj.dataSourceSettings) {
987
+ prop = obj.dataSourceSettings[key];
988
+ if (Object.prototype.toString.call(prop) === "[object Array]" &&
989
+ prop.length > 0) {
990
+ prop = prop.map((item) => item.properties || item);
991
+ }
992
+ }
993
+ return prop;
994
+ }
995
+ enginePopulating(args) {
996
+ this.grandTotals = {};
997
+ this.subTotals = {};
998
+ this.allDataValue = [];
999
+ // if (args.dataSourceSettings.sortSettings.length) {
1000
+ // for (
1001
+ // let i = 0;
1002
+ // i < args.dataSourceSettings.sortSettings.length;
1003
+ // i++
1004
+ // ) {
1005
+ // if (
1006
+ // this.fieldlistObj.lastSortInfo &&
1007
+ // this.fieldlistObj.lastSortInfo.name ===
1008
+ // args.dataSourceSettings.sortSettings[i].name &&
1009
+ // this.fieldlistObj.lastSortInfo.order === "Ascending" &&
1010
+ // !(
1011
+ // this.fieldlistObj.lastSortInfo.name ===
1012
+ // this.previousSort.name &&
1013
+ // this.previousSort.order === "None"
1014
+ // )
1015
+ // ) {
1016
+ // args.dataSourceSettings.sortSettings[i].order = "None";
1017
+ // } else if (
1018
+ // this.previousSort &&
1019
+ // this.fieldlistObj.lastSortInfo &&
1020
+ // this.fieldlistObj.lastSortInfo.name ===
1021
+ // this.previousSort.name &&
1022
+ // this.previousSort.order === "Ascending"
1023
+ // ) {
1024
+ // args.dataSourceSettings.sortSettings[i].order = "Ascending";
1025
+ // }
1026
+ // }
1027
+ // }
1028
+ }
1029
+ cellClick(args) {
1030
+ if (args.currentCell.classList.contains("e-headercell")) {
1031
+ this.flag = true;
1032
+ }
1033
+ // 清除排序
1034
+ if (this.pivotObj.dataSourceSettings.valueSortSettings.sortOrder &&
1035
+ this.pivotObj.dataSourceSettings.valueSortSettings.headerText &&
1036
+ this.pivotObj.dataSourceSettings.valueSortSettings.sortOrder ===
1037
+ "Descending" &&
1038
+ args.data.valueSort &&
1039
+ this.pivotObj.dataSourceSettings.valueSortSettings.headerText ===
1040
+ args.data.valueSort.levelName) {
1041
+ this.pivotObj.setProperties({
1042
+ dataSourceSettings: {
1043
+ valueSortSettings: {
1044
+ sortOrder: "Descending",
1045
+ headerText: "",
1046
+ },
1047
+ },
1048
+ }, true);
1049
+ if (this.pivotObj)
1050
+ this.pivotObj.refreshData();
1051
+ this.flag = false;
1052
+ this.config.valueSortSettings = {};
1053
+ this.portlet.config = JSON.stringify(this.config);
1054
+ }
1055
+ }
1056
+ queryCell(args) {
1057
+ this.pivotObj.renderModule.rowCellBoundEvent(args);
1058
+ let rowIndex = Number(args.cell.getAttribute("index"));
1059
+ // 新版本26.x中 aria-colindex 会比旧版本v20.x 多1
1060
+ let colIndex = parseInt(args.cell.getAttribute("aria-colindex")) - 1;
1061
+ if (!this.pivotObj.dataSourceSettings.conditionalFormatSettings.length) {
1062
+ if (args.data && args.data[0].formattedText === "Grand Total") {
1063
+ args.cell.classList.add("grand-class");
1064
+ }
1065
+ else {
1066
+ args.cell.classList.add(rowIndex % 2 ? "odd-class" : "even-class");
1067
+ }
1068
+ }
1069
+ else {
1070
+ let measureArr = this.pivotObj.dataSourceSettings.conditionalFormatSettings.map((obj) => {
1071
+ return obj.measure;
1072
+ });
1073
+ if (measureArr.includes(args.data[colIndex].actualText) &&
1074
+ args.data[colIndex].style) {
1075
+ args.cell.style.cssText += `background-color: ${args.data[colIndex].style.backgroundColor} !important`;
1076
+ }
1077
+ if (args.data && args.data[0].formattedText === "Grand Total")
1078
+ args.cell.classList.add("e-customclass");
1079
+ }
1080
+ if (args.data && args.data[0].formattedText === "Grand Total") {
1081
+ args.cell.classList.add("grand-class");
1082
+ }
1083
+ else {
1084
+ if (rowIndex % 2) {
1085
+ args.cell.classList.add("odd-class");
1086
+ }
1087
+ else {
1088
+ args.cell.classList.add("even-class");
1089
+ }
1090
+ }
1091
+ //get sorting data
1092
+ if (this.flag) {
1093
+ this.flag = false;
1094
+ this.config.valueSortSettings =
1095
+ this.pivotObj.dataSourceSettings.valueSortSettings["properties"];
1096
+ this.portlet.config = JSON.stringify(this.config);
1097
+ }
1098
+ //customize the header text
1099
+ if (this.pivotObj.dataSourceSettings.rows.length === 0) {
1100
+ if (args.data &&
1101
+ args.data[colIndex] &&
1102
+ args.data[colIndex].axis === "row") {
1103
+ args.cell.querySelector(".e-cellvalue").innerText =
1104
+ args.data[colIndex].formattedText;
1105
+ }
1106
+ }
1107
+ // SMP2-2912 subtotal字体加粗
1108
+ if (this.pivotObj.dataSourceSettings.rows.length &&
1109
+ args.data[colIndex] &&
1110
+ args.data[0].level !==
1111
+ this.pivotObj.dataSourceSettings.rows.length - 1 &&
1112
+ args.data[colIndex].rowHeaders !== "" &&
1113
+ args.data[colIndex].axis == "value") {
1114
+ args.cell.classList.add("e-customclass");
1115
+ }
1116
+ }
1117
+ headerCell(args) {
1118
+ this.pivotObj.renderModule.columnCellBoundEvent(args);
1119
+ if (this.pivotObj.dataSourceSettings.columns.length === 0) {
1120
+ let node = args.node.querySelector(".e-headercelldiv .e-headertext");
1121
+ if (node)
1122
+ node.innerText = args.cell.column.headerText;
1123
+ }
1124
+ const textAlign = args.cell.column.textAlign;
1125
+ args.cell.column.headerTextAlign = textAlign;
1126
+ args.node.style.textAlign = textAlign === "Right" ? "right" : "left"; // Align right for numeric columns
1127
+ if (textAlign === "Right") {
1128
+ args.node.classList.add("header-align-right");
1129
+ }
1130
+ this.ref.markForCheck();
1131
+ }
1132
+ dataBound(e) {
1133
+ if (this.isInit) {
1134
+ this.isInit = false;
1135
+ }
1136
+ this.grandTotals = {};
1137
+ this.subTotals = {};
1138
+ if (this.pivotObj.grid) {
1139
+ this.pivotObj.grid.resizeStop = this.resizeStop.bind(this);
1140
+ }
1141
+ if (this.pivotObj) {
1142
+ var index = [];
1143
+ // Get the empty row headers here.
1144
+ var emptyRowHeader = document.querySelectorAll('td[aria-label=" column header "]');
1145
+ for (var ele of emptyRowHeader) {
1146
+ if (ele) {
1147
+ index.push(ele.getAttribute("index"));
1148
+ // Remove all the empty row headers here.
1149
+ ele.closest("tr").remove();
1150
+ }
1151
+ }
1152
+ for (var i = 0; i < index.length; i++) {
1153
+ // Get the empty values here.
1154
+ var emptyValues = this.pivotObj.element.querySelectorAll(`td[index="${index[i]}"]`);
1155
+ if (emptyValues[0]) {
1156
+ // Remove all the empty value rows here.
1157
+ emptyValues[0].closest("tr").remove();
1158
+ }
1159
+ }
1160
+ }
1161
+ if (this.fieldlistObj &&
1162
+ this.fieldlistObj.pivotButtonModule &&
1163
+ this.fieldlistObj.pivotButtonModule.menuOption) {
1164
+ this.fieldlistObj.pivotButtonModule.menuOption.stringAggregateTypes = [
1165
+ "Count",
1166
+ "DistinctCount",
1167
+ "First",
1168
+ "Last",
1169
+ ];
1170
+ }
1171
+ if (this.pivotObj.pivotButtonModule &&
1172
+ this.pivotObj.pivotButtonModule.menuOption) {
1173
+ this.pivotObj.pivotButtonModule.menuOption.stringAggregateTypes = [
1174
+ "Count",
1175
+ "DistinctCount",
1176
+ "First",
1177
+ "Last",
1178
+ ];
1179
+ }
1180
+ let allSummaryType = ALL_AGGREGATE_TYPES;
1181
+ this.pivotObj.getAllSummaryType = function () {
1182
+ return allSummaryType;
1183
+ };
1184
+ if (this.fieldlistObj) {
1185
+ this.fieldlistObj.aggregateTypes = allSummaryType;
1186
+ this.fieldlistObj.getAllSummaryType = function () {
1187
+ return allSummaryType;
1188
+ };
1189
+ }
1190
+ this.setValueItemData();
1191
+ }
1192
+ setValueItemData() {
1193
+ setTimeout(() => {
1194
+ const fieldDom = this.fieldlistObj.fieldListSpinnerElement;
1195
+ this.dataSourceSettings.values.forEach((value) => {
1196
+ if (value.type !== "First" && value.type !== "Last") {
1197
+ return;
1198
+ }
1199
+ const valuesDom = fieldDom.querySelector(`.e-values .${value.name} .e-pvt-btn-content`);
1200
+ if (valuesDom.innerHTML !== `${value.type} of ${value.caption}`) {
1201
+ valuesDom.innerHTML = `${value.type} of ${value.caption}`;
1202
+ }
1203
+ });
1204
+ });
1205
+ }
1206
+ calculatedCellSets(args, curFields) {
1207
+ let matchFields = curFields["matchFields"];
1208
+ let formula = curFields["formula"];
1209
+ let value = 0;
1210
+ let rows = this.pivotObj.dataSourceSettings.rows;
1211
+ let invalidTypes = ["string", "nvarchar", "date", "datetime"];
1212
+ let isInvalid = matchFields.some((f) => invalidTypes.includes(this.configFields.filter((el) => el.colName === f.matchWord)[0]["dataType"]));
1213
+ let currentrowCellType = args.rowCellType;
1214
+ if (isInvalid)
1215
+ return "-";
1216
+ if (args.rowCellType === "subTotal" ||
1217
+ args.rowCellType === "grandTotal") {
1218
+ let childHeaders = [];
1219
+ let sum = 0;
1220
+ let cloneCellSets = cloneDeep(args.cellSets);
1221
+ let groupNameArrays = [];
1222
+ for (let index = args.row.level; index < rows.length; index++) {
1223
+ groupNameArrays.push(rows[index].name);
1224
+ }
1225
+ for (let i = 0; i < cloneCellSets.length; i++) {
1226
+ let values = [];
1227
+ let header = groupNameArrays
1228
+ .map((name) => {
1229
+ values.push(cloneCellSets[i][name]);
1230
+ return cloneCellSets[i][name];
1231
+ })
1232
+ .join("-");
1233
+ if (!childHeaders.includes(header)) {
1234
+ childHeaders.push(header);
1235
+ let filterObj = {};
1236
+ groupNameArrays.map((name, i) => (filterObj[name] = values[i]));
1237
+ args.cellSets = _filter(cloneCellSets, filterObj);
1238
+ args.rowCellType = "value";
1239
+ sum += this.calculatedValues(args, matchFields, formula);
1240
+ }
1241
+ }
1242
+ args.rowCellType = currentrowCellType;
1243
+ // 暂存当前SubTotal, 用于收缩时读取
1244
+ let prefixHeader = this.getCalcHeader(args, formula);
1245
+ this.updateTempSubtotals(prefixHeader, sum);
1246
+ return sum;
1247
+ }
1248
+ else if (args.rowCellType === "value") {
1249
+ if (args.row.hasChild) {
1250
+ // collapse 读取SubTotal
1251
+ let header = this.getCalcHeader(args, formula);
1252
+ let index = this.tempSubtotals.findIndex((item) => item.rowName === header);
1253
+ if (index > -1) {
1254
+ value = this.tempSubtotals[index].rowValue;
1255
+ }
1256
+ }
1257
+ else {
1258
+ // expand
1259
+ value = this.calculatedValues(args, matchFields, formula);
1260
+ }
1261
+ }
1262
+ return value;
1263
+ }
1264
+ actionFailure(args) {
1265
+ if (args.actionName == "Drill down" || args.actionName == "Drill up") {
1266
+ // Triggers when the current UI action fails to achieve the desired result.
1267
+ }
1268
+ }
1269
+ getCalcHeader(args, formula) {
1270
+ let header = "";
1271
+ let rows = this.pivotObj.dataSourceSettings.rows;
1272
+ let groupNameArrays = [];
1273
+ for (let index = 0; index < args.row.level; index++) {
1274
+ groupNameArrays.push(rows[index].name);
1275
+ }
1276
+ header = groupNameArrays.length
1277
+ ? groupNameArrays
1278
+ .map((name) => {
1279
+ return args.cellSets[0][name];
1280
+ })
1281
+ .join("-") +
1282
+ "-" +
1283
+ args.row.actualText
1284
+ : args.row.actualText;
1285
+ if (formula)
1286
+ header += "___" + formula;
1287
+ return header;
1288
+ }
1289
+ updateTempSubtotals(rowName, rowValue) {
1290
+ let index = this.tempSubtotals.findIndex((item) => item.rowName === rowName);
1291
+ let temp = {};
1292
+ temp.rowName = rowName;
1293
+ temp.rowValue = rowValue;
1294
+ if (index > -1) {
1295
+ this.tempSubtotals.splice(index, 1, temp);
1296
+ }
1297
+ else {
1298
+ this.tempSubtotals.push(temp);
1299
+ }
1300
+ }
1301
+ calculatedValues(args, matchFields, formula) {
1302
+ if (matchFields.length) {
1303
+ let calculedMatchFields = matchFields.map((f) => {
1304
+ switch (f.matchMethod) {
1305
+ case "First":
1306
+ case "Last":
1307
+ f.replaceValue = this.calculatedFistLast(args, f.matchMethod, f.matchWord);
1308
+ break;
1309
+ case "Max":
1310
+ f.replaceValue = maxBy(args.cellSets, (o) => Number(o[f.matchWord]))[f.matchWord];
1311
+ break;
1312
+ case "Min":
1313
+ f.replaceValue = minBy(args.cellSets, (o) => Number(o[f.matchWord]))[f.matchWord];
1314
+ break;
1315
+ case "Sum":
1316
+ f.replaceValue = sumBy(args.cellSets, (o) => Number(o[f.matchWord]));
1317
+ // SMP2-4094 Unicorn - L3 Adjusted NAV value issues
1318
+ f.replaceValue =
1319
+ f.replaceValue && f.replaceValue.toFixed(10);
1320
+ break;
1321
+ case "Avg":
1322
+ f.replaceValue = meanBy(args.cellSets, (o) => Number(o[f.matchWord]));
1323
+ break;
1324
+ default:
1325
+ break;
1326
+ }
1327
+ return f;
1328
+ });
1329
+ let resultFormula = formula;
1330
+ if (calculedMatchFields.length) {
1331
+ for (let i = 0; i < calculedMatchFields.length; i++) {
1332
+ resultFormula = resultFormula.replace(calculedMatchFields[i].matchStr, "(" + calculedMatchFields[i].replaceValue + ")");
1333
+ }
1334
+ }
1335
+ try {
1336
+ let result = new Function("return " + resultFormula.replace(/[^-<>?:()\d/*+.]/g, ""))();
1337
+ if (isNaN(result) || !isFinite(result)) {
1338
+ return 0;
1339
+ }
1340
+ else {
1341
+ return result;
1342
+ }
1343
+ }
1344
+ catch (error) {
1345
+ return NaN;
1346
+ }
1347
+ }
1348
+ return 0;
1349
+ }
1350
+ totalFormatted = {};
1351
+ aggregateCellInfo(args) {
1352
+ let asOfDate = this.pbf.time(this.dashboard.asOfDate);
1353
+ // if calculated field
1354
+ if (args.aggregateType == "CalculatedField") {
1355
+ for (let i = 0; i < this.customCalculatedFields.length; i++) {
1356
+ if (args.fieldName == this.customCalculatedFields[i].name) {
1357
+ args.value = this.calculatedCellSets(args, this.customCalculatedFields[i]);
1358
+ }
1359
+ }
1360
+ }
1361
+ if ([
1362
+ "CalculateIRR",
1363
+ "CalculateIRRBeforeCarried",
1364
+ "CalculateIRRIRRDate",
1365
+ "CalculateIRRMTD",
1366
+ "CalculateIRRQTD",
1367
+ "CalculateIRRYTD",
1368
+ ].includes(args.aggregateType)) {
1369
+ // console.log("==========================");
1370
+ // console.log("args:", args);
1371
+ let valueField;
1372
+ let dateField;
1373
+ let startDate;
1374
+ let endDate;
1375
+ switch (args.aggregateType) {
1376
+ case "CalculateIRR":
1377
+ valueField = "IRRAdjValue";
1378
+ dateField = "IRRDate";
1379
+ break;
1380
+ case "CalculateIRRMTD":
1381
+ startDate = moment(asOfDate)
1382
+ .startOf("month")
1383
+ .format("YYYY-MM-DD");
1384
+ endDate = moment(asOfDate).format("YYYY-MM-DD");
1385
+ valueField = "IRRAdjValue";
1386
+ dateField = "IRRDate";
1387
+ break;
1388
+ case "CalculateIRRQTD":
1389
+ startDate = moment(asOfDate)
1390
+ .startOf("quarter")
1391
+ .format("YYYY-MM-DD");
1392
+ endDate = moment(asOfDate).format("YYYY-MM-DD");
1393
+ valueField = "IRRAdjValue";
1394
+ dateField = "IRRDate";
1395
+ break;
1396
+ case "CalculateIRRYTD":
1397
+ startDate = moment(asOfDate)
1398
+ .startOf("year")
1399
+ .format("YYYY-MM-DD");
1400
+ endDate = moment(asOfDate).format("YYYY-MM-DD");
1401
+ valueField = "IRRAdjValue";
1402
+ dateField = "IRRDate";
1403
+ break;
1404
+ case "CalculateIRRIRRDate":
1405
+ valueField = "IRRAdjValue";
1406
+ dateField = "CalculateIRRDate";
1407
+ break;
1408
+ case "CalculateIRRBeforeCarried":
1409
+ valueField = "IRRAdjValueBeforeCarry";
1410
+ dateField = "IRRDate";
1411
+ break;
1412
+ default:
1413
+ break;
1414
+ }
1415
+ let NAVAdj = 0;
1416
+ let values = [];
1417
+ let beforeStartNAVAdj = 0; // 存储上一个阶段的NAVAdj总和
1418
+ let beforeStartValues = []; // 存储上一个阶段的累计集合 (只是为了打印,没有实际用途)
1419
+ let field = this.configFields.filter((el) => el.colName ===
1420
+ this.dashboardPorletsService.getAggregateType(args.aggregateType));
1421
+ for (let i = 0; i < args.cellSets.length; i++) {
1422
+ const data = {
1423
+ amount: args.cellSets[i]["IRRAmount"],
1424
+ date: this.pbf.time(args.cellSets[i][dateField]) ===
1425
+ "Invalid date"
1426
+ ? asOfDate
1427
+ : this.pbf.time(args.cellSets[i][dateField]),
1428
+ };
1429
+ // SMP2-16920
1430
+ // If IRR Date > Dashboard report date = Takes as of dashboard report date
1431
+ if (args.aggregateType === "CalculateIRRIRRDate" &&
1432
+ asOfDate < this.pbf.time(args.cellSets[i][dateField])) {
1433
+ data.date = asOfDate;
1434
+ }
1435
+ NAVAdj += args.cellSets[i][valueField];
1436
+ // SMP2-17219 MTD QTD YTD IRR
1437
+ if (startDate && endDate) {
1438
+ if (moment(data.date).isBefore(startDate)) {
1439
+ data[valueField] = args.cellSets[i][valueField];
1440
+ beforeStartValues.push(data);
1441
+ beforeStartNAVAdj += data[valueField];
1442
+ }
1443
+ if (!moment(data.date).isBetween(startDate, endDate, null, "[]")) {
1444
+ continue;
1445
+ }
1446
+ }
1447
+ if (data.amount != 0) {
1448
+ values.push(data);
1449
+ }
1450
+ }
1451
+ if (NAVAdj > 0.0001 || NAVAdj < -0.0001) {
1452
+ values.push({
1453
+ amount: NAVAdj,
1454
+ date: asOfDate,
1455
+ });
1456
+ }
1457
+ values = sortBy(values, "date");
1458
+ // 如果是MTD,QTD,YTD 则需要把当前阶段以前的所有数据进行汇总,加入计算
1459
+ if (startDate && endDate) {
1460
+ values.unshift({
1461
+ amount: -beforeStartNAVAdj,
1462
+ date: this.pbf.time(startDate),
1463
+ });
1464
+ }
1465
+ // console.log("beforeStartValues:", beforeStartValues);
1466
+ // console.log("values:", values);
1467
+ if (values.length > 0) {
1468
+ let guess = 0.1;
1469
+ const sumAmount = values
1470
+ .map((item) => item.amount)
1471
+ .reduce((prev, curr) => prev + curr, 0);
1472
+ if (sumAmount < 0) {
1473
+ guess = -0.1;
1474
+ }
1475
+ //SMP2-2249 fixed the big irr issue
1476
+ if (sumAmount === 0) {
1477
+ args.value = 0;
1478
+ }
1479
+ else {
1480
+ const valueItems = values.slice(0, values.length - 1);
1481
+ const valueList = valueItems.map((item) => item.amount);
1482
+ const dateList = valueItems.map((item) => item.date);
1483
+ const lastItem = values[values.length - 1];
1484
+ const navAdjust = lastItem.amount;
1485
+ const latestDate = lastItem.date;
1486
+ let irr = this.dashboardPorletsService.ExcelFormulas._CalculateXirr(valueList, dateList, navAdjust, latestDate);
1487
+ args.value = irr === null ? "" : irr;
1488
+ }
1489
+ }
1490
+ else {
1491
+ args.value = "";
1492
+ }
1493
+ // console.log("args.value:", args.value);
1494
+ if (this.pivotObj.engineModule &&
1495
+ this.pivotObj.engineModule.formatFields[args.fieldName]) {
1496
+ delete this.pivotObj.engineModule.formatFields[args.fieldName];
1497
+ this.pivotObj.engineModule.formatFields[args.fieldName] = {
1498
+ name: args.fieldName,
1499
+ format: field.length > 0
1500
+ ? field[0].format &&
1501
+ field[0].format.length &&
1502
+ field[0].format[0].formatChecked
1503
+ ? this.dashboardPorletsService.pivotTableformatPercent(field[0].format[0].selectedFormat)
1504
+ : this.dashboardPorletsService.formatPercent(field[0].dp)
1505
+ : "P2",
1506
+ };
1507
+ }
1508
+ }
1509
+ // SMP2-16520 TWR 月/季/年 && SMP2-16683 VAR
1510
+ if ([
1511
+ "CalculateTWRMTD",
1512
+ "CalculateTWRQTD",
1513
+ "CalculateTWRYTD",
1514
+ "CalculateVARMTD_99",
1515
+ "CalculateVARQTD_99",
1516
+ "CalculateVARYTD_99",
1517
+ "CalculateVARMTD_95",
1518
+ "CalculateVARQTD_95",
1519
+ "CalculateVARYTD_95",
1520
+ ].includes(args.aggregateType)) {
1521
+ // console.log("==========================");
1522
+ // console.log("args:", args);
1523
+ let valueField = "IRRAdjValue";
1524
+ let dateField = "IRRDate";
1525
+ let timeRange;
1526
+ switch (args.aggregateType) {
1527
+ case "CalculateTWRMTD":
1528
+ case "CalculateVARMTD_99":
1529
+ case "CalculateVARMTD_95":
1530
+ timeRange = "month";
1531
+ break;
1532
+ case "CalculateTWRQTD":
1533
+ case "CalculateVARQTD_99":
1534
+ case "CalculateVARQTD_95":
1535
+ timeRange = "quarter";
1536
+ break;
1537
+ case "CalculateTWRYTD":
1538
+ case "CalculateVARYTD_99":
1539
+ case "CalculateVARYTD_95":
1540
+ timeRange = "year";
1541
+ break;
1542
+ default:
1543
+ break;
1544
+ }
1545
+ let values = []; // 这个阶段的累计集合
1546
+ let field = this.configFields.filter((el) => el.colName ===
1547
+ this.dashboardPorletsService.getAggregateType(args.aggregateType));
1548
+ for (let i = 0; i < args.cellSets.length; i++) {
1549
+ const data = {
1550
+ [valueField]: args.cellSets[i][valueField],
1551
+ date: this.pbf.time(args.cellSets[i][dateField]) ===
1552
+ "Invalid date"
1553
+ ? asOfDate
1554
+ : this.pbf.time(args.cellSets[i][dateField]),
1555
+ };
1556
+ values.push(data);
1557
+ }
1558
+ // 如果asOfDate不是 本月/季度/年 的最后一天,都是截至 上个月/季度/年 的最后一天的数据去计算
1559
+ let _asOfDate = moment(asOfDate);
1560
+ // console.log("_asOfDate:", _asOfDate);
1561
+ let isEndOfPeriod = (unit) => {
1562
+ return (_asOfDate.format("YYYY-MM-DD") ===
1563
+ _asOfDate.endOf(unit).format("YYYY-MM-DD"));
1564
+ };
1565
+ let endDate = isEndOfPeriod(timeRange)
1566
+ ? moment(asOfDate).format("YYYY-MM-DD")
1567
+ : moment(asOfDate)
1568
+ .subtract(1, timeRange)
1569
+ .endOf(timeRange)
1570
+ .format("YYYY-MM-DD");
1571
+ // console.log("endDate:", endDate);
1572
+ values = values.filter((item) => moment(item.date).isSameOrBefore(endDate));
1573
+ values = sortBy(values, "date");
1574
+ // console.log("values:", values);
1575
+ if (values.length > 0) {
1576
+ let result = this.getTimeRanges(values, endDate, timeRange, "date"); // 各个阶段的数据
1577
+ let resultTotal = {}; // 各个阶段总和
1578
+ for (const prop in result) {
1579
+ resultTotal[prop] = result[prop].reduce((acc, cur) => {
1580
+ return acc + (cur[valueField] || 0);
1581
+ }, 0);
1582
+ }
1583
+ // console.log("result:", result);
1584
+ // console.log("resultTotal:", resultTotal);
1585
+ const cumulativeSum = {}; // 各个阶段累计和
1586
+ let sum = 0;
1587
+ for (const key of Object.keys(resultTotal)) {
1588
+ sum += resultTotal[key];
1589
+ cumulativeSum[`${key}`] = sum;
1590
+ }
1591
+ // console.log("cumulativeSum:", cumulativeSum);
1592
+ const keys = Object.keys(cumulativeSum);
1593
+ let twrList = [];
1594
+ // 遍历每两个阶段 计算TWR
1595
+ for (let i = 0; i < keys.length - 1; i++) {
1596
+ const key1 = keys[i];
1597
+ const key2 = keys[i + 1];
1598
+ // 计算两个阶段之间的递增量, 出数不能为0
1599
+ if (cumulativeSum[key1] != 0) {
1600
+ const increment = cumulativeSum[key2] - cumulativeSum[key1];
1601
+ let twr = increment / cumulativeSum[key1];
1602
+ twrList.push({
1603
+ date: key2,
1604
+ twr: twr,
1605
+ });
1606
+ }
1607
+ }
1608
+ // 计算Average TWR
1609
+ // console.log("twrList:", twrList);
1610
+ let averageTWR = this.calculateGrowthRate(twrList.map((x) => x.twr));
1611
+ // console.log("计算Average TWR:", averageTWR);
1612
+ if ([
1613
+ "CalculateTWRMTD",
1614
+ "CalculateTWRQTD",
1615
+ "CalculateTWRYTD",
1616
+ ].includes(args.aggregateType)) {
1617
+ // SMP2-16520 TWR 月/季/年
1618
+ args.value =
1619
+ isNaN(averageTWR) || averageTWR == null
1620
+ ? ""
1621
+ : Number(averageTWR);
1622
+ }
1623
+ else {
1624
+ if (isNaN(averageTWR) || averageTWR == null) {
1625
+ args.value = "";
1626
+ }
1627
+ else {
1628
+ // SMP2-16683 VAR 区分99%和95%
1629
+ let ZScore = [
1630
+ "CalculateVARMTD_99",
1631
+ "CalculateVARQTD_99",
1632
+ "CalculateVARYTD_99",
1633
+ ].includes(args.aggregateType)
1634
+ ? 2.33
1635
+ : 1.65;
1636
+ if (twrList.length < 2) {
1637
+ args.value = "";
1638
+ }
1639
+ else {
1640
+ let SD = this.calculateStandardDeviation(twrList.map((x) => x.twr));
1641
+ // console.log("calculateStandardDeviation:", SD);
1642
+ let VAR = averageTWR - SD * ZScore;
1643
+ args.value = Number(VAR);
1644
+ }
1645
+ }
1646
+ }
1647
+ // console.log("args.value:", args.value);
1648
+ }
1649
+ if (this.pivotObj.engineModule &&
1650
+ this.pivotObj.engineModule.formatFields[args.fieldName]) {
1651
+ delete this.pivotObj.engineModule.formatFields[args.fieldName];
1652
+ this.pivotObj.engineModule.formatFields[args.fieldName] = {
1653
+ name: args.fieldName,
1654
+ format: field.length > 0
1655
+ ? field[0].format &&
1656
+ field[0].format.length &&
1657
+ field[0].format[0].formatChecked
1658
+ ? this.dashboardPorletsService.pivotTableformatPercent(field[0].format[0].selectedFormat)
1659
+ : this.dashboardPorletsService.formatPercent(field[0].dp)
1660
+ : "P2",
1661
+ };
1662
+ }
1663
+ }
1664
+ //SMP2-2701
1665
+ if (args.aggregateType === "CalculateIRRActualAudited") {
1666
+ let NAVAdj = 0;
1667
+ let values = [];
1668
+ let field = this.configFields.filter((el) => el.colName ===
1669
+ this.dashboardPorletsService.getAggregateType(args.aggregateType));
1670
+ //SMP2-2713 only judge for this dataMart(GrossNet)
1671
+ if (this.portlet.figureCode === "GrossNet" ||
1672
+ this.portlet.figureCode ===
1673
+ "CombinedInvestmentFundNCompanyCashflow") {
1674
+ for (let i = 0; i < args.cellSets.length; i++) {
1675
+ const data = {
1676
+ amount: args.cellSets[i]["IRRAmount"],
1677
+ date: this.pbf.time(args.cellSets[i]["IRRDate"]) ===
1678
+ "Invalid date"
1679
+ ? asOfDate
1680
+ : this.pbf.time(args.cellSets[i]["IRRDate"]),
1681
+ };
1682
+ NAVAdj += args.cellSets[i]["ActualAuditedNAV"];
1683
+ if (data.amount != 0) {
1684
+ values.push(data);
1685
+ }
1686
+ }
1687
+ }
1688
+ //filter the data by the DataType(Actual Reported Audited)
1689
+ else {
1690
+ let argsdata = args.cellSets.filter((el) => el.DataType === "ACTUAL_AUDITED" ||
1691
+ el.DataType === "REPORTED");
1692
+ for (let i = 0; i < argsdata.length; i++) {
1693
+ const data = {
1694
+ amount: argsdata[i]["IRRAmount"],
1695
+ date: this.pbf.time(argsdata[i]["IRRDate"]) ===
1696
+ "Invalid date"
1697
+ ? asOfDate
1698
+ : this.pbf.time(argsdata[i]["IRRDate"]),
1699
+ };
1700
+ NAVAdj += argsdata[i]["IRRAdjValue"];
1701
+ if (data.amount != 0) {
1702
+ values.push(data);
1703
+ }
1704
+ }
1705
+ }
1706
+ if (NAVAdj > 0.0001 || NAVAdj < -0.0001) {
1707
+ values.push({
1708
+ amount: NAVAdj,
1709
+ date: asOfDate,
1710
+ });
1711
+ }
1712
+ values = sortBy(values, "date");
1713
+ if (values.length > 0) {
1714
+ let guess = 0.1;
1715
+ const sumAmount = values
1716
+ .map((item) => item.amount)
1717
+ .reduce((prev, curr) => prev + curr, 0);
1718
+ if (sumAmount < 0) {
1719
+ guess = -0.1;
1720
+ }
1721
+ //SMP2-2249 fixed the big irr issue
1722
+ if (sumAmount === 0) {
1723
+ args.value = 0;
1724
+ }
1725
+ else {
1726
+ const valueItems = values.slice(0, values.length - 1);
1727
+ const valueList = valueItems.map((item) => item.amount);
1728
+ const dateList = valueItems.map((item) => item.date);
1729
+ const lastItem = values[values.length - 1];
1730
+ const navAdjust = lastItem.amount;
1731
+ const latestDate = lastItem.date;
1732
+ let irr = this.dashboardPorletsService.ExcelFormulas._CalculateXirr(valueList, dateList, navAdjust, latestDate);
1733
+ args.value = irr === null ? 0 : irr;
1734
+ }
1735
+ }
1736
+ else {
1737
+ args.value = 0;
1738
+ }
1739
+ if (this.pivotObj.engineModule &&
1740
+ this.pivotObj.engineModule.formatFields[args.fieldName]) {
1741
+ delete this.pivotObj.engineModule.formatFields[args.fieldName];
1742
+ this.pivotObj.engineModule.formatFields[args.fieldName] = {
1743
+ name: args.fieldName,
1744
+ format: field.length > 0
1745
+ ? field[0].format &&
1746
+ field[0].format.length &&
1747
+ field[0].format[0].formatChecked
1748
+ ? this.dashboardPorletsService.pivotTableformatPercent(field[0].format[0].selectedFormat)
1749
+ : this.dashboardPorletsService.formatPercent(field[0].dp)
1750
+ : "P2",
1751
+ };
1752
+ }
1753
+ }
1754
+ //SMP2-3411
1755
+ if (args.aggregateType === "CalculateIRRReported") {
1756
+ let NAVAdj = 0;
1757
+ let values = [];
1758
+ let field = this.configFields.filter((el) => el.colName ===
1759
+ this.dashboardPorletsService.getAggregateType(args.aggregateType));
1760
+ if (this.portlet.figureCode === "GrossNet" ||
1761
+ this.portlet.figureCode ===
1762
+ "CombinedInvestmentFundNCompanyCashflow") {
1763
+ for (let i = 0; i < args.cellSets.length; i++) {
1764
+ const data = {
1765
+ amount: args.cellSets[i]["IRRAmount"],
1766
+ date: this.pbf.time(args.cellSets[i]["IRRDate"]) ===
1767
+ "Invalid date"
1768
+ ? asOfDate
1769
+ : this.pbf.time(args.cellSets[i]["IRRDate"]),
1770
+ };
1771
+ NAVAdj += args.cellSets[i]["ReportedNAV"];
1772
+ if (data.amount != 0) {
1773
+ values.push(data);
1774
+ }
1775
+ }
1776
+ }
1777
+ else {
1778
+ for (let i = 0; i < args.cellSets.length; i++) {
1779
+ const data = {
1780
+ amount: args.cellSets[i]["IRRAmount"],
1781
+ date: this.pbf.time(args.cellSets[i]["IRRDate"]) ===
1782
+ "Invalid date"
1783
+ ? asOfDate
1784
+ : this.pbf.time(args.cellSets[i]["IRRDate"]),
1785
+ };
1786
+ NAVAdj += args.cellSets[i]["IRRAdjValue"];
1787
+ if (data.amount != 0) {
1788
+ values.push(data);
1789
+ }
1790
+ }
1791
+ }
1792
+ if (NAVAdj > 0.0001 || NAVAdj < -0.0001) {
1793
+ values.push({
1794
+ amount: NAVAdj,
1795
+ date: asOfDate,
1796
+ });
1797
+ }
1798
+ values = sortBy(values, "date");
1799
+ if (values.length > 0) {
1800
+ let guess = 0.1;
1801
+ const sumAmount = values
1802
+ .map((item) => item.amount)
1803
+ .reduce((prev, curr) => prev + curr, 0);
1804
+ if (sumAmount < 0) {
1805
+ guess = -0.1;
1806
+ }
1807
+ //SMP2-2249 fixed the big irr issue
1808
+ if (sumAmount === 0) {
1809
+ args.value = 0;
1810
+ }
1811
+ else {
1812
+ const valueItems = values.slice(0, values.length - 1);
1813
+ const valueList = valueItems.map((item) => item.amount);
1814
+ const dateList = valueItems.map((item) => item.date);
1815
+ const lastItem = values[values.length - 1];
1816
+ const navAdjust = lastItem.amount;
1817
+ const latestDate = lastItem.date;
1818
+ let irr = this.dashboardPorletsService.ExcelFormulas._CalculateXirr(valueList, dateList, navAdjust, latestDate);
1819
+ args.value = irr === null ? 0 : irr;
1820
+ }
1821
+ }
1822
+ else {
1823
+ args.value = 0;
1824
+ }
1825
+ if (this.pivotObj.engineModule &&
1826
+ this.pivotObj.engineModule.formatFields[args.fieldName]) {
1827
+ delete this.pivotObj.engineModule.formatFields[args.fieldName];
1828
+ this.pivotObj.engineModule.formatFields[args.fieldName] = {
1829
+ name: args.fieldName,
1830
+ format: field.length > 0
1831
+ ? field[0].format &&
1832
+ field[0].format.length &&
1833
+ field[0].format[0].formatChecked
1834
+ ? this.dashboardPorletsService.pivotTableformatPercent(field[0].format[0].selectedFormat)
1835
+ : this.dashboardPorletsService.formatPercent(field[0].dp)
1836
+ : "P2",
1837
+ };
1838
+ }
1839
+ }
1840
+ if (args.aggregateType === "CalculateMultiple" ||
1841
+ args.aggregateType === "CalculatePIC" ||
1842
+ args.aggregateType === "CalculateDPI" ||
1843
+ args.aggregateType === "CalculateTVPI" ||
1844
+ args.aggregateType === "CalculateRVPI" ||
1845
+ args.aggregateType === "CalculateMActualAudited" ||
1846
+ args.aggregateType === "CalculateMReported") {
1847
+ let totalNumerator = 0;
1848
+ let totalDenominator = 0;
1849
+ let numeratorName;
1850
+ let denominatorName;
1851
+ let field = this.configFields.filter((el) => el.colName ===
1852
+ this.dashboardPorletsService.getAggregateType(args.aggregateType));
1853
+ if (field.length > 0) {
1854
+ const formulaArray = field[0].formula.split("/");
1855
+ numeratorName = formulaArray[0];
1856
+ denominatorName = formulaArray[1];
1857
+ }
1858
+ for (let j = 0; j < args.cellSets.length; j++) {
1859
+ totalNumerator += args.cellSets[j][numeratorName];
1860
+ totalDenominator += args.cellSets[j][denominatorName];
1861
+ }
1862
+ if (totalDenominator !== 0) {
1863
+ args.value = totalNumerator / totalDenominator;
1864
+ if (this.pivotObj.engineModule &&
1865
+ this.pivotObj.engineModule.formatFields[args.fieldName]) {
1866
+ delete this.pivotObj.engineModule.formatFields[args.fieldName];
1867
+ this.pivotObj.engineModule.formatFields[args.fieldName] = {
1868
+ name: args.fieldName,
1869
+ format: field.length > 0
1870
+ ? field[0].format &&
1871
+ field[0].format.length &&
1872
+ field[0].format[0].formatChecked
1873
+ ? this.dashboardPorletsService.pivotTableformatMultiple(field[0].format[0].selectedFormat)
1874
+ : this.dashboardPorletsService.formatMultiple(field[0].dp)
1875
+ : "###0.00'x'",
1876
+ };
1877
+ }
1878
+ }
1879
+ else {
1880
+ args.value = "";
1881
+ }
1882
+ }
1883
+ if (args.aggregateType === "First" || args.aggregateType === "Last") {
1884
+ args.value = this.calculatedFistLast(args, args.aggregateType, args.fieldName);
1885
+ }
1886
+ if (args.aggregateType === "Count" ||
1887
+ args.aggregateType === "DistinctCount") {
1888
+ if (args.value) {
1889
+ args.value = args.value.toFixed(2);
1890
+ }
1891
+ }
1892
+ if (!args.value &&
1893
+ args.value !== 0 &&
1894
+ args.value !== false &&
1895
+ args.value !== "false") {
1896
+ args.skipFormatting = true;
1897
+ args.value = "";
1898
+ }
1899
+ // 新建pivot table, 还没有设置row, 选了column之后grandtotal会有值
1900
+ if (args.rowCellType === "grandTotal" &&
1901
+ !this.pivotObj.dataSourceSettings.rows.length) {
1902
+ args.value = "";
1903
+ }
1904
+ //SMP2-2889
1905
+ if (args.rowCellType === "subTotal") {
1906
+ const valueField_data = this.config.yaxis.series.filter((el) => el.colName === args.fieldName);
1907
+ if (valueField_data.length > 0) {
1908
+ if (valueField_data[0].showSubTotals === false) {
1909
+ args.value = "";
1910
+ args.skipFormatting = true;
1911
+ }
1912
+ }
1913
+ }
1914
+ if (args.rowCellType === "grandTotal") {
1915
+ const valueField_data = this.config.yaxis.series.filter((el) => el.colName === args.fieldName);
1916
+ if (valueField_data.length > 0) {
1917
+ if (valueField_data[0].showGrandTotals === false) {
1918
+ args.value = "";
1919
+ args.skipFormatting = true;
1920
+ }
1921
+ }
1922
+ }
1923
+ // SMP2-3416 start
1924
+ if (this.zeroFormatData.hgList.includes(args.fieldName) &&
1925
+ args.value === 0) {
1926
+ args.value = "-";
1927
+ args.skipFormatting = true;
1928
+ }
1929
+ if (this.zeroFormatData.emptyList.includes(args.fieldName) &&
1930
+ args.value === 0) {
1931
+ args.value = "";
1932
+ args.skipFormatting = true;
1933
+ }
1934
+ if (this.millionFields.includes(args.fieldName) &&
1935
+ !isNaN(Number(args.value)) &&
1936
+ args.value !== 0 &&
1937
+ args.value !== "" &&
1938
+ args.value !== null) {
1939
+ if (args.columnCellType == "grandTotal" &&
1940
+ args.rowCellType == "grandTotal") {
1941
+ if (!this.totalFormatted[args.fieldName]) {
1942
+ this.totalFormatted[args.fieldName] = true;
1943
+ args.value = args.value / 1000000;
1944
+ }
1945
+ }
1946
+ else {
1947
+ args.value = args.value / 1000000;
1948
+ }
1949
+ }
1950
+ // SMP2-2486 & percentNum的format问题
1951
+ if (this.percentNumFields.length &&
1952
+ this.percentNumFields.includes(args.fieldName) &&
1953
+ !isNaN(Number(args.value)) &&
1954
+ args.value !== 0 &&
1955
+ args.value !== "" &&
1956
+ args.value !== null) {
1957
+ if (args.columnCellType == "grandTotal" &&
1958
+ args.rowCellType == "grandTotal") {
1959
+ if (!this.totalFormatted[args.fieldName]) {
1960
+ this.totalFormatted[args.fieldName] = true;
1961
+ args.value = args.value / 100;
1962
+ }
1963
+ }
1964
+ else {
1965
+ args.value = args.value / 100;
1966
+ }
1967
+ }
1968
+ if (args.aggregateType == "CalculatedField" &&
1969
+ !isNaN(Number(args.value)) &&
1970
+ !this.pivotObj.engineModule.formatFields[args.fieldName].format) {
1971
+ args.value = Number(args.value).toFixed(2);
1972
+ }
1973
+ // SMP2-3416 end
1974
+ this.ref.markForCheck();
1975
+ this.ref.detectChanges();
1976
+ }
1977
+ calculatedFistLast(args, aggregateType, fieldName) {
1978
+ if (!args.row.actualText)
1979
+ args.row.actualText = args.row.formattedText;
1980
+ if (!args.column.actualText)
1981
+ args.column.actualText = args.column.formattedText;
1982
+ let field = this.configFields.filter((el) => el.colName === fieldName)[0];
1983
+ if (args.rowCellType === "value" && !args.row.hasChild) {
1984
+ if (args.cellSets[0]) {
1985
+ if (aggregateType === "First") {
1986
+ for (let firstIndex = 0; firstIndex < args.cellSets.length; firstIndex++) {
1987
+ if (this.pivotObj.dataSourceSettings.columns.length ==
1988
+ 1 &&
1989
+ args.columnCellType == "grandTotal") {
1990
+ if (field.dataType == "string" ||
1991
+ field.dataType == "nvarchar" ||
1992
+ field.dataType == "date" ||
1993
+ field.dataType == "datetime") {
1994
+ args.value = "";
1995
+ }
1996
+ else {
1997
+ if (this.allDataValue &&
1998
+ this.allDataValue.length) {
1999
+ let rowObjs = this.allDataValue[args.row.rowIndex];
2000
+ if (rowObjs) {
2001
+ let rowObjsArr = JSON.parse(JSON.stringify(rowObjs));
2002
+ let obj = rowObjsArr.filter((el) => el.actualText == fieldName &&
2003
+ el.isGrandSum)[0];
2004
+ if (obj)
2005
+ args.value = obj.value;
2006
+ }
2007
+ }
2008
+ else {
2009
+ args.value = isNaN(Number(this.grandTotals["row" +
2010
+ args.row.actualText +
2011
+ fieldName]))
2012
+ ? null
2013
+ : Number(this.grandTotals["row" +
2014
+ args.row.actualText +
2015
+ fieldName]);
2016
+ }
2017
+ }
2018
+ }
2019
+ else {
2020
+ args.value = args.cellSets[firstIndex][fieldName];
2021
+ }
2022
+ if (field.dataType == "number" ||
2023
+ field.dataType == "multiple" ||
2024
+ field.dataType == "percent" ||
2025
+ field.dataType == "percentNum") {
2026
+ if (args.value != null)
2027
+ break;
2028
+ }
2029
+ else if (field.dataType == "date" ||
2030
+ field.dataType == "datetime") {
2031
+ if (this.pbf.time(args.value) > "1900-01-01")
2032
+ break;
2033
+ }
2034
+ else if (args.value)
2035
+ break;
2036
+ }
2037
+ }
2038
+ if (aggregateType === "Last") {
2039
+ for (let lastIndex = args.cellSets.length - 1; lastIndex >= 0; lastIndex--) {
2040
+ if (this.pivotObj.dataSourceSettings.columns.length ==
2041
+ 1 &&
2042
+ args.columnCellType == "grandTotal") {
2043
+ if (field.dataType == "string" ||
2044
+ field.dataType == "nvarchar" ||
2045
+ field.dataType == "date" ||
2046
+ field.dataType == "datetime") {
2047
+ args.value = "";
2048
+ }
2049
+ else {
2050
+ if (this.allDataValue &&
2051
+ this.allDataValue.length) {
2052
+ let rowObjs = this.allDataValue[args.row.rowIndex];
2053
+ if (rowObjs) {
2054
+ let rowObjsArr = JSON.parse(JSON.stringify(rowObjs));
2055
+ let obj = rowObjsArr.filter((el) => el.actualText == fieldName &&
2056
+ el.isGrandSum)[0];
2057
+ if (obj)
2058
+ args.value = obj.value;
2059
+ }
2060
+ }
2061
+ else {
2062
+ args.value = isNaN(Number(this.grandTotals["row" +
2063
+ args.row.actualText +
2064
+ fieldName]))
2065
+ ? null
2066
+ : Number(this.grandTotals["row" +
2067
+ args.row.actualText +
2068
+ fieldName]);
2069
+ }
2070
+ }
2071
+ }
2072
+ else {
2073
+ args.value = args.cellSets[lastIndex][fieldName];
2074
+ }
2075
+ if (field.dataType == "number" ||
2076
+ field.dataType == "multiple" ||
2077
+ field.dataType == "percent" ||
2078
+ field.dataType == "percentNum") {
2079
+ if (args.value != null)
2080
+ break;
2081
+ }
2082
+ else if (field.dataType == "date" ||
2083
+ field.dataType == "datetime") {
2084
+ if (this.pbf.time(args.value) > "1900-01-01")
2085
+ break;
2086
+ }
2087
+ else if (args.value)
2088
+ break;
2089
+ }
2090
+ }
2091
+ if (field.dataType == "number" ||
2092
+ field.dataType == "multiple" ||
2093
+ field.dataType == "percent" ||
2094
+ field.dataType == "percentNum") {
2095
+ if (this.pivotObj.dataSourceSettings.rows.length) {
2096
+ if (!this.pivotObj.dataSourceSettings.columns.length) {
2097
+ if (!Number(this.grandTotals[fieldName]) ||
2098
+ isNaN(Number(this.grandTotals[fieldName]))) {
2099
+ this.grandTotals[fieldName] = 0;
2100
+ }
2101
+ if (args.aggregateType !== "CalculatedField") {
2102
+ this.grandTotals[fieldName] += Number(args.value);
2103
+ }
2104
+ }
2105
+ else if (this.pivotObj.dataSourceSettings.columns.length == 1) {
2106
+ // "row" + args.row.actualText + fieldName 表示(cell: args.rowCellType === "value" && args.columnCellType === "grandTotal")
2107
+ if (!Number(this.grandTotals["row" + args.row.actualText + fieldName]) ||
2108
+ isNaN(Number(this.grandTotals["row" +
2109
+ args.row.actualText +
2110
+ fieldName]))) {
2111
+ this.grandTotals["row" + args.row.actualText + fieldName] = 0;
2112
+ }
2113
+ this.grandTotals["row" + args.row.actualText + fieldName] += Number(args.value);
2114
+ // "col" + args.column.actualText + fieldName 表示(cell: args.rowCellType === "grandTotal" && args.columnCellType === "value")
2115
+ if (!Number(this.grandTotals["col" +
2116
+ args.column.actualText +
2117
+ fieldName]) ||
2118
+ isNaN(Number(this.grandTotals["col" +
2119
+ args.column.actualText +
2120
+ fieldName]))) {
2121
+ this.grandTotals["col" + args.column.actualText + fieldName] = 0;
2122
+ }
2123
+ this.grandTotals["col" + args.column.actualText + fieldName] += Number(args.value);
2124
+ }
2125
+ }
2126
+ }
2127
+ }
2128
+ }
2129
+ else if (args.rowCellType === "subTotal" || args.row.hasChild) {
2130
+ const dataType = field.dataType;
2131
+ if (dataType === "string" ||
2132
+ dataType === "nvarchar" ||
2133
+ dataType == "date" ||
2134
+ dataType == "datetime") {
2135
+ args.value = "";
2136
+ }
2137
+ else {
2138
+ let value = 0;
2139
+ let childHeaders = [];
2140
+ if (aggregateType === "First") {
2141
+ let groupNameArrays = [];
2142
+ let rows = this.pivotObj.dataSourceSettings.rows;
2143
+ for (let index = args.row.level; index < rows.length; index++) {
2144
+ groupNameArrays.push(rows[index].name);
2145
+ }
2146
+ for (let i = 0; i < args.cellSets.length; i++) {
2147
+ let values = [];
2148
+ let header = groupNameArrays
2149
+ .map((name) => {
2150
+ values.push(args.cellSets[i][name]);
2151
+ return args.cellSets[i][name];
2152
+ })
2153
+ .join("-");
2154
+ if (!childHeaders.includes(header)) {
2155
+ let filterObj = {};
2156
+ groupNameArrays.map((name, x) => (filterObj[name] = values[x]));
2157
+ let _CellSets = _filter(args.cellSets, filterObj);
2158
+ childHeaders.push(header);
2159
+ value += Number(_CellSets[0][fieldName]) || 0;
2160
+ }
2161
+ }
2162
+ }
2163
+ if (aggregateType === "Last") {
2164
+ let groupNameArrays = [];
2165
+ let rows = this.pivotObj.dataSourceSettings.rows;
2166
+ for (let index = args.row.level; index < rows.length; index++) {
2167
+ groupNameArrays.push(rows[index].name);
2168
+ }
2169
+ for (let i = args.cellSets.length - 1; i >= 0; i--) {
2170
+ let values = [];
2171
+ let header = groupNameArrays
2172
+ .map((name) => {
2173
+ values.push(args.cellSets[i][name]);
2174
+ return args.cellSets[i][name];
2175
+ })
2176
+ .join("-");
2177
+ if (!childHeaders.includes(header)) {
2178
+ let filterObj = {};
2179
+ groupNameArrays.map((name, x) => (filterObj[name] = values[x]));
2180
+ let _CellSets = _filter(args.cellSets, filterObj);
2181
+ childHeaders.push(header);
2182
+ value +=
2183
+ Number(_CellSets[_CellSets.length - 1][fieldName]) || 0;
2184
+ }
2185
+ }
2186
+ }
2187
+ if (args.column.actualText !== "Grand Total")
2188
+ this.columnTexts.push(args.column.actualText);
2189
+ if (!this.pivotObj.dataSourceSettings.columns.length) {
2190
+ if (!Number(this.subTotals[fieldName]) ||
2191
+ isNaN(Number(this.subTotals[fieldName]))) {
2192
+ this.subTotals[fieldName] = 0;
2193
+ }
2194
+ this.subTotals[fieldName] += Number(value);
2195
+ }
2196
+ else if (this.pivotObj.dataSourceSettings.columns.length == 1) {
2197
+ if (!Number(this.subTotals[args.row.actualText +
2198
+ args.column.actualText +
2199
+ fieldName]) ||
2200
+ isNaN(Number(this.subTotals[args.row.actualText +
2201
+ args.column.actualText +
2202
+ fieldName]))) {
2203
+ this.subTotals[args.row.actualText +
2204
+ args.column.actualText +
2205
+ fieldName] = 0;
2206
+ }
2207
+ this.subTotals[args.row.actualText + args.column.actualText + fieldName] += Number(value);
2208
+ }
2209
+ // ---> allDataValue中这个单元格的值不正确
2210
+ if (args.columnCellType === "grandTotal" &&
2211
+ this.pivotObj.dataSourceSettings.columns.length == 1) {
2212
+ if (this.allDataValue && this.allDataValue.length) {
2213
+ args.value =
2214
+ this.subTotals[args.row.actualText + "Grand Total" + fieldName];
2215
+ }
2216
+ else {
2217
+ this.columnTexts = uniqBy(this.columnTexts, (el) => el);
2218
+ let val = 0;
2219
+ for (let i = 0; i < this.columnTexts.length; i++) {
2220
+ const element = this.columnTexts[i];
2221
+ val +=
2222
+ this.subTotals[args.row.actualText + element + fieldName];
2223
+ }
2224
+ args.value = val;
2225
+ }
2226
+ }
2227
+ else {
2228
+ args.value = value;
2229
+ }
2230
+ }
2231
+ }
2232
+ else if (args.rowCellType === "grandTotal") {
2233
+ const dataType = field.dataType;
2234
+ if (dataType == "string" ||
2235
+ dataType == "nvarchar" ||
2236
+ dataType == "date" ||
2237
+ dataType == "datetime") {
2238
+ args.value = "";
2239
+ }
2240
+ else {
2241
+ if (!this.pivotObj.dataSourceSettings.columns.length) {
2242
+ if (this.allDataValue && this.allDataValue.length) {
2243
+ let rowObjs = this.allDataValue[this.allDataValue.length - 1];
2244
+ if (rowObjs) {
2245
+ let rowObjsArr = JSON.parse(JSON.stringify(rowObjs));
2246
+ let objArr = rowObjsArr.filter((el) => el.actualText == fieldName && el.isGrandSum);
2247
+ if (objArr && objArr.length) {
2248
+ args.value = objArr[objArr.length - 1].value;
2249
+ }
2250
+ else if (Object.keys(this.grandTotals).includes(fieldName)) {
2251
+ args.value = this.grandTotals[fieldName];
2252
+ }
2253
+ }
2254
+ }
2255
+ else {
2256
+ args.value = this.grandTotals[fieldName];
2257
+ }
2258
+ }
2259
+ else {
2260
+ if (args.columnCellType === "grandTotal") {
2261
+ if (this.allDataValue && this.allDataValue.length) {
2262
+ let rowObjs = this.allDataValue[this.allDataValue.length - 1];
2263
+ if (rowObjs) {
2264
+ let rowObjsArr = JSON.parse(JSON.stringify(rowObjs));
2265
+ let objArr = rowObjsArr.filter((el) => el.actualText == fieldName &&
2266
+ el.isGrandSum);
2267
+ if (objArr && objArr.length) {
2268
+ args.value =
2269
+ objArr[objArr.length - 1].value;
2270
+ }
2271
+ else if (Object.keys(this.grandTotals).includes("col" +
2272
+ args.column.actualText +
2273
+ fieldName)) {
2274
+ args.value =
2275
+ this.grandTotals["col" +
2276
+ args.column.actualText +
2277
+ fieldName];
2278
+ }
2279
+ }
2280
+ }
2281
+ else {
2282
+ args.value =
2283
+ this.grandTotals["col" + args.column.actualText + fieldName];
2284
+ }
2285
+ }
2286
+ else {
2287
+ if (this.allDataValue && this.allDataValue.length) {
2288
+ let rowObjs = this.allDataValue[this.allDataValue.length - 1];
2289
+ let rowObjsArr = JSON.parse(JSON.stringify(rowObjs));
2290
+ let objArr = rowObjsArr.filter((el) => el.actualText == fieldName &&
2291
+ el.isGrandSum &&
2292
+ el.columnHeaders == args.column.actualText);
2293
+ if (objArr && objArr.length) {
2294
+ args.value = objArr[objArr.length - 1].value;
2295
+ }
2296
+ else if (Object.keys(this.grandTotals).includes("col" + args.column.actualText + fieldName)) {
2297
+ args.value =
2298
+ this.grandTotals["col" +
2299
+ args.column.actualText +
2300
+ fieldName];
2301
+ }
2302
+ }
2303
+ else {
2304
+ args.value =
2305
+ this.grandTotals["col" + args.column.actualText + fieldName];
2306
+ }
2307
+ }
2308
+ }
2309
+ }
2310
+ }
2311
+ this.formatVal(args, fieldName);
2312
+ return args.value;
2313
+ }
2314
+ formatVal(args, fieldName) {
2315
+ this.configFields.forEach((field) => {
2316
+ if (field.colName == fieldName) {
2317
+ switch (field.dataType) {
2318
+ case "date":
2319
+ case "datetime":
2320
+ if (args.value)
2321
+ args.value = new Date(args.value);
2322
+ break;
2323
+ default:
2324
+ break;
2325
+ }
2326
+ }
2327
+ });
2328
+ }
2329
+ getexcludeFields(fields, data) {
2330
+ let namearray = [];
2331
+ let array = [];
2332
+ for (let prop in data) {
2333
+ array.push(prop);
2334
+ }
2335
+ for (let item of fields) {
2336
+ namearray.push(item.colName);
2337
+ }
2338
+ this.excludeFields = differenceWith(array, namearray);
2339
+ if (this.excludeFields.length &&
2340
+ this.config.groupSettings &&
2341
+ this.config.groupSettings.length) {
2342
+ for (let i = 0; i < this.excludeFields.length; i++) {
2343
+ const el = this.excludeFields[i];
2344
+ if (startsWith(el, this.config.groupSettings[0].name + "_")) {
2345
+ this.excludeFields.splice(i, 1);
2346
+ i--;
2347
+ }
2348
+ }
2349
+ }
2350
+ }
2351
+ getInfo() {
2352
+ this.datePipeFormat = localStorage.getItem("datePipe");
2353
+ this.translation = JSON.parse(localStorage.getItem("translation"));
2354
+ }
2355
+ onFieldDrop(args) {
2356
+ this.dataSourceSettings.values = [...args.dataSourceSettings.values];
2357
+ //change the calcualteField method use the corresponding calculate
2358
+ const calcualteField = this.configFields.filter((el) => el.colName === args.fieldName && el.isCalculatedField);
2359
+ if (calcualteField.length > 0) {
2360
+ args.dropField.type =
2361
+ this.dashboardPorletsService.getCalculateMethod(calcualteField[0].colName);
2362
+ args.dropField.caption = args.dropField.caption
2363
+ .replace("Calculate", "")
2364
+ .trim();
2365
+ }
2366
+ for (let i = 0; i < args.dataSourceSettings.filterSettings.length; i++) {
2367
+ if (args.dataSourceSettings.filterSettings[i].name ===
2368
+ args.fieldName &&
2369
+ args.dropAxis === "") {
2370
+ args.dataSourceSettings.filterSettings.splice(i, 1);
2371
+ this.filterSettings = args.dataSourceSettings.filterSettings;
2372
+ break;
2373
+ }
2374
+ }
2375
+ }
2376
+ // Calculated field事件:创建
2377
+ calculatedFieldCreate(args) {
2378
+ if (args.calculatedField.name !== "" &&
2379
+ args.calculatedField.name.trim() !== "") {
2380
+ let index = this.fieldlistObj.dataSourceSettings.calculatedFieldSettings.findIndex((el) => el.name === args.calculatedField.name);
2381
+ if (index !== -1) {
2382
+ if (args.calculatedField.formatString === "") {
2383
+ this.fieldlistObj.dataSourceSettings.calculatedFieldSettings[index].formatString = "N2";
2384
+ }
2385
+ else {
2386
+ this.fieldlistObj.dataSourceSettings.calculatedFieldSettings[index].formatString = args.calculatedField.formatString;
2387
+ }
2388
+ }
2389
+ else {
2390
+ if (args.calculatedField.formatString === "") {
2391
+ args.calculatedField.formatString = "N2";
2392
+ }
2393
+ }
2394
+ // 移除重复
2395
+ let fIndex = this.customCalculatedFields.findIndex((f) => f.name === args.calculatedField.name);
2396
+ if (fIndex > -1) {
2397
+ this.customCalculatedFields.splice(fIndex, 1);
2398
+ }
2399
+ // 匹配运算符 First || Last
2400
+ let formulaStr = args.calculatedField.formula;
2401
+ let reg1 = /"First\((.+?)\)"/g;
2402
+ let reg2 = /"Last\((.+?)\)"/g;
2403
+ if (reg1.test(formulaStr) || reg2.test(formulaStr)) {
2404
+ // 判断是否存在First || Last 表达式
2405
+ let matchFirstFields = Array.from(formulaStr["matchAll"](/"First\((.+?)\)"/g), (m) => {
2406
+ return {
2407
+ matchStr: m[0],
2408
+ matchWord: m[1],
2409
+ replaceValue: "",
2410
+ matchMethod: "First",
2411
+ };
2412
+ });
2413
+ let matchLastFields = Array.from(formulaStr["matchAll"](/"Last\((.+?)\)"/g), (m) => {
2414
+ return {
2415
+ matchStr: m[0],
2416
+ matchWord: m[1],
2417
+ replaceValue: "",
2418
+ matchMethod: "Last",
2419
+ };
2420
+ });
2421
+ let matchMaxFields = Array.from(formulaStr["matchAll"](/"Max\((.+?)\)"/g), (m) => {
2422
+ return {
2423
+ matchStr: m[0],
2424
+ matchWord: m[1],
2425
+ replaceValue: "",
2426
+ matchMethod: "Max",
2427
+ };
2428
+ });
2429
+ let matchMinFields = Array.from(formulaStr["matchAll"](/"Min\((.+?)\)"/g), (m) => {
2430
+ return {
2431
+ matchStr: m[0],
2432
+ matchWord: m[1],
2433
+ replaceValue: "",
2434
+ matchMethod: "Min",
2435
+ };
2436
+ });
2437
+ let matchSumFields = Array.from(formulaStr["matchAll"](/"Sum\((.+?)\)"/g), (m) => {
2438
+ return {
2439
+ matchStr: m[0],
2440
+ matchWord: m[1],
2441
+ replaceValue: "",
2442
+ matchMethod: "Sum",
2443
+ };
2444
+ });
2445
+ let matchAvgFields = Array.from(formulaStr["matchAll"](/"Avg\((.+?)\)"/g), (m) => {
2446
+ return {
2447
+ matchStr: m[0],
2448
+ matchWord: m[1],
2449
+ replaceValue: "",
2450
+ matchMethod: "Avg",
2451
+ };
2452
+ });
2453
+ if (matchFirstFields.every((x) => this.allowedCalculatedFields.includes(x.matchWord)) &&
2454
+ matchLastFields.every((x) => this.allowedCalculatedFields.includes(x.matchWord))) {
2455
+ // 判断First和Last表达式内的字段是否合法
2456
+ this.customCalculatedFields.push({
2457
+ name: args.calculatedField.name,
2458
+ formula: args.calculatedField.formula,
2459
+ matchFields: [
2460
+ // @ts-ignore
2461
+ ...matchFirstFields,
2462
+ ...matchLastFields,
2463
+ ...matchMaxFields,
2464
+ ...matchMinFields,
2465
+ ...matchSumFields,
2466
+ ...matchAvgFields,
2467
+ ],
2468
+ grandTotal: 0,
2469
+ });
2470
+ let fieldName = (formulaStr.split("First(")[1] ||
2471
+ formulaStr.split("Last(")[1]).split(")")[0];
2472
+ args.calculatedField.formula =
2473
+ "'\"" + "Sum(" + fieldName + ')"=' + formulaStr + "'";
2474
+ }
2475
+ }
2476
+ }
2477
+ }
2478
+ // Calculated field事件:完成
2479
+ actionComplete(args) {
2480
+ if (args.actionName === "Field aggregated" ||
2481
+ args.actionName === "Field list closed") {
2482
+ this.dataSourceSettings.values = [
2483
+ ...args.dataSourceSettings.values,
2484
+ ];
2485
+ this.setValueItemData();
2486
+ }
2487
+ if (args.actionName == "Field removed") {
2488
+ if (args.fieldInfo &&
2489
+ args.fieldInfo.fieldItem &&
2490
+ args.fieldInfo.fieldItem.type == "CalculatedField") {
2491
+ let field = args.fieldInfo.fieldName;
2492
+ // Remove the deleted calculated field from an stored array.
2493
+ this.customCalculatedFields =
2494
+ this.customCalculatedFields.filter(function (obj) {
2495
+ return obj.name !== field;
2496
+ });
2497
+ }
2498
+ }
2499
+ }
2500
+ // Calculated field事件:开始
2501
+ actionBegin(args) {
2502
+ if (args.actionName === "Edit calculated field") {
2503
+ for (let i = 0; i < this.customCalculatedFields.length; i++) {
2504
+ if (this.customCalculatedFields[i].name &&
2505
+ this.pivotObj.engineModule.fieldList[this.customCalculatedFields[i].name]) {
2506
+ this.pivotObj.engineModule.fieldList[this.customCalculatedFields[i].name].formula = this.customCalculatedFields[i].formula;
2507
+ }
2508
+ }
2509
+ }
2510
+ }
2511
+ resizeStop(args) {
2512
+ if (this.config.columnsWidth) {
2513
+ const header_field = this.config.columnsWidth.filter((el) => el.headerText === args.column.headerText);
2514
+ if (header_field.length > 0) {
2515
+ header_field[0].width = parseInt(args.column.width);
2516
+ }
2517
+ else {
2518
+ this.config.columnsWidth.push({
2519
+ headerText: args.column.headerText,
2520
+ width: parseInt(args.column.width),
2521
+ });
2522
+ }
2523
+ }
2524
+ else {
2525
+ this.config.columnsWidth = [];
2526
+ this.config.columnsWidth.push({
2527
+ headerText: args.column.headerText,
2528
+ width: parseInt(args.column.width),
2529
+ });
2530
+ }
2531
+ const portlet = this.portlet;
2532
+ portlet.config = JSON.stringify(this.config);
2533
+ const index = this.portlets.findIndex((x) => x.newId === portlet.newId);
2534
+ if (index > -1)
2535
+ this.portlets[index] = portlet;
2536
+ }
2537
+ setColumnsRender(args) {
2538
+ if (args.stackedColumns) {
2539
+ args.stackedColumns.forEach((col) => {
2540
+ if (col.format &&
2541
+ (col.format.indexOf("N") !== -1 ||
2542
+ col.format === "percent" ||
2543
+ col.format.indexOf("P") !== -1)) {
2544
+ col.textAlign = "Right";
2545
+ }
2546
+ });
2547
+ }
2548
+ if (this.config.columnsWidth) {
2549
+ for (let i = 0; i < args.columns.length; i++) {
2550
+ if (args.columns[i].headerText === "" ||
2551
+ !args.columns[i].headerText) {
2552
+ const column_row = this.config.columnsWidth.filter((el) => el.headerText === args.columns[i].headerText);
2553
+ if (column_row.length > 0) {
2554
+ args.columns[i].width = column_row[0].width;
2555
+ }
2556
+ }
2557
+ else {
2558
+ const headerText = args.columns[i].headerText
2559
+ .replace(/\s+/g, "")
2560
+ .split(".");
2561
+ if (headerText && headerText.length > 0) {
2562
+ const column = this.config.columnsWidth.filter((el) => el.headerText
2563
+ .replace(/\s+/g, "")
2564
+ .toLowerCase() ===
2565
+ headerText[headerText.length - 1].toLowerCase());
2566
+ if (column.length > 0) {
2567
+ args.columns[i].width = column[0].width;
2568
+ }
2569
+ }
2570
+ }
2571
+ // date format about quarterly
2572
+ let pivotValues = this.pivotObj.pivotValues;
2573
+ if (this.formatDates && this.formatDates.length) {
2574
+ let dateFields = this.formatDates.map((el) => {
2575
+ return el.name;
2576
+ });
2577
+ for (let k = 1; k < pivotValues.length; k++) {
2578
+ for (let j = 0; pivotValues[k] != null && j < pivotValues[k].length; j++) {
2579
+ if (pivotValues[k][j] != null &&
2580
+ (j == 0
2581
+ ? dateFields.includes(pivotValues[k][j].valueSort.axis)
2582
+ : dateFields.includes(pivotValues[k][j].actualText))) {
2583
+ //Customize the Row headers/Column headers based on your needs
2584
+ let headers;
2585
+ if (j === 0) {
2586
+ headers = pivotValues[k][j].actualText;
2587
+ }
2588
+ else {
2589
+ // headers = pivotValues[k][j].formattedText;
2590
+ headers = pivotValues[k][j].value;
2591
+ }
2592
+ if (headers) {
2593
+ let date = new Date(headers);
2594
+ let quarter = Math.floor(date.getMonth() / 3) + 1;
2595
+ let format;
2596
+ this.formatDates.map((el) => {
2597
+ if (j == 0) {
2598
+ if (el.name ==
2599
+ pivotValues[k][j].valueSort.axis)
2600
+ format = el.format;
2601
+ }
2602
+ else {
2603
+ if (el.name ==
2604
+ pivotValues[k][j].actualText)
2605
+ format = el.format;
2606
+ }
2607
+ });
2608
+ pivotValues[k][j].formattedText =
2609
+ this.getQuarterValue(format, date, quarter);
2610
+ }
2611
+ }
2612
+ }
2613
+ }
2614
+ }
2615
+ }
2616
+ // if(this.pivotObj) this.pivotObj.refreshData();
2617
+ }
2618
+ }
2619
+ onLoad() {
2620
+ // SMP2-15651 开启虚拟滚动并sort列后,来回滚动会导致数据空白
2621
+ // 官方链接 https://ej2.syncfusion.com/angular/documentation/pivotview/virtual-scrolling#virtual-scrolling-for-static-field-list
2622
+ // Demo链接 https://stackblitz.com/edit/github-7ggk2u-4rkzb3?file=src%2Fapp.component.ts
2623
+ this.fieldlistObj.pivotGridModule = this
2624
+ .pivotObj;
2625
+ }
2626
+ ondataBound() {
2627
+ if (Browser.isDevice) {
2628
+ this.pivotObj.element.style.width = '100%';
2629
+ this.pivotObj.allowCalculatedField = true;
2630
+ this.pivotObj.showFieldList = true;
2631
+ }
2632
+ }
2633
+ enginePopulated(args) {
2634
+ let clonedValues;
2635
+ let currentPivotValues = this.getClonedPivotValues(this.pivotObj.engineModule.pivotValues);
2636
+ let pageSettings = this.pivotObj.engineModule.pageSettings;
2637
+ if (this.pivotObj.engineModule.generateGridData) {
2638
+ // 没法复现 https://raiselp.atlassian.net/browse/SMP2-1724 处理的这个问题情况, 直接注释掉
2639
+ // 下面这段代码会影响 https://raiselp.atlassian.net/browse/SMP2-12139
2640
+ // this.pivotObj.engineModule.generateGridData(
2641
+ // this.pivotObj.dataSourceSettings,
2642
+ // true
2643
+ // );
2644
+ clonedValues = this.getClonedPivotValues(this.pivotObj.engineModule.pivotValues);
2645
+ this.pivotObj.engineModule.pivotValues = currentPivotValues;
2646
+ this.pivotObj.engineModule.pageSettings = pageSettings;
2647
+ // Here "clonedValues" contains the whole pivot values.
2648
+ this.allDataValue = clonedValues;
2649
+ }
2650
+ }
2651
+ getClonedPivotValues(pivotValues) {
2652
+ let clonedSets = [];
2653
+ if (pivotValues && pivotValues.length) {
2654
+ for (let i = 0; i < pivotValues.length; i++) {
2655
+ if (pivotValues[i]) {
2656
+ clonedSets[i] = [];
2657
+ for (let j = 0; j < pivotValues[i].length; j++) {
2658
+ if (pivotValues[i][j]) {
2659
+ /* eslint-disable */
2660
+ clonedSets[i][j] = this.getClonedPivotValueObj(pivotValues[i][j]);
2661
+ /* eslint-enable */
2662
+ }
2663
+ }
2664
+ }
2665
+ }
2666
+ }
2667
+ return clonedSets;
2668
+ }
2669
+ getClonedPivotValueObj(data) {
2670
+ let keyPos = 0;
2671
+ let framedSet = {};
2672
+ if (!(data === null || data === undefined)) {
2673
+ let fields = Object.keys(data);
2674
+ while (keyPos < fields.length) {
2675
+ framedSet[fields[keyPos]] = data[fields[keyPos]];
2676
+ keyPos++;
2677
+ }
2678
+ }
2679
+ else {
2680
+ framedSet = data;
2681
+ }
2682
+ return framedSet;
2683
+ }
2684
+ //#region Filtering the TreeNodes
2685
+ searchNodes(args) {
2686
+ let _text = args.maskedValue;
2687
+ let predicats = [], _array = [], _filter = [];
2688
+ if (_text == "") {
2689
+ this.changeDataSource(this.fieldlistObj.treeViewModule.getTreeData());
2690
+ }
2691
+ else {
2692
+ let predicate = new Predicate("caption", "contains", _text, true);
2693
+ let filteredList = new DataManager(this.fieldlistObj.treeViewModule.getTreeData()).executeLocal(new Query().where(predicate));
2694
+ for (let j = 0; j < filteredList.length; j++) {
2695
+ _filter.push(filteredList[j]["id"]);
2696
+ let filters = this.getFilterItems(filteredList[j], this.fieldlistObj.treeViewModule.getTreeData());
2697
+ for (let i = 0; i < filters.length; i++) {
2698
+ if (_array.indexOf(filters[i]) == -1 &&
2699
+ filters[i] != null) {
2700
+ _array.push(filters[i]);
2701
+ predicats.push(new Predicate("id", "equal", filters[i], false));
2702
+ }
2703
+ }
2704
+ }
2705
+ if (predicats.length == 0) {
2706
+ this.changeDataSource([]);
2707
+ }
2708
+ else {
2709
+ let query = new Query().where(Predicate.or(predicats));
2710
+ let newList = new DataManager(this.fieldlistObj.treeViewModule.getTreeData()).executeLocal(query);
2711
+ this.changeDataSource(newList);
2712
+ }
2713
+ }
2714
+ }
2715
+ //Find the Parent Nodes for corresponding childs
2716
+ getFilterItems(fList, list) {
2717
+ let nodes = [];
2718
+ nodes.push(fList["id"]);
2719
+ let query2 = new Query().where("id", "equal", fList["pid"], false);
2720
+ let fList1 = new DataManager(list).executeLocal(query2);
2721
+ if (fList1.length != 0) {
2722
+ let pNode = this.getFilterItems(fList1[0], list);
2723
+ for (let i = 0; i < pNode.length; i++) {
2724
+ if (nodes.indexOf(pNode[i]) == -1 && pNode[i] != null)
2725
+ nodes.push(pNode[i]);
2726
+ }
2727
+ return nodes;
2728
+ }
2729
+ return nodes;
2730
+ }
2731
+ created(args) {
2732
+ if (this.fieldlistObj && !this.fieldlistObj.engineModule.fields) {
2733
+ this.fieldlistObj.engineModule.fields = [];
2734
+ }
2735
+ let search = document.createElement("input");
2736
+ search.id = "pivotSearchBox" + this.fieldlistObj.element.id;
2737
+ let el = document.querySelector("#" + this.fieldlistObj.element.id + "_Container .e-field-table");
2738
+ if (el)
2739
+ el.prepend(search);
2740
+ this.pivotSearchBox = new MaskedTextBox({
2741
+ placeholder: this.translation.SEARCH || ".SEARCH",
2742
+ cssClass: "pivot-search",
2743
+ change: this.searchNodes.bind(this),
2744
+ });
2745
+ this.pivotSearchBox.appendTo("#pivotSearchBox" + this.fieldlistObj.element.id);
2746
+ // NEW Dashboard 点击"apply"时,请求新数据
2747
+ let applyBtn = document.getElementById(this.fieldlistObj.element.id + "_DeferUpdateButton1");
2748
+ applyBtn &&
2749
+ applyBtn.addEventListener("click", () => {
2750
+ this.pageLoading = true;
2751
+ this.dashboardPorletsService.getDataByPortletsNew([this.portlet], () => {
2752
+ this.pageLoading = false;
2753
+ this.Pivot_Data =
2754
+ this.dashboardPorletsService.getResultByDataTable(this.portlet, false, false, this.dashboard.id);
2755
+ this.pivotObj.dataSourceSettings.dataSource =
2756
+ this.Pivot_Data;
2757
+ if (this.Pivot_Data) {
2758
+ let groups = this.config.xaxis.groups;
2759
+ let rows = [];
2760
+ if (groups) {
2761
+ for (let gitem of groups) {
2762
+ const field = this.configFields.filter((el) => el.colName === gitem.name);
2763
+ if (field.length > 0) {
2764
+ gitem.showSubTotals =
2765
+ field[0].showSubTotals;
2766
+ gitem.caption =
2767
+ field[0].langValue ||
2768
+ this.translation[field[0].langCode] ||
2769
+ field[0].langCode ||
2770
+ gitem.caption;
2771
+ }
2772
+ rows.push(gitem);
2773
+ }
2774
+ }
2775
+ this.Pivot_Data.map((data) => {
2776
+ rows.forEach((row) => {
2777
+ if (data[row.name] === "") {
2778
+ data[row.name] = "null";
2779
+ }
2780
+ });
2781
+ });
2782
+ }
2783
+ if (this.pivotObj)
2784
+ this.pivotObj.refreshData();
2785
+ this.ref.markForCheck();
2786
+ this.ref.detectChanges();
2787
+ }, null, false, this.dashboard, false);
2788
+ });
2789
+ // 点击"cancel"时,恢复原始数据
2790
+ let cancelBtn = document.getElementById(this.fieldlistObj.element.id + "_DeferUpdateButton2");
2791
+ cancelBtn &&
2792
+ cancelBtn.addEventListener("click", () => {
2793
+ this.pivotObj.dataSourceSettings.dataSource =
2794
+ [...this.Pivot_Data];
2795
+ if (this.pivotObj)
2796
+ this.pivotObj.refreshData();
2797
+ this.ref.markForCheck();
2798
+ this.ref.detectChanges();
2799
+ });
2800
+ }
2801
+ fieldListRefreshed(args) {
2802
+ if (this.pivotSearchBox) {
2803
+ this.pivotSearchBox.value = "";
2804
+ this.changeDataSource(this.fieldlistObj.treeViewModule.getTreeData());
2805
+ }
2806
+ }
2807
+ changeDataSource(data) {
2808
+ let fieldTable = this.fieldlistObj.treeViewModule.fieldTable;
2809
+ if (fieldTable) {
2810
+ fieldTable.fields = {
2811
+ dataSource: data,
2812
+ id: "id",
2813
+ text: "caption",
2814
+ isChecked: "isSelected",
2815
+ parentID: "pid",
2816
+ iconCss: "spriteCssClass",
2817
+ };
2818
+ }
2819
+ }
2820
+ //SMP2-2957 fix the date issue on the raw data
2821
+ drillThrough(args) {
2822
+ for (let i = 0; i < args.gridColumns.length; i++) {
2823
+ const data = this.configFields.filter((el) => el.colName === args.gridColumns[i].field);
2824
+ if (data && data.length > 0) {
2825
+ if (data[0].dataType === "date" ||
2826
+ data[0].dataType === "datetime") {
2827
+ args.gridColumns[i].type = "date";
2828
+ }
2829
+ }
2830
+ }
2831
+ }
2832
+ //#endregion
2833
+ setFontSettingConditional(obj, data, code) {
2834
+ if (code === -1) {
2835
+ obj.style.color = data.negaFontColor;
2836
+ obj.style.fontFamily = data.negaFontFamilyValue;
2837
+ obj.style.fontSize = data.negaFontSizeValue;
2838
+ obj.style.backgroundColor = data.negaBackgroundColor;
2839
+ }
2840
+ else {
2841
+ obj.style.color = data.fontColor;
2842
+ obj.style.fontFamily = data.fontFamilyValue;
2843
+ obj.style.fontSize = data.fontSizeValue;
2844
+ obj.style.backgroundColor = data.backgroundColor;
2845
+ }
2846
+ }
2847
+ setCompareConditional(negaConditionalFormatObj, conditionalFormatObj, data) {
2848
+ if (Math.sign(data.compareValue1) == 0) {
2849
+ switch (data.compareSelect) {
2850
+ case "LessThan": // 小于
2851
+ case "LessThanOrEqualTo": // 小于等于
2852
+ negaConditionalFormatObj.value1 = 0;
2853
+ negaConditionalFormatObj.conditions = "LessThan";
2854
+ this.setFontSettingConditional(negaConditionalFormatObj, data, -1);
2855
+ break;
2856
+ case "GreaterThan": // 大于
2857
+ case "GreaterThanOrEqualTo": // 大于等于
2858
+ conditionalFormatObj.value1 = 0;
2859
+ conditionalFormatObj.conditions = "GreaterThan";
2860
+ this.setFontSettingConditional(conditionalFormatObj, data, 1);
2861
+ break;
2862
+ case "NotEquals": // 不等于
2863
+ negaConditionalFormatObj.value1 = 0;
2864
+ negaConditionalFormatObj.conditions = "LessThan";
2865
+ this.setFontSettingConditional(negaConditionalFormatObj, data, -1);
2866
+ conditionalFormatObj.value1 = 0;
2867
+ conditionalFormatObj.conditions = "GreaterThan";
2868
+ this.setFontSettingConditional(conditionalFormatObj, data, 1);
2869
+ break;
2870
+ case "Between": // value1<= val <=value2
2871
+ if (Math.sign(data.compareValue2) === 1) {
2872
+ conditionalFormatObj.value1 = 0;
2873
+ conditionalFormatObj.value2 = Number(data.compareValue2);
2874
+ conditionalFormatObj.conditions = "Between";
2875
+ this.setFontSettingConditional(conditionalFormatObj, data, 1);
2876
+ }
2877
+ break;
2878
+ case "NotBetween": // val >= value2, val <= value1
2879
+ if (Math.sign(data.compareValue2) === 1) {
2880
+ conditionalFormatObj.value1 = Number(data.compareValue2);
2881
+ conditionalFormatObj.conditions = "GreaterThan";
2882
+ this.setFontSettingConditional(conditionalFormatObj, data, 1);
2883
+ negaConditionalFormatObj.value1 = 0;
2884
+ negaConditionalFormatObj.conditions = "LessThan";
2885
+ this.setFontSettingConditional(negaConditionalFormatObj, data, -1);
2886
+ }
2887
+ break;
2888
+ default:
2889
+ break;
2890
+ }
2891
+ }
2892
+ else if (Math.sign(data.compareValue1) === 1) {
2893
+ switch (data.compareSelect) {
2894
+ case "LessThan": // 小于
2895
+ case "LessThanOrEqualTo": // 小于等于
2896
+ conditionalFormatObj.value1 = 0;
2897
+ conditionalFormatObj.value2 = Number(data.compareValue1);
2898
+ conditionalFormatObj.conditions = "Between";
2899
+ this.setFontSettingConditional(conditionalFormatObj, data, 1);
2900
+ negaConditionalFormatObj.value1 = 0;
2901
+ negaConditionalFormatObj.conditions = "LessThan";
2902
+ this.setFontSettingConditional(negaConditionalFormatObj, data, -1);
2903
+ break;
2904
+ case "GreaterThan": // 大于
2905
+ case "GreaterThanOrEqualTo": // 大于等于
2906
+ conditionalFormatObj.value1 = Number(data.compareValue1);
2907
+ conditionalFormatObj.conditions = "GreaterThan";
2908
+ this.setFontSettingConditional(conditionalFormatObj, data, 1);
2909
+ break;
2910
+ case "Equals": // 等于
2911
+ conditionalFormatObj.value1 = Number(data.compareValue1);
2912
+ conditionalFormatObj.conditions = "Equals";
2913
+ this.setFontSettingConditional(conditionalFormatObj, data, 1);
2914
+ break;
2915
+ case "NotEquals": // 不等于
2916
+ conditionalFormatObj.value1 = 0;
2917
+ conditionalFormatObj.value2 = Number(data.compareValue1);
2918
+ conditionalFormatObj.conditions = "Between";
2919
+ // push进数组
2920
+ conditionalFormatObj.value1 = Number(data.compareValue1);
2921
+ conditionalFormatObj.conditions = "GreaterThan";
2922
+ // push进数组
2923
+ negaConditionalFormatObj.value1 = 0;
2924
+ negaConditionalFormatObj.conditions = "LessThanOrEqualTo";
2925
+ this.setFontSettingConditional(negaConditionalFormatObj, data, -1);
2926
+ this.setFontSettingConditional(conditionalFormatObj, data, 1);
2927
+ break;
2928
+ case "Between": // value1<= val <=value2
2929
+ if (Math.sign(data.compareValue2) === 1) {
2930
+ conditionalFormatObj.value1 = Number(data.compareValue1);
2931
+ conditionalFormatObj.value2 = Number(data.compareValue2);
2932
+ conditionalFormatObj.conditions = "Between";
2933
+ this.setFontSettingConditional(conditionalFormatObj, data, 1);
2934
+ }
2935
+ break;
2936
+ case "NotBetween": // val >= value2, val <= value1
2937
+ if (Math.sign(data.compareValue2) === 1) {
2938
+ conditionalFormatObj.value1 = 0;
2939
+ conditionalFormatObj.value2 = Number(data.compareValue1);
2940
+ conditionalFormatObj.conditions = "Between";
2941
+ // push进数组
2942
+ conditionalFormatObj.value1 = Number(data.compareValue2);
2943
+ conditionalFormatObj.conditions = "GreaterThan";
2944
+ // push进数组
2945
+ this.setFontSettingConditional(conditionalFormatObj, data, 1);
2946
+ }
2947
+ break;
2948
+ default:
2949
+ break;
2950
+ }
2951
+ }
2952
+ else if (Math.sign(data.compareValue1) === -1) {
2953
+ switch (data.compareSelect) {
2954
+ case "LessThan": // 小于
2955
+ case "LessThanOrEqualTo": // 小于等于
2956
+ negaConditionalFormatObj.value1 = data.compareValue1;
2957
+ negaConditionalFormatObj.conditions = data.compareSelect;
2958
+ this.setFontSettingConditional(negaConditionalFormatObj, data, -1);
2959
+ break;
2960
+ case "GreaterThan": // 大于
2961
+ case "GreaterThanOrEqualTo": // 大于等于
2962
+ conditionalFormatObj.value1 = 0;
2963
+ conditionalFormatObj.conditions = "GreaterThanOrEqualTo";
2964
+ negaConditionalFormatObj.value1 = 0;
2965
+ negaConditionalFormatObj.value2 = data.compareValue1;
2966
+ negaConditionalFormatObj.conditions = "Between";
2967
+ this.setFontSettingConditional(conditionalFormatObj, data, 1);
2968
+ this.setFontSettingConditional(negaConditionalFormatObj, data, -1);
2969
+ break;
2970
+ case "Equals": // 等于
2971
+ negaConditionalFormatObj.value1 = data.compareValue1;
2972
+ negaConditionalFormatObj.conditions = "Equals";
2973
+ this.setFontSettingConditional(negaConditionalFormatObj, data, -1);
2974
+ case "NotEquals": // 不等于
2975
+ negaConditionalFormatObj.value1 = data.compareValue1;
2976
+ negaConditionalFormatObj.conditions = "NotEquals";
2977
+ this.setFontSettingConditional(negaConditionalFormatObj, data, -1);
2978
+ conditionalFormatObj.value1 = 0;
2979
+ conditionalFormatObj.conditions = "GreaterThan";
2980
+ this.setFontSettingConditional(conditionalFormatObj, data, 1);
2981
+ break;
2982
+ case "Between": // value1<= val <=value2
2983
+ if (Math.sign(data.compareValue2)) {
2984
+ negaConditionalFormatObj.value1 = 0;
2985
+ negaConditionalFormatObj.value2 = data.compareValue1;
2986
+ negaConditionalFormatObj.conditions = "Between";
2987
+ this.setFontSettingConditional(negaConditionalFormatObj, data, -1);
2988
+ conditionalFormatObj.value1 = 0;
2989
+ conditionalFormatObj.value2 = data.compareValue2;
2990
+ conditionalFormatObj.conditions = "Between";
2991
+ this.setFontSettingConditional(conditionalFormatObj, data, 1);
2992
+ }
2993
+ else {
2994
+ negaConditionalFormatObj.value1 = data.compareValue1;
2995
+ negaConditionalFormatObj.value2 = data.compareValue2;
2996
+ negaConditionalFormatObj.conditions = "Between";
2997
+ this.setFontSettingConditional(negaConditionalFormatObj, data, -1);
2998
+ }
2999
+ break;
3000
+ case "NotBetween": // val >= value2, val <= value1
3001
+ if (Math.sign(data.compareValue2)) {
3002
+ negaConditionalFormatObj.value1 = data.compareValue1;
3003
+ negaConditionalFormatObj.conditions = "LessThan";
3004
+ this.setFontSettingConditional(negaConditionalFormatObj, data, -1);
3005
+ conditionalFormatObj.value1 = data.compareValue2;
3006
+ conditionalFormatObj.conditions = "GreaterThan";
3007
+ this.setFontSettingConditional(conditionalFormatObj, data, 1);
3008
+ }
3009
+ else {
3010
+ negaConditionalFormatObj.value1 = data.compareValue1;
3011
+ negaConditionalFormatObj.value2 = data.compareValue2;
3012
+ negaConditionalFormatObj.conditions = "NotBetween";
3013
+ this.setFontSettingConditional(negaConditionalFormatObj, data, -1);
3014
+ conditionalFormatObj.value1 = 0;
3015
+ conditionalFormatObj.conditions = "GreaterThan";
3016
+ this.setFontSettingConditional(conditionalFormatObj, data, 1);
3017
+ }
3018
+ break;
3019
+ default:
3020
+ break;
3021
+ }
3022
+ }
3023
+ }
3024
+ getQuarterValue(format, date, quarter) {
3025
+ let year;
3026
+ switch (format) {
3027
+ case "Q1 2021":
3028
+ year = date.getFullYear();
3029
+ return "Q" + quarter + " " + year;
3030
+ case "Q1 21":
3031
+ year = date.getYear() - 100;
3032
+ return "Q" + quarter + " " + year;
3033
+ case "2021 Q1":
3034
+ year = date.getFullYear();
3035
+ return year + " " + "Q" + quarter;
3036
+ case "21 Q1":
3037
+ year = date.getYear() - 100;
3038
+ return year + " " + "Q" + quarter;
3039
+ }
3040
+ }
3041
+ customiseCell(args) {
3042
+ if (args.column.type === "date" || args.column.type === "dateTime") {
3043
+ const { field } = args.column;
3044
+ if (!args.data[field]) {
3045
+ args.column.type = "string";
3046
+ args.column.format = "";
3047
+ }
3048
+ }
3049
+ }
3050
+ /**
3051
+ * @param timeArray 数组对象 [{"date":"2021-01-01"},{"date":"2021-02-01"}]
3052
+ * @param endDate 截至时间
3053
+ * @param interval 时间间隔 year / quarter / month
3054
+ * @param timeKey 时间字段名 date
3055
+ * @returns 划分后的时间分组对象
3056
+ */
3057
+ getTimeRanges(timeArray, endDate, interval, timeKey) {
3058
+ // 将时间字符串转换为 moment 对象
3059
+ const dates = timeArray.map((item) => moment(item[timeKey || "date"]));
3060
+ // 分隔符
3061
+ const delimiter = "-";
3062
+ // 找到最小时间和最大时间
3063
+ const minDate = moment.min(dates);
3064
+ const maxDate = moment(endDate);
3065
+ // 初始化结果对象
3066
+ const result = {};
3067
+ // 根据入参进行划分
3068
+ if (interval === "year") {
3069
+ const startYear = minDate.year();
3070
+ const endYear = maxDate.year();
3071
+ for (let year = startYear; year <= endYear; year++) {
3072
+ result[year] = [];
3073
+ }
3074
+ dates.forEach((date, index) => {
3075
+ const year = date.year();
3076
+ result[year].push(timeArray[index]);
3077
+ });
3078
+ }
3079
+ else if (interval === "quarter") {
3080
+ // 存储季度字符串
3081
+ const quarters = [];
3082
+ // 逐一遍历每个季度
3083
+ for (let currentDate = minDate.clone(); currentDate.isSameOrBefore(maxDate); currentDate.add(3, "months")) {
3084
+ const year = currentDate.year();
3085
+ const quarter = Math.ceil((currentDate.month() + 1) / 3); // 计算季度
3086
+ quarters.push(`${year}${delimiter}Q${quarter}`); // 格式化并添加到数组
3087
+ }
3088
+ // 输出所有季度
3089
+ quarters.forEach((quarter, index) => {
3090
+ result[quarter] = [];
3091
+ });
3092
+ dates.forEach((date, index) => {
3093
+ const year = date.year();
3094
+ const quarter = date.quarter(); // 获取季度
3095
+ if (quarter === 1)
3096
+ result[year + delimiter + "Q1"].push(timeArray[index]);
3097
+ else if (quarter === 2)
3098
+ result[year + delimiter + "Q2"].push(timeArray[index]);
3099
+ else if (quarter === 3)
3100
+ result[year + delimiter + "Q3"].push(timeArray[index]);
3101
+ else if (quarter === 4)
3102
+ result[year + delimiter + "Q4"].push(timeArray[index]);
3103
+ });
3104
+ }
3105
+ else if (interval === "month") {
3106
+ // 存储月份字符串
3107
+ const months = [];
3108
+ // 逐一遍历每个月
3109
+ for (let currentDate = minDate.clone(); currentDate.isSameOrBefore(maxDate); currentDate.add(1, "months")) {
3110
+ months.push(currentDate.format(`YYYY${delimiter}MM`)); // 格式化并添加到数组
3111
+ }
3112
+ // 输出所有月份
3113
+ months.forEach((month, index) => {
3114
+ result[month] = [];
3115
+ });
3116
+ dates.forEach((date, index) => {
3117
+ const year = date.year();
3118
+ const month = (date.month() + 1).toString().padStart(2, "0"); // 0-11
3119
+ result[year + delimiter + month].push(timeArray[index]);
3120
+ });
3121
+ }
3122
+ return result;
3123
+ }
3124
+ /**
3125
+ * 计算几何算数平方更
3126
+ * @param values 数组 [0, 0, 0.2575]
3127
+ * @returns
3128
+ */
3129
+ calculateGrowthRate(values) {
3130
+ const product = values.reduce((acc, val) => acc * (1 + val), 1);
3131
+ if (product >= 0) {
3132
+ return Math.pow(product, 1 / values.length) - 1;
3133
+ }
3134
+ else if (product < 0) {
3135
+ if (values.length % 2 == 0) {
3136
+ return null;
3137
+ }
3138
+ else {
3139
+ return this.nthroot(product, values.length) - 1;
3140
+ }
3141
+ }
3142
+ }
3143
+ nthroot(x, n) {
3144
+ let ng = n % 2;
3145
+ if (ng == 1 || x < 0)
3146
+ x = -x;
3147
+ var r = Math.pow(x, 1 / n);
3148
+ n = Math.pow(r, n);
3149
+ if (Math.abs(x - n) < 1 && x > 0 === n > 0)
3150
+ return ng ? -r : r;
3151
+ }
3152
+ /**
3153
+ * 标准偏差
3154
+ * @param values 数组 [0, 0, -0.4775]
3155
+ * @returns 0.2756847535380463
3156
+ */
3157
+ calculateStandardDeviation(values) {
3158
+ const n = values.length;
3159
+ // 检查数据点数量
3160
+ if (n < 2) {
3161
+ throw new Error("至少需要两个数据点来计算样本标准偏差");
3162
+ }
3163
+ // 计算均值
3164
+ const mean = values.reduce((acc, val) => acc + val, 0) / n;
3165
+ // 计算方差
3166
+ const variance = values.reduce((acc, val) => acc + Math.pow(val - mean, 2), 0) /
3167
+ (n - 1);
3168
+ // 返回标准偏差
3169
+ return Math.sqrt(variance);
3170
+ }
3171
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: GadgetPivotComponent, deps: [{ token: i1.DashboardPorletsService }, { token: i2.DashboardService }, { token: i0.ChangeDetectorRef }, { token: PBF_TOKEN, optional: true }], target: i0.ɵɵFactoryTarget.Component });
3172
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: GadgetPivotComponent, selector: "rs-gadget-pivot", inputs: { portlet: "portlet", dashboard: "dashboard", portlets: "portlets" }, providers: [
3173
+ ToolbarService,
3174
+ FieldListService,
3175
+ NumberFormattingService,
3176
+ CalculatedFieldService,
3177
+ GroupingBarService,
3178
+ VirtualScrollService,
3179
+ DrillThroughService,
3180
+ ], viewQueries: [{ propertyName: "pivotObj", first: true, predicate: ["pivotview"], descendants: true }, { propertyName: "fieldlistObj", first: true, predicate: ["pivotfieldlist"], descendants: true }], ngImport: i0, template: "<div class=\"control-section\" style=\"overflow: hidden; height: 100%\">\r\n\t<ejs-pivotview\r\n\t\twidth=\"100%\"\r\n\t\theight=\"100%\"\r\n\t\tstyle=\"display: block\"\r\n\t\t[dataSourceSettings]=\"dataSourceSettings\"\r\n\t\t#pivotview\r\n\t\t(dataBound)=\"dataBound($event)\"\r\n\t\tenableValueSorting=\"true\"\r\n\t\tallowConditionalFormatting=\"true\"\r\n\t\t[allowDeferLayoutUpdate]=\"true\"\r\n\t\t[gridSettings]=\"gridSettings\"\r\n\t\tallowExcelExport=\"true\"\r\n\t\tallowGrouping=\"true\"\r\n\t\t[zoomSettings]=\"zoomSettings\"\r\n\t\tenableVirtualization=\"true\"\r\n\t\t(enginePopulated)=\"afterEnginePopulate($event)\"\r\n\t\t(aggregateCellInfo)=\"aggregateCellInfo($event)\"\r\n\t\t(cellClick)=\"cellClick($event)\"\r\n\t\tallowDrillThrough=\"true\"\r\n\t\t(actionFailure)=\"actionFailure($event)\"\r\n\t\t(actionComplete)=\"actionComplete($event)\"\r\n\t\t(actionBegin)=\"actionBegin($event)\"\r\n\t\t(fieldListRefreshed)=\"fieldListRefreshed($event)\"\r\n\t\t(drillThrough)=\"drillThrough($event)\"\r\n\t\t[showTooltip]=\"false\"\r\n\t\t(queryCellInfo)=\"customiseCell($event)\"\r\n\t\t(beforeExport)=\"beforeExport($event)\"\r\n\t>\r\n\t</ejs-pivotview>\r\n\r\n\t<div class=\"pivotfieldlist-control\">\r\n\t\t<ejs-pivotfieldlist\r\n\t\t\t[id]=\"portlet.newId\"\r\n\t\t\t#pivotfieldlist\r\n\t\t\t[allowDeferLayoutUpdate]=\"true\"\r\n\t\t\trenderMode=\"Popup\"\r\n\t\t\t(enginePopulated)=\"afterPopulate($event)\"\r\n\t\t\t(memberEditorOpen)=\"onMemberEditorOpen($event)\"\r\n\t\t\t(enginePopulating)=\"enginePopulating($event)\"\r\n\t\t\t(aggregateCellInfo)=\"aggregateCellInfo($event)\"\r\n\t\t\t(fieldDrop)=\"onFieldDrop($event)\"\r\n\t\t\t(actionComplete)=\"actionComplete($event)\"\r\n\t\t\t(actionBegin)=\"actionBegin($event)\"\r\n\t\t\t(calculatedFieldCreate)=\"calculatedFieldCreate($event)\"\r\n\t\t\t(load)=\"onLoad()\"\r\n\t\t\t(created)=\"created($event)\"\r\n\t\t\t(dataBound)='ondataBound()'\r\n\t\t>\r\n\t\t</ejs-pivotfieldlist>\r\n\t</div>\r\n\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: ["::ng-deep .e-pivotview .e-gridcontent tr:nth-child(2n) .e-leftfreeze.e-freezeleftborder:not(.e-gtot){background-color:#fff}.gadgetBar ul{margin:0;padding:0;list-style:none;display:inline-block;background:#fff;border-radius:5px}.gadgetBar ul li{display:inline-block;width:45px;height:39px;line-height:39px;text-align:center;cursor:pointer}:host::ng-deep .e-cellvalue{color:unset!important}:host ::ng-deep .e-pivotview .e-gtot{font-weight:400!important}:host ::ng-deep .e-pivotview .grand-class{background-color:#fff!important}:host ::ng-deep .e-pivotview .grand-class .e-cellvalue{font-size:12px;font-weight:700!important}:host ::ng-deep .e-headercell{background-color:#eaedf0!important}:host ::ng-deep .e-headercell .e-headertext{font-size:12px!important}:host ::ng-deep .e-columnsheader{background-color:#f8fafb!important}.logoImg{position:absolute!important;left:10px!important}:host ::ng-deep .image-{height:55px;width:55px;border-radius:50px;overflow:hidden;margin:5px 5px 5px 0;display:inline-flex;justify-content:center;align-items:center}:host ::ng-deep .image- img{width:55px}:host::ng-deep .e-pivotview .e-customclass .e-cellvalue{font-weight:700!important}:host::ng-deep .e-gridcontent .e-rowcell .e-cellvalue{background-color:transparent!important}::ng-deep .e-pivotfieldlist-container #AccountTypeCode .e-sort{opacity:0;pointer-events:none}::ng-deep .e-pivotfieldlist-container .e-footer-content .e-checkbox-layout{display:none}:host ::ng-deep .control-section .e-spin-show,:host ::ng-deep .control-section .e-spinner-pane{display:none!important}:host ::ng-deep .control-section .e-grid .e-gridheader .e-headercell .e-sortfilterdiv,:host ::ng-deep .control-section .e-treegrid .e-gridheader .e-headercell .e-sortfilterdiv{right:0}:host ::ng-deep .control-section .header-align-right .e-headercelldiv{text-align:right!important;justify-content:flex-end!important;padding-right:28px!important}:host ::ng-deep .control-section .header-align-right .e-headercelldiv .e-pivotcell-container{width:100%}:host ::ng-deep .control-section .e-pivotview{border:none!important}:host ::ng-deep .control-section .e-pivotview tr{height:32px!important}:host ::ng-deep .control-section .e-pivotview tr th{height:40px!important;background:#fff!important}:host ::ng-deep .control-section .e-pivotview .e-grid.e-default.e-bothlines .e-headercell{border-right:none!important;border-left:none!important}:host ::ng-deep .control-section .e-pivotview .e-table{border-right:none!important}:host ::ng-deep .control-section .e-pivotview svg{outline:none!important}:host ::ng-deep .control-section .e-pivotview svg>g>rect{stroke-width:0!important}:host ::ng-deep .control-section .e-pivotview .e-gridcontent .e-rowcell{border-right:none!important;border-left:none!important;border-color:#eff1f3!important}:host ::ng-deep .control-section .e-gridheader{border-top:none!important;border-color:#eff1f3!important;background-color:#fff!important}:host ::ng-deep .control-section .e-headertext{font-weight:400!important;color:#43566c!important}::ng-deep .e-pivot-treeview-outer li .e-text-content .e-list-text{margin-bottom:0!important}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.PivotViewComponent, selector: "ejs-pivotview", inputs: ["aggregateTypes", "allowCalculatedField", "allowConditionalFormatting", "allowDataCompression", "allowDeferLayoutUpdate", "allowDrillThrough", "allowExcelExport", "allowGrouping", "allowNumberFormatting", "allowPdfExport", "cellTemplate", "chartSettings", "chartTypes", "cssClass", "dataSourceSettings", "displayOption", "editSettings", "enableFieldSearching", "enableHtmlSanitizer", "enablePaging", "enablePersistence", "enableRtl", "enableValueSorting", "enableVirtualization", "exportAllPages", "gridSettings", "groupingBarSettings", "height", "hyperlinkSettings", "loadOnDemandInMemberEditor", "locale", "maxNodeLimitInMemberEditor", "maxRowsInDrillThrough", "pageSettings", "pagerSettings", "pivotValues", "showFieldList", "showGroupingBar", "showToolbar", "showTooltip", "showValuesButton", "spinnerTemplate", "toolbar", "toolbarTemplate", "tooltipTemplate", "virtualScrollSettings", "width"], outputs: ["actionBegin", "actionComplete", "actionFailure", "afterServiceInvoke", "aggregateCellInfo", "aggregateMenuOpen", "beforeExport", "beforeServiceInvoke", "beginDrillThrough", "calculatedFieldCreate", "cellClick", "cellSelected", "cellSelecting", "chartSeriesCreated", "conditionalFormatting", "created", "dataBound", "destroyed", "drill", "drillThrough", "editCompleted", "enginePopulated", "enginePopulating", "exportComplete", "fetchReport", "fieldDragStart", "fieldDrop", "fieldListRefreshed", "fieldRemove", "hyperlinkCellClick", "load", "loadReport", "memberEditorOpen", "memberFiltering", "newReport", "numberFormatting", "onFieldDropped", "onHeadersSort", "onPdfCellRender", "removeReport", "renameReport", "saveReport", "toolbarClick", "toolbarRender"] }, { kind: "component", type: i4.PivotFieldListComponent, selector: "ejs-pivotfieldlist", inputs: ["aggregateTypes", "allowCalculatedField", "allowDeferLayoutUpdate", "cssClass", "currencyCode", "dataSourceSettings", "enableFieldSearching", "enableHtmlSanitizer", "enablePersistence", "enableRtl", "loadOnDemandInMemberEditor", "locale", "maxNodeLimitInMemberEditor", "renderMode", "showValuesButton", "spinnerTemplate", "target"], outputs: ["actionBegin", "actionComplete", "actionFailure", "afterServiceInvoke", "aggregateCellInfo", "aggregateMenuOpen", "beforeServiceInvoke", "calculatedFieldCreate", "created", "dataBound", "destroyed", "enginePopulated", "enginePopulating", "fieldDragStart", "fieldDrop", "fieldRemove", "load", "memberEditorOpen", "memberFiltering", "onFieldDropped", "onHeadersSort"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
3181
+ }
3182
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: GadgetPivotComponent, decorators: [{
3183
+ type: Component,
3184
+ args: [{ selector: "rs-gadget-pivot", providers: [
3185
+ ToolbarService,
3186
+ FieldListService,
3187
+ NumberFormattingService,
3188
+ CalculatedFieldService,
3189
+ GroupingBarService,
3190
+ VirtualScrollService,
3191
+ DrillThroughService,
3192
+ ], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"control-section\" style=\"overflow: hidden; height: 100%\">\r\n\t<ejs-pivotview\r\n\t\twidth=\"100%\"\r\n\t\theight=\"100%\"\r\n\t\tstyle=\"display: block\"\r\n\t\t[dataSourceSettings]=\"dataSourceSettings\"\r\n\t\t#pivotview\r\n\t\t(dataBound)=\"dataBound($event)\"\r\n\t\tenableValueSorting=\"true\"\r\n\t\tallowConditionalFormatting=\"true\"\r\n\t\t[allowDeferLayoutUpdate]=\"true\"\r\n\t\t[gridSettings]=\"gridSettings\"\r\n\t\tallowExcelExport=\"true\"\r\n\t\tallowGrouping=\"true\"\r\n\t\t[zoomSettings]=\"zoomSettings\"\r\n\t\tenableVirtualization=\"true\"\r\n\t\t(enginePopulated)=\"afterEnginePopulate($event)\"\r\n\t\t(aggregateCellInfo)=\"aggregateCellInfo($event)\"\r\n\t\t(cellClick)=\"cellClick($event)\"\r\n\t\tallowDrillThrough=\"true\"\r\n\t\t(actionFailure)=\"actionFailure($event)\"\r\n\t\t(actionComplete)=\"actionComplete($event)\"\r\n\t\t(actionBegin)=\"actionBegin($event)\"\r\n\t\t(fieldListRefreshed)=\"fieldListRefreshed($event)\"\r\n\t\t(drillThrough)=\"drillThrough($event)\"\r\n\t\t[showTooltip]=\"false\"\r\n\t\t(queryCellInfo)=\"customiseCell($event)\"\r\n\t\t(beforeExport)=\"beforeExport($event)\"\r\n\t>\r\n\t</ejs-pivotview>\r\n\r\n\t<div class=\"pivotfieldlist-control\">\r\n\t\t<ejs-pivotfieldlist\r\n\t\t\t[id]=\"portlet.newId\"\r\n\t\t\t#pivotfieldlist\r\n\t\t\t[allowDeferLayoutUpdate]=\"true\"\r\n\t\t\trenderMode=\"Popup\"\r\n\t\t\t(enginePopulated)=\"afterPopulate($event)\"\r\n\t\t\t(memberEditorOpen)=\"onMemberEditorOpen($event)\"\r\n\t\t\t(enginePopulating)=\"enginePopulating($event)\"\r\n\t\t\t(aggregateCellInfo)=\"aggregateCellInfo($event)\"\r\n\t\t\t(fieldDrop)=\"onFieldDrop($event)\"\r\n\t\t\t(actionComplete)=\"actionComplete($event)\"\r\n\t\t\t(actionBegin)=\"actionBegin($event)\"\r\n\t\t\t(calculatedFieldCreate)=\"calculatedFieldCreate($event)\"\r\n\t\t\t(load)=\"onLoad()\"\r\n\t\t\t(created)=\"created($event)\"\r\n\t\t\t(dataBound)='ondataBound()'\r\n\t\t>\r\n\t\t</ejs-pivotfieldlist>\r\n\t</div>\r\n\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: ["::ng-deep .e-pivotview .e-gridcontent tr:nth-child(2n) .e-leftfreeze.e-freezeleftborder:not(.e-gtot){background-color:#fff}.gadgetBar ul{margin:0;padding:0;list-style:none;display:inline-block;background:#fff;border-radius:5px}.gadgetBar ul li{display:inline-block;width:45px;height:39px;line-height:39px;text-align:center;cursor:pointer}:host::ng-deep .e-cellvalue{color:unset!important}:host ::ng-deep .e-pivotview .e-gtot{font-weight:400!important}:host ::ng-deep .e-pivotview .grand-class{background-color:#fff!important}:host ::ng-deep .e-pivotview .grand-class .e-cellvalue{font-size:12px;font-weight:700!important}:host ::ng-deep .e-headercell{background-color:#eaedf0!important}:host ::ng-deep .e-headercell .e-headertext{font-size:12px!important}:host ::ng-deep .e-columnsheader{background-color:#f8fafb!important}.logoImg{position:absolute!important;left:10px!important}:host ::ng-deep .image-{height:55px;width:55px;border-radius:50px;overflow:hidden;margin:5px 5px 5px 0;display:inline-flex;justify-content:center;align-items:center}:host ::ng-deep .image- img{width:55px}:host::ng-deep .e-pivotview .e-customclass .e-cellvalue{font-weight:700!important}:host::ng-deep .e-gridcontent .e-rowcell .e-cellvalue{background-color:transparent!important}::ng-deep .e-pivotfieldlist-container #AccountTypeCode .e-sort{opacity:0;pointer-events:none}::ng-deep .e-pivotfieldlist-container .e-footer-content .e-checkbox-layout{display:none}:host ::ng-deep .control-section .e-spin-show,:host ::ng-deep .control-section .e-spinner-pane{display:none!important}:host ::ng-deep .control-section .e-grid .e-gridheader .e-headercell .e-sortfilterdiv,:host ::ng-deep .control-section .e-treegrid .e-gridheader .e-headercell .e-sortfilterdiv{right:0}:host ::ng-deep .control-section .header-align-right .e-headercelldiv{text-align:right!important;justify-content:flex-end!important;padding-right:28px!important}:host ::ng-deep .control-section .header-align-right .e-headercelldiv .e-pivotcell-container{width:100%}:host ::ng-deep .control-section .e-pivotview{border:none!important}:host ::ng-deep .control-section .e-pivotview tr{height:32px!important}:host ::ng-deep .control-section .e-pivotview tr th{height:40px!important;background:#fff!important}:host ::ng-deep .control-section .e-pivotview .e-grid.e-default.e-bothlines .e-headercell{border-right:none!important;border-left:none!important}:host ::ng-deep .control-section .e-pivotview .e-table{border-right:none!important}:host ::ng-deep .control-section .e-pivotview svg{outline:none!important}:host ::ng-deep .control-section .e-pivotview svg>g>rect{stroke-width:0!important}:host ::ng-deep .control-section .e-pivotview .e-gridcontent .e-rowcell{border-right:none!important;border-left:none!important;border-color:#eff1f3!important}:host ::ng-deep .control-section .e-gridheader{border-top:none!important;border-color:#eff1f3!important;background-color:#fff!important}:host ::ng-deep .control-section .e-headertext{font-weight:400!important;color:#43566c!important}::ng-deep .e-pivot-treeview-outer li .e-text-content .e-list-text{margin-bottom:0!important}\n"] }]
3193
+ }], ctorParameters: function () { return [{ type: i1.DashboardPorletsService }, { type: i2.DashboardService }, { type: i0.ChangeDetectorRef }, { type: undefined, decorators: [{
3194
+ type: Optional
3195
+ }, {
3196
+ type: Inject,
3197
+ args: [PBF_TOKEN]
3198
+ }] }]; }, propDecorators: { portlet: [{
3199
+ type: Input
3200
+ }], dashboard: [{
3201
+ type: Input
3202
+ }], portlets: [{
3203
+ type: Input
3204
+ }], pivotObj: [{
3205
+ type: ViewChild,
3206
+ args: ["pivotview", { static: false }]
3207
+ }], fieldlistObj: [{
3208
+ type: ViewChild,
3209
+ args: ["pivotfieldlist", { static: false }]
3210
+ }] } });
3211
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gadget-pivot.component.js","sourceRoot":"","sources":["../../../../../../../projects/raise-common-lib/src/lib/dashboard/gadget-group/gadget-pivot/gadget-pivot.component.ts","../../../../../../../projects/raise-common-lib/src/lib/dashboard/gadget-group/gadget-pivot/gadget-pivot.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n\tChangeDetectorRef,\r\n\tComponent,\r\n\tInput,\r\n\tOnInit,\r\n\tViewChild,\r\n\tChangeDetectionStrategy,\r\n\tInject,\r\n\tOptional,\r\n} from \"@angular/core\";\r\n\r\nimport {\r\n\tIDataOptions,\r\n\tPivotFieldListComponent,\r\n\tPivotViewComponent,\r\n\tEnginePopulatedEventArgs,\r\n\tIDataSet,\r\n\tToolbarService,\r\n\tFieldListService,\r\n\tNumberFormattingService,\r\n\tCalculatedFieldService,\r\n\tCalculatedFieldCreateEventArgs,\r\n\tGroupingBarService,\r\n\tFieldDropEventArgs,\r\n\tISort,\r\n\tVirtualScrollService,\r\n\tIPivotValues,\r\n\tIPageSettings,\r\n\tDrillThroughEventArgs,\r\n\tDrillThroughService,\r\n\tPivotActionFailureEventArgs,\r\n\tQueryCellInfoEventArgs,\r\n} from \"@syncfusion/ej2-angular-pivotview\";\r\nimport {\r\n\tL10n,\r\n\tenableRipple,\r\n\tBrowser,\r\n} from \"@syncfusion/ej2-base\";\r\nimport { GridSettings } from \"@syncfusion/ej2-pivotview/src/pivotview/model/gridsettings\";\r\nimport {\r\n\tsortBy,\r\n\tdifferenceWith,\r\n\tstartsWith,\r\n\tcloneDeep,\r\n\tuniqBy,\r\n\tfilter as _filter,\r\n\tmaxBy,\r\n\tminBy,\r\n\tsumBy,\r\n\tmeanBy,\r\n} from \"lodash\";\r\nimport { DashboardService } from \"../../dashboard.service\";\r\nimport {\r\n\tAGGREGATE_TYPES_TEXT,\r\n\tALL_AGGREGATE_TYPES,\r\n\tDashboardPorletsService,\r\n} from \"../../dashboardPorlets.service\";\r\nimport { Observable, Subscription } from \"rxjs\";\r\nimport { MaskedTextBox } from \"@syncfusion/ej2-inputs/src/maskedtextbox/maskedtextbox\";\r\nimport { DataManager } from \"@syncfusion/ej2-data/src/manager\";\r\nimport { Predicate, Query } from \"@syncfusion/ej2-data/src/query\";\r\nimport { DataUtil } from \"@syncfusion/ej2-data\";\r\nimport moment from \"moment\";\r\nimport { PBF_TOKEN } from \"../../../service/InjectionToken\";\r\n\r\nenableRipple(false);\r\n\r\n@Component({\r\n\tselector: \"rs-gadget-pivot\",\r\n\ttemplateUrl: \"./gadget-pivot.component.html\",\r\n\tstyleUrls: [\"./gadget-pivot.component.scss\"],\r\n\tproviders: [\r\n\t\tToolbarService,\r\n\t\tFieldListService,\r\n\t\tNumberFormattingService,\r\n\t\tCalculatedFieldService,\r\n\t\tGroupingBarService,\r\n\t\tVirtualScrollService,\r\n\t\tDrillThroughService,\r\n\t],\r\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class GadgetPivotComponent implements OnInit {\r\n\t@Input() portlet;\r\n\t@Input() dashboard;\r\n\t@Input() portlets;\r\n\tprivate Pivot_Data: IDataSet[];\r\n\tprivate config;\r\n\tpublic dataSourceSettings: IDataOptions;\r\n\tpublic gridSettings: GridSettings;\r\n\tprivate excludeFields = [];\r\n\tprivate filterSettings = [];\r\n\tprivate datePipeFormat;\r\n\tpublic translation;\r\n\t@ViewChild(\"pivotview\", { static: false })\r\n\tprivate pivotObj: PivotViewComponent;\r\n\t@ViewChild(\"pivotfieldlist\", { static: false })\r\n\tpublic fieldlistObj: PivotFieldListComponent;\r\n\tprivate observable = new Observable();\r\n\tprivate grandTotals = {};\r\n\tprivate subTotals = {};\r\n\tprivate flag: boolean = false;\r\n\tprivate previousSort: ISort;\r\n\tprivate subscriptions: Subscription[] = [];\r\n\tprivate allDataValue;\r\n\t// private calculatedFieldSettings;\r\n\tprivate isInit: boolean = true;\r\n\tprivate pivotSearchBox: MaskedTextBox;\r\n\tpublic tooltipSettings = {\r\n\t\tenable: false,\r\n\t};\r\n\tprivate columnTexts = [];\r\n\tprivate configFields = [];\r\n\tprivate quarterFormat = [\r\n\t\t{ value: \"03/2021\", format: \"MM/yyyy\" },\r\n\t\t{ value: \"03/21\", format: \"MM/dd\" },\r\n\t\t{ value: \"3/2021\", format: \"M/yyyy\" },\r\n\t\t{ value: \"3/21\", format: \"M/yy\" },\r\n\t\t{ value: \"March 2021\", format: \"MMMM yyyy\" },\r\n\t\t{ value: \"Mar, 2021\", format: \"MMM, yyyy\" },\r\n\t\t{ value: \"March, 2021\", format: \"MMMM, yyyy\" },\r\n\t\t{ value: \"2021\", format: \"yyyy\" },\r\n\t];\r\n\tzoomSettings = {\r\n\t\tenable: false,\r\n\t};\r\n\titemDataTypeSortArr = [\r\n\t\t\"Assets\",\r\n\t\t\"Liabilities\",\r\n\t\t\"Equity\",\r\n\t\t\"P&L\",\r\n\t\t\"Cashflow\",\r\n\t];\r\n\tprivate formatDates = [];\r\n\tprivate customCalculatedFields: any[] = []; // 自定义计算列\r\n\tprivate allowedCalculatedFields: any[] = []; // 允许自定义算法的字段\r\n\tprivate zeroFormatData = {\r\n\t\temptyList: [],\r\n\t\thgList: [],\r\n\t};\r\n\tprivate millionFields = [];\r\n\tprivate tempSubtotals = [];\r\n\tpublic orderByColumns; // Eg: \"DueDate, Sequence\"\r\n\tpublic isApplyIRR: boolean = false;\r\n\tpublic calcIRRData: any;\r\n\tprivate percentNumFields = [];\r\n\tpublic pageLoading;\r\n\r\n\tconstructor(\r\n\t\tprivate dashboardPorletsService: DashboardPorletsService,\r\n\t\tprivate dashboardService: DashboardService,\r\n\t\tprivate ref: ChangeDetectorRef,\r\n\t\t@Optional() @Inject(PBF_TOKEN) private pbf: any,\r\n\r\n\t) {}\r\n\r\n\tngOnInit() {\r\n\t\tthis.getInfo();\r\n\t\tL10n.load({\r\n\t\t\t\"en-US\": {\r\n\t\t\t\tpivotview: AGGREGATE_TYPES_TEXT,\r\n\t\t\t\tpivotfieldlist: AGGREGATE_TYPES_TEXT,\r\n\t\t\t},\r\n\t\t\tzh: {\r\n\t\t\t\tpivotview: AGGREGATE_TYPES_TEXT,\r\n\t\t\t\tpivotfieldlist: AGGREGATE_TYPES_TEXT,\r\n\t\t\t},\r\n\t\t\t\"zh-Hant-HK\": {\r\n\t\t\t\tpivotview: AGGREGATE_TYPES_TEXT,\r\n\t\t\t\tpivotfieldlist: AGGREGATE_TYPES_TEXT,\r\n\t\t\t},\r\n\t\t\tja: {\r\n\t\t\t\tpivotview: AGGREGATE_TYPES_TEXT,\r\n\t\t\t\tpivotfieldlist: AGGREGATE_TYPES_TEXT,\r\n\t\t\t},\r\n\t\t\tko: {\r\n\t\t\t\tpivotview: AGGREGATE_TYPES_TEXT,\r\n\t\t\t\tpivotfieldlist: AGGREGATE_TYPES_TEXT,\r\n\t\t\t},\r\n\t\t\tfr: {\r\n\t\t\t\tpivotview: AGGREGATE_TYPES_TEXT,\r\n\t\t\t\tpivotfieldlist: AGGREGATE_TYPES_TEXT,\r\n\t\t\t},\r\n\t\t});\r\n\t\tthis.getData();\r\n\t}\r\n\r\n\tngAfterViewInit(): void {\r\n\t\tthis.subscriptions.push(\r\n\t\t\tthis.dashboardService.getchangePivot().subscribe((updated) => {\r\n\t\t\t\tif (updated === this.portlet.newId) {\r\n\t\t\t\t\tthis.getData();\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.getData();\r\n\t\t\t\t\tif (this.pivotObj) this.pivotObj.refreshData();\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.pageLoading = false;\r\n\t\t\t\t\tthis.getData();\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((updated) => {\r\n\t\t\t\tif (updated === this.portlet.newId) {\r\n\t\t\t\t\tthis.getData();\r\n\t\t\t\t\tif (this.pivotObj) this.pivotObj.refreshData();\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\r\n\t\t\t\t.clearFieldListObservable()\r\n\t\t\t\t.subscribe((updated) => {\r\n\t\t\t\t\tif (updated === this.portlet.newId) {\r\n\t\t\t\t\t\tthis.pivotObj.dataSourceSettings.dataSource = [];\r\n\t\t\t\t\t\tif (this.pivotObj) this.pivotObj.refreshData();\r\n\t\t\t\t\t\tif (this.fieldlistObj)\r\n\t\t\t\t\t\t\tthis.fieldlistObj.updateDataSource();\r\n\t\t\t\t\t\tthis.ref.markForCheck();\r\n\t\t\t\t\t\tthis.ref.detectChanges();\r\n\t\t\t\t\t}\r\n\t\t\t\t})\r\n\t\t);\r\n\r\n\t\t// title change\r\n\t\tthis.subscriptions.push(\r\n\t\t\tthis.dashboardService.updatePortletTitle().subscribe((updated) => {\r\n\t\t\t\tif (updated) {\r\n\t\t\t\t\tthis.config = JSON.parse(this.portlet.config);\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\tonMemberEditorOpen(args: any): void {\r\n\t\t// 你可以在这里根据需要修改args来自定义过滤窗口的行为\r\n\t\t// 11247 专门为item data type而设置\r\n\t\tif (args.fieldName === \"AccountTypeCode\") {\r\n\t\t\tlet res = new Array(5).fill(null);\r\n\t\t\tconst fieldMembers = [...args.fieldMembers];\r\n\r\n\t\t\tfor (let i = fieldMembers.length - 1; i >= 0; i--) {\r\n\t\t\t\tlet index = -1;\r\n\t\t\t\tconst item = this.itemDataTypeSortArr.find((name, ind) => {\r\n\t\t\t\t\tif (fieldMembers[i].actualText === name) {\r\n\t\t\t\t\t\tindex = ind;\r\n\t\t\t\t\t}\r\n\t\t\t\t\treturn fieldMembers[i].actualText === name;\r\n\t\t\t\t});\r\n\t\t\t\tif (!item) {\r\n\t\t\t\t\tcontinue;\r\n\t\t\t\t}\r\n\t\t\t\tconst fillItem = fieldMembers.splice(i, 1);\r\n\t\t\t\tres[index] = fillItem[0];\r\n\t\t\t}\r\n\t\t\tres = res.filter((item) => item) || [];\r\n\t\t\targs.fieldMembers = [...res, ...fieldMembers];\r\n\t\t\tsetTimeout(() => {\r\n\t\t\t\tconst ele = document.querySelector(\".e-member-editor-dialog\");\r\n\t\t\t\tif (ele) {\r\n\t\t\t\t\tele.querySelector(\".e-filter-sort\").setAttribute(\r\n\t\t\t\t\t\t\"style\",\r\n\t\t\t\t\t\t\"display: none\"\r\n\t\t\t\t\t);\r\n\t\t\t\t}\r\n\t\t\t});\r\n\t\t}\r\n\t}\r\n\r\n\tprivate setGridSettings() {\r\n\t\tthis.gridSettings = {\r\n\t\t\tcolumnWidth: 140,\r\n\t\t\trowHeight: 40,\r\n\t\t\tallowSelection: true,\r\n\t\t\tselectionSettings: {\r\n\t\t\t\tmode: \"Cell\",\r\n\t\t\t\ttype: \"Multiple\",\r\n\t\t\t\tcellSelectionMode: \"Box\",\r\n\t\t\t},\r\n\t\t\tcolumnRender: this.observable.subscribe((args) => {\r\n\t\t\t\tthis.setColumnsRender(args);\r\n\t\t\t}) as any,\r\n\t\t\t// 升级后 默认会有导出样式覆盖，需要手动设置导出标题样式\r\n\t\t\texcelHeaderQueryCellInfo: this.observable.subscribe((args: any) => {\r\n\t\t\t\t// args.style是个ExcelStyle类型\r\n\t\t\t\targs.style = {\r\n\t\t\t\t\tbold: true, // 字体加粗\r\n\t\t\t\t\tvAlign: \"Center\",\r\n\t\t\t\t\twrapText: false, // 不换行\r\n\t\t\t\t\tindent: 0,\r\n\t\t\t\t\tborders: null, // 不需要border\r\n\t\t\t\t};\r\n\t\t\t}) as any,\r\n\t\t\t// 升级后 默认会有导出样式覆盖，需要手动设置导出内容样式\r\n\t\t\texcelQueryCellInfo: this.observable.subscribe((args: any) => {\r\n\t\t\t\t// #f486cfff 这里输出的是RGBA 颜色格式， xlsx里不需要透明度,去掉尾部ff\r\n\t\t\t\tif (args.style && args.style.backColor) {\r\n\t\t\t\t\targs.style.backColor = args.style.backColor.substring(0, 7);\r\n\t\t\t\t}\r\n\t\t\t\tlet _style: any = {\r\n\t\t\t\t\tbold: false,\r\n\t\t\t\t\twrapText: false,\r\n\t\t\t\t\tborders: null,\r\n\t\t\t\t\tfontColor: args.style.fontColor,\r\n\t\t\t\t\tbackColor: args.style.backColor,\r\n\t\t\t\t};\r\n\t\t\t\tlet colIndex = args.cell.colIndex;\r\n\t\t\t\tlet rowIndex = args.cell.rowIndex;\r\n\t\t\t\tif (this.config.showGrandTotals) {\r\n\t\t\t\t\t// GrandTotal不需要颜色\r\n\t\t\t\t\tif (args.data.length === rowIndex + 1) {\r\n\t\t\t\t\t\tdelete _style.fontColor;\r\n\t\t\t\t\t\tdelete _style.backColor;\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t\tif (args.data[rowIndex][colIndex].formattedText == \"\") {\r\n\t\t\t\t\targs.value = \"\";\r\n\t\t\t\t}\r\n\t\t\t\targs.style = Object.assign(args.style, _style);\r\n\t\t\t\tif (args.value === \"\" && args.style.numberFormat) {\r\n\t\t\t\t\targs.style.numberFormat = null;\r\n\t\t\t\t}\r\n\t\t\t\tif (this.formatDates && this.formatDates.length) {\r\n\t\t\t\t\tlet dateFields = this.formatDates.map((el) => {\r\n\t\t\t\t\t\treturn el.name;\r\n\t\t\t\t\t});\r\n\t\t\t\t\tif (\r\n\t\t\t\t\t\t(args as any).value &&\r\n\t\t\t\t\t\t((args as any).cell.colIndex === 0\r\n\t\t\t\t\t\t\t? dateFields.includes(\r\n\t\t\t\t\t\t\t\t\t(args as any).cell.valueSort.axis\r\n\t\t\t\t\t\t\t  )\r\n\t\t\t\t\t\t\t: dateFields.includes(\r\n\t\t\t\t\t\t\t\t\t(args as any).cell.actualText\r\n\t\t\t\t\t\t\t  ))\r\n\t\t\t\t\t) {\r\n\t\t\t\t\t\t//Customize the Row headers/Column headers based on your needs\r\n\t\t\t\t\t\tlet headers;\r\n\t\t\t\t\t\tif ((args as any).cell.colIndex === 0) {\r\n\t\t\t\t\t\t\theaders = (args as any).cell.actualText;\r\n\t\t\t\t\t\t} else {\r\n\t\t\t\t\t\t\t// headers = pivotValues[k][j].formattedText;\r\n\t\t\t\t\t\t\theaders = (args as any).value;\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\tif (headers) {\r\n\t\t\t\t\t\t\tlet date = new Date(headers);\r\n\r\n\t\t\t\t\t\t\tlet quarter = Math.floor(date.getMonth() / 3) + 1;\r\n\r\n\t\t\t\t\t\t\tlet format;\r\n\r\n\t\t\t\t\t\t\tthis.formatDates.map((el) => {\r\n\t\t\t\t\t\t\t\tif ((args as any).cell.colIndex == 0) {\r\n\t\t\t\t\t\t\t\t\tif (\r\n\t\t\t\t\t\t\t\t\t\tel.name ==\r\n\t\t\t\t\t\t\t\t\t\t(args as any).cell.valueSort.axis\r\n\t\t\t\t\t\t\t\t\t)\r\n\t\t\t\t\t\t\t\t\t\tformat = el.format;\r\n\t\t\t\t\t\t\t\t} else {\r\n\t\t\t\t\t\t\t\t\tif (\r\n\t\t\t\t\t\t\t\t\t\tel.name == (args as any).cell.actualText\r\n\t\t\t\t\t\t\t\t\t)\r\n\t\t\t\t\t\t\t\t\t\tformat = el.format;\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\t(args as any).value = this.getQuarterValue(\r\n\t\t\t\t\t\t\t\tformat,\r\n\t\t\t\t\t\t\t\tdate,\r\n\t\t\t\t\t\t\t\tquarter\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}\r\n\t\t\t}) as any,\r\n\t\t} as GridSettings;\r\n\t}\r\n\r\n\tbeforeExport(exportData) {\r\n\t\tif (exportData) {\r\n\t\t\tconst keyMap = {};\r\n\t\t\tthis.dataSourceSettings.formatSettings.forEach((data) => {\r\n\t\t\t\tif (\r\n\t\t\t\t\tdata.format === \"#,###,,.0;(#,###,,.0)\" ||\r\n\t\t\t\t\tdata.format === \"#,###,,;(#,###,,)\" ||\r\n\t\t\t\t\tdata.format === \"#,###,,.00;(#,###,,.00)\"\r\n\t\t\t\t) {\r\n\t\t\t\t\tkeyMap[data.name] = true;\r\n\t\t\t\t}\r\n\t\t\t});\r\n\t\t\tif (\r\n\t\t\t\texportData.dataCollections &&\r\n\t\t\t\texportData.dataCollections.length\r\n\t\t\t) {\r\n\t\t\t\texportData.dataCollections[0].forEach((row) => {\r\n\t\t\t\t\trow.forEach((cell) => {\r\n\t\t\t\t\t\tif (keyMap[cell.actualText]) {\r\n\t\t\t\t\t\t\tcell.value = cell.actualValue;\r\n\t\t\t\t\t\t}\r\n\r\n\t\t\t\t\t\tif (\r\n\t\t\t\t\t\t\ttypeof cell.value === \"object\" &&\r\n\t\t\t\t\t\t\ttypeof cell.formattedText === \"string\"\r\n\t\t\t\t\t\t) {\r\n\t\t\t\t\t\t\tcell.value = cell.formattedText;\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\t}\r\n\t\t}\r\n\t}\r\n\r\n\tprivate async getData() {\r\n\t\tthis.pageLoading = false;\r\n\t\tlet columns = [];\r\n\t\tlet values = [];\r\n\t\tlet formatSettings = [];\r\n\t\tlet rows = [];\r\n\t\tlet fieldMapping = [];\r\n\t\t// 清空grandTotals和subTotals\r\n\t\tthis.grandTotals = {};\r\n\t\tthis.subTotals = {};\r\n\t\tthis.config = JSON.parse(this.portlet.config);\r\n\t\tthis.setGridSettings();\r\n\t\tif (this.config.fields) {\r\n\t\t\tif (this.dashboardPorletsService.allFieldsObj[this.portlet.id]) {\r\n\t\t\t\tthis.configFields =\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} else {\r\n\t\t\t\tthis.configFields = [...this.config.fields];\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tthis.Pivot_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\r\n\t\tthis.orderByColumns = this.dashboardPorletsService.getOrderByColumnsNew(\r\n\t\t\tthis.portlet.figureCode,\r\n\t\t\tthis.dashboard\r\n\t\t);\r\n\r\n\t\tthis.Pivot_Data = DataUtil.parse.parseJson(this.Pivot_Data);\r\n\t\tif (this.Pivot_Data && this.Pivot_Data.length > 0) {\r\n\t\t\t// 移除列名和数据key不匹配的项\r\n\t\t\tthis.getexcludeFields(this.configFields, this.Pivot_Data[0]);\r\n\t\t\tif (!this.allowedCalculatedFields.length) {\r\n\t\t\t\tthis.allowedCalculatedFields = Object.keys(this.Pivot_Data[0]);\r\n\t\t\t}\r\n\t\t\tfor (let item of this.configFields) {\r\n\t\t\t\t// 字段分组 https://ej2.syncfusion.com/angular/documentation/pivotview/field-list?search=fieldMapping#group-fields-under-desired-folder-name\r\n\t\t\t\tfieldMapping.push({\r\n\t\t\t\t\tname: item.colName,\r\n\t\t\t\t\tcaption: item.addtionName\r\n\t\t\t\t\t\t? `${item.langValue} ${item.addtionName}`\r\n\t\t\t\t\t\t: item.langValue\r\n\t\t\t\t\t\t? item.langValue\r\n\t\t\t\t\t\t: this.translation[item.langCode] || item.langCode,\r\n\r\n\t\t\t\t\tdataType: item.dataType,\r\n\t\t\t\t});\r\n\t\t\t}\r\n\t\t}\r\n\t\tif (this.configFields) {\r\n\t\t\tthis.percentNumFields = [];\r\n\t\t\tthis.formatDates = [];\r\n\t\t\tthis.zeroFormatData.hgList = [];\r\n\t\t\tthis.zeroFormatData.emptyList = [];\r\n\t\t\tthis.millionFields = [];\r\n\t\t\tthis.configFields.map((el) => {\r\n\t\t\t\t// SMP2-2486 & percentNum的format问题\r\n\t\t\t\tif (el.dataType == \"percentNum\") {\r\n\t\t\t\t\tthis.percentNumFields.push(el.colName);\r\n\t\t\t\t}\r\n\t\t\t\tif (\r\n\t\t\t\t\tel.format &&\r\n\t\t\t\t\tel.format.length &&\r\n\t\t\t\t\tel.format[0].formatChecked &&\r\n\t\t\t\t\t[2, 5, 8, 11, 14, 17].includes(el.format[0].selectedFormat)\r\n\t\t\t\t)\r\n\t\t\t\t\tthis.zeroFormatData.hgList.push(el.colName);\r\n\t\t\t\tif (\r\n\t\t\t\t\tel.format &&\r\n\t\t\t\t\tel.format.length &&\r\n\t\t\t\t\tel.format[0].formatChecked &&\r\n\t\t\t\t\t[3, 6, 9, 12, 15, 18].includes(el.format[0].selectedFormat)\r\n\t\t\t\t)\r\n\t\t\t\t\tthis.zeroFormatData.emptyList.push(el.colName);\r\n\t\t\t\t//  pivotTableformatPercent 百分比也有10,11,12 但是它是显示0.00x的格式，所以得排除\r\n\t\t\t\tif (\r\n\t\t\t\t\tel.dataType !== \"percent\" &&\r\n\t\t\t\t\tel.format &&\r\n\t\t\t\t\tel.format.length &&\r\n\t\t\t\t\tel.format[0].formatChecked &&\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.millionFields.push(el.colName);\r\n\t\t\t\tif (\r\n\t\t\t\t\tel.dataType === \"number\" &&\r\n\t\t\t\t\t(!el.format ||\r\n\t\t\t\t\t\t(el.format &&\r\n\t\t\t\t\t\t\tel.format.length &&\r\n\t\t\t\t\t\t\t!el.format[0].formatChecked))\r\n\t\t\t\t) {\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\t//SMP2-3026 and SMP2-3059\r\n\t\t\t\t\t\tformat:\r\n\t\t\t\t\t\t\tel.colName !== \"PortInvStk\" &&\r\n\t\t\t\t\t\t\tel.colName !== \"PortFdInvStk\"\r\n\t\t\t\t\t\t\t\t? this.dashboardPorletsService.formatNumber(\r\n\t\t\t\t\t\t\t\t\t\tel.dp\r\n\t\t\t\t\t\t\t\t  )\r\n\t\t\t\t\t\t\t\t: \"##0.#######0\",\r\n\t\t\t\t\t\tuseGrouping: true,\r\n\t\t\t\t\t};\r\n\r\n\t\t\t\t\tformatSettings.push(formatData);\r\n\t\t\t\t}\r\n\t\t\t\tif (\r\n\t\t\t\t\t(el.dataType === \"percent\" ||\r\n\t\t\t\t\t\tel.dataType === \"percentNum\") &&\r\n\t\t\t\t\t(!el.format ||\r\n\t\t\t\t\t\t(el.format &&\r\n\t\t\t\t\t\t\tel.format.length &&\r\n\t\t\t\t\t\t\t!el.format[0].formatChecked))\r\n\t\t\t\t) {\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: this.dashboardPorletsService.formatPercent(\r\n\t\t\t\t\t\t\tel.dp\r\n\t\t\t\t\t\t),\r\n\t\t\t\t\t};\r\n\t\t\t\t\tformatSettings.push(formatData);\r\n\t\t\t\t}\r\n\t\t\t\tif (\r\n\t\t\t\t\tel.dataType === \"multiple\" &&\r\n\t\t\t\t\t(!el.format ||\r\n\t\t\t\t\t\t(el.format &&\r\n\t\t\t\t\t\t\tel.format.length &&\r\n\t\t\t\t\t\t\t!el.format[0].formatChecked))\r\n\t\t\t\t) {\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: this.dashboardPorletsService.formatMultiple(\r\n\t\t\t\t\t\t\tel.dp\r\n\t\t\t\t\t\t),\r\n\t\t\t\t\t};\r\n\t\t\t\t\tformatSettings.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\tswitch (format_) {\r\n\t\t\t\t\t\t\t\tcase \"DD/MM/YYYY\":\r\n\t\t\t\t\t\t\t\t\tformat = \"dd/MM/yyyy\";\r\n\t\t\t\t\t\t\t\t\tbreak;\r\n\t\t\t\t\t\t\t\tcase \"DD/MM/YY\":\r\n\t\t\t\t\t\t\t\t\tformat = \"dd/MM/yy\";\r\n\t\t\t\t\t\t\t\t\tbreak;\r\n\t\t\t\t\t\t\t\tcase \"MM/DD/YYYY\":\r\n\t\t\t\t\t\t\t\t\tformat = \"MM/dd/yyyy\";\r\n\t\t\t\t\t\t\t\t\tbreak;\r\n\t\t\t\t\t\t\t\tcase \"MM/DD/YY\":\r\n\t\t\t\t\t\t\t\t\tformat = \"MM/dd/yy\";\r\n\t\t\t\t\t\t\t\t\tbreak;\r\n\t\t\t\t\t\t\t\tcase \"YYYY-MM-DD\":\r\n\t\t\t\t\t\t\t\t\tformat = \"yyyy-MM-dd\";\r\n\t\t\t\t\t\t\t\t\tbreak;\r\n\t\t\t\t\t\t\t\tcase \"YY-MM-DD\":\r\n\t\t\t\t\t\t\t\t\tformat = \"yy-MM-dd\";\r\n\t\t\t\t\t\t\t\t\tbreak;\r\n\t\t\t\t\t\t\t\tcase \"DD-MM-YYYY\":\r\n\t\t\t\t\t\t\t\t\tformat = \"dd-MM-yyyy\";\r\n\t\t\t\t\t\t\t\t\tbreak;\r\n\t\t\t\t\t\t\t\tcase \"DD-MM-YY\":\r\n\t\t\t\t\t\t\t\t\tformat = \"dd-MM-yy\";\r\n\t\t\t\t\t\t\t\t\tbreak;\r\n\t\t\t\t\t\t\t\tcase \"MM-DD-YYYY\":\r\n\t\t\t\t\t\t\t\t\tformat = \"MM-dd-yyyy\";\r\n\t\t\t\t\t\t\t\t\tbreak;\r\n\t\t\t\t\t\t\t\tcase \"MM-DD-YY\":\r\n\t\t\t\t\t\t\t\t\tformat = \"MM-dd-yy\";\r\n\t\t\t\t\t\t\t\t\tbreak;\r\n\t\t\t\t\t\t\t\tcase \"MMM DD, YYYY\":\r\n\t\t\t\t\t\t\t\t\tformat = \"MMM dd, yyyy\";\r\n\t\t\t\t\t\t\t\t\tbreak;\r\n\t\t\t\t\t\t\t\tcase \"DD-MMM-YYYY\":\r\n\t\t\t\t\t\t\t\t\tformat = \"dd-MMM-yyyy\";\r\n\t\t\t\t\t\t\t\t\tbreak;\r\n\t\t\t\t\t\t\t\tdefault:\r\n\t\t\t\t\t\t\t\t\tbreak;\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\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\tformatSettings.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\r\n\t\t\t\t\t\tformatSettings.push(formatData);\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t});\r\n\t\t}\r\n\t\t//calculatedFieldSettings format push to formatSettings\r\n\t\tif (\r\n\t\t\tthis.config.calculatedFieldSettings &&\r\n\t\t\tthis.config.calculatedFieldSettings.length > 0\r\n\t\t) {\r\n\t\t\tthis.config.calculatedFieldSettings.map((el) => {\r\n\t\t\t\tif (el.formatString !== \"\") {\r\n\t\t\t\t\tfor (let i = formatSettings.length - 1; i >= 0; i--) {\r\n\t\t\t\t\t\tif (formatSettings[i].name === el.name) {\r\n\t\t\t\t\t\t\tformatSettings.splice(i, 1);\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}\r\n\t\t\t\t\tformatSettings.push({\r\n\t\t\t\t\t\tname: el.name,\r\n\t\t\t\t\t\tformat: el.formatString,\r\n\t\t\t\t\t});\r\n\t\t\t\t}\r\n\t\t\t});\r\n\t\t}\r\n\t\tlet series = this.config.yaxis.series;\r\n\t\tif (series) {\r\n\t\t\tfor (let item of series) {\r\n\t\t\t\tconst value = {\r\n\t\t\t\t\tname: item.colName,\r\n\t\t\t\t\tcaption: this.getCaptionByName(item.colName) || item.title,\r\n\t\t\t\t\ttype: item.calMethod,\r\n\t\t\t\t};\r\n\t\t\t\tvalues.push(value);\r\n\t\t\t}\r\n\t\t}\r\n\t\tlet groups = this.config.xaxis.groups;\r\n\t\tif (groups) {\r\n\t\t\tfor (let gitem of groups) {\r\n\t\t\t\tconst field = this.configFields.filter(\r\n\t\t\t\t\t(el) => el.colName === gitem.name\r\n\t\t\t\t);\r\n\t\t\t\tif (field.length > 0) {\r\n\t\t\t\t\tgitem.showSubTotals = field[0].showSubTotals;\r\n\t\t\t\t\tgitem.caption =\r\n\t\t\t\t\t\tfield[0].langValue ||\r\n\t\t\t\t\t\tthis.translation[field[0].langCode] ||\r\n\t\t\t\t\t\tgitem.caption ||\r\n\t\t\t\t\t\tfield[0].langCode;\r\n\t\t\t\t}\r\n\t\t\t\trows.push(gitem);\r\n\t\t\t}\r\n\t\t}\r\n\t\tif (this.config.columnGroup && this.config.columnGroup.length) {\r\n\t\t\tfor (let item of this.config.columnGroup) {\r\n\t\t\t\tconst field = this.configFields.filter(\r\n\t\t\t\t\t(el) => el.colName === item.name\r\n\t\t\t\t);\r\n\t\t\t\tif (field.length > 0) {\r\n\t\t\t\t\titem.showSubTotals = field[0].showSubTotals;\r\n\t\t\t\t\titem.caption =\r\n\t\t\t\t\t\tfield[0].langValue ||\r\n\t\t\t\t\t\tthis.translation[field[0].langCode] ||\r\n\t\t\t\t\t\tfield[0].langCode ||\r\n\t\t\t\t\t\titem.caption;\r\n\t\t\t\t}\r\n\t\t\t\tcolumns.push(item);\r\n\t\t\t}\r\n\t\t}\r\n\t\tlet conditionalFormatSettings = [];\r\n\t\tthis.configFields.forEach((field) => {\r\n\t\t\tif (field.format && field.format.length) {\r\n\t\t\t\tif (field.format[0].fontSettingChecked) {\r\n\t\t\t\t\tlet conditionalFormatObj = {\r\n\t\t\t\t\t\tapplyGrandTotals: true,\r\n\t\t\t\t\t\tmeasure: \"\",\r\n\t\t\t\t\t\tvalue1: null,\r\n\t\t\t\t\t\tvalue2: null,\r\n\t\t\t\t\t\tconditions: \"\",\r\n\t\t\t\t\t\tstyle: {\r\n\t\t\t\t\t\t\tbackgroundColor: \"\",\r\n\t\t\t\t\t\t\tcolor: \"\",\r\n\t\t\t\t\t\t\tfontFamily: \"\",\r\n\t\t\t\t\t\t\tfontSize: \"\",\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t};\r\n\t\t\t\t\tlet negaConditionalFormatObj = {\r\n\t\t\t\t\t\tapplyGrandTotals: true,\r\n\t\t\t\t\t\tmeasure: \"\",\r\n\t\t\t\t\t\tvalue1: null,\r\n\t\t\t\t\t\tvalue2: null,\r\n\t\t\t\t\t\tconditions: \"\",\r\n\t\t\t\t\t\tstyle: {\r\n\t\t\t\t\t\t\tbackgroundColor: \"\",\r\n\t\t\t\t\t\t\tcolor: \"\",\r\n\t\t\t\t\t\t\tfontFamily: \"\",\r\n\t\t\t\t\t\t\tfontSize: \"\",\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t};\r\n\t\t\t\t\t// font setting start\r\n\t\t\t\t\tnegaConditionalFormatObj.measure =\r\n\t\t\t\t\t\tfield.format[0].selectedField;\r\n\t\t\t\t\tconditionalFormatObj.measure =\r\n\t\t\t\t\t\tfield.format[0].selectedField;\r\n\r\n\t\t\t\t\tif (\r\n\t\t\t\t\t\tfield.format[0].formatChecked &&\r\n\t\t\t\t\t\tfield.format[0].compareSelect\r\n\t\t\t\t\t) {\r\n\t\t\t\t\t\tthis.setCompareConditional(\r\n\t\t\t\t\t\t\tnegaConditionalFormatObj,\r\n\t\t\t\t\t\t\tconditionalFormatObj,\r\n\t\t\t\t\t\t\tfield.format[0]\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\t} else {\r\n\t\t\t\t\t\tdelete conditionalFormatObj.value2;\r\n\t\t\t\t\t\tdelete negaConditionalFormatObj.value2;\r\n\t\t\t\t\t\tnegaConditionalFormatObj.value1 = 0;\r\n\t\t\t\t\t\tnegaConditionalFormatObj.conditions = \"LessThan\";\r\n\t\t\t\t\t\tconditionalFormatObj.value1 = 0;\r\n\t\t\t\t\t\tconditionalFormatObj.conditions = \"GreaterThan\";\r\n\t\t\t\t\t\tthis.setFontSettingConditional(\r\n\t\t\t\t\t\t\tnegaConditionalFormatObj,\r\n\t\t\t\t\t\t\tfield.format[0],\r\n\t\t\t\t\t\t\t-1\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\t\tthis.setFontSettingConditional(\r\n\t\t\t\t\t\t\tconditionalFormatObj,\r\n\t\t\t\t\t\t\tfield.format[0],\r\n\t\t\t\t\t\t\t1\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\t}\r\n\t\t\t\t\tconditionalFormatSettings.push(negaConditionalFormatObj);\r\n\t\t\t\t\tconditionalFormatSettings.unshift(conditionalFormatObj);\r\n\t\t\t\t\t// font setting end\r\n\t\t\t\t}\r\n\t\t\t\tlet formatSettingsObj = {\r\n\t\t\t\t\tname: \"\",\r\n\t\t\t\t\tformat: \"\",\r\n\t\t\t\t};\r\n\t\t\t\tif (field.format[0].formatChecked) {\r\n\t\t\t\t\tformatSettingsObj.name = field.format[0].selectedField;\r\n\t\t\t\t\tformatSettingsObj.format =\r\n\t\t\t\t\t\tthis.dashboardPorletsService.pivotTableformatNumber(\r\n\t\t\t\t\t\t\tfield.format[0].selectedFormat\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\tswitch (field.format[0].dataType) {\r\n\t\t\t\t\t\tcase \"number\":\r\n\t\t\t\t\t\t\tformatSettingsObj.format =\r\n\t\t\t\t\t\t\t\tthis.dashboardPorletsService.pivotTableformatNumber(\r\n\t\t\t\t\t\t\t\t\tfield.format[0].selectedFormat\r\n\t\t\t\t\t\t\t\t);\r\n\t\t\t\t\t\t\tbreak;\r\n\t\t\t\t\t\tcase \"integer\":\r\n\t\t\t\t\t\t\tformatSettingsObj.format =\r\n\t\t\t\t\t\t\t\tthis.dashboardPorletsService.pivotTableformatInteger(\r\n\t\t\t\t\t\t\t\t\tfield.format[0].selectedFormat\r\n\t\t\t\t\t\t\t\t);\r\n\t\t\t\t\t\t\tbreak;\r\n\t\t\t\t\t\tcase \"percentNum\":\r\n\t\t\t\t\t\tcase \"percent\":\r\n\t\t\t\t\t\t\tformatSettingsObj.format =\r\n\t\t\t\t\t\t\t\tthis.dashboardPorletsService.pivotTableformatPercent(\r\n\t\t\t\t\t\t\t\t\tfield.format[0].selectedFormat\r\n\t\t\t\t\t\t\t\t);\r\n\t\t\t\t\t\t\tbreak;\r\n\t\t\t\t\t\tcase \"multiple\":\r\n\t\t\t\t\t\t\tformatSettingsObj.format =\r\n\t\t\t\t\t\t\t\tthis.dashboardPorletsService.pivotTableformatMultiple(\r\n\t\t\t\t\t\t\t\t\tfield.format[0].selectedFormat\r\n\t\t\t\t\t\t\t\t);\r\n\t\t\t\t\t\t\tbreak;\r\n\t\t\t\t\t\tcase \"date\":\r\n\t\t\t\t\t\tcase \"datetime\":\r\n\t\t\t\t\t\t\tlet format = \"\";\r\n\t\t\t\t\t\t\tif (field.format && field.format.length) {\r\n\t\t\t\t\t\t\t\tif (field.format[0].dateType == \"Quarter\") {\r\n\t\t\t\t\t\t\t\t\tformat =\r\n\t\t\t\t\t\t\t\t\t\tfield.format[0].selectedFormatDisplay;\r\n\t\t\t\t\t\t\t\t} else if (field.format[0].dateType == \"Date\") {\r\n\t\t\t\t\t\t\t\t\tlet fromIdx =\r\n\t\t\t\t\t\t\t\t\t\tfield.format[0].selectedFormatDisplay.indexOf(\r\n\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\tlet toIdx =\r\n\t\t\t\t\t\t\t\t\t\tfield.format[0].selectedFormatDisplay.indexOf(\r\n\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\tformat =\r\n\t\t\t\t\t\t\t\t\t\tfield.format[0].selectedFormatDisplay.slice(\r\n\t\t\t\t\t\t\t\t\t\t\tfromIdx + 1,\r\n\t\t\t\t\t\t\t\t\t\t\ttoIdx\r\n\t\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\tif (format) {\r\n\t\t\t\t\t\t\t\tformatSettingsObj = {\r\n\t\t\t\t\t\t\t\t\tname: field.colName,\r\n\t\t\t\t\t\t\t\t\tformat: \"\",\r\n\t\t\t\t\t\t\t\t};\r\n\t\t\t\t\t\t\t\t// field.dataType = \"string\";\r\n\t\t\t\t\t\t\t} else {\r\n\t\t\t\t\t\t\t\tformatSettingsObj.format = this.datePipeFormat;\r\n\t\t\t\t\t\t\t\tformatSettingsObj[\"type\"] = \"date\";\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\tbreak;\r\n\t\t\t\t\t\tdefault:\r\n\t\t\t\t\t\t\tbreak;\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t\tif (\r\n\t\t\t\t\tfield.format[0].dataType !== \"string\" &&\r\n\t\t\t\t\tformatSettingsObj.format\r\n\t\t\t\t) {\r\n\t\t\t\t\tformatSettings.push(formatSettingsObj);\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t});\r\n\t\tthis.customCalculatedFields = this.config.customCalculatedFields\r\n\t\t\t? this.config.customCalculatedFields\r\n\t\t\t: [];\r\n\r\n\t\t// SMP2-4582 AGIC - Dashboard item sequence\r\n\t\tlet isExistSeq = false;\r\n\t\tlet sortSettings = this.config.sortSettings || [];\r\n\t\tif (\r\n\t\t\tthis.Pivot_Data &&\r\n\t\t\tthis.Pivot_Data[0] &&\r\n\t\t\tthis.Pivot_Data[0].Seq !== null\r\n\t\t) {\r\n\t\t\t// 取消Name的默认排序，根据Seq来排序\r\n\t\t\tsortSettings.push({ name: \"Name\", order: \"None\" });\r\n\t\t\tisExistSeq = true;\r\n\t\t}\r\n\t\tlet filterSettings = this.dashboardPorletsService.checkFilterSettings(\r\n\t\t\tthis.config,\r\n\t\t\tthis.configFields,\r\n\t\t\tthis.Pivot_Data\r\n\t\t);\r\n\t\tlet nameFilter = filterSettings.find((x) => x.name === \"Name\");\r\n\t\t// 存在 Name的filter时，会按照默认排序，需要对Name进行Seq排序处理\r\n\t\tif (isExistSeq && nameFilter && rows.some((x) => x.name === \"Name\")) {\r\n\t\t\tlet items = nameFilter.items; // 拿到当前排序，默认A-Z\r\n\t\t\tlet seqArr = [];\r\n\t\t\titems.forEach((name) => {\r\n\t\t\t\tlet obj = this.Pivot_Data.find((x) => x.Name === name);\r\n\t\t\t\tlet item: any = {\r\n\t\t\t\t\tname: name,\r\n\t\t\t\t\tseq: obj.Seq,\r\n\t\t\t\t};\r\n\t\t\t\tseqArr.push(item);\r\n\t\t\t});\r\n\t\t\tseqArr.sort((a, b) => a.seq - b.seq);\r\n\t\t\tnameFilter.items = seqArr.map((x) => x.name);\r\n\t\t}\r\n\r\n\t\tconst allFields =\r\n\t\t\tthis.dashboardPorletsService.allFieldsObj[this.portlet.id];\r\n\t\tif (allFields) {\r\n\t\t\tvalues.forEach((value) => {\r\n\t\t\t\tconst item = allFields.find(\r\n\t\t\t\t\t(field) => field.colName === value.name\r\n\t\t\t\t);\r\n\t\t\t\tif (item) {\r\n\t\t\t\t\tvalue.caption =\r\n\t\t\t\t\t\t(item.format &&\r\n\t\t\t\t\t\t\titem.format.length &&\r\n\t\t\t\t\t\t\titem.format[0].displayName) ||\r\n\t\t\t\t\t\titem.langValue ||\r\n\t\t\t\t\t\tthis.translation[item.langCode] ||\r\n\t\t\t\t\t\titem.langCode;\r\n\t\t\t\t}\r\n\t\t\t});\r\n\t\t}\r\n\t\tlet hasItemDataType = false;\r\n\t\tif (this.Pivot_Data) {\r\n\t\t\tthis.Pivot_Data.map((data) => {\r\n\t\t\t\tif (data[\"AccountTypeCode\"]) {\r\n\t\t\t\t\thasItemDataType = true;\r\n\t\t\t\t}\r\n\t\t\t\trows.forEach((row) => {\r\n\t\t\t\t\tif (data[row.name] === \"\") {\r\n\t\t\t\t\t\tdata[row.name] = \"null\";\r\n\t\t\t\t\t}\r\n\t\t\t\t});\r\n\t\t\t});\r\n\t\t}\r\n\t\tif (hasItemDataType) {\r\n\t\t\tsortSettings.push({\r\n\t\t\t\tname: \"AccountTypeCode\",\r\n\t\t\t\torder: \"Ascending\",\r\n\t\t\t\tmembersOrder: [...this.itemDataTypeSortArr],\r\n\t\t\t});\r\n\t\t}\r\n\t\tthis.config.filters.forEach((filter) => {\r\n\t\t\tfilter.caption =\r\n\t\t\t\tthis.getCaptionByName(filter.name) || filter.caption;\r\n\t\t});\r\n\t\tthis.dataSourceSettings = {\r\n\t\t\tdataSource: this.Pivot_Data || [],\r\n\t\t\trows: rows || [],\r\n\t\t\tcolumns: columns || [],\r\n\t\t\tvalues: values || [],\r\n\t\t\tfilters: this.config.filters,\r\n\t\t\tfilterSettings: filterSettings,\r\n\t\t\texcludeFields: this.excludeFields,\r\n\t\t\tformatSettings: formatSettings,\r\n\t\t\tconditionalFormatSettings: conditionalFormatSettings,\r\n\t\t\t// 用于收起展开指定层级, 这玩意只能展开第一层,\r\n\t\t\t// 必须设定expandAll 为false（默认是false）， 这样子才能实现只展开两层\r\n\t\t\t// drilledMembers,\r\n\t\t\texpandAll: true,\r\n\t\t\tenableSorting: true,\r\n\t\t\tfieldMapping: fieldMapping,\r\n\t\t\tcalculatedFieldSettings: this.config.calculatedFieldSettings,\r\n\t\t\tsortSettings: sortSettings,\r\n\t\t\t// groupSettings: this.config.groupSettings,\r\n\t\t\tvalueSortSettings: this.config.valueSortSettings,\r\n\t\t\tshowGrandTotals: this.config.showGrandTotals,\r\n\t\t\tshowRowGrandTotals: this.config.showRowGrandTotals,\r\n\t\t\tshowColumnGrandTotals: this.config.showColumnGrandTotals,\r\n\t\t\tshowSubTotals: this.config.showSubTotals,\r\n\t\t\tshowRowSubTotals: this.config.showRowSubTotals,\r\n\t\t\tshowColumnSubTotals: this.config.showColumnSubTotals,\r\n\t\t};\r\n\t\tconsole.log(\"this.dataSourceSettings\", this.dataSourceSettings);\r\n\r\n\t\tthis.ref.markForCheck();\r\n\t}\r\n\r\n\tgetCaptionByName(nameString) {\r\n\t\tif (!nameString) return \"\";\r\n\t\tconst field = this.configFields.find((el) => el.colName === nameString);\r\n\r\n\t\treturn field\r\n\t\t\t? field.langValue ||\r\n\t\t\t\t\tthis.translation[field && field.langCode] ||\r\n\t\t\t\t\tfield.langCode\r\n\t\t\t: \"\";\r\n\t}\r\n\r\n\tpublic afterPopulate(args: EnginePopulatedEventArgs): void {\r\n\t\tthis.tempSubtotals = [];\r\n\t\tthis.grandTotals = {};\r\n\t\tthis.subTotals = {};\r\n\t\tlet tempshowArray = [];\r\n\t\tthis.config.yaxis.series.forEach((item) => {\r\n\t\t\tif (\r\n\t\t\t\titem.hasOwnProperty(\"showSubTotals\") &&\r\n\t\t\t\titem.hasOwnProperty(\"showGrandTotals\")\r\n\t\t\t) {\r\n\t\t\t\ttempshowArray.push({\r\n\t\t\t\t\tname: item.colName,\r\n\t\t\t\t\tcalMethod: item.calMethod,\r\n\t\t\t\t\tshowSubTotals: item.showSubTotals,\r\n\t\t\t\t\tshowGrandTotals: item.showGrandTotals,\r\n\t\t\t\t});\r\n\t\t\t} else {\r\n\t\t\t\tif (item.hasOwnProperty(\"showGrandTotals\")) {\r\n\t\t\t\t\ttempshowArray.push({\r\n\t\t\t\t\t\tname: item.colName,\r\n\t\t\t\t\t\tcalMethod: item.calMethod,\r\n\t\t\t\t\t\tshowGrandTotals: item.showGrandTotals,\r\n\t\t\t\t\t});\r\n\t\t\t\t}\r\n\t\t\t\tif (item.hasOwnProperty(\"showSubTotals\")) {\r\n\t\t\t\t\ttempshowArray.push({\r\n\t\t\t\t\t\tname: item.colName,\r\n\t\t\t\t\t\tcalMethod: item.calMethod,\r\n\t\t\t\t\t\tshowSubTotals: item.showSubTotals,\r\n\t\t\t\t\t});\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t});\r\n\r\n\t\tif (this.fieldlistObj && this.pivotObj) {\r\n\t\t\tthis.config.columnGroup = [];\r\n\t\t\tthis.config.xaxis.groups = [];\r\n\t\t\tthis.config.yaxis.series = [];\r\n\t\t\tthis.config.filters = [];\r\n\t\t\tthis.config.filterSettings = [];\r\n\t\t\tthis.config.calculatedFieldSettings = [];\r\n\t\t\tlet groupSettings = this.getDataSourceSettingsProp(\r\n\t\t\t\tthis.fieldlistObj,\r\n\t\t\t\t\"groupSettings\"\r\n\t\t\t);\r\n\t\t\tlet columns = this.getDataSourceSettingsProp(\r\n\t\t\t\tthis.fieldlistObj,\r\n\t\t\t\t\"columns\"\r\n\t\t\t);\r\n\t\t\tlet rows = this.getDataSourceSettingsProp(\r\n\t\t\t\tthis.fieldlistObj,\r\n\t\t\t\t\"rows\"\r\n\t\t\t);\r\n\t\t\tlet filters = this.getDataSourceSettingsProp(\r\n\t\t\t\tthis.fieldlistObj,\r\n\t\t\t\t\"filters\"\r\n\t\t\t);\r\n\t\t\tlet filterSettings = this.getDataSourceSettingsProp(\r\n\t\t\t\tthis.fieldlistObj,\r\n\t\t\t\t\"filterSettings\"\r\n\t\t\t);\r\n\t\t\tlet values = this.getDataSourceSettingsProp(\r\n\t\t\t\tthis.fieldlistObj,\r\n\t\t\t\t\"values\"\r\n\t\t\t);\r\n\t\t\tlet sortSettings = this.getDataSourceSettingsProp(\r\n\t\t\t\tthis.fieldlistObj,\r\n\t\t\t\t\"sortSettings\"\r\n\t\t\t);\r\n\t\t\tlet calculatedFieldSettings = this.getDataSourceSettingsProp(\r\n\t\t\t\tthis.fieldlistObj,\r\n\t\t\t\t\"calculatedFieldSettings\"\r\n\t\t\t);\r\n\t\t\tif (groupSettings.length === 0) {\r\n\t\t\t\tfor (let column of columns) {\r\n\t\t\t\t\tthis.config.columnGroup.push({\r\n\t\t\t\t\t\tname: column.name,\r\n\t\t\t\t\t\tcaption:\r\n\t\t\t\t\t\t\tthis.getCaptionByName(column.name) ||\r\n\t\t\t\t\t\t\tcolumn.caption,\r\n\t\t\t\t\t});\r\n\t\t\t\t}\r\n\t\t\t} else {\r\n\t\t\t\t//If there is a group, first filter the columns of the group field, and then only save the last one\r\n\t\t\t\tfor (let column of columns) {\r\n\t\t\t\t\tif (!startsWith(column.name, groupSettings[0].name + \"_\")) {\r\n\t\t\t\t\t\tthis.config.columnGroup.push({\r\n\t\t\t\t\t\t\tname: column.name,\r\n\t\t\t\t\t\t\tcaption:\r\n\t\t\t\t\t\t\t\tcolumn.name === groupSettings[0].name\r\n\t\t\t\t\t\t\t\t\t? \"\"\r\n\t\t\t\t\t\t\t\t\t: this.getCaptionByName(column.name) ||\r\n\t\t\t\t\t\t\t\t\t  column.caption,\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\t}\r\n\t\t\tfor (let row of rows) {\r\n\t\t\t\tthis.config.xaxis.groups.push({\r\n\t\t\t\t\tname: row.name,\r\n\t\t\t\t\tcaption: this.getCaptionByName(row.name) || row.caption,\r\n\t\t\t\t});\r\n\t\t\t}\r\n\t\t\tfor (let filter of filters) {\r\n\t\t\t\tthis.config.filters.push({\r\n\t\t\t\t\tname: filter.name,\r\n\t\t\t\t\tcaption:\r\n\t\t\t\t\t\tthis.getCaptionByName(filter.name) || filter.caption,\r\n\t\t\t\t});\r\n\t\t\t}\r\n\t\t\tif (this.filterSettings && this.filterSettings.length > 0) {\r\n\t\t\t\targs.dataSourceSettings.filterSettings = this.filterSettings;\r\n\t\t\t\tthis.config.filterSettings = this.filterSettings;\r\n\t\t\t\tdelete this.filterSettings;\r\n\t\t\t} else {\r\n\t\t\t\tthis.config.filterSettings = filterSettings;\r\n\t\t\t}\r\n\t\t\tfor (let value of values) {\r\n\t\t\t\tlet seriesData;\r\n\t\t\t\tlet tempShowObj;\r\n\t\t\t\tlet filterTempshowArray = [];\r\n\t\t\t\tif (tempshowArray.length) {\r\n\t\t\t\t\tfilterTempshowArray = tempshowArray.filter(\r\n\t\t\t\t\t\t(item) =>\r\n\t\t\t\t\t\t\titem.name === value.name &&\r\n\t\t\t\t\t\t\titem.calMethod === value.type\r\n\t\t\t\t\t);\r\n\t\t\t\t\tif (filterTempshowArray.length) {\r\n\t\t\t\t\t\ttempShowObj = filterTempshowArray[0];\r\n\t\t\t\t\t\tif (\r\n\t\t\t\t\t\t\ttempShowObj.hasOwnProperty(\"showSubTotals\") &&\r\n\t\t\t\t\t\t\ttempShowObj.hasOwnProperty(\"showGrandTotals\")\r\n\t\t\t\t\t\t) {\r\n\t\t\t\t\t\t\tseriesData = {\r\n\t\t\t\t\t\t\t\tcolName: value.name,\r\n\t\t\t\t\t\t\t\tcalMethod: value.type,\r\n\t\t\t\t\t\t\t\ttitle: value.caption,\r\n\t\t\t\t\t\t\t\tshowSubTotals: tempShowObj.showSubTotals,\r\n\t\t\t\t\t\t\t\tshowGrandTotals: tempShowObj.showGrandTotals,\r\n\t\t\t\t\t\t\t};\r\n\t\t\t\t\t\t} else {\r\n\t\t\t\t\t\t\tif (tempShowObj.hasOwnProperty(\"showGrandTotals\")) {\r\n\t\t\t\t\t\t\t\tseriesData = {\r\n\t\t\t\t\t\t\t\t\tcolName: value.name,\r\n\t\t\t\t\t\t\t\t\tcalMethod: value.type,\r\n\t\t\t\t\t\t\t\t\ttitle: value.caption,\r\n\t\t\t\t\t\t\t\t\tshowGrandTotals:\r\n\t\t\t\t\t\t\t\t\t\ttempShowObj.showGrandTotals,\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\tif (tempShowObj.hasOwnProperty(\"showSubTotals\")) {\r\n\t\t\t\t\t\t\t\tseriesData = {\r\n\t\t\t\t\t\t\t\t\tcolName: value.name,\r\n\t\t\t\t\t\t\t\t\tcalMethod: value.type,\r\n\t\t\t\t\t\t\t\t\ttitle: value.caption,\r\n\t\t\t\t\t\t\t\t\tshowSubTotals: tempShowObj.showSubTotals,\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}\r\n\t\t\t\tif (!seriesData) {\r\n\t\t\t\t\tseriesData = {\r\n\t\t\t\t\t\tcolName: value.name,\r\n\t\t\t\t\t\ttitle: value.caption,\r\n\t\t\t\t\t\tcalMethod: value.type,\r\n\t\t\t\t\t};\r\n\t\t\t\t}\r\n\t\t\t\tthis.config.yaxis.series.push(seriesData);\r\n\t\t\t}\r\n\t\t\tfor (let calculate of calculatedFieldSettings) {\r\n\t\t\t\tconst calculateData = {\r\n\t\t\t\t\tname: calculate.name,\r\n\t\t\t\t\tformula: calculate.formula,\r\n\t\t\t\t\tformatString:\r\n\t\t\t\t\t\tcalculate.formatString === \"\"\r\n\t\t\t\t\t\t\t? \"N2\"\r\n\t\t\t\t\t\t\t: calculate.formatString,\r\n\t\t\t\t};\r\n\t\t\t\tthis.config.calculatedFieldSettings.push(calculateData);\r\n\t\t\t}\r\n\t\t\tthis.config.customCalculatedFields = this.customCalculatedFields;\r\n\t\t\tthis.config.sortSettings = sortSettings;\r\n\t\t\tthis.config.groupSettings = groupSettings;\r\n\t\t\tthis.fieldlistObj.updateView(this.pivotObj);\r\n\t\t}\r\n\t\tthis.portlet.config = JSON.stringify(this.config);\r\n\t\t//remove the sort\r\n\t\tif (this.pivotObj.dataSourceSettings.sortSettings.length > 0) {\r\n\t\t\tthis.previousSort = this.fieldlistObj.lastSortInfo;\r\n\t\t\t(this.fieldlistObj as any).lastSortInfo = [];\r\n\t\t}\r\n\t}\r\n\r\n\tpublic afterEnginePopulate(args: any) {\r\n\t\tif (!Browser.isDevice && this.fieldlistObj && this.pivotObj) {\r\n\t\t\tthis.config.groupSettings = this.getDataSourceSettingsProp(\r\n\t\t\t\tthis.pivotObj,\r\n\t\t\t\t\"groupSettings\"\r\n\t\t\t);\r\n\t\t\tthis.portlet.config = JSON.stringify(this.config);\r\n\t\t\tif (this.fieldlistObj) this.fieldlistObj.update(this.pivotObj);\r\n\t\t\tthis.pivotObj.grid.queryCellInfo = this.queryCell.bind(this);\r\n\t\t\tthis.pivotObj.grid.headerCellInfo = this.headerCell.bind(this);\r\n\t\t\t// SMP2-3929 rollback\r\n\t\t\t// if (!this.isApplyIRR)\r\n\t\t\t// \tthis.getCalculationResultByDashboardDataTableId();\r\n\t\t}\r\n\t\tif (this.Pivot_Data && this.Pivot_Data.length) {\r\n\t\t\tsetTimeout(() => {\r\n\t\t\t\tthis.enginePopulated(args);\r\n\t\t\t}, 1500);\r\n\t\t}\r\n\t}\r\n\r\n\tprivate getDataSourceSettingsProp(obj, key) {\r\n\t\tlet prop = null;\r\n\t\tif (obj && obj.dataSourceSettings) {\r\n\t\t\tprop = obj.dataSourceSettings[key];\r\n\t\t\tif (\r\n\t\t\t\tObject.prototype.toString.call(prop) === \"[object Array]\" &&\r\n\t\t\t\tprop.length > 0\r\n\t\t\t) {\r\n\t\t\t\tprop = prop.map((item) => item.properties || item);\r\n\t\t\t}\r\n\t\t}\r\n\t\treturn prop;\r\n\t}\r\n\r\n\tpublic enginePopulating(args) {\r\n\t\tthis.grandTotals = {};\r\n\t\tthis.subTotals = {};\r\n\t\tthis.allDataValue = [];\r\n\t\t// if (args.dataSourceSettings.sortSettings.length) {\r\n\t\t// \tfor (\r\n\t\t// \t\tlet i = 0;\r\n\t\t// \t\ti < args.dataSourceSettings.sortSettings.length;\r\n\t\t// \t\ti++\r\n\t\t// \t) {\r\n\t\t// \t\tif (\r\n\t\t// \t\t\tthis.fieldlistObj.lastSortInfo &&\r\n\t\t// \t\t\tthis.fieldlistObj.lastSortInfo.name ===\r\n\t\t// \t\t\t\targs.dataSourceSettings.sortSettings[i].name &&\r\n\t\t// \t\t\tthis.fieldlistObj.lastSortInfo.order === \"Ascending\" &&\r\n\t\t// \t\t\t!(\r\n\t\t// \t\t\t\tthis.fieldlistObj.lastSortInfo.name ===\r\n\t\t// \t\t\t\t\tthis.previousSort.name &&\r\n\t\t// \t\t\t\tthis.previousSort.order === \"None\"\r\n\t\t// \t\t\t)\r\n\t\t// \t\t) {\r\n\t\t// \t\t\targs.dataSourceSettings.sortSettings[i].order = \"None\";\r\n\t\t// \t\t} else if (\r\n\t\t// \t\t\tthis.previousSort &&\r\n\t\t// \t\t\tthis.fieldlistObj.lastSortInfo &&\r\n\t\t// \t\t\tthis.fieldlistObj.lastSortInfo.name ===\r\n\t\t// \t\t\t\tthis.previousSort.name &&\r\n\t\t// \t\t\tthis.previousSort.order === \"Ascending\"\r\n\t\t// \t\t) {\r\n\t\t// \t\t\targs.dataSourceSettings.sortSettings[i].order = \"Ascending\";\r\n\t\t// \t\t}\r\n\t\t// \t}\r\n\t\t// }\r\n\t}\r\n\r\n\tpublic cellClick(args) {\r\n\t\tif (args.currentCell.classList.contains(\"e-headercell\")) {\r\n\t\t\tthis.flag = true;\r\n\t\t}\r\n\t\t// 清除排序\r\n\t\tif (\r\n\t\t\tthis.pivotObj.dataSourceSettings.valueSortSettings.sortOrder &&\r\n\t\t\tthis.pivotObj.dataSourceSettings.valueSortSettings.headerText &&\r\n\t\t\tthis.pivotObj.dataSourceSettings.valueSortSettings.sortOrder ===\r\n\t\t\t\t\"Descending\" &&\r\n\t\t\targs.data.valueSort &&\r\n\t\t\tthis.pivotObj.dataSourceSettings.valueSortSettings.headerText ===\r\n\t\t\t\targs.data.valueSort.levelName\r\n\t\t) {\r\n\t\t\tthis.pivotObj.setProperties(\r\n\t\t\t\t{\r\n\t\t\t\t\tdataSourceSettings: {\r\n\t\t\t\t\t\tvalueSortSettings: {\r\n\t\t\t\t\t\t\tsortOrder: \"Descending\",\r\n\t\t\t\t\t\t\theaderText: \"\",\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\t\ttrue\r\n\t\t\t);\r\n\t\t\tif (this.pivotObj) this.pivotObj.refreshData();\r\n\t\t\tthis.flag = false;\r\n\t\t\tthis.config.valueSortSettings = {};\r\n\t\t\tthis.portlet.config = JSON.stringify(this.config);\r\n\t\t}\r\n\t}\r\n\r\n\tprivate queryCell(args: any): void {\r\n\t\t(this.pivotObj.renderModule as any).rowCellBoundEvent(args);\r\n\t\tlet rowIndex = Number(args.cell.getAttribute(\"index\"));\r\n\t\t// 新版本26.x中 aria-colindex 会比旧版本v20.x 多1\r\n\t\tlet colIndex = parseInt(args.cell.getAttribute(\"aria-colindex\")) - 1;\r\n\t\tif (\r\n\t\t\t!this.pivotObj.dataSourceSettings.conditionalFormatSettings.length\r\n\t\t) {\r\n\t\t\tif (args.data && args.data[0].formattedText === \"Grand Total\") {\r\n\t\t\t\targs.cell.classList.add(\"grand-class\");\r\n\t\t\t} else {\r\n\t\t\t\targs.cell.classList.add(\r\n\t\t\t\t\trowIndex % 2 ? \"odd-class\" : \"even-class\"\r\n\t\t\t\t);\r\n\t\t\t}\r\n\t\t} else {\r\n\t\t\tlet measureArr =\r\n\t\t\t\tthis.pivotObj.dataSourceSettings.conditionalFormatSettings.map(\r\n\t\t\t\t\t(obj) => {\r\n\t\t\t\t\t\treturn obj.measure;\r\n\t\t\t\t\t}\r\n\t\t\t\t);\r\n\t\t\tif (\r\n\t\t\t\tmeasureArr.includes(args.data[colIndex].actualText) &&\r\n\t\t\t\targs.data[colIndex].style\r\n\t\t\t) {\r\n\t\t\t\targs.cell.style.cssText += `background-color: ${args.data[colIndex].style.backgroundColor} !important`;\r\n\t\t\t}\r\n\t\t\tif (args.data && args.data[0].formattedText === \"Grand Total\")\r\n\t\t\t\targs.cell.classList.add(\"e-customclass\");\r\n\t\t}\r\n\r\n\t\tif (args.data && args.data[0].formattedText === \"Grand Total\") {\r\n\t\t\targs.cell.classList.add(\"grand-class\");\r\n\t\t} else {\r\n\t\t\tif (rowIndex % 2) {\r\n\t\t\t\targs.cell.classList.add(\"odd-class\");\r\n\t\t\t} else {\r\n\t\t\t\targs.cell.classList.add(\"even-class\");\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t//get sorting data\r\n\t\tif (this.flag) {\r\n\t\t\tthis.flag = false;\r\n\t\t\tthis.config.valueSortSettings =\r\n\t\t\t\tthis.pivotObj.dataSourceSettings.valueSortSettings[\r\n\t\t\t\t\t\"properties\"\r\n\t\t\t\t];\r\n\t\t\tthis.portlet.config = JSON.stringify(this.config);\r\n\t\t}\r\n\t\t//customize the header text\r\n\t\tif (this.pivotObj.dataSourceSettings.rows.length === 0) {\r\n\t\t\tif (\r\n\t\t\t\targs.data &&\r\n\t\t\t\targs.data[colIndex] &&\r\n\t\t\t\targs.data[colIndex].axis === \"row\"\r\n\t\t\t) {\r\n\t\t\t\targs.cell.querySelector(\".e-cellvalue\").innerText =\r\n\t\t\t\t\targs.data[colIndex].formattedText;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t// SMP2-2912 subtotal字体加粗\r\n\t\tif (\r\n\t\t\tthis.pivotObj.dataSourceSettings.rows.length &&\r\n\t\t\targs.data[colIndex] &&\r\n\t\t\targs.data[0].level !==\r\n\t\t\t\tthis.pivotObj.dataSourceSettings.rows.length - 1 &&\r\n\t\t\targs.data[colIndex].rowHeaders !== \"\" &&\r\n\t\t\targs.data[colIndex].axis == \"value\"\r\n\t\t) {\r\n\t\t\targs.cell.classList.add(\"e-customclass\");\r\n\t\t}\r\n\t}\r\n\r\n\tprivate headerCell(args: any): void {\r\n\t\t(this.pivotObj.renderModule as any).columnCellBoundEvent(args);\r\n\t\tif (this.pivotObj.dataSourceSettings.columns.length === 0) {\r\n\t\t\tlet node = args.node.querySelector(\r\n\t\t\t\t\".e-headercelldiv .e-headertext\"\r\n\t\t\t);\r\n\t\t\tif (node) node.innerText = args.cell.column.headerText;\r\n\t\t}\r\n\t\tconst textAlign = args.cell.column.textAlign;\r\n\t\targs.cell.column.headerTextAlign = textAlign;\r\n\t\targs.node.style.textAlign = textAlign === \"Right\" ? \"right\" : \"left\"; // Align right for numeric columns\r\n\t\tif (textAlign === \"Right\") {\r\n\t\t\targs.node.classList.add(\"header-align-right\");\r\n\t\t}\r\n\t\tthis.ref.markForCheck();\r\n\t}\r\n\r\n\tpublic dataBound(e) {\r\n\t\tif (this.isInit) {\r\n\t\t\tthis.isInit = false;\r\n\t\t}\r\n\t\tthis.grandTotals = {};\r\n\t\tthis.subTotals = {};\r\n\t\tif (this.pivotObj.grid) {\r\n\t\t\tthis.pivotObj.grid.resizeStop = this.resizeStop.bind(this);\r\n\t\t}\r\n\t\tif (this.pivotObj) {\r\n\t\t\tvar index = [];\r\n\t\t\t// Get the empty row headers here.\r\n\t\t\tvar emptyRowHeader: any = document.querySelectorAll(\r\n\t\t\t\t'td[aria-label=\" column header \"]'\r\n\t\t\t);\r\n\t\t\tfor (var ele of emptyRowHeader) {\r\n\t\t\t\tif (ele) {\r\n\t\t\t\t\tindex.push(ele.getAttribute(\"index\"));\r\n\t\t\t\t\t// Remove all the empty row headers here.\r\n\t\t\t\t\tele.closest(\"tr\").remove();\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\tfor (var i = 0; i < index.length; i++) {\r\n\t\t\t\t// Get the empty values here.\r\n\t\t\t\tvar emptyValues = this.pivotObj.element.querySelectorAll(\r\n\t\t\t\t\t`td[index=\"${index[i]}\"]`\r\n\t\t\t\t);\r\n\t\t\t\tif (emptyValues[0]) {\r\n\t\t\t\t\t// Remove all the empty value rows here.\r\n\t\t\t\t\temptyValues[0].closest(\"tr\").remove();\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t\tif (\r\n\t\t\tthis.fieldlistObj &&\r\n\t\t\tthis.fieldlistObj.pivotButtonModule &&\r\n\t\t\tthis.fieldlistObj.pivotButtonModule.menuOption\r\n\t\t) {\r\n\t\t\t(\r\n\t\t\t\tthis.fieldlistObj.pivotButtonModule.menuOption as any\r\n\t\t\t).stringAggregateTypes = [\r\n\t\t\t\t\"Count\",\r\n\t\t\t\t\"DistinctCount\",\r\n\t\t\t\t\"First\",\r\n\t\t\t\t\"Last\",\r\n\t\t\t];\r\n\t\t}\r\n\t\tif (\r\n\t\t\tthis.pivotObj.pivotButtonModule &&\r\n\t\t\tthis.pivotObj.pivotButtonModule.menuOption\r\n\t\t) {\r\n\t\t\t(\r\n\t\t\t\tthis.pivotObj.pivotButtonModule.menuOption as any\r\n\t\t\t).stringAggregateTypes = [\r\n\t\t\t\t\"Count\",\r\n\t\t\t\t\"DistinctCount\",\r\n\t\t\t\t\"First\",\r\n\t\t\t\t\"Last\",\r\n\t\t\t];\r\n\t\t}\r\n\t\tlet allSummaryType = ALL_AGGREGATE_TYPES as any;\r\n\t\tthis.pivotObj.getAllSummaryType = function () {\r\n\t\t\treturn allSummaryType;\r\n\t\t};\r\n\t\tif (this.fieldlistObj) {\r\n\t\t\tthis.fieldlistObj.aggregateTypes = allSummaryType;\r\n\t\t\tthis.fieldlistObj.getAllSummaryType = function () {\r\n\t\t\t\treturn allSummaryType;\r\n\t\t\t};\r\n\t\t}\r\n\t\tthis.setValueItemData();\r\n\t}\r\n\r\n\tprivate setValueItemData() {\r\n\t\tsetTimeout(() => {\r\n\t\t\tconst fieldDom = this.fieldlistObj.fieldListSpinnerElement;\r\n\t\t\tthis.dataSourceSettings.values.forEach((value: any) => {\r\n\t\t\t\tif (value.type !== \"First\" && value.type !== \"Last\") {\r\n\t\t\t\t\treturn;\r\n\t\t\t\t}\r\n\t\t\t\tconst valuesDom = fieldDom.querySelector(\r\n\t\t\t\t\t`.e-values .${value.name} .e-pvt-btn-content`\r\n\t\t\t\t);\r\n\t\t\t\tif (\r\n\t\t\t\t\tvaluesDom.innerHTML !== `${value.type} of ${value.caption}`\r\n\t\t\t\t) {\r\n\t\t\t\t\tvaluesDom.innerHTML = `${value.type} of ${value.caption}`;\r\n\t\t\t\t}\r\n\t\t\t});\r\n\t\t});\r\n\t}\r\n\r\n\tprivate calculatedCellSets(args, curFields) {\r\n\t\tlet matchFields = curFields[\"matchFields\"];\r\n\t\tlet formula = curFields[\"formula\"];\r\n\t\tlet value = 0;\r\n\t\tlet rows = this.pivotObj.dataSourceSettings.rows;\r\n\t\tlet invalidTypes = [\"string\", \"nvarchar\", \"date\", \"datetime\"];\r\n\t\tlet isInvalid = matchFields.some((f) =>\r\n\t\t\tinvalidTypes.includes(\r\n\t\t\t\tthis.configFields.filter((el) => el.colName === f.matchWord)[0][\r\n\t\t\t\t\t\"dataType\"\r\n\t\t\t\t]\r\n\t\t\t)\r\n\t\t);\r\n\t\tlet currentrowCellType = args.rowCellType;\r\n\t\tif (isInvalid) return \"-\";\r\n\t\tif (\r\n\t\t\targs.rowCellType === \"subTotal\" ||\r\n\t\t\targs.rowCellType === \"grandTotal\"\r\n\t\t) {\r\n\t\t\tlet childHeaders = [];\r\n\t\t\tlet sum = 0;\r\n\t\t\tlet cloneCellSets = cloneDeep(args.cellSets);\r\n\t\t\tlet groupNameArrays = [];\r\n\t\t\tfor (let index = args.row.level; index < rows.length; index++) {\r\n\t\t\t\tgroupNameArrays.push(rows[index].name);\r\n\t\t\t}\r\n\t\t\tfor (let i = 0; i < cloneCellSets.length; i++) {\r\n\t\t\t\tlet values = [];\r\n\t\t\t\tlet header = groupNameArrays\r\n\t\t\t\t\t.map((name) => {\r\n\t\t\t\t\t\tvalues.push(cloneCellSets[i][name]);\r\n\t\t\t\t\t\treturn cloneCellSets[i][name];\r\n\t\t\t\t\t})\r\n\t\t\t\t\t.join(\"-\");\r\n\t\t\t\tif (!(childHeaders as any).includes(header)) {\r\n\t\t\t\t\tchildHeaders.push(header);\r\n\t\t\t\t\tlet filterObj: any = {};\r\n\t\t\t\t\tgroupNameArrays.map(\r\n\t\t\t\t\t\t(name, i) => (filterObj[name] = values[i])\r\n\t\t\t\t\t);\r\n\t\t\t\t\targs.cellSets = _filter(cloneCellSets, filterObj);\r\n\t\t\t\t\targs.rowCellType = \"value\";\r\n\t\t\t\t\tsum += this.calculatedValues(args, matchFields, formula);\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\targs.rowCellType = currentrowCellType;\r\n\r\n\t\t\t// 暂存当前SubTotal， 用于收缩时读取\r\n\t\t\tlet prefixHeader = this.getCalcHeader(args, formula);\r\n\t\t\tthis.updateTempSubtotals(prefixHeader, sum);\r\n\t\t\treturn sum;\r\n\t\t} else if (args.rowCellType === \"value\") {\r\n\t\t\tif (args.row.hasChild) {\r\n\t\t\t\t// collapse 读取SubTotal\r\n\t\t\t\tlet header = this.getCalcHeader(args, formula);\r\n\t\t\t\tlet index = this.tempSubtotals.findIndex(\r\n\t\t\t\t\t(item) => item.rowName === header\r\n\t\t\t\t);\r\n\t\t\t\tif (index > -1) {\r\n\t\t\t\t\tvalue = this.tempSubtotals[index].rowValue;\r\n\t\t\t\t}\r\n\t\t\t} else {\r\n\t\t\t\t// expand\r\n\t\t\t\tvalue = this.calculatedValues(args, matchFields, formula);\r\n\t\t\t}\r\n\t\t}\r\n\t\treturn value;\r\n\t}\r\n\r\n\tactionFailure(args: PivotActionFailureEventArgs): void {\r\n\t\tif (args.actionName == \"Drill down\" || args.actionName == \"Drill up\") {\r\n\t\t\t// Triggers when the current UI action fails to achieve the desired result.\r\n\t\t}\r\n\t}\r\n\r\n\tprivate getCalcHeader(args, formula?) {\r\n\t\tlet header = \"\";\r\n\t\tlet rows = this.pivotObj.dataSourceSettings.rows;\r\n\t\tlet groupNameArrays = [];\r\n\t\tfor (let index = 0; index < args.row.level; index++) {\r\n\t\t\tgroupNameArrays.push(rows[index].name);\r\n\t\t}\r\n\t\theader = groupNameArrays.length\r\n\t\t\t? groupNameArrays\r\n\t\t\t\t\t.map((name) => {\r\n\t\t\t\t\t\treturn args.cellSets[0][name];\r\n\t\t\t\t\t})\r\n\t\t\t\t\t.join(\"-\") +\r\n\t\t\t  \"-\" +\r\n\t\t\t  args.row.actualText\r\n\t\t\t: args.row.actualText;\r\n\t\tif (formula) header += \"___\" + formula;\r\n\t\treturn header;\r\n\t}\r\n\r\n\tprivate updateTempSubtotals(rowName, rowValue) {\r\n\t\tlet index = this.tempSubtotals.findIndex(\r\n\t\t\t(item) => item.rowName === rowName\r\n\t\t);\r\n\t\tlet temp: any = {};\r\n\t\ttemp.rowName = rowName;\r\n\t\ttemp.rowValue = rowValue;\r\n\t\tif (index > -1) {\r\n\t\t\tthis.tempSubtotals.splice(index, 1, temp);\r\n\t\t} else {\r\n\t\t\tthis.tempSubtotals.push(temp);\r\n\t\t}\r\n\t}\r\n\r\n\tprivate calculatedValues(args, matchFields, formula) {\r\n\t\tif (matchFields.length) {\r\n\t\t\tlet calculedMatchFields = matchFields.map((f) => {\r\n\t\t\t\tswitch (f.matchMethod) {\r\n\t\t\t\t\tcase \"First\":\r\n\t\t\t\t\tcase \"Last\":\r\n\t\t\t\t\t\tf.replaceValue = this.calculatedFistLast(\r\n\t\t\t\t\t\t\targs,\r\n\t\t\t\t\t\t\tf.matchMethod,\r\n\t\t\t\t\t\t\tf.matchWord\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\t\tbreak;\r\n\t\t\t\t\tcase \"Max\":\r\n\t\t\t\t\t\tf.replaceValue = maxBy(args.cellSets, (o) =>\r\n\t\t\t\t\t\t\tNumber(o[f.matchWord])\r\n\t\t\t\t\t\t)[f.matchWord];\r\n\t\t\t\t\t\tbreak;\r\n\t\t\t\t\tcase \"Min\":\r\n\t\t\t\t\t\tf.replaceValue = minBy(args.cellSets, (o) =>\r\n\t\t\t\t\t\t\tNumber(o[f.matchWord])\r\n\t\t\t\t\t\t)[f.matchWord];\r\n\t\t\t\t\t\tbreak;\r\n\t\t\t\t\tcase \"Sum\":\r\n\t\t\t\t\t\tf.replaceValue = sumBy(args.cellSets, (o) =>\r\n\t\t\t\t\t\t\tNumber(o[f.matchWord])\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\t\t// SMP2-4094 Unicorn - L3 Adjusted NAV value issues\r\n\t\t\t\t\t\tf.replaceValue =\r\n\t\t\t\t\t\t\tf.replaceValue && f.replaceValue.toFixed(10);\r\n\t\t\t\t\t\tbreak;\r\n\t\t\t\t\tcase \"Avg\":\r\n\t\t\t\t\t\tf.replaceValue = meanBy(args.cellSets, (o) =>\r\n\t\t\t\t\t\t\tNumber(o[f.matchWord])\r\n\t\t\t\t\t\t);\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\treturn f;\r\n\t\t\t});\r\n\t\t\tlet resultFormula = formula;\r\n\t\t\tif (calculedMatchFields.length) {\r\n\t\t\t\tfor (let i = 0; i < calculedMatchFields.length; i++) {\r\n\t\t\t\t\tresultFormula = resultFormula.replace(\r\n\t\t\t\t\t\tcalculedMatchFields[i].matchStr,\r\n\t\t\t\t\t\t\"(\" + calculedMatchFields[i].replaceValue + \")\"\r\n\t\t\t\t\t);\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\ttry {\r\n\t\t\t\tlet result = new Function(\r\n\t\t\t\t\t\"return \" + resultFormula.replace(/[^-<>?:()\\d/*+.]/g, \"\")\r\n\t\t\t\t)();\r\n\t\t\t\tif (isNaN(result) || !isFinite(result)) {\r\n\t\t\t\t\treturn 0;\r\n\t\t\t\t} else {\r\n\t\t\t\t\treturn result;\r\n\t\t\t\t}\r\n\t\t\t} catch (error) {\r\n\t\t\t\treturn NaN;\r\n\t\t\t}\r\n\t\t}\r\n\t\treturn 0;\r\n\t}\r\n\r\n\ttotalFormatted = {};\r\n\tpublic aggregateCellInfo(args) {\r\n\t\tlet asOfDate = this.pbf.time(this.dashboard.asOfDate);\r\n\t\t// if calculated field\r\n\t\tif (args.aggregateType == \"CalculatedField\") {\r\n\t\t\tfor (let i = 0; i < this.customCalculatedFields.length; i++) {\r\n\t\t\t\tif (args.fieldName == this.customCalculatedFields[i].name) {\r\n\t\t\t\t\targs.value = this.calculatedCellSets(\r\n\t\t\t\t\t\targs,\r\n\t\t\t\t\t\tthis.customCalculatedFields[i]\r\n\t\t\t\t\t);\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\t[\r\n\t\t\t\t\"CalculateIRR\",\r\n\t\t\t\t\"CalculateIRRBeforeCarried\",\r\n\t\t\t\t\"CalculateIRRIRRDate\",\r\n\t\t\t\t\"CalculateIRRMTD\",\r\n\t\t\t\t\"CalculateIRRQTD\",\r\n\t\t\t\t\"CalculateIRRYTD\",\r\n\t\t\t].includes(args.aggregateType)\r\n\t\t) {\r\n\t\t\t// console.log(\"==========================\");\r\n\t\t\t// console.log(\"args:\", args);\r\n\t\t\tlet valueField;\r\n\t\t\tlet dateField;\r\n\t\t\tlet startDate;\r\n\t\t\tlet endDate;\r\n\t\t\tswitch (args.aggregateType) {\r\n\t\t\t\tcase \"CalculateIRR\":\r\n\t\t\t\t\tvalueField = \"IRRAdjValue\";\r\n\t\t\t\t\tdateField = \"IRRDate\";\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase \"CalculateIRRMTD\":\r\n\t\t\t\t\tstartDate = moment(asOfDate)\r\n\t\t\t\t\t\t.startOf(\"month\")\r\n\t\t\t\t\t\t.format(\"YYYY-MM-DD\");\r\n\t\t\t\t\tendDate = moment(asOfDate).format(\"YYYY-MM-DD\");\r\n\t\t\t\t\tvalueField = \"IRRAdjValue\";\r\n\t\t\t\t\tdateField = \"IRRDate\";\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase \"CalculateIRRQTD\":\r\n\t\t\t\t\tstartDate = moment(asOfDate)\r\n\t\t\t\t\t\t.startOf(\"quarter\")\r\n\t\t\t\t\t\t.format(\"YYYY-MM-DD\");\r\n\t\t\t\t\tendDate = moment(asOfDate).format(\"YYYY-MM-DD\");\r\n\t\t\t\t\tvalueField = \"IRRAdjValue\";\r\n\t\t\t\t\tdateField = \"IRRDate\";\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase \"CalculateIRRYTD\":\r\n\t\t\t\t\tstartDate = moment(asOfDate)\r\n\t\t\t\t\t\t.startOf(\"year\")\r\n\t\t\t\t\t\t.format(\"YYYY-MM-DD\");\r\n\t\t\t\t\tendDate = moment(asOfDate).format(\"YYYY-MM-DD\");\r\n\t\t\t\t\tvalueField = \"IRRAdjValue\";\r\n\t\t\t\t\tdateField = \"IRRDate\";\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase \"CalculateIRRIRRDate\":\r\n\t\t\t\t\tvalueField = \"IRRAdjValue\";\r\n\t\t\t\t\tdateField = \"CalculateIRRDate\";\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase \"CalculateIRRBeforeCarried\":\r\n\t\t\t\t\tvalueField = \"IRRAdjValueBeforeCarry\";\r\n\t\t\t\t\tdateField = \"IRRDate\";\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tdefault:\r\n\t\t\t\t\tbreak;\r\n\t\t\t}\r\n\t\t\tlet NAVAdj = 0;\r\n\t\t\tlet values = [];\r\n\t\t\tlet beforeStartNAVAdj = 0; // 存储上一个阶段的NAVAdj总和\r\n\t\t\tlet beforeStartValues = []; // 存储上一个阶段的累计集合 (只是为了打印，没有实际用途)\r\n\t\t\tlet field = this.configFields.filter(\r\n\t\t\t\t(el) =>\r\n\t\t\t\t\tel.colName ===\r\n\t\t\t\t\tthis.dashboardPorletsService.getAggregateType(\r\n\t\t\t\t\t\targs.aggregateType\r\n\t\t\t\t\t)\r\n\t\t\t);\r\n\t\t\tfor (let i = 0; i < args.cellSets.length; i++) {\r\n\t\t\t\tconst data = {\r\n\t\t\t\t\tamount: args.cellSets[i][\"IRRAmount\"],\r\n\t\t\t\t\tdate:\r\n\t\t\t\t\t\tthis.pbf.time(args.cellSets[i][dateField]) ===\r\n\t\t\t\t\t\t\"Invalid date\"\r\n\t\t\t\t\t\t\t? asOfDate\r\n\t\t\t\t\t\t\t: this.pbf.time(args.cellSets[i][dateField]),\r\n\t\t\t\t};\r\n\t\t\t\t// SMP2-16920\r\n\t\t\t\t// If IRR Date > Dashboard report date = Takes as of dashboard report date\r\n\t\t\t\tif (\r\n\t\t\t\t\targs.aggregateType === \"CalculateIRRIRRDate\" &&\r\n\t\t\t\t\tasOfDate < this.pbf.time(args.cellSets[i][dateField])\r\n\t\t\t\t) {\r\n\t\t\t\t\tdata.date = asOfDate;\r\n\t\t\t\t}\r\n\t\t\t\tNAVAdj += args.cellSets[i][valueField];\r\n\t\t\t\t// SMP2-17219 MTD QTD YTD IRR\r\n\t\t\t\tif (startDate && endDate) {\r\n\t\t\t\t\tif (moment(data.date).isBefore(startDate)) {\r\n\t\t\t\t\t\tdata[valueField] = args.cellSets[i][valueField];\r\n\t\t\t\t\t\tbeforeStartValues.push(data);\r\n\t\t\t\t\t\tbeforeStartNAVAdj += data[valueField];\r\n\t\t\t\t\t}\r\n\t\t\t\t\tif (\r\n\t\t\t\t\t\t!moment(data.date).isBetween(\r\n\t\t\t\t\t\t\tstartDate,\r\n\t\t\t\t\t\t\tendDate,\r\n\t\t\t\t\t\t\tnull,\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\tcontinue;\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t\tif (data.amount != 0) {\r\n\t\t\t\t\tvalues.push(data);\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\tif (NAVAdj > 0.0001 || NAVAdj < -0.0001) {\r\n\t\t\t\tvalues.push({\r\n\t\t\t\t\tamount: NAVAdj,\r\n\t\t\t\t\tdate: asOfDate,\r\n\t\t\t\t});\r\n\t\t\t}\r\n\t\t\tvalues = sortBy(values, \"date\");\r\n\t\t\t// 如果是MTD,QTD,YTD 则需要把当前阶段以前的所有数据进行汇总，加入计算\r\n\t\t\tif (startDate && endDate) {\r\n\t\t\t\tvalues.unshift({\r\n\t\t\t\t\tamount: -beforeStartNAVAdj, // 开始的数据需要取反\r\n\t\t\t\t\tdate: this.pbf.time(startDate),\r\n\t\t\t\t});\r\n\t\t\t}\r\n\t\t\t// console.log(\"beforeStartValues:\", beforeStartValues);\r\n\t\t\t// console.log(\"values:\", values);\r\n\t\t\tif (values.length > 0) {\r\n\t\t\t\tlet guess = 0.1;\r\n\t\t\t\tconst sumAmount = values\r\n\t\t\t\t\t.map((item) => item.amount)\r\n\t\t\t\t\t.reduce((prev, curr) => prev + curr, 0);\r\n\t\t\t\tif (sumAmount < 0) {\r\n\t\t\t\t\tguess = -0.1;\r\n\t\t\t\t}\r\n\t\t\t\t//SMP2-2249 fixed the big irr issue\r\n\t\t\t\tif (sumAmount === 0) {\r\n\t\t\t\t\targs.value = 0;\r\n\t\t\t\t} else {\r\n\t\t\t\t\tconst valueItems = values.slice(0, values.length - 1);\r\n\t\t\t\t\tconst valueList = valueItems.map((item) => item.amount);\r\n\t\t\t\t\tconst dateList = valueItems.map((item) => item.date);\r\n\t\t\t\t\tconst lastItem = values[values.length - 1];\r\n\t\t\t\t\tconst navAdjust = lastItem.amount;\r\n\t\t\t\t\tconst latestDate = lastItem.date;\r\n\t\t\t\t\tlet irr =\r\n\t\t\t\t\t\tthis.dashboardPorletsService.ExcelFormulas._CalculateXirr(\r\n\t\t\t\t\t\t\tvalueList,\r\n\t\t\t\t\t\t\tdateList,\r\n\t\t\t\t\t\t\tnavAdjust,\r\n\t\t\t\t\t\t\tlatestDate\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\targs.value = irr === null ? \"\" : irr;\r\n\t\t\t\t}\r\n\t\t\t} else {\r\n\t\t\t\targs.value = \"\";\r\n\t\t\t}\r\n\t\t\t// console.log(\"args.value:\", args.value);\r\n\t\t\tif (\r\n\t\t\t\tthis.pivotObj.engineModule &&\r\n\t\t\t\tthis.pivotObj.engineModule.formatFields[args.fieldName]\r\n\t\t\t) {\r\n\t\t\t\tdelete this.pivotObj.engineModule.formatFields[args.fieldName];\r\n\t\t\t\tthis.pivotObj.engineModule.formatFields[args.fieldName] = {\r\n\t\t\t\t\tname: args.fieldName,\r\n\t\t\t\t\tformat:\r\n\t\t\t\t\t\tfield.length > 0\r\n\t\t\t\t\t\t\t? field[0].format &&\r\n\t\t\t\t\t\t\t  field[0].format.length &&\r\n\t\t\t\t\t\t\t  field[0].format[0].formatChecked\r\n\t\t\t\t\t\t\t\t? this.dashboardPorletsService.pivotTableformatPercent(\r\n\t\t\t\t\t\t\t\t\t\tfield[0].format[0].selectedFormat\r\n\t\t\t\t\t\t\t\t  )\r\n\t\t\t\t\t\t\t\t: this.dashboardPorletsService.formatPercent(\r\n\t\t\t\t\t\t\t\t\t\tfield[0].dp\r\n\t\t\t\t\t\t\t\t  )\r\n\t\t\t\t\t\t\t: \"P2\",\r\n\t\t\t\t};\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t//  SMP2-16520 TWR 月/季/年 && SMP2-16683 VAR\r\n\t\tif (\r\n\t\t\t[\r\n\t\t\t\t\"CalculateTWRMTD\",\r\n\t\t\t\t\"CalculateTWRQTD\",\r\n\t\t\t\t\"CalculateTWRYTD\",\r\n\t\t\t\t\"CalculateVARMTD_99\",\r\n\t\t\t\t\"CalculateVARQTD_99\",\r\n\t\t\t\t\"CalculateVARYTD_99\",\r\n\t\t\t\t\"CalculateVARMTD_95\",\r\n\t\t\t\t\"CalculateVARQTD_95\",\r\n\t\t\t\t\"CalculateVARYTD_95\",\r\n\t\t\t].includes(args.aggregateType)\r\n\t\t) {\r\n\t\t\t// console.log(\"==========================\");\r\n\t\t\t// console.log(\"args:\", args);\r\n\t\t\tlet valueField = \"IRRAdjValue\";\r\n\t\t\tlet dateField = \"IRRDate\";\r\n\t\t\tlet timeRange;\r\n\t\t\tswitch (args.aggregateType) {\r\n\t\t\t\tcase \"CalculateTWRMTD\":\r\n\t\t\t\tcase \"CalculateVARMTD_99\":\r\n\t\t\t\tcase \"CalculateVARMTD_95\":\r\n\t\t\t\t\ttimeRange = \"month\";\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase \"CalculateTWRQTD\":\r\n\t\t\t\tcase \"CalculateVARQTD_99\":\r\n\t\t\t\tcase \"CalculateVARQTD_95\":\r\n\t\t\t\t\ttimeRange = \"quarter\";\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase \"CalculateTWRYTD\":\r\n\t\t\t\tcase \"CalculateVARYTD_99\":\r\n\t\t\t\tcase \"CalculateVARYTD_95\":\r\n\t\t\t\t\ttimeRange = \"year\";\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tdefault:\r\n\t\t\t\t\tbreak;\r\n\t\t\t}\r\n\t\t\tlet values = []; // 这个阶段的累计集合\r\n\t\t\tlet field = this.configFields.filter(\r\n\t\t\t\t(el) =>\r\n\t\t\t\t\tel.colName ===\r\n\t\t\t\t\tthis.dashboardPorletsService.getAggregateType(\r\n\t\t\t\t\t\targs.aggregateType\r\n\t\t\t\t\t)\r\n\t\t\t);\r\n\t\t\tfor (let i = 0; i < args.cellSets.length; i++) {\r\n\t\t\t\tconst data = {\r\n\t\t\t\t\t[valueField]: args.cellSets[i][valueField],\r\n\t\t\t\t\tdate:\r\n\t\t\t\t\t\tthis.pbf.time(args.cellSets[i][dateField]) ===\r\n\t\t\t\t\t\t\"Invalid date\"\r\n\t\t\t\t\t\t\t? asOfDate\r\n\t\t\t\t\t\t\t: this.pbf.time(args.cellSets[i][dateField]),\r\n\t\t\t\t};\r\n\t\t\t\tvalues.push(data);\r\n\t\t\t}\r\n\r\n\t\t\t// 如果asOfDate不是 本月/季度/年 的最后一天，都是截至 上个月/季度/年 的最后一天的数据去计算\r\n\t\t\tlet _asOfDate = moment(asOfDate);\r\n\t\t\t// console.log(\"_asOfDate:\", _asOfDate);\r\n\t\t\tlet isEndOfPeriod = (unit) => {\r\n\t\t\t\treturn (\r\n\t\t\t\t\t_asOfDate.format(\"YYYY-MM-DD\") ===\r\n\t\t\t\t\t_asOfDate.endOf(unit).format(\"YYYY-MM-DD\")\r\n\t\t\t\t);\r\n\t\t\t};\r\n\t\t\tlet endDate = isEndOfPeriod(timeRange)\r\n\t\t\t\t? moment(asOfDate).format(\"YYYY-MM-DD\")\r\n\t\t\t\t: moment(asOfDate)\r\n\t\t\t\t\t\t.subtract(1, timeRange)\r\n\t\t\t\t\t\t.endOf(timeRange)\r\n\t\t\t\t\t\t.format(\"YYYY-MM-DD\");\r\n\r\n\t\t\t// console.log(\"endDate:\", endDate);\r\n\t\t\tvalues = values.filter((item) =>\r\n\t\t\t\tmoment(item.date).isSameOrBefore(endDate)\r\n\t\t\t);\r\n\t\t\tvalues = sortBy(values, \"date\");\r\n\t\t\t// console.log(\"values:\", values);\r\n\r\n\t\t\tif (values.length > 0) {\r\n\t\t\t\tlet result = this.getTimeRanges(\r\n\t\t\t\t\tvalues,\r\n\t\t\t\t\tendDate,\r\n\t\t\t\t\ttimeRange,\r\n\t\t\t\t\t\"date\"\r\n\t\t\t\t); // 各个阶段的数据\r\n\t\t\t\tlet resultTotal = {}; // 各个阶段总和\r\n\t\t\t\tfor (const prop in result) {\r\n\t\t\t\t\tresultTotal[prop] = result[prop].reduce((acc, cur) => {\r\n\t\t\t\t\t\treturn acc + (cur[valueField] || 0);\r\n\t\t\t\t\t}, 0);\r\n\t\t\t\t}\r\n\t\t\t\t// console.log(\"result:\", result);\r\n\t\t\t\t// console.log(\"resultTotal:\", resultTotal);\r\n\r\n\t\t\t\tconst cumulativeSum = {}; // 各个阶段累计和\r\n\t\t\t\tlet sum = 0;\r\n\t\t\t\tfor (const key of Object.keys(resultTotal)) {\r\n\t\t\t\t\tsum += resultTotal[key];\r\n\t\t\t\t\tcumulativeSum[`${key}`] = sum;\r\n\t\t\t\t}\r\n\t\t\t\t// console.log(\"cumulativeSum:\", cumulativeSum);\r\n\r\n\t\t\t\tconst keys = Object.keys(cumulativeSum);\r\n\t\t\t\tlet twrList = [];\r\n\t\t\t\t// 遍历每两个阶段 计算TWR\r\n\t\t\t\tfor (let i = 0; i < keys.length - 1; i++) {\r\n\t\t\t\t\tconst key1 = keys[i];\r\n\t\t\t\t\tconst key2 = keys[i + 1];\r\n\r\n\t\t\t\t\t// 计算两个阶段之间的递增量, 出数不能为0\r\n\t\t\t\t\tif (cumulativeSum[key1] != 0) {\r\n\t\t\t\t\t\tconst increment =\r\n\t\t\t\t\t\t\tcumulativeSum[key2] - cumulativeSum[key1];\r\n\t\t\t\t\t\tlet twr = increment / cumulativeSum[key1];\r\n\t\t\t\t\t\ttwrList.push({\r\n\t\t\t\t\t\t\tdate: key2,\r\n\t\t\t\t\t\t\ttwr: twr,\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\t\t// 计算Average TWR\r\n\t\t\t\t// console.log(\"twrList:\", twrList);\r\n\t\t\t\tlet averageTWR = this.calculateGrowthRate(\r\n\t\t\t\t\ttwrList.map((x) => x.twr)\r\n\t\t\t\t);\r\n\t\t\t\t// console.log(\"计算Average TWR:\", averageTWR);\r\n\t\t\t\tif (\r\n\t\t\t\t\t[\r\n\t\t\t\t\t\t\"CalculateTWRMTD\",\r\n\t\t\t\t\t\t\"CalculateTWRQTD\",\r\n\t\t\t\t\t\t\"CalculateTWRYTD\",\r\n\t\t\t\t\t].includes(args.aggregateType)\r\n\t\t\t\t) {\r\n\t\t\t\t\t// SMP2-16520 TWR 月/季/年\r\n\t\t\t\t\targs.value =\r\n\t\t\t\t\t\tisNaN(averageTWR) || averageTWR == null\r\n\t\t\t\t\t\t\t? \"\"\r\n\t\t\t\t\t\t\t: Number(averageTWR);\r\n\t\t\t\t} else {\r\n\t\t\t\t\tif (isNaN(averageTWR) || averageTWR == null) {\r\n\t\t\t\t\t\targs.value = \"\";\r\n\t\t\t\t\t} else {\r\n\t\t\t\t\t\t// SMP2-16683 VAR 区分99%和95%\r\n\t\t\t\t\t\tlet ZScore = [\r\n\t\t\t\t\t\t\t\"CalculateVARMTD_99\",\r\n\t\t\t\t\t\t\t\"CalculateVARQTD_99\",\r\n\t\t\t\t\t\t\t\"CalculateVARYTD_99\",\r\n\t\t\t\t\t\t].includes(args.aggregateType)\r\n\t\t\t\t\t\t\t? 2.33\r\n\t\t\t\t\t\t\t: 1.65;\r\n\t\t\t\t\t\tif (twrList.length < 2) {\r\n\t\t\t\t\t\t\targs.value = \"\";\r\n\t\t\t\t\t\t} else {\r\n\t\t\t\t\t\t\tlet SD = this.calculateStandardDeviation(\r\n\t\t\t\t\t\t\t\ttwrList.map((x) => x.twr)\r\n\t\t\t\t\t\t\t);\r\n\t\t\t\t\t\t\t// console.log(\"calculateStandardDeviation:\", SD);\r\n\t\t\t\t\t\t\tlet VAR = averageTWR - SD * ZScore;\r\n\t\t\t\t\t\t\targs.value = Number(VAR);\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\t\t// console.log(\"args.value:\", args.value);\r\n\t\t\t}\r\n\r\n\t\t\tif (\r\n\t\t\t\tthis.pivotObj.engineModule &&\r\n\t\t\t\tthis.pivotObj.engineModule.formatFields[args.fieldName]\r\n\t\t\t) {\r\n\t\t\t\tdelete this.pivotObj.engineModule.formatFields[args.fieldName];\r\n\t\t\t\tthis.pivotObj.engineModule.formatFields[args.fieldName] = {\r\n\t\t\t\t\tname: args.fieldName,\r\n\t\t\t\t\tformat:\r\n\t\t\t\t\t\tfield.length > 0\r\n\t\t\t\t\t\t\t? field[0].format &&\r\n\t\t\t\t\t\t\t  field[0].format.length &&\r\n\t\t\t\t\t\t\t  field[0].format[0].formatChecked\r\n\t\t\t\t\t\t\t\t? this.dashboardPorletsService.pivotTableformatPercent(\r\n\t\t\t\t\t\t\t\t\t\tfield[0].format[0].selectedFormat\r\n\t\t\t\t\t\t\t\t  )\r\n\t\t\t\t\t\t\t\t: this.dashboardPorletsService.formatPercent(\r\n\t\t\t\t\t\t\t\t\t\tfield[0].dp\r\n\t\t\t\t\t\t\t\t  )\r\n\t\t\t\t\t\t\t: \"P2\",\r\n\t\t\t\t};\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t//SMP2-2701\r\n\t\tif (args.aggregateType === \"CalculateIRRActualAudited\") {\r\n\t\t\tlet NAVAdj = 0;\r\n\t\t\tlet values = [];\r\n\t\t\tlet field = this.configFields.filter(\r\n\t\t\t\t(el) =>\r\n\t\t\t\t\tel.colName ===\r\n\t\t\t\t\tthis.dashboardPorletsService.getAggregateType(\r\n\t\t\t\t\t\targs.aggregateType\r\n\t\t\t\t\t)\r\n\t\t\t);\r\n\t\t\t//SMP2-2713 only judge for this dataMart(GrossNet)\r\n\t\t\tif (\r\n\t\t\t\tthis.portlet.figureCode === \"GrossNet\" ||\r\n\t\t\t\tthis.portlet.figureCode ===\r\n\t\t\t\t\t\"CombinedInvestmentFundNCompanyCashflow\"\r\n\t\t\t) {\r\n\t\t\t\tfor (let i = 0; i < args.cellSets.length; i++) {\r\n\t\t\t\t\tconst data = {\r\n\t\t\t\t\t\tamount: args.cellSets[i][\"IRRAmount\"],\r\n\t\t\t\t\t\tdate:\r\n\t\t\t\t\t\t\tthis.pbf.time(args.cellSets[i][\"IRRDate\"]) ===\r\n\t\t\t\t\t\t\t\"Invalid date\"\r\n\t\t\t\t\t\t\t\t? asOfDate\r\n\t\t\t\t\t\t\t\t: this.pbf.time(args.cellSets[i][\"IRRDate\"]),\r\n\t\t\t\t\t};\r\n\t\t\t\t\tNAVAdj += args.cellSets[i][\"ActualAuditedNAV\"];\r\n\t\t\t\t\tif (data.amount != 0) {\r\n\t\t\t\t\t\tvalues.push(data);\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\t//filter the data by the DataType(Actual Reported Audited)\r\n\t\t\telse {\r\n\t\t\t\tlet argsdata = args.cellSets.filter(\r\n\t\t\t\t\t(el) =>\r\n\t\t\t\t\t\tel.DataType === \"ACTUAL_AUDITED\" ||\r\n\t\t\t\t\t\tel.DataType === \"REPORTED\"\r\n\t\t\t\t);\r\n\t\t\t\tfor (let i = 0; i < argsdata.length; i++) {\r\n\t\t\t\t\tconst data = {\r\n\t\t\t\t\t\tamount: argsdata[i][\"IRRAmount\"],\r\n\t\t\t\t\t\tdate:\r\n\t\t\t\t\t\t\tthis.pbf.time(argsdata[i][\"IRRDate\"]) ===\r\n\t\t\t\t\t\t\t\"Invalid date\"\r\n\t\t\t\t\t\t\t\t? asOfDate\r\n\t\t\t\t\t\t\t\t: this.pbf.time(argsdata[i][\"IRRDate\"]),\r\n\t\t\t\t\t};\r\n\t\t\t\t\tNAVAdj += argsdata[i][\"IRRAdjValue\"];\r\n\t\t\t\t\tif (data.amount != 0) {\r\n\t\t\t\t\t\tvalues.push(data);\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\tif (NAVAdj > 0.0001 || NAVAdj < -0.0001) {\r\n\t\t\t\tvalues.push({\r\n\t\t\t\t\tamount: NAVAdj,\r\n\t\t\t\t\tdate: asOfDate,\r\n\t\t\t\t});\r\n\t\t\t}\r\n\t\t\tvalues = sortBy(values, \"date\");\r\n\t\t\tif (values.length > 0) {\r\n\t\t\t\tlet guess = 0.1;\r\n\t\t\t\tconst sumAmount = values\r\n\t\t\t\t\t.map((item) => item.amount)\r\n\t\t\t\t\t.reduce((prev, curr) => prev + curr, 0);\r\n\t\t\t\tif (sumAmount < 0) {\r\n\t\t\t\t\tguess = -0.1;\r\n\t\t\t\t}\r\n\t\t\t\t//SMP2-2249 fixed the big irr issue\r\n\t\t\t\tif (sumAmount === 0) {\r\n\t\t\t\t\targs.value = 0;\r\n\t\t\t\t} else {\r\n\t\t\t\t\tconst valueItems = values.slice(0, values.length - 1);\r\n\t\t\t\t\tconst valueList = valueItems.map((item) => item.amount);\r\n\t\t\t\t\tconst dateList = valueItems.map((item) => item.date);\r\n\t\t\t\t\tconst lastItem = values[values.length - 1];\r\n\t\t\t\t\tconst navAdjust = lastItem.amount;\r\n\t\t\t\t\tconst latestDate = lastItem.date;\r\n\t\t\t\t\tlet irr =\r\n\t\t\t\t\t\tthis.dashboardPorletsService.ExcelFormulas._CalculateXirr(\r\n\t\t\t\t\t\t\tvalueList,\r\n\t\t\t\t\t\t\tdateList,\r\n\t\t\t\t\t\t\tnavAdjust,\r\n\t\t\t\t\t\t\tlatestDate\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\targs.value = irr === null ? 0 : irr;\r\n\t\t\t\t}\r\n\t\t\t} else {\r\n\t\t\t\targs.value = 0;\r\n\t\t\t}\r\n\t\t\tif (\r\n\t\t\t\tthis.pivotObj.engineModule &&\r\n\t\t\t\tthis.pivotObj.engineModule.formatFields[args.fieldName]\r\n\t\t\t) {\r\n\t\t\t\tdelete this.pivotObj.engineModule.formatFields[args.fieldName];\r\n\t\t\t\tthis.pivotObj.engineModule.formatFields[args.fieldName] = {\r\n\t\t\t\t\tname: args.fieldName,\r\n\t\t\t\t\tformat:\r\n\t\t\t\t\t\tfield.length > 0\r\n\t\t\t\t\t\t\t? field[0].format &&\r\n\t\t\t\t\t\t\t  field[0].format.length &&\r\n\t\t\t\t\t\t\t  field[0].format[0].formatChecked\r\n\t\t\t\t\t\t\t\t? this.dashboardPorletsService.pivotTableformatPercent(\r\n\t\t\t\t\t\t\t\t\t\tfield[0].format[0].selectedFormat\r\n\t\t\t\t\t\t\t\t  )\r\n\t\t\t\t\t\t\t\t: this.dashboardPorletsService.formatPercent(\r\n\t\t\t\t\t\t\t\t\t\tfield[0].dp\r\n\t\t\t\t\t\t\t\t  )\r\n\t\t\t\t\t\t\t: \"P2\",\r\n\t\t\t\t};\r\n\t\t\t}\r\n\t\t}\r\n\t\t//SMP2-3411\r\n\t\tif (args.aggregateType === \"CalculateIRRReported\") {\r\n\t\t\tlet NAVAdj = 0;\r\n\t\t\tlet values = [];\r\n\t\t\tlet field = this.configFields.filter(\r\n\t\t\t\t(el) =>\r\n\t\t\t\t\tel.colName ===\r\n\t\t\t\t\tthis.dashboardPorletsService.getAggregateType(\r\n\t\t\t\t\t\targs.aggregateType\r\n\t\t\t\t\t)\r\n\t\t\t);\r\n\t\t\tif (\r\n\t\t\t\tthis.portlet.figureCode === \"GrossNet\" ||\r\n\t\t\t\tthis.portlet.figureCode ===\r\n\t\t\t\t\t\"CombinedInvestmentFundNCompanyCashflow\"\r\n\t\t\t) {\r\n\t\t\t\tfor (let i = 0; i < args.cellSets.length; i++) {\r\n\t\t\t\t\tconst data = {\r\n\t\t\t\t\t\tamount: args.cellSets[i][\"IRRAmount\"],\r\n\t\t\t\t\t\tdate:\r\n\t\t\t\t\t\t\tthis.pbf.time(args.cellSets[i][\"IRRDate\"]) ===\r\n\t\t\t\t\t\t\t\"Invalid date\"\r\n\t\t\t\t\t\t\t\t? asOfDate\r\n\t\t\t\t\t\t\t\t: this.pbf.time(args.cellSets[i][\"IRRDate\"]),\r\n\t\t\t\t\t};\r\n\t\t\t\t\tNAVAdj += args.cellSets[i][\"ReportedNAV\"];\r\n\t\t\t\t\tif (data.amount != 0) {\r\n\t\t\t\t\t\tvalues.push(data);\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t} else {\r\n\t\t\t\tfor (let i = 0; i < args.cellSets.length; i++) {\r\n\t\t\t\t\tconst data = {\r\n\t\t\t\t\t\tamount: args.cellSets[i][\"IRRAmount\"],\r\n\t\t\t\t\t\tdate:\r\n\t\t\t\t\t\t\tthis.pbf.time(args.cellSets[i][\"IRRDate\"]) ===\r\n\t\t\t\t\t\t\t\"Invalid date\"\r\n\t\t\t\t\t\t\t\t? asOfDate\r\n\t\t\t\t\t\t\t\t: this.pbf.time(args.cellSets[i][\"IRRDate\"]),\r\n\t\t\t\t\t};\r\n\t\t\t\t\tNAVAdj += args.cellSets[i][\"IRRAdjValue\"];\r\n\t\t\t\t\tif (data.amount != 0) {\r\n\t\t\t\t\t\tvalues.push(data);\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\tif (NAVAdj > 0.0001 || NAVAdj < -0.0001) {\r\n\t\t\t\tvalues.push({\r\n\t\t\t\t\tamount: NAVAdj,\r\n\t\t\t\t\tdate: asOfDate,\r\n\t\t\t\t});\r\n\t\t\t}\r\n\t\t\tvalues = sortBy(values, \"date\");\r\n\t\t\tif (values.length > 0) {\r\n\t\t\t\tlet guess = 0.1;\r\n\t\t\t\tconst sumAmount = values\r\n\t\t\t\t\t.map((item) => item.amount)\r\n\t\t\t\t\t.reduce((prev, curr) => prev + curr, 0);\r\n\t\t\t\tif (sumAmount < 0) {\r\n\t\t\t\t\tguess = -0.1;\r\n\t\t\t\t}\r\n\t\t\t\t//SMP2-2249 fixed the big irr issue\r\n\t\t\t\tif (sumAmount === 0) {\r\n\t\t\t\t\targs.value = 0;\r\n\t\t\t\t} else {\r\n\t\t\t\t\tconst valueItems = values.slice(0, values.length - 1);\r\n\t\t\t\t\tconst valueList = valueItems.map((item) => item.amount);\r\n\t\t\t\t\tconst dateList = valueItems.map((item) => item.date);\r\n\t\t\t\t\tconst lastItem = values[values.length - 1];\r\n\t\t\t\t\tconst navAdjust = lastItem.amount;\r\n\t\t\t\t\tconst latestDate = lastItem.date;\r\n\t\t\t\t\tlet irr =\r\n\t\t\t\t\t\tthis.dashboardPorletsService.ExcelFormulas._CalculateXirr(\r\n\t\t\t\t\t\t\tvalueList,\r\n\t\t\t\t\t\t\tdateList,\r\n\t\t\t\t\t\t\tnavAdjust,\r\n\t\t\t\t\t\t\tlatestDate\r\n\t\t\t\t\t\t);\r\n\r\n\t\t\t\t\targs.value = irr === null ? 0 : irr;\r\n\t\t\t\t}\r\n\t\t\t} else {\r\n\t\t\t\targs.value = 0;\r\n\t\t\t}\r\n\t\t\tif (\r\n\t\t\t\tthis.pivotObj.engineModule &&\r\n\t\t\t\tthis.pivotObj.engineModule.formatFields[args.fieldName]\r\n\t\t\t) {\r\n\t\t\t\tdelete this.pivotObj.engineModule.formatFields[args.fieldName];\r\n\t\t\t\tthis.pivotObj.engineModule.formatFields[args.fieldName] = {\r\n\t\t\t\t\tname: args.fieldName,\r\n\t\t\t\t\tformat:\r\n\t\t\t\t\t\tfield.length > 0\r\n\t\t\t\t\t\t\t? field[0].format &&\r\n\t\t\t\t\t\t\t  field[0].format.length &&\r\n\t\t\t\t\t\t\t  field[0].format[0].formatChecked\r\n\t\t\t\t\t\t\t\t? this.dashboardPorletsService.pivotTableformatPercent(\r\n\t\t\t\t\t\t\t\t\t\tfield[0].format[0].selectedFormat\r\n\t\t\t\t\t\t\t\t  )\r\n\t\t\t\t\t\t\t\t: this.dashboardPorletsService.formatPercent(\r\n\t\t\t\t\t\t\t\t\t\tfield[0].dp\r\n\t\t\t\t\t\t\t\t  )\r\n\t\t\t\t\t\t\t: \"P2\",\r\n\t\t\t\t};\r\n\t\t\t}\r\n\t\t}\r\n\t\tif (\r\n\t\t\targs.aggregateType === \"CalculateMultiple\" ||\r\n\t\t\targs.aggregateType === \"CalculatePIC\" ||\r\n\t\t\targs.aggregateType === \"CalculateDPI\" ||\r\n\t\t\targs.aggregateType === \"CalculateTVPI\" ||\r\n\t\t\targs.aggregateType === \"CalculateRVPI\" ||\r\n\t\t\targs.aggregateType === \"CalculateMActualAudited\" ||\r\n\t\t\targs.aggregateType === \"CalculateMReported\"\r\n\t\t) {\r\n\t\t\tlet totalNumerator = 0;\r\n\t\t\tlet totalDenominator = 0;\r\n\t\t\tlet numeratorName;\r\n\t\t\tlet denominatorName;\r\n\t\t\tlet field = this.configFields.filter(\r\n\t\t\t\t(el) =>\r\n\t\t\t\t\tel.colName ===\r\n\t\t\t\t\tthis.dashboardPorletsService.getAggregateType(\r\n\t\t\t\t\t\targs.aggregateType\r\n\t\t\t\t\t)\r\n\t\t\t);\r\n\t\t\tif (field.length > 0) {\r\n\t\t\t\tconst formulaArray = field[0].formula.split(\"/\");\r\n\t\t\t\tnumeratorName = formulaArray[0];\r\n\t\t\t\tdenominatorName = formulaArray[1];\r\n\t\t\t}\r\n\t\t\tfor (let j = 0; j < args.cellSets.length; j++) {\r\n\t\t\t\ttotalNumerator += args.cellSets[j][numeratorName];\r\n\t\t\t\ttotalDenominator += args.cellSets[j][denominatorName];\r\n\t\t\t}\r\n\t\t\tif (totalDenominator !== 0) {\r\n\t\t\t\targs.value = totalNumerator / totalDenominator;\r\n\t\t\t\tif (\r\n\t\t\t\t\tthis.pivotObj.engineModule &&\r\n\t\t\t\t\tthis.pivotObj.engineModule.formatFields[args.fieldName]\r\n\t\t\t\t) {\r\n\t\t\t\t\tdelete this.pivotObj.engineModule.formatFields[\r\n\t\t\t\t\t\targs.fieldName\r\n\t\t\t\t\t];\r\n\t\t\t\t\tthis.pivotObj.engineModule.formatFields[args.fieldName] = {\r\n\t\t\t\t\t\tname: args.fieldName,\r\n\t\t\t\t\t\tformat:\r\n\t\t\t\t\t\t\tfield.length > 0\r\n\t\t\t\t\t\t\t\t? field[0].format &&\r\n\t\t\t\t\t\t\t\t  field[0].format.length &&\r\n\t\t\t\t\t\t\t\t  field[0].format[0].formatChecked\r\n\t\t\t\t\t\t\t\t\t? this.dashboardPorletsService.pivotTableformatMultiple(\r\n\t\t\t\t\t\t\t\t\t\t\tfield[0].format[0].selectedFormat\r\n\t\t\t\t\t\t\t\t\t  )\r\n\t\t\t\t\t\t\t\t\t: this.dashboardPorletsService.formatMultiple(\r\n\t\t\t\t\t\t\t\t\t\t\tfield[0].dp\r\n\t\t\t\t\t\t\t\t\t  )\r\n\t\t\t\t\t\t\t\t: \"###0.00'x'\",\r\n\t\t\t\t\t};\r\n\t\t\t\t}\r\n\t\t\t} else {\r\n\t\t\t\targs.value = \"\";\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tif (args.aggregateType === \"First\" || args.aggregateType === \"Last\") {\r\n\t\t\targs.value = this.calculatedFistLast(\r\n\t\t\t\targs,\r\n\t\t\t\targs.aggregateType,\r\n\t\t\t\targs.fieldName\r\n\t\t\t);\r\n\t\t}\r\n\r\n\t\tif (\r\n\t\t\targs.aggregateType === \"Count\" ||\r\n\t\t\targs.aggregateType === \"DistinctCount\"\r\n\t\t) {\r\n\t\t\tif (args.value) {\r\n\t\t\t\targs.value = args.value.toFixed(2);\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tif (\r\n\t\t\t!args.value &&\r\n\t\t\targs.value !== 0 &&\r\n\t\t\targs.value !== false &&\r\n\t\t\targs.value !== \"false\"\r\n\t\t) {\r\n\t\t\targs.skipFormatting = true;\r\n\t\t\targs.value = \"\";\r\n\t\t}\r\n\t\t// 新建pivot table, 还没有设置row, 选了column之后grandtotal会有值\r\n\t\tif (\r\n\t\t\targs.rowCellType === \"grandTotal\" &&\r\n\t\t\t!this.pivotObj.dataSourceSettings.rows.length\r\n\t\t) {\r\n\t\t\targs.value = \"\";\r\n\t\t}\r\n\t\t//SMP2-2889\r\n\t\tif (args.rowCellType === \"subTotal\") {\r\n\t\t\tconst valueField_data = this.config.yaxis.series.filter(\r\n\t\t\t\t(el) => el.colName === args.fieldName\r\n\t\t\t);\r\n\t\t\tif (valueField_data.length > 0) {\r\n\t\t\t\tif (valueField_data[0].showSubTotals === false) {\r\n\t\t\t\t\targs.value = \"\";\r\n\t\t\t\t\targs.skipFormatting = true;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t\tif (args.rowCellType === \"grandTotal\") {\r\n\t\t\tconst valueField_data = this.config.yaxis.series.filter(\r\n\t\t\t\t(el) => el.colName === args.fieldName\r\n\t\t\t);\r\n\t\t\tif (valueField_data.length > 0) {\r\n\t\t\t\tif (valueField_data[0].showGrandTotals === false) {\r\n\t\t\t\t\targs.value = \"\";\r\n\t\t\t\t\targs.skipFormatting = true;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t\t// SMP2-3416 start\r\n\t\tif (\r\n\t\t\tthis.zeroFormatData.hgList.includes(args.fieldName) &&\r\n\t\t\targs.value === 0\r\n\t\t) {\r\n\t\t\targs.value = \"-\";\r\n\t\t\targs.skipFormatting = true;\r\n\t\t}\r\n\t\tif (\r\n\t\t\tthis.zeroFormatData.emptyList.includes(args.fieldName) &&\r\n\t\t\targs.value === 0\r\n\t\t) {\r\n\t\t\targs.value = \"\";\r\n\t\t\targs.skipFormatting = true;\r\n\t\t}\r\n\t\tif (\r\n\t\t\tthis.millionFields.includes(args.fieldName) &&\r\n\t\t\t!isNaN(Number(args.value)) &&\r\n\t\t\targs.value !== 0 &&\r\n\t\t\targs.value !== \"\" &&\r\n\t\t\targs.value !== null\r\n\t\t) {\r\n\t\t\tif (\r\n\t\t\t\targs.columnCellType == \"grandTotal\" &&\r\n\t\t\t\targs.rowCellType == \"grandTotal\"\r\n\t\t\t) {\r\n\t\t\t\tif (!this.totalFormatted[args.fieldName]) {\r\n\t\t\t\t\tthis.totalFormatted[args.fieldName] = true;\r\n\t\t\t\t\targs.value = args.value / 1000000;\r\n\t\t\t\t}\r\n\t\t\t} else {\r\n\t\t\t\targs.value = args.value / 1000000;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t// SMP2-2486 & percentNum的format问题\r\n\t\tif (\r\n\t\t\tthis.percentNumFields.length &&\r\n\t\t\tthis.percentNumFields.includes(args.fieldName) &&\r\n\t\t\t!isNaN(Number(args.value)) &&\r\n\t\t\targs.value !== 0 &&\r\n\t\t\targs.value !== \"\" &&\r\n\t\t\targs.value !== null\r\n\t\t) {\r\n\t\t\tif (\r\n\t\t\t\targs.columnCellType == \"grandTotal\" &&\r\n\t\t\t\targs.rowCellType == \"grandTotal\"\r\n\t\t\t) {\r\n\t\t\t\tif (!this.totalFormatted[args.fieldName]) {\r\n\t\t\t\t\tthis.totalFormatted[args.fieldName] = true;\r\n\t\t\t\t\targs.value = args.value / 100;\r\n\t\t\t\t}\r\n\t\t\t} else {\r\n\t\t\t\targs.value = args.value / 100;\r\n\t\t\t}\r\n\t\t}\r\n\t\tif (\r\n\t\t\targs.aggregateType == \"CalculatedField\" &&\r\n\t\t\t!isNaN(Number(args.value)) &&\r\n\t\t\t!this.pivotObj.engineModule.formatFields[args.fieldName].format\r\n\t\t) {\r\n\t\t\targs.value = Number(args.value).toFixed(2);\r\n\t\t}\r\n\t\t// SMP2-3416 end\r\n\t\tthis.ref.markForCheck();\r\n\t\tthis.ref.detectChanges();\r\n\t}\r\n\r\n\tprivate calculatedFistLast(args, aggregateType, fieldName) {\r\n\t\tif (!args.row.actualText) args.row.actualText = args.row.formattedText;\r\n\t\tif (!args.column.actualText)\r\n\t\t\targs.column.actualText = args.column.formattedText;\r\n\t\tlet field = this.configFields.filter(\r\n\t\t\t(el) => el.colName === fieldName\r\n\t\t)[0];\r\n\t\tif (args.rowCellType === \"value\" && !args.row.hasChild) {\r\n\t\t\tif (args.cellSets[0]) {\r\n\t\t\t\tif (aggregateType === \"First\") {\r\n\t\t\t\t\tfor (\r\n\t\t\t\t\t\tlet firstIndex = 0;\r\n\t\t\t\t\t\tfirstIndex < args.cellSets.length;\r\n\t\t\t\t\t\tfirstIndex++\r\n\t\t\t\t\t) {\r\n\t\t\t\t\t\tif (\r\n\t\t\t\t\t\t\tthis.pivotObj.dataSourceSettings.columns.length ==\r\n\t\t\t\t\t\t\t\t1 &&\r\n\t\t\t\t\t\t\targs.columnCellType == \"grandTotal\"\r\n\t\t\t\t\t\t) {\r\n\t\t\t\t\t\t\tif (\r\n\t\t\t\t\t\t\t\tfield.dataType == \"string\" ||\r\n\t\t\t\t\t\t\t\tfield.dataType == \"nvarchar\" ||\r\n\t\t\t\t\t\t\t\tfield.dataType == \"date\" ||\r\n\t\t\t\t\t\t\t\tfield.dataType == \"datetime\"\r\n\t\t\t\t\t\t\t) {\r\n\t\t\t\t\t\t\t\targs.value = \"\";\r\n\t\t\t\t\t\t\t} else {\r\n\t\t\t\t\t\t\t\tif (\r\n\t\t\t\t\t\t\t\t\tthis.allDataValue &&\r\n\t\t\t\t\t\t\t\t\tthis.allDataValue.length\r\n\t\t\t\t\t\t\t\t) {\r\n\t\t\t\t\t\t\t\t\tlet rowObjs =\r\n\t\t\t\t\t\t\t\t\t\tthis.allDataValue[args.row.rowIndex];\r\n\t\t\t\t\t\t\t\t\tif (rowObjs) {\r\n\t\t\t\t\t\t\t\t\t\tlet rowObjsArr = JSON.parse(\r\n\t\t\t\t\t\t\t\t\t\t\tJSON.stringify(rowObjs)\r\n\t\t\t\t\t\t\t\t\t\t);\r\n\t\t\t\t\t\t\t\t\t\tlet obj = rowObjsArr.filter(\r\n\t\t\t\t\t\t\t\t\t\t\t(el) =>\r\n\t\t\t\t\t\t\t\t\t\t\t\tel.actualText == fieldName &&\r\n\t\t\t\t\t\t\t\t\t\t\t\tel.isGrandSum\r\n\t\t\t\t\t\t\t\t\t\t)[0];\r\n\t\t\t\t\t\t\t\t\t\tif (obj) args.value = obj.value;\r\n\t\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t\t} else {\r\n\t\t\t\t\t\t\t\t\targs.value = isNaN(\r\n\t\t\t\t\t\t\t\t\t\tNumber(\r\n\t\t\t\t\t\t\t\t\t\t\tthis.grandTotals[\r\n\t\t\t\t\t\t\t\t\t\t\t\t\"row\" +\r\n\t\t\t\t\t\t\t\t\t\t\t\t\targs.row.actualText +\r\n\t\t\t\t\t\t\t\t\t\t\t\t\tfieldName\r\n\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)\r\n\t\t\t\t\t\t\t\t\t\t? null\r\n\t\t\t\t\t\t\t\t\t\t: Number(\r\n\t\t\t\t\t\t\t\t\t\t\t\tthis.grandTotals[\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\"row\" +\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\targs.row.actualText +\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tfieldName\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}\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t} else {\r\n\t\t\t\t\t\t\targs.value = args.cellSets[firstIndex][fieldName];\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\tif (\r\n\t\t\t\t\t\t\tfield.dataType == \"number\" ||\r\n\t\t\t\t\t\t\tfield.dataType == \"multiple\" ||\r\n\t\t\t\t\t\t\tfield.dataType == \"percent\" ||\r\n\t\t\t\t\t\t\tfield.dataType == \"percentNum\"\r\n\t\t\t\t\t\t) {\r\n\t\t\t\t\t\t\tif (args.value != null) break;\r\n\t\t\t\t\t\t} else if (\r\n\t\t\t\t\t\t\tfield.dataType == \"date\" ||\r\n\t\t\t\t\t\t\tfield.dataType == \"datetime\"\r\n\t\t\t\t\t\t) {\r\n\t\t\t\t\t\t\tif (this.pbf.time(args.value) > \"1900-01-01\") break;\r\n\t\t\t\t\t\t} else if (args.value) break;\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t\tif (aggregateType === \"Last\") {\r\n\t\t\t\t\tfor (\r\n\t\t\t\t\t\tlet lastIndex = args.cellSets.length - 1;\r\n\t\t\t\t\t\tlastIndex >= 0;\r\n\t\t\t\t\t\tlastIndex--\r\n\t\t\t\t\t) {\r\n\t\t\t\t\t\tif (\r\n\t\t\t\t\t\t\tthis.pivotObj.dataSourceSettings.columns.length ==\r\n\t\t\t\t\t\t\t\t1 &&\r\n\t\t\t\t\t\t\targs.columnCellType == \"grandTotal\"\r\n\t\t\t\t\t\t) {\r\n\t\t\t\t\t\t\tif (\r\n\t\t\t\t\t\t\t\tfield.dataType == \"string\" ||\r\n\t\t\t\t\t\t\t\tfield.dataType == \"nvarchar\" ||\r\n\t\t\t\t\t\t\t\tfield.dataType == \"date\" ||\r\n\t\t\t\t\t\t\t\tfield.dataType == \"datetime\"\r\n\t\t\t\t\t\t\t) {\r\n\t\t\t\t\t\t\t\targs.value = \"\";\r\n\t\t\t\t\t\t\t} else {\r\n\t\t\t\t\t\t\t\tif (\r\n\t\t\t\t\t\t\t\t\tthis.allDataValue &&\r\n\t\t\t\t\t\t\t\t\tthis.allDataValue.length\r\n\t\t\t\t\t\t\t\t) {\r\n\t\t\t\t\t\t\t\t\tlet rowObjs =\r\n\t\t\t\t\t\t\t\t\t\tthis.allDataValue[args.row.rowIndex];\r\n\t\t\t\t\t\t\t\t\tif (rowObjs) {\r\n\t\t\t\t\t\t\t\t\t\tlet rowObjsArr = JSON.parse(\r\n\t\t\t\t\t\t\t\t\t\t\tJSON.stringify(rowObjs)\r\n\t\t\t\t\t\t\t\t\t\t);\r\n\t\t\t\t\t\t\t\t\t\tlet obj = rowObjsArr.filter(\r\n\t\t\t\t\t\t\t\t\t\t\t(el) =>\r\n\t\t\t\t\t\t\t\t\t\t\t\tel.actualText == fieldName &&\r\n\t\t\t\t\t\t\t\t\t\t\t\tel.isGrandSum\r\n\t\t\t\t\t\t\t\t\t\t)[0];\r\n\t\t\t\t\t\t\t\t\t\tif (obj) args.value = obj.value;\r\n\t\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t\t} else {\r\n\t\t\t\t\t\t\t\t\targs.value = isNaN(\r\n\t\t\t\t\t\t\t\t\t\tNumber(\r\n\t\t\t\t\t\t\t\t\t\t\tthis.grandTotals[\r\n\t\t\t\t\t\t\t\t\t\t\t\t\"row\" +\r\n\t\t\t\t\t\t\t\t\t\t\t\t\targs.row.actualText +\r\n\t\t\t\t\t\t\t\t\t\t\t\t\tfieldName\r\n\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)\r\n\t\t\t\t\t\t\t\t\t\t? null\r\n\t\t\t\t\t\t\t\t\t\t: Number(\r\n\t\t\t\t\t\t\t\t\t\t\t\tthis.grandTotals[\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\"row\" +\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\targs.row.actualText +\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tfieldName\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}\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t} else {\r\n\t\t\t\t\t\t\targs.value = args.cellSets[lastIndex][fieldName];\r\n\t\t\t\t\t\t}\r\n\r\n\t\t\t\t\t\tif (\r\n\t\t\t\t\t\t\tfield.dataType == \"number\" ||\r\n\t\t\t\t\t\t\tfield.dataType == \"multiple\" ||\r\n\t\t\t\t\t\t\tfield.dataType == \"percent\" ||\r\n\t\t\t\t\t\t\tfield.dataType == \"percentNum\"\r\n\t\t\t\t\t\t) {\r\n\t\t\t\t\t\t\tif (args.value != null) break;\r\n\t\t\t\t\t\t} else if (\r\n\t\t\t\t\t\t\tfield.dataType == \"date\" ||\r\n\t\t\t\t\t\t\tfield.dataType == \"datetime\"\r\n\t\t\t\t\t\t) {\r\n\t\t\t\t\t\t\tif (this.pbf.time(args.value) > \"1900-01-01\") break;\r\n\t\t\t\t\t\t} else if (args.value) break;\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\r\n\t\t\t\tif (\r\n\t\t\t\t\tfield.dataType == \"number\" ||\r\n\t\t\t\t\tfield.dataType == \"multiple\" ||\r\n\t\t\t\t\tfield.dataType == \"percent\" ||\r\n\t\t\t\t\tfield.dataType == \"percentNum\"\r\n\t\t\t\t) {\r\n\t\t\t\t\tif (this.pivotObj.dataSourceSettings.rows.length) {\r\n\t\t\t\t\t\tif (!this.pivotObj.dataSourceSettings.columns.length) {\r\n\t\t\t\t\t\t\tif (\r\n\t\t\t\t\t\t\t\t!Number(this.grandTotals[fieldName]) ||\r\n\t\t\t\t\t\t\t\tisNaN(Number(this.grandTotals[fieldName]))\r\n\t\t\t\t\t\t\t) {\r\n\t\t\t\t\t\t\t\tthis.grandTotals[fieldName] = 0;\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\tif (args.aggregateType !== \"CalculatedField\") {\r\n\t\t\t\t\t\t\t\tthis.grandTotals[fieldName] += Number(\r\n\t\t\t\t\t\t\t\t\targs.value\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} else if (\r\n\t\t\t\t\t\t\tthis.pivotObj.dataSourceSettings.columns.length == 1\r\n\t\t\t\t\t\t) {\r\n\t\t\t\t\t\t\t// \"row\" + args.row.actualText + fieldName 表示(cell: args.rowCellType === \"value\" && args.columnCellType === \"grandTotal\")\r\n\t\t\t\t\t\t\tif (\r\n\t\t\t\t\t\t\t\t!Number(\r\n\t\t\t\t\t\t\t\t\tthis.grandTotals[\r\n\t\t\t\t\t\t\t\t\t\t\"row\" + args.row.actualText + fieldName\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\tisNaN(\r\n\t\t\t\t\t\t\t\t\tNumber(\r\n\t\t\t\t\t\t\t\t\t\tthis.grandTotals[\r\n\t\t\t\t\t\t\t\t\t\t\t\"row\" +\r\n\t\t\t\t\t\t\t\t\t\t\t\targs.row.actualText +\r\n\t\t\t\t\t\t\t\t\t\t\t\tfieldName\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)\r\n\t\t\t\t\t\t\t) {\r\n\t\t\t\t\t\t\t\tthis.grandTotals[\r\n\t\t\t\t\t\t\t\t\t\"row\" + args.row.actualText + fieldName\r\n\t\t\t\t\t\t\t\t] = 0;\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\tthis.grandTotals[\r\n\t\t\t\t\t\t\t\t\"row\" + args.row.actualText + fieldName\r\n\t\t\t\t\t\t\t] += Number(args.value);\r\n\r\n\t\t\t\t\t\t\t// \"col\" + args.column.actualText + fieldName 表示(cell: args.rowCellType === \"grandTotal\" && args.columnCellType === \"value\")\r\n\t\t\t\t\t\t\tif (\r\n\t\t\t\t\t\t\t\t!Number(\r\n\t\t\t\t\t\t\t\t\tthis.grandTotals[\r\n\t\t\t\t\t\t\t\t\t\t\"col\" +\r\n\t\t\t\t\t\t\t\t\t\t\targs.column.actualText +\r\n\t\t\t\t\t\t\t\t\t\t\tfieldName\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\tisNaN(\r\n\t\t\t\t\t\t\t\t\tNumber(\r\n\t\t\t\t\t\t\t\t\t\tthis.grandTotals[\r\n\t\t\t\t\t\t\t\t\t\t\t\"col\" +\r\n\t\t\t\t\t\t\t\t\t\t\t\targs.column.actualText +\r\n\t\t\t\t\t\t\t\t\t\t\t\tfieldName\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)\r\n\t\t\t\t\t\t\t) {\r\n\t\t\t\t\t\t\t\tthis.grandTotals[\r\n\t\t\t\t\t\t\t\t\t\"col\" + args.column.actualText + fieldName\r\n\t\t\t\t\t\t\t\t] = 0;\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\tthis.grandTotals[\r\n\t\t\t\t\t\t\t\t\"col\" + args.column.actualText + fieldName\r\n\t\t\t\t\t\t\t] += Number(args.value);\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\t}\r\n\t\t} else if (args.rowCellType === \"subTotal\" || args.row.hasChild) {\r\n\t\t\tconst dataType = field.dataType;\r\n\t\t\tif (\r\n\t\t\t\tdataType === \"string\" ||\r\n\t\t\t\tdataType === \"nvarchar\" ||\r\n\t\t\t\tdataType == \"date\" ||\r\n\t\t\t\tdataType == \"datetime\"\r\n\t\t\t) {\r\n\t\t\t\targs.value = \"\";\r\n\t\t\t} else {\r\n\t\t\t\tlet value = 0;\r\n\t\t\t\tlet childHeaders = [];\r\n\t\t\t\tif (aggregateType === \"First\") {\r\n\t\t\t\t\tlet groupNameArrays = [];\r\n\t\t\t\t\tlet rows = this.pivotObj.dataSourceSettings.rows;\r\n\t\t\t\t\tfor (\r\n\t\t\t\t\t\tlet index = args.row.level;\r\n\t\t\t\t\t\tindex < rows.length;\r\n\t\t\t\t\t\tindex++\r\n\t\t\t\t\t) {\r\n\t\t\t\t\t\tgroupNameArrays.push(rows[index].name);\r\n\t\t\t\t\t}\r\n\t\t\t\t\tfor (let i = 0; i < args.cellSets.length; i++) {\r\n\t\t\t\t\t\tlet values = [];\r\n\t\t\t\t\t\tlet header = groupNameArrays\r\n\t\t\t\t\t\t\t.map((name) => {\r\n\t\t\t\t\t\t\t\tvalues.push(args.cellSets[i][name]);\r\n\t\t\t\t\t\t\t\treturn args.cellSets[i][name];\r\n\t\t\t\t\t\t\t})\r\n\t\t\t\t\t\t\t.join(\"-\");\r\n\t\t\t\t\t\tif (!(childHeaders as any).includes(header)) {\r\n\t\t\t\t\t\t\tlet filterObj: any = {};\r\n\t\t\t\t\t\t\tgroupNameArrays.map(\r\n\t\t\t\t\t\t\t\t(name, x) => (filterObj[name] = values[x])\r\n\t\t\t\t\t\t\t);\r\n\t\t\t\t\t\t\tlet _CellSets = _filter(args.cellSets, filterObj);\r\n\t\t\t\t\t\t\tchildHeaders.push(header);\r\n\t\t\t\t\t\t\tvalue += Number(_CellSets[0][fieldName]) || 0;\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\t\tif (aggregateType === \"Last\") {\r\n\t\t\t\t\tlet groupNameArrays = [];\r\n\t\t\t\t\tlet rows = this.pivotObj.dataSourceSettings.rows;\r\n\t\t\t\t\tfor (\r\n\t\t\t\t\t\tlet index = args.row.level;\r\n\t\t\t\t\t\tindex < rows.length;\r\n\t\t\t\t\t\tindex++\r\n\t\t\t\t\t) {\r\n\t\t\t\t\t\tgroupNameArrays.push(rows[index].name);\r\n\t\t\t\t\t}\r\n\t\t\t\t\tfor (let i = args.cellSets.length - 1; i >= 0; i--) {\r\n\t\t\t\t\t\tlet values = [];\r\n\t\t\t\t\t\tlet header = groupNameArrays\r\n\t\t\t\t\t\t\t.map((name) => {\r\n\t\t\t\t\t\t\t\tvalues.push(args.cellSets[i][name]);\r\n\t\t\t\t\t\t\t\treturn args.cellSets[i][name];\r\n\t\t\t\t\t\t\t})\r\n\t\t\t\t\t\t\t.join(\"-\");\r\n\t\t\t\t\t\tif (!(childHeaders as any).includes(header)) {\r\n\t\t\t\t\t\t\tlet filterObj: any = {};\r\n\t\t\t\t\t\t\tgroupNameArrays.map(\r\n\t\t\t\t\t\t\t\t(name, x) => (filterObj[name] = values[x])\r\n\t\t\t\t\t\t\t);\r\n\t\t\t\t\t\t\tlet _CellSets = _filter(args.cellSets, filterObj);\r\n\t\t\t\t\t\t\tchildHeaders.push(header);\r\n\t\t\t\t\t\t\tvalue +=\r\n\t\t\t\t\t\t\t\tNumber(\r\n\t\t\t\t\t\t\t\t\t_CellSets[_CellSets.length - 1][fieldName]\r\n\t\t\t\t\t\t\t\t) || 0;\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\tif (args.column.actualText !== \"Grand Total\")\r\n\t\t\t\t\tthis.columnTexts.push(args.column.actualText);\r\n\r\n\t\t\t\tif (!this.pivotObj.dataSourceSettings.columns.length) {\r\n\t\t\t\t\tif (\r\n\t\t\t\t\t\t!Number(this.subTotals[fieldName]) ||\r\n\t\t\t\t\t\tisNaN(Number(this.subTotals[fieldName]))\r\n\t\t\t\t\t) {\r\n\t\t\t\t\t\tthis.subTotals[fieldName] = 0;\r\n\t\t\t\t\t}\r\n\t\t\t\t\tthis.subTotals[fieldName] += Number(value);\r\n\t\t\t\t} else if (\r\n\t\t\t\t\tthis.pivotObj.dataSourceSettings.columns.length == 1\r\n\t\t\t\t) {\r\n\t\t\t\t\tif (\r\n\t\t\t\t\t\t!Number(\r\n\t\t\t\t\t\t\tthis.subTotals[\r\n\t\t\t\t\t\t\t\targs.row.actualText +\r\n\t\t\t\t\t\t\t\t\targs.column.actualText +\r\n\t\t\t\t\t\t\t\t\tfieldName\r\n\t\t\t\t\t\t\t]\r\n\t\t\t\t\t\t) ||\r\n\t\t\t\t\t\tisNaN(\r\n\t\t\t\t\t\t\tNumber(\r\n\t\t\t\t\t\t\t\tthis.subTotals[\r\n\t\t\t\t\t\t\t\t\targs.row.actualText +\r\n\t\t\t\t\t\t\t\t\t\targs.column.actualText +\r\n\t\t\t\t\t\t\t\t\t\tfieldName\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\tthis.subTotals[\r\n\t\t\t\t\t\t\targs.row.actualText +\r\n\t\t\t\t\t\t\t\targs.column.actualText +\r\n\t\t\t\t\t\t\t\tfieldName\r\n\t\t\t\t\t\t] = 0;\r\n\t\t\t\t\t}\r\n\t\t\t\t\tthis.subTotals[\r\n\t\t\t\t\t\targs.row.actualText + args.column.actualText + fieldName\r\n\t\t\t\t\t] += Number(value);\r\n\t\t\t\t}\r\n\t\t\t\t// ---> allDataValue中这个单元格的值不正确\r\n\t\t\t\tif (\r\n\t\t\t\t\targs.columnCellType === \"grandTotal\" &&\r\n\t\t\t\t\tthis.pivotObj.dataSourceSettings.columns.length == 1\r\n\t\t\t\t) {\r\n\t\t\t\t\tif (this.allDataValue && this.allDataValue.length) {\r\n\t\t\t\t\t\targs.value =\r\n\t\t\t\t\t\t\tthis.subTotals[\r\n\t\t\t\t\t\t\t\targs.row.actualText + \"Grand Total\" + fieldName\r\n\t\t\t\t\t\t\t];\r\n\t\t\t\t\t} else {\r\n\t\t\t\t\t\tthis.columnTexts = uniqBy(this.columnTexts, (el) => el);\r\n\t\t\t\t\t\tlet val = 0;\r\n\t\t\t\t\t\tfor (let i = 0; i < this.columnTexts.length; i++) {\r\n\t\t\t\t\t\t\tconst element = this.columnTexts[i];\r\n\t\t\t\t\t\t\tval +=\r\n\t\t\t\t\t\t\t\tthis.subTotals[\r\n\t\t\t\t\t\t\t\t\targs.row.actualText + element + fieldName\r\n\t\t\t\t\t\t\t\t];\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\targs.value = val;\r\n\t\t\t\t\t}\r\n\t\t\t\t} else {\r\n\t\t\t\t\targs.value = value;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t} else if (args.rowCellType === \"grandTotal\") {\r\n\t\t\tconst dataType = field.dataType;\r\n\t\t\tif (\r\n\t\t\t\tdataType == \"string\" ||\r\n\t\t\t\tdataType == \"nvarchar\" ||\r\n\t\t\t\tdataType == \"date\" ||\r\n\t\t\t\tdataType == \"datetime\"\r\n\t\t\t) {\r\n\t\t\t\targs.value = \"\";\r\n\t\t\t} else {\r\n\t\t\t\tif (!this.pivotObj.dataSourceSettings.columns.length) {\r\n\t\t\t\t\tif (this.allDataValue && this.allDataValue.length) {\r\n\t\t\t\t\t\tlet rowObjs =\r\n\t\t\t\t\t\t\tthis.allDataValue[this.allDataValue.length - 1];\r\n\t\t\t\t\t\tif (rowObjs) {\r\n\t\t\t\t\t\t\tlet rowObjsArr = JSON.parse(\r\n\t\t\t\t\t\t\t\tJSON.stringify(rowObjs)\r\n\t\t\t\t\t\t\t);\r\n\t\t\t\t\t\t\tlet objArr = rowObjsArr.filter(\r\n\t\t\t\t\t\t\t\t(el) =>\r\n\t\t\t\t\t\t\t\t\tel.actualText == fieldName && el.isGrandSum\r\n\t\t\t\t\t\t\t);\r\n\t\t\t\t\t\t\tif (objArr && objArr.length) {\r\n\t\t\t\t\t\t\t\targs.value = objArr[objArr.length - 1].value;\r\n\t\t\t\t\t\t\t} else if (\r\n\t\t\t\t\t\t\t\tObject.keys(this.grandTotals).includes(\r\n\t\t\t\t\t\t\t\t\tfieldName\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\t\targs.value = this.grandTotals[fieldName];\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t} else {\r\n\t\t\t\t\t\targs.value = this.grandTotals[fieldName];\r\n\t\t\t\t\t}\r\n\t\t\t\t} else {\r\n\t\t\t\t\tif (args.columnCellType === \"grandTotal\") {\r\n\t\t\t\t\t\tif (this.allDataValue && this.allDataValue.length) {\r\n\t\t\t\t\t\t\tlet rowObjs =\r\n\t\t\t\t\t\t\t\tthis.allDataValue[this.allDataValue.length - 1];\r\n\t\t\t\t\t\t\tif (rowObjs) {\r\n\t\t\t\t\t\t\t\tlet rowObjsArr = JSON.parse(\r\n\t\t\t\t\t\t\t\t\tJSON.stringify(rowObjs)\r\n\t\t\t\t\t\t\t\t);\r\n\t\t\t\t\t\t\t\tlet objArr = rowObjsArr.filter(\r\n\t\t\t\t\t\t\t\t\t(el) =>\r\n\t\t\t\t\t\t\t\t\t\tel.actualText == fieldName &&\r\n\t\t\t\t\t\t\t\t\t\tel.isGrandSum\r\n\t\t\t\t\t\t\t\t);\r\n\t\t\t\t\t\t\t\tif (objArr && objArr.length) {\r\n\t\t\t\t\t\t\t\t\targs.value =\r\n\t\t\t\t\t\t\t\t\t\tobjArr[objArr.length - 1].value;\r\n\t\t\t\t\t\t\t\t} else if (\r\n\t\t\t\t\t\t\t\t\tObject.keys(this.grandTotals).includes(\r\n\t\t\t\t\t\t\t\t\t\t\"col\" +\r\n\t\t\t\t\t\t\t\t\t\t\targs.column.actualText +\r\n\t\t\t\t\t\t\t\t\t\t\tfieldName\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\targs.value =\r\n\t\t\t\t\t\t\t\t\t\tthis.grandTotals[\r\n\t\t\t\t\t\t\t\t\t\t\t\"col\" +\r\n\t\t\t\t\t\t\t\t\t\t\t\targs.column.actualText +\r\n\t\t\t\t\t\t\t\t\t\t\t\tfieldName\r\n\t\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} else {\r\n\t\t\t\t\t\t\targs.value =\r\n\t\t\t\t\t\t\t\tthis.grandTotals[\r\n\t\t\t\t\t\t\t\t\t\"col\" + args.column.actualText + fieldName\r\n\t\t\t\t\t\t\t\t];\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t} else {\r\n\t\t\t\t\t\tif (this.allDataValue && this.allDataValue.length) {\r\n\t\t\t\t\t\t\tlet rowObjs =\r\n\t\t\t\t\t\t\t\tthis.allDataValue[this.allDataValue.length - 1];\r\n\t\t\t\t\t\t\tlet rowObjsArr = JSON.parse(\r\n\t\t\t\t\t\t\t\tJSON.stringify(rowObjs)\r\n\t\t\t\t\t\t\t);\r\n\t\t\t\t\t\t\tlet objArr = rowObjsArr.filter(\r\n\t\t\t\t\t\t\t\t(el) =>\r\n\t\t\t\t\t\t\t\t\tel.actualText == fieldName &&\r\n\t\t\t\t\t\t\t\t\tel.isGrandSum &&\r\n\t\t\t\t\t\t\t\t\tel.columnHeaders == args.column.actualText\r\n\t\t\t\t\t\t\t);\r\n\t\t\t\t\t\t\tif (objArr && objArr.length) {\r\n\t\t\t\t\t\t\t\targs.value = objArr[objArr.length - 1].value;\r\n\t\t\t\t\t\t\t} else if (\r\n\t\t\t\t\t\t\t\tObject.keys(this.grandTotals).includes(\r\n\t\t\t\t\t\t\t\t\t\"col\" + args.column.actualText + fieldName\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\t\targs.value =\r\n\t\t\t\t\t\t\t\t\tthis.grandTotals[\r\n\t\t\t\t\t\t\t\t\t\t\"col\" +\r\n\t\t\t\t\t\t\t\t\t\t\targs.column.actualText +\r\n\t\t\t\t\t\t\t\t\t\t\tfieldName\r\n\t\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} else {\r\n\t\t\t\t\t\t\targs.value =\r\n\t\t\t\t\t\t\t\tthis.grandTotals[\r\n\t\t\t\t\t\t\t\t\t\"col\" + args.column.actualText + fieldName\r\n\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\t\t\t}\r\n\t\t}\r\n\t\tthis.formatVal(args, fieldName);\r\n\t\treturn args.value;\r\n\t}\r\n\r\n\tprivate formatVal(args, fieldName) {\r\n\t\tthis.configFields.forEach((field) => {\r\n\t\t\tif (field.colName == fieldName) {\r\n\t\t\t\tswitch (field.dataType) {\r\n\t\t\t\t\tcase \"date\":\r\n\t\t\t\t\tcase \"datetime\":\r\n\t\t\t\t\t\tif (args.value) args.value = new Date(args.value);\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}\r\n\t\t});\r\n\t}\r\n\r\n\tprivate getexcludeFields(fields, data) {\r\n\t\tlet namearray = [];\r\n\t\tlet array = [];\r\n\t\tfor (let prop in data) {\r\n\t\t\tarray.push(prop);\r\n\t\t}\r\n\t\tfor (let item of fields) {\r\n\t\t\tnamearray.push(item.colName);\r\n\t\t}\r\n\t\tthis.excludeFields = differenceWith(array, namearray);\r\n\t\tif (\r\n\t\t\tthis.excludeFields.length &&\r\n\t\t\tthis.config.groupSettings &&\r\n\t\t\tthis.config.groupSettings.length\r\n\t\t) {\r\n\t\t\tfor (let i = 0; i < this.excludeFields.length; i++) {\r\n\t\t\t\tconst el = this.excludeFields[i];\r\n\t\t\t\tif (startsWith(el, this.config.groupSettings[0].name + \"_\")) {\r\n\t\t\t\t\tthis.excludeFields.splice(i, 1);\r\n\t\t\t\t\ti--;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\tprivate getInfo() {\r\n\t\tthis.datePipeFormat = localStorage.getItem(\"datePipe\");\r\n\t\tthis.translation = JSON.parse(localStorage.getItem(\"translation\"));\r\n\t}\r\n\r\n\tpublic onFieldDrop(args: FieldDropEventArgs) {\r\n\t\tthis.dataSourceSettings.values = [...args.dataSourceSettings.values];\r\n\t\t//change the calcualteField method use the corresponding calculate\r\n\t\tconst calcualteField = this.configFields.filter(\r\n\t\t\t(el) => el.colName === args.fieldName && el.isCalculatedField\r\n\t\t);\r\n\t\tif (calcualteField.length > 0) {\r\n\t\t\targs.dropField.type =\r\n\t\t\t\tthis.dashboardPorletsService.getCalculateMethod(\r\n\t\t\t\t\tcalcualteField[0].colName\r\n\t\t\t\t) as any;\r\n\t\t\targs.dropField.caption = args.dropField.caption\r\n\t\t\t\t.replace(\"Calculate\", \"\")\r\n\t\t\t\t.trim();\r\n\t\t}\r\n\t\tfor (\r\n\t\t\tlet i = 0;\r\n\t\t\ti < args.dataSourceSettings.filterSettings.length;\r\n\t\t\ti++\r\n\t\t) {\r\n\t\t\tif (\r\n\t\t\t\targs.dataSourceSettings.filterSettings[i].name ===\r\n\t\t\t\t\targs.fieldName &&\r\n\t\t\t\targs.dropAxis === \"\"\r\n\t\t\t) {\r\n\t\t\t\targs.dataSourceSettings.filterSettings.splice(i, 1);\r\n\t\t\t\tthis.filterSettings = args.dataSourceSettings.filterSettings;\r\n\t\t\t\tbreak;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\t// Calculated field事件：创建\r\n\tpublic calculatedFieldCreate(args: CalculatedFieldCreateEventArgs) {\r\n\t\tif (\r\n\t\t\targs.calculatedField.name !== \"\" &&\r\n\t\t\targs.calculatedField.name.trim() !== \"\"\r\n\t\t) {\r\n\t\t\tlet index =\r\n\t\t\t\tthis.fieldlistObj.dataSourceSettings.calculatedFieldSettings.findIndex(\r\n\t\t\t\t\t(el) => el.name === args.calculatedField.name\r\n\t\t\t\t);\r\n\t\t\tif (index !== -1) {\r\n\t\t\t\tif (args.calculatedField.formatString === \"\") {\r\n\t\t\t\t\tthis.fieldlistObj.dataSourceSettings.calculatedFieldSettings[\r\n\t\t\t\t\t\tindex\r\n\t\t\t\t\t].formatString = \"N2\";\r\n\t\t\t\t} else {\r\n\t\t\t\t\tthis.fieldlistObj.dataSourceSettings.calculatedFieldSettings[\r\n\t\t\t\t\t\tindex\r\n\t\t\t\t\t].formatString = args.calculatedField.formatString;\r\n\t\t\t\t}\r\n\t\t\t} else {\r\n\t\t\t\tif (args.calculatedField.formatString === \"\") {\r\n\t\t\t\t\targs.calculatedField.formatString = \"N2\";\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\t// 移除重复\r\n\t\t\tlet fIndex = this.customCalculatedFields.findIndex(\r\n\t\t\t\t(f) => f.name === args.calculatedField.name\r\n\t\t\t);\r\n\t\t\tif (fIndex > -1) {\r\n\t\t\t\tthis.customCalculatedFields.splice(fIndex, 1);\r\n\t\t\t}\r\n\t\t\t// 匹配运算符 First || Last\r\n\t\t\tlet formulaStr = args.calculatedField.formula;\r\n\t\t\tlet reg1 = /\"First\\((.+?)\\)\"/g;\r\n\t\t\tlet reg2 = /\"Last\\((.+?)\\)\"/g;\r\n\t\t\tif (reg1.test(formulaStr) || reg2.test(formulaStr)) {\r\n\t\t\t\t// 判断是否存在First || Last 表达式\r\n\t\t\t\tlet matchFirstFields = Array.from(\r\n\t\t\t\t\tformulaStr[\"matchAll\"](/\"First\\((.+?)\\)\"/g),\r\n\t\t\t\t\t(m) => {\r\n\t\t\t\t\t\treturn {\r\n\t\t\t\t\t\t\tmatchStr: m[0],\r\n\t\t\t\t\t\t\tmatchWord: m[1],\r\n\t\t\t\t\t\t\treplaceValue: \"\",\r\n\t\t\t\t\t\t\tmatchMethod: \"First\",\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\t\tlet matchLastFields = Array.from(\r\n\t\t\t\t\tformulaStr[\"matchAll\"](/\"Last\\((.+?)\\)\"/g),\r\n\t\t\t\t\t(m) => {\r\n\t\t\t\t\t\treturn {\r\n\t\t\t\t\t\t\tmatchStr: m[0],\r\n\t\t\t\t\t\t\tmatchWord: m[1],\r\n\t\t\t\t\t\t\treplaceValue: \"\",\r\n\t\t\t\t\t\t\tmatchMethod: \"Last\",\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\t\tlet matchMaxFields = Array.from(\r\n\t\t\t\t\tformulaStr[\"matchAll\"](/\"Max\\((.+?)\\)\"/g),\r\n\t\t\t\t\t(m) => {\r\n\t\t\t\t\t\treturn {\r\n\t\t\t\t\t\t\tmatchStr: m[0],\r\n\t\t\t\t\t\t\tmatchWord: m[1],\r\n\t\t\t\t\t\t\treplaceValue: \"\",\r\n\t\t\t\t\t\t\tmatchMethod: \"Max\",\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\t\tlet matchMinFields = Array.from(\r\n\t\t\t\t\tformulaStr[\"matchAll\"](/\"Min\\((.+?)\\)\"/g),\r\n\t\t\t\t\t(m) => {\r\n\t\t\t\t\t\treturn {\r\n\t\t\t\t\t\t\tmatchStr: m[0],\r\n\t\t\t\t\t\t\tmatchWord: m[1],\r\n\t\t\t\t\t\t\treplaceValue: \"\",\r\n\t\t\t\t\t\t\tmatchMethod: \"Min\",\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\t\tlet matchSumFields = Array.from(\r\n\t\t\t\t\tformulaStr[\"matchAll\"](/\"Sum\\((.+?)\\)\"/g),\r\n\t\t\t\t\t(m) => {\r\n\t\t\t\t\t\treturn {\r\n\t\t\t\t\t\t\tmatchStr: m[0],\r\n\t\t\t\t\t\t\tmatchWord: m[1],\r\n\t\t\t\t\t\t\treplaceValue: \"\",\r\n\t\t\t\t\t\t\tmatchMethod: \"Sum\",\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\t\tlet matchAvgFields = Array.from(\r\n\t\t\t\t\tformulaStr[\"matchAll\"](/\"Avg\\((.+?)\\)\"/g),\r\n\t\t\t\t\t(m) => {\r\n\t\t\t\t\t\treturn {\r\n\t\t\t\t\t\t\tmatchStr: m[0],\r\n\t\t\t\t\t\t\tmatchWord: m[1],\r\n\t\t\t\t\t\t\treplaceValue: \"\",\r\n\t\t\t\t\t\t\tmatchMethod: \"Avg\",\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\t\tif (\r\n\t\t\t\t\tmatchFirstFields.every((x) =>\r\n\t\t\t\t\t\tthis.allowedCalculatedFields.includes(x.matchWord)\r\n\t\t\t\t\t) &&\r\n\t\t\t\t\tmatchLastFields.every((x) =>\r\n\t\t\t\t\t\tthis.allowedCalculatedFields.includes(x.matchWord)\r\n\t\t\t\t\t)\r\n\t\t\t\t) {\r\n\t\t\t\t\t// 判断First和Last表达式内的字段是否合法\r\n\t\t\t\t\tthis.customCalculatedFields.push({\r\n\t\t\t\t\t\tname: args.calculatedField.name,\r\n\t\t\t\t\t\tformula: args.calculatedField.formula,\r\n\t\t\t\t\t\tmatchFields: [\r\n\t\t\t\t\t\t\t// @ts-ignore\r\n\t\t\t\t\t\t\t...matchFirstFields,\r\n\t\t\t\t\t\t\t...matchLastFields,\r\n\t\t\t\t\t\t\t...matchMaxFields,\r\n\t\t\t\t\t\t\t...matchMinFields,\r\n\t\t\t\t\t\t\t...matchSumFields,\r\n\t\t\t\t\t\t\t...matchAvgFields,\r\n\t\t\t\t\t\t],\r\n\t\t\t\t\t\tgrandTotal: 0,\r\n\t\t\t\t\t});\r\n\t\t\t\t\tlet fieldName = (\r\n\t\t\t\t\t\tformulaStr.split(\"First(\")[1] ||\r\n\t\t\t\t\t\tformulaStr.split(\"Last(\")[1]\r\n\t\t\t\t\t).split(\")\")[0];\r\n\t\t\t\t\targs.calculatedField.formula =\r\n\t\t\t\t\t\t\"'\\\"\" + \"Sum(\" + fieldName + ')\"=' + formulaStr + \"'\";\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\t// Calculated field事件：完成\r\n\tpublic actionComplete(args) {\r\n\t\tif (\r\n\t\t\targs.actionName === \"Field aggregated\" ||\r\n\t\t\targs.actionName === \"Field list closed\"\r\n\t\t) {\r\n\t\t\tthis.dataSourceSettings.values = [\r\n\t\t\t\t...args.dataSourceSettings.values,\r\n\t\t\t];\r\n\t\t\tthis.setValueItemData();\r\n\t\t}\r\n\t\tif (args.actionName == \"Field removed\") {\r\n\t\t\tif (\r\n\t\t\t\targs.fieldInfo &&\r\n\t\t\t\targs.fieldInfo.fieldItem &&\r\n\t\t\t\targs.fieldInfo.fieldItem.type == \"CalculatedField\"\r\n\t\t\t) {\r\n\t\t\t\tlet field = args.fieldInfo.fieldName;\r\n\t\t\t\t// Remove the deleted calculated field from an stored array.\r\n\t\t\t\tthis.customCalculatedFields =\r\n\t\t\t\t\tthis.customCalculatedFields.filter(function (obj) {\r\n\t\t\t\t\t\treturn obj.name !== field;\r\n\t\t\t\t\t});\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\t// Calculated field事件：开始\r\n\tpublic actionBegin(args) {\r\n\t\tif (args.actionName === \"Edit calculated field\") {\r\n\t\t\tfor (let i = 0; i < this.customCalculatedFields.length; i++) {\r\n\t\t\t\tif (\r\n\t\t\t\t\tthis.customCalculatedFields[i].name &&\r\n\t\t\t\t\tthis.pivotObj.engineModule.fieldList[\r\n\t\t\t\t\t\tthis.customCalculatedFields[i].name\r\n\t\t\t\t\t]\r\n\t\t\t\t) {\r\n\t\t\t\t\tthis.pivotObj.engineModule.fieldList[\r\n\t\t\t\t\t\tthis.customCalculatedFields[i].name\r\n\t\t\t\t\t].formula = this.customCalculatedFields[i].formula;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\tprivate resizeStop(args) {\r\n\t\tif (this.config.columnsWidth) {\r\n\t\t\tconst header_field = this.config.columnsWidth.filter(\r\n\t\t\t\t(el) => el.headerText === args.column.headerText\r\n\t\t\t);\r\n\t\t\tif (header_field.length > 0) {\r\n\t\t\t\theader_field[0].width = parseInt(args.column.width);\r\n\t\t\t} else {\r\n\t\t\t\tthis.config.columnsWidth.push({\r\n\t\t\t\t\theaderText: args.column.headerText,\r\n\t\t\t\t\twidth: parseInt(args.column.width),\r\n\t\t\t\t});\r\n\t\t\t}\r\n\t\t} else {\r\n\t\t\tthis.config.columnsWidth = [];\r\n\t\t\tthis.config.columnsWidth.push({\r\n\t\t\t\theaderText: args.column.headerText,\r\n\t\t\t\twidth: parseInt(args.column.width),\r\n\t\t\t});\r\n\t\t}\r\n\t\tconst portlet = this.portlet;\r\n\t\tportlet.config = JSON.stringify(this.config);\r\n\t\tconst index = this.portlets.findIndex((x) => x.newId === portlet.newId);\r\n\t\tif (index > -1) this.portlets[index] = portlet;\r\n\t}\r\n\r\n\tprivate setColumnsRender(args) {\r\n\t\tif (args.stackedColumns) {\r\n\t\t\targs.stackedColumns.forEach((col) => {\r\n\t\t\t\tif (\r\n\t\t\t\t\tcol.format &&\r\n\t\t\t\t\t(col.format.indexOf(\"N\") !== -1 ||\r\n\t\t\t\t\t\tcol.format === \"percent\" ||\r\n\t\t\t\t\t\tcol.format.indexOf(\"P\") !== -1)\r\n\t\t\t\t) {\r\n\t\t\t\t\tcol.textAlign = \"Right\";\r\n\t\t\t\t}\r\n\t\t\t});\r\n\t\t}\r\n\r\n\t\tif (this.config.columnsWidth) {\r\n\t\t\tfor (let i = 0; i < (args as any).columns.length; i++) {\r\n\t\t\t\tif (\r\n\t\t\t\t\targs.columns[i].headerText === \"\" ||\r\n\t\t\t\t\t!args.columns[i].headerText\r\n\t\t\t\t) {\r\n\t\t\t\t\tconst column_row = this.config.columnsWidth.filter(\r\n\t\t\t\t\t\t(el) => el.headerText === args.columns[i].headerText\r\n\t\t\t\t\t);\r\n\t\t\t\t\tif (column_row.length > 0) {\r\n\t\t\t\t\t\targs.columns[i].width = column_row[0].width;\r\n\t\t\t\t\t}\r\n\t\t\t\t} else {\r\n\t\t\t\t\tconst headerText = args.columns[i].headerText\r\n\t\t\t\t\t\t.replace(/\\s+/g, \"\")\r\n\t\t\t\t\t\t.split(\".\");\r\n\t\t\t\t\tif (headerText && headerText.length > 0) {\r\n\t\t\t\t\t\tconst column = this.config.columnsWidth.filter(\r\n\t\t\t\t\t\t\t(el) =>\r\n\t\t\t\t\t\t\t\tel.headerText\r\n\t\t\t\t\t\t\t\t\t.replace(/\\s+/g, \"\")\r\n\t\t\t\t\t\t\t\t\t.toLowerCase() ===\r\n\t\t\t\t\t\t\t\theaderText[headerText.length - 1].toLowerCase()\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\t\tif (column.length > 0) {\r\n\t\t\t\t\t\t\t(args as any).columns[i].width = column[0].width;\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\t\t// date format about quarterly\r\n\t\t\t\tlet pivotValues: any = this.pivotObj.pivotValues;\r\n\t\t\t\tif (this.formatDates && this.formatDates.length) {\r\n\t\t\t\t\tlet dateFields = this.formatDates.map((el) => {\r\n\t\t\t\t\t\treturn el.name;\r\n\t\t\t\t\t});\r\n\t\t\t\t\tfor (let k = 1; k < pivotValues.length; k++) {\r\n\t\t\t\t\t\tfor (\r\n\t\t\t\t\t\t\tlet j = 0;\r\n\t\t\t\t\t\t\tpivotValues[k] != null && j < pivotValues[k].length;\r\n\t\t\t\t\t\t\tj++\r\n\t\t\t\t\t\t) {\r\n\t\t\t\t\t\t\tif (\r\n\t\t\t\t\t\t\t\tpivotValues[k][j] != null &&\r\n\t\t\t\t\t\t\t\t(j == 0\r\n\t\t\t\t\t\t\t\t\t? dateFields.includes(\r\n\t\t\t\t\t\t\t\t\t\t\tpivotValues[k][j].valueSort.axis\r\n\t\t\t\t\t\t\t\t\t  )\r\n\t\t\t\t\t\t\t\t\t: dateFields.includes(\r\n\t\t\t\t\t\t\t\t\t\t\tpivotValues[k][j].actualText\r\n\t\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\t\t//Customize the Row headers/Column headers based on your needs\r\n\t\t\t\t\t\t\t\tlet headers;\r\n\t\t\t\t\t\t\t\tif (j === 0) {\r\n\t\t\t\t\t\t\t\t\theaders = pivotValues[k][j].actualText;\r\n\t\t\t\t\t\t\t\t} else {\r\n\t\t\t\t\t\t\t\t\t// headers = pivotValues[k][j].formattedText;\r\n\t\t\t\t\t\t\t\t\theaders = pivotValues[k][j].value;\r\n\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t\tif (headers) {\r\n\t\t\t\t\t\t\t\t\tlet date = new Date(headers);\r\n\r\n\t\t\t\t\t\t\t\t\tlet quarter =\r\n\t\t\t\t\t\t\t\t\t\tMath.floor(date.getMonth() / 3) + 1;\r\n\r\n\t\t\t\t\t\t\t\t\tlet format;\r\n\r\n\t\t\t\t\t\t\t\t\tthis.formatDates.map((el) => {\r\n\t\t\t\t\t\t\t\t\t\tif (j == 0) {\r\n\t\t\t\t\t\t\t\t\t\t\tif (\r\n\t\t\t\t\t\t\t\t\t\t\t\tel.name ==\r\n\t\t\t\t\t\t\t\t\t\t\t\tpivotValues[k][j].valueSort.axis\r\n\t\t\t\t\t\t\t\t\t\t\t)\r\n\t\t\t\t\t\t\t\t\t\t\t\tformat = el.format;\r\n\t\t\t\t\t\t\t\t\t\t} else {\r\n\t\t\t\t\t\t\t\t\t\t\tif (\r\n\t\t\t\t\t\t\t\t\t\t\t\tel.name ==\r\n\t\t\t\t\t\t\t\t\t\t\t\tpivotValues[k][j].actualText\r\n\t\t\t\t\t\t\t\t\t\t\t)\r\n\t\t\t\t\t\t\t\t\t\t\t\tformat = el.format;\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\tpivotValues[k][j].formattedText =\r\n\t\t\t\t\t\t\t\t\t\tthis.getQuarterValue(\r\n\t\t\t\t\t\t\t\t\t\t\tformat,\r\n\t\t\t\t\t\t\t\t\t\t\tdate,\r\n\t\t\t\t\t\t\t\t\t\t\tquarter\r\n\t\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}\r\n\t\t\t}\r\n\t\t\t// if(this.pivotObj) this.pivotObj.refreshData();\r\n\t\t}\r\n\t}\r\n\r\n\tpublic onLoad(): void {\r\n\t\t// SMP2-15651 开启虚拟滚动并sort列后，来回滚动会导致数据空白\r\n\t\t// 官方链接 https://ej2.syncfusion.com/angular/documentation/pivotview/virtual-scrolling#virtual-scrolling-for-static-field-list\r\n\t\t// Demo链接 https://stackblitz.com/edit/github-7ggk2u-4rkzb3?file=src%2Fapp.component.ts\r\n\t\t(this.fieldlistObj as PivotFieldListComponent).pivotGridModule = this\r\n\t\t\t.pivotObj as PivotViewComponent;\r\n\t}\r\n\r\n\tondataBound(){\r\n\t\tif (Browser.isDevice) {\r\n            this.pivotObj.element.style.width = '100%';\r\n            this.pivotObj.allowCalculatedField = true;\r\n            this.pivotObj.showFieldList = true;\r\n        }\r\n\t}\r\n\r\n\tprivate enginePopulated(args) {\r\n\t\tlet clonedValues: IPivotValues;\r\n\t\tlet currentPivotValues: any = this.getClonedPivotValues(\r\n\t\t\tthis.pivotObj.engineModule.pivotValues\r\n\t\t);\r\n\t\tlet pageSettings: IPageSettings =\r\n\t\t\tthis.pivotObj.engineModule.pageSettings;\r\n\r\n\t\tif (this.pivotObj.engineModule.generateGridData) {\r\n\t\t\t// 没法复现 https://raiselp.atlassian.net/browse/SMP2-1724 处理的这个问题情况, 直接注释掉\r\n\t\t\t// 下面这段代码会影响 https://raiselp.atlassian.net/browse/SMP2-12139\r\n\t\t\t// this.pivotObj.engineModule.generateGridData(\r\n\t\t\t// \tthis.pivotObj.dataSourceSettings,\r\n\t\t\t// \ttrue\r\n\t\t\t// );\r\n\t\t\tclonedValues = this.getClonedPivotValues(\r\n\t\t\t\tthis.pivotObj.engineModule.pivotValues\r\n\t\t\t);\r\n\r\n\t\t\tthis.pivotObj.engineModule.pivotValues = currentPivotValues;\r\n\r\n\t\t\tthis.pivotObj.engineModule.pageSettings = pageSettings;\r\n\r\n\t\t\t// Here \"clonedValues\" contains the whole pivot values.\r\n\t\t\tthis.allDataValue = clonedValues;\r\n\t\t}\r\n\t}\r\n\r\n\tprivate getClonedPivotValues(pivotValues: IPivotValues): IPivotValues {\r\n\t\tlet clonedSets: IPivotValues = [];\r\n\t\tif (pivotValues && pivotValues.length) {\r\n\t\t\tfor (let i: number = 0; i < pivotValues.length; i++) {\r\n\t\t\t\tif (pivotValues[i]) {\r\n\t\t\t\t\tclonedSets[i] = [];\r\n\t\t\t\t\tfor (let j: number = 0; j < pivotValues[i].length; j++) {\r\n\t\t\t\t\t\tif (pivotValues[i][j]) {\r\n\t\t\t\t\t\t\t/* eslint-disable */\r\n\t\t\t\t\t\t\tclonedSets[i][j] = this.getClonedPivotValueObj(\r\n\t\t\t\t\t\t\t\tpivotValues[i][j] as { [key: string]: Object }\r\n\t\t\t\t\t\t\t);\r\n\t\t\t\t\t\t\t/* eslint-enable */\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\t}\r\n\t\t}\r\n\t\treturn clonedSets;\r\n\t}\r\n\r\n\tprivate getClonedPivotValueObj(data: { [key: string]: Object }): {\r\n\t\t[key: string]: Object;\r\n\t} {\r\n\t\tlet keyPos: number = 0;\r\n\t\tlet framedSet: any = {};\r\n\t\tif (!(data === null || data === undefined)) {\r\n\t\t\tlet fields: string[] = Object.keys(data);\r\n\t\t\twhile (keyPos < fields.length) {\r\n\t\t\t\tframedSet[fields[keyPos]] = data[fields[keyPos]];\r\n\t\t\t\tkeyPos++;\r\n\t\t\t}\r\n\t\t} else {\r\n\t\t\tframedSet = data;\r\n\t\t}\r\n\t\treturn framedSet;\r\n\t}\r\n\r\n\t//#region Filtering the TreeNodes\r\n\tprivate searchNodes(args) {\r\n\t\tlet _text = args.maskedValue;\r\n\t\tlet predicats = [],\r\n\t\t\t_array = [],\r\n\t\t\t_filter = [];\r\n\t\tif (_text == \"\") {\r\n\t\t\tthis.changeDataSource(\r\n\t\t\t\t((this as any).fieldlistObj.treeViewModule as any).getTreeData()\r\n\t\t\t);\r\n\t\t} else {\r\n\t\t\tlet predicate = new Predicate(\"caption\", \"contains\", _text, true);\r\n\t\t\tlet filteredList = new DataManager(\r\n\t\t\t\t((this as any).fieldlistObj.treeViewModule as any).getTreeData()\r\n\t\t\t).executeLocal(new Query().where(predicate));\r\n\t\t\tfor (let j = 0; j < filteredList.length; j++) {\r\n\t\t\t\t_filter.push(filteredList[j][\"id\"]);\r\n\t\t\t\tlet filters = this.getFilterItems(\r\n\t\t\t\t\tfilteredList[j],\r\n\t\t\t\t\t(\r\n\t\t\t\t\t\t(this as any).fieldlistObj.treeViewModule as any\r\n\t\t\t\t\t).getTreeData()\r\n\t\t\t\t);\r\n\t\t\t\tfor (let i = 0; i < filters.length; i++) {\r\n\t\t\t\t\tif (\r\n\t\t\t\t\t\t_array.indexOf(filters[i]) == -1 &&\r\n\t\t\t\t\t\tfilters[i] != null\r\n\t\t\t\t\t) {\r\n\t\t\t\t\t\t_array.push(filters[i]);\r\n\t\t\t\t\t\tpredicats.push(\r\n\t\t\t\t\t\t\tnew Predicate(\"id\", \"equal\", filters[i], false)\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\t}\r\n\t\t\tif (predicats.length == 0) {\r\n\t\t\t\tthis.changeDataSource([]);\r\n\t\t\t} else {\r\n\t\t\t\tlet query = new Query().where(Predicate.or(predicats));\r\n\t\t\t\tlet newList = new DataManager(\r\n\t\t\t\t\t(\r\n\t\t\t\t\t\t(this as any).fieldlistObj.treeViewModule as any\r\n\t\t\t\t\t).getTreeData()\r\n\t\t\t\t).executeLocal(query);\r\n\t\t\t\tthis.changeDataSource(newList);\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\t//Find the Parent Nodes for corresponding childs\r\n\tpublic getFilterItems(fList, list) {\r\n\t\tlet nodes = [];\r\n\t\tnodes.push(fList[\"id\"]);\r\n\t\tlet query2 = new Query().where(\"id\", \"equal\", fList[\"pid\"], false);\r\n\t\tlet fList1 = new DataManager(list).executeLocal(query2);\r\n\t\tif (fList1.length != 0) {\r\n\t\t\tlet pNode = this.getFilterItems(fList1[0], list);\r\n\t\t\tfor (let i = 0; i < pNode.length; i++) {\r\n\t\t\t\tif (nodes.indexOf(pNode[i]) == -1 && pNode[i] != null)\r\n\t\t\t\t\tnodes.push(pNode[i]);\r\n\t\t\t}\r\n\t\t\treturn nodes;\r\n\t\t}\r\n\t\treturn nodes;\r\n\t}\r\n\r\n\tpublic created(args: any) {\r\n\t\tif (this.fieldlistObj && !this.fieldlistObj.engineModule.fields) {\r\n\t\t\tthis.fieldlistObj.engineModule.fields = [];\r\n\t\t}\r\n\t\tlet search = document.createElement(\"input\");\r\n\t\tsearch.id = \"pivotSearchBox\" + this.fieldlistObj.element.id;\r\n\t\tlet el = document.querySelector(\r\n\t\t\t\"#\" + this.fieldlistObj.element.id + \"_Container .e-field-table\"\r\n\t\t);\r\n\t\tif (el) el.prepend(search);\r\n\t\tthis.pivotSearchBox = new MaskedTextBox({\r\n\t\t\tplaceholder: this.translation.SEARCH || \".SEARCH\",\r\n\t\t\tcssClass: \"pivot-search\",\r\n\t\t\tchange: this.searchNodes.bind(this),\r\n\t\t});\r\n\t\tthis.pivotSearchBox.appendTo(\r\n\t\t\t\"#pivotSearchBox\" + this.fieldlistObj.element.id\r\n\t\t);\r\n\r\n\t\t// NEW Dashboard 点击\"apply\"时，请求新数据\r\n\t\tlet applyBtn = document.getElementById(\r\n\t\t\tthis.fieldlistObj.element.id + \"_DeferUpdateButton1\"\r\n\t\t);\r\n\r\n\t\tapplyBtn &&\r\n\t\t\tapplyBtn.addEventListener(\"click\", () => {\r\n\t\t\t\tthis.pageLoading = true;\r\n\t\t\t\tthis.dashboardPorletsService.getDataByPortletsNew(\r\n\t\t\t\t\t[this.portlet],\r\n\t\t\t\t\t() => {\r\n\t\t\t\t\t\tthis.pageLoading = false;\r\n\t\t\t\t\t\tthis.Pivot_Data =\r\n\t\t\t\t\t\t\tthis.dashboardPorletsService.getResultByDataTable(\r\n\t\t\t\t\t\t\t\tthis.portlet,\r\n\t\t\t\t\t\t\t\tfalse,\r\n\t\t\t\t\t\t\t\tfalse,\r\n\t\t\t\t\t\t\t\tthis.dashboard.id\r\n\t\t\t\t\t\t\t);\r\n\t\t\t\t\t\tthis.pivotObj.dataSourceSettings.dataSource =\r\n\t\t\t\t\t\t\tthis.Pivot_Data;\r\n\r\n\t\t\t\t\t\tif (this.Pivot_Data) {\r\n\t\t\t\t\t\t\tlet groups = this.config.xaxis.groups;\r\n\t\t\t\t\t\t\tlet rows = [];\r\n\t\t\t\t\t\t\tif (groups) {\r\n\t\t\t\t\t\t\t\tfor (let gitem of groups) {\r\n\t\t\t\t\t\t\t\t\tconst field = this.configFields.filter(\r\n\t\t\t\t\t\t\t\t\t\t(el) => el.colName === gitem.name\r\n\t\t\t\t\t\t\t\t\t);\r\n\t\t\t\t\t\t\t\t\tif (field.length > 0) {\r\n\t\t\t\t\t\t\t\t\t\tgitem.showSubTotals =\r\n\t\t\t\t\t\t\t\t\t\t\tfield[0].showSubTotals;\r\n\t\t\t\t\t\t\t\t\t\tgitem.caption =\r\n\t\t\t\t\t\t\t\t\t\t\tfield[0].langValue ||\r\n\t\t\t\t\t\t\t\t\t\t\tthis.translation[\r\n\t\t\t\t\t\t\t\t\t\t\t\tfield[0].langCode\r\n\t\t\t\t\t\t\t\t\t\t\t] ||\r\n\t\t\t\t\t\t\t\t\t\t\tfield[0].langCode ||\r\n\t\t\t\t\t\t\t\t\t\t\tgitem.caption;\r\n\t\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t\t\trows.push(gitem);\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\tthis.Pivot_Data.map((data) => {\r\n\t\t\t\t\t\t\t\trows.forEach((row) => {\r\n\t\t\t\t\t\t\t\t\tif (data[row.name] === \"\") {\r\n\t\t\t\t\t\t\t\t\t\tdata[row.name] = \"null\";\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\tif (this.pivotObj) this.pivotObj.refreshData();\r\n\t\t\t\t\t\tthis.ref.markForCheck();\r\n\t\t\t\t\t\tthis.ref.detectChanges();\r\n\t\t\t\t\t},\r\n\t\t\t\t\tnull,\r\n\t\t\t\t\tfalse,\r\n\t\t\t\t\tthis.dashboard,\r\n\t\t\t\t\tfalse\r\n\t\t\t\t);\r\n\t\t\t});\r\n\t\t\t\r\n\t\t// 点击\"cancel\"时，恢复原始数据\r\n\t\tlet cancelBtn = document.getElementById(\r\n\t\t\tthis.fieldlistObj.element.id + \"_DeferUpdateButton2\"\r\n\t\t);\r\n\r\n\t\tcancelBtn &&\r\n\t\t\tcancelBtn.addEventListener(\"click\", () => {\r\n\t\t\t\tthis.pivotObj.dataSourceSettings.dataSource =\r\n\t\t\t\t\t[...this.Pivot_Data];\r\n\t\t\t\tif (this.pivotObj) this.pivotObj.refreshData();\r\n\t\t\t\tthis.ref.markForCheck();\r\n\t\t\t\tthis.ref.detectChanges();\r\n\t\t\t});\t\t\r\n\t}\r\n\r\n\tpublic fieldListRefreshed(args) {\r\n\t\tif (this.pivotSearchBox) {\r\n\t\t\tthis.pivotSearchBox.value = \"\";\r\n\t\t\tthis.changeDataSource(\r\n\t\t\t\t(this.fieldlistObj.treeViewModule as any).getTreeData()\r\n\t\t\t);\r\n\t\t}\r\n\t}\r\n\r\n\tprivate changeDataSource(data) {\r\n\t\tlet fieldTable = (this as any).fieldlistObj.treeViewModule.fieldTable;\r\n\t\tif (fieldTable) {\r\n\t\t\tfieldTable.fields = {\r\n\t\t\t\tdataSource: data,\r\n\t\t\t\tid: \"id\",\r\n\t\t\t\ttext: \"caption\",\r\n\t\t\t\tisChecked: \"isSelected\",\r\n\t\t\t\tparentID: \"pid\",\r\n\t\t\t\ticonCss: \"spriteCssClass\",\r\n\t\t\t};\r\n\t\t}\r\n\t}\r\n\r\n\t//SMP2-2957 fix the date issue on the raw data\r\n\tpublic drillThrough(args: DrillThroughEventArgs) {\r\n\t\tfor (let i = 0; i < args.gridColumns.length; i++) {\r\n\t\t\tconst data = this.configFields.filter(\r\n\t\t\t\t(el) => el.colName === args.gridColumns[i].field\r\n\t\t\t);\r\n\t\t\tif (data && data.length > 0) {\r\n\t\t\t\tif (\r\n\t\t\t\t\tdata[0].dataType === \"date\" ||\r\n\t\t\t\t\tdata[0].dataType === \"datetime\"\r\n\t\t\t\t) {\r\n\t\t\t\t\targs.gridColumns[i].type = \"date\";\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\t//#endregion\r\n\r\n\tprivate setFontSettingConditional(obj, data, code) {\r\n\t\tif (code === -1) {\r\n\t\t\tobj.style.color = data.negaFontColor;\r\n\t\t\tobj.style.fontFamily = data.negaFontFamilyValue;\r\n\t\t\tobj.style.fontSize = data.negaFontSizeValue;\r\n\t\t\tobj.style.backgroundColor = data.negaBackgroundColor;\r\n\t\t} else {\r\n\t\t\tobj.style.color = data.fontColor;\r\n\t\t\tobj.style.fontFamily = data.fontFamilyValue;\r\n\t\t\tobj.style.fontSize = data.fontSizeValue;\r\n\t\t\tobj.style.backgroundColor = data.backgroundColor;\r\n\t\t}\r\n\t}\r\n\r\n\tprivate setCompareConditional(\r\n\t\tnegaConditionalFormatObj,\r\n\t\tconditionalFormatObj,\r\n\t\tdata\r\n\t) {\r\n\t\tif (Math.sign(data.compareValue1) == 0) {\r\n\t\t\tswitch (data.compareSelect) {\r\n\t\t\t\tcase \"LessThan\": // 小于\r\n\t\t\t\tcase \"LessThanOrEqualTo\": // 小于等于\r\n\t\t\t\t\tnegaConditionalFormatObj.value1 = 0;\r\n\t\t\t\t\tnegaConditionalFormatObj.conditions = \"LessThan\";\r\n\t\t\t\t\tthis.setFontSettingConditional(\r\n\t\t\t\t\t\tnegaConditionalFormatObj,\r\n\t\t\t\t\t\tdata,\r\n\t\t\t\t\t\t-1\r\n\t\t\t\t\t);\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase \"GreaterThan\": // 大于\r\n\t\t\t\tcase \"GreaterThanOrEqualTo\": // 大于等于\r\n\t\t\t\t\tconditionalFormatObj.value1 = 0;\r\n\t\t\t\t\tconditionalFormatObj.conditions = \"GreaterThan\";\r\n\t\t\t\t\tthis.setFontSettingConditional(\r\n\t\t\t\t\t\tconditionalFormatObj,\r\n\t\t\t\t\t\tdata,\r\n\t\t\t\t\t\t1\r\n\t\t\t\t\t);\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase \"NotEquals\": // 不等于\r\n\t\t\t\t\tnegaConditionalFormatObj.value1 = 0;\r\n\t\t\t\t\tnegaConditionalFormatObj.conditions = \"LessThan\";\r\n\t\t\t\t\tthis.setFontSettingConditional(\r\n\t\t\t\t\t\tnegaConditionalFormatObj,\r\n\t\t\t\t\t\tdata,\r\n\t\t\t\t\t\t-1\r\n\t\t\t\t\t);\r\n\t\t\t\t\tconditionalFormatObj.value1 = 0;\r\n\t\t\t\t\tconditionalFormatObj.conditions = \"GreaterThan\";\r\n\t\t\t\t\tthis.setFontSettingConditional(\r\n\t\t\t\t\t\tconditionalFormatObj,\r\n\t\t\t\t\t\tdata,\r\n\t\t\t\t\t\t1\r\n\t\t\t\t\t);\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase \"Between\": // value1<= val <=value2\r\n\t\t\t\t\tif (Math.sign(data.compareValue2) === 1) {\r\n\t\t\t\t\t\tconditionalFormatObj.value1 = 0;\r\n\t\t\t\t\t\tconditionalFormatObj.value2 = Number(\r\n\t\t\t\t\t\t\tdata.compareValue2\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\t\tconditionalFormatObj.conditions = \"Between\";\r\n\t\t\t\t\t\tthis.setFontSettingConditional(\r\n\t\t\t\t\t\t\tconditionalFormatObj,\r\n\t\t\t\t\t\t\tdata,\r\n\t\t\t\t\t\t\t1\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\t}\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase \"NotBetween\": // val >= value2, val <= value1\r\n\t\t\t\t\tif (Math.sign(data.compareValue2) === 1) {\r\n\t\t\t\t\t\tconditionalFormatObj.value1 = Number(\r\n\t\t\t\t\t\t\tdata.compareValue2\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\t\tconditionalFormatObj.conditions = \"GreaterThan\";\r\n\t\t\t\t\t\tthis.setFontSettingConditional(\r\n\t\t\t\t\t\t\tconditionalFormatObj,\r\n\t\t\t\t\t\t\tdata,\r\n\t\t\t\t\t\t\t1\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\t\tnegaConditionalFormatObj.value1 = 0;\r\n\t\t\t\t\t\tnegaConditionalFormatObj.conditions = \"LessThan\";\r\n\t\t\t\t\t\tthis.setFontSettingConditional(\r\n\t\t\t\t\t\t\tnegaConditionalFormatObj,\r\n\t\t\t\t\t\t\tdata,\r\n\t\t\t\t\t\t\t-1\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\t}\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tdefault:\r\n\t\t\t\t\tbreak;\r\n\t\t\t}\r\n\t\t} else if (Math.sign(data.compareValue1) === 1) {\r\n\t\t\tswitch (data.compareSelect) {\r\n\t\t\t\tcase \"LessThan\": // 小于\r\n\t\t\t\tcase \"LessThanOrEqualTo\": // 小于等于\r\n\t\t\t\t\tconditionalFormatObj.value1 = 0;\r\n\t\t\t\t\tconditionalFormatObj.value2 = Number(data.compareValue1);\r\n\t\t\t\t\tconditionalFormatObj.conditions = \"Between\";\r\n\t\t\t\t\tthis.setFontSettingConditional(\r\n\t\t\t\t\t\tconditionalFormatObj,\r\n\t\t\t\t\t\tdata,\r\n\t\t\t\t\t\t1\r\n\t\t\t\t\t);\r\n\t\t\t\t\tnegaConditionalFormatObj.value1 = 0;\r\n\t\t\t\t\tnegaConditionalFormatObj.conditions = \"LessThan\";\r\n\t\t\t\t\tthis.setFontSettingConditional(\r\n\t\t\t\t\t\tnegaConditionalFormatObj,\r\n\t\t\t\t\t\tdata,\r\n\t\t\t\t\t\t-1\r\n\t\t\t\t\t);\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase \"GreaterThan\": // 大于\r\n\t\t\t\tcase \"GreaterThanOrEqualTo\": // 大于等于\r\n\t\t\t\t\tconditionalFormatObj.value1 = Number(data.compareValue1);\r\n\t\t\t\t\tconditionalFormatObj.conditions = \"GreaterThan\";\r\n\t\t\t\t\tthis.setFontSettingConditional(\r\n\t\t\t\t\t\tconditionalFormatObj,\r\n\t\t\t\t\t\tdata,\r\n\t\t\t\t\t\t1\r\n\t\t\t\t\t);\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase \"Equals\": // 等于\r\n\t\t\t\t\tconditionalFormatObj.value1 = Number(data.compareValue1);\r\n\t\t\t\t\tconditionalFormatObj.conditions = \"Equals\";\r\n\t\t\t\t\tthis.setFontSettingConditional(\r\n\t\t\t\t\t\tconditionalFormatObj,\r\n\t\t\t\t\t\tdata,\r\n\t\t\t\t\t\t1\r\n\t\t\t\t\t);\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase \"NotEquals\": // 不等于\r\n\t\t\t\t\tconditionalFormatObj.value1 = 0;\r\n\t\t\t\t\tconditionalFormatObj.value2 = Number(data.compareValue1);\r\n\t\t\t\t\tconditionalFormatObj.conditions = \"Between\";\r\n\t\t\t\t\t// push进数组\r\n\t\t\t\t\tconditionalFormatObj.value1 = Number(data.compareValue1);\r\n\t\t\t\t\tconditionalFormatObj.conditions = \"GreaterThan\";\r\n\t\t\t\t\t// push进数组\r\n\r\n\t\t\t\t\tnegaConditionalFormatObj.value1 = 0;\r\n\t\t\t\t\tnegaConditionalFormatObj.conditions = \"LessThanOrEqualTo\";\r\n\t\t\t\t\tthis.setFontSettingConditional(\r\n\t\t\t\t\t\tnegaConditionalFormatObj,\r\n\t\t\t\t\t\tdata,\r\n\t\t\t\t\t\t-1\r\n\t\t\t\t\t);\r\n\t\t\t\t\tthis.setFontSettingConditional(\r\n\t\t\t\t\t\tconditionalFormatObj,\r\n\t\t\t\t\t\tdata,\r\n\t\t\t\t\t\t1\r\n\t\t\t\t\t);\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase \"Between\": // value1<= val <=value2\r\n\t\t\t\t\tif (Math.sign(data.compareValue2) === 1) {\r\n\t\t\t\t\t\tconditionalFormatObj.value1 = Number(\r\n\t\t\t\t\t\t\tdata.compareValue1\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\t\tconditionalFormatObj.value2 = Number(\r\n\t\t\t\t\t\t\tdata.compareValue2\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\t\tconditionalFormatObj.conditions = \"Between\";\r\n\t\t\t\t\t\tthis.setFontSettingConditional(\r\n\t\t\t\t\t\t\tconditionalFormatObj,\r\n\t\t\t\t\t\t\tdata,\r\n\t\t\t\t\t\t\t1\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\t}\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase \"NotBetween\": // val >= value2, val <= value1\r\n\t\t\t\t\tif (Math.sign(data.compareValue2) === 1) {\r\n\t\t\t\t\t\tconditionalFormatObj.value1 = 0;\r\n\t\t\t\t\t\tconditionalFormatObj.value2 = Number(\r\n\t\t\t\t\t\t\tdata.compareValue1\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\t\tconditionalFormatObj.conditions = \"Between\";\r\n\t\t\t\t\t\t// push进数组\r\n\t\t\t\t\t\tconditionalFormatObj.value1 = Number(\r\n\t\t\t\t\t\t\tdata.compareValue2\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\t\tconditionalFormatObj.conditions = \"GreaterThan\";\r\n\t\t\t\t\t\t// push进数组\r\n\t\t\t\t\t\tthis.setFontSettingConditional(\r\n\t\t\t\t\t\t\tconditionalFormatObj,\r\n\t\t\t\t\t\t\tdata,\r\n\t\t\t\t\t\t\t1\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\t}\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tdefault:\r\n\t\t\t\t\tbreak;\r\n\t\t\t}\r\n\t\t} else if (Math.sign(data.compareValue1) === -1) {\r\n\t\t\tswitch (data.compareSelect) {\r\n\t\t\t\tcase \"LessThan\": // 小于\r\n\t\t\t\tcase \"LessThanOrEqualTo\": // 小于等于\r\n\t\t\t\t\tnegaConditionalFormatObj.value1 = data.compareValue1;\r\n\t\t\t\t\tnegaConditionalFormatObj.conditions = data.compareSelect;\r\n\t\t\t\t\tthis.setFontSettingConditional(\r\n\t\t\t\t\t\tnegaConditionalFormatObj,\r\n\t\t\t\t\t\tdata,\r\n\t\t\t\t\t\t-1\r\n\t\t\t\t\t);\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase \"GreaterThan\": // 大于\r\n\t\t\t\tcase \"GreaterThanOrEqualTo\": // 大于等于\r\n\t\t\t\t\tconditionalFormatObj.value1 = 0;\r\n\t\t\t\t\tconditionalFormatObj.conditions = \"GreaterThanOrEqualTo\";\r\n\t\t\t\t\tnegaConditionalFormatObj.value1 = 0;\r\n\t\t\t\t\tnegaConditionalFormatObj.value2 = data.compareValue1;\r\n\t\t\t\t\tnegaConditionalFormatObj.conditions = \"Between\";\r\n\t\t\t\t\tthis.setFontSettingConditional(\r\n\t\t\t\t\t\tconditionalFormatObj,\r\n\t\t\t\t\t\tdata,\r\n\t\t\t\t\t\t1\r\n\t\t\t\t\t);\r\n\t\t\t\t\tthis.setFontSettingConditional(\r\n\t\t\t\t\t\tnegaConditionalFormatObj,\r\n\t\t\t\t\t\tdata,\r\n\t\t\t\t\t\t-1\r\n\t\t\t\t\t);\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase \"Equals\": // 等于\r\n\t\t\t\t\tnegaConditionalFormatObj.value1 = data.compareValue1;\r\n\t\t\t\t\tnegaConditionalFormatObj.conditions = \"Equals\";\r\n\t\t\t\t\tthis.setFontSettingConditional(\r\n\t\t\t\t\t\tnegaConditionalFormatObj,\r\n\t\t\t\t\t\tdata,\r\n\t\t\t\t\t\t-1\r\n\t\t\t\t\t);\r\n\t\t\t\tcase \"NotEquals\": // 不等于\r\n\t\t\t\t\tnegaConditionalFormatObj.value1 = data.compareValue1;\r\n\t\t\t\t\tnegaConditionalFormatObj.conditions = \"NotEquals\";\r\n\t\t\t\t\tthis.setFontSettingConditional(\r\n\t\t\t\t\t\tnegaConditionalFormatObj,\r\n\t\t\t\t\t\tdata,\r\n\t\t\t\t\t\t-1\r\n\t\t\t\t\t);\r\n\t\t\t\t\tconditionalFormatObj.value1 = 0;\r\n\t\t\t\t\tconditionalFormatObj.conditions = \"GreaterThan\";\r\n\t\t\t\t\tthis.setFontSettingConditional(\r\n\t\t\t\t\t\tconditionalFormatObj,\r\n\t\t\t\t\t\tdata,\r\n\t\t\t\t\t\t1\r\n\t\t\t\t\t);\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase \"Between\": // value1<= val <=value2\r\n\t\t\t\t\tif (Math.sign(data.compareValue2)) {\r\n\t\t\t\t\t\tnegaConditionalFormatObj.value1 = 0;\r\n\t\t\t\t\t\tnegaConditionalFormatObj.value2 = data.compareValue1;\r\n\t\t\t\t\t\tnegaConditionalFormatObj.conditions = \"Between\";\r\n\t\t\t\t\t\tthis.setFontSettingConditional(\r\n\t\t\t\t\t\t\tnegaConditionalFormatObj,\r\n\t\t\t\t\t\t\tdata,\r\n\t\t\t\t\t\t\t-1\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\t\tconditionalFormatObj.value1 = 0;\r\n\t\t\t\t\t\tconditionalFormatObj.value2 = data.compareValue2;\r\n\t\t\t\t\t\tconditionalFormatObj.conditions = \"Between\";\r\n\t\t\t\t\t\tthis.setFontSettingConditional(\r\n\t\t\t\t\t\t\tconditionalFormatObj,\r\n\t\t\t\t\t\t\tdata,\r\n\t\t\t\t\t\t\t1\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\t} else {\r\n\t\t\t\t\t\tnegaConditionalFormatObj.value1 = data.compareValue1;\r\n\t\t\t\t\t\tnegaConditionalFormatObj.value2 = data.compareValue2;\r\n\t\t\t\t\t\tnegaConditionalFormatObj.conditions = \"Between\";\r\n\t\t\t\t\t\tthis.setFontSettingConditional(\r\n\t\t\t\t\t\t\tnegaConditionalFormatObj,\r\n\t\t\t\t\t\t\tdata,\r\n\t\t\t\t\t\t\t-1\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\t}\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase \"NotBetween\": // val >= value2, val <= value1\r\n\t\t\t\t\tif (Math.sign(data.compareValue2)) {\r\n\t\t\t\t\t\tnegaConditionalFormatObj.value1 = data.compareValue1;\r\n\t\t\t\t\t\tnegaConditionalFormatObj.conditions = \"LessThan\";\r\n\t\t\t\t\t\tthis.setFontSettingConditional(\r\n\t\t\t\t\t\t\tnegaConditionalFormatObj,\r\n\t\t\t\t\t\t\tdata,\r\n\t\t\t\t\t\t\t-1\r\n\t\t\t\t\t\t);\r\n\r\n\t\t\t\t\t\tconditionalFormatObj.value1 = data.compareValue2;\r\n\t\t\t\t\t\tconditionalFormatObj.conditions = \"GreaterThan\";\r\n\t\t\t\t\t\tthis.setFontSettingConditional(\r\n\t\t\t\t\t\t\tconditionalFormatObj,\r\n\t\t\t\t\t\t\tdata,\r\n\t\t\t\t\t\t\t1\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\t} else {\r\n\t\t\t\t\t\tnegaConditionalFormatObj.value1 = data.compareValue1;\r\n\t\t\t\t\t\tnegaConditionalFormatObj.value2 = data.compareValue2;\r\n\t\t\t\t\t\tnegaConditionalFormatObj.conditions = \"NotBetween\";\r\n\t\t\t\t\t\tthis.setFontSettingConditional(\r\n\t\t\t\t\t\t\tnegaConditionalFormatObj,\r\n\t\t\t\t\t\t\tdata,\r\n\t\t\t\t\t\t\t-1\r\n\t\t\t\t\t\t);\r\n\r\n\t\t\t\t\t\tconditionalFormatObj.value1 = 0;\r\n\t\t\t\t\t\tconditionalFormatObj.conditions = \"GreaterThan\";\r\n\t\t\t\t\t\tthis.setFontSettingConditional(\r\n\t\t\t\t\t\t\tconditionalFormatObj,\r\n\t\t\t\t\t\t\tdata,\r\n\t\t\t\t\t\t\t1\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\t}\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tdefault:\r\n\t\t\t\t\tbreak;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\tprivate getQuarterValue(format, date, quarter) {\r\n\t\tlet year: any;\r\n\t\tswitch (format) {\r\n\t\t\tcase \"Q1 2021\":\r\n\t\t\t\tyear = date.getFullYear();\r\n\t\t\t\treturn \"Q\" + quarter + \" \" + year;\r\n\t\t\tcase \"Q1 21\":\r\n\t\t\t\tyear = (date as any).getYear() - 100;\r\n\t\t\t\treturn \"Q\" + quarter + \" \" + year;\r\n\t\t\tcase \"2021 Q1\":\r\n\t\t\t\tyear = date.getFullYear();\r\n\t\t\t\treturn year + \" \" + \"Q\" + quarter;\r\n\t\t\tcase \"21 Q1\":\r\n\t\t\t\tyear = (date as any).getYear() - 100;\r\n\t\t\t\treturn year + \" \" + \"Q\" + quarter;\r\n\t\t}\r\n\t}\r\n\r\n\tcustomiseCell(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}\r\n\r\n\t/**\r\n\t * @param timeArray 数组对象 [{\"date\":\"2021-01-01\"},{\"date\":\"2021-02-01\"}]\r\n\t * @param endDate 截至时间\r\n\t * @param interval 时间间隔 year / quarter / month\r\n\t * @param timeKey 时间字段名 date\r\n\t * @returns 划分后的时间分组对象\r\n\t */\r\n\tgetTimeRanges(timeArray, endDate, interval, timeKey) {\r\n\t\t// 将时间字符串转换为 moment 对象\r\n\t\tconst dates = timeArray.map((item) => moment(item[timeKey || \"date\"]));\r\n\r\n\t\t// 分隔符\r\n\t\tconst delimiter = \"-\";\r\n\r\n\t\t// 找到最小时间和最大时间\r\n\t\tconst minDate = moment.min(dates);\r\n\t\tconst maxDate = moment(endDate);\r\n\r\n\t\t// 初始化结果对象\r\n\t\tconst result = {};\r\n\r\n\t\t// 根据入参进行划分\r\n\t\tif (interval === \"year\") {\r\n\t\t\tconst startYear = minDate.year();\r\n\t\t\tconst endYear = maxDate.year();\r\n\r\n\t\t\tfor (let year = startYear; year <= endYear; year++) {\r\n\t\t\t\tresult[year] = [];\r\n\t\t\t}\r\n\r\n\t\t\tdates.forEach((date, index) => {\r\n\t\t\t\tconst year = date.year();\r\n\t\t\t\tresult[year].push(timeArray[index]);\r\n\t\t\t});\r\n\t\t} else if (interval === \"quarter\") {\r\n\t\t\t// 存储季度字符串\r\n\t\t\tconst quarters = [];\r\n\r\n\t\t\t// 逐一遍历每个季度\r\n\t\t\tfor (\r\n\t\t\t\tlet currentDate = minDate.clone();\r\n\t\t\t\tcurrentDate.isSameOrBefore(maxDate);\r\n\t\t\t\tcurrentDate.add(3, \"months\")\r\n\t\t\t) {\r\n\t\t\t\tconst year = currentDate.year();\r\n\t\t\t\tconst quarter = Math.ceil((currentDate.month() + 1) / 3); // 计算季度\r\n\t\t\t\tquarters.push(`${year}${delimiter}Q${quarter}`); // 格式化并添加到数组\r\n\t\t\t}\r\n\r\n\t\t\t// 输出所有季度\r\n\t\t\tquarters.forEach((quarter, index) => {\r\n\t\t\t\tresult[quarter] = [];\r\n\t\t\t});\r\n\r\n\t\t\tdates.forEach((date, index) => {\r\n\t\t\t\tconst year = date.year();\r\n\t\t\t\tconst quarter = date.quarter(); // 获取季度\r\n\t\t\t\tif (quarter === 1)\r\n\t\t\t\t\tresult[year + delimiter + \"Q1\"].push(timeArray[index]);\r\n\t\t\t\telse if (quarter === 2)\r\n\t\t\t\t\tresult[year + delimiter + \"Q2\"].push(timeArray[index]);\r\n\t\t\t\telse if (quarter === 3)\r\n\t\t\t\t\tresult[year + delimiter + \"Q3\"].push(timeArray[index]);\r\n\t\t\t\telse if (quarter === 4)\r\n\t\t\t\t\tresult[year + delimiter + \"Q4\"].push(timeArray[index]);\r\n\t\t\t});\r\n\t\t} else if (interval === \"month\") {\r\n\t\t\t// 存储月份字符串\r\n\t\t\tconst months = [];\r\n\r\n\t\t\t// 逐一遍历每个月\r\n\t\t\tfor (\r\n\t\t\t\tlet currentDate = minDate.clone();\r\n\t\t\t\tcurrentDate.isSameOrBefore(maxDate);\r\n\t\t\t\tcurrentDate.add(1, \"months\")\r\n\t\t\t) {\r\n\t\t\t\tmonths.push(currentDate.format(`YYYY${delimiter}MM`)); // 格式化并添加到数组\r\n\t\t\t}\r\n\r\n\t\t\t// 输出所有月份\r\n\t\t\tmonths.forEach((month, index) => {\r\n\t\t\t\tresult[month] = [];\r\n\t\t\t});\r\n\r\n\t\t\tdates.forEach((date, index) => {\r\n\t\t\t\tconst year = date.year();\r\n\t\t\t\tconst month = (date.month() + 1).toString().padStart(2, \"0\"); // 0-11\r\n\t\t\t\tresult[year + delimiter + month].push(timeArray[index]);\r\n\t\t\t});\r\n\t\t}\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\t/**\r\n\t * 计算几何算数平方更\r\n\t * @param values 数组 [0, 0, 0.2575]\r\n\t * @returns\r\n\t */\r\n\tcalculateGrowthRate(values) {\r\n\t\tconst product = values.reduce((acc, val) => acc * (1 + val), 1);\r\n\t\tif (product >= 0) {\r\n\t\t\treturn Math.pow(product, 1 / values.length) - 1;\r\n\t\t} else if (product < 0) {\r\n\t\t\tif (values.length % 2 == 0) {\r\n\t\t\t\treturn null;\r\n\t\t\t} else {\r\n\t\t\t\treturn this.nthroot(product, values.length) - 1;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\tnthroot(x, n) {\r\n\t\tlet ng = n % 2;\r\n\t\tif (ng == 1 || x < 0) x = -x;\r\n\t\tvar r = Math.pow(x, 1 / n);\r\n\t\tn = Math.pow(r, n);\r\n\r\n\t\tif (Math.abs(x - n) < 1 && x > 0 === n > 0) return ng ? -r : r;\r\n\t}\r\n\r\n\t/**\r\n\t * 标准偏差\r\n\t * @param values 数组 [0, 0, -0.4775]\r\n\t * @returns 0.2756847535380463\r\n\t */\r\n\tcalculateStandardDeviation(values) {\r\n\t\tconst n = values.length;\r\n\r\n\t\t// 检查数据点数量\r\n\t\tif (n < 2) {\r\n\t\t\tthrow new Error(\"至少需要两个数据点来计算样本标准偏差\");\r\n\t\t}\r\n\r\n\t\t// 计算均值\r\n\t\tconst mean = values.reduce((acc, val) => acc + val, 0) / n;\r\n\r\n\t\t// 计算方差\r\n\t\tconst variance =\r\n\t\t\tvalues.reduce((acc, val) => acc + Math.pow(val - mean, 2), 0) /\r\n\t\t\t(n - 1);\r\n\r\n\t\t// 返回标准偏差\r\n\t\treturn Math.sqrt(variance);\r\n\t}\r\n}\r\n","<div class=\"control-section\" style=\"overflow: hidden; height: 100%\">\r\n\t<ejs-pivotview\r\n\t\twidth=\"100%\"\r\n\t\theight=\"100%\"\r\n\t\tstyle=\"display: block\"\r\n\t\t[dataSourceSettings]=\"dataSourceSettings\"\r\n\t\t#pivotview\r\n\t\t(dataBound)=\"dataBound($event)\"\r\n\t\tenableValueSorting=\"true\"\r\n\t\tallowConditionalFormatting=\"true\"\r\n\t\t[allowDeferLayoutUpdate]=\"true\"\r\n\t\t[gridSettings]=\"gridSettings\"\r\n\t\tallowExcelExport=\"true\"\r\n\t\tallowGrouping=\"true\"\r\n\t\t[zoomSettings]=\"zoomSettings\"\r\n\t\tenableVirtualization=\"true\"\r\n\t\t(enginePopulated)=\"afterEnginePopulate($event)\"\r\n\t\t(aggregateCellInfo)=\"aggregateCellInfo($event)\"\r\n\t\t(cellClick)=\"cellClick($event)\"\r\n\t\tallowDrillThrough=\"true\"\r\n\t\t(actionFailure)=\"actionFailure($event)\"\r\n\t\t(actionComplete)=\"actionComplete($event)\"\r\n\t\t(actionBegin)=\"actionBegin($event)\"\r\n\t\t(fieldListRefreshed)=\"fieldListRefreshed($event)\"\r\n\t\t(drillThrough)=\"drillThrough($event)\"\r\n\t\t[showTooltip]=\"false\"\r\n\t\t(queryCellInfo)=\"customiseCell($event)\"\r\n\t\t(beforeExport)=\"beforeExport($event)\"\r\n\t>\r\n\t</ejs-pivotview>\r\n\r\n\t<div class=\"pivotfieldlist-control\">\r\n\t\t<ejs-pivotfieldlist\r\n\t\t\t[id]=\"portlet.newId\"\r\n\t\t\t#pivotfieldlist\r\n\t\t\t[allowDeferLayoutUpdate]=\"true\"\r\n\t\t\trenderMode=\"Popup\"\r\n\t\t\t(enginePopulated)=\"afterPopulate($event)\"\r\n\t\t\t(memberEditorOpen)=\"onMemberEditorOpen($event)\"\r\n\t\t\t(enginePopulating)=\"enginePopulating($event)\"\r\n\t\t\t(aggregateCellInfo)=\"aggregateCellInfo($event)\"\r\n\t\t\t(fieldDrop)=\"onFieldDrop($event)\"\r\n\t\t\t(actionComplete)=\"actionComplete($event)\"\r\n\t\t\t(actionBegin)=\"actionBegin($event)\"\r\n\t\t\t(calculatedFieldCreate)=\"calculatedFieldCreate($event)\"\r\n\t\t\t(load)=\"onLoad()\"\r\n\t\t\t(created)=\"created($event)\"\r\n\t\t\t(dataBound)='ondataBound()'\r\n\t\t>\r\n\t\t</ejs-pivotfieldlist>\r\n\t</div>\r\n\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"]}