d2coreui 21.0.33 → 23.0.0

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 (295) hide show
  1. package/components/clipboard/clipboardUtils.d.ts +4 -3
  2. package/components/clipboard/clipboardUtils.js +47 -22
  3. package/components/clipboard/clipboardUtils.js.map +1 -1
  4. package/components/codemirror/SyntaxHighlighter.d.ts +21 -21
  5. package/components/codemirror/SyntaxHighlighter.js +45 -44
  6. package/components/codemirror/SyntaxHighlighter.js.map +1 -1
  7. package/components/collapse/expandable.d.ts +13 -12
  8. package/components/collapse/expandable.js +20 -20
  9. package/components/collapse/expandable.js.map +1 -1
  10. package/components/color/colorPicker.d.ts +20 -20
  11. package/components/color/colorPicker.js +53 -53
  12. package/components/color/colorPicker.js.map +1 -1
  13. package/components/color/colorSwatch.d.ts +13 -12
  14. package/components/color/colorSwatch.js +62 -62
  15. package/components/color/colorSwatch.js.map +1 -1
  16. package/components/color/colorUtils.d.ts +7 -7
  17. package/components/color/colorUtils.js +43 -43
  18. package/components/color/colorUtils.js.map +1 -1
  19. package/components/date/dateRangeInput.d.ts +66 -64
  20. package/components/date/dateRangeInput.js +292 -297
  21. package/components/date/dateRangeInput.js.map +1 -1
  22. package/components/date/dateRangeInputAdvancedPanel.d.ts +27 -26
  23. package/components/date/dateRangeInputAdvancedPanel.js +130 -115
  24. package/components/date/dateRangeInputAdvancedPanel.js.map +1 -1
  25. package/components/date/dateRangeInputConfirm.d.ts +31 -29
  26. package/components/date/dateRangeInputConfirm.js +132 -121
  27. package/components/date/dateRangeInputConfirm.js.map +1 -1
  28. package/components/date/dateTimeInput.d.ts +72 -69
  29. package/components/date/dateTimeInput.js +440 -412
  30. package/components/date/dateTimeInput.js.map +1 -1
  31. package/components/date/durationInput.d.ts +59 -56
  32. package/components/date/durationInput.js +269 -280
  33. package/components/date/durationInput.js.map +1 -1
  34. package/components/form/NiceFormItem.d.ts +14 -14
  35. package/components/form/NiceFormItem.js +28 -31
  36. package/components/form/NiceFormItem.js.map +1 -1
  37. package/components/grid/cell/beanAccessor.d.ts +9 -0
  38. package/components/grid/cell/beanAccessor.js +13 -0
  39. package/components/grid/cell/beanAccessor.js.map +1 -0
  40. package/components/grid/cell/cellEditorUtils.d.ts +4 -4
  41. package/components/grid/cell/cellEditorUtils.js +8 -8
  42. package/components/grid/cell/customEnumCellEditor.d.ts +4 -26
  43. package/components/grid/cell/customEnumCellEditor.js +82 -91
  44. package/components/grid/cell/customEnumCellEditor.js.map +1 -1
  45. package/components/grid/cell/dataGridCellEditorComponent.d.ts +14 -0
  46. package/components/grid/cell/dataGridCellEditorComponent.js +49 -0
  47. package/components/grid/cell/dataGridCellEditorComponent.js.map +1 -0
  48. package/components/grid/cell/dateCellEditor.d.ts +4 -25
  49. package/components/grid/cell/dateCellEditor.js +53 -72
  50. package/components/grid/cell/dateCellEditor.js.map +1 -1
  51. package/components/grid/cell/durationCellEditor.d.ts +4 -24
  52. package/components/grid/cell/durationCellEditor.js +74 -97
  53. package/components/grid/cell/durationCellEditor.js.map +1 -1
  54. package/components/grid/cell/hexaOctetStringCellEditor.d.ts +4 -24
  55. package/components/grid/cell/hexaOctetStringCellEditor.js +70 -94
  56. package/components/grid/cell/hexaOctetStringCellEditor.js.map +1 -1
  57. package/components/grid/cell/hexaValueCellEditor.d.ts +4 -24
  58. package/components/grid/cell/hexaValueCellEditor.js +65 -89
  59. package/components/grid/cell/hexaValueCellEditor.js.map +1 -1
  60. package/components/grid/cell/numberCellEditor.d.ts +4 -27
  61. package/components/grid/cell/numberCellEditor.js +73 -95
  62. package/components/grid/cell/numberCellEditor.js.map +1 -1
  63. package/components/grid/cell/rangeSelector.d.ts +78 -78
  64. package/components/grid/cell/rangeSelector.js +526 -518
  65. package/components/grid/cell/rangeSelector.js.map +1 -1
  66. package/components/grid/cell/simpleStatusTextCellEditor.d.ts +4 -32
  67. package/components/grid/cell/simpleStatusTextCellEditor.js +106 -116
  68. package/components/grid/cell/simpleStatusTextCellEditor.js.map +1 -1
  69. package/components/grid/cell/statusTextCellEditor.d.ts +4 -32
  70. package/components/grid/cell/statusTextCellEditor.js +136 -159
  71. package/components/grid/cell/statusTextCellEditor.js.map +1 -1
  72. package/components/grid/cell/tableDefaultRowStyleRules.d.ts +20 -20
  73. package/components/grid/cell/tableDefaultRowStyleRules.js +29 -18
  74. package/components/grid/cell/tableDefaultRowStyleRules.js.map +1 -1
  75. package/components/grid/cell/textCellEditor.d.ts +4 -21
  76. package/components/grid/cell/textCellEditor.js +63 -85
  77. package/components/grid/cell/textCellEditor.js.map +1 -1
  78. package/components/grid/cell/withAgGridHooks.d.ts +3 -0
  79. package/components/grid/cell/withAgGridHooks.js +15 -0
  80. package/components/grid/cell/withAgGridHooks.js.map +1 -0
  81. package/components/grid/columnUtils.d.ts +5 -5
  82. package/components/grid/columnUtils.js +26 -26
  83. package/components/grid/columnUtils.js.map +1 -1
  84. package/components/grid/config/columnTransfer.d.ts +21 -22
  85. package/components/grid/config/columnTransfer.js +205 -201
  86. package/components/grid/config/columnTransfer.js.map +1 -1
  87. package/components/grid/config/dataGridEditor.d.ts +41 -41
  88. package/components/grid/config/dataGridEditor.js +181 -160
  89. package/components/grid/config/dataGridEditor.js.map +1 -1
  90. package/components/grid/config/rowHeightCalculator.d.ts +8 -0
  91. package/components/grid/config/rowHeightCalculator.js +20 -0
  92. package/components/grid/config/rowHeightCalculator.js.map +1 -0
  93. package/components/grid/config/rowStylePicker.d.ts +27 -25
  94. package/components/grid/config/rowStylePicker.js +127 -109
  95. package/components/grid/config/rowStylePicker.js.map +1 -1
  96. package/components/grid/dataGrid.d.ts +218 -206
  97. package/components/grid/dataGrid.js +1629 -1538
  98. package/components/grid/dataGrid.js.map +1 -1
  99. package/components/grid/detail/detailHeaderPanel.d.ts +13 -13
  100. package/components/grid/detail/detailHeaderPanel.js +25 -25
  101. package/components/grid/detail/detailHeaderPanel.js.map +1 -1
  102. package/components/grid/export/contextMenu.d.ts +18 -24
  103. package/components/grid/export/contextMenu.js +116 -113
  104. package/components/grid/export/contextMenu.js.map +1 -1
  105. package/components/grid/export/progressPopup.d.ts +29 -29
  106. package/components/grid/export/progressPopup.js +93 -93
  107. package/components/grid/export/progressPopup.js.map +1 -1
  108. package/components/grid/export/worker/clipboardExport.d.ts +1 -1
  109. package/components/grid/export/worker/clipboardExport.js +8 -8
  110. package/components/grid/export/worker/csvExport.d.ts +1 -1
  111. package/components/grid/export/worker/csvExport.js +8 -8
  112. package/components/grid/export/worker/pdfExport.d.ts +1 -1
  113. package/components/grid/export/worker/pdfExport.js +81 -81
  114. package/components/grid/export/worker/pdfExport.js.map +1 -1
  115. package/components/grid/export/worker/txtExport.d.ts +1 -1
  116. package/components/grid/export/worker/txtExport.js +19 -19
  117. package/components/grid/extendedDataGrid.d.ts +140 -140
  118. package/components/grid/extendedDataGrid.js +704 -695
  119. package/components/grid/extendedDataGrid.js.map +1 -1
  120. package/components/grid/filter/customColumnFilter.d.ts +5 -21
  121. package/components/grid/filter/customColumnFilter.js +11 -82
  122. package/components/grid/filter/customColumnFilter.js.map +1 -1
  123. package/components/grid/filter/dataGridColumnFilter.d.ts +17 -0
  124. package/components/grid/filter/dataGridColumnFilter.js +49 -0
  125. package/components/grid/filter/dataGridColumnFilter.js.map +1 -0
  126. package/components/grid/filter/dateColumnFilter.d.ts +7 -11
  127. package/components/grid/filter/dateColumnFilter.js +22 -56
  128. package/components/grid/filter/dateColumnFilter.js.map +1 -1
  129. package/components/grid/filter/textColumnFilter.d.ts +8 -20
  130. package/components/grid/filter/textColumnFilter.js +24 -76
  131. package/components/grid/filter/textColumnFilter.js.map +1 -1
  132. package/components/grid/filter/wildcardQuickFilterEngine.d.ts +7 -0
  133. package/components/grid/filter/wildcardQuickFilterEngine.js +48 -0
  134. package/components/grid/filter/wildcardQuickFilterEngine.js.map +1 -0
  135. package/components/grid/header/simpleHeader.d.ts +17 -16
  136. package/components/grid/header/simpleHeader.js +230 -186
  137. package/components/grid/header/simpleHeader.js.map +1 -1
  138. package/components/grid/panel/dataGridPagination.d.ts +16 -16
  139. package/components/grid/panel/dataGridPagination.js +58 -58
  140. package/components/grid/panel/dataGridPagination.js.map +1 -1
  141. package/components/grid/panel/loadingOverlay.d.ts +6 -6
  142. package/components/grid/panel/loadingOverlay.js +10 -10
  143. package/components/grid/panel/loadingOverlay.js.map +1 -1
  144. package/components/grid/panel/noRecordsOverlay.d.ts +6 -6
  145. package/components/grid/panel/noRecordsOverlay.js +10 -10
  146. package/components/grid/panel/noRecordsOverlay.js.map +1 -1
  147. package/components/grid/panel/tablePagination.d.ts +10 -10
  148. package/components/grid/panel/tablePagination.js +45 -45
  149. package/components/grid/panel/tablePagination.js.map +1 -1
  150. package/components/icons/dropdownArrow.d.ts +8 -0
  151. package/components/icons/dropdownArrow.js +59 -0
  152. package/components/icons/dropdownArrow.js.map +1 -0
  153. package/components/icons/undoIcon.d.ts +8 -8
  154. package/components/icons/undoIcon.js +6 -6
  155. package/components/input/autoCompleteInput.d.ts +35 -35
  156. package/components/input/autoCompleteInput.js +122 -121
  157. package/components/input/autoCompleteInput.js.map +1 -1
  158. package/components/input/draftUtils.d.ts +4 -4
  159. package/components/input/draftUtils.js +48 -48
  160. package/components/input/draftUtils.js.map +1 -1
  161. package/components/input/draftail.d.ts +1 -1
  162. package/components/input/draftail.js +1 -1
  163. package/components/input/hexaFormattedInput.d.ts +16 -16
  164. package/components/input/hexaFormattedInput.js +54 -54
  165. package/components/input/hexaFormattedInput.js.map +1 -1
  166. package/components/input/mask/helpers.d.ts +28 -28
  167. package/components/input/mask/helpers.js +112 -112
  168. package/components/input/mask/helpers.js.map +1 -1
  169. package/components/input/mask/inputMaskCore.d.ts +46 -46
  170. package/components/input/mask/inputMaskCore.js +278 -278
  171. package/components/input/mask/inputMaskCore.js.map +1 -1
  172. package/components/input/mask/pattern.d.ts +20 -20
  173. package/components/input/mask/pattern.js +78 -78
  174. package/components/input/mask/pattern.js.map +1 -1
  175. package/components/input/maskedInput.d.ts +373 -351
  176. package/components/input/maskedInput.js +224 -224
  177. package/components/input/maskedInput.js.map +1 -1
  178. package/components/input/passwordInput.d.ts +9 -9
  179. package/components/input/passwordInput.js +55 -55
  180. package/components/input/passwordInput.js.map +1 -1
  181. package/components/input/simpleAutoComplete.d.ts +12 -12
  182. package/components/input/simpleAutoComplete.js +41 -43
  183. package/components/input/simpleAutoComplete.js.map +1 -1
  184. package/components/input/textarea/extractSpansOfClasses.d.ts +15 -15
  185. package/components/input/textarea/extractSpansOfClasses.js +96 -96
  186. package/components/input/textarea/extractSpansOfClasses.js.map +1 -1
  187. package/components/input/textarea/getRanges.d.ts +1 -1
  188. package/components/input/textarea/getRanges.js +73 -73
  189. package/components/input/textarea/getRanges.js.map +1 -1
  190. package/components/input/textarea/getType.d.ts +1 -1
  191. package/components/input/textarea/getType.js +26 -26
  192. package/components/input/textarea/getType.js.map +1 -1
  193. package/components/input/textarea/highlighedContents.d.ts +6 -6
  194. package/components/input/textarea/highlighedContents.js +10 -10
  195. package/components/input/textarea/mentionsWithHighlighting.d.ts +27 -27
  196. package/components/input/textarea/mentionsWithHighlighting.js +60 -60
  197. package/components/input/textarea/mentionsWithHighlighting.js.map +1 -1
  198. package/components/keyboard/keyboardUtils.d.ts +5 -5
  199. package/components/keyboard/keyboardUtils.js +32 -32
  200. package/components/modal/draggableModalProvider.d.ts +4 -4
  201. package/components/modal/draggableModalProvider.js +21 -21
  202. package/components/modal/draggableModalProvider.js.map +1 -1
  203. package/components/modal/impl/clamp.d.ts +1 -1
  204. package/components/modal/impl/clamp.js +1 -1
  205. package/components/modal/impl/clamp.js.map +1 -1
  206. package/components/modal/impl/draggableModal.d.ts +12 -12
  207. package/components/modal/impl/draggableModal.js +17 -17
  208. package/components/modal/impl/draggableModal.js.map +1 -1
  209. package/components/modal/impl/draggableModalContext.d.ts +9 -9
  210. package/components/modal/impl/draggableModalContext.js +2 -2
  211. package/components/modal/impl/draggableModalContext.js.map +1 -1
  212. package/components/modal/impl/draggableModalInner.d.ts +15 -13
  213. package/components/modal/impl/draggableModalInner.js +57 -55
  214. package/components/modal/impl/draggableModalInner.js.map +1 -1
  215. package/components/modal/impl/draggableModalReducer.d.ts +66 -62
  216. package/components/modal/impl/draggableModalReducer.js +77 -78
  217. package/components/modal/impl/draggableModalReducer.js.map +1 -1
  218. package/components/modal/impl/getWindowSize.d.ts +4 -4
  219. package/components/modal/impl/getWindowSize.js +4 -4
  220. package/components/modal/impl/getWindowSize.js.map +1 -1
  221. package/components/modal/impl/index.d.ts +3 -3
  222. package/components/modal/impl/index.js +3 -3
  223. package/components/modal/impl/index.js.map +1 -1
  224. package/components/modal/impl/resizeHandle.d.ts +3 -3
  225. package/components/modal/impl/resizeHandle.js +4 -4
  226. package/components/modal/impl/resizeHandle.js.map +1 -1
  227. package/components/modal/impl/useDrag.d.ts +5 -5
  228. package/components/modal/impl/useDrag.js +42 -42
  229. package/components/modal/impl/useDrag.js.map +1 -1
  230. package/components/modal/impl/usePrevious.d.ts +1 -1
  231. package/components/modal/impl/usePrevious.js +8 -8
  232. package/components/modal/impl/usePrevious.js.map +1 -1
  233. package/components/modal/impl/useResize.d.ts +7 -7
  234. package/components/modal/impl/useResize.js +46 -46
  235. package/components/modal/impl/useResize.js.map +1 -1
  236. package/components/modal/modalDialog.d.ts +49 -49
  237. package/components/modal/modalDialog.js +152 -152
  238. package/components/modal/modalDialog.js.map +1 -1
  239. package/components/picker/enumValuePicker.d.ts +16 -16
  240. package/components/picker/enumValuePicker.js +34 -34
  241. package/components/picker/enumValuePicker.js.map +1 -1
  242. package/components/platformSpecific.d.ts +10 -10
  243. package/components/platformSpecific.js +27 -27
  244. package/components/scrollTo/onlyText.d.ts +4 -4
  245. package/components/scrollTo/onlyText.js +30 -30
  246. package/components/scrollTo/onlyText.js.map +1 -1
  247. package/components/scrollTo/scrollTo.d.ts +41 -39
  248. package/components/scrollTo/scrollTo.js +264 -264
  249. package/components/scrollTo/scrollTo.js.map +1 -1
  250. package/components/style/withCss.d.ts +9 -0
  251. package/components/style/withCss.js +6 -0
  252. package/components/style/withCss.js.map +1 -0
  253. package/components/style/withInputNumberCss.d.ts +6 -0
  254. package/components/style/withInputNumberCss.js +13 -0
  255. package/components/style/withInputNumberCss.js.map +1 -0
  256. package/components/table/dragSortingTable.d.ts +13 -14
  257. package/components/table/dragSortingTable.js +96 -82
  258. package/components/table/dragSortingTable.js.map +1 -1
  259. package/components/text/impl/innerSize.d.ts +2 -2
  260. package/components/text/impl/innerSize.js +12 -12
  261. package/components/text/impl/series.d.ts +1 -1
  262. package/components/text/impl/series.js +28 -28
  263. package/components/text/impl/shallowEqual.d.ts +1 -1
  264. package/components/text/impl/shallowEqual.js +18 -18
  265. package/components/text/impl/shallowEqual.js.map +1 -1
  266. package/components/text/impl/uniqueId.d.ts +1 -1
  267. package/components/text/impl/uniqueId.js +4 -4
  268. package/components/text/impl/whilst.d.ts +1 -1
  269. package/components/text/impl/whilst.js +19 -19
  270. package/components/text/impl/whilst.js.map +1 -1
  271. package/components/text/textFit.d.ts +38 -38
  272. package/components/text/textFit.js +165 -168
  273. package/components/text/textFit.js.map +1 -1
  274. package/i18n/components.cs.json +101 -100
  275. package/i18n/components.sk.json +101 -100
  276. package/i18n/components.uk.json +101 -100
  277. package/i18n/componentsLocaleHolder.d.ts +3 -3
  278. package/i18n/componentsLocaleHolder.js +28 -28
  279. package/i18n/componentsLocaleHolder.js.map +1 -1
  280. package/package.json +71 -70
  281. package/style/index.less +274 -298
  282. package/style/modal/DraggableModal.css +43 -40
  283. package/style/modal/ResizeHandle.css +27 -19
  284. package/tsconfig.build.json +24 -24
  285. package/tsconfig.json +11 -11
  286. package/components/grid/cell/wildcardQuickFilter.d.ts +0 -11
  287. package/components/grid/cell/wildcardQuickFilter.js +0 -61
  288. package/components/grid/cell/wildcardQuickFilter.js.map +0 -1
  289. package/components/table/dataTable.d.ts +0 -17
  290. package/components/table/dataTable.js +0 -79
  291. package/components/table/dataTable.js.map +0 -1
  292. package/style/antd/antd-tree-showline.css +0 -25
  293. package/style/antd/full-height-tabs.scss +0 -63
  294. package/style/draftail/draftail-editor.css +0 -179
  295. package/style/table/dragSortingTable.css +0 -7
