ling-yun-custom-components 0.0.39 → 0.0.41

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 (39) hide show
  1. package/es/AppIntro.mjs +536 -0
  2. package/es/BuildComponents.mjs +1 -1
  3. package/es/IconRenderer.mjs +1 -1
  4. package/es/PageNotFound.mjs +23 -27
  5. package/es/PaginationTable.mjs +5 -4
  6. package/es/assets/AppIntro.css +1 -0
  7. package/es/assets/BuildComponents.css +1 -1
  8. package/es/assets/PageNotFound.css +0 -0
  9. package/es/assets/PaginationTable.css +1 -1
  10. package/es/chunks/global.DLyUBjAm.js +8080 -0
  11. package/es/chunks/global.Dasz_fnL.js +16065 -0
  12. package/es/chunks/global.DpSgdQXX.js +7906 -0
  13. package/es/chunks/layout.BgtHhnxJ.js +66 -0
  14. package/es/chunks/layout.CRtj9xK9.js +230 -0
  15. package/es/chunks/layout.CYgILBXq.js +592 -0
  16. package/es/chunks/layout.DTDMwNO7.js +231 -0
  17. package/es/chunks/layout.D_fCzVf0.js +39 -0
  18. package/es/chunks/layout.DdM4MaRr.js +149 -0
  19. package/es/index.mjs +93 -80
  20. package/lib/AppIntro.js +1 -0
  21. package/lib/BuildComponents.js +1 -1
  22. package/lib/IconRenderer.js +1 -1
  23. package/lib/PageNotFound.js +1 -1
  24. package/lib/PaginationTable.js +1 -1
  25. package/lib/assets/AppIntro.css +1 -0
  26. package/lib/assets/BuildComponents.css +1 -1
  27. package/lib/assets/PageNotFound.css +0 -0
  28. package/lib/assets/PaginationTable.css +1 -1
  29. package/lib/chunks/global.3UE6pLnj.js +1 -0
  30. package/lib/chunks/global.BNjIXg3D.js +1 -0
  31. package/lib/chunks/global.Cmc2k3td.js +1 -0
  32. package/lib/chunks/layout.BCsKDB9S.js +1 -0
  33. package/lib/chunks/layout.BbWwZ-k5.js +1 -0
  34. package/lib/chunks/layout.BlY_nSey.js +1 -0
  35. package/lib/chunks/layout.CsWdFS5P.js +1 -0
  36. package/lib/chunks/layout.DE2mqrz_.js +1 -0
  37. package/lib/chunks/layout.YVnsUDl7.js +1 -0
  38. package/lib/index.js +1 -1
  39. package/package.json +6 -4
