buefy 0.7.9 → 0.8.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (347) hide show
  1. package/CHANGELOG.md +82 -0
  2. package/dist/buefy.css +13759 -8263
  3. package/dist/buefy.js +9073 -14866
  4. package/dist/buefy.min.css +1 -5
  5. package/dist/buefy.min.js +2 -2
  6. package/dist/cjs/autocomplete.js +22 -0
  7. package/dist/cjs/button.js +106 -0
  8. package/dist/cjs/checkbox.js +135 -0
  9. package/dist/cjs/chunk-07fe6fc0.js +247 -0
  10. package/dist/cjs/chunk-0af453a7.js +105 -0
  11. package/dist/cjs/chunk-0e89e51b.js +394 -0
  12. package/dist/cjs/chunk-13e039f5.js +104 -0
  13. package/dist/cjs/chunk-143d9e6d.js +404 -0
  14. package/dist/cjs/chunk-19ebd649.js +114 -0
  15. package/dist/cjs/chunk-1b1231ce.js +94 -0
  16. package/dist/cjs/chunk-1e6abfcf.js +94 -0
  17. package/dist/cjs/chunk-28d164b1.js +172 -0
  18. package/dist/cjs/chunk-3396605d.js +394 -0
  19. package/dist/cjs/chunk-364a37a0.js +404 -0
  20. package/dist/cjs/chunk-3b066933.js +103 -0
  21. package/dist/cjs/chunk-3dffe6e7.js +54 -0
  22. package/dist/cjs/chunk-4a03b064.js +199 -0
  23. package/dist/cjs/chunk-50b06939.js +153 -0
  24. package/dist/cjs/chunk-52623128.js +105 -0
  25. package/dist/cjs/chunk-53d4f332.js +94 -0
  26. package/dist/cjs/chunk-544a95da.js +404 -0
  27. package/dist/cjs/chunk-545f01b1.js +49 -0
  28. package/dist/cjs/chunk-59b91990.js +64 -0
  29. package/dist/cjs/chunk-5b2a3329.js +394 -0
  30. package/dist/cjs/chunk-60061aa8.js +172 -0
  31. package/dist/cjs/chunk-67658e54.js +404 -0
  32. package/dist/cjs/chunk-6963026a.js +86 -0
  33. package/dist/cjs/chunk-6cece6b7.js +140 -0
  34. package/dist/cjs/chunk-6d6465c1.js +140 -0
  35. package/dist/cjs/chunk-6e9c0aca.js +94 -0
  36. package/dist/cjs/chunk-77f69fca.js +106 -0
  37. package/dist/cjs/chunk-7a25d736.js +114 -0
  38. package/dist/cjs/chunk-876befa8.js +247 -0
  39. package/dist/cjs/chunk-8985ffff.js +105 -0
  40. package/dist/cjs/chunk-8a05c8c9.js +207 -0
  41. package/dist/cjs/chunk-90407463.js +258 -0
  42. package/dist/cjs/chunk-956525c9.js +106 -0
  43. package/dist/cjs/chunk-96ce35a2.js +114 -0
  44. package/dist/cjs/chunk-9da1d120.js +86 -0
  45. package/dist/cjs/chunk-9f6a8079.js +54 -0
  46. package/dist/cjs/chunk-a60dc21d.js +281 -0
  47. package/dist/cjs/chunk-b628277d.js +199 -0
  48. package/dist/cjs/chunk-c146745e.js +153 -0
  49. package/dist/cjs/chunk-c2aec7a9.js +547 -0
  50. package/dist/cjs/chunk-c9641331.js +86 -0
  51. package/dist/cjs/chunk-d492406b.js +172 -0
  52. package/dist/cjs/chunk-e0aa62a0.js +404 -0
  53. package/dist/cjs/chunk-e45e0329.js +48 -0
  54. package/dist/cjs/chunk-e5de6583.js +207 -0
  55. package/dist/cjs/chunk-e85cceb6.js +258 -0
  56. package/dist/cjs/chunk-ed5addd6.js +547 -0
  57. package/dist/cjs/chunk-ef4753d5.js +283 -0
  58. package/dist/cjs/chunk-f0c597f9.js +199 -0
  59. package/dist/cjs/chunk-f1df1c63.js +9 -0
  60. package/dist/cjs/chunk-f1ee2f5c.js +207 -0
  61. package/dist/cjs/chunk-fbd4d545.js +247 -0
  62. package/dist/cjs/clockpicker.js +447 -0
  63. package/dist/cjs/collapse.js +102 -0
  64. package/dist/cjs/datepicker.js +1281 -0
  65. package/dist/cjs/dialog.js +237 -0
  66. package/dist/cjs/dropdown.js +19 -0
  67. package/dist/cjs/field.js +18 -0
  68. package/dist/cjs/icon.js +17 -0
  69. package/dist/cjs/index.js +164 -0
  70. package/dist/cjs/input.js +20 -0
  71. package/dist/cjs/loading.js +166 -0
  72. package/dist/cjs/menu.js +231 -0
  73. package/dist/cjs/message.js +65 -0
  74. package/dist/cjs/modal.js +48 -0
  75. package/dist/cjs/navbar.js +258 -0
  76. package/dist/cjs/notification.js +142 -0
  77. package/dist/cjs/numberinput.js +191 -0
  78. package/dist/cjs/pagination.js +19 -0
  79. package/dist/cjs/progress.js +151 -0
  80. package/dist/cjs/radio.js +224 -0
  81. package/dist/cjs/select.js +20 -0
  82. package/dist/cjs/slider.js +511 -0
  83. package/dist/cjs/snackbar.js +114 -0
  84. package/dist/cjs/steps.js +352 -0
  85. package/dist/cjs/switch.js +144 -0
  86. package/dist/cjs/table.js +877 -0
  87. package/dist/cjs/tabs.js +258 -0
  88. package/dist/cjs/tag.js +63 -0
  89. package/dist/cjs/taginput.js +297 -0
  90. package/dist/cjs/timepicker.js +75 -0
  91. package/dist/cjs/toast.js +89 -0
  92. package/dist/cjs/tooltip.js +17 -0
  93. package/dist/cjs/upload.js +210 -0
  94. package/dist/components/autocomplete/index.js +1084 -2
  95. package/dist/components/autocomplete/index.min.js +2 -0
  96. package/dist/components/button/index.js +425 -2
  97. package/dist/components/button/index.min.js +2 -0
  98. package/dist/components/checkbox/index.js +342 -2
  99. package/dist/components/checkbox/index.min.js +2 -0
  100. package/dist/components/clockpicker/index.js +2340 -2
  101. package/dist/components/clockpicker/index.min.js +2 -0
  102. package/dist/components/collapse/index.js +201 -2
  103. package/dist/components/collapse/index.min.js +2 -0
  104. package/dist/components/datepicker/index.js +2720 -2
  105. package/dist/components/datepicker/index.min.js +2 -0
  106. package/dist/components/dialog/index.js +768 -2
  107. package/dist/components/dialog/index.min.js +2 -0
  108. package/dist/components/dropdown/index.js +555 -2
  109. package/dist/components/dropdown/index.min.js +2 -0
  110. package/dist/components/field/index.js +447 -2
  111. package/dist/components/field/index.min.js +2 -0
  112. package/dist/components/icon/index.js +322 -2
  113. package/dist/components/icon/index.min.js +2 -0
  114. package/dist/components/input/index.js +675 -2
  115. package/dist/components/input/index.min.js +2 -0
  116. package/dist/components/loading/index.js +282 -2
  117. package/dist/components/loading/index.min.js +2 -0
  118. package/dist/components/menu/index.js +550 -2
  119. package/dist/components/menu/index.min.js +2 -0
  120. package/dist/components/message/index.js +482 -2
  121. package/dist/components/message/index.min.js +2 -0
  122. package/dist/components/modal/index.js +400 -2
  123. package/dist/components/modal/index.min.js +2 -0
  124. package/dist/components/navbar/index.js +371 -0
  125. package/dist/components/navbar/index.min.js +2 -0
  126. package/dist/components/notification/index.js +705 -2
  127. package/dist/components/notification/index.min.js +2 -0
  128. package/dist/components/numberinput/index.js +846 -2
  129. package/dist/components/numberinput/index.min.js +2 -0
  130. package/dist/components/pagination/index.js +577 -2
  131. package/dist/components/pagination/index.min.js +2 -0
  132. package/dist/components/progress/index.js +250 -0
  133. package/dist/components/progress/index.min.js +2 -0
  134. package/dist/components/radio/index.js +323 -2
  135. package/dist/components/radio/index.min.js +2 -0
  136. package/dist/components/select/index.js +571 -2
  137. package/dist/components/select/index.min.js +2 -0
  138. package/dist/components/slider/index.js +764 -0
  139. package/dist/components/slider/index.min.js +2 -0
  140. package/dist/components/snackbar/index.js +397 -2
  141. package/dist/components/snackbar/index.min.js +2 -0
  142. package/dist/components/steps/index.js +721 -2
  143. package/dist/components/steps/index.min.js +2 -0
  144. package/dist/components/switch/index.js +243 -2
  145. package/dist/components/switch/index.min.js +2 -0
  146. package/dist/components/table/index.js +1870 -2
  147. package/dist/components/table/index.min.js +2 -0
  148. package/dist/components/tabs/index.js +627 -2
  149. package/dist/components/tabs/index.min.js +2 -0
  150. package/dist/components/tag/index.js +262 -2
  151. package/dist/components/tag/index.min.js +2 -0
  152. package/dist/components/taginput/index.js +1459 -2
  153. package/dist/components/taginput/index.min.js +2 -0
  154. package/dist/components/timepicker/index.js +2053 -2
  155. package/dist/components/timepicker/index.min.js +2 -0
  156. package/dist/components/toast/index.js +372 -2
  157. package/dist/components/toast/index.min.js +2 -0
  158. package/dist/components/tooltip/index.js +236 -2
  159. package/dist/components/tooltip/index.min.js +2 -0
  160. package/dist/components/upload/index.js +501 -2
  161. package/dist/components/upload/index.min.js +2 -0
  162. package/dist/esm/autocomplete.js +18 -0
  163. package/dist/esm/button.js +102 -0
  164. package/dist/esm/checkbox.js +131 -0
  165. package/dist/esm/chunk-00e3e67f.js +401 -0
  166. package/dist/esm/chunk-051f8b06.js +105 -0
  167. package/dist/esm/chunk-0566c90d.js +152 -0
  168. package/dist/esm/chunk-07e19446.js +545 -0
  169. package/dist/esm/chunk-085a700d.js +7 -0
  170. package/dist/esm/chunk-0ad6938a.js +53 -0
  171. package/dist/esm/chunk-0e3f4fb5.js +52 -0
  172. package/dist/esm/chunk-10c85529.js +151 -0
  173. package/dist/esm/chunk-121b1efa.js +197 -0
  174. package/dist/esm/chunk-19dad95e.js +256 -0
  175. package/dist/esm/chunk-231b6066.js +113 -0
  176. package/dist/esm/chunk-24d1a01f.js +279 -0
  177. package/dist/esm/chunk-297bff6b.js +393 -0
  178. package/dist/esm/chunk-2b2ae5c6.js +245 -0
  179. package/dist/esm/chunk-2cb6f867.js +46 -0
  180. package/dist/esm/chunk-33717194.js +392 -0
  181. package/dist/esm/chunk-3b811b77.js +139 -0
  182. package/dist/esm/chunk-3e47308f.js +104 -0
  183. package/dist/esm/chunk-411d6eea.js +84 -0
  184. package/dist/esm/chunk-4535dec5.js +92 -0
  185. package/dist/esm/chunk-47a5f3a1.js +103 -0
  186. package/dist/esm/chunk-4a5384da.js +205 -0
  187. package/dist/esm/chunk-4b663574.js +112 -0
  188. package/dist/esm/chunk-4d393f09.js +170 -0
  189. package/dist/esm/chunk-4d695899.js +257 -0
  190. package/dist/esm/chunk-4f508891.js +171 -0
  191. package/dist/esm/chunk-531b8274.js +281 -0
  192. package/dist/esm/chunk-591ee4a2.js +151 -0
  193. package/dist/esm/chunk-5d3bf82e.js +170 -0
  194. package/dist/esm/chunk-5e0b0665.js +104 -0
  195. package/dist/esm/chunk-648b9aa4.js +45 -0
  196. package/dist/esm/chunk-666940cf.js +546 -0
  197. package/dist/esm/chunk-67c97e13.js +246 -0
  198. package/dist/esm/chunk-6844653e.js +401 -0
  199. package/dist/esm/chunk-699b7cb4.js +245 -0
  200. package/dist/esm/chunk-6f881e7d.js +51 -0
  201. package/dist/esm/chunk-7123d158.js +256 -0
  202. package/dist/esm/chunk-7cf87590.js +60 -0
  203. package/dist/esm/chunk-823177ac.js +545 -0
  204. package/dist/esm/chunk-8838757a.js +401 -0
  205. package/dist/esm/chunk-8ca878c0.js +198 -0
  206. package/dist/esm/chunk-8fc2e874.js +85 -0
  207. package/dist/esm/chunk-912ed715.js +92 -0
  208. package/dist/esm/chunk-92acc21f.js +392 -0
  209. package/dist/esm/chunk-98e86f40.js +197 -0
  210. package/dist/esm/chunk-99a1f9df.js +92 -0
  211. package/dist/esm/chunk-9a776697.js +112 -0
  212. package/dist/esm/chunk-9e3207cc.js +46 -0
  213. package/dist/esm/chunk-9ec14e09.js +112 -0
  214. package/dist/esm/chunk-a5ea70d0.js +205 -0
  215. package/dist/esm/chunk-ac3f4847.js +138 -0
  216. package/dist/esm/chunk-b5376f3e.js +92 -0
  217. package/dist/esm/chunk-b56eb2c8.js +197 -0
  218. package/dist/esm/chunk-b796d1b2.js +392 -0
  219. package/dist/esm/chunk-b822a5db.js +205 -0
  220. package/dist/esm/chunk-b9bdb0e4.js +6 -0
  221. package/dist/esm/chunk-bfe15983.js +401 -0
  222. package/dist/esm/chunk-c9039f68.js +104 -0
  223. package/dist/esm/chunk-cc718c15.js +245 -0
  224. package/dist/esm/chunk-cca88db8.js +99 -0
  225. package/dist/esm/chunk-d6200087.js +50 -0
  226. package/dist/esm/chunk-daeac852.js +138 -0
  227. package/dist/esm/chunk-db31c548.js +103 -0
  228. package/dist/esm/chunk-e5568f45.js +84 -0
  229. package/dist/esm/chunk-e5fce48f.js +59 -0
  230. package/dist/esm/chunk-e84b4047.js +170 -0
  231. package/dist/esm/chunk-e8d90b72.js +98 -0
  232. package/dist/esm/chunk-e932bb68.js +206 -0
  233. package/dist/esm/chunk-edd8ff91.js +103 -0
  234. package/dist/esm/chunk-f0465d8d.js +84 -0
  235. package/dist/esm/chunk-f743d154.js +93 -0
  236. package/dist/esm/chunk-f8036b32.js +402 -0
  237. package/dist/esm/chunk-f984748f.js +401 -0
  238. package/dist/esm/chunk-fd5b0e1e.js +99 -0
  239. package/dist/esm/clockpicker.js +443 -0
  240. package/dist/esm/collapse.js +98 -0
  241. package/dist/esm/datepicker.js +1277 -0
  242. package/dist/esm/dialog.js +231 -0
  243. package/dist/esm/dropdown.js +14 -0
  244. package/dist/esm/field.js +14 -0
  245. package/dist/esm/icon.js +13 -0
  246. package/dist/esm/index.js +154 -0
  247. package/dist/esm/input.js +16 -0
  248. package/dist/esm/loading.js +159 -0
  249. package/dist/esm/menu.js +225 -0
  250. package/dist/esm/message.js +61 -0
  251. package/dist/esm/modal.js +42 -0
  252. package/dist/esm/navbar.js +253 -0
  253. package/dist/esm/notification.js +135 -0
  254. package/dist/esm/numberinput.js +187 -0
  255. package/dist/esm/pagination.js +15 -0
  256. package/dist/esm/progress.js +147 -0
  257. package/dist/esm/radio.js +219 -0
  258. package/dist/esm/select.js +16 -0
  259. package/dist/esm/slider.js +506 -0
  260. package/dist/esm/snackbar.js +108 -0
  261. package/dist/esm/steps.js +347 -0
  262. package/dist/esm/switch.js +140 -0
  263. package/dist/esm/table.js +872 -0
  264. package/dist/esm/tabs.js +253 -0
  265. package/dist/esm/tag.js +59 -0
  266. package/dist/esm/taginput.js +293 -0
  267. package/dist/esm/timepicker.js +71 -0
  268. package/dist/esm/toast.js +83 -0
  269. package/dist/esm/tooltip.js +13 -0
  270. package/dist/esm/upload.js +206 -0
  271. package/package.json +26 -4
  272. package/src/components/checkbox/Checkbox.vue +12 -4
  273. package/src/components/checkbox/CheckboxButton.vue +10 -2
  274. package/src/components/clockpicker/Clockpicker.vue +0 -5
  275. package/src/components/datepicker/Datepicker.spec.js +60 -0
  276. package/src/components/datepicker/Datepicker.vue +46 -19
  277. package/src/components/datepicker/DatepickerTable.spec.js +107 -2
  278. package/src/components/datepicker/DatepickerTable.vue +73 -4
  279. package/src/components/datepicker/DatepickerTableRow.spec.js +127 -17
  280. package/src/components/datepicker/DatepickerTableRow.vue +103 -4
  281. package/src/components/dialog/Dialog.vue +5 -3
  282. package/src/components/dialog/index.js +2 -2
  283. package/src/components/dropdown/Dropdown.vue +1 -4
  284. package/src/components/dropdown/DropdownItem.vue +7 -3
  285. package/src/components/field/Field.spec.js +18 -0
  286. package/src/components/field/Field.vue +21 -2
  287. package/src/components/index.js +6 -0
  288. package/src/components/input/Input.vue +2 -2
  289. package/src/components/loading/index.js +1 -1
  290. package/src/components/modal/index.js +1 -1
  291. package/src/components/navbar/NavBar.spec.js +76 -0
  292. package/src/components/navbar/Navbar.vue +127 -0
  293. package/src/components/navbar/NavbarBurger.vue +25 -0
  294. package/src/components/navbar/NavbarItem.vue +21 -0
  295. package/src/components/navbar/index.js +20 -0
  296. package/src/components/notification/index.js +1 -1
  297. package/src/components/pagination/Pagination.vue +28 -6
  298. package/src/components/progress/Progress.spec.js +77 -0
  299. package/src/components/progress/Progress.vue +108 -0
  300. package/src/components/progress/__snapshots__/Progress.spec.js.snap +7 -0
  301. package/src/components/progress/index.js +17 -0
  302. package/src/components/radio/Radio.spec.js +18 -1
  303. package/src/components/radio/Radio.vue +11 -5
  304. package/src/components/radio/RadioButton.spec.js +18 -1
  305. package/src/components/radio/RadioButton.vue +20 -8
  306. package/src/components/select/Select.spec.js +22 -1
  307. package/src/components/select/Select.vue +2 -1
  308. package/src/components/select/__snapshots__/Select.spec.js.snap +7 -0
  309. package/src/components/slider/Slider.spec.js +10 -0
  310. package/src/components/slider/Slider.vue +240 -0
  311. package/src/components/slider/SliderThumb.vue +188 -0
  312. package/src/components/slider/SliderTick.vue +43 -0
  313. package/src/components/slider/index.js +20 -0
  314. package/src/components/snackbar/index.js +2 -2
  315. package/src/components/steps/StepItem.vue +2 -3
  316. package/src/components/steps/Steps.vue +7 -5
  317. package/src/components/switch/Switch.spec.js +29 -0
  318. package/src/components/switch/Switch.vue +29 -5
  319. package/src/components/switch/__snapshots__/Switch.spec.js.snap +3 -0
  320. package/src/components/table/Table.vue +30 -8
  321. package/src/components/table/TableColumn.vue +2 -2
  322. package/src/components/tag/Tag.vue +4 -1
  323. package/src/components/taginput/Taginput.spec.js +10 -0
  324. package/src/components/taginput/Taginput.vue +8 -3
  325. package/src/components/toast/index.js +2 -2
  326. package/src/components/tooltip/Tooltip.vue +5 -5
  327. package/src/components/upload/Upload.vue +15 -8
  328. package/src/index.js +11 -4
  329. package/src/scss/buefy-build.scss +3 -3
  330. package/src/scss/buefy.scss +4 -0
  331. package/src/scss/components/_datepicker.scss +40 -1
  332. package/src/scss/components/_form.scss +52 -1
  333. package/src/scss/components/_progress.scss +45 -0
  334. package/src/scss/components/_radio.scss +14 -14
  335. package/src/scss/components/_slider.scss +138 -0
  336. package/src/scss/components/_steps.scss +4 -4
  337. package/src/scss/components/_switch.scss +54 -2
  338. package/src/scss/components/_taginput.scss +3 -0
  339. package/src/scss/components/_upload.scss +1 -3
  340. package/src/utils/SlotComponent.js +9 -2
  341. package/src/utils/TimepickerMixin.js +17 -6
  342. package/src/utils/config.js +4 -1
  343. package/src/utils/helpers.spec.js +67 -0
  344. package/src/utils/plugins.js +2 -1
  345. package/types/components.d.ts +3 -3
  346. package/types/index.d.ts +24 -11
  347. package/dist/components/index.js +0 -2
