@sdcsd/draggable-components 1.0.0 → 1.0.2

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.
Files changed (265) hide show
  1. package/dist/draggable-components.common.js +4460 -2508
  2. package/dist/draggable-components.common.js.map +1 -1
  3. package/dist/draggable-components.css +1 -1
  4. package/dist/draggable-components.umd.js +4464 -2512
  5. package/dist/draggable-components.umd.js.map +1 -1
  6. package/dist/draggable-components.umd.min.js +1 -1
  7. package/dist/draggable-components.umd.min.js.map +1 -1
  8. package/dist/img/ad.b8bed3d2.svg +154 -0
  9. package/dist/img/ae.978a5276.svg +1 -0
  10. package/dist/img/af.d8fb0d22.svg +1 -0
  11. package/dist/img/ag.7a5c6f51.svg +1 -0
  12. package/dist/img/ai.96e24e9e.svg +1 -0
  13. package/dist/img/al.bfd0a0ce.svg +1 -0
  14. package/dist/img/am.6ab4c4d0.svg +1 -0
  15. package/dist/img/ao.2359a082.svg +1 -0
  16. package/dist/img/aq.65a5c99b.svg +1 -0
  17. package/dist/img/ar.51c7aeb1.svg +1 -0
  18. package/dist/img/as.caaf405e.svg +1 -0
  19. package/dist/img/at.8ba54155.svg +1 -0
  20. package/dist/img/au.e875a51e.svg +1 -0
  21. package/dist/img/aw.ab68008c.svg +1 -0
  22. package/dist/img/ax.d78ede0e.svg +1 -0
  23. package/dist/img/az.b02e1d89.svg +1 -0
  24. package/dist/img/ba.ff62357b.svg +1 -0
  25. package/dist/img/bb.1fe811b7.svg +7 -0
  26. package/dist/img/bd.05e8826e.svg +1 -0
  27. package/dist/img/be.2f762fbb.svg +1 -0
  28. package/dist/img/bf.c07fc50c.svg +1 -0
  29. package/dist/img/bg.1756f2d9.svg +1 -0
  30. package/dist/img/bh.0dc78a04.svg +1 -0
  31. package/dist/img/bi.515d4c82.svg +26 -0
  32. package/dist/img/bj.2f8ccc90.svg +1 -0
  33. package/dist/img/bl.55df0a2e.svg +1 -0
  34. package/dist/img/bm.7d91827f.svg +1 -0
  35. package/dist/img/bn.7b712c9b.svg +58 -0
  36. package/dist/img/bo.24408e4f.svg +1 -0
  37. package/dist/img/bq.5f6ef944.svg +1 -0
  38. package/dist/img/br.92fc6153.svg +1 -0
  39. package/dist/img/bs.f74bac51.svg +1 -0
  40. package/dist/img/bt.0247753b.svg +466 -0
  41. package/dist/img/bv.d91702a1.svg +1 -0
  42. package/dist/img/bw.b3272f19.svg +1 -0
  43. package/dist/img/by.0a7149c2.svg +1 -0
  44. package/dist/img/bz.b76fcd7d.svg +1 -0
  45. package/dist/img/ca.f8c2d112.svg +1 -0
  46. package/dist/img/cc.a8ffbd16.svg +19 -0
  47. package/dist/img/cd.c6cc7e0f.svg +1 -0
  48. package/dist/img/cf.97629cb9.svg +1 -0
  49. package/dist/img/cg.75c9979a.svg +5 -0
  50. package/dist/img/ch.72a82891.svg +1 -0
  51. package/dist/img/ci.6bf90550.svg +1 -0
  52. package/dist/img/ck.420c555e.svg +1 -0
  53. package/dist/img/cl.4cbf573b.svg +14 -0
  54. package/dist/img/cm.a76c9da2.svg +15 -0
  55. package/dist/img/cn.c40591ea.svg +1 -0
  56. package/dist/img/co.5580c56f.svg +5 -0
  57. package/dist/img/cr.74dd61b6.svg +1 -0
  58. package/dist/img/cu.8bd5be6b.svg +6 -0
  59. package/dist/img/cv.1a517aea.svg +24 -0
  60. package/dist/img/cw.c92a4146.svg +16 -0
  61. package/dist/img/cx.db137cac.svg +15 -0
  62. package/dist/img/cy.ce826661.svg +1 -0
  63. package/dist/img/cz.65042957.svg +5 -0
  64. package/dist/img/de.a1435756.svg +1 -0
  65. package/dist/img/dj.02e75e20.svg +1 -0
  66. package/dist/img/dk.76cf3e39.svg +5 -0
  67. package/dist/img/dm.3a68c10d.svg +1 -0
  68. package/dist/img/do.4ba64fb6.svg +1 -0
  69. package/dist/img/dz.c3635144.svg +5 -0
  70. package/dist/img/ec.d5a3e215.svg +519 -0
  71. package/dist/img/ee.dd2a64a6.svg +1 -0
  72. package/dist/img/eg.9498b313.svg +78 -0
  73. package/dist/img/eh.242720f7.svg +9 -0
  74. package/dist/img/er.2ad12126.svg +6 -0
  75. package/dist/img/es.c3853709.svg +1 -0
  76. package/dist/img/et.15040bfc.svg +1 -0
  77. package/dist/img/eu.93555e17.svg +1 -0
  78. package/dist/img/fi.747657c3.svg +5 -0
  79. package/dist/img/fj.41e534b0.svg +1 -0
  80. package/dist/img/fk.4e9526a8.svg +1 -0
  81. package/dist/img/fm.5901edbf.svg +16 -0
  82. package/dist/img/fo.d5facc7a.svg +11 -0
  83. package/dist/img/fr.55df0a2e.svg +1 -0
  84. package/dist/img/ga.de003fa2.svg +5 -0
  85. package/dist/img/gb-eng.bb489b94.svg +7 -0
  86. package/dist/img/gb-nir.c39480d5.svg +1 -0
  87. package/dist/img/gb-sct.dd6733a9.svg +1 -0
  88. package/dist/img/gb-wls.adce5953.svg +9 -0
  89. package/dist/img/gb.c39480d5.svg +1 -0
  90. package/dist/img/gd.471a003b.svg +1 -0
  91. package/dist/img/ge.a48e9919.svg +1 -0
  92. package/dist/img/gf.55df0a2e.svg +1 -0
  93. package/dist/img/gg.d38e76e4.svg +8 -0
  94. package/dist/img/gh.28ab14b2.svg +6 -0
  95. package/dist/img/gi.3e92bec7.svg +54 -0
  96. package/dist/img/gl.a5c256e1.svg +4 -0
  97. package/dist/img/gm.2583d210.svg +7 -0
  98. package/dist/img/gn.23ee49e7.svg +5 -0
  99. package/dist/img/gp.55df0a2e.svg +1 -0
  100. package/dist/img/gq.5dc050f9.svg +75 -0
  101. package/dist/img/gr.abd7d677.svg +1 -0
  102. package/dist/img/gs.7b917516.svg +1 -0
  103. package/dist/img/gt.ca224d7c.svg +214 -0
  104. package/dist/img/gu.c3db56a6.svg +1 -0
  105. package/dist/img/gw.65b1fcad.svg +13 -0
  106. package/dist/img/gy.9c2891ac.svg +7 -0
  107. package/dist/img/hk.b953ca2c.svg +1 -0
  108. package/dist/img/hm.e875a51e.svg +1 -0
  109. package/dist/img/hn.515bf7aa.svg +1 -0
  110. package/dist/img/hr.f4e06f4d.svg +1 -0
  111. package/dist/img/ht.b8bdde5a.svg +1 -0
  112. package/dist/img/hu.456f4b1b.svg +1 -0
  113. package/dist/img/id.a8161cf2.svg +1 -0
  114. package/dist/img/ie.8f8ca447.svg +1 -0
  115. package/dist/img/il.033c38c0.svg +1 -0
  116. package/dist/img/im.46d995fd.svg +1 -0
  117. package/dist/img/in.69b796ab.svg +1 -0
  118. package/dist/img/io.5e7836dd.svg +1 -0
  119. package/dist/img/iq.66216bd0.svg +1 -0
  120. package/dist/img/ir.5ce127e4.svg +31 -0
  121. package/dist/img/is.75a62d93.svg +1 -0
  122. package/dist/img/it.27fe7edc.svg +1 -0
  123. package/dist/img/je.1478f6ec.svg +1 -0
  124. package/dist/img/jm.4daaf707.svg +1 -0
  125. package/dist/img/jo.9c2e45cc.svg +7 -0
  126. package/dist/img/jp.66dacdf5.svg +4 -0
  127. package/dist/img/ke.bbb6db06.svg +23 -0
  128. package/dist/img/kg.b835c7fc.svg +1 -0
  129. package/dist/img/kh.820b80bf.svg +116 -0
  130. package/dist/img/ki.1e425fd5.svg +1 -0
  131. package/dist/img/km.780746a1.svg +13 -0
  132. package/dist/img/kn.ad086c55.svg +1 -0
  133. package/dist/img/kp.a270b79c.svg +16 -0
  134. package/dist/img/kr.94941e04.svg +1 -0
  135. package/dist/img/kw.b3d9907a.svg +6 -0
  136. package/dist/img/ky.69021ebc.svg +1 -0
  137. package/dist/img/kz.0ded3b63.svg +37 -0
  138. package/dist/img/la.ac7e695a.svg +1 -0
  139. package/dist/img/lb.2b985ffb.svg +5 -0
  140. package/dist/img/lc.25152dc3.svg +6 -0
  141. package/dist/img/li.3518ccf5.svg +56 -0
  142. package/dist/img/lk.23e5cb5f.svg +1 -0
  143. package/dist/img/lr.3de4997b.svg +15 -0
  144. package/dist/img/ls.2183506a.svg +23 -0
  145. package/dist/img/lt.60ce52ef.svg +1 -0
  146. package/dist/img/lu.97e411b3.svg +1 -0
  147. package/dist/img/lv.12cebcfb.svg +1 -0
  148. package/dist/img/ly.8952f9a4.svg +8 -0
  149. package/dist/img/ma.caaf228d.svg +1 -0
  150. package/dist/img/mc.9ce1d042.svg +1 -0
  151. package/dist/img/md.6b8abcb3.svg +1 -0
  152. package/dist/img/me.749d2e34.svg +93 -0
  153. package/dist/img/mf.55df0a2e.svg +1 -0
  154. package/dist/img/mg.3bb33f8d.svg +1 -0
  155. package/dist/img/mh.1ce06f01.svg +1 -0
  156. package/dist/img/mk.2ac054eb.svg +1 -0
  157. package/dist/img/ml.9030b284.svg +5 -0
  158. package/dist/img/mm.ff055a25.svg +12 -0
  159. package/dist/img/mn.7bd9a92b.svg +1 -0
  160. package/dist/img/mo.46b51100.svg +10 -0
  161. package/dist/img/mp.91055a88.svg +1 -0
  162. package/dist/img/mq.55df0a2e.svg +1 -0
  163. package/dist/img/mr.4ae40103.svg +1 -0
  164. package/dist/img/ms.672d771e.svg +1 -0
  165. package/dist/img/mt.23c648aa.svg +1 -0
  166. package/dist/img/mu.ca7b8131.svg +1 -0
  167. package/dist/img/mv.4cca1ac7.svg +1 -0
  168. package/dist/img/mw.b19033b2.svg +24 -0
  169. package/dist/img/mx.216d2ed6.svg +1 -0
  170. package/dist/img/my.537daaa3.svg +1 -0
  171. package/dist/img/mz.03ab17e9.svg +13 -0
  172. package/dist/img/na.347a6e25.svg +1 -0
  173. package/dist/img/nc.55df0a2e.svg +1 -0
  174. package/dist/img/ne.465d9739.svg +6 -0
  175. package/dist/img/nf.7a5c5828.svg +5 -0
  176. package/dist/img/ng.ae382946.svg +4 -0
  177. package/dist/img/ni.c1e4af11.svg +161 -0
  178. package/dist/img/nl.5f6ef944.svg +1 -0
  179. package/dist/img/no.d91702a1.svg +1 -0
  180. package/dist/img/np.7b78f86d.svg +33 -0
  181. package/dist/img/nr.6b72bbc1.svg +1 -0
  182. package/dist/img/nu.971e5c2f.svg +1 -0
  183. package/dist/img/nz.30299530.svg +1 -0
  184. package/dist/img/om.299d7167.svg +1 -0
  185. package/dist/img/pa.931bfe6b.svg +1 -0
  186. package/dist/img/pe.89b9f8a2.svg +320 -0
  187. package/dist/img/people-icon2.6c5193fc.png +0 -0
  188. package/dist/img/pf.cd51dc27.svg +1 -0
  189. package/dist/img/pg.8c906c8c.svg +13 -0
  190. package/dist/img/ph.62b10c25.svg +1 -0
  191. package/dist/img/pk.f33c2297.svg +1 -0
  192. package/dist/img/pl.e2afe0f6.svg +1 -0
  193. package/dist/img/pm.55df0a2e.svg +1 -0
  194. package/dist/img/pn.a7cc83d2.svg +1 -0
  195. package/dist/img/pr.44606b44.svg +1 -0
  196. package/dist/img/ps.7fb44a73.svg +1 -0
  197. package/dist/img/pt.352ff4b0.svg +1 -0
  198. package/dist/img/pw.c5a4b0fe.svg +1 -0
  199. package/dist/img/py.9f48a110.svg +1 -0
  200. package/dist/img/qa.b39ab9d6.svg +1 -0
  201. package/dist/img/re.55df0a2e.svg +1 -0
  202. package/dist/img/ro.a9e8cdfe.svg +1 -0
  203. package/dist/img/rs.e4159b1c.svg +1 -0
  204. package/dist/img/ru.182478bc.svg +1 -0
  205. package/dist/img/rw.bf080503.svg +13 -0
  206. package/dist/img/sa.943cf626.svg +1 -0
  207. package/dist/img/sb.2c776db7.svg +1 -0
  208. package/dist/img/sc.c689a310.svg +7 -0
  209. package/dist/img/sd.ea2d2bd4.svg +6 -0
  210. package/dist/img/se.9e47ea03.svg +5 -0
  211. package/dist/img/sg.14be03f1.svg +11 -0
  212. package/dist/img/sh.c39480d5.svg +1 -0
  213. package/dist/img/si.9a72ead6.svg +1 -0
  214. package/dist/img/sj.d91702a1.svg +1 -0
  215. package/dist/img/sk.d8e0e96c.svg +1 -0
  216. package/dist/img/sl.890bdc29.svg +1 -0
  217. package/dist/img/sm.bdd98917.svg +1 -0
  218. package/dist/img/sn.42cfbd39.svg +1 -0
  219. package/dist/img/so.f89e77ad.svg +1 -0
  220. package/dist/img/sr.cbccf817.svg +1 -0
  221. package/dist/img/ss.562eaa76.svg +1 -0
  222. package/dist/img/st.b435df97.svg +1 -0
  223. package/dist/img/sv.87a195b6.svg +1 -0
  224. package/dist/img/sx.8db7b1db.svg +1 -0
  225. package/dist/img/sy.02c1d5b2.svg +1 -0
  226. package/dist/img/sz.59e2dbc4.svg +1 -0
  227. package/dist/img/tc.729aa511.svg +1 -0
  228. package/dist/img/td.f6b0a98f.svg +1 -0
  229. package/dist/img/tf.d9c9ef13.svg +1 -0
  230. package/dist/img/tg.c270b112.svg +1 -0
  231. package/dist/img/th.3530959a.svg +1 -0
  232. package/dist/img/tj.ab3bac64.svg +1 -0
  233. package/dist/img/tk.e5fa89ea.svg +1 -0
  234. package/dist/img/tl.f0649357.svg +1 -0
  235. package/dist/img/tm.b5f65296.svg +1 -0
  236. package/dist/img/tn.22c29ff7.svg +9 -0
  237. package/dist/img/to.ba2127cb.svg +1 -0
  238. package/dist/img/tr.cf31c9d6.svg +1 -0
  239. package/dist/img/tt.8ab31263.svg +5 -0
  240. package/dist/img/tv.d1412347.svg +1 -0
  241. package/dist/img/tw.74b88030.svg +1 -0
  242. package/dist/img/tz.ee919c0a.svg +1 -0
  243. package/dist/img/ua.8a287858.svg +1 -0
  244. package/dist/img/ug.ccaa7a85.svg +1 -0
  245. package/dist/img/um.eadfb4ed.svg +1 -0
  246. package/dist/img/us.eadfb4ed.svg +1 -0
  247. package/dist/img/uy.6068a814.svg +1 -0
  248. package/dist/img/uz.b20f1adb.svg +1 -0
  249. package/dist/img/va.6182350f.svg +1 -0
  250. package/dist/img/vc.bd0bfc7e.svg +1 -0
  251. package/dist/img/ve.243693de.svg +1 -0
  252. package/dist/img/vg.ccea90f1.svg +1 -0
  253. package/dist/img/vi.2cca2f61.svg +1 -0
  254. package/dist/img/vn.44c0954e.svg +1 -0
  255. package/dist/img/vu.0c83fc4f.svg +1 -0
  256. package/dist/img/wf.9cbf71ee.svg +1 -0
  257. package/dist/img/ws.adcc72ee.svg +1 -0
  258. package/dist/img/xk.4f3781ca.svg +1 -0
  259. package/dist/img/ye.1a89616e.svg +1 -0
  260. package/dist/img/yt.55df0a2e.svg +1 -0
  261. package/dist/img/za.b2f370d4.svg +1 -0
  262. package/dist/img/zm.112bea3f.svg +1 -0
  263. package/dist/img/zw.bc893918.svg +1 -0
  264. package/package.json +1 -1
  265. package/readme.md +10 -0
@@ -1 +1 @@
1
- {"version":3,"sources":["webpack://draggable-components/webpack/bootstrap","webpack://draggable-components/./package/hotProduct/hotProduct.vue?89b6","webpack://draggable-components//Users/cxm/project/csd/dl_cluster_admin_ui/node_modules/swiper/dist/js/swiper.js","webpack://draggable-components/./assets/whatsapp.png","webpack://draggable-components/./node_modules/element-ui/lib/theme-chalk/index.css?8823","webpack://draggable-components/./assets/telephone.png","webpack://draggable-components/./assets/language.png","webpack://draggable-components/./package/floatNav/floatNav.vue?06e3","webpack://draggable-components/./package/newsInformation/newsInformation.vue?60d9","webpack://draggable-components/./assets/home-world-bg.png","webpack://draggable-components/./package/productList/productList.vue?f9f1","webpack://draggable-components/./assets/chat.png","webpack://draggable-components/./package/carousel/carousel.vue?99d9","webpack://draggable-components/./package/headerNav/headerNav.vue?f4fa","webpack://draggable-components/./package/headerNav/headerNav.vue?9507","webpack://draggable-components/./assets/medal-icon.png","webpack://draggable-components//Users/cxm/project/csd/dl_cluster_admin_ui/node_modules/swiper/dist/css/swiper.css?21a3","webpack://draggable-components/./assets/r-icon.png","webpack://draggable-components/./assets/e-mail.png","webpack://draggable-components/./node_modules/@soda/get-current-script/index.js","webpack://draggable-components/./package/productList/productList.vue?1ccc","webpack://draggable-components/./package/newsInformation/newsInformation.vue?ef75","webpack://draggable-components/./assets/diamond-icon.png","webpack://draggable-components/./assets/equipment-icon.png","webpack://draggable-components/./package/headerNav/changeLanguageDialog.vue?fa91","webpack://draggable-components/./package/floatNav/floatNav.vue?79f5","webpack://draggable-components/./package/carousel/carousel.vue?93b3","webpack://draggable-components/./package/footerNav/footerNav.vue?6364","webpack://draggable-components/./assets/diamond-icon2.png","webpack://draggable-components/./assets/left-arrow.svg","webpack://draggable-components/./package/footerNav/footerNav.vue?f233","webpack://draggable-components/./assets/company-intro-bg.png","webpack://draggable-components/./package/companyIntroduction/companyIntroduction.vue?4034","webpack://draggable-components/./package/companyIntroduction/companyIntroduction.vue?1e50","webpack://draggable-components/./assets/project-icon.png","webpack://draggable-components/./assets/top-icon.png","webpack://draggable-components/./package/headerNav/changeLanguageDialog.vue?ae2e","webpack://draggable-components//Users/cxm/project/csd/dl_cluster_admin_ui/node_modules/vue-awesome-swiper/dist/vue-awesome-swiper.js","webpack://draggable-components/./package/hotProduct/hotProduct.vue?a0cf","webpack://draggable-components/./assets/people-icon.png","webpack://draggable-components/./node_modules/@vue/cli-service/lib/commands/build/setPublicPath.js","webpack://draggable-components/./package/carousel/carousel.vue","webpack://draggable-components/package/carousel/carousel.vue","webpack://draggable-components/./package/carousel/carousel.vue?11b0","webpack://draggable-components/./node_modules/vue-loader/lib/runtime/componentNormalizer.js","webpack://draggable-components/./package/carousel/carousel.vue?7f78","webpack://draggable-components/./package/carousel/index.js","webpack://draggable-components/./package/companyIntroduction/companyIntroduction.vue","webpack://draggable-components/package/companyIntroduction/companyIntroduction.vue","webpack://draggable-components/./package/companyIntroduction/companyIntroduction.vue?de4b","webpack://draggable-components/./package/companyIntroduction/companyIntroduction.vue?a6ee","webpack://draggable-components/./package/companyIntroduction/index.js","webpack://draggable-components/./package/floatNav/floatNav.vue","webpack://draggable-components/package/floatNav/floatNav.vue","webpack://draggable-components/./package/floatNav/floatNav.vue?f1da","webpack://draggable-components/./package/floatNav/floatNav.vue?e24f","webpack://draggable-components/./package/floatNav/index.js","webpack://draggable-components/./package/footerNav/footerNav.vue","webpack://draggable-components/package/footerNav/footerNav.vue","webpack://draggable-components/./package/footerNav/footerNav.vue?4aff","webpack://draggable-components/./package/footerNav/footerNav.vue?967e","webpack://draggable-components/./package/footerNav/index.js","webpack://draggable-components/./package/headerNav/headerNav.vue","webpack://draggable-components/./package/headerNav/menus.js","webpack://draggable-components/./package/headerNav/changeLanguageDialog.vue","webpack://draggable-components/package/headerNav/changeLanguageDialog.vue","webpack://draggable-components/./package/headerNav/changeLanguageDialog.vue?010f","webpack://draggable-components/./package/headerNav/changeLanguageDialog.vue?7743","webpack://draggable-components/package/headerNav/headerNav.vue","webpack://draggable-components/./package/headerNav/headerNav.vue?d2bb","webpack://draggable-components/./package/headerNav/headerNav.vue?933c","webpack://draggable-components/./package/headerNav/index.js","webpack://draggable-components/./package/hotProduct/hotProduct.vue","webpack://draggable-components/package/hotProduct/hotProduct.vue","webpack://draggable-components/./package/hotProduct/hotProduct.vue?8b61","webpack://draggable-components/./package/hotProduct/hotProduct.vue?3e98","webpack://draggable-components/./package/hotProduct/index.js","webpack://draggable-components/./package/newsInformation/newsInformation.vue","webpack://draggable-components/package/newsInformation/newsInformation.vue","webpack://draggable-components/./package/newsInformation/newsInformation.vue?d189","webpack://draggable-components/./package/newsInformation/newsInformation.vue?1485","webpack://draggable-components/./package/newsInformation/index.js","webpack://draggable-components/./package/productList/productList.vue","webpack://draggable-components/package/productList/productList.vue","webpack://draggable-components/./package/productList/productList.vue?d7bd","webpack://draggable-components/./package/productList/productList.vue?3698","webpack://draggable-components/./package/productList/index.js","webpack://draggable-components/./index.js","webpack://draggable-components/./node_modules/@vue/cli-service/lib/commands/build/entry-lib.js"],"names":["render","_vm","_c","_self","staticClass","clickDisabled","_e","styleType","attrs","swiperOptions","_l","carouselList","item","key","id","url","title","on","click","$event","stopPropagation","handleClick","slot","require","staticRenderFns","name","components","swiper","swiperSlide","props","type","String","default","Array","Boolean","theme","data","slidesPerView","loop","autoplay","delay","stopOnLastSlide","disableOnInteraction","speed","navigation","nextEl","prevEl","pagination","el","clickable","swiperInstance","watch","handler","newVal","$nextTick","update","deep","immediate","mounted","initSwiper","methods","link","window","open","length","destroy","setTimeout","swiperElements","document","querySelectorAll","running","start","initiated","init","carousel","install","Vue","component","class","_v","_s","introduction","subTitle","domProps","pcIntroduction","_m","directives","rawName","value","moreMenu","isShow","expression","handleShowMore","apply","arguments","Object","pcContent","mobileContent","isBlank","console","log","$props","companyIntroduction","sideiItem","index","jump","icon","label","desc","handleToTop","staticStyle","sideiItemNew","iconClass","footerInfo","tel","whatsapp","email","computed","thirdSoft","maxCatgId","scrollTo","top","behavior","row","thirdAccount","equipment","$store","state","app","device","$axios","post","err","floatNav","contactWay","content","friendlyLink","list","linkSite","linkTitle","productCategory","categoryTitle","qrcode","href","$router","resolve","path","query","categoryId","footerNav","logo","menus","searchText","keydown","indexOf","_k","keyCode","handleSearch","input","target","composing","changeLanguage","handleMenuHover","handleMenuLeave","handleClickMenu","showSubMenu","handleSubMenuContainerEnter","handleSubMenuContainerLeave","children","secondMenu","secondIndex","thirdMenu","thirdIndex","fourthMenu","fourthIndex","showLanguageDialog","close","handleLanguageSelect","menu","renderMenuItem","createElement","menuItem","toString","map","MenuComponent","mode","validator","includes","defaultActive","backgroundColor","textColor","activeTextColor","select","indexPath","visible","handleClose","update:visible","model","activeTab","callback","$$v","languageList","region","languages","emits","$emit","ChangeLanguageDialog","navList","allNavList","hoveredSubItem","leaveTimer","result","find","navItem","destroyed","language","push","clearTimeout","handleSubMenuHover","handleSubMenuItemHover","subItem","headerNav","hotProductData","displayProductList","slice","productCount","mainPic","split","prodTitle","prodDescription","moreBtnTitle","swiperOptions2","mouseenter","activeIndex","mouseleave","style","bottom","sortType","productType","productList","isShowMoreBtn","moreBtnIsBlank","slidesPerGroup","slidesPerColumn","spaceBetween","hotProduct","newsInformationData","displayNewsList","description","publicDate","newsCount","replaceAll","newsType","newsCategory","newsList","newsInformation","productListData","busiProdNewId","forEach"],"mappings":";;QAAA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;;QAEA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;;;QAGA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;QACA,0CAA0C,gCAAgC;QAC1E;QACA;;QAEA;QACA;QACA;QACA,wDAAwD,kBAAkB;QAC1E;QACA,iDAAiD,cAAc;QAC/D;;QAEA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA,yCAAyC,iCAAiC;QAC1E,gHAAgH,mBAAmB,EAAE;QACrI;QACA;;QAEA;QACA;QACA;QACA,2BAA2B,0BAA0B,EAAE;QACvD,iCAAiC,eAAe;QAChD;QACA;QACA;;QAEA;QACA,sDAAsD,+DAA+D;;QAErH;QACA;;;QAGA;QACA;;;;;;;;;AClFA;AAAA;AAAA;;;;;;;;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,EAAE,KAA4D;AAC9D,EAAE,SACoD;AACtD,CAAC,oBAAoB;;AAErB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY;AACZ,oDAAoD;AACpD,0DAA0D;AAC1D;AACA,8BAA8B;AAC9B;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;AACA;AACA,0CAA0C;AAC1C;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,iBAAiB;AACjB,gDAAgD;AAChD;AACA;AACA,SAAS;AACT;AACA,KAAK;AACL,eAAe,WAAW;AAC1B,GAAG,YAAY;;AAEf;AACA;AACA;AACA;AACA,KAAK;AACL,gBAAgB;AAChB,eAAe;AACf;AACA;AACA,KAAK;AACL,oDAAoD;AACpD,0DAA0D;AAC1D;AACA;AACA;AACA;AACA,SAAS;AACT;AACA,KAAK;AACL,8BAA8B;AAC9B,4BAA4B;AAC5B,cAAc;AACd,wCAAwC;AACxC,4CAA4C;AAC5C,GAAG,UAAU;;AAEb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,mBAAmB,gBAAgB;AACnC;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0CAA0C,iBAAiB;AAC3D,0CAA0C,oBAAoB;AAC9D,uEAAuE,iBAAiB;AACxF,6CAA6C,oBAAoB;AACjE,8CAA8C,qBAAqB;AACnE;AACA;AACA,qBAAqB,kCAAkC;AACvD;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA,qBAAqB,gBAAgB;AACrC,yBAAyB,kBAAkB;AAC3C;AACA;AACA,OAAO;AACP;AACA;AACA,OAAO;AACP;AACA,mBAAmB,qBAAqB;AACxC;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,mBAAmB,gBAAgB;AACnC,+CAA+C,0BAA0B;AACzE;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,oBAAoB;AACvC,qBAAqB,iBAAiB;AACtC,yFAAyF,mCAAmC;AAC5H;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,oBAAoB;AACvC,qBAAqB,iBAAiB;AACtC,yFAAyF,sCAAsC;AAC/H;AACA;AACA;AACA;AACA;AACA,mBAAmB,cAAc;AACjC;AACA;AACA;AACA;AACA,mBAAmB,oBAAoB;AACvC,qBAAqB,iBAAiB;AACtC,yFAAyF,sCAAsC;AAC/H;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,oBAAoB,oCAAoC;AACxD;AACA;;AAEA;AACA,mBAAmB,iBAAiB;AACpC;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,iBAAiB;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,mBAAmB,iBAAiB;AACpC;AACA,uCAAuC,gCAAgC;AACvE;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,iBAAiB;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iCAAiC;AACjC;AACA,mBAAmB,iBAAiB;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,iBAAiB;;AAEpC;AACA;AACA,oBAAoB,QAAQ;AAC5B;AACA;AACA;AACA;AACA,yCAAyC,mCAAmC;AAC5E;AACA,0CAA0C;AAC1C,uBAAuB,oBAAoB;AAC3C,iDAAiD,uCAAuC;AACxF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,iBAAiB;AACpC;AACA;AACA,mBAAmB,mBAAmB;AACtC;AACA,kCAAkC,uBAAuB;AACzD,yCAAyC,8BAA8B;AACvE;AACA;AACA;AACA,WAAW;AACX;AACA;AACA,OAAO;AACP;AACA,mBAAmB,mBAAmB;AACtC;AACA,sCAAsC,2BAA2B;AACjE,+CAA+C,oCAAoC;AACnF;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,iBAAiB;;AAEpC;AACA,mBAAmB,mBAAmB;AACtC;AACA,qBAAqB,iBAAiB;AACtC;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,2CAA2C,QAAQ;AACnD;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,mBAAmB,mBAAmB;AACtC;AACA,qBAAqB,iBAAiB;AACtC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,mEAAmE,sBAAsB,EAAE;AAC3F;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8BAA8B,QAAQ;AACtC;AACA,iBAAiB,mBAAmB;AACpC;AACA;AACA;AACA;AACA,iBAAiB,mBAAmB;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,kBAAkB,4CAA4C;AAC9D;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB,oEAAoE;AAC1F,OAAO;AACP,mBAAmB,iBAAiB;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB,iBAAiB;AAClC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,aAAa;AACjC;AACA,mBAAmB,iBAAiB;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,mBAAmB,iBAAiB;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,mBAAmB,iBAAiB;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iDAAiD,cAAc;AAC/D;AACA,uBAAuB,6BAA6B;AACpD,0CAA0C,2CAA2C;AACrF,sCAAsC,uCAAuC;;AAE7E;AACA,iBAAiB,wBAAwB;AACzC,oCAAoC,aAAa;AACjD;AACA;AACA,KAAK,6BAA6B,mBAAmB;AACrD,gCAAgC,mBAAmB;;AAEnD;AACA;AACA,iBAAiB,wBAAwB;AACzC,oCAAoC,aAAa;AACjD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mCAAmC,QAAQ;AAC3C;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uCAAuC,aAAa;AACpD;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4BAA4B,qBAAqB;AACjD;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,mBAAmB,iBAAiB;AACpC;AACA,qBAAqB,iBAAiB;AACtC;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,yBAAyB,qBAAqB;AAC9C;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,eAAe,iBAAiB;AAChC;AACA;AACA;AACA,+CAA+C,QAAQ;AACvD;AACA;AACA,OAAO;AACP,mBAAmB,qBAAqB;AACxC;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,uCAAuC,+CAA+C;AACtF;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc,qBAAqB;AACnC;AACA,uCAAuC;AACvC;AACA,mCAAmC,oBAAoB;AACvD,OAAO,OAAO,oBAAoB;AAClC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,sCAAsC,8CAA8C;AACpF;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc,qBAAqB;AACnC;AACA,2CAA2C;AAC3C;AACA,mCAAmC,oBAAoB;AACvD,OAAO,OAAO,oBAAoB;AAClC;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB,mBAAmB,iBAAiB;AACpC;AACA;AACA,mDAAmD,kCAAkC;AACrF,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB,mBAAmB,iBAAiB;AACpC,sCAAsC;AACtC;AACA;AACA,uCAAuC,sBAAsB;AAC7D,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB;AACvB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,iBAAiB;AACpC;AACA,qBAAqB,kBAAkB;AACvC;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB;AACtB,mBAAmB,iBAAiB;AACpC;;AAEA,qBAAqB,uBAAuB;AAC5C;AACA,6CAA6C,8BAA8B;AAC3E,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,iBAAiB;AACpC,+BAA+B,yCAAyC;AACxE;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,eAAe,iBAAiB;AAChC;AACA,iBAAiB,kBAAkB;AACnC;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;;AAEA;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,oEAAoE,4BAA4B,EAAE;AAClG;AACA,mEAAmE;AACnE;AACA;AACA,OAAO;AACP;AACA;AACA;;AAEA;AACA;AACA,kCAAkC,oCAAoC;AACtE;AACA,wCAAwC,uCAAuC;AAC/E;AACA,cAAc,sCAAsC;AACpD;AACA;AACA;AACA,kCAAkC,oCAAoC;AACtE;AACA,wCAAwC,uCAAuC;AAC/E;AACA,cAAc,sCAAsC;AACpD;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qEAAqE,0BAA0B,EAAE;AACjG;;AAEA,mBAAmB,YAAY;AAC/B;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA,qBAAqB,iBAAiB;AACtC;AACA;AACA;AACA,yDAAyD,iBAAiB;AAC1E;AACA;AACA;AACA;AACA;AACA,eAAe;AACf;AACA;AACA,eAAe;AACf;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA,OAAO;;AAEP;AACA;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,OAAO;;AAEP;AACA;AACA;AACA,uBAAuB,mBAAmB;AAC1C,mCAAmC,aAAa;AAChD;AACA;AACA,OAAO;;AAEP;AACA;AACA,OAAO;;AAEP;AACA;AACA;AACA,6CAA6C;AAC7C;AACA;AACA;AACA,aAAa;AACb,WAAW;AACX;AACA,SAAS;AACT;AACA;AACA;AACA,OAAO;;AAEP;AACA;AACA,OAAO;AACP;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;;AAEA,yBAAyB,cAAc,qBAAqB;;AAE5D;AACA;AACA,wCAAwC,aAAa;AACrD;AACA;AACA,yCAAyC,kCAAkC;AAC3E;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA,wCAAwC,aAAa;AACrD;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,gCAAgC,aAAa;AAC7C;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA,SAAS;AACT;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;;AAEA;AACA,gCAAgC,aAAa;AAC7C;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;AACT;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA,4BAA4B,QAAQ;AACpC;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;;AAEA;AACA,4BAA4B,QAAQ;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA,qBAAqB,QAAQ;AAC7B;AACA;;AAEA;AACA;AACA;;AAEA;AACA,mCAAmC,8BAA8B;AACjE;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,mCAAmC,+BAA+B,EAAE;AACpE;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA,cAAc,aAAa,gCAAgC,EAAE;AAC7D,UAAU,aAAa,oCAAoC,EAAE;;AAE7D;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,mBAAmB,kBAAkB;AACrC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4CAA4C,UAAU,EAAE;;AAExD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,mCAAmC;AACrE,OAAO;AACP;AACA,kCAAkC,mCAAmC;;AAErE;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACA,6CAA6C,iEAAiE;AAC9G,sBAAsB,iEAAiE;AACvF,iDAAiD,mBAAmB;AACpE,kCAAkC,2CAA2C;AAC7E,oDAAoD,8BAA8B;AAClF;AACA,OAAO;AACP,kCAAkC,2CAA2C;AAC7E,oDAAoD,8BAA8B;AAClF;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA,sBAAsB,6DAA6D;AACnF;AACA;AACA,kCAAkC,iBAAiB,6DAA6D,EAAE;AAClH,YAAY,iBAAiB,8DAA8D,EAAE;AAC7F;;AAEA;AACA;AACA;AACA,kCAAkC,iBAAiB,6DAA6D,EAAE;AAClH,YAAY,iBAAiB,8DAA8D,EAAE;AAC7F;AACA;AACA,yBAAyB,uBAAuB;AAChD;AACA,oCAAoC,6CAA6C;AACjF,iEAAiE,oCAAoC;AACrG;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,uBAAuB,uBAAuB;AAC9C;AACA,kCAAkC,iDAAiD;AACnF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gCAAgC,gBAAgB;;AAEhD;AACA;AACA,kBAAkB,aAAa,oCAAoC,EAAE;AACrE,cAAc,aAAa,qCAAqC,EAAE;AAClE,OAAO,OAAO,aAAa,sCAAsC,EAAE;AACnE;;AAEA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;AACT;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA,wCAAwC,wBAAwB;AAChE;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,iBAAiB,4CAA4C;AAC7D;AACA,2CAA2C,OAAO;AAClD;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA,eAAe,yBAAyB;AACxC;AACA;AACA;AACA;AACA;;AAEA;AACA,oBAAoB,qDAAqD;AACzE;;AAEA;AACA;AACA;AACA,mBAAmB,mBAAmB;AACtC;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA,8BAA8B,QAAQ;AACtC,6DAA6D,6BAA6B;;AAE1F;AACA,cAAc,0BAA0B;;AAExC;AACA;;AAEA;AACA;;AAEA,mBAAmB,mBAAmB;AACtC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL,qEAAqE,wCAAwC;;AAE7G;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB,uBAAuB;AAC5C;AACA;AACA;AACA,WAAW;AACX;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,oEAAoE,iBAAiB;AACrF;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,uCAAuC,iCAAiC;AACxE;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB,0BAA0B;AAC/C,yCAAyC,mBAAmB;AAC5D;AACA;;AAEA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,cAAc,sCAAsC;;AAEpD;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,iCAAiC,8EAA8E;AAC/G,YAAY,+DAA+D;AAC3E;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,wCAAwC,cAAc;AACtD,6CAA6C,cAAc;AAC3D,YAAY,eAAe;AAC3B;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,wCAAwC,cAAc;AACtD,6CAA6C,cAAc;AAC3D,YAAY,eAAe;AAC3B;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA,yBAAyB,gBAAgB;;AAEzC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,uCAAuC,iCAAiC;;AAExE;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA,qBAAqB,uBAAuB;AAC5C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gDAAgD,cAAc;AAC9D;AACA;;AAEA;AACA,mCAAmC,oBAAoB;AACvD,wCAAwC,oBAAoB;AAC5D,UAAU,qBAAqB;;;AAG/B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8CAA8C,QAAQ;AACtD,oCAAoC,QAAQ;AAC5C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,sBAAsB,cAAc;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,sBAAsB,cAAc;AACpC;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,mCAAmC;AACvD;AACA;AACA;AACA,0DAA0D,uBAAuB,EAAE;AACnF,8DAA8D,uBAAuB,EAAE;;AAEvF;AACA;AACA;AACA;AACA;AACA,0BAA0B,oCAAoC;AAC9D;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,6BAA6B,QAAQ;AACrC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,WAAW;AACX,SAAS;AACT;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,SAAS;AACT,OAAO;AACP;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,uBAAuB,oBAAoB;AAC3C;AACA;AACA;AACA;AACA;AACA;;AAEA,kEAAkE,qCAAqC;;AAEvG;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,wCAAwC,uBAAuB;AAC/D,kFAAkF,wBAAwB;AAC1G;AACA,KAAK;AACL,qBAAqB,2BAA2B;AAChD;AACA;AACA,4CAA4C,UAAU;AACtD;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,4GAA4G,QAAQ;AACpH;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,4EAA4E,QAAQ;AACpF;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB,mBAAmB;AACxC,wBAAwB,8BAA8B;AACtD;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,qBAAqB,mBAAmB;AACxC,wBAAwB,+BAA+B;AACvD;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,gCAAgC,YAAY;AAC5C;AACA;AACA;AACA;;AAEA;AACA,uBAAuB,qBAAqB;AAC5C,0BAA0B,gCAAgC;AAC1D;AACA;AACA,KAAK;AACL;AACA;;AAEA,qBAAqB,2BAA2B;AAChD;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,qBAAqB,0BAA0B;AAC/C;AACA,2CAA2C,0CAA0C;AACrF,6CAA6C,qBAAqB;AAClE;AACA;AACA,KAAK;AACL;AACA,yCAAyC,0CAA0C;AACnF,2CAA2C,qBAAqB;AAChE;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;;AAEA;AACA,mBAAmB,0BAA0B;AAC7C;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,4CAA4C,oBAAoB;AAChE,sCAAsC,oBAAoB;AAC1D;AACA;AACA;;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B,qBAAqB;AAC/C;AACA,8DAA8D,QAAQ;AACtE,8DAA8D,QAAQ;AACtE,yCAAyC,QAAQ;AACjD;AACA;AACA;AACA;AACA;AACA,kDAAkD,QAAQ;AAC1D;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA;AACA,+BAA+B,iCAAiC;AAChE;AACA;AACA,8CAA8C,wBAAwB;AACtE;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B,qBAAqB;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA,sDAAsD,QAAQ;AAC9D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wDAAwD,QAAQ;;AAEhE;AACA;;AAEA;AACA;AACA,0HAA0H,QAAQ;;AAElI;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,cAAc,cAAc;;AAE5B;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8BAA8B,4IAA4I;AAC1K,KAAK;AACL;AACA,8BAA8B,2IAA2I;AACzK;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA,+BAA+B,QAAQ;;AAEvC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B,qBAAqB;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,gCAAgC,iCAAiC;AACjE;AACA,4CAA4C,QAAQ;AACpD;AACA,SAAS;AACT;AACA;AACA,gCAAgC,iCAAiC;AACjE;AACA;AACA;;AAEA;AACA;AACA,8BAA8B,0BAA0B;AACxD,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,kBAAkB,4BAA4B;;AAE9C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA,qDAAqD,qBAAqB;AAC1E,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA,qDAAqD,qBAAqB;AAC1E,SAAS;AACT;AACA,yBAAyB,qBAAqB;AAC9C;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA,SAAS;AACT;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2EAA2E,QAAQ;AACnF;;AAEA;AACA;AACA;AACA,gDAAgD,QAAQ;AACxD;AACA,aAAa;AACb,WAAW;AACX,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gDAAgD,QAAQ;AACxD;AACA,aAAa;AACb;AACA,SAAS;AACT;AACA;;AAEA;AACA;AACA,OAAO;AACP;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,mBAAmB,uBAAuB;AAC1C;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8CAA8C,mDAAmD;AACjG,cAAc,2BAA2B;AACzC;AACA;AACA,mDAAmD,mDAAmD;AACtG,cAAc,2BAA2B;AACzC;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA,qCAAqC,QAAQ;;AAE7C;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,wCAAwC,oBAAoB;AAC5D;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA,4HAA4H,gCAAgC;AAC5J;AACA,mGAAmG,mCAAmC;AACtI;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA,8HAA8H,gCAAgC;AAC9J;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,2CAA2C;AAC3C;AACA;AACA,iFAAiF,QAAQ;;AAEzF;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,kDAAkD,QAAQ;AAC1D;AACA;AACA,WAAW;AACX;AACA,WAAW;AACX;AACA;AACA,SAAS;AACT;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,OAAO;;AAEP;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,uBAAuB,kBAAkB;AACzC;AACA;AACA;AACA;AACA,KAAK;AACL,iCAAiC,0CAA0C,EAAE;AAC7E,mBAAmB,mBAAmB;AACtC;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;;AAEA,qBAAqB;;AAErB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,KAAK;;AAEL;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA,iBAAiB;;AAEjB;AACA;AACA;AACA,qBAAqB,YAAY;AACjC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,4FAA4F,QAAQ;AACpG,8CAA8C,0BAA0B;AACxE;AACA,gDAAgD,iBAAiB;AACjE;AACA;AACA;AACA,mBAAmB,gCAAgC;AACnD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,wCAAwC,kDAAkD;;AAE1F;AACA;AACA;AACA;AACA;;AAEA,yBAAyB;;AAEzB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,oBAAoB,aAAa;;AAEjC,8BAA8B;AAC9B,6BAA6B,gBAAgB;;AAE7C;;AAEA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;;AAEP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0EAA0E,QAAQ;AAClF,0EAA0E,QAAQ;AAClF;AACA,uCAAuC;AACvC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yCAAyC,4BAA4B,kBAAkB;AACvF;AACA,OAAO;;AAEP;AACA,wCAAwC;AACxC;;AAEA;AACA,qCAAqC;AACrC,6CAA6C;AAC7C,2CAA2C;;AAE3C;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,yCAAyC,WAAW,kBAAkB;AACtE;AACA,SAAS;AACT;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;;AAET;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;;AAET;AACA;AACA;;AAEA,OAAO;;AAEP;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,2BAA2B,oBAAoB,qBAAqB,YAAY,qBAAqB,SAAS,qBAAqB,KAAK,qBAAqB;;AAE7J;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qCAAqC,mBAAmB;AACxD;AACA;AACA;AACA,yCAAyC,kBAAkB;AAC3D;AACA;AACA,uCAAuC,UAAU;AACjD;AACA;AACA;AACA,yCAAyC,kBAAkB;AAC3D;AACA;AACA,OAAO;AACP,uCAAuC,qBAAqB;AAC5D;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,wCAAwC,QAAQ;AAChD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,OAAO;;AAEP;AACA,uBAAuB,iBAAiB;;AAExC;AACA;;AAEA;AACA;AACA,+BAA+B,QAAQ;;AAEvC;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,OAAO;;AAEP;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qEAAqE,QAAQ;AAC7E;AACA;AACA,WAAW;AACX;AACA,qEAAqE,QAAQ;AAC7E;AACA,WAAW;AACX,SAAS;AACT,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,SAAS;AACT;AACA;AACA,OAAO;;AAEP;AACA;AACA;AACA;AACA,OAAO;;AAEP;AACA,KAAK;AACL;AACA;AACA,yDAAyD,QAAQ;AACjE;AACA;AACA,uBAAuB,6BAA6B;AACpD;AACA;AACA;AACA;AACA,6CAA6C,gDAAgD;;AAE7F;AACA,oDAAoD,oBAAoB;AACxE,KAAK;AACL;AACA;AACA;AACA;AACA,OAAO;AACP;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,gCAAgC,sBAAsB;AACtD,YAAY,qDAAqD;;AAEjE;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,OAAO;;AAEP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8BAA8B,SAAS;AACvC;AACA;AACA;AACA,WAAW;AACX,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,kCAAkC,iBAAiB;AACnD;AACA;AACA;AACA;AACA;AACA,uBAAuB,qBAAqB;AAC5C;AACA;AACA;AACA,WAAW;AACX,mCAAmC,yBAAyB;AAC5D,qCAAqC,0BAA0B;AAC/D;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,2CAA2C,cAAc,EAAE;AAC3D;AACA,OAAO;AACP;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sDAAsD,iDAAiD;AACvG,yBAAyB,wCAAwC;AACjE;AACA,KAAK;AACL;AACA;AACA;AACA,uBAAuB,mBAAmB;AAC1C,0BAA0B,uCAAuC;AACjE;AACA,OAAO;AACP;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;;AAEA;AACA,uBAAuB,mBAAmB;AAC1C,0BAA0B,0CAA0C;AACpE;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,2EAA2E,QAAQ;AACnF;AACA;AACA,8CAA8C,QAAQ;AACtD;AACA;AACA;AACA;AACA,+CAA+C,kBAAkB;AACjE;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA,0CAA0C,kBAAkB;AAC5D;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB;AACnB,SAAS;AACT,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA,6CAA6C,QAAQ;AACrD;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,6CAA6C,QAAQ;AACrD;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA,4BAA4B,qBAAqB,EAAE;AACnD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB,+CAA+C;AACjE;AACA;AACA;AACA;AACA;AACA,uBAAuB,wBAAwB;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB,kBAAkB;AACxC;AACA;AACA;AACA,iCAAiC,oBAAoB;AACrD,gBAAgB,uBAAuB;AACvC;AACA,sFAAsF,oBAAoB;AAC1G,sFAAsF,oBAAoB;AAC1G,OAAO;AACP;AACA,iCAAiC,oBAAoB;AACrD,gBAAgB,uBAAuB;AACvC;AACA,qCAAqC,oBAAoB;AACzD,qCAAqC,oBAAoB;AACzD;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,oCAAoC,QAAQ;AAC5C;AACA;AACA,KAAK;AACL;AACA;AACA,qCAAqC,QAAQ;AAC7C;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;;AAEA;AACA;AACA,8CAA8C;AAC9C;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,4DAA4D,yBAAyB;AACrF;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;;AAEA;AACA,iBAAiB;AACjB;AACA,iBAAiB;;AAEjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,gCAAgC;AAChC;AACA;AACA,SAAS,OAAO;AAChB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;;AAEA,2DAA2D,aAAa;;AAExE,4BAA4B,qBAAqB,EAAE;AACnD;AACA;;AAEA;;AAEA;AACA;AACA,8DAA8D,iCAAiC;AAC/F,gBAAgB,aAAa;AAC7B,SAAS,0DAA0D,qBAAqB;AACxF,cAAc,aAAa;AAC3B,OAAO;AACP;AACA;;AAEA,wBAAwB,aAAa;;AAErC,0BAA0B,gBAAgB;;AAE1C;AACA;AACA;AACA;AACA;AACA;AACA,aAAa,kCAAkC,aAAa;AAC5D,WAAW;AACX;AACA;AACA,WAAW,kCAAkC,aAAa;AAC1D;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,gDAAgD,kCAAkC;AAClF,gDAAgD,kCAAkC;;AAElF;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;;AAEA;AACA,mFAAmF,wBAAwB;AAC3G;AACA,uFAAuF,aAAa;AACpG;;AAEA,6BAA6B,oBAAoB;AACjD,YAAY,uBAAuB;AACnC;AACA,KAAK;AACL;AACA;AACA,8BAA8B,cAAc;AAC5C,sCAAsC,cAAc;AACpD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,8BAA8B,cAAc;AAC5C,uCAAuC,cAAc;AACrD;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA,+CAA+C,4BAA4B;AAC3E,OAAO;AACP;AACA;AACA,wCAAwC,6BAA6B;AACrE,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;;AAEA,+BAA+B,QAAQ;AACvC;AACA;AACA;;AAEA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,sDAAsD,QAAQ;AAC9D;AACA,KAAK;AACL;AACA;AACA;AACA,gDAAgD,QAAQ;AACxD;AACA,KAAK;AACL;AACA;AACA;AACA,8CAA8C,QAAQ;;AAEtD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,gHAAgH,QAAQ;AACxH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,kBAAkB;AACpD,wEAAwE,2BAA2B;AACnG,OAAO;AACP;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,oCAAoC,gBAAgB;AACpD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,gHAAgH,QAAQ;AACxH;;AAEA;AACA;AACA;AACA;AACA,uBAAuB,qBAAqB;AAC5C;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,uBAAuB,QAAQ;;AAE/B;AACA,6BAA6B,QAAQ;;AAErC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,mCAAmC,8BAA8B;AACjE;AACA,SAAS;AACT;;AAEA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA,gHAAgH,QAAQ;AACxH;;AAEA;AACA;AACA,sCAAsC,iEAAiE;AACvG;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kDAAkD,eAAe,EAAE;AACnE,gDAAgD,eAAe,EAAE;AACjE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;AACA,gEAAgE,QAAQ;AACxE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,OAAO;AACP;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA,KAAK;AACL;AACA;AACA,gEAAgE,QAAQ;AACxE;AACA,KAAK;AACL;AACA;AACA,gEAAgE,QAAQ;;AAExE;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;;AAEA;AACA;AACA,OAAO;AACP;AACA;;AAEA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;;AAEA,wCAAwC,QAAQ;AAChD,6BAA6B,oBAAoB;AACjD,YAAY,uBAAuB;AACnC;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;;AAEA,wCAAwC,QAAQ;AAChD;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,wCAAwC,QAAQ;AAChD;AACA;AACA;AACA;AACA;AACA;AACA,iFAAiF,iCAAiC;AAClH,kFAAkF,gCAAgC;AAClH;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,wCAAwC,QAAQ;AAChD;AACA;AACA;AACA;AACA;AACA;AACA,iFAAiF,iCAAiC;AAClH,kFAAkF,gCAAgC;AAClH;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,wCAAwC,QAAQ;AAChD;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,OAAO;;AAEP;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,OAAO;AACP;AACA;AACA;;AAEA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX,OAAO;AACP,KAAK;AACL;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,+BAA+B,sBAAsB;AACrD;AACA,SAAS;AACT,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA,8CAA8C,QAAQ;AACtD;AACA;AACA,OAAO;AACP;AACA;AACA,8CAA8C,QAAQ;AACtD;AACA,OAAO;AACP;AACA;AACA,8CAA8C,QAAQ;AACtD;AACA,OAAO;AACP;AACA;AACA,8CAA8C,QAAQ;AACtD;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;AACA,uCAAuC,UAAU;AACjD;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4CAA4C,yDAAyD;AACrG;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+DAA+D,QAAQ;AACvE;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+DAA+D,QAAQ;AACvE;AACA;AACA;AACA;AACA,6BAA6B,8BAA8B;AAC3D,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,+DAA+D,QAAQ;AACvE,4BAA4B,QAAQ;AACpC,2BAA2B,oBAAoB;AAC/C;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,+DAA+D,QAAQ;AACvE;AACA,kDAAkD,QAAQ;;AAE1D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,mFAAmF,QAAQ;;AAE3F;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,oCAAoC,iDAAiD;AACrF,oCAAoC,iDAAiD;AACrF,+BAA+B,gCAAgC;AAC/D;AACA;AACA,0EAA0E,gBAAgB;AAC1F,0EAA0E,gBAAgB;AAC1F;AACA;AACA;;AAEA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,+DAA+D,QAAQ;AACvE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,6BAA6B,4EAA4E;AACzG,6BAA6B,4EAA4E;AACzG;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,+DAA+D,QAAQ;;AAEvE;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,+DAA+D,QAAQ;;AAEvE;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,yBAAyB,QAAQ;AACjC;;AAEA,sIAAsI,gCAAgC;;AAEtK;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,0BAA0B,QAAQ;;AAElC;;AAEA,sIAAsI,gCAAgC;;AAEtK;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B;AAC1B,4BAA4B;AAC5B,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;;AAEA;AACA;AACA,OAAO;AACP;AACA;AACA,OAAO;;AAEP;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,mCAAmC,QAAQ;AAC3C;AACA,OAAO;AACP;AACA;AACA,mCAAmC,QAAQ;AAC3C;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;;AAEA;AACA;AACA,yCAAyC,QAAQ;AACjD,uCAAuC,QAAQ;AAC/C;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,iCAAiC,QAAQ;;AAEzC;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,8HAA8H,QAAQ;AACtI;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,SAAS;;AAET;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,SAAS,0BAA0B,aAAa;AAChD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,4CAA4C,uCAAuC;AACnF;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP,iCAAiC,iCAAiC;AAClE,8BAA8B,4BAA4B;AAC1D;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qDAAqD,gBAAgB;AACrE,kCAAkC,8BAA8B;AAChE;AACA;AACA,kCAAkC,mBAAmB;AACrD,kCAAkC,8BAA8B;AAChE;AACA,SAAS;AACT;AACA,qCAAqC,gDAAgD;;AAErF;AACA,qCAAqC,gDAAgD;AACrF;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;;AAEA,mCAAmC,kBAAkB;;AAErD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,kBAAkB,UAAU;;AAE5B;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB,uBAAuB;AAC9C;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,8BAA8B,QAAQ;AACtC;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA,mBAAmB,uBAAuB;AAC1C;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA,yCAAyC,QAAQ;AACjD;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,yCAAyC,QAAQ;AACjD;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,yCAAyC,QAAQ;AACjD;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,yCAAyC,QAAQ;AACjD;AACA,OAAO;AACP;AACA;AACA,yCAAyC,QAAQ;AACjD;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,6BAA6B,QAAQ;AACrC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,sCAAsC,QAAQ;AAC9C;AACA;AACA,KAAK;AACL;AACA;;AAEA,+BAA+B,QAAQ;AACvC;AACA;AACA;;AAEA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sFAAsF,OAAO;AAC7F,SAAS;AACT;AACA,KAAK;AACL;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,wEAAwE,iCAAiC;;AAEzG;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gDAAgD,OAAO;AACvD,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA,0CAA0C,QAAQ;AAClD;AACA;AACA,OAAO;AACP;AACA;AACA,0CAA0C,QAAQ;AAClD;AACA,OAAO;AACP;AACA;AACA,0CAA0C,QAAQ;AAClD;AACA,OAAO;AACP;AACA;AACA,0CAA0C,QAAQ;AAClD;AACA,OAAO;AACP;AACA;AACA,0CAA0C,QAAQ;AAClD;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;AACA,mCAAmC,QAAQ;AAC3C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uDAAuD,QAAQ;AAC/D;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA,wFAAwF,oBAAoB,EAAE;AAC9G;AACA;AACA;AACA,cAAc;AACd,KAAK;AACL;AACA;AACA,0EAA0E,QAAQ;AAClF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,eAAe;AACjD,OAAO;AACP,+BAA+B,eAAe;AAC9C;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,sDAAsD,YAAY;AAClE;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8CAA8C,QAAQ;AACtD;AACA;AACA,KAAK;AACL;AACA;AACA,wFAAwF,QAAQ;AAChG;AACA,kHAAkH,KAAE;AACpH,OAAO;AACP;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,8GAA8G,QAAQ;AACtH;AACA;AACA;AACA;AACA,sDAAsD,YAAY;AAClE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA,WAAW;AACX;AACA;AACA,WAAW;AACX;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;AACT;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA,2DAA2D,cAAc;AACzE,oCAAoC,cAAc;AAClD;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,qCAAqC,cAAc;AACnD,2DAA2D,cAAc;;AAEzE;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,qCAAqC,QAAQ;AAC7C,mCAAmC,QAAQ;AAC3C,oCAAoC,uCAAuC;AAC3E;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oEAAoE,QAAQ;AAC5E,oCAAoC,QAAQ;AAC5C;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,WAAW;AACX,SAAS;AACT,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA,qBAAqB,mBAAmB;AACxC;AACA;AACA;AACA,8CAA8C,wBAAwB;AACtE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+BAA+B,QAAQ;AACvC,4CAA4C,QAAQ;AACpD;AACA;AACA;AACA,yBAAyB,0BAA0B;AACnD;AACA;AACA,SAAS;AACT;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA,8CAA8C,QAAQ;AACtD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,8CAA8C,QAAQ;AACtD;AACA,OAAO;AACP;AACA;AACA,8CAA8C,QAAQ;AACtD;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6BAA6B,+BAA+B;AAC5D,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB,mBAAmB;AACxC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,oBAAoB,sDAAsD;AAC1E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oCAAoC,wDAAwD;AAC5F,mCAAmC,sDAAsD;AACzF;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;;AAEP;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA,8CAA8C,QAAQ;AACtD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,8CAA8C,QAAQ;AACtD;AACA,OAAO;AACP;AACA;AACA,8CAA8C,QAAQ;AACtD;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA,qBAAqB,mBAAmB;AACxC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oCAAoC,wDAAwD;AAC5F,mCAAmC,sDAAsD;AACzF;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+BAA+B,QAAQ;AACvC,4CAA4C,QAAQ;AACpD;AACA;AACA;AACA;AACA,yBAAyB,0BAA0B;AACnD;AACA;AACA,SAAS;AACT;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA,8CAA8C,QAAQ;AACtD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,8CAA8C,QAAQ;AACtD;AACA,OAAO;AACP;AACA;AACA,8CAA8C,QAAQ;AACtD;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6CAA6C,YAAY;AACzD;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,2CAA2C,gBAAgB;AAC3D,2CAA2C,gBAAgB;AAC3D,2CAA2C,gBAAgB;AAC3D,wCAAwC,aAAa;AACrD,wCAAwC,aAAa;;AAErD;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uCAAuC,gFAAgF;AACvH,sCAAsC,mFAAmF;AACzH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA,mDAAmD,QAAQ;;AAE3D;AACA;;AAEA;AACA;AACA,OAAO;AACP;AACA;AACA,mDAAmD,QAAQ;AAC3D;AACA,OAAO;AACP;AACA;AACA,mDAAmD,QAAQ;AAC3D;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP,8DAA8D;AAC9D;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,0BAA0B,QAAQ;AAClC;AACA;AACA,iGAAiG,QAAQ;AACzG,yEAAyE,QAAQ;AACjF;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+CAA+C,0BAA0B;AACzE,oDAAoD,0BAA0B;AAC9E,uEAAuE,0BAA0B;AACjG,cAAc,0BAA0B;AACxC;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,0BAA0B,QAAQ;;AAElC;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uDAAuD,kCAAkC;AACzF,4DAA4D,kCAAkC;AAC9F,mGAAmG,qCAAqC;AACxI,iGAAiG,kCAAkC;AACnI,gBAAgB,kCAAkC;AAClD,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,uBAAuB,sBAAsB;AAC7C;AACA;AACA,OAAO;AACP,yBAAyB,wBAAwB;AACjD;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;A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","file":"draggable-components.common.js","sourcesContent":[" \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = \"fb15\");\n","export * from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./hotProduct.vue?vue&type=style&index=0&id=ae70b464&prod&scoped=true&lang=scss\"","/**\n * Swiper 4.5.1\n * Most modern mobile touch slider and framework with hardware accelerated transitions\n * http://www.idangero.us/swiper/\n *\n * Copyright 2014-2019 Vladimir Kharlampidi\n *\n * Released under the MIT License\n *\n * Released on: September 13, 2019\n */\n\n(function (global, factory) {\n typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :\n typeof define === 'function' && define.amd ? define(factory) :\n (global = global || self, global.Swiper = factory());\n}(this, function () { 'use strict';\n\n /**\n * SSR Window 1.0.1\n * Better handling for window object in SSR environment\n * https://github.com/nolimits4web/ssr-window\n *\n * Copyright 2018, Vladimir Kharlampidi\n *\n * Licensed under MIT\n *\n * Released on: July 18, 2018\n */\n var doc = (typeof document === 'undefined') ? {\n body: {},\n addEventListener: function addEventListener() {},\n removeEventListener: function removeEventListener() {},\n activeElement: {\n blur: function blur() {},\n nodeName: '',\n },\n querySelector: function querySelector() {\n return null;\n },\n querySelectorAll: function querySelectorAll() {\n return [];\n },\n getElementById: function getElementById() {\n return null;\n },\n createEvent: function createEvent() {\n return {\n initEvent: function initEvent() {},\n };\n },\n createElement: function createElement() {\n return {\n children: [],\n childNodes: [],\n style: {},\n setAttribute: function setAttribute() {},\n getElementsByTagName: function getElementsByTagName() {\n return [];\n },\n };\n },\n location: { hash: '' },\n } : document; // eslint-disable-line\n\n var win = (typeof window === 'undefined') ? {\n document: doc,\n navigator: {\n userAgent: '',\n },\n location: {},\n history: {},\n CustomEvent: function CustomEvent() {\n return this;\n },\n addEventListener: function addEventListener() {},\n removeEventListener: function removeEventListener() {},\n getComputedStyle: function getComputedStyle() {\n return {\n getPropertyValue: function getPropertyValue() {\n return '';\n },\n };\n },\n Image: function Image() {},\n Date: function Date() {},\n screen: {},\n setTimeout: function setTimeout() {},\n clearTimeout: function clearTimeout() {},\n } : window; // eslint-disable-line\n\n /**\n * Dom7 2.1.3\n * Minimalistic JavaScript library for DOM manipulation, with a jQuery-compatible API\n * http://framework7.io/docs/dom.html\n *\n * Copyright 2019, Vladimir Kharlampidi\n * The iDangero.us\n * http://www.idangero.us/\n *\n * Licensed under MIT\n *\n * Released on: February 11, 2019\n */\n\n var Dom7 = function Dom7(arr) {\n var self = this;\n // Create array-like object\n for (var i = 0; i < arr.length; i += 1) {\n self[i] = arr[i];\n }\n self.length = arr.length;\n // Return collection with methods\n return this;\n };\n\n function $(selector, context) {\n var arr = [];\n var i = 0;\n if (selector && !context) {\n if (selector instanceof Dom7) {\n return selector;\n }\n }\n if (selector) {\n // String\n if (typeof selector === 'string') {\n var els;\n var tempParent;\n var html = selector.trim();\n if (html.indexOf('<') >= 0 && html.indexOf('>') >= 0) {\n var toCreate = 'div';\n if (html.indexOf('<li') === 0) { toCreate = 'ul'; }\n if (html.indexOf('<tr') === 0) { toCreate = 'tbody'; }\n if (html.indexOf('<td') === 0 || html.indexOf('<th') === 0) { toCreate = 'tr'; }\n if (html.indexOf('<tbody') === 0) { toCreate = 'table'; }\n if (html.indexOf('<option') === 0) { toCreate = 'select'; }\n tempParent = doc.createElement(toCreate);\n tempParent.innerHTML = html;\n for (i = 0; i < tempParent.childNodes.length; i += 1) {\n arr.push(tempParent.childNodes[i]);\n }\n } else {\n if (!context && selector[0] === '#' && !selector.match(/[ .<>:~]/)) {\n // Pure ID selector\n els = [doc.getElementById(selector.trim().split('#')[1])];\n } else {\n // Other selectors\n els = (context || doc).querySelectorAll(selector.trim());\n }\n for (i = 0; i < els.length; i += 1) {\n if (els[i]) { arr.push(els[i]); }\n }\n }\n } else if (selector.nodeType || selector === win || selector === doc) {\n // Node/element\n arr.push(selector);\n } else if (selector.length > 0 && selector[0].nodeType) {\n // Array of elements or instance of Dom\n for (i = 0; i < selector.length; i += 1) {\n arr.push(selector[i]);\n }\n }\n }\n return new Dom7(arr);\n }\n\n $.fn = Dom7.prototype;\n $.Class = Dom7;\n $.Dom7 = Dom7;\n\n function unique(arr) {\n var uniqueArray = [];\n for (var i = 0; i < arr.length; i += 1) {\n if (uniqueArray.indexOf(arr[i]) === -1) { uniqueArray.push(arr[i]); }\n }\n return uniqueArray;\n }\n\n // Classes and attributes\n function addClass(className) {\n if (typeof className === 'undefined') {\n return this;\n }\n var classes = className.split(' ');\n for (var i = 0; i < classes.length; i += 1) {\n for (var j = 0; j < this.length; j += 1) {\n if (typeof this[j] !== 'undefined' && typeof this[j].classList !== 'undefined') { this[j].classList.add(classes[i]); }\n }\n }\n return this;\n }\n function removeClass(className) {\n var classes = className.split(' ');\n for (var i = 0; i < classes.length; i += 1) {\n for (var j = 0; j < this.length; j += 1) {\n if (typeof this[j] !== 'undefined' && typeof this[j].classList !== 'undefined') { this[j].classList.remove(classes[i]); }\n }\n }\n return this;\n }\n function hasClass(className) {\n if (!this[0]) { return false; }\n return this[0].classList.contains(className);\n }\n function toggleClass(className) {\n var classes = className.split(' ');\n for (var i = 0; i < classes.length; i += 1) {\n for (var j = 0; j < this.length; j += 1) {\n if (typeof this[j] !== 'undefined' && typeof this[j].classList !== 'undefined') { this[j].classList.toggle(classes[i]); }\n }\n }\n return this;\n }\n function attr(attrs, value) {\n var arguments$1 = arguments;\n\n if (arguments.length === 1 && typeof attrs === 'string') {\n // Get attr\n if (this[0]) { return this[0].getAttribute(attrs); }\n return undefined;\n }\n\n // Set attrs\n for (var i = 0; i < this.length; i += 1) {\n if (arguments$1.length === 2) {\n // String\n this[i].setAttribute(attrs, value);\n } else {\n // Object\n // eslint-disable-next-line\n for (var attrName in attrs) {\n this[i][attrName] = attrs[attrName];\n this[i].setAttribute(attrName, attrs[attrName]);\n }\n }\n }\n return this;\n }\n // eslint-disable-next-line\n function removeAttr(attr) {\n for (var i = 0; i < this.length; i += 1) {\n this[i].removeAttribute(attr);\n }\n return this;\n }\n function data(key, value) {\n var el;\n if (typeof value === 'undefined') {\n el = this[0];\n // Get value\n if (el) {\n if (el.dom7ElementDataStorage && (key in el.dom7ElementDataStorage)) {\n return el.dom7ElementDataStorage[key];\n }\n\n var dataKey = el.getAttribute((\"data-\" + key));\n if (dataKey) {\n return dataKey;\n }\n return undefined;\n }\n return undefined;\n }\n\n // Set value\n for (var i = 0; i < this.length; i += 1) {\n el = this[i];\n if (!el.dom7ElementDataStorage) { el.dom7ElementDataStorage = {}; }\n el.dom7ElementDataStorage[key] = value;\n }\n return this;\n }\n // Transforms\n // eslint-disable-next-line\n function transform(transform) {\n for (var i = 0; i < this.length; i += 1) {\n var elStyle = this[i].style;\n elStyle.webkitTransform = transform;\n elStyle.transform = transform;\n }\n return this;\n }\n function transition(duration) {\n if (typeof duration !== 'string') {\n duration = duration + \"ms\"; // eslint-disable-line\n }\n for (var i = 0; i < this.length; i += 1) {\n var elStyle = this[i].style;\n elStyle.webkitTransitionDuration = duration;\n elStyle.transitionDuration = duration;\n }\n return this;\n }\n // Events\n function on() {\n var assign;\n\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n var eventType = args[0];\n var targetSelector = args[1];\n var listener = args[2];\n var capture = args[3];\n if (typeof args[1] === 'function') {\n (assign = args, eventType = assign[0], listener = assign[1], capture = assign[2]);\n targetSelector = undefined;\n }\n if (!capture) { capture = false; }\n\n function handleLiveEvent(e) {\n var target = e.target;\n if (!target) { return; }\n var eventData = e.target.dom7EventData || [];\n if (eventData.indexOf(e) < 0) {\n eventData.unshift(e);\n }\n if ($(target).is(targetSelector)) { listener.apply(target, eventData); }\n else {\n var parents = $(target).parents(); // eslint-disable-line\n for (var k = 0; k < parents.length; k += 1) {\n if ($(parents[k]).is(targetSelector)) { listener.apply(parents[k], eventData); }\n }\n }\n }\n function handleEvent(e) {\n var eventData = e && e.target ? e.target.dom7EventData || [] : [];\n if (eventData.indexOf(e) < 0) {\n eventData.unshift(e);\n }\n listener.apply(this, eventData);\n }\n var events = eventType.split(' ');\n var j;\n for (var i = 0; i < this.length; i += 1) {\n var el = this[i];\n if (!targetSelector) {\n for (j = 0; j < events.length; j += 1) {\n var event = events[j];\n if (!el.dom7Listeners) { el.dom7Listeners = {}; }\n if (!el.dom7Listeners[event]) { el.dom7Listeners[event] = []; }\n el.dom7Listeners[event].push({\n listener: listener,\n proxyListener: handleEvent,\n });\n el.addEventListener(event, handleEvent, capture);\n }\n } else {\n // Live events\n for (j = 0; j < events.length; j += 1) {\n var event$1 = events[j];\n if (!el.dom7LiveListeners) { el.dom7LiveListeners = {}; }\n if (!el.dom7LiveListeners[event$1]) { el.dom7LiveListeners[event$1] = []; }\n el.dom7LiveListeners[event$1].push({\n listener: listener,\n proxyListener: handleLiveEvent,\n });\n el.addEventListener(event$1, handleLiveEvent, capture);\n }\n }\n }\n return this;\n }\n function off() {\n var assign;\n\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n var eventType = args[0];\n var targetSelector = args[1];\n var listener = args[2];\n var capture = args[3];\n if (typeof args[1] === 'function') {\n (assign = args, eventType = assign[0], listener = assign[1], capture = assign[2]);\n targetSelector = undefined;\n }\n if (!capture) { capture = false; }\n\n var events = eventType.split(' ');\n for (var i = 0; i < events.length; i += 1) {\n var event = events[i];\n for (var j = 0; j < this.length; j += 1) {\n var el = this[j];\n var handlers = (void 0);\n if (!targetSelector && el.dom7Listeners) {\n handlers = el.dom7Listeners[event];\n } else if (targetSelector && el.dom7LiveListeners) {\n handlers = el.dom7LiveListeners[event];\n }\n if (handlers && handlers.length) {\n for (var k = handlers.length - 1; k >= 0; k -= 1) {\n var handler = handlers[k];\n if (listener && handler.listener === listener) {\n el.removeEventListener(event, handler.proxyListener, capture);\n handlers.splice(k, 1);\n } else if (listener && handler.listener && handler.listener.dom7proxy && handler.listener.dom7proxy === listener) {\n el.removeEventListener(event, handler.proxyListener, capture);\n handlers.splice(k, 1);\n } else if (!listener) {\n el.removeEventListener(event, handler.proxyListener, capture);\n handlers.splice(k, 1);\n }\n }\n }\n }\n }\n return this;\n }\n function trigger() {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var events = args[0].split(' ');\n var eventData = args[1];\n for (var i = 0; i < events.length; i += 1) {\n var event = events[i];\n for (var j = 0; j < this.length; j += 1) {\n var el = this[j];\n var evt = (void 0);\n try {\n evt = new win.CustomEvent(event, {\n detail: eventData,\n bubbles: true,\n cancelable: true,\n });\n } catch (e) {\n evt = doc.createEvent('Event');\n evt.initEvent(event, true, true);\n evt.detail = eventData;\n }\n // eslint-disable-next-line\n el.dom7EventData = args.filter(function (data, dataIndex) { return dataIndex > 0; });\n el.dispatchEvent(evt);\n el.dom7EventData = [];\n delete el.dom7EventData;\n }\n }\n return this;\n }\n function transitionEnd(callback) {\n var events = ['webkitTransitionEnd', 'transitionend'];\n var dom = this;\n var i;\n function fireCallBack(e) {\n /* jshint validthis:true */\n if (e.target !== this) { return; }\n callback.call(this, e);\n for (i = 0; i < events.length; i += 1) {\n dom.off(events[i], fireCallBack);\n }\n }\n if (callback) {\n for (i = 0; i < events.length; i += 1) {\n dom.on(events[i], fireCallBack);\n }\n }\n return this;\n }\n function outerWidth(includeMargins) {\n if (this.length > 0) {\n if (includeMargins) {\n // eslint-disable-next-line\n var styles = this.styles();\n return this[0].offsetWidth + parseFloat(styles.getPropertyValue('margin-right')) + parseFloat(styles.getPropertyValue('margin-left'));\n }\n return this[0].offsetWidth;\n }\n return null;\n }\n function outerHeight(includeMargins) {\n if (this.length > 0) {\n if (includeMargins) {\n // eslint-disable-next-line\n var styles = this.styles();\n return this[0].offsetHeight + parseFloat(styles.getPropertyValue('margin-top')) + parseFloat(styles.getPropertyValue('margin-bottom'));\n }\n return this[0].offsetHeight;\n }\n return null;\n }\n function offset() {\n if (this.length > 0) {\n var el = this[0];\n var box = el.getBoundingClientRect();\n var body = doc.body;\n var clientTop = el.clientTop || body.clientTop || 0;\n var clientLeft = el.clientLeft || body.clientLeft || 0;\n var scrollTop = el === win ? win.scrollY : el.scrollTop;\n var scrollLeft = el === win ? win.scrollX : el.scrollLeft;\n return {\n top: (box.top + scrollTop) - clientTop,\n left: (box.left + scrollLeft) - clientLeft,\n };\n }\n\n return null;\n }\n function styles() {\n if (this[0]) { return win.getComputedStyle(this[0], null); }\n return {};\n }\n function css(props, value) {\n var i;\n if (arguments.length === 1) {\n if (typeof props === 'string') {\n if (this[0]) { return win.getComputedStyle(this[0], null).getPropertyValue(props); }\n } else {\n for (i = 0; i < this.length; i += 1) {\n // eslint-disable-next-line\n for (var prop in props) {\n this[i].style[prop] = props[prop];\n }\n }\n return this;\n }\n }\n if (arguments.length === 2 && typeof props === 'string') {\n for (i = 0; i < this.length; i += 1) {\n this[i].style[props] = value;\n }\n return this;\n }\n return this;\n }\n // Iterate over the collection passing elements to `callback`\n function each(callback) {\n // Don't bother continuing without a callback\n if (!callback) { return this; }\n // Iterate over the current collection\n for (var i = 0; i < this.length; i += 1) {\n // If the callback returns false\n if (callback.call(this[i], i, this[i]) === false) {\n // End the loop early\n return this;\n }\n }\n // Return `this` to allow chained DOM operations\n return this;\n }\n // eslint-disable-next-line\n function html(html) {\n if (typeof html === 'undefined') {\n return this[0] ? this[0].innerHTML : undefined;\n }\n\n for (var i = 0; i < this.length; i += 1) {\n this[i].innerHTML = html;\n }\n return this;\n }\n // eslint-disable-next-line\n function text(text) {\n if (typeof text === 'undefined') {\n if (this[0]) {\n return this[0].textContent.trim();\n }\n return null;\n }\n\n for (var i = 0; i < this.length; i += 1) {\n this[i].textContent = text;\n }\n return this;\n }\n function is(selector) {\n var el = this[0];\n var compareWith;\n var i;\n if (!el || typeof selector === 'undefined') { return false; }\n if (typeof selector === 'string') {\n if (el.matches) { return el.matches(selector); }\n else if (el.webkitMatchesSelector) { return el.webkitMatchesSelector(selector); }\n else if (el.msMatchesSelector) { return el.msMatchesSelector(selector); }\n\n compareWith = $(selector);\n for (i = 0; i < compareWith.length; i += 1) {\n if (compareWith[i] === el) { return true; }\n }\n return false;\n } else if (selector === doc) { return el === doc; }\n else if (selector === win) { return el === win; }\n\n if (selector.nodeType || selector instanceof Dom7) {\n compareWith = selector.nodeType ? [selector] : selector;\n for (i = 0; i < compareWith.length; i += 1) {\n if (compareWith[i] === el) { return true; }\n }\n return false;\n }\n return false;\n }\n function index() {\n var child = this[0];\n var i;\n if (child) {\n i = 0;\n // eslint-disable-next-line\n while ((child = child.previousSibling) !== null) {\n if (child.nodeType === 1) { i += 1; }\n }\n return i;\n }\n return undefined;\n }\n // eslint-disable-next-line\n function eq(index) {\n if (typeof index === 'undefined') { return this; }\n var length = this.length;\n var returnIndex;\n if (index > length - 1) {\n return new Dom7([]);\n }\n if (index < 0) {\n returnIndex = length + index;\n if (returnIndex < 0) { return new Dom7([]); }\n return new Dom7([this[returnIndex]]);\n }\n return new Dom7([this[index]]);\n }\n function append() {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var newChild;\n\n for (var k = 0; k < args.length; k += 1) {\n newChild = args[k];\n for (var i = 0; i < this.length; i += 1) {\n if (typeof newChild === 'string') {\n var tempDiv = doc.createElement('div');\n tempDiv.innerHTML = newChild;\n while (tempDiv.firstChild) {\n this[i].appendChild(tempDiv.firstChild);\n }\n } else if (newChild instanceof Dom7) {\n for (var j = 0; j < newChild.length; j += 1) {\n this[i].appendChild(newChild[j]);\n }\n } else {\n this[i].appendChild(newChild);\n }\n }\n }\n\n return this;\n }\n function prepend(newChild) {\n var i;\n var j;\n for (i = 0; i < this.length; i += 1) {\n if (typeof newChild === 'string') {\n var tempDiv = doc.createElement('div');\n tempDiv.innerHTML = newChild;\n for (j = tempDiv.childNodes.length - 1; j >= 0; j -= 1) {\n this[i].insertBefore(tempDiv.childNodes[j], this[i].childNodes[0]);\n }\n } else if (newChild instanceof Dom7) {\n for (j = 0; j < newChild.length; j += 1) {\n this[i].insertBefore(newChild[j], this[i].childNodes[0]);\n }\n } else {\n this[i].insertBefore(newChild, this[i].childNodes[0]);\n }\n }\n return this;\n }\n function next(selector) {\n if (this.length > 0) {\n if (selector) {\n if (this[0].nextElementSibling && $(this[0].nextElementSibling).is(selector)) {\n return new Dom7([this[0].nextElementSibling]);\n }\n return new Dom7([]);\n }\n\n if (this[0].nextElementSibling) { return new Dom7([this[0].nextElementSibling]); }\n return new Dom7([]);\n }\n return new Dom7([]);\n }\n function nextAll(selector) {\n var nextEls = [];\n var el = this[0];\n if (!el) { return new Dom7([]); }\n while (el.nextElementSibling) {\n var next = el.nextElementSibling; // eslint-disable-line\n if (selector) {\n if ($(next).is(selector)) { nextEls.push(next); }\n } else { nextEls.push(next); }\n el = next;\n }\n return new Dom7(nextEls);\n }\n function prev(selector) {\n if (this.length > 0) {\n var el = this[0];\n if (selector) {\n if (el.previousElementSibling && $(el.previousElementSibling).is(selector)) {\n return new Dom7([el.previousElementSibling]);\n }\n return new Dom7([]);\n }\n\n if (el.previousElementSibling) { return new Dom7([el.previousElementSibling]); }\n return new Dom7([]);\n }\n return new Dom7([]);\n }\n function prevAll(selector) {\n var prevEls = [];\n var el = this[0];\n if (!el) { return new Dom7([]); }\n while (el.previousElementSibling) {\n var prev = el.previousElementSibling; // eslint-disable-line\n if (selector) {\n if ($(prev).is(selector)) { prevEls.push(prev); }\n } else { prevEls.push(prev); }\n el = prev;\n }\n return new Dom7(prevEls);\n }\n function parent(selector) {\n var parents = []; // eslint-disable-line\n for (var i = 0; i < this.length; i += 1) {\n if (this[i].parentNode !== null) {\n if (selector) {\n if ($(this[i].parentNode).is(selector)) { parents.push(this[i].parentNode); }\n } else {\n parents.push(this[i].parentNode);\n }\n }\n }\n return $(unique(parents));\n }\n function parents(selector) {\n var parents = []; // eslint-disable-line\n for (var i = 0; i < this.length; i += 1) {\n var parent = this[i].parentNode; // eslint-disable-line\n while (parent) {\n if (selector) {\n if ($(parent).is(selector)) { parents.push(parent); }\n } else {\n parents.push(parent);\n }\n parent = parent.parentNode;\n }\n }\n return $(unique(parents));\n }\n function closest(selector) {\n var closest = this; // eslint-disable-line\n if (typeof selector === 'undefined') {\n return new Dom7([]);\n }\n if (!closest.is(selector)) {\n closest = closest.parents(selector).eq(0);\n }\n return closest;\n }\n function find(selector) {\n var foundElements = [];\n for (var i = 0; i < this.length; i += 1) {\n var found = this[i].querySelectorAll(selector);\n for (var j = 0; j < found.length; j += 1) {\n foundElements.push(found[j]);\n }\n }\n return new Dom7(foundElements);\n }\n function children(selector) {\n var children = []; // eslint-disable-line\n for (var i = 0; i < this.length; i += 1) {\n var childNodes = this[i].childNodes;\n\n for (var j = 0; j < childNodes.length; j += 1) {\n if (!selector) {\n if (childNodes[j].nodeType === 1) { children.push(childNodes[j]); }\n } else if (childNodes[j].nodeType === 1 && $(childNodes[j]).is(selector)) {\n children.push(childNodes[j]);\n }\n }\n }\n return new Dom7(unique(children));\n }\n function remove() {\n for (var i = 0; i < this.length; i += 1) {\n if (this[i].parentNode) { this[i].parentNode.removeChild(this[i]); }\n }\n return this;\n }\n function add() {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var dom = this;\n var i;\n var j;\n for (i = 0; i < args.length; i += 1) {\n var toAdd = $(args[i]);\n for (j = 0; j < toAdd.length; j += 1) {\n dom[dom.length] = toAdd[j];\n dom.length += 1;\n }\n }\n return dom;\n }\n\n var Methods = {\n addClass: addClass,\n removeClass: removeClass,\n hasClass: hasClass,\n toggleClass: toggleClass,\n attr: attr,\n removeAttr: removeAttr,\n data: data,\n transform: transform,\n transition: transition,\n on: on,\n off: off,\n trigger: trigger,\n transitionEnd: transitionEnd,\n outerWidth: outerWidth,\n outerHeight: outerHeight,\n offset: offset,\n css: css,\n each: each,\n html: html,\n text: text,\n is: is,\n index: index,\n eq: eq,\n append: append,\n prepend: prepend,\n next: next,\n nextAll: nextAll,\n prev: prev,\n prevAll: prevAll,\n parent: parent,\n parents: parents,\n closest: closest,\n find: find,\n children: children,\n remove: remove,\n add: add,\n styles: styles,\n };\n\n Object.keys(Methods).forEach(function (methodName) {\n $.fn[methodName] = $.fn[methodName] || Methods[methodName];\n });\n\n var Utils = {\n deleteProps: function deleteProps(obj) {\n var object = obj;\n Object.keys(object).forEach(function (key) {\n try {\n object[key] = null;\n } catch (e) {\n // no getter for object\n }\n try {\n delete object[key];\n } catch (e) {\n // something got wrong\n }\n });\n },\n nextTick: function nextTick(callback, delay) {\n if ( delay === void 0 ) delay = 0;\n\n return setTimeout(callback, delay);\n },\n now: function now() {\n return Date.now();\n },\n getTranslate: function getTranslate(el, axis) {\n if ( axis === void 0 ) axis = 'x';\n\n var matrix;\n var curTransform;\n var transformMatrix;\n\n var curStyle = win.getComputedStyle(el, null);\n\n if (win.WebKitCSSMatrix) {\n curTransform = curStyle.transform || curStyle.webkitTransform;\n if (curTransform.split(',').length > 6) {\n curTransform = curTransform.split(', ').map(function (a) { return a.replace(',', '.'); }).join(', ');\n }\n // Some old versions of Webkit choke when 'none' is passed; pass\n // empty string instead in this case\n transformMatrix = new win.WebKitCSSMatrix(curTransform === 'none' ? '' : curTransform);\n } else {\n transformMatrix = curStyle.MozTransform || curStyle.OTransform || curStyle.MsTransform || curStyle.msTransform || curStyle.transform || curStyle.getPropertyValue('transform').replace('translate(', 'matrix(1, 0, 0, 1,');\n matrix = transformMatrix.toString().split(',');\n }\n\n if (axis === 'x') {\n // Latest Chrome and webkits Fix\n if (win.WebKitCSSMatrix) { curTransform = transformMatrix.m41; }\n // Crazy IE10 Matrix\n else if (matrix.length === 16) { curTransform = parseFloat(matrix[12]); }\n // Normal Browsers\n else { curTransform = parseFloat(matrix[4]); }\n }\n if (axis === 'y') {\n // Latest Chrome and webkits Fix\n if (win.WebKitCSSMatrix) { curTransform = transformMatrix.m42; }\n // Crazy IE10 Matrix\n else if (matrix.length === 16) { curTransform = parseFloat(matrix[13]); }\n // Normal Browsers\n else { curTransform = parseFloat(matrix[5]); }\n }\n return curTransform || 0;\n },\n parseUrlQuery: function parseUrlQuery(url) {\n var query = {};\n var urlToParse = url || win.location.href;\n var i;\n var params;\n var param;\n var length;\n if (typeof urlToParse === 'string' && urlToParse.length) {\n urlToParse = urlToParse.indexOf('?') > -1 ? urlToParse.replace(/\\S*\\?/, '') : '';\n params = urlToParse.split('&').filter(function (paramsPart) { return paramsPart !== ''; });\n length = params.length;\n\n for (i = 0; i < length; i += 1) {\n param = params[i].replace(/#\\S+/g, '').split('=');\n query[decodeURIComponent(param[0])] = typeof param[1] === 'undefined' ? undefined : decodeURIComponent(param[1]) || '';\n }\n }\n return query;\n },\n isObject: function isObject(o) {\n return typeof o === 'object' && o !== null && o.constructor && o.constructor === Object;\n },\n extend: function extend() {\n var args = [], len$1 = arguments.length;\n while ( len$1-- ) args[ len$1 ] = arguments[ len$1 ];\n\n var to = Object(args[0]);\n for (var i = 1; i < args.length; i += 1) {\n var nextSource = args[i];\n if (nextSource !== undefined && nextSource !== null) {\n var keysArray = Object.keys(Object(nextSource));\n for (var nextIndex = 0, len = keysArray.length; nextIndex < len; nextIndex += 1) {\n var nextKey = keysArray[nextIndex];\n var desc = Object.getOwnPropertyDescriptor(nextSource, nextKey);\n if (desc !== undefined && desc.enumerable) {\n if (Utils.isObject(to[nextKey]) && Utils.isObject(nextSource[nextKey])) {\n Utils.extend(to[nextKey], nextSource[nextKey]);\n } else if (!Utils.isObject(to[nextKey]) && Utils.isObject(nextSource[nextKey])) {\n to[nextKey] = {};\n Utils.extend(to[nextKey], nextSource[nextKey]);\n } else {\n to[nextKey] = nextSource[nextKey];\n }\n }\n }\n }\n }\n return to;\n },\n };\n\n var Support = (function Support() {\n var testDiv = doc.createElement('div');\n return {\n touch: (win.Modernizr && win.Modernizr.touch === true) || (function checkTouch() {\n return !!((win.navigator.maxTouchPoints > 0) || ('ontouchstart' in win) || (win.DocumentTouch && doc instanceof win.DocumentTouch));\n }()),\n\n pointerEvents: !!(win.navigator.pointerEnabled || win.PointerEvent || ('maxTouchPoints' in win.navigator && win.navigator.maxTouchPoints > 0)),\n prefixedPointerEvents: !!win.navigator.msPointerEnabled,\n\n transition: (function checkTransition() {\n var style = testDiv.style;\n return ('transition' in style || 'webkitTransition' in style || 'MozTransition' in style);\n }()),\n transforms3d: (win.Modernizr && win.Modernizr.csstransforms3d === true) || (function checkTransforms3d() {\n var style = testDiv.style;\n return ('webkitPerspective' in style || 'MozPerspective' in style || 'OPerspective' in style || 'MsPerspective' in style || 'perspective' in style);\n }()),\n\n flexbox: (function checkFlexbox() {\n var style = testDiv.style;\n var styles = ('alignItems webkitAlignItems webkitBoxAlign msFlexAlign mozBoxAlign webkitFlexDirection msFlexDirection mozBoxDirection mozBoxOrient webkitBoxDirection webkitBoxOrient').split(' ');\n for (var i = 0; i < styles.length; i += 1) {\n if (styles[i] in style) { return true; }\n }\n return false;\n }()),\n\n observer: (function checkObserver() {\n return ('MutationObserver' in win || 'WebkitMutationObserver' in win);\n }()),\n\n passiveListener: (function checkPassiveListener() {\n var supportsPassive = false;\n try {\n var opts = Object.defineProperty({}, 'passive', {\n // eslint-disable-next-line\n get: function get() {\n supportsPassive = true;\n },\n });\n win.addEventListener('testPassiveListener', null, opts);\n } catch (e) {\n // No support\n }\n return supportsPassive;\n }()),\n\n gestures: (function checkGestures() {\n return 'ongesturestart' in win;\n }()),\n };\n }());\n\n var Browser = (function Browser() {\n function isSafari() {\n var ua = win.navigator.userAgent.toLowerCase();\n return (ua.indexOf('safari') >= 0 && ua.indexOf('chrome') < 0 && ua.indexOf('android') < 0);\n }\n return {\n isIE: !!win.navigator.userAgent.match(/Trident/g) || !!win.navigator.userAgent.match(/MSIE/g),\n isEdge: !!win.navigator.userAgent.match(/Edge/g),\n isSafari: isSafari(),\n isUiWebView: /(iPhone|iPod|iPad).*AppleWebKit(?!.*Safari)/i.test(win.navigator.userAgent),\n };\n }());\n\n var SwiperClass = function SwiperClass(params) {\n if ( params === void 0 ) params = {};\n\n var self = this;\n self.params = params;\n\n // Events\n self.eventsListeners = {};\n\n if (self.params && self.params.on) {\n Object.keys(self.params.on).forEach(function (eventName) {\n self.on(eventName, self.params.on[eventName]);\n });\n }\n };\n\n var staticAccessors = { components: { configurable: true } };\n\n SwiperClass.prototype.on = function on (events, handler, priority) {\n var self = this;\n if (typeof handler !== 'function') { return self; }\n var method = priority ? 'unshift' : 'push';\n events.split(' ').forEach(function (event) {\n if (!self.eventsListeners[event]) { self.eventsListeners[event] = []; }\n self.eventsListeners[event][method](handler);\n });\n return self;\n };\n\n SwiperClass.prototype.once = function once (events, handler, priority) {\n var self = this;\n if (typeof handler !== 'function') { return self; }\n function onceHandler() {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n handler.apply(self, args);\n self.off(events, onceHandler);\n if (onceHandler.f7proxy) {\n delete onceHandler.f7proxy;\n }\n }\n onceHandler.f7proxy = handler;\n return self.on(events, onceHandler, priority);\n };\n\n SwiperClass.prototype.off = function off (events, handler) {\n var self = this;\n if (!self.eventsListeners) { return self; }\n events.split(' ').forEach(function (event) {\n if (typeof handler === 'undefined') {\n self.eventsListeners[event] = [];\n } else if (self.eventsListeners[event] && self.eventsListeners[event].length) {\n self.eventsListeners[event].forEach(function (eventHandler, index) {\n if (eventHandler === handler || (eventHandler.f7proxy && eventHandler.f7proxy === handler)) {\n self.eventsListeners[event].splice(index, 1);\n }\n });\n }\n });\n return self;\n };\n\n SwiperClass.prototype.emit = function emit () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var self = this;\n if (!self.eventsListeners) { return self; }\n var events;\n var data;\n var context;\n if (typeof args[0] === 'string' || Array.isArray(args[0])) {\n events = args[0];\n data = args.slice(1, args.length);\n context = self;\n } else {\n events = args[0].events;\n data = args[0].data;\n context = args[0].context || self;\n }\n var eventsArray = Array.isArray(events) ? events : events.split(' ');\n eventsArray.forEach(function (event) {\n if (self.eventsListeners && self.eventsListeners[event]) {\n var handlers = [];\n self.eventsListeners[event].forEach(function (eventHandler) {\n handlers.push(eventHandler);\n });\n handlers.forEach(function (eventHandler) {\n eventHandler.apply(context, data);\n });\n }\n });\n return self;\n };\n\n SwiperClass.prototype.useModulesParams = function useModulesParams (instanceParams) {\n var instance = this;\n if (!instance.modules) { return; }\n Object.keys(instance.modules).forEach(function (moduleName) {\n var module = instance.modules[moduleName];\n // Extend params\n if (module.params) {\n Utils.extend(instanceParams, module.params);\n }\n });\n };\n\n SwiperClass.prototype.useModules = function useModules (modulesParams) {\n if ( modulesParams === void 0 ) modulesParams = {};\n\n var instance = this;\n if (!instance.modules) { return; }\n Object.keys(instance.modules).forEach(function (moduleName) {\n var module = instance.modules[moduleName];\n var moduleParams = modulesParams[moduleName] || {};\n // Extend instance methods and props\n if (module.instance) {\n Object.keys(module.instance).forEach(function (modulePropName) {\n var moduleProp = module.instance[modulePropName];\n if (typeof moduleProp === 'function') {\n instance[modulePropName] = moduleProp.bind(instance);\n } else {\n instance[modulePropName] = moduleProp;\n }\n });\n }\n // Add event listeners\n if (module.on && instance.on) {\n Object.keys(module.on).forEach(function (moduleEventName) {\n instance.on(moduleEventName, module.on[moduleEventName]);\n });\n }\n\n // Module create callback\n if (module.create) {\n module.create.bind(instance)(moduleParams);\n }\n });\n };\n\n staticAccessors.components.set = function (components) {\n var Class = this;\n if (!Class.use) { return; }\n Class.use(components);\n };\n\n SwiperClass.installModule = function installModule (module) {\n var params = [], len = arguments.length - 1;\n while ( len-- > 0 ) params[ len ] = arguments[ len + 1 ];\n\n var Class = this;\n if (!Class.prototype.modules) { Class.prototype.modules = {}; }\n var name = module.name || (((Object.keys(Class.prototype.modules).length) + \"_\" + (Utils.now())));\n Class.prototype.modules[name] = module;\n // Prototype\n if (module.proto) {\n Object.keys(module.proto).forEach(function (key) {\n Class.prototype[key] = module.proto[key];\n });\n }\n // Class\n if (module.static) {\n Object.keys(module.static).forEach(function (key) {\n Class[key] = module.static[key];\n });\n }\n // Callback\n if (module.install) {\n module.install.apply(Class, params);\n }\n return Class;\n };\n\n SwiperClass.use = function use (module) {\n var params = [], len = arguments.length - 1;\n while ( len-- > 0 ) params[ len ] = arguments[ len + 1 ];\n\n var Class = this;\n if (Array.isArray(module)) {\n module.forEach(function (m) { return Class.installModule(m); });\n return Class;\n }\n return Class.installModule.apply(Class, [ module ].concat( params ));\n };\n\n Object.defineProperties( SwiperClass, staticAccessors );\n\n function updateSize () {\n var swiper = this;\n var width;\n var height;\n var $el = swiper.$el;\n if (typeof swiper.params.width !== 'undefined') {\n width = swiper.params.width;\n } else {\n width = $el[0].clientWidth;\n }\n if (typeof swiper.params.height !== 'undefined') {\n height = swiper.params.height;\n } else {\n height = $el[0].clientHeight;\n }\n if ((width === 0 && swiper.isHorizontal()) || (height === 0 && swiper.isVertical())) {\n return;\n }\n\n // Subtract paddings\n width = width - parseInt($el.css('padding-left'), 10) - parseInt($el.css('padding-right'), 10);\n height = height - parseInt($el.css('padding-top'), 10) - parseInt($el.css('padding-bottom'), 10);\n\n Utils.extend(swiper, {\n width: width,\n height: height,\n size: swiper.isHorizontal() ? width : height,\n });\n }\n\n function updateSlides () {\n var swiper = this;\n var params = swiper.params;\n\n var $wrapperEl = swiper.$wrapperEl;\n var swiperSize = swiper.size;\n var rtl = swiper.rtlTranslate;\n var wrongRTL = swiper.wrongRTL;\n var isVirtual = swiper.virtual && params.virtual.enabled;\n var previousSlidesLength = isVirtual ? swiper.virtual.slides.length : swiper.slides.length;\n var slides = $wrapperEl.children((\".\" + (swiper.params.slideClass)));\n var slidesLength = isVirtual ? swiper.virtual.slides.length : slides.length;\n var snapGrid = [];\n var slidesGrid = [];\n var slidesSizesGrid = [];\n\n var offsetBefore = params.slidesOffsetBefore;\n if (typeof offsetBefore === 'function') {\n offsetBefore = params.slidesOffsetBefore.call(swiper);\n }\n\n var offsetAfter = params.slidesOffsetAfter;\n if (typeof offsetAfter === 'function') {\n offsetAfter = params.slidesOffsetAfter.call(swiper);\n }\n\n var previousSnapGridLength = swiper.snapGrid.length;\n var previousSlidesGridLength = swiper.snapGrid.length;\n\n var spaceBetween = params.spaceBetween;\n var slidePosition = -offsetBefore;\n var prevSlideSize = 0;\n var index = 0;\n if (typeof swiperSize === 'undefined') {\n return;\n }\n if (typeof spaceBetween === 'string' && spaceBetween.indexOf('%') >= 0) {\n spaceBetween = (parseFloat(spaceBetween.replace('%', '')) / 100) * swiperSize;\n }\n\n swiper.virtualSize = -spaceBetween;\n\n // reset margins\n if (rtl) { slides.css({ marginLeft: '', marginTop: '' }); }\n else { slides.css({ marginRight: '', marginBottom: '' }); }\n\n var slidesNumberEvenToRows;\n if (params.slidesPerColumn > 1) {\n if (Math.floor(slidesLength / params.slidesPerColumn) === slidesLength / swiper.params.slidesPerColumn) {\n slidesNumberEvenToRows = slidesLength;\n } else {\n slidesNumberEvenToRows = Math.ceil(slidesLength / params.slidesPerColumn) * params.slidesPerColumn;\n }\n if (params.slidesPerView !== 'auto' && params.slidesPerColumnFill === 'row') {\n slidesNumberEvenToRows = Math.max(slidesNumberEvenToRows, params.slidesPerView * params.slidesPerColumn);\n }\n }\n\n // Calc slides\n var slideSize;\n var slidesPerColumn = params.slidesPerColumn;\n var slidesPerRow = slidesNumberEvenToRows / slidesPerColumn;\n var numFullColumns = Math.floor(slidesLength / params.slidesPerColumn);\n for (var i = 0; i < slidesLength; i += 1) {\n slideSize = 0;\n var slide = slides.eq(i);\n if (params.slidesPerColumn > 1) {\n // Set slides order\n var newSlideOrderIndex = (void 0);\n var column = (void 0);\n var row = (void 0);\n if (\n (params.slidesPerColumnFill === 'column')\n || (params.slidesPerColumnFill === 'row' && params.slidesPerGroup > 1)\n ) {\n if (params.slidesPerColumnFill === 'column') {\n column = Math.floor(i / slidesPerColumn);\n row = i - (column * slidesPerColumn);\n if (column > numFullColumns || (column === numFullColumns && row === slidesPerColumn - 1)) {\n row += 1;\n if (row >= slidesPerColumn) {\n row = 0;\n column += 1;\n }\n }\n } else {\n var groupIndex = Math.floor(i / params.slidesPerGroup);\n row = Math.floor(i / params.slidesPerView) - groupIndex * params.slidesPerColumn;\n column = i - row * params.slidesPerView - groupIndex * params.slidesPerView;\n }\n newSlideOrderIndex = column + ((row * slidesNumberEvenToRows) / slidesPerColumn);\n slide\n .css({\n '-webkit-box-ordinal-group': newSlideOrderIndex,\n '-moz-box-ordinal-group': newSlideOrderIndex,\n '-ms-flex-order': newSlideOrderIndex,\n '-webkit-order': newSlideOrderIndex,\n order: newSlideOrderIndex,\n });\n } else {\n row = Math.floor(i / slidesPerRow);\n column = i - (row * slidesPerRow);\n }\n slide\n .css(\n (\"margin-\" + (swiper.isHorizontal() ? 'top' : 'left')),\n (row !== 0 && params.spaceBetween) && (((params.spaceBetween) + \"px\"))\n )\n .attr('data-swiper-column', column)\n .attr('data-swiper-row', row);\n }\n if (slide.css('display') === 'none') { continue; } // eslint-disable-line\n\n if (params.slidesPerView === 'auto') {\n var slideStyles = win.getComputedStyle(slide[0], null);\n var currentTransform = slide[0].style.transform;\n var currentWebKitTransform = slide[0].style.webkitTransform;\n if (currentTransform) {\n slide[0].style.transform = 'none';\n }\n if (currentWebKitTransform) {\n slide[0].style.webkitTransform = 'none';\n }\n if (params.roundLengths) {\n slideSize = swiper.isHorizontal()\n ? slide.outerWidth(true)\n : slide.outerHeight(true);\n } else {\n // eslint-disable-next-line\n if (swiper.isHorizontal()) {\n var width = parseFloat(slideStyles.getPropertyValue('width'));\n var paddingLeft = parseFloat(slideStyles.getPropertyValue('padding-left'));\n var paddingRight = parseFloat(slideStyles.getPropertyValue('padding-right'));\n var marginLeft = parseFloat(slideStyles.getPropertyValue('margin-left'));\n var marginRight = parseFloat(slideStyles.getPropertyValue('margin-right'));\n var boxSizing = slideStyles.getPropertyValue('box-sizing');\n if (boxSizing && boxSizing === 'border-box' && !Browser.isIE) {\n slideSize = width + marginLeft + marginRight;\n } else {\n slideSize = width + paddingLeft + paddingRight + marginLeft + marginRight;\n }\n } else {\n var height = parseFloat(slideStyles.getPropertyValue('height'));\n var paddingTop = parseFloat(slideStyles.getPropertyValue('padding-top'));\n var paddingBottom = parseFloat(slideStyles.getPropertyValue('padding-bottom'));\n var marginTop = parseFloat(slideStyles.getPropertyValue('margin-top'));\n var marginBottom = parseFloat(slideStyles.getPropertyValue('margin-bottom'));\n var boxSizing$1 = slideStyles.getPropertyValue('box-sizing');\n if (boxSizing$1 && boxSizing$1 === 'border-box' && !Browser.isIE) {\n slideSize = height + marginTop + marginBottom;\n } else {\n slideSize = height + paddingTop + paddingBottom + marginTop + marginBottom;\n }\n }\n }\n if (currentTransform) {\n slide[0].style.transform = currentTransform;\n }\n if (currentWebKitTransform) {\n slide[0].style.webkitTransform = currentWebKitTransform;\n }\n if (params.roundLengths) { slideSize = Math.floor(slideSize); }\n } else {\n slideSize = (swiperSize - ((params.slidesPerView - 1) * spaceBetween)) / params.slidesPerView;\n if (params.roundLengths) { slideSize = Math.floor(slideSize); }\n\n if (slides[i]) {\n if (swiper.isHorizontal()) {\n slides[i].style.width = slideSize + \"px\";\n } else {\n slides[i].style.height = slideSize + \"px\";\n }\n }\n }\n if (slides[i]) {\n slides[i].swiperSlideSize = slideSize;\n }\n slidesSizesGrid.push(slideSize);\n\n\n if (params.centeredSlides) {\n slidePosition = slidePosition + (slideSize / 2) + (prevSlideSize / 2) + spaceBetween;\n if (prevSlideSize === 0 && i !== 0) { slidePosition = slidePosition - (swiperSize / 2) - spaceBetween; }\n if (i === 0) { slidePosition = slidePosition - (swiperSize / 2) - spaceBetween; }\n if (Math.abs(slidePosition) < 1 / 1000) { slidePosition = 0; }\n if (params.roundLengths) { slidePosition = Math.floor(slidePosition); }\n if ((index) % params.slidesPerGroup === 0) { snapGrid.push(slidePosition); }\n slidesGrid.push(slidePosition);\n } else {\n if (params.roundLengths) { slidePosition = Math.floor(slidePosition); }\n if ((index) % params.slidesPerGroup === 0) { snapGrid.push(slidePosition); }\n slidesGrid.push(slidePosition);\n slidePosition = slidePosition + slideSize + spaceBetween;\n }\n\n swiper.virtualSize += slideSize + spaceBetween;\n\n prevSlideSize = slideSize;\n\n index += 1;\n }\n swiper.virtualSize = Math.max(swiper.virtualSize, swiperSize) + offsetAfter;\n var newSlidesGrid;\n\n if (\n rtl && wrongRTL && (params.effect === 'slide' || params.effect === 'coverflow')) {\n $wrapperEl.css({ width: ((swiper.virtualSize + params.spaceBetween) + \"px\") });\n }\n if (!Support.flexbox || params.setWrapperSize) {\n if (swiper.isHorizontal()) { $wrapperEl.css({ width: ((swiper.virtualSize + params.spaceBetween) + \"px\") }); }\n else { $wrapperEl.css({ height: ((swiper.virtualSize + params.spaceBetween) + \"px\") }); }\n }\n\n if (params.slidesPerColumn > 1) {\n swiper.virtualSize = (slideSize + params.spaceBetween) * slidesNumberEvenToRows;\n swiper.virtualSize = Math.ceil(swiper.virtualSize / params.slidesPerColumn) - params.spaceBetween;\n if (swiper.isHorizontal()) { $wrapperEl.css({ width: ((swiper.virtualSize + params.spaceBetween) + \"px\") }); }\n else { $wrapperEl.css({ height: ((swiper.virtualSize + params.spaceBetween) + \"px\") }); }\n if (params.centeredSlides) {\n newSlidesGrid = [];\n for (var i$1 = 0; i$1 < snapGrid.length; i$1 += 1) {\n var slidesGridItem = snapGrid[i$1];\n if (params.roundLengths) { slidesGridItem = Math.floor(slidesGridItem); }\n if (snapGrid[i$1] < swiper.virtualSize + snapGrid[0]) { newSlidesGrid.push(slidesGridItem); }\n }\n snapGrid = newSlidesGrid;\n }\n }\n\n // Remove last grid elements depending on width\n if (!params.centeredSlides) {\n newSlidesGrid = [];\n for (var i$2 = 0; i$2 < snapGrid.length; i$2 += 1) {\n var slidesGridItem$1 = snapGrid[i$2];\n if (params.roundLengths) { slidesGridItem$1 = Math.floor(slidesGridItem$1); }\n if (snapGrid[i$2] <= swiper.virtualSize - swiperSize) {\n newSlidesGrid.push(slidesGridItem$1);\n }\n }\n snapGrid = newSlidesGrid;\n if (Math.floor(swiper.virtualSize - swiperSize) - Math.floor(snapGrid[snapGrid.length - 1]) > 1) {\n snapGrid.push(swiper.virtualSize - swiperSize);\n }\n }\n if (snapGrid.length === 0) { snapGrid = [0]; }\n\n if (params.spaceBetween !== 0) {\n if (swiper.isHorizontal()) {\n if (rtl) { slides.css({ marginLeft: (spaceBetween + \"px\") }); }\n else { slides.css({ marginRight: (spaceBetween + \"px\") }); }\n } else { slides.css({ marginBottom: (spaceBetween + \"px\") }); }\n }\n\n if (params.centerInsufficientSlides) {\n var allSlidesSize = 0;\n slidesSizesGrid.forEach(function (slideSizeValue) {\n allSlidesSize += slideSizeValue + (params.spaceBetween ? params.spaceBetween : 0);\n });\n allSlidesSize -= params.spaceBetween;\n if (allSlidesSize < swiperSize) {\n var allSlidesOffset = (swiperSize - allSlidesSize) / 2;\n snapGrid.forEach(function (snap, snapIndex) {\n snapGrid[snapIndex] = snap - allSlidesOffset;\n });\n slidesGrid.forEach(function (snap, snapIndex) {\n slidesGrid[snapIndex] = snap + allSlidesOffset;\n });\n }\n }\n\n Utils.extend(swiper, {\n slides: slides,\n snapGrid: snapGrid,\n slidesGrid: slidesGrid,\n slidesSizesGrid: slidesSizesGrid,\n });\n\n if (slidesLength !== previousSlidesLength) {\n swiper.emit('slidesLengthChange');\n }\n if (snapGrid.length !== previousSnapGridLength) {\n if (swiper.params.watchOverflow) { swiper.checkOverflow(); }\n swiper.emit('snapGridLengthChange');\n }\n if (slidesGrid.length !== previousSlidesGridLength) {\n swiper.emit('slidesGridLengthChange');\n }\n\n if (params.watchSlidesProgress || params.watchSlidesVisibility) {\n swiper.updateSlidesOffset();\n }\n }\n\n function updateAutoHeight (speed) {\n var swiper = this;\n var activeSlides = [];\n var newHeight = 0;\n var i;\n if (typeof speed === 'number') {\n swiper.setTransition(speed);\n } else if (speed === true) {\n swiper.setTransition(swiper.params.speed);\n }\n // Find slides currently in view\n if (swiper.params.slidesPerView !== 'auto' && swiper.params.slidesPerView > 1) {\n for (i = 0; i < Math.ceil(swiper.params.slidesPerView); i += 1) {\n var index = swiper.activeIndex + i;\n if (index > swiper.slides.length) { break; }\n activeSlides.push(swiper.slides.eq(index)[0]);\n }\n } else {\n activeSlides.push(swiper.slides.eq(swiper.activeIndex)[0]);\n }\n\n // Find new height from highest slide in view\n for (i = 0; i < activeSlides.length; i += 1) {\n if (typeof activeSlides[i] !== 'undefined') {\n var height = activeSlides[i].offsetHeight;\n newHeight = height > newHeight ? height : newHeight;\n }\n }\n\n // Update Height\n if (newHeight) { swiper.$wrapperEl.css('height', (newHeight + \"px\")); }\n }\n\n function updateSlidesOffset () {\n var swiper = this;\n var slides = swiper.slides;\n for (var i = 0; i < slides.length; i += 1) {\n slides[i].swiperSlideOffset = swiper.isHorizontal() ? slides[i].offsetLeft : slides[i].offsetTop;\n }\n }\n\n function updateSlidesProgress (translate) {\n if ( translate === void 0 ) translate = (this && this.translate) || 0;\n\n var swiper = this;\n var params = swiper.params;\n\n var slides = swiper.slides;\n var rtl = swiper.rtlTranslate;\n\n if (slides.length === 0) { return; }\n if (typeof slides[0].swiperSlideOffset === 'undefined') { swiper.updateSlidesOffset(); }\n\n var offsetCenter = -translate;\n if (rtl) { offsetCenter = translate; }\n\n // Visible Slides\n slides.removeClass(params.slideVisibleClass);\n\n swiper.visibleSlidesIndexes = [];\n swiper.visibleSlides = [];\n\n for (var i = 0; i < slides.length; i += 1) {\n var slide = slides[i];\n var slideProgress = (\n (offsetCenter + (params.centeredSlides ? swiper.minTranslate() : 0)) - slide.swiperSlideOffset\n ) / (slide.swiperSlideSize + params.spaceBetween);\n if (params.watchSlidesVisibility) {\n var slideBefore = -(offsetCenter - slide.swiperSlideOffset);\n var slideAfter = slideBefore + swiper.slidesSizesGrid[i];\n var isVisible = (slideBefore >= 0 && slideBefore < swiper.size - 1)\n || (slideAfter > 1 && slideAfter <= swiper.size)\n || (slideBefore <= 0 && slideAfter >= swiper.size);\n if (isVisible) {\n swiper.visibleSlides.push(slide);\n swiper.visibleSlidesIndexes.push(i);\n slides.eq(i).addClass(params.slideVisibleClass);\n }\n }\n slide.progress = rtl ? -slideProgress : slideProgress;\n }\n swiper.visibleSlides = $(swiper.visibleSlides);\n }\n\n function updateProgress (translate) {\n if ( translate === void 0 ) translate = (this && this.translate) || 0;\n\n var swiper = this;\n var params = swiper.params;\n\n var translatesDiff = swiper.maxTranslate() - swiper.minTranslate();\n var progress = swiper.progress;\n var isBeginning = swiper.isBeginning;\n var isEnd = swiper.isEnd;\n var wasBeginning = isBeginning;\n var wasEnd = isEnd;\n if (translatesDiff === 0) {\n progress = 0;\n isBeginning = true;\n isEnd = true;\n } else {\n progress = (translate - swiper.minTranslate()) / (translatesDiff);\n isBeginning = progress <= 0;\n isEnd = progress >= 1;\n }\n Utils.extend(swiper, {\n progress: progress,\n isBeginning: isBeginning,\n isEnd: isEnd,\n });\n\n if (params.watchSlidesProgress || params.watchSlidesVisibility) { swiper.updateSlidesProgress(translate); }\n\n if (isBeginning && !wasBeginning) {\n swiper.emit('reachBeginning toEdge');\n }\n if (isEnd && !wasEnd) {\n swiper.emit('reachEnd toEdge');\n }\n if ((wasBeginning && !isBeginning) || (wasEnd && !isEnd)) {\n swiper.emit('fromEdge');\n }\n\n swiper.emit('progress', progress);\n }\n\n function updateSlidesClasses () {\n var swiper = this;\n\n var slides = swiper.slides;\n var params = swiper.params;\n var $wrapperEl = swiper.$wrapperEl;\n var activeIndex = swiper.activeIndex;\n var realIndex = swiper.realIndex;\n var isVirtual = swiper.virtual && params.virtual.enabled;\n\n slides.removeClass(((params.slideActiveClass) + \" \" + (params.slideNextClass) + \" \" + (params.slidePrevClass) + \" \" + (params.slideDuplicateActiveClass) + \" \" + (params.slideDuplicateNextClass) + \" \" + (params.slideDuplicatePrevClass)));\n\n var activeSlide;\n if (isVirtual) {\n activeSlide = swiper.$wrapperEl.find((\".\" + (params.slideClass) + \"[data-swiper-slide-index=\\\"\" + activeIndex + \"\\\"]\"));\n } else {\n activeSlide = slides.eq(activeIndex);\n }\n\n // Active classes\n activeSlide.addClass(params.slideActiveClass);\n\n if (params.loop) {\n // Duplicate to all looped slides\n if (activeSlide.hasClass(params.slideDuplicateClass)) {\n $wrapperEl\n .children((\".\" + (params.slideClass) + \":not(.\" + (params.slideDuplicateClass) + \")[data-swiper-slide-index=\\\"\" + realIndex + \"\\\"]\"))\n .addClass(params.slideDuplicateActiveClass);\n } else {\n $wrapperEl\n .children((\".\" + (params.slideClass) + \".\" + (params.slideDuplicateClass) + \"[data-swiper-slide-index=\\\"\" + realIndex + \"\\\"]\"))\n .addClass(params.slideDuplicateActiveClass);\n }\n }\n // Next Slide\n var nextSlide = activeSlide.nextAll((\".\" + (params.slideClass))).eq(0).addClass(params.slideNextClass);\n if (params.loop && nextSlide.length === 0) {\n nextSlide = slides.eq(0);\n nextSlide.addClass(params.slideNextClass);\n }\n // Prev Slide\n var prevSlide = activeSlide.prevAll((\".\" + (params.slideClass))).eq(0).addClass(params.slidePrevClass);\n if (params.loop && prevSlide.length === 0) {\n prevSlide = slides.eq(-1);\n prevSlide.addClass(params.slidePrevClass);\n }\n if (params.loop) {\n // Duplicate to all looped slides\n if (nextSlide.hasClass(params.slideDuplicateClass)) {\n $wrapperEl\n .children((\".\" + (params.slideClass) + \":not(.\" + (params.slideDuplicateClass) + \")[data-swiper-slide-index=\\\"\" + (nextSlide.attr('data-swiper-slide-index')) + \"\\\"]\"))\n .addClass(params.slideDuplicateNextClass);\n } else {\n $wrapperEl\n .children((\".\" + (params.slideClass) + \".\" + (params.slideDuplicateClass) + \"[data-swiper-slide-index=\\\"\" + (nextSlide.attr('data-swiper-slide-index')) + \"\\\"]\"))\n .addClass(params.slideDuplicateNextClass);\n }\n if (prevSlide.hasClass(params.slideDuplicateClass)) {\n $wrapperEl\n .children((\".\" + (params.slideClass) + \":not(.\" + (params.slideDuplicateClass) + \")[data-swiper-slide-index=\\\"\" + (prevSlide.attr('data-swiper-slide-index')) + \"\\\"]\"))\n .addClass(params.slideDuplicatePrevClass);\n } else {\n $wrapperEl\n .children((\".\" + (params.slideClass) + \".\" + (params.slideDuplicateClass) + \"[data-swiper-slide-index=\\\"\" + (prevSlide.attr('data-swiper-slide-index')) + \"\\\"]\"))\n .addClass(params.slideDuplicatePrevClass);\n }\n }\n }\n\n function updateActiveIndex (newActiveIndex) {\n var swiper = this;\n var translate = swiper.rtlTranslate ? swiper.translate : -swiper.translate;\n var slidesGrid = swiper.slidesGrid;\n var snapGrid = swiper.snapGrid;\n var params = swiper.params;\n var previousIndex = swiper.activeIndex;\n var previousRealIndex = swiper.realIndex;\n var previousSnapIndex = swiper.snapIndex;\n var activeIndex = newActiveIndex;\n var snapIndex;\n if (typeof activeIndex === 'undefined') {\n for (var i = 0; i < slidesGrid.length; i += 1) {\n if (typeof slidesGrid[i + 1] !== 'undefined') {\n if (translate >= slidesGrid[i] && translate < slidesGrid[i + 1] - ((slidesGrid[i + 1] - slidesGrid[i]) / 2)) {\n activeIndex = i;\n } else if (translate >= slidesGrid[i] && translate < slidesGrid[i + 1]) {\n activeIndex = i + 1;\n }\n } else if (translate >= slidesGrid[i]) {\n activeIndex = i;\n }\n }\n // Normalize slideIndex\n if (params.normalizeSlideIndex) {\n if (activeIndex < 0 || typeof activeIndex === 'undefined') { activeIndex = 0; }\n }\n }\n if (snapGrid.indexOf(translate) >= 0) {\n snapIndex = snapGrid.indexOf(translate);\n } else {\n snapIndex = Math.floor(activeIndex / params.slidesPerGroup);\n }\n if (snapIndex >= snapGrid.length) { snapIndex = snapGrid.length - 1; }\n if (activeIndex === previousIndex) {\n if (snapIndex !== previousSnapIndex) {\n swiper.snapIndex = snapIndex;\n swiper.emit('snapIndexChange');\n }\n return;\n }\n\n // Get real index\n var realIndex = parseInt(swiper.slides.eq(activeIndex).attr('data-swiper-slide-index') || activeIndex, 10);\n\n Utils.extend(swiper, {\n snapIndex: snapIndex,\n realIndex: realIndex,\n previousIndex: previousIndex,\n activeIndex: activeIndex,\n });\n swiper.emit('activeIndexChange');\n swiper.emit('snapIndexChange');\n if (previousRealIndex !== realIndex) {\n swiper.emit('realIndexChange');\n }\n if (swiper.initialized || swiper.runCallbacksOnInit) {\n swiper.emit('slideChange');\n }\n }\n\n function updateClickedSlide (e) {\n var swiper = this;\n var params = swiper.params;\n var slide = $(e.target).closest((\".\" + (params.slideClass)))[0];\n var slideFound = false;\n if (slide) {\n for (var i = 0; i < swiper.slides.length; i += 1) {\n if (swiper.slides[i] === slide) { slideFound = true; }\n }\n }\n\n if (slide && slideFound) {\n swiper.clickedSlide = slide;\n if (swiper.virtual && swiper.params.virtual.enabled) {\n swiper.clickedIndex = parseInt($(slide).attr('data-swiper-slide-index'), 10);\n } else {\n swiper.clickedIndex = $(slide).index();\n }\n } else {\n swiper.clickedSlide = undefined;\n swiper.clickedIndex = undefined;\n return;\n }\n if (params.slideToClickedSlide && swiper.clickedIndex !== undefined && swiper.clickedIndex !== swiper.activeIndex) {\n swiper.slideToClickedSlide();\n }\n }\n\n var update = {\n updateSize: updateSize,\n updateSlides: updateSlides,\n updateAutoHeight: updateAutoHeight,\n updateSlidesOffset: updateSlidesOffset,\n updateSlidesProgress: updateSlidesProgress,\n updateProgress: updateProgress,\n updateSlidesClasses: updateSlidesClasses,\n updateActiveIndex: updateActiveIndex,\n updateClickedSlide: updateClickedSlide,\n };\n\n function getTranslate (axis) {\n if ( axis === void 0 ) axis = this.isHorizontal() ? 'x' : 'y';\n\n var swiper = this;\n\n var params = swiper.params;\n var rtl = swiper.rtlTranslate;\n var translate = swiper.translate;\n var $wrapperEl = swiper.$wrapperEl;\n\n if (params.virtualTranslate) {\n return rtl ? -translate : translate;\n }\n\n var currentTranslate = Utils.getTranslate($wrapperEl[0], axis);\n if (rtl) { currentTranslate = -currentTranslate; }\n\n return currentTranslate || 0;\n }\n\n function setTranslate (translate, byController) {\n var swiper = this;\n var rtl = swiper.rtlTranslate;\n var params = swiper.params;\n var $wrapperEl = swiper.$wrapperEl;\n var progress = swiper.progress;\n var x = 0;\n var y = 0;\n var z = 0;\n\n if (swiper.isHorizontal()) {\n x = rtl ? -translate : translate;\n } else {\n y = translate;\n }\n\n if (params.roundLengths) {\n x = Math.floor(x);\n y = Math.floor(y);\n }\n\n if (!params.virtualTranslate) {\n if (Support.transforms3d) { $wrapperEl.transform((\"translate3d(\" + x + \"px, \" + y + \"px, \" + z + \"px)\")); }\n else { $wrapperEl.transform((\"translate(\" + x + \"px, \" + y + \"px)\")); }\n }\n swiper.previousTranslate = swiper.translate;\n swiper.translate = swiper.isHorizontal() ? x : y;\n\n // Check if we need to update progress\n var newProgress;\n var translatesDiff = swiper.maxTranslate() - swiper.minTranslate();\n if (translatesDiff === 0) {\n newProgress = 0;\n } else {\n newProgress = (translate - swiper.minTranslate()) / (translatesDiff);\n }\n if (newProgress !== progress) {\n swiper.updateProgress(translate);\n }\n\n swiper.emit('setTranslate', swiper.translate, byController);\n }\n\n function minTranslate () {\n return (-this.snapGrid[0]);\n }\n\n function maxTranslate () {\n return (-this.snapGrid[this.snapGrid.length - 1]);\n }\n\n var translate = {\n getTranslate: getTranslate,\n setTranslate: setTranslate,\n minTranslate: minTranslate,\n maxTranslate: maxTranslate,\n };\n\n function setTransition (duration, byController) {\n var swiper = this;\n\n swiper.$wrapperEl.transition(duration);\n\n swiper.emit('setTransition', duration, byController);\n }\n\n function transitionStart (runCallbacks, direction) {\n if ( runCallbacks === void 0 ) runCallbacks = true;\n\n var swiper = this;\n var activeIndex = swiper.activeIndex;\n var params = swiper.params;\n var previousIndex = swiper.previousIndex;\n if (params.autoHeight) {\n swiper.updateAutoHeight();\n }\n\n var dir = direction;\n if (!dir) {\n if (activeIndex > previousIndex) { dir = 'next'; }\n else if (activeIndex < previousIndex) { dir = 'prev'; }\n else { dir = 'reset'; }\n }\n\n swiper.emit('transitionStart');\n\n if (runCallbacks && activeIndex !== previousIndex) {\n if (dir === 'reset') {\n swiper.emit('slideResetTransitionStart');\n return;\n }\n swiper.emit('slideChangeTransitionStart');\n if (dir === 'next') {\n swiper.emit('slideNextTransitionStart');\n } else {\n swiper.emit('slidePrevTransitionStart');\n }\n }\n }\n\n function transitionEnd$1 (runCallbacks, direction) {\n if ( runCallbacks === void 0 ) runCallbacks = true;\n\n var swiper = this;\n var activeIndex = swiper.activeIndex;\n var previousIndex = swiper.previousIndex;\n swiper.animating = false;\n swiper.setTransition(0);\n\n var dir = direction;\n if (!dir) {\n if (activeIndex > previousIndex) { dir = 'next'; }\n else if (activeIndex < previousIndex) { dir = 'prev'; }\n else { dir = 'reset'; }\n }\n\n swiper.emit('transitionEnd');\n\n if (runCallbacks && activeIndex !== previousIndex) {\n if (dir === 'reset') {\n swiper.emit('slideResetTransitionEnd');\n return;\n }\n swiper.emit('slideChangeTransitionEnd');\n if (dir === 'next') {\n swiper.emit('slideNextTransitionEnd');\n } else {\n swiper.emit('slidePrevTransitionEnd');\n }\n }\n }\n\n var transition$1 = {\n setTransition: setTransition,\n transitionStart: transitionStart,\n transitionEnd: transitionEnd$1,\n };\n\n function slideTo (index, speed, runCallbacks, internal) {\n if ( index === void 0 ) index = 0;\n if ( speed === void 0 ) speed = this.params.speed;\n if ( runCallbacks === void 0 ) runCallbacks = true;\n\n var swiper = this;\n var slideIndex = index;\n if (slideIndex < 0) { slideIndex = 0; }\n\n var params = swiper.params;\n var snapGrid = swiper.snapGrid;\n var slidesGrid = swiper.slidesGrid;\n var previousIndex = swiper.previousIndex;\n var activeIndex = swiper.activeIndex;\n var rtl = swiper.rtlTranslate;\n if (swiper.animating && params.preventInteractionOnTransition) {\n return false;\n }\n\n var snapIndex = Math.floor(slideIndex / params.slidesPerGroup);\n if (snapIndex >= snapGrid.length) { snapIndex = snapGrid.length - 1; }\n\n if ((activeIndex || params.initialSlide || 0) === (previousIndex || 0) && runCallbacks) {\n swiper.emit('beforeSlideChangeStart');\n }\n\n var translate = -snapGrid[snapIndex];\n\n // Update progress\n swiper.updateProgress(translate);\n\n // Normalize slideIndex\n if (params.normalizeSlideIndex) {\n for (var i = 0; i < slidesGrid.length; i += 1) {\n if (-Math.floor(translate * 100) >= Math.floor(slidesGrid[i] * 100)) {\n slideIndex = i;\n }\n }\n }\n // Directions locks\n if (swiper.initialized && slideIndex !== activeIndex) {\n if (!swiper.allowSlideNext && translate < swiper.translate && translate < swiper.minTranslate()) {\n return false;\n }\n if (!swiper.allowSlidePrev && translate > swiper.translate && translate > swiper.maxTranslate()) {\n if ((activeIndex || 0) !== slideIndex) { return false; }\n }\n }\n\n var direction;\n if (slideIndex > activeIndex) { direction = 'next'; }\n else if (slideIndex < activeIndex) { direction = 'prev'; }\n else { direction = 'reset'; }\n\n\n // Update Index\n if ((rtl && -translate === swiper.translate) || (!rtl && translate === swiper.translate)) {\n swiper.updateActiveIndex(slideIndex);\n // Update Height\n if (params.autoHeight) {\n swiper.updateAutoHeight();\n }\n swiper.updateSlidesClasses();\n if (params.effect !== 'slide') {\n swiper.setTranslate(translate);\n }\n if (direction !== 'reset') {\n swiper.transitionStart(runCallbacks, direction);\n swiper.transitionEnd(runCallbacks, direction);\n }\n return false;\n }\n\n if (speed === 0 || !Support.transition) {\n swiper.setTransition(0);\n swiper.setTranslate(translate);\n swiper.updateActiveIndex(slideIndex);\n swiper.updateSlidesClasses();\n swiper.emit('beforeTransitionStart', speed, internal);\n swiper.transitionStart(runCallbacks, direction);\n swiper.transitionEnd(runCallbacks, direction);\n } else {\n swiper.setTransition(speed);\n swiper.setTranslate(translate);\n swiper.updateActiveIndex(slideIndex);\n swiper.updateSlidesClasses();\n swiper.emit('beforeTransitionStart', speed, internal);\n swiper.transitionStart(runCallbacks, direction);\n if (!swiper.animating) {\n swiper.animating = true;\n if (!swiper.onSlideToWrapperTransitionEnd) {\n swiper.onSlideToWrapperTransitionEnd = function transitionEnd(e) {\n if (!swiper || swiper.destroyed) { return; }\n if (e.target !== this) { return; }\n swiper.$wrapperEl[0].removeEventListener('transitionend', swiper.onSlideToWrapperTransitionEnd);\n swiper.$wrapperEl[0].removeEventListener('webkitTransitionEnd', swiper.onSlideToWrapperTransitionEnd);\n swiper.onSlideToWrapperTransitionEnd = null;\n delete swiper.onSlideToWrapperTransitionEnd;\n swiper.transitionEnd(runCallbacks, direction);\n };\n }\n swiper.$wrapperEl[0].addEventListener('transitionend', swiper.onSlideToWrapperTransitionEnd);\n swiper.$wrapperEl[0].addEventListener('webkitTransitionEnd', swiper.onSlideToWrapperTransitionEnd);\n }\n }\n\n return true;\n }\n\n function slideToLoop (index, speed, runCallbacks, internal) {\n if ( index === void 0 ) index = 0;\n if ( speed === void 0 ) speed = this.params.speed;\n if ( runCallbacks === void 0 ) runCallbacks = true;\n\n var swiper = this;\n var newIndex = index;\n if (swiper.params.loop) {\n newIndex += swiper.loopedSlides;\n }\n\n return swiper.slideTo(newIndex, speed, runCallbacks, internal);\n }\n\n /* eslint no-unused-vars: \"off\" */\n function slideNext (speed, runCallbacks, internal) {\n if ( speed === void 0 ) speed = this.params.speed;\n if ( runCallbacks === void 0 ) runCallbacks = true;\n\n var swiper = this;\n var params = swiper.params;\n var animating = swiper.animating;\n if (params.loop) {\n if (animating) { return false; }\n swiper.loopFix();\n // eslint-disable-next-line\n swiper._clientLeft = swiper.$wrapperEl[0].clientLeft;\n return swiper.slideTo(swiper.activeIndex + params.slidesPerGroup, speed, runCallbacks, internal);\n }\n return swiper.slideTo(swiper.activeIndex + params.slidesPerGroup, speed, runCallbacks, internal);\n }\n\n /* eslint no-unused-vars: \"off\" */\n function slidePrev (speed, runCallbacks, internal) {\n if ( speed === void 0 ) speed = this.params.speed;\n if ( runCallbacks === void 0 ) runCallbacks = true;\n\n var swiper = this;\n var params = swiper.params;\n var animating = swiper.animating;\n var snapGrid = swiper.snapGrid;\n var slidesGrid = swiper.slidesGrid;\n var rtlTranslate = swiper.rtlTranslate;\n\n if (params.loop) {\n if (animating) { return false; }\n swiper.loopFix();\n // eslint-disable-next-line\n swiper._clientLeft = swiper.$wrapperEl[0].clientLeft;\n }\n var translate = rtlTranslate ? swiper.translate : -swiper.translate;\n function normalize(val) {\n if (val < 0) { return -Math.floor(Math.abs(val)); }\n return Math.floor(val);\n }\n var normalizedTranslate = normalize(translate);\n var normalizedSnapGrid = snapGrid.map(function (val) { return normalize(val); });\n var normalizedSlidesGrid = slidesGrid.map(function (val) { return normalize(val); });\n\n var currentSnap = snapGrid[normalizedSnapGrid.indexOf(normalizedTranslate)];\n var prevSnap = snapGrid[normalizedSnapGrid.indexOf(normalizedTranslate) - 1];\n var prevIndex;\n if (typeof prevSnap !== 'undefined') {\n prevIndex = slidesGrid.indexOf(prevSnap);\n if (prevIndex < 0) { prevIndex = swiper.activeIndex - 1; }\n }\n return swiper.slideTo(prevIndex, speed, runCallbacks, internal);\n }\n\n /* eslint no-unused-vars: \"off\" */\n function slideReset (speed, runCallbacks, internal) {\n if ( speed === void 0 ) speed = this.params.speed;\n if ( runCallbacks === void 0 ) runCallbacks = true;\n\n var swiper = this;\n return swiper.slideTo(swiper.activeIndex, speed, runCallbacks, internal);\n }\n\n /* eslint no-unused-vars: \"off\" */\n function slideToClosest (speed, runCallbacks, internal) {\n if ( speed === void 0 ) speed = this.params.speed;\n if ( runCallbacks === void 0 ) runCallbacks = true;\n\n var swiper = this;\n var index = swiper.activeIndex;\n var snapIndex = Math.floor(index / swiper.params.slidesPerGroup);\n\n if (snapIndex < swiper.snapGrid.length - 1) {\n var translate = swiper.rtlTranslate ? swiper.translate : -swiper.translate;\n\n var currentSnap = swiper.snapGrid[snapIndex];\n var nextSnap = swiper.snapGrid[snapIndex + 1];\n\n if ((translate - currentSnap) > (nextSnap - currentSnap) / 2) {\n index = swiper.params.slidesPerGroup;\n }\n }\n\n return swiper.slideTo(index, speed, runCallbacks, internal);\n }\n\n function slideToClickedSlide () {\n var swiper = this;\n var params = swiper.params;\n var $wrapperEl = swiper.$wrapperEl;\n\n var slidesPerView = params.slidesPerView === 'auto' ? swiper.slidesPerViewDynamic() : params.slidesPerView;\n var slideToIndex = swiper.clickedIndex;\n var realIndex;\n if (params.loop) {\n if (swiper.animating) { return; }\n realIndex = parseInt($(swiper.clickedSlide).attr('data-swiper-slide-index'), 10);\n if (params.centeredSlides) {\n if (\n (slideToIndex < swiper.loopedSlides - (slidesPerView / 2))\n || (slideToIndex > (swiper.slides.length - swiper.loopedSlides) + (slidesPerView / 2))\n ) {\n swiper.loopFix();\n slideToIndex = $wrapperEl\n .children((\".\" + (params.slideClass) + \"[data-swiper-slide-index=\\\"\" + realIndex + \"\\\"]:not(.\" + (params.slideDuplicateClass) + \")\"))\n .eq(0)\n .index();\n\n Utils.nextTick(function () {\n swiper.slideTo(slideToIndex);\n });\n } else {\n swiper.slideTo(slideToIndex);\n }\n } else if (slideToIndex > swiper.slides.length - slidesPerView) {\n swiper.loopFix();\n slideToIndex = $wrapperEl\n .children((\".\" + (params.slideClass) + \"[data-swiper-slide-index=\\\"\" + realIndex + \"\\\"]:not(.\" + (params.slideDuplicateClass) + \")\"))\n .eq(0)\n .index();\n\n Utils.nextTick(function () {\n swiper.slideTo(slideToIndex);\n });\n } else {\n swiper.slideTo(slideToIndex);\n }\n } else {\n swiper.slideTo(slideToIndex);\n }\n }\n\n var slide = {\n slideTo: slideTo,\n slideToLoop: slideToLoop,\n slideNext: slideNext,\n slidePrev: slidePrev,\n slideReset: slideReset,\n slideToClosest: slideToClosest,\n slideToClickedSlide: slideToClickedSlide,\n };\n\n function loopCreate () {\n var swiper = this;\n var params = swiper.params;\n var $wrapperEl = swiper.$wrapperEl;\n // Remove duplicated slides\n $wrapperEl.children((\".\" + (params.slideClass) + \".\" + (params.slideDuplicateClass))).remove();\n\n var slides = $wrapperEl.children((\".\" + (params.slideClass)));\n\n if (params.loopFillGroupWithBlank) {\n var blankSlidesNum = params.slidesPerGroup - (slides.length % params.slidesPerGroup);\n if (blankSlidesNum !== params.slidesPerGroup) {\n for (var i = 0; i < blankSlidesNum; i += 1) {\n var blankNode = $(doc.createElement('div')).addClass(((params.slideClass) + \" \" + (params.slideBlankClass)));\n $wrapperEl.append(blankNode);\n }\n slides = $wrapperEl.children((\".\" + (params.slideClass)));\n }\n }\n\n if (params.slidesPerView === 'auto' && !params.loopedSlides) { params.loopedSlides = slides.length; }\n\n swiper.loopedSlides = parseInt(params.loopedSlides || params.slidesPerView, 10);\n swiper.loopedSlides += params.loopAdditionalSlides;\n if (swiper.loopedSlides > slides.length) {\n swiper.loopedSlides = slides.length;\n }\n\n var prependSlides = [];\n var appendSlides = [];\n slides.each(function (index, el) {\n var slide = $(el);\n if (index < swiper.loopedSlides) { appendSlides.push(el); }\n if (index < slides.length && index >= slides.length - swiper.loopedSlides) { prependSlides.push(el); }\n slide.attr('data-swiper-slide-index', index);\n });\n for (var i$1 = 0; i$1 < appendSlides.length; i$1 += 1) {\n $wrapperEl.append($(appendSlides[i$1].cloneNode(true)).addClass(params.slideDuplicateClass));\n }\n for (var i$2 = prependSlides.length - 1; i$2 >= 0; i$2 -= 1) {\n $wrapperEl.prepend($(prependSlides[i$2].cloneNode(true)).addClass(params.slideDuplicateClass));\n }\n }\n\n function loopFix () {\n var swiper = this;\n var params = swiper.params;\n var activeIndex = swiper.activeIndex;\n var slides = swiper.slides;\n var loopedSlides = swiper.loopedSlides;\n var allowSlidePrev = swiper.allowSlidePrev;\n var allowSlideNext = swiper.allowSlideNext;\n var snapGrid = swiper.snapGrid;\n var rtl = swiper.rtlTranslate;\n var newIndex;\n swiper.allowSlidePrev = true;\n swiper.allowSlideNext = true;\n\n var snapTranslate = -snapGrid[activeIndex];\n var diff = snapTranslate - swiper.getTranslate();\n\n\n // Fix For Negative Oversliding\n if (activeIndex < loopedSlides) {\n newIndex = (slides.length - (loopedSlides * 3)) + activeIndex;\n newIndex += loopedSlides;\n var slideChanged = swiper.slideTo(newIndex, 0, false, true);\n if (slideChanged && diff !== 0) {\n swiper.setTranslate((rtl ? -swiper.translate : swiper.translate) - diff);\n }\n } else if ((params.slidesPerView === 'auto' && activeIndex >= loopedSlides * 2) || (activeIndex >= slides.length - loopedSlides)) {\n // Fix For Positive Oversliding\n newIndex = -slides.length + activeIndex + loopedSlides;\n newIndex += loopedSlides;\n var slideChanged$1 = swiper.slideTo(newIndex, 0, false, true);\n if (slideChanged$1 && diff !== 0) {\n swiper.setTranslate((rtl ? -swiper.translate : swiper.translate) - diff);\n }\n }\n swiper.allowSlidePrev = allowSlidePrev;\n swiper.allowSlideNext = allowSlideNext;\n }\n\n function loopDestroy () {\n var swiper = this;\n var $wrapperEl = swiper.$wrapperEl;\n var params = swiper.params;\n var slides = swiper.slides;\n $wrapperEl.children((\".\" + (params.slideClass) + \".\" + (params.slideDuplicateClass) + \",.\" + (params.slideClass) + \".\" + (params.slideBlankClass))).remove();\n slides.removeAttr('data-swiper-slide-index');\n }\n\n var loop = {\n loopCreate: loopCreate,\n loopFix: loopFix,\n loopDestroy: loopDestroy,\n };\n\n function setGrabCursor (moving) {\n var swiper = this;\n if (Support.touch || !swiper.params.simulateTouch || (swiper.params.watchOverflow && swiper.isLocked)) { return; }\n var el = swiper.el;\n el.style.cursor = 'move';\n el.style.cursor = moving ? '-webkit-grabbing' : '-webkit-grab';\n el.style.cursor = moving ? '-moz-grabbin' : '-moz-grab';\n el.style.cursor = moving ? 'grabbing' : 'grab';\n }\n\n function unsetGrabCursor () {\n var swiper = this;\n if (Support.touch || (swiper.params.watchOverflow && swiper.isLocked)) { return; }\n swiper.el.style.cursor = '';\n }\n\n var grabCursor = {\n setGrabCursor: setGrabCursor,\n unsetGrabCursor: unsetGrabCursor,\n };\n\n function appendSlide (slides) {\n var swiper = this;\n var $wrapperEl = swiper.$wrapperEl;\n var params = swiper.params;\n if (params.loop) {\n swiper.loopDestroy();\n }\n if (typeof slides === 'object' && 'length' in slides) {\n for (var i = 0; i < slides.length; i += 1) {\n if (slides[i]) { $wrapperEl.append(slides[i]); }\n }\n } else {\n $wrapperEl.append(slides);\n }\n if (params.loop) {\n swiper.loopCreate();\n }\n if (!(params.observer && Support.observer)) {\n swiper.update();\n }\n }\n\n function prependSlide (slides) {\n var swiper = this;\n var params = swiper.params;\n var $wrapperEl = swiper.$wrapperEl;\n var activeIndex = swiper.activeIndex;\n\n if (params.loop) {\n swiper.loopDestroy();\n }\n var newActiveIndex = activeIndex + 1;\n if (typeof slides === 'object' && 'length' in slides) {\n for (var i = 0; i < slides.length; i += 1) {\n if (slides[i]) { $wrapperEl.prepend(slides[i]); }\n }\n newActiveIndex = activeIndex + slides.length;\n } else {\n $wrapperEl.prepend(slides);\n }\n if (params.loop) {\n swiper.loopCreate();\n }\n if (!(params.observer && Support.observer)) {\n swiper.update();\n }\n swiper.slideTo(newActiveIndex, 0, false);\n }\n\n function addSlide (index, slides) {\n var swiper = this;\n var $wrapperEl = swiper.$wrapperEl;\n var params = swiper.params;\n var activeIndex = swiper.activeIndex;\n var activeIndexBuffer = activeIndex;\n if (params.loop) {\n activeIndexBuffer -= swiper.loopedSlides;\n swiper.loopDestroy();\n swiper.slides = $wrapperEl.children((\".\" + (params.slideClass)));\n }\n var baseLength = swiper.slides.length;\n if (index <= 0) {\n swiper.prependSlide(slides);\n return;\n }\n if (index >= baseLength) {\n swiper.appendSlide(slides);\n return;\n }\n var newActiveIndex = activeIndexBuffer > index ? activeIndexBuffer + 1 : activeIndexBuffer;\n\n var slidesBuffer = [];\n for (var i = baseLength - 1; i >= index; i -= 1) {\n var currentSlide = swiper.slides.eq(i);\n currentSlide.remove();\n slidesBuffer.unshift(currentSlide);\n }\n\n if (typeof slides === 'object' && 'length' in slides) {\n for (var i$1 = 0; i$1 < slides.length; i$1 += 1) {\n if (slides[i$1]) { $wrapperEl.append(slides[i$1]); }\n }\n newActiveIndex = activeIndexBuffer > index ? activeIndexBuffer + slides.length : activeIndexBuffer;\n } else {\n $wrapperEl.append(slides);\n }\n\n for (var i$2 = 0; i$2 < slidesBuffer.length; i$2 += 1) {\n $wrapperEl.append(slidesBuffer[i$2]);\n }\n\n if (params.loop) {\n swiper.loopCreate();\n }\n if (!(params.observer && Support.observer)) {\n swiper.update();\n }\n if (params.loop) {\n swiper.slideTo(newActiveIndex + swiper.loopedSlides, 0, false);\n } else {\n swiper.slideTo(newActiveIndex, 0, false);\n }\n }\n\n function removeSlide (slidesIndexes) {\n var swiper = this;\n var params = swiper.params;\n var $wrapperEl = swiper.$wrapperEl;\n var activeIndex = swiper.activeIndex;\n\n var activeIndexBuffer = activeIndex;\n if (params.loop) {\n activeIndexBuffer -= swiper.loopedSlides;\n swiper.loopDestroy();\n swiper.slides = $wrapperEl.children((\".\" + (params.slideClass)));\n }\n var newActiveIndex = activeIndexBuffer;\n var indexToRemove;\n\n if (typeof slidesIndexes === 'object' && 'length' in slidesIndexes) {\n for (var i = 0; i < slidesIndexes.length; i += 1) {\n indexToRemove = slidesIndexes[i];\n if (swiper.slides[indexToRemove]) { swiper.slides.eq(indexToRemove).remove(); }\n if (indexToRemove < newActiveIndex) { newActiveIndex -= 1; }\n }\n newActiveIndex = Math.max(newActiveIndex, 0);\n } else {\n indexToRemove = slidesIndexes;\n if (swiper.slides[indexToRemove]) { swiper.slides.eq(indexToRemove).remove(); }\n if (indexToRemove < newActiveIndex) { newActiveIndex -= 1; }\n newActiveIndex = Math.max(newActiveIndex, 0);\n }\n\n if (params.loop) {\n swiper.loopCreate();\n }\n\n if (!(params.observer && Support.observer)) {\n swiper.update();\n }\n if (params.loop) {\n swiper.slideTo(newActiveIndex + swiper.loopedSlides, 0, false);\n } else {\n swiper.slideTo(newActiveIndex, 0, false);\n }\n }\n\n function removeAllSlides () {\n var swiper = this;\n\n var slidesIndexes = [];\n for (var i = 0; i < swiper.slides.length; i += 1) {\n slidesIndexes.push(i);\n }\n swiper.removeSlide(slidesIndexes);\n }\n\n var manipulation = {\n appendSlide: appendSlide,\n prependSlide: prependSlide,\n addSlide: addSlide,\n removeSlide: removeSlide,\n removeAllSlides: removeAllSlides,\n };\n\n var Device = (function Device() {\n var ua = win.navigator.userAgent;\n\n var device = {\n ios: false,\n android: false,\n androidChrome: false,\n desktop: false,\n windows: false,\n iphone: false,\n ipod: false,\n ipad: false,\n cordova: win.cordova || win.phonegap,\n phonegap: win.cordova || win.phonegap,\n };\n\n var windows = ua.match(/(Windows Phone);?[\\s\\/]+([\\d.]+)?/); // eslint-disable-line\n var android = ua.match(/(Android);?[\\s\\/]+([\\d.]+)?/); // eslint-disable-line\n var ipad = ua.match(/(iPad).*OS\\s([\\d_]+)/);\n var ipod = ua.match(/(iPod)(.*OS\\s([\\d_]+))?/);\n var iphone = !ipad && ua.match(/(iPhone\\sOS|iOS)\\s([\\d_]+)/);\n\n\n // Windows\n if (windows) {\n device.os = 'windows';\n device.osVersion = windows[2];\n device.windows = true;\n }\n // Android\n if (android && !windows) {\n device.os = 'android';\n device.osVersion = android[2];\n device.android = true;\n device.androidChrome = ua.toLowerCase().indexOf('chrome') >= 0;\n }\n if (ipad || iphone || ipod) {\n device.os = 'ios';\n device.ios = true;\n }\n // iOS\n if (iphone && !ipod) {\n device.osVersion = iphone[2].replace(/_/g, '.');\n device.iphone = true;\n }\n if (ipad) {\n device.osVersion = ipad[2].replace(/_/g, '.');\n device.ipad = true;\n }\n if (ipod) {\n device.osVersion = ipod[3] ? ipod[3].replace(/_/g, '.') : null;\n device.iphone = true;\n }\n // iOS 8+ changed UA\n if (device.ios && device.osVersion && ua.indexOf('Version/') >= 0) {\n if (device.osVersion.split('.')[0] === '10') {\n device.osVersion = ua.toLowerCase().split('version/')[1].split(' ')[0];\n }\n }\n\n // Desktop\n device.desktop = !(device.os || device.android || device.webView);\n\n // Webview\n device.webView = (iphone || ipad || ipod) && ua.match(/.*AppleWebKit(?!.*Safari)/i);\n\n // Minimal UI\n if (device.os && device.os === 'ios') {\n var osVersionArr = device.osVersion.split('.');\n var metaViewport = doc.querySelector('meta[name=\"viewport\"]');\n device.minimalUi = !device.webView\n && (ipod || iphone)\n && (osVersionArr[0] * 1 === 7 ? osVersionArr[1] * 1 >= 1 : osVersionArr[0] * 1 > 7)\n && metaViewport && metaViewport.getAttribute('content').indexOf('minimal-ui') >= 0;\n }\n\n // Pixel Ratio\n device.pixelRatio = win.devicePixelRatio || 1;\n\n // Export object\n return device;\n }());\n\n function onTouchStart (event) {\n var swiper = this;\n var data = swiper.touchEventsData;\n var params = swiper.params;\n var touches = swiper.touches;\n if (swiper.animating && params.preventInteractionOnTransition) {\n return;\n }\n var e = event;\n if (e.originalEvent) { e = e.originalEvent; }\n data.isTouchEvent = e.type === 'touchstart';\n if (!data.isTouchEvent && 'which' in e && e.which === 3) { return; }\n if (!data.isTouchEvent && 'button' in e && e.button > 0) { return; }\n if (data.isTouched && data.isMoved) { return; }\n if (params.noSwiping && $(e.target).closest(params.noSwipingSelector ? params.noSwipingSelector : (\".\" + (params.noSwipingClass)))[0]) {\n swiper.allowClick = true;\n return;\n }\n if (params.swipeHandler) {\n if (!$(e).closest(params.swipeHandler)[0]) { return; }\n }\n\n touches.currentX = e.type === 'touchstart' ? e.targetTouches[0].pageX : e.pageX;\n touches.currentY = e.type === 'touchstart' ? e.targetTouches[0].pageY : e.pageY;\n var startX = touches.currentX;\n var startY = touches.currentY;\n\n // Do NOT start if iOS edge swipe is detected. Otherwise iOS app (UIWebView) cannot swipe-to-go-back anymore\n\n var edgeSwipeDetection = params.edgeSwipeDetection || params.iOSEdgeSwipeDetection;\n var edgeSwipeThreshold = params.edgeSwipeThreshold || params.iOSEdgeSwipeThreshold;\n if (\n edgeSwipeDetection\n && ((startX <= edgeSwipeThreshold)\n || (startX >= win.screen.width - edgeSwipeThreshold))\n ) {\n return;\n }\n\n Utils.extend(data, {\n isTouched: true,\n isMoved: false,\n allowTouchCallbacks: true,\n isScrolling: undefined,\n startMoving: undefined,\n });\n\n touches.startX = startX;\n touches.startY = startY;\n data.touchStartTime = Utils.now();\n swiper.allowClick = true;\n swiper.updateSize();\n swiper.swipeDirection = undefined;\n if (params.threshold > 0) { data.allowThresholdMove = false; }\n if (e.type !== 'touchstart') {\n var preventDefault = true;\n if ($(e.target).is(data.formElements)) { preventDefault = false; }\n if (\n doc.activeElement\n && $(doc.activeElement).is(data.formElements)\n && doc.activeElement !== e.target\n ) {\n doc.activeElement.blur();\n }\n\n var shouldPreventDefault = preventDefault && swiper.allowTouchMove && params.touchStartPreventDefault;\n if (params.touchStartForcePreventDefault || shouldPreventDefault) {\n e.preventDefault();\n }\n }\n swiper.emit('touchStart', e);\n }\n\n function onTouchMove (event) {\n var swiper = this;\n var data = swiper.touchEventsData;\n var params = swiper.params;\n var touches = swiper.touches;\n var rtl = swiper.rtlTranslate;\n var e = event;\n if (e.originalEvent) { e = e.originalEvent; }\n if (!data.isTouched) {\n if (data.startMoving && data.isScrolling) {\n swiper.emit('touchMoveOpposite', e);\n }\n return;\n }\n if (data.isTouchEvent && e.type === 'mousemove') { return; }\n var pageX = e.type === 'touchmove' ? e.targetTouches[0].pageX : e.pageX;\n var pageY = e.type === 'touchmove' ? e.targetTouches[0].pageY : e.pageY;\n if (e.preventedByNestedSwiper) {\n touches.startX = pageX;\n touches.startY = pageY;\n return;\n }\n if (!swiper.allowTouchMove) {\n // isMoved = true;\n swiper.allowClick = false;\n if (data.isTouched) {\n Utils.extend(touches, {\n startX: pageX,\n startY: pageY,\n currentX: pageX,\n currentY: pageY,\n });\n data.touchStartTime = Utils.now();\n }\n return;\n }\n if (data.isTouchEvent && params.touchReleaseOnEdges && !params.loop) {\n if (swiper.isVertical()) {\n // Vertical\n if (\n (pageY < touches.startY && swiper.translate <= swiper.maxTranslate())\n || (pageY > touches.startY && swiper.translate >= swiper.minTranslate())\n ) {\n data.isTouched = false;\n data.isMoved = false;\n return;\n }\n } else if (\n (pageX < touches.startX && swiper.translate <= swiper.maxTranslate())\n || (pageX > touches.startX && swiper.translate >= swiper.minTranslate())\n ) {\n return;\n }\n }\n if (data.isTouchEvent && doc.activeElement) {\n if (e.target === doc.activeElement && $(e.target).is(data.formElements)) {\n data.isMoved = true;\n swiper.allowClick = false;\n return;\n }\n }\n if (data.allowTouchCallbacks) {\n swiper.emit('touchMove', e);\n }\n if (e.targetTouches && e.targetTouches.length > 1) { return; }\n\n touches.currentX = pageX;\n touches.currentY = pageY;\n\n var diffX = touches.currentX - touches.startX;\n var diffY = touches.currentY - touches.startY;\n if (swiper.params.threshold && Math.sqrt((Math.pow( diffX, 2 )) + (Math.pow( diffY, 2 ))) < swiper.params.threshold) { return; }\n\n if (typeof data.isScrolling === 'undefined') {\n var touchAngle;\n if ((swiper.isHorizontal() && touches.currentY === touches.startY) || (swiper.isVertical() && touches.currentX === touches.startX)) {\n data.isScrolling = false;\n } else {\n // eslint-disable-next-line\n if ((diffX * diffX) + (diffY * diffY) >= 25) {\n touchAngle = (Math.atan2(Math.abs(diffY), Math.abs(diffX)) * 180) / Math.PI;\n data.isScrolling = swiper.isHorizontal() ? touchAngle > params.touchAngle : (90 - touchAngle > params.touchAngle);\n }\n }\n }\n if (data.isScrolling) {\n swiper.emit('touchMoveOpposite', e);\n }\n if (typeof data.startMoving === 'undefined') {\n if (touches.currentX !== touches.startX || touches.currentY !== touches.startY) {\n data.startMoving = true;\n }\n }\n if (data.isScrolling) {\n data.isTouched = false;\n return;\n }\n if (!data.startMoving) {\n return;\n }\n swiper.allowClick = false;\n e.preventDefault();\n if (params.touchMoveStopPropagation && !params.nested) {\n e.stopPropagation();\n }\n\n if (!data.isMoved) {\n if (params.loop) {\n swiper.loopFix();\n }\n data.startTranslate = swiper.getTranslate();\n swiper.setTransition(0);\n if (swiper.animating) {\n swiper.$wrapperEl.trigger('webkitTransitionEnd transitionend');\n }\n data.allowMomentumBounce = false;\n // Grab Cursor\n if (params.grabCursor && (swiper.allowSlideNext === true || swiper.allowSlidePrev === true)) {\n swiper.setGrabCursor(true);\n }\n swiper.emit('sliderFirstMove', e);\n }\n swiper.emit('sliderMove', e);\n data.isMoved = true;\n\n var diff = swiper.isHorizontal() ? diffX : diffY;\n touches.diff = diff;\n\n diff *= params.touchRatio;\n if (rtl) { diff = -diff; }\n\n swiper.swipeDirection = diff > 0 ? 'prev' : 'next';\n data.currentTranslate = diff + data.startTranslate;\n\n var disableParentSwiper = true;\n var resistanceRatio = params.resistanceRatio;\n if (params.touchReleaseOnEdges) {\n resistanceRatio = 0;\n }\n if ((diff > 0 && data.currentTranslate > swiper.minTranslate())) {\n disableParentSwiper = false;\n if (params.resistance) { data.currentTranslate = (swiper.minTranslate() - 1) + (Math.pow( (-swiper.minTranslate() + data.startTranslate + diff), resistanceRatio )); }\n } else if (diff < 0 && data.currentTranslate < swiper.maxTranslate()) {\n disableParentSwiper = false;\n if (params.resistance) { data.currentTranslate = (swiper.maxTranslate() + 1) - (Math.pow( (swiper.maxTranslate() - data.startTranslate - diff), resistanceRatio )); }\n }\n\n if (disableParentSwiper) {\n e.preventedByNestedSwiper = true;\n }\n\n // Directions locks\n if (!swiper.allowSlideNext && swiper.swipeDirection === 'next' && data.currentTranslate < data.startTranslate) {\n data.currentTranslate = data.startTranslate;\n }\n if (!swiper.allowSlidePrev && swiper.swipeDirection === 'prev' && data.currentTranslate > data.startTranslate) {\n data.currentTranslate = data.startTranslate;\n }\n\n\n // Threshold\n if (params.threshold > 0) {\n if (Math.abs(diff) > params.threshold || data.allowThresholdMove) {\n if (!data.allowThresholdMove) {\n data.allowThresholdMove = true;\n touches.startX = touches.currentX;\n touches.startY = touches.currentY;\n data.currentTranslate = data.startTranslate;\n touches.diff = swiper.isHorizontal() ? touches.currentX - touches.startX : touches.currentY - touches.startY;\n return;\n }\n } else {\n data.currentTranslate = data.startTranslate;\n return;\n }\n }\n\n if (!params.followFinger) { return; }\n\n // Update active index in free mode\n if (params.freeMode || params.watchSlidesProgress || params.watchSlidesVisibility) {\n swiper.updateActiveIndex();\n swiper.updateSlidesClasses();\n }\n if (params.freeMode) {\n // Velocity\n if (data.velocities.length === 0) {\n data.velocities.push({\n position: touches[swiper.isHorizontal() ? 'startX' : 'startY'],\n time: data.touchStartTime,\n });\n }\n data.velocities.push({\n position: touches[swiper.isHorizontal() ? 'currentX' : 'currentY'],\n time: Utils.now(),\n });\n }\n // Update progress\n swiper.updateProgress(data.currentTranslate);\n // Update translate\n swiper.setTranslate(data.currentTranslate);\n }\n\n function onTouchEnd (event) {\n var swiper = this;\n var data = swiper.touchEventsData;\n\n var params = swiper.params;\n var touches = swiper.touches;\n var rtl = swiper.rtlTranslate;\n var $wrapperEl = swiper.$wrapperEl;\n var slidesGrid = swiper.slidesGrid;\n var snapGrid = swiper.snapGrid;\n var e = event;\n if (e.originalEvent) { e = e.originalEvent; }\n if (data.allowTouchCallbacks) {\n swiper.emit('touchEnd', e);\n }\n data.allowTouchCallbacks = false;\n if (!data.isTouched) {\n if (data.isMoved && params.grabCursor) {\n swiper.setGrabCursor(false);\n }\n data.isMoved = false;\n data.startMoving = false;\n return;\n }\n // Return Grab Cursor\n if (params.grabCursor && data.isMoved && data.isTouched && (swiper.allowSlideNext === true || swiper.allowSlidePrev === true)) {\n swiper.setGrabCursor(false);\n }\n\n // Time diff\n var touchEndTime = Utils.now();\n var timeDiff = touchEndTime - data.touchStartTime;\n\n // Tap, doubleTap, Click\n if (swiper.allowClick) {\n swiper.updateClickedSlide(e);\n swiper.emit('tap', e);\n if (timeDiff < 300 && (touchEndTime - data.lastClickTime) > 300) {\n if (data.clickTimeout) { clearTimeout(data.clickTimeout); }\n data.clickTimeout = Utils.nextTick(function () {\n if (!swiper || swiper.destroyed) { return; }\n swiper.emit('click', e);\n }, 300);\n }\n if (timeDiff < 300 && (touchEndTime - data.lastClickTime) < 300) {\n if (data.clickTimeout) { clearTimeout(data.clickTimeout); }\n swiper.emit('doubleTap', e);\n }\n }\n\n data.lastClickTime = Utils.now();\n Utils.nextTick(function () {\n if (!swiper.destroyed) { swiper.allowClick = true; }\n });\n\n if (!data.isTouched || !data.isMoved || !swiper.swipeDirection || touches.diff === 0 || data.currentTranslate === data.startTranslate) {\n data.isTouched = false;\n data.isMoved = false;\n data.startMoving = false;\n return;\n }\n data.isTouched = false;\n data.isMoved = false;\n data.startMoving = false;\n\n var currentPos;\n if (params.followFinger) {\n currentPos = rtl ? swiper.translate : -swiper.translate;\n } else {\n currentPos = -data.currentTranslate;\n }\n\n if (params.freeMode) {\n if (currentPos < -swiper.minTranslate()) {\n swiper.slideTo(swiper.activeIndex);\n return;\n }\n if (currentPos > -swiper.maxTranslate()) {\n if (swiper.slides.length < snapGrid.length) {\n swiper.slideTo(snapGrid.length - 1);\n } else {\n swiper.slideTo(swiper.slides.length - 1);\n }\n return;\n }\n\n if (params.freeModeMomentum) {\n if (data.velocities.length > 1) {\n var lastMoveEvent = data.velocities.pop();\n var velocityEvent = data.velocities.pop();\n\n var distance = lastMoveEvent.position - velocityEvent.position;\n var time = lastMoveEvent.time - velocityEvent.time;\n swiper.velocity = distance / time;\n swiper.velocity /= 2;\n if (Math.abs(swiper.velocity) < params.freeModeMinimumVelocity) {\n swiper.velocity = 0;\n }\n // this implies that the user stopped moving a finger then released.\n // There would be no events with distance zero, so the last event is stale.\n if (time > 150 || (Utils.now() - lastMoveEvent.time) > 300) {\n swiper.velocity = 0;\n }\n } else {\n swiper.velocity = 0;\n }\n swiper.velocity *= params.freeModeMomentumVelocityRatio;\n\n data.velocities.length = 0;\n var momentumDuration = 1000 * params.freeModeMomentumRatio;\n var momentumDistance = swiper.velocity * momentumDuration;\n\n var newPosition = swiper.translate + momentumDistance;\n if (rtl) { newPosition = -newPosition; }\n\n var doBounce = false;\n var afterBouncePosition;\n var bounceAmount = Math.abs(swiper.velocity) * 20 * params.freeModeMomentumBounceRatio;\n var needsLoopFix;\n if (newPosition < swiper.maxTranslate()) {\n if (params.freeModeMomentumBounce) {\n if (newPosition + swiper.maxTranslate() < -bounceAmount) {\n newPosition = swiper.maxTranslate() - bounceAmount;\n }\n afterBouncePosition = swiper.maxTranslate();\n doBounce = true;\n data.allowMomentumBounce = true;\n } else {\n newPosition = swiper.maxTranslate();\n }\n if (params.loop && params.centeredSlides) { needsLoopFix = true; }\n } else if (newPosition > swiper.minTranslate()) {\n if (params.freeModeMomentumBounce) {\n if (newPosition - swiper.minTranslate() > bounceAmount) {\n newPosition = swiper.minTranslate() + bounceAmount;\n }\n afterBouncePosition = swiper.minTranslate();\n doBounce = true;\n data.allowMomentumBounce = true;\n } else {\n newPosition = swiper.minTranslate();\n }\n if (params.loop && params.centeredSlides) { needsLoopFix = true; }\n } else if (params.freeModeSticky) {\n var nextSlide;\n for (var j = 0; j < snapGrid.length; j += 1) {\n if (snapGrid[j] > -newPosition) {\n nextSlide = j;\n break;\n }\n }\n\n if (Math.abs(snapGrid[nextSlide] - newPosition) < Math.abs(snapGrid[nextSlide - 1] - newPosition) || swiper.swipeDirection === 'next') {\n newPosition = snapGrid[nextSlide];\n } else {\n newPosition = snapGrid[nextSlide - 1];\n }\n newPosition = -newPosition;\n }\n if (needsLoopFix) {\n swiper.once('transitionEnd', function () {\n swiper.loopFix();\n });\n }\n // Fix duration\n if (swiper.velocity !== 0) {\n if (rtl) {\n momentumDuration = Math.abs((-newPosition - swiper.translate) / swiper.velocity);\n } else {\n momentumDuration = Math.abs((newPosition - swiper.translate) / swiper.velocity);\n }\n } else if (params.freeModeSticky) {\n swiper.slideToClosest();\n return;\n }\n\n if (params.freeModeMomentumBounce && doBounce) {\n swiper.updateProgress(afterBouncePosition);\n swiper.setTransition(momentumDuration);\n swiper.setTranslate(newPosition);\n swiper.transitionStart(true, swiper.swipeDirection);\n swiper.animating = true;\n $wrapperEl.transitionEnd(function () {\n if (!swiper || swiper.destroyed || !data.allowMomentumBounce) { return; }\n swiper.emit('momentumBounce');\n\n swiper.setTransition(params.speed);\n swiper.setTranslate(afterBouncePosition);\n $wrapperEl.transitionEnd(function () {\n if (!swiper || swiper.destroyed) { return; }\n swiper.transitionEnd();\n });\n });\n } else if (swiper.velocity) {\n swiper.updateProgress(newPosition);\n swiper.setTransition(momentumDuration);\n swiper.setTranslate(newPosition);\n swiper.transitionStart(true, swiper.swipeDirection);\n if (!swiper.animating) {\n swiper.animating = true;\n $wrapperEl.transitionEnd(function () {\n if (!swiper || swiper.destroyed) { return; }\n swiper.transitionEnd();\n });\n }\n } else {\n swiper.updateProgress(newPosition);\n }\n\n swiper.updateActiveIndex();\n swiper.updateSlidesClasses();\n } else if (params.freeModeSticky) {\n swiper.slideToClosest();\n return;\n }\n\n if (!params.freeModeMomentum || timeDiff >= params.longSwipesMs) {\n swiper.updateProgress();\n swiper.updateActiveIndex();\n swiper.updateSlidesClasses();\n }\n return;\n }\n\n // Find current slide\n var stopIndex = 0;\n var groupSize = swiper.slidesSizesGrid[0];\n for (var i = 0; i < slidesGrid.length; i += params.slidesPerGroup) {\n if (typeof slidesGrid[i + params.slidesPerGroup] !== 'undefined') {\n if (currentPos >= slidesGrid[i] && currentPos < slidesGrid[i + params.slidesPerGroup]) {\n stopIndex = i;\n groupSize = slidesGrid[i + params.slidesPerGroup] - slidesGrid[i];\n }\n } else if (currentPos >= slidesGrid[i]) {\n stopIndex = i;\n groupSize = slidesGrid[slidesGrid.length - 1] - slidesGrid[slidesGrid.length - 2];\n }\n }\n\n // Find current slide size\n var ratio = (currentPos - slidesGrid[stopIndex]) / groupSize;\n\n if (timeDiff > params.longSwipesMs) {\n // Long touches\n if (!params.longSwipes) {\n swiper.slideTo(swiper.activeIndex);\n return;\n }\n if (swiper.swipeDirection === 'next') {\n if (ratio >= params.longSwipesRatio) { swiper.slideTo(stopIndex + params.slidesPerGroup); }\n else { swiper.slideTo(stopIndex); }\n }\n if (swiper.swipeDirection === 'prev') {\n if (ratio > (1 - params.longSwipesRatio)) { swiper.slideTo(stopIndex + params.slidesPerGroup); }\n else { swiper.slideTo(stopIndex); }\n }\n } else {\n // Short swipes\n if (!params.shortSwipes) {\n swiper.slideTo(swiper.activeIndex);\n return;\n }\n if (swiper.swipeDirection === 'next') {\n swiper.slideTo(stopIndex + params.slidesPerGroup);\n }\n if (swiper.swipeDirection === 'prev') {\n swiper.slideTo(stopIndex);\n }\n }\n }\n\n function onResize () {\n var swiper = this;\n\n var params = swiper.params;\n var el = swiper.el;\n\n if (el && el.offsetWidth === 0) { return; }\n\n // Breakpoints\n if (params.breakpoints) {\n swiper.setBreakpoint();\n }\n\n // Save locks\n var allowSlideNext = swiper.allowSlideNext;\n var allowSlidePrev = swiper.allowSlidePrev;\n var snapGrid = swiper.snapGrid;\n\n // Disable locks on resize\n swiper.allowSlideNext = true;\n swiper.allowSlidePrev = true;\n\n swiper.updateSize();\n swiper.updateSlides();\n\n if (params.freeMode) {\n var newTranslate = Math.min(Math.max(swiper.translate, swiper.maxTranslate()), swiper.minTranslate());\n swiper.setTranslate(newTranslate);\n swiper.updateActiveIndex();\n swiper.updateSlidesClasses();\n\n if (params.autoHeight) {\n swiper.updateAutoHeight();\n }\n } else {\n swiper.updateSlidesClasses();\n if ((params.slidesPerView === 'auto' || params.slidesPerView > 1) && swiper.isEnd && !swiper.params.centeredSlides) {\n swiper.slideTo(swiper.slides.length - 1, 0, false, true);\n } else {\n swiper.slideTo(swiper.activeIndex, 0, false, true);\n }\n }\n if (swiper.autoplay && swiper.autoplay.running && swiper.autoplay.paused) {\n swiper.autoplay.run();\n }\n // Return locks after resize\n swiper.allowSlidePrev = allowSlidePrev;\n swiper.allowSlideNext = allowSlideNext;\n\n if (swiper.params.watchOverflow && snapGrid !== swiper.snapGrid) {\n swiper.checkOverflow();\n }\n }\n\n function onClick (e) {\n var swiper = this;\n if (!swiper.allowClick) {\n if (swiper.params.preventClicks) { e.preventDefault(); }\n if (swiper.params.preventClicksPropagation && swiper.animating) {\n e.stopPropagation();\n e.stopImmediatePropagation();\n }\n }\n }\n\n function attachEvents() {\n var swiper = this;\n var params = swiper.params;\n var touchEvents = swiper.touchEvents;\n var el = swiper.el;\n var wrapperEl = swiper.wrapperEl;\n\n {\n swiper.onTouchStart = onTouchStart.bind(swiper);\n swiper.onTouchMove = onTouchMove.bind(swiper);\n swiper.onTouchEnd = onTouchEnd.bind(swiper);\n }\n\n swiper.onClick = onClick.bind(swiper);\n\n var target = params.touchEventsTarget === 'container' ? el : wrapperEl;\n var capture = !!params.nested;\n\n // Touch Events\n {\n if (!Support.touch && (Support.pointerEvents || Support.prefixedPointerEvents)) {\n target.addEventListener(touchEvents.start, swiper.onTouchStart, false);\n doc.addEventListener(touchEvents.move, swiper.onTouchMove, capture);\n doc.addEventListener(touchEvents.end, swiper.onTouchEnd, false);\n } else {\n if (Support.touch) {\n var passiveListener = touchEvents.start === 'touchstart' && Support.passiveListener && params.passiveListeners ? { passive: true, capture: false } : false;\n target.addEventListener(touchEvents.start, swiper.onTouchStart, passiveListener);\n target.addEventListener(touchEvents.move, swiper.onTouchMove, Support.passiveListener ? { passive: false, capture: capture } : capture);\n target.addEventListener(touchEvents.end, swiper.onTouchEnd, passiveListener);\n }\n if ((params.simulateTouch && !Device.ios && !Device.android) || (params.simulateTouch && !Support.touch && Device.ios)) {\n target.addEventListener('mousedown', swiper.onTouchStart, false);\n doc.addEventListener('mousemove', swiper.onTouchMove, capture);\n doc.addEventListener('mouseup', swiper.onTouchEnd, false);\n }\n }\n // Prevent Links Clicks\n if (params.preventClicks || params.preventClicksPropagation) {\n target.addEventListener('click', swiper.onClick, true);\n }\n }\n\n // Resize handler\n swiper.on((Device.ios || Device.android ? 'resize orientationchange observerUpdate' : 'resize observerUpdate'), onResize, true);\n }\n\n function detachEvents() {\n var swiper = this;\n\n var params = swiper.params;\n var touchEvents = swiper.touchEvents;\n var el = swiper.el;\n var wrapperEl = swiper.wrapperEl;\n\n var target = params.touchEventsTarget === 'container' ? el : wrapperEl;\n var capture = !!params.nested;\n\n // Touch Events\n {\n if (!Support.touch && (Support.pointerEvents || Support.prefixedPointerEvents)) {\n target.removeEventListener(touchEvents.start, swiper.onTouchStart, false);\n doc.removeEventListener(touchEvents.move, swiper.onTouchMove, capture);\n doc.removeEventListener(touchEvents.end, swiper.onTouchEnd, false);\n } else {\n if (Support.touch) {\n var passiveListener = touchEvents.start === 'onTouchStart' && Support.passiveListener && params.passiveListeners ? { passive: true, capture: false } : false;\n target.removeEventListener(touchEvents.start, swiper.onTouchStart, passiveListener);\n target.removeEventListener(touchEvents.move, swiper.onTouchMove, capture);\n target.removeEventListener(touchEvents.end, swiper.onTouchEnd, passiveListener);\n }\n if ((params.simulateTouch && !Device.ios && !Device.android) || (params.simulateTouch && !Support.touch && Device.ios)) {\n target.removeEventListener('mousedown', swiper.onTouchStart, false);\n doc.removeEventListener('mousemove', swiper.onTouchMove, capture);\n doc.removeEventListener('mouseup', swiper.onTouchEnd, false);\n }\n }\n // Prevent Links Clicks\n if (params.preventClicks || params.preventClicksPropagation) {\n target.removeEventListener('click', swiper.onClick, true);\n }\n }\n\n // Resize handler\n swiper.off((Device.ios || Device.android ? 'resize orientationchange observerUpdate' : 'resize observerUpdate'), onResize);\n }\n\n var events = {\n attachEvents: attachEvents,\n detachEvents: detachEvents,\n };\n\n function setBreakpoint () {\n var swiper = this;\n var activeIndex = swiper.activeIndex;\n var initialized = swiper.initialized;\n var loopedSlides = swiper.loopedSlides; if ( loopedSlides === void 0 ) loopedSlides = 0;\n var params = swiper.params;\n var breakpoints = params.breakpoints;\n if (!breakpoints || (breakpoints && Object.keys(breakpoints).length === 0)) { return; }\n\n // Set breakpoint for window width and update parameters\n var breakpoint = swiper.getBreakpoint(breakpoints);\n\n if (breakpoint && swiper.currentBreakpoint !== breakpoint) {\n var breakpointOnlyParams = breakpoint in breakpoints ? breakpoints[breakpoint] : undefined;\n if (breakpointOnlyParams) {\n ['slidesPerView', 'spaceBetween', 'slidesPerGroup'].forEach(function (param) {\n var paramValue = breakpointOnlyParams[param];\n if (typeof paramValue === 'undefined') { return; }\n if (param === 'slidesPerView' && (paramValue === 'AUTO' || paramValue === 'auto')) {\n breakpointOnlyParams[param] = 'auto';\n } else if (param === 'slidesPerView') {\n breakpointOnlyParams[param] = parseFloat(paramValue);\n } else {\n breakpointOnlyParams[param] = parseInt(paramValue, 10);\n }\n });\n }\n\n var breakpointParams = breakpointOnlyParams || swiper.originalParams;\n var directionChanged = breakpointParams.direction && breakpointParams.direction !== params.direction;\n var needsReLoop = params.loop && (breakpointParams.slidesPerView !== params.slidesPerView || directionChanged);\n\n if (directionChanged && initialized) {\n swiper.changeDirection();\n }\n\n Utils.extend(swiper.params, breakpointParams);\n\n Utils.extend(swiper, {\n allowTouchMove: swiper.params.allowTouchMove,\n allowSlideNext: swiper.params.allowSlideNext,\n allowSlidePrev: swiper.params.allowSlidePrev,\n });\n\n swiper.currentBreakpoint = breakpoint;\n\n if (needsReLoop && initialized) {\n swiper.loopDestroy();\n swiper.loopCreate();\n swiper.updateSlides();\n swiper.slideTo((activeIndex - loopedSlides) + swiper.loopedSlides, 0, false);\n }\n\n swiper.emit('breakpoint', breakpointParams);\n }\n }\n\n function getBreakpoint (breakpoints) {\n var swiper = this;\n // Get breakpoint for window width\n if (!breakpoints) { return undefined; }\n var breakpoint = false;\n var points = [];\n Object.keys(breakpoints).forEach(function (point) {\n points.push(point);\n });\n points.sort(function (a, b) { return parseInt(a, 10) - parseInt(b, 10); });\n for (var i = 0; i < points.length; i += 1) {\n var point = points[i];\n if (swiper.params.breakpointsInverse) {\n if (point <= win.innerWidth) {\n breakpoint = point;\n }\n } else if (point >= win.innerWidth && !breakpoint) {\n breakpoint = point;\n }\n }\n return breakpoint || 'max';\n }\n\n var breakpoints = { setBreakpoint: setBreakpoint, getBreakpoint: getBreakpoint };\n\n function addClasses () {\n var swiper = this;\n var classNames = swiper.classNames;\n var params = swiper.params;\n var rtl = swiper.rtl;\n var $el = swiper.$el;\n var suffixes = [];\n\n suffixes.push('initialized');\n suffixes.push(params.direction);\n\n if (params.freeMode) {\n suffixes.push('free-mode');\n }\n if (!Support.flexbox) {\n suffixes.push('no-flexbox');\n }\n if (params.autoHeight) {\n suffixes.push('autoheight');\n }\n if (rtl) {\n suffixes.push('rtl');\n }\n if (params.slidesPerColumn > 1) {\n suffixes.push('multirow');\n }\n if (Device.android) {\n suffixes.push('android');\n }\n if (Device.ios) {\n suffixes.push('ios');\n }\n // WP8 Touch Events Fix\n if ((Browser.isIE || Browser.isEdge) && (Support.pointerEvents || Support.prefixedPointerEvents)) {\n suffixes.push((\"wp8-\" + (params.direction)));\n }\n\n suffixes.forEach(function (suffix) {\n classNames.push(params.containerModifierClass + suffix);\n });\n\n $el.addClass(classNames.join(' '));\n }\n\n function removeClasses () {\n var swiper = this;\n var $el = swiper.$el;\n var classNames = swiper.classNames;\n\n $el.removeClass(classNames.join(' '));\n }\n\n var classes = { addClasses: addClasses, removeClasses: removeClasses };\n\n function loadImage (imageEl, src, srcset, sizes, checkForComplete, callback) {\n var image;\n function onReady() {\n if (callback) { callback(); }\n }\n if (!imageEl.complete || !checkForComplete) {\n if (src) {\n image = new win.Image();\n image.onload = onReady;\n image.onerror = onReady;\n if (sizes) {\n image.sizes = sizes;\n }\n if (srcset) {\n image.srcset = srcset;\n }\n if (src) {\n image.src = src;\n }\n } else {\n onReady();\n }\n } else {\n // image already loaded...\n onReady();\n }\n }\n\n function preloadImages () {\n var swiper = this;\n swiper.imagesToLoad = swiper.$el.find('img');\n function onReady() {\n if (typeof swiper === 'undefined' || swiper === null || !swiper || swiper.destroyed) { return; }\n if (swiper.imagesLoaded !== undefined) { swiper.imagesLoaded += 1; }\n if (swiper.imagesLoaded === swiper.imagesToLoad.length) {\n if (swiper.params.updateOnImagesReady) { swiper.update(); }\n swiper.emit('imagesReady');\n }\n }\n for (var i = 0; i < swiper.imagesToLoad.length; i += 1) {\n var imageEl = swiper.imagesToLoad[i];\n swiper.loadImage(\n imageEl,\n imageEl.currentSrc || imageEl.getAttribute('src'),\n imageEl.srcset || imageEl.getAttribute('srcset'),\n imageEl.sizes || imageEl.getAttribute('sizes'),\n true,\n onReady\n );\n }\n }\n\n var images = {\n loadImage: loadImage,\n preloadImages: preloadImages,\n };\n\n function checkOverflow() {\n var swiper = this;\n var wasLocked = swiper.isLocked;\n\n swiper.isLocked = swiper.snapGrid.length === 1;\n swiper.allowSlideNext = !swiper.isLocked;\n swiper.allowSlidePrev = !swiper.isLocked;\n\n // events\n if (wasLocked !== swiper.isLocked) { swiper.emit(swiper.isLocked ? 'lock' : 'unlock'); }\n\n if (wasLocked && wasLocked !== swiper.isLocked) {\n swiper.isEnd = false;\n swiper.navigation.update();\n }\n }\n\n var checkOverflow$1 = { checkOverflow: checkOverflow };\n\n var defaults = {\n init: true,\n direction: 'horizontal',\n touchEventsTarget: 'container',\n initialSlide: 0,\n speed: 300,\n //\n preventInteractionOnTransition: false,\n\n // To support iOS's swipe-to-go-back gesture (when being used in-app, with UIWebView).\n edgeSwipeDetection: false,\n edgeSwipeThreshold: 20,\n\n // Free mode\n freeMode: false,\n freeModeMomentum: true,\n freeModeMomentumRatio: 1,\n freeModeMomentumBounce: true,\n freeModeMomentumBounceRatio: 1,\n freeModeMomentumVelocityRatio: 1,\n freeModeSticky: false,\n freeModeMinimumVelocity: 0.02,\n\n // Autoheight\n autoHeight: false,\n\n // Set wrapper width\n setWrapperSize: false,\n\n // Virtual Translate\n virtualTranslate: false,\n\n // Effects\n effect: 'slide', // 'slide' or 'fade' or 'cube' or 'coverflow' or 'flip'\n\n // Breakpoints\n breakpoints: undefined,\n breakpointsInverse: false,\n\n // Slides grid\n spaceBetween: 0,\n slidesPerView: 1,\n slidesPerColumn: 1,\n slidesPerColumnFill: 'column',\n slidesPerGroup: 1,\n centeredSlides: false,\n slidesOffsetBefore: 0, // in px\n slidesOffsetAfter: 0, // in px\n normalizeSlideIndex: true,\n centerInsufficientSlides: false,\n\n // Disable swiper and hide navigation when container not overflow\n watchOverflow: false,\n\n // Round length\n roundLengths: false,\n\n // Touches\n touchRatio: 1,\n touchAngle: 45,\n simulateTouch: true,\n shortSwipes: true,\n longSwipes: true,\n longSwipesRatio: 0.5,\n longSwipesMs: 300,\n followFinger: true,\n allowTouchMove: true,\n threshold: 0,\n touchMoveStopPropagation: true,\n touchStartPreventDefault: true,\n touchStartForcePreventDefault: false,\n touchReleaseOnEdges: false,\n\n // Unique Navigation Elements\n uniqueNavElements: true,\n\n // Resistance\n resistance: true,\n resistanceRatio: 0.85,\n\n // Progress\n watchSlidesProgress: false,\n watchSlidesVisibility: false,\n\n // Cursor\n grabCursor: false,\n\n // Clicks\n preventClicks: true,\n preventClicksPropagation: true,\n slideToClickedSlide: false,\n\n // Images\n preloadImages: true,\n updateOnImagesReady: true,\n\n // loop\n loop: false,\n loopAdditionalSlides: 0,\n loopedSlides: null,\n loopFillGroupWithBlank: false,\n\n // Swiping/no swiping\n allowSlidePrev: true,\n allowSlideNext: true,\n swipeHandler: null, // '.swipe-handler',\n noSwiping: true,\n noSwipingClass: 'swiper-no-swiping',\n noSwipingSelector: null,\n\n // Passive Listeners\n passiveListeners: true,\n\n // NS\n containerModifierClass: 'swiper-container-', // NEW\n slideClass: 'swiper-slide',\n slideBlankClass: 'swiper-slide-invisible-blank',\n slideActiveClass: 'swiper-slide-active',\n slideDuplicateActiveClass: 'swiper-slide-duplicate-active',\n slideVisibleClass: 'swiper-slide-visible',\n slideDuplicateClass: 'swiper-slide-duplicate',\n slideNextClass: 'swiper-slide-next',\n slideDuplicateNextClass: 'swiper-slide-duplicate-next',\n slidePrevClass: 'swiper-slide-prev',\n slideDuplicatePrevClass: 'swiper-slide-duplicate-prev',\n wrapperClass: 'swiper-wrapper',\n\n // Callbacks\n runCallbacksOnInit: true,\n };\n\n /* eslint no-param-reassign: \"off\" */\n\n var prototypes = {\n update: update,\n translate: translate,\n transition: transition$1,\n slide: slide,\n loop: loop,\n grabCursor: grabCursor,\n manipulation: manipulation,\n events: events,\n breakpoints: breakpoints,\n checkOverflow: checkOverflow$1,\n classes: classes,\n images: images,\n };\n\n var extendedDefaults = {};\n\n var Swiper = /*@__PURE__*/(function (SwiperClass) {\n function Swiper() {\n var assign;\n\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n var el;\n var params;\n if (args.length === 1 && args[0].constructor && args[0].constructor === Object) {\n params = args[0];\n } else {\n (assign = args, el = assign[0], params = assign[1]);\n }\n if (!params) { params = {}; }\n\n params = Utils.extend({}, params);\n if (el && !params.el) { params.el = el; }\n\n SwiperClass.call(this, params);\n\n Object.keys(prototypes).forEach(function (prototypeGroup) {\n Object.keys(prototypes[prototypeGroup]).forEach(function (protoMethod) {\n if (!Swiper.prototype[protoMethod]) {\n Swiper.prototype[protoMethod] = prototypes[prototypeGroup][protoMethod];\n }\n });\n });\n\n // Swiper Instance\n var swiper = this;\n if (typeof swiper.modules === 'undefined') {\n swiper.modules = {};\n }\n Object.keys(swiper.modules).forEach(function (moduleName) {\n var module = swiper.modules[moduleName];\n if (module.params) {\n var moduleParamName = Object.keys(module.params)[0];\n var moduleParams = module.params[moduleParamName];\n if (typeof moduleParams !== 'object' || moduleParams === null) { return; }\n if (!(moduleParamName in params && 'enabled' in moduleParams)) { return; }\n if (params[moduleParamName] === true) {\n params[moduleParamName] = { enabled: true };\n }\n if (\n typeof params[moduleParamName] === 'object'\n && !('enabled' in params[moduleParamName])\n ) {\n params[moduleParamName].enabled = true;\n }\n if (!params[moduleParamName]) { params[moduleParamName] = { enabled: false }; }\n }\n });\n\n // Extend defaults with modules params\n var swiperParams = Utils.extend({}, defaults);\n swiper.useModulesParams(swiperParams);\n\n // Extend defaults with passed params\n swiper.params = Utils.extend({}, swiperParams, extendedDefaults, params);\n swiper.originalParams = Utils.extend({}, swiper.params);\n swiper.passedParams = Utils.extend({}, params);\n\n // Save Dom lib\n swiper.$ = $;\n\n // Find el\n var $el = $(swiper.params.el);\n el = $el[0];\n\n if (!el) {\n return undefined;\n }\n\n if ($el.length > 1) {\n var swipers = [];\n $el.each(function (index, containerEl) {\n var newParams = Utils.extend({}, params, { el: containerEl });\n swipers.push(new Swiper(newParams));\n });\n return swipers;\n }\n\n el.swiper = swiper;\n $el.data('swiper', swiper);\n\n // Find Wrapper\n var $wrapperEl = $el.children((\".\" + (swiper.params.wrapperClass)));\n\n // Extend Swiper\n Utils.extend(swiper, {\n $el: $el,\n el: el,\n $wrapperEl: $wrapperEl,\n wrapperEl: $wrapperEl[0],\n\n // Classes\n classNames: [],\n\n // Slides\n slides: $(),\n slidesGrid: [],\n snapGrid: [],\n slidesSizesGrid: [],\n\n // isDirection\n isHorizontal: function isHorizontal() {\n return swiper.params.direction === 'horizontal';\n },\n isVertical: function isVertical() {\n return swiper.params.direction === 'vertical';\n },\n // RTL\n rtl: (el.dir.toLowerCase() === 'rtl' || $el.css('direction') === 'rtl'),\n rtlTranslate: swiper.params.direction === 'horizontal' && (el.dir.toLowerCase() === 'rtl' || $el.css('direction') === 'rtl'),\n wrongRTL: $wrapperEl.css('display') === '-webkit-box',\n\n // Indexes\n activeIndex: 0,\n realIndex: 0,\n\n //\n isBeginning: true,\n isEnd: false,\n\n // Props\n translate: 0,\n previousTranslate: 0,\n progress: 0,\n velocity: 0,\n animating: false,\n\n // Locks\n allowSlideNext: swiper.params.allowSlideNext,\n allowSlidePrev: swiper.params.allowSlidePrev,\n\n // Touch Events\n touchEvents: (function touchEvents() {\n var touch = ['touchstart', 'touchmove', 'touchend'];\n var desktop = ['mousedown', 'mousemove', 'mouseup'];\n if (Support.pointerEvents) {\n desktop = ['pointerdown', 'pointermove', 'pointerup'];\n } else if (Support.prefixedPointerEvents) {\n desktop = ['MSPointerDown', 'MSPointerMove', 'MSPointerUp'];\n }\n swiper.touchEventsTouch = {\n start: touch[0],\n move: touch[1],\n end: touch[2],\n };\n swiper.touchEventsDesktop = {\n start: desktop[0],\n move: desktop[1],\n end: desktop[2],\n };\n return Support.touch || !swiper.params.simulateTouch ? swiper.touchEventsTouch : swiper.touchEventsDesktop;\n }()),\n touchEventsData: {\n isTouched: undefined,\n isMoved: undefined,\n allowTouchCallbacks: undefined,\n touchStartTime: undefined,\n isScrolling: undefined,\n currentTranslate: undefined,\n startTranslate: undefined,\n allowThresholdMove: undefined,\n // Form elements to match\n formElements: 'input, select, option, textarea, button, video',\n // Last click time\n lastClickTime: Utils.now(),\n clickTimeout: undefined,\n // Velocities\n velocities: [],\n allowMomentumBounce: undefined,\n isTouchEvent: undefined,\n startMoving: undefined,\n },\n\n // Clicks\n allowClick: true,\n\n // Touches\n allowTouchMove: swiper.params.allowTouchMove,\n\n touches: {\n startX: 0,\n startY: 0,\n currentX: 0,\n currentY: 0,\n diff: 0,\n },\n\n // Images\n imagesToLoad: [],\n imagesLoaded: 0,\n\n });\n\n // Install Modules\n swiper.useModules();\n\n // Init\n if (swiper.params.init) {\n swiper.init();\n }\n\n // Return app instance\n return swiper;\n }\n\n if ( SwiperClass ) Swiper.__proto__ = SwiperClass;\n Swiper.prototype = Object.create( SwiperClass && SwiperClass.prototype );\n Swiper.prototype.constructor = Swiper;\n\n var staticAccessors = { extendedDefaults: { configurable: true },defaults: { configurable: true },Class: { configurable: true },$: { configurable: true } };\n\n Swiper.prototype.slidesPerViewDynamic = function slidesPerViewDynamic () {\n var swiper = this;\n var params = swiper.params;\n var slides = swiper.slides;\n var slidesGrid = swiper.slidesGrid;\n var swiperSize = swiper.size;\n var activeIndex = swiper.activeIndex;\n var spv = 1;\n if (params.centeredSlides) {\n var slideSize = slides[activeIndex].swiperSlideSize;\n var breakLoop;\n for (var i = activeIndex + 1; i < slides.length; i += 1) {\n if (slides[i] && !breakLoop) {\n slideSize += slides[i].swiperSlideSize;\n spv += 1;\n if (slideSize > swiperSize) { breakLoop = true; }\n }\n }\n for (var i$1 = activeIndex - 1; i$1 >= 0; i$1 -= 1) {\n if (slides[i$1] && !breakLoop) {\n slideSize += slides[i$1].swiperSlideSize;\n spv += 1;\n if (slideSize > swiperSize) { breakLoop = true; }\n }\n }\n } else {\n for (var i$2 = activeIndex + 1; i$2 < slides.length; i$2 += 1) {\n if (slidesGrid[i$2] - slidesGrid[activeIndex] < swiperSize) {\n spv += 1;\n }\n }\n }\n return spv;\n };\n\n Swiper.prototype.update = function update () {\n var swiper = this;\n if (!swiper || swiper.destroyed) { return; }\n var snapGrid = swiper.snapGrid;\n var params = swiper.params;\n // Breakpoints\n if (params.breakpoints) {\n swiper.setBreakpoint();\n }\n swiper.updateSize();\n swiper.updateSlides();\n swiper.updateProgress();\n swiper.updateSlidesClasses();\n\n function setTranslate() {\n var translateValue = swiper.rtlTranslate ? swiper.translate * -1 : swiper.translate;\n var newTranslate = Math.min(Math.max(translateValue, swiper.maxTranslate()), swiper.minTranslate());\n swiper.setTranslate(newTranslate);\n swiper.updateActiveIndex();\n swiper.updateSlidesClasses();\n }\n var translated;\n if (swiper.params.freeMode) {\n setTranslate();\n if (swiper.params.autoHeight) {\n swiper.updateAutoHeight();\n }\n } else {\n if ((swiper.params.slidesPerView === 'auto' || swiper.params.slidesPerView > 1) && swiper.isEnd && !swiper.params.centeredSlides) {\n translated = swiper.slideTo(swiper.slides.length - 1, 0, false, true);\n } else {\n translated = swiper.slideTo(swiper.activeIndex, 0, false, true);\n }\n if (!translated) {\n setTranslate();\n }\n }\n if (params.watchOverflow && snapGrid !== swiper.snapGrid) {\n swiper.checkOverflow();\n }\n swiper.emit('update');\n };\n\n Swiper.prototype.changeDirection = function changeDirection (newDirection, needUpdate) {\n if ( needUpdate === void 0 ) needUpdate = true;\n\n var swiper = this;\n var currentDirection = swiper.params.direction;\n if (!newDirection) {\n // eslint-disable-next-line\n newDirection = currentDirection === 'horizontal' ? 'vertical' : 'horizontal';\n }\n if ((newDirection === currentDirection) || (newDirection !== 'horizontal' && newDirection !== 'vertical')) {\n return swiper;\n }\n\n swiper.$el\n .removeClass((\"\" + (swiper.params.containerModifierClass) + currentDirection + \" wp8-\" + currentDirection))\n .addClass((\"\" + (swiper.params.containerModifierClass) + newDirection));\n\n if ((Browser.isIE || Browser.isEdge) && (Support.pointerEvents || Support.prefixedPointerEvents)) {\n swiper.$el.addClass(((swiper.params.containerModifierClass) + \"wp8-\" + newDirection));\n }\n\n swiper.params.direction = newDirection;\n\n swiper.slides.each(function (slideIndex, slideEl) {\n if (newDirection === 'vertical') {\n slideEl.style.width = '';\n } else {\n slideEl.style.height = '';\n }\n });\n\n swiper.emit('changeDirection');\n if (needUpdate) { swiper.update(); }\n\n return swiper;\n };\n\n Swiper.prototype.init = function init () {\n var swiper = this;\n if (swiper.initialized) { return; }\n\n swiper.emit('beforeInit');\n\n // Set breakpoint\n if (swiper.params.breakpoints) {\n swiper.setBreakpoint();\n }\n\n // Add Classes\n swiper.addClasses();\n\n // Create loop\n if (swiper.params.loop) {\n swiper.loopCreate();\n }\n\n // Update size\n swiper.updateSize();\n\n // Update slides\n swiper.updateSlides();\n\n if (swiper.params.watchOverflow) {\n swiper.checkOverflow();\n }\n\n // Set Grab Cursor\n if (swiper.params.grabCursor) {\n swiper.setGrabCursor();\n }\n\n if (swiper.params.preloadImages) {\n swiper.preloadImages();\n }\n\n // Slide To Initial Slide\n if (swiper.params.loop) {\n swiper.slideTo(swiper.params.initialSlide + swiper.loopedSlides, 0, swiper.params.runCallbacksOnInit);\n } else {\n swiper.slideTo(swiper.params.initialSlide, 0, swiper.params.runCallbacksOnInit);\n }\n\n // Attach events\n swiper.attachEvents();\n\n // Init Flag\n swiper.initialized = true;\n\n // Emit\n swiper.emit('init');\n };\n\n Swiper.prototype.destroy = function destroy (deleteInstance, cleanStyles) {\n if ( deleteInstance === void 0 ) deleteInstance = true;\n if ( cleanStyles === void 0 ) cleanStyles = true;\n\n var swiper = this;\n var params = swiper.params;\n var $el = swiper.$el;\n var $wrapperEl = swiper.$wrapperEl;\n var slides = swiper.slides;\n\n if (typeof swiper.params === 'undefined' || swiper.destroyed) {\n return null;\n }\n\n swiper.emit('beforeDestroy');\n\n // Init Flag\n swiper.initialized = false;\n\n // Detach events\n swiper.detachEvents();\n\n // Destroy loop\n if (params.loop) {\n swiper.loopDestroy();\n }\n\n // Cleanup styles\n if (cleanStyles) {\n swiper.removeClasses();\n $el.removeAttr('style');\n $wrapperEl.removeAttr('style');\n if (slides && slides.length) {\n slides\n .removeClass([\n params.slideVisibleClass,\n params.slideActiveClass,\n params.slideNextClass,\n params.slidePrevClass ].join(' '))\n .removeAttr('style')\n .removeAttr('data-swiper-slide-index')\n .removeAttr('data-swiper-column')\n .removeAttr('data-swiper-row');\n }\n }\n\n swiper.emit('destroy');\n\n // Detach emitter events\n Object.keys(swiper.eventsListeners).forEach(function (eventName) {\n swiper.off(eventName);\n });\n\n if (deleteInstance !== false) {\n swiper.$el[0].swiper = null;\n swiper.$el.data('swiper', null);\n Utils.deleteProps(swiper);\n }\n swiper.destroyed = true;\n\n return null;\n };\n\n Swiper.extendDefaults = function extendDefaults (newDefaults) {\n Utils.extend(extendedDefaults, newDefaults);\n };\n\n staticAccessors.extendedDefaults.get = function () {\n return extendedDefaults;\n };\n\n staticAccessors.defaults.get = function () {\n return defaults;\n };\n\n staticAccessors.Class.get = function () {\n return SwiperClass;\n };\n\n staticAccessors.$.get = function () {\n return $;\n };\n\n Object.defineProperties( Swiper, staticAccessors );\n\n return Swiper;\n }(SwiperClass));\n\n var Device$1 = {\n name: 'device',\n proto: {\n device: Device,\n },\n static: {\n device: Device,\n },\n };\n\n var Support$1 = {\n name: 'support',\n proto: {\n support: Support,\n },\n static: {\n support: Support,\n },\n };\n\n var Browser$1 = {\n name: 'browser',\n proto: {\n browser: Browser,\n },\n static: {\n browser: Browser,\n },\n };\n\n var Resize = {\n name: 'resize',\n create: function create() {\n var swiper = this;\n Utils.extend(swiper, {\n resize: {\n resizeHandler: function resizeHandler() {\n if (!swiper || swiper.destroyed || !swiper.initialized) { return; }\n swiper.emit('beforeResize');\n swiper.emit('resize');\n },\n orientationChangeHandler: function orientationChangeHandler() {\n if (!swiper || swiper.destroyed || !swiper.initialized) { return; }\n swiper.emit('orientationchange');\n },\n },\n });\n },\n on: {\n init: function init() {\n var swiper = this;\n // Emit resize\n win.addEventListener('resize', swiper.resize.resizeHandler);\n\n // Emit orientationchange\n win.addEventListener('orientationchange', swiper.resize.orientationChangeHandler);\n },\n destroy: function destroy() {\n var swiper = this;\n win.removeEventListener('resize', swiper.resize.resizeHandler);\n win.removeEventListener('orientationchange', swiper.resize.orientationChangeHandler);\n },\n },\n };\n\n var Observer = {\n func: win.MutationObserver || win.WebkitMutationObserver,\n attach: function attach(target, options) {\n if ( options === void 0 ) options = {};\n\n var swiper = this;\n\n var ObserverFunc = Observer.func;\n var observer = new ObserverFunc(function (mutations) {\n // The observerUpdate event should only be triggered\n // once despite the number of mutations. Additional\n // triggers are redundant and are very costly\n if (mutations.length === 1) {\n swiper.emit('observerUpdate', mutations[0]);\n return;\n }\n var observerUpdate = function observerUpdate() {\n swiper.emit('observerUpdate', mutations[0]);\n };\n\n if (win.requestAnimationFrame) {\n win.requestAnimationFrame(observerUpdate);\n } else {\n win.setTimeout(observerUpdate, 0);\n }\n });\n\n observer.observe(target, {\n attributes: typeof options.attributes === 'undefined' ? true : options.attributes,\n childList: typeof options.childList === 'undefined' ? true : options.childList,\n characterData: typeof options.characterData === 'undefined' ? true : options.characterData,\n });\n\n swiper.observer.observers.push(observer);\n },\n init: function init() {\n var swiper = this;\n if (!Support.observer || !swiper.params.observer) { return; }\n if (swiper.params.observeParents) {\n var containerParents = swiper.$el.parents();\n for (var i = 0; i < containerParents.length; i += 1) {\n swiper.observer.attach(containerParents[i]);\n }\n }\n // Observe container\n swiper.observer.attach(swiper.$el[0], { childList: swiper.params.observeSlideChildren });\n\n // Observe wrapper\n swiper.observer.attach(swiper.$wrapperEl[0], { attributes: false });\n },\n destroy: function destroy() {\n var swiper = this;\n swiper.observer.observers.forEach(function (observer) {\n observer.disconnect();\n });\n swiper.observer.observers = [];\n },\n };\n\n var Observer$1 = {\n name: 'observer',\n params: {\n observer: false,\n observeParents: false,\n observeSlideChildren: false,\n },\n create: function create() {\n var swiper = this;\n Utils.extend(swiper, {\n observer: {\n init: Observer.init.bind(swiper),\n attach: Observer.attach.bind(swiper),\n destroy: Observer.destroy.bind(swiper),\n observers: [],\n },\n });\n },\n on: {\n init: function init() {\n var swiper = this;\n swiper.observer.init();\n },\n destroy: function destroy() {\n var swiper = this;\n swiper.observer.destroy();\n },\n },\n };\n\n var Virtual = {\n update: function update(force) {\n var swiper = this;\n var ref = swiper.params;\n var slidesPerView = ref.slidesPerView;\n var slidesPerGroup = ref.slidesPerGroup;\n var centeredSlides = ref.centeredSlides;\n var ref$1 = swiper.params.virtual;\n var addSlidesBefore = ref$1.addSlidesBefore;\n var addSlidesAfter = ref$1.addSlidesAfter;\n var ref$2 = swiper.virtual;\n var previousFrom = ref$2.from;\n var previousTo = ref$2.to;\n var slides = ref$2.slides;\n var previousSlidesGrid = ref$2.slidesGrid;\n var renderSlide = ref$2.renderSlide;\n var previousOffset = ref$2.offset;\n swiper.updateActiveIndex();\n var activeIndex = swiper.activeIndex || 0;\n\n var offsetProp;\n if (swiper.rtlTranslate) { offsetProp = 'right'; }\n else { offsetProp = swiper.isHorizontal() ? 'left' : 'top'; }\n\n var slidesAfter;\n var slidesBefore;\n if (centeredSlides) {\n slidesAfter = Math.floor(slidesPerView / 2) + slidesPerGroup + addSlidesBefore;\n slidesBefore = Math.floor(slidesPerView / 2) + slidesPerGroup + addSlidesAfter;\n } else {\n slidesAfter = slidesPerView + (slidesPerGroup - 1) + addSlidesBefore;\n slidesBefore = slidesPerGroup + addSlidesAfter;\n }\n var from = Math.max((activeIndex || 0) - slidesBefore, 0);\n var to = Math.min((activeIndex || 0) + slidesAfter, slides.length - 1);\n var offset = (swiper.slidesGrid[from] || 0) - (swiper.slidesGrid[0] || 0);\n\n Utils.extend(swiper.virtual, {\n from: from,\n to: to,\n offset: offset,\n slidesGrid: swiper.slidesGrid,\n });\n\n function onRendered() {\n swiper.updateSlides();\n swiper.updateProgress();\n swiper.updateSlidesClasses();\n if (swiper.lazy && swiper.params.lazy.enabled) {\n swiper.lazy.load();\n }\n }\n\n if (previousFrom === from && previousTo === to && !force) {\n if (swiper.slidesGrid !== previousSlidesGrid && offset !== previousOffset) {\n swiper.slides.css(offsetProp, (offset + \"px\"));\n }\n swiper.updateProgress();\n return;\n }\n if (swiper.params.virtual.renderExternal) {\n swiper.params.virtual.renderExternal.call(swiper, {\n offset: offset,\n from: from,\n to: to,\n slides: (function getSlides() {\n var slidesToRender = [];\n for (var i = from; i <= to; i += 1) {\n slidesToRender.push(slides[i]);\n }\n return slidesToRender;\n }()),\n });\n onRendered();\n return;\n }\n var prependIndexes = [];\n var appendIndexes = [];\n if (force) {\n swiper.$wrapperEl.find((\".\" + (swiper.params.slideClass))).remove();\n } else {\n for (var i = previousFrom; i <= previousTo; i += 1) {\n if (i < from || i > to) {\n swiper.$wrapperEl.find((\".\" + (swiper.params.slideClass) + \"[data-swiper-slide-index=\\\"\" + i + \"\\\"]\")).remove();\n }\n }\n }\n for (var i$1 = 0; i$1 < slides.length; i$1 += 1) {\n if (i$1 >= from && i$1 <= to) {\n if (typeof previousTo === 'undefined' || force) {\n appendIndexes.push(i$1);\n } else {\n if (i$1 > previousTo) { appendIndexes.push(i$1); }\n if (i$1 < previousFrom) { prependIndexes.push(i$1); }\n }\n }\n }\n appendIndexes.forEach(function (index) {\n swiper.$wrapperEl.append(renderSlide(slides[index], index));\n });\n prependIndexes.sort(function (a, b) { return b - a; }).forEach(function (index) {\n swiper.$wrapperEl.prepend(renderSlide(slides[index], index));\n });\n swiper.$wrapperEl.children('.swiper-slide').css(offsetProp, (offset + \"px\"));\n onRendered();\n },\n renderSlide: function renderSlide(slide, index) {\n var swiper = this;\n var params = swiper.params.virtual;\n if (params.cache && swiper.virtual.cache[index]) {\n return swiper.virtual.cache[index];\n }\n var $slideEl = params.renderSlide\n ? $(params.renderSlide.call(swiper, slide, index))\n : $((\"<div class=\\\"\" + (swiper.params.slideClass) + \"\\\" data-swiper-slide-index=\\\"\" + index + \"\\\">\" + slide + \"</div>\"));\n if (!$slideEl.attr('data-swiper-slide-index')) { $slideEl.attr('data-swiper-slide-index', index); }\n if (params.cache) { swiper.virtual.cache[index] = $slideEl; }\n return $slideEl;\n },\n appendSlide: function appendSlide(slides) {\n var swiper = this;\n if (typeof slides === 'object' && 'length' in slides) {\n for (var i = 0; i < slides.length; i += 1) {\n if (slides[i]) { swiper.virtual.slides.push(slides[i]); }\n }\n } else {\n swiper.virtual.slides.push(slides);\n }\n swiper.virtual.update(true);\n },\n prependSlide: function prependSlide(slides) {\n var swiper = this;\n var activeIndex = swiper.activeIndex;\n var newActiveIndex = activeIndex + 1;\n var numberOfNewSlides = 1;\n\n if (Array.isArray(slides)) {\n for (var i = 0; i < slides.length; i += 1) {\n if (slides[i]) { swiper.virtual.slides.unshift(slides[i]); }\n }\n newActiveIndex = activeIndex + slides.length;\n numberOfNewSlides = slides.length;\n } else {\n swiper.virtual.slides.unshift(slides);\n }\n if (swiper.params.virtual.cache) {\n var cache = swiper.virtual.cache;\n var newCache = {};\n Object.keys(cache).forEach(function (cachedIndex) {\n newCache[parseInt(cachedIndex, 10) + numberOfNewSlides] = cache[cachedIndex];\n });\n swiper.virtual.cache = newCache;\n }\n swiper.virtual.update(true);\n swiper.slideTo(newActiveIndex, 0);\n },\n removeSlide: function removeSlide(slidesIndexes) {\n var swiper = this;\n if (typeof slidesIndexes === 'undefined' || slidesIndexes === null) { return; }\n var activeIndex = swiper.activeIndex;\n if (Array.isArray(slidesIndexes)) {\n for (var i = slidesIndexes.length - 1; i >= 0; i -= 1) {\n swiper.virtual.slides.splice(slidesIndexes[i], 1);\n if (swiper.params.virtual.cache) {\n delete swiper.virtual.cache[slidesIndexes[i]];\n }\n if (slidesIndexes[i] < activeIndex) { activeIndex -= 1; }\n activeIndex = Math.max(activeIndex, 0);\n }\n } else {\n swiper.virtual.slides.splice(slidesIndexes, 1);\n if (swiper.params.virtual.cache) {\n delete swiper.virtual.cache[slidesIndexes];\n }\n if (slidesIndexes < activeIndex) { activeIndex -= 1; }\n activeIndex = Math.max(activeIndex, 0);\n }\n swiper.virtual.update(true);\n swiper.slideTo(activeIndex, 0);\n },\n removeAllSlides: function removeAllSlides() {\n var swiper = this;\n swiper.virtual.slides = [];\n if (swiper.params.virtual.cache) {\n swiper.virtual.cache = {};\n }\n swiper.virtual.update(true);\n swiper.slideTo(0, 0);\n },\n };\n\n var Virtual$1 = {\n name: 'virtual',\n params: {\n virtual: {\n enabled: false,\n slides: [],\n cache: true,\n renderSlide: null,\n renderExternal: null,\n addSlidesBefore: 0,\n addSlidesAfter: 0,\n },\n },\n create: function create() {\n var swiper = this;\n Utils.extend(swiper, {\n virtual: {\n update: Virtual.update.bind(swiper),\n appendSlide: Virtual.appendSlide.bind(swiper),\n prependSlide: Virtual.prependSlide.bind(swiper),\n removeSlide: Virtual.removeSlide.bind(swiper),\n removeAllSlides: Virtual.removeAllSlides.bind(swiper),\n renderSlide: Virtual.renderSlide.bind(swiper),\n slides: swiper.params.virtual.slides,\n cache: {},\n },\n });\n },\n on: {\n beforeInit: function beforeInit() {\n var swiper = this;\n if (!swiper.params.virtual.enabled) { return; }\n swiper.classNames.push(((swiper.params.containerModifierClass) + \"virtual\"));\n var overwriteParams = {\n watchSlidesProgress: true,\n };\n Utils.extend(swiper.params, overwriteParams);\n Utils.extend(swiper.originalParams, overwriteParams);\n\n if (!swiper.params.initialSlide) {\n swiper.virtual.update();\n }\n },\n setTranslate: function setTranslate() {\n var swiper = this;\n if (!swiper.params.virtual.enabled) { return; }\n swiper.virtual.update();\n },\n },\n };\n\n var Keyboard = {\n handle: function handle(event) {\n var swiper = this;\n var rtl = swiper.rtlTranslate;\n var e = event;\n if (e.originalEvent) { e = e.originalEvent; } // jquery fix\n var kc = e.keyCode || e.charCode;\n // Directions locks\n if (!swiper.allowSlideNext && ((swiper.isHorizontal() && kc === 39) || (swiper.isVertical() && kc === 40) || kc === 34)) {\n return false;\n }\n if (!swiper.allowSlidePrev && ((swiper.isHorizontal() && kc === 37) || (swiper.isVertical() && kc === 38) || kc === 33)) {\n return false;\n }\n if (e.shiftKey || e.altKey || e.ctrlKey || e.metaKey) {\n return undefined;\n }\n if (doc.activeElement && doc.activeElement.nodeName && (doc.activeElement.nodeName.toLowerCase() === 'input' || doc.activeElement.nodeName.toLowerCase() === 'textarea')) {\n return undefined;\n }\n if (swiper.params.keyboard.onlyInViewport && (kc === 33 || kc === 34 || kc === 37 || kc === 39 || kc === 38 || kc === 40)) {\n var inView = false;\n // Check that swiper should be inside of visible area of window\n if (swiper.$el.parents((\".\" + (swiper.params.slideClass))).length > 0 && swiper.$el.parents((\".\" + (swiper.params.slideActiveClass))).length === 0) {\n return undefined;\n }\n var windowWidth = win.innerWidth;\n var windowHeight = win.innerHeight;\n var swiperOffset = swiper.$el.offset();\n if (rtl) { swiperOffset.left -= swiper.$el[0].scrollLeft; }\n var swiperCoord = [\n [swiperOffset.left, swiperOffset.top],\n [swiperOffset.left + swiper.width, swiperOffset.top],\n [swiperOffset.left, swiperOffset.top + swiper.height],\n [swiperOffset.left + swiper.width, swiperOffset.top + swiper.height] ];\n for (var i = 0; i < swiperCoord.length; i += 1) {\n var point = swiperCoord[i];\n if (\n point[0] >= 0 && point[0] <= windowWidth\n && point[1] >= 0 && point[1] <= windowHeight\n ) {\n inView = true;\n }\n }\n if (!inView) { return undefined; }\n }\n if (swiper.isHorizontal()) {\n if (kc === 33 || kc === 34 || kc === 37 || kc === 39) {\n if (e.preventDefault) { e.preventDefault(); }\n else { e.returnValue = false; }\n }\n if (((kc === 34 || kc === 39) && !rtl) || ((kc === 33 || kc === 37) && rtl)) { swiper.slideNext(); }\n if (((kc === 33 || kc === 37) && !rtl) || ((kc === 34 || kc === 39) && rtl)) { swiper.slidePrev(); }\n } else {\n if (kc === 33 || kc === 34 || kc === 38 || kc === 40) {\n if (e.preventDefault) { e.preventDefault(); }\n else { e.returnValue = false; }\n }\n if (kc === 34 || kc === 40) { swiper.slideNext(); }\n if (kc === 33 || kc === 38) { swiper.slidePrev(); }\n }\n swiper.emit('keyPress', kc);\n return undefined;\n },\n enable: function enable() {\n var swiper = this;\n if (swiper.keyboard.enabled) { return; }\n $(doc).on('keydown', swiper.keyboard.handle);\n swiper.keyboard.enabled = true;\n },\n disable: function disable() {\n var swiper = this;\n if (!swiper.keyboard.enabled) { return; }\n $(doc).off('keydown', swiper.keyboard.handle);\n swiper.keyboard.enabled = false;\n },\n };\n\n var Keyboard$1 = {\n name: 'keyboard',\n params: {\n keyboard: {\n enabled: false,\n onlyInViewport: true,\n },\n },\n create: function create() {\n var swiper = this;\n Utils.extend(swiper, {\n keyboard: {\n enabled: false,\n enable: Keyboard.enable.bind(swiper),\n disable: Keyboard.disable.bind(swiper),\n handle: Keyboard.handle.bind(swiper),\n },\n });\n },\n on: {\n init: function init() {\n var swiper = this;\n if (swiper.params.keyboard.enabled) {\n swiper.keyboard.enable();\n }\n },\n destroy: function destroy() {\n var swiper = this;\n if (swiper.keyboard.enabled) {\n swiper.keyboard.disable();\n }\n },\n },\n };\n\n function isEventSupported() {\n var eventName = 'onwheel';\n var isSupported = eventName in doc;\n\n if (!isSupported) {\n var element = doc.createElement('div');\n element.setAttribute(eventName, 'return;');\n isSupported = typeof element[eventName] === 'function';\n }\n\n if (!isSupported\n && doc.implementation\n && doc.implementation.hasFeature\n // always returns true in newer browsers as per the standard.\n // @see http://dom.spec.whatwg.org/#dom-domimplementation-hasfeature\n && doc.implementation.hasFeature('', '') !== true\n ) {\n // This is the only way to test support for the `wheel` event in IE9+.\n isSupported = doc.implementation.hasFeature('Events.wheel', '3.0');\n }\n\n return isSupported;\n }\n var Mousewheel = {\n lastScrollTime: Utils.now(),\n event: (function getEvent() {\n if (win.navigator.userAgent.indexOf('firefox') > -1) { return 'DOMMouseScroll'; }\n return isEventSupported() ? 'wheel' : 'mousewheel';\n }()),\n normalize: function normalize(e) {\n // Reasonable defaults\n var PIXEL_STEP = 10;\n var LINE_HEIGHT = 40;\n var PAGE_HEIGHT = 800;\n\n var sX = 0;\n var sY = 0; // spinX, spinY\n var pX = 0;\n var pY = 0; // pixelX, pixelY\n\n // Legacy\n if ('detail' in e) {\n sY = e.detail;\n }\n if ('wheelDelta' in e) {\n sY = -e.wheelDelta / 120;\n }\n if ('wheelDeltaY' in e) {\n sY = -e.wheelDeltaY / 120;\n }\n if ('wheelDeltaX' in e) {\n sX = -e.wheelDeltaX / 120;\n }\n\n // side scrolling on FF with DOMMouseScroll\n if ('axis' in e && e.axis === e.HORIZONTAL_AXIS) {\n sX = sY;\n sY = 0;\n }\n\n pX = sX * PIXEL_STEP;\n pY = sY * PIXEL_STEP;\n\n if ('deltaY' in e) {\n pY = e.deltaY;\n }\n if ('deltaX' in e) {\n pX = e.deltaX;\n }\n\n if ((pX || pY) && e.deltaMode) {\n if (e.deltaMode === 1) { // delta in LINE units\n pX *= LINE_HEIGHT;\n pY *= LINE_HEIGHT;\n } else { // delta in PAGE units\n pX *= PAGE_HEIGHT;\n pY *= PAGE_HEIGHT;\n }\n }\n\n // Fall-back if spin cannot be determined\n if (pX && !sX) {\n sX = (pX < 1) ? -1 : 1;\n }\n if (pY && !sY) {\n sY = (pY < 1) ? -1 : 1;\n }\n\n return {\n spinX: sX,\n spinY: sY,\n pixelX: pX,\n pixelY: pY,\n };\n },\n handleMouseEnter: function handleMouseEnter() {\n var swiper = this;\n swiper.mouseEntered = true;\n },\n handleMouseLeave: function handleMouseLeave() {\n var swiper = this;\n swiper.mouseEntered = false;\n },\n handle: function handle(event) {\n var e = event;\n var swiper = this;\n var params = swiper.params.mousewheel;\n\n if (!swiper.mouseEntered && !params.releaseOnEdges) { return true; }\n\n if (e.originalEvent) { e = e.originalEvent; } // jquery fix\n var delta = 0;\n var rtlFactor = swiper.rtlTranslate ? -1 : 1;\n\n var data = Mousewheel.normalize(e);\n\n if (params.forceToAxis) {\n if (swiper.isHorizontal()) {\n if (Math.abs(data.pixelX) > Math.abs(data.pixelY)) { delta = data.pixelX * rtlFactor; }\n else { return true; }\n } else if (Math.abs(data.pixelY) > Math.abs(data.pixelX)) { delta = data.pixelY; }\n else { return true; }\n } else {\n delta = Math.abs(data.pixelX) > Math.abs(data.pixelY) ? -data.pixelX * rtlFactor : -data.pixelY;\n }\n\n if (delta === 0) { return true; }\n\n if (params.invert) { delta = -delta; }\n\n if (!swiper.params.freeMode) {\n if (Utils.now() - swiper.mousewheel.lastScrollTime > 60) {\n if (delta < 0) {\n if ((!swiper.isEnd || swiper.params.loop) && !swiper.animating) {\n swiper.slideNext();\n swiper.emit('scroll', e);\n } else if (params.releaseOnEdges) { return true; }\n } else if ((!swiper.isBeginning || swiper.params.loop) && !swiper.animating) {\n swiper.slidePrev();\n swiper.emit('scroll', e);\n } else if (params.releaseOnEdges) { return true; }\n }\n swiper.mousewheel.lastScrollTime = (new win.Date()).getTime();\n } else {\n // Freemode or scrollContainer:\n if (swiper.params.loop) {\n swiper.loopFix();\n }\n var position = swiper.getTranslate() + (delta * params.sensitivity);\n var wasBeginning = swiper.isBeginning;\n var wasEnd = swiper.isEnd;\n\n if (position >= swiper.minTranslate()) { position = swiper.minTranslate(); }\n if (position <= swiper.maxTranslate()) { position = swiper.maxTranslate(); }\n\n swiper.setTransition(0);\n swiper.setTranslate(position);\n swiper.updateProgress();\n swiper.updateActiveIndex();\n swiper.updateSlidesClasses();\n\n if ((!wasBeginning && swiper.isBeginning) || (!wasEnd && swiper.isEnd)) {\n swiper.updateSlidesClasses();\n }\n\n if (swiper.params.freeModeSticky) {\n clearTimeout(swiper.mousewheel.timeout);\n swiper.mousewheel.timeout = Utils.nextTick(function () {\n swiper.slideToClosest();\n }, 300);\n }\n // Emit event\n swiper.emit('scroll', e);\n\n // Stop autoplay\n if (swiper.params.autoplay && swiper.params.autoplayDisableOnInteraction) { swiper.autoplay.stop(); }\n // Return page scroll on edge positions\n if (position === swiper.minTranslate() || position === swiper.maxTranslate()) { return true; }\n }\n\n if (e.preventDefault) { e.preventDefault(); }\n else { e.returnValue = false; }\n return false;\n },\n enable: function enable() {\n var swiper = this;\n if (!Mousewheel.event) { return false; }\n if (swiper.mousewheel.enabled) { return false; }\n var target = swiper.$el;\n if (swiper.params.mousewheel.eventsTarged !== 'container') {\n target = $(swiper.params.mousewheel.eventsTarged);\n }\n target.on('mouseenter', swiper.mousewheel.handleMouseEnter);\n target.on('mouseleave', swiper.mousewheel.handleMouseLeave);\n target.on(Mousewheel.event, swiper.mousewheel.handle);\n swiper.mousewheel.enabled = true;\n return true;\n },\n disable: function disable() {\n var swiper = this;\n if (!Mousewheel.event) { return false; }\n if (!swiper.mousewheel.enabled) { return false; }\n var target = swiper.$el;\n if (swiper.params.mousewheel.eventsTarged !== 'container') {\n target = $(swiper.params.mousewheel.eventsTarged);\n }\n target.off(Mousewheel.event, swiper.mousewheel.handle);\n swiper.mousewheel.enabled = false;\n return true;\n },\n };\n\n var Mousewheel$1 = {\n name: 'mousewheel',\n params: {\n mousewheel: {\n enabled: false,\n releaseOnEdges: false,\n invert: false,\n forceToAxis: false,\n sensitivity: 1,\n eventsTarged: 'container',\n },\n },\n create: function create() {\n var swiper = this;\n Utils.extend(swiper, {\n mousewheel: {\n enabled: false,\n enable: Mousewheel.enable.bind(swiper),\n disable: Mousewheel.disable.bind(swiper),\n handle: Mousewheel.handle.bind(swiper),\n handleMouseEnter: Mousewheel.handleMouseEnter.bind(swiper),\n handleMouseLeave: Mousewheel.handleMouseLeave.bind(swiper),\n lastScrollTime: Utils.now(),\n },\n });\n },\n on: {\n init: function init() {\n var swiper = this;\n if (swiper.params.mousewheel.enabled) { swiper.mousewheel.enable(); }\n },\n destroy: function destroy() {\n var swiper = this;\n if (swiper.mousewheel.enabled) { swiper.mousewheel.disable(); }\n },\n },\n };\n\n var Navigation = {\n update: function update() {\n // Update Navigation Buttons\n var swiper = this;\n var params = swiper.params.navigation;\n\n if (swiper.params.loop) { return; }\n var ref = swiper.navigation;\n var $nextEl = ref.$nextEl;\n var $prevEl = ref.$prevEl;\n\n if ($prevEl && $prevEl.length > 0) {\n if (swiper.isBeginning) {\n $prevEl.addClass(params.disabledClass);\n } else {\n $prevEl.removeClass(params.disabledClass);\n }\n $prevEl[swiper.params.watchOverflow && swiper.isLocked ? 'addClass' : 'removeClass'](params.lockClass);\n }\n if ($nextEl && $nextEl.length > 0) {\n if (swiper.isEnd) {\n $nextEl.addClass(params.disabledClass);\n } else {\n $nextEl.removeClass(params.disabledClass);\n }\n $nextEl[swiper.params.watchOverflow && swiper.isLocked ? 'addClass' : 'removeClass'](params.lockClass);\n }\n },\n onPrevClick: function onPrevClick(e) {\n var swiper = this;\n e.preventDefault();\n if (swiper.isBeginning && !swiper.params.loop) { return; }\n swiper.slidePrev();\n },\n onNextClick: function onNextClick(e) {\n var swiper = this;\n e.preventDefault();\n if (swiper.isEnd && !swiper.params.loop) { return; }\n swiper.slideNext();\n },\n init: function init() {\n var swiper = this;\n var params = swiper.params.navigation;\n if (!(params.nextEl || params.prevEl)) { return; }\n\n var $nextEl;\n var $prevEl;\n if (params.nextEl) {\n $nextEl = $(params.nextEl);\n if (\n swiper.params.uniqueNavElements\n && typeof params.nextEl === 'string'\n && $nextEl.length > 1\n && swiper.$el.find(params.nextEl).length === 1\n ) {\n $nextEl = swiper.$el.find(params.nextEl);\n }\n }\n if (params.prevEl) {\n $prevEl = $(params.prevEl);\n if (\n swiper.params.uniqueNavElements\n && typeof params.prevEl === 'string'\n && $prevEl.length > 1\n && swiper.$el.find(params.prevEl).length === 1\n ) {\n $prevEl = swiper.$el.find(params.prevEl);\n }\n }\n\n if ($nextEl && $nextEl.length > 0) {\n $nextEl.on('click', swiper.navigation.onNextClick);\n }\n if ($prevEl && $prevEl.length > 0) {\n $prevEl.on('click', swiper.navigation.onPrevClick);\n }\n\n Utils.extend(swiper.navigation, {\n $nextEl: $nextEl,\n nextEl: $nextEl && $nextEl[0],\n $prevEl: $prevEl,\n prevEl: $prevEl && $prevEl[0],\n });\n },\n destroy: function destroy() {\n var swiper = this;\n var ref = swiper.navigation;\n var $nextEl = ref.$nextEl;\n var $prevEl = ref.$prevEl;\n if ($nextEl && $nextEl.length) {\n $nextEl.off('click', swiper.navigation.onNextClick);\n $nextEl.removeClass(swiper.params.navigation.disabledClass);\n }\n if ($prevEl && $prevEl.length) {\n $prevEl.off('click', swiper.navigation.onPrevClick);\n $prevEl.removeClass(swiper.params.navigation.disabledClass);\n }\n },\n };\n\n var Navigation$1 = {\n name: 'navigation',\n params: {\n navigation: {\n nextEl: null,\n prevEl: null,\n\n hideOnClick: false,\n disabledClass: 'swiper-button-disabled',\n hiddenClass: 'swiper-button-hidden',\n lockClass: 'swiper-button-lock',\n },\n },\n create: function create() {\n var swiper = this;\n Utils.extend(swiper, {\n navigation: {\n init: Navigation.init.bind(swiper),\n update: Navigation.update.bind(swiper),\n destroy: Navigation.destroy.bind(swiper),\n onNextClick: Navigation.onNextClick.bind(swiper),\n onPrevClick: Navigation.onPrevClick.bind(swiper),\n },\n });\n },\n on: {\n init: function init() {\n var swiper = this;\n swiper.navigation.init();\n swiper.navigation.update();\n },\n toEdge: function toEdge() {\n var swiper = this;\n swiper.navigation.update();\n },\n fromEdge: function fromEdge() {\n var swiper = this;\n swiper.navigation.update();\n },\n destroy: function destroy() {\n var swiper = this;\n swiper.navigation.destroy();\n },\n click: function click(e) {\n var swiper = this;\n var ref = swiper.navigation;\n var $nextEl = ref.$nextEl;\n var $prevEl = ref.$prevEl;\n if (\n swiper.params.navigation.hideOnClick\n && !$(e.target).is($prevEl)\n && !$(e.target).is($nextEl)\n ) {\n var isHidden;\n if ($nextEl) {\n isHidden = $nextEl.hasClass(swiper.params.navigation.hiddenClass);\n } else if ($prevEl) {\n isHidden = $prevEl.hasClass(swiper.params.navigation.hiddenClass);\n }\n if (isHidden === true) {\n swiper.emit('navigationShow', swiper);\n } else {\n swiper.emit('navigationHide', swiper);\n }\n if ($nextEl) {\n $nextEl.toggleClass(swiper.params.navigation.hiddenClass);\n }\n if ($prevEl) {\n $prevEl.toggleClass(swiper.params.navigation.hiddenClass);\n }\n }\n },\n },\n };\n\n var Pagination = {\n update: function update() {\n // Render || Update Pagination bullets/items\n var swiper = this;\n var rtl = swiper.rtl;\n var params = swiper.params.pagination;\n if (!params.el || !swiper.pagination.el || !swiper.pagination.$el || swiper.pagination.$el.length === 0) { return; }\n var slidesLength = swiper.virtual && swiper.params.virtual.enabled ? swiper.virtual.slides.length : swiper.slides.length;\n var $el = swiper.pagination.$el;\n // Current/Total\n var current;\n var total = swiper.params.loop ? Math.ceil((slidesLength - (swiper.loopedSlides * 2)) / swiper.params.slidesPerGroup) : swiper.snapGrid.length;\n if (swiper.params.loop) {\n current = Math.ceil((swiper.activeIndex - swiper.loopedSlides) / swiper.params.slidesPerGroup);\n if (current > slidesLength - 1 - (swiper.loopedSlides * 2)) {\n current -= (slidesLength - (swiper.loopedSlides * 2));\n }\n if (current > total - 1) { current -= total; }\n if (current < 0 && swiper.params.paginationType !== 'bullets') { current = total + current; }\n } else if (typeof swiper.snapIndex !== 'undefined') {\n current = swiper.snapIndex;\n } else {\n current = swiper.activeIndex || 0;\n }\n // Types\n if (params.type === 'bullets' && swiper.pagination.bullets && swiper.pagination.bullets.length > 0) {\n var bullets = swiper.pagination.bullets;\n var firstIndex;\n var lastIndex;\n var midIndex;\n if (params.dynamicBullets) {\n swiper.pagination.bulletSize = bullets.eq(0)[swiper.isHorizontal() ? 'outerWidth' : 'outerHeight'](true);\n $el.css(swiper.isHorizontal() ? 'width' : 'height', ((swiper.pagination.bulletSize * (params.dynamicMainBullets + 4)) + \"px\"));\n if (params.dynamicMainBullets > 1 && swiper.previousIndex !== undefined) {\n swiper.pagination.dynamicBulletIndex += (current - swiper.previousIndex);\n if (swiper.pagination.dynamicBulletIndex > (params.dynamicMainBullets - 1)) {\n swiper.pagination.dynamicBulletIndex = params.dynamicMainBullets - 1;\n } else if (swiper.pagination.dynamicBulletIndex < 0) {\n swiper.pagination.dynamicBulletIndex = 0;\n }\n }\n firstIndex = current - swiper.pagination.dynamicBulletIndex;\n lastIndex = firstIndex + (Math.min(bullets.length, params.dynamicMainBullets) - 1);\n midIndex = (lastIndex + firstIndex) / 2;\n }\n bullets.removeClass(((params.bulletActiveClass) + \" \" + (params.bulletActiveClass) + \"-next \" + (params.bulletActiveClass) + \"-next-next \" + (params.bulletActiveClass) + \"-prev \" + (params.bulletActiveClass) + \"-prev-prev \" + (params.bulletActiveClass) + \"-main\"));\n if ($el.length > 1) {\n bullets.each(function (index, bullet) {\n var $bullet = $(bullet);\n var bulletIndex = $bullet.index();\n if (bulletIndex === current) {\n $bullet.addClass(params.bulletActiveClass);\n }\n if (params.dynamicBullets) {\n if (bulletIndex >= firstIndex && bulletIndex <= lastIndex) {\n $bullet.addClass(((params.bulletActiveClass) + \"-main\"));\n }\n if (bulletIndex === firstIndex) {\n $bullet\n .prev()\n .addClass(((params.bulletActiveClass) + \"-prev\"))\n .prev()\n .addClass(((params.bulletActiveClass) + \"-prev-prev\"));\n }\n if (bulletIndex === lastIndex) {\n $bullet\n .next()\n .addClass(((params.bulletActiveClass) + \"-next\"))\n .next()\n .addClass(((params.bulletActiveClass) + \"-next-next\"));\n }\n }\n });\n } else {\n var $bullet = bullets.eq(current);\n $bullet.addClass(params.bulletActiveClass);\n if (params.dynamicBullets) {\n var $firstDisplayedBullet = bullets.eq(firstIndex);\n var $lastDisplayedBullet = bullets.eq(lastIndex);\n for (var i = firstIndex; i <= lastIndex; i += 1) {\n bullets.eq(i).addClass(((params.bulletActiveClass) + \"-main\"));\n }\n $firstDisplayedBullet\n .prev()\n .addClass(((params.bulletActiveClass) + \"-prev\"))\n .prev()\n .addClass(((params.bulletActiveClass) + \"-prev-prev\"));\n $lastDisplayedBullet\n .next()\n .addClass(((params.bulletActiveClass) + \"-next\"))\n .next()\n .addClass(((params.bulletActiveClass) + \"-next-next\"));\n }\n }\n if (params.dynamicBullets) {\n var dynamicBulletsLength = Math.min(bullets.length, params.dynamicMainBullets + 4);\n var bulletsOffset = (((swiper.pagination.bulletSize * dynamicBulletsLength) - (swiper.pagination.bulletSize)) / 2) - (midIndex * swiper.pagination.bulletSize);\n var offsetProp = rtl ? 'right' : 'left';\n bullets.css(swiper.isHorizontal() ? offsetProp : 'top', (bulletsOffset + \"px\"));\n }\n }\n if (params.type === 'fraction') {\n $el.find((\".\" + (params.currentClass))).text(params.formatFractionCurrent(current + 1));\n $el.find((\".\" + (params.totalClass))).text(params.formatFractionTotal(total));\n }\n if (params.type === 'progressbar') {\n var progressbarDirection;\n if (params.progressbarOpposite) {\n progressbarDirection = swiper.isHorizontal() ? 'vertical' : 'horizontal';\n } else {\n progressbarDirection = swiper.isHorizontal() ? 'horizontal' : 'vertical';\n }\n var scale = (current + 1) / total;\n var scaleX = 1;\n var scaleY = 1;\n if (progressbarDirection === 'horizontal') {\n scaleX = scale;\n } else {\n scaleY = scale;\n }\n $el.find((\".\" + (params.progressbarFillClass))).transform((\"translate3d(0,0,0) scaleX(\" + scaleX + \") scaleY(\" + scaleY + \")\")).transition(swiper.params.speed);\n }\n if (params.type === 'custom' && params.renderCustom) {\n $el.html(params.renderCustom(swiper, current + 1, total));\n swiper.emit('paginationRender', swiper, $el[0]);\n } else {\n swiper.emit('paginationUpdate', swiper, $el[0]);\n }\n $el[swiper.params.watchOverflow && swiper.isLocked ? 'addClass' : 'removeClass'](params.lockClass);\n },\n render: function render() {\n // Render Container\n var swiper = this;\n var params = swiper.params.pagination;\n if (!params.el || !swiper.pagination.el || !swiper.pagination.$el || swiper.pagination.$el.length === 0) { return; }\n var slidesLength = swiper.virtual && swiper.params.virtual.enabled ? swiper.virtual.slides.length : swiper.slides.length;\n\n var $el = swiper.pagination.$el;\n var paginationHTML = '';\n if (params.type === 'bullets') {\n var numberOfBullets = swiper.params.loop ? Math.ceil((slidesLength - (swiper.loopedSlides * 2)) / swiper.params.slidesPerGroup) : swiper.snapGrid.length;\n for (var i = 0; i < numberOfBullets; i += 1) {\n if (params.renderBullet) {\n paginationHTML += params.renderBullet.call(swiper, i, params.bulletClass);\n } else {\n paginationHTML += \"<\" + (params.bulletElement) + \" class=\\\"\" + (params.bulletClass) + \"\\\"></\" + (params.bulletElement) + \">\";\n }\n }\n $el.html(paginationHTML);\n swiper.pagination.bullets = $el.find((\".\" + (params.bulletClass)));\n }\n if (params.type === 'fraction') {\n if (params.renderFraction) {\n paginationHTML = params.renderFraction.call(swiper, params.currentClass, params.totalClass);\n } else {\n paginationHTML = \"<span class=\\\"\" + (params.currentClass) + \"\\\"></span>\"\n + ' / '\n + \"<span class=\\\"\" + (params.totalClass) + \"\\\"></span>\";\n }\n $el.html(paginationHTML);\n }\n if (params.type === 'progressbar') {\n if (params.renderProgressbar) {\n paginationHTML = params.renderProgressbar.call(swiper, params.progressbarFillClass);\n } else {\n paginationHTML = \"<span class=\\\"\" + (params.progressbarFillClass) + \"\\\"></span>\";\n }\n $el.html(paginationHTML);\n }\n if (params.type !== 'custom') {\n swiper.emit('paginationRender', swiper.pagination.$el[0]);\n }\n },\n init: function init() {\n var swiper = this;\n var params = swiper.params.pagination;\n if (!params.el) { return; }\n\n var $el = $(params.el);\n if ($el.length === 0) { return; }\n\n if (\n swiper.params.uniqueNavElements\n && typeof params.el === 'string'\n && $el.length > 1\n && swiper.$el.find(params.el).length === 1\n ) {\n $el = swiper.$el.find(params.el);\n }\n\n if (params.type === 'bullets' && params.clickable) {\n $el.addClass(params.clickableClass);\n }\n\n $el.addClass(params.modifierClass + params.type);\n\n if (params.type === 'bullets' && params.dynamicBullets) {\n $el.addClass((\"\" + (params.modifierClass) + (params.type) + \"-dynamic\"));\n swiper.pagination.dynamicBulletIndex = 0;\n if (params.dynamicMainBullets < 1) {\n params.dynamicMainBullets = 1;\n }\n }\n if (params.type === 'progressbar' && params.progressbarOpposite) {\n $el.addClass(params.progressbarOppositeClass);\n }\n\n if (params.clickable) {\n $el.on('click', (\".\" + (params.bulletClass)), function onClick(e) {\n e.preventDefault();\n var index = $(this).index() * swiper.params.slidesPerGroup;\n if (swiper.params.loop) { index += swiper.loopedSlides; }\n swiper.slideTo(index);\n });\n }\n\n Utils.extend(swiper.pagination, {\n $el: $el,\n el: $el[0],\n });\n },\n destroy: function destroy() {\n var swiper = this;\n var params = swiper.params.pagination;\n if (!params.el || !swiper.pagination.el || !swiper.pagination.$el || swiper.pagination.$el.length === 0) { return; }\n var $el = swiper.pagination.$el;\n\n $el.removeClass(params.hiddenClass);\n $el.removeClass(params.modifierClass + params.type);\n if (swiper.pagination.bullets) { swiper.pagination.bullets.removeClass(params.bulletActiveClass); }\n if (params.clickable) {\n $el.off('click', (\".\" + (params.bulletClass)));\n }\n },\n };\n\n var Pagination$1 = {\n name: 'pagination',\n params: {\n pagination: {\n el: null,\n bulletElement: 'span',\n clickable: false,\n hideOnClick: false,\n renderBullet: null,\n renderProgressbar: null,\n renderFraction: null,\n renderCustom: null,\n progressbarOpposite: false,\n type: 'bullets', // 'bullets' or 'progressbar' or 'fraction' or 'custom'\n dynamicBullets: false,\n dynamicMainBullets: 1,\n formatFractionCurrent: function (number) { return number; },\n formatFractionTotal: function (number) { return number; },\n bulletClass: 'swiper-pagination-bullet',\n bulletActiveClass: 'swiper-pagination-bullet-active',\n modifierClass: 'swiper-pagination-', // NEW\n currentClass: 'swiper-pagination-current',\n totalClass: 'swiper-pagination-total',\n hiddenClass: 'swiper-pagination-hidden',\n progressbarFillClass: 'swiper-pagination-progressbar-fill',\n progressbarOppositeClass: 'swiper-pagination-progressbar-opposite',\n clickableClass: 'swiper-pagination-clickable', // NEW\n lockClass: 'swiper-pagination-lock',\n },\n },\n create: function create() {\n var swiper = this;\n Utils.extend(swiper, {\n pagination: {\n init: Pagination.init.bind(swiper),\n render: Pagination.render.bind(swiper),\n update: Pagination.update.bind(swiper),\n destroy: Pagination.destroy.bind(swiper),\n dynamicBulletIndex: 0,\n },\n });\n },\n on: {\n init: function init() {\n var swiper = this;\n swiper.pagination.init();\n swiper.pagination.render();\n swiper.pagination.update();\n },\n activeIndexChange: function activeIndexChange() {\n var swiper = this;\n if (swiper.params.loop) {\n swiper.pagination.update();\n } else if (typeof swiper.snapIndex === 'undefined') {\n swiper.pagination.update();\n }\n },\n snapIndexChange: function snapIndexChange() {\n var swiper = this;\n if (!swiper.params.loop) {\n swiper.pagination.update();\n }\n },\n slidesLengthChange: function slidesLengthChange() {\n var swiper = this;\n if (swiper.params.loop) {\n swiper.pagination.render();\n swiper.pagination.update();\n }\n },\n snapGridLengthChange: function snapGridLengthChange() {\n var swiper = this;\n if (!swiper.params.loop) {\n swiper.pagination.render();\n swiper.pagination.update();\n }\n },\n destroy: function destroy() {\n var swiper = this;\n swiper.pagination.destroy();\n },\n click: function click(e) {\n var swiper = this;\n if (\n swiper.params.pagination.el\n && swiper.params.pagination.hideOnClick\n && swiper.pagination.$el.length > 0\n && !$(e.target).hasClass(swiper.params.pagination.bulletClass)\n ) {\n var isHidden = swiper.pagination.$el.hasClass(swiper.params.pagination.hiddenClass);\n if (isHidden === true) {\n swiper.emit('paginationShow', swiper);\n } else {\n swiper.emit('paginationHide', swiper);\n }\n swiper.pagination.$el.toggleClass(swiper.params.pagination.hiddenClass);\n }\n },\n },\n };\n\n var Scrollbar = {\n setTranslate: function setTranslate() {\n var swiper = this;\n if (!swiper.params.scrollbar.el || !swiper.scrollbar.el) { return; }\n var scrollbar = swiper.scrollbar;\n var rtl = swiper.rtlTranslate;\n var progress = swiper.progress;\n var dragSize = scrollbar.dragSize;\n var trackSize = scrollbar.trackSize;\n var $dragEl = scrollbar.$dragEl;\n var $el = scrollbar.$el;\n var params = swiper.params.scrollbar;\n\n var newSize = dragSize;\n var newPos = (trackSize - dragSize) * progress;\n if (rtl) {\n newPos = -newPos;\n if (newPos > 0) {\n newSize = dragSize - newPos;\n newPos = 0;\n } else if (-newPos + dragSize > trackSize) {\n newSize = trackSize + newPos;\n }\n } else if (newPos < 0) {\n newSize = dragSize + newPos;\n newPos = 0;\n } else if (newPos + dragSize > trackSize) {\n newSize = trackSize - newPos;\n }\n if (swiper.isHorizontal()) {\n if (Support.transforms3d) {\n $dragEl.transform((\"translate3d(\" + newPos + \"px, 0, 0)\"));\n } else {\n $dragEl.transform((\"translateX(\" + newPos + \"px)\"));\n }\n $dragEl[0].style.width = newSize + \"px\";\n } else {\n if (Support.transforms3d) {\n $dragEl.transform((\"translate3d(0px, \" + newPos + \"px, 0)\"));\n } else {\n $dragEl.transform((\"translateY(\" + newPos + \"px)\"));\n }\n $dragEl[0].style.height = newSize + \"px\";\n }\n if (params.hide) {\n clearTimeout(swiper.scrollbar.timeout);\n $el[0].style.opacity = 1;\n swiper.scrollbar.timeout = setTimeout(function () {\n $el[0].style.opacity = 0;\n $el.transition(400);\n }, 1000);\n }\n },\n setTransition: function setTransition(duration) {\n var swiper = this;\n if (!swiper.params.scrollbar.el || !swiper.scrollbar.el) { return; }\n swiper.scrollbar.$dragEl.transition(duration);\n },\n updateSize: function updateSize() {\n var swiper = this;\n if (!swiper.params.scrollbar.el || !swiper.scrollbar.el) { return; }\n\n var scrollbar = swiper.scrollbar;\n var $dragEl = scrollbar.$dragEl;\n var $el = scrollbar.$el;\n\n $dragEl[0].style.width = '';\n $dragEl[0].style.height = '';\n var trackSize = swiper.isHorizontal() ? $el[0].offsetWidth : $el[0].offsetHeight;\n\n var divider = swiper.size / swiper.virtualSize;\n var moveDivider = divider * (trackSize / swiper.size);\n var dragSize;\n if (swiper.params.scrollbar.dragSize === 'auto') {\n dragSize = trackSize * divider;\n } else {\n dragSize = parseInt(swiper.params.scrollbar.dragSize, 10);\n }\n\n if (swiper.isHorizontal()) {\n $dragEl[0].style.width = dragSize + \"px\";\n } else {\n $dragEl[0].style.height = dragSize + \"px\";\n }\n\n if (divider >= 1) {\n $el[0].style.display = 'none';\n } else {\n $el[0].style.display = '';\n }\n if (swiper.params.scrollbar.hide) {\n $el[0].style.opacity = 0;\n }\n Utils.extend(scrollbar, {\n trackSize: trackSize,\n divider: divider,\n moveDivider: moveDivider,\n dragSize: dragSize,\n });\n scrollbar.$el[swiper.params.watchOverflow && swiper.isLocked ? 'addClass' : 'removeClass'](swiper.params.scrollbar.lockClass);\n },\n getPointerPosition: function getPointerPosition(e) {\n var swiper = this;\n if (swiper.isHorizontal()) {\n return ((e.type === 'touchstart' || e.type === 'touchmove') ? e.targetTouches[0].pageX : e.pageX || e.clientX);\n }\n return ((e.type === 'touchstart' || e.type === 'touchmove') ? e.targetTouches[0].pageY : e.pageY || e.clientY);\n },\n setDragPosition: function setDragPosition(e) {\n var swiper = this;\n var scrollbar = swiper.scrollbar;\n var rtl = swiper.rtlTranslate;\n var $el = scrollbar.$el;\n var dragSize = scrollbar.dragSize;\n var trackSize = scrollbar.trackSize;\n var dragStartPos = scrollbar.dragStartPos;\n\n var positionRatio;\n positionRatio = ((scrollbar.getPointerPosition(e)) - $el.offset()[swiper.isHorizontal() ? 'left' : 'top']\n - (dragStartPos !== null ? dragStartPos : dragSize / 2)) / (trackSize - dragSize);\n positionRatio = Math.max(Math.min(positionRatio, 1), 0);\n if (rtl) {\n positionRatio = 1 - positionRatio;\n }\n\n var position = swiper.minTranslate() + ((swiper.maxTranslate() - swiper.minTranslate()) * positionRatio);\n\n swiper.updateProgress(position);\n swiper.setTranslate(position);\n swiper.updateActiveIndex();\n swiper.updateSlidesClasses();\n },\n onDragStart: function onDragStart(e) {\n var swiper = this;\n var params = swiper.params.scrollbar;\n var scrollbar = swiper.scrollbar;\n var $wrapperEl = swiper.$wrapperEl;\n var $el = scrollbar.$el;\n var $dragEl = scrollbar.$dragEl;\n swiper.scrollbar.isTouched = true;\n swiper.scrollbar.dragStartPos = (e.target === $dragEl[0] || e.target === $dragEl)\n ? scrollbar.getPointerPosition(e) - e.target.getBoundingClientRect()[swiper.isHorizontal() ? 'left' : 'top'] : null;\n e.preventDefault();\n e.stopPropagation();\n\n $wrapperEl.transition(100);\n $dragEl.transition(100);\n scrollbar.setDragPosition(e);\n\n clearTimeout(swiper.scrollbar.dragTimeout);\n\n $el.transition(0);\n if (params.hide) {\n $el.css('opacity', 1);\n }\n swiper.emit('scrollbarDragStart', e);\n },\n onDragMove: function onDragMove(e) {\n var swiper = this;\n var scrollbar = swiper.scrollbar;\n var $wrapperEl = swiper.$wrapperEl;\n var $el = scrollbar.$el;\n var $dragEl = scrollbar.$dragEl;\n\n if (!swiper.scrollbar.isTouched) { return; }\n if (e.preventDefault) { e.preventDefault(); }\n else { e.returnValue = false; }\n scrollbar.setDragPosition(e);\n $wrapperEl.transition(0);\n $el.transition(0);\n $dragEl.transition(0);\n swiper.emit('scrollbarDragMove', e);\n },\n onDragEnd: function onDragEnd(e) {\n var swiper = this;\n\n var params = swiper.params.scrollbar;\n var scrollbar = swiper.scrollbar;\n var $el = scrollbar.$el;\n\n if (!swiper.scrollbar.isTouched) { return; }\n swiper.scrollbar.isTouched = false;\n if (params.hide) {\n clearTimeout(swiper.scrollbar.dragTimeout);\n swiper.scrollbar.dragTimeout = Utils.nextTick(function () {\n $el.css('opacity', 0);\n $el.transition(400);\n }, 1000);\n }\n swiper.emit('scrollbarDragEnd', e);\n if (params.snapOnRelease) {\n swiper.slideToClosest();\n }\n },\n enableDraggable: function enableDraggable() {\n var swiper = this;\n if (!swiper.params.scrollbar.el) { return; }\n var scrollbar = swiper.scrollbar;\n var touchEventsTouch = swiper.touchEventsTouch;\n var touchEventsDesktop = swiper.touchEventsDesktop;\n var params = swiper.params;\n var $el = scrollbar.$el;\n var target = $el[0];\n var activeListener = Support.passiveListener && params.passiveListeners ? { passive: false, capture: false } : false;\n var passiveListener = Support.passiveListener && params.passiveListeners ? { passive: true, capture: false } : false;\n if (!Support.touch) {\n target.addEventListener(touchEventsDesktop.start, swiper.scrollbar.onDragStart, activeListener);\n doc.addEventListener(touchEventsDesktop.move, swiper.scrollbar.onDragMove, activeListener);\n doc.addEventListener(touchEventsDesktop.end, swiper.scrollbar.onDragEnd, passiveListener);\n } else {\n target.addEventListener(touchEventsTouch.start, swiper.scrollbar.onDragStart, activeListener);\n target.addEventListener(touchEventsTouch.move, swiper.scrollbar.onDragMove, activeListener);\n target.addEventListener(touchEventsTouch.end, swiper.scrollbar.onDragEnd, passiveListener);\n }\n },\n disableDraggable: function disableDraggable() {\n var swiper = this;\n if (!swiper.params.scrollbar.el) { return; }\n var scrollbar = swiper.scrollbar;\n var touchEventsTouch = swiper.touchEventsTouch;\n var touchEventsDesktop = swiper.touchEventsDesktop;\n var params = swiper.params;\n var $el = scrollbar.$el;\n var target = $el[0];\n var activeListener = Support.passiveListener && params.passiveListeners ? { passive: false, capture: false } : false;\n var passiveListener = Support.passiveListener && params.passiveListeners ? { passive: true, capture: false } : false;\n if (!Support.touch) {\n target.removeEventListener(touchEventsDesktop.start, swiper.scrollbar.onDragStart, activeListener);\n doc.removeEventListener(touchEventsDesktop.move, swiper.scrollbar.onDragMove, activeListener);\n doc.removeEventListener(touchEventsDesktop.end, swiper.scrollbar.onDragEnd, passiveListener);\n } else {\n target.removeEventListener(touchEventsTouch.start, swiper.scrollbar.onDragStart, activeListener);\n target.removeEventListener(touchEventsTouch.move, swiper.scrollbar.onDragMove, activeListener);\n target.removeEventListener(touchEventsTouch.end, swiper.scrollbar.onDragEnd, passiveListener);\n }\n },\n init: function init() {\n var swiper = this;\n if (!swiper.params.scrollbar.el) { return; }\n var scrollbar = swiper.scrollbar;\n var $swiperEl = swiper.$el;\n var params = swiper.params.scrollbar;\n\n var $el = $(params.el);\n if (swiper.params.uniqueNavElements && typeof params.el === 'string' && $el.length > 1 && $swiperEl.find(params.el).length === 1) {\n $el = $swiperEl.find(params.el);\n }\n\n var $dragEl = $el.find((\".\" + (swiper.params.scrollbar.dragClass)));\n if ($dragEl.length === 0) {\n $dragEl = $((\"<div class=\\\"\" + (swiper.params.scrollbar.dragClass) + \"\\\"></div>\"));\n $el.append($dragEl);\n }\n\n Utils.extend(scrollbar, {\n $el: $el,\n el: $el[0],\n $dragEl: $dragEl,\n dragEl: $dragEl[0],\n });\n\n if (params.draggable) {\n scrollbar.enableDraggable();\n }\n },\n destroy: function destroy() {\n var swiper = this;\n swiper.scrollbar.disableDraggable();\n },\n };\n\n var Scrollbar$1 = {\n name: 'scrollbar',\n params: {\n scrollbar: {\n el: null,\n dragSize: 'auto',\n hide: false,\n draggable: false,\n snapOnRelease: true,\n lockClass: 'swiper-scrollbar-lock',\n dragClass: 'swiper-scrollbar-drag',\n },\n },\n create: function create() {\n var swiper = this;\n Utils.extend(swiper, {\n scrollbar: {\n init: Scrollbar.init.bind(swiper),\n destroy: Scrollbar.destroy.bind(swiper),\n updateSize: Scrollbar.updateSize.bind(swiper),\n setTranslate: Scrollbar.setTranslate.bind(swiper),\n setTransition: Scrollbar.setTransition.bind(swiper),\n enableDraggable: Scrollbar.enableDraggable.bind(swiper),\n disableDraggable: Scrollbar.disableDraggable.bind(swiper),\n setDragPosition: Scrollbar.setDragPosition.bind(swiper),\n getPointerPosition: Scrollbar.getPointerPosition.bind(swiper),\n onDragStart: Scrollbar.onDragStart.bind(swiper),\n onDragMove: Scrollbar.onDragMove.bind(swiper),\n onDragEnd: Scrollbar.onDragEnd.bind(swiper),\n isTouched: false,\n timeout: null,\n dragTimeout: null,\n },\n });\n },\n on: {\n init: function init() {\n var swiper = this;\n swiper.scrollbar.init();\n swiper.scrollbar.updateSize();\n swiper.scrollbar.setTranslate();\n },\n update: function update() {\n var swiper = this;\n swiper.scrollbar.updateSize();\n },\n resize: function resize() {\n var swiper = this;\n swiper.scrollbar.updateSize();\n },\n observerUpdate: function observerUpdate() {\n var swiper = this;\n swiper.scrollbar.updateSize();\n },\n setTranslate: function setTranslate() {\n var swiper = this;\n swiper.scrollbar.setTranslate();\n },\n setTransition: function setTransition(duration) {\n var swiper = this;\n swiper.scrollbar.setTransition(duration);\n },\n destroy: function destroy() {\n var swiper = this;\n swiper.scrollbar.destroy();\n },\n },\n };\n\n var Parallax = {\n setTransform: function setTransform(el, progress) {\n var swiper = this;\n var rtl = swiper.rtl;\n\n var $el = $(el);\n var rtlFactor = rtl ? -1 : 1;\n\n var p = $el.attr('data-swiper-parallax') || '0';\n var x = $el.attr('data-swiper-parallax-x');\n var y = $el.attr('data-swiper-parallax-y');\n var scale = $el.attr('data-swiper-parallax-scale');\n var opacity = $el.attr('data-swiper-parallax-opacity');\n\n if (x || y) {\n x = x || '0';\n y = y || '0';\n } else if (swiper.isHorizontal()) {\n x = p;\n y = '0';\n } else {\n y = p;\n x = '0';\n }\n\n if ((x).indexOf('%') >= 0) {\n x = (parseInt(x, 10) * progress * rtlFactor) + \"%\";\n } else {\n x = (x * progress * rtlFactor) + \"px\";\n }\n if ((y).indexOf('%') >= 0) {\n y = (parseInt(y, 10) * progress) + \"%\";\n } else {\n y = (y * progress) + \"px\";\n }\n\n if (typeof opacity !== 'undefined' && opacity !== null) {\n var currentOpacity = opacity - ((opacity - 1) * (1 - Math.abs(progress)));\n $el[0].style.opacity = currentOpacity;\n }\n if (typeof scale === 'undefined' || scale === null) {\n $el.transform((\"translate3d(\" + x + \", \" + y + \", 0px)\"));\n } else {\n var currentScale = scale - ((scale - 1) * (1 - Math.abs(progress)));\n $el.transform((\"translate3d(\" + x + \", \" + y + \", 0px) scale(\" + currentScale + \")\"));\n }\n },\n setTranslate: function setTranslate() {\n var swiper = this;\n var $el = swiper.$el;\n var slides = swiper.slides;\n var progress = swiper.progress;\n var snapGrid = swiper.snapGrid;\n $el.children('[data-swiper-parallax], [data-swiper-parallax-x], [data-swiper-parallax-y], [data-swiper-parallax-opacity], [data-swiper-parallax-scale]')\n .each(function (index, el) {\n swiper.parallax.setTransform(el, progress);\n });\n slides.each(function (slideIndex, slideEl) {\n var slideProgress = slideEl.progress;\n if (swiper.params.slidesPerGroup > 1 && swiper.params.slidesPerView !== 'auto') {\n slideProgress += Math.ceil(slideIndex / 2) - (progress * (snapGrid.length - 1));\n }\n slideProgress = Math.min(Math.max(slideProgress, -1), 1);\n $(slideEl).find('[data-swiper-parallax], [data-swiper-parallax-x], [data-swiper-parallax-y], [data-swiper-parallax-opacity], [data-swiper-parallax-scale]')\n .each(function (index, el) {\n swiper.parallax.setTransform(el, slideProgress);\n });\n });\n },\n setTransition: function setTransition(duration) {\n if ( duration === void 0 ) duration = this.params.speed;\n\n var swiper = this;\n var $el = swiper.$el;\n $el.find('[data-swiper-parallax], [data-swiper-parallax-x], [data-swiper-parallax-y], [data-swiper-parallax-opacity], [data-swiper-parallax-scale]')\n .each(function (index, parallaxEl) {\n var $parallaxEl = $(parallaxEl);\n var parallaxDuration = parseInt($parallaxEl.attr('data-swiper-parallax-duration'), 10) || duration;\n if (duration === 0) { parallaxDuration = 0; }\n $parallaxEl.transition(parallaxDuration);\n });\n },\n };\n\n var Parallax$1 = {\n name: 'parallax',\n params: {\n parallax: {\n enabled: false,\n },\n },\n create: function create() {\n var swiper = this;\n Utils.extend(swiper, {\n parallax: {\n setTransform: Parallax.setTransform.bind(swiper),\n setTranslate: Parallax.setTranslate.bind(swiper),\n setTransition: Parallax.setTransition.bind(swiper),\n },\n });\n },\n on: {\n beforeInit: function beforeInit() {\n var swiper = this;\n if (!swiper.params.parallax.enabled) { return; }\n swiper.params.watchSlidesProgress = true;\n swiper.originalParams.watchSlidesProgress = true;\n },\n init: function init() {\n var swiper = this;\n if (!swiper.params.parallax.enabled) { return; }\n swiper.parallax.setTranslate();\n },\n setTranslate: function setTranslate() {\n var swiper = this;\n if (!swiper.params.parallax.enabled) { return; }\n swiper.parallax.setTranslate();\n },\n setTransition: function setTransition(duration) {\n var swiper = this;\n if (!swiper.params.parallax.enabled) { return; }\n swiper.parallax.setTransition(duration);\n },\n },\n };\n\n var Zoom = {\n // Calc Scale From Multi-touches\n getDistanceBetweenTouches: function getDistanceBetweenTouches(e) {\n if (e.targetTouches.length < 2) { return 1; }\n var x1 = e.targetTouches[0].pageX;\n var y1 = e.targetTouches[0].pageY;\n var x2 = e.targetTouches[1].pageX;\n var y2 = e.targetTouches[1].pageY;\n var distance = Math.sqrt((Math.pow( (x2 - x1), 2 )) + (Math.pow( (y2 - y1), 2 )));\n return distance;\n },\n // Events\n onGestureStart: function onGestureStart(e) {\n var swiper = this;\n var params = swiper.params.zoom;\n var zoom = swiper.zoom;\n var gesture = zoom.gesture;\n zoom.fakeGestureTouched = false;\n zoom.fakeGestureMoved = false;\n if (!Support.gestures) {\n if (e.type !== 'touchstart' || (e.type === 'touchstart' && e.targetTouches.length < 2)) {\n return;\n }\n zoom.fakeGestureTouched = true;\n gesture.scaleStart = Zoom.getDistanceBetweenTouches(e);\n }\n if (!gesture.$slideEl || !gesture.$slideEl.length) {\n gesture.$slideEl = $(e.target).closest('.swiper-slide');\n if (gesture.$slideEl.length === 0) { gesture.$slideEl = swiper.slides.eq(swiper.activeIndex); }\n gesture.$imageEl = gesture.$slideEl.find('img, svg, canvas');\n gesture.$imageWrapEl = gesture.$imageEl.parent((\".\" + (params.containerClass)));\n gesture.maxRatio = gesture.$imageWrapEl.attr('data-swiper-zoom') || params.maxRatio;\n if (gesture.$imageWrapEl.length === 0) {\n gesture.$imageEl = undefined;\n return;\n }\n }\n gesture.$imageEl.transition(0);\n swiper.zoom.isScaling = true;\n },\n onGestureChange: function onGestureChange(e) {\n var swiper = this;\n var params = swiper.params.zoom;\n var zoom = swiper.zoom;\n var gesture = zoom.gesture;\n if (!Support.gestures) {\n if (e.type !== 'touchmove' || (e.type === 'touchmove' && e.targetTouches.length < 2)) {\n return;\n }\n zoom.fakeGestureMoved = true;\n gesture.scaleMove = Zoom.getDistanceBetweenTouches(e);\n }\n if (!gesture.$imageEl || gesture.$imageEl.length === 0) { return; }\n if (Support.gestures) {\n zoom.scale = e.scale * zoom.currentScale;\n } else {\n zoom.scale = (gesture.scaleMove / gesture.scaleStart) * zoom.currentScale;\n }\n if (zoom.scale > gesture.maxRatio) {\n zoom.scale = (gesture.maxRatio - 1) + (Math.pow( ((zoom.scale - gesture.maxRatio) + 1), 0.5 ));\n }\n if (zoom.scale < params.minRatio) {\n zoom.scale = (params.minRatio + 1) - (Math.pow( ((params.minRatio - zoom.scale) + 1), 0.5 ));\n }\n gesture.$imageEl.transform((\"translate3d(0,0,0) scale(\" + (zoom.scale) + \")\"));\n },\n onGestureEnd: function onGestureEnd(e) {\n var swiper = this;\n var params = swiper.params.zoom;\n var zoom = swiper.zoom;\n var gesture = zoom.gesture;\n if (!Support.gestures) {\n if (!zoom.fakeGestureTouched || !zoom.fakeGestureMoved) {\n return;\n }\n if (e.type !== 'touchend' || (e.type === 'touchend' && e.changedTouches.length < 2 && !Device.android)) {\n return;\n }\n zoom.fakeGestureTouched = false;\n zoom.fakeGestureMoved = false;\n }\n if (!gesture.$imageEl || gesture.$imageEl.length === 0) { return; }\n zoom.scale = Math.max(Math.min(zoom.scale, gesture.maxRatio), params.minRatio);\n gesture.$imageEl.transition(swiper.params.speed).transform((\"translate3d(0,0,0) scale(\" + (zoom.scale) + \")\"));\n zoom.currentScale = zoom.scale;\n zoom.isScaling = false;\n if (zoom.scale === 1) { gesture.$slideEl = undefined; }\n },\n onTouchStart: function onTouchStart(e) {\n var swiper = this;\n var zoom = swiper.zoom;\n var gesture = zoom.gesture;\n var image = zoom.image;\n if (!gesture.$imageEl || gesture.$imageEl.length === 0) { return; }\n if (image.isTouched) { return; }\n if (Device.android) { e.preventDefault(); }\n image.isTouched = true;\n image.touchesStart.x = e.type === 'touchstart' ? e.targetTouches[0].pageX : e.pageX;\n image.touchesStart.y = e.type === 'touchstart' ? e.targetTouches[0].pageY : e.pageY;\n },\n onTouchMove: function onTouchMove(e) {\n var swiper = this;\n var zoom = swiper.zoom;\n var gesture = zoom.gesture;\n var image = zoom.image;\n var velocity = zoom.velocity;\n if (!gesture.$imageEl || gesture.$imageEl.length === 0) { return; }\n swiper.allowClick = false;\n if (!image.isTouched || !gesture.$slideEl) { return; }\n\n if (!image.isMoved) {\n image.width = gesture.$imageEl[0].offsetWidth;\n image.height = gesture.$imageEl[0].offsetHeight;\n image.startX = Utils.getTranslate(gesture.$imageWrapEl[0], 'x') || 0;\n image.startY = Utils.getTranslate(gesture.$imageWrapEl[0], 'y') || 0;\n gesture.slideWidth = gesture.$slideEl[0].offsetWidth;\n gesture.slideHeight = gesture.$slideEl[0].offsetHeight;\n gesture.$imageWrapEl.transition(0);\n if (swiper.rtl) {\n image.startX = -image.startX;\n image.startY = -image.startY;\n }\n }\n // Define if we need image drag\n var scaledWidth = image.width * zoom.scale;\n var scaledHeight = image.height * zoom.scale;\n\n if (scaledWidth < gesture.slideWidth && scaledHeight < gesture.slideHeight) { return; }\n\n image.minX = Math.min(((gesture.slideWidth / 2) - (scaledWidth / 2)), 0);\n image.maxX = -image.minX;\n image.minY = Math.min(((gesture.slideHeight / 2) - (scaledHeight / 2)), 0);\n image.maxY = -image.minY;\n\n image.touchesCurrent.x = e.type === 'touchmove' ? e.targetTouches[0].pageX : e.pageX;\n image.touchesCurrent.y = e.type === 'touchmove' ? e.targetTouches[0].pageY : e.pageY;\n\n if (!image.isMoved && !zoom.isScaling) {\n if (\n swiper.isHorizontal()\n && (\n (Math.floor(image.minX) === Math.floor(image.startX) && image.touchesCurrent.x < image.touchesStart.x)\n || (Math.floor(image.maxX) === Math.floor(image.startX) && image.touchesCurrent.x > image.touchesStart.x)\n )\n ) {\n image.isTouched = false;\n return;\n } if (\n !swiper.isHorizontal()\n && (\n (Math.floor(image.minY) === Math.floor(image.startY) && image.touchesCurrent.y < image.touchesStart.y)\n || (Math.floor(image.maxY) === Math.floor(image.startY) && image.touchesCurrent.y > image.touchesStart.y)\n )\n ) {\n image.isTouched = false;\n return;\n }\n }\n e.preventDefault();\n e.stopPropagation();\n\n image.isMoved = true;\n image.currentX = (image.touchesCurrent.x - image.touchesStart.x) + image.startX;\n image.currentY = (image.touchesCurrent.y - image.touchesStart.y) + image.startY;\n\n if (image.currentX < image.minX) {\n image.currentX = (image.minX + 1) - (Math.pow( ((image.minX - image.currentX) + 1), 0.8 ));\n }\n if (image.currentX > image.maxX) {\n image.currentX = (image.maxX - 1) + (Math.pow( ((image.currentX - image.maxX) + 1), 0.8 ));\n }\n\n if (image.currentY < image.minY) {\n image.currentY = (image.minY + 1) - (Math.pow( ((image.minY - image.currentY) + 1), 0.8 ));\n }\n if (image.currentY > image.maxY) {\n image.currentY = (image.maxY - 1) + (Math.pow( ((image.currentY - image.maxY) + 1), 0.8 ));\n }\n\n // Velocity\n if (!velocity.prevPositionX) { velocity.prevPositionX = image.touchesCurrent.x; }\n if (!velocity.prevPositionY) { velocity.prevPositionY = image.touchesCurrent.y; }\n if (!velocity.prevTime) { velocity.prevTime = Date.now(); }\n velocity.x = (image.touchesCurrent.x - velocity.prevPositionX) / (Date.now() - velocity.prevTime) / 2;\n velocity.y = (image.touchesCurrent.y - velocity.prevPositionY) / (Date.now() - velocity.prevTime) / 2;\n if (Math.abs(image.touchesCurrent.x - velocity.prevPositionX) < 2) { velocity.x = 0; }\n if (Math.abs(image.touchesCurrent.y - velocity.prevPositionY) < 2) { velocity.y = 0; }\n velocity.prevPositionX = image.touchesCurrent.x;\n velocity.prevPositionY = image.touchesCurrent.y;\n velocity.prevTime = Date.now();\n\n gesture.$imageWrapEl.transform((\"translate3d(\" + (image.currentX) + \"px, \" + (image.currentY) + \"px,0)\"));\n },\n onTouchEnd: function onTouchEnd() {\n var swiper = this;\n var zoom = swiper.zoom;\n var gesture = zoom.gesture;\n var image = zoom.image;\n var velocity = zoom.velocity;\n if (!gesture.$imageEl || gesture.$imageEl.length === 0) { return; }\n if (!image.isTouched || !image.isMoved) {\n image.isTouched = false;\n image.isMoved = false;\n return;\n }\n image.isTouched = false;\n image.isMoved = false;\n var momentumDurationX = 300;\n var momentumDurationY = 300;\n var momentumDistanceX = velocity.x * momentumDurationX;\n var newPositionX = image.currentX + momentumDistanceX;\n var momentumDistanceY = velocity.y * momentumDurationY;\n var newPositionY = image.currentY + momentumDistanceY;\n\n // Fix duration\n if (velocity.x !== 0) { momentumDurationX = Math.abs((newPositionX - image.currentX) / velocity.x); }\n if (velocity.y !== 0) { momentumDurationY = Math.abs((newPositionY - image.currentY) / velocity.y); }\n var momentumDuration = Math.max(momentumDurationX, momentumDurationY);\n\n image.currentX = newPositionX;\n image.currentY = newPositionY;\n\n // Define if we need image drag\n var scaledWidth = image.width * zoom.scale;\n var scaledHeight = image.height * zoom.scale;\n image.minX = Math.min(((gesture.slideWidth / 2) - (scaledWidth / 2)), 0);\n image.maxX = -image.minX;\n image.minY = Math.min(((gesture.slideHeight / 2) - (scaledHeight / 2)), 0);\n image.maxY = -image.minY;\n image.currentX = Math.max(Math.min(image.currentX, image.maxX), image.minX);\n image.currentY = Math.max(Math.min(image.currentY, image.maxY), image.minY);\n\n gesture.$imageWrapEl.transition(momentumDuration).transform((\"translate3d(\" + (image.currentX) + \"px, \" + (image.currentY) + \"px,0)\"));\n },\n onTransitionEnd: function onTransitionEnd() {\n var swiper = this;\n var zoom = swiper.zoom;\n var gesture = zoom.gesture;\n if (gesture.$slideEl && swiper.previousIndex !== swiper.activeIndex) {\n gesture.$imageEl.transform('translate3d(0,0,0) scale(1)');\n gesture.$imageWrapEl.transform('translate3d(0,0,0)');\n\n zoom.scale = 1;\n zoom.currentScale = 1;\n\n gesture.$slideEl = undefined;\n gesture.$imageEl = undefined;\n gesture.$imageWrapEl = undefined;\n }\n },\n // Toggle Zoom\n toggle: function toggle(e) {\n var swiper = this;\n var zoom = swiper.zoom;\n\n if (zoom.scale && zoom.scale !== 1) {\n // Zoom Out\n zoom.out();\n } else {\n // Zoom In\n zoom.in(e);\n }\n },\n in: function in$1(e) {\n var swiper = this;\n\n var zoom = swiper.zoom;\n var params = swiper.params.zoom;\n var gesture = zoom.gesture;\n var image = zoom.image;\n\n if (!gesture.$slideEl) {\n gesture.$slideEl = swiper.clickedSlide ? $(swiper.clickedSlide) : swiper.slides.eq(swiper.activeIndex);\n gesture.$imageEl = gesture.$slideEl.find('img, svg, canvas');\n gesture.$imageWrapEl = gesture.$imageEl.parent((\".\" + (params.containerClass)));\n }\n if (!gesture.$imageEl || gesture.$imageEl.length === 0) { return; }\n\n gesture.$slideEl.addClass((\"\" + (params.zoomedSlideClass)));\n\n var touchX;\n var touchY;\n var offsetX;\n var offsetY;\n var diffX;\n var diffY;\n var translateX;\n var translateY;\n var imageWidth;\n var imageHeight;\n var scaledWidth;\n var scaledHeight;\n var translateMinX;\n var translateMinY;\n var translateMaxX;\n var translateMaxY;\n var slideWidth;\n var slideHeight;\n\n if (typeof image.touchesStart.x === 'undefined' && e) {\n touchX = e.type === 'touchend' ? e.changedTouches[0].pageX : e.pageX;\n touchY = e.type === 'touchend' ? e.changedTouches[0].pageY : e.pageY;\n } else {\n touchX = image.touchesStart.x;\n touchY = image.touchesStart.y;\n }\n\n zoom.scale = gesture.$imageWrapEl.attr('data-swiper-zoom') || params.maxRatio;\n zoom.currentScale = gesture.$imageWrapEl.attr('data-swiper-zoom') || params.maxRatio;\n if (e) {\n slideWidth = gesture.$slideEl[0].offsetWidth;\n slideHeight = gesture.$slideEl[0].offsetHeight;\n offsetX = gesture.$slideEl.offset().left;\n offsetY = gesture.$slideEl.offset().top;\n diffX = (offsetX + (slideWidth / 2)) - touchX;\n diffY = (offsetY + (slideHeight / 2)) - touchY;\n\n imageWidth = gesture.$imageEl[0].offsetWidth;\n imageHeight = gesture.$imageEl[0].offsetHeight;\n scaledWidth = imageWidth * zoom.scale;\n scaledHeight = imageHeight * zoom.scale;\n\n translateMinX = Math.min(((slideWidth / 2) - (scaledWidth / 2)), 0);\n translateMinY = Math.min(((slideHeight / 2) - (scaledHeight / 2)), 0);\n translateMaxX = -translateMinX;\n translateMaxY = -translateMinY;\n\n translateX = diffX * zoom.scale;\n translateY = diffY * zoom.scale;\n\n if (translateX < translateMinX) {\n translateX = translateMinX;\n }\n if (translateX > translateMaxX) {\n translateX = translateMaxX;\n }\n\n if (translateY < translateMinY) {\n translateY = translateMinY;\n }\n if (translateY > translateMaxY) {\n translateY = translateMaxY;\n }\n } else {\n translateX = 0;\n translateY = 0;\n }\n gesture.$imageWrapEl.transition(300).transform((\"translate3d(\" + translateX + \"px, \" + translateY + \"px,0)\"));\n gesture.$imageEl.transition(300).transform((\"translate3d(0,0,0) scale(\" + (zoom.scale) + \")\"));\n },\n out: function out() {\n var swiper = this;\n\n var zoom = swiper.zoom;\n var params = swiper.params.zoom;\n var gesture = zoom.gesture;\n\n if (!gesture.$slideEl) {\n gesture.$slideEl = swiper.clickedSlide ? $(swiper.clickedSlide) : swiper.slides.eq(swiper.activeIndex);\n gesture.$imageEl = gesture.$slideEl.find('img, svg, canvas');\n gesture.$imageWrapEl = gesture.$imageEl.parent((\".\" + (params.containerClass)));\n }\n if (!gesture.$imageEl || gesture.$imageEl.length === 0) { return; }\n\n zoom.scale = 1;\n zoom.currentScale = 1;\n gesture.$imageWrapEl.transition(300).transform('translate3d(0,0,0)');\n gesture.$imageEl.transition(300).transform('translate3d(0,0,0) scale(1)');\n gesture.$slideEl.removeClass((\"\" + (params.zoomedSlideClass)));\n gesture.$slideEl = undefined;\n },\n // Attach/Detach Events\n enable: function enable() {\n var swiper = this;\n var zoom = swiper.zoom;\n if (zoom.enabled) { return; }\n zoom.enabled = true;\n\n var passiveListener = swiper.touchEvents.start === 'touchstart' && Support.passiveListener && swiper.params.passiveListeners ? { passive: true, capture: false } : false;\n\n // Scale image\n if (Support.gestures) {\n swiper.$wrapperEl.on('gesturestart', '.swiper-slide', zoom.onGestureStart, passiveListener);\n swiper.$wrapperEl.on('gesturechange', '.swiper-slide', zoom.onGestureChange, passiveListener);\n swiper.$wrapperEl.on('gestureend', '.swiper-slide', zoom.onGestureEnd, passiveListener);\n } else if (swiper.touchEvents.start === 'touchstart') {\n swiper.$wrapperEl.on(swiper.touchEvents.start, '.swiper-slide', zoom.onGestureStart, passiveListener);\n swiper.$wrapperEl.on(swiper.touchEvents.move, '.swiper-slide', zoom.onGestureChange, passiveListener);\n swiper.$wrapperEl.on(swiper.touchEvents.end, '.swiper-slide', zoom.onGestureEnd, passiveListener);\n }\n\n // Move image\n swiper.$wrapperEl.on(swiper.touchEvents.move, (\".\" + (swiper.params.zoom.containerClass)), zoom.onTouchMove);\n },\n disable: function disable() {\n var swiper = this;\n var zoom = swiper.zoom;\n if (!zoom.enabled) { return; }\n\n swiper.zoom.enabled = false;\n\n var passiveListener = swiper.touchEvents.start === 'touchstart' && Support.passiveListener && swiper.params.passiveListeners ? { passive: true, capture: false } : false;\n\n // Scale image\n if (Support.gestures) {\n swiper.$wrapperEl.off('gesturestart', '.swiper-slide', zoom.onGestureStart, passiveListener);\n swiper.$wrapperEl.off('gesturechange', '.swiper-slide', zoom.onGestureChange, passiveListener);\n swiper.$wrapperEl.off('gestureend', '.swiper-slide', zoom.onGestureEnd, passiveListener);\n } else if (swiper.touchEvents.start === 'touchstart') {\n swiper.$wrapperEl.off(swiper.touchEvents.start, '.swiper-slide', zoom.onGestureStart, passiveListener);\n swiper.$wrapperEl.off(swiper.touchEvents.move, '.swiper-slide', zoom.onGestureChange, passiveListener);\n swiper.$wrapperEl.off(swiper.touchEvents.end, '.swiper-slide', zoom.onGestureEnd, passiveListener);\n }\n\n // Move image\n swiper.$wrapperEl.off(swiper.touchEvents.move, (\".\" + (swiper.params.zoom.containerClass)), zoom.onTouchMove);\n },\n };\n\n var Zoom$1 = {\n name: 'zoom',\n params: {\n zoom: {\n enabled: false,\n maxRatio: 3,\n minRatio: 1,\n toggle: true,\n containerClass: 'swiper-zoom-container',\n zoomedSlideClass: 'swiper-slide-zoomed',\n },\n },\n create: function create() {\n var swiper = this;\n var zoom = {\n enabled: false,\n scale: 1,\n currentScale: 1,\n isScaling: false,\n gesture: {\n $slideEl: undefined,\n slideWidth: undefined,\n slideHeight: undefined,\n $imageEl: undefined,\n $imageWrapEl: undefined,\n maxRatio: 3,\n },\n image: {\n isTouched: undefined,\n isMoved: undefined,\n currentX: undefined,\n currentY: undefined,\n minX: undefined,\n minY: undefined,\n maxX: undefined,\n maxY: undefined,\n width: undefined,\n height: undefined,\n startX: undefined,\n startY: undefined,\n touchesStart: {},\n touchesCurrent: {},\n },\n velocity: {\n x: undefined,\n y: undefined,\n prevPositionX: undefined,\n prevPositionY: undefined,\n prevTime: undefined,\n },\n };\n\n ('onGestureStart onGestureChange onGestureEnd onTouchStart onTouchMove onTouchEnd onTransitionEnd toggle enable disable in out').split(' ').forEach(function (methodName) {\n zoom[methodName] = Zoom[methodName].bind(swiper);\n });\n Utils.extend(swiper, {\n zoom: zoom,\n });\n\n var scale = 1;\n Object.defineProperty(swiper.zoom, 'scale', {\n get: function get() {\n return scale;\n },\n set: function set(value) {\n if (scale !== value) {\n var imageEl = swiper.zoom.gesture.$imageEl ? swiper.zoom.gesture.$imageEl[0] : undefined;\n var slideEl = swiper.zoom.gesture.$slideEl ? swiper.zoom.gesture.$slideEl[0] : undefined;\n swiper.emit('zoomChange', value, imageEl, slideEl);\n }\n scale = value;\n },\n });\n },\n on: {\n init: function init() {\n var swiper = this;\n if (swiper.params.zoom.enabled) {\n swiper.zoom.enable();\n }\n },\n destroy: function destroy() {\n var swiper = this;\n swiper.zoom.disable();\n },\n touchStart: function touchStart(e) {\n var swiper = this;\n if (!swiper.zoom.enabled) { return; }\n swiper.zoom.onTouchStart(e);\n },\n touchEnd: function touchEnd(e) {\n var swiper = this;\n if (!swiper.zoom.enabled) { return; }\n swiper.zoom.onTouchEnd(e);\n },\n doubleTap: function doubleTap(e) {\n var swiper = this;\n if (swiper.params.zoom.enabled && swiper.zoom.enabled && swiper.params.zoom.toggle) {\n swiper.zoom.toggle(e);\n }\n },\n transitionEnd: function transitionEnd() {\n var swiper = this;\n if (swiper.zoom.enabled && swiper.params.zoom.enabled) {\n swiper.zoom.onTransitionEnd();\n }\n },\n },\n };\n\n var Lazy = {\n loadInSlide: function loadInSlide(index, loadInDuplicate) {\n if ( loadInDuplicate === void 0 ) loadInDuplicate = true;\n\n var swiper = this;\n var params = swiper.params.lazy;\n if (typeof index === 'undefined') { return; }\n if (swiper.slides.length === 0) { return; }\n var isVirtual = swiper.virtual && swiper.params.virtual.enabled;\n\n var $slideEl = isVirtual\n ? swiper.$wrapperEl.children((\".\" + (swiper.params.slideClass) + \"[data-swiper-slide-index=\\\"\" + index + \"\\\"]\"))\n : swiper.slides.eq(index);\n\n var $images = $slideEl.find((\".\" + (params.elementClass) + \":not(.\" + (params.loadedClass) + \"):not(.\" + (params.loadingClass) + \")\"));\n if ($slideEl.hasClass(params.elementClass) && !$slideEl.hasClass(params.loadedClass) && !$slideEl.hasClass(params.loadingClass)) {\n $images = $images.add($slideEl[0]);\n }\n if ($images.length === 0) { return; }\n\n $images.each(function (imageIndex, imageEl) {\n var $imageEl = $(imageEl);\n $imageEl.addClass(params.loadingClass);\n\n var background = $imageEl.attr('data-background');\n var src = $imageEl.attr('data-src');\n var srcset = $imageEl.attr('data-srcset');\n var sizes = $imageEl.attr('data-sizes');\n\n swiper.loadImage($imageEl[0], (src || background), srcset, sizes, false, function () {\n if (typeof swiper === 'undefined' || swiper === null || !swiper || (swiper && !swiper.params) || swiper.destroyed) { return; }\n if (background) {\n $imageEl.css('background-image', (\"url(\\\"\" + background + \"\\\")\"));\n $imageEl.removeAttr('data-background');\n } else {\n if (srcset) {\n $imageEl.attr('srcset', srcset);\n $imageEl.removeAttr('data-srcset');\n }\n if (sizes) {\n $imageEl.attr('sizes', sizes);\n $imageEl.removeAttr('data-sizes');\n }\n if (src) {\n $imageEl.attr('src', src);\n $imageEl.removeAttr('data-src');\n }\n }\n\n $imageEl.addClass(params.loadedClass).removeClass(params.loadingClass);\n $slideEl.find((\".\" + (params.preloaderClass))).remove();\n if (swiper.params.loop && loadInDuplicate) {\n var slideOriginalIndex = $slideEl.attr('data-swiper-slide-index');\n if ($slideEl.hasClass(swiper.params.slideDuplicateClass)) {\n var originalSlide = swiper.$wrapperEl.children((\"[data-swiper-slide-index=\\\"\" + slideOriginalIndex + \"\\\"]:not(.\" + (swiper.params.slideDuplicateClass) + \")\"));\n swiper.lazy.loadInSlide(originalSlide.index(), false);\n } else {\n var duplicatedSlide = swiper.$wrapperEl.children((\".\" + (swiper.params.slideDuplicateClass) + \"[data-swiper-slide-index=\\\"\" + slideOriginalIndex + \"\\\"]\"));\n swiper.lazy.loadInSlide(duplicatedSlide.index(), false);\n }\n }\n swiper.emit('lazyImageReady', $slideEl[0], $imageEl[0]);\n });\n\n swiper.emit('lazyImageLoad', $slideEl[0], $imageEl[0]);\n });\n },\n load: function load() {\n var swiper = this;\n var $wrapperEl = swiper.$wrapperEl;\n var swiperParams = swiper.params;\n var slides = swiper.slides;\n var activeIndex = swiper.activeIndex;\n var isVirtual = swiper.virtual && swiperParams.virtual.enabled;\n var params = swiperParams.lazy;\n\n var slidesPerView = swiperParams.slidesPerView;\n if (slidesPerView === 'auto') {\n slidesPerView = 0;\n }\n\n function slideExist(index) {\n if (isVirtual) {\n if ($wrapperEl.children((\".\" + (swiperParams.slideClass) + \"[data-swiper-slide-index=\\\"\" + index + \"\\\"]\")).length) {\n return true;\n }\n } else if (slides[index]) { return true; }\n return false;\n }\n function slideIndex(slideEl) {\n if (isVirtual) {\n return $(slideEl).attr('data-swiper-slide-index');\n }\n return $(slideEl).index();\n }\n\n if (!swiper.lazy.initialImageLoaded) { swiper.lazy.initialImageLoaded = true; }\n if (swiper.params.watchSlidesVisibility) {\n $wrapperEl.children((\".\" + (swiperParams.slideVisibleClass))).each(function (elIndex, slideEl) {\n var index = isVirtual ? $(slideEl).attr('data-swiper-slide-index') : $(slideEl).index();\n swiper.lazy.loadInSlide(index);\n });\n } else if (slidesPerView > 1) {\n for (var i = activeIndex; i < activeIndex + slidesPerView; i += 1) {\n if (slideExist(i)) { swiper.lazy.loadInSlide(i); }\n }\n } else {\n swiper.lazy.loadInSlide(activeIndex);\n }\n if (params.loadPrevNext) {\n if (slidesPerView > 1 || (params.loadPrevNextAmount && params.loadPrevNextAmount > 1)) {\n var amount = params.loadPrevNextAmount;\n var spv = slidesPerView;\n var maxIndex = Math.min(activeIndex + spv + Math.max(amount, spv), slides.length);\n var minIndex = Math.max(activeIndex - Math.max(spv, amount), 0);\n // Next Slides\n for (var i$1 = activeIndex + slidesPerView; i$1 < maxIndex; i$1 += 1) {\n if (slideExist(i$1)) { swiper.lazy.loadInSlide(i$1); }\n }\n // Prev Slides\n for (var i$2 = minIndex; i$2 < activeIndex; i$2 += 1) {\n if (slideExist(i$2)) { swiper.lazy.loadInSlide(i$2); }\n }\n } else {\n var nextSlide = $wrapperEl.children((\".\" + (swiperParams.slideNextClass)));\n if (nextSlide.length > 0) { swiper.lazy.loadInSlide(slideIndex(nextSlide)); }\n\n var prevSlide = $wrapperEl.children((\".\" + (swiperParams.slidePrevClass)));\n if (prevSlide.length > 0) { swiper.lazy.loadInSlide(slideIndex(prevSlide)); }\n }\n }\n },\n };\n\n var Lazy$1 = {\n name: 'lazy',\n params: {\n lazy: {\n enabled: false,\n loadPrevNext: false,\n loadPrevNextAmount: 1,\n loadOnTransitionStart: false,\n\n elementClass: 'swiper-lazy',\n loadingClass: 'swiper-lazy-loading',\n loadedClass: 'swiper-lazy-loaded',\n preloaderClass: 'swiper-lazy-preloader',\n },\n },\n create: function create() {\n var swiper = this;\n Utils.extend(swiper, {\n lazy: {\n initialImageLoaded: false,\n load: Lazy.load.bind(swiper),\n loadInSlide: Lazy.loadInSlide.bind(swiper),\n },\n });\n },\n on: {\n beforeInit: function beforeInit() {\n var swiper = this;\n if (swiper.params.lazy.enabled && swiper.params.preloadImages) {\n swiper.params.preloadImages = false;\n }\n },\n init: function init() {\n var swiper = this;\n if (swiper.params.lazy.enabled && !swiper.params.loop && swiper.params.initialSlide === 0) {\n swiper.lazy.load();\n }\n },\n scroll: function scroll() {\n var swiper = this;\n if (swiper.params.freeMode && !swiper.params.freeModeSticky) {\n swiper.lazy.load();\n }\n },\n resize: function resize() {\n var swiper = this;\n if (swiper.params.lazy.enabled) {\n swiper.lazy.load();\n }\n },\n scrollbarDragMove: function scrollbarDragMove() {\n var swiper = this;\n if (swiper.params.lazy.enabled) {\n swiper.lazy.load();\n }\n },\n transitionStart: function transitionStart() {\n var swiper = this;\n if (swiper.params.lazy.enabled) {\n if (swiper.params.lazy.loadOnTransitionStart || (!swiper.params.lazy.loadOnTransitionStart && !swiper.lazy.initialImageLoaded)) {\n swiper.lazy.load();\n }\n }\n },\n transitionEnd: function transitionEnd() {\n var swiper = this;\n if (swiper.params.lazy.enabled && !swiper.params.lazy.loadOnTransitionStart) {\n swiper.lazy.load();\n }\n },\n },\n };\n\n /* eslint no-bitwise: [\"error\", { \"allow\": [\">>\"] }] */\n\n var Controller = {\n LinearSpline: function LinearSpline(x, y) {\n var binarySearch = (function search() {\n var maxIndex;\n var minIndex;\n var guess;\n return function (array, val) {\n minIndex = -1;\n maxIndex = array.length;\n while (maxIndex - minIndex > 1) {\n guess = maxIndex + minIndex >> 1;\n if (array[guess] <= val) {\n minIndex = guess;\n } else {\n maxIndex = guess;\n }\n }\n return maxIndex;\n };\n }());\n this.x = x;\n this.y = y;\n this.lastIndex = x.length - 1;\n // Given an x value (x2), return the expected y2 value:\n // (x1,y1) is the known point before given value,\n // (x3,y3) is the known point after given value.\n var i1;\n var i3;\n\n this.interpolate = function interpolate(x2) {\n if (!x2) { return 0; }\n\n // Get the indexes of x1 and x3 (the array indexes before and after given x2):\n i3 = binarySearch(this.x, x2);\n i1 = i3 - 1;\n\n // We have our indexes i1 & i3, so we can calculate already:\n // y2 := ((x2−x1) × (y3−y1)) ÷ (x3−x1) + y1\n return (((x2 - this.x[i1]) * (this.y[i3] - this.y[i1])) / (this.x[i3] - this.x[i1])) + this.y[i1];\n };\n return this;\n },\n // xxx: for now i will just save one spline function to to\n getInterpolateFunction: function getInterpolateFunction(c) {\n var swiper = this;\n if (!swiper.controller.spline) {\n swiper.controller.spline = swiper.params.loop\n ? new Controller.LinearSpline(swiper.slidesGrid, c.slidesGrid)\n : new Controller.LinearSpline(swiper.snapGrid, c.snapGrid);\n }\n },\n setTranslate: function setTranslate(setTranslate$1, byController) {\n var swiper = this;\n var controlled = swiper.controller.control;\n var multiplier;\n var controlledTranslate;\n function setControlledTranslate(c) {\n // this will create an Interpolate function based on the snapGrids\n // x is the Grid of the scrolled scroller and y will be the controlled scroller\n // it makes sense to create this only once and recall it for the interpolation\n // the function does a lot of value caching for performance\n var translate = swiper.rtlTranslate ? -swiper.translate : swiper.translate;\n if (swiper.params.controller.by === 'slide') {\n swiper.controller.getInterpolateFunction(c);\n // i am not sure why the values have to be multiplicated this way, tried to invert the snapGrid\n // but it did not work out\n controlledTranslate = -swiper.controller.spline.interpolate(-translate);\n }\n\n if (!controlledTranslate || swiper.params.controller.by === 'container') {\n multiplier = (c.maxTranslate() - c.minTranslate()) / (swiper.maxTranslate() - swiper.minTranslate());\n controlledTranslate = ((translate - swiper.minTranslate()) * multiplier) + c.minTranslate();\n }\n\n if (swiper.params.controller.inverse) {\n controlledTranslate = c.maxTranslate() - controlledTranslate;\n }\n c.updateProgress(controlledTranslate);\n c.setTranslate(controlledTranslate, swiper);\n c.updateActiveIndex();\n c.updateSlidesClasses();\n }\n if (Array.isArray(controlled)) {\n for (var i = 0; i < controlled.length; i += 1) {\n if (controlled[i] !== byController && controlled[i] instanceof Swiper) {\n setControlledTranslate(controlled[i]);\n }\n }\n } else if (controlled instanceof Swiper && byController !== controlled) {\n setControlledTranslate(controlled);\n }\n },\n setTransition: function setTransition(duration, byController) {\n var swiper = this;\n var controlled = swiper.controller.control;\n var i;\n function setControlledTransition(c) {\n c.setTransition(duration, swiper);\n if (duration !== 0) {\n c.transitionStart();\n if (c.params.autoHeight) {\n Utils.nextTick(function () {\n c.updateAutoHeight();\n });\n }\n c.$wrapperEl.transitionEnd(function () {\n if (!controlled) { return; }\n if (c.params.loop && swiper.params.controller.by === 'slide') {\n c.loopFix();\n }\n c.transitionEnd();\n });\n }\n }\n if (Array.isArray(controlled)) {\n for (i = 0; i < controlled.length; i += 1) {\n if (controlled[i] !== byController && controlled[i] instanceof Swiper) {\n setControlledTransition(controlled[i]);\n }\n }\n } else if (controlled instanceof Swiper && byController !== controlled) {\n setControlledTransition(controlled);\n }\n },\n };\n var Controller$1 = {\n name: 'controller',\n params: {\n controller: {\n control: undefined,\n inverse: false,\n by: 'slide', // or 'container'\n },\n },\n create: function create() {\n var swiper = this;\n Utils.extend(swiper, {\n controller: {\n control: swiper.params.controller.control,\n getInterpolateFunction: Controller.getInterpolateFunction.bind(swiper),\n setTranslate: Controller.setTranslate.bind(swiper),\n setTransition: Controller.setTransition.bind(swiper),\n },\n });\n },\n on: {\n update: function update() {\n var swiper = this;\n if (!swiper.controller.control) { return; }\n if (swiper.controller.spline) {\n swiper.controller.spline = undefined;\n delete swiper.controller.spline;\n }\n },\n resize: function resize() {\n var swiper = this;\n if (!swiper.controller.control) { return; }\n if (swiper.controller.spline) {\n swiper.controller.spline = undefined;\n delete swiper.controller.spline;\n }\n },\n observerUpdate: function observerUpdate() {\n var swiper = this;\n if (!swiper.controller.control) { return; }\n if (swiper.controller.spline) {\n swiper.controller.spline = undefined;\n delete swiper.controller.spline;\n }\n },\n setTranslate: function setTranslate(translate, byController) {\n var swiper = this;\n if (!swiper.controller.control) { return; }\n swiper.controller.setTranslate(translate, byController);\n },\n setTransition: function setTransition(duration, byController) {\n var swiper = this;\n if (!swiper.controller.control) { return; }\n swiper.controller.setTransition(duration, byController);\n },\n },\n };\n\n var a11y = {\n makeElFocusable: function makeElFocusable($el) {\n $el.attr('tabIndex', '0');\n return $el;\n },\n addElRole: function addElRole($el, role) {\n $el.attr('role', role);\n return $el;\n },\n addElLabel: function addElLabel($el, label) {\n $el.attr('aria-label', label);\n return $el;\n },\n disableEl: function disableEl($el) {\n $el.attr('aria-disabled', true);\n return $el;\n },\n enableEl: function enableEl($el) {\n $el.attr('aria-disabled', false);\n return $el;\n },\n onEnterKey: function onEnterKey(e) {\n var swiper = this;\n var params = swiper.params.a11y;\n if (e.keyCode !== 13) { return; }\n var $targetEl = $(e.target);\n if (swiper.navigation && swiper.navigation.$nextEl && $targetEl.is(swiper.navigation.$nextEl)) {\n if (!(swiper.isEnd && !swiper.params.loop)) {\n swiper.slideNext();\n }\n if (swiper.isEnd) {\n swiper.a11y.notify(params.lastSlideMessage);\n } else {\n swiper.a11y.notify(params.nextSlideMessage);\n }\n }\n if (swiper.navigation && swiper.navigation.$prevEl && $targetEl.is(swiper.navigation.$prevEl)) {\n if (!(swiper.isBeginning && !swiper.params.loop)) {\n swiper.slidePrev();\n }\n if (swiper.isBeginning) {\n swiper.a11y.notify(params.firstSlideMessage);\n } else {\n swiper.a11y.notify(params.prevSlideMessage);\n }\n }\n if (swiper.pagination && $targetEl.is((\".\" + (swiper.params.pagination.bulletClass)))) {\n $targetEl[0].click();\n }\n },\n notify: function notify(message) {\n var swiper = this;\n var notification = swiper.a11y.liveRegion;\n if (notification.length === 0) { return; }\n notification.html('');\n notification.html(message);\n },\n updateNavigation: function updateNavigation() {\n var swiper = this;\n\n if (swiper.params.loop) { return; }\n var ref = swiper.navigation;\n var $nextEl = ref.$nextEl;\n var $prevEl = ref.$prevEl;\n\n if ($prevEl && $prevEl.length > 0) {\n if (swiper.isBeginning) {\n swiper.a11y.disableEl($prevEl);\n } else {\n swiper.a11y.enableEl($prevEl);\n }\n }\n if ($nextEl && $nextEl.length > 0) {\n if (swiper.isEnd) {\n swiper.a11y.disableEl($nextEl);\n } else {\n swiper.a11y.enableEl($nextEl);\n }\n }\n },\n updatePagination: function updatePagination() {\n var swiper = this;\n var params = swiper.params.a11y;\n if (swiper.pagination && swiper.params.pagination.clickable && swiper.pagination.bullets && swiper.pagination.bullets.length) {\n swiper.pagination.bullets.each(function (bulletIndex, bulletEl) {\n var $bulletEl = $(bulletEl);\n swiper.a11y.makeElFocusable($bulletEl);\n swiper.a11y.addElRole($bulletEl, 'button');\n swiper.a11y.addElLabel($bulletEl, params.paginationBulletMessage.replace(/{{index}}/, $bulletEl.index() + 1));\n });\n }\n },\n init: function init() {\n var swiper = this;\n\n swiper.$el.append(swiper.a11y.liveRegion);\n\n // Navigation\n var params = swiper.params.a11y;\n var $nextEl;\n var $prevEl;\n if (swiper.navigation && swiper.navigation.$nextEl) {\n $nextEl = swiper.navigation.$nextEl;\n }\n if (swiper.navigation && swiper.navigation.$prevEl) {\n $prevEl = swiper.navigation.$prevEl;\n }\n if ($nextEl) {\n swiper.a11y.makeElFocusable($nextEl);\n swiper.a11y.addElRole($nextEl, 'button');\n swiper.a11y.addElLabel($nextEl, params.nextSlideMessage);\n $nextEl.on('keydown', swiper.a11y.onEnterKey);\n }\n if ($prevEl) {\n swiper.a11y.makeElFocusable($prevEl);\n swiper.a11y.addElRole($prevEl, 'button');\n swiper.a11y.addElLabel($prevEl, params.prevSlideMessage);\n $prevEl.on('keydown', swiper.a11y.onEnterKey);\n }\n\n // Pagination\n if (swiper.pagination && swiper.params.pagination.clickable && swiper.pagination.bullets && swiper.pagination.bullets.length) {\n swiper.pagination.$el.on('keydown', (\".\" + (swiper.params.pagination.bulletClass)), swiper.a11y.onEnterKey);\n }\n },\n destroy: function destroy() {\n var swiper = this;\n if (swiper.a11y.liveRegion && swiper.a11y.liveRegion.length > 0) { swiper.a11y.liveRegion.remove(); }\n\n var $nextEl;\n var $prevEl;\n if (swiper.navigation && swiper.navigation.$nextEl) {\n $nextEl = swiper.navigation.$nextEl;\n }\n if (swiper.navigation && swiper.navigation.$prevEl) {\n $prevEl = swiper.navigation.$prevEl;\n }\n if ($nextEl) {\n $nextEl.off('keydown', swiper.a11y.onEnterKey);\n }\n if ($prevEl) {\n $prevEl.off('keydown', swiper.a11y.onEnterKey);\n }\n\n // Pagination\n if (swiper.pagination && swiper.params.pagination.clickable && swiper.pagination.bullets && swiper.pagination.bullets.length) {\n swiper.pagination.$el.off('keydown', (\".\" + (swiper.params.pagination.bulletClass)), swiper.a11y.onEnterKey);\n }\n },\n };\n var A11y = {\n name: 'a11y',\n params: {\n a11y: {\n enabled: true,\n notificationClass: 'swiper-notification',\n prevSlideMessage: 'Previous slide',\n nextSlideMessage: 'Next slide',\n firstSlideMessage: 'This is the first slide',\n lastSlideMessage: 'This is the last slide',\n paginationBulletMessage: 'Go to slide {{index}}',\n },\n },\n create: function create() {\n var swiper = this;\n Utils.extend(swiper, {\n a11y: {\n liveRegion: $((\"<span class=\\\"\" + (swiper.params.a11y.notificationClass) + \"\\\" aria-live=\\\"assertive\\\" aria-atomic=\\\"true\\\"></span>\")),\n },\n });\n Object.keys(a11y).forEach(function (methodName) {\n swiper.a11y[methodName] = a11y[methodName].bind(swiper);\n });\n },\n on: {\n init: function init() {\n var swiper = this;\n if (!swiper.params.a11y.enabled) { return; }\n swiper.a11y.init();\n swiper.a11y.updateNavigation();\n },\n toEdge: function toEdge() {\n var swiper = this;\n if (!swiper.params.a11y.enabled) { return; }\n swiper.a11y.updateNavigation();\n },\n fromEdge: function fromEdge() {\n var swiper = this;\n if (!swiper.params.a11y.enabled) { return; }\n swiper.a11y.updateNavigation();\n },\n paginationUpdate: function paginationUpdate() {\n var swiper = this;\n if (!swiper.params.a11y.enabled) { return; }\n swiper.a11y.updatePagination();\n },\n destroy: function destroy() {\n var swiper = this;\n if (!swiper.params.a11y.enabled) { return; }\n swiper.a11y.destroy();\n },\n },\n };\n\n var History = {\n init: function init() {\n var swiper = this;\n if (!swiper.params.history) { return; }\n if (!win.history || !win.history.pushState) {\n swiper.params.history.enabled = false;\n swiper.params.hashNavigation.enabled = true;\n return;\n }\n var history = swiper.history;\n history.initialized = true;\n history.paths = History.getPathValues();\n if (!history.paths.key && !history.paths.value) { return; }\n history.scrollToSlide(0, history.paths.value, swiper.params.runCallbacksOnInit);\n if (!swiper.params.history.replaceState) {\n win.addEventListener('popstate', swiper.history.setHistoryPopState);\n }\n },\n destroy: function destroy() {\n var swiper = this;\n if (!swiper.params.history.replaceState) {\n win.removeEventListener('popstate', swiper.history.setHistoryPopState);\n }\n },\n setHistoryPopState: function setHistoryPopState() {\n var swiper = this;\n swiper.history.paths = History.getPathValues();\n swiper.history.scrollToSlide(swiper.params.speed, swiper.history.paths.value, false);\n },\n getPathValues: function getPathValues() {\n var pathArray = win.location.pathname.slice(1).split('/').filter(function (part) { return part !== ''; });\n var total = pathArray.length;\n var key = pathArray[total - 2];\n var value = pathArray[total - 1];\n return { key: key, value: value };\n },\n setHistory: function setHistory(key, index) {\n var swiper = this;\n if (!swiper.history.initialized || !swiper.params.history.enabled) { return; }\n var slide = swiper.slides.eq(index);\n var value = History.slugify(slide.attr('data-history'));\n if (!win.location.pathname.includes(key)) {\n value = key + \"/\" + value;\n }\n var currentState = win.history.state;\n if (currentState && currentState.value === value) {\n return;\n }\n if (swiper.params.history.replaceState) {\n win.history.replaceState({ value: value }, null, value);\n } else {\n win.history.pushState({ value: value }, null, value);\n }\n },\n slugify: function slugify(text) {\n return text.toString()\n .replace(/\\s+/g, '-')\n .replace(/[^\\w-]+/g, '')\n .replace(/--+/g, '-')\n .replace(/^-+/, '')\n .replace(/-+$/, '');\n },\n scrollToSlide: function scrollToSlide(speed, value, runCallbacks) {\n var swiper = this;\n if (value) {\n for (var i = 0, length = swiper.slides.length; i < length; i += 1) {\n var slide = swiper.slides.eq(i);\n var slideHistory = History.slugify(slide.attr('data-history'));\n if (slideHistory === value && !slide.hasClass(swiper.params.slideDuplicateClass)) {\n var index = slide.index();\n swiper.slideTo(index, speed, runCallbacks);\n }\n }\n } else {\n swiper.slideTo(0, speed, runCallbacks);\n }\n },\n };\n\n var History$1 = {\n name: 'history',\n params: {\n history: {\n enabled: false,\n replaceState: false,\n key: 'slides',\n },\n },\n create: function create() {\n var swiper = this;\n Utils.extend(swiper, {\n history: {\n init: History.init.bind(swiper),\n setHistory: History.setHistory.bind(swiper),\n setHistoryPopState: History.setHistoryPopState.bind(swiper),\n scrollToSlide: History.scrollToSlide.bind(swiper),\n destroy: History.destroy.bind(swiper),\n },\n });\n },\n on: {\n init: function init() {\n var swiper = this;\n if (swiper.params.history.enabled) {\n swiper.history.init();\n }\n },\n destroy: function destroy() {\n var swiper = this;\n if (swiper.params.history.enabled) {\n swiper.history.destroy();\n }\n },\n transitionEnd: function transitionEnd() {\n var swiper = this;\n if (swiper.history.initialized) {\n swiper.history.setHistory(swiper.params.history.key, swiper.activeIndex);\n }\n },\n },\n };\n\n var HashNavigation = {\n onHashCange: function onHashCange() {\n var swiper = this;\n var newHash = doc.location.hash.replace('#', '');\n var activeSlideHash = swiper.slides.eq(swiper.activeIndex).attr('data-hash');\n if (newHash !== activeSlideHash) {\n var newIndex = swiper.$wrapperEl.children((\".\" + (swiper.params.slideClass) + \"[data-hash=\\\"\" + newHash + \"\\\"]\")).index();\n if (typeof newIndex === 'undefined') { return; }\n swiper.slideTo(newIndex);\n }\n },\n setHash: function setHash() {\n var swiper = this;\n if (!swiper.hashNavigation.initialized || !swiper.params.hashNavigation.enabled) { return; }\n if (swiper.params.hashNavigation.replaceState && win.history && win.history.replaceState) {\n win.history.replaceState(null, null, ((\"#\" + (swiper.slides.eq(swiper.activeIndex).attr('data-hash'))) || ''));\n } else {\n var slide = swiper.slides.eq(swiper.activeIndex);\n var hash = slide.attr('data-hash') || slide.attr('data-history');\n doc.location.hash = hash || '';\n }\n },\n init: function init() {\n var swiper = this;\n if (!swiper.params.hashNavigation.enabled || (swiper.params.history && swiper.params.history.enabled)) { return; }\n swiper.hashNavigation.initialized = true;\n var hash = doc.location.hash.replace('#', '');\n if (hash) {\n var speed = 0;\n for (var i = 0, length = swiper.slides.length; i < length; i += 1) {\n var slide = swiper.slides.eq(i);\n var slideHash = slide.attr('data-hash') || slide.attr('data-history');\n if (slideHash === hash && !slide.hasClass(swiper.params.slideDuplicateClass)) {\n var index = slide.index();\n swiper.slideTo(index, speed, swiper.params.runCallbacksOnInit, true);\n }\n }\n }\n if (swiper.params.hashNavigation.watchState) {\n $(win).on('hashchange', swiper.hashNavigation.onHashCange);\n }\n },\n destroy: function destroy() {\n var swiper = this;\n if (swiper.params.hashNavigation.watchState) {\n $(win).off('hashchange', swiper.hashNavigation.onHashCange);\n }\n },\n };\n var HashNavigation$1 = {\n name: 'hash-navigation',\n params: {\n hashNavigation: {\n enabled: false,\n replaceState: false,\n watchState: false,\n },\n },\n create: function create() {\n var swiper = this;\n Utils.extend(swiper, {\n hashNavigation: {\n initialized: false,\n init: HashNavigation.init.bind(swiper),\n destroy: HashNavigation.destroy.bind(swiper),\n setHash: HashNavigation.setHash.bind(swiper),\n onHashCange: HashNavigation.onHashCange.bind(swiper),\n },\n });\n },\n on: {\n init: function init() {\n var swiper = this;\n if (swiper.params.hashNavigation.enabled) {\n swiper.hashNavigation.init();\n }\n },\n destroy: function destroy() {\n var swiper = this;\n if (swiper.params.hashNavigation.enabled) {\n swiper.hashNavigation.destroy();\n }\n },\n transitionEnd: function transitionEnd() {\n var swiper = this;\n if (swiper.hashNavigation.initialized) {\n swiper.hashNavigation.setHash();\n }\n },\n },\n };\n\n /* eslint no-underscore-dangle: \"off\" */\n\n var Autoplay = {\n run: function run() {\n var swiper = this;\n var $activeSlideEl = swiper.slides.eq(swiper.activeIndex);\n var delay = swiper.params.autoplay.delay;\n if ($activeSlideEl.attr('data-swiper-autoplay')) {\n delay = $activeSlideEl.attr('data-swiper-autoplay') || swiper.params.autoplay.delay;\n }\n clearTimeout(swiper.autoplay.timeout);\n swiper.autoplay.timeout = Utils.nextTick(function () {\n if (swiper.params.autoplay.reverseDirection) {\n if (swiper.params.loop) {\n swiper.loopFix();\n swiper.slidePrev(swiper.params.speed, true, true);\n swiper.emit('autoplay');\n } else if (!swiper.isBeginning) {\n swiper.slidePrev(swiper.params.speed, true, true);\n swiper.emit('autoplay');\n } else if (!swiper.params.autoplay.stopOnLastSlide) {\n swiper.slideTo(swiper.slides.length - 1, swiper.params.speed, true, true);\n swiper.emit('autoplay');\n } else {\n swiper.autoplay.stop();\n }\n } else if (swiper.params.loop) {\n swiper.loopFix();\n swiper.slideNext(swiper.params.speed, true, true);\n swiper.emit('autoplay');\n } else if (!swiper.isEnd) {\n swiper.slideNext(swiper.params.speed, true, true);\n swiper.emit('autoplay');\n } else if (!swiper.params.autoplay.stopOnLastSlide) {\n swiper.slideTo(0, swiper.params.speed, true, true);\n swiper.emit('autoplay');\n } else {\n swiper.autoplay.stop();\n }\n }, delay);\n },\n start: function start() {\n var swiper = this;\n if (typeof swiper.autoplay.timeout !== 'undefined') { return false; }\n if (swiper.autoplay.running) { return false; }\n swiper.autoplay.running = true;\n swiper.emit('autoplayStart');\n swiper.autoplay.run();\n return true;\n },\n stop: function stop() {\n var swiper = this;\n if (!swiper.autoplay.running) { return false; }\n if (typeof swiper.autoplay.timeout === 'undefined') { return false; }\n\n if (swiper.autoplay.timeout) {\n clearTimeout(swiper.autoplay.timeout);\n swiper.autoplay.timeout = undefined;\n }\n swiper.autoplay.running = false;\n swiper.emit('autoplayStop');\n return true;\n },\n pause: function pause(speed) {\n var swiper = this;\n if (!swiper.autoplay.running) { return; }\n if (swiper.autoplay.paused) { return; }\n if (swiper.autoplay.timeout) { clearTimeout(swiper.autoplay.timeout); }\n swiper.autoplay.paused = true;\n if (speed === 0 || !swiper.params.autoplay.waitForTransition) {\n swiper.autoplay.paused = false;\n swiper.autoplay.run();\n } else {\n swiper.$wrapperEl[0].addEventListener('transitionend', swiper.autoplay.onTransitionEnd);\n swiper.$wrapperEl[0].addEventListener('webkitTransitionEnd', swiper.autoplay.onTransitionEnd);\n }\n },\n };\n\n var Autoplay$1 = {\n name: 'autoplay',\n params: {\n autoplay: {\n enabled: false,\n delay: 3000,\n waitForTransition: true,\n disableOnInteraction: true,\n stopOnLastSlide: false,\n reverseDirection: false,\n },\n },\n create: function create() {\n var swiper = this;\n Utils.extend(swiper, {\n autoplay: {\n running: false,\n paused: false,\n run: Autoplay.run.bind(swiper),\n start: Autoplay.start.bind(swiper),\n stop: Autoplay.stop.bind(swiper),\n pause: Autoplay.pause.bind(swiper),\n onTransitionEnd: function onTransitionEnd(e) {\n if (!swiper || swiper.destroyed || !swiper.$wrapperEl) { return; }\n if (e.target !== this) { return; }\n swiper.$wrapperEl[0].removeEventListener('transitionend', swiper.autoplay.onTransitionEnd);\n swiper.$wrapperEl[0].removeEventListener('webkitTransitionEnd', swiper.autoplay.onTransitionEnd);\n swiper.autoplay.paused = false;\n if (!swiper.autoplay.running) {\n swiper.autoplay.stop();\n } else {\n swiper.autoplay.run();\n }\n },\n },\n });\n },\n on: {\n init: function init() {\n var swiper = this;\n if (swiper.params.autoplay.enabled) {\n swiper.autoplay.start();\n }\n },\n beforeTransitionStart: function beforeTransitionStart(speed, internal) {\n var swiper = this;\n if (swiper.autoplay.running) {\n if (internal || !swiper.params.autoplay.disableOnInteraction) {\n swiper.autoplay.pause(speed);\n } else {\n swiper.autoplay.stop();\n }\n }\n },\n sliderFirstMove: function sliderFirstMove() {\n var swiper = this;\n if (swiper.autoplay.running) {\n if (swiper.params.autoplay.disableOnInteraction) {\n swiper.autoplay.stop();\n } else {\n swiper.autoplay.pause();\n }\n }\n },\n destroy: function destroy() {\n var swiper = this;\n if (swiper.autoplay.running) {\n swiper.autoplay.stop();\n }\n },\n },\n };\n\n var Fade = {\n setTranslate: function setTranslate() {\n var swiper = this;\n var slides = swiper.slides;\n for (var i = 0; i < slides.length; i += 1) {\n var $slideEl = swiper.slides.eq(i);\n var offset = $slideEl[0].swiperSlideOffset;\n var tx = -offset;\n if (!swiper.params.virtualTranslate) { tx -= swiper.translate; }\n var ty = 0;\n if (!swiper.isHorizontal()) {\n ty = tx;\n tx = 0;\n }\n var slideOpacity = swiper.params.fadeEffect.crossFade\n ? Math.max(1 - Math.abs($slideEl[0].progress), 0)\n : 1 + Math.min(Math.max($slideEl[0].progress, -1), 0);\n $slideEl\n .css({\n opacity: slideOpacity,\n })\n .transform((\"translate3d(\" + tx + \"px, \" + ty + \"px, 0px)\"));\n }\n },\n setTransition: function setTransition(duration) {\n var swiper = this;\n var slides = swiper.slides;\n var $wrapperEl = swiper.$wrapperEl;\n slides.transition(duration);\n if (swiper.params.virtualTranslate && duration !== 0) {\n var eventTriggered = false;\n slides.transitionEnd(function () {\n if (eventTriggered) { return; }\n if (!swiper || swiper.destroyed) { return; }\n eventTriggered = true;\n swiper.animating = false;\n var triggerEvents = ['webkitTransitionEnd', 'transitionend'];\n for (var i = 0; i < triggerEvents.length; i += 1) {\n $wrapperEl.trigger(triggerEvents[i]);\n }\n });\n }\n },\n };\n\n var EffectFade = {\n name: 'effect-fade',\n params: {\n fadeEffect: {\n crossFade: false,\n },\n },\n create: function create() {\n var swiper = this;\n Utils.extend(swiper, {\n fadeEffect: {\n setTranslate: Fade.setTranslate.bind(swiper),\n setTransition: Fade.setTransition.bind(swiper),\n },\n });\n },\n on: {\n beforeInit: function beforeInit() {\n var swiper = this;\n if (swiper.params.effect !== 'fade') { return; }\n swiper.classNames.push(((swiper.params.containerModifierClass) + \"fade\"));\n var overwriteParams = {\n slidesPerView: 1,\n slidesPerColumn: 1,\n slidesPerGroup: 1,\n watchSlidesProgress: true,\n spaceBetween: 0,\n virtualTranslate: true,\n };\n Utils.extend(swiper.params, overwriteParams);\n Utils.extend(swiper.originalParams, overwriteParams);\n },\n setTranslate: function setTranslate() {\n var swiper = this;\n if (swiper.params.effect !== 'fade') { return; }\n swiper.fadeEffect.setTranslate();\n },\n setTransition: function setTransition(duration) {\n var swiper = this;\n if (swiper.params.effect !== 'fade') { return; }\n swiper.fadeEffect.setTransition(duration);\n },\n },\n };\n\n var Cube = {\n setTranslate: function setTranslate() {\n var swiper = this;\n var $el = swiper.$el;\n var $wrapperEl = swiper.$wrapperEl;\n var slides = swiper.slides;\n var swiperWidth = swiper.width;\n var swiperHeight = swiper.height;\n var rtl = swiper.rtlTranslate;\n var swiperSize = swiper.size;\n var params = swiper.params.cubeEffect;\n var isHorizontal = swiper.isHorizontal();\n var isVirtual = swiper.virtual && swiper.params.virtual.enabled;\n var wrapperRotate = 0;\n var $cubeShadowEl;\n if (params.shadow) {\n if (isHorizontal) {\n $cubeShadowEl = $wrapperEl.find('.swiper-cube-shadow');\n if ($cubeShadowEl.length === 0) {\n $cubeShadowEl = $('<div class=\"swiper-cube-shadow\"></div>');\n $wrapperEl.append($cubeShadowEl);\n }\n $cubeShadowEl.css({ height: (swiperWidth + \"px\") });\n } else {\n $cubeShadowEl = $el.find('.swiper-cube-shadow');\n if ($cubeShadowEl.length === 0) {\n $cubeShadowEl = $('<div class=\"swiper-cube-shadow\"></div>');\n $el.append($cubeShadowEl);\n }\n }\n }\n for (var i = 0; i < slides.length; i += 1) {\n var $slideEl = slides.eq(i);\n var slideIndex = i;\n if (isVirtual) {\n slideIndex = parseInt($slideEl.attr('data-swiper-slide-index'), 10);\n }\n var slideAngle = slideIndex * 90;\n var round = Math.floor(slideAngle / 360);\n if (rtl) {\n slideAngle = -slideAngle;\n round = Math.floor(-slideAngle / 360);\n }\n var progress = Math.max(Math.min($slideEl[0].progress, 1), -1);\n var tx = 0;\n var ty = 0;\n var tz = 0;\n if (slideIndex % 4 === 0) {\n tx = -round * 4 * swiperSize;\n tz = 0;\n } else if ((slideIndex - 1) % 4 === 0) {\n tx = 0;\n tz = -round * 4 * swiperSize;\n } else if ((slideIndex - 2) % 4 === 0) {\n tx = swiperSize + (round * 4 * swiperSize);\n tz = swiperSize;\n } else if ((slideIndex - 3) % 4 === 0) {\n tx = -swiperSize;\n tz = (3 * swiperSize) + (swiperSize * 4 * round);\n }\n if (rtl) {\n tx = -tx;\n }\n\n if (!isHorizontal) {\n ty = tx;\n tx = 0;\n }\n\n var transform = \"rotateX(\" + (isHorizontal ? 0 : -slideAngle) + \"deg) rotateY(\" + (isHorizontal ? slideAngle : 0) + \"deg) translate3d(\" + tx + \"px, \" + ty + \"px, \" + tz + \"px)\";\n if (progress <= 1 && progress > -1) {\n wrapperRotate = (slideIndex * 90) + (progress * 90);\n if (rtl) { wrapperRotate = (-slideIndex * 90) - (progress * 90); }\n }\n $slideEl.transform(transform);\n if (params.slideShadows) {\n // Set shadows\n var shadowBefore = isHorizontal ? $slideEl.find('.swiper-slide-shadow-left') : $slideEl.find('.swiper-slide-shadow-top');\n var shadowAfter = isHorizontal ? $slideEl.find('.swiper-slide-shadow-right') : $slideEl.find('.swiper-slide-shadow-bottom');\n if (shadowBefore.length === 0) {\n shadowBefore = $((\"<div class=\\\"swiper-slide-shadow-\" + (isHorizontal ? 'left' : 'top') + \"\\\"></div>\"));\n $slideEl.append(shadowBefore);\n }\n if (shadowAfter.length === 0) {\n shadowAfter = $((\"<div class=\\\"swiper-slide-shadow-\" + (isHorizontal ? 'right' : 'bottom') + \"\\\"></div>\"));\n $slideEl.append(shadowAfter);\n }\n if (shadowBefore.length) { shadowBefore[0].style.opacity = Math.max(-progress, 0); }\n if (shadowAfter.length) { shadowAfter[0].style.opacity = Math.max(progress, 0); }\n }\n }\n $wrapperEl.css({\n '-webkit-transform-origin': (\"50% 50% -\" + (swiperSize / 2) + \"px\"),\n '-moz-transform-origin': (\"50% 50% -\" + (swiperSize / 2) + \"px\"),\n '-ms-transform-origin': (\"50% 50% -\" + (swiperSize / 2) + \"px\"),\n 'transform-origin': (\"50% 50% -\" + (swiperSize / 2) + \"px\"),\n });\n\n if (params.shadow) {\n if (isHorizontal) {\n $cubeShadowEl.transform((\"translate3d(0px, \" + ((swiperWidth / 2) + params.shadowOffset) + \"px, \" + (-swiperWidth / 2) + \"px) rotateX(90deg) rotateZ(0deg) scale(\" + (params.shadowScale) + \")\"));\n } else {\n var shadowAngle = Math.abs(wrapperRotate) - (Math.floor(Math.abs(wrapperRotate) / 90) * 90);\n var multiplier = 1.5 - (\n (Math.sin((shadowAngle * 2 * Math.PI) / 360) / 2)\n + (Math.cos((shadowAngle * 2 * Math.PI) / 360) / 2)\n );\n var scale1 = params.shadowScale;\n var scale2 = params.shadowScale / multiplier;\n var offset = params.shadowOffset;\n $cubeShadowEl.transform((\"scale3d(\" + scale1 + \", 1, \" + scale2 + \") translate3d(0px, \" + ((swiperHeight / 2) + offset) + \"px, \" + (-swiperHeight / 2 / scale2) + \"px) rotateX(-90deg)\"));\n }\n }\n var zFactor = (Browser.isSafari || Browser.isUiWebView) ? (-swiperSize / 2) : 0;\n $wrapperEl\n .transform((\"translate3d(0px,0,\" + zFactor + \"px) rotateX(\" + (swiper.isHorizontal() ? 0 : wrapperRotate) + \"deg) rotateY(\" + (swiper.isHorizontal() ? -wrapperRotate : 0) + \"deg)\"));\n },\n setTransition: function setTransition(duration) {\n var swiper = this;\n var $el = swiper.$el;\n var slides = swiper.slides;\n slides\n .transition(duration)\n .find('.swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left')\n .transition(duration);\n if (swiper.params.cubeEffect.shadow && !swiper.isHorizontal()) {\n $el.find('.swiper-cube-shadow').transition(duration);\n }\n },\n };\n\n var EffectCube = {\n name: 'effect-cube',\n params: {\n cubeEffect: {\n slideShadows: true,\n shadow: true,\n shadowOffset: 20,\n shadowScale: 0.94,\n },\n },\n create: function create() {\n var swiper = this;\n Utils.extend(swiper, {\n cubeEffect: {\n setTranslate: Cube.setTranslate.bind(swiper),\n setTransition: Cube.setTransition.bind(swiper),\n },\n });\n },\n on: {\n beforeInit: function beforeInit() {\n var swiper = this;\n if (swiper.params.effect !== 'cube') { return; }\n swiper.classNames.push(((swiper.params.containerModifierClass) + \"cube\"));\n swiper.classNames.push(((swiper.params.containerModifierClass) + \"3d\"));\n var overwriteParams = {\n slidesPerView: 1,\n slidesPerColumn: 1,\n slidesPerGroup: 1,\n watchSlidesProgress: true,\n resistanceRatio: 0,\n spaceBetween: 0,\n centeredSlides: false,\n virtualTranslate: true,\n };\n Utils.extend(swiper.params, overwriteParams);\n Utils.extend(swiper.originalParams, overwriteParams);\n },\n setTranslate: function setTranslate() {\n var swiper = this;\n if (swiper.params.effect !== 'cube') { return; }\n swiper.cubeEffect.setTranslate();\n },\n setTransition: function setTransition(duration) {\n var swiper = this;\n if (swiper.params.effect !== 'cube') { return; }\n swiper.cubeEffect.setTransition(duration);\n },\n },\n };\n\n var Flip = {\n setTranslate: function setTranslate() {\n var swiper = this;\n var slides = swiper.slides;\n var rtl = swiper.rtlTranslate;\n for (var i = 0; i < slides.length; i += 1) {\n var $slideEl = slides.eq(i);\n var progress = $slideEl[0].progress;\n if (swiper.params.flipEffect.limitRotation) {\n progress = Math.max(Math.min($slideEl[0].progress, 1), -1);\n }\n var offset = $slideEl[0].swiperSlideOffset;\n var rotate = -180 * progress;\n var rotateY = rotate;\n var rotateX = 0;\n var tx = -offset;\n var ty = 0;\n if (!swiper.isHorizontal()) {\n ty = tx;\n tx = 0;\n rotateX = -rotateY;\n rotateY = 0;\n } else if (rtl) {\n rotateY = -rotateY;\n }\n\n $slideEl[0].style.zIndex = -Math.abs(Math.round(progress)) + slides.length;\n\n if (swiper.params.flipEffect.slideShadows) {\n // Set shadows\n var shadowBefore = swiper.isHorizontal() ? $slideEl.find('.swiper-slide-shadow-left') : $slideEl.find('.swiper-slide-shadow-top');\n var shadowAfter = swiper.isHorizontal() ? $slideEl.find('.swiper-slide-shadow-right') : $slideEl.find('.swiper-slide-shadow-bottom');\n if (shadowBefore.length === 0) {\n shadowBefore = $((\"<div class=\\\"swiper-slide-shadow-\" + (swiper.isHorizontal() ? 'left' : 'top') + \"\\\"></div>\"));\n $slideEl.append(shadowBefore);\n }\n if (shadowAfter.length === 0) {\n shadowAfter = $((\"<div class=\\\"swiper-slide-shadow-\" + (swiper.isHorizontal() ? 'right' : 'bottom') + \"\\\"></div>\"));\n $slideEl.append(shadowAfter);\n }\n if (shadowBefore.length) { shadowBefore[0].style.opacity = Math.max(-progress, 0); }\n if (shadowAfter.length) { shadowAfter[0].style.opacity = Math.max(progress, 0); }\n }\n $slideEl\n .transform((\"translate3d(\" + tx + \"px, \" + ty + \"px, 0px) rotateX(\" + rotateX + \"deg) rotateY(\" + rotateY + \"deg)\"));\n }\n },\n setTransition: function setTransition(duration) {\n var swiper = this;\n var slides = swiper.slides;\n var activeIndex = swiper.activeIndex;\n var $wrapperEl = swiper.$wrapperEl;\n slides\n .transition(duration)\n .find('.swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left')\n .transition(duration);\n if (swiper.params.virtualTranslate && duration !== 0) {\n var eventTriggered = false;\n // eslint-disable-next-line\n slides.eq(activeIndex).transitionEnd(function onTransitionEnd() {\n if (eventTriggered) { return; }\n if (!swiper || swiper.destroyed) { return; }\n // if (!$(this).hasClass(swiper.params.slideActiveClass)) return;\n eventTriggered = true;\n swiper.animating = false;\n var triggerEvents = ['webkitTransitionEnd', 'transitionend'];\n for (var i = 0; i < triggerEvents.length; i += 1) {\n $wrapperEl.trigger(triggerEvents[i]);\n }\n });\n }\n },\n };\n\n var EffectFlip = {\n name: 'effect-flip',\n params: {\n flipEffect: {\n slideShadows: true,\n limitRotation: true,\n },\n },\n create: function create() {\n var swiper = this;\n Utils.extend(swiper, {\n flipEffect: {\n setTranslate: Flip.setTranslate.bind(swiper),\n setTransition: Flip.setTransition.bind(swiper),\n },\n });\n },\n on: {\n beforeInit: function beforeInit() {\n var swiper = this;\n if (swiper.params.effect !== 'flip') { return; }\n swiper.classNames.push(((swiper.params.containerModifierClass) + \"flip\"));\n swiper.classNames.push(((swiper.params.containerModifierClass) + \"3d\"));\n var overwriteParams = {\n slidesPerView: 1,\n slidesPerColumn: 1,\n slidesPerGroup: 1,\n watchSlidesProgress: true,\n spaceBetween: 0,\n virtualTranslate: true,\n };\n Utils.extend(swiper.params, overwriteParams);\n Utils.extend(swiper.originalParams, overwriteParams);\n },\n setTranslate: function setTranslate() {\n var swiper = this;\n if (swiper.params.effect !== 'flip') { return; }\n swiper.flipEffect.setTranslate();\n },\n setTransition: function setTransition(duration) {\n var swiper = this;\n if (swiper.params.effect !== 'flip') { return; }\n swiper.flipEffect.setTransition(duration);\n },\n },\n };\n\n var Coverflow = {\n setTranslate: function setTranslate() {\n var swiper = this;\n var swiperWidth = swiper.width;\n var swiperHeight = swiper.height;\n var slides = swiper.slides;\n var $wrapperEl = swiper.$wrapperEl;\n var slidesSizesGrid = swiper.slidesSizesGrid;\n var params = swiper.params.coverflowEffect;\n var isHorizontal = swiper.isHorizontal();\n var transform = swiper.translate;\n var center = isHorizontal ? -transform + (swiperWidth / 2) : -transform + (swiperHeight / 2);\n var rotate = isHorizontal ? params.rotate : -params.rotate;\n var translate = params.depth;\n // Each slide offset from center\n for (var i = 0, length = slides.length; i < length; i += 1) {\n var $slideEl = slides.eq(i);\n var slideSize = slidesSizesGrid[i];\n var slideOffset = $slideEl[0].swiperSlideOffset;\n var offsetMultiplier = ((center - slideOffset - (slideSize / 2)) / slideSize) * params.modifier;\n\n var rotateY = isHorizontal ? rotate * offsetMultiplier : 0;\n var rotateX = isHorizontal ? 0 : rotate * offsetMultiplier;\n // var rotateZ = 0\n var translateZ = -translate * Math.abs(offsetMultiplier);\n\n var translateY = isHorizontal ? 0 : params.stretch * (offsetMultiplier);\n var translateX = isHorizontal ? params.stretch * (offsetMultiplier) : 0;\n\n // Fix for ultra small values\n if (Math.abs(translateX) < 0.001) { translateX = 0; }\n if (Math.abs(translateY) < 0.001) { translateY = 0; }\n if (Math.abs(translateZ) < 0.001) { translateZ = 0; }\n if (Math.abs(rotateY) < 0.001) { rotateY = 0; }\n if (Math.abs(rotateX) < 0.001) { rotateX = 0; }\n\n var slideTransform = \"translate3d(\" + translateX + \"px,\" + translateY + \"px,\" + translateZ + \"px) rotateX(\" + rotateX + \"deg) rotateY(\" + rotateY + \"deg)\";\n\n $slideEl.transform(slideTransform);\n $slideEl[0].style.zIndex = -Math.abs(Math.round(offsetMultiplier)) + 1;\n if (params.slideShadows) {\n // Set shadows\n var $shadowBeforeEl = isHorizontal ? $slideEl.find('.swiper-slide-shadow-left') : $slideEl.find('.swiper-slide-shadow-top');\n var $shadowAfterEl = isHorizontal ? $slideEl.find('.swiper-slide-shadow-right') : $slideEl.find('.swiper-slide-shadow-bottom');\n if ($shadowBeforeEl.length === 0) {\n $shadowBeforeEl = $((\"<div class=\\\"swiper-slide-shadow-\" + (isHorizontal ? 'left' : 'top') + \"\\\"></div>\"));\n $slideEl.append($shadowBeforeEl);\n }\n if ($shadowAfterEl.length === 0) {\n $shadowAfterEl = $((\"<div class=\\\"swiper-slide-shadow-\" + (isHorizontal ? 'right' : 'bottom') + \"\\\"></div>\"));\n $slideEl.append($shadowAfterEl);\n }\n if ($shadowBeforeEl.length) { $shadowBeforeEl[0].style.opacity = offsetMultiplier > 0 ? offsetMultiplier : 0; }\n if ($shadowAfterEl.length) { $shadowAfterEl[0].style.opacity = (-offsetMultiplier) > 0 ? -offsetMultiplier : 0; }\n }\n }\n\n // Set correct perspective for IE10\n if (Support.pointerEvents || Support.prefixedPointerEvents) {\n var ws = $wrapperEl[0].style;\n ws.perspectiveOrigin = center + \"px 50%\";\n }\n },\n setTransition: function setTransition(duration) {\n var swiper = this;\n swiper.slides\n .transition(duration)\n .find('.swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left')\n .transition(duration);\n },\n };\n\n var EffectCoverflow = {\n name: 'effect-coverflow',\n params: {\n coverflowEffect: {\n rotate: 50,\n stretch: 0,\n depth: 100,\n modifier: 1,\n slideShadows: true,\n },\n },\n create: function create() {\n var swiper = this;\n Utils.extend(swiper, {\n coverflowEffect: {\n setTranslate: Coverflow.setTranslate.bind(swiper),\n setTransition: Coverflow.setTransition.bind(swiper),\n },\n });\n },\n on: {\n beforeInit: function beforeInit() {\n var swiper = this;\n if (swiper.params.effect !== 'coverflow') { return; }\n\n swiper.classNames.push(((swiper.params.containerModifierClass) + \"coverflow\"));\n swiper.classNames.push(((swiper.params.containerModifierClass) + \"3d\"));\n\n swiper.params.watchSlidesProgress = true;\n swiper.originalParams.watchSlidesProgress = true;\n },\n setTranslate: function setTranslate() {\n var swiper = this;\n if (swiper.params.effect !== 'coverflow') { return; }\n swiper.coverflowEffect.setTranslate();\n },\n setTransition: function setTransition(duration) {\n var swiper = this;\n if (swiper.params.effect !== 'coverflow') { return; }\n swiper.coverflowEffect.setTransition(duration);\n },\n },\n };\n\n var Thumbs = {\n init: function init() {\n var swiper = this;\n var ref = swiper.params;\n var thumbsParams = ref.thumbs;\n var SwiperClass = swiper.constructor;\n if (thumbsParams.swiper instanceof SwiperClass) {\n swiper.thumbs.swiper = thumbsParams.swiper;\n Utils.extend(swiper.thumbs.swiper.originalParams, {\n watchSlidesProgress: true,\n slideToClickedSlide: false,\n });\n Utils.extend(swiper.thumbs.swiper.params, {\n watchSlidesProgress: true,\n slideToClickedSlide: false,\n });\n } else if (Utils.isObject(thumbsParams.swiper)) {\n swiper.thumbs.swiper = new SwiperClass(Utils.extend({}, thumbsParams.swiper, {\n watchSlidesVisibility: true,\n watchSlidesProgress: true,\n slideToClickedSlide: false,\n }));\n swiper.thumbs.swiperCreated = true;\n }\n swiper.thumbs.swiper.$el.addClass(swiper.params.thumbs.thumbsContainerClass);\n swiper.thumbs.swiper.on('tap', swiper.thumbs.onThumbClick);\n },\n onThumbClick: function onThumbClick() {\n var swiper = this;\n var thumbsSwiper = swiper.thumbs.swiper;\n if (!thumbsSwiper) { return; }\n var clickedIndex = thumbsSwiper.clickedIndex;\n var clickedSlide = thumbsSwiper.clickedSlide;\n if (clickedSlide && $(clickedSlide).hasClass(swiper.params.thumbs.slideThumbActiveClass)) { return; }\n if (typeof clickedIndex === 'undefined' || clickedIndex === null) { return; }\n var slideToIndex;\n if (thumbsSwiper.params.loop) {\n slideToIndex = parseInt($(thumbsSwiper.clickedSlide).attr('data-swiper-slide-index'), 10);\n } else {\n slideToIndex = clickedIndex;\n }\n if (swiper.params.loop) {\n var currentIndex = swiper.activeIndex;\n if (swiper.slides.eq(currentIndex).hasClass(swiper.params.slideDuplicateClass)) {\n swiper.loopFix();\n // eslint-disable-next-line\n swiper._clientLeft = swiper.$wrapperEl[0].clientLeft;\n currentIndex = swiper.activeIndex;\n }\n var prevIndex = swiper.slides.eq(currentIndex).prevAll((\"[data-swiper-slide-index=\\\"\" + slideToIndex + \"\\\"]\")).eq(0).index();\n var nextIndex = swiper.slides.eq(currentIndex).nextAll((\"[data-swiper-slide-index=\\\"\" + slideToIndex + \"\\\"]\")).eq(0).index();\n if (typeof prevIndex === 'undefined') { slideToIndex = nextIndex; }\n else if (typeof nextIndex === 'undefined') { slideToIndex = prevIndex; }\n else if (nextIndex - currentIndex < currentIndex - prevIndex) { slideToIndex = nextIndex; }\n else { slideToIndex = prevIndex; }\n }\n swiper.slideTo(slideToIndex);\n },\n update: function update(initial) {\n var swiper = this;\n var thumbsSwiper = swiper.thumbs.swiper;\n if (!thumbsSwiper) { return; }\n\n var slidesPerView = thumbsSwiper.params.slidesPerView === 'auto'\n ? thumbsSwiper.slidesPerViewDynamic()\n : thumbsSwiper.params.slidesPerView;\n\n if (swiper.realIndex !== thumbsSwiper.realIndex) {\n var currentThumbsIndex = thumbsSwiper.activeIndex;\n var newThumbsIndex;\n if (thumbsSwiper.params.loop) {\n if (thumbsSwiper.slides.eq(currentThumbsIndex).hasClass(thumbsSwiper.params.slideDuplicateClass)) {\n thumbsSwiper.loopFix();\n // eslint-disable-next-line\n thumbsSwiper._clientLeft = thumbsSwiper.$wrapperEl[0].clientLeft;\n currentThumbsIndex = thumbsSwiper.activeIndex;\n }\n // Find actual thumbs index to slide to\n var prevThumbsIndex = thumbsSwiper.slides.eq(currentThumbsIndex).prevAll((\"[data-swiper-slide-index=\\\"\" + (swiper.realIndex) + \"\\\"]\")).eq(0).index();\n var nextThumbsIndex = thumbsSwiper.slides.eq(currentThumbsIndex).nextAll((\"[data-swiper-slide-index=\\\"\" + (swiper.realIndex) + \"\\\"]\")).eq(0).index();\n if (typeof prevThumbsIndex === 'undefined') { newThumbsIndex = nextThumbsIndex; }\n else if (typeof nextThumbsIndex === 'undefined') { newThumbsIndex = prevThumbsIndex; }\n else if (nextThumbsIndex - currentThumbsIndex === currentThumbsIndex - prevThumbsIndex) { newThumbsIndex = currentThumbsIndex; }\n else if (nextThumbsIndex - currentThumbsIndex < currentThumbsIndex - prevThumbsIndex) { newThumbsIndex = nextThumbsIndex; }\n else { newThumbsIndex = prevThumbsIndex; }\n } else {\n newThumbsIndex = swiper.realIndex;\n }\n if (thumbsSwiper.visibleSlidesIndexes && thumbsSwiper.visibleSlidesIndexes.indexOf(newThumbsIndex) < 0) {\n if (thumbsSwiper.params.centeredSlides) {\n if (newThumbsIndex > currentThumbsIndex) {\n newThumbsIndex = newThumbsIndex - Math.floor(slidesPerView / 2) + 1;\n } else {\n newThumbsIndex = newThumbsIndex + Math.floor(slidesPerView / 2) - 1;\n }\n } else if (newThumbsIndex > currentThumbsIndex) {\n newThumbsIndex = newThumbsIndex - slidesPerView + 1;\n }\n thumbsSwiper.slideTo(newThumbsIndex, initial ? 0 : undefined);\n }\n }\n\n // Activate thumbs\n var thumbsToActivate = 1;\n var thumbActiveClass = swiper.params.thumbs.slideThumbActiveClass;\n\n if (swiper.params.slidesPerView > 1 && !swiper.params.centeredSlides) {\n thumbsToActivate = swiper.params.slidesPerView;\n }\n\n thumbsSwiper.slides.removeClass(thumbActiveClass);\n if (thumbsSwiper.params.loop || thumbsSwiper.params.virtual) {\n for (var i = 0; i < thumbsToActivate; i += 1) {\n thumbsSwiper.$wrapperEl.children((\"[data-swiper-slide-index=\\\"\" + (swiper.realIndex + i) + \"\\\"]\")).addClass(thumbActiveClass);\n }\n } else {\n for (var i$1 = 0; i$1 < thumbsToActivate; i$1 += 1) {\n thumbsSwiper.slides.eq(swiper.realIndex + i$1).addClass(thumbActiveClass);\n }\n }\n },\n };\n var Thumbs$1 = {\n name: 'thumbs',\n params: {\n thumbs: {\n swiper: null,\n slideThumbActiveClass: 'swiper-slide-thumb-active',\n thumbsContainerClass: 'swiper-container-thumbs',\n },\n },\n create: function create() {\n var swiper = this;\n Utils.extend(swiper, {\n thumbs: {\n swiper: null,\n init: Thumbs.init.bind(swiper),\n update: Thumbs.update.bind(swiper),\n onThumbClick: Thumbs.onThumbClick.bind(swiper),\n },\n });\n },\n on: {\n beforeInit: function beforeInit() {\n var swiper = this;\n var ref = swiper.params;\n var thumbs = ref.thumbs;\n if (!thumbs || !thumbs.swiper) { return; }\n swiper.thumbs.init();\n swiper.thumbs.update(true);\n },\n slideChange: function slideChange() {\n var swiper = this;\n if (!swiper.thumbs.swiper) { return; }\n swiper.thumbs.update();\n },\n update: function update() {\n var swiper = this;\n if (!swiper.thumbs.swiper) { return; }\n swiper.thumbs.update();\n },\n resize: function resize() {\n var swiper = this;\n if (!swiper.thumbs.swiper) { return; }\n swiper.thumbs.update();\n },\n observerUpdate: function observerUpdate() {\n var swiper = this;\n if (!swiper.thumbs.swiper) { return; }\n swiper.thumbs.update();\n },\n setTransition: function setTransition(duration) {\n var swiper = this;\n var thumbsSwiper = swiper.thumbs.swiper;\n if (!thumbsSwiper) { return; }\n thumbsSwiper.setTransition(duration);\n },\n beforeDestroy: function beforeDestroy() {\n var swiper = this;\n var thumbsSwiper = swiper.thumbs.swiper;\n if (!thumbsSwiper) { return; }\n if (swiper.thumbs.swiperCreated && thumbsSwiper) {\n thumbsSwiper.destroy();\n }\n },\n },\n };\n\n // Swiper Class\n\n var components = [\n Device$1,\n Support$1,\n Browser$1,\n Resize,\n Observer$1,\n Virtual$1,\n Keyboard$1,\n Mousewheel$1,\n Navigation$1,\n Pagination$1,\n Scrollbar$1,\n Parallax$1,\n Zoom$1,\n Lazy$1,\n Controller$1,\n A11y,\n History$1,\n HashNavigation$1,\n Autoplay$1,\n EffectFade,\n EffectCube,\n EffectFlip,\n EffectCoverflow,\n Thumbs$1\n ];\n\n if (typeof Swiper.use === 'undefined') {\n Swiper.use = Swiper.Class.use;\n Swiper.installModule = Swiper.Class.installModule;\n }\n\n Swiper.use(components);\n\n return Swiper;\n\n}));\n","module.exports = __webpack_public_path__ + \"img/whatsapp.9c2f5908.png\";","// extracted by mini-css-extract-plugin","module.exports = __webpack_public_path__ + \"img/telephone.07c3bfa0.png\";","module.exports = \"data:image/png;base64,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\"","// extracted by mini-css-extract-plugin","export * from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./newsInformation.vue?vue&type=style&index=0&id=19a6b5ac&prod&scoped=true&lang=scss\"","module.exports = __webpack_public_path__ + \"img/home-world-bg.f70a74e8.png\";","// extracted by mini-css-extract-plugin","module.exports = \"data:image/png;base64,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\"","// extracted by mini-css-extract-plugin","export * from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./headerNav.vue?vue&type=style&index=0&id=3593ffc6&prod&scoped=true&lang=scss\"","// extracted by mini-css-extract-plugin","module.exports = __webpack_public_path__ + \"img/medal-icon.a8cde317.png\";","// extracted by mini-css-extract-plugin","module.exports = __webpack_public_path__ + \"img/r-icon.2584a2ec.png\";","module.exports = __webpack_public_path__ + \"img/e-mail.f952948e.png\";","// addapted from the document.currentScript polyfill by Adam Miller\n// MIT license\n// source: https://github.com/amiller-gh/currentScript-polyfill\n\n// added support for Firefox https://bugzilla.mozilla.org/show_bug.cgi?id=1620505\n\n(function (root, factory) {\n if (typeof define === 'function' && define.amd) {\n define([], factory);\n } else if (typeof module === 'object' && module.exports) {\n module.exports = factory();\n } else {\n root.getCurrentScript = factory();\n }\n}(typeof self !== 'undefined' ? self : this, function () {\n function getCurrentScript () {\n var descriptor = Object.getOwnPropertyDescriptor(document, 'currentScript')\n // for chrome\n if (!descriptor && 'currentScript' in document && document.currentScript) {\n return document.currentScript\n }\n\n // for other browsers with native support for currentScript\n if (descriptor && descriptor.get !== getCurrentScript && document.currentScript) {\n return document.currentScript\n }\n \n // IE 8-10 support script readyState\n // IE 11+ & Firefox support stack trace\n try {\n throw new Error();\n }\n catch (err) {\n // Find the second match for the \"at\" string to get file src url from stack.\n var ieStackRegExp = /.*at [^(]*\\((.*):(.+):(.+)\\)$/ig,\n ffStackRegExp = /@([^@]*):(\\d+):(\\d+)\\s*$/ig,\n stackDetails = ieStackRegExp.exec(err.stack) || ffStackRegExp.exec(err.stack),\n scriptLocation = (stackDetails && stackDetails[1]) || false,\n line = (stackDetails && stackDetails[2]) || false,\n currentLocation = document.location.href.replace(document.location.hash, ''),\n pageSource,\n inlineScriptSourceRegExp,\n inlineScriptSource,\n scripts = document.getElementsByTagName('script'); // Live NodeList collection\n \n if (scriptLocation === currentLocation) {\n pageSource = document.documentElement.outerHTML;\n inlineScriptSourceRegExp = new RegExp('(?:[^\\\\n]+?\\\\n){0,' + (line - 2) + '}[^<]*<script>([\\\\d\\\\D]*?)<\\\\/script>[\\\\d\\\\D]*', 'i');\n inlineScriptSource = pageSource.replace(inlineScriptSourceRegExp, '$1').trim();\n }\n \n for (var i = 0; i < scripts.length; i++) {\n // If ready state is interactive, return the script tag\n if (scripts[i].readyState === 'interactive') {\n return scripts[i];\n }\n \n // If src matches, return the script tag\n if (scripts[i].src === scriptLocation) {\n return scripts[i];\n }\n \n // If inline source matches, return the script tag\n if (\n scriptLocation === currentLocation &&\n scripts[i].innerHTML &&\n scripts[i].innerHTML.trim() === inlineScriptSource\n ) {\n return scripts[i];\n }\n }\n \n // If no match, return null\n return null;\n }\n };\n\n return getCurrentScript\n}));\n","export * from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./productList.vue?vue&type=style&index=0&id=280a79e6&prod&scoped=true&lang=scss\"","// extracted by mini-css-extract-plugin","module.exports = __webpack_public_path__ + \"img/diamond-icon.a74d4441.png\";","module.exports = \"data:image/png;base64,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\"","// extracted by mini-css-extract-plugin","export * from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./floatNav.vue?vue&type=style&index=0&id=487febec&prod&scoped=true&lang=scss\"","export * from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./carousel.vue?vue&type=style&index=0&id=57e1ecdc&prod&scoped=true&lang=scss\"","export * from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./footerNav.vue?vue&type=style&index=0&id=6f2164cf&prod&scoped=true&lang=scss\"","module.exports = __webpack_public_path__ + \"img/diamond-icon2.bcb24d08.png\";","module.exports = __webpack_public_path__ + \"img/left-arrow.37f00f63.svg\";","// extracted by mini-css-extract-plugin","module.exports = __webpack_public_path__ + \"img/company-intro-bg.e2568bd2.png\";","export * from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./companyIntroduction.vue?vue&type=style&index=0&id=29fbc5fe&prod&scoped=true&lang=scss\"","// extracted by mini-css-extract-plugin","module.exports = __webpack_public_path__ + \"img/project-icon.0b452510.png\";","module.exports = \"data:image/png;base64,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\"","export * from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./changeLanguageDialog.vue?vue&type=style&index=0&id=00547f6c&prod&scoped=true&lang=scss\"","!function(e,t){\"object\"==typeof exports&&\"object\"==typeof module?module.exports=t(require(\"swiper/dist/js/swiper.js\")):\"function\"==typeof define&&define.amd?define(\"VueAwesomeSwiper\",[\"swiper\"],t):\"object\"==typeof exports?exports.VueAwesomeSwiper=t(require(\"swiper/dist/js/swiper.js\")):e.VueAwesomeSwiper=t(e.Swiper)}(this,function(e){return function(e){function t(i){if(n[i])return n[i].exports;var s=n[i]={i:i,l:!1,exports:{}};return e[i].call(s.exports,s,s.exports,t),s.l=!0,s.exports}var n={};return t.m=e,t.c=n,t.i=function(e){return e},t.d=function(e,n,i){t.o(e,n)||Object.defineProperty(e,n,{configurable:!1,enumerable:!0,get:i})},t.n=function(e){var n=e&&e.__esModule?function(){return e.default}:function(){return e};return t.d(n,\"a\",n),n},t.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},t.p=\"/\",t(t.s=4)}([function(t,n){t.exports=e},function(e,t){e.exports=function(e,t,n,i,s,r){var o,a=e=e||{},u=typeof e.default;\"object\"!==u&&\"function\"!==u||(o=e,a=e.default);var p=\"function\"==typeof a?a.options:a;t&&(p.render=t.render,p.staticRenderFns=t.staticRenderFns,p._compiled=!0),n&&(p.functional=!0),s&&(p._scopeId=s);var l;if(r?(l=function(e){e=e||this.$vnode&&this.$vnode.ssrContext||this.parent&&this.parent.$vnode&&this.parent.$vnode.ssrContext,e||\"undefined\"==typeof __VUE_SSR_CONTEXT__||(e=__VUE_SSR_CONTEXT__),i&&i.call(this,e),e&&e._registeredComponents&&e._registeredComponents.add(r)},p._ssrRegister=l):i&&(l=i),l){var c=p.functional,d=c?p.render:p.beforeCreate;c?(p._injectStyles=l,p.render=function(e,t){return l.call(t),d(e,t)}):p.beforeCreate=d?[].concat(d,l):[l]}return{esModule:o,exports:a,options:p}}},function(e,t,n){\"use strict\";Object.defineProperty(t,\"__esModule\",{value:!0});var i=n(5),s=n.n(i),r=n(8),o=n(1),a=o(s.a,r.a,!1,null,null,null);t.default=a.exports},function(e,t,n){\"use strict\";Object.defineProperty(t,\"__esModule\",{value:!0});var i=n(6),s=n.n(i),r=n(7),o=n(1),a=o(s.a,r.a,!1,null,null,null);t.default=a.exports},function(e,t,n){\"use strict\";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,\"__esModule\",{value:!0}),t.install=t.swiperSlide=t.swiper=t.Swiper=void 0;var s=n(0),r=i(s),o=n(2),a=i(o),u=n(3),p=i(u),l=window.Swiper||r.default,c=p.default,d=a.default,f=function(e,t){t&&(p.default.props.globalOptions.default=function(){return t}),e.component(p.default.name,p.default),e.component(a.default.name,a.default)},h={Swiper:l,swiper:c,swiperSlide:d,install:f};t.default=h,t.Swiper=l,t.swiper=c,t.swiperSlide=d,t.install=f},function(e,t,n){\"use strict\";Object.defineProperty(t,\"__esModule\",{value:!0}),t.default={name:\"swiper-slide\",data:function(){return{slideClass:\"swiper-slide\"}},ready:function(){this.update()},mounted:function(){this.update(),this.$parent&&this.$parent.options&&this.$parent.options.slideClass&&(this.slideClass=this.$parent.options.slideClass)},updated:function(){this.update()},attached:function(){this.update()},methods:{update:function(){this.$parent&&this.$parent.swiper&&this.$parent.update()}}}},function(e,t,n){\"use strict\";Object.defineProperty(t,\"__esModule\",{value:!0});var i=n(0),s=function(e){return e&&e.__esModule?e:{default:e}}(i),r=window.Swiper||s.default;\"function\"!=typeof Object.assign&&Object.defineProperty(Object,\"assign\",{value:function(e,t){if(null==e)throw new TypeError(\"Cannot convert undefined or null to object\");for(var n=Object(e),i=1;i<arguments.length;i++){var s=arguments[i];if(null!=s)for(var r in s)Object.prototype.hasOwnProperty.call(s,r)&&(n[r]=s[r])}return n},writable:!0,configurable:!0});var o=[\"beforeDestroy\",\"slideChange\",\"slideChangeTransitionStart\",\"slideChangeTransitionEnd\",\"slideNextTransitionStart\",\"slideNextTransitionEnd\",\"slidePrevTransitionStart\",\"slidePrevTransitionEnd\",\"transitionStart\",\"transitionEnd\",\"touchStart\",\"touchMove\",\"touchMoveOpposite\",\"sliderMove\",\"touchEnd\",\"click\",\"tap\",\"doubleTap\",\"imagesReady\",\"progress\",\"reachBeginning\",\"reachEnd\",\"fromEdge\",\"setTranslate\",\"setTransition\",\"resize\"];t.default={name:\"swiper\",props:{options:{type:Object,default:function(){return{}}},globalOptions:{type:Object,required:!1,default:function(){return{}}}},data:function(){return{swiper:null,classes:{wrapperClass:\"swiper-wrapper\"}}},ready:function(){this.swiper||this.mountInstance()},mounted:function(){if(!this.swiper){var e=!1;for(var t in this.classes)this.classes.hasOwnProperty(t)&&this.options[t]&&(e=!0,this.classes[t]=this.options[t]);e?this.$nextTick(this.mountInstance):this.mountInstance()}},activated:function(){this.update()},updated:function(){this.update()},beforeDestroy:function(){this.$nextTick(function(){this.swiper&&(this.swiper.destroy&&this.swiper.destroy(),delete this.swiper)})},methods:{update:function(){this.swiper&&(this.swiper.update&&this.swiper.update(),this.swiper.navigation&&this.swiper.navigation.update(),this.swiper.pagination&&this.swiper.pagination.render(),this.swiper.pagination&&this.swiper.pagination.update())},mountInstance:function(){var e=Object.assign({},this.globalOptions,this.options);this.swiper=new r(this.$el,e),this.bindEvents(),this.$emit(\"ready\",this.swiper)},bindEvents:function(){var e=this,t=this;o.forEach(function(n){e.swiper.on(n,function(){t.$emit.apply(t,[n].concat(Array.prototype.slice.call(arguments))),t.$emit.apply(t,[n.replace(/([A-Z])/g,\"-$1\").toLowerCase()].concat(Array.prototype.slice.call(arguments)))})})}}}},function(e,t,n){\"use strict\";var i=function(){var e=this,t=e.$createElement,n=e._self._c||t;return n(\"div\",{staticClass:\"swiper-container\"},[e._t(\"parallax-bg\"),e._v(\" \"),n(\"div\",{class:e.classes.wrapperClass},[e._t(\"default\")],2),e._v(\" \"),e._t(\"pagination\"),e._v(\" \"),e._t(\"button-prev\"),e._v(\" \"),e._t(\"button-next\"),e._v(\" \"),e._t(\"scrollbar\")],2)},s=[],r={render:i,staticRenderFns:s};t.a=r},function(e,t,n){\"use strict\";var i=function(){var e=this,t=e.$createElement;return(e._self._c||t)(\"div\",{class:e.slideClass},[e._t(\"default\")],2)},s=[],r={render:i,staticRenderFns:s};t.a=r}])});","// extracted by mini-css-extract-plugin","module.exports = __webpack_public_path__ + \"img/people-icon.82edf9a7.png\";","// This file is imported into lib/wc client bundles.\n\nif (typeof window !== 'undefined') {\n var currentScript = window.document.currentScript\n if (process.env.NEED_CURRENTSCRIPT_POLYFILL) {\n var getCurrentScript = require('@soda/get-current-script')\n currentScript = getCurrentScript()\n\n // for backward compatibility, because previously we directly included the polyfill\n if (!('currentScript' in document)) {\n Object.defineProperty(document, 'currentScript', { get: getCurrentScript })\n }\n }\n\n var src = currentScript && currentScript.src.match(/(.+\\/)[^/]+\\.js(\\?.*)?$/)\n if (src) {\n __webpack_public_path__ = src[1] // eslint-disable-line\n }\n}\n\n// Indicate to webpack that this file can be concatenated\nexport default null\n","var render = function render(){var _vm=this,_c=_vm._self._c;return _c('div',{staticClass:\"carousel-component\"},[(_vm.clickDisabled)?_c('div',{staticClass:\"carousel-component-click-disabled-mask\"}):_vm._e(),(_vm.styleType === 'style1')?_c('div',{staticClass:\"carousel-component-style1\"},[_c('swiper',{attrs:{\"options\":_vm.swiperOptions}},[_vm._l((_vm.carouselList),function(item){return _c('swiper-slide',{key:item.id},[_c('img',{staticClass:\"carousel-component-swiper-img\",attrs:{\"src\":item.url,\"alt\":item.title || ''},on:{\"click\":function($event){$event.stopPropagation();return _vm.handleClick(item)}}})])}),_c('div',{staticClass:\"swiper-pagination\",attrs:{\"slot\":\"pagination\"},slot:\"pagination\"}),_c('div',{staticClass:\"swiper-button-next\",attrs:{\"slot\":\"button-next\"},slot:\"button-next\"},[_c('img',{attrs:{\"src\":require(\"../../assets/left-arrow.svg\"),\"alt\":\"\"}})]),_c('div',{staticClass:\"swiper-button-prev\",attrs:{\"slot\":\"button-prev\"},slot:\"button-prev\"},[_c('img',{attrs:{\"src\":require(\"../../assets/left-arrow.svg\"),\"alt\":\"\"}})])],2)],1):(_vm.styleType === 'style2')?_c('div',{staticClass:\"carousel-component-style2\"},[_c('swiper',{attrs:{\"options\":_vm.swiperOptions}},_vm._l((_vm.carouselList),function(item){return _c('swiper-slide',{key:item.id},[_c('img',{staticClass:\"carousel-component-swiper-img\",attrs:{\"src\":item.url,\"alt\":item.title || ''},on:{\"click\":function($event){$event.stopPropagation();return _vm.handleClick(item)}}})])}),1)],1):(_vm.styleType === 'style3')?_c('div'):_vm._e()])\n}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","<template>\n <div class=\"carousel-component\">\n <!-- 点击事件禁用遮罩 -->\n <div v-if=\"clickDisabled\" class=\"carousel-component-click-disabled-mask\" />\n <!-- 占位符 -->\n <div v-if=\"styleType === 'style1'\" class=\"carousel-component-style1\">\n <!-- 样式一 -->\n <swiper :options=\"swiperOptions\">\n <swiper-slide v-for=\"item in carouselList\" :key=\"item.id\">\n <img :src=\"item.url\" :alt=\"item.title || ''\" class=\"carousel-component-swiper-img\" @click.stop=\"handleClick(item)\">\n </swiper-slide>\n\n <!-- 分页器 -->\n <div slot=\"pagination\" class=\"swiper-pagination\" />\n <!-- 导航按钮 -->\n <div slot=\"button-next\" class=\"swiper-button-next\">\n <img src=\"../../assets/left-arrow.svg\" alt=\"\">\n </div>\n <div slot=\"button-prev\" class=\"swiper-button-prev\">\n <img src=\"../../assets/left-arrow.svg\" alt=\"\">\n </div>\n </swiper>\n </div>\n <div v-else-if=\"styleType === 'style2'\" class=\"carousel-component-style2\">\n <!-- 样式二 -->\n <!-- 样式一 -->\n <swiper :options=\"swiperOptions\">\n <swiper-slide v-for=\"item in carouselList\" :key=\"item.id\">\n <img :src=\"item.url\" :alt=\"item.title || ''\" class=\"carousel-component-swiper-img\" @click.stop=\"handleClick(item)\">\n </swiper-slide>\n </swiper>\n </div>\n <div v-else-if=\"styleType === 'style3'\">\n <!-- 样式三 -->\n </div>\n </div>\n</template>\n\n<script>\n// 轮播图组件 carouselConfig组件在调整了图片顺序后,当前组件的图片展示有点问题,图片会在切换前闪一下,但是实际数据是变化了的,在展示端是没有问题的,\nimport { swiper, swiperSlide } from 'vue-awesome-swiper'\nimport 'swiper/dist/css/swiper.css'\nexport default {\n name: 'CarouselComponent',\n components: {\n swiper,\n swiperSlide\n },\n props: {\n styleType: {\n type: String,\n default: 'style1'\n },\n carouselList: {\n type: Array,\n default: () => []\n },\n clickDisabled: {\n type: Boolean,\n default: false\n },\n theme: {\n type: String,\n default: ''\n }\n },\n data() {\n return {\n swiperOptions: {\n slidesPerView: 1,\n loop: true,\n autoplay: {\n delay: 6000,\n stopOnLastSlide: false, // 到最后一张图后是否停止自动播放\n disableOnInteraction: false // 鼠标悬停时不停止自动播放\n },\n speed: 1000,\n // 导航按钮\n navigation: {\n nextEl: '.swiper-button-next',\n prevEl: '.swiper-button-prev'\n },\n pagination: {\n el: '.swiper-pagination',\n clickable: true // 允许分页点击跳转\n }\n },\n swiperInstance: null // 保存Swiper实例\n }\n },\n watch: {\n // 监听轮播图数据变化,重新初始化Swiper\n carouselList: {\n handler(newVal) {\n // 延迟执行,确保DOM已更新\n this.$nextTick(() => {\n // this.initSwiper()\n if (this.swiperInstance) {\n this.swiperInstance.update()\n }\n })\n },\n deep: true,\n immediate: true\n }\n },\n mounted() {\n // 组件挂载后初始化Swiper\n this.$nextTick(() => {\n this.initSwiper()\n })\n },\n methods: {\n handleClick(item) {\n if (!item.link) {\n return\n }\n window.open(item.link, '_blank')\n },\n // 初始化Swiper实例\n initSwiper() {\n // 确保有轮播图数据\n if (!this.carouselList || this.carouselList.length === 0) {\n return\n }\n\n // 如果已有实例,先销毁\n if (this.swiperInstance) {\n this.swiperInstance.destroy()\n }\n\n // 获取Swiper实例并重新初始化\n setTimeout(() => {\n const swiperElements = document.querySelectorAll('.swiper-container')\n if (swiperElements.length > 0) {\n // Vue Awesome Swiper会自动初始化,这里手动处理一些功能\n this.swiperInstance = swiperElements[0].swiper\n\n // 确保自动播放已启动\n if (this.swiperInstance && !this.swiperInstance.autoplay.running) {\n this.swiperInstance.autoplay.start()\n }\n\n // 确保导航按钮已绑定\n if (this.swiperInstance && !this.swiperInstance.navigation.initiated) {\n this.swiperInstance.navigation.init()\n this.swiperInstance.navigation.update()\n }\n\n // 确保分页器已绑定\n if (this.swiperInstance && !this.swiperInstance.pagination.initiated) {\n this.swiperInstance.pagination.init()\n this.swiperInstance.pagination.update()\n }\n }\n }, 100)\n }\n }\n}\n</script>\n\n<style scoped lang=\"scss\">\n.carousel-component {\n width: 100%;\n height: fit-content;\n min-height: 50px;\n background-color: #f5f5f5;\n background-color: #fff;\n position: relative;\n\n .carousel-component-click-disabled-mask {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n z-index: 1000;\n }\n\n .carousel-component-style1 {\n .carousel-component-swiper-img {\n width: 100%;\n height: 889px;\n display: block;\n object-fit: cover;\n }\n\n /* Swiper导航按钮样式 */\n .swiper-button-next,\n .swiper-button-prev {\n color: rgba(255, 255, 255, 0.8);\n width: 15%;\n height: 100%;\n top: 0;\n margin-top: 0;\n background-color: rgba(0, 0, 0, 0.3);\n border-radius: 50%;\n transition: all 0.3s ease;\n background: none;\n // background: url('../../assets/left-arrow.svg') no-repeat center center;\n cursor: pointer;\n opacity: 0.5;\n display: flex;\n justify-content: center;\n align-items: center;\n\n img {\n width: 20px;\n height: 20px;\n }\n\n &:hover {\n color: #fff;\n opacity: 1;\n }\n\n &::after {\n font-size: 18px;\n }\n }\n\n .swiper-button-prev {\n left: 0;\n }\n\n .swiper-button-next {\n right: 0;\n transform: rotate(180deg);\n }\n\n /* Swiper分页器样式 */\n .swiper-pagination {\n ::v-deep .swiper-pagination-bullet {\n flex: 0 1 auto;\n width: 30px;\n height: 3px;\n opacity: 1;\n margin: 0 3px;\n background: #fff;\n background-clip: padding-box;\n transition: all 0.6s ease;\n opacity: 0.5;\n border-radius: 0;\n }\n ::v-deep.swiper-pagination-bullet-active {\n opacity: 1;\n }\n }\n }\n\n .carousel-component-style2 {\n .carousel-component-swiper-img {\n width: 100%;\n height: 597px;\n display: block;\n object-fit: cover;\n }\n }\n}\n</style>\n\n","import mod from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./carousel.vue?vue&type=script&lang=js\"; export default mod; export * from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./carousel.vue?vue&type=script&lang=js\"","/* globals __VUE_SSR_CONTEXT__ */\n\n// IMPORTANT: Do NOT use ES2015 features in this file (except for modules).\n// This module is a runtime utility for cleaner component module output and will\n// be included in the final webpack user bundle.\n\nexport default function normalizeComponent(\n scriptExports,\n render,\n staticRenderFns,\n functionalTemplate,\n injectStyles,\n scopeId,\n moduleIdentifier /* server only */,\n shadowMode /* vue-cli only */\n) {\n // Vue.extend constructor export interop\n var options =\n typeof scriptExports === 'function' ? scriptExports.options : scriptExports\n\n // render functions\n if (render) {\n options.render = render\n options.staticRenderFns = staticRenderFns\n options._compiled = true\n }\n\n // functional template\n if (functionalTemplate) {\n options.functional = true\n }\n\n // scopedId\n if (scopeId) {\n options._scopeId = 'data-v-' + scopeId\n }\n\n var hook\n if (moduleIdentifier) {\n // server build\n hook = function (context) {\n // 2.3 injection\n context =\n context || // cached call\n (this.$vnode && this.$vnode.ssrContext) || // stateful\n (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional\n // 2.2 with runInNewContext: true\n if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') {\n context = __VUE_SSR_CONTEXT__\n }\n // inject component styles\n if (injectStyles) {\n injectStyles.call(this, context)\n }\n // register component module identifier for async chunk inferrence\n if (context && context._registeredComponents) {\n context._registeredComponents.add(moduleIdentifier)\n }\n }\n // used by ssr in case component is cached and beforeCreate\n // never gets called\n options._ssrRegister = hook\n } else if (injectStyles) {\n hook = shadowMode\n ? function () {\n injectStyles.call(\n this,\n (options.functional ? this.parent : this).$root.$options.shadowRoot\n )\n }\n : injectStyles\n }\n\n if (hook) {\n if (options.functional) {\n // for template-only hot-reload because in that case the render fn doesn't\n // go through the normalizer\n options._injectStyles = hook\n // register for functional component in vue file\n var originalRender = options.render\n options.render = function renderWithStyleInjection(h, context) {\n hook.call(context)\n return originalRender(h, context)\n }\n } else {\n // inject component registration as beforeCreate hook\n var existing = options.beforeCreate\n options.beforeCreate = existing ? [].concat(existing, hook) : [hook]\n }\n }\n\n return {\n exports: scriptExports,\n options: options\n }\n}\n","import { render, staticRenderFns } from \"./carousel.vue?vue&type=template&id=57e1ecdc&scoped=true\"\nimport script from \"./carousel.vue?vue&type=script&lang=js\"\nexport * from \"./carousel.vue?vue&type=script&lang=js\"\nimport style0 from \"./carousel.vue?vue&type=style&index=0&id=57e1ecdc&prod&scoped=true&lang=scss\"\n\n\n/* normalize component */\nimport normalizer from \"!../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n \"57e1ecdc\",\n null\n \n)\n\nexport default component.exports","import carousel from './carousel.vue'\n\ncarousel.install = Vue => Vue.component(carousel.name, carousel)\n\nexport default carousel\n","var render = function render(){var _vm=this,_c=_vm._self._c;return _c('div',{staticClass:\"companyIntroduction-component\",class:_vm.theme},[(_vm.clickDisabled)?_c('div',{staticClass:\"companyIntroduction-component-click-disabled-mask\"}):_vm._e(),(_vm.styleType === 'style1')?_c('div',{staticClass:\"companyIntroduction-component-style1\"},[_c('div',{staticClass:\"companyIntroduction-title\"},[_vm._v(_vm._s(_vm.introduction.title))]),_c('div',{staticClass:\"companyIntroduction-subTitle\"},[_vm._v(_vm._s(_vm.introduction.subTitle))]),_c('div',{staticClass:\"companyIntroduction-content\",domProps:{\"innerHTML\":_vm._s(_vm.introduction.pcIntroduction)}}),_vm._m(0),_c('div',{directives:[{name:\"show\",rawName:\"v-show\",value:(_vm.introduction.moreMenu.isShow),expression:\"introduction.moreMenu.isShow\"}],staticClass:\"companyIntroduction-moreMenu\"},[_c('div',{staticClass:\"companyIntroduction-moreMenu-name\",on:{\"click\":function($event){$event.stopPropagation();return _vm.handleShowMore.apply(null, arguments)}}},[_vm._v(_vm._s(_vm.introduction.moreMenu.name))])]),_c('img',{staticClass:\"companyIntroduction-moreMenu-bg\",attrs:{\"src\":require(\"../../assets/home-world-bg.png\")}})]):_vm._e(),(_vm.styleType === 'style2')?_c('div',{staticClass:\"companyIntroduction-component-style2\"},[_c('div',{staticClass:\"companyIntroduction-title\"},[_vm._v(_vm._s(_vm.introduction.title))]),_c('div',{staticClass:\"companyIntroduction-subTitle\"},[_vm._v(_vm._s(_vm.introduction.subTitle))]),_c('div',{staticClass:\"companyIntroduction-content\",domProps:{\"innerHTML\":_vm._s(_vm.introduction.pcIntroduction)}}),_vm._m(1),_c('div',{directives:[{name:\"show\",rawName:\"v-show\",value:(_vm.introduction.moreMenu.isShow),expression:\"introduction.moreMenu.isShow\"}],staticClass:\"companyIntroduction-moreMenu\"},[_c('div',{staticClass:\"companyIntroduction-moreMenu-name\",on:{\"click\":function($event){$event.stopPropagation();return _vm.handleShowMore.apply(null, arguments)}}},[_vm._v(_vm._s(_vm.introduction.moreMenu.name))])])]):_vm._e(),(_vm.styleType === 'style2')?_c('img',{staticClass:\"style2-companyIntroduction-moreMenu-bg\",attrs:{\"src\":require(\"../../assets/company-intro-bg.png\")}}):_vm._e()])\n}\nvar staticRenderFns = [function (){var _vm=this,_c=_vm._self._c;return _c('div',{staticClass:\"companyIntroduction-feature\"},[_c('div',{staticClass:\"companyIntroduction-feature-item\"},[_c('div',{staticClass:\"companyIntroduction-feature-item-icon\"},[_c('img',{attrs:{\"src\":require(\"../../assets/diamond-icon.png\"),\"alt\":\"\"}})]),_c('div',{staticClass:\"companyIntroduction-feature-item-title\"},[_vm._v(\"高质量\")])]),_c('div',{staticClass:\"companyIntroduction-feature-item\"},[_c('div',{staticClass:\"companyIntroduction-feature-item-icon\"},[_c('img',{attrs:{\"src\":require(\"../../assets/people-icon.png\"),\"alt\":\"\"}})]),_c('div',{staticClass:\"companyIntroduction-feature-item-title\"},[_vm._v(\"领导品牌\")])]),_c('div',{staticClass:\"companyIntroduction-feature-item\"},[_c('div',{staticClass:\"companyIntroduction-feature-item-icon\"},[_c('img',{attrs:{\"src\":require(\"../../assets/r-icon.png\"),\"alt\":\"\"}})]),_c('div',{staticClass:\"companyIntroduction-feature-item-title\"},[_vm._v(\"专业团队\")])]),_c('div',{staticClass:\"companyIntroduction-feature-item\"},[_c('div',{staticClass:\"companyIntroduction-feature-item-icon\"},[_c('img',{attrs:{\"src\":require(\"../../assets/project-icon.png\"),\"alt\":\"\"}})]),_c('div',{staticClass:\"companyIntroduction-feature-item-title\"},[_vm._v(\"先进设备\")])])])\n},function (){var _vm=this,_c=_vm._self._c;return _c('div',{staticClass:\"companyIntroduction-feature\"},[_c('div',{staticClass:\"companyIntroduction-feature-item\"},[_c('div',{staticClass:\"companyIntroduction-feature-item-icon\"},[_c('img',{attrs:{\"src\":require(\"../../assets/diamond-icon2.png\"),\"alt\":\"\"}})]),_c('div',{staticClass:\"companyIntroduction-feature-item-title\"},[_vm._v(\"高质量\")])]),_c('div',{staticClass:\"companyIntroduction-feature-item\"},[_c('div',{staticClass:\"companyIntroduction-feature-item-icon\"},[_c('img',{attrs:{\"src\":require(\"../../assets/medal-icon.png\"),\"alt\":\"\"}})]),_c('div',{staticClass:\"companyIntroduction-feature-item-title\"},[_vm._v(\"领导品牌\")])]),_c('div',{staticClass:\"companyIntroduction-feature-item\"},[_c('div',{staticClass:\"companyIntroduction-feature-item-icon\"},[_c('img',{attrs:{\"src\":require(\"../../assets/people-icon.png\"),\"alt\":\"\"}})]),_c('div',{staticClass:\"companyIntroduction-feature-item-title\"},[_vm._v(\"专业团队\")])]),_c('div',{staticClass:\"companyIntroduction-feature-item\"},[_c('div',{staticClass:\"companyIntroduction-feature-item-icon\"},[_c('img',{attrs:{\"src\":require(\"../../assets/equipment-icon.png\"),\"alt\":\"\"}})]),_c('div',{staticClass:\"companyIntroduction-feature-item-title\"},[_vm._v(\"先进设备\")])])])\n}]\n\nexport { render, staticRenderFns }","<template>\n <div class=\"companyIntroduction-component\" :class=\"theme\">\n <div v-if=\"clickDisabled\" class=\"companyIntroduction-component-click-disabled-mask\" />\n <div v-if=\"styleType === 'style1'\" class=\"companyIntroduction-component-style1\">\n <div class=\"companyIntroduction-title\">{{ introduction.title }}</div>\n <div class=\"companyIntroduction-subTitle\">{{ introduction.subTitle }}</div>\n <div class=\"companyIntroduction-content\" v-html=\"introduction.pcIntroduction\" />\n <div class=\"companyIntroduction-feature\">\n <div class=\"companyIntroduction-feature-item\">\n <div class=\"companyIntroduction-feature-item-icon\">\n <img src=\"../../assets/diamond-icon.png\" alt=\"\">\n </div>\n <div class=\"companyIntroduction-feature-item-title\">高质量</div>\n </div>\n <div class=\"companyIntroduction-feature-item\">\n <div class=\"companyIntroduction-feature-item-icon\">\n <img src=\"../../assets/people-icon.png\" alt=\"\">\n </div>\n <div class=\"companyIntroduction-feature-item-title\">领导品牌</div>\n </div>\n <div class=\"companyIntroduction-feature-item\">\n <div class=\"companyIntroduction-feature-item-icon\">\n <img src=\"../../assets/r-icon.png\" alt=\"\">\n </div>\n <div class=\"companyIntroduction-feature-item-title\">专业团队</div>\n </div>\n <div class=\"companyIntroduction-feature-item\">\n <div class=\"companyIntroduction-feature-item-icon\">\n <img src=\"../../assets/project-icon.png\" alt=\"\">\n </div>\n <div class=\"companyIntroduction-feature-item-title\">先进设备</div>\n </div>\n </div>\n <div v-show=\"introduction.moreMenu.isShow\" class=\"companyIntroduction-moreMenu\">\n <div class=\"companyIntroduction-moreMenu-name\" @click.stop=\"handleShowMore\">{{ introduction.moreMenu.name }}</div>\n </div>\n <img class=\"companyIntroduction-moreMenu-bg\" src=\"../../assets/home-world-bg.png\">\n </div>\n <div v-if=\"styleType === 'style2'\" class=\"companyIntroduction-component-style2\">\n <div class=\"companyIntroduction-title\">{{ introduction.title }}</div>\n <div class=\"companyIntroduction-subTitle\">{{ introduction.subTitle }}</div>\n <div class=\"companyIntroduction-content\" v-html=\"introduction.pcIntroduction\" />\n <div class=\"companyIntroduction-feature\">\n <div class=\"companyIntroduction-feature-item\">\n <div class=\"companyIntroduction-feature-item-icon\">\n <img src=\"../../assets/diamond-icon2.png\" alt=\"\">\n </div>\n <div class=\"companyIntroduction-feature-item-title\">高质量</div>\n </div>\n <div class=\"companyIntroduction-feature-item\">\n <div class=\"companyIntroduction-feature-item-icon\">\n <img src=\"../../assets/medal-icon.png\" alt=\"\">\n </div>\n <div class=\"companyIntroduction-feature-item-title\">领导品牌</div>\n </div>\n <div class=\"companyIntroduction-feature-item\">\n <div class=\"companyIntroduction-feature-item-icon\">\n <img src=\"../../assets/people-icon.png\" alt=\"\">\n </div>\n <div class=\"companyIntroduction-feature-item-title\">专业团队</div>\n </div>\n <div class=\"companyIntroduction-feature-item\">\n <div class=\"companyIntroduction-feature-item-icon\">\n <img src=\"../../assets/equipment-icon.png\" alt=\"\">\n </div>\n <div class=\"companyIntroduction-feature-item-title\">先进设备</div>\n </div>\n </div>\n <div v-show=\"introduction.moreMenu.isShow\" class=\"companyIntroduction-moreMenu\">\n <div class=\"companyIntroduction-moreMenu-name\" @click.stop=\"handleShowMore\">{{ introduction.moreMenu.name }}</div>\n </div>\n </div>\n <!-- 样式2背景图 -->\n <img v-if=\"styleType === 'style2'\" class=\"style2-companyIntroduction-moreMenu-bg\" src=\"../../assets/company-intro-bg.png\">\n </div>\n</template>\n\n<script>\nexport default {\n name: 'CompanyIntroductionComponent',\n props: {\n clickDisabled: {\n type: Boolean,\n default: false\n },\n styleType: {\n type: String,\n default: 'style1'\n },\n introduction: {\n type: Object,\n default: () => ({\n title: '',\n subTitle: '',\n pcContent: '',\n mobileContent: '',\n moreMenu: {\n name: '',\n isShow: true,\n isBlank: true\n }\n })\n },\n theme: {\n type: String,\n default: ''\n }\n },\n methods: {\n handleShowMore() {\n console.log(this.$props.introduction)\n }\n }\n}\n</script>\n\n<style scoped lang=\"scss\">\n@import '../../styles/theme.css';\n.companyIntroduction-component {\n position: relative;\n width: 100%;\n\n .companyIntroduction-component-click-disabled-mask {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n z-index: 1000;\n }\n\n .companyIntroduction-component-style1 {\n max-width: 1200px;\n padding: 0 15px;\n height: 100%;\n min-height: 20px;\n margin-left: auto;\n margin-right: auto;\n .companyIntroduction-title {\n margin: 26px 0 15px;\n color: #015fe8;\n width: 100%;\n text-align: center;\n font-size: 24px;\n font-weight: 500;\n line-height: 1.2;\n }\n .companyIntroduction-subTitle {\n margin-bottom: 8px;\n color: #015fe8;\n width: 100%;\n text-align: center;\n font-weight: 400;\n font-size: 14px;\n line-height: 1.2;\n }\n .companyIntroduction-content {\n display: flow-root; // 构建BFC,清除内部浮动\n margin-top: 18px;\n margin-bottom: 52px;\n color: #575757;\n font-size: 14px;\n }\n .companyIntroduction-feature {\n display: flex;\n justify-content: space-between;\n align-items: center;\n\n .companyIntroduction-feature-item {\n flex: 0 0 25%;\n max-width: 25%;\n padding: 0 15px;\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n position: relative;\n z-index: 1;\n .companyIntroduction-feature-item-icon {\n width: 70px;\n height: 70px;\n margin-bottom: 16px;\n display: flex;\n align-items: center;\n justify-content: center;\n background: #f3f4f6;\n border-radius: 8px;\n img {\n width: 40px;\n height: 40px;\n }\n }\n .companyIntroduction-feature-item-title {\n font-size: 14px;\n font-weight: 400;\n line-height: 1.5;\n color: rgb(135, 139, 144);\n }\n }\n }\n\n .companyIntroduction-moreMenu {\n margin-top: 16px;\n margin-left: auto;\n margin-right: auto;\n width: 150px;\n padding: 8px 35px;\n background-color: rgb(1, 95, 232);\n border-radius: 30px;\n color: #fff;\n font-size: 14px;\n cursor: pointer;\n font-weight: 400;\n line-height: 21px;\n transition: all 0.3s ease-in-out;\n text-align: center;\n position: relative;\n z-index: 1;\n &:hover {\n box-shadow: 2px 2px 10px 0 rgba(0,0,0,.2);\n }\n }\n .companyIntroduction-moreMenu-bg {\n max-width: 100%;\n height: auto;\n margin-top: -180px;\n pointer-events: none;\n border: none;\n\n }\n }\n\n .companyIntroduction-component-style2 {\n max-width: 1200px;\n padding: 100px 15px 0;\n height: 100%;\n min-height: 20px;\n margin-left: auto;\n margin-right: auto;\n position: relative;\n z-index: 1;\n .companyIntroduction-title {\n margin-bottom: 25px;\n color: var(--theme-title-color);\n width: 100%;\n text-align: center;\n font-size: 46px;\n font-weight: 500;\n line-height: 1;\n }\n .companyIntroduction-subTitle {\n margin-bottom: 50px;\n color: var(--theme-subTitle-color);\n width: 100%;\n text-align: center;\n font-weight: 500;\n font-size: 26px;\n line-height: 1;\n }\n .companyIntroduction-content {\n display: flow-root; // 构建BFC,清除内部浮动\n margin-bottom: 32px;\n }\n .companyIntroduction-feature {\n display: flex;\n justify-content: center;\n align-items: center;\n gap: 129px;\n\n .companyIntroduction-feature-item {\n padding: 0 15px;\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n position: relative;\n z-index: 1;\n .companyIntroduction-feature-item-icon {\n width: 50px;\n height: 50px;\n margin-bottom: 5px;\n display: flex;\n align-items: center;\n justify-content: center;\n img {\n width: 50px;\n height: 50px;\n }\n }\n .companyIntroduction-feature-item-title {\n font-size: 18px;\n font-weight: 500;\n line-height: 1;\n color: rgba(0, 0, 0, 0.5);\n }\n }\n }\n\n .companyIntroduction-moreMenu {\n margin-top: 50px;\n margin-left: auto;\n margin-right: auto;\n width: 120px;\n padding: 9px 20px;\n background: var(--theme-more-btn-color);\n border-radius: 6px;\n color: #fff;\n font-size: 16px;\n cursor: pointer;\n font-weight: 500;\n line-height: 1;\n transition: all 0.3s ease-in-out;\n text-align: center;\n position: relative;\n z-index: 1;\n &:hover {\n box-shadow: var(--theme-more-btn-hover-shadow);\n }\n }\n }\n\n .style2-companyIntroduction-moreMenu-bg {\n max-width: 100%;\n height: auto;\n pointer-events: none;\n border: none;\n position: absolute;\n top: 0;\n left: 0;\n z-index: 0;\n object-fit: cover;\n }\n}\n</style>\n\n","import mod from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./companyIntroduction.vue?vue&type=script&lang=js\"; export default mod; export * from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./companyIntroduction.vue?vue&type=script&lang=js\"","import { render, staticRenderFns } from \"./companyIntroduction.vue?vue&type=template&id=29fbc5fe&scoped=true\"\nimport script from \"./companyIntroduction.vue?vue&type=script&lang=js\"\nexport * from \"./companyIntroduction.vue?vue&type=script&lang=js\"\nimport style0 from \"./companyIntroduction.vue?vue&type=style&index=0&id=29fbc5fe&prod&scoped=true&lang=scss\"\n\n\n/* normalize component */\nimport normalizer from \"!../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n \"29fbc5fe\",\n null\n \n)\n\nexport default component.exports","import companyIntroduction from './companyIntroduction.vue'\n\ncompanyIntroduction.install = Vue => Vue.component(companyIntroduction.name, companyIntroduction)\n\nexport default companyIntroduction\n","var render = function render(){var _vm=this,_c=_vm._self._c;return _c('div',{staticClass:\"floatNav-component\",class:_vm.theme},[(_vm.clickDisabled)?_c('div',{staticClass:\"float-nav-click-disabled-mask\"}):_vm._e(),(_vm.styleType === 'style1')?_c('ul',{staticClass:\"side-nav-style1 special-border\"},[_vm._l((_vm.sideiItem),function(item,index){return _c('li',{key:index,staticClass:\"side-item\",on:{\"click\":function($event){return _vm.jump(item)}}},[_c('div',{staticClass:\"side-label\"},[_c('img',{attrs:{\"src\":item.icon,\"alt\":item.label}}),_c('h4',[_vm._v(_vm._s(item.label))])]),(item.desc)?_c('div',{staticClass:\"side-desc\",domProps:{\"innerHTML\":_vm._s(item.desc)}}):_vm._e()])}),_c('li',{staticClass:\"side-item side-item-top\",on:{\"click\":_vm.handleToTop}},[_vm._m(0)])],2):_vm._e(),(_vm.styleType === 'style2')?_c('div',[_c('ul',{staticClass:\"side-nav-style2\",staticStyle:{\"padding\":\"20px 0\"}},_vm._l((_vm.sideiItemNew),function(item,index){return _c('li',{key:index,staticClass:\"side-item\",on:{\"click\":function($event){return _vm.jump(item)}}},[_c('div',{staticClass:\"side-label\"},[_c('i',{staticClass:\"iconfont\",class:item.iconClass}),_c('h4',[_vm._v(_vm._s(item.label))])])])}),0),_c('ul',{staticClass:\"side-nav-style2\",staticStyle:{\"margin-top\":\"16px\"}},[_c('li',{staticClass:\"side-item side-item-top\",on:{\"click\":_vm.handleToTop}},[_vm._m(1)])])]):_vm._e()])\n}\nvar staticRenderFns = [function (){var _vm=this,_c=_vm._self._c;return _c('div',{staticClass:\"side-label\"},[_c('img',{attrs:{\"src\":require(\"../../assets/top-icon.png\"),\"alt\":\"\"}}),_c('h4',[_vm._v(\"Top\")])])\n},function (){var _vm=this,_c=_vm._self._c;return _c('div',{staticClass:\"side-label\"},[_c('i',{staticClass:\"iconfont icon-a-zu126\"}),_c('h4',[_vm._v(\"Top\")])])\n}]\n\nexport { render, staticRenderFns }","<template>\n <div class=\"floatNav-component\" :class=\"theme\">\n <!-- 点击事件禁用遮罩 -->\n <div v-if=\"clickDisabled\" class=\"float-nav-click-disabled-mask\" />\n <ul v-if=\"styleType === 'style1'\" class=\"side-nav-style1 special-border\">\n <li\n v-for=\"(item, index) in sideiItem\"\n :key=\"index\"\n class=\"side-item\"\n @click=\"jump(item)\"\n >\n <div class=\"side-label\">\n <img :src=\"item.icon\" :alt=\"item.label\">\n <h4>{{ item.label }}</h4>\n </div>\n <div v-if=\"item.desc\" class=\"side-desc\" v-html=\"item.desc\" />\n </li>\n <li class=\"side-item side-item-top\" @click=\"handleToTop\">\n <div class=\"side-label\">\n <img src=\"../../assets/top-icon.png\" alt=\"\">\n <h4>Top</h4>\n </div>\n </li>\n </ul>\n <div v-if=\"styleType === 'style2'\">\n <ul class=\"side-nav-style2\" style=\"padding: 20px 0;\">\n <li v-for=\"(item, index) in sideiItemNew\" :key=\"index\" class=\"side-item\" @click=\"jump(item)\">\n <div class=\"side-label\">\n <i :class=\"item.iconClass\" class=\"iconfont\" />\n <h4>{{ item.label }}</h4>\n </div>\n </li>\n </ul>\n <ul class=\"side-nav-style2\" style=\"margin-top: 16px;\">\n <li class=\"side-item side-item-top\" @click=\"handleToTop\">\n <div class=\"side-label\">\n <i class=\"iconfont icon-a-zu126\" />\n <h4>Top</h4>\n </div>\n </li>\n </ul>\n </div>\n </div>\n</template>\n\n<script>\nexport default {\n name: 'FloatNavComponent',\n props: {\n styleType: {\n type: String,\n default: ''\n },\n footerInfo: {\n type: Object,\n default: () => ({\n tel: '',\n whatsapp: '',\n email: ''\n })\n },\n clickDisabled: {\n type: Boolean,\n default: false\n },\n theme: {\n type: String,\n default: ''\n }\n },\n computed: {\n sideiItem() {\n return [\n {\n icon: require('../../assets/telephone.png'),\n label: 'Contact',\n url: `tel:${this.$props.footerInfo.tel}`,\n thirdSoft: 'Tel',\n desc: `<div\">\n <h6>Contant Us</h6>\n <p>${this.$props.footerInfo.tel}</p>\n </div>`\n },\n {\n icon: require('../../assets/chat.png'),\n label: 'Online',\n url: `/inquiry?maxCatgId=${this.maxCatgId}`\n },\n {\n icon: require('../../assets/whatsapp.png'),\n label: 'WhatsApp',\n thirdSoft: 'WhatsApp',\n url: `https://wa.me/${this.$props.footerInfo.whatsapp}`,\n desc: `<div>\n <h6>WhatsApp</h6>\n <p>${this.$props.footerInfo.whatsapp}</p>\n </div>`\n },\n {\n icon: require('../../assets/e-mail.png'),\n label: 'Email',\n thirdSoft: 'Email',\n url: `mailto:${this.$props.footerInfo.email}`,\n desc: `<div>\n <h6>Email</h6>\n <p>${this.$props.footerInfo.email}</p>\n </div>`\n }\n ]\n },\n sideiItemNew() {\n return [\n {\n iconClass: 'icon-a-zu107',\n label: 'Contact',\n url: `tel:${this.$props.footerInfo.tel}`,\n thirdSoft: 'Tel',\n desc: `<div\">\n <h6>Contant Us</h6>\n <p>${this.$props.footerInfo.tel}</p>\n </div>`\n },\n {\n iconClass: 'icon-link-chain--create-hyperlink-link-make-unlink-conn',\n label: 'Online',\n url: `/inquiry?maxCatgId=${this.maxCatgId}`\n },\n {\n iconClass: 'icon-a-zu118',\n label: 'WhatsApp',\n thirdSoft: 'WhatsApp',\n url: `https://wa.me/${this.$props.footerInfo.whatsapp}`,\n desc: `<div>\n <h6>WhatsApp</h6>\n <p>${this.$props.footerInfo.whatsapp}</p>\n </div>`\n },\n {\n iconClass: 'icon-a-zu122',\n label: 'Email',\n thirdSoft: 'Email',\n url: `mailto:${this.$props.footerInfo.email}`,\n desc: `<div>\n <h6>Email</h6>\n <p>${this.$props.footerInfo.email}</p>\n </div>`\n }\n ]\n }\n },\n methods: {\n handleToTop() {\n window.scrollTo({\n top: 0,\n behavior: 'smooth'\n })\n },\n async jump(row) {\n let thirdAccount = ''\n if (row.thirdSoft === 'Tel') {\n thirdAccount = this.$props.footerInfo.tel\n }\n if (row.thirdSoft === 'WhatsApp') {\n thirdAccount = this.$props.footerInfo.whatsapp\n }\n if (row.thirdSoft === 'Email') {\n thirdAccount = this.$props.footerInfo.email\n }\n const data = {\n equipment: this.$store.state.app.device,\n thirdSoft: row.thirdSoft,\n thirdAccount: thirdAccount\n }\n if (row.thirdSoft) {\n try {\n await this.$axios.post('/web/thirdItemSave', data)\n } catch (err) {\n console.log(err)\n }\n }\n if (row.url) {\n window.open(row.url)\n }\n }\n }\n}\n</script>\n\n<style scoped lang=\"scss\">\n@import '../../assets/icons/iconfont.css';\n.floatNav-component {\n position: fixed;\n top: 200px;\n right: 0;\n z-index: 999;\n\n ul {\n padding-inline-start: 0;\n margin-block-start: 0;\n margin-block-end: 0;\n }\n\n .float-nav-click-disabled-mask {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n z-index: 1000;\n }\n\n .side-nav-style1 {\n display: flex;\n flex-direction: column;\n align-items: flex-end;\n @mixin active {\n .side-desc {\n width: max-content;\n padding: 12px 24px;\n visibility: visible;\n }\n }\n .side-item {\n display: flex;\n align-items: center;\n cursor: pointer;\n &:hover {\n @include active;\n }\n .side-label {\n width: 72px;\n height: 72px;\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n background-color: #fff;\n box-shadow: 0px 2px 6px 1px rgba(1,95,232,0.13);\n img {\n width: 24px;\n height: 24px;\n margin-bottom: 5px;\n }\n h4 {\n margin-top: 0;\n margin-bottom: 0;\n color: #323436;\n font-size: 12px;\n }\n }\n\n &:nth-last-child(2) {\n .side-label {\n img {\n width: 26px;\n height: 20px;\n }\n }\n }\n .side-desc {\n width: 0;\n height: 72px;\n visibility: hidden;\n background-color: #015fe8;\n color: #fff;\n }\n }\n .side-item-active {\n @include active;\n }\n .side-item-top {\n margin-top: 16px;\n }\n }\n\n .side-nav-style2 {\n display: flex;\n flex-direction: column;\n align-items: flex-end;\n // border: var(--theme-float-nav-border);\n border-radius: 50px;\n overflow: hidden;\n background-color: #fff;\n box-shadow: var(--theme-float-nav-shadow);\n\n .side-item {\n display: flex;\n align-items: center;\n cursor: pointer;\n &:hover {\n .side-label {\n .iconfont {\n color: var(--theme-float-nav-icon-active-color);\n }\n }\n h4 {\n color: var(--theme-float-nav-text-active-color);\n }\n }\n\n .side-label {\n width: 100px;\n height: 100px;\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n background-color: #fff;\n .iconfont {\n margin-bottom: 5px;\n font-size: 39px;\n color: var(--theme-float-nav-icon-color);\n }\n h4 {\n margin-top: 0;\n margin-bottom: 0;\n color: var(--theme-float-nav-text-color);\n font-size: 15px;\n font-weight: 400;\n text-align: center;\n }\n }\n }\n .side-item-top {\n }\n }\n}\n</style>\n","import mod from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./floatNav.vue?vue&type=script&lang=js\"; export default mod; export * from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./floatNav.vue?vue&type=script&lang=js\"","import { render, staticRenderFns } from \"./floatNav.vue?vue&type=template&id=487febec&scoped=true\"\nimport script from \"./floatNav.vue?vue&type=script&lang=js\"\nexport * from \"./floatNav.vue?vue&type=script&lang=js\"\nimport style0 from \"./floatNav.vue?vue&type=style&index=0&id=487febec&prod&scoped=true&lang=scss\"\n\n\n/* normalize component */\nimport normalizer from \"!../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n \"487febec\",\n null\n \n)\n\nexport default component.exports","import floatNav from './floatNav.vue'\n\nfloatNav.install = Vue => Vue.component(floatNav.name, floatNav)\n\nexport default floatNav\n","var render = function render(){var _vm=this,_c=_vm._self._c;return _c('div',{staticClass:\"footerNav-component\",class:_vm.theme},[(_vm.clickDisabled)?_c('div',{staticClass:\"footer-nav-click-disabled-mask\"}):_vm._e(),(_vm.styleType === 'style1')?_c('div',{staticClass:\"footerNav-component-style1\"},[_c('el-row',{staticClass:\"footerNav-compoennt-contact-us-row\",attrs:{\"justify\":\"center\"}},[_c('el-col',{attrs:{\"span\":6}},[_c('div',{staticClass:\"footerNav-compoennt-contact-us\"},[_c('div',{staticClass:\"footerNav-compoennt-contact-us-title\"},[_vm._v(_vm._s(_vm.contactWay.title))]),_c('div',{staticClass:\"footerNav-compoennt-contact-us-content\",domProps:{\"innerHTML\":_vm._s(_vm.contactWay.content)}})])]),_c('el-col',{attrs:{\"span\":6}},[_c('div',{staticClass:\"footerNav-compoennt-contact-us\"},[_c('div',{staticClass:\"footerNav-compoennt-contact-us-title\"},[_vm._v(_vm._s(_vm.friendlyLink.title))]),_c('div',{staticClass:\"footerNav-compoennt-contact-us-content\"},_vm._l((_vm.friendlyLink.list),function(item,index){return _c('div',{key:index,staticClass:\"footerNav-compoennt-contact-us-content-item\"},[_c('a',{directives:[{name:\"show\",rawName:\"v-show\",value:(item.isShow),expression:\"item.isShow\"}],attrs:{\"href\":item.linkSite,\"target\":item.isBlank ? '_blank' : '_self'}},[_vm._v(_vm._s(item.linkTitle))])])}),0)])]),_c('el-col',{attrs:{\"span\":6}},[_c('div',{staticClass:\"footerNav-compoennt-contact-us\"},[_c('div',{staticClass:\"footerNav-compoennt-contact-us-title\"},[_vm._v(_vm._s(_vm.productCategory.title))]),_c('div',{staticClass:\"footerNav-compoennt-contact-us-content\"},_vm._l((_vm.productCategory.list),function(item,index){return _c('div',{key:index,staticClass:\"footerNav-compoennt-contact-us-content-item\"},[_c('span',{directives:[{name:\"show\",rawName:\"v-show\",value:(item.isShow),expression:\"item.isShow\"}],on:{\"click\":function($event){$event.stopPropagation();return _vm.handleClick(item)}}},[_vm._v(_vm._s(item.categoryTitle))])])}),0)])]),_c('el-col',{attrs:{\"span\":6}},[_c('div',{staticClass:\"footerNav-compoennt-contact-us-qrcode\"},[_c('img',{staticClass:\"footerNav-compoennt-contact-us-qrcode-img\",attrs:{\"src\":_vm.qrcode,\"alt\":\"二维码\"}}),_c('div',{staticClass:\"footerNav-compoennt-contact-us-qrcode-text\"},[_vm._v(\"Shandong Chengda Truck Trailer Co., Ltd\")])])])],1),_c('div',{staticClass:\"footerNav-compoennt-copyright\"},[_vm._v(\" Copyright © Shandong Chengda Truck Trailer Co., Ltd. All rights reserved.Privacy Policy \")])],1):_vm._e(),(_vm.styleType === 'style2')?_c('div',{staticClass:\"footerNav-component-style2\"},[_c('div',{staticClass:\"footerNav-compoennt-style2-container\"},[_c('el-row',{staticClass:\"footerNav-compoennt-contact-us-row\",attrs:{\"justify\":\"center\"}},[_c('el-col',{attrs:{\"span\":6}},[_c('div',{staticClass:\"footerNav-compoennt-contact-us-qrcode\"},[_c('img',{staticClass:\"footerNav-compoennt-contact-us-qrcode-img\",attrs:{\"src\":_vm.qrcode,\"alt\":\"二维码\"}}),_c('div',{staticClass:\"footerNav-compoennt-contact-us-qrcode-text\"},[_vm._v(\"Shandong Chengda Truck Trailer Co., Ltd\")])])]),_c('el-col',{attrs:{\"span\":8}},[_c('div',{staticClass:\"footerNav-compoennt-contact-us\"},[_c('div',{staticClass:\"footerNav-compoennt-contact-us-title\"},[_vm._v(_vm._s(_vm.contactWay.title))]),_c('div',{staticClass:\"footerNav-compoennt-contact-us-content\",domProps:{\"innerHTML\":_vm._s(_vm.contactWay.content)}})])]),_c('el-col',{attrs:{\"span\":5}},[_c('div',{staticClass:\"footerNav-compoennt-contact-us\"},[_c('div',{staticClass:\"footerNav-compoennt-contact-us-title\"},[_vm._v(_vm._s(_vm.friendlyLink.title))]),_c('div',{staticClass:\"footerNav-compoennt-contact-us-content\"},_vm._l((_vm.friendlyLink.list),function(item,index){return _c('div',{key:index,staticClass:\"footerNav-compoennt-contact-us-content-item\"},[_c('a',{directives:[{name:\"show\",rawName:\"v-show\",value:(item.isShow),expression:\"item.isShow\"}],attrs:{\"href\":item.linkSite,\"target\":item.isBlank ? '_blank' : '_self'}},[_vm._v(_vm._s(item.linkTitle))])])}),0)])]),_c('el-col',{attrs:{\"span\":5}},[_c('div',{staticClass:\"footerNav-compoennt-contact-us\"},[_c('div',{staticClass:\"footerNav-compoennt-contact-us-title\"},[_vm._v(_vm._s(_vm.productCategory.title))]),_c('div',{staticClass:\"footerNav-compoennt-contact-us-content\"},_vm._l((_vm.productCategory.list),function(item,index){return _c('div',{key:index,staticClass:\"footerNav-compoennt-contact-us-content-item\"},[_c('span',{directives:[{name:\"show\",rawName:\"v-show\",value:(item.isShow),expression:\"item.isShow\"}],on:{\"click\":function($event){$event.stopPropagation();return _vm.handleClick(item)}}},[_vm._v(_vm._s(item.categoryTitle))])])}),0)])])],1),_c('div',{staticClass:\"footerNav-compoennt-copyright\"},[_vm._v(\" Copyright © Shandong Chengda Truck Trailer Co., Ltd. All rights reserved.Privacy Policy \")])],1)]):_vm._e()])\n}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","<template>\n <div class=\"footerNav-component\" :class=\"theme\">\n <!-- 点击事件禁用遮罩 -->\n <div v-if=\"clickDisabled\" class=\"footer-nav-click-disabled-mask\" />\n <div v-if=\"styleType === 'style1'\" class=\"footerNav-component-style1\">\n <el-row justify=\"center\" class=\"footerNav-compoennt-contact-us-row\">\n <el-col :span=\"6\">\n <div class=\"footerNav-compoennt-contact-us\">\n <div class=\"footerNav-compoennt-contact-us-title\">{{ contactWay.title }}</div>\n <div class=\"footerNav-compoennt-contact-us-content\" v-html=\"contactWay.content\" />\n </div>\n </el-col>\n <el-col :span=\"6\">\n <div class=\"footerNav-compoennt-contact-us\">\n <div class=\"footerNav-compoennt-contact-us-title\">{{ friendlyLink.title }}</div>\n <div class=\"footerNav-compoennt-contact-us-content\">\n <div v-for=\"(item, index) in friendlyLink.list\" :key=\"index\" class=\"footerNav-compoennt-contact-us-content-item\">\n <a v-show=\"item.isShow\" :href=\"item.linkSite\" :target=\"item.isBlank ? '_blank' : '_self'\">{{ item.linkTitle }}</a>\n </div>\n </div>\n </div>\n </el-col>\n <el-col :span=\"6\">\n <div class=\"footerNav-compoennt-contact-us\">\n <div class=\"footerNav-compoennt-contact-us-title\">{{ productCategory.title }}</div>\n <div class=\"footerNav-compoennt-contact-us-content\">\n <div v-for=\"(item, index) in productCategory.list\" :key=\"index\" class=\"footerNav-compoennt-contact-us-content-item\">\n <span v-show=\"item.isShow\" @click.stop=\"handleClick(item)\">{{ item.categoryTitle }}</span>\n </div>\n </div>\n </div>\n </el-col>\n <el-col :span=\"6\">\n <div class=\"footerNav-compoennt-contact-us-qrcode\">\n <img class=\"footerNav-compoennt-contact-us-qrcode-img\" :src=\"qrcode\" alt=\"二维码\">\n <div class=\"footerNav-compoennt-contact-us-qrcode-text\">Shandong Chengda Truck Trailer Co., Ltd</div>\n </div>\n </el-col>\n </el-row>\n <div class=\"footerNav-compoennt-copyright\">\n Copyright © Shandong Chengda Truck Trailer Co., Ltd. All rights reserved.Privacy Policy\n </div>\n </div>\n <div v-if=\"styleType === 'style2'\" class=\"footerNav-component-style2\">\n <div class=\"footerNav-compoennt-style2-container\">\n <el-row justify=\"center\" class=\"footerNav-compoennt-contact-us-row\">\n <el-col :span=\"6\">\n <div class=\"footerNav-compoennt-contact-us-qrcode\">\n <img class=\"footerNav-compoennt-contact-us-qrcode-img\" :src=\"qrcode\" alt=\"二维码\">\n <div class=\"footerNav-compoennt-contact-us-qrcode-text\">Shandong Chengda Truck Trailer Co., Ltd</div>\n </div>\n </el-col>\n <el-col :span=\"8\">\n <div class=\"footerNav-compoennt-contact-us\">\n <div class=\"footerNav-compoennt-contact-us-title\">{{ contactWay.title }}</div>\n <div class=\"footerNav-compoennt-contact-us-content\" v-html=\"contactWay.content\" />\n </div>\n </el-col>\n <el-col :span=\"5\">\n <div class=\"footerNav-compoennt-contact-us\">\n <div class=\"footerNav-compoennt-contact-us-title\">{{ friendlyLink.title }}</div>\n <div class=\"footerNav-compoennt-contact-us-content\">\n <div v-for=\"(item, index) in friendlyLink.list\" :key=\"index\" class=\"footerNav-compoennt-contact-us-content-item\">\n <a v-show=\"item.isShow\" :href=\"item.linkSite\" :target=\"item.isBlank ? '_blank' : '_self'\">{{ item.linkTitle }}</a>\n </div>\n </div>\n </div>\n </el-col>\n <el-col :span=\"5\">\n <div class=\"footerNav-compoennt-contact-us\">\n <div class=\"footerNav-compoennt-contact-us-title\">{{ productCategory.title }}</div>\n <div class=\"footerNav-compoennt-contact-us-content\">\n <div v-for=\"(item, index) in productCategory.list\" :key=\"index\" class=\"footerNav-compoennt-contact-us-content-item\">\n <span v-show=\"item.isShow\" @click.stop=\"handleClick(item)\">{{ item.categoryTitle }}</span>\n </div>\n </div>\n </div>\n </el-col>\n </el-row>\n <div class=\"footerNav-compoennt-copyright\">\n Copyright © Shandong Chengda Truck Trailer Co., Ltd. All rights reserved.Privacy Policy\n </div>\n </div>\n </div>\n </div>\n</template>\n\n<script>\nexport default {\n name: 'FooterNavComponent',\n props: {\n styleType: {\n type: String,\n default: 'style1'\n },\n contactWay: {\n title: '联系我们',\n content: ''\n },\n friendlyLink: {\n list: []\n },\n productCategory: {\n list: []\n },\n qrcode: {\n type: String,\n default: ''\n },\n theme: {\n type: String,\n default: ''\n },\n clickDisabled: {\n type: Boolean,\n default: false\n }\n },\n methods: {\n handleClick(item) {\n const { href } = this.$router.resolve({\n path: '/base/product/category',\n query: { categoryId: item.categoryId }\n })\n window.open(href, item.isBlank ? '_blank' : '_self')\n }\n }\n}\n</script>\n\n<style scoped lang=\"scss\">\n.footerNav-component {\n position: relative;\n .footer-nav-click-disabled-mask {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n z-index: 1000;\n }\n .footerNav-component-style1 {\n background-color: #152235;\n width: 100%;\n height: auto;\n .footerNav-compoennt-contact-us-row {\n padding: 0 16%;\n display: flex;\n }\n\n .footerNav-compoennt-contact-us {\n padding: 52px 15px 0;\n margin-bottom: 16px;\n .footerNav-compoennt-contact-us-title {\n font-size: 18px;\n font-weight: 700;\n line-height: 27px;\n color: #fff;\n margin-bottom: 18px;\n }\n .footerNav-compoennt-contact-us-content {\n margin-bottom: 16px;\n color: #b0b6b9;\n font-size: 14px;\n font-weight: 400;\n line-height: 21px;\n ::v-deep p {\n word-break: break-all !important;\n white-space: pre-wrap !important;\n }\n ::v-deep span {\n word-break: break-all !important;\n white-space: pre-wrap !important;\n }\n\n .footerNav-compoennt-contact-us-content-item {\n height: 21px;\n line-height: 21px;\n margin-bottom: 16px;\n a {\n font-size: 14px;\n font-weight: 400;\n color: #b0b6b9;\n }\n }\n }\n }\n .footerNav-compoennt-contact-us-qrcode {\n padding: 52px 15px 0;\n width: fit-content;\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n .footerNav-compoennt-contact-us-qrcode-img {\n width: 212px;\n height: 212px;\n }\n .footerNav-compoennt-contact-us-qrcode-text {\n margin-top: 4px;\n width: 128px;\n text-align: center;\n color: #f0f0f0;\n font-size: 12px;\n line-height: 1.5;\n }\n }\n .footerNav-compoennt-copyright {\n width: 100%;\n height: 72px;\n line-height: 72px;\n text-align: center;\n color: #fff;\n font-size: 14px;\n font-weight: 400;\n border-top: 1px solid #eaeaea;\n }\n }\n\n .footerNav-component-style2 {\n width: 100%;\n height: auto;\n background-color: #191919;\n .footerNav-compoennt-style2-container {\n margin: 0 auto;\n padding-top: 112px;\n max-width: 1334px;\n }\n .footerNav-compoennt-contact-us {\n margin-bottom: 60px;\n padding-right: 148px;\n .footerNav-compoennt-contact-us-title {\n font-size: 22px;\n font-weight: 400;\n line-height: 22px;\n color: #fff;\n margin-bottom: 50px;\n }\n .footerNav-compoennt-contact-us-content {\n color: rgba(255, 255, 255, 0.5);\n font-size: 16px;\n font-weight: 500;\n line-height: 1.5;\n ::v-deep p {\n word-break: break-all !important;\n white-space: pre-wrap !important;\n }\n ::v-deep span {\n word-break: break-all !important;\n white-space: pre-wrap !important;\n }\n\n .footerNav-compoennt-contact-us-content-item {\n color: rgba(255, 255, 255, 0.5);\n font-size: 16px;\n font-weight: 500;\n line-height: 1.5;\n a {\n font-size: 14px;\n font-weight: 400;\n color: #b0b6b9;\n }\n }\n }\n }\n .footerNav-compoennt-contact-us-qrcode {\n width: fit-content;\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n justify-content: center;\n .footerNav-compoennt-contact-us-qrcode-img {\n width: 212px;\n height: 212px;\n }\n .footerNav-compoennt-contact-us-qrcode-text {\n margin-top: 4px;\n width: 128px;\n text-align: left;\n color: #f0f0f0;\n font-size: 12px;\n line-height: 1.5;\n }\n }\n .footerNav-compoennt-copyright {\n width: 100%;\n padding-bottom: 38px;\n line-height: 1;\n text-align: center;\n color: rgba(255, 255, 255, 0.8);\n font-size: 18px;\n font-weight: 400;\n }\n }\n}\n</style>\n","import mod from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./footerNav.vue?vue&type=script&lang=js\"; export default mod; export * from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./footerNav.vue?vue&type=script&lang=js\"","import { render, staticRenderFns } from \"./footerNav.vue?vue&type=template&id=6f2164cf&scoped=true\"\nimport script from \"./footerNav.vue?vue&type=script&lang=js\"\nexport * from \"./footerNav.vue?vue&type=script&lang=js\"\nimport style0 from \"./footerNav.vue?vue&type=style&index=0&id=6f2164cf&prod&scoped=true&lang=scss\"\n\n\n/* normalize component */\nimport normalizer from \"!../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n \"6f2164cf\",\n null\n \n)\n\nexport default component.exports","import footerNav from './footerNav.vue'\n\nfooterNav.install = Vue => Vue.component(footerNav.name, footerNav)\n\nexport default footerNav\n","var render = function render(){var _vm=this,_c=_vm._self._c;return _c('div',{staticClass:\"header-nav-component\",class:_vm.theme},[(_vm.clickDisabled)?_c('div',{staticClass:\"header-nav-component-click-disabled-mask\"}):_vm._e(),(_vm.styleType === 'style1')?_c('div',{staticClass:\"header-nav-style1\"},[_c('div',{staticClass:\"headerNav-component--style1__logo\"},[_c('img',{attrs:{\"src\":_vm.logo,\"alt\":\"\"}})]),_c('div',{staticClass:\"headerNav-component--style1__menu\"},[(_vm.menus.length > 0)?_c('MenuComponent',{attrs:{\"menus\":_vm.menus,\"mode\":\"horizontal\"}}):_vm._e()],1),_c('div',{staticClass:\"headerNav-component--style1__operate\"},[_c('div',{staticClass:\"headerNav-component--style1__operate-search\"},[_c('i',{staticClass:\"headerNav-component--style1__operate-search-icon el-icon-search\"}),_c('input',{directives:[{name:\"model\",rawName:\"v-model\",value:(_vm.searchText),expression:\"searchText\"}],staticClass:\"headerNav-component--style1__operate-search-input\",attrs:{\"type\":\"text\",\"placeholder\":\"搜索\"},domProps:{\"value\":(_vm.searchText)},on:{\"keydown\":function($event){if(!$event.type.indexOf('key')&&_vm._k($event.keyCode,\"enter\",13,$event.key,\"Enter\"))return null;return _vm.handleSearch.apply(null, arguments)},\"input\":function($event){if($event.target.composing)return;_vm.searchText=$event.target.value}}})]),_c('img',{staticClass:\"headerNav-component--style1__operate-language\",attrs:{\"src\":require(\"../../assets/language.png\")},on:{\"click\":_vm.changeLanguage}})])]):_vm._e(),(_vm.styleType === 'style2')?_c('div',{staticClass:\"header-nav-style2\"},[_c('div',{staticClass:\"headerNav-component--style2__left\"},[_c('div',{staticClass:\"headerNav-component--style2__menu\",on:{\"mouseenter\":_vm.handleMenuHover,\"mouseleave\":_vm.handleMenuLeave}},_vm._l((_vm.menus),function(item){return _c('div',{key:item.id,staticClass:\"headerNav-component--style2__menu-item\",on:{\"click\":function($event){return _vm.handleClickMenu(item)}}},[_vm._v(\" \"+_vm._s(item.name || item.label)+\" \")])}),0),_c('div',{staticClass:\"headerNav-component--style2__logo\"},[_c('img',{attrs:{\"src\":_vm.logo,\"alt\":\"\"}})])]),_c('div',{staticClass:\"headerNav-component--style2__operate\"},[_c('div',{staticClass:\"headerNav-component--style2__operate-search\"},[_c('i',{staticClass:\"iconfont headerNav-component--style2__operate-search-icon icon-sousuo\"}),_c('input',{directives:[{name:\"model\",rawName:\"v-model\",value:(_vm.searchText),expression:\"searchText\"}],staticClass:\"headerNav-component--style2__operate-search-input\",attrs:{\"type\":\"text\",\"placeholder\":\"搜索\"},domProps:{\"value\":(_vm.searchText)},on:{\"keydown\":function($event){if(!$event.type.indexOf('key')&&_vm._k($event.keyCode,\"enter\",13,$event.key,\"Enter\"))return null;return _vm.handleSearch.apply(null, arguments)},\"input\":function($event){if($event.target.composing)return;_vm.searchText=$event.target.value}}})]),_c('i',{staticClass:\"iconfont headerNav-component--style2__operate-language icon-a-zu61\",on:{\"click\":_vm.changeLanguage}})]),_c('div',{staticClass:\"headerNav-component-style2__submenu\",class:{'show': _vm.showSubMenu},on:{\"mouseenter\":_vm.handleSubMenuContainerEnter,\"mouseleave\":_vm.handleSubMenuContainerLeave}},_vm._l((_vm.menus),function(item,index){return _c('div',{key:index},[(item.children && item.children.length > 0)?_c('div',{staticClass:\"headerNav-component-style2__submenu-container\"},_vm._l((item.children),function(secondMenu,secondIndex){return _c('div',{key:secondIndex,staticClass:\"headerNav-component-style2__submenu-container__item\"},[_c('div',{staticClass:\"headerNav-component-style2__submenu-container__item__title\",on:{\"click\":function($event){return _vm.handleClickMenu(secondMenu)}}},[_vm._v(_vm._s(secondMenu.name || secondMenu.label))]),(secondMenu.children && secondMenu.children.length > 0)?_c('div',{staticClass:\"headerNav-component-style2__thirdmenu-container\"},_vm._l((secondMenu.children),function(thirdMenu,thirdIndex){return _c('div',{key:thirdIndex,staticClass:\"headerNav-component-style2__thirdmenu-container__item\"},[_c('div',{staticClass:\"headerNav-component-style2__thirdmenu-container__item__title\",on:{\"click\":function($event){return _vm.handleClickMenu(thirdMenu)}}},[_vm._v(_vm._s(thirdMenu.name || thirdMenu.label))]),(thirdMenu.children && thirdMenu.children.length > 0)?_c('div',{staticClass:\"headerNav-component-style2__thirdmenu-container__item__submenu\"},_vm._l((thirdMenu.children),function(fourthMenu,fourthIndex){return _c('div',{key:fourthIndex,staticClass:\"headerNav-component-style2__thirdmenu-container__item__submenu__item\",on:{\"click\":function($event){return _vm.handleClickMenu(fourthMenu)}}},[_vm._v(_vm._s(fourthMenu.name || fourthMenu.label))])}),0):_vm._e()])}),0):_vm._e()])}),0):_vm._e()])}),0)]):_vm._e(),(_vm.styleType === 'style3')?_c('div',{staticClass:\"header-nav-style3\"},[_c('div',{staticClass:\"headerNav-component--style3__menu\"},[_c('MenuComponent',{attrs:{\"menus\":_vm.menus,\"mode\":\"horizontal\",\"background-color\":\"#fff\",\"text-color\":\"#333\",\"active-text-color\":\"#409EFF\"}})],1)]):_vm._e(),_c('ChangeLanguageDialog',{attrs:{\"visible\":_vm.showLanguageDialog},on:{\"close\":function($event){_vm.showLanguageDialog = false},\"select\":_vm.handleLanguageSelect}})],1)\n}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","// 点击菜单\nconst handleClickMenu = (menu) => {\n // 如果有子节点,则当前不可点击\n if (menu.children && menu.children.length > 0) {\n return\n }\n // 点击菜单项的回调函数\n console.log('点击了菜单项:', menu)\n // this.$router.push({\n // path: menu.url || ''\n // })\n}\n// 递归渲染子菜单\nconst renderMenuItem = (createElement, menuItem) => {\n // 如果有子菜单,渲染为submenu\n if (menuItem.children && menuItem.children.length > 0) {\n return createElement(\n 'el-submenu',\n {\n props: {\n index: menuItem.id ? menuItem.id.toString() : ''\n },\n on: {\n click: () => {\n // 点击菜单项的回调函数\n handleClickMenu(menuItem)\n }\n }\n },\n [\n createElement('template', {\n slot: 'title'\n }, [menuItem.name || menuItem.label || '']),\n // 递归渲染子菜单\n ...menuItem.children.map(item => renderMenuItem(createElement, item))\n ]\n )\n } else {\n // 没有子菜单,渲染为menu-item\n return createElement(\n 'el-menu-item',\n {\n props: {\n index: menuItem.id ? menuItem.id.toString() : ''\n },\n on: {\n click: () => {\n // 点击菜单项的回调函数\n handleClickMenu(menuItem)\n }\n }\n },\n [menuItem.name || menuItem.label || '']\n )\n }\n}\n\nconst MenuComponent = {\n props: {\n menus: {\n type: Array,\n default: () => [] // [ { id, name, path, children: [....] } ]\n },\n mode: {\n type: String,\n default: 'horizontal', // 可选: 'horizontal' 或 'vertical'\n validator: (value) => ['horizontal', 'vertical'].includes(value)\n },\n defaultActive: {\n type: String,\n default: ''\n },\n backgroundColor: {\n type: String,\n default: '#fff'\n },\n textColor: {\n type: String,\n default: '#000'\n },\n activeTextColor: {\n type: String,\n default: '#ffd04b'\n }\n },\n render: function(createElement) {\n return createElement(\n 'el-menu',\n {\n props: {\n defaultActive: 'home',\n mode: this.mode,\n backgroundColor: this.backgroundColor,\n textColor: this.textColor,\n activeTextColor: this.activeTextColor\n },\n on: {\n select: (index, indexPath) => {\n // 菜单选择事件\n console.log('选择了菜单:', index, indexPath)\n },\n open: (index, indexPath) => {\n // 子菜单展开事件\n console.log('展开了子菜单:', index, indexPath)\n },\n close: (index, indexPath) => {\n // 子菜单收起事件\n console.log('收起了子菜单:', index, indexPath)\n }\n }\n },\n // 渲染所有菜单项\n [\n renderMenuItem(createElement, {\n name: 'Home',\n id: 'home',\n path: '/home'\n }),\n this.menus.map(menu => renderMenuItem(createElement, menu))\n ]\n )\n }\n}\n\nexport default MenuComponent\n","var render = function render(){var _vm=this,_c=_vm._self._c;return _c('el-dialog',{attrs:{\"visible\":_vm.visible,\"width\":\"1334px\",\"before-close\":_vm.handleClose},on:{\"update:visible\":function($event){_vm.visible=$event}}},[_c('div',{staticClass:\"change-language-dialog\"},[_c('div',{staticClass:\"change-language-dialog-header\"},[_c('div',{staticClass:\"change-language-dialog-header-title\"},[_vm._v(\"选择区域/语言\")]),_c('div',{staticClass:\"change-language-dialog-header-input\"},[_c('i',{staticClass:\"el-icon-search\"}),_c('input',{directives:[{name:\"model\",rawName:\"v-model\",value:(_vm.searchText),expression:\"searchText\"}],attrs:{\"type\":\"text\",\"placeholder\":'搜索'},domProps:{\"value\":(_vm.searchText)},on:{\"keydown\":function($event){if(!$event.type.indexOf('key')&&_vm._k($event.keyCode,\"enter\",13,$event.key,\"Enter\"))return null;return _vm.handleSearch.apply(null, arguments)},\"input\":function($event){if($event.target.composing)return;_vm.searchText=$event.target.value}}})])]),_c('div',{staticClass:\"change-language-dialog-content\"},[_c('el-tabs',{model:{value:(_vm.activeTab),callback:function ($$v) {_vm.activeTab=$$v},expression:\"activeTab\"}},_vm._l((_vm.languageList),function(region){return _c('el-tab-pane',{key:region.id,attrs:{\"label\":region.name,\"name\":region.id}},_vm._l((region.languages),function(item){return _c('div',{key:item.id,staticClass:\"language-item\"},[_vm._v(\" \"+_vm._s(item.name)+\" \")])}),0)}),1)],1)])])\n}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","<template>\n <el-dialog\n :visible.sync=\"visible\"\n width=\"1334px\"\n :before-close=\"handleClose\"\n >\n <div class=\"change-language-dialog\">\n <div class=\"change-language-dialog-header\">\n <div class=\"change-language-dialog-header-title\">选择区域/语言</div>\n <div class=\"change-language-dialog-header-input\">\n <i class=\"el-icon-search\" />\n <input v-model=\"searchText\" type=\"text\" :placeholder=\"'搜索'\" @keydown.enter=\"handleSearch\">\n </div>\n </div>\n <div class=\"change-language-dialog-content\">\n <el-tabs v-model=\"activeTab\">\n <el-tab-pane v-for=\"region in languageList\" :label=\"region.name\" :name=\"region.id\" :key=\"region.id\">\n <div v-for=\"item in region.languages\" :key=\"item.id\" class=\"language-item\">\n {{ item.name }}\n </div>\n </el-tab-pane>\n </el-tabs>\n </div>\n </div>\n </el-dialog>\n</template>\n\n<script>\nexport default {\n name: 'ChangeLanguageDialog',\n props: {\n visible: {\n type: Boolean,\n default: false\n }\n },\n emits: ['close', 'select'],\n data() {\n return {\n activeTab: '',\n searchText: ''\n }\n },\n methods: {\n handleSearch() {\n\n },\n handleClose() {\n this.$emit('close')\n },\n handleLanguageSelect(item) {\n this.$emit('select', item)\n }\n }\n}\n</script>\n\n<style scoped lang=\"scss\">\n::v-deep .el-dialog {\n border-radius: 12px !important;\n}\n\n::v-deep .el-dialog__header {\n border-radius: 12px 12px 0 0 !important;\n}\n\n::v-deep .el-dialog__body {\n border-radius: 0 0 12px 12px !important;\n padding: 0 !important;\n}\n\n.change-language-dialog {\n padding: 10px 50px 93px;\n .change-language-dialog-header {\n display: flex;\n justify-content: space-between;\n align-items: center;\n .change-language-dialog-header-title {\n font-weight: bold;\n font-size: 16px;\n color: #000000;\n text-align: left;\n font-style: normal;\n text-transform: none;\n }\n .change-language-dialog-header-input {\n box-sizing: border-box;\n padding: 0 20px;\n width: 398px;\n height: 38px;\n display: flex;\n align-items: center;\n justify-content: flex-start;\n gap: 10px;\n border: 1px solid rgba(0, 0, 0, 0.1);\n border-radius: 10px;\n\n i {\n font-size: 15px;\n color: rgba(11, 11, 11, 0.2);\n }\n\n input {\n width: 100%;\n border: none;\n font-weight: 400;\n font-size: 15px;\n color: #111111;\n outline: none;\n // placeholder字体颜色\n &::placeholder {\n color: rgba(11, 11, 11, 0.2);\n }\n\n &::-webkit-input-placeholder {\n color: rgba(11, 11, 11, 0.2);\n }\n\n &::-moz-placeholder {\n color: rgba(11, 11, 11, 0.2);\n }\n\n &:-ms-input-placeholder {\n color: rgba(11, 11, 11, 0.2);\n }\n }\n }\n }\n}\n</style>\n","import mod from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./changeLanguageDialog.vue?vue&type=script&lang=js\"; export default mod; export * from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./changeLanguageDialog.vue?vue&type=script&lang=js\"","import { render, staticRenderFns } from \"./changeLanguageDialog.vue?vue&type=template&id=00547f6c&scoped=true\"\nimport script from \"./changeLanguageDialog.vue?vue&type=script&lang=js\"\nexport * from \"./changeLanguageDialog.vue?vue&type=script&lang=js\"\nimport style0 from \"./changeLanguageDialog.vue?vue&type=style&index=0&id=00547f6c&prod&scoped=true&lang=scss\"\n\n\n/* normalize component */\nimport normalizer from \"!../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n \"00547f6c\",\n null\n \n)\n\nexport default component.exports","<template>\n <div class=\"header-nav-component\" :class=\"theme\">\n <!-- 点击事件禁用遮罩 -->\n <div v-if=\"clickDisabled\" class=\"header-nav-component-click-disabled-mask\" />\n <div v-if=\"styleType === 'style1'\" class=\"header-nav-style1\">\n <div class=\"headerNav-component--style1__logo\">\n <img :src=\"logo\" alt=\"\">\n </div>\n <div class=\"headerNav-component--style1__menu\">\n <MenuComponent v-if=\"menus.length > 0\" :menus=\"menus\" mode=\"horizontal\" />\n </div>\n <div class=\"headerNav-component--style1__operate\">\n <div class=\"headerNav-component--style1__operate-search\">\n <i class=\"headerNav-component--style1__operate-search-icon el-icon-search\" />\n <input v-model=\"searchText\" type=\"text\" placeholder=\"搜索\" class=\"headerNav-component--style1__operate-search-input\" @keydown.enter=\"handleSearch\">\n </div>\n <img class=\"headerNav-component--style1__operate-language\" src=\"../../assets/language.png\" @click=\"changeLanguage\">\n </div>\n </div>\n <div v-if=\"styleType === 'style2'\" class=\"header-nav-style2\">\n <div class=\"headerNav-component--style2__left\">\n <div class=\"headerNav-component--style2__menu\" @mouseenter=\"handleMenuHover\" @mouseleave=\"handleMenuLeave\">\n <!-- <MenuComponent :menus=\"menus\" mode=\"horizontal\" /> -->\n <div v-for=\"item in menus\" :key=\"item.id\" class=\"headerNav-component--style2__menu-item\" @click=\"handleClickMenu(item)\">\n {{ item.name || item.label }}\n </div>\n </div>\n <div class=\"headerNav-component--style2__logo\">\n <img :src=\"logo\" alt=\"\">\n </div>\n </div>\n <div class=\"headerNav-component--style2__operate\">\n <div class=\"headerNav-component--style2__operate-search\">\n <i class=\"iconfont headerNav-component--style2__operate-search-icon icon-sousuo\" />\n <input v-model=\"searchText\" type=\"text\" placeholder=\"搜索\" class=\"headerNav-component--style2__operate-search-input\" @keydown.enter=\"handleSearch\">\n </div>\n <i class=\"iconfont headerNav-component--style2__operate-language icon-a-zu61\" @click=\"changeLanguage\" />\n </div>\n\n <div\n class=\"headerNav-component-style2__submenu\"\n :class=\"{'show': showSubMenu}\"\n @mouseenter=\"handleSubMenuContainerEnter\"\n @mouseleave=\"handleSubMenuContainerLeave\"\n >\n <div v-for=\"(item, index) in menus\" :key=\"index\">\n <div v-if=\"item.children && item.children.length > 0\" class=\"headerNav-component-style2__submenu-container\">\n <div v-for=\"(secondMenu, secondIndex) in item.children\" :key=\"secondIndex\" class=\"headerNav-component-style2__submenu-container__item\">\n <div class=\"headerNav-component-style2__submenu-container__item__title\" @click=\"handleClickMenu(secondMenu)\">{{ secondMenu.name || secondMenu.label }}</div>\n <div v-if=\"secondMenu.children && secondMenu.children.length > 0\" class=\"headerNav-component-style2__thirdmenu-container\">\n <div v-for=\"(thirdMenu, thirdIndex) in secondMenu.children\" :key=\"thirdIndex\" class=\"headerNav-component-style2__thirdmenu-container__item\">\n <div class=\"headerNav-component-style2__thirdmenu-container__item__title\" @click=\"handleClickMenu(thirdMenu)\">{{ thirdMenu.name || thirdMenu.label }}</div>\n <div v-if=\"thirdMenu.children && thirdMenu.children.length > 0\" class=\"headerNav-component-style2__thirdmenu-container__item__submenu\">\n <div v-for=\"(fourthMenu, fourthIndex) in thirdMenu.children\" :key=\"fourthIndex\" class=\"headerNav-component-style2__thirdmenu-container__item__submenu__item\" @click=\"handleClickMenu(fourthMenu)\">{{ fourthMenu.name || fourthMenu.label }}</div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n <div v-if=\"styleType === 'style3'\" class=\"header-nav-style3\">\n <div class=\"headerNav-component--style3__menu\">\n <MenuComponent\n :menus=\"menus\"\n mode=\"horizontal\"\n background-color=\"#fff\"\n text-color=\"#333\"\n active-text-color=\"#409EFF\"\n />\n </div>\n </div>\n <ChangeLanguageDialog\n :visible=\"showLanguageDialog\"\n @close=\"showLanguageDialog = false\"\n @select=\"handleLanguageSelect\"\n />\n </div>\n</template>\n\n<script>\nimport MenuComponent from './menus'\nimport ChangeLanguageDialog from './changeLanguageDialog'\n\nexport default {\n name: 'HeaderNavComponent',\n components: {\n MenuComponent,\n ChangeLanguageDialog\n },\n props: {\n logo: {\n type: String,\n default: ''\n },\n styleType: {\n type: String,\n default: 'style1'\n },\n navList: {\n type: Array,\n default: () => []\n },\n allNavList: {\n type: Array,\n default: () => []\n },\n clickDisabled: {\n type: Boolean,\n default: false\n },\n theme: {\n type: String,\n default: ''\n }\n },\n data() {\n return {\n searchText: '',\n showSubMenu: false,\n hoveredSubItem: null,\n leaveTimer: null,\n showLanguageDialog: false\n }\n },\n computed: {\n menus() {\n return this.navList.map(item => {\n const result = this.allNavList.find(navItem => navItem.id === item.linkSite)\n return {\n ...result,\n name: item.name || ''\n }\n })\n }\n },\n destroyed() {\n },\n methods: {\n changeLanguage() {\n this.showLanguageDialog = true\n console.log(this.showLanguageDialog)\n },\n handleLanguageSelect(language) {\n // 处理语言选择逻辑\n console.log('Selected language:', language)\n this.showLanguageDialog = false\n },\n handleClickMenu(menu) {\n // 如果有子节点,则当前不可点击\n if (menu.children && menu.children.length > 0) {\n return\n }\n // 点击菜单项的回调函数\n console.log('点击了菜单项:', menu)\n // this.$router.push({\n // path: menu.url || ''\n // })\n },\n handleSearch() {\n // todo 搜索\n this.$router.push({\n path: 'search-result?str=' + this.searchText\n })\n },\n handleMenuHover(menu) {\n this.showSubMenu = true\n console.log(this.menus)\n },\n handleMenuLeave() {\n // 延迟隐藏,以便用户可以移动鼠标到子菜单\n this.leaveTimer = setTimeout(() => {\n this.showSubMenu = false\n this.hoveredSubItem = null\n }, 200)\n },\n handleSubMenuContainerEnter() {\n // 当鼠标进入子菜单容器时,清除定时器并保持显示状态\n if (this.leaveTimer) {\n clearTimeout(this.leaveTimer)\n this.leaveTimer = null\n }\n this.showSubMenu = true\n },\n handleSubMenuContainerLeave() {\n // 当鼠标离开子菜单容器时,延迟隐藏\n this.leaveTimer = setTimeout(() => {\n this.showSubMenu = false\n this.hoveredSubItem = null\n }, 200)\n },\n\n handleSubMenuHover(menu) {\n // 当鼠标进入二级菜单时,清除定时器并保持显示状态\n if (this.leaveTimer) {\n clearTimeout(this.leaveTimer)\n this.leaveTimer = null\n }\n this.showSubMenu = true\n },\n handleSubMenuItemHover(subItem) {\n this.hoveredSubItem = subItem\n this.showSubMenu = true\n }\n }\n}\n</script>\n\n<style scoped lang=\"scss\">\n@import '../../styles/theme.css';\n.header-nav-component {\n width: 100%;\n\n // 点击事件禁用遮罩\n .header-nav-component-click-disabled-mask {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n z-index: 99;\n }\n\n .header-nav-style1 {\n padding: 0 31px;\n height: 92px;\n display: flex;\n align-items: center;\n justify-content: space-between;\n background: #FFF;\n\n .headerNav-component--style1__logo {\n width: 265px;\n img {\n width: 100%;\n }\n }\n\n .headerNav-component--style1__menu {\n ::v-deep .el-menu {\n border-bottom: 0 !important;\n }\n ::v-deep .el-menu-item {\n box-sizing: border-box !important;\n height: 56px !important;\n line-height: 14px !important;\n color: #303133 !important;\n transition: border-color 0.3s ease-in-out !important;\n border: none !important;\n }\n\n ::v-deep .el-menu-item, .el-submenu__title {\n line-height: 56px !important;\n padding: 0 20px !important;\n }\n\n ::v-deep .el-menu--horizontal .el-menu-item:not(.is-disabled):hover {\n color: #303133 !important;\n }\n\n ::v-deep .el-menu-item:focus, ::v-deep .el-menu-item:hover {\n background-color: #ecf5ff !important;\n }\n }\n\n .headerNav-component--style1__operate {\n display: flex;\n align-items: center;\n\n .headerNav-component--style1__operate-search {\n width: 120px;\n height: 44px;\n position: relative;\n transition: all 0.3s ease-in-out;\n border-radius: 22px;\n\n &:focus-within {\n width: 340px;\n box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.25);\n color: #495057;\n background-color: #fff;\n }\n\n .headerNav-component--style1__operate-search-icon {\n position: absolute;\n top: 50%;\n left: 14px;\n transform: translateY(-50%);\n color: #015fe8;\n font-size: 20px;\n font-weight: 500;\n }\n .headerNav-component--style1__operate-search-input {\n padding: 0 12px 0 44px;\n width: 100%;\n height: 44px;\n border-radius: 22px;\n border: 1px solid #015fe8;\n font-size: 16px;\n outline: none;\n\n // placeholder 颜色\n &::placeholder {\n color: #015fe8;\n font-size: 16px;\n font-weight: 500;\n }\n }\n }\n\n .headerNav-component--style1__operate-language {\n width: 20px;\n height: 20px;\n margin-left: 16px;\n cursor: pointer;\n }\n\n }\n }\n\n .header-nav-style2 {\n padding: 0 70px;\n width: 100%;\n height: 106px;\n display: flex;\n align-items: center;\n justify-content: space-between;\n background: #FFF;\n position: relative;\n\n .headerNav-component-style2__submenu {\n position: absolute;\n top: 100%;\n left: 0;\n right: 0;\n background: #fff;\n box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);\n z-index: 999;\n padding: 11px 70px 20px;\n opacity: 0;\n transform: translateY(-10px);\n visibility: hidden;\n transition: all 0.3s ease-in-out;\n\n &.show {\n opacity: 1;\n transform: translateY(0);\n visibility: visible;\n }\n\n .headerNav-component-style2__submenu-container {\n display: flex;\n justify-content: center;\n gap: 20px;\n\n .headerNav-component-style2__submenu-container__item {\n padding-top: 14px;\n padding-right: 25px;\n border-right: 1px solid rgba(112, 112, 112, 0.16);\n\n .headerNav-component-style2__submenu-container__item__title {\n margin-bottom: 20px;\n font-weight: bold;\n font-size: 16px;\n color: #000000;\n cursor: pointer;\n\n &:hover {\n color: var(--theme-header-menu-selected-color);\n }\n }\n\n .headerNav-component-style2__thirdmenu-container {\n display: flex;\n flex-direction: column;\n gap: 20px;\n .headerNav-component-style2__thirdmenu-container__item {\n display: flex;\n align-items: center;\n justify-content: flex-start;\n gap: 29px;\n .headerNav-component-style2__thirdmenu-container__item__title {\n font-size: 13px;\n color: #000000;\n font-weight: 400;\n cursor: pointer;\n\n &:hover {\n color: var(--theme-header-menu-selected-color);\n }\n }\n .headerNav-component-style2__thirdmenu-container__item__submenu {\n padding-left: 24px;\n display: flex;\n justify-content: flex-start;\n align-items: center;\n gap: 17px;\n border-left: 1px solid rgba(112, 112, 112, 0.16);\n .headerNav-component-style2__thirdmenu-container__item__submenu__item {\n font-weight: 400;\n font-size: 13px;\n color: rgba(112, 112, 112, 0.5);\n display: inline-flex;\n align-items: center;\n cursor: pointer;\n\n &::before {\n content: '';\n display: inline-block;\n width: 5px;\n height: 5px;\n background-color: rgba(112, 112, 112, 0.16);\n border-radius: 50%;\n margin-right: 8px;\n\n &:hover {\n background-color: var(--theme-header-menu-selected-color);\n }\n }\n\n &:hover {\n color: var(--theme-header-menu-selected-color);\n &::before {\n background-color: var(--theme-header-menu-selected-color);\n }\n }\n }\n }\n }\n }\n }\n }\n }\n\n .headerNav-component--style2__left {\n min-width: calc(50% + 152px); // 当菜单内容少的时候,保证图标在header正中间,如果宽度超出,就往右挤\n width: fit-content;\n display: flex;\n align-items: center;\n justify-content: space-between;\n }\n .headerNav-component--style2__menu {\n display: flex;\n align-items: center;\n justify-content: flex-start;\n gap: 62px;\n\n .headerNav-component--style2__menu-item {\n box-sizing: border-box;\n height: 56px;\n font-weight: 400;\n font-size: 16px;\n color: var(--theme-header-menu-color);\n transition: border-color 0.3s ease-in-out;\n line-height: 56px;\n cursor: pointer;\n &:hover {\n color: var(--theme-header-menu-selected-color) !important;\n }\n }\n }\n\n .headerNav-component--style2__logo {\n width: 304px;\n img {\n width: 100%;\n }\n }\n\n .headerNav-component--style2__operate {\n display: flex;\n align-items: center;\n\n .headerNav-component--style2__operate-search {\n width: 146px;\n height: 50px;\n position: relative;\n transition: all 0.3s ease-in-out;\n border-radius: 25px;\n\n &:focus-within {\n width: 340px;\n box-shadow: var(--theme-input-shadow);\n color: #495057;\n background-color: #fff;\n }\n\n .headerNav-component--style2__operate-search-icon {\n position: absolute;\n top: 50%;\n left: 20px;\n transform: translateY(-50%);\n color: var(--theme-input-color);\n font-size: 19px;\n }\n .headerNav-component--style2__operate-search-input {\n padding: 0 20px 0 50px;\n width: 100%;\n height: 50px;\n border-radius: 25px;\n border: 1.5px solid var(--theme-input-border-color);\n font-size: 16px;\n outline: none;\n\n // placeholder 颜色\n &::placeholder {\n color: var(--theme-input-color);\n font-size: 16px;\n font-weight: 500;\n }\n }\n }\n\n .headerNav-component--style2__operate-language {\n margin-left: 20px;\n font-size: 22px;\n cursor: pointer;\n color: var(--theme-change-language-icon-color);\n }\n\n }\n }\n}\n</style>\n","import mod from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./headerNav.vue?vue&type=script&lang=js\"; export default mod; export * from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./headerNav.vue?vue&type=script&lang=js\"","import { render, staticRenderFns } from \"./headerNav.vue?vue&type=template&id=3593ffc6&scoped=true\"\nimport script from \"./headerNav.vue?vue&type=script&lang=js\"\nexport * from \"./headerNav.vue?vue&type=script&lang=js\"\nimport style0 from \"./headerNav.vue?vue&type=style&index=0&id=3593ffc6&prod&scoped=true&lang=scss\"\n\n\n/* normalize component */\nimport normalizer from \"!../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n \"3593ffc6\",\n null\n \n)\n\nexport default component.exports","import headerNav from './headerNav.vue'\n\nheaderNav.install = Vue => Vue.component(headerNav.name, headerNav)\n\nexport default headerNav\n","var render = function render(){var _vm=this,_c=_vm._self._c;return _c('div',{staticClass:\"hotProduct-component\",class:_vm.theme},[(_vm.clickDisabled)?_c('div',{staticClass:\"hotProduct-component-click-disabled-mask\"}):_vm._e(),(_vm.styleType === 'style1')?_c('div',{staticClass:\"hotProduct-component-style1\"},[_c('div',{staticClass:\"hotProduct-component-style1__container\"},[_c('div',{staticClass:\"hotProduct-component-title\"},[_vm._v(_vm._s(_vm.hotProductData.title))]),_c('div',{staticClass:\"hotProduct-component-subTitle\"},[_vm._v(_vm._s(_vm.hotProductData.subTitle))]),(_vm.hotProductData.displayProductList)?_c('swiper',{staticClass:\"hotProduct-component-swiper\",attrs:{\"options\":_vm.swiperOptions}},[_vm._l((_vm.hotProductData.displayProductList.slice(0, _vm.hotProductData.productCount)),function(item){return _c('swiper-slide',{key:item.id,staticClass:\"hotProduct-component-swiper-item\"},[_c('div',{staticClass:\"hotProduct-component-swiper-item-container\"},[_c('img',{staticClass:\"hotProduct-component-swiper-item-img\",attrs:{\"src\":item.mainPic.split(',')[0],\"alt\":\"\"},on:{\"click\":function($event){$event.stopPropagation();return _vm.handleClick(item)}}}),_c('div',{staticClass:\"hotProduct-component-swiper-item-content\"},[_c('div',{staticClass:\"hotProduct-component-swiper-item-title\"},[_vm._v(_vm._s(item.prodTitle))]),_c('div',{staticClass:\"hotProduct-component-swiper-item-desc\"},[_vm._v(_vm._s(item.prodDescription))])]),_c('div',{staticClass:\"hotProduct-component-swiper-item-btn\"},[_vm._v(\" 查看详情 \"),_c('i',{staticClass:\"iconfont el-icon-top-right\"})])])])}),_c('div',{staticClass:\"swiper-button-next-hotProduct\",attrs:{\"slot\":\"button-next\"},slot:\"button-next\"},[_c('div',{staticClass:\"swiper-button-next-hotProduct-content\"},[_c('img',{attrs:{\"src\":require(\"../../assets/left-arrow.svg\"),\"alt\":\"\"}})])]),_c('div',{staticClass:\"swiper-button-prev-hotProduct\",attrs:{\"slot\":\"button-prev\"},slot:\"button-prev\"},[_c('div',{staticClass:\"swiper-button-prev-hotProduct-content\"},[_c('img',{attrs:{\"src\":require(\"../../assets/left-arrow.svg\"),\"alt\":\"\"}})])])],2):_vm._e(),_c('div',{staticClass:\"hotProduct-component-moreBtn\"},[_vm._v(\" \"+_vm._s(_vm.hotProductData.moreBtnTitle)+\" \")])],1)]):_vm._e(),(_vm.styleType === 'style2')?_c('div',{staticClass:\"hotProduct-component-style2\"},[_c('div',{staticClass:\"hotProduct-component-style2__container\"},[_c('div',{staticClass:\"hotProduct-component-title\"},[_vm._v(_vm._s(_vm.hotProductData.title))]),_c('div',{staticClass:\"hotProduct-component-subTitle\"},[_vm._v(_vm._s(_vm.hotProductData.subTitle))]),(_vm.hotProductData.displayProductList)?_c('swiper',{staticClass:\"hotProduct-component-swiper\",attrs:{\"options\":_vm.swiperOptions2}},[_vm._l((_vm.hotProductData.displayProductList.slice(0, _vm.hotProductData.productCount)),function(item,index){return _c('swiper-slide',{key:item.id,staticClass:\"hotProduct-component-swiper-item\"},[_c('div',{staticClass:\"hotProduct-component-swiper-item-container\"},[_c('div',{staticClass:\"hotProduct-component-swiper-item-img-container\",on:{\"mouseenter\":function($event){_vm.activeIndex = index},\"mouseleave\":function($event){_vm.activeIndex = null}}},[_c('img',{staticClass:\"hotProduct-component-swiper-item-img\",attrs:{\"src\":item.mainPic.split(',')[0],\"alt\":\"\"},on:{\"click\":function($event){$event.stopPropagation();return _vm.handleClick(item)}}}),_c('div',{staticClass:\"hotProduct-component-swiper-item-btn\",style:({bottom: index === _vm.activeIndex ? '0px' : '-50px'})},[_vm._v(\" 查看详情 \")])]),_c('div',{staticClass:\"hotProduct-component-swiper-item-content\"},[_c('div',{staticClass:\"hotProduct-component-swiper-item-title\"},[_vm._v(_vm._s(item.prodTitle))]),_c('div',{staticClass:\"hotProduct-component-swiper-item-desc\"},[_vm._v(_vm._s(item.prodDescription))])])])])}),_c('div',{staticClass:\"hot-product-swiper-pagination\",attrs:{\"slot\":\"pagination\"},slot:\"pagination\"})],2):_vm._e(),_c('div',{staticClass:\"hotProduct-component-moreBtn\"},[_vm._v(\" \"+_vm._s(_vm.hotProductData.moreBtnTitle)+\" \")])],1)]):_vm._e()])\n}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","<template>\n <div class=\"hotProduct-component\" :class=\"theme\">\n <!-- 热门产品 -->\n <!-- 点击事件禁用遮罩 -->\n <div v-if=\"clickDisabled\" class=\"hotProduct-component-click-disabled-mask\" />\n <div v-if=\"styleType === 'style1'\" class=\"hotProduct-component-style1\">\n <div class=\"hotProduct-component-style1__container\">\n <!-- 标题 -->\n <div class=\"hotProduct-component-title\">{{ hotProductData.title }}</div>\n <!-- 副标题 -->\n <div class=\"hotProduct-component-subTitle\">{{ hotProductData.subTitle }}</div>\n <!-- 热门产品列表 -->\n <swiper v-if=\"hotProductData.displayProductList\" :options=\"swiperOptions\" class=\"hotProduct-component-swiper\">\n <swiper-slide v-for=\"item in hotProductData.displayProductList.slice(0, hotProductData.productCount)\" :key=\"item.id\" class=\"hotProduct-component-swiper-item\">\n <div class=\"hotProduct-component-swiper-item-container\">\n <img :src=\"item.mainPic.split(',')[0]\" alt=\"\" class=\"hotProduct-component-swiper-item-img\" @click.stop=\"handleClick(item)\">\n <div class=\"hotProduct-component-swiper-item-content\">\n <div class=\"hotProduct-component-swiper-item-title\">{{ item.prodTitle }}</div>\n <div class=\"hotProduct-component-swiper-item-desc\">{{ item.prodDescription }}</div>\n </div>\n <div class=\"hotProduct-component-swiper-item-btn\">\n 查看详情\n <i class=\"iconfont el-icon-top-right\" />\n </div>\n </div>\n </swiper-slide>\n <!-- 导航按钮 -->\n <div slot=\"button-next\" class=\"swiper-button-next-hotProduct\">\n <div class=\"swiper-button-next-hotProduct-content\">\n <img src=\"../../assets/left-arrow.svg\" alt=\"\">\n </div>\n </div>\n <div slot=\"button-prev\" class=\"swiper-button-prev-hotProduct\">\n <div class=\"swiper-button-prev-hotProduct-content\">\n <img src=\"../../assets/left-arrow.svg\" alt=\"\">\n </div>\n </div>\n </swiper>\n <div class=\"hotProduct-component-moreBtn\">\n {{ hotProductData.moreBtnTitle }}\n </div>\n </div>\n </div>\n <div v-if=\"styleType === 'style2'\" class=\"hotProduct-component-style2\">\n <div class=\"hotProduct-component-style2__container\">\n <!-- 标题 -->\n <div class=\"hotProduct-component-title\">{{ hotProductData.title }}</div>\n <!-- 副标题 -->\n <div class=\"hotProduct-component-subTitle\">{{ hotProductData.subTitle }}</div>\n <!-- 热门产品列表 -->\n <swiper v-if=\"hotProductData.displayProductList\" :options=\"swiperOptions2\" class=\"hotProduct-component-swiper\">\n <swiper-slide v-for=\"(item, index) in hotProductData.displayProductList.slice(0, hotProductData.productCount)\" :key=\"item.id\" class=\"hotProduct-component-swiper-item\">\n <div class=\"hotProduct-component-swiper-item-container\">\n <div class=\"hotProduct-component-swiper-item-img-container\" @mouseenter=\"activeIndex = index\" @mouseleave=\"activeIndex = null\">\n <img :src=\"item.mainPic.split(',')[0]\" alt=\"\" class=\"hotProduct-component-swiper-item-img\" @click.stop=\"handleClick(item)\">\n <div class=\"hotProduct-component-swiper-item-btn\" :style=\"{bottom: index === activeIndex ? '0px' : '-50px'}\">\n 查看详情\n </div>\n </div>\n <div class=\"hotProduct-component-swiper-item-content\">\n <div class=\"hotProduct-component-swiper-item-title\">{{ item.prodTitle }}</div>\n <div class=\"hotProduct-component-swiper-item-desc\">{{ item.prodDescription }}</div>\n </div>\n </div>\n </swiper-slide>\n <!-- 导航按钮 -->\n <div slot=\"pagination\" class=\"hot-product-swiper-pagination\" />\n </swiper>\n <div class=\"hotProduct-component-moreBtn\">\n {{ hotProductData.moreBtnTitle }}\n </div>\n </div>\n </div>\n </div>\n</template>\n\n<script>\nimport { swiper, swiperSlide } from 'vue-awesome-swiper'\nimport 'swiper/dist/css/swiper.css'\n\nexport default {\n name: 'HotProductComponent',\n components: {\n swiper,\n swiperSlide\n },\n props: {\n clickDisabled: {\n type: Boolean,\n default: false\n },\n styleType: {\n type: String,\n default: 'style1'\n },\n hotProductData: {\n type: Object,\n default: () => ({\n title: '', // 标题名称\n subTitle: '', // 副标题名称\n sortType: 'custom', // 数据排序 自定义排序(custom) / 根据浏览量排序(pv) 默认自定义排序\n productType: 'all', // 全部产品(all) / 选择分类(category) / 手动选择(manual) 默认全部产品\n productCount: 4, // productType == all 全部产品 显示的产品数量,最少4个\n productCategory: [], // productType == category 选择的分类 如果是产品分类 则需要选择具体的产品类别\n productList: [], // 手动选择的产品列表\n moreBtnTitle: '', // “更多”按钮文字\n isShowMoreBtn: true, // 是否显示\n moreBtnIsBlank: true, // 是否打开新窗口\n displayProductList: [] // 显示的产品列表\n })\n },\n theme: {\n type: String,\n default: ''\n }\n },\n data() {\n return {\n swiperOptions: {\n slidesPerView: 4,\n slidesPerGroup: 4,\n loop: true,\n autoplay: {\n delay: 6000,\n stopOnLastSlide: false, // 到最后一张图后是否停止自动播放\n disableOnInteraction: false // 鼠标悬停时不停止自动播放\n },\n speed: 1000,\n // 导航按钮\n navigation: {\n nextEl: '.swiper-button-next-hotProduct',\n prevEl: '.swiper-button-prev-hotProduct'\n }\n },\n swiperOptions2: {\n slidesPerView: 3,\n slidesPerColumn: 2,\n spaceBetween: 20,\n autoplay: {\n delay: 6000,\n stopOnLastSlide: false, // 到最后一张图后是否停止自动播放\n disableOnInteraction: true // 鼠标悬停时不停止自动播放\n },\n pagination: {\n el: '.hot-product-swiper-pagination',\n clickable: true\n }\n },\n activeIndex: null\n }\n },\n mounted() {\n // 组件挂载后初始化Swiper\n this.$nextTick(() => {\n // 获取产品\n // this.initSwiper()\n })\n }\n}\n</script>\n\n<style scoped lang=\"scss\">\n@import '../../styles/theme.css';\n.hotProduct-component {\n width: 100%;\n height: 100%;\n min-height: 20px;\n display: flow-root;\n position: relative;\n\n .hotProduct-component-click-disabled-mask {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n z-index: 999;\n }\n\n .hotProduct-component-style1 {\n background: rgb(245, 247, 249);\n .hotProduct-component-style1__container {\n max-width: 1200px;\n margin-left: auto;\n margin-right: auto;\n }\n .hotProduct-component-title {\n padding-top: 26px;\n padding-bottom: 15px;\n font-size: 24px;\n font-weight: 500;\n line-height: 28.8px;\n text-align: center;\n color: #015fe8;\n }\n .hotProduct-component-subTitle {\n margin-bottom: 24px;\n font-size: 14px;\n font-weight: 400;\n line-height: 1.2;\n text-align: center;\n color: #015fe8;\n }\n .hotProduct-component-swiper {\n /* Swiper导航按钮样式 */\n .swiper-button-next-hotProduct,\n .swiper-button-prev-hotProduct {\n position: absolute;\n width: 15%;\n height: 100%;\n top: 0;\n margin-top: 0;\n background-color: rgba(0, 0, 0, 0.3);\n border-radius: 50%;\n transition: all 0.3s ease;\n background: none;\n // background: url('../../assets/left-arrow.svg') no-repeat center center;\n cursor: pointer;\n opacity: 0.5;\n display: flex;\n justify-content: center;\n align-items: center;\n z-index: 1;\n\n div {\n width: 46px;\n height: 46px;\n background-color: #7f7f7f;\n display: flex;\n justify-content: center;\n align-items: center;\n }\n\n img {\n width: 20px;\n height: 20px;\n }\n\n &:hover {\n color: #fff;\n opacity: 1;\n }\n\n &::after {\n font-size: 18px;\n }\n }\n\n .swiper-button-prev-hotProduct {\n left: -30px;\n }\n\n .swiper-button-next-hotProduct {\n right: -30px;\n transform: rotate(180deg);\n }\n\n ::v-deep .hotProduct-component-swiper-item {\n padding: 0 15px;\n width: 270px !important;\n\n }\n ::v-deep .hotProduct-component-swiper-item-container {\n background-color: #FFF;\n padding-bottom: 16px;\n transition: all 0.3s ease-in-out;\n &:hover {\n box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.1);\n }\n }\n\n ::v-deep .hotProduct-component-swiper-item-content {\n padding: 18px 16px 0;\n border-top: 1px solid #e6e8ec;\n }\n ::v-deep .hotProduct-component-swiper-item-img {\n width: 270px;\n height: 387px;\n object-fit: cover;\n }\n ::v-deep .hotProduct-component-swiper-item-title {\n font-size: 14px;\n font-weight: 500;\n line-height: 16.8px;\n color: #212222;\n margin-bottom: 13px;\n }\n ::v-deep .hotProduct-component-swiper-item-desc {\n font-size: 14px;\n font-weight: 400;\n line-height: 21px;\n color: #212222;\n }\n ::v-deep .hotProduct-component-swiper-item-btn {\n margin: 32px auto 0;\n width: 145px;\n border: 1px solid #015fe8;\n border-radius: 30px;\n line-height: 21px;\n padding: 6px 0;\n text-align: center;\n color: #015fe8;\n font-size: 14px;\n font-weight: 400;\n cursor: pointer;\n }\n }\n .hotProduct-component-moreBtn {\n width: fit-content;\n margin: 44px auto 44px;\n padding: 8px 35px;\n font-size: 14px;\n font-weight: 400;\n line-height: 21px;\n text-align: center;\n border-radius: 30px;\n background-color: #015fe8;\n color: #fff;\n cursor: pointer;\n transition: all 0.3s ease-in-out;\n &:hover {\n box-shadow: 2px 2px 10px 0 rgba(0,0,0,.2);\n }\n }\n }\n\n .hotProduct-component-style2 {\n background: #fff;\n\n .hotProduct-component-style2__container {\n padding-bottom: 100px;\n max-width: 1330px;\n width: 1330px;\n margin-left: auto;\n margin-right: auto;\n }\n .hotProduct-component-title {\n padding-top: 100px;\n margin-bottom: 25px;\n font-size: 46px;\n font-weight: 500;\n line-height: 1;\n text-align: center;\n color: var(--theme-content-title-color);\n }\n .hotProduct-component-subTitle {\n margin-bottom: 46px;\n font-size: 26px;\n font-weight: 500;\n line-height: 1;\n text-align: center;\n color: var(--theme-content-subTitle-color);\n }\n .hotProduct-component-swiper {\n ::v-deep .hotProduct-component-swiper-item-content {\n padding: 20px 0 0;\n }\n ::v-deep .hotProduct-component-swiper-item-img-container {\n position: relative;\n width: 100%;\n height: 258px;\n background: #F6F7F9;\n border-radius: 20px;\n overflow: hidden;\n }\n ::v-deep .hotProduct-component-swiper-item-btn {\n position: absolute;\n width: 100%;\n height: 50px;\n border-radius: 20px;\n line-height: 1px;\n cursor: pointer;\n display: flex;\n justify-content: center;\n align-items: center;\n background: var(--theme-detail-btn-bg-color);\n transition: all 0.3s ease-in-out;\n color: #fff;\n font-size: 16px;\n font-weight: 500;\n }\n ::v-deep .hotProduct-component-swiper-item-img {\n width: 100%;\n height: 258px;\n object-fit: cover;\n }\n ::v-deep .hotProduct-component-swiper-item-title {\n width: 100%;\n font-size: 16px;\n font-weight: 500;\n line-height: 1;\n color: #000000;\n margin-bottom: 15px;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n ::v-deep .hotProduct-component-swiper-item-desc {\n width: 100%;\n font-weight: 500;\n font-size: 16px;\n color: rgba(0,0,0,0.5);\n line-height: normal;\n overflow: hidden;\n text-overflow: ellipsis;\n display: -webkit-box;\n -webkit-line-clamp: 3;\n -webkit-box-orient: vertical;\n }\n ::v-deep .swiper-wrapper {\n padding-bottom: 40px;\n }\n ::v-deep .hot-product-swiper-pagination {\n text-align: center;\n\n .swiper-pagination-bullet {\n width: 33px;\n height: 3px;\n background: #000000;\n opacity: 0.2;\n transition: all 0.3s ease-in-out;\n border-radius: 0;\n }\n\n .swiper-pagination-bullet-active {\n width: 54px;\n height: 3px;\n background: #000000;\n opacity: 1;\n }\n }\n }\n .hotProduct-component-moreBtn {\n width: fit-content;\n margin: 50px auto 0;\n padding: 9px 21px;\n font-size: 16px;\n font-weight: 400;\n line-height: 1;\n text-align: center;\n border-radius: 6px;\n background-color: transparent;\n color: var(--theme-more-btn-color);\n border: var(--theme-more-btn-border);\n cursor: pointer;\n transition: all 0.3s ease-in-out;\n &:hover {\n background: var(--theme-more-btn-hover-bg-color);\n color: #fff;\n border-color: var(--theme-more-btn-hover-bg-color);\n }\n }\n }\n}\n\n</style>\n","import mod from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./hotProduct.vue?vue&type=script&lang=js\"; export default mod; export * from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./hotProduct.vue?vue&type=script&lang=js\"","import { render, staticRenderFns } from \"./hotProduct.vue?vue&type=template&id=ae70b464&scoped=true\"\nimport script from \"./hotProduct.vue?vue&type=script&lang=js\"\nexport * from \"./hotProduct.vue?vue&type=script&lang=js\"\nimport style0 from \"./hotProduct.vue?vue&type=style&index=0&id=ae70b464&prod&scoped=true&lang=scss\"\n\n\n/* normalize component */\nimport normalizer from \"!../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n \"ae70b464\",\n null\n \n)\n\nexport default component.exports","import hotProduct from './hotProduct.vue'\n\nhotProduct.install = Vue => Vue.component(hotProduct.name, hotProduct)\n\nexport default hotProduct\n","var render = function render(){var _vm=this,_c=_vm._self._c;return _c('div',{staticClass:\"newsInformation-component\",class:_vm.theme},[(_vm.clickDisabled)?_c('div',{staticClass:\"newsInformation-component-click-disabled-mask\"}):_vm._e(),(_vm.styleType === 'style1')?_c('div',{staticClass:\"newsInformation-component-style1\"},[_c('div',{staticClass:\"newsInformation-component-style1__container\"},[_c('div',{staticClass:\"newsInformation-component-title\"},[_vm._v(_vm._s(_vm.newsInformationData.title))]),_c('div',{staticClass:\"newsInformation-component-subTitle\"},[_vm._v(_vm._s(_vm.newsInformationData.subTitle))]),_c('div',{staticClass:\"newsInformation-component-newsList\"},[(_vm.newsInformationData.displayNewsList && _vm.newsInformationData.displayNewsList.length > 0)?_c('div',{staticClass:\"newsInformation-component-newsList-item-left\"},[_c('img',{attrs:{\"src\":_vm.newsInformationData.displayNewsList[0].mainPic,\"alt\":\"\"}}),_c('div',{staticClass:\"newsInformation-component-newsList-item-title\"},[_vm._v(_vm._s(_vm.newsInformationData.displayNewsList[0].title))]),_c('div',{staticClass:\"newsInformation-component-newsList-item-description\"},[_vm._v(_vm._s(_vm.newsInformationData.displayNewsList[0].description))]),_c('div',{staticClass:\"newsInformation-component-newsList-item-bottom\"},[_c('div',{staticClass:\"newsInformation-component-newsList-item-bottom-more-btn\"},[_vm._v(\" \"+_vm._s(_vm.newsInformationData.moreBtnTitle)+\" \")]),_c('div',{staticClass:\"newsInformation-component-newsList-item-bottom-date\"},[_vm._v(\" \"+_vm._s(_vm.newsInformationData.displayNewsList[0].publicDate)+\" \")])])]):_vm._e(),(_vm.newsInformationData.displayNewsList && _vm.newsInformationData.displayNewsList.length > 1)?_c('div',{staticClass:\"newsInformation-component-newsList-right\"},_vm._l((_vm.newsInformationData.displayNewsList.slice(1, _vm.newsInformationData.newsCount)),function(item){return _c('div',{key:item.id,staticClass:\"newsInformation-component-newsList-item\"},[_c('img',{attrs:{\"src\":item.mainPic,\"alt\":\"\"}}),_c('div',{staticClass:\"newsInformation-component-newsList-item-content\"},[_c('div',{staticClass:\"newsInformation-component-newsList-item-content-title\"},[_vm._v(_vm._s(item.title))]),_c('div',{staticClass:\"newsInformation-component-newsList-item-content-description\"},[_vm._v(_vm._s(item.description))]),_c('div',{staticClass:\"newsInformation-component-newsList-item-content-bottom\"},[_c('span',[_vm._v(_vm._s(item.publicDate))]),_c('i',{staticClass:\"iconfont el-icon-right\"})])])])}),0):_vm._e()]),_c('div',{staticClass:\"newsInformation-component-moreBtn\"},[_vm._v(\" \"+_vm._s(_vm.newsInformationData.moreBtnTitle)+\" \")])])]):_vm._e(),(_vm.styleType === 'style2')?_c('div',{staticClass:\"newsInformation-component-style2\"},[_c('div',{staticClass:\"newsInformation-component-style2__container\"},[_c('div',{staticClass:\"newsInformation-component-title\"},[_vm._v(_vm._s(_vm.newsInformationData.title))]),_c('div',{staticClass:\"newsInformation-component-subTitle\"},[_vm._v(_vm._s(_vm.newsInformationData.subTitle))]),_c('div',{staticClass:\"newsInformation-component-newsList\"},[(_vm.newsInformationData.displayNewsList && _vm.newsInformationData.displayNewsList.length > 0)?_c('div',{staticClass:\"newsInformation-component-newsList-item-left\"},[_c('img',{attrs:{\"src\":_vm.newsInformationData.displayNewsList[0].mainPic,\"alt\":\"\"}}),_c('div',{staticClass:\"newsInformation-component-newsList-item-title\"},[_vm._v(_vm._s(_vm.newsInformationData.displayNewsList[0].title))])]):_vm._e(),(_vm.newsInformationData.displayNewsList && _vm.newsInformationData.displayNewsList.length > 0)?_c('div',{staticClass:\"newsInformation-component-newsList-item-middle\"},[_c('div',{staticClass:\"newsInformation-component-newsList-item-description\"},[_vm._v(_vm._s(_vm.newsInformationData.displayNewsList[0].description))])]):_vm._e(),(_vm.newsInformationData.displayNewsList && _vm.newsInformationData.displayNewsList.length > 1)?_c('div',{staticClass:\"newsInformation-component-newsList-right\"},[_c('div',{staticClass:\"newsInformation-component-newsList-title\"},[_vm._v(\"热门资讯\")]),_vm._l((_vm.newsInformationData.displayNewsList.slice(1, _vm.newsInformationData.newsCount)),function(item){return _c('div',{key:item.id,staticClass:\"newsInformation-component-newsList-item\"},[_c('img',{attrs:{\"src\":item.mainPic,\"alt\":\"\"}}),_c('div',{staticClass:\"newsInformation-component-newsList-item-content\"},[_c('div',{staticClass:\"newsInformation-component-newsList-item-content-title\"},[_vm._v(_vm._s(item.title))]),_c('div',{staticClass:\"newsInformation-component-newsList-item-content-description\"},[_vm._v(_vm._s(item.description))]),_c('div',{staticClass:\"newsInformation-component-newsList-item-content-bottom\"},[_c('span',[_vm._v(_vm._s(item.publicDate ? item.publicDate.replaceAll('-', '.') : ''))])])])])})],2):_vm._e()]),_c('div',{staticClass:\"newsInformation-component-moreBtn\"},[_vm._v(\" \"+_vm._s(_vm.newsInformationData.moreBtnTitle)+\" \")])])]):_vm._e()])\n}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","<template>\n <div class=\"newsInformation-component\" :class=\"theme\">\n <!-- 新闻资讯 -->\n <!-- 点击事件禁用遮罩 -->\n <div v-if=\"clickDisabled\" class=\"newsInformation-component-click-disabled-mask\" />\n <div v-if=\"styleType === 'style1'\" class=\"newsInformation-component-style1\">\n <div class=\"newsInformation-component-style1__container\">\n <!-- 标题 -->\n <div class=\"newsInformation-component-title\">{{ newsInformationData.title }}</div>\n <!-- 副标题 -->\n <div class=\"newsInformation-component-subTitle\">{{ newsInformationData.subTitle }}</div>\n <!-- 文章列表 -->\n <div class=\"newsInformation-component-newsList\">\n <div v-if=\"newsInformationData.displayNewsList && newsInformationData.displayNewsList.length > 0\" class=\"newsInformation-component-newsList-item-left\">\n <img :src=\"newsInformationData.displayNewsList[0].mainPic\" alt=\"\">\n <div class=\"newsInformation-component-newsList-item-title\">{{ newsInformationData.displayNewsList[0].title }}</div>\n <div class=\"newsInformation-component-newsList-item-description\">{{ newsInformationData.displayNewsList[0].description }}</div>\n <div class=\"newsInformation-component-newsList-item-bottom\">\n <div class=\"newsInformation-component-newsList-item-bottom-more-btn\">\n {{ newsInformationData.moreBtnTitle }}\n </div>\n <div class=\"newsInformation-component-newsList-item-bottom-date\">\n {{ newsInformationData.displayNewsList[0].publicDate }}\n </div>\n </div>\n </div>\n <div v-if=\"newsInformationData.displayNewsList && newsInformationData.displayNewsList.length > 1\" class=\"newsInformation-component-newsList-right\">\n <div v-for=\"item in newsInformationData.displayNewsList.slice(1, newsInformationData.newsCount)\" :key=\"item.id\" class=\"newsInformation-component-newsList-item\">\n <img :src=\"item.mainPic\" alt=\"\">\n <div class=\"newsInformation-component-newsList-item-content\">\n <div class=\"newsInformation-component-newsList-item-content-title\">{{ item.title }}</div>\n <div class=\"newsInformation-component-newsList-item-content-description\">{{ item.description }}</div>\n <div class=\"newsInformation-component-newsList-item-content-bottom\">\n <span>{{ item.publicDate }}</span>\n <i class=\"iconfont el-icon-right\" />\n </div>\n </div>\n </div>\n </div>\n </div>\n <div class=\"newsInformation-component-moreBtn\">\n {{ newsInformationData.moreBtnTitle }}\n </div>\n </div>\n </div>\n <div v-if=\"styleType === 'style2'\" class=\"newsInformation-component-style2\">\n <div class=\"newsInformation-component-style2__container\">\n <!-- 标题 -->\n <div class=\"newsInformation-component-title\">{{ newsInformationData.title }}</div>\n <!-- 副标题 -->\n <div class=\"newsInformation-component-subTitle\">{{ newsInformationData.subTitle }}</div>\n <!-- 文章列表 -->\n <div class=\"newsInformation-component-newsList\">\n <div v-if=\"newsInformationData.displayNewsList && newsInformationData.displayNewsList.length > 0\" class=\"newsInformation-component-newsList-item-left\">\n <img :src=\"newsInformationData.displayNewsList[0].mainPic\" alt=\"\">\n <div class=\"newsInformation-component-newsList-item-title\">{{ newsInformationData.displayNewsList[0].title }}</div>\n </div>\n <div v-if=\"newsInformationData.displayNewsList && newsInformationData.displayNewsList.length > 0\" class=\"newsInformation-component-newsList-item-middle\">\n <div class=\"newsInformation-component-newsList-item-description\">{{ newsInformationData.displayNewsList[0].description }}</div>\n </div>\n <div v-if=\"newsInformationData.displayNewsList && newsInformationData.displayNewsList.length > 1\" class=\"newsInformation-component-newsList-right\">\n <div class=\"newsInformation-component-newsList-title\">热门资讯</div>\n <div v-for=\"item in newsInformationData.displayNewsList.slice(1, newsInformationData.newsCount)\" :key=\"item.id\" class=\"newsInformation-component-newsList-item\">\n <img :src=\"item.mainPic\" alt=\"\">\n <div class=\"newsInformation-component-newsList-item-content\">\n <div class=\"newsInformation-component-newsList-item-content-title\">{{ item.title }}</div>\n <div class=\"newsInformation-component-newsList-item-content-description\">{{ item.description }}</div>\n <div class=\"newsInformation-component-newsList-item-content-bottom\">\n <span>{{ item.publicDate ? item.publicDate.replaceAll('-', '.') : '' }}</span>\n </div>\n </div>\n </div>\n </div>\n </div>\n <div class=\"newsInformation-component-moreBtn\">\n {{ newsInformationData.moreBtnTitle }}\n </div>\n </div>\n </div>\n </div>\n</template>\n\n<script>\n\nexport default {\n name: 'NewsInformationComponent',\n props: {\n clickDisabled: {\n type: Boolean,\n default: false\n },\n styleType: {\n type: String,\n default: 'style1'\n },\n newsInformationData: {\n type: Object,\n default: () => ({\n title: '', // 标题名称\n subTitle: '', // 副标题名称\n sortType: 'custom', // 数据排序 自定义排序(custom) / 根据点击量排序(pv) 默认自定义排序\n newsType: 'all', // 全部新闻(all) / 选择分类(category) / 手动选择(manual) 默认全部新闻\n newsCount: 4, // newsType == all 全部新闻 显示的新闻数量,最少4个\n newsCategory: [], // newsType == category 选择的分类 如果是新闻分类 则需要选择具体的新闻类别\n newsList: [], // 手动选择的新闻列表id\n moreBtnTitle: '', // “更多”按钮文字\n isShowMoreBtn: true, // 是否显示\n moreBtnIsBlank: true, // 是否打开新窗口\n displayNewsList: [] // 最终展示的新闻资讯列表,由父组件调用接口并排序后传递\n })\n },\n theme: {\n type: String,\n default: ''\n }\n },\n data() {\n return {\n swiperOptions: {\n slidesPerView: 4,\n slidesPerGroup: 4,\n loop: true,\n autoplay: {\n delay: 6000,\n stopOnLastSlide: false, // 到最后一张图后是否停止自动播放\n disableOnInteraction: false // 鼠标悬停时不停止自动播放\n },\n speed: 1000,\n // 导航按钮\n navigation: {\n nextEl: '.swiper-button-next-newsInformation',\n prevEl: '.swiper-button-prev-newsInformation'\n }\n }\n }\n },\n mounted() {\n // 组件挂载后初始化Swiper\n this.$nextTick(() => {\n // 获取产品\n // this.initSwiper()\n })\n }\n}\n</script>\n\n<style scoped lang=\"scss\">\n.newsInformation-component {\n width: 100%;\n height: 100%;\n min-height: 20px;\n display: flow-root;\n position: relative;\n\n .newsInformation-component-click-disabled-mask {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n z-index: 999;\n }\n\n .newsInformation-component-style1 {\n background: #f5f7f9;\n .newsInformation-component-style1__container {\n padding-top: 26px;\n padding-bottom: 24px;\n max-width: 1200px;\n margin-left: auto;\n margin-right: auto;\n }\n .newsInformation-component-title {\n margin-top: 26px;\n margin-bottom: 15px;\n font-size: 24px;\n font-weight: 500;\n line-height: 28.8px;\n text-align: center;\n color: #015fe8;\n }\n .newsInformation-component-subTitle {\n margin-bottom: 24px;\n font-size: 14px;\n font-weight: 400;\n line-height: 1.2;\n text-align: center;\n color: #015fe8;\n }\n .newsInformation-component-newsList {\n display: flex;\n justify-content: center;\n align-items: flex-start;\n flex-wrap: wrap;\n .newsInformation-component-newsList-item-left {\n padding: 0 15px;\n width: 600px;\n background-color: #fff;\n img {\n width: 570px;\n height: 570px;\n }\n .newsInformation-component-newsList-item-title {\n margin-top: 20px;\n margin-bottom: 20px;\n padding: 0 17px;\n font-size: 24px;\n font-weight: 500;\n line-height: 28.8px;\n color: #212222;\n // 超出两行省略\n overflow: hidden;\n text-overflow: ellipsis;\n display: -webkit-box;\n -webkit-line-clamp: 2;\n -webkit-box-orient: vertical;\n }\n .newsInformation-component-newsList-item-description {\n padding: 0 17px;\n color: #878b90;\n // 超出两行省略\n overflow: hidden;\n text-overflow: ellipsis;\n display: -webkit-box;\n -webkit-line-clamp: 2;\n -webkit-box-orient: vertical;\n font-size: 14px;\n font-weight: 400;\n line-height: 21px;\n }\n .newsInformation-component-newsList-item-bottom {\n padding: 0 17px;\n display: flex;\n justify-content: space-between;\n align-items: center;\n margin-top: 24px;\n .newsInformation-component-newsList-item-bottom-more-btn {\n width: fit-content;\n margin: 61px 0 44px;\n padding: 8px 35px;\n font-size: 14px;\n font-weight: 400;\n line-height: 21px;\n text-align: center;\n border-radius: 30px;\n background-color: #015fe8;\n color: #fff;\n cursor: pointer;\n transition: all 0.3s ease-in-out;\n &:hover {\n box-shadow: 2px 2px 10px 0 rgba(0,0,0,.2);\n }\n }\n .newsInformation-component-newsList-item-bottom-date {\n font-size: 14px;\n font-weight: 400;\n line-height: 21px;\n text-align: center;\n color: #878b90;\n }\n }\n }\n .newsInformation-component-newsList-right {\n padding: 0 15px;\n width: 600px;\n .newsInformation-component-newsList-item {\n margin-bottom: 16px;\n width: 100%;\n height: 200px;\n background-color: #fff;\n display: flex;\n justify-content: center;\n img {\n margin-right: 15px;\n width: 220px;\n height: 200px;\n }\n .newsInformation-component-newsList-item-content {\n padding: 26px 18px;\n .newsInformation-component-newsList-item-content-title {\n margin-bottom: 20px;\n font-size: 14px;\n font-weight: 500;\n line-height: 16.8px;\n color: #212222;\n }\n .newsInformation-component-newsList-item-content-description {\n font-size: 14px;\n font-weight: 400;\n line-height: 21px;\n color: #878b90;\n // 超出三行省略\n overflow: hidden;\n text-overflow: ellipsis;\n display: -webkit-box;\n -webkit-line-clamp: 3;\n -webkit-box-orient: vertical;\n }\n .newsInformation-component-newsList-item-content-bottom {\n margin-top: 26px;\n display: flex;\n justify-content: space-between;\n align-items: center;\n font-size: 14px;\n font-weight: 400;\n line-height: 21px;\n color: #878b90;\n\n i {\n font-size: 18px;\n }\n }\n }\n }\n }\n }\n\n .newsInformation-component-moreBtn {\n width: fit-content;\n margin: 24px auto 0;\n padding: 8px 35px;\n font-size: 14px;\n font-weight: 400;\n line-height: 21px;\n text-align: center;\n border-radius: 30px;\n background-color: #015fe8;\n color: #fff;\n cursor: pointer;\n transition: all 0.3s ease-in-out;\n &:hover {\n box-shadow: 2px 2px 10px 0 rgba(0,0,0,.2);\n }\n }\n }\n\n .newsInformation-component-style2 {\n background: #fff;\n .newsInformation-component-style2__container {\n padding-top: 100px;\n max-width: 1334px;\n margin-left: auto;\n margin-right: auto;\n }\n .newsInformation-component-title {\n margin-bottom: 25px;\n height: 46px;\n font-weight: 500;\n font-size: 46px;\n color: var(--theme-content-title-color);\n text-align: center;\n font-style: normal;\n text-transform: none;\n line-height: 46px;\n }\n .newsInformation-component-subTitle {\n margin-bottom: 50px;\n height: 26px;\n font-weight: 500;\n font-size: 26px;\n color: var(--theme-content-subTitle-color);\n text-align: center;\n font-style: normal;\n text-transform: none;\n }\n .newsInformation-component-newsList {\n display: flex;\n justify-content: center;\n align-items: flex-start;\n flex-wrap: wrap;\n gap: 20px;\n .newsInformation-component-newsList-item-left {\n width: 431px;\n height: 558px;\n background-color: #F6F7F9;\n img {\n display: block;\n width: 431px;\n height: 416px;\n }\n .newsInformation-component-newsList-item-title {\n margin-top: 40px;\n margin-bottom: 40px;\n padding: 0 25px;\n font-size: 16px;\n font-weight: 500;\n line-height: 1.2;\n color: #000000;\n // 超出两行省略\n overflow: hidden;\n text-overflow: ellipsis;\n display: -webkit-box;\n -webkit-line-clamp: 3;\n -webkit-box-orient: vertical;\n }\n .newsInformation-component-newsList-item-description {\n padding: 0 17px;\n color: #878b90;\n // 超出两行省略\n overflow: hidden;\n text-overflow: ellipsis;\n display: -webkit-box;\n -webkit-line-clamp: 2;\n -webkit-box-orient: vertical;\n font-size: 14px;\n font-weight: 400;\n line-height: 21px;\n }\n }\n .newsInformation-component-newsList-item-middle {\n padding: 50px 40px;\n width: 431px;\n height: 558px;\n background-color: #E4E9EE;\n background-image: url('../../assets/news-center-bg.png');\n background-size: cover;\n background-position: center;\n font-weight: 500;\n font-size: 16px;\n color: #000000;\n text-align: left;\n font-style: normal;\n text-transform: none;\n overflow: hidden;\n }\n .newsInformation-component-newsList-right {\n width: calc(100% - 431px - 20px - 431px - 20px);\n height: 558px;\n\n .newsInformation-component-newsList-title {\n margin-bottom: 30px;\n font-weight: 500;\n font-size: 26px;\n color: #000000;\n text-align: left;\n font-style: normal;\n text-transform: none;\n line-height: 1;\n }\n .newsInformation-component-newsList-item {\n margin-bottom: 20px;\n width: 100%;\n height: 154px;\n background-color: #fff;\n display: flex;\n justify-content: center;\n img {\n width: 200px;\n height: 154px;\n }\n .newsInformation-component-newsList-item-content {\n padding-left: 21px;\n .newsInformation-component-newsList-item-content-title {\n margin-bottom: 15px;\n line-height: 1;\n width: 210px;\n height: 18px;\n font-weight: 500;\n font-size: 16px;\n color: #000000;\n text-align: left;\n font-style: normal;\n text-transform: none;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n }\n .newsInformation-component-newsList-item-content-description {\n margin-bottom: 15px;\n line-height: 1.2;\n // 超出三行省略\n overflow: hidden;\n text-overflow: ellipsis;\n display: -webkit-box;\n -webkit-line-clamp: 3;\n -webkit-box-orient: vertical;\n font-weight: 500;\n font-size: 16px;\n color: rgba(0, 0, 0, 0.5);\n text-align: left;\n font-style: normal;\n text-transform: none;\n }\n .newsInformation-component-newsList-item-content-bottom {\n height: 16px;\n font-weight: 500;\n font-size: 16px;\n color: #000000;\n text-align: left;\n font-style: normal;\n text-transform: none;\n }\n }\n }\n }\n }\n\n .newsInformation-component-moreBtn {\n width: fit-content;\n margin: 50px auto;\n padding: 9px 21px;\n font-size: 16px;\n font-weight: 500;\n line-height: 1;\n text-align: center;\n border-radius: 6px;\n border: var(--theme-more-btn-border);\n color: var(--theme-more-btn-color);\n cursor: pointer;\n transition: all 0.3s ease-in-out;\n &:hover {\n background-color: var(--theme-more-btn-hover-bg-color);\n color: #fff;\n border-color: var(--theme-more-btn-hover-bg-color);\n }\n }\n }\n\n}\n\n</style>\n","import mod from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./newsInformation.vue?vue&type=script&lang=js\"; export default mod; export * from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./newsInformation.vue?vue&type=script&lang=js\"","import { render, staticRenderFns } from \"./newsInformation.vue?vue&type=template&id=19a6b5ac&scoped=true\"\nimport script from \"./newsInformation.vue?vue&type=script&lang=js\"\nexport * from \"./newsInformation.vue?vue&type=script&lang=js\"\nimport style0 from \"./newsInformation.vue?vue&type=style&index=0&id=19a6b5ac&prod&scoped=true&lang=scss\"\n\n\n/* normalize component */\nimport normalizer from \"!../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n \"19a6b5ac\",\n null\n \n)\n\nexport default component.exports","import newsInformation from './newsInformation.vue'\n\nnewsInformation.install = Vue => Vue.component(newsInformation.name, newsInformation)\n\nexport default newsInformation\n","var render = function render(){var _vm=this,_c=_vm._self._c;return _c('div',{staticClass:\"productList-component\",class:_vm.theme},[(_vm.clickDisabled)?_c('div',{staticClass:\"productList-component-click-disabled-mask\"}):_vm._e(),(_vm.styleType === 'style1')?_c('div',{staticClass:\"productList-component-style1\"},[_c('div',{staticClass:\"productList-component-style1__container\"},[_c('div',{staticClass:\"productList-component-title\"},[_vm._v(_vm._s(_vm.productListData.title))]),_c('div',{staticClass:\"productList-component-subTitle\"},[_vm._v(_vm._s(_vm.productListData.subTitle))]),(_vm.productListData.displayProductList)?_c('div',{staticClass:\"productList-component-productList\"},_vm._l((_vm.productListData.displayProductList.slice(0, _vm.productListData.productCount)),function(item){return _c('div',{key:item.busiProdNewId,staticClass:\"productList-component-productItem\"},[_c('div',{staticClass:\"productList-component-productImg\"},[_c('img',{attrs:{\"src\":item.mainPic.split(',')[0],\"alt\":\"\"}})]),_c('div',{staticClass:\"productList-component-productInfo\"},[_c('div',{staticClass:\"productList-component-productName\"},[_vm._v(_vm._s(item.prodTitle))]),_c('div',{staticClass:\"productList-component-productPrice\"},[_vm._v(\"¥\"+_vm._s(item.prodDescription))]),_vm._m(0,true)])])}),0):_vm._e(),_c('div',{staticClass:\"productList-component-moreBtn\"},[_vm._v(\" \"+_vm._s(_vm.productListData.moreBtnTitle)+\" \")])])]):_vm._e(),(_vm.styleType === 'style2')?_c('div',{staticClass:\"productList-component-style2\"},[_c('div',{staticClass:\"productList-component-style2__container\"},[_c('div',{staticClass:\"productList-component-title\"},[_vm._v(_vm._s(_vm.productListData.title))]),_c('div',{staticClass:\"productList-component-subTitle\"},[_vm._v(_vm._s(_vm.productListData.subTitle))]),(_vm.productListData.displayProductList)?_c('swiper',{staticClass:\"productList-component-productList\",attrs:{\"options\":_vm.swiperOptions}},[_vm._l((_vm.productListData.displayProductList.slice(0, _vm.productListData.productCount)),function(item){return _c('swiper-slide',{key:item.busiProdNewId,staticClass:\"productList-component-productItem\"},[_c('div',{staticClass:\"productList-component-productInfo\"},[_c('div',{staticClass:\"productList-component-productName\"},[_vm._v(_vm._s(item.prodTitle))]),_c('div',{staticClass:\"productList-component-productPrice\"},[_vm._v(\"¥\"+_vm._s(item.prodDescription))]),_c('div',{staticClass:\"productList-component-productMore\"},[_vm._v(\" 查看详情 \")])]),_c('div',{staticClass:\"productList-component-productImg\"},[_c('img',{attrs:{\"src\":item.mainPic.split(',')[0],\"alt\":\"\"}})])])}),_c('div',{staticClass:\"productList-component-pagination\",attrs:{\"slot\":\"pagination\"},slot:\"pagination\"})],2):_vm._e(),_c('div',{staticClass:\"productList-component-moreBtn\"},[_vm._v(\" \"+_vm._s(_vm.productListData.moreBtnTitle)+\" \")])],1)]):_vm._e()])\n}\nvar staticRenderFns = [function (){var _vm=this,_c=_vm._self._c;return _c('div',{staticClass:\"productList-component-productMore\"},[_vm._v(\" 查看更多 \"),_c('i',{staticClass:\"iconfont el-icon-top-right\"})])\n}]\n\nexport { render, staticRenderFns }","<template>\n <div class=\"productList-component\" :class=\"theme\">\n <!-- 热门产品 -->\n <!-- 点击事件禁用遮罩 -->\n <div v-if=\"clickDisabled\" class=\"productList-component-click-disabled-mask\" />\n <div v-if=\"styleType === 'style1'\" class=\"productList-component-style1\">\n <div class=\"productList-component-style1__container\">\n <!-- 标题 -->\n <div class=\"productList-component-title\">{{ productListData.title }}</div>\n <!-- 副标题 -->\n <div class=\"productList-component-subTitle\">{{ productListData.subTitle }}</div>\n <!-- 热门产品列表 -->\n <div v-if=\"productListData.displayProductList\" class=\"productList-component-productList\">\n <div v-for=\"item in productListData.displayProductList.slice(0, productListData.productCount)\" :key=\"item.busiProdNewId\" class=\"productList-component-productItem\">\n <div class=\"productList-component-productImg\">\n <img :src=\"item.mainPic.split(',')[0]\" alt=\"\">\n </div>\n <div class=\"productList-component-productInfo\">\n <div class=\"productList-component-productName\">{{ item.prodTitle }}</div>\n <div class=\"productList-component-productPrice\">¥{{ item.prodDescription }}</div>\n <div class=\"productList-component-productMore\">\n 查看更多\n <i class=\"iconfont el-icon-top-right\" />\n </div>\n </div>\n </div>\n </div>\n <div class=\"productList-component-moreBtn\">\n {{ productListData.moreBtnTitle }}\n </div>\n </div>\n </div>\n <div v-if=\"styleType === 'style2'\" class=\"productList-component-style2\">\n <div class=\"productList-component-style2__container\">\n <!-- 标题 -->\n <div class=\"productList-component-title\">{{ productListData.title }}</div>\n <!-- 副标题 -->\n <div class=\"productList-component-subTitle\">{{ productListData.subTitle }}</div>\n <!-- 热门产品列表 -->\n <swiper v-if=\"productListData.displayProductList\" :options=\"swiperOptions\" class=\"productList-component-productList\">\n <swiper-slide v-for=\"item in productListData.displayProductList.slice(0, productListData.productCount)\" :key=\"item.busiProdNewId\" class=\"productList-component-productItem\">\n <div class=\"productList-component-productInfo\">\n <div class=\"productList-component-productName\">{{ item.prodTitle }}</div>\n <div class=\"productList-component-productPrice\">¥{{ item.prodDescription }}</div>\n <div class=\"productList-component-productMore\">\n 查看详情\n </div>\n </div>\n <div class=\"productList-component-productImg\">\n <img :src=\"item.mainPic.split(',')[0]\" alt=\"\">\n </div>\n </swiper-slide>\n <!-- 导航按钮 -->\n <div slot=\"pagination\" class=\"productList-component-pagination\" />\n </swiper>\n <div class=\"productList-component-moreBtn\">\n {{ productListData.moreBtnTitle }}\n </div>\n </div>\n </div>\n </div>\n</template>\n\n<script>\nimport { swiper, swiperSlide } from 'vue-awesome-swiper'\nimport 'swiper/dist/css/swiper.css'\nexport default {\n name: 'ProductListComponent',\n components: {\n swiper,\n swiperSlide\n },\n props: {\n clickDisabled: {\n type: Boolean,\n default: false\n },\n styleType: {\n type: String,\n default: 'style1'\n },\n productListData: {\n title: '', // 标题名称\n subTitle: '', // 副标题名称\n sortType: 'custom', // 数据排序 自定义排序(custom) / 根据浏览量排序(pv) 默认自定义排序\n productType: 'all', // 全部产品(all) / 选择分类(category) / 手动选择(manual) 默认全部产品\n productCount: 4, // productType == all 全部产品 显示的产品数量,最少4个\n productCategory: [], // productType == category 选择的分类 如果是产品分类 则需要选择具体的产品类别\n productList: [], // 手动选择的产品列表\n moreBtnTitle: '', // “更多”按钮文字\n isShowMoreBtn: true, // 是否显示\n moreBtnIsBlank: true, // 是否打开新窗口\n displayProductList: [] // 显示的产品列表\n }, // 产品列表\n theme: {\n type: String,\n default: ''\n }\n },\n data() {\n return {\n productList: [],\n swiperOptions: {\n slidesPerView: 3,\n slidesPerColumn: 3,\n spaceBetween: 20,\n // autoplay: {\n // delay: 6000,\n // stopOnLastSlide: false, // 到最后一张图后是否停止自动播放\n // disableOnInteraction: true, // 鼠标悬停时不停止自动播放\n // },\n pagination: {\n el: '.productList-component-pagination',\n clickable: true\n }\n }\n }\n },\n mounted() {\n // 组件挂载后初始化Swiper\n this.$nextTick(() => {\n // 获取产品\n // this.initSwiper()\n })\n }\n}\n</script>\n\n<style scoped lang=\"scss\">\n.productList-component {\n width: 100%;\n height: 100%;\n min-height: 20px;\n background: rgb(245, 247, 249);\n display: flow-root;\n background-color: #fff;\n position: relative;\n\n .productList-component-click-disabled-mask {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n z-index: 999;\n }\n\n .productList-component-style1 {\n .productList-component-style1__container {\n max-width: 1200px;\n margin-left: auto;\n margin-right: auto;\n }\n .productList-component-title {\n margin-top: 26px;\n margin-bottom: 15px;\n font-size: 24px;\n font-weight: 500;\n line-height: 28.8px;\n text-align: center;\n color: #015fe8;\n }\n .productList-component-subTitle {\n margin-bottom: 24px;\n font-size: 14px;\n font-weight: 400;\n line-height: 1.2;\n text-align: center;\n color: #015fe8;\n }\n .productList-component-productList {\n margin-top: 20px;\n display: grid;\n grid-template-columns: repeat(2, 1fr);\n grid-gap: 32px;\n\n .productList-component-productItem {\n display: flex;\n justify-content: center;\n align-items: center;\n border: 1px solid #e4e6ea;\n background-color: #fff;\n transition: all 0.3s ease-in-out;\n &:hover {\n box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.1);\n }\n .productList-component-productImg {\n flex: 0 0 284px;\n width: 284px;\n height: 284px;\n border-right: 1px solid #e4e6ea;\n img {\n width: 100%;\n height: 100%;\n object-fit: cover;\n }\n }\n .productList-component-productInfo {\n flex: 1;\n padding: 21px 16px;\n .productList-component-productName {\n margin-bottom: 28px;\n font-size: 14px;\n font-weight: 500;\n line-height: 16.8px;\n color: #212222;\n // 超出两行省略号\n overflow: hidden;\n text-overflow: ellipsis;\n display: -webkit-box;\n -webkit-line-clamp: 2;\n -webkit-box-orient: vertical;\n }\n .productList-component-productPrice {\n // 超出两行省略号\n overflow: hidden;\n text-overflow: ellipsis;\n display: -webkit-box;\n -webkit-line-clamp: 7;\n -webkit-box-orient: vertical;\n color: #555;\n font-size: 16px;\n font-weight: 400;\n line-height: 24px;\n }\n .productList-component-productMore {\n width: fit-content;\n margin-top: 10px;\n border-radius: 30px;\n border: 1px solid #015fe8;\n padding: 6px 25px;\n text-align: center;\n color: #015fe8;\n background-color: #fff;\n font-size: 16px;\n font-weight: 400;\n line-height: 24px;\n }\n }\n }\n }\n .productList-component-moreBtn {\n width: fit-content;\n margin: 44px auto 44px;\n padding: 8px 35px;\n font-size: 14px;\n font-weight: 400;\n line-height: 21px;\n text-align: center;\n border-radius: 30px;\n background-color: #015fe8;\n color: #fff;\n cursor: pointer;\n transition: all 0.3s ease-in-out;\n &:hover {\n box-shadow: 2px 2px 10px 0 rgba(0,0,0,.2);\n }\n }\n }\n\n .productList-component-style2 {\n padding: 100px 0 40px;\n background: #DDE1E9;\n .productList-component-style2__container {\n max-width: 1567px;\n margin-left: auto;\n margin-right: auto;\n }\n .productList-component-title {\n margin-bottom: 25px;\n font-size: 46px;\n font-weight: 500;\n line-height: 1.2;\n text-align: center;\n color: var(--theme-content-title-color);\n }\n .productList-component-subTitle {\n margin-bottom: 50px;\n font-size: 26px;\n font-weight: 500;\n line-height: 1.2;\n text-align: center;\n color: var(--theme-content-subTitle-color);\n }\n // .productList-component-productItem {\n // height: 319px;\n // display: flex;\n // justify-content: center;\n // align-items: center;\n // background-color: #fff;\n // transition: all 0.3s ease-in-out;\n // background: #FFFFFF;\n // border-radius: 20px;\n // }\n .productList-component-productList {\n padding-bottom: 43px;\n .productList-component-productItem {\n // height: 319px;\n display: flex;\n justify-content: center;\n align-items: center;\n transition: all 0.3s ease-in-out;\n background: #FFFFFF;\n border-radius: 20px;\n .productList-component-productImg {\n flex: 0 0 50%;\n width: 50%;\n height: 100%;\n display: flex;\n justify-content: center;\n align-items: center;\n img {\n width: 100%;\n object-fit: cover;\n }\n }\n .productList-component-productInfo {\n box-sizing: border-box;\n height: 100%;\n flex: 1;\n padding: 40px 0 40px 40px;\n .productList-component-productName {\n margin-bottom: 15px;\n font-weight: 500;\n font-size: 16px;\n color: #000000;\n line-height: 1.2;\n // 超出1行省略号\n overflow: hidden;\n text-overflow: ellipsis;\n }\n .productList-component-productPrice {\n // 超出两行省略号\n overflow: hidden;\n text-overflow: ellipsis;\n display: -webkit-box;\n -webkit-line-clamp: 5;\n -webkit-box-orient: vertical;\n font-weight: 500;\n font-size: 16px;\n color: rgba(0, 0, 0, 0.5);\n line-height: 1.5;\n }\n .productList-component-productMore {\n padding: 9px 14px;\n width: fit-content;\n margin-top: 38px;\n border-radius: 6px;\n border: var(--theme-detail-btn-border);\n padding: 6px 25px;\n text-align: center;\n color: var(--theme-detail-btn-color);\n background-color: #fff;\n font-size: 16px;\n font-weight: 500;\n line-height: 1.2;\n cursor: pointer;\n transition: all 0.3s ease-in-out;\n\n &:hover {\n background-color: var(--theme-detail-btn-bg-color);\n color: #fff;\n border-color: var(--theme-detail-btn-bg-color);\n }\n }\n }\n }\n }\n .productList-component-pagination {\n margin-top: 40px;\n text-align: center;\n\n ::v-deep .swiper-pagination-bullet {\n width: 33px;\n height: 3px;\n background: #000000;\n opacity: 0.2;\n transition: all 0.3s ease-in-out;\n border-radius: 0;\n }\n\n ::v-deep .swiper-pagination-bullet-active {\n width: 54px;\n height: 3px;\n background: #000000;\n opacity: 1;\n }\n }\n .productList-component-moreBtn {\n padding: 0 21px;\n width: fit-content;\n margin: 50px auto 0;\n height: 34px;\n font-size: 14px;\n font-weight: 400;\n border-radius: 6px;\n background-color: transparent;\n color: #fff;\n cursor: pointer;\n transition: all 0.3s ease-in-out;\n border: var(--theme-more-btn-border-dark);\n color: var(--theme-more-btn-color);\n display: flex;\n align-items: center;\n justify-content: center;\n\n &:hover {\n background-color: var(--theme-more-btn-hover-bg-color);\n color: #fff;\n border-color: var(--theme-more-btn-hover-bg-color);\n }\n }\n }\n}\n\n</style>\n","import mod from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./productList.vue?vue&type=script&lang=js\"; export default mod; export * from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./productList.vue?vue&type=script&lang=js\"","import { render, staticRenderFns } from \"./productList.vue?vue&type=template&id=280a79e6&scoped=true\"\nimport script from \"./productList.vue?vue&type=script&lang=js\"\nexport * from \"./productList.vue?vue&type=script&lang=js\"\nimport style0 from \"./productList.vue?vue&type=style&index=0&id=280a79e6&prod&scoped=true&lang=scss\"\n\n\n/* normalize component */\nimport normalizer from \"!../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n \"280a79e6\",\n null\n \n)\n\nexport default component.exports","import productList from './productList.vue'\n\nproductList.install = Vue => Vue.component(productList.name, productList)\n\nexport default productList\n","import 'element-ui/lib/theme-chalk/index.css'\nimport carousel from './package/carousel/index'\nimport companyIntroduction from './package/companyIntroduction/index'\nimport floatNav from './package/floatNav/index'\nimport footerNav from './package/footerNav/index'\nimport headerNav from './package/headerNav/index'\nimport hotProduct from './package/hotProduct/index'\nimport newsInformation from './package/newsInformation/index'\nimport productList from './package/productList/index'\n\nconst components = [\n carousel,\n companyIntroduction,\n floatNav,\n footerNav,\n headerNav,\n hotProduct,\n newsInformation,\n productList\n]\n\nconst install = function(Vue) {\n components.forEach(component => {\n Vue.component(component.name, component)\n })\n}\n\nif (typeof window !== 'undefined' && window.Vue) {\n install(window.Vue)\n}\n\nexport default {\n install,\n carousel,\n companyIntroduction,\n floatNav,\n footerNav,\n headerNav,\n hotProduct,\n newsInformation,\n productList\n}\n","import './setPublicPath'\nimport mod from '~entry'\nexport default mod\nexport * from '~entry'\n"],"sourceRoot":""}
1
+ {"version":3,"sources":["webpack://draggable-components/webpack/bootstrap","webpack://draggable-components/./assets/nationalFlag/bv.svg","webpack://draggable-components/./assets/nationalFlag/it.svg","webpack://draggable-components/./assets/nationalFlag/fk.svg","webpack://draggable-components/./assets/nationalFlag/vi.svg","webpack://draggable-components//Users/cxm/project/csd/dl_cluster_admin_ui/node_modules/swiper/dist/js/swiper.js","webpack://draggable-components/./assets/nationalFlag/tm.svg","webpack://draggable-components/./assets/nationalFlag/et.svg","webpack://draggable-components/./assets/nationalFlag/pe.svg","webpack://draggable-components/./assets/nationalFlag/kp.svg","webpack://draggable-components/./assets/nationalFlag/mq.svg","webpack://draggable-components/./assets/nationalFlag/kw.svg","webpack://draggable-components/./assets/nationalFlag/kn.svg","webpack://draggable-components/./assets/whatsapp.png","webpack://draggable-components/./assets/nationalFlag/me.svg","webpack://draggable-components/./assets/nationalFlag/fr.svg","webpack://draggable-components/./assets/nationalFlag/ky.svg","webpack://draggable-components/./assets/nationalFlag/ws.svg","webpack://draggable-components/./package/headerNav/headerNav.vue?ab0b","webpack://draggable-components/./assets/telephone.png","webpack://draggable-components/./assets/nationalFlag/sl.svg","webpack://draggable-components/./assets/nationalFlag/ad.svg","webpack://draggable-components/./assets/nationalFlag/ye.svg","webpack://draggable-components/./assets/nationalFlag/sg.svg","webpack://draggable-components/./assets/nationalFlag/ng.svg","webpack://draggable-components/./assets/nationalFlag/au.svg","webpack://draggable-components/./assets/nationalFlag/ne.svg","webpack://draggable-components/./assets/nationalFlag/mu.svg","webpack://draggable-components/./assets/nationalFlag/cc.svg","webpack://draggable-components/./assets/language.png","webpack://draggable-components/./assets/nationalFlag/eh.svg","webpack://draggable-components/./assets/nationalFlag/bs.svg","webpack://draggable-components/./assets/nationalFlag/pk.svg","webpack://draggable-components/./assets/nationalFlag/il.svg","webpack://draggable-components/./assets/nationalFlag/ao.svg","webpack://draggable-components/./assets/nationalFlag/br.svg","webpack://draggable-components/./assets/nationalFlag/az.svg","webpack://draggable-components/./assets/nationalFlag/ir.svg","webpack://draggable-components/./assets/nationalFlag/in.svg","webpack://draggable-components/./assets/nationalFlag/lv.svg","webpack://draggable-components/./assets/nationalFlag/gq.svg","webpack://draggable-components/./assets/nationalFlag/zm.svg","webpack://draggable-components/./assets/nationalFlag/bl.svg","webpack://draggable-components/./assets/nationalFlag/gs.svg","webpack://draggable-components/./assets/nationalFlag/sd.svg","webpack://draggable-components/./assets/nationalFlag/cw.svg","webpack://draggable-components/./assets/nationalFlag/mn.svg","webpack://draggable-components/./assets/nationalFlag/ee.svg","webpack://draggable-components/./assets/nationalFlag/lr.svg","webpack://draggable-components/./assets/nationalFlag/hr.svg","webpack://draggable-components/./assets/nationalFlag/dk.svg","webpack://draggable-components/./assets/nationalFlag/bb.svg","webpack://draggable-components/./assets/nationalFlag/gh.svg","webpack://draggable-components/./assets/nationalFlag/so.svg","webpack://draggable-components/./assets/nationalFlag/zw.svg","webpack://draggable-components/./assets/nationalFlag/er.svg","webpack://draggable-components/./assets/nationalFlag/tn.svg","webpack://draggable-components/./assets/nationalFlag/dj.svg","webpack://draggable-components/./assets/nationalFlag/ke.svg","webpack://draggable-components/./assets/nationalFlag/tl.svg","webpack://draggable-components/./assets/nationalFlag/bn.svg","webpack://draggable-components/./assets/nationalFlag/gr.svg","webpack://draggable-components/./assets/home-world-bg.png","webpack://draggable-components/./assets/nationalFlag/bj.svg","webpack://draggable-components/./assets/nationalFlag/lt.svg","webpack://draggable-components/./assets/nationalFlag/gd.svg","webpack://draggable-components/./assets/nationalFlag/bf.svg","webpack://draggable-components/./assets/nationalFlag/li.svg","webpack://draggable-components/./assets/nationalFlag/mc.svg","webpack://draggable-components/./assets/nationalFlag/ml.svg","webpack://draggable-components/./package/floatNav/floatNav.vue?58fd","webpack://draggable-components/./assets/nationalFlag/ve.svg","webpack://draggable-components/./assets/nationalFlag/nr.svg","webpack://draggable-components/./assets/nationalFlag/km.svg","webpack://draggable-components/./assets/nationalFlag/bt.svg","webpack://draggable-components/./assets/people-icon2.png","webpack://draggable-components/./assets/nationalFlag/gl.svg","webpack://draggable-components/./assets/nationalFlag/do.svg","webpack://draggable-components/./assets/nationalFlag/sv.svg","webpack://draggable-components/./assets/nationalFlag/cv.svg","webpack://draggable-components/./assets/nationalFlag sync ^\\.\\/.*$","webpack://draggable-components/./assets/nationalFlag/ba.svg","webpack://draggable-components/./assets/nationalFlag/af.svg","webpack://draggable-components/./assets/nationalFlag/gu.svg","webpack://draggable-components/./assets/nationalFlag/ae.svg","webpack://draggable-components/./assets/chat.png","webpack://draggable-components/./assets/nationalFlag/sz.svg","webpack://draggable-components/./assets/nationalFlag/hu.svg","webpack://draggable-components/./assets/nationalFlag/mz.svg","webpack://draggable-components/./assets/nationalFlag/td.svg","webpack://draggable-components/./assets/nationalFlag/dm.svg","webpack://draggable-components/./assets/nationalFlag/rs.svg","webpack://draggable-components/./assets/nationalFlag/sk.svg","webpack://draggable-components/./assets/nationalFlag/re.svg","webpack://draggable-components/./assets/nationalFlag/fj.svg","webpack://draggable-components/./assets/nationalFlag/py.svg","webpack://draggable-components/./assets/nationalFlag/to.svg","webpack://draggable-components//Users/cxm/project/csd/dl_cluster_admin_ui/node_modules/@vue/cli-service/lib/commands/build/setPublicPath.js","webpack://draggable-components/./package/carousel/carousel.vue?8714","webpack://draggable-components/./assets/index.js","webpack://draggable-components/package/carousel/carousel.vue","webpack://draggable-components/./package/carousel/carousel.vue?98ba","webpack://draggable-components//Users/cxm/project/csd/dl_cluster_admin_ui/node_modules/vue-loader/lib/runtime/componentNormalizer.js","webpack://draggable-components/./package/carousel/carousel.vue","webpack://draggable-components/./package/carousel/index.js","webpack://draggable-components/./package/companyIntroduction/companyIntroduction.vue?cac9","webpack://draggable-components/./i18n/index.js","webpack://draggable-components/package/companyIntroduction/companyIntroduction.vue","webpack://draggable-components/./package/companyIntroduction/companyIntroduction.vue?6a73","webpack://draggable-components/./package/companyIntroduction/companyIntroduction.vue","webpack://draggable-components/./package/companyIntroduction/index.js","webpack://draggable-components/./package/floatNav/floatNav.vue?46aa","webpack://draggable-components/package/floatNav/floatNav.vue","webpack://draggable-components/./package/floatNav/floatNav.vue?38b2","webpack://draggable-components/./package/floatNav/floatNav.vue","webpack://draggable-components/./package/floatNav/index.js","webpack://draggable-components/./package/footerNav/footerNav.vue?432e","webpack://draggable-components/package/footerNav/footerNav.vue","webpack://draggable-components/./package/footerNav/footerNav.vue?8396","webpack://draggable-components/./package/footerNav/footerNav.vue","webpack://draggable-components/./package/footerNav/index.js","webpack://draggable-components/./package/headerNav/headerNav.vue?d12b","webpack://draggable-components/./package/headerNav/menus.js","webpack://draggable-components/./package/headerNav/changeLanguageDialog.vue?9312","webpack://draggable-components/package/headerNav/changeLanguageDialog.vue","webpack://draggable-components/./package/headerNav/changeLanguageDialog.vue?eeab","webpack://draggable-components/./package/headerNav/changeLanguageDialog.vue","webpack://draggable-components/package/headerNav/headerNav.vue","webpack://draggable-components/./package/headerNav/headerNav.vue?aab0","webpack://draggable-components/./package/headerNav/headerNav.vue","webpack://draggable-components/./package/headerNav/index.js","webpack://draggable-components/./package/hotProduct/hotProduct.vue?57bc","webpack://draggable-components/package/hotProduct/hotProduct.vue","webpack://draggable-components/./package/hotProduct/hotProduct.vue?3dac","webpack://draggable-components/./package/hotProduct/hotProduct.vue","webpack://draggable-components/./package/hotProduct/index.js","webpack://draggable-components/./package/newsInformation/newsInformation.vue?499c","webpack://draggable-components/package/newsInformation/newsInformation.vue","webpack://draggable-components/./package/newsInformation/newsInformation.vue?b1c3","webpack://draggable-components/./package/newsInformation/newsInformation.vue","webpack://draggable-components/./package/newsInformation/index.js","webpack://draggable-components/./package/productList/productList.vue?da27","webpack://draggable-components/package/productList/productList.vue","webpack://draggable-components/./package/productList/productList.vue?2956","webpack://draggable-components/./package/productList/productList.vue","webpack://draggable-components/./package/productList/index.js","webpack://draggable-components/./index.js","webpack://draggable-components//Users/cxm/project/csd/dl_cluster_admin_ui/node_modules/@vue/cli-service/lib/commands/build/entry-lib.js","webpack://draggable-components/./assets/nationalFlag/io.svg","webpack://draggable-components/./assets/nationalFlag/tc.svg","webpack://draggable-components/./assets/nationalFlag/bm.svg","webpack://draggable-components/./assets/nationalFlag/hm.svg","webpack://draggable-components/./assets/nationalFlag/sj.svg","webpack://draggable-components/./assets/nationalFlag/gi.svg","webpack://draggable-components/./assets/nationalFlag/ca.svg","webpack://draggable-components/./assets/nationalFlag/im.svg","webpack://draggable-components/./assets/nationalFlag/mm.svg","webpack://draggable-components/./assets/nationalFlag/bw.svg","webpack://draggable-components/./package/hotProduct/hotProduct.vue?abdc","webpack://draggable-components//Users/cxm/project/csd/dl_cluster_admin_ui/node_modules/@soda/get-current-script/index.js","webpack://draggable-components/./assets/nationalFlag/gb.svg","webpack://draggable-components/./package/footerNav/footerNav.vue?a4c1","webpack://draggable-components/./assets/nationalFlag/de.svg","webpack://draggable-components/./assets/nationalFlag/nc.svg","webpack://draggable-components/./assets/nationalFlag/vg.svg","webpack://draggable-components/./assets/nationalFlag/ge.svg","webpack://draggable-components/./assets/nationalFlag/id.svg","webpack://draggable-components/./assets/nationalFlag/tv.svg","webpack://draggable-components/./assets/nationalFlag/lk.svg","webpack://draggable-components/./package/carousel/carousel.vue?11e1","webpack://draggable-components/./assets/nationalFlag/jo.svg","webpack://draggable-components/./assets/nationalFlag/ps.svg","webpack://draggable-components/./assets/nationalFlag/gf.svg","webpack://draggable-components/./assets/nationalFlag/gp.svg","webpack://draggable-components/./assets/nationalFlag/sy.svg","webpack://draggable-components/./assets/nationalFlag/lc.svg","webpack://draggable-components/./assets/nationalFlag/va.svg","webpack://draggable-components/./assets/nationalFlag/nz.svg","webpack://draggable-components/./assets/nationalFlag/gn.svg","webpack://draggable-components/./assets/nationalFlag/nu.svg","webpack://draggable-components/./assets/medal-icon.png","webpack://draggable-components/./assets/nationalFlag/ly.svg","webpack://draggable-components/./assets/nationalFlag/sx.svg","webpack://draggable-components/./assets/nationalFlag/as.svg","webpack://draggable-components/./assets/nationalFlag/tf.svg","webpack://draggable-components/./assets/nationalFlag/co.svg","webpack://draggable-components/./assets/nationalFlag/gb-nir.svg","webpack://draggable-components/./assets/nationalFlag/aq.svg","webpack://draggable-components//Users/cxm/project/csd/dl_cluster_admin_ui/node_modules/swiper/dist/css/swiper.css?ced6","webpack://draggable-components/./assets/nationalFlag/hn.svg","webpack://draggable-components/./assets/nationalFlag/vc.svg","webpack://draggable-components/./assets/nationalFlag/tg.svg","webpack://draggable-components/./assets/nationalFlag/si.svg","webpack://draggable-components/./assets/r-icon.png","webpack://draggable-components/./assets/nationalFlag/pl.svg","webpack://draggable-components/./assets/nationalFlag/ro.svg","webpack://draggable-components/./assets/nationalFlag/pm.svg","webpack://draggable-components/./assets/nationalFlag/kz.svg","webpack://draggable-components/./assets/nationalFlag/mx.svg","webpack://draggable-components/./assets/e-mail.png","webpack://draggable-components/./package/hotProduct/hotProduct.vue?504f","webpack://draggable-components/./assets/nationalFlag/am.svg","webpack://draggable-components/./package/companyIntroduction/companyIntroduction.vue?7854","webpack://draggable-components/./assets/nationalFlag/gg.svg","webpack://draggable-components/./assets/nationalFlag/ss.svg","webpack://draggable-components/./assets/news-center-bg.png","webpack://draggable-components/./assets/nationalFlag/ms.svg","webpack://draggable-components/./package/floatNav/floatNav.vue?d931","webpack://draggable-components/./assets/nationalFlag/ma.svg","webpack://draggable-components/./assets/nationalFlag/ag.svg","webpack://draggable-components/./assets/nationalFlag/jp.svg","webpack://draggable-components/./assets/nationalFlag/sm.svg","webpack://draggable-components/./assets/nationalFlag/vu.svg","webpack://draggable-components/./assets/nationalFlag/mh.svg","webpack://draggable-components/./assets/nationalFlag/mr.svg","webpack://draggable-components/./assets/nationalFlag/mf.svg","webpack://draggable-components/external {\"commonjs\":\"vue\",\"commonjs2\":\"vue\",\"root\":\"Vue\"}","webpack://draggable-components/./assets/nationalFlag/na.svg","webpack://draggable-components/./assets/nationalFlag/om.svg","webpack://draggable-components/./assets/nationalFlag/ie.svg","webpack://draggable-components/./assets/nationalFlag/je.svg","webpack://draggable-components/./assets/nationalFlag/cu.svg","webpack://draggable-components/./assets/nationalFlag/kr.svg","webpack://draggable-components/./assets/nationalFlag/pt.svg","webpack://draggable-components/./assets/nationalFlag/gw.svg","webpack://draggable-components/./package/newsInformation/newsInformation.vue?7f02","webpack://draggable-components/./assets/nationalFlag/ar.svg","webpack://draggable-components/./assets/nationalFlag/th.svg","webpack://draggable-components/./assets/nationalFlag/is.svg","webpack://draggable-components/./assets/nationalFlag/ua.svg","webpack://draggable-components/./assets/nationalFlag/cl.svg","webpack://draggable-components/./assets/nationalFlag/es.svg","webpack://draggable-components/./assets/nationalFlag/lb.svg","webpack://draggable-components/./assets/nationalFlag/ai.svg","webpack://draggable-components/./assets/nationalFlag/sh.svg","webpack://draggable-components/./assets/nationalFlag/pg.svg","webpack://draggable-components/./assets/nationalFlag/iq.svg","webpack://draggable-components/./assets/nationalFlag/tt.svg","webpack://draggable-components/./assets/nationalFlag/ci.svg","webpack://draggable-components/./assets/nationalFlag/um.svg","webpack://draggable-components/./assets/nationalFlag/gb-sct.svg","webpack://draggable-components/./assets/nationalFlag/sa.svg","webpack://draggable-components/./assets/nationalFlag/tj.svg","webpack://draggable-components/./assets/nationalFlag/aw.svg","webpack://draggable-components/./assets/nationalFlag/lu.svg","webpack://draggable-components/./assets/nationalFlag/nf.svg","webpack://draggable-components/./assets/nationalFlag/ug.svg","webpack://draggable-components/./package/headerNav/changeLanguageDialog.vue?fbc3","webpack://draggable-components/./assets/nationalFlag/be.svg","webpack://draggable-components/./assets/nationalFlag/tz.svg","webpack://draggable-components/./assets/nationalFlag/nl.svg","webpack://draggable-components/./package/headerNav/headerNav.vue?8a01","webpack://draggable-components/./assets/nationalFlag/st.svg","webpack://draggable-components//Users/cxm/project/csd/dl_cluster_admin_ui/node_modules/element-ui/lib/theme-chalk/index.css?0feb","webpack://draggable-components/./assets/nationalFlag/gm.svg","webpack://draggable-components/./assets/nationalFlag/fi.svg","webpack://draggable-components/./assets/nationalFlag/ls.svg","webpack://draggable-components/./assets/nationalFlag/jm.svg","webpack://draggable-components/./assets/diamond-icon.png","webpack://draggable-components/./assets/nationalFlag/bo.svg","webpack://draggable-components/./assets/nationalFlag/fm.svg","webpack://draggable-components/./assets/nationalFlag/mo.svg","webpack://draggable-components/./assets/nationalFlag/ki.svg","webpack://draggable-components/./assets/nationalFlag/us.svg","webpack://draggable-components/./assets/nationalFlag/yt.svg","webpack://draggable-components/./assets/nationalFlag/sr.svg","webpack://draggable-components/./assets/equipment-icon.png","webpack://draggable-components/./assets/nationalFlag/ru.svg","webpack://draggable-components/./assets/nationalFlag/fo.svg","webpack://draggable-components/./assets/nationalFlag/by.svg","webpack://draggable-components/./assets/nationalFlag/my.svg","webpack://draggable-components/./assets/nationalFlag/gb-wls.svg","webpack://draggable-components/./assets/nationalFlag/rw.svg","webpack://draggable-components/./assets/nationalFlag/za.svg","webpack://draggable-components/./assets/nationalFlag/bg.svg","webpack://draggable-components/./assets/nationalFlag/cg.svg","webpack://draggable-components/./assets/nationalFlag/bh.svg","webpack://draggable-components/./assets/nationalFlag/pa.svg","webpack://draggable-components/./assets/nationalFlag/tr.svg","webpack://draggable-components/./package/productList/productList.vue?62ab","webpack://draggable-components/./package/footerNav/footerNav.vue?b298","webpack://draggable-components/./assets/nationalFlag/sc.svg","webpack://draggable-components/./assets/diamond-icon2.png","webpack://draggable-components/./assets/left-arrow.svg","webpack://draggable-components/./assets/nationalFlag/mk.svg","webpack://draggable-components/./assets/nationalFlag/tk.svg","webpack://draggable-components/./assets/nationalFlag/cd.svg","webpack://draggable-components/./assets/nationalFlag/np.svg","webpack://draggable-components/./assets/nationalFlag/kg.svg","webpack://draggable-components/./assets/nationalFlag/ec.svg","webpack://draggable-components/./assets/nationalFlag/xk.svg","webpack://draggable-components/./assets/nationalFlag/uy.svg","webpack://draggable-components/./package/newsInformation/newsInformation.vue?58ab","webpack://draggable-components/./assets/nationalFlag/eg.svg","webpack://draggable-components/./assets/nationalFlag/hk.svg","webpack://draggable-components/./assets/nationalFlag/vn.svg","webpack://draggable-components/./assets/company-intro-bg.png","webpack://draggable-components/./assets/nationalFlag/mp.svg","webpack://draggable-components/./assets/nationalFlag/qa.svg","webpack://draggable-components/./assets/nationalFlag/ch.svg","webpack://draggable-components/./assets/nationalFlag/cf.svg","webpack://draggable-components/./assets/nationalFlag/no.svg","webpack://draggable-components/./assets/nationalFlag/mg.svg","webpack://draggable-components/./assets/nationalFlag/mw.svg","webpack://draggable-components/./package/carousel/carousel.vue?60de","webpack://draggable-components/./assets/nationalFlag/cm.svg","webpack://draggable-components/./assets/nationalFlag/ni.svg","webpack://draggable-components/./assets/nationalFlag/sb.svg","webpack://draggable-components/./assets/nationalFlag/gt.svg","webpack://draggable-components/./assets/nationalFlag/ph.svg","webpack://draggable-components/./assets/project-icon.png","webpack://draggable-components/./assets/nationalFlag/mt.svg","webpack://draggable-components/./assets/nationalFlag/ck.svg","webpack://draggable-components/./assets/nationalFlag/kh.svg","webpack://draggable-components/./assets/nationalFlag/cx.svg","webpack://draggable-components/./assets/nationalFlag/bi.svg","webpack://draggable-components/./assets/nationalFlag/cn.svg","webpack://draggable-components/./assets/nationalFlag/mv.svg","webpack://draggable-components/./assets/nationalFlag/uz.svg","webpack://draggable-components/./assets/nationalFlag/se.svg","webpack://draggable-components/./assets/nationalFlag/al.svg","webpack://draggable-components/./assets/nationalFlag/cy.svg","webpack://draggable-components/./assets/nationalFlag/gb-eng.svg","webpack://draggable-components/./assets/nationalFlag/ht.svg","webpack://draggable-components/./assets/nationalFlag/la.svg","webpack://draggable-components/./assets/top-icon.png","webpack://draggable-components/./assets/nationalFlag/at.svg","webpack://draggable-components/./assets/nationalFlag/pw.svg","webpack://draggable-components/./assets/nationalFlag/cr.svg","webpack://draggable-components/./assets/nationalFlag/dz.svg","webpack://draggable-components/./assets/nationalFlag/gy.svg","webpack://draggable-components//Users/cxm/project/csd/dl_cluster_admin_ui/node_modules/vue-awesome-swiper/dist/vue-awesome-swiper.js","webpack://draggable-components/./assets/nationalFlag/bq.svg","webpack://draggable-components/./assets/nationalFlag/pf.svg","webpack://draggable-components/./package/productList/productList.vue?0961","webpack://draggable-components/./assets/nationalFlag/cz.svg","webpack://draggable-components/./assets/nationalFlag/bz.svg","webpack://draggable-components/./assets/nationalFlag/bd.svg","webpack://draggable-components/./assets/nationalFlag/sn.svg","webpack://draggable-components/./assets/nationalFlag/ga.svg","webpack://draggable-components/./assets/nationalFlag/md.svg","webpack://draggable-components/./assets/people-icon.png","webpack://draggable-components/./package/companyIntroduction/companyIntroduction.vue?2efa","webpack://draggable-components/./assets/nationalFlag/tw.svg","webpack://draggable-components/./assets/nationalFlag/wf.svg","webpack://draggable-components/./assets/nationalFlag/pr.svg","webpack://draggable-components/./package/headerNav/changeLanguageDialog.vue?0103","webpack://draggable-components/./assets/nationalFlag/pn.svg","webpack://draggable-components/./assets/nationalFlag/eu.svg","webpack://draggable-components/./assets/nationalFlag/ax.svg"],"names":["assets","chat","companyIntroBg","diamondIcon","diamondIcon2","email","equipmentIcon","homeWorldBg","language","leftArrow","medalIcon","newsCenterBg","peopleIcon","peopleIcon2","projectIcon","rIcon","telephone","topIcon","whatsapp","name","components","swiper","swiperSlide","props","styleType","type","String","default","carouselList","Array","clickDisabled","Boolean","theme","data","swiperOptions","slidesPerView","loop","autoplay","delay","stopOnLastSlide","disableOnInteraction","speed","navigation","nextEl","prevEl","pagination","el","clickable","swiperInstance","watch","handler","newVal","$nextTick","update","deep","immediate","mounted","initSwiper","methods","handleClick","item","link","window","open","length","destroy","setTimeout","swiperElements","document","querySelectorAll","running","start","initiated","init","carousel","install","Vue","component","I18nService","constructor","state","observable","localStorage","getItem","translations","loading","setLanguage","setItem","getLanguage","loadTranslations","response","t","key","defaultValue","changeLanguage","getTranslations","keys","result","forEach","i18nService","introduction","Object","title","subTitle","pcContent","mobileContent","moreMenu","isShow","isBlank","aboutUsMaxId","$t","handleShowMore","location","href","companyIntroduction","footerInfo","tel","maxCatgId","computed","sideiItem","icon","label","url","thirdSoft","desc","sideiItemNew","iconClass","handleToTop","scrollTo","top","behavior","jump","row","thirdAccount","equipment","$axios","post","err","console","log","floatNav","contactWay","content","friendlyLink","list","productCategory","qrcode","$router","resolve","path","query","categoryId","footerNav","handleClickMenu","menu","children","routeMap","catgLevel","catgType","id","maxParentId","renderMenuItem","createElement","menuItem","index","toString","on","click","slot","map","MenuComponent","menus","mode","validator","value","includes","defaultActive","backgroundColor","textColor","activeTextColor","render","select","indexPath","close","visible","languageList","emits","activeTab","searchText","languageActive","safeLanguageList","isArray","filteredLanguageList","searchLower","toLowerCase","region","filteredNations","nationalVos","filter","nation","languages","some","oceania","getImageSrc","require","img","handleSearch","handleClose","$emit","handleLanguageSelect","ChangeLanguageDialog","logo","navList","allNavList","showSubMenu","hoveredSubItem","leaveTimer","showLanguageDialog","find","navItem","linkSite","destroyed","handleClickLogo","code","push","handleMenuHover","handleMenuLeave","handleSubMenuContainerEnter","clearTimeout","handleSubMenuContainerLeave","handleSubMenuHover","handleSubMenuItemHover","subItem","headerNav","hotProductData","sortType","productType","productCount","productList","moreBtnTitle","isShowMoreBtn","moreBtnIsBlank","displayProductList","slidesPerGroup","swiperOptions2","slidesPerColumn","spaceBetween","activeIndex","catgId","handleViewMore","hotProduct","newsInformationData","newsType","newsCount","newsCategory","newsList","displayNewsList","handleMoreClick","newsInformation","productListData"],"mappings":";;QAAA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;;QAEA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;;;QAGA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;QACA,0CAA0C,gCAAgC;QAC1E;QACA;;QAEA;QACA;QACA;QACA,wDAAwD,kBAAkB;QAC1E;QACA,iDAAiD,cAAc;QAC/D;;QAEA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA,yCAAyC,iCAAiC;QAC1E,gHAAgH,mBAAmB,EAAE;QACrI;QACA;;QAEA;QACA;QACA;QACA,2BAA2B,0BAA0B,EAAE;QACvD,iCAAiC,eAAe;QAChD;QACA;QACA;;QAEA;QACA,sDAAsD,+DAA+D;;QAErH;QACA;;;QAGA;QACA;;;;;;;;AClFA,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,EAAE,KAA4D;AAC9D,EAAE,SACoD;AACtD,CAAC,oBAAoB;;AAErB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY;AACZ,oDAAoD;AACpD,0DAA0D;AAC1D;AACA,8BAA8B;AAC9B;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;AACA;AACA,0CAA0C;AAC1C;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,iBAAiB;AACjB,gDAAgD;AAChD;AACA;AACA,SAAS;AACT;AACA,KAAK;AACL,eAAe,WAAW;AAC1B,GAAG,YAAY;;AAEf;AACA;AACA;AACA;AACA,KAAK;AACL,gBAAgB;AAChB,eAAe;AACf;AACA;AACA,KAAK;AACL,oDAAoD;AACpD,0DAA0D;AAC1D;AACA;AACA;AACA;AACA,SAAS;AACT;AACA,KAAK;AACL,8BAA8B;AAC9B,4BAA4B;AAC5B,cAAc;AACd,wCAAwC;AACxC,4CAA4C;AAC5C,GAAG,UAAU;;AAEb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,mBAAmB,gBAAgB;AACnC;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0CAA0C,iBAAiB;AAC3D,0CAA0C,oBAAoB;AAC9D,uEAAuE,iBAAiB;AACxF,6CAA6C,oBAAoB;AACjE,8CAA8C,qBAAqB;AACnE;AACA;AACA,qBAAqB,kCAAkC;AACvD;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA,qBAAqB,gBAAgB;AACrC,yBAAyB,kBAAkB;AAC3C;AACA;AACA,OAAO;AACP;AACA;AACA,OAAO;AACP;AACA,mBAAmB,qBAAqB;AACxC;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,mBAAmB,gBAAgB;AACnC,+CAA+C,0BAA0B;AACzE;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,oBAAoB;AACvC,qBAAqB,iBAAiB;AACtC,yFAAyF,mCAAmC;AAC5H;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,oBAAoB;AACvC,qBAAqB,iBAAiB;AACtC,yFAAyF,sCAAsC;AAC/H;AACA;AACA;AACA;AACA;AACA,mBAAmB,cAAc;AACjC;AACA;AACA;AACA;AACA,mBAAmB,oBAAoB;AACvC,qBAAqB,iBAAiB;AACtC,yFAAyF,sCAAsC;AAC/H;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,oBAAoB,oCAAoC;AACxD;AACA;;AAEA;AACA,mBAAmB,iBAAiB;AACpC;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,iBAAiB;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,mBAAmB,iBAAiB;AACpC;AACA,uCAAuC,gCAAgC;AACvE;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,iBAAiB;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iCAAiC;AACjC;AACA,mBAAmB,iBAAiB;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,iBAAiB;;AAEpC;AACA;AACA,oBAAoB,QAAQ;AAC5B;AACA;AACA;AACA;AACA,yCAAyC,mCAAmC;AAC5E;AACA,0CAA0C;AAC1C,uBAAuB,oBAAoB;AAC3C,iDAAiD,uCAAuC;AACxF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,iBAAiB;AACpC;AACA;AACA,mBAAmB,mBAAmB;AACtC;AACA,kCAAkC,uBAAuB;AACzD,yCAAyC,8BAA8B;AACvE;AACA;AACA;AACA,WAAW;AACX;AACA;AACA,OAAO;AACP;AACA,mBAAmB,mBAAmB;AACtC;AACA,sCAAsC,2BAA2B;AACjE,+CAA+C,oCAAoC;AACnF;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,iBAAiB;;AAEpC;AACA,mBAAmB,mBAAmB;AACtC;AACA,qBAAqB,iBAAiB;AACtC;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,2CAA2C,QAAQ;AACnD;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,mBAAmB,mBAAmB;AACtC;AACA,qBAAqB,iBAAiB;AACtC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,mEAAmE,sBAAsB,EAAE;AAC3F;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8BAA8B,QAAQ;AACtC;AACA,iBAAiB,mBAAmB;AACpC;AACA;AACA;AACA;AACA,iBAAiB,mBAAmB;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,kBAAkB,4CAA4C;AAC9D;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB,oEAAoE;AAC1F,OAAO;AACP,mBAAmB,iBAAiB;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB,iBAAiB;AAClC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,aAAa;AACjC;AACA,mBAAmB,iBAAiB;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,mBAAmB,iBAAiB;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,mBAAmB,iBAAiB;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iDAAiD,cAAc;AAC/D;AACA,uBAAuB,6BAA6B;AACpD,0CAA0C,2CAA2C;AACrF,sCAAsC,uCAAuC;;AAE7E;AACA,iBAAiB,wBAAwB;AACzC,oCAAoC,aAAa;AACjD;AACA;AACA,KAAK,6BAA6B,mBAAmB;AACrD,gCAAgC,mBAAmB;;AAEnD;AACA;AACA,iBAAiB,wBAAwB;AACzC,oCAAoC,aAAa;AACjD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mCAAmC,QAAQ;AAC3C;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uCAAuC,aAAa;AACpD;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4BAA4B,qBAAqB;AACjD;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,mBAAmB,iBAAiB;AACpC;AACA,qBAAqB,iBAAiB;AACtC;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,yBAAyB,qBAAqB;AAC9C;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,eAAe,iBAAiB;AAChC;AACA;AACA;AACA,+CAA+C,QAAQ;AACvD;AACA;AACA,OAAO;AACP,mBAAmB,qBAAqB;AACxC;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,uCAAuC,+CAA+C;AACtF;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc,qBAAqB;AACnC;AACA,uCAAuC;AACvC;AACA,mCAAmC,oBAAoB;AACvD,OAAO,OAAO,oBAAoB;AAClC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,sCAAsC,8CAA8C;AACpF;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc,qBAAqB;AACnC;AACA,2CAA2C;AAC3C;AACA,mCAAmC,oBAAoB;AACvD,OAAO,OAAO,oBAAoB;AAClC;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB,mBAAmB,iBAAiB;AACpC;AACA;AACA,mDAAmD,kCAAkC;AACrF,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB,mBAAmB,iBAAiB;AACpC,sCAAsC;AACtC;AACA;AACA,uCAAuC,sBAAsB;AAC7D,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB;AACvB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,iBAAiB;AACpC;AACA,qBAAqB,kBAAkB;AACvC;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB;AACtB,mBAAmB,iBAAiB;AACpC;;AAEA,qBAAqB,uBAAuB;AAC5C;AACA,6CAA6C,8BAA8B;AAC3E,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,iBAAiB;AACpC,+BAA+B,yCAAyC;AACxE;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,eAAe,iBAAiB;AAChC;AACA,iBAAiB,kBAAkB;AACnC;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;;AAEA;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,oEAAoE,4BAA4B,EAAE;AAClG;AACA,mEAAmE;AACnE;AACA;AACA,OAAO;AACP;AACA;AACA;;AAEA;AACA;AACA,kCAAkC,oCAAoC;AACtE;AACA,wCAAwC,uCAAuC;AAC/E;AACA,cAAc,sCAAsC;AACpD;AACA;AACA;AACA,kCAAkC,oCAAoC;AACtE;AACA,wCAAwC,uCAAuC;AAC/E;AACA,cAAc,sCAAsC;AACpD;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qEAAqE,0BAA0B,EAAE;AACjG;;AAEA,mBAAmB,YAAY;AAC/B;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA,qBAAqB,iBAAiB;AACtC;AACA;AACA;AACA,yDAAyD,iBAAiB;AAC1E;AACA;AACA;AACA;AACA;AACA,eAAe;AACf;AACA;AACA,eAAe;AACf;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA,OAAO;;AAEP;AACA;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,OAAO;;AAEP;AACA;AACA;AACA,uBAAuB,mBAAmB;AAC1C,mCAAmC,aAAa;AAChD;AACA;AACA,OAAO;;AAEP;AACA;AACA,OAAO;;AAEP;AACA;AACA;AACA,6CAA6C;AAC7C;AACA;AACA;AACA,aAAa;AACb,WAAW;AACX;AACA,SAAS;AACT;AACA;AACA;AACA,OAAO;;AAEP;AACA;AACA,OAAO;AACP;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;;AAEA,yBAAyB,cAAc,qBAAqB;;AAE5D;AACA;AACA,wCAAwC,aAAa;AACrD;AACA;AACA,yCAAyC,kCAAkC;AAC3E;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA,wCAAwC,aAAa;AACrD;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,gCAAgC,aAAa;AAC7C;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA,SAAS;AACT;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;;AAEA;AACA,gCAAgC,aAAa;AAC7C;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;AACT;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA,4BAA4B,QAAQ;AACpC;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;;AAEA;AACA,4BAA4B,QAAQ;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA,qBAAqB,QAAQ;AAC7B;AACA;;AAEA;AACA;AACA;;AAEA;AACA,mCAAmC,8BAA8B;AACjE;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,mCAAmC,+BAA+B,EAAE;AACpE;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA,cAAc,aAAa,gCAAgC,EAAE;AAC7D,UAAU,aAAa,oCAAoC,EAAE;;AAE7D;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,mBAAmB,kBAAkB;AACrC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4CAA4C,UAAU,EAAE;;AAExD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,mCAAmC;AACrE,OAAO;AACP;AACA,kCAAkC,mCAAmC;;AAErE;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACA,6CAA6C,iEAAiE;AAC9G,sBAAsB,iEAAiE;AACvF,iDAAiD,mBAAmB;AACpE,kCAAkC,2CAA2C;AAC7E,oDAAoD,8BAA8B;AAClF;AACA,OAAO;AACP,kCAAkC,2CAA2C;AAC7E,oDAAoD,8BAA8B;AAClF;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA,sBAAsB,6DAA6D;AACnF;AACA;AACA,kCAAkC,iBAAiB,6DAA6D,EAAE;AAClH,YAAY,iBAAiB,8DAA8D,EAAE;AAC7F;;AAEA;AACA;AACA;AACA,kCAAkC,iBAAiB,6DAA6D,EAAE;AAClH,YAAY,iBAAiB,8DAA8D,EAAE;AAC7F;AACA;AACA,yBAAyB,uBAAuB;AAChD;AACA,oCAAoC,6CAA6C;AACjF,iEAAiE,oCAAoC;AACrG;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,uBAAuB,uBAAuB;AAC9C;AACA,kCAAkC,iDAAiD;AACnF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gCAAgC,gBAAgB;;AAEhD;AACA;AACA,kBAAkB,aAAa,oCAAoC,EAAE;AACrE,cAAc,aAAa,qCAAqC,EAAE;AAClE,OAAO,OAAO,aAAa,sCAAsC,EAAE;AACnE;;AAEA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;AACT;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA,wCAAwC,wBAAwB;AAChE;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,iBAAiB,4CAA4C;AAC7D;AACA,2CAA2C,OAAO;AAClD;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA,eAAe,yBAAyB;AACxC;AACA;AACA;AACA;AACA;;AAEA;AACA,oBAAoB,qDAAqD;AACzE;;AAEA;AACA;AACA;AACA,mBAAmB,mBAAmB;AACtC;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA,8BAA8B,QAAQ;AACtC,6DAA6D,6BAA6B;;AAE1F;AACA,cAAc,0BAA0B;;AAExC;AACA;;AAEA;AACA;;AAEA,mBAAmB,mBAAmB;AACtC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL,qEAAqE,wCAAwC;;AAE7G;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB,uBAAuB;AAC5C;AACA;AACA;AACA,WAAW;AACX;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,oEAAoE,iBAAiB;AACrF;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,uCAAuC,iCAAiC;AACxE;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB,0BAA0B;AAC/C,yCAAyC,mBAAmB;AAC5D;AACA;;AAEA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,cAAc,sCAAsC;;AAEpD;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,iCAAiC,8EAA8E;AAC/G,YAAY,+DAA+D;AAC3E;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,wCAAwC,cAAc;AACtD,6CAA6C,cAAc;AAC3D,YAAY,eAAe;AAC3B;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,wCAAwC,cAAc;AACtD,6CAA6C,cAAc;AAC3D,YAAY,eAAe;AAC3B;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA,yBAAyB,gBAAgB;;AAEzC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,uCAAuC,iCAAiC;;AAExE;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA,qBAAqB,uBAAuB;AAC5C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gDAAgD,cAAc;AAC9D;AACA;;AAEA;AACA,mCAAmC,oBAAoB;AACvD,wCAAwC,oBAAoB;AAC5D,UAAU,qBAAqB;;;AAG/B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8CAA8C,QAAQ;AACtD,oCAAoC,QAAQ;AAC5C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,sBAAsB,cAAc;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,sBAAsB,cAAc;AACpC;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,mCAAmC;AACvD;AACA;AACA;AACA,0DAA0D,uBAAuB,EAAE;AACnF,8DAA8D,uBAAuB,EAAE;;AAEvF;AACA;AACA;AACA;AACA;AACA,0BAA0B,oCAAoC;AAC9D;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,6BAA6B,QAAQ;AACrC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,WAAW;AACX,SAAS;AACT;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,SAAS;AACT,OAAO;AACP;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,uBAAuB,oBAAoB;AAC3C;AACA;AACA;AACA;AACA;AACA;;AAEA,kEAAkE,qCAAqC;;AAEvG;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,wCAAwC,uBAAuB;AAC/D,kFAAkF,wBAAwB;AAC1G;AACA,KAAK;AACL,qBAAqB,2BAA2B;AAChD;AACA;AACA,4CAA4C,UAAU;AACtD;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,4GAA4G,QAAQ;AACpH;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,4EAA4E,QAAQ;AACpF;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB,mBAAmB;AACxC,wBAAwB,8BAA8B;AACtD;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,qBAAqB,mBAAmB;AACxC,wBAAwB,+BAA+B;AACvD;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,gCAAgC,YAAY;AAC5C;AACA;AACA;AACA;;AAEA;AACA,uBAAuB,qBAAqB;AAC5C,0BAA0B,gCAAgC;AAC1D;AACA;AACA,KAAK;AACL;AACA;;AAEA,qBAAqB,2BAA2B;AAChD;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,qBAAqB,0BAA0B;AAC/C;AACA,2CAA2C,0CAA0C;AACrF,6CAA6C,qBAAqB;AAClE;AACA;AACA,KAAK;AACL;AACA,yCAAyC,0CAA0C;AACnF,2CAA2C,qBAAqB;AAChE;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;;AAEA;AACA,mBAAmB,0BAA0B;AAC7C;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,4CAA4C,oBAAoB;AAChE,sCAAsC,oBAAoB;AAC1D;AACA;AACA;;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B,qBAAqB;AAC/C;AACA,8DAA8D,QAAQ;AACtE,8DAA8D,QAAQ;AACtE,yCAAyC,QAAQ;AACjD;AACA;AACA;AACA;AACA;AACA,kDAAkD,QAAQ;AAC1D;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA;AACA,+BAA+B,iCAAiC;AAChE;AACA;AACA,8CAA8C,wBAAwB;AACtE;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B,qBAAqB;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA,sDAAsD,QAAQ;AAC9D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wDAAwD,QAAQ;;AAEhE;AACA;;AAEA;AACA;AACA,0HAA0H,QAAQ;;AAElI;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,cAAc,cAAc;;AAE5B;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8BAA8B,4IAA4I;AAC1K,KAAK;AACL;AACA,8BAA8B,2IAA2I;AACzK;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA,+BAA+B,QAAQ;;AAEvC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B,qBAAqB;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,gCAAgC,iCAAiC;AACjE;AACA,4CAA4C,QAAQ;AACpD;AACA,SAAS;AACT;AACA;AACA,gCAAgC,iCAAiC;AACjE;AACA;AACA;;AAEA;AACA;AACA,8BAA8B,0BAA0B;AACxD,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,kBAAkB,4BAA4B;;AAE9C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA,qDAAqD,qBAAqB;AAC1E,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA,qDAAqD,qBAAqB;AAC1E,SAAS;AACT;AACA,yBAAyB,qBAAqB;AAC9C;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA,SAAS;AACT;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2EAA2E,QAAQ;AACnF;;AAEA;AACA;AACA;AACA,gDAAgD,QAAQ;AACxD;AACA,aAAa;AACb,WAAW;AACX,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gDAAgD,QAAQ;AACxD;AACA,aAAa;AACb;AACA,SAAS;AACT;AACA;;AAEA;AACA;AACA,OAAO;AACP;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,mBAAmB,uBAAuB;AAC1C;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8CAA8C,mDAAmD;AACjG,cAAc,2BAA2B;AACzC;AACA;AACA,mDAAmD,mDAAmD;AACtG,cAAc,2BAA2B;AACzC;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA,qCAAqC,QAAQ;;AAE7C;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,wCAAwC,oBAAoB;AAC5D;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA,4HAA4H,gCAAgC;AAC5J;AACA,mGAAmG,mCAAmC;AACtI;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA,8HAA8H,gCAAgC;AAC9J;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,2CAA2C;AAC3C;AACA;AACA,iFAAiF,QAAQ;;AAEzF;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,kDAAkD,QAAQ;AAC1D;AACA;AACA,WAAW;AACX;AACA,WAAW;AACX;AACA;AACA,SAAS;AACT;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,OAAO;;AAEP;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,uBAAuB,kBAAkB;AACzC;AACA;AACA;AACA;AACA,KAAK;AACL,iCAAiC,0CAA0C,EAAE;AAC7E,mBAAmB,mBAAmB;AACtC;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;;AAEA,qBAAqB;;AAErB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,KAAK;;AAEL;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA,iBAAiB;;AAEjB;AACA;AACA;AACA,qBAAqB,YAAY;AACjC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,4FAA4F,QAAQ;AACpG,8CAA8C,0BAA0B;AACxE;AACA,gDAAgD,iBAAiB;AACjE;AACA;AACA;AACA,mBAAmB,gCAAgC;AACnD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,wCAAwC,kDAAkD;;AAE1F;AACA;AACA;AACA;AACA;;AAEA,yBAAyB;;AAEzB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,oBAAoB,aAAa;;AAEjC,8BAA8B;AAC9B,6BAA6B,gBAAgB;;AAE7C;;AAEA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;;AAEP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0EAA0E,QAAQ;AAClF,0EAA0E,QAAQ;AAClF;AACA,uCAAuC;AACvC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yCAAyC,4BAA4B,kBAAkB;AACvF;AACA,OAAO;;AAEP;AACA,wCAAwC;AACxC;;AAEA;AACA,qCAAqC;AACrC,6CAA6C;AAC7C,2CAA2C;;AAE3C;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,yCAAyC,WAAW,kBAAkB;AACtE;AACA,SAAS;AACT;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;;AAET;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;;AAET;AACA;AACA;;AAEA,OAAO;;AAEP;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,2BAA2B,oBAAoB,qBAAqB,YAAY,qBAAqB,SAAS,qBAAqB,KAAK,qBAAqB;;AAE7J;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qCAAqC,mBAAmB;AACxD;AACA;AACA;AACA,yCAAyC,kBAAkB;AAC3D;AACA;AACA,uCAAuC,UAAU;AACjD;AACA;AACA;AACA,yCAAyC,kBAAkB;AAC3D;AACA;AACA,OAAO;AACP,uCAAuC,qBAAqB;AAC5D;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,wCAAwC,QAAQ;AAChD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,OAAO;;AAEP;AACA,uBAAuB,iBAAiB;;AAExC;AACA;;AAEA;AACA;AACA,+BAA+B,QAAQ;;AAEvC;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,OAAO;;AAEP;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qEAAqE,QAAQ;AAC7E;AACA;AACA,WAAW;AACX;AACA,qEAAqE,QAAQ;AAC7E;AACA,WAAW;AACX,SAAS;AACT,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,SAAS;AACT;AACA;AACA,OAAO;;AAEP;AACA;AACA;AACA;AACA,OAAO;;AAEP;AACA,KAAK;AACL;AACA;AACA,yDAAyD,QAAQ;AACjE;AACA;AACA,uBAAuB,6BAA6B;AACpD;AACA;AACA;AACA;AACA,6CAA6C,gDAAgD;;AAE7F;AACA,oDAAoD,oBAAoB;AACxE,KAAK;AACL;AACA;AACA;AACA;AACA,OAAO;AACP;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,gCAAgC,sBAAsB;AACtD,YAAY,qDAAqD;;AAEjE;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,OAAO;;AAEP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8BAA8B,SAAS;AACvC;AACA;AACA;AACA,WAAW;AACX,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,kCAAkC,iBAAiB;AACnD;AACA;AACA;AACA;AACA;AACA,uBAAuB,qBAAqB;AAC5C;AACA;AACA;AACA,WAAW;AACX,mCAAmC,yBAAyB;AAC5D,qCAAqC,0BAA0B;AAC/D;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,2CAA2C,cAAc,EAAE;AAC3D;AACA,OAAO;AACP;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sDAAsD,iDAAiD;AACvG,yBAAyB,wCAAwC;AACjE;AACA,KAAK;AACL;AACA;AACA;AACA,uBAAuB,mBAAmB;AAC1C,0BAA0B,uCAAuC;AACjE;AACA,OAAO;AACP;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;;AAEA;AACA,uBAAuB,mBAAmB;AAC1C,0BAA0B,0CAA0C;AACpE;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,2EAA2E,QAAQ;AACnF;AACA;AACA,8CAA8C,QAAQ;AACtD;AACA;AACA;AACA;AACA,+CAA+C,kBAAkB;AACjE;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA,0CAA0C,kBAAkB;AAC5D;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB;AACnB,SAAS;AACT,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA,6CAA6C,QAAQ;AACrD;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,6CAA6C,QAAQ;AACrD;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA,4BAA4B,qBAAqB,EAAE;AACnD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB,+CAA+C;AACjE;AACA;AACA;AACA;AACA;AACA,uBAAuB,wBAAwB;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB,kBAAkB;AACxC;AACA;AACA;AACA,iCAAiC,oBAAoB;AACrD,gBAAgB,uBAAuB;AACvC;AACA,sFAAsF,oBAAoB;AAC1G,sFAAsF,oBAAoB;AAC1G,OAAO;AACP;AACA,iCAAiC,oBAAoB;AACrD,gBAAgB,uBAAuB;AACvC;AACA,qCAAqC,oBAAoB;AACzD,qCAAqC,oBAAoB;AACzD;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,oCAAoC,QAAQ;AAC5C;AACA;AACA,KAAK;AACL;AACA;AACA,qCAAqC,QAAQ;AAC7C;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;;AAEA;AACA;AACA,8CAA8C;AAC9C;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,4DAA4D,yBAAyB;AACrF;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;;AAEA;AACA,iBAAiB;AACjB;AACA,iBAAiB;;AAEjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,gCAAgC;AAChC;AACA;AACA,SAAS,OAAO;AAChB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;;AAEA,2DAA2D,aAAa;;AAExE,4BAA4B,qBAAqB,EAAE;AACnD;AACA;;AAEA;;AAEA;AACA;AACA,8DAA8D,iCAAiC;AAC/F,gBAAgB,aAAa;AAC7B,SAAS,0DAA0D,qBAAqB;AACxF,cAAc,aAAa;AAC3B,OAAO;AACP;AACA;;AAEA,wBAAwB,aAAa;;AAErC,0BAA0B,gBAAgB;;AAE1C;AACA;AACA;AACA;AACA;AACA;AACA,aAAa,kCAAkC,aAAa;AAC5D,WAAW;AACX;AACA;AACA,WAAW,kCAAkC,aAAa;AAC1D;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,gDAAgD,kCAAkC;AAClF,gDAAgD,kCAAkC;;AAElF;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;;AAEA;AACA,mFAAmF,wBAAwB;AAC3G;AACA,uFAAuF,aAAa;AACpG;;AAEA,6BAA6B,oBAAoB;AACjD,YAAY,uBAAuB;AACnC;AACA,KAAK;AACL;AACA;AACA,8BAA8B,cAAc;AAC5C,sCAAsC,cAAc;AACpD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,8BAA8B,cAAc;AAC5C,uCAAuC,cAAc;AACrD;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA,+CAA+C,4BAA4B;AAC3E,OAAO;AACP;AACA;AACA,wCAAwC,6BAA6B;AACrE,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;;AAEA,+BAA+B,QAAQ;AACvC;AACA;AACA;;AAEA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,sDAAsD,QAAQ;AAC9D;AACA,KAAK;AACL;AACA;AACA;AACA,gDAAgD,QAAQ;AACxD;AACA,KAAK;AACL;AACA;AACA;AACA,8CAA8C,QAAQ;;AAEtD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,gHAAgH,QAAQ;AACxH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,kBAAkB;AACpD,wEAAwE,2BAA2B;AACnG,OAAO;AACP;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,oCAAoC,gBAAgB;AACpD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,gHAAgH,QAAQ;AACxH;;AAEA;AACA;AACA;AACA;AACA,uBAAuB,qBAAqB;AAC5C;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,uBAAuB,QAAQ;;AAE/B;AACA,6BAA6B,QAAQ;;AAErC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,mCAAmC,8BAA8B;AACjE;AACA,SAAS;AACT;;AAEA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA,gHAAgH,QAAQ;AACxH;;AAEA;AACA;AACA,sCAAsC,iEAAiE;AACvG;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kDAAkD,eAAe,EAAE;AACnE,gDAAgD,eAAe,EAAE;AACjE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;AACA,gEAAgE,QAAQ;AACxE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,OAAO;AACP;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA,KAAK;AACL;AACA;AACA,gEAAgE,QAAQ;AACxE;AACA,KAAK;AACL;AACA;AACA,gEAAgE,QAAQ;;AAExE;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;;AAEA;AACA;AACA,OAAO;AACP;AACA;;AAEA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;;AAEA,wCAAwC,QAAQ;AAChD,6BAA6B,oBAAoB;AACjD,YAAY,uBAAuB;AACnC;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;;AAEA,wCAAwC,QAAQ;AAChD;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,wCAAwC,QAAQ;AAChD;AACA;AACA;AACA;AACA;AACA;AACA,iFAAiF,iCAAiC;AAClH,kFAAkF,gCAAgC;AAClH;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,wCAAwC,QAAQ;AAChD;AACA;AACA;AACA;AACA;AACA;AACA,iFAAiF,iCAAiC;AAClH,kFAAkF,gCAAgC;AAClH;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,wCAAwC,QAAQ;AAChD;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,OAAO;;AAEP;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,OAAO;AACP;AACA;AACA;;AAEA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX,OAAO;AACP,KAAK;AACL;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,+BAA+B,sBAAsB;AACrD;AACA,SAAS;AACT,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA,8CAA8C,QAAQ;AACtD;AACA;AACA,OAAO;AACP;AACA;AACA,8CAA8C,QAAQ;AACtD;AACA,OAAO;AACP;AACA;AACA,8CAA8C,QAAQ;AACtD;AACA,OAAO;AACP;AACA;AACA,8CAA8C,QAAQ;AACtD;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;AACA,uCAAuC,UAAU;AACjD;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4CAA4C,yDAAyD;AACrG;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+DAA+D,QAAQ;AACvE;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+DAA+D,QAAQ;AACvE;AACA;AACA;AACA;AACA,6BAA6B,8BAA8B;AAC3D,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,+DAA+D,QAAQ;AACvE,4BAA4B,QAAQ;AACpC,2BAA2B,oBAAoB;AAC/C;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,+DAA+D,QAAQ;AACvE;AACA,kDAAkD,QAAQ;;AAE1D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,mFAAmF,QAAQ;;AAE3F;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,oCAAoC,iDAAiD;AACrF,oCAAoC,iDAAiD;AACrF,+BAA+B,gCAAgC;AAC/D;AACA;AACA,0EAA0E,gBAAgB;AAC1F,0EAA0E,gBAAgB;AAC1F;AACA;AACA;;AAEA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,+DAA+D,QAAQ;AACvE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,6BAA6B,4EAA4E;AACzG,6BAA6B,4EAA4E;AACzG;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,+DAA+D,QAAQ;;AAEvE;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,+DAA+D,QAAQ;;AAEvE;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,yBAAyB,QAAQ;AACjC;;AAEA,sIAAsI,gCAAgC;;AAEtK;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,0BAA0B,QAAQ;;AAElC;;AAEA,sIAAsI,gCAAgC;;AAEtK;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B;AAC1B,4BAA4B;AAC5B,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;;AAEA;AACA;AACA,OAAO;AACP;AACA;AACA,OAAO;;AAEP;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,mCAAmC,QAAQ;AAC3C;AACA,OAAO;AACP;AACA;AACA,mCAAmC,QAAQ;AAC3C;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;;AAEA;AACA;AACA,yCAAyC,QAAQ;AACjD,uCAAuC,QAAQ;AAC/C;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,iCAAiC,QAAQ;;AAEzC;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,8HAA8H,QAAQ;AACtI;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,SAAS;;AAET;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,SAAS,0BAA0B,aAAa;AAChD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,4CAA4C,uCAAuC;AACnF;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP,iCAAiC,iCAAiC;AAClE,8BAA8B,4BAA4B;AAC1D;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qDAAqD,gBAAgB;AACrE,kCAAkC,8BAA8B;AAChE;AACA;AACA,kCAAkC,mBAAmB;AACrD,kCAAkC,8BAA8B;AAChE;AACA,SAAS;AACT;AACA,qCAAqC,gDAAgD;;AAErF;AACA,qCAAqC,gDAAgD;AACrF;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;;AAEA,mCAAmC,kBAAkB;;AAErD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,kBAAkB,UAAU;;AAE5B;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB,uBAAuB;AAC9C;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,8BAA8B,QAAQ;AACtC;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA,mBAAmB,uBAAuB;AAC1C;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA,yCAAyC,QAAQ;AACjD;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,yCAAyC,QAAQ;AACjD;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,yCAAyC,QAAQ;AACjD;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,yCAAyC,QAAQ;AACjD;AACA,OAAO;AACP;AACA;AACA,yCAAyC,QAAQ;AACjD;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,6BAA6B,QAAQ;AACrC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,sCAAsC,QAAQ;AAC9C;AACA;AACA,KAAK;AACL;AACA;;AAEA,+BAA+B,QAAQ;AACvC;AACA;AACA;;AAEA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sFAAsF,OAAO;AAC7F,SAAS;AACT;AACA,KAAK;AACL;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,wEAAwE,iCAAiC;;AAEzG;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gDAAgD,OAAO;AACvD,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA,0CAA0C,QAAQ;AAClD;AACA;AACA,OAAO;AACP;AACA;AACA,0CAA0C,QAAQ;AAClD;AACA,OAAO;AACP;AACA;AACA,0CAA0C,QAAQ;AAClD;AACA,OAAO;AACP;AACA;AACA,0CAA0C,QAAQ;AAClD;AACA,OAAO;AACP;AACA;AACA,0CAA0C,QAAQ;AAClD;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;AACA,mCAAmC,QAAQ;AAC3C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uDAAuD,QAAQ;AAC/D;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA,wFAAwF,oBAAoB,EAAE;AAC9G;AACA;AACA;AACA,cAAc;AACd,KAAK;AACL;AACA;AACA,0EAA0E,QAAQ;AAClF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,eAAe;AACjD,OAAO;AACP,+BAA+B,eAAe;AAC9C;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,sDAAsD,YAAY;AAClE;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8CAA8C,QAAQ;AACtD;AACA;AACA,KAAK;AACL;AACA;AACA,wFAAwF,QAAQ;AAChG;AACA,kHAAkH,KAAE;AACpH,OAAO;AACP;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,8GAA8G,QAAQ;AACtH;AACA;AACA;AACA;AACA,sDAAsD,YAAY;AAClE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA,WAAW;AACX;AACA;AACA,WAAW;AACX;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;AACT;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA,2DAA2D,cAAc;AACzE,oCAAoC,cAAc;AAClD;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,qCAAqC,cAAc;AACnD,2DAA2D,cAAc;;AAEzE;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,qCAAqC,QAAQ;AAC7C,mCAAmC,QAAQ;AAC3C,oCAAoC,uCAAuC;AAC3E;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oEAAoE,QAAQ;AAC5E,oCAAoC,QAAQ;AAC5C;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,WAAW;AACX,SAAS;AACT,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA,qBAAqB,mBAAmB;AACxC;AACA;AACA;AACA,8CAA8C,wBAAwB;AACtE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+BAA+B,QAAQ;AACvC,4CAA4C,QAAQ;AACpD;AACA;AACA;AACA,yBAAyB,0BAA0B;AACnD;AACA;AACA,SAAS;AACT;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA,8CAA8C,QAAQ;AACtD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,8CAA8C,QAAQ;AACtD;AACA,OAAO;AACP;AACA;AACA,8CAA8C,QAAQ;AACtD;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6BAA6B,+BAA+B;AAC5D,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB,mBAAmB;AACxC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,oBAAoB,sDAAsD;AAC1E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oCAAoC,wDAAwD;AAC5F,mCAAmC,sDAAsD;AACzF;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;;AAEP;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA,8CAA8C,QAAQ;AACtD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,8CAA8C,QAAQ;AACtD;AACA,OAAO;AACP;AACA;AACA,8CAA8C,QAAQ;AACtD;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA,qBAAqB,mBAAmB;AACxC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oCAAoC,wDAAwD;AAC5F,mCAAmC,sDAAsD;AACzF;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+BAA+B,QAAQ;AACvC,4CAA4C,QAAQ;AACpD;AACA;AACA;AACA;AACA,yBAAyB,0BAA0B;AACnD;AACA;AACA,SAAS;AACT;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA,8CAA8C,QAAQ;AACtD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,8CAA8C,QAAQ;AACtD;AACA,OAAO;AACP;AACA;AACA,8CAA8C,QAAQ;AACtD;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6CAA6C,YAAY;AACzD;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,2CAA2C,gBAAgB;AAC3D,2CAA2C,gBAAgB;AAC3D,2CAA2C,gBAAgB;AAC3D,wCAAwC,aAAa;AACrD,wCAAwC,aAAa;;AAErD;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uCAAuC,gFAAgF;AACvH,sCAAsC,mFAAmF;AACzH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA,mDAAmD,QAAQ;;AAE3D;AACA;;AAEA;AACA;AACA,OAAO;AACP;AACA;AACA,mDAAmD,QAAQ;AAC3D;AACA,OAAO;AACP;AACA;AACA,mDAAmD,QAAQ;AAC3D;AACA,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP,8DAA8D;AAC9D;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,0BAA0B,QAAQ;AAClC;AACA;AACA,iGAAiG,QAAQ;AACzG,yEAAyE,QAAQ;AACjF;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+CAA+C,0BAA0B;AACzE,oDAAoD,0BAA0B;AAC9E,uEAAuE,0BAA0B;AACjG,cAAc,0BAA0B;AACxC;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,0BAA0B,QAAQ;;AAElC;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uDAAuD,kCAAkC;AACzF,4DAA4D,kCAAkC;AAC9F,mGAAmG,qCAAqC;AACxI,iGAAiG,kCAAkC;AACnI,gBAAgB,kCAAkC;AAClD,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,uBAAuB,sBAAsB;AAC7C;AACA;AACA,OAAO;AACP,yBAAyB,wBAAwB;AACjD;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,wCAAwC,QAAQ;AAChD;AACA;AACA,OAAO;AACP;AACA;AACA,oCAAoC,QAAQ;AAC5C;AACA,OAAO;AACP;AACA;AACA,oCAAoC,QAAQ;AAC5C;AACA,OAAO;AACP;AACA;AACA,oCAAoC,QAAQ;AAC5C;AACA,OAAO;AACP;AACA;AACA,oCAAoC,QAAQ;AAC5C;AACA,OAAO;AACP;AACA;AACA;AACA,4BAA4B,QAAQ;AACpC;AACA,OAAO;AACP;AACA;AACA;AACA,4BAA4B,QAAQ;AACpC;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA,CAAC;;;;;;;;ACr8PD,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,+B;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,uC;;;;;;;ACAA,iBAAiB,qBAAuB,gC;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iCAAiC,wnE;;;;;;;ACAjC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,oC;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,uC;;;;;;;ACAA,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,mC;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2B;;;;;;;ACpRA,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iCAAiC,ohJ;;;;;;;ACAjC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;;;;;;ACAxC;;AAEA;AACA;AACA,MAAM,IAAuC;AAC7C,2BAA2B,mBAAO,CAAC,MAA0B;AAC7D;;AAEA;AACA;AACA,wDAAwD,wBAAwB;AAChF;AAC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;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,6B;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,6B;;;;;;;ACAxC,uC;;;;;;;ACAA,iBAAiB,qBAAuB,yB;;;;;;;;ACAxC;AAAA;AAAA;;;;;;;;ACAA,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,qC;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;;ACAxC;AAAA;AAAA;;;;;;;;ACAA,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,gC;;;;;;;ACAA,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,uC;;;;;;;ACAA,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,6B;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;;ACAxC;AAAA;AAAA;;;;;;;;ACAA,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;;ACAxC;AAAA;AAAA;;;;;;;;ACAA,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,uC;;;;;;;ACAA,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,mC;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iCAAiC,gxI;;;;;;;ACAjC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,6B;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;;ACAxC;AAAA;AAAA;;;;;;;;;ACAA;AAAA;AAAA;;;;;;;;ACAA,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,oC;;;;;;;ACAxC,iBAAiB,qBAAuB,iC;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;;ACAxC;AAAA;AAAA;;;;;;;;ACAA,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,uC;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,uC;;;;;;;ACAA,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,mC;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,6B;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iCAAiC,4uG;;;;;;;ACAjC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,eAAe,KAAiD,kBAAkB,mBAAO,CAAC,MAA0B,GAAG,SAAqM,CAAC,kBAAkB,mBAAmB,cAAc,4BAA4B,YAAY,qBAAqB,2DAA2D,SAAS,mCAAmC,SAAS,qBAAqB,qCAAqC,oCAAoC,EAAE,iBAAiB,iCAAiC,iBAAiB,YAAY,UAAU,sBAAsB,mBAAmB,iDAAiD,kBAAkB,gBAAgB,YAAY,eAAe,gCAAgC,eAAe,oBAAoB,gDAAgD,uCAAuC,iHAAiH,MAAM,oBAAoB,0PAA0P,+BAA+B,+CAA+C,4CAA4C,wBAAwB,sCAAsC,OAAO,iCAAiC,iBAAiB,aAAa,sCAAsC,SAAS,EAAE,iEAAiE,oBAAoB,iBAAiB,aAAa,sCAAsC,SAAS,EAAE,iEAAiE,oBAAoB,iBAAiB,aAAa,cAAc,0BAA0B,WAAW,sCAAsC,SAAS,mDAAmD,iHAAiH,qDAAqD,SAAS,8EAA8E,IAAI,2CAA2C,8DAA8D,iBAAiB,aAAa,sCAAsC,SAAS,aAAa,oCAAoC,OAAO,2BAA2B,kBAAkB,cAAc,oBAAoB,qIAAqI,oBAAoB,cAAc,qBAAqB,cAAc,UAAU,kBAAkB,4DAA4D,iBAAiB,aAAa,sCAAsC,SAAS,EAAE,yBAAyB,0BAA0B,WAAW,+BAA+B,yEAAyE,oBAAoB,6EAA6E,wBAAwB,mBAAmB,KAAK,mBAAmB,iFAAiF,SAAS,6BAA6B,EAAE,+aAA+a,WAAW,qBAAqB,SAAS,+BAA+B,UAAU,gBAAgB,2CAA2C,WAAW,iBAAiB,OAAO,qBAAqB,gCAAgC,kBAAkB,kCAAkC,oBAAoB,iBAAiB,SAAS,kHAAkH,2DAA2D,sBAAsB,cAAc,oBAAoB,cAAc,0BAA0B,0BAA0B,6EAA6E,EAAE,UAAU,kBAAkB,gOAAgO,0BAA0B,sBAAsB,kCAAkC,gFAAgF,uBAAuB,kBAAkB,sBAAsB,yBAAyB,8KAA8K,EAAE,KAAK,iBAAiB,aAAa,iBAAiB,8CAA8C,gBAAgB,+BAA+B,yCAAyC,6BAA6B,+IAA+I,SAAS,4BAA4B,MAAM,iBAAiB,aAAa,iBAAiB,8BAA8B,6BAA6B,mBAAmB,sBAAsB,SAAS,4BAA4B,MAAM,GAAG,E;;;;;;;ACA7zL,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,uC;;;;;;;ACAA,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,kC;;;;;;;ACAxC,uC;;;;;;;ACAA,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,uC;;;;;;;ACAA,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB;;;;;;;ACAxC,iBAAiB,qBAAuB,yB","file":"draggable-components.common.js","sourcesContent":[" \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = \"54be\");\n","module.exports = __webpack_public_path__ + \"img/bv.d91702a1.svg\";","module.exports = __webpack_public_path__ + \"img/it.27fe7edc.svg\";","module.exports = __webpack_public_path__ + \"img/fk.4e9526a8.svg\";","module.exports = __webpack_public_path__ + \"img/vi.2cca2f61.svg\";","/**\n * Swiper 4.5.1\n * Most modern mobile touch slider and framework with hardware accelerated transitions\n * http://www.idangero.us/swiper/\n *\n * Copyright 2014-2019 Vladimir Kharlampidi\n *\n * Released under the MIT License\n *\n * Released on: September 13, 2019\n */\n\n(function (global, factory) {\n typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :\n typeof define === 'function' && define.amd ? define(factory) :\n (global = global || self, global.Swiper = factory());\n}(this, function () { 'use strict';\n\n /**\n * SSR Window 1.0.1\n * Better handling for window object in SSR environment\n * https://github.com/nolimits4web/ssr-window\n *\n * Copyright 2018, Vladimir Kharlampidi\n *\n * Licensed under MIT\n *\n * Released on: July 18, 2018\n */\n var doc = (typeof document === 'undefined') ? {\n body: {},\n addEventListener: function addEventListener() {},\n removeEventListener: function removeEventListener() {},\n activeElement: {\n blur: function blur() {},\n nodeName: '',\n },\n querySelector: function querySelector() {\n return null;\n },\n querySelectorAll: function querySelectorAll() {\n return [];\n },\n getElementById: function getElementById() {\n return null;\n },\n createEvent: function createEvent() {\n return {\n initEvent: function initEvent() {},\n };\n },\n createElement: function createElement() {\n return {\n children: [],\n childNodes: [],\n style: {},\n setAttribute: function setAttribute() {},\n getElementsByTagName: function getElementsByTagName() {\n return [];\n },\n };\n },\n location: { hash: '' },\n } : document; // eslint-disable-line\n\n var win = (typeof window === 'undefined') ? {\n document: doc,\n navigator: {\n userAgent: '',\n },\n location: {},\n history: {},\n CustomEvent: function CustomEvent() {\n return this;\n },\n addEventListener: function addEventListener() {},\n removeEventListener: function removeEventListener() {},\n getComputedStyle: function getComputedStyle() {\n return {\n getPropertyValue: function getPropertyValue() {\n return '';\n },\n };\n },\n Image: function Image() {},\n Date: function Date() {},\n screen: {},\n setTimeout: function setTimeout() {},\n clearTimeout: function clearTimeout() {},\n } : window; // eslint-disable-line\n\n /**\n * Dom7 2.1.3\n * Minimalistic JavaScript library for DOM manipulation, with a jQuery-compatible API\n * http://framework7.io/docs/dom.html\n *\n * Copyright 2019, Vladimir Kharlampidi\n * The iDangero.us\n * http://www.idangero.us/\n *\n * Licensed under MIT\n *\n * Released on: February 11, 2019\n */\n\n var Dom7 = function Dom7(arr) {\n var self = this;\n // Create array-like object\n for (var i = 0; i < arr.length; i += 1) {\n self[i] = arr[i];\n }\n self.length = arr.length;\n // Return collection with methods\n return this;\n };\n\n function $(selector, context) {\n var arr = [];\n var i = 0;\n if (selector && !context) {\n if (selector instanceof Dom7) {\n return selector;\n }\n }\n if (selector) {\n // String\n if (typeof selector === 'string') {\n var els;\n var tempParent;\n var html = selector.trim();\n if (html.indexOf('<') >= 0 && html.indexOf('>') >= 0) {\n var toCreate = 'div';\n if (html.indexOf('<li') === 0) { toCreate = 'ul'; }\n if (html.indexOf('<tr') === 0) { toCreate = 'tbody'; }\n if (html.indexOf('<td') === 0 || html.indexOf('<th') === 0) { toCreate = 'tr'; }\n if (html.indexOf('<tbody') === 0) { toCreate = 'table'; }\n if (html.indexOf('<option') === 0) { toCreate = 'select'; }\n tempParent = doc.createElement(toCreate);\n tempParent.innerHTML = html;\n for (i = 0; i < tempParent.childNodes.length; i += 1) {\n arr.push(tempParent.childNodes[i]);\n }\n } else {\n if (!context && selector[0] === '#' && !selector.match(/[ .<>:~]/)) {\n // Pure ID selector\n els = [doc.getElementById(selector.trim().split('#')[1])];\n } else {\n // Other selectors\n els = (context || doc).querySelectorAll(selector.trim());\n }\n for (i = 0; i < els.length; i += 1) {\n if (els[i]) { arr.push(els[i]); }\n }\n }\n } else if (selector.nodeType || selector === win || selector === doc) {\n // Node/element\n arr.push(selector);\n } else if (selector.length > 0 && selector[0].nodeType) {\n // Array of elements or instance of Dom\n for (i = 0; i < selector.length; i += 1) {\n arr.push(selector[i]);\n }\n }\n }\n return new Dom7(arr);\n }\n\n $.fn = Dom7.prototype;\n $.Class = Dom7;\n $.Dom7 = Dom7;\n\n function unique(arr) {\n var uniqueArray = [];\n for (var i = 0; i < arr.length; i += 1) {\n if (uniqueArray.indexOf(arr[i]) === -1) { uniqueArray.push(arr[i]); }\n }\n return uniqueArray;\n }\n\n // Classes and attributes\n function addClass(className) {\n if (typeof className === 'undefined') {\n return this;\n }\n var classes = className.split(' ');\n for (var i = 0; i < classes.length; i += 1) {\n for (var j = 0; j < this.length; j += 1) {\n if (typeof this[j] !== 'undefined' && typeof this[j].classList !== 'undefined') { this[j].classList.add(classes[i]); }\n }\n }\n return this;\n }\n function removeClass(className) {\n var classes = className.split(' ');\n for (var i = 0; i < classes.length; i += 1) {\n for (var j = 0; j < this.length; j += 1) {\n if (typeof this[j] !== 'undefined' && typeof this[j].classList !== 'undefined') { this[j].classList.remove(classes[i]); }\n }\n }\n return this;\n }\n function hasClass(className) {\n if (!this[0]) { return false; }\n return this[0].classList.contains(className);\n }\n function toggleClass(className) {\n var classes = className.split(' ');\n for (var i = 0; i < classes.length; i += 1) {\n for (var j = 0; j < this.length; j += 1) {\n if (typeof this[j] !== 'undefined' && typeof this[j].classList !== 'undefined') { this[j].classList.toggle(classes[i]); }\n }\n }\n return this;\n }\n function attr(attrs, value) {\n var arguments$1 = arguments;\n\n if (arguments.length === 1 && typeof attrs === 'string') {\n // Get attr\n if (this[0]) { return this[0].getAttribute(attrs); }\n return undefined;\n }\n\n // Set attrs\n for (var i = 0; i < this.length; i += 1) {\n if (arguments$1.length === 2) {\n // String\n this[i].setAttribute(attrs, value);\n } else {\n // Object\n // eslint-disable-next-line\n for (var attrName in attrs) {\n this[i][attrName] = attrs[attrName];\n this[i].setAttribute(attrName, attrs[attrName]);\n }\n }\n }\n return this;\n }\n // eslint-disable-next-line\n function removeAttr(attr) {\n for (var i = 0; i < this.length; i += 1) {\n this[i].removeAttribute(attr);\n }\n return this;\n }\n function data(key, value) {\n var el;\n if (typeof value === 'undefined') {\n el = this[0];\n // Get value\n if (el) {\n if (el.dom7ElementDataStorage && (key in el.dom7ElementDataStorage)) {\n return el.dom7ElementDataStorage[key];\n }\n\n var dataKey = el.getAttribute((\"data-\" + key));\n if (dataKey) {\n return dataKey;\n }\n return undefined;\n }\n return undefined;\n }\n\n // Set value\n for (var i = 0; i < this.length; i += 1) {\n el = this[i];\n if (!el.dom7ElementDataStorage) { el.dom7ElementDataStorage = {}; }\n el.dom7ElementDataStorage[key] = value;\n }\n return this;\n }\n // Transforms\n // eslint-disable-next-line\n function transform(transform) {\n for (var i = 0; i < this.length; i += 1) {\n var elStyle = this[i].style;\n elStyle.webkitTransform = transform;\n elStyle.transform = transform;\n }\n return this;\n }\n function transition(duration) {\n if (typeof duration !== 'string') {\n duration = duration + \"ms\"; // eslint-disable-line\n }\n for (var i = 0; i < this.length; i += 1) {\n var elStyle = this[i].style;\n elStyle.webkitTransitionDuration = duration;\n elStyle.transitionDuration = duration;\n }\n return this;\n }\n // Events\n function on() {\n var assign;\n\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n var eventType = args[0];\n var targetSelector = args[1];\n var listener = args[2];\n var capture = args[3];\n if (typeof args[1] === 'function') {\n (assign = args, eventType = assign[0], listener = assign[1], capture = assign[2]);\n targetSelector = undefined;\n }\n if (!capture) { capture = false; }\n\n function handleLiveEvent(e) {\n var target = e.target;\n if (!target) { return; }\n var eventData = e.target.dom7EventData || [];\n if (eventData.indexOf(e) < 0) {\n eventData.unshift(e);\n }\n if ($(target).is(targetSelector)) { listener.apply(target, eventData); }\n else {\n var parents = $(target).parents(); // eslint-disable-line\n for (var k = 0; k < parents.length; k += 1) {\n if ($(parents[k]).is(targetSelector)) { listener.apply(parents[k], eventData); }\n }\n }\n }\n function handleEvent(e) {\n var eventData = e && e.target ? e.target.dom7EventData || [] : [];\n if (eventData.indexOf(e) < 0) {\n eventData.unshift(e);\n }\n listener.apply(this, eventData);\n }\n var events = eventType.split(' ');\n var j;\n for (var i = 0; i < this.length; i += 1) {\n var el = this[i];\n if (!targetSelector) {\n for (j = 0; j < events.length; j += 1) {\n var event = events[j];\n if (!el.dom7Listeners) { el.dom7Listeners = {}; }\n if (!el.dom7Listeners[event]) { el.dom7Listeners[event] = []; }\n el.dom7Listeners[event].push({\n listener: listener,\n proxyListener: handleEvent,\n });\n el.addEventListener(event, handleEvent, capture);\n }\n } else {\n // Live events\n for (j = 0; j < events.length; j += 1) {\n var event$1 = events[j];\n if (!el.dom7LiveListeners) { el.dom7LiveListeners = {}; }\n if (!el.dom7LiveListeners[event$1]) { el.dom7LiveListeners[event$1] = []; }\n el.dom7LiveListeners[event$1].push({\n listener: listener,\n proxyListener: handleLiveEvent,\n });\n el.addEventListener(event$1, handleLiveEvent, capture);\n }\n }\n }\n return this;\n }\n function off() {\n var assign;\n\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n var eventType = args[0];\n var targetSelector = args[1];\n var listener = args[2];\n var capture = args[3];\n if (typeof args[1] === 'function') {\n (assign = args, eventType = assign[0], listener = assign[1], capture = assign[2]);\n targetSelector = undefined;\n }\n if (!capture) { capture = false; }\n\n var events = eventType.split(' ');\n for (var i = 0; i < events.length; i += 1) {\n var event = events[i];\n for (var j = 0; j < this.length; j += 1) {\n var el = this[j];\n var handlers = (void 0);\n if (!targetSelector && el.dom7Listeners) {\n handlers = el.dom7Listeners[event];\n } else if (targetSelector && el.dom7LiveListeners) {\n handlers = el.dom7LiveListeners[event];\n }\n if (handlers && handlers.length) {\n for (var k = handlers.length - 1; k >= 0; k -= 1) {\n var handler = handlers[k];\n if (listener && handler.listener === listener) {\n el.removeEventListener(event, handler.proxyListener, capture);\n handlers.splice(k, 1);\n } else if (listener && handler.listener && handler.listener.dom7proxy && handler.listener.dom7proxy === listener) {\n el.removeEventListener(event, handler.proxyListener, capture);\n handlers.splice(k, 1);\n } else if (!listener) {\n el.removeEventListener(event, handler.proxyListener, capture);\n handlers.splice(k, 1);\n }\n }\n }\n }\n }\n return this;\n }\n function trigger() {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var events = args[0].split(' ');\n var eventData = args[1];\n for (var i = 0; i < events.length; i += 1) {\n var event = events[i];\n for (var j = 0; j < this.length; j += 1) {\n var el = this[j];\n var evt = (void 0);\n try {\n evt = new win.CustomEvent(event, {\n detail: eventData,\n bubbles: true,\n cancelable: true,\n });\n } catch (e) {\n evt = doc.createEvent('Event');\n evt.initEvent(event, true, true);\n evt.detail = eventData;\n }\n // eslint-disable-next-line\n el.dom7EventData = args.filter(function (data, dataIndex) { return dataIndex > 0; });\n el.dispatchEvent(evt);\n el.dom7EventData = [];\n delete el.dom7EventData;\n }\n }\n return this;\n }\n function transitionEnd(callback) {\n var events = ['webkitTransitionEnd', 'transitionend'];\n var dom = this;\n var i;\n function fireCallBack(e) {\n /* jshint validthis:true */\n if (e.target !== this) { return; }\n callback.call(this, e);\n for (i = 0; i < events.length; i += 1) {\n dom.off(events[i], fireCallBack);\n }\n }\n if (callback) {\n for (i = 0; i < events.length; i += 1) {\n dom.on(events[i], fireCallBack);\n }\n }\n return this;\n }\n function outerWidth(includeMargins) {\n if (this.length > 0) {\n if (includeMargins) {\n // eslint-disable-next-line\n var styles = this.styles();\n return this[0].offsetWidth + parseFloat(styles.getPropertyValue('margin-right')) + parseFloat(styles.getPropertyValue('margin-left'));\n }\n return this[0].offsetWidth;\n }\n return null;\n }\n function outerHeight(includeMargins) {\n if (this.length > 0) {\n if (includeMargins) {\n // eslint-disable-next-line\n var styles = this.styles();\n return this[0].offsetHeight + parseFloat(styles.getPropertyValue('margin-top')) + parseFloat(styles.getPropertyValue('margin-bottom'));\n }\n return this[0].offsetHeight;\n }\n return null;\n }\n function offset() {\n if (this.length > 0) {\n var el = this[0];\n var box = el.getBoundingClientRect();\n var body = doc.body;\n var clientTop = el.clientTop || body.clientTop || 0;\n var clientLeft = el.clientLeft || body.clientLeft || 0;\n var scrollTop = el === win ? win.scrollY : el.scrollTop;\n var scrollLeft = el === win ? win.scrollX : el.scrollLeft;\n return {\n top: (box.top + scrollTop) - clientTop,\n left: (box.left + scrollLeft) - clientLeft,\n };\n }\n\n return null;\n }\n function styles() {\n if (this[0]) { return win.getComputedStyle(this[0], null); }\n return {};\n }\n function css(props, value) {\n var i;\n if (arguments.length === 1) {\n if (typeof props === 'string') {\n if (this[0]) { return win.getComputedStyle(this[0], null).getPropertyValue(props); }\n } else {\n for (i = 0; i < this.length; i += 1) {\n // eslint-disable-next-line\n for (var prop in props) {\n this[i].style[prop] = props[prop];\n }\n }\n return this;\n }\n }\n if (arguments.length === 2 && typeof props === 'string') {\n for (i = 0; i < this.length; i += 1) {\n this[i].style[props] = value;\n }\n return this;\n }\n return this;\n }\n // Iterate over the collection passing elements to `callback`\n function each(callback) {\n // Don't bother continuing without a callback\n if (!callback) { return this; }\n // Iterate over the current collection\n for (var i = 0; i < this.length; i += 1) {\n // If the callback returns false\n if (callback.call(this[i], i, this[i]) === false) {\n // End the loop early\n return this;\n }\n }\n // Return `this` to allow chained DOM operations\n return this;\n }\n // eslint-disable-next-line\n function html(html) {\n if (typeof html === 'undefined') {\n return this[0] ? this[0].innerHTML : undefined;\n }\n\n for (var i = 0; i < this.length; i += 1) {\n this[i].innerHTML = html;\n }\n return this;\n }\n // eslint-disable-next-line\n function text(text) {\n if (typeof text === 'undefined') {\n if (this[0]) {\n return this[0].textContent.trim();\n }\n return null;\n }\n\n for (var i = 0; i < this.length; i += 1) {\n this[i].textContent = text;\n }\n return this;\n }\n function is(selector) {\n var el = this[0];\n var compareWith;\n var i;\n if (!el || typeof selector === 'undefined') { return false; }\n if (typeof selector === 'string') {\n if (el.matches) { return el.matches(selector); }\n else if (el.webkitMatchesSelector) { return el.webkitMatchesSelector(selector); }\n else if (el.msMatchesSelector) { return el.msMatchesSelector(selector); }\n\n compareWith = $(selector);\n for (i = 0; i < compareWith.length; i += 1) {\n if (compareWith[i] === el) { return true; }\n }\n return false;\n } else if (selector === doc) { return el === doc; }\n else if (selector === win) { return el === win; }\n\n if (selector.nodeType || selector instanceof Dom7) {\n compareWith = selector.nodeType ? [selector] : selector;\n for (i = 0; i < compareWith.length; i += 1) {\n if (compareWith[i] === el) { return true; }\n }\n return false;\n }\n return false;\n }\n function index() {\n var child = this[0];\n var i;\n if (child) {\n i = 0;\n // eslint-disable-next-line\n while ((child = child.previousSibling) !== null) {\n if (child.nodeType === 1) { i += 1; }\n }\n return i;\n }\n return undefined;\n }\n // eslint-disable-next-line\n function eq(index) {\n if (typeof index === 'undefined') { return this; }\n var length = this.length;\n var returnIndex;\n if (index > length - 1) {\n return new Dom7([]);\n }\n if (index < 0) {\n returnIndex = length + index;\n if (returnIndex < 0) { return new Dom7([]); }\n return new Dom7([this[returnIndex]]);\n }\n return new Dom7([this[index]]);\n }\n function append() {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var newChild;\n\n for (var k = 0; k < args.length; k += 1) {\n newChild = args[k];\n for (var i = 0; i < this.length; i += 1) {\n if (typeof newChild === 'string') {\n var tempDiv = doc.createElement('div');\n tempDiv.innerHTML = newChild;\n while (tempDiv.firstChild) {\n this[i].appendChild(tempDiv.firstChild);\n }\n } else if (newChild instanceof Dom7) {\n for (var j = 0; j < newChild.length; j += 1) {\n this[i].appendChild(newChild[j]);\n }\n } else {\n this[i].appendChild(newChild);\n }\n }\n }\n\n return this;\n }\n function prepend(newChild) {\n var i;\n var j;\n for (i = 0; i < this.length; i += 1) {\n if (typeof newChild === 'string') {\n var tempDiv = doc.createElement('div');\n tempDiv.innerHTML = newChild;\n for (j = tempDiv.childNodes.length - 1; j >= 0; j -= 1) {\n this[i].insertBefore(tempDiv.childNodes[j], this[i].childNodes[0]);\n }\n } else if (newChild instanceof Dom7) {\n for (j = 0; j < newChild.length; j += 1) {\n this[i].insertBefore(newChild[j], this[i].childNodes[0]);\n }\n } else {\n this[i].insertBefore(newChild, this[i].childNodes[0]);\n }\n }\n return this;\n }\n function next(selector) {\n if (this.length > 0) {\n if (selector) {\n if (this[0].nextElementSibling && $(this[0].nextElementSibling).is(selector)) {\n return new Dom7([this[0].nextElementSibling]);\n }\n return new Dom7([]);\n }\n\n if (this[0].nextElementSibling) { return new Dom7([this[0].nextElementSibling]); }\n return new Dom7([]);\n }\n return new Dom7([]);\n }\n function nextAll(selector) {\n var nextEls = [];\n var el = this[0];\n if (!el) { return new Dom7([]); }\n while (el.nextElementSibling) {\n var next = el.nextElementSibling; // eslint-disable-line\n if (selector) {\n if ($(next).is(selector)) { nextEls.push(next); }\n } else { nextEls.push(next); }\n el = next;\n }\n return new Dom7(nextEls);\n }\n function prev(selector) {\n if (this.length > 0) {\n var el = this[0];\n if (selector) {\n if (el.previousElementSibling && $(el.previousElementSibling).is(selector)) {\n return new Dom7([el.previousElementSibling]);\n }\n return new Dom7([]);\n }\n\n if (el.previousElementSibling) { return new Dom7([el.previousElementSibling]); }\n return new Dom7([]);\n }\n return new Dom7([]);\n }\n function prevAll(selector) {\n var prevEls = [];\n var el = this[0];\n if (!el) { return new Dom7([]); }\n while (el.previousElementSibling) {\n var prev = el.previousElementSibling; // eslint-disable-line\n if (selector) {\n if ($(prev).is(selector)) { prevEls.push(prev); }\n } else { prevEls.push(prev); }\n el = prev;\n }\n return new Dom7(prevEls);\n }\n function parent(selector) {\n var parents = []; // eslint-disable-line\n for (var i = 0; i < this.length; i += 1) {\n if (this[i].parentNode !== null) {\n if (selector) {\n if ($(this[i].parentNode).is(selector)) { parents.push(this[i].parentNode); }\n } else {\n parents.push(this[i].parentNode);\n }\n }\n }\n return $(unique(parents));\n }\n function parents(selector) {\n var parents = []; // eslint-disable-line\n for (var i = 0; i < this.length; i += 1) {\n var parent = this[i].parentNode; // eslint-disable-line\n while (parent) {\n if (selector) {\n if ($(parent).is(selector)) { parents.push(parent); }\n } else {\n parents.push(parent);\n }\n parent = parent.parentNode;\n }\n }\n return $(unique(parents));\n }\n function closest(selector) {\n var closest = this; // eslint-disable-line\n if (typeof selector === 'undefined') {\n return new Dom7([]);\n }\n if (!closest.is(selector)) {\n closest = closest.parents(selector).eq(0);\n }\n return closest;\n }\n function find(selector) {\n var foundElements = [];\n for (var i = 0; i < this.length; i += 1) {\n var found = this[i].querySelectorAll(selector);\n for (var j = 0; j < found.length; j += 1) {\n foundElements.push(found[j]);\n }\n }\n return new Dom7(foundElements);\n }\n function children(selector) {\n var children = []; // eslint-disable-line\n for (var i = 0; i < this.length; i += 1) {\n var childNodes = this[i].childNodes;\n\n for (var j = 0; j < childNodes.length; j += 1) {\n if (!selector) {\n if (childNodes[j].nodeType === 1) { children.push(childNodes[j]); }\n } else if (childNodes[j].nodeType === 1 && $(childNodes[j]).is(selector)) {\n children.push(childNodes[j]);\n }\n }\n }\n return new Dom7(unique(children));\n }\n function remove() {\n for (var i = 0; i < this.length; i += 1) {\n if (this[i].parentNode) { this[i].parentNode.removeChild(this[i]); }\n }\n return this;\n }\n function add() {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var dom = this;\n var i;\n var j;\n for (i = 0; i < args.length; i += 1) {\n var toAdd = $(args[i]);\n for (j = 0; j < toAdd.length; j += 1) {\n dom[dom.length] = toAdd[j];\n dom.length += 1;\n }\n }\n return dom;\n }\n\n var Methods = {\n addClass: addClass,\n removeClass: removeClass,\n hasClass: hasClass,\n toggleClass: toggleClass,\n attr: attr,\n removeAttr: removeAttr,\n data: data,\n transform: transform,\n transition: transition,\n on: on,\n off: off,\n trigger: trigger,\n transitionEnd: transitionEnd,\n outerWidth: outerWidth,\n outerHeight: outerHeight,\n offset: offset,\n css: css,\n each: each,\n html: html,\n text: text,\n is: is,\n index: index,\n eq: eq,\n append: append,\n prepend: prepend,\n next: next,\n nextAll: nextAll,\n prev: prev,\n prevAll: prevAll,\n parent: parent,\n parents: parents,\n closest: closest,\n find: find,\n children: children,\n remove: remove,\n add: add,\n styles: styles,\n };\n\n Object.keys(Methods).forEach(function (methodName) {\n $.fn[methodName] = $.fn[methodName] || Methods[methodName];\n });\n\n var Utils = {\n deleteProps: function deleteProps(obj) {\n var object = obj;\n Object.keys(object).forEach(function (key) {\n try {\n object[key] = null;\n } catch (e) {\n // no getter for object\n }\n try {\n delete object[key];\n } catch (e) {\n // something got wrong\n }\n });\n },\n nextTick: function nextTick(callback, delay) {\n if ( delay === void 0 ) delay = 0;\n\n return setTimeout(callback, delay);\n },\n now: function now() {\n return Date.now();\n },\n getTranslate: function getTranslate(el, axis) {\n if ( axis === void 0 ) axis = 'x';\n\n var matrix;\n var curTransform;\n var transformMatrix;\n\n var curStyle = win.getComputedStyle(el, null);\n\n if (win.WebKitCSSMatrix) {\n curTransform = curStyle.transform || curStyle.webkitTransform;\n if (curTransform.split(',').length > 6) {\n curTransform = curTransform.split(', ').map(function (a) { return a.replace(',', '.'); }).join(', ');\n }\n // Some old versions of Webkit choke when 'none' is passed; pass\n // empty string instead in this case\n transformMatrix = new win.WebKitCSSMatrix(curTransform === 'none' ? '' : curTransform);\n } else {\n transformMatrix = curStyle.MozTransform || curStyle.OTransform || curStyle.MsTransform || curStyle.msTransform || curStyle.transform || curStyle.getPropertyValue('transform').replace('translate(', 'matrix(1, 0, 0, 1,');\n matrix = transformMatrix.toString().split(',');\n }\n\n if (axis === 'x') {\n // Latest Chrome and webkits Fix\n if (win.WebKitCSSMatrix) { curTransform = transformMatrix.m41; }\n // Crazy IE10 Matrix\n else if (matrix.length === 16) { curTransform = parseFloat(matrix[12]); }\n // Normal Browsers\n else { curTransform = parseFloat(matrix[4]); }\n }\n if (axis === 'y') {\n // Latest Chrome and webkits Fix\n if (win.WebKitCSSMatrix) { curTransform = transformMatrix.m42; }\n // Crazy IE10 Matrix\n else if (matrix.length === 16) { curTransform = parseFloat(matrix[13]); }\n // Normal Browsers\n else { curTransform = parseFloat(matrix[5]); }\n }\n return curTransform || 0;\n },\n parseUrlQuery: function parseUrlQuery(url) {\n var query = {};\n var urlToParse = url || win.location.href;\n var i;\n var params;\n var param;\n var length;\n if (typeof urlToParse === 'string' && urlToParse.length) {\n urlToParse = urlToParse.indexOf('?') > -1 ? urlToParse.replace(/\\S*\\?/, '') : '';\n params = urlToParse.split('&').filter(function (paramsPart) { return paramsPart !== ''; });\n length = params.length;\n\n for (i = 0; i < length; i += 1) {\n param = params[i].replace(/#\\S+/g, '').split('=');\n query[decodeURIComponent(param[0])] = typeof param[1] === 'undefined' ? undefined : decodeURIComponent(param[1]) || '';\n }\n }\n return query;\n },\n isObject: function isObject(o) {\n return typeof o === 'object' && o !== null && o.constructor && o.constructor === Object;\n },\n extend: function extend() {\n var args = [], len$1 = arguments.length;\n while ( len$1-- ) args[ len$1 ] = arguments[ len$1 ];\n\n var to = Object(args[0]);\n for (var i = 1; i < args.length; i += 1) {\n var nextSource = args[i];\n if (nextSource !== undefined && nextSource !== null) {\n var keysArray = Object.keys(Object(nextSource));\n for (var nextIndex = 0, len = keysArray.length; nextIndex < len; nextIndex += 1) {\n var nextKey = keysArray[nextIndex];\n var desc = Object.getOwnPropertyDescriptor(nextSource, nextKey);\n if (desc !== undefined && desc.enumerable) {\n if (Utils.isObject(to[nextKey]) && Utils.isObject(nextSource[nextKey])) {\n Utils.extend(to[nextKey], nextSource[nextKey]);\n } else if (!Utils.isObject(to[nextKey]) && Utils.isObject(nextSource[nextKey])) {\n to[nextKey] = {};\n Utils.extend(to[nextKey], nextSource[nextKey]);\n } else {\n to[nextKey] = nextSource[nextKey];\n }\n }\n }\n }\n }\n return to;\n },\n };\n\n var Support = (function Support() {\n var testDiv = doc.createElement('div');\n return {\n touch: (win.Modernizr && win.Modernizr.touch === true) || (function checkTouch() {\n return !!((win.navigator.maxTouchPoints > 0) || ('ontouchstart' in win) || (win.DocumentTouch && doc instanceof win.DocumentTouch));\n }()),\n\n pointerEvents: !!(win.navigator.pointerEnabled || win.PointerEvent || ('maxTouchPoints' in win.navigator && win.navigator.maxTouchPoints > 0)),\n prefixedPointerEvents: !!win.navigator.msPointerEnabled,\n\n transition: (function checkTransition() {\n var style = testDiv.style;\n return ('transition' in style || 'webkitTransition' in style || 'MozTransition' in style);\n }()),\n transforms3d: (win.Modernizr && win.Modernizr.csstransforms3d === true) || (function checkTransforms3d() {\n var style = testDiv.style;\n return ('webkitPerspective' in style || 'MozPerspective' in style || 'OPerspective' in style || 'MsPerspective' in style || 'perspective' in style);\n }()),\n\n flexbox: (function checkFlexbox() {\n var style = testDiv.style;\n var styles = ('alignItems webkitAlignItems webkitBoxAlign msFlexAlign mozBoxAlign webkitFlexDirection msFlexDirection mozBoxDirection mozBoxOrient webkitBoxDirection webkitBoxOrient').split(' ');\n for (var i = 0; i < styles.length; i += 1) {\n if (styles[i] in style) { return true; }\n }\n return false;\n }()),\n\n observer: (function checkObserver() {\n return ('MutationObserver' in win || 'WebkitMutationObserver' in win);\n }()),\n\n passiveListener: (function checkPassiveListener() {\n var supportsPassive = false;\n try {\n var opts = Object.defineProperty({}, 'passive', {\n // eslint-disable-next-line\n get: function get() {\n supportsPassive = true;\n },\n });\n win.addEventListener('testPassiveListener', null, opts);\n } catch (e) {\n // No support\n }\n return supportsPassive;\n }()),\n\n gestures: (function checkGestures() {\n return 'ongesturestart' in win;\n }()),\n };\n }());\n\n var Browser = (function Browser() {\n function isSafari() {\n var ua = win.navigator.userAgent.toLowerCase();\n return (ua.indexOf('safari') >= 0 && ua.indexOf('chrome') < 0 && ua.indexOf('android') < 0);\n }\n return {\n isIE: !!win.navigator.userAgent.match(/Trident/g) || !!win.navigator.userAgent.match(/MSIE/g),\n isEdge: !!win.navigator.userAgent.match(/Edge/g),\n isSafari: isSafari(),\n isUiWebView: /(iPhone|iPod|iPad).*AppleWebKit(?!.*Safari)/i.test(win.navigator.userAgent),\n };\n }());\n\n var SwiperClass = function SwiperClass(params) {\n if ( params === void 0 ) params = {};\n\n var self = this;\n self.params = params;\n\n // Events\n self.eventsListeners = {};\n\n if (self.params && self.params.on) {\n Object.keys(self.params.on).forEach(function (eventName) {\n self.on(eventName, self.params.on[eventName]);\n });\n }\n };\n\n var staticAccessors = { components: { configurable: true } };\n\n SwiperClass.prototype.on = function on (events, handler, priority) {\n var self = this;\n if (typeof handler !== 'function') { return self; }\n var method = priority ? 'unshift' : 'push';\n events.split(' ').forEach(function (event) {\n if (!self.eventsListeners[event]) { self.eventsListeners[event] = []; }\n self.eventsListeners[event][method](handler);\n });\n return self;\n };\n\n SwiperClass.prototype.once = function once (events, handler, priority) {\n var self = this;\n if (typeof handler !== 'function') { return self; }\n function onceHandler() {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n handler.apply(self, args);\n self.off(events, onceHandler);\n if (onceHandler.f7proxy) {\n delete onceHandler.f7proxy;\n }\n }\n onceHandler.f7proxy = handler;\n return self.on(events, onceHandler, priority);\n };\n\n SwiperClass.prototype.off = function off (events, handler) {\n var self = this;\n if (!self.eventsListeners) { return self; }\n events.split(' ').forEach(function (event) {\n if (typeof handler === 'undefined') {\n self.eventsListeners[event] = [];\n } else if (self.eventsListeners[event] && self.eventsListeners[event].length) {\n self.eventsListeners[event].forEach(function (eventHandler, index) {\n if (eventHandler === handler || (eventHandler.f7proxy && eventHandler.f7proxy === handler)) {\n self.eventsListeners[event].splice(index, 1);\n }\n });\n }\n });\n return self;\n };\n\n SwiperClass.prototype.emit = function emit () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var self = this;\n if (!self.eventsListeners) { return self; }\n var events;\n var data;\n var context;\n if (typeof args[0] === 'string' || Array.isArray(args[0])) {\n events = args[0];\n data = args.slice(1, args.length);\n context = self;\n } else {\n events = args[0].events;\n data = args[0].data;\n context = args[0].context || self;\n }\n var eventsArray = Array.isArray(events) ? events : events.split(' ');\n eventsArray.forEach(function (event) {\n if (self.eventsListeners && self.eventsListeners[event]) {\n var handlers = [];\n self.eventsListeners[event].forEach(function (eventHandler) {\n handlers.push(eventHandler);\n });\n handlers.forEach(function (eventHandler) {\n eventHandler.apply(context, data);\n });\n }\n });\n return self;\n };\n\n SwiperClass.prototype.useModulesParams = function useModulesParams (instanceParams) {\n var instance = this;\n if (!instance.modules) { return; }\n Object.keys(instance.modules).forEach(function (moduleName) {\n var module = instance.modules[moduleName];\n // Extend params\n if (module.params) {\n Utils.extend(instanceParams, module.params);\n }\n });\n };\n\n SwiperClass.prototype.useModules = function useModules (modulesParams) {\n if ( modulesParams === void 0 ) modulesParams = {};\n\n var instance = this;\n if (!instance.modules) { return; }\n Object.keys(instance.modules).forEach(function (moduleName) {\n var module = instance.modules[moduleName];\n var moduleParams = modulesParams[moduleName] || {};\n // Extend instance methods and props\n if (module.instance) {\n Object.keys(module.instance).forEach(function (modulePropName) {\n var moduleProp = module.instance[modulePropName];\n if (typeof moduleProp === 'function') {\n instance[modulePropName] = moduleProp.bind(instance);\n } else {\n instance[modulePropName] = moduleProp;\n }\n });\n }\n // Add event listeners\n if (module.on && instance.on) {\n Object.keys(module.on).forEach(function (moduleEventName) {\n instance.on(moduleEventName, module.on[moduleEventName]);\n });\n }\n\n // Module create callback\n if (module.create) {\n module.create.bind(instance)(moduleParams);\n }\n });\n };\n\n staticAccessors.components.set = function (components) {\n var Class = this;\n if (!Class.use) { return; }\n Class.use(components);\n };\n\n SwiperClass.installModule = function installModule (module) {\n var params = [], len = arguments.length - 1;\n while ( len-- > 0 ) params[ len ] = arguments[ len + 1 ];\n\n var Class = this;\n if (!Class.prototype.modules) { Class.prototype.modules = {}; }\n var name = module.name || (((Object.keys(Class.prototype.modules).length) + \"_\" + (Utils.now())));\n Class.prototype.modules[name] = module;\n // Prototype\n if (module.proto) {\n Object.keys(module.proto).forEach(function (key) {\n Class.prototype[key] = module.proto[key];\n });\n }\n // Class\n if (module.static) {\n Object.keys(module.static).forEach(function (key) {\n Class[key] = module.static[key];\n });\n }\n // Callback\n if (module.install) {\n module.install.apply(Class, params);\n }\n return Class;\n };\n\n SwiperClass.use = function use (module) {\n var params = [], len = arguments.length - 1;\n while ( len-- > 0 ) params[ len ] = arguments[ len + 1 ];\n\n var Class = this;\n if (Array.isArray(module)) {\n module.forEach(function (m) { return Class.installModule(m); });\n return Class;\n }\n return Class.installModule.apply(Class, [ module ].concat( params ));\n };\n\n Object.defineProperties( SwiperClass, staticAccessors );\n\n function updateSize () {\n var swiper = this;\n var width;\n var height;\n var $el = swiper.$el;\n if (typeof swiper.params.width !== 'undefined') {\n width = swiper.params.width;\n } else {\n width = $el[0].clientWidth;\n }\n if (typeof swiper.params.height !== 'undefined') {\n height = swiper.params.height;\n } else {\n height = $el[0].clientHeight;\n }\n if ((width === 0 && swiper.isHorizontal()) || (height === 0 && swiper.isVertical())) {\n return;\n }\n\n // Subtract paddings\n width = width - parseInt($el.css('padding-left'), 10) - parseInt($el.css('padding-right'), 10);\n height = height - parseInt($el.css('padding-top'), 10) - parseInt($el.css('padding-bottom'), 10);\n\n Utils.extend(swiper, {\n width: width,\n height: height,\n size: swiper.isHorizontal() ? width : height,\n });\n }\n\n function updateSlides () {\n var swiper = this;\n var params = swiper.params;\n\n var $wrapperEl = swiper.$wrapperEl;\n var swiperSize = swiper.size;\n var rtl = swiper.rtlTranslate;\n var wrongRTL = swiper.wrongRTL;\n var isVirtual = swiper.virtual && params.virtual.enabled;\n var previousSlidesLength = isVirtual ? swiper.virtual.slides.length : swiper.slides.length;\n var slides = $wrapperEl.children((\".\" + (swiper.params.slideClass)));\n var slidesLength = isVirtual ? swiper.virtual.slides.length : slides.length;\n var snapGrid = [];\n var slidesGrid = [];\n var slidesSizesGrid = [];\n\n var offsetBefore = params.slidesOffsetBefore;\n if (typeof offsetBefore === 'function') {\n offsetBefore = params.slidesOffsetBefore.call(swiper);\n }\n\n var offsetAfter = params.slidesOffsetAfter;\n if (typeof offsetAfter === 'function') {\n offsetAfter = params.slidesOffsetAfter.call(swiper);\n }\n\n var previousSnapGridLength = swiper.snapGrid.length;\n var previousSlidesGridLength = swiper.snapGrid.length;\n\n var spaceBetween = params.spaceBetween;\n var slidePosition = -offsetBefore;\n var prevSlideSize = 0;\n var index = 0;\n if (typeof swiperSize === 'undefined') {\n return;\n }\n if (typeof spaceBetween === 'string' && spaceBetween.indexOf('%') >= 0) {\n spaceBetween = (parseFloat(spaceBetween.replace('%', '')) / 100) * swiperSize;\n }\n\n swiper.virtualSize = -spaceBetween;\n\n // reset margins\n if (rtl) { slides.css({ marginLeft: '', marginTop: '' }); }\n else { slides.css({ marginRight: '', marginBottom: '' }); }\n\n var slidesNumberEvenToRows;\n if (params.slidesPerColumn > 1) {\n if (Math.floor(slidesLength / params.slidesPerColumn) === slidesLength / swiper.params.slidesPerColumn) {\n slidesNumberEvenToRows = slidesLength;\n } else {\n slidesNumberEvenToRows = Math.ceil(slidesLength / params.slidesPerColumn) * params.slidesPerColumn;\n }\n if (params.slidesPerView !== 'auto' && params.slidesPerColumnFill === 'row') {\n slidesNumberEvenToRows = Math.max(slidesNumberEvenToRows, params.slidesPerView * params.slidesPerColumn);\n }\n }\n\n // Calc slides\n var slideSize;\n var slidesPerColumn = params.slidesPerColumn;\n var slidesPerRow = slidesNumberEvenToRows / slidesPerColumn;\n var numFullColumns = Math.floor(slidesLength / params.slidesPerColumn);\n for (var i = 0; i < slidesLength; i += 1) {\n slideSize = 0;\n var slide = slides.eq(i);\n if (params.slidesPerColumn > 1) {\n // Set slides order\n var newSlideOrderIndex = (void 0);\n var column = (void 0);\n var row = (void 0);\n if (\n (params.slidesPerColumnFill === 'column')\n || (params.slidesPerColumnFill === 'row' && params.slidesPerGroup > 1)\n ) {\n if (params.slidesPerColumnFill === 'column') {\n column = Math.floor(i / slidesPerColumn);\n row = i - (column * slidesPerColumn);\n if (column > numFullColumns || (column === numFullColumns && row === slidesPerColumn - 1)) {\n row += 1;\n if (row >= slidesPerColumn) {\n row = 0;\n column += 1;\n }\n }\n } else {\n var groupIndex = Math.floor(i / params.slidesPerGroup);\n row = Math.floor(i / params.slidesPerView) - groupIndex * params.slidesPerColumn;\n column = i - row * params.slidesPerView - groupIndex * params.slidesPerView;\n }\n newSlideOrderIndex = column + ((row * slidesNumberEvenToRows) / slidesPerColumn);\n slide\n .css({\n '-webkit-box-ordinal-group': newSlideOrderIndex,\n '-moz-box-ordinal-group': newSlideOrderIndex,\n '-ms-flex-order': newSlideOrderIndex,\n '-webkit-order': newSlideOrderIndex,\n order: newSlideOrderIndex,\n });\n } else {\n row = Math.floor(i / slidesPerRow);\n column = i - (row * slidesPerRow);\n }\n slide\n .css(\n (\"margin-\" + (swiper.isHorizontal() ? 'top' : 'left')),\n (row !== 0 && params.spaceBetween) && (((params.spaceBetween) + \"px\"))\n )\n .attr('data-swiper-column', column)\n .attr('data-swiper-row', row);\n }\n if (slide.css('display') === 'none') { continue; } // eslint-disable-line\n\n if (params.slidesPerView === 'auto') {\n var slideStyles = win.getComputedStyle(slide[0], null);\n var currentTransform = slide[0].style.transform;\n var currentWebKitTransform = slide[0].style.webkitTransform;\n if (currentTransform) {\n slide[0].style.transform = 'none';\n }\n if (currentWebKitTransform) {\n slide[0].style.webkitTransform = 'none';\n }\n if (params.roundLengths) {\n slideSize = swiper.isHorizontal()\n ? slide.outerWidth(true)\n : slide.outerHeight(true);\n } else {\n // eslint-disable-next-line\n if (swiper.isHorizontal()) {\n var width = parseFloat(slideStyles.getPropertyValue('width'));\n var paddingLeft = parseFloat(slideStyles.getPropertyValue('padding-left'));\n var paddingRight = parseFloat(slideStyles.getPropertyValue('padding-right'));\n var marginLeft = parseFloat(slideStyles.getPropertyValue('margin-left'));\n var marginRight = parseFloat(slideStyles.getPropertyValue('margin-right'));\n var boxSizing = slideStyles.getPropertyValue('box-sizing');\n if (boxSizing && boxSizing === 'border-box' && !Browser.isIE) {\n slideSize = width + marginLeft + marginRight;\n } else {\n slideSize = width + paddingLeft + paddingRight + marginLeft + marginRight;\n }\n } else {\n var height = parseFloat(slideStyles.getPropertyValue('height'));\n var paddingTop = parseFloat(slideStyles.getPropertyValue('padding-top'));\n var paddingBottom = parseFloat(slideStyles.getPropertyValue('padding-bottom'));\n var marginTop = parseFloat(slideStyles.getPropertyValue('margin-top'));\n var marginBottom = parseFloat(slideStyles.getPropertyValue('margin-bottom'));\n var boxSizing$1 = slideStyles.getPropertyValue('box-sizing');\n if (boxSizing$1 && boxSizing$1 === 'border-box' && !Browser.isIE) {\n slideSize = height + marginTop + marginBottom;\n } else {\n slideSize = height + paddingTop + paddingBottom + marginTop + marginBottom;\n }\n }\n }\n if (currentTransform) {\n slide[0].style.transform = currentTransform;\n }\n if (currentWebKitTransform) {\n slide[0].style.webkitTransform = currentWebKitTransform;\n }\n if (params.roundLengths) { slideSize = Math.floor(slideSize); }\n } else {\n slideSize = (swiperSize - ((params.slidesPerView - 1) * spaceBetween)) / params.slidesPerView;\n if (params.roundLengths) { slideSize = Math.floor(slideSize); }\n\n if (slides[i]) {\n if (swiper.isHorizontal()) {\n slides[i].style.width = slideSize + \"px\";\n } else {\n slides[i].style.height = slideSize + \"px\";\n }\n }\n }\n if (slides[i]) {\n slides[i].swiperSlideSize = slideSize;\n }\n slidesSizesGrid.push(slideSize);\n\n\n if (params.centeredSlides) {\n slidePosition = slidePosition + (slideSize / 2) + (prevSlideSize / 2) + spaceBetween;\n if (prevSlideSize === 0 && i !== 0) { slidePosition = slidePosition - (swiperSize / 2) - spaceBetween; }\n if (i === 0) { slidePosition = slidePosition - (swiperSize / 2) - spaceBetween; }\n if (Math.abs(slidePosition) < 1 / 1000) { slidePosition = 0; }\n if (params.roundLengths) { slidePosition = Math.floor(slidePosition); }\n if ((index) % params.slidesPerGroup === 0) { snapGrid.push(slidePosition); }\n slidesGrid.push(slidePosition);\n } else {\n if (params.roundLengths) { slidePosition = Math.floor(slidePosition); }\n if ((index) % params.slidesPerGroup === 0) { snapGrid.push(slidePosition); }\n slidesGrid.push(slidePosition);\n slidePosition = slidePosition + slideSize + spaceBetween;\n }\n\n swiper.virtualSize += slideSize + spaceBetween;\n\n prevSlideSize = slideSize;\n\n index += 1;\n }\n swiper.virtualSize = Math.max(swiper.virtualSize, swiperSize) + offsetAfter;\n var newSlidesGrid;\n\n if (\n rtl && wrongRTL && (params.effect === 'slide' || params.effect === 'coverflow')) {\n $wrapperEl.css({ width: ((swiper.virtualSize + params.spaceBetween) + \"px\") });\n }\n if (!Support.flexbox || params.setWrapperSize) {\n if (swiper.isHorizontal()) { $wrapperEl.css({ width: ((swiper.virtualSize + params.spaceBetween) + \"px\") }); }\n else { $wrapperEl.css({ height: ((swiper.virtualSize + params.spaceBetween) + \"px\") }); }\n }\n\n if (params.slidesPerColumn > 1) {\n swiper.virtualSize = (slideSize + params.spaceBetween) * slidesNumberEvenToRows;\n swiper.virtualSize = Math.ceil(swiper.virtualSize / params.slidesPerColumn) - params.spaceBetween;\n if (swiper.isHorizontal()) { $wrapperEl.css({ width: ((swiper.virtualSize + params.spaceBetween) + \"px\") }); }\n else { $wrapperEl.css({ height: ((swiper.virtualSize + params.spaceBetween) + \"px\") }); }\n if (params.centeredSlides) {\n newSlidesGrid = [];\n for (var i$1 = 0; i$1 < snapGrid.length; i$1 += 1) {\n var slidesGridItem = snapGrid[i$1];\n if (params.roundLengths) { slidesGridItem = Math.floor(slidesGridItem); }\n if (snapGrid[i$1] < swiper.virtualSize + snapGrid[0]) { newSlidesGrid.push(slidesGridItem); }\n }\n snapGrid = newSlidesGrid;\n }\n }\n\n // Remove last grid elements depending on width\n if (!params.centeredSlides) {\n newSlidesGrid = [];\n for (var i$2 = 0; i$2 < snapGrid.length; i$2 += 1) {\n var slidesGridItem$1 = snapGrid[i$2];\n if (params.roundLengths) { slidesGridItem$1 = Math.floor(slidesGridItem$1); }\n if (snapGrid[i$2] <= swiper.virtualSize - swiperSize) {\n newSlidesGrid.push(slidesGridItem$1);\n }\n }\n snapGrid = newSlidesGrid;\n if (Math.floor(swiper.virtualSize - swiperSize) - Math.floor(snapGrid[snapGrid.length - 1]) > 1) {\n snapGrid.push(swiper.virtualSize - swiperSize);\n }\n }\n if (snapGrid.length === 0) { snapGrid = [0]; }\n\n if (params.spaceBetween !== 0) {\n if (swiper.isHorizontal()) {\n if (rtl) { slides.css({ marginLeft: (spaceBetween + \"px\") }); }\n else { slides.css({ marginRight: (spaceBetween + \"px\") }); }\n } else { slides.css({ marginBottom: (spaceBetween + \"px\") }); }\n }\n\n if (params.centerInsufficientSlides) {\n var allSlidesSize = 0;\n slidesSizesGrid.forEach(function (slideSizeValue) {\n allSlidesSize += slideSizeValue + (params.spaceBetween ? params.spaceBetween : 0);\n });\n allSlidesSize -= params.spaceBetween;\n if (allSlidesSize < swiperSize) {\n var allSlidesOffset = (swiperSize - allSlidesSize) / 2;\n snapGrid.forEach(function (snap, snapIndex) {\n snapGrid[snapIndex] = snap - allSlidesOffset;\n });\n slidesGrid.forEach(function (snap, snapIndex) {\n slidesGrid[snapIndex] = snap + allSlidesOffset;\n });\n }\n }\n\n Utils.extend(swiper, {\n slides: slides,\n snapGrid: snapGrid,\n slidesGrid: slidesGrid,\n slidesSizesGrid: slidesSizesGrid,\n });\n\n if (slidesLength !== previousSlidesLength) {\n swiper.emit('slidesLengthChange');\n }\n if (snapGrid.length !== previousSnapGridLength) {\n if (swiper.params.watchOverflow) { swiper.checkOverflow(); }\n swiper.emit('snapGridLengthChange');\n }\n if (slidesGrid.length !== previousSlidesGridLength) {\n swiper.emit('slidesGridLengthChange');\n }\n\n if (params.watchSlidesProgress || params.watchSlidesVisibility) {\n swiper.updateSlidesOffset();\n }\n }\n\n function updateAutoHeight (speed) {\n var swiper = this;\n var activeSlides = [];\n var newHeight = 0;\n var i;\n if (typeof speed === 'number') {\n swiper.setTransition(speed);\n } else if (speed === true) {\n swiper.setTransition(swiper.params.speed);\n }\n // Find slides currently in view\n if (swiper.params.slidesPerView !== 'auto' && swiper.params.slidesPerView > 1) {\n for (i = 0; i < Math.ceil(swiper.params.slidesPerView); i += 1) {\n var index = swiper.activeIndex + i;\n if (index > swiper.slides.length) { break; }\n activeSlides.push(swiper.slides.eq(index)[0]);\n }\n } else {\n activeSlides.push(swiper.slides.eq(swiper.activeIndex)[0]);\n }\n\n // Find new height from highest slide in view\n for (i = 0; i < activeSlides.length; i += 1) {\n if (typeof activeSlides[i] !== 'undefined') {\n var height = activeSlides[i].offsetHeight;\n newHeight = height > newHeight ? height : newHeight;\n }\n }\n\n // Update Height\n if (newHeight) { swiper.$wrapperEl.css('height', (newHeight + \"px\")); }\n }\n\n function updateSlidesOffset () {\n var swiper = this;\n var slides = swiper.slides;\n for (var i = 0; i < slides.length; i += 1) {\n slides[i].swiperSlideOffset = swiper.isHorizontal() ? slides[i].offsetLeft : slides[i].offsetTop;\n }\n }\n\n function updateSlidesProgress (translate) {\n if ( translate === void 0 ) translate = (this && this.translate) || 0;\n\n var swiper = this;\n var params = swiper.params;\n\n var slides = swiper.slides;\n var rtl = swiper.rtlTranslate;\n\n if (slides.length === 0) { return; }\n if (typeof slides[0].swiperSlideOffset === 'undefined') { swiper.updateSlidesOffset(); }\n\n var offsetCenter = -translate;\n if (rtl) { offsetCenter = translate; }\n\n // Visible Slides\n slides.removeClass(params.slideVisibleClass);\n\n swiper.visibleSlidesIndexes = [];\n swiper.visibleSlides = [];\n\n for (var i = 0; i < slides.length; i += 1) {\n var slide = slides[i];\n var slideProgress = (\n (offsetCenter + (params.centeredSlides ? swiper.minTranslate() : 0)) - slide.swiperSlideOffset\n ) / (slide.swiperSlideSize + params.spaceBetween);\n if (params.watchSlidesVisibility) {\n var slideBefore = -(offsetCenter - slide.swiperSlideOffset);\n var slideAfter = slideBefore + swiper.slidesSizesGrid[i];\n var isVisible = (slideBefore >= 0 && slideBefore < swiper.size - 1)\n || (slideAfter > 1 && slideAfter <= swiper.size)\n || (slideBefore <= 0 && slideAfter >= swiper.size);\n if (isVisible) {\n swiper.visibleSlides.push(slide);\n swiper.visibleSlidesIndexes.push(i);\n slides.eq(i).addClass(params.slideVisibleClass);\n }\n }\n slide.progress = rtl ? -slideProgress : slideProgress;\n }\n swiper.visibleSlides = $(swiper.visibleSlides);\n }\n\n function updateProgress (translate) {\n if ( translate === void 0 ) translate = (this && this.translate) || 0;\n\n var swiper = this;\n var params = swiper.params;\n\n var translatesDiff = swiper.maxTranslate() - swiper.minTranslate();\n var progress = swiper.progress;\n var isBeginning = swiper.isBeginning;\n var isEnd = swiper.isEnd;\n var wasBeginning = isBeginning;\n var wasEnd = isEnd;\n if (translatesDiff === 0) {\n progress = 0;\n isBeginning = true;\n isEnd = true;\n } else {\n progress = (translate - swiper.minTranslate()) / (translatesDiff);\n isBeginning = progress <= 0;\n isEnd = progress >= 1;\n }\n Utils.extend(swiper, {\n progress: progress,\n isBeginning: isBeginning,\n isEnd: isEnd,\n });\n\n if (params.watchSlidesProgress || params.watchSlidesVisibility) { swiper.updateSlidesProgress(translate); }\n\n if (isBeginning && !wasBeginning) {\n swiper.emit('reachBeginning toEdge');\n }\n if (isEnd && !wasEnd) {\n swiper.emit('reachEnd toEdge');\n }\n if ((wasBeginning && !isBeginning) || (wasEnd && !isEnd)) {\n swiper.emit('fromEdge');\n }\n\n swiper.emit('progress', progress);\n }\n\n function updateSlidesClasses () {\n var swiper = this;\n\n var slides = swiper.slides;\n var params = swiper.params;\n var $wrapperEl = swiper.$wrapperEl;\n var activeIndex = swiper.activeIndex;\n var realIndex = swiper.realIndex;\n var isVirtual = swiper.virtual && params.virtual.enabled;\n\n slides.removeClass(((params.slideActiveClass) + \" \" + (params.slideNextClass) + \" \" + (params.slidePrevClass) + \" \" + (params.slideDuplicateActiveClass) + \" \" + (params.slideDuplicateNextClass) + \" \" + (params.slideDuplicatePrevClass)));\n\n var activeSlide;\n if (isVirtual) {\n activeSlide = swiper.$wrapperEl.find((\".\" + (params.slideClass) + \"[data-swiper-slide-index=\\\"\" + activeIndex + \"\\\"]\"));\n } else {\n activeSlide = slides.eq(activeIndex);\n }\n\n // Active classes\n activeSlide.addClass(params.slideActiveClass);\n\n if (params.loop) {\n // Duplicate to all looped slides\n if (activeSlide.hasClass(params.slideDuplicateClass)) {\n $wrapperEl\n .children((\".\" + (params.slideClass) + \":not(.\" + (params.slideDuplicateClass) + \")[data-swiper-slide-index=\\\"\" + realIndex + \"\\\"]\"))\n .addClass(params.slideDuplicateActiveClass);\n } else {\n $wrapperEl\n .children((\".\" + (params.slideClass) + \".\" + (params.slideDuplicateClass) + \"[data-swiper-slide-index=\\\"\" + realIndex + \"\\\"]\"))\n .addClass(params.slideDuplicateActiveClass);\n }\n }\n // Next Slide\n var nextSlide = activeSlide.nextAll((\".\" + (params.slideClass))).eq(0).addClass(params.slideNextClass);\n if (params.loop && nextSlide.length === 0) {\n nextSlide = slides.eq(0);\n nextSlide.addClass(params.slideNextClass);\n }\n // Prev Slide\n var prevSlide = activeSlide.prevAll((\".\" + (params.slideClass))).eq(0).addClass(params.slidePrevClass);\n if (params.loop && prevSlide.length === 0) {\n prevSlide = slides.eq(-1);\n prevSlide.addClass(params.slidePrevClass);\n }\n if (params.loop) {\n // Duplicate to all looped slides\n if (nextSlide.hasClass(params.slideDuplicateClass)) {\n $wrapperEl\n .children((\".\" + (params.slideClass) + \":not(.\" + (params.slideDuplicateClass) + \")[data-swiper-slide-index=\\\"\" + (nextSlide.attr('data-swiper-slide-index')) + \"\\\"]\"))\n .addClass(params.slideDuplicateNextClass);\n } else {\n $wrapperEl\n .children((\".\" + (params.slideClass) + \".\" + (params.slideDuplicateClass) + \"[data-swiper-slide-index=\\\"\" + (nextSlide.attr('data-swiper-slide-index')) + \"\\\"]\"))\n .addClass(params.slideDuplicateNextClass);\n }\n if (prevSlide.hasClass(params.slideDuplicateClass)) {\n $wrapperEl\n .children((\".\" + (params.slideClass) + \":not(.\" + (params.slideDuplicateClass) + \")[data-swiper-slide-index=\\\"\" + (prevSlide.attr('data-swiper-slide-index')) + \"\\\"]\"))\n .addClass(params.slideDuplicatePrevClass);\n } else {\n $wrapperEl\n .children((\".\" + (params.slideClass) + \".\" + (params.slideDuplicateClass) + \"[data-swiper-slide-index=\\\"\" + (prevSlide.attr('data-swiper-slide-index')) + \"\\\"]\"))\n .addClass(params.slideDuplicatePrevClass);\n }\n }\n }\n\n function updateActiveIndex (newActiveIndex) {\n var swiper = this;\n var translate = swiper.rtlTranslate ? swiper.translate : -swiper.translate;\n var slidesGrid = swiper.slidesGrid;\n var snapGrid = swiper.snapGrid;\n var params = swiper.params;\n var previousIndex = swiper.activeIndex;\n var previousRealIndex = swiper.realIndex;\n var previousSnapIndex = swiper.snapIndex;\n var activeIndex = newActiveIndex;\n var snapIndex;\n if (typeof activeIndex === 'undefined') {\n for (var i = 0; i < slidesGrid.length; i += 1) {\n if (typeof slidesGrid[i + 1] !== 'undefined') {\n if (translate >= slidesGrid[i] && translate < slidesGrid[i + 1] - ((slidesGrid[i + 1] - slidesGrid[i]) / 2)) {\n activeIndex = i;\n } else if (translate >= slidesGrid[i] && translate < slidesGrid[i + 1]) {\n activeIndex = i + 1;\n }\n } else if (translate >= slidesGrid[i]) {\n activeIndex = i;\n }\n }\n // Normalize slideIndex\n if (params.normalizeSlideIndex) {\n if (activeIndex < 0 || typeof activeIndex === 'undefined') { activeIndex = 0; }\n }\n }\n if (snapGrid.indexOf(translate) >= 0) {\n snapIndex = snapGrid.indexOf(translate);\n } else {\n snapIndex = Math.floor(activeIndex / params.slidesPerGroup);\n }\n if (snapIndex >= snapGrid.length) { snapIndex = snapGrid.length - 1; }\n if (activeIndex === previousIndex) {\n if (snapIndex !== previousSnapIndex) {\n swiper.snapIndex = snapIndex;\n swiper.emit('snapIndexChange');\n }\n return;\n }\n\n // Get real index\n var realIndex = parseInt(swiper.slides.eq(activeIndex).attr('data-swiper-slide-index') || activeIndex, 10);\n\n Utils.extend(swiper, {\n snapIndex: snapIndex,\n realIndex: realIndex,\n previousIndex: previousIndex,\n activeIndex: activeIndex,\n });\n swiper.emit('activeIndexChange');\n swiper.emit('snapIndexChange');\n if (previousRealIndex !== realIndex) {\n swiper.emit('realIndexChange');\n }\n if (swiper.initialized || swiper.runCallbacksOnInit) {\n swiper.emit('slideChange');\n }\n }\n\n function updateClickedSlide (e) {\n var swiper = this;\n var params = swiper.params;\n var slide = $(e.target).closest((\".\" + (params.slideClass)))[0];\n var slideFound = false;\n if (slide) {\n for (var i = 0; i < swiper.slides.length; i += 1) {\n if (swiper.slides[i] === slide) { slideFound = true; }\n }\n }\n\n if (slide && slideFound) {\n swiper.clickedSlide = slide;\n if (swiper.virtual && swiper.params.virtual.enabled) {\n swiper.clickedIndex = parseInt($(slide).attr('data-swiper-slide-index'), 10);\n } else {\n swiper.clickedIndex = $(slide).index();\n }\n } else {\n swiper.clickedSlide = undefined;\n swiper.clickedIndex = undefined;\n return;\n }\n if (params.slideToClickedSlide && swiper.clickedIndex !== undefined && swiper.clickedIndex !== swiper.activeIndex) {\n swiper.slideToClickedSlide();\n }\n }\n\n var update = {\n updateSize: updateSize,\n updateSlides: updateSlides,\n updateAutoHeight: updateAutoHeight,\n updateSlidesOffset: updateSlidesOffset,\n updateSlidesProgress: updateSlidesProgress,\n updateProgress: updateProgress,\n updateSlidesClasses: updateSlidesClasses,\n updateActiveIndex: updateActiveIndex,\n updateClickedSlide: updateClickedSlide,\n };\n\n function getTranslate (axis) {\n if ( axis === void 0 ) axis = this.isHorizontal() ? 'x' : 'y';\n\n var swiper = this;\n\n var params = swiper.params;\n var rtl = swiper.rtlTranslate;\n var translate = swiper.translate;\n var $wrapperEl = swiper.$wrapperEl;\n\n if (params.virtualTranslate) {\n return rtl ? -translate : translate;\n }\n\n var currentTranslate = Utils.getTranslate($wrapperEl[0], axis);\n if (rtl) { currentTranslate = -currentTranslate; }\n\n return currentTranslate || 0;\n }\n\n function setTranslate (translate, byController) {\n var swiper = this;\n var rtl = swiper.rtlTranslate;\n var params = swiper.params;\n var $wrapperEl = swiper.$wrapperEl;\n var progress = swiper.progress;\n var x = 0;\n var y = 0;\n var z = 0;\n\n if (swiper.isHorizontal()) {\n x = rtl ? -translate : translate;\n } else {\n y = translate;\n }\n\n if (params.roundLengths) {\n x = Math.floor(x);\n y = Math.floor(y);\n }\n\n if (!params.virtualTranslate) {\n if (Support.transforms3d) { $wrapperEl.transform((\"translate3d(\" + x + \"px, \" + y + \"px, \" + z + \"px)\")); }\n else { $wrapperEl.transform((\"translate(\" + x + \"px, \" + y + \"px)\")); }\n }\n swiper.previousTranslate = swiper.translate;\n swiper.translate = swiper.isHorizontal() ? x : y;\n\n // Check if we need to update progress\n var newProgress;\n var translatesDiff = swiper.maxTranslate() - swiper.minTranslate();\n if (translatesDiff === 0) {\n newProgress = 0;\n } else {\n newProgress = (translate - swiper.minTranslate()) / (translatesDiff);\n }\n if (newProgress !== progress) {\n swiper.updateProgress(translate);\n }\n\n swiper.emit('setTranslate', swiper.translate, byController);\n }\n\n function minTranslate () {\n return (-this.snapGrid[0]);\n }\n\n function maxTranslate () {\n return (-this.snapGrid[this.snapGrid.length - 1]);\n }\n\n var translate = {\n getTranslate: getTranslate,\n setTranslate: setTranslate,\n minTranslate: minTranslate,\n maxTranslate: maxTranslate,\n };\n\n function setTransition (duration, byController) {\n var swiper = this;\n\n swiper.$wrapperEl.transition(duration);\n\n swiper.emit('setTransition', duration, byController);\n }\n\n function transitionStart (runCallbacks, direction) {\n if ( runCallbacks === void 0 ) runCallbacks = true;\n\n var swiper = this;\n var activeIndex = swiper.activeIndex;\n var params = swiper.params;\n var previousIndex = swiper.previousIndex;\n if (params.autoHeight) {\n swiper.updateAutoHeight();\n }\n\n var dir = direction;\n if (!dir) {\n if (activeIndex > previousIndex) { dir = 'next'; }\n else if (activeIndex < previousIndex) { dir = 'prev'; }\n else { dir = 'reset'; }\n }\n\n swiper.emit('transitionStart');\n\n if (runCallbacks && activeIndex !== previousIndex) {\n if (dir === 'reset') {\n swiper.emit('slideResetTransitionStart');\n return;\n }\n swiper.emit('slideChangeTransitionStart');\n if (dir === 'next') {\n swiper.emit('slideNextTransitionStart');\n } else {\n swiper.emit('slidePrevTransitionStart');\n }\n }\n }\n\n function transitionEnd$1 (runCallbacks, direction) {\n if ( runCallbacks === void 0 ) runCallbacks = true;\n\n var swiper = this;\n var activeIndex = swiper.activeIndex;\n var previousIndex = swiper.previousIndex;\n swiper.animating = false;\n swiper.setTransition(0);\n\n var dir = direction;\n if (!dir) {\n if (activeIndex > previousIndex) { dir = 'next'; }\n else if (activeIndex < previousIndex) { dir = 'prev'; }\n else { dir = 'reset'; }\n }\n\n swiper.emit('transitionEnd');\n\n if (runCallbacks && activeIndex !== previousIndex) {\n if (dir === 'reset') {\n swiper.emit('slideResetTransitionEnd');\n return;\n }\n swiper.emit('slideChangeTransitionEnd');\n if (dir === 'next') {\n swiper.emit('slideNextTransitionEnd');\n } else {\n swiper.emit('slidePrevTransitionEnd');\n }\n }\n }\n\n var transition$1 = {\n setTransition: setTransition,\n transitionStart: transitionStart,\n transitionEnd: transitionEnd$1,\n };\n\n function slideTo (index, speed, runCallbacks, internal) {\n if ( index === void 0 ) index = 0;\n if ( speed === void 0 ) speed = this.params.speed;\n if ( runCallbacks === void 0 ) runCallbacks = true;\n\n var swiper = this;\n var slideIndex = index;\n if (slideIndex < 0) { slideIndex = 0; }\n\n var params = swiper.params;\n var snapGrid = swiper.snapGrid;\n var slidesGrid = swiper.slidesGrid;\n var previousIndex = swiper.previousIndex;\n var activeIndex = swiper.activeIndex;\n var rtl = swiper.rtlTranslate;\n if (swiper.animating && params.preventInteractionOnTransition) {\n return false;\n }\n\n var snapIndex = Math.floor(slideIndex / params.slidesPerGroup);\n if (snapIndex >= snapGrid.length) { snapIndex = snapGrid.length - 1; }\n\n if ((activeIndex || params.initialSlide || 0) === (previousIndex || 0) && runCallbacks) {\n swiper.emit('beforeSlideChangeStart');\n }\n\n var translate = -snapGrid[snapIndex];\n\n // Update progress\n swiper.updateProgress(translate);\n\n // Normalize slideIndex\n if (params.normalizeSlideIndex) {\n for (var i = 0; i < slidesGrid.length; i += 1) {\n if (-Math.floor(translate * 100) >= Math.floor(slidesGrid[i] * 100)) {\n slideIndex = i;\n }\n }\n }\n // Directions locks\n if (swiper.initialized && slideIndex !== activeIndex) {\n if (!swiper.allowSlideNext && translate < swiper.translate && translate < swiper.minTranslate()) {\n return false;\n }\n if (!swiper.allowSlidePrev && translate > swiper.translate && translate > swiper.maxTranslate()) {\n if ((activeIndex || 0) !== slideIndex) { return false; }\n }\n }\n\n var direction;\n if (slideIndex > activeIndex) { direction = 'next'; }\n else if (slideIndex < activeIndex) { direction = 'prev'; }\n else { direction = 'reset'; }\n\n\n // Update Index\n if ((rtl && -translate === swiper.translate) || (!rtl && translate === swiper.translate)) {\n swiper.updateActiveIndex(slideIndex);\n // Update Height\n if (params.autoHeight) {\n swiper.updateAutoHeight();\n }\n swiper.updateSlidesClasses();\n if (params.effect !== 'slide') {\n swiper.setTranslate(translate);\n }\n if (direction !== 'reset') {\n swiper.transitionStart(runCallbacks, direction);\n swiper.transitionEnd(runCallbacks, direction);\n }\n return false;\n }\n\n if (speed === 0 || !Support.transition) {\n swiper.setTransition(0);\n swiper.setTranslate(translate);\n swiper.updateActiveIndex(slideIndex);\n swiper.updateSlidesClasses();\n swiper.emit('beforeTransitionStart', speed, internal);\n swiper.transitionStart(runCallbacks, direction);\n swiper.transitionEnd(runCallbacks, direction);\n } else {\n swiper.setTransition(speed);\n swiper.setTranslate(translate);\n swiper.updateActiveIndex(slideIndex);\n swiper.updateSlidesClasses();\n swiper.emit('beforeTransitionStart', speed, internal);\n swiper.transitionStart(runCallbacks, direction);\n if (!swiper.animating) {\n swiper.animating = true;\n if (!swiper.onSlideToWrapperTransitionEnd) {\n swiper.onSlideToWrapperTransitionEnd = function transitionEnd(e) {\n if (!swiper || swiper.destroyed) { return; }\n if (e.target !== this) { return; }\n swiper.$wrapperEl[0].removeEventListener('transitionend', swiper.onSlideToWrapperTransitionEnd);\n swiper.$wrapperEl[0].removeEventListener('webkitTransitionEnd', swiper.onSlideToWrapperTransitionEnd);\n swiper.onSlideToWrapperTransitionEnd = null;\n delete swiper.onSlideToWrapperTransitionEnd;\n swiper.transitionEnd(runCallbacks, direction);\n };\n }\n swiper.$wrapperEl[0].addEventListener('transitionend', swiper.onSlideToWrapperTransitionEnd);\n swiper.$wrapperEl[0].addEventListener('webkitTransitionEnd', swiper.onSlideToWrapperTransitionEnd);\n }\n }\n\n return true;\n }\n\n function slideToLoop (index, speed, runCallbacks, internal) {\n if ( index === void 0 ) index = 0;\n if ( speed === void 0 ) speed = this.params.speed;\n if ( runCallbacks === void 0 ) runCallbacks = true;\n\n var swiper = this;\n var newIndex = index;\n if (swiper.params.loop) {\n newIndex += swiper.loopedSlides;\n }\n\n return swiper.slideTo(newIndex, speed, runCallbacks, internal);\n }\n\n /* eslint no-unused-vars: \"off\" */\n function slideNext (speed, runCallbacks, internal) {\n if ( speed === void 0 ) speed = this.params.speed;\n if ( runCallbacks === void 0 ) runCallbacks = true;\n\n var swiper = this;\n var params = swiper.params;\n var animating = swiper.animating;\n if (params.loop) {\n if (animating) { return false; }\n swiper.loopFix();\n // eslint-disable-next-line\n swiper._clientLeft = swiper.$wrapperEl[0].clientLeft;\n return swiper.slideTo(swiper.activeIndex + params.slidesPerGroup, speed, runCallbacks, internal);\n }\n return swiper.slideTo(swiper.activeIndex + params.slidesPerGroup, speed, runCallbacks, internal);\n }\n\n /* eslint no-unused-vars: \"off\" */\n function slidePrev (speed, runCallbacks, internal) {\n if ( speed === void 0 ) speed = this.params.speed;\n if ( runCallbacks === void 0 ) runCallbacks = true;\n\n var swiper = this;\n var params = swiper.params;\n var animating = swiper.animating;\n var snapGrid = swiper.snapGrid;\n var slidesGrid = swiper.slidesGrid;\n var rtlTranslate = swiper.rtlTranslate;\n\n if (params.loop) {\n if (animating) { return false; }\n swiper.loopFix();\n // eslint-disable-next-line\n swiper._clientLeft = swiper.$wrapperEl[0].clientLeft;\n }\n var translate = rtlTranslate ? swiper.translate : -swiper.translate;\n function normalize(val) {\n if (val < 0) { return -Math.floor(Math.abs(val)); }\n return Math.floor(val);\n }\n var normalizedTranslate = normalize(translate);\n var normalizedSnapGrid = snapGrid.map(function (val) { return normalize(val); });\n var normalizedSlidesGrid = slidesGrid.map(function (val) { return normalize(val); });\n\n var currentSnap = snapGrid[normalizedSnapGrid.indexOf(normalizedTranslate)];\n var prevSnap = snapGrid[normalizedSnapGrid.indexOf(normalizedTranslate) - 1];\n var prevIndex;\n if (typeof prevSnap !== 'undefined') {\n prevIndex = slidesGrid.indexOf(prevSnap);\n if (prevIndex < 0) { prevIndex = swiper.activeIndex - 1; }\n }\n return swiper.slideTo(prevIndex, speed, runCallbacks, internal);\n }\n\n /* eslint no-unused-vars: \"off\" */\n function slideReset (speed, runCallbacks, internal) {\n if ( speed === void 0 ) speed = this.params.speed;\n if ( runCallbacks === void 0 ) runCallbacks = true;\n\n var swiper = this;\n return swiper.slideTo(swiper.activeIndex, speed, runCallbacks, internal);\n }\n\n /* eslint no-unused-vars: \"off\" */\n function slideToClosest (speed, runCallbacks, internal) {\n if ( speed === void 0 ) speed = this.params.speed;\n if ( runCallbacks === void 0 ) runCallbacks = true;\n\n var swiper = this;\n var index = swiper.activeIndex;\n var snapIndex = Math.floor(index / swiper.params.slidesPerGroup);\n\n if (snapIndex < swiper.snapGrid.length - 1) {\n var translate = swiper.rtlTranslate ? swiper.translate : -swiper.translate;\n\n var currentSnap = swiper.snapGrid[snapIndex];\n var nextSnap = swiper.snapGrid[snapIndex + 1];\n\n if ((translate - currentSnap) > (nextSnap - currentSnap) / 2) {\n index = swiper.params.slidesPerGroup;\n }\n }\n\n return swiper.slideTo(index, speed, runCallbacks, internal);\n }\n\n function slideToClickedSlide () {\n var swiper = this;\n var params = swiper.params;\n var $wrapperEl = swiper.$wrapperEl;\n\n var slidesPerView = params.slidesPerView === 'auto' ? swiper.slidesPerViewDynamic() : params.slidesPerView;\n var slideToIndex = swiper.clickedIndex;\n var realIndex;\n if (params.loop) {\n if (swiper.animating) { return; }\n realIndex = parseInt($(swiper.clickedSlide).attr('data-swiper-slide-index'), 10);\n if (params.centeredSlides) {\n if (\n (slideToIndex < swiper.loopedSlides - (slidesPerView / 2))\n || (slideToIndex > (swiper.slides.length - swiper.loopedSlides) + (slidesPerView / 2))\n ) {\n swiper.loopFix();\n slideToIndex = $wrapperEl\n .children((\".\" + (params.slideClass) + \"[data-swiper-slide-index=\\\"\" + realIndex + \"\\\"]:not(.\" + (params.slideDuplicateClass) + \")\"))\n .eq(0)\n .index();\n\n Utils.nextTick(function () {\n swiper.slideTo(slideToIndex);\n });\n } else {\n swiper.slideTo(slideToIndex);\n }\n } else if (slideToIndex > swiper.slides.length - slidesPerView) {\n swiper.loopFix();\n slideToIndex = $wrapperEl\n .children((\".\" + (params.slideClass) + \"[data-swiper-slide-index=\\\"\" + realIndex + \"\\\"]:not(.\" + (params.slideDuplicateClass) + \")\"))\n .eq(0)\n .index();\n\n Utils.nextTick(function () {\n swiper.slideTo(slideToIndex);\n });\n } else {\n swiper.slideTo(slideToIndex);\n }\n } else {\n swiper.slideTo(slideToIndex);\n }\n }\n\n var slide = {\n slideTo: slideTo,\n slideToLoop: slideToLoop,\n slideNext: slideNext,\n slidePrev: slidePrev,\n slideReset: slideReset,\n slideToClosest: slideToClosest,\n slideToClickedSlide: slideToClickedSlide,\n };\n\n function loopCreate () {\n var swiper = this;\n var params = swiper.params;\n var $wrapperEl = swiper.$wrapperEl;\n // Remove duplicated slides\n $wrapperEl.children((\".\" + (params.slideClass) + \".\" + (params.slideDuplicateClass))).remove();\n\n var slides = $wrapperEl.children((\".\" + (params.slideClass)));\n\n if (params.loopFillGroupWithBlank) {\n var blankSlidesNum = params.slidesPerGroup - (slides.length % params.slidesPerGroup);\n if (blankSlidesNum !== params.slidesPerGroup) {\n for (var i = 0; i < blankSlidesNum; i += 1) {\n var blankNode = $(doc.createElement('div')).addClass(((params.slideClass) + \" \" + (params.slideBlankClass)));\n $wrapperEl.append(blankNode);\n }\n slides = $wrapperEl.children((\".\" + (params.slideClass)));\n }\n }\n\n if (params.slidesPerView === 'auto' && !params.loopedSlides) { params.loopedSlides = slides.length; }\n\n swiper.loopedSlides = parseInt(params.loopedSlides || params.slidesPerView, 10);\n swiper.loopedSlides += params.loopAdditionalSlides;\n if (swiper.loopedSlides > slides.length) {\n swiper.loopedSlides = slides.length;\n }\n\n var prependSlides = [];\n var appendSlides = [];\n slides.each(function (index, el) {\n var slide = $(el);\n if (index < swiper.loopedSlides) { appendSlides.push(el); }\n if (index < slides.length && index >= slides.length - swiper.loopedSlides) { prependSlides.push(el); }\n slide.attr('data-swiper-slide-index', index);\n });\n for (var i$1 = 0; i$1 < appendSlides.length; i$1 += 1) {\n $wrapperEl.append($(appendSlides[i$1].cloneNode(true)).addClass(params.slideDuplicateClass));\n }\n for (var i$2 = prependSlides.length - 1; i$2 >= 0; i$2 -= 1) {\n $wrapperEl.prepend($(prependSlides[i$2].cloneNode(true)).addClass(params.slideDuplicateClass));\n }\n }\n\n function loopFix () {\n var swiper = this;\n var params = swiper.params;\n var activeIndex = swiper.activeIndex;\n var slides = swiper.slides;\n var loopedSlides = swiper.loopedSlides;\n var allowSlidePrev = swiper.allowSlidePrev;\n var allowSlideNext = swiper.allowSlideNext;\n var snapGrid = swiper.snapGrid;\n var rtl = swiper.rtlTranslate;\n var newIndex;\n swiper.allowSlidePrev = true;\n swiper.allowSlideNext = true;\n\n var snapTranslate = -snapGrid[activeIndex];\n var diff = snapTranslate - swiper.getTranslate();\n\n\n // Fix For Negative Oversliding\n if (activeIndex < loopedSlides) {\n newIndex = (slides.length - (loopedSlides * 3)) + activeIndex;\n newIndex += loopedSlides;\n var slideChanged = swiper.slideTo(newIndex, 0, false, true);\n if (slideChanged && diff !== 0) {\n swiper.setTranslate((rtl ? -swiper.translate : swiper.translate) - diff);\n }\n } else if ((params.slidesPerView === 'auto' && activeIndex >= loopedSlides * 2) || (activeIndex >= slides.length - loopedSlides)) {\n // Fix For Positive Oversliding\n newIndex = -slides.length + activeIndex + loopedSlides;\n newIndex += loopedSlides;\n var slideChanged$1 = swiper.slideTo(newIndex, 0, false, true);\n if (slideChanged$1 && diff !== 0) {\n swiper.setTranslate((rtl ? -swiper.translate : swiper.translate) - diff);\n }\n }\n swiper.allowSlidePrev = allowSlidePrev;\n swiper.allowSlideNext = allowSlideNext;\n }\n\n function loopDestroy () {\n var swiper = this;\n var $wrapperEl = swiper.$wrapperEl;\n var params = swiper.params;\n var slides = swiper.slides;\n $wrapperEl.children((\".\" + (params.slideClass) + \".\" + (params.slideDuplicateClass) + \",.\" + (params.slideClass) + \".\" + (params.slideBlankClass))).remove();\n slides.removeAttr('data-swiper-slide-index');\n }\n\n var loop = {\n loopCreate: loopCreate,\n loopFix: loopFix,\n loopDestroy: loopDestroy,\n };\n\n function setGrabCursor (moving) {\n var swiper = this;\n if (Support.touch || !swiper.params.simulateTouch || (swiper.params.watchOverflow && swiper.isLocked)) { return; }\n var el = swiper.el;\n el.style.cursor = 'move';\n el.style.cursor = moving ? '-webkit-grabbing' : '-webkit-grab';\n el.style.cursor = moving ? '-moz-grabbin' : '-moz-grab';\n el.style.cursor = moving ? 'grabbing' : 'grab';\n }\n\n function unsetGrabCursor () {\n var swiper = this;\n if (Support.touch || (swiper.params.watchOverflow && swiper.isLocked)) { return; }\n swiper.el.style.cursor = '';\n }\n\n var grabCursor = {\n setGrabCursor: setGrabCursor,\n unsetGrabCursor: unsetGrabCursor,\n };\n\n function appendSlide (slides) {\n var swiper = this;\n var $wrapperEl = swiper.$wrapperEl;\n var params = swiper.params;\n if (params.loop) {\n swiper.loopDestroy();\n }\n if (typeof slides === 'object' && 'length' in slides) {\n for (var i = 0; i < slides.length; i += 1) {\n if (slides[i]) { $wrapperEl.append(slides[i]); }\n }\n } else {\n $wrapperEl.append(slides);\n }\n if (params.loop) {\n swiper.loopCreate();\n }\n if (!(params.observer && Support.observer)) {\n swiper.update();\n }\n }\n\n function prependSlide (slides) {\n var swiper = this;\n var params = swiper.params;\n var $wrapperEl = swiper.$wrapperEl;\n var activeIndex = swiper.activeIndex;\n\n if (params.loop) {\n swiper.loopDestroy();\n }\n var newActiveIndex = activeIndex + 1;\n if (typeof slides === 'object' && 'length' in slides) {\n for (var i = 0; i < slides.length; i += 1) {\n if (slides[i]) { $wrapperEl.prepend(slides[i]); }\n }\n newActiveIndex = activeIndex + slides.length;\n } else {\n $wrapperEl.prepend(slides);\n }\n if (params.loop) {\n swiper.loopCreate();\n }\n if (!(params.observer && Support.observer)) {\n swiper.update();\n }\n swiper.slideTo(newActiveIndex, 0, false);\n }\n\n function addSlide (index, slides) {\n var swiper = this;\n var $wrapperEl = swiper.$wrapperEl;\n var params = swiper.params;\n var activeIndex = swiper.activeIndex;\n var activeIndexBuffer = activeIndex;\n if (params.loop) {\n activeIndexBuffer -= swiper.loopedSlides;\n swiper.loopDestroy();\n swiper.slides = $wrapperEl.children((\".\" + (params.slideClass)));\n }\n var baseLength = swiper.slides.length;\n if (index <= 0) {\n swiper.prependSlide(slides);\n return;\n }\n if (index >= baseLength) {\n swiper.appendSlide(slides);\n return;\n }\n var newActiveIndex = activeIndexBuffer > index ? activeIndexBuffer + 1 : activeIndexBuffer;\n\n var slidesBuffer = [];\n for (var i = baseLength - 1; i >= index; i -= 1) {\n var currentSlide = swiper.slides.eq(i);\n currentSlide.remove();\n slidesBuffer.unshift(currentSlide);\n }\n\n if (typeof slides === 'object' && 'length' in slides) {\n for (var i$1 = 0; i$1 < slides.length; i$1 += 1) {\n if (slides[i$1]) { $wrapperEl.append(slides[i$1]); }\n }\n newActiveIndex = activeIndexBuffer > index ? activeIndexBuffer + slides.length : activeIndexBuffer;\n } else {\n $wrapperEl.append(slides);\n }\n\n for (var i$2 = 0; i$2 < slidesBuffer.length; i$2 += 1) {\n $wrapperEl.append(slidesBuffer[i$2]);\n }\n\n if (params.loop) {\n swiper.loopCreate();\n }\n if (!(params.observer && Support.observer)) {\n swiper.update();\n }\n if (params.loop) {\n swiper.slideTo(newActiveIndex + swiper.loopedSlides, 0, false);\n } else {\n swiper.slideTo(newActiveIndex, 0, false);\n }\n }\n\n function removeSlide (slidesIndexes) {\n var swiper = this;\n var params = swiper.params;\n var $wrapperEl = swiper.$wrapperEl;\n var activeIndex = swiper.activeIndex;\n\n var activeIndexBuffer = activeIndex;\n if (params.loop) {\n activeIndexBuffer -= swiper.loopedSlides;\n swiper.loopDestroy();\n swiper.slides = $wrapperEl.children((\".\" + (params.slideClass)));\n }\n var newActiveIndex = activeIndexBuffer;\n var indexToRemove;\n\n if (typeof slidesIndexes === 'object' && 'length' in slidesIndexes) {\n for (var i = 0; i < slidesIndexes.length; i += 1) {\n indexToRemove = slidesIndexes[i];\n if (swiper.slides[indexToRemove]) { swiper.slides.eq(indexToRemove).remove(); }\n if (indexToRemove < newActiveIndex) { newActiveIndex -= 1; }\n }\n newActiveIndex = Math.max(newActiveIndex, 0);\n } else {\n indexToRemove = slidesIndexes;\n if (swiper.slides[indexToRemove]) { swiper.slides.eq(indexToRemove).remove(); }\n if (indexToRemove < newActiveIndex) { newActiveIndex -= 1; }\n newActiveIndex = Math.max(newActiveIndex, 0);\n }\n\n if (params.loop) {\n swiper.loopCreate();\n }\n\n if (!(params.observer && Support.observer)) {\n swiper.update();\n }\n if (params.loop) {\n swiper.slideTo(newActiveIndex + swiper.loopedSlides, 0, false);\n } else {\n swiper.slideTo(newActiveIndex, 0, false);\n }\n }\n\n function removeAllSlides () {\n var swiper = this;\n\n var slidesIndexes = [];\n for (var i = 0; i < swiper.slides.length; i += 1) {\n slidesIndexes.push(i);\n }\n swiper.removeSlide(slidesIndexes);\n }\n\n var manipulation = {\n appendSlide: appendSlide,\n prependSlide: prependSlide,\n addSlide: addSlide,\n removeSlide: removeSlide,\n removeAllSlides: removeAllSlides,\n };\n\n var Device = (function Device() {\n var ua = win.navigator.userAgent;\n\n var device = {\n ios: false,\n android: false,\n androidChrome: false,\n desktop: false,\n windows: false,\n iphone: false,\n ipod: false,\n ipad: false,\n cordova: win.cordova || win.phonegap,\n phonegap: win.cordova || win.phonegap,\n };\n\n var windows = ua.match(/(Windows Phone);?[\\s\\/]+([\\d.]+)?/); // eslint-disable-line\n var android = ua.match(/(Android);?[\\s\\/]+([\\d.]+)?/); // eslint-disable-line\n var ipad = ua.match(/(iPad).*OS\\s([\\d_]+)/);\n var ipod = ua.match(/(iPod)(.*OS\\s([\\d_]+))?/);\n var iphone = !ipad && ua.match(/(iPhone\\sOS|iOS)\\s([\\d_]+)/);\n\n\n // Windows\n if (windows) {\n device.os = 'windows';\n device.osVersion = windows[2];\n device.windows = true;\n }\n // Android\n if (android && !windows) {\n device.os = 'android';\n device.osVersion = android[2];\n device.android = true;\n device.androidChrome = ua.toLowerCase().indexOf('chrome') >= 0;\n }\n if (ipad || iphone || ipod) {\n device.os = 'ios';\n device.ios = true;\n }\n // iOS\n if (iphone && !ipod) {\n device.osVersion = iphone[2].replace(/_/g, '.');\n device.iphone = true;\n }\n if (ipad) {\n device.osVersion = ipad[2].replace(/_/g, '.');\n device.ipad = true;\n }\n if (ipod) {\n device.osVersion = ipod[3] ? ipod[3].replace(/_/g, '.') : null;\n device.iphone = true;\n }\n // iOS 8+ changed UA\n if (device.ios && device.osVersion && ua.indexOf('Version/') >= 0) {\n if (device.osVersion.split('.')[0] === '10') {\n device.osVersion = ua.toLowerCase().split('version/')[1].split(' ')[0];\n }\n }\n\n // Desktop\n device.desktop = !(device.os || device.android || device.webView);\n\n // Webview\n device.webView = (iphone || ipad || ipod) && ua.match(/.*AppleWebKit(?!.*Safari)/i);\n\n // Minimal UI\n if (device.os && device.os === 'ios') {\n var osVersionArr = device.osVersion.split('.');\n var metaViewport = doc.querySelector('meta[name=\"viewport\"]');\n device.minimalUi = !device.webView\n && (ipod || iphone)\n && (osVersionArr[0] * 1 === 7 ? osVersionArr[1] * 1 >= 1 : osVersionArr[0] * 1 > 7)\n && metaViewport && metaViewport.getAttribute('content').indexOf('minimal-ui') >= 0;\n }\n\n // Pixel Ratio\n device.pixelRatio = win.devicePixelRatio || 1;\n\n // Export object\n return device;\n }());\n\n function onTouchStart (event) {\n var swiper = this;\n var data = swiper.touchEventsData;\n var params = swiper.params;\n var touches = swiper.touches;\n if (swiper.animating && params.preventInteractionOnTransition) {\n return;\n }\n var e = event;\n if (e.originalEvent) { e = e.originalEvent; }\n data.isTouchEvent = e.type === 'touchstart';\n if (!data.isTouchEvent && 'which' in e && e.which === 3) { return; }\n if (!data.isTouchEvent && 'button' in e && e.button > 0) { return; }\n if (data.isTouched && data.isMoved) { return; }\n if (params.noSwiping && $(e.target).closest(params.noSwipingSelector ? params.noSwipingSelector : (\".\" + (params.noSwipingClass)))[0]) {\n swiper.allowClick = true;\n return;\n }\n if (params.swipeHandler) {\n if (!$(e).closest(params.swipeHandler)[0]) { return; }\n }\n\n touches.currentX = e.type === 'touchstart' ? e.targetTouches[0].pageX : e.pageX;\n touches.currentY = e.type === 'touchstart' ? e.targetTouches[0].pageY : e.pageY;\n var startX = touches.currentX;\n var startY = touches.currentY;\n\n // Do NOT start if iOS edge swipe is detected. Otherwise iOS app (UIWebView) cannot swipe-to-go-back anymore\n\n var edgeSwipeDetection = params.edgeSwipeDetection || params.iOSEdgeSwipeDetection;\n var edgeSwipeThreshold = params.edgeSwipeThreshold || params.iOSEdgeSwipeThreshold;\n if (\n edgeSwipeDetection\n && ((startX <= edgeSwipeThreshold)\n || (startX >= win.screen.width - edgeSwipeThreshold))\n ) {\n return;\n }\n\n Utils.extend(data, {\n isTouched: true,\n isMoved: false,\n allowTouchCallbacks: true,\n isScrolling: undefined,\n startMoving: undefined,\n });\n\n touches.startX = startX;\n touches.startY = startY;\n data.touchStartTime = Utils.now();\n swiper.allowClick = true;\n swiper.updateSize();\n swiper.swipeDirection = undefined;\n if (params.threshold > 0) { data.allowThresholdMove = false; }\n if (e.type !== 'touchstart') {\n var preventDefault = true;\n if ($(e.target).is(data.formElements)) { preventDefault = false; }\n if (\n doc.activeElement\n && $(doc.activeElement).is(data.formElements)\n && doc.activeElement !== e.target\n ) {\n doc.activeElement.blur();\n }\n\n var shouldPreventDefault = preventDefault && swiper.allowTouchMove && params.touchStartPreventDefault;\n if (params.touchStartForcePreventDefault || shouldPreventDefault) {\n e.preventDefault();\n }\n }\n swiper.emit('touchStart', e);\n }\n\n function onTouchMove (event) {\n var swiper = this;\n var data = swiper.touchEventsData;\n var params = swiper.params;\n var touches = swiper.touches;\n var rtl = swiper.rtlTranslate;\n var e = event;\n if (e.originalEvent) { e = e.originalEvent; }\n if (!data.isTouched) {\n if (data.startMoving && data.isScrolling) {\n swiper.emit('touchMoveOpposite', e);\n }\n return;\n }\n if (data.isTouchEvent && e.type === 'mousemove') { return; }\n var pageX = e.type === 'touchmove' ? e.targetTouches[0].pageX : e.pageX;\n var pageY = e.type === 'touchmove' ? e.targetTouches[0].pageY : e.pageY;\n if (e.preventedByNestedSwiper) {\n touches.startX = pageX;\n touches.startY = pageY;\n return;\n }\n if (!swiper.allowTouchMove) {\n // isMoved = true;\n swiper.allowClick = false;\n if (data.isTouched) {\n Utils.extend(touches, {\n startX: pageX,\n startY: pageY,\n currentX: pageX,\n currentY: pageY,\n });\n data.touchStartTime = Utils.now();\n }\n return;\n }\n if (data.isTouchEvent && params.touchReleaseOnEdges && !params.loop) {\n if (swiper.isVertical()) {\n // Vertical\n if (\n (pageY < touches.startY && swiper.translate <= swiper.maxTranslate())\n || (pageY > touches.startY && swiper.translate >= swiper.minTranslate())\n ) {\n data.isTouched = false;\n data.isMoved = false;\n return;\n }\n } else if (\n (pageX < touches.startX && swiper.translate <= swiper.maxTranslate())\n || (pageX > touches.startX && swiper.translate >= swiper.minTranslate())\n ) {\n return;\n }\n }\n if (data.isTouchEvent && doc.activeElement) {\n if (e.target === doc.activeElement && $(e.target).is(data.formElements)) {\n data.isMoved = true;\n swiper.allowClick = false;\n return;\n }\n }\n if (data.allowTouchCallbacks) {\n swiper.emit('touchMove', e);\n }\n if (e.targetTouches && e.targetTouches.length > 1) { return; }\n\n touches.currentX = pageX;\n touches.currentY = pageY;\n\n var diffX = touches.currentX - touches.startX;\n var diffY = touches.currentY - touches.startY;\n if (swiper.params.threshold && Math.sqrt((Math.pow( diffX, 2 )) + (Math.pow( diffY, 2 ))) < swiper.params.threshold) { return; }\n\n if (typeof data.isScrolling === 'undefined') {\n var touchAngle;\n if ((swiper.isHorizontal() && touches.currentY === touches.startY) || (swiper.isVertical() && touches.currentX === touches.startX)) {\n data.isScrolling = false;\n } else {\n // eslint-disable-next-line\n if ((diffX * diffX) + (diffY * diffY) >= 25) {\n touchAngle = (Math.atan2(Math.abs(diffY), Math.abs(diffX)) * 180) / Math.PI;\n data.isScrolling = swiper.isHorizontal() ? touchAngle > params.touchAngle : (90 - touchAngle > params.touchAngle);\n }\n }\n }\n if (data.isScrolling) {\n swiper.emit('touchMoveOpposite', e);\n }\n if (typeof data.startMoving === 'undefined') {\n if (touches.currentX !== touches.startX || touches.currentY !== touches.startY) {\n data.startMoving = true;\n }\n }\n if (data.isScrolling) {\n data.isTouched = false;\n return;\n }\n if (!data.startMoving) {\n return;\n }\n swiper.allowClick = false;\n e.preventDefault();\n if (params.touchMoveStopPropagation && !params.nested) {\n e.stopPropagation();\n }\n\n if (!data.isMoved) {\n if (params.loop) {\n swiper.loopFix();\n }\n data.startTranslate = swiper.getTranslate();\n swiper.setTransition(0);\n if (swiper.animating) {\n swiper.$wrapperEl.trigger('webkitTransitionEnd transitionend');\n }\n data.allowMomentumBounce = false;\n // Grab Cursor\n if (params.grabCursor && (swiper.allowSlideNext === true || swiper.allowSlidePrev === true)) {\n swiper.setGrabCursor(true);\n }\n swiper.emit('sliderFirstMove', e);\n }\n swiper.emit('sliderMove', e);\n data.isMoved = true;\n\n var diff = swiper.isHorizontal() ? diffX : diffY;\n touches.diff = diff;\n\n diff *= params.touchRatio;\n if (rtl) { diff = -diff; }\n\n swiper.swipeDirection = diff > 0 ? 'prev' : 'next';\n data.currentTranslate = diff + data.startTranslate;\n\n var disableParentSwiper = true;\n var resistanceRatio = params.resistanceRatio;\n if (params.touchReleaseOnEdges) {\n resistanceRatio = 0;\n }\n if ((diff > 0 && data.currentTranslate > swiper.minTranslate())) {\n disableParentSwiper = false;\n if (params.resistance) { data.currentTranslate = (swiper.minTranslate() - 1) + (Math.pow( (-swiper.minTranslate() + data.startTranslate + diff), resistanceRatio )); }\n } else if (diff < 0 && data.currentTranslate < swiper.maxTranslate()) {\n disableParentSwiper = false;\n if (params.resistance) { data.currentTranslate = (swiper.maxTranslate() + 1) - (Math.pow( (swiper.maxTranslate() - data.startTranslate - diff), resistanceRatio )); }\n }\n\n if (disableParentSwiper) {\n e.preventedByNestedSwiper = true;\n }\n\n // Directions locks\n if (!swiper.allowSlideNext && swiper.swipeDirection === 'next' && data.currentTranslate < data.startTranslate) {\n data.currentTranslate = data.startTranslate;\n }\n if (!swiper.allowSlidePrev && swiper.swipeDirection === 'prev' && data.currentTranslate > data.startTranslate) {\n data.currentTranslate = data.startTranslate;\n }\n\n\n // Threshold\n if (params.threshold > 0) {\n if (Math.abs(diff) > params.threshold || data.allowThresholdMove) {\n if (!data.allowThresholdMove) {\n data.allowThresholdMove = true;\n touches.startX = touches.currentX;\n touches.startY = touches.currentY;\n data.currentTranslate = data.startTranslate;\n touches.diff = swiper.isHorizontal() ? touches.currentX - touches.startX : touches.currentY - touches.startY;\n return;\n }\n } else {\n data.currentTranslate = data.startTranslate;\n return;\n }\n }\n\n if (!params.followFinger) { return; }\n\n // Update active index in free mode\n if (params.freeMode || params.watchSlidesProgress || params.watchSlidesVisibility) {\n swiper.updateActiveIndex();\n swiper.updateSlidesClasses();\n }\n if (params.freeMode) {\n // Velocity\n if (data.velocities.length === 0) {\n data.velocities.push({\n position: touches[swiper.isHorizontal() ? 'startX' : 'startY'],\n time: data.touchStartTime,\n });\n }\n data.velocities.push({\n position: touches[swiper.isHorizontal() ? 'currentX' : 'currentY'],\n time: Utils.now(),\n });\n }\n // Update progress\n swiper.updateProgress(data.currentTranslate);\n // Update translate\n swiper.setTranslate(data.currentTranslate);\n }\n\n function onTouchEnd (event) {\n var swiper = this;\n var data = swiper.touchEventsData;\n\n var params = swiper.params;\n var touches = swiper.touches;\n var rtl = swiper.rtlTranslate;\n var $wrapperEl = swiper.$wrapperEl;\n var slidesGrid = swiper.slidesGrid;\n var snapGrid = swiper.snapGrid;\n var e = event;\n if (e.originalEvent) { e = e.originalEvent; }\n if (data.allowTouchCallbacks) {\n swiper.emit('touchEnd', e);\n }\n data.allowTouchCallbacks = false;\n if (!data.isTouched) {\n if (data.isMoved && params.grabCursor) {\n swiper.setGrabCursor(false);\n }\n data.isMoved = false;\n data.startMoving = false;\n return;\n }\n // Return Grab Cursor\n if (params.grabCursor && data.isMoved && data.isTouched && (swiper.allowSlideNext === true || swiper.allowSlidePrev === true)) {\n swiper.setGrabCursor(false);\n }\n\n // Time diff\n var touchEndTime = Utils.now();\n var timeDiff = touchEndTime - data.touchStartTime;\n\n // Tap, doubleTap, Click\n if (swiper.allowClick) {\n swiper.updateClickedSlide(e);\n swiper.emit('tap', e);\n if (timeDiff < 300 && (touchEndTime - data.lastClickTime) > 300) {\n if (data.clickTimeout) { clearTimeout(data.clickTimeout); }\n data.clickTimeout = Utils.nextTick(function () {\n if (!swiper || swiper.destroyed) { return; }\n swiper.emit('click', e);\n }, 300);\n }\n if (timeDiff < 300 && (touchEndTime - data.lastClickTime) < 300) {\n if (data.clickTimeout) { clearTimeout(data.clickTimeout); }\n swiper.emit('doubleTap', e);\n }\n }\n\n data.lastClickTime = Utils.now();\n Utils.nextTick(function () {\n if (!swiper.destroyed) { swiper.allowClick = true; }\n });\n\n if (!data.isTouched || !data.isMoved || !swiper.swipeDirection || touches.diff === 0 || data.currentTranslate === data.startTranslate) {\n data.isTouched = false;\n data.isMoved = false;\n data.startMoving = false;\n return;\n }\n data.isTouched = false;\n data.isMoved = false;\n data.startMoving = false;\n\n var currentPos;\n if (params.followFinger) {\n currentPos = rtl ? swiper.translate : -swiper.translate;\n } else {\n currentPos = -data.currentTranslate;\n }\n\n if (params.freeMode) {\n if (currentPos < -swiper.minTranslate()) {\n swiper.slideTo(swiper.activeIndex);\n return;\n }\n if (currentPos > -swiper.maxTranslate()) {\n if (swiper.slides.length < snapGrid.length) {\n swiper.slideTo(snapGrid.length - 1);\n } else {\n swiper.slideTo(swiper.slides.length - 1);\n }\n return;\n }\n\n if (params.freeModeMomentum) {\n if (data.velocities.length > 1) {\n var lastMoveEvent = data.velocities.pop();\n var velocityEvent = data.velocities.pop();\n\n var distance = lastMoveEvent.position - velocityEvent.position;\n var time = lastMoveEvent.time - velocityEvent.time;\n swiper.velocity = distance / time;\n swiper.velocity /= 2;\n if (Math.abs(swiper.velocity) < params.freeModeMinimumVelocity) {\n swiper.velocity = 0;\n }\n // this implies that the user stopped moving a finger then released.\n // There would be no events with distance zero, so the last event is stale.\n if (time > 150 || (Utils.now() - lastMoveEvent.time) > 300) {\n swiper.velocity = 0;\n }\n } else {\n swiper.velocity = 0;\n }\n swiper.velocity *= params.freeModeMomentumVelocityRatio;\n\n data.velocities.length = 0;\n var momentumDuration = 1000 * params.freeModeMomentumRatio;\n var momentumDistance = swiper.velocity * momentumDuration;\n\n var newPosition = swiper.translate + momentumDistance;\n if (rtl) { newPosition = -newPosition; }\n\n var doBounce = false;\n var afterBouncePosition;\n var bounceAmount = Math.abs(swiper.velocity) * 20 * params.freeModeMomentumBounceRatio;\n var needsLoopFix;\n if (newPosition < swiper.maxTranslate()) {\n if (params.freeModeMomentumBounce) {\n if (newPosition + swiper.maxTranslate() < -bounceAmount) {\n newPosition = swiper.maxTranslate() - bounceAmount;\n }\n afterBouncePosition = swiper.maxTranslate();\n doBounce = true;\n data.allowMomentumBounce = true;\n } else {\n newPosition = swiper.maxTranslate();\n }\n if (params.loop && params.centeredSlides) { needsLoopFix = true; }\n } else if (newPosition > swiper.minTranslate()) {\n if (params.freeModeMomentumBounce) {\n if (newPosition - swiper.minTranslate() > bounceAmount) {\n newPosition = swiper.minTranslate() + bounceAmount;\n }\n afterBouncePosition = swiper.minTranslate();\n doBounce = true;\n data.allowMomentumBounce = true;\n } else {\n newPosition = swiper.minTranslate();\n }\n if (params.loop && params.centeredSlides) { needsLoopFix = true; }\n } else if (params.freeModeSticky) {\n var nextSlide;\n for (var j = 0; j < snapGrid.length; j += 1) {\n if (snapGrid[j] > -newPosition) {\n nextSlide = j;\n break;\n }\n }\n\n if (Math.abs(snapGrid[nextSlide] - newPosition) < Math.abs(snapGrid[nextSlide - 1] - newPosition) || swiper.swipeDirection === 'next') {\n newPosition = snapGrid[nextSlide];\n } else {\n newPosition = snapGrid[nextSlide - 1];\n }\n newPosition = -newPosition;\n }\n if (needsLoopFix) {\n swiper.once('transitionEnd', function () {\n swiper.loopFix();\n });\n }\n // Fix duration\n if (swiper.velocity !== 0) {\n if (rtl) {\n momentumDuration = Math.abs((-newPosition - swiper.translate) / swiper.velocity);\n } else {\n momentumDuration = Math.abs((newPosition - swiper.translate) / swiper.velocity);\n }\n } else if (params.freeModeSticky) {\n swiper.slideToClosest();\n return;\n }\n\n if (params.freeModeMomentumBounce && doBounce) {\n swiper.updateProgress(afterBouncePosition);\n swiper.setTransition(momentumDuration);\n swiper.setTranslate(newPosition);\n swiper.transitionStart(true, swiper.swipeDirection);\n swiper.animating = true;\n $wrapperEl.transitionEnd(function () {\n if (!swiper || swiper.destroyed || !data.allowMomentumBounce) { return; }\n swiper.emit('momentumBounce');\n\n swiper.setTransition(params.speed);\n swiper.setTranslate(afterBouncePosition);\n $wrapperEl.transitionEnd(function () {\n if (!swiper || swiper.destroyed) { return; }\n swiper.transitionEnd();\n });\n });\n } else if (swiper.velocity) {\n swiper.updateProgress(newPosition);\n swiper.setTransition(momentumDuration);\n swiper.setTranslate(newPosition);\n swiper.transitionStart(true, swiper.swipeDirection);\n if (!swiper.animating) {\n swiper.animating = true;\n $wrapperEl.transitionEnd(function () {\n if (!swiper || swiper.destroyed) { return; }\n swiper.transitionEnd();\n });\n }\n } else {\n swiper.updateProgress(newPosition);\n }\n\n swiper.updateActiveIndex();\n swiper.updateSlidesClasses();\n } else if (params.freeModeSticky) {\n swiper.slideToClosest();\n return;\n }\n\n if (!params.freeModeMomentum || timeDiff >= params.longSwipesMs) {\n swiper.updateProgress();\n swiper.updateActiveIndex();\n swiper.updateSlidesClasses();\n }\n return;\n }\n\n // Find current slide\n var stopIndex = 0;\n var groupSize = swiper.slidesSizesGrid[0];\n for (var i = 0; i < slidesGrid.length; i += params.slidesPerGroup) {\n if (typeof slidesGrid[i + params.slidesPerGroup] !== 'undefined') {\n if (currentPos >= slidesGrid[i] && currentPos < slidesGrid[i + params.slidesPerGroup]) {\n stopIndex = i;\n groupSize = slidesGrid[i + params.slidesPerGroup] - slidesGrid[i];\n }\n } else if (currentPos >= slidesGrid[i]) {\n stopIndex = i;\n groupSize = slidesGrid[slidesGrid.length - 1] - slidesGrid[slidesGrid.length - 2];\n }\n }\n\n // Find current slide size\n var ratio = (currentPos - slidesGrid[stopIndex]) / groupSize;\n\n if (timeDiff > params.longSwipesMs) {\n // Long touches\n if (!params.longSwipes) {\n swiper.slideTo(swiper.activeIndex);\n return;\n }\n if (swiper.swipeDirection === 'next') {\n if (ratio >= params.longSwipesRatio) { swiper.slideTo(stopIndex + params.slidesPerGroup); }\n else { swiper.slideTo(stopIndex); }\n }\n if (swiper.swipeDirection === 'prev') {\n if (ratio > (1 - params.longSwipesRatio)) { swiper.slideTo(stopIndex + params.slidesPerGroup); }\n else { swiper.slideTo(stopIndex); }\n }\n } else {\n // Short swipes\n if (!params.shortSwipes) {\n swiper.slideTo(swiper.activeIndex);\n return;\n }\n if (swiper.swipeDirection === 'next') {\n swiper.slideTo(stopIndex + params.slidesPerGroup);\n }\n if (swiper.swipeDirection === 'prev') {\n swiper.slideTo(stopIndex);\n }\n }\n }\n\n function onResize () {\n var swiper = this;\n\n var params = swiper.params;\n var el = swiper.el;\n\n if (el && el.offsetWidth === 0) { return; }\n\n // Breakpoints\n if (params.breakpoints) {\n swiper.setBreakpoint();\n }\n\n // Save locks\n var allowSlideNext = swiper.allowSlideNext;\n var allowSlidePrev = swiper.allowSlidePrev;\n var snapGrid = swiper.snapGrid;\n\n // Disable locks on resize\n swiper.allowSlideNext = true;\n swiper.allowSlidePrev = true;\n\n swiper.updateSize();\n swiper.updateSlides();\n\n if (params.freeMode) {\n var newTranslate = Math.min(Math.max(swiper.translate, swiper.maxTranslate()), swiper.minTranslate());\n swiper.setTranslate(newTranslate);\n swiper.updateActiveIndex();\n swiper.updateSlidesClasses();\n\n if (params.autoHeight) {\n swiper.updateAutoHeight();\n }\n } else {\n swiper.updateSlidesClasses();\n if ((params.slidesPerView === 'auto' || params.slidesPerView > 1) && swiper.isEnd && !swiper.params.centeredSlides) {\n swiper.slideTo(swiper.slides.length - 1, 0, false, true);\n } else {\n swiper.slideTo(swiper.activeIndex, 0, false, true);\n }\n }\n if (swiper.autoplay && swiper.autoplay.running && swiper.autoplay.paused) {\n swiper.autoplay.run();\n }\n // Return locks after resize\n swiper.allowSlidePrev = allowSlidePrev;\n swiper.allowSlideNext = allowSlideNext;\n\n if (swiper.params.watchOverflow && snapGrid !== swiper.snapGrid) {\n swiper.checkOverflow();\n }\n }\n\n function onClick (e) {\n var swiper = this;\n if (!swiper.allowClick) {\n if (swiper.params.preventClicks) { e.preventDefault(); }\n if (swiper.params.preventClicksPropagation && swiper.animating) {\n e.stopPropagation();\n e.stopImmediatePropagation();\n }\n }\n }\n\n function attachEvents() {\n var swiper = this;\n var params = swiper.params;\n var touchEvents = swiper.touchEvents;\n var el = swiper.el;\n var wrapperEl = swiper.wrapperEl;\n\n {\n swiper.onTouchStart = onTouchStart.bind(swiper);\n swiper.onTouchMove = onTouchMove.bind(swiper);\n swiper.onTouchEnd = onTouchEnd.bind(swiper);\n }\n\n swiper.onClick = onClick.bind(swiper);\n\n var target = params.touchEventsTarget === 'container' ? el : wrapperEl;\n var capture = !!params.nested;\n\n // Touch Events\n {\n if (!Support.touch && (Support.pointerEvents || Support.prefixedPointerEvents)) {\n target.addEventListener(touchEvents.start, swiper.onTouchStart, false);\n doc.addEventListener(touchEvents.move, swiper.onTouchMove, capture);\n doc.addEventListener(touchEvents.end, swiper.onTouchEnd, false);\n } else {\n if (Support.touch) {\n var passiveListener = touchEvents.start === 'touchstart' && Support.passiveListener && params.passiveListeners ? { passive: true, capture: false } : false;\n target.addEventListener(touchEvents.start, swiper.onTouchStart, passiveListener);\n target.addEventListener(touchEvents.move, swiper.onTouchMove, Support.passiveListener ? { passive: false, capture: capture } : capture);\n target.addEventListener(touchEvents.end, swiper.onTouchEnd, passiveListener);\n }\n if ((params.simulateTouch && !Device.ios && !Device.android) || (params.simulateTouch && !Support.touch && Device.ios)) {\n target.addEventListener('mousedown', swiper.onTouchStart, false);\n doc.addEventListener('mousemove', swiper.onTouchMove, capture);\n doc.addEventListener('mouseup', swiper.onTouchEnd, false);\n }\n }\n // Prevent Links Clicks\n if (params.preventClicks || params.preventClicksPropagation) {\n target.addEventListener('click', swiper.onClick, true);\n }\n }\n\n // Resize handler\n swiper.on((Device.ios || Device.android ? 'resize orientationchange observerUpdate' : 'resize observerUpdate'), onResize, true);\n }\n\n function detachEvents() {\n var swiper = this;\n\n var params = swiper.params;\n var touchEvents = swiper.touchEvents;\n var el = swiper.el;\n var wrapperEl = swiper.wrapperEl;\n\n var target = params.touchEventsTarget === 'container' ? el : wrapperEl;\n var capture = !!params.nested;\n\n // Touch Events\n {\n if (!Support.touch && (Support.pointerEvents || Support.prefixedPointerEvents)) {\n target.removeEventListener(touchEvents.start, swiper.onTouchStart, false);\n doc.removeEventListener(touchEvents.move, swiper.onTouchMove, capture);\n doc.removeEventListener(touchEvents.end, swiper.onTouchEnd, false);\n } else {\n if (Support.touch) {\n var passiveListener = touchEvents.start === 'onTouchStart' && Support.passiveListener && params.passiveListeners ? { passive: true, capture: false } : false;\n target.removeEventListener(touchEvents.start, swiper.onTouchStart, passiveListener);\n target.removeEventListener(touchEvents.move, swiper.onTouchMove, capture);\n target.removeEventListener(touchEvents.end, swiper.onTouchEnd, passiveListener);\n }\n if ((params.simulateTouch && !Device.ios && !Device.android) || (params.simulateTouch && !Support.touch && Device.ios)) {\n target.removeEventListener('mousedown', swiper.onTouchStart, false);\n doc.removeEventListener('mousemove', swiper.onTouchMove, capture);\n doc.removeEventListener('mouseup', swiper.onTouchEnd, false);\n }\n }\n // Prevent Links Clicks\n if (params.preventClicks || params.preventClicksPropagation) {\n target.removeEventListener('click', swiper.onClick, true);\n }\n }\n\n // Resize handler\n swiper.off((Device.ios || Device.android ? 'resize orientationchange observerUpdate' : 'resize observerUpdate'), onResize);\n }\n\n var events = {\n attachEvents: attachEvents,\n detachEvents: detachEvents,\n };\n\n function setBreakpoint () {\n var swiper = this;\n var activeIndex = swiper.activeIndex;\n var initialized = swiper.initialized;\n var loopedSlides = swiper.loopedSlides; if ( loopedSlides === void 0 ) loopedSlides = 0;\n var params = swiper.params;\n var breakpoints = params.breakpoints;\n if (!breakpoints || (breakpoints && Object.keys(breakpoints).length === 0)) { return; }\n\n // Set breakpoint for window width and update parameters\n var breakpoint = swiper.getBreakpoint(breakpoints);\n\n if (breakpoint && swiper.currentBreakpoint !== breakpoint) {\n var breakpointOnlyParams = breakpoint in breakpoints ? breakpoints[breakpoint] : undefined;\n if (breakpointOnlyParams) {\n ['slidesPerView', 'spaceBetween', 'slidesPerGroup'].forEach(function (param) {\n var paramValue = breakpointOnlyParams[param];\n if (typeof paramValue === 'undefined') { return; }\n if (param === 'slidesPerView' && (paramValue === 'AUTO' || paramValue === 'auto')) {\n breakpointOnlyParams[param] = 'auto';\n } else if (param === 'slidesPerView') {\n breakpointOnlyParams[param] = parseFloat(paramValue);\n } else {\n breakpointOnlyParams[param] = parseInt(paramValue, 10);\n }\n });\n }\n\n var breakpointParams = breakpointOnlyParams || swiper.originalParams;\n var directionChanged = breakpointParams.direction && breakpointParams.direction !== params.direction;\n var needsReLoop = params.loop && (breakpointParams.slidesPerView !== params.slidesPerView || directionChanged);\n\n if (directionChanged && initialized) {\n swiper.changeDirection();\n }\n\n Utils.extend(swiper.params, breakpointParams);\n\n Utils.extend(swiper, {\n allowTouchMove: swiper.params.allowTouchMove,\n allowSlideNext: swiper.params.allowSlideNext,\n allowSlidePrev: swiper.params.allowSlidePrev,\n });\n\n swiper.currentBreakpoint = breakpoint;\n\n if (needsReLoop && initialized) {\n swiper.loopDestroy();\n swiper.loopCreate();\n swiper.updateSlides();\n swiper.slideTo((activeIndex - loopedSlides) + swiper.loopedSlides, 0, false);\n }\n\n swiper.emit('breakpoint', breakpointParams);\n }\n }\n\n function getBreakpoint (breakpoints) {\n var swiper = this;\n // Get breakpoint for window width\n if (!breakpoints) { return undefined; }\n var breakpoint = false;\n var points = [];\n Object.keys(breakpoints).forEach(function (point) {\n points.push(point);\n });\n points.sort(function (a, b) { return parseInt(a, 10) - parseInt(b, 10); });\n for (var i = 0; i < points.length; i += 1) {\n var point = points[i];\n if (swiper.params.breakpointsInverse) {\n if (point <= win.innerWidth) {\n breakpoint = point;\n }\n } else if (point >= win.innerWidth && !breakpoint) {\n breakpoint = point;\n }\n }\n return breakpoint || 'max';\n }\n\n var breakpoints = { setBreakpoint: setBreakpoint, getBreakpoint: getBreakpoint };\n\n function addClasses () {\n var swiper = this;\n var classNames = swiper.classNames;\n var params = swiper.params;\n var rtl = swiper.rtl;\n var $el = swiper.$el;\n var suffixes = [];\n\n suffixes.push('initialized');\n suffixes.push(params.direction);\n\n if (params.freeMode) {\n suffixes.push('free-mode');\n }\n if (!Support.flexbox) {\n suffixes.push('no-flexbox');\n }\n if (params.autoHeight) {\n suffixes.push('autoheight');\n }\n if (rtl) {\n suffixes.push('rtl');\n }\n if (params.slidesPerColumn > 1) {\n suffixes.push('multirow');\n }\n if (Device.android) {\n suffixes.push('android');\n }\n if (Device.ios) {\n suffixes.push('ios');\n }\n // WP8 Touch Events Fix\n if ((Browser.isIE || Browser.isEdge) && (Support.pointerEvents || Support.prefixedPointerEvents)) {\n suffixes.push((\"wp8-\" + (params.direction)));\n }\n\n suffixes.forEach(function (suffix) {\n classNames.push(params.containerModifierClass + suffix);\n });\n\n $el.addClass(classNames.join(' '));\n }\n\n function removeClasses () {\n var swiper = this;\n var $el = swiper.$el;\n var classNames = swiper.classNames;\n\n $el.removeClass(classNames.join(' '));\n }\n\n var classes = { addClasses: addClasses, removeClasses: removeClasses };\n\n function loadImage (imageEl, src, srcset, sizes, checkForComplete, callback) {\n var image;\n function onReady() {\n if (callback) { callback(); }\n }\n if (!imageEl.complete || !checkForComplete) {\n if (src) {\n image = new win.Image();\n image.onload = onReady;\n image.onerror = onReady;\n if (sizes) {\n image.sizes = sizes;\n }\n if (srcset) {\n image.srcset = srcset;\n }\n if (src) {\n image.src = src;\n }\n } else {\n onReady();\n }\n } else {\n // image already loaded...\n onReady();\n }\n }\n\n function preloadImages () {\n var swiper = this;\n swiper.imagesToLoad = swiper.$el.find('img');\n function onReady() {\n if (typeof swiper === 'undefined' || swiper === null || !swiper || swiper.destroyed) { return; }\n if (swiper.imagesLoaded !== undefined) { swiper.imagesLoaded += 1; }\n if (swiper.imagesLoaded === swiper.imagesToLoad.length) {\n if (swiper.params.updateOnImagesReady) { swiper.update(); }\n swiper.emit('imagesReady');\n }\n }\n for (var i = 0; i < swiper.imagesToLoad.length; i += 1) {\n var imageEl = swiper.imagesToLoad[i];\n swiper.loadImage(\n imageEl,\n imageEl.currentSrc || imageEl.getAttribute('src'),\n imageEl.srcset || imageEl.getAttribute('srcset'),\n imageEl.sizes || imageEl.getAttribute('sizes'),\n true,\n onReady\n );\n }\n }\n\n var images = {\n loadImage: loadImage,\n preloadImages: preloadImages,\n };\n\n function checkOverflow() {\n var swiper = this;\n var wasLocked = swiper.isLocked;\n\n swiper.isLocked = swiper.snapGrid.length === 1;\n swiper.allowSlideNext = !swiper.isLocked;\n swiper.allowSlidePrev = !swiper.isLocked;\n\n // events\n if (wasLocked !== swiper.isLocked) { swiper.emit(swiper.isLocked ? 'lock' : 'unlock'); }\n\n if (wasLocked && wasLocked !== swiper.isLocked) {\n swiper.isEnd = false;\n swiper.navigation.update();\n }\n }\n\n var checkOverflow$1 = { checkOverflow: checkOverflow };\n\n var defaults = {\n init: true,\n direction: 'horizontal',\n touchEventsTarget: 'container',\n initialSlide: 0,\n speed: 300,\n //\n preventInteractionOnTransition: false,\n\n // To support iOS's swipe-to-go-back gesture (when being used in-app, with UIWebView).\n edgeSwipeDetection: false,\n edgeSwipeThreshold: 20,\n\n // Free mode\n freeMode: false,\n freeModeMomentum: true,\n freeModeMomentumRatio: 1,\n freeModeMomentumBounce: true,\n freeModeMomentumBounceRatio: 1,\n freeModeMomentumVelocityRatio: 1,\n freeModeSticky: false,\n freeModeMinimumVelocity: 0.02,\n\n // Autoheight\n autoHeight: false,\n\n // Set wrapper width\n setWrapperSize: false,\n\n // Virtual Translate\n virtualTranslate: false,\n\n // Effects\n effect: 'slide', // 'slide' or 'fade' or 'cube' or 'coverflow' or 'flip'\n\n // Breakpoints\n breakpoints: undefined,\n breakpointsInverse: false,\n\n // Slides grid\n spaceBetween: 0,\n slidesPerView: 1,\n slidesPerColumn: 1,\n slidesPerColumnFill: 'column',\n slidesPerGroup: 1,\n centeredSlides: false,\n slidesOffsetBefore: 0, // in px\n slidesOffsetAfter: 0, // in px\n normalizeSlideIndex: true,\n centerInsufficientSlides: false,\n\n // Disable swiper and hide navigation when container not overflow\n watchOverflow: false,\n\n // Round length\n roundLengths: false,\n\n // Touches\n touchRatio: 1,\n touchAngle: 45,\n simulateTouch: true,\n shortSwipes: true,\n longSwipes: true,\n longSwipesRatio: 0.5,\n longSwipesMs: 300,\n followFinger: true,\n allowTouchMove: true,\n threshold: 0,\n touchMoveStopPropagation: true,\n touchStartPreventDefault: true,\n touchStartForcePreventDefault: false,\n touchReleaseOnEdges: false,\n\n // Unique Navigation Elements\n uniqueNavElements: true,\n\n // Resistance\n resistance: true,\n resistanceRatio: 0.85,\n\n // Progress\n watchSlidesProgress: false,\n watchSlidesVisibility: false,\n\n // Cursor\n grabCursor: false,\n\n // Clicks\n preventClicks: true,\n preventClicksPropagation: true,\n slideToClickedSlide: false,\n\n // Images\n preloadImages: true,\n updateOnImagesReady: true,\n\n // loop\n loop: false,\n loopAdditionalSlides: 0,\n loopedSlides: null,\n loopFillGroupWithBlank: false,\n\n // Swiping/no swiping\n allowSlidePrev: true,\n allowSlideNext: true,\n swipeHandler: null, // '.swipe-handler',\n noSwiping: true,\n noSwipingClass: 'swiper-no-swiping',\n noSwipingSelector: null,\n\n // Passive Listeners\n passiveListeners: true,\n\n // NS\n containerModifierClass: 'swiper-container-', // NEW\n slideClass: 'swiper-slide',\n slideBlankClass: 'swiper-slide-invisible-blank',\n slideActiveClass: 'swiper-slide-active',\n slideDuplicateActiveClass: 'swiper-slide-duplicate-active',\n slideVisibleClass: 'swiper-slide-visible',\n slideDuplicateClass: 'swiper-slide-duplicate',\n slideNextClass: 'swiper-slide-next',\n slideDuplicateNextClass: 'swiper-slide-duplicate-next',\n slidePrevClass: 'swiper-slide-prev',\n slideDuplicatePrevClass: 'swiper-slide-duplicate-prev',\n wrapperClass: 'swiper-wrapper',\n\n // Callbacks\n runCallbacksOnInit: true,\n };\n\n /* eslint no-param-reassign: \"off\" */\n\n var prototypes = {\n update: update,\n translate: translate,\n transition: transition$1,\n slide: slide,\n loop: loop,\n grabCursor: grabCursor,\n manipulation: manipulation,\n events: events,\n breakpoints: breakpoints,\n checkOverflow: checkOverflow$1,\n classes: classes,\n images: images,\n };\n\n var extendedDefaults = {};\n\n var Swiper = /*@__PURE__*/(function (SwiperClass) {\n function Swiper() {\n var assign;\n\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n var el;\n var params;\n if (args.length === 1 && args[0].constructor && args[0].constructor === Object) {\n params = args[0];\n } else {\n (assign = args, el = assign[0], params = assign[1]);\n }\n if (!params) { params = {}; }\n\n params = Utils.extend({}, params);\n if (el && !params.el) { params.el = el; }\n\n SwiperClass.call(this, params);\n\n Object.keys(prototypes).forEach(function (prototypeGroup) {\n Object.keys(prototypes[prototypeGroup]).forEach(function (protoMethod) {\n if (!Swiper.prototype[protoMethod]) {\n Swiper.prototype[protoMethod] = prototypes[prototypeGroup][protoMethod];\n }\n });\n });\n\n // Swiper Instance\n var swiper = this;\n if (typeof swiper.modules === 'undefined') {\n swiper.modules = {};\n }\n Object.keys(swiper.modules).forEach(function (moduleName) {\n var module = swiper.modules[moduleName];\n if (module.params) {\n var moduleParamName = Object.keys(module.params)[0];\n var moduleParams = module.params[moduleParamName];\n if (typeof moduleParams !== 'object' || moduleParams === null) { return; }\n if (!(moduleParamName in params && 'enabled' in moduleParams)) { return; }\n if (params[moduleParamName] === true) {\n params[moduleParamName] = { enabled: true };\n }\n if (\n typeof params[moduleParamName] === 'object'\n && !('enabled' in params[moduleParamName])\n ) {\n params[moduleParamName].enabled = true;\n }\n if (!params[moduleParamName]) { params[moduleParamName] = { enabled: false }; }\n }\n });\n\n // Extend defaults with modules params\n var swiperParams = Utils.extend({}, defaults);\n swiper.useModulesParams(swiperParams);\n\n // Extend defaults with passed params\n swiper.params = Utils.extend({}, swiperParams, extendedDefaults, params);\n swiper.originalParams = Utils.extend({}, swiper.params);\n swiper.passedParams = Utils.extend({}, params);\n\n // Save Dom lib\n swiper.$ = $;\n\n // Find el\n var $el = $(swiper.params.el);\n el = $el[0];\n\n if (!el) {\n return undefined;\n }\n\n if ($el.length > 1) {\n var swipers = [];\n $el.each(function (index, containerEl) {\n var newParams = Utils.extend({}, params, { el: containerEl });\n swipers.push(new Swiper(newParams));\n });\n return swipers;\n }\n\n el.swiper = swiper;\n $el.data('swiper', swiper);\n\n // Find Wrapper\n var $wrapperEl = $el.children((\".\" + (swiper.params.wrapperClass)));\n\n // Extend Swiper\n Utils.extend(swiper, {\n $el: $el,\n el: el,\n $wrapperEl: $wrapperEl,\n wrapperEl: $wrapperEl[0],\n\n // Classes\n classNames: [],\n\n // Slides\n slides: $(),\n slidesGrid: [],\n snapGrid: [],\n slidesSizesGrid: [],\n\n // isDirection\n isHorizontal: function isHorizontal() {\n return swiper.params.direction === 'horizontal';\n },\n isVertical: function isVertical() {\n return swiper.params.direction === 'vertical';\n },\n // RTL\n rtl: (el.dir.toLowerCase() === 'rtl' || $el.css('direction') === 'rtl'),\n rtlTranslate: swiper.params.direction === 'horizontal' && (el.dir.toLowerCase() === 'rtl' || $el.css('direction') === 'rtl'),\n wrongRTL: $wrapperEl.css('display') === '-webkit-box',\n\n // Indexes\n activeIndex: 0,\n realIndex: 0,\n\n //\n isBeginning: true,\n isEnd: false,\n\n // Props\n translate: 0,\n previousTranslate: 0,\n progress: 0,\n velocity: 0,\n animating: false,\n\n // Locks\n allowSlideNext: swiper.params.allowSlideNext,\n allowSlidePrev: swiper.params.allowSlidePrev,\n\n // Touch Events\n touchEvents: (function touchEvents() {\n var touch = ['touchstart', 'touchmove', 'touchend'];\n var desktop = ['mousedown', 'mousemove', 'mouseup'];\n if (Support.pointerEvents) {\n desktop = ['pointerdown', 'pointermove', 'pointerup'];\n } else if (Support.prefixedPointerEvents) {\n desktop = ['MSPointerDown', 'MSPointerMove', 'MSPointerUp'];\n }\n swiper.touchEventsTouch = {\n start: touch[0],\n move: touch[1],\n end: touch[2],\n };\n swiper.touchEventsDesktop = {\n start: desktop[0],\n move: desktop[1],\n end: desktop[2],\n };\n return Support.touch || !swiper.params.simulateTouch ? swiper.touchEventsTouch : swiper.touchEventsDesktop;\n }()),\n touchEventsData: {\n isTouched: undefined,\n isMoved: undefined,\n allowTouchCallbacks: undefined,\n touchStartTime: undefined,\n isScrolling: undefined,\n currentTranslate: undefined,\n startTranslate: undefined,\n allowThresholdMove: undefined,\n // Form elements to match\n formElements: 'input, select, option, textarea, button, video',\n // Last click time\n lastClickTime: Utils.now(),\n clickTimeout: undefined,\n // Velocities\n velocities: [],\n allowMomentumBounce: undefined,\n isTouchEvent: undefined,\n startMoving: undefined,\n },\n\n // Clicks\n allowClick: true,\n\n // Touches\n allowTouchMove: swiper.params.allowTouchMove,\n\n touches: {\n startX: 0,\n startY: 0,\n currentX: 0,\n currentY: 0,\n diff: 0,\n },\n\n // Images\n imagesToLoad: [],\n imagesLoaded: 0,\n\n });\n\n // Install Modules\n swiper.useModules();\n\n // Init\n if (swiper.params.init) {\n swiper.init();\n }\n\n // Return app instance\n return swiper;\n }\n\n if ( SwiperClass ) Swiper.__proto__ = SwiperClass;\n Swiper.prototype = Object.create( SwiperClass && SwiperClass.prototype );\n Swiper.prototype.constructor = Swiper;\n\n var staticAccessors = { extendedDefaults: { configurable: true },defaults: { configurable: true },Class: { configurable: true },$: { configurable: true } };\n\n Swiper.prototype.slidesPerViewDynamic = function slidesPerViewDynamic () {\n var swiper = this;\n var params = swiper.params;\n var slides = swiper.slides;\n var slidesGrid = swiper.slidesGrid;\n var swiperSize = swiper.size;\n var activeIndex = swiper.activeIndex;\n var spv = 1;\n if (params.centeredSlides) {\n var slideSize = slides[activeIndex].swiperSlideSize;\n var breakLoop;\n for (var i = activeIndex + 1; i < slides.length; i += 1) {\n if (slides[i] && !breakLoop) {\n slideSize += slides[i].swiperSlideSize;\n spv += 1;\n if (slideSize > swiperSize) { breakLoop = true; }\n }\n }\n for (var i$1 = activeIndex - 1; i$1 >= 0; i$1 -= 1) {\n if (slides[i$1] && !breakLoop) {\n slideSize += slides[i$1].swiperSlideSize;\n spv += 1;\n if (slideSize > swiperSize) { breakLoop = true; }\n }\n }\n } else {\n for (var i$2 = activeIndex + 1; i$2 < slides.length; i$2 += 1) {\n if (slidesGrid[i$2] - slidesGrid[activeIndex] < swiperSize) {\n spv += 1;\n }\n }\n }\n return spv;\n };\n\n Swiper.prototype.update = function update () {\n var swiper = this;\n if (!swiper || swiper.destroyed) { return; }\n var snapGrid = swiper.snapGrid;\n var params = swiper.params;\n // Breakpoints\n if (params.breakpoints) {\n swiper.setBreakpoint();\n }\n swiper.updateSize();\n swiper.updateSlides();\n swiper.updateProgress();\n swiper.updateSlidesClasses();\n\n function setTranslate() {\n var translateValue = swiper.rtlTranslate ? swiper.translate * -1 : swiper.translate;\n var newTranslate = Math.min(Math.max(translateValue, swiper.maxTranslate()), swiper.minTranslate());\n swiper.setTranslate(newTranslate);\n swiper.updateActiveIndex();\n swiper.updateSlidesClasses();\n }\n var translated;\n if (swiper.params.freeMode) {\n setTranslate();\n if (swiper.params.autoHeight) {\n swiper.updateAutoHeight();\n }\n } else {\n if ((swiper.params.slidesPerView === 'auto' || swiper.params.slidesPerView > 1) && swiper.isEnd && !swiper.params.centeredSlides) {\n translated = swiper.slideTo(swiper.slides.length - 1, 0, false, true);\n } else {\n translated = swiper.slideTo(swiper.activeIndex, 0, false, true);\n }\n if (!translated) {\n setTranslate();\n }\n }\n if (params.watchOverflow && snapGrid !== swiper.snapGrid) {\n swiper.checkOverflow();\n }\n swiper.emit('update');\n };\n\n Swiper.prototype.changeDirection = function changeDirection (newDirection, needUpdate) {\n if ( needUpdate === void 0 ) needUpdate = true;\n\n var swiper = this;\n var currentDirection = swiper.params.direction;\n if (!newDirection) {\n // eslint-disable-next-line\n newDirection = currentDirection === 'horizontal' ? 'vertical' : 'horizontal';\n }\n if ((newDirection === currentDirection) || (newDirection !== 'horizontal' && newDirection !== 'vertical')) {\n return swiper;\n }\n\n swiper.$el\n .removeClass((\"\" + (swiper.params.containerModifierClass) + currentDirection + \" wp8-\" + currentDirection))\n .addClass((\"\" + (swiper.params.containerModifierClass) + newDirection));\n\n if ((Browser.isIE || Browser.isEdge) && (Support.pointerEvents || Support.prefixedPointerEvents)) {\n swiper.$el.addClass(((swiper.params.containerModifierClass) + \"wp8-\" + newDirection));\n }\n\n swiper.params.direction = newDirection;\n\n swiper.slides.each(function (slideIndex, slideEl) {\n if (newDirection === 'vertical') {\n slideEl.style.width = '';\n } else {\n slideEl.style.height = '';\n }\n });\n\n swiper.emit('changeDirection');\n if (needUpdate) { swiper.update(); }\n\n return swiper;\n };\n\n Swiper.prototype.init = function init () {\n var swiper = this;\n if (swiper.initialized) { return; }\n\n swiper.emit('beforeInit');\n\n // Set breakpoint\n if (swiper.params.breakpoints) {\n swiper.setBreakpoint();\n }\n\n // Add Classes\n swiper.addClasses();\n\n // Create loop\n if (swiper.params.loop) {\n swiper.loopCreate();\n }\n\n // Update size\n swiper.updateSize();\n\n // Update slides\n swiper.updateSlides();\n\n if (swiper.params.watchOverflow) {\n swiper.checkOverflow();\n }\n\n // Set Grab Cursor\n if (swiper.params.grabCursor) {\n swiper.setGrabCursor();\n }\n\n if (swiper.params.preloadImages) {\n swiper.preloadImages();\n }\n\n // Slide To Initial Slide\n if (swiper.params.loop) {\n swiper.slideTo(swiper.params.initialSlide + swiper.loopedSlides, 0, swiper.params.runCallbacksOnInit);\n } else {\n swiper.slideTo(swiper.params.initialSlide, 0, swiper.params.runCallbacksOnInit);\n }\n\n // Attach events\n swiper.attachEvents();\n\n // Init Flag\n swiper.initialized = true;\n\n // Emit\n swiper.emit('init');\n };\n\n Swiper.prototype.destroy = function destroy (deleteInstance, cleanStyles) {\n if ( deleteInstance === void 0 ) deleteInstance = true;\n if ( cleanStyles === void 0 ) cleanStyles = true;\n\n var swiper = this;\n var params = swiper.params;\n var $el = swiper.$el;\n var $wrapperEl = swiper.$wrapperEl;\n var slides = swiper.slides;\n\n if (typeof swiper.params === 'undefined' || swiper.destroyed) {\n return null;\n }\n\n swiper.emit('beforeDestroy');\n\n // Init Flag\n swiper.initialized = false;\n\n // Detach events\n swiper.detachEvents();\n\n // Destroy loop\n if (params.loop) {\n swiper.loopDestroy();\n }\n\n // Cleanup styles\n if (cleanStyles) {\n swiper.removeClasses();\n $el.removeAttr('style');\n $wrapperEl.removeAttr('style');\n if (slides && slides.length) {\n slides\n .removeClass([\n params.slideVisibleClass,\n params.slideActiveClass,\n params.slideNextClass,\n params.slidePrevClass ].join(' '))\n .removeAttr('style')\n .removeAttr('data-swiper-slide-index')\n .removeAttr('data-swiper-column')\n .removeAttr('data-swiper-row');\n }\n }\n\n swiper.emit('destroy');\n\n // Detach emitter events\n Object.keys(swiper.eventsListeners).forEach(function (eventName) {\n swiper.off(eventName);\n });\n\n if (deleteInstance !== false) {\n swiper.$el[0].swiper = null;\n swiper.$el.data('swiper', null);\n Utils.deleteProps(swiper);\n }\n swiper.destroyed = true;\n\n return null;\n };\n\n Swiper.extendDefaults = function extendDefaults (newDefaults) {\n Utils.extend(extendedDefaults, newDefaults);\n };\n\n staticAccessors.extendedDefaults.get = function () {\n return extendedDefaults;\n };\n\n staticAccessors.defaults.get = function () {\n return defaults;\n };\n\n staticAccessors.Class.get = function () {\n return SwiperClass;\n };\n\n staticAccessors.$.get = function () {\n return $;\n };\n\n Object.defineProperties( Swiper, staticAccessors );\n\n return Swiper;\n }(SwiperClass));\n\n var Device$1 = {\n name: 'device',\n proto: {\n device: Device,\n },\n static: {\n device: Device,\n },\n };\n\n var Support$1 = {\n name: 'support',\n proto: {\n support: Support,\n },\n static: {\n support: Support,\n },\n };\n\n var Browser$1 = {\n name: 'browser',\n proto: {\n browser: Browser,\n },\n static: {\n browser: Browser,\n },\n };\n\n var Resize = {\n name: 'resize',\n create: function create() {\n var swiper = this;\n Utils.extend(swiper, {\n resize: {\n resizeHandler: function resizeHandler() {\n if (!swiper || swiper.destroyed || !swiper.initialized) { return; }\n swiper.emit('beforeResize');\n swiper.emit('resize');\n },\n orientationChangeHandler: function orientationChangeHandler() {\n if (!swiper || swiper.destroyed || !swiper.initialized) { return; }\n swiper.emit('orientationchange');\n },\n },\n });\n },\n on: {\n init: function init() {\n var swiper = this;\n // Emit resize\n win.addEventListener('resize', swiper.resize.resizeHandler);\n\n // Emit orientationchange\n win.addEventListener('orientationchange', swiper.resize.orientationChangeHandler);\n },\n destroy: function destroy() {\n var swiper = this;\n win.removeEventListener('resize', swiper.resize.resizeHandler);\n win.removeEventListener('orientationchange', swiper.resize.orientationChangeHandler);\n },\n },\n };\n\n var Observer = {\n func: win.MutationObserver || win.WebkitMutationObserver,\n attach: function attach(target, options) {\n if ( options === void 0 ) options = {};\n\n var swiper = this;\n\n var ObserverFunc = Observer.func;\n var observer = new ObserverFunc(function (mutations) {\n // The observerUpdate event should only be triggered\n // once despite the number of mutations. Additional\n // triggers are redundant and are very costly\n if (mutations.length === 1) {\n swiper.emit('observerUpdate', mutations[0]);\n return;\n }\n var observerUpdate = function observerUpdate() {\n swiper.emit('observerUpdate', mutations[0]);\n };\n\n if (win.requestAnimationFrame) {\n win.requestAnimationFrame(observerUpdate);\n } else {\n win.setTimeout(observerUpdate, 0);\n }\n });\n\n observer.observe(target, {\n attributes: typeof options.attributes === 'undefined' ? true : options.attributes,\n childList: typeof options.childList === 'undefined' ? true : options.childList,\n characterData: typeof options.characterData === 'undefined' ? true : options.characterData,\n });\n\n swiper.observer.observers.push(observer);\n },\n init: function init() {\n var swiper = this;\n if (!Support.observer || !swiper.params.observer) { return; }\n if (swiper.params.observeParents) {\n var containerParents = swiper.$el.parents();\n for (var i = 0; i < containerParents.length; i += 1) {\n swiper.observer.attach(containerParents[i]);\n }\n }\n // Observe container\n swiper.observer.attach(swiper.$el[0], { childList: swiper.params.observeSlideChildren });\n\n // Observe wrapper\n swiper.observer.attach(swiper.$wrapperEl[0], { attributes: false });\n },\n destroy: function destroy() {\n var swiper = this;\n swiper.observer.observers.forEach(function (observer) {\n observer.disconnect();\n });\n swiper.observer.observers = [];\n },\n };\n\n var Observer$1 = {\n name: 'observer',\n params: {\n observer: false,\n observeParents: false,\n observeSlideChildren: false,\n },\n create: function create() {\n var swiper = this;\n Utils.extend(swiper, {\n observer: {\n init: Observer.init.bind(swiper),\n attach: Observer.attach.bind(swiper),\n destroy: Observer.destroy.bind(swiper),\n observers: [],\n },\n });\n },\n on: {\n init: function init() {\n var swiper = this;\n swiper.observer.init();\n },\n destroy: function destroy() {\n var swiper = this;\n swiper.observer.destroy();\n },\n },\n };\n\n var Virtual = {\n update: function update(force) {\n var swiper = this;\n var ref = swiper.params;\n var slidesPerView = ref.slidesPerView;\n var slidesPerGroup = ref.slidesPerGroup;\n var centeredSlides = ref.centeredSlides;\n var ref$1 = swiper.params.virtual;\n var addSlidesBefore = ref$1.addSlidesBefore;\n var addSlidesAfter = ref$1.addSlidesAfter;\n var ref$2 = swiper.virtual;\n var previousFrom = ref$2.from;\n var previousTo = ref$2.to;\n var slides = ref$2.slides;\n var previousSlidesGrid = ref$2.slidesGrid;\n var renderSlide = ref$2.renderSlide;\n var previousOffset = ref$2.offset;\n swiper.updateActiveIndex();\n var activeIndex = swiper.activeIndex || 0;\n\n var offsetProp;\n if (swiper.rtlTranslate) { offsetProp = 'right'; }\n else { offsetProp = swiper.isHorizontal() ? 'left' : 'top'; }\n\n var slidesAfter;\n var slidesBefore;\n if (centeredSlides) {\n slidesAfter = Math.floor(slidesPerView / 2) + slidesPerGroup + addSlidesBefore;\n slidesBefore = Math.floor(slidesPerView / 2) + slidesPerGroup + addSlidesAfter;\n } else {\n slidesAfter = slidesPerView + (slidesPerGroup - 1) + addSlidesBefore;\n slidesBefore = slidesPerGroup + addSlidesAfter;\n }\n var from = Math.max((activeIndex || 0) - slidesBefore, 0);\n var to = Math.min((activeIndex || 0) + slidesAfter, slides.length - 1);\n var offset = (swiper.slidesGrid[from] || 0) - (swiper.slidesGrid[0] || 0);\n\n Utils.extend(swiper.virtual, {\n from: from,\n to: to,\n offset: offset,\n slidesGrid: swiper.slidesGrid,\n });\n\n function onRendered() {\n swiper.updateSlides();\n swiper.updateProgress();\n swiper.updateSlidesClasses();\n if (swiper.lazy && swiper.params.lazy.enabled) {\n swiper.lazy.load();\n }\n }\n\n if (previousFrom === from && previousTo === to && !force) {\n if (swiper.slidesGrid !== previousSlidesGrid && offset !== previousOffset) {\n swiper.slides.css(offsetProp, (offset + \"px\"));\n }\n swiper.updateProgress();\n return;\n }\n if (swiper.params.virtual.renderExternal) {\n swiper.params.virtual.renderExternal.call(swiper, {\n offset: offset,\n from: from,\n to: to,\n slides: (function getSlides() {\n var slidesToRender = [];\n for (var i = from; i <= to; i += 1) {\n slidesToRender.push(slides[i]);\n }\n return slidesToRender;\n }()),\n });\n onRendered();\n return;\n }\n var prependIndexes = [];\n var appendIndexes = [];\n if (force) {\n swiper.$wrapperEl.find((\".\" + (swiper.params.slideClass))).remove();\n } else {\n for (var i = previousFrom; i <= previousTo; i += 1) {\n if (i < from || i > to) {\n swiper.$wrapperEl.find((\".\" + (swiper.params.slideClass) + \"[data-swiper-slide-index=\\\"\" + i + \"\\\"]\")).remove();\n }\n }\n }\n for (var i$1 = 0; i$1 < slides.length; i$1 += 1) {\n if (i$1 >= from && i$1 <= to) {\n if (typeof previousTo === 'undefined' || force) {\n appendIndexes.push(i$1);\n } else {\n if (i$1 > previousTo) { appendIndexes.push(i$1); }\n if (i$1 < previousFrom) { prependIndexes.push(i$1); }\n }\n }\n }\n appendIndexes.forEach(function (index) {\n swiper.$wrapperEl.append(renderSlide(slides[index], index));\n });\n prependIndexes.sort(function (a, b) { return b - a; }).forEach(function (index) {\n swiper.$wrapperEl.prepend(renderSlide(slides[index], index));\n });\n swiper.$wrapperEl.children('.swiper-slide').css(offsetProp, (offset + \"px\"));\n onRendered();\n },\n renderSlide: function renderSlide(slide, index) {\n var swiper = this;\n var params = swiper.params.virtual;\n if (params.cache && swiper.virtual.cache[index]) {\n return swiper.virtual.cache[index];\n }\n var $slideEl = params.renderSlide\n ? $(params.renderSlide.call(swiper, slide, index))\n : $((\"<div class=\\\"\" + (swiper.params.slideClass) + \"\\\" data-swiper-slide-index=\\\"\" + index + \"\\\">\" + slide + \"</div>\"));\n if (!$slideEl.attr('data-swiper-slide-index')) { $slideEl.attr('data-swiper-slide-index', index); }\n if (params.cache) { swiper.virtual.cache[index] = $slideEl; }\n return $slideEl;\n },\n appendSlide: function appendSlide(slides) {\n var swiper = this;\n if (typeof slides === 'object' && 'length' in slides) {\n for (var i = 0; i < slides.length; i += 1) {\n if (slides[i]) { swiper.virtual.slides.push(slides[i]); }\n }\n } else {\n swiper.virtual.slides.push(slides);\n }\n swiper.virtual.update(true);\n },\n prependSlide: function prependSlide(slides) {\n var swiper = this;\n var activeIndex = swiper.activeIndex;\n var newActiveIndex = activeIndex + 1;\n var numberOfNewSlides = 1;\n\n if (Array.isArray(slides)) {\n for (var i = 0; i < slides.length; i += 1) {\n if (slides[i]) { swiper.virtual.slides.unshift(slides[i]); }\n }\n newActiveIndex = activeIndex + slides.length;\n numberOfNewSlides = slides.length;\n } else {\n swiper.virtual.slides.unshift(slides);\n }\n if (swiper.params.virtual.cache) {\n var cache = swiper.virtual.cache;\n var newCache = {};\n Object.keys(cache).forEach(function (cachedIndex) {\n newCache[parseInt(cachedIndex, 10) + numberOfNewSlides] = cache[cachedIndex];\n });\n swiper.virtual.cache = newCache;\n }\n swiper.virtual.update(true);\n swiper.slideTo(newActiveIndex, 0);\n },\n removeSlide: function removeSlide(slidesIndexes) {\n var swiper = this;\n if (typeof slidesIndexes === 'undefined' || slidesIndexes === null) { return; }\n var activeIndex = swiper.activeIndex;\n if (Array.isArray(slidesIndexes)) {\n for (var i = slidesIndexes.length - 1; i >= 0; i -= 1) {\n swiper.virtual.slides.splice(slidesIndexes[i], 1);\n if (swiper.params.virtual.cache) {\n delete swiper.virtual.cache[slidesIndexes[i]];\n }\n if (slidesIndexes[i] < activeIndex) { activeIndex -= 1; }\n activeIndex = Math.max(activeIndex, 0);\n }\n } else {\n swiper.virtual.slides.splice(slidesIndexes, 1);\n if (swiper.params.virtual.cache) {\n delete swiper.virtual.cache[slidesIndexes];\n }\n if (slidesIndexes < activeIndex) { activeIndex -= 1; }\n activeIndex = Math.max(activeIndex, 0);\n }\n swiper.virtual.update(true);\n swiper.slideTo(activeIndex, 0);\n },\n removeAllSlides: function removeAllSlides() {\n var swiper = this;\n swiper.virtual.slides = [];\n if (swiper.params.virtual.cache) {\n swiper.virtual.cache = {};\n }\n swiper.virtual.update(true);\n swiper.slideTo(0, 0);\n },\n };\n\n var Virtual$1 = {\n name: 'virtual',\n params: {\n virtual: {\n enabled: false,\n slides: [],\n cache: true,\n renderSlide: null,\n renderExternal: null,\n addSlidesBefore: 0,\n addSlidesAfter: 0,\n },\n },\n create: function create() {\n var swiper = this;\n Utils.extend(swiper, {\n virtual: {\n update: Virtual.update.bind(swiper),\n appendSlide: Virtual.appendSlide.bind(swiper),\n prependSlide: Virtual.prependSlide.bind(swiper),\n removeSlide: Virtual.removeSlide.bind(swiper),\n removeAllSlides: Virtual.removeAllSlides.bind(swiper),\n renderSlide: Virtual.renderSlide.bind(swiper),\n slides: swiper.params.virtual.slides,\n cache: {},\n },\n });\n },\n on: {\n beforeInit: function beforeInit() {\n var swiper = this;\n if (!swiper.params.virtual.enabled) { return; }\n swiper.classNames.push(((swiper.params.containerModifierClass) + \"virtual\"));\n var overwriteParams = {\n watchSlidesProgress: true,\n };\n Utils.extend(swiper.params, overwriteParams);\n Utils.extend(swiper.originalParams, overwriteParams);\n\n if (!swiper.params.initialSlide) {\n swiper.virtual.update();\n }\n },\n setTranslate: function setTranslate() {\n var swiper = this;\n if (!swiper.params.virtual.enabled) { return; }\n swiper.virtual.update();\n },\n },\n };\n\n var Keyboard = {\n handle: function handle(event) {\n var swiper = this;\n var rtl = swiper.rtlTranslate;\n var e = event;\n if (e.originalEvent) { e = e.originalEvent; } // jquery fix\n var kc = e.keyCode || e.charCode;\n // Directions locks\n if (!swiper.allowSlideNext && ((swiper.isHorizontal() && kc === 39) || (swiper.isVertical() && kc === 40) || kc === 34)) {\n return false;\n }\n if (!swiper.allowSlidePrev && ((swiper.isHorizontal() && kc === 37) || (swiper.isVertical() && kc === 38) || kc === 33)) {\n return false;\n }\n if (e.shiftKey || e.altKey || e.ctrlKey || e.metaKey) {\n return undefined;\n }\n if (doc.activeElement && doc.activeElement.nodeName && (doc.activeElement.nodeName.toLowerCase() === 'input' || doc.activeElement.nodeName.toLowerCase() === 'textarea')) {\n return undefined;\n }\n if (swiper.params.keyboard.onlyInViewport && (kc === 33 || kc === 34 || kc === 37 || kc === 39 || kc === 38 || kc === 40)) {\n var inView = false;\n // Check that swiper should be inside of visible area of window\n if (swiper.$el.parents((\".\" + (swiper.params.slideClass))).length > 0 && swiper.$el.parents((\".\" + (swiper.params.slideActiveClass))).length === 0) {\n return undefined;\n }\n var windowWidth = win.innerWidth;\n var windowHeight = win.innerHeight;\n var swiperOffset = swiper.$el.offset();\n if (rtl) { swiperOffset.left -= swiper.$el[0].scrollLeft; }\n var swiperCoord = [\n [swiperOffset.left, swiperOffset.top],\n [swiperOffset.left + swiper.width, swiperOffset.top],\n [swiperOffset.left, swiperOffset.top + swiper.height],\n [swiperOffset.left + swiper.width, swiperOffset.top + swiper.height] ];\n for (var i = 0; i < swiperCoord.length; i += 1) {\n var point = swiperCoord[i];\n if (\n point[0] >= 0 && point[0] <= windowWidth\n && point[1] >= 0 && point[1] <= windowHeight\n ) {\n inView = true;\n }\n }\n if (!inView) { return undefined; }\n }\n if (swiper.isHorizontal()) {\n if (kc === 33 || kc === 34 || kc === 37 || kc === 39) {\n if (e.preventDefault) { e.preventDefault(); }\n else { e.returnValue = false; }\n }\n if (((kc === 34 || kc === 39) && !rtl) || ((kc === 33 || kc === 37) && rtl)) { swiper.slideNext(); }\n if (((kc === 33 || kc === 37) && !rtl) || ((kc === 34 || kc === 39) && rtl)) { swiper.slidePrev(); }\n } else {\n if (kc === 33 || kc === 34 || kc === 38 || kc === 40) {\n if (e.preventDefault) { e.preventDefault(); }\n else { e.returnValue = false; }\n }\n if (kc === 34 || kc === 40) { swiper.slideNext(); }\n if (kc === 33 || kc === 38) { swiper.slidePrev(); }\n }\n swiper.emit('keyPress', kc);\n return undefined;\n },\n enable: function enable() {\n var swiper = this;\n if (swiper.keyboard.enabled) { return; }\n $(doc).on('keydown', swiper.keyboard.handle);\n swiper.keyboard.enabled = true;\n },\n disable: function disable() {\n var swiper = this;\n if (!swiper.keyboard.enabled) { return; }\n $(doc).off('keydown', swiper.keyboard.handle);\n swiper.keyboard.enabled = false;\n },\n };\n\n var Keyboard$1 = {\n name: 'keyboard',\n params: {\n keyboard: {\n enabled: false,\n onlyInViewport: true,\n },\n },\n create: function create() {\n var swiper = this;\n Utils.extend(swiper, {\n keyboard: {\n enabled: false,\n enable: Keyboard.enable.bind(swiper),\n disable: Keyboard.disable.bind(swiper),\n handle: Keyboard.handle.bind(swiper),\n },\n });\n },\n on: {\n init: function init() {\n var swiper = this;\n if (swiper.params.keyboard.enabled) {\n swiper.keyboard.enable();\n }\n },\n destroy: function destroy() {\n var swiper = this;\n if (swiper.keyboard.enabled) {\n swiper.keyboard.disable();\n }\n },\n },\n };\n\n function isEventSupported() {\n var eventName = 'onwheel';\n var isSupported = eventName in doc;\n\n if (!isSupported) {\n var element = doc.createElement('div');\n element.setAttribute(eventName, 'return;');\n isSupported = typeof element[eventName] === 'function';\n }\n\n if (!isSupported\n && doc.implementation\n && doc.implementation.hasFeature\n // always returns true in newer browsers as per the standard.\n // @see http://dom.spec.whatwg.org/#dom-domimplementation-hasfeature\n && doc.implementation.hasFeature('', '') !== true\n ) {\n // This is the only way to test support for the `wheel` event in IE9+.\n isSupported = doc.implementation.hasFeature('Events.wheel', '3.0');\n }\n\n return isSupported;\n }\n var Mousewheel = {\n lastScrollTime: Utils.now(),\n event: (function getEvent() {\n if (win.navigator.userAgent.indexOf('firefox') > -1) { return 'DOMMouseScroll'; }\n return isEventSupported() ? 'wheel' : 'mousewheel';\n }()),\n normalize: function normalize(e) {\n // Reasonable defaults\n var PIXEL_STEP = 10;\n var LINE_HEIGHT = 40;\n var PAGE_HEIGHT = 800;\n\n var sX = 0;\n var sY = 0; // spinX, spinY\n var pX = 0;\n var pY = 0; // pixelX, pixelY\n\n // Legacy\n if ('detail' in e) {\n sY = e.detail;\n }\n if ('wheelDelta' in e) {\n sY = -e.wheelDelta / 120;\n }\n if ('wheelDeltaY' in e) {\n sY = -e.wheelDeltaY / 120;\n }\n if ('wheelDeltaX' in e) {\n sX = -e.wheelDeltaX / 120;\n }\n\n // side scrolling on FF with DOMMouseScroll\n if ('axis' in e && e.axis === e.HORIZONTAL_AXIS) {\n sX = sY;\n sY = 0;\n }\n\n pX = sX * PIXEL_STEP;\n pY = sY * PIXEL_STEP;\n\n if ('deltaY' in e) {\n pY = e.deltaY;\n }\n if ('deltaX' in e) {\n pX = e.deltaX;\n }\n\n if ((pX || pY) && e.deltaMode) {\n if (e.deltaMode === 1) { // delta in LINE units\n pX *= LINE_HEIGHT;\n pY *= LINE_HEIGHT;\n } else { // delta in PAGE units\n pX *= PAGE_HEIGHT;\n pY *= PAGE_HEIGHT;\n }\n }\n\n // Fall-back if spin cannot be determined\n if (pX && !sX) {\n sX = (pX < 1) ? -1 : 1;\n }\n if (pY && !sY) {\n sY = (pY < 1) ? -1 : 1;\n }\n\n return {\n spinX: sX,\n spinY: sY,\n pixelX: pX,\n pixelY: pY,\n };\n },\n handleMouseEnter: function handleMouseEnter() {\n var swiper = this;\n swiper.mouseEntered = true;\n },\n handleMouseLeave: function handleMouseLeave() {\n var swiper = this;\n swiper.mouseEntered = false;\n },\n handle: function handle(event) {\n var e = event;\n var swiper = this;\n var params = swiper.params.mousewheel;\n\n if (!swiper.mouseEntered && !params.releaseOnEdges) { return true; }\n\n if (e.originalEvent) { e = e.originalEvent; } // jquery fix\n var delta = 0;\n var rtlFactor = swiper.rtlTranslate ? -1 : 1;\n\n var data = Mousewheel.normalize(e);\n\n if (params.forceToAxis) {\n if (swiper.isHorizontal()) {\n if (Math.abs(data.pixelX) > Math.abs(data.pixelY)) { delta = data.pixelX * rtlFactor; }\n else { return true; }\n } else if (Math.abs(data.pixelY) > Math.abs(data.pixelX)) { delta = data.pixelY; }\n else { return true; }\n } else {\n delta = Math.abs(data.pixelX) > Math.abs(data.pixelY) ? -data.pixelX * rtlFactor : -data.pixelY;\n }\n\n if (delta === 0) { return true; }\n\n if (params.invert) { delta = -delta; }\n\n if (!swiper.params.freeMode) {\n if (Utils.now() - swiper.mousewheel.lastScrollTime > 60) {\n if (delta < 0) {\n if ((!swiper.isEnd || swiper.params.loop) && !swiper.animating) {\n swiper.slideNext();\n swiper.emit('scroll', e);\n } else if (params.releaseOnEdges) { return true; }\n } else if ((!swiper.isBeginning || swiper.params.loop) && !swiper.animating) {\n swiper.slidePrev();\n swiper.emit('scroll', e);\n } else if (params.releaseOnEdges) { return true; }\n }\n swiper.mousewheel.lastScrollTime = (new win.Date()).getTime();\n } else {\n // Freemode or scrollContainer:\n if (swiper.params.loop) {\n swiper.loopFix();\n }\n var position = swiper.getTranslate() + (delta * params.sensitivity);\n var wasBeginning = swiper.isBeginning;\n var wasEnd = swiper.isEnd;\n\n if (position >= swiper.minTranslate()) { position = swiper.minTranslate(); }\n if (position <= swiper.maxTranslate()) { position = swiper.maxTranslate(); }\n\n swiper.setTransition(0);\n swiper.setTranslate(position);\n swiper.updateProgress();\n swiper.updateActiveIndex();\n swiper.updateSlidesClasses();\n\n if ((!wasBeginning && swiper.isBeginning) || (!wasEnd && swiper.isEnd)) {\n swiper.updateSlidesClasses();\n }\n\n if (swiper.params.freeModeSticky) {\n clearTimeout(swiper.mousewheel.timeout);\n swiper.mousewheel.timeout = Utils.nextTick(function () {\n swiper.slideToClosest();\n }, 300);\n }\n // Emit event\n swiper.emit('scroll', e);\n\n // Stop autoplay\n if (swiper.params.autoplay && swiper.params.autoplayDisableOnInteraction) { swiper.autoplay.stop(); }\n // Return page scroll on edge positions\n if (position === swiper.minTranslate() || position === swiper.maxTranslate()) { return true; }\n }\n\n if (e.preventDefault) { e.preventDefault(); }\n else { e.returnValue = false; }\n return false;\n },\n enable: function enable() {\n var swiper = this;\n if (!Mousewheel.event) { return false; }\n if (swiper.mousewheel.enabled) { return false; }\n var target = swiper.$el;\n if (swiper.params.mousewheel.eventsTarged !== 'container') {\n target = $(swiper.params.mousewheel.eventsTarged);\n }\n target.on('mouseenter', swiper.mousewheel.handleMouseEnter);\n target.on('mouseleave', swiper.mousewheel.handleMouseLeave);\n target.on(Mousewheel.event, swiper.mousewheel.handle);\n swiper.mousewheel.enabled = true;\n return true;\n },\n disable: function disable() {\n var swiper = this;\n if (!Mousewheel.event) { return false; }\n if (!swiper.mousewheel.enabled) { return false; }\n var target = swiper.$el;\n if (swiper.params.mousewheel.eventsTarged !== 'container') {\n target = $(swiper.params.mousewheel.eventsTarged);\n }\n target.off(Mousewheel.event, swiper.mousewheel.handle);\n swiper.mousewheel.enabled = false;\n return true;\n },\n };\n\n var Mousewheel$1 = {\n name: 'mousewheel',\n params: {\n mousewheel: {\n enabled: false,\n releaseOnEdges: false,\n invert: false,\n forceToAxis: false,\n sensitivity: 1,\n eventsTarged: 'container',\n },\n },\n create: function create() {\n var swiper = this;\n Utils.extend(swiper, {\n mousewheel: {\n enabled: false,\n enable: Mousewheel.enable.bind(swiper),\n disable: Mousewheel.disable.bind(swiper),\n handle: Mousewheel.handle.bind(swiper),\n handleMouseEnter: Mousewheel.handleMouseEnter.bind(swiper),\n handleMouseLeave: Mousewheel.handleMouseLeave.bind(swiper),\n lastScrollTime: Utils.now(),\n },\n });\n },\n on: {\n init: function init() {\n var swiper = this;\n if (swiper.params.mousewheel.enabled) { swiper.mousewheel.enable(); }\n },\n destroy: function destroy() {\n var swiper = this;\n if (swiper.mousewheel.enabled) { swiper.mousewheel.disable(); }\n },\n },\n };\n\n var Navigation = {\n update: function update() {\n // Update Navigation Buttons\n var swiper = this;\n var params = swiper.params.navigation;\n\n if (swiper.params.loop) { return; }\n var ref = swiper.navigation;\n var $nextEl = ref.$nextEl;\n var $prevEl = ref.$prevEl;\n\n if ($prevEl && $prevEl.length > 0) {\n if (swiper.isBeginning) {\n $prevEl.addClass(params.disabledClass);\n } else {\n $prevEl.removeClass(params.disabledClass);\n }\n $prevEl[swiper.params.watchOverflow && swiper.isLocked ? 'addClass' : 'removeClass'](params.lockClass);\n }\n if ($nextEl && $nextEl.length > 0) {\n if (swiper.isEnd) {\n $nextEl.addClass(params.disabledClass);\n } else {\n $nextEl.removeClass(params.disabledClass);\n }\n $nextEl[swiper.params.watchOverflow && swiper.isLocked ? 'addClass' : 'removeClass'](params.lockClass);\n }\n },\n onPrevClick: function onPrevClick(e) {\n var swiper = this;\n e.preventDefault();\n if (swiper.isBeginning && !swiper.params.loop) { return; }\n swiper.slidePrev();\n },\n onNextClick: function onNextClick(e) {\n var swiper = this;\n e.preventDefault();\n if (swiper.isEnd && !swiper.params.loop) { return; }\n swiper.slideNext();\n },\n init: function init() {\n var swiper = this;\n var params = swiper.params.navigation;\n if (!(params.nextEl || params.prevEl)) { return; }\n\n var $nextEl;\n var $prevEl;\n if (params.nextEl) {\n $nextEl = $(params.nextEl);\n if (\n swiper.params.uniqueNavElements\n && typeof params.nextEl === 'string'\n && $nextEl.length > 1\n && swiper.$el.find(params.nextEl).length === 1\n ) {\n $nextEl = swiper.$el.find(params.nextEl);\n }\n }\n if (params.prevEl) {\n $prevEl = $(params.prevEl);\n if (\n swiper.params.uniqueNavElements\n && typeof params.prevEl === 'string'\n && $prevEl.length > 1\n && swiper.$el.find(params.prevEl).length === 1\n ) {\n $prevEl = swiper.$el.find(params.prevEl);\n }\n }\n\n if ($nextEl && $nextEl.length > 0) {\n $nextEl.on('click', swiper.navigation.onNextClick);\n }\n if ($prevEl && $prevEl.length > 0) {\n $prevEl.on('click', swiper.navigation.onPrevClick);\n }\n\n Utils.extend(swiper.navigation, {\n $nextEl: $nextEl,\n nextEl: $nextEl && $nextEl[0],\n $prevEl: $prevEl,\n prevEl: $prevEl && $prevEl[0],\n });\n },\n destroy: function destroy() {\n var swiper = this;\n var ref = swiper.navigation;\n var $nextEl = ref.$nextEl;\n var $prevEl = ref.$prevEl;\n if ($nextEl && $nextEl.length) {\n $nextEl.off('click', swiper.navigation.onNextClick);\n $nextEl.removeClass(swiper.params.navigation.disabledClass);\n }\n if ($prevEl && $prevEl.length) {\n $prevEl.off('click', swiper.navigation.onPrevClick);\n $prevEl.removeClass(swiper.params.navigation.disabledClass);\n }\n },\n };\n\n var Navigation$1 = {\n name: 'navigation',\n params: {\n navigation: {\n nextEl: null,\n prevEl: null,\n\n hideOnClick: false,\n disabledClass: 'swiper-button-disabled',\n hiddenClass: 'swiper-button-hidden',\n lockClass: 'swiper-button-lock',\n },\n },\n create: function create() {\n var swiper = this;\n Utils.extend(swiper, {\n navigation: {\n init: Navigation.init.bind(swiper),\n update: Navigation.update.bind(swiper),\n destroy: Navigation.destroy.bind(swiper),\n onNextClick: Navigation.onNextClick.bind(swiper),\n onPrevClick: Navigation.onPrevClick.bind(swiper),\n },\n });\n },\n on: {\n init: function init() {\n var swiper = this;\n swiper.navigation.init();\n swiper.navigation.update();\n },\n toEdge: function toEdge() {\n var swiper = this;\n swiper.navigation.update();\n },\n fromEdge: function fromEdge() {\n var swiper = this;\n swiper.navigation.update();\n },\n destroy: function destroy() {\n var swiper = this;\n swiper.navigation.destroy();\n },\n click: function click(e) {\n var swiper = this;\n var ref = swiper.navigation;\n var $nextEl = ref.$nextEl;\n var $prevEl = ref.$prevEl;\n if (\n swiper.params.navigation.hideOnClick\n && !$(e.target).is($prevEl)\n && !$(e.target).is($nextEl)\n ) {\n var isHidden;\n if ($nextEl) {\n isHidden = $nextEl.hasClass(swiper.params.navigation.hiddenClass);\n } else if ($prevEl) {\n isHidden = $prevEl.hasClass(swiper.params.navigation.hiddenClass);\n }\n if (isHidden === true) {\n swiper.emit('navigationShow', swiper);\n } else {\n swiper.emit('navigationHide', swiper);\n }\n if ($nextEl) {\n $nextEl.toggleClass(swiper.params.navigation.hiddenClass);\n }\n if ($prevEl) {\n $prevEl.toggleClass(swiper.params.navigation.hiddenClass);\n }\n }\n },\n },\n };\n\n var Pagination = {\n update: function update() {\n // Render || Update Pagination bullets/items\n var swiper = this;\n var rtl = swiper.rtl;\n var params = swiper.params.pagination;\n if (!params.el || !swiper.pagination.el || !swiper.pagination.$el || swiper.pagination.$el.length === 0) { return; }\n var slidesLength = swiper.virtual && swiper.params.virtual.enabled ? swiper.virtual.slides.length : swiper.slides.length;\n var $el = swiper.pagination.$el;\n // Current/Total\n var current;\n var total = swiper.params.loop ? Math.ceil((slidesLength - (swiper.loopedSlides * 2)) / swiper.params.slidesPerGroup) : swiper.snapGrid.length;\n if (swiper.params.loop) {\n current = Math.ceil((swiper.activeIndex - swiper.loopedSlides) / swiper.params.slidesPerGroup);\n if (current > slidesLength - 1 - (swiper.loopedSlides * 2)) {\n current -= (slidesLength - (swiper.loopedSlides * 2));\n }\n if (current > total - 1) { current -= total; }\n if (current < 0 && swiper.params.paginationType !== 'bullets') { current = total + current; }\n } else if (typeof swiper.snapIndex !== 'undefined') {\n current = swiper.snapIndex;\n } else {\n current = swiper.activeIndex || 0;\n }\n // Types\n if (params.type === 'bullets' && swiper.pagination.bullets && swiper.pagination.bullets.length > 0) {\n var bullets = swiper.pagination.bullets;\n var firstIndex;\n var lastIndex;\n var midIndex;\n if (params.dynamicBullets) {\n swiper.pagination.bulletSize = bullets.eq(0)[swiper.isHorizontal() ? 'outerWidth' : 'outerHeight'](true);\n $el.css(swiper.isHorizontal() ? 'width' : 'height', ((swiper.pagination.bulletSize * (params.dynamicMainBullets + 4)) + \"px\"));\n if (params.dynamicMainBullets > 1 && swiper.previousIndex !== undefined) {\n swiper.pagination.dynamicBulletIndex += (current - swiper.previousIndex);\n if (swiper.pagination.dynamicBulletIndex > (params.dynamicMainBullets - 1)) {\n swiper.pagination.dynamicBulletIndex = params.dynamicMainBullets - 1;\n } else if (swiper.pagination.dynamicBulletIndex < 0) {\n swiper.pagination.dynamicBulletIndex = 0;\n }\n }\n firstIndex = current - swiper.pagination.dynamicBulletIndex;\n lastIndex = firstIndex + (Math.min(bullets.length, params.dynamicMainBullets) - 1);\n midIndex = (lastIndex + firstIndex) / 2;\n }\n bullets.removeClass(((params.bulletActiveClass) + \" \" + (params.bulletActiveClass) + \"-next \" + (params.bulletActiveClass) + \"-next-next \" + (params.bulletActiveClass) + \"-prev \" + (params.bulletActiveClass) + \"-prev-prev \" + (params.bulletActiveClass) + \"-main\"));\n if ($el.length > 1) {\n bullets.each(function (index, bullet) {\n var $bullet = $(bullet);\n var bulletIndex = $bullet.index();\n if (bulletIndex === current) {\n $bullet.addClass(params.bulletActiveClass);\n }\n if (params.dynamicBullets) {\n if (bulletIndex >= firstIndex && bulletIndex <= lastIndex) {\n $bullet.addClass(((params.bulletActiveClass) + \"-main\"));\n }\n if (bulletIndex === firstIndex) {\n $bullet\n .prev()\n .addClass(((params.bulletActiveClass) + \"-prev\"))\n .prev()\n .addClass(((params.bulletActiveClass) + \"-prev-prev\"));\n }\n if (bulletIndex === lastIndex) {\n $bullet\n .next()\n .addClass(((params.bulletActiveClass) + \"-next\"))\n .next()\n .addClass(((params.bulletActiveClass) + \"-next-next\"));\n }\n }\n });\n } else {\n var $bullet = bullets.eq(current);\n $bullet.addClass(params.bulletActiveClass);\n if (params.dynamicBullets) {\n var $firstDisplayedBullet = bullets.eq(firstIndex);\n var $lastDisplayedBullet = bullets.eq(lastIndex);\n for (var i = firstIndex; i <= lastIndex; i += 1) {\n bullets.eq(i).addClass(((params.bulletActiveClass) + \"-main\"));\n }\n $firstDisplayedBullet\n .prev()\n .addClass(((params.bulletActiveClass) + \"-prev\"))\n .prev()\n .addClass(((params.bulletActiveClass) + \"-prev-prev\"));\n $lastDisplayedBullet\n .next()\n .addClass(((params.bulletActiveClass) + \"-next\"))\n .next()\n .addClass(((params.bulletActiveClass) + \"-next-next\"));\n }\n }\n if (params.dynamicBullets) {\n var dynamicBulletsLength = Math.min(bullets.length, params.dynamicMainBullets + 4);\n var bulletsOffset = (((swiper.pagination.bulletSize * dynamicBulletsLength) - (swiper.pagination.bulletSize)) / 2) - (midIndex * swiper.pagination.bulletSize);\n var offsetProp = rtl ? 'right' : 'left';\n bullets.css(swiper.isHorizontal() ? offsetProp : 'top', (bulletsOffset + \"px\"));\n }\n }\n if (params.type === 'fraction') {\n $el.find((\".\" + (params.currentClass))).text(params.formatFractionCurrent(current + 1));\n $el.find((\".\" + (params.totalClass))).text(params.formatFractionTotal(total));\n }\n if (params.type === 'progressbar') {\n var progressbarDirection;\n if (params.progressbarOpposite) {\n progressbarDirection = swiper.isHorizontal() ? 'vertical' : 'horizontal';\n } else {\n progressbarDirection = swiper.isHorizontal() ? 'horizontal' : 'vertical';\n }\n var scale = (current + 1) / total;\n var scaleX = 1;\n var scaleY = 1;\n if (progressbarDirection === 'horizontal') {\n scaleX = scale;\n } else {\n scaleY = scale;\n }\n $el.find((\".\" + (params.progressbarFillClass))).transform((\"translate3d(0,0,0) scaleX(\" + scaleX + \") scaleY(\" + scaleY + \")\")).transition(swiper.params.speed);\n }\n if (params.type === 'custom' && params.renderCustom) {\n $el.html(params.renderCustom(swiper, current + 1, total));\n swiper.emit('paginationRender', swiper, $el[0]);\n } else {\n swiper.emit('paginationUpdate', swiper, $el[0]);\n }\n $el[swiper.params.watchOverflow && swiper.isLocked ? 'addClass' : 'removeClass'](params.lockClass);\n },\n render: function render() {\n // Render Container\n var swiper = this;\n var params = swiper.params.pagination;\n if (!params.el || !swiper.pagination.el || !swiper.pagination.$el || swiper.pagination.$el.length === 0) { return; }\n var slidesLength = swiper.virtual && swiper.params.virtual.enabled ? swiper.virtual.slides.length : swiper.slides.length;\n\n var $el = swiper.pagination.$el;\n var paginationHTML = '';\n if (params.type === 'bullets') {\n var numberOfBullets = swiper.params.loop ? Math.ceil((slidesLength - (swiper.loopedSlides * 2)) / swiper.params.slidesPerGroup) : swiper.snapGrid.length;\n for (var i = 0; i < numberOfBullets; i += 1) {\n if (params.renderBullet) {\n paginationHTML += params.renderBullet.call(swiper, i, params.bulletClass);\n } else {\n paginationHTML += \"<\" + (params.bulletElement) + \" class=\\\"\" + (params.bulletClass) + \"\\\"></\" + (params.bulletElement) + \">\";\n }\n }\n $el.html(paginationHTML);\n swiper.pagination.bullets = $el.find((\".\" + (params.bulletClass)));\n }\n if (params.type === 'fraction') {\n if (params.renderFraction) {\n paginationHTML = params.renderFraction.call(swiper, params.currentClass, params.totalClass);\n } else {\n paginationHTML = \"<span class=\\\"\" + (params.currentClass) + \"\\\"></span>\"\n + ' / '\n + \"<span class=\\\"\" + (params.totalClass) + \"\\\"></span>\";\n }\n $el.html(paginationHTML);\n }\n if (params.type === 'progressbar') {\n if (params.renderProgressbar) {\n paginationHTML = params.renderProgressbar.call(swiper, params.progressbarFillClass);\n } else {\n paginationHTML = \"<span class=\\\"\" + (params.progressbarFillClass) + \"\\\"></span>\";\n }\n $el.html(paginationHTML);\n }\n if (params.type !== 'custom') {\n swiper.emit('paginationRender', swiper.pagination.$el[0]);\n }\n },\n init: function init() {\n var swiper = this;\n var params = swiper.params.pagination;\n if (!params.el) { return; }\n\n var $el = $(params.el);\n if ($el.length === 0) { return; }\n\n if (\n swiper.params.uniqueNavElements\n && typeof params.el === 'string'\n && $el.length > 1\n && swiper.$el.find(params.el).length === 1\n ) {\n $el = swiper.$el.find(params.el);\n }\n\n if (params.type === 'bullets' && params.clickable) {\n $el.addClass(params.clickableClass);\n }\n\n $el.addClass(params.modifierClass + params.type);\n\n if (params.type === 'bullets' && params.dynamicBullets) {\n $el.addClass((\"\" + (params.modifierClass) + (params.type) + \"-dynamic\"));\n swiper.pagination.dynamicBulletIndex = 0;\n if (params.dynamicMainBullets < 1) {\n params.dynamicMainBullets = 1;\n }\n }\n if (params.type === 'progressbar' && params.progressbarOpposite) {\n $el.addClass(params.progressbarOppositeClass);\n }\n\n if (params.clickable) {\n $el.on('click', (\".\" + (params.bulletClass)), function onClick(e) {\n e.preventDefault();\n var index = $(this).index() * swiper.params.slidesPerGroup;\n if (swiper.params.loop) { index += swiper.loopedSlides; }\n swiper.slideTo(index);\n });\n }\n\n Utils.extend(swiper.pagination, {\n $el: $el,\n el: $el[0],\n });\n },\n destroy: function destroy() {\n var swiper = this;\n var params = swiper.params.pagination;\n if (!params.el || !swiper.pagination.el || !swiper.pagination.$el || swiper.pagination.$el.length === 0) { return; }\n var $el = swiper.pagination.$el;\n\n $el.removeClass(params.hiddenClass);\n $el.removeClass(params.modifierClass + params.type);\n if (swiper.pagination.bullets) { swiper.pagination.bullets.removeClass(params.bulletActiveClass); }\n if (params.clickable) {\n $el.off('click', (\".\" + (params.bulletClass)));\n }\n },\n };\n\n var Pagination$1 = {\n name: 'pagination',\n params: {\n pagination: {\n el: null,\n bulletElement: 'span',\n clickable: false,\n hideOnClick: false,\n renderBullet: null,\n renderProgressbar: null,\n renderFraction: null,\n renderCustom: null,\n progressbarOpposite: false,\n type: 'bullets', // 'bullets' or 'progressbar' or 'fraction' or 'custom'\n dynamicBullets: false,\n dynamicMainBullets: 1,\n formatFractionCurrent: function (number) { return number; },\n formatFractionTotal: function (number) { return number; },\n bulletClass: 'swiper-pagination-bullet',\n bulletActiveClass: 'swiper-pagination-bullet-active',\n modifierClass: 'swiper-pagination-', // NEW\n currentClass: 'swiper-pagination-current',\n totalClass: 'swiper-pagination-total',\n hiddenClass: 'swiper-pagination-hidden',\n progressbarFillClass: 'swiper-pagination-progressbar-fill',\n progressbarOppositeClass: 'swiper-pagination-progressbar-opposite',\n clickableClass: 'swiper-pagination-clickable', // NEW\n lockClass: 'swiper-pagination-lock',\n },\n },\n create: function create() {\n var swiper = this;\n Utils.extend(swiper, {\n pagination: {\n init: Pagination.init.bind(swiper),\n render: Pagination.render.bind(swiper),\n update: Pagination.update.bind(swiper),\n destroy: Pagination.destroy.bind(swiper),\n dynamicBulletIndex: 0,\n },\n });\n },\n on: {\n init: function init() {\n var swiper = this;\n swiper.pagination.init();\n swiper.pagination.render();\n swiper.pagination.update();\n },\n activeIndexChange: function activeIndexChange() {\n var swiper = this;\n if (swiper.params.loop) {\n swiper.pagination.update();\n } else if (typeof swiper.snapIndex === 'undefined') {\n swiper.pagination.update();\n }\n },\n snapIndexChange: function snapIndexChange() {\n var swiper = this;\n if (!swiper.params.loop) {\n swiper.pagination.update();\n }\n },\n slidesLengthChange: function slidesLengthChange() {\n var swiper = this;\n if (swiper.params.loop) {\n swiper.pagination.render();\n swiper.pagination.update();\n }\n },\n snapGridLengthChange: function snapGridLengthChange() {\n var swiper = this;\n if (!swiper.params.loop) {\n swiper.pagination.render();\n swiper.pagination.update();\n }\n },\n destroy: function destroy() {\n var swiper = this;\n swiper.pagination.destroy();\n },\n click: function click(e) {\n var swiper = this;\n if (\n swiper.params.pagination.el\n && swiper.params.pagination.hideOnClick\n && swiper.pagination.$el.length > 0\n && !$(e.target).hasClass(swiper.params.pagination.bulletClass)\n ) {\n var isHidden = swiper.pagination.$el.hasClass(swiper.params.pagination.hiddenClass);\n if (isHidden === true) {\n swiper.emit('paginationShow', swiper);\n } else {\n swiper.emit('paginationHide', swiper);\n }\n swiper.pagination.$el.toggleClass(swiper.params.pagination.hiddenClass);\n }\n },\n },\n };\n\n var Scrollbar = {\n setTranslate: function setTranslate() {\n var swiper = this;\n if (!swiper.params.scrollbar.el || !swiper.scrollbar.el) { return; }\n var scrollbar = swiper.scrollbar;\n var rtl = swiper.rtlTranslate;\n var progress = swiper.progress;\n var dragSize = scrollbar.dragSize;\n var trackSize = scrollbar.trackSize;\n var $dragEl = scrollbar.$dragEl;\n var $el = scrollbar.$el;\n var params = swiper.params.scrollbar;\n\n var newSize = dragSize;\n var newPos = (trackSize - dragSize) * progress;\n if (rtl) {\n newPos = -newPos;\n if (newPos > 0) {\n newSize = dragSize - newPos;\n newPos = 0;\n } else if (-newPos + dragSize > trackSize) {\n newSize = trackSize + newPos;\n }\n } else if (newPos < 0) {\n newSize = dragSize + newPos;\n newPos = 0;\n } else if (newPos + dragSize > trackSize) {\n newSize = trackSize - newPos;\n }\n if (swiper.isHorizontal()) {\n if (Support.transforms3d) {\n $dragEl.transform((\"translate3d(\" + newPos + \"px, 0, 0)\"));\n } else {\n $dragEl.transform((\"translateX(\" + newPos + \"px)\"));\n }\n $dragEl[0].style.width = newSize + \"px\";\n } else {\n if (Support.transforms3d) {\n $dragEl.transform((\"translate3d(0px, \" + newPos + \"px, 0)\"));\n } else {\n $dragEl.transform((\"translateY(\" + newPos + \"px)\"));\n }\n $dragEl[0].style.height = newSize + \"px\";\n }\n if (params.hide) {\n clearTimeout(swiper.scrollbar.timeout);\n $el[0].style.opacity = 1;\n swiper.scrollbar.timeout = setTimeout(function () {\n $el[0].style.opacity = 0;\n $el.transition(400);\n }, 1000);\n }\n },\n setTransition: function setTransition(duration) {\n var swiper = this;\n if (!swiper.params.scrollbar.el || !swiper.scrollbar.el) { return; }\n swiper.scrollbar.$dragEl.transition(duration);\n },\n updateSize: function updateSize() {\n var swiper = this;\n if (!swiper.params.scrollbar.el || !swiper.scrollbar.el) { return; }\n\n var scrollbar = swiper.scrollbar;\n var $dragEl = scrollbar.$dragEl;\n var $el = scrollbar.$el;\n\n $dragEl[0].style.width = '';\n $dragEl[0].style.height = '';\n var trackSize = swiper.isHorizontal() ? $el[0].offsetWidth : $el[0].offsetHeight;\n\n var divider = swiper.size / swiper.virtualSize;\n var moveDivider = divider * (trackSize / swiper.size);\n var dragSize;\n if (swiper.params.scrollbar.dragSize === 'auto') {\n dragSize = trackSize * divider;\n } else {\n dragSize = parseInt(swiper.params.scrollbar.dragSize, 10);\n }\n\n if (swiper.isHorizontal()) {\n $dragEl[0].style.width = dragSize + \"px\";\n } else {\n $dragEl[0].style.height = dragSize + \"px\";\n }\n\n if (divider >= 1) {\n $el[0].style.display = 'none';\n } else {\n $el[0].style.display = '';\n }\n if (swiper.params.scrollbar.hide) {\n $el[0].style.opacity = 0;\n }\n Utils.extend(scrollbar, {\n trackSize: trackSize,\n divider: divider,\n moveDivider: moveDivider,\n dragSize: dragSize,\n });\n scrollbar.$el[swiper.params.watchOverflow && swiper.isLocked ? 'addClass' : 'removeClass'](swiper.params.scrollbar.lockClass);\n },\n getPointerPosition: function getPointerPosition(e) {\n var swiper = this;\n if (swiper.isHorizontal()) {\n return ((e.type === 'touchstart' || e.type === 'touchmove') ? e.targetTouches[0].pageX : e.pageX || e.clientX);\n }\n return ((e.type === 'touchstart' || e.type === 'touchmove') ? e.targetTouches[0].pageY : e.pageY || e.clientY);\n },\n setDragPosition: function setDragPosition(e) {\n var swiper = this;\n var scrollbar = swiper.scrollbar;\n var rtl = swiper.rtlTranslate;\n var $el = scrollbar.$el;\n var dragSize = scrollbar.dragSize;\n var trackSize = scrollbar.trackSize;\n var dragStartPos = scrollbar.dragStartPos;\n\n var positionRatio;\n positionRatio = ((scrollbar.getPointerPosition(e)) - $el.offset()[swiper.isHorizontal() ? 'left' : 'top']\n - (dragStartPos !== null ? dragStartPos : dragSize / 2)) / (trackSize - dragSize);\n positionRatio = Math.max(Math.min(positionRatio, 1), 0);\n if (rtl) {\n positionRatio = 1 - positionRatio;\n }\n\n var position = swiper.minTranslate() + ((swiper.maxTranslate() - swiper.minTranslate()) * positionRatio);\n\n swiper.updateProgress(position);\n swiper.setTranslate(position);\n swiper.updateActiveIndex();\n swiper.updateSlidesClasses();\n },\n onDragStart: function onDragStart(e) {\n var swiper = this;\n var params = swiper.params.scrollbar;\n var scrollbar = swiper.scrollbar;\n var $wrapperEl = swiper.$wrapperEl;\n var $el = scrollbar.$el;\n var $dragEl = scrollbar.$dragEl;\n swiper.scrollbar.isTouched = true;\n swiper.scrollbar.dragStartPos = (e.target === $dragEl[0] || e.target === $dragEl)\n ? scrollbar.getPointerPosition(e) - e.target.getBoundingClientRect()[swiper.isHorizontal() ? 'left' : 'top'] : null;\n e.preventDefault();\n e.stopPropagation();\n\n $wrapperEl.transition(100);\n $dragEl.transition(100);\n scrollbar.setDragPosition(e);\n\n clearTimeout(swiper.scrollbar.dragTimeout);\n\n $el.transition(0);\n if (params.hide) {\n $el.css('opacity', 1);\n }\n swiper.emit('scrollbarDragStart', e);\n },\n onDragMove: function onDragMove(e) {\n var swiper = this;\n var scrollbar = swiper.scrollbar;\n var $wrapperEl = swiper.$wrapperEl;\n var $el = scrollbar.$el;\n var $dragEl = scrollbar.$dragEl;\n\n if (!swiper.scrollbar.isTouched) { return; }\n if (e.preventDefault) { e.preventDefault(); }\n else { e.returnValue = false; }\n scrollbar.setDragPosition(e);\n $wrapperEl.transition(0);\n $el.transition(0);\n $dragEl.transition(0);\n swiper.emit('scrollbarDragMove', e);\n },\n onDragEnd: function onDragEnd(e) {\n var swiper = this;\n\n var params = swiper.params.scrollbar;\n var scrollbar = swiper.scrollbar;\n var $el = scrollbar.$el;\n\n if (!swiper.scrollbar.isTouched) { return; }\n swiper.scrollbar.isTouched = false;\n if (params.hide) {\n clearTimeout(swiper.scrollbar.dragTimeout);\n swiper.scrollbar.dragTimeout = Utils.nextTick(function () {\n $el.css('opacity', 0);\n $el.transition(400);\n }, 1000);\n }\n swiper.emit('scrollbarDragEnd', e);\n if (params.snapOnRelease) {\n swiper.slideToClosest();\n }\n },\n enableDraggable: function enableDraggable() {\n var swiper = this;\n if (!swiper.params.scrollbar.el) { return; }\n var scrollbar = swiper.scrollbar;\n var touchEventsTouch = swiper.touchEventsTouch;\n var touchEventsDesktop = swiper.touchEventsDesktop;\n var params = swiper.params;\n var $el = scrollbar.$el;\n var target = $el[0];\n var activeListener = Support.passiveListener && params.passiveListeners ? { passive: false, capture: false } : false;\n var passiveListener = Support.passiveListener && params.passiveListeners ? { passive: true, capture: false } : false;\n if (!Support.touch) {\n target.addEventListener(touchEventsDesktop.start, swiper.scrollbar.onDragStart, activeListener);\n doc.addEventListener(touchEventsDesktop.move, swiper.scrollbar.onDragMove, activeListener);\n doc.addEventListener(touchEventsDesktop.end, swiper.scrollbar.onDragEnd, passiveListener);\n } else {\n target.addEventListener(touchEventsTouch.start, swiper.scrollbar.onDragStart, activeListener);\n target.addEventListener(touchEventsTouch.move, swiper.scrollbar.onDragMove, activeListener);\n target.addEventListener(touchEventsTouch.end, swiper.scrollbar.onDragEnd, passiveListener);\n }\n },\n disableDraggable: function disableDraggable() {\n var swiper = this;\n if (!swiper.params.scrollbar.el) { return; }\n var scrollbar = swiper.scrollbar;\n var touchEventsTouch = swiper.touchEventsTouch;\n var touchEventsDesktop = swiper.touchEventsDesktop;\n var params = swiper.params;\n var $el = scrollbar.$el;\n var target = $el[0];\n var activeListener = Support.passiveListener && params.passiveListeners ? { passive: false, capture: false } : false;\n var passiveListener = Support.passiveListener && params.passiveListeners ? { passive: true, capture: false } : false;\n if (!Support.touch) {\n target.removeEventListener(touchEventsDesktop.start, swiper.scrollbar.onDragStart, activeListener);\n doc.removeEventListener(touchEventsDesktop.move, swiper.scrollbar.onDragMove, activeListener);\n doc.removeEventListener(touchEventsDesktop.end, swiper.scrollbar.onDragEnd, passiveListener);\n } else {\n target.removeEventListener(touchEventsTouch.start, swiper.scrollbar.onDragStart, activeListener);\n target.removeEventListener(touchEventsTouch.move, swiper.scrollbar.onDragMove, activeListener);\n target.removeEventListener(touchEventsTouch.end, swiper.scrollbar.onDragEnd, passiveListener);\n }\n },\n init: function init() {\n var swiper = this;\n if (!swiper.params.scrollbar.el) { return; }\n var scrollbar = swiper.scrollbar;\n var $swiperEl = swiper.$el;\n var params = swiper.params.scrollbar;\n\n var $el = $(params.el);\n if (swiper.params.uniqueNavElements && typeof params.el === 'string' && $el.length > 1 && $swiperEl.find(params.el).length === 1) {\n $el = $swiperEl.find(params.el);\n }\n\n var $dragEl = $el.find((\".\" + (swiper.params.scrollbar.dragClass)));\n if ($dragEl.length === 0) {\n $dragEl = $((\"<div class=\\\"\" + (swiper.params.scrollbar.dragClass) + \"\\\"></div>\"));\n $el.append($dragEl);\n }\n\n Utils.extend(scrollbar, {\n $el: $el,\n el: $el[0],\n $dragEl: $dragEl,\n dragEl: $dragEl[0],\n });\n\n if (params.draggable) {\n scrollbar.enableDraggable();\n }\n },\n destroy: function destroy() {\n var swiper = this;\n swiper.scrollbar.disableDraggable();\n },\n };\n\n var Scrollbar$1 = {\n name: 'scrollbar',\n params: {\n scrollbar: {\n el: null,\n dragSize: 'auto',\n hide: false,\n draggable: false,\n snapOnRelease: true,\n lockClass: 'swiper-scrollbar-lock',\n dragClass: 'swiper-scrollbar-drag',\n },\n },\n create: function create() {\n var swiper = this;\n Utils.extend(swiper, {\n scrollbar: {\n init: Scrollbar.init.bind(swiper),\n destroy: Scrollbar.destroy.bind(swiper),\n updateSize: Scrollbar.updateSize.bind(swiper),\n setTranslate: Scrollbar.setTranslate.bind(swiper),\n setTransition: Scrollbar.setTransition.bind(swiper),\n enableDraggable: Scrollbar.enableDraggable.bind(swiper),\n disableDraggable: Scrollbar.disableDraggable.bind(swiper),\n setDragPosition: Scrollbar.setDragPosition.bind(swiper),\n getPointerPosition: Scrollbar.getPointerPosition.bind(swiper),\n onDragStart: Scrollbar.onDragStart.bind(swiper),\n onDragMove: Scrollbar.onDragMove.bind(swiper),\n onDragEnd: Scrollbar.onDragEnd.bind(swiper),\n isTouched: false,\n timeout: null,\n dragTimeout: null,\n },\n });\n },\n on: {\n init: function init() {\n var swiper = this;\n swiper.scrollbar.init();\n swiper.scrollbar.updateSize();\n swiper.scrollbar.setTranslate();\n },\n update: function update() {\n var swiper = this;\n swiper.scrollbar.updateSize();\n },\n resize: function resize() {\n var swiper = this;\n swiper.scrollbar.updateSize();\n },\n observerUpdate: function observerUpdate() {\n var swiper = this;\n swiper.scrollbar.updateSize();\n },\n setTranslate: function setTranslate() {\n var swiper = this;\n swiper.scrollbar.setTranslate();\n },\n setTransition: function setTransition(duration) {\n var swiper = this;\n swiper.scrollbar.setTransition(duration);\n },\n destroy: function destroy() {\n var swiper = this;\n swiper.scrollbar.destroy();\n },\n },\n };\n\n var Parallax = {\n setTransform: function setTransform(el, progress) {\n var swiper = this;\n var rtl = swiper.rtl;\n\n var $el = $(el);\n var rtlFactor = rtl ? -1 : 1;\n\n var p = $el.attr('data-swiper-parallax') || '0';\n var x = $el.attr('data-swiper-parallax-x');\n var y = $el.attr('data-swiper-parallax-y');\n var scale = $el.attr('data-swiper-parallax-scale');\n var opacity = $el.attr('data-swiper-parallax-opacity');\n\n if (x || y) {\n x = x || '0';\n y = y || '0';\n } else if (swiper.isHorizontal()) {\n x = p;\n y = '0';\n } else {\n y = p;\n x = '0';\n }\n\n if ((x).indexOf('%') >= 0) {\n x = (parseInt(x, 10) * progress * rtlFactor) + \"%\";\n } else {\n x = (x * progress * rtlFactor) + \"px\";\n }\n if ((y).indexOf('%') >= 0) {\n y = (parseInt(y, 10) * progress) + \"%\";\n } else {\n y = (y * progress) + \"px\";\n }\n\n if (typeof opacity !== 'undefined' && opacity !== null) {\n var currentOpacity = opacity - ((opacity - 1) * (1 - Math.abs(progress)));\n $el[0].style.opacity = currentOpacity;\n }\n if (typeof scale === 'undefined' || scale === null) {\n $el.transform((\"translate3d(\" + x + \", \" + y + \", 0px)\"));\n } else {\n var currentScale = scale - ((scale - 1) * (1 - Math.abs(progress)));\n $el.transform((\"translate3d(\" + x + \", \" + y + \", 0px) scale(\" + currentScale + \")\"));\n }\n },\n setTranslate: function setTranslate() {\n var swiper = this;\n var $el = swiper.$el;\n var slides = swiper.slides;\n var progress = swiper.progress;\n var snapGrid = swiper.snapGrid;\n $el.children('[data-swiper-parallax], [data-swiper-parallax-x], [data-swiper-parallax-y], [data-swiper-parallax-opacity], [data-swiper-parallax-scale]')\n .each(function (index, el) {\n swiper.parallax.setTransform(el, progress);\n });\n slides.each(function (slideIndex, slideEl) {\n var slideProgress = slideEl.progress;\n if (swiper.params.slidesPerGroup > 1 && swiper.params.slidesPerView !== 'auto') {\n slideProgress += Math.ceil(slideIndex / 2) - (progress * (snapGrid.length - 1));\n }\n slideProgress = Math.min(Math.max(slideProgress, -1), 1);\n $(slideEl).find('[data-swiper-parallax], [data-swiper-parallax-x], [data-swiper-parallax-y], [data-swiper-parallax-opacity], [data-swiper-parallax-scale]')\n .each(function (index, el) {\n swiper.parallax.setTransform(el, slideProgress);\n });\n });\n },\n setTransition: function setTransition(duration) {\n if ( duration === void 0 ) duration = this.params.speed;\n\n var swiper = this;\n var $el = swiper.$el;\n $el.find('[data-swiper-parallax], [data-swiper-parallax-x], [data-swiper-parallax-y], [data-swiper-parallax-opacity], [data-swiper-parallax-scale]')\n .each(function (index, parallaxEl) {\n var $parallaxEl = $(parallaxEl);\n var parallaxDuration = parseInt($parallaxEl.attr('data-swiper-parallax-duration'), 10) || duration;\n if (duration === 0) { parallaxDuration = 0; }\n $parallaxEl.transition(parallaxDuration);\n });\n },\n };\n\n var Parallax$1 = {\n name: 'parallax',\n params: {\n parallax: {\n enabled: false,\n },\n },\n create: function create() {\n var swiper = this;\n Utils.extend(swiper, {\n parallax: {\n setTransform: Parallax.setTransform.bind(swiper),\n setTranslate: Parallax.setTranslate.bind(swiper),\n setTransition: Parallax.setTransition.bind(swiper),\n },\n });\n },\n on: {\n beforeInit: function beforeInit() {\n var swiper = this;\n if (!swiper.params.parallax.enabled) { return; }\n swiper.params.watchSlidesProgress = true;\n swiper.originalParams.watchSlidesProgress = true;\n },\n init: function init() {\n var swiper = this;\n if (!swiper.params.parallax.enabled) { return; }\n swiper.parallax.setTranslate();\n },\n setTranslate: function setTranslate() {\n var swiper = this;\n if (!swiper.params.parallax.enabled) { return; }\n swiper.parallax.setTranslate();\n },\n setTransition: function setTransition(duration) {\n var swiper = this;\n if (!swiper.params.parallax.enabled) { return; }\n swiper.parallax.setTransition(duration);\n },\n },\n };\n\n var Zoom = {\n // Calc Scale From Multi-touches\n getDistanceBetweenTouches: function getDistanceBetweenTouches(e) {\n if (e.targetTouches.length < 2) { return 1; }\n var x1 = e.targetTouches[0].pageX;\n var y1 = e.targetTouches[0].pageY;\n var x2 = e.targetTouches[1].pageX;\n var y2 = e.targetTouches[1].pageY;\n var distance = Math.sqrt((Math.pow( (x2 - x1), 2 )) + (Math.pow( (y2 - y1), 2 )));\n return distance;\n },\n // Events\n onGestureStart: function onGestureStart(e) {\n var swiper = this;\n var params = swiper.params.zoom;\n var zoom = swiper.zoom;\n var gesture = zoom.gesture;\n zoom.fakeGestureTouched = false;\n zoom.fakeGestureMoved = false;\n if (!Support.gestures) {\n if (e.type !== 'touchstart' || (e.type === 'touchstart' && e.targetTouches.length < 2)) {\n return;\n }\n zoom.fakeGestureTouched = true;\n gesture.scaleStart = Zoom.getDistanceBetweenTouches(e);\n }\n if (!gesture.$slideEl || !gesture.$slideEl.length) {\n gesture.$slideEl = $(e.target).closest('.swiper-slide');\n if (gesture.$slideEl.length === 0) { gesture.$slideEl = swiper.slides.eq(swiper.activeIndex); }\n gesture.$imageEl = gesture.$slideEl.find('img, svg, canvas');\n gesture.$imageWrapEl = gesture.$imageEl.parent((\".\" + (params.containerClass)));\n gesture.maxRatio = gesture.$imageWrapEl.attr('data-swiper-zoom') || params.maxRatio;\n if (gesture.$imageWrapEl.length === 0) {\n gesture.$imageEl = undefined;\n return;\n }\n }\n gesture.$imageEl.transition(0);\n swiper.zoom.isScaling = true;\n },\n onGestureChange: function onGestureChange(e) {\n var swiper = this;\n var params = swiper.params.zoom;\n var zoom = swiper.zoom;\n var gesture = zoom.gesture;\n if (!Support.gestures) {\n if (e.type !== 'touchmove' || (e.type === 'touchmove' && e.targetTouches.length < 2)) {\n return;\n }\n zoom.fakeGestureMoved = true;\n gesture.scaleMove = Zoom.getDistanceBetweenTouches(e);\n }\n if (!gesture.$imageEl || gesture.$imageEl.length === 0) { return; }\n if (Support.gestures) {\n zoom.scale = e.scale * zoom.currentScale;\n } else {\n zoom.scale = (gesture.scaleMove / gesture.scaleStart) * zoom.currentScale;\n }\n if (zoom.scale > gesture.maxRatio) {\n zoom.scale = (gesture.maxRatio - 1) + (Math.pow( ((zoom.scale - gesture.maxRatio) + 1), 0.5 ));\n }\n if (zoom.scale < params.minRatio) {\n zoom.scale = (params.minRatio + 1) - (Math.pow( ((params.minRatio - zoom.scale) + 1), 0.5 ));\n }\n gesture.$imageEl.transform((\"translate3d(0,0,0) scale(\" + (zoom.scale) + \")\"));\n },\n onGestureEnd: function onGestureEnd(e) {\n var swiper = this;\n var params = swiper.params.zoom;\n var zoom = swiper.zoom;\n var gesture = zoom.gesture;\n if (!Support.gestures) {\n if (!zoom.fakeGestureTouched || !zoom.fakeGestureMoved) {\n return;\n }\n if (e.type !== 'touchend' || (e.type === 'touchend' && e.changedTouches.length < 2 && !Device.android)) {\n return;\n }\n zoom.fakeGestureTouched = false;\n zoom.fakeGestureMoved = false;\n }\n if (!gesture.$imageEl || gesture.$imageEl.length === 0) { return; }\n zoom.scale = Math.max(Math.min(zoom.scale, gesture.maxRatio), params.minRatio);\n gesture.$imageEl.transition(swiper.params.speed).transform((\"translate3d(0,0,0) scale(\" + (zoom.scale) + \")\"));\n zoom.currentScale = zoom.scale;\n zoom.isScaling = false;\n if (zoom.scale === 1) { gesture.$slideEl = undefined; }\n },\n onTouchStart: function onTouchStart(e) {\n var swiper = this;\n var zoom = swiper.zoom;\n var gesture = zoom.gesture;\n var image = zoom.image;\n if (!gesture.$imageEl || gesture.$imageEl.length === 0) { return; }\n if (image.isTouched) { return; }\n if (Device.android) { e.preventDefault(); }\n image.isTouched = true;\n image.touchesStart.x = e.type === 'touchstart' ? e.targetTouches[0].pageX : e.pageX;\n image.touchesStart.y = e.type === 'touchstart' ? e.targetTouches[0].pageY : e.pageY;\n },\n onTouchMove: function onTouchMove(e) {\n var swiper = this;\n var zoom = swiper.zoom;\n var gesture = zoom.gesture;\n var image = zoom.image;\n var velocity = zoom.velocity;\n if (!gesture.$imageEl || gesture.$imageEl.length === 0) { return; }\n swiper.allowClick = false;\n if (!image.isTouched || !gesture.$slideEl) { return; }\n\n if (!image.isMoved) {\n image.width = gesture.$imageEl[0].offsetWidth;\n image.height = gesture.$imageEl[0].offsetHeight;\n image.startX = Utils.getTranslate(gesture.$imageWrapEl[0], 'x') || 0;\n image.startY = Utils.getTranslate(gesture.$imageWrapEl[0], 'y') || 0;\n gesture.slideWidth = gesture.$slideEl[0].offsetWidth;\n gesture.slideHeight = gesture.$slideEl[0].offsetHeight;\n gesture.$imageWrapEl.transition(0);\n if (swiper.rtl) {\n image.startX = -image.startX;\n image.startY = -image.startY;\n }\n }\n // Define if we need image drag\n var scaledWidth = image.width * zoom.scale;\n var scaledHeight = image.height * zoom.scale;\n\n if (scaledWidth < gesture.slideWidth && scaledHeight < gesture.slideHeight) { return; }\n\n image.minX = Math.min(((gesture.slideWidth / 2) - (scaledWidth / 2)), 0);\n image.maxX = -image.minX;\n image.minY = Math.min(((gesture.slideHeight / 2) - (scaledHeight / 2)), 0);\n image.maxY = -image.minY;\n\n image.touchesCurrent.x = e.type === 'touchmove' ? e.targetTouches[0].pageX : e.pageX;\n image.touchesCurrent.y = e.type === 'touchmove' ? e.targetTouches[0].pageY : e.pageY;\n\n if (!image.isMoved && !zoom.isScaling) {\n if (\n swiper.isHorizontal()\n && (\n (Math.floor(image.minX) === Math.floor(image.startX) && image.touchesCurrent.x < image.touchesStart.x)\n || (Math.floor(image.maxX) === Math.floor(image.startX) && image.touchesCurrent.x > image.touchesStart.x)\n )\n ) {\n image.isTouched = false;\n return;\n } if (\n !swiper.isHorizontal()\n && (\n (Math.floor(image.minY) === Math.floor(image.startY) && image.touchesCurrent.y < image.touchesStart.y)\n || (Math.floor(image.maxY) === Math.floor(image.startY) && image.touchesCurrent.y > image.touchesStart.y)\n )\n ) {\n image.isTouched = false;\n return;\n }\n }\n e.preventDefault();\n e.stopPropagation();\n\n image.isMoved = true;\n image.currentX = (image.touchesCurrent.x - image.touchesStart.x) + image.startX;\n image.currentY = (image.touchesCurrent.y - image.touchesStart.y) + image.startY;\n\n if (image.currentX < image.minX) {\n image.currentX = (image.minX + 1) - (Math.pow( ((image.minX - image.currentX) + 1), 0.8 ));\n }\n if (image.currentX > image.maxX) {\n image.currentX = (image.maxX - 1) + (Math.pow( ((image.currentX - image.maxX) + 1), 0.8 ));\n }\n\n if (image.currentY < image.minY) {\n image.currentY = (image.minY + 1) - (Math.pow( ((image.minY - image.currentY) + 1), 0.8 ));\n }\n if (image.currentY > image.maxY) {\n image.currentY = (image.maxY - 1) + (Math.pow( ((image.currentY - image.maxY) + 1), 0.8 ));\n }\n\n // Velocity\n if (!velocity.prevPositionX) { velocity.prevPositionX = image.touchesCurrent.x; }\n if (!velocity.prevPositionY) { velocity.prevPositionY = image.touchesCurrent.y; }\n if (!velocity.prevTime) { velocity.prevTime = Date.now(); }\n velocity.x = (image.touchesCurrent.x - velocity.prevPositionX) / (Date.now() - velocity.prevTime) / 2;\n velocity.y = (image.touchesCurrent.y - velocity.prevPositionY) / (Date.now() - velocity.prevTime) / 2;\n if (Math.abs(image.touchesCurrent.x - velocity.prevPositionX) < 2) { velocity.x = 0; }\n if (Math.abs(image.touchesCurrent.y - velocity.prevPositionY) < 2) { velocity.y = 0; }\n velocity.prevPositionX = image.touchesCurrent.x;\n velocity.prevPositionY = image.touchesCurrent.y;\n velocity.prevTime = Date.now();\n\n gesture.$imageWrapEl.transform((\"translate3d(\" + (image.currentX) + \"px, \" + (image.currentY) + \"px,0)\"));\n },\n onTouchEnd: function onTouchEnd() {\n var swiper = this;\n var zoom = swiper.zoom;\n var gesture = zoom.gesture;\n var image = zoom.image;\n var velocity = zoom.velocity;\n if (!gesture.$imageEl || gesture.$imageEl.length === 0) { return; }\n if (!image.isTouched || !image.isMoved) {\n image.isTouched = false;\n image.isMoved = false;\n return;\n }\n image.isTouched = false;\n image.isMoved = false;\n var momentumDurationX = 300;\n var momentumDurationY = 300;\n var momentumDistanceX = velocity.x * momentumDurationX;\n var newPositionX = image.currentX + momentumDistanceX;\n var momentumDistanceY = velocity.y * momentumDurationY;\n var newPositionY = image.currentY + momentumDistanceY;\n\n // Fix duration\n if (velocity.x !== 0) { momentumDurationX = Math.abs((newPositionX - image.currentX) / velocity.x); }\n if (velocity.y !== 0) { momentumDurationY = Math.abs((newPositionY - image.currentY) / velocity.y); }\n var momentumDuration = Math.max(momentumDurationX, momentumDurationY);\n\n image.currentX = newPositionX;\n image.currentY = newPositionY;\n\n // Define if we need image drag\n var scaledWidth = image.width * zoom.scale;\n var scaledHeight = image.height * zoom.scale;\n image.minX = Math.min(((gesture.slideWidth / 2) - (scaledWidth / 2)), 0);\n image.maxX = -image.minX;\n image.minY = Math.min(((gesture.slideHeight / 2) - (scaledHeight / 2)), 0);\n image.maxY = -image.minY;\n image.currentX = Math.max(Math.min(image.currentX, image.maxX), image.minX);\n image.currentY = Math.max(Math.min(image.currentY, image.maxY), image.minY);\n\n gesture.$imageWrapEl.transition(momentumDuration).transform((\"translate3d(\" + (image.currentX) + \"px, \" + (image.currentY) + \"px,0)\"));\n },\n onTransitionEnd: function onTransitionEnd() {\n var swiper = this;\n var zoom = swiper.zoom;\n var gesture = zoom.gesture;\n if (gesture.$slideEl && swiper.previousIndex !== swiper.activeIndex) {\n gesture.$imageEl.transform('translate3d(0,0,0) scale(1)');\n gesture.$imageWrapEl.transform('translate3d(0,0,0)');\n\n zoom.scale = 1;\n zoom.currentScale = 1;\n\n gesture.$slideEl = undefined;\n gesture.$imageEl = undefined;\n gesture.$imageWrapEl = undefined;\n }\n },\n // Toggle Zoom\n toggle: function toggle(e) {\n var swiper = this;\n var zoom = swiper.zoom;\n\n if (zoom.scale && zoom.scale !== 1) {\n // Zoom Out\n zoom.out();\n } else {\n // Zoom In\n zoom.in(e);\n }\n },\n in: function in$1(e) {\n var swiper = this;\n\n var zoom = swiper.zoom;\n var params = swiper.params.zoom;\n var gesture = zoom.gesture;\n var image = zoom.image;\n\n if (!gesture.$slideEl) {\n gesture.$slideEl = swiper.clickedSlide ? $(swiper.clickedSlide) : swiper.slides.eq(swiper.activeIndex);\n gesture.$imageEl = gesture.$slideEl.find('img, svg, canvas');\n gesture.$imageWrapEl = gesture.$imageEl.parent((\".\" + (params.containerClass)));\n }\n if (!gesture.$imageEl || gesture.$imageEl.length === 0) { return; }\n\n gesture.$slideEl.addClass((\"\" + (params.zoomedSlideClass)));\n\n var touchX;\n var touchY;\n var offsetX;\n var offsetY;\n var diffX;\n var diffY;\n var translateX;\n var translateY;\n var imageWidth;\n var imageHeight;\n var scaledWidth;\n var scaledHeight;\n var translateMinX;\n var translateMinY;\n var translateMaxX;\n var translateMaxY;\n var slideWidth;\n var slideHeight;\n\n if (typeof image.touchesStart.x === 'undefined' && e) {\n touchX = e.type === 'touchend' ? e.changedTouches[0].pageX : e.pageX;\n touchY = e.type === 'touchend' ? e.changedTouches[0].pageY : e.pageY;\n } else {\n touchX = image.touchesStart.x;\n touchY = image.touchesStart.y;\n }\n\n zoom.scale = gesture.$imageWrapEl.attr('data-swiper-zoom') || params.maxRatio;\n zoom.currentScale = gesture.$imageWrapEl.attr('data-swiper-zoom') || params.maxRatio;\n if (e) {\n slideWidth = gesture.$slideEl[0].offsetWidth;\n slideHeight = gesture.$slideEl[0].offsetHeight;\n offsetX = gesture.$slideEl.offset().left;\n offsetY = gesture.$slideEl.offset().top;\n diffX = (offsetX + (slideWidth / 2)) - touchX;\n diffY = (offsetY + (slideHeight / 2)) - touchY;\n\n imageWidth = gesture.$imageEl[0].offsetWidth;\n imageHeight = gesture.$imageEl[0].offsetHeight;\n scaledWidth = imageWidth * zoom.scale;\n scaledHeight = imageHeight * zoom.scale;\n\n translateMinX = Math.min(((slideWidth / 2) - (scaledWidth / 2)), 0);\n translateMinY = Math.min(((slideHeight / 2) - (scaledHeight / 2)), 0);\n translateMaxX = -translateMinX;\n translateMaxY = -translateMinY;\n\n translateX = diffX * zoom.scale;\n translateY = diffY * zoom.scale;\n\n if (translateX < translateMinX) {\n translateX = translateMinX;\n }\n if (translateX > translateMaxX) {\n translateX = translateMaxX;\n }\n\n if (translateY < translateMinY) {\n translateY = translateMinY;\n }\n if (translateY > translateMaxY) {\n translateY = translateMaxY;\n }\n } else {\n translateX = 0;\n translateY = 0;\n }\n gesture.$imageWrapEl.transition(300).transform((\"translate3d(\" + translateX + \"px, \" + translateY + \"px,0)\"));\n gesture.$imageEl.transition(300).transform((\"translate3d(0,0,0) scale(\" + (zoom.scale) + \")\"));\n },\n out: function out() {\n var swiper = this;\n\n var zoom = swiper.zoom;\n var params = swiper.params.zoom;\n var gesture = zoom.gesture;\n\n if (!gesture.$slideEl) {\n gesture.$slideEl = swiper.clickedSlide ? $(swiper.clickedSlide) : swiper.slides.eq(swiper.activeIndex);\n gesture.$imageEl = gesture.$slideEl.find('img, svg, canvas');\n gesture.$imageWrapEl = gesture.$imageEl.parent((\".\" + (params.containerClass)));\n }\n if (!gesture.$imageEl || gesture.$imageEl.length === 0) { return; }\n\n zoom.scale = 1;\n zoom.currentScale = 1;\n gesture.$imageWrapEl.transition(300).transform('translate3d(0,0,0)');\n gesture.$imageEl.transition(300).transform('translate3d(0,0,0) scale(1)');\n gesture.$slideEl.removeClass((\"\" + (params.zoomedSlideClass)));\n gesture.$slideEl = undefined;\n },\n // Attach/Detach Events\n enable: function enable() {\n var swiper = this;\n var zoom = swiper.zoom;\n if (zoom.enabled) { return; }\n zoom.enabled = true;\n\n var passiveListener = swiper.touchEvents.start === 'touchstart' && Support.passiveListener && swiper.params.passiveListeners ? { passive: true, capture: false } : false;\n\n // Scale image\n if (Support.gestures) {\n swiper.$wrapperEl.on('gesturestart', '.swiper-slide', zoom.onGestureStart, passiveListener);\n swiper.$wrapperEl.on('gesturechange', '.swiper-slide', zoom.onGestureChange, passiveListener);\n swiper.$wrapperEl.on('gestureend', '.swiper-slide', zoom.onGestureEnd, passiveListener);\n } else if (swiper.touchEvents.start === 'touchstart') {\n swiper.$wrapperEl.on(swiper.touchEvents.start, '.swiper-slide', zoom.onGestureStart, passiveListener);\n swiper.$wrapperEl.on(swiper.touchEvents.move, '.swiper-slide', zoom.onGestureChange, passiveListener);\n swiper.$wrapperEl.on(swiper.touchEvents.end, '.swiper-slide', zoom.onGestureEnd, passiveListener);\n }\n\n // Move image\n swiper.$wrapperEl.on(swiper.touchEvents.move, (\".\" + (swiper.params.zoom.containerClass)), zoom.onTouchMove);\n },\n disable: function disable() {\n var swiper = this;\n var zoom = swiper.zoom;\n if (!zoom.enabled) { return; }\n\n swiper.zoom.enabled = false;\n\n var passiveListener = swiper.touchEvents.start === 'touchstart' && Support.passiveListener && swiper.params.passiveListeners ? { passive: true, capture: false } : false;\n\n // Scale image\n if (Support.gestures) {\n swiper.$wrapperEl.off('gesturestart', '.swiper-slide', zoom.onGestureStart, passiveListener);\n swiper.$wrapperEl.off('gesturechange', '.swiper-slide', zoom.onGestureChange, passiveListener);\n swiper.$wrapperEl.off('gestureend', '.swiper-slide', zoom.onGestureEnd, passiveListener);\n } else if (swiper.touchEvents.start === 'touchstart') {\n swiper.$wrapperEl.off(swiper.touchEvents.start, '.swiper-slide', zoom.onGestureStart, passiveListener);\n swiper.$wrapperEl.off(swiper.touchEvents.move, '.swiper-slide', zoom.onGestureChange, passiveListener);\n swiper.$wrapperEl.off(swiper.touchEvents.end, '.swiper-slide', zoom.onGestureEnd, passiveListener);\n }\n\n // Move image\n swiper.$wrapperEl.off(swiper.touchEvents.move, (\".\" + (swiper.params.zoom.containerClass)), zoom.onTouchMove);\n },\n };\n\n var Zoom$1 = {\n name: 'zoom',\n params: {\n zoom: {\n enabled: false,\n maxRatio: 3,\n minRatio: 1,\n toggle: true,\n containerClass: 'swiper-zoom-container',\n zoomedSlideClass: 'swiper-slide-zoomed',\n },\n },\n create: function create() {\n var swiper = this;\n var zoom = {\n enabled: false,\n scale: 1,\n currentScale: 1,\n isScaling: false,\n gesture: {\n $slideEl: undefined,\n slideWidth: undefined,\n slideHeight: undefined,\n $imageEl: undefined,\n $imageWrapEl: undefined,\n maxRatio: 3,\n },\n image: {\n isTouched: undefined,\n isMoved: undefined,\n currentX: undefined,\n currentY: undefined,\n minX: undefined,\n minY: undefined,\n maxX: undefined,\n maxY: undefined,\n width: undefined,\n height: undefined,\n startX: undefined,\n startY: undefined,\n touchesStart: {},\n touchesCurrent: {},\n },\n velocity: {\n x: undefined,\n y: undefined,\n prevPositionX: undefined,\n prevPositionY: undefined,\n prevTime: undefined,\n },\n };\n\n ('onGestureStart onGestureChange onGestureEnd onTouchStart onTouchMove onTouchEnd onTransitionEnd toggle enable disable in out').split(' ').forEach(function (methodName) {\n zoom[methodName] = Zoom[methodName].bind(swiper);\n });\n Utils.extend(swiper, {\n zoom: zoom,\n });\n\n var scale = 1;\n Object.defineProperty(swiper.zoom, 'scale', {\n get: function get() {\n return scale;\n },\n set: function set(value) {\n if (scale !== value) {\n var imageEl = swiper.zoom.gesture.$imageEl ? swiper.zoom.gesture.$imageEl[0] : undefined;\n var slideEl = swiper.zoom.gesture.$slideEl ? swiper.zoom.gesture.$slideEl[0] : undefined;\n swiper.emit('zoomChange', value, imageEl, slideEl);\n }\n scale = value;\n },\n });\n },\n on: {\n init: function init() {\n var swiper = this;\n if (swiper.params.zoom.enabled) {\n swiper.zoom.enable();\n }\n },\n destroy: function destroy() {\n var swiper = this;\n swiper.zoom.disable();\n },\n touchStart: function touchStart(e) {\n var swiper = this;\n if (!swiper.zoom.enabled) { return; }\n swiper.zoom.onTouchStart(e);\n },\n touchEnd: function touchEnd(e) {\n var swiper = this;\n if (!swiper.zoom.enabled) { return; }\n swiper.zoom.onTouchEnd(e);\n },\n doubleTap: function doubleTap(e) {\n var swiper = this;\n if (swiper.params.zoom.enabled && swiper.zoom.enabled && swiper.params.zoom.toggle) {\n swiper.zoom.toggle(e);\n }\n },\n transitionEnd: function transitionEnd() {\n var swiper = this;\n if (swiper.zoom.enabled && swiper.params.zoom.enabled) {\n swiper.zoom.onTransitionEnd();\n }\n },\n },\n };\n\n var Lazy = {\n loadInSlide: function loadInSlide(index, loadInDuplicate) {\n if ( loadInDuplicate === void 0 ) loadInDuplicate = true;\n\n var swiper = this;\n var params = swiper.params.lazy;\n if (typeof index === 'undefined') { return; }\n if (swiper.slides.length === 0) { return; }\n var isVirtual = swiper.virtual && swiper.params.virtual.enabled;\n\n var $slideEl = isVirtual\n ? swiper.$wrapperEl.children((\".\" + (swiper.params.slideClass) + \"[data-swiper-slide-index=\\\"\" + index + \"\\\"]\"))\n : swiper.slides.eq(index);\n\n var $images = $slideEl.find((\".\" + (params.elementClass) + \":not(.\" + (params.loadedClass) + \"):not(.\" + (params.loadingClass) + \")\"));\n if ($slideEl.hasClass(params.elementClass) && !$slideEl.hasClass(params.loadedClass) && !$slideEl.hasClass(params.loadingClass)) {\n $images = $images.add($slideEl[0]);\n }\n if ($images.length === 0) { return; }\n\n $images.each(function (imageIndex, imageEl) {\n var $imageEl = $(imageEl);\n $imageEl.addClass(params.loadingClass);\n\n var background = $imageEl.attr('data-background');\n var src = $imageEl.attr('data-src');\n var srcset = $imageEl.attr('data-srcset');\n var sizes = $imageEl.attr('data-sizes');\n\n swiper.loadImage($imageEl[0], (src || background), srcset, sizes, false, function () {\n if (typeof swiper === 'undefined' || swiper === null || !swiper || (swiper && !swiper.params) || swiper.destroyed) { return; }\n if (background) {\n $imageEl.css('background-image', (\"url(\\\"\" + background + \"\\\")\"));\n $imageEl.removeAttr('data-background');\n } else {\n if (srcset) {\n $imageEl.attr('srcset', srcset);\n $imageEl.removeAttr('data-srcset');\n }\n if (sizes) {\n $imageEl.attr('sizes', sizes);\n $imageEl.removeAttr('data-sizes');\n }\n if (src) {\n $imageEl.attr('src', src);\n $imageEl.removeAttr('data-src');\n }\n }\n\n $imageEl.addClass(params.loadedClass).removeClass(params.loadingClass);\n $slideEl.find((\".\" + (params.preloaderClass))).remove();\n if (swiper.params.loop && loadInDuplicate) {\n var slideOriginalIndex = $slideEl.attr('data-swiper-slide-index');\n if ($slideEl.hasClass(swiper.params.slideDuplicateClass)) {\n var originalSlide = swiper.$wrapperEl.children((\"[data-swiper-slide-index=\\\"\" + slideOriginalIndex + \"\\\"]:not(.\" + (swiper.params.slideDuplicateClass) + \")\"));\n swiper.lazy.loadInSlide(originalSlide.index(), false);\n } else {\n var duplicatedSlide = swiper.$wrapperEl.children((\".\" + (swiper.params.slideDuplicateClass) + \"[data-swiper-slide-index=\\\"\" + slideOriginalIndex + \"\\\"]\"));\n swiper.lazy.loadInSlide(duplicatedSlide.index(), false);\n }\n }\n swiper.emit('lazyImageReady', $slideEl[0], $imageEl[0]);\n });\n\n swiper.emit('lazyImageLoad', $slideEl[0], $imageEl[0]);\n });\n },\n load: function load() {\n var swiper = this;\n var $wrapperEl = swiper.$wrapperEl;\n var swiperParams = swiper.params;\n var slides = swiper.slides;\n var activeIndex = swiper.activeIndex;\n var isVirtual = swiper.virtual && swiperParams.virtual.enabled;\n var params = swiperParams.lazy;\n\n var slidesPerView = swiperParams.slidesPerView;\n if (slidesPerView === 'auto') {\n slidesPerView = 0;\n }\n\n function slideExist(index) {\n if (isVirtual) {\n if ($wrapperEl.children((\".\" + (swiperParams.slideClass) + \"[data-swiper-slide-index=\\\"\" + index + \"\\\"]\")).length) {\n return true;\n }\n } else if (slides[index]) { return true; }\n return false;\n }\n function slideIndex(slideEl) {\n if (isVirtual) {\n return $(slideEl).attr('data-swiper-slide-index');\n }\n return $(slideEl).index();\n }\n\n if (!swiper.lazy.initialImageLoaded) { swiper.lazy.initialImageLoaded = true; }\n if (swiper.params.watchSlidesVisibility) {\n $wrapperEl.children((\".\" + (swiperParams.slideVisibleClass))).each(function (elIndex, slideEl) {\n var index = isVirtual ? $(slideEl).attr('data-swiper-slide-index') : $(slideEl).index();\n swiper.lazy.loadInSlide(index);\n });\n } else if (slidesPerView > 1) {\n for (var i = activeIndex; i < activeIndex + slidesPerView; i += 1) {\n if (slideExist(i)) { swiper.lazy.loadInSlide(i); }\n }\n } else {\n swiper.lazy.loadInSlide(activeIndex);\n }\n if (params.loadPrevNext) {\n if (slidesPerView > 1 || (params.loadPrevNextAmount && params.loadPrevNextAmount > 1)) {\n var amount = params.loadPrevNextAmount;\n var spv = slidesPerView;\n var maxIndex = Math.min(activeIndex + spv + Math.max(amount, spv), slides.length);\n var minIndex = Math.max(activeIndex - Math.max(spv, amount), 0);\n // Next Slides\n for (var i$1 = activeIndex + slidesPerView; i$1 < maxIndex; i$1 += 1) {\n if (slideExist(i$1)) { swiper.lazy.loadInSlide(i$1); }\n }\n // Prev Slides\n for (var i$2 = minIndex; i$2 < activeIndex; i$2 += 1) {\n if (slideExist(i$2)) { swiper.lazy.loadInSlide(i$2); }\n }\n } else {\n var nextSlide = $wrapperEl.children((\".\" + (swiperParams.slideNextClass)));\n if (nextSlide.length > 0) { swiper.lazy.loadInSlide(slideIndex(nextSlide)); }\n\n var prevSlide = $wrapperEl.children((\".\" + (swiperParams.slidePrevClass)));\n if (prevSlide.length > 0) { swiper.lazy.loadInSlide(slideIndex(prevSlide)); }\n }\n }\n },\n };\n\n var Lazy$1 = {\n name: 'lazy',\n params: {\n lazy: {\n enabled: false,\n loadPrevNext: false,\n loadPrevNextAmount: 1,\n loadOnTransitionStart: false,\n\n elementClass: 'swiper-lazy',\n loadingClass: 'swiper-lazy-loading',\n loadedClass: 'swiper-lazy-loaded',\n preloaderClass: 'swiper-lazy-preloader',\n },\n },\n create: function create() {\n var swiper = this;\n Utils.extend(swiper, {\n lazy: {\n initialImageLoaded: false,\n load: Lazy.load.bind(swiper),\n loadInSlide: Lazy.loadInSlide.bind(swiper),\n },\n });\n },\n on: {\n beforeInit: function beforeInit() {\n var swiper = this;\n if (swiper.params.lazy.enabled && swiper.params.preloadImages) {\n swiper.params.preloadImages = false;\n }\n },\n init: function init() {\n var swiper = this;\n if (swiper.params.lazy.enabled && !swiper.params.loop && swiper.params.initialSlide === 0) {\n swiper.lazy.load();\n }\n },\n scroll: function scroll() {\n var swiper = this;\n if (swiper.params.freeMode && !swiper.params.freeModeSticky) {\n swiper.lazy.load();\n }\n },\n resize: function resize() {\n var swiper = this;\n if (swiper.params.lazy.enabled) {\n swiper.lazy.load();\n }\n },\n scrollbarDragMove: function scrollbarDragMove() {\n var swiper = this;\n if (swiper.params.lazy.enabled) {\n swiper.lazy.load();\n }\n },\n transitionStart: function transitionStart() {\n var swiper = this;\n if (swiper.params.lazy.enabled) {\n if (swiper.params.lazy.loadOnTransitionStart || (!swiper.params.lazy.loadOnTransitionStart && !swiper.lazy.initialImageLoaded)) {\n swiper.lazy.load();\n }\n }\n },\n transitionEnd: function transitionEnd() {\n var swiper = this;\n if (swiper.params.lazy.enabled && !swiper.params.lazy.loadOnTransitionStart) {\n swiper.lazy.load();\n }\n },\n },\n };\n\n /* eslint no-bitwise: [\"error\", { \"allow\": [\">>\"] }] */\n\n var Controller = {\n LinearSpline: function LinearSpline(x, y) {\n var binarySearch = (function search() {\n var maxIndex;\n var minIndex;\n var guess;\n return function (array, val) {\n minIndex = -1;\n maxIndex = array.length;\n while (maxIndex - minIndex > 1) {\n guess = maxIndex + minIndex >> 1;\n if (array[guess] <= val) {\n minIndex = guess;\n } else {\n maxIndex = guess;\n }\n }\n return maxIndex;\n };\n }());\n this.x = x;\n this.y = y;\n this.lastIndex = x.length - 1;\n // Given an x value (x2), return the expected y2 value:\n // (x1,y1) is the known point before given value,\n // (x3,y3) is the known point after given value.\n var i1;\n var i3;\n\n this.interpolate = function interpolate(x2) {\n if (!x2) { return 0; }\n\n // Get the indexes of x1 and x3 (the array indexes before and after given x2):\n i3 = binarySearch(this.x, x2);\n i1 = i3 - 1;\n\n // We have our indexes i1 & i3, so we can calculate already:\n // y2 := ((x2−x1) × (y3−y1)) ÷ (x3−x1) + y1\n return (((x2 - this.x[i1]) * (this.y[i3] - this.y[i1])) / (this.x[i3] - this.x[i1])) + this.y[i1];\n };\n return this;\n },\n // xxx: for now i will just save one spline function to to\n getInterpolateFunction: function getInterpolateFunction(c) {\n var swiper = this;\n if (!swiper.controller.spline) {\n swiper.controller.spline = swiper.params.loop\n ? new Controller.LinearSpline(swiper.slidesGrid, c.slidesGrid)\n : new Controller.LinearSpline(swiper.snapGrid, c.snapGrid);\n }\n },\n setTranslate: function setTranslate(setTranslate$1, byController) {\n var swiper = this;\n var controlled = swiper.controller.control;\n var multiplier;\n var controlledTranslate;\n function setControlledTranslate(c) {\n // this will create an Interpolate function based on the snapGrids\n // x is the Grid of the scrolled scroller and y will be the controlled scroller\n // it makes sense to create this only once and recall it for the interpolation\n // the function does a lot of value caching for performance\n var translate = swiper.rtlTranslate ? -swiper.translate : swiper.translate;\n if (swiper.params.controller.by === 'slide') {\n swiper.controller.getInterpolateFunction(c);\n // i am not sure why the values have to be multiplicated this way, tried to invert the snapGrid\n // but it did not work out\n controlledTranslate = -swiper.controller.spline.interpolate(-translate);\n }\n\n if (!controlledTranslate || swiper.params.controller.by === 'container') {\n multiplier = (c.maxTranslate() - c.minTranslate()) / (swiper.maxTranslate() - swiper.minTranslate());\n controlledTranslate = ((translate - swiper.minTranslate()) * multiplier) + c.minTranslate();\n }\n\n if (swiper.params.controller.inverse) {\n controlledTranslate = c.maxTranslate() - controlledTranslate;\n }\n c.updateProgress(controlledTranslate);\n c.setTranslate(controlledTranslate, swiper);\n c.updateActiveIndex();\n c.updateSlidesClasses();\n }\n if (Array.isArray(controlled)) {\n for (var i = 0; i < controlled.length; i += 1) {\n if (controlled[i] !== byController && controlled[i] instanceof Swiper) {\n setControlledTranslate(controlled[i]);\n }\n }\n } else if (controlled instanceof Swiper && byController !== controlled) {\n setControlledTranslate(controlled);\n }\n },\n setTransition: function setTransition(duration, byController) {\n var swiper = this;\n var controlled = swiper.controller.control;\n var i;\n function setControlledTransition(c) {\n c.setTransition(duration, swiper);\n if (duration !== 0) {\n c.transitionStart();\n if (c.params.autoHeight) {\n Utils.nextTick(function () {\n c.updateAutoHeight();\n });\n }\n c.$wrapperEl.transitionEnd(function () {\n if (!controlled) { return; }\n if (c.params.loop && swiper.params.controller.by === 'slide') {\n c.loopFix();\n }\n c.transitionEnd();\n });\n }\n }\n if (Array.isArray(controlled)) {\n for (i = 0; i < controlled.length; i += 1) {\n if (controlled[i] !== byController && controlled[i] instanceof Swiper) {\n setControlledTransition(controlled[i]);\n }\n }\n } else if (controlled instanceof Swiper && byController !== controlled) {\n setControlledTransition(controlled);\n }\n },\n };\n var Controller$1 = {\n name: 'controller',\n params: {\n controller: {\n control: undefined,\n inverse: false,\n by: 'slide', // or 'container'\n },\n },\n create: function create() {\n var swiper = this;\n Utils.extend(swiper, {\n controller: {\n control: swiper.params.controller.control,\n getInterpolateFunction: Controller.getInterpolateFunction.bind(swiper),\n setTranslate: Controller.setTranslate.bind(swiper),\n setTransition: Controller.setTransition.bind(swiper),\n },\n });\n },\n on: {\n update: function update() {\n var swiper = this;\n if (!swiper.controller.control) { return; }\n if (swiper.controller.spline) {\n swiper.controller.spline = undefined;\n delete swiper.controller.spline;\n }\n },\n resize: function resize() {\n var swiper = this;\n if (!swiper.controller.control) { return; }\n if (swiper.controller.spline) {\n swiper.controller.spline = undefined;\n delete swiper.controller.spline;\n }\n },\n observerUpdate: function observerUpdate() {\n var swiper = this;\n if (!swiper.controller.control) { return; }\n if (swiper.controller.spline) {\n swiper.controller.spline = undefined;\n delete swiper.controller.spline;\n }\n },\n setTranslate: function setTranslate(translate, byController) {\n var swiper = this;\n if (!swiper.controller.control) { return; }\n swiper.controller.setTranslate(translate, byController);\n },\n setTransition: function setTransition(duration, byController) {\n var swiper = this;\n if (!swiper.controller.control) { return; }\n swiper.controller.setTransition(duration, byController);\n },\n },\n };\n\n var a11y = {\n makeElFocusable: function makeElFocusable($el) {\n $el.attr('tabIndex', '0');\n return $el;\n },\n addElRole: function addElRole($el, role) {\n $el.attr('role', role);\n return $el;\n },\n addElLabel: function addElLabel($el, label) {\n $el.attr('aria-label', label);\n return $el;\n },\n disableEl: function disableEl($el) {\n $el.attr('aria-disabled', true);\n return $el;\n },\n enableEl: function enableEl($el) {\n $el.attr('aria-disabled', false);\n return $el;\n },\n onEnterKey: function onEnterKey(e) {\n var swiper = this;\n var params = swiper.params.a11y;\n if (e.keyCode !== 13) { return; }\n var $targetEl = $(e.target);\n if (swiper.navigation && swiper.navigation.$nextEl && $targetEl.is(swiper.navigation.$nextEl)) {\n if (!(swiper.isEnd && !swiper.params.loop)) {\n swiper.slideNext();\n }\n if (swiper.isEnd) {\n swiper.a11y.notify(params.lastSlideMessage);\n } else {\n swiper.a11y.notify(params.nextSlideMessage);\n }\n }\n if (swiper.navigation && swiper.navigation.$prevEl && $targetEl.is(swiper.navigation.$prevEl)) {\n if (!(swiper.isBeginning && !swiper.params.loop)) {\n swiper.slidePrev();\n }\n if (swiper.isBeginning) {\n swiper.a11y.notify(params.firstSlideMessage);\n } else {\n swiper.a11y.notify(params.prevSlideMessage);\n }\n }\n if (swiper.pagination && $targetEl.is((\".\" + (swiper.params.pagination.bulletClass)))) {\n $targetEl[0].click();\n }\n },\n notify: function notify(message) {\n var swiper = this;\n var notification = swiper.a11y.liveRegion;\n if (notification.length === 0) { return; }\n notification.html('');\n notification.html(message);\n },\n updateNavigation: function updateNavigation() {\n var swiper = this;\n\n if (swiper.params.loop) { return; }\n var ref = swiper.navigation;\n var $nextEl = ref.$nextEl;\n var $prevEl = ref.$prevEl;\n\n if ($prevEl && $prevEl.length > 0) {\n if (swiper.isBeginning) {\n swiper.a11y.disableEl($prevEl);\n } else {\n swiper.a11y.enableEl($prevEl);\n }\n }\n if ($nextEl && $nextEl.length > 0) {\n if (swiper.isEnd) {\n swiper.a11y.disableEl($nextEl);\n } else {\n swiper.a11y.enableEl($nextEl);\n }\n }\n },\n updatePagination: function updatePagination() {\n var swiper = this;\n var params = swiper.params.a11y;\n if (swiper.pagination && swiper.params.pagination.clickable && swiper.pagination.bullets && swiper.pagination.bullets.length) {\n swiper.pagination.bullets.each(function (bulletIndex, bulletEl) {\n var $bulletEl = $(bulletEl);\n swiper.a11y.makeElFocusable($bulletEl);\n swiper.a11y.addElRole($bulletEl, 'button');\n swiper.a11y.addElLabel($bulletEl, params.paginationBulletMessage.replace(/{{index}}/, $bulletEl.index() + 1));\n });\n }\n },\n init: function init() {\n var swiper = this;\n\n swiper.$el.append(swiper.a11y.liveRegion);\n\n // Navigation\n var params = swiper.params.a11y;\n var $nextEl;\n var $prevEl;\n if (swiper.navigation && swiper.navigation.$nextEl) {\n $nextEl = swiper.navigation.$nextEl;\n }\n if (swiper.navigation && swiper.navigation.$prevEl) {\n $prevEl = swiper.navigation.$prevEl;\n }\n if ($nextEl) {\n swiper.a11y.makeElFocusable($nextEl);\n swiper.a11y.addElRole($nextEl, 'button');\n swiper.a11y.addElLabel($nextEl, params.nextSlideMessage);\n $nextEl.on('keydown', swiper.a11y.onEnterKey);\n }\n if ($prevEl) {\n swiper.a11y.makeElFocusable($prevEl);\n swiper.a11y.addElRole($prevEl, 'button');\n swiper.a11y.addElLabel($prevEl, params.prevSlideMessage);\n $prevEl.on('keydown', swiper.a11y.onEnterKey);\n }\n\n // Pagination\n if (swiper.pagination && swiper.params.pagination.clickable && swiper.pagination.bullets && swiper.pagination.bullets.length) {\n swiper.pagination.$el.on('keydown', (\".\" + (swiper.params.pagination.bulletClass)), swiper.a11y.onEnterKey);\n }\n },\n destroy: function destroy() {\n var swiper = this;\n if (swiper.a11y.liveRegion && swiper.a11y.liveRegion.length > 0) { swiper.a11y.liveRegion.remove(); }\n\n var $nextEl;\n var $prevEl;\n if (swiper.navigation && swiper.navigation.$nextEl) {\n $nextEl = swiper.navigation.$nextEl;\n }\n if (swiper.navigation && swiper.navigation.$prevEl) {\n $prevEl = swiper.navigation.$prevEl;\n }\n if ($nextEl) {\n $nextEl.off('keydown', swiper.a11y.onEnterKey);\n }\n if ($prevEl) {\n $prevEl.off('keydown', swiper.a11y.onEnterKey);\n }\n\n // Pagination\n if (swiper.pagination && swiper.params.pagination.clickable && swiper.pagination.bullets && swiper.pagination.bullets.length) {\n swiper.pagination.$el.off('keydown', (\".\" + (swiper.params.pagination.bulletClass)), swiper.a11y.onEnterKey);\n }\n },\n };\n var A11y = {\n name: 'a11y',\n params: {\n a11y: {\n enabled: true,\n notificationClass: 'swiper-notification',\n prevSlideMessage: 'Previous slide',\n nextSlideMessage: 'Next slide',\n firstSlideMessage: 'This is the first slide',\n lastSlideMessage: 'This is the last slide',\n paginationBulletMessage: 'Go to slide {{index}}',\n },\n },\n create: function create() {\n var swiper = this;\n Utils.extend(swiper, {\n a11y: {\n liveRegion: $((\"<span class=\\\"\" + (swiper.params.a11y.notificationClass) + \"\\\" aria-live=\\\"assertive\\\" aria-atomic=\\\"true\\\"></span>\")),\n },\n });\n Object.keys(a11y).forEach(function (methodName) {\n swiper.a11y[methodName] = a11y[methodName].bind(swiper);\n });\n },\n on: {\n init: function init() {\n var swiper = this;\n if (!swiper.params.a11y.enabled) { return; }\n swiper.a11y.init();\n swiper.a11y.updateNavigation();\n },\n toEdge: function toEdge() {\n var swiper = this;\n if (!swiper.params.a11y.enabled) { return; }\n swiper.a11y.updateNavigation();\n },\n fromEdge: function fromEdge() {\n var swiper = this;\n if (!swiper.params.a11y.enabled) { return; }\n swiper.a11y.updateNavigation();\n },\n paginationUpdate: function paginationUpdate() {\n var swiper = this;\n if (!swiper.params.a11y.enabled) { return; }\n swiper.a11y.updatePagination();\n },\n destroy: function destroy() {\n var swiper = this;\n if (!swiper.params.a11y.enabled) { return; }\n swiper.a11y.destroy();\n },\n },\n };\n\n var History = {\n init: function init() {\n var swiper = this;\n if (!swiper.params.history) { return; }\n if (!win.history || !win.history.pushState) {\n swiper.params.history.enabled = false;\n swiper.params.hashNavigation.enabled = true;\n return;\n }\n var history = swiper.history;\n history.initialized = true;\n history.paths = History.getPathValues();\n if (!history.paths.key && !history.paths.value) { return; }\n history.scrollToSlide(0, history.paths.value, swiper.params.runCallbacksOnInit);\n if (!swiper.params.history.replaceState) {\n win.addEventListener('popstate', swiper.history.setHistoryPopState);\n }\n },\n destroy: function destroy() {\n var swiper = this;\n if (!swiper.params.history.replaceState) {\n win.removeEventListener('popstate', swiper.history.setHistoryPopState);\n }\n },\n setHistoryPopState: function setHistoryPopState() {\n var swiper = this;\n swiper.history.paths = History.getPathValues();\n swiper.history.scrollToSlide(swiper.params.speed, swiper.history.paths.value, false);\n },\n getPathValues: function getPathValues() {\n var pathArray = win.location.pathname.slice(1).split('/').filter(function (part) { return part !== ''; });\n var total = pathArray.length;\n var key = pathArray[total - 2];\n var value = pathArray[total - 1];\n return { key: key, value: value };\n },\n setHistory: function setHistory(key, index) {\n var swiper = this;\n if (!swiper.history.initialized || !swiper.params.history.enabled) { return; }\n var slide = swiper.slides.eq(index);\n var value = History.slugify(slide.attr('data-history'));\n if (!win.location.pathname.includes(key)) {\n value = key + \"/\" + value;\n }\n var currentState = win.history.state;\n if (currentState && currentState.value === value) {\n return;\n }\n if (swiper.params.history.replaceState) {\n win.history.replaceState({ value: value }, null, value);\n } else {\n win.history.pushState({ value: value }, null, value);\n }\n },\n slugify: function slugify(text) {\n return text.toString()\n .replace(/\\s+/g, '-')\n .replace(/[^\\w-]+/g, '')\n .replace(/--+/g, '-')\n .replace(/^-+/, '')\n .replace(/-+$/, '');\n },\n scrollToSlide: function scrollToSlide(speed, value, runCallbacks) {\n var swiper = this;\n if (value) {\n for (var i = 0, length = swiper.slides.length; i < length; i += 1) {\n var slide = swiper.slides.eq(i);\n var slideHistory = History.slugify(slide.attr('data-history'));\n if (slideHistory === value && !slide.hasClass(swiper.params.slideDuplicateClass)) {\n var index = slide.index();\n swiper.slideTo(index, speed, runCallbacks);\n }\n }\n } else {\n swiper.slideTo(0, speed, runCallbacks);\n }\n },\n };\n\n var History$1 = {\n name: 'history',\n params: {\n history: {\n enabled: false,\n replaceState: false,\n key: 'slides',\n },\n },\n create: function create() {\n var swiper = this;\n Utils.extend(swiper, {\n history: {\n init: History.init.bind(swiper),\n setHistory: History.setHistory.bind(swiper),\n setHistoryPopState: History.setHistoryPopState.bind(swiper),\n scrollToSlide: History.scrollToSlide.bind(swiper),\n destroy: History.destroy.bind(swiper),\n },\n });\n },\n on: {\n init: function init() {\n var swiper = this;\n if (swiper.params.history.enabled) {\n swiper.history.init();\n }\n },\n destroy: function destroy() {\n var swiper = this;\n if (swiper.params.history.enabled) {\n swiper.history.destroy();\n }\n },\n transitionEnd: function transitionEnd() {\n var swiper = this;\n if (swiper.history.initialized) {\n swiper.history.setHistory(swiper.params.history.key, swiper.activeIndex);\n }\n },\n },\n };\n\n var HashNavigation = {\n onHashCange: function onHashCange() {\n var swiper = this;\n var newHash = doc.location.hash.replace('#', '');\n var activeSlideHash = swiper.slides.eq(swiper.activeIndex).attr('data-hash');\n if (newHash !== activeSlideHash) {\n var newIndex = swiper.$wrapperEl.children((\".\" + (swiper.params.slideClass) + \"[data-hash=\\\"\" + newHash + \"\\\"]\")).index();\n if (typeof newIndex === 'undefined') { return; }\n swiper.slideTo(newIndex);\n }\n },\n setHash: function setHash() {\n var swiper = this;\n if (!swiper.hashNavigation.initialized || !swiper.params.hashNavigation.enabled) { return; }\n if (swiper.params.hashNavigation.replaceState && win.history && win.history.replaceState) {\n win.history.replaceState(null, null, ((\"#\" + (swiper.slides.eq(swiper.activeIndex).attr('data-hash'))) || ''));\n } else {\n var slide = swiper.slides.eq(swiper.activeIndex);\n var hash = slide.attr('data-hash') || slide.attr('data-history');\n doc.location.hash = hash || '';\n }\n },\n init: function init() {\n var swiper = this;\n if (!swiper.params.hashNavigation.enabled || (swiper.params.history && swiper.params.history.enabled)) { return; }\n swiper.hashNavigation.initialized = true;\n var hash = doc.location.hash.replace('#', '');\n if (hash) {\n var speed = 0;\n for (var i = 0, length = swiper.slides.length; i < length; i += 1) {\n var slide = swiper.slides.eq(i);\n var slideHash = slide.attr('data-hash') || slide.attr('data-history');\n if (slideHash === hash && !slide.hasClass(swiper.params.slideDuplicateClass)) {\n var index = slide.index();\n swiper.slideTo(index, speed, swiper.params.runCallbacksOnInit, true);\n }\n }\n }\n if (swiper.params.hashNavigation.watchState) {\n $(win).on('hashchange', swiper.hashNavigation.onHashCange);\n }\n },\n destroy: function destroy() {\n var swiper = this;\n if (swiper.params.hashNavigation.watchState) {\n $(win).off('hashchange', swiper.hashNavigation.onHashCange);\n }\n },\n };\n var HashNavigation$1 = {\n name: 'hash-navigation',\n params: {\n hashNavigation: {\n enabled: false,\n replaceState: false,\n watchState: false,\n },\n },\n create: function create() {\n var swiper = this;\n Utils.extend(swiper, {\n hashNavigation: {\n initialized: false,\n init: HashNavigation.init.bind(swiper),\n destroy: HashNavigation.destroy.bind(swiper),\n setHash: HashNavigation.setHash.bind(swiper),\n onHashCange: HashNavigation.onHashCange.bind(swiper),\n },\n });\n },\n on: {\n init: function init() {\n var swiper = this;\n if (swiper.params.hashNavigation.enabled) {\n swiper.hashNavigation.init();\n }\n },\n destroy: function destroy() {\n var swiper = this;\n if (swiper.params.hashNavigation.enabled) {\n swiper.hashNavigation.destroy();\n }\n },\n transitionEnd: function transitionEnd() {\n var swiper = this;\n if (swiper.hashNavigation.initialized) {\n swiper.hashNavigation.setHash();\n }\n },\n },\n };\n\n /* eslint no-underscore-dangle: \"off\" */\n\n var Autoplay = {\n run: function run() {\n var swiper = this;\n var $activeSlideEl = swiper.slides.eq(swiper.activeIndex);\n var delay = swiper.params.autoplay.delay;\n if ($activeSlideEl.attr('data-swiper-autoplay')) {\n delay = $activeSlideEl.attr('data-swiper-autoplay') || swiper.params.autoplay.delay;\n }\n clearTimeout(swiper.autoplay.timeout);\n swiper.autoplay.timeout = Utils.nextTick(function () {\n if (swiper.params.autoplay.reverseDirection) {\n if (swiper.params.loop) {\n swiper.loopFix();\n swiper.slidePrev(swiper.params.speed, true, true);\n swiper.emit('autoplay');\n } else if (!swiper.isBeginning) {\n swiper.slidePrev(swiper.params.speed, true, true);\n swiper.emit('autoplay');\n } else if (!swiper.params.autoplay.stopOnLastSlide) {\n swiper.slideTo(swiper.slides.length - 1, swiper.params.speed, true, true);\n swiper.emit('autoplay');\n } else {\n swiper.autoplay.stop();\n }\n } else if (swiper.params.loop) {\n swiper.loopFix();\n swiper.slideNext(swiper.params.speed, true, true);\n swiper.emit('autoplay');\n } else if (!swiper.isEnd) {\n swiper.slideNext(swiper.params.speed, true, true);\n swiper.emit('autoplay');\n } else if (!swiper.params.autoplay.stopOnLastSlide) {\n swiper.slideTo(0, swiper.params.speed, true, true);\n swiper.emit('autoplay');\n } else {\n swiper.autoplay.stop();\n }\n }, delay);\n },\n start: function start() {\n var swiper = this;\n if (typeof swiper.autoplay.timeout !== 'undefined') { return false; }\n if (swiper.autoplay.running) { return false; }\n swiper.autoplay.running = true;\n swiper.emit('autoplayStart');\n swiper.autoplay.run();\n return true;\n },\n stop: function stop() {\n var swiper = this;\n if (!swiper.autoplay.running) { return false; }\n if (typeof swiper.autoplay.timeout === 'undefined') { return false; }\n\n if (swiper.autoplay.timeout) {\n clearTimeout(swiper.autoplay.timeout);\n swiper.autoplay.timeout = undefined;\n }\n swiper.autoplay.running = false;\n swiper.emit('autoplayStop');\n return true;\n },\n pause: function pause(speed) {\n var swiper = this;\n if (!swiper.autoplay.running) { return; }\n if (swiper.autoplay.paused) { return; }\n if (swiper.autoplay.timeout) { clearTimeout(swiper.autoplay.timeout); }\n swiper.autoplay.paused = true;\n if (speed === 0 || !swiper.params.autoplay.waitForTransition) {\n swiper.autoplay.paused = false;\n swiper.autoplay.run();\n } else {\n swiper.$wrapperEl[0].addEventListener('transitionend', swiper.autoplay.onTransitionEnd);\n swiper.$wrapperEl[0].addEventListener('webkitTransitionEnd', swiper.autoplay.onTransitionEnd);\n }\n },\n };\n\n var Autoplay$1 = {\n name: 'autoplay',\n params: {\n autoplay: {\n enabled: false,\n delay: 3000,\n waitForTransition: true,\n disableOnInteraction: true,\n stopOnLastSlide: false,\n reverseDirection: false,\n },\n },\n create: function create() {\n var swiper = this;\n Utils.extend(swiper, {\n autoplay: {\n running: false,\n paused: false,\n run: Autoplay.run.bind(swiper),\n start: Autoplay.start.bind(swiper),\n stop: Autoplay.stop.bind(swiper),\n pause: Autoplay.pause.bind(swiper),\n onTransitionEnd: function onTransitionEnd(e) {\n if (!swiper || swiper.destroyed || !swiper.$wrapperEl) { return; }\n if (e.target !== this) { return; }\n swiper.$wrapperEl[0].removeEventListener('transitionend', swiper.autoplay.onTransitionEnd);\n swiper.$wrapperEl[0].removeEventListener('webkitTransitionEnd', swiper.autoplay.onTransitionEnd);\n swiper.autoplay.paused = false;\n if (!swiper.autoplay.running) {\n swiper.autoplay.stop();\n } else {\n swiper.autoplay.run();\n }\n },\n },\n });\n },\n on: {\n init: function init() {\n var swiper = this;\n if (swiper.params.autoplay.enabled) {\n swiper.autoplay.start();\n }\n },\n beforeTransitionStart: function beforeTransitionStart(speed, internal) {\n var swiper = this;\n if (swiper.autoplay.running) {\n if (internal || !swiper.params.autoplay.disableOnInteraction) {\n swiper.autoplay.pause(speed);\n } else {\n swiper.autoplay.stop();\n }\n }\n },\n sliderFirstMove: function sliderFirstMove() {\n var swiper = this;\n if (swiper.autoplay.running) {\n if (swiper.params.autoplay.disableOnInteraction) {\n swiper.autoplay.stop();\n } else {\n swiper.autoplay.pause();\n }\n }\n },\n destroy: function destroy() {\n var swiper = this;\n if (swiper.autoplay.running) {\n swiper.autoplay.stop();\n }\n },\n },\n };\n\n var Fade = {\n setTranslate: function setTranslate() {\n var swiper = this;\n var slides = swiper.slides;\n for (var i = 0; i < slides.length; i += 1) {\n var $slideEl = swiper.slides.eq(i);\n var offset = $slideEl[0].swiperSlideOffset;\n var tx = -offset;\n if (!swiper.params.virtualTranslate) { tx -= swiper.translate; }\n var ty = 0;\n if (!swiper.isHorizontal()) {\n ty = tx;\n tx = 0;\n }\n var slideOpacity = swiper.params.fadeEffect.crossFade\n ? Math.max(1 - Math.abs($slideEl[0].progress), 0)\n : 1 + Math.min(Math.max($slideEl[0].progress, -1), 0);\n $slideEl\n .css({\n opacity: slideOpacity,\n })\n .transform((\"translate3d(\" + tx + \"px, \" + ty + \"px, 0px)\"));\n }\n },\n setTransition: function setTransition(duration) {\n var swiper = this;\n var slides = swiper.slides;\n var $wrapperEl = swiper.$wrapperEl;\n slides.transition(duration);\n if (swiper.params.virtualTranslate && duration !== 0) {\n var eventTriggered = false;\n slides.transitionEnd(function () {\n if (eventTriggered) { return; }\n if (!swiper || swiper.destroyed) { return; }\n eventTriggered = true;\n swiper.animating = false;\n var triggerEvents = ['webkitTransitionEnd', 'transitionend'];\n for (var i = 0; i < triggerEvents.length; i += 1) {\n $wrapperEl.trigger(triggerEvents[i]);\n }\n });\n }\n },\n };\n\n var EffectFade = {\n name: 'effect-fade',\n params: {\n fadeEffect: {\n crossFade: false,\n },\n },\n create: function create() {\n var swiper = this;\n Utils.extend(swiper, {\n fadeEffect: {\n setTranslate: Fade.setTranslate.bind(swiper),\n setTransition: Fade.setTransition.bind(swiper),\n },\n });\n },\n on: {\n beforeInit: function beforeInit() {\n var swiper = this;\n if (swiper.params.effect !== 'fade') { return; }\n swiper.classNames.push(((swiper.params.containerModifierClass) + \"fade\"));\n var overwriteParams = {\n slidesPerView: 1,\n slidesPerColumn: 1,\n slidesPerGroup: 1,\n watchSlidesProgress: true,\n spaceBetween: 0,\n virtualTranslate: true,\n };\n Utils.extend(swiper.params, overwriteParams);\n Utils.extend(swiper.originalParams, overwriteParams);\n },\n setTranslate: function setTranslate() {\n var swiper = this;\n if (swiper.params.effect !== 'fade') { return; }\n swiper.fadeEffect.setTranslate();\n },\n setTransition: function setTransition(duration) {\n var swiper = this;\n if (swiper.params.effect !== 'fade') { return; }\n swiper.fadeEffect.setTransition(duration);\n },\n },\n };\n\n var Cube = {\n setTranslate: function setTranslate() {\n var swiper = this;\n var $el = swiper.$el;\n var $wrapperEl = swiper.$wrapperEl;\n var slides = swiper.slides;\n var swiperWidth = swiper.width;\n var swiperHeight = swiper.height;\n var rtl = swiper.rtlTranslate;\n var swiperSize = swiper.size;\n var params = swiper.params.cubeEffect;\n var isHorizontal = swiper.isHorizontal();\n var isVirtual = swiper.virtual && swiper.params.virtual.enabled;\n var wrapperRotate = 0;\n var $cubeShadowEl;\n if (params.shadow) {\n if (isHorizontal) {\n $cubeShadowEl = $wrapperEl.find('.swiper-cube-shadow');\n if ($cubeShadowEl.length === 0) {\n $cubeShadowEl = $('<div class=\"swiper-cube-shadow\"></div>');\n $wrapperEl.append($cubeShadowEl);\n }\n $cubeShadowEl.css({ height: (swiperWidth + \"px\") });\n } else {\n $cubeShadowEl = $el.find('.swiper-cube-shadow');\n if ($cubeShadowEl.length === 0) {\n $cubeShadowEl = $('<div class=\"swiper-cube-shadow\"></div>');\n $el.append($cubeShadowEl);\n }\n }\n }\n for (var i = 0; i < slides.length; i += 1) {\n var $slideEl = slides.eq(i);\n var slideIndex = i;\n if (isVirtual) {\n slideIndex = parseInt($slideEl.attr('data-swiper-slide-index'), 10);\n }\n var slideAngle = slideIndex * 90;\n var round = Math.floor(slideAngle / 360);\n if (rtl) {\n slideAngle = -slideAngle;\n round = Math.floor(-slideAngle / 360);\n }\n var progress = Math.max(Math.min($slideEl[0].progress, 1), -1);\n var tx = 0;\n var ty = 0;\n var tz = 0;\n if (slideIndex % 4 === 0) {\n tx = -round * 4 * swiperSize;\n tz = 0;\n } else if ((slideIndex - 1) % 4 === 0) {\n tx = 0;\n tz = -round * 4 * swiperSize;\n } else if ((slideIndex - 2) % 4 === 0) {\n tx = swiperSize + (round * 4 * swiperSize);\n tz = swiperSize;\n } else if ((slideIndex - 3) % 4 === 0) {\n tx = -swiperSize;\n tz = (3 * swiperSize) + (swiperSize * 4 * round);\n }\n if (rtl) {\n tx = -tx;\n }\n\n if (!isHorizontal) {\n ty = tx;\n tx = 0;\n }\n\n var transform = \"rotateX(\" + (isHorizontal ? 0 : -slideAngle) + \"deg) rotateY(\" + (isHorizontal ? slideAngle : 0) + \"deg) translate3d(\" + tx + \"px, \" + ty + \"px, \" + tz + \"px)\";\n if (progress <= 1 && progress > -1) {\n wrapperRotate = (slideIndex * 90) + (progress * 90);\n if (rtl) { wrapperRotate = (-slideIndex * 90) - (progress * 90); }\n }\n $slideEl.transform(transform);\n if (params.slideShadows) {\n // Set shadows\n var shadowBefore = isHorizontal ? $slideEl.find('.swiper-slide-shadow-left') : $slideEl.find('.swiper-slide-shadow-top');\n var shadowAfter = isHorizontal ? $slideEl.find('.swiper-slide-shadow-right') : $slideEl.find('.swiper-slide-shadow-bottom');\n if (shadowBefore.length === 0) {\n shadowBefore = $((\"<div class=\\\"swiper-slide-shadow-\" + (isHorizontal ? 'left' : 'top') + \"\\\"></div>\"));\n $slideEl.append(shadowBefore);\n }\n if (shadowAfter.length === 0) {\n shadowAfter = $((\"<div class=\\\"swiper-slide-shadow-\" + (isHorizontal ? 'right' : 'bottom') + \"\\\"></div>\"));\n $slideEl.append(shadowAfter);\n }\n if (shadowBefore.length) { shadowBefore[0].style.opacity = Math.max(-progress, 0); }\n if (shadowAfter.length) { shadowAfter[0].style.opacity = Math.max(progress, 0); }\n }\n }\n $wrapperEl.css({\n '-webkit-transform-origin': (\"50% 50% -\" + (swiperSize / 2) + \"px\"),\n '-moz-transform-origin': (\"50% 50% -\" + (swiperSize / 2) + \"px\"),\n '-ms-transform-origin': (\"50% 50% -\" + (swiperSize / 2) + \"px\"),\n 'transform-origin': (\"50% 50% -\" + (swiperSize / 2) + \"px\"),\n });\n\n if (params.shadow) {\n if (isHorizontal) {\n $cubeShadowEl.transform((\"translate3d(0px, \" + ((swiperWidth / 2) + params.shadowOffset) + \"px, \" + (-swiperWidth / 2) + \"px) rotateX(90deg) rotateZ(0deg) scale(\" + (params.shadowScale) + \")\"));\n } else {\n var shadowAngle = Math.abs(wrapperRotate) - (Math.floor(Math.abs(wrapperRotate) / 90) * 90);\n var multiplier = 1.5 - (\n (Math.sin((shadowAngle * 2 * Math.PI) / 360) / 2)\n + (Math.cos((shadowAngle * 2 * Math.PI) / 360) / 2)\n );\n var scale1 = params.shadowScale;\n var scale2 = params.shadowScale / multiplier;\n var offset = params.shadowOffset;\n $cubeShadowEl.transform((\"scale3d(\" + scale1 + \", 1, \" + scale2 + \") translate3d(0px, \" + ((swiperHeight / 2) + offset) + \"px, \" + (-swiperHeight / 2 / scale2) + \"px) rotateX(-90deg)\"));\n }\n }\n var zFactor = (Browser.isSafari || Browser.isUiWebView) ? (-swiperSize / 2) : 0;\n $wrapperEl\n .transform((\"translate3d(0px,0,\" + zFactor + \"px) rotateX(\" + (swiper.isHorizontal() ? 0 : wrapperRotate) + \"deg) rotateY(\" + (swiper.isHorizontal() ? -wrapperRotate : 0) + \"deg)\"));\n },\n setTransition: function setTransition(duration) {\n var swiper = this;\n var $el = swiper.$el;\n var slides = swiper.slides;\n slides\n .transition(duration)\n .find('.swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left')\n .transition(duration);\n if (swiper.params.cubeEffect.shadow && !swiper.isHorizontal()) {\n $el.find('.swiper-cube-shadow').transition(duration);\n }\n },\n };\n\n var EffectCube = {\n name: 'effect-cube',\n params: {\n cubeEffect: {\n slideShadows: true,\n shadow: true,\n shadowOffset: 20,\n shadowScale: 0.94,\n },\n },\n create: function create() {\n var swiper = this;\n Utils.extend(swiper, {\n cubeEffect: {\n setTranslate: Cube.setTranslate.bind(swiper),\n setTransition: Cube.setTransition.bind(swiper),\n },\n });\n },\n on: {\n beforeInit: function beforeInit() {\n var swiper = this;\n if (swiper.params.effect !== 'cube') { return; }\n swiper.classNames.push(((swiper.params.containerModifierClass) + \"cube\"));\n swiper.classNames.push(((swiper.params.containerModifierClass) + \"3d\"));\n var overwriteParams = {\n slidesPerView: 1,\n slidesPerColumn: 1,\n slidesPerGroup: 1,\n watchSlidesProgress: true,\n resistanceRatio: 0,\n spaceBetween: 0,\n centeredSlides: false,\n virtualTranslate: true,\n };\n Utils.extend(swiper.params, overwriteParams);\n Utils.extend(swiper.originalParams, overwriteParams);\n },\n setTranslate: function setTranslate() {\n var swiper = this;\n if (swiper.params.effect !== 'cube') { return; }\n swiper.cubeEffect.setTranslate();\n },\n setTransition: function setTransition(duration) {\n var swiper = this;\n if (swiper.params.effect !== 'cube') { return; }\n swiper.cubeEffect.setTransition(duration);\n },\n },\n };\n\n var Flip = {\n setTranslate: function setTranslate() {\n var swiper = this;\n var slides = swiper.slides;\n var rtl = swiper.rtlTranslate;\n for (var i = 0; i < slides.length; i += 1) {\n var $slideEl = slides.eq(i);\n var progress = $slideEl[0].progress;\n if (swiper.params.flipEffect.limitRotation) {\n progress = Math.max(Math.min($slideEl[0].progress, 1), -1);\n }\n var offset = $slideEl[0].swiperSlideOffset;\n var rotate = -180 * progress;\n var rotateY = rotate;\n var rotateX = 0;\n var tx = -offset;\n var ty = 0;\n if (!swiper.isHorizontal()) {\n ty = tx;\n tx = 0;\n rotateX = -rotateY;\n rotateY = 0;\n } else if (rtl) {\n rotateY = -rotateY;\n }\n\n $slideEl[0].style.zIndex = -Math.abs(Math.round(progress)) + slides.length;\n\n if (swiper.params.flipEffect.slideShadows) {\n // Set shadows\n var shadowBefore = swiper.isHorizontal() ? $slideEl.find('.swiper-slide-shadow-left') : $slideEl.find('.swiper-slide-shadow-top');\n var shadowAfter = swiper.isHorizontal() ? $slideEl.find('.swiper-slide-shadow-right') : $slideEl.find('.swiper-slide-shadow-bottom');\n if (shadowBefore.length === 0) {\n shadowBefore = $((\"<div class=\\\"swiper-slide-shadow-\" + (swiper.isHorizontal() ? 'left' : 'top') + \"\\\"></div>\"));\n $slideEl.append(shadowBefore);\n }\n if (shadowAfter.length === 0) {\n shadowAfter = $((\"<div class=\\\"swiper-slide-shadow-\" + (swiper.isHorizontal() ? 'right' : 'bottom') + \"\\\"></div>\"));\n $slideEl.append(shadowAfter);\n }\n if (shadowBefore.length) { shadowBefore[0].style.opacity = Math.max(-progress, 0); }\n if (shadowAfter.length) { shadowAfter[0].style.opacity = Math.max(progress, 0); }\n }\n $slideEl\n .transform((\"translate3d(\" + tx + \"px, \" + ty + \"px, 0px) rotateX(\" + rotateX + \"deg) rotateY(\" + rotateY + \"deg)\"));\n }\n },\n setTransition: function setTransition(duration) {\n var swiper = this;\n var slides = swiper.slides;\n var activeIndex = swiper.activeIndex;\n var $wrapperEl = swiper.$wrapperEl;\n slides\n .transition(duration)\n .find('.swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left')\n .transition(duration);\n if (swiper.params.virtualTranslate && duration !== 0) {\n var eventTriggered = false;\n // eslint-disable-next-line\n slides.eq(activeIndex).transitionEnd(function onTransitionEnd() {\n if (eventTriggered) { return; }\n if (!swiper || swiper.destroyed) { return; }\n // if (!$(this).hasClass(swiper.params.slideActiveClass)) return;\n eventTriggered = true;\n swiper.animating = false;\n var triggerEvents = ['webkitTransitionEnd', 'transitionend'];\n for (var i = 0; i < triggerEvents.length; i += 1) {\n $wrapperEl.trigger(triggerEvents[i]);\n }\n });\n }\n },\n };\n\n var EffectFlip = {\n name: 'effect-flip',\n params: {\n flipEffect: {\n slideShadows: true,\n limitRotation: true,\n },\n },\n create: function create() {\n var swiper = this;\n Utils.extend(swiper, {\n flipEffect: {\n setTranslate: Flip.setTranslate.bind(swiper),\n setTransition: Flip.setTransition.bind(swiper),\n },\n });\n },\n on: {\n beforeInit: function beforeInit() {\n var swiper = this;\n if (swiper.params.effect !== 'flip') { return; }\n swiper.classNames.push(((swiper.params.containerModifierClass) + \"flip\"));\n swiper.classNames.push(((swiper.params.containerModifierClass) + \"3d\"));\n var overwriteParams = {\n slidesPerView: 1,\n slidesPerColumn: 1,\n slidesPerGroup: 1,\n watchSlidesProgress: true,\n spaceBetween: 0,\n virtualTranslate: true,\n };\n Utils.extend(swiper.params, overwriteParams);\n Utils.extend(swiper.originalParams, overwriteParams);\n },\n setTranslate: function setTranslate() {\n var swiper = this;\n if (swiper.params.effect !== 'flip') { return; }\n swiper.flipEffect.setTranslate();\n },\n setTransition: function setTransition(duration) {\n var swiper = this;\n if (swiper.params.effect !== 'flip') { return; }\n swiper.flipEffect.setTransition(duration);\n },\n },\n };\n\n var Coverflow = {\n setTranslate: function setTranslate() {\n var swiper = this;\n var swiperWidth = swiper.width;\n var swiperHeight = swiper.height;\n var slides = swiper.slides;\n var $wrapperEl = swiper.$wrapperEl;\n var slidesSizesGrid = swiper.slidesSizesGrid;\n var params = swiper.params.coverflowEffect;\n var isHorizontal = swiper.isHorizontal();\n var transform = swiper.translate;\n var center = isHorizontal ? -transform + (swiperWidth / 2) : -transform + (swiperHeight / 2);\n var rotate = isHorizontal ? params.rotate : -params.rotate;\n var translate = params.depth;\n // Each slide offset from center\n for (var i = 0, length = slides.length; i < length; i += 1) {\n var $slideEl = slides.eq(i);\n var slideSize = slidesSizesGrid[i];\n var slideOffset = $slideEl[0].swiperSlideOffset;\n var offsetMultiplier = ((center - slideOffset - (slideSize / 2)) / slideSize) * params.modifier;\n\n var rotateY = isHorizontal ? rotate * offsetMultiplier : 0;\n var rotateX = isHorizontal ? 0 : rotate * offsetMultiplier;\n // var rotateZ = 0\n var translateZ = -translate * Math.abs(offsetMultiplier);\n\n var translateY = isHorizontal ? 0 : params.stretch * (offsetMultiplier);\n var translateX = isHorizontal ? params.stretch * (offsetMultiplier) : 0;\n\n // Fix for ultra small values\n if (Math.abs(translateX) < 0.001) { translateX = 0; }\n if (Math.abs(translateY) < 0.001) { translateY = 0; }\n if (Math.abs(translateZ) < 0.001) { translateZ = 0; }\n if (Math.abs(rotateY) < 0.001) { rotateY = 0; }\n if (Math.abs(rotateX) < 0.001) { rotateX = 0; }\n\n var slideTransform = \"translate3d(\" + translateX + \"px,\" + translateY + \"px,\" + translateZ + \"px) rotateX(\" + rotateX + \"deg) rotateY(\" + rotateY + \"deg)\";\n\n $slideEl.transform(slideTransform);\n $slideEl[0].style.zIndex = -Math.abs(Math.round(offsetMultiplier)) + 1;\n if (params.slideShadows) {\n // Set shadows\n var $shadowBeforeEl = isHorizontal ? $slideEl.find('.swiper-slide-shadow-left') : $slideEl.find('.swiper-slide-shadow-top');\n var $shadowAfterEl = isHorizontal ? $slideEl.find('.swiper-slide-shadow-right') : $slideEl.find('.swiper-slide-shadow-bottom');\n if ($shadowBeforeEl.length === 0) {\n $shadowBeforeEl = $((\"<div class=\\\"swiper-slide-shadow-\" + (isHorizontal ? 'left' : 'top') + \"\\\"></div>\"));\n $slideEl.append($shadowBeforeEl);\n }\n if ($shadowAfterEl.length === 0) {\n $shadowAfterEl = $((\"<div class=\\\"swiper-slide-shadow-\" + (isHorizontal ? 'right' : 'bottom') + \"\\\"></div>\"));\n $slideEl.append($shadowAfterEl);\n }\n if ($shadowBeforeEl.length) { $shadowBeforeEl[0].style.opacity = offsetMultiplier > 0 ? offsetMultiplier : 0; }\n if ($shadowAfterEl.length) { $shadowAfterEl[0].style.opacity = (-offsetMultiplier) > 0 ? -offsetMultiplier : 0; }\n }\n }\n\n // Set correct perspective for IE10\n if (Support.pointerEvents || Support.prefixedPointerEvents) {\n var ws = $wrapperEl[0].style;\n ws.perspectiveOrigin = center + \"px 50%\";\n }\n },\n setTransition: function setTransition(duration) {\n var swiper = this;\n swiper.slides\n .transition(duration)\n .find('.swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left')\n .transition(duration);\n },\n };\n\n var EffectCoverflow = {\n name: 'effect-coverflow',\n params: {\n coverflowEffect: {\n rotate: 50,\n stretch: 0,\n depth: 100,\n modifier: 1,\n slideShadows: true,\n },\n },\n create: function create() {\n var swiper = this;\n Utils.extend(swiper, {\n coverflowEffect: {\n setTranslate: Coverflow.setTranslate.bind(swiper),\n setTransition: Coverflow.setTransition.bind(swiper),\n },\n });\n },\n on: {\n beforeInit: function beforeInit() {\n var swiper = this;\n if (swiper.params.effect !== 'coverflow') { return; }\n\n swiper.classNames.push(((swiper.params.containerModifierClass) + \"coverflow\"));\n swiper.classNames.push(((swiper.params.containerModifierClass) + \"3d\"));\n\n swiper.params.watchSlidesProgress = true;\n swiper.originalParams.watchSlidesProgress = true;\n },\n setTranslate: function setTranslate() {\n var swiper = this;\n if (swiper.params.effect !== 'coverflow') { return; }\n swiper.coverflowEffect.setTranslate();\n },\n setTransition: function setTransition(duration) {\n var swiper = this;\n if (swiper.params.effect !== 'coverflow') { return; }\n swiper.coverflowEffect.setTransition(duration);\n },\n },\n };\n\n var Thumbs = {\n init: function init() {\n var swiper = this;\n var ref = swiper.params;\n var thumbsParams = ref.thumbs;\n var SwiperClass = swiper.constructor;\n if (thumbsParams.swiper instanceof SwiperClass) {\n swiper.thumbs.swiper = thumbsParams.swiper;\n Utils.extend(swiper.thumbs.swiper.originalParams, {\n watchSlidesProgress: true,\n slideToClickedSlide: false,\n });\n Utils.extend(swiper.thumbs.swiper.params, {\n watchSlidesProgress: true,\n slideToClickedSlide: false,\n });\n } else if (Utils.isObject(thumbsParams.swiper)) {\n swiper.thumbs.swiper = new SwiperClass(Utils.extend({}, thumbsParams.swiper, {\n watchSlidesVisibility: true,\n watchSlidesProgress: true,\n slideToClickedSlide: false,\n }));\n swiper.thumbs.swiperCreated = true;\n }\n swiper.thumbs.swiper.$el.addClass(swiper.params.thumbs.thumbsContainerClass);\n swiper.thumbs.swiper.on('tap', swiper.thumbs.onThumbClick);\n },\n onThumbClick: function onThumbClick() {\n var swiper = this;\n var thumbsSwiper = swiper.thumbs.swiper;\n if (!thumbsSwiper) { return; }\n var clickedIndex = thumbsSwiper.clickedIndex;\n var clickedSlide = thumbsSwiper.clickedSlide;\n if (clickedSlide && $(clickedSlide).hasClass(swiper.params.thumbs.slideThumbActiveClass)) { return; }\n if (typeof clickedIndex === 'undefined' || clickedIndex === null) { return; }\n var slideToIndex;\n if (thumbsSwiper.params.loop) {\n slideToIndex = parseInt($(thumbsSwiper.clickedSlide).attr('data-swiper-slide-index'), 10);\n } else {\n slideToIndex = clickedIndex;\n }\n if (swiper.params.loop) {\n var currentIndex = swiper.activeIndex;\n if (swiper.slides.eq(currentIndex).hasClass(swiper.params.slideDuplicateClass)) {\n swiper.loopFix();\n // eslint-disable-next-line\n swiper._clientLeft = swiper.$wrapperEl[0].clientLeft;\n currentIndex = swiper.activeIndex;\n }\n var prevIndex = swiper.slides.eq(currentIndex).prevAll((\"[data-swiper-slide-index=\\\"\" + slideToIndex + \"\\\"]\")).eq(0).index();\n var nextIndex = swiper.slides.eq(currentIndex).nextAll((\"[data-swiper-slide-index=\\\"\" + slideToIndex + \"\\\"]\")).eq(0).index();\n if (typeof prevIndex === 'undefined') { slideToIndex = nextIndex; }\n else if (typeof nextIndex === 'undefined') { slideToIndex = prevIndex; }\n else if (nextIndex - currentIndex < currentIndex - prevIndex) { slideToIndex = nextIndex; }\n else { slideToIndex = prevIndex; }\n }\n swiper.slideTo(slideToIndex);\n },\n update: function update(initial) {\n var swiper = this;\n var thumbsSwiper = swiper.thumbs.swiper;\n if (!thumbsSwiper) { return; }\n\n var slidesPerView = thumbsSwiper.params.slidesPerView === 'auto'\n ? thumbsSwiper.slidesPerViewDynamic()\n : thumbsSwiper.params.slidesPerView;\n\n if (swiper.realIndex !== thumbsSwiper.realIndex) {\n var currentThumbsIndex = thumbsSwiper.activeIndex;\n var newThumbsIndex;\n if (thumbsSwiper.params.loop) {\n if (thumbsSwiper.slides.eq(currentThumbsIndex).hasClass(thumbsSwiper.params.slideDuplicateClass)) {\n thumbsSwiper.loopFix();\n // eslint-disable-next-line\n thumbsSwiper._clientLeft = thumbsSwiper.$wrapperEl[0].clientLeft;\n currentThumbsIndex = thumbsSwiper.activeIndex;\n }\n // Find actual thumbs index to slide to\n var prevThumbsIndex = thumbsSwiper.slides.eq(currentThumbsIndex).prevAll((\"[data-swiper-slide-index=\\\"\" + (swiper.realIndex) + \"\\\"]\")).eq(0).index();\n var nextThumbsIndex = thumbsSwiper.slides.eq(currentThumbsIndex).nextAll((\"[data-swiper-slide-index=\\\"\" + (swiper.realIndex) + \"\\\"]\")).eq(0).index();\n if (typeof prevThumbsIndex === 'undefined') { newThumbsIndex = nextThumbsIndex; }\n else if (typeof nextThumbsIndex === 'undefined') { newThumbsIndex = prevThumbsIndex; }\n else if (nextThumbsIndex - currentThumbsIndex === currentThumbsIndex - prevThumbsIndex) { newThumbsIndex = currentThumbsIndex; }\n else if (nextThumbsIndex - currentThumbsIndex < currentThumbsIndex - prevThumbsIndex) { newThumbsIndex = nextThumbsIndex; }\n else { newThumbsIndex = prevThumbsIndex; }\n } else {\n newThumbsIndex = swiper.realIndex;\n }\n if (thumbsSwiper.visibleSlidesIndexes && thumbsSwiper.visibleSlidesIndexes.indexOf(newThumbsIndex) < 0) {\n if (thumbsSwiper.params.centeredSlides) {\n if (newThumbsIndex > currentThumbsIndex) {\n newThumbsIndex = newThumbsIndex - Math.floor(slidesPerView / 2) + 1;\n } else {\n newThumbsIndex = newThumbsIndex + Math.floor(slidesPerView / 2) - 1;\n }\n } else if (newThumbsIndex > currentThumbsIndex) {\n newThumbsIndex = newThumbsIndex - slidesPerView + 1;\n }\n thumbsSwiper.slideTo(newThumbsIndex, initial ? 0 : undefined);\n }\n }\n\n // Activate thumbs\n var thumbsToActivate = 1;\n var thumbActiveClass = swiper.params.thumbs.slideThumbActiveClass;\n\n if (swiper.params.slidesPerView > 1 && !swiper.params.centeredSlides) {\n thumbsToActivate = swiper.params.slidesPerView;\n }\n\n thumbsSwiper.slides.removeClass(thumbActiveClass);\n if (thumbsSwiper.params.loop || thumbsSwiper.params.virtual) {\n for (var i = 0; i < thumbsToActivate; i += 1) {\n thumbsSwiper.$wrapperEl.children((\"[data-swiper-slide-index=\\\"\" + (swiper.realIndex + i) + \"\\\"]\")).addClass(thumbActiveClass);\n }\n } else {\n for (var i$1 = 0; i$1 < thumbsToActivate; i$1 += 1) {\n thumbsSwiper.slides.eq(swiper.realIndex + i$1).addClass(thumbActiveClass);\n }\n }\n },\n };\n var Thumbs$1 = {\n name: 'thumbs',\n params: {\n thumbs: {\n swiper: null,\n slideThumbActiveClass: 'swiper-slide-thumb-active',\n thumbsContainerClass: 'swiper-container-thumbs',\n },\n },\n create: function create() {\n var swiper = this;\n Utils.extend(swiper, {\n thumbs: {\n swiper: null,\n init: Thumbs.init.bind(swiper),\n update: Thumbs.update.bind(swiper),\n onThumbClick: Thumbs.onThumbClick.bind(swiper),\n },\n });\n },\n on: {\n beforeInit: function beforeInit() {\n var swiper = this;\n var ref = swiper.params;\n var thumbs = ref.thumbs;\n if (!thumbs || !thumbs.swiper) { return; }\n swiper.thumbs.init();\n swiper.thumbs.update(true);\n },\n slideChange: function slideChange() {\n var swiper = this;\n if (!swiper.thumbs.swiper) { return; }\n swiper.thumbs.update();\n },\n update: function update() {\n var swiper = this;\n if (!swiper.thumbs.swiper) { return; }\n swiper.thumbs.update();\n },\n resize: function resize() {\n var swiper = this;\n if (!swiper.thumbs.swiper) { return; }\n swiper.thumbs.update();\n },\n observerUpdate: function observerUpdate() {\n var swiper = this;\n if (!swiper.thumbs.swiper) { return; }\n swiper.thumbs.update();\n },\n setTransition: function setTransition(duration) {\n var swiper = this;\n var thumbsSwiper = swiper.thumbs.swiper;\n if (!thumbsSwiper) { return; }\n thumbsSwiper.setTransition(duration);\n },\n beforeDestroy: function beforeDestroy() {\n var swiper = this;\n var thumbsSwiper = swiper.thumbs.swiper;\n if (!thumbsSwiper) { return; }\n if (swiper.thumbs.swiperCreated && thumbsSwiper) {\n thumbsSwiper.destroy();\n }\n },\n },\n };\n\n // Swiper Class\n\n var components = [\n Device$1,\n Support$1,\n Browser$1,\n Resize,\n Observer$1,\n Virtual$1,\n Keyboard$1,\n Mousewheel$1,\n Navigation$1,\n Pagination$1,\n Scrollbar$1,\n Parallax$1,\n Zoom$1,\n Lazy$1,\n Controller$1,\n A11y,\n History$1,\n HashNavigation$1,\n Autoplay$1,\n EffectFade,\n EffectCube,\n EffectFlip,\n EffectCoverflow,\n Thumbs$1\n ];\n\n if (typeof Swiper.use === 'undefined') {\n Swiper.use = Swiper.Class.use;\n Swiper.installModule = Swiper.Class.installModule;\n }\n\n Swiper.use(components);\n\n return Swiper;\n\n}));\n","module.exports = __webpack_public_path__ + \"img/tm.b5f65296.svg\";","module.exports = __webpack_public_path__ + \"img/et.15040bfc.svg\";","module.exports = __webpack_public_path__ + \"img/pe.89b9f8a2.svg\";","module.exports = __webpack_public_path__ + \"img/kp.a270b79c.svg\";","module.exports = __webpack_public_path__ + \"img/mq.55df0a2e.svg\";","module.exports = __webpack_public_path__ + \"img/kw.b3d9907a.svg\";","module.exports = __webpack_public_path__ + \"img/kn.ad086c55.svg\";","module.exports = __webpack_public_path__ + \"img/whatsapp.9c2f5908.png\";","module.exports = __webpack_public_path__ + \"img/me.749d2e34.svg\";","module.exports = __webpack_public_path__ + \"img/fr.55df0a2e.svg\";","module.exports = __webpack_public_path__ + \"img/ky.69021ebc.svg\";","module.exports = __webpack_public_path__ + \"img/ws.adcc72ee.svg\";","// extracted by mini-css-extract-plugin","module.exports = __webpack_public_path__ + \"img/telephone.07c3bfa0.png\";","module.exports = __webpack_public_path__ + \"img/sl.890bdc29.svg\";","module.exports = __webpack_public_path__ + \"img/ad.b8bed3d2.svg\";","module.exports = __webpack_public_path__ + \"img/ye.1a89616e.svg\";","module.exports = __webpack_public_path__ + \"img/sg.14be03f1.svg\";","module.exports = __webpack_public_path__ + \"img/ng.ae382946.svg\";","module.exports = __webpack_public_path__ + \"img/au.e875a51e.svg\";","module.exports = __webpack_public_path__ + \"img/ne.465d9739.svg\";","module.exports = __webpack_public_path__ + \"img/mu.ca7b8131.svg\";","module.exports = __webpack_public_path__ + \"img/cc.a8ffbd16.svg\";","module.exports = \"data:image/png;base64,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\"","module.exports = __webpack_public_path__ + \"img/eh.242720f7.svg\";","module.exports = __webpack_public_path__ + \"img/bs.f74bac51.svg\";","module.exports = __webpack_public_path__ + \"img/pk.f33c2297.svg\";","module.exports = __webpack_public_path__ + \"img/il.033c38c0.svg\";","module.exports = __webpack_public_path__ + \"img/ao.2359a082.svg\";","module.exports = __webpack_public_path__ + \"img/br.92fc6153.svg\";","module.exports = __webpack_public_path__ + \"img/az.b02e1d89.svg\";","module.exports = __webpack_public_path__ + \"img/ir.5ce127e4.svg\";","module.exports = __webpack_public_path__ + \"img/in.69b796ab.svg\";","module.exports = __webpack_public_path__ + \"img/lv.12cebcfb.svg\";","module.exports = __webpack_public_path__ + \"img/gq.5dc050f9.svg\";","module.exports = __webpack_public_path__ + \"img/zm.112bea3f.svg\";","module.exports = __webpack_public_path__ + \"img/bl.55df0a2e.svg\";","module.exports = __webpack_public_path__ + \"img/gs.7b917516.svg\";","module.exports = __webpack_public_path__ + \"img/sd.ea2d2bd4.svg\";","module.exports = __webpack_public_path__ + \"img/cw.c92a4146.svg\";","module.exports = __webpack_public_path__ + \"img/mn.7bd9a92b.svg\";","module.exports = __webpack_public_path__ + \"img/ee.dd2a64a6.svg\";","module.exports = __webpack_public_path__ + \"img/lr.3de4997b.svg\";","module.exports = __webpack_public_path__ + \"img/hr.f4e06f4d.svg\";","module.exports = __webpack_public_path__ + \"img/dk.76cf3e39.svg\";","module.exports = __webpack_public_path__ + \"img/bb.1fe811b7.svg\";","module.exports = __webpack_public_path__ + \"img/gh.28ab14b2.svg\";","module.exports = __webpack_public_path__ + \"img/so.f89e77ad.svg\";","module.exports = __webpack_public_path__ + \"img/zw.bc893918.svg\";","module.exports = __webpack_public_path__ + \"img/er.2ad12126.svg\";","module.exports = __webpack_public_path__ + \"img/tn.22c29ff7.svg\";","module.exports = __webpack_public_path__ + \"img/dj.02e75e20.svg\";","module.exports = __webpack_public_path__ + \"img/ke.bbb6db06.svg\";","module.exports = __webpack_public_path__ + \"img/tl.f0649357.svg\";","module.exports = __webpack_public_path__ + \"img/bn.7b712c9b.svg\";","module.exports = __webpack_public_path__ + \"img/gr.abd7d677.svg\";","module.exports = __webpack_public_path__ + \"img/home-world-bg.f70a74e8.png\";","module.exports = __webpack_public_path__ + \"img/bj.2f8ccc90.svg\";","module.exports = __webpack_public_path__ + \"img/lt.60ce52ef.svg\";","module.exports = __webpack_public_path__ + \"img/gd.471a003b.svg\";","module.exports = __webpack_public_path__ + \"img/bf.c07fc50c.svg\";","module.exports = __webpack_public_path__ + \"img/li.3518ccf5.svg\";","module.exports = __webpack_public_path__ + \"img/mc.9ce1d042.svg\";","module.exports = __webpack_public_path__ + \"img/ml.9030b284.svg\";","// extracted by mini-css-extract-plugin","module.exports = __webpack_public_path__ + \"img/ve.243693de.svg\";","module.exports = __webpack_public_path__ + \"img/nr.6b72bbc1.svg\";","module.exports = __webpack_public_path__ + \"img/km.780746a1.svg\";","module.exports = __webpack_public_path__ + \"img/bt.0247753b.svg\";","module.exports = __webpack_public_path__ + \"img/people-icon2.6c5193fc.png\";","module.exports = __webpack_public_path__ + \"img/gl.a5c256e1.svg\";","module.exports = __webpack_public_path__ + \"img/do.4ba64fb6.svg\";","module.exports = __webpack_public_path__ + \"img/sv.87a195b6.svg\";","module.exports = __webpack_public_path__ + \"img/cv.1a517aea.svg\";","var map = {\n\t\"./ad.svg\": \"1553\",\n\t\"./ae.svg\": \"4a81\",\n\t\"./af.svg\": \"49b8\",\n\t\"./ag.svg\": \"8631\",\n\t\"./ai.svg\": \"95c8\",\n\t\"./al.svg\": \"e010\",\n\t\"./am.svg\": \"7ee1\",\n\t\"./ao.svg\": \"1dc4\",\n\t\"./aq.svg\": \"78f6\",\n\t\"./ar.svg\": \"931e\",\n\t\"./as.svg\": \"768c\",\n\t\"./at.svg\": \"e66e\",\n\t\"./au.svg\": \"188c\",\n\t\"./aw.svg\": \"9fc1\",\n\t\"./ax.svg\": \"ffd0\",\n\t\"./az.svg\": \"2026\",\n\t\"./ba.svg\": \"4968\",\n\t\"./bb.svg\": \"2f2a\",\n\t\"./bd.svg\": \"f63d\",\n\t\"./be.svg\": \"a517\",\n\t\"./bf.svg\": \"3a4e\",\n\t\"./bg.svg\": \"ba13\",\n\t\"./bh.svg\": \"ba88\",\n\t\"./bi.svg\": \"def2\",\n\t\"./bj.svg\": \"39b2\",\n\t\"./bl.svg\": \"2836\",\n\t\"./bm.svg\": \"56f5\",\n\t\"./bn.svg\": \"3491\",\n\t\"./bo.svg\": \"af2c\",\n\t\"./bq.svg\": \"ec08\",\n\t\"./br.svg\": \"1e8c\",\n\t\"./bs.svg\": \"1bdf\",\n\t\"./bt.svg\": \"41c8\",\n\t\"./bv.svg\": \"006a\",\n\t\"./bw.svg\": \"5c13\",\n\t\"./by.svg\": \"b48e\",\n\t\"./bz.svg\": \"f5ed\",\n\t\"./ca.svg\": \"5a52\",\n\t\"./cc.svg\": \"1ab9\",\n\t\"./cd.svg\": \"c28f\",\n\t\"./cf.svg\": \"d1bb\",\n\t\"./cg.svg\": \"ba40\",\n\t\"./ch.svg\": \"d0ec\",\n\t\"./ci.svg\": \"9a5e\",\n\t\"./ck.svg\": \"dd62\",\n\t\"./cl.svg\": \"9416\",\n\t\"./cm.svg\": \"d6f3\",\n\t\"./cn.svg\": \"df2b\",\n\t\"./co.svg\": \"7751\",\n\t\"./cr.svg\": \"e864\",\n\t\"./cu.svg\": \"8ec1\",\n\t\"./cv.svg\": \"491c\",\n\t\"./cw.svg\": \"29de\",\n\t\"./cx.svg\": \"dde2\",\n\t\"./cy.svg\": \"e02f\",\n\t\"./cz.svg\": \"f41b\",\n\t\"./de.svg\": \"61de\",\n\t\"./dj.svg\": \"3386\",\n\t\"./dk.svg\": \"2d52\",\n\t\"./dm.svg\": \"50d0\",\n\t\"./do.svg\": \"483f\",\n\t\"./dz.svg\": \"e9b8\",\n\t\"./ec.svg\": \"c548\",\n\t\"./ee.svg\": \"2c61\",\n\t\"./eg.svg\": \"ccdd\",\n\t\"./eh.svg\": \"1b6c\",\n\t\"./er.svg\": \"3280\",\n\t\"./es.svg\": \"9468\",\n\t\"./et.svg\": \"07b3\",\n\t\"./eu.svg\": \"febc\",\n\t\"./fi.svg\": \"ac51\",\n\t\"./fj.svg\": \"5412\",\n\t\"./fk.svg\": \"0279\",\n\t\"./fm.svg\": \"af65\",\n\t\"./fo.svg\": \"b438\",\n\t\"./fr.svg\": \"108c\",\n\t\"./ga.svg\": \"f8bc\",\n\t\"./gb-eng.svg\": \"e216\",\n\t\"./gb-nir.svg\": \"77a1\",\n\t\"./gb-sct.svg\": \"9d70\",\n\t\"./gb-wls.svg\": \"b814\",\n\t\"./gb.svg\": \"5fa1\",\n\t\"./gd.svg\": \"3a3f\",\n\t\"./ge.svg\": \"65fb\",\n\t\"./gf.svg\": \"69c1\",\n\t\"./gg.svg\": \"81b4\",\n\t\"./gh.svg\": \"3104\",\n\t\"./gi.svg\": \"59f4\",\n\t\"./gl.svg\": \"4822\",\n\t\"./gm.svg\": \"ab50\",\n\t\"./gn.svg\": \"7318\",\n\t\"./gp.svg\": \"6a7d\",\n\t\"./gq.svg\": \"2740\",\n\t\"./gr.svg\": \"35bc\",\n\t\"./gs.svg\": \"28a7\",\n\t\"./gt.svg\": \"d8fc\",\n\t\"./gu.svg\": \"4a14\",\n\t\"./gw.svg\": \"910b\",\n\t\"./gy.svg\": \"e9c3\",\n\t\"./hk.svg\": \"ce21\",\n\t\"./hm.svg\": \"580f\",\n\t\"./hn.svg\": \"79d4\",\n\t\"./hr.svg\": \"2cc1\",\n\t\"./ht.svg\": \"e286\",\n\t\"./hu.svg\": \"4d36\",\n\t\"./id.svg\": \"66b3\",\n\t\"./ie.svg\": \"8ce9\",\n\t\"./il.svg\": \"1ce4\",\n\t\"./im.svg\": \"5a87\",\n\t\"./in.svg\": \"24dd\",\n\t\"./io.svg\": \"5596\",\n\t\"./iq.svg\": \"9880\",\n\t\"./ir.svg\": \"2263\",\n\t\"./is.svg\": \"9382\",\n\t\"./it.svg\": \"0154\",\n\t\"./je.svg\": \"8d0b\",\n\t\"./jm.svg\": \"adcd\",\n\t\"./jo.svg\": \"68bf\",\n\t\"./jp.svg\": \"87a0\",\n\t\"./ke.svg\": \"33ac\",\n\t\"./kg.svg\": \"c464\",\n\t\"./kh.svg\": \"ddad\",\n\t\"./ki.svg\": \"b059\",\n\t\"./km.svg\": \"4170\",\n\t\"./kn.svg\": \"0d2b\",\n\t\"./kp.svg\": \"097d\",\n\t\"./kr.svg\": \"8f52\",\n\t\"./kw.svg\": \"0cd4\",\n\t\"./ky.svg\": \"1113\",\n\t\"./kz.svg\": \"7c4e\",\n\t\"./la.svg\": \"e436\",\n\t\"./lb.svg\": \"952f\",\n\t\"./lc.svg\": \"6c88\",\n\t\"./li.svg\": \"3ac0\",\n\t\"./lk.svg\": \"6801\",\n\t\"./lr.svg\": \"2cbb\",\n\t\"./ls.svg\": \"ad13\",\n\t\"./lt.svg\": \"39b8\",\n\t\"./lu.svg\": \"a06d\",\n\t\"./lv.svg\": \"26a3\",\n\t\"./ly.svg\": \"75ef\",\n\t\"./ma.svg\": \"84b7\",\n\t\"./mc.svg\": \"3c2c\",\n\t\"./md.svg\": \"f8bf\",\n\t\"./me.svg\": \"1071\",\n\t\"./mf.svg\": \"8b0c\",\n\t\"./mg.svg\": \"d290\",\n\t\"./mh.svg\": \"8a0b\",\n\t\"./mk.svg\": \"bfb5\",\n\t\"./ml.svg\": \"3cba\",\n\t\"./mm.svg\": \"5bb7\",\n\t\"./mn.svg\": \"2a95\",\n\t\"./mo.svg\": \"b015\",\n\t\"./mp.svg\": \"cff1\",\n\t\"./mq.svg\": \"0aa4\",\n\t\"./mr.svg\": \"8ad9\",\n\t\"./ms.svg\": \"843f\",\n\t\"./mt.svg\": \"dcc5\",\n\t\"./mu.svg\": \"19da\",\n\t\"./mv.svg\": \"df9f\",\n\t\"./mw.svg\": \"d43c\",\n\t\"./mx.svg\": \"7cb1\",\n\t\"./my.svg\": \"b6e0\",\n\t\"./mz.svg\": \"4dce\",\n\t\"./na.svg\": \"8bd4\",\n\t\"./nc.svg\": \"6502\",\n\t\"./ne.svg\": \"18cb\",\n\t\"./nf.svg\": \"a0c5\",\n\t\"./ng.svg\": \"1772\",\n\t\"./ni.svg\": \"d7cc\",\n\t\"./nl.svg\": \"a58e\",\n\t\"./no.svg\": \"d27d\",\n\t\"./np.svg\": \"c426\",\n\t\"./nr.svg\": \"4136\",\n\t\"./nu.svg\": \"7401\",\n\t\"./nz.svg\": \"7157\",\n\t\"./om.svg\": \"8cd5\",\n\t\"./pa.svg\": \"bc55\",\n\t\"./pe.svg\": \"0838\",\n\t\"./pf.svg\": \"f117\",\n\t\"./pg.svg\": \"96e6\",\n\t\"./ph.svg\": \"d9fa\",\n\t\"./pk.svg\": \"1c92\",\n\t\"./pl.svg\": \"7bfd\",\n\t\"./pm.svg\": \"7c3e\",\n\t\"./pn.svg\": \"fe6f\",\n\t\"./pr.svg\": \"fc4f\",\n\t\"./ps.svg\": \"695c\",\n\t\"./pt.svg\": \"90b2\",\n\t\"./pw.svg\": \"e6b7\",\n\t\"./py.svg\": \"5479\",\n\t\"./qa.svg\": \"d0d2\",\n\t\"./re.svg\": \"5293\",\n\t\"./ro.svg\": \"7c1e\",\n\t\"./rs.svg\": \"515e\",\n\t\"./ru.svg\": \"b3e1\",\n\t\"./rw.svg\": \"b8f7\",\n\t\"./sa.svg\": \"9eba\",\n\t\"./sb.svg\": \"d829\",\n\t\"./sc.svg\": \"be80\",\n\t\"./sd.svg\": \"28f9\",\n\t\"./se.svg\": \"dfff\",\n\t\"./sg.svg\": \"174c\",\n\t\"./sh.svg\": \"95c9\",\n\t\"./si.svg\": \"7b5a\",\n\t\"./sj.svg\": \"59c0\",\n\t\"./sk.svg\": \"51c0\",\n\t\"./sl.svg\": \"143b\",\n\t\"./sm.svg\": \"87e3\",\n\t\"./sn.svg\": \"f6a3\",\n\t\"./so.svg\": \"3148\",\n\t\"./sr.svg\": \"b1a9\",\n\t\"./ss.svg\": \"81ce\",\n\t\"./st.svg\": \"a94a\",\n\t\"./sv.svg\": \"48e7\",\n\t\"./sx.svg\": \"7673\",\n\t\"./sy.svg\": \"6c52\",\n\t\"./sz.svg\": \"4c9f\",\n\t\"./tc.svg\": \"5604\",\n\t\"./td.svg\": \"5000\",\n\t\"./tf.svg\": \"76a0\",\n\t\"./tg.svg\": \"7abf\",\n\t\"./th.svg\": \"9372\",\n\t\"./tj.svg\": \"9f19\",\n\t\"./tk.svg\": \"c097\",\n\t\"./tl.svg\": \"33b3\",\n\t\"./tm.svg\": \"068d\",\n\t\"./tn.svg\": \"32eb\",\n\t\"./to.svg\": \"54a3\",\n\t\"./tr.svg\": \"bdfb\",\n\t\"./tt.svg\": \"99ce\",\n\t\"./tv.svg\": \"679e\",\n\t\"./tw.svg\": \"fb8c\",\n\t\"./tz.svg\": \"a52c\",\n\t\"./ua.svg\": \"93f2\",\n\t\"./ug.svg\": \"a244\",\n\t\"./um.svg\": \"9a71\",\n\t\"./us.svg\": \"b076\",\n\t\"./uy.svg\": \"c791\",\n\t\"./uz.svg\": \"dfb2\",\n\t\"./va.svg\": \"6ed1\",\n\t\"./vc.svg\": \"7a8b\",\n\t\"./ve.svg\": \"40c6\",\n\t\"./vg.svg\": \"651f\",\n\t\"./vi.svg\": \"02c6\",\n\t\"./vn.svg\": \"ce64\",\n\t\"./vu.svg\": \"8914\",\n\t\"./wf.svg\": \"fc22\",\n\t\"./ws.svg\": \"134b\",\n\t\"./xk.svg\": \"c78e\",\n\t\"./ye.svg\": \"15b1\",\n\t\"./yt.svg\": \"b177\",\n\t\"./za.svg\": \"b9db\",\n\t\"./zm.svg\": \"27af\",\n\t\"./zw.svg\": \"3275\"\n};\n\n\nfunction webpackContext(req) {\n\tvar id = webpackContextResolve(req);\n\treturn __webpack_require__(id);\n}\nfunction webpackContextResolve(req) {\n\tif(!__webpack_require__.o(map, req)) {\n\t\tvar e = new Error(\"Cannot find module '\" + req + \"'\");\n\t\te.code = 'MODULE_NOT_FOUND';\n\t\tthrow e;\n\t}\n\treturn map[req];\n}\nwebpackContext.keys = function webpackContextKeys() {\n\treturn Object.keys(map);\n};\nwebpackContext.resolve = webpackContextResolve;\nmodule.exports = webpackContext;\nwebpackContext.id = \"4938\";","module.exports = __webpack_public_path__ + \"img/ba.ff62357b.svg\";","module.exports = __webpack_public_path__ + \"img/af.d8fb0d22.svg\";","module.exports = __webpack_public_path__ + \"img/gu.c3db56a6.svg\";","module.exports = __webpack_public_path__ + \"img/ae.978a5276.svg\";","module.exports = \"data:image/png;base64,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\"","module.exports = __webpack_public_path__ + \"img/sz.59e2dbc4.svg\";","module.exports = __webpack_public_path__ + \"img/hu.456f4b1b.svg\";","module.exports = __webpack_public_path__ + \"img/mz.03ab17e9.svg\";","module.exports = __webpack_public_path__ + \"img/td.f6b0a98f.svg\";","module.exports = __webpack_public_path__ + \"img/dm.3a68c10d.svg\";","module.exports = __webpack_public_path__ + \"img/rs.e4159b1c.svg\";","module.exports = __webpack_public_path__ + \"img/sk.d8e0e96c.svg\";","module.exports = __webpack_public_path__ + \"img/re.55df0a2e.svg\";","module.exports = __webpack_public_path__ + \"img/fj.41e534b0.svg\";","module.exports = __webpack_public_path__ + \"img/py.9f48a110.svg\";","module.exports = __webpack_public_path__ + \"img/to.ba2127cb.svg\";","// This file is imported into lib/wc client bundles.\n\nif (typeof window !== 'undefined') {\n var currentScript = window.document.currentScript\n if (process.env.NEED_CURRENTSCRIPT_POLYFILL) {\n var getCurrentScript = require('@soda/get-current-script')\n currentScript = getCurrentScript()\n\n // for backward compatibility, because previously we directly included the polyfill\n if (!('currentScript' in document)) {\n Object.defineProperty(document, 'currentScript', { get: getCurrentScript })\n }\n }\n\n var src = currentScript && currentScript.src.match(/(.+\\/)[^/]+\\.js(\\?.*)?$/)\n if (src) {\n __webpack_public_path__ = src[1] // eslint-disable-line\n }\n}\n\n// Indicate to webpack that this file can be concatenated\nexport default null\n","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:\"carousel-component\"},[(_vm.clickDisabled)?_c('div',{staticClass:\"carousel-component-click-disabled-mask\"}):_vm._e(),(_vm.styleType === 'style1')?_c('div',{staticClass:\"carousel-component-style1\"},[_c('swiper',{attrs:{\"options\":_vm.swiperOptions}},[_vm._l((_vm.carouselList),function(item){return _c('swiper-slide',{key:item.id},[_c('img',{staticClass:\"carousel-component-swiper-img\",attrs:{\"src\":item.url,\"alt\":item.title || ''},on:{\"click\":function($event){$event.stopPropagation();return _vm.handleClick(item)}}})])}),_c('div',{staticClass:\"swiper-pagination\",attrs:{\"slot\":\"pagination\"},slot:\"pagination\"}),_c('div',{staticClass:\"swiper-button-next\",attrs:{\"slot\":\"button-next\"},slot:\"button-next\"},[_c('img',{attrs:{\"src\":_vm.assets.leftArrow,\"alt\":\"\"}})]),_c('div',{staticClass:\"swiper-button-prev\",attrs:{\"slot\":\"button-prev\"},slot:\"button-prev\"},[_c('img',{attrs:{\"src\":_vm.assets.rightArrow,\"alt\":\"\"}})])],2)],1):(_vm.styleType === 'style2')?_c('div',{staticClass:\"carousel-component-style2\"},[_c('swiper',{attrs:{\"options\":_vm.swiperOptions}},_vm._l((_vm.carouselList),function(item){return _c('swiper-slide',{key:item.id},[_c('img',{staticClass:\"carousel-component-swiper-img\",attrs:{\"src\":item.url,\"alt\":item.title || ''},on:{\"click\":function($event){$event.stopPropagation();return _vm.handleClick(item)}}})])}),1)],1):(_vm.styleType === 'style3')?_c('div'):_vm._e()])}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","import chat from './chat.png'\nimport companyIntroBg from './company-intro-bg.png'\nimport diamondIcon from './diamond-icon.png'\nimport diamondIcon2 from './diamond-icon2.png'\nimport email from './e-mail.png'\nimport equipmentIcon from './equipment-icon.png'\nimport homeWorldBg from './home-world-bg.png'\nimport language from './language.png'\nimport leftArrow from './left-arrow.svg'\nimport medalIcon from './medal-icon.png'\nimport newsCenterBg from './news-center-bg.png'\nimport peopleIcon from './people-icon.png'\nimport peopleIcon2 from './people-icon2.png'\nimport projectIcon from './project-icon.png'\nimport rIcon from './r-icon.png'\nimport telephone from './telephone.png'\nimport topIcon from './top-icon.png'\nimport whatsapp from './whatsapp.png'\n\nexport const assets = {\n // 主目录图片\n chat,\n companyIntroBg,\n diamondIcon,\n diamondIcon2,\n email,\n equipmentIcon,\n homeWorldBg,\n language,\n leftArrow,\n medalIcon,\n newsCenterBg,\n peopleIcon,\n peopleIcon2,\n projectIcon,\n rIcon,\n telephone,\n topIcon,\n whatsapp\n}\n","<template>\n <div class=\"carousel-component\">\n <!-- 点击事件禁用遮罩 -->\n <div v-if=\"clickDisabled\" class=\"carousel-component-click-disabled-mask\" />\n <!-- 占位符 -->\n <div v-if=\"styleType === 'style1'\" class=\"carousel-component-style1\">\n <!-- 样式一 -->\n <swiper :options=\"swiperOptions\">\n <swiper-slide v-for=\"item in carouselList\" :key=\"item.id\">\n <img :src=\"item.url\" :alt=\"item.title || ''\" class=\"carousel-component-swiper-img\" @click.stop=\"handleClick(item)\">\n </swiper-slide>\n\n <!-- 分页器 -->\n <div slot=\"pagination\" class=\"swiper-pagination\" />\n <!-- 导航按钮 -->\n <div slot=\"button-next\" class=\"swiper-button-next\">\n <img :src=\"assets.leftArrow\" alt=\"\">\n </div>\n <div slot=\"button-prev\" class=\"swiper-button-prev\">\n <img :src=\"assets.rightArrow\" alt=\"\">\n </div>\n </swiper>\n </div>\n <div v-else-if=\"styleType === 'style2'\" class=\"carousel-component-style2\">\n <!-- 样式二 -->\n <!-- 样式一 -->\n <swiper :options=\"swiperOptions\">\n <swiper-slide v-for=\"item in carouselList\" :key=\"item.id\">\n <img :src=\"item.url\" :alt=\"item.title || ''\" class=\"carousel-component-swiper-img\" @click.stop=\"handleClick(item)\">\n </swiper-slide>\n </swiper>\n </div>\n <div v-else-if=\"styleType === 'style3'\">\n <!-- 样式三 -->\n </div>\n </div>\n</template>\n\n<script>\n// 轮播图组件 carouselConfig组件在调整了图片顺序后,当前组件的图片展示有点问题,图片会在切换前闪一下,但是实际数据是变化了的,在展示端是没有问题的,\nimport { swiper, swiperSlide } from 'vue-awesome-swiper'\nimport 'swiper/dist/css/swiper.css'\nimport { assets } from '../../assets/index.js'\nexport default {\n name: 'CarouselComponent',\n components: {\n swiper,\n swiperSlide\n },\n props: {\n styleType: { // 选择的轮播图样式\n type: String,\n default: 'style1'\n },\n carouselList: { // 轮播图数据列表\n type: Array,\n default: () => []\n },\n clickDisabled: { // 是否给页面添加透明遮罩,防止点击\n type: Boolean,\n default: false\n },\n theme: { // 轮播图主题样式\n type: String,\n default: ''\n }\n },\n data() {\n return {\n assets: assets,\n swiperOptions: {\n slidesPerView: 1,\n loop: true,\n autoplay: {\n delay: 6000,\n stopOnLastSlide: false, // 到最后一张图后是否停止自动播放\n disableOnInteraction: false // 鼠标悬停时不停止自动播放\n },\n speed: 1000,\n // 导航按钮\n navigation: {\n nextEl: '.swiper-button-next',\n prevEl: '.swiper-button-prev'\n },\n pagination: {\n el: '.swiper-pagination',\n clickable: true // 允许分页点击跳转\n }\n },\n swiperInstance: null // 保存Swiper实例\n }\n },\n watch: {\n // 监听轮播图数据变化,重新初始化Swiper\n carouselList: {\n handler(newVal) {\n // 延迟执行,确保DOM已更新\n this.$nextTick(() => {\n // this.initSwiper()\n if (this.swiperInstance) {\n this.swiperInstance.update()\n }\n })\n },\n deep: true,\n immediate: true\n }\n },\n mounted() {\n // 组件挂载后初始化Swiper\n this.$nextTick(() => {\n this.initSwiper()\n })\n },\n methods: {\n handleClick(item) {\n if (!item.link) {\n return\n }\n window.open(item.link, '_blank')\n },\n // 初始化Swiper实例\n initSwiper() {\n // 确保有轮播图数据\n if (!this.carouselList || this.carouselList.length === 0) {\n return\n }\n\n // 如果已有实例,先销毁\n if (this.swiperInstance) {\n this.swiperInstance.destroy()\n }\n\n // 获取Swiper实例并重新初始化\n setTimeout(() => {\n const swiperElements = document.querySelectorAll('.swiper-container')\n if (swiperElements.length > 0) {\n // Vue Awesome Swiper会自动初始化,这里手动处理一些功能\n this.swiperInstance = swiperElements[0].swiper\n\n // 确保自动播放已启动\n if (this.swiperInstance && !this.swiperInstance.autoplay.running) {\n this.swiperInstance.autoplay.start()\n }\n\n // 确保导航按钮已绑定\n if (this.swiperInstance && !this.swiperInstance.navigation.initiated) {\n this.swiperInstance.navigation.init()\n this.swiperInstance.navigation.update()\n }\n\n // 确保分页器已绑定\n if (this.swiperInstance && !this.swiperInstance.pagination.initiated) {\n this.swiperInstance.pagination.init()\n this.swiperInstance.pagination.update()\n }\n }\n }, 100)\n }\n }\n}\n</script>\n\n<style scoped lang=\"scss\">\n.carousel-component {\n width: 100%;\n height: fit-content;\n min-height: 50px;\n background-color: #f5f5f5;\n background-color: #fff;\n position: relative;\n\n .carousel-component-click-disabled-mask {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n z-index: 1000;\n }\n\n .carousel-component-style1 {\n .carousel-component-swiper-img {\n width: 100%;\n height: 889px;\n display: block;\n object-fit: cover;\n }\n\n /* Swiper导航按钮样式 */\n .swiper-button-next,\n .swiper-button-prev {\n color: rgba(255, 255, 255, 0.8);\n width: 15%;\n height: 100%;\n top: 0;\n margin-top: 0;\n background-color: rgba(0, 0, 0, 0.3);\n border-radius: 50%;\n transition: all 0.3s ease;\n background: none;\n // background: url('../../assets/left-arrow.svg') no-repeat center center;\n cursor: pointer;\n opacity: 0.5;\n display: flex;\n justify-content: center;\n align-items: center;\n\n img {\n width: 20px;\n height: 20px;\n }\n\n &:hover {\n color: #fff;\n opacity: 1;\n }\n\n &::after {\n font-size: 18px;\n }\n }\n\n .swiper-button-prev {\n left: 0;\n }\n\n .swiper-button-next {\n right: 0;\n transform: rotate(180deg);\n }\n\n /* Swiper分页器样式 */\n .swiper-pagination {\n ::v-deep .swiper-pagination-bullet {\n flex: 0 1 auto;\n width: 30px;\n height: 3px;\n opacity: 1;\n margin: 0 3px;\n background: #fff;\n background-clip: padding-box;\n transition: all 0.6s ease;\n opacity: 0.5;\n border-radius: 0;\n }\n ::v-deep.swiper-pagination-bullet-active {\n opacity: 1;\n }\n }\n }\n\n .carousel-component-style2 {\n .carousel-component-swiper-img {\n width: 100%;\n height: 597px;\n display: block;\n object-fit: cover;\n }\n }\n}\n</style>\n\n","import mod from \"-!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../../../../../../node_modules/thread-loader/dist/cjs.js!../../../../../../../node_modules/babel-loader/lib/index.js!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./carousel.vue?vue&type=script&lang=js\"; export default mod; export * from \"-!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../../../../../../node_modules/thread-loader/dist/cjs.js!../../../../../../../node_modules/babel-loader/lib/index.js!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./carousel.vue?vue&type=script&lang=js\"","/* globals __VUE_SSR_CONTEXT__ */\n\n// IMPORTANT: Do NOT use ES2015 features in this file (except for modules).\n// This module is a runtime utility for cleaner component module output and will\n// be included in the final webpack user bundle.\n\nexport default function normalizeComponent(\n scriptExports,\n render,\n staticRenderFns,\n functionalTemplate,\n injectStyles,\n scopeId,\n moduleIdentifier /* server only */,\n shadowMode /* vue-cli only */\n) {\n // Vue.extend constructor export interop\n var options =\n typeof scriptExports === 'function' ? scriptExports.options : scriptExports\n\n // render functions\n if (render) {\n options.render = render\n options.staticRenderFns = staticRenderFns\n options._compiled = true\n }\n\n // functional template\n if (functionalTemplate) {\n options.functional = true\n }\n\n // scopedId\n if (scopeId) {\n options._scopeId = 'data-v-' + scopeId\n }\n\n var hook\n if (moduleIdentifier) {\n // server build\n hook = function (context) {\n // 2.3 injection\n context =\n context || // cached call\n (this.$vnode && this.$vnode.ssrContext) || // stateful\n (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional\n // 2.2 with runInNewContext: true\n if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') {\n context = __VUE_SSR_CONTEXT__\n }\n // inject component styles\n if (injectStyles) {\n injectStyles.call(this, context)\n }\n // register component module identifier for async chunk inferrence\n if (context && context._registeredComponents) {\n context._registeredComponents.add(moduleIdentifier)\n }\n }\n // used by ssr in case component is cached and beforeCreate\n // never gets called\n options._ssrRegister = hook\n } else if (injectStyles) {\n hook = shadowMode\n ? function () {\n injectStyles.call(\n this,\n (options.functional ? this.parent : this).$root.$options.shadowRoot\n )\n }\n : injectStyles\n }\n\n if (hook) {\n if (options.functional) {\n // for template-only hot-reload because in that case the render fn doesn't\n // go through the normalizer\n options._injectStyles = hook\n // register for functional component in vue file\n var originalRender = options.render\n options.render = function renderWithStyleInjection(h, context) {\n hook.call(context)\n return originalRender(h, context)\n }\n } else {\n // inject component registration as beforeCreate hook\n var existing = options.beforeCreate\n options.beforeCreate = existing ? [].concat(existing, hook) : [hook]\n }\n }\n\n return {\n exports: scriptExports,\n options: options\n }\n}\n","import { render, staticRenderFns } from \"./carousel.vue?vue&type=template&id=4a5ee43f&scoped=true\"\nimport script from \"./carousel.vue?vue&type=script&lang=js\"\nexport * from \"./carousel.vue?vue&type=script&lang=js\"\nimport style0 from \"./carousel.vue?vue&type=style&index=0&id=4a5ee43f&prod&scoped=true&lang=scss\"\n\n\n/* normalize component */\nimport normalizer from \"!../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n \"4a5ee43f\",\n null\n \n)\n\nexport default component.exports","import carousel from './carousel.vue'\n\ncarousel.install = Vue => Vue.component(carousel.name, carousel)\n\nexport default carousel\n","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:\"companyIntroduction-component\",class:_vm.theme},[(_vm.clickDisabled)?_c('div',{staticClass:\"companyIntroduction-component-click-disabled-mask\"}):_vm._e(),(_vm.styleType === 'style1')?_c('div',{staticClass:\"companyIntroduction-component-style1\"},[_c('div',{staticClass:\"companyIntroduction-title\"},[_vm._v(_vm._s(_vm.introduction.title))]),_c('div',{staticClass:\"companyIntroduction-subTitle\"},[_vm._v(_vm._s(_vm.introduction.subTitle))]),_c('div',{staticClass:\"companyIntroduction-content\",domProps:{\"innerHTML\":_vm._s(_vm.introduction.pcIntroduction)}}),_c('div',{staticClass:\"companyIntroduction-feature\"},[_c('div',{staticClass:\"companyIntroduction-feature-item\"},[_c('div',{staticClass:\"companyIntroduction-feature-item-icon\"},[_c('img',{attrs:{\"src\":_vm.assets.diamondIcon,\"alt\":\"\"}})]),_c('div',{staticClass:\"companyIntroduction-feature-item-title\"},[_vm._v(_vm._s(_vm.$t('高质量')))])]),_c('div',{staticClass:\"companyIntroduction-feature-item\"},[_c('div',{staticClass:\"companyIntroduction-feature-item-icon\"},[_c('img',{attrs:{\"src\":_vm.assets.peopleIcon,\"alt\":\"\"}})]),_c('div',{staticClass:\"companyIntroduction-feature-item-title\"},[_vm._v(_vm._s(_vm.$t('领导品牌')))])]),_c('div',{staticClass:\"companyIntroduction-feature-item\"},[_c('div',{staticClass:\"companyIntroduction-feature-item-icon\"},[_c('img',{attrs:{\"src\":_vm.assets.rIcon,\"alt\":\"\"}})]),_c('div',{staticClass:\"companyIntroduction-feature-item-title\"},[_vm._v(_vm._s(_vm.$t('专业团队')))])]),_c('div',{staticClass:\"companyIntroduction-feature-item\"},[_c('div',{staticClass:\"companyIntroduction-feature-item-icon\"},[_c('img',{attrs:{\"src\":_vm.assets.projectIcon,\"alt\":\"\"}})]),_c('div',{staticClass:\"companyIntroduction-feature-item-title\"},[_vm._v(_vm._s(_vm.$t('先进设备')))])])]),_c('div',{directives:[{name:\"show\",rawName:\"v-show\",value:(_vm.introduction.moreMenu.isShow),expression:\"introduction.moreMenu.isShow\"}],staticClass:\"companyIntroduction-moreMenu\"},[_c('div',{staticClass:\"companyIntroduction-moreMenu-name\",on:{\"click\":function($event){$event.stopPropagation();return _vm.handleShowMore($event)}}},[_vm._v(_vm._s(_vm.introduction.moreMenu.name))])]),_c('img',{staticClass:\"companyIntroduction-moreMenu-bg\",attrs:{\"src\":_vm.assets.homeWorldBg,\"alt\":\"\"}})]):_vm._e(),(_vm.styleType === 'style2')?_c('div',{staticClass:\"companyIntroduction-component-style2\"},[_c('div',{staticClass:\"companyIntroduction-title\"},[_vm._v(_vm._s(_vm.introduction.title))]),_c('div',{staticClass:\"companyIntroduction-subTitle\"},[_vm._v(_vm._s(_vm.introduction.subTitle))]),_c('div',{staticClass:\"companyIntroduction-content\",domProps:{\"innerHTML\":_vm._s(_vm.introduction.pcIntroduction)}}),_c('div',{staticClass:\"companyIntroduction-feature\"},[_c('div',{staticClass:\"companyIntroduction-feature-item\"},[_c('div',{staticClass:\"companyIntroduction-feature-item-icon\"},[_c('img',{attrs:{\"src\":_vm.assets.diamondIcon2,\"alt\":\"\"}})]),_c('div',{staticClass:\"companyIntroduction-feature-item-title\"},[_vm._v(_vm._s(_vm.$t('高质量')))])]),_c('div',{staticClass:\"companyIntroduction-feature-item\"},[_c('div',{staticClass:\"companyIntroduction-feature-item-icon\"},[_c('img',{attrs:{\"src\":_vm.assets.medalIcon,\"alt\":\"\"}})]),_c('div',{staticClass:\"companyIntroduction-feature-item-title\"},[_vm._v(_vm._s(_vm.$t('领导品牌')))])]),_c('div',{staticClass:\"companyIntroduction-feature-item\"},[_c('div',{staticClass:\"companyIntroduction-feature-item-icon\"},[_c('img',{attrs:{\"src\":_vm.assets.peopleIcon2,\"alt\":\"\"}})]),_c('div',{staticClass:\"companyIntroduction-feature-item-title\"},[_vm._v(_vm._s(_vm.$t('专业团队')))])]),_c('div',{staticClass:\"companyIntroduction-feature-item\"},[_c('div',{staticClass:\"companyIntroduction-feature-item-icon\"},[_c('img',{attrs:{\"src\":_vm.assets.equipmentIcon,\"alt\":\"\"}})]),_c('div',{staticClass:\"companyIntroduction-feature-item-title\"},[_vm._v(_vm._s(_vm.$t('先进设备')))])])]),_c('div',{directives:[{name:\"show\",rawName:\"v-show\",value:(_vm.introduction.moreMenu.isShow),expression:\"introduction.moreMenu.isShow\"}],staticClass:\"companyIntroduction-moreMenu\"},[_c('div',{staticClass:\"companyIntroduction-moreMenu-name\",on:{\"click\":function($event){$event.stopPropagation();return _vm.handleShowMore($event)}}},[_vm._v(_vm._s(_vm.introduction.moreMenu.name))])])]):_vm._e(),(_vm.styleType === 'style2')?_c('img',{staticClass:\"style2-companyIntroduction-moreMenu-bg\",attrs:{\"src\":_vm.assets.companyIntroBg,\"alt\":\"\"}}):_vm._e()])}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","import Vue from 'vue'\n\nclass I18nService {\n constructor() {\n // 使用 Vue.observable 使状态具有响应式\n this.state = Vue.observable({\n language: localStorage.getItem('language') || 'zh',\n translations: {},\n loading: false\n })\n }\n\n // 设置当前语言\n setLanguage(language) {\n this.state.language = language\n localStorage.setItem('language', language)\n }\n\n // 获取当前语言\n getLanguage() {\n return this.state.language || localStorage.getItem('language') || 'zh'\n }\n\n // 加载翻译内容\n async loadTranslations(response) {\n if (response) {\n this.state.translations = response\n } else {\n this.state.translations = {}\n }\n }\n\n // 获取翻译内容\n t(key, defaultValue = '') {\n const language = this.getLanguage()\n if (!this.state.translations) {\n this.loadTranslations(language)\n return defaultValue\n }\n return this.state.translations[key] || defaultValue || key\n }\n\n // 切换语言\n async changeLanguage(language) {\n this.setLanguage(language)\n await this.loadTranslations(language)\n }\n\n // 批量获取翻译内容\n getTranslations(keys) {\n const result = {}\n keys.forEach(key => {\n result[key] = this.t(key)\n })\n return result\n }\n}\n\n// 创建单例实例\nconst i18nService = new I18nService()\n\n// 初始化时加载当前语言的翻译\ni18nService.loadTranslations()\n\nexport default i18nService\n","<template>\n <div class=\"companyIntroduction-component\" :class=\"theme\">\n <div v-if=\"clickDisabled\" class=\"companyIntroduction-component-click-disabled-mask\" />\n <div v-if=\"styleType === 'style1'\" class=\"companyIntroduction-component-style1\">\n <div class=\"companyIntroduction-title\">{{ introduction.title }}</div>\n <div class=\"companyIntroduction-subTitle\">{{ introduction.subTitle }}</div>\n <div class=\"companyIntroduction-content\" v-html=\"introduction.pcIntroduction\" />\n <div class=\"companyIntroduction-feature\">\n <div class=\"companyIntroduction-feature-item\">\n <div class=\"companyIntroduction-feature-item-icon\">\n <img :src=\"assets.diamondIcon\" alt=\"\">\n </div>\n <div class=\"companyIntroduction-feature-item-title\">{{ $t('高质量') }}</div>\n </div>\n <div class=\"companyIntroduction-feature-item\">\n <div class=\"companyIntroduction-feature-item-icon\">\n <img :src=\"assets.peopleIcon\" alt=\"\">\n </div>\n <div class=\"companyIntroduction-feature-item-title\">{{ $t('领导品牌') }}</div>\n </div>\n <div class=\"companyIntroduction-feature-item\">\n <div class=\"companyIntroduction-feature-item-icon\">\n <img :src=\"assets.rIcon\" alt=\"\">\n </div>\n <div class=\"companyIntroduction-feature-item-title\">{{ $t('专业团队') }}</div>\n </div>\n <div class=\"companyIntroduction-feature-item\">\n <div class=\"companyIntroduction-feature-item-icon\">\n <img :src=\"assets.projectIcon\" alt=\"\">\n </div>\n <div class=\"companyIntroduction-feature-item-title\">{{ $t('先进设备') }}</div>\n </div>\n </div>\n <div v-show=\"introduction.moreMenu.isShow\" class=\"companyIntroduction-moreMenu\">\n <div class=\"companyIntroduction-moreMenu-name\" @click.stop=\"handleShowMore\">{{ introduction.moreMenu.name }}</div>\n </div>\n <img class=\"companyIntroduction-moreMenu-bg\" :src=\"assets.homeWorldBg\" alt=\"\">\n </div>\n <div v-if=\"styleType === 'style2'\" class=\"companyIntroduction-component-style2\">\n <div class=\"companyIntroduction-title\">{{ introduction.title }}</div>\n <div class=\"companyIntroduction-subTitle\">{{ introduction.subTitle }}</div>\n <div class=\"companyIntroduction-content\" v-html=\"introduction.pcIntroduction\" />\n <div class=\"companyIntroduction-feature\">\n <div class=\"companyIntroduction-feature-item\">\n <div class=\"companyIntroduction-feature-item-icon\">\n <img :src=\"assets.diamondIcon2\" alt=\"\">\n </div>\n <div class=\"companyIntroduction-feature-item-title\">{{ $t('高质量') }}</div>\n </div>\n <div class=\"companyIntroduction-feature-item\">\n <div class=\"companyIntroduction-feature-item-icon\">\n <img :src=\"assets.medalIcon\" alt=\"\">\n </div>\n <div class=\"companyIntroduction-feature-item-title\">{{ $t('领导品牌') }}</div>\n </div>\n <div class=\"companyIntroduction-feature-item\">\n <div class=\"companyIntroduction-feature-item-icon\">\n <img :src=\"assets.peopleIcon2\" alt=\"\">\n </div>\n <div class=\"companyIntroduction-feature-item-title\">{{ $t('专业团队') }}</div>\n </div>\n <div class=\"companyIntroduction-feature-item\">\n <div class=\"companyIntroduction-feature-item-icon\">\n <img :src=\"assets.equipmentIcon\" alt=\"\">\n </div>\n <div class=\"companyIntroduction-feature-item-title\">{{ $t('先进设备') }}</div>\n </div>\n </div>\n <div v-show=\"introduction.moreMenu.isShow\" class=\"companyIntroduction-moreMenu\">\n <div class=\"companyIntroduction-moreMenu-name\" @click.stop=\"handleShowMore\">{{ introduction.moreMenu.name }}</div>\n </div>\n </div>\n <!-- 样式2背景图 -->\n <img v-if=\"styleType === 'style2'\" class=\"style2-companyIntroduction-moreMenu-bg\" :src=\"assets.companyIntroBg\" alt=\"\">\n </div>\n</template>\n\n<script>\nimport i18nService from '../../i18n/index.js'\nimport { assets } from '../../assets/index.js'\nexport default {\n name: 'CompanyIntroductionComponent',\n props: {\n clickDisabled: { // 是否给页面添加透明遮罩,防止点击\n type: Boolean,\n default: false\n },\n styleType: { // 选择的公司介绍样式\n type: String,\n default: 'style1'\n },\n introduction: { // 公司介绍内容\n type: Object,\n default: () => ({\n title: '', // 公司介绍标题名称\n subTitle: '', // 公司介绍副标题名称\n pcContent: '', // PC端公司介绍内容\n mobileContent: '', // 移动端公司介绍内容 不过目前还不兼容移动端样式\n moreMenu: { // 更多按钮配置\n name: '', // 更多按钮名称\n isShow: true, // 是否展示\n isBlank: true // 是否新窗口打开\n }\n })\n },\n theme: { // 公司介绍主题样式\n type: String,\n default: ''\n },\n aboutUsMaxId: { // 通过接口请求获得的关于我们的maxCatgId, 用于跳转\n type: String,\n default: ''\n }\n },\n data() {\n return {\n assets: assets\n }\n },\n methods: {\n $t(key, defaultValue = '') {\n return i18nService.t(key, defaultValue)\n },\n handleShowMore() {\n if (this.introduction.moreMenu.isBlank) {\n window.open(`/separate?maxCatgId=${this.aboutUsMaxId}&title=About%20Us`, '_blank')\n } else {\n window.location.href = `/separate?maxCatgId=${this.aboutUsMaxId}&title=About%20Us`\n }\n }\n }\n}\n</script>\n\n<style scoped lang=\"scss\">\n@import '../../styles/theme.css';\n.companyIntroduction-component {\n position: relative;\n width: 100%;\n\n .companyIntroduction-component-click-disabled-mask {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n z-index: 1000;\n }\n\n .companyIntroduction-component-style1 {\n max-width: 1200px;\n padding: 0 15px;\n height: 100%;\n min-height: 20px;\n margin-left: auto;\n margin-right: auto;\n .companyIntroduction-title {\n margin: 26px 0 15px;\n color: #015fe8;\n width: 100%;\n text-align: center;\n font-size: 24px;\n font-weight: 500;\n line-height: 1.2;\n }\n .companyIntroduction-subTitle {\n margin-bottom: 8px;\n color: #015fe8;\n width: 100%;\n text-align: center;\n font-weight: 400;\n font-size: 14px;\n line-height: 1.2;\n }\n .companyIntroduction-content {\n display: flow-root; // 构建BFC,清除内部浮动\n margin-top: 18px;\n margin-bottom: 52px;\n color: #575757;\n font-size: 14px;\n }\n .companyIntroduction-feature {\n display: flex;\n justify-content: space-between;\n align-items: center;\n\n .companyIntroduction-feature-item {\n flex: 0 0 25%;\n max-width: 25%;\n padding: 0 15px;\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n position: relative;\n z-index: 1;\n .companyIntroduction-feature-item-icon {\n width: 70px;\n height: 70px;\n margin-bottom: 16px;\n display: flex;\n align-items: center;\n justify-content: center;\n background: #f3f4f6;\n border-radius: 8px;\n img {\n width: 40px;\n height: 40px;\n }\n }\n .companyIntroduction-feature-item-title {\n font-size: 14px;\n font-weight: 400;\n line-height: 1.5;\n color: rgb(135, 139, 144);\n }\n }\n }\n\n .companyIntroduction-moreMenu {\n margin-top: 16px;\n margin-left: auto;\n margin-right: auto;\n width: 150px;\n padding: 8px 35px;\n background-color: rgb(1, 95, 232);\n border-radius: 30px;\n color: #fff;\n font-size: 14px;\n cursor: pointer;\n font-weight: 400;\n line-height: 21px;\n transition: all 0.3s ease-in-out;\n text-align: center;\n position: relative;\n z-index: 1;\n &:hover {\n box-shadow: 2px 2px 10px 0 rgba(0,0,0,.2);\n }\n }\n .companyIntroduction-moreMenu-bg {\n max-width: 100%;\n height: auto;\n margin-top: -180px;\n pointer-events: none;\n border: none;\n\n }\n }\n\n .companyIntroduction-component-style2 {\n max-width: 1200px;\n padding: 100px 15px 0;\n height: 100%;\n min-height: 20px;\n margin-left: auto;\n margin-right: auto;\n position: relative;\n z-index: 1;\n .companyIntroduction-title {\n margin-bottom: 25px;\n color: var(--theme-title-color);\n width: 100%;\n text-align: center;\n font-size: 46px;\n font-weight: 500;\n line-height: 1;\n }\n .companyIntroduction-subTitle {\n margin-bottom: 50px;\n color: var(--theme-subTitle-color);\n width: 100%;\n text-align: center;\n font-weight: 500;\n font-size: 26px;\n line-height: 1;\n }\n .companyIntroduction-content {\n display: flow-root; // 构建BFC,清除内部浮动\n margin-bottom: 32px;\n }\n .companyIntroduction-feature {\n display: flex;\n justify-content: center;\n align-items: center;\n gap: 129px;\n\n .companyIntroduction-feature-item {\n padding: 0 15px;\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n position: relative;\n z-index: 1;\n .companyIntroduction-feature-item-icon {\n width: 50px;\n height: 50px;\n margin-bottom: 5px;\n display: flex;\n align-items: center;\n justify-content: center;\n img {\n width: 50px;\n height: 50px;\n }\n }\n .companyIntroduction-feature-item-title {\n font-size: 18px;\n font-weight: 500;\n line-height: 1;\n color: rgba(0, 0, 0, 0.5);\n }\n }\n }\n\n .companyIntroduction-moreMenu {\n margin-top: 50px;\n margin-left: auto;\n margin-right: auto;\n width: 120px;\n padding: 9px 20px;\n background: var(--theme-more-btn-color);\n border-radius: 6px;\n color: #fff;\n font-size: 16px;\n cursor: pointer;\n font-weight: 500;\n line-height: 1;\n transition: all 0.3s ease-in-out;\n text-align: center;\n position: relative;\n z-index: 1;\n &:hover {\n box-shadow: var(--theme-more-btn-hover-shadow);\n }\n }\n }\n\n .style2-companyIntroduction-moreMenu-bg {\n max-width: 100%;\n height: auto;\n pointer-events: none;\n border: none;\n position: absolute;\n top: 0;\n left: 0;\n z-index: 0;\n object-fit: cover;\n }\n}\n</style>\n\n","import mod from \"-!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../../../../../../node_modules/thread-loader/dist/cjs.js!../../../../../../../node_modules/babel-loader/lib/index.js!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./companyIntroduction.vue?vue&type=script&lang=js\"; export default mod; export * from \"-!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../../../../../../node_modules/thread-loader/dist/cjs.js!../../../../../../../node_modules/babel-loader/lib/index.js!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./companyIntroduction.vue?vue&type=script&lang=js\"","import { render, staticRenderFns } from \"./companyIntroduction.vue?vue&type=template&id=a0dd5942&scoped=true\"\nimport script from \"./companyIntroduction.vue?vue&type=script&lang=js\"\nexport * from \"./companyIntroduction.vue?vue&type=script&lang=js\"\nimport style0 from \"./companyIntroduction.vue?vue&type=style&index=0&id=a0dd5942&prod&scoped=true&lang=scss\"\n\n\n/* normalize component */\nimport normalizer from \"!../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n \"a0dd5942\",\n null\n \n)\n\nexport default component.exports","import companyIntroduction from './companyIntroduction.vue'\n\ncompanyIntroduction.install = Vue => Vue.component(companyIntroduction.name, companyIntroduction)\n\nexport default companyIntroduction\n","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:\"floatNav-component\",class:_vm.theme},[(_vm.clickDisabled)?_c('div',{staticClass:\"float-nav-click-disabled-mask\"}):_vm._e(),(_vm.styleType === 'style1')?_c('ul',{staticClass:\"side-nav-style1 special-border\"},[_vm._l((_vm.sideiItem),function(item,index){return _c('li',{key:index,staticClass:\"side-item\",on:{\"click\":function($event){return _vm.jump(item)}}},[_c('div',{staticClass:\"side-label\"},[_c('img',{attrs:{\"src\":item.icon,\"alt\":item.label}}),_c('h4',[_vm._v(_vm._s(item.label))])]),(item.desc)?_c('div',{staticClass:\"side-desc\",domProps:{\"innerHTML\":_vm._s(item.desc)}}):_vm._e()])}),_c('li',{staticClass:\"side-item side-item-top\",on:{\"click\":_vm.handleToTop}},[_c('div',{staticClass:\"side-label\"},[_c('img',{attrs:{\"src\":_vm.assets.topIcon,\"alt\":\"\"}}),_c('h4',[_vm._v(\"Top\")])])])],2):_vm._e(),(_vm.styleType === 'style2')?_c('div',[_c('ul',{staticClass:\"side-nav-style2\",staticStyle:{\"padding\":\"20px 0\"}},_vm._l((_vm.sideiItemNew),function(item,index){return _c('li',{key:index,staticClass:\"side-item\",on:{\"click\":function($event){return _vm.jump(item)}}},[_c('div',{staticClass:\"side-label\"},[_c('i',{staticClass:\"iconfont\",class:item.iconClass}),_c('h4',[_vm._v(_vm._s(item.label))])])])}),0),_c('ul',{staticClass:\"side-nav-style2\",staticStyle:{\"margin-top\":\"16px\"}},[_c('li',{staticClass:\"side-item side-item-top\",on:{\"click\":_vm.handleToTop}},[_vm._m(0)])])]):_vm._e()])}\nvar staticRenderFns = [function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:\"side-label\"},[_c('i',{staticClass:\"iconfont icon-a-zu126\"}),_c('h4',[_vm._v(\"Top\")])])}]\n\nexport { render, staticRenderFns }","<template>\n <div class=\"floatNav-component\" :class=\"theme\">\n <!-- 点击事件禁用遮罩 -->\n <div v-if=\"clickDisabled\" class=\"float-nav-click-disabled-mask\" />\n <ul v-if=\"styleType === 'style1'\" class=\"side-nav-style1 special-border\">\n <li\n v-for=\"(item, index) in sideiItem\"\n :key=\"index\"\n class=\"side-item\"\n @click=\"jump(item)\"\n >\n <div class=\"side-label\">\n <img :src=\"item.icon\" :alt=\"item.label\">\n <h4>{{ item.label }}</h4>\n </div>\n <div v-if=\"item.desc\" class=\"side-desc\" v-html=\"item.desc\" />\n </li>\n <li class=\"side-item side-item-top\" @click=\"handleToTop\">\n <div class=\"side-label\">\n <img :src=\"assets.topIcon\" alt=\"\">\n <h4>Top</h4>\n </div>\n </li>\n </ul>\n <div v-if=\"styleType === 'style2'\">\n <ul class=\"side-nav-style2\" style=\"padding: 20px 0;\">\n <li v-for=\"(item, index) in sideiItemNew\" :key=\"index\" class=\"side-item\" @click=\"jump(item)\">\n <div class=\"side-label\">\n <i :class=\"item.iconClass\" class=\"iconfont\" />\n <h4>{{ item.label }}</h4>\n </div>\n </li>\n </ul>\n <ul class=\"side-nav-style2\" style=\"margin-top: 16px;\">\n <li class=\"side-item side-item-top\" @click=\"handleToTop\">\n <div class=\"side-label\">\n <i class=\"iconfont icon-a-zu126\" />\n <h4>Top</h4>\n </div>\n </li>\n </ul>\n </div>\n </div>\n</template>\n\n<script>\nimport i18nService from '../../i18n/index.js'\nimport { assets } from '../../assets/index.js'\nexport default {\n name: 'FloatNavComponent',\n props: {\n styleType: {\n type: String,\n default: ''\n },\n footerInfo: {\n type: Object,\n default: () => ({\n tel: '',\n whatsapp: '',\n email: ''\n })\n },\n clickDisabled: {\n type: Boolean,\n default: false\n },\n theme: {\n type: String,\n default: ''\n },\n maxCatgId: {\n type: String,\n default: ''\n }\n },\n data() {\n return {\n assets: assets\n }\n },\n computed: {\n sideiItem() {\n return [\n {\n icon: this.assets.telephone,\n label: 'Contact',\n url: `tel:${this.footerInfo.tel}`,\n thirdSoft: 'Tel',\n desc: `<div\">\n <h6>Contant Us</h6>\n <p>${this.footerInfo.tel}</p>\n </div>`\n },\n {\n icon: this.assets.chat,\n label: 'Online',\n url: `/inquiry?maxCatgId=${this.maxCatgId}`\n },\n {\n icon: this.assets.whatsapp,\n label: 'WhatsApp',\n thirdSoft: 'WhatsApp',\n url: `https://wa.me/${this.footerInfo.whatsapp}`,\n desc: `<div>\n <h6>WhatsApp</h6>\n <p>${this.footerInfo.whatsapp}</p>\n </div>`\n },\n {\n icon: this.assets.email,\n label: 'Email',\n thirdSoft: 'Email',\n url: `mailto:${this.footerInfo.email}`,\n desc: `<div>\n <h6>Email</h6>\n <p>${this.footerInfo.email}</p>\n </div>`\n }\n ]\n },\n sideiItemNew() {\n return [\n {\n iconClass: 'icon-a-zu107',\n label: this.$t('联系'),\n url: `tel:${this.footerInfo.tel}`,\n thirdSoft: 'Tel',\n desc: `<div\">\n <h6>${this.$t('联系我们')}</h6>\n <p>${this.footerInfo.tel}</p>\n </div>`\n },\n {\n iconClass: 'icon-link-chain--create-hyperlink-link-make-unlink-conn',\n label: this.$t('在线咨询'),\n url: `/inquiry?maxCatgId=${this.maxCatgId}`\n },\n {\n iconClass: 'icon-a-zu118',\n label: 'WhatsApp',\n thirdSoft: 'WhatsApp',\n url: `https://wa.me/${this.footerInfo.whatsapp}`,\n desc: `<div>\n <h6>WhatsApp</h6>\n <p>${this.footerInfo.whatsapp}</p>\n </div>`\n },\n {\n iconClass: 'icon-a-zu122',\n label: this.$t('邮箱'),\n thirdSoft: 'Email',\n url: `mailto:${this.footerInfo.email}`,\n desc: `<div>\n <h6>${this.$t('邮箱')}</h6>\n <p>${this.footerInfo.email}</p>\n </div>`\n }\n ]\n }\n },\n methods: {\n $t(key, defaultValue = '') {\n return i18nService.t(key, defaultValue)\n },\n handleToTop() {\n window.scrollTo({\n top: 0,\n behavior: 'smooth'\n })\n },\n async jump(row) {\n let thirdAccount = ''\n if (row.thirdSoft === 'Tel') {\n thirdAccount = this.footerInfo.tel\n }\n if (row.thirdSoft === 'WhatsApp') {\n thirdAccount = this.footerInfo.whatsapp\n }\n if (row.thirdSoft === 'Email') {\n thirdAccount = this.footerInfo.email\n }\n const data = {\n equipment: '电脑端',\n thirdSoft: row.thirdSoft,\n thirdAccount: thirdAccount\n }\n if (row.thirdSoft) {\n try {\n await this.$axios.post('/web/thirdItemSave', data)\n } catch (err) {\n console.log(err)\n }\n }\n if (row.url) {\n window.open(row.url)\n }\n }\n }\n}\n</script>\n\n<style scoped lang=\"scss\">\n@import '../../assets/icons/iconfont.css';\n.floatNav-component {\n position: fixed;\n top: 200px;\n right: 0;\n z-index: 999;\n\n ul {\n padding-inline-start: 0;\n margin-block-start: 0;\n margin-block-end: 0;\n }\n\n .float-nav-click-disabled-mask {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n z-index: 1000;\n }\n\n .side-nav-style1 {\n display: flex;\n flex-direction: column;\n align-items: flex-end;\n @mixin active {\n .side-desc {\n width: max-content;\n padding: 12px 24px;\n visibility: visible;\n }\n }\n .side-item {\n display: flex;\n align-items: center;\n cursor: pointer;\n &:hover {\n @include active;\n }\n .side-label {\n width: 72px;\n height: 72px;\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n background-color: #fff;\n box-shadow: 0px 2px 6px 1px rgba(1,95,232,0.13);\n img {\n width: 24px;\n height: 24px;\n margin-bottom: 5px;\n }\n h4 {\n margin-top: 0;\n margin-bottom: 0;\n color: #323436;\n font-size: 12px;\n }\n }\n\n &:nth-last-child(2) {\n .side-label {\n img {\n width: 26px;\n height: 20px;\n }\n }\n }\n .side-desc {\n width: 0;\n height: 72px;\n visibility: hidden;\n background-color: #015fe8;\n color: #fff;\n }\n }\n .side-item-active {\n @include active;\n }\n .side-item-top {\n margin-top: 16px;\n }\n }\n\n .side-nav-style2 {\n display: flex;\n flex-direction: column;\n align-items: flex-end;\n // border: var(--theme-float-nav-border);\n border-radius: 50px;\n overflow: hidden;\n background-color: #fff;\n box-shadow: var(--theme-float-nav-shadow);\n\n .side-item {\n display: flex;\n align-items: center;\n cursor: pointer;\n &:hover {\n .side-label {\n .iconfont {\n color: var(--theme-float-nav-icon-active-color);\n }\n }\n h4 {\n color: var(--theme-float-nav-text-active-color);\n }\n }\n\n .side-label {\n width: 100px;\n height: 100px;\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n background-color: #fff;\n .iconfont {\n margin-bottom: 5px;\n font-size: 39px;\n color: var(--theme-float-nav-icon-color);\n }\n h4 {\n margin-top: 0;\n margin-bottom: 0;\n color: var(--theme-float-nav-text-color);\n font-size: 15px;\n font-weight: 400;\n text-align: center;\n }\n }\n }\n .side-item-top {\n }\n }\n}\n</style>\n","import mod from \"-!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../../../../../../node_modules/thread-loader/dist/cjs.js!../../../../../../../node_modules/babel-loader/lib/index.js!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./floatNav.vue?vue&type=script&lang=js\"; export default mod; export * from \"-!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../../../../../../node_modules/thread-loader/dist/cjs.js!../../../../../../../node_modules/babel-loader/lib/index.js!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./floatNav.vue?vue&type=script&lang=js\"","import { render, staticRenderFns } from \"./floatNav.vue?vue&type=template&id=676ee15d&scoped=true\"\nimport script from \"./floatNav.vue?vue&type=script&lang=js\"\nexport * from \"./floatNav.vue?vue&type=script&lang=js\"\nimport style0 from \"./floatNav.vue?vue&type=style&index=0&id=676ee15d&prod&scoped=true&lang=scss\"\n\n\n/* normalize component */\nimport normalizer from \"!../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n \"676ee15d\",\n null\n \n)\n\nexport default component.exports","import floatNav from './floatNav.vue'\n\nfloatNav.install = Vue => Vue.component(floatNav.name, floatNav)\n\nexport default floatNav\n","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:\"footerNav-component\",class:_vm.theme},[(_vm.clickDisabled)?_c('div',{staticClass:\"footer-nav-click-disabled-mask\"}):_vm._e(),(_vm.styleType === 'style1')?_c('div',{staticClass:\"footerNav-component-style1\"},[_c('el-row',{staticClass:\"footerNav-compoennt-contact-us-row\",attrs:{\"justify\":\"center\"}},[_c('el-col',{attrs:{\"span\":6}},[_c('div',{staticClass:\"footerNav-compoennt-contact-us\"},[_c('div',{staticClass:\"footerNav-compoennt-contact-us-title\"},[_vm._v(_vm._s(_vm.contactWay.title))]),_c('div',{staticClass:\"footerNav-compoennt-contact-us-content\",domProps:{\"innerHTML\":_vm._s(_vm.contactWay.content)}})])]),_c('el-col',{attrs:{\"span\":6}},[_c('div',{staticClass:\"footerNav-compoennt-contact-us\"},[_c('div',{staticClass:\"footerNav-compoennt-contact-us-title\"},[_vm._v(_vm._s(_vm.friendlyLink.title))]),_c('div',{staticClass:\"footerNav-compoennt-contact-us-content\"},_vm._l((_vm.friendlyLink.list),function(item,index){return _c('div',{key:index,staticClass:\"footerNav-compoennt-contact-us-content-item\"},[_c('a',{directives:[{name:\"show\",rawName:\"v-show\",value:(item.isShow),expression:\"item.isShow\"}],attrs:{\"href\":item.linkSite,\"target\":item.isBlank ? '_blank' : '_self'}},[_vm._v(_vm._s(item.linkTitle))])])}),0)])]),_c('el-col',{attrs:{\"span\":6}},[_c('div',{staticClass:\"footerNav-compoennt-contact-us\"},[_c('div',{staticClass:\"footerNav-compoennt-contact-us-title\"},[_vm._v(_vm._s(_vm.productCategory.title))]),_c('div',{staticClass:\"footerNav-compoennt-contact-us-content\"},_vm._l((_vm.productCategory.list),function(item,index){return _c('div',{key:index,staticClass:\"footerNav-compoennt-contact-us-content-item\"},[_c('span',{directives:[{name:\"show\",rawName:\"v-show\",value:(item.isShow),expression:\"item.isShow\"}],on:{\"click\":function($event){$event.stopPropagation();return _vm.handleClick(item)}}},[_vm._v(_vm._s(item.categoryTitle))])])}),0)])]),_c('el-col',{attrs:{\"span\":6}},[_c('div',{staticClass:\"footerNav-compoennt-contact-us-qrcode\"},[_c('img',{staticClass:\"footerNav-compoennt-contact-us-qrcode-img\",attrs:{\"src\":_vm.qrcode,\"alt\":\"二维码\"}}),_c('div',{staticClass:\"footerNav-compoennt-contact-us-qrcode-text\"},[_vm._v(\"Shandong Chengda Truck Trailer Co., Ltd\")])])])],1),_c('div',{staticClass:\"footerNav-compoennt-copyright\"},[_vm._v(\" Copyright © Shandong Chengda Truck Trailer Co., Ltd. All rights reserved.Privacy Policy \")])],1):_vm._e(),(_vm.styleType === 'style2')?_c('div',{staticClass:\"footerNav-component-style2\"},[_c('div',{staticClass:\"footerNav-compoennt-style2-container\"},[_c('el-row',{staticClass:\"footerNav-compoennt-contact-us-row\",attrs:{\"justify\":\"center\"}},[_c('el-col',{attrs:{\"span\":6}},[_c('div',{staticClass:\"footerNav-compoennt-contact-us-qrcode\"},[_c('img',{staticClass:\"footerNav-compoennt-contact-us-qrcode-img\",attrs:{\"src\":_vm.qrcode,\"alt\":\"二维码\"}}),_c('div',{staticClass:\"footerNav-compoennt-contact-us-qrcode-text\"},[_vm._v(\"Shandong Chengda Truck Trailer Co., Ltd\")])])]),_c('el-col',{attrs:{\"span\":8}},[_c('div',{staticClass:\"footerNav-compoennt-contact-us\"},[_c('div',{staticClass:\"footerNav-compoennt-contact-us-title\"},[_vm._v(_vm._s(_vm.contactWay.title))]),_c('div',{staticClass:\"footerNav-compoennt-contact-us-content\",domProps:{\"innerHTML\":_vm._s(_vm.contactWay.content)}})])]),_c('el-col',{attrs:{\"span\":5}},[_c('div',{staticClass:\"footerNav-compoennt-contact-us\"},[_c('div',{staticClass:\"footerNav-compoennt-contact-us-title\"},[_vm._v(_vm._s(_vm.friendlyLink.title))]),_c('div',{staticClass:\"footerNav-compoennt-contact-us-content\"},_vm._l((_vm.friendlyLink.list),function(item,index){return _c('div',{key:index,staticClass:\"footerNav-compoennt-contact-us-content-item\"},[_c('a',{directives:[{name:\"show\",rawName:\"v-show\",value:(item.isShow),expression:\"item.isShow\"}],attrs:{\"href\":item.linkSite,\"target\":item.isBlank ? '_blank' : '_self'}},[_vm._v(_vm._s(item.linkTitle))])])}),0)])]),_c('el-col',{attrs:{\"span\":5}},[_c('div',{staticClass:\"footerNav-compoennt-contact-us\"},[_c('div',{staticClass:\"footerNav-compoennt-contact-us-title\"},[_vm._v(_vm._s(_vm.productCategory.title))]),_c('div',{staticClass:\"footerNav-compoennt-contact-us-content\"},_vm._l((_vm.productCategory.list),function(item,index){return _c('div',{key:index,staticClass:\"footerNav-compoennt-contact-us-content-item\"},[_c('span',{directives:[{name:\"show\",rawName:\"v-show\",value:(item.isShow),expression:\"item.isShow\"}],on:{\"click\":function($event){$event.stopPropagation();return _vm.handleClick(item)}}},[_vm._v(_vm._s(item.categoryTitle))])])}),0)])])],1),_c('div',{staticClass:\"footerNav-compoennt-copyright\"},[_vm._v(\" Copyright © Shandong Chengda Truck Trailer Co., Ltd. All rights reserved.Privacy Policy \")])],1)]):_vm._e()])}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","<template>\n <div class=\"footerNav-component\" :class=\"theme\">\n <!-- 点击事件禁用遮罩 -->\n <div v-if=\"clickDisabled\" class=\"footer-nav-click-disabled-mask\" />\n <div v-if=\"styleType === 'style1'\" class=\"footerNav-component-style1\">\n <el-row justify=\"center\" class=\"footerNav-compoennt-contact-us-row\">\n <el-col :span=\"6\">\n <div class=\"footerNav-compoennt-contact-us\">\n <div class=\"footerNav-compoennt-contact-us-title\">{{ contactWay.title }}</div>\n <div class=\"footerNav-compoennt-contact-us-content\" v-html=\"contactWay.content\" />\n </div>\n </el-col>\n <el-col :span=\"6\">\n <div class=\"footerNav-compoennt-contact-us\">\n <div class=\"footerNav-compoennt-contact-us-title\">{{ friendlyLink.title }}</div>\n <div class=\"footerNav-compoennt-contact-us-content\">\n <div v-for=\"(item, index) in friendlyLink.list\" :key=\"index\" class=\"footerNav-compoennt-contact-us-content-item\">\n <a v-show=\"item.isShow\" :href=\"item.linkSite\" :target=\"item.isBlank ? '_blank' : '_self'\">{{ item.linkTitle }}</a>\n </div>\n </div>\n </div>\n </el-col>\n <el-col :span=\"6\">\n <div class=\"footerNav-compoennt-contact-us\">\n <div class=\"footerNav-compoennt-contact-us-title\">{{ productCategory.title }}</div>\n <div class=\"footerNav-compoennt-contact-us-content\">\n <div v-for=\"(item, index) in productCategory.list\" :key=\"index\" class=\"footerNav-compoennt-contact-us-content-item\">\n <span v-show=\"item.isShow\" @click.stop=\"handleClick(item)\">{{ item.categoryTitle }}</span>\n </div>\n </div>\n </div>\n </el-col>\n <el-col :span=\"6\">\n <div class=\"footerNav-compoennt-contact-us-qrcode\">\n <img class=\"footerNav-compoennt-contact-us-qrcode-img\" :src=\"qrcode\" alt=\"二维码\">\n <div class=\"footerNav-compoennt-contact-us-qrcode-text\">Shandong Chengda Truck Trailer Co., Ltd</div>\n </div>\n </el-col>\n </el-row>\n <div class=\"footerNav-compoennt-copyright\">\n Copyright © Shandong Chengda Truck Trailer Co., Ltd. All rights reserved.Privacy Policy\n </div>\n </div>\n <div v-if=\"styleType === 'style2'\" class=\"footerNav-component-style2\">\n <div class=\"footerNav-compoennt-style2-container\">\n <el-row justify=\"center\" class=\"footerNav-compoennt-contact-us-row\">\n <el-col :span=\"6\">\n <div class=\"footerNav-compoennt-contact-us-qrcode\">\n <img class=\"footerNav-compoennt-contact-us-qrcode-img\" :src=\"qrcode\" alt=\"二维码\">\n <div class=\"footerNav-compoennt-contact-us-qrcode-text\">Shandong Chengda Truck Trailer Co., Ltd</div>\n </div>\n </el-col>\n <el-col :span=\"8\">\n <div class=\"footerNav-compoennt-contact-us\">\n <div class=\"footerNav-compoennt-contact-us-title\">{{ contactWay.title }}</div>\n <div class=\"footerNav-compoennt-contact-us-content\" v-html=\"contactWay.content\" />\n </div>\n </el-col>\n <el-col :span=\"5\">\n <div class=\"footerNav-compoennt-contact-us\">\n <div class=\"footerNav-compoennt-contact-us-title\">{{ friendlyLink.title }}</div>\n <div class=\"footerNav-compoennt-contact-us-content\">\n <div v-for=\"(item, index) in friendlyLink.list\" :key=\"index\" class=\"footerNav-compoennt-contact-us-content-item\">\n <a v-show=\"item.isShow\" :href=\"item.linkSite\" :target=\"item.isBlank ? '_blank' : '_self'\">{{ item.linkTitle }}</a>\n </div>\n </div>\n </div>\n </el-col>\n <el-col :span=\"5\">\n <div class=\"footerNav-compoennt-contact-us\">\n <div class=\"footerNav-compoennt-contact-us-title\">{{ productCategory.title }}</div>\n <div class=\"footerNav-compoennt-contact-us-content\">\n <div v-for=\"(item, index) in productCategory.list\" :key=\"index\" class=\"footerNav-compoennt-contact-us-content-item\">\n <span v-show=\"item.isShow\" @click.stop=\"handleClick(item)\">{{ item.categoryTitle }}</span>\n </div>\n </div>\n </div>\n </el-col>\n </el-row>\n <div class=\"footerNav-compoennt-copyright\">\n Copyright © Shandong Chengda Truck Trailer Co., Ltd. All rights reserved.Privacy Policy\n </div>\n </div>\n </div>\n </div>\n</template>\n\n<script>\nexport default {\n name: 'FooterNavComponent',\n props: {\n styleType: {\n type: String,\n default: 'style1'\n },\n contactWay: {\n title: '联系我们',\n content: ''\n },\n friendlyLink: {\n list: []\n },\n productCategory: {\n list: []\n },\n qrcode: {\n type: String,\n default: ''\n },\n theme: {\n type: String,\n default: ''\n },\n clickDisabled: {\n type: Boolean,\n default: false\n }\n },\n methods: {\n handleClick(item) {\n const { href } = this.$router.resolve({\n path: '/base/product/category',\n query: { categoryId: item.categoryId }\n })\n window.open(href, item.isBlank ? '_blank' : '_self')\n }\n }\n}\n</script>\n\n<style scoped lang=\"scss\">\n.footerNav-component {\n position: relative;\n .footer-nav-click-disabled-mask {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n z-index: 1000;\n }\n .footerNav-component-style1 {\n background-color: #152235;\n width: 100%;\n height: auto;\n .footerNav-compoennt-contact-us-row {\n padding: 0 16%;\n display: flex;\n }\n\n .footerNav-compoennt-contact-us {\n padding: 52px 15px 0;\n margin-bottom: 16px;\n .footerNav-compoennt-contact-us-title {\n font-size: 18px;\n font-weight: 700;\n line-height: 27px;\n color: #fff;\n margin-bottom: 18px;\n }\n .footerNav-compoennt-contact-us-content {\n margin-bottom: 16px;\n color: #b0b6b9;\n font-size: 14px;\n font-weight: 400;\n line-height: 21px;\n ::v-deep p {\n word-break: break-all !important;\n white-space: pre-wrap !important;\n }\n ::v-deep span {\n word-break: break-all !important;\n white-space: pre-wrap !important;\n }\n\n .footerNav-compoennt-contact-us-content-item {\n height: 21px;\n line-height: 21px;\n margin-bottom: 16px;\n a {\n font-size: 14px;\n font-weight: 400;\n color: #b0b6b9;\n }\n }\n }\n }\n .footerNav-compoennt-contact-us-qrcode {\n padding: 52px 15px 0;\n width: fit-content;\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n .footerNav-compoennt-contact-us-qrcode-img {\n width: 212px;\n height: 212px;\n }\n .footerNav-compoennt-contact-us-qrcode-text {\n margin-top: 4px;\n width: 128px;\n text-align: center;\n color: #f0f0f0;\n font-size: 12px;\n line-height: 1.5;\n }\n }\n .footerNav-compoennt-copyright {\n width: 100%;\n height: 72px;\n line-height: 72px;\n text-align: center;\n color: #fff;\n font-size: 14px;\n font-weight: 400;\n border-top: 1px solid #eaeaea;\n }\n }\n\n .footerNav-component-style2 {\n width: 100%;\n height: auto;\n background-color: #191919;\n .footerNav-compoennt-style2-container {\n margin: 0 auto;\n padding-top: 112px;\n max-width: 1334px;\n }\n .footerNav-compoennt-contact-us {\n margin-bottom: 60px;\n padding-right: 148px;\n .footerNav-compoennt-contact-us-title {\n font-size: 22px;\n font-weight: 400;\n line-height: 22px;\n color: #fff;\n margin-bottom: 50px;\n }\n .footerNav-compoennt-contact-us-content {\n color: rgba(255, 255, 255, 0.5);\n font-size: 16px;\n font-weight: 500;\n line-height: 1.5;\n ::v-deep p {\n word-break: break-all !important;\n white-space: pre-wrap !important;\n }\n ::v-deep span {\n word-break: break-all !important;\n white-space: pre-wrap !important;\n }\n\n .footerNav-compoennt-contact-us-content-item {\n color: rgba(255, 255, 255, 0.5);\n font-size: 16px;\n font-weight: 500;\n line-height: 1.5;\n a {\n font-size: 14px;\n font-weight: 400;\n color: #b0b6b9;\n }\n }\n }\n }\n .footerNav-compoennt-contact-us-qrcode {\n width: fit-content;\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n justify-content: center;\n .footerNav-compoennt-contact-us-qrcode-img {\n width: 212px;\n height: 212px;\n }\n .footerNav-compoennt-contact-us-qrcode-text {\n margin-top: 4px;\n width: 128px;\n text-align: left;\n color: #f0f0f0;\n font-size: 12px;\n line-height: 1.5;\n }\n }\n .footerNav-compoennt-copyright {\n width: 100%;\n padding-bottom: 38px;\n line-height: 1;\n text-align: center;\n color: rgba(255, 255, 255, 0.8);\n font-size: 18px;\n font-weight: 400;\n }\n }\n}\n</style>\n","import mod from \"-!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../../../../../../node_modules/thread-loader/dist/cjs.js!../../../../../../../node_modules/babel-loader/lib/index.js!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./footerNav.vue?vue&type=script&lang=js\"; export default mod; export * from \"-!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../../../../../../node_modules/thread-loader/dist/cjs.js!../../../../../../../node_modules/babel-loader/lib/index.js!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./footerNav.vue?vue&type=script&lang=js\"","import { render, staticRenderFns } from \"./footerNav.vue?vue&type=template&id=6f2164cf&scoped=true\"\nimport script from \"./footerNav.vue?vue&type=script&lang=js\"\nexport * from \"./footerNav.vue?vue&type=script&lang=js\"\nimport style0 from \"./footerNav.vue?vue&type=style&index=0&id=6f2164cf&prod&scoped=true&lang=scss\"\n\n\n/* normalize component */\nimport normalizer from \"!../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n \"6f2164cf\",\n null\n \n)\n\nexport default component.exports","import footerNav from './footerNav.vue'\n\nfooterNav.install = Vue => Vue.component(footerNav.name, footerNav)\n\nexport default footerNav\n","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:\"header-nav-component\",class:_vm.theme},[(_vm.clickDisabled)?_c('div',{staticClass:\"header-nav-component-click-disabled-mask\"}):_vm._e(),(_vm.styleType === 'style1')?_c('div',{staticClass:\"header-nav-style1\"},[_c('div',{staticClass:\"headerNav-component--style1__logo\"},[_c('img',{attrs:{\"src\":_vm.logo,\"alt\":\"\"},on:{\"click\":_vm.handleClickLogo}})]),_c('div',{staticClass:\"headerNav-component--style1__menu\"},[(_vm.menus.length > 0)?_c('MenuComponent',{attrs:{\"menus\":_vm.menus,\"mode\":\"horizontal\"}}):_vm._e()],1),_c('div',{staticClass:\"headerNav-component--style1__operate\"},[_c('div',{staticClass:\"headerNav-component--style1__operate-search\"},[_c('i',{staticClass:\"headerNav-component--style1__operate-search-icon el-icon-search\"}),_c('input',{directives:[{name:\"model\",rawName:\"v-model\",value:(_vm.searchText),expression:\"searchText\"}],staticClass:\"headerNav-component--style1__operate-search-input\",attrs:{\"type\":\"text\",\"placeholder\":_vm.$t('搜索').toUpperCase()},domProps:{\"value\":(_vm.searchText)},on:{\"keydown\":function($event){if(!$event.type.indexOf('key')&&_vm._k($event.keyCode,\"enter\",13,$event.key,\"Enter\")){ return null; }return _vm.handleSearch($event)},\"input\":function($event){if($event.target.composing){ return; }_vm.searchText=$event.target.value}}})]),_c('img',{staticClass:\"headerNav-component--style1__operate-language\",attrs:{\"src\":_vm.assets.language},on:{\"click\":_vm.changeLanguage}})])]):_vm._e(),(_vm.styleType === 'style2')?_c('div',{staticClass:\"header-nav-style2\"},[_c('div',{staticClass:\"headerNav-component--style2__left\"},[_c('div',{staticClass:\"headerNav-component--style2__menu\",on:{\"mouseenter\":_vm.handleMenuHover,\"mouseleave\":_vm.handleMenuLeave}},[_c('div',{staticClass:\"headerNav-component--style2__menu-item\",on:{\"click\":function($event){return _vm.handleClickMenu({ name: '首页', label: '首页' })}}},[_vm._v(\" \"+_vm._s(_vm.$t('首页'))+\" \")]),_vm._l((_vm.menus),function(item){return _c('div',{key:item.id,staticClass:\"headerNav-component--style2__menu-item\",on:{\"click\":function($event){return _vm.handleClickMenu(item)}}},[_vm._v(\" \"+_vm._s(item.name || item.label)+\" \")])})],2),_c('div',{staticClass:\"headerNav-component--style2__logo\"},[_c('img',{attrs:{\"src\":_vm.logo,\"alt\":\"\"},on:{\"click\":_vm.handleClickLogo}})])]),_c('div',{staticClass:\"headerNav-component--style2__operate\"},[_c('div',{staticClass:\"headerNav-component--style2__operate-search\"},[_c('i',{staticClass:\"iconfont headerNav-component--style2__operate-search-icon icon-sousuo\"}),_c('input',{directives:[{name:\"model\",rawName:\"v-model\",value:(_vm.searchText),expression:\"searchText\"}],staticClass:\"headerNav-component--style2__operate-search-input\",attrs:{\"type\":\"text\",\"placeholder\":_vm.$t('搜索').toUpperCase()},domProps:{\"value\":(_vm.searchText)},on:{\"keydown\":function($event){if(!$event.type.indexOf('key')&&_vm._k($event.keyCode,\"enter\",13,$event.key,\"Enter\")){ return null; }return _vm.handleSearch($event)},\"input\":function($event){if($event.target.composing){ return; }_vm.searchText=$event.target.value}}})]),_c('i',{staticClass:\"iconfont headerNav-component--style2__operate-language icon-a-zu61\",on:{\"click\":_vm.changeLanguage}})]),_c('div',{staticClass:\"headerNav-component-style2__submenu\",class:{'show': _vm.showSubMenu},on:{\"mouseenter\":_vm.handleSubMenuContainerEnter,\"mouseleave\":_vm.handleSubMenuContainerLeave}},_vm._l((_vm.menus),function(item,index){return _c('div',{key:index},[(item.children && item.children.length > 0)?_c('div',{staticClass:\"headerNav-component-style2__submenu-container\"},_vm._l((item.children),function(secondMenu,secondIndex){return _c('div',{key:secondIndex,staticClass:\"headerNav-component-style2__submenu-container__item\"},[_c('div',{staticClass:\"headerNav-component-style2__submenu-container__item__title\",on:{\"click\":function($event){return _vm.handleClickMenu(secondMenu)}}},[_vm._v(_vm._s(secondMenu.name || secondMenu.label))]),(secondMenu.children && secondMenu.children.length > 0)?_c('div',{staticClass:\"headerNav-component-style2__thirdmenu-container\"},_vm._l((secondMenu.children),function(thirdMenu,thirdIndex){return _c('div',{key:thirdIndex,staticClass:\"headerNav-component-style2__thirdmenu-container__item\"},[_c('div',{staticClass:\"headerNav-component-style2__thirdmenu-container__item__title\",on:{\"click\":function($event){return _vm.handleClickMenu(thirdMenu)}}},[_vm._v(_vm._s(thirdMenu.name || thirdMenu.label))]),(thirdMenu.children && thirdMenu.children.length > 0)?_c('div',{staticClass:\"headerNav-component-style2__thirdmenu-container__item__submenu\"},_vm._l((thirdMenu.children),function(fourthMenu,fourthIndex){return _c('div',{key:fourthIndex,staticClass:\"headerNav-component-style2__thirdmenu-container__item__submenu__item\",on:{\"click\":function($event){return _vm.handleClickMenu(fourthMenu)}}},[_vm._v(_vm._s(fourthMenu.name || fourthMenu.label))])}),0):_vm._e()])}),0):_vm._e()])}),0):_vm._e()])}),0)]):_vm._e(),(_vm.styleType === 'style3')?_c('div',{staticClass:\"header-nav-style3\"},[_c('div',{staticClass:\"headerNav-component--style3__menu\"},[_c('MenuComponent',{attrs:{\"menus\":_vm.menus,\"mode\":\"horizontal\",\"background-color\":\"#fff\",\"text-color\":\"#333\",\"active-text-color\":\"#409EFF\"}})],1)]):_vm._e(),_c('ChangeLanguageDialog',{attrs:{\"visible\":_vm.showLanguageDialog,\"language-list\":_vm.languageList},on:{\"close\":function($event){_vm.showLanguageDialog = false},\"select\":_vm.handleLanguageSelect}})],1)}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","import i18nService from '../../i18n/index.js'\nconst $t = (key, defaultValue = '') => {\n return i18nService.t(key, defaultValue)\n}\n// 点击菜单\nconst handleClickMenu = (menu) => {\n // 如果有子节点,则当前不可点击\n if (menu.children && menu.children.length > 0) {\n return\n }\n const routeMap = {\n 'dym': 'separate', // 单页面\n 'xp': 'inquiry', // 询盘栏目\n 'wz': 'article-page', // 文章栏目\n 'cp': 'products' // 产品栏目\n }\n let url = ''\n if (menu.catgLevel === 1) {\n url = `/${routeMap[menu.catgType]}?maxCatgId=${menu.id}&title=${menu.label}`\n } else {\n url = `/${routeMap[menu.catgType]}?&catgId=${menu.id}&maxCatgId=${menu.maxParentId}&title=${menu.label}`\n }\n window.location.href = url\n}\n// 递归渲染子菜单\nconst renderMenuItem = (createElement, menuItem) => {\n // 如果有子菜单,渲染为submenu\n if (menuItem.children && menuItem.children.length > 0) {\n return createElement(\n 'el-submenu',\n {\n props: {\n index: menuItem.id ? menuItem.id.toString() : ''\n },\n on: {\n click: () => {\n // 点击菜单项的回调函数\n handleClickMenu(menuItem)\n }\n }\n },\n [\n createElement('template', {\n slot: 'title'\n }, [menuItem.name || menuItem.label || '']),\n // 递归渲染子菜单\n ...menuItem.children.map(item => renderMenuItem(createElement, item))\n ]\n )\n } else {\n // 没有子菜单,渲染为menu-item\n return createElement(\n 'el-menu-item',\n {\n props: {\n index: menuItem.id ? menuItem.id.toString() : ''\n },\n on: {\n click: () => {\n // 点击菜单项的回调函数\n handleClickMenu(menuItem)\n }\n }\n },\n [menuItem.name || menuItem.label || '']\n )\n }\n}\n\nconst MenuComponent = {\n props: {\n menus: {\n type: Array,\n default: () => [] // [ { id, name, path, children: [....] } ]\n },\n mode: {\n type: String,\n default: 'horizontal', // 可选: 'horizontal' 或 'vertical'\n validator: (value) => ['horizontal', 'vertical'].includes(value)\n },\n defaultActive: {\n type: String,\n default: ''\n },\n backgroundColor: {\n type: String,\n default: '#fff'\n },\n textColor: {\n type: String,\n default: '#000'\n },\n activeTextColor: {\n type: String,\n default: '#ffd04b'\n }\n },\n render: function(createElement) {\n return createElement(\n 'el-menu',\n {\n props: {\n defaultActive: 'home',\n mode: this.mode,\n backgroundColor: this.backgroundColor,\n textColor: this.textColor,\n activeTextColor: this.activeTextColor\n },\n on: {\n select: (index, indexPath) => {\n // 菜单选择事件\n console.log('选择了菜单:', index, indexPath)\n },\n open: (index, indexPath) => {\n // 子菜单展开事件\n console.log('展开了子菜单:', index, indexPath)\n },\n close: (index, indexPath) => {\n // 子菜单收起事件\n console.log('收起了子菜单:', index, indexPath)\n }\n }\n },\n // 渲染所有菜单项\n [\n renderMenuItem(createElement, {\n name: $t('首页'),\n id: 'home',\n path: '/home'\n }),\n this.menus.map(menu => renderMenuItem(createElement, menu))\n ]\n )\n }\n}\n\nexport default MenuComponent\n","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('el-dialog',{attrs:{\"visible\":_vm.visible,\"width\":\"1334px\",\"before-close\":_vm.handleClose}},[_c('div',{staticClass:\"change-language-dialog\"},[_c('div',{staticClass:\"change-language-dialog-header\"},[_c('div',{staticClass:\"change-language-dialog-header-title\"},[_vm._v(\"选择区域/语言\")]),_c('div',{staticClass:\"change-language-dialog-header-input\"},[_c('i',{staticClass:\"el-icon-search\"}),_c('input',{directives:[{name:\"model\",rawName:\"v-model\",value:(_vm.searchText),expression:\"searchText\"}],attrs:{\"type\":\"text\",\"placeholder\":'搜索'},domProps:{\"value\":(_vm.searchText)},on:{\"keydown\":function($event){if(!$event.type.indexOf('key')&&_vm._k($event.keyCode,\"enter\",13,$event.key,\"Enter\")){ return null; }return _vm.handleSearch($event)},\"input\":function($event){if($event.target.composing){ return; }_vm.searchText=$event.target.value}}})])]),_c('div',{staticClass:\"change-language-dialog-content\"},[(_vm.filteredLanguageList.length > 0)?_c('el-tabs',{model:{value:(_vm.activeTab),callback:function ($$v) {_vm.activeTab=$$v},expression:\"activeTab\"}},_vm._l((_vm.filteredLanguageList),function(region){return _c('el-tab-pane',{key:region.oceania,staticClass:\"language-group\",attrs:{\"label\":region.oceania,\"name\":region.oceania}},_vm._l((region.nationalVos),function(item){return _c('div',{key:item.id,staticClass:\"language-item\"},[_c('div',{staticClass:\"language-item-country\"},[_c('div',{staticClass:\"language-item-country-title\"},[_c('img',{attrs:{\"src\":_vm.getImageSrc(item),\"width\":\"26\",\"alt\":\"\"}}),_vm._v(\" \"+_vm._s(item.name)+\" \")]),_c('div',{staticClass:\"language-item-country-language\"},_vm._l((item.languages),function(language){return _c('span',{key:language.code,class:{'language-item-country-language-active': _vm.languageActive === language.code},on:{\"click\":function($event){return _vm.handleLanguageSelect(language)}}},[_vm._v(_vm._s(language.name))])}),0)])])}),0)}),1):_c('div',{staticClass:\"no-result\"},[_c('p',[_vm._v(\"未找到匹配的语言\")])])],1)])])}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","<template>\n <el-dialog\n :visible=\"visible\"\n width=\"1334px\"\n :before-close=\"handleClose\"\n >\n <div class=\"change-language-dialog\">\n <div class=\"change-language-dialog-header\">\n <div class=\"change-language-dialog-header-title\">选择区域/语言</div>\n <div class=\"change-language-dialog-header-input\">\n <i class=\"el-icon-search\" />\n <input v-model=\"searchText\" type=\"text\" :placeholder=\"'搜索'\" @keydown.enter=\"handleSearch\">\n </div>\n </div>\n <div class=\"change-language-dialog-content\">\n <el-tabs v-if=\"filteredLanguageList.length > 0\" v-model=\"activeTab\">\n <el-tab-pane v-for=\"region in filteredLanguageList\" :key=\"region.oceania\" :label=\"region.oceania\" :name=\"region.oceania\" class=\"language-group\">\n <div v-for=\"item in region.nationalVos\" :key=\"item.id\" class=\"language-item\">\n <div class=\"language-item-country\">\n <div class=\"language-item-country-title\">\n <img :src=\"getImageSrc(item)\" width=\"26\" alt=\"\">\n {{ item.name }}\n </div>\n <div class=\"language-item-country-language\">\n <span v-for=\"language in item.languages\" :key=\"language.code\" :class=\"{'language-item-country-language-active': languageActive === language.code}\" @click=\"handleLanguageSelect(language)\">{{ language.name }}</span>\n </div>\n </div>\n </div>\n </el-tab-pane>\n </el-tabs>\n <div v-else class=\"no-result\">\n <p>未找到匹配的语言</p>\n </div>\n </div>\n </div>\n </el-dialog>\n</template>\n\n<script>\nexport default {\n name: 'ChangeLanguageDialog',\n props: {\n visible: {\n type: Boolean,\n default: false\n },\n languageList: {\n type: Array,\n default: () => []\n }\n },\n emits: ['close', 'select'],\n data() {\n return {\n activeTab: '',\n searchText: '',\n languageActive: ''\n }\n },\n computed: {\n safeLanguageList() {\n // 确保 languageList 是数组,并且每个元素都有必要的属性\n if (!Array.isArray(this.languageList)) {\n return []\n }\n return this.languageList\n },\n filteredLanguageList() {\n if (!this.searchText) {\n return this.safeLanguageList\n }\n\n const searchLower = this.searchText.toLowerCase()\n\n return this.safeLanguageList.map(region => {\n const filteredNations = region.nationalVos.filter(nation => {\n // 搜索国家名称\n if (nation.name.toLowerCase().includes(searchLower)) {\n return true\n }\n // 搜索语言名称\n return nation.languages.some(language =>\n language.name.toLowerCase().includes(searchLower)\n )\n })\n\n return {\n ...region,\n nationalVos: filteredNations\n }\n }).filter(region => region.nationalVos.length > 0)\n }\n },\n watch: {\n visible(newVal) {\n if (newVal) {\n this.activeTab = this.safeLanguageList[0] && this.safeLanguageList[0].oceania ? this.safeLanguageList[0].oceania : ''\n this.searchText = ''\n }\n },\n searchText(newVal) {\n if (newVal) {\n // 搜索时,自动切换到第一个匹配的标签页\n this.$nextTick(() => {\n if (this.filteredLanguageList.length > 0) {\n this.activeTab = this.filteredLanguageList[0].oceania\n }\n })\n } else {\n // 清空搜索时,回到第一个标签页\n if (this.safeLanguageList.length > 0) {\n this.activeTab = this.safeLanguageList[0].oceania\n }\n }\n }\n },\n methods: {\n getImageSrc(item) {\n return require(`../../assets/nationalFlag/${item.img}`)\n },\n handleSearch() {\n\n },\n handleClose() {\n this.$emit('close')\n },\n handleLanguageSelect(item) {\n this.$emit('select', item)\n }\n }\n}\n</script>\n\n<style scoped lang=\"scss\">\n::v-deep .el-dialog {\n border-radius: 12px !important;\n}\n\n::v-deep .el-dialog__header {\n border-radius: 12px 12px 0 0 !important;\n}\n\n::v-deep .el-dialog__body {\n border-radius: 0 0 12px 12px !important;\n padding: 0 !important;\n}\n\n.change-language-dialog {\n padding: 10px 50px 93px;\n .change-language-dialog-header {\n display: flex;\n justify-content: space-between;\n align-items: center;\n .change-language-dialog-header-title {\n font-weight: bold;\n font-size: 16px;\n color: #000000;\n text-align: left;\n font-style: normal;\n text-transform: none;\n }\n .change-language-dialog-header-input {\n box-sizing: border-box;\n padding: 0 20px;\n width: 398px;\n height: 38px;\n display: flex;\n align-items: center;\n justify-content: flex-start;\n gap: 10px;\n border: 1px solid rgba(0, 0, 0, 0.1);\n border-radius: 10px;\n\n i {\n font-size: 15px;\n color: rgba(11, 11, 11, 0.2);\n }\n\n input {\n width: 100%;\n border: none;\n font-weight: 400;\n font-size: 15px;\n color: #111111;\n outline: none;\n // placeholder字体颜色\n &::placeholder {\n color: rgba(11, 11, 11, 0.2);\n }\n\n &::-webkit-input-placeholder {\n color: rgba(11, 11, 11, 0.2);\n }\n\n &::-moz-placeholder {\n color: rgba(11, 11, 11, 0.2);\n }\n\n &:-ms-input-placeholder {\n color: rgba(11, 11, 11, 0.2);\n }\n }\n }\n }\n\n .change-language-dialog-content {\n .language-group {\n display: grid;\n grid-template-columns: repeat(3, 1fr);\n gap: 10px;\n .language-item {\n .language-item-country {\n display: flex;\n justify-content: flex-start;\n align-items: center;\n gap: 10px;\n cursor: pointer;\n .language-item-country-title {\n display: flex;\n align-items: center;\n font-weight: 500;\n font-size: 15px;\n color: #000000;\n\n img {\n margin-right: 15px;\n }\n }\n .language-item-country-language {\n display: flex;\n gap: 10px;\n span {\n padding: 0 12px;\n width: fit-content;\n height: 26px;\n background: rgba(17, 17, 17, 0.03);\n border-radius: 13px;\n color: #000000;\n font-size: 13px;\n line-height: 26px;\n text-align: center;\n transition: all 0.3s ease-in-out;\n\n &:hover {\n background: #2A73D6;\n color: #fff;\n }\n }\n .language-item-country-language-active {\n background: #2A73D6;\n color: #fff;\n }\n }\n }\n }\n }\n .no-result {\n display: flex;\n justify-content: center;\n align-items: center;\n height: 300px;\n font-size: 16px;\n color: #999;\n }\n }\n}\n</style>\n","import mod from \"-!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../../../../../../node_modules/thread-loader/dist/cjs.js!../../../../../../../node_modules/babel-loader/lib/index.js!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./changeLanguageDialog.vue?vue&type=script&lang=js\"; export default mod; export * from \"-!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../../../../../../node_modules/thread-loader/dist/cjs.js!../../../../../../../node_modules/babel-loader/lib/index.js!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./changeLanguageDialog.vue?vue&type=script&lang=js\"","import { render, staticRenderFns } from \"./changeLanguageDialog.vue?vue&type=template&id=5dee3d3d&scoped=true\"\nimport script from \"./changeLanguageDialog.vue?vue&type=script&lang=js\"\nexport * from \"./changeLanguageDialog.vue?vue&type=script&lang=js\"\nimport style0 from \"./changeLanguageDialog.vue?vue&type=style&index=0&id=5dee3d3d&prod&scoped=true&lang=scss\"\n\n\n/* normalize component */\nimport normalizer from \"!../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n \"5dee3d3d\",\n null\n \n)\n\nexport default component.exports","<template>\n <div class=\"header-nav-component\" :class=\"theme\">\n <!-- 点击事件禁用遮罩 -->\n <div v-if=\"clickDisabled\" class=\"header-nav-component-click-disabled-mask\" />\n <div v-if=\"styleType === 'style1'\" class=\"header-nav-style1\">\n <div class=\"headerNav-component--style1__logo\">\n <img :src=\"logo\" alt=\"\" @click=\"handleClickLogo\">\n </div>\n <div class=\"headerNav-component--style1__menu\">\n <MenuComponent v-if=\"menus.length > 0\" :menus=\"menus\" mode=\"horizontal\" />\n </div>\n <div class=\"headerNav-component--style1__operate\">\n <div class=\"headerNav-component--style1__operate-search\">\n <i class=\"headerNav-component--style1__operate-search-icon el-icon-search\" />\n <input v-model=\"searchText\" type=\"text\" :placeholder=\"$t('搜索').toUpperCase()\" class=\"headerNav-component--style1__operate-search-input\" @keydown.enter=\"handleSearch\">\n </div>\n <img class=\"headerNav-component--style1__operate-language\" :src=\"assets.language\" @click=\"changeLanguage\">\n </div>\n </div>\n <div v-if=\"styleType === 'style2'\" class=\"header-nav-style2\">\n <div class=\"headerNav-component--style2__left\">\n <div class=\"headerNav-component--style2__menu\" @mouseenter=\"handleMenuHover\" @mouseleave=\"handleMenuLeave\">\n <!-- <MenuComponent :menus=\"menus\" mode=\"horizontal\" /> -->\n <div class=\"headerNav-component--style2__menu-item\" @click=\"handleClickMenu({ name: '首页', label: '首页' })\">\n {{ $t('首页') }}\n </div>\n <div v-for=\"item in menus\" :key=\"item.id\" class=\"headerNav-component--style2__menu-item\" @click=\"handleClickMenu(item)\">\n {{ item.name || item.label }}\n </div>\n </div>\n <div class=\"headerNav-component--style2__logo\">\n <img :src=\"logo\" alt=\"\" @click=\"handleClickLogo\">\n </div>\n </div>\n <div class=\"headerNav-component--style2__operate\">\n <div class=\"headerNav-component--style2__operate-search\">\n <i class=\"iconfont headerNav-component--style2__operate-search-icon icon-sousuo\" />\n <input v-model=\"searchText\" type=\"text\" :placeholder=\"$t('搜索').toUpperCase()\" class=\"headerNav-component--style2__operate-search-input\" @keydown.enter=\"handleSearch\">\n </div>\n <i class=\"iconfont headerNav-component--style2__operate-language icon-a-zu61\" @click=\"changeLanguage\" />\n </div>\n\n <div\n class=\"headerNav-component-style2__submenu\"\n :class=\"{'show': showSubMenu}\"\n @mouseenter=\"handleSubMenuContainerEnter\"\n @mouseleave=\"handleSubMenuContainerLeave\"\n >\n <div v-for=\"(item, index) in menus\" :key=\"index\">\n <div v-if=\"item.children && item.children.length > 0\" class=\"headerNav-component-style2__submenu-container\">\n <div v-for=\"(secondMenu, secondIndex) in item.children\" :key=\"secondIndex\" class=\"headerNav-component-style2__submenu-container__item\">\n <div class=\"headerNav-component-style2__submenu-container__item__title\" @click=\"handleClickMenu(secondMenu)\">{{ secondMenu.name || secondMenu.label }}</div>\n <div v-if=\"secondMenu.children && secondMenu.children.length > 0\" class=\"headerNav-component-style2__thirdmenu-container\">\n <div v-for=\"(thirdMenu, thirdIndex) in secondMenu.children\" :key=\"thirdIndex\" class=\"headerNav-component-style2__thirdmenu-container__item\">\n <div class=\"headerNav-component-style2__thirdmenu-container__item__title\" @click=\"handleClickMenu(thirdMenu)\">{{ thirdMenu.name || thirdMenu.label }}</div>\n <div v-if=\"thirdMenu.children && thirdMenu.children.length > 0\" class=\"headerNav-component-style2__thirdmenu-container__item__submenu\">\n <div v-for=\"(fourthMenu, fourthIndex) in thirdMenu.children\" :key=\"fourthIndex\" class=\"headerNav-component-style2__thirdmenu-container__item__submenu__item\" @click=\"handleClickMenu(fourthMenu)\">{{ fourthMenu.name || fourthMenu.label }}</div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n <div v-if=\"styleType === 'style3'\" class=\"header-nav-style3\">\n <div class=\"headerNav-component--style3__menu\">\n <MenuComponent\n :menus=\"menus\"\n mode=\"horizontal\"\n background-color=\"#fff\"\n text-color=\"#333\"\n active-text-color=\"#409EFF\"\n />\n </div>\n </div>\n <ChangeLanguageDialog\n :visible=\"showLanguageDialog\"\n :language-list=\"languageList\"\n @close=\"showLanguageDialog = false\"\n @select=\"handleLanguageSelect\"\n />\n </div>\n</template>\n\n<script>\nimport MenuComponent from './menus'\nimport ChangeLanguageDialog from './changeLanguageDialog'\nimport i18nService from '../../i18n/index.js'\nimport { assets } from '../../assets/index.js'\n\nexport default {\n name: 'HeaderNavComponent',\n components: {\n MenuComponent,\n ChangeLanguageDialog\n },\n props: {\n logo: { // 公司logo图片路径\n type: String,\n default: ''\n },\n styleType: { // 选择的导航栏样式\n type: String,\n default: 'style1'\n },\n navList: { // 配置的导航列表, 展示内容以这个为准\n type: Array,\n default: () => []\n },\n allNavList: { // 完整的导航列表, 辅助展示导航菜单, navList中的内容不全,缺少子菜单等信息\n type: Array,\n default: () => []\n },\n clickDisabled: { // 是否给页面添加透明遮罩,防止点击\n type: Boolean,\n default: false\n },\n theme: { // 导航栏主题样式\n type: String,\n default: ''\n },\n languageList: { // 切换语言时用到的语言列表\n type: Array,\n default: () => []\n }\n },\n emits: ['changeLanguage'],\n data() {\n return {\n assets: assets,\n searchText: '',\n showSubMenu: false,\n hoveredSubItem: null,\n leaveTimer: null,\n showLanguageDialog: false\n }\n },\n computed: {\n menus() {\n return this.navList.map(item => {\n const result = this.allNavList.find(navItem => navItem.id === item.linkSite)\n return {\n ...result,\n name: item.name || ''\n }\n })\n }\n },\n destroyed() {\n },\n methods: {\n handleClickLogo() {\n // 回到根页面\n window.location.href = '/'\n },\n $t(key, defaultValue = '') {\n return i18nService.t(key, defaultValue)\n },\n changeLanguage() {\n this.showLanguageDialog = true\n console.log(this.showLanguageDialog)\n },\n handleLanguageSelect(language) {\n // 处理语言选择逻辑\n this.showLanguageDialog = false\n this.$emit('changeLanguage', language.code)\n },\n handleClickMenu(menu) {\n // 如果有子节点,则当前不可点击\n if (menu.children && menu.children.length > 0) {\n return\n }\n const routeMap = {\n 'dym': 'separate', // 单页面\n 'xp': 'inquiry', // 询盘栏目\n 'wz': 'article-page', // 文章栏目\n 'cp': 'products' // 产品栏目\n }\n let url = ''\n if (menu.catgLevel === 1) {\n url = `/${routeMap[menu.catgType]}?maxCatgId=${menu.id}&title=${menu.label}`\n } else {\n url = `/${routeMap[menu.catgType]}?&catgId=${menu.id}&maxCatgId=${menu.maxParentId}&title=${menu.label}`\n }\n window.location.href = url\n },\n handleSearch() {\n // todo 搜索\n this.$router.push({\n path: 'search-result?str=' + this.searchText\n })\n },\n handleMenuHover(menu) {\n this.showSubMenu = true\n console.log(this.menus)\n },\n handleMenuLeave() {\n // 延迟隐藏,以便用户可以移动鼠标到子菜单\n this.leaveTimer = setTimeout(() => {\n this.showSubMenu = false\n this.hoveredSubItem = null\n }, 200)\n },\n handleSubMenuContainerEnter() {\n // 当鼠标进入子菜单容器时,清除定时器并保持显示状态\n if (this.leaveTimer) {\n clearTimeout(this.leaveTimer)\n this.leaveTimer = null\n }\n this.showSubMenu = true\n },\n handleSubMenuContainerLeave() {\n // 当鼠标离开子菜单容器时,延迟隐藏\n this.leaveTimer = setTimeout(() => {\n this.showSubMenu = false\n this.hoveredSubItem = null\n }, 200)\n },\n\n handleSubMenuHover(menu) {\n // 当鼠标进入二级菜单时,清除定时器并保持显示状态\n if (this.leaveTimer) {\n clearTimeout(this.leaveTimer)\n this.leaveTimer = null\n }\n this.showSubMenu = true\n },\n handleSubMenuItemHover(subItem) {\n this.hoveredSubItem = subItem\n this.showSubMenu = true\n }\n }\n}\n</script>\n\n<style scoped lang=\"scss\">\n@import '../../styles/theme.css';\n.header-nav-component {\n width: 100%;\n\n // 点击事件禁用遮罩\n .header-nav-component-click-disabled-mask {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n z-index: 99;\n }\n\n .header-nav-style1 {\n padding: 0 31px;\n height: 92px;\n display: flex;\n align-items: center;\n justify-content: space-between;\n background: #FFF;\n\n .headerNav-component--style1__logo {\n width: 265px;\n img {\n width: 100%;\n cursor: pointer;\n }\n }\n\n .headerNav-component--style1__menu {\n ::v-deep .el-menu {\n border-bottom: 0 !important;\n }\n ::v-deep .el-menu-item {\n box-sizing: border-box !important;\n height: 56px !important;\n line-height: 14px !important;\n color: #303133 !important;\n transition: border-color 0.3s ease-in-out !important;\n border: none !important;\n }\n\n ::v-deep .el-menu-item, .el-submenu__title {\n line-height: 56px !important;\n padding: 0 20px !important;\n }\n\n ::v-deep .el-menu--horizontal .el-menu-item:not(.is-disabled):hover {\n color: #303133 !important;\n }\n\n ::v-deep .el-menu-item:focus, ::v-deep .el-menu-item:hover {\n background-color: #ecf5ff !important;\n }\n }\n\n .headerNav-component--style1__operate {\n display: flex;\n align-items: center;\n\n .headerNav-component--style1__operate-search {\n width: 120px;\n height: 44px;\n position: relative;\n transition: all 0.3s ease-in-out;\n border-radius: 22px;\n\n &:focus-within {\n width: 340px;\n box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.25);\n color: #495057;\n background-color: #fff;\n }\n\n .headerNav-component--style1__operate-search-icon {\n position: absolute;\n top: 50%;\n left: 14px;\n transform: translateY(-50%);\n color: #015fe8;\n font-size: 20px;\n font-weight: 500;\n }\n .headerNav-component--style1__operate-search-input {\n padding: 0 12px 0 44px;\n width: 100%;\n height: 44px;\n border-radius: 22px;\n border: 1px solid #015fe8;\n font-size: 16px;\n outline: none;\n\n // placeholder 颜色\n &::placeholder {\n color: #015fe8;\n font-size: 16px;\n font-weight: 500;\n }\n }\n }\n\n .headerNav-component--style1__operate-language {\n width: 20px;\n height: 20px;\n margin-left: 16px;\n cursor: pointer;\n }\n\n }\n }\n\n .header-nav-style2 {\n padding: 0 70px;\n width: 100%;\n height: 106px;\n display: flex;\n align-items: center;\n justify-content: space-between;\n background: #FFF;\n position: relative;\n\n .headerNav-component-style2__submenu {\n position: absolute;\n top: 100%;\n left: 0;\n right: 0;\n background: #fff;\n box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);\n z-index: 999;\n padding: 11px 70px 20px;\n opacity: 0;\n transform: translateY(-10px);\n visibility: hidden;\n transition: all 0.3s ease-in-out;\n\n &.show {\n opacity: 1;\n transform: translateY(0);\n visibility: visible;\n }\n\n .headerNav-component-style2__submenu-container {\n display: flex;\n justify-content: center;\n gap: 20px;\n\n .headerNav-component-style2__submenu-container__item {\n padding-top: 14px;\n padding-right: 25px;\n border-right: 1px solid rgba(112, 112, 112, 0.16);\n\n .headerNav-component-style2__submenu-container__item__title {\n margin-bottom: 20px;\n font-weight: bold;\n font-size: 16px;\n color: #000000;\n cursor: pointer;\n\n &:hover {\n color: var(--theme-header-menu-selected-color);\n }\n }\n\n .headerNav-component-style2__thirdmenu-container {\n display: flex;\n flex-direction: column;\n gap: 20px;\n .headerNav-component-style2__thirdmenu-container__item {\n display: flex;\n align-items: center;\n justify-content: flex-start;\n gap: 29px;\n .headerNav-component-style2__thirdmenu-container__item__title {\n font-size: 13px;\n color: #000000;\n font-weight: 400;\n cursor: pointer;\n\n &:hover {\n color: var(--theme-header-menu-selected-color);\n }\n }\n .headerNav-component-style2__thirdmenu-container__item__submenu {\n padding-left: 24px;\n display: flex;\n justify-content: flex-start;\n align-items: center;\n gap: 17px;\n border-left: 1px solid rgba(112, 112, 112, 0.16);\n .headerNav-component-style2__thirdmenu-container__item__submenu__item {\n font-weight: 400;\n font-size: 13px;\n color: rgba(112, 112, 112, 0.5);\n display: inline-flex;\n align-items: center;\n cursor: pointer;\n\n &::before {\n content: '';\n display: inline-block;\n width: 5px;\n height: 5px;\n background-color: rgba(112, 112, 112, 0.16);\n border-radius: 50%;\n margin-right: 8px;\n\n &:hover {\n background-color: var(--theme-header-menu-selected-color);\n }\n }\n\n &:hover {\n color: var(--theme-header-menu-selected-color);\n &::before {\n background-color: var(--theme-header-menu-selected-color);\n }\n }\n }\n }\n }\n }\n }\n }\n }\n\n .headerNav-component--style2__left {\n min-width: calc(50% + 152px); // 当菜单内容少的时候,保证图标在header正中间,如果宽度超出,就往右挤\n width: fit-content;\n display: flex;\n align-items: center;\n justify-content: space-between;\n }\n .headerNav-component--style2__menu {\n display: flex;\n align-items: center;\n justify-content: flex-start;\n gap: 62px;\n\n .headerNav-component--style2__menu-item {\n box-sizing: border-box;\n height: 56px;\n font-weight: 400;\n font-size: 16px;\n color: var(--theme-header-menu-color);\n transition: border-color 0.3s ease-in-out;\n line-height: 56px;\n cursor: pointer;\n &:hover {\n color: var(--theme-header-menu-selected-color) !important;\n }\n }\n }\n\n .headerNav-component--style2__logo {\n width: 304px;\n img {\n width: 100%;\n cursor: pointer;\n }\n }\n\n .headerNav-component--style2__operate {\n display: flex;\n align-items: center;\n\n .headerNav-component--style2__operate-search {\n width: 146px;\n height: 50px;\n position: relative;\n transition: all 0.3s ease-in-out;\n border-radius: 25px;\n\n &:focus-within {\n width: 340px;\n box-shadow: var(--theme-input-shadow);\n color: #495057;\n background-color: #fff;\n }\n\n .headerNav-component--style2__operate-search-icon {\n position: absolute;\n top: 50%;\n left: 20px;\n transform: translateY(-50%);\n color: var(--theme-input-color);\n font-size: 19px;\n }\n .headerNav-component--style2__operate-search-input {\n padding: 0 20px 0 50px;\n width: 100%;\n height: 50px;\n border-radius: 25px;\n border: 1.5px solid var(--theme-input-border-color);\n font-size: 16px;\n outline: none;\n\n // placeholder 颜色\n &::placeholder {\n color: var(--theme-input-color);\n font-size: 16px;\n font-weight: 500;\n }\n }\n }\n\n .headerNav-component--style2__operate-language {\n margin-left: 20px;\n font-size: 22px;\n cursor: pointer;\n color: var(--theme-change-language-icon-color);\n }\n\n }\n }\n}\n</style>\n","import mod from \"-!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../../../../../../node_modules/thread-loader/dist/cjs.js!../../../../../../../node_modules/babel-loader/lib/index.js!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./headerNav.vue?vue&type=script&lang=js\"; export default mod; export * from \"-!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../../../../../../node_modules/thread-loader/dist/cjs.js!../../../../../../../node_modules/babel-loader/lib/index.js!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./headerNav.vue?vue&type=script&lang=js\"","import { render, staticRenderFns } from \"./headerNav.vue?vue&type=template&id=70d07b09&scoped=true\"\nimport script from \"./headerNav.vue?vue&type=script&lang=js\"\nexport * from \"./headerNav.vue?vue&type=script&lang=js\"\nimport style0 from \"./headerNav.vue?vue&type=style&index=0&id=70d07b09&prod&scoped=true&lang=scss\"\n\n\n/* normalize component */\nimport normalizer from \"!../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n \"70d07b09\",\n null\n \n)\n\nexport default component.exports","import headerNav from './headerNav.vue'\n\nheaderNav.install = Vue => Vue.component(headerNav.name, headerNav)\n\nexport default headerNav\n","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:\"hotProduct-component\",class:_vm.theme},[(_vm.clickDisabled)?_c('div',{staticClass:\"hotProduct-component-click-disabled-mask\"}):_vm._e(),(_vm.styleType === 'style1')?_c('div',{staticClass:\"hotProduct-component-style1\"},[_c('div',{staticClass:\"hotProduct-component-style1__container\"},[_c('div',{staticClass:\"hotProduct-component-title\"},[_vm._v(_vm._s(_vm.hotProductData.title))]),_c('div',{staticClass:\"hotProduct-component-subTitle\"},[_vm._v(_vm._s(_vm.hotProductData.subTitle))]),(_vm.hotProductData.displayProductList)?_c('swiper',{staticClass:\"hotProduct-component-swiper\",attrs:{\"options\":_vm.swiperOptions}},[_vm._l((_vm.hotProductData.displayProductList.slice(0, _vm.hotProductData.productCount)),function(item){return _c('swiper-slide',{key:item.id,staticClass:\"hotProduct-component-swiper-item\"},[_c('div',{staticClass:\"hotProduct-component-swiper-item-container\"},[_c('img',{staticClass:\"hotProduct-component-swiper-item-img\",attrs:{\"src\":item.mainPic.split(',')[0],\"alt\":\"\"}}),_c('div',{staticClass:\"hotProduct-component-swiper-item-content\"},[_c('div',{staticClass:\"hotProduct-component-swiper-item-title\"},[_vm._v(_vm._s(item.prodTitle))]),_c('div',{staticClass:\"hotProduct-component-swiper-item-desc\"},[_vm._v(_vm._s(item.prodDescription))])]),_c('div',{staticClass:\"hotProduct-component-swiper-item-btn\",on:{\"click\":function($event){$event.stopPropagation();return _vm.handleClick(item)}}},[_vm._v(\" \"+_vm._s(_vm.$t('查看详情'))+\" \"),_c('i',{staticClass:\"iconfont el-icon-top-right\"})])])])}),_c('div',{staticClass:\"swiper-button-next-hotProduct\",attrs:{\"slot\":\"button-next\"},slot:\"button-next\"},[_c('div',{staticClass:\"swiper-button-next-hotProduct-content\"},[_c('img',{attrs:{\"src\":_vm.assets.leftArrow,\"alt\":\"\"}})])]),_c('div',{staticClass:\"swiper-button-prev-hotProduct\",attrs:{\"slot\":\"button-prev\"},slot:\"button-prev\"},[_c('div',{staticClass:\"swiper-button-prev-hotProduct-content\"},[_c('img',{attrs:{\"src\":_vm.assets.leftArrow,\"alt\":\"\"}})])])],2):_vm._e(),_c('div',{staticClass:\"hotProduct-component-moreBtn\",on:{\"click\":_vm.handleViewMore}},[_vm._v(\" \"+_vm._s(_vm.hotProductData.moreBtnTitle)+\" \")])],1)]):_vm._e(),(_vm.styleType === 'style2')?_c('div',{staticClass:\"hotProduct-component-style2\"},[_c('div',{staticClass:\"hotProduct-component-style2__container\"},[_c('div',{staticClass:\"hotProduct-component-title\"},[_vm._v(_vm._s(_vm.hotProductData.title))]),_c('div',{staticClass:\"hotProduct-component-subTitle\"},[_vm._v(_vm._s(_vm.hotProductData.subTitle))]),(_vm.hotProductData.displayProductList)?_c('swiper',{staticClass:\"hotProduct-component-swiper\",attrs:{\"options\":_vm.swiperOptions2}},[_vm._l((_vm.hotProductData.displayProductList.slice(0, _vm.hotProductData.productCount)),function(item,index){return _c('swiper-slide',{key:item.id,staticClass:\"hotProduct-component-swiper-item\"},[_c('div',{staticClass:\"hotProduct-component-swiper-item-container\"},[_c('div',{staticClass:\"hotProduct-component-swiper-item-img-container\",on:{\"mouseenter\":function($event){_vm.activeIndex = index},\"mouseleave\":function($event){_vm.activeIndex = null}}},[_c('img',{staticClass:\"hotProduct-component-swiper-item-img\",attrs:{\"src\":item.mainPic.split(',')[0],\"alt\":\"\"}}),_c('div',{staticClass:\"hotProduct-component-swiper-item-btn\",style:({bottom: index === _vm.activeIndex ? '0px' : '-50px'}),on:{\"click\":function($event){$event.stopPropagation();return _vm.handleClick(item)}}},[_vm._v(\" \"+_vm._s(_vm.$t('查看详情'))+\" \")])]),_c('div',{staticClass:\"hotProduct-component-swiper-item-content\"},[_c('div',{staticClass:\"hotProduct-component-swiper-item-title\"},[_vm._v(_vm._s(item.prodTitle))]),_c('div',{staticClass:\"hotProduct-component-swiper-item-desc\"},[_vm._v(_vm._s(item.prodDescription))])])])])}),_c('div',{staticClass:\"hot-product-swiper-pagination\",attrs:{\"slot\":\"pagination\"},slot:\"pagination\"})],2):_vm._e(),_c('div',{staticClass:\"hotProduct-component-moreBtn\",on:{\"click\":_vm.handleViewMore}},[_vm._v(\" \"+_vm._s(_vm.hotProductData.moreBtnTitle)+\" \")])],1)]):_vm._e()])}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","<template>\n <div class=\"hotProduct-component\" :class=\"theme\">\n <!-- 热门产品 -->\n <!-- 点击事件禁用遮罩 -->\n <div v-if=\"clickDisabled\" class=\"hotProduct-component-click-disabled-mask\" />\n <div v-if=\"styleType === 'style1'\" class=\"hotProduct-component-style1\">\n <div class=\"hotProduct-component-style1__container\">\n <!-- 标题 -->\n <div class=\"hotProduct-component-title\">{{ hotProductData.title }}</div>\n <!-- 副标题 -->\n <div class=\"hotProduct-component-subTitle\">{{ hotProductData.subTitle }}</div>\n <!-- 热门产品列表 -->\n <swiper v-if=\"hotProductData.displayProductList\" :options=\"swiperOptions\" class=\"hotProduct-component-swiper\">\n <swiper-slide v-for=\"item in hotProductData.displayProductList.slice(0, hotProductData.productCount)\" :key=\"item.id\" class=\"hotProduct-component-swiper-item\">\n <div class=\"hotProduct-component-swiper-item-container\">\n <img :src=\"item.mainPic.split(',')[0]\" alt=\"\" class=\"hotProduct-component-swiper-item-img\">\n <div class=\"hotProduct-component-swiper-item-content\">\n <div class=\"hotProduct-component-swiper-item-title\">{{ item.prodTitle }}</div>\n <div class=\"hotProduct-component-swiper-item-desc\">{{ item.prodDescription }}</div>\n </div>\n <div class=\"hotProduct-component-swiper-item-btn\" @click.stop=\"handleClick(item)\">\n {{ $t('查看详情') }}\n <i class=\"iconfont el-icon-top-right\" />\n </div>\n </div>\n </swiper-slide>\n <!-- 导航按钮 -->\n <div slot=\"button-next\" class=\"swiper-button-next-hotProduct\">\n <div class=\"swiper-button-next-hotProduct-content\">\n <img :src=\"assets.leftArrow\" alt=\"\">\n </div>\n </div>\n <div slot=\"button-prev\" class=\"swiper-button-prev-hotProduct\">\n <div class=\"swiper-button-prev-hotProduct-content\">\n <img :src=\"assets.leftArrow\" alt=\"\">\n </div>\n </div>\n </swiper>\n <div class=\"hotProduct-component-moreBtn\" @click=\"handleViewMore\">\n {{ hotProductData.moreBtnTitle }}\n </div>\n </div>\n </div>\n <div v-if=\"styleType === 'style2'\" class=\"hotProduct-component-style2\">\n <div class=\"hotProduct-component-style2__container\">\n <!-- 标题 -->\n <div class=\"hotProduct-component-title\">{{ hotProductData.title }}</div>\n <!-- 副标题 -->\n <div class=\"hotProduct-component-subTitle\">{{ hotProductData.subTitle }}</div>\n <!-- 热门产品列表 -->\n <swiper v-if=\"hotProductData.displayProductList\" :options=\"swiperOptions2\" class=\"hotProduct-component-swiper\">\n <swiper-slide v-for=\"(item, index) in hotProductData.displayProductList.slice(0, hotProductData.productCount)\" :key=\"item.id\" class=\"hotProduct-component-swiper-item\">\n <div class=\"hotProduct-component-swiper-item-container\">\n <div class=\"hotProduct-component-swiper-item-img-container\" @mouseenter=\"activeIndex = index\" @mouseleave=\"activeIndex = null\">\n <img :src=\"item.mainPic.split(',')[0]\" alt=\"\" class=\"hotProduct-component-swiper-item-img\">\n <div class=\"hotProduct-component-swiper-item-btn\" :style=\"{bottom: index === activeIndex ? '0px' : '-50px'}\" @click.stop=\"handleClick(item)\">\n {{ $t('查看详情') }}\n </div>\n </div>\n <div class=\"hotProduct-component-swiper-item-content\">\n <div class=\"hotProduct-component-swiper-item-title\">{{ item.prodTitle }}</div>\n <div class=\"hotProduct-component-swiper-item-desc\">{{ item.prodDescription }}</div>\n </div>\n </div>\n </swiper-slide>\n <!-- 导航按钮 -->\n <div slot=\"pagination\" class=\"hot-product-swiper-pagination\" />\n </swiper>\n <div class=\"hotProduct-component-moreBtn\" @click=\"handleViewMore\">\n {{ hotProductData.moreBtnTitle }}\n </div>\n </div>\n </div>\n </div>\n</template>\n\n<script>\nimport { swiper, swiperSlide } from 'vue-awesome-swiper'\nimport 'swiper/dist/css/swiper.css'\nimport i18nService from '../../i18n/index.js'\nimport { assets } from '../../assets/index.js'\nexport default {\n name: 'HotProductComponent',\n components: {\n swiper,\n swiperSlide\n },\n props: {\n clickDisabled: {\n type: Boolean,\n default: false\n },\n styleType: {\n type: String,\n default: 'style1'\n },\n hotProductData: {\n type: Object,\n default: () => ({\n title: '', // 标题名称\n subTitle: '', // 副标题名称\n sortType: 'custom', // 数据排序 自定义排序(custom) / 根据浏览量排序(pv) 默认自定义排序\n productType: 'all', // 全部产品(all) / 选择分类(category) / 手动选择(manual) 默认全部产品\n productCount: 4, // productType == all 全部产品 显示的产品数量,最少4个\n productCategory: [], // productType == category 选择的分类 如果是产品分类 则需要选择具体的产品类别\n productList: [], // 手动选择的产品列表\n moreBtnTitle: '', // “更多”按钮文字\n isShowMoreBtn: true, // 是否显示\n moreBtnIsBlank: true, // 是否打开新窗口\n displayProductList: [] // 显示的产品列表\n })\n },\n theme: {\n type: String,\n default: ''\n }\n },\n data() {\n return {\n assets: assets,\n swiperOptions: {\n slidesPerView: 4,\n slidesPerGroup: 4,\n loop: true,\n autoplay: {\n delay: 6000,\n stopOnLastSlide: false, // 到最后一张图后是否停止自动播放\n disableOnInteraction: false // 鼠标悬停时不停止自动播放\n },\n speed: 1000,\n // 导航按钮\n navigation: {\n nextEl: '.swiper-button-next-hotProduct',\n prevEl: '.swiper-button-prev-hotProduct'\n }\n },\n swiperOptions2: {\n slidesPerView: 3,\n slidesPerColumn: 2,\n spaceBetween: 20,\n autoplay: {\n delay: 6000,\n stopOnLastSlide: false, // 到最后一张图后是否停止自动播放\n disableOnInteraction: true // 鼠标悬停时不停止自动播放\n },\n pagination: {\n el: '.hot-product-swiper-pagination',\n clickable: true\n }\n },\n activeIndex: null\n }\n },\n mounted() {\n // 组件挂载后初始化Swiper\n this.$nextTick(() => {\n // 获取产品\n // this.initSwiper()\n })\n },\n methods: {\n $t(key, defaultValue = '') {\n return i18nService.t(key, defaultValue)\n },\n handleClick(item) {\n window.location.href = `/products/${item.id}?catgId=${item.catgId}&maxCatgId=${item.maxCatgId}&title=${item.title}`\n },\n handleViewMore() {\n if (this.hotProductData.moreBtnIsBlank) {\n window.open(`/products?maxCatgId=${this.hotProductData.displayProductList[0].maxCatgId}&title=${this.hotProductData.displayProductList[0].title}`, '_blank')\n } else {\n window.location.href = `/products?maxCatgId=${this.hotProductData.displayProductList[0].maxCatgId}&title=${this.hotProductData.displayProductList[0].title}`\n }\n }\n }\n}\n</script>\n\n<style scoped lang=\"scss\">\n@import '../../styles/theme.css';\n.hotProduct-component {\n width: 100%;\n height: 100%;\n min-height: 20px;\n display: flow-root;\n position: relative;\n\n .hotProduct-component-click-disabled-mask {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n z-index: 999;\n }\n\n .hotProduct-component-style1 {\n background: rgb(245, 247, 249);\n .hotProduct-component-style1__container {\n max-width: 1200px;\n margin-left: auto;\n margin-right: auto;\n }\n .hotProduct-component-title {\n padding-top: 26px;\n padding-bottom: 15px;\n font-size: 24px;\n font-weight: 500;\n line-height: 28.8px;\n text-align: center;\n color: #015fe8;\n }\n .hotProduct-component-subTitle {\n margin-bottom: 24px;\n font-size: 14px;\n font-weight: 400;\n line-height: 1.2;\n text-align: center;\n color: #015fe8;\n }\n .hotProduct-component-swiper {\n /* Swiper导航按钮样式 */\n .swiper-button-next-hotProduct,\n .swiper-button-prev-hotProduct {\n position: absolute;\n width: 15%;\n height: 100%;\n top: 0;\n margin-top: 0;\n background-color: rgba(0, 0, 0, 0.3);\n border-radius: 50%;\n transition: all 0.3s ease;\n background: none;\n // background: url('../../assets/left-arrow.svg') no-repeat center center;\n cursor: pointer;\n opacity: 0.5;\n display: flex;\n justify-content: center;\n align-items: center;\n z-index: 1;\n\n div {\n width: 46px;\n height: 46px;\n background-color: #7f7f7f;\n display: flex;\n justify-content: center;\n align-items: center;\n }\n\n img {\n width: 20px;\n height: 20px;\n }\n\n &:hover {\n color: #fff;\n opacity: 1;\n }\n\n &::after {\n font-size: 18px;\n }\n }\n\n .swiper-button-prev-hotProduct {\n left: -30px;\n }\n\n .swiper-button-next-hotProduct {\n right: -30px;\n transform: rotate(180deg);\n }\n\n ::v-deep .hotProduct-component-swiper-item {\n padding: 0 15px;\n width: 270px !important;\n\n }\n ::v-deep .hotProduct-component-swiper-item-container {\n background-color: #FFF;\n padding-bottom: 16px;\n transition: all 0.3s ease-in-out;\n &:hover {\n box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.1);\n }\n }\n\n ::v-deep .hotProduct-component-swiper-item-content {\n padding: 18px 16px 0;\n border-top: 1px solid #e6e8ec;\n }\n ::v-deep .hotProduct-component-swiper-item-img {\n width: 270px;\n height: 387px;\n object-fit: cover;\n }\n ::v-deep .hotProduct-component-swiper-item-title {\n font-size: 14px;\n font-weight: 500;\n line-height: 16.8px;\n color: #212222;\n margin-bottom: 13px;\n }\n ::v-deep .hotProduct-component-swiper-item-desc {\n font-size: 14px;\n font-weight: 400;\n line-height: 21px;\n color: #212222;\n }\n ::v-deep .hotProduct-component-swiper-item-btn {\n margin: 32px auto 0;\n width: 145px;\n border: 1px solid #015fe8;\n border-radius: 30px;\n line-height: 21px;\n padding: 6px 0;\n text-align: center;\n color: #015fe8;\n font-size: 14px;\n font-weight: 400;\n cursor: pointer;\n }\n }\n .hotProduct-component-moreBtn {\n width: fit-content;\n margin: 44px auto 44px;\n padding: 8px 35px;\n font-size: 14px;\n font-weight: 400;\n line-height: 21px;\n text-align: center;\n border-radius: 30px;\n background-color: #015fe8;\n color: #fff;\n cursor: pointer;\n transition: all 0.3s ease-in-out;\n &:hover {\n box-shadow: 2px 2px 10px 0 rgba(0,0,0,.2);\n }\n }\n }\n\n .hotProduct-component-style2 {\n background: #fff;\n\n .hotProduct-component-style2__container {\n padding-bottom: 100px;\n max-width: 1330px;\n width: 1330px;\n margin-left: auto;\n margin-right: auto;\n }\n .hotProduct-component-title {\n padding-top: 100px;\n margin-bottom: 25px;\n font-size: 46px;\n font-weight: 500;\n line-height: 1;\n text-align: center;\n color: var(--theme-content-title-color);\n }\n .hotProduct-component-subTitle {\n margin-bottom: 46px;\n font-size: 26px;\n font-weight: 500;\n line-height: 1;\n text-align: center;\n color: var(--theme-content-subTitle-color);\n }\n .hotProduct-component-swiper {\n ::v-deep .hotProduct-component-swiper-item-content {\n padding: 20px 0 0;\n }\n ::v-deep .hotProduct-component-swiper-item-img-container {\n position: relative;\n width: 100%;\n height: 258px;\n background: #F6F7F9;\n border-radius: 20px;\n overflow: hidden;\n }\n ::v-deep .hotProduct-component-swiper-item-btn {\n position: absolute;\n width: 100%;\n height: 50px;\n border-radius: 20px;\n line-height: 1px;\n cursor: pointer;\n display: flex;\n justify-content: center;\n align-items: center;\n background: var(--theme-detail-btn-bg-color);\n transition: all 0.3s ease-in-out;\n color: #fff;\n font-size: 16px;\n font-weight: 500;\n }\n ::v-deep .hotProduct-component-swiper-item-img {\n width: 100%;\n height: 258px;\n object-fit: cover;\n }\n ::v-deep .hotProduct-component-swiper-item-title {\n width: 100%;\n font-size: 16px;\n font-weight: 500;\n line-height: 1;\n color: #000000;\n margin-bottom: 15px;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n ::v-deep .hotProduct-component-swiper-item-desc {\n width: 100%;\n font-weight: 500;\n font-size: 16px;\n color: rgba(0,0,0,0.5);\n line-height: normal;\n overflow: hidden;\n text-overflow: ellipsis;\n display: -webkit-box;\n -webkit-line-clamp: 3;\n -webkit-box-orient: vertical;\n }\n ::v-deep .swiper-wrapper {\n padding-bottom: 40px;\n }\n ::v-deep .hot-product-swiper-pagination {\n text-align: center;\n\n .swiper-pagination-bullet {\n width: 33px;\n height: 3px;\n background: #000000;\n opacity: 0.2;\n transition: all 0.3s ease-in-out;\n border-radius: 0;\n }\n\n .swiper-pagination-bullet-active {\n width: 54px;\n height: 3px;\n background: #000000;\n opacity: 1;\n }\n }\n }\n .hotProduct-component-moreBtn {\n width: fit-content;\n margin: 50px auto 0;\n padding: 9px 21px;\n font-size: 16px;\n font-weight: 400;\n line-height: 1;\n text-align: center;\n border-radius: 6px;\n background-color: transparent;\n color: var(--theme-more-btn-color);\n border: var(--theme-more-btn-border);\n cursor: pointer;\n transition: all 0.3s ease-in-out;\n &:hover {\n background: var(--theme-more-btn-hover-bg-color);\n color: #fff;\n border-color: var(--theme-more-btn-hover-bg-color);\n }\n }\n }\n}\n\n</style>\n","import mod from \"-!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../../../../../../node_modules/thread-loader/dist/cjs.js!../../../../../../../node_modules/babel-loader/lib/index.js!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./hotProduct.vue?vue&type=script&lang=js\"; export default mod; export * from \"-!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../../../../../../node_modules/thread-loader/dist/cjs.js!../../../../../../../node_modules/babel-loader/lib/index.js!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./hotProduct.vue?vue&type=script&lang=js\"","import { render, staticRenderFns } from \"./hotProduct.vue?vue&type=template&id=7e23e47b&scoped=true\"\nimport script from \"./hotProduct.vue?vue&type=script&lang=js\"\nexport * from \"./hotProduct.vue?vue&type=script&lang=js\"\nimport style0 from \"./hotProduct.vue?vue&type=style&index=0&id=7e23e47b&prod&scoped=true&lang=scss\"\n\n\n/* normalize component */\nimport normalizer from \"!../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n \"7e23e47b\",\n null\n \n)\n\nexport default component.exports","import hotProduct from './hotProduct.vue'\n\nhotProduct.install = Vue => Vue.component(hotProduct.name, hotProduct)\n\nexport default hotProduct\n","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:\"newsInformation-component\",class:_vm.theme},[(_vm.clickDisabled)?_c('div',{staticClass:\"newsInformation-component-click-disabled-mask\"}):_vm._e(),(_vm.styleType === 'style1')?_c('div',{staticClass:\"newsInformation-component-style1\"},[_c('div',{staticClass:\"newsInformation-component-style1__container\"},[_c('div',{staticClass:\"newsInformation-component-title\"},[_vm._v(_vm._s(_vm.newsInformationData.title))]),_c('div',{staticClass:\"newsInformation-component-subTitle\"},[_vm._v(_vm._s(_vm.newsInformationData.subTitle))]),_c('div',{staticClass:\"newsInformation-component-newsList\"},[(_vm.newsInformationData.displayNewsList && _vm.newsInformationData.displayNewsList.length > 0)?_c('div',{staticClass:\"newsInformation-component-newsList-item-left\"},[_c('img',{attrs:{\"src\":_vm.newsInformationData.displayNewsList[0].mainPic,\"alt\":\"\"}}),_c('div',{staticClass:\"newsInformation-component-newsList-item-title\"},[_vm._v(_vm._s(_vm.newsInformationData.displayNewsList[0].title))]),_c('div',{staticClass:\"newsInformation-component-newsList-item-description\"},[_vm._v(_vm._s(_vm.newsInformationData.displayNewsList[0].description))]),_c('div',{staticClass:\"newsInformation-component-newsList-item-bottom\"},[_c('div',{staticClass:\"newsInformation-component-newsList-item-bottom-more-btn\",on:{\"click\":function($event){return _vm.handleClick(_vm.newsInformationData.displayNewsList[0])}}},[_vm._v(\" \"+_vm._s(_vm.newsInformationData.moreBtnTitle)+\" \")]),_c('div',{staticClass:\"newsInformation-component-newsList-item-bottom-date\"},[_vm._v(\" \"+_vm._s(_vm.newsInformationData.displayNewsList[0].publicDate)+\" \")])])]):_vm._e(),(_vm.newsInformationData.displayNewsList && _vm.newsInformationData.displayNewsList.length > 1)?_c('div',{staticClass:\"newsInformation-component-newsList-right\"},_vm._l((_vm.newsInformationData.displayNewsList.slice(1, _vm.newsInformationData.newsCount)),function(item){return _c('div',{key:item.id,staticClass:\"newsInformation-component-newsList-item\",on:{\"click\":function($event){return _vm.handleClick(item)}}},[_c('img',{attrs:{\"src\":item.mainPic,\"alt\":\"\"}}),_c('div',{staticClass:\"newsInformation-component-newsList-item-content\"},[_c('div',{staticClass:\"newsInformation-component-newsList-item-content-title\"},[_vm._v(_vm._s(item.title))]),_c('div',{staticClass:\"newsInformation-component-newsList-item-content-description\"},[_vm._v(_vm._s(item.description))]),_c('div',{staticClass:\"newsInformation-component-newsList-item-content-bottom\"},[_c('span',[_vm._v(_vm._s(item.publicDate))]),_c('i',{staticClass:\"iconfont el-icon-right\"})])])])}),0):_vm._e()]),_c('div',{staticClass:\"newsInformation-component-moreBtn\",on:{\"click\":_vm.handleMoreClick}},[_vm._v(\" \"+_vm._s(_vm.newsInformationData.moreBtnTitle)+\" \")])])]):_vm._e(),(_vm.styleType === 'style2')?_c('div',{staticClass:\"newsInformation-component-style2\"},[_c('div',{staticClass:\"newsInformation-component-style2__container\"},[_c('div',{staticClass:\"newsInformation-component-title\"},[_vm._v(_vm._s(_vm.newsInformationData.title))]),_c('div',{staticClass:\"newsInformation-component-subTitle\"},[_vm._v(_vm._s(_vm.newsInformationData.subTitle))]),_c('div',{staticClass:\"newsInformation-component-newsList\"},[(_vm.newsInformationData.displayNewsList && _vm.newsInformationData.displayNewsList.length > 0)?_c('div',{staticClass:\"newsInformation-component-newsList-item-left\"},[_c('img',{attrs:{\"src\":_vm.newsInformationData.displayNewsList[0].mainPic,\"alt\":\"\"}}),_c('div',{staticClass:\"newsInformation-component-newsList-item-title\",on:{\"click\":function($event){return _vm.handleClick(_vm.newsInformationData.displayNewsList[0])}}},[_vm._v(_vm._s(_vm.newsInformationData.displayNewsList[0].title))])]):_vm._e(),(_vm.newsInformationData.displayNewsList && _vm.newsInformationData.displayNewsList.length > 0)?_c('div',{staticClass:\"newsInformation-component-newsList-item-middle\",style:({ backgroundImage: (\"url(\" + (_vm.assets.newsCenterBg) + \")\") })},[_c('div',{staticClass:\"newsInformation-component-newsList-item-description\"},[_vm._v(_vm._s(_vm.newsInformationData.displayNewsList[0].description))])]):_vm._e(),(_vm.newsInformationData.displayNewsList && _vm.newsInformationData.displayNewsList.length > 1)?_c('div',{staticClass:\"newsInformation-component-newsList-right\"},[_c('div',{staticClass:\"newsInformation-component-newsList-title\"},[_vm._v(_vm._s(_vm.$t('热门资讯')))]),_vm._l((_vm.newsInformationData.displayNewsList.slice(1, _vm.newsInformationData.newsCount)),function(item){return _c('div',{key:item.id,staticClass:\"newsInformation-component-newsList-item\",on:{\"click\":function($event){return _vm.handleClick(item)}}},[_c('img',{attrs:{\"src\":item.mainPic,\"alt\":\"\"}}),_c('div',{staticClass:\"newsInformation-component-newsList-item-content\"},[_c('div',{staticClass:\"newsInformation-component-newsList-item-content-title\"},[_vm._v(_vm._s(item.title))]),_c('div',{staticClass:\"newsInformation-component-newsList-item-content-description\"},[_vm._v(_vm._s(item.description))]),_c('div',{staticClass:\"newsInformation-component-newsList-item-content-bottom\"},[_c('span',[_vm._v(_vm._s(item.publicDate ? item.publicDate.replaceAll('-', '.') : ''))])])])])})],2):_vm._e()]),_c('div',{staticClass:\"newsInformation-component-moreBtn\",on:{\"click\":_vm.handleMoreClick}},[_vm._v(\" \"+_vm._s(_vm.newsInformationData.moreBtnTitle)+\" \")])])]):_vm._e()])}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","<template>\n <div class=\"newsInformation-component\" :class=\"theme\">\n <!-- 新闻资讯 -->\n <!-- 点击事件禁用遮罩 -->\n <div v-if=\"clickDisabled\" class=\"newsInformation-component-click-disabled-mask\" />\n <div v-if=\"styleType === 'style1'\" class=\"newsInformation-component-style1\">\n <div class=\"newsInformation-component-style1__container\">\n <!-- 标题 -->\n <div class=\"newsInformation-component-title\">{{ newsInformationData.title }}</div>\n <!-- 副标题 -->\n <div class=\"newsInformation-component-subTitle\">{{ newsInformationData.subTitle }}</div>\n <!-- 文章列表 -->\n <div class=\"newsInformation-component-newsList\">\n <div v-if=\"newsInformationData.displayNewsList && newsInformationData.displayNewsList.length > 0\" class=\"newsInformation-component-newsList-item-left\">\n <img :src=\"newsInformationData.displayNewsList[0].mainPic\" alt=\"\">\n <div class=\"newsInformation-component-newsList-item-title\">{{ newsInformationData.displayNewsList[0].title }}</div>\n <div class=\"newsInformation-component-newsList-item-description\">{{ newsInformationData.displayNewsList[0].description }}</div>\n <div class=\"newsInformation-component-newsList-item-bottom\">\n <div class=\"newsInformation-component-newsList-item-bottom-more-btn\" @click=\"handleClick(newsInformationData.displayNewsList[0])\">\n {{ newsInformationData.moreBtnTitle }}\n </div>\n <div class=\"newsInformation-component-newsList-item-bottom-date\">\n {{ newsInformationData.displayNewsList[0].publicDate }}\n </div>\n </div>\n </div>\n <div v-if=\"newsInformationData.displayNewsList && newsInformationData.displayNewsList.length > 1\" class=\"newsInformation-component-newsList-right\">\n <div v-for=\"item in newsInformationData.displayNewsList.slice(1, newsInformationData.newsCount)\" :key=\"item.id\" class=\"newsInformation-component-newsList-item\" @click=\"handleClick(item)\">\n <img :src=\"item.mainPic\" alt=\"\">\n <div class=\"newsInformation-component-newsList-item-content\">\n <div class=\"newsInformation-component-newsList-item-content-title\">{{ item.title }}</div>\n <div class=\"newsInformation-component-newsList-item-content-description\">{{ item.description }}</div>\n <div class=\"newsInformation-component-newsList-item-content-bottom\">\n <span>{{ item.publicDate }}</span>\n <i class=\"iconfont el-icon-right\" />\n </div>\n </div>\n </div>\n </div>\n </div>\n <div class=\"newsInformation-component-moreBtn\" @click=\"handleMoreClick\">\n {{ newsInformationData.moreBtnTitle }}\n </div>\n </div>\n </div>\n <div v-if=\"styleType === 'style2'\" class=\"newsInformation-component-style2\">\n <div class=\"newsInformation-component-style2__container\">\n <!-- 标题 -->\n <div class=\"newsInformation-component-title\">{{ newsInformationData.title }}</div>\n <!-- 副标题 -->\n <div class=\"newsInformation-component-subTitle\">{{ newsInformationData.subTitle }}</div>\n <!-- 文章列表 -->\n <div class=\"newsInformation-component-newsList\">\n <div v-if=\"newsInformationData.displayNewsList && newsInformationData.displayNewsList.length > 0\" class=\"newsInformation-component-newsList-item-left\">\n <img :src=\"newsInformationData.displayNewsList[0].mainPic\" alt=\"\">\n <div class=\"newsInformation-component-newsList-item-title\" @click=\"handleClick(newsInformationData.displayNewsList[0])\">{{ newsInformationData.displayNewsList[0].title }}</div>\n </div>\n <div v-if=\"newsInformationData.displayNewsList && newsInformationData.displayNewsList.length > 0\" class=\"newsInformation-component-newsList-item-middle\" :style=\"{ backgroundImage: `url(${assets.newsCenterBg})` }\">\n <div class=\"newsInformation-component-newsList-item-description\">{{ newsInformationData.displayNewsList[0].description }}</div>\n </div>\n <div v-if=\"newsInformationData.displayNewsList && newsInformationData.displayNewsList.length > 1\" class=\"newsInformation-component-newsList-right\">\n <div class=\"newsInformation-component-newsList-title\">{{ $t('热门资讯') }}</div>\n <div v-for=\"item in newsInformationData.displayNewsList.slice(1, newsInformationData.newsCount)\" :key=\"item.id\" class=\"newsInformation-component-newsList-item\" @click=\"handleClick(item)\">\n <img :src=\"item.mainPic\" alt=\"\">\n <div class=\"newsInformation-component-newsList-item-content\">\n <div class=\"newsInformation-component-newsList-item-content-title\">{{ item.title }}</div>\n <div class=\"newsInformation-component-newsList-item-content-description\">{{ item.description }}</div>\n <div class=\"newsInformation-component-newsList-item-content-bottom\">\n <span>{{ item.publicDate ? item.publicDate.replaceAll('-', '.') : '' }}</span>\n </div>\n </div>\n </div>\n </div>\n </div>\n <div class=\"newsInformation-component-moreBtn\" @click=\"handleMoreClick\">\n {{ newsInformationData.moreBtnTitle }}\n </div>\n </div>\n </div>\n </div>\n</template>\n\n<script>\nimport i18nService from '../../i18n/index.js'\nimport { assets } from '../../assets/index.js'\nexport default {\n name: 'NewsInformationComponent',\n props: {\n clickDisabled: {\n type: Boolean,\n default: false\n },\n styleType: {\n type: String,\n default: 'style1'\n },\n newsInformationData: {\n type: Object,\n default: () => ({\n title: '', // 标题名称\n subTitle: '', // 副标题名称\n sortType: 'custom', // 数据排序 自定义排序(custom) / 根据点击量排序(pv) 默认自定义排序\n newsType: 'all', // 全部新闻(all) / 选择分类(category) / 手动选择(manual) 默认全部新闻\n newsCount: 4, // newsType == all 全部新闻 显示的新闻数量,最少4个\n newsCategory: [], // newsType == category 选择的分类 如果是新闻分类 则需要选择具体的新闻类别\n newsList: [], // 手动选择的新闻列表id\n moreBtnTitle: '', // “更多”按钮文字\n isShowMoreBtn: true, // 是否显示\n moreBtnIsBlank: true, // 是否打开新窗口\n displayNewsList: [] // 最终展示的新闻资讯列表,由父组件调用接口并排序后传递\n })\n },\n theme: {\n type: String,\n default: ''\n }\n },\n data() {\n return {\n assets: assets,\n swiperOptions: {\n slidesPerView: 4,\n slidesPerGroup: 4,\n loop: true,\n autoplay: {\n delay: 6000,\n stopOnLastSlide: false, // 到最后一张图后是否停止自动播放\n disableOnInteraction: false // 鼠标悬停时不停止自动播放\n },\n speed: 1000,\n // 导航按钮\n navigation: {\n nextEl: '.swiper-button-next-newsInformation',\n prevEl: '.swiper-button-prev-newsInformation'\n }\n }\n }\n },\n mounted() {\n // 组件挂载后初始化Swiper\n this.$nextTick(() => {\n // 获取产品\n // this.initSwiper()\n })\n },\n methods: {\n $t(key, defaultValue = '') {\n return i18nService.t(key, defaultValue)\n },\n handleClick(item) {\n if (this.newsInformationData.moreBtnIsBlank) {\n window.open(`/article-page/${item.id}?&maxCatgId=${item.maxCatgId}&catgId=${item.catgId}&title=${item.title}`, '_blank')\n } else {\n window.location.href = `/article-page/${item.id}?&maxCatgId=${item.maxCatgId}&catgId=${item.catgId}&title=${item.title}`\n }\n },\n handleMoreClick() {\n if (this.newsInformationData.moreBtnIsBlank) {\n window.open(`/article-page?maxCatgId=${this.newsInformationData.displayNewsList[0].maxCatgId}&title=${this.newsInformationData.displayNewsList[0].title}`, '_blank')\n } else {\n window.location.href = `/article-page?maxCatgId=${this.newsInformationData.displayNewsList[0].maxCatgId}&title=${this.newsInformationData.displayNewsList[0].title}`\n }\n }\n }\n}\n</script>\n\n<style scoped lang=\"scss\">\n.newsInformation-component {\n width: 100%;\n height: 100%;\n min-height: 20px;\n display: flow-root;\n position: relative;\n\n .newsInformation-component-click-disabled-mask {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n z-index: 999;\n }\n\n .newsInformation-component-style1 {\n background: #f5f7f9;\n .newsInformation-component-style1__container {\n padding-top: 26px;\n padding-bottom: 24px;\n max-width: 1200px;\n margin-left: auto;\n margin-right: auto;\n }\n .newsInformation-component-title {\n margin-top: 26px;\n margin-bottom: 15px;\n font-size: 24px;\n font-weight: 500;\n line-height: 28.8px;\n text-align: center;\n color: #015fe8;\n }\n .newsInformation-component-subTitle {\n margin-bottom: 24px;\n font-size: 14px;\n font-weight: 400;\n line-height: 1.2;\n text-align: center;\n color: #015fe8;\n }\n .newsInformation-component-newsList {\n display: flex;\n justify-content: center;\n align-items: flex-start;\n flex-wrap: wrap;\n .newsInformation-component-newsList-item-left {\n padding: 0 15px;\n width: 600px;\n background-color: #fff;\n img {\n width: 570px;\n height: 570px;\n }\n .newsInformation-component-newsList-item-title {\n margin-top: 20px;\n margin-bottom: 20px;\n padding: 0 17px;\n font-size: 24px;\n font-weight: 500;\n line-height: 28.8px;\n color: #212222;\n // 超出两行省略\n overflow: hidden;\n text-overflow: ellipsis;\n display: -webkit-box;\n -webkit-line-clamp: 2;\n -webkit-box-orient: vertical;\n }\n .newsInformation-component-newsList-item-description {\n padding: 0 17px;\n color: #878b90;\n // 超出两行省略\n overflow: hidden;\n text-overflow: ellipsis;\n display: -webkit-box;\n -webkit-line-clamp: 2;\n -webkit-box-orient: vertical;\n font-size: 14px;\n font-weight: 400;\n line-height: 21px;\n }\n .newsInformation-component-newsList-item-bottom {\n padding: 0 17px;\n display: flex;\n justify-content: space-between;\n align-items: center;\n margin-top: 24px;\n .newsInformation-component-newsList-item-bottom-more-btn {\n width: fit-content;\n margin: 61px 0 44px;\n padding: 8px 35px;\n font-size: 14px;\n font-weight: 400;\n line-height: 21px;\n text-align: center;\n border-radius: 30px;\n background-color: #015fe8;\n color: #fff;\n cursor: pointer;\n transition: all 0.3s ease-in-out;\n &:hover {\n box-shadow: 2px 2px 10px 0 rgba(0,0,0,.2);\n }\n }\n .newsInformation-component-newsList-item-bottom-date {\n font-size: 14px;\n font-weight: 400;\n line-height: 21px;\n text-align: center;\n color: #878b90;\n }\n }\n }\n .newsInformation-component-newsList-right {\n padding: 0 15px;\n width: 600px;\n .newsInformation-component-newsList-item {\n margin-bottom: 16px;\n width: 100%;\n height: 200px;\n background-color: #fff;\n display: flex;\n justify-content: center;\n img {\n margin-right: 15px;\n width: 220px;\n height: 200px;\n }\n .newsInformation-component-newsList-item-content {\n padding: 26px 18px;\n .newsInformation-component-newsList-item-content-title {\n margin-bottom: 20px;\n font-size: 14px;\n font-weight: 500;\n line-height: 16.8px;\n color: #212222;\n }\n .newsInformation-component-newsList-item-content-description {\n font-size: 14px;\n font-weight: 400;\n line-height: 21px;\n color: #878b90;\n // 超出三行省略\n overflow: hidden;\n text-overflow: ellipsis;\n display: -webkit-box;\n -webkit-line-clamp: 3;\n -webkit-box-orient: vertical;\n }\n .newsInformation-component-newsList-item-content-bottom {\n margin-top: 26px;\n display: flex;\n justify-content: space-between;\n align-items: center;\n font-size: 14px;\n font-weight: 400;\n line-height: 21px;\n color: #878b90;\n\n i {\n font-size: 18px;\n }\n }\n }\n }\n }\n }\n\n .newsInformation-component-moreBtn {\n width: fit-content;\n margin: 24px auto 0;\n padding: 8px 35px;\n font-size: 14px;\n font-weight: 400;\n line-height: 21px;\n text-align: center;\n border-radius: 30px;\n background-color: #015fe8;\n color: #fff;\n cursor: pointer;\n transition: all 0.3s ease-in-out;\n &:hover {\n box-shadow: 2px 2px 10px 0 rgba(0,0,0,.2);\n }\n }\n }\n\n .newsInformation-component-style2 {\n background: #fff;\n .newsInformation-component-style2__container {\n padding-top: 100px;\n max-width: 1334px;\n margin-left: auto;\n margin-right: auto;\n }\n .newsInformation-component-title {\n margin-bottom: 25px;\n height: 46px;\n font-weight: 500;\n font-size: 46px;\n color: var(--theme-content-title-color);\n text-align: center;\n font-style: normal;\n text-transform: none;\n line-height: 46px;\n }\n .newsInformation-component-subTitle {\n margin-bottom: 50px;\n height: 26px;\n font-weight: 500;\n font-size: 26px;\n color: var(--theme-content-subTitle-color);\n text-align: center;\n font-style: normal;\n text-transform: none;\n }\n .newsInformation-component-newsList {\n display: flex;\n justify-content: center;\n align-items: flex-start;\n flex-wrap: wrap;\n gap: 20px;\n .newsInformation-component-newsList-item-left {\n width: 431px;\n height: 558px;\n background-color: #F6F7F9;\n img {\n display: block;\n width: 431px;\n height: 416px;\n }\n .newsInformation-component-newsList-item-title {\n margin-top: 40px;\n margin-bottom: 40px;\n padding: 0 25px;\n font-size: 16px;\n font-weight: 500;\n line-height: 1.2;\n color: #000000;\n // 超出两行省略\n overflow: hidden;\n text-overflow: ellipsis;\n display: -webkit-box;\n -webkit-line-clamp: 3;\n -webkit-box-orient: vertical;\n cursor: pointer;\n }\n .newsInformation-component-newsList-item-description {\n padding: 0 17px;\n color: #878b90;\n // 超出两行省略\n overflow: hidden;\n text-overflow: ellipsis;\n display: -webkit-box;\n -webkit-line-clamp: 2;\n -webkit-box-orient: vertical;\n font-size: 14px;\n font-weight: 400;\n line-height: 21px;\n }\n }\n .newsInformation-component-newsList-item-middle {\n padding: 50px 40px;\n width: 431px;\n height: 558px;\n background-color: #E4E9EE;\n background-size: cover;\n background-position: center;\n font-weight: 500;\n font-size: 16px;\n color: #000000;\n text-align: left;\n font-style: normal;\n text-transform: none;\n overflow: hidden;\n }\n .newsInformation-component-newsList-right {\n width: calc(100% - 431px - 20px - 431px - 20px);\n height: 558px;\n\n .newsInformation-component-newsList-title {\n margin-bottom: 30px;\n font-weight: 500;\n font-size: 26px;\n color: #000000;\n text-align: left;\n font-style: normal;\n text-transform: none;\n line-height: 1;\n }\n .newsInformation-component-newsList-item {\n margin-bottom: 20px;\n width: 100%;\n height: 154px;\n background-color: #fff;\n display: flex;\n justify-content: center;\n cursor: pointer;\n\n img {\n width: 200px;\n height: 154px;\n }\n .newsInformation-component-newsList-item-content {\n padding-left: 21px;\n .newsInformation-component-newsList-item-content-title {\n margin-bottom: 15px;\n line-height: 1;\n width: 210px;\n height: 18px;\n font-weight: 500;\n font-size: 16px;\n color: #000000;\n text-align: left;\n font-style: normal;\n text-transform: none;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n }\n .newsInformation-component-newsList-item-content-description {\n margin-bottom: 15px;\n line-height: 1.2;\n // 超出三行省略\n overflow: hidden;\n text-overflow: ellipsis;\n display: -webkit-box;\n -webkit-line-clamp: 3;\n -webkit-box-orient: vertical;\n font-weight: 500;\n font-size: 16px;\n color: rgba(0, 0, 0, 0.5);\n text-align: left;\n font-style: normal;\n text-transform: none;\n }\n .newsInformation-component-newsList-item-content-bottom {\n height: 16px;\n font-weight: 500;\n font-size: 16px;\n color: #000000;\n text-align: left;\n font-style: normal;\n text-transform: none;\n }\n }\n }\n }\n }\n\n .newsInformation-component-moreBtn {\n width: fit-content;\n margin: 50px auto;\n padding: 9px 21px;\n font-size: 16px;\n font-weight: 500;\n line-height: 1;\n text-align: center;\n border-radius: 6px;\n border: var(--theme-more-btn-border);\n color: var(--theme-more-btn-color);\n cursor: pointer;\n transition: all 0.3s ease-in-out;\n &:hover {\n background-color: var(--theme-more-btn-hover-bg-color);\n color: #fff;\n border-color: var(--theme-more-btn-hover-bg-color);\n }\n }\n }\n\n}\n\n</style>\n","import mod from \"-!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../../../../../../node_modules/thread-loader/dist/cjs.js!../../../../../../../node_modules/babel-loader/lib/index.js!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./newsInformation.vue?vue&type=script&lang=js\"; export default mod; export * from \"-!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../../../../../../node_modules/thread-loader/dist/cjs.js!../../../../../../../node_modules/babel-loader/lib/index.js!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./newsInformation.vue?vue&type=script&lang=js\"","import { render, staticRenderFns } from \"./newsInformation.vue?vue&type=template&id=75b8d9ae&scoped=true\"\nimport script from \"./newsInformation.vue?vue&type=script&lang=js\"\nexport * from \"./newsInformation.vue?vue&type=script&lang=js\"\nimport style0 from \"./newsInformation.vue?vue&type=style&index=0&id=75b8d9ae&prod&scoped=true&lang=scss\"\n\n\n/* normalize component */\nimport normalizer from \"!../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n \"75b8d9ae\",\n null\n \n)\n\nexport default component.exports","import newsInformation from './newsInformation.vue'\n\nnewsInformation.install = Vue => Vue.component(newsInformation.name, newsInformation)\n\nexport default newsInformation\n","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:\"productList-component\",class:_vm.theme},[(_vm.clickDisabled)?_c('div',{staticClass:\"productList-component-click-disabled-mask\"}):_vm._e(),(_vm.styleType === 'style1')?_c('div',{staticClass:\"productList-component-style1\"},[_c('div',{staticClass:\"productList-component-style1__container\"},[_c('div',{staticClass:\"productList-component-title\"},[_vm._v(_vm._s(_vm.productListData.title))]),_c('div',{staticClass:\"productList-component-subTitle\"},[_vm._v(_vm._s(_vm.productListData.subTitle))]),(_vm.productListData.displayProductList)?_c('div',{staticClass:\"productList-component-productList\"},_vm._l((_vm.productListData.displayProductList.slice(0, _vm.productListData.productCount)),function(item){return _c('div',{key:item.busiProdNewId,staticClass:\"productList-component-productItem\"},[_c('div',{staticClass:\"productList-component-productImg\"},[_c('img',{attrs:{\"src\":item.mainPic.split(',')[0],\"alt\":\"\"}})]),_c('div',{staticClass:\"productList-component-productInfo\"},[_c('div',{staticClass:\"productList-component-productName\"},[_vm._v(_vm._s(item.prodTitle))]),_c('div',{staticClass:\"productList-component-productPrice\"},[_vm._v(\"¥\"+_vm._s(item.prodDescription))]),_c('div',{staticClass:\"productList-component-productMore\",on:{\"click\":function($event){return _vm.handleClick(item)}}},[_vm._v(\" \"+_vm._s(_vm.$t('查看详情'))+\" \"),_c('i',{staticClass:\"el-icon-top-right\"})])])])}),0):_vm._e(),_c('div',{staticClass:\"productList-component-moreBtn\",on:{\"click\":_vm.handleViewMore}},[_vm._v(\" \"+_vm._s(_vm.productListData.moreBtnTitle)+\" \")])])]):_vm._e(),(_vm.styleType === 'style2')?_c('div',{staticClass:\"productList-component-style2\"},[_c('div',{staticClass:\"productList-component-style2__container\"},[_c('div',{staticClass:\"productList-component-title\"},[_vm._v(_vm._s(_vm.productListData.title))]),_c('div',{staticClass:\"productList-component-subTitle\"},[_vm._v(_vm._s(_vm.productListData.subTitle))]),(_vm.productListData.displayProductList)?_c('swiper',{staticClass:\"productList-component-productList\",attrs:{\"options\":_vm.swiperOptions}},[_vm._l((_vm.productListData.displayProductList.slice(0, _vm.productListData.productCount)),function(item){return _c('swiper-slide',{key:item.busiProdNewId,staticClass:\"productList-component-productItem\"},[_c('div',{staticClass:\"productList-component-productInfo\"},[_c('div',{staticClass:\"productList-component-productName\"},[_vm._v(_vm._s(item.prodTitle))]),_c('div',{staticClass:\"productList-component-productPrice\"},[_vm._v(\"¥\"+_vm._s(item.prodDescription))]),_c('div',{staticClass:\"productList-component-productMore\",on:{\"click\":function($event){return _vm.handleClick(item)}}},[_vm._v(\" \"+_vm._s(_vm.$t('查看详情'))+\" \")])]),_c('div',{staticClass:\"productList-component-productImg\"},[_c('img',{attrs:{\"src\":item.mainPic.split(',')[0],\"alt\":\"\"}})])])}),_c('div',{staticClass:\"productList-component-pagination\",attrs:{\"slot\":\"pagination\"},slot:\"pagination\"})],2):_vm._e(),_c('div',{staticClass:\"productList-component-moreBtn\",on:{\"click\":_vm.handleViewMore}},[_vm._v(\" \"+_vm._s(_vm.productListData.moreBtnTitle)+\" \")])],1)]):_vm._e()])}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","<template>\n <div class=\"productList-component\" :class=\"theme\">\n <!-- 热门产品 -->\n <!-- 点击事件禁用遮罩 -->\n <div v-if=\"clickDisabled\" class=\"productList-component-click-disabled-mask\" />\n <div v-if=\"styleType === 'style1'\" class=\"productList-component-style1\">\n <div class=\"productList-component-style1__container\">\n <!-- 标题 -->\n <div class=\"productList-component-title\">{{ productListData.title }}</div>\n <!-- 副标题 -->\n <div class=\"productList-component-subTitle\">{{ productListData.subTitle }}</div>\n <!-- 热门产品列表 -->\n <div v-if=\"productListData.displayProductList\" class=\"productList-component-productList\">\n <div v-for=\"item in productListData.displayProductList.slice(0, productListData.productCount)\" :key=\"item.busiProdNewId\" class=\"productList-component-productItem\">\n <div class=\"productList-component-productImg\">\n <img :src=\"item.mainPic.split(',')[0]\" alt=\"\">\n </div>\n <div class=\"productList-component-productInfo\">\n <div class=\"productList-component-productName\">{{ item.prodTitle }}</div>\n <div class=\"productList-component-productPrice\">¥{{ item.prodDescription }}</div>\n <div class=\"productList-component-productMore\" @click=\"handleClick(item)\">\n {{ $t('查看详情') }}\n <i class=\"el-icon-top-right\" />\n </div>\n </div>\n </div>\n </div>\n <div class=\"productList-component-moreBtn\" @click=\"handleViewMore\">\n {{ productListData.moreBtnTitle }}\n </div>\n </div>\n </div>\n <div v-if=\"styleType === 'style2'\" class=\"productList-component-style2\">\n <div class=\"productList-component-style2__container\">\n <!-- 标题 -->\n <div class=\"productList-component-title\">{{ productListData.title }}</div>\n <!-- 副标题 -->\n <div class=\"productList-component-subTitle\">{{ productListData.subTitle }}</div>\n <!-- 热门产品列表 -->\n <swiper v-if=\"productListData.displayProductList\" :options=\"swiperOptions\" class=\"productList-component-productList\">\n <swiper-slide v-for=\"item in productListData.displayProductList.slice(0, productListData.productCount)\" :key=\"item.busiProdNewId\" class=\"productList-component-productItem\">\n <div class=\"productList-component-productInfo\">\n <div class=\"productList-component-productName\">{{ item.prodTitle }}</div>\n <div class=\"productList-component-productPrice\">¥{{ item.prodDescription }}</div>\n <div class=\"productList-component-productMore\" @click=\"handleClick(item)\">\n {{ $t('查看详情') }}\n </div>\n </div>\n <div class=\"productList-component-productImg\">\n <img :src=\"item.mainPic.split(',')[0]\" alt=\"\">\n </div>\n </swiper-slide>\n <!-- 导航按钮 -->\n <div slot=\"pagination\" class=\"productList-component-pagination\" />\n </swiper>\n <div class=\"productList-component-moreBtn\" @click=\"handleViewMore\">\n {{ productListData.moreBtnTitle }}\n </div>\n </div>\n </div>\n </div>\n</template>\n\n<script>\nimport { swiper, swiperSlide } from 'vue-awesome-swiper'\nimport 'swiper/dist/css/swiper.css'\nimport i18nService from '../../i18n/index.js'\nexport default {\n name: 'ProductListComponent',\n components: {\n swiper,\n swiperSlide\n },\n props: {\n clickDisabled: {\n type: Boolean,\n default: false\n },\n styleType: {\n type: String,\n default: 'style1'\n },\n productListData: {\n title: '', // 标题名称\n subTitle: '', // 副标题名称\n sortType: 'custom', // 数据排序 自定义排序(custom) / 根据浏览量排序(pv) 默认自定义排序\n productType: 'all', // 全部产品(all) / 选择分类(category) / 手动选择(manual) 默认全部产品\n productCount: 4, // productType == all 全部产品 显示的产品数量,最少4个\n productCategory: [], // productType == category 选择的分类 如果是产品分类 则需要选择具体的产品类别\n productList: [], // 手动选择的产品列表\n moreBtnTitle: '', // “更多”按钮文字\n isShowMoreBtn: true, // 是否显示\n moreBtnIsBlank: true, // 是否打开新窗口\n displayProductList: [] // 显示的产品列表\n }, // 产品列表\n theme: {\n type: String,\n default: ''\n }\n },\n data() {\n return {\n productList: [],\n swiperOptions: {\n slidesPerView: 3,\n slidesPerColumn: 3,\n spaceBetween: 20,\n // autoplay: {\n // delay: 6000,\n // stopOnLastSlide: false, // 到最后一张图后是否停止自动播放\n // disableOnInteraction: true, // 鼠标悬停时不停止自动播放\n // },\n pagination: {\n el: '.productList-component-pagination',\n clickable: true\n }\n }\n }\n },\n mounted() {\n // 组件挂载后初始化Swiper\n this.$nextTick(() => {\n // 获取产品\n // this.initSwiper()\n })\n },\n methods: {\n $t(key, defaultValue = '') {\n return i18nService.t(key, defaultValue)\n },\n handleClick(item) {\n window.location.href = `/products/${item.id}?catgId=${item.catgId}&maxCatgId=${item.maxCatgId}&title=${item.title}`\n },\n handleViewMore() {\n if (this.productListData.moreBtnIsBlank) {\n window.open(`/products?maxCatgId=${this.productListData.displayProductList[0].maxCatgId}&title=${this.productListData.displayProductList[0].title}`, '_blank')\n } else {\n window.location.href = `/products?maxCatgId=${this.productListData.displayProductList[0].maxCatgId}&title=${this.productListData.displayProductList[0].title}`\n }\n }\n }\n}\n</script>\n\n<style scoped lang=\"scss\">\n.productList-component {\n width: 100%;\n height: 100%;\n min-height: 20px;\n background: rgb(245, 247, 249);\n display: flow-root;\n background-color: #fff;\n position: relative;\n\n .productList-component-click-disabled-mask {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n z-index: 999;\n }\n\n .productList-component-style1 {\n .productList-component-style1__container {\n max-width: 1200px;\n margin-left: auto;\n margin-right: auto;\n }\n .productList-component-title {\n margin-top: 26px;\n margin-bottom: 15px;\n font-size: 24px;\n font-weight: 500;\n line-height: 28.8px;\n text-align: center;\n color: #015fe8;\n }\n .productList-component-subTitle {\n margin-bottom: 24px;\n font-size: 14px;\n font-weight: 400;\n line-height: 1.2;\n text-align: center;\n color: #015fe8;\n }\n .productList-component-productList {\n margin-top: 20px;\n display: grid;\n grid-template-columns: repeat(2, 1fr);\n grid-gap: 32px;\n\n .productList-component-productItem {\n display: flex;\n justify-content: center;\n align-items: center;\n border: 1px solid #e4e6ea;\n background-color: #fff;\n transition: all 0.3s ease-in-out;\n &:hover {\n box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.1);\n }\n .productList-component-productImg {\n flex: 0 0 284px;\n width: 284px;\n height: 284px;\n border-right: 1px solid #e4e6ea;\n img {\n width: 100%;\n height: 100%;\n object-fit: cover;\n }\n }\n .productList-component-productInfo {\n flex: 1;\n padding: 21px 16px;\n .productList-component-productName {\n margin-bottom: 28px;\n font-size: 14px;\n font-weight: 500;\n line-height: 16.8px;\n color: #212222;\n // 超出两行省略号\n overflow: hidden;\n text-overflow: ellipsis;\n display: -webkit-box;\n -webkit-line-clamp: 2;\n -webkit-box-orient: vertical;\n }\n .productList-component-productPrice {\n // 超出两行省略号\n overflow: hidden;\n text-overflow: ellipsis;\n display: -webkit-box;\n -webkit-line-clamp: 7;\n -webkit-box-orient: vertical;\n color: #555;\n font-size: 16px;\n font-weight: 400;\n line-height: 24px;\n }\n .productList-component-productMore {\n width: fit-content;\n margin-top: 10px;\n border-radius: 30px;\n border: 1px solid #015fe8;\n padding: 6px 25px;\n text-align: center;\n color: #015fe8;\n background-color: #fff;\n font-size: 16px;\n font-weight: 400;\n line-height: 24px;\n cursor: pointer;\n }\n }\n }\n }\n .productList-component-moreBtn {\n width: fit-content;\n margin: 44px auto 44px;\n padding: 8px 35px;\n font-size: 14px;\n font-weight: 400;\n line-height: 21px;\n text-align: center;\n border-radius: 30px;\n background-color: #015fe8;\n color: #fff;\n cursor: pointer;\n transition: all 0.3s ease-in-out;\n &:hover {\n box-shadow: 2px 2px 10px 0 rgba(0,0,0,.2);\n }\n }\n }\n\n .productList-component-style2 {\n padding: 100px 0 40px;\n background: #DDE1E9;\n .productList-component-style2__container {\n max-width: 1567px;\n margin-left: auto;\n margin-right: auto;\n }\n .productList-component-title {\n margin-bottom: 25px;\n font-size: 46px;\n font-weight: 500;\n line-height: 1.2;\n text-align: center;\n color: var(--theme-content-title-color);\n }\n .productList-component-subTitle {\n margin-bottom: 50px;\n font-size: 26px;\n font-weight: 500;\n line-height: 1.2;\n text-align: center;\n color: var(--theme-content-subTitle-color);\n }\n // .productList-component-productItem {\n // height: 319px;\n // display: flex;\n // justify-content: center;\n // align-items: center;\n // background-color: #fff;\n // transition: all 0.3s ease-in-out;\n // background: #FFFFFF;\n // border-radius: 20px;\n // }\n .productList-component-productList {\n padding-bottom: 43px;\n .productList-component-productItem {\n // height: 319px;\n display: flex;\n justify-content: center;\n align-items: center;\n transition: all 0.3s ease-in-out;\n background: #FFFFFF;\n border-radius: 20px;\n .productList-component-productImg {\n flex: 0 0 50%;\n width: 50%;\n height: 100%;\n display: flex;\n justify-content: center;\n align-items: center;\n img {\n width: 100%;\n object-fit: cover;\n }\n }\n .productList-component-productInfo {\n box-sizing: border-box;\n height: 100%;\n flex: 1;\n padding: 40px 0 40px 40px;\n .productList-component-productName {\n margin-bottom: 15px;\n font-weight: 500;\n font-size: 16px;\n color: #000000;\n line-height: 1.2;\n // 超出1行省略号\n overflow: hidden;\n text-overflow: ellipsis;\n }\n .productList-component-productPrice {\n // 超出两行省略号\n overflow: hidden;\n text-overflow: ellipsis;\n display: -webkit-box;\n -webkit-line-clamp: 5;\n -webkit-box-orient: vertical;\n font-weight: 500;\n font-size: 16px;\n color: rgba(0, 0, 0, 0.5);\n line-height: 1.5;\n }\n .productList-component-productMore {\n padding: 9px 14px;\n width: fit-content;\n margin-top: 38px;\n border-radius: 6px;\n border: var(--theme-detail-btn-border);\n padding: 6px 25px;\n text-align: center;\n color: var(--theme-detail-btn-color);\n background-color: #fff;\n font-size: 16px;\n font-weight: 500;\n line-height: 1.2;\n cursor: pointer;\n transition: all 0.3s ease-in-out;\n\n &:hover {\n background-color: var(--theme-detail-btn-bg-color);\n color: #fff;\n border-color: var(--theme-detail-btn-bg-color);\n }\n }\n }\n }\n }\n .productList-component-pagination {\n margin-top: 40px;\n text-align: center;\n\n ::v-deep .swiper-pagination-bullet {\n width: 33px;\n height: 3px;\n background: #000000;\n opacity: 0.2;\n transition: all 0.3s ease-in-out;\n border-radius: 0;\n }\n\n ::v-deep .swiper-pagination-bullet-active {\n width: 54px;\n height: 3px;\n background: #000000;\n opacity: 1;\n }\n }\n .productList-component-moreBtn {\n padding: 0 21px;\n width: fit-content;\n margin: 50px auto 0;\n height: 34px;\n font-size: 14px;\n font-weight: 400;\n border-radius: 6px;\n background-color: transparent;\n color: #fff;\n cursor: pointer;\n transition: all 0.3s ease-in-out;\n border: var(--theme-more-btn-border-dark);\n color: var(--theme-more-btn-color);\n display: flex;\n align-items: center;\n justify-content: center;\n\n &:hover {\n background-color: var(--theme-more-btn-hover-bg-color);\n color: #fff;\n border-color: var(--theme-more-btn-hover-bg-color);\n }\n }\n }\n}\n\n</style>\n","import mod from \"-!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../../../../../../node_modules/thread-loader/dist/cjs.js!../../../../../../../node_modules/babel-loader/lib/index.js!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./productList.vue?vue&type=script&lang=js\"; export default mod; export * from \"-!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../../../../../../node_modules/thread-loader/dist/cjs.js!../../../../../../../node_modules/babel-loader/lib/index.js!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./productList.vue?vue&type=script&lang=js\"","import { render, staticRenderFns } from \"./productList.vue?vue&type=template&id=6799530a&scoped=true\"\nimport script from \"./productList.vue?vue&type=script&lang=js\"\nexport * from \"./productList.vue?vue&type=script&lang=js\"\nimport style0 from \"./productList.vue?vue&type=style&index=0&id=6799530a&prod&scoped=true&lang=scss\"\n\n\n/* normalize component */\nimport normalizer from \"!../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n \"6799530a\",\n null\n \n)\n\nexport default component.exports","import productList from './productList.vue'\n\nproductList.install = Vue => Vue.component(productList.name, productList)\n\nexport default productList\n","import 'element-ui/lib/theme-chalk/index.css'\nimport carousel from './package/carousel/index'\nimport companyIntroduction from './package/companyIntroduction/index'\nimport floatNav from './package/floatNav/index'\nimport footerNav from './package/footerNav/index'\nimport headerNav from './package/headerNav/index'\nimport hotProduct from './package/hotProduct/index'\nimport newsInformation from './package/newsInformation/index'\nimport productList from './package/productList/index'\n\nconst components = [\n carousel,\n companyIntroduction,\n floatNav,\n footerNav,\n headerNav,\n hotProduct,\n newsInformation,\n productList\n]\n\nconst install = function(Vue) {\n components.forEach(component => {\n Vue.component(component.name, component)\n })\n}\n\nif (typeof window !== 'undefined' && window.Vue) {\n install(window.Vue)\n}\n\nexport default {\n install,\n carousel,\n companyIntroduction,\n floatNav,\n footerNav,\n headerNav,\n hotProduct,\n newsInformation,\n productList\n}\n","import './setPublicPath'\nimport mod from '~entry'\nexport default mod\nexport * from '~entry'\n","module.exports = __webpack_public_path__ + \"img/io.5e7836dd.svg\";","module.exports = __webpack_public_path__ + \"img/tc.729aa511.svg\";","module.exports = __webpack_public_path__ + \"img/bm.7d91827f.svg\";","module.exports = __webpack_public_path__ + \"img/hm.e875a51e.svg\";","module.exports = __webpack_public_path__ + \"img/sj.d91702a1.svg\";","module.exports = __webpack_public_path__ + \"img/gi.3e92bec7.svg\";","module.exports = __webpack_public_path__ + \"img/ca.f8c2d112.svg\";","module.exports = __webpack_public_path__ + \"img/im.46d995fd.svg\";","module.exports = __webpack_public_path__ + \"img/mm.ff055a25.svg\";","module.exports = __webpack_public_path__ + \"img/bw.b3272f19.svg\";","export * from \"-!../../../../../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../../../../../../node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../../../../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../../../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../../../../../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./hotProduct.vue?vue&type=style&index=0&id=7e23e47b&prod&scoped=true&lang=scss\"","// addapted from the document.currentScript polyfill by Adam Miller\n// MIT license\n// source: https://github.com/amiller-gh/currentScript-polyfill\n\n// added support for Firefox https://bugzilla.mozilla.org/show_bug.cgi?id=1620505\n\n(function (root, factory) {\n if (typeof define === 'function' && define.amd) {\n define([], factory);\n } else if (typeof module === 'object' && module.exports) {\n module.exports = factory();\n } else {\n root.getCurrentScript = factory();\n }\n}(typeof self !== 'undefined' ? self : this, function () {\n function getCurrentScript () {\n var descriptor = Object.getOwnPropertyDescriptor(document, 'currentScript')\n // for chrome\n if (!descriptor && 'currentScript' in document && document.currentScript) {\n return document.currentScript\n }\n\n // for other browsers with native support for currentScript\n if (descriptor && descriptor.get !== getCurrentScript && document.currentScript) {\n return document.currentScript\n }\n \n // IE 8-10 support script readyState\n // IE 11+ & Firefox support stack trace\n try {\n throw new Error();\n }\n catch (err) {\n // Find the second match for the \"at\" string to get file src url from stack.\n var ieStackRegExp = /.*at [^(]*\\((.*):(.+):(.+)\\)$/ig,\n ffStackRegExp = /@([^@]*):(\\d+):(\\d+)\\s*$/ig,\n stackDetails = ieStackRegExp.exec(err.stack) || ffStackRegExp.exec(err.stack),\n scriptLocation = (stackDetails && stackDetails[1]) || false,\n line = (stackDetails && stackDetails[2]) || false,\n currentLocation = document.location.href.replace(document.location.hash, ''),\n pageSource,\n inlineScriptSourceRegExp,\n inlineScriptSource,\n scripts = document.getElementsByTagName('script'); // Live NodeList collection\n \n if (scriptLocation === currentLocation) {\n pageSource = document.documentElement.outerHTML;\n inlineScriptSourceRegExp = new RegExp('(?:[^\\\\n]+?\\\\n){0,' + (line - 2) + '}[^<]*<script>([\\\\d\\\\D]*?)<\\\\/script>[\\\\d\\\\D]*', 'i');\n inlineScriptSource = pageSource.replace(inlineScriptSourceRegExp, '$1').trim();\n }\n \n for (var i = 0; i < scripts.length; i++) {\n // If ready state is interactive, return the script tag\n if (scripts[i].readyState === 'interactive') {\n return scripts[i];\n }\n \n // If src matches, return the script tag\n if (scripts[i].src === scriptLocation) {\n return scripts[i];\n }\n \n // If inline source matches, return the script tag\n if (\n scriptLocation === currentLocation &&\n scripts[i].innerHTML &&\n scripts[i].innerHTML.trim() === inlineScriptSource\n ) {\n return scripts[i];\n }\n }\n \n // If no match, return null\n return null;\n }\n };\n\n return getCurrentScript\n}));\n","module.exports = __webpack_public_path__ + \"img/gb.c39480d5.svg\";","// extracted by mini-css-extract-plugin","module.exports = __webpack_public_path__ + \"img/de.a1435756.svg\";","module.exports = __webpack_public_path__ + \"img/nc.55df0a2e.svg\";","module.exports = __webpack_public_path__ + \"img/vg.ccea90f1.svg\";","module.exports = __webpack_public_path__ + \"img/ge.a48e9919.svg\";","module.exports = __webpack_public_path__ + \"img/id.a8161cf2.svg\";","module.exports = __webpack_public_path__ + \"img/tv.d1412347.svg\";","module.exports = __webpack_public_path__ + \"img/lk.23e5cb5f.svg\";","export * from \"-!../../../../../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../../../../../../node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../../../../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../../../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../../../../../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./carousel.vue?vue&type=style&index=0&id=4a5ee43f&prod&scoped=true&lang=scss\"","module.exports = __webpack_public_path__ + \"img/jo.9c2e45cc.svg\";","module.exports = __webpack_public_path__ + \"img/ps.7fb44a73.svg\";","module.exports = __webpack_public_path__ + \"img/gf.55df0a2e.svg\";","module.exports = __webpack_public_path__ + \"img/gp.55df0a2e.svg\";","module.exports = __webpack_public_path__ + \"img/sy.02c1d5b2.svg\";","module.exports = __webpack_public_path__ + \"img/lc.25152dc3.svg\";","module.exports = __webpack_public_path__ + \"img/va.6182350f.svg\";","module.exports = __webpack_public_path__ + \"img/nz.30299530.svg\";","module.exports = __webpack_public_path__ + \"img/gn.23ee49e7.svg\";","module.exports = __webpack_public_path__ + \"img/nu.971e5c2f.svg\";","module.exports = __webpack_public_path__ + \"img/medal-icon.a8cde317.png\";","module.exports = __webpack_public_path__ + \"img/ly.8952f9a4.svg\";","module.exports = __webpack_public_path__ + \"img/sx.8db7b1db.svg\";","module.exports = __webpack_public_path__ + \"img/as.caaf405e.svg\";","module.exports = __webpack_public_path__ + \"img/tf.d9c9ef13.svg\";","module.exports = __webpack_public_path__ + \"img/co.5580c56f.svg\";","module.exports = __webpack_public_path__ + \"img/gb-nir.c39480d5.svg\";","module.exports = __webpack_public_path__ + \"img/aq.65a5c99b.svg\";","// extracted by mini-css-extract-plugin","module.exports = __webpack_public_path__ + \"img/hn.515bf7aa.svg\";","module.exports = __webpack_public_path__ + \"img/vc.bd0bfc7e.svg\";","module.exports = __webpack_public_path__ + \"img/tg.c270b112.svg\";","module.exports = __webpack_public_path__ + \"img/si.9a72ead6.svg\";","module.exports = __webpack_public_path__ + \"img/r-icon.2584a2ec.png\";","module.exports = __webpack_public_path__ + \"img/pl.e2afe0f6.svg\";","module.exports = __webpack_public_path__ + \"img/ro.a9e8cdfe.svg\";","module.exports = __webpack_public_path__ + \"img/pm.55df0a2e.svg\";","module.exports = __webpack_public_path__ + \"img/kz.0ded3b63.svg\";","module.exports = __webpack_public_path__ + \"img/mx.216d2ed6.svg\";","module.exports = __webpack_public_path__ + \"img/e-mail.f952948e.png\";","// extracted by mini-css-extract-plugin","module.exports = __webpack_public_path__ + \"img/am.6ab4c4d0.svg\";","export * from \"-!../../../../../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../../../../../../node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../../../../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../../../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../../../../../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./companyIntroduction.vue?vue&type=style&index=0&id=a0dd5942&prod&scoped=true&lang=scss\"","module.exports = __webpack_public_path__ + \"img/gg.d38e76e4.svg\";","module.exports = __webpack_public_path__ + \"img/ss.562eaa76.svg\";","module.exports = __webpack_public_path__ + \"img/news-center-bg.dafd5a5c.png\";","module.exports = __webpack_public_path__ + \"img/ms.672d771e.svg\";","export * from \"-!../../../../../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../../../../../../node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../../../../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../../../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../../../../../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./floatNav.vue?vue&type=style&index=0&id=676ee15d&prod&scoped=true&lang=scss\"","module.exports = __webpack_public_path__ + \"img/ma.caaf228d.svg\";","module.exports = __webpack_public_path__ + \"img/ag.7a5c6f51.svg\";","module.exports = __webpack_public_path__ + \"img/jp.66dacdf5.svg\";","module.exports = __webpack_public_path__ + \"img/sm.bdd98917.svg\";","module.exports = __webpack_public_path__ + \"img/vu.0c83fc4f.svg\";","module.exports = __webpack_public_path__ + \"img/mh.1ce06f01.svg\";","module.exports = __webpack_public_path__ + \"img/mr.4ae40103.svg\";","module.exports = __webpack_public_path__ + \"img/mf.55df0a2e.svg\";","module.exports = require(\"vue\");","module.exports = __webpack_public_path__ + \"img/na.347a6e25.svg\";","module.exports = __webpack_public_path__ + \"img/om.299d7167.svg\";","module.exports = __webpack_public_path__ + \"img/ie.8f8ca447.svg\";","module.exports = __webpack_public_path__ + \"img/je.1478f6ec.svg\";","module.exports = __webpack_public_path__ + \"img/cu.8bd5be6b.svg\";","module.exports = __webpack_public_path__ + \"img/kr.94941e04.svg\";","module.exports = __webpack_public_path__ + \"img/pt.352ff4b0.svg\";","module.exports = __webpack_public_path__ + \"img/gw.65b1fcad.svg\";","// extracted by mini-css-extract-plugin","module.exports = __webpack_public_path__ + \"img/ar.51c7aeb1.svg\";","module.exports = __webpack_public_path__ + \"img/th.3530959a.svg\";","module.exports = __webpack_public_path__ + \"img/is.75a62d93.svg\";","module.exports = __webpack_public_path__ + \"img/ua.8a287858.svg\";","module.exports = __webpack_public_path__ + \"img/cl.4cbf573b.svg\";","module.exports = __webpack_public_path__ + \"img/es.c3853709.svg\";","module.exports = __webpack_public_path__ + \"img/lb.2b985ffb.svg\";","module.exports = __webpack_public_path__ + \"img/ai.96e24e9e.svg\";","module.exports = __webpack_public_path__ + \"img/sh.c39480d5.svg\";","module.exports = __webpack_public_path__ + \"img/pg.8c906c8c.svg\";","module.exports = __webpack_public_path__ + \"img/iq.66216bd0.svg\";","module.exports = __webpack_public_path__ + \"img/tt.8ab31263.svg\";","module.exports = __webpack_public_path__ + \"img/ci.6bf90550.svg\";","module.exports = __webpack_public_path__ + \"img/um.eadfb4ed.svg\";","module.exports = __webpack_public_path__ + \"img/gb-sct.dd6733a9.svg\";","module.exports = __webpack_public_path__ + \"img/sa.943cf626.svg\";","module.exports = __webpack_public_path__ + \"img/tj.ab3bac64.svg\";","module.exports = __webpack_public_path__ + \"img/aw.ab68008c.svg\";","module.exports = __webpack_public_path__ + \"img/lu.97e411b3.svg\";","module.exports = __webpack_public_path__ + \"img/nf.7a5c5828.svg\";","module.exports = __webpack_public_path__ + \"img/ug.ccaa7a85.svg\";","export * from \"-!../../../../../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../../../../../../node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../../../../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../../../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../../../../../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./changeLanguageDialog.vue?vue&type=style&index=0&id=5dee3d3d&prod&scoped=true&lang=scss\"","module.exports = __webpack_public_path__ + \"img/be.2f762fbb.svg\";","module.exports = __webpack_public_path__ + \"img/tz.ee919c0a.svg\";","module.exports = __webpack_public_path__ + \"img/nl.5f6ef944.svg\";","export * from \"-!../../../../../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../../../../../../node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../../../../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../../../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../../../../../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./headerNav.vue?vue&type=style&index=0&id=70d07b09&prod&scoped=true&lang=scss\"","module.exports = __webpack_public_path__ + \"img/st.b435df97.svg\";","// extracted by mini-css-extract-plugin","module.exports = __webpack_public_path__ + \"img/gm.2583d210.svg\";","module.exports = __webpack_public_path__ + \"img/fi.747657c3.svg\";","module.exports = __webpack_public_path__ + \"img/ls.2183506a.svg\";","module.exports = __webpack_public_path__ + \"img/jm.4daaf707.svg\";","module.exports = __webpack_public_path__ + \"img/diamond-icon.a74d4441.png\";","module.exports = __webpack_public_path__ + \"img/bo.24408e4f.svg\";","module.exports = __webpack_public_path__ + \"img/fm.5901edbf.svg\";","module.exports = __webpack_public_path__ + \"img/mo.46b51100.svg\";","module.exports = __webpack_public_path__ + \"img/ki.1e425fd5.svg\";","module.exports = __webpack_public_path__ + \"img/us.eadfb4ed.svg\";","module.exports = __webpack_public_path__ + \"img/yt.55df0a2e.svg\";","module.exports = __webpack_public_path__ + \"img/sr.cbccf817.svg\";","module.exports = \"data:image/png;base64,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\"","module.exports = __webpack_public_path__ + \"img/ru.182478bc.svg\";","module.exports = __webpack_public_path__ + \"img/fo.d5facc7a.svg\";","module.exports = __webpack_public_path__ + \"img/by.0a7149c2.svg\";","module.exports = __webpack_public_path__ + \"img/my.537daaa3.svg\";","module.exports = __webpack_public_path__ + \"img/gb-wls.adce5953.svg\";","module.exports = __webpack_public_path__ + \"img/rw.bf080503.svg\";","module.exports = __webpack_public_path__ + \"img/za.b2f370d4.svg\";","module.exports = __webpack_public_path__ + \"img/bg.1756f2d9.svg\";","module.exports = __webpack_public_path__ + \"img/cg.75c9979a.svg\";","module.exports = __webpack_public_path__ + \"img/bh.0dc78a04.svg\";","module.exports = __webpack_public_path__ + \"img/pa.931bfe6b.svg\";","module.exports = __webpack_public_path__ + \"img/tr.cf31c9d6.svg\";","export * from \"-!../../../../../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../../../../../../node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../../../../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../../../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../../../../../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./productList.vue?vue&type=style&index=0&id=6799530a&prod&scoped=true&lang=scss\"","export * from \"-!../../../../../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../../../../../../node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../../../../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../../../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../../../../../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./footerNav.vue?vue&type=style&index=0&id=6f2164cf&prod&scoped=true&lang=scss\"","module.exports = __webpack_public_path__ + \"img/sc.c689a310.svg\";","module.exports = __webpack_public_path__ + \"img/diamond-icon2.bcb24d08.png\";","module.exports = __webpack_public_path__ + \"img/left-arrow.37f00f63.svg\";","module.exports = __webpack_public_path__ + \"img/mk.2ac054eb.svg\";","module.exports = __webpack_public_path__ + \"img/tk.e5fa89ea.svg\";","module.exports = __webpack_public_path__ + \"img/cd.c6cc7e0f.svg\";","module.exports = __webpack_public_path__ + \"img/np.7b78f86d.svg\";","module.exports = __webpack_public_path__ + \"img/kg.b835c7fc.svg\";","module.exports = __webpack_public_path__ + \"img/ec.d5a3e215.svg\";","module.exports = __webpack_public_path__ + \"img/xk.4f3781ca.svg\";","module.exports = __webpack_public_path__ + \"img/uy.6068a814.svg\";","export * from \"-!../../../../../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--8-oneOf-1-0!../../../../../../../node_modules/css-loader/dist/cjs.js??ref--8-oneOf-1-1!../../../../../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../../../../node_modules/postcss-loader/src/index.js??ref--8-oneOf-1-2!../../../../../../../node_modules/sass-loader/dist/cjs.js??ref--8-oneOf-1-3!../../../../../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./newsInformation.vue?vue&type=style&index=0&id=75b8d9ae&prod&scoped=true&lang=scss\"","module.exports = __webpack_public_path__ + \"img/eg.9498b313.svg\";","module.exports = __webpack_public_path__ + \"img/hk.b953ca2c.svg\";","module.exports = __webpack_public_path__ + \"img/vn.44c0954e.svg\";","module.exports = __webpack_public_path__ + \"img/company-intro-bg.e2568bd2.png\";","module.exports = __webpack_public_path__ + \"img/mp.91055a88.svg\";","module.exports = __webpack_public_path__ + \"img/qa.b39ab9d6.svg\";","module.exports = __webpack_public_path__ + \"img/ch.72a82891.svg\";","module.exports = __webpack_public_path__ + \"img/cf.97629cb9.svg\";","module.exports = __webpack_public_path__ + \"img/no.d91702a1.svg\";","module.exports = __webpack_public_path__ + \"img/mg.3bb33f8d.svg\";","module.exports = __webpack_public_path__ + \"img/mw.b19033b2.svg\";","// extracted by mini-css-extract-plugin","module.exports = __webpack_public_path__ + \"img/cm.a76c9da2.svg\";","module.exports = __webpack_public_path__ + \"img/ni.c1e4af11.svg\";","module.exports = __webpack_public_path__ + \"img/sb.2c776db7.svg\";","module.exports = __webpack_public_path__ + \"img/gt.ca224d7c.svg\";","module.exports = __webpack_public_path__ + \"img/ph.62b10c25.svg\";","module.exports = __webpack_public_path__ + \"img/project-icon.0b452510.png\";","module.exports = __webpack_public_path__ + \"img/mt.23c648aa.svg\";","module.exports = __webpack_public_path__ + \"img/ck.420c555e.svg\";","module.exports = __webpack_public_path__ + \"img/kh.820b80bf.svg\";","module.exports = __webpack_public_path__ + \"img/cx.db137cac.svg\";","module.exports = __webpack_public_path__ + \"img/bi.515d4c82.svg\";","module.exports = __webpack_public_path__ + \"img/cn.c40591ea.svg\";","module.exports = __webpack_public_path__ + \"img/mv.4cca1ac7.svg\";","module.exports = __webpack_public_path__ + \"img/uz.b20f1adb.svg\";","module.exports = __webpack_public_path__ + \"img/se.9e47ea03.svg\";","module.exports = __webpack_public_path__ + \"img/al.bfd0a0ce.svg\";","module.exports = __webpack_public_path__ + \"img/cy.ce826661.svg\";","module.exports = __webpack_public_path__ + \"img/gb-eng.bb489b94.svg\";","module.exports = __webpack_public_path__ + \"img/ht.b8bdde5a.svg\";","module.exports = __webpack_public_path__ + \"img/la.ac7e695a.svg\";","module.exports = \"data:image/png;base64,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\"","module.exports = __webpack_public_path__ + \"img/at.8ba54155.svg\";","module.exports = __webpack_public_path__ + \"img/pw.c5a4b0fe.svg\";","module.exports = __webpack_public_path__ + \"img/cr.74dd61b6.svg\";","module.exports = __webpack_public_path__ + \"img/dz.c3635144.svg\";","module.exports = __webpack_public_path__ + \"img/gy.9c2891ac.svg\";","!function(e,t){\"object\"==typeof exports&&\"object\"==typeof module?module.exports=t(require(\"swiper/dist/js/swiper.js\")):\"function\"==typeof define&&define.amd?define(\"VueAwesomeSwiper\",[\"swiper\"],t):\"object\"==typeof exports?exports.VueAwesomeSwiper=t(require(\"swiper/dist/js/swiper.js\")):e.VueAwesomeSwiper=t(e.Swiper)}(this,function(e){return function(e){function t(i){if(n[i])return n[i].exports;var s=n[i]={i:i,l:!1,exports:{}};return e[i].call(s.exports,s,s.exports,t),s.l=!0,s.exports}var n={};return t.m=e,t.c=n,t.i=function(e){return e},t.d=function(e,n,i){t.o(e,n)||Object.defineProperty(e,n,{configurable:!1,enumerable:!0,get:i})},t.n=function(e){var n=e&&e.__esModule?function(){return e.default}:function(){return e};return t.d(n,\"a\",n),n},t.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},t.p=\"/\",t(t.s=4)}([function(t,n){t.exports=e},function(e,t){e.exports=function(e,t,n,i,s,r){var o,a=e=e||{},u=typeof e.default;\"object\"!==u&&\"function\"!==u||(o=e,a=e.default);var p=\"function\"==typeof a?a.options:a;t&&(p.render=t.render,p.staticRenderFns=t.staticRenderFns,p._compiled=!0),n&&(p.functional=!0),s&&(p._scopeId=s);var l;if(r?(l=function(e){e=e||this.$vnode&&this.$vnode.ssrContext||this.parent&&this.parent.$vnode&&this.parent.$vnode.ssrContext,e||\"undefined\"==typeof __VUE_SSR_CONTEXT__||(e=__VUE_SSR_CONTEXT__),i&&i.call(this,e),e&&e._registeredComponents&&e._registeredComponents.add(r)},p._ssrRegister=l):i&&(l=i),l){var c=p.functional,d=c?p.render:p.beforeCreate;c?(p._injectStyles=l,p.render=function(e,t){return l.call(t),d(e,t)}):p.beforeCreate=d?[].concat(d,l):[l]}return{esModule:o,exports:a,options:p}}},function(e,t,n){\"use strict\";Object.defineProperty(t,\"__esModule\",{value:!0});var i=n(5),s=n.n(i),r=n(8),o=n(1),a=o(s.a,r.a,!1,null,null,null);t.default=a.exports},function(e,t,n){\"use strict\";Object.defineProperty(t,\"__esModule\",{value:!0});var i=n(6),s=n.n(i),r=n(7),o=n(1),a=o(s.a,r.a,!1,null,null,null);t.default=a.exports},function(e,t,n){\"use strict\";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,\"__esModule\",{value:!0}),t.install=t.swiperSlide=t.swiper=t.Swiper=void 0;var s=n(0),r=i(s),o=n(2),a=i(o),u=n(3),p=i(u),l=window.Swiper||r.default,c=p.default,d=a.default,f=function(e,t){t&&(p.default.props.globalOptions.default=function(){return t}),e.component(p.default.name,p.default),e.component(a.default.name,a.default)},h={Swiper:l,swiper:c,swiperSlide:d,install:f};t.default=h,t.Swiper=l,t.swiper=c,t.swiperSlide=d,t.install=f},function(e,t,n){\"use strict\";Object.defineProperty(t,\"__esModule\",{value:!0}),t.default={name:\"swiper-slide\",data:function(){return{slideClass:\"swiper-slide\"}},ready:function(){this.update()},mounted:function(){this.update(),this.$parent&&this.$parent.options&&this.$parent.options.slideClass&&(this.slideClass=this.$parent.options.slideClass)},updated:function(){this.update()},attached:function(){this.update()},methods:{update:function(){this.$parent&&this.$parent.swiper&&this.$parent.update()}}}},function(e,t,n){\"use strict\";Object.defineProperty(t,\"__esModule\",{value:!0});var i=n(0),s=function(e){return e&&e.__esModule?e:{default:e}}(i),r=window.Swiper||s.default;\"function\"!=typeof Object.assign&&Object.defineProperty(Object,\"assign\",{value:function(e,t){if(null==e)throw new TypeError(\"Cannot convert undefined or null to object\");for(var n=Object(e),i=1;i<arguments.length;i++){var s=arguments[i];if(null!=s)for(var r in s)Object.prototype.hasOwnProperty.call(s,r)&&(n[r]=s[r])}return n},writable:!0,configurable:!0});var o=[\"beforeDestroy\",\"slideChange\",\"slideChangeTransitionStart\",\"slideChangeTransitionEnd\",\"slideNextTransitionStart\",\"slideNextTransitionEnd\",\"slidePrevTransitionStart\",\"slidePrevTransitionEnd\",\"transitionStart\",\"transitionEnd\",\"touchStart\",\"touchMove\",\"touchMoveOpposite\",\"sliderMove\",\"touchEnd\",\"click\",\"tap\",\"doubleTap\",\"imagesReady\",\"progress\",\"reachBeginning\",\"reachEnd\",\"fromEdge\",\"setTranslate\",\"setTransition\",\"resize\"];t.default={name:\"swiper\",props:{options:{type:Object,default:function(){return{}}},globalOptions:{type:Object,required:!1,default:function(){return{}}}},data:function(){return{swiper:null,classes:{wrapperClass:\"swiper-wrapper\"}}},ready:function(){this.swiper||this.mountInstance()},mounted:function(){if(!this.swiper){var e=!1;for(var t in this.classes)this.classes.hasOwnProperty(t)&&this.options[t]&&(e=!0,this.classes[t]=this.options[t]);e?this.$nextTick(this.mountInstance):this.mountInstance()}},activated:function(){this.update()},updated:function(){this.update()},beforeDestroy:function(){this.$nextTick(function(){this.swiper&&(this.swiper.destroy&&this.swiper.destroy(),delete this.swiper)})},methods:{update:function(){this.swiper&&(this.swiper.update&&this.swiper.update(),this.swiper.navigation&&this.swiper.navigation.update(),this.swiper.pagination&&this.swiper.pagination.render(),this.swiper.pagination&&this.swiper.pagination.update())},mountInstance:function(){var e=Object.assign({},this.globalOptions,this.options);this.swiper=new r(this.$el,e),this.bindEvents(),this.$emit(\"ready\",this.swiper)},bindEvents:function(){var e=this,t=this;o.forEach(function(n){e.swiper.on(n,function(){t.$emit.apply(t,[n].concat(Array.prototype.slice.call(arguments))),t.$emit.apply(t,[n.replace(/([A-Z])/g,\"-$1\").toLowerCase()].concat(Array.prototype.slice.call(arguments)))})})}}}},function(e,t,n){\"use strict\";var i=function(){var e=this,t=e.$createElement,n=e._self._c||t;return n(\"div\",{staticClass:\"swiper-container\"},[e._t(\"parallax-bg\"),e._v(\" \"),n(\"div\",{class:e.classes.wrapperClass},[e._t(\"default\")],2),e._v(\" \"),e._t(\"pagination\"),e._v(\" \"),e._t(\"button-prev\"),e._v(\" \"),e._t(\"button-next\"),e._v(\" \"),e._t(\"scrollbar\")],2)},s=[],r={render:i,staticRenderFns:s};t.a=r},function(e,t,n){\"use strict\";var i=function(){var e=this,t=e.$createElement;return(e._self._c||t)(\"div\",{class:e.slideClass},[e._t(\"default\")],2)},s=[],r={render:i,staticRenderFns:s};t.a=r}])});","module.exports = __webpack_public_path__ + \"img/bq.5f6ef944.svg\";","module.exports = __webpack_public_path__ + \"img/pf.cd51dc27.svg\";","// extracted by mini-css-extract-plugin","module.exports = __webpack_public_path__ + \"img/cz.65042957.svg\";","module.exports = __webpack_public_path__ + \"img/bz.b76fcd7d.svg\";","module.exports = __webpack_public_path__ + \"img/bd.05e8826e.svg\";","module.exports = __webpack_public_path__ + \"img/sn.42cfbd39.svg\";","module.exports = __webpack_public_path__ + \"img/ga.de003fa2.svg\";","module.exports = __webpack_public_path__ + \"img/md.6b8abcb3.svg\";","module.exports = __webpack_public_path__ + \"img/people-icon.82edf9a7.png\";","// extracted by mini-css-extract-plugin","module.exports = __webpack_public_path__ + \"img/tw.74b88030.svg\";","module.exports = __webpack_public_path__ + \"img/wf.9cbf71ee.svg\";","module.exports = __webpack_public_path__ + \"img/pr.44606b44.svg\";","// extracted by mini-css-extract-plugin","module.exports = __webpack_public_path__ + \"img/pn.a7cc83d2.svg\";","module.exports = __webpack_public_path__ + \"img/eu.93555e17.svg\";","module.exports = __webpack_public_path__ + \"img/ax.d78ede0e.svg\";"],"sourceRoot":""}