ling-yun-custom-components 0.0.10

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 (123) hide show
  1. package/es/BatchImport.mjs +208 -0
  2. package/es/BuildComponents.mjs +190 -0
  3. package/es/CustomDialog.mjs +7 -0
  4. package/es/CustomDropdown.mjs +145 -0
  5. package/es/CustomPagination.mjs +7 -0
  6. package/es/CustomSelect.mjs +7 -0
  7. package/es/CustomTab.mjs +33 -0
  8. package/es/CustomTitle.mjs +7 -0
  9. package/es/FileList.mjs +7 -0
  10. package/es/GradientButton.mjs +120 -0
  11. package/es/IconEmpty.mjs +7 -0
  12. package/es/IconRenderer.mjs +42 -0
  13. package/es/IconSelect.mjs +120 -0
  14. package/es/PaginationTable.mjs +407 -0
  15. package/es/SearchBar.mjs +7 -0
  16. package/es/TreeSelect.mjs +406 -0
  17. package/es/TreeShowSelect.mjs +82 -0
  18. package/es/UpdatePasswordDialog.mjs +119 -0
  19. package/es/UploadFile.mjs +7 -0
  20. package/es/assets/BuildComponents.css +1 -0
  21. package/es/assets/CustomDropdown.css +1 -0
  22. package/es/assets/CustomTab.css +1 -0
  23. package/es/assets/GradientButton.css +1 -0
  24. package/es/assets/IconSelect.css +1 -0
  25. package/es/assets/PaginationTable.css +1 -0
  26. package/es/assets/TreeSelect.css +1 -0
  27. package/es/assets/TreeShowSelect.css +1 -0
  28. package/es/assets/UpdatePasswordDialog.css +1 -0
  29. package/es/assets/layout.css +0 -0
  30. package/es/assets/layout2.css +1 -0
  31. package/es/assets/layout3.css +1 -0
  32. package/es/assets/layout4.css +1 -0
  33. package/es/assets/layout5.css +1 -0
  34. package/es/assets/layout6.css +1 -0
  35. package/es/chunks/_plugin-vue_export-helper.CHgC5LLL.js +9 -0
  36. package/es/chunks/global.DVwnOczb.js +7828 -0
  37. package/es/chunks/index.D4Kbv-m1.js +8991 -0
  38. package/es/chunks/index.DfOANPhX.js +1729 -0
  39. package/es/chunks/index.DlooXR0t.js +9576 -0
  40. package/es/chunks/index.bCzIhWFw.js +7 -0
  41. package/es/chunks/layout.1y3OJ-ea.js +230 -0
  42. package/es/chunks/layout.2Mabaug0.js +121 -0
  43. package/es/chunks/layout.6MxjcpGc.js +584 -0
  44. package/es/chunks/layout.BJE8rMzK.js +230 -0
  45. package/es/chunks/layout.BKJPyxR8.js +39 -0
  46. package/es/chunks/layout.C0UEMbnF.js +98 -0
  47. package/es/chunks/layout.CTQtuC78.js +584 -0
  48. package/es/chunks/layout.CUOtHOHG.js +66 -0
  49. package/es/chunks/layout.CiNI5oQK.js +149 -0
  50. package/es/chunks/layout.CnANFnM1.js +584 -0
  51. package/es/chunks/layout.CtWHo87D.js +121 -0
  52. package/es/chunks/layout.Day1LJyl.js +234 -0
  53. package/es/chunks/layout.DeAFov0o.js +234 -0
  54. package/es/chunks/layout.Dvw3u-s5.js +234 -0
  55. package/es/chunks/layout.LCKaV7EX.js +230 -0
  56. package/es/chunks/layout.ZxPdKhRp.js +149 -0
  57. package/es/chunks/layout._A_rHZM7.js +149 -0
  58. package/es/chunks/layout.f58eO4Hr.js +98 -0
  59. package/es/chunks/layout.t3qD0LTW.js +121 -0
  60. package/es/chunks/layout.ypvwQzq5.js +98 -0
  61. package/es/index.mjs +81 -0
  62. package/lib/BatchImport.js +1 -0
  63. package/lib/BuildComponents.js +1 -0
  64. package/lib/CustomDialog.js +1 -0
  65. package/lib/CustomDropdown.js +1 -0
  66. package/lib/CustomPagination.js +1 -0
  67. package/lib/CustomSelect.js +1 -0
  68. package/lib/CustomTab.js +1 -0
  69. package/lib/CustomTitle.js +1 -0
  70. package/lib/FileList.js +1 -0
  71. package/lib/GradientButton.js +1 -0
  72. package/lib/IconEmpty.js +1 -0
  73. package/lib/IconRenderer.js +1 -0
  74. package/lib/IconSelect.js +1 -0
  75. package/lib/PaginationTable.js +1 -0
  76. package/lib/SearchBar.js +1 -0
  77. package/lib/TreeSelect.js +1 -0
  78. package/lib/TreeShowSelect.js +1 -0
  79. package/lib/UpdatePasswordDialog.js +1 -0
  80. package/lib/UploadFile.js +1 -0
  81. package/lib/assets/BuildComponents.css +1 -0
  82. package/lib/assets/CustomDropdown.css +1 -0
  83. package/lib/assets/CustomTab.css +1 -0
  84. package/lib/assets/GradientButton.css +1 -0
  85. package/lib/assets/IconSelect.css +1 -0
  86. package/lib/assets/PaginationTable.css +1 -0
  87. package/lib/assets/TreeSelect.css +1 -0
  88. package/lib/assets/TreeShowSelect.css +1 -0
  89. package/lib/assets/UpdatePasswordDialog.css +1 -0
  90. package/lib/assets/layout.css +0 -0
  91. package/lib/assets/layout2.css +1 -0
  92. package/lib/assets/layout3.css +1 -0
  93. package/lib/assets/layout4.css +1 -0
  94. package/lib/assets/layout5.css +1 -0
  95. package/lib/assets/layout6.css +1 -0
  96. package/lib/chunks/_plugin-vue_export-helper.BHFhmbuH.js +1 -0
  97. package/lib/chunks/global.Cv8u--Cy.js +1 -0
  98. package/lib/chunks/index.Bixsw9fA.js +23 -0
  99. package/lib/chunks/index.CkihWzK6.js +1 -0
  100. package/lib/chunks/index.CrvqvcN9.js +23 -0
  101. package/lib/chunks/index.DJKAT9lI.js +1 -0
  102. package/lib/chunks/layout.-yZzrp74.js +1 -0
  103. package/lib/chunks/layout.2PAIPzYY.js +1 -0
  104. package/lib/chunks/layout.5iOiFlVu.js +1 -0
  105. package/lib/chunks/layout.B-T_NE6r.js +1 -0
  106. package/lib/chunks/layout.BBNd1hLQ.js +1 -0
  107. package/lib/chunks/layout.BNJsxQ2g.js +1 -0
  108. package/lib/chunks/layout.BSF3ruxz.js +1 -0
  109. package/lib/chunks/layout.BXdjRFbn.js +1 -0
  110. package/lib/chunks/layout.BhL14Rqh.js +1 -0
  111. package/lib/chunks/layout.BmQYiD_b.js +1 -0
  112. package/lib/chunks/layout.CDg3sCTi.js +1 -0
  113. package/lib/chunks/layout.CeVldGUL.js +1 -0
  114. package/lib/chunks/layout.CjJiAY0w.js +1 -0
  115. package/lib/chunks/layout.CoSBrO12.js +1 -0
  116. package/lib/chunks/layout.CwA4IJ1g.js +1 -0
  117. package/lib/chunks/layout.DDTIwGYp.js +1 -0
  118. package/lib/chunks/layout.DOS2ezSW.js +1 -0
  119. package/lib/chunks/layout.D_TxPvRy.js +1 -0
  120. package/lib/chunks/layout.DfiLurg1.js +1 -0
  121. package/lib/chunks/layout.gqpUcAHO.js +1 -0
  122. package/lib/index.js +1 -0
  123. package/package.json +205 -0
