cy-element-ui 1.0.3 → 1.0.5

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 (416) hide show
  1. package/README.md +163 -59
  2. package/lib/alert.js +211 -203
  3. package/lib/aside.js +29 -29
  4. package/lib/autocomplete.js +4615 -483
  5. package/lib/avatar.js +152 -126
  6. package/lib/backtop.js +117 -125
  7. package/lib/badge.js +128 -134
  8. package/lib/breadcrumb-item.js +146 -122
  9. package/lib/breadcrumb.js +97 -96
  10. package/lib/button-group.js +68 -65
  11. package/lib/button.js +67 -87
  12. package/lib/calendar.js +2475 -603
  13. package/lib/card.js +101 -100
  14. package/lib/carousel-item.js +854 -210
  15. package/lib/carousel.js +575 -408
  16. package/lib/cascader-panel.js +3546 -1153
  17. package/lib/cascader.js +7376 -970
  18. package/lib/checkbox-button.js +337 -290
  19. package/lib/checkbox-group.js +176 -105
  20. package/lib/checkbox.js +240 -220
  21. package/lib/col.js +113 -68
  22. package/lib/collapse-item.js +1228 -225
  23. package/lib/collapse.js +163 -123
  24. package/lib/color-picker.js +5223 -1251
  25. package/lib/container.js +98 -88
  26. package/lib/date-picker.js +8396 -3945
  27. package/lib/descriptions-item.js +53 -32
  28. package/lib/descriptions.js +697 -334
  29. package/lib/dialog.js +1725 -247
  30. package/lib/directives/mousewheel.js +14 -20
  31. package/lib/directives/repeat-click.js +27 -30
  32. package/lib/divider.js +38 -45
  33. package/lib/drawer.js +1032 -238
  34. package/lib/dropdown-item.js +159 -111
  35. package/lib/dropdown-menu.js +2445 -117
  36. package/lib/dropdown.js +1675 -366
  37. package/lib/element-ui.common.js +49110 -39985
  38. package/lib/empty.js +1084 -203
  39. package/lib/fileUpload.js +3900 -0
  40. package/lib/footer.js +29 -29
  41. package/lib/form-item.js +1236 -467
  42. package/lib/form.js +326 -258
  43. package/lib/header.js +80 -80
  44. package/lib/icon.js +71 -68
  45. package/lib/image.js +2389 -743
  46. package/lib/index.js +1 -1
  47. package/lib/infinite-scroll.js +814 -150
  48. package/lib/input-number.js +2181 -444
  49. package/lib/input.js +1197 -517
  50. package/lib/link.js +117 -135
  51. package/lib/loading.js +1130 -363
  52. package/lib/locale/format.js +38 -49
  53. package/lib/locale/index.js +38 -52
  54. package/lib/locale/lang/af-ZA.js +130 -123
  55. package/lib/locale/lang/ar.js +123 -122
  56. package/lib/locale/lang/az.js +122 -121
  57. package/lib/locale/lang/bg.js +133 -123
  58. package/lib/locale/lang/bn.js +121 -121
  59. package/lib/locale/lang/ca.js +123 -122
  60. package/lib/locale/lang/cs-CZ.js +127 -125
  61. package/lib/locale/lang/da.js +124 -122
  62. package/lib/locale/lang/de.js +126 -124
  63. package/lib/locale/lang/ee.js +125 -123
  64. package/lib/locale/lang/el.js +125 -123
  65. package/lib/locale/lang/en.js +127 -123
  66. package/lib/locale/lang/eo.js +125 -123
  67. package/lib/locale/lang/es.js +123 -122
  68. package/lib/locale/lang/eu.js +128 -123
  69. package/lib/locale/lang/fa.js +125 -123
  70. package/lib/locale/lang/fi.js +125 -123
  71. package/lib/locale/lang/fr.js +125 -122
  72. package/lib/locale/lang/he.js +130 -123
  73. package/lib/locale/lang/hr.js +128 -123
  74. package/lib/locale/lang/hu.js +124 -122
  75. package/lib/locale/lang/hy-AM.js +125 -123
  76. package/lib/locale/lang/id.js +124 -123
  77. package/lib/locale/lang/is.js +124 -123
  78. package/lib/locale/lang/it.js +123 -122
  79. package/lib/locale/lang/ja.js +125 -123
  80. package/lib/locale/lang/kg.js +125 -123
  81. package/lib/locale/lang/km.js +124 -123
  82. package/lib/locale/lang/ko.js +125 -123
  83. package/lib/locale/lang/ku.js +125 -123
  84. package/lib/locale/lang/kz.js +125 -123
  85. package/lib/locale/lang/lo-LA.js +121 -121
  86. package/lib/locale/lang/lt.js +125 -123
  87. package/lib/locale/lang/lv.js +125 -123
  88. package/lib/locale/lang/mn.js +125 -123
  89. package/lib/locale/lang/ms.js +123 -122
  90. package/lib/locale/lang/nb-NO.js +123 -122
  91. package/lib/locale/lang/nl.js +125 -123
  92. package/lib/locale/lang/pl.js +125 -123
  93. package/lib/locale/lang/pt-br.js +124 -123
  94. package/lib/locale/lang/pt.js +133 -123
  95. package/lib/locale/lang/ro.js +125 -123
  96. package/lib/locale/lang/ru-RU.js +124 -123
  97. package/lib/locale/lang/si.js +127 -123
  98. package/lib/locale/lang/sk.js +126 -125
  99. package/lib/locale/lang/sl.js +125 -123
  100. package/lib/locale/lang/sr-Latn.js +124 -123
  101. package/lib/locale/lang/sr.js +128 -123
  102. package/lib/locale/lang/sv-SE.js +128 -123
  103. package/lib/locale/lang/sw.js +127 -123
  104. package/lib/locale/lang/ta.js +130 -122
  105. package/lib/locale/lang/th.js +127 -123
  106. package/lib/locale/lang/tk.js +129 -123
  107. package/lib/locale/lang/tr-TR.js +125 -123
  108. package/lib/locale/lang/ua.js +124 -123
  109. package/lib/locale/lang/ug-CN.js +124 -123
  110. package/lib/locale/lang/uz-UZ.js +124 -123
  111. package/lib/locale/lang/vi.js +124 -123
  112. package/lib/locale/lang/zh-CN.js +124 -123
  113. package/lib/locale/lang/zh-TW.js +128 -123
  114. package/lib/main.js +23 -21
  115. package/lib/menu-item-group.js +105 -111
  116. package/lib/menu-item.js +3558 -253
  117. package/lib/menu.js +1680 -528
  118. package/lib/message-box.js +3427 -684
  119. package/lib/message.js +1677 -229
  120. package/lib/mixins/emitter.js +28 -30
  121. package/lib/mixins/focus.js +10 -11
  122. package/lib/mixins/locale.js +12 -14
  123. package/lib/mixins/migrating.js +38 -45
  124. package/lib/notification.js +1707 -269
  125. package/lib/option-group.js +190 -139
  126. package/lib/option.js +949 -196
  127. package/lib/page-header.js +964 -42
  128. package/lib/pagination.js +6947 -641
  129. package/lib/popconfirm.js +3951 -223
  130. package/lib/popover.js +3247 -369
  131. package/lib/progress.js +254 -244
  132. package/lib/radio-button.js +259 -226
  133. package/lib/radio-group.js +249 -186
  134. package/lib/radio.js +263 -253
  135. package/lib/rate.js +1399 -420
  136. package/lib/result.js +183 -227
  137. package/lib/row.js +58 -41
  138. package/lib/scrollbar.js +1331 -278
  139. package/lib/select.js +5816 -1428
  140. package/lib/skeleton-item.js +133 -145
  141. package/lib/skeleton.js +82 -91
  142. package/lib/slider.js +5157 -702
  143. package/lib/spinner.js +113 -101
  144. package/lib/statistic.js +10205 -254
  145. package/lib/step.js +274 -311
  146. package/lib/steps.js +854 -117
  147. package/lib/subTitle.js +292 -0
  148. package/lib/submenu.js +2867 -429
  149. package/lib/switch.js +1051 -291
  150. package/lib/tab-pane.js +125 -135
  151. package/lib/tabDialog.js +2658 -0
  152. package/lib/table-column.js +1975 -751
  153. package/lib/table.js +8019 -3979
  154. package/lib/tabs.js +1455 -605
  155. package/lib/tag.js +73 -68
  156. package/lib/theme-chalk/src/index.scss +3 -0
  157. package/lib/time-picker.js +6821 -1944
  158. package/lib/time-select.js +6297 -1186
  159. package/lib/timeline-item.js +43 -84
  160. package/lib/timeline.js +43 -39
  161. package/lib/tooltip.js +3185 -287
  162. package/lib/transfer.js +2943 -625
  163. package/lib/transitions/collapse-transition.js +69 -87
  164. package/lib/tree.js +3312 -1791
  165. package/lib/treeSelect.js +4436 -0
  166. package/lib/umd/locale/af-ZA.js +145 -138
  167. package/lib/umd/locale/ar.js +138 -137
  168. package/lib/umd/locale/az.js +139 -137
  169. package/lib/umd/locale/bg.js +148 -138
  170. package/lib/umd/locale/bn.js +138 -137
  171. package/lib/umd/locale/ca.js +138 -137
  172. package/lib/umd/locale/cs-CZ.js +142 -140
  173. package/lib/umd/locale/da.js +139 -137
  174. package/lib/umd/locale/de.js +141 -139
  175. package/lib/umd/locale/ee.js +140 -138
  176. package/lib/umd/locale/el.js +140 -138
  177. package/lib/umd/locale/en.js +142 -138
  178. package/lib/umd/locale/eo.js +140 -138
  179. package/lib/umd/locale/es.js +138 -137
  180. package/lib/umd/locale/eu.js +143 -138
  181. package/lib/umd/locale/fa.js +140 -138
  182. package/lib/umd/locale/fi.js +140 -138
  183. package/lib/umd/locale/fr.js +140 -137
  184. package/lib/umd/locale/he.js +145 -138
  185. package/lib/umd/locale/hr.js +143 -138
  186. package/lib/umd/locale/hu.js +139 -137
  187. package/lib/umd/locale/hy-AM.js +140 -138
  188. package/lib/umd/locale/id.js +139 -138
  189. package/lib/umd/locale/is.js +139 -138
  190. package/lib/umd/locale/it.js +138 -137
  191. package/lib/umd/locale/ja.js +140 -138
  192. package/lib/umd/locale/kg.js +140 -138
  193. package/lib/umd/locale/km.js +139 -138
  194. package/lib/umd/locale/ko.js +140 -138
  195. package/lib/umd/locale/ku.js +140 -138
  196. package/lib/umd/locale/kz.js +140 -138
  197. package/lib/umd/locale/lo-LA.js +138 -137
  198. package/lib/umd/locale/lt.js +140 -138
  199. package/lib/umd/locale/lv.js +140 -138
  200. package/lib/umd/locale/mn.js +140 -138
  201. package/lib/umd/locale/ms.js +138 -137
  202. package/lib/umd/locale/nb-NO.js +138 -137
  203. package/lib/umd/locale/nl.js +140 -138
  204. package/lib/umd/locale/pl.js +140 -138
  205. package/lib/umd/locale/pt-br.js +139 -138
  206. package/lib/umd/locale/pt.js +148 -138
  207. package/lib/umd/locale/ro.js +140 -138
  208. package/lib/umd/locale/ru-RU.js +139 -138
  209. package/lib/umd/locale/si.js +142 -138
  210. package/lib/umd/locale/sk.js +141 -140
  211. package/lib/umd/locale/sl.js +140 -138
  212. package/lib/umd/locale/sr-Latn.js +139 -138
  213. package/lib/umd/locale/sr.js +143 -138
  214. package/lib/umd/locale/sv-SE.js +143 -138
  215. package/lib/umd/locale/sw.js +142 -138
  216. package/lib/umd/locale/ta.js +145 -137
  217. package/lib/umd/locale/th.js +142 -138
  218. package/lib/umd/locale/tk.js +144 -138
  219. package/lib/umd/locale/tr-TR.js +140 -138
  220. package/lib/umd/locale/ua.js +139 -138
  221. package/lib/umd/locale/ug-CN.js +139 -138
  222. package/lib/umd/locale/uz-UZ.js +139 -138
  223. package/lib/umd/locale/vi.js +139 -138
  224. package/lib/umd/locale/zh-CN.js +139 -138
  225. package/lib/umd/locale/zh-TW.js +143 -138
  226. package/lib/upload.js +2377 -987
  227. package/lib/utils/after-leave.js +36 -33
  228. package/lib/utils/aria-dialog.js +55 -73
  229. package/lib/utils/aria-utils.js +67 -76
  230. package/lib/utils/clickoutside.js +52 -60
  231. package/lib/utils/date-util.js +198 -241
  232. package/lib/utils/date.js +6 -368
  233. package/lib/utils/date_source.js +349 -0
  234. package/lib/utils/dom.js +167 -183
  235. package/lib/utils/lodash.js +13 -9421
  236. package/lib/utils/lodash_source.js +9421 -0
  237. package/lib/utils/menu/aria-menubar.js +13 -18
  238. package/lib/utils/menu/aria-menuitem.js +43 -54
  239. package/lib/utils/menu/aria-submenu.js +50 -59
  240. package/lib/utils/merge.js +15 -17
  241. package/lib/utils/popper.js +1141 -1170
  242. package/lib/utils/popup/index.js +186 -230
  243. package/lib/utils/popup/popup-manager.js +159 -191
  244. package/lib/utils/resize-event.js +29 -44
  245. package/lib/utils/scroll-into-view.js +25 -33
  246. package/lib/utils/scrollbar-width.js +25 -36
  247. package/lib/utils/shared.js +3 -3
  248. package/lib/utils/types.js +19 -32
  249. package/lib/utils/util.js +187 -221
  250. package/lib/utils/vdom.js +5 -9
  251. package/lib/utils/vue-popper.js +166 -188
  252. package/package.json +20 -19
  253. package/packages/alert/src/main.vue +63 -63
  254. package/packages/aside/src/main.vue +9 -9
  255. package/packages/autocomplete/src/autocomplete-suggestions.vue +46 -46
  256. package/packages/autocomplete/src/autocomplete.vue +198 -198
  257. package/packages/avatar/src/main.vue +5 -5
  258. package/packages/backtop/src/main.vue +3 -3
  259. package/packages/badge/src/main.vue +1 -1
  260. package/packages/breadcrumb/src/breadcrumb-item.vue +26 -26
  261. package/packages/breadcrumb/src/breadcrumb.vue +22 -22
  262. package/packages/button/src/button-group.vue +3 -3
  263. package/packages/button/src/button.vue +44 -44
  264. package/packages/calendar/src/date-table.vue +3 -3
  265. package/packages/calendar/src/main.vue +7 -7
  266. package/packages/card/src/main.vue +9 -9
  267. package/packages/carousel/src/item.vue +98 -98
  268. package/packages/carousel/src/main.vue +2 -2
  269. package/packages/cascader/src/cascader.vue +4 -4
  270. package/packages/cascader-panel/src/cascader-menu.vue +4 -4
  271. package/packages/cascader-panel/src/cascader-node.vue +232 -232
  272. package/packages/cascader-panel/src/cascader-panel.vue +3 -3
  273. package/packages/cascader-panel/src/node.js +2 -3
  274. package/packages/cascader-panel/src/store.js +0 -1
  275. package/packages/checkbox/src/checkbox-button.vue +139 -139
  276. package/packages/checkbox/src/checkbox-group.vue +33 -33
  277. package/packages/checkbox/src/checkbox.vue +140 -140
  278. package/packages/col/src/col.js +5 -5
  279. package/packages/collapse/src/collapse-item.vue +55 -55
  280. package/packages/collapse/src/collapse.vue +54 -54
  281. package/packages/color-picker/src/color.js +4 -4
  282. package/packages/color-picker/src/components/alpha-slider.vue +100 -100
  283. package/packages/color-picker/src/components/hue-slider.vue +91 -91
  284. package/packages/color-picker/src/components/picker-dropdown.vue +64 -64
  285. package/packages/color-picker/src/components/predefine.vue +43 -43
  286. package/packages/color-picker/src/components/sv-panel.vue +70 -70
  287. package/packages/color-picker/src/main.vue +141 -141
  288. package/packages/container/src/main.vue +20 -20
  289. package/packages/date-picker/src/basic/date-table.vue +360 -360
  290. package/packages/date-picker/src/basic/month-table.vue +222 -223
  291. package/packages/date-picker/src/basic/time-spinner.vue +174 -174
  292. package/packages/date-picker/src/basic/year-table.vue +91 -91
  293. package/packages/date-picker/src/panel/date-range.vue +415 -415
  294. package/packages/date-picker/src/panel/date.vue +423 -423
  295. package/packages/date-picker/src/panel/month-range.vue +177 -177
  296. package/packages/date-picker/src/panel/time-range.vue +173 -173
  297. package/packages/date-picker/src/panel/time-select.vue +131 -131
  298. package/packages/date-picker/src/panel/time.vue +131 -131
  299. package/packages/date-picker/src/picker.vue +7 -7
  300. package/packages/descriptions/src/descriptions-row.js +3 -3
  301. package/packages/descriptions/src/index.js +1 -1
  302. package/packages/dialog/src/component.vue +155 -155
  303. package/packages/divider/src/main.vue +1 -1
  304. package/packages/drawer/src/main.vue +2 -2
  305. package/packages/dropdown/src/dropdown-item.vue +15 -15
  306. package/packages/dropdown/src/dropdown-menu.vue +47 -47
  307. package/packages/dropdown/src/dropdown.vue +260 -260
  308. package/packages/empty/src/index.vue +1 -1
  309. package/packages/fileUpload/index.js +8 -0
  310. package/packages/fileUpload/src/main.vue +430 -0
  311. package/packages/footer/src/main.vue +9 -9
  312. package/packages/form/src/form-item.vue +245 -245
  313. package/packages/form/src/form.vue +154 -154
  314. package/packages/header/src/main.vue +9 -9
  315. package/packages/icon/src/icon.vue +6 -6
  316. package/packages/image/src/image-viewer.vue +9 -9
  317. package/packages/image/src/main.vue +206 -206
  318. package/packages/infinite-scroll/src/main.js +1 -2
  319. package/packages/input/src/calcTextareaHeight.js +2 -2
  320. package/packages/input/src/input.vue +311 -311
  321. package/packages/input-number/src/input-number.vue +205 -205
  322. package/packages/loading/src/loading.vue +19 -19
  323. package/packages/main/src/main.vue +4 -4
  324. package/packages/menu/src/menu-item-group.vue +27 -27
  325. package/packages/menu/src/menu-item.vue +69 -69
  326. package/packages/menu/src/menu.vue +284 -284
  327. package/packages/menu/src/submenu.vue +308 -309
  328. package/packages/message/src/main.js +1 -1
  329. package/packages/message/src/main.vue +72 -72
  330. package/packages/message-box/src/main.vue +216 -216
  331. package/packages/notification/src/main.js +1 -1
  332. package/packages/notification/src/main.vue +93 -93
  333. package/packages/pagination/src/pager.vue +99 -99
  334. package/packages/popconfirm/src/main.vue +28 -28
  335. package/packages/popover/src/main.vue +6 -6
  336. package/packages/progress/src/progress.vue +174 -174
  337. package/packages/radio/src/radio-button.vue +64 -64
  338. package/packages/radio/src/radio-group.vue +88 -88
  339. package/packages/radio/src/radio.vue +74 -74
  340. package/packages/rate/src/main.vue +270 -270
  341. package/packages/row/src/row.js +3 -3
  342. package/packages/scrollbar/src/main.js +2 -2
  343. package/packages/scrollbar/src/util.js +1 -1
  344. package/packages/select/src/option-group.vue +46 -46
  345. package/packages/select/src/option.vue +122 -122
  346. package/packages/select/src/select-dropdown.vue +49 -49
  347. package/packages/select/src/select.vue +676 -676
  348. package/packages/skeleton/src/item.vue +12 -12
  349. package/packages/slider/src/button.vue +191 -191
  350. package/packages/slider/src/main.vue +314 -314
  351. package/packages/spinner/src/spinner.vue +16 -16
  352. package/packages/statistic/src/main.vue +5 -6
  353. package/packages/steps/src/step.vue +2 -2
  354. package/packages/steps/src/steps.vue +4 -4
  355. package/packages/subTitle/index.js +8 -0
  356. package/packages/subTitle/src/main.vue +33 -0
  357. package/packages/switch/src/component.vue +123 -123
  358. package/packages/tabDialog/index.js +23 -0
  359. package/packages/tabDialog/src/dialog/drag.js +63 -0
  360. package/packages/tabDialog/src/dialog/dragHeight.js +34 -0
  361. package/packages/tabDialog/src/dialog/dragWidth.js +30 -0
  362. package/packages/tabDialog/src/main.vue +277 -0
  363. package/packages/table/src/filter-panel.vue +128 -128
  364. package/packages/table/src/store/index.js +1 -1
  365. package/packages/table/src/table-body.js +2 -2
  366. package/packages/table/src/table-column.js +1 -1
  367. package/packages/table/src/table-header.js +1 -1
  368. package/packages/table/src/table-layout.js +1 -1
  369. package/packages/table/src/table.vue +416 -416
  370. package/packages/tabs/src/tab-bar.vue +43 -43
  371. package/packages/tabs/src/tab-nav.vue +250 -250
  372. package/packages/tabs/src/tab-pane.vue +34 -34
  373. package/packages/tabs/src/tabs.vue +165 -165
  374. package/packages/tag/src/tag.vue +52 -52
  375. package/packages/theme-chalk/src/index.scss +3 -0
  376. package/packages/theme-cy/lib/element.css +1 -0
  377. package/packages/theme-cy/lib/fileUpload.css +1 -0
  378. package/packages/theme-cy/lib/index.css +1 -1
  379. package/packages/theme-cy/lib/subTitle.css +1 -0
  380. package/packages/theme-cy/lib/tabDialog.css +1 -0
  381. package/packages/theme-cy/lib/treeselect.css +1 -1
  382. package/packages/theme-cy/src/element.scss +45 -0
  383. package/packages/theme-cy/src/fileUpload.scss +30 -0
  384. package/packages/theme-cy/src/index.scss +4 -0
  385. package/packages/theme-cy/src/subTitle.scss +26 -0
  386. package/packages/theme-cy/src/tabDialog.scss +43 -0
  387. package/packages/theme-cy/src/treeselect.scss +20 -14
  388. package/packages/timeline/src/item.vue +24 -24
  389. package/packages/timeline/src/main.vue +27 -27
  390. package/packages/tooltip/src/main.js +1 -1
  391. package/packages/transfer/src/main.vue +169 -169
  392. package/packages/transfer/src/transfer-panel.vue +164 -164
  393. package/packages/tree/src/tree-node.vue +169 -169
  394. package/packages/tree/src/tree.vue +408 -408
  395. package/packages/treeSelect/index.js +8 -0
  396. package/packages/{treeselect → treeSelect}/src/main.vue +19 -19
  397. package/packages/upload/src/ajax.js +3 -3
  398. package/packages/upload/src/upload-dragger.vue +50 -50
  399. package/packages/upload/src/upload-list.vue +33 -33
  400. package/packages/upload/src/upload.vue +1 -1
  401. package/src/index.js +13 -5
  402. package/src/locale/format.js +0 -1
  403. package/src/mixins/migrating.js +2 -2
  404. package/src/utils/date.js +2 -368
  405. package/src/utils/date_source.js +368 -0
  406. package/src/utils/lodash.js +9 -18075
  407. package/src/utils/lodash_source.js +18075 -0
  408. package/src/utils/types.js +1 -1
  409. package/types/element-ui.d.ts +16 -3
  410. package/types/fileUpload.d.ts +5 -0
  411. package/types/subTitle.d.ts +5 -0
  412. package/types/tabDialog.d.ts +5 -0
  413. package/types/treeSelect.d.ts +5 -0
  414. package/lib/treeselect.js +0 -682
  415. package/packages/treeselect/index.js +0 -8
  416. package/types/treeselect.d.ts +0 -5
