@carbon/ibm-products 1.12.0 → 1.15.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (246) hide show
  1. package/css/components/Datagrid/styles/addons/CustomizeColumnsModal.css +47 -0
  2. package/css/components/Datagrid/styles/addons/CustomizeColumnsModal.css.map +1 -0
  3. package/css/components/Datagrid/styles/addons/RowSizeDropdown.css +20 -0
  4. package/css/components/Datagrid/styles/addons/RowSizeDropdown.css.map +1 -0
  5. package/css/components/Datagrid/styles/datagrid.css +264 -0
  6. package/css/components/Datagrid/styles/datagrid.css.map +1 -0
  7. package/css/components/Datagrid/styles/index.css +509 -0
  8. package/css/components/Datagrid/styles/index.css.map +1 -0
  9. package/css/components/Datagrid/styles/useActionsColumn.css +23 -0
  10. package/css/components/Datagrid/styles/useActionsColumn.css.map +1 -0
  11. package/css/components/Datagrid/styles/useColumnRightAlign.css +28 -0
  12. package/css/components/Datagrid/styles/useColumnRightAlign.css.map +1 -0
  13. package/css/components/Datagrid/styles/useNestedRows.css +15 -0
  14. package/css/components/Datagrid/styles/useNestedRows.css.map +1 -0
  15. package/css/components/Datagrid/styles/useNestedTable.css +25 -0
  16. package/css/components/Datagrid/styles/useNestedTable.css.map +1 -0
  17. package/css/components/Datagrid/styles/useSelectAllToggle.css +28 -0
  18. package/css/components/Datagrid/styles/useSelectAllToggle.css.map +1 -0
  19. package/css/components/Datagrid/styles/useSortableColumns.css +50 -0
  20. package/css/components/Datagrid/styles/useSortableColumns.css.map +1 -0
  21. package/css/components/Datagrid/styles/useStickyColumn.css +35 -0
  22. package/css/components/Datagrid/styles/useStickyColumn.css.map +1 -0
  23. package/css/index-full-carbon.css +653 -21
  24. package/css/index-full-carbon.css.map +1 -1
  25. package/css/index-full-carbon.min.css +6 -6
  26. package/css/index-full-carbon.min.css.map +1 -1
  27. package/css/index-without-carbon-released-only.css +21 -10
  28. package/css/index-without-carbon-released-only.css.map +1 -1
  29. package/css/index-without-carbon-released-only.min.css +2 -2
  30. package/css/index-without-carbon-released-only.min.css.map +1 -1
  31. package/css/index-without-carbon.css +653 -21
  32. package/css/index-without-carbon.css.map +1 -1
  33. package/css/index-without-carbon.min.css +5 -5
  34. package/css/index-without-carbon.min.css.map +1 -1
  35. package/css/index.css +653 -21
  36. package/css/index.css.map +1 -1
  37. package/css/index.min.css +6 -6
  38. package/css/index.min.css.map +1 -1
  39. package/es/components/ActionBar/ActionBar.js +3 -1
  40. package/es/components/ActionBar/ActionBarOverflowItems.js +5 -3
  41. package/es/components/AddSelect/AddSelect.js +98 -40
  42. package/es/components/AddSelect/AddSelectFilter.js +129 -0
  43. package/es/components/AddSelect/AddSelectList.js +27 -1
  44. package/es/components/AddSelect/AddSelectSidebar.js +15 -5
  45. package/es/components/AddSelect/add-select-utils.js +30 -0
  46. package/es/components/BreadcrumbWithOverflow/BreadcrumbWithOverflow.js +2 -0
  47. package/es/components/DataSpreadsheet/DataSpreadsheet.js +269 -142
  48. package/es/components/DataSpreadsheet/DataSpreadsheetBody.js +122 -39
  49. package/es/components/DataSpreadsheet/DataSpreadsheetHeader.js +46 -17
  50. package/es/components/DataSpreadsheet/hooks/index.js +11 -0
  51. package/es/components/DataSpreadsheet/hooks/useMultipleKeyTracking.js +139 -0
  52. package/es/components/DataSpreadsheet/hooks/useResetSpreadsheetFocus.js +2 -4
  53. package/es/components/DataSpreadsheet/hooks/useSpreadsheetEdit.js +68 -0
  54. package/es/components/DataSpreadsheet/hooks/useSpreadsheetOutsideClick.js +6 -6
  55. package/es/components/DataSpreadsheet/utils/createCellSelectionArea.js +20 -8
  56. package/es/components/DataSpreadsheet/utils/getSelectionAreaPoints.js +18 -0
  57. package/es/components/DataSpreadsheet/utils/handleActiveCellInSelectionEnter.js +121 -0
  58. package/es/components/DataSpreadsheet/utils/handleActiveCellInSelectionTab.js +108 -0
  59. package/es/components/DataSpreadsheet/utils/handleEditSubmit.js +87 -0
  60. package/es/components/DataSpreadsheet/utils/handleHeaderCellSelection.js +42 -8
  61. package/es/components/DataSpreadsheet/utils/handleMultipleKeys.js +225 -13
  62. package/es/components/DataSpreadsheet/utils/selectAllCells.js +53 -0
  63. package/es/components/Datagrid/Datagrid/Datagrid.js +70 -0
  64. package/es/components/Datagrid/Datagrid/DatagridBody.js +36 -0
  65. package/es/components/Datagrid/Datagrid/DatagridEmptyBody.js +19 -0
  66. package/es/components/Datagrid/Datagrid/DatagridExpandedRow.js +26 -0
  67. package/es/components/Datagrid/Datagrid/DatagridHead.js +31 -0
  68. package/es/components/Datagrid/Datagrid/DatagridHeaderRow.js +57 -0
  69. package/es/components/Datagrid/Datagrid/DatagridRefBody.js +37 -0
  70. package/es/components/Datagrid/Datagrid/DatagridRow.js +50 -0
  71. package/es/components/Datagrid/Datagrid/DatagridSelectAll.js +50 -0
  72. package/es/components/Datagrid/Datagrid/DatagridSelectAllWithToggle.js +122 -0
  73. package/es/components/Datagrid/Datagrid/DatagridSimpleBody.js +36 -0
  74. package/es/components/Datagrid/Datagrid/DatagridToolbar.js +22 -0
  75. package/es/components/Datagrid/Datagrid/DatagridVirtualBody.js +87 -0
  76. package/es/components/Datagrid/Datagrid/DraggableElement.js +188 -0
  77. package/es/components/Datagrid/Datagrid/addons/CustomizeColumns/Actions.js +78 -0
  78. package/es/components/Datagrid/Datagrid/addons/CustomizeColumns/ButtonWrapper.js +51 -0
  79. package/es/components/Datagrid/Datagrid/addons/CustomizeColumns/Columns.js +140 -0
  80. package/es/components/Datagrid/Datagrid/addons/CustomizeColumns/CustomizeColumnsModal.js +157 -0
  81. package/es/components/Datagrid/Datagrid/addons/CustomizeColumns/ModalWrapper.js +62 -0
  82. package/es/components/Datagrid/Datagrid/addons/CustomizeColumns/common.js +13 -0
  83. package/es/components/Datagrid/Datagrid/addons/CustomizeColumns/index.js +9 -0
  84. package/es/components/Datagrid/Datagrid/addons/RowSize/RowSizeDropdown.js +62 -0
  85. package/es/components/Datagrid/Datagrid/addons/RowSize/RowSizeRadioGroup.js +139 -0
  86. package/es/components/Datagrid/Datagrid/addons/RowSize/index.js +8 -0
  87. package/es/components/Datagrid/Datagrid/index.js +8 -0
  88. package/es/components/Datagrid/Datagrid.stories/CustomizeColumnStory.js +6 -0
  89. package/es/components/Datagrid/Datagrid.stories/LeftPanelStory.js +6 -0
  90. package/es/components/Datagrid/Datagrid.stories/RowSizeDropdownStory.js +6 -0
  91. package/es/components/Datagrid/Datagrid.stories/SelectAllWithToggleStory.js +6 -0
  92. package/es/components/Datagrid/Datagrid.stories/StickyActionsColumnStory.js +92 -0
  93. package/es/components/Datagrid/Datagrid.stories/common.js +199 -0
  94. package/es/components/Datagrid/Datagrid.stories/index.js +5 -0
  95. package/es/components/Datagrid/common-column-ids.js +8 -0
  96. package/es/components/Datagrid/index.js +22 -0
  97. package/es/components/Datagrid/useActionsColumn.js +86 -0
  98. package/es/components/Datagrid/useColumnRightAlign.js +52 -0
  99. package/es/components/Datagrid/useCustomizeColumns.js +45 -0
  100. package/es/components/Datagrid/useDatagrid.js +44 -0
  101. package/es/components/Datagrid/useDefaultStringRenderer.js +48 -0
  102. package/es/components/Datagrid/useDisableSelectRows.js +84 -0
  103. package/es/components/Datagrid/useExpandedRow.js +52 -0
  104. package/es/components/Datagrid/useFlexResize.js +51 -0
  105. package/es/components/Datagrid/useFloatingScroll.js +88 -0
  106. package/es/components/Datagrid/useInfiniteScroll.js +54 -0
  107. package/es/components/Datagrid/useNestedRows.js +53 -0
  108. package/es/components/Datagrid/useOnRowClick.js +37 -0
  109. package/es/components/Datagrid/useParentDimensions.js +65 -0
  110. package/es/components/Datagrid/useResizeTable.js +40 -0
  111. package/es/components/Datagrid/useRowExpander.js +34 -0
  112. package/es/components/Datagrid/useRowIsMouseOver.js +61 -0
  113. package/es/components/Datagrid/useRowRenderer.js +30 -0
  114. package/es/components/Datagrid/useRowSize.js +56 -0
  115. package/es/components/Datagrid/useSelectAllToggle.js +74 -0
  116. package/es/components/Datagrid/useSelectRows.js +107 -0
  117. package/es/components/Datagrid/useSkeletonRows.js +32 -0
  118. package/es/components/Datagrid/useSortableColumns.js +110 -0
  119. package/es/components/Datagrid/useStickyColumn.js +183 -0
  120. package/es/components/HTTPErrors/assets/HTTPErrorSvg403.js +2 -3
  121. package/es/components/HTTPErrors/assets/HTTPErrorSvg404.js +2 -3
  122. package/es/components/HTTPErrors/assets/HTTPErrorSvgOther.js +2 -3
  123. package/es/components/MultiAddSelect/MultiAddSelect.js +150 -3
  124. package/es/components/PageHeader/PageHeader.js +3 -1
  125. package/es/components/SingleAddSelect/SingleAddSelect.js +90 -4
  126. package/es/components/TagSet/TagSet.js +22 -6
  127. package/es/components/Tearsheet/TearsheetShell.js +34 -10
  128. package/es/components/UserProfileImage/UserProfileImage.js +37 -9
  129. package/es/components/index.js +2 -1
  130. package/es/global/js/package-settings.js +4 -2
  131. package/lib/components/ActionBar/ActionBar.js +3 -1
  132. package/lib/components/ActionBar/ActionBarOverflowItems.js +5 -3
  133. package/lib/components/AddSelect/AddSelect.js +97 -38
  134. package/lib/components/AddSelect/AddSelectFilter.js +147 -0
  135. package/lib/components/AddSelect/AddSelectList.js +28 -1
  136. package/lib/components/AddSelect/AddSelectSidebar.js +15 -11
  137. package/lib/components/AddSelect/add-select-utils.js +35 -2
  138. package/lib/components/BreadcrumbWithOverflow/BreadcrumbWithOverflow.js +2 -0
  139. package/lib/components/DataSpreadsheet/DataSpreadsheet.js +279 -145
  140. package/lib/components/DataSpreadsheet/DataSpreadsheetBody.js +121 -45
  141. package/lib/components/DataSpreadsheet/DataSpreadsheetHeader.js +47 -17
  142. package/lib/components/DataSpreadsheet/hooks/index.js +45 -0
  143. package/lib/components/DataSpreadsheet/hooks/useMultipleKeyTracking.js +151 -0
  144. package/lib/components/DataSpreadsheet/hooks/useResetSpreadsheetFocus.js +2 -4
  145. package/lib/components/DataSpreadsheet/hooks/useSpreadsheetEdit.js +79 -0
  146. package/lib/components/DataSpreadsheet/hooks/useSpreadsheetOutsideClick.js +6 -5
  147. package/lib/components/DataSpreadsheet/utils/createCellSelectionArea.js +21 -8
  148. package/lib/components/DataSpreadsheet/utils/getSelectionAreaPoints.js +27 -0
  149. package/lib/components/DataSpreadsheet/utils/handleActiveCellInSelectionEnter.js +127 -0
  150. package/lib/components/DataSpreadsheet/utils/handleActiveCellInSelectionTab.js +118 -0
  151. package/lib/components/DataSpreadsheet/utils/handleEditSubmit.js +94 -0
  152. package/lib/components/DataSpreadsheet/utils/handleHeaderCellSelection.js +44 -8
  153. package/lib/components/DataSpreadsheet/utils/handleMultipleKeys.js +235 -20
  154. package/lib/components/DataSpreadsheet/utils/selectAllCells.js +60 -0
  155. package/lib/components/Datagrid/Datagrid/Datagrid.js +86 -0
  156. package/lib/components/Datagrid/Datagrid/DatagridBody.js +50 -0
  157. package/lib/components/Datagrid/Datagrid/DatagridEmptyBody.js +31 -0
  158. package/lib/components/Datagrid/Datagrid/DatagridExpandedRow.js +38 -0
  159. package/lib/components/Datagrid/Datagrid/DatagridHead.js +43 -0
  160. package/lib/components/Datagrid/Datagrid/DatagridHeaderRow.js +73 -0
  161. package/lib/components/Datagrid/Datagrid/DatagridRefBody.js +44 -0
  162. package/lib/components/Datagrid/Datagrid/DatagridRow.js +56 -0
  163. package/lib/components/Datagrid/Datagrid/DatagridSelectAll.js +55 -0
  164. package/lib/components/Datagrid/Datagrid/DatagridSelectAllWithToggle.js +139 -0
  165. package/lib/components/Datagrid/Datagrid/DatagridSimpleBody.js +44 -0
  166. package/lib/components/Datagrid/Datagrid/DatagridToolbar.js +35 -0
  167. package/lib/components/Datagrid/Datagrid/DatagridVirtualBody.js +101 -0
  168. package/lib/components/Datagrid/Datagrid/DraggableElement.js +210 -0
  169. package/lib/components/Datagrid/Datagrid/addons/CustomizeColumns/Actions.js +92 -0
  170. package/lib/components/Datagrid/Datagrid/addons/CustomizeColumns/ButtonWrapper.js +65 -0
  171. package/lib/components/Datagrid/Datagrid/addons/CustomizeColumns/Columns.js +166 -0
  172. package/lib/components/Datagrid/Datagrid/addons/CustomizeColumns/CustomizeColumnsModal.js +173 -0
  173. package/lib/components/Datagrid/Datagrid/addons/CustomizeColumns/ModalWrapper.js +73 -0
  174. package/lib/components/Datagrid/Datagrid/addons/CustomizeColumns/common.js +25 -0
  175. package/lib/components/Datagrid/Datagrid/addons/CustomizeColumns/index.js +23 -0
  176. package/lib/components/Datagrid/Datagrid/addons/RowSize/RowSizeDropdown.js +80 -0
  177. package/lib/components/Datagrid/Datagrid/addons/RowSize/RowSizeRadioGroup.js +160 -0
  178. package/lib/components/Datagrid/Datagrid/addons/RowSize/index.js +15 -0
  179. package/lib/components/Datagrid/Datagrid/index.js +15 -0
  180. package/lib/components/Datagrid/Datagrid.stories/CustomizeColumnStory.js +13 -0
  181. package/lib/components/Datagrid/Datagrid.stories/LeftPanelStory.js +13 -0
  182. package/lib/components/Datagrid/Datagrid.stories/RowSizeDropdownStory.js +13 -0
  183. package/lib/components/Datagrid/Datagrid.stories/SelectAllWithToggleStory.js +13 -0
  184. package/lib/components/Datagrid/Datagrid.stories/StickyActionsColumnStory.js +112 -0
  185. package/lib/components/Datagrid/Datagrid.stories/common.js +215 -0
  186. package/lib/components/Datagrid/Datagrid.stories/index.js +47 -0
  187. package/lib/components/Datagrid/common-column-ids.js +16 -0
  188. package/lib/components/Datagrid/index.js +127 -0
  189. package/lib/components/Datagrid/useActionsColumn.js +94 -0
  190. package/lib/components/Datagrid/useColumnRightAlign.js +59 -0
  191. package/lib/components/Datagrid/useCustomizeColumns.js +55 -0
  192. package/lib/components/Datagrid/useDatagrid.js +58 -0
  193. package/lib/components/Datagrid/useDefaultStringRenderer.js +54 -0
  194. package/lib/components/Datagrid/useDisableSelectRows.js +92 -0
  195. package/lib/components/Datagrid/useExpandedRow.js +58 -0
  196. package/lib/components/Datagrid/useFlexResize.js +61 -0
  197. package/lib/components/Datagrid/useFloatingScroll.js +101 -0
  198. package/lib/components/Datagrid/useInfiniteScroll.js +67 -0
  199. package/lib/components/Datagrid/useNestedRows.js +65 -0
  200. package/lib/components/Datagrid/useOnRowClick.js +45 -0
  201. package/lib/components/Datagrid/useParentDimensions.js +75 -0
  202. package/lib/components/Datagrid/useResizeTable.js +48 -0
  203. package/lib/components/Datagrid/useRowExpander.js +45 -0
  204. package/lib/components/Datagrid/useRowIsMouseOver.js +66 -0
  205. package/lib/components/Datagrid/useRowRenderer.js +40 -0
  206. package/lib/components/Datagrid/useRowSize.js +67 -0
  207. package/lib/components/Datagrid/useSelectAllToggle.js +88 -0
  208. package/lib/components/Datagrid/useSelectRows.js +119 -0
  209. package/lib/components/Datagrid/useSkeletonRows.js +42 -0
  210. package/lib/components/Datagrid/useSortableColumns.js +117 -0
  211. package/lib/components/Datagrid/useStickyColumn.js +190 -0
  212. package/lib/components/HTTPErrors/assets/HTTPErrorSvg403.js +2 -3
  213. package/lib/components/HTTPErrors/assets/HTTPErrorSvg404.js +2 -3
  214. package/lib/components/HTTPErrors/assets/HTTPErrorSvgOther.js +2 -3
  215. package/lib/components/MultiAddSelect/MultiAddSelect.js +150 -2
  216. package/lib/components/PageHeader/PageHeader.js +3 -1
  217. package/lib/components/SingleAddSelect/SingleAddSelect.js +91 -3
  218. package/lib/components/TagSet/TagSet.js +22 -6
  219. package/lib/components/Tearsheet/TearsheetShell.js +36 -10
  220. package/lib/components/UserProfileImage/UserProfileImage.js +37 -9
  221. package/lib/components/index.js +9 -1
  222. package/lib/global/js/package-settings.js +4 -2
  223. package/package.json +20 -16
  224. package/scss/components/AboutModal/_about-modal.scss +4 -0
  225. package/scss/components/AddSelect/_add-select.scss +51 -2
  226. package/scss/components/DataSpreadsheet/_data-spreadsheet.scss +72 -9
  227. package/scss/components/Datagrid/_datagrid.scss +66 -0
  228. package/scss/components/Datagrid/_index.scss +8 -0
  229. package/scss/components/Datagrid/_storybook-styles.scss +26 -0
  230. package/scss/components/Datagrid/styles/_variables.scss +9 -0
  231. package/scss/components/Datagrid/styles/addons/CustomizeColumnsModal.scss +48 -0
  232. package/scss/components/Datagrid/styles/addons/RowSizeDropdown.scss +23 -0
  233. package/scss/components/Datagrid/styles/datagrid.scss +318 -0
  234. package/scss/components/Datagrid/styles/index.scss +17 -0
  235. package/scss/components/Datagrid/styles/useActionsColumn.scss +24 -0
  236. package/scss/components/Datagrid/styles/useColumnRightAlign.scss +29 -0
  237. package/scss/components/Datagrid/styles/useNestedRows.scss +17 -0
  238. package/scss/components/Datagrid/styles/useNestedTable.scss +28 -0
  239. package/scss/components/Datagrid/styles/useSelectAllToggle.scss +28 -0
  240. package/scss/components/Datagrid/styles/useSortableColumns.scss +55 -0
  241. package/scss/components/Datagrid/styles/useStickyColumn.scss +38 -0
  242. package/scss/components/ExportModal/_export-modal.scss +0 -4
  243. package/scss/components/HTTPErrors/_http-errors.scss +16 -16
  244. package/scss/components/PageHeader/_page-header.scss +4 -0
  245. package/scss/components/Tearsheet/_tearsheet.scss +4 -0
  246. package/scss/components/_index.scss +1 -0
