@ultraviolet/ui 1.80.0 → 1.81.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/dist/components/List/ListContext.cjs +5 -3
- package/dist/components/List/ListContext.d.ts +4 -1
- package/dist/components/List/ListContext.js +5 -3
- package/dist/components/List/Row.cjs +20 -10
- package/dist/components/List/Row.d.ts +3 -0
- package/dist/components/List/Row.js +20 -10
- package/dist/components/List/SkeletonRows.cjs +7 -3
- package/dist/components/List/SkeletonRows.js +7 -3
- package/dist/components/List/index.cjs +19 -3
- package/dist/components/List/index.d.ts +4 -10
- package/dist/components/List/index.js +19 -3
- package/dist/components/List/types.d.ts +9 -0
- package/dist/components/Modal/ModalContent.cjs +1 -1
- package/dist/components/Modal/ModalContent.d.ts +1 -1
- package/dist/components/Modal/ModalContent.js +1 -1
- package/dist/components/Popup/animations.d.ts +12 -2
- package/dist/components/ProgressBar/index.cjs +54 -14
- package/dist/components/ProgressBar/index.d.ts +4 -1
- package/dist/components/ProgressBar/index.js +54 -14
- package/dist/components/Table/Row.cjs +19 -9
- package/dist/components/Table/Row.js +19 -9
- package/dist/components/Table/TableContext.cjs +5 -3
- package/dist/components/Table/TableContext.d.ts +4 -1
- package/dist/components/Table/TableContext.js +5 -3
- package/dist/components/Table/index.cjs +19 -3
- package/dist/components/Table/index.d.ts +4 -11
- package/dist/components/Table/index.js +19 -3
- package/dist/components/Table/types.d.ts +10 -0
- package/dist/components/TagInput/index.cjs +4 -4
- package/dist/components/TagInput/index.js +4 -4
- package/dist/components/VerificationCode/index.cjs +2 -2
- package/dist/components/VerificationCode/index.js +2 -2
- package/dist/utils/animations.d.ts +162 -27
- package/package.json +8 -8
|
@@ -2,6 +2,7 @@ import { jsx, Fragment, jsxs } from "@emotion/react/jsx-runtime";
|
|
|
2
2
|
import _styled from "@emotion/styled/base";
|
|
3
3
|
import { Skeleton } from "../Skeleton/index.js";
|
|
4
4
|
import { Cell } from "./Cell.js";
|
|
5
|
+
import { useListContext } from "./ListContext.js";
|
|
5
6
|
import { StyledRow } from "./Row.js";
|
|
6
7
|
function _EMOTION_STRINGIFIED_CSS_ERROR__() {
|
|
7
8
|
return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).";
|
|
@@ -16,7 +17,7 @@ const StyledLoadingRow = /* @__PURE__ */ _styled(StyledRow, process.env.NODE_ENV
|
|
|
16
17
|
styles: "cursor:progress"
|
|
17
18
|
} : {
|
|
18
19
|
name: "g8zzui",
|
|
19
|
-
styles: "cursor:progress/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
20
|
+
styles: "cursor:progress/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0xpc3QvU2tlbGV0b25Sb3dzLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFNMEMiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvTGlzdC9Ta2VsZXRvblJvd3MudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBTa2VsZXRvbiB9IGZyb20gJy4uL1NrZWxldG9uJ1xuaW1wb3J0IHsgQ2VsbCB9IGZyb20gJy4vQ2VsbCdcbmltcG9ydCB7IHVzZUxpc3RDb250ZXh0IH0gZnJvbSAnLi9MaXN0Q29udGV4dCdcbmltcG9ydCB7IFN0eWxlZFJvdyB9IGZyb20gJy4vUm93J1xuXG5jb25zdCBTdHlsZWRMb2FkaW5nUm93ID0gc3R5bGVkKFN0eWxlZFJvdylgXG4gIGN1cnNvcjogcHJvZ3Jlc3M7XG5gXG5cbmNvbnN0IFN0eWxlZFNrZWxldG9uID0gc3R5bGVkKFNrZWxldG9uKWBcbiAgd2lkdGg6IDgwJTtcbiAgbWF4LXdpZHRoOiAxMDAlO1xuICBhbGlnbi1pdGVtczogc3RhcnQ7XG4gIGp1c3RpZnktY29udGVudDogY2VudGVyO1xuYFxuXG50eXBlIExpc3RMb2FkaW5nU2tlbGV0b25Qcm9wcyA9IHtcbiAgc2VsZWN0YWJsZTogYm9vbGVhblxuICByb3dzOiBudW1iZXJcbiAgY29sczogbnVtYmVyXG59XG5cbmV4cG9ydCBjb25zdCBTa2VsZXRvblJvd3MgPSAoe1xuICBzZWxlY3RhYmxlLFxuICByb3dzLFxuICBjb2xzLFxufTogTGlzdExvYWRpbmdTa2VsZXRvblByb3BzKSA9PiB7XG4gIGNvbnN0IHJvd0FycmF5ID0gQXJyYXkuZnJvbSh7IGxlbmd0aDogcm93cyB9LCAoXywgaW5kZXgpID0+IGluZGV4KVxuICBjb25zdCBjb2xBcnJheSA9IEFycmF5LmZyb20oeyBsZW5ndGg6IGNvbHMgfSwgKF8sIGluZGV4KSA9PiBpbmRleClcbiAgY29uc3QgeyBjb2x1bW5zIH0gPSB1c2VMaXN0Q29udGV4dCgpXG5cbiAgcmV0dXJuIChcbiAgICA8PlxuICAgICAge3Jvd0FycmF5Lm1hcChpbmRleCA9PiAoXG4gICAgICAgIDxTdHlsZWRMb2FkaW5nUm93XG4gICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgcm9sZT1cInJvd1wiXG4gICAgICAgICAgaWQ9e2Bza2VsZXRvbi0ke2luZGV4fWB9XG4gICAgICAgICAgY29sdW1ucz17Y29sdW1uc31cbiAgICAgICAgICBrZXk9e2luZGV4fVxuICAgICAgICA+XG4gICAgICAgICAge3NlbGVjdGFibGUgPyA8ZGl2IC8+IDogbnVsbH1cbiAgICAgICAgICB7Y29sQXJyYXkubWFwKGNvbHVtbkluZGV4ID0+IChcbiAgICAgICAgICAgIDxDZWxsIGtleT17Y29sdW1uSW5kZXh9PlxuICAgICAgICAgICAgICA8U3R5bGVkU2tlbGV0b24gdmFyaWFudD1cImxpbmVcIiAvPlxuICAgICAgICAgICAgPC9DZWxsPlxuICAgICAgICAgICkpfVxuICAgICAgICA8L1N0eWxlZExvYWRpbmdSb3c+XG4gICAgICApKX1cbiAgICA8Lz5cbiAgKVxufVxuIl19 */",
|
|
20
21
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
21
22
|
});
|
|
22
23
|
const StyledSkeleton = /* @__PURE__ */ _styled(Skeleton, process.env.NODE_ENV === "production" ? {
|
|
@@ -29,7 +30,7 @@ const StyledSkeleton = /* @__PURE__ */ _styled(Skeleton, process.env.NODE_ENV ==
|
|
|
29
30
|
styles: "width:80%;max-width:100%;align-items:start;justify-content:center"
|
|
30
31
|
} : {
|
|
31
32
|
name: "10a39c7",
|
|
32
|
-
styles: "width:80%;max-width:100%;align-items:start;justify-content:center/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
33
|
+
styles: "width:80%;max-width:100%;align-items:start;justify-content:center/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0xpc3QvU2tlbGV0b25Sb3dzLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFVdUMiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvTGlzdC9Ta2VsZXRvblJvd3MudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBTa2VsZXRvbiB9IGZyb20gJy4uL1NrZWxldG9uJ1xuaW1wb3J0IHsgQ2VsbCB9IGZyb20gJy4vQ2VsbCdcbmltcG9ydCB7IHVzZUxpc3RDb250ZXh0IH0gZnJvbSAnLi9MaXN0Q29udGV4dCdcbmltcG9ydCB7IFN0eWxlZFJvdyB9IGZyb20gJy4vUm93J1xuXG5jb25zdCBTdHlsZWRMb2FkaW5nUm93ID0gc3R5bGVkKFN0eWxlZFJvdylgXG4gIGN1cnNvcjogcHJvZ3Jlc3M7XG5gXG5cbmNvbnN0IFN0eWxlZFNrZWxldG9uID0gc3R5bGVkKFNrZWxldG9uKWBcbiAgd2lkdGg6IDgwJTtcbiAgbWF4LXdpZHRoOiAxMDAlO1xuICBhbGlnbi1pdGVtczogc3RhcnQ7XG4gIGp1c3RpZnktY29udGVudDogY2VudGVyO1xuYFxuXG50eXBlIExpc3RMb2FkaW5nU2tlbGV0b25Qcm9wcyA9IHtcbiAgc2VsZWN0YWJsZTogYm9vbGVhblxuICByb3dzOiBudW1iZXJcbiAgY29sczogbnVtYmVyXG59XG5cbmV4cG9ydCBjb25zdCBTa2VsZXRvblJvd3MgPSAoe1xuICBzZWxlY3RhYmxlLFxuICByb3dzLFxuICBjb2xzLFxufTogTGlzdExvYWRpbmdTa2VsZXRvblByb3BzKSA9PiB7XG4gIGNvbnN0IHJvd0FycmF5ID0gQXJyYXkuZnJvbSh7IGxlbmd0aDogcm93cyB9LCAoXywgaW5kZXgpID0+IGluZGV4KVxuICBjb25zdCBjb2xBcnJheSA9IEFycmF5LmZyb20oeyBsZW5ndGg6IGNvbHMgfSwgKF8sIGluZGV4KSA9PiBpbmRleClcbiAgY29uc3QgeyBjb2x1bW5zIH0gPSB1c2VMaXN0Q29udGV4dCgpXG5cbiAgcmV0dXJuIChcbiAgICA8PlxuICAgICAge3Jvd0FycmF5Lm1hcChpbmRleCA9PiAoXG4gICAgICAgIDxTdHlsZWRMb2FkaW5nUm93XG4gICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgcm9sZT1cInJvd1wiXG4gICAgICAgICAgaWQ9e2Bza2VsZXRvbi0ke2luZGV4fWB9XG4gICAgICAgICAgY29sdW1ucz17Y29sdW1uc31cbiAgICAgICAgICBrZXk9e2luZGV4fVxuICAgICAgICA+XG4gICAgICAgICAge3NlbGVjdGFibGUgPyA8ZGl2IC8+IDogbnVsbH1cbiAgICAgICAgICB7Y29sQXJyYXkubWFwKGNvbHVtbkluZGV4ID0+IChcbiAgICAgICAgICAgIDxDZWxsIGtleT17Y29sdW1uSW5kZXh9PlxuICAgICAgICAgICAgICA8U3R5bGVkU2tlbGV0b24gdmFyaWFudD1cImxpbmVcIiAvPlxuICAgICAgICAgICAgPC9DZWxsPlxuICAgICAgICAgICkpfVxuICAgICAgICA8L1N0eWxlZExvYWRpbmdSb3c+XG4gICAgICApKX1cbiAgICA8Lz5cbiAgKVxufVxuIl19 */",
|
|
33
34
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
34
35
|
});
|
|
35
36
|
const SkeletonRows = ({
|
|
@@ -43,7 +44,10 @@ const SkeletonRows = ({
|
|
|
43
44
|
const colArray = Array.from({
|
|
44
45
|
length: cols
|
|
45
46
|
}, (_, index) => index);
|
|
46
|
-
|
|
47
|
+
const {
|
|
48
|
+
columns
|
|
49
|
+
} = useListContext();
|
|
50
|
+
return /* @__PURE__ */ jsx(Fragment, { children: rowArray.map((index) => /* @__PURE__ */ jsxs(StyledLoadingRow, { sentiment: "neutral", role: "row", id: `skeleton-${index}`, columns, children: [
|
|
47
51
|
selectable ? /* @__PURE__ */ jsx("div", {}) : null,
|
|
48
52
|
colArray.map((columnIndex) => /* @__PURE__ */ jsx(Cell, { children: /* @__PURE__ */ jsx(StyledSkeleton, { variant: "line" }) }, columnIndex))
|
|
49
53
|
] }, index)) });
|
|
@@ -12,6 +12,22 @@ const SelectBar = require("./SelectBar.cjs");
|
|
|
12
12
|
const SkeletonRows = require("./SkeletonRows.cjs");
|
|
13
13
|
const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
|
|
14
14
|
const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
|
|
15
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__() {
|
|
16
|
+
return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).";
|
|
17
|
+
}
|
|
18
|
+
const TableContainer = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
|
|
19
|
+
target: "ef5qi1"
|
|
20
|
+
} : {
|
|
21
|
+
target: "ef5qi1",
|
|
22
|
+
label: "TableContainer"
|
|
23
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
24
|
+
name: "wzrgqf",
|
|
25
|
+
styles: "min-width:100%;overflow-x:scroll"
|
|
26
|
+
} : {
|
|
27
|
+
name: "wzrgqf",
|
|
28
|
+
styles: "min-width:100%;overflow-x:scroll/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0xpc3QvaW5kZXgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVlpQyIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9MaXN0L2luZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHR5cGUgeyBEaXNwYXRjaCwgRm9yd2FyZGVkUmVmLCBSZWFjdE5vZGUsIFNldFN0YXRlQWN0aW9uIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBmb3J3YXJkUmVmIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBDZWxsIH0gZnJvbSAnLi9DZWxsJ1xuaW1wb3J0IHsgSGVhZGVyQ2VsbCB9IGZyb20gJy4vSGVhZGVyQ2VsbCdcbmltcG9ydCB7IEhlYWRlclJvdyB9IGZyb20gJy4vSGVhZGVyUm93J1xuaW1wb3J0IHsgTGlzdFByb3ZpZGVyLCB1c2VMaXN0Q29udGV4dCB9IGZyb20gJy4vTGlzdENvbnRleHQnXG5pbXBvcnQgeyBSb3cgfSBmcm9tICcuL1JvdydcbmltcG9ydCB7IFNlbGVjdEJhciB9IGZyb20gJy4vU2VsZWN0QmFyJ1xuaW1wb3J0IHsgU2tlbGV0b25Sb3dzIH0gZnJvbSAnLi9Ta2VsZXRvblJvd3MnXG5pbXBvcnQgdHlwZSB7IENvbHVtblByb3BzIH0gZnJvbSAnLi90eXBlcydcblxuY29uc3QgVGFibGVDb250YWluZXIgPSBzdHlsZWQuZGl2YFxuICBtaW4td2lkdGg6IDEwMCU7XG4gIG92ZXJmbG93LXg6IHNjcm9sbDtcbmBcblxuY29uc3QgU3R5bGVkVGFibGUgPSBzdHlsZWQudGFibGVgXG4gIHdpZHRoOiAxMDAlO1xuICBib3gtc2l6aW5nOiBjb250ZW50LWJveDtcbiAgZ2FwOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycxJ119O1xuICBib3JkZXItY29sbGFwc2U6IGNvbGxhcHNlZDtcbiAgYm9yZGVyLXNwYWNpbmc6IDAgJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMiddfTtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuYFxuXG50eXBlIExpc3RQcm9wcyA9IHtcbiAgZXhwYW5kYWJsZT86IGJvb2xlYW5cbiAgc2VsZWN0YWJsZT86IGJvb2xlYW5cbiAgY29sdW1uczogQ29sdW1uUHJvcHNbXVxuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIC8qKlxuICAgKiBTZXQgaXQgdG8gdHJ1ZSBpZiB5b3Ugd2FudCB0byBkaXNwbGF5IGEgcGxhY2Vob2xkZXIgZHVyaW5nIGxvYWRpbmdcbiAgICogKi9cbiAgbG9hZGluZz86IGJvb2xlYW5cbiAgLyoqXG4gICAqIEF1dG8gY29sbGFwc2UgaXMgY29sbGFwc2luZyBleHBhbmRhYmxlIHJvdyB3aGVuIGFub3RoZXIgaXMgZXhwYW5kaW5nXG4gICAqICovXG4gIGF1dG9Db2xsYXBzZT86IGJvb2xlYW5cbiAgLyoqXG4gICAqIEFjdGlvbiB3aGVuIHNlbGVjdGlvbiBjaGFuZ2VzIChnZXQgdGhlIGxpc3Qgb2Ygc2VsZWN0ZWQgcm93cylcbiAgICovXG4gIG9uU2VsZWN0ZWRDaGFuZ2U/OiBEaXNwYXRjaDxTZXRTdGF0ZUFjdGlvbjxzdHJpbmdbXT4+XG59XG5cbmNvbnN0IEJhc2VMaXN0ID0gZm9yd2FyZFJlZihcbiAgKFxuICAgIHtcbiAgICAgIGV4cGFuZGFibGUgPSBmYWxzZSxcbiAgICAgIHNlbGVjdGFibGUgPSBmYWxzZSxcbiAgICAgIGNvbHVtbnMsXG4gICAgICBjaGlsZHJlbixcbiAgICAgIGxvYWRpbmcsXG4gICAgICBhdXRvQ29sbGFwc2UgPSBmYWxzZSxcbiAgICAgIG9uU2VsZWN0ZWRDaGFuZ2UsXG4gICAgfTogTGlzdFByb3BzLFxuICAgIHJlZjogRm9yd2FyZGVkUmVmPEhUTUxUYWJsZUVsZW1lbnQ+LFxuICApID0+IChcbiAgICA8TGlzdFByb3ZpZGVyXG4gICAgICBzZWxlY3RhYmxlPXtzZWxlY3RhYmxlfVxuICAgICAgZXhwYW5kQnV0dG9uPXtleHBhbmRhYmxlfVxuICAgICAgYXV0b0NvbGxhcHNlPXthdXRvQ29sbGFwc2V9XG4gICAgICBvblNlbGVjdGVkQ2hhbmdlPXtvblNlbGVjdGVkQ2hhbmdlfVxuICAgICAgY29sdW1ucz17Y29sdW1uc31cbiAgICA+XG4gICAgICA8VGFibGVDb250YWluZXI+XG4gICAgICAgIDxTdHlsZWRUYWJsZSByZWY9e3JlZn0+XG4gICAgICAgICAgPEhlYWRlclJvdyBoYXNTZWxlY3RBbGxDb2x1bW49e3NlbGVjdGFibGV9PlxuICAgICAgICAgICAge2NvbHVtbnMubWFwKChjb2x1bW4sIGluZGV4KSA9PiAoXG4gICAgICAgICAgICAgIDxIZWFkZXJDZWxsXG4gICAgICAgICAgICAgICAga2V5PXtgaGVhZGVyLWNvbHVtbi0ke2luZGV4fWB9XG4gICAgICAgICAgICAgICAgaXNPcmRlcmVkPXtjb2x1bW4uaXNPcmRlcmVkfVxuICAgICAgICAgICAgICAgIG9yZGVyRGlyZWN0aW9uPXtjb2x1bW4ub3JkZXJEaXJlY3Rpb259XG4gICAgICAgICAgICAgICAgb25PcmRlcj17Y29sdW1uLm9uT3JkZXJ9XG4gICAgICAgICAgICAgICAgaW5mbz17Y29sdW1uLmluZm99XG4gICAgICAgICAgICAgICAgd2lkdGg9e2NvbHVtbi53aWR0aH1cbiAgICAgICAgICAgICAgICBtaW5XaXRoPXtjb2x1bW4ubWluV2lkdGh9XG4gICAgICAgICAgICAgICAgbWF4V2lkdGg9e2NvbHVtbi5tYXhXaWR0aH1cbiAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgIHtjb2x1bW4ubGFiZWx9XG4gICAgICAgICAgICAgIDwvSGVhZGVyQ2VsbD5cbiAgICAgICAgICAgICkpfVxuICAgICAgICAgIDwvSGVhZGVyUm93PlxuICAgICAgICAgIDx0Ym9keT5cbiAgICAgICAgICAgIHtsb2FkaW5nID8gKFxuICAgICAgICAgICAgICA8U2tlbGV0b25Sb3dzXG4gICAgICAgICAgICAgICAgc2VsZWN0YWJsZT17c2VsZWN0YWJsZX1cbiAgICAgICAgICAgICAgICByb3dzPXs1fVxuICAgICAgICAgICAgICAgIGNvbHM9e2NvbHVtbnMubGVuZ3RofVxuICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgKSA6IChcbiAgICAgICAgICAgICAgY2hpbGRyZW5cbiAgICAgICAgICAgICl9XG4gICAgICAgICAgPC90Ym9keT5cbiAgICAgICAgPC9TdHlsZWRUYWJsZT5cbiAgICAgIDwvVGFibGVDb250YWluZXI+XG4gICAgPC9MaXN0UHJvdmlkZXI+XG4gICksXG4pXG5cbi8qKlxuICogTGlzdCBpcyBhIGNvbXBvbmVudCB0aGF0IGRpc3BsYXlzIGEgbGlzdCBvZiBpdGVtcyBiYXNlZCBvbiB0aGUgY29sdW1ucyB5b3UgcHJvdmlkZSBhbmQgdGhlIGRhdGEgeW91IHBhc3MuXG4gKi9cbmV4cG9ydCBjb25zdCBMaXN0ID0gT2JqZWN0LmFzc2lnbihCYXNlTGlzdCwge1xuICBSb3csXG4gIENlbGwsXG4gIFNlbGVjdEJhcixcbiAgdXNlTGlzdENvbnRleHQsXG59KVxuIl19 */",
|
|
29
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
30
|
+
});
|
|
15
31
|
const StyledTable = /* @__PURE__ */ _styled__default.default("table", process.env.NODE_ENV === "production" ? {
|
|
16
32
|
target: "ef5qi0"
|
|
17
33
|
} : {
|
|
@@ -21,7 +37,7 @@ const StyledTable = /* @__PURE__ */ _styled__default.default("table", process.en
|
|
|
21
37
|
theme
|
|
22
38
|
}) => theme.space["1"], ";border-collapse:collapsed;border-spacing:0 ", ({
|
|
23
39
|
theme
|
|
24
|
-
}) => theme.space["2"], ";position:relative;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
40
|
+
}) => theme.space["2"], ";position:relative;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0xpc3QvaW5kZXgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWlCZ0MiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvTGlzdC9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB0eXBlIHsgRGlzcGF0Y2gsIEZvcndhcmRlZFJlZiwgUmVhY3ROb2RlLCBTZXRTdGF0ZUFjdGlvbiB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgZm9yd2FyZFJlZiB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgQ2VsbCB9IGZyb20gJy4vQ2VsbCdcbmltcG9ydCB7IEhlYWRlckNlbGwgfSBmcm9tICcuL0hlYWRlckNlbGwnXG5pbXBvcnQgeyBIZWFkZXJSb3cgfSBmcm9tICcuL0hlYWRlclJvdydcbmltcG9ydCB7IExpc3RQcm92aWRlciwgdXNlTGlzdENvbnRleHQgfSBmcm9tICcuL0xpc3RDb250ZXh0J1xuaW1wb3J0IHsgUm93IH0gZnJvbSAnLi9Sb3cnXG5pbXBvcnQgeyBTZWxlY3RCYXIgfSBmcm9tICcuL1NlbGVjdEJhcidcbmltcG9ydCB7IFNrZWxldG9uUm93cyB9IGZyb20gJy4vU2tlbGV0b25Sb3dzJ1xuaW1wb3J0IHR5cGUgeyBDb2x1bW5Qcm9wcyB9IGZyb20gJy4vdHlwZXMnXG5cbmNvbnN0IFRhYmxlQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcbiAgbWluLXdpZHRoOiAxMDAlO1xuICBvdmVyZmxvdy14OiBzY3JvbGw7XG5gXG5cbmNvbnN0IFN0eWxlZFRhYmxlID0gc3R5bGVkLnRhYmxlYFxuICB3aWR0aDogMTAwJTtcbiAgYm94LXNpemluZzogY29udGVudC1ib3g7XG4gIGdhcDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMSddfTtcbiAgYm9yZGVyLWNvbGxhcHNlOiBjb2xsYXBzZWQ7XG4gIGJvcmRlci1zcGFjaW5nOiAwICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzInXX07XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbmBcblxudHlwZSBMaXN0UHJvcHMgPSB7XG4gIGV4cGFuZGFibGU/OiBib29sZWFuXG4gIHNlbGVjdGFibGU/OiBib29sZWFuXG4gIGNvbHVtbnM6IENvbHVtblByb3BzW11cbiAgY2hpbGRyZW46IFJlYWN0Tm9kZVxuICAvKipcbiAgICogU2V0IGl0IHRvIHRydWUgaWYgeW91IHdhbnQgdG8gZGlzcGxheSBhIHBsYWNlaG9sZGVyIGR1cmluZyBsb2FkaW5nXG4gICAqICovXG4gIGxvYWRpbmc/OiBib29sZWFuXG4gIC8qKlxuICAgKiBBdXRvIGNvbGxhcHNlIGlzIGNvbGxhcHNpbmcgZXhwYW5kYWJsZSByb3cgd2hlbiBhbm90aGVyIGlzIGV4cGFuZGluZ1xuICAgKiAqL1xuICBhdXRvQ29sbGFwc2U/OiBib29sZWFuXG4gIC8qKlxuICAgKiBBY3Rpb24gd2hlbiBzZWxlY3Rpb24gY2hhbmdlcyAoZ2V0IHRoZSBsaXN0IG9mIHNlbGVjdGVkIHJvd3MpXG4gICAqL1xuICBvblNlbGVjdGVkQ2hhbmdlPzogRGlzcGF0Y2g8U2V0U3RhdGVBY3Rpb248c3RyaW5nW10+PlxufVxuXG5jb25zdCBCYXNlTGlzdCA9IGZvcndhcmRSZWYoXG4gIChcbiAgICB7XG4gICAgICBleHBhbmRhYmxlID0gZmFsc2UsXG4gICAgICBzZWxlY3RhYmxlID0gZmFsc2UsXG4gICAgICBjb2x1bW5zLFxuICAgICAgY2hpbGRyZW4sXG4gICAgICBsb2FkaW5nLFxuICAgICAgYXV0b0NvbGxhcHNlID0gZmFsc2UsXG4gICAgICBvblNlbGVjdGVkQ2hhbmdlLFxuICAgIH06IExpc3RQcm9wcyxcbiAgICByZWY6IEZvcndhcmRlZFJlZjxIVE1MVGFibGVFbGVtZW50PixcbiAgKSA9PiAoXG4gICAgPExpc3RQcm92aWRlclxuICAgICAgc2VsZWN0YWJsZT17c2VsZWN0YWJsZX1cbiAgICAgIGV4cGFuZEJ1dHRvbj17ZXhwYW5kYWJsZX1cbiAgICAgIGF1dG9Db2xsYXBzZT17YXV0b0NvbGxhcHNlfVxuICAgICAgb25TZWxlY3RlZENoYW5nZT17b25TZWxlY3RlZENoYW5nZX1cbiAgICAgIGNvbHVtbnM9e2NvbHVtbnN9XG4gICAgPlxuICAgICAgPFRhYmxlQ29udGFpbmVyPlxuICAgICAgICA8U3R5bGVkVGFibGUgcmVmPXtyZWZ9PlxuICAgICAgICAgIDxIZWFkZXJSb3cgaGFzU2VsZWN0QWxsQ29sdW1uPXtzZWxlY3RhYmxlfT5cbiAgICAgICAgICAgIHtjb2x1bW5zLm1hcCgoY29sdW1uLCBpbmRleCkgPT4gKFxuICAgICAgICAgICAgICA8SGVhZGVyQ2VsbFxuICAgICAgICAgICAgICAgIGtleT17YGhlYWRlci1jb2x1bW4tJHtpbmRleH1gfVxuICAgICAgICAgICAgICAgIGlzT3JkZXJlZD17Y29sdW1uLmlzT3JkZXJlZH1cbiAgICAgICAgICAgICAgICBvcmRlckRpcmVjdGlvbj17Y29sdW1uLm9yZGVyRGlyZWN0aW9ufVxuICAgICAgICAgICAgICAgIG9uT3JkZXI9e2NvbHVtbi5vbk9yZGVyfVxuICAgICAgICAgICAgICAgIGluZm89e2NvbHVtbi5pbmZvfVxuICAgICAgICAgICAgICAgIHdpZHRoPXtjb2x1bW4ud2lkdGh9XG4gICAgICAgICAgICAgICAgbWluV2l0aD17Y29sdW1uLm1pbldpZHRofVxuICAgICAgICAgICAgICAgIG1heFdpZHRoPXtjb2x1bW4ubWF4V2lkdGh9XG4gICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICB7Y29sdW1uLmxhYmVsfVxuICAgICAgICAgICAgICA8L0hlYWRlckNlbGw+XG4gICAgICAgICAgICApKX1cbiAgICAgICAgICA8L0hlYWRlclJvdz5cbiAgICAgICAgICA8dGJvZHk+XG4gICAgICAgICAgICB7bG9hZGluZyA/IChcbiAgICAgICAgICAgICAgPFNrZWxldG9uUm93c1xuICAgICAgICAgICAgICAgIHNlbGVjdGFibGU9e3NlbGVjdGFibGV9XG4gICAgICAgICAgICAgICAgcm93cz17NX1cbiAgICAgICAgICAgICAgICBjb2xzPXtjb2x1bW5zLmxlbmd0aH1cbiAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICkgOiAoXG4gICAgICAgICAgICAgIGNoaWxkcmVuXG4gICAgICAgICAgICApfVxuICAgICAgICAgIDwvdGJvZHk+XG4gICAgICAgIDwvU3R5bGVkVGFibGU+XG4gICAgICA8L1RhYmxlQ29udGFpbmVyPlxuICAgIDwvTGlzdFByb3ZpZGVyPlxuICApLFxuKVxuXG4vKipcbiAqIExpc3QgaXMgYSBjb21wb25lbnQgdGhhdCBkaXNwbGF5cyBhIGxpc3Qgb2YgaXRlbXMgYmFzZWQgb24gdGhlIGNvbHVtbnMgeW91IHByb3ZpZGUgYW5kIHRoZSBkYXRhIHlvdSBwYXNzLlxuICovXG5leHBvcnQgY29uc3QgTGlzdCA9IE9iamVjdC5hc3NpZ24oQmFzZUxpc3QsIHtcbiAgUm93LFxuICBDZWxsLFxuICBTZWxlY3RCYXIsXG4gIHVzZUxpc3RDb250ZXh0LFxufSlcbiJdfQ== */"));
|
|
25
41
|
const BaseList = React.forwardRef(({
|
|
26
42
|
expandable = false,
|
|
27
43
|
selectable = false,
|
|
@@ -30,10 +46,10 @@ const BaseList = React.forwardRef(({
|
|
|
30
46
|
loading,
|
|
31
47
|
autoCollapse = false,
|
|
32
48
|
onSelectedChange
|
|
33
|
-
}, ref) => /* @__PURE__ */ jsxRuntime.jsx(ListContext.ListProvider, { selectable, expandButton: expandable, autoCollapse, onSelectedChange, children: /* @__PURE__ */ jsxRuntime.jsxs(StyledTable, { ref, children: [
|
|
49
|
+
}, ref) => /* @__PURE__ */ jsxRuntime.jsx(ListContext.ListProvider, { selectable, expandButton: expandable, autoCollapse, onSelectedChange, columns, children: /* @__PURE__ */ jsxRuntime.jsx(TableContainer, { children: /* @__PURE__ */ jsxRuntime.jsxs(StyledTable, { ref, children: [
|
|
34
50
|
/* @__PURE__ */ jsxRuntime.jsx(HeaderRow.HeaderRow, { hasSelectAllColumn: selectable, children: columns.map((column, index) => /* @__PURE__ */ jsxRuntime.jsx(HeaderCell.HeaderCell, { isOrdered: column.isOrdered, orderDirection: column.orderDirection, onOrder: column.onOrder, info: column.info, width: column.width, minWith: column.minWidth, maxWidth: column.maxWidth, children: column.label }, `header-column-${index}`)) }),
|
|
35
51
|
/* @__PURE__ */ jsxRuntime.jsx("tbody", { children: loading ? /* @__PURE__ */ jsxRuntime.jsx(SkeletonRows.SkeletonRows, { selectable, rows: 5, cols: columns.length }) : children })
|
|
36
|
-
] }) }));
|
|
52
|
+
] }) }) }));
|
|
37
53
|
const List = Object.assign(BaseList, {
|
|
38
54
|
Row: Row.Row,
|
|
39
55
|
Cell: Cell.Cell,
|
|
@@ -1,13 +1,6 @@
|
|
|
1
|
-
import type {
|
|
2
|
-
import { HeaderCell } from './HeaderCell';
|
|
1
|
+
import type { Dispatch, ReactNode, SetStateAction } from 'react';
|
|
3
2
|
import { SelectBar } from './SelectBar';
|
|
4
|
-
type ColumnProps
|
|
5
|
-
label?: string;
|
|
6
|
-
width?: string;
|
|
7
|
-
minWidth?: string;
|
|
8
|
-
maxWidth?: string;
|
|
9
|
-
info?: string;
|
|
10
|
-
};
|
|
3
|
+
import type { ColumnProps } from './types';
|
|
11
4
|
type ListProps = {
|
|
12
5
|
expandable?: boolean;
|
|
13
6
|
selectable?: boolean;
|
|
@@ -65,11 +58,12 @@ export declare const List: import("react").ForwardRefExoticComponent<ListProps &
|
|
|
65
58
|
selectRow: (rowId: string) => void;
|
|
66
59
|
unselectRow: (rowId: string) => void;
|
|
67
60
|
selectable: boolean;
|
|
68
|
-
allRowSelectValue: ComponentProps<typeof import("..").Checkbox>["checked"];
|
|
61
|
+
allRowSelectValue: import("react").ComponentProps<typeof import("..").Checkbox>["checked"];
|
|
69
62
|
selectAll: () => void;
|
|
70
63
|
unselectAll: () => void;
|
|
71
64
|
refList: import("react").RefObject<HTMLInputElement[]>;
|
|
72
65
|
inRange: string[];
|
|
66
|
+
columns: ColumnProps[];
|
|
73
67
|
};
|
|
74
68
|
};
|
|
75
69
|
export {};
|
|
@@ -8,6 +8,22 @@ import { ListProvider, useListContext } from "./ListContext.js";
|
|
|
8
8
|
import { Row } from "./Row.js";
|
|
9
9
|
import { SelectBar } from "./SelectBar.js";
|
|
10
10
|
import { SkeletonRows } from "./SkeletonRows.js";
|
|
11
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__() {
|
|
12
|
+
return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).";
|
|
13
|
+
}
|
|
14
|
+
const TableContainer = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
|
|
15
|
+
target: "ef5qi1"
|
|
16
|
+
} : {
|
|
17
|
+
target: "ef5qi1",
|
|
18
|
+
label: "TableContainer"
|
|
19
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
20
|
+
name: "wzrgqf",
|
|
21
|
+
styles: "min-width:100%;overflow-x:scroll"
|
|
22
|
+
} : {
|
|
23
|
+
name: "wzrgqf",
|
|
24
|
+
styles: "min-width:100%;overflow-x:scroll/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0xpc3QvaW5kZXgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVlpQyIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9MaXN0L2luZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHR5cGUgeyBEaXNwYXRjaCwgRm9yd2FyZGVkUmVmLCBSZWFjdE5vZGUsIFNldFN0YXRlQWN0aW9uIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBmb3J3YXJkUmVmIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBDZWxsIH0gZnJvbSAnLi9DZWxsJ1xuaW1wb3J0IHsgSGVhZGVyQ2VsbCB9IGZyb20gJy4vSGVhZGVyQ2VsbCdcbmltcG9ydCB7IEhlYWRlclJvdyB9IGZyb20gJy4vSGVhZGVyUm93J1xuaW1wb3J0IHsgTGlzdFByb3ZpZGVyLCB1c2VMaXN0Q29udGV4dCB9IGZyb20gJy4vTGlzdENvbnRleHQnXG5pbXBvcnQgeyBSb3cgfSBmcm9tICcuL1JvdydcbmltcG9ydCB7IFNlbGVjdEJhciB9IGZyb20gJy4vU2VsZWN0QmFyJ1xuaW1wb3J0IHsgU2tlbGV0b25Sb3dzIH0gZnJvbSAnLi9Ta2VsZXRvblJvd3MnXG5pbXBvcnQgdHlwZSB7IENvbHVtblByb3BzIH0gZnJvbSAnLi90eXBlcydcblxuY29uc3QgVGFibGVDb250YWluZXIgPSBzdHlsZWQuZGl2YFxuICBtaW4td2lkdGg6IDEwMCU7XG4gIG92ZXJmbG93LXg6IHNjcm9sbDtcbmBcblxuY29uc3QgU3R5bGVkVGFibGUgPSBzdHlsZWQudGFibGVgXG4gIHdpZHRoOiAxMDAlO1xuICBib3gtc2l6aW5nOiBjb250ZW50LWJveDtcbiAgZ2FwOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycxJ119O1xuICBib3JkZXItY29sbGFwc2U6IGNvbGxhcHNlZDtcbiAgYm9yZGVyLXNwYWNpbmc6IDAgJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMiddfTtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuYFxuXG50eXBlIExpc3RQcm9wcyA9IHtcbiAgZXhwYW5kYWJsZT86IGJvb2xlYW5cbiAgc2VsZWN0YWJsZT86IGJvb2xlYW5cbiAgY29sdW1uczogQ29sdW1uUHJvcHNbXVxuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIC8qKlxuICAgKiBTZXQgaXQgdG8gdHJ1ZSBpZiB5b3Ugd2FudCB0byBkaXNwbGF5IGEgcGxhY2Vob2xkZXIgZHVyaW5nIGxvYWRpbmdcbiAgICogKi9cbiAgbG9hZGluZz86IGJvb2xlYW5cbiAgLyoqXG4gICAqIEF1dG8gY29sbGFwc2UgaXMgY29sbGFwc2luZyBleHBhbmRhYmxlIHJvdyB3aGVuIGFub3RoZXIgaXMgZXhwYW5kaW5nXG4gICAqICovXG4gIGF1dG9Db2xsYXBzZT86IGJvb2xlYW5cbiAgLyoqXG4gICAqIEFjdGlvbiB3aGVuIHNlbGVjdGlvbiBjaGFuZ2VzIChnZXQgdGhlIGxpc3Qgb2Ygc2VsZWN0ZWQgcm93cylcbiAgICovXG4gIG9uU2VsZWN0ZWRDaGFuZ2U/OiBEaXNwYXRjaDxTZXRTdGF0ZUFjdGlvbjxzdHJpbmdbXT4+XG59XG5cbmNvbnN0IEJhc2VMaXN0ID0gZm9yd2FyZFJlZihcbiAgKFxuICAgIHtcbiAgICAgIGV4cGFuZGFibGUgPSBmYWxzZSxcbiAgICAgIHNlbGVjdGFibGUgPSBmYWxzZSxcbiAgICAgIGNvbHVtbnMsXG4gICAgICBjaGlsZHJlbixcbiAgICAgIGxvYWRpbmcsXG4gICAgICBhdXRvQ29sbGFwc2UgPSBmYWxzZSxcbiAgICAgIG9uU2VsZWN0ZWRDaGFuZ2UsXG4gICAgfTogTGlzdFByb3BzLFxuICAgIHJlZjogRm9yd2FyZGVkUmVmPEhUTUxUYWJsZUVsZW1lbnQ+LFxuICApID0+IChcbiAgICA8TGlzdFByb3ZpZGVyXG4gICAgICBzZWxlY3RhYmxlPXtzZWxlY3RhYmxlfVxuICAgICAgZXhwYW5kQnV0dG9uPXtleHBhbmRhYmxlfVxuICAgICAgYXV0b0NvbGxhcHNlPXthdXRvQ29sbGFwc2V9XG4gICAgICBvblNlbGVjdGVkQ2hhbmdlPXtvblNlbGVjdGVkQ2hhbmdlfVxuICAgICAgY29sdW1ucz17Y29sdW1uc31cbiAgICA+XG4gICAgICA8VGFibGVDb250YWluZXI+XG4gICAgICAgIDxTdHlsZWRUYWJsZSByZWY9e3JlZn0+XG4gICAgICAgICAgPEhlYWRlclJvdyBoYXNTZWxlY3RBbGxDb2x1bW49e3NlbGVjdGFibGV9PlxuICAgICAgICAgICAge2NvbHVtbnMubWFwKChjb2x1bW4sIGluZGV4KSA9PiAoXG4gICAgICAgICAgICAgIDxIZWFkZXJDZWxsXG4gICAgICAgICAgICAgICAga2V5PXtgaGVhZGVyLWNvbHVtbi0ke2luZGV4fWB9XG4gICAgICAgICAgICAgICAgaXNPcmRlcmVkPXtjb2x1bW4uaXNPcmRlcmVkfVxuICAgICAgICAgICAgICAgIG9yZGVyRGlyZWN0aW9uPXtjb2x1bW4ub3JkZXJEaXJlY3Rpb259XG4gICAgICAgICAgICAgICAgb25PcmRlcj17Y29sdW1uLm9uT3JkZXJ9XG4gICAgICAgICAgICAgICAgaW5mbz17Y29sdW1uLmluZm99XG4gICAgICAgICAgICAgICAgd2lkdGg9e2NvbHVtbi53aWR0aH1cbiAgICAgICAgICAgICAgICBtaW5XaXRoPXtjb2x1bW4ubWluV2lkdGh9XG4gICAgICAgICAgICAgICAgbWF4V2lkdGg9e2NvbHVtbi5tYXhXaWR0aH1cbiAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgIHtjb2x1bW4ubGFiZWx9XG4gICAgICAgICAgICAgIDwvSGVhZGVyQ2VsbD5cbiAgICAgICAgICAgICkpfVxuICAgICAgICAgIDwvSGVhZGVyUm93PlxuICAgICAgICAgIDx0Ym9keT5cbiAgICAgICAgICAgIHtsb2FkaW5nID8gKFxuICAgICAgICAgICAgICA8U2tlbGV0b25Sb3dzXG4gICAgICAgICAgICAgICAgc2VsZWN0YWJsZT17c2VsZWN0YWJsZX1cbiAgICAgICAgICAgICAgICByb3dzPXs1fVxuICAgICAgICAgICAgICAgIGNvbHM9e2NvbHVtbnMubGVuZ3RofVxuICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgKSA6IChcbiAgICAgICAgICAgICAgY2hpbGRyZW5cbiAgICAgICAgICAgICl9XG4gICAgICAgICAgPC90Ym9keT5cbiAgICAgICAgPC9TdHlsZWRUYWJsZT5cbiAgICAgIDwvVGFibGVDb250YWluZXI+XG4gICAgPC9MaXN0UHJvdmlkZXI+XG4gICksXG4pXG5cbi8qKlxuICogTGlzdCBpcyBhIGNvbXBvbmVudCB0aGF0IGRpc3BsYXlzIGEgbGlzdCBvZiBpdGVtcyBiYXNlZCBvbiB0aGUgY29sdW1ucyB5b3UgcHJvdmlkZSBhbmQgdGhlIGRhdGEgeW91IHBhc3MuXG4gKi9cbmV4cG9ydCBjb25zdCBMaXN0ID0gT2JqZWN0LmFzc2lnbihCYXNlTGlzdCwge1xuICBSb3csXG4gIENlbGwsXG4gIFNlbGVjdEJhcixcbiAgdXNlTGlzdENvbnRleHQsXG59KVxuIl19 */",
|
|
25
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
26
|
+
});
|
|
11
27
|
const StyledTable = /* @__PURE__ */ _styled("table", process.env.NODE_ENV === "production" ? {
|
|
12
28
|
target: "ef5qi0"
|
|
13
29
|
} : {
|
|
@@ -17,7 +33,7 @@ const StyledTable = /* @__PURE__ */ _styled("table", process.env.NODE_ENV === "p
|
|
|
17
33
|
theme
|
|
18
34
|
}) => theme.space["1"], ";border-collapse:collapsed;border-spacing:0 ", ({
|
|
19
35
|
theme
|
|
20
|
-
}) => theme.space["2"], ";position:relative;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
36
|
+
}) => theme.space["2"], ";position:relative;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0xpc3QvaW5kZXgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWlCZ0MiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvTGlzdC9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB0eXBlIHsgRGlzcGF0Y2gsIEZvcndhcmRlZFJlZiwgUmVhY3ROb2RlLCBTZXRTdGF0ZUFjdGlvbiB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgZm9yd2FyZFJlZiB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgQ2VsbCB9IGZyb20gJy4vQ2VsbCdcbmltcG9ydCB7IEhlYWRlckNlbGwgfSBmcm9tICcuL0hlYWRlckNlbGwnXG5pbXBvcnQgeyBIZWFkZXJSb3cgfSBmcm9tICcuL0hlYWRlclJvdydcbmltcG9ydCB7IExpc3RQcm92aWRlciwgdXNlTGlzdENvbnRleHQgfSBmcm9tICcuL0xpc3RDb250ZXh0J1xuaW1wb3J0IHsgUm93IH0gZnJvbSAnLi9Sb3cnXG5pbXBvcnQgeyBTZWxlY3RCYXIgfSBmcm9tICcuL1NlbGVjdEJhcidcbmltcG9ydCB7IFNrZWxldG9uUm93cyB9IGZyb20gJy4vU2tlbGV0b25Sb3dzJ1xuaW1wb3J0IHR5cGUgeyBDb2x1bW5Qcm9wcyB9IGZyb20gJy4vdHlwZXMnXG5cbmNvbnN0IFRhYmxlQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcbiAgbWluLXdpZHRoOiAxMDAlO1xuICBvdmVyZmxvdy14OiBzY3JvbGw7XG5gXG5cbmNvbnN0IFN0eWxlZFRhYmxlID0gc3R5bGVkLnRhYmxlYFxuICB3aWR0aDogMTAwJTtcbiAgYm94LXNpemluZzogY29udGVudC1ib3g7XG4gIGdhcDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMSddfTtcbiAgYm9yZGVyLWNvbGxhcHNlOiBjb2xsYXBzZWQ7XG4gIGJvcmRlci1zcGFjaW5nOiAwICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzInXX07XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbmBcblxudHlwZSBMaXN0UHJvcHMgPSB7XG4gIGV4cGFuZGFibGU/OiBib29sZWFuXG4gIHNlbGVjdGFibGU/OiBib29sZWFuXG4gIGNvbHVtbnM6IENvbHVtblByb3BzW11cbiAgY2hpbGRyZW46IFJlYWN0Tm9kZVxuICAvKipcbiAgICogU2V0IGl0IHRvIHRydWUgaWYgeW91IHdhbnQgdG8gZGlzcGxheSBhIHBsYWNlaG9sZGVyIGR1cmluZyBsb2FkaW5nXG4gICAqICovXG4gIGxvYWRpbmc/OiBib29sZWFuXG4gIC8qKlxuICAgKiBBdXRvIGNvbGxhcHNlIGlzIGNvbGxhcHNpbmcgZXhwYW5kYWJsZSByb3cgd2hlbiBhbm90aGVyIGlzIGV4cGFuZGluZ1xuICAgKiAqL1xuICBhdXRvQ29sbGFwc2U/OiBib29sZWFuXG4gIC8qKlxuICAgKiBBY3Rpb24gd2hlbiBzZWxlY3Rpb24gY2hhbmdlcyAoZ2V0IHRoZSBsaXN0IG9mIHNlbGVjdGVkIHJvd3MpXG4gICAqL1xuICBvblNlbGVjdGVkQ2hhbmdlPzogRGlzcGF0Y2g8U2V0U3RhdGVBY3Rpb248c3RyaW5nW10+PlxufVxuXG5jb25zdCBCYXNlTGlzdCA9IGZvcndhcmRSZWYoXG4gIChcbiAgICB7XG4gICAgICBleHBhbmRhYmxlID0gZmFsc2UsXG4gICAgICBzZWxlY3RhYmxlID0gZmFsc2UsXG4gICAgICBjb2x1bW5zLFxuICAgICAgY2hpbGRyZW4sXG4gICAgICBsb2FkaW5nLFxuICAgICAgYXV0b0NvbGxhcHNlID0gZmFsc2UsXG4gICAgICBvblNlbGVjdGVkQ2hhbmdlLFxuICAgIH06IExpc3RQcm9wcyxcbiAgICByZWY6IEZvcndhcmRlZFJlZjxIVE1MVGFibGVFbGVtZW50PixcbiAgKSA9PiAoXG4gICAgPExpc3RQcm92aWRlclxuICAgICAgc2VsZWN0YWJsZT17c2VsZWN0YWJsZX1cbiAgICAgIGV4cGFuZEJ1dHRvbj17ZXhwYW5kYWJsZX1cbiAgICAgIGF1dG9Db2xsYXBzZT17YXV0b0NvbGxhcHNlfVxuICAgICAgb25TZWxlY3RlZENoYW5nZT17b25TZWxlY3RlZENoYW5nZX1cbiAgICAgIGNvbHVtbnM9e2NvbHVtbnN9XG4gICAgPlxuICAgICAgPFRhYmxlQ29udGFpbmVyPlxuICAgICAgICA8U3R5bGVkVGFibGUgcmVmPXtyZWZ9PlxuICAgICAgICAgIDxIZWFkZXJSb3cgaGFzU2VsZWN0QWxsQ29sdW1uPXtzZWxlY3RhYmxlfT5cbiAgICAgICAgICAgIHtjb2x1bW5zLm1hcCgoY29sdW1uLCBpbmRleCkgPT4gKFxuICAgICAgICAgICAgICA8SGVhZGVyQ2VsbFxuICAgICAgICAgICAgICAgIGtleT17YGhlYWRlci1jb2x1bW4tJHtpbmRleH1gfVxuICAgICAgICAgICAgICAgIGlzT3JkZXJlZD17Y29sdW1uLmlzT3JkZXJlZH1cbiAgICAgICAgICAgICAgICBvcmRlckRpcmVjdGlvbj17Y29sdW1uLm9yZGVyRGlyZWN0aW9ufVxuICAgICAgICAgICAgICAgIG9uT3JkZXI9e2NvbHVtbi5vbk9yZGVyfVxuICAgICAgICAgICAgICAgIGluZm89e2NvbHVtbi5pbmZvfVxuICAgICAgICAgICAgICAgIHdpZHRoPXtjb2x1bW4ud2lkdGh9XG4gICAgICAgICAgICAgICAgbWluV2l0aD17Y29sdW1uLm1pbldpZHRofVxuICAgICAgICAgICAgICAgIG1heFdpZHRoPXtjb2x1bW4ubWF4V2lkdGh9XG4gICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICB7Y29sdW1uLmxhYmVsfVxuICAgICAgICAgICAgICA8L0hlYWRlckNlbGw+XG4gICAgICAgICAgICApKX1cbiAgICAgICAgICA8L0hlYWRlclJvdz5cbiAgICAgICAgICA8dGJvZHk+XG4gICAgICAgICAgICB7bG9hZGluZyA/IChcbiAgICAgICAgICAgICAgPFNrZWxldG9uUm93c1xuICAgICAgICAgICAgICAgIHNlbGVjdGFibGU9e3NlbGVjdGFibGV9XG4gICAgICAgICAgICAgICAgcm93cz17NX1cbiAgICAgICAgICAgICAgICBjb2xzPXtjb2x1bW5zLmxlbmd0aH1cbiAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICkgOiAoXG4gICAgICAgICAgICAgIGNoaWxkcmVuXG4gICAgICAgICAgICApfVxuICAgICAgICAgIDwvdGJvZHk+XG4gICAgICAgIDwvU3R5bGVkVGFibGU+XG4gICAgICA8L1RhYmxlQ29udGFpbmVyPlxuICAgIDwvTGlzdFByb3ZpZGVyPlxuICApLFxuKVxuXG4vKipcbiAqIExpc3QgaXMgYSBjb21wb25lbnQgdGhhdCBkaXNwbGF5cyBhIGxpc3Qgb2YgaXRlbXMgYmFzZWQgb24gdGhlIGNvbHVtbnMgeW91IHByb3ZpZGUgYW5kIHRoZSBkYXRhIHlvdSBwYXNzLlxuICovXG5leHBvcnQgY29uc3QgTGlzdCA9IE9iamVjdC5hc3NpZ24oQmFzZUxpc3QsIHtcbiAgUm93LFxuICBDZWxsLFxuICBTZWxlY3RCYXIsXG4gIHVzZUxpc3RDb250ZXh0LFxufSlcbiJdfQ== */"));
|
|
21
37
|
const BaseList = forwardRef(({
|
|
22
38
|
expandable = false,
|
|
23
39
|
selectable = false,
|
|
@@ -26,10 +42,10 @@ const BaseList = forwardRef(({
|
|
|
26
42
|
loading,
|
|
27
43
|
autoCollapse = false,
|
|
28
44
|
onSelectedChange
|
|
29
|
-
}, ref) => /* @__PURE__ */ jsx(ListProvider, { selectable, expandButton: expandable, autoCollapse, onSelectedChange, children: /* @__PURE__ */ jsxs(StyledTable, { ref, children: [
|
|
45
|
+
}, ref) => /* @__PURE__ */ jsx(ListProvider, { selectable, expandButton: expandable, autoCollapse, onSelectedChange, columns, children: /* @__PURE__ */ jsx(TableContainer, { children: /* @__PURE__ */ jsxs(StyledTable, { ref, children: [
|
|
30
46
|
/* @__PURE__ */ jsx(HeaderRow, { hasSelectAllColumn: selectable, children: columns.map((column, index) => /* @__PURE__ */ jsx(HeaderCell, { isOrdered: column.isOrdered, orderDirection: column.orderDirection, onOrder: column.onOrder, info: column.info, width: column.width, minWith: column.minWidth, maxWidth: column.maxWidth, children: column.label }, `header-column-${index}`)) }),
|
|
31
47
|
/* @__PURE__ */ jsx("tbody", { children: loading ? /* @__PURE__ */ jsx(SkeletonRows, { selectable, rows: 5, cols: columns.length }) : children })
|
|
32
|
-
] }) }));
|
|
48
|
+
] }) }) }));
|
|
33
49
|
const List = Object.assign(BaseList, {
|
|
34
50
|
Row,
|
|
35
51
|
Cell,
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { ComponentProps } from 'react';
|
|
2
|
+
import type { HeaderCell } from './HeaderCell';
|
|
3
|
+
export type ColumnProps = Pick<ComponentProps<typeof HeaderCell>, 'isOrdered' | 'onOrder' | 'orderDirection'> & {
|
|
4
|
+
label?: string;
|
|
5
|
+
width?: string;
|
|
6
|
+
minWidth?: string;
|
|
7
|
+
maxWidth?: string;
|
|
8
|
+
info?: string;
|
|
9
|
+
};
|
|
@@ -15,7 +15,7 @@ const StyledContainer = /* @__PURE__ */ _styled__default.default("div", process.
|
|
|
15
15
|
theme
|
|
16
16
|
}) => theme.space["2"], ";right:", ({
|
|
17
17
|
theme
|
|
18
|
-
}) => theme.space["2"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
18
|
+
}) => theme.space["2"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL01vZGFsL01vZGFsQ29udGVudC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBT2tDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL01vZGFsL01vZGFsQ29udGVudC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB0eXBlIHsgQ29tcG9uZW50UHJvcHMgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB0eXBlIHsgTW9kYWwgfSBmcm9tICcuJ1xuaW1wb3J0IHsgQnV0dG9uIH0gZnJvbSAnLi4vQnV0dG9uJ1xuaW1wb3J0IHsgRGlhbG9nIH0gZnJvbSAnLi9jb21wb25lbnRzL0RpYWxvZydcbmltcG9ydCB0eXBlIHsgTW9kYWxQbGFjZW1lbnQsIE1vZGFsU2l6ZSB9IGZyb20gJy4vdHlwZXMnXG5cbmNvbnN0IFN0eWxlZENvbnRhaW5lciA9IHN0eWxlZC5kaXZgXG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgdG9wOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycyJ119O1xuICByaWdodDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMiddfTtcbmBcblxudHlwZSBNb2RhbENvbnRlbnRQcm9wcyA9IENvbXBvbmVudFByb3BzPHR5cGVvZiBNb2RhbD4gJiB7XG4gIHZpc2libGU6IGJvb2xlYW5cbiAgb3BlbjogYm9vbGVhblxuICBvcGVuZWQ6IGJvb2xlYW5cbiAgcGxhY2VtZW50OiBNb2RhbFBsYWNlbWVudFxuICBmaW5hbFNpemU6IE1vZGFsU2l6ZVxuICBmaW5hbElkOiBzdHJpbmdcbiAgaGFuZGxlT3BlbjogKCkgPT4gdm9pZFxuICBoYW5kbGVUb2dnbGU6ICgpID0+IHZvaWRcbiAgaGFuZGxlQ2xvc2U6ICgpID0+IHZvaWRcbiAgZGF0YVRlc3RJZD86IHN0cmluZ1xufVxuXG5leHBvcnQgY29uc3QgTW9kYWxDb250ZW50ID0gKHtcbiAgdmlzaWJsZSxcbiAgb3BlbixcbiAgb3BlbmVkLFxuICBwbGFjZW1lbnQsXG4gIGZpbmFsU2l6ZSxcbiAgYXJpYUxhYmVsLFxuICBoaWRlT25DbGlja091dHNpZGUsXG4gIGhpZGVPbkVzYyxcbiAgcHJldmVudEJvZHlTY3JvbGwsXG4gIGhhbmRsZUNsb3NlLFxuICBjbGFzc05hbWUsXG4gIGJhY2tkcm9wQ2xhc3NOYW1lLFxuICBkYXRhVGVzdElkLFxuICBjdXN0b21EaWFsb2dTdHlsZXMsXG4gIGN1c3RvbURpYWxvZ0JhY2tkcm9wU3R5bGVzLFxuICBpc0Nsb3NhYmxlLFxuICBjaGlsZHJlbixcbiAgaGFuZGxlT3BlbixcbiAgaGFuZGxlVG9nZ2xlLFxuICBmaW5hbElkLFxufTogTW9kYWxDb250ZW50UHJvcHMpID0+XG4gIHZpc2libGUgfHwgb3BlbiB8fCBvcGVuZWQgPyAoXG4gICAgPERpYWxvZ1xuICAgICAgb3Blbj17dmlzaWJsZSB8fCBvcGVuIHx8IG9wZW5lZH1cbiAgICAgIHBsYWNlbWVudD17cGxhY2VtZW50fVxuICAgICAgc2l6ZT17ZmluYWxTaXplfVxuICAgICAgYXJpYUxhYmVsPXthcmlhTGFiZWx9XG4gICAgICBoaWRlT25DbGlja091dHNpZGU9e2hpZGVPbkNsaWNrT3V0c2lkZX1cbiAgICAgIGhpZGVPbkVzYz17aGlkZU9uRXNjfVxuICAgICAgcHJldmVudEJvZHlTY3JvbGw9e3ByZXZlbnRCb2R5U2Nyb2xsfVxuICAgICAgb25DbG9zZT17aGFuZGxlQ2xvc2V9XG4gICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgIGJhY2tkcm9wQ2xhc3NOYW1lPXtiYWNrZHJvcENsYXNzTmFtZX1cbiAgICAgIGRhdGEtdGVzdGlkPXtkYXRhVGVzdElkfVxuICAgICAgaWQ9e2ZpbmFsSWR9XG4gICAgICBkaWFsb2dDc3M9e2N1c3RvbURpYWxvZ1N0eWxlc31cbiAgICAgIGJhY2tkcm9wQ3NzPXtjdXN0b21EaWFsb2dCYWNrZHJvcFN0eWxlc31cbiAgICA+XG4gICAgICA8PlxuICAgICAgICB7dHlwZW9mIGNoaWxkcmVuID09PSAnZnVuY3Rpb24nXG4gICAgICAgICAgPyBjaGlsZHJlbih7XG4gICAgICAgICAgICAgIHZpc2libGUsXG4gICAgICAgICAgICAgIG9uQ2xvc2U6IGhhbmRsZUNsb3NlLFxuICAgICAgICAgICAgICBvbk9wZW46IGhhbmRsZU9wZW4sXG4gICAgICAgICAgICAgIHRvZ2dsZTogaGFuZGxlVG9nZ2xlLFxuICAgICAgICAgICAgICBtb2RhbElkOiBmaW5hbElkLFxuICAgICAgICAgICAgICBoaWRlOiBoYW5kbGVDbG9zZSxcbiAgICAgICAgICAgICAgY2xvc2U6IGhhbmRsZUNsb3NlLFxuICAgICAgICAgICAgICBzaG93OiBoYW5kbGVPcGVuLFxuICAgICAgICAgICAgfSlcbiAgICAgICAgICA6IGNoaWxkcmVufVxuICAgICAgICA8U3R5bGVkQ29udGFpbmVyPlxuICAgICAgICAgIHtpc0Nsb3NhYmxlID8gKFxuICAgICAgICAgICAgPEJ1dHRvblxuICAgICAgICAgICAgICBkYXRhLXRlc3RpZD17XG4gICAgICAgICAgICAgICAgZGF0YVRlc3RJZCA/IGAke2RhdGFUZXN0SWR9LWNsb3NlLWJ1dHRvbmAgOiB1bmRlZmluZWRcbiAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICBvbkNsaWNrPXtoYW5kbGVDbG9zZX1cbiAgICAgICAgICAgICAgdmFyaWFudD1cImdob3N0XCJcbiAgICAgICAgICAgICAgc2l6ZT1cInNtYWxsXCJcbiAgICAgICAgICAgICAgaWNvbj1cImNsb3NlXCJcbiAgICAgICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgICAgIGFyaWEtbGFiZWw9XCJjbG9zZVwiXG4gICAgICAgICAgICAvPlxuICAgICAgICAgICkgOiBudWxsfVxuICAgICAgICA8L1N0eWxlZENvbnRhaW5lcj5cbiAgICAgIDwvPlxuICAgIDwvRGlhbG9nPlxuICApIDogbnVsbFxuIl19 */"));
|
|
19
19
|
const ModalContent = ({
|
|
20
20
|
visible,
|
|
21
21
|
open,
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import type { ComponentProps } from 'react';
|
|
2
|
-
import type { ModalPlacement, ModalSize } from './types';
|
|
3
2
|
import type { Modal } from '.';
|
|
3
|
+
import type { ModalPlacement, ModalSize } from './types';
|
|
4
4
|
type ModalContentProps = ComponentProps<typeof Modal> & {
|
|
5
5
|
visible: boolean;
|
|
6
6
|
open: boolean;
|
|
@@ -11,7 +11,7 @@ const StyledContainer = /* @__PURE__ */ _styled("div", process.env.NODE_ENV ===
|
|
|
11
11
|
theme
|
|
12
12
|
}) => theme.space["2"], ";right:", ({
|
|
13
13
|
theme
|
|
14
|
-
}) => theme.space["2"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
14
|
+
}) => theme.space["2"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL01vZGFsL01vZGFsQ29udGVudC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBT2tDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL01vZGFsL01vZGFsQ29udGVudC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB0eXBlIHsgQ29tcG9uZW50UHJvcHMgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB0eXBlIHsgTW9kYWwgfSBmcm9tICcuJ1xuaW1wb3J0IHsgQnV0dG9uIH0gZnJvbSAnLi4vQnV0dG9uJ1xuaW1wb3J0IHsgRGlhbG9nIH0gZnJvbSAnLi9jb21wb25lbnRzL0RpYWxvZydcbmltcG9ydCB0eXBlIHsgTW9kYWxQbGFjZW1lbnQsIE1vZGFsU2l6ZSB9IGZyb20gJy4vdHlwZXMnXG5cbmNvbnN0IFN0eWxlZENvbnRhaW5lciA9IHN0eWxlZC5kaXZgXG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgdG9wOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycyJ119O1xuICByaWdodDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMiddfTtcbmBcblxudHlwZSBNb2RhbENvbnRlbnRQcm9wcyA9IENvbXBvbmVudFByb3BzPHR5cGVvZiBNb2RhbD4gJiB7XG4gIHZpc2libGU6IGJvb2xlYW5cbiAgb3BlbjogYm9vbGVhblxuICBvcGVuZWQ6IGJvb2xlYW5cbiAgcGxhY2VtZW50OiBNb2RhbFBsYWNlbWVudFxuICBmaW5hbFNpemU6IE1vZGFsU2l6ZVxuICBmaW5hbElkOiBzdHJpbmdcbiAgaGFuZGxlT3BlbjogKCkgPT4gdm9pZFxuICBoYW5kbGVUb2dnbGU6ICgpID0+IHZvaWRcbiAgaGFuZGxlQ2xvc2U6ICgpID0+IHZvaWRcbiAgZGF0YVRlc3RJZD86IHN0cmluZ1xufVxuXG5leHBvcnQgY29uc3QgTW9kYWxDb250ZW50ID0gKHtcbiAgdmlzaWJsZSxcbiAgb3BlbixcbiAgb3BlbmVkLFxuICBwbGFjZW1lbnQsXG4gIGZpbmFsU2l6ZSxcbiAgYXJpYUxhYmVsLFxuICBoaWRlT25DbGlja091dHNpZGUsXG4gIGhpZGVPbkVzYyxcbiAgcHJldmVudEJvZHlTY3JvbGwsXG4gIGhhbmRsZUNsb3NlLFxuICBjbGFzc05hbWUsXG4gIGJhY2tkcm9wQ2xhc3NOYW1lLFxuICBkYXRhVGVzdElkLFxuICBjdXN0b21EaWFsb2dTdHlsZXMsXG4gIGN1c3RvbURpYWxvZ0JhY2tkcm9wU3R5bGVzLFxuICBpc0Nsb3NhYmxlLFxuICBjaGlsZHJlbixcbiAgaGFuZGxlT3BlbixcbiAgaGFuZGxlVG9nZ2xlLFxuICBmaW5hbElkLFxufTogTW9kYWxDb250ZW50UHJvcHMpID0+XG4gIHZpc2libGUgfHwgb3BlbiB8fCBvcGVuZWQgPyAoXG4gICAgPERpYWxvZ1xuICAgICAgb3Blbj17dmlzaWJsZSB8fCBvcGVuIHx8IG9wZW5lZH1cbiAgICAgIHBsYWNlbWVudD17cGxhY2VtZW50fVxuICAgICAgc2l6ZT17ZmluYWxTaXplfVxuICAgICAgYXJpYUxhYmVsPXthcmlhTGFiZWx9XG4gICAgICBoaWRlT25DbGlja091dHNpZGU9e2hpZGVPbkNsaWNrT3V0c2lkZX1cbiAgICAgIGhpZGVPbkVzYz17aGlkZU9uRXNjfVxuICAgICAgcHJldmVudEJvZHlTY3JvbGw9e3ByZXZlbnRCb2R5U2Nyb2xsfVxuICAgICAgb25DbG9zZT17aGFuZGxlQ2xvc2V9XG4gICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgIGJhY2tkcm9wQ2xhc3NOYW1lPXtiYWNrZHJvcENsYXNzTmFtZX1cbiAgICAgIGRhdGEtdGVzdGlkPXtkYXRhVGVzdElkfVxuICAgICAgaWQ9e2ZpbmFsSWR9XG4gICAgICBkaWFsb2dDc3M9e2N1c3RvbURpYWxvZ1N0eWxlc31cbiAgICAgIGJhY2tkcm9wQ3NzPXtjdXN0b21EaWFsb2dCYWNrZHJvcFN0eWxlc31cbiAgICA+XG4gICAgICA8PlxuICAgICAgICB7dHlwZW9mIGNoaWxkcmVuID09PSAnZnVuY3Rpb24nXG4gICAgICAgICAgPyBjaGlsZHJlbih7XG4gICAgICAgICAgICAgIHZpc2libGUsXG4gICAgICAgICAgICAgIG9uQ2xvc2U6IGhhbmRsZUNsb3NlLFxuICAgICAgICAgICAgICBvbk9wZW46IGhhbmRsZU9wZW4sXG4gICAgICAgICAgICAgIHRvZ2dsZTogaGFuZGxlVG9nZ2xlLFxuICAgICAgICAgICAgICBtb2RhbElkOiBmaW5hbElkLFxuICAgICAgICAgICAgICBoaWRlOiBoYW5kbGVDbG9zZSxcbiAgICAgICAgICAgICAgY2xvc2U6IGhhbmRsZUNsb3NlLFxuICAgICAgICAgICAgICBzaG93OiBoYW5kbGVPcGVuLFxuICAgICAgICAgICAgfSlcbiAgICAgICAgICA6IGNoaWxkcmVufVxuICAgICAgICA8U3R5bGVkQ29udGFpbmVyPlxuICAgICAgICAgIHtpc0Nsb3NhYmxlID8gKFxuICAgICAgICAgICAgPEJ1dHRvblxuICAgICAgICAgICAgICBkYXRhLXRlc3RpZD17XG4gICAgICAgICAgICAgICAgZGF0YVRlc3RJZCA/IGAke2RhdGFUZXN0SWR9LWNsb3NlLWJ1dHRvbmAgOiB1bmRlZmluZWRcbiAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICBvbkNsaWNrPXtoYW5kbGVDbG9zZX1cbiAgICAgICAgICAgICAgdmFyaWFudD1cImdob3N0XCJcbiAgICAgICAgICAgICAgc2l6ZT1cInNtYWxsXCJcbiAgICAgICAgICAgICAgaWNvbj1cImNsb3NlXCJcbiAgICAgICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgICAgIGFyaWEtbGFiZWw9XCJjbG9zZVwiXG4gICAgICAgICAgICAvPlxuICAgICAgICAgICkgOiBudWxsfVxuICAgICAgICA8L1N0eWxlZENvbnRhaW5lcj5cbiAgICAgIDwvPlxuICAgIDwvRGlhbG9nPlxuICApIDogbnVsbFxuIl19 */"));
|
|
15
15
|
const ModalContent = ({
|
|
16
16
|
visible,
|
|
17
17
|
open,
|
|
@@ -7,5 +7,15 @@ export type PositionsType = {
|
|
|
7
7
|
popupInitialPosition: string;
|
|
8
8
|
popupPosition: string;
|
|
9
9
|
};
|
|
10
|
-
export declare const animation: (positions: PositionsType) =>
|
|
11
|
-
|
|
10
|
+
export declare const animation: (positions: PositionsType) => {
|
|
11
|
+
name: string;
|
|
12
|
+
styles: string;
|
|
13
|
+
anim: 1;
|
|
14
|
+
toString: () => string;
|
|
15
|
+
} & string;
|
|
16
|
+
export declare const exitAnimation: (positions: PositionsType) => {
|
|
17
|
+
name: string;
|
|
18
|
+
styles: string;
|
|
19
|
+
anim: 1;
|
|
20
|
+
toString: () => string;
|
|
21
|
+
} & string;
|
|
@@ -7,6 +7,9 @@ const index = require("../Stack/index.cjs");
|
|
|
7
7
|
const index$1 = require("../Text/index.cjs");
|
|
8
8
|
const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
|
|
9
9
|
const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
|
|
10
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__() {
|
|
11
|
+
return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).";
|
|
12
|
+
}
|
|
10
13
|
const shineAnimation = react.keyframes`
|
|
11
14
|
from {
|
|
12
15
|
left: -25%;
|
|
@@ -17,9 +20,9 @@ const shineAnimation = react.keyframes`
|
|
|
17
20
|
}
|
|
18
21
|
`;
|
|
19
22
|
const StyledProgressContainer = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
|
|
20
|
-
target: "
|
|
23
|
+
target: "e1b95x8r4"
|
|
21
24
|
} : {
|
|
22
|
-
target: "
|
|
25
|
+
target: "e1b95x8r4",
|
|
23
26
|
label: "StyledProgressContainer"
|
|
24
27
|
})("overflow:hidden;position:relative;height:", ({
|
|
25
28
|
theme
|
|
@@ -27,18 +30,44 @@ const StyledProgressContainer = /* @__PURE__ */ _styled__default.default("div",
|
|
|
27
30
|
theme
|
|
28
31
|
}) => theme.radii.default, ";background-color:", ({
|
|
29
32
|
theme
|
|
30
|
-
}) => theme.colors.neutral.backgroundStrong, ";width:100%;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
33
|
+
}) => theme.colors.neutral.backgroundStrong, ";width:100%;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/ProgressBar/index.tsx"],"names":[],"mappings":"AAyB0C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/ProgressBar/index.tsx","sourcesContent":["import { keyframes } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport type { Color } from '../../theme'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst shineAnimation = keyframes`\n  from {\n    left: -25%;\n  }\n\n  to {\n    left: 100%;\n  }\n`\n\nexport const progressBarSentiments = [\n  'primary',\n  'success',\n  'warning',\n  'info',\n  'danger',\n] as const\n\nconst StyledProgressContainer = styled.div`\n  overflow: hidden;\n  position: relative;\n  height: ${({ theme }) => theme.sizing['050']};\n  margin-left: 0;\n  margin-right: 0;\n  border-radius: ${({ theme }) => theme.radii.default};\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundStrong};\n  width: 100%;\n`\nconst StyledStack = styled(Stack)`\n  width: fit-content;\n`\nconst StyledText = styled(Text)`\n  width: max-content;\n`\nconst StyledProgress = styled.div`\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  width: 25%;\n  opacity: 0.8;\n  background: linear-gradient(\n    90deg,\n    rgba(255, 255, 255, 0),\n    rgba(255, 255, 255, 0.3),\n    rgba(255, 255, 255, 0.4),\n    rgba(255, 255, 255, 0.3),\n    rgba(255, 255, 255, 0)\n  );\n  animation: ${shineAnimation} 1s linear infinite;\n`\n\nconst StyledFilled = styled('div', {\n  shouldForwardProp: prop => !['sentiment', 'percentageValue'].includes(prop),\n})<{ sentiment: string; percentageValue: number }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  background-color: ${({ theme, sentiment }) =>\n    theme.colors[sentiment as Color].backgroundStrong ?? 'inherit'};\n  transition: 0.3s width;\n  width: ${({ percentageValue }) => percentageValue}%;\n`\n\ntype ProgressBarProps = {\n  sentiment?: (typeof progressBarSentiments)[number]\n  value?: number\n  showProgress?: boolean\n  prefix?: ReactNode\n  suffix?: ReactNode\n  max?: number\n  label?: string\n  labelDescription?: ReactNode\n  direction?: 'column' | 'row'\n  /** Put ProgressBar in a loading state */\n  progress?: boolean\n  className?: string\n  'data-testid'?: string\n  'aria-labelledby'?: string\n  'aria-label'?: string\n}\n\n/**\n * Progress bar component to display progress of a task. Can be used to display progress of a form or a loading state.\n */\nexport const ProgressBar = ({\n  progress = false,\n  value = 0,\n  sentiment = 'primary',\n  className,\n  'data-testid': dataTestId,\n  showProgress = false,\n  prefix,\n  suffix = '%',\n  max = 100,\n  label,\n  labelDescription,\n  direction = 'column',\n  'aria-labelledby': ariaLabelledBy,\n  'aria-label': ariaLabel,\n}: ProgressBarProps) => (\n  <Stack\n    gap={direction === 'column' ? 1 : 2}\n    direction={direction}\n    alignItems=\"center\"\n  >\n    {direction === 'column' && (label || showProgress) ? (\n      <Stack\n        direction=\"row\"\n        justifyContent={!label && showProgress ? 'right' : 'space-between'}\n        width=\"100%\"\n      >\n        <Stack gap={1} direction=\"row\" alignItems=\"center\">\n          {label ? (\n            <Text as=\"label\" variant=\"bodySmallStrong\" sentiment=\"neutral\">\n              {label}\n            </Text>\n          ) : null}\n          {typeof labelDescription === 'string' ? (\n            <Text as=\"label\" variant=\"bodySmall\">\n              {labelDescription}\n            </Text>\n          ) : null}\n          {labelDescription && typeof labelDescription !== 'string'\n            ? labelDescription\n            : null}\n        </Stack>\n        {showProgress ? (\n          <Text\n            as=\"label\"\n            variant=\"bodySmall\"\n            sentiment=\"neutral\"\n            placement=\"right\"\n          >\n            {prefix}\n            {suffix === '%'\n              ? (100 * Math.max(0, Math.min(max, value))) / max\n              : Math.max(0, Math.min(max, value))}\n            {suffix}\n          </Text>\n        ) : null}\n      </Stack>\n    ) : null}\n    {label && direction === 'row' && labelDescription ? (\n      <StyledStack direction=\"row\" gap={1}>\n        <StyledText as=\"label\" variant=\"bodySmallStrong\" sentiment=\"neutral\">\n          {label}\n        </StyledText>\n        {typeof labelDescription === 'string' ? (\n          <Text as=\"label\" variant=\"bodySmall\">\n            {labelDescription}\n          </Text>\n        ) : (\n          labelDescription\n        )}\n      </StyledStack>\n    ) : null}\n    {label && direction === 'row' && !labelDescription ? (\n      <StyledStack direction=\"row\" gap={1}>\n        <StyledText as=\"label\" variant=\"bodySmallStrong\" sentiment=\"neutral\">\n          {label}\n        </StyledText>\n      </StyledStack>\n    ) : null}\n    <StyledProgressContainer\n      role=\"progressbar\"\n      aria-valuenow={value}\n      aria-valuemin={0}\n      aria-valuemax={max}\n      className={className}\n      data-testid={dataTestId}\n      aria-labelledby={ariaLabelledBy}\n      aria-label={ariaLabel}\n    >\n      {progress ? (\n        <StyledProgress />\n      ) : (\n        <StyledFilled\n          sentiment={sentiment}\n          percentageValue={(100 * Math.max(0, Math.min(max, value))) / max}\n        />\n      )}\n    </StyledProgressContainer>\n    {showProgress && direction === 'row' ? (\n      <StyledStack direction=\"row\" gap={1}>\n        <StyledText as=\"label\" variant=\"bodySmall\" sentiment=\"neutral\">\n          {prefix}\n          {suffix === '%'\n            ? (100 * Math.max(0, Math.min(max, value))) / max\n            : Math.max(0, Math.min(max, value))}\n          {suffix}\n        </StyledText>\n      </StyledStack>\n    ) : null}\n  </Stack>\n)\n"]} */"));
|
|
34
|
+
const StyledStack = /* @__PURE__ */ _styled__default.default(index.Stack, process.env.NODE_ENV === "production" ? {
|
|
35
|
+
target: "e1b95x8r3"
|
|
36
|
+
} : {
|
|
37
|
+
target: "e1b95x8r3",
|
|
38
|
+
label: "StyledStack"
|
|
39
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
40
|
+
name: "1tjylrs",
|
|
41
|
+
styles: "width:fit-content"
|
|
42
|
+
} : {
|
|
43
|
+
name: "1tjylrs",
|
|
44
|
+
styles: "width:fit-content/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/ProgressBar/index.tsx"],"names":[],"mappings":"AAmCiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/ProgressBar/index.tsx","sourcesContent":["import { keyframes } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport type { Color } from '../../theme'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst shineAnimation = keyframes`\n  from {\n    left: -25%;\n  }\n\n  to {\n    left: 100%;\n  }\n`\n\nexport const progressBarSentiments = [\n  'primary',\n  'success',\n  'warning',\n  'info',\n  'danger',\n] as const\n\nconst StyledProgressContainer = styled.div`\n  overflow: hidden;\n  position: relative;\n  height: ${({ theme }) => theme.sizing['050']};\n  margin-left: 0;\n  margin-right: 0;\n  border-radius: ${({ theme }) => theme.radii.default};\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundStrong};\n  width: 100%;\n`\nconst StyledStack = styled(Stack)`\n  width: fit-content;\n`\nconst StyledText = styled(Text)`\n  width: max-content;\n`\nconst StyledProgress = styled.div`\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  width: 25%;\n  opacity: 0.8;\n  background: linear-gradient(\n    90deg,\n    rgba(255, 255, 255, 0),\n    rgba(255, 255, 255, 0.3),\n    rgba(255, 255, 255, 0.4),\n    rgba(255, 255, 255, 0.3),\n    rgba(255, 255, 255, 0)\n  );\n  animation: ${shineAnimation} 1s linear infinite;\n`\n\nconst StyledFilled = styled('div', {\n  shouldForwardProp: prop => !['sentiment', 'percentageValue'].includes(prop),\n})<{ sentiment: string; percentageValue: number }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  background-color: ${({ theme, sentiment }) =>\n    theme.colors[sentiment as Color].backgroundStrong ?? 'inherit'};\n  transition: 0.3s width;\n  width: ${({ percentageValue }) => percentageValue}%;\n`\n\ntype ProgressBarProps = {\n  sentiment?: (typeof progressBarSentiments)[number]\n  value?: number\n  showProgress?: boolean\n  prefix?: ReactNode\n  suffix?: ReactNode\n  max?: number\n  label?: string\n  labelDescription?: ReactNode\n  direction?: 'column' | 'row'\n  /** Put ProgressBar in a loading state */\n  progress?: boolean\n  className?: string\n  'data-testid'?: string\n  'aria-labelledby'?: string\n  'aria-label'?: string\n}\n\n/**\n * Progress bar component to display progress of a task. Can be used to display progress of a form or a loading state.\n */\nexport const ProgressBar = ({\n  progress = false,\n  value = 0,\n  sentiment = 'primary',\n  className,\n  'data-testid': dataTestId,\n  showProgress = false,\n  prefix,\n  suffix = '%',\n  max = 100,\n  label,\n  labelDescription,\n  direction = 'column',\n  'aria-labelledby': ariaLabelledBy,\n  'aria-label': ariaLabel,\n}: ProgressBarProps) => (\n  <Stack\n    gap={direction === 'column' ? 1 : 2}\n    direction={direction}\n    alignItems=\"center\"\n  >\n    {direction === 'column' && (label || showProgress) ? (\n      <Stack\n        direction=\"row\"\n        justifyContent={!label && showProgress ? 'right' : 'space-between'}\n        width=\"100%\"\n      >\n        <Stack gap={1} direction=\"row\" alignItems=\"center\">\n          {label ? (\n            <Text as=\"label\" variant=\"bodySmallStrong\" sentiment=\"neutral\">\n              {label}\n            </Text>\n          ) : null}\n          {typeof labelDescription === 'string' ? (\n            <Text as=\"label\" variant=\"bodySmall\">\n              {labelDescription}\n            </Text>\n          ) : null}\n          {labelDescription && typeof labelDescription !== 'string'\n            ? labelDescription\n            : null}\n        </Stack>\n        {showProgress ? (\n          <Text\n            as=\"label\"\n            variant=\"bodySmall\"\n            sentiment=\"neutral\"\n            placement=\"right\"\n          >\n            {prefix}\n            {suffix === '%'\n              ? (100 * Math.max(0, Math.min(max, value))) / max\n              : Math.max(0, Math.min(max, value))}\n            {suffix}\n          </Text>\n        ) : null}\n      </Stack>\n    ) : null}\n    {label && direction === 'row' && labelDescription ? (\n      <StyledStack direction=\"row\" gap={1}>\n        <StyledText as=\"label\" variant=\"bodySmallStrong\" sentiment=\"neutral\">\n          {label}\n        </StyledText>\n        {typeof labelDescription === 'string' ? (\n          <Text as=\"label\" variant=\"bodySmall\">\n            {labelDescription}\n          </Text>\n        ) : (\n          labelDescription\n        )}\n      </StyledStack>\n    ) : null}\n    {label && direction === 'row' && !labelDescription ? (\n      <StyledStack direction=\"row\" gap={1}>\n        <StyledText as=\"label\" variant=\"bodySmallStrong\" sentiment=\"neutral\">\n          {label}\n        </StyledText>\n      </StyledStack>\n    ) : null}\n    <StyledProgressContainer\n      role=\"progressbar\"\n      aria-valuenow={value}\n      aria-valuemin={0}\n      aria-valuemax={max}\n      className={className}\n      data-testid={dataTestId}\n      aria-labelledby={ariaLabelledBy}\n      aria-label={ariaLabel}\n    >\n      {progress ? (\n        <StyledProgress />\n      ) : (\n        <StyledFilled\n          sentiment={sentiment}\n          percentageValue={(100 * Math.max(0, Math.min(max, value))) / max}\n        />\n      )}\n    </StyledProgressContainer>\n    {showProgress && direction === 'row' ? (\n      <StyledStack direction=\"row\" gap={1}>\n        <StyledText as=\"label\" variant=\"bodySmall\" sentiment=\"neutral\">\n          {prefix}\n          {suffix === '%'\n            ? (100 * Math.max(0, Math.min(max, value))) / max\n            : Math.max(0, Math.min(max, value))}\n          {suffix}\n        </StyledText>\n      </StyledStack>\n    ) : null}\n  </Stack>\n)\n"]} */",
|
|
45
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
46
|
+
});
|
|
47
|
+
const StyledText = /* @__PURE__ */ _styled__default.default(index$1.Text, process.env.NODE_ENV === "production" ? {
|
|
48
|
+
target: "e1b95x8r2"
|
|
49
|
+
} : {
|
|
50
|
+
target: "e1b95x8r2",
|
|
51
|
+
label: "StyledText"
|
|
52
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
53
|
+
name: "95qvyx",
|
|
54
|
+
styles: "width:max-content"
|
|
55
|
+
} : {
|
|
56
|
+
name: "95qvyx",
|
|
57
|
+
styles: "width:max-content/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/ProgressBar/index.tsx"],"names":[],"mappings":"AAsC+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/ProgressBar/index.tsx","sourcesContent":["import { keyframes } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport type { Color } from '../../theme'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst shineAnimation = keyframes`\n  from {\n    left: -25%;\n  }\n\n  to {\n    left: 100%;\n  }\n`\n\nexport const progressBarSentiments = [\n  'primary',\n  'success',\n  'warning',\n  'info',\n  'danger',\n] as const\n\nconst StyledProgressContainer = styled.div`\n  overflow: hidden;\n  position: relative;\n  height: ${({ theme }) => theme.sizing['050']};\n  margin-left: 0;\n  margin-right: 0;\n  border-radius: ${({ theme }) => theme.radii.default};\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundStrong};\n  width: 100%;\n`\nconst StyledStack = styled(Stack)`\n  width: fit-content;\n`\nconst StyledText = styled(Text)`\n  width: max-content;\n`\nconst StyledProgress = styled.div`\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  width: 25%;\n  opacity: 0.8;\n  background: linear-gradient(\n    90deg,\n    rgba(255, 255, 255, 0),\n    rgba(255, 255, 255, 0.3),\n    rgba(255, 255, 255, 0.4),\n    rgba(255, 255, 255, 0.3),\n    rgba(255, 255, 255, 0)\n  );\n  animation: ${shineAnimation} 1s linear infinite;\n`\n\nconst StyledFilled = styled('div', {\n  shouldForwardProp: prop => !['sentiment', 'percentageValue'].includes(prop),\n})<{ sentiment: string; percentageValue: number }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  background-color: ${({ theme, sentiment }) =>\n    theme.colors[sentiment as Color].backgroundStrong ?? 'inherit'};\n  transition: 0.3s width;\n  width: ${({ percentageValue }) => percentageValue}%;\n`\n\ntype ProgressBarProps = {\n  sentiment?: (typeof progressBarSentiments)[number]\n  value?: number\n  showProgress?: boolean\n  prefix?: ReactNode\n  suffix?: ReactNode\n  max?: number\n  label?: string\n  labelDescription?: ReactNode\n  direction?: 'column' | 'row'\n  /** Put ProgressBar in a loading state */\n  progress?: boolean\n  className?: string\n  'data-testid'?: string\n  'aria-labelledby'?: string\n  'aria-label'?: string\n}\n\n/**\n * Progress bar component to display progress of a task. Can be used to display progress of a form or a loading state.\n */\nexport const ProgressBar = ({\n  progress = false,\n  value = 0,\n  sentiment = 'primary',\n  className,\n  'data-testid': dataTestId,\n  showProgress = false,\n  prefix,\n  suffix = '%',\n  max = 100,\n  label,\n  labelDescription,\n  direction = 'column',\n  'aria-labelledby': ariaLabelledBy,\n  'aria-label': ariaLabel,\n}: ProgressBarProps) => (\n  <Stack\n    gap={direction === 'column' ? 1 : 2}\n    direction={direction}\n    alignItems=\"center\"\n  >\n    {direction === 'column' && (label || showProgress) ? (\n      <Stack\n        direction=\"row\"\n        justifyContent={!label && showProgress ? 'right' : 'space-between'}\n        width=\"100%\"\n      >\n        <Stack gap={1} direction=\"row\" alignItems=\"center\">\n          {label ? (\n            <Text as=\"label\" variant=\"bodySmallStrong\" sentiment=\"neutral\">\n              {label}\n            </Text>\n          ) : null}\n          {typeof labelDescription === 'string' ? (\n            <Text as=\"label\" variant=\"bodySmall\">\n              {labelDescription}\n            </Text>\n          ) : null}\n          {labelDescription && typeof labelDescription !== 'string'\n            ? labelDescription\n            : null}\n        </Stack>\n        {showProgress ? (\n          <Text\n            as=\"label\"\n            variant=\"bodySmall\"\n            sentiment=\"neutral\"\n            placement=\"right\"\n          >\n            {prefix}\n            {suffix === '%'\n              ? (100 * Math.max(0, Math.min(max, value))) / max\n              : Math.max(0, Math.min(max, value))}\n            {suffix}\n          </Text>\n        ) : null}\n      </Stack>\n    ) : null}\n    {label && direction === 'row' && labelDescription ? (\n      <StyledStack direction=\"row\" gap={1}>\n        <StyledText as=\"label\" variant=\"bodySmallStrong\" sentiment=\"neutral\">\n          {label}\n        </StyledText>\n        {typeof labelDescription === 'string' ? (\n          <Text as=\"label\" variant=\"bodySmall\">\n            {labelDescription}\n          </Text>\n        ) : (\n          labelDescription\n        )}\n      </StyledStack>\n    ) : null}\n    {label && direction === 'row' && !labelDescription ? (\n      <StyledStack direction=\"row\" gap={1}>\n        <StyledText as=\"label\" variant=\"bodySmallStrong\" sentiment=\"neutral\">\n          {label}\n        </StyledText>\n      </StyledStack>\n    ) : null}\n    <StyledProgressContainer\n      role=\"progressbar\"\n      aria-valuenow={value}\n      aria-valuemin={0}\n      aria-valuemax={max}\n      className={className}\n      data-testid={dataTestId}\n      aria-labelledby={ariaLabelledBy}\n      aria-label={ariaLabel}\n    >\n      {progress ? (\n        <StyledProgress />\n      ) : (\n        <StyledFilled\n          sentiment={sentiment}\n          percentageValue={(100 * Math.max(0, Math.min(max, value))) / max}\n        />\n      )}\n    </StyledProgressContainer>\n    {showProgress && direction === 'row' ? (\n      <StyledStack direction=\"row\" gap={1}>\n        <StyledText as=\"label\" variant=\"bodySmall\" sentiment=\"neutral\">\n          {prefix}\n          {suffix === '%'\n            ? (100 * Math.max(0, Math.min(max, value))) / max\n            : Math.max(0, Math.min(max, value))}\n          {suffix}\n        </StyledText>\n      </StyledStack>\n    ) : null}\n  </Stack>\n)\n"]} */",
|
|
58
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
59
|
+
});
|
|
31
60
|
const StyledProgress = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
|
|
32
61
|
target: "e1b95x8r1"
|
|
33
62
|
} : {
|
|
34
63
|
target: "e1b95x8r1",
|
|
35
64
|
label: "StyledProgress"
|
|
36
|
-
})("position:absolute;top:0;left:0;bottom:0;width:25%;opacity:0.8;background:linear-gradient(\n 90deg,\n rgba(255, 255, 255, 0),\n rgba(255, 255, 255, 0.3),\n rgba(255, 255, 255, 0.4),\n rgba(255, 255, 255, 0.3),\n rgba(255, 255, 255, 0)\n );animation:", shineAnimation, " 1s linear infinite;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
65
|
+
})("position:absolute;top:0;left:0;bottom:0;width:25%;opacity:0.8;background:linear-gradient(\n 90deg,\n rgba(255, 255, 255, 0),\n rgba(255, 255, 255, 0.3),\n rgba(255, 255, 255, 0.4),\n rgba(255, 255, 255, 0.3),\n rgba(255, 255, 255, 0)\n );animation:", shineAnimation, " 1s linear infinite;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/ProgressBar/index.tsx"],"names":[],"mappings":"AAyCiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/ProgressBar/index.tsx","sourcesContent":["import { keyframes } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport type { Color } from '../../theme'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst shineAnimation = keyframes`\n  from {\n    left: -25%;\n  }\n\n  to {\n    left: 100%;\n  }\n`\n\nexport const progressBarSentiments = [\n  'primary',\n  'success',\n  'warning',\n  'info',\n  'danger',\n] as const\n\nconst StyledProgressContainer = styled.div`\n  overflow: hidden;\n  position: relative;\n  height: ${({ theme }) => theme.sizing['050']};\n  margin-left: 0;\n  margin-right: 0;\n  border-radius: ${({ theme }) => theme.radii.default};\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundStrong};\n  width: 100%;\n`\nconst StyledStack = styled(Stack)`\n  width: fit-content;\n`\nconst StyledText = styled(Text)`\n  width: max-content;\n`\nconst StyledProgress = styled.div`\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  width: 25%;\n  opacity: 0.8;\n  background: linear-gradient(\n    90deg,\n    rgba(255, 255, 255, 0),\n    rgba(255, 255, 255, 0.3),\n    rgba(255, 255, 255, 0.4),\n    rgba(255, 255, 255, 0.3),\n    rgba(255, 255, 255, 0)\n  );\n  animation: ${shineAnimation} 1s linear infinite;\n`\n\nconst StyledFilled = styled('div', {\n  shouldForwardProp: prop => !['sentiment', 'percentageValue'].includes(prop),\n})<{ sentiment: string; percentageValue: number }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  background-color: ${({ theme, sentiment }) =>\n    theme.colors[sentiment as Color].backgroundStrong ?? 'inherit'};\n  transition: 0.3s width;\n  width: ${({ percentageValue }) => percentageValue}%;\n`\n\ntype ProgressBarProps = {\n  sentiment?: (typeof progressBarSentiments)[number]\n  value?: number\n  showProgress?: boolean\n  prefix?: ReactNode\n  suffix?: ReactNode\n  max?: number\n  label?: string\n  labelDescription?: ReactNode\n  direction?: 'column' | 'row'\n  /** Put ProgressBar in a loading state */\n  progress?: boolean\n  className?: string\n  'data-testid'?: string\n  'aria-labelledby'?: string\n  'aria-label'?: string\n}\n\n/**\n * Progress bar component to display progress of a task. Can be used to display progress of a form or a loading state.\n */\nexport const ProgressBar = ({\n  progress = false,\n  value = 0,\n  sentiment = 'primary',\n  className,\n  'data-testid': dataTestId,\n  showProgress = false,\n  prefix,\n  suffix = '%',\n  max = 100,\n  label,\n  labelDescription,\n  direction = 'column',\n  'aria-labelledby': ariaLabelledBy,\n  'aria-label': ariaLabel,\n}: ProgressBarProps) => (\n  <Stack\n    gap={direction === 'column' ? 1 : 2}\n    direction={direction}\n    alignItems=\"center\"\n  >\n    {direction === 'column' && (label || showProgress) ? (\n      <Stack\n        direction=\"row\"\n        justifyContent={!label && showProgress ? 'right' : 'space-between'}\n        width=\"100%\"\n      >\n        <Stack gap={1} direction=\"row\" alignItems=\"center\">\n          {label ? (\n            <Text as=\"label\" variant=\"bodySmallStrong\" sentiment=\"neutral\">\n              {label}\n            </Text>\n          ) : null}\n          {typeof labelDescription === 'string' ? (\n            <Text as=\"label\" variant=\"bodySmall\">\n              {labelDescription}\n            </Text>\n          ) : null}\n          {labelDescription && typeof labelDescription !== 'string'\n            ? labelDescription\n            : null}\n        </Stack>\n        {showProgress ? (\n          <Text\n            as=\"label\"\n            variant=\"bodySmall\"\n            sentiment=\"neutral\"\n            placement=\"right\"\n          >\n            {prefix}\n            {suffix === '%'\n              ? (100 * Math.max(0, Math.min(max, value))) / max\n              : Math.max(0, Math.min(max, value))}\n            {suffix}\n          </Text>\n        ) : null}\n      </Stack>\n    ) : null}\n    {label && direction === 'row' && labelDescription ? (\n      <StyledStack direction=\"row\" gap={1}>\n        <StyledText as=\"label\" variant=\"bodySmallStrong\" sentiment=\"neutral\">\n          {label}\n        </StyledText>\n        {typeof labelDescription === 'string' ? (\n          <Text as=\"label\" variant=\"bodySmall\">\n            {labelDescription}\n          </Text>\n        ) : (\n          labelDescription\n        )}\n      </StyledStack>\n    ) : null}\n    {label && direction === 'row' && !labelDescription ? (\n      <StyledStack direction=\"row\" gap={1}>\n        <StyledText as=\"label\" variant=\"bodySmallStrong\" sentiment=\"neutral\">\n          {label}\n        </StyledText>\n      </StyledStack>\n    ) : null}\n    <StyledProgressContainer\n      role=\"progressbar\"\n      aria-valuenow={value}\n      aria-valuemin={0}\n      aria-valuemax={max}\n      className={className}\n      data-testid={dataTestId}\n      aria-labelledby={ariaLabelledBy}\n      aria-label={ariaLabel}\n    >\n      {progress ? (\n        <StyledProgress />\n      ) : (\n        <StyledFilled\n          sentiment={sentiment}\n          percentageValue={(100 * Math.max(0, Math.min(max, value))) / max}\n        />\n      )}\n    </StyledProgressContainer>\n    {showProgress && direction === 'row' ? (\n      <StyledStack direction=\"row\" gap={1}>\n        <StyledText as=\"label\" variant=\"bodySmall\" sentiment=\"neutral\">\n          {prefix}\n          {suffix === '%'\n            ? (100 * Math.max(0, Math.min(max, value))) / max\n            : Math.max(0, Math.min(max, value))}\n          {suffix}\n        </StyledText>\n      </StyledStack>\n    ) : null}\n  </Stack>\n)\n"]} */"));
|
|
37
66
|
const StyledFilled = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
|
|
38
|
-
shouldForwardProp: (prop) => !["sentiment", "
|
|
67
|
+
shouldForwardProp: (prop) => !["sentiment", "percentageValue"].includes(prop),
|
|
39
68
|
target: "e1b95x8r0"
|
|
40
69
|
} : {
|
|
41
|
-
shouldForwardProp: (prop) => !["sentiment", "
|
|
70
|
+
shouldForwardProp: (prop) => !["sentiment", "percentageValue"].includes(prop),
|
|
42
71
|
target: "e1b95x8r0",
|
|
43
72
|
label: "StyledFilled"
|
|
44
73
|
})("border-radius:", ({
|
|
@@ -47,8 +76,8 @@ const StyledFilled = /* @__PURE__ */ _styled__default.default("div", process.env
|
|
|
47
76
|
theme,
|
|
48
77
|
sentiment
|
|
49
78
|
}) => theme.colors[sentiment].backgroundStrong ?? "inherit", ";transition:0.3s width;width:", ({
|
|
50
|
-
|
|
51
|
-
}) =>
|
|
79
|
+
percentageValue
|
|
80
|
+
}) => percentageValue, "%;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/ProgressBar/index.tsx"],"names":[],"mappings":"AA6DkD","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/ProgressBar/index.tsx","sourcesContent":["import { keyframes } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport type { Color } from '../../theme'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst shineAnimation = keyframes`\n  from {\n    left: -25%;\n  }\n\n  to {\n    left: 100%;\n  }\n`\n\nexport const progressBarSentiments = [\n  'primary',\n  'success',\n  'warning',\n  'info',\n  'danger',\n] as const\n\nconst StyledProgressContainer = styled.div`\n  overflow: hidden;\n  position: relative;\n  height: ${({ theme }) => theme.sizing['050']};\n  margin-left: 0;\n  margin-right: 0;\n  border-radius: ${({ theme }) => theme.radii.default};\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundStrong};\n  width: 100%;\n`\nconst StyledStack = styled(Stack)`\n  width: fit-content;\n`\nconst StyledText = styled(Text)`\n  width: max-content;\n`\nconst StyledProgress = styled.div`\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  width: 25%;\n  opacity: 0.8;\n  background: linear-gradient(\n    90deg,\n    rgba(255, 255, 255, 0),\n    rgba(255, 255, 255, 0.3),\n    rgba(255, 255, 255, 0.4),\n    rgba(255, 255, 255, 0.3),\n    rgba(255, 255, 255, 0)\n  );\n  animation: ${shineAnimation} 1s linear infinite;\n`\n\nconst StyledFilled = styled('div', {\n  shouldForwardProp: prop => !['sentiment', 'percentageValue'].includes(prop),\n})<{ sentiment: string; percentageValue: number }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  background-color: ${({ theme, sentiment }) =>\n    theme.colors[sentiment as Color].backgroundStrong ?? 'inherit'};\n  transition: 0.3s width;\n  width: ${({ percentageValue }) => percentageValue}%;\n`\n\ntype ProgressBarProps = {\n  sentiment?: (typeof progressBarSentiments)[number]\n  value?: number\n  showProgress?: boolean\n  prefix?: ReactNode\n  suffix?: ReactNode\n  max?: number\n  label?: string\n  labelDescription?: ReactNode\n  direction?: 'column' | 'row'\n  /** Put ProgressBar in a loading state */\n  progress?: boolean\n  className?: string\n  'data-testid'?: string\n  'aria-labelledby'?: string\n  'aria-label'?: string\n}\n\n/**\n * Progress bar component to display progress of a task. Can be used to display progress of a form or a loading state.\n */\nexport const ProgressBar = ({\n  progress = false,\n  value = 0,\n  sentiment = 'primary',\n  className,\n  'data-testid': dataTestId,\n  showProgress = false,\n  prefix,\n  suffix = '%',\n  max = 100,\n  label,\n  labelDescription,\n  direction = 'column',\n  'aria-labelledby': ariaLabelledBy,\n  'aria-label': ariaLabel,\n}: ProgressBarProps) => (\n  <Stack\n    gap={direction === 'column' ? 1 : 2}\n    direction={direction}\n    alignItems=\"center\"\n  >\n    {direction === 'column' && (label || showProgress) ? (\n      <Stack\n        direction=\"row\"\n        justifyContent={!label && showProgress ? 'right' : 'space-between'}\n        width=\"100%\"\n      >\n        <Stack gap={1} direction=\"row\" alignItems=\"center\">\n          {label ? (\n            <Text as=\"label\" variant=\"bodySmallStrong\" sentiment=\"neutral\">\n              {label}\n            </Text>\n          ) : null}\n          {typeof labelDescription === 'string' ? (\n            <Text as=\"label\" variant=\"bodySmall\">\n              {labelDescription}\n            </Text>\n          ) : null}\n          {labelDescription && typeof labelDescription !== 'string'\n            ? labelDescription\n            : null}\n        </Stack>\n        {showProgress ? (\n          <Text\n            as=\"label\"\n            variant=\"bodySmall\"\n            sentiment=\"neutral\"\n            placement=\"right\"\n          >\n            {prefix}\n            {suffix === '%'\n              ? (100 * Math.max(0, Math.min(max, value))) / max\n              : Math.max(0, Math.min(max, value))}\n            {suffix}\n          </Text>\n        ) : null}\n      </Stack>\n    ) : null}\n    {label && direction === 'row' && labelDescription ? (\n      <StyledStack direction=\"row\" gap={1}>\n        <StyledText as=\"label\" variant=\"bodySmallStrong\" sentiment=\"neutral\">\n          {label}\n        </StyledText>\n        {typeof labelDescription === 'string' ? (\n          <Text as=\"label\" variant=\"bodySmall\">\n            {labelDescription}\n          </Text>\n        ) : (\n          labelDescription\n        )}\n      </StyledStack>\n    ) : null}\n    {label && direction === 'row' && !labelDescription ? (\n      <StyledStack direction=\"row\" gap={1}>\n        <StyledText as=\"label\" variant=\"bodySmallStrong\" sentiment=\"neutral\">\n          {label}\n        </StyledText>\n      </StyledStack>\n    ) : null}\n    <StyledProgressContainer\n      role=\"progressbar\"\n      aria-valuenow={value}\n      aria-valuemin={0}\n      aria-valuemax={max}\n      className={className}\n      data-testid={dataTestId}\n      aria-labelledby={ariaLabelledBy}\n      aria-label={ariaLabel}\n    >\n      {progress ? (\n        <StyledProgress />\n      ) : (\n        <StyledFilled\n          sentiment={sentiment}\n          percentageValue={(100 * Math.max(0, Math.min(max, value))) / max}\n        />\n      )}\n    </StyledProgressContainer>\n    {showProgress && direction === 'row' ? (\n      <StyledStack direction=\"row\" gap={1}>\n        <StyledText as=\"label\" variant=\"bodySmall\" sentiment=\"neutral\">\n          {prefix}\n          {suffix === '%'\n            ? (100 * Math.max(0, Math.min(max, value))) / max\n            : Math.max(0, Math.min(max, value))}\n          {suffix}\n        </StyledText>\n      </StyledStack>\n    ) : null}\n  </Stack>\n)\n"]} */"));
|
|
52
81
|
const ProgressBar = ({
|
|
53
82
|
progress = false,
|
|
54
83
|
value = 0,
|
|
@@ -56,6 +85,9 @@ const ProgressBar = ({
|
|
|
56
85
|
className,
|
|
57
86
|
"data-testid": dataTestId,
|
|
58
87
|
showProgress = false,
|
|
88
|
+
prefix,
|
|
89
|
+
suffix = "%",
|
|
90
|
+
max = 100,
|
|
59
91
|
label,
|
|
60
92
|
labelDescription,
|
|
61
93
|
direction = "column",
|
|
@@ -68,14 +100,22 @@ const ProgressBar = ({
|
|
|
68
100
|
typeof labelDescription === "string" ? /* @__PURE__ */ jsxRuntime.jsx(index$1.Text, { as: "label", variant: "bodySmall", children: labelDescription }) : null,
|
|
69
101
|
labelDescription && typeof labelDescription !== "string" ? labelDescription : null
|
|
70
102
|
] }),
|
|
71
|
-
showProgress ? /* @__PURE__ */ jsxRuntime.
|
|
103
|
+
showProgress ? /* @__PURE__ */ jsxRuntime.jsxs(index$1.Text, { as: "label", variant: "bodySmall", sentiment: "neutral", placement: "right", children: [
|
|
104
|
+
prefix,
|
|
105
|
+
suffix === "%" ? 100 * Math.max(0, Math.min(max, value)) / max : Math.max(0, Math.min(max, value)),
|
|
106
|
+
suffix
|
|
107
|
+
] }) : null
|
|
72
108
|
] }) : null,
|
|
73
|
-
label && direction === "row" && labelDescription ? /* @__PURE__ */ jsxRuntime.jsxs(
|
|
74
|
-
/* @__PURE__ */ jsxRuntime.jsx(
|
|
109
|
+
label && direction === "row" && labelDescription ? /* @__PURE__ */ jsxRuntime.jsxs(StyledStack, { direction: "row", gap: 1, children: [
|
|
110
|
+
/* @__PURE__ */ jsxRuntime.jsx(StyledText, { as: "label", variant: "bodySmallStrong", sentiment: "neutral", children: label }),
|
|
75
111
|
typeof labelDescription === "string" ? /* @__PURE__ */ jsxRuntime.jsx(index$1.Text, { as: "label", variant: "bodySmall", children: labelDescription }) : labelDescription
|
|
76
112
|
] }) : null,
|
|
77
|
-
label && direction === "row" && !labelDescription ? /* @__PURE__ */ jsxRuntime.jsx(
|
|
78
|
-
/* @__PURE__ */ jsxRuntime.jsx(StyledProgressContainer, { role: "progressbar", "aria-valuenow": value, "aria-valuemin": 0, "aria-valuemax":
|
|
79
|
-
showProgress && direction === "row" ? /* @__PURE__ */ jsxRuntime.jsx(
|
|
113
|
+
label && direction === "row" && !labelDescription ? /* @__PURE__ */ jsxRuntime.jsx(StyledStack, { direction: "row", gap: 1, children: /* @__PURE__ */ jsxRuntime.jsx(StyledText, { as: "label", variant: "bodySmallStrong", sentiment: "neutral", children: label }) }) : null,
|
|
114
|
+
/* @__PURE__ */ jsxRuntime.jsx(StyledProgressContainer, { role: "progressbar", "aria-valuenow": value, "aria-valuemin": 0, "aria-valuemax": max, className, "data-testid": dataTestId, "aria-labelledby": ariaLabelledBy, "aria-label": ariaLabel, children: progress ? /* @__PURE__ */ jsxRuntime.jsx(StyledProgress, {}) : /* @__PURE__ */ jsxRuntime.jsx(StyledFilled, { sentiment, percentageValue: 100 * Math.max(0, Math.min(max, value)) / max }) }),
|
|
115
|
+
showProgress && direction === "row" ? /* @__PURE__ */ jsxRuntime.jsx(StyledStack, { direction: "row", gap: 1, children: /* @__PURE__ */ jsxRuntime.jsxs(StyledText, { as: "label", variant: "bodySmall", sentiment: "neutral", children: [
|
|
116
|
+
prefix,
|
|
117
|
+
suffix === "%" ? 100 * Math.max(0, Math.min(max, value)) / max : Math.max(0, Math.min(max, value)),
|
|
118
|
+
suffix
|
|
119
|
+
] }) }) : null
|
|
80
120
|
] });
|
|
81
121
|
exports.ProgressBar = ProgressBar;
|
|
@@ -4,6 +4,9 @@ type ProgressBarProps = {
|
|
|
4
4
|
sentiment?: (typeof progressBarSentiments)[number];
|
|
5
5
|
value?: number;
|
|
6
6
|
showProgress?: boolean;
|
|
7
|
+
prefix?: ReactNode;
|
|
8
|
+
suffix?: ReactNode;
|
|
9
|
+
max?: number;
|
|
7
10
|
label?: string;
|
|
8
11
|
labelDescription?: ReactNode;
|
|
9
12
|
direction?: 'column' | 'row';
|
|
@@ -17,5 +20,5 @@ type ProgressBarProps = {
|
|
|
17
20
|
/**
|
|
18
21
|
* Progress bar component to display progress of a task. Can be used to display progress of a form or a loading state.
|
|
19
22
|
*/
|
|
20
|
-
export declare const ProgressBar: ({ progress, value, sentiment, className, "data-testid": dataTestId, showProgress, label, labelDescription, direction, "aria-labelledby": ariaLabelledBy, "aria-label": ariaLabel, }: ProgressBarProps) => import("@emotion/react/jsx-runtime").JSX.Element;
|
|
23
|
+
export declare const ProgressBar: ({ progress, value, sentiment, className, "data-testid": dataTestId, showProgress, prefix, suffix, max, label, labelDescription, direction, "aria-labelledby": ariaLabelledBy, "aria-label": ariaLabel, }: ProgressBarProps) => import("@emotion/react/jsx-runtime").JSX.Element;
|
|
21
24
|
export {};
|