@cmstops/pro-compo 0.3.34 → 0.3.36
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/index.css +269 -59
- package/dist/index.min.css +1 -1
- package/es/docPreview/component.d.ts +0 -0
- package/es/docPreview/component.js +153 -0
- package/es/docPreview/components/PreviewIframe.d.ts +0 -0
- package/es/docPreview/components/PreviewIframe.js +37 -0
- package/es/docPreview/images/phone.js +2 -0
- package/es/docPreview/index.d.ts +2 -0
- package/es/docPreview/index.js +7 -0
- package/es/docPreview/scripts/api.d.ts +1 -0
- package/es/docPreview/scripts/hook.d.ts +20 -0
- package/es/docPreview/scripts/hook.js +119 -0
- package/es/docPreview/style/css.js +1 -0
- package/es/docPreview/style/index.css +139 -0
- package/es/docPreview/style/index.d.ts +1 -0
- package/es/docPreview/style/index.js +1 -0
- package/es/docPreview/style/index.less +129 -0
- package/es/docPreview/style/previewIframe.less +36 -0
- package/es/hooks/useSelection.js +1 -1
- package/es/hooks/useUpload.d.ts +15 -0
- package/es/hooks/useUpload.js +88 -0
- package/es/index.css +269 -59
- package/es/index.d.ts +1 -0
- package/es/index.js +1 -0
- package/es/index.less +1 -0
- package/es/selectResourceModal/component.js +30 -16
- package/es/selectResourceModal/components/ListCardWrapper/index.d.ts +0 -0
- package/es/selectResourceModal/components/ListCardWrapper/index.js +56 -0
- package/es/selectResourceModal/components/ListContent/index.js +16 -36
- package/es/selectResourceModal/components/ListContentLocal/components/Upload.d.ts +0 -0
- package/es/selectResourceModal/components/ListContentLocal/components/Upload.js +56 -0
- package/es/selectResourceModal/components/ListContentLocal/index.d.ts +0 -0
- package/es/selectResourceModal/components/ListContentLocal/index.js +90 -0
- package/es/selectResourceModal/components/ListFilter/index.js +12 -4
- package/es/selectResourceModal/style/index.css +98 -58
- package/es/selectResourceModal/style/index.less +20 -2
- package/es/selectResourceModal/style/listCardWrapper.less +63 -0
- package/es/selectResourceModal/style/listContent.less +1 -63
- package/es/selectResourceModal/style/listContentLocal.less +26 -0
- package/es/selectResourceModal/style/listSelected.less +11 -3
- package/es/thumbCard/assets/magic.js +2 -0
- package/es/thumbCard/component.js +80 -53
- package/es/thumbCard/style/index.css +32 -1
- package/es/thumbCard/style/index.less +45 -7
- package/es/utils/index.d.ts +2 -0
- package/es/utils/index.js +40 -1
- package/es/utils/tusUpload.d.ts +8 -0
- package/es/utils/tusUpload.js +35 -1
- package/lib/docPreview/component.js +154 -0
- package/lib/docPreview/components/PreviewIframe.js +38 -0
- package/lib/docPreview/images/phone.js +3 -0
- package/lib/docPreview/index.js +8 -0
- package/lib/docPreview/scripts/hook.js +123 -0
- package/lib/docPreview/style/css.js +2 -0
- package/lib/docPreview/style/index.css +139 -0
- package/lib/docPreview/style/index.js +2 -0
- package/lib/docPreview/style/index.less +129 -0
- package/lib/docPreview/style/previewIframe.less +36 -0
- package/lib/hooks/useSelection.js +1 -1
- package/lib/hooks/useUpload.js +91 -0
- package/lib/index.css +269 -59
- package/lib/index.js +2 -0
- package/lib/index.less +1 -0
- package/lib/selectResourceModal/component.js +31 -17
- package/lib/selectResourceModal/components/ListCardWrapper/index.js +57 -0
- package/lib/selectResourceModal/components/ListContent/index.js +19 -39
- package/lib/selectResourceModal/components/ListContentLocal/components/Upload.js +57 -0
- package/lib/selectResourceModal/components/ListContentLocal/index.js +91 -0
- package/lib/selectResourceModal/components/ListFilter/index.js +12 -4
- package/lib/selectResourceModal/style/index.css +98 -58
- package/lib/selectResourceModal/style/index.less +20 -2
- package/lib/selectResourceModal/style/listCardWrapper.less +63 -0
- package/lib/selectResourceModal/style/listContent.less +1 -63
- package/lib/selectResourceModal/style/listContentLocal.less +26 -0
- package/lib/selectResourceModal/style/listSelected.less +11 -3
- package/lib/thumbCard/assets/magic.js +3 -0
- package/lib/thumbCard/component.js +78 -51
- package/lib/thumbCard/style/index.css +32 -1
- package/lib/thumbCard/style/index.less +45 -7
- package/lib/utils/index.js +41 -0
- package/lib/utils/tusUpload.js +35 -0
- package/package.json +1 -1
|
@@ -1,67 +1,5 @@
|
|
|
1
1
|
.card-list-wrapper {
|
|
2
2
|
display: grid;
|
|
3
3
|
grid-gap: 20px;
|
|
4
|
-
grid-template-columns: repeat(
|
|
5
|
-
|
|
6
|
-
.card-wrapper-image {
|
|
7
|
-
position: relative;
|
|
8
|
-
overflow: hidden;
|
|
9
|
-
|
|
10
|
-
.card-wrapper {
|
|
11
|
-
overflow: hidden;
|
|
12
|
-
// 宽高:43
|
|
13
|
-
aspect-ratio: 4 / 3;
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
.card-alias {
|
|
17
|
-
width: 100%;
|
|
18
|
-
margin-top: 6px;
|
|
19
|
-
overflow: hidden;
|
|
20
|
-
color: #3d3d3d;
|
|
21
|
-
font-size: 14px;
|
|
22
|
-
line-height: 22px;
|
|
23
|
-
white-space: nowrap;
|
|
24
|
-
text-overflow: ellipsis;
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
&:hover .check-box-wrapper .check-box,
|
|
28
|
-
.check-box-wrapper .check-box.active {
|
|
29
|
-
opacity: 1;
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
.check-box-wrapper {
|
|
33
|
-
position: absolute;
|
|
34
|
-
top: 8px;
|
|
35
|
-
left: 8px;
|
|
36
|
-
cursor: pointer;
|
|
37
|
-
|
|
38
|
-
.check-box {
|
|
39
|
-
box-sizing: border-box;
|
|
40
|
-
width: 22px;
|
|
41
|
-
height: 22px;
|
|
42
|
-
font-size: 14px;
|
|
43
|
-
line-height: 22px;
|
|
44
|
-
text-align: center;
|
|
45
|
-
background-color: rgba(0, 0, 0, 0.2);
|
|
46
|
-
border: 1px solid white;
|
|
47
|
-
border-radius: 50%;
|
|
48
|
-
opacity: 0;
|
|
49
|
-
transition: all 0.3s ease-in-out;
|
|
50
|
-
|
|
51
|
-
&::selection {
|
|
52
|
-
display: none;
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
&:hover {
|
|
56
|
-
background-color: rgba(0, 0, 0, 0.3);
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
&.active {
|
|
60
|
-
color: white;
|
|
61
|
-
background-color: #165dff;
|
|
62
|
-
border-color: #165dff;
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
}
|
|
4
|
+
grid-template-columns: repeat(5, 1fr);
|
|
67
5
|
}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
.upload-list-wrapper {
|
|
2
|
+
.list-content {
|
|
3
|
+
margin-top: 30px;
|
|
4
|
+
|
|
5
|
+
.list-tips {
|
|
6
|
+
margin-bottom: 16px;
|
|
7
|
+
color: #3d3d3d;
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
.upload-list-wrapper .upload-wrapper {
|
|
13
|
+
display: flex;
|
|
14
|
+
flex-direction: column;
|
|
15
|
+
|
|
16
|
+
.upload-buttons {
|
|
17
|
+
display: flex;
|
|
18
|
+
gap: 20px;
|
|
19
|
+
justify-content: center;
|
|
20
|
+
margin: 20px 0;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
.upload-dragger {
|
|
24
|
+
width: calc(100% - 2px);
|
|
25
|
+
}
|
|
26
|
+
}
|
|
@@ -8,7 +8,6 @@
|
|
|
8
8
|
}
|
|
9
9
|
|
|
10
10
|
width: 420px;
|
|
11
|
-
max-height: 600px;
|
|
12
11
|
padding: 0 !important;
|
|
13
12
|
overflow: hidden;
|
|
14
13
|
border: none;
|
|
@@ -16,7 +15,12 @@
|
|
|
16
15
|
box-shadow: 0 4px 10px 0 rgba(0, 0, 0, 0.1);
|
|
17
16
|
|
|
18
17
|
.arco-popover-content {
|
|
18
|
+
display: flex;
|
|
19
|
+
flex-direction: column;
|
|
20
|
+
height: 100%;
|
|
21
|
+
max-height: 600px;
|
|
19
22
|
margin-top: 0;
|
|
23
|
+
overflow: hidden;
|
|
20
24
|
}
|
|
21
25
|
|
|
22
26
|
.list-panel-header {
|
|
@@ -40,8 +44,12 @@
|
|
|
40
44
|
}
|
|
41
45
|
|
|
42
46
|
.list-selected-record {
|
|
43
|
-
|
|
44
|
-
|
|
47
|
+
flex: 1;
|
|
48
|
+
overflow-y: scroll;
|
|
49
|
+
|
|
50
|
+
&::-webkit-scrollbar {
|
|
51
|
+
display: none;
|
|
52
|
+
}
|
|
45
53
|
|
|
46
54
|
.list-selected-item {
|
|
47
55
|
display: flex;
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
var magic = "";
|
|
2
|
+
export { magic as default };
|
|
@@ -1,11 +1,17 @@
|
|
|
1
|
-
import { defineComponent, computed, openBlock, createElementBlock, normalizeStyle,
|
|
1
|
+
import { defineComponent, computed, openBlock, createElementBlock, normalizeClass, normalizeStyle, createVNode, unref, Fragment, createCommentVNode, withCtx, createTextVNode, createElementVNode, createBlock, mergeProps, renderList, withModifiers, toDisplayString } from "vue";
|
|
2
2
|
import { IconPlus } from "@arco-design/web-vue/es/icon";
|
|
3
3
|
import { IconResource, IconComputer } from "@arco-iconbox/vue-cmstop-icons";
|
|
4
|
-
import { Dropdown, Doption, Image } from "@arco-design/web-vue";
|
|
4
|
+
import { Progress, Dropdown, Doption, Image } from "@arco-design/web-vue";
|
|
5
|
+
import magic from "./assets/magic.js";
|
|
5
6
|
import { DEFAULT_BASE_API } from "../config.js";
|
|
6
|
-
|
|
7
|
+
import { mediaTime } from "../utils/index.js";
|
|
8
|
+
const _hoisted_1 = {
|
|
9
|
+
key: 0,
|
|
10
|
+
class: "thumb-upload-loading"
|
|
11
|
+
};
|
|
7
12
|
const _hoisted_2 = { class: "thumb-handler-list" };
|
|
8
13
|
const _hoisted_3 = ["onClick"];
|
|
14
|
+
const _hoisted_4 = { class: "thumb-select-tag" };
|
|
9
15
|
const _sfc_main = defineComponent({
|
|
10
16
|
...{ name: "thumbCard" },
|
|
11
17
|
__name: "component",
|
|
@@ -14,6 +20,7 @@ const _sfc_main = defineComponent({
|
|
|
14
20
|
url: {},
|
|
15
21
|
thumb: {},
|
|
16
22
|
isEdit: { type: Boolean },
|
|
23
|
+
useMask: { type: Boolean },
|
|
17
24
|
options: {},
|
|
18
25
|
meta: {},
|
|
19
26
|
catalog: {},
|
|
@@ -24,13 +31,31 @@ const _sfc_main = defineComponent({
|
|
|
24
31
|
const props = __props;
|
|
25
32
|
const emits = __emit;
|
|
26
33
|
const BASE_API = props.BASE_API || DEFAULT_BASE_API;
|
|
27
|
-
const WATER_BG_URL =
|
|
34
|
+
const WATER_BG_URL = magic;
|
|
35
|
+
const isUploading = computed(() => {
|
|
36
|
+
var _a;
|
|
37
|
+
return ((_a = props.meta) == null ? void 0 : _a.progress) != null;
|
|
38
|
+
});
|
|
28
39
|
const thumb = computed(() => {
|
|
29
|
-
|
|
40
|
+
if (["image", "video"].includes(props.catalog || "")) {
|
|
41
|
+
return props.thumb || props.url || "";
|
|
42
|
+
}
|
|
43
|
+
return `${BASE_API}/static/img/music.2ee269c.png`;
|
|
44
|
+
});
|
|
45
|
+
const styleObject = computed(() => {
|
|
46
|
+
const style = {};
|
|
47
|
+
if (props.useMask) {
|
|
48
|
+
style.backgroundImage = `url(${WATER_BG_URL})`;
|
|
49
|
+
}
|
|
50
|
+
return style;
|
|
51
|
+
});
|
|
52
|
+
const classList = computed(() => {
|
|
53
|
+
const list = [];
|
|
54
|
+
if (!props.useMask) {
|
|
55
|
+
list.push("thumb-no-mask");
|
|
56
|
+
}
|
|
57
|
+
return list;
|
|
30
58
|
});
|
|
31
|
-
const styleObject = computed(() => ({
|
|
32
|
-
backgroundImage: `url(${WATER_BG_URL})`
|
|
33
|
-
}));
|
|
34
59
|
const aImageAttr = computed(() => {
|
|
35
60
|
return {
|
|
36
61
|
fit: "contain",
|
|
@@ -47,67 +72,69 @@ const _sfc_main = defineComponent({
|
|
|
47
72
|
emits("edit", { key });
|
|
48
73
|
}
|
|
49
74
|
return (_ctx, _cache) => {
|
|
75
|
+
var _a;
|
|
50
76
|
return openBlock(), createElementBlock("div", {
|
|
51
|
-
class: "thumb-select-wrapper",
|
|
77
|
+
class: normalizeClass(["thumb-select-wrapper", classList.value]),
|
|
52
78
|
style: normalizeStyle(styleObject.value)
|
|
53
79
|
}, [
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
80
|
+
isUploading.value ? (openBlock(), createElementBlock("div", _hoisted_1, [
|
|
81
|
+
createVNode(unref(Progress), {
|
|
82
|
+
type: "circle",
|
|
83
|
+
percent: ((_a = _ctx.meta) == null ? void 0 : _a.progress) / 10
|
|
84
|
+
}, null, 8, ["percent"])
|
|
85
|
+
])) : _ctx.isEdit && !_ctx.url ? (openBlock(), createElementBlock(Fragment, { key: 1 }, [
|
|
86
|
+
createCommentVNode(" \u7F16\u8F91\u6A21\u5F0F\u4E0B\u53EF\u4F7F\u7528\u60AC\u6D6E\u6846\u5FEB\u901F\u63D2\u5165\u7D20\u6750 "),
|
|
87
|
+
createVNode(unref(Dropdown), {
|
|
88
|
+
trigger: "hover",
|
|
89
|
+
onSelect: handleEdit
|
|
90
|
+
}, {
|
|
91
|
+
content: withCtx(() => [
|
|
92
|
+
createVNode(unref(Doption), { value: "resource" }, {
|
|
93
|
+
default: withCtx(() => [
|
|
94
|
+
createVNode(unref(IconResource)),
|
|
95
|
+
createTextVNode(" \u7D20\u6750\u5E93\u9009\u62E9 ")
|
|
96
|
+
]),
|
|
97
|
+
_: 1
|
|
98
|
+
}),
|
|
99
|
+
createVNode(unref(Doption), { value: "local" }, {
|
|
100
|
+
default: withCtx(() => [
|
|
101
|
+
createVNode(unref(IconComputer)),
|
|
102
|
+
createTextVNode(" \u672C\u5730\u4E0A\u4F20 ")
|
|
103
|
+
]),
|
|
104
|
+
_: 1
|
|
105
|
+
})
|
|
106
|
+
]),
|
|
107
|
+
default: withCtx(() => [
|
|
108
|
+
createElementVNode("div", {
|
|
109
|
+
class: "thumb-add",
|
|
110
|
+
onClick: _cache[0] || (_cache[0] = ($event) => handleEdit("resource"))
|
|
111
|
+
}, [
|
|
112
|
+
createVNode(unref(IconPlus))
|
|
113
|
+
])
|
|
114
|
+
]),
|
|
115
|
+
_: 1
|
|
116
|
+
})
|
|
117
|
+
], 64)) : _ctx.catalog && _ctx.url ? (openBlock(), createElementBlock(Fragment, { key: 2 }, [
|
|
118
|
+
createCommentVNode(" \u6709\u7C7B\u578B\u7684\u5C01\u9762 "),
|
|
82
119
|
createCommentVNode(" \u56FE\u7247 "),
|
|
83
|
-
_ctx.catalog
|
|
120
|
+
_ctx.catalog ? (openBlock(), createBlock(unref(Image), mergeProps({
|
|
84
121
|
key: 0,
|
|
85
122
|
class: "thumb-image",
|
|
86
123
|
src: thumb.value
|
|
87
|
-
}, aImageAttr.value), null, 16, ["src"])) :
|
|
88
|
-
createCommentVNode(" \u89C6\u9891 "),
|
|
89
|
-
createVNode(unref(Image), mergeProps({
|
|
90
|
-
class: "thumb-image",
|
|
91
|
-
src: thumb.value
|
|
92
|
-
}, aImageAttr.value), null, 16, ["src"])
|
|
93
|
-
], 64)) : _ctx.catalog === "audio" ? (openBlock(), createElementBlock(Fragment, { key: 2 }, [
|
|
94
|
-
createCommentVNode(" \u97F3\u9891 "),
|
|
95
|
-
createTextVNode(" \u97F3\u9891 ")
|
|
96
|
-
], 64)) : createCommentVNode("v-if", true),
|
|
124
|
+
}, aImageAttr.value), null, 16, ["src"])) : createCommentVNode("v-if", true),
|
|
97
125
|
createCommentVNode(" \u5C55\u793A\u6A21\u5F0F "),
|
|
98
126
|
createElementVNode("div", _hoisted_2, [
|
|
99
127
|
(openBlock(true), createElementBlock(Fragment, null, renderList(_ctx.handlersKey, (item) => {
|
|
100
128
|
return openBlock(), createElementBlock("div", {
|
|
101
129
|
key: item.key,
|
|
102
130
|
class: "handler-item",
|
|
103
|
-
onClick: () => handleOption(item.key)
|
|
131
|
+
onClick: withModifiers(() => handleOption(item.key), ["stop"])
|
|
104
132
|
}, toDisplayString(item.label), 9, _hoisted_3);
|
|
105
133
|
}), 128))
|
|
106
134
|
])
|
|
107
|
-
], 64)) : (
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
], 4);
|
|
135
|
+
], 64)) : createCommentVNode("v-if", true),
|
|
136
|
+
createElementVNode("div", _hoisted_4, toDisplayString(unref(mediaTime)(_ctx.meta.length)), 1)
|
|
137
|
+
], 6);
|
|
111
138
|
};
|
|
112
139
|
}
|
|
113
140
|
});
|
|
@@ -9,6 +9,18 @@
|
|
|
9
9
|
border-radius: 2px;
|
|
10
10
|
cursor: pointer;
|
|
11
11
|
}
|
|
12
|
+
.thumb-select-wrapper .thumb-upload-loading {
|
|
13
|
+
display: flex;
|
|
14
|
+
align-items: center;
|
|
15
|
+
justify-content: center;
|
|
16
|
+
width: 100%;
|
|
17
|
+
height: 100%;
|
|
18
|
+
color: #fff;
|
|
19
|
+
background-color: rgba(0, 0, 0, 0.5);
|
|
20
|
+
}
|
|
21
|
+
.thumb-select-wrapper .thumb-upload-loading .arco-progress-circle-text {
|
|
22
|
+
color: #fff;
|
|
23
|
+
}
|
|
12
24
|
.thumb-select-wrapper .thumb-add {
|
|
13
25
|
color: var(--color-text-2);
|
|
14
26
|
font-size: 16px;
|
|
@@ -45,7 +57,26 @@
|
|
|
45
57
|
.thumb-select-wrapper:hover .thumb-handler-list {
|
|
46
58
|
opacity: 1;
|
|
47
59
|
}
|
|
48
|
-
.
|
|
60
|
+
.thumb-select-wrapper:hover .thumb-select-tag {
|
|
61
|
+
opacity: 0;
|
|
62
|
+
}
|
|
63
|
+
.thumb-select-wrapper.thumb-no-mask {
|
|
64
|
+
background-color: #f2f3f5;
|
|
65
|
+
border: 1px dashed #e5e6eb !important;
|
|
66
|
+
}
|
|
67
|
+
.thumb-select-wrapper .thumb-select-tag {
|
|
68
|
+
position: absolute;
|
|
69
|
+
right: 5px;
|
|
70
|
+
bottom: 5px;
|
|
71
|
+
padding: 2px 10px;
|
|
72
|
+
color: #fff;
|
|
73
|
+
font-size: 12px;
|
|
74
|
+
background-color: rgba(0, 0, 0, 0.5);
|
|
75
|
+
border-radius: 16px;
|
|
76
|
+
opacity: 1;
|
|
77
|
+
transition: all 0.3s ease-in-out;
|
|
78
|
+
}
|
|
79
|
+
.thumb-select-wrapper .arco-dropdown-option-content {
|
|
49
80
|
display: flex;
|
|
50
81
|
gap: 8px;
|
|
51
82
|
align-items: center;
|
|
@@ -10,6 +10,21 @@
|
|
|
10
10
|
border-radius: 2px;
|
|
11
11
|
cursor: pointer;
|
|
12
12
|
|
|
13
|
+
// loading 模式
|
|
14
|
+
.thumb-upload-loading {
|
|
15
|
+
display: flex;
|
|
16
|
+
align-items: center;
|
|
17
|
+
justify-content: center;
|
|
18
|
+
width: 100%;
|
|
19
|
+
height: 100%;
|
|
20
|
+
color: #fff;
|
|
21
|
+
background-color: rgba(0, 0, 0, 0.5);
|
|
22
|
+
|
|
23
|
+
.arco-progress-circle-text {
|
|
24
|
+
color: #fff;
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
|
|
13
28
|
// 添加模式
|
|
14
29
|
.thumb-add {
|
|
15
30
|
color: var(--color-text-2);
|
|
@@ -58,13 +73,36 @@
|
|
|
58
73
|
.thumb-handler-list {
|
|
59
74
|
opacity: 1;
|
|
60
75
|
}
|
|
76
|
+
|
|
77
|
+
.thumb-select-tag {
|
|
78
|
+
opacity: 0;
|
|
79
|
+
}
|
|
61
80
|
}
|
|
62
|
-
}
|
|
63
81
|
|
|
64
|
-
//
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
82
|
+
// 非马赛克模式
|
|
83
|
+
&.thumb-no-mask {
|
|
84
|
+
background-color: #f2f3f5;
|
|
85
|
+
border: 1px dashed #e5e6eb !important;
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
.thumb-select-tag {
|
|
89
|
+
position: absolute;
|
|
90
|
+
right: 5px;
|
|
91
|
+
bottom: 5px;
|
|
92
|
+
padding: 2px 10px;
|
|
93
|
+
color: #fff;
|
|
94
|
+
font-size: 12px;
|
|
95
|
+
background-color: rgba(0, 0, 0, 0.5);
|
|
96
|
+
border-radius: 16px;
|
|
97
|
+
opacity: 1;
|
|
98
|
+
transition: all 0.3s ease-in-out;
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
// 素材选择
|
|
102
|
+
.arco-dropdown-option-content {
|
|
103
|
+
display: flex;
|
|
104
|
+
gap: 8px;
|
|
105
|
+
align-items: center;
|
|
106
|
+
font-size: 14px;
|
|
107
|
+
}
|
|
70
108
|
}
|
package/es/utils/index.d.ts
CHANGED
|
@@ -13,3 +13,5 @@ export declare const timeFormat: (value: any) => string;
|
|
|
13
13
|
export declare const validateForm: (formRef: any) => Promise<unknown>;
|
|
14
14
|
export declare function getRealUrl(BASE_API: string, url: string): Promise<unknown>;
|
|
15
15
|
export declare function getThemeColor(BASE_API: string, src: string): Promise<unknown>;
|
|
16
|
+
export declare function copyContent(content: string | Blob): Promise<boolean>;
|
|
17
|
+
export declare function mediaTime(v: number): string;
|
package/es/utils/index.js
CHANGED
|
@@ -107,4 +107,43 @@ function getThemeColor(BASE_API, src) {
|
|
|
107
107
|
});
|
|
108
108
|
});
|
|
109
109
|
}
|
|
110
|
-
|
|
110
|
+
async function copyContent(content) {
|
|
111
|
+
try {
|
|
112
|
+
if (typeof content === "string") {
|
|
113
|
+
const input = document.createElement("input");
|
|
114
|
+
input.setAttribute("value", content);
|
|
115
|
+
document.body.appendChild(input);
|
|
116
|
+
input.select();
|
|
117
|
+
document.execCommand("copy");
|
|
118
|
+
document.body.removeChild(input);
|
|
119
|
+
return true;
|
|
120
|
+
}
|
|
121
|
+
if (window.__POWERED_BY_WUJIE__) {
|
|
122
|
+
await window.parent.navigator.clipboard.write([
|
|
123
|
+
new ClipboardItem({
|
|
124
|
+
"image/png": content
|
|
125
|
+
})
|
|
126
|
+
]);
|
|
127
|
+
} else {
|
|
128
|
+
await navigator.clipboard.write([
|
|
129
|
+
new ClipboardItem({
|
|
130
|
+
"image/png": content
|
|
131
|
+
})
|
|
132
|
+
]);
|
|
133
|
+
}
|
|
134
|
+
return true;
|
|
135
|
+
} catch (e) {
|
|
136
|
+
return false;
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
function mediaTime(v) {
|
|
140
|
+
const h = Math.floor(v / (60 * 60));
|
|
141
|
+
const m = Math.floor((v - h) / 60);
|
|
142
|
+
const s = Math.floor(v - h * 360 - m * 60);
|
|
143
|
+
let ret = "";
|
|
144
|
+
ret += `${h < 10 ? `0${h}` : h}:`;
|
|
145
|
+
ret += `${m < 10 ? `0${m}` : m}:`;
|
|
146
|
+
ret += s < 10 ? `0${s}` : s;
|
|
147
|
+
return ret;
|
|
148
|
+
}
|
|
149
|
+
export { copyContent, dateYYYYDDMMHHmm, generateUUID, getRealUrl, getThemeColor, mediaTime, noCoverText, replaceSuffix, timeFormat, to, validateForm };
|
package/es/utils/tusUpload.d.ts
CHANGED
|
@@ -6,3 +6,11 @@ import * as TUS from 'tus-js-client';
|
|
|
6
6
|
* @returns
|
|
7
7
|
*/
|
|
8
8
|
export declare function uploadByTUS(file: File, progressCallback?: (b: number, t: number) => void): Promise<TUS.Upload>;
|
|
9
|
+
export declare class TusUploadTask {
|
|
10
|
+
file: any;
|
|
11
|
+
upload: any;
|
|
12
|
+
platformKey?: string;
|
|
13
|
+
constructor(file: any, platformKey?: string);
|
|
14
|
+
start(callback: (bytesUploaded: any, bytesTotal: any) => any): Promise<unknown>;
|
|
15
|
+
abort(): any;
|
|
16
|
+
}
|
package/es/utils/tusUpload.js
CHANGED
|
@@ -47,4 +47,38 @@ function getFileType(file) {
|
|
|
47
47
|
fType = "application/x-rar";
|
|
48
48
|
return fType;
|
|
49
49
|
}
|
|
50
|
-
|
|
50
|
+
class TusUploadTask {
|
|
51
|
+
constructor(file, platformKey) {
|
|
52
|
+
this.file = file;
|
|
53
|
+
this.platformKey = platformKey || "holly";
|
|
54
|
+
}
|
|
55
|
+
start(callback) {
|
|
56
|
+
return new Promise((resolve, reject) => {
|
|
57
|
+
const upload = new TUS.Upload(this.file, {
|
|
58
|
+
endpoint: `${DEFAULT_UPLOAD_URL}/upload/`,
|
|
59
|
+
chunkSize: DEFAULT_UPLOAD_CHUNK_SIZE || 5242880,
|
|
60
|
+
retryDelays: [0, 1e3, 3e3, 5e3],
|
|
61
|
+
overridePatchMethod: true,
|
|
62
|
+
removeFingerprintOnSuccess: true,
|
|
63
|
+
metadata: {
|
|
64
|
+
filename: this.file.name,
|
|
65
|
+
filetype: getFileType(this.file),
|
|
66
|
+
platform: this.platformKey
|
|
67
|
+
},
|
|
68
|
+
onBeforeRequest: (req) => {
|
|
69
|
+
const xhr = req.getUnderlyingObject();
|
|
70
|
+
xhr.withCredentials = true;
|
|
71
|
+
},
|
|
72
|
+
onProgress: callback,
|
|
73
|
+
onSuccess: () => resolve(upload.url),
|
|
74
|
+
onError: (error) => reject(error)
|
|
75
|
+
});
|
|
76
|
+
this.upload = upload;
|
|
77
|
+
upload.start();
|
|
78
|
+
});
|
|
79
|
+
}
|
|
80
|
+
abort() {
|
|
81
|
+
return this.upload.abort();
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
export { TusUploadTask, uploadByTUS };
|