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