@kyfe/fms-vue2-components 0.0.5 → 0.0.7
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/fms-ks-file-view/index.js +76 -76
- package/dist/fms-ks-file-view/style.css +1 -1
- package/dist/fms-ks-upload/index.js +143 -0
- package/dist/fms-ks-upload/style.css +1 -0
- package/dist/index.js +29 -26
- package/dist/oa-datetime-picker-new/style.css +1 -1
- package/package.json +1 -1
- package/src/components/fms-ks-file-view/components/attachment.vue +7 -7
- package/src/components/fms-ks-upload/camera.svg +1 -0
- package/src/components/fms-ks-upload/fms-ks-upload.vue +302 -0
- package/src/components/fms-ks-upload/index.js +7 -0
- package/src/components/fms-ks-upload//344/270/212/344/274/240/347/273/204/344/273/266.md +0 -0
- package/src/index.js +5 -2
|
@@ -1,30 +1,30 @@
|
|
|
1
1
|
import './../fms-copy-box/style.css';
|
|
2
|
-
import
|
|
2
|
+
import "vue";
|
|
3
3
|
import { n as c } from "../plugin-vue2_normalizer.ed7092a9.js";
|
|
4
|
-
import './style.css';const l = "", n = "", B = "", D = "", C = "", Q = "", h = "", d = "", u = "";
|
|
4
|
+
import './style.css';const o = "", g = "", l = "", w = "", D = "", C = "", Q = "", d = "", u = "";
|
|
5
5
|
function p(A) {
|
|
6
6
|
var e = "";
|
|
7
7
|
if (!A)
|
|
8
8
|
return e;
|
|
9
9
|
A < 0.1 * 1024 ? e = A.toFixed(2) + "B" : A < 0.1 * 1024 * 1024 ? e = (A / 1024).toFixed(2) + "KB" : A < 0.1 * 1024 * 1024 * 1024 ? e = (A / (1024 * 1024)).toFixed(2) + "MB" : e = (A / (1024 * 1024 * 1024)).toFixed(2) + "GB";
|
|
10
|
-
var t = e + "",
|
|
11
|
-
return
|
|
10
|
+
var t = e + "", s = t.indexOf("."), B = t.substr(s + 1, 2);
|
|
11
|
+
return B == "00" ? t.substring(0, s) + t.substr(s + 3, 2) : e;
|
|
12
12
|
}
|
|
13
13
|
const {
|
|
14
|
-
ImagePreview:
|
|
15
|
-
} = window.vant, m = window.ks,
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
const
|
|
14
|
+
ImagePreview: r
|
|
15
|
+
} = window.vant, m = window.ks, i = /* @__PURE__ */ new Map();
|
|
16
|
+
i.set("doc", o);
|
|
17
|
+
i.set("docx", o);
|
|
18
|
+
i.set("ppt", g);
|
|
19
|
+
i.set("pptx", g);
|
|
20
|
+
i.set("pps", g);
|
|
21
|
+
i.set("ppsx", g);
|
|
22
|
+
i.set("xls", l);
|
|
23
|
+
i.set("xlsx", l);
|
|
24
|
+
i.set("pdf", C);
|
|
25
|
+
i.set("xmind", Q);
|
|
26
|
+
i.set("txt", d);
|
|
27
|
+
const h = {
|
|
28
28
|
name: "attachment-view",
|
|
29
29
|
props: {
|
|
30
30
|
fileList: {
|
|
@@ -45,7 +45,7 @@ const E = {
|
|
|
45
45
|
const {
|
|
46
46
|
fileList: A
|
|
47
47
|
} = this;
|
|
48
|
-
let e = (A || []).filter((
|
|
48
|
+
let e = (A || []).filter((s) => this.isImageType(s.extendName));
|
|
49
49
|
if (!e || !e.length)
|
|
50
50
|
return [];
|
|
51
51
|
let t = 5 - e.length % 5;
|
|
@@ -80,76 +80,76 @@ const E = {
|
|
|
80
80
|
return A.substr(0, A.lastIndexOf("."));
|
|
81
81
|
},
|
|
82
82
|
getFileIcon(A) {
|
|
83
|
-
return
|
|
83
|
+
return i.get(A) || w;
|
|
84
84
|
},
|
|
85
|
-
renderHead() {
|
|
85
|
+
renderHead(A) {
|
|
86
86
|
const {
|
|
87
|
-
fileCount:
|
|
88
|
-
titleName:
|
|
87
|
+
fileCount: e,
|
|
88
|
+
titleName: t
|
|
89
89
|
} = this;
|
|
90
|
-
return
|
|
90
|
+
return A("div", {
|
|
91
91
|
class: "att-head"
|
|
92
|
-
}, [
|
|
92
|
+
}, [A("img", {
|
|
93
93
|
attrs: {
|
|
94
|
-
src:
|
|
94
|
+
src: D
|
|
95
95
|
},
|
|
96
96
|
class: "file-icon"
|
|
97
|
-
}),
|
|
97
|
+
}), A("div", {
|
|
98
98
|
class: "att-title"
|
|
99
|
-
}, [
|
|
99
|
+
}, [t, "(", e, ")"])]);
|
|
100
100
|
},
|
|
101
|
-
renderImages() {
|
|
101
|
+
renderImages(A) {
|
|
102
102
|
const {
|
|
103
|
-
imgList:
|
|
103
|
+
imgList: e
|
|
104
104
|
} = this;
|
|
105
|
-
return
|
|
105
|
+
return e && e.length ? A("div", {
|
|
106
106
|
class: "att-imgs"
|
|
107
|
-
}, [
|
|
107
|
+
}, [A("div", {
|
|
108
108
|
class: "att-img-content"
|
|
109
|
-
}, [
|
|
109
|
+
}, [e.map((t, s) => t ? A("div", {
|
|
110
110
|
class: "att-img",
|
|
111
111
|
on: {
|
|
112
|
-
click: () => this.previewAssets(
|
|
112
|
+
click: () => this.previewAssets(s, e)
|
|
113
113
|
},
|
|
114
114
|
style: {
|
|
115
|
-
backgroundImage: `url(${
|
|
115
|
+
backgroundImage: `url(${t.url})`
|
|
116
116
|
}
|
|
117
|
-
}) :
|
|
117
|
+
}) : A("div", {
|
|
118
118
|
class: "att-img-hidden"
|
|
119
119
|
}))])]) : null;
|
|
120
120
|
},
|
|
121
|
-
renderOtherFiles() {
|
|
121
|
+
renderOtherFiles(A) {
|
|
122
122
|
const {
|
|
123
|
-
otherFileList:
|
|
123
|
+
otherFileList: e
|
|
124
124
|
} = this;
|
|
125
|
-
return
|
|
125
|
+
return e && e.length ? A("div", {
|
|
126
126
|
class: "att-files"
|
|
127
|
-
}, [
|
|
127
|
+
}, [e.map((t) => A("div", {
|
|
128
128
|
class: "att-file",
|
|
129
129
|
on: {
|
|
130
|
-
click: () => this.previewFile(
|
|
130
|
+
click: () => this.previewFile(t)
|
|
131
131
|
}
|
|
132
|
-
}, [
|
|
132
|
+
}, [A("div", {
|
|
133
133
|
class: "att-file-icon"
|
|
134
|
-
}, [
|
|
134
|
+
}, [A("img", {
|
|
135
135
|
attrs: {
|
|
136
|
-
src: this.getFileIcon(
|
|
136
|
+
src: this.getFileIcon(t.extendName),
|
|
137
137
|
width: "32",
|
|
138
138
|
height: "32"
|
|
139
139
|
}
|
|
140
|
-
})]),
|
|
140
|
+
})]), A("div", {
|
|
141
141
|
class: "att-file-info-wrap"
|
|
142
|
-
}, [
|
|
142
|
+
}, [A("div", {
|
|
143
143
|
class: "att-file-fullname"
|
|
144
|
-
}, [
|
|
144
|
+
}, [A("div", {
|
|
145
145
|
class: "att-file-name"
|
|
146
|
-
}, [this.splitFileName(
|
|
146
|
+
}, [this.splitFileName(t.name)]), t.extendName ? A("div", {
|
|
147
147
|
class: "att-file-extend"
|
|
148
|
-
}, [".",
|
|
148
|
+
}, [".", t.extendName]) : null]), A("div", {
|
|
149
149
|
class: "att-file-size"
|
|
150
|
-
}, [p(
|
|
150
|
+
}, [p(t.size)])]), A("div", {
|
|
151
151
|
class: "preview-icon-wrap"
|
|
152
|
-
}, [
|
|
152
|
+
}, [A("img", {
|
|
153
153
|
attrs: {
|
|
154
154
|
width: "16",
|
|
155
155
|
height: "16",
|
|
@@ -158,13 +158,13 @@ const E = {
|
|
|
158
158
|
})])]))]) : null;
|
|
159
159
|
},
|
|
160
160
|
previewAssets(A, e) {
|
|
161
|
-
let t = e.map((
|
|
161
|
+
let t = e.map((s) => s && s.url && s.url).filter((s) => !!s);
|
|
162
162
|
window.isKsPcMiniProgram ? (this.$emit("preview", e[A]), window.ks.previewAssets({
|
|
163
163
|
index: A,
|
|
164
164
|
filePaths: t
|
|
165
|
-
})) :
|
|
165
|
+
})) : r ? (window.ks.setCloseButton({
|
|
166
166
|
isShow: !1
|
|
167
|
-
}),
|
|
167
|
+
}), r({
|
|
168
168
|
images: t,
|
|
169
169
|
startPosition: A,
|
|
170
170
|
loop: this.loop,
|
|
@@ -189,40 +189,40 @@ const E = {
|
|
|
189
189
|
});
|
|
190
190
|
}
|
|
191
191
|
},
|
|
192
|
-
render() {
|
|
193
|
-
return
|
|
192
|
+
render(A) {
|
|
193
|
+
return A("div", {
|
|
194
194
|
class: "att-view"
|
|
195
|
-
}, [this.$slots.header ? this.$slots.header : this.renderHead(), this.renderImages(), this.renderOtherFiles()]);
|
|
195
|
+
}, [this.$slots.header ? this.$slots.header : this.renderHead(A), this.renderImages(A), this.renderOtherFiles(A)]);
|
|
196
196
|
}
|
|
197
197
|
};
|
|
198
|
-
const
|
|
199
|
-
var
|
|
198
|
+
const E = null, I = null;
|
|
199
|
+
var F = /* @__PURE__ */ c(
|
|
200
|
+
h,
|
|
200
201
|
E,
|
|
201
202
|
I,
|
|
202
|
-
F,
|
|
203
203
|
!1,
|
|
204
204
|
null,
|
|
205
|
-
"
|
|
205
|
+
"cb8343c7",
|
|
206
206
|
null,
|
|
207
207
|
null
|
|
208
208
|
);
|
|
209
|
-
const
|
|
210
|
-
const
|
|
209
|
+
const n = F.exports;
|
|
210
|
+
const f = {
|
|
211
211
|
name: "FmsKsFileView",
|
|
212
212
|
components: {
|
|
213
213
|
AttachmentView: {
|
|
214
|
-
extends:
|
|
214
|
+
extends: n,
|
|
215
215
|
props: {
|
|
216
216
|
onPreview: Function
|
|
217
217
|
},
|
|
218
218
|
methods: {
|
|
219
219
|
previewAssets(A, e) {
|
|
220
|
-
var
|
|
221
|
-
(
|
|
220
|
+
var s;
|
|
221
|
+
(s = this.onPreview) != null && s.call(this, e[A]) || n.methods.previewAssets.call(this, A, e);
|
|
222
222
|
},
|
|
223
223
|
previewFile(A) {
|
|
224
224
|
var t;
|
|
225
|
-
(t = this.onPreview) != null && t.call(this, A) ||
|
|
225
|
+
(t = this.onPreview) != null && t.call(this, A) || n.methods.previewFile.call(this, A);
|
|
226
226
|
}
|
|
227
227
|
}
|
|
228
228
|
}
|
|
@@ -258,29 +258,29 @@ const v = {
|
|
|
258
258
|
}
|
|
259
259
|
}
|
|
260
260
|
};
|
|
261
|
-
var
|
|
261
|
+
var v = function() {
|
|
262
262
|
var e = this, t = e._self._c;
|
|
263
|
-
return t("div", { staticClass: "flow-fms-file-view", on: { preview: (
|
|
264
|
-
e.activeNames =
|
|
263
|
+
return t("div", { staticClass: "flow-fms-file-view", on: { preview: (s) => e.$emit("preview", s) } }, [t("van-collapse", { model: { value: e.activeNames, callback: function(s) {
|
|
264
|
+
e.activeNames = s;
|
|
265
265
|
}, expression: "activeNames" } }, [t("van-collapse-item", { staticClass: "collapse-title--expend_border-bottom-hidden", attrs: { name: "1" }, scopedSlots: e._u([e.$slots.title ? { key: "title", fn: function() {
|
|
266
266
|
return [e._t("title")];
|
|
267
267
|
}, proxy: !0 } : { key: "title", fn: function() {
|
|
268
268
|
return [t("div", [t("strong", [e._v("\u9644\u4EF6")])])];
|
|
269
269
|
}, proxy: !0 }], null, !0) }, [e.fileList.length > 0 ? t("div", { staticClass: "file-wrap" }, [t("attachment-view", { attrs: { fileList: e.fileList, onPreview: e.onPreview } })], 1) : t("div", { staticClass: "no-file" }, [e._v("\u6682\u65E0\u9644\u4EF6")])])], 1)], 1);
|
|
270
|
-
},
|
|
270
|
+
}, O = [], z = /* @__PURE__ */ c(
|
|
271
|
+
f,
|
|
271
272
|
v,
|
|
272
273
|
O,
|
|
273
|
-
z,
|
|
274
274
|
!1,
|
|
275
275
|
null,
|
|
276
276
|
"44a81d96",
|
|
277
277
|
null,
|
|
278
278
|
null
|
|
279
279
|
);
|
|
280
|
-
const
|
|
281
|
-
|
|
282
|
-
A.component(
|
|
280
|
+
const a = z.exports;
|
|
281
|
+
a.install = function(A) {
|
|
282
|
+
A.component(a.name, a);
|
|
283
283
|
};
|
|
284
284
|
export {
|
|
285
|
-
|
|
285
|
+
a as default
|
|
286
286
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
.att-view[data-v-
|
|
1
|
+
.att-view[data-v-cb8343c7]{position:relative;padding:12px 16px 0;font-size:14px;color:#333}.att-view[data-v-cb8343c7]:after{position:absolute;content:" ";pointer-events:none;right:0;top:0;left:16px;right:16px;border-bottom:1px solid #f2f2f2;-webkit-transform:scaleY(.5);transform:scaleY(.5)}.att-view .att-head[data-v-cb8343c7]{display:flex;align-items:center;margin-bottom:12px}.att-view .att-head .file-icon[data-v-cb8343c7]{width:14px;height:14px}.att-view .att-head .att-title[data-v-cb8343c7]{font-size:14px;text-align:left;color:#6e6d72;margin-left:4px}.att-view .att-head .att-head-tips[data-v-cb8343c7]{font-size:12px;color:#999}.att-view .att-imgs[data-v-cb8343c7]{margin-top:12px}.att-view .att-imgs .att-img-content[data-v-cb8343c7]{position:relative;display:flex;flex-wrap:wrap;flex-direction:row}.att-view .att-imgs .att-img-content .att-img[data-v-cb8343c7]{margin:0 12px 10px 0;width:52px;height:52px;border:.5px solid #cacaca;border-radius:4px;background-position:center;background-size:cover}.att-view .att-imgs .att-img-content .att-img-hidden[data-v-cb8343c7]{width:60px;height:0}.att-view .att-files .att-file[data-v-cb8343c7]{display:flex;width:100%;height:52px;background:#f7f8fa;border:.5px solid #ebedf5;border-radius:4px;margin-bottom:10px}.att-view .att-files .att-file:first-child .att-file-fullname[data-v-cb8343c7]:before{display:none}.att-view .att-files .att-file[data-v-cb8343c7]:last-child{margin-bottom:0}.att-view .att-files .att-file .att-file-icon[data-v-cb8343c7]{padding:10px 0 10px 10px;width:42px;height:100%;background-position:center;background-size:cover}.att-view .att-files .att-file .att-file-info-wrap[data-v-cb8343c7]{padding:6px 0 6px 10px;width:calc(100% - 90px)}.att-view .att-files .att-file .att-file-info-wrap .att-file-fullname[data-v-cb8343c7]{display:flex;position:relative;width:100%;font-size:14px;color:#03050d;line-height:20px}.att-view .att-files .att-file .att-file-info-wrap .att-file-fullname .att-file-name[data-v-cb8343c7]{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.att-view .att-files .att-file .att-file-info-wrap .att-file-size[data-v-cb8343c7]{font-size:12px;color:#858793;line-height:18px}.att-view .att-files .att-file .preview-icon-wrap[data-v-cb8343c7]{padding:18px 16px;width:48px;height:100%}.collapse-wrap[data-v-44a81d96]{border-radius:6px;overflow:hidden}.collapse-title--expend_border-bottom-hidden[data-v-44a81d96] .van-collapse-item__title--expanded:after{right:0!important;left:0}.field-reason[data-v-44a81d96]{display:block}.field-reason[data-v-44a81d96] .van-field__value{border-radius:4px;background-color:#f7f8fa;margin-top:8px}.field-reason[data-v-44a81d96] .van-field__value .van-field__body{padding:0;line-height:20px}.field-reason[data-v-44a81d96] .van-field__value .van-field__body input.van-field__control{height:40px;padding:0 12px}.field-reason[data-v-44a81d96] .van-field__value .van-field__body textarea.van-field__control{padding:12px}.field-reason[data-v-44a81d96] .van-field__value .van-field__body .van-field__right-icon{position:absolute;bottom:0;right:16px;height:32px;display:flex;align-items:center;padding:0}.field-reason[data-v-44a81d96] .van-field__value .van-field__word-limit{margin-right:16px;color:#858793;padding-bottom:8px}.flow-fms-file-view[data-v-44a81d96]{border-radius:6px;overflow:hidden}.flow-fms-file-view[data-v-44a81d96] .van-hairline--top-bottom:after{border:none}.flow-fms-file-view[data-v-44a81d96] .van-collapse-item__content{background-color:#fff}.flow-fms-file-view .file-wrap[data-v-44a81d96]{display:flex;flex-wrap:wrap;background:#fff}.flow-fms-file-view .file-wrap .att-view[data-v-44a81d96]{padding:0;width:100%}.flow-fms-file-view .file-wrap .att-view[data-v-44a81d96] .att-head{display:none}.flow-fms-file-view .file-wrap .att-view[data-v-44a81d96] .att-imgs{margin-top:0}.flow-fms-file-view .file-wrap .att-view[data-v-44a81d96]:after{border-bottom:none}.flow-fms-file-view .file-wrap .file-item[data-v-44a81d96]{height:40px;width:50vw;padding-left:12px;position:relative;display:flex;align-items:center}.flow-fms-file-view .file-wrap .file-item .file-icon[data-v-44a81d96]{width:21px;height:21px;margin-right:6px}.flow-fms-file-view .file-wrap .file-item .file-name[data-v-44a81d96]{width:0;flex:1;color:#03050d;font-size:14px;display:flex;align-items:center}.flow-fms-file-view .file-wrap .file-item .file-name .name[data-v-44a81d96]{max-width:calc(100% - 40px);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.flow-fms-file-view .no-file[data-v-44a81d96]{padding:0 16px;text-align:center}
|
|
@@ -0,0 +1,143 @@
|
|
|
1
|
+
import './../fms-copy-box/style.css';
|
|
2
|
+
import { n as l } from "../plugin-vue2_normalizer.ed7092a9.js";
|
|
3
|
+
import './style.css';const r = "";
|
|
4
|
+
const c = window.vant && window.vant.Toast, M = {
|
|
5
|
+
name: "FmsKsUpload",
|
|
6
|
+
props: {
|
|
7
|
+
value: {
|
|
8
|
+
type: Array,
|
|
9
|
+
default: () => []
|
|
10
|
+
},
|
|
11
|
+
bizId: String,
|
|
12
|
+
bizCode: String,
|
|
13
|
+
maxLength: Number,
|
|
14
|
+
type: {
|
|
15
|
+
type: String,
|
|
16
|
+
default: "edit"
|
|
17
|
+
},
|
|
18
|
+
process: {
|
|
19
|
+
type: Number,
|
|
20
|
+
default: 100
|
|
21
|
+
},
|
|
22
|
+
onPreviewBefore: Function
|
|
23
|
+
},
|
|
24
|
+
data() {
|
|
25
|
+
return {
|
|
26
|
+
show: !1,
|
|
27
|
+
actions: [{ name: "\u4ECE\u76F8\u518C\u9009\u62E9" }, { name: "\u62CD\u7167" }],
|
|
28
|
+
showPdf: !1,
|
|
29
|
+
pdfUrl: ""
|
|
30
|
+
};
|
|
31
|
+
},
|
|
32
|
+
methods: {
|
|
33
|
+
onPreview() {
|
|
34
|
+
this.onPreviewBefore && typeof this.onPreviewBefore == "function" && this.onPreviewBefore() || (this.show = !0);
|
|
35
|
+
},
|
|
36
|
+
onCancel() {
|
|
37
|
+
this.show = !1;
|
|
38
|
+
},
|
|
39
|
+
async onSelect(t) {
|
|
40
|
+
let e = null;
|
|
41
|
+
try {
|
|
42
|
+
if (this.$emit("beforeSelect", t), t.name === "\u4ECE\u76F8\u518C\u9009\u62E9") {
|
|
43
|
+
const s = Number(this.maxLength - this.value.length);
|
|
44
|
+
console.log("\u4ECE\u76F8\u518C\u9009\u62E9", t, s, this.maxLength, this.value.length), e = await window.ks.callFunc({
|
|
45
|
+
method: "pickAssets",
|
|
46
|
+
params: {
|
|
47
|
+
totalCount: s,
|
|
48
|
+
allowRecordVideo: !1,
|
|
49
|
+
selectType: 1,
|
|
50
|
+
quality: 80
|
|
51
|
+
}
|
|
52
|
+
});
|
|
53
|
+
} else
|
|
54
|
+
t.name === "\u62CD\u7167" && (e = await window.ks.takeByCamera());
|
|
55
|
+
this.onCancel(), this.maxLength && e.length > this.maxLength ? c("\u9009\u62E9\u6587\u4EF6\u592A\u591A") : this.upload(e);
|
|
56
|
+
} catch (s) {
|
|
57
|
+
console.info("onSelect--error", s), s && s.msg && c(s.msg), this.onCancel();
|
|
58
|
+
}
|
|
59
|
+
},
|
|
60
|
+
onDelete(t) {
|
|
61
|
+
let e = JSON.parse(JSON.stringify(this.value)), s = e[t];
|
|
62
|
+
e.splice(t, 1), this.$emit("input", e), this.$http("file.deleteByBizAndId", 10124, s).then((a) => {
|
|
63
|
+
this.$emit("deleteSuccess", a, s);
|
|
64
|
+
}).catch((a) => {
|
|
65
|
+
console.log(a);
|
|
66
|
+
});
|
|
67
|
+
},
|
|
68
|
+
async upload(t) {
|
|
69
|
+
try {
|
|
70
|
+
let e = await window.ks.uploadAssets({
|
|
71
|
+
filePaths: t.map((s) => s.filePath),
|
|
72
|
+
fileNames: t.map((s) => s.fileName),
|
|
73
|
+
bizCode: this.bizCode,
|
|
74
|
+
bizId: this.bizId
|
|
75
|
+
});
|
|
76
|
+
console.log("uploadRes---", e), this.$emit("input", e.reverse()), this.$emit("uploadsuccess", t, e), this.onCancel();
|
|
77
|
+
} catch (e) {
|
|
78
|
+
console.log("\u4E0A\u4F20\u5931\u8D25--", e);
|
|
79
|
+
}
|
|
80
|
+
},
|
|
81
|
+
previewAssets(t, e) {
|
|
82
|
+
let s = e.filter((i) => (i.contentType || "").toLowerCase().startsWith("image") || ["jpg", "jpeg", "png", "bmp", "HEIC", "webp", "tiff"].includes(
|
|
83
|
+
(i.extendName || "").toLowerCase()
|
|
84
|
+
)).map((i) => i.url);
|
|
85
|
+
const a = s.findIndex((i) => i === t);
|
|
86
|
+
this.$emit("beforePreviewAssets", {
|
|
87
|
+
index: a,
|
|
88
|
+
list: e
|
|
89
|
+
}), window.ks.previewAssets({
|
|
90
|
+
index: a,
|
|
91
|
+
filePaths: s
|
|
92
|
+
});
|
|
93
|
+
},
|
|
94
|
+
pdfPreview(t) {
|
|
95
|
+
this.$emit("beforePreviewAssets", {
|
|
96
|
+
index,
|
|
97
|
+
list
|
|
98
|
+
}), window.ks.callFunc({
|
|
99
|
+
method: "previewFile",
|
|
100
|
+
params: {
|
|
101
|
+
filePath: t.url,
|
|
102
|
+
fileName: t.name,
|
|
103
|
+
fileSize: String(t.size)
|
|
104
|
+
}
|
|
105
|
+
});
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
};
|
|
109
|
+
var w = function() {
|
|
110
|
+
var e = this, s = e._self._c;
|
|
111
|
+
return s("div", { staticClass: "van-uploader" }, [s("div", { staticClass: "van-uploader__wrapper" }, [e._l(e.value, function(a, i) {
|
|
112
|
+
return s("div", { key: i, staticClass: "van-uploader__preview" }, [s("div", { class: { "van-image": !0, "van-uploader__preview-image": !0 }, staticStyle: { overflow: "hidden", "border-radius": "4px", width: "52px", height: "52px" } }, [e.process !== 100 ? s("div", { staticClass: "mask-wrap" }, [s("div", { staticClass: "mask-content" }, [s("div", { staticClass: "mask-progress-bar" }, [s("div", { staticClass: "mask-progress-step", style: { width: `${e.process / 100 * 44}px` } })]), s("div", { staticClass: "mask-text" }, [e._v("\u8BC6\u522B\u4E2D")])])]) : e._e(), (a.contentType || "").toLowerCase().startsWith("image") || ["jpg", "jpeg", "png", "bmp", "HEIC", "webp", "tiff"].includes(
|
|
113
|
+
(a.extendName || "").toLowerCase()
|
|
114
|
+
) ? s("img", { staticClass: "van-image__img", staticStyle: { "object-fit": "cover" }, attrs: { src: a.url }, on: { click: function(o) {
|
|
115
|
+
return e.previewAssets(a.url, e.value);
|
|
116
|
+
} } }) : (a.contentType || "").toLowerCase().includes("pdf") || ["pdf"].includes((a.extendName || "").toLowerCase()) ? s("div", { on: { click: function(o) {
|
|
117
|
+
return e.pdfPreview(a);
|
|
118
|
+
} } }, [s("img", { staticClass: "van-image__img", attrs: { src: "https://erphostjs.kye-erp.com/hr-oa-kts/ks-app/kuasheng-oa/images/pdf.svg", alt: "" } })]) : s("div", { staticClass: "van-uploader__upload", staticStyle: { margin: "0" } }, [e._m(0, !0)])]), e.type === "edit" ? s("i", { staticClass: "van-icon van-icon-clear van-uploader__preview-delete", staticStyle: { color: "#a7aab7", border: "1px solid #fff", fontSize: "14px" }, on: { click: function(o) {
|
|
119
|
+
return e.onDelete(i);
|
|
120
|
+
} } }) : e._e()]);
|
|
121
|
+
}), (e.maxLength && e.value.length < e.maxLength || !e.maxLength) && e.type === "edit" ? s("div", { staticClass: "van-uploader__upload", staticStyle: { "font-size": "22px" }, on: { click: e.onPreview } }, [s("img", { staticClass: "upload-icon", attrs: { src: r } })]) : e._e()], 2), s("ks-action-sheet", { attrs: { actions: e.actions, "get-container": "body", "cancel-text": "\u53D6\u6D88" }, on: { select: e.onSelect, cancel: e.onCancel }, model: { value: e.show, callback: function(a) {
|
|
122
|
+
e.show = a;
|
|
123
|
+
}, expression: "show" } })], 1);
|
|
124
|
+
}, u = [function() {
|
|
125
|
+
var t = this, e = t._self._c;
|
|
126
|
+
return e("div", { staticClass: "van-uploader__preview-show" }, [t._v("\u6587\u4EF6\u8BF7\u5230"), e("br"), t._v("ERP\u67E5\u770B")]);
|
|
127
|
+
}], d = /* @__PURE__ */ l(
|
|
128
|
+
M,
|
|
129
|
+
w,
|
|
130
|
+
u,
|
|
131
|
+
!1,
|
|
132
|
+
null,
|
|
133
|
+
"d54b97c2",
|
|
134
|
+
null,
|
|
135
|
+
null
|
|
136
|
+
);
|
|
137
|
+
const n = d.exports;
|
|
138
|
+
n.install = function(t) {
|
|
139
|
+
t.component(n.name, n);
|
|
140
|
+
};
|
|
141
|
+
export {
|
|
142
|
+
n as default
|
|
143
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
.van-uploader[data-v-d54b97c2]{padding-top:4px}.van-uploader__upload[data-v-d54b97c2]{cursor:pointer;border-radius:4px}.van-uploader__preview-delete[data-v-d54b97c2]{font-size:18px;top:-8px;right:-8px;bottom:unset;border-radius:100%;background-color:#fff;color:#969799}.van-uploader .pdf-border[data-v-d54b97c2]{border:1px solid #e8e8e8;display:flex;align-items:center;padding:2px;color:#a6a6a6;font-size:12px}.van-uploader .mask-wrap[data-v-d54b97c2]{width:52px;height:52px;background-color:#000000b3;position:absolute;display:flex;justify-content:center;align-items:center}.van-uploader .mask-wrap .mask-content[data-v-d54b97c2]{display:flex;align-items:center;flex-direction:column;justify-content:center;margin-top:4px}.van-uploader .mask-wrap .mask-content .mask-progress-bar[data-v-d54b97c2]{width:44px;height:4px;background-color:#ffffff80;border-radius:2px}.van-uploader .mask-wrap .mask-content .mask-progress-bar .mask-progress-step[data-v-d54b97c2]{height:4px;background-color:#ffffffe6;border-radius:2px}.van-uploader .mask-wrap .mask-content .mask-text[data-v-d54b97c2]{line-height:24px;color:#fff;font-size:10px}.van-popup[data-v-d54b97c2]{overflow:inherit!important}.van-popup .close-btn[data-v-d54b97c2]{bottom:150px;position:absolute;left:50%;transform:translate(-50%);color:#fff;font-size:25px;background-color:#7972fe;border-radius:50%;border:none;padding:8px}[data-v-d54b97c2] .van-uploader__upload{border:.5px dashed #c6c6d0;width:52px;height:52px;background-color:#fff}.van-uploader__preview-show[data-v-d54b97c2]{font-size:12px;color:#999;text-align:center}
|
package/dist/index.js
CHANGED
|
@@ -1,37 +1,40 @@
|
|
|
1
1
|
import './fms-copy-box/style.css';
|
|
2
|
-
import
|
|
3
|
-
import { default as
|
|
4
|
-
import
|
|
5
|
-
import { default as
|
|
2
|
+
import s from "./fms-copy-box/index.js";
|
|
3
|
+
import { default as G } from "./fms-copy-box/index.js";
|
|
4
|
+
import r from "./fms-empty/index.js";
|
|
5
|
+
import { default as T } from "./fms-empty/index.js";
|
|
6
6
|
import "./fms-ks-decrypt/index.js";
|
|
7
7
|
import t from "./fms-ks-file-upload/index.js";
|
|
8
|
-
import { default as
|
|
8
|
+
import { default as b } from "./fms-ks-file-upload/index.js";
|
|
9
9
|
import p from "./fms-ks-file-view/index.js";
|
|
10
|
-
import { default as
|
|
10
|
+
import { default as j } from "./fms-ks-file-view/index.js";
|
|
11
11
|
import e from "./fms-scroll-list/index.js";
|
|
12
|
-
import { default as
|
|
13
|
-
import
|
|
14
|
-
import { default as
|
|
12
|
+
import { default as q } from "./fms-scroll-list/index.js";
|
|
13
|
+
import a from "./fms-ks-form-grid/index.js";
|
|
14
|
+
import { default as z } from "./fms-ks-form-grid/index.js";
|
|
15
15
|
import "./fms-ks-search-tips/index.js";
|
|
16
|
-
import
|
|
17
|
-
import {
|
|
18
|
-
import { F
|
|
19
|
-
import { F as
|
|
20
|
-
|
|
21
|
-
|
|
16
|
+
import f from "./fms-ks-upload/index.js";
|
|
17
|
+
import { default as H } from "./fms-ks-upload/index.js";
|
|
18
|
+
import { F } from "./fms-ks-decrypt.2f88e659.js";
|
|
19
|
+
import { F as J } from "./fms-ks-decrypt.2f88e659.js";
|
|
20
|
+
import { F as i } from "./fms-ks-search-tips.d36859c3.js";
|
|
21
|
+
import { F as N } from "./fms-ks-search-tips.d36859c3.js";
|
|
22
|
+
const l = [s, r, F, t, p, e, a, i, f], d = function(m) {
|
|
23
|
+
l.forEach((o) => {
|
|
22
24
|
m.component(o.name, o);
|
|
23
25
|
});
|
|
24
|
-
},
|
|
25
|
-
install:
|
|
26
|
+
}, B = {
|
|
27
|
+
install: d
|
|
26
28
|
};
|
|
27
29
|
export {
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
30
|
+
G as FmsCopyBox,
|
|
31
|
+
T as FmsEmpty,
|
|
32
|
+
J as FmsKsDecrypt,
|
|
33
|
+
b as FmsKsFileUpload,
|
|
34
|
+
j as FmsKsFileView,
|
|
35
|
+
z as FmsKsFormGrid,
|
|
36
|
+
N as FmsKsSearchTips,
|
|
37
|
+
H as FmsKsUpload,
|
|
38
|
+
q as FmsScrollList,
|
|
39
|
+
B as default
|
|
37
40
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
.ks-date-picker__body{flex:1;overflow:hidden;height:100%;position:relative}.ks-date-picker .van-calendar__body{height:100%;flex:1;overflow:auto;-webkit-overflow-scrolling:touch}.ks-date-picker .van-calendar__month-title{height:40px;line-height:40px;color:#333}.ks-date-picker .van-calendar__day{color:#333}.ks-date-picker .van-calendar__day.van-calendar__day--disabled{color:#ccc}.ks-date-picker .van-calendar__selected-day,.ks-date-picker .van-calendar__day--start,.ks-date-picker .van-calendar__day--end{color:#fff;background-color:#7972fe;border-radius:50%;width:44px;height:44px;line-height:44px;display:flex;align-items:center;justify-content:center}.ks-date-picker .van-calendar__day--start-end{color:#fff;background-color:#7972fe;width:54px;height:44px;line-height:44px;display:flex;align-items:center;justify-content:center;position:relative}.ks-date-picker .van-calendar__day--middle:after{top:3px;bottom:3px}.ks-date-picker .van-calendar__day--start,.ks-date-picker .van-calendar__day--end{position:relative}.ks-date-picker .van-calendar__day--start:after{position:absolute;left:50%;top:0;bottom:0;width:85%;content:" ";background-color:#7972fe1a}.ks-date-picker .van-calendar__day--end:after{position:absolute;right:50%;top:0;bottom:0;width:85%;content:" ";background-color:#7972fe1a}.ks-date-picker .van-calendar__bottom-info{font-size:10px;line-height:10px;font-weight:300;bottom:3px;position:absolute;right:0;left:0}.ks-date-picker .van-calendar__confirm{height:44px;line-height:44px;margin-top:0}.ks-date-picker-
|
|
1
|
+
.ks-date-picker__body{flex:1;overflow:hidden;height:100%;position:relative}.ks-date-picker .van-calendar__body{height:100%;flex:1;overflow:auto;-webkit-overflow-scrolling:touch}.ks-date-picker .van-calendar__month-title{height:40px;line-height:40px;color:#333}.ks-date-picker .van-calendar__day{color:#333}.ks-date-picker .van-calendar__day.van-calendar__day--disabled{color:#ccc}.ks-date-picker .van-calendar__selected-day,.ks-date-picker .van-calendar__day--start,.ks-date-picker .van-calendar__day--end{color:#fff;background-color:#7972fe;border-radius:50%;width:44px;height:44px;line-height:44px;display:flex;align-items:center;justify-content:center}.ks-date-picker .van-calendar__day--start-end{color:#fff;background-color:#7972fe;width:54px;height:44px;line-height:44px;display:flex;align-items:center;justify-content:center;position:relative}.ks-date-picker .van-calendar__day--middle:after{top:3px;bottom:3px}.ks-date-picker .van-calendar__day--start,.ks-date-picker .van-calendar__day--end{position:relative}.ks-date-picker .van-calendar__day--start:after{position:absolute;left:50%;top:0;bottom:0;width:85%;content:" ";background-color:#7972fe1a}.ks-date-picker .van-calendar__day--end:after{position:absolute;right:50%;top:0;bottom:0;width:85%;content:" ";background-color:#7972fe1a}.ks-date-picker .van-calendar__bottom-info{font-size:10px;line-height:10px;font-weight:300;bottom:3px;position:absolute;right:0;left:0}.ks-date-picker .van-calendar__confirm{height:44px;line-height:44px;margin-top:0}.ks-date-picker-dropdown-warpper{position:fixed;left:0;right:0;bottom:0;z-index:10;overflow:hidden}.ks-date-picker-dropdown-popup{position:absolute;height:88%}.ks-date-picker-dropdown-popup .van-popup__close-icon--top-left{top:10px}.ks-date-picker-dropdown{height:100%;overflow:hidden;display:flex;flex-direction:column}.ks-date-picker-dropdown__footer{height:62px;padding:16px 16px 0;box-shadow:0 0 4px #9e9bda38;z-index:1}
|
package/package.json
CHANGED
|
@@ -100,7 +100,7 @@ export default {
|
|
|
100
100
|
},
|
|
101
101
|
// renders
|
|
102
102
|
// head
|
|
103
|
-
renderHead() {
|
|
103
|
+
renderHead(h) {
|
|
104
104
|
const { fileCount, titleName } = this
|
|
105
105
|
return (
|
|
106
106
|
<div class="att-head">
|
|
@@ -112,7 +112,7 @@ export default {
|
|
|
112
112
|
)
|
|
113
113
|
},
|
|
114
114
|
// img list
|
|
115
|
-
renderImages() {
|
|
115
|
+
renderImages(h) {
|
|
116
116
|
const { imgList } = this
|
|
117
117
|
return imgList && imgList.length ? (
|
|
118
118
|
<div class="att-imgs">
|
|
@@ -133,7 +133,7 @@ export default {
|
|
|
133
133
|
) : null
|
|
134
134
|
},
|
|
135
135
|
// 其他文件
|
|
136
|
-
renderOtherFiles() {
|
|
136
|
+
renderOtherFiles(h) {
|
|
137
137
|
const { otherFileList } = this
|
|
138
138
|
return otherFileList && otherFileList.length ? (
|
|
139
139
|
<div class="att-files">
|
|
@@ -213,12 +213,12 @@ export default {
|
|
|
213
213
|
})
|
|
214
214
|
},
|
|
215
215
|
},
|
|
216
|
-
render() {
|
|
216
|
+
render(h) {
|
|
217
217
|
return (
|
|
218
218
|
<div class="att-view">
|
|
219
|
-
{this.$slots.header ? this.$slots.header : this.renderHead()}
|
|
220
|
-
{this.renderImages()}
|
|
221
|
-
{this.renderOtherFiles()}
|
|
219
|
+
{this.$slots.header ? this.$slots.header : this.renderHead(h)}
|
|
220
|
+
{this.renderImages(h)}
|
|
221
|
+
{this.renderOtherFiles(h)}
|
|
222
222
|
</div>
|
|
223
223
|
)
|
|
224
224
|
},
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" fill="none" version="1.1" width="15.01025390625" height="13.9381103515625" viewBox="0 0 15.01025390625 13.9381103515625"><g><g><path d="M3.75244,2.14429L2.25,2.14429C1.00736,2.14429,0,3.15165,0,4.39429L0,11.6881C0,12.9308,1.00736,13.9381,2.25,13.9381L12.7603,13.9381C14.0029,13.9381,15.0103,12.9308,15.0103,11.6881L15.0103,4.39429C15.0103,3.15165,14.0029,2.14429,12.7603,2.14429L11.2578,2.14429C11.2578,0.960006,10.2976,0,9.11328,0L5.89697,0C4.71269,0,3.75244,0.960006,3.75244,2.14429ZM11.2036,7.77271C11.2036,9.8153,9.54748,11.4711,7.50488,11.4711C5.46228,11.4711,3.80664,9.8153,3.80664,7.77271C3.80664,5.73011,5.46228,4.07422,7.50488,4.07422C9.54748,4.07422,11.2036,5.73011,11.2036,7.77271ZM9.70361,7.77271C9.70361,6.55853,8.71906,5.57422,7.50488,5.57422C6.29071,5.57422,5.30664,6.55853,5.30664,7.77271C5.30664,8.98688,6.29071,9.97107,7.50488,9.97107C8.71906,9.97107,9.70361,8.98688,9.70361,7.77271Z" fill-rule="evenodd" fill="#E3E5ED" fill-opacity="1"/></g></g></svg>
|
|
@@ -0,0 +1,302 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<div class="van-uploader">
|
|
3
|
+
<!-- <van-button @click="demo">单击</van-button> -->
|
|
4
|
+
<div class="van-uploader__wrapper">
|
|
5
|
+
<!-- 已经上传后的附件预览 -->
|
|
6
|
+
<div v-for="(item, index) of value"
|
|
7
|
+
:key="index"
|
|
8
|
+
class="van-uploader__preview">
|
|
9
|
+
<div :class="{'van-image': true, 'van-uploader__preview-image': true,}"
|
|
10
|
+
style="overflow: hidden; border-radius: 4px; width: 52px;height: 52px;">
|
|
11
|
+
<!-- 显示识别进度-报销申请页面有使用到 -->
|
|
12
|
+
<div v-if="process !== 100"
|
|
13
|
+
class="mask-wrap">
|
|
14
|
+
<div class="mask-content">
|
|
15
|
+
<div class="mask-progress-bar">
|
|
16
|
+
<div class="mask-progress-step"
|
|
17
|
+
:style="{width: `${process/100*44}px` }"></div>
|
|
18
|
+
</div>
|
|
19
|
+
<div class="mask-text">识别中</div>
|
|
20
|
+
</div>
|
|
21
|
+
</div>
|
|
22
|
+
<img v-if="(item.contentType || '').toLowerCase().startsWith('image') ||
|
|
23
|
+
['jpg', 'jpeg', 'png', 'bmp', 'HEIC', 'webp', 'tiff'].includes(
|
|
24
|
+
(item.extendName || '').toLowerCase()
|
|
25
|
+
)"
|
|
26
|
+
:src="item.url"
|
|
27
|
+
@click="previewAssets(item.url, value)"
|
|
28
|
+
class="van-image__img"
|
|
29
|
+
style="object-fit: cover;" />
|
|
30
|
+
<div v-else-if="(item.contentType || '').toLowerCase().includes('pdf') ||
|
|
31
|
+
['pdf'].includes((item.extendName || '').toLowerCase())"
|
|
32
|
+
@click="pdfPreview(item)"><img class="van-image__img"
|
|
33
|
+
src="https://erphostjs.kye-erp.com/hr-oa-kts/ks-app/kuasheng-oa/images/pdf.svg"
|
|
34
|
+
alt=""></div>
|
|
35
|
+
<div v-else
|
|
36
|
+
class="van-uploader__upload"
|
|
37
|
+
style="margin:0;">
|
|
38
|
+
<div class="van-uploader__preview-show">文件请到<br />ERP查看</div>
|
|
39
|
+
</div>
|
|
40
|
+
</div>
|
|
41
|
+
<i class="van-icon van-icon-clear van-uploader__preview-delete"
|
|
42
|
+
v-if="type === 'edit'"
|
|
43
|
+
style="color: #a7aab7;border:1px solid #fff;fontSize: 14px;"
|
|
44
|
+
@click="onDelete(index)"></i>
|
|
45
|
+
</div>
|
|
46
|
+
<!-- 上传按钮 -->
|
|
47
|
+
<div v-if="((maxLength && value.length < maxLength) || !maxLength) && type === 'edit'"
|
|
48
|
+
class="van-uploader__upload"
|
|
49
|
+
@click="onPreview"
|
|
50
|
+
style="font-size: 22px;">
|
|
51
|
+
<img class="upload-icon" src="./camera.svg" />
|
|
52
|
+
<!-- <i class="van-icon van-icon-photograph van-uploader__upload-icon" style="font-size: 16px;"></i> -->
|
|
53
|
+
</div>
|
|
54
|
+
</div>
|
|
55
|
+
<ks-action-sheet v-model="show"
|
|
56
|
+
:actions="actions"
|
|
57
|
+
get-container="body"
|
|
58
|
+
cancel-text="取消"
|
|
59
|
+
@select="onSelect"
|
|
60
|
+
@cancel="onCancel" />
|
|
61
|
+
<!-- <van-popup v-model="showPdf" get-container="body">
|
|
62
|
+
<pdf-prev :url="pdfUrl" v-if="showPdf"></pdf-prev>
|
|
63
|
+
<van-icon name="cross"
|
|
64
|
+
class="close-btn"
|
|
65
|
+
@click="showPdf = false" />
|
|
66
|
+
</van-popup> -->
|
|
67
|
+
</div>
|
|
68
|
+
</template>
|
|
69
|
+
|
|
70
|
+
<script>
|
|
71
|
+
const Toast = window.vant && window.vant.Toast
|
|
72
|
+
|
|
73
|
+
export default {
|
|
74
|
+
name: "FmsKsUpload",
|
|
75
|
+
// components: { PdfPrev },
|
|
76
|
+
props: {
|
|
77
|
+
value: {
|
|
78
|
+
type: Array,
|
|
79
|
+
default: () => ([])
|
|
80
|
+
},
|
|
81
|
+
bizId: String,
|
|
82
|
+
bizCode: String,
|
|
83
|
+
maxLength: Number
|
|
84
|
+
,
|
|
85
|
+
type: { // edit 可以编辑 detail 不可以编辑
|
|
86
|
+
type: String,
|
|
87
|
+
default: 'edit'
|
|
88
|
+
},
|
|
89
|
+
process: { // 识别进度
|
|
90
|
+
type: Number,
|
|
91
|
+
default: 100
|
|
92
|
+
},
|
|
93
|
+
onPreviewBefore: Function, // 点击上传按钮之前的操作,可终止唤起弹框
|
|
94
|
+
},
|
|
95
|
+
data () {
|
|
96
|
+
return {
|
|
97
|
+
show: false,
|
|
98
|
+
actions: [{ name: "从相册选择" }, { name: "拍照" }],
|
|
99
|
+
showPdf: false,
|
|
100
|
+
pdfUrl: ''
|
|
101
|
+
};
|
|
102
|
+
},
|
|
103
|
+
methods: {
|
|
104
|
+
onPreview () {
|
|
105
|
+
if (this.onPreviewBefore && typeof this.onPreviewBefore === 'function') {
|
|
106
|
+
const flag = this.onPreviewBefore()
|
|
107
|
+
if (flag) {
|
|
108
|
+
return
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
this.show = true;
|
|
112
|
+
},
|
|
113
|
+
onCancel () {
|
|
114
|
+
this.show = false;
|
|
115
|
+
},
|
|
116
|
+
async onSelect(item) {
|
|
117
|
+
let fileList = null
|
|
118
|
+
try {
|
|
119
|
+
// NOTE: 此处原代码为 this.$store.commit('setPreviewFile', true),因改为组件库,所以此处改为暴露事件 beforeSelect
|
|
120
|
+
this.$emit('beforeSelect', item)
|
|
121
|
+
if (item.name === '从相册选择') {
|
|
122
|
+
// 选择照片的数量( 默认可选9张图片 )
|
|
123
|
+
const totalCount = Number(this.maxLength - this.value.length)
|
|
124
|
+
console.log('从相册选择', item, totalCount, this.maxLength, this.value.length)
|
|
125
|
+
fileList = await window.ks.callFunc({
|
|
126
|
+
method: 'pickAssets',
|
|
127
|
+
params: {
|
|
128
|
+
totalCount: totalCount,
|
|
129
|
+
allowRecordVideo: false,
|
|
130
|
+
selectType: 1,
|
|
131
|
+
quality: 80,
|
|
132
|
+
},
|
|
133
|
+
})
|
|
134
|
+
} else if (item.name === '拍照') {
|
|
135
|
+
fileList = await window.ks.takeByCamera()
|
|
136
|
+
}
|
|
137
|
+
this.onCancel()
|
|
138
|
+
if (this.maxLength && fileList.length > this.maxLength) {
|
|
139
|
+
Toast('选择文件太多')
|
|
140
|
+
} else {
|
|
141
|
+
this.upload(fileList)
|
|
142
|
+
}
|
|
143
|
+
} catch (error) {
|
|
144
|
+
console.info('onSelect--error', error)
|
|
145
|
+
if (error && error.msg) {
|
|
146
|
+
Toast(error.msg)
|
|
147
|
+
}
|
|
148
|
+
this.onCancel()
|
|
149
|
+
}
|
|
150
|
+
},
|
|
151
|
+
onDelete (index) {
|
|
152
|
+
let list = JSON.parse(JSON.stringify(this.value))
|
|
153
|
+
let data = list[index]
|
|
154
|
+
list.splice(index, 1)
|
|
155
|
+
this.$emit('input', list)
|
|
156
|
+
this.$http('file.deleteByBizAndId', 10124, data).then(res => {
|
|
157
|
+
this.$emit('deleteSuccess', res, data)
|
|
158
|
+
}).catch(err => {
|
|
159
|
+
console.log(err)
|
|
160
|
+
})
|
|
161
|
+
},
|
|
162
|
+
async upload (list) {
|
|
163
|
+
try {
|
|
164
|
+
let res = await window.ks.uploadAssets({
|
|
165
|
+
filePaths: list.map(item => item.filePath),
|
|
166
|
+
fileNames: list.map(item => item.fileName),
|
|
167
|
+
bizCode: this.bizCode,
|
|
168
|
+
bizId: this.bizId
|
|
169
|
+
})
|
|
170
|
+
// 这里有个坑,安卓与IOS机型不同的地方,list中的name,安卓同样图片name不同,为时间戳;苹果同样图片name相同,为之前的文件名称
|
|
171
|
+
console.log('uploadRes---', res)
|
|
172
|
+
this.$emit('input', res.reverse())
|
|
173
|
+
this.$emit('uploadsuccess', list, res)
|
|
174
|
+
this.onCancel()
|
|
175
|
+
} catch (error) {
|
|
176
|
+
console.log('上传失败--', error)
|
|
177
|
+
}
|
|
178
|
+
},
|
|
179
|
+
previewAssets(url, list) {
|
|
180
|
+
// NOTE: 此处原代码为 this.$store.commit('setPreviewFile', true),因改为组件库,所以此处改为暴露事件 beforePreviewAssets
|
|
181
|
+
let filePaths = list.filter(item => (item.contentType || '').toLowerCase().startsWith('image') ||
|
|
182
|
+
['jpg', 'jpeg', 'png', 'bmp', 'HEIC', 'webp', 'tiff'].includes(
|
|
183
|
+
(item.extendName || '').toLowerCase()
|
|
184
|
+
)).map(item => item.url)
|
|
185
|
+
const index = filePaths.findIndex(item => item === url)
|
|
186
|
+
|
|
187
|
+
this.$emit('beforePreviewAssets', {
|
|
188
|
+
index,
|
|
189
|
+
list,
|
|
190
|
+
})
|
|
191
|
+
window.ks.previewAssets({
|
|
192
|
+
index, // 默认从第几个资源开始浏览 index不能大于assetsPaths的长度
|
|
193
|
+
filePaths // 接口返回的文件系统路径,或者本地路径
|
|
194
|
+
})
|
|
195
|
+
},
|
|
196
|
+
pdfPreview (item) {
|
|
197
|
+
// this.showPdf = true
|
|
198
|
+
// this.pdfUrl = item.url
|
|
199
|
+
// NOTE: 此处原代码为 this.$store.commit('setPreviewFile', true),因改为组件库,所以此处改为暴露事件 beforePreviewAssets
|
|
200
|
+
this.$emit('beforePreviewAssets', {
|
|
201
|
+
index,
|
|
202
|
+
list,
|
|
203
|
+
})
|
|
204
|
+
window.ks.callFunc({
|
|
205
|
+
method: 'previewFile',
|
|
206
|
+
params: {
|
|
207
|
+
filePath: item.url,
|
|
208
|
+
fileName: item.name,
|
|
209
|
+
fileSize: String(item.size) // 改为string类型
|
|
210
|
+
}
|
|
211
|
+
})
|
|
212
|
+
}
|
|
213
|
+
}
|
|
214
|
+
};
|
|
215
|
+
</script>
|
|
216
|
+
|
|
217
|
+
<style lang="less" scoped>
|
|
218
|
+
.van-uploader {
|
|
219
|
+
// padding-bottom: 10px;
|
|
220
|
+
padding-top: 4px;
|
|
221
|
+
&__upload {
|
|
222
|
+
cursor: pointer;
|
|
223
|
+
border-radius: 4px;
|
|
224
|
+
}
|
|
225
|
+
&__preview-delete {
|
|
226
|
+
font-size: 18px;
|
|
227
|
+
top: -8px;
|
|
228
|
+
right: -8px;
|
|
229
|
+
bottom: unset;
|
|
230
|
+
border-radius: 100%;
|
|
231
|
+
background-color: #fff;
|
|
232
|
+
color: #969799;
|
|
233
|
+
}
|
|
234
|
+
.pdf-border {
|
|
235
|
+
border: 1px solid #e8e8e8;
|
|
236
|
+
display: flex;
|
|
237
|
+
align-items: center;
|
|
238
|
+
padding: 2px;
|
|
239
|
+
color: #a6a6a6;
|
|
240
|
+
font-size: 12px;
|
|
241
|
+
}
|
|
242
|
+
.mask-wrap {
|
|
243
|
+
width: 52px;
|
|
244
|
+
height: 52px;
|
|
245
|
+
background-color: rgba(0, 0, 0, 0.7);
|
|
246
|
+
position: absolute;
|
|
247
|
+
display: flex;
|
|
248
|
+
justify-content: center;
|
|
249
|
+
align-items: center;
|
|
250
|
+
.mask-content {
|
|
251
|
+
display: flex;
|
|
252
|
+
align-items: center;
|
|
253
|
+
flex-direction: column;
|
|
254
|
+
justify-content: center;
|
|
255
|
+
margin-top: 4px;
|
|
256
|
+
.mask-progress-bar {
|
|
257
|
+
width: 44px;
|
|
258
|
+
height: 4px;
|
|
259
|
+
background-color: rgba(255, 255, 255, 0.5);
|
|
260
|
+
border-radius: 2px;
|
|
261
|
+
.mask-progress-step {
|
|
262
|
+
// width: 20px;
|
|
263
|
+
height: 4px;
|
|
264
|
+
background-color: rgba(255, 255, 255, 0.9);
|
|
265
|
+
border-radius: 2px;
|
|
266
|
+
}
|
|
267
|
+
}
|
|
268
|
+
.mask-text {
|
|
269
|
+
line-height: 24px;
|
|
270
|
+
color: #fff;
|
|
271
|
+
font-size: 10px;
|
|
272
|
+
}
|
|
273
|
+
}
|
|
274
|
+
}
|
|
275
|
+
}
|
|
276
|
+
.van-popup {
|
|
277
|
+
overflow: inherit !important;
|
|
278
|
+
.close-btn {
|
|
279
|
+
bottom: 150px;
|
|
280
|
+
position: absolute;
|
|
281
|
+
left: 50%;
|
|
282
|
+
transform: translateX(-50%);
|
|
283
|
+
color: #fff;
|
|
284
|
+
font-size: 25px;
|
|
285
|
+
background-color: #7972fe;
|
|
286
|
+
border-radius: 50%;
|
|
287
|
+
border: none;
|
|
288
|
+
padding: 8px;
|
|
289
|
+
}
|
|
290
|
+
}
|
|
291
|
+
/deep/ .van-uploader__upload {
|
|
292
|
+
border: 0.5px dashed #c6c6d0;
|
|
293
|
+
width: 52px;
|
|
294
|
+
height: 52px;
|
|
295
|
+
background-color: #fff;
|
|
296
|
+
}
|
|
297
|
+
.van-uploader__preview-show {
|
|
298
|
+
font-size: 12px;
|
|
299
|
+
color: #999;
|
|
300
|
+
text-align: center;
|
|
301
|
+
}
|
|
302
|
+
</style>
|
|
File without changes
|
package/src/index.js
CHANGED
|
@@ -7,6 +7,7 @@ import FmsKsFileView from './components/fms-ks-file-view/index'
|
|
|
7
7
|
import FmsScrollList from './components/fms-scroll-list/index'
|
|
8
8
|
import FmsKsFormGrid from './components/fms-ks-form-grid'
|
|
9
9
|
import FmsKsSearchTips from './components/fms-ks-search-tips'
|
|
10
|
+
import FmsKsUpload from './components/fms-ks-upload/index'
|
|
10
11
|
|
|
11
12
|
const components = [
|
|
12
13
|
FmsCopyBox,
|
|
@@ -16,7 +17,8 @@ const components = [
|
|
|
16
17
|
FmsKsFileView,
|
|
17
18
|
FmsScrollList,
|
|
18
19
|
FmsKsFormGrid,
|
|
19
|
-
FmsKsSearchTips
|
|
20
|
+
FmsKsSearchTips,
|
|
21
|
+
FmsKsUpload
|
|
20
22
|
]
|
|
21
23
|
|
|
22
24
|
const install = function(Vue) {
|
|
@@ -34,7 +36,8 @@ export {
|
|
|
34
36
|
FmsKsFileView,
|
|
35
37
|
FmsScrollList,
|
|
36
38
|
FmsKsFormGrid,
|
|
37
|
-
FmsKsSearchTips
|
|
39
|
+
FmsKsSearchTips,
|
|
40
|
+
FmsKsUpload
|
|
38
41
|
}
|
|
39
42
|
// 全量导出
|
|
40
43
|
export default {
|