@@ -1,187 +1,231 @@
1
- import React from 'react';
2
- import { CheckOutlined, ColumnWidthOutlined, ControlOutlined, EyeInvisibleOutlined, PushpinOutlined } from "@ant-design/icons";
3
- import { Dropdown, Menu } from "antd";
4
- import i18n from "d2core/i18n/i18n";
5
- import { UndoMenuIcon } from "d2coreui/components/icons/undoIcon";
6
- export default class SimpleHeader extends React.Component {
7
- constructor(props) {
8
- super(props);
9
- this.unmounted = false;
10
- this.state = {
11
- sortMode: "",
12
- sortOrderIndex: null,
13
- filterPresent: false,
14
- menuVisible: false
15
- };
16
- this.lastMovingChanged = 0;
17
- this.onHeaderClick = this.onHeaderClick.bind(this);
18
- this.onMovingChanged = this.onMovingChanged.bind(this);
19
- this.onFilterChanged = this.onFilterChanged.bind(this);
20
- this.onSortChanged = this.onSortChanged.bind(this);
21
- this.onMultiSortChanged = this.onMultiSortChanged.bind(this);
22
- this.onMenuSelect = this.onMenuSelect.bind(this);
23
- props.column.addEventListener('movingChanged', this.onMovingChanged);
24
- props.column.addEventListener('filterChanged', this.onFilterChanged);
25
- props.column.addEventListener('sortChanged', this.onSortChanged);
26
- props.api.addEventListener('sortChanged', this.onMultiSortChanged);
27
- }
28
- componentDidMount() {
29
- this.onFilterChanged();
30
- this.onSortChanged();
31
- }
32
- componentWillUnmount() {
33
- this.props.column.removeEventListener(this.onMovingChanged);
34
- this.props.column.removeEventListener(this.onFilterChanged);
35
- this.props.column.removeEventListener(this.onSortChanged);
36
- this.unmounted = true;
37
- }
38
- onHeaderClick(event) {
39
- const target = event.target;
40
- if (target && target.className && target.className.indexOf("menu") >= 0) {
41
- return;
42
- }
43
- const moving = this.props.column.isMoving();
44
- const nowTime = new Date().getTime();
45
- const movedRecently = (nowTime - this.lastMovingChanged) < 50;
46
- const columnMoving = moving || movedRecently;
47
- if (!columnMoving && this.props.column.colDef.sortable) {
48
- const sortUsingCtrl = this.props.api.gridOptionsWrapper.isMultiSortKeyCtrl();
49
- const multiSort = sortUsingCtrl ? (event.ctrlKey || event.metaKey) : event.shiftKey;
50
- this.props.api.sortController.progressSort(this.props.column, multiSort, "uiColumnSorted");
51
- }
52
- }
53
- onMovingChanged() {
54
- this.lastMovingChanged = new Date().getTime();
55
- }
56
- onFilterChanged() {
57
- const filterPresent = this.props.column.isFilterActive();
58
- if (!this.unmounted) {
59
- this.setState({ filterPresent: filterPresent });
60
- }
61
- }
62
- onSortChanged() {
63
- let sortMode = "";
64
- if (this.props.column.isSortAscending()) {
65
- sortMode = "asc";
66
- }
67
- else if (this.props.column.isSortDescending()) {
68
- sortMode = "desc";
69
- }
70
- if (!this.unmounted) {
71
- this.setState({
72
- sortMode: sortMode,
73
- });
74
- }
75
- }
76
- onMultiSortChanged() {
77
- let showOrderIndex = null;
78
- const col = this.props.column;
79
- const allColumnsWithSorting = this.props.api.sortController.getColumnsWithSortingOrdered();
80
- const indexThisCol = allColumnsWithSorting.indexOf(col);
81
- const moreThanOneColSorting = allColumnsWithSorting.length > 1;
82
- const showIndex = col.isSorting() && moreThanOneColSorting;
83
- if (showIndex) {
84
- showOrderIndex = indexThisCol + 1;
85
- }
86
- if (!this.unmounted) {
87
- this.setState({
88
- showOrderIndex: showOrderIndex
89
- });
90
- }
91
- }
92
- onMenuSelect(clickParam) {
93
- const { key } = clickParam;
94
- const pinned = this.props.column.pinned;
95
- if (key === "pinLeft") {
96
- if (pinned === "left") {
97
- this.props.columnApi.setColumnPinned(this.props.column, null);
98
- }
99
- else {
100
- this.props.columnApi.setColumnPinned(this.props.column, "left");
101
- }
102
- }
103
- else if (key === "pinRight") {
104
- if (pinned === "right") {
105
- this.props.columnApi.setColumnPinned(this.props.column, null);
106
- }
107
- else {
108
- this.props.columnApi.setColumnPinned(this.props.column, "right");
109
- }
110
- }
111
- else if (key === "autosizeColumn") {
112
- this.props.columnApi.autoSizeColumn(this.props.column);
113
- }
114
- else if (key === "hideColumn") {
115
- this.props.columnApi.setColumnVisible(this.props.column, false);
116
- }
117
- else if (key === "autosizeAllColumns") {
118
- this.props.columnApi.autoSizeAllColumns();
119
- }
120
- else if (key === "resetColumns") {
121
- this.props.columnApi.resetColumnState();
122
- }
123
- else if (key === "columnsConfig") {
124
- this.props.onColumnsConfigVisible(true);
125
- }
126
- this.setState({ menuVisible: false });
127
- }
128
- renderMenu() {
129
- const pinned = this.props.column.pinned;
130
- return (React.createElement(Menu, { onClick: this.onMenuSelect },
131
- React.createElement(Menu.SubMenu, { title: React.createElement("span", null,
132
- React.createElement(PushpinOutlined, null),
133
- " ",
134
- i18n("Pin Column")) },
135
- React.createElement(Menu.Item, { key: "pinLeft", icon: React.createElement(CheckOutlined, { style: { visibility: pinned === "left" ? "visible" : "hidden" } }) }, i18n("Pin Left")),
136
- React.createElement(Menu.Item, { key: "pinRight", icon: React.createElement(CheckOutlined, { style: { visibility: pinned === "right" ? "visible" : "hidden" } }) }, i18n("Pin Right"))),
137
- React.createElement(Menu.Item, { key: "autosizeColumn", icon: React.createElement(ColumnWidthOutlined, null) }, i18n("Autosize Column")),
138
- React.createElement(Menu.Item, { key: "hideColumn", icon: React.createElement(EyeInvisibleOutlined, null) }, i18n("Hide Column")),
139
- React.createElement(Menu.Divider, { key: "divider-menu" }),
140
- React.createElement(Menu.Item, { key: "autosizeAllColumns", icon: React.createElement(ColumnWidthOutlined, null) }, i18n("Autosize All Columns")),
141
- React.createElement(Menu.Item, { key: "resetColumns", icon: React.createElement(UndoMenuIcon, null) }, i18n("Reset Columns")),
142
- React.createElement(Menu.Item, { key: "columnsConfig", icon: React.createElement(ControlOutlined, null) }, i18n("Columns Configuration"))));
143
- }
144
- render() {
145
- const alwaysHideNoSort = !this.props.column.getColDef().unSortIcon && !this.props.api.gridOptionsWrapper.isUnSortIcon();
146
- const sortAscClassName = !this.props.column.isSortAscending() ? "ag-hidden" : "", sortDescClassName = !this.props.column.isSortDescending() ? "ag-hidden" : "", sortNoneClassName = alwaysHideNoSort || !this.props.column.isSortNone() ? "ag-hidden" : "";
147
- let containerClassName = "";
148
- if (this.props.column.isSortAscending()) {
149
- containerClassName = 'ag-header-cell-sorted-asc';
150
- }
151
- else if (this.props.column.isSortDescending()) {
152
- containerClassName = 'ag-header-cell-sorted-desc';
153
- }
154
- else if (this.props.column.isSortNone()) {
155
- containerClassName = 'ag-header-cell-sorted-none';
156
- }
157
- const sortOrderIndexClassName = !this.state.showOrderIndex ? "ag-hidden" : "";
158
- const filterClassName = !this.state.filterPresent ? "ag-hidden" : "";
159
- const columnMenu = this.renderMenu();
160
- const textStyle = { fontSize: this.props.context.fontSize, lineHeight: this.props.context.lineHeight };
161
- return (React.createElement(Dropdown, { overlay: columnMenu, trigger: ["contextMenu"], placement: "bottomCenter" },
162
- React.createElement("div", { className: "ag-cell-label-container " + containerClassName, role: "presentation", onClick: this.onHeaderClick, onMouseOver: () => {
163
- this.setState({ menuVisible: true });
164
- }, onMouseOut: () => {
165
- this.setState({ menuVisible: false });
166
- } },
167
- React.createElement(Dropdown, { overlay: columnMenu, trigger: ["click"], placement: "bottomCenter" },
168
- React.createElement("span", { ref: "eMenu", className: "ag-header-icon ag-header-cell-menu-button", style: {
169
- opacity: this.state.menuVisible ? 1 : 0,
170
- transition: "opacity 0.2s, border 0.2s",
171
- cursor: this.state.menuVisible ? "pointer" : undefined
172
- } },
173
- React.createElement("span", { className: "ag-icon ag-icon-menu", unselectable: "on" }))),
174
- React.createElement("div", { ref: "eLabel", className: "ag-header-cell-label", role: "presentation", unselectable: "on", style: textStyle },
175
- React.createElement("span", { ref: "eText", className: "ag-header-cell-text", role: "columnheader", unselectable: "on" }, this.props.displayName),
176
- React.createElement("span", { ref: "eFilter", className: "ag-header-icon ag-filter-icon " + filterClassName },
177
- React.createElement("span", { className: "ag-icon ag-icon-filter", unselectable: "on" })),
178
- React.createElement("span", { ref: "eSortAsc", className: "ag-header-icon ag-sort-ascending-icon " + sortAscClassName },
179
- React.createElement("span", { className: "ag-icon ag-icon-asc", unselectable: "on" })),
180
- React.createElement("span", { ref: "eSortDesc", className: "ag-header-icon ag-sort-descending-icon " + sortDescClassName },
181
- React.createElement("span", { className: "ag-icon ag-icon-desc", unselectable: "on" })),
182
- React.createElement("span", { ref: "eSortNone", className: "ag-header-icon ag-sort-none-icon " + sortNoneClassName },
183
- React.createElement("span", { className: "ag-icon ag-icon-none", unselectable: "on" })),
184
- React.createElement("span", { ref: "eSortOrder", className: "ag-header-icon ag-sort-order " + sortOrderIndexClassName }, this.state.showOrderIndex)))));
185
- }
186
- }
1
+ import React from 'react';
2
+ import { CheckOutlined, ColumnWidthOutlined, ControlOutlined, EyeInvisibleOutlined, PushpinOutlined } from "@ant-design/icons";
3
+ import { Dropdown } from "antd";
4
+ import i18n from "d2core/i18n/i18n";
5
+ import { UndoMenuIcon } from "d2coreui/components/icons/undoIcon";
6
+ import { calculateLineHeight, GRID_DEFAULT_ROW_HEIGHT_DELTA } from "../config/rowHeightCalculator";
7
+ export default class SimpleHeader extends React.Component {
8
+ constructor(props) {
9
+ super(props);
10
+ this.unmounted = false;
11
+ this.state = {
12
+ sortMode: "",
13
+ sortOrderIndex: null,
14
+ filterPresent: false,
15
+ menuVisible: false
16
+ };
17
+ this.lastMovingChanged = 0;
18
+ this.onHeaderClick = this.onHeaderClick.bind(this);
19
+ this.onMovingChanged = this.onMovingChanged.bind(this);
20
+ this.onFilterChanged = this.onFilterChanged.bind(this);
21
+ this.onSortChanged = this.onSortChanged.bind(this);
22
+ this.onMultiSortChanged = this.onMultiSortChanged.bind(this);
23
+ this.onMenuSelect = this.onMenuSelect.bind(this);
24
+ props.column.addEventListener('movingChanged', this.onMovingChanged);
25
+ props.column.addEventListener('filterChanged', this.onFilterChanged);
26
+ props.column.addEventListener('sortChanged', this.onSortChanged);
27
+ props.api.addEventListener('sortChanged', this.onMultiSortChanged);
28
+ }
29
+ componentDidMount() {
30
+ this.onFilterChanged();
31
+ this.onSortChanged();
32
+ }
33
+ componentWillUnmount() {
34
+ this.props.column.removeEventListener(this.onMovingChanged);
35
+ this.props.column.removeEventListener(this.onFilterChanged);
36
+ this.props.column.removeEventListener(this.onSortChanged);
37
+ this.unmounted = true;
38
+ }
39
+ onHeaderClick(event) {
40
+ const target = event.target;
41
+ if (target && target.className && target.className.indexOf("menu") >= 0) {
42
+ return;
43
+ }
44
+ const moving = this.props.column.isMoving();
45
+ const nowTime = new Date().getTime();
46
+ const movedRecently = (nowTime - this.lastMovingChanged) < 50;
47
+ const columnMoving = moving || movedRecently;
48
+ if (!columnMoving && this.props.column.colDef.sortable) {
49
+ const sortUsingCtrl = this.props.api.getGridOption('multiSortKey') === 'ctrl';
50
+ const multiSort = sortUsingCtrl ? (event.ctrlKey || event.metaKey) : event.shiftKey;
51
+ this.props.progressSort(multiSort);
52
+ }
53
+ }
54
+ onMovingChanged() {
55
+ this.lastMovingChanged = new Date().getTime();
56
+ }
57
+ onFilterChanged() {
58
+ const filterPresent = this.props.column.isFilterActive();
59
+ if (!this.unmounted) {
60
+ this.setState({ filterPresent: filterPresent });
61
+ }
62
+ }
63
+ onSortChanged() {
64
+ let sortMode = "";
65
+ if (this.props.column.isSortAscending()) {
66
+ sortMode = "asc";
67
+ }
68
+ else if (this.props.column.isSortDescending()) {
69
+ sortMode = "desc";
70
+ }
71
+ if (!this.unmounted) {
72
+ this.setState({
73
+ sortMode: sortMode,
74
+ });
75
+ }
76
+ }
77
+ onMultiSortChanged() {
78
+ let showOrderIndex = null;
79
+ const col = this.props.column;
80
+ const allColumnsWithSorting = this.props.api.getColumns().filter((c) => !!c.getSort());
81
+ const moreThanOneColSorting = allColumnsWithSorting.length > 1;
82
+ const showIndex = col.isSorting() && moreThanOneColSorting;
83
+ if (showIndex) {
84
+ showOrderIndex = col.getSortIndex() + 1;
85
+ }
86
+ if (!this.unmounted) {
87
+ this.setState({
88
+ showOrderIndex: showOrderIndex
89
+ });
90
+ }
91
+ }
92
+ onMenuSelect(clickParam) {
93
+ const { key } = clickParam;
94
+ const pinned = this.props.column.pinned;
95
+ if (key === "pinLeft") {
96
+ if (pinned === "left") {
97
+ this.props.api.setColumnsPinned([this.props.column], null);
98
+ }
99
+ else {
100
+ this.props.api.setColumnsPinned([this.props.column], "left");
101
+ }
102
+ }
103
+ else if (key === "pinRight") {
104
+ if (pinned === "right") {
105
+ this.props.api.setColumnsPinned([this.props.column], null);
106
+ }
107
+ else {
108
+ this.props.api.setColumnsPinned([this.props.column], "right");
109
+ }
110
+ }
111
+ else if (key === "autosizeColumn") {
112
+ this.props.api.autoSizeColumns([this.props.column]);
113
+ }
114
+ else if (key === "hideColumn") {
115
+ this.props.api.setColumnsVisible([this.props.column], false);
116
+ }
117
+ else if (key === "autosizeAllColumns") {
118
+ this.props.api.autoSizeAllColumns();
119
+ }
120
+ else if (key === "resetColumns") {
121
+ this.props.api.resetColumnState();
122
+ }
123
+ else if (key === "columnsConfig") {
124
+ this.props.onColumnsConfigVisible(true);
125
+ }
126
+ this.setState({ menuVisible: false });
127
+ }
128
+ getColumnMenu() {
129
+ const pinned = this.props.column.pinned;
130
+ const items = [
131
+ {
132
+ key: "pin",
133
+ label: React.createElement("span", null,
134
+ React.createElement(PushpinOutlined, null),
135
+ " ",
136
+ i18n("Pin Column")),
137
+ children: [
138
+ {
139
+ key: "pinLeft",
140
+ icon: React.createElement(CheckOutlined, { style: { visibility: pinned === "left" ? "visible" : "hidden" } }),
141
+ label: i18n("Pin Left"),
142
+ },
143
+ {
144
+ key: "pinRight",
145
+ icon: React.createElement(CheckOutlined, { style: { visibility: pinned === "right" ? "visible" : "hidden" } }),
146
+ label: i18n("Pin Right"),
147
+ },
148
+ ]
149
+ },
150
+ {
151
+ key: "autosizeColumn",
152
+ icon: React.createElement(ColumnWidthOutlined, null),
153
+ label: i18n("Autosize Column")
154
+ },
155
+ {
156
+ key: "hideColumn",
157
+ icon: React.createElement(EyeInvisibleOutlined, null),
158
+ label: i18n("Hide Column"),
159
+ },
160
+ {
161
+ key: "divider-menu",
162
+ type: "divider",
163
+ },
164
+ {
165
+ key: "autosizeAllColumns",
166
+ icon: React.createElement(ColumnWidthOutlined, null),
167
+ label: i18n("Autosize All Columns")
168
+ },
169
+ {
170
+ key: "resetColumns",
171
+ icon: React.createElement(UndoMenuIcon, null),
172
+ label: i18n("Reset Columns")
173
+ },
174
+ {
175
+ key: "columnsConfig",
176
+ icon: React.createElement(ControlOutlined, null),
177
+ label: i18n("Columns Configuration")
178
+ },
179
+ ];
180
+ return {
181
+ onClick: this.onMenuSelect,
182
+ items: items,
183
+ };
184
+ }
185
+ render() {
186
+ const alwaysHideNoSort = !this.props.column.getColDef().unSortIcon && !this.props.api.getGridOption('unSortIcon');
187
+ const sortAscClassName = !this.props.column.isSortAscending() ? "ag-hidden" : "", sortDescClassName = !this.props.column.isSortDescending() ? "ag-hidden" : "", sortNoneClassName = alwaysHideNoSort || !this.props.column.isSortNone() ? "ag-hidden" : "";
188
+ let containerClassName = "";
189
+ if (this.props.column.isSortAscending()) {
190
+ containerClassName = 'ag-header-cell-sorted-asc';
191
+ }
192
+ else if (this.props.column.isSortDescending()) {
193
+ containerClassName = 'ag-header-cell-sorted-desc';
194
+ }
195
+ else if (this.props.column.isSortNone()) {
196
+ containerClassName = 'ag-header-cell-sorted-none';
197
+ }
198
+ const sortOrderIndexClassName = !this.state.showOrderIndex ? "ag-hidden" : "";
199
+ const filterClassName = !this.state.filterPresent ? "ag-hidden" : "";
200
+ const columnMenu = this.getColumnMenu();
201
+ const textStyle = {
202
+ fontSize: this.props.context.fontSize,
203
+ lineHeight: calculateLineHeight(this.props.context.fontSize, GRID_DEFAULT_ROW_HEIGHT_DELTA + 2)
204
+ };
205
+ return (React.createElement(Dropdown, { menu: columnMenu, trigger: ["contextMenu"], placement: "bottom" },
206
+ React.createElement("div", { className: "ag-cell-label-container " + containerClassName, role: "presentation", onClick: this.onHeaderClick, onMouseOver: () => {
207
+ this.setState({ menuVisible: true });
208
+ }, onMouseOut: () => {
209
+ this.setState({ menuVisible: false });
210
+ } },
211
+ React.createElement(Dropdown, { menu: columnMenu, trigger: ["click"], placement: "bottom" },
212
+ React.createElement("span", { ref: "eMenu", className: "ag-header-icon ag-header-cell-menu-button", style: {
213
+ opacity: this.state.menuVisible ? 1 : 0,
214
+ transition: "opacity 0.2s, border 0.2s",
215
+ cursor: this.state.menuVisible ? "pointer" : undefined
216
+ } },
217
+ React.createElement("span", { className: "ag-icon ag-icon-menu", unselectable: "on" }))),
218
+ React.createElement("div", { className: "ag-header-cell-label", role: "presentation", unselectable: "on", style: textStyle },
219
+ React.createElement("span", { className: "ag-header-cell-text", role: "columnheader", unselectable: "on" }, this.props.displayName),
220
+ React.createElement("span", { className: "ag-header-icon ag-filter-icon " + filterClassName },
221
+ React.createElement("span", { className: "ag-icon ag-icon-filter", unselectable: "on" })),
222
+ React.createElement("span", { className: "ag-header-icon ag-sort-ascending-icon " + sortAscClassName },
223
+ React.createElement("span", { className: "ag-icon ag-icon-asc", unselectable: "on" })),
224
+ React.createElement("span", { className: "ag-header-icon ag-sort-descending-icon " + sortDescClassName },
225
+ React.createElement("span", { className: "ag-icon ag-icon-desc", unselectable: "on" })),
226
+ React.createElement("span", { className: "ag-header-icon ag-sort-none-icon " + sortNoneClassName },
227
+ React.createElement("span", { className: "ag-icon ag-icon-none", unselectable: "on" })),
228
+ React.createElement("span", { className: "ag-header-icon ag-sort-order " + sortOrderIndexClassName }, this.state.showOrderIndex)))));
229
+ }
230
+ }
187
231
  //# sourceMappingURL=simpleHeader.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"simpleHeader.js","sourceRoot":"","sources":["../../../../../components/grid/header/simpleHeader.tsx"],"names":[],"mappings":"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","sourcesContent":["import React from 'react';\nimport {\n CheckOutlined,\n ColumnWidthOutlined,\n ControlOutlined,\n EyeInvisibleOutlined,\n PushpinOutlined\n} from \"@ant-design/icons\";\nimport {Dropdown, Menu} from \"antd\";\nimport i18n from \"d2core/i18n/i18n\"\nimport {UndoMenuIcon} from \"d2coreui/components/icons/undoIcon\";\n\nexport default class SimpleHeader extends React.Component<any, any> {\n lastMovingChanged: number;\n unmounted: boolean = false;\n\n constructor(props: Readonly<any>) {\n super(props);\n this.state = {\n sortMode: \"\",\n sortOrderIndex: null,\n filterPresent: false,\n menuVisible: false\n };\n this.lastMovingChanged = 0;\n this.onHeaderClick = this.onHeaderClick.bind(this);\n this.onMovingChanged = this.onMovingChanged.bind(this);\n this.onFilterChanged = this.onFilterChanged.bind(this);\n this.onSortChanged = this.onSortChanged.bind(this);\n this.onMultiSortChanged = this.onMultiSortChanged.bind(this);\n this.onMenuSelect = this.onMenuSelect.bind(this);\n props.column.addEventListener('movingChanged', this.onMovingChanged);\n props.column.addEventListener('filterChanged', this.onFilterChanged);\n props.column.addEventListener('sortChanged', this.onSortChanged);\n props.api.addEventListener('sortChanged', this.onMultiSortChanged);\n }\n\n componentDidMount() {\n this.onFilterChanged();\n this.onSortChanged();\n }\n\n componentWillUnmount() {\n this.props.column.removeEventListener(this.onMovingChanged);\n this.props.column.removeEventListener(this.onFilterChanged);\n this.props.column.removeEventListener(this.onSortChanged);\n this.unmounted = true;\n }\n\n onHeaderClick(event: React.MouseEvent<HTMLDivElement>) {\n const target = event.target as HTMLElement;\n if (target && target.className && target.className.indexOf(\"menu\") >= 0) {\n // now clicking on menu button, ignore sorting operation\n return;\n }\n // sometimes when moving a column via dragging, this was also firing a clicked event.\n // this check stops sort if a) column is moving or b) column moved less than 200ms ago (so caters for race condition)\n const moving = this.props.column.isMoving();\n const nowTime = new Date().getTime();\n // typically there is <2ms if moving flag was set recently, as it would be done in same VM turn\n const movedRecently = (nowTime - this.lastMovingChanged) < 50;\n const columnMoving = moving || movedRecently;\n\n if (!columnMoving && this.props.column.colDef.sortable) {\n const sortUsingCtrl = this.props.api.gridOptionsWrapper.isMultiSortKeyCtrl();\n const multiSort = sortUsingCtrl ? (event.ctrlKey || event.metaKey) : event.shiftKey;\n this.props.api.sortController.progressSort(this.props.column, multiSort, \"uiColumnSorted\");\n }\n }\n\n // keep track of last time the moving changed flag was set\n onMovingChanged() {\n this.lastMovingChanged = new Date().getTime();\n }\n\n onFilterChanged() {\n const filterPresent = this.props.column.isFilterActive();\n if (!this.unmounted) {\n this.setState({filterPresent: filterPresent});\n }\n }\n\n onSortChanged() {\n let sortMode = \"\";\n if (this.props.column.isSortAscending()) {\n sortMode = \"asc\";\n } else if (this.props.column.isSortDescending()) {\n sortMode = \"desc\";\n }\n if (!this.unmounted) {\n this.setState({\n sortMode: sortMode,\n });\n }\n }\n\n onMultiSortChanged() {\n let showOrderIndex = null;\n const col = this.props.column;\n const allColumnsWithSorting = this.props.api.sortController.getColumnsWithSortingOrdered();\n const indexThisCol = allColumnsWithSorting.indexOf(col);\n const moreThanOneColSorting = allColumnsWithSorting.length > 1;\n const showIndex = col.isSorting() && moreThanOneColSorting;\n if (showIndex) {\n showOrderIndex = indexThisCol + 1;\n }\n\n if (!this.unmounted) {\n this.setState({\n showOrderIndex: showOrderIndex\n });\n }\n }\n\n onMenuSelect(clickParam: any) {\n const {key} = clickParam;\n const pinned = this.props.column.pinned;\n if (key === \"pinLeft\") {\n if (pinned === \"left\") {\n this.props.columnApi.setColumnPinned(this.props.column, null);\n } else {\n this.props.columnApi.setColumnPinned(this.props.column, \"left\");\n }\n } else if (key === \"pinRight\") {\n if (pinned === \"right\") {\n this.props.columnApi.setColumnPinned(this.props.column, null);\n } else {\n this.props.columnApi.setColumnPinned(this.props.column, \"right\");\n }\n } else if (key === \"autosizeColumn\") {\n this.props.columnApi.autoSizeColumn(this.props.column);\n } else if (key === \"hideColumn\") {\n this.props.columnApi.setColumnVisible(this.props.column, false);\n } else if (key === \"autosizeAllColumns\") {\n this.props.columnApi.autoSizeAllColumns();\n } else if (key === \"resetColumns\") {\n this.props.columnApi.resetColumnState();\n } else if (key === \"columnsConfig\") {\n this.props.onColumnsConfigVisible(true);\n }\n this.setState({menuVisible: false});\n }\n\n renderMenu() {\n const pinned = this.props.column.pinned;\n return (\n <Menu onClick={this.onMenuSelect}>\n <Menu.SubMenu title={<span><PushpinOutlined/> {i18n(\"Pin Column\")}</span>}>\n <Menu.Item key=\"pinLeft\" icon={<CheckOutlined style={{visibility: pinned === \"left\" ? \"visible\" : \"hidden\"}}/>}>\n {i18n(\"Pin Left\")}\n </Menu.Item>\n <Menu.Item key=\"pinRight\" icon={<CheckOutlined style={{visibility: pinned === \"right\" ? \"visible\" : \"hidden\"}}/>}>\n {i18n(\"Pin Right\")}\n </Menu.Item>\n </Menu.SubMenu>\n <Menu.Item key=\"autosizeColumn\" icon={<ColumnWidthOutlined/>}>\n {i18n(\"Autosize Column\")}\n </Menu.Item>\n <Menu.Item key=\"hideColumn\" icon={<EyeInvisibleOutlined/>}>\n {i18n(\"Hide Column\")}\n </Menu.Item>\n <Menu.Divider key=\"divider-menu\"/>\n <Menu.Item key=\"autosizeAllColumns\" icon={<ColumnWidthOutlined/>}>\n {i18n(\"Autosize All Columns\")}\n </Menu.Item>\n <Menu.Item key=\"resetColumns\" icon={<UndoMenuIcon/>}>\n {i18n(\"Reset Columns\")}\n </Menu.Item>\n <Menu.Item key=\"columnsConfig\" icon={<ControlOutlined/>}>\n {i18n(\"Columns Configuration\")}\n </Menu.Item>\n </Menu>\n );\n }\n\n render() {\n const alwaysHideNoSort = !this.props.column.getColDef().unSortIcon && !this.props.api.gridOptionsWrapper.isUnSortIcon();\n const sortAscClassName = !this.props.column.isSortAscending() ? \"ag-hidden\" : \"\",\n sortDescClassName = !this.props.column.isSortDescending() ? \"ag-hidden\" : \"\",\n sortNoneClassName = alwaysHideNoSort || !this.props.column.isSortNone() ? \"ag-hidden\" : \"\";\n let containerClassName = \"\";\n if (this.props.column.isSortAscending()) {\n containerClassName = 'ag-header-cell-sorted-asc';\n } else if (this.props.column.isSortDescending()) {\n containerClassName = 'ag-header-cell-sorted-desc';\n } else if (this.props.column.isSortNone()) {\n containerClassName = 'ag-header-cell-sorted-none';\n }\n const sortOrderIndexClassName = !this.state.showOrderIndex ? \"ag-hidden\" : \"\";\n const filterClassName = !this.state.filterPresent ? \"ag-hidden\" : \"\";\n const columnMenu = this.renderMenu();\n\n const textStyle = {fontSize: this.props.context.fontSize, lineHeight: this.props.context.lineHeight};\n\n return (\n <Dropdown overlay={columnMenu} trigger={[\"contextMenu\"]} placement=\"bottomCenter\">\n <div className={\"ag-cell-label-container \" + containerClassName} role=\"presentation\"\n onClick={this.onHeaderClick}\n onMouseOver={() => {\n this.setState({menuVisible: true});\n }}\n onMouseOut={() => {\n this.setState({menuVisible: false});\n }}>\n <Dropdown overlay={columnMenu} trigger={[\"click\"]} placement=\"bottomCenter\">\n <span ref=\"eMenu\" className=\"ag-header-icon ag-header-cell-menu-button\"\n style={{\n opacity: this.state.menuVisible ? 1 : 0,\n transition: \"opacity 0.2s, border 0.2s\",\n cursor: this.state.menuVisible ? \"pointer\" : undefined\n }}>\n <span className=\"ag-icon ag-icon-menu\" unselectable=\"on\"/>\n </span>\n </Dropdown>\n <div ref=\"eLabel\" className=\"ag-header-cell-label\" role=\"presentation\" unselectable=\"on\"\n style={textStyle}>\n <span ref=\"eText\" className=\"ag-header-cell-text\" role=\"columnheader\" unselectable=\"on\">\n {this.props.displayName}\n </span>\n <span ref=\"eFilter\" className={\"ag-header-icon ag-filter-icon \" + filterClassName}>\n <span className=\"ag-icon ag-icon-filter\" unselectable=\"on\"/>\n </span>\n <span ref=\"eSortAsc\" className={\"ag-header-icon ag-sort-ascending-icon \" + sortAscClassName}>\n <span className=\"ag-icon ag-icon-asc\" unselectable=\"on\"/>\n </span>\n <span ref=\"eSortDesc\" className={\"ag-header-icon ag-sort-descending-icon \" + sortDescClassName}>\n <span className=\"ag-icon ag-icon-desc\" unselectable=\"on\"/>\n </span>\n <span ref=\"eSortNone\" className={\"ag-header-icon ag-sort-none-icon \" + sortNoneClassName}>\n <span className=\"ag-icon ag-icon-none\" unselectable=\"on\"/>\n </span>\n <span ref=\"eSortOrder\" className={\"ag-header-icon ag-sort-order \" + sortOrderIndexClassName}>\n {this.state.showOrderIndex}\n </span>\n </div>\n </div>\n </Dropdown>\n );\n }\n}"]}
