@huilian/components-tms 1.0.0

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.
@@ -0,0 +1,907 @@
1
+ (function (l, r) {
2
+ if (!l || l.getElementById('livereloadscript')) return;
3
+ r = l.createElement('script');
4
+ r.async = 1;
5
+ r.src = '//' + (self.location.host || 'localhost').split(':')[0] + ':35729/livereload.js?snipver=1';
6
+ r.id = 'livereloadscript';
7
+ l.getElementsByTagName('head')[0].appendChild(r);
8
+ })(self.document);
9
+
10
+ import { mapGetters } from 'vuex';
11
+ import axios from 'axios'; //
12
+ //
13
+ //
14
+ //
15
+
16
+ var script$2 = {
17
+ name: 'HelloWorld',
18
+ props: {
19
+ msg: String
20
+ }
21
+ };
22
+
23
+ function normalizeComponent(template, style, script, scopeId, isFunctionalTemplate, moduleIdentifier
24
+ /* server only */
25
+ , shadowMode, createInjector, createInjectorSSR, createInjectorShadow) {
26
+ if (typeof shadowMode !== 'boolean') {
27
+ createInjectorSSR = createInjector;
28
+ createInjector = shadowMode;
29
+ shadowMode = false;
30
+ } // Vue.extend constructor export interop.
31
+
32
+
33
+ const options = typeof script === 'function' ? script.options : script; // render functions
34
+
35
+ if (template && template.render) {
36
+ options.render = template.render;
37
+ options.staticRenderFns = template.staticRenderFns;
38
+ options._compiled = true; // functional template
39
+
40
+ if (isFunctionalTemplate) {
41
+ options.functional = true;
42
+ }
43
+ } // scopedId
44
+
45
+
46
+ if (scopeId) {
47
+ options._scopeId = scopeId;
48
+ }
49
+
50
+ let hook;
51
+
52
+ if (moduleIdentifier) {
53
+ // server build
54
+ hook = function (context) {
55
+ // 2.3 injection
56
+ context = context || // cached call
57
+ this.$vnode && this.$vnode.ssrContext || // stateful
58
+ this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext; // functional
59
+ // 2.2 with runInNewContext: true
60
+
61
+ if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') {
62
+ context = __VUE_SSR_CONTEXT__;
63
+ } // inject component styles
64
+
65
+
66
+ if (style) {
67
+ style.call(this, createInjectorSSR(context));
68
+ } // register component module identifier for async chunk inference
69
+
70
+
71
+ if (context && context._registeredComponents) {
72
+ context._registeredComponents.add(moduleIdentifier);
73
+ }
74
+ }; // used by ssr in case component is cached and beforeCreate
75
+ // never gets called
76
+
77
+
78
+ options._ssrRegister = hook;
79
+ } else if (style) {
80
+ hook = shadowMode ? function (context) {
81
+ style.call(this, createInjectorShadow(context, this.$root.$options.shadowRoot));
82
+ } : function (context) {
83
+ style.call(this, createInjector(context));
84
+ };
85
+ }
86
+
87
+ if (hook) {
88
+ if (options.functional) {
89
+ // register for functional component in vue file
90
+ const originalRender = options.render;
91
+
92
+ options.render = function renderWithStyleInjection(h, context) {
93
+ hook.call(context);
94
+ return originalRender(h, context);
95
+ };
96
+ } else {
97
+ // inject component registration as beforeCreate hook
98
+ const existing = options.beforeCreate;
99
+ options.beforeCreate = existing ? [].concat(existing, hook) : [hook];
100
+ }
101
+ }
102
+
103
+ return script;
104
+ }
105
+ /* script */
106
+
107
+
108
+ const __vue_script__$2 = script$2;
109
+ /* template */
110
+
111
+ var __vue_render__$2 = function () {
112
+ var _vm = this;
113
+
114
+ var _h = _vm.$createElement;
115
+
116
+ var _c = _vm._self._c || _h;
117
+
118
+ return _c("el-button", [_vm._v("123")]);
119
+ };
120
+
121
+ var __vue_staticRenderFns__$2 = [];
122
+ __vue_render__$2._withStripped = true;
123
+ /* style */
124
+
125
+ const __vue_inject_styles__$2 = undefined;
126
+ /* scoped */
127
+
128
+ const __vue_scope_id__$2 = undefined;
129
+ /* module identifier */
130
+
131
+ const __vue_module_identifier__$2 = undefined;
132
+ /* functional template */
133
+
134
+ const __vue_is_functional_template__$2 = false;
135
+ /* style inject */
136
+
137
+ /* style inject SSR */
138
+
139
+ /* style inject shadow dom */
140
+
141
+ const __vue_component__$2 = /*#__PURE__*/normalizeComponent({
142
+ render: __vue_render__$2,
143
+ staticRenderFns: __vue_staticRenderFns__$2
144
+ }, __vue_inject_styles__$2, __vue_script__$2, __vue_scope_id__$2, __vue_is_functional_template__$2, __vue_module_identifier__$2, false, undefined, undefined, undefined);
145
+
146
+ __vue_component__$2.install = function (Vue) {
147
+ Vue.component(__vue_component__$2.name, __vue_component__$2);
148
+ }; //
149
+ //
150
+ //
151
+ //
152
+ //
153
+ //
154
+ //
155
+ //
156
+ //
157
+ //
158
+ //
159
+ //
160
+ //
161
+ //
162
+ //
163
+ //
164
+ //
165
+ //
166
+ //
167
+ //
168
+ //
169
+ //
170
+ //
171
+ //
172
+ //
173
+ //
174
+ //
175
+ //
176
+ //
177
+ //
178
+ //
179
+ //
180
+ //
181
+
182
+
183
+ var script$1 = {
184
+ name: 'HelloVue',
185
+ props: {
186
+ msg: String
187
+ }
188
+ };
189
+ const isOldIE = typeof navigator !== 'undefined' && /msie [6-9]\\b/.test(navigator.userAgent.toLowerCase());
190
+
191
+ function createInjector(context) {
192
+ return (id, style) => addStyle(id, style);
193
+ }
194
+
195
+ let HEAD;
196
+ const styles = {};
197
+
198
+ function addStyle(id, css) {
199
+ const group = isOldIE ? css.media || 'default' : id;
200
+ const style = styles[group] || (styles[group] = {
201
+ ids: new Set(),
202
+ styles: []
203
+ });
204
+
205
+ if (!style.ids.has(id)) {
206
+ style.ids.add(id);
207
+ let code = css.source;
208
+
209
+ if (css.map) {
210
+ // https://developer.chrome.com/devtools/docs/javascript-debugging
211
+ // this makes source maps inside style tags work properly in Chrome
212
+ code += '\n/*# sourceURL=' + css.map.sources[0] + ' */'; // http://stackoverflow.com/a/26603875
213
+
214
+ code += '\n/*# sourceMappingURL=data:application/json;base64,' + btoa(unescape(encodeURIComponent(JSON.stringify(css.map)))) + ' */';
215
+ }
216
+
217
+ if (!style.element) {
218
+ style.element = document.createElement('style');
219
+ style.element.type = 'text/css';
220
+ if (css.media) style.element.setAttribute('media', css.media);
221
+
222
+ if (HEAD === undefined) {
223
+ HEAD = document.head || document.getElementsByTagName('head')[0];
224
+ }
225
+
226
+ HEAD.appendChild(style.element);
227
+ }
228
+
229
+ if ('styleSheet' in style.element) {
230
+ style.styles.push(code);
231
+ style.element.styleSheet.cssText = style.styles.filter(Boolean).join('\n');
232
+ } else {
233
+ const index = style.ids.size - 1;
234
+ const textNode = document.createTextNode(code);
235
+ const nodes = style.element.childNodes;
236
+ if (nodes[index]) style.element.removeChild(nodes[index]);
237
+ if (nodes.length) style.element.insertBefore(textNode, nodes[index]);else style.element.appendChild(textNode);
238
+ }
239
+ }
240
+ }
241
+ /* script */
242
+
243
+
244
+ const __vue_script__$1 = script$1;
245
+ /* template */
246
+
247
+ var __vue_render__$1 = function () {
248
+ var _vm = this;
249
+
250
+ var _h = _vm.$createElement;
251
+
252
+ var _c = _vm._self._c || _h;
253
+
254
+ return _c("div", {
255
+ staticClass: "hello"
256
+ }, [_c("h1", [_vm._v(_vm._s(_vm.msg))]), _vm._v(" "), _vm._m(0), _vm._v(" "), _c("h3", [_vm._v("Installed CLI Plugins")]), _vm._v(" "), _vm._m(1), _vm._v(" "), _c("h3", [_vm._v("Essential Links")]), _vm._v(" "), _vm._m(2), _vm._v(" "), _c("h3", [_vm._v("Ecosystem")]), _vm._v(" "), _vm._m(3)]);
257
+ };
258
+
259
+ var __vue_staticRenderFns__$1 = [function () {
260
+ var _vm = this;
261
+
262
+ var _h = _vm.$createElement;
263
+
264
+ var _c = _vm._self._c || _h;
265
+
266
+ return _c("p", [_vm._v("\n For a guide and recipes on how to configure / customize this project,"), _c("br"), _vm._v("\n check out the\n "), _c("a", {
267
+ attrs: {
268
+ href: "https://cli.vuejs.org",
269
+ target: "_blank",
270
+ rel: "noopener"
271
+ }
272
+ }, [_vm._v("vue-cli documentation")]), _vm._v(".\n ")]);
273
+ }, function () {
274
+ var _vm = this;
275
+
276
+ var _h = _vm.$createElement;
277
+
278
+ var _c = _vm._self._c || _h;
279
+
280
+ return _c("ul", [_c("li", [_c("a", {
281
+ attrs: {
282
+ href: "https://github.com/vuejs/vue-cli/tree/dev/packages/%40vue/cli-plugin-babel",
283
+ target: "_blank",
284
+ rel: "noopener"
285
+ }
286
+ }, [_vm._v("babel")])]), _vm._v(" "), _c("li", [_c("a", {
287
+ attrs: {
288
+ href: "https://github.com/vuejs/vue-cli/tree/dev/packages/%40vue/cli-plugin-typescript",
289
+ target: "_blank",
290
+ rel: "noopener"
291
+ }
292
+ }, [_vm._v("typescript")])]), _vm._v(" "), _c("li", [_c("a", {
293
+ attrs: {
294
+ href: "https://github.com/vuejs/vue-cli/tree/dev/packages/%40vue/cli-plugin-eslint",
295
+ target: "_blank",
296
+ rel: "noopener"
297
+ }
298
+ }, [_vm._v("eslint")])])]);
299
+ }, function () {
300
+ var _vm = this;
301
+
302
+ var _h = _vm.$createElement;
303
+
304
+ var _c = _vm._self._c || _h;
305
+
306
+ return _c("ul", [_c("li", [_c("a", {
307
+ attrs: {
308
+ href: "https://vuejs.org",
309
+ target: "_blank",
310
+ rel: "noopener"
311
+ }
312
+ }, [_vm._v("Core Docs")])]), _vm._v(" "), _c("li", [_c("a", {
313
+ attrs: {
314
+ href: "https://forum.vuejs.org",
315
+ target: "_blank",
316
+ rel: "noopener"
317
+ }
318
+ }, [_vm._v("Forum")])]), _vm._v(" "), _c("li", [_c("a", {
319
+ attrs: {
320
+ href: "https://chat.vuejs.org",
321
+ target: "_blank",
322
+ rel: "noopener"
323
+ }
324
+ }, [_vm._v("Community Chat")])]), _vm._v(" "), _c("li", [_c("a", {
325
+ attrs: {
326
+ href: "https://twitter.com/vuejs",
327
+ target: "_blank",
328
+ rel: "noopener"
329
+ }
330
+ }, [_vm._v("Twitter")])]), _vm._v(" "), _c("li", [_c("a", {
331
+ attrs: {
332
+ href: "https://news.vuejs.org",
333
+ target: "_blank",
334
+ rel: "noopener"
335
+ }
336
+ }, [_vm._v("News")])])]);
337
+ }, function () {
338
+ var _vm = this;
339
+
340
+ var _h = _vm.$createElement;
341
+
342
+ var _c = _vm._self._c || _h;
343
+
344
+ return _c("ul", [_c("li", [_c("a", {
345
+ attrs: {
346
+ href: "https://router.vuejs.org",
347
+ target: "_blank",
348
+ rel: "noopener"
349
+ }
350
+ }, [_vm._v("vue-router")])]), _vm._v(" "), _c("li", [_c("a", {
351
+ attrs: {
352
+ href: "https://vuex.vuejs.org",
353
+ target: "_blank",
354
+ rel: "noopener"
355
+ }
356
+ }, [_vm._v("vuex")])]), _vm._v(" "), _c("li", [_c("a", {
357
+ attrs: {
358
+ href: "https://github.com/vuejs/vue-devtools#vue-devtools",
359
+ target: "_blank",
360
+ rel: "noopener"
361
+ }
362
+ }, [_vm._v("vue-devtools")])]), _vm._v(" "), _c("li", [_c("a", {
363
+ attrs: {
364
+ href: "https://vue-loader.vuejs.org",
365
+ target: "_blank",
366
+ rel: "noopener"
367
+ }
368
+ }, [_vm._v("vue-loader")])]), _vm._v(" "), _c("li", [_c("a", {
369
+ attrs: {
370
+ href: "https://github.com/vuejs/awesome-vue",
371
+ target: "_blank",
372
+ rel: "noopener"
373
+ }
374
+ }, [_vm._v("awesome-vue")])])]);
375
+ }];
376
+ __vue_render__$1._withStripped = true;
377
+ /* style */
378
+
379
+ const __vue_inject_styles__$1 = function (inject) {
380
+ if (!inject) return;
381
+ inject("data-v-d79cbb16_0", {
382
+ source: "\nh3[data-v-d79cbb16] {\n margin: 40px 0 0;\n}\nul[data-v-d79cbb16] {\n list-style-type: none;\n padding: 0;\n}\nli[data-v-d79cbb16] {\n display: inline-block;\n margin: 0 10px;\n}\na[data-v-d79cbb16] {\n color: #42b983;\n}\n",
383
+ map: {
384
+ "version": 3,
385
+ "sources": ["/Users/chenlei/HLcode/test/components/HelloVue/index.vue"],
386
+ "names": [],
387
+ "mappings": ";AA4CA;EACA,gBAAA;AACA;AACA;EACA,qBAAA;EACA,UAAA;AACA;AACA;EACA,qBAAA;EACA,cAAA;AACA;AACA;EACA,cAAA;AACA",
388
+ "file": "index.vue",
389
+ "sourcesContent": ["<template>\n <div class=\"hello\">\n <h1>{{ msg }}</h1>\n <p>\n For a guide and recipes on how to configure / customize this project,<br>\n check out the\n <a href=\"https://cli.vuejs.org\" target=\"_blank\" rel=\"noopener\">vue-cli documentation</a>.\n </p>\n <h3>Installed CLI Plugins</h3>\n <ul>\n <li><a href=\"https://github.com/vuejs/vue-cli/tree/dev/packages/%40vue/cli-plugin-babel\" target=\"_blank\" rel=\"noopener\">babel</a></li>\n <li><a href=\"https://github.com/vuejs/vue-cli/tree/dev/packages/%40vue/cli-plugin-typescript\" target=\"_blank\" rel=\"noopener\">typescript</a></li>\n <li><a href=\"https://github.com/vuejs/vue-cli/tree/dev/packages/%40vue/cli-plugin-eslint\" target=\"_blank\" rel=\"noopener\">eslint</a></li>\n </ul>\n <h3>Essential Links</h3>\n <ul>\n <li><a href=\"https://vuejs.org\" target=\"_blank\" rel=\"noopener\">Core Docs</a></li>\n <li><a href=\"https://forum.vuejs.org\" target=\"_blank\" rel=\"noopener\">Forum</a></li>\n <li><a href=\"https://chat.vuejs.org\" target=\"_blank\" rel=\"noopener\">Community Chat</a></li>\n <li><a href=\"https://twitter.com/vuejs\" target=\"_blank\" rel=\"noopener\">Twitter</a></li>\n <li><a href=\"https://news.vuejs.org\" target=\"_blank\" rel=\"noopener\">News</a></li>\n </ul>\n <h3>Ecosystem</h3>\n <ul>\n <li><a href=\"https://router.vuejs.org\" target=\"_blank\" rel=\"noopener\">vue-router</a></li>\n <li><a href=\"https://vuex.vuejs.org\" target=\"_blank\" rel=\"noopener\">vuex</a></li>\n <li><a href=\"https://github.com/vuejs/vue-devtools#vue-devtools\" target=\"_blank\" rel=\"noopener\">vue-devtools</a></li>\n <li><a href=\"https://vue-loader.vuejs.org\" target=\"_blank\" rel=\"noopener\">vue-loader</a></li>\n <li><a href=\"https://github.com/vuejs/awesome-vue\" target=\"_blank\" rel=\"noopener\">awesome-vue</a></li>\n </ul>\n </div>\n</template>\n\n<script>\nexport default {\n name: 'HelloVue',\n props: {\n msg: String,\n },\n};\n</script>\n\n<!-- Add \"scoped\" attribute to limit CSS to this component only -->\n<style scoped>\nh3 {\n margin: 40px 0 0;\n}\nul {\n list-style-type: none;\n padding: 0;\n}\nli {\n display: inline-block;\n margin: 0 10px;\n}\na {\n color: #42b983;\n}\n</style>"]
390
+ },
391
+ media: undefined
392
+ });
393
+ };
394
+ /* scoped */
395
+
396
+
397
+ const __vue_scope_id__$1 = "data-v-d79cbb16";
398
+ /* module identifier */
399
+
400
+ const __vue_module_identifier__$1 = undefined;
401
+ /* functional template */
402
+
403
+ const __vue_is_functional_template__$1 = false;
404
+ /* style inject SSR */
405
+
406
+ /* style inject shadow dom */
407
+
408
+ const __vue_component__$1 = /*#__PURE__*/normalizeComponent({
409
+ render: __vue_render__$1,
410
+ staticRenderFns: __vue_staticRenderFns__$1
411
+ }, __vue_inject_styles__$1, __vue_script__$1, __vue_scope_id__$1, __vue_is_functional_template__$1, __vue_module_identifier__$1, false, createInjector, undefined, undefined);
412
+
413
+ __vue_component__$1.install = function (Vue) {
414
+ Vue.component(__vue_component__$1.name, __vue_component__$1);
415
+ };
416
+
417
+ var img$7 = "";
418
+ var img$6 = "";
419
+ var img$5 = "";
420
+ var img$4 = "";
421
+ var img$3 = "";
422
+ var img$2 = "";
423
+ var img$1 = "";
424
+ var img = ""; //
425
+
426
+ var script = {
427
+ props: {
428
+ limit: {
429
+ // 限制文件个数
430
+ default: 1,
431
+ type: Number
432
+ },
433
+ multiple: {
434
+ // 上传多个文件
435
+ default: false,
436
+ type: Boolean
437
+ },
438
+ formMaxSize: {
439
+ // 限制文件大小
440
+ default: 10,
441
+ // M
442
+ type: Number
443
+ },
444
+ fileUrl: {
445
+ // 文件数组
446
+ default: [],
447
+ type: Array
448
+ },
449
+ formData: {
450
+ // 上传时附带的额外参数
451
+ default: () => {
452
+ return {
453
+ attachmenType: 'VOUCHER'
454
+ };
455
+ },
456
+ type: Object
457
+ },
458
+ fileType: {
459
+ // 限制选择文件类型
460
+ // default: '.pptx,.csv,.zip,.rar,image/*,application/msexcel,application/msword,application/pdf,application/vnd.openxmlformats-officedocument.spreadsheetml.sheet,application/vnd.openxmlformats-officedocument.wordprocessingml.document, text/plain',
461
+ default: () => {
462
+ return ['.pptx', '.csv', '.zip', '.rar', '.jpg', '.jpeg', '.png', '.doc', '.docx', '.pdf', '.PDF', '.xls', '.xlsx'];
463
+ },
464
+ type: Array
465
+ },
466
+ fileDisabled: {
467
+ default: false,
468
+ type: Boolean
469
+ },
470
+ apiUrl: String
471
+ },
472
+
473
+ data() {
474
+ return {
475
+ formFileList: [],
476
+ // 显示上传文件
477
+ dialogImageUrl: '',
478
+ loading: '',
479
+ noneBtnImg: false
480
+ };
481
+ },
482
+
483
+ computed: { ...mapGetters(['userInfo'])
484
+ },
485
+ watch: {
486
+ fileUrl: {
487
+ deep: true,
488
+ immediate: true,
489
+
490
+ handler() {
491
+ this.formFileList = this.fileUrl;
492
+
493
+ if (this.fileDisabled) {
494
+ this.noneBtnImg = true;
495
+ }
496
+ }
497
+
498
+ }
499
+ },
500
+ methods: {
501
+ // 缩略图展示
502
+ bgImg(file) {
503
+ let type = '';
504
+ const types = {
505
+ IMG: '',
506
+ WORD: img$2,
507
+ EXCEL: img$6,
508
+ PDF: img$5,
509
+ CSV: img$7,
510
+ RAR: img$3,
511
+ ZIP: img$1,
512
+ PPT: img$4,
513
+ APK: img
514
+ };
515
+
516
+ if (file.raw) {
517
+ type = this.fileFormat(file.name);
518
+ } else {
519
+ type = this.fileFormat(file.url);
520
+ }
521
+
522
+ if (type === 'IMG') {
523
+ return file.url;
524
+ } else {
525
+ return types[type];
526
+ }
527
+ },
528
+
529
+ // 文件格式
530
+ fileFormat(name) {
531
+ const images = 'bmp|jpg|jpeg|png|gif|svg|webp|JPG|JPEG|PNG';
532
+ const word = 'doc|docx|DOC|DOCX';
533
+ const excel = 'xls|xlsx|XLS|XLSX';
534
+ const pdf = 'pdf|PDF';
535
+ const csv = 'csv|CSV';
536
+ const rar = 'rar|RAR';
537
+ const zip = 'zip|ZIP';
538
+ const ppt = 'pptx|PPTX';
539
+ const apk = 'apk|APK';
540
+ const pattern_images = new RegExp('.(' + images + ')$');
541
+ const pattern_word = new RegExp('.(' + word + ')$');
542
+ const pattern_excel = new RegExp('.(' + excel + ')$');
543
+ const pattern_pdf = new RegExp('.(' + pdf + ')$');
544
+ const pattern_csv = new RegExp('.(' + csv + ')$');
545
+ const pattern_rar = new RegExp('.(' + rar + ')$');
546
+ const pattern_zip = new RegExp('.(' + zip + ')$');
547
+ const pattern_ppt = new RegExp('.(' + ppt + ')$');
548
+ const pattern_apk = new RegExp('.(' + apk + ')$');
549
+
550
+ if (name.indexOf('?') > -1) {
551
+ name = name.split('?')[0];
552
+ }
553
+
554
+ if (pattern_images.test(name)) {
555
+ return 'IMG';
556
+ } else if (pattern_word.test(name)) {
557
+ return 'WORD';
558
+ } else if (pattern_excel.test(name)) {
559
+ return 'EXCEL';
560
+ } else if (pattern_pdf.test(name)) {
561
+ return 'PDF';
562
+ } else if (pattern_csv.test(name)) {
563
+ return 'CSV';
564
+ } else if (pattern_rar.test(name)) {
565
+ return 'RAR';
566
+ } else if (pattern_zip.test(name)) {
567
+ return 'ZIP';
568
+ } else if (pattern_ppt.test(name)) {
569
+ return 'PPT';
570
+ } else if (pattern_apk.test(name)) {
571
+ return 'APK';
572
+ }
573
+ },
574
+
575
+ // 开始上传前验证
576
+ beforeUploadForm(file) {
577
+ // 验证文件大小
578
+ if (file.size / 1024 / 1024 > this.formMaxSize) {
579
+ setTimeout(() => {
580
+ this.$message({
581
+ message: `上传文件 “${file.name}” 大小不能超过${this.formMaxSize}M!`,
582
+ type: 'warning'
583
+ });
584
+ }, 1);
585
+ return false;
586
+ } // 中文乱码处理
587
+ // if (file.raw) {
588
+ // let reader = new FileReader(); // 读取文件内容
589
+ // reader.readAsText(file.raw, "gb2312"); // 防止中文乱码问题,不加reader.onload方法都不会触发
590
+ // reader.onload = function(e) {
591
+ // this.contentHtml = e.target.result; // txt文本内容,接下来就可以对其进行校验处理了
592
+ // };
593
+ // }
594
+ // 验证文件类型
595
+
596
+
597
+ if (!this.fileType.includes('.' + file.name.split('.')[1])) {
598
+ setTimeout(() => {
599
+ this.$message({
600
+ message: `上传文件 “${file.name}” 格式错误!`,
601
+ type: 'warning'
602
+ });
603
+ }, 1);
604
+ return false;
605
+ }
606
+ },
607
+
608
+ formHandleRemove(file, formFileList) {
609
+ if (file.status !== 'ready') {
610
+ this.formFileList.splice(this.formFileList.indexOf(file), 1);
611
+ this.noneBtnImg = this.formFileList.length >= this.limit;
612
+ }
613
+ },
614
+
615
+ handlePictureCardPreview(file) {
616
+ let type, url;
617
+
618
+ if (file.raw) {
619
+ type = this.fileFormat(file.name);
620
+ url = file.response.data[0].attachmenturl;
621
+ } else {
622
+ type = this.fileFormat(file.url);
623
+ url = file.url;
624
+ }
625
+
626
+ if (type === 'IMG') {
627
+ this.dialogImageUrl = file.url;
628
+ this.$refs.previewImg.showViewer = true;
629
+ } else if (type === 'PDF') {
630
+ window.open('https://www.hellogil.com/web/contractPreview.html?url=' + url.replace('http://', 'https://'));
631
+ } else if (type === 'WORD' || type === 'EXCEL' || type === 'CSV' || type === 'PPT') {
632
+ window.open(`https://www.hellogil.cn:8012/onlinePreview?watermarkTxt=${this.userInfo.userName}${this.userInfo.jobCard}&url=` + url.replace('http://', 'https://'));
633
+ } else {
634
+ this.$message({
635
+ message: '该文件不支持预览!',
636
+ type: 'warning'
637
+ });
638
+ }
639
+ },
640
+
641
+ handleDownload(file) {
642
+ console.log(file);
643
+ var name;
644
+
645
+ if (file.name) {
646
+ name = file.name;
647
+
648
+ if (!name.indexOf('.') > -1) {
649
+ var a = file.url.split('/');
650
+ var b = a[a.length - 1];
651
+ name = file.name + '.' + b.split('.')[1];
652
+ }
653
+ } else {
654
+ var a = file.url.split('/');
655
+ name = a[a.length - 1];
656
+ }
657
+
658
+ axios({
659
+ method: 'post',
660
+ url: process.env.VUE_APP_BASE_API + '/huilianApi/uploader/downloadZipFiles',
661
+ data: 'fileUrls=' + JSON.stringify([{
662
+ imgName: name.replace(/\&/g, '-').replace(/\?/g, '-').replace(/\%/g, '-'),
663
+ dataImg: file.url
664
+ }]),
665
+ responseType: 'blob' // 加上这个是重点
666
+
667
+ }).then(res => {
668
+ this.downloadFile(res.data, name);
669
+ });
670
+ },
671
+
672
+ downloadFile(data, name) {
673
+ const url = window.URL.createObjectURL(new Blob([data]));
674
+ const link = document.createElement('a');
675
+ link.style.display = 'none';
676
+ link.href = url;
677
+ link.setAttribute('download', name);
678
+ document.body.appendChild(link);
679
+ link.click();
680
+ URL.revokeObjectURL(link.href);
681
+ document.body.removeChild(link);
682
+ this.$message({
683
+ message: '下载成功',
684
+ type: 'success'
685
+ });
686
+ },
687
+
688
+ // 允许上传文件个数验证
689
+ formHandleExceed(files, formFileList) {
690
+ this.$message.warning(`最多上传 ${this.limit} 个文件!`);
691
+ },
692
+
693
+ // 上传文件
694
+ handleUploadForm(file, fileList) {// console.log(file.status)
695
+ // if (file.status === 'ready') {
696
+ // this.loading = this.$loading({
697
+ // lock: true,
698
+ // text: '上传中,请稍候...',
699
+ // spinner: 'el-icon-loading',
700
+ // background: 'rgba(0, 0, 0, 0.7)'
701
+ // })
702
+ // } else {
703
+ // // this.loading.close()
704
+ // }
705
+ },
706
+
707
+ // 上传成功
708
+ handleSuccess(response, file, fileList) {
709
+ var num = 0;
710
+
711
+ for (var i = 0; i < fileList.length; i++) {
712
+ if (fileList[i].status === 'success') {
713
+ num++;
714
+ }
715
+ }
716
+
717
+ if (num === fileList.length) {
718
+ // this.formFileList = [];
719
+ // for(var i = 0; i<fileList.length; i++){
720
+ // this.formFileList.push(fileList[i])
721
+ // }
722
+ this.formFileList = fileList;
723
+ this.$emit('update:fileUrl', this.formFileList);
724
+ this.noneBtnImg = this.formFileList.length >= this.limit;
725
+ } // if (response.result === 'success') {
726
+ // this.formFileList.push(file)
727
+ // } else {
728
+ // // console.log(response, file, fileList)
729
+ // fileList.splice(fileList.indexOf(file), 1)
730
+ // this.$message.error(
731
+ // response.msg
732
+ // )
733
+ // }
734
+
735
+ },
736
+
737
+ // 上传失败
738
+ handleError(err, file, fileList) {
739
+ console.log(err); // this.loading.close()
740
+ }
741
+
742
+ }
743
+ };
744
+ /* script */
745
+
746
+ const __vue_script__ = script;
747
+ /* template */
748
+
749
+ var __vue_render__ = function () {
750
+ var _vm = this;
751
+
752
+ var _h = _vm.$createElement;
753
+
754
+ var _c = _vm._self._c || _h;
755
+
756
+ return _c("div", {
757
+ staticClass: "upload_file_box"
758
+ }, [_c("div", {
759
+ staticStyle: {
760
+ height: "0",
761
+ overflow: "hidden"
762
+ }
763
+ }, [_c("el-image", {
764
+ ref: "previewImg",
765
+ attrs: {
766
+ src: _vm.dialogImageUrl,
767
+ "preview-src-list": _vm.formFileList.map(function (item) {
768
+ return _vm.bgImg(item);
769
+ })
770
+ }
771
+ })], 1), _vm._v(" "), _c("el-upload", {
772
+ class: {
773
+ disUoloadSty: _vm.noneBtnImg
774
+ },
775
+ attrs: {
776
+ action: _vm.apiUrl,
777
+ "list-type": "picture-card",
778
+ limit: _vm.limit,
779
+ multiple: _vm.multiple,
780
+ data: _vm.formData,
781
+ accept: _vm.fileType.join(","),
782
+ disabled: _vm.fileDisabled,
783
+ "file-list": _vm.formFileList,
784
+ "on-exceed": _vm.formHandleExceed,
785
+ "before-upload": _vm.beforeUploadForm,
786
+ "on-change": _vm.handleUploadForm,
787
+ "on-remove": _vm.formHandleRemove,
788
+ "on-success": _vm.handleSuccess,
789
+ "on-error": _vm.handleError
790
+ },
791
+ scopedSlots: _vm._u([{
792
+ key: "file",
793
+ fn: function (ref) {
794
+ var file = ref.file;
795
+ return _c("div", {
796
+ staticClass: "upload_file_operation"
797
+ }, [_c("div", {
798
+ staticClass: "upload_file_bg",
799
+ style: "background: url(" + _vm.bgImg(file) + ") no-repeat 50% 50%; background-size: contain;"
800
+ }), _vm._v(" "), _c("span", {
801
+ staticClass: "el-upload-list__item-actions"
802
+ }, [_c("span", {
803
+ staticClass: "el-upload-list__item-preview",
804
+ on: {
805
+ click: function ($event) {
806
+ return _vm.handlePictureCardPreview(file);
807
+ }
808
+ }
809
+ }, [_c("i", {
810
+ staticClass: "el-icon-zoom-in"
811
+ })]), _vm._v(" "), _c("span", {
812
+ staticClass: "el-upload-list__item-delete",
813
+ on: {
814
+ click: function ($event) {
815
+ return _vm.handleDownload(file);
816
+ }
817
+ }
818
+ }, [_c("i", {
819
+ staticClass: "el-icon-download"
820
+ })]), _vm._v(" "), !_vm.fileDisabled ? _c("span", {
821
+ staticClass: "el-upload-list__item-delete",
822
+ on: {
823
+ click: function ($event) {
824
+ return _vm.formHandleRemove(file);
825
+ }
826
+ }
827
+ }, [_c("i", {
828
+ staticClass: "el-icon-delete"
829
+ })]) : _vm._e()]), _vm._v(" "), file.status !== "success" ? _c("span", {
830
+ staticClass: "el-upload-list__item-actions",
831
+ staticStyle: {
832
+ opacity: "1"
833
+ }
834
+ }, [_c("i", {
835
+ staticClass: "el-icon-loading"
836
+ })]) : _vm._e()]);
837
+ }
838
+ }])
839
+ }, [_c("i", {
840
+ staticClass: "el-icon-plus",
841
+ attrs: {
842
+ slot: "default"
843
+ },
844
+ slot: "default"
845
+ })])], 1);
846
+ };
847
+
848
+ var __vue_staticRenderFns__ = [];
849
+ __vue_render__._withStripped = true;
850
+ /* style */
851
+
852
+ const __vue_inject_styles__ = function (inject) {
853
+ if (!inject) return;
854
+ inject("data-v-3f416594_0", {
855
+ source: ".upload_file_box .el-upload-list--picture-card .el-upload-list__item {\n width: 104px;\n height: 104px;\n}\n.upload_file_box .el-upload--picture-card {\n width: 104px;\n height: 104px;\n line-height: 104px;\n}\n.upload_file_box .upload_file_operation {\n width: 100%;\n height: 100%;\n}\n.upload_file_box .upload_file_operation .upload_file_bg {\n width: 100%;\n height: 100%;\n}\n.upload_file_box .disUoloadSty .el-upload--picture-card {\n display: none;\n}\n\n/*# sourceMappingURL=index.vue.map */",
856
+ map: {
857
+ "version": 3,
858
+ "sources": ["/Users/chenlei/HLcode/test/components/UploadFile/index.vue", "index.vue"],
859
+ "names": [],
860
+ "mappings": "AAmXA;EACA,YAAA;EACA,aAAA;AClXA;ADqXA;EACA,YAAA;EACA,aAAA;EACA,kBAAA;ACnXA;ADqXA;EACA,WAAA;EACA,YAAA;ACnXA;ADoXA;EACA,WAAA;EACA,YAAA;AClXA;ADqXA;EACA,aAAA;ACnXA;;AAEA,oCAAoC",
861
+ "file": "index.vue",
862
+ "sourcesContent": ["<template>\n <div class=\"upload_file_box\">\n <div style=\"height: 0; overflow: hidden;\">\n <el-image\n ref=\"previewImg\"\n :src=\"dialogImageUrl\"\n :preview-src-list=\"formFileList.map(item=>bgImg(item))\"\n />\n </div>\n <el-upload\n :class=\"{disUoloadSty:noneBtnImg}\"\n :action=\"apiUrl\"\n list-type=\"picture-card\"\n :limit=\"limit\"\n :multiple=\"multiple\"\n :data=\"formData\"\n :accept=\"fileType.join(',')\"\n :disabled=\"fileDisabled\"\n :file-list=\"formFileList\"\n :on-exceed=\"formHandleExceed\"\n :before-upload=\"beforeUploadForm\"\n :on-change=\"handleUploadForm\"\n :on-remove=\"formHandleRemove\"\n :on-success=\"handleSuccess\"\n :on-error=\"handleError\"\n >\n <i slot=\"default\" class=\"el-icon-plus\" />\n <div slot=\"file\" slot-scope=\"{file}\" class=\"upload_file_operation\">\n <div class=\"upload_file_bg\" :style=\"`background: url(${bgImg(file)}) no-repeat 50% 50%; background-size: contain;`\" />\n <span class=\"el-upload-list__item-actions\">\n <span\n class=\"el-upload-list__item-preview\"\n @click=\"handlePictureCardPreview(file)\"\n >\n <i class=\"el-icon-zoom-in\" />\n </span>\n <span\n class=\"el-upload-list__item-delete\"\n @click=\"handleDownload(file)\"\n >\n <i class=\"el-icon-download\" />\n </span>\n <span\n v-if=\"!fileDisabled\"\n class=\"el-upload-list__item-delete\"\n @click=\"formHandleRemove(file)\"\n >\n <i class=\"el-icon-delete\" />\n </span>\n </span>\n <span v-if=\"file.status !== 'success'\" style=\"opacity: 1;\" class=\"el-upload-list__item-actions\">\n <i class=\"el-icon-loading\"></i>\n </span>\n </div>\n </el-upload>\n </div>\n</template>\n\n<script>\n// import { attachment } from '@/config/api/publicApi'\nimport { mapGetters } from 'vuex'\nimport axios from 'axios'\nimport CSV from './fileImages/CSV.png'\nimport EXCEL from './fileImages/EXCEL.png'\nimport PDF from './fileImages/PDF.png'\nimport PPT from './fileImages/PPT.png'\nimport RAR from './fileImages/RAR.png'\nimport WORD from './fileImages/WORD.png'\nimport ZIP from './fileImages/ZIP.png'\nimport APK from './fileImages/APK.png'\n\nexport default {\n props: {\n limit: { // 限制文件个数\n default: 1,\n type: Number\n },\n multiple: { // 上传多个文件\n default: false,\n type: Boolean\n },\n formMaxSize: { // 限制文件大小\n default: 10, // M\n type: Number\n },\n fileUrl: { // 文件数组\n default: [],\n type: Array\n },\n formData: { // 上传时附带的额外参数\n default: () => {\n return {\n attachmenType: 'VOUCHER'\n }\n },\n type: Object\n },\n fileType: { // 限制选择文件类型\n // default: '.pptx,.csv,.zip,.rar,image/*,application/msexcel,application/msword,application/pdf,application/vnd.openxmlformats-officedocument.spreadsheetml.sheet,application/vnd.openxmlformats-officedocument.wordprocessingml.document, text/plain',\n default: () => {\n return ['.pptx', '.csv', '.zip', '.rar', '.jpg', '.jpeg', '.png', '.doc', '.docx', '.pdf', '.PDF', '.xls', '.xlsx']\n },\n type: Array\n },\n fileDisabled: {\n default: false,\n type: Boolean\n },\n apiUrl: String\n },\n data() {\n return {\n formFileList: [], // 显示上传文件\n dialogImageUrl: '',\n loading: '',\n noneBtnImg: false\n }\n },\n computed: {\n ...mapGetters([\n 'userInfo'\n ])\n },\n watch: {\n fileUrl: {\n deep: true,\n immediate: true,\n handler() {\n this.formFileList = this.fileUrl\n if(this.fileDisabled){\n this.noneBtnImg = true\n }\n }\n }\n },\n methods: {\n // 缩略图展示\n bgImg(file) {\n let type = ''\n const types = {\n IMG: '',\n WORD: WORD,\n EXCEL: EXCEL,\n PDF: PDF,\n CSV: CSV,\n RAR: RAR,\n ZIP: ZIP,\n PPT: PPT,\n APK: APK\n }\n\n if (file.raw) {\n type = this.fileFormat(file.name)\n } else {\n type = this.fileFormat(file.url)\n }\n\n if (type === 'IMG') {\n return file.url\n } else {\n return types[type]\n }\n },\n // 文件格式\n fileFormat(name) {\n const images = 'bmp|jpg|jpeg|png|gif|svg|webp|JPG|JPEG|PNG'\n const word = 'doc|docx|DOC|DOCX'\n const excel = 'xls|xlsx|XLS|XLSX'\n const pdf = 'pdf|PDF'\n const csv = 'csv|CSV'\n const rar = 'rar|RAR'\n const zip = 'zip|ZIP'\n const ppt = 'pptx|PPTX'\n const apk = 'apk|APK'\n\n const pattern_images = new RegExp('.(' + images + ')$')\n const pattern_word = new RegExp('.(' + word + ')$')\n const pattern_excel = new RegExp('.(' + excel + ')$')\n const pattern_pdf = new RegExp('.(' + pdf + ')$')\n const pattern_csv = new RegExp('.(' + csv + ')$')\n const pattern_rar = new RegExp('.(' + rar + ')$')\n const pattern_zip = new RegExp('.(' + zip + ')$')\n const pattern_ppt = new RegExp('.(' + ppt + ')$')\n const pattern_apk = new RegExp('.(' + apk + ')$')\n\n if (name.indexOf('?') > -1) {\n name = name.split('?')[0]\n }\n\n if (pattern_images.test(name)) {\n return 'IMG'\n } else if (pattern_word.test(name)) {\n return 'WORD'\n } else if (pattern_excel.test(name)) {\n return 'EXCEL'\n } else if (pattern_pdf.test(name)) {\n return 'PDF'\n } else if (pattern_csv.test(name)) {\n return 'CSV'\n } else if (pattern_rar.test(name)) {\n return 'RAR'\n } else if (pattern_zip.test(name)) {\n return 'ZIP'\n } else if (pattern_ppt.test(name)) {\n return 'PPT'\n } else if (pattern_apk.test(name)) {\n return 'APK'\n }\n },\n // 开始上传前验证\n beforeUploadForm(file) {\n // 验证文件大小\n if (file.size / 1024 / 1024 > this.formMaxSize) {\n setTimeout(()=>{\n this.$message({\n message: `上传文件 “${file.name}” 大小不能超过${this.formMaxSize}M!`,\n type: 'warning'\n })\n },1)\n return false\n }\n // 中文乱码处理\n // if (file.raw) {\n // let reader = new FileReader(); // 读取文件内容\n // reader.readAsText(file.raw, \"gb2312\"); // 防止中文乱码问题,不加reader.onload方法都不会触发\n // reader.onload = function(e) {\n // this.contentHtml = e.target.result; // txt文本内容,接下来就可以对其进行校验处理了\n // };\n // }\n // 验证文件类型\n if (!this.fileType.includes('.' + file.name.split('.')[1])) {\n setTimeout(()=>{\n this.$message({\n message: `上传文件 “${file.name}” 格式错误!`,\n type: 'warning'\n })\n },1)\n return false\n }\n },\n formHandleRemove(file, formFileList) {\n if (file.status !== 'ready') {\n this.formFileList.splice(this.formFileList.indexOf(file), 1)\n this.noneBtnImg = this.formFileList.length >= this.limit\n }\n },\n handlePictureCardPreview(file) {\n let type, url\n if (file.raw) {\n type = this.fileFormat(file.name)\n url = file.response.data[0].attachmenturl\n } else {\n type = this.fileFormat(file.url)\n url = file.url\n }\n\n if (type === 'IMG') {\n this.dialogImageUrl = file.url\n this.$refs.previewImg.showViewer = true\n } else if (type === 'PDF') {\n window.open('https://www.hellogil.com/web/contractPreview.html?url=' + url.replace('http://', 'https://'))\n } else if (type === 'WORD' || type === 'EXCEL' || type === 'CSV' || type === 'PPT') {\n window.open(`https://www.hellogil.cn:8012/onlinePreview?watermarkTxt=${this.userInfo.userName}${this.userInfo.jobCard}&url=` + url.replace('http://', 'https://'))\n } else {\n this.$message({\n message: '该文件不支持预览!',\n type: 'warning'\n })\n }\n },\n handleDownload(file) {\n console.log(file)\n var name\n if (file.name) {\n name = file.name\n if (!name.indexOf('.') > -1) {\n var a = file.url.split('/')\n var b = a[a.length - 1]\n name = file.name + '.' + b.split('.')[1]\n }\n } else {\n var a = file.url.split('/')\n name = a[a.length - 1]\n }\n axios({\n method: 'post',\n url: process.env.VUE_APP_BASE_API + '/huilianApi/uploader/downloadZipFiles',\n data: 'fileUrls=' + JSON.stringify([{\n imgName: name.replace(/\\&/g, '-').replace(/\\?/g, '-').replace(/\\%/g, '-'),\n dataImg: file.url\n }]),\n responseType: 'blob' // 加上这个是重点\n }).then(res => {\n this.downloadFile(res.data, name)\n })\n },\n downloadFile(data, name) {\n const url = window.URL.createObjectURL(new Blob([data]))\n const link = document.createElement('a')\n link.style.display = 'none'\n link.href = url\n link.setAttribute('download', name)\n document.body.appendChild(link)\n link.click()\n URL.revokeObjectURL(link.href)\n document.body.removeChild(link)\n this.$message({\n message: '下载成功',\n type: 'success'\n })\n },\n // 允许上传文件个数验证\n formHandleExceed(files, formFileList) {\n this.$message.warning(\n `最多上传 ${this.limit} 个文件!`\n )\n },\n // 上传文件\n handleUploadForm(file, fileList) {\n // console.log(file.status)\n // if (file.status === 'ready') {\n // this.loading = this.$loading({\n // lock: true,\n // text: '上传中,请稍候...',\n // spinner: 'el-icon-loading',\n // background: 'rgba(0, 0, 0, 0.7)'\n // })\n // } else {\n // // this.loading.close()\n // }\n },\n // 上传成功\n handleSuccess(response, file, fileList) {\n var num = 0;\n for(var i = 0; i<fileList.length; i++){\n if(fileList[i].status === 'success'){\n num++\n }\n }\n if(num === fileList.length ){\n // this.formFileList = [];\n // for(var i = 0; i<fileList.length; i++){\n // this.formFileList.push(fileList[i])\n // }\n this.formFileList = fileList;\n this.$emit('update:fileUrl',this.formFileList);\n this.noneBtnImg = this.formFileList.length >= this.limit\n }\n \n // if (response.result === 'success') {\n // this.formFileList.push(file)\n // } else {\n // // console.log(response, file, fileList)\n // fileList.splice(fileList.indexOf(file), 1)\n // this.$message.error(\n // response.msg\n // )\n // }\n },\n // 上传失败\n handleError(err, file, fileList) {\n console.log(err)\n // this.loading.close()\n }\n }\n}\n</script>\n\n<style lang=\"scss\">\n.upload_file_box{\n .el-upload-list--picture-card{\n .el-upload-list__item{\n width: 104px;\n height: 104px;\n }\n }\n .el-upload--picture-card{\n width: 104px;\n height: 104px;\n line-height: 104px;\n }\n .upload_file_operation{\n width: 100%;\n height: 100%;\n .upload_file_bg{\n width: 100%;\n height: 100%;\n }\n }\n .disUoloadSty .el-upload--picture-card{\n display:none;\n }\n}\n</style>\n", ".upload_file_box .el-upload-list--picture-card .el-upload-list__item {\n width: 104px;\n height: 104px;\n}\n.upload_file_box .el-upload--picture-card {\n width: 104px;\n height: 104px;\n line-height: 104px;\n}\n.upload_file_box .upload_file_operation {\n width: 100%;\n height: 100%;\n}\n.upload_file_box .upload_file_operation .upload_file_bg {\n width: 100%;\n height: 100%;\n}\n.upload_file_box .disUoloadSty .el-upload--picture-card {\n display: none;\n}\n\n/*# sourceMappingURL=index.vue.map */"]
863
+ },
864
+ media: undefined
865
+ });
866
+ };
867
+ /* scoped */
868
+
869
+
870
+ const __vue_scope_id__ = undefined;
871
+ /* module identifier */
872
+
873
+ const __vue_module_identifier__ = undefined;
874
+ /* functional template */
875
+
876
+ const __vue_is_functional_template__ = false;
877
+ /* style inject SSR */
878
+
879
+ /* style inject shadow dom */
880
+
881
+ const __vue_component__ = /*#__PURE__*/normalizeComponent({
882
+ render: __vue_render__,
883
+ staticRenderFns: __vue_staticRenderFns__
884
+ }, __vue_inject_styles__, __vue_script__, __vue_scope_id__, __vue_is_functional_template__, __vue_module_identifier__, false, createInjector, undefined, undefined);
885
+
886
+ __vue_component__.install = function (Vue) {
887
+ Vue.component(__vue_component__.name, __vue_component__);
888
+ };
889
+
890
+ var version = "1.0.0";
891
+ const components = [__vue_component__$2, __vue_component__$1, __vue_component__];
892
+
893
+ const install = function (Vue) {
894
+ components.forEach(component => {
895
+ Vue.component(component.name, component);
896
+ });
897
+ };
898
+
899
+ if (typeof window !== "undefined" && window.Vue) {
900
+ install(window.Vue);
901
+ }
902
+
903
+ var index = {
904
+ version,
905
+ install
906
+ };
907
+ export { __vue_component__$1 as HelloVue, __vue_component__$2 as MyButton, __vue_component__ as UploadFile, index as default, install };