cy-element-ui 1.0.87 → 1.1.1

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 (959) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +148 -172
  3. package/lib/index.js +1 -58539
  4. package/package.json +150 -159
  5. package/packages/alert/index.js +8 -8
  6. package/packages/alert/src/main.vue +94 -94
  7. package/packages/aside/index.js +8 -8
  8. package/packages/aside/src/main.vue +20 -20
  9. package/packages/autocomplete/index.js +8 -8
  10. package/packages/autocomplete/src/autocomplete-suggestions.vue +76 -76
  11. package/packages/autocomplete/src/autocomplete.vue +285 -285
  12. package/packages/avatar/index.js +8 -8
  13. package/packages/avatar/src/main.vue +107 -107
  14. package/packages/backtop/index.js +8 -8
  15. package/packages/backtop/src/main.vue +110 -110
  16. package/packages/badge/index.js +8 -8
  17. package/packages/badge/src/main.vue +53 -53
  18. package/packages/breadcrumb/index.js +8 -8
  19. package/packages/breadcrumb/src/breadcrumb-item.vue +41 -41
  20. package/packages/breadcrumb/src/breadcrumb.vue +34 -34
  21. package/packages/breadcrumb-item/index.js +8 -8
  22. package/packages/button/index.js +8 -8
  23. package/packages/button/src/button-group.vue +10 -10
  24. package/packages/button/src/button.vue +78 -78
  25. package/packages/button-group/index.js +8 -8
  26. package/packages/calendar/index.js +8 -8
  27. package/packages/calendar/src/date-table.vue +200 -200
  28. package/packages/calendar/src/main.vue +280 -280
  29. package/packages/card/index.js +8 -8
  30. package/packages/card/src/main.vue +23 -23
  31. package/packages/carousel/index.js +8 -8
  32. package/packages/carousel/src/item.vue +138 -138
  33. package/packages/carousel/src/main.vue +315 -315
  34. package/packages/carousel-item/index.js +8 -8
  35. package/packages/cascader/index.js +8 -8
  36. package/packages/cascader/src/cascader.vue +663 -663
  37. package/packages/cascader-panel/index.js +8 -8
  38. package/packages/cascader-panel/src/cascader-menu.vue +138 -138
  39. package/packages/cascader-panel/src/cascader-node.vue +246 -246
  40. package/packages/cascader-panel/src/cascader-panel.vue +391 -391
  41. package/packages/cascader-panel/src/node.js +166 -165
  42. package/packages/cascader-panel/src/store.js +58 -57
  43. package/packages/checkbox/index.js +8 -8
  44. package/packages/checkbox/src/checkbox-button.vue +199 -199
  45. package/packages/checkbox/src/checkbox-group.vue +48 -48
  46. package/packages/checkbox/src/checkbox.vue +222 -222
  47. package/packages/checkbox-button/index.js +8 -8
  48. package/packages/checkbox-group/index.js +8 -8
  49. package/packages/col/index.js +9 -9
  50. package/packages/col/src/col.js +71 -71
  51. package/packages/collapse/index.js +9 -9
  52. package/packages/collapse/src/collapse-item.vue +114 -114
  53. package/packages/collapse/src/collapse.vue +73 -73
  54. package/packages/collapse-item/index.js +8 -8
  55. package/packages/color-picker/index.js +8 -8
  56. package/packages/color-picker/src/color.js +317 -317
  57. package/packages/color-picker/src/components/alpha-slider.vue +132 -132
  58. package/packages/color-picker/src/components/hue-slider.vue +123 -123
  59. package/packages/color-picker/src/components/picker-dropdown.vue +121 -121
  60. package/packages/color-picker/src/components/predefine.vue +61 -61
  61. package/packages/color-picker/src/components/sv-panel.vue +100 -100
  62. package/packages/color-picker/src/draggable.js +36 -36
  63. package/packages/color-picker/src/main.vue +188 -188
  64. package/packages/container/index.js +8 -8
  65. package/packages/container/src/main.vue +33 -33
  66. package/packages/date-picker/index.js +8 -8
  67. package/packages/date-picker/src/basic/date-table.vue +441 -441
  68. package/packages/date-picker/src/basic/month-table.vue +269 -268
  69. package/packages/date-picker/src/basic/time-spinner.vue +304 -304
  70. package/packages/date-picker/src/basic/year-table.vue +111 -111
  71. package/packages/date-picker/src/panel/date-range.vue +680 -680
  72. package/packages/date-picker/src/panel/date.vue +609 -609
  73. package/packages/date-picker/src/panel/month-range.vue +289 -289
  74. package/packages/date-picker/src/panel/time-range.vue +248 -248
  75. package/packages/date-picker/src/panel/time-select.vue +178 -178
  76. package/packages/date-picker/src/panel/time.vue +186 -186
  77. package/packages/date-picker/src/picker/date-picker.js +43 -43
  78. package/packages/date-picker/src/picker/time-picker.js +39 -39
  79. package/packages/date-picker/src/picker/time-select.js +21 -21
  80. package/packages/date-picker/src/picker.vue +932 -390
  81. package/packages/descriptions/index.js +8 -8
  82. package/packages/descriptions/src/descriptions-item.js +30 -30
  83. package/packages/descriptions/src/descriptions-row.js +116 -116
  84. package/packages/descriptions/src/index.js +180 -180
  85. package/packages/descriptions-item/index.js +8 -8
  86. package/packages/dialog/index.js +8 -8
  87. package/packages/dialog/src/component.vue +212 -212
  88. package/packages/divider/index.js +8 -8
  89. package/packages/divider/src/main.vue +37 -37
  90. package/packages/drawer/index.js +8 -8
  91. package/packages/drawer/src/main.vue +205 -205
  92. package/packages/dropdown/index.js +8 -8
  93. package/packages/dropdown/src/dropdown-item.vue +37 -37
  94. package/packages/dropdown/src/dropdown-menu.vue +63 -63
  95. package/packages/dropdown/src/dropdown.vue +293 -293
  96. package/packages/dropdown-item/index.js +8 -8
  97. package/packages/dropdown-menu/index.js +8 -8
  98. package/packages/empty/index.js +7 -7
  99. package/packages/empty/src/img-empty.vue +132 -132
  100. package/packages/empty/src/index.vue +50 -50
  101. package/packages/footer/index.js +8 -8
  102. package/packages/footer/src/main.vue +20 -20
  103. package/packages/form/index.js +8 -8
  104. package/packages/form/src/form-item.vue +294 -334
  105. package/packages/form/src/form.vue +182 -182
  106. package/packages/form/src/label-wrap.vue +78 -0
  107. package/packages/form-item/index.js +8 -8
  108. package/packages/header/index.js +8 -8
  109. package/packages/header/src/main.vue +20 -20
  110. package/packages/icon/index.js +8 -8
  111. package/packages/icon/src/icon.vue +13 -13
  112. package/packages/image/index.js +8 -8
  113. package/packages/image/src/image-viewer.vue +330 -330
  114. package/packages/image/src/main.vue +249 -249
  115. package/packages/infinite-scroll/index.js +8 -8
  116. package/packages/infinite-scroll/src/main.js +150 -149
  117. package/packages/input/index.js +8 -8
  118. package/packages/input/src/calcTextareaHeight.js +104 -104
  119. package/packages/input/src/input.vue +440 -440
  120. package/packages/input-number/index.js +8 -8
  121. package/packages/input-number/src/input-number.vue +286 -286
  122. package/packages/link/index.js +8 -8
  123. package/packages/link/src/main.vue +53 -53
  124. package/packages/loading/index.js +11 -11
  125. package/packages/loading/src/directive.js +133 -133
  126. package/packages/loading/src/index.js +106 -106
  127. package/packages/loading/src/loading.vue +41 -41
  128. package/packages/main/index.js +8 -8
  129. package/packages/main/src/main.vue +12 -12
  130. package/packages/menu/index.js +8 -8
  131. package/packages/menu/src/menu-item-group.vue +45 -45
  132. package/packages/menu/src/menu-item.vue +112 -112
  133. package/packages/menu/src/menu-mixin.js +44 -44
  134. package/packages/menu/src/menu.vue +325 -325
  135. package/packages/menu/src/submenu.vue +349 -348
  136. package/packages/menu-item/index.js +8 -8
  137. package/packages/menu-item-group/index.js +8 -8
  138. package/packages/message/index.js +2 -2
  139. package/packages/message/src/main.js +91 -91
  140. package/packages/message/src/main.vue +117 -117
  141. package/packages/message-box/index.js +2 -2
  142. package/packages/message-box/src/main.js +216 -216
  143. package/packages/message-box/src/main.vue +332 -332
  144. package/packages/notification/index.js +2 -2
  145. package/packages/notification/src/main.js +94 -94
  146. package/packages/notification/src/main.vue +152 -152
  147. package/packages/option/index.js +8 -8
  148. package/packages/option-group/index.js +8 -8
  149. package/packages/page-header/index.js +8 -8
  150. package/packages/page-header/src/main.vue +30 -30
  151. package/packages/pagination/index.js +8 -8
  152. package/packages/pagination/src/pager.vue +163 -163
  153. package/packages/pagination/src/pagination.js +386 -386
  154. package/packages/popconfirm/index.js +8 -8
  155. package/packages/popconfirm/src/main.vue +104 -104
  156. package/packages/popover/index.js +14 -14
  157. package/packages/popover/src/directive.js +20 -20
  158. package/packages/popover/src/main.vue +237 -237
  159. package/packages/progress/index.js +8 -8
  160. package/packages/progress/src/progress.vue +235 -235
  161. package/packages/radio/index.js +8 -8
  162. package/packages/radio/src/radio-button.vue +115 -115
  163. package/packages/radio/src/radio-group.vue +113 -113
  164. package/packages/radio/src/radio.vue +134 -134
  165. package/packages/radio-button/index.js +8 -8
  166. package/packages/radio-group/index.js +8 -8
  167. package/packages/rate/index.js +8 -8
  168. package/packages/rate/src/main.vue +348 -348
  169. package/packages/result/index.js +8 -8
  170. package/packages/result/src/icon-error.vue +13 -13
  171. package/packages/result/src/icon-info.vue +13 -13
  172. package/packages/result/src/icon-success.vue +13 -13
  173. package/packages/result/src/icon-warning.vue +13 -13
  174. package/packages/result/src/index.vue +65 -65
  175. package/packages/row/index.js +9 -9
  176. package/packages/row/src/row.js +44 -44
  177. package/packages/scrollbar/index.js +8 -8
  178. package/packages/scrollbar/src/bar.js +92 -92
  179. package/packages/scrollbar/src/main.js +130 -130
  180. package/packages/scrollbar/src/util.js +34 -34
  181. package/packages/select/index.js +8 -8
  182. package/packages/select/src/navigation-mixin.js +54 -54
  183. package/packages/select/src/option-group.vue +60 -60
  184. package/packages/select/src/option.vue +168 -168
  185. package/packages/select/src/select-dropdown.vue +74 -74
  186. package/packages/select/src/select.vue +900 -900
  187. package/packages/skeleton/index.js +8 -8
  188. package/packages/skeleton/src/img-placeholder.vue +16 -16
  189. package/packages/skeleton/src/index.vue +76 -76
  190. package/packages/skeleton/src/item.vue +22 -22
  191. package/packages/skeleton-item/index.js +8 -8
  192. package/packages/slider/index.js +8 -8
  193. package/packages/slider/src/button.vue +238 -238
  194. package/packages/slider/src/main.vue +427 -427
  195. package/packages/slider/src/marker.js +18 -18
  196. package/packages/spinner/index.js +8 -8
  197. package/packages/spinner/src/spinner.vue +27 -27
  198. package/packages/statistic/index.js +8 -8
  199. package/packages/statistic/src/main.vue +204 -203
  200. package/packages/step/index.js +8 -8
  201. package/packages/steps/README.md +69 -69
  202. package/packages/steps/index.js +8 -8
  203. package/packages/steps/src/step.vue +184 -184
  204. package/packages/steps/src/steps.vue +68 -68
  205. package/packages/submenu/index.js +8 -8
  206. package/packages/switch/index.js +9 -9
  207. package/packages/switch/src/component.vue +174 -174
  208. package/packages/tab-pane/index.js +8 -8
  209. package/packages/table/index.js +8 -8
  210. package/packages/table/src/config.js +124 -124
  211. package/packages/table/src/dropdown.js +28 -28
  212. package/packages/table/src/filter-panel.vue +194 -194
  213. package/packages/table/src/layout-observer.js +68 -68
  214. package/packages/table/src/store/current.js +76 -76
  215. package/packages/table/src/store/expand.js +65 -65
  216. package/packages/table/src/store/helper.js +41 -41
  217. package/packages/table/src/store/index.js +147 -147
  218. package/packages/table/src/store/tree.js +209 -209
  219. package/packages/table/src/store/watcher.js +381 -381
  220. package/packages/table/src/table-body.js +469 -469
  221. package/packages/table/src/table-column.js +319 -319
  222. package/packages/table/src/table-footer.js +153 -153
  223. package/packages/table/src/table-header.js +511 -511
  224. package/packages/table/src/table-layout.js +249 -249
  225. package/packages/table/src/table-row.js +101 -101
  226. package/packages/table/src/table.vue +712 -718
  227. package/packages/table/src/util.js +273 -273
  228. package/packages/table-column/index.js +8 -8
  229. package/packages/tabs/index.js +8 -8
  230. package/packages/tabs/src/tab-bar.vue +57 -57
  231. package/packages/tabs/src/tab-nav.vue +294 -294
  232. package/packages/tabs/src/tab-pane.vue +56 -56
  233. package/packages/tabs/src/tabs.vue +191 -191
  234. package/packages/tag/index.js +8 -8
  235. package/packages/tag/src/tag.vue +58 -58
  236. package/packages/theme-chalk/README.md +33 -33
  237. package/packages/theme-chalk/gulpfile.js +25 -27
  238. package/packages/theme-chalk/package.json +35 -35
  239. package/packages/theme-chalk/src/alert.scss +147 -147
  240. package/packages/theme-chalk/src/aside.scss +7 -7
  241. package/packages/theme-chalk/src/autocomplete.scss +80 -80
  242. package/packages/theme-chalk/src/avatar.scss +51 -51
  243. package/packages/theme-chalk/src/backtop.scss +22 -22
  244. package/packages/theme-chalk/src/badge.scss +57 -57
  245. package/packages/theme-chalk/src/base.scss +2 -2
  246. package/packages/theme-chalk/src/breadcrumb.scss +55 -55
  247. package/packages/theme-chalk/src/button.scss +262 -262
  248. package/packages/theme-chalk/src/calendar.scss +79 -79
  249. package/packages/theme-chalk/src/card.scss +32 -32
  250. package/packages/theme-chalk/src/carousel-item.scss +50 -50
  251. package/packages/theme-chalk/src/carousel.scss +161 -161
  252. package/packages/theme-chalk/src/cascader-panel.scss +120 -120
  253. package/packages/theme-chalk/src/cascader.scss +182 -182
  254. package/packages/theme-chalk/src/checkbox.scss +359 -359
  255. package/packages/theme-chalk/src/col.scss +156 -156
  256. package/packages/theme-chalk/src/collapse.scss +63 -63
  257. package/packages/theme-chalk/src/color-picker.scss +384 -384
  258. package/packages/theme-chalk/src/common/popup.scss +42 -42
  259. package/packages/theme-chalk/src/common/transition.scss +99 -99
  260. package/packages/theme-chalk/src/common/var.scss +1028 -1028
  261. package/packages/theme-chalk/src/container.scss +14 -14
  262. package/packages/theme-chalk/src/date-picker/date-picker.scss +97 -97
  263. package/packages/theme-chalk/src/date-picker/date-range-picker.scss +101 -101
  264. package/packages/theme-chalk/src/date-picker/date-table.scss +151 -151
  265. package/packages/theme-chalk/src/date-picker/month-table.scss +82 -82
  266. package/packages/theme-chalk/src/date-picker/picker-panel.scss +117 -117
  267. package/packages/theme-chalk/src/date-picker/picker.scss +197 -197
  268. package/packages/theme-chalk/src/date-picker/time-picker.scss +85 -85
  269. package/packages/theme-chalk/src/date-picker/time-range-picker.scss +31 -31
  270. package/packages/theme-chalk/src/date-picker/time-spinner.scss +110 -110
  271. package/packages/theme-chalk/src/date-picker/year-table.scss +51 -51
  272. package/packages/theme-chalk/src/date-picker.scss +11 -11
  273. package/packages/theme-chalk/src/descriptions-item.scss +42 -42
  274. package/packages/theme-chalk/src/descriptions.scss +111 -111
  275. package/packages/theme-chalk/src/dialog.scss +123 -123
  276. package/packages/theme-chalk/src/display.scss +12 -12
  277. package/packages/theme-chalk/src/divider.scss +47 -47
  278. package/packages/theme-chalk/src/drawer.scss +219 -219
  279. package/packages/theme-chalk/src/dropdown.scss +182 -182
  280. package/packages/theme-chalk/src/empty.scss +45 -45
  281. package/packages/theme-chalk/src/footer.scss +8 -8
  282. package/packages/theme-chalk/src/form.scss +167 -167
  283. package/packages/theme-chalk/src/header.scss +8 -8
  284. package/packages/theme-chalk/src/icon.scss +1167 -1167
  285. package/packages/theme-chalk/src/image.scss +179 -179
  286. package/packages/theme-chalk/src/index.scss +87 -87
  287. package/packages/theme-chalk/src/input-number.scss +261 -180
  288. package/packages/theme-chalk/src/input.scss +360 -360
  289. package/packages/theme-chalk/src/link.scss +81 -81
  290. package/packages/theme-chalk/src/loading.scss +96 -96
  291. package/packages/theme-chalk/src/main.scss +12 -12
  292. package/packages/theme-chalk/src/menu.scss +289 -289
  293. package/packages/theme-chalk/src/message-box.scss +226 -226
  294. package/packages/theme-chalk/src/message.scss +120 -120
  295. package/packages/theme-chalk/src/mixins/_button.scss +81 -81
  296. package/packages/theme-chalk/src/mixins/config.scss +4 -4
  297. package/packages/theme-chalk/src/mixins/function.scss +44 -44
  298. package/packages/theme-chalk/src/mixins/mixins.scss +191 -196
  299. package/packages/theme-chalk/src/mixins/utils.scss +39 -39
  300. package/packages/theme-chalk/src/notification.scss +99 -99
  301. package/packages/theme-chalk/src/option-group.scss +42 -42
  302. package/packages/theme-chalk/src/option.scss +36 -36
  303. package/packages/theme-chalk/src/page-header.scss +41 -41
  304. package/packages/theme-chalk/src/pagination.scss +295 -295
  305. package/packages/theme-chalk/src/popconfirm.scss +16 -16
  306. package/packages/theme-chalk/src/popover.scss +40 -40
  307. package/packages/theme-chalk/src/popper.scss +101 -101
  308. package/packages/theme-chalk/src/progress.scss +141 -141
  309. package/packages/theme-chalk/src/radio-button.scss +113 -113
  310. package/packages/theme-chalk/src/radio-group.scss +9 -9
  311. package/packages/theme-chalk/src/radio.scss +199 -199
  312. package/packages/theme-chalk/src/rate.scss +49 -49
  313. package/packages/theme-chalk/src/reset.scss +79 -79
  314. package/packages/theme-chalk/src/result.scss +61 -61
  315. package/packages/theme-chalk/src/row.scss +43 -43
  316. package/packages/theme-chalk/src/scrollbar.scss +72 -72
  317. package/packages/theme-chalk/src/select-dropdown.scss +62 -62
  318. package/packages/theme-chalk/src/select.scss +152 -152
  319. package/packages/theme-chalk/src/skeleton-item.scss +84 -84
  320. package/packages/theme-chalk/src/skeleton.scss +40 -40
  321. package/packages/theme-chalk/src/slider.scss +250 -250
  322. package/packages/theme-chalk/src/spinner.scss +44 -44
  323. package/packages/theme-chalk/src/statistic.scss +38 -38
  324. package/packages/theme-chalk/src/step.scss +317 -317
  325. package/packages/theme-chalk/src/steps.scss +20 -20
  326. package/packages/theme-chalk/src/switch.scss +116 -116
  327. package/packages/theme-chalk/src/table-column.scss +97 -97
  328. package/packages/theme-chalk/src/table.scss +564 -564
  329. package/packages/theme-chalk/src/tabs.scss +602 -602
  330. package/packages/theme-chalk/src/tag.scss +163 -163
  331. package/packages/theme-chalk/src/time-picker.scss +8 -8
  332. package/packages/theme-chalk/src/time-select.scss +37 -37
  333. package/packages/theme-chalk/src/timeline-item.scss +86 -86
  334. package/packages/theme-chalk/src/timeline.scss +14 -14
  335. package/packages/theme-chalk/src/tooltip.scss +141 -141
  336. package/packages/theme-chalk/src/transfer.scss +227 -227
  337. package/packages/theme-chalk/src/tree.scss +123 -123
  338. package/packages/theme-chalk/src/upload.scss +603 -603
  339. package/packages/time-picker/index.js +8 -8
  340. package/packages/time-select/index.js +8 -8
  341. package/packages/timeline/index.js +8 -8
  342. package/packages/timeline/src/item.vue +73 -73
  343. package/packages/timeline/src/main.vue +33 -33
  344. package/packages/timeline-item/index.js +8 -8
  345. package/packages/tooltip/index.js +8 -8
  346. package/packages/tooltip/src/main.js +242 -242
  347. package/packages/transfer/index.js +8 -8
  348. package/packages/transfer/src/main.vue +231 -231
  349. package/packages/transfer/src/transfer-panel.vue +251 -251
  350. package/packages/tree/index.js +8 -8
  351. package/packages/tree/src/model/node.js +484 -484
  352. package/packages/tree/src/model/tree-store.js +340 -340
  353. package/packages/tree/src/model/util.js +27 -27
  354. package/packages/tree/src/tree-node.vue +279 -279
  355. package/packages/tree/src/tree.vue +496 -496
  356. package/packages/upload/index.js +8 -8
  357. package/packages/upload/src/ajax.js +85 -85
  358. package/packages/upload/src/index.vue +338 -338
  359. package/packages/upload/src/upload-dragger.vue +70 -70
  360. package/packages/upload/src/upload-list.vue +105 -105
  361. package/packages/upload/src/upload.vue +211 -211
  362. package/src/directives/mousewheel.js +18 -18
  363. package/src/directives/repeat-click.js +26 -26
  364. package/src/index.js +202 -216
  365. package/src/locale/format.js +46 -45
  366. package/src/locale/index.js +48 -48
  367. package/src/locale/lang/en.js +123 -123
  368. package/src/locale/lang/zh-CN.js +123 -123
  369. package/src/locale/lang/zh-TW.js +123 -123
  370. package/src/mixins/emitter.js +33 -33
  371. package/src/mixins/focus.js +9 -9
  372. package/src/mixins/locale.js +9 -9
  373. package/src/mixins/migrating.js +54 -54
  374. package/src/transitions/collapse-transition.js +77 -77
  375. package/src/utils/after-leave.js +27 -27
  376. package/src/utils/aria-dialog.js +90 -90
  377. package/src/utils/aria-utils.js +122 -122
  378. package/src/utils/clickoutside.js +76 -76
  379. package/src/utils/date-util.js +282 -282
  380. package/src/utils/date.js +368 -368
  381. package/src/utils/dom.js +227 -227
  382. package/src/utils/lodash.js +18075 -18075
  383. package/src/utils/menu/aria-menubar.js +14 -14
  384. package/src/utils/menu/aria-menuitem.js +49 -49
  385. package/src/utils/menu/aria-submenu.js +59 -59
  386. package/src/utils/merge.js +15 -15
  387. package/src/utils/popper.js +1276 -1276
  388. package/src/utils/popup/index.js +218 -218
  389. package/src/utils/popup/popup-manager.js +194 -194
  390. package/src/utils/resize-event.js +36 -36
  391. package/src/utils/scroll-into-view.js +27 -27
  392. package/src/utils/scrollbar-width.js +29 -29
  393. package/src/utils/shared.js +7 -7
  394. package/src/utils/types.js +40 -40
  395. package/src/utils/util.js +245 -245
  396. package/src/utils/vdom.js +5 -5
  397. package/src/utils/vue-popper.js +198 -198
  398. package/types/alert.d.ts +31 -31
  399. package/types/aside.d.ts +7 -7
  400. package/types/autocomplete.d.ts +78 -78
  401. package/types/avatar.d.ts +20 -20
  402. package/types/backtop.d.ts +16 -16
  403. package/types/badge.d.ts +16 -16
  404. package/types/breadcrumb-item.d.ts +10 -10
  405. package/types/breadcrumb.d.ts +10 -10
  406. package/types/button-group.d.ts +4 -4
  407. package/types/button.d.ts +37 -37
  408. package/types/calendar.d.ts +15 -15
  409. package/types/card.d.ts +26 -26
  410. package/types/carousel-item.d.ts +10 -10
  411. package/types/carousel.d.ts +57 -57
  412. package/types/cascader-panel.d.ts +72 -72
  413. package/types/cascader.d.ts +65 -65
  414. package/types/checkbox-button.d.ts +22 -22
  415. package/types/checkbox-group.d.ts +22 -22
  416. package/types/checkbox.d.ts +34 -34
  417. package/types/col.d.ts +46 -46
  418. package/types/collapse-item.d.ts +26 -26
  419. package/types/collapse.d.ts +10 -10
  420. package/types/color-picker.d.ts +21 -21
  421. package/types/component.d.ts +13 -13
  422. package/types/container.d.ts +7 -7
  423. package/types/date-picker.d.ts +124 -124
  424. package/types/descriptions-item.d.ts +37 -37
  425. package/types/descriptions.d.ts +52 -52
  426. package/types/dialog.d.ts +62 -62
  427. package/types/divider.d.ts +12 -12
  428. package/types/drawer.d.ts +63 -63
  429. package/types/dropdown-item.d.ts +16 -16
  430. package/types/dropdown-menu.d.ts +4 -4
  431. package/types/dropdown.d.ts +38 -38
  432. package/types/element-ui.d.ts +1 -22
  433. package/types/empty.d.ts +31 -31
  434. package/types/footer.d.ts +7 -7
  435. package/types/form-item.d.ts +37 -37
  436. package/types/form.d.ts +82 -82
  437. package/types/header.d.ts +7 -7
  438. package/types/icon.d.ts +7 -7
  439. package/types/image.d.ts +43 -43
  440. package/types/index.d.ts +4 -4
  441. package/types/infinite-scroll.d.ts +5 -5
  442. package/types/input-number.d.ts +47 -47
  443. package/types/input.d.ts +107 -107
  444. package/types/link.d.ts +25 -25
  445. package/types/loading.d.ts +62 -62
  446. package/types/main.d.ts +4 -4
  447. package/types/menu-item-group.d.ts +7 -7
  448. package/types/menu-item.d.ts +10 -10
  449. package/types/menu.d.ts +46 -46
  450. package/types/message-box.d.ts +176 -176
  451. package/types/message.d.ts +90 -90
  452. package/types/notification.d.ts +84 -84
  453. package/types/option-group.d.ts +10 -10
  454. package/types/option.d.ts +13 -13
  455. package/types/page-header.d.ts +10 -10
  456. package/types/pagination.d.ts +43 -43
  457. package/types/popconfirm.d.ts +29 -29
  458. package/types/popover.d.ts +71 -71
  459. package/types/progress.d.ts +37 -37
  460. package/types/radio-button.d.ts +16 -16
  461. package/types/radio-group.d.ts +18 -18
  462. package/types/radio.d.ts +19 -19
  463. package/types/rate.d.ts +64 -64
  464. package/types/result.d.ts +33 -33
  465. package/types/row.d.ts +25 -25
  466. package/types/select.d.ts +90 -90
  467. package/types/skeleton-item.d.ts +7 -7
  468. package/types/skeleton.d.ts +33 -33
  469. package/types/slider.d.ts +68 -68
  470. package/types/spinner.d.ts +16 -16
  471. package/types/statistic.d.ts +37 -37
  472. package/types/step.d.ts +34 -34
  473. package/types/steps.d.ts +28 -28
  474. package/types/submenu.d.ts +22 -22
  475. package/types/switch.d.ts +43 -43
  476. package/types/tab-pane.d.ts +19 -19
  477. package/types/table-column.d.ts +117 -117
  478. package/types/table.d.ts +177 -177
  479. package/types/tabs.d.ts +31 -31
  480. package/types/tag.d.ts +28 -28
  481. package/types/time-picker.d.ts +63 -63
  482. package/types/time-select.d.ts +56 -56
  483. package/types/timeline-item.d.ts +20 -20
  484. package/types/timeline.d.ts +6 -6
  485. package/types/tooltip.d.ts +52 -52
  486. package/types/transfer.d.ts +73 -73
  487. package/types/tree.d.ts +266 -266
  488. package/types/upload.d.ts +124 -124
  489. package/web-types.json +4195 -4195
  490. package/lib/alert.js +0 -402
  491. package/lib/aside.js +0 -270
  492. package/lib/autocomplete.js +0 -4651
  493. package/lib/avatar.js +0 -363
  494. package/lib/backtop.js +0 -386
  495. package/lib/badge.js +0 -313
  496. package/lib/breadcrumb-item.js +0 -309
  497. package/lib/breadcrumb.js +0 -287
  498. package/lib/button-group.js +0 -256
  499. package/lib/button.js +0 -332
  500. package/lib/calendar.js +0 -2373
  501. package/lib/card.js +0 -289
  502. package/lib/carousel-item.js +0 -755
  503. package/lib/carousel.js +0 -719
  504. package/lib/cascader-panel.js +0 -3623
  505. package/lib/cascader.js +0 -7498
  506. package/lib/checkbox-button.js +0 -573
  507. package/lib/checkbox-group.js +0 -344
  508. package/lib/checkbox.js +0 -603
  509. package/lib/col.js +0 -177
  510. package/lib/collapse-item.js +0 -1156
  511. package/lib/collapse.js +0 -323
  512. package/lib/color-picker.js +0 -5600
  513. package/lib/container.js +0 -281
  514. package/lib/date-picker.js +0 -9871
  515. package/lib/descriptions-item.js +0 -140
  516. package/lib/descriptions.js +0 -512
  517. package/lib/dialog.js +0 -1736
  518. package/lib/directives/mousewheel.js +0 -26
  519. package/lib/directives/repeat-click.js +0 -33
  520. package/lib/divider.js +0 -297
  521. package/lib/drawer.js +0 -1316
  522. package/lib/dropdown-item.js +0 -332
  523. package/lib/dropdown-menu.js +0 -2545
  524. package/lib/dropdown.js +0 -1579
  525. package/lib/element-ui.common.js +0 -54072
  526. package/lib/empty.js +0 -1186
  527. package/lib/fileUpload.js +0 -3276
  528. package/lib/footer.js +0 -270
  529. package/lib/form-item.js +0 -1129
  530. package/lib/form.js +0 -471
  531. package/lib/header.js +0 -270
  532. package/lib/icon.js +0 -260
  533. package/lib/image.js +0 -2386
  534. package/lib/infinite-scroll.js +0 -591
  535. package/lib/input-number.js +0 -2093
  536. package/lib/input.js +0 -1358
  537. package/lib/link.js +0 -308
  538. package/lib/loading.js +0 -1349
  539. package/lib/locale/format.js +0 -55
  540. package/lib/locale/index.js +0 -63
  541. package/lib/locale/lang/af-ZA.js +0 -126
  542. package/lib/locale/lang/ar.js +0 -125
  543. package/lib/locale/lang/az.js +0 -126
  544. package/lib/locale/lang/bg.js +0 -126
  545. package/lib/locale/lang/bn.js +0 -126
  546. package/lib/locale/lang/ca.js +0 -125
  547. package/lib/locale/lang/cs-CZ.js +0 -128
  548. package/lib/locale/lang/da.js +0 -125
  549. package/lib/locale/lang/de.js +0 -127
  550. package/lib/locale/lang/ee.js +0 -126
  551. package/lib/locale/lang/el.js +0 -126
  552. package/lib/locale/lang/en.js +0 -126
  553. package/lib/locale/lang/eo.js +0 -126
  554. package/lib/locale/lang/es.js +0 -125
  555. package/lib/locale/lang/eu.js +0 -126
  556. package/lib/locale/lang/fa.js +0 -126
  557. package/lib/locale/lang/fi.js +0 -126
  558. package/lib/locale/lang/fr.js +0 -125
  559. package/lib/locale/lang/he.js +0 -126
  560. package/lib/locale/lang/hr.js +0 -126
  561. package/lib/locale/lang/hu.js +0 -125
  562. package/lib/locale/lang/hy-AM.js +0 -126
  563. package/lib/locale/lang/id.js +0 -126
  564. package/lib/locale/lang/is.js +0 -126
  565. package/lib/locale/lang/it.js +0 -125
  566. package/lib/locale/lang/ja.js +0 -126
  567. package/lib/locale/lang/kg.js +0 -126
  568. package/lib/locale/lang/km.js +0 -126
  569. package/lib/locale/lang/ko.js +0 -126
  570. package/lib/locale/lang/ku.js +0 -126
  571. package/lib/locale/lang/kz.js +0 -126
  572. package/lib/locale/lang/lo-LA.js +0 -126
  573. package/lib/locale/lang/lt.js +0 -126
  574. package/lib/locale/lang/lv.js +0 -126
  575. package/lib/locale/lang/mn.js +0 -126
  576. package/lib/locale/lang/ms.js +0 -125
  577. package/lib/locale/lang/nb-NO.js +0 -125
  578. package/lib/locale/lang/nl.js +0 -126
  579. package/lib/locale/lang/pl.js +0 -126
  580. package/lib/locale/lang/pt-br.js +0 -126
  581. package/lib/locale/lang/pt.js +0 -126
  582. package/lib/locale/lang/ro.js +0 -126
  583. package/lib/locale/lang/ru-RU.js +0 -126
  584. package/lib/locale/lang/si.js +0 -126
  585. package/lib/locale/lang/sk.js +0 -128
  586. package/lib/locale/lang/sl.js +0 -126
  587. package/lib/locale/lang/sr-Latn.js +0 -126
  588. package/lib/locale/lang/sr.js +0 -126
  589. package/lib/locale/lang/sv-SE.js +0 -126
  590. package/lib/locale/lang/sw.js +0 -126
  591. package/lib/locale/lang/ta.js +0 -125
  592. package/lib/locale/lang/th.js +0 -126
  593. package/lib/locale/lang/tk.js +0 -126
  594. package/lib/locale/lang/tr-TR.js +0 -126
  595. package/lib/locale/lang/ua.js +0 -126
  596. package/lib/locale/lang/ug-CN.js +0 -126
  597. package/lib/locale/lang/uz-UZ.js +0 -126
  598. package/lib/locale/lang/vi.js +0 -126
  599. package/lib/locale/lang/zh-CN.js +0 -126
  600. package/lib/locale/lang/zh-TW.js +0 -126
  601. package/lib/main.js +0 -257
  602. package/lib/menu-item-group.js +0 -296
  603. package/lib/menu-item.js +0 -3344
  604. package/lib/menu.js +0 -1556
  605. package/lib/message-box.js +0 -3564
  606. package/lib/message.js +0 -1601
  607. package/lib/mixins/emitter.js +0 -36
  608. package/lib/mixins/focus.js +0 -15
  609. package/lib/mixins/locale.js +0 -17
  610. package/lib/mixins/migrating.js +0 -69
  611. package/lib/notification.js +0 -1662
  612. package/lib/option-group.js +0 -364
  613. package/lib/option.js +0 -835
  614. package/lib/page-header.js +0 -908
  615. package/lib/pagination.js +0 -6855
  616. package/lib/popconfirm.js +0 -3708
  617. package/lib/popover.js +0 -3118
  618. package/lib/progress.js +0 -542
  619. package/lib/radio-button.js +0 -456
  620. package/lib/radio-group.js +0 -412
  621. package/lib/radio.js +0 -482
  622. package/lib/rate.js +0 -1278
  623. package/lib/result.js +0 -528
  624. package/lib/row.js +0 -149
  625. package/lib/scrollbar.js +0 -1108
  626. package/lib/select.js +0 -6134
  627. package/lib/selectDisplayInput.js +0 -355
  628. package/lib/skeleton-item.js +0 -322
  629. package/lib/skeleton.js +0 -345
  630. package/lib/slider.js +0 -5231
  631. package/lib/spinner.js +0 -293
  632. package/lib/statistic.js +0 -9999
  633. package/lib/step.js +0 -476
  634. package/lib/steps.js +0 -745
  635. package/lib/subTitle.js +0 -284
  636. package/lib/submenu.js +0 -3021
  637. package/lib/switch.js +0 -970
  638. package/lib/tab-pane.js +0 -318
  639. package/lib/tabDialog.js +0 -2264
  640. package/lib/table-column.js +0 -1800
  641. package/lib/table.js +0 -8803
  642. package/lib/tabs.js +0 -1329
  643. package/lib/tag.js +0 -304
  644. package/lib/theme-chalk/README.md +0 -33
  645. package/lib/theme-chalk/base.css +0 -1
  646. package/lib/theme-chalk/element.css +0 -1
  647. package/lib/theme-chalk/fileUpload.css +0 -1
  648. package/lib/theme-chalk/fonts/element-icons.ttf +0 -0
  649. package/lib/theme-chalk/fonts/element-icons.woff +0 -0
  650. package/lib/theme-chalk/gulpfile.js +0 -27
  651. package/lib/theme-chalk/index.css +0 -1
  652. package/lib/theme-chalk/package.json +0 -35
  653. package/lib/theme-chalk/selectDisplayInput.css +0 -1
  654. package/lib/theme-chalk/src/alert.scss +0 -147
  655. package/lib/theme-chalk/src/aside.scss +0 -7
  656. package/lib/theme-chalk/src/autocomplete.scss +0 -80
  657. package/lib/theme-chalk/src/avatar.scss +0 -51
  658. package/lib/theme-chalk/src/backtop.scss +0 -22
  659. package/lib/theme-chalk/src/badge.scss +0 -57
  660. package/lib/theme-chalk/src/base.scss +0 -2
  661. package/lib/theme-chalk/src/breadcrumb-item.scss +0 -0
  662. package/lib/theme-chalk/src/breadcrumb.scss +0 -55
  663. package/lib/theme-chalk/src/button-group.scss +0 -0
  664. package/lib/theme-chalk/src/button.scss +0 -262
  665. package/lib/theme-chalk/src/calendar.scss +0 -79
  666. package/lib/theme-chalk/src/card.scss +0 -32
  667. package/lib/theme-chalk/src/carousel-item.scss +0 -50
  668. package/lib/theme-chalk/src/carousel.scss +0 -161
  669. package/lib/theme-chalk/src/cascader-panel.scss +0 -120
  670. package/lib/theme-chalk/src/cascader.scss +0 -182
  671. package/lib/theme-chalk/src/checkbox-button.scss +0 -0
  672. package/lib/theme-chalk/src/checkbox-group.scss +0 -0
  673. package/lib/theme-chalk/src/checkbox.scss +0 -359
  674. package/lib/theme-chalk/src/col.scss +0 -156
  675. package/lib/theme-chalk/src/collapse-item.scss +0 -0
  676. package/lib/theme-chalk/src/collapse.scss +0 -63
  677. package/lib/theme-chalk/src/color-picker.scss +0 -384
  678. package/lib/theme-chalk/src/common/popup.scss +0 -42
  679. package/lib/theme-chalk/src/common/transition.scss +0 -99
  680. package/lib/theme-chalk/src/common/var.scss +0 -1028
  681. package/lib/theme-chalk/src/container.scss +0 -14
  682. package/lib/theme-chalk/src/date-picker/date-picker.scss +0 -97
  683. package/lib/theme-chalk/src/date-picker/date-range-picker.scss +0 -101
  684. package/lib/theme-chalk/src/date-picker/date-table.scss +0 -151
  685. package/lib/theme-chalk/src/date-picker/month-table.scss +0 -82
  686. package/lib/theme-chalk/src/date-picker/picker-panel.scss +0 -117
  687. package/lib/theme-chalk/src/date-picker/picker.scss +0 -197
  688. package/lib/theme-chalk/src/date-picker/time-picker.scss +0 -85
  689. package/lib/theme-chalk/src/date-picker/time-range-picker.scss +0 -31
  690. package/lib/theme-chalk/src/date-picker/time-spinner.scss +0 -110
  691. package/lib/theme-chalk/src/date-picker/year-table.scss +0 -51
  692. package/lib/theme-chalk/src/date-picker.scss +0 -12
  693. package/lib/theme-chalk/src/descriptions-item.scss +0 -42
  694. package/lib/theme-chalk/src/descriptions.scss +0 -111
  695. package/lib/theme-chalk/src/dialog.scss +0 -123
  696. package/lib/theme-chalk/src/display.scss +0 -12
  697. package/lib/theme-chalk/src/divider.scss +0 -47
  698. package/lib/theme-chalk/src/drawer.scss +0 -219
  699. package/lib/theme-chalk/src/dropdown-item.scss +0 -0
  700. package/lib/theme-chalk/src/dropdown-menu.scss +0 -0
  701. package/lib/theme-chalk/src/dropdown.scss +0 -182
  702. package/lib/theme-chalk/src/empty.scss +0 -45
  703. package/lib/theme-chalk/src/fonts/element-icons.ttf +0 -0
  704. package/lib/theme-chalk/src/fonts/element-icons.woff +0 -0
  705. package/lib/theme-chalk/src/footer.scss +0 -8
  706. package/lib/theme-chalk/src/form-item.scss +0 -0
  707. package/lib/theme-chalk/src/form.scss +0 -167
  708. package/lib/theme-chalk/src/header.scss +0 -8
  709. package/lib/theme-chalk/src/icon.scss +0 -1167
  710. package/lib/theme-chalk/src/image.scss +0 -179
  711. package/lib/theme-chalk/src/index.scss +0 -87
  712. package/lib/theme-chalk/src/infinite-scroll.scss +0 -0
  713. package/lib/theme-chalk/src/infiniteScroll.scss +0 -0
  714. package/lib/theme-chalk/src/input-number.scss +0 -180
  715. package/lib/theme-chalk/src/input.scss +0 -360
  716. package/lib/theme-chalk/src/link.scss +0 -81
  717. package/lib/theme-chalk/src/loading.scss +0 -96
  718. package/lib/theme-chalk/src/main.scss +0 -12
  719. package/lib/theme-chalk/src/menu-item-group.scss +0 -0
  720. package/lib/theme-chalk/src/menu-item.scss +0 -0
  721. package/lib/theme-chalk/src/menu.scss +0 -289
  722. package/lib/theme-chalk/src/message-box.scss +0 -226
  723. package/lib/theme-chalk/src/message.scss +0 -120
  724. package/lib/theme-chalk/src/mixins/_button.scss +0 -81
  725. package/lib/theme-chalk/src/mixins/config.scss +0 -4
  726. package/lib/theme-chalk/src/mixins/function.scss +0 -44
  727. package/lib/theme-chalk/src/mixins/mixins.scss +0 -196
  728. package/lib/theme-chalk/src/mixins/utils.scss +0 -39
  729. package/lib/theme-chalk/src/notification.scss +0 -99
  730. package/lib/theme-chalk/src/option-group.scss +0 -42
  731. package/lib/theme-chalk/src/option.scss +0 -36
  732. package/lib/theme-chalk/src/page-header.scss +0 -41
  733. package/lib/theme-chalk/src/pagination.scss +0 -295
  734. package/lib/theme-chalk/src/popconfirm.scss +0 -16
  735. package/lib/theme-chalk/src/popover.scss +0 -40
  736. package/lib/theme-chalk/src/popper.scss +0 -101
  737. package/lib/theme-chalk/src/progress.scss +0 -141
  738. package/lib/theme-chalk/src/radio-button.scss +0 -113
  739. package/lib/theme-chalk/src/radio-group.scss +0 -9
  740. package/lib/theme-chalk/src/radio.scss +0 -199
  741. package/lib/theme-chalk/src/rate.scss +0 -49
  742. package/lib/theme-chalk/src/reset.scss +0 -79
  743. package/lib/theme-chalk/src/result.scss +0 -61
  744. package/lib/theme-chalk/src/row.scss +0 -43
  745. package/lib/theme-chalk/src/scrollbar.scss +0 -72
  746. package/lib/theme-chalk/src/select-dropdown.scss +0 -62
  747. package/lib/theme-chalk/src/select.scss +0 -152
  748. package/lib/theme-chalk/src/skeleton-item.scss +0 -84
  749. package/lib/theme-chalk/src/skeleton.scss +0 -40
  750. package/lib/theme-chalk/src/slider.scss +0 -250
  751. package/lib/theme-chalk/src/spinner.scss +0 -44
  752. package/lib/theme-chalk/src/statistic.scss +0 -38
  753. package/lib/theme-chalk/src/step.scss +0 -317
  754. package/lib/theme-chalk/src/steps.scss +0 -20
  755. package/lib/theme-chalk/src/submenu.scss +0 -0
  756. package/lib/theme-chalk/src/switch.scss +0 -116
  757. package/lib/theme-chalk/src/tab-pane.scss +0 -0
  758. package/lib/theme-chalk/src/table-column.scss +0 -97
  759. package/lib/theme-chalk/src/table.scss +0 -564
  760. package/lib/theme-chalk/src/tabs.scss +0 -602
  761. package/lib/theme-chalk/src/tag.scss +0 -163
  762. package/lib/theme-chalk/src/time-picker.scss +0 -8
  763. package/lib/theme-chalk/src/time-select.scss +0 -37
  764. package/lib/theme-chalk/src/timeline-item.scss +0 -86
  765. package/lib/theme-chalk/src/timeline.scss +0 -14
  766. package/lib/theme-chalk/src/tooltip.scss +0 -141
  767. package/lib/theme-chalk/src/transfer.scss +0 -227
  768. package/lib/theme-chalk/src/tree.scss +0 -123
  769. package/lib/theme-chalk/src/upload.scss +0 -603
  770. package/lib/theme-chalk/subTitle.css +0 -1
  771. package/lib/theme-chalk/tabDialog.css +0 -1
  772. package/lib/theme-chalk/treeSelect.css +0 -1
  773. package/lib/theme-cy/base.css +0 -1
  774. package/lib/theme-cy/element.css +0 -1
  775. package/lib/theme-cy/fileUpload.css +0 -1
  776. package/lib/theme-cy/index.css +0 -1
  777. package/lib/theme-cy/selectDisplayInput.css +0 -1
  778. package/lib/theme-cy/subTitle.css +0 -1
  779. package/lib/theme-cy/tabDialog.css +0 -1
  780. package/lib/theme-cy/treeSelect.css +0 -1
  781. package/lib/time-picker.js +0 -6881
  782. package/lib/time-select.js +0 -5892
  783. package/lib/timeline-item.js +0 -329
  784. package/lib/timeline.js +0 -275
  785. package/lib/tooltip.js +0 -2950
  786. package/lib/transfer.js +0 -2998
  787. package/lib/transitions/collapse-transition.js +0 -91
  788. package/lib/tree.js +0 -3470
  789. package/lib/treeSelect.js +0 -4058
  790. package/lib/umd/locale/af-ZA.js +0 -142
  791. package/lib/umd/locale/ar.js +0 -141
  792. package/lib/umd/locale/az.js +0 -141
  793. package/lib/umd/locale/bg.js +0 -142
  794. package/lib/umd/locale/bn.js +0 -141
  795. package/lib/umd/locale/ca.js +0 -141
  796. package/lib/umd/locale/cs-CZ.js +0 -144
  797. package/lib/umd/locale/da.js +0 -141
  798. package/lib/umd/locale/de.js +0 -143
  799. package/lib/umd/locale/ee.js +0 -142
  800. package/lib/umd/locale/el.js +0 -142
  801. package/lib/umd/locale/en.js +0 -142
  802. package/lib/umd/locale/eo.js +0 -142
  803. package/lib/umd/locale/es.js +0 -141
  804. package/lib/umd/locale/eu.js +0 -142
  805. package/lib/umd/locale/fa.js +0 -142
  806. package/lib/umd/locale/fi.js +0 -142
  807. package/lib/umd/locale/fr.js +0 -141
  808. package/lib/umd/locale/he.js +0 -142
  809. package/lib/umd/locale/hr.js +0 -142
  810. package/lib/umd/locale/hu.js +0 -141
  811. package/lib/umd/locale/hy-AM.js +0 -142
  812. package/lib/umd/locale/id.js +0 -142
  813. package/lib/umd/locale/is.js +0 -142
  814. package/lib/umd/locale/it.js +0 -141
  815. package/lib/umd/locale/ja.js +0 -142
  816. package/lib/umd/locale/kg.js +0 -142
  817. package/lib/umd/locale/km.js +0 -142
  818. package/lib/umd/locale/ko.js +0 -142
  819. package/lib/umd/locale/ku.js +0 -142
  820. package/lib/umd/locale/kz.js +0 -142
  821. package/lib/umd/locale/lo-LA.js +0 -141
  822. package/lib/umd/locale/lt.js +0 -142
  823. package/lib/umd/locale/lv.js +0 -142
  824. package/lib/umd/locale/mn.js +0 -142
  825. package/lib/umd/locale/ms.js +0 -141
  826. package/lib/umd/locale/nb-NO.js +0 -141
  827. package/lib/umd/locale/nl.js +0 -142
  828. package/lib/umd/locale/pl.js +0 -142
  829. package/lib/umd/locale/pt-br.js +0 -142
  830. package/lib/umd/locale/pt.js +0 -142
  831. package/lib/umd/locale/ro.js +0 -142
  832. package/lib/umd/locale/ru-RU.js +0 -142
  833. package/lib/umd/locale/si.js +0 -142
  834. package/lib/umd/locale/sk.js +0 -144
  835. package/lib/umd/locale/sl.js +0 -142
  836. package/lib/umd/locale/sr-Latn.js +0 -142
  837. package/lib/umd/locale/sr.js +0 -142
  838. package/lib/umd/locale/sv-SE.js +0 -142
  839. package/lib/umd/locale/sw.js +0 -142
  840. package/lib/umd/locale/ta.js +0 -141
  841. package/lib/umd/locale/th.js +0 -142
  842. package/lib/umd/locale/tk.js +0 -142
  843. package/lib/umd/locale/tr-TR.js +0 -142
  844. package/lib/umd/locale/ua.js +0 -142
  845. package/lib/umd/locale/ug-CN.js +0 -142
  846. package/lib/umd/locale/uz-UZ.js +0 -142
  847. package/lib/umd/locale/vi.js +0 -142
  848. package/lib/umd/locale/zh-CN.js +0 -142
  849. package/lib/umd/locale/zh-TW.js +0 -142
  850. package/lib/upload.js +0 -2337
  851. package/lib/utils/after-leave.js +0 -35
  852. package/lib/utils/aria-dialog.js +0 -104
  853. package/lib/utils/aria-utils.js +0 -126
  854. package/lib/utils/clickoutside.js +0 -79
  855. package/lib/utils/date-util.js +0 -310
  856. package/lib/utils/date.js +0 -369
  857. package/lib/utils/dom.js +0 -234
  858. package/lib/utils/lodash.js +0 -9421
  859. package/lib/utils/menu/aria-menubar.js +0 -24
  860. package/lib/utils/menu/aria-menuitem.js +0 -62
  861. package/lib/utils/menu/aria-submenu.js +0 -69
  862. package/lib/utils/merge.js +0 -21
  863. package/lib/utils/popper.js +0 -1261
  864. package/lib/utils/popup/index.js +0 -233
  865. package/lib/utils/popup/popup-manager.js +0 -205
  866. package/lib/utils/resize-event.js +0 -59
  867. package/lib/utils/scroll-into-view.js +0 -38
  868. package/lib/utils/scrollbar-width.js +0 -39
  869. package/lib/utils/shared.js +0 -12
  870. package/lib/utils/types.js +0 -52
  871. package/lib/utils/util.js +0 -272
  872. package/lib/utils/vdom.js +0 -13
  873. package/lib/utils/vue-popper.js +0 -202
  874. package/packages/fileUpload/index.js +0 -8
  875. package/packages/fileUpload/src/main.vue +0 -430
  876. package/packages/selectDisplayInput/index.js +0 -8
  877. package/packages/selectDisplayInput/src/main.vue +0 -75
  878. package/packages/subTitle/index.js +0 -8
  879. package/packages/subTitle/src/main.vue +0 -33
  880. package/packages/tabDialog/index.js +0 -23
  881. package/packages/tabDialog/src/dialog/drag.js +0 -63
  882. package/packages/tabDialog/src/dialog/dragHeight.js +0 -34
  883. package/packages/tabDialog/src/dialog/dragWidth.js +0 -30
  884. package/packages/tabDialog/src/main.vue +0 -277
  885. package/packages/theme-cy/README.md +0 -38
  886. package/packages/theme-cy/gulpfile.js +0 -27
  887. package/packages/theme-cy/package.json +0 -35
  888. package/packages/theme-cy/src/base.scss +0 -3
  889. package/packages/theme-cy/src/element.scss +0 -45
  890. package/packages/theme-cy/src/fileUpload.scss +0 -30
  891. package/packages/theme-cy/src/index.scss +0 -7
  892. package/packages/theme-cy/src/selectDisplayInput.scss +0 -76
  893. package/packages/theme-cy/src/subTitle.scss +0 -26
  894. package/packages/theme-cy/src/tabDialog.scss +0 -43
  895. package/packages/theme-cy/src/treeSelect.scss +0 -98
  896. package/packages/treeSelect/index.js +0 -8
  897. package/packages/treeSelect/src/main.vue +0 -325
  898. package/src/locale/lang/af-ZA.js +0 -123
  899. package/src/locale/lang/ar.js +0 -122
  900. package/src/locale/lang/az.js +0 -126
  901. package/src/locale/lang/bg.js +0 -123
  902. package/src/locale/lang/bn.js +0 -126
  903. package/src/locale/lang/ca.js +0 -122
  904. package/src/locale/lang/cs-CZ.js +0 -125
  905. package/src/locale/lang/da.js +0 -122
  906. package/src/locale/lang/de.js +0 -124
  907. package/src/locale/lang/ee.js +0 -123
  908. package/src/locale/lang/el.js +0 -123
  909. package/src/locale/lang/eo.js +0 -123
  910. package/src/locale/lang/es.js +0 -122
  911. package/src/locale/lang/eu.js +0 -123
  912. package/src/locale/lang/fa.js +0 -123
  913. package/src/locale/lang/fi.js +0 -123
  914. package/src/locale/lang/fr.js +0 -122
  915. package/src/locale/lang/he.js +0 -123
  916. package/src/locale/lang/hr.js +0 -123
  917. package/src/locale/lang/hu.js +0 -122
  918. package/src/locale/lang/hy-AM.js +0 -123
  919. package/src/locale/lang/id.js +0 -123
  920. package/src/locale/lang/is.js +0 -124
  921. package/src/locale/lang/it.js +0 -122
  922. package/src/locale/lang/ja.js +0 -123
  923. package/src/locale/lang/kg.js +0 -123
  924. package/src/locale/lang/km.js +0 -123
  925. package/src/locale/lang/ko.js +0 -123
  926. package/src/locale/lang/ku.js +0 -123
  927. package/src/locale/lang/kz.js +0 -123
  928. package/src/locale/lang/lo-LA.js +0 -126
  929. package/src/locale/lang/lt.js +0 -123
  930. package/src/locale/lang/lv.js +0 -123
  931. package/src/locale/lang/mn.js +0 -123
  932. package/src/locale/lang/ms.js +0 -122
  933. package/src/locale/lang/nb-NO.js +0 -122
  934. package/src/locale/lang/nl.js +0 -123
  935. package/src/locale/lang/pl.js +0 -123
  936. package/src/locale/lang/pt-br.js +0 -123
  937. package/src/locale/lang/pt.js +0 -123
  938. package/src/locale/lang/ro.js +0 -123
  939. package/src/locale/lang/ru-RU.js +0 -123
  940. package/src/locale/lang/si.js +0 -123
  941. package/src/locale/lang/sk.js +0 -125
  942. package/src/locale/lang/sl.js +0 -123
  943. package/src/locale/lang/sr-Latn.js +0 -123
  944. package/src/locale/lang/sr.js +0 -123
  945. package/src/locale/lang/sv-SE.js +0 -123
  946. package/src/locale/lang/sw.js +0 -123
  947. package/src/locale/lang/ta.js +0 -122
  948. package/src/locale/lang/th.js +0 -123
  949. package/src/locale/lang/tk.js +0 -123
  950. package/src/locale/lang/tr-TR.js +0 -123
  951. package/src/locale/lang/ua.js +0 -123
  952. package/src/locale/lang/ug-CN.js +0 -123
  953. package/src/locale/lang/uz-UZ.js +0 -123
  954. package/src/locale/lang/vi.js +0 -123
  955. package/types/fileUpload.d.ts +0 -5
  956. package/types/selectDisplayInput.d.ts +0 -5
  957. package/types/subTitle.d.ts +0 -5
  958. package/types/tabDialog.d.ts +0 -5
  959. package/types/treeSelect.d.ts +0 -5