1
+ {"version":3,"file":"simpleHeader.js","sourceRoot":"","sources":["../../../../../components/grid/header/simpleHeader.tsx"],"names":[],"mappings":"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","sourcesContent":["import React from 'react';\r\nimport {\r\n CheckOutlined,\r\n ColumnWidthOutlined,\r\n ControlOutlined,\r\n EyeInvisibleOutlined,\r\n PushpinOutlined\r\n} from \"@ant-design/icons\";\r\nimport {Dropdown, MenuProps} from \"antd\";\r\nimport i18n from \"d2core/i18n/i18n\"\r\nimport {UndoMenuIcon} from \"d2coreui/components/icons/undoIcon\";\r\nimport {MenuElement} from \"../dataGrid\";\r\nimport {calculateLineHeight, GRID_DEFAULT_ROW_HEIGHT_DELTA} from \"../config/rowHeightCalculator\";\r\nimport {Column} from \"ag-grid-community\";\r\n\r\nexport default class SimpleHeader extends React.Component<any, any> {\r\n lastMovingChanged: number;\r\n unmounted: boolean = false;\r\n\r\n constructor(props: Readonly<any>) {\r\n super(props);\r\n this.state = {\r\n sortMode: \"\",\r\n sortOrderIndex: null,\r\n filterPresent: false,\r\n menuVisible: false\r\n };\r\n this.lastMovingChanged = 0;\r\n this.onHeaderClick = this.onHeaderClick.bind(this);\r\n this.onMovingChanged = this.onMovingChanged.bind(this);\r\n this.onFilterChanged = this.onFilterChanged.bind(this);\r\n this.onSortChanged = this.onSortChanged.bind(this);\r\n this.onMultiSortChanged = this.onMultiSortChanged.bind(this);\r\n this.onMenuSelect = this.onMenuSelect.bind(this);\r\n props.column.addEventListener('movingChanged', this.onMovingChanged);\r\n props.column.addEventListener('filterChanged', this.onFilterChanged);\r\n props.column.addEventListener('sortChanged', this.onSortChanged);\r\n props.api.addEventListener('sortChanged', this.onMultiSortChanged);\r\n }\r\n\r\n componentDidMount() {\r\n this.onFilterChanged();\r\n this.onSortChanged();\r\n }\r\n\r\n componentWillUnmount() {\r\n this.props.column.removeEventListener(this.onMovingChanged);\r\n this.props.column.removeEventListener(this.onFilterChanged);\r\n this.props.column.removeEventListener(this.onSortChanged);\r\n this.unmounted = true;\r\n }\r\n\r\n onHeaderClick(event: React.MouseEvent<HTMLDivElement>) {\r\n const target = event.target as HTMLElement;\r\n if (target && target.className && target.className.indexOf(\"menu\") >= 0) {\r\n // now clicking on menu button, ignore sorting operation\r\n return;\r\n }\r\n // sometimes when moving a column via dragging, this was also firing a clicked event.\r\n // this check stops sort if a) column is moving or b) column moved less than 200ms ago (so caters for race condition)\r\n const moving = this.props.column.isMoving();\r\n const nowTime = new Date().getTime();\r\n // typically there is <2ms if moving flag was set recently, as it would be done in same VM turn\r\n const movedRecently = (nowTime - this.lastMovingChanged) < 50;\r\n const columnMoving = moving || movedRecently;\r\n\r\n if (!columnMoving && this.props.column.colDef.sortable) {\r\n const sortUsingCtrl = this.props.api.getGridOption('multiSortKey') === 'ctrl';\r\n const multiSort = sortUsingCtrl ? (event.ctrlKey || event.metaKey) : event.shiftKey;\r\n this.props.progressSort(multiSort);\r\n }\r\n }\r\n\r\n // keep track of last time the moving changed flag was set\r\n onMovingChanged() {\r\n this.lastMovingChanged = new Date().getTime();\r\n }\r\n\r\n onFilterChanged() {\r\n const filterPresent = this.props.column.isFilterActive();\r\n if (!this.unmounted) {\r\n this.setState({filterPresent: filterPresent});\r\n }\r\n }\r\n\r\n onSortChanged() {\r\n let sortMode = \"\";\r\n if (this.props.column.isSortAscending()) {\r\n sortMode = \"asc\";\r\n } else if (this.props.column.isSortDescending()) {\r\n sortMode = \"desc\";\r\n }\r\n if (!this.unmounted) {\r\n this.setState({\r\n sortMode: sortMode,\r\n });\r\n }\r\n }\r\n\r\n onMultiSortChanged() {\r\n let showOrderIndex = null;\r\n const col = this.props.column;\r\n const allColumnsWithSorting = this.props.api.getColumns().filter((c:Column)=> !!c.getSort());\r\n\r\n const moreThanOneColSorting = allColumnsWithSorting.length > 1;\r\n const showIndex = col.isSorting() && moreThanOneColSorting;\r\n if (showIndex) {\r\n showOrderIndex = col.getSortIndex()!! + 1;\r\n }\r\n\r\n if (!this.unmounted) {\r\n this.setState({\r\n showOrderIndex: showOrderIndex\r\n });\r\n }\r\n }\r\n\r\n onMenuSelect(clickParam: any) {\r\n const {key} = clickParam;\r\n const pinned = this.props.column.pinned;\r\n if (key === \"pinLeft\") {\r\n if (pinned === \"left\") {\r\n this.props.api.setColumnsPinned([this.props.column], null);\r\n } else {\r\n this.props.api.setColumnsPinned([this.props.column], \"left\");\r\n }\r\n } else if (key === \"pinRight\") {\r\n if (pinned === \"right\") {\r\n this.props.api.setColumnsPinned([this.props.column], null);\r\n } else {\r\n this.props.api.setColumnsPinned([this.props.column], \"right\");\r\n }\r\n } else if (key === \"autosizeColumn\") {\r\n this.props.api.autoSizeColumns([this.props.column]);\r\n } else if (key === \"hideColumn\") {\r\n this.props.api.setColumnsVisible([this.props.column], false);\r\n } else if (key === \"autosizeAllColumns\") {\r\n this.props.api.autoSizeAllColumns();\r\n } else if (key === \"resetColumns\") {\r\n this.props.api.resetColumnState();\r\n } else if (key === \"columnsConfig\") {\r\n this.props.onColumnsConfigVisible(true);\r\n }\r\n this.setState({menuVisible: false});\r\n }\r\n\r\n getColumnMenu(): MenuProps {\r\n const pinned = this.props.column.pinned;\r\n const items: MenuElement[] = [\r\n {\r\n key: \"pin\",\r\n label: <span><PushpinOutlined/> {i18n(\"Pin Column\")}</span>,\r\n children: [\r\n {\r\n key: \"pinLeft\",\r\n icon: <CheckOutlined style={{visibility: pinned === \"left\" ? \"visible\" : \"hidden\"}}/>,\r\n label: i18n(\"Pin Left\"),\r\n },\r\n {\r\n key: \"pinRight\",\r\n icon: <CheckOutlined style={{visibility: pinned === \"right\" ? \"visible\" : \"hidden\"}}/>,\r\n label: i18n(\"Pin Right\"),\r\n },\r\n ]\r\n },\r\n {\r\n key: \"autosizeColumn\",\r\n icon: <ColumnWidthOutlined/>,\r\n label: i18n(\"Autosize Column\")\r\n },\r\n {\r\n key: \"hideColumn\",\r\n icon: <EyeInvisibleOutlined/>,\r\n label: i18n(\"Hide Column\"),\r\n },\r\n {\r\n key: \"divider-menu\",\r\n type: \"divider\",\r\n },\r\n {\r\n key: \"autosizeAllColumns\",\r\n icon: <ColumnWidthOutlined/>,\r\n label: i18n(\"Autosize All Columns\")\r\n },\r\n {\r\n key: \"resetColumns\",\r\n icon: <UndoMenuIcon/>,\r\n label: i18n(\"Reset Columns\")\r\n },\r\n {\r\n key: \"columnsConfig\",\r\n icon: <ControlOutlined/>,\r\n label: i18n(\"Columns Configuration\")\r\n },\r\n ];\r\n\r\n return {\r\n onClick: this.onMenuSelect,\r\n items: items,\r\n };\r\n }\r\n\r\n render() {\r\n const alwaysHideNoSort = !this.props.column.getColDef().unSortIcon && !this.props.api.getGridOption('unSortIcon');\r\n const sortAscClassName = !this.props.column.isSortAscending() ? \"ag-hidden\" : \"\",\r\n sortDescClassName = !this.props.column.isSortDescending() ? \"ag-hidden\" : \"\",\r\n sortNoneClassName = alwaysHideNoSort || !this.props.column.isSortNone() ? \"ag-hidden\" : \"\";\r\n let containerClassName = \"\";\r\n if (this.props.column.isSortAscending()) {\r\n containerClassName = 'ag-header-cell-sorted-asc';\r\n } else if (this.props.column.isSortDescending()) {\r\n containerClassName = 'ag-header-cell-sorted-desc';\r\n } else if (this.props.column.isSortNone()) {\r\n containerClassName = 'ag-header-cell-sorted-none';\r\n }\r\n const sortOrderIndexClassName = !this.state.showOrderIndex ? \"ag-hidden\" : \"\";\r\n const filterClassName = !this.state.filterPresent ? \"ag-hidden\" : \"\";\r\n const columnMenu = this.getColumnMenu();\r\n\r\n const textStyle = {\r\n fontSize: this.props.context.fontSize,\r\n lineHeight: calculateLineHeight(this.props.context.fontSize, GRID_DEFAULT_ROW_HEIGHT_DELTA + 2)\r\n };\r\n\r\n return (\r\n <Dropdown menu={columnMenu} trigger={[\"contextMenu\"]} placement=\"bottom\">\r\n <div className={\"ag-cell-label-container \" + containerClassName} role=\"presentation\"\r\n onClick={this.onHeaderClick}\r\n onMouseOver={() => {\r\n this.setState({menuVisible: true});\r\n }}\r\n onMouseOut={() => {\r\n this.setState({menuVisible: false});\r\n }}>\r\n <Dropdown menu={columnMenu} trigger={[\"click\"]} placement=\"bottom\">\r\n <span ref=\"eMenu\" className=\"ag-header-icon ag-header-cell-menu-button\"\r\n style={{\r\n opacity: this.state.menuVisible ? 1 : 0,\r\n transition: \"opacity 0.2s, border 0.2s\",\r\n cursor: this.state.menuVisible ? \"pointer\" : undefined\r\n }}>\r\n <span className=\"ag-icon ag-icon-menu\" unselectable=\"on\"/>\r\n </span>\r\n </Dropdown>\r\n <div className=\"ag-header-cell-label\" role=\"presentation\" unselectable=\"on\"\r\n style={textStyle}>\r\n <span className=\"ag-header-cell-text\" role=\"columnheader\" unselectable=\"on\">\r\n {this.props.displayName}\r\n </span>\r\n <span className={\"ag-header-icon ag-filter-icon \" + filterClassName}>\r\n <span className=\"ag-icon ag-icon-filter\" unselectable=\"on\"/>\r\n </span>\r\n <span className={\"ag-header-icon ag-sort-ascending-icon \" + sortAscClassName}>\r\n <span className=\"ag-icon ag-icon-asc\" unselectable=\"on\"/>\r\n </span>\r\n <span className={\"ag-header-icon ag-sort-descending-icon \" + sortDescClassName}>\r\n <span className=\"ag-icon ag-icon-desc\" unselectable=\"on\"/>\r\n </span>\r\n <span className={\"ag-header-icon ag-sort-none-icon \" + sortNoneClassName}>\r\n <span className=\"ag-icon ag-icon-none\" unselectable=\"on\"/>\r\n </span>\r\n <span className={\"ag-header-icon ag-sort-order \" + sortOrderIndexClassName}>\r\n {this.state.showOrderIndex}\r\n </span>\r\n </div>\r\n </div>\r\n </Dropdown>\r\n );\r\n }\r\n}"]}
@@ -1,16 +1,16 @@
1
- import React from "react";
2
- interface DataGridPaginationProps {
3
- disabled?: boolean;
4
- current: number;
5
- pageSize: number;
6
- total: number;
7
- onGoToPage(page: number): void;
8
- }
9
- interface DataGridPaginationState {
10
- gotoPageNumber?: number;
11
- }
12
- export default class DataGridPagination extends React.Component<DataGridPaginationProps, DataGridPaginationState> {
13
- constructor(props: Readonly<DataGridPaginationProps>);
14
- render(): JSX.Element;
15
- }
16
- export {};
1
+ import React from "react";
2
+ interface DataGridPaginationProps {
3
+ disabled?: boolean;
4
+ current: number;
5
+ pageSize: number;
6
+ total: number;
7
+ onGoToPage(page: number): void;
8
+ }
9
+ interface DataGridPaginationState {
10
+ gotoPageNumber?: number;
11
+ }
12
+ export default class DataGridPagination extends React.Component<DataGridPaginationProps, DataGridPaginationState> {
13
+ constructor(props: Readonly<DataGridPaginationProps>);
14
+ render(): React.JSX.Element;
15
+ }
16
+ export {};