@cmstops/pro-compo 0.3.35 → 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.
Files changed (61) hide show
  1. package/dist/index.css +156 -2
  2. package/dist/index.min.css +1 -1
  3. package/es/docPreview/component.d.ts +0 -0
  4. package/es/docPreview/component.js +153 -0
  5. package/es/docPreview/components/PreviewIframe.d.ts +0 -0
  6. package/es/docPreview/components/PreviewIframe.js +37 -0
  7. package/es/docPreview/images/phone.js +2 -0
  8. package/es/docPreview/index.d.ts +2 -0
  9. package/es/docPreview/index.js +7 -0
  10. package/es/docPreview/scripts/api.d.ts +1 -0
  11. package/es/docPreview/scripts/hook.d.ts +20 -0
  12. package/es/docPreview/scripts/hook.js +119 -0
  13. package/es/docPreview/style/css.js +1 -0
  14. package/es/docPreview/style/index.css +139 -0
  15. package/es/docPreview/style/index.d.ts +1 -0
  16. package/es/docPreview/style/index.js +1 -0
  17. package/es/docPreview/style/index.less +129 -0
  18. package/es/docPreview/style/previewIframe.less +36 -0
  19. package/es/hooks/useSelection.js +1 -1
  20. package/es/index.css +156 -2
  21. package/es/index.d.ts +1 -0
  22. package/es/index.js +1 -0
  23. package/es/index.less +1 -0
  24. package/es/selectResourceModal/component.js +7 -9
  25. package/es/selectResourceModal/components/ListContent/index.js +4 -1
  26. package/es/selectResourceModal/components/ListContentLocal/components/Upload.js +2 -13
  27. package/es/selectResourceModal/components/ListContentLocal/index.js +4 -1
  28. package/es/selectResourceModal/components/ListFilter/index.js +3 -2
  29. package/es/selectResourceModal/style/index.css +1 -1
  30. package/es/selectResourceModal/style/index.less +1 -1
  31. package/es/thumbCard/component.js +15 -15
  32. package/es/thumbCard/style/index.css +16 -1
  33. package/es/thumbCard/style/index.less +24 -7
  34. package/es/utils/index.d.ts +2 -0
  35. package/es/utils/index.js +40 -1
  36. package/lib/docPreview/component.js +154 -0
  37. package/lib/docPreview/components/PreviewIframe.js +38 -0
  38. package/lib/docPreview/images/phone.js +3 -0
  39. package/lib/docPreview/index.js +8 -0
  40. package/lib/docPreview/scripts/hook.js +123 -0
  41. package/lib/docPreview/style/css.js +2 -0
  42. package/lib/docPreview/style/index.css +139 -0
  43. package/lib/docPreview/style/index.js +2 -0
  44. package/lib/docPreview/style/index.less +129 -0
  45. package/lib/docPreview/style/previewIframe.less +36 -0
  46. package/lib/hooks/useSelection.js +1 -1
  47. package/lib/index.css +156 -2
  48. package/lib/index.js +2 -0
  49. package/lib/index.less +1 -0
  50. package/lib/selectResourceModal/component.js +6 -8
  51. package/lib/selectResourceModal/components/ListContent/index.js +4 -1
  52. package/lib/selectResourceModal/components/ListContentLocal/components/Upload.js +1 -12
  53. package/lib/selectResourceModal/components/ListContentLocal/index.js +4 -1
  54. package/lib/selectResourceModal/components/ListFilter/index.js +3 -2
  55. package/lib/selectResourceModal/style/index.css +1 -1
  56. package/lib/selectResourceModal/style/index.less +1 -1
  57. package/lib/thumbCard/component.js +15 -15
  58. package/lib/thumbCard/style/index.css +16 -1
  59. package/lib/thumbCard/style/index.less +24 -7
  60. package/lib/utils/index.js +41 -0
  61. package/package.json +1 -1
