image-list.js 44 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611
  1. exports.ids = [14];
  2. exports.modules = {
  3. /***/ 147:
  4. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  5. "use strict";
  6. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "e", function() { return on; });
  7. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "d", function() { return off; });
  8. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "f", function() { return once; });
  9. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "c", function() { return hasClass; });
  10. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return addClass; });
  11. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "g", function() { return removeClass; });
  12. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "b", function() { return getStyle; });
  13. /* unused harmony export setStyle */
  14. /* unused harmony export isScroll */
  15. /* unused harmony export getScrollContainer */
  16. /* unused harmony export isInContainer */
  17. /* harmony import */ var vue__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(0);
  18. /* harmony import */ var vue__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(vue__WEBPACK_IMPORTED_MODULE_0__);
  19. /* istanbul ignore next */
  20. const isServer = vue__WEBPACK_IMPORTED_MODULE_0___default.a.prototype.$isServer;
  21. const SPECIAL_CHARS_REGEXP = /([\:\-\_]+(.))/g;
  22. const MOZ_HACK_REGEXP = /^moz([A-Z])/;
  23. const ieVersion = isServer ? 0 : Number(document.documentMode);
  24. /* istanbul ignore next */
  25. const trim = function(string) {
  26. return (string || '').replace(/^[\s\uFEFF]+|[\s\uFEFF]+$/g, '');
  27. };
  28. /* istanbul ignore next */
  29. const camelCase = function(name) {
  30. return name.replace(SPECIAL_CHARS_REGEXP, function(_, separator, letter, offset) {
  31. return offset ? letter.toUpperCase() : letter;
  32. }).replace(MOZ_HACK_REGEXP, 'Moz$1');
  33. };
  34. /* istanbul ignore next */
  35. const on = (function() {
  36. if (!isServer && document.addEventListener) {
  37. return function(element, event, handler) {
  38. if (element && event && handler) {
  39. element.addEventListener(event, handler, false);
  40. }
  41. };
  42. } else {
  43. return function(element, event, handler) {
  44. if (element && event && handler) {
  45. element.attachEvent('on' + event, handler);
  46. }
  47. };
  48. }
  49. })();
  50. /* istanbul ignore next */
  51. const off = (function() {
  52. if (!isServer && document.removeEventListener) {
  53. return function(element, event, handler) {
  54. if (element && event) {
  55. element.removeEventListener(event, handler, false);
  56. }
  57. };
  58. } else {
  59. return function(element, event, handler) {
  60. if (element && event) {
  61. element.detachEvent('on' + event, handler);
  62. }
  63. };
  64. }
  65. })();
  66. /* istanbul ignore next */
  67. const once = function(el, event, fn) {
  68. var listener = function() {
  69. if (fn) {
  70. fn.apply(this, arguments);
  71. }
  72. off(el, event, listener);
  73. };
  74. on(el, event, listener);
  75. };
  76. /* istanbul ignore next */
  77. function hasClass(el, cls) {
  78. if (!el || !cls) return false;
  79. if (cls.indexOf(' ') !== -1) throw new Error('className should not contain space.');
  80. if (el.classList) {
  81. return el.classList.contains(cls);
  82. } else {
  83. return (' ' + el.className + ' ').indexOf(' ' + cls + ' ') > -1;
  84. }
  85. };
  86. /* istanbul ignore next */
  87. function addClass(el, cls) {
  88. if (!el) return;
  89. var curClass = el.className;
  90. var classes = (cls || '').split(' ');
  91. for (var i = 0, j = classes.length; i < j; i++) {
  92. var clsName = classes[i];
  93. if (!clsName) continue;
  94. if (el.classList) {
  95. el.classList.add(clsName);
  96. } else if (!hasClass(el, clsName)) {
  97. curClass += ' ' + clsName;
  98. }
  99. }
  100. if (!el.classList) {
  101. el.setAttribute('class', curClass);
  102. }
  103. };
  104. /* istanbul ignore next */
  105. function removeClass(el, cls) {
  106. if (!el || !cls) return;
  107. var classes = cls.split(' ');
  108. var curClass = ' ' + el.className + ' ';
  109. for (var i = 0, j = classes.length; i < j; i++) {
  110. var clsName = classes[i];
  111. if (!clsName) continue;
  112. if (el.classList) {
  113. el.classList.remove(clsName);
  114. } else if (hasClass(el, clsName)) {
  115. curClass = curClass.replace(' ' + clsName + ' ', ' ');
  116. }
  117. }
  118. if (!el.classList) {
  119. el.setAttribute('class', trim(curClass));
  120. }
  121. };
  122. /* istanbul ignore next */
  123. const getStyle = ieVersion < 9 ? function(element, styleName) {
  124. if (isServer) return;
  125. if (!element || !styleName) return null;
  126. styleName = camelCase(styleName);
  127. if (styleName === 'float') {
  128. styleName = 'styleFloat';
  129. }
  130. try {
  131. switch (styleName) {
  132. case 'opacity':
  133. try {
  134. return element.filters.item('alpha').opacity / 100;
  135. } catch (e) {
  136. return 1.0;
  137. }
  138. default:
  139. return (element.style[styleName] || element.currentStyle ? element.currentStyle[styleName] : null);
  140. }
  141. } catch (e) {
  142. return element.style[styleName];
  143. }
  144. } : function(element, styleName) {
  145. if (isServer) return;
  146. if (!element || !styleName) return null;
  147. styleName = camelCase(styleName);
  148. if (styleName === 'float') {
  149. styleName = 'cssFloat';
  150. }
  151. try {
  152. var computed = document.defaultView.getComputedStyle(element, '');
  153. return element.style[styleName] || computed ? computed[styleName] : null;
  154. } catch (e) {
  155. return element.style[styleName];
  156. }
  157. };
  158. /* istanbul ignore next */
  159. function setStyle(element, styleName, value) {
  160. if (!element || !styleName) return;
  161. if (typeof styleName === 'object') {
  162. for (var prop in styleName) {
  163. if (styleName.hasOwnProperty(prop)) {
  164. setStyle(element, prop, styleName[prop]);
  165. }
  166. }
  167. } else {
  168. styleName = camelCase(styleName);
  169. if (styleName === 'opacity' && ieVersion < 9) {
  170. element.style.filter = isNaN(value) ? '' : 'alpha(opacity=' + value * 100 + ')';
  171. } else {
  172. element.style[styleName] = value;
  173. }
  174. }
  175. };
  176. const isScroll = (el, vertical) => {
  177. if (isServer) return;
  178. const determinedDirection = vertical !== null && vertical !== undefined;
  179. const overflow = determinedDirection
  180. ? vertical
  181. ? getStyle(el, 'overflow-y')
  182. : getStyle(el, 'overflow-x')
  183. : getStyle(el, 'overflow');
  184. return overflow.match(/(scroll|auto|overlay)/);
  185. };
  186. const getScrollContainer = (el, vertical) => {
  187. if (isServer) return;
  188. let parent = el;
  189. while (parent) {
  190. if ([window, document, document.documentElement].includes(parent)) {
  191. return window;
  192. }
  193. if (isScroll(parent, vertical)) {
  194. return parent;
  195. }
  196. parent = parent.parentNode;
  197. }
  198. return parent;
  199. };
  200. const isInContainer = (el, container) => {
  201. if (isServer || !el || !container) return false;
  202. const elRect = el.getBoundingClientRect();
  203. let containerRect;
  204. if ([window, document, document.documentElement, null, undefined].includes(container)) {
  205. containerRect = {
  206. top: 0,
  207. right: window.innerWidth,
  208. bottom: window.innerHeight,
  209. left: 0
  210. };
  211. } else {
  212. containerRect = container.getBoundingClientRect();
  213. }
  214. return elRect.top < containerRect.bottom &&
  215. elRect.bottom > containerRect.top &&
  216. elRect.right > containerRect.left &&
  217. elRect.left < containerRect.right;
  218. };
  219. /***/ }),
  220. /***/ 148:
  221. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  222. "use strict";
  223. // EXPORTS
  224. __webpack_require__.d(__webpack_exports__, "a", function() { return /* binding */ isFirefox; });
  225. __webpack_require__.d(__webpack_exports__, "c", function() { return /* binding */ kebabCase; });
  226. __webpack_require__.d(__webpack_exports__, "d", function() { return /* binding */ rafThrottle; });
  227. __webpack_require__.d(__webpack_exports__, "b", function() { return /* binding */ isMac; });
  228. // UNUSED EXPORTS: noop, hasOwn, toObject, getValueByPath, getPropByPath, generateId, valueEquals, escapeRegexpString, arrayFindIndex, arrayFind, coerceTruthyValueToArray, isIE, isEdge, autoprefixer, capitalize, looseEqual, arrayEquals, isEqual, isEmpty, objToArray
  229. // EXTERNAL MODULE: external "vue"
  230. var external_vue_ = __webpack_require__(0);
  231. var external_vue_default = /*#__PURE__*/__webpack_require__.n(external_vue_);
  232. // CONCATENATED MODULE: ./node_modules/element-ui/src/utils/types.js
  233. function isString(obj) {
  234. return Object.prototype.toString.call(obj) === '[object String]';
  235. }
  236. function isObject(obj) {
  237. return Object.prototype.toString.call(obj) === '[object Object]';
  238. }
  239. function isHtmlElement(node) {
  240. return node && node.nodeType === Node.ELEMENT_NODE;
  241. }
  242. /**
  243. * - Inspired:
  244. * https://github.com/jashkenas/underscore/blob/master/modules/isFunction.js
  245. */
  246. let isFunction = (functionToCheck) => {
  247. var getType = {};
  248. return functionToCheck && getType.toString.call(functionToCheck) === '[object Function]';
  249. };
  250. if ( true && typeof Int8Array !== 'object' && (external_vue_default.a.prototype.$isServer || typeof document.childNodes !== 'function')) {
  251. isFunction = function(obj) {
  252. return typeof obj === 'function' || false;
  253. };
  254. }
  255. const isUndefined = (val)=> {
  256. return val === void 0;
  257. };
  258. const isDefined = (val) => {
  259. return val !== undefined && val !== null;
  260. };
  261. // CONCATENATED MODULE: ./node_modules/element-ui/src/utils/util.js
  262. const util_hasOwnProperty = Object.prototype.hasOwnProperty;
  263. function noop() {};
  264. function hasOwn(obj, key) {
  265. return util_hasOwnProperty.call(obj, key);
  266. };
  267. function extend(to, _from) {
  268. for (let key in _from) {
  269. to[key] = _from[key];
  270. }
  271. return to;
  272. };
  273. function toObject(arr) {
  274. var res = {};
  275. for (let i = 0; i < arr.length; i++) {
  276. if (arr[i]) {
  277. extend(res, arr[i]);
  278. }
  279. }
  280. return res;
  281. };
  282. const getValueByPath = function(object, prop) {
  283. prop = prop || '';
  284. const paths = prop.split('.');
  285. let current = object;
  286. let result = null;
  287. for (let i = 0, j = paths.length; i < j; i++) {
  288. const path = paths[i];
  289. if (!current) break;
  290. if (i === j - 1) {
  291. result = current[path];
  292. break;
  293. }
  294. current = current[path];
  295. }
  296. return result;
  297. };
  298. function getPropByPath(obj, path, strict) {
  299. let tempObj = obj;
  300. path = path.replace(/\[(\w+)\]/g, '.$1');
  301. path = path.replace(/^\./, '');
  302. let keyArr = path.split('.');
  303. let i = 0;
  304. for (let len = keyArr.length; i < len - 1; ++i) {
  305. if (!tempObj && !strict) break;
  306. let key = keyArr[i];
  307. if (key in tempObj) {
  308. tempObj = tempObj[key];
  309. } else {
  310. if (strict) {
  311. throw new Error('please transfer a valid prop path to form item!');
  312. }
  313. break;
  314. }
  315. }
  316. return {
  317. o: tempObj,
  318. k: keyArr[i],
  319. v: tempObj ? tempObj[keyArr[i]] : null
  320. };
  321. };
  322. const generateId = function() {
  323. return Math.floor(Math.random() * 10000);
  324. };
  325. const valueEquals = (a, b) => {
  326. // see: https://stackoverflow.com/questions/3115982/how-to-check-if-two-arrays-are-equal-with-javascript
  327. if (a === b) return true;
  328. if (!(a instanceof Array)) return false;
  329. if (!(b instanceof Array)) return false;
  330. if (a.length !== b.length) return false;
  331. for (let i = 0; i !== a.length; ++i) {
  332. if (a[i] !== b[i]) return false;
  333. }
  334. return true;
  335. };
  336. const escapeRegexpString = (value = '') => String(value).replace(/[|\\{}()[\]^$+*?.]/g, '\\$&');
  337. // TODO: use native Array.find, Array.findIndex when IE support is dropped
  338. const arrayFindIndex = function(arr, pred) {
  339. for (let i = 0; i !== arr.length; ++i) {
  340. if (pred(arr[i])) {
  341. return i;
  342. }
  343. }
  344. return -1;
  345. };
  346. const arrayFind = function(arr, pred) {
  347. const idx = arrayFindIndex(arr, pred);
  348. return idx !== -1 ? arr[idx] : undefined;
  349. };
  350. // coerce truthy value to array
  351. const coerceTruthyValueToArray = function(val) {
  352. if (Array.isArray(val)) {
  353. return val;
  354. } else if (val) {
  355. return [val];
  356. } else {
  357. return [];
  358. }
  359. };
  360. const isIE = function() {
  361. return !external_vue_default.a.prototype.$isServer && !isNaN(Number(document.documentMode));
  362. };
  363. const isEdge = function() {
  364. return !external_vue_default.a.prototype.$isServer && navigator.userAgent.indexOf('Edge') > -1;
  365. };
  366. const isFirefox = function() {
  367. return !external_vue_default.a.prototype.$isServer && !!window.navigator.userAgent.match(/firefox/i);
  368. };
  369. const autoprefixer = function(style) {
  370. if (typeof style !== 'object') return style;
  371. const rules = ['transform', 'transition', 'animation'];
  372. const prefixes = ['ms-', 'webkit-'];
  373. rules.forEach(rule => {
  374. const value = style[rule];
  375. if (rule && value) {
  376. prefixes.forEach(prefix => {
  377. style[prefix + rule] = value;
  378. });
  379. }
  380. });
  381. return style;
  382. };
  383. const kebabCase = function(str) {
  384. const hyphenateRE = /([^-])([A-Z])/g;
  385. return str
  386. .replace(hyphenateRE, '$1-$2')
  387. .replace(hyphenateRE, '$1-$2')
  388. .toLowerCase();
  389. };
  390. const capitalize = function(str) {
  391. if (!isString(str)) return str;
  392. return str.charAt(0).toUpperCase() + str.slice(1);
  393. };
  394. const looseEqual = function(a, b) {
  395. const isObjectA = isObject(a);
  396. const isObjectB = isObject(b);
  397. if (isObjectA && isObjectB) {
  398. return JSON.stringify(a) === JSON.stringify(b);
  399. } else if (!isObjectA && !isObjectB) {
  400. return String(a) === String(b);
  401. } else {
  402. return false;
  403. }
  404. };
  405. const arrayEquals = function(arrayA, arrayB) {
  406. arrayA = arrayA || [];
  407. arrayB = arrayB || [];
  408. if (arrayA.length !== arrayB.length) {
  409. return false;
  410. }
  411. for (let i = 0; i < arrayA.length; i++) {
  412. if (!looseEqual(arrayA[i], arrayB[i])) {
  413. return false;
  414. }
  415. }
  416. return true;
  417. };
  418. const isEqual = function(value1, value2) {
  419. if (Array.isArray(value1) && Array.isArray(value2)) {
  420. return arrayEquals(value1, value2);
  421. }
  422. return looseEqual(value1, value2);
  423. };
  424. const isEmpty = function(val) {
  425. // null or undefined
  426. if (val == null) return true;
  427. if (typeof val === 'boolean') return false;
  428. if (typeof val === 'number') return !val;
  429. if (val instanceof Error) return val.message === '';
  430. switch (Object.prototype.toString.call(val)) {
  431. // String or Array
  432. case '[object String]':
  433. case '[object Array]':
  434. return !val.length;
  435. // Map or Set or File
  436. case '[object File]':
  437. case '[object Map]':
  438. case '[object Set]': {
  439. return !val.size;
  440. }
  441. // Plain Object
  442. case '[object Object]': {
  443. return !Object.keys(val).length;
  444. }
  445. }
  446. return false;
  447. };
  448. function rafThrottle(fn) {
  449. let locked = false;
  450. return function(...args) {
  451. if (locked) return;
  452. locked = true;
  453. window.requestAnimationFrame(_ => {
  454. fn.apply(this, args);
  455. locked = false;
  456. });
  457. };
  458. }
  459. function objToArray(obj) {
  460. if (Array.isArray(obj)) {
  461. return obj;
  462. }
  463. return isEmpty(obj) ? [] : [obj];
  464. }
  465. const isMac = function() {
  466. return !external_vue_default.a.prototype.$isServer && /macintosh|mac os x/i.test(navigator.userAgent);
  467. };
  468. /***/ }),
  469. /***/ 149:
  470. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  471. "use strict";
  472. /* harmony default export */ __webpack_exports__["a"] = (function(target) {
  473. for (let i = 1, j = arguments.length; i < j; i++) {
  474. let source = arguments[i] || {};
  475. for (let prop in source) {
  476. if (source.hasOwnProperty(prop)) {
  477. let value = source[prop];
  478. if (value !== undefined) {
  479. target[prop] = value;
  480. }
  481. }
  482. }
  483. }
  484. return target;
  485. });;
  486. /***/ }),
  487. /***/ 157:
  488. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  489. "use strict";
  490. // CONCATENATED MODULE: ./node_modules/babel-loader/lib??ref--2-0!./node_modules/vue-loader/lib/loaders/templateLoader.js??ref--6!./node_modules/@nuxt/components/dist/loader.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./node_modules/element-ui/packages/image/src/image-viewer.vue?vue&type=template&id=44a7b0fb
  491. var render = function render() {
  492. var _vm = this,
  493. _c = _vm._self._c;
  494. return _c('transition', {
  495. attrs: {
  496. "name": "viewer-fade"
  497. }
  498. }, [_c('div', {
  499. ref: "el-image-viewer__wrapper",
  500. staticClass: "el-image-viewer__wrapper",
  501. style: {
  502. 'z-index': _vm.viewerZIndex
  503. },
  504. attrs: {
  505. "tabindex": "-1"
  506. }
  507. }, [_c('div', {
  508. staticClass: "el-image-viewer__mask",
  509. on: {
  510. "click": function ($event) {
  511. if ($event.target !== $event.currentTarget) return null;
  512. return _vm.handleMaskClick.apply(null, arguments);
  513. }
  514. }
  515. }), _vm._v(" "), _c('span', {
  516. staticClass: "el-image-viewer__btn el-image-viewer__close",
  517. on: {
  518. "click": _vm.hide
  519. }
  520. }, [_c('i', {
  521. staticClass: "el-icon-close"
  522. })]), _vm._v(" "), !_vm.isSingle ? [_c('span', {
  523. staticClass: "el-image-viewer__btn el-image-viewer__prev",
  524. class: {
  525. 'is-disabled': !_vm.infinite && _vm.isFirst
  526. },
  527. on: {
  528. "click": _vm.prev
  529. }
  530. }, [_c('i', {
  531. staticClass: "el-icon-arrow-left"
  532. })]), _vm._v(" "), _c('span', {
  533. staticClass: "el-image-viewer__btn el-image-viewer__next",
  534. class: {
  535. 'is-disabled': !_vm.infinite && _vm.isLast
  536. },
  537. on: {
  538. "click": _vm.next
  539. }
  540. }, [_c('i', {
  541. staticClass: "el-icon-arrow-right"
  542. })])] : _vm._e(), _vm._v(" "), _c('div', {
  543. staticClass: "el-image-viewer__btn el-image-viewer__actions"
  544. }, [_c('div', {
  545. staticClass: "el-image-viewer__actions__inner"
  546. }, [_c('i', {
  547. staticClass: "el-icon-zoom-out",
  548. on: {
  549. "click": function ($event) {
  550. return _vm.handleActions('zoomOut');
  551. }
  552. }
  553. }), _vm._v(" "), _c('i', {
  554. staticClass: "el-icon-zoom-in",
  555. on: {
  556. "click": function ($event) {
  557. return _vm.handleActions('zoomIn');
  558. }
  559. }
  560. }), _vm._v(" "), _c('i', {
  561. staticClass: "el-image-viewer__actions__divider"
  562. }), _vm._v(" "), _c('i', {
  563. class: _vm.mode.icon,
  564. on: {
  565. "click": _vm.toggleMode
  566. }
  567. }), _vm._v(" "), _c('i', {
  568. staticClass: "el-image-viewer__actions__divider"
  569. }), _vm._v(" "), _c('i', {
  570. staticClass: "el-icon-refresh-left",
  571. on: {
  572. "click": function ($event) {
  573. return _vm.handleActions('anticlocelise');
  574. }
  575. }
  576. }), _vm._v(" "), _c('i', {
  577. staticClass: "el-icon-refresh-right",
  578. on: {
  579. "click": function ($event) {
  580. return _vm.handleActions('clocelise');
  581. }
  582. }
  583. })])]), _vm._v(" "), _c('div', {
  584. staticClass: "el-image-viewer__canvas"
  585. }, _vm._l(_vm.urlList, function (url, i) {
  586. return i === _vm.index ? _c('img', {
  587. key: url,
  588. ref: "img",
  589. refInFor: true,
  590. staticClass: "el-image-viewer__img",
  591. style: _vm.imgStyle,
  592. attrs: {
  593. "src": _vm.currentImg
  594. },
  595. on: {
  596. "load": _vm.handleImgLoad,
  597. "error": _vm.handleImgError,
  598. "mousedown": _vm.handleMouseDown
  599. }
  600. }) : _vm._e();
  601. }), 0)], 2)]);
  602. };
  603. var staticRenderFns = [];
  604. // CONCATENATED MODULE: ./node_modules/element-ui/packages/image/src/image-viewer.vue?vue&type=template&id=44a7b0fb
  605. // EXTERNAL MODULE: ./node_modules/element-ui/src/utils/dom.js
  606. var utils_dom = __webpack_require__(147);
  607. // EXTERNAL MODULE: ./node_modules/element-ui/src/utils/util.js + 1 modules
  608. var util = __webpack_require__(148);
  609. // EXTERNAL MODULE: external "vue"
  610. var external_vue_ = __webpack_require__(0);
  611. var external_vue_default = /*#__PURE__*/__webpack_require__.n(external_vue_);
  612. // EXTERNAL MODULE: ./node_modules/element-ui/src/utils/merge.js
  613. var merge = __webpack_require__(149);
  614. // CONCATENATED MODULE: ./node_modules/element-ui/src/utils/popup/popup-manager.js
  615. let hasModal = false;
  616. let hasInitZIndex = false;
  617. let popup_manager_zIndex;
  618. const getModal = function() {
  619. if (external_vue_default.a.prototype.$isServer) return;
  620. let modalDom = PopupManager.modalDom;
  621. if (modalDom) {
  622. hasModal = true;
  623. } else {
  624. hasModal = false;
  625. modalDom = document.createElement('div');
  626. PopupManager.modalDom = modalDom;
  627. modalDom.addEventListener('touchmove', function(event) {
  628. event.preventDefault();
  629. event.stopPropagation();
  630. });
  631. modalDom.addEventListener('click', function() {
  632. PopupManager.doOnModalClick && PopupManager.doOnModalClick();
  633. });
  634. }
  635. return modalDom;
  636. };
  637. const instances = {};
  638. const PopupManager = {
  639. modalFade: true,
  640. getInstance: function(id) {
  641. return instances[id];
  642. },
  643. register: function(id, instance) {
  644. if (id && instance) {
  645. instances[id] = instance;
  646. }
  647. },
  648. deregister: function(id) {
  649. if (id) {
  650. instances[id] = null;
  651. delete instances[id];
  652. }
  653. },
  654. nextZIndex: function() {
  655. return PopupManager.zIndex++;
  656. },
  657. modalStack: [],
  658. doOnModalClick: function() {
  659. const topItem = PopupManager.modalStack[PopupManager.modalStack.length - 1];
  660. if (!topItem) return;
  661. const instance = PopupManager.getInstance(topItem.id);
  662. if (instance && instance.closeOnClickModal) {
  663. instance.close();
  664. }
  665. },
  666. openModal: function(id, zIndex, dom, modalClass, modalFade) {
  667. if (external_vue_default.a.prototype.$isServer) return;
  668. if (!id || zIndex === undefined) return;
  669. this.modalFade = modalFade;
  670. const modalStack = this.modalStack;
  671. for (let i = 0, j = modalStack.length; i < j; i++) {
  672. const item = modalStack[i];
  673. if (item.id === id) {
  674. return;
  675. }
  676. }
  677. const modalDom = getModal();
  678. Object(utils_dom["a" /* addClass */])(modalDom, 'v-modal');
  679. if (this.modalFade && !hasModal) {
  680. Object(utils_dom["a" /* addClass */])(modalDom, 'v-modal-enter');
  681. }
  682. if (modalClass) {
  683. let classArr = modalClass.trim().split(/\s+/);
  684. classArr.forEach(item => Object(utils_dom["a" /* addClass */])(modalDom, item));
  685. }
  686. setTimeout(() => {
  687. Object(utils_dom["g" /* removeClass */])(modalDom, 'v-modal-enter');
  688. }, 200);
  689. if (dom && dom.parentNode && dom.parentNode.nodeType !== 11) {
  690. dom.parentNode.appendChild(modalDom);
  691. } else {
  692. document.body.appendChild(modalDom);
  693. }
  694. if (zIndex) {
  695. modalDom.style.zIndex = zIndex;
  696. }
  697. modalDom.tabIndex = 0;
  698. modalDom.style.display = '';
  699. this.modalStack.push({ id: id, zIndex: zIndex, modalClass: modalClass });
  700. },
  701. closeModal: function(id) {
  702. const modalStack = this.modalStack;
  703. const modalDom = getModal();
  704. if (modalStack.length > 0) {
  705. const topItem = modalStack[modalStack.length - 1];
  706. if (topItem.id === id) {
  707. if (topItem.modalClass) {
  708. let classArr = topItem.modalClass.trim().split(/\s+/);
  709. classArr.forEach(item => Object(utils_dom["g" /* removeClass */])(modalDom, item));
  710. }
  711. modalStack.pop();
  712. if (modalStack.length > 0) {
  713. modalDom.style.zIndex = modalStack[modalStack.length - 1].zIndex;
  714. }
  715. } else {
  716. for (let i = modalStack.length - 1; i >= 0; i--) {
  717. if (modalStack[i].id === id) {
  718. modalStack.splice(i, 1);
  719. break;
  720. }
  721. }
  722. }
  723. }
  724. if (modalStack.length === 0) {
  725. if (this.modalFade) {
  726. Object(utils_dom["a" /* addClass */])(modalDom, 'v-modal-leave');
  727. }
  728. setTimeout(() => {
  729. if (modalStack.length === 0) {
  730. if (modalDom.parentNode) modalDom.parentNode.removeChild(modalDom);
  731. modalDom.style.display = 'none';
  732. PopupManager.modalDom = undefined;
  733. }
  734. Object(utils_dom["g" /* removeClass */])(modalDom, 'v-modal-leave');
  735. }, 200);
  736. }
  737. }
  738. };
  739. Object.defineProperty(PopupManager, 'zIndex', {
  740. configurable: true,
  741. get() {
  742. if (!hasInitZIndex) {
  743. popup_manager_zIndex = popup_manager_zIndex || (external_vue_default.a.prototype.$ELEMENT || {}).zIndex || 2000;
  744. hasInitZIndex = true;
  745. }
  746. return popup_manager_zIndex;
  747. },
  748. set(value) {
  749. popup_manager_zIndex = value;
  750. }
  751. });
  752. const getTopPopup = function() {
  753. if (external_vue_default.a.prototype.$isServer) return;
  754. if (PopupManager.modalStack.length > 0) {
  755. const topPopup = PopupManager.modalStack[PopupManager.modalStack.length - 1];
  756. if (!topPopup) return;
  757. const instance = PopupManager.getInstance(topPopup.id);
  758. return instance;
  759. }
  760. };
  761. if (!external_vue_default.a.prototype.$isServer) {
  762. // handle `esc` key when the popup is shown
  763. window.addEventListener('keydown', function(event) {
  764. if (event.keyCode === 27) {
  765. const topPopup = getTopPopup();
  766. if (topPopup && topPopup.closeOnPressEscape) {
  767. topPopup.handleClose
  768. ? topPopup.handleClose()
  769. : (topPopup.handleAction ? topPopup.handleAction('cancel') : topPopup.close());
  770. }
  771. }
  772. });
  773. }
  774. /* harmony default export */ var popup_manager = (PopupManager);
  775. // CONCATENATED MODULE: ./node_modules/element-ui/src/utils/scrollbar-width.js
  776. let scrollBarWidth;
  777. /* harmony default export */ var scrollbar_width = (function() {
  778. if (external_vue_default.a.prototype.$isServer) return 0;
  779. if (scrollBarWidth !== undefined) return scrollBarWidth;
  780. const outer = document.createElement('div');
  781. outer.className = 'el-scrollbar__wrap';
  782. outer.style.visibility = 'hidden';
  783. outer.style.width = '100px';
  784. outer.style.position = 'absolute';
  785. outer.style.top = '-9999px';
  786. document.body.appendChild(outer);
  787. const widthNoScroll = outer.offsetWidth;
  788. outer.style.overflow = 'scroll';
  789. const inner = document.createElement('div');
  790. inner.style.width = '100%';
  791. outer.appendChild(inner);
  792. const widthWithScroll = inner.offsetWidth;
  793. outer.parentNode.removeChild(outer);
  794. scrollBarWidth = widthNoScroll - widthWithScroll;
  795. return scrollBarWidth;
  796. });;
  797. // CONCATENATED MODULE: ./node_modules/element-ui/src/utils/popup/index.js
  798. let idSeed = 1;
  799. let popup_scrollBarWidth;
  800. /* harmony default export */ var popup = ({
  801. props: {
  802. visible: {
  803. type: Boolean,
  804. default: false
  805. },
  806. openDelay: {},
  807. closeDelay: {},
  808. zIndex: {},
  809. modal: {
  810. type: Boolean,
  811. default: false
  812. },
  813. modalFade: {
  814. type: Boolean,
  815. default: true
  816. },
  817. modalClass: {},
  818. modalAppendToBody: {
  819. type: Boolean,
  820. default: false
  821. },
  822. lockScroll: {
  823. type: Boolean,
  824. default: true
  825. },
  826. closeOnPressEscape: {
  827. type: Boolean,
  828. default: false
  829. },
  830. closeOnClickModal: {
  831. type: Boolean,
  832. default: false
  833. }
  834. },
  835. beforeMount() {
  836. this._popupId = 'popup-' + idSeed++;
  837. popup_manager.register(this._popupId, this);
  838. },
  839. beforeDestroy() {
  840. popup_manager.deregister(this._popupId);
  841. popup_manager.closeModal(this._popupId);
  842. this.restoreBodyStyle();
  843. },
  844. data() {
  845. return {
  846. opened: false,
  847. bodyPaddingRight: null,
  848. computedBodyPaddingRight: 0,
  849. withoutHiddenClass: true,
  850. rendered: false
  851. };
  852. },
  853. watch: {
  854. visible(val) {
  855. if (val) {
  856. if (this._opening) return;
  857. if (!this.rendered) {
  858. this.rendered = true;
  859. external_vue_default.a.nextTick(() => {
  860. this.open();
  861. });
  862. } else {
  863. this.open();
  864. }
  865. } else {
  866. this.close();
  867. }
  868. }
  869. },
  870. methods: {
  871. open(options) {
  872. if (!this.rendered) {
  873. this.rendered = true;
  874. }
  875. const props = Object(merge["a" /* default */])({}, this.$props || this, options);
  876. if (this._closeTimer) {
  877. clearTimeout(this._closeTimer);
  878. this._closeTimer = null;
  879. }
  880. clearTimeout(this._openTimer);
  881. const openDelay = Number(props.openDelay);
  882. if (openDelay > 0) {
  883. this._openTimer = setTimeout(() => {
  884. this._openTimer = null;
  885. this.doOpen(props);
  886. }, openDelay);
  887. } else {
  888. this.doOpen(props);
  889. }
  890. },
  891. doOpen(props) {
  892. if (this.$isServer) return;
  893. if (this.willOpen && !this.willOpen()) return;
  894. if (this.opened) return;
  895. this._opening = true;
  896. const dom = this.$el;
  897. const modal = props.modal;
  898. const zIndex = props.zIndex;
  899. if (zIndex) {
  900. popup_manager.zIndex = zIndex;
  901. }
  902. if (modal) {
  903. if (this._closing) {
  904. popup_manager.closeModal(this._popupId);
  905. this._closing = false;
  906. }
  907. popup_manager.openModal(this._popupId, popup_manager.nextZIndex(), this.modalAppendToBody ? undefined : dom, props.modalClass, props.modalFade);
  908. if (props.lockScroll) {
  909. this.withoutHiddenClass = !Object(utils_dom["c" /* hasClass */])(document.body, 'el-popup-parent--hidden');
  910. if (this.withoutHiddenClass) {
  911. this.bodyPaddingRight = document.body.style.paddingRight;
  912. this.computedBodyPaddingRight = parseInt(Object(utils_dom["b" /* getStyle */])(document.body, 'paddingRight'), 10);
  913. }
  914. popup_scrollBarWidth = scrollbar_width();
  915. let bodyHasOverflow = document.documentElement.clientHeight < document.body.scrollHeight;
  916. let bodyOverflowY = Object(utils_dom["b" /* getStyle */])(document.body, 'overflowY');
  917. if (popup_scrollBarWidth > 0 && (bodyHasOverflow || bodyOverflowY === 'scroll') && this.withoutHiddenClass) {
  918. document.body.style.paddingRight = this.computedBodyPaddingRight + popup_scrollBarWidth + 'px';
  919. }
  920. Object(utils_dom["a" /* addClass */])(document.body, 'el-popup-parent--hidden');
  921. }
  922. }
  923. if (getComputedStyle(dom).position === 'static') {
  924. dom.style.position = 'absolute';
  925. }
  926. dom.style.zIndex = popup_manager.nextZIndex();
  927. this.opened = true;
  928. this.onOpen && this.onOpen();
  929. this.doAfterOpen();
  930. },
  931. doAfterOpen() {
  932. this._opening = false;
  933. },
  934. close() {
  935. if (this.willClose && !this.willClose()) return;
  936. if (this._openTimer !== null) {
  937. clearTimeout(this._openTimer);
  938. this._openTimer = null;
  939. }
  940. clearTimeout(this._closeTimer);
  941. const closeDelay = Number(this.closeDelay);
  942. if (closeDelay > 0) {
  943. this._closeTimer = setTimeout(() => {
  944. this._closeTimer = null;
  945. this.doClose();
  946. }, closeDelay);
  947. } else {
  948. this.doClose();
  949. }
  950. },
  951. doClose() {
  952. this._closing = true;
  953. this.onClose && this.onClose();
  954. if (this.lockScroll) {
  955. setTimeout(this.restoreBodyStyle, 200);
  956. }
  957. this.opened = false;
  958. this.doAfterClose();
  959. },
  960. doAfterClose() {
  961. popup_manager.closeModal(this._popupId);
  962. this._closing = false;
  963. },
  964. restoreBodyStyle() {
  965. if (this.modal && this.withoutHiddenClass) {
  966. document.body.style.paddingRight = this.bodyPaddingRight;
  967. Object(utils_dom["g" /* removeClass */])(document.body, 'el-popup-parent--hidden');
  968. }
  969. this.withoutHiddenClass = true;
  970. }
  971. }
  972. });
  973. // CONCATENATED MODULE: ./node_modules/babel-loader/lib??ref--2-0!./node_modules/@nuxt/components/dist/loader.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./node_modules/element-ui/packages/image/src/image-viewer.vue?vue&type=script&lang=js
  974. const Mode = {
  975. CONTAIN: {
  976. name: 'contain',
  977. icon: 'el-icon-full-screen'
  978. },
  979. ORIGINAL: {
  980. name: 'original',
  981. icon: 'el-icon-c-scale-to-original'
  982. }
  983. };
  984. const mousewheelEventName = Object(util["a" /* isFirefox */])() ? 'DOMMouseScroll' : 'mousewheel';
  985. /* harmony default export */ var image_viewervue_type_script_lang_js = ({
  986. name: 'elImageViewer',
  987. props: {
  988. urlList: {
  989. type: Array,
  990. default: () => []
  991. },
  992. zIndex: {
  993. type: Number,
  994. default: 2000
  995. },
  996. onSwitch: {
  997. type: Function,
  998. default: () => {}
  999. },
  1000. onClose: {
  1001. type: Function,
  1002. default: () => {}
  1003. },
  1004. initialIndex: {
  1005. type: Number,
  1006. default: 0
  1007. },
  1008. appendToBody: {
  1009. type: Boolean,
  1010. default: true
  1011. },
  1012. maskClosable: {
  1013. type: Boolean,
  1014. default: true
  1015. }
  1016. },
  1017. data() {
  1018. return {
  1019. index: this.initialIndex,
  1020. isShow: false,
  1021. infinite: true,
  1022. loading: false,
  1023. mode: Mode.CONTAIN,
  1024. transform: {
  1025. scale: 1,
  1026. deg: 0,
  1027. offsetX: 0,
  1028. offsetY: 0,
  1029. enableTransition: false
  1030. }
  1031. };
  1032. },
  1033. computed: {
  1034. isSingle() {
  1035. return this.urlList.length <= 1;
  1036. },
  1037. isFirst() {
  1038. return this.index === 0;
  1039. },
  1040. isLast() {
  1041. return this.index === this.urlList.length - 1;
  1042. },
  1043. currentImg() {
  1044. return this.urlList[this.index];
  1045. },
  1046. imgStyle() {
  1047. const {
  1048. scale,
  1049. deg,
  1050. offsetX,
  1051. offsetY,
  1052. enableTransition
  1053. } = this.transform;
  1054. const style = {
  1055. transform: `scale(${scale}) rotate(${deg}deg)`,
  1056. transition: enableTransition ? 'transform .3s' : '',
  1057. 'margin-left': `${offsetX}px`,
  1058. 'margin-top': `${offsetY}px`
  1059. };
  1060. if (this.mode === Mode.CONTAIN) {
  1061. style.maxWidth = style.maxHeight = '100%';
  1062. }
  1063. return style;
  1064. },
  1065. viewerZIndex() {
  1066. const nextZIndex = popup_manager.nextZIndex();
  1067. return this.zIndex > nextZIndex ? this.zIndex : nextZIndex;
  1068. }
  1069. },
  1070. watch: {
  1071. index: {
  1072. handler: function (val) {
  1073. this.reset();
  1074. this.onSwitch(val);
  1075. }
  1076. },
  1077. currentImg(val) {
  1078. this.$nextTick(_ => {
  1079. const $img = this.$refs.img[0];
  1080. if (!$img.complete) {
  1081. this.loading = true;
  1082. }
  1083. });
  1084. }
  1085. },
  1086. methods: {
  1087. hide() {
  1088. this.deviceSupportUninstall();
  1089. this.onClose();
  1090. },
  1091. deviceSupportInstall() {
  1092. this._keyDownHandler = e => {
  1093. e.stopPropagation();
  1094. const keyCode = e.keyCode;
  1095. switch (keyCode) {
  1096. // ESC
  1097. case 27:
  1098. this.hide();
  1099. break;
  1100. // SPACE
  1101. case 32:
  1102. this.toggleMode();
  1103. break;
  1104. // LEFT_ARROW
  1105. case 37:
  1106. this.prev();
  1107. break;
  1108. // UP_ARROW
  1109. case 38:
  1110. this.handleActions('zoomIn');
  1111. break;
  1112. // RIGHT_ARROW
  1113. case 39:
  1114. this.next();
  1115. break;
  1116. // DOWN_ARROW
  1117. case 40:
  1118. this.handleActions('zoomOut');
  1119. break;
  1120. }
  1121. };
  1122. this._mouseWheelHandler = Object(util["d" /* rafThrottle */])(e => {
  1123. const delta = e.wheelDelta ? e.wheelDelta : -e.detail;
  1124. if (delta > 0) {
  1125. this.handleActions('zoomIn', {
  1126. zoomRate: 0.015,
  1127. enableTransition: false
  1128. });
  1129. } else {
  1130. this.handleActions('zoomOut', {
  1131. zoomRate: 0.015,
  1132. enableTransition: false
  1133. });
  1134. }
  1135. });
  1136. Object(utils_dom["e" /* on */])(document, 'keydown', this._keyDownHandler);
  1137. Object(utils_dom["e" /* on */])(document, mousewheelEventName, this._mouseWheelHandler);
  1138. },
  1139. deviceSupportUninstall() {
  1140. Object(utils_dom["d" /* off */])(document, 'keydown', this._keyDownHandler);
  1141. Object(utils_dom["d" /* off */])(document, mousewheelEventName, this._mouseWheelHandler);
  1142. this._keyDownHandler = null;
  1143. this._mouseWheelHandler = null;
  1144. },
  1145. handleImgLoad(e) {
  1146. this.loading = false;
  1147. },
  1148. handleImgError(e) {
  1149. this.loading = false;
  1150. e.target.alt = '加载失败';
  1151. },
  1152. handleMouseDown(e) {
  1153. if (this.loading || e.button !== 0) return;
  1154. const {
  1155. offsetX,
  1156. offsetY
  1157. } = this.transform;
  1158. const startX = e.pageX;
  1159. const startY = e.pageY;
  1160. this._dragHandler = Object(util["d" /* rafThrottle */])(ev => {
  1161. this.transform.offsetX = offsetX + ev.pageX - startX;
  1162. this.transform.offsetY = offsetY + ev.pageY - startY;
  1163. });
  1164. Object(utils_dom["e" /* on */])(document, 'mousemove', this._dragHandler);
  1165. Object(utils_dom["e" /* on */])(document, 'mouseup', ev => {
  1166. Object(utils_dom["d" /* off */])(document, 'mousemove', this._dragHandler);
  1167. });
  1168. e.preventDefault();
  1169. },
  1170. handleMaskClick() {
  1171. if (this.maskClosable) {
  1172. this.hide();
  1173. }
  1174. },
  1175. reset() {
  1176. this.transform = {
  1177. scale: 1,
  1178. deg: 0,
  1179. offsetX: 0,
  1180. offsetY: 0,
  1181. enableTransition: false
  1182. };
  1183. },
  1184. toggleMode() {
  1185. if (this.loading) return;
  1186. const modeNames = Object.keys(Mode);
  1187. const modeValues = Object.values(Mode);
  1188. const index = modeValues.indexOf(this.mode);
  1189. const nextIndex = (index + 1) % modeNames.length;
  1190. this.mode = Mode[modeNames[nextIndex]];
  1191. this.reset();
  1192. },
  1193. prev() {
  1194. if (this.isFirst && !this.infinite) return;
  1195. const len = this.urlList.length;
  1196. this.index = (this.index - 1 + len) % len;
  1197. },
  1198. next() {
  1199. if (this.isLast && !this.infinite) return;
  1200. const len = this.urlList.length;
  1201. this.index = (this.index + 1) % len;
  1202. },
  1203. handleActions(action, options = {}) {
  1204. if (this.loading) return;
  1205. const {
  1206. zoomRate,
  1207. rotateDeg,
  1208. enableTransition
  1209. } = {
  1210. zoomRate: 0.2,
  1211. rotateDeg: 90,
  1212. enableTransition: true,
  1213. ...options
  1214. };
  1215. const {
  1216. transform
  1217. } = this;
  1218. switch (action) {
  1219. case 'zoomOut':
  1220. if (transform.scale > 0.2) {
  1221. transform.scale = parseFloat((transform.scale - zoomRate).toFixed(3));
  1222. }
  1223. break;
  1224. case 'zoomIn':
  1225. transform.scale = parseFloat((transform.scale + zoomRate).toFixed(3));
  1226. break;
  1227. case 'clocelise':
  1228. transform.deg += rotateDeg;
  1229. break;
  1230. case 'anticlocelise':
  1231. transform.deg -= rotateDeg;
  1232. break;
  1233. }
  1234. transform.enableTransition = enableTransition;
  1235. }
  1236. },
  1237. mounted() {
  1238. this.deviceSupportInstall();
  1239. if (this.appendToBody) {
  1240. document.body.appendChild(this.$el);
  1241. }
  1242. // add tabindex then wrapper can be focusable via Javascript
  1243. // focus wrapper so arrow key can't cause inner scroll behavior underneath
  1244. this.$refs['el-image-viewer__wrapper'].focus();
  1245. },
  1246. destroyed() {
  1247. // if appendToBody is true, remove DOM node after destroy
  1248. if (this.appendToBody && this.$el && this.$el.parentNode) {
  1249. this.$el.parentNode.removeChild(this.$el);
  1250. }
  1251. }
  1252. });
  1253. // CONCATENATED MODULE: ./node_modules/element-ui/packages/image/src/image-viewer.vue?vue&type=script&lang=js
  1254. /* harmony default export */ var src_image_viewervue_type_script_lang_js = (image_viewervue_type_script_lang_js);
  1255. // EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js
  1256. var componentNormalizer = __webpack_require__(2);
  1257. // CONCATENATED MODULE: ./node_modules/element-ui/packages/image/src/image-viewer.vue
  1258. /* normalize component */
  1259. var component = Object(componentNormalizer["a" /* default */])(
  1260. src_image_viewervue_type_script_lang_js,
  1261. render,
  1262. staticRenderFns,
  1263. false,
  1264. null,
  1265. null,
  1266. "17d24eb5"
  1267. )
  1268. /* harmony default export */ var image_viewer = __webpack_exports__["a"] = (component.exports);
  1269. /***/ }),
  1270. /***/ 165:
  1271. /***/ (function(module, exports) {
  1272. // Exports
  1273. module.exports = {
  1274. };
  1275. /***/ }),
  1276. /***/ 186:
  1277. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  1278. "use strict";
  1279. __webpack_require__.r(__webpack_exports__);
  1280. /* harmony import */ var _node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_imageList_vue_vue_type_style_index_0_id_d262f43e_prod_lang_scss_scoped_true__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(165);
  1281. /* harmony import */ var _node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_imageList_vue_vue_type_style_index_0_id_d262f43e_prod_lang_scss_scoped_true__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_imageList_vue_vue_type_style_index_0_id_d262f43e_prod_lang_scss_scoped_true__WEBPACK_IMPORTED_MODULE_0__);
  1282. /* harmony reexport (unknown) */ for(var __WEBPACK_IMPORT_KEY__ in _node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_imageList_vue_vue_type_style_index_0_id_d262f43e_prod_lang_scss_scoped_true__WEBPACK_IMPORTED_MODULE_0__) if(["default"].indexOf(__WEBPACK_IMPORT_KEY__) < 0) (function(key) { __webpack_require__.d(__webpack_exports__, key, function() { return _node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_imageList_vue_vue_type_style_index_0_id_d262f43e_prod_lang_scss_scoped_true__WEBPACK_IMPORTED_MODULE_0__[key]; }) }(__WEBPACK_IMPORT_KEY__));
  1283. /***/ }),
  1284. /***/ 196:
  1285. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  1286. "use strict";
  1287. // ESM COMPAT FLAG
  1288. __webpack_require__.r(__webpack_exports__);
  1289. // CONCATENATED MODULE: ./node_modules/babel-loader/lib??ref--2-0!./node_modules/vue-loader/lib/loaders/templateLoader.js??ref--6!./node_modules/@nuxt/components/dist/loader.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./components/imageList.vue?vue&type=template&id=d262f43e&scoped=true
  1290. var render = function render() {
  1291. var _vm = this,
  1292. _c = _vm._self._c;
  1293. return _c('div', {
  1294. staticClass: "wrap flex row"
  1295. }, [_vm._ssrNode("<i class=\"el-icon-arrow-left\" data-v-d262f43e></i> "), _vm._ssrNode("<div class=\"list\" data-v-d262f43e>", "</div>", _vm._l(_vm.data, function (item, index) {
  1296. return _c('el-image', {
  1297. key: index,
  1298. staticClass: "image",
  1299. attrs: {
  1300. "src": item.cdn_url,
  1301. "fit": "cover"
  1302. },
  1303. on: {
  1304. "click": function ($event) {
  1305. return _vm.handleViwer(index);
  1306. }
  1307. }
  1308. });
  1309. }), 1), _vm._ssrNode(" <i class=\"el-icon-arrow-right\" data-v-d262f43e></i> "), _vm.showViewer ? _c('ElImageViewer', {
  1310. attrs: {
  1311. "initial-index": _vm.currentPre,
  1312. "on-close": _vm.closeViewer,
  1313. "url-list": _vm.comImg
  1314. }
  1315. }) : _vm._e()], 2);
  1316. };
  1317. var staticRenderFns = [];
  1318. // CONCATENATED MODULE: ./components/imageList.vue?vue&type=template&id=d262f43e&scoped=true
  1319. // EXTERNAL MODULE: ./node_modules/element-ui/packages/image/src/image-viewer.vue + 7 modules
  1320. var image_viewer = __webpack_require__(157);
  1321. // CONCATENATED MODULE: ./node_modules/babel-loader/lib??ref--2-0!./node_modules/@nuxt/components/dist/loader.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./components/imageList.vue?vue&type=script&lang=js
  1322. /* harmony default export */ var imageListvue_type_script_lang_js = ({
  1323. components: {
  1324. ElImageViewer: image_viewer["a" /* default */]
  1325. },
  1326. props: {
  1327. data: {
  1328. type: Array,
  1329. default: () => {
  1330. return [];
  1331. }
  1332. }
  1333. },
  1334. data() {
  1335. return {
  1336. currentPre: 0,
  1337. showViewer: false
  1338. };
  1339. },
  1340. computed: {
  1341. comImg() {
  1342. return this.data.map(i => i.cdn_url);
  1343. }
  1344. },
  1345. methods: {
  1346. scroll(amount) {
  1347. const list = this.$refs.list;
  1348. list.scrollLeft += amount * list.clientWidth;
  1349. },
  1350. closeViewer() {
  1351. this.showViewer = false;
  1352. },
  1353. handleViwer(i) {
  1354. this.currentPre = i;
  1355. this.showViewer = true;
  1356. }
  1357. }
  1358. });
  1359. // CONCATENATED MODULE: ./components/imageList.vue?vue&type=script&lang=js
  1360. /* harmony default export */ var components_imageListvue_type_script_lang_js = (imageListvue_type_script_lang_js);
  1361. // EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js
  1362. var componentNormalizer = __webpack_require__(2);
  1363. // CONCATENATED MODULE: ./components/imageList.vue
  1364. function injectStyles (context) {
  1365. var style0 = __webpack_require__(186)
  1366. if (style0.__inject__) style0.__inject__(context)
  1367. }
  1368. /* normalize component */
  1369. var component = Object(componentNormalizer["a" /* default */])(
  1370. components_imageListvue_type_script_lang_js,
  1371. render,
  1372. staticRenderFns,
  1373. false,
  1374. injectStyles,
  1375. "d262f43e",
  1376. "05c2c4fb"
  1377. )
  1378. /* harmony default export */ var imageList = __webpack_exports__["default"] = (component.exports);
  1379. /***/ })
  1380. };;
  1381. //# sourceMappingURL=image-list.js.map