@@ -1,1276 +1,1276 @@
1
- /**
2
- * @fileOverview Kickass library to create and place poppers near their reference elements.
3
- * @version {{version}}
4
- * @license
5
- * Copyright (c) 2016 Federico Zivolo and contributors
6
- *
7
- * Permission is hereby granted, free of charge, to any person obtaining a copy
8
- * of this software and associated documentation files (the "Software"), to deal
9
- * in the Software without restriction, including without limitation the rights
10
- * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
11
- * copies of the Software, and to permit persons to whom the Software is
12
- * furnished to do so, subject to the following conditions:
13
- *
14
- * The above copyright notice and this permission notice shall be included in all
15
- * copies or substantial portions of the Software.
16
- *
17
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
18
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
19
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
20
- * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
21
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
22
- * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
23
- * SOFTWARE.
24
- */
25
-
26
- //
27
- // Cross module loader
28
- // Supported: Node, AMD, Browser globals
29
- //
30
- ;(function (root, factory) {
31
- if (typeof define === 'function' && define.amd) {
32
- // AMD. Register as an anonymous module.
33
- define(factory);
34
- } else if (typeof module === 'object' && module.exports) {
35
- // Node. Does not work with strict CommonJS, but
36
- // only CommonJS-like environments that support module.exports,
37
- // like Node.
38
- module.exports = factory();
39
- } else {
40
- // Browser globals (root is window)
41
- root.Popper = factory();
42
- }
43
- }(this, function () {
44
-
45
- 'use strict';
46
-
47
- var root = window;
48
-
49
- // default options
50
- var DEFAULTS = {
51
- // placement of the popper
52
- placement: 'bottom',
53
-
54
- gpuAcceleration: true,
55
-
56
- // shift popper from its origin by the given amount of pixels (can be negative)
57
- offset: 0,
58
-
59
- // the element which will act as boundary of the popper
60
- boundariesElement: 'viewport',
61
-
62
- // amount of pixel used to define a minimum distance between the boundaries and the popper
63
- boundariesPadding: 5,
64
-
65
- // popper will try to prevent overflow following this order,
66
- // by default, then, it could overflow on the left and on top of the boundariesElement
67
- preventOverflowOrder: ['left', 'right', 'top', 'bottom'],
68
-
69
- // the behavior used by flip to change the placement of the popper
70
- flipBehavior: 'flip',
71
-
72
- arrowElement: '[x-arrow]',
73
-
74
- arrowOffset: 0,
75
-
76
- // list of functions used to modify the offsets before they are applied to the popper
77
- modifiers: [ 'shift', 'offset', 'preventOverflow', 'keepTogether', 'arrow', 'flip', 'applyStyle'],
78
-
79
- modifiersIgnored: [],
80
-
81
- forceAbsolute: false
82
- };
83
-
84
- /**
85
- * Create a new Popper.js instance
86
- * @constructor Popper
87
- * @param {HTMLElement} reference - The reference element used to position the popper
88
- * @param {HTMLElement|Object} popper
89
- * The HTML element used as popper, or a configuration used to generate the popper.
90
- * @param {String} [popper.tagName='div'] The tag name of the generated popper.
91
- * @param {Array} [popper.classNames=['popper']] Array of classes to apply to the generated popper.
92
- * @param {Array} [popper.attributes] Array of attributes to apply, specify `attr:value` to assign a value to it.
93
- * @param {HTMLElement|String} [popper.parent=window.document.body] The parent element, given as HTMLElement or as query string.
94
- * @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`.
95
- * @param {String} [popper.contentType='text'] If `html`, the `content` will be parsed as HTML. If `node`, it will be appended as-is.
96
- * @param {String} [popper.arrowTagName='div'] Same as `popper.tagName` but for the arrow element.
97
- * @param {Array} [popper.arrowClassNames='popper__arrow'] Same as `popper.classNames` but for the arrow element.
98
- * @param {String} [popper.arrowAttributes=['x-arrow']] Same as `popper.attributes` but for the arrow element.
99
- * @param {Object} options
100
- * @param {String} [options.placement=bottom]
101
- * Placement of the popper accepted values: `top(-start, -end), right(-start, -end), bottom(-start, -right),
102
- * left(-start, -end)`
103
- *
104
- * @param {HTMLElement|String} [options.arrowElement='[x-arrow]']
105
- * The DOM Node used as arrow for the popper, or a CSS selector used to get the DOM node. It must be child of
106
- * its parent Popper. Popper.js will apply to the given element the style required to align the arrow with its
107
- * reference element.
108
- * By default, it will look for a child node of the popper with the `x-arrow` attribute.
109
- *
110
- * @param {Boolean} [options.gpuAcceleration=true]
111
- * When this property is set to true, the popper position will be applied using CSS3 translate3d, allowing the
112
- * browser to use the GPU to accelerate the rendering.
113
- * If set to false, the popper will be placed using `top` and `left` properties, not using the GPU.
114
- *
115
- * @param {Number} [options.offset=0]
116
- * Amount of pixels the popper will be shifted (can be negative).
117
- *
118
- * @param {String|Element} [options.boundariesElement='viewport']
119
- * The element which will define the boundaries of the popper position, the popper will never be placed outside
120
- * of the defined boundaries (except if `keepTogether` is enabled)
121
- *
122
- * @param {Number} [options.boundariesPadding=5]
123
- * Additional padding for the boundaries
124
- *
125
- * @param {Array} [options.preventOverflowOrder=['left', 'right', 'top', 'bottom']]
126
- * Order used when Popper.js tries to avoid overflows from the boundaries, they will be checked in order,
127
- * this means that the last ones will never overflow
128
- *
129
- * @param {String|Array} [options.flipBehavior='flip']
130
- * The behavior used by the `flip` modifier to change the placement of the popper when the latter is trying to
131
- * overlap its reference element. Defining `flip` as value, the placement will be flipped on
132
- * its axis (`right - left`, `top - bottom`).
133
- * You can even pass an array of placements (eg: `['right', 'left', 'top']` ) to manually specify
134
- * how alter the placement when a flip is needed. (eg. in the above example, it would first flip from right to left,
135
- * then, if even in its new placement, the popper is overlapping its reference element, it will be moved to top)
136
- *
137
- * @param {Array} [options.modifiers=[ 'shift', 'offset', 'preventOverflow', 'keepTogether', 'arrow', 'flip', 'applyStyle']]
138
- * List of functions used to modify the data before they are applied to the popper, add your custom functions
139
- * to this array to edit the offsets and placement.
140
- * The function should reflect the @params and @returns of preventOverflow
141
- *
142
- * @param {Array} [options.modifiersIgnored=[]]
143
- * Put here any built-in modifier name you want to exclude from the modifiers list
144
- * The function should reflect the @params and @returns of preventOverflow
145
- *
146
- * @param {Boolean} [options.removeOnDestroy=false]
147
- * Set to true if you want to automatically remove the popper when you call the `destroy` method.
148
- */
149
- function Popper(reference, popper, options) {
150
- this._reference = reference.jquery ? reference[0] : reference;
151
- this.state = {};
152
-
153
- // if the popper variable is a configuration object, parse it to generate an HTMLElement
154
- // generate a default popper if is not defined
155
- var isNotDefined = typeof popper === 'undefined' || popper === null;
156
- var isConfig = popper && Object.prototype.toString.call(popper) === '[object Object]';
157
- if (isNotDefined || isConfig) {
158
- this._popper = this.parse(isConfig ? popper : {});
159
- }
160
- // otherwise, use the given HTMLElement as popper
161
- else {
162
- this._popper = popper.jquery ? popper[0] : popper;
163
- }
164
-
165
- // with {} we create a new object with the options inside it
166
- this._options = Object.assign({}, DEFAULTS, options);
167
-
168
- // refactoring modifiers' list
169
- this._options.modifiers = this._options.modifiers.map(function(modifier){
170
- // remove ignored modifiers
171
- if (this._options.modifiersIgnored.indexOf(modifier) !== -1) return;
172
-
173
- // set the x-placement attribute before everything else because it could be used to add margins to the popper
174
- // margins needs to be calculated to get the correct popper offsets
175
- if (modifier === 'applyStyle') {
176
- this._popper.setAttribute('x-placement', this._options.placement);
177
- }
178
-
179
- // return predefined modifier identified by string or keep the custom one
180
- return this.modifiers[modifier] || modifier;
181
- }.bind(this));
182
-
183
- // make sure to apply the popper position before any computation
184
- this.state.position = this._getPosition(this._popper, this._reference);
185
- setStyle(this._popper, { position: this.state.position, top: 0 });
186
-
187
- // fire the first update to position the popper in the right place
188
- this.update();
189
-
190
- // setup event listeners, they will take care of update the position in specific situations
191
- this._setupEventListeners();
192
- return this;
193
- }
194
-
195
-
196
- //
197
- // Methods
198
- //
199
- /**
200
- * Destroy the popper
201
- * @method
202
- * @memberof Popper
203
- */
204
- Popper.prototype.destroy = function() {
205
- this._popper.removeAttribute('x-placement');
206
- this._popper.style.left = '';
207
- this._popper.style.position = '';
208
- this._popper.style.top = '';
209
- this._popper.style[getSupportedPropertyName('transform')] = '';
210
- this._removeEventListeners();
211
-
212
- // remove the popper if user explicity asked for the deletion on destroy
213
- if (this._options.removeOnDestroy) {
214
- this._popper.remove();
215
- }
216
- return this;
217
- };
218
-
219
- /**
220
- * Updates the position of the popper, computing the new offsets and applying the new style
221
- * @method
222
- * @memberof Popper
223
- */
224
- Popper.prototype.update = function() {
225
- var data = { instance: this, styles: {} };
226
-
227
- // store placement inside the data object, modifiers will be able to edit `placement` if needed
228
- // and refer to _originalPlacement to know the original value
229
- data.placement = this._options.placement;
230
- data._originalPlacement = this._options.placement;
231
-
232
- // compute the popper and reference offsets and put them inside data.offsets
233
- data.offsets = this._getOffsets(this._popper, this._reference, data.placement);
234
-
235
- // get boundaries
236
- data.boundaries = this._getBoundaries(data, this._options.boundariesPadding, this._options.boundariesElement);
237
-
238
- data = this.runModifiers(data, this._options.modifiers);
239
-
240
- if (typeof this.state.updateCallback === 'function') {
241
- this.state.updateCallback(data);
242
- }
243
- };
244
-
245
- /**
246
- * If a function is passed, it will be executed after the initialization of popper with as first argument the Popper instance.
247
- * @method
248
- * @memberof Popper
249
- * @param {Function} callback
250
- */
251
- Popper.prototype.onCreate = function(callback) {
252
- // the createCallbacks return as first argument the popper instance
253
- callback(this);
254
- return this;
255
- };
256
-
257
- /**
258
- * If a function is passed, it will be executed after each update of popper with as first argument the set of coordinates and informations
259
- * used to style popper and its arrow.
260
- * NOTE: it doesn't get fired on the first call of the `Popper.update()` method inside the `Popper` constructor!
261
- * @method
262
- * @memberof Popper
263
- * @param {Function} callback
264
- */
265
- Popper.prototype.onUpdate = function(callback) {
266
- this.state.updateCallback = callback;
267
- return this;
268
- };
269
-
270
- /**
271
- * Helper used to generate poppers from a configuration file
272
- * @method
273
- * @memberof Popper
274
- * @param config {Object} configuration
275
- * @returns {HTMLElement} popper
276
- */
277
- Popper.prototype.parse = function(config) {
278
- var defaultConfig = {
279
- tagName: 'div',
280
- classNames: [ 'popper' ],
281
- attributes: [],
282
- parent: root.document.body,
283
- content: '',
284
- contentType: 'text',
285
- arrowTagName: 'div',
286
- arrowClassNames: [ 'popper__arrow' ],
287
- arrowAttributes: [ 'x-arrow']
288
- };
289
- config = Object.assign({}, defaultConfig, config);
290
-
291
- var d = root.document;
292
-
293
- var popper = d.createElement(config.tagName);
294
- addClassNames(popper, config.classNames);
295
- addAttributes(popper, config.attributes);
296
- if (config.contentType === 'node') {
297
- popper.appendChild(config.content.jquery ? config.content[0] : config.content);
298
- }else if (config.contentType === 'html') {
299
- popper.innerHTML = config.content;
300
- } else {
301
- popper.textContent = config.content;
302
- }
303
-
304
- if (config.arrowTagName) {
305
- var arrow = d.createElement(config.arrowTagName);
306
- addClassNames(arrow, config.arrowClassNames);
307
- addAttributes(arrow, config.arrowAttributes);
308
- popper.appendChild(arrow);
309
- }
310
-
311
- var parent = config.parent.jquery ? config.parent[0] : config.parent;
312
-
313
- // if the given parent is a string, use it to match an element
314
- // if more than one element is matched, the first one will be used as parent
315
- // if no elements are matched, the script will throw an error
316
- if (typeof parent === 'string') {
317
- parent = d.querySelectorAll(config.parent);
318
- if (parent.length > 1) {
319
- console.warn('WARNING: the given `parent` query(' + config.parent + ') matched more than one element, the first one will be used');
320
- }
321
- if (parent.length === 0) {
322
- throw 'ERROR: the given `parent` doesn\'t exists!';
323
- }
324
- parent = parent[0];
325
- }
326
- // if the given parent is a DOM nodes list or an array of nodes with more than one element,
327
- // the first one will be used as parent
328
- if (parent.length > 1 && parent instanceof Element === false) {
329
- console.warn('WARNING: you have passed as parent a list of elements, the first one will be used');
330
- parent = parent[0];
331
- }
332
-
333
- // append the generated popper to its parent
334
- parent.appendChild(popper);
335
-
336
- return popper;
337
-
338
- /**
339
- * Adds class names to the given element
340
- * @function
341
- * @ignore
342
- * @param {HTMLElement} target
343
- * @param {Array} classes
344
- */
345
- function addClassNames(element, classNames) {
346
- classNames.forEach(function(className) {
347
- element.classList.add(className);
348
- });
349
- }
350
-
351
- /**
352
- * Adds attributes to the given element
353
- * @function
354
- * @ignore
355
- * @param {HTMLElement} target
356
- * @param {Array} attributes
357
- * @example
358
- * addAttributes(element, [ 'data-info:foobar' ]);
359
- */
360
- function addAttributes(element, attributes) {
361
- attributes.forEach(function(attribute) {
362
- element.setAttribute(attribute.split(':')[0], attribute.split(':')[1] || '');
363
- });
364
- }
365
-
366
- };
367
-
368
- /**
369
- * Helper used to get the position which will be applied to the popper
370
- * @method
371
- * @memberof Popper
372
- * @param config {HTMLElement} popper element
373
- * @param reference {HTMLElement} reference element
374
- * @returns {String} position
375
- */
376
- Popper.prototype._getPosition = function(popper, reference) {
377
- var container = getOffsetParent(reference);
378
-
379
- if (this._options.forceAbsolute) {
380
- return 'absolute';
381
- }
382
-
383
- // Decide if the popper will be fixed
384
- // If the reference element is inside a fixed context, the popper will be fixed as well to allow them to scroll together
385
- var isParentFixed = isFixed(reference, container);
386
- return isParentFixed ? 'fixed' : 'absolute';
387
- };
388
-
389
- /**
390
- * Get offsets to the popper
391
- * @method
392
- * @memberof Popper
393
- * @access private
394
- * @param {Element} popper - the popper element
395
- * @param {Element} reference - the reference element (the popper will be relative to this)
396
- * @returns {Object} An object containing the offsets which will be applied to the popper
397
- */
398
- Popper.prototype._getOffsets = function(popper, reference, placement) {
399
- placement = placement.split('-')[0];
400
- var popperOffsets = {};
401
-
402
- popperOffsets.position = this.state.position;
403
- var isParentFixed = popperOffsets.position === 'fixed';
404
-
405
- //
406
- // Get reference element position
407
- //
408
- var referenceOffsets = getOffsetRectRelativeToCustomParent(reference, getOffsetParent(popper), isParentFixed);
409
-
410
- //
411
- // Get popper sizes
412
- //
413
- var popperRect = getOuterSizes(popper);
414
-
415
- //
416
- // Compute offsets of popper
417
- //
418
-
419
- // depending by the popper placement we have to compute its offsets slightly differently
420
- if (['right', 'left'].indexOf(placement) !== -1) {
421
- popperOffsets.top = referenceOffsets.top + referenceOffsets.height / 2 - popperRect.height / 2;
422
- if (placement === 'left') {
423
- popperOffsets.left = referenceOffsets.left - popperRect.width;
424
- } else {
425
- popperOffsets.left = referenceOffsets.right;
426
- }
427
- } else {
428
- popperOffsets.left = referenceOffsets.left + referenceOffsets.width / 2 - popperRect.width / 2;
429
- if (placement === 'top') {
430
- popperOffsets.top = referenceOffsets.top - popperRect.height;
431
- } else {
432
- popperOffsets.top = referenceOffsets.bottom;
433
- }
434
- }
435
-
436
- // Add width and height to our offsets object
437
- popperOffsets.width = popperRect.width;
438
- popperOffsets.height = popperRect.height;
439
-
440
- return {
441
- popper: popperOffsets,
442
- reference: referenceOffsets
443
- };
444
- };
445
-
446
-
447
- /**
448
- * Setup needed event listeners used to update the popper position
449
- * @method
450
- * @memberof Popper
451
- * @access private
452
- */
453
- Popper.prototype._setupEventListeners = function() {
454
- // NOTE: 1 DOM access here
455
- this.state.updateBound = this.update.bind(this);
456
- root.addEventListener('resize', this.state.updateBound);
457
- // if the boundariesElement is window we don't need to listen for the scroll event
458
- if (this._options.boundariesElement !== 'window') {
459
- var target = getScrollParent(this._reference);
460
- // here it could be both `body` or `documentElement` thanks to Firefox, we then check both
461
- if (target === root.document.body || target === root.document.documentElement) {
462
- target = root;
463
- }
464
- target.addEventListener('scroll', this.state.updateBound);
465
- this.state.scrollTarget = target;
466
- }
467
- };
468
-
469
- /**
470
- * Remove event listeners used to update the popper position
471
- * @method
472
- * @memberof Popper
473
- * @access private
474
- */
475
- Popper.prototype._removeEventListeners = function() {
476
- // NOTE: 1 DOM access here
477
- root.removeEventListener('resize', this.state.updateBound);
478
- if (this._options.boundariesElement !== 'window' && this.state.scrollTarget) {
479
- this.state.scrollTarget.removeEventListener('scroll', this.state.updateBound);
480
- this.state.scrollTarget = null;
481
- }
482
- this.state.updateBound = null;
483
- };
484
-
485
- /**
486
- * Computed the boundaries limits and return them
487
- * @method
488
- * @memberof Popper
489
- * @access private
490
- * @param {Object} data - Object containing the property "offsets" generated by `_getOffsets`
491
- * @param {Number} padding - Boundaries padding
492
- * @param {Element} boundariesElement - Element used to define the boundaries
493
- * @returns {Object} Coordinates of the boundaries
494
- */
495
- Popper.prototype._getBoundaries = function(data, padding, boundariesElement) {
496
- // NOTE: 1 DOM access here
497
- var boundaries = {};
498
- var width, height;
499
- if (boundariesElement === 'window') {
500
- var body = root.document.body,
501
- html = root.document.documentElement;
502
-
503
- height = Math.max( body.scrollHeight, body.offsetHeight, html.clientHeight, html.scrollHeight, html.offsetHeight );
504
- width = Math.max( body.scrollWidth, body.offsetWidth, html.clientWidth, html.scrollWidth, html.offsetWidth );
505
-
506
- boundaries = {
507
- top: 0,
508
- right: width,
509
- bottom: height,
510
- left: 0
511
- };
512
- } else if (boundariesElement === 'viewport') {
513
- var offsetParent = getOffsetParent(this._popper);
514
- var scrollParent = getScrollParent(this._popper);
515
- var offsetParentRect = getOffsetRect(offsetParent);
516
-
517
- // Thanks the fucking native API, `document.body.scrollTop` & `document.documentElement.scrollTop`
518
- var getScrollTopValue = function (element) {
519
- return element == document.body ? Math.max(document.documentElement.scrollTop, document.body.scrollTop) : element.scrollTop;
520
- }
521
- var getScrollLeftValue = function (element) {
522
- return element == document.body ? Math.max(document.documentElement.scrollLeft, document.body.scrollLeft) : element.scrollLeft;
523
- }
524
-
525
- // if the popper is fixed we don't have to substract scrolling from the boundaries
526
- var scrollTop = data.offsets.popper.position === 'fixed' ? 0 : getScrollTopValue(scrollParent);
527
- var scrollLeft = data.offsets.popper.position === 'fixed' ? 0 : getScrollLeftValue(scrollParent);
528
-
529
- boundaries = {
530
- top: 0 - (offsetParentRect.top - scrollTop),
531
- right: root.document.documentElement.clientWidth - (offsetParentRect.left - scrollLeft),
532
- bottom: root.document.documentElement.clientHeight - (offsetParentRect.top - scrollTop),
533
- left: 0 - (offsetParentRect.left - scrollLeft)
534
- };
535
- } else {
536
- if (getOffsetParent(this._popper) === boundariesElement) {
537
- boundaries = {
538
- top: 0,
539
- left: 0,
540
- right: boundariesElement.clientWidth,
541
- bottom: boundariesElement.clientHeight
542
- };
543
- } else {
544
- boundaries = getOffsetRect(boundariesElement);
545
- }
546
- }
547
- boundaries.left += padding;
548
- boundaries.right -= padding;
549
- boundaries.top = boundaries.top + padding;
550
- boundaries.bottom = boundaries.bottom - padding;
551
- return boundaries;
552
- };
553
-
554
-
555
- /**
556
- * Loop trough the list of modifiers and run them in order, each of them will then edit the data object
557
- * @method
558
- * @memberof Popper
559
- * @access public
560
- * @param {Object} data
561
- * @param {Array} modifiers
562
- * @param {Function} ends
563
- */
564
- Popper.prototype.runModifiers = function(data, modifiers, ends) {
565
- var modifiersToRun = modifiers.slice();
566
- if (ends !== undefined) {
567
- modifiersToRun = this._options.modifiers.slice(0, getArrayKeyIndex(this._options.modifiers, ends));
568
- }
569
-
570
- modifiersToRun.forEach(function(modifier) {
571
- if (isFunction(modifier)) {
572
- data = modifier.call(this, data);
573
- }
574
- }.bind(this));
575
-
576
- return data;
577
- };
578
-
579
- /**
580
- * Helper used to know if the given modifier depends from another one.
581
- * @method
582
- * @memberof Popper
583
- * @param {String} requesting - name of requesting modifier
584
- * @param {String} requested - name of requested modifier
585
- * @returns {Boolean}
586
- */
587
- Popper.prototype.isModifierRequired = function(requesting, requested) {
588
- var index = getArrayKeyIndex(this._options.modifiers, requesting);
589
- return !!this._options.modifiers.slice(0, index).filter(function(modifier) {
590
- return modifier === requested;
591
- }).length;
592
- };
593
-
594
- //
595
- // Modifiers
596
- //
597
-
598
- /**
599
- * Modifiers list
600
- * @namespace Popper.modifiers
601
- * @memberof Popper
602
- * @type {Object}
603
- */
604
- Popper.prototype.modifiers = {};
605
-
606
- /**
607
- * Apply the computed styles to the popper element
608
- * @method
609
- * @memberof Popper.modifiers
610
- * @argument {Object} data - The data object generated by `update` method
611
- * @returns {Object} The same data object
612
- */
613
- Popper.prototype.modifiers.applyStyle = function(data) {
614
- // apply the final offsets to the popper
615
- // NOTE: 1 DOM access here
616
- var styles = {
617
- position: data.offsets.popper.position
618
- };
619
-
620
- // round top and left to avoid blurry text
621
- var left = Math.round(data.offsets.popper.left);
622
- var top = Math.round(data.offsets.popper.top);
623
-
624
- // if gpuAcceleration is set to true and transform is supported, we use `translate3d` to apply the position to the popper
625
- // we automatically use the supported prefixed version if needed
626
- var prefixedProperty;
627
- if (this._options.gpuAcceleration && (prefixedProperty = getSupportedPropertyName('transform'))) {
628
- styles[prefixedProperty] = 'translate3d(' + left + 'px, ' + top + 'px, 0)';
629
- styles.top = 0;
630
- styles.left = 0;
631
- }
632
- // othwerise, we use the standard `left` and `top` properties
633
- else {
634
- styles.left =left;
635
- styles.top = top;
636
- }
637
-
638
- // any property present in `data.styles` will be applied to the popper,
639
- // in this way we can make the 3rd party modifiers add custom styles to it
640
- // Be aware, modifiers could override the properties defined in the previous
641
- // lines of this modifier!
642
- Object.assign(styles, data.styles);
643
-
644
- setStyle(this._popper, styles);
645
-
646
- // set an attribute which will be useful to style the tooltip (use it to properly position its arrow)
647
- // NOTE: 1 DOM access here
648
- this._popper.setAttribute('x-placement', data.placement);
649
-
650
- // if the arrow modifier is required and the arrow style has been computed, apply the arrow style
651
- if (this.isModifierRequired(this.modifiers.applyStyle, this.modifiers.arrow) && data.offsets.arrow) {
652
- setStyle(data.arrowElement, data.offsets.arrow);
653
- }
654
-
655
- return data;
656
- };
657
-
658
- /**
659
- * Modifier used to shift the popper on the start or end of its reference element side
660
- * @method
661
- * @memberof Popper.modifiers
662
- * @argument {Object} data - The data object generated by `update` method
663
- * @returns {Object} The data object, properly modified
664
- */
665
- Popper.prototype.modifiers.shift = function(data) {
666
- var placement = data.placement;
667
- var basePlacement = placement.split('-')[0];
668
- var shiftVariation = placement.split('-')[1];
669
-
670
- // if shift shiftVariation is specified, run the modifier
671
- if (shiftVariation) {
672
- var reference = data.offsets.reference;
673
- var popper = getPopperClientRect(data.offsets.popper);
674
-
675
- var shiftOffsets = {
676
- y: {
677
- start: { top: reference.top },
678
- end: { top: reference.top + reference.height - popper.height }
679
- },
680
- x: {
681
- start: { left: reference.left },
682
- end: { left: reference.left + reference.width - popper.width }
683
- }
684
- };
685
-
686
- var axis = ['bottom', 'top'].indexOf(basePlacement) !== -1 ? 'x' : 'y';
687
-
688
- data.offsets.popper = Object.assign(popper, shiftOffsets[axis][shiftVariation]);
689
- }
690
-
691
- return data;
692
- };
693
-
694
-
695
- /**
696
- * Modifier used to make sure the popper does not overflows from it's boundaries
697
- * @method
698
- * @memberof Popper.modifiers
699
- * @argument {Object} data - The data object generated by `update` method
700
- * @returns {Object} The data object, properly modified
701
- */
702
- Popper.prototype.modifiers.preventOverflow = function(data) {
703
- var order = this._options.preventOverflowOrder;
704
- var popper = getPopperClientRect(data.offsets.popper);
705
-
706
- var check = {
707
- left: function() {
708
- var left = popper.left;
709
- if (popper.left < data.boundaries.left) {
710
- left = Math.max(popper.left, data.boundaries.left);
711
- }
712
- return { left: left };
713
- },
714
- right: function() {
715
- var left = popper.left;
716
- if (popper.right > data.boundaries.right) {
717
- left = Math.min(popper.left, data.boundaries.right - popper.width);
718
- }
719
- return { left: left };
720
- },
721
- top: function() {
722
- var top = popper.top;
723
- if (popper.top < data.boundaries.top) {
724
- top = Math.max(popper.top, data.boundaries.top);
725
- }
726
- return { top: top };
727
- },
728
- bottom: function() {
729
- var top = popper.top;
730
- if (popper.bottom > data.boundaries.bottom) {
731
- top = Math.min(popper.top, data.boundaries.bottom - popper.height);
732
- }
733
- return { top: top };
734
- }
735
- };
736
-
737
- order.forEach(function(direction) {
738
- data.offsets.popper = Object.assign(popper, check[direction]());
739
- });
740
-
741
- return data;
742
- };
743
-
744
- /**
745
- * Modifier used to make sure the popper is always near its reference
746
- * @method
747
- * @memberof Popper.modifiers
748
- * @argument {Object} data - The data object generated by _update method
749
- * @returns {Object} The data object, properly modified
750
- */
751
- Popper.prototype.modifiers.keepTogether = function(data) {
752
- var popper = getPopperClientRect(data.offsets.popper);
753
- var reference = data.offsets.reference;
754
- var f = Math.floor;
755
-
756
- if (popper.right < f(reference.left)) {
757
- data.offsets.popper.left = f(reference.left) - popper.width;
758
- }
759
- if (popper.left > f(reference.right)) {
760
- data.offsets.popper.left = f(reference.right);
761
- }
762
- if (popper.bottom < f(reference.top)) {
763
- data.offsets.popper.top = f(reference.top) - popper.height;
764
- }
765
- if (popper.top > f(reference.bottom)) {
766
- data.offsets.popper.top = f(reference.bottom);
767
- }
768
-
769
- return data;
770
- };
771
-
772
- /**
773
- * Modifier used to flip the placement of the popper when the latter is starting overlapping its reference element.
774
- * Requires the `preventOverflow` modifier before it in order to work.
775
- * **NOTE:** This modifier will run all its previous modifiers everytime it tries to flip the popper!
776
- * @method
777
- * @memberof Popper.modifiers
778
- * @argument {Object} data - The data object generated by _update method
779
- * @returns {Object} The data object, properly modified
780
- */
781
- Popper.prototype.modifiers.flip = function(data) {
782
- // check if preventOverflow is in the list of modifiers before the flip modifier.
783
- // otherwise flip would not work as expected.
784
- if (!this.isModifierRequired(this.modifiers.flip, this.modifiers.preventOverflow)) {
785
- console.warn('WARNING: preventOverflow modifier is required by flip modifier in order to work, be sure to include it before flip!');
786
- return data;
787
- }
788
-
789
- if (data.flipped && data.placement === data._originalPlacement) {
790
- // seems like flip is trying to loop, probably there's not enough space on any of the flippable sides
791
- return data;
792
- }
793
-
794
- var placement = data.placement.split('-')[0];
795
- var placementOpposite = getOppositePlacement(placement);
796
- var variation = data.placement.split('-')[1] || '';
797
-
798
- var flipOrder = [];
799
- if(this._options.flipBehavior === 'flip') {
800
- flipOrder = [
801
- placement,
802
- placementOpposite
803
- ];
804
- } else {
805
- flipOrder = this._options.flipBehavior;
806
- }
807
-
808
- flipOrder.forEach(function(step, index) {
809
- if (placement !== step || flipOrder.length === index + 1) {
810
- return;
811
- }
812
-
813
- placement = data.placement.split('-')[0];
814
- placementOpposite = getOppositePlacement(placement);
815
-
816
- var popperOffsets = getPopperClientRect(data.offsets.popper);
817
-
818
- // this boolean is used to distinguish right and bottom from top and left
819
- // they need different computations to get flipped
820
- var a = ['right', 'bottom'].indexOf(placement) !== -1;
821
-
822
- // using Math.floor because the reference offsets may contain decimals we are not going to consider here
823
- if (
824
- a && Math.floor(data.offsets.reference[placement]) > Math.floor(popperOffsets[placementOpposite]) ||
825
- !a && Math.floor(data.offsets.reference[placement]) < Math.floor(popperOffsets[placementOpposite])
826
- ) {
827
- // we'll use this boolean to detect any flip loop
828
- data.flipped = true;
829
- data.placement = flipOrder[index + 1];
830
- if (variation) {
831
- data.placement += '-' + variation;
832
- }
833
- data.offsets.popper = this._getOffsets(this._popper, this._reference, data.placement).popper;
834
-
835
- data = this.runModifiers(data, this._options.modifiers, this._flip);
836
- }
837
- }.bind(this));
838
- return data;
839
- };
840
-
841
- /**
842
- * Modifier used to add an offset to the popper, useful if you more granularity positioning your popper.
843
- * The offsets will shift the popper on the side of its reference element.
844
- * @method
845
- * @memberof Popper.modifiers
846
- * @argument {Object} data - The data object generated by _update method
847
- * @returns {Object} The data object, properly modified
848
- */
849
- Popper.prototype.modifiers.offset = function(data) {
850
- var offset = this._options.offset;
851
- var popper = data.offsets.popper;
852
-
853
- if (data.placement.indexOf('left') !== -1) {
854
- popper.top -= offset;
855
- }
856
- else if (data.placement.indexOf('right') !== -1) {
857
- popper.top += offset;
858
- }
859
- else if (data.placement.indexOf('top') !== -1) {
860
- popper.left -= offset;
861
- }
862
- else if (data.placement.indexOf('bottom') !== -1) {
863
- popper.left += offset;
864
- }
865
- return data;
866
- };
867
-
868
- /**
869
- * 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
870
- * It will use the CSS outer size of the arrow element to know how many pixels of conjuction are needed
871
- * @method
872
- * @memberof Popper.modifiers
873
- * @argument {Object} data - The data object generated by _update method
874
- * @returns {Object} The data object, properly modified
875
- */
876
- Popper.prototype.modifiers.arrow = function(data) {
877
- var arrow = this._options.arrowElement;
878
- var arrowOffset = this._options.arrowOffset;
879
-
880
- // if the arrowElement is a string, suppose it's a CSS selector
881
- if (typeof arrow === 'string') {
882
- arrow = this._popper.querySelector(arrow);
883
- }
884
-
885
- // if arrow element is not found, don't run the modifier
886
- if (!arrow) {
887
- return data;
888
- }
889
-
890
- // the arrow element must be child of its popper
891
- if (!this._popper.contains(arrow)) {
892
- console.warn('WARNING: `arrowElement` must be child of its popper element!');
893
- return data;
894
- }
895
-
896
- // arrow depends on keepTogether in order to work
897
- if (!this.isModifierRequired(this.modifiers.arrow, this.modifiers.keepTogether)) {
898
- console.warn('WARNING: keepTogether modifier is required by arrow modifier in order to work, be sure to include it before arrow!');
899
- return data;
900
- }
901
-
902
- var arrowStyle = {};
903
- var placement = data.placement.split('-')[0];
904
- var popper = getPopperClientRect(data.offsets.popper);
905
- var reference = data.offsets.reference;
906
- var isVertical = ['left', 'right'].indexOf(placement) !== -1;
907
-
908
- var len = isVertical ? 'height' : 'width';
909
- var side = isVertical ? 'top' : 'left';
910
- var translate = isVertical ? 'translateY' : 'translateX';
911
- var altSide = isVertical ? 'left' : 'top';
912
- var opSide = isVertical ? 'bottom' : 'right';
913
- var arrowSize = getOuterSizes(arrow)[len];
914
-
915
- //
916
- // extends keepTogether behavior making sure the popper and its reference have enough pixels in conjuction
917
- //
918
-
919
- // top/left side
920
- if (reference[opSide] - arrowSize < popper[side]) {
921
- data.offsets.popper[side] -= popper[side] - (reference[opSide] - arrowSize);
922
- }
923
- // bottom/right side
924
- if (reference[side] + arrowSize > popper[opSide]) {
925
- data.offsets.popper[side] += (reference[side] + arrowSize) - popper[opSide];
926
- }
927
-
928
- // compute center of the popper
929
- var center = reference[side] + (arrowOffset || (reference[len] / 2) - (arrowSize / 2));
930
-
931
- var sideValue = center - popper[side];
932
-
933
- // prevent arrow from being placed not contiguously to its popper
934
- sideValue = Math.max(Math.min(popper[len] - arrowSize - 8, sideValue), 8);
935
- arrowStyle[side] = sideValue;
936
- arrowStyle[altSide] = ''; // make sure to remove any old style from the arrow
937
-
938
- data.offsets.arrow = arrowStyle;
939
- data.arrowElement = arrow;
940
-
941
- return data;
942
- };
943
-
944
-
945
- //
946
- // Helpers
947
- //
948
-
949
- /**
950
- * Get the outer sizes of the given element (offset size + margins)
951
- * @function
952
- * @ignore
953
- * @argument {Element} element
954
- * @returns {Object} object containing width and height properties
955
- */
956
- function getOuterSizes(element) {
957
- // NOTE: 1 DOM access here
958
- var _display = element.style.display, _visibility = element.style.visibility;
959
- element.style.display = 'block'; element.style.visibility = 'hidden';
960
- var calcWidthToForceRepaint = element.offsetWidth;
961
-
962
- // original method
963
- var styles = root.getComputedStyle(element);
964
- var x = parseFloat(styles.marginTop) + parseFloat(styles.marginBottom);
965
- var y = parseFloat(styles.marginLeft) + parseFloat(styles.marginRight);
966
- var result = { width: element.offsetWidth + y, height: element.offsetHeight + x };
967
-
968
- // reset element styles
969
- element.style.display = _display; element.style.visibility = _visibility;
970
- return result;
971
- }
972
-
973
- /**
974
- * Get the opposite placement of the given one/
975
- * @function
976
- * @ignore
977
- * @argument {String} placement
978
- * @returns {String} flipped placement
979
- */
980
- function getOppositePlacement(placement) {
981
- var hash = {left: 'right', right: 'left', bottom: 'top', top: 'bottom' };
982
- return placement.replace(/left|right|bottom|top/g, function(matched){
983
- return hash[matched];
984
- });
985
- }
986
-
987
- /**
988
- * Given the popper offsets, generate an output similar to getBoundingClientRect
989
- * @function
990
- * @ignore
991
- * @argument {Object} popperOffsets
992
- * @returns {Object} ClientRect like output
993
- */
994
- function getPopperClientRect(popperOffsets) {
995
- var offsets = Object.assign({}, popperOffsets);
996
- offsets.right = offsets.left + offsets.width;
997
- offsets.bottom = offsets.top + offsets.height;
998
- return offsets;
999
- }
1000
-
1001
- /**
1002
- * Given an array and the key to find, returns its index
1003
- * @function
1004
- * @ignore
1005
- * @argument {Array} arr
1006
- * @argument keyToFind
1007
- * @returns index or null
1008
- */
1009
- function getArrayKeyIndex(arr, keyToFind) {
1010
- var i = 0, key;
1011
- for (key in arr) {
1012
- if (arr[key] === keyToFind) {
1013
- return i;
1014
- }
1015
- i++;
1016
- }
1017
- return null;
1018
- }
1019
-
1020
- /**
1021
- * Get CSS computed property of the given element
1022
- * @function
1023
- * @ignore
1024
- * @argument {Eement} element
1025
- * @argument {String} property
1026
- */
1027
- function getStyleComputedProperty(element, property) {
1028
- // NOTE: 1 DOM access here
1029
- var css = root.getComputedStyle(element, null);
1030
- return css[property];
1031
- }
1032
-
1033
- /**
1034
- * Returns the offset parent of the given element
1035
- * @function
1036
- * @ignore
1037
- * @argument {Element} element
1038
- * @returns {Element} offset parent
1039
- */
1040
- function getOffsetParent(element) {
1041
- // NOTE: 1 DOM access here
1042
- var offsetParent = element.offsetParent;
1043
- return offsetParent === root.document.body || !offsetParent ? root.document.documentElement : offsetParent;
1044
- }
1045
-
1046
- /**
1047
- * Returns the scrolling parent of the given element
1048
- * @function
1049
- * @ignore
1050
- * @argument {Element} element
1051
- * @returns {Element} offset parent
1052
- */
1053
- function getScrollParent(element) {
1054
- var parent = element.parentNode;
1055
-
1056
- if (!parent) {
1057
- return element;
1058
- }
1059
-
1060
- if (parent === root.document) {
1061
- // Firefox puts the scrollTOp value on `documentElement` instead of `body`, we then check which of them is
1062
- // greater than 0 and return the proper element
1063
- if (root.document.body.scrollTop || root.document.body.scrollLeft) {
1064
- return root.document.body;
1065
- } else {
1066
- return root.document.documentElement;
1067
- }
1068
- }
1069
-
1070
- // Firefox want us to check `-x` and `-y` variations as well
1071
- if (
1072
- ['scroll', 'auto'].indexOf(getStyleComputedProperty(parent, 'overflow')) !== -1 ||
1073
- ['scroll', 'auto'].indexOf(getStyleComputedProperty(parent, 'overflow-x')) !== -1 ||
1074
- ['scroll', 'auto'].indexOf(getStyleComputedProperty(parent, 'overflow-y')) !== -1
1075
- ) {
1076
- // If the detected scrollParent is body, we perform an additional check on its parentNode
1077
- // in this way we'll get body if the browser is Chrome-ish, or documentElement otherwise
1078
- // fixes issue #65
1079
- return parent;
1080
- }
1081
- return getScrollParent(element.parentNode);
1082
- }
1083
-
1084
- /**
1085
- * Check if the given element is fixed or is inside a fixed parent
1086
- * @function
1087
- * @ignore
1088
- * @argument {Element} element
1089
- * @argument {Element} customContainer
1090
- * @returns {Boolean} answer to "isFixed?"
1091
- */
1092
- function isFixed(element) {
1093
- if (element === root.document.body) {
1094
- return false;
1095
- }
1096
- if (getStyleComputedProperty(element, 'position') === 'fixed') {
1097
- return true;
1098
- }
1099
- return element.parentNode ? isFixed(element.parentNode) : element;
1100
- }
1101
-
1102
- /**
1103
- * Set the style to the given popper
1104
- * @function
1105
- * @ignore
1106
- * @argument {Element} element - Element to apply the style to
1107
- * @argument {Object} styles - Object with a list of properties and values which will be applied to the element
1108
- */
1109
- function setStyle(element, styles) {
1110
- function is_numeric(n) {
1111
- return (n !== '' && !isNaN(parseFloat(n)) && isFinite(n));
1112
- }
1113
- Object.keys(styles).forEach(function(prop) {
1114
- var unit = '';
1115
- // add unit if the value is numeric and is one of the following
1116
- if (['width', 'height', 'top', 'right', 'bottom', 'left'].indexOf(prop) !== -1 && is_numeric(styles[prop])) {
1117
- unit = 'px';
1118
- }
1119
- element.style[prop] = styles[prop] + unit;
1120
- });
1121
- }
1122
-
1123
- /**
1124
- * Check if the given variable is a function
1125
- * @function
1126
- * @ignore
1127
- * @argument {*} functionToCheck - variable to check
1128
- * @returns {Boolean} answer to: is a function?
1129
- */
1130
- function isFunction(functionToCheck) {
1131
- var getType = {};
1132
- return functionToCheck && getType.toString.call(functionToCheck) === '[object Function]';
1133
- }
1134
-
1135
- /**
1136
- * Get the position of the given element, relative to its offset parent
1137
- * @function
1138
- * @ignore
1139
- * @param {Element} element
1140
- * @return {Object} position - Coordinates of the element and its `scrollTop`
1141
- */
1142
- function getOffsetRect(element) {
1143
- var elementRect = {
1144
- width: element.offsetWidth,
1145
- height: element.offsetHeight,
1146
- left: element.offsetLeft,
1147
- top: element.offsetTop
1148
- };
1149
-
1150
- elementRect.right = elementRect.left + elementRect.width;
1151
- elementRect.bottom = elementRect.top + elementRect.height;
1152
-
1153
- // position
1154
- return elementRect;
1155
- }
1156
-
1157
- /**
1158
- * Get bounding client rect of given element
1159
- * @function
1160
- * @ignore
1161
- * @param {HTMLElement} element
1162
- * @return {Object} client rect
1163
- */
1164
- function getBoundingClientRect(element) {
1165
- var rect = element.getBoundingClientRect();
1166
-
1167
- // whether the IE version is lower than 11
1168
- var isIE = navigator.userAgent.indexOf("MSIE") != -1;
1169
-
1170
- // fix ie document bounding top always 0 bug
1171
- var rectTop = isIE && element.tagName === 'HTML'
1172
- ? -element.scrollTop
1173
- : rect.top;
1174
-
1175
- return {
1176
- left: rect.left,
1177
- top: rectTop,
1178
- right: rect.right,
1179
- bottom: rect.bottom,
1180
- width: rect.right - rect.left,
1181
- height: rect.bottom - rectTop
1182
- };
1183
- }
1184
-
1185
- /**
1186
- * Given an element and one of its parents, return the offset
1187
- * @function
1188
- * @ignore
1189
- * @param {HTMLElement} element
1190
- * @param {HTMLElement} parent
1191
- * @return {Object} rect
1192
- */
1193
- function getOffsetRectRelativeToCustomParent(element, parent, fixed) {
1194
- var elementRect = getBoundingClientRect(element);
1195
- var parentRect = getBoundingClientRect(parent);
1196
-
1197
- if (fixed) {
1198
- var scrollParent = getScrollParent(parent);
1199
- parentRect.top += scrollParent.scrollTop;
1200
- parentRect.bottom += scrollParent.scrollTop;
1201
- parentRect.left += scrollParent.scrollLeft;
1202
- parentRect.right += scrollParent.scrollLeft;
1203
- }
1204
-
1205
- var rect = {
1206
- top: elementRect.top - parentRect.top ,
1207
- left: elementRect.left - parentRect.left ,
1208
- bottom: (elementRect.top - parentRect.top) + elementRect.height,
1209
- right: (elementRect.left - parentRect.left) + elementRect.width,
1210
- width: elementRect.width,
1211
- height: elementRect.height
1212
- };
1213
- return rect;
1214
- }
1215
-
1216
- /**
1217
- * Get the prefixed supported property name
1218
- * @function
1219
- * @ignore
1220
- * @argument {String} property (camelCase)
1221
- * @returns {String} prefixed property (camelCase)
1222
- */
1223
- function getSupportedPropertyName(property) {
1224
- var prefixes = ['', 'ms', 'webkit', 'moz', 'o'];
1225
-
1226
- for (var i = 0; i < prefixes.length; i++) {
1227
- var toCheck = prefixes[i] ? prefixes[i] + property.charAt(0).toUpperCase() + property.slice(1) : property;
1228
- if (typeof root.document.body.style[toCheck] !== 'undefined') {
1229
- return toCheck;
1230
- }
1231
- }
1232
- return null;
1233
- }
1234
-
1235
- /**
1236
- * The Object.assign() method is used to copy the values of all enumerable own properties from one or more source
1237
- * objects to a target object. It will return the target object.
1238
- * This polyfill doesn't support symbol properties, since ES5 doesn't have symbols anyway
1239
- * Source: https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Global_Objects/Object/assign
1240
- * @function
1241
- * @ignore
1242
- */
1243
- if (!Object.assign) {
1244
- Object.defineProperty(Object, 'assign', {
1245
- enumerable: false,
1246
- configurable: true,
1247
- writable: true,
1248
- value: function(target) {
1249
- if (target === undefined || target === null) {
1250
- throw new TypeError('Cannot convert first argument to object');
1251
- }
1252
-
1253
- var to = Object(target);
1254
- for (var i = 1; i < arguments.length; i++) {
1255
- var nextSource = arguments[i];
1256
- if (nextSource === undefined || nextSource === null) {
1257
- continue;
1258
- }
1259
- nextSource = Object(nextSource);
1260
-
1261
- var keysArray = Object.keys(nextSource);
1262
- for (var nextIndex = 0, len = keysArray.length; nextIndex < len; nextIndex++) {
1263
- var nextKey = keysArray[nextIndex];
1264
- var desc = Object.getOwnPropertyDescriptor(nextSource, nextKey);
1265
- if (desc !== undefined && desc.enumerable) {
1266
- to[nextKey] = nextSource[nextKey];
1267
- }
1268
- }
1269
- }
1270
- return to;
1271
- }
1272
- });
1273
- }
1274
-
1275
- return Popper;
1276
- }));
1
+ /**
2
+ * @fileOverview Kickass library to create and place poppers near their reference elements.
3
+ * @version {{version}}
4
+ * @license
5
+ * Copyright (c) 2016 Federico Zivolo and contributors
6
+ *
7
+ * Permission is hereby granted, free of charge, to any person obtaining a copy
8
+ * of this software and associated documentation files (the "Software"), to deal
9
+ * in the Software without restriction, including without limitation the rights
10
+ * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
11
+ * copies of the Software, and to permit persons to whom the Software is
12
+ * furnished to do so, subject to the following conditions:
13
+ *
14
+ * The above copyright notice and this permission notice shall be included in all
15
+ * copies or substantial portions of the Software.
16
+ *
17
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
18
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
19
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
20
+ * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
21
+ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
22
+ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
23
+ * SOFTWARE.
24
+ */
25
+
26
+ //
27
+ // Cross module loader
28
+ // Supported: Node, AMD, Browser globals
29
+ //
30
+ ;(function (root, factory) {
31
+ if (typeof define === 'function' && define.amd) {
32
+ // AMD. Register as an anonymous module.
33
+ define(factory);
34
+ } else if (typeof module === 'object' && module.exports) {
35
+ // Node. Does not work with strict CommonJS, but
36
+ // only CommonJS-like environments that support module.exports,
37
+ // like Node.
38
+ module.exports = factory();
39
+ } else {
40
+ // Browser globals (root is window)
41
+ root.Popper = factory();
42
+ }
43
+ }(this, function () {
44
+
45
+ 'use strict';
46
+
47
+ var root = window;
48
+
49
+ // default options
50
+ var DEFAULTS = {
51
+ // placement of the popper
52
+ placement: 'bottom',
53
+
54
+ gpuAcceleration: true,
55
+
56
+ // shift popper from its origin by the given amount of pixels (can be negative)
57
+ offset: 0,
58
+
59
+ // the element which will act as boundary of the popper
60
+ boundariesElement: 'viewport',
61
+
62
+ // amount of pixel used to define a minimum distance between the boundaries and the popper
63
+ boundariesPadding: 5,
64
+
65
+ // popper will try to prevent overflow following this order,
66
+ // by default, then, it could overflow on the left and on top of the boundariesElement
67
+ preventOverflowOrder: ['left', 'right', 'top', 'bottom'],
68
+
69
+ // the behavior used by flip to change the placement of the popper
70
+ flipBehavior: 'flip',
71
+
72
+ arrowElement: '[x-arrow]',
73
+
74
+ arrowOffset: 0,
75
+
76
+ // list of functions used to modify the offsets before they are applied to the popper
77
+ modifiers: [ 'shift', 'offset', 'preventOverflow', 'keepTogether', 'arrow', 'flip', 'applyStyle'],
78
+
79
+ modifiersIgnored: [],
80
+
81
+ forceAbsolute: false
82
+ };
83
+
84
+ /**
85
+ * Create a new Popper.js instance
86
+ * @constructor Popper
87
+ * @param {HTMLElement} reference - The reference element used to position the popper
88
+ * @param {HTMLElement|Object} popper
89
+ * The HTML element used as popper, or a configuration used to generate the popper.
90
+ * @param {String} [popper.tagName='div'] The tag name of the generated popper.
91
+ * @param {Array} [popper.classNames=['popper']] Array of classes to apply to the generated popper.
92
+ * @param {Array} [popper.attributes] Array of attributes to apply, specify `attr:value` to assign a value to it.
93
+ * @param {HTMLElement|String} [popper.parent=window.document.body] The parent element, given as HTMLElement or as query string.
94
+ * @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`.
95
+ * @param {String} [popper.contentType='text'] If `html`, the `content` will be parsed as HTML. If `node`, it will be appended as-is.
96
+ * @param {String} [popper.arrowTagName='div'] Same as `popper.tagName` but for the arrow element.
97
+ * @param {Array} [popper.arrowClassNames='popper__arrow'] Same as `popper.classNames` but for the arrow element.
98
+ * @param {String} [popper.arrowAttributes=['x-arrow']] Same as `popper.attributes` but for the arrow element.
99
+ * @param {Object} options
100
+ * @param {String} [options.placement=bottom]
101
+ * Placement of the popper accepted values: `top(-start, -end), right(-start, -end), bottom(-start, -right),
102
+ * left(-start, -end)`
103
+ *
104
+ * @param {HTMLElement|String} [options.arrowElement='[x-arrow]']
105
+ * The DOM Node used as arrow for the popper, or a CSS selector used to get the DOM node. It must be child of
106
+ * its parent Popper. Popper.js will apply to the given element the style required to align the arrow with its
107
+ * reference element.
108
+ * By default, it will look for a child node of the popper with the `x-arrow` attribute.
109
+ *
110
+ * @param {Boolean} [options.gpuAcceleration=true]
111
+ * When this property is set to true, the popper position will be applied using CSS3 translate3d, allowing the
112
+ * browser to use the GPU to accelerate the rendering.
113
+ * If set to false, the popper will be placed using `top` and `left` properties, not using the GPU.
114
+ *
115
+ * @param {Number} [options.offset=0]
116
+ * Amount of pixels the popper will be shifted (can be negative).
117
+ *
118
+ * @param {String|Element} [options.boundariesElement='viewport']
119
+ * The element which will define the boundaries of the popper position, the popper will never be placed outside
120
+ * of the defined boundaries (except if `keepTogether` is enabled)
121
+ *
122
+ * @param {Number} [options.boundariesPadding=5]
123
+ * Additional padding for the boundaries
124
+ *
125
+ * @param {Array} [options.preventOverflowOrder=['left', 'right', 'top', 'bottom']]
126
+ * Order used when Popper.js tries to avoid overflows from the boundaries, they will be checked in order,
127
+ * this means that the last ones will never overflow
128
+ *
129
+ * @param {String|Array} [options.flipBehavior='flip']
130
+ * The behavior used by the `flip` modifier to change the placement of the popper when the latter is trying to
131
+ * overlap its reference element. Defining `flip` as value, the placement will be flipped on
132
+ * its axis (`right - left`, `top - bottom`).
133
+ * You can even pass an array of placements (eg: `['right', 'left', 'top']` ) to manually specify
134
+ * how alter the placement when a flip is needed. (eg. in the above example, it would first flip from right to left,
135
+ * then, if even in its new placement, the popper is overlapping its reference element, it will be moved to top)
136
+ *
137
+ * @param {Array} [options.modifiers=[ 'shift', 'offset', 'preventOverflow', 'keepTogether', 'arrow', 'flip', 'applyStyle']]
138
+ * List of functions used to modify the data before they are applied to the popper, add your custom functions
139
+ * to this array to edit the offsets and placement.
140
+ * The function should reflect the @params and @returns of preventOverflow
141
+ *
142
+ * @param {Array} [options.modifiersIgnored=[]]
143
+ * Put here any built-in modifier name you want to exclude from the modifiers list
144
+ * The function should reflect the @params and @returns of preventOverflow
145
+ *
146
+ * @param {Boolean} [options.removeOnDestroy=false]
147
+ * Set to true if you want to automatically remove the popper when you call the `destroy` method.
148
+ */
149
+ function Popper(reference, popper, options) {
150
+ this._reference = reference.jquery ? reference[0] : reference;
151
+ this.state = {};
152
+
153
+ // if the popper variable is a configuration object, parse it to generate an HTMLElement
154
+ // generate a default popper if is not defined
155
+ var isNotDefined = typeof popper === 'undefined' || popper === null;
156
+ var isConfig = popper && Object.prototype.toString.call(popper) === '[object Object]';
157
+ if (isNotDefined || isConfig) {
158
+ this._popper = this.parse(isConfig ? popper : {});
159
+ }
160
+ // otherwise, use the given HTMLElement as popper
161
+ else {
162
+ this._popper = popper.jquery ? popper[0] : popper;
163
+ }
164
+
165
+ // with {} we create a new object with the options inside it
166
+ this._options = Object.assign({}, DEFAULTS, options);
167
+
168
+ // refactoring modifiers' list
169
+ this._options.modifiers = this._options.modifiers.map(function(modifier){
170
+ // remove ignored modifiers
171
+ if (this._options.modifiersIgnored.indexOf(modifier) !== -1) return;
172
+
173
+ // set the x-placement attribute before everything else because it could be used to add margins to the popper
174
+ // margins needs to be calculated to get the correct popper offsets
175
+ if (modifier === 'applyStyle') {
176
+ this._popper.setAttribute('x-placement', this._options.placement);
177
+ }
178
+
179
+ // return predefined modifier identified by string or keep the custom one
180
+ return this.modifiers[modifier] || modifier;
181
+ }.bind(this));
182
+
183
+ // make sure to apply the popper position before any computation
184
+ this.state.position = this._getPosition(this._popper, this._reference);
185
+ setStyle(this._popper, { position: this.state.position, top: 0 });
186
+
187
+ // fire the first update to position the popper in the right place
188
+ this.update();
189
+
190
+ // setup event listeners, they will take care of update the position in specific situations
191
+ this._setupEventListeners();
192
+ return this;
193
+ }
194
+
195
+
196
+ //
197
+ // Methods
198
+ //
199
+ /**
200
+ * Destroy the popper
201
+ * @method
202
+ * @memberof Popper
203
+ */
204
+ Popper.prototype.destroy = function() {
205
+ this._popper.removeAttribute('x-placement');
206
+ this._popper.style.left = '';
207
+ this._popper.style.position = '';
208
+ this._popper.style.top = '';
209
+ this._popper.style[getSupportedPropertyName('transform')] = '';
210
+ this._removeEventListeners();
211
+
212
+ // remove the popper if user explicity asked for the deletion on destroy
213
+ if (this._options.removeOnDestroy) {
214
+ this._popper.remove();
215
+ }
216
+ return this;
217
+ };
218
+
219
+ /**
220
+ * Updates the position of the popper, computing the new offsets and applying the new style
221
+ * @method
222
+ * @memberof Popper
223
+ */
224
+ Popper.prototype.update = function() {
225
+ var data = { instance: this, styles: {} };
226
+
227
+ // store placement inside the data object, modifiers will be able to edit `placement` if needed
228
+ // and refer to _originalPlacement to know the original value
229
+ data.placement = this._options.placement;
230
+ data._originalPlacement = this._options.placement;
231
+
232
+ // compute the popper and reference offsets and put them inside data.offsets
233
+ data.offsets = this._getOffsets(this._popper, this._reference, data.placement);
234
+
235
+ // get boundaries
236
+ data.boundaries = this._getBoundaries(data, this._options.boundariesPadding, this._options.boundariesElement);
237
+
238
+ data = this.runModifiers(data, this._options.modifiers);
239
+
240
+ if (typeof this.state.updateCallback === 'function') {
241
+ this.state.updateCallback(data);
242
+ }
243
+ };
244
+
245
+ /**
246
+ * If a function is passed, it will be executed after the initialization of popper with as first argument the Popper instance.
247
+ * @method
248
+ * @memberof Popper
249
+ * @param {Function} callback
250
+ */
251
+ Popper.prototype.onCreate = function(callback) {
252
+ // the createCallbacks return as first argument the popper instance
253
+ callback(this);
254
+ return this;
255
+ };
256
+
257
+ /**
258
+ * If a function is passed, it will be executed after each update of popper with as first argument the set of coordinates and informations
259
+ * used to style popper and its arrow.
260
+ * NOTE: it doesn't get fired on the first call of the `Popper.update()` method inside the `Popper` constructor!
261
+ * @method
262
+ * @memberof Popper
263
+ * @param {Function} callback
264
+ */
265
+ Popper.prototype.onUpdate = function(callback) {
266
+ this.state.updateCallback = callback;
267
+ return this;
268
+ };
269
+
270
+ /**
271
+ * Helper used to generate poppers from a configuration file
272
+ * @method
273
+ * @memberof Popper
274
+ * @param config {Object} configuration
275
+ * @returns {HTMLElement} popper
276
+ */
277
+ Popper.prototype.parse = function(config) {
278
+ var defaultConfig = {
279
+ tagName: 'div',
280
+ classNames: [ 'popper' ],
281
+ attributes: [],
282
+ parent: root.document.body,
283
+ content: '',
284
+ contentType: 'text',
285
+ arrowTagName: 'div',
286
+ arrowClassNames: [ 'popper__arrow' ],
287
+ arrowAttributes: [ 'x-arrow']
288
+ };
289
+ config = Object.assign({}, defaultConfig, config);
290
+
291
+ var d = root.document;
292
+
293
+ var popper = d.createElement(config.tagName);
294
+ addClassNames(popper, config.classNames);
295
+ addAttributes(popper, config.attributes);
296
+ if (config.contentType === 'node') {
297
+ popper.appendChild(config.content.jquery ? config.content[0] : config.content);
298
+ }else if (config.contentType === 'html') {
299
+ popper.innerHTML = config.content;
300
+ } else {
301
+ popper.textContent = config.content;
302
+ }
303
+
304
+ if (config.arrowTagName) {
305
+ var arrow = d.createElement(config.arrowTagName);
306
+ addClassNames(arrow, config.arrowClassNames);
307
+ addAttributes(arrow, config.arrowAttributes);
308
+ popper.appendChild(arrow);
309
+ }
310
+
311
+ var parent = config.parent.jquery ? config.parent[0] : config.parent;
312
+
313
+ // if the given parent is a string, use it to match an element
314
+ // if more than one element is matched, the first one will be used as parent
315
+ // if no elements are matched, the script will throw an error
316
+ if (typeof parent === 'string') {
317
+ parent = d.querySelectorAll(config.parent);
318
+ if (parent.length > 1) {
319
+ console.warn('WARNING: the given `parent` query(' + config.parent + ') matched more than one element, the first one will be used');
320
+ }
321
+ if (parent.length === 0) {
322
+ throw 'ERROR: the given `parent` doesn\'t exists!';
323
+ }
324
+ parent = parent[0];
325
+ }
326
+ // if the given parent is a DOM nodes list or an array of nodes with more than one element,
327
+ // the first one will be used as parent
328
+ if (parent.length > 1 && parent instanceof Element === false) {
329
+ console.warn('WARNING: you have passed as parent a list of elements, the first one will be used');
330
+ parent = parent[0];
331
+ }
332
+
333
+ // append the generated popper to its parent
334
+ parent.appendChild(popper);
335
+
336
+ return popper;
337
+
338
+ /**
339
+ * Adds class names to the given element
340
+ * @function
341
+ * @ignore
342
+ * @param {HTMLElement} target
343
+ * @param {Array} classes
344
+ */
345
+ function addClassNames(element, classNames) {
346
+ classNames.forEach(function(className) {
347
+ element.classList.add(className);
348
+ });
349
+ }
350
+
351
+ /**
352
+ * Adds attributes to the given element
353
+ * @function
354
+ * @ignore
355
+ * @param {HTMLElement} target
356
+ * @param {Array} attributes
357
+ * @example
358
+ * addAttributes(element, [ 'data-info:foobar' ]);
359
+ */
360
+ function addAttributes(element, attributes) {
361
+ attributes.forEach(function(attribute) {
362
+ element.setAttribute(attribute.split(':')[0], attribute.split(':')[1] || '');
363
+ });
364
+ }
365
+
366
+ };
367
+
368
+ /**
369
+ * Helper used to get the position which will be applied to the popper
370
+ * @method
371
+ * @memberof Popper
372
+ * @param config {HTMLElement} popper element
373
+ * @param reference {HTMLElement} reference element
374
+ * @returns {String} position
375
+ */
376
+ Popper.prototype._getPosition = function(popper, reference) {
377
+ var container = getOffsetParent(reference);
378
+
379
+ if (this._options.forceAbsolute) {
380
+ return 'absolute';
381
+ }
382
+
383
+ // Decide if the popper will be fixed
384
+ // If the reference element is inside a fixed context, the popper will be fixed as well to allow them to scroll together
385
+ var isParentFixed = isFixed(reference, container);
386
+ return isParentFixed ? 'fixed' : 'absolute';
387
+ };
388
+
389
+ /**
390
+ * Get offsets to the popper
391
+ * @method
392
+ * @memberof Popper
393
+ * @access private
394
+ * @param {Element} popper - the popper element
395
+ * @param {Element} reference - the reference element (the popper will be relative to this)
396
+ * @returns {Object} An object containing the offsets which will be applied to the popper
397
+ */
398
+ Popper.prototype._getOffsets = function(popper, reference, placement) {
399
+ placement = placement.split('-')[0];
400
+ var popperOffsets = {};
401
+
402
+ popperOffsets.position = this.state.position;
403
+ var isParentFixed = popperOffsets.position === 'fixed';
404
+
405
+ //
406
+ // Get reference element position
407
+ //
408
+ var referenceOffsets = getOffsetRectRelativeToCustomParent(reference, getOffsetParent(popper), isParentFixed);
409
+
410
+ //
411
+ // Get popper sizes
412
+ //
413
+ var popperRect = getOuterSizes(popper);
414
+
415
+ //
416
+ // Compute offsets of popper
417
+ //
418
+
419
+ // depending by the popper placement we have to compute its offsets slightly differently
420
+ if (['right', 'left'].indexOf(placement) !== -1) {
421
+ popperOffsets.top = referenceOffsets.top + referenceOffsets.height / 2 - popperRect.height / 2;
422
+ if (placement === 'left') {
423
+ popperOffsets.left = referenceOffsets.left - popperRect.width;
424
+ } else {
425
+ popperOffsets.left = referenceOffsets.right;
426
+ }
427
+ } else {
428
+ popperOffsets.left = referenceOffsets.left + referenceOffsets.width / 2 - popperRect.width / 2;
429
+ if (placement === 'top') {
430
+ popperOffsets.top = referenceOffsets.top - popperRect.height;
431
+ } else {
432
+ popperOffsets.top = referenceOffsets.bottom;
433
+ }
434
+ }
435
+
436
+ // Add width and height to our offsets object
437
+ popperOffsets.width = popperRect.width;
438
+ popperOffsets.height = popperRect.height;
439
+
440
+ return {
441
+ popper: popperOffsets,
442
+ reference: referenceOffsets
443
+ };
444
+ };
445
+
446
+
447
+ /**
448
+ * Setup needed event listeners used to update the popper position
449
+ * @method
450
+ * @memberof Popper
451
+ * @access private
452
+ */
453
+ Popper.prototype._setupEventListeners = function() {
454
+ // NOTE: 1 DOM access here
455
+ this.state.updateBound = this.update.bind(this);
456
+ root.addEventListener('resize', this.state.updateBound);
457
+ // if the boundariesElement is window we don't need to listen for the scroll event
458
+ if (this._options.boundariesElement !== 'window') {
459
+ var target = getScrollParent(this._reference);
460
+ // here it could be both `body` or `documentElement` thanks to Firefox, we then check both
461
+ if (target === root.document.body || target === root.document.documentElement) {
462
+ target = root;
463
+ }
464
+ target.addEventListener('scroll', this.state.updateBound);
465
+ this.state.scrollTarget = target;
466
+ }
467
+ };
468
+
469
+ /**
470
+ * Remove event listeners used to update the popper position
471
+ * @method
472
+ * @memberof Popper
473
+ * @access private
474
+ */
475
+ Popper.prototype._removeEventListeners = function() {
476
+ // NOTE: 1 DOM access here
477
+ root.removeEventListener('resize', this.state.updateBound);
478
+ if (this._options.boundariesElement !== 'window' && this.state.scrollTarget) {
479
+ this.state.scrollTarget.removeEventListener('scroll', this.state.updateBound);
480
+ this.state.scrollTarget = null;
481
+ }
482
+ this.state.updateBound = null;
483
+ };
484
+
485
+ /**
486
+ * Computed the boundaries limits and return them
487
+ * @method
488
+ * @memberof Popper
489
+ * @access private
490
+ * @param {Object} data - Object containing the property "offsets" generated by `_getOffsets`
491
+ * @param {Number} padding - Boundaries padding
492
+ * @param {Element} boundariesElement - Element used to define the boundaries
493
+ * @returns {Object} Coordinates of the boundaries
494
+ */
495
+ Popper.prototype._getBoundaries = function(data, padding, boundariesElement) {
496
+ // NOTE: 1 DOM access here
497
+ var boundaries = {};
498
+ var width, height;
499
+ if (boundariesElement === 'window') {
500
+ var body = root.document.body,
501
+ html = root.document.documentElement;
502
+
503
+ height = Math.max( body.scrollHeight, body.offsetHeight, html.clientHeight, html.scrollHeight, html.offsetHeight );
504
+ width = Math.max( body.scrollWidth, body.offsetWidth, html.clientWidth, html.scrollWidth, html.offsetWidth );
505
+
506
+ boundaries = {
507
+ top: 0,
508
+ right: width,
509
+ bottom: height,
510
+ left: 0
511
+ };
512
+ } else if (boundariesElement === 'viewport') {
513
+ var offsetParent = getOffsetParent(this._popper);
514
+ var scrollParent = getScrollParent(this._popper);
515
+ var offsetParentRect = getOffsetRect(offsetParent);
516
+
517
+ // Thanks the fucking native API, `document.body.scrollTop` & `document.documentElement.scrollTop`
518
+ var getScrollTopValue = function (element) {
519
+ return element == document.body ? Math.max(document.documentElement.scrollTop, document.body.scrollTop) : element.scrollTop;
520
+ }
521
+ var getScrollLeftValue = function (element) {
522
+ return element == document.body ? Math.max(document.documentElement.scrollLeft, document.body.scrollLeft) : element.scrollLeft;
523
+ }
524
+
525
+ // if the popper is fixed we don't have to substract scrolling from the boundaries
526
+ var scrollTop = data.offsets.popper.position === 'fixed' ? 0 : getScrollTopValue(scrollParent);
527
+ var scrollLeft = data.offsets.popper.position === 'fixed' ? 0 : getScrollLeftValue(scrollParent);
528
+
529
+ boundaries = {
530
+ top: 0 - (offsetParentRect.top - scrollTop),
531
+ right: root.document.documentElement.clientWidth - (offsetParentRect.left - scrollLeft),
532
+ bottom: root.document.documentElement.clientHeight - (offsetParentRect.top - scrollTop),
533
+ left: 0 - (offsetParentRect.left - scrollLeft)
534
+ };
535
+ } else {
536
+ if (getOffsetParent(this._popper) === boundariesElement) {
537
+ boundaries = {
538
+ top: 0,
539
+ left: 0,
540
+ right: boundariesElement.clientWidth,
541
+ bottom: boundariesElement.clientHeight
542
+ };
543
+ } else {
544
+ boundaries = getOffsetRect(boundariesElement);
545
+ }
546
+ }
547
+ boundaries.left += padding;
548
+ boundaries.right -= padding;
549
+ boundaries.top = boundaries.top + padding;
550
+ boundaries.bottom = boundaries.bottom - padding;
551
+ return boundaries;
552
+ };
553
+
554
+
555
+ /**
556
+ * Loop trough the list of modifiers and run them in order, each of them will then edit the data object
557
+ * @method
558
+ * @memberof Popper
559
+ * @access public
560
+ * @param {Object} data
561
+ * @param {Array} modifiers
562
+ * @param {Function} ends
563
+ */
564
+ Popper.prototype.runModifiers = function(data, modifiers, ends) {
565
+ var modifiersToRun = modifiers.slice();
566
+ if (ends !== undefined) {
567
+ modifiersToRun = this._options.modifiers.slice(0, getArrayKeyIndex(this._options.modifiers, ends));
568
+ }
569
+
570
+ modifiersToRun.forEach(function(modifier) {
571
+ if (isFunction(modifier)) {
572
+ data = modifier.call(this, data);
573
+ }
574
+ }.bind(this));
575
+
576
+ return data;
577
+ };
578
+
579
+ /**
580
+ * Helper used to know if the given modifier depends from another one.
581
+ * @method
582
+ * @memberof Popper
583
+ * @param {String} requesting - name of requesting modifier
584
+ * @param {String} requested - name of requested modifier
585
+ * @returns {Boolean}
586
+ */
587
+ Popper.prototype.isModifierRequired = function(requesting, requested) {
588
+ var index = getArrayKeyIndex(this._options.modifiers, requesting);
589
+ return !!this._options.modifiers.slice(0, index).filter(function(modifier) {
590
+ return modifier === requested;
591
+ }).length;
592
+ };
593
+
594
+ //
595
+ // Modifiers
596
+ //
597
+
598
+ /**
599
+ * Modifiers list
600
+ * @namespace Popper.modifiers
601
+ * @memberof Popper
602
+ * @type {Object}
603
+ */
604
+ Popper.prototype.modifiers = {};
605
+
606
+ /**
607
+ * Apply the computed styles to the popper element
608
+ * @method
609
+ * @memberof Popper.modifiers
610
+ * @argument {Object} data - The data object generated by `update` method
611
+ * @returns {Object} The same data object
612
+ */
613
+ Popper.prototype.modifiers.applyStyle = function(data) {
614
+ // apply the final offsets to the popper
615
+ // NOTE: 1 DOM access here
616
+ var styles = {
617
+ position: data.offsets.popper.position
618
+ };
619
+
620
+ // round top and left to avoid blurry text
621
+ var left = Math.round(data.offsets.popper.left);
622
+ var top = Math.round(data.offsets.popper.top);
623
+
624
+ // if gpuAcceleration is set to true and transform is supported, we use `translate3d` to apply the position to the popper
625
+ // we automatically use the supported prefixed version if needed
626
+ var prefixedProperty;
627
+ if (this._options.gpuAcceleration && (prefixedProperty = getSupportedPropertyName('transform'))) {
628
+ styles[prefixedProperty] = 'translate3d(' + left + 'px, ' + top + 'px, 0)';
629
+ styles.top = 0;
630
+ styles.left = 0;
631
+ }
632
+ // othwerise, we use the standard `left` and `top` properties
633
+ else {
634
+ styles.left =left;
635
+ styles.top = top;
636
+ }
637
+
638
+ // any property present in `data.styles` will be applied to the popper,
639
+ // in this way we can make the 3rd party modifiers add custom styles to it
640
+ // Be aware, modifiers could override the properties defined in the previous
641
+ // lines of this modifier!
642
+ Object.assign(styles, data.styles);
643
+
644
+ setStyle(this._popper, styles);
645
+
646
+ // set an attribute which will be useful to style the tooltip (use it to properly position its arrow)
647
+ // NOTE: 1 DOM access here
648
+ this._popper.setAttribute('x-placement', data.placement);
649
+
650
+ // if the arrow modifier is required and the arrow style has been computed, apply the arrow style
651
+ if (this.isModifierRequired(this.modifiers.applyStyle, this.modifiers.arrow) && data.offsets.arrow) {
652
+ setStyle(data.arrowElement, data.offsets.arrow);
653
+ }
654
+
655
+ return data;
656
+ };
657
+
658
+ /**
659
+ * Modifier used to shift the popper on the start or end of its reference element side
660
+ * @method
661
+ * @memberof Popper.modifiers
662
+ * @argument {Object} data - The data object generated by `update` method
663
+ * @returns {Object} The data object, properly modified
664
+ */
665
+ Popper.prototype.modifiers.shift = function(data) {
666
+ var placement = data.placement;
667
+ var basePlacement = placement.split('-')[0];
668
+ var shiftVariation = placement.split('-')[1];
669
+
670
+ // if shift shiftVariation is specified, run the modifier
671
+ if (shiftVariation) {
672
+ var reference = data.offsets.reference;
673
+ var popper = getPopperClientRect(data.offsets.popper);
674
+
675
+ var shiftOffsets = {
676
+ y: {
677
+ start: { top: reference.top },
678
+ end: { top: reference.top + reference.height - popper.height }
679
+ },
680
+ x: {
681
+ start: { left: reference.left },
682
+ end: { left: reference.left + reference.width - popper.width }
683
+ }
684
+ };
685
+
686
+ var axis = ['bottom', 'top'].indexOf(basePlacement) !== -1 ? 'x' : 'y';
687
+
688
+ data.offsets.popper = Object.assign(popper, shiftOffsets[axis][shiftVariation]);
689
+ }
690
+
691
+ return data;
692
+ };
693
+
694
+
695
+ /**
696
+ * Modifier used to make sure the popper does not overflows from it's boundaries
697
+ * @method
698
+ * @memberof Popper.modifiers
699
+ * @argument {Object} data - The data object generated by `update` method
700
+ * @returns {Object} The data object, properly modified
701
+ */
702
+ Popper.prototype.modifiers.preventOverflow = function(data) {
703
+ var order = this._options.preventOverflowOrder;
704
+ var popper = getPopperClientRect(data.offsets.popper);
705
+
706
+ var check = {
707
+ left: function() {
708
+ var left = popper.left;
709
+ if (popper.left < data.boundaries.left) {
710
+ left = Math.max(popper.left, data.boundaries.left);
711
+ }
712
+ return { left: left };
713
+ },
714
+ right: function() {
715
+ var left = popper.left;
716
+ if (popper.right > data.boundaries.right) {
717
+ left = Math.min(popper.left, data.boundaries.right - popper.width);
718
+ }
719
+ return { left: left };
720
+ },
721
+ top: function() {
722
+ var top = popper.top;
723
+ if (popper.top < data.boundaries.top) {
724
+ top = Math.max(popper.top, data.boundaries.top);
725
+ }
726
+ return { top: top };
727
+ },
728
+ bottom: function() {
729
+ var top = popper.top;
730
+ if (popper.bottom > data.boundaries.bottom) {
731
+ top = Math.min(popper.top, data.boundaries.bottom - popper.height);
732
+ }
733
+ return { top: top };
734
+ }
735
+ };
736
+
737
+ order.forEach(function(direction) {
738
+ data.offsets.popper = Object.assign(popper, check[direction]());
739
+ });
740
+
741
+ return data;
742
+ };
743
+
744
+ /**
745
+ * Modifier used to make sure the popper is always near its reference
746
+ * @method
747
+ * @memberof Popper.modifiers
748
+ * @argument {Object} data - The data object generated by _update method
749
+ * @returns {Object} The data object, properly modified
750
+ */
751
+ Popper.prototype.modifiers.keepTogether = function(data) {
752
+ var popper = getPopperClientRect(data.offsets.popper);
753
+ var reference = data.offsets.reference;
754
+ var f = Math.floor;
755
+
756
+ if (popper.right < f(reference.left)) {
757
+ data.offsets.popper.left = f(reference.left) - popper.width;
758
+ }
759
+ if (popper.left > f(reference.right)) {
760
+ data.offsets.popper.left = f(reference.right);
761
+ }
762
+ if (popper.bottom < f(reference.top)) {
763
+ data.offsets.popper.top = f(reference.top) - popper.height;
764
+ }
765
+ if (popper.top > f(reference.bottom)) {
766
+ data.offsets.popper.top = f(reference.bottom);
767
+ }
768
+
769
+ return data;
770
+ };
771
+
772
+ /**
773
+ * Modifier used to flip the placement of the popper when the latter is starting overlapping its reference element.
774
+ * Requires the `preventOverflow` modifier before it in order to work.
775
+ * **NOTE:** This modifier will run all its previous modifiers everytime it tries to flip the popper!
776
+ * @method
777
+ * @memberof Popper.modifiers
778
+ * @argument {Object} data - The data object generated by _update method
779
+ * @returns {Object} The data object, properly modified
780
+ */
781
+ Popper.prototype.modifiers.flip = function(data) {
782
+ // check if preventOverflow is in the list of modifiers before the flip modifier.
783
+ // otherwise flip would not work as expected.
784
+ if (!this.isModifierRequired(this.modifiers.flip, this.modifiers.preventOverflow)) {
785
+ console.warn('WARNING: preventOverflow modifier is required by flip modifier in order to work, be sure to include it before flip!');
786
+ return data;
787
+ }
788
+
789
+ if (data.flipped && data.placement === data._originalPlacement) {
790
+ // seems like flip is trying to loop, probably there's not enough space on any of the flippable sides
791
+ return data;
792
+ }
793
+
794
+ var placement = data.placement.split('-')[0];
795
+ var placementOpposite = getOppositePlacement(placement);
796
+ var variation = data.placement.split('-')[1] || '';
797
+
798
+ var flipOrder = [];
799
+ if(this._options.flipBehavior === 'flip') {
800
+ flipOrder = [
801
+ placement,
802
+ placementOpposite
803
+ ];
804
+ } else {
805
+ flipOrder = this._options.flipBehavior;
806
+ }
807
+
808
+ flipOrder.forEach(function(step, index) {
809
+ if (placement !== step || flipOrder.length === index + 1) {
810
+ return;
811
+ }
812
+
813
+ placement = data.placement.split('-')[0];
814
+ placementOpposite = getOppositePlacement(placement);
815
+
816
+ var popperOffsets = getPopperClientRect(data.offsets.popper);
817
+
818
+ // this boolean is used to distinguish right and bottom from top and left
819
+ // they need different computations to get flipped
820
+ var a = ['right', 'bottom'].indexOf(placement) !== -1;
821
+
822
+ // using Math.floor because the reference offsets may contain decimals we are not going to consider here
823
+ if (
824
+ a && Math.floor(data.offsets.reference[placement]) > Math.floor(popperOffsets[placementOpposite]) ||
825
+ !a && Math.floor(data.offsets.reference[placement]) < Math.floor(popperOffsets[placementOpposite])
826
+ ) {
827
+ // we'll use this boolean to detect any flip loop
828
+ data.flipped = true;
829
+ data.placement = flipOrder[index + 1];
830
+ if (variation) {
831
+ data.placement += '-' + variation;
832
+ }
833
+ data.offsets.popper = this._getOffsets(this._popper, this._reference, data.placement).popper;
834
+
835
+ data = this.runModifiers(data, this._options.modifiers, this._flip);
836
+ }
837
+ }.bind(this));
838
+ return data;
839
+ };
840
+
841
+ /**
842
+ * Modifier used to add an offset to the popper, useful if you more granularity positioning your popper.
843
+ * The offsets will shift the popper on the side of its reference element.
844
+ * @method
845
+ * @memberof Popper.modifiers
846
+ * @argument {Object} data - The data object generated by _update method
847
+ * @returns {Object} The data object, properly modified
848
+ */
849
+ Popper.prototype.modifiers.offset = function(data) {
850
+ var offset = this._options.offset;
851
+ var popper = data.offsets.popper;
852
+
853
+ if (data.placement.indexOf('left') !== -1) {
854
+ popper.top -= offset;
855
+ }
856
+ else if (data.placement.indexOf('right') !== -1) {
857
+ popper.top += offset;
858
+ }
859
+ else if (data.placement.indexOf('top') !== -1) {
860
+ popper.left -= offset;
861
+ }
862
+ else if (data.placement.indexOf('bottom') !== -1) {
863
+ popper.left += offset;
864
+ }
865
+ return data;
866
+ };
867
+
868
+ /**
869
+ * 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
870
+ * It will use the CSS outer size of the arrow element to know how many pixels of conjuction are needed
871
+ * @method
872
+ * @memberof Popper.modifiers
873
+ * @argument {Object} data - The data object generated by _update method
874
+ * @returns {Object} The data object, properly modified
875
+ */
876
+ Popper.prototype.modifiers.arrow = function(data) {
877
+ var arrow = this._options.arrowElement;
878
+ var arrowOffset = this._options.arrowOffset;
879
+
880
+ // if the arrowElement is a string, suppose it's a CSS selector
881
+ if (typeof arrow === 'string') {
882
+ arrow = this._popper.querySelector(arrow);
883
+ }
884
+
885
+ // if arrow element is not found, don't run the modifier
886
+ if (!arrow) {
887
+ return data;
888
+ }
889
+
890
+ // the arrow element must be child of its popper
891
+ if (!this._popper.contains(arrow)) {
892
+ console.warn('WARNING: `arrowElement` must be child of its popper element!');
893
+ return data;
894
+ }
895
+
896
+ // arrow depends on keepTogether in order to work
897
+ if (!this.isModifierRequired(this.modifiers.arrow, this.modifiers.keepTogether)) {
898
+ console.warn('WARNING: keepTogether modifier is required by arrow modifier in order to work, be sure to include it before arrow!');
899
+ return data;
900
+ }
901
+
902
+ var arrowStyle = {};
903
+ var placement = data.placement.split('-')[0];
904
+ var popper = getPopperClientRect(data.offsets.popper);
905
+ var reference = data.offsets.reference;
906
+ var isVertical = ['left', 'right'].indexOf(placement) !== -1;
907
+
908
+ var len = isVertical ? 'height' : 'width';
909
+ var side = isVertical ? 'top' : 'left';
910
+ var translate = isVertical ? 'translateY' : 'translateX';
911
+ var altSide = isVertical ? 'left' : 'top';
912
+ var opSide = isVertical ? 'bottom' : 'right';
913
+ var arrowSize = getOuterSizes(arrow)[len];
914
+
915
+ //
916
+ // extends keepTogether behavior making sure the popper and its reference have enough pixels in conjuction
917
+ //
918
+
919
+ // top/left side
920
+ if (reference[opSide] - arrowSize < popper[side]) {
921
+ data.offsets.popper[side] -= popper[side] - (reference[opSide] - arrowSize);
922
+ }
923
+ // bottom/right side
924
+ if (reference[side] + arrowSize > popper[opSide]) {
925
+ data.offsets.popper[side] += (reference[side] + arrowSize) - popper[opSide];
926
+ }
927
+
928
+ // compute center of the popper
929
+ var center = reference[side] + (arrowOffset || (reference[len] / 2) - (arrowSize / 2));
930
+
931
+ var sideValue = center - popper[side];
932
+
933
+ // prevent arrow from being placed not contiguously to its popper
934
+ sideValue = Math.max(Math.min(popper[len] - arrowSize - 8, sideValue), 8);
935
+ arrowStyle[side] = sideValue;
936
+ arrowStyle[altSide] = ''; // make sure to remove any old style from the arrow
937
+
938
+ data.offsets.arrow = arrowStyle;
939
+ data.arrowElement = arrow;
940
+
941
+ return data;
942
+ };
943
+
944
+
945
+ //
946
+ // Helpers
947
+ //
948
+
949
+ /**
950
+ * Get the outer sizes of the given element (offset size + margins)
951
+ * @function
952
+ * @ignore
953
+ * @argument {Element} element
954
+ * @returns {Object} object containing width and height properties
955
+ */
956
+ function getOuterSizes(element) {
957
+ // NOTE: 1 DOM access here
958
+ var _display = element.style.display, _visibility = element.style.visibility;
959
+ element.style.display = 'block'; element.style.visibility = 'hidden';
960
+ var calcWidthToForceRepaint = element.offsetWidth;
961
+
962
+ // original method
963
+ var styles = root.getComputedStyle(element);
964
+ var x = parseFloat(styles.marginTop) + parseFloat(styles.marginBottom);
965
+ var y = parseFloat(styles.marginLeft) + parseFloat(styles.marginRight);
966
+ var result = { width: element.offsetWidth + y, height: element.offsetHeight + x };
967
+
968
+ // reset element styles
969
+ element.style.display = _display; element.style.visibility = _visibility;
970
+ return result;
971
+ }
972
+
973
+ /**
974
+ * Get the opposite placement of the given one/
975
+ * @function
976
+ * @ignore
977
+ * @argument {String} placement
978
+ * @returns {String} flipped placement
979
+ */
980
+ function getOppositePlacement(placement) {
981
+ var hash = {left: 'right', right: 'left', bottom: 'top', top: 'bottom' };
982
+ return placement.replace(/left|right|bottom|top/g, function(matched){
983
+ return hash[matched];
984
+ });
985
+ }
986
+
987
+ /**
988
+ * Given the popper offsets, generate an output similar to getBoundingClientRect
989
+ * @function
990
+ * @ignore
991
+ * @argument {Object} popperOffsets
992
+ * @returns {Object} ClientRect like output
993
+ */
994
+ function getPopperClientRect(popperOffsets) {
995
+ var offsets = Object.assign({}, popperOffsets);
996
+ offsets.right = offsets.left + offsets.width;
997
+ offsets.bottom = offsets.top + offsets.height;
998
+ return offsets;
999
+ }
1000
+
1001
+ /**
1002
+ * Given an array and the key to find, returns its index
1003
+ * @function
1004
+ * @ignore
1005
+ * @argument {Array} arr
1006
+ * @argument keyToFind
1007
+ * @returns index or null
1008
+ */
1009
+ function getArrayKeyIndex(arr, keyToFind) {
1010
+ var i = 0, key;
1011
+ for (key in arr) {
1012
+ if (arr[key] === keyToFind) {
1013
+ return i;
1014
+ }
1015
+ i++;
1016
+ }
1017
+ return null;
1018
+ }
1019
+
1020
+ /**
1021
+ * Get CSS computed property of the given element
1022
+ * @function
1023
+ * @ignore
1024
+ * @argument {Eement} element
1025
+ * @argument {String} property
1026
+ */
1027
+ function getStyleComputedProperty(element, property) {
1028
+ // NOTE: 1 DOM access here
1029
+ var css = root.getComputedStyle(element, null);
1030
+ return css[property];
1031
+ }
1032
+
1033
+ /**
1034
+ * Returns the offset parent of the given element
1035
+ * @function
1036
+ * @ignore
1037
+ * @argument {Element} element
1038
+ * @returns {Element} offset parent
1039
+ */
1040
+ function getOffsetParent(element) {
1041
+ // NOTE: 1 DOM access here
1042
+ var offsetParent = element.offsetParent;
1043
+ return offsetParent === root.document.body || !offsetParent ? root.document.documentElement : offsetParent;
1044
+ }
1045
+
1046
+ /**
1047
+ * Returns the scrolling parent of the given element
1048
+ * @function
1049
+ * @ignore
1050
+ * @argument {Element} element
1051
+ * @returns {Element} offset parent
1052
+ */
1053
+ function getScrollParent(element) {
1054
+ var parent = element.parentNode;
1055
+
1056
+ if (!parent) {
1057
+ return element;
1058
+ }
1059
+
1060
+ if (parent === root.document) {
1061
+ // Firefox puts the scrollTOp value on `documentElement` instead of `body`, we then check which of them is
1062
+ // greater than 0 and return the proper element
1063
+ if (root.document.body.scrollTop || root.document.body.scrollLeft) {
1064
+ return root.document.body;
1065
+ } else {
1066
+ return root.document.documentElement;
1067
+ }
1068
+ }
1069
+
1070
+ // Firefox want us to check `-x` and `-y` variations as well
1071
+ if (
1072
+ ['scroll', 'auto'].indexOf(getStyleComputedProperty(parent, 'overflow')) !== -1 ||
1073
+ ['scroll', 'auto'].indexOf(getStyleComputedProperty(parent, 'overflow-x')) !== -1 ||
1074
+ ['scroll', 'auto'].indexOf(getStyleComputedProperty(parent, 'overflow-y')) !== -1
1075
+ ) {
1076
+ // If the detected scrollParent is body, we perform an additional check on its parentNode
1077
+ // in this way we'll get body if the browser is Chrome-ish, or documentElement otherwise
1078
+ // fixes issue #65
1079
+ return parent;
1080
+ }
1081
+ return getScrollParent(element.parentNode);
1082
+ }
1083
+
1084
+ /**
1085
+ * Check if the given element is fixed or is inside a fixed parent
1086
+ * @function
1087
+ * @ignore
1088
+ * @argument {Element} element
1089
+ * @argument {Element} customContainer
1090
+ * @returns {Boolean} answer to "isFixed?"
1091
+ */
1092
+ function isFixed(element) {
1093
+ if (element === root.document.body) {
1094
+ return false;
1095
+ }
1096
+ if (getStyleComputedProperty(element, 'position') === 'fixed') {
1097
+ return true;
1098
+ }
1099
+ return element.parentNode ? isFixed(element.parentNode) : element;
1100
+ }
1101
+
1102
+ /**
1103
+ * Set the style to the given popper
1104
+ * @function
1105
+ * @ignore
1106
+ * @argument {Element} element - Element to apply the style to
1107
+ * @argument {Object} styles - Object with a list of properties and values which will be applied to the element
1108
+ */
1109
+ function setStyle(element, styles) {
1110
+ function is_numeric(n) {
1111
+ return (n !== '' && !isNaN(parseFloat(n)) && isFinite(n));
1112
+ }
1113
+ Object.keys(styles).forEach(function(prop) {
1114
+ var unit = '';
1115
+ // add unit if the value is numeric and is one of the following
1116
+ if (['width', 'height', 'top', 'right', 'bottom', 'left'].indexOf(prop) !== -1 && is_numeric(styles[prop])) {
1117
+ unit = 'px';
1118
+ }
1119
+ element.style[prop] = styles[prop] + unit;
1120
+ });
1121
+ }
1122
+
1123
+ /**
1124
+ * Check if the given variable is a function
1125
+ * @function
1126
+ * @ignore
1127
+ * @argument {*} functionToCheck - variable to check
1128
+ * @returns {Boolean} answer to: is a function?
1129
+ */
1130
+ function isFunction(functionToCheck) {
1131
+ var getType = {};
1132
+ return functionToCheck && getType.toString.call(functionToCheck) === '[object Function]';
1133
+ }
1134
+
1135
+ /**
1136
+ * Get the position of the given element, relative to its offset parent
1137
+ * @function
1138
+ * @ignore
1139
+ * @param {Element} element
1140
+ * @return {Object} position - Coordinates of the element and its `scrollTop`
1141
+ */
1142
+ function getOffsetRect(element) {
1143
+ var elementRect = {
1144
+ width: element.offsetWidth,
1145
+ height: element.offsetHeight,
1146
+ left: element.offsetLeft,
1147
+ top: element.offsetTop
1148
+ };
1149
+
1150
+ elementRect.right = elementRect.left + elementRect.width;
1151
+ elementRect.bottom = elementRect.top + elementRect.height;
1152
+
1153
+ // position
1154
+ return elementRect;
1155
+ }
1156
+
1157
+ /**
1158
+ * Get bounding client rect of given element
1159
+ * @function
1160
+ * @ignore
1161
+ * @param {HTMLElement} element
1162
+ * @return {Object} client rect
1163
+ */
1164
+ function getBoundingClientRect(element) {
1165
+ var rect = element.getBoundingClientRect();
1166
+
1167
+ // whether the IE version is lower than 11
1168
+ var isIE = navigator.userAgent.indexOf("MSIE") != -1;
1169
+
1170
+ // fix ie document bounding top always 0 bug
1171
+ var rectTop = isIE && element.tagName === 'HTML'
1172
+ ? -element.scrollTop
1173
+ : rect.top;
1174
+
1175
+ return {
1176
+ left: rect.left,
1177
+ top: rectTop,
1178
+ right: rect.right,
1179
+ bottom: rect.bottom,
1180
+ width: rect.right - rect.left,
1181
+ height: rect.bottom - rectTop
1182
+ };
1183
+ }
1184
+
1185
+ /**
1186
+ * Given an element and one of its parents, return the offset
1187
+ * @function
1188
+ * @ignore
1189
+ * @param {HTMLElement} element
1190
+ * @param {HTMLElement} parent
1191
+ * @return {Object} rect
1192
+ */
1193
+ function getOffsetRectRelativeToCustomParent(element, parent, fixed) {
1194
+ var elementRect = getBoundingClientRect(element);
1195
+ var parentRect = getBoundingClientRect(parent);
1196
+
1197
+ if (fixed) {
1198
+ var scrollParent = getScrollParent(parent);
1199
+ parentRect.top += scrollParent.scrollTop;
1200
+ parentRect.bottom += scrollParent.scrollTop;
1201
+ parentRect.left += scrollParent.scrollLeft;
1202
+ parentRect.right += scrollParent.scrollLeft;
1203
+ }
1204
+
1205
+ var rect = {
1206
+ top: elementRect.top - parentRect.top ,
1207
+ left: elementRect.left - parentRect.left ,
1208
+ bottom: (elementRect.top - parentRect.top) + elementRect.height,
1209
+ right: (elementRect.left - parentRect.left) + elementRect.width,
1210
+ width: elementRect.width,
1211
+ height: elementRect.height
1212
+ };
1213
+ return rect;
1214
+ }
1215
+
1216
+ /**
1217
+ * Get the prefixed supported property name
1218
+ * @function
1219
+ * @ignore
1220
+ * @argument {String} property (camelCase)
1221
+ * @returns {String} prefixed property (camelCase)
1222
+ */
1223
+ function getSupportedPropertyName(property) {
1224
+ var prefixes = ['', 'ms', 'webkit', 'moz', 'o'];
1225
+
1226
+ for (var i = 0; i < prefixes.length; i++) {
1227
+ var toCheck = prefixes[i] ? prefixes[i] + property.charAt(0).toUpperCase() + property.slice(1) : property;
1228
+ if (typeof root.document.body.style[toCheck] !== 'undefined') {
1229
+ return toCheck;
1230
+ }
1231
+ }
1232
+ return null;
1233
+ }
1234
+
1235
+ /**
1236
+ * The Object.assign() method is used to copy the values of all enumerable own properties from one or more source
1237
+ * objects to a target object. It will return the target object.
1238
+ * This polyfill doesn't support symbol properties, since ES5 doesn't have symbols anyway
1239
+ * Source: https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Global_Objects/Object/assign
1240
+ * @function
1241
+ * @ignore
1242
+ */
1243
+ if (!Object.assign) {
1244
+ Object.defineProperty(Object, 'assign', {
1245
+ enumerable: false,
1246
+ configurable: true,
1247
+ writable: true,
1248
+ value: function(target) {
1249
+ if (target === undefined || target === null) {
1250
+ throw new TypeError('Cannot convert first argument to object');
1251
+ }
1252
+
1253
+ var to = Object(target);
1254
+ for (var i = 1; i < arguments.length; i++) {
1255
+ var nextSource = arguments[i];
1256
+ if (nextSource === undefined || nextSource === null) {
1257
+ continue;
1258
+ }
1259
+ nextSource = Object(nextSource);
1260
+
1261
+ var keysArray = Object.keys(nextSource);
1262
+ for (var nextIndex = 0, len = keysArray.length; nextIndex < len; nextIndex++) {
1263
+ var nextKey = keysArray[nextIndex];
1264
+ var desc = Object.getOwnPropertyDescriptor(nextSource, nextKey);
1265
+ if (desc !== undefined && desc.enumerable) {
1266
+ to[nextKey] = nextSource[nextKey];
1267
+ }
1268
+ }
1269
+ }
1270
+ return to;
1271
+ }
1272
+ });
1273
+ }
1274
+
1275
+ return Popper;
1276
+ }));