@terraware/web-components 2.3.66-rc.0 → 2.3.66
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/Checkbox.d.ts +1 -1
- package/components/Checkbox.js +1 -2
- package/components/table/EnhancedTableToolbar.d.ts.map +1 -1
- package/components/table/EnhancedTableToolbar.js +8 -4
- package/components/table/index.d.ts +3 -4
- package/components/table/index.d.ts.map +1 -1
- package/components/table/index.js +11 -33
- package/package.json +1 -1
- package/stories/Table.stories.d.ts +2 -2
- package/stories/Table.stories.d.ts.map +1 -1
package/components/Checkbox.d.ts
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
import { Theme } from '@mui/material';
|
2
2
|
import React from 'react';
|
3
|
-
export declare const CheckboxStyle: (theme: Theme
|
3
|
+
export declare const CheckboxStyle: (theme: Theme) => {
|
4
4
|
padding: string;
|
5
5
|
'& .MuiSvgIcon-root': {
|
6
6
|
fill: import("csstype").Property.Color | undefined;
|
package/components/Checkbox.js
CHANGED
@@ -9,9 +9,8 @@ exports.default = Checkbox;
|
|
9
9
|
var _material = require("@mui/material");
|
10
10
|
var _react = _interopRequireDefault(require("react"));
|
11
11
|
var CheckboxStyle = function CheckboxStyle(theme) {
|
12
|
-
var paddingRight = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1;
|
13
12
|
return {
|
14
|
-
padding: theme.spacing(0,
|
13
|
+
padding: theme.spacing(0, 1, 0, 0),
|
15
14
|
'& .MuiSvgIcon-root': {
|
16
15
|
fill: theme.palette.TwClrBrdrSecondary
|
17
16
|
},
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"EnhancedTableToolbar.d.ts","sourceRoot":"","sources":["../../../src/components/table/EnhancedTableToolbar.tsx"],"names":[],"mappings":"
|
1
|
+
{"version":3,"file":"EnhancedTableToolbar.d.ts","sourceRoot":"","sources":["../../../src/components/table/EnhancedTableToolbar.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAE,YAAY,EAAE,MAAM,GAAG,CAAC;AAiBjC,UAAU,yBAAyB;IACjC,WAAW,EAAE,MAAM,CAAC;IACpB,qBAAqB,CAAC,EAAE,CAAC,WAAW,EAAE,MAAM,KAAK,MAAM,CAAC;IACxD,aAAa,CAAC,EAAE,YAAY,EAAE,CAAC;CAChC;AAED,MAAM,CAAC,OAAO,UAAU,oBAAoB,CAAC,KAAK,EAAE,yBAAyB,GAAG,GAAG,CAAC,OAAO,GAAG,IAAI,CAyBjG"}
|
@@ -5,10 +5,11 @@ Object.defineProperty(exports, "__esModule", {
|
|
5
5
|
value: true
|
6
6
|
});
|
7
7
|
exports.default = EnhancedTableToolbar;
|
8
|
+
var _react = _interopRequireDefault(require("react"));
|
8
9
|
var _material = require("@mui/material");
|
9
10
|
var _Button = _interopRequireDefault(require("../Button/Button"));
|
10
11
|
var _styles = require("@mui/styles");
|
11
|
-
var
|
12
|
+
var _Tooltip = _interopRequireDefault(require("../Tooltip/Tooltip"));
|
12
13
|
var styles = (0, _styles.makeStyles)(function (theme) {
|
13
14
|
return {
|
14
15
|
toolbar: {
|
@@ -34,8 +35,11 @@ function EnhancedTableToolbar(props) {
|
|
34
35
|
variant: "subtitle1",
|
35
36
|
component: "div",
|
36
37
|
className: classes.flexText
|
37
|
-
}, renderNumSelectedText(numSelected)), topBarButtons === null || topBarButtons === void 0 ? void 0 : topBarButtons.map(function (tbButton) {
|
38
|
-
return /*#__PURE__*/_react.default.createElement(
|
38
|
+
}, renderNumSelectedText(numSelected)), topBarButtons === null || topBarButtons === void 0 ? void 0 : topBarButtons.map(function (tbButton, index) {
|
39
|
+
return /*#__PURE__*/_react.default.createElement(_Tooltip.default, {
|
40
|
+
title: tbButton.tooltipTitle,
|
41
|
+
key: index
|
42
|
+
}, /*#__PURE__*/_react.default.createElement(_Button.default, {
|
39
43
|
className: classes.buttonSpacing,
|
40
44
|
key: tbButton.buttonText,
|
41
45
|
label: tbButton.buttonText,
|
@@ -44,6 +48,6 @@ function EnhancedTableToolbar(props) {
|
|
44
48
|
onClick: tbButton.onButtonClick,
|
45
49
|
icon: tbButton.icon,
|
46
50
|
disabled: tbButton.disabled
|
47
|
-
});
|
51
|
+
}));
|
48
52
|
})) : null;
|
49
53
|
}
|
@@ -1,5 +1,5 @@
|
|
1
|
-
import React from 'react';
|
2
1
|
import { TooltipProps } from '@mui/material';
|
2
|
+
import React from 'react';
|
3
3
|
import { SortOrder } from './sort';
|
4
4
|
import { TableRowType } from './TableCellRenderer';
|
5
5
|
import { DetailsRendererProps, RendererProps, TableColumnType } from './types';
|
@@ -42,8 +42,6 @@ export interface Props<T> extends LocalizationProps {
|
|
42
42
|
reloadData?: () => void;
|
43
43
|
stickyHeader?: boolean;
|
44
44
|
hideHeader?: boolean;
|
45
|
-
isSelectable?: (row: T) => boolean;
|
46
|
-
checkboxTooltip?: (row: T) => TooltipProps['title'];
|
47
45
|
}
|
48
46
|
export type TopBarButton = {
|
49
47
|
buttonText?: string;
|
@@ -51,7 +49,8 @@ export type TopBarButton = {
|
|
51
49
|
onButtonClick: () => void;
|
52
50
|
icon?: IconName;
|
53
51
|
disabled?: boolean;
|
52
|
+
tooltipTitle?: TooltipProps['title'];
|
54
53
|
};
|
55
|
-
export default function EnhancedTable<T extends TableRowType>({ id, columns, rows, order: _order, orderBy: _orderBy, Renderer, onSelect, DetailsRenderer, sortComparator, sortHandler, isInactive, isPresorted, onReorderEnd, isClickable, emptyTableMessage, showCheckbox, showTopBar, topBarButtons, selectedRows, setSelectedRows, controlledOnSelect, reloadData, stickyHeader, hideHeader, booleanFalseText, booleanTrueText, editText, renderNumSelectedText, renderPaginationText,
|
54
|
+
export default function EnhancedTable<T extends TableRowType>({ id, columns, rows, order: _order, orderBy: _orderBy, Renderer, onSelect, DetailsRenderer, sortComparator, sortHandler, isInactive, isPresorted, onReorderEnd, isClickable, emptyTableMessage, showCheckbox, showTopBar, topBarButtons, selectedRows, setSelectedRows, controlledOnSelect, reloadData, stickyHeader, hideHeader, booleanFalseText, booleanTrueText, editText, renderNumSelectedText, renderPaginationText, }: Props<T>): JSX.Element;
|
56
55
|
export declare function tableSort<T>(ignore: boolean, array: T[], comparator: (a: T, b: T) => number): T[];
|
57
56
|
//# sourceMappingURL=index.d.ts.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/table/index.tsx"],"names":[],"mappings":"AAAA,OAAO,
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/table/index.tsx"],"names":[],"mappings":"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"}
|
@@ -10,8 +10,8 @@ exports.tableSort = tableSort;
|
|
10
10
|
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/toConsumableArray"));
|
11
11
|
var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/objectSpread2"));
|
12
12
|
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/slicedToArray"));
|
13
|
-
var _react = _interopRequireWildcard(require("react"));
|
14
13
|
var _material = require("@mui/material");
|
14
|
+
var _react = _interopRequireWildcard(require("react"));
|
15
15
|
var _EnhancedTableToolbar = _interopRequireDefault(require("./EnhancedTableToolbar"));
|
16
16
|
var _sort = require("./sort");
|
17
17
|
var _TableCellRenderer = _interopRequireDefault(require("./TableCellRenderer"));
|
@@ -21,7 +21,6 @@ var _core = require("@dnd-kit/core");
|
|
21
21
|
var _sortable = require("@dnd-kit/sortable");
|
22
22
|
var _utils = require("../../utils");
|
23
23
|
var _Checkbox = require("../Checkbox");
|
24
|
-
var _IconTooltip = _interopRequireDefault(require("../IconTooltip"));
|
25
24
|
var tableStyles = (0, _styles.makeStyles)(function (theme) {
|
26
25
|
return {
|
27
26
|
hover: {
|
@@ -81,9 +80,7 @@ function EnhancedTable(_ref) {
|
|
81
80
|
booleanTrueText = _ref.booleanTrueText,
|
82
81
|
editText = _ref.editText,
|
83
82
|
renderNumSelectedText = _ref.renderNumSelectedText,
|
84
|
-
renderPaginationText = _ref.renderPaginationText
|
85
|
-
isSelectable = _ref.isSelectable,
|
86
|
-
checkboxTooltip = _ref.checkboxTooltip;
|
83
|
+
renderPaginationText = _ref.renderPaginationText;
|
87
84
|
var classes = tableStyles();
|
88
85
|
var theme = (0, _material.useTheme)();
|
89
86
|
var _React$useState = _react.default.useState(_order),
|
@@ -115,15 +112,6 @@ function EnhancedTable(_ref) {
|
|
115
112
|
_useState10 = (0, _slicedToArray2.default)(_useState9, 2),
|
116
113
|
displayColumnDetails = _useState10[0],
|
117
114
|
setDisplayColumnDetails = _useState10[1];
|
118
|
-
var selectableRows = (0, _react.useMemo)(function () {
|
119
|
-
if (isSelectable) {
|
120
|
-
return rows.filter(function (row) {
|
121
|
-
return isSelectable(row);
|
122
|
-
});
|
123
|
-
} else {
|
124
|
-
return rows;
|
125
|
-
}
|
126
|
-
}, [isSelectable, rows]);
|
127
115
|
(0, _react.useEffect)(function () {
|
128
116
|
var columnsKeyNames = columns.map(function (col) {
|
129
117
|
return col.key;
|
@@ -145,16 +133,16 @@ function EnhancedTable(_ref) {
|
|
145
133
|
}
|
146
134
|
}, [displayColumnKeyNames, displayColumnsIndexed]);
|
147
135
|
(0, _react.useEffect)(function () {
|
148
|
-
if (setSelectedRows &&
|
136
|
+
if (setSelectedRows && rows.length >= 0) {
|
149
137
|
setSelectedRows(function (currentlySelectedRows) {
|
150
138
|
var emptyArray = [];
|
151
|
-
if (
|
139
|
+
if (rows.length || currentlySelectedRows.length > rows.length) {
|
152
140
|
return emptyArray;
|
153
141
|
}
|
154
142
|
return currentlySelectedRows;
|
155
143
|
});
|
156
144
|
}
|
157
|
-
}, [
|
145
|
+
}, [rows, setSelectedRows]);
|
158
146
|
(0, _react.useEffect)(function () {
|
159
147
|
// this is not most elegant but we want to do this if table was sorted by some column in a presorted table
|
160
148
|
// but we don't know when the data changes, hence this useEffect on the data size
|
@@ -182,7 +170,7 @@ function EnhancedTable(_ref) {
|
|
182
170
|
var handleSelectAllClick = function handleSelectAllClick(event) {
|
183
171
|
if (setSelectedRows) {
|
184
172
|
if (event.target.checked) {
|
185
|
-
setSelectedRows(
|
173
|
+
setSelectedRows(rows);
|
186
174
|
return;
|
187
175
|
} else {
|
188
176
|
setSelectedRows([]);
|
@@ -190,7 +178,7 @@ function EnhancedTable(_ref) {
|
|
190
178
|
}
|
191
179
|
};
|
192
180
|
var handleClick = function handleClick(event, row) {
|
193
|
-
if (setSelectedRows && selectedRows
|
181
|
+
if (setSelectedRows && selectedRows) {
|
194
182
|
var selectedIndex = selectedRows.indexOf(row);
|
195
183
|
var newSelected = [];
|
196
184
|
if (selectedIndex === -1) {
|
@@ -289,7 +277,7 @@ function EnhancedTable(_ref) {
|
|
289
277
|
onReorderEnd: onReorderEndHandler,
|
290
278
|
numSelected: showCheckbox ? selectedRows === null || selectedRows === void 0 ? void 0 : selectedRows.length : undefined,
|
291
279
|
onSelectAllClick: showCheckbox ? handleSelectAllClick : undefined,
|
292
|
-
rowCount: showCheckbox ?
|
280
|
+
rowCount: showCheckbox ? rows === null || rows === void 0 ? void 0 : rows.length : undefined
|
293
281
|
}), /*#__PURE__*/_react.default.createElement(_material.TableBody, null, rows.length < 1 && emptyTableMessage && /*#__PURE__*/_react.default.createElement(_material.TableRow, null, /*#__PURE__*/_react.default.createElement(_material.TableCell, {
|
294
282
|
colSpan: columns.length + 1,
|
295
283
|
align: "center"
|
@@ -298,7 +286,6 @@ function EnhancedTable(_ref) {
|
|
298
286
|
return onSelect(row);
|
299
287
|
} : undefined;
|
300
288
|
var isItemSelected = isSelected(row);
|
301
|
-
var tooltipTitle = checkboxTooltip ? checkboxTooltip(row) : undefined;
|
302
289
|
return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, {
|
303
290
|
key: index
|
304
291
|
}, /*#__PURE__*/_react.default.createElement(_material.TableRow, {
|
@@ -322,24 +309,15 @@ function EnhancedTable(_ref) {
|
|
322
309
|
}, showCheckbox && /*#__PURE__*/_react.default.createElement(_material.TableCell, {
|
323
310
|
padding: "checkbox",
|
324
311
|
className: classes.cellDefault
|
325
|
-
}, /*#__PURE__*/_react.default.createElement(_material.Box, {
|
326
|
-
display: "flex",
|
327
|
-
alignItems: "center"
|
328
312
|
}, /*#__PURE__*/_react.default.createElement(_material.Checkbox, {
|
329
313
|
disableRipple: true,
|
330
|
-
sx: (0, _Checkbox.CheckboxStyle)(theme
|
331
|
-
disabled: isSelectable && !isSelectable(row),
|
314
|
+
sx: (0, _Checkbox.CheckboxStyle)(theme),
|
332
315
|
color: "primary",
|
333
316
|
checked: isItemSelected,
|
334
317
|
onClick: function onClick(e) {
|
335
|
-
|
336
|
-
if (rowSelectable && (!isClickable || !isClickable(row))) {
|
337
|
-
handleClick(e, row);
|
338
|
-
}
|
318
|
+
return !isClickable || !isClickable(row) ? handleClick(e, row) : null;
|
339
319
|
}
|
340
|
-
}),
|
341
|
-
title: tooltipTitle
|
342
|
-
}))), displayColumnDetails && displayColumnDetails.map(function (c) {
|
320
|
+
})), displayColumnDetails && displayColumnDetails.map(function (c) {
|
343
321
|
return /*#__PURE__*/_react.default.createElement(Renderer, {
|
344
322
|
index: index + 1,
|
345
323
|
key: c.key,
|
package/package.json
CHANGED
@@ -12,11 +12,11 @@ export declare const Selectable: import("@storybook/types").AnnotatedStoryFn<imp
|
|
12
12
|
name: string;
|
13
13
|
lastname: string;
|
14
14
|
}>>;
|
15
|
-
export declare const
|
15
|
+
export declare const Presorted: import("@storybook/types").AnnotatedStoryFn<import("@storybook/react/dist/types-0a347bb9").R, TableProps<{
|
16
16
|
name: string;
|
17
17
|
lastname: string;
|
18
18
|
}>>;
|
19
|
-
export declare const
|
19
|
+
export declare const ShowTopBar: import("@storybook/types").AnnotatedStoryFn<import("@storybook/react/dist/types-0a347bb9").R, TableProps<{
|
20
20
|
name: string;
|
21
21
|
lastname: string;
|
22
22
|
}>>;
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"Table.stories.d.ts","sourceRoot":"","sources":["../../src/stories/Table.stories.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,EAAE,KAAK,IAAI,UAAU,EAAE,MAAM,2BAA2B,CAAC;;;;;AAYvE,wBAGE;
|
1
|
+
{"version":3,"file":"Table.stories.d.ts","sourceRoot":"","sources":["../../src/stories/Table.stories.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,EAAE,KAAK,IAAI,UAAU,EAAE,MAAM,2BAA2B,CAAC;;;;;AAYvE,wBAGE;AAmDF,eAAO,MAAM,OAAO;UAtCqB,MAAM;cAAY,MAAM;GAsCzB,CAAC;AACzC,eAAO,MAAM,UAAU;UAvCkB,MAAM;cAAY,MAAM;GAuCtB,CAAC;AAC5C,eAAO,MAAM,SAAS;UAxCmB,MAAM;cAAY,MAAM;GAwCvB,CAAC;AAC3C,eAAO,MAAM,UAAU;UAzCkB,MAAM;cAAY,MAAM;GAyCtB,CAAC"}
|