@@ -5,7 +5,8 @@
5
5
  * LICENSE file in the root directory of this source tree.
6
6
  */
7
7
  import { useEffect } from 'react';
8
- import { pkg } from '../../../settings'; // Click outside useEffect for spreadsheet
8
+ import { pkg } from '../../../settings';
9
+ import { removeCellSelections } from '../utils/removeCellSelections'; // Click outside useEffect for spreadsheet
9
10
 
10
11
  export var useSpreadsheetOutsideClick = function useSpreadsheetOutsideClick(_ref) {
11
12
  var spreadsheetRef = _ref.spreadsheetRef,
@@ -14,9 +15,7 @@ export var useSpreadsheetOutsideClick = function useSpreadsheetOutsideClick(_ref
14
15
  setActiveCellCoordinates = _ref.setActiveCellCoordinates,
15
16
  setSelectionAreas = _ref.setSelectionAreas,
16
17
  removeActiveCell = _ref.removeActiveCell,
17
- removeCellSelections = _ref.removeCellSelections,
18
18
  setContainerHasFocus = _ref.setContainerHasFocus,
19
- activeKeys = _ref.activeKeys,
20
19
  removeCellEditor = _ref.removeCellEditor;
21
20
  useEffect(function () {
22
21
  var handleOutsideClick = function handleOutsideClick(event) {
@@ -27,15 +26,16 @@ export var useSpreadsheetOutsideClick = function useSpreadsheetOutsideClick(_ref
27
26
  setActiveCellCoordinates(null);
28
27
  setSelectionAreas([]);
29
28
  removeActiveCell();
30
- removeCellSelections();
29
+ removeCellSelections({
30
+ spreadsheetRef: spreadsheetRef
31
+ });
31
32
  setContainerHasFocus(false);
32
33
  removeCellEditor();
33
- activeKeys.current = [];
34
34
  };
35
35
 
36
36
  document.addEventListener('click', handleOutsideClick);
37
37
  return function () {
38
38
  document.removeEventListener('click', handleOutsideClick);
39
39
  };
40
- }, [spreadsheetRef, removeActiveCell, removeCellSelections, activeKeys, blockClass, setActiveCellCoordinates, setContainerHasFocus, setSelectionAreas, removeCellEditor]);
40
+ }, [spreadsheetRef, removeActiveCell, blockClass, setActiveCellCoordinates, setContainerHasFocus, setSelectionAreas, removeCellEditor]);
41
41
  };
