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