react-science 0.22.2 → 0.23.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/components/forms/Checkbox.js +62 -0
- package/lib/components/forms/Select.js +114 -0
- package/lib/components/forms/index.js +1 -0
- package/lib/components/table/Table.js +6 -6
- package/lib-esm/components/forms/Checkbox.d.ts +11 -0
- package/lib-esm/components/forms/Checkbox.d.ts.map +1 -0
- package/lib-esm/components/forms/Checkbox.js +36 -0
- package/lib-esm/components/forms/Checkbox.js.map +1 -0
- package/lib-esm/components/forms/Select.d.ts +21 -0
- package/lib-esm/components/forms/Select.d.ts.map +1 -0
- package/lib-esm/components/forms/Select.js +85 -0
- package/lib-esm/components/forms/Select.js.map +1 -0
- package/lib-esm/components/forms/index.d.ts +1 -0
- package/lib-esm/components/forms/index.d.ts.map +1 -1
- package/lib-esm/components/forms/index.js +1 -0
- package/lib-esm/components/forms/index.js.map +1 -1
- package/lib-esm/components/table/Table.d.ts +4 -3
- package/lib-esm/components/table/Table.d.ts.map +1 -1
- package/lib-esm/components/table/Table.js +6 -6
- package/lib-esm/components/table/Table.js.map +1 -1
- package/package.json +3 -1
- package/src/components/forms/Checkbox.tsx +78 -0
- package/src/components/forms/Select.tsx +185 -0
- package/src/components/forms/index.ts +1 -0
- package/src/components/table/Table.tsx +14 -6
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
+
exports.Checkbox = void 0;
|
|
27
|
+
const jsx_runtime_1 = require("@emotion/react/jsx-runtime");
|
|
28
|
+
/** @jsxImportSource @emotion/react */
|
|
29
|
+
const react_1 = require("@emotion/react");
|
|
30
|
+
const RadixCheckbox = __importStar(require("@radix-ui/react-checkbox"));
|
|
31
|
+
const index_1 = require("react-icons/rx/index");
|
|
32
|
+
const enabledColor = '#1677ff';
|
|
33
|
+
const disabledColor = '#b8b8b8';
|
|
34
|
+
function Checkbox(props) {
|
|
35
|
+
const { checked = 'indeterminate', disabled = false, label, onChange, } = props;
|
|
36
|
+
return ((0, jsx_runtime_1.jsxs)("label", { style: {
|
|
37
|
+
display: 'flex',
|
|
38
|
+
alignItems: 'center',
|
|
39
|
+
fontSize: '1.125em',
|
|
40
|
+
}, children: [(0, jsx_runtime_1.jsx)(RadixCheckbox.Root, { checked: checked, onCheckedChange: onChange, disabled: disabled, css: (0, react_1.css)({
|
|
41
|
+
width: '16px',
|
|
42
|
+
height: '16px',
|
|
43
|
+
backgroundColor: disabled
|
|
44
|
+
? 'rgba(0, 0, 0, 0.04)'
|
|
45
|
+
: checked
|
|
46
|
+
? enabledColor
|
|
47
|
+
: 'white',
|
|
48
|
+
borderWidth: '1px',
|
|
49
|
+
borderColor: checked && !disabled ? enabledColor : disabledColor,
|
|
50
|
+
borderRadius: '4px',
|
|
51
|
+
display: 'flex',
|
|
52
|
+
alignItems: 'center',
|
|
53
|
+
justifyContent: 'center',
|
|
54
|
+
cursor: disabled ? 'not-allowed' : 'pointer',
|
|
55
|
+
}), children: (0, jsx_runtime_1.jsx)(RadixCheckbox.Indicator, { css: (0, react_1.css)({
|
|
56
|
+
color: disabled ? disabledColor : 'white',
|
|
57
|
+
}), children: checked === true ? ((0, jsx_runtime_1.jsx)(index_1.RxCheck, {})) : checked === 'indeterminate' ? ((0, jsx_runtime_1.jsx)(index_1.RxMinus, {})) : null }) }), (0, jsx_runtime_1.jsx)("span", { style: {
|
|
58
|
+
paddingInline: '8px',
|
|
59
|
+
lineHeight: '16px',
|
|
60
|
+
}, children: label })] }));
|
|
61
|
+
}
|
|
62
|
+
exports.Checkbox = Checkbox;
|
|
@@ -0,0 +1,114 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
26
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
27
|
+
};
|
|
28
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
29
|
+
exports.Select = void 0;
|
|
30
|
+
const jsx_runtime_1 = require("@emotion/react/jsx-runtime");
|
|
31
|
+
/** @jsxImportSource @emotion/react */
|
|
32
|
+
const styled_1 = __importDefault(require("@emotion/styled"));
|
|
33
|
+
const RadixSelect = __importStar(require("@radix-ui/react-select"));
|
|
34
|
+
const react_select_1 = require("@radix-ui/react-select");
|
|
35
|
+
const react_1 = require("react");
|
|
36
|
+
const fa_1 = require("react-icons/fa");
|
|
37
|
+
const Portal_1 = require("../root-layout/Portal");
|
|
38
|
+
const SelectRoot = styled_1.default.div `
|
|
39
|
+
display: inline-flex;
|
|
40
|
+
align-items: center;
|
|
41
|
+
justify-content: space-between;
|
|
42
|
+
background-color: #ffffff;
|
|
43
|
+
font-size: 1.125em;
|
|
44
|
+
width: 120px;
|
|
45
|
+
`;
|
|
46
|
+
const SelectTrigger = (0, styled_1.default)(RadixSelect.Trigger) `
|
|
47
|
+
width: 100%;
|
|
48
|
+
display: flex;
|
|
49
|
+
align-items: center;
|
|
50
|
+
justify-content: space-between;
|
|
51
|
+
border-radius: 4px;
|
|
52
|
+
border: 1px solid rgba(0, 0, 0, 0.15);
|
|
53
|
+
padding: 4px 11px;
|
|
54
|
+
user-select: none;
|
|
55
|
+
font-size: 1.125em;
|
|
56
|
+
line-height: 1.125em;
|
|
57
|
+
|
|
58
|
+
&[data-disabled] {
|
|
59
|
+
color: rgba(0, 0, 0, 0.5);
|
|
60
|
+
background-color: #f5f5f5;
|
|
61
|
+
}
|
|
62
|
+
`;
|
|
63
|
+
const SelectContent = (0, styled_1.default)(RadixSelect.Content) `
|
|
64
|
+
width: var(--radix-select-trigger-width);
|
|
65
|
+
max-height: var(--radix-select-content-available-height);
|
|
66
|
+
`;
|
|
67
|
+
const SelectViewport = (0, styled_1.default)(RadixSelect.Viewport) `
|
|
68
|
+
width: var(--radix-select-trigger-width);
|
|
69
|
+
border-radius: 4px;
|
|
70
|
+
box-sizing: border-box;
|
|
71
|
+
border: 1px solid rgba(0, 0, 0, 0.15);
|
|
72
|
+
background-color: white;
|
|
73
|
+
padding: 5px;
|
|
74
|
+
`;
|
|
75
|
+
const SelectItem = (0, styled_1.default)(RadixSelect.Item) `
|
|
76
|
+
user-select: none;
|
|
77
|
+
font-size: 1.125em;
|
|
78
|
+
padding: 4px 11px;
|
|
79
|
+
width: 100%;
|
|
80
|
+
display: flex;
|
|
81
|
+
align-items: center;
|
|
82
|
+
justify-content: space-between;
|
|
83
|
+
|
|
84
|
+
&:hover {
|
|
85
|
+
background-color: #e6f4ff;
|
|
86
|
+
}
|
|
87
|
+
&[data-disabled] {
|
|
88
|
+
color: rgba(0, 0, 0, 0.5);
|
|
89
|
+
}
|
|
90
|
+
`;
|
|
91
|
+
const SelectLabel = (0, styled_1.default)(RadixSelect.Label) `
|
|
92
|
+
color: rgba(0, 0, 0, 0.5);
|
|
93
|
+
font-size: 1em;
|
|
94
|
+
padding: 4px 11px;
|
|
95
|
+
margin-top: 8px;
|
|
96
|
+
`;
|
|
97
|
+
const SelectItemIndicator = (0, styled_1.default)(RadixSelect.ItemIndicator) `
|
|
98
|
+
right: 0;
|
|
99
|
+
width: 25px;
|
|
100
|
+
display: inline-flex;
|
|
101
|
+
align-items: center;
|
|
102
|
+
justify-content: center;
|
|
103
|
+
`;
|
|
104
|
+
const SelectSeparator = (0, styled_1.default)(RadixSelect.Separator) `
|
|
105
|
+
height: 1px;
|
|
106
|
+
width: 100%;
|
|
107
|
+
background-color: rgba(0, 0, 0, 0.15);
|
|
108
|
+
margin: 5px 0;
|
|
109
|
+
`;
|
|
110
|
+
function Select(props) {
|
|
111
|
+
const { placeholder, value, onSelect, options, disabled = false, style, } = props;
|
|
112
|
+
return ((0, jsx_runtime_1.jsx)(SelectRoot, { style: { ...style }, children: (0, jsx_runtime_1.jsxs)(RadixSelect.Root, { value: value, onValueChange: onSelect, disabled: disabled, children: [(0, jsx_runtime_1.jsxs)(SelectTrigger, { children: [(0, jsx_runtime_1.jsx)(RadixSelect.Value, { placeholder: placeholder }), (0, jsx_runtime_1.jsx)(RadixSelect.Icon, { asChild: true, children: (0, jsx_runtime_1.jsx)(fa_1.FaChevronDown, {}) })] }), (0, jsx_runtime_1.jsx)(Portal_1.Portal, { children: (0, jsx_runtime_1.jsxs)(SelectContent, { position: "popper", children: [(0, jsx_runtime_1.jsx)(RadixSelect.ScrollUpButton, { children: (0, jsx_runtime_1.jsx)(fa_1.FaChevronUp, {}) }), (0, jsx_runtime_1.jsx)(SelectViewport, { children: options.map((group, groupIndex) => ((0, jsx_runtime_1.jsxs)(react_1.Fragment, { children: [group.map((optionOrCategory, optionOrCategoryIndex) => 'options' in optionOrCategory ? ((0, jsx_runtime_1.jsxs)(react_select_1.SelectGroup, { children: [(0, jsx_runtime_1.jsx)(SelectLabel, { children: optionOrCategory.label }), optionOrCategory.options.map((option) => ((0, jsx_runtime_1.jsxs)(SelectItem, { value: option.value, disabled: option.disabled, children: [(0, jsx_runtime_1.jsx)(RadixSelect.ItemText, { children: option.label }), (0, jsx_runtime_1.jsx)(SelectItemIndicator, { children: (0, jsx_runtime_1.jsx)(fa_1.FaCheck, {}) })] }, option.value)))] }, optionOrCategoryIndex)) : ((0, jsx_runtime_1.jsxs)(SelectItem, { value: optionOrCategory.value, disabled: optionOrCategory.disabled, children: [(0, jsx_runtime_1.jsx)(RadixSelect.ItemText, { children: optionOrCategory.label }), (0, jsx_runtime_1.jsx)(SelectItemIndicator, { children: (0, jsx_runtime_1.jsx)(fa_1.FaCheck, {}) })] }, optionOrCategory.value))), groupIndex < options.length - 1 && (0, jsx_runtime_1.jsx)(SelectSeparator, {})] }, groupIndex))) }), (0, jsx_runtime_1.jsx)(RadixSelect.ScrollDownButton, {}), (0, jsx_runtime_1.jsx)(RadixSelect.Arrow, {})] }) })] }) }));
|
|
113
|
+
}
|
|
114
|
+
exports.Select = Select;
|
|
@@ -15,4 +15,5 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
17
|
__exportStar(require("./Input"), exports);
|
|
18
|
+
__exportStar(require("./Checkbox"), exports);
|
|
18
19
|
__exportStar(require("./context"), exports);
|
|
@@ -44,10 +44,10 @@ function splitChildren(children) {
|
|
|
44
44
|
return { Rows, Header };
|
|
45
45
|
}
|
|
46
46
|
function Table(props) {
|
|
47
|
-
const { border = true, children } = props;
|
|
47
|
+
const { border = true, style = {}, children } = props;
|
|
48
48
|
const { Header, Rows } = splitChildren(children);
|
|
49
49
|
const tableContextValue = (0, react_2.useMemo)(() => ({ border }), [border]);
|
|
50
|
-
return ((0, jsx_runtime_1.jsx)(TableContext.Provider, { value: tableContextValue, children: (0, jsx_runtime_1.jsxs)("table", { children: [Header, (0, jsx_runtime_1.jsx)("tbody", { children: Rows })] }) }));
|
|
50
|
+
return ((0, jsx_runtime_1.jsx)(TableContext.Provider, { value: tableContextValue, children: (0, jsx_runtime_1.jsxs)("table", { style: style, children: [Header, (0, jsx_runtime_1.jsx)("tbody", { children: Rows })] }) }));
|
|
51
51
|
}
|
|
52
52
|
exports.Table = Table;
|
|
53
53
|
function useRowChildren(children) {
|
|
@@ -79,11 +79,11 @@ function useRowChildren(children) {
|
|
|
79
79
|
}
|
|
80
80
|
return { cells };
|
|
81
81
|
}
|
|
82
|
-
function Row({ children, border = false }) {
|
|
82
|
+
function Row({ children, style = {}, border = false }) {
|
|
83
83
|
const { cells } = useRowChildren(children);
|
|
84
|
-
return (0, jsx_runtime_1.jsx)("tr", { style: { border: border ? '1px solid black' : '' }, children: cells });
|
|
84
|
+
return ((0, jsx_runtime_1.jsx)("tr", { style: { border: border ? '1px solid black' : '', ...style }, children: cells }));
|
|
85
85
|
}
|
|
86
86
|
Table.Row = Row;
|
|
87
|
-
Table.Header = ({ children, border = false }) => {
|
|
88
|
-
return ((0, jsx_runtime_1.jsx)("thead", { children: (0, jsx_runtime_1.jsx)(Table.Row, { border: border, children: children }) }));
|
|
87
|
+
Table.Header = ({ children, style, border = false }) => {
|
|
88
|
+
return ((0, jsx_runtime_1.jsx)("thead", { children: (0, jsx_runtime_1.jsx)(Table.Row, { border: border, style: style, children: children }) }));
|
|
89
89
|
};
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { ReactNode } from 'react';
|
|
2
|
+
export type CheckedState = boolean | 'indeterminate';
|
|
3
|
+
interface CheckboxProps {
|
|
4
|
+
checked?: CheckedState;
|
|
5
|
+
disabled?: boolean;
|
|
6
|
+
label?: ReactNode;
|
|
7
|
+
onChange?: (checked: CheckedState) => void;
|
|
8
|
+
}
|
|
9
|
+
export declare function Checkbox(props: CheckboxProps): import("@emotion/react/jsx-runtime").JSX.Element;
|
|
10
|
+
export {};
|
|
11
|
+
//# sourceMappingURL=Checkbox.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Checkbox.d.ts","sourceRoot":"","sources":["../../../src/components/forms/Checkbox.tsx"],"names":[],"mappings":"AAGA,OAAO,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAGlC,MAAM,MAAM,YAAY,GAAG,OAAO,GAAG,eAAe,CAAC;AAErD,UAAU,aAAa;IACrB,OAAO,CAAC,EAAE,YAAY,CAAC;IACvB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,KAAK,CAAC,EAAE,SAAS,CAAC;IAClB,QAAQ,CAAC,EAAE,CAAC,OAAO,EAAE,YAAY,KAAK,IAAI,CAAC;CAC5C;AAKD,wBAAgB,QAAQ,CAAC,KAAK,EAAE,aAAa,oDA2D5C"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "@emotion/react/jsx-runtime";
|
|
2
|
+
/** @jsxImportSource @emotion/react */
|
|
3
|
+
import { css } from '@emotion/react';
|
|
4
|
+
import * as RadixCheckbox from '@radix-ui/react-checkbox';
|
|
5
|
+
import { RxCheck, RxMinus } from 'react-icons/rx/index';
|
|
6
|
+
const enabledColor = '#1677ff';
|
|
7
|
+
const disabledColor = '#b8b8b8';
|
|
8
|
+
export function Checkbox(props) {
|
|
9
|
+
const { checked = 'indeterminate', disabled = false, label, onChange, } = props;
|
|
10
|
+
return (_jsxs("label", { style: {
|
|
11
|
+
display: 'flex',
|
|
12
|
+
alignItems: 'center',
|
|
13
|
+
fontSize: '1.125em',
|
|
14
|
+
}, children: [_jsx(RadixCheckbox.Root, { checked: checked, onCheckedChange: onChange, disabled: disabled, css: css({
|
|
15
|
+
width: '16px',
|
|
16
|
+
height: '16px',
|
|
17
|
+
backgroundColor: disabled
|
|
18
|
+
? 'rgba(0, 0, 0, 0.04)'
|
|
19
|
+
: checked
|
|
20
|
+
? enabledColor
|
|
21
|
+
: 'white',
|
|
22
|
+
borderWidth: '1px',
|
|
23
|
+
borderColor: checked && !disabled ? enabledColor : disabledColor,
|
|
24
|
+
borderRadius: '4px',
|
|
25
|
+
display: 'flex',
|
|
26
|
+
alignItems: 'center',
|
|
27
|
+
justifyContent: 'center',
|
|
28
|
+
cursor: disabled ? 'not-allowed' : 'pointer',
|
|
29
|
+
}), children: _jsx(RadixCheckbox.Indicator, { css: css({
|
|
30
|
+
color: disabled ? disabledColor : 'white',
|
|
31
|
+
}), children: checked === true ? (_jsx(RxCheck, {})) : checked === 'indeterminate' ? (_jsx(RxMinus, {})) : null }) }), _jsx("span", { style: {
|
|
32
|
+
paddingInline: '8px',
|
|
33
|
+
lineHeight: '16px',
|
|
34
|
+
}, children: label })] }));
|
|
35
|
+
}
|
|
36
|
+
//# sourceMappingURL=Checkbox.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Checkbox.js","sourceRoot":"","sources":["../../../src/components/forms/Checkbox.tsx"],"names":[],"mappings":";AAAA,sCAAsC;AACtC,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACrC,OAAO,KAAK,aAAa,MAAM,0BAA0B,CAAC;AAE1D,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAWxD,MAAM,YAAY,GAAG,SAAS,CAAC;AAC/B,MAAM,aAAa,GAAG,SAAS,CAAC;AAEhC,MAAM,UAAU,QAAQ,CAAC,KAAoB;IAC3C,MAAM,EACJ,OAAO,GAAG,eAAe,EACzB,QAAQ,GAAG,KAAK,EAChB,KAAK,EACL,QAAQ,GACT,GAAG,KAAK,CAAC;IAEV,OAAO,CACL,iBACE,KAAK,EAAE;YACL,OAAO,EAAE,MAAM;YACf,UAAU,EAAE,QAAQ;YACpB,QAAQ,EAAE,SAAS;SACpB,aAED,KAAC,aAAa,CAAC,IAAI,IACjB,OAAO,EAAE,OAAO,EAChB,eAAe,EAAE,QAAQ,EACzB,QAAQ,EAAE,QAAQ,EAClB,GAAG,EAAE,GAAG,CAAC;oBACP,KAAK,EAAE,MAAM;oBACb,MAAM,EAAE,MAAM;oBACd,eAAe,EAAE,QAAQ;wBACvB,CAAC,CAAC,qBAAqB;wBACvB,CAAC,CAAC,OAAO;4BACT,CAAC,CAAC,YAAY;4BACd,CAAC,CAAC,OAAO;oBACX,WAAW,EAAE,KAAK;oBAClB,WAAW,EAAE,OAAO,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,aAAa;oBAChE,YAAY,EAAE,KAAK;oBACnB,OAAO,EAAE,MAAM;oBACf,UAAU,EAAE,QAAQ;oBACpB,cAAc,EAAE,QAAQ;oBACxB,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,SAAS;iBAC7C,CAAC,YAEF,KAAC,aAAa,CAAC,SAAS,IACtB,GAAG,EAAE,GAAG,CAAC;wBACP,KAAK,EAAE,QAAQ,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,OAAO;qBAC1C,CAAC,YAED,OAAO,KAAK,IAAI,CAAC,CAAC,CAAC,CAClB,KAAC,OAAO,KAAG,CACZ,CAAC,CAAC,CAAC,OAAO,KAAK,eAAe,CAAC,CAAC,CAAC,CAChC,KAAC,OAAO,KAAG,CACZ,CAAC,CAAC,CAAC,IAAI,GACgB,GACP,EACrB,eACE,KAAK,EAAE;oBACL,aAAa,EAAE,KAAK;oBACpB,UAAU,EAAE,MAAM;iBACnB,YAEA,KAAK,GACD,IACD,CACT,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { ReactNode, CSSProperties } from 'react';
|
|
2
|
+
interface Category {
|
|
3
|
+
label: ReactNode;
|
|
4
|
+
options: Option[];
|
|
5
|
+
}
|
|
6
|
+
interface Option {
|
|
7
|
+
label: ReactNode;
|
|
8
|
+
value: string;
|
|
9
|
+
disabled?: boolean;
|
|
10
|
+
}
|
|
11
|
+
export interface SelectProps {
|
|
12
|
+
placeholder?: string;
|
|
13
|
+
value?: string;
|
|
14
|
+
onSelect?: (value: string) => void;
|
|
15
|
+
options: (Option[] | Category[])[];
|
|
16
|
+
disabled?: boolean;
|
|
17
|
+
style?: CSSProperties;
|
|
18
|
+
}
|
|
19
|
+
export declare function Select(props: SelectProps): import("@emotion/react/jsx-runtime").JSX.Element;
|
|
20
|
+
export {};
|
|
21
|
+
//# sourceMappingURL=Select.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Select.d.ts","sourceRoot":"","sources":["../../../src/components/forms/Select.tsx"],"names":[],"mappings":"AAIA,OAAO,EAAY,SAAS,EAAE,aAAa,EAAE,MAAM,OAAO,CAAC;AAK3D,UAAU,QAAQ;IAChB,KAAK,EAAE,SAAS,CAAC;IACjB,OAAO,EAAE,MAAM,EAAE,CAAC;CACnB;AACD,UAAU,MAAM;IACd,KAAK,EAAE,SAAS,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAED,MAAM,WAAW,WAAW;IAC1B,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACnC,OAAO,EAAE,CAAC,MAAM,EAAE,GAAG,QAAQ,EAAE,CAAC,EAAE,CAAC;IACnC,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,KAAK,CAAC,EAAE,aAAa,CAAC;CACvB;AAkFD,wBAAgB,MAAM,CAAC,KAAK,EAAE,WAAW,oDA4ExC"}
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "@emotion/react/jsx-runtime";
|
|
2
|
+
/** @jsxImportSource @emotion/react */
|
|
3
|
+
import styled from '@emotion/styled';
|
|
4
|
+
import * as RadixSelect from '@radix-ui/react-select';
|
|
5
|
+
import { SelectGroup } from '@radix-ui/react-select';
|
|
6
|
+
import { Fragment } from 'react';
|
|
7
|
+
import { FaCheck, FaChevronDown, FaChevronUp } from 'react-icons/fa';
|
|
8
|
+
import { Portal } from '../root-layout/Portal';
|
|
9
|
+
const SelectRoot = styled.div `
|
|
10
|
+
display: inline-flex;
|
|
11
|
+
align-items: center;
|
|
12
|
+
justify-content: space-between;
|
|
13
|
+
background-color: #ffffff;
|
|
14
|
+
font-size: 1.125em;
|
|
15
|
+
width: 120px;
|
|
16
|
+
`;
|
|
17
|
+
const SelectTrigger = styled(RadixSelect.Trigger) `
|
|
18
|
+
width: 100%;
|
|
19
|
+
display: flex;
|
|
20
|
+
align-items: center;
|
|
21
|
+
justify-content: space-between;
|
|
22
|
+
border-radius: 4px;
|
|
23
|
+
border: 1px solid rgba(0, 0, 0, 0.15);
|
|
24
|
+
padding: 4px 11px;
|
|
25
|
+
user-select: none;
|
|
26
|
+
font-size: 1.125em;
|
|
27
|
+
line-height: 1.125em;
|
|
28
|
+
|
|
29
|
+
&[data-disabled] {
|
|
30
|
+
color: rgba(0, 0, 0, 0.5);
|
|
31
|
+
background-color: #f5f5f5;
|
|
32
|
+
}
|
|
33
|
+
`;
|
|
34
|
+
const SelectContent = styled(RadixSelect.Content) `
|
|
35
|
+
width: var(--radix-select-trigger-width);
|
|
36
|
+
max-height: var(--radix-select-content-available-height);
|
|
37
|
+
`;
|
|
38
|
+
const SelectViewport = styled(RadixSelect.Viewport) `
|
|
39
|
+
width: var(--radix-select-trigger-width);
|
|
40
|
+
border-radius: 4px;
|
|
41
|
+
box-sizing: border-box;
|
|
42
|
+
border: 1px solid rgba(0, 0, 0, 0.15);
|
|
43
|
+
background-color: white;
|
|
44
|
+
padding: 5px;
|
|
45
|
+
`;
|
|
46
|
+
const SelectItem = styled(RadixSelect.Item) `
|
|
47
|
+
user-select: none;
|
|
48
|
+
font-size: 1.125em;
|
|
49
|
+
padding: 4px 11px;
|
|
50
|
+
width: 100%;
|
|
51
|
+
display: flex;
|
|
52
|
+
align-items: center;
|
|
53
|
+
justify-content: space-between;
|
|
54
|
+
|
|
55
|
+
&:hover {
|
|
56
|
+
background-color: #e6f4ff;
|
|
57
|
+
}
|
|
58
|
+
&[data-disabled] {
|
|
59
|
+
color: rgba(0, 0, 0, 0.5);
|
|
60
|
+
}
|
|
61
|
+
`;
|
|
62
|
+
const SelectLabel = styled(RadixSelect.Label) `
|
|
63
|
+
color: rgba(0, 0, 0, 0.5);
|
|
64
|
+
font-size: 1em;
|
|
65
|
+
padding: 4px 11px;
|
|
66
|
+
margin-top: 8px;
|
|
67
|
+
`;
|
|
68
|
+
const SelectItemIndicator = styled(RadixSelect.ItemIndicator) `
|
|
69
|
+
right: 0;
|
|
70
|
+
width: 25px;
|
|
71
|
+
display: inline-flex;
|
|
72
|
+
align-items: center;
|
|
73
|
+
justify-content: center;
|
|
74
|
+
`;
|
|
75
|
+
const SelectSeparator = styled(RadixSelect.Separator) `
|
|
76
|
+
height: 1px;
|
|
77
|
+
width: 100%;
|
|
78
|
+
background-color: rgba(0, 0, 0, 0.15);
|
|
79
|
+
margin: 5px 0;
|
|
80
|
+
`;
|
|
81
|
+
export function Select(props) {
|
|
82
|
+
const { placeholder, value, onSelect, options, disabled = false, style, } = props;
|
|
83
|
+
return (_jsx(SelectRoot, { style: { ...style }, children: _jsxs(RadixSelect.Root, { value: value, onValueChange: onSelect, disabled: disabled, children: [_jsxs(SelectTrigger, { children: [_jsx(RadixSelect.Value, { placeholder: placeholder }), _jsx(RadixSelect.Icon, { asChild: true, children: _jsx(FaChevronDown, {}) })] }), _jsx(Portal, { children: _jsxs(SelectContent, { position: "popper", children: [_jsx(RadixSelect.ScrollUpButton, { children: _jsx(FaChevronUp, {}) }), _jsx(SelectViewport, { children: options.map((group, groupIndex) => (_jsxs(Fragment, { children: [group.map((optionOrCategory, optionOrCategoryIndex) => 'options' in optionOrCategory ? (_jsxs(SelectGroup, { children: [_jsx(SelectLabel, { children: optionOrCategory.label }), optionOrCategory.options.map((option) => (_jsxs(SelectItem, { value: option.value, disabled: option.disabled, children: [_jsx(RadixSelect.ItemText, { children: option.label }), _jsx(SelectItemIndicator, { children: _jsx(FaCheck, {}) })] }, option.value)))] }, optionOrCategoryIndex)) : (_jsxs(SelectItem, { value: optionOrCategory.value, disabled: optionOrCategory.disabled, children: [_jsx(RadixSelect.ItemText, { children: optionOrCategory.label }), _jsx(SelectItemIndicator, { children: _jsx(FaCheck, {}) })] }, optionOrCategory.value))), groupIndex < options.length - 1 && _jsx(SelectSeparator, {})] }, groupIndex))) }), _jsx(RadixSelect.ScrollDownButton, {}), _jsx(RadixSelect.Arrow, {})] }) })] }) }));
|
|
84
|
+
}
|
|
85
|
+
//# sourceMappingURL=Select.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Select.js","sourceRoot":"","sources":["../../../src/components/forms/Select.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/forms/index.ts"],"names":[],"mappings":"AAAA,cAAc,SAAS,CAAC;AACxB,cAAc,WAAW,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/forms/index.ts"],"names":[],"mappings":"AAAA,cAAc,SAAS,CAAC;AACxB,cAAc,YAAY,CAAC;AAC3B,cAAc,WAAW,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/forms/index.ts"],"names":[],"mappings":"AAAA,cAAc,SAAS,CAAC;AACxB,cAAc,WAAW,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/forms/index.ts"],"names":[],"mappings":"AAAA,cAAc,SAAS,CAAC;AACxB,cAAc,YAAY,CAAC;AAC3B,cAAc,WAAW,CAAC"}
|
|
@@ -1,11 +1,12 @@
|
|
|
1
|
-
import { ReactNode } from 'react';
|
|
1
|
+
import { CSSProperties, ReactNode } from 'react';
|
|
2
2
|
export interface TableProps {
|
|
3
3
|
children?: ReactNode;
|
|
4
4
|
border?: boolean;
|
|
5
|
+
style?: CSSProperties;
|
|
5
6
|
}
|
|
6
7
|
export declare function Table(props: TableProps): import("@emotion/react/jsx-runtime").JSX.Element;
|
|
7
8
|
export declare namespace Table {
|
|
8
|
-
var Row: ({ children, border }: TableProps) => import("@emotion/react/jsx-runtime").JSX.Element;
|
|
9
|
-
var Header: ({ children, border }: TableProps) => import("@emotion/react/jsx-runtime").JSX.Element;
|
|
9
|
+
var Row: ({ children, style, border }: TableProps) => import("@emotion/react/jsx-runtime").JSX.Element;
|
|
10
|
+
var Header: ({ children, style, border }: TableProps) => import("@emotion/react/jsx-runtime").JSX.Element;
|
|
10
11
|
}
|
|
11
12
|
//# sourceMappingURL=Table.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Table.d.ts","sourceRoot":"","sources":["../../../src/components/table/Table.tsx"],"names":[],"mappings":"AAEA,OAAO,
|
|
1
|
+
{"version":3,"file":"Table.d.ts","sourceRoot":"","sources":["../../../src/components/table/Table.tsx"],"names":[],"mappings":"AAEA,OAAO,EAGL,aAAa,EAGb,SAAS,EAGV,MAAM,OAAO,CAAC;AAiDf,MAAM,WAAW,UAAU;IACzB,QAAQ,CAAC,EAAE,SAAS,CAAC;IACrB,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,KAAK,CAAC,EAAE,aAAa,CAAC;CACvB;AAED,wBAAgB,KAAK,CAAC,KAAK,EAAE,UAAU,oDAYtC;yBAZe,KAAK"}
|
|
@@ -41,10 +41,10 @@ function splitChildren(children) {
|
|
|
41
41
|
return { Rows, Header };
|
|
42
42
|
}
|
|
43
43
|
export function Table(props) {
|
|
44
|
-
const { border = true, children } = props;
|
|
44
|
+
const { border = true, style = {}, children } = props;
|
|
45
45
|
const { Header, Rows } = splitChildren(children);
|
|
46
46
|
const tableContextValue = useMemo(() => ({ border }), [border]);
|
|
47
|
-
return (_jsx(TableContext.Provider, { value: tableContextValue, children: _jsxs("table", { children: [Header, _jsx("tbody", { children: Rows })] }) }));
|
|
47
|
+
return (_jsx(TableContext.Provider, { value: tableContextValue, children: _jsxs("table", { style: style, children: [Header, _jsx("tbody", { children: Rows })] }) }));
|
|
48
48
|
}
|
|
49
49
|
function useRowChildren(children) {
|
|
50
50
|
const cells = [];
|
|
@@ -75,12 +75,12 @@ function useRowChildren(children) {
|
|
|
75
75
|
}
|
|
76
76
|
return { cells };
|
|
77
77
|
}
|
|
78
|
-
function Row({ children, border = false }) {
|
|
78
|
+
function Row({ children, style = {}, border = false }) {
|
|
79
79
|
const { cells } = useRowChildren(children);
|
|
80
|
-
return _jsx("tr", { style: { border: border ? '1px solid black' : '' }, children: cells });
|
|
80
|
+
return (_jsx("tr", { style: { border: border ? '1px solid black' : '', ...style }, children: cells }));
|
|
81
81
|
}
|
|
82
82
|
Table.Row = Row;
|
|
83
|
-
Table.Header = ({ children, border = false }) => {
|
|
84
|
-
return (_jsx("thead", { children: _jsx(Table.Row, { border: border, children: children }) }));
|
|
83
|
+
Table.Header = ({ children, style, border = false }) => {
|
|
84
|
+
return (_jsx("thead", { children: _jsx(Table.Row, { border: border, style: style, children: children }) }));
|
|
85
85
|
};
|
|
86
86
|
//# sourceMappingURL=Table.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Table.js","sourceRoot":"","sources":["../../../src/components/table/Table.tsx"],"names":[],"mappings":";AAAA,sCAAsC;AACtC,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACrC,OAAO,EACL,QAAQ,EACR,aAAa,
|
|
1
|
+
{"version":3,"file":"Table.js","sourceRoot":"","sources":["../../../src/components/table/Table.tsx"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "react-science",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.23.0",
|
|
4
4
|
"description": "React components to build analysis UI",
|
|
5
5
|
"exports": {
|
|
6
6
|
"./app": {
|
|
@@ -66,6 +66,8 @@
|
|
|
66
66
|
"@headlessui/react": "^1.7.14",
|
|
67
67
|
"@lukeed/uuid": "^2.0.1",
|
|
68
68
|
"@popperjs/core": "^2.11.7",
|
|
69
|
+
"@radix-ui/react-checkbox": "^1.0.4",
|
|
70
|
+
"@radix-ui/react-select": "^1.2.2",
|
|
69
71
|
"@tanstack/react-query": "^4.29.5",
|
|
70
72
|
"@tanstack/react-table": "^8.8.5",
|
|
71
73
|
"biologic-converter": "^0.6.0",
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
/** @jsxImportSource @emotion/react */
|
|
2
|
+
import { css } from '@emotion/react';
|
|
3
|
+
import * as RadixCheckbox from '@radix-ui/react-checkbox';
|
|
4
|
+
import { ReactNode } from 'react';
|
|
5
|
+
import { RxCheck, RxMinus } from 'react-icons/rx/index';
|
|
6
|
+
|
|
7
|
+
export type CheckedState = boolean | 'indeterminate';
|
|
8
|
+
|
|
9
|
+
interface CheckboxProps {
|
|
10
|
+
checked?: CheckedState;
|
|
11
|
+
disabled?: boolean;
|
|
12
|
+
label?: ReactNode;
|
|
13
|
+
onChange?: (checked: CheckedState) => void;
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
const enabledColor = '#1677ff';
|
|
17
|
+
const disabledColor = '#b8b8b8';
|
|
18
|
+
|
|
19
|
+
export function Checkbox(props: CheckboxProps) {
|
|
20
|
+
const {
|
|
21
|
+
checked = 'indeterminate',
|
|
22
|
+
disabled = false,
|
|
23
|
+
label,
|
|
24
|
+
onChange,
|
|
25
|
+
} = props;
|
|
26
|
+
|
|
27
|
+
return (
|
|
28
|
+
<label
|
|
29
|
+
style={{
|
|
30
|
+
display: 'flex',
|
|
31
|
+
alignItems: 'center',
|
|
32
|
+
fontSize: '1.125em',
|
|
33
|
+
}}
|
|
34
|
+
>
|
|
35
|
+
<RadixCheckbox.Root
|
|
36
|
+
checked={checked}
|
|
37
|
+
onCheckedChange={onChange}
|
|
38
|
+
disabled={disabled}
|
|
39
|
+
css={css({
|
|
40
|
+
width: '16px',
|
|
41
|
+
height: '16px',
|
|
42
|
+
backgroundColor: disabled
|
|
43
|
+
? 'rgba(0, 0, 0, 0.04)'
|
|
44
|
+
: checked
|
|
45
|
+
? enabledColor
|
|
46
|
+
: 'white',
|
|
47
|
+
borderWidth: '1px',
|
|
48
|
+
borderColor: checked && !disabled ? enabledColor : disabledColor,
|
|
49
|
+
borderRadius: '4px',
|
|
50
|
+
display: 'flex',
|
|
51
|
+
alignItems: 'center',
|
|
52
|
+
justifyContent: 'center',
|
|
53
|
+
cursor: disabled ? 'not-allowed' : 'pointer',
|
|
54
|
+
})}
|
|
55
|
+
>
|
|
56
|
+
<RadixCheckbox.Indicator
|
|
57
|
+
css={css({
|
|
58
|
+
color: disabled ? disabledColor : 'white',
|
|
59
|
+
})}
|
|
60
|
+
>
|
|
61
|
+
{checked === true ? (
|
|
62
|
+
<RxCheck />
|
|
63
|
+
) : checked === 'indeterminate' ? (
|
|
64
|
+
<RxMinus />
|
|
65
|
+
) : null}
|
|
66
|
+
</RadixCheckbox.Indicator>
|
|
67
|
+
</RadixCheckbox.Root>
|
|
68
|
+
<span
|
|
69
|
+
style={{
|
|
70
|
+
paddingInline: '8px',
|
|
71
|
+
lineHeight: '16px',
|
|
72
|
+
}}
|
|
73
|
+
>
|
|
74
|
+
{label}
|
|
75
|
+
</span>
|
|
76
|
+
</label>
|
|
77
|
+
);
|
|
78
|
+
}
|
|
@@ -0,0 +1,185 @@
|
|
|
1
|
+
/** @jsxImportSource @emotion/react */
|
|
2
|
+
import styled from '@emotion/styled';
|
|
3
|
+
import * as RadixSelect from '@radix-ui/react-select';
|
|
4
|
+
import { SelectGroup } from '@radix-ui/react-select';
|
|
5
|
+
import { Fragment, ReactNode, CSSProperties } from 'react';
|
|
6
|
+
import { FaCheck, FaChevronDown, FaChevronUp } from 'react-icons/fa';
|
|
7
|
+
|
|
8
|
+
import { Portal } from '../root-layout/Portal';
|
|
9
|
+
|
|
10
|
+
interface Category {
|
|
11
|
+
label: ReactNode;
|
|
12
|
+
options: Option[];
|
|
13
|
+
}
|
|
14
|
+
interface Option {
|
|
15
|
+
label: ReactNode;
|
|
16
|
+
value: string;
|
|
17
|
+
disabled?: boolean;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
export interface SelectProps {
|
|
21
|
+
placeholder?: string;
|
|
22
|
+
value?: string;
|
|
23
|
+
onSelect?: (value: string) => void;
|
|
24
|
+
options: (Option[] | Category[])[];
|
|
25
|
+
disabled?: boolean;
|
|
26
|
+
style?: CSSProperties;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
const SelectRoot = styled.div`
|
|
30
|
+
display: inline-flex;
|
|
31
|
+
align-items: center;
|
|
32
|
+
justify-content: space-between;
|
|
33
|
+
background-color: #ffffff;
|
|
34
|
+
font-size: 1.125em;
|
|
35
|
+
width: 120px;
|
|
36
|
+
`;
|
|
37
|
+
|
|
38
|
+
const SelectTrigger = styled(RadixSelect.Trigger)`
|
|
39
|
+
width: 100%;
|
|
40
|
+
display: flex;
|
|
41
|
+
align-items: center;
|
|
42
|
+
justify-content: space-between;
|
|
43
|
+
border-radius: 4px;
|
|
44
|
+
border: 1px solid rgba(0, 0, 0, 0.15);
|
|
45
|
+
padding: 4px 11px;
|
|
46
|
+
user-select: none;
|
|
47
|
+
font-size: 1.125em;
|
|
48
|
+
line-height: 1.125em;
|
|
49
|
+
|
|
50
|
+
&[data-disabled] {
|
|
51
|
+
color: rgba(0, 0, 0, 0.5);
|
|
52
|
+
background-color: #f5f5f5;
|
|
53
|
+
}
|
|
54
|
+
`;
|
|
55
|
+
|
|
56
|
+
const SelectContent = styled(RadixSelect.Content)`
|
|
57
|
+
width: var(--radix-select-trigger-width);
|
|
58
|
+
max-height: var(--radix-select-content-available-height);
|
|
59
|
+
`;
|
|
60
|
+
|
|
61
|
+
const SelectViewport = styled(RadixSelect.Viewport)`
|
|
62
|
+
width: var(--radix-select-trigger-width);
|
|
63
|
+
border-radius: 4px;
|
|
64
|
+
box-sizing: border-box;
|
|
65
|
+
border: 1px solid rgba(0, 0, 0, 0.15);
|
|
66
|
+
background-color: white;
|
|
67
|
+
padding: 5px;
|
|
68
|
+
`;
|
|
69
|
+
|
|
70
|
+
const SelectItem = styled(RadixSelect.Item)`
|
|
71
|
+
user-select: none;
|
|
72
|
+
font-size: 1.125em;
|
|
73
|
+
padding: 4px 11px;
|
|
74
|
+
width: 100%;
|
|
75
|
+
display: flex;
|
|
76
|
+
align-items: center;
|
|
77
|
+
justify-content: space-between;
|
|
78
|
+
|
|
79
|
+
&:hover {
|
|
80
|
+
background-color: #e6f4ff;
|
|
81
|
+
}
|
|
82
|
+
&[data-disabled] {
|
|
83
|
+
color: rgba(0, 0, 0, 0.5);
|
|
84
|
+
}
|
|
85
|
+
`;
|
|
86
|
+
|
|
87
|
+
const SelectLabel = styled(RadixSelect.Label)`
|
|
88
|
+
color: rgba(0, 0, 0, 0.5);
|
|
89
|
+
font-size: 1em;
|
|
90
|
+
padding: 4px 11px;
|
|
91
|
+
margin-top: 8px;
|
|
92
|
+
`;
|
|
93
|
+
|
|
94
|
+
const SelectItemIndicator = styled(RadixSelect.ItemIndicator)`
|
|
95
|
+
right: 0;
|
|
96
|
+
width: 25px;
|
|
97
|
+
display: inline-flex;
|
|
98
|
+
align-items: center;
|
|
99
|
+
justify-content: center;
|
|
100
|
+
`;
|
|
101
|
+
|
|
102
|
+
const SelectSeparator = styled(RadixSelect.Separator)`
|
|
103
|
+
height: 1px;
|
|
104
|
+
width: 100%;
|
|
105
|
+
background-color: rgba(0, 0, 0, 0.15);
|
|
106
|
+
margin: 5px 0;
|
|
107
|
+
`;
|
|
108
|
+
|
|
109
|
+
export function Select(props: SelectProps) {
|
|
110
|
+
const {
|
|
111
|
+
placeholder,
|
|
112
|
+
value,
|
|
113
|
+
onSelect,
|
|
114
|
+
options,
|
|
115
|
+
disabled = false,
|
|
116
|
+
style,
|
|
117
|
+
} = props;
|
|
118
|
+
|
|
119
|
+
return (
|
|
120
|
+
<SelectRoot style={{ ...style }}>
|
|
121
|
+
<RadixSelect.Root
|
|
122
|
+
value={value}
|
|
123
|
+
onValueChange={onSelect}
|
|
124
|
+
disabled={disabled}
|
|
125
|
+
>
|
|
126
|
+
<SelectTrigger>
|
|
127
|
+
<RadixSelect.Value placeholder={placeholder} />
|
|
128
|
+
<RadixSelect.Icon asChild>
|
|
129
|
+
<FaChevronDown />
|
|
130
|
+
</RadixSelect.Icon>
|
|
131
|
+
</SelectTrigger>
|
|
132
|
+
<Portal>
|
|
133
|
+
<SelectContent position="popper">
|
|
134
|
+
<RadixSelect.ScrollUpButton>
|
|
135
|
+
<FaChevronUp />
|
|
136
|
+
</RadixSelect.ScrollUpButton>
|
|
137
|
+
<SelectViewport>
|
|
138
|
+
{options.map((group, groupIndex) => (
|
|
139
|
+
<Fragment key={groupIndex}>
|
|
140
|
+
{group.map((optionOrCategory, optionOrCategoryIndex) =>
|
|
141
|
+
'options' in optionOrCategory ? (
|
|
142
|
+
<SelectGroup key={optionOrCategoryIndex}>
|
|
143
|
+
<SelectLabel>{optionOrCategory.label}</SelectLabel>
|
|
144
|
+
{optionOrCategory.options.map((option) => (
|
|
145
|
+
<SelectItem
|
|
146
|
+
key={option.value}
|
|
147
|
+
value={option.value}
|
|
148
|
+
disabled={option.disabled}
|
|
149
|
+
>
|
|
150
|
+
<RadixSelect.ItemText>
|
|
151
|
+
{option.label}
|
|
152
|
+
</RadixSelect.ItemText>
|
|
153
|
+
<SelectItemIndicator>
|
|
154
|
+
<FaCheck />
|
|
155
|
+
</SelectItemIndicator>
|
|
156
|
+
</SelectItem>
|
|
157
|
+
))}
|
|
158
|
+
</SelectGroup>
|
|
159
|
+
) : (
|
|
160
|
+
<SelectItem
|
|
161
|
+
key={optionOrCategory.value}
|
|
162
|
+
value={optionOrCategory.value}
|
|
163
|
+
disabled={optionOrCategory.disabled}
|
|
164
|
+
>
|
|
165
|
+
<RadixSelect.ItemText>
|
|
166
|
+
{optionOrCategory.label}
|
|
167
|
+
</RadixSelect.ItemText>
|
|
168
|
+
<SelectItemIndicator>
|
|
169
|
+
<FaCheck />
|
|
170
|
+
</SelectItemIndicator>
|
|
171
|
+
</SelectItem>
|
|
172
|
+
),
|
|
173
|
+
)}
|
|
174
|
+
{groupIndex < options.length - 1 && <SelectSeparator />}
|
|
175
|
+
</Fragment>
|
|
176
|
+
))}
|
|
177
|
+
</SelectViewport>
|
|
178
|
+
<RadixSelect.ScrollDownButton />
|
|
179
|
+
<RadixSelect.Arrow />
|
|
180
|
+
</SelectContent>
|
|
181
|
+
</Portal>
|
|
182
|
+
</RadixSelect.Root>
|
|
183
|
+
</SelectRoot>
|
|
184
|
+
);
|
|
185
|
+
}
|
|
@@ -3,6 +3,7 @@ import { css } from '@emotion/react';
|
|
|
3
3
|
import {
|
|
4
4
|
Children,
|
|
5
5
|
createContext,
|
|
6
|
+
CSSProperties,
|
|
6
7
|
isValidElement,
|
|
7
8
|
ReactElement,
|
|
8
9
|
ReactNode,
|
|
@@ -60,15 +61,16 @@ function splitChildren(children: ReactNode) {
|
|
|
60
61
|
export interface TableProps {
|
|
61
62
|
children?: ReactNode;
|
|
62
63
|
border?: boolean;
|
|
64
|
+
style?: CSSProperties;
|
|
63
65
|
}
|
|
64
66
|
|
|
65
67
|
export function Table(props: TableProps) {
|
|
66
|
-
const { border = true, children } = props;
|
|
68
|
+
const { border = true, style = {}, children } = props;
|
|
67
69
|
const { Header, Rows } = splitChildren(children);
|
|
68
70
|
const tableContextValue = useMemo(() => ({ border }), [border]);
|
|
69
71
|
return (
|
|
70
72
|
<TableContext.Provider value={tableContextValue}>
|
|
71
|
-
<table>
|
|
73
|
+
<table style={style}>
|
|
72
74
|
{Header}
|
|
73
75
|
<tbody>{Rows}</tbody>
|
|
74
76
|
</table>
|
|
@@ -114,15 +116,21 @@ function useRowChildren(children: ReactNode) {
|
|
|
114
116
|
return { cells };
|
|
115
117
|
}
|
|
116
118
|
|
|
117
|
-
function Row({ children, border = false }: TableProps) {
|
|
119
|
+
function Row({ children, style = {}, border = false }: TableProps) {
|
|
118
120
|
const { cells } = useRowChildren(children);
|
|
119
|
-
return
|
|
121
|
+
return (
|
|
122
|
+
<tr style={{ border: border ? '1px solid black' : '', ...style }}>
|
|
123
|
+
{cells}
|
|
124
|
+
</tr>
|
|
125
|
+
);
|
|
120
126
|
}
|
|
121
127
|
Table.Row = Row;
|
|
122
|
-
Table.Header = ({ children, border = false }: TableProps) => {
|
|
128
|
+
Table.Header = ({ children, style, border = false }: TableProps) => {
|
|
123
129
|
return (
|
|
124
130
|
<thead>
|
|
125
|
-
<Table.Row border={border}
|
|
131
|
+
<Table.Row border={border} style={style}>
|
|
132
|
+
{children}
|
|
133
|
+
</Table.Row>
|
|
126
134
|
</thead>
|
|
127
135
|
);
|
|
128
136
|
};
|