@@ -0,0 +1,45 @@
1
+ var config = {
2
+ defaultContainerElement: null,
3
+ defaultIconPack: 'mdi',
4
+ defaultIconComponent: null,
5
+ defaultDialogConfirmText: null,
6
+ defaultDialogCancelText: null,
7
+ defaultSnackbarDuration: 3500,
8
+ defaultSnackbarPosition: null,
9
+ defaultToastDuration: 2000,
10
+ defaultToastPosition: null,
11
+ defaultNotificationDuration: 2000,
12
+ defaultNotificationPosition: null,
13
+ defaultTooltipType: 'is-primary',
14
+ defaultTooltipAnimated: false,
15
+ defaultTooltipDelay: 0,
16
+ defaultInputAutocomplete: 'on',
17
+ defaultDateFormatter: null,
18
+ defaultDateParser: null,
19
+ defaultDateCreator: null,
20
+ defaultDayNames: null,
21
+ defaultMonthNames: null,
22
+ defaultFirstDayOfWeek: null,
23
+ defaultUnselectableDaysOfWeek: null,
24
+ defaultTimeFormatter: null,
25
+ defaultTimeParser: null,
26
+ defaultModalCanCancel: ['escape', 'x', 'outside', 'button'],
27
+ defaultModalScroll: null,
28
+ defaultDatepickerMobileNative: true,
29
+ defaultTimepickerMobileNative: true,
30
+ defaultNoticeQueue: true,
31
+ defaultInputHasCounter: true,
32
+ defaultTaginputHasCounter: true,
33
+ defaultUseHtml5Validation: true,
34
+ defaultDropdownMobileModal: true,
35
+ defaultFieldLabelPosition: null,
36
+ defaultDatepickerYearsRange: [-100, 3],
37
+ defaultDatepickerNearbyMonthDays: true,
38
+ defaultDatepickerNearbySelectableMonthDays: false
39
+ };
40
+ var config$1 = config;
41
+ var setOptions = function setOptions(options) {
42
+ config = options;
43
+ };
44
+
45
+ export { config$1 as c, setOptions as s };
@@ -0,0 +1,546 @@
1
+ /*! Buefy v0.7.10 | MIT License | github.com/buefy/buefy */
2
+ import { i as isMobile } from './chunk-7cf87590.js';
3
+ import { c as config } from './chunk-2cb6f867.js';
4
+ import { F as FormElementMixin } from './chunk-0566c90d.js';
5
+
6
+ var AM = 'AM';
7
+ var PM = 'PM';
8
+ var HOUR_FORMAT_24 = '24';
9
+ var HOUR_FORMAT_12 = '12';
10
+
11
+ var defaultTimeFormatter = function defaultTimeFormatter(date, vm) {
12
+ var hours = date.getHours();
13
+ var minutes = date.getMinutes();
14
+ var seconds = date.getSeconds();
15
+ var period = '';
16
+
17
+ if (vm.hourFormat === HOUR_FORMAT_12) {
18
+ period = ' ' + (hours < 12 ? AM : PM);
19
+
20
+ if (hours > 12) {
21
+ hours -= 12;
22
+ } else if (hours === 0) {
23
+ hours = 12;
24
+ }
25
+ }
26
+
27
+ return vm.pad(hours) + ':' + vm.pad(minutes) + (vm.enableSeconds ? ':' + vm.pad(seconds) : '') + period;
28
+ };
29
+
30
+ var defaultTimeParser = function defaultTimeParser(timeString, vm) {
31
+ if (timeString) {
32
+ var am = false;
33
+
34
+ if (vm.hourFormat === HOUR_FORMAT_12) {
35
+ var dateString12 = timeString.split(' ');
36
+ timeString = dateString12[0];
37
+ am = dateString12[1] === AM;
38
+ }
39
+
40
+ var time = timeString.split(':');
41
+ var hours = parseInt(time[0], 10);
42
+ var minutes = parseInt(time[1], 10);
43
+ var seconds = vm.enableSeconds ? parseInt(time[2], 10) : 0;
44
+
45
+ if (isNaN(hours) || hours < 0 || hours > 23 || vm.hourFormat === HOUR_FORMAT_12 && (hours < 1 || hours > 12) || isNaN(minutes) || minutes < 0 || minutes > 59) {
46
+ return null;
47
+ }
48
+
49
+ var d = null;
50
+
51
+ if (vm.computedValue && !isNaN(vm.computedValue)) {
52
+ d = new Date(vm.computedValue);
53
+ } else {
54
+ d = new Date();
55
+ d.setMilliseconds(0);
56
+ }
57
+
58
+ d.setSeconds(seconds);
59
+ d.setMinutes(minutes);
60
+
61
+ if (vm.hourFormat === HOUR_FORMAT_12) {
62
+ if (am && hours === 12) {
63
+ hours = 0;
64
+ } else if (!am && hours !== 12) {
65
+ hours += 12;
66
+ }
67
+ }
68
+
69
+ d.setHours(hours);
70
+ return new Date(d.getTime());
71
+ }
72
+
73
+ return null;
74
+ };
75
+
76
+ var TimepickerMixin = {
77
+ mixins: [FormElementMixin],
78
+ inheritAttrs: false,
79
+ props: {
80
+ value: Date,
81
+ inline: Boolean,
82
+ minTime: Date,
83
+ maxTime: Date,
84
+ placeholder: String,
85
+ editable: Boolean,
86
+ disabled: Boolean,
87
+ hourFormat: {
88
+ type: String,
89
+ default: HOUR_FORMAT_24,
90
+ validator: function validator(value) {
91
+ return value === HOUR_FORMAT_24 || value === HOUR_FORMAT_12;
92
+ }
93
+ },
94
+ incrementMinutes: {
95
+ type: Number,
96
+ default: 1
97
+ },
98
+ incrementSeconds: {
99
+ type: Number,
100
+ default: 1
101
+ },
102
+ timeFormatter: {
103
+ type: Function,
104
+ default: function _default(date, vm) {
105
+ if (typeof config.defaultTimeFormatter === 'function') {
106
+ return config.defaultTimeFormatter(date);
107
+ } else {
108
+ return defaultTimeFormatter(date, vm);
109
+ }
110
+ }
111
+ },
112
+ timeParser: {
113
+ type: Function,
114
+ default: function _default(date, vm) {
115
+ if (typeof config.defaultTimeParser === 'function') {
116
+ return config.defaultTimeParser(date);
117
+ } else {
118
+ return defaultTimeParser(date, vm);
119
+ }
120
+ }
121
+ },
122
+ mobileNative: {
123
+ type: Boolean,
124
+ default: function _default() {
125
+ return config.defaultTimepickerMobileNative;
126
+ }
127
+ },
128
+ position: String,
129
+ unselectableTimes: Array,
130
+ openOnFocus: Boolean,
131
+ enableSeconds: Boolean,
132
+ defaultMinutes: Number,
133
+ defaultSeconds: Number
134
+ },
135
+ data: function data() {
136
+ return {
137
+ dateSelected: this.value,
138
+ hoursSelected: null,
139
+ minutesSelected: null,
140
+ secondsSelected: null,
141
+ meridienSelected: null,
142
+ _elementRef: 'input',
143
+ AM: AM,
144
+ PM: PM,
145
+ HOUR_FORMAT_24: HOUR_FORMAT_24,
146
+ HOUR_FORMAT_12: HOUR_FORMAT_12
147
+ };
148
+ },
149
+ computed: {
150
+ computedValue: {
151
+ get: function get() {
152
+ return this.dateSelected;
153
+ },
154
+ set: function set(value) {
155
+ this.dateSelected = value;
156
+ this.$emit('input', value);
157
+ }
158
+ },
159
+ hours: function hours() {
160
+ var hours = [];
161
+ var numberOfHours = this.isHourFormat24 ? 24 : 12;
162
+
163
+ for (var i = 0; i < numberOfHours; i++) {
164
+ var value = i;
165
+ var label = value;
166
+
167
+ if (!this.isHourFormat24) {
168
+ value = i + 1;
169
+ label = value;
170
+
171
+ if (this.meridienSelected === this.AM) {
172
+ if (value === 12) {
173
+ value = 0;
174
+ }
175
+ } else if (this.meridienSelected === this.PM) {
176
+ if (value !== 12) {
177
+ value += 12;
178
+ }
179
+ }
180
+ }
181
+
182
+ hours.push({
183
+ label: this.formatNumber(label),
184
+ value: value
185
+ });
186
+ }
187
+
188
+ return hours;
189
+ },
190
+ minutes: function minutes() {
191
+ var minutes = [];
192
+
193
+ for (var i = 0; i < 60; i += this.incrementMinutes) {
194
+ minutes.push({
195
+ label: this.formatNumber(i),
196
+ value: i
197
+ });
198
+ }
199
+
200
+ return minutes;
201
+ },
202
+ seconds: function seconds() {
203
+ var seconds = [];
204
+
205
+ for (var i = 0; i < 60; i += this.incrementSeconds) {
206
+ seconds.push({
207
+ label: this.formatNumber(i),
208
+ value: i
209
+ });
210
+ }
211
+
212
+ return seconds;
213
+ },
214
+ meridiens: function meridiens() {
215
+ return [AM, PM];
216
+ },
217
+ isMobile: function isMobile$1() {
218
+ return this.mobileNative && isMobile.any();
219
+ },
220
+ isHourFormat24: function isHourFormat24() {
221
+ return this.hourFormat === HOUR_FORMAT_24;
222
+ }
223
+ },
224
+ watch: {
225
+ hourFormat: function hourFormat() {
226
+ if (this.hoursSelected !== null) {
227
+ this.meridienSelected = this.hoursSelected >= 12 ? PM : AM;
228
+ }
229
+ },
230
+
231
+ /**
232
+ * When v-model is changed:
233
+ * 1. Update internal value.
234
+ * 2. If it's invalid, validate again.
235
+ */
236
+ value: {
237
+ handler: function handler(value) {
238
+ this.updateInternalState(value);
239
+ !this.isValid && this.$refs.input.checkHtml5Validity();
240
+ },
241
+ immediate: true
242
+ }
243
+ },
244
+ methods: {
245
+ onMeridienChange: function onMeridienChange(value) {
246
+ if (this.hoursSelected !== null) {
247
+ if (value === PM) {
248
+ this.hoursSelected += 12;
249
+ } else if (value === AM) {
250
+ this.hoursSelected -= 12;
251
+ }
252
+ }
253
+
254
+ this.updateDateSelected(this.hoursSelected, this.minutesSelected, this.enableSeconds ? this.secondsSelected : 0, value);
255
+ },
256
+ onHoursChange: function onHoursChange(value) {
257
+ if (!this.minutesSelected && this.defaultMinutes) {
258
+ this.minutesSelected = this.defaultMinutes;
259
+ }
260
+
261
+ if (!this.secondsSelected && this.defaultSeconds) {
262
+ this.secondsSelected = this.defaultSeconds;
263
+ }
264
+
265
+ this.updateDateSelected(parseInt(value, 10), this.minutesSelected, this.enableSeconds ? this.secondsSelected : 0, this.meridienSelected);
266
+ },
267
+ onMinutesChange: function onMinutesChange(value) {
268
+ if (!this.secondsSelected && this.defaultSeconds) {
269
+ this.secondsSelected = this.defaultSeconds;
270
+ }
271
+
272
+ this.updateDateSelected(this.hoursSelected, parseInt(value, 10), this.enableSeconds ? this.secondsSelected : 0, this.meridienSelected);
273
+ },
274
+ onSecondsChange: function onSecondsChange(value) {
275
+ this.updateDateSelected(this.hoursSelected, this.minutesSelected, parseInt(value, 10), this.meridienSelected);
276
+ },
277
+ updateDateSelected: function updateDateSelected(hours, minutes, seconds, meridiens) {
278
+ if (hours != null && minutes != null && (!this.isHourFormat24 && meridiens !== null || this.isHourFormat24)) {
279
+ var time = null;
280
+
281
+ if (this.computedValue && !isNaN(this.computedValue)) {
282
+ time = new Date(this.computedValue);
283
+ } else {
284
+ time = new Date();
285
+ time.setMilliseconds(0);
286
+ }
287
+
288
+ time.setHours(hours);
289
+ time.setMinutes(minutes);
290
+ time.setSeconds(seconds);
291
+ this.computedValue = new Date(time.getTime());
292
+ }
293
+ },
294
+ updateInternalState: function updateInternalState(value) {
295
+ if (value) {
296
+ this.hoursSelected = value.getHours();
297
+ this.minutesSelected = value.getMinutes();
298
+ this.secondsSelected = value.getSeconds();
299
+ this.meridienSelected = value.getHours() >= 12 ? PM : AM;
300
+ } else {
301
+ this.hoursSelected = null;
302
+ this.minutesSelected = null;
303
+ this.secondsSelected = null;
304
+ this.meridienSelected = AM;
305
+ }
306
+
307
+ this.dateSelected = value;
308
+ },
309
+ isHourDisabled: function isHourDisabled(hour) {
310
+ var _this = this;
311
+
312
+ var disabled = false;
313
+
314
+ if (this.minTime) {
315
+ var minHours = this.minTime.getHours();
316
+ disabled = hour < minHours;
317
+ }
318
+
319
+ if (this.maxTime) {
320
+ if (!disabled) {
321
+ var maxHours = this.maxTime.getHours();
322
+ disabled = hour > maxHours;
323
+ }
324
+ }
325
+
326
+ if (this.unselectableTimes) {
327
+ if (!disabled) {
328
+ var unselectable = this.unselectableTimes.filter(function (time) {
329
+ if (_this.enableSeconds && _this.secondsSelected !== null) {
330
+ return time.getHours() === hour && time.getMinutes() === _this.minutesSelected && time.getSeconds() === _this.secondsSelected;
331
+ } else if (_this.minutesSelected !== null) {
332
+ return time.getHours() === hour && time.getMinutes() === _this.minutesSelected;
333
+ } else {
334
+ return time.getHours() === hour;
335
+ }
336
+ });
337
+ disabled = unselectable.length > 0;
338
+ }
339
+ }
340
+
341
+ return disabled;
342
+ },
343
+ isMinuteDisabled: function isMinuteDisabled(minute) {
344
+ var _this2 = this;
345
+
346
+ var disabled = false;
347
+
348
+ if (this.hoursSelected !== null) {
349
+ if (this.isHourDisabled(this.hoursSelected)) {
350
+ disabled = true;
351
+ } else {
352
+ if (this.minTime) {
353
+ var minHours = this.minTime.getHours();
354
+ var minMinutes = this.minTime.getMinutes();
355
+ disabled = this.hoursSelected === minHours && minute < minMinutes;
356
+ }
357
+
358
+ if (this.maxTime) {
359
+ if (!disabled) {
360
+ var maxHours = this.maxTime.getHours();
361
+ var maxMinutes = this.maxTime.getMinutes();
362
+ disabled = this.hoursSelected === maxHours && minute > maxMinutes;
363
+ }
364
+ }
365
+ }
366
+
367
+ if (this.unselectableTimes) {
368
+ if (!disabled) {
369
+ var unselectable = this.unselectableTimes.filter(function (time) {
370
+ if (_this2.enableSeconds && _this2.secondsSelected !== null) {
371
+ return time.getHours() === _this2.hoursSelected && time.getMinutes() === minute && time.getSeconds() === _this2.secondsSelected;
372
+ } else {
373
+ return time.getHours() === _this2.hoursSelected && time.getMinutes() === minute;
374
+ }
375
+ });
376
+ disabled = unselectable.length > 0;
377
+ }
378
+ }
379
+ }
380
+
381
+ return disabled;
382
+ },
383
+ isSecondDisabled: function isSecondDisabled(second) {
384
+ var _this3 = this;
385
+
386
+ var disabled = false;
387
+
388
+ if (this.minutesSelected !== null) {
389
+ if (this.isMinuteDisabled(this.minutesSelected)) {
390
+ disabled = true;
391
+ } else {
392
+ if (this.minTime) {
393
+ var minHours = this.minTime.getHours();
394
+ var minMinutes = this.minTime.getMinutes();
395
+ var minSeconds = this.minTime.getSeconds();
396
+ disabled = this.hoursSelected === minHours && this.minutesSelected === minMinutes && second < minSeconds;
397
+ }
398
+
399
+ if (this.maxTime) {
400
+ if (!disabled) {
401
+ var maxHours = this.maxTime.getHours();
402
+ var maxMinutes = this.maxTime.getMinutes();
403
+ var maxSeconds = this.maxTime.getSeconds();
404
+ disabled = this.hoursSelected === maxHours && this.minutesSelected === maxMinutes && second > maxSeconds;
405
+ }
406
+ }
407
+ }
408
+
409
+ if (this.unselectableTimes) {
410
+ if (!disabled) {
411
+ var unselectable = this.unselectableTimes.filter(function (time) {
412
+ return time.getHours() === _this3.hoursSelected && time.getMinutes() === _this3.minutesSelected && time.getSeconds() === second;
413
+ });
414
+ disabled = unselectable.length > 0;
415
+ }
416
+ }
417
+ }
418
+
419
+ return disabled;
420
+ },
421
+
422
+ /*
423
+ * Parse string into date
424
+ */
425
+ onChange: function onChange(value) {
426
+ var date = this.timeParser(value, this);
427
+ this.updateInternalState(date);
428
+
429
+ if (date && !isNaN(date)) {
430
+ this.computedValue = date;
431
+ } else {
432
+ // Force refresh input value when not valid date
433
+ this.computedValue = null;
434
+ this.$refs.input.newValue = this.computedValue;
435
+ }
436
+ },
437
+
438
+ /*
439
+ * Toggle timepicker
440
+ */
441
+ toggle: function toggle(active) {
442
+ if (this.$refs.dropdown) {
443
+ this.$refs.dropdown.isActive = typeof active === 'boolean' ? active : !this.$refs.dropdown.isActive;
444
+ }
445
+ },
446
+
447
+ /*
448
+ * Close timepicker
449
+ */
450
+ close: function close() {
451
+ this.toggle(false);
452
+ },
453
+
454
+ /*
455
+ * Call default onFocus method and show timepicker
456
+ */
457
+ handleOnFocus: function handleOnFocus() {
458
+ this.onFocus();
459
+
460
+ if (this.openOnFocus) {
461
+ this.toggle(true);
462
+ }
463
+ },
464
+
465
+ /*
466
+ * Format date into string 'HH-MM-SS'
467
+ */
468
+ formatHHMMSS: function formatHHMMSS(value) {
469
+ var date = new Date(value);
470
+
471
+ if (value && !isNaN(date)) {
472
+ var hours = date.getHours();
473
+ var minutes = date.getMinutes();
474
+ var seconds = date.getSeconds();
475
+ return this.formatNumber(hours) + ':' + this.formatNumber(minutes, true) + ':' + this.formatNumber(seconds, true);
476
+ }
477
+
478
+ return '';
479
+ },
480
+
481
+ /*
482
+ * Parse time from string
483
+ */
484
+ onChangeNativePicker: function onChangeNativePicker(event) {
485
+ var date = event.target.value;
486
+
487
+ if (date) {
488
+ var time = null;
489
+
490
+ if (this.computedValue && !isNaN(this.computedValue)) {
491
+ time = new Date(this.computedValue);
492
+ } else {
493
+ time = new Date();
494
+ time.setMilliseconds(0);
495
+ }
496
+
497
+ var t = date.split(':');
498
+ time.setHours(parseInt(t[0], 10));
499
+ time.setMinutes(parseInt(t[1], 10));
500
+ time.setSeconds(t[2] ? parseInt(t[2], 10) : 0);
501
+ this.computedValue = new Date(time.getTime());
502
+ } else {
503
+ this.computedValue = null;
504
+ }
505
+ },
506
+ formatNumber: function formatNumber(value, isMinute) {
507
+ return this.isHourFormat24 || isMinute ? this.pad(value) : value;
508
+ },
509
+ pad: function pad(value) {
510
+ return (value < 10 ? '0' : '') + value;
511
+ },
512
+
513
+ /*
514
+ * Format date into string
515
+ */
516
+ formatValue: function formatValue(date) {
517
+ if (date && !isNaN(date)) {
518
+ return this.timeFormatter(date, this);
519
+ } else {
520
+ return null;
521
+ }
522
+ },
523
+
524
+ /**
525
+ * Keypress event that is bound to the document.
526
+ */
527
+ keyPress: function keyPress(event) {
528
+ // Esc key
529
+ if (this.$refs.dropdown && this.$refs.dropdown.isActive && event.keyCode === 27) {
530
+ this.toggle(false);
531
+ }
532
+ }
533
+ },
534
+ created: function created() {
535
+ if (typeof window !== 'undefined') {
536
+ document.addEventListener('keyup', this.keyPress);
537
+ }
538
+ },
539
+ beforeDestroy: function beforeDestroy() {
540
+ if (typeof window !== 'undefined') {
541
+ document.removeEventListener('keyup', this.keyPress);
542
+ }
543
+ }
544
+ };
545
+
546
+ export { TimepickerMixin as T };