@carbon/ibm-products 2.43.2-canary.112 → 2.43.2-canary.113

Sign up to get free protection for your applications and to get access to all the features.
@@ -29,6 +29,10 @@ var useInitialColumnSort = function useInitialColumnSort(instance) {
29
29
  if (sortableColumn) {
30
30
  var columnId = sortableColumn.id,
31
31
  order = sortableColumn.order;
32
+ // prevents edge case where initial sort state of none actually starts out as ascending
33
+ if (order !== 'ASC' && order !== 'DESC') {
34
+ return;
35
+ }
32
36
  var _getNewSortOrder = getNewSortOrder(order),
33
37
  newSortDesc = _getNewSortOrder.newSortDesc,
34
38
  newOrder = _getNewSortOrder.newOrder;
@@ -5,9 +5,10 @@
5
5
  * LICENSE file in the root directory of this source tree.
6
6
  */
7
7
  import { Hooks } from 'react-table';
8
- export declare const getNewSortOrder: (sortOrder?: boolean | string) => {
9
- newSortDesc: boolean;
10
- newOrder: string;
11
- };
8
+ interface Order {
9
+ newOrder: 'ASC' | 'DESC' | 'NONE';
10
+ newSortDesc: undefined | boolean;
11
+ }
12
+ export declare const getNewSortOrder: (currentOrder?: boolean | string) => Order;
12
13
  declare const useSortableColumns: (hooks: Hooks) => void;
13
14
  export default useSortableColumns;
@@ -15,23 +15,28 @@ import { SelectAll } from './Datagrid/DatagridSelectAll.js';
15
15
  import { DatagridSlug } from './Datagrid/addons/Slug/DatagridSlug.js';
16
16
 
17
17
  var blockClass = "".concat(pkg.prefix, "--datagrid");
18
- var ordering = {
19
- ASC: 'ASC',
20
- DESC: 'DESC',
21
- NONE: 'NONE'
22
- };
23
- var getNewSortOrder = function getNewSortOrder(sortOrder) {
18
+ var getNewSortOrder = function getNewSortOrder(currentOrder) {
24
19
  var order = {
25
- newSortDesc: false,
26
- newOrder: ordering.NONE
20
+ newOrder: 'NONE',
21
+ newSortDesc: undefined
27
22
  };
28
- if (sortOrder === false || sortOrder === ordering.DESC) {
29
- order.newOrder = ordering.DESC;
23
+
24
+ // NONE => ASC
25
+ if (currentOrder === undefined) {
26
+ order.newOrder = 'ASC';
27
+ order.newSortDesc = false;
28
+ }
29
+
30
+ // ACS => DESC
31
+ if (currentOrder === false || currentOrder === 'DESC') {
32
+ order.newOrder = 'DESC';
30
33
  order.newSortDesc = true;
31
34
  }
32
- if (sortOrder === undefined || sortOrder === ordering.ASC) {
33
- order.newOrder = ordering.ASC;
34
- order.newSortDesc = false;
35
+
36
+ // DESC => NONE
37
+ if (currentOrder === true || currentOrder === 'ASC') {
38
+ order.newOrder = 'NONE';
39
+ order.newSortDesc = undefined;
35
40
  }
36
41
  return order;
37
42
  };
@@ -33,6 +33,10 @@ var useInitialColumnSort = function useInitialColumnSort(instance) {
33
33
  if (sortableColumn) {
34
34
  var columnId = sortableColumn.id,
35
35
  order = sortableColumn.order;
36
+ // prevents edge case where initial sort state of none actually starts out as ascending
37
+ if (order !== 'ASC' && order !== 'DESC') {
38
+ return;
39
+ }
36
40
  var _getNewSortOrder = useSortableColumns.getNewSortOrder(order),
37
41
  newSortDesc = _getNewSortOrder.newSortDesc,
38
42
  newOrder = _getNewSortOrder.newOrder;
@@ -5,9 +5,10 @@
5
5
  * LICENSE file in the root directory of this source tree.
6
6
  */
7
7
  import { Hooks } from 'react-table';
8
- export declare const getNewSortOrder: (sortOrder?: boolean | string) => {
9
- newSortDesc: boolean;
10
- newOrder: string;
11
- };
8
+ interface Order {
9
+ newOrder: 'ASC' | 'DESC' | 'NONE';
10
+ newSortDesc: undefined | boolean;
11
+ }
12
+ export declare const getNewSortOrder: (currentOrder?: boolean | string) => Order;
12
13
  declare const useSortableColumns: (hooks: Hooks) => void;
13
14
  export default useSortableColumns;
@@ -24,23 +24,28 @@ var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
24
24
  var cx__default = /*#__PURE__*/_interopDefaultLegacy(cx);
25
25
 
26
26
  var blockClass = "".concat(settings.pkg.prefix, "--datagrid");
27
- var ordering = {
28
- ASC: 'ASC',
29
- DESC: 'DESC',
30
- NONE: 'NONE'
31
- };
32
- var getNewSortOrder = function getNewSortOrder(sortOrder) {
27
+ var getNewSortOrder = function getNewSortOrder(currentOrder) {
33
28
  var order = {
34
- newSortDesc: false,
35
- newOrder: ordering.NONE
29
+ newOrder: 'NONE',
30
+ newSortDesc: undefined
36
31
  };
37
- if (sortOrder === false || sortOrder === ordering.DESC) {
38
- order.newOrder = ordering.DESC;
32
+
33
+ // NONE => ASC
34
+ if (currentOrder === undefined) {
35
+ order.newOrder = 'ASC';
36
+ order.newSortDesc = false;
37
+ }
38
+
39
+ // ACS => DESC
40
+ if (currentOrder === false || currentOrder === 'DESC') {
41
+ order.newOrder = 'DESC';
39
42
  order.newSortDesc = true;
40
43
  }
41
- if (sortOrder === undefined || sortOrder === ordering.ASC) {
42
- order.newOrder = ordering.ASC;
43
- order.newSortDesc = false;
44
+
45
+ // DESC => NONE
46
+ if (currentOrder === true || currentOrder === 'ASC') {
47
+ order.newOrder = 'NONE';
48
+ order.newSortDesc = undefined;
44
49
  }
45
50
  return order;
46
51
  };
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@carbon/ibm-products",
3
3
  "description": "Carbon for IBM Products",
4
- "version": "2.43.2-canary.112+d816aad33",
4
+ "version": "2.43.2-canary.113+c246a3d4c",
5
5
  "license": "Apache-2.0",
6
6
  "main": "lib/index.js",
7
7
  "module": "es/index.js",
@@ -96,7 +96,7 @@
96
96
  "dependencies": {
97
97
  "@babel/runtime": "^7.23.9",
98
98
  "@carbon/feature-flags": "^0.20.0",
99
- "@carbon/ibm-products-styles": "^2.39.1-canary.122+d816aad33",
99
+ "@carbon/ibm-products-styles": "^2.42.0",
100
100
  "@carbon/telemetry": "^0.1.0",
101
101
  "@dnd-kit/core": "^6.0.8",
102
102
  "@dnd-kit/modifiers": "^7.0.0",
@@ -120,5 +120,5 @@
120
120
  "react": "^16.8.6 || ^17.0.1 || ^18.2.0",
121
121
  "react-dom": "^16.8.6 || ^17.0.1 || ^18.2.0"
122
122
  },
123
- "gitHead": "d816aad330c70ca9902484ad301db60c58496f9b"
123
+ "gitHead": "c246a3d4cebb84b68cc879805e84466fd81dc1ab"
124
124
  }