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.
- package/components/clipboard/clipboardUtils.d.ts +4 -3
- package/components/clipboard/clipboardUtils.js +47 -22
- package/components/clipboard/clipboardUtils.js.map +1 -1
- package/components/codemirror/SyntaxHighlighter.d.ts +21 -21
- package/components/codemirror/SyntaxHighlighter.js +45 -44
- package/components/codemirror/SyntaxHighlighter.js.map +1 -1
- package/components/collapse/expandable.d.ts +13 -12
- package/components/collapse/expandable.js +20 -20
- package/components/collapse/expandable.js.map +1 -1
- package/components/color/colorPicker.d.ts +20 -20
- package/components/color/colorPicker.js +53 -53
- package/components/color/colorPicker.js.map +1 -1
- package/components/color/colorSwatch.d.ts +13 -12
- package/components/color/colorSwatch.js +62 -62
- package/components/color/colorSwatch.js.map +1 -1
- package/components/color/colorUtils.d.ts +7 -7
- package/components/color/colorUtils.js +43 -43
- package/components/color/colorUtils.js.map +1 -1
- package/components/date/dateRangeInput.d.ts +66 -64
- package/components/date/dateRangeInput.js +292 -297
- package/components/date/dateRangeInput.js.map +1 -1
- package/components/date/dateRangeInputAdvancedPanel.d.ts +27 -26
- package/components/date/dateRangeInputAdvancedPanel.js +130 -115
- package/components/date/dateRangeInputAdvancedPanel.js.map +1 -1
- package/components/date/dateRangeInputConfirm.d.ts +31 -29
- package/components/date/dateRangeInputConfirm.js +132 -121
- package/components/date/dateRangeInputConfirm.js.map +1 -1
- package/components/date/dateTimeInput.d.ts +72 -69
- package/components/date/dateTimeInput.js +440 -412
- package/components/date/dateTimeInput.js.map +1 -1
- package/components/date/durationInput.d.ts +59 -56
- package/components/date/durationInput.js +269 -280
- package/components/date/durationInput.js.map +1 -1
- package/components/form/NiceFormItem.d.ts +14 -14
- package/components/form/NiceFormItem.js +28 -31
- package/components/form/NiceFormItem.js.map +1 -1
- package/components/grid/cell/beanAccessor.d.ts +9 -0
- package/components/grid/cell/beanAccessor.js +13 -0
- package/components/grid/cell/beanAccessor.js.map +1 -0
- package/components/grid/cell/cellEditorUtils.d.ts +4 -4
- package/components/grid/cell/cellEditorUtils.js +8 -8
- package/components/grid/cell/customEnumCellEditor.d.ts +4 -26
- package/components/grid/cell/customEnumCellEditor.js +82 -91
- package/components/grid/cell/customEnumCellEditor.js.map +1 -1
- package/components/grid/cell/dataGridCellEditorComponent.d.ts +14 -0
- package/components/grid/cell/dataGridCellEditorComponent.js +49 -0
- package/components/grid/cell/dataGridCellEditorComponent.js.map +1 -0
- package/components/grid/cell/dateCellEditor.d.ts +4 -25
- package/components/grid/cell/dateCellEditor.js +53 -72
- package/components/grid/cell/dateCellEditor.js.map +1 -1
- package/components/grid/cell/durationCellEditor.d.ts +4 -24
- package/components/grid/cell/durationCellEditor.js +74 -97
- package/components/grid/cell/durationCellEditor.js.map +1 -1
- package/components/grid/cell/hexaOctetStringCellEditor.d.ts +4 -24
- package/components/grid/cell/hexaOctetStringCellEditor.js +70 -94
- package/components/grid/cell/hexaOctetStringCellEditor.js.map +1 -1
- package/components/grid/cell/hexaValueCellEditor.d.ts +4 -24
- package/components/grid/cell/hexaValueCellEditor.js +65 -89
- package/components/grid/cell/hexaValueCellEditor.js.map +1 -1
- package/components/grid/cell/numberCellEditor.d.ts +4 -27
- package/components/grid/cell/numberCellEditor.js +73 -95
- package/components/grid/cell/numberCellEditor.js.map +1 -1
- package/components/grid/cell/rangeSelector.d.ts +78 -78
- package/components/grid/cell/rangeSelector.js +526 -518
- package/components/grid/cell/rangeSelector.js.map +1 -1
- package/components/grid/cell/simpleStatusTextCellEditor.d.ts +4 -32
- package/components/grid/cell/simpleStatusTextCellEditor.js +106 -116
- package/components/grid/cell/simpleStatusTextCellEditor.js.map +1 -1
- package/components/grid/cell/statusTextCellEditor.d.ts +4 -32
- package/components/grid/cell/statusTextCellEditor.js +136 -159
- package/components/grid/cell/statusTextCellEditor.js.map +1 -1
- package/components/grid/cell/tableDefaultRowStyleRules.d.ts +20 -20
- package/components/grid/cell/tableDefaultRowStyleRules.js +29 -18
- package/components/grid/cell/tableDefaultRowStyleRules.js.map +1 -1
- package/components/grid/cell/textCellEditor.d.ts +4 -21
- package/components/grid/cell/textCellEditor.js +63 -85
- package/components/grid/cell/textCellEditor.js.map +1 -1
- package/components/grid/cell/withAgGridHooks.d.ts +3 -0
- package/components/grid/cell/withAgGridHooks.js +15 -0
- package/components/grid/cell/withAgGridHooks.js.map +1 -0
- package/components/grid/columnUtils.d.ts +5 -5
- package/components/grid/columnUtils.js +26 -26
- package/components/grid/columnUtils.js.map +1 -1
- package/components/grid/config/columnTransfer.d.ts +21 -22
- package/components/grid/config/columnTransfer.js +205 -201
- package/components/grid/config/columnTransfer.js.map +1 -1
- package/components/grid/config/dataGridEditor.d.ts +41 -41
- package/components/grid/config/dataGridEditor.js +181 -160
- package/components/grid/config/dataGridEditor.js.map +1 -1
- package/components/grid/config/rowHeightCalculator.d.ts +8 -0
- package/components/grid/config/rowHeightCalculator.js +20 -0
- package/components/grid/config/rowHeightCalculator.js.map +1 -0
- package/components/grid/config/rowStylePicker.d.ts +27 -25
- package/components/grid/config/rowStylePicker.js +127 -109
- package/components/grid/config/rowStylePicker.js.map +1 -1
- package/components/grid/dataGrid.d.ts +218 -206
- package/components/grid/dataGrid.js +1629 -1538
- package/components/grid/dataGrid.js.map +1 -1
- package/components/grid/detail/detailHeaderPanel.d.ts +13 -13
- package/components/grid/detail/detailHeaderPanel.js +25 -25
- package/components/grid/detail/detailHeaderPanel.js.map +1 -1
- package/components/grid/export/contextMenu.d.ts +18 -24
- package/components/grid/export/contextMenu.js +116 -113
- package/components/grid/export/contextMenu.js.map +1 -1
- package/components/grid/export/progressPopup.d.ts +29 -29
- package/components/grid/export/progressPopup.js +93 -93
- package/components/grid/export/progressPopup.js.map +1 -1
- package/components/grid/export/worker/clipboardExport.d.ts +1 -1
- package/components/grid/export/worker/clipboardExport.js +8 -8
- package/components/grid/export/worker/csvExport.d.ts +1 -1
- package/components/grid/export/worker/csvExport.js +8 -8
- package/components/grid/export/worker/pdfExport.d.ts +1 -1
- package/components/grid/export/worker/pdfExport.js +81 -81
- package/components/grid/export/worker/pdfExport.js.map +1 -1
- package/components/grid/export/worker/txtExport.d.ts +1 -1
- package/components/grid/export/worker/txtExport.js +19 -19
- package/components/grid/extendedDataGrid.d.ts +140 -140
- package/components/grid/extendedDataGrid.js +704 -695
- package/components/grid/extendedDataGrid.js.map +1 -1
- package/components/grid/filter/customColumnFilter.d.ts +5 -21
- package/components/grid/filter/customColumnFilter.js +11 -82
- package/components/grid/filter/customColumnFilter.js.map +1 -1
- package/components/grid/filter/dataGridColumnFilter.d.ts +17 -0
- package/components/grid/filter/dataGridColumnFilter.js +49 -0
- package/components/grid/filter/dataGridColumnFilter.js.map +1 -0
- package/components/grid/filter/dateColumnFilter.d.ts +7 -11
- package/components/grid/filter/dateColumnFilter.js +22 -56
- package/components/grid/filter/dateColumnFilter.js.map +1 -1
- package/components/grid/filter/textColumnFilter.d.ts +8 -20
- package/components/grid/filter/textColumnFilter.js +24 -76
- package/components/grid/filter/textColumnFilter.js.map +1 -1
- package/components/grid/filter/wildcardQuickFilterEngine.d.ts +7 -0
- package/components/grid/filter/wildcardQuickFilterEngine.js +48 -0
- package/components/grid/filter/wildcardQuickFilterEngine.js.map +1 -0
- package/components/grid/header/simpleHeader.d.ts +17 -16
- package/components/grid/header/simpleHeader.js +230 -186
- package/components/grid/header/simpleHeader.js.map +1 -1
- package/components/grid/panel/dataGridPagination.d.ts +16 -16
- package/components/grid/panel/dataGridPagination.js +58 -58
- package/components/grid/panel/dataGridPagination.js.map +1 -1
- package/components/grid/panel/loadingOverlay.d.ts +6 -6
- package/components/grid/panel/loadingOverlay.js +10 -10
- package/components/grid/panel/loadingOverlay.js.map +1 -1
- package/components/grid/panel/noRecordsOverlay.d.ts +6 -6
- package/components/grid/panel/noRecordsOverlay.js +10 -10
- package/components/grid/panel/noRecordsOverlay.js.map +1 -1
- package/components/grid/panel/tablePagination.d.ts +10 -10
- package/components/grid/panel/tablePagination.js +45 -45
- package/components/grid/panel/tablePagination.js.map +1 -1
- package/components/icons/dropdownArrow.d.ts +8 -0
- package/components/icons/dropdownArrow.js +59 -0
- package/components/icons/dropdownArrow.js.map +1 -0
- package/components/icons/undoIcon.d.ts +8 -8
- package/components/icons/undoIcon.js +6 -6
- package/components/input/autoCompleteInput.d.ts +35 -35
- package/components/input/autoCompleteInput.js +122 -121
- package/components/input/autoCompleteInput.js.map +1 -1
- package/components/input/draftUtils.d.ts +4 -4
- package/components/input/draftUtils.js +48 -48
- package/components/input/draftUtils.js.map +1 -1
- package/components/input/draftail.d.ts +1 -1
- package/components/input/draftail.js +1 -1
- package/components/input/hexaFormattedInput.d.ts +16 -16
- package/components/input/hexaFormattedInput.js +54 -54
- package/components/input/hexaFormattedInput.js.map +1 -1
- package/components/input/mask/helpers.d.ts +28 -28
- package/components/input/mask/helpers.js +112 -112
- package/components/input/mask/helpers.js.map +1 -1
- package/components/input/mask/inputMaskCore.d.ts +46 -46
- package/components/input/mask/inputMaskCore.js +278 -278
- package/components/input/mask/inputMaskCore.js.map +1 -1
- package/components/input/mask/pattern.d.ts +20 -20
- package/components/input/mask/pattern.js +78 -78
- package/components/input/mask/pattern.js.map +1 -1
- package/components/input/maskedInput.d.ts +373 -351
- package/components/input/maskedInput.js +224 -224
- package/components/input/maskedInput.js.map +1 -1
- package/components/input/passwordInput.d.ts +9 -9
- package/components/input/passwordInput.js +55 -55
- package/components/input/passwordInput.js.map +1 -1
- package/components/input/simpleAutoComplete.d.ts +12 -12
- package/components/input/simpleAutoComplete.js +41 -43
- package/components/input/simpleAutoComplete.js.map +1 -1
- package/components/input/textarea/extractSpansOfClasses.d.ts +15 -15
- package/components/input/textarea/extractSpansOfClasses.js +96 -96
- package/components/input/textarea/extractSpansOfClasses.js.map +1 -1
- package/components/input/textarea/getRanges.d.ts +1 -1
- package/components/input/textarea/getRanges.js +73 -73
- package/components/input/textarea/getRanges.js.map +1 -1
- package/components/input/textarea/getType.d.ts +1 -1
- package/components/input/textarea/getType.js +26 -26
- package/components/input/textarea/getType.js.map +1 -1
- package/components/input/textarea/highlighedContents.d.ts +6 -6
- package/components/input/textarea/highlighedContents.js +10 -10
- package/components/input/textarea/mentionsWithHighlighting.d.ts +27 -27
- package/components/input/textarea/mentionsWithHighlighting.js +60 -60
- package/components/input/textarea/mentionsWithHighlighting.js.map +1 -1
- package/components/keyboard/keyboardUtils.d.ts +5 -5
- package/components/keyboard/keyboardUtils.js +32 -32
- package/components/modal/draggableModalProvider.d.ts +4 -4
- package/components/modal/draggableModalProvider.js +21 -21
- package/components/modal/draggableModalProvider.js.map +1 -1
- package/components/modal/impl/clamp.d.ts +1 -1
- package/components/modal/impl/clamp.js +1 -1
- package/components/modal/impl/clamp.js.map +1 -1
- package/components/modal/impl/draggableModal.d.ts +12 -12
- package/components/modal/impl/draggableModal.js +17 -17
- package/components/modal/impl/draggableModal.js.map +1 -1
- package/components/modal/impl/draggableModalContext.d.ts +9 -9
- package/components/modal/impl/draggableModalContext.js +2 -2
- package/components/modal/impl/draggableModalContext.js.map +1 -1
- package/components/modal/impl/draggableModalInner.d.ts +15 -13
- package/components/modal/impl/draggableModalInner.js +57 -55
- package/components/modal/impl/draggableModalInner.js.map +1 -1
- package/components/modal/impl/draggableModalReducer.d.ts +66 -62
- package/components/modal/impl/draggableModalReducer.js +77 -78
- package/components/modal/impl/draggableModalReducer.js.map +1 -1
- package/components/modal/impl/getWindowSize.d.ts +4 -4
- package/components/modal/impl/getWindowSize.js +4 -4
- package/components/modal/impl/getWindowSize.js.map +1 -1
- package/components/modal/impl/index.d.ts +3 -3
- package/components/modal/impl/index.js +3 -3
- package/components/modal/impl/index.js.map +1 -1
- package/components/modal/impl/resizeHandle.d.ts +3 -3
- package/components/modal/impl/resizeHandle.js +4 -4
- package/components/modal/impl/resizeHandle.js.map +1 -1
- package/components/modal/impl/useDrag.d.ts +5 -5
- package/components/modal/impl/useDrag.js +42 -42
- package/components/modal/impl/useDrag.js.map +1 -1
- package/components/modal/impl/usePrevious.d.ts +1 -1
- package/components/modal/impl/usePrevious.js +8 -8
- package/components/modal/impl/usePrevious.js.map +1 -1
- package/components/modal/impl/useResize.d.ts +7 -7
- package/components/modal/impl/useResize.js +46 -46
- package/components/modal/impl/useResize.js.map +1 -1
- package/components/modal/modalDialog.d.ts +49 -49
- package/components/modal/modalDialog.js +152 -152
- package/components/modal/modalDialog.js.map +1 -1
- package/components/picker/enumValuePicker.d.ts +16 -16
- package/components/picker/enumValuePicker.js +34 -34
- package/components/picker/enumValuePicker.js.map +1 -1
- package/components/platformSpecific.d.ts +10 -10
- package/components/platformSpecific.js +27 -27
- package/components/scrollTo/onlyText.d.ts +4 -4
- package/components/scrollTo/onlyText.js +30 -30
- package/components/scrollTo/onlyText.js.map +1 -1
- package/components/scrollTo/scrollTo.d.ts +41 -39
- package/components/scrollTo/scrollTo.js +264 -264
- package/components/scrollTo/scrollTo.js.map +1 -1
- package/components/style/withCss.d.ts +9 -0
- package/components/style/withCss.js +6 -0
- package/components/style/withCss.js.map +1 -0
- package/components/style/withInputNumberCss.d.ts +6 -0
- package/components/style/withInputNumberCss.js +13 -0
- package/components/style/withInputNumberCss.js.map +1 -0
- package/components/table/dragSortingTable.d.ts +13 -14
- package/components/table/dragSortingTable.js +96 -82
- package/components/table/dragSortingTable.js.map +1 -1
- package/components/text/impl/innerSize.d.ts +2 -2
- package/components/text/impl/innerSize.js +12 -12
- package/components/text/impl/series.d.ts +1 -1
- package/components/text/impl/series.js +28 -28
- package/components/text/impl/shallowEqual.d.ts +1 -1
- package/components/text/impl/shallowEqual.js +18 -18
- package/components/text/impl/shallowEqual.js.map +1 -1
- package/components/text/impl/uniqueId.d.ts +1 -1
- package/components/text/impl/uniqueId.js +4 -4
- package/components/text/impl/whilst.d.ts +1 -1
- package/components/text/impl/whilst.js +19 -19
- package/components/text/impl/whilst.js.map +1 -1
- package/components/text/textFit.d.ts +38 -38
- package/components/text/textFit.js +165 -168
- package/components/text/textFit.js.map +1 -1
- package/i18n/components.cs.json +101 -100
- package/i18n/components.sk.json +101 -100
- package/i18n/components.uk.json +101 -100
- package/i18n/componentsLocaleHolder.d.ts +3 -3
- package/i18n/componentsLocaleHolder.js +28 -28
- package/i18n/componentsLocaleHolder.js.map +1 -1
- package/package.json +71 -70
- package/style/index.less +274 -298
- package/style/modal/DraggableModal.css +43 -40
- package/style/modal/ResizeHandle.css +27 -19
- package/tsconfig.build.json +24 -24
- package/tsconfig.json +11 -11
- package/components/grid/cell/wildcardQuickFilter.d.ts +0 -11
- package/components/grid/cell/wildcardQuickFilter.js +0 -61
- package/components/grid/cell/wildcardQuickFilter.js.map +0 -1
- package/components/table/dataTable.d.ts +0 -17
- package/components/table/dataTable.js +0 -79
- package/components/table/dataTable.js.map +0 -1
- package/style/antd/antd-tree-showline.css +0 -25
- package/style/antd/full-height-tabs.scss +0 -63
- package/style/draftail/draftail-editor.css +0 -179
- 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
|
|
4
|
-
import i18n from "d2core/i18n/i18n";
|
|
5
|
-
import { UndoMenuIcon } from "d2coreui/components/icons/undoIcon";
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
this.
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
this.
|
|
18
|
-
this.
|
|
19
|
-
this.
|
|
20
|
-
this.
|
|
21
|
-
this.
|
|
22
|
-
this.
|
|
23
|
-
|
|
24
|
-
props.column.addEventListener('
|
|
25
|
-
props.column.addEventListener('
|
|
26
|
-
props.
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
this.
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
this.props.column.removeEventListener(this.
|
|
35
|
-
this.props.column.removeEventListener(this.
|
|
36
|
-
this.
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
const
|
|
45
|
-
const
|
|
46
|
-
const
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
const
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
const
|
|
80
|
-
const
|
|
81
|
-
const moreThanOneColSorting = allColumnsWithSorting.length > 1;
|
|
82
|
-
const showIndex = col.isSorting() && moreThanOneColSorting;
|
|
83
|
-
if (showIndex) {
|
|
84
|
-
showOrderIndex =
|
|
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.
|
|
98
|
-
}
|
|
99
|
-
else {
|
|
100
|
-
this.props.
|
|
101
|
-
}
|
|
102
|
-
}
|
|
103
|
-
else if (key === "pinRight") {
|
|
104
|
-
if (pinned === "right") {
|
|
105
|
-
this.props.
|
|
106
|
-
}
|
|
107
|
-
else {
|
|
108
|
-
this.props.
|
|
109
|
-
}
|
|
110
|
-
}
|
|
111
|
-
else if (key === "autosizeColumn") {
|
|
112
|
-
this.props.
|
|
113
|
-
}
|
|
114
|
-
else if (key === "hideColumn") {
|
|
115
|
-
this.props.
|
|
116
|
-
}
|
|
117
|
-
else if (key === "autosizeAllColumns") {
|
|
118
|
-
this.props.
|
|
119
|
-
}
|
|
120
|
-
else if (key === "resetColumns") {
|
|
121
|
-
this.props.
|
|
122
|
-
}
|
|
123
|
-
else if (key === "columnsConfig") {
|
|
124
|
-
this.props.onColumnsConfigVisible(true);
|
|
125
|
-
}
|
|
126
|
-
this.setState({ menuVisible: false });
|
|
127
|
-
}
|
|
128
|
-
|
|
129
|
-
const pinned = this.props.column.pinned;
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
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 {};
|