@vendorflow/components 2.0.71 → 2.0.74

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (36) hide show
  1. package/lib/components/material-ui/AudioPlayer/AudioPlayer.d.ts +3 -2
  2. package/lib/components/material-ui/AudioPlayer/AudioPlayer.js +2 -2
  3. package/lib/components/material-ui/AudioPlayer/AudioPlayer.story.js +1 -1
  4. package/lib/components/material-ui/DataTable/Data.js +1 -1
  5. package/lib/components/material-ui/DataTable/DataTable.d.ts +7 -3
  6. package/lib/components/material-ui/DataTable/DataTable.js +71 -66
  7. package/lib/components/material-ui/DataTable/DataTable.story.js +11 -2
  8. package/lib/components/material-ui/DataTable/SortIndicator.js +2 -2
  9. package/lib/components/material-ui/DataTable/TablePieces/AppliedFilters.d.ts +12 -0
  10. package/lib/components/material-ui/DataTable/TablePieces/AppliedFilters.js +26 -0
  11. package/lib/components/material-ui/DataTable/TablePieces/BodyCell.d.ts +10 -0
  12. package/lib/components/material-ui/DataTable/TablePieces/BodyCell.js +49 -0
  13. package/lib/components/material-ui/DataTable/TablePieces/BodyRow.d.ts +15 -0
  14. package/lib/components/material-ui/DataTable/TablePieces/BodyRow.js +88 -0
  15. package/lib/components/material-ui/DataTable/TablePieces/GlobalSearchFilter.d.ts +10 -0
  16. package/lib/components/material-ui/DataTable/TablePieces/GlobalSearchFilter.js +49 -0
  17. package/lib/components/material-ui/DataTable/TablePieces/HeaderCell.d.ts +12 -0
  18. package/lib/components/material-ui/DataTable/TablePieces/HeaderCell.js +53 -0
  19. package/lib/components/material-ui/DataTable/TablePieces/IndeterminateCheckbox.d.ts +4 -0
  20. package/lib/components/material-ui/DataTable/TablePieces/IndeterminateCheckbox.js +65 -0
  21. package/lib/components/material-ui/DataTable/TablePieces/SortIndicator.d.ts +10 -0
  22. package/lib/components/material-ui/DataTable/TablePieces/SortIndicator.js +33 -0
  23. package/lib/components/material-ui/DataTable/TablePieces/Table.d.ts +12 -0
  24. package/lib/components/material-ui/DataTable/TablePieces/Table.js +47 -0
  25. package/lib/components/material-ui/DataTable/TablePieces/TableBodyContent.d.ts +25 -0
  26. package/lib/components/material-ui/DataTable/TablePieces/TableBodyContent.js +71 -0
  27. package/lib/components/material-ui/DataTable/TablePieces/Toolbar.d.ts +24 -0
  28. package/lib/components/material-ui/DataTable/TablePieces/Toolbar.js +63 -0
  29. package/lib/components/material-ui/DataTable/TablePieces/ViewColumnTool.d.ts +11 -0
  30. package/lib/components/material-ui/DataTable/TablePieces/ViewColumnTool.js +76 -0
  31. package/lib/components/material-ui/DataTable/Utils.d.ts +25 -0
  32. package/lib/components/material-ui/DataTable/Utils.js +119 -0
  33. package/lib/components/material-ui/Modal/Modal.d.ts +1 -0
  34. package/lib/components/material-ui/Modal/Modal.js +13 -7
  35. package/lib/components/material-ui/Modal/Modal.story.js +30 -3
  36. package/package.json +5 -2