@@ -6,22 +6,34 @@
6
6
  */
7
7
  import { px } from '@carbon/layout';
8
8
  import { deepCloneObject } from '../../../global/js/utils/deepCloneObject';
9
+ import { getSelectionAreaPoints } from './getSelectionAreaPoints';
9
10
  export var createCellSelectionArea = function createCellSelectionArea(_ref) {
10
- var area = _ref.area,
11
+ var ref = _ref.ref,
12
+ area = _ref.area,
11
13
  blockClass = _ref.blockClass,
12
14
  defaultColumn = _ref.defaultColumn,
13
15
  selectionAreas = _ref.selectionAreas,
14
- setSelectionAreas = _ref.setSelectionAreas;
15
- var greatestRow = Math.max(area.point1.row, area.point2.row);
16
- var greatestColumn = Math.max(area.point1.column, area.point2.column);
17
- var lowestRowIndex = Math.min(area.point1.row, area.point2.row);
18
- var lowestColumnIndex = Math.min(area.point1.column, area.point2.column);
16
+ setSelectionAreas = _ref.setSelectionAreas,
17
+ setActiveCellInsideSelectionArea = _ref.setActiveCellInsideSelectionArea;
18
+
19
+ var _getSelectionAreaPoin = getSelectionAreaPoints(area),
20
+ lowestColumnIndex = _getSelectionAreaPoin.lowestColumnIndex,
21
+ lowestRowIndex = _getSelectionAreaPoin.lowestRowIndex,
22
+ greatestColumnIndex = _getSelectionAreaPoin.greatestColumnIndex,
23
+ greatestRowIndex = _getSelectionAreaPoin.greatestRowIndex;
24
+
25
+ if (greatestRowIndex - lowestRowIndex > 0 || greatestColumnIndex - lowestColumnIndex > 0) {
26
+ setActiveCellInsideSelectionArea(true);
27
+ var activeCellElement = ref.current.querySelector(".".concat(blockClass, "__active-cell--highlight"));
28
+ activeCellElement.setAttribute('data-selection-id', area.matcher);
29
+ }
30
+
19
31
  var point1Element = document.querySelector("[data-row-index=\"".concat(area.point1.row, "\"][data-column-index=\"").concat(area.point1.column, "\"]")) || document.querySelector(".".concat(blockClass, "__body--td")); // if we can't find the point1 element (this can happen in the case where a virtualized row is not present anymore in the DOM), we get the default height/width of the first body cell we find
20
32
 
21
33
  var selectionAreaCellWidth = point1Element.offsetWidth;
22
34
  var selectionAreaCellHeight = point1Element.offsetHeight;
23
- var selectionAreaTotalWidth = selectionAreaCellWidth * (greatestColumn - lowestColumnIndex + 1);
24
- var selectionAreaTotalHeight = selectionAreaCellHeight * (greatestRow - lowestRowIndex + 1);
35
+ var selectionAreaTotalWidth = selectionAreaCellWidth * (greatestColumnIndex - lowestColumnIndex + 1);
36
+ var selectionAreaTotalHeight = selectionAreaCellHeight * (greatestRowIndex - lowestRowIndex + 1);
25
37
  var bodyContainer = document.querySelector(".".concat(blockClass, "__list--container")).firstElementChild;
26
38
  var placementElement = bodyContainer.querySelector("[data-row-index=\"".concat(lowestRowIndex, "\"][data-column-index=\"").concat(lowestColumnIndex, "\"]"));
27
39
  var relativePosition = {
@@ -0,0 +1,18 @@
1
+ /**
2
+ * Copyright IBM Corp. 2022, 2022
3
+ *
4
+ * This source code is licensed under the Apache-2.0 license found in the
5
+ * LICENSE file in the root directory of this source tree.
6
+ */
7
+ export var getSelectionAreaPoints = function getSelectionAreaPoints(area) {
8
+ var greatestRowIndex = Math.max(area.point1.row, area.point2.row);
9
+ var greatestColumnIndex = Math.max(area.point1.column, area.point2.column);
10
+ var lowestRowIndex = Math.min(area.point1.row, area.point2.row);
11
+ var lowestColumnIndex = Math.min(area.point1.column, area.point2.column);
12
+ return {
13
+ greatestRowIndex: greatestRowIndex,
14
+ greatestColumnIndex: greatestColumnIndex,
15
+ lowestColumnIndex: lowestColumnIndex,
16
+ lowestRowIndex: lowestRowIndex
17
+ };
18
+ };
@@ -0,0 +1,121 @@
1
+ import _defineProperty from "@babel/runtime/helpers/defineProperty";
2
+
3
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
4
+
5
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
6
+
7
+ /**
8
+ * Copyright IBM Corp. 2022, 2022
9
+ *
10
+ * This source code is licensed under the Apache-2.0 license found in the
11
+ * LICENSE file in the root directory of this source tree.
12
+ */
13
+ import { getSelectionAreaPoints } from './getSelectionAreaPoints';
14
+ export var handleActiveCellInSelectionEnter = function handleActiveCellInSelectionEnter(_ref) {
15
+ var activeCellInsideSelectionArea = _ref.activeCellInsideSelectionArea,
16
+ activeCellCoordinates = _ref.activeCellCoordinates,
17
+ activeCellRef = _ref.activeCellRef,
18
+ selectionAreas = _ref.selectionAreas,
19
+ updateActiveCellCoordinates = _ref.updateActiveCellCoordinates;
20
+
21
+ if (!activeCellInsideSelectionArea) {
22
+ return;
23
+ }
24
+
25
+ var activeCellSelectionId = activeCellRef.current.getAttribute('data-selection-id');
26
+ var activeCellIndexInSelectionAreas = selectionAreas.findIndex(function (item) {
27
+ return item.matcher === activeCellSelectionId;
28
+ });
29
+ var selectionAreaToNavigate = selectionAreas[activeCellIndexInSelectionAreas];
30
+
31
+ var _getSelectionAreaPoin = getSelectionAreaPoints(selectionAreaToNavigate),
32
+ lowestColumnIndex = _getSelectionAreaPoin.lowestColumnIndex,
33
+ lowestRowIndex = _getSelectionAreaPoin.lowestRowIndex,
34
+ greatestColumnIndex = _getSelectionAreaPoin.greatestColumnIndex,
35
+ greatestRowIndex = _getSelectionAreaPoin.greatestRowIndex; // Move active cell down one row if possible
36
+
37
+
38
+ var coordinatesClone = _objectSpread({}, activeCellCoordinates);
39
+
40
+ if ((activeCellCoordinates === null || activeCellCoordinates === void 0 ? void 0 : activeCellCoordinates.row) < greatestRowIndex) {
41
+ updateActiveCellCoordinates({
42
+ coords: coordinatesClone,
43
+ updatedValue: {
44
+ row: (coordinatesClone === null || coordinatesClone === void 0 ? void 0 : coordinatesClone.row) + 1
45
+ },
46
+ optOutOfSelectionAreaUpdate: true
47
+ });
48
+ } // Move active cell to next column of selection area if it exists
49
+ // If not, find the next selection area and update active cell to
50
+ // be the first cell in that selection
51
+
52
+
53
+ if ((activeCellCoordinates === null || activeCellCoordinates === void 0 ? void 0 : activeCellCoordinates.row) === greatestRowIndex) {
54
+ if ((activeCellCoordinates === null || activeCellCoordinates === void 0 ? void 0 : activeCellCoordinates.column) < greatestColumnIndex) {
55
+ updateActiveCellCoordinates({
56
+ coords: coordinatesClone,
57
+ updatedValue: {
58
+ column: (coordinatesClone === null || coordinatesClone === void 0 ? void 0 : coordinatesClone.column) + 1,
59
+ row: lowestRowIndex
60
+ },
61
+ optOutOfSelectionAreaUpdate: true
62
+ });
63
+ } // Move to next selection area if there is one, or back to
64
+ // the beginning of the current selection
65
+
66
+
67
+ if ((activeCellCoordinates === null || activeCellCoordinates === void 0 ? void 0 : activeCellCoordinates.column) === greatestColumnIndex) {
68
+ if (selectionAreas.length > 1) {
69
+ if (selectionAreas[activeCellIndexInSelectionAreas + 1]) {
70
+ // Update activeCellRef data-selection-id attribute to the matcher of the next selection area
71
+ activeCellRef.current.setAttribute('data-selection-id', selectionAreas[activeCellIndexInSelectionAreas + 1].matcher);
72
+ var nextSelectionArea = selectionAreas[activeCellIndexInSelectionAreas + 1];
73
+
74
+ var _getSelectionAreaPoin2 = getSelectionAreaPoints(nextSelectionArea),
75
+ _lowestColumnIndex = _getSelectionAreaPoin2.lowestColumnIndex,
76
+ _lowestRowIndex = _getSelectionAreaPoin2.lowestRowIndex;
77
+
78
+ updateActiveCellCoordinates({
79
+ coords: coordinatesClone,
80
+ updatedValue: {
81
+ column: _lowestColumnIndex,
82
+ row: _lowestRowIndex
83
+ },
84
+ optOutOfSelectionAreaUpdate: true
85
+ });
86
+ return;
87
+ } else {
88
+ // There are multiple selection areas and the active cell is in the last one
89
+ // So we need to move the active cell to the first cell in the first selection area
90
+ activeCellRef.current.setAttribute('data-selection-id', selectionAreas[0].matcher);
91
+ var firstSelectionArea = selectionAreas[0];
92
+
93
+ var _getSelectionAreaPoin3 = getSelectionAreaPoints(firstSelectionArea),
94
+ _lowestColumnIndex2 = _getSelectionAreaPoin3.lowestColumnIndex,
95
+ _lowestRowIndex2 = _getSelectionAreaPoin3.lowestRowIndex;
96
+
97
+ updateActiveCellCoordinates({
98
+ coords: coordinatesClone,
99
+ updatedValue: {
100
+ column: _lowestColumnIndex2,
101
+ row: _lowestRowIndex2
102
+ },
103
+ optOutOfSelectionAreaUpdate: true
104
+ });
105
+ }
106
+ } // Only one selection area, go back to first cell in the selection
107
+
108
+
109
+ if (selectionAreas.length === 1) {
110
+ return updateActiveCellCoordinates({
111
+ coords: coordinatesClone,
112
+ updatedValue: {
113
+ column: lowestColumnIndex,
114
+ row: lowestRowIndex
115
+ },
116
+ optOutOfSelectionAreaUpdate: true
117
+ });
118
+ }
119
+ }
120
+ }
121
+ };
@@ -0,0 +1,108 @@
1
+ /**
2
+ * Copyright IBM Corp. 2022, 2022
3
+ *
4
+ * This source code is licensed under the Apache-2.0 license found in the
5
+ * LICENSE file in the root directory of this source tree.
6
+ */
7
+ import { getSelectionAreaPoints } from './getSelectionAreaPoints';
8
+ export var handleActiveCellInSelectionTab = function handleActiveCellInSelectionTab(_ref) {
9
+ var activeCellInsideSelectionArea = _ref.activeCellInsideSelectionArea,
10
+ activeCellCoordinates = _ref.activeCellCoordinates,
11
+ activeCellRef = _ref.activeCellRef,
12
+ selectionAreas = _ref.selectionAreas,
13
+ updateActiveCellCoordinates = _ref.updateActiveCellCoordinates;
14
+
15
+ if (!activeCellInsideSelectionArea) {
16
+ return;
17
+ }
18
+
19
+ var activeCellSelectionId = activeCellRef.current.getAttribute('data-selection-id');
20
+ var activeCellIndexInSelectionAreas = selectionAreas.findIndex(function (item) {
21
+ return item.matcher === activeCellSelectionId;
22
+ });
23
+ var selectionAreaToNavigate = selectionAreas[activeCellIndexInSelectionAreas];
24
+
25
+ var _getSelectionAreaPoin = getSelectionAreaPoints(selectionAreaToNavigate),
26
+ lowestColumnIndex = _getSelectionAreaPoin.lowestColumnIndex,
27
+ lowestRowIndex = _getSelectionAreaPoin.lowestRowIndex,
28
+ greatestColumnIndex = _getSelectionAreaPoin.greatestColumnIndex,
29
+ greatestRowIndex = _getSelectionAreaPoin.greatestRowIndex; // Move active cell to next column in selection area
30
+
31
+
32
+ if ((activeCellCoordinates === null || activeCellCoordinates === void 0 ? void 0 : activeCellCoordinates.column) < greatestColumnIndex) {
33
+ updateActiveCellCoordinates({
34
+ updatedValue: {
35
+ column: (activeCellCoordinates === null || activeCellCoordinates === void 0 ? void 0 : activeCellCoordinates.column) + 1
36
+ },
37
+ optOutOfSelectionAreaUpdate: true
38
+ });
39
+ } // Move active cell to next row of selection area if it exists
40
+ // If not, find the next selection area and update active cell to
41
+ // be the first cell in that selection
42
+
43
+
44
+ if ((activeCellCoordinates === null || activeCellCoordinates === void 0 ? void 0 : activeCellCoordinates.column) === greatestColumnIndex) {
45
+ if ((activeCellCoordinates === null || activeCellCoordinates === void 0 ? void 0 : activeCellCoordinates.row) < greatestRowIndex) {
46
+ updateActiveCellCoordinates({
47
+ updatedValue: {
48
+ column: lowestColumnIndex,
49
+ row: (activeCellCoordinates === null || activeCellCoordinates === void 0 ? void 0 : activeCellCoordinates.row) + 1
50
+ },
51
+ optOutOfSelectionAreaUpdate: true
52
+ });
53
+ } // Move to next selection area if there is on, or back to
54
+ // the beginning of the current selection
55
+
56
+
57
+ if ((activeCellCoordinates === null || activeCellCoordinates === void 0 ? void 0 : activeCellCoordinates.row) === greatestRowIndex) {
58
+ if (selectionAreas.length > 1) {
59
+ if (selectionAreas[activeCellIndexInSelectionAreas + 1]) {
60
+ // Update activeCellRef data-selection-id attribute to the matcher of the next selection area
61
+ activeCellRef.current.setAttribute('data-selection-id', selectionAreas[activeCellIndexInSelectionAreas + 1].matcher);
62
+ var nextSelectionArea = selectionAreas[activeCellIndexInSelectionAreas + 1];
63
+
64
+ var _getSelectionAreaPoin2 = getSelectionAreaPoints(nextSelectionArea),
65
+ _lowestColumnIndex = _getSelectionAreaPoin2.lowestColumnIndex,
66
+ _lowestRowIndex = _getSelectionAreaPoin2.lowestRowIndex;
67
+
68
+ updateActiveCellCoordinates({
69
+ updatedValue: {
70
+ column: _lowestColumnIndex,
71
+ row: _lowestRowIndex
72
+ },
73
+ optOutOfSelectionAreaUpdate: true
74
+ });
75
+ return;
76
+ } else {
77
+ // There are multiple selection areas and the active cell is in the last one
78
+ // So we need to move the active cell to the first cell in the first selection area
79
+ activeCellRef.current.setAttribute('data-selection-id', selectionAreas[0].matcher);
80
+ var firstSelectionArea = selectionAreas[0];
81
+
82
+ var _getSelectionAreaPoin3 = getSelectionAreaPoints(firstSelectionArea),
83
+ _lowestColumnIndex2 = _getSelectionAreaPoin3.lowestColumnIndex,
84
+ _lowestRowIndex2 = _getSelectionAreaPoin3.lowestRowIndex;
85
+
86
+ updateActiveCellCoordinates({
87
+ updatedValue: {
88
+ column: _lowestColumnIndex2,
89
+ row: _lowestRowIndex2
90
+ },
91
+ optOutOfSelectionAreaUpdate: true
92
+ });
93
+ }
94
+ } // Only one selection area, go back to first cell in the selection
95
+
96
+
97
+ if (selectionAreas.length === 1) {
98
+ return updateActiveCellCoordinates({
99
+ updatedValue: {
100
+ column: lowestColumnIndex,
101
+ row: lowestRowIndex
102
+ },
103
+ optOutOfSelectionAreaUpdate: true
104
+ });
105
+ }
106
+ }
107
+ }
108
+ };
@@ -0,0 +1,87 @@
1
+ import _defineProperty from "@babel/runtime/helpers/defineProperty";
2
+
3
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
4
+
5
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
6
+
7
+ /**
8
+ * Copyright IBM Corp. 2022, 2022
9
+ *
10
+ * This source code is licensed under the Apache-2.0 license found in the
11
+ * LICENSE file in the root directory of this source tree.
12
+ */
13
+ import { removeCellSelections } from './removeCellSelections';
14
+ import uuidv4 from '../../../global/js/utils/uuidv4'; // Update the data
15
+
16
+ export var handleEditSubmit = function handleEditSubmit(_ref) {
17
+ var activeCellCoordinates = _ref.activeCellCoordinates,
18
+ cellEditorRulerRef = _ref.cellEditorRulerRef,
19
+ columns = _ref.columns,
20
+ previousState = _ref.previousState,
21
+ removeCellEditor = _ref.removeCellEditor,
22
+ rows = _ref.rows,
23
+ setActiveCellCoordinates = _ref.setActiveCellCoordinates,
24
+ setCurrentMatcher = _ref.setCurrentMatcher,
25
+ setSelectionAreas = _ref.setSelectionAreas,
26
+ spreadsheetRef = _ref.spreadsheetRef,
27
+ updateData = _ref.updateData;
28
+ return function (event) {
29
+ var key = event.key;
30
+
31
+ var updateSelectionAreaOnCellEditSubmit = function updateSelectionAreaOnCellEditSubmit(_ref2) {
32
+ var type = _ref2.type;
33
+
34
+ var submitEditChanges = function submitEditChanges() {
35
+ var prevCoords = previousState === null || previousState === void 0 ? void 0 : previousState.activeCellCoordinates;
36
+ var cellProps = rows[prevCoords === null || prevCoords === void 0 ? void 0 : prevCoords.row].cells[prevCoords === null || prevCoords === void 0 ? void 0 : prevCoords.column];
37
+ removeCellEditor();
38
+ updateData(prevCoords === null || prevCoords === void 0 ? void 0 : prevCoords.row, cellProps.column.id);
39
+ };
40
+
41
+ removeCellSelections({
42
+ spreadsheetRef: spreadsheetRef
43
+ });
44
+ submitEditChanges();
45
+ var tempMatcher = uuidv4();
46
+ var newSelectionArea = {
47
+ row: type === 'Enter' ? activeCellCoordinates.row === rows.length - 1 ? activeCellCoordinates.row : activeCellCoordinates.row + 1 : activeCellCoordinates.row,
48
+ column: type === 'Tab' ? activeCellCoordinates.column === columns.length - 1 ? activeCellCoordinates.column : activeCellCoordinates.column + 1 : activeCellCoordinates.column
49
+ };
50
+ setSelectionAreas([{
51
+ point1: newSelectionArea,
52
+ point2: newSelectionArea,
53
+ matcher: tempMatcher,
54
+ areaCreated: false
55
+ }]);
56
+ setCurrentMatcher(tempMatcher);
57
+ cellEditorRulerRef.current.textContent = '';
58
+ };
59
+
60
+ if (key === 'Enter') {
61
+ updateSelectionAreaOnCellEditSubmit({
62
+ type: 'Enter'
63
+ });
64
+ setActiveCellCoordinates(function (prev) {
65
+ return _objectSpread(_objectSpread({}, prev), {}, {
66
+ row: prev.row === rows.length - 1 ? prev.row : prev.row + 1 // do not move to next cell below if we're already in the last row
67
+
68
+ });
69
+ });
70
+ }
71
+
72
+ if (key === 'Tab') {
73
+ event.preventDefault();
74
+ updateSelectionAreaOnCellEditSubmit({
75
+ type: 'Tab'
76
+ });
77
+ setActiveCellCoordinates(function (prev) {
78
+ return _objectSpread(_objectSpread({}, prev), {}, {
79
+ column: prev.column === columns.length - 1 ? prev.column : prev.column + 1 // do not move to next cell below if we're already in the last column
80
+
81
+ });
82
+ });
83
+ }
84
+
85
+ return;
86
+ };
87
+ };
@@ -1,11 +1,15 @@
1
+ import _toConsumableArray from "@babel/runtime/helpers/toConsumableArray";
2
+
1
3
  /**
2
4
  * Copyright IBM Corp. 2022, 2022
3
5
  *
4
6
  * This source code is licensed under the Apache-2.0 license found in the
5
7
  * LICENSE file in the root directory of this source tree.
6
8
  */
9
+ import { deepCloneObject } from '../../../global/js/utils/deepCloneObject';
7
10
  import uuidv4 from '../../../global/js/utils/uuidv4';
8
11
  import { removeCellSelections } from './removeCellSelections';
12
+ import { checkActiveHeaderCell } from './checkActiveHeaderCell';
9
13
  export var handleHeaderCellSelection = function handleHeaderCellSelection(_ref) {
10
14
  var type = _ref.type,
11
15
  activeCellCoordinates = _ref.activeCellCoordinates,
@@ -17,8 +21,16 @@ export var handleHeaderCellSelection = function handleHeaderCellSelection(_ref)
17
21
  spreadsheetRef = _ref.spreadsheetRef,
18
22
  index = _ref.index,
19
23
  isKeyboard = _ref.isKeyboard,
20
- setSelectionAreaData = _ref.setSelectionAreaData;
21
- setSelectionAreaData([]);
24
+ setSelectionAreaData = _ref.setSelectionAreaData,
25
+ isHoldingCommandKey = _ref.isHoldingCommandKey;
26
+
27
+ if (!isHoldingCommandKey) {
28
+ setSelectionAreaData([]);
29
+ removeCellSelections({
30
+ spreadsheetRef: spreadsheetRef
31
+ });
32
+ }
33
+
22
34
  var rowValue = isKeyboard ? activeCellCoordinates === null || activeCellCoordinates === void 0 ? void 0 : activeCellCoordinates.row : index;
23
35
  var columnValue = isKeyboard ? activeCellCoordinates === null || activeCellCoordinates === void 0 ? void 0 : activeCellCoordinates.column : index;
24
36
  var point1 = {
@@ -36,13 +48,35 @@ export var handleHeaderCellSelection = function handleHeaderCellSelection(_ref)
36
48
  column: type === 'column' ? columnValue : 0
37
49
  });
38
50
  setCurrentMatcher(tempMatcher);
39
- removeCellSelections({
40
- spreadsheetRef: spreadsheetRef
41
- });
42
- setSelectionAreas([{
51
+ var newSelectionArea = {
43
52
  point1: point1,
44
53
  point2: point2,
45
54
  areaCreated: false,
46
- matcher: tempMatcher
47
- }]);
55
+ matcher: tempMatcher,
56
+ header: {
57
+ type: type,
58
+ index: index
59
+ }
60
+ };
61
+ setSelectionAreas(function (prev) {
62
+ var selectionsClone = deepCloneObject(prev);
63
+
64
+ if (isHoldingCommandKey) {
65
+ var selectionsFromHeaderCell = selectionsClone.filter(function (item) {
66
+ return item.header.type;
67
+ });
68
+ var previouslyCreatedHeaderSelection = selectionsFromHeaderCell.filter(function (item) {
69
+ return item.header.type === type;
70
+ });
71
+ var isHeaderPartOfPreviousSelection = checkActiveHeaderCell(index, previouslyCreatedHeaderSelection, type); // Prevents row/column header selections from being created multiple times
72
+
73
+ if (previouslyCreatedHeaderSelection.length && isHeaderPartOfPreviousSelection) {
74
+ return prev;
75
+ }
76
+
77
+ return [].concat(_toConsumableArray(prev), [newSelectionArea]);
78
+ }
79
+
80
+ return [newSelectionArea];
81
+ });
48
82
  };