@@ -0,0 +1,7 @@
1
+ const e = (n) => (n.install = (t) => {
2
+ const a = n.name || n.__name;
3
+ t.component(a, n);
4
+ }, n);
5
+ export {
6
+ e as w
7
+ };
@@ -0,0 +1,230 @@
1
+ import { ref as z, computed as p, watch as k, createElementBlock as f, openBlock as m, createVNode as R, createBlock as D, createCommentVNode as U, unref as h, mergeProps as B, withCtx as M, 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 { b as i, i as L, N as Q, h as j } from "./index.D4Kbv-m1.js";
4
+ import { _ as J, u as v } from "./layout._A_rHZM7.js";
5
+ import { _ as K } from "./_plugin-vue_export-helper.CHgC5LLL.js";
6
+ import '../assets/layout5.css';const l = [];
7
+ for (let A = 0; A < 256; ++A)
8
+ l.push((A + 256).toString(16).slice(1));
9
+ function G(A, a = 0) {
10
+ return (l[A[a + 0]] + l[A[a + 1]] + l[A[a + 2]] + l[A[a + 3]] + "-" + l[A[a + 4]] + l[A[a + 5]] + "-" + l[A[a + 6]] + l[A[a + 7]] + "-" + l[A[a + 8]] + l[A[a + 9]] + "-" + l[A[a + 10]] + l[A[a + 11]] + l[A[a + 12]] + l[A[a + 13]] + l[A[a + 14]] + l[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), w = { randomUUID: AA };
23
+ function eA(A, a, b) {
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, b) {
31
+ return w.randomUUID && !A ? w.randomUUID() : eA(A);
32
+ }
33
+ const aA = "", uA = { class: "w-full" }, lA = { 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: b }) {
118
+ const t = A, s = b, F = z(null), n = z([]), T = 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 u = t.maxSize * 1024 * 1024;
125
+ return e.size <= u;
126
+ }, Z = (e) => y(e, !0), y = (e, u) => {
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 u && Q(o.value.maxCount), !1;
133
+ return d?.includes(e.type) ? X(e) ? !0 : (u && j(o.value.formatMaxSize), !1) : (u && j(o.value.formatAcceptText), !1);
134
+ }, q = ({ file: e }) => {
135
+ if (!y(e, !1))
136
+ return;
137
+ const u = {
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(u), !T.value || t.isCustomRequest) {
146
+ setTimeout(() => {
147
+ V(u, 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(u, v.success, d);
157
+ }).catch(() => {
158
+ V(u, v.error);
159
+ });
160
+ }, I = (e) => {
161
+ n.value.push(e), s(i.updateModelValue, n.value), s(i.change, e);
162
+ }, V = (e, u, r = {}) => {
163
+ const d = n.value.findIndex((g) => g.uuid === e.uuid);
164
+ d !== -1 && (n.value[d] = {
165
+ ...n.value[d],
166
+ fileStatus: u,
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 k(
173
+ () => t.modelValue,
174
+ (e) => {
175
+ Array.isArray(e) && (n.value = e);
176
+ },
177
+ { immediate: !0 }
178
+ ), a({
179
+ handleBeforeUpload: y,
180
+ httpRequest: q
181
+ }), (e, u) => (m(), f("div", uA, [
182
+ R(h(N), B({
183
+ ref_key: "uploadRef",
184
+ ref: F,
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: M(() => [
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", lA, [
201
+ c("div", nA, [
202
+ R(h(Y), {
203
+ src: h(aA),
204
+ class: "absolute image"
205
+ }, null, 8, ["src"])
206
+ ])
207
+ ]),
208
+ u[1] || (u[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(), D(J, B({
219
+ key: 0,
220
+ modelValue: n.value,
221
+ "onUpdate:modelValue": u[0] || (u[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
+ };
@@ -0,0 +1,121 @@
1
+ import { ref as g, computed as o, onMounted as S, nextTick as C, watch as k, createBlock as M, openBlock as j, resolveDynamicComponent as D, unref as b, mergeProps as F } from "vue";
2
+ import { ElTreeSelect as x, ElSelectV2 as E } from "element-plus";
3
+ import { emitsMap as r } from "ling-yun-methods";
4
+ const q = /* @__PURE__ */ Object.assign({
5
+ name: "CustomSelect"
6
+ }, {
7
+ __name: "layout",
8
+ props: {
9
+ // 绑定值
10
+ modelValue: {
11
+ type: [String, Number, Array, Object],
12
+ default: () => null
13
+ },
14
+ // 是否可清空
15
+ clearable: {
16
+ type: Boolean,
17
+ default: !0
18
+ },
19
+ // 是否可搜索
20
+ filterable: {
21
+ type: Boolean,
22
+ default: !0
23
+ },
24
+ // 多选时是否将选中值按文字的形式展示
25
+ collapseTags: {
26
+ type: Boolean,
27
+ default: !0
28
+ },
29
+ // 多选
30
+ multiple: {
31
+ type: Boolean,
32
+ default: !1
33
+ },
34
+ // 接口配置
35
+ apiConfig: {
36
+ type: Function
37
+ },
38
+ // 数据映射配置
39
+ mapping: {
40
+ type: Object,
41
+ default: () => ({
42
+ label: "label",
43
+ value: "value",
44
+ disabled: "disabled",
45
+ children: "children"
46
+ })
47
+ },
48
+ // 静态数据
49
+ staticOptions: {
50
+ type: Array,
51
+ default: () => []
52
+ },
53
+ // 是否在组件挂载时自动加载数据
54
+ autoLoad: {
55
+ type: Boolean,
56
+ default: !0
57
+ },
58
+ // 请求参数
59
+ params: {
60
+ type: Object,
61
+ default: () => ({})
62
+ },
63
+ // 是否为树形选择器
64
+ isTreeSelect: {
65
+ type: Boolean,
66
+ default: !1
67
+ }
68
+ },
69
+ emits: [r.updateModelValue, r.change],
70
+ setup(l, { expose: v, emit: y }) {
71
+ const e = l, s = y, n = g(e.modelValue), i = g([]), c = o(() => typeof e.apiConfig == "function"), h = o(() => e.staticOptions.length > 0 ? e.staticOptions : i.value), V = o(() => e.isTreeSelect ? "data" : "options"), T = o(() => e.isTreeSelect ? "children" : "options"), B = o(() => ({
72
+ ...e.mapping,
73
+ [T.value]: e.mapping.children
74
+ })), p = async () => {
75
+ c.value && e.apiConfig(e.params)?.then((a) => {
76
+ i.value = d(a?.data || []);
77
+ });
78
+ };
79
+ function d(a, u = !1) {
80
+ return a.map((t) => {
81
+ const m = u || t.isEnabled === 0, f = {
82
+ ...t,
83
+ disabled: m
84
+ };
85
+ return t.children && t.children.length > 0 && (f.children = d(t.children, m)), f;
86
+ });
87
+ }
88
+ const O = () => {
89
+ s(r.updateModelValue, n.value), s(r.change, n.value);
90
+ };
91
+ return v({
92
+ clear: () => {
93
+ i.value = [], n.value = e.multiple ? [] : null;
94
+ },
95
+ loadData: p
96
+ }), S(() => {
97
+ e.autoLoad && c.value && C(() => {
98
+ p();
99
+ });
100
+ }), k(
101
+ () => e.modelValue,
102
+ (a) => {
103
+ n.value = a;
104
+ },
105
+ { immediate: !0 }
106
+ ), (a, u) => (j(), M(D(l.isTreeSelect ? b(x) : b(E)), F({
107
+ modelValue: n.value,
108
+ "onUpdate:modelValue": u[0] || (u[0] = (t) => n.value = t),
109
+ props: B.value,
110
+ multiple: l.multiple,
111
+ "collapse-tags": l.collapseTags,
112
+ filterable: l.filterable,
113
+ clearable: l.clearable,
114
+ [V.value || ""]: h.value,
115
+ "node-key": l.mapping.value
116
+ }, a.$attrs, { onChange: O }), null, 16, ["modelValue", "props", "multiple", "collapse-tags", "filterable", "clearable", "node-key"]));
117
+ }
118
+ });
119
+ export {
120
+ q as default
121
+ };