@@ -0,0 +1,49 @@
1
+ "use strict";
2
+ var __makeTemplateObject = (this && this.__makeTemplateObject) || function (cooked, raw) {
3
+ if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; }
4
+ return cooked;
5
+ };
6
+ var __read = (this && this.__read) || function (o, n) {
7
+ var m = typeof Symbol === "function" && o[Symbol.iterator];
8
+ if (!m) return o;
9
+ var i = m.call(o), r, ar = [], e;
10
+ try {
11
+ while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
12
+ }
13
+ catch (error) { e = { error: error }; }
14
+ finally {
15
+ try {
16
+ if (r && !r.done && (m = i["return"])) m.call(i);
17
+ }
18
+ finally { if (e) throw e.error; }
19
+ }
20
+ return ar;
21
+ };
22
+ Object.defineProperty(exports, "__esModule", { value: true });
23
+ /** @jsxRuntime classic */
24
+ /** @jsx jsx */
25
+ var react_1 = require("@emotion/react");
26
+ var material_1 = require("@mui/material");
27
+ var icons_material_1 = require("@mui/icons-material");
28
+ var react_table_1 = require("react-table");
29
+ var react_2 = require("react");
30
+ function GlobalSearchFilter(_a) {
31
+ var globalFilter = _a.globalFilter, setGlobalFilter = _a.setGlobalFilter, setShowSearch = _a.setShowSearch;
32
+ var _b = __read((0, react_2.useState)(globalFilter), 2), value = _b[0], setValue = _b[1];
33
+ var onChange = (0, react_table_1.useAsyncDebounce)(function (value) {
34
+ setGlobalFilter(value || undefined);
35
+ }, 300);
36
+ return ((0, react_1.jsx)("div", { css: (0, react_1.css)(templateObject_1 || (templateObject_1 = __makeTemplateObject(["\n max-width: 100%;\n min-width: 20rem;\n display: flex;\n flex-direction: row;\n justify-content: flex-start;\n align-items: center;\n "], ["\n max-width: 100%;\n min-width: 20rem;\n display: flex;\n flex-direction: row;\n justify-content: flex-start;\n align-items: center;\n "]))), "data-testid": "globalSearchFilter" },
37
+ (0, react_1.jsx)(icons_material_1.Search, null),
38
+ (0, react_1.jsx)(material_1.TextField, { value: value || '', onChange: function (evt) {
39
+ setValue(evt.target.value);
40
+ onChange(evt.target.value);
41
+ }, fullWidth: true, variant: "standard", autoFocus: true }),
42
+ (0, react_1.jsx)(material_1.IconButton, { onClick: function () {
43
+ setGlobalFilter(null);
44
+ setShowSearch(false);
45
+ } },
46
+ (0, react_1.jsx)(icons_material_1.Close, null))));
47
+ }
48
+ exports.default = GlobalSearchFilter;
49
+ var templateObject_1;
@@ -0,0 +1,12 @@
1
+ /** @jsxRuntime classic */
2
+ /** @jsx jsx */
3
+ import { jsx } from '@emotion/react';
4
+ import { EnhancedHeader } from '../DataTable';
5
+ import { TableHeaderProps } from 'react-table';
6
+ interface Props<D extends object> {
7
+ className?: string;
8
+ header: EnhancedHeader<D>;
9
+ headerProps: Omit<TableHeaderProps, 'key'>;
10
+ }
11
+ export default function HeaderCell<D extends object>({ className, header, headerProps }: Props<D>): jsx.JSX.Element;
12
+ export {};
@@ -0,0 +1,53 @@
1
+ "use strict";
2
+ var __makeTemplateObject = (this && this.__makeTemplateObject) || function (cooked, raw) {
3
+ if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; }
4
+ return cooked;
5
+ };
6
+ var __assign = (this && this.__assign) || function () {
7
+ __assign = Object.assign || function(t) {
8
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
9
+ s = arguments[i];
10
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
11
+ t[p] = s[p];
12
+ }
13
+ return t;
14
+ };
15
+ return __assign.apply(this, arguments);
16
+ };
17
+ var __rest = (this && this.__rest) || function (s, e) {
18
+ var t = {};
19
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
20
+ t[p] = s[p];
21
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
22
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
23
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
24
+ t[p[i]] = s[p[i]];
25
+ }
26
+ return t;
27
+ };
28
+ var __importDefault = (this && this.__importDefault) || function (mod) {
29
+ return (mod && mod.__esModule) ? mod : { "default": mod };
30
+ };
31
+ Object.defineProperty(exports, "__esModule", { value: true });
32
+ /** @jsxRuntime classic */
33
+ /** @jsx jsx */
34
+ var react_1 = require("@emotion/react");
35
+ var classnames_1 = __importDefault(require("classnames"));
36
+ var SortIndicator_1 = __importDefault(require("./SortIndicator"));
37
+ var material_1 = require("@mui/material");
38
+ var DataTable_1 = require("../DataTable");
39
+ function HeaderCell(_a) {
40
+ var className = _a.className, header = _a.header, headerProps = _a.headerProps;
41
+ var headerPropsClassName = headerProps.className, style = headerProps.style, restOfProps = __rest(headerProps, ["className", "style"]);
42
+ return ((0, react_1.jsx)(react_1.ClassNames, null, function (_a) {
43
+ var css = _a.css, cx = _a.cx;
44
+ return ((0, react_1.jsx)(material_1.TableCell, __assign({}, restOfProps, { component: "div", variant: "head", css: cx(
45
+ // @ts-ignore
46
+ css(style), css(templateObject_1 || (templateObject_1 = __makeTemplateObject(["\n && {\n display: flex;\n box-sizing: border-box;\n padding: ", "px;\n }\n "], ["\n && {\n display: flex;\n box-sizing: border-box;\n padding: ", "px;\n }\n "])), DataTable_1.CELL_PADDING), header.minWidth !== undefined && css(templateObject_2 || (templateObject_2 = __makeTemplateObject(["\n min-width: ", "px;\n "], ["\n min-width: ", "px;\n "])), header.minWidth), header.maxWidth !== undefined && css(templateObject_3 || (templateObject_3 = __makeTemplateObject(["\n max-width: ", "px;\n "], ["\n max-width: ", "px;\n "])), header.maxWidth)), className: (0, classnames_1.default)(headerPropsClassName, className, "col-" + header.id) }),
47
+ (0, react_1.jsx)("div", { css: cx(css(templateObject_4 || (templateObject_4 = __makeTemplateObject(["\n display: flex;\n flex-direction: row;\n justify-content: ", ";\n align-items: center;\n width: 100%;\n overflow: hidden;\n white-space: nowrap;\n text-overflow: ellipsis;\n "], ["\n display: flex;\n flex-direction: row;\n justify-content: ", ";\n align-items: center;\n width: 100%;\n overflow: hidden;\n white-space: nowrap;\n text-overflow: ellipsis;\n "])), header.columns != null ? 'center' : 'flex-start')) },
48
+ (0, react_1.jsx)("span", { css: cx(css(templateObject_5 || (templateObject_5 = __makeTemplateObject(["\n font-weight: 600;\n flex: none;\n "], ["\n font-weight: 600;\n flex: none;\n "])))) }, header.render('Header')),
49
+ (0, react_1.jsx)(SortIndicator_1.default, { canSort: header.canSort, isSorted: header.isSorted, isSortedDesc: header.isSortedDesc }))));
50
+ }));
51
+ }
52
+ exports.default = HeaderCell;
53
+ var templateObject_1, templateObject_2, templateObject_3, templateObject_4, templateObject_5;
@@ -0,0 +1,4 @@
1
+ /// <reference types="react" />
2
+ export declare const CHECKBOX_WIDTH = 32;
3
+ declare const IndeterminateCheckbox: import("react").ForwardRefExoticComponent<HTMLInputElement & import("react").RefAttributes<HTMLInputElement>>;
4
+ export default IndeterminateCheckbox;
@@ -0,0 +1,65 @@
1
+ "use strict";
2
+ var __makeTemplateObject = (this && this.__makeTemplateObject) || function (cooked, raw) {
3
+ if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; }
4
+ return cooked;
5
+ };
6
+ var __assign = (this && this.__assign) || function () {
7
+ __assign = Object.assign || function(t) {
8
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
9
+ s = arguments[i];
10
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
11
+ t[p] = s[p];
12
+ }
13
+ return t;
14
+ };
15
+ return __assign.apply(this, arguments);
16
+ };
17
+ var __rest = (this && this.__rest) || function (s, e) {
18
+ var t = {};
19
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
20
+ t[p] = s[p];
21
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
22
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
23
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
24
+ t[p[i]] = s[p[i]];
25
+ }
26
+ return t;
27
+ };
28
+ Object.defineProperty(exports, "__esModule", { value: true });
29
+ exports.CHECKBOX_WIDTH = void 0;
30
+ /** @jsxRuntime classic */
31
+ /** @jsx jsx */
32
+ var react_1 = require("@emotion/react");
33
+ var react_2 = require("react");
34
+ var material_1 = require("@mui/material");
35
+ exports.CHECKBOX_WIDTH = 32;
36
+ // eslint-disable-next-line react/display-name
37
+ var IndeterminateCheckbox = (0, react_2.forwardRef)(function (_a, ref) {
38
+ var indeterminate = _a.indeterminate, restOfProps = __rest(_a, ["indeterminate"]);
39
+ var resolvedRef = useForwardedRef(ref);
40
+ (0, react_2.useEffect)(function () {
41
+ if (resolvedRef.current) {
42
+ resolvedRef.current.indeterminate = indeterminate;
43
+ }
44
+ }, [resolvedRef, indeterminate]);
45
+ return ((0, react_1.jsx)(react_2.Fragment, null,
46
+ (0, react_1.jsx)(material_1.Checkbox, __assign({ css: (0, react_1.css)(templateObject_1 || (templateObject_1 = __makeTemplateObject(["\n width: ", "px;\n height: ", "px;\n "], ["\n width: ", "px;\n height: ", "px;\n "])), exports.CHECKBOX_WIDTH, exports.CHECKBOX_WIDTH),
47
+ //@ts-ignore
48
+ ref: resolvedRef }, restOfProps, { indeterminate: indeterminate }))));
49
+ });
50
+ exports.default = IndeterminateCheckbox;
51
+ function useForwardedRef(ref) {
52
+ var innerRef = (0, react_2.useRef)(null);
53
+ (0, react_2.useEffect)(function () {
54
+ if (!ref)
55
+ return;
56
+ if (typeof ref === 'function') {
57
+ ref(innerRef.current);
58
+ }
59
+ else {
60
+ ref.current = innerRef.current;
61
+ }
62
+ }, []);
63
+ return innerRef;
64
+ }
65
+ var templateObject_1;
@@ -0,0 +1,10 @@
1
+ /** @jsxRuntime classic */
2
+ /** @jsx jsx */
3
+ import { jsx } from '@emotion/react';
4
+ interface Props {
5
+ canSort?: boolean;
6
+ isSorted?: boolean;
7
+ isSortedDesc?: boolean;
8
+ }
9
+ export default function SortIndicator({ canSort, isSorted, isSortedDesc }: Props): jsx.JSX.Element | null;
10
+ export {};
@@ -0,0 +1,33 @@
1
+ "use strict";
2
+ var __makeTemplateObject = (this && this.__makeTemplateObject) || function (cooked, raw) {
3
+ if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; }
4
+ return cooked;
5
+ };
6
+ Object.defineProperty(exports, "__esModule", { value: true });
7
+ /** @jsxRuntime classic */
8
+ /** @jsx jsx */
9
+ var react_1 = require("@emotion/react");
10
+ var icons_material_1 = require("@mui/icons-material");
11
+ var iconStyle = (0, react_1.css)(templateObject_1 || (templateObject_1 = __makeTemplateObject(["\n margin-left: 0.25rem;\n color: #b2b2b2;\n line-height: 0;\n\n && {\n font-size: 1rem;\n }\n"], ["\n margin-left: 0.25rem;\n color: #b2b2b2;\n line-height: 0;\n\n && {\n font-size: 1rem;\n }\n"])));
12
+ var smallIconStyle = (0, react_1.css)(templateObject_2 || (templateObject_2 = __makeTemplateObject(["\n ", ";\n && {\n font-size: 0.75rem;\n }\n"], ["\n ", ";\n && {\n font-size: 0.75rem;\n }\n"])), iconStyle);
13
+ var wrapperStyle = (0, react_1.css)(templateObject_3 || (templateObject_3 = __makeTemplateObject(["\n line-height: 0;\n flex: none;\n"], ["\n line-height: 0;\n flex: none;\n"])));
14
+ var stackedWrapperStyle = (0, react_1.css)(templateObject_4 || (templateObject_4 = __makeTemplateObject(["\n ", ";\n flex: none;\n display: inline-flex;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n"], ["\n ", ";\n flex: none;\n display: inline-flex;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n"])), wrapperStyle);
15
+ function SortIndicator(_a) {
16
+ var canSort = _a.canSort, isSorted = _a.isSorted, isSortedDesc = _a.isSortedDesc;
17
+ if (!canSort) {
18
+ return null;
19
+ }
20
+ if (!isSorted) {
21
+ return ((0, react_1.jsx)("span", { css: stackedWrapperStyle },
22
+ (0, react_1.jsx)(icons_material_1.ArrowUpward, { css: smallIconStyle }),
23
+ (0, react_1.jsx)(icons_material_1.ArrowDownward, { css: smallIconStyle })));
24
+ }
25
+ if (isSortedDesc) {
26
+ return ((0, react_1.jsx)("span", { css: wrapperStyle },
27
+ (0, react_1.jsx)(icons_material_1.ArrowDownward, { css: iconStyle })));
28
+ }
29
+ return ((0, react_1.jsx)("span", { css: wrapperStyle },
30
+ (0, react_1.jsx)(icons_material_1.ArrowUpward, { css: iconStyle })));
31
+ }
32
+ exports.default = SortIndicator;
33
+ var templateObject_1, templateObject_2, templateObject_3, templateObject_4;
@@ -0,0 +1,12 @@
1
+ /** @jsxRuntime classic */
2
+ /** @jsx jsx */
3
+ import { jsx } from '@emotion/react';
4
+ import { TablePropGetter, TableProps } from 'react-table';
5
+ import { ReactNode } from 'react';
6
+ interface Props<D extends object> {
7
+ children: ReactNode;
8
+ className?: string;
9
+ getTableProps: (propGetter?: TablePropGetter<D>) => TableProps;
10
+ }
11
+ export default function Table<D extends object>({ children, className, getTableProps }: Props<D>): jsx.JSX.Element;
12
+ export {};
@@ -0,0 +1,47 @@
1
+ "use strict";
2
+ var __makeTemplateObject = (this && this.__makeTemplateObject) || function (cooked, raw) {
3
+ if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; }
4
+ return cooked;
5
+ };
6
+ var __assign = (this && this.__assign) || function () {
7
+ __assign = Object.assign || function(t) {
8
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
9
+ s = arguments[i];
10
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
11
+ t[p] = s[p];
12
+ }
13
+ return t;
14
+ };
15
+ return __assign.apply(this, arguments);
16
+ };
17
+ var __rest = (this && this.__rest) || function (s, e) {
18
+ var t = {};
19
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
20
+ t[p] = s[p];
21
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
22
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
23
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
24
+ t[p[i]] = s[p[i]];
25
+ }
26
+ return t;
27
+ };
28
+ var __importDefault = (this && this.__importDefault) || function (mod) {
29
+ return (mod && mod.__esModule) ? mod : { "default": mod };
30
+ };
31
+ Object.defineProperty(exports, "__esModule", { value: true });
32
+ /** @jsxRuntime classic */
33
+ /** @jsx jsx */
34
+ var react_1 = require("@emotion/react");
35
+ var classnames_1 = __importDefault(require("classnames"));
36
+ function Table(_a) {
37
+ var children = _a.children, className = _a.className, getTableProps = _a.getTableProps;
38
+ var _b = getTableProps(), style = _b.style, tablePropsClassName = _b.className, restOfProps = __rest(_b, ["style", "className"]);
39
+ return ((0, react_1.jsx)(react_1.ClassNames, null, function (_a) {
40
+ var css = _a.css, cx = _a.cx;
41
+ return ((0, react_1.jsx)("div", __assign({}, restOfProps, { className: (0, classnames_1.default)(tablePropsClassName, className, 'VfTable'), css: cx(
42
+ // @ts-ignore
43
+ css(style), css(templateObject_1 || (templateObject_1 = __makeTemplateObject(["\n height: 100%;\n "], ["\n height: 100%;\n "])))) }), children));
44
+ }));
45
+ }
46
+ exports.default = Table;
47
+ var templateObject_1;
@@ -0,0 +1,25 @@
1
+ /** @jsxRuntime classic */
2
+ /** @jsx jsx */
3
+ import { jsx } from '@emotion/react';
4
+ import { Dispatch, MutableRefObject, SetStateAction } from 'react';
5
+ import { Row } from 'react-table';
6
+ interface Props<D extends object> {
7
+ defaultRowHeight: number;
8
+ ExpandedComponent: ((props: {
9
+ data: D;
10
+ }) => JSX.Element) | undefined;
11
+ hasScrollbarRefCallback: (node: HTMLDivElement | null) => void;
12
+ height: number | undefined;
13
+ isVirtualizeEnabled: boolean;
14
+ noMatchLabel?: string;
15
+ prepareRow: (row: Row<D>) => void;
16
+ scrollContainerRef: MutableRefObject<HTMLDivElement | null>;
17
+ setScrollLeft: Dispatch<SetStateAction<number>>;
18
+ tableBodyRef: MutableRefObject<HTMLDivElement | null>;
19
+ tableBodyMeasureRefCallback: (node: HTMLDivElement | null) => void;
20
+ tableRows: Row<D>[];
21
+ totalColumnsWidth: number;
22
+ width: number | undefined;
23
+ }
24
+ export default function TableBodyContent<D extends object>({ defaultRowHeight, ExpandedComponent, hasScrollbarRefCallback, height, isVirtualizeEnabled, noMatchLabel, prepareRow, scrollContainerRef, setScrollLeft, tableBodyRef, tableBodyMeasureRefCallback, tableRows, totalColumnsWidth, width, }: Props<D>): jsx.JSX.Element;
25
+ export {};
@@ -0,0 +1,71 @@
1
+ "use strict";
2
+ var __makeTemplateObject = (this && this.__makeTemplateObject) || function (cooked, raw) {
3
+ if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; }
4
+ return cooked;
5
+ };
6
+ var __rest = (this && this.__rest) || function (s, e) {
7
+ var t = {};
8
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
9
+ t[p] = s[p];
10
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
11
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
12
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
13
+ t[p[i]] = s[p[i]];
14
+ }
15
+ return t;
16
+ };
17
+ var __importDefault = (this && this.__importDefault) || function (mod) {
18
+ return (mod && mod.__esModule) ? mod : { "default": mod };
19
+ };
20
+ Object.defineProperty(exports, "__esModule", { value: true });
21
+ /** @jsxRuntime classic */
22
+ /** @jsx jsx */
23
+ var react_1 = require("@emotion/react");
24
+ var react_virtualized_1 = require("react-virtualized");
25
+ var BodyRow_1 = __importDefault(require("./BodyRow"));
26
+ var material_1 = require("@mui/material");
27
+ var react_2 = require("react");
28
+ function TableBodyContent(_a) {
29
+ var defaultRowHeight = _a.defaultRowHeight, ExpandedComponent = _a.ExpandedComponent, hasScrollbarRefCallback = _a.hasScrollbarRefCallback, height = _a.height, isVirtualizeEnabled = _a.isVirtualizeEnabled, noMatchLabel = _a.noMatchLabel, prepareRow = _a.prepareRow, scrollContainerRef = _a.scrollContainerRef, setScrollLeft = _a.setScrollLeft, tableBodyRef = _a.tableBodyRef, tableBodyMeasureRefCallback = _a.tableBodyMeasureRefCallback, tableRows = _a.tableRows, totalColumnsWidth = _a.totalColumnsWidth, width = _a.width;
30
+ var cache = (0, react_2.useRef)(new react_virtualized_1.CellMeasurerCache({ fixedWidth: true, defaultHeight: defaultRowHeight, defaultWidth: totalColumnsWidth }));
31
+ function renderRow(_a) {
32
+ var columnIndex = _a.columnIndex, rowIndex = _a.rowIndex, key = _a.key, parent = _a.parent, style = _a.style;
33
+ var row = tableRows[rowIndex];
34
+ prepareRow(row);
35
+ var _b = row.getRowProps(), _ = _b.key, restOfRowProps = __rest(_b, ["key"]);
36
+ return ((0, react_1.jsx)(react_virtualized_1.CellMeasurer, { cache: cache.current, columnIndex: columnIndex, key: key, rowIndex: rowIndex, parent: parent }, function (_a) {
37
+ var measure = _a.measure, registerChild = _a.registerChild;
38
+ return ((0, react_1.jsx)(BodyRow_1.default, { key: key, innerRef: registerChild, ExpandedComponent: ExpandedComponent, row: row, rowProps: restOfRowProps, style: style, measure: measure }));
39
+ }));
40
+ }
41
+ return ((0, react_1.jsx)(material_1.TableBody, { ref: function (node) {
42
+ // @ts-ignore
43
+ tableBodyRef.current = node;
44
+ tableBodyMeasureRefCallback(node); // need this to get the height and width
45
+ if (isVirtualizeEnabled) {
46
+ scrollContainerRef.current = (node === null || node === void 0 ? void 0 : node.firstElementChild) || null;
47
+ hasScrollbarRefCallback((node === null || node === void 0 ? void 0 : node.firstElementChild) || null);
48
+ }
49
+ }, component: "div", css: (0, react_1.css)(templateObject_1 || (templateObject_1 = __makeTemplateObject(["\n && {\n display: block;\n }\n "], ["\n && {\n display: block;\n }\n "]))), className: "DataTable__TableBody" },
50
+ isVirtualizeEnabled && !!height && !!width && ((0, react_1.jsx)(react_virtualized_1.Grid, { deferredMeasurementCache: cache.current, height: height, width: width, overscanRowCount: 5, columnCount: 1, columnWidth: cache.current.columnWidth, rowCount: tableRows.length, rowHeight: cache.current.rowHeight, estimatedRowSize: defaultRowHeight, cellRenderer: renderRow, onScroll: function (params) {
51
+ var scrollLeft = params.scrollLeft;
52
+ setScrollLeft(scrollLeft);
53
+ } })),
54
+ !isVirtualizeEnabled && !!height && !!width && ((0, react_1.jsx)("div", { css: (0, react_1.css)(templateObject_2 || (templateObject_2 = __makeTemplateObject(["\n height: ", "px;\n width: ", "px;\n overflow: auto;\n "], ["\n height: ", "px;\n width: ", "px;\n overflow: auto;\n "])), height, width), ref: function (node) {
55
+ scrollContainerRef.current = node;
56
+ hasScrollbarRefCallback(node);
57
+ }, onScroll: function (evt) {
58
+ var scrollLeft = evt.target.scrollLeft;
59
+ setScrollLeft(scrollLeft);
60
+ } },
61
+ (0, react_1.jsx)("div", null, tableRows.length > 0 ? (tableRows.map(function (row) {
62
+ prepareRow(row);
63
+ var _a = row.getRowProps(), key = _a.key, restOfRowProps = __rest(_a, ["key"]);
64
+ return ((0, react_1.jsx)(BodyRow_1.default, { key: key, ExpandedComponent: ExpandedComponent, row: row, rowProps: restOfRowProps }));
65
+ })) : ((0, react_1.jsx)(material_1.TableRow, { component: "div", css: (0, react_1.css)(templateObject_3 || (templateObject_3 = __makeTemplateObject(["\n && {\n display: flex;\n flex-direction: row;\n flex-wrap: nowrap;\n align-items: center;\n box-sizing: border-box;\n min-width: 100%;\n width: 100%;\n border-bottom: 1px solid rgba(224, 224, 224, 1);\n }\n\n &&:last-child {\n border-bottom: none;\n }\n "], ["\n && {\n display: flex;\n flex-direction: row;\n flex-wrap: nowrap;\n align-items: center;\n box-sizing: border-box;\n min-width: 100%;\n width: 100%;\n border-bottom: 1px solid rgba(224, 224, 224, 1);\n }\n\n &&:last-child {\n border-bottom: none;\n }\n "]))) },
66
+ (0, react_1.jsx)(material_1.TableCell, { component: "div", variant: "body", css: (0, react_1.css)(templateObject_4 || (templateObject_4 = __makeTemplateObject(["\n && {\n display: block;\n border-bottom: none;\n width: 100%;\n }\n "], ["\n && {\n display: block;\n border-bottom: none;\n width: 100%;\n }\n "]))) },
67
+ (0, react_1.jsx)("div", { css: (0, react_1.css)(templateObject_5 || (templateObject_5 = __makeTemplateObject(["\n text-align: center;\n "], ["\n text-align: center;\n "]))) },
68
+ (0, react_1.jsx)("span", null, noMatchLabel))))))))));
69
+ }
70
+ exports.default = TableBodyContent;
71
+ var templateObject_1, templateObject_2, templateObject_3, templateObject_4, templateObject_5;
@@ -0,0 +1,24 @@
1
+ /** @jsxRuntime classic */
2
+ /** @jsx jsx */
3
+ import { jsx } from '@emotion/react';
4
+ import { ReactNode } from 'react';
5
+ import { SimpleMap } from '../../../../types/Internal.types';
6
+ import { EnhancedHeader } from '../DataTable';
7
+ import { UseFiltersInstanceProps } from 'react-table';
8
+ interface Props<D extends object> {
9
+ title?: string;
10
+ allColumns: EnhancedHeader<D>[];
11
+ columnNameById: SimpleMap<string>;
12
+ enableFilters?: boolean;
13
+ enableGlobalSearch?: boolean;
14
+ enableHideColumns?: boolean;
15
+ hasRowsSelected: boolean;
16
+ numRowsSelected: number;
17
+ globalFilter: string;
18
+ renderActions?: () => ReactNode;
19
+ renderRowSelectActions?: () => ReactNode;
20
+ setAllFilters: UseFiltersInstanceProps<D>['setAllFilters'];
21
+ setGlobalFilter: (filterValue: any) => void | Promise<void>;
22
+ }
23
+ export default function Toolbar<D extends object>({ title, allColumns, columnNameById, enableFilters, enableGlobalSearch, enableHideColumns, hasRowsSelected, numRowsSelected, globalFilter, renderActions, renderRowSelectActions, setAllFilters, setGlobalFilter, }: Props<D>): jsx.JSX.Element;
24
+ export {};
@@ -0,0 +1,63 @@
1
+ "use strict";
2
+ var __makeTemplateObject = (this && this.__makeTemplateObject) || function (cooked, raw) {
3
+ if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; }
4
+ return cooked;
5
+ };
6
+ var __read = (this && this.__read) || function (o, n) {
7
+ var m = typeof Symbol === "function" && o[Symbol.iterator];
8
+ if (!m) return o;
9
+ var i = m.call(o), r, ar = [], e;
10
+ try {
11
+ while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
12
+ }
13
+ catch (error) { e = { error: error }; }
14
+ finally {
15
+ try {
16
+ if (r && !r.done && (m = i["return"])) m.call(i);
17
+ }
18
+ finally { if (e) throw e.error; }
19
+ }
20
+ return ar;
21
+ };
22
+ var __importDefault = (this && this.__importDefault) || function (mod) {
23
+ return (mod && mod.__esModule) ? mod : { "default": mod };
24
+ };
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ /** @jsxRuntime classic */
27
+ /** @jsx jsx */
28
+ var react_1 = require("@emotion/react");
29
+ var material_1 = require("@mui/material");
30
+ var ViewColumnTool_1 = __importDefault(require("./ViewColumnTool"));
31
+ var icons_material_1 = require("@mui/icons-material");
32
+ var react_2 = require("react");
33
+ var GlobalSearchFilter_1 = __importDefault(require("./GlobalSearchFilter"));
34
+ var FilterTool_1 = __importDefault(require("../FilterTool"));
35
+ function Toolbar(_a) {
36
+ var title = _a.title, allColumns = _a.allColumns, columnNameById = _a.columnNameById, enableFilters = _a.enableFilters, enableGlobalSearch = _a.enableGlobalSearch, enableHideColumns = _a.enableHideColumns, hasRowsSelected = _a.hasRowsSelected, numRowsSelected = _a.numRowsSelected, globalFilter = _a.globalFilter, renderActions = _a.renderActions, renderRowSelectActions = _a.renderRowSelectActions, setAllFilters = _a.setAllFilters, setGlobalFilter = _a.setGlobalFilter;
37
+ var _b = __read((0, react_2.useState)(false), 2), showSearch = _b[0], setShowSearch = _b[1];
38
+ return ((0, react_1.jsx)(material_1.Toolbar, { sx: hasRowsSelected ? { backgroundColor: function (theme) { return (0, material_1.lighten)(theme.palette.primary.light, 0.85); } } : undefined }, hasRowsSelected ? ((0, react_1.jsx)(material_1.Grid, { container: true, spacing: 2 },
39
+ (0, react_1.jsx)(material_1.Grid, { item: true, sm: 6 },
40
+ (0, react_1.jsx)(material_1.Stack, { height: "100%", direction: "row", alignContent: "center" },
41
+ (0, react_1.jsx)(material_1.Typography, { css: (0, react_1.css)(templateObject_1 || (templateObject_1 = __makeTemplateObject(["\n font-size: 1.125rem;\n margin-top: 4px;\n "], ["\n font-size: 1.125rem;\n margin-top: 4px;\n "]))) },
42
+ numRowsSelected,
43
+ " selected"))),
44
+ (0, react_1.jsx)(material_1.Grid, { item: true, sm: 6 },
45
+ (0, react_1.jsx)(material_1.Stack, { direction: "row", justifyContent: "flex-end", css: (0, react_1.css)(templateObject_2 || (templateObject_2 = __makeTemplateObject(["\n width: 100%;\n "], ["\n width: 100%;\n "]))) }, renderRowSelectActions && renderRowSelectActions())))) : ((0, react_1.jsx)(material_1.Grid, { container: true, spacing: 2 },
46
+ (0, react_1.jsx)(material_1.Grid, { item: true, sm: 6 },
47
+ (0, react_1.jsx)(material_1.Stack, { direction: "row" }, enableGlobalSearch && showSearch ? ((0, react_1.jsx)(GlobalSearchFilter_1.default, { globalFilter: globalFilter, setGlobalFilter: setGlobalFilter, setShowSearch: setShowSearch })) : ((0, react_1.jsx)(material_1.Typography, { css: (0, react_1.css)(templateObject_3 || (templateObject_3 = __makeTemplateObject(["\n font-size: 1.125rem;\n margin-top: 6px;\n "], ["\n font-size: 1.125rem;\n margin-top: 6px;\n "]))) }, title || '')))),
48
+ (0, react_1.jsx)(material_1.Grid, { item: true, sm: 6 },
49
+ (0, react_1.jsx)(material_1.Stack, { direction: "row", justifyContent: "flex-end", css: (0, react_1.css)(templateObject_4 || (templateObject_4 = __makeTemplateObject(["\n width: 100%;\n "], ["\n width: 100%;\n "]))) },
50
+ enableGlobalSearch && ((0, react_1.jsx)(material_1.Tooltip, { title: "Search" },
51
+ (0, react_1.jsx)(material_1.IconButton, { onClick: function () {
52
+ if (showSearch) {
53
+ setGlobalFilter(null);
54
+ }
55
+ setShowSearch(!showSearch);
56
+ } },
57
+ (0, react_1.jsx)(icons_material_1.Search, null)))),
58
+ enableHideColumns && (0, react_1.jsx)(ViewColumnTool_1.default, { allColumns: allColumns, columnNameById: columnNameById }),
59
+ enableFilters && ((0, react_1.jsx)(FilterTool_1.default, { allColumns: allColumns, columnNameById: columnNameById, setAllFilters: setAllFilters })),
60
+ renderActions && renderActions()))))));
61
+ }
62
+ exports.default = Toolbar;
63
+ var templateObject_1, templateObject_2, templateObject_3, templateObject_4;
@@ -0,0 +1,11 @@
1
+ /** @jsxRuntime classic */
2
+ /** @jsx jsx */
3
+ import { jsx } from '@emotion/react';
4
+ import { ColumnInstance } from 'react-table';
5
+ import { SimpleMap } from '../../../../types/Internal.types';
6
+ interface Props<D extends object> {
7
+ allColumns: ColumnInstance<D>[];
8
+ columnNameById: SimpleMap<string>;
9
+ }
10
+ export default function ViewColumnTool<D extends object>({ allColumns, columnNameById }: Props<D>): jsx.JSX.Element;
11
+ export {};
@@ -0,0 +1,76 @@
1
+ "use strict";
2
+ var __makeTemplateObject = (this && this.__makeTemplateObject) || function (cooked, raw) {
3
+ if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; }
4
+ return cooked;
5
+ };
6
+ var __assign = (this && this.__assign) || function () {
7
+ __assign = Object.assign || function(t) {
8
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
9
+ s = arguments[i];
10
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
11
+ t[p] = s[p];
12
+ }
13
+ return t;
14
+ };
15
+ return __assign.apply(this, arguments);
16
+ };
17
+ var __read = (this && this.__read) || function (o, n) {
18
+ var m = typeof Symbol === "function" && o[Symbol.iterator];
19
+ if (!m) return o;
20
+ var i = m.call(o), r, ar = [], e;
21
+ try {
22
+ while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
23
+ }
24
+ catch (error) { e = { error: error }; }
25
+ finally {
26
+ try {
27
+ if (r && !r.done && (m = i["return"])) m.call(i);
28
+ }
29
+ finally { if (e) throw e.error; }
30
+ }
31
+ return ar;
32
+ };
33
+ var __importDefault = (this && this.__importDefault) || function (mod) {
34
+ return (mod && mod.__esModule) ? mod : { "default": mod };
35
+ };
36
+ Object.defineProperty(exports, "__esModule", { value: true });
37
+ /** @jsxRuntime classic */
38
+ /** @jsx jsx */
39
+ var react_1 = require("@emotion/react");
40
+ var react_2 = require("react");
41
+ var material_1 = require("@mui/material");
42
+ var icons_material_1 = require("@mui/icons-material");
43
+ var nanoid_1 = require("nanoid");
44
+ var IndeterminateCheckbox_1 = __importDefault(require("./IndeterminateCheckbox"));
45
+ function ViewColumnTool(_a) {
46
+ var allColumns = _a.allColumns, columnNameById = _a.columnNameById;
47
+ var id = (0, react_2.useMemo)(function () { return (0, nanoid_1.nanoid)(); }, []);
48
+ var _b = __read((0, react_2.useState)(null), 2), anchorEl = _b[0], setAnchorEl = _b[1];
49
+ var open = !!anchorEl;
50
+ function handleClick(evt) {
51
+ setAnchorEl(evt.currentTarget);
52
+ }
53
+ function handleClose() {
54
+ setAnchorEl(null);
55
+ }
56
+ return ((0, react_1.jsx)(react_2.Fragment, null,
57
+ (0, react_1.jsx)(material_1.Tooltip, { title: "Show Columns" },
58
+ (0, react_1.jsx)(material_1.IconButton, { "aria-describedby": id, onClick: handleClick },
59
+ (0, react_1.jsx)(icons_material_1.ViewColumn, null))),
60
+ (0, react_1.jsx)(material_1.Popover, { id: id, open: open, anchorEl: anchorEl, onClose: handleClose, anchorOrigin: { vertical: 'bottom', horizontal: 'center' } },
61
+ (0, react_1.jsx)("div", { css: (0, react_1.css)(templateObject_1 || (templateObject_1 = __makeTemplateObject(["\n padding: 0.5rem;\n "], ["\n padding: 0.5rem;\n "]))) },
62
+ (0, react_1.jsx)("div", { css: (0, react_1.css)(templateObject_2 || (templateObject_2 = __makeTemplateObject(["\n display: flex;\n flex-direction: row;\n justify-content: flex-start;\n align-items: center;\n "], ["\n display: flex;\n flex-direction: row;\n justify-content: flex-start;\n align-items: center;\n "]))) },
63
+ (0, react_1.jsx)(material_1.Typography, { css: (0, react_1.css)(templateObject_3 || (templateObject_3 = __makeTemplateObject(["\n font-size: 14px;\n color: rgba(0, 0, 0, 0.54);\n "], ["\n font-size: 14px;\n color: rgba(0, 0, 0, 0.54);\n "]))) }, "Show Columns"),
64
+ (0, react_1.jsx)(material_1.Tooltip, { title: "Close" },
65
+ (0, react_1.jsx)(material_1.IconButton, { onClick: handleClose },
66
+ (0, react_1.jsx)(icons_material_1.Close, null)))),
67
+ (0, react_1.jsx)("div", { css: (0, react_1.css)(templateObject_4 || (templateObject_4 = __makeTemplateObject(["\n display: flex;\n flex-direction: column;\n justify-content: flex-start;\n align-items: flex-start;\n "], ["\n display: flex;\n flex-direction: column;\n justify-content: flex-start;\n align-items: flex-start;\n "]))) }, allColumns
68
+ .filter(function (column) { return column.id !== 'custom'; })
69
+ .map(function (column) {
70
+ return ((0, react_1.jsx)(material_1.FormControlLabel, { key: column.id, label: columnNameById[column.id],
71
+ // @ts-ignore
72
+ control: (0, react_1.jsx)(IndeterminateCheckbox_1.default, __assign({}, column.getToggleHiddenProps())) }));
73
+ }))))));
74
+ }
75
+ exports.default = ViewColumnTool;
76
+ var templateObject_1, templateObject_2, templateObject_3, templateObject_4;
@@ -0,0 +1,25 @@
1
+ /// <reference types="react" />
2
+ import short from 'short-uuid';
3
+ import { EnhancedRow } from './DataTable';
4
+ /**
5
+ * This custom hook is designed to replace the `<CellMeasurer />` component in `react-virtualized`
6
+ * in `react-window`
7
+ *
8
+ * This hook returns props to be given to the `<VariableSizeList />` component in `react-window`
9
+ *
10
+ * `items` are react elements
11
+ */
12
+ export default function useCellMeasurer({ items, renderItem, }: {
13
+ items: any[];
14
+ renderItem: (item: EnhancedRow<any>) => JSX.Element;
15
+ }): {
16
+ innerRef: import("react").RefObject<HTMLDivElement>;
17
+ itemSize: (index: any) => number;
18
+ itemCount: number;
19
+ key: short.SUUID;
20
+ style: {
21
+ visibility?: undefined;
22
+ } | {
23
+ visibility: string;
24
+ };
25
+ };