@lingshugroup/web-plus 1.0.2 → 1.0.4

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 (57) hide show
  1. package/README.md +3 -11
  2. package/lib/index.css +1 -1
  3. package/lib/index.css.br +0 -0
  4. package/lib/index.css.gz +0 -0
  5. package/lib/packages/ls-components/components/confirm/Index.vue/index.cjs +1 -1
  6. package/lib/packages/ls-components/components/confirm/Index.vue/index.js +1 -1
  7. package/lib/packages/ls-components/components/confirm/Index.vue/index2.cjs +1 -1
  8. package/lib/packages/ls-components/components/confirm/Index.vue/index2.js +10 -10
  9. package/lib/packages/ls-components/components/confirm/Index.vue/index2.js.br +0 -0
  10. package/lib/packages/ls-components/components/confirm/Index.vue/index2.js.gz +0 -0
  11. package/lib/packages/ls-components/components/confirm/types/index.cjs +1 -1
  12. package/lib/packages/ls-components/components/confirm/types/index.js +11 -5
  13. package/lib/packages/ls-components/components/confirm/types/index.js.br +0 -0
  14. package/lib/packages/ls-components/components/confirm/types/index.js.gz +0 -0
  15. package/lib/packages/ls-components/components/descriptions/Index.vue/index.cjs +1 -1
  16. package/lib/packages/ls-components/components/descriptions/Index.vue/index.js +1 -1
  17. package/lib/packages/ls-components/components/dialog/Index.vue/index.cjs +1 -1
  18. package/lib/packages/ls-components/components/dialog/Index.vue/index.js +1 -1
  19. package/lib/packages/ls-components/components/dialog/Index.vue/index2.cjs +1 -1
  20. package/lib/packages/ls-components/components/dialog/Index.vue/index2.js +46 -42
  21. package/lib/packages/ls-components/components/dialog/Index.vue/index2.js.br +0 -0
  22. package/lib/packages/ls-components/components/dialog/Index.vue/index2.js.gz +0 -0
  23. package/lib/packages/ls-components/components/form/Form.vue/index.cjs +1 -1
  24. package/lib/packages/ls-components/components/form/Form.vue/index.js +2 -2
  25. package/lib/packages/ls-components/components/form/Form.vue/index2.cjs +1 -1
  26. package/lib/packages/ls-components/components/form/Form.vue/index2.js +176 -145
  27. package/lib/packages/ls-components/components/form/Form.vue/index2.js.br +0 -0
  28. package/lib/packages/ls-components/components/form/Form.vue/index2.js.gz +0 -0
  29. package/lib/packages/ls-components/components/form/FormItem.vue/index.cjs +1 -1
  30. package/lib/packages/ls-components/components/form/FormItem.vue/index.js +1 -1
  31. package/lib/packages/ls-components/components/form/FormItem.vue/index2.cjs +1 -1
  32. package/lib/packages/ls-components/components/form/FormItem.vue/index2.js +165 -161
  33. package/lib/packages/ls-components/components/form/FormItem.vue/index2.js.br +0 -0
  34. package/lib/packages/ls-components/components/form/FormItem.vue/index2.js.gz +0 -0
  35. package/lib/packages/ls-components/components/form/types/index.cjs +1 -1
  36. package/lib/packages/ls-components/components/form/types/index.js +6 -5
  37. package/lib/packages/ls-components/components/form/types/index.js.br +0 -0
  38. package/lib/packages/ls-components/components/form/types/index.js.gz +0 -0
  39. package/lib/packages/ls-components/components/table/Table.vue/index.cjs +1 -1
  40. package/lib/packages/ls-components/components/table/Table.vue/index.js +2 -2
  41. package/lib/packages/ls-components/components/table/Table.vue/index2.cjs +1 -1
  42. package/lib/packages/ls-components/components/table/Table.vue/index2.js +129 -118
  43. package/lib/packages/ls-components/components/table/Table.vue/index2.js.br +0 -0
  44. package/lib/packages/ls-components/components/table/Table.vue/index2.js.gz +0 -0
  45. package/lib/packages/ls-components/components/tree/Index.vue/index.cjs +1 -1
  46. package/lib/packages/ls-components/components/tree/Index.vue/index.js +2 -2
  47. package/lib/packages/ls-components/components/tree/Index.vue/index2.cjs +1 -1
  48. package/lib/packages/ls-components/components/tree/Index.vue/index2.js +112 -100
  49. package/lib/packages/ls-components/components/tree/Index.vue/index2.js.br +0 -0
  50. package/lib/packages/ls-components/components/tree/Index.vue/index2.js.gz +0 -0
  51. package/lib/packages/ls-components/components/upload/Index.vue/index.cjs +1 -1
  52. package/lib/packages/ls-components/components/upload/Index.vue/index.js +2 -2
  53. package/lib/packages/ls-components/components/upload/Index.vue/index2.cjs +1 -1
  54. package/lib/packages/ls-components/components/upload/Index.vue/index2.js +188 -183
  55. package/lib/packages/ls-components/components/upload/Index.vue/index2.js.br +0 -0
  56. package/lib/packages/ls-components/components/upload/Index.vue/index2.js.gz +0 -0
  57. package/package.json +1 -1
@@ -1,152 +1,164 @@
1
- var W = Object.defineProperty;
2
- var a = (h, p) => W(h, "name", { value: p, configurable: !0 });
1
+ var $ = Object.defineProperty;
2
+ var i = (p, h) => $(p, "name", { value: h, configurable: !0 });
3
3
  /* empty css */
4
+ /* empty css */
4
5
  /* empty css */
5
6
  /* empty css */
6
- import { defineComponent as A, ref as u, computed as $, watch as z, nextTick as k, openBlock as b, createElementBlock as L, normalizeClass as x, unref as d, createBlock as O, isRef as U, withCtx as S, createTextVNode as j, createCommentVNode as F, createVNode as G, mergeProps as J, createElementVNode as E, toDisplayString as M } from "vue";
7
+ import { defineComponent as A, ref as f, computed as L, watch as O, nextTick as x, openBlock as S, createBlock as _, unref as d, withCtx as C, createElementVNode as y, normalizeClass as E, isRef as U, createTextVNode as j, createCommentVNode as F, createVNode as G, mergeProps as J, toDisplayString as M } from "vue";
7
8
  import { useNamespace as Q } from "../../_hooks/useNamespace/index.js";