@@ -0,0 +1,153 @@
1
+ import { defineComponent, toRef, onMounted, openBlock, createElementBlock, createElementVNode, createVNode, unref, withCtx, Fragment, createCommentVNode, createTextVNode, toDisplayString, isRef, renderList, createBlock } from "vue";
2
+ import { Spin, Link, Button, Select, Option } from "@arco-design/web-vue";
3
+ import { IconClose } from "@arco-design/web-vue/es/icon";
4
+ import { DEFAULT_BASE_API } from "../config.js";
5
+ import _sfc_main$1 from "./components/PreviewIframe.js";
6
+ import { useDocPreview, EXPIRE_TIME_OPTIONS } from "./scripts/hook.js";
7
+ const _hoisted_1 = { class: "doc-preview-container" };
8
+ const _hoisted_2 = { class: "preview-close" };
9
+ const _hoisted_3 = { class: "doc-preview-share" };
10
+ const _hoisted_4 = { class: "doc-preview-share-img" };
11
+ const _hoisted_5 = ["src"];
12
+ const _hoisted_6 = /* @__PURE__ */ createElementVNode("div", { class: "doc-preview-share-tips" }, "\u626B\u63CF\u4E8C\u7EF4\u7801\u8BBF\u95EE", -1);
13
+ const _hoisted_7 = { class: "doc-preview-share-header" };
14
+ const _hoisted_8 = /* @__PURE__ */ createElementVNode("span", null, "\u9884\u89C8\u5730\u5740", -1);
15
+ const _hoisted_9 = { class: "doc-preview-share-link" };
16
+ const _hoisted_10 = { class: "doc-preview-share-link-value" };
17
+ const _hoisted_11 = { class: "doc-preview-share-link-hint" };
18
+ const _hoisted_12 = { class: "doc-preview-share-action" };
19
+ const _hoisted_13 = /* @__PURE__ */ createElementVNode("div", { class: "doc-preview-share-img" }, [
20
+ /* @__PURE__ */ createElementVNode("div", { class: "doc-preview-share-img-hint" }, " \u6682\u65E0\u9884\u89C8 ")
21
+ ], -1);
22
+ const _hoisted_14 = /* @__PURE__ */ createElementVNode("div", { class: "doc-preview-share-tips" }, " \u5185\u5BB9\u6682\u65E0\u9884\u89C8\u94FE\u63A5\uFF0C\u53EF\u751F\u6210\u9884\u89C8\u94FE\u63A5 ", -1);
23
+ const _hoisted_15 = { class: "doc-preview-share-header" };
24
+ const _hoisted_16 = /* @__PURE__ */ createElementVNode("span", null, "\u94FE\u63A5\u6709\u6548\u65F6\u957F", -1);
25
+ const _hoisted_17 = { class: "doc-preview-share-action" };
26
+ const _sfc_main = defineComponent({
27
+ ...{ name: "docPreview" },
28
+ __name: "component",
29
+ props: {
30
+ BASE_API: {},
31
+ hashid: {}
32
+ },
33
+ emits: ["close"],
34
+ setup(__props, { emit: __emit }) {
35
+ const props = __props;
36
+ const emits = __emit;
37
+ const BASE_API = props.BASE_API || DEFAULT_BASE_API;
38
+ const {
39
+ generate,
40
+ cancel,
41
+ copy,
42
+ shareData,
43
+ innerUrl,
44
+ expireTime,
45
+ intervalTime,
46
+ loading
47
+ } = useDocPreview(BASE_API, toRef(props, "hashid"));
48
+ onMounted(() => {
49
+ generate();
50
+ });
51
+ return (_ctx, _cache) => {
52
+ return openBlock(), createElementBlock("div", _hoisted_1, [
53
+ createElementVNode("div", _hoisted_2, [
54
+ createVNode(unref(IconClose), {
55
+ onClick: _cache[0] || (_cache[0] = ($event) => emits("close"))
56
+ })
57
+ ]),
58
+ createVNode(_sfc_main$1, { src: unref(innerUrl) }, null, 8, ["src"]),
59
+ createVNode(unref(Spin), { loading: unref(loading) }, {
60
+ default: withCtx(() => [
61
+ createElementVNode("div", _hoisted_3, [
62
+ unref(shareData) ? (openBlock(), createElementBlock(Fragment, { key: 0 }, [
63
+ createCommentVNode(" \u4E8C\u7EF4\u7801 "),
64
+ createElementVNode("div", _hoisted_4, [
65
+ createElementVNode("img", {
66
+ src: unref(shareData).qrCode,
67
+ alt: ""
68
+ }, null, 8, _hoisted_5)
69
+ ]),
70
+ createCommentVNode(" \u5907\u6CE8 "),
71
+ _hoisted_6,
72
+ createCommentVNode(" \u94FE\u63A5\u524D\u7F6E\u64CD\u4F5C "),
73
+ createElementVNode("div", _hoisted_7, [
74
+ _hoisted_8,
75
+ createVNode(unref(Link), {
76
+ type: "text",
77
+ onClick: unref(copy)
78
+ }, {
79
+ default: withCtx(() => [
80
+ createTextVNode(" \u590D\u5236\u94FE\u63A5 ")
81
+ ]),
82
+ _: 1
83
+ }, 8, ["onClick"])
84
+ ]),
85
+ createCommentVNode(" \u94FE\u63A5 "),
86
+ createElementVNode("div", _hoisted_9, [
87
+ createElementVNode("div", _hoisted_10, toDisplayString(unref(shareData).shareUrl), 1),
88
+ createElementVNode("div", _hoisted_11, " \u94FE\u63A5\u5269\u4F59\u65F6\u95F4\uFF1A" + toDisplayString(unref(intervalTime)), 1)
89
+ ]),
90
+ createCommentVNode(" \u64CD\u4F5C "),
91
+ createElementVNode("div", _hoisted_12, [
92
+ createVNode(unref(Button), {
93
+ onClick: _cache[1] || (_cache[1] = ($event) => unref(cancel)())
94
+ }, {
95
+ default: withCtx(() => [
96
+ createTextVNode("\u53D6\u6D88\u9884\u89C8\u94FE\u63A5")
97
+ ]),
98
+ _: 1
99
+ }),
100
+ createVNode(unref(Button), {
101
+ type: "primary",
102
+ onClick: _cache[2] || (_cache[2] = ($event) => unref(cancel)(true))
103
+ }, {
104
+ default: withCtx(() => [
105
+ createTextVNode(" \u66F4\u65B0\u9884\u89C8\u6709\u6548\u671F ")
106
+ ]),
107
+ _: 1
108
+ })
109
+ ])
110
+ ], 64)) : (openBlock(), createElementBlock(Fragment, { key: 1 }, [
111
+ _hoisted_13,
112
+ _hoisted_14,
113
+ createElementVNode("div", _hoisted_15, [
114
+ _hoisted_16,
115
+ createVNode(unref(Select), {
116
+ modelValue: unref(expireTime),
117
+ "onUpdate:modelValue": _cache[3] || (_cache[3] = ($event) => isRef(expireTime) ? expireTime.value = $event : null),
118
+ size: "mini",
119
+ style: { "width": "120px" }
120
+ }, {
121
+ default: withCtx(() => [
122
+ (openBlock(true), createElementBlock(Fragment, null, renderList(unref(EXPIRE_TIME_OPTIONS), (t, index) => {
123
+ return openBlock(), createBlock(unref(Option), {
124
+ key: index,
125
+ label: t.label,
126
+ value: t.value
127
+ }, null, 8, ["label", "value"]);
128
+ }), 128))
129
+ ]),
130
+ _: 1
131
+ }, 8, ["modelValue"])
132
+ ]),
133
+ createElementVNode("div", _hoisted_17, [
134
+ createVNode(unref(Button), {
135
+ type: "primary",
136
+ onClick: _cache[4] || (_cache[4] = () => unref(generate)())
137
+ }, {
138
+ default: withCtx(() => [
139
+ createTextVNode(" \u751F\u6210\u9884\u89C8\u94FE\u63A5 ")
140
+ ]),
141
+ _: 1
142
+ })
143
+ ])
144
+ ], 64))
145
+ ])
146
+ ]),
147
+ _: 1
148
+ }, 8, ["loading"])
149
+ ]);
150
+ };
151
+ }
152
+ });
153
+ export { _sfc_main as default };
File without changes
@@ -0,0 +1,37 @@
1
+ import { defineComponent, openBlock, createElementBlock, createElementVNode, createVNode, unref } from "vue";
2
+ import _imports_0 from "../images/phone.js";
3
+ import { Spin } from "@arco-design/web-vue";
4
+ const _hoisted_1 = { class: "iframe-container" };
5
+ const _hoisted_2 = /* @__PURE__ */ createElementVNode("img", {
6
+ src: _imports_0,
7
+ alt: ""
8
+ }, null, -1);
9
+ const _hoisted_3 = { class: "iframe-content" };
10
+ const _hoisted_4 = ["src"];
11
+ const _hoisted_5 = {
12
+ key: 1,
13
+ class: "loading-wrapper"
14
+ };
15
+ const _sfc_main = defineComponent({
16
+ __name: "PreviewIframe",
17
+ props: {
18
+ src: {}
19
+ },
20
+ setup(__props) {
21
+ return (_ctx, _cache) => {
22
+ return openBlock(), createElementBlock("div", _hoisted_1, [
23
+ _hoisted_2,
24
+ createElementVNode("div", _hoisted_3, [
25
+ _ctx.src ? (openBlock(), createElementBlock("iframe", {
26
+ key: 0,
27
+ style: { "overflow": "hidden" },
28
+ src: _ctx.src
29
+ }, null, 8, _hoisted_4)) : (openBlock(), createElementBlock("div", _hoisted_5, [
30
+ createVNode(unref(Spin), { loading: true })
31
+ ]))
32
+ ])
33
+ ]);
34
+ };
35
+ }
36
+ });
37
+ export { _sfc_main as default };
@@ -0,0 +1,2 @@
1
+ var _imports_0 = "";
2
+ export { _imports_0 as default };
@@ -0,0 +1,2 @@
1
+ declare const docPreview: any;
2
+ export default docPreview;
@@ -0,0 +1,7 @@
1
+ import _sfc_main from "./component.js";
2
+ const docPreview = Object.assign(_sfc_main, {
3
+ install: (app) => {
4
+ app.component(_sfc_main.name, _sfc_main);
5
+ }
6
+ });
7
+ export { docPreview as default };
@@ -0,0 +1 @@
1
+ export declare function generateDocPreviewLink(BASE_API: string, params: any): import("axios").AxiosPromise<any>;
@@ -0,0 +1,20 @@
1
+ import { Ref } from 'vue';
2
+ export declare function generateDocPreviewLink(BASE_API: string, params: any): import("axios").AxiosPromise<any>;
3
+ export declare const EXPIRE_TIME_OPTIONS: {
4
+ label: string;
5
+ value: number;
6
+ }[];
7
+ export declare function useDocPreview(BASE_API: string, hashid: Ref<string>): {
8
+ generate: (cancel?: boolean | undefined) => Promise<boolean>;
9
+ cancel: (update?: boolean | undefined) => Promise<void>;
10
+ copy: () => Promise<void>;
11
+ loading: Ref<boolean>;
12
+ expireTime: Ref<number>;
13
+ innerUrl: Ref<string>;
14
+ shareData: Ref<{
15
+ qrCode: string;
16
+ shareUrl: string;
17
+ expiredAt: number;
18
+ } | null>;
19
+ intervalTime: Ref<string>;
20
+ };
@@ -0,0 +1,119 @@
1
+ import { ref } from "vue";
2
+ import { Message } from "@arco-design/web-vue";
3
+ import request from "../../utils/request.js";
4
+ import { copyContent } from "../../utils/index.js";
5
+ function generateDocPreviewLink(BASE_API, params) {
6
+ return request(BASE_API, {
7
+ url: "/poplar/v3/preview/document/generate",
8
+ method: "post",
9
+ data: params
10
+ });
11
+ }
12
+ function getTimeToNow(second) {
13
+ second = parseInt((second / 1e3).toFixed(0), 10);
14
+ function need(value, label) {
15
+ if (!value)
16
+ return "";
17
+ const tow = (n) => {
18
+ return n >= 0 && n < 10 ? `0${n}` : `${n}`;
19
+ };
20
+ return tow(value) + label;
21
+ }
22
+ const day = Math.floor(second / 86400);
23
+ second %= 86400;
24
+ const hour = Math.floor(second / 3600);
25
+ second %= 3600;
26
+ const minute = Math.floor(second / 60);
27
+ second %= 60;
28
+ return need(day, "\u5929") + need(hour, "\u5C0F\u65F6") + need(minute, "\u5206\u949F") + need(second, "\u79D2");
29
+ }
30
+ const EXPIRE_TIME_OPTIONS = [
31
+ { label: "1\u5C0F\u65F6", value: 60 * 60 },
32
+ { label: "6\u5C0F\u65F6", value: 60 * 60 * 6 },
33
+ { label: "12\u5C0F\u65F6", value: 60 * 60 * 12 },
34
+ { label: "24\u5C0F\u65F6", value: 60 * 60 * 24 },
35
+ { label: "3\u5929", value: 60 * 60 * 24 * 3 },
36
+ { label: "7\u5929", value: 60 * 60 * 24 * 7 },
37
+ { label: "15\u5929", value: 60 * 60 * 24 * 15 },
38
+ { label: "30\u5929", value: 60 * 60 * 24 * 30 }
39
+ ];
40
+ function useDocPreview(BASE_API, hashid) {
41
+ const innerUrl = ref("");
42
+ const shareData = ref(null);
43
+ const expireTime = ref(60 * 60 * 24);
44
+ const loading = ref(false);
45
+ const intervalTime = ref("");
46
+ let interval = null;
47
+ function startInterval() {
48
+ var _a;
49
+ if (!((_a = shareData.value) == null ? void 0 : _a.expiredAt)) {
50
+ clearInterval(interval);
51
+ interval = null;
52
+ return;
53
+ }
54
+ const now = new Date().getTime();
55
+ const expire = new Date(shareData.value.expiredAt).getTime();
56
+ intervalTime.value = getTimeToNow(expire - now);
57
+ }
58
+ async function generate(cancel2) {
59
+ loading.value = true;
60
+ const params = { force: true, hash_id: hashid.value };
61
+ if (!cancel2)
62
+ params.expiration = expireTime.value;
63
+ else
64
+ params.expiration = 0;
65
+ try {
66
+ const { code, message } = await generateDocPreviewLink(BASE_API, params);
67
+ if (code !== 0)
68
+ return false;
69
+ const { expired_at, share_url, inner_url, qr_code } = message;
70
+ if (cancel2) {
71
+ shareData.value = null;
72
+ clearInterval(interval);
73
+ interval = null;
74
+ intervalTime.value = "";
75
+ } else {
76
+ shareData.value = {
77
+ qrCode: `data:image/png;base64,${qr_code}`,
78
+ shareUrl: share_url,
79
+ expiredAt: expired_at
80
+ };
81
+ innerUrl.value = `${inner_url}?reqTime=${+new Date()}`;
82
+ setInterval(startInterval, 1e3);
83
+ }
84
+ return true;
85
+ } catch (e) {
86
+ console.log(e, "----");
87
+ return false;
88
+ } finally {
89
+ loading.value = false;
90
+ }
91
+ }
92
+ async function cancel(update) {
93
+ const flag = await generate(true);
94
+ if (!flag)
95
+ return;
96
+ const text = update ? "\u5DF2\u53D6\u6D88\u9884\u89C8\uFF0C\u8BF7\u66F4\u65B0\u6709\u6548\u671F\u91CD\u65B0\u751F\u6210\u9884\u89C8\u94FE\u63A5" : "\u5DF2\u53D6\u6D88\u9884\u89C8\u94FE\u63A5";
97
+ Message.warning(text);
98
+ }
99
+ async function copy() {
100
+ var _a;
101
+ if (!((_a = shareData.value) == null ? void 0 : _a.shareUrl))
102
+ return;
103
+ const res = await copyContent(shareData.value.shareUrl);
104
+ if (res) {
105
+ Message.success("\u590D\u5236\u6210\u529F");
106
+ }
107
+ }
108
+ return {
109
+ generate,
110
+ cancel,
111
+ copy,
112
+ loading,
113
+ expireTime,
114
+ innerUrl,
115
+ shareData,
116
+ intervalTime
117
+ };
118
+ }
119
+ export { EXPIRE_TIME_OPTIONS, generateDocPreviewLink, useDocPreview };
@@ -0,0 +1 @@
1
+ import "./index.css";