@@ -82,12 +82,474 @@ module.exports =
82
82
  /******/
83
83
  /******/
84
84
  /******/ // Load entry module and return exports
85
- /******/ return __webpack_require__(__webpack_require__.s = 83);
85
+ /******/ return __webpack_require__(__webpack_require__.s = 172);
86
86
  /******/ })
87
87
  /************************************************************************/
88
88
  /******/ ({
89
89
 
90
90
  /***/ 0:
91
+ /***/ (function(module, exports) {
92
+
93
+ module.exports = require("vue");
94
+
95
+ /***/ }),
96
+
97
+ /***/ 1:
98
+ /***/ (function(module, __webpack_exports__, __webpack_require__) {
99
+
100
+ "use strict";
101
+ /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "g", function() { return on; });
102
+ /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "f", function() { return off; });
103
+ /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "h", function() { return once; });
104
+ /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "d", function() { return hasClass; });
105
+ /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return addClass; });
106
+ /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "i", function() { return removeClass; });
107
+ /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "c", function() { return getStyle; });
108
+ /* unused harmony export setStyle */
109
+ /* unused harmony export isScroll */
110
+ /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "b", function() { return getScrollContainer; });
111
+ /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "e", function() { return isInContainer; });
112
+ /* harmony import */ var core_js_modules_es_array_filter_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(18);
113
+ /* harmony import */ var core_js_modules_es_array_filter_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_array_filter_js__WEBPACK_IMPORTED_MODULE_0__);
114
+ /* harmony import */ var core_js_modules_es_array_includes_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(53);
115
+ /* harmony import */ var core_js_modules_es_array_includes_js__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_array_includes_js__WEBPACK_IMPORTED_MODULE_1__);
116
+ /* harmony import */ var core_js_modules_es_number_constructor_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(6);
117
+ /* harmony import */ var core_js_modules_es_number_constructor_js__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_number_constructor_js__WEBPACK_IMPORTED_MODULE_2__);
118
+ /* harmony import */ var core_js_modules_es_object_to_string_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(3);
119
+ /* harmony import */ var core_js_modules_es_object_to_string_js__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_object_to_string_js__WEBPACK_IMPORTED_MODULE_3__);
120
+ /* harmony import */ var core_js_modules_es_regexp_exec_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7);
121
+ /* harmony import */ var core_js_modules_es_regexp_exec_js__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_regexp_exec_js__WEBPACK_IMPORTED_MODULE_4__);
122
+ /* harmony import */ var core_js_modules_es_string_match_js__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(16);
123
+ /* harmony import */ var core_js_modules_es_string_match_js__WEBPACK_IMPORTED_MODULE_5___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_string_match_js__WEBPACK_IMPORTED_MODULE_5__);
124
+ /* harmony import */ var core_js_modules_es_string_replace_js__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(12);
125
+ /* harmony import */ var core_js_modules_es_string_replace_js__WEBPACK_IMPORTED_MODULE_6___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_string_replace_js__WEBPACK_IMPORTED_MODULE_6__);
126
+ /* harmony import */ var vue__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(0);
127
+ /* harmony import */ var vue__WEBPACK_IMPORTED_MODULE_7___default = /*#__PURE__*/__webpack_require__.n(vue__WEBPACK_IMPORTED_MODULE_7__);
128
+
129
+
130
+
131
+
132
+
133
+
134
+
135
+ /* istanbul ignore next */
136
+
137
+
138
+ var isServer = vue__WEBPACK_IMPORTED_MODULE_7___default.a.prototype.$isServer;
139
+ var SPECIAL_CHARS_REGEXP = /([\:\-\_]+(.))/g;
140
+ var MOZ_HACK_REGEXP = /^moz([A-Z])/;
141
+ var ieVersion = isServer ? 0 : Number(document.documentMode);
142
+
143
+ /* istanbul ignore next */
144
+ var trim = function trim(string) {
145
+ return (string || '').replace(/^[\s\uFEFF]+|[\s\uFEFF]+$/g, '');
146
+ };
147
+ /* istanbul ignore next */
148
+ var camelCase = function camelCase(name) {
149
+ return name.replace(SPECIAL_CHARS_REGEXP, function (_, separator, letter, offset) {
150
+ return offset ? letter.toUpperCase() : letter;
151
+ }).replace(MOZ_HACK_REGEXP, 'Moz$1');
152
+ };
153
+
154
+ /* istanbul ignore next */
155
+ var on = function () {
156
+ if (!isServer && document.addEventListener) {
157
+ return function (element, event, handler) {
158
+ if (element && event && handler) {
159
+ element.addEventListener(event, handler, false);
160
+ }
161
+ };
162
+ } else {
163
+ return function (element, event, handler) {
164
+ if (element && event && handler) {
165
+ element.attachEvent('on' + event, handler);
166
+ }
167
+ };
168
+ }
169
+ }();
170
+
171
+ /* istanbul ignore next */
172
+ var off = function () {
173
+ if (!isServer && document.removeEventListener) {
174
+ return function (element, event, handler) {
175
+ if (element && event) {
176
+ element.removeEventListener(event, handler, false);
177
+ }
178
+ };
179
+ } else {
180
+ return function (element, event, handler) {
181
+ if (element && event) {
182
+ element.detachEvent('on' + event, handler);
183
+ }
184
+ };
185
+ }
186
+ }();
187
+
188
+ /* istanbul ignore next */
189
+ var once = function once(el, event, fn) {
190
+ var _listener = function listener() {
191
+ if (fn) {
192
+ fn.apply(this, arguments);
193
+ }
194
+ off(el, event, _listener);
195
+ };
196
+ on(el, event, _listener);
197
+ };
198
+
199
+ /* istanbul ignore next */
200
+ function hasClass(el, cls) {
201
+ if (!el || !cls) return false;
202
+ if (cls.indexOf(' ') !== -1) throw new Error('className should not contain space.');
203
+ if (el.classList) {
204
+ return el.classList.contains(cls);
205
+ } else {
206
+ return (' ' + el.className + ' ').indexOf(' ' + cls + ' ') > -1;
207
+ }
208
+ }
209
+ ;
210
+
211
+ /* istanbul ignore next */
212
+ function addClass(el, cls) {
213
+ if (!el) return;
214
+ var curClass = el.className;
215
+ var classes = (cls || '').split(' ');
216
+ for (var i = 0, j = classes.length; i < j; i++) {
217
+ var clsName = classes[i];
218
+ if (!clsName) continue;
219
+ if (el.classList) {
220
+ el.classList.add(clsName);
221
+ } else if (!hasClass(el, clsName)) {
222
+ curClass += ' ' + clsName;
223
+ }
224
+ }
225
+ if (!el.classList) {
226
+ el.setAttribute('class', curClass);
227
+ }
228
+ }
229
+ ;
230
+
231
+ /* istanbul ignore next */
232
+ function removeClass(el, cls) {
233
+ if (!el || !cls) return;
234
+ var classes = cls.split(' ');
235
+ var curClass = ' ' + el.className + ' ';
236
+ for (var i = 0, j = classes.length; i < j; i++) {
237
+ var clsName = classes[i];
238
+ if (!clsName) continue;
239
+ if (el.classList) {
240
+ el.classList.remove(clsName);
241
+ } else if (hasClass(el, clsName)) {
242
+ curClass = curClass.replace(' ' + clsName + ' ', ' ');
243
+ }
244
+ }
245
+ if (!el.classList) {
246
+ el.setAttribute('class', trim(curClass));
247
+ }
248
+ }
249
+ ;
250
+
251
+ /* istanbul ignore next */
252
+ var getStyle = ieVersion < 9 ? function (element, styleName) {
253
+ if (isServer) return;
254
+ if (!element || !styleName) return null;
255
+ styleName = camelCase(styleName);
256
+ if (styleName === 'float') {
257
+ styleName = 'styleFloat';
258
+ }
259
+ try {
260
+ switch (styleName) {
261
+ case 'opacity':
262
+ try {
263
+ return element.filters.item('alpha').opacity / 100;
264
+ } catch (e) {
265
+ return 1.0;
266
+ }
267
+ default:
268
+ return element.style[styleName] || element.currentStyle ? element.currentStyle[styleName] : null;
269
+ }
270
+ } catch (e) {
271
+ return element.style[styleName];
272
+ }
273
+ } : function (element, styleName) {
274
+ if (isServer) return;
275
+ if (!element || !styleName) return null;
276
+ styleName = camelCase(styleName);
277
+ if (styleName === 'float') {
278
+ styleName = 'cssFloat';
279
+ }
280
+ try {
281
+ var computed = document.defaultView.getComputedStyle(element, '');
282
+ return element.style[styleName] || computed ? computed[styleName] : null;
283
+ } catch (e) {
284
+ return element.style[styleName];
285
+ }
286
+ };
287
+
288
+ /* istanbul ignore next */
289
+ function setStyle(element, styleName, value) {
290
+ if (!element || !styleName) return;
291
+ if (typeof styleName === 'object') {
292
+ for (var prop in styleName) {
293
+ if (styleName.hasOwnProperty(prop)) {
294
+ setStyle(element, prop, styleName[prop]);
295
+ }
296
+ }
297
+ } else {
298
+ styleName = camelCase(styleName);
299
+ if (styleName === 'opacity' && ieVersion < 9) {
300
+ element.style.filter = isNaN(value) ? '' : 'alpha(opacity=' + value * 100 + ')';
301
+ } else {
302
+ element.style[styleName] = value;
303
+ }
304
+ }
305
+ }
306
+ ;
307
+ var isScroll = function isScroll(el, vertical) {
308
+ if (isServer) return;
309
+ var determinedDirection = vertical !== null && vertical !== undefined;
310
+ var overflow = determinedDirection ? vertical ? getStyle(el, 'overflow-y') : getStyle(el, 'overflow-x') : getStyle(el, 'overflow');
311
+ return overflow.match(/(scroll|auto|overlay)/);
312
+ };
313
+ var getScrollContainer = function getScrollContainer(el, vertical) {
314
+ if (isServer) return;
315
+ var parent = el;
316
+ while (parent) {
317
+ if ([window, document, document.documentElement].includes(parent)) {
318
+ return window;
319
+ }
320
+ if (isScroll(parent, vertical)) {
321
+ return parent;
322
+ }
323
+ parent = parent.parentNode;
324
+ }
325
+ return parent;
326
+ };
327
+ var isInContainer = function isInContainer(el, container) {
328
+ if (isServer || !el || !container) return false;
329
+ var elRect = el.getBoundingClientRect();
330
+ var containerRect;
331
+ if ([window, document, document.documentElement, null, undefined].includes(container)) {
332
+ containerRect = {
333
+ top: 0,
334
+ right: window.innerWidth,
335
+ bottom: window.innerHeight,
336
+ left: 0
337
+ };
338
+ } else {
339
+ containerRect = container.getBoundingClientRect();
340
+ }
341
+ return elRect.top < containerRect.bottom && elRect.bottom > containerRect.top && elRect.right > containerRect.left && elRect.left < containerRect.right;
342
+ };
343
+
344
+ /***/ }),
345
+
346
+ /***/ 10:
347
+ /***/ (function(module, exports) {
348
+
349
+ module.exports = require("core-js/modules/web.dom-collections.for-each.js");
350
+
351
+ /***/ }),
352
+
353
+ /***/ 11:
354
+ /***/ (function(module, exports) {
355
+
356
+ module.exports = require("core-js/modules/es.regexp.to-string.js");
357
+
358
+ /***/ }),
359
+
360
+ /***/ 12:
361
+ /***/ (function(module, exports) {
362
+
363
+ module.exports = require("core-js/modules/es.string.replace.js");
364
+
365
+ /***/ }),
366
+
367
+ /***/ 13:
368
+ /***/ (function(module, exports) {
369
+
370
+ module.exports = require("core-js/modules/es.array.slice.js");
371
+
372
+ /***/ }),
373
+
374
+ /***/ 15:
375
+ /***/ (function(module, __webpack_exports__, __webpack_require__) {
376
+
377
+ "use strict";
378
+ /* harmony default export */ __webpack_exports__["a"] = (function (target) {
379
+ for (var i = 1, j = arguments.length; i < j; i++) {
380
+ var source = arguments[i] || {};
381
+ for (var prop in source) {
382
+ if (source.hasOwnProperty(prop)) {
383
+ var value = source[prop];
384
+ if (value !== undefined) {
385
+ target[prop] = value;
386
+ }
387
+ }
388
+ }
389
+ }
390
+ return target;
391
+ });
392
+ ;
393
+
394
+ /***/ }),
395
+
396
+ /***/ 16:
397
+ /***/ (function(module, exports) {
398
+
399
+ module.exports = require("core-js/modules/es.string.match.js");
400
+
401
+ /***/ }),
402
+
403
+ /***/ 17:
404
+ /***/ (function(module, exports) {
405
+
406
+ module.exports = require("core-js/modules/es.object.keys.js");
407
+
408
+ /***/ }),
409
+
410
+ /***/ 172:
411
+ /***/ (function(module, __webpack_exports__, __webpack_require__) {
412
+
413
+ "use strict";
414
+ // ESM COMPAT FLAG
415
+ __webpack_require__.r(__webpack_exports__);
416
+
417
+ // EXTERNAL MODULE: external "core-js/modules/es.function.name.js"
418
+ var es_function_name_js_ = __webpack_require__(5);
419
+
420
+ // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??ref--5!./node_modules/vue-loader/lib??vue-loader-options!./packages/dropdown/src/dropdown-menu.vue?vue&type=template&id=8e1ce7e8
421
+ var render = function render() {
422
+ var _vm = this,
423
+ _c = _vm._self._c
424
+ return _c(
425
+ "transition",
426
+ { attrs: { name: "el-zoom-in-top" }, on: { "after-leave": _vm.doDestroy } },
427
+ [
428
+ _c(
429
+ "ul",
430
+ {
431
+ directives: [
432
+ {
433
+ name: "show",
434
+ rawName: "v-show",
435
+ value: _vm.showPopper,
436
+ expression: "showPopper",
437
+ },
438
+ ],
439
+ staticClass: "el-dropdown-menu el-popper",
440
+ class: [_vm.size && `el-dropdown-menu--${_vm.size}`],
441
+ },
442
+ [_vm._t("default")],
443
+ 2
444
+ ),
445
+ ]
446
+ )
447
+ }
448
+ var staticRenderFns = []
449
+ render._withStripped = true
450
+
451
+
452
+ // CONCATENATED MODULE: ./packages/dropdown/src/dropdown-menu.vue?vue&type=template&id=8e1ce7e8
453
+
454
+ // EXTERNAL MODULE: external "core-js/modules/es.number.constructor.js"
455
+ var es_number_constructor_js_ = __webpack_require__(6);
456
+
457
+ // EXTERNAL MODULE: ./src/utils/vue-popper.js
458
+ var vue_popper = __webpack_require__(51);
459
+
460
+ // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/dropdown/src/dropdown-menu.vue?vue&type=script&lang=js
461
+
462
+
463
+ /* harmony default export */ var dropdown_menuvue_type_script_lang_js = ({
464
+ name: 'ElDropdownMenu',
465
+ componentName: 'ElDropdownMenu',
466
+ mixins: [vue_popper["a" /* default */]],
467
+ props: {
468
+ visibleArrow: {
469
+ type: Boolean,
470
+ default: true
471
+ },
472
+ arrowOffset: {
473
+ type: Number,
474
+ default: 0
475
+ }
476
+ },
477
+ data: function data() {
478
+ return {
479
+ size: this.dropdown.dropdownSize
480
+ };
481
+ },
482
+ inject: ['dropdown'],
483
+ created: function created() {
484
+ var _this = this;
485
+ this.$on('updatePopper', function () {
486
+ if (_this.showPopper) _this.updatePopper();
487
+ });
488
+ this.$on('visible', function (val) {
489
+ _this.showPopper = val;
490
+ });
491
+ },
492
+ mounted: function mounted() {
493
+ this.dropdown.popperElm = this.popperElm = this.$el;
494
+ this.referenceElm = this.dropdown.$el;
495
+ // compatible with 2.6 new v-slot syntax
496
+ // issue link https://github.com/ElemeFE/element/issues/14345
497
+ this.dropdown.initDomOperation();
498
+ },
499
+ watch: {
500
+ 'dropdown.placement': {
501
+ immediate: true,
502
+ handler: function handler(val) {
503
+ this.currentPlacement = val;
504
+ }
505
+ }
506
+ }
507
+ });
508
+ // CONCATENATED MODULE: ./packages/dropdown/src/dropdown-menu.vue?vue&type=script&lang=js
509
+ /* harmony default export */ var src_dropdown_menuvue_type_script_lang_js = (dropdown_menuvue_type_script_lang_js);
510
+ // EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js
511
+ var componentNormalizer = __webpack_require__(2);
512
+
513
+ // CONCATENATED MODULE: ./packages/dropdown/src/dropdown-menu.vue
514
+
515
+
516
+
517
+
518
+
519
+ /* normalize component */
520
+
521
+ var component = Object(componentNormalizer["a" /* default */])(
522
+ src_dropdown_menuvue_type_script_lang_js,
523
+ render,
524
+ staticRenderFns,
525
+ false,
526
+ null,
527
+ null,
528
+ null
529
+
530
+ )
531
+
532
+ /* harmony default export */ var dropdown_menu = (component.exports);
533
+ // CONCATENATED MODULE: ./packages/dropdown-menu/index.js
534
+
535
+
536
+
537
+ /* istanbul ignore next */
538
+ dropdown_menu.install = function (Vue) {
539
+ Vue.component(dropdown_menu.name, dropdown_menu);
540
+ };
541
+ /* harmony default export */ var packages_dropdown_menu = __webpack_exports__["default"] = (dropdown_menu);
542
+
543
+ /***/ }),
544
+
545
+ /***/ 18:
546
+ /***/ (function(module, exports) {
547
+
548
+ module.exports = require("core-js/modules/es.array.filter.js");
549
+
550
+ /***/ }),
551
+
552
+ /***/ 2:
91
553
  /***/ (function(module, __webpack_exports__, __webpack_require__) {
92
554
 
93
555
  "use strict";
@@ -192,159 +654,2025 @@ function normalizeComponent(
192
654
 
193
655
  /***/ }),
194
656
 
195
- /***/ 5:
657
+ /***/ 20:
196
658
  /***/ (function(module, exports) {
197
659
 
198
- module.exports = require("element-ui/lib/utils/vue-popper");
660
+ module.exports = require("core-js/modules/es.array.map.js");
199
661
 
200
662
  /***/ }),
201
663
 
202
- /***/ 83:
664
+ /***/ 22:
665
+ /***/ (function(module, exports) {
666
+
667
+ module.exports = require("core-js/modules/es.array.splice.js");
668
+
669
+ /***/ }),
670
+
671
+ /***/ 23:
203
672
  /***/ (function(module, __webpack_exports__, __webpack_require__) {
204
673
 
205
674
  "use strict";
206
- // ESM COMPAT FLAG
207
- __webpack_require__.r(__webpack_exports__);
675
+ /* harmony import */ var vue__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(0);
676
+ /* harmony import */ var vue__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(vue__WEBPACK_IMPORTED_MODULE_0__);
208
677
 
209
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/dropdown/src/dropdown-menu.vue?vue&type=template&id=f47388ae
210
- var render = function () {
211
- var _vm = this
212
- var _h = _vm.$createElement
213
- var _c = _vm._self._c || _h
214
- return _c(
215
- "transition",
216
- { attrs: { name: "el-zoom-in-top" }, on: { "after-leave": _vm.doDestroy } },
217
- [
218
- _c(
219
- "ul",
220
- {
221
- directives: [
222
- {
223
- name: "show",
224
- rawName: "v-show",
225
- value: _vm.showPopper,
226
- expression: "showPopper",
227
- },
228
- ],
229
- staticClass: "el-dropdown-menu el-popper",
230
- class: [_vm.size && "el-dropdown-menu--" + _vm.size],
231
- },
232
- [_vm._t("default")],
233
- 2
234
- ),
235
- ]
236
- )
237
- }
238
- var staticRenderFns = []
239
- render._withStripped = true
678
+ var scrollBarWidth;
679
+ /* harmony default export */ __webpack_exports__["a"] = (function () {
680
+ if (vue__WEBPACK_IMPORTED_MODULE_0___default.a.prototype.$isServer) return 0;
681
+ if (scrollBarWidth !== undefined) return scrollBarWidth;
682
+ var outer = document.createElement('div');
683
+ outer.className = 'el-scrollbar__wrap';
684
+ outer.style.visibility = 'hidden';
685
+ outer.style.width = '100px';
686
+ outer.style.position = 'absolute';
687
+ outer.style.top = '-9999px';
688
+ document.body.appendChild(outer);
689
+ var widthNoScroll = outer.offsetWidth;
690
+ outer.style.overflow = 'scroll';
691
+ var inner = document.createElement('div');
692
+ inner.style.width = '100%';
693
+ outer.appendChild(inner);
694
+ var widthWithScroll = inner.offsetWidth;
695
+ outer.parentNode.removeChild(outer);
696
+ scrollBarWidth = widthNoScroll - widthWithScroll;
697
+ return scrollBarWidth;
698
+ });
699
+ ;
240
700
 
701
+ /***/ }),
241
702
 
242
- // CONCATENATED MODULE: ./packages/dropdown/src/dropdown-menu.vue?vue&type=template&id=f47388ae
703
+ /***/ 24:
704
+ /***/ (function(module, __webpack_exports__, __webpack_require__) {
243
705
 
244
- // EXTERNAL MODULE: external "element-ui/lib/utils/vue-popper"
245
- var vue_popper_ = __webpack_require__(5);
246
- var vue_popper_default = /*#__PURE__*/__webpack_require__.n(vue_popper_);
706
+ "use strict";
247
707
 
248
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/dropdown/src/dropdown-menu.vue?vue&type=script&lang=js
249
- //
250
- //
251
- //
252
- //
253
- //
254
- //
255
- //
708
+ // EXPORTS
709
+ __webpack_require__.d(__webpack_exports__, "a", function() { return /* reexport */ popup_manager; });
256
710
 
711
+ // EXTERNAL MODULE: external "core-js/modules/es.number.constructor.js"
712
+ var es_number_constructor_js_ = __webpack_require__(6);
257
713
 
714
+ // EXTERNAL MODULE: external "vue"
715
+ var external_vue_ = __webpack_require__(0);
716
+ var external_vue_default = /*#__PURE__*/__webpack_require__.n(external_vue_);
258
717
 
259
- /* harmony default export */ var dropdown_menuvue_type_script_lang_js = ({
260
- name: 'ElDropdownMenu',
718
+ // EXTERNAL MODULE: ./src/utils/merge.js
719
+ var merge = __webpack_require__(15);
261
720
 
262
- componentName: 'ElDropdownMenu',
721
+ // EXTERNAL MODULE: external "core-js/modules/es.array.splice.js"
722
+ var es_array_splice_js_ = __webpack_require__(22);
263
723
 
264
- mixins: [vue_popper_default.a],
724
+ // EXTERNAL MODULE: external "core-js/modules/es.object.to-string.js"
725
+ var es_object_to_string_js_ = __webpack_require__(3);
265
726
 
266
- props: {
267
- visibleArrow: {
268
- type: Boolean,
269
- default: true
270
- },
271
- arrowOffset: {
272
- type: Number,
273
- default: 0
274
- }
275
- },
727
+ // EXTERNAL MODULE: external "core-js/modules/es.regexp.exec.js"
728
+ var es_regexp_exec_js_ = __webpack_require__(7);
276
729
 
277
- data: function data() {
278
- return {
279
- size: this.dropdown.dropdownSize
280
- };
281
- },
730
+ // EXTERNAL MODULE: external "core-js/modules/es.string.split.js"
731
+ var es_string_split_js_ = __webpack_require__(59);
282
732
 
733
+ // EXTERNAL MODULE: external "core-js/modules/es.string.trim.js"
734
+ var es_string_trim_js_ = __webpack_require__(55);
283
735
 
284
- inject: ['dropdown'],
736
+ // EXTERNAL MODULE: external "core-js/modules/web.dom-collections.for-each.js"
737
+ var web_dom_collections_for_each_js_ = __webpack_require__(10);
285
738
 
286
- created: function created() {
287
- var _this = this;
739
+ // EXTERNAL MODULE: ./src/utils/dom.js
740
+ var utils_dom = __webpack_require__(1);
288
741
 
289
- this.$on('updatePopper', function () {
290
- if (_this.showPopper) _this.updatePopper();
291
- });
292
- this.$on('visible', function (val) {
293
- _this.showPopper = val;
294
- });
295
- },
296
- mounted: function mounted() {
297
- this.dropdown.popperElm = this.popperElm = this.$el;
298
- this.referenceElm = this.dropdown.$el;
299
- // compatible with 2.6 new v-slot syntax
300
- // issue link https://github.com/ElemeFE/element/issues/14345
301
- this.dropdown.initDomOperation();
302
- },
303
-
304
-
305
- watch: {
306
- 'dropdown.placement': {
307
- immediate: true,
308
- handler: function handler(val) {
309
- this.currentPlacement = val;
310
- }
311
- }
312
- }
742
+ // CONCATENATED MODULE: ./src/utils/popup/popup-manager.js
743
+
744
+
745
+
746
+
747
+
748
+
749
+
750
+
751
+ var hasModal = false;
752
+ var hasInitZIndex = false;
753
+ var popup_manager_zIndex;
754
+ var popup_manager_getModal = function getModal() {
755
+ if (external_vue_default.a.prototype.$isServer) return;
756
+ var modalDom = PopupManager.modalDom;
757
+ if (modalDom) {
758
+ hasModal = true;
759
+ } else {
760
+ hasModal = false;
761
+ modalDom = document.createElement('div');
762
+ PopupManager.modalDom = modalDom;
763
+ modalDom.addEventListener('touchmove', function (event) {
764
+ event.preventDefault();
765
+ event.stopPropagation();
766
+ });
767
+ modalDom.addEventListener('click', function () {
768
+ PopupManager.doOnModalClick && PopupManager.doOnModalClick();
769
+ });
770
+ }
771
+ return modalDom;
772
+ };
773
+ var instances = {};
774
+ var PopupManager = {
775
+ modalFade: true,
776
+ getInstance: function getInstance(id) {
777
+ return instances[id];
778
+ },
779
+ register: function register(id, instance) {
780
+ if (id && instance) {
781
+ instances[id] = instance;
782
+ }
783
+ },
784
+ deregister: function deregister(id) {
785
+ if (id) {
786
+ instances[id] = null;
787
+ delete instances[id];
788
+ }
789
+ },
790
+ nextZIndex: function nextZIndex() {
791
+ return PopupManager.zIndex++;
792
+ },
793
+ modalStack: [],
794
+ doOnModalClick: function doOnModalClick() {
795
+ var topItem = PopupManager.modalStack[PopupManager.modalStack.length - 1];
796
+ if (!topItem) return;
797
+ var instance = PopupManager.getInstance(topItem.id);
798
+ if (instance && instance.closeOnClickModal) {
799
+ instance.close();
800
+ }
801
+ },
802
+ openModal: function openModal(id, zIndex, dom, modalClass, modalFade) {
803
+ if (external_vue_default.a.prototype.$isServer) return;
804
+ if (!id || zIndex === undefined) return;
805
+ this.modalFade = modalFade;
806
+ var modalStack = this.modalStack;
807
+ for (var i = 0, j = modalStack.length; i < j; i++) {
808
+ var item = modalStack[i];
809
+ if (item.id === id) {
810
+ return;
811
+ }
812
+ }
813
+ var modalDom = popup_manager_getModal();
814
+ Object(utils_dom["a" /* addClass */])(modalDom, 'v-modal');
815
+ if (this.modalFade && !hasModal) {
816
+ Object(utils_dom["a" /* addClass */])(modalDom, 'v-modal-enter');
817
+ }
818
+ if (modalClass) {
819
+ var classArr = modalClass.trim().split(/\s+/);
820
+ classArr.forEach(function (item) {
821
+ return Object(utils_dom["a" /* addClass */])(modalDom, item);
822
+ });
823
+ }
824
+ setTimeout(function () {
825
+ Object(utils_dom["i" /* removeClass */])(modalDom, 'v-modal-enter');
826
+ }, 200);
827
+ if (dom && dom.parentNode && dom.parentNode.nodeType !== 11) {
828
+ dom.parentNode.appendChild(modalDom);
829
+ } else {
830
+ document.body.appendChild(modalDom);
831
+ }
832
+ if (zIndex) {
833
+ modalDom.style.zIndex = zIndex;
834
+ }
835
+ modalDom.tabIndex = 0;
836
+ modalDom.style.display = '';
837
+ this.modalStack.push({
838
+ id: id,
839
+ zIndex: zIndex,
840
+ modalClass: modalClass
841
+ });
842
+ },
843
+ closeModal: function closeModal(id) {
844
+ var modalStack = this.modalStack;
845
+ var modalDom = popup_manager_getModal();
846
+ if (modalStack.length > 0) {
847
+ var topItem = modalStack[modalStack.length - 1];
848
+ if (topItem.id === id) {
849
+ if (topItem.modalClass) {
850
+ var classArr = topItem.modalClass.trim().split(/\s+/);
851
+ classArr.forEach(function (item) {
852
+ return Object(utils_dom["i" /* removeClass */])(modalDom, item);
853
+ });
854
+ }
855
+ modalStack.pop();
856
+ if (modalStack.length > 0) {
857
+ modalDom.style.zIndex = modalStack[modalStack.length - 1].zIndex;
858
+ }
859
+ } else {
860
+ for (var i = modalStack.length - 1; i >= 0; i--) {
861
+ if (modalStack[i].id === id) {
862
+ modalStack.splice(i, 1);
863
+ break;
864
+ }
865
+ }
866
+ }
867
+ }
868
+ if (modalStack.length === 0) {
869
+ if (this.modalFade) {
870
+ Object(utils_dom["a" /* addClass */])(modalDom, 'v-modal-leave');
871
+ }
872
+ setTimeout(function () {
873
+ if (modalStack.length === 0) {
874
+ if (modalDom.parentNode) modalDom.parentNode.removeChild(modalDom);
875
+ modalDom.style.display = 'none';
876
+ PopupManager.modalDom = undefined;
877
+ }
878
+ Object(utils_dom["i" /* removeClass */])(modalDom, 'v-modal-leave');
879
+ }, 200);
880
+ }
881
+ }
882
+ };
883
+ Object.defineProperty(PopupManager, 'zIndex', {
884
+ configurable: true,
885
+ get: function get() {
886
+ if (!hasInitZIndex) {
887
+ popup_manager_zIndex = popup_manager_zIndex || (external_vue_default.a.prototype.$ELEMENT || {}).zIndex || 2000;
888
+ hasInitZIndex = true;
889
+ }
890
+ return popup_manager_zIndex;
891
+ },
892
+ set: function set(value) {
893
+ popup_manager_zIndex = value;
894
+ }
313
895
  });
314
- // CONCATENATED MODULE: ./packages/dropdown/src/dropdown-menu.vue?vue&type=script&lang=js
315
- /* harmony default export */ var src_dropdown_menuvue_type_script_lang_js = (dropdown_menuvue_type_script_lang_js);
316
- // EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js
317
- var componentNormalizer = __webpack_require__(0);
896
+ var popup_manager_getTopPopup = function getTopPopup() {
897
+ if (external_vue_default.a.prototype.$isServer) return;
898
+ if (PopupManager.modalStack.length > 0) {
899
+ var topPopup = PopupManager.modalStack[PopupManager.modalStack.length - 1];
900
+ if (!topPopup) return;
901
+ var instance = PopupManager.getInstance(topPopup.id);
902
+ return instance;
903
+ }
904
+ };
905
+ if (!external_vue_default.a.prototype.$isServer) {
906
+ // handle `esc` key when the popup is shown
907
+ window.addEventListener('keydown', function (event) {
908
+ if (event.keyCode === 27) {
909
+ var topPopup = popup_manager_getTopPopup();
910
+ if (topPopup && topPopup.closeOnPressEscape) {
911
+ topPopup.handleClose ? topPopup.handleClose() : topPopup.handleAction ? topPopup.handleAction('cancel') : topPopup.close();
912
+ }
913
+ }
914
+ });
915
+ }
916
+ /* harmony default export */ var popup_manager = (PopupManager);
917
+ // EXTERNAL MODULE: ./src/utils/scrollbar-width.js
918
+ var scrollbar_width = __webpack_require__(23);
318
919
 
319
- // CONCATENATED MODULE: ./packages/dropdown/src/dropdown-menu.vue
920
+ // CONCATENATED MODULE: ./src/utils/popup/index.js
320
921
 
321
922
 
322
923
 
323
924
 
324
925
 
325
- /* normalize component */
326
926
 
327
- var component = Object(componentNormalizer["a" /* default */])(
328
- src_dropdown_menuvue_type_script_lang_js,
329
- render,
330
- staticRenderFns,
331
- false,
332
- null,
333
- null,
334
- null
335
-
336
- )
927
+ var idSeed = 1;
928
+ var scrollBarWidth;
929
+ /* harmony default export */ var popup = __webpack_exports__["b"] = ({
930
+ props: {
931
+ visible: {
932
+ type: Boolean,
933
+ default: false
934
+ },
935
+ openDelay: {},
936
+ closeDelay: {},
937
+ zIndex: {},
938
+ modal: {
939
+ type: Boolean,
940
+ default: false
941
+ },
942
+ modalFade: {
943
+ type: Boolean,
944
+ default: true
945
+ },
946
+ modalClass: {},
947
+ modalAppendToBody: {
948
+ type: Boolean,
949
+ default: false
950
+ },
951
+ lockScroll: {
952
+ type: Boolean,
953
+ default: true
954
+ },
955
+ closeOnPressEscape: {
956
+ type: Boolean,
957
+ default: false
958
+ },
959
+ closeOnClickModal: {
960
+ type: Boolean,
961
+ default: false
962
+ }
963
+ },
964
+ beforeMount: function beforeMount() {
965
+ this._popupId = 'popup-' + idSeed++;
966
+ popup_manager.register(this._popupId, this);
967
+ },
968
+ beforeDestroy: function beforeDestroy() {
969
+ popup_manager.deregister(this._popupId);
970
+ popup_manager.closeModal(this._popupId);
971
+ this.restoreBodyStyle();
972
+ },
973
+ data: function data() {
974
+ return {
975
+ opened: false,
976
+ bodyPaddingRight: null,
977
+ computedBodyPaddingRight: 0,
978
+ withoutHiddenClass: true,
979
+ rendered: false
980
+ };
981
+ },
982
+ watch: {
983
+ visible: function visible(val) {
984
+ var _this = this;
985
+ if (val) {
986
+ if (this._opening) return;
987
+ if (!this.rendered) {
988
+ this.rendered = true;
989
+ external_vue_default.a.nextTick(function () {
990
+ _this.open();
991
+ });
992
+ } else {
993
+ this.open();
994
+ }
995
+ } else {
996
+ this.close();
997
+ }
998
+ }
999
+ },
1000
+ methods: {
1001
+ open: function open(options) {
1002
+ var _this2 = this;
1003
+ if (!this.rendered) {
1004
+ this.rendered = true;
1005
+ }
1006
+ var props = Object(merge["a" /* default */])({}, this.$props || this, options);
1007
+ if (this._closeTimer) {
1008
+ clearTimeout(this._closeTimer);
1009
+ this._closeTimer = null;
1010
+ }
1011
+ clearTimeout(this._openTimer);
1012
+ var openDelay = Number(props.openDelay);
1013
+ if (openDelay > 0) {
1014
+ this._openTimer = setTimeout(function () {
1015
+ _this2._openTimer = null;
1016
+ _this2.doOpen(props);
1017
+ }, openDelay);
1018
+ } else {
1019
+ this.doOpen(props);
1020
+ }
1021
+ },
1022
+ doOpen: function doOpen(props) {
1023
+ if (this.$isServer) return;
1024
+ if (this.willOpen && !this.willOpen()) return;
1025
+ if (this.opened) return;
1026
+ this._opening = true;
1027
+ var dom = this.$el;
1028
+ var modal = props.modal;
1029
+ var zIndex = props.zIndex;
1030
+ if (zIndex) {
1031
+ popup_manager.zIndex = zIndex;
1032
+ }
1033
+ if (modal) {
1034
+ if (this._closing) {
1035
+ popup_manager.closeModal(this._popupId);
1036
+ this._closing = false;
1037
+ }
1038
+ popup_manager.openModal(this._popupId, popup_manager.nextZIndex(), this.modalAppendToBody ? undefined : dom, props.modalClass, props.modalFade);
1039
+ if (props.lockScroll) {
1040
+ this.withoutHiddenClass = !Object(utils_dom["d" /* hasClass */])(document.body, 'el-popup-parent--hidden');
1041
+ if (this.withoutHiddenClass) {
1042
+ this.bodyPaddingRight = document.body.style.paddingRight;
1043
+ this.computedBodyPaddingRight = parseInt(Object(utils_dom["c" /* getStyle */])(document.body, 'paddingRight'), 10);
1044
+ }
1045
+ scrollBarWidth = Object(scrollbar_width["a" /* default */])();
1046
+ var bodyHasOverflow = document.documentElement.clientHeight < document.body.scrollHeight;
1047
+ var bodyOverflowY = Object(utils_dom["c" /* getStyle */])(document.body, 'overflowY');
1048
+ if (scrollBarWidth > 0 && (bodyHasOverflow || bodyOverflowY === 'scroll') && this.withoutHiddenClass) {
1049
+ document.body.style.paddingRight = this.computedBodyPaddingRight + scrollBarWidth + 'px';
1050
+ }
1051
+ Object(utils_dom["a" /* addClass */])(document.body, 'el-popup-parent--hidden');
1052
+ }
1053
+ }
1054
+ if (getComputedStyle(dom).position === 'static') {
1055
+ dom.style.position = 'absolute';
1056
+ }
1057
+ dom.style.zIndex = popup_manager.nextZIndex();
1058
+ this.opened = true;
1059
+ this.onOpen && this.onOpen();
1060
+ this.doAfterOpen();
1061
+ },
1062
+ doAfterOpen: function doAfterOpen() {
1063
+ this._opening = false;
1064
+ },
1065
+ close: function close() {
1066
+ var _this3 = this;
1067
+ if (this.willClose && !this.willClose()) return;
1068
+ if (this._openTimer !== null) {
1069
+ clearTimeout(this._openTimer);
1070
+ this._openTimer = null;
1071
+ }
1072
+ clearTimeout(this._closeTimer);
1073
+ var closeDelay = Number(this.closeDelay);
1074
+ if (closeDelay > 0) {
1075
+ this._closeTimer = setTimeout(function () {
1076
+ _this3._closeTimer = null;
1077
+ _this3.doClose();
1078
+ }, closeDelay);
1079
+ } else {
1080
+ this.doClose();
1081
+ }
1082
+ },
1083
+ doClose: function doClose() {
1084
+ this._closing = true;
1085
+ this.onClose && this.onClose();
1086
+ if (this.lockScroll) {
1087
+ setTimeout(this.restoreBodyStyle, 200);
1088
+ }
1089
+ this.opened = false;
1090
+ this.doAfterClose();
1091
+ },
1092
+ doAfterClose: function doAfterClose() {
1093
+ popup_manager.closeModal(this._popupId);
1094
+ this._closing = false;
1095
+ },
1096
+ restoreBodyStyle: function restoreBodyStyle() {
1097
+ if (this.modal && this.withoutHiddenClass) {
1098
+ document.body.style.paddingRight = this.bodyPaddingRight;
1099
+ Object(utils_dom["i" /* removeClass */])(document.body, 'el-popup-parent--hidden');
1100
+ }
1101
+ this.withoutHiddenClass = true;
1102
+ }
1103
+ }
1104
+ });
337
1105
 
338
- /* harmony default export */ var dropdown_menu = (component.exports);
339
- // CONCATENATED MODULE: ./packages/dropdown-menu/index.js
340
1106
 
1107
+ /***/ }),
1108
+
1109
+ /***/ 3:
1110
+ /***/ (function(module, exports) {
341
1111
 
342
- /* istanbul ignore next */
343
- dropdown_menu.install = function (Vue) {
344
- Vue.component(dropdown_menu.name, dropdown_menu);
1112
+ module.exports = require("core-js/modules/es.object.to-string.js");
1113
+
1114
+ /***/ }),
1115
+
1116
+ /***/ 5:
1117
+ /***/ (function(module, exports) {
1118
+
1119
+ module.exports = require("core-js/modules/es.function.name.js");
1120
+
1121
+ /***/ }),
1122
+
1123
+ /***/ 51:
1124
+ /***/ (function(module, __webpack_exports__, __webpack_require__) {
1125
+
1126
+ "use strict";
1127
+ /* harmony import */ var core_js_modules_es_function_name_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(5);
1128
+ /* harmony import */ var core_js_modules_es_function_name_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_function_name_js__WEBPACK_IMPORTED_MODULE_0__);
1129
+ /* harmony import */ var core_js_modules_es_number_constructor_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(6);
1130
+ /* harmony import */ var core_js_modules_es_number_constructor_js__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_number_constructor_js__WEBPACK_IMPORTED_MODULE_1__);
1131
+ /* harmony import */ var core_js_modules_es_regexp_exec_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7);
1132
+ /* harmony import */ var core_js_modules_es_regexp_exec_js__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_regexp_exec_js__WEBPACK_IMPORTED_MODULE_2__);
1133
+ /* harmony import */ var vue__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(0);
1134
+ /* harmony import */ var vue__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(vue__WEBPACK_IMPORTED_MODULE_3__);
1135
+ /* harmony import */ var _popup__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(24);
1136
+
1137
+
1138
+
1139
+
1140
+
1141
+ var PopperJS = vue__WEBPACK_IMPORTED_MODULE_3___default.a.prototype.$isServer ? function () {} : __webpack_require__(73);
1142
+ var stop = function stop(e) {
1143
+ return e.stopPropagation();
345
1144
  };
346
1145
 
347
- /* harmony default export */ var packages_dropdown_menu = __webpack_exports__["default"] = (dropdown_menu);
1146
+ /**
1147
+ * @param {HTMLElement} [reference=$refs.reference] - The reference element used to position the popper.
1148
+ * @param {HTMLElement} [popper=$refs.popper] - The HTML element used as popper, or a configuration used to generate the popper.
1149
+ * @param {String} [placement=button] - Placement of the popper accepted values: top(-start, -end), right(-start, -end), bottom(-start, -end), left(-start, -end)
1150
+ * @param {Number} [offset=0] - Amount of pixels the popper will be shifted (can be negative).
1151
+ * @param {Boolean} [visible=false] Visibility of the popup element.
1152
+ * @param {Boolean} [visible-arrow=false] Visibility of the arrow, no style.
1153
+ */
1154
+ /* harmony default export */ __webpack_exports__["a"] = ({
1155
+ props: {
1156
+ transformOrigin: {
1157
+ type: [Boolean, String],
1158
+ default: true
1159
+ },
1160
+ placement: {
1161
+ type: String,
1162
+ default: 'bottom'
1163
+ },
1164
+ boundariesPadding: {
1165
+ type: Number,
1166
+ default: 5
1167
+ },
1168
+ reference: {},
1169
+ popper: {},
1170
+ offset: {
1171
+ default: 0
1172
+ },
1173
+ value: Boolean,
1174
+ visibleArrow: Boolean,
1175
+ arrowOffset: {
1176
+ type: Number,
1177
+ default: 35
1178
+ },
1179
+ appendToBody: {
1180
+ type: Boolean,
1181
+ default: true
1182
+ },
1183
+ popperOptions: {
1184
+ type: Object,
1185
+ default: function _default() {
1186
+ return {
1187
+ gpuAcceleration: false
1188
+ };
1189
+ }
1190
+ }
1191
+ },
1192
+ data: function data() {
1193
+ return {
1194
+ showPopper: false,
1195
+ currentPlacement: ''
1196
+ };
1197
+ },
1198
+ watch: {
1199
+ value: {
1200
+ immediate: true,
1201
+ handler: function handler(val) {
1202
+ this.showPopper = val;
1203
+ this.$emit('input', val);
1204
+ }
1205
+ },
1206
+ showPopper: function showPopper(val) {
1207
+ if (this.disabled) return;
1208
+ val ? this.updatePopper() : this.destroyPopper();
1209
+ this.$emit('input', val);
1210
+ }
1211
+ },
1212
+ methods: {
1213
+ createPopper: function createPopper() {
1214
+ var _this = this;
1215
+ if (this.$isServer) return;
1216
+ this.currentPlacement = this.currentPlacement || this.placement;
1217
+ if (!/^(top|bottom|left|right)(-start|-end)?$/g.test(this.currentPlacement)) {
1218
+ return;
1219
+ }
1220
+ var options = this.popperOptions;
1221
+ var popper = this.popperElm = this.popperElm || this.popper || this.$refs.popper;
1222
+ var reference = this.referenceElm = this.referenceElm || this.reference || this.$refs.reference;
1223
+ if (!reference && this.$slots.reference && this.$slots.reference[0]) {
1224
+ reference = this.referenceElm = this.$slots.reference[0].elm;
1225
+ }
1226
+ if (!popper || !reference) return;
1227
+ if (this.visibleArrow) this.appendArrow(popper);
1228
+ if (this.appendToBody) document.body.appendChild(this.popperElm);
1229
+ if (this.popperJS && this.popperJS.destroy) {
1230
+ this.popperJS.destroy();
1231
+ }
1232
+ options.placement = this.currentPlacement;
1233
+ options.offset = this.offset;
1234
+ options.arrowOffset = this.arrowOffset;
1235
+ this.popperJS = new PopperJS(reference, popper, options);
1236
+ this.popperJS.onCreate(function (_) {
1237
+ _this.$emit('created', _this);
1238
+ _this.resetTransformOrigin();
1239
+ _this.$nextTick(_this.updatePopper);
1240
+ });
1241
+ if (typeof options.onUpdate === 'function') {
1242
+ this.popperJS.onUpdate(options.onUpdate);
1243
+ }
1244
+ this.popperJS._popper.style.zIndex = _popup__WEBPACK_IMPORTED_MODULE_4__[/* PopupManager */ "a"].nextZIndex();
1245
+ this.popperElm.addEventListener('click', stop);
1246
+ },
1247
+ updatePopper: function updatePopper() {
1248
+ var popperJS = this.popperJS;
1249
+ if (popperJS) {
1250
+ popperJS.update();
1251
+ if (popperJS._popper) {
1252
+ popperJS._popper.style.zIndex = _popup__WEBPACK_IMPORTED_MODULE_4__[/* PopupManager */ "a"].nextZIndex();
1253
+ }
1254
+ } else {
1255
+ this.createPopper();
1256
+ }
1257
+ },
1258
+ doDestroy: function doDestroy(forceDestroy) {
1259
+ /* istanbul ignore if */
1260
+ if (!this.popperJS || this.showPopper && !forceDestroy) return;
1261
+ this.popperJS.destroy();
1262
+ this.popperJS = null;
1263
+ },
1264
+ destroyPopper: function destroyPopper() {
1265
+ if (this.popperJS) {
1266
+ this.resetTransformOrigin();
1267
+ }
1268
+ },
1269
+ resetTransformOrigin: function resetTransformOrigin() {
1270
+ if (!this.transformOrigin) return;
1271
+ var placementMap = {
1272
+ top: 'bottom',
1273
+ bottom: 'top',
1274
+ left: 'right',
1275
+ right: 'left'
1276
+ };
1277
+ var placement = this.popperJS._popper.getAttribute('x-placement').split('-')[0];
1278
+ var origin = placementMap[placement];
1279
+ this.popperJS._popper.style.transformOrigin = typeof this.transformOrigin === 'string' ? this.transformOrigin : ['top', 'bottom'].indexOf(placement) > -1 ? "center " + origin : origin + " center";
1280
+ },
1281
+ appendArrow: function appendArrow(element) {
1282
+ var hash;
1283
+ if (this.appended) {
1284
+ return;
1285
+ }
1286
+ this.appended = true;
1287
+ for (var item in element.attributes) {
1288
+ if (/^_v-/.test(element.attributes[item].name)) {
1289
+ hash = element.attributes[item].name;
1290
+ break;
1291
+ }
1292
+ }
1293
+ var arrow = document.createElement('div');
1294
+ if (hash) {
1295
+ arrow.setAttribute(hash, '');
1296
+ }
1297
+ arrow.setAttribute('x-arrow', '');
1298
+ arrow.className = 'popper__arrow';
1299
+ element.appendChild(arrow);
1300
+ }
1301
+ },
1302
+ beforeDestroy: function beforeDestroy() {
1303
+ this.doDestroy(true);
1304
+ if (this.popperElm && this.popperElm.parentNode === document.body) {
1305
+ this.popperElm.removeEventListener('click', stop);
1306
+ document.body.removeChild(this.popperElm);
1307
+ }
1308
+ },
1309
+ // call destroy in keep-alive mode
1310
+ deactivated: function deactivated() {
1311
+ this.$options.beforeDestroy[0].call(this);
1312
+ }
1313
+ });
1314
+
1315
+ /***/ }),
1316
+
1317
+ /***/ 53:
1318
+ /***/ (function(module, exports) {
1319
+
1320
+ module.exports = require("core-js/modules/es.array.includes.js");
1321
+
1322
+ /***/ }),
1323
+
1324
+ /***/ 55:
1325
+ /***/ (function(module, exports) {
1326
+
1327
+ module.exports = require("core-js/modules/es.string.trim.js");
1328
+
1329
+ /***/ }),
1330
+
1331
+ /***/ 59:
1332
+ /***/ (function(module, exports) {
1333
+
1334
+ module.exports = require("core-js/modules/es.string.split.js");
1335
+
1336
+ /***/ }),
1337
+
1338
+ /***/ 6:
1339
+ /***/ (function(module, exports) {
1340
+
1341
+ module.exports = require("core-js/modules/es.number.constructor.js");
1342
+
1343
+ /***/ }),
1344
+
1345
+ /***/ 60:
1346
+ /***/ (function(module, exports) {
1347
+
1348
+ module.exports = require("core-js/modules/es.object.assign.js");
1349
+
1350
+ /***/ }),
1351
+
1352
+ /***/ 66:
1353
+ /***/ (function(module, exports) {
1354
+
1355
+ /* WEBPACK VAR INJECTION */(function(__webpack_amd_options__) {/* globals __webpack_amd_options__ */
1356
+ module.exports = __webpack_amd_options__;
1357
+
1358
+ /* WEBPACK VAR INJECTION */}.call(this, {}))
1359
+
1360
+ /***/ }),
1361
+
1362
+ /***/ 67:
1363
+ /***/ (function(module, exports) {
1364
+
1365
+ module.exports = function(originalModule) {
1366
+ if (!originalModule.webpackPolyfill) {
1367
+ var module = Object.create(originalModule);
1368
+ // module.parent = undefined by default
1369
+ if (!module.children) module.children = [];
1370
+ Object.defineProperty(module, "loaded", {
1371
+ enumerable: true,
1372
+ get: function() {
1373
+ return module.l;
1374
+ }
1375
+ });
1376
+ Object.defineProperty(module, "id", {
1377
+ enumerable: true,
1378
+ get: function() {
1379
+ return module.i;
1380
+ }
1381
+ });
1382
+ Object.defineProperty(module, "exports", {
1383
+ enumerable: true
1384
+ });
1385
+ module.webpackPolyfill = 1;
1386
+ }
1387
+ return module;
1388
+ };
1389
+
1390
+
1391
+ /***/ }),
1392
+
1393
+ /***/ 7:
1394
+ /***/ (function(module, exports) {
1395
+
1396
+ module.exports = require("core-js/modules/es.regexp.exec.js");
1397
+
1398
+ /***/ }),
1399
+
1400
+ /***/ 73:
1401
+ /***/ (function(module, __webpack_exports__, __webpack_require__) {
1402
+
1403
+ "use strict";
1404
+ __webpack_require__.r(__webpack_exports__);
1405
+ /* WEBPACK VAR INJECTION */(function(module) {/* harmony import */ var core_js_modules_es_array_filter_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(18);
1406
+ /* harmony import */ var core_js_modules_es_array_filter_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_array_filter_js__WEBPACK_IMPORTED_MODULE_0__);
1407
+ /* harmony import */ var core_js_modules_es_array_map_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(20);
1408
+ /* harmony import */ var core_js_modules_es_array_map_js__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_array_map_js__WEBPACK_IMPORTED_MODULE_1__);
1409
+ /* harmony import */ var core_js_modules_es_array_slice_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(13);
1410
+ /* harmony import */ var core_js_modules_es_array_slice_js__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_array_slice_js__WEBPACK_IMPORTED_MODULE_2__);
1411
+ /* harmony import */ var core_js_modules_es_object_assign_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(60);
1412
+ /* harmony import */ var core_js_modules_es_object_assign_js__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_object_assign_js__WEBPACK_IMPORTED_MODULE_3__);
1413
+ /* harmony import */ var core_js_modules_es_object_get_own_property_descriptor_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(74);
1414
+ /* harmony import */ var core_js_modules_es_object_get_own_property_descriptor_js__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_object_get_own_property_descriptor_js__WEBPACK_IMPORTED_MODULE_4__);
1415
+ /* harmony import */ var core_js_modules_es_object_keys_js__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(17);
1416
+ /* harmony import */ var core_js_modules_es_object_keys_js__WEBPACK_IMPORTED_MODULE_5___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_object_keys_js__WEBPACK_IMPORTED_MODULE_5__);
1417
+ /* harmony import */ var core_js_modules_es_object_to_string_js__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(3);
1418
+ /* harmony import */ var core_js_modules_es_object_to_string_js__WEBPACK_IMPORTED_MODULE_6___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_object_to_string_js__WEBPACK_IMPORTED_MODULE_6__);
1419
+ /* harmony import */ var core_js_modules_es_regexp_exec_js__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(7);
1420
+ /* harmony import */ var core_js_modules_es_regexp_exec_js__WEBPACK_IMPORTED_MODULE_7___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_regexp_exec_js__WEBPACK_IMPORTED_MODULE_7__);
1421
+ /* harmony import */ var core_js_modules_es_regexp_to_string_js__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(11);
1422
+ /* harmony import */ var core_js_modules_es_regexp_to_string_js__WEBPACK_IMPORTED_MODULE_8___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_regexp_to_string_js__WEBPACK_IMPORTED_MODULE_8__);
1423
+ /* harmony import */ var core_js_modules_es_string_replace_js__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(12);
1424
+ /* harmony import */ var core_js_modules_es_string_replace_js__WEBPACK_IMPORTED_MODULE_9___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_string_replace_js__WEBPACK_IMPORTED_MODULE_9__);
1425
+ /* harmony import */ var core_js_modules_web_dom_collections_for_each_js__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(10);
1426
+ /* harmony import */ var core_js_modules_web_dom_collections_for_each_js__WEBPACK_IMPORTED_MODULE_10___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_web_dom_collections_for_each_js__WEBPACK_IMPORTED_MODULE_10__);
1427
+
1428
+
1429
+
1430
+
1431
+
1432
+
1433
+
1434
+
1435
+
1436
+
1437
+
1438
+ /**
1439
+ * @fileOverview Kickass library to create and place poppers near their reference elements.
1440
+ * @version {{version}}
1441
+ * @license
1442
+ * Copyright (c) 2016 Federico Zivolo and contributors
1443
+ *
1444
+ * Permission is hereby granted, free of charge, to any person obtaining a copy
1445
+ * of this software and associated documentation files (the "Software"), to deal
1446
+ * in the Software without restriction, including without limitation the rights
1447
+ * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
1448
+ * copies of the Software, and to permit persons to whom the Software is
1449
+ * furnished to do so, subject to the following conditions:
1450
+ *
1451
+ * The above copyright notice and this permission notice shall be included in all
1452
+ * copies or substantial portions of the Software.
1453
+ *
1454
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
1455
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
1456
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
1457
+ * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
1458
+ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
1459
+ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
1460
+ * SOFTWARE.
1461
+ */
1462
+
1463
+ //
1464
+ // Cross module loader
1465
+ // Supported: Node, AMD, Browser globals
1466
+ //
1467
+ ;
1468
+ (function (root, factory) {
1469
+ if (typeof define === 'function' && __webpack_require__(66)) {
1470
+ // AMD. Register as an anonymous module.
1471
+ define(factory);
1472
+ } else if ( true && module.exports) {
1473
+ // Node. Does not work with strict CommonJS, but
1474
+ // only CommonJS-like environments that support module.exports,
1475
+ // like Node.
1476
+ module.exports = factory();
1477
+ } else {
1478
+ // Browser globals (root is window)
1479
+ root.Popper = factory();
1480
+ }
1481
+ })(undefined, function () {
1482
+ 'use strict';
1483
+
1484
+ var root = window;
1485
+
1486
+ // default options
1487
+ var DEFAULTS = {
1488
+ // placement of the popper
1489
+ placement: 'bottom',
1490
+ gpuAcceleration: true,
1491
+ // shift popper from its origin by the given amount of pixels (can be negative)
1492
+ offset: 0,
1493
+ // the element which will act as boundary of the popper
1494
+ boundariesElement: 'viewport',
1495
+ // amount of pixel used to define a minimum distance between the boundaries and the popper
1496
+ boundariesPadding: 5,
1497
+ // popper will try to prevent overflow following this order,
1498
+ // by default, then, it could overflow on the left and on top of the boundariesElement
1499
+ preventOverflowOrder: ['left', 'right', 'top', 'bottom'],
1500
+ // the behavior used by flip to change the placement of the popper
1501
+ flipBehavior: 'flip',
1502
+ arrowElement: '[x-arrow]',
1503
+ arrowOffset: 0,
1504
+ // list of functions used to modify the offsets before they are applied to the popper
1505
+ modifiers: ['shift', 'offset', 'preventOverflow', 'keepTogether', 'arrow', 'flip', 'applyStyle'],
1506
+ modifiersIgnored: [],
1507
+ forceAbsolute: false
1508
+ };
1509
+
1510
+ /**
1511
+ * Create a new Popper.js instance
1512
+ * @constructor Popper
1513
+ * @param {HTMLElement} reference - The reference element used to position the popper
1514
+ * @param {HTMLElement|Object} popper
1515
+ * The HTML element used as popper, or a configuration used to generate the popper.
1516
+ * @param {String} [popper.tagName='div'] The tag name of the generated popper.
1517
+ * @param {Array} [popper.classNames=['popper']] Array of classes to apply to the generated popper.
1518
+ * @param {Array} [popper.attributes] Array of attributes to apply, specify `attr:value` to assign a value to it.
1519
+ * @param {HTMLElement|String} [popper.parent=window.document.body] The parent element, given as HTMLElement or as query string.
1520
+ * @param {String} [popper.content=''] The content of the popper, it can be text, html, or node; if it is not text, set `contentType` to `html` or `node`.
1521
+ * @param {String} [popper.contentType='text'] If `html`, the `content` will be parsed as HTML. If `node`, it will be appended as-is.
1522
+ * @param {String} [popper.arrowTagName='div'] Same as `popper.tagName` but for the arrow element.
1523
+ * @param {Array} [popper.arrowClassNames='popper__arrow'] Same as `popper.classNames` but for the arrow element.
1524
+ * @param {String} [popper.arrowAttributes=['x-arrow']] Same as `popper.attributes` but for the arrow element.
1525
+ * @param {Object} options
1526
+ * @param {String} [options.placement=bottom]
1527
+ * Placement of the popper accepted values: `top(-start, -end), right(-start, -end), bottom(-start, -right),
1528
+ * left(-start, -end)`
1529
+ *
1530
+ * @param {HTMLElement|String} [options.arrowElement='[x-arrow]']
1531
+ * The DOM Node used as arrow for the popper, or a CSS selector used to get the DOM node. It must be child of
1532
+ * its parent Popper. Popper.js will apply to the given element the style required to align the arrow with its
1533
+ * reference element.
1534
+ * By default, it will look for a child node of the popper with the `x-arrow` attribute.
1535
+ *
1536
+ * @param {Boolean} [options.gpuAcceleration=true]
1537
+ * When this property is set to true, the popper position will be applied using CSS3 translate3d, allowing the
1538
+ * browser to use the GPU to accelerate the rendering.
1539
+ * If set to false, the popper will be placed using `top` and `left` properties, not using the GPU.
1540
+ *
1541
+ * @param {Number} [options.offset=0]
1542
+ * Amount of pixels the popper will be shifted (can be negative).
1543
+ *
1544
+ * @param {String|Element} [options.boundariesElement='viewport']
1545
+ * The element which will define the boundaries of the popper position, the popper will never be placed outside
1546
+ * of the defined boundaries (except if `keepTogether` is enabled)
1547
+ *
1548
+ * @param {Number} [options.boundariesPadding=5]
1549
+ * Additional padding for the boundaries
1550
+ *
1551
+ * @param {Array} [options.preventOverflowOrder=['left', 'right', 'top', 'bottom']]
1552
+ * Order used when Popper.js tries to avoid overflows from the boundaries, they will be checked in order,
1553
+ * this means that the last ones will never overflow
1554
+ *
1555
+ * @param {String|Array} [options.flipBehavior='flip']
1556
+ * The behavior used by the `flip` modifier to change the placement of the popper when the latter is trying to
1557
+ * overlap its reference element. Defining `flip` as value, the placement will be flipped on
1558
+ * its axis (`right - left`, `top - bottom`).
1559
+ * You can even pass an array of placements (eg: `['right', 'left', 'top']` ) to manually specify
1560
+ * how alter the placement when a flip is needed. (eg. in the above example, it would first flip from right to left,
1561
+ * then, if even in its new placement, the popper is overlapping its reference element, it will be moved to top)
1562
+ *
1563
+ * @param {Array} [options.modifiers=[ 'shift', 'offset', 'preventOverflow', 'keepTogether', 'arrow', 'flip', 'applyStyle']]
1564
+ * List of functions used to modify the data before they are applied to the popper, add your custom functions
1565
+ * to this array to edit the offsets and placement.
1566
+ * The function should reflect the @params and @returns of preventOverflow
1567
+ *
1568
+ * @param {Array} [options.modifiersIgnored=[]]
1569
+ * Put here any built-in modifier name you want to exclude from the modifiers list
1570
+ * The function should reflect the @params and @returns of preventOverflow
1571
+ *
1572
+ * @param {Boolean} [options.removeOnDestroy=false]
1573
+ * Set to true if you want to automatically remove the popper when you call the `destroy` method.
1574
+ */
1575
+ function Popper(reference, popper, options) {
1576
+ this._reference = reference.jquery ? reference[0] : reference;
1577
+ this.state = {};
1578
+
1579
+ // if the popper variable is a configuration object, parse it to generate an HTMLElement
1580
+ // generate a default popper if is not defined
1581
+ var isNotDefined = typeof popper === 'undefined' || popper === null;
1582
+ var isConfig = popper && Object.prototype.toString.call(popper) === '[object Object]';
1583
+ if (isNotDefined || isConfig) {
1584
+ this._popper = this.parse(isConfig ? popper : {});
1585
+ }
1586
+ // otherwise, use the given HTMLElement as popper
1587
+ else {
1588
+ this._popper = popper.jquery ? popper[0] : popper;
1589
+ }
1590
+
1591
+ // with {} we create a new object with the options inside it
1592
+ this._options = Object.assign({}, DEFAULTS, options);
1593
+
1594
+ // refactoring modifiers' list
1595
+ this._options.modifiers = this._options.modifiers.map(function (modifier) {
1596
+ // remove ignored modifiers
1597
+ if (this._options.modifiersIgnored.indexOf(modifier) !== -1) return;
1598
+
1599
+ // set the x-placement attribute before everything else because it could be used to add margins to the popper
1600
+ // margins needs to be calculated to get the correct popper offsets
1601
+ if (modifier === 'applyStyle') {
1602
+ this._popper.setAttribute('x-placement', this._options.placement);
1603
+ }
1604
+
1605
+ // return predefined modifier identified by string or keep the custom one
1606
+ return this.modifiers[modifier] || modifier;
1607
+ }.bind(this));
1608
+
1609
+ // make sure to apply the popper position before any computation
1610
+ this.state.position = this._getPosition(this._popper, this._reference);
1611
+ setStyle(this._popper, {
1612
+ position: this.state.position,
1613
+ top: 0
1614
+ });
1615
+
1616
+ // fire the first update to position the popper in the right place
1617
+ this.update();
1618
+
1619
+ // setup event listeners, they will take care of update the position in specific situations
1620
+ this._setupEventListeners();
1621
+ return this;
1622
+ }
1623
+
1624
+ //
1625
+ // Methods
1626
+ //
1627
+ /**
1628
+ * Destroy the popper
1629
+ * @method
1630
+ * @memberof Popper
1631
+ */
1632
+ Popper.prototype.destroy = function () {
1633
+ this._popper.removeAttribute('x-placement');
1634
+ this._popper.style.left = '';
1635
+ this._popper.style.position = '';
1636
+ this._popper.style.top = '';
1637
+ this._popper.style[getSupportedPropertyName('transform')] = '';
1638
+ this._removeEventListeners();
1639
+
1640
+ // remove the popper if user explicity asked for the deletion on destroy
1641
+ if (this._options.removeOnDestroy) {
1642
+ this._popper.remove();
1643
+ }
1644
+ return this;
1645
+ };
1646
+
1647
+ /**
1648
+ * Updates the position of the popper, computing the new offsets and applying the new style
1649
+ * @method
1650
+ * @memberof Popper
1651
+ */
1652
+ Popper.prototype.update = function () {
1653
+ var data = {
1654
+ instance: this,
1655
+ styles: {}
1656
+ };
1657
+
1658
+ // store placement inside the data object, modifiers will be able to edit `placement` if needed
1659
+ // and refer to _originalPlacement to know the original value
1660
+ data.placement = this._options.placement;
1661
+ data._originalPlacement = this._options.placement;
1662
+
1663
+ // compute the popper and reference offsets and put them inside data.offsets
1664
+ data.offsets = this._getOffsets(this._popper, this._reference, data.placement);
1665
+
1666
+ // get boundaries
1667
+ data.boundaries = this._getBoundaries(data, this._options.boundariesPadding, this._options.boundariesElement);
1668
+ data = this.runModifiers(data, this._options.modifiers);
1669
+ if (typeof this.state.updateCallback === 'function') {
1670
+ this.state.updateCallback(data);
1671
+ }
1672
+ };
1673
+
1674
+ /**
1675
+ * If a function is passed, it will be executed after the initialization of popper with as first argument the Popper instance.
1676
+ * @method
1677
+ * @memberof Popper
1678
+ * @param {Function} callback
1679
+ */
1680
+ Popper.prototype.onCreate = function (callback) {
1681
+ // the createCallbacks return as first argument the popper instance
1682
+ callback(this);
1683
+ return this;
1684
+ };
1685
+
1686
+ /**
1687
+ * If a function is passed, it will be executed after each update of popper with as first argument the set of coordinates and informations
1688
+ * used to style popper and its arrow.
1689
+ * NOTE: it doesn't get fired on the first call of the `Popper.update()` method inside the `Popper` constructor!
1690
+ * @method
1691
+ * @memberof Popper
1692
+ * @param {Function} callback
1693
+ */
1694
+ Popper.prototype.onUpdate = function (callback) {
1695
+ this.state.updateCallback = callback;
1696
+ return this;
1697
+ };
1698
+
1699
+ /**
1700
+ * Helper used to generate poppers from a configuration file
1701
+ * @method
1702
+ * @memberof Popper
1703
+ * @param config {Object} configuration
1704
+ * @returns {HTMLElement} popper
1705
+ */
1706
+ Popper.prototype.parse = function (config) {
1707
+ var defaultConfig = {
1708
+ tagName: 'div',
1709
+ classNames: ['popper'],
1710
+ attributes: [],
1711
+ parent: root.document.body,
1712
+ content: '',
1713
+ contentType: 'text',
1714
+ arrowTagName: 'div',
1715
+ arrowClassNames: ['popper__arrow'],
1716
+ arrowAttributes: ['x-arrow']
1717
+ };
1718
+ config = Object.assign({}, defaultConfig, config);
1719
+ var d = root.document;
1720
+ var popper = d.createElement(config.tagName);
1721
+ addClassNames(popper, config.classNames);
1722
+ addAttributes(popper, config.attributes);
1723
+ if (config.contentType === 'node') {
1724
+ popper.appendChild(config.content.jquery ? config.content[0] : config.content);
1725
+ } else if (config.contentType === 'html') {
1726
+ popper.innerHTML = config.content;
1727
+ } else {
1728
+ popper.textContent = config.content;
1729
+ }
1730
+ if (config.arrowTagName) {
1731
+ var arrow = d.createElement(config.arrowTagName);
1732
+ addClassNames(arrow, config.arrowClassNames);
1733
+ addAttributes(arrow, config.arrowAttributes);
1734
+ popper.appendChild(arrow);
1735
+ }
1736
+ var parent = config.parent.jquery ? config.parent[0] : config.parent;
1737
+
1738
+ // if the given parent is a string, use it to match an element
1739
+ // if more than one element is matched, the first one will be used as parent
1740
+ // if no elements are matched, the script will throw an error
1741
+ if (typeof parent === 'string') {
1742
+ parent = d.querySelectorAll(config.parent);
1743
+ if (parent.length > 1) {
1744
+ console.warn('WARNING: the given `parent` query(' + config.parent + ') matched more than one element, the first one will be used');
1745
+ }
1746
+ if (parent.length === 0) {
1747
+ throw 'ERROR: the given `parent` doesn\'t exists!';
1748
+ }
1749
+ parent = parent[0];
1750
+ }
1751
+ // if the given parent is a DOM nodes list or an array of nodes with more than one element,
1752
+ // the first one will be used as parent
1753
+ if (parent.length > 1 && parent instanceof Element === false) {
1754
+ console.warn('WARNING: you have passed as parent a list of elements, the first one will be used');
1755
+ parent = parent[0];
1756
+ }
1757
+
1758
+ // append the generated popper to its parent
1759
+ parent.appendChild(popper);
1760
+ return popper;
1761
+
1762
+ /**
1763
+ * Adds class names to the given element
1764
+ * @function
1765
+ * @ignore
1766
+ * @param {HTMLElement} target
1767
+ * @param {Array} classes
1768
+ */
1769
+ function addClassNames(element, classNames) {
1770
+ classNames.forEach(function (className) {
1771
+ element.classList.add(className);
1772
+ });
1773
+ }
1774
+
1775
+ /**
1776
+ * Adds attributes to the given element
1777
+ * @function
1778
+ * @ignore
1779
+ * @param {HTMLElement} target
1780
+ * @param {Array} attributes
1781
+ * @example
1782
+ * addAttributes(element, [ 'data-info:foobar' ]);
1783
+ */
1784
+ function addAttributes(element, attributes) {
1785
+ attributes.forEach(function (attribute) {
1786
+ element.setAttribute(attribute.split(':')[0], attribute.split(':')[1] || '');
1787
+ });
1788
+ }
1789
+ };
1790
+
1791
+ /**
1792
+ * Helper used to get the position which will be applied to the popper
1793
+ * @method
1794
+ * @memberof Popper
1795
+ * @param config {HTMLElement} popper element
1796
+ * @param reference {HTMLElement} reference element
1797
+ * @returns {String} position
1798
+ */
1799
+ Popper.prototype._getPosition = function (popper, reference) {
1800
+ var container = getOffsetParent(reference);
1801
+ if (this._options.forceAbsolute) {
1802
+ return 'absolute';
1803
+ }
1804
+
1805
+ // Decide if the popper will be fixed
1806
+ // If the reference element is inside a fixed context, the popper will be fixed as well to allow them to scroll together
1807
+ var isParentFixed = isFixed(reference, container);
1808
+ return isParentFixed ? 'fixed' : 'absolute';
1809
+ };
1810
+
1811
+ /**
1812
+ * Get offsets to the popper
1813
+ * @method
1814
+ * @memberof Popper
1815
+ * @access private
1816
+ * @param {Element} popper - the popper element
1817
+ * @param {Element} reference - the reference element (the popper will be relative to this)
1818
+ * @returns {Object} An object containing the offsets which will be applied to the popper
1819
+ */
1820
+ Popper.prototype._getOffsets = function (popper, reference, placement) {
1821
+ placement = placement.split('-')[0];
1822
+ var popperOffsets = {};
1823
+ popperOffsets.position = this.state.position;
1824
+ var isParentFixed = popperOffsets.position === 'fixed';
1825
+
1826
+ //
1827
+ // Get reference element position
1828
+ //
1829
+ var referenceOffsets = getOffsetRectRelativeToCustomParent(reference, getOffsetParent(popper), isParentFixed);
1830
+
1831
+ //
1832
+ // Get popper sizes
1833
+ //
1834
+ var popperRect = getOuterSizes(popper);
1835
+
1836
+ //
1837
+ // Compute offsets of popper
1838
+ //
1839
+
1840
+ // depending by the popper placement we have to compute its offsets slightly differently
1841
+ if (['right', 'left'].indexOf(placement) !== -1) {
1842
+ popperOffsets.top = referenceOffsets.top + referenceOffsets.height / 2 - popperRect.height / 2;
1843
+ if (placement === 'left') {
1844
+ popperOffsets.left = referenceOffsets.left - popperRect.width;
1845
+ } else {
1846
+ popperOffsets.left = referenceOffsets.right;
1847
+ }
1848
+ } else {
1849
+ popperOffsets.left = referenceOffsets.left + referenceOffsets.width / 2 - popperRect.width / 2;
1850
+ if (placement === 'top') {
1851
+ popperOffsets.top = referenceOffsets.top - popperRect.height;
1852
+ } else {
1853
+ popperOffsets.top = referenceOffsets.bottom;
1854
+ }
1855
+ }
1856
+
1857
+ // Add width and height to our offsets object
1858
+ popperOffsets.width = popperRect.width;
1859
+ popperOffsets.height = popperRect.height;
1860
+ return {
1861
+ popper: popperOffsets,
1862
+ reference: referenceOffsets
1863
+ };
1864
+ };
1865
+
1866
+ /**
1867
+ * Setup needed event listeners used to update the popper position
1868
+ * @method
1869
+ * @memberof Popper
1870
+ * @access private
1871
+ */
1872
+ Popper.prototype._setupEventListeners = function () {
1873
+ // NOTE: 1 DOM access here
1874
+ this.state.updateBound = this.update.bind(this);
1875
+ root.addEventListener('resize', this.state.updateBound);
1876
+ // if the boundariesElement is window we don't need to listen for the scroll event
1877
+ if (this._options.boundariesElement !== 'window') {
1878
+ var target = getScrollParent(this._reference);
1879
+ // here it could be both `body` or `documentElement` thanks to Firefox, we then check both
1880
+ if (target === root.document.body || target === root.document.documentElement) {
1881
+ target = root;
1882
+ }
1883
+ target.addEventListener('scroll', this.state.updateBound);
1884
+ this.state.scrollTarget = target;
1885
+ }
1886
+ };
1887
+
1888
+ /**
1889
+ * Remove event listeners used to update the popper position
1890
+ * @method
1891
+ * @memberof Popper
1892
+ * @access private
1893
+ */
1894
+ Popper.prototype._removeEventListeners = function () {
1895
+ // NOTE: 1 DOM access here
1896
+ root.removeEventListener('resize', this.state.updateBound);
1897
+ if (this._options.boundariesElement !== 'window' && this.state.scrollTarget) {
1898
+ this.state.scrollTarget.removeEventListener('scroll', this.state.updateBound);
1899
+ this.state.scrollTarget = null;
1900
+ }
1901
+ this.state.updateBound = null;
1902
+ };
1903
+
1904
+ /**
1905
+ * Computed the boundaries limits and return them
1906
+ * @method
1907
+ * @memberof Popper
1908
+ * @access private
1909
+ * @param {Object} data - Object containing the property "offsets" generated by `_getOffsets`
1910
+ * @param {Number} padding - Boundaries padding
1911
+ * @param {Element} boundariesElement - Element used to define the boundaries
1912
+ * @returns {Object} Coordinates of the boundaries
1913
+ */
1914
+ Popper.prototype._getBoundaries = function (data, padding, boundariesElement) {
1915
+ // NOTE: 1 DOM access here
1916
+ var boundaries = {};
1917
+ var width, height;
1918
+ if (boundariesElement === 'window') {
1919
+ var body = root.document.body,
1920
+ html = root.document.documentElement;
1921
+ height = Math.max(body.scrollHeight, body.offsetHeight, html.clientHeight, html.scrollHeight, html.offsetHeight);
1922
+ width = Math.max(body.scrollWidth, body.offsetWidth, html.clientWidth, html.scrollWidth, html.offsetWidth);
1923
+ boundaries = {
1924
+ top: 0,
1925
+ right: width,
1926
+ bottom: height,
1927
+ left: 0
1928
+ };
1929
+ } else if (boundariesElement === 'viewport') {
1930
+ var offsetParent = getOffsetParent(this._popper);
1931
+ var scrollParent = getScrollParent(this._popper);
1932
+ var offsetParentRect = getOffsetRect(offsetParent);
1933
+
1934
+ // Thanks the fucking native API, `document.body.scrollTop` & `document.documentElement.scrollTop`
1935
+ var getScrollTopValue = function getScrollTopValue(element) {
1936
+ return element == document.body ? Math.max(document.documentElement.scrollTop, document.body.scrollTop) : element.scrollTop;
1937
+ };
1938
+ var getScrollLeftValue = function getScrollLeftValue(element) {
1939
+ return element == document.body ? Math.max(document.documentElement.scrollLeft, document.body.scrollLeft) : element.scrollLeft;
1940
+ };
1941
+
1942
+ // if the popper is fixed we don't have to substract scrolling from the boundaries
1943
+ var scrollTop = data.offsets.popper.position === 'fixed' ? 0 : getScrollTopValue(scrollParent);
1944
+ var scrollLeft = data.offsets.popper.position === 'fixed' ? 0 : getScrollLeftValue(scrollParent);
1945
+ boundaries = {
1946
+ top: 0 - (offsetParentRect.top - scrollTop),
1947
+ right: root.document.documentElement.clientWidth - (offsetParentRect.left - scrollLeft),
1948
+ bottom: root.document.documentElement.clientHeight - (offsetParentRect.top - scrollTop),
1949
+ left: 0 - (offsetParentRect.left - scrollLeft)
1950
+ };
1951
+ } else {
1952
+ if (getOffsetParent(this._popper) === boundariesElement) {
1953
+ boundaries = {
1954
+ top: 0,
1955
+ left: 0,
1956
+ right: boundariesElement.clientWidth,
1957
+ bottom: boundariesElement.clientHeight
1958
+ };
1959
+ } else {
1960
+ boundaries = getOffsetRect(boundariesElement);
1961
+ }
1962
+ }
1963
+ boundaries.left += padding;
1964
+ boundaries.right -= padding;
1965
+ boundaries.top = boundaries.top + padding;
1966
+ boundaries.bottom = boundaries.bottom - padding;
1967
+ return boundaries;
1968
+ };
1969
+
1970
+ /**
1971
+ * Loop trough the list of modifiers and run them in order, each of them will then edit the data object
1972
+ * @method
1973
+ * @memberof Popper
1974
+ * @access public
1975
+ * @param {Object} data
1976
+ * @param {Array} modifiers
1977
+ * @param {Function} ends
1978
+ */
1979
+ Popper.prototype.runModifiers = function (data, modifiers, ends) {
1980
+ var modifiersToRun = modifiers.slice();
1981
+ if (ends !== undefined) {
1982
+ modifiersToRun = this._options.modifiers.slice(0, getArrayKeyIndex(this._options.modifiers, ends));
1983
+ }
1984
+ modifiersToRun.forEach(function (modifier) {
1985
+ if (isFunction(modifier)) {
1986
+ data = modifier.call(this, data);
1987
+ }
1988
+ }.bind(this));
1989
+ return data;
1990
+ };
1991
+
1992
+ /**
1993
+ * Helper used to know if the given modifier depends from another one.
1994
+ * @method
1995
+ * @memberof Popper
1996
+ * @param {String} requesting - name of requesting modifier
1997
+ * @param {String} requested - name of requested modifier
1998
+ * @returns {Boolean}
1999
+ */
2000
+ Popper.prototype.isModifierRequired = function (requesting, requested) {
2001
+ var index = getArrayKeyIndex(this._options.modifiers, requesting);
2002
+ return !!this._options.modifiers.slice(0, index).filter(function (modifier) {
2003
+ return modifier === requested;
2004
+ }).length;
2005
+ };
2006
+
2007
+ //
2008
+ // Modifiers
2009
+ //
2010
+
2011
+ /**
2012
+ * Modifiers list
2013
+ * @namespace Popper.modifiers
2014
+ * @memberof Popper
2015
+ * @type {Object}
2016
+ */
2017
+ Popper.prototype.modifiers = {};
2018
+
2019
+ /**
2020
+ * Apply the computed styles to the popper element
2021
+ * @method
2022
+ * @memberof Popper.modifiers
2023
+ * @argument {Object} data - The data object generated by `update` method
2024
+ * @returns {Object} The same data object
2025
+ */
2026
+ Popper.prototype.modifiers.applyStyle = function (data) {
2027
+ // apply the final offsets to the popper
2028
+ // NOTE: 1 DOM access here
2029
+ var styles = {
2030
+ position: data.offsets.popper.position
2031
+ };
2032
+
2033
+ // round top and left to avoid blurry text
2034
+ var left = Math.round(data.offsets.popper.left);
2035
+ var top = Math.round(data.offsets.popper.top);
2036
+
2037
+ // if gpuAcceleration is set to true and transform is supported, we use `translate3d` to apply the position to the popper
2038
+ // we automatically use the supported prefixed version if needed
2039
+ var prefixedProperty;
2040
+ if (this._options.gpuAcceleration && (prefixedProperty = getSupportedPropertyName('transform'))) {
2041
+ styles[prefixedProperty] = 'translate3d(' + left + 'px, ' + top + 'px, 0)';
2042
+ styles.top = 0;
2043
+ styles.left = 0;
2044
+ }
2045
+ // othwerise, we use the standard `left` and `top` properties
2046
+ else {
2047
+ styles.left = left;
2048
+ styles.top = top;
2049
+ }
2050
+
2051
+ // any property present in `data.styles` will be applied to the popper,
2052
+ // in this way we can make the 3rd party modifiers add custom styles to it
2053
+ // Be aware, modifiers could override the properties defined in the previous
2054
+ // lines of this modifier!
2055
+ Object.assign(styles, data.styles);
2056
+ setStyle(this._popper, styles);
2057
+
2058
+ // set an attribute which will be useful to style the tooltip (use it to properly position its arrow)
2059
+ // NOTE: 1 DOM access here
2060
+ this._popper.setAttribute('x-placement', data.placement);
2061
+
2062
+ // if the arrow modifier is required and the arrow style has been computed, apply the arrow style
2063
+ if (this.isModifierRequired(this.modifiers.applyStyle, this.modifiers.arrow) && data.offsets.arrow) {
2064
+ setStyle(data.arrowElement, data.offsets.arrow);
2065
+ }
2066
+ return data;
2067
+ };
2068
+
2069
+ /**
2070
+ * Modifier used to shift the popper on the start or end of its reference element side
2071
+ * @method
2072
+ * @memberof Popper.modifiers
2073
+ * @argument {Object} data - The data object generated by `update` method
2074
+ * @returns {Object} The data object, properly modified
2075
+ */
2076
+ Popper.prototype.modifiers.shift = function (data) {
2077
+ var placement = data.placement;
2078
+ var basePlacement = placement.split('-')[0];
2079
+ var shiftVariation = placement.split('-')[1];
2080
+
2081
+ // if shift shiftVariation is specified, run the modifier
2082
+ if (shiftVariation) {
2083
+ var reference = data.offsets.reference;
2084
+ var popper = getPopperClientRect(data.offsets.popper);
2085
+ var shiftOffsets = {
2086
+ y: {
2087
+ start: {
2088
+ top: reference.top
2089
+ },
2090
+ end: {
2091
+ top: reference.top + reference.height - popper.height
2092
+ }
2093
+ },
2094
+ x: {
2095
+ start: {
2096
+ left: reference.left
2097
+ },
2098
+ end: {
2099
+ left: reference.left + reference.width - popper.width
2100
+ }
2101
+ }
2102
+ };
2103
+ var axis = ['bottom', 'top'].indexOf(basePlacement) !== -1 ? 'x' : 'y';
2104
+ data.offsets.popper = Object.assign(popper, shiftOffsets[axis][shiftVariation]);
2105
+ }
2106
+ return data;
2107
+ };
2108
+
2109
+ /**
2110
+ * Modifier used to make sure the popper does not overflows from it's boundaries
2111
+ * @method
2112
+ * @memberof Popper.modifiers
2113
+ * @argument {Object} data - The data object generated by `update` method
2114
+ * @returns {Object} The data object, properly modified
2115
+ */
2116
+ Popper.prototype.modifiers.preventOverflow = function (data) {
2117
+ var order = this._options.preventOverflowOrder;
2118
+ var popper = getPopperClientRect(data.offsets.popper);
2119
+ var check = {
2120
+ left: function left() {
2121
+ var left = popper.left;
2122
+ if (popper.left < data.boundaries.left) {
2123
+ left = Math.max(popper.left, data.boundaries.left);
2124
+ }
2125
+ return {
2126
+ left: left
2127
+ };
2128
+ },
2129
+ right: function right() {
2130
+ var left = popper.left;
2131
+ if (popper.right > data.boundaries.right) {
2132
+ left = Math.min(popper.left, data.boundaries.right - popper.width);
2133
+ }
2134
+ return {
2135
+ left: left
2136
+ };
2137
+ },
2138
+ top: function top() {
2139
+ var top = popper.top;
2140
+ if (popper.top < data.boundaries.top) {
2141
+ top = Math.max(popper.top, data.boundaries.top);
2142
+ }
2143
+ return {
2144
+ top: top
2145
+ };
2146
+ },
2147
+ bottom: function bottom() {
2148
+ var top = popper.top;
2149
+ if (popper.bottom > data.boundaries.bottom) {
2150
+ top = Math.min(popper.top, data.boundaries.bottom - popper.height);
2151
+ }
2152
+ return {
2153
+ top: top
2154
+ };
2155
+ }
2156
+ };
2157
+ order.forEach(function (direction) {
2158
+ data.offsets.popper = Object.assign(popper, check[direction]());
2159
+ });
2160
+ return data;
2161
+ };
2162
+
2163
+ /**
2164
+ * Modifier used to make sure the popper is always near its reference
2165
+ * @method
2166
+ * @memberof Popper.modifiers
2167
+ * @argument {Object} data - The data object generated by _update method
2168
+ * @returns {Object} The data object, properly modified
2169
+ */
2170
+ Popper.prototype.modifiers.keepTogether = function (data) {
2171
+ var popper = getPopperClientRect(data.offsets.popper);
2172
+ var reference = data.offsets.reference;
2173
+ var f = Math.floor;
2174
+ if (popper.right < f(reference.left)) {
2175
+ data.offsets.popper.left = f(reference.left) - popper.width;
2176
+ }
2177
+ if (popper.left > f(reference.right)) {
2178
+ data.offsets.popper.left = f(reference.right);
2179
+ }
2180
+ if (popper.bottom < f(reference.top)) {
2181
+ data.offsets.popper.top = f(reference.top) - popper.height;
2182
+ }
2183
+ if (popper.top > f(reference.bottom)) {
2184
+ data.offsets.popper.top = f(reference.bottom);
2185
+ }
2186
+ return data;
2187
+ };
2188
+
2189
+ /**
2190
+ * Modifier used to flip the placement of the popper when the latter is starting overlapping its reference element.
2191
+ * Requires the `preventOverflow` modifier before it in order to work.
2192
+ * **NOTE:** This modifier will run all its previous modifiers everytime it tries to flip the popper!
2193
+ * @method
2194
+ * @memberof Popper.modifiers
2195
+ * @argument {Object} data - The data object generated by _update method
2196
+ * @returns {Object} The data object, properly modified
2197
+ */
2198
+ Popper.prototype.modifiers.flip = function (data) {
2199
+ // check if preventOverflow is in the list of modifiers before the flip modifier.
2200
+ // otherwise flip would not work as expected.
2201
+ if (!this.isModifierRequired(this.modifiers.flip, this.modifiers.preventOverflow)) {
2202
+ console.warn('WARNING: preventOverflow modifier is required by flip modifier in order to work, be sure to include it before flip!');
2203
+ return data;
2204
+ }
2205
+ if (data.flipped && data.placement === data._originalPlacement) {
2206
+ // seems like flip is trying to loop, probably there's not enough space on any of the flippable sides
2207
+ return data;
2208
+ }
2209
+ var placement = data.placement.split('-')[0];
2210
+ var placementOpposite = getOppositePlacement(placement);
2211
+ var variation = data.placement.split('-')[1] || '';
2212
+ var flipOrder = [];
2213
+ if (this._options.flipBehavior === 'flip') {
2214
+ flipOrder = [placement, placementOpposite];
2215
+ } else {
2216
+ flipOrder = this._options.flipBehavior;
2217
+ }
2218
+ flipOrder.forEach(function (step, index) {
2219
+ if (placement !== step || flipOrder.length === index + 1) {
2220
+ return;
2221
+ }
2222
+ placement = data.placement.split('-')[0];
2223
+ placementOpposite = getOppositePlacement(placement);
2224
+ var popperOffsets = getPopperClientRect(data.offsets.popper);
2225
+
2226
+ // this boolean is used to distinguish right and bottom from top and left
2227
+ // they need different computations to get flipped
2228
+ var a = ['right', 'bottom'].indexOf(placement) !== -1;
2229
+
2230
+ // using Math.floor because the reference offsets may contain decimals we are not going to consider here
2231
+ if (a && Math.floor(data.offsets.reference[placement]) > Math.floor(popperOffsets[placementOpposite]) || !a && Math.floor(data.offsets.reference[placement]) < Math.floor(popperOffsets[placementOpposite])) {
2232
+ // we'll use this boolean to detect any flip loop
2233
+ data.flipped = true;
2234
+ data.placement = flipOrder[index + 1];
2235
+ if (variation) {
2236
+ data.placement += '-' + variation;
2237
+ }
2238
+ data.offsets.popper = this._getOffsets(this._popper, this._reference, data.placement).popper;
2239
+ data = this.runModifiers(data, this._options.modifiers, this._flip);
2240
+ }
2241
+ }.bind(this));
2242
+ return data;
2243
+ };
2244
+
2245
+ /**
2246
+ * Modifier used to add an offset to the popper, useful if you more granularity positioning your popper.
2247
+ * The offsets will shift the popper on the side of its reference element.
2248
+ * @method
2249
+ * @memberof Popper.modifiers
2250
+ * @argument {Object} data - The data object generated by _update method
2251
+ * @returns {Object} The data object, properly modified
2252
+ */
2253
+ Popper.prototype.modifiers.offset = function (data) {
2254
+ var offset = this._options.offset;
2255
+ var popper = data.offsets.popper;
2256
+ if (data.placement.indexOf('left') !== -1) {
2257
+ popper.top -= offset;
2258
+ } else if (data.placement.indexOf('right') !== -1) {
2259
+ popper.top += offset;
2260
+ } else if (data.placement.indexOf('top') !== -1) {
2261
+ popper.left -= offset;
2262
+ } else if (data.placement.indexOf('bottom') !== -1) {
2263
+ popper.left += offset;
2264
+ }
2265
+ return data;
2266
+ };
2267
+
2268
+ /**
2269
+ * Modifier used to move the arrows on the edge of the popper to make sure them are always between the popper and the reference element
2270
+ * It will use the CSS outer size of the arrow element to know how many pixels of conjuction are needed
2271
+ * @method
2272
+ * @memberof Popper.modifiers
2273
+ * @argument {Object} data - The data object generated by _update method
2274
+ * @returns {Object} The data object, properly modified
2275
+ */
2276
+ Popper.prototype.modifiers.arrow = function (data) {
2277
+ var arrow = this._options.arrowElement;
2278
+ var arrowOffset = this._options.arrowOffset;
2279
+
2280
+ // if the arrowElement is a string, suppose it's a CSS selector
2281
+ if (typeof arrow === 'string') {
2282
+ arrow = this._popper.querySelector(arrow);
2283
+ }
2284
+
2285
+ // if arrow element is not found, don't run the modifier
2286
+ if (!arrow) {
2287
+ return data;
2288
+ }
2289
+
2290
+ // the arrow element must be child of its popper
2291
+ if (!this._popper.contains(arrow)) {
2292
+ console.warn('WARNING: `arrowElement` must be child of its popper element!');
2293
+ return data;
2294
+ }
2295
+
2296
+ // arrow depends on keepTogether in order to work
2297
+ if (!this.isModifierRequired(this.modifiers.arrow, this.modifiers.keepTogether)) {
2298
+ console.warn('WARNING: keepTogether modifier is required by arrow modifier in order to work, be sure to include it before arrow!');
2299
+ return data;
2300
+ }
2301
+ var arrowStyle = {};
2302
+ var placement = data.placement.split('-')[0];
2303
+ var popper = getPopperClientRect(data.offsets.popper);
2304
+ var reference = data.offsets.reference;
2305
+ var isVertical = ['left', 'right'].indexOf(placement) !== -1;
2306
+ var len = isVertical ? 'height' : 'width';
2307
+ var side = isVertical ? 'top' : 'left';
2308
+ var translate = isVertical ? 'translateY' : 'translateX';
2309
+ var altSide = isVertical ? 'left' : 'top';
2310
+ var opSide = isVertical ? 'bottom' : 'right';
2311
+ var arrowSize = getOuterSizes(arrow)[len];
2312
+
2313
+ //
2314
+ // extends keepTogether behavior making sure the popper and its reference have enough pixels in conjuction
2315
+ //
2316
+
2317
+ // top/left side
2318
+ if (reference[opSide] - arrowSize < popper[side]) {
2319
+ data.offsets.popper[side] -= popper[side] - (reference[opSide] - arrowSize);
2320
+ }
2321
+ // bottom/right side
2322
+ if (reference[side] + arrowSize > popper[opSide]) {
2323
+ data.offsets.popper[side] += reference[side] + arrowSize - popper[opSide];
2324
+ }
2325
+
2326
+ // compute center of the popper
2327
+ var center = reference[side] + (arrowOffset || reference[len] / 2 - arrowSize / 2);
2328
+ var sideValue = center - popper[side];
2329
+
2330
+ // prevent arrow from being placed not contiguously to its popper
2331
+ sideValue = Math.max(Math.min(popper[len] - arrowSize - 8, sideValue), 8);
2332
+ arrowStyle[side] = sideValue;
2333
+ arrowStyle[altSide] = ''; // make sure to remove any old style from the arrow
2334
+
2335
+ data.offsets.arrow = arrowStyle;
2336
+ data.arrowElement = arrow;
2337
+ return data;
2338
+ };
2339
+
2340
+ //
2341
+ // Helpers
2342
+ //
2343
+
2344
+ /**
2345
+ * Get the outer sizes of the given element (offset size + margins)
2346
+ * @function
2347
+ * @ignore
2348
+ * @argument {Element} element
2349
+ * @returns {Object} object containing width and height properties
2350
+ */
2351
+ function getOuterSizes(element) {
2352
+ // NOTE: 1 DOM access here
2353
+ var _display = element.style.display,
2354
+ _visibility = element.style.visibility;
2355
+ element.style.display = 'block';
2356
+ element.style.visibility = 'hidden';
2357
+ var calcWidthToForceRepaint = element.offsetWidth;
2358
+
2359
+ // original method
2360
+ var styles = root.getComputedStyle(element);
2361
+ var x = parseFloat(styles.marginTop) + parseFloat(styles.marginBottom);
2362
+ var y = parseFloat(styles.marginLeft) + parseFloat(styles.marginRight);
2363
+ var result = {
2364
+ width: element.offsetWidth + y,
2365
+ height: element.offsetHeight + x
2366
+ };
2367
+
2368
+ // reset element styles
2369
+ element.style.display = _display;
2370
+ element.style.visibility = _visibility;
2371
+ return result;
2372
+ }
2373
+
2374
+ /**
2375
+ * Get the opposite placement of the given one/
2376
+ * @function
2377
+ * @ignore
2378
+ * @argument {String} placement
2379
+ * @returns {String} flipped placement
2380
+ */
2381
+ function getOppositePlacement(placement) {
2382
+ var hash = {
2383
+ left: 'right',
2384
+ right: 'left',
2385
+ bottom: 'top',
2386
+ top: 'bottom'
2387
+ };
2388
+ return placement.replace(/left|right|bottom|top/g, function (matched) {
2389
+ return hash[matched];
2390
+ });
2391
+ }
2392
+
2393
+ /**
2394
+ * Given the popper offsets, generate an output similar to getBoundingClientRect
2395
+ * @function
2396
+ * @ignore
2397
+ * @argument {Object} popperOffsets
2398
+ * @returns {Object} ClientRect like output
2399
+ */
2400
+ function getPopperClientRect(popperOffsets) {
2401
+ var offsets = Object.assign({}, popperOffsets);
2402
+ offsets.right = offsets.left + offsets.width;
2403
+ offsets.bottom = offsets.top + offsets.height;
2404
+ return offsets;
2405
+ }
2406
+
2407
+ /**
2408
+ * Given an array and the key to find, returns its index
2409
+ * @function
2410
+ * @ignore
2411
+ * @argument {Array} arr
2412
+ * @argument keyToFind
2413
+ * @returns index or null
2414
+ */
2415
+ function getArrayKeyIndex(arr, keyToFind) {
2416
+ var i = 0,
2417
+ key;
2418
+ for (key in arr) {
2419
+ if (arr[key] === keyToFind) {
2420
+ return i;
2421
+ }
2422
+ i++;
2423
+ }
2424
+ return null;
2425
+ }
2426
+
2427
+ /**
2428
+ * Get CSS computed property of the given element
2429
+ * @function
2430
+ * @ignore
2431
+ * @argument {Eement} element
2432
+ * @argument {String} property
2433
+ */
2434
+ function getStyleComputedProperty(element, property) {
2435
+ // NOTE: 1 DOM access here
2436
+ var css = root.getComputedStyle(element, null);
2437
+ return css[property];
2438
+ }
2439
+
2440
+ /**
2441
+ * Returns the offset parent of the given element
2442
+ * @function
2443
+ * @ignore
2444
+ * @argument {Element} element
2445
+ * @returns {Element} offset parent
2446
+ */
2447
+ function getOffsetParent(element) {
2448
+ // NOTE: 1 DOM access here
2449
+ var offsetParent = element.offsetParent;
2450
+ return offsetParent === root.document.body || !offsetParent ? root.document.documentElement : offsetParent;
2451
+ }
2452
+
2453
+ /**
2454
+ * Returns the scrolling parent of the given element
2455
+ * @function
2456
+ * @ignore
2457
+ * @argument {Element} element
2458
+ * @returns {Element} offset parent
2459
+ */
2460
+ function getScrollParent(element) {
2461
+ var parent = element.parentNode;
2462
+ if (!parent) {
2463
+ return element;
2464
+ }
2465
+ if (parent === root.document) {
2466
+ // Firefox puts the scrollTOp value on `documentElement` instead of `body`, we then check which of them is
2467
+ // greater than 0 and return the proper element
2468
+ if (root.document.body.scrollTop || root.document.body.scrollLeft) {
2469
+ return root.document.body;
2470
+ } else {
2471
+ return root.document.documentElement;
2472
+ }
2473
+ }
2474
+
2475
+ // Firefox want us to check `-x` and `-y` variations as well
2476
+ if (['scroll', 'auto'].indexOf(getStyleComputedProperty(parent, 'overflow')) !== -1 || ['scroll', 'auto'].indexOf(getStyleComputedProperty(parent, 'overflow-x')) !== -1 || ['scroll', 'auto'].indexOf(getStyleComputedProperty(parent, 'overflow-y')) !== -1) {
2477
+ // If the detected scrollParent is body, we perform an additional check on its parentNode
2478
+ // in this way we'll get body if the browser is Chrome-ish, or documentElement otherwise
2479
+ // fixes issue #65
2480
+ return parent;
2481
+ }
2482
+ return getScrollParent(element.parentNode);
2483
+ }
2484
+
2485
+ /**
2486
+ * Check if the given element is fixed or is inside a fixed parent
2487
+ * @function
2488
+ * @ignore
2489
+ * @argument {Element} element
2490
+ * @argument {Element} customContainer
2491
+ * @returns {Boolean} answer to "isFixed?"
2492
+ */
2493
+ function isFixed(element) {
2494
+ if (element === root.document.body) {
2495
+ return false;
2496
+ }
2497
+ if (getStyleComputedProperty(element, 'position') === 'fixed') {
2498
+ return true;
2499
+ }
2500
+ return element.parentNode ? isFixed(element.parentNode) : element;
2501
+ }
2502
+
2503
+ /**
2504
+ * Set the style to the given popper
2505
+ * @function
2506
+ * @ignore
2507
+ * @argument {Element} element - Element to apply the style to
2508
+ * @argument {Object} styles - Object with a list of properties and values which will be applied to the element
2509
+ */
2510
+ function setStyle(element, styles) {
2511
+ function is_numeric(n) {
2512
+ return n !== '' && !isNaN(parseFloat(n)) && isFinite(n);
2513
+ }
2514
+ Object.keys(styles).forEach(function (prop) {
2515
+ var unit = '';
2516
+ // add unit if the value is numeric and is one of the following
2517
+ if (['width', 'height', 'top', 'right', 'bottom', 'left'].indexOf(prop) !== -1 && is_numeric(styles[prop])) {
2518
+ unit = 'px';
2519
+ }
2520
+ element.style[prop] = styles[prop] + unit;
2521
+ });
2522
+ }
2523
+
2524
+ /**
2525
+ * Check if the given variable is a function
2526
+ * @function
2527
+ * @ignore
2528
+ * @argument {*} functionToCheck - variable to check
2529
+ * @returns {Boolean} answer to: is a function?
2530
+ */
2531
+ function isFunction(functionToCheck) {
2532
+ var getType = {};
2533
+ return functionToCheck && getType.toString.call(functionToCheck) === '[object Function]';
2534
+ }
2535
+
2536
+ /**
2537
+ * Get the position of the given element, relative to its offset parent
2538
+ * @function
2539
+ * @ignore
2540
+ * @param {Element} element
2541
+ * @return {Object} position - Coordinates of the element and its `scrollTop`
2542
+ */
2543
+ function getOffsetRect(element) {
2544
+ var elementRect = {
2545
+ width: element.offsetWidth,
2546
+ height: element.offsetHeight,
2547
+ left: element.offsetLeft,
2548
+ top: element.offsetTop
2549
+ };
2550
+ elementRect.right = elementRect.left + elementRect.width;
2551
+ elementRect.bottom = elementRect.top + elementRect.height;
2552
+
2553
+ // position
2554
+ return elementRect;
2555
+ }
2556
+
2557
+ /**
2558
+ * Get bounding client rect of given element
2559
+ * @function
2560
+ * @ignore
2561
+ * @param {HTMLElement} element
2562
+ * @return {Object} client rect
2563
+ */
2564
+ function getBoundingClientRect(element) {
2565
+ var rect = element.getBoundingClientRect();
2566
+
2567
+ // whether the IE version is lower than 11
2568
+ var isIE = navigator.userAgent.indexOf("MSIE") != -1;
2569
+
2570
+ // fix ie document bounding top always 0 bug
2571
+ var rectTop = isIE && element.tagName === 'HTML' ? -element.scrollTop : rect.top;
2572
+ return {
2573
+ left: rect.left,
2574
+ top: rectTop,
2575
+ right: rect.right,
2576
+ bottom: rect.bottom,
2577
+ width: rect.right - rect.left,
2578
+ height: rect.bottom - rectTop
2579
+ };
2580
+ }
2581
+
2582
+ /**
2583
+ * Given an element and one of its parents, return the offset
2584
+ * @function
2585
+ * @ignore
2586
+ * @param {HTMLElement} element
2587
+ * @param {HTMLElement} parent
2588
+ * @return {Object} rect
2589
+ */
2590
+ function getOffsetRectRelativeToCustomParent(element, parent, fixed) {
2591
+ var elementRect = getBoundingClientRect(element);
2592
+ var parentRect = getBoundingClientRect(parent);
2593
+ if (fixed) {
2594
+ var scrollParent = getScrollParent(parent);
2595
+ parentRect.top += scrollParent.scrollTop;
2596
+ parentRect.bottom += scrollParent.scrollTop;
2597
+ parentRect.left += scrollParent.scrollLeft;
2598
+ parentRect.right += scrollParent.scrollLeft;
2599
+ }
2600
+ var rect = {
2601
+ top: elementRect.top - parentRect.top,
2602
+ left: elementRect.left - parentRect.left,
2603
+ bottom: elementRect.top - parentRect.top + elementRect.height,
2604
+ right: elementRect.left - parentRect.left + elementRect.width,
2605
+ width: elementRect.width,
2606
+ height: elementRect.height
2607
+ };
2608
+ return rect;
2609
+ }
2610
+
2611
+ /**
2612
+ * Get the prefixed supported property name
2613
+ * @function
2614
+ * @ignore
2615
+ * @argument {String} property (camelCase)
2616
+ * @returns {String} prefixed property (camelCase)
2617
+ */
2618
+ function getSupportedPropertyName(property) {
2619
+ var prefixes = ['', 'ms', 'webkit', 'moz', 'o'];
2620
+ for (var i = 0; i < prefixes.length; i++) {
2621
+ var toCheck = prefixes[i] ? prefixes[i] + property.charAt(0).toUpperCase() + property.slice(1) : property;
2622
+ if (typeof root.document.body.style[toCheck] !== 'undefined') {
2623
+ return toCheck;
2624
+ }
2625
+ }
2626
+ return null;
2627
+ }
2628
+
2629
+ /**
2630
+ * The Object.assign() method is used to copy the values of all enumerable own properties from one or more source
2631
+ * objects to a target object. It will return the target object.
2632
+ * This polyfill doesn't support symbol properties, since ES5 doesn't have symbols anyway
2633
+ * Source: https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Global_Objects/Object/assign
2634
+ * @function
2635
+ * @ignore
2636
+ */
2637
+ if (!Object.assign) {
2638
+ Object.defineProperty(Object, 'assign', {
2639
+ enumerable: false,
2640
+ configurable: true,
2641
+ writable: true,
2642
+ value: function value(target) {
2643
+ if (target === undefined || target === null) {
2644
+ throw new TypeError('Cannot convert first argument to object');
2645
+ }
2646
+ var to = Object(target);
2647
+ for (var i = 1; i < arguments.length; i++) {
2648
+ var nextSource = arguments[i];
2649
+ if (nextSource === undefined || nextSource === null) {
2650
+ continue;
2651
+ }
2652
+ nextSource = Object(nextSource);
2653
+ var keysArray = Object.keys(nextSource);
2654
+ for (var nextIndex = 0, len = keysArray.length; nextIndex < len; nextIndex++) {
2655
+ var nextKey = keysArray[nextIndex];
2656
+ var desc = Object.getOwnPropertyDescriptor(nextSource, nextKey);
2657
+ if (desc !== undefined && desc.enumerable) {
2658
+ to[nextKey] = nextSource[nextKey];
2659
+ }
2660
+ }
2661
+ }
2662
+ return to;
2663
+ }
2664
+ });
2665
+ }
2666
+ return Popper;
2667
+ });
2668
+ /* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(67)(module)))
2669
+
2670
+ /***/ }),
2671
+
2672
+ /***/ 74:
2673
+ /***/ (function(module, exports) {
2674
+
2675
+ module.exports = require("core-js/modules/es.object.get-own-property-descriptor.js");
348
2676
 
349
2677
  /***/ })
350
2678