@genesislcap/pbc-reporting-ui 1.0.1

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 (210) hide show
  1. package/README.md +47 -0
  2. package/dist/dts/assets/images/index.d.ts +11 -0
  3. package/dist/dts/assets/images/index.d.ts.map +1 -0
  4. package/dist/dts/components/components.d.ts +5 -0
  5. package/dist/dts/components/components.d.ts.map +1 -0
  6. package/dist/dts/components/create-edit/create-edit.d.ts +17 -0
  7. package/dist/dts/components/create-edit/create-edit.d.ts.map +1 -0
  8. package/dist/dts/components/create-edit/create-edit.styles.d.ts +2 -0
  9. package/dist/dts/components/create-edit/create-edit.styles.d.ts.map +1 -0
  10. package/dist/dts/components/create-edit/create-edit.template.d.ts +3 -0
  11. package/dist/dts/components/create-edit/create-edit.template.d.ts.map +1 -0
  12. package/dist/dts/components/create-edit/index.d.ts +4 -0
  13. package/dist/dts/components/create-edit/index.d.ts.map +1 -0
  14. package/dist/dts/components/index.d.ts +2 -0
  15. package/dist/dts/components/index.d.ts.map +1 -0
  16. package/dist/dts/components/list/columns.d.ts +14 -0
  17. package/dist/dts/components/list/columns.d.ts.map +1 -0
  18. package/dist/dts/components/list/index.d.ts +4 -0
  19. package/dist/dts/components/list/index.d.ts.map +1 -0
  20. package/dist/dts/components/list/list.d.ts +19 -0
  21. package/dist/dts/components/list/list.d.ts.map +1 -0
  22. package/dist/dts/components/list/list.styles.d.ts +2 -0
  23. package/dist/dts/components/list/list.styles.d.ts.map +1 -0
  24. package/dist/dts/components/list/list.template.d.ts +3 -0
  25. package/dist/dts/components/list/list.template.d.ts.map +1 -0
  26. package/dist/dts/components/preview/columns.d.ts +15 -0
  27. package/dist/dts/components/preview/columns.d.ts.map +1 -0
  28. package/dist/dts/components/preview/index.d.ts +4 -0
  29. package/dist/dts/components/preview/index.d.ts.map +1 -0
  30. package/dist/dts/components/preview/preview.d.ts +28 -0
  31. package/dist/dts/components/preview/preview.d.ts.map +1 -0
  32. package/dist/dts/components/preview/preview.styles.d.ts +2 -0
  33. package/dist/dts/components/preview/preview.styles.d.ts.map +1 -0
  34. package/dist/dts/components/preview/preview.template.d.ts +3 -0
  35. package/dist/dts/components/preview/preview.template.d.ts.map +1 -0
  36. package/dist/dts/components/select-fields/columns.d.ts +65 -0
  37. package/dist/dts/components/select-fields/columns.d.ts.map +1 -0
  38. package/dist/dts/components/select-fields/data.d.ts +49 -0
  39. package/dist/dts/components/select-fields/data.d.ts.map +1 -0
  40. package/dist/dts/components/select-fields/index.d.ts +3 -0
  41. package/dist/dts/components/select-fields/index.d.ts.map +1 -0
  42. package/dist/dts/components/select-fields/select-fields.d.ts +57 -0
  43. package/dist/dts/components/select-fields/select-fields.d.ts.map +1 -0
  44. package/dist/dts/components/select-fields/select-fields.styles.d.ts +2 -0
  45. package/dist/dts/components/select-fields/select-fields.styles.d.ts.map +1 -0
  46. package/dist/dts/components/select-fields/select-fields.template.d.ts +4 -0
  47. package/dist/dts/components/select-fields/select-fields.template.d.ts.map +1 -0
  48. package/dist/dts/components/select-filters/columns.d.ts +88 -0
  49. package/dist/dts/components/select-filters/columns.d.ts.map +1 -0
  50. package/dist/dts/components/select-filters/index.d.ts +4 -0
  51. package/dist/dts/components/select-filters/index.d.ts.map +1 -0
  52. package/dist/dts/components/select-filters/select-filters.d.ts +46 -0
  53. package/dist/dts/components/select-filters/select-filters.d.ts.map +1 -0
  54. package/dist/dts/components/select-filters/select-filters.styles.d.ts +2 -0
  55. package/dist/dts/components/select-filters/select-filters.styles.d.ts.map +1 -0
  56. package/dist/dts/components/select-filters/select-filters.template.d.ts +4 -0
  57. package/dist/dts/components/select-filters/select-filters.template.d.ts.map +1 -0
  58. package/dist/dts/components/wizard/debug.d.ts +3 -0
  59. package/dist/dts/components/wizard/debug.d.ts.map +1 -0
  60. package/dist/dts/components/wizard/index.d.ts +3 -0
  61. package/dist/dts/components/wizard/index.d.ts.map +1 -0
  62. package/dist/dts/components/wizard/steps/filters.d.ts +3 -0
  63. package/dist/dts/components/wizard/steps/filters.d.ts.map +1 -0
  64. package/dist/dts/components/wizard/steps/index.d.ts +5 -0
  65. package/dist/dts/components/wizard/steps/index.d.ts.map +1 -0
  66. package/dist/dts/components/wizard/steps/name.d.ts +4 -0
  67. package/dist/dts/components/wizard/steps/name.d.ts.map +1 -0
  68. package/dist/dts/components/wizard/steps/run.d.ts +3 -0
  69. package/dist/dts/components/wizard/steps/run.d.ts.map +1 -0
  70. package/dist/dts/components/wizard/steps/select.d.ts +3 -0
  71. package/dist/dts/components/wizard/steps/select.d.ts.map +1 -0
  72. package/dist/dts/components/wizard/wizard.d.ts +83 -0
  73. package/dist/dts/components/wizard/wizard.d.ts.map +1 -0
  74. package/dist/dts/components/wizard/wizard.styles.d.ts +2 -0
  75. package/dist/dts/components/wizard/wizard.styles.d.ts.map +1 -0
  76. package/dist/dts/components/wizard/wizard.template.d.ts +4 -0
  77. package/dist/dts/components/wizard/wizard.template.d.ts.map +1 -0
  78. package/dist/dts/components/wizard/wizard.types.d.ts +41 -0
  79. package/dist/dts/components/wizard/wizard.types.d.ts.map +1 -0
  80. package/dist/dts/constants/grid-config.d.ts +17 -0
  81. package/dist/dts/constants/grid-config.d.ts.map +1 -0
  82. package/dist/dts/index.d.ts +3 -0
  83. package/dist/dts/index.d.ts.map +1 -0
  84. package/dist/dts/index.federated.d.ts +1 -0
  85. package/dist/dts/index.federated.d.ts.map +1 -0
  86. package/dist/dts/layouts/default.d.ts +3 -0
  87. package/dist/dts/layouts/default.d.ts.map +1 -0
  88. package/dist/dts/layouts/index.d.ts +3 -0
  89. package/dist/dts/layouts/index.d.ts.map +1 -0
  90. package/dist/dts/layouts/two-pane-horizontal.d.ts +6 -0
  91. package/dist/dts/layouts/two-pane-horizontal.d.ts.map +1 -0
  92. package/dist/dts/main/index.d.ts +3 -0
  93. package/dist/dts/main/index.d.ts.map +1 -0
  94. package/dist/dts/main/main.d.ts +18 -0
  95. package/dist/dts/main/main.d.ts.map +1 -0
  96. package/dist/dts/main/main.styles.d.ts +2 -0
  97. package/dist/dts/main/main.styles.d.ts.map +1 -0
  98. package/dist/dts/main/main.template.d.ts +6 -0
  99. package/dist/dts/main/main.template.d.ts.map +1 -0
  100. package/dist/dts/routes/config.d.ts +25 -0
  101. package/dist/dts/routes/config.d.ts.map +1 -0
  102. package/dist/dts/routes/index.d.ts +2 -0
  103. package/dist/dts/routes/index.d.ts.map +1 -0
  104. package/dist/dts/routes/not-found/not-found.d.ts +4 -0
  105. package/dist/dts/routes/not-found/not-found.d.ts.map +1 -0
  106. package/dist/dts/routes/protected/protected.d.ts +8 -0
  107. package/dist/dts/routes/protected/protected.d.ts.map +1 -0
  108. package/dist/dts/routes/protected/protected.styles.d.ts +2 -0
  109. package/dist/dts/routes/protected/protected.styles.d.ts.map +1 -0
  110. package/dist/dts/routes/protected/protected.template.d.ts +3 -0
  111. package/dist/dts/routes/protected/protected.template.d.ts.map +1 -0
  112. package/dist/dts/routes/reporting-home/reporting-home-styles.d.ts +2 -0
  113. package/dist/dts/routes/reporting-home/reporting-home-styles.d.ts.map +1 -0
  114. package/dist/dts/routes/reporting-home/reporting-home-template.d.ts +4 -0
  115. package/dist/dts/routes/reporting-home/reporting-home-template.d.ts.map +1 -0
  116. package/dist/dts/routes/reporting-home/reporting-home.d.ts +26 -0
  117. package/dist/dts/routes/reporting-home/reporting-home.d.ts.map +1 -0
  118. package/dist/dts/routes/reporting-home/types.d.ts +13 -0
  119. package/dist/dts/routes/reporting-home/types.d.ts.map +1 -0
  120. package/dist/dts/styles/colors.d.ts +17 -0
  121. package/dist/dts/styles/colors.d.ts.map +1 -0
  122. package/dist/dts/styles/helpers.d.ts +5 -0
  123. package/dist/dts/styles/helpers.d.ts.map +1 -0
  124. package/dist/dts/styles/index.d.ts +5 -0
  125. package/dist/dts/styles/index.d.ts.map +1 -0
  126. package/dist/dts/styles/normalize.d.ts +5 -0
  127. package/dist/dts/styles/normalize.d.ts.map +1 -0
  128. package/dist/dts/styles/styles.d.ts +4 -0
  129. package/dist/dts/styles/styles.d.ts.map +1 -0
  130. package/dist/dts/utils/filterObjectArray.d.ts +12 -0
  131. package/dist/dts/utils/filterObjectArray.d.ts.map +1 -0
  132. package/dist/dts/utils/getFiltersByType.d.ts +12 -0
  133. package/dist/dts/utils/getFiltersByType.d.ts.map +1 -0
  134. package/dist/dts/utils/getSelectedFields.d.ts +5 -0
  135. package/dist/dts/utils/getSelectedFields.d.ts.map +1 -0
  136. package/dist/dts/utils/index.d.ts +5 -0
  137. package/dist/dts/utils/index.d.ts.map +1 -0
  138. package/dist/dts/utils/logger.d.ts +2 -0
  139. package/dist/dts/utils/logger.d.ts.map +1 -0
  140. package/dist/esm/assets/images/index.js +60 -0
  141. package/dist/esm/components/components.js +51 -0
  142. package/dist/esm/components/create-edit/create-edit.js +70 -0
  143. package/dist/esm/components/create-edit/create-edit.styles.js +18 -0
  144. package/dist/esm/components/create-edit/create-edit.template.js +13 -0
  145. package/dist/esm/components/create-edit/index.js +3 -0
  146. package/dist/esm/components/index.js +1 -0
  147. package/dist/esm/components/list/columns.js +105 -0
  148. package/dist/esm/components/list/index.js +3 -0
  149. package/dist/esm/components/list/list.js +127 -0
  150. package/dist/esm/components/list/list.styles.js +28 -0
  151. package/dist/esm/components/list/list.template.js +25 -0
  152. package/dist/esm/components/preview/columns.js +21 -0
  153. package/dist/esm/components/preview/index.js +3 -0
  154. package/dist/esm/components/preview/preview.js +111 -0
  155. package/dist/esm/components/preview/preview.styles.js +21 -0
  156. package/dist/esm/components/preview/preview.template.js +30 -0
  157. package/dist/esm/components/select-fields/columns.js +51 -0
  158. package/dist/esm/components/select-fields/data.js +218 -0
  159. package/dist/esm/components/select-fields/index.js +3 -0
  160. package/dist/esm/components/select-fields/select-fields.js +197 -0
  161. package/dist/esm/components/select-fields/select-fields.styles.js +21 -0
  162. package/dist/esm/components/select-fields/select-fields.template.js +49 -0
  163. package/dist/esm/components/select-filters/columns.js +43 -0
  164. package/dist/esm/components/select-filters/index.js +3 -0
  165. package/dist/esm/components/select-filters/select-filters.js +192 -0
  166. package/dist/esm/components/select-filters/select-filters.styles.js +20 -0
  167. package/dist/esm/components/select-filters/select-filters.template.js +51 -0
  168. package/dist/esm/components/wizard/debug.js +34 -0
  169. package/dist/esm/components/wizard/index.js +2 -0
  170. package/dist/esm/components/wizard/steps/filters.js +9 -0
  171. package/dist/esm/components/wizard/steps/index.js +4 -0
  172. package/dist/esm/components/wizard/steps/name.js +58 -0
  173. package/dist/esm/components/wizard/steps/run.js +11 -0
  174. package/dist/esm/components/wizard/steps/select.js +11 -0
  175. package/dist/esm/components/wizard/wizard.js +363 -0
  176. package/dist/esm/components/wizard/wizard.styles.js +193 -0
  177. package/dist/esm/components/wizard/wizard.template.js +113 -0
  178. package/dist/esm/components/wizard/wizard.types.js +7 -0
  179. package/dist/esm/constants/grid-config.js +19 -0
  180. package/dist/esm/index.federated.js +1 -0
  181. package/dist/esm/index.js +2 -0
  182. package/dist/esm/layouts/default.js +27 -0
  183. package/dist/esm/layouts/index.js +2 -0
  184. package/dist/esm/layouts/two-pane-horizontal.js +86 -0
  185. package/dist/esm/main/index.js +2 -0
  186. package/dist/esm/main/main.js +80 -0
  187. package/dist/esm/main/main.styles.js +15 -0
  188. package/dist/esm/main/main.template.js +12 -0
  189. package/dist/esm/routes/config.js +84 -0
  190. package/dist/esm/routes/index.js +1 -0
  191. package/dist/esm/routes/not-found/not-found.js +29 -0
  192. package/dist/esm/routes/protected/protected.js +32 -0
  193. package/dist/esm/routes/protected/protected.styles.js +18 -0
  194. package/dist/esm/routes/protected/protected.template.js +7 -0
  195. package/dist/esm/routes/reporting-home/reporting-home-styles.js +74 -0
  196. package/dist/esm/routes/reporting-home/reporting-home-template.js +85 -0
  197. package/dist/esm/routes/reporting-home/reporting-home.js +103 -0
  198. package/dist/esm/routes/reporting-home/types.js +7 -0
  199. package/dist/esm/styles/colors.js +17 -0
  200. package/dist/esm/styles/helpers.js +179 -0
  201. package/dist/esm/styles/index.js +4 -0
  202. package/dist/esm/styles/normalize.js +13 -0
  203. package/dist/esm/styles/styles.js +22 -0
  204. package/dist/esm/utils/filterObjectArray.js +13 -0
  205. package/dist/esm/utils/getFiltersByType.js +62 -0
  206. package/dist/esm/utils/getSelectedFields.js +13 -0
  207. package/dist/esm/utils/index.js +4 -0
  208. package/dist/esm/utils/logger.js +2 -0
  209. package/index.html +26 -0
  210. package/package.json +79 -0
