@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.
- package/lib/bundle.cjs.js +927 -0
- package/lib/bundle.esm.js +907 -0
- package/package.json +56 -0
|
@@ -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 };
|