sea-react-components 1.0.2
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/LICENSE +21 -0
- package/README.md +1 -0
- package/dist/HOC/can-access-application/index.d.ts +9 -0
- package/dist/HOC/can-access-application/index.d.ts.map +1 -0
- package/dist/HOC/can-access-application/index.js +11 -0
- package/dist/HOC/with-authorization/index.d.ts +12 -0
- package/dist/HOC/with-authorization/index.d.ts.map +1 -0
- package/dist/HOC/with-authorization/index.js +23 -0
- package/dist/components/alert/index.d.ts +12 -0
- package/dist/components/alert/index.d.ts.map +1 -0
- package/dist/components/alert/index.js +51 -0
- package/dist/components/avatar/index.d.ts +10 -0
- package/dist/components/avatar/index.d.ts.map +1 -0
- package/dist/components/avatar/index.js +26 -0
- package/dist/components/badge/index.d.ts +8 -0
- package/dist/components/badge/index.d.ts.map +1 -0
- package/dist/components/badge/index.js +33 -0
- package/dist/components/breadcrumb/index.d.ts +7 -0
- package/dist/components/breadcrumb/index.d.ts.map +1 -0
- package/dist/components/breadcrumb/index.js +8 -0
- package/dist/components/button/index.d.ts +6 -0
- package/dist/components/button/index.d.ts.map +1 -0
- package/dist/components/button/index.js +18 -0
- package/dist/components/carousel/index.d.ts +17 -0
- package/dist/components/carousel/index.d.ts.map +1 -0
- package/dist/components/carousel/index.js +89 -0
- package/dist/components/checkbox/index.d.ts +11 -0
- package/dist/components/checkbox/index.d.ts.map +1 -0
- package/dist/components/checkbox/index.js +15 -0
- package/dist/components/color-picker/index.d.ts +8 -0
- package/dist/components/color-picker/index.d.ts.map +1 -0
- package/dist/components/color-picker/index.js +21 -0
- package/dist/components/count-down/index.d.ts +6 -0
- package/dist/components/count-down/index.d.ts.map +1 -0
- package/dist/components/count-down/index.js +32 -0
- package/dist/components/drawer/index.d.ts +12 -0
- package/dist/components/drawer/index.d.ts.map +1 -0
- package/dist/components/drawer/index.js +15 -0
- package/dist/components/file-input/components/file-item/index.d.ts +9 -0
- package/dist/components/file-input/components/file-item/index.d.ts.map +1 -0
- package/dist/components/file-input/components/file-item/index.js +10 -0
- package/dist/components/file-input/index.d.ts +44 -0
- package/dist/components/file-input/index.d.ts.map +1 -0
- package/dist/components/file-input/index.js +85 -0
- package/dist/components/icon/index.d.ts +7 -0
- package/dist/components/icon/index.d.ts.map +1 -0
- package/dist/components/icon/index.js +5 -0
- package/dist/components/input/index.d.ts +9 -0
- package/dist/components/input/index.d.ts.map +1 -0
- package/dist/components/input/index.js +33 -0
- package/dist/components/list-item/components/page-button/index.d.ts +8 -0
- package/dist/components/list-item/components/page-button/index.d.ts.map +1 -0
- package/dist/components/list-item/components/page-button/index.js +8 -0
- package/dist/components/list-item/components/pagination/index.d.ts +9 -0
- package/dist/components/list-item/components/pagination/index.d.ts.map +1 -0
- package/dist/components/list-item/components/pagination/index.js +49 -0
- package/dist/components/list-item/components/search-input/index.d.ts +7 -0
- package/dist/components/list-item/components/search-input/index.d.ts.map +1 -0
- package/dist/components/list-item/components/search-input/index.js +38 -0
- package/dist/components/list-item/index.d.ts +26 -0
- package/dist/components/list-item/index.d.ts.map +1 -0
- package/dist/components/list-item/index.js +23 -0
- package/dist/components/loader/index.d.ts +6 -0
- package/dist/components/loader/index.d.ts.map +1 -0
- package/dist/components/loader/index.js +5 -0
- package/dist/components/menu/index.d.ts +9 -0
- package/dist/components/menu/index.d.ts.map +1 -0
- package/dist/components/menu/index.js +19 -0
- package/dist/components/menu/menu-item/index.d.ts +10 -0
- package/dist/components/menu/menu-item/index.d.ts.map +1 -0
- package/dist/components/menu/menu-item/index.js +19 -0
- package/dist/components/modal/index.d.ts +12 -0
- package/dist/components/modal/index.d.ts.map +1 -0
- package/dist/components/modal/index.js +41 -0
- package/dist/components/not-authorized/index.d.ts +2 -0
- package/dist/components/not-authorized/index.d.ts.map +1 -0
- package/dist/components/not-authorized/index.js +5 -0
- package/dist/components/otp-input/index.d.ts +7 -0
- package/dist/components/otp-input/index.d.ts.map +1 -0
- package/dist/components/otp-input/index.js +35 -0
- package/dist/components/paper/index.d.ts +4 -0
- package/dist/components/paper/index.d.ts.map +1 -0
- package/dist/components/paper/index.js +17 -0
- package/dist/components/progress-bar/index.d.ts +11 -0
- package/dist/components/progress-bar/index.d.ts.map +1 -0
- package/dist/components/progress-bar/index.js +32 -0
- package/dist/components/radio-button/index.d.ts +10 -0
- package/dist/components/radio-button/index.d.ts.map +1 -0
- package/dist/components/radio-button/index.js +17 -0
- package/dist/components/select/index.d.ts +16 -0
- package/dist/components/select/index.d.ts.map +1 -0
- package/dist/components/select/index.js +36 -0
- package/dist/components/skeleton/index.d.ts +4 -0
- package/dist/components/skeleton/index.d.ts.map +1 -0
- package/dist/components/skeleton/index.js +5 -0
- package/dist/components/stacked-avatars/index.d.ts +10 -0
- package/dist/components/stacked-avatars/index.d.ts.map +1 -0
- package/dist/components/stacked-avatars/index.js +23 -0
- package/dist/components/tab/index.d.ts +16 -0
- package/dist/components/tab/index.d.ts.map +1 -0
- package/dist/components/tab/index.js +23 -0
- package/dist/components/table/index.d.ts +22 -0
- package/dist/components/table/index.d.ts.map +1 -0
- package/dist/components/table/index.js +67 -0
- package/dist/components/text-editor/components/toolbar/index.d.ts +9 -0
- package/dist/components/text-editor/components/toolbar/index.d.ts.map +1 -0
- package/dist/components/text-editor/components/toolbar/index.js +280 -0
- package/dist/components/text-editor/index.d.ts +12 -0
- package/dist/components/text-editor/index.d.ts.map +1 -0
- package/dist/components/text-editor/index.js +152 -0
- package/dist/components/text-editor/style.css +132 -0
- package/dist/components/text-editor/utils/index.d.ts +14 -0
- package/dist/components/text-editor/utils/index.d.ts.map +1 -0
- package/dist/components/text-editor/utils/index.js +82 -0
- package/dist/components/textarea/index.d.ts +7 -0
- package/dist/components/textarea/index.d.ts.map +1 -0
- package/dist/components/textarea/index.js +24 -0
- package/dist/components/toggle/index.d.ts +8 -0
- package/dist/components/toggle/index.d.ts.map +1 -0
- package/dist/components/toggle/index.js +12 -0
- package/dist/components/tooltip/index.d.ts +10 -0
- package/dist/components/tooltip/index.d.ts.map +1 -0
- package/dist/components/tooltip/index.js +15 -0
- package/dist/components/tree-checkbox/components/tree-checkbox-item/index.d.ts +10 -0
- package/dist/components/tree-checkbox/components/tree-checkbox-item/index.d.ts.map +1 -0
- package/dist/components/tree-checkbox/components/tree-checkbox-item/index.js +10 -0
- package/dist/components/tree-checkbox/index.d.ts +26 -0
- package/dist/components/tree-checkbox/index.d.ts.map +1 -0
- package/dist/components/tree-checkbox/index.js +62 -0
- package/dist/components/tree-checkbox/utils/index.d.ts +9 -0
- package/dist/components/tree-checkbox/utils/index.d.ts.map +1 -0
- package/dist/components/tree-checkbox/utils/index.js +14 -0
- package/dist/constants/index.d.ts +2 -0
- package/dist/constants/index.d.ts.map +1 -0
- package/dist/constants/index.js +1 -0
- package/dist/hooks/list-items-hook/types.d.ts +18 -0
- package/dist/hooks/list-items-hook/types.d.ts.map +1 -0
- package/dist/hooks/list-items-hook/types.js +1 -0
- package/dist/hooks/list-items-hook/useBulkActions.d.ts +3 -0
- package/dist/hooks/list-items-hook/useBulkActions.d.ts.map +1 -0
- package/dist/hooks/list-items-hook/useBulkActions.js +8 -0
- package/dist/hooks/list-items-hook/useFilters.d.ts +3 -0
- package/dist/hooks/list-items-hook/useFilters.d.ts.map +1 -0
- package/dist/hooks/list-items-hook/useFilters.js +27 -0
- package/dist/hooks/list-items-hook/usePagination.d.ts +2 -0
- package/dist/hooks/list-items-hook/usePagination.d.ts.map +1 -0
- package/dist/hooks/list-items-hook/usePagination.js +21 -0
- package/dist/index.d.ts +40 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +42 -0
- package/dist/styles.css +7 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/dist/utils/axios/index.d.ts +7 -0
- package/dist/utils/axios/index.d.ts.map +1 -0
- package/dist/utils/axios/index.js +23 -0
- package/dist/utils/color/index.d.ts +7 -0
- package/dist/utils/color/index.d.ts.map +1 -0
- package/dist/utils/color/index.js +22 -0
- package/dist/utils/file/index.d.ts +2 -0
- package/dist/utils/file/index.d.ts.map +1 -0
- package/dist/utils/file/index.js +8 -0
- package/dist/utils/jwt/index.d.ts +2 -0
- package/dist/utils/jwt/index.d.ts.map +1 -0
- package/dist/utils/jwt/index.js +1 -0
- package/dist/utils/validation/index.d.ts +10 -0
- package/dist/utils/validation/index.d.ts.map +1 -0
- package/dist/utils/validation/index.js +20 -0
- package/package.json +66 -0
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import React, { LegacyRef } from "react";
|
|
2
|
+
export type Props = {
|
|
3
|
+
ref?: LegacyRef<HTMLTextAreaElement> | undefined;
|
|
4
|
+
errorMessage?: string | boolean;
|
|
5
|
+
} & React.TextareaHTMLAttributes<HTMLTextAreaElement>;
|
|
6
|
+
export default function Textarea({ errorMessage, className, ref, ...props }: Props): import("react/jsx-runtime").JSX.Element;
|
|
7
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/textarea/index.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,EAAE,SAAS,EAAY,MAAM,OAAO,CAAC;AAEnD,MAAM,MAAM,KAAK,GAAG;IAClB,GAAG,CAAC,EAAE,SAAS,CAAC,mBAAmB,CAAC,GAAG,SAAS,CAAC;IACjD,YAAY,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC;CACjC,GAAG,KAAK,CAAC,sBAAsB,CAAC,mBAAmB,CAAC,CAAC;AACtD,MAAM,CAAC,OAAO,UAAU,QAAQ,CAAC,EAC/B,YAAY,EACZ,SAAS,EACT,GAAG,EACH,GAAG,KAAK,EACT,EAAE,KAAK,2CA4BP"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
var __rest = (this && this.__rest) || function (s, e) {
|
|
3
|
+
var t = {};
|
|
4
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
|
|
5
|
+
t[p] = s[p];
|
|
6
|
+
if (s != null && typeof Object.getOwnPropertySymbols === "function")
|
|
7
|
+
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
|
|
8
|
+
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
|
|
9
|
+
t[p[i]] = s[p[i]];
|
|
10
|
+
}
|
|
11
|
+
return t;
|
|
12
|
+
};
|
|
13
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
14
|
+
import clsx from "clsx";
|
|
15
|
+
import { useState } from "react";
|
|
16
|
+
export default function Textarea(_a) {
|
|
17
|
+
var { errorMessage, className, ref } = _a, props = __rest(_a, ["errorMessage", "className", "ref"]);
|
|
18
|
+
const [isFocused, setIsFocused] = useState(false);
|
|
19
|
+
return (_jsxs("div", { className: "flex flex-col gap-1", children: [_jsx("div", { className: clsx("flex items-center justify-between gap-2 bg-white px-3 py-2 rounded-xl border-0.5 hover:border-primary", errorMessage
|
|
20
|
+
? "border-error"
|
|
21
|
+
: isFocused
|
|
22
|
+
? "border-primary"
|
|
23
|
+
: "border-gray-200"), children: _jsx("textarea", Object.assign({ ref: ref, onFocus: () => setIsFocused(true), onBlur: () => setIsFocused(false), className: clsx("outline-none text-text flex-1", className) }, props)) }), errorMessage && (_jsx("p", { className: "pl-1 text-sm text-error", children: errorMessage }))] }));
|
|
24
|
+
}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export type Props = {
|
|
2
|
+
checked: boolean;
|
|
3
|
+
onChange: (checked: boolean) => void;
|
|
4
|
+
label?: string;
|
|
5
|
+
disabled?: boolean;
|
|
6
|
+
};
|
|
7
|
+
export default function Toggle({ checked, onChange, label, disabled }: Props): import("react/jsx-runtime").JSX.Element;
|
|
8
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/toggle/index.tsx"],"names":[],"mappings":"AAGA,MAAM,MAAM,KAAK,GAAG;IAClB,OAAO,EAAE,OAAO,CAAC;IACjB,QAAQ,EAAE,CAAC,OAAO,EAAE,OAAO,KAAK,IAAI,CAAC;IACrC,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB,CAAC;AACF,MAAM,CAAC,OAAO,UAAU,MAAM,CAAC,EAAE,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE,EAAE,KAAK,2CAqC3E"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import clsx from "clsx";
|
|
3
|
+
export default function Toggle({ checked, onChange, label, disabled }) {
|
|
4
|
+
const handleChange = (e) => {
|
|
5
|
+
onChange(e.target.checked);
|
|
6
|
+
};
|
|
7
|
+
return (_jsxs("label", { className: "flex items-center space-x-3 cursor-pointer select-none", children: [label && (_jsx("span", { className: "text-sm font-medium text-gray-700", children: label })), _jsxs("div", { className: "relative", children: [_jsx("input", { type: "checkbox", className: "sr-only", checked: checked, onChange: handleChange, disabled: disabled }), _jsx("div", { className: clsx("block w-10 h-6 rounded-full transition", disabled
|
|
8
|
+
? "bg-gray-300"
|
|
9
|
+
: checked
|
|
10
|
+
? "bg-primary"
|
|
11
|
+
: "bg-primary bg-opacity-40") }), _jsx("div", { className: clsx("absolute top-1 left-1 h-4 w-4 bg-white rounded-full transition", checked ? "translate-x-4" : "") })] })] }));
|
|
12
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { ReactNode } from "react";
|
|
2
|
+
export type Props = {
|
|
3
|
+
text: string;
|
|
4
|
+
children: ReactNode;
|
|
5
|
+
placement?: "top" | "bottom" | "left" | "right";
|
|
6
|
+
containerClassName?: string;
|
|
7
|
+
textClassName?: string;
|
|
8
|
+
};
|
|
9
|
+
export default function Tooltip({ text, children, placement, containerClassName, textClassName, }: Props): import("react/jsx-runtime").JSX.Element;
|
|
10
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/tooltip/index.tsx"],"names":[],"mappings":"AAEA,OAAc,EAAE,SAAS,EAAY,MAAM,OAAO,CAAC;AAEnD,MAAM,MAAM,KAAK,GAAG;IAClB,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,SAAS,CAAC;IACpB,SAAS,CAAC,EAAE,KAAK,GAAG,QAAQ,GAAG,MAAM,GAAG,OAAO,CAAC;IAChD,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB,CAAC;AAEF,MAAM,CAAC,OAAO,UAAU,OAAO,CAAC,EAC9B,IAAI,EACJ,QAAQ,EACR,SAAiB,EACjB,kBAAiC,EACjC,aAA4B,GAC7B,EAAE,KAAK,2CA+BP"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsxs as _jsxs, jsx as _jsx } from "react/jsx-runtime";
|
|
3
|
+
import clsx from "clsx";
|
|
4
|
+
import { useState } from "react";
|
|
5
|
+
export default function Tooltip({ text, children, placement = "top", containerClassName = "bg-primary", textClassName = "text-white", }) {
|
|
6
|
+
const [visible, setVisible] = useState(false);
|
|
7
|
+
// Define position classes based on the placement prop
|
|
8
|
+
const positionClasses = {
|
|
9
|
+
top: "bottom-full mb-2 left-1/2 transform -translate-x-1/2",
|
|
10
|
+
bottom: "top-full mt-2 left-1/2 transform -translate-x-1/2",
|
|
11
|
+
left: "right-full mr-2 top-1/2 transform -translate-y-1/2",
|
|
12
|
+
right: "left-full ml-2 top-1/2 transform -translate-y-1/2",
|
|
13
|
+
};
|
|
14
|
+
return (_jsxs("div", { className: "relative inline-block", onMouseEnter: () => setVisible(true), onMouseLeave: () => setVisible(false), children: [children, visible && (_jsx("div", { className: clsx("absolute px-2 py-1 rounded shadow-lg", positionClasses[placement], containerClassName), children: _jsxs("p", { className: textClassName, children: [" ", text] }) }))] }));
|
|
15
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { TreeNode } from "../..";
|
|
2
|
+
type Props<K> = {
|
|
3
|
+
name: string;
|
|
4
|
+
node: TreeNode<K>;
|
|
5
|
+
readonly: boolean;
|
|
6
|
+
onChange: (nodeKey: K, checked: boolean) => void;
|
|
7
|
+
};
|
|
8
|
+
export default function TreeCheckboxItem<K>({ name, node, readonly, onChange, }: Props<K>): import("react/jsx-runtime").JSX.Element;
|
|
9
|
+
export {};
|
|
10
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/components/tree-checkbox/components/tree-checkbox-item/index.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAGjC,KAAK,KAAK,CAAC,CAAC,IAAI;IACd,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC;IAClB,QAAQ,EAAE,OAAO,CAAC;IAClB,QAAQ,EAAE,CAAC,OAAO,EAAE,CAAC,EAAE,OAAO,EAAE,OAAO,KAAK,IAAI,CAAC;CAClD,CAAC;AACF,MAAM,CAAC,OAAO,UAAU,gBAAgB,CAAC,CAAC,EAAE,EAC1C,IAAI,EACJ,IAAI,EACJ,QAAQ,EACR,QAAQ,GACT,EAAE,KAAK,CAAC,CAAC,CAAC,2CA8BV"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import Checkbox from "../../../checkbox";
|
|
4
|
+
export default function TreeCheckboxItem({ name, node, readonly, onChange, }) {
|
|
5
|
+
const handleCheckboxChange = (checked) => {
|
|
6
|
+
onChange(node.key, checked);
|
|
7
|
+
};
|
|
8
|
+
return (_jsxs("div", { className: "flex flex-col gap-3", children: [_jsxs("div", { className: "flex gap-3 items-center", children: [_jsx(Checkbox, { checked: node.checked !== "none", semiChecked: node.checked === "some", onChange: (checked) => handleCheckboxChange(checked), disabled: readonly }), _jsx("p", { children: node.label })] }), node.children &&
|
|
9
|
+
node.children.map((n) => (_jsx("div", { className: "pl-5", children: _jsx(TreeCheckboxItem, { name: name, node: n, readonly: readonly, onChange: onChange }) }, `${name}-${n.key}`)))] }));
|
|
10
|
+
}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
export declare const Utils: {
|
|
2
|
+
makeTreeNode: <T, K>(data: T, keys: {
|
|
3
|
+
key: keyof T;
|
|
4
|
+
label: keyof T;
|
|
5
|
+
isLeaf: keyof T;
|
|
6
|
+
checked: keyof T;
|
|
7
|
+
children: keyof T;
|
|
8
|
+
}) => TreeNode<K>;
|
|
9
|
+
};
|
|
10
|
+
export type CheckedValues = "all" | "some" | "none";
|
|
11
|
+
export type TreeNode<K> = {
|
|
12
|
+
key: K;
|
|
13
|
+
label: string;
|
|
14
|
+
isLeaf: boolean;
|
|
15
|
+
checked: CheckedValues;
|
|
16
|
+
children?: TreeNode<K>[];
|
|
17
|
+
};
|
|
18
|
+
export type Props<K> = {
|
|
19
|
+
name: string;
|
|
20
|
+
nodes: TreeNode<K>[];
|
|
21
|
+
readonly?: boolean;
|
|
22
|
+
onChange: (checkedLeafNodes: TreeNode<K>[], checkedNodes: TreeNode<K>[]) => void;
|
|
23
|
+
};
|
|
24
|
+
declare const TreeCheckbox: <K>({ name, nodes, onChange, readonly, }: Props<K>) => import("react/jsx-runtime").JSX.Element;
|
|
25
|
+
export default TreeCheckbox;
|
|
26
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/tree-checkbox/index.tsx"],"names":[],"mappings":"AAOA,eAAO,MAAM,KAAK;;;;;;;;CAAmB,CAAC;AAEtC,MAAM,MAAM,aAAa,GAAG,KAAK,GAAG,MAAM,GAAG,MAAM,CAAC;AAEpD,MAAM,MAAM,QAAQ,CAAC,CAAC,IAAI;IACxB,GAAG,EAAE,CAAC,CAAC;IACP,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,OAAO,CAAC;IAChB,OAAO,EAAE,aAAa,CAAC;IACvB,QAAQ,CAAC,EAAE,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC;CAC1B,CAAC;AAEF,MAAM,MAAM,KAAK,CAAC,CAAC,IAAI;IACrB,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC;IACrB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,QAAQ,EAAE,CACR,gBAAgB,EAAE,QAAQ,CAAC,CAAC,CAAC,EAAE,EAC/B,YAAY,EAAE,QAAQ,CAAC,CAAC,CAAC,EAAE,KACxB,IAAI,CAAC;CACX,CAAC;AAEF,QAAA,MAAM,YAAY,GAAI,CAAC,wCAKpB,KAAK,CAAC,CAAC,CAAC,4CAwHV,CAAC;AAEF,eAAe,YAAY,CAAC"}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
3
|
+
import { useEffect, useState } from "react";
|
|
4
|
+
import TreeCheckboxItem from "./components/tree-checkbox-item";
|
|
5
|
+
import { makeTreeNode } from "./utils";
|
|
6
|
+
import { Utils as U } from "sea-platform-helpers";
|
|
7
|
+
export const Utils = { makeTreeNode };
|
|
8
|
+
const TreeCheckbox = ({ name, nodes, onChange, readonly = false, }) => {
|
|
9
|
+
const [currentNodes, setCurrentNodes] = useState([]);
|
|
10
|
+
useEffect(() => {
|
|
11
|
+
setCurrentNodes(nodes);
|
|
12
|
+
}, [nodes]);
|
|
13
|
+
useEffect(() => {
|
|
14
|
+
const flattenArrays = currentNodes.map((node) => U.Tree.flattenTree(node, "children"));
|
|
15
|
+
const flattenNodes = flattenArrays.reduce((acc, curr) => acc.concat(curr), []);
|
|
16
|
+
const checkedNodes = flattenNodes.filter((n) => n.checked !== "none");
|
|
17
|
+
const checkedLeafNodes = checkedNodes.filter((n) => n.checked === "all" && n.isLeaf);
|
|
18
|
+
onChange(checkedLeafNodes, checkedNodes);
|
|
19
|
+
}, [currentNodes]);
|
|
20
|
+
const updateParentCheckStatus = (node) => {
|
|
21
|
+
if (!node.children || node.children.length === 0) {
|
|
22
|
+
return node.checked;
|
|
23
|
+
}
|
|
24
|
+
const allChildrenChecked = node.children.every((child) => child.checked === "all");
|
|
25
|
+
if (allChildrenChecked)
|
|
26
|
+
return "all";
|
|
27
|
+
const someChildrenChecked = node.children.some((child) => child.checked !== "none");
|
|
28
|
+
if (someChildrenChecked)
|
|
29
|
+
return "some";
|
|
30
|
+
return "none";
|
|
31
|
+
};
|
|
32
|
+
const updateChildCheckStatus = (node, newStatus) => {
|
|
33
|
+
var _a;
|
|
34
|
+
return Object.assign(Object.assign({}, node), { checked: newStatus, children: (_a = node.children) === null || _a === void 0 ? void 0 : _a.map((child) => updateChildCheckStatus(child, newStatus)) });
|
|
35
|
+
};
|
|
36
|
+
const handleCheckNodeRecursive = (nodes, nodeKey, checked) => {
|
|
37
|
+
return nodes.map((node) => {
|
|
38
|
+
// Check if the current node matches the key
|
|
39
|
+
if (node.key === nodeKey) {
|
|
40
|
+
const newChecked = checked ? "all" : "none";
|
|
41
|
+
return Object.assign(Object.assign({}, node), { checked: newChecked, children: node.children
|
|
42
|
+
? node.children.map((child) => updateChildCheckStatus(child, newChecked))
|
|
43
|
+
: undefined });
|
|
44
|
+
}
|
|
45
|
+
// If it doesn't match, recursively update the children
|
|
46
|
+
if (node.children) {
|
|
47
|
+
const updatedChildren = handleCheckNodeRecursive(node.children, nodeKey, checked);
|
|
48
|
+
const updatedNode = Object.assign(Object.assign({}, node), { children: updatedChildren });
|
|
49
|
+
// Update the parent's status based on the children's status
|
|
50
|
+
return Object.assign(Object.assign({}, updatedNode), { checked: updateParentCheckStatus(updatedNode) });
|
|
51
|
+
}
|
|
52
|
+
// If it's a leaf node and doesn't match, return as is
|
|
53
|
+
return node;
|
|
54
|
+
});
|
|
55
|
+
};
|
|
56
|
+
const handleChange = (nodeKey, checked) => {
|
|
57
|
+
const newCurrentNodes = handleCheckNodeRecursive(currentNodes, nodeKey, checked);
|
|
58
|
+
setCurrentNodes(newCurrentNodes);
|
|
59
|
+
};
|
|
60
|
+
return (_jsx("div", { className: "flex flex-col gap-3", children: currentNodes.map((n) => (_jsx(TreeCheckboxItem, { name: name, node: n, readonly: readonly, onChange: handleChange }, `${name}-${n.key}`))) }));
|
|
61
|
+
};
|
|
62
|
+
export default TreeCheckbox;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/tree-checkbox/utils/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,IAAI,CAAC;AAE9B,eAAO,MAAM,YAAY,GAAI,CAAC,EAAE,CAAC,QACzB,CAAC,QACD;IACJ,GAAG,EAAE,MAAM,CAAC,CAAC;IACb,KAAK,EAAE,MAAM,CAAC,CAAC;IACf,MAAM,EAAE,MAAM,CAAC,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC,CAAC;CACnB,gBAgBF,CAAC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
export const makeTreeNode = (data, keys) => {
|
|
2
|
+
const node = {
|
|
3
|
+
key: data[keys.key],
|
|
4
|
+
label: data[keys.label],
|
|
5
|
+
isLeaf: data[keys.isLeaf],
|
|
6
|
+
checked: data[keys.checked],
|
|
7
|
+
children: [],
|
|
8
|
+
};
|
|
9
|
+
const children = data[keys.children];
|
|
10
|
+
if (children) {
|
|
11
|
+
node["children"] = children.map((n) => makeTreeNode(n, keys));
|
|
12
|
+
}
|
|
13
|
+
return node;
|
|
14
|
+
};
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export declare const PROFILE_PLACEHOLDER_IMAGE = "";
|
|
2
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/constants/index.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,yBAAyB,4qnDACqonD,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export const PROFILE_PLACEHOLDER_IMAGE = "";
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
export interface Option<T> {
|
|
2
|
+
value: T;
|
|
3
|
+
label: string;
|
|
4
|
+
}
|
|
5
|
+
export type Filter<K> = {
|
|
6
|
+
name: string;
|
|
7
|
+
label?: string | undefined;
|
|
8
|
+
options: Option<K>[];
|
|
9
|
+
value: K;
|
|
10
|
+
setValue: (newValue: K) => void;
|
|
11
|
+
};
|
|
12
|
+
export type BulkActionFeature = {
|
|
13
|
+
selectedRowIds: string[];
|
|
14
|
+
setSelectedRowIds: (ids: string[]) => void;
|
|
15
|
+
bulkActions: React.ButtonHTMLAttributes<HTMLButtonElement>[];
|
|
16
|
+
};
|
|
17
|
+
export declare const DEFAULT_FILTER_VALUE = "all";
|
|
18
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/hooks/list-items-hook/types.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,MAAM,CAAC,CAAC;IACvB,KAAK,EAAE,CAAC,CAAC;IACT,KAAK,EAAE,MAAM,CAAC;CACf;AAED,MAAM,MAAM,MAAM,CAAC,CAAC,IAAI;IACtB,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;IAC3B,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC;IACrB,KAAK,EAAE,CAAC,CAAC;IACT,QAAQ,EAAE,CAAC,QAAQ,EAAE,CAAC,KAAK,IAAI,CAAC;CACjC,CAAC;AAEF,MAAM,MAAM,iBAAiB,GAAG;IAC9B,cAAc,EAAE,MAAM,EAAE,CAAC;IACzB,iBAAiB,EAAE,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,IAAI,CAAC;IAC3C,WAAW,EAAE,KAAK,CAAC,oBAAoB,CAAC,iBAAiB,CAAC,EAAE,CAAC;CAC9D,CAAC;AAEF,eAAO,MAAM,oBAAoB,QAAQ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export const DEFAULT_FILTER_VALUE = "all";
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useBulkActions.d.ts","sourceRoot":"","sources":["../../../src/hooks/list-items-hook/useBulkActions.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,iBAAiB,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAEpD,wBAAgB,cAAc,CAAC,CAAC,EAC9B,iBAAiB,EAAE,iBAAiB,GAAG,SAAS,EAChD,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,EACpB,KAAK,EAAE,MAAM,QAOd"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useFilters.d.ts","sourceRoot":"","sources":["../../../src/hooks/list-items-hook/useFilters.ts"],"names":[],"mappings":"AACA,OAAO,EAAwB,MAAM,EAAE,MAAM,SAAS,CAAC;AAEvD,wBAAgB,UAAU,CAAC,CAAC,EAC1B,IAAI,EAAE,MAAM,EACZ,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,EACpB,YAAY,CAAC,EAAE,CAAC,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,KAAK,IAAI,EACxD,QAAQ,CAAC,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,MAAM,GAAG,IAAI,GAAG,SAAS,QA2BvD"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { useEffect } from "react";
|
|
2
|
+
import { DEFAULT_FILTER_VALUE } from "./types";
|
|
3
|
+
export function useFilters(name, filters, updateParams, getParam) {
|
|
4
|
+
const paramNames = filters.reduce((acc, f) => {
|
|
5
|
+
acc[f.name] = `${name}-${f.name}`;
|
|
6
|
+
return acc;
|
|
7
|
+
}, {});
|
|
8
|
+
// Update URL params when filters change
|
|
9
|
+
useEffect(() => {
|
|
10
|
+
if (updateParams) {
|
|
11
|
+
const updated = {};
|
|
12
|
+
filters.forEach((f) => {
|
|
13
|
+
updated[paramNames[f.name]] = String(f.value);
|
|
14
|
+
});
|
|
15
|
+
updateParams(updated);
|
|
16
|
+
}
|
|
17
|
+
}, [filters.map((f) => f.value).join("-")]);
|
|
18
|
+
// Set default filter values from URL on first render
|
|
19
|
+
useEffect(() => {
|
|
20
|
+
if (getParam) {
|
|
21
|
+
filters.forEach((f) => {
|
|
22
|
+
const val = getParam(paramNames[f.name]);
|
|
23
|
+
f.setValue(val ? val : DEFAULT_FILTER_VALUE);
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
}, []);
|
|
27
|
+
}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export declare function usePagination(name: string, page: number, setPage: (page: number) => void, rowsPerPage: number, setRowsPerPage: (val: number) => void, updateParams?: (updates: Record<string, string>) => void, getParam?: (name: string) => string | null | undefined): void;
|
|
2
|
+
//# sourceMappingURL=usePagination.d.ts.map
|