8
9
  import { lsTreeProps as X, emitNames as Y } from "../types/index.js";
9
10
  import { excutePowerTree as Z } from "../../_utils/power/index.js";
10
- import ee from "../../../../../node_modules/.pnpm/lodash-es@4.17.21/node_modules/lodash-es/merge/index.js";
11
- import { ElCheckbox as te } from "../../../../../node_modules/.pnpm/element-plus@2.8.1_vue@3.4.38_typescript@5.5.4_/node_modules/element-plus/es/components/checkbox/index/index.js";
12
- import { ElTree as le } from "../../../../../node_modules/.pnpm/element-plus@2.8.1_vue@3.4.38_typescript@5.5.4_/node_modules/element-plus/es/components/tree/index/index.js";
13
- const ne = A({
11
+ import ee from "../../../../../node_modules/.pnpm/element-plus@2.8.1_vue@3.4.38_typescript@5.5.4_/node_modules/element-plus/dist/locale/zh-cn/index.js";
12
+ import te from "../../../../../node_modules/.pnpm/lodash-es@4.17.21/node_modules/lodash-es/merge/index.js";
13
+ import { ElCheckbox as le } from "../../../../../node_modules/.pnpm/element-plus@2.8.1_vue@3.4.38_typescript@5.5.4_/node_modules/element-plus/es/components/checkbox/index/index.js";
14
+ import { ElTree as ne } from "../../../../../node_modules/.pnpm/element-plus@2.8.1_vue@3.4.38_typescript@5.5.4_/node_modules/element-plus/es/components/tree/index/index.js";
15
+ import { ElConfigProvider as oe } from "../../../../../node_modules/.pnpm/element-plus@2.8.1_vue@3.4.38_typescript@5.5.4_/node_modules/element-plus/es/components/config-provider/index/index.js";
16
+ const ie = A({
14
17
  name: "LSTree"
15
- }), me = /* @__PURE__ */ A({
16
- ...ne,
18
+ }), Ne = /* @__PURE__ */ A({
19
+ ...ie,
17
20
  props: X,
18
21
  emits: Y,
19
- setup(h, { expose: p, emit: _ }) {
20
- const C = _, i = h, y = Q("tree"), P = y.b(), T = y.b("box"), w = u({
22
+ setup(p, { expose: h, emit: P }) {
23
+ const v = P, r = p, g = Q("tree"), T = g.b(), w = g.b("box"), K = f({
21
24
  showCheckbox: !0,
22
25
  defaultExpandAll: !0,
23
26
  nodeKey: "id",
24
27
  checkStrictly: !1,
25
28
  defaultCheckedKeys: []
26
- }), r = u(), s = u(!1), c = u(!1), m = u([]), K = $(() => i.height ? {
27
- maxHeight: i.height
29
+ }), a = f(), s = f(!1), c = f(!1), m = f([]), V = L(() => r.height ? {
30
+ maxHeight: r.height
28
31
  } : {});
29
- z(
30
- () => i.data,
32
+ O(
33
+ () => r.data,
31
34
  async (e) => {
32
- e && e.length > 0 && (s.value = !1, c.value = !1, m.value = V(), B(), await k(), r.value.filter(), v(), I());
35
+ e && e.length > 0 && (s.value = !1, c.value = !1, m.value = B(), q(), await x(), a.value.filter(), k(), I());
33
36
  },
34
37
  {
35
38
  immediate: !0,
36
39
  deep: !0
37
40
  }
38
41
  );
39
- function V() {
40
- return i.data.reduce((e, t) => (e.push(t.id), t.children && e.push(...g(t.children)), e), []);
42
+ function B() {
43
+ return r.data.reduce((e, t) => (e.push(t.id), t.children && e.push(...N(t.children)), e), []);
41
44
  }
42
- a(V, "getAllNodeKeys");
43
- function g(e) {
44
- return e.reduce((t, n) => (t.push(n.id), n.children && t.push(...g(n.children)), t), []);
45
+ i(B, "getAllNodeKeys");
46
+ function N(e) {
47
+ return e.reduce((t, l) => (t.push(l.id), l.children && t.push(...N(l.children)), t), []);
45
48
  }
46
- a(g, "getAllChildKeys");
47
- async function B() {
48
- var t, n;
49
- await k();
49
+ i(N, "getAllChildKeys");
50
+ async function q() {
51
+ var t, l;
52
+ await x();
50
53
  const e = document.getElementsByClassName("hide-child-node");
51
54
  for (let o = 0; o < e.length; o++) {
52
- const l = e[o].parentNode;
53
- l.style.opacity = 0, l.style.width = 0, l.style.height = 0, (n = (t = l == null ? void 0 : l.parentNode) == null ? void 0 : t.parentNode) != null && n.previousElementSibling && (l.parentNode.parentNode.previousElementSibling.querySelector(".el-icon").style.opacity = 0, l.parentNode.parentNode.previousElementSibling.querySelector(".el-icon").style.visibility = "hidden");
55
+ const n = e[o].parentNode;
56
+ n.style.opacity = 0, n.style.width = 0, n.style.height = 0, (l = (t = n == null ? void 0 : n.parentNode) == null ? void 0 : t.parentNode) != null && l.previousElementSibling && (n.parentNode.parentNode.previousElementSibling.querySelector(".el-icon").style.opacity = 0, n.parentNode.parentNode.previousElementSibling.querySelector(".el-icon").style.visibility = "hidden");
54
57
  }
55
58
  }
56
- a(B, "updateHideStyle");
57
- function q() {
58
- c.value = !1, r.value && r.value.setCheckedKeys(s.value ? m.value : []);
59
+ i(q, "updateHideStyle");
60
+ function R() {
61
+ c.value = !1, a.value && a.value.setCheckedKeys(s.value ? m.value : []);
59
62
  }
60
- a(q, "handleCheckAllChange");
61
- function R(e, t) {
62
- const { permission: n } = t || {};
63
- if (n != null && n.startsWith(i.hideNodePrefix))
63
+ i(R, "handleCheckAllChange");
64
+ function z(e, t) {
65
+ const { permission: l } = t || {};
66
+ if (l != null && l.startsWith(r.hideNodePrefix))
64
67
  return !1;
65
68
  if (!e) return !0;
66
- const { label: o } = i.dataProps || {};
69
+ const { label: o } = r.dataProps || {};
67
70
  return o ? t[o].indexOf(e) !== -1 : !0;
68
71
  }
69
- a(R, "filterNode");
72
+ i(z, "filterNode");
70
73
  function D(e, t) {
71
- r.value.setCheckedNodes(Z(i.data, e, t)), C("handleCheck", e, t);
74
+ a.value.setCheckedNodes(Z(r.data, e, t)), v("handleCheck", e, t);
72
75
  }
73
- a(D, "handleCheck");
76
+ i(D, "handleCheck");
74
77
  function H(e, t) {
75
- v(), C("handleChekChange", e, t);
78
+ k(), v("handleChekChange", e, t);
76
79
  }
77
- a(H, "handleChekChange");
78
- function v() {
79
- const e = r.value.getCheckedNodes(!1, !0);
80
+ i(H, "handleChekChange");
81
+ function k() {
82
+ const e = a.value.getCheckedNodes(!1, !0);
80
83
  let t = [];
81
- e.forEach((n) => {
82
- const { id: o, parentId: l } = n;
83
- t.push(o || l);
84
+ e.forEach((l) => {
85
+ const { id: o, parentId: n } = l;
86
+ t.push(o || n);
84
87
  }), t.length > 0 ? t.length === m.value.length ? (s.value = !0, c.value = !1) : (s.value = !1, c.value = !0) : (s.value = !1, c.value = !1);
85
88
  }
86
- a(v, "updateAllCheckStatus");
89
+ i(k, "updateAllCheckStatus");
87
90
  function I() {
88
91
  var e, t;
89
- if (i.direction == "h") {
90
- const n = (t = (e = r.value) == null ? void 0 : e.el$) == null ? void 0 : t.getElementsByClassName("el-tree-node");
91
- for (let o = 0; o < n.length; o++) {
92
- const l = n[o];
93
- if (l) {
94
- const f = l.querySelector(".el-tree-node__content .el-icon");
95
- f && getComputedStyle(f).visibility === "hidden" && (l.style.display = "inline-block", l.style.verticalAlign = "middle");
92
+ if (r.direction == "h") {
93
+ const l = (t = (e = a.value) == null ? void 0 : e.el$) == null ? void 0 : t.getElementsByClassName("el-tree-node");
94
+ for (let o = 0; o < l.length; o++) {
95
+ const n = l[o];
96
+ if (n) {
97
+ const u = n.querySelector(".el-tree-node__content .el-icon");
98
+ u && getComputedStyle(u).visibility === "hidden" && (n.style.display = "inline-block", n.style.verticalAlign = "middle");
96
99
  }
97
100
  }
98
101
  }
99
102
  }
100
- return a(I, "updateStyle"), p({
101
- lsTreeRef: r
103
+ return i(I, "updateStyle"), h({
104
+ lsTreeRef: a
102
105
  }), (e, t) => {
103
- const n = te, o = le;
104
- return b(), L("div", {
105
- class: x(d(P))
106
- }, [
107
- e.isCheckAll ? (b(), O(n, {
108
- key: 0,
109
- modelValue: d(s),
110
- "onUpdate:modelValue": t[0] || (t[0] = (l) => U(s) ? s.value = l : null),
111
- indeterminate: d(c),
112
- onChange: q
113
- }, {
114
- default: S(() => [
115
- j(" 全选 ")
116
- ]),
117
- _: 1
118
- }, 8, ["modelValue", "indeterminate"])) : F("", !0),
119
- G(o, J({
120
- ref_key: "lsTreeRef",
121
- ref: r,
122
- class: [d(T), !e.isExpand && "expand-disabled"],
123
- style: d(K)
124
- }, d(ee)(d(w), e.$attrs), {
125
- data: e.data,
126
- props: e.dataProps,
127
- "expand-on-click-node": e.isExpand,
128
- "filter-node-method": R,
129
- onCheck: D,
130
- onCheckChange: H
131
- }), {
132
- default: S(({ node: l, data: f }) => {
133
- var N;
134
- return [
135
- E("span", {
136
- class: x(["custom-tree-node", {
137
- "hide-child-node": e.hideNodePrefix && ((N = f.permission) == null ? void 0 : N.startsWith(e.hideNodePrefix))
138
- }])
139
- }, [
140
- E("span", null, M(l.label), 1)
141
- ], 2)
142
- ];
143
- }),
144
- _: 1
145
- }, 16, ["class", "style", "data", "props", "expand-on-click-node"])
146
- ], 2);
106
+ const l = le, o = ne, n = oe;
107
+ return S(), _(n, {
108
+ locale: d(ee),
109
+ "value-on-clear": void 0,
110
+ "empty-values": [void 0, null]
111
+ }, {
112
+ default: C(() => [
113
+ y("div", {
114
+ class: E(d(T))
115
+ }, [
116
+ e.isCheckAll ? (S(), _(l, {
117
+ key: 0,
118
+ modelValue: d(s),
119
+ "onUpdate:modelValue": t[0] || (t[0] = (u) => U(s) ? s.value = u : null),
120
+ indeterminate: d(c),
121
+ onChange: R
122
+ }, {
123
+ default: C(() => [
124
+ j(" 全选 ")
125
+ ]),
126
+ _: 1
127
+ }, 8, ["modelValue", "indeterminate"])) : F("", !0),
128
+ G(o, J({
129
+ ref_key: "lsTreeRef",
130
+ ref: a,
131
+ class: [d(w), !e.isExpand && "expand-disabled"],
132
+ style: d(V)
133
+ }, d(te)(d(K), e.$attrs), {
134
+ data: e.data,
135
+ props: e.dataProps,
136
+ "expand-on-click-node": e.isExpand,
137
+ "filter-node-method": z,
138
+ onCheck: D,
139
+ onCheckChange: H
140
+ }), {
141
+ default: C(({ node: u, data: W }) => {
142
+ var b;
143
+ return [
144
+ y("span", {
145
+ class: E(["custom-tree-node", {
146
+ "hide-child-node": e.hideNodePrefix && ((b = W.permission) == null ? void 0 : b.startsWith(e.hideNodePrefix))
147
+ }])
148
+ }, [
149
+ y("span", null, M(u.label), 1)
150
+ ], 2)
151
+ ];
152
+ }),
153
+ _: 1
154
+ }, 16, ["class", "style", "data", "props", "expand-on-click-node"])
155
+ ], 2)
156
+ ]),
157
+ _: 1
158
+ }, 8, ["locale"]);
147
159
  };
148
160
  }
149
161
  });
150
162
  export {
151
- me as default
163
+ Ne as default
152
164
  };
@@ -1 +1 @@
1
- "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=;/* empty css */;/* empty css */const t=,/* empty css */u=t.default(e.default,[["__scopeId","data-v-5c57f45e"]]);exports.default=u;
1
+ "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=;/* empty css */;/* empty css */const t=,/* empty css */u=t.default(e.default,[["__scopeId","data-v-12b1af67"]]);exports.default=u;
@@ -1,7 +1,7 @@
1
1
  import o from "./index2.js";
2
2
  /* empty css */
3
3
  import t from "../../../../../_virtual/_plugin-vue_export-helper/index.js";
4
- const a = /* @__PURE__ */ t(o, [["__scopeId", "data-v-5c57f45e"]]);
4
+ const _ = /* @__PURE__ */ t(o, [["__scopeId", "data-v-12b1af67"]]);
5
5
  export {
6
- a as default
6
+ _ as default
7
7
  };
@@ -1 +1 @@
1
- "use strict";var se=Object.defineProperty;var a=(v,L)=>se(v,"name",{value:L,configurable:!0});Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});;/* empty css */;/* empty css */;/* empty css */const e=require("vue"),B=,/* empty css */ce=,/* empty css */de=,/* empty css */y=,/* empty css */D=;/* empty css */;/* empty css */;/* empty css */const fe=,/* empty css */E=,/* empty css */me=,/* empty css */ve=a(v=>(e.pushScopeId("data-v-5c57f45e"),v=v(),e.popScopeId(),v),"_withScopeId"),pe={class:"ls-drag"},ge={class:"drag-txt ls-color-brand6"},he=ve(()=>e.createElementVNode("div",{class:"drag-txt ls-color-text2"},"拖拽到此区域",-1)),we={key:0,class:"btn-picture-card"},ke={key:0,class:"ls-tip"},ye=e.defineComponent({name:"LSUpload",inheritAttrs:!1,__name:"Index",props:B.lsUploadProps,emits:["uploadErrorFunc","onChangeFunc","httpResponseFunc"],setup(v,{emit:L}){const b=e.useSlots(),F=e.useAttrs(),I=de.useNamespace("upload").b(),f=e.ref(),s=e.ref(!1),p=e.reactive({isCover:!0,accept:"",disabled:s}),r=e.reactive({uploadFileList:[],initUploadStatus:!0,showPreview:!1,typePreview:"",sourcePreview:"",iconColor:ce.getVariable("colorText1")}),n=v,_=L,P=e.computed(()=>{var t,o;return(((t=n==null?void 0:n.item)==null?void 0:t.isToast)||typeof((o=n==null?void 0:n.item)==null?void 0:o.isToast))==="undefined"}),g=e.computed(()=>{var o;const t=(o=n==null?void 0:n.item)==null?void 0:o.isCover;return typeof t>"u"?!0:t}),h=e.computed(()=>F.multiple),w=e.computed(()=>{const t=F["auto-upload"];return typeof t>"u"?!0:t}),O=e.computed(()=>{var t;return((t=n==null?void 0:n.item)==null?void 0:t.emptyFileMsg)||""}),j=e.computed(()=>F["list-type"]),k=e.computed(()=>j.value===B.UPLOAD_TYPE_MAP.picCard),C=e.computed(()=>{var t;return((t=n==null?void 0:n.item)==null?void 0:t.limitFile)||[]}),W=e.computed(()=>{var t;return((t=n==null?void 0:n.item)==null?void 0:t.limitFileMsg)||""}),M=e.computed(()=>{var t;return((t=n==null?void 0:n.item)==null?void 0:t.limitSize)||2}),G=e.computed(()=>{var t;return((t=n==null?void 0:n.item)==null?void 0:t.limitSizeMsg)||""}),X=e.computed(()=>{var t;return((t=n==null?void 0:n.item)==null?void 0:t.limitNumMsg)||""}),T=e.computed(()=>F.drag),q=e.computed(()=>{const t=k.value?"图片":"文件";let o=`选择${t}`;return s.value?o="正在上传...":g.value&&!h.value?w.value?r.initUploadStatus?o="点击上传":o="重新上传":r.initUploadStatus?o=`选择${t}`:o="重新上传":w.value&&(o="点击上传"),o}),Y=e.computed(()=>{let t="不限制上传格式,";return k.value&&(t="文件须为图片格式,"),`${t}文件大小不超过${M.value}M`}),V=e.computed(()=>{var t;return(t=n==null?void 0:n.item)==null?void 0:t.httpRequestFunc}),S=e.computed(()=>{var t;return(t=n==null?void 0:n.item)==null?void 0:t.textPreview});e.watch([g,V],([t,o])=>{p.isCover=t,o&&o instanceof Function&&(p["http-request"]=ne)},{immediate:!0,deep:!0}),e.watch(()=>C.value,t=>{t&&t.length>0&&H(t)},{immediate:!0,deep:!0});function H(t){p.accept="",t.forEach(o=>{const l=B.fileTypeMap[o]||"";l&&(p.accept&&(p.accept+=","),p.accept+=l)})}a(H,"updateFileAccept");function x(t){const{formRuleFunc:o,formValidateFunc:l}=e.toRefs(n==null?void 0:n.item);if(o&&o.value instanceof Function&&l&&l.value instanceof Function){const i=o.value(),{message:u}=i;i.message=t,l.value(),i.message=u}_("uploadErrorFunc",t)}a(x,"validateForm");function J(t,o){if(s.value=!1,n.onExceed)return n.onExceed(t,o);const l=`当前限制选择 ${F.limit} 个文件,本次选择了 ${t.length} 个文件,共选择了 ${t.length+o.length} 个文件`||X.value;P.value?setTimeout(()=>{E.ElMessage.warning(l)},200):x(l)}a(J,"onExceedAction");function K(t){if(n.beforeUpload){const l=n.beforeUpload(t);return l&&g.value&&!h.value&&U(),l}const o=N(t,!0);return o&&w.value&&g.value&&!h.value&&U(),o}a(K,"beforeUploadAction");function N(t,o){let l=!0;const{size:i,name:u}=t,c=C.value.length>0&&!A(u),d=i/1024/1024>M.value;if(c){const m=W.value||`上传文件 ${t.name} 只能是 ${C.value.filter(ue=>ue).join(",").toLocaleLowerCase()} 格式!`;P.value&&o?setTimeout(()=>{E.ElMessage.error(m)},200):x(m),l=!1}if(d){const m=G.value||`上传文件 ${t.name} 大小不能超过 ${M.value}MB!`;P.value&&o?setTimeout(()=>{E.ElMessage.error(m)},200):x(m),l=!1}if(k.value&&!A(u,B.IMG_SUFFIX_LIST)){const m=`上传文件 ${t.name} 不是图片格式的文件!`;P.value&&o?setTimeout(()=>{E.ElMessage.error(m)},200):x(m),l=!1}return l}a(N,"validateUploadFile");function A(t,o){let l=[];if(C.value.length>0?l=C.value:o&&(l=o),l.length<=0)return!0;for(let i=0;i<l.length;i++){const u=(l[i]||"").toLowerCase();if(t.toLowerCase().endsWith(u))return!0}return!1}a(A,"fileTypeMatch");function U(t,o){r.uploadFileList.splice(t||0,o||r.uploadFileList.length-1)}a(U,"updateCoverFileList");function Q(t,o){r.uploadFileList=o;const l=t.raw&&N(t.raw,!w.value);if(l&&g.value&&!h.value&&U(),n.onChange)return n.onChange(t,o);const{size:i}=t;if(i<=0){$();const u=O.value||"禁止上传空文件,请检查后重新上传!";P.value?E.ElMessage.error(u):x(u);return}t.raw&&(!w.value&&!l?$():(t.blob=URL.createObjectURL(t.raw)||"",_("onChangeFunc",t)))}a(Q,"onChangeAction");function $(){let t=0;r.uploadFileList.length>1&&(t=r.uploadFileList.length-1),U(t,1),_("onChangeFunc",{})}a($,"setChangeRes");function Z(t,o,l){s.value=!1,r.initUploadStatus=!1;const{formRuleFunc:i,formValidateFunc:u}=e.toRefs(n==null?void 0:n.item);if(i&&i.value instanceof Function&&u&&u.value instanceof Function&&u.value(),n.onSuccess)return n.onSuccess(t,o,l)}a(Z,"onSuccessAction");function ee(t,o,l){if(s.value=!1,n.onError)return n.onError(t,o,l)}a(ee,"onErrorAction");function te(t,o){if(r.initUploadStatus=!o.length,n.onRemove)return n.onRemove(t,o)}a(te,"onRemoveAction");function oe(t){if(n.onPreview)return n.onPreview(t);const{raw:o,url:l,blob:i,name:u}=t,{type:c}=o||{};o&&(S.value&&S.value.length>0?c!=null&&c.startsWith("image")?(r.typePreview="image",r.sourcePreview=k.value?[l]:[i],r.showPreview=!0):S.value.includes("pdf")&&c=="application/pdf"?(r.typePreview="pdf",r.sourcePreview=i,r.showPreview=!0):S.value.includes("xlsx")&&["application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"].includes(c)?(r.typePreview="xlsx",fetch(i).then(d=>d.blob()).then(d=>{r.sourcePreview=new File([d],u,{type:c}),r.showPreview=!0})):S.value.includes("docx")&&c=="application/vnd.openxmlformats-officedocument.wordprocessingml.document"&&(r.typePreview="docx",fetch(i).then(d=>d.blob()).then(d=>d.arrayBuffer()).then(d=>{r.sourcePreview=d,r.showPreview=!0})):k.value&&c!=null&&c.startsWith("image")&&(r.typePreview="image",r.sourcePreview=[l],r.showPreview=!0))}a(oe,"onPreviewAction");async function ne(t){const{file:o}=t;if(!o)return;const{size:l}=o;if(l<=0||!N(o,!1))return;if(n.httpRequest)return n.httpRequest(t);const i=new FormData;if(i.append("file",o),V.value instanceof Function){s.value=!0;let u={};try{u=await V.value(i)}catch(c){u=c}finally{s.value=!1,_("httpResponseFunc",u)}}}a(ne,"httpRequestAction");function R(){let t=!1;for(let o=0;o<r.uploadFileList.length;o++)if(r.uploadFileList[o].status===B.UPLOAD_STATUS_MAP.ready){t=!0;break}return t}a(R,"hasReadyFile");function z(){var t;(t=f==null?void 0:f.value)==null||t.submit()}a(z,"comfirmUpload");function le(t){f==null||f.value.handleRemove(t)}a(le,"removeFile");function re(){r.uploadFileList.forEach(t=>{var o;if(t)try{(o=f==null?void 0:f.value)==null||o.abort(t),le(t)}catch{}})}a(re,"cancelUpload");function ie(){s.value=!0}a(ie,"onProgressAction");function ae(){r.showPreview=!1,r.sourcePreview=""}return a(ae,"closePreview"),(t,o)=>{const l=me.ElUpload,i=e.resolveComponent("LSPreview");return e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass([e.unref(I),e.unref(T)?"ls-upload-drag":""])},[e.createVNode(l,e.mergeProps({ref_key:"uploadRef",ref:f},e.unref(fe.default)(e.unref(p),t.$attrs),{"on-exceed":J,"before-upload":K,"on-change":Q,"on-success":Z,"on-error":ee,"on-remove":te,"on-preview":oe,"on-progress":ie}),e.createSlots({trigger:e.withCtx(()=>[e.unref(b).trigger?e.renderSlot(t.$slots,"trigger",{key:1},void 0,!0):(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.unref(T)?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.unref(s)?(e.openBlock(),e.createBlock(y.default,{key:0,text:"",loading:e.unref(s)},null,8,["loading"])):(e.openBlock(),e.createBlock(D.default,{key:1,class:"upload-icon",name:"UploadFilled",size:"56",color:"#E7E7E7"})),e.createElementVNode("div",pe,[e.createElementVNode("div",ge,e.toDisplayString(e.unref(q)),1),e.unref(s)?e.createCommentVNode("",!0):(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.createTextVNode("   /   "),he],64))])],64)):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[e.unref(k)?(e.openBlock(),e.createElementBlock("div",we,[e.unref(s)?(e.openBlock(),e.createBlock(y.default,{key:0,text:"",loading:e.unref(s)},null,8,["loading"])):(e.openBlock(),e.createBlock(D.default,{key:1,class:"upload-btn-plus",name:"Plus",size:28,color:e.unref(r).iconColor},null,8,["color"])),e.createElementVNode("div",null,e.toDisplayString(e.unref(q)),1)])):(e.openBlock(),e.createBlock(y.default,{key:1,plain:"",icon:"upload",loading:e.unref(s)},{default:e.withCtx(()=>[e.createTextVNode(e.toDisplayString(e.unref(q)),1)]),_:1},8,["loading"]))],64))],64))]),default:e.withCtx(()=>[e.unref(b).default?e.renderSlot(t.$slots,"default",{key:1},void 0,!0):(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.unref(w)?e.createCommentVNode("",!0):(e.openBlock(),e.createElementBlock("div",{key:0,class:e.normalizeClass(["upload-btn-handle",[e.unref(T)?"drag-css":"nor-css",!e.unref(g)||e.unref(h)?"multi-css":""]])},[e.unref(T)?(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[!e.unref(g)||e.unref(h)?(e.openBlock(),e.createBlock(y.default,{key:0,type:"primary",onClick:re,class:"ls-upload-btn-com ls-upload-btn-cancel"},{default:e.withCtx(()=>[e.createTextVNode("取消上传")]),_:1})):e.createCommentVNode("",!0),e.createVNode(y.default,{class:e.normalizeClass(["start-upload ls-upload-btn-com ls-upload-btn-comfirm",{"is-ready":R()}]),type:"primary",loading:e.unref(s),onClick:z},{default:e.withCtx(()=>[e.createTextVNode("开始上传")]),_:1},8,["class","loading"])],64)):(e.openBlock(),e.createBlock(y.default,{key:0,type:"primary",class:e.normalizeClass(["ls-upload-btn-com ls-upload-btn-comfirm",{"is-ready":R()}]),loading:e.unref(s),onClick:z},{default:e.withCtx(()=>[e.createTextVNode("开始上传 ")]),_:1},8,["class","loading"]))],2))],64))]),tip:e.withCtx(()=>[e.unref(b).tip?e.renderSlot(t.$slots,"tip",{key:1},void 0,!0):(e.openBlock(),e.createElementBlock("div",ke,e.toDisplayString(e.unref(Y)),1))]),_:2},[e.unref(b).file?{name:"file",fn:e.withCtx(()=>[e.renderSlot(t.$slots,"file",{},void 0,!0)]),key:"0"}:void 0]),1040),e.createVNode(i,{modelValue:e.unref(r).showPreview,"onUpdate:modelValue":o[0]||(o[0]=u=>e.unref(r).showPreview=u),"on-close":ae,type:e.unref(r).typePreview,source:e.unref(r).sourcePreview},null,8,["modelValue","type","source"])],2)}}});exports.default=ye;
1
+ "use strict";var ce=Object.defineProperty;var a=(v,L)=>ce(v,"name",{value:L,configurable:!0});Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});;/* empty css */;/* empty css */;/* empty css */const e=require("vue"),x=,/* empty css */de=,/* empty css */fe=,/* empty css */y=,/* empty css */I=;/* empty css */;/* empty css */;/* empty css */const me=,/* empty css */E=,/* empty css */ve=,/* empty css */pe=a(v=>(e.pushScopeId("data-v-12b1af67"),v=v(),e.popScopeId(),v),"_withScopeId"),ge={class:"ls-drag"},he={class:"drag-txt ls-color-brand6"},we=pe(()=>e.createElementVNode("div",{class:"drag-txt ls-color-text2"},"拖拽到此区域",-1)),ke={key:0,class:"btn-picture-card"},ye={key:0,class:"ls-tip"},Fe=e.defineComponent({name:"LSUpload",inheritAttrs:!1,__name:"Index",props:x.lsUploadProps,emits:["uploadErrorFunc","onChangeFunc","httpResponseFunc"],setup(v,{emit:L}){const b=e.useSlots(),F=e.useAttrs(),O=fe.useNamespace("upload").b(),f=e.ref(),s=e.ref(!1),p=e.reactive({isCover:!0,accept:"",disabled:s}),l=e.reactive({uploadFileList:[],initUploadStatus:!0,showPreview:!1,typePreview:"",sourcePreview:"",iconColor:de.getVariable("colorText1")}),n=v,_=L,P=e.computed(()=>{var t,o;return(((t=n==null?void 0:n.item)==null?void 0:t.isToast)||typeof((o=n==null?void 0:n.item)==null?void 0:o.isToast))==="undefined"}),g=e.computed(()=>{var o;const t=(o=n==null?void 0:n.item)==null?void 0:o.isCover;return typeof t>"u"?!0:t}),w=e.computed(()=>F.multiple),k=e.computed(()=>{const t=F["auto-upload"];return typeof t>"u"?!0:t}),j=e.computed(()=>{var t;return((t=n==null?void 0:n.item)==null?void 0:t.emptyFileMsg)||""}),W=e.computed(()=>F["list-type"]),h=e.computed(()=>W.value===x.UPLOAD_TYPE_MAP.picCard),C=e.computed(()=>{var t;return((t=n==null?void 0:n.item)==null?void 0:t.limitFile)||[]}),G=e.computed(()=>{var t;return((t=n==null?void 0:n.item)==null?void 0:t.limitFileMsg)||""}),M=e.computed(()=>{var t;return((t=n==null?void 0:n.item)==null?void 0:t.limitSize)||2}),X=e.computed(()=>{var t;return((t=n==null?void 0:n.item)==null?void 0:t.limitSizeMsg)||""}),Y=e.computed(()=>{var t;return((t=n==null?void 0:n.item)==null?void 0:t.limitNumMsg)||""}),A=e.computed(()=>{var t;return((t=n==null?void 0:n.item)==null?void 0:t.profile)||!1}),T=e.computed(()=>F.drag),V=e.computed(()=>{const t=h.value?"图片":"文件";let o=`选择${t}`;return s.value?o="正在上传...":g.value&&!w.value?k.value?l.initUploadStatus?o="点击上传":o="重新上传":l.initUploadStatus?o=`选择${t}`:o="重新上传":k.value&&(o="点击上传"),o}),H=e.computed(()=>{let t="不限制上传格式,";return h.value&&(t="文件须为图片格式,"),`${t}文件大小不超过${M.value}M`}),q=e.computed(()=>{var t;return(t=n==null?void 0:n.item)==null?void 0:t.httpRequestFunc}),B=e.computed(()=>{var t;return(t=n==null?void 0:n.item)==null?void 0:t.textPreview});e.watch([g,q],([t,o])=>{p.isCover=t,o&&o instanceof Function&&(p["http-request"]=re)},{immediate:!0,deep:!0}),e.watch(()=>C.value,t=>{t&&t.length>0&&J(t)},{immediate:!0,deep:!0});function J(t){p.accept="",t.forEach(o=>{const r=x.fileTypeMap[o]||"";r&&(p.accept&&(p.accept+=","),p.accept+=r)})}a(J,"updateFileAccept");function S(t){const{formRuleFunc:o,formValidateFunc:r}=e.toRefs(n==null?void 0:n.item);if(o&&o.value instanceof Function&&r&&r.value instanceof Function){const i=o.value(),{message:u}=i;i.message=t,r.value(),i.message=u}_("uploadErrorFunc",t)}a(S,"validateForm");function K(t,o){if(s.value=!1,n.onExceed)return n.onExceed(t,o);const r=`当前限制选择 ${F.limit} 个文件,本次选择了 ${t.length} 个文件,共选择了 ${t.length+o.length} 个文件`||Y.value;P.value?setTimeout(()=>{E.ElMessage.warning(r)},200):S(r)}a(K,"onExceedAction");function Q(t){if(n.beforeUpload){const r=n.beforeUpload(t);return r&&g.value&&!w.value&&U(),r}const o=N(t,!0);return o&&k.value&&g.value&&!w.value&&U(),o}a(Q,"beforeUploadAction");function N(t,o){let r=!0;const{size:i,name:u}=t,c=C.value.length>0&&!$(u),d=i/1024/1024>M.value;if(c){const m=G.value||`上传文件 ${t.name} 只能是 ${C.value.filter(se=>se).join(",").toLocaleLowerCase()} 格式!`;P.value&&o?setTimeout(()=>{E.ElMessage.error(m)},200):S(m),r=!1}if(d){const m=X.value||`上传文件 ${t.name} 大小不能超过 ${M.value}MB!`;P.value&&o?setTimeout(()=>{E.ElMessage.error(m)},200):S(m),r=!1}if(h.value&&!$(u,x.IMG_SUFFIX_LIST)){const m=`上传文件 ${t.name} 不是图片格式的文件!`;P.value&&o?setTimeout(()=>{E.ElMessage.error(m)},200):S(m),r=!1}return r}a(N,"validateUploadFile");function $(t,o){let r=[];if(C.value.length>0?r=C.value:o&&(r=o),r.length<=0)return!0;for(let i=0;i<r.length;i++){const u=(r[i]||"").toLowerCase();if(t.toLowerCase().endsWith(u))return!0}return!1}a($,"fileTypeMatch");function U(t,o){l.uploadFileList.splice(t||0,o||l.uploadFileList.length-1)}a(U,"updateCoverFileList");function Z(t,o){l.uploadFileList=o;const r=t.raw&&N(t.raw,!k.value);if(r&&g.value&&!w.value&&U(),n.onChange)return n.onChange(t,o);const{size:i}=t;if(i<=0){R();const u=j.value||"禁止上传空文件,请检查后重新上传!";P.value?E.ElMessage.error(u):S(u);return}t.raw&&(!k.value&&!r?R():(t.blob=URL.createObjectURL(t.raw)||"",_("onChangeFunc",t)))}a(Z,"onChangeAction");function R(){let t=0;l.uploadFileList.length>1&&(t=l.uploadFileList.length-1),U(t,1),_("onChangeFunc",{})}a(R,"setChangeRes");function ee(t,o,r){s.value=!1,l.initUploadStatus=!1;const{formRuleFunc:i,formValidateFunc:u}=e.toRefs(n==null?void 0:n.item);if(i&&i.value instanceof Function&&u&&u.value instanceof Function&&u.value(),n.onSuccess)return n.onSuccess(t,o,r)}a(ee,"onSuccessAction");function te(t,o,r){if(s.value=!1,n.onError)return n.onError(t,o,r)}a(te,"onErrorAction");function oe(t,o){if(l.initUploadStatus=!o.length,n.onRemove)return n.onRemove(t,o)}a(oe,"onRemoveAction");function ne(t){if(n.onPreview)return n.onPreview(t);const{raw:o,url:r,blob:i,name:u}=t,{type:c}=o||{};o?B.value&&B.value.length>0?c!=null&&c.startsWith("image")?(l.typePreview="image",l.sourcePreview=h.value?[r]:[i],l.showPreview=!0):B.value.includes("pdf")&&c=="application/pdf"?(l.typePreview="pdf",l.sourcePreview=i,l.showPreview=!0):B.value.includes("xlsx")&&["application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"].includes(c)?(l.typePreview="xlsx",fetch(i).then(d=>d.blob()).then(d=>{l.sourcePreview=new File([d],u,{type:c}),l.showPreview=!0})):B.value.includes("docx")&&c=="application/vnd.openxmlformats-officedocument.wordprocessingml.document"&&(l.typePreview="docx",fetch(i).then(d=>d.blob()).then(d=>d.arrayBuffer()).then(d=>{l.sourcePreview=d,l.showPreview=!0})):h.value&&c!=null&&c.startsWith("image")&&(l.typePreview="image",l.sourcePreview=[r],l.showPreview=!0):h.value&&(l.typePreview="image",l.sourcePreview=[r],l.showPreview=!0)}a(ne,"onPreviewAction");async function re(t){const{file:o}=t;if(!o)return;const{size:r}=o;if(r<=0||!N(o,!1))return;if(n.httpRequest)return n.httpRequest(t);const i=new FormData;if(i.append("file",o),q.value instanceof Function){s.value=!0;let u={};try{u=await q.value(i)}catch(c){u=c}finally{s.value=!1,_("httpResponseFunc",u)}}}a(re,"httpRequestAction");function z(){let t=!1;for(let o=0;o<l.uploadFileList.length;o++)if(l.uploadFileList[o].status===x.UPLOAD_STATUS_MAP.ready){t=!0;break}return t}a(z,"hasReadyFile");function D(){var t;(t=f==null?void 0:f.value)==null||t.submit()}a(D,"comfirmUpload");function le(t){f==null||f.value.handleRemove(t)}a(le,"removeFile");function ie(){l.uploadFileList.forEach(t=>{var o;if(t)try{(o=f==null?void 0:f.value)==null||o.abort(t),le(t)}catch{}})}a(ie,"cancelUpload");function ae(){s.value=!0}a(ae,"onProgressAction");function ue(){l.showPreview=!1,l.sourcePreview=""}return a(ue,"closePreview"),(t,o)=>{const r=ve.ElUpload,i=e.resolveComponent("LSPreview");return e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass([e.unref(O),e.unref(T)?"ls-upload-drag":"",e.unref(A)?"ls-profile":""])},[e.createVNode(r,e.mergeProps({ref_key:"uploadRef",ref:f},e.unref(me.default)(e.unref(p),t.$attrs),{"on-exceed":K,"before-upload":Q,"on-change":Z,"on-success":ee,"on-error":te,"on-remove":oe,"on-preview":ne,"on-progress":ae}),e.createSlots({trigger:e.withCtx(()=>[e.unref(A)?e.createCommentVNode("",!0):(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.unref(b).trigger?e.renderSlot(t.$slots,"trigger",{key:1},void 0,!0):(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.unref(T)?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.unref(s)?(e.openBlock(),e.createBlock(y.default,{key:0,text:"",loading:e.unref(s)},null,8,["loading"])):(e.openBlock(),e.createBlock(I.default,{key:1,class:"upload-icon",name:"UploadFilled",size:"56",color:"#E7E7E7"})),e.createElementVNode("div",ge,[e.createElementVNode("div",he,e.toDisplayString(e.unref(V)),1),e.unref(s)?e.createCommentVNode("",!0):(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.createTextVNode("   /   "),we],64))])],64)):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[e.unref(h)?(e.openBlock(),e.createElementBlock("div",ke,[e.unref(s)?(e.openBlock(),e.createBlock(y.default,{key:0,text:"",loading:e.unref(s)},null,8,["loading"])):(e.openBlock(),e.createBlock(I.default,{key:1,class:"upload-btn-plus",name:"Plus",size:28,color:e.unref(l).iconColor},null,8,["color"])),e.createElementVNode("div",null,e.toDisplayString(e.unref(V)),1)])):(e.openBlock(),e.createBlock(y.default,{key:1,plain:"",icon:"upload",loading:e.unref(s)},{default:e.withCtx(()=>[e.createTextVNode(e.toDisplayString(e.unref(V)),1)]),_:1},8,["loading"]))],64))],64))],64))]),default:e.withCtx(()=>[e.unref(b).default?e.renderSlot(t.$slots,"default",{key:1},void 0,!0):(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.unref(k)?e.createCommentVNode("",!0):(e.openBlock(),e.createElementBlock("div",{key:0,class:e.normalizeClass(["upload-btn-handle",[e.unref(T)?"drag-css":"nor-css",!e.unref(g)||e.unref(w)?"multi-css":""]])},[e.unref(T)?(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[!e.unref(g)||e.unref(w)?(e.openBlock(),e.createBlock(y.default,{key:0,type:"primary",onClick:ie,class:"ls-upload-btn-com ls-upload-btn-cancel"},{default:e.withCtx(()=>[e.createTextVNode("取消上传")]),_:1})):e.createCommentVNode("",!0),e.createVNode(y.default,{class:e.normalizeClass(["start-upload ls-upload-btn-com ls-upload-btn-comfirm",{"is-ready":z()}]),type:"primary",loading:e.unref(s),onClick:D},{default:e.withCtx(()=>[e.createTextVNode("开始上传")]),_:1},8,["class","loading"])],64)):(e.openBlock(),e.createBlock(y.default,{key:0,type:"primary",class:e.normalizeClass(["ls-upload-btn-com ls-upload-btn-comfirm",{"is-ready":z()}]),loading:e.unref(s),onClick:D},{default:e.withCtx(()=>[e.createTextVNode("开始上传 ")]),_:1},8,["class","loading"]))],2))],64))]),tip:e.withCtx(()=>[e.unref(b).tip?e.renderSlot(t.$slots,"tip",{key:1},void 0,!0):(e.openBlock(),e.createElementBlock("div",ye,e.toDisplayString(e.unref(H)),1))]),_:2},[e.unref(b).file?{name:"file",fn:e.withCtx(()=>[e.renderSlot(t.$slots,"file",{},void 0,!0)]),key:"0"}:void 0]),1040),e.createVNode(i,{modelValue:e.unref(l).showPreview,"onUpdate:modelValue":o[0]||(o[0]=u=>e.unref(l).showPreview=u),"on-close":ue,type:e.unref(l).typePreview,source:e.unref(l).sourcePreview},null,8,["modelValue","type","source"])],2)}}});exports.default=Fe;