@@ -0,0 +1,111 @@
1
+ import { __awaiter, __decorate } from "tslib";
2
+ import { Datasource } from '@genesislcap/foundation-comms';
3
+ import { formatDateTimestamp, formatDateTimeTimestamp } from '@genesislcap/foundation-utils';
4
+ import { customElement, FASTElement, observable, attr } from '@microsoft/fast-element';
5
+ import { getColumns, getGridOptions } from './columns';
6
+ import { PreviewStyles as styles } from './preview.styles';
7
+ import { PreviewReportTemplate as template } from './preview.template';
8
+ const name = 'reporting-preview';
9
+ let Preview = class Preview extends FASTElement {
10
+ constructor() {
11
+ super(...arguments);
12
+ this.report = {};
13
+ /**
14
+ * Fetch data from server and load to grid
15
+ */
16
+ this.fetchAndLoadToGrid = () => __awaiter(this, void 0, void 0, function* () {
17
+ // Get the data from the selected dataserver
18
+ // NOTE: Backend field REPORT_DATASOURCE and REPORT_DATA_SOURCE are not consistent in Events and Dataserver
19
+ const resourceName = this.report['REPORT_DATASOURCE'] || this.report['REPORT_DATA_SOURCE'];
20
+ yield this.datasource.init(Object.assign({ resourceName }, this.datasourceSettings), true);
21
+ this.data = yield this.datasource.snapshotFiltered();
22
+ // Map data from dataserver to the grid
23
+ this.grid['gridOptions'] = Object.assign(Object.assign({}, getGridOptions()), { columnDefs: getColumns(this.report['REPORT_COLUMNS']), rowData: this.data });
24
+ });
25
+ /**
26
+ * Export to csv handle
27
+ */
28
+ this.exportToCsv = () => {
29
+ const params = {
30
+ fileName: 'export.csv',
31
+ };
32
+ params.processCellCallback = (cellParams) => this.formatDateType(cellParams);
33
+ this.grid.gridApi.exportDataAsCsv(Object.assign({}, params));
34
+ };
35
+ this.formatDateType = (cellParams) => {
36
+ let dateFormatter;
37
+ this.report['REPORT_COLUMNS'].forEach((column) => {
38
+ if (column.name == cellParams.column.colId) {
39
+ column.type === 'DATE'
40
+ ? (dateFormatter = formatDateTimestamp(cellParams.value))
41
+ : column.type === 'DATETIME'
42
+ ? (dateFormatter = formatDateTimeTimestamp(cellParams.value))
43
+ : (dateFormatter = cellParams.value);
44
+ }
45
+ });
46
+ return dateFormatter;
47
+ };
48
+ }
49
+ /**
50
+ * When report variable changes handle
51
+ */
52
+ reportChanged(old, newValue) {
53
+ // Skip if empty report object
54
+ if (old &&
55
+ Object.keys(old).length != 0 &&
56
+ Object.keys(newValue).length > 0 &&
57
+ (newValue['REPORT_DATASOURCE'] || newValue['REPORT_DATA_SOURCE'])) {
58
+ this.fetchAndLoadToGrid();
59
+ }
60
+ }
61
+ /**
62
+ * On component load
63
+ */
64
+ connectedCallback() {
65
+ super.connectedCallback();
66
+ this.fetchAndLoadToGrid();
67
+ this.grid.addEventListener('onGridReady', () => {
68
+ const model = {};
69
+ this.report['REPORT_COLUMNS']
70
+ .filter((f) => f.filter)
71
+ .forEach((f) => {
72
+ model[f.name] = {
73
+ filterType: 'text',
74
+ type: f.filter.conditional,
75
+ filter: f.filter.value,
76
+ };
77
+ });
78
+ this.grid.gridApi.setFilterModel(model);
79
+ window.addEventListener('resize', () => {
80
+ setTimeout(() => {
81
+ var _a, _b;
82
+ (_b = (_a = this.grid) === null || _a === void 0 ? void 0 : _a.columnApi) === null || _b === void 0 ? void 0 : _b.autoSizeAllColumns();
83
+ });
84
+ });
85
+ this.grid.gridApi.addEventListener('firstDataRendered', () => {
86
+ var _a, _b;
87
+ (_b = (_a = this.grid) === null || _a === void 0 ? void 0 : _a.columnApi) === null || _b === void 0 ? void 0 : _b.autoSizeAllColumns();
88
+ });
89
+ });
90
+ }
91
+ };
92
+ __decorate([
93
+ Datasource
94
+ ], Preview.prototype, "datasource", void 0);
95
+ __decorate([
96
+ attr
97
+ ], Preview.prototype, "report", void 0);
98
+ __decorate([
99
+ observable
100
+ ], Preview.prototype, "data", void 0);
101
+ __decorate([
102
+ observable
103
+ ], Preview.prototype, "datasourceSettings", void 0);
104
+ Preview = __decorate([
105
+ customElement({
106
+ name,
107
+ template,
108
+ styles,
109
+ })
110
+ ], Preview);
111
+ export { Preview };
@@ -0,0 +1,21 @@
1
+ import { css } from '@microsoft/fast-element';
2
+ import { helperStyles } from '../../styles';
3
+ export const PreviewStyles = css `
4
+ ${helperStyles}
5
+ .preview {
6
+ display: flex;
7
+ width: 100%;
8
+ height: 100%;
9
+ }
10
+
11
+ .header {
12
+ display: flex;
13
+ align-items: center;
14
+ justify-content: space-between;
15
+ }
16
+
17
+ .controls {
18
+ align-items: center;
19
+ display: flex;
20
+ }
21
+ `;
@@ -0,0 +1,30 @@
1
+ import { html, ref } from '@microsoft/fast-element';
2
+ export const PreviewReportTemplate = html `
3
+ <div class="preview" data-test-id="preview">
4
+ <zero-card class="card">
5
+ <div class="header">
6
+ <div>
7
+ <h3 class="card-title">${(x) => x.report['REPORT_NAME']}</h3>
8
+ <p>${(x) => x.report['REPORT_DESCRIPTION']}</p>
9
+ </div>
10
+ <div class="controls">
11
+ <zero-button
12
+ appearance="primary-gradient"
13
+ @click=${(x) => x.exportToCsv()}
14
+ data-test-id="export-csv-button"
15
+ >
16
+ Export to csv
17
+ <zero-icon class="ml-5px" name="arrow-down"></zero-icon>
18
+ </zero-button>
19
+ </div>
20
+ </div>
21
+ <div class="w-full h-90pc">
22
+ <zero-grid-pro
23
+ ${ref('grid')}
24
+ floatingFilter="false"
25
+ rowSelection="multiple"
26
+ ></zero-grid-pro>
27
+ </div>
28
+ </zero-card>
29
+ </div>
30
+ `;
@@ -0,0 +1,51 @@
1
+ import { defaultRowConfig } from '../../constants/grid-config';
2
+ /**
3
+ * Field selection grid config
4
+ */
5
+ export const FIELD_SELECT_CONFIG = {
6
+ colDefs: [
7
+ {
8
+ checkboxSelection: true,
9
+ filter: false,
10
+ headerCheckboxSelection: true,
11
+ width: 60,
12
+ },
13
+ {
14
+ field: 'name',
15
+ headerName: 'Field Name',
16
+ },
17
+ ],
18
+ gridOptions: Object.assign(Object.assign({}, defaultRowConfig), { defaultColDef: {
19
+ filter: false,
20
+ floatingFilter: false,
21
+ sortable: false,
22
+ sort: 'asc',
23
+ suppressMenu: false,
24
+ resizable: false,
25
+ }, debug: true }),
26
+ };
27
+ /**
28
+ * Selected fields config
29
+ */
30
+ export const SELECTED_FIELDS_CONFIG = {
31
+ colDefs: [
32
+ {
33
+ checkboxSelection: true,
34
+ filter: false,
35
+ headerCheckboxSelection: true,
36
+ sortable: false,
37
+ width: 60,
38
+ },
39
+ {
40
+ field: 'name',
41
+ headerName: 'Column name',
42
+ },
43
+ ],
44
+ gridOptions: Object.assign(Object.assign({}, defaultRowConfig), { defaultColDef: {
45
+ filter: false,
46
+ floatingFilter: false,
47
+ sortable: false,
48
+ suppressMenu: false,
49
+ resizable: false,
50
+ }, animateRows: true, debug: true, rowDragManaged: true }),
51
+ };
@@ -0,0 +1,218 @@
1
+ export const data = [
2
+ {
3
+ name: 'AMOUNT',
4
+ selected: false,
5
+ type: 'DOUBLE',
6
+ displayName: 'AMOUNT',
7
+ availableFilters: [
8
+ {
9
+ type: 'equals',
10
+ name: 'Equals',
11
+ filterType: 'number',
12
+ },
13
+ {
14
+ type: 'notEqual',
15
+ name: 'Not equal',
16
+ filterType: 'number',
17
+ },
18
+ {
19
+ type: 'lessThan',
20
+ name: 'Less than',
21
+ filterType: 'number',
22
+ },
23
+ {
24
+ type: 'lessThanEquals',
25
+ name: 'Less than or equals',
26
+ filterType: 'number',
27
+ },
28
+ {
29
+ type: 'greaterThan',
30
+ name: 'Greater than',
31
+ filterType: 'number',
32
+ },
33
+ {
34
+ type: 'greaterThanOrEquals',
35
+ name: 'Greater than or equals',
36
+ filterType: 'number',
37
+ },
38
+ {
39
+ type: 'inRange',
40
+ name: 'In range',
41
+ filterType: 'number',
42
+ },
43
+ ],
44
+ filterIsActive: false,
45
+ selectedFilter: {
46
+ type: 'greaterThan',
47
+ name: 'Greater than',
48
+ filterType: 'number',
49
+ },
50
+ selectedFilterValue: 10000,
51
+ },
52
+ {
53
+ name: 'BASE_CURRENCY_AMOUNT',
54
+ selected: false,
55
+ type: 'DOUBLE',
56
+ displayName: 'BASE_CURRENCY_AMOUNT',
57
+ availableFilters: [
58
+ {
59
+ type: 'equals',
60
+ name: 'Equals',
61
+ filterType: 'number',
62
+ },
63
+ {
64
+ type: 'notEqual',
65
+ name: 'Not equal',
66
+ filterType: 'number',
67
+ },
68
+ {
69
+ type: 'lessThan',
70
+ name: 'Less than',
71
+ filterType: 'number',
72
+ },
73
+ {
74
+ type: 'lessThanEquals',
75
+ name: 'Less than or equals',
76
+ filterType: 'number',
77
+ },
78
+ {
79
+ type: 'greaterThan',
80
+ name: 'Greater than',
81
+ filterType: 'number',
82
+ },
83
+ {
84
+ type: 'greaterThanOrEquals',
85
+ name: 'Greater than or equals',
86
+ filterType: 'number',
87
+ },
88
+ {
89
+ type: 'inRange',
90
+ name: 'In range',
91
+ filterType: 'number',
92
+ },
93
+ ],
94
+ filterIsActive: false,
95
+ selectedFilter: {
96
+ type: 'greaterThan',
97
+ name: 'Greater than',
98
+ filterType: 'number',
99
+ },
100
+ },
101
+ {
102
+ name: 'BOND_STOCK_CCY',
103
+ selected: false,
104
+ type: 'STRING',
105
+ displayName: 'BOND_STOCK_CCY',
106
+ availableFilters: [
107
+ {
108
+ type: 'equals',
109
+ name: 'Equals',
110
+ filterType: 'text',
111
+ },
112
+ {
113
+ type: 'notEqual',
114
+ name: 'Not equal',
115
+ filterType: 'text',
116
+ },
117
+ {
118
+ type: 'contains',
119
+ name: 'Contains',
120
+ filterType: 'text',
121
+ },
122
+ {
123
+ type: 'notContains',
124
+ name: 'Not contains',
125
+ filterType: 'text',
126
+ },
127
+ {
128
+ type: 'startsWith',
129
+ name: 'Starts with',
130
+ filterType: 'text',
131
+ },
132
+ {
133
+ type: 'endsWith',
134
+ name: 'Ends with',
135
+ filterType: 'text',
136
+ },
137
+ ],
138
+ filterIsActive: false,
139
+ },
140
+ {
141
+ name: 'BOND_STOCK_TRADE_ID',
142
+ selected: false,
143
+ type: 'STRING',
144
+ displayName: 'BOND_STOCK_TRADE_ID',
145
+ availableFilters: [
146
+ {
147
+ type: 'equals',
148
+ name: 'Equals',
149
+ filterType: 'text',
150
+ },
151
+ {
152
+ type: 'notEqual',
153
+ name: 'Not equal',
154
+ filterType: 'text',
155
+ },
156
+ {
157
+ type: 'contains',
158
+ name: 'Contains',
159
+ filterType: 'text',
160
+ },
161
+ {
162
+ type: 'notContains',
163
+ name: 'Not contains',
164
+ filterType: 'text',
165
+ },
166
+ {
167
+ type: 'startsWith',
168
+ name: 'Starts with',
169
+ filterType: 'text',
170
+ },
171
+ {
172
+ type: 'endsWith',
173
+ name: 'Ends with',
174
+ filterType: 'text',
175
+ },
176
+ ],
177
+ filterIsActive: false,
178
+ },
179
+ {
180
+ name: 'CURRENCY_PAIR',
181
+ selected: false,
182
+ type: 'STRING',
183
+ displayName: 'CURRENCY_PAIR',
184
+ availableFilters: [
185
+ {
186
+ type: 'equals',
187
+ name: 'Equals',
188
+ filterType: 'text',
189
+ },
190
+ {
191
+ type: 'notEqual',
192
+ name: 'Not equal',
193
+ filterType: 'text',
194
+ },
195
+ {
196
+ type: 'contains',
197
+ name: 'Contains',
198
+ filterType: 'text',
199
+ },
200
+ {
201
+ type: 'notContains',
202
+ name: 'Not contains',
203
+ filterType: 'text',
204
+ },
205
+ {
206
+ type: 'startsWith',
207
+ name: 'Starts with',
208
+ filterType: 'text',
209
+ },
210
+ {
211
+ type: 'endsWith',
212
+ name: 'Ends with',
213
+ filterType: 'text',
214
+ },
215
+ ],
216
+ filterIsActive: false,
217
+ },
218
+ ];
@@ -0,0 +1,3 @@
1
+ export * from './select-fields';
2
+ export * from './select-fields.template';
3
+ // export * from './select-fields.styles';
@@ -0,0 +1,197 @@
1
+ import { __awaiter, __decorate } from "tslib";
2
+ import { Connect } from '@genesislcap/foundation-comms';
3
+ import { ZeroAgTextRenderer } from '@genesislcap/foundation-zero-grid-pro';
4
+ import { customElement, FASTElement, observable, attr } from '@microsoft/fast-element';
5
+ import { filterObjectArray, getSelectedFields } from '../../utils';
6
+ import { FIELD_SELECT_CONFIG, SELECTED_FIELDS_CONFIG } from './columns';
7
+ import { SelectFieldsStyles } from './select-fields.styles';
8
+ import { SelectFieldsTemplate } from './select-fields.template';
9
+ let SelectFields = class SelectFields extends FASTElement {
10
+ constructor() {
11
+ super(...arguments);
12
+ this.fieldsToRemove = [];
13
+ this.report = {};
14
+ this.selectedDatasource = '';
15
+ /**
16
+ * As the current fieldsGrid does not have display name ctx, we need to make sure the text renderer field value is not lost
17
+ * @param array Array
18
+ * @returns Array
19
+ */
20
+ this.makeSureFieldValueIsNotLost = (array) => {
21
+ return array.map((field) => {
22
+ var _a;
23
+ const matchingField = (_a = this.selectedFields) === null || _a === void 0 ? void 0 : _a.find((f) => (f === null || f === void 0 ? void 0 : f.name) === (field === null || field === void 0 ? void 0 : field.name));
24
+ return Object.assign(Object.assign({}, field), matchingField);
25
+ });
26
+ };
27
+ /**
28
+ * When text renderer text field changes handle
29
+ * @param value string
30
+ * @param params Object
31
+ */
32
+ this.onTextFieldChange = (value, params) => __awaiter(this, void 0, void 0, function* () {
33
+ const newFields = this.selectedFields.map((field) => {
34
+ let newField = Object.assign({}, field);
35
+ if (field.name === params.node.data.name) {
36
+ newField = Object.assign(Object.assign({}, newField), { displayName: value });
37
+ }
38
+ return newField;
39
+ });
40
+ this.setSelectedFields(newFields);
41
+ });
42
+ /**
43
+ * Refresh select field grid data
44
+ */
45
+ this.refreshSelectFieldGridData = () => {
46
+ const selectedFieldsOrder = [];
47
+ this.selectedFieldsGrid.gridApi.forEachNodeAfterFilterAndSort((rowNode) => {
48
+ selectedFieldsOrder.push(rowNode.data);
49
+ });
50
+ this.setSelectedFields([...this.makeSureFieldValueIsNotLost(selectedFieldsOrder)]);
51
+ };
52
+ /**
53
+ * Remove fields from selected fields grid and deselect them from the available fields grid
54
+ */
55
+ this.removeSelectedFields = () => {
56
+ // filter fields from selected list
57
+ const filteredFields = filterObjectArray('name', this.selectedFields, this.fieldsToRemove);
58
+ this.setSelectedFields(filteredFields);
59
+ // reset removal array
60
+ this.fieldsToRemove = [];
61
+ // deselect available fieldgrid
62
+ this.allFieldsGrid.gridApi.deselectAll();
63
+ // reselect
64
+ this.allFieldsGrid.gridApi.forEachNode((node) => {
65
+ filteredFields.find((field) => field.name === node.data.name) && node.setSelected(true);
66
+ });
67
+ };
68
+ }
69
+ /**
70
+ * Loading selected fields grid when we have selected rows
71
+ */
72
+ selectedFieldsChanged(oldValue) {
73
+ var _a, _b, _c, _d;
74
+ if (oldValue) {
75
+ (_b = (_a = this.selectedFieldsGrid) === null || _a === void 0 ? void 0 : _a.gridApi) === null || _b === void 0 ? void 0 : _b.setRowData(this.selectedFields);
76
+ (_d = (_c = this.selectedFieldsGrid) === null || _c === void 0 ? void 0 : _c.gridApi) === null || _d === void 0 ? void 0 : _d.refreshCells();
77
+ }
78
+ }
79
+ connectedCallback() {
80
+ super.connectedCallback();
81
+ this.loadAllFieldsGrid();
82
+ this.loadSelectedFieldsGrid();
83
+ }
84
+ /**
85
+ * Update selected fields on parent component
86
+ */
87
+ setSelectedFields(fields) {
88
+ this.$emit('setSelectedFields', { fields });
89
+ }
90
+ /**
91
+ * Loads the allFieldsGrid
92
+ */
93
+ loadAllFieldsGrid() {
94
+ return __awaiter(this, void 0, void 0, function* () {
95
+ this.allFieldsGrid.gridOptions = Object.assign(Object.assign({}, FIELD_SELECT_CONFIG.gridOptions), { columnDefs: FIELD_SELECT_CONFIG.colDefs, rowData: [...this.fieldData], onSelectionChanged: () => {
96
+ if (this.selectedFields) {
97
+ this.selectedFields = getSelectedFields(this.allFieldsGrid, this.selectedFields);
98
+ this.setSelectedFields([...this.makeSureFieldValueIsNotLost(this.selectedFields)]);
99
+ }
100
+ else {
101
+ this.setSelectedFields([
102
+ ...this.makeSureFieldValueIsNotLost(this.allFieldsGrid.gridApi.getSelectedRows()),
103
+ ]);
104
+ }
105
+ }, onFirstDataRendered: () => {
106
+ var _a, _b;
107
+ (_b = (_a = this.allFieldsGrid) === null || _a === void 0 ? void 0 : _a.gridApi) === null || _b === void 0 ? void 0 : _b.sizeColumnsToFit();
108
+ this.selectDefaultFields();
109
+ }, onGridReady: () => {
110
+ window.addEventListener('resize', () => {
111
+ setTimeout(() => {
112
+ var _a, _b;
113
+ (_b = (_a = this.allFieldsGrid) === null || _a === void 0 ? void 0 : _a.gridApi) === null || _b === void 0 ? void 0 : _b.sizeColumnsToFit();
114
+ });
115
+ });
116
+ } });
117
+ });
118
+ }
119
+ /**
120
+ * Loads the allFieldsGrid
121
+ */
122
+ loadSelectedFieldsGrid() {
123
+ return __awaiter(this, void 0, void 0, function* () {
124
+ this.selectedFieldsGrid.gridOptions = Object.assign(Object.assign({}, SELECTED_FIELDS_CONFIG.gridOptions), { onRowDragEnd: this.refreshSelectFieldGridData, columnDefs: [
125
+ ...SELECTED_FIELDS_CONFIG.colDefs,
126
+ {
127
+ field: 'displayName',
128
+ headerName: 'Display name',
129
+ cellRenderer: ZeroAgTextRenderer,
130
+ cellRendererParams: {
131
+ accessor: 'displayName',
132
+ onChange: this.onTextFieldChange,
133
+ },
134
+ },
135
+ {
136
+ rowDrag: true,
137
+ width: 60,
138
+ sortable: false,
139
+ filter: false,
140
+ },
141
+ ], rowData: [], onGridReady: () => {
142
+ window.addEventListener('resize', () => {
143
+ setTimeout(() => {
144
+ var _a, _b;
145
+ (_b = (_a = this.selectedFieldsGrid) === null || _a === void 0 ? void 0 : _a.gridApi) === null || _b === void 0 ? void 0 : _b.sizeColumnsToFit();
146
+ });
147
+ });
148
+ }, onFirstDataRendered: () => {
149
+ var _a, _b;
150
+ (_b = (_a = this.selectedFieldsGrid) === null || _a === void 0 ? void 0 : _a.gridApi) === null || _b === void 0 ? void 0 : _b.sizeColumnsToFit();
151
+ }, onSelectionChanged: () => {
152
+ this.fieldsToRemove = this.selectedFieldsGrid.gridApi.getSelectedRows();
153
+ } });
154
+ });
155
+ }
156
+ /**
157
+ * Select default fields
158
+ */
159
+ selectDefaultFields() {
160
+ if (this.selectedFields.length) {
161
+ this.allFieldsGrid.gridApi.forEachNode((node) => {
162
+ this.selectedFields.find((field) => field.name === node.data.name) &&
163
+ node.setSelected(true);
164
+ });
165
+ this.setSelectedFields([...this.makeSureFieldValueIsNotLost(this.selectedFields)]);
166
+ }
167
+ else {
168
+ this.selectedFields = [];
169
+ }
170
+ }
171
+ };
172
+ __decorate([
173
+ Connect
174
+ ], SelectFields.prototype, "connect", void 0);
175
+ __decorate([
176
+ observable
177
+ ], SelectFields.prototype, "fieldsToRemove", void 0);
178
+ __decorate([
179
+ observable
180
+ ], SelectFields.prototype, "fieldData", void 0);
181
+ __decorate([
182
+ observable
183
+ ], SelectFields.prototype, "report", void 0);
184
+ __decorate([
185
+ observable
186
+ ], SelectFields.prototype, "selectedFields", void 0);
187
+ __decorate([
188
+ attr
189
+ ], SelectFields.prototype, "selectedDatasource", void 0);
190
+ SelectFields = __decorate([
191
+ customElement({
192
+ name: 'reporting-select-fields',
193
+ template: SelectFieldsTemplate,
194
+ styles: SelectFieldsStyles,
195
+ })
196
+ ], SelectFields);
197
+ export { SelectFields };
@@ -0,0 +1,21 @@
1
+ import { neutralLayer3 } from '@microsoft/fast-components';
2
+ import { css } from '@microsoft/fast-element';
3
+ import { helperStyles, normalizeStyles } from '../../styles';
4
+ export const SelectFieldsStyles = css `
5
+ ${helperStyles}
6
+ ${normalizeStyles}
7
+ .available-fields,
8
+ .selected-fields {
9
+ height: 100%;
10
+ }
11
+
12
+ .select-fields {
13
+ display: flex;
14
+ width: 100%;
15
+ height: 100%;
16
+ }
17
+
18
+ zero-card {
19
+ background-color: ${neutralLayer3};
20
+ }
21
+ `;