@@ -0,0 +1,66 @@
1
+ import { computed as n, createElementBlock as i, openBlock as o, createVNode as r, createElementVNode as l, unref as a, withCtx as m, createBlock as s, resolveDynamicComponent as p, normalizeStyle as y, toDisplayString as f } from "vue";
2
+ import { IconEmpty as u } from "color-message-lingyun-vue";
3
+ import { ElIcon as d } from "element-plus";
4
+ import { _ as x } from "./_plugin-vue_export-helper.CHgC5LLL.js";
5
+ import '../assets/PageNotFound.css';const S = { class: "icon-empty flex flex-col items-center justify-center" }, z = /* @__PURE__ */ Object.assign({
6
+ name: "IconEmpty"
7
+ }, {
8
+ __name: "layout",
9
+ props: {
10
+ // 图标组件
11
+ icon: {
12
+ type: Object,
13
+ default: u
14
+ },
15
+ // 图标大小
16
+ iconSize: {
17
+ type: Number,
18
+ default: 64
19
+ },
20
+ // 图标颜色
21
+ iconColor: {
22
+ type: String,
23
+ default: "#c0c4cc"
24
+ },
25
+ // 显示文字
26
+ text: {
27
+ type: String,
28
+ default: "暂无数据"
29
+ },
30
+ // 文字颜色
31
+ textColor: {
32
+ type: String,
33
+ default: "#909399"
34
+ },
35
+ // 文字字号
36
+ textSize: {
37
+ type: Number,
38
+ default: 14
39
+ }
40
+ },
41
+ setup(t) {
42
+ const e = t, c = n(() => ({
43
+ color: e.textColor,
44
+ fontSize: `${e.textSize}px`
45
+ }));
46
+ return (E, I) => (o(), i("div", S, [
47
+ r(a(d), {
48
+ size: t.iconSize,
49
+ color: t.iconColor,
50
+ class: "icon-empty-icon"
51
+ }, {
52
+ default: m(() => [
53
+ (o(), s(p(t.icon)))
54
+ ]),
55
+ _: 1
56
+ }, 8, ["size", "color"]),
57
+ l("div", {
58
+ class: "icon-empty-text",
59
+ style: y(c.value)
60
+ }, f(t.text), 5)
61
+ ]));
62
+ }
63
+ }), b = /* @__PURE__ */ x(z, [["__scopeId", "data-v-c69a2cce"]]);
64
+ export {
65
+ b as I
66
+ };
@@ -0,0 +1,230 @@
1
+ import { ref as z, computed as p, watch as M, createElementBlock as f, openBlock as m, createVNode as R, createBlock as k, createCommentVNode as U, unref as h, mergeProps as B, withCtx as D, renderSlot as O, Fragment as E, createElementVNode as c, toDisplayString as x } from "vue";
2
+ import { ElUpload as N, ElImage as Y } from "element-plus";
3
+ import { emitsMap as i, uploadFileTypeMap as L, messageError as Q, messageWarning as F } from "ling-yun-methods";
4
+ import { _ as J, u as v } from "./layout.DdM4MaRr.js";
5
+ import { _ as K } from "./_plugin-vue_export-helper.CHgC5LLL.js";
6
+ import '../assets/layout4.css';const u = [];
7
+ for (let A = 0; A < 256; ++A)
8
+ u.push((A + 256).toString(16).slice(1));
9
+ function G(A, a = 0) {
10
+ return (u[A[a + 0]] + u[A[a + 1]] + u[A[a + 2]] + u[A[a + 3]] + "-" + u[A[a + 4]] + u[A[a + 5]] + "-" + u[A[a + 6]] + u[A[a + 7]] + "-" + u[A[a + 8]] + u[A[a + 9]] + "-" + u[A[a + 10]] + u[A[a + 11]] + u[A[a + 12]] + u[A[a + 13]] + u[A[a + 14]] + u[A[a + 15]]).toLowerCase();
11
+ }
12
+ let W;
13
+ const $ = new Uint8Array(16);
14
+ function _() {
15
+ if (!W) {
16
+ if (typeof crypto > "u" || !crypto.getRandomValues)
17
+ throw new Error("crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported");
18
+ W = crypto.getRandomValues.bind(crypto);
19
+ }
20
+ return W($);
21
+ }
22
+ const AA = typeof crypto < "u" && crypto.randomUUID && crypto.randomUUID.bind(crypto), T = { randomUUID: AA };
23
+ function eA(A, a, y) {
24
+ A = A || {};
25
+ const t = A.random ?? A.rng?.() ?? _();
26
+ if (t.length < 16)
27
+ throw new Error("Random bytes length must be >= 16");
28
+ return t[6] = t[6] & 15 | 64, t[8] = t[8] & 63 | 128, G(t);
29
+ }
30
+ function tA(A, a, y) {
31
+ return T.randomUUID && !A ? T.randomUUID() : eA(A);
32
+ }
33
+ const aA = "", lA = { class: "w-full" }, uA = { class: "flex items-center justify-center" }, nA = { class: "upload-webp overflow-hidden flex items-center justify-center relative" }, oA = { class: "text-74798c fz-12 pd-t-6" }, rA = { key: 0 }, dA = { key: 1 }, iA = /* @__PURE__ */ Object.assign({
34
+ name: "UploadFile"
35
+ }, {
36
+ __name: "layout",
37
+ props: {
38
+ // 已上传的文件列表
39
+ modelValue: {
40
+ type: Array,
41
+ default: () => []
42
+ },
43
+ // 是否禁用
44
+ disabled: {
45
+ type: Boolean,
46
+ default: !1
47
+ },
48
+ // 是否支持多选
49
+ multiple: {
50
+ type: Boolean,
51
+ default: !1
52
+ },
53
+ // 文件类型
54
+ uploadFileType: {
55
+ type: Array,
56
+ default: () => []
57
+ },
58
+ // 单个文件最大大小 (MB)
59
+ maxSize: {
60
+ type: Number,
61
+ default: 10
62
+ },
63
+ // 最多上传的文件个数
64
+ maxCount: {
65
+ type: Number,
66
+ default: 10
67
+ },
68
+ // 上传接口配置
69
+ apiConfig: {
70
+ type: Function,
71
+ default: null
72
+ },
73
+ // 自定义参数
74
+ params: {
75
+ type: Object,
76
+ default: () => ({})
77
+ },
78
+ // 是否自动上传
79
+ autoUpload: {
80
+ type: Boolean,
81
+ default: !0
82
+ },
83
+ // 字段映射
84
+ fieldMapping: {
85
+ type: Object,
86
+ default: () => ({
87
+ // fileName: 'fileName',
88
+ // fileUrl: 'fileUrl',
89
+ })
90
+ },
91
+ // 是否显示文件列表
92
+ showFileList: {
93
+ type: Boolean,
94
+ default: !0
95
+ },
96
+ // 是否自定义请求
97
+ isCustomRequest: {
98
+ type: Boolean,
99
+ default: !1
100
+ },
101
+ // 上传文件时的字段名
102
+ fileField: {
103
+ type: String,
104
+ default: "file"
105
+ },
106
+ // 是否拖拽
107
+ drag: {
108
+ type: Boolean,
109
+ default: !0
110
+ },
111
+ uploadTipObj: {
112
+ type: Object,
113
+ default: null
114
+ }
115
+ },
116
+ emits: [i.updateModelValue, i.change, i.delete],
117
+ setup(A, { expose: a, emit: y }) {
118
+ const t = A, s = y, j = z(null), n = z([]), w = p(() => typeof t.apiConfig == "function"), S = p(() => t.uploadFileType?.join("、")), C = p(() => t.uploadFileType?.map((e) => `.${e}`)?.join(",")), P = p(() => t.maxSize ? `${t.maxSize}MB` : ""), o = p(() => t.uploadTipObj ? t.uploadTipObj : {
119
+ formatAcceptText: `支持 ${S.value} 格式文件`,
120
+ formatMaxSize: `单个文件不超过 ${P.value}`,
121
+ maxCount: `最多上传 ${t.maxCount} 个文件`
122
+ }), X = (e) => {
123
+ if (!t.maxSize) return !0;
124
+ const l = t.maxSize * 1024 * 1024;
125
+ return e.size <= l;
126
+ }, Z = (e) => b(e, !0), b = (e, l) => {
127
+ const r = t.uploadFileType.map((g) => L?.[g]), d = [...new Set(r)];
128
+ if (t.maxCount && n.value?.length >= t.maxCount)
129
+ if (t.maxCount === 1)
130
+ n.value = [];
131
+ else
132
+ return l && Q(o.value.maxCount), !1;
133
+ return d?.includes(e.type) ? X(e) ? !0 : (l && F(o.value.formatMaxSize), !1) : (l && F(o.value.formatAcceptText), !1);
134
+ }, q = ({ file: e }) => {
135
+ if (!b(e, !1))
136
+ return;
137
+ const l = {
138
+ uuid: tA(),
139
+ raw: e,
140
+ type: e.type,
141
+ size: e.size,
142
+ fileStatus: v.uploading,
143
+ [t.fieldMapping.fileName]: e.name
144
+ };
145
+ if (I(l), !w.value || t.isCustomRequest) {
146
+ setTimeout(() => {
147
+ V(l, v.success);
148
+ }, 100);
149
+ return;
150
+ }
151
+ t.apiConfig?.({
152
+ [t.fileField]: e,
153
+ ...t.params
154
+ }).then(({ data: r }) => {
155
+ const d = r?.[0] || r?.files?.[0] || r;
156
+ V(l, v.success, d);
157
+ }).catch(() => {
158
+ V(l, v.error);
159
+ });
160
+ }, I = (e) => {
161
+ n.value.push(e), s(i.updateModelValue, n.value), s(i.change, e);
162
+ }, V = (e, l, r = {}) => {
163
+ const d = n.value.findIndex((g) => g.uuid === e.uuid);
164
+ d !== -1 && (n.value[d] = {
165
+ ...n.value[d],
166
+ fileStatus: l,
167
+ ...r
168
+ }, s(i.updateModelValue, n.value), s(i.change, n.value[d]));
169
+ }, H = (e) => {
170
+ s(i.delete, e);
171
+ };
172
+ return M(
173
+ () => t.modelValue,
174
+ (e) => {
175
+ Array.isArray(e) && (n.value = e);
176
+ },
177
+ { immediate: !0 }
178
+ ), a({
179
+ handleBeforeUpload: b,
180
+ httpRequest: q
181
+ }), (e, l) => (m(), f("div", lA, [
182
+ R(h(N), B({
183
+ ref_key: "uploadRef",
184
+ ref: j,
185
+ action: "#",
186
+ accept: C.value,
187
+ multiple: A.multiple,
188
+ disabled: A.disabled,
189
+ "before-upload": Z,
190
+ "http-request": q,
191
+ "show-file-list": !1,
192
+ "auto-upload": A.autoUpload,
193
+ drag: A.drag
194
+ }, e.$attrs, { class: "upload-wrapper" }), {
195
+ default: D(() => [
196
+ e.$slots.tip ? O(e.$slots, "tip", {
197
+ key: 0,
198
+ uploadTip: o.value
199
+ }, void 0, !0) : (m(), f(E, { key: 1 }, [
200
+ c("div", uA, [
201
+ c("div", nA, [
202
+ R(h(Y), {
203
+ src: h(aA),
204
+ class: "absolute image"
205
+ }, null, 8, ["src"])
206
+ ])
207
+ ]),
208
+ l[1] || (l[1] = c("div", { class: "text-262626 fz-14 weight-500" }, "点击或拖拽文件上传", -1)),
209
+ c("div", oA, [
210
+ c("span", null, x(o.value.formatAcceptText), 1),
211
+ o.value.formatMaxSize ? (m(), f("span", rA, "," + x(o.value.formatMaxSize), 1)) : U("", !0),
212
+ o.value.maxCount ? (m(), f("span", dA, "," + x(o.value.maxCount), 1)) : U("", !0)
213
+ ])
214
+ ], 64))
215
+ ]),
216
+ _: 3
217
+ }, 16, ["accept", "multiple", "disabled", "auto-upload", "drag"]),
218
+ n.value?.length && A.showFileList ? (m(), k(J, B({
219
+ key: 0,
220
+ modelValue: n.value,
221
+ "onUpdate:modelValue": l[0] || (l[0] = (r) => n.value = r),
222
+ "field-mapping": A.fieldMapping,
223
+ "show-delete": !A.disabled
224
+ }, e.$attrs, { onDelete: H }), null, 16, ["modelValue", "field-mapping", "show-delete"])) : U("", !0)
225
+ ]));
226
+ }
227
+ }), vA = /* @__PURE__ */ K(iA, [["__scopeId", "data-v-c9d51ce3"]]);
228
+ export {
229
+ vA as default
230
+ };