@cozeloop/components 0.0.1
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/README.md +3 -0
- package/dist/base-search-select/base-search-form-select.d.ts +3 -0
- package/dist/base-search-select/base-search-form-select.js +6 -0
- package/dist/base-search-select/base-search-form-select.js.map +1 -0
- package/dist/base-search-select/base-search-select.d.ts +9 -0
- package/dist/base-search-select/base-search-select.js +125 -0
- package/dist/base-search-select/base-search-select.js.map +1 -0
- package/dist/base-search-select/index.d.ts +3 -0
- package/dist/base-search-select/index.js +3 -0
- package/dist/base-search-select/index.js.map +1 -0
- package/dist/base-search-select/types.d.ts +10 -0
- package/dist/base-search-select/types.js +2 -0
- package/dist/base-search-select/types.js.map +1 -0
- package/dist/base-search-select/utils.d.ts +8 -0
- package/dist/base-search-select/utils.js +48 -0
- package/dist/base-search-select/utils.js.map +1 -0
- package/dist/code-editor/index.d.ts +3 -0
- package/dist/code-editor/index.js +6 -0
- package/dist/code-editor/index.js.map +1 -0
- package/dist/collapse-card/index.d.ts +13 -0
- package/dist/collapse-card/index.js +31 -0
- package/dist/collapse-card/index.js.map +1 -0
- package/dist/collapsible-card/index.d.ts +13 -0
- package/dist/collapsible-card/index.js +13 -0
- package/dist/collapsible-card/index.js.map +1 -0
- package/dist/column-manage-storage/index.d.ts +11 -0
- package/dist/column-manage-storage/index.js +48 -0
- package/dist/column-manage-storage/index.js.map +1 -0
- package/dist/columns-select/index.d.ts +19 -0
- package/dist/columns-select/index.js +79 -0
- package/dist/columns-select/index.js.map +1 -0
- package/dist/edit-icon-button/index.d.ts +8 -0
- package/dist/edit-icon-button/index.js +13 -0
- package/dist/edit-icon-button/index.js.map +1 -0
- package/dist/es/collapsible-card/index.js +45 -0
- package/dist/es/collapsible-card/index.module.js +5 -0
- package/dist/es/collapsible-card/index_module.css +48 -0
- package/dist/es/column-manage-storage/index.js +73 -0
- package/dist/es/columns-select/index.js +219 -0
- package/dist/es/hooks/use-infinite-scroll.js +178 -0
- package/dist/es/hooks/use-mouse-down-offset.js +41 -0
- package/dist/es/id-render/icon-button-container.js +61 -0
- package/dist/es/id-render/index.js +78 -0
- package/dist/es/index.js +66 -0
- package/dist/es/infinite-scroll-table/index.js +98 -0
- package/dist/es/input-slider/index.js +123 -0
- package/dist/es/input-slider/index.module.js +5 -0
- package/dist/es/input-slider/index_module.css +21 -0
- package/dist/es/large-txt-render/index.js +38 -0
- package/dist/es/page-content/index.js +108 -0
- package/dist/es/primary-page/index.js +4 -0
- package/dist/es/primary-page/primary-header.js +38 -0
- package/dist/es/resize-sidesheet/index.js +100 -0
- package/dist/es/resize-sidesheet/index.module.js +5 -0
- package/dist/es/resize-sidesheet/index_module.css +9 -0
- package/dist/es/resize-sidesheet/use-drag.js +31 -0
- package/dist/es/table/index.js +56 -0
- package/dist/es/table/index.module.js +5 -0
- package/dist/es/table/index_module.css +90 -0
- package/dist/es/table/sort-icon.js +105 -0
- package/dist/es/table/table-with-pagination.js +112 -0
- package/dist/es/table/table-without-pagniation.js +74 -0
- package/dist/es/table-col-actions/index.js +103 -0
- package/dist/es/table-header/index.js +68 -0
- package/dist/es/table-header/index.module.js +5 -0
- package/dist/es/table-header/index_module.css +3 -0
- package/dist/es/tabs/index.js +42 -0
- package/dist/es/tabs/index.module.js +5 -0
- package/dist/es/tabs/index_module.css +37 -0
- package/dist/es/text-with-copy/index.js +71 -0
- package/dist/es/tooltip-with-disabled/index.js +49 -0
- package/dist/es/utils/basic.js +44 -0
- package/dist/es/utils/rect.js +37 -0
- package/dist/hooks/use-infinite-scroll.d.ts +23 -0
- package/dist/hooks/use-infinite-scroll.js +133 -0
- package/dist/hooks/use-infinite-scroll.js.map +1 -0
- package/dist/hooks/use-mouse-down-offset.d.ts +9 -0
- package/dist/hooks/use-mouse-down-offset.js +39 -0
- package/dist/hooks/use-mouse-down-offset.js.map +1 -0
- package/dist/id-render/icon-button-container.d.ts +6 -0
- package/dist/id-render/icon-button-container.js +6 -0
- package/dist/id-render/icon-button-container.js.map +1 -0
- package/dist/id-render/index.d.ts +7 -0
- package/dist/id-render/index.js +21 -0
- package/dist/id-render/index.js.map +1 -0
- package/dist/index.d.ts +19 -0
- package/dist/index.js +22 -0
- package/dist/index.js.map +1 -0
- package/dist/infinite-scroll-table/index.d.ts +19 -0
- package/dist/infinite-scroll-table/index.js +34 -0
- package/dist/infinite-scroll-table/index.js.map +1 -0
- package/dist/info-tooltip/index.d.ts +6 -0
- package/dist/info-tooltip/index.js +6 -0
- package/dist/info-tooltip/index.js.map +1 -0
- package/dist/input-slider/index.d.ts +14 -0
- package/dist/input-slider/index.js +81 -0
- package/dist/input-slider/index.js.map +1 -0
- package/dist/jump-button/jump-icon-button.d.ts +4 -0
- package/dist/jump-button/jump-icon-button.js +7 -0
- package/dist/jump-button/jump-icon-button.js.map +1 -0
- package/dist/large-txt-render/index.d.ts +4 -0
- package/dist/large-txt-render/index.js +26 -0
- package/dist/large-txt-render/index.js.map +1 -0
- package/dist/lib/collapsible-card/index.js +79 -0
- package/dist/lib/collapsible-card/index.module.js +25 -0
- package/dist/lib/collapsible-card/index_module.css +48 -0
- package/dist/lib/column-manage-storage/index.js +98 -0
- package/dist/lib/columns-select/index.js +241 -0
- package/dist/lib/hooks/use-infinite-scroll.js +195 -0
- package/dist/lib/hooks/use-mouse-down-offset.js +65 -0
- package/dist/lib/id-render/icon-button-container.js +89 -0
- package/dist/lib/id-render/index.js +112 -0
- package/dist/lib/index.js +110 -0
- package/dist/lib/infinite-scroll-table/index.js +126 -0
- package/dist/lib/input-slider/index.js +154 -0
- package/dist/lib/input-slider/index.module.js +25 -0
- package/dist/lib/input-slider/index_module.css +21 -0
- package/dist/lib/large-txt-render/index.js +62 -0
- package/dist/lib/page-content/index.js +136 -0
- package/dist/lib/primary-page/index.js +28 -0
- package/dist/lib/primary-page/primary-header.js +72 -0
- package/dist/lib/resize-sidesheet/index.js +129 -0
- package/dist/lib/resize-sidesheet/index.module.js +25 -0
- package/dist/lib/resize-sidesheet/index_module.css +9 -0
- package/dist/lib/resize-sidesheet/use-drag.js +55 -0
- package/dist/lib/table/index.js +88 -0
- package/dist/lib/table/index.module.js +25 -0
- package/dist/lib/table/index_module.css +90 -0
- package/dist/lib/table/sort-icon.js +137 -0
- package/dist/lib/table/table-with-pagination.js +146 -0
- package/dist/lib/table/table-without-pagniation.js +108 -0
- package/dist/lib/table-col-actions/index.js +123 -0
- package/dist/lib/table-header/index.js +96 -0
- package/dist/lib/table-header/index.module.js +25 -0
- package/dist/lib/table-header/index_module.css +3 -0
- package/dist/lib/tabs/index.js +74 -0
- package/dist/lib/tabs/index.module.js +25 -0
- package/dist/lib/tabs/index_module.css +37 -0
- package/dist/lib/text-with-copy/index.js +105 -0
- package/dist/lib/tooltip-with-disabled/index.js +71 -0
- package/dist/lib/utils/basic.js +78 -0
- package/dist/lib/utils/rect.js +65 -0
- package/dist/logic-expr/consts.d.ts +4 -0
- package/dist/logic-expr/consts.js +5 -0
- package/dist/logic-expr/consts.js.map +1 -0
- package/dist/logic-expr/expr-group-render.d.ts +2 -0
- package/dist/logic-expr/expr-group-render.js +60 -0
- package/dist/logic-expr/expr-group-render.js.map +1 -0
- package/dist/logic-expr/expr-render.d.ts +2 -0
- package/dist/logic-expr/expr-render.js +84 -0
- package/dist/logic-expr/expr-render.js.map +1 -0
- package/dist/logic-expr/index.d.ts +2 -0
- package/dist/logic-expr/index.js +2 -0
- package/dist/logic-expr/index.js.map +1 -0
- package/dist/logic-expr/logic-expr.d.ts +2 -0
- package/dist/logic-expr/logic-expr.js +187 -0
- package/dist/logic-expr/logic-expr.js.map +1 -0
- package/dist/logic-expr/logic-not.d.ts +10 -0
- package/dist/logic-expr/logic-not.js +20 -0
- package/dist/logic-expr/logic-not.js.map +1 -0
- package/dist/logic-expr/logic-toggle.d.ts +12 -0
- package/dist/logic-expr/logic-toggle.js +32 -0
- package/dist/logic-expr/logic-toggle.js.map +1 -0
- package/dist/logic-expr/types.d.ts +79 -0
- package/dist/logic-expr/types.js +2 -0
- package/dist/logic-expr/types.js.map +1 -0
- package/dist/open-detail-button/index.d.ts +6 -0
- package/dist/open-detail-button/index.js +11 -0
- package/dist/open-detail-button/index.js.map +1 -0
- package/dist/page-content/index.d.ts +20 -0
- package/dist/page-content/index.js +23 -0
- package/dist/page-content/index.js.map +1 -0
- package/dist/primary-page/index.d.ts +1 -0
- package/dist/primary-page/index.js +2 -0
- package/dist/primary-page/index.js.map +1 -0
- package/dist/primary-page/primary-header.d.ts +10 -0
- package/dist/primary-page/primary-header.js +4 -0
- package/dist/primary-page/primary-header.js.map +1 -0
- package/dist/resize-sidesheet/index.d.ts +6 -0
- package/dist/resize-sidesheet/index.js +15 -0
- package/dist/resize-sidesheet/index.js.map +1 -0
- package/dist/resize-sidesheet/use-drag.d.ts +10 -0
- package/dist/resize-sidesheet/use-drag.js +25 -0
- package/dist/resize-sidesheet/use-drag.js.map +1 -0
- package/dist/route/route-back-action.d.ts +6 -0
- package/dist/route/route-back-action.js +29 -0
- package/dist/route/route-back-action.js.map +1 -0
- package/dist/table/index.d.ts +2 -0
- package/dist/table/index.js +6 -0
- package/dist/table/index.js.map +1 -0
- package/dist/table/sort-icon.d.ts +8 -0
- package/dist/table/sort-icon.js +30 -0
- package/dist/table/sort-icon.js.map +1 -0
- package/dist/table/table-with-pagination.d.ts +14 -0
- package/dist/table/table-with-pagination.js +55 -0
- package/dist/table/table-with-pagination.js.map +1 -0
- package/dist/table/table-without-pagniation.d.ts +8 -0
- package/dist/table/table-without-pagniation.js +36 -0
- package/dist/table/table-without-pagniation.js.map +1 -0
- package/dist/table-col-actions/index.d.ts +17 -0
- package/dist/table-col-actions/index.js +24 -0
- package/dist/table-col-actions/index.js.map +1 -0
- package/dist/table-header/index.d.ts +12 -0
- package/dist/table-header/index.js +10 -0
- package/dist/table-header/index.js.map +1 -0
- package/dist/tabs/index.d.ts +2 -0
- package/dist/tabs/index.js +9 -0
- package/dist/tabs/index.js.map +1 -0
- package/dist/text-with-copy/index.d.ts +14 -0
- package/dist/text-with-copy/index.js +21 -0
- package/dist/text-with-copy/index.js.map +1 -0
- package/dist/tooltip-with-disabled/index.d.ts +5 -0
- package/dist/tooltip-with-disabled/index.js +9 -0
- package/dist/tooltip-with-disabled/index.js.map +1 -0
- package/dist/tsconfig.build.tsbuildinfo +1 -0
- package/dist/types/collapsible-card/index.d.ts +22 -0
- package/dist/types/column-manage-storage/index.d.ts +11 -0
- package/dist/types/columns-select/index.d.ts +29 -0
- package/dist/types/hooks/use-infinite-scroll.d.ts +23 -0
- package/dist/types/hooks/use-mouse-down-offset.d.ts +9 -0
- package/dist/types/id-render/icon-button-container.d.ts +12 -0
- package/dist/types/id-render/index.d.ts +13 -0
- package/dist/types/index.d.ts +19 -0
- package/dist/types/infinite-scroll-table/index.d.ts +19 -0
- package/dist/types/input-slider/index.d.ts +14 -0
- package/dist/types/large-txt-render/index.d.ts +4 -0
- package/dist/types/page-content/index.d.ts +36 -0
- package/dist/types/primary-page/index.d.ts +1 -0
- package/dist/types/primary-page/primary-header.d.ts +17 -0
- package/dist/types/resize-sidesheet/index.d.ts +6 -0
- package/dist/types/resize-sidesheet/use-drag.d.ts +10 -0
- package/dist/types/table/index.d.ts +2 -0
- package/dist/types/table/sort-icon.d.ts +13 -0
- package/dist/types/table/table-with-pagination.d.ts +14 -0
- package/dist/types/table/table-without-pagniation.d.ts +8 -0
- package/dist/types/table-col-actions/index.d.ts +21 -0
- package/dist/types/table-header/index.d.ts +20 -0
- package/dist/types/tabs/index.d.ts +2 -0
- package/dist/types/text-with-copy/index.d.ts +24 -0
- package/dist/types/tooltip-with-disabled/index.d.ts +9 -0
- package/dist/types/utils/basic.d.ts +1 -0
- package/dist/types/utils/rect.d.ts +10 -0
- package/dist/upload/index.d.ts +9 -0
- package/dist/upload/index.js +25 -0
- package/dist/upload/index.js.map +1 -0
- package/dist/user-profile/index.d.ts +8 -0
- package/dist/user-profile/index.js +16 -0
- package/dist/user-profile/index.js.map +1 -0
- package/dist/user-select/index.d.ts +0 -0
- package/dist/user-select/index.js +188 -0
- package/dist/user-select/index.js.map +1 -0
- package/dist/user-select/user-info.d.ts +8 -0
- package/dist/user-select/user-info.js +16 -0
- package/dist/user-select/user-info.js.map +1 -0
- package/dist/utils/basic.d.ts +1 -0
- package/dist/utils/basic.js +24 -0
- package/dist/utils/basic.js.map +1 -0
- package/dist/utils/rect.d.ts +10 -0
- package/dist/utils/rect.js +35 -0
- package/dist/utils/rect.js.map +1 -0
- package/dist/version-list/version-descriptions.d.ts +15 -0
- package/dist/version-list/version-descriptions.js +14 -0
- package/dist/version-list/version-descriptions.js.map +1 -0
- package/dist/version-list/version-item.d.ts +9 -0
- package/dist/version-list/version-item.js +6 -0
- package/dist/version-list/version-item.js.map +1 -0
- package/dist/version-list/version-list.d.ts +11 -0
- package/dist/version-list/version-list.js +11 -0
- package/dist/version-list/version-list.js.map +1 -0
- package/dist/version-list/version-switch-panel.d.ts +5 -0
- package/dist/version-list/version-switch-panel.js +10 -0
- package/dist/version-list/version-switch-panel.js.map +1 -0
- package/package.json +54 -0
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __defProps = Object.defineProperties;
|
|
3
|
+
var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
|
|
4
|
+
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __propIsEnum = Object.prototype.propertyIsEnumerable;
|
|
7
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
8
|
+
var __spreadValues = (a, b) => {
|
|
9
|
+
for (var prop in b || (b = {}))
|
|
10
|
+
if (__hasOwnProp.call(b, prop))
|
|
11
|
+
__defNormalProp(a, prop, b[prop]);
|
|
12
|
+
if (__getOwnPropSymbols)
|
|
13
|
+
for (var prop of __getOwnPropSymbols(b)) {
|
|
14
|
+
if (__propIsEnum.call(b, prop))
|
|
15
|
+
__defNormalProp(a, prop, b[prop]);
|
|
16
|
+
}
|
|
17
|
+
return a;
|
|
18
|
+
};
|
|
19
|
+
var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
|
|
20
|
+
var __objRest = (source, exclude) => {
|
|
21
|
+
var target = {};
|
|
22
|
+
for (var prop in source)
|
|
23
|
+
if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
|
|
24
|
+
target[prop] = source[prop];
|
|
25
|
+
if (source != null && __getOwnPropSymbols)
|
|
26
|
+
for (var prop of __getOwnPropSymbols(source)) {
|
|
27
|
+
if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
|
|
28
|
+
target[prop] = source[prop];
|
|
29
|
+
}
|
|
30
|
+
return target;
|
|
31
|
+
};
|
|
32
|
+
import { jsx } from "react/jsx-runtime";
|
|
33
|
+
import cs from "classnames";
|
|
34
|
+
import { Tabs } from "@coze-arch/coze-design";
|
|
35
|
+
import styles from "./index.module";
|
|
36
|
+
const LoopTabs = (props) => {
|
|
37
|
+
const _a = props, { className } = _a, rest = __objRest(_a, ["className"]);
|
|
38
|
+
return /* @__PURE__ */ jsx(Tabs, __spreadProps(__spreadValues({}, rest), { className: cs(styles.tabs, className) }));
|
|
39
|
+
};
|
|
40
|
+
export {
|
|
41
|
+
LoopTabs
|
|
42
|
+
};
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
.tabs_98a2e {
|
|
2
|
+
display: flex;
|
|
3
|
+
flex-direction: column;
|
|
4
|
+
}
|
|
5
|
+
.tabs_98a2e .semi-tabs-bar-card.semi-tabs-bar-top .semi-tabs-tab:first-of-type {
|
|
6
|
+
margin-left: 24px;
|
|
7
|
+
}
|
|
8
|
+
.tabs_98a2e .semi-tabs-tab-card.semi-tabs-tab-top.semi-tabs-tab {
|
|
9
|
+
height: 36px;
|
|
10
|
+
padding-top: 6px;
|
|
11
|
+
padding-bottom: 6px;
|
|
12
|
+
color: var(--semi-color-text-0);
|
|
13
|
+
background-color: #F6F8FA;
|
|
14
|
+
border: 1px solid var(--semi-color-border);
|
|
15
|
+
border-top-left-radius: 4px;
|
|
16
|
+
border-top-right-radius: 4px;
|
|
17
|
+
}
|
|
18
|
+
.tabs_98a2e .semi-tabs-tab-card.semi-tabs-tab-top.semi-tabs-tab-active {
|
|
19
|
+
color: rgb(var(--coze-up-brand-9));
|
|
20
|
+
background: linear-gradient(to bottom, rgb(var(--coze-up-brand-9)) 2px, transparent 2px);
|
|
21
|
+
border-top: 1px solid rgb(var(--coze-up-brand-9));
|
|
22
|
+
border-bottom: 1px solid var(--semi-color-bg-2);
|
|
23
|
+
}
|
|
24
|
+
.tabs_98a2e .semi-tabs-content {
|
|
25
|
+
overflow: hidden;
|
|
26
|
+
flex: 1 1;
|
|
27
|
+
padding: 0;
|
|
28
|
+
}
|
|
29
|
+
.tabs_98a2e .semi-tabs-pane {
|
|
30
|
+
height: 100%;
|
|
31
|
+
}
|
|
32
|
+
.tabs_98a2e .semi-tabs-pane-motion-overlay {
|
|
33
|
+
height: 100%;
|
|
34
|
+
}
|
|
35
|
+
.tabs_98a2e .semi-tag-large {
|
|
36
|
+
height: 20px;
|
|
37
|
+
}
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
2
|
+
import classNames from "classnames";
|
|
3
|
+
import { IconCozCopy } from "@coze-arch/coze-design/icons";
|
|
4
|
+
import { IconButton, Tooltip, Typography } from "@coze-arch/coze-design";
|
|
5
|
+
import { handleCopy } from "../utils/basic";
|
|
6
|
+
function TextWithCopy({
|
|
7
|
+
displayText,
|
|
8
|
+
copyTooltipText,
|
|
9
|
+
content,
|
|
10
|
+
className,
|
|
11
|
+
maxWidth,
|
|
12
|
+
style,
|
|
13
|
+
textClassName,
|
|
14
|
+
textType = "secondary",
|
|
15
|
+
onlyIconCopy
|
|
16
|
+
}) {
|
|
17
|
+
return /* @__PURE__ */ jsxs(
|
|
18
|
+
"div",
|
|
19
|
+
{
|
|
20
|
+
className: classNames("flex items-center justify-start gap-1", className),
|
|
21
|
+
style,
|
|
22
|
+
children: [
|
|
23
|
+
/* @__PURE__ */ jsx(
|
|
24
|
+
Typography.Text,
|
|
25
|
+
{
|
|
26
|
+
className: classNames(
|
|
27
|
+
"max-w-full",
|
|
28
|
+
{
|
|
29
|
+
"cursor-pointer": !onlyIconCopy
|
|
30
|
+
},
|
|
31
|
+
textClassName
|
|
32
|
+
),
|
|
33
|
+
type: textType,
|
|
34
|
+
style: { maxWidth },
|
|
35
|
+
ellipsis: {
|
|
36
|
+
showTooltip: { opts: { theme: "dark", content } }
|
|
37
|
+
},
|
|
38
|
+
onClick: onlyIconCopy ? void 0 : (e) => {
|
|
39
|
+
content && handleCopy(content);
|
|
40
|
+
e == null ? void 0 : e.stopPropagation();
|
|
41
|
+
},
|
|
42
|
+
children: displayText || content || ""
|
|
43
|
+
}
|
|
44
|
+
),
|
|
45
|
+
content ? /* @__PURE__ */ jsx(Tooltip, { content: copyTooltipText || "复制内容", theme: "dark", children: /* @__PURE__ */ jsx(
|
|
46
|
+
IconButton,
|
|
47
|
+
{
|
|
48
|
+
size: "mini",
|
|
49
|
+
color: "secondary",
|
|
50
|
+
className: "flex-shrink-0 !w-[20px] !h-[20px]",
|
|
51
|
+
icon: /* @__PURE__ */ jsx(
|
|
52
|
+
IconCozCopy,
|
|
53
|
+
{
|
|
54
|
+
className: "",
|
|
55
|
+
onClick: (e) => {
|
|
56
|
+
content && handleCopy(content);
|
|
57
|
+
e == null ? void 0 : e.stopPropagation();
|
|
58
|
+
},
|
|
59
|
+
fontSize: 14,
|
|
60
|
+
fill: "var(--semi-color-text-2)"
|
|
61
|
+
}
|
|
62
|
+
)
|
|
63
|
+
}
|
|
64
|
+
) }) : null
|
|
65
|
+
]
|
|
66
|
+
}
|
|
67
|
+
);
|
|
68
|
+
}
|
|
69
|
+
export {
|
|
70
|
+
TextWithCopy
|
|
71
|
+
};
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __defProps = Object.defineProperties;
|
|
3
|
+
var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
|
|
4
|
+
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __propIsEnum = Object.prototype.propertyIsEnumerable;
|
|
7
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
8
|
+
var __spreadValues = (a, b) => {
|
|
9
|
+
for (var prop in b || (b = {}))
|
|
10
|
+
if (__hasOwnProp.call(b, prop))
|
|
11
|
+
__defNormalProp(a, prop, b[prop]);
|
|
12
|
+
if (__getOwnPropSymbols)
|
|
13
|
+
for (var prop of __getOwnPropSymbols(b)) {
|
|
14
|
+
if (__propIsEnum.call(b, prop))
|
|
15
|
+
__defNormalProp(a, prop, b[prop]);
|
|
16
|
+
}
|
|
17
|
+
return a;
|
|
18
|
+
};
|
|
19
|
+
var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
|
|
20
|
+
var __objRest = (source, exclude) => {
|
|
21
|
+
var target = {};
|
|
22
|
+
for (var prop in source)
|
|
23
|
+
if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
|
|
24
|
+
target[prop] = source[prop];
|
|
25
|
+
if (source != null && __getOwnPropSymbols)
|
|
26
|
+
for (var prop of __getOwnPropSymbols(source)) {
|
|
27
|
+
if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
|
|
28
|
+
target[prop] = source[prop];
|
|
29
|
+
}
|
|
30
|
+
return target;
|
|
31
|
+
};
|
|
32
|
+
import { Fragment, jsx } from "react/jsx-runtime";
|
|
33
|
+
import { Tooltip } from "@coze-arch/coze-design";
|
|
34
|
+
function TooltipWhenDisabled(_a) {
|
|
35
|
+
var _b = _a, {
|
|
36
|
+
children,
|
|
37
|
+
disabled
|
|
38
|
+
} = _b, rest = __objRest(_b, [
|
|
39
|
+
"children",
|
|
40
|
+
"disabled"
|
|
41
|
+
]);
|
|
42
|
+
if (disabled) {
|
|
43
|
+
return /* @__PURE__ */ jsx(Tooltip, __spreadProps(__spreadValues({}, rest), { children }));
|
|
44
|
+
}
|
|
45
|
+
return /* @__PURE__ */ jsx(Fragment, { children });
|
|
46
|
+
}
|
|
47
|
+
export {
|
|
48
|
+
TooltipWhenDisabled
|
|
49
|
+
};
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
var __async = (__this, __arguments, generator) => {
|
|
2
|
+
return new Promise((resolve, reject) => {
|
|
3
|
+
var fulfilled = (value) => {
|
|
4
|
+
try {
|
|
5
|
+
step(generator.next(value));
|
|
6
|
+
} catch (e) {
|
|
7
|
+
reject(e);
|
|
8
|
+
}
|
|
9
|
+
};
|
|
10
|
+
var rejected = (value) => {
|
|
11
|
+
try {
|
|
12
|
+
step(generator.throw(value));
|
|
13
|
+
} catch (e) {
|
|
14
|
+
reject(e);
|
|
15
|
+
}
|
|
16
|
+
};
|
|
17
|
+
var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
|
|
18
|
+
step((generator = generator.apply(__this, __arguments)).next());
|
|
19
|
+
});
|
|
20
|
+
};
|
|
21
|
+
import copy from "copy-to-clipboard";
|
|
22
|
+
import { Toast } from "@coze-arch/coze-design";
|
|
23
|
+
const handleCopy = (value, hideToast) => __async(void 0, null, function* () {
|
|
24
|
+
try {
|
|
25
|
+
copy(value);
|
|
26
|
+
!hideToast && Toast.success({
|
|
27
|
+
content: "复制成功",
|
|
28
|
+
showClose: false,
|
|
29
|
+
zIndex: 99999
|
|
30
|
+
});
|
|
31
|
+
return Promise.resolve(true);
|
|
32
|
+
} catch (e) {
|
|
33
|
+
Toast.warning({
|
|
34
|
+
content: "复制失败",
|
|
35
|
+
showClose: false,
|
|
36
|
+
zIndex: 99999
|
|
37
|
+
});
|
|
38
|
+
console.error(e);
|
|
39
|
+
return Promise.resolve(false);
|
|
40
|
+
}
|
|
41
|
+
});
|
|
42
|
+
export {
|
|
43
|
+
handleCopy
|
|
44
|
+
};
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
const isBrowser = !!(typeof window !== "undefined" && window.document && window.document.createElement);
|
|
2
|
+
const getScrollTop = (el) => {
|
|
3
|
+
if (el === document || el === document.documentElement || el === document.body) {
|
|
4
|
+
return Math.max(
|
|
5
|
+
window.pageYOffset,
|
|
6
|
+
document.documentElement.scrollTop,
|
|
7
|
+
document.body.scrollTop
|
|
8
|
+
);
|
|
9
|
+
}
|
|
10
|
+
return el.scrollTop;
|
|
11
|
+
};
|
|
12
|
+
const getScrollHeight = (el) => el.scrollHeight || Math.max(document.documentElement.scrollHeight, document.body.scrollHeight);
|
|
13
|
+
const getClientHeight = (el) => el.clientHeight || Math.max(document.documentElement.clientHeight, document.body.clientHeight);
|
|
14
|
+
function getTargetElement(target, defaultElement) {
|
|
15
|
+
if (!isBrowser) {
|
|
16
|
+
return void 0;
|
|
17
|
+
}
|
|
18
|
+
if (!target) {
|
|
19
|
+
return defaultElement;
|
|
20
|
+
}
|
|
21
|
+
let targetElement;
|
|
22
|
+
if (typeof target === "function") {
|
|
23
|
+
targetElement = target();
|
|
24
|
+
} else if ("current" in target) {
|
|
25
|
+
targetElement = target.current;
|
|
26
|
+
} else {
|
|
27
|
+
targetElement = target;
|
|
28
|
+
}
|
|
29
|
+
return targetElement;
|
|
30
|
+
}
|
|
31
|
+
export {
|
|
32
|
+
getClientHeight,
|
|
33
|
+
getScrollHeight,
|
|
34
|
+
getScrollTop,
|
|
35
|
+
getTargetElement,
|
|
36
|
+
isBrowser
|
|
37
|
+
};
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { type InfiniteScrollOptions, type Data, type Service } from 'ahooks/lib/useInfiniteScroll/types';
|
|
2
|
+
/**
|
|
3
|
+
* ahook的实现,在刷新列表时会出现以下两个问题
|
|
4
|
+
* 1. 发送存量数据对应的列表请求
|
|
5
|
+
* 2. 列表请求重复
|
|
6
|
+
* 因此fork ahook 实现,并将reload含义定义为刷新列表,并回到第一页
|
|
7
|
+
* @param service
|
|
8
|
+
* @param options
|
|
9
|
+
* @returns
|
|
10
|
+
*/
|
|
11
|
+
export declare const useInfiniteScroll: <TData extends Data>(service: Service<TData>, options?: InfiniteScrollOptions<TData>) => {
|
|
12
|
+
data: TData | undefined;
|
|
13
|
+
loading: boolean;
|
|
14
|
+
error: Error | undefined;
|
|
15
|
+
loadingMore: boolean;
|
|
16
|
+
noMore: boolean;
|
|
17
|
+
loadMore: () => void;
|
|
18
|
+
loadMoreAsync: () => Promise<TData>;
|
|
19
|
+
reload: () => void;
|
|
20
|
+
reloadAsync: () => Promise<TData>;
|
|
21
|
+
mutate: import("react").Dispatch<import("react").SetStateAction<TData | undefined>>;
|
|
22
|
+
cancel: () => void;
|
|
23
|
+
};
|
|
@@ -0,0 +1,133 @@
|
|
|
1
|
+
/* eslint-disable @flow-infra/max-line-per-function */
|
|
2
|
+
/* eslint-disable max-lines-per-function */
|
|
3
|
+
import { useMemo, useState } from 'react';
|
|
4
|
+
import { getTargetElement } from 'ahooks/lib/utils/domTarget';
|
|
5
|
+
import { useEventListener, useMemoizedFn, useRequest, useUpdateEffect, } from 'ahooks';
|
|
6
|
+
import { getClientHeight, getScrollHeight, getScrollTop } from '../utils/rect';
|
|
7
|
+
/**
|
|
8
|
+
* ahook的实现,在刷新列表时会出现以下两个问题
|
|
9
|
+
* 1. 发送存量数据对应的列表请求
|
|
10
|
+
* 2. 列表请求重复
|
|
11
|
+
* 因此fork ahook 实现,并将reload含义定义为刷新列表,并回到第一页
|
|
12
|
+
* @param service
|
|
13
|
+
* @param options
|
|
14
|
+
* @returns
|
|
15
|
+
*/
|
|
16
|
+
export const useInfiniteScroll = (service, options = {}) => {
|
|
17
|
+
const { target, isNoMore, threshold = 100, reloadDeps = [], manual, onBefore, onSuccess, onError, onFinally, } = options;
|
|
18
|
+
const [finalData, setFinalData] = useState();
|
|
19
|
+
const [loadingMore, setLoadingMore] = useState(false);
|
|
20
|
+
const noMore = useMemo(() => {
|
|
21
|
+
if (!isNoMore) {
|
|
22
|
+
return false;
|
|
23
|
+
}
|
|
24
|
+
return isNoMore(finalData);
|
|
25
|
+
}, [finalData]);
|
|
26
|
+
const { loading, error, run, runAsync, cancel } = useRequest(async (lastData) => {
|
|
27
|
+
const currentData = await service(lastData);
|
|
28
|
+
if (!lastData) {
|
|
29
|
+
setFinalData({
|
|
30
|
+
...currentData,
|
|
31
|
+
list: [...(currentData.list ?? [])],
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
else {
|
|
35
|
+
setFinalData({
|
|
36
|
+
...currentData,
|
|
37
|
+
list: [...(lastData.list ?? []), ...currentData.list],
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
return currentData;
|
|
41
|
+
}, {
|
|
42
|
+
manual,
|
|
43
|
+
onFinally: (_, d, e) => {
|
|
44
|
+
setLoadingMore(false);
|
|
45
|
+
onFinally?.(d, e);
|
|
46
|
+
},
|
|
47
|
+
onBefore: () => onBefore?.(),
|
|
48
|
+
onSuccess: d => {
|
|
49
|
+
// setTimeout(() => {
|
|
50
|
+
// scrollMethod();
|
|
51
|
+
// });
|
|
52
|
+
onSuccess?.(d);
|
|
53
|
+
setTimeout(() => {
|
|
54
|
+
checkFirstScreen();
|
|
55
|
+
});
|
|
56
|
+
},
|
|
57
|
+
onError,
|
|
58
|
+
});
|
|
59
|
+
const loadMore = useMemoizedFn(() => {
|
|
60
|
+
if (noMore) {
|
|
61
|
+
return;
|
|
62
|
+
}
|
|
63
|
+
setLoadingMore(true);
|
|
64
|
+
run(finalData);
|
|
65
|
+
});
|
|
66
|
+
const loadMoreAsync = useMemoizedFn(() => {
|
|
67
|
+
if (noMore) {
|
|
68
|
+
// eslint-disable-next-line prefer-promise-reject-errors
|
|
69
|
+
return Promise.reject();
|
|
70
|
+
}
|
|
71
|
+
setLoadingMore(true);
|
|
72
|
+
return runAsync(finalData);
|
|
73
|
+
});
|
|
74
|
+
const reload = () => {
|
|
75
|
+
setLoadingMore(false);
|
|
76
|
+
setFinalData(undefined);
|
|
77
|
+
return run();
|
|
78
|
+
};
|
|
79
|
+
const reloadAsync = () => {
|
|
80
|
+
setLoadingMore(false);
|
|
81
|
+
return runAsync();
|
|
82
|
+
};
|
|
83
|
+
const checkFirstScreen = () => {
|
|
84
|
+
let el = getTargetElement(target);
|
|
85
|
+
if (!el) {
|
|
86
|
+
return;
|
|
87
|
+
}
|
|
88
|
+
el = el === document ? document.documentElement : el;
|
|
89
|
+
const scrollHeight = getScrollHeight(el);
|
|
90
|
+
const clientHeight = getClientHeight(el);
|
|
91
|
+
if (scrollHeight <= clientHeight) {
|
|
92
|
+
// 首屏没满,自动 loadMore
|
|
93
|
+
loadMore();
|
|
94
|
+
}
|
|
95
|
+
};
|
|
96
|
+
const scrollMethod = () => {
|
|
97
|
+
let el = getTargetElement(target);
|
|
98
|
+
if (!el) {
|
|
99
|
+
return;
|
|
100
|
+
}
|
|
101
|
+
el = el === document ? document.documentElement : el;
|
|
102
|
+
const scrollTop = getScrollTop(el);
|
|
103
|
+
const scrollHeight = getScrollHeight(el);
|
|
104
|
+
const clientHeight = getClientHeight(el);
|
|
105
|
+
if (scrollHeight - scrollTop <= clientHeight + threshold) {
|
|
106
|
+
loadMore();
|
|
107
|
+
}
|
|
108
|
+
};
|
|
109
|
+
useEventListener('scroll', () => {
|
|
110
|
+
if (loading || loadingMore) {
|
|
111
|
+
return;
|
|
112
|
+
}
|
|
113
|
+
scrollMethod();
|
|
114
|
+
}, { target });
|
|
115
|
+
useUpdateEffect(() => {
|
|
116
|
+
setFinalData(undefined);
|
|
117
|
+
run();
|
|
118
|
+
}, [...reloadDeps]);
|
|
119
|
+
return {
|
|
120
|
+
data: finalData,
|
|
121
|
+
loading: !loadingMore && loading,
|
|
122
|
+
error,
|
|
123
|
+
loadingMore,
|
|
124
|
+
noMore,
|
|
125
|
+
loadMore,
|
|
126
|
+
loadMoreAsync,
|
|
127
|
+
reload: useMemoizedFn(reload),
|
|
128
|
+
reloadAsync: useMemoizedFn(reloadAsync),
|
|
129
|
+
mutate: setFinalData,
|
|
130
|
+
cancel,
|
|
131
|
+
};
|
|
132
|
+
};
|
|
133
|
+
//# sourceMappingURL=use-infinite-scroll.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-infinite-scroll.js","sourceRoot":"","sources":["../../src/hooks/use-infinite-scroll.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { useState, useRef, useCallback } from 'react';
|
|
2
|
+
import { useLatest, useMemoizedFn } from 'ahooks';
|
|
3
|
+
export const useMouseDownOffset = (callback) => {
|
|
4
|
+
const [isActive, setIsActive] = useState(false);
|
|
5
|
+
const targetRef = useRef(null);
|
|
6
|
+
const [startPosition, setStartPosition] = useState(null);
|
|
7
|
+
const callbackRef = useLatest(callback);
|
|
8
|
+
const ref = useCallback((node) => {
|
|
9
|
+
if (targetRef.current) {
|
|
10
|
+
targetRef.current.removeEventListener('mousedown', handleMouseDown);
|
|
11
|
+
}
|
|
12
|
+
targetRef.current = node; // 更新 ref
|
|
13
|
+
if (targetRef.current) {
|
|
14
|
+
targetRef.current.addEventListener('mousedown', handleMouseDown);
|
|
15
|
+
}
|
|
16
|
+
}, []);
|
|
17
|
+
const handleMouseDown = useMemoizedFn((event) => {
|
|
18
|
+
setIsActive(true);
|
|
19
|
+
setStartPosition({ offsetX: event.clientX, offsetY: event.clientY });
|
|
20
|
+
window.addEventListener('mousemove', handleMouseMove);
|
|
21
|
+
window.addEventListener('mouseup', handleMouseUp);
|
|
22
|
+
});
|
|
23
|
+
const handleMouseMove = useMemoizedFn((event) => {
|
|
24
|
+
if (startPosition) {
|
|
25
|
+
callbackRef.current({
|
|
26
|
+
offsetX: event.clientX - startPosition.offsetX,
|
|
27
|
+
offsetY: event.clientY - startPosition.offsetY,
|
|
28
|
+
});
|
|
29
|
+
}
|
|
30
|
+
});
|
|
31
|
+
const handleMouseUp = useMemoizedFn(() => {
|
|
32
|
+
setIsActive(false);
|
|
33
|
+
setStartPosition(null);
|
|
34
|
+
window.removeEventListener('mousemove', handleMouseMove);
|
|
35
|
+
window.removeEventListener('mouseup', handleMouseUp);
|
|
36
|
+
});
|
|
37
|
+
return { isActive, ref };
|
|
38
|
+
};
|
|
39
|
+
//# sourceMappingURL=use-mouse-down-offset.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-mouse-down-offset.js","sourceRoot":"","sources":["../../src/hooks/use-mouse-down-offset.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,OAAO,CAAC;AAEtD,OAAO,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,QAAQ,CAAC;AAOlD,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAAC,QAAkC,EAAE,EAAE;IACvE,MAAM,CAAC,QAAQ,EAAE,WAAW,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IAChD,MAAM,SAAS,GAAG,MAAM,CAAqB,IAAI,CAAC,CAAC;IACnD,MAAM,CAAC,aAAa,EAAE,gBAAgB,CAAC,GAAG,QAAQ,CAAgB,IAAI,CAAC,CAAC;IACxE,MAAM,WAAW,GAAG,SAAS,CAAC,QAAQ,CAAC,CAAC;IAExC,MAAM,GAAG,GAAG,WAAW,CAAC,CAAC,IAAwB,EAAE,EAAE;QACnD,IAAI,SAAS,CAAC,OAAO,EAAE,CAAC;YACtB,SAAS,CAAC,OAAO,CAAC,mBAAmB,CAAC,WAAW,EAAE,eAAe,CAAC,CAAC;QACtE,CAAC;QACD,SAAS,CAAC,OAAO,GAAG,IAAI,CAAC,CAAC,SAAS;QACnC,IAAI,SAAS,CAAC,OAAO,EAAE,CAAC;YACtB,SAAS,CAAC,OAAO,CAAC,gBAAgB,CAAC,WAAW,EAAE,eAAe,CAAC,CAAC;QACnE,CAAC;IACH,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,MAAM,eAAe,GAAG,aAAa,CAAC,CAAC,KAAiB,EAAE,EAAE;QAC1D,WAAW,CAAC,IAAI,CAAC,CAAC;QAClB,gBAAgB,CAAC,EAAE,OAAO,EAAE,KAAK,CAAC,OAAO,EAAE,OAAO,EAAE,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC;QACrE,MAAM,CAAC,gBAAgB,CAAC,WAAW,EAAE,eAAe,CAAC,CAAC;QACtD,MAAM,CAAC,gBAAgB,CAAC,SAAS,EAAE,aAAa,CAAC,CAAC;IACpD,CAAC,CAAC,CAAC;IAEH,MAAM,eAAe,GAAG,aAAa,CAAC,CAAC,KAAiB,EAAE,EAAE;QAC1D,IAAI,aAAa,EAAE,CAAC;YAClB,WAAW,CAAC,OAAO,CAAC;gBAClB,OAAO,EAAE,KAAK,CAAC,OAAO,GAAG,aAAa,CAAC,OAAO;gBAC9C,OAAO,EAAE,KAAK,CAAC,OAAO,GAAG,aAAa,CAAC,OAAO;aAC/C,CAAC,CAAC;QACL,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,MAAM,aAAa,GAAG,aAAa,CAAC,GAAG,EAAE;QACvC,WAAW,CAAC,KAAK,CAAC,CAAC;QACnB,gBAAgB,CAAC,IAAI,CAAC,CAAC;QACvB,MAAM,CAAC,mBAAmB,CAAC,WAAW,EAAE,eAAe,CAAC,CAAC;QACzD,MAAM,CAAC,mBAAmB,CAAC,SAAS,EAAE,aAAa,CAAC,CAAC;IACvD,CAAC,CAAC,CAAC;IAEH,OAAO,EAAE,QAAQ,EAAE,GAAG,EAAE,CAAC;AAC3B,CAAC,CAAC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { type DOMAttributes } from 'react';
|
|
2
|
+
export default function IconButtonContainer({ icon, className, style, onClick, ...rest }: {
|
|
3
|
+
icon: React.ReactNode;
|
|
4
|
+
className?: string;
|
|
5
|
+
style?: React.CSSProperties;
|
|
6
|
+
} & DOMAttributes<HTMLDivElement>): import("react/jsx-runtime").JSX.Element;
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import cls from 'classnames';
|
|
3
|
+
export default function IconButtonContainer({ icon, className, style, onClick, ...rest }) {
|
|
4
|
+
return (_jsx("div", { ...rest, onClick: onClick, style: style, className: cls('inline-flex items-center justify-center w-5 h-5 rounded-[4px] cursor-pointer text-[var(--coz-fg-secondary)] hover:text-[var(--coz-fg-primary)] hover:bg-[var(--coz-mg-secondary-hovered)]', className), children: icon }));
|
|
5
|
+
}
|
|
6
|
+
//# sourceMappingURL=icon-button-container.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"icon-button-container.js","sourceRoot":"","sources":["../../src/id-render/icon-button-container.tsx"],"names":[],"mappings":";AAEA,OAAO,GAAG,MAAM,YAAY,CAAC;AAE7B,MAAM,CAAC,OAAO,UAAU,mBAAmB,CAAC,EAC1C,IAAI,EACJ,SAAS,EACT,KAAK,EACL,OAAO,EACP,GAAG,IAAI,EAKwB;IAC/B,OAAO,CACL,iBACM,IAAI,EACR,OAAO,EAAE,OAAO,EAChB,KAAK,EAAE,KAAK,EACZ,SAAS,EAAE,GAAG,CACZ,2LAA2L,EAC3L,SAAS,CACV,YAEA,IAAI,GACD,CACP,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { jsxs as _jsxs, jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import classNames from 'classnames';
|
|
3
|
+
import { IconCozCopy } from '@coze-arch/coze-design/icons';
|
|
4
|
+
import { Toast, Tooltip } from '@coze-arch/coze-design';
|
|
5
|
+
import IconButtonContainer from './icon-button-container';
|
|
6
|
+
export function IDRender({ id, showSuffixLength = 5, enableCopy = true, useTag = false, defaultShowCopyBtn, }) {
|
|
7
|
+
const idString = id?.toString() ?? '';
|
|
8
|
+
const suffix = idString.slice(Math.max(idString.length - showSuffixLength, 0), idString.length);
|
|
9
|
+
return (_jsxs("div", { className: "group flex items-center gap-1", onClick: e => e.stopPropagation(), children: [_jsx(Tooltip, { content: idString, theme: "dark", children: useTag ? (_jsxs("div", { className: "shrink-0 h-5 flex items-center px-2 rounded-[3px] border border-solid border-[var(--coz-stroke-plus)] font-medium text-[var(--coz-fg-primary)]", children: ["#", suffix || '-'] })) : (_jsxs("span", { className: "shrink-0", children: ["#", suffix || '-'] })) }), enableCopy ? (_jsx(Tooltip, { content: "\u590D\u5236 ID", theme: "dark", children: _jsx("div", { children: _jsx(IconButtonContainer, { className: classNames('id-render-copy-action-button shrink-0 text-sm', defaultShowCopyBtn ? '' : ' hidden group-hover:flex'), icon: _jsx(IconCozCopy, {}), onClick: async (e) => {
|
|
10
|
+
e.stopPropagation();
|
|
11
|
+
try {
|
|
12
|
+
await navigator.clipboard.writeText(idString);
|
|
13
|
+
Toast.success('复制成功');
|
|
14
|
+
}
|
|
15
|
+
catch (error) {
|
|
16
|
+
console.error(error);
|
|
17
|
+
Toast.error('复制失败');
|
|
18
|
+
}
|
|
19
|
+
} }) }) })) : null] }));
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/id-render/index.tsx"],"names":[],"mappings":";AAAA,OAAO,UAAU,MAAM,YAAY,CAAC;AACpC,OAAO,EAAE,WAAW,EAAE,MAAM,8BAA8B,CAAC;AAC3D,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AAExD,OAAO,mBAAmB,MAAM,yBAAyB,CAAC;AAE1D,MAAM,UAAU,QAAQ,CAAC,EACvB,EAAE,EACF,gBAAgB,GAAG,CAAC,EACpB,UAAU,GAAG,IAAI,EACjB,MAAM,GAAG,KAAK,EACd,kBAAkB,GAOnB;IACC,MAAM,QAAQ,GAAG,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;IACtC,MAAM,MAAM,GAAG,QAAQ,CAAC,KAAK,CAC3B,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,MAAM,GAAG,gBAAgB,EAAE,CAAC,CAAC,EAC/C,QAAQ,CAAC,MAAM,CAChB,CAAC;IACF,OAAO,CACL,eACE,SAAS,EAAC,+BAA+B,EACzC,OAAO,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,eAAe,EAAE,aAEjC,KAAC,OAAO,IAAC,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAC,MAAM,YACrC,MAAM,CAAC,CAAC,CAAC,CACR,eAAK,SAAS,EAAC,gJAAgJ,kBAC3J,MAAM,IAAI,GAAG,IACX,CACP,CAAC,CAAC,CAAC,CACF,gBAAM,SAAS,EAAC,UAAU,kBAAG,MAAM,IAAI,GAAG,IAAQ,CACnD,GACO,EACT,UAAU,CAAC,CAAC,CAAC,CACZ,KAAC,OAAO,IAAC,OAAO,EAAC,iBAAO,EAAC,KAAK,EAAC,MAAM,YACnC,wBACE,KAAC,mBAAmB,IAClB,SAAS,EAAE,UAAU,CACnB,+CAA+C,EAC/C,kBAAkB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,0BAA0B,CACrD,EACD,IAAI,EAAE,KAAC,WAAW,KAAG,EACrB,OAAO,EAAE,KAAK,EAAC,CAAC,EAAC,EAAE;4BACjB,CAAC,CAAC,eAAe,EAAE,CAAC;4BACpB,IAAI,CAAC;gCACH,MAAM,SAAS,CAAC,SAAS,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;gCAC9C,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;4BACxB,CAAC;4BAAC,OAAO,KAAK,EAAE,CAAC;gCACf,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;gCACrB,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;4BACtB,CAAC;wBACH,CAAC,GACD,GACE,GACE,CACX,CAAC,CAAC,CAAC,IAAI,IACJ,CACP,CAAC;AACJ,CAAC"}
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
export { ColumnSelector, type ColumnItem } from './columns-select';
|
|
2
|
+
export { TooltipWhenDisabled } from './tooltip-with-disabled';
|
|
3
|
+
export { LoopTable } from './table';
|
|
4
|
+
export { TableWithPagination, DEFAULT_PAGE_SIZE, PAGE_SIZE_OPTIONS, } from './table/table-with-pagination';
|
|
5
|
+
export { PageError, PageLoading, PageNoAuth, PageNoContent, PageNotFound, FullPage, } from './page-content';
|
|
6
|
+
export { TableColActions } from './table-col-actions';
|
|
7
|
+
export { LoopTabs } from './tabs';
|
|
8
|
+
export { LargeTxtRender } from './large-txt-render';
|
|
9
|
+
export { InputSlider } from './input-slider';
|
|
10
|
+
export { handleCopy } from './utils/basic';
|
|
11
|
+
export { TextWithCopy } from './text-with-copy';
|
|
12
|
+
export { IDRender } from './id-render';
|
|
13
|
+
export { default as IconButtonContainer } from './id-render/icon-button-container';
|
|
14
|
+
export { getColumnManageStorage, setColumnsManageStorage, dealColumnsWithStorage, } from './column-manage-storage';
|
|
15
|
+
export { PrimaryPage } from './primary-page';
|
|
16
|
+
export { ResizeSidesheet } from './resize-sidesheet';
|
|
17
|
+
export { InfiniteScrollTable, type InfiniteScrollTableRef, } from './infinite-scroll-table';
|
|
18
|
+
export { TableHeader, type TableHeaderProps } from './table-header';
|
|
19
|
+
export { TableWithoutPagination } from './table/table-without-pagniation';
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
export { ColumnSelector } from './columns-select';
|
|
2
|
+
export { TooltipWhenDisabled } from './tooltip-with-disabled';
|
|
3
|
+
export { LoopTable } from './table';
|
|
4
|
+
export { TableWithPagination, DEFAULT_PAGE_SIZE, PAGE_SIZE_OPTIONS, } from './table/table-with-pagination';
|
|
5
|
+
export { PageError, PageLoading, PageNoAuth, PageNoContent, PageNotFound, FullPage, } from './page-content';
|
|
6
|
+
export { TableColActions } from './table-col-actions';
|
|
7
|
+
export { LoopTabs } from './tabs';
|
|
8
|
+
export { LargeTxtRender } from './large-txt-render';
|
|
9
|
+
export { InputSlider } from './input-slider';
|
|
10
|
+
export { handleCopy } from './utils/basic';
|
|
11
|
+
export { TextWithCopy } from './text-with-copy';
|
|
12
|
+
export { IDRender } from './id-render';
|
|
13
|
+
export { default as IconButtonContainer } from './id-render/icon-button-container';
|
|
14
|
+
export { getColumnManageStorage, setColumnsManageStorage, dealColumnsWithStorage, } from './column-manage-storage';
|
|
15
|
+
export { PrimaryPage } from './primary-page';
|
|
16
|
+
export { ResizeSidesheet } from './resize-sidesheet';
|
|
17
|
+
export { InfiniteScrollTable, } from './infinite-scroll-table';
|
|
18
|
+
export { TableHeader } from './table-header';
|
|
19
|
+
// import { TableHeaderProps } from './table-header';
|
|
20
|
+
// export const a = {} as unknown as TableHeaderProps;
|
|
21
|
+
export { TableWithoutPagination } from './table/table-without-pagniation';
|
|
22
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAmB,MAAM,kBAAkB,CAAC;AACnE,OAAO,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AAE9D,OAAO,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AACpC,OAAO,EACL,mBAAmB,EACnB,iBAAiB,EACjB,iBAAiB,GAClB,MAAM,+BAA+B,CAAC;AACvC,OAAO,EACL,SAAS,EACT,WAAW,EACX,UAAU,EACV,aAAa,EACb,YAAY,EACZ,QAAQ,GACT,MAAM,gBAAgB,CAAC;AAExB,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAC;AAElC,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAEpD,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAE7C,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAE3C,OAAO,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAC;AAChD,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AACvC,OAAO,EAAE,OAAO,IAAI,mBAAmB,EAAE,MAAM,mCAAmC,CAAC;AAEnF,OAAO,EACL,sBAAsB,EACtB,uBAAuB,EACvB,sBAAsB,GACvB,MAAM,yBAAyB,CAAC;AAEjC,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAE7C,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AAErD,OAAO,EACL,mBAAmB,GAEpB,MAAM,yBAAyB,CAAC;AAEjC,OAAO,EAAE,WAAW,EAAyB,MAAM,gBAAgB,CAAC;AACpE,sDAAsD;AACtD,sDAAsD;AAEtD,OAAO,EAAE,sBAAsB,EAAE,MAAM,kCAAkC,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { type ForwardedRef } from 'react';
|
|
2
|
+
import { type Data, type InfiniteScrollOptions, type Service } from 'ahooks/lib/useInfiniteScroll/types';
|
|
3
|
+
import { useInfiniteScroll } from 'ahooks';
|
|
4
|
+
import { type TableProps } from '@coze-arch/coze-design';
|
|
5
|
+
interface ExpandData extends Data {
|
|
6
|
+
hasMore?: boolean;
|
|
7
|
+
}
|
|
8
|
+
interface InfiniteScrollTableProps<TData extends ExpandData> {
|
|
9
|
+
service: Service<TData>;
|
|
10
|
+
options?: InfiniteScrollOptions<TData>;
|
|
11
|
+
}
|
|
12
|
+
export interface InfiniteScrollTableRef {
|
|
13
|
+
hookRes: ReturnType<typeof useInfiniteScroll>;
|
|
14
|
+
}
|
|
15
|
+
type Props<TData extends ExpandData> = TableProps & InfiniteScrollTableProps<TData>;
|
|
16
|
+
export declare const InfiniteScrollTable: <TData extends ExpandData>(props: Props<TData> & {
|
|
17
|
+
ref?: ForwardedRef<InfiniteScrollTableRef>;
|
|
18
|
+
}) => React.ReactElement | null;
|
|
19
|
+
export {};
|