kdutify 0.16.9-rc.0

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 (425) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +70 -0
  3. package/dist/kdutify.css +12850 -0
  4. package/dist/kdutify.css.map +1 -0
  5. package/dist/kdutify.js +16285 -0
  6. package/dist/kdutify.js.map +1 -0
  7. package/dist/kdutify.min.css +7 -0
  8. package/dist/kdutify.min.css.map +1 -0
  9. package/dist/kdutify.min.js +6 -0
  10. package/es5/components/KAlert/KAlert.js +80 -0
  11. package/es5/components/KAlert/index.js +7 -0
  12. package/es5/components/KApp/KApp.js +67 -0
  13. package/es5/components/KApp/index.js +7 -0
  14. package/es5/components/KAvatar/KAvatar.js +31 -0
  15. package/es5/components/KAvatar/index.js +7 -0
  16. package/es5/components/KBadge/KBadge.js +59 -0
  17. package/es5/components/KBadge/index.js +7 -0
  18. package/es5/components/KBottomNav/KBottomNav.js +50 -0
  19. package/es5/components/KBottomNav/index.js +7 -0
  20. package/es5/components/KBottomSheet/KBottomSheet.js +36 -0
  21. package/es5/components/KBottomSheet/index.js +7 -0
  22. package/es5/components/KBreadcrumbs/KBreadcrumbs.js +36 -0
  23. package/es5/components/KBreadcrumbs/KBreadcrumbsItem.js +38 -0
  24. package/es5/components/KBreadcrumbs/index.js +11 -0
  25. package/es5/components/KBtn/KBtn.js +153 -0
  26. package/es5/components/KBtn/index.js +7 -0
  27. package/es5/components/KBtnToggle/KBtnToggle.js +92 -0
  28. package/es5/components/KBtnToggle/index.js +7 -0
  29. package/es5/components/KCard/KCard.js +63 -0
  30. package/es5/components/KCard/KCardMedia.js +41 -0
  31. package/es5/components/KCard/KCardTitle.js +21 -0
  32. package/es5/components/KCard/index.js +19 -0
  33. package/es5/components/KCarousel/KCarousel.js +178 -0
  34. package/es5/components/KCarousel/KCarouselItem.js +63 -0
  35. package/es5/components/KCarousel/index.js +11 -0
  36. package/es5/components/KCheckbox/KCheckbox.js +89 -0
  37. package/es5/components/KCheckbox/index.js +7 -0
  38. package/es5/components/KChip/KChip.js +81 -0
  39. package/es5/components/KChip/index.js +7 -0
  40. package/es5/components/KDataTable/KDataTable.js +347 -0
  41. package/es5/components/KDataTable/KEditDialog.js +108 -0
  42. package/es5/components/KDataTable/index.js +14 -0
  43. package/es5/components/KDataTable/mixins/body.js +103 -0
  44. package/es5/components/KDataTable/mixins/foot.js +118 -0
  45. package/es5/components/KDataTable/mixins/head.js +123 -0
  46. package/es5/components/KDataTable/mixins/progress.js +16 -0
  47. package/es5/components/KDatePicker/KDatePicker.js +416 -0
  48. package/es5/components/KDatePicker/index.js +7 -0
  49. package/es5/components/KDatePicker/mixins/date-header.js +68 -0
  50. package/es5/components/KDatePicker/mixins/date-table.js +101 -0
  51. package/es5/components/KDatePicker/mixins/date-title.js +64 -0
  52. package/es5/components/KDatePicker/mixins/date-years.js +53 -0
  53. package/es5/components/KDatePicker/mixins/month-table.js +91 -0
  54. package/es5/components/KDialog/KDialog.js +181 -0
  55. package/es5/components/KDialog/index.js +7 -0
  56. package/es5/components/KDivider/KDivider.js +29 -0
  57. package/es5/components/KDivider/index.js +7 -0
  58. package/es5/components/KExpansionPanel/KExpansionPanel.js +60 -0
  59. package/es5/components/KExpansionPanel/KExpansionPanelContent.js +114 -0
  60. package/es5/components/KExpansionPanel/index.js +9 -0
  61. package/es5/components/KFooter/KFooter.js +61 -0
  62. package/es5/components/KFooter/index.js +7 -0
  63. package/es5/components/KForm/KForm.js +203 -0
  64. package/es5/components/KForm/index.js +7 -0
  65. package/es5/components/KGrid/KContainer.js +5 -0
  66. package/es5/components/KGrid/KContent.js +33 -0
  67. package/es5/components/KGrid/KFlex.js +5 -0
  68. package/es5/components/KGrid/KLayout.js +5 -0
  69. package/es5/components/KGrid/grid.js +43 -0
  70. package/es5/components/KGrid/index.js +20 -0
  71. package/es5/components/KIcon/KIcon.js +93 -0
  72. package/es5/components/KIcon/index.js +7 -0
  73. package/es5/components/KList/KList.js +82 -0
  74. package/es5/components/KList/KListGroup.js +100 -0
  75. package/es5/components/KList/KListTile.js +65 -0
  76. package/es5/components/KList/KListTileAction.js +15 -0
  77. package/es5/components/KList/index.js +27 -0
  78. package/es5/components/KMenu/KMenu.js +178 -0
  79. package/es5/components/KMenu/index.js +7 -0
  80. package/es5/components/KMenu/mixins/menu-activator.js +59 -0
  81. package/es5/components/KMenu/mixins/menu-generators.js +88 -0
  82. package/es5/components/KMenu/mixins/menu-keyable.js +64 -0
  83. package/es5/components/KMenu/mixins/menu-position.js +64 -0
  84. package/es5/components/KNavigationDrawer/KNavigationDrawer.js +238 -0
  85. package/es5/components/KNavigationDrawer/index.js +7 -0
  86. package/es5/components/KPagination/KPagination.js +167 -0
  87. package/es5/components/KPagination/index.js +7 -0
  88. package/es5/components/KParallax/KParallax.js +98 -0
  89. package/es5/components/KParallax/index.js +7 -0
  90. package/es5/components/KProgressCircular/KProgressCircular.js +145 -0
  91. package/es5/components/KProgressCircular/index.js +7 -0
  92. package/es5/components/KProgressLinear/KProgressLinear.js +146 -0
  93. package/es5/components/KProgressLinear/index.js +7 -0
  94. package/es5/components/KRadioGroup/KRadio.js +148 -0
  95. package/es5/components/KRadioGroup/KRadioGroup.js +139 -0
  96. package/es5/components/KRadioGroup/index.js +11 -0
  97. package/es5/components/KSelect/KSelect.js +635 -0
  98. package/es5/components/KSelect/index.js +7 -0
  99. package/es5/components/KSelect/mixins/select-autocomplete.js +125 -0
  100. package/es5/components/KSelect/mixins/select-generators.js +298 -0
  101. package/es5/components/KSlider/KSlider.js +306 -0
  102. package/es5/components/KSlider/index.js +7 -0
  103. package/es5/components/KSnackbar/KSnackbar.js +106 -0
  104. package/es5/components/KSnackbar/index.js +7 -0
  105. package/es5/components/KSpeedDial/KSpeedDial.js +89 -0
  106. package/es5/components/KSpeedDial/index.js +7 -0
  107. package/es5/components/KStepper/KStepper.js +112 -0
  108. package/es5/components/KStepper/KStepperContent.js +134 -0
  109. package/es5/components/KStepper/KStepperStep.js +105 -0
  110. package/es5/components/KStepper/index.js +17 -0
  111. package/es5/components/KSubheader/KSubheader.js +29 -0
  112. package/es5/components/KSubheader/index.js +7 -0
  113. package/es5/components/KSwitch/KSwitch.js +55 -0
  114. package/es5/components/KSwitch/index.js +7 -0
  115. package/es5/components/KSystemBar/KSystemBar.js +54 -0
  116. package/es5/components/KSystemBar/index.js +7 -0
  117. package/es5/components/KTabs/KTabs.js +272 -0
  118. package/es5/components/KTabs/KTabsBar.js +205 -0
  119. package/es5/components/KTabs/KTabsContent.js +86 -0
  120. package/es5/components/KTabs/KTabsItem.js +103 -0
  121. package/es5/components/KTabs/KTabsItems.js +40 -0
  122. package/es5/components/KTabs/KTabsSlider.js +14 -0
  123. package/es5/components/KTabs/index.js +17 -0
  124. package/es5/components/KTextField/KTextField.js +275 -0
  125. package/es5/components/KTextField/index.js +7 -0
  126. package/es5/components/KTimePicker/KTimePicker.js +302 -0
  127. package/es5/components/KTimePicker/index.js +7 -0
  128. package/es5/components/KTimePicker/mixins/time-body.js +207 -0
  129. package/es5/components/KTimePicker/mixins/time-title.js +55 -0
  130. package/es5/components/KToolbar/KToolbar.js +193 -0
  131. package/es5/components/KToolbar/KToolbarSideIcon.js +29 -0
  132. package/es5/components/KToolbar/index.js +17 -0
  133. package/es5/components/KTooltip/KTooltip.js +156 -0
  134. package/es5/components/KTooltip/index.js +7 -0
  135. package/es5/components/Kdutify/index.js +50 -0
  136. package/es5/components/index.js +45 -0
  137. package/es5/components/transitions/expand-transition.js +36 -0
  138. package/es5/components/transitions/index.js +47 -0
  139. package/es5/components/transitions/row-expand-transition.js +38 -0
  140. package/es5/directives/click-outside.js +100 -0
  141. package/es5/directives/index.js +15 -0
  142. package/es5/directives/resize.js +30 -0
  143. package/es5/directives/ripple.js +144 -0
  144. package/es5/directives/scroll.js +32 -0
  145. package/es5/directives/touch.js +102 -0
  146. package/es5/index.js +30 -0
  147. package/es5/mixins/applicationable.js +9 -0
  148. package/es5/mixins/bootable.js +31 -0
  149. package/es5/mixins/button-group.js +82 -0
  150. package/es5/mixins/colorable.js +24 -0
  151. package/es5/mixins/contextualable.js +10 -0
  152. package/es5/mixins/delayable.js +57 -0
  153. package/es5/mixins/dependent.js +121 -0
  154. package/es5/mixins/detachable.js +41 -0
  155. package/es5/mixins/filterable.js +8 -0
  156. package/es5/mixins/input.js +219 -0
  157. package/es5/mixins/loadable.js +31 -0
  158. package/es5/mixins/maskable.js +181 -0
  159. package/es5/mixins/menuable.js +293 -0
  160. package/es5/mixins/overlayable.js +202 -0
  161. package/es5/mixins/picker.js +36 -0
  162. package/es5/mixins/positionable.js +10 -0
  163. package/es5/mixins/rippleable.js +21 -0
  164. package/es5/mixins/routable.js +66 -0
  165. package/es5/mixins/selectable.js +79 -0
  166. package/es5/mixins/stackable.js +70 -0
  167. package/es5/mixins/tab-focusable.js +7 -0
  168. package/es5/mixins/themeable.js +15 -0
  169. package/es5/mixins/toggleable.js +31 -0
  170. package/es5/mixins/transitionable.js +7 -0
  171. package/es5/mixins/translatable.js +62 -0
  172. package/es5/mixins/validatable.js +138 -0
  173. package/es5/util/breakpoint.js +128 -0
  174. package/es5/util/helpers.js +139 -0
  175. package/es5/util/load.js +15 -0
  176. package/es5/util/mask.js +159 -0
  177. package/es5/util/testing.js +160 -0
  178. package/es5/util/to-have-been-warned.js +117 -0
  179. package/es5/util/touchSupport.js +14 -0
  180. package/index.d.ts +8 -0
  181. package/package.json +134 -0
  182. package/src/components/KAlert/KAlert.js +77 -0
  183. package/src/components/KAlert/index.js +7 -0
  184. package/src/components/KApp/KApp.js +64 -0
  185. package/src/components/KApp/index.js +7 -0
  186. package/src/components/KAvatar/KAvatar.js +27 -0
  187. package/src/components/KAvatar/index.js +7 -0
  188. package/src/components/KBadge/KBadge.js +62 -0
  189. package/src/components/KBadge/index.js +7 -0
  190. package/src/components/KBottomNav/KBottomNav.js +50 -0
  191. package/src/components/KBottomNav/index.js +7 -0
  192. package/src/components/KBottomSheet/KBottomSheet.js +41 -0
  193. package/src/components/KBottomSheet/index.js +7 -0
  194. package/src/components/KBreadcrumbs/KBreadcrumbs.js +35 -0
  195. package/src/components/KBreadcrumbs/KBreadcrumbsItem.js +38 -0
  196. package/src/components/KBreadcrumbs/index.js +11 -0
  197. package/src/components/KBtn/KBtn.js +163 -0
  198. package/src/components/KBtn/index.js +7 -0
  199. package/src/components/KBtnToggle/KBtnToggle.js +92 -0
  200. package/src/components/KBtnToggle/index.js +7 -0
  201. package/src/components/KCard/KCard.js +61 -0
  202. package/src/components/KCard/KCardMedia.js +41 -0
  203. package/src/components/KCard/KCardTitle.js +17 -0
  204. package/src/components/KCard/index.js +19 -0
  205. package/src/components/KCarousel/KCarousel.js +174 -0
  206. package/src/components/KCarousel/KCarouselItem.js +65 -0
  207. package/src/components/KCarousel/index.js +11 -0
  208. package/src/components/KCheckbox/KCheckbox.js +92 -0
  209. package/src/components/KCheckbox/index.js +7 -0
  210. package/src/components/KChip/KChip.js +83 -0
  211. package/src/components/KChip/index.js +7 -0
  212. package/src/components/KDataTable/KDataTable.js +346 -0
  213. package/src/components/KDataTable/KEditDialog.js +110 -0
  214. package/src/components/KDataTable/index.js +16 -0
  215. package/src/components/KDataTable/mixins/body.js +98 -0
  216. package/src/components/KDataTable/mixins/foot.js +128 -0
  217. package/src/components/KDataTable/mixins/head.js +119 -0
  218. package/src/components/KDataTable/mixins/progress.js +16 -0
  219. package/src/components/KDatePicker/KDatePicker.js +382 -0
  220. package/src/components/KDatePicker/index.js +7 -0
  221. package/src/components/KDatePicker/mixins/date-header.js +74 -0
  222. package/src/components/KDatePicker/mixins/date-table.js +95 -0
  223. package/src/components/KDatePicker/mixins/date-title.js +76 -0
  224. package/src/components/KDatePicker/mixins/date-years.js +42 -0
  225. package/src/components/KDatePicker/mixins/month-table.js +82 -0
  226. package/src/components/KDialog/KDialog.js +184 -0
  227. package/src/components/KDialog/index.js +7 -0
  228. package/src/components/KDivider/KDivider.js +25 -0
  229. package/src/components/KDivider/index.js +7 -0
  230. package/src/components/KExpansionPanel/KExpansionPanel.js +55 -0
  231. package/src/components/KExpansionPanel/KExpansionPanelContent.js +112 -0
  232. package/src/components/KExpansionPanel/index.js +9 -0
  233. package/src/components/KFooter/KFooter.js +67 -0
  234. package/src/components/KFooter/index.js +7 -0
  235. package/src/components/KForm/KForm.js +117 -0
  236. package/src/components/KForm/index.js +7 -0
  237. package/src/components/KGrid/KContainer.js +5 -0
  238. package/src/components/KGrid/KContent.js +29 -0
  239. package/src/components/KGrid/KFlex.js +5 -0
  240. package/src/components/KGrid/KLayout.js +5 -0
  241. package/src/components/KGrid/grid.js +40 -0
  242. package/src/components/KGrid/index.js +27 -0
  243. package/src/components/KIcon/KIcon.js +87 -0
  244. package/src/components/KIcon/index.js +7 -0
  245. package/src/components/KList/KList.js +75 -0
  246. package/src/components/KList/KListGroup.js +95 -0
  247. package/src/components/KList/KListTile.js +62 -0
  248. package/src/components/KList/KListTileAction.js +12 -0
  249. package/src/components/KList/index.js +27 -0
  250. package/src/components/KMenu/KMenu.js +207 -0
  251. package/src/components/KMenu/index.js +7 -0
  252. package/src/components/KMenu/mixins/menu-activator.js +51 -0
  253. package/src/components/KMenu/mixins/menu-generators.js +84 -0
  254. package/src/components/KMenu/mixins/menu-keyable.js +68 -0
  255. package/src/components/KMenu/mixins/menu-position.js +72 -0
  256. package/src/components/KNavigationDrawer/KNavigationDrawer.js +267 -0
  257. package/src/components/KNavigationDrawer/index.js +7 -0
  258. package/src/components/KPagination/KPagination.js +168 -0
  259. package/src/components/KPagination/index.js +7 -0
  260. package/src/components/KParallax/KParallax.js +99 -0
  261. package/src/components/KParallax/index.js +7 -0
  262. package/src/components/KProgressCircular/KProgressCircular.js +160 -0
  263. package/src/components/KProgressCircular/index.js +7 -0
  264. package/src/components/KProgressLinear/KProgressLinear.js +157 -0
  265. package/src/components/KProgressLinear/index.js +7 -0
  266. package/src/components/KRadioGroup/KRadio.js +153 -0
  267. package/src/components/KRadioGroup/KRadioGroup.js +118 -0
  268. package/src/components/KRadioGroup/index.js +11 -0
  269. package/src/components/KSelect/KSelect.js +641 -0
  270. package/src/components/KSelect/index.js +7 -0
  271. package/src/components/KSelect/mixins/select-autocomplete.js +125 -0
  272. package/src/components/KSelect/mixins/select-generators.js +300 -0
  273. package/src/components/KSlider/KSlider.js +311 -0
  274. package/src/components/KSlider/index.js +7 -0
  275. package/src/components/KSnackbar/KSnackbar.js +97 -0
  276. package/src/components/KSnackbar/index.js +7 -0
  277. package/src/components/KSpeedDial/KSpeedDial.js +80 -0
  278. package/src/components/KSpeedDial/index.js +7 -0
  279. package/src/components/KStepper/KStepper.js +95 -0
  280. package/src/components/KStepper/KStepperContent.js +138 -0
  281. package/src/components/KStepper/KStepperStep.js +100 -0
  282. package/src/components/KStepper/index.js +17 -0
  283. package/src/components/KSubheader/KSubheader.js +25 -0
  284. package/src/components/KSubheader/index.js +7 -0
  285. package/src/components/KSwitch/KSwitch.js +58 -0
  286. package/src/components/KSwitch/index.js +7 -0
  287. package/src/components/KSystemBar/KSystemBar.js +54 -0
  288. package/src/components/KSystemBar/index.js +7 -0
  289. package/src/components/KTabs/KTabs.js +240 -0
  290. package/src/components/KTabs/KTabsBar.js +202 -0
  291. package/src/components/KTabs/KTabsContent.js +90 -0
  292. package/src/components/KTabs/KTabsItem.js +99 -0
  293. package/src/components/KTabs/KTabsItems.js +40 -0
  294. package/src/components/KTabs/KTabsSlider.js +14 -0
  295. package/src/components/KTabs/index.js +17 -0
  296. package/src/components/KTextField/KTextField.js +246 -0
  297. package/src/components/KTextField/index.js +7 -0
  298. package/src/components/KTimePicker/KTimePicker.js +282 -0
  299. package/src/components/KTimePicker/index.js +7 -0
  300. package/src/components/KTimePicker/mixins/time-body.js +208 -0
  301. package/src/components/KTimePicker/mixins/time-title.js +51 -0
  302. package/src/components/KToolbar/KToolbar.js +206 -0
  303. package/src/components/KToolbar/KToolbarSideIcon.js +26 -0
  304. package/src/components/KToolbar/index.js +19 -0
  305. package/src/components/KTooltip/KTooltip.js +161 -0
  306. package/src/components/KTooltip/index.js +7 -0
  307. package/src/components/Kdutify/index.js +48 -0
  308. package/src/components/index.js +45 -0
  309. package/src/components/transitions/expand-transition.js +34 -0
  310. package/src/components/transitions/index.js +50 -0
  311. package/src/components/transitions/row-expand-transition.js +38 -0
  312. package/src/directives/click-outside.js +72 -0
  313. package/src/directives/index.js +21 -0
  314. package/src/directives/resize.js +30 -0
  315. package/src/directives/ripple.js +120 -0
  316. package/src/directives/scroll.js +31 -0
  317. package/src/directives/touch.js +90 -0
  318. package/src/index.js +30 -0
  319. package/src/mixins/applicationable.js +9 -0
  320. package/src/mixins/bootable.js +31 -0
  321. package/src/mixins/button-group.js +77 -0
  322. package/src/mixins/colorable.js +20 -0
  323. package/src/mixins/contextualable.js +10 -0
  324. package/src/mixins/delayable.js +54 -0
  325. package/src/mixins/dependent.js +55 -0
  326. package/src/mixins/detachable.js +44 -0
  327. package/src/mixins/filterable.js +8 -0
  328. package/src/mixins/input.js +220 -0
  329. package/src/mixins/loadable.js +33 -0
  330. package/src/mixins/maskable.js +117 -0
  331. package/src/mixins/menuable.js +299 -0
  332. package/src/mixins/overlayable.js +180 -0
  333. package/src/mixins/picker.js +35 -0
  334. package/src/mixins/positionable.js +10 -0
  335. package/src/mixins/rippleable.js +21 -0
  336. package/src/mixins/routable.js +66 -0
  337. package/src/mixins/selectable.js +84 -0
  338. package/src/mixins/stackable.js +44 -0
  339. package/src/mixins/tab-focusable.js +7 -0
  340. package/src/mixins/themeable.js +15 -0
  341. package/src/mixins/toggleable.js +28 -0
  342. package/src/mixins/transitionable.js +7 -0
  343. package/src/mixins/translatable.js +67 -0
  344. package/src/mixins/validatable.js +124 -0
  345. package/src/stylus/app.styl +6 -0
  346. package/src/stylus/bootstrap.styl +1 -0
  347. package/src/stylus/components/_alerts.styl +44 -0
  348. package/src/stylus/components/_app.styl +21 -0
  349. package/src/stylus/components/_avatars.styl +22 -0
  350. package/src/stylus/components/_badges.styl +49 -0
  351. package/src/stylus/components/_bottom-navs.styl +86 -0
  352. package/src/stylus/components/_bottom-sheets.styl +18 -0
  353. package/src/stylus/components/_breadcrumbs.styl +46 -0
  354. package/src/stylus/components/_button-toggle.styl +55 -0
  355. package/src/stylus/components/_buttons.styl +339 -0
  356. package/src/stylus/components/_cards.styl +85 -0
  357. package/src/stylus/components/_carousel.styl +76 -0
  358. package/src/stylus/components/_chips.styl +102 -0
  359. package/src/stylus/components/_content.styl +6 -0
  360. package/src/stylus/components/_data-table.styl +113 -0
  361. package/src/stylus/components/_date-picker.styl +214 -0
  362. package/src/stylus/components/_dialogs.styl +63 -0
  363. package/src/stylus/components/_dividers.styl +19 -0
  364. package/src/stylus/components/_expansion-panel.styl +85 -0
  365. package/src/stylus/components/_footer.styl +40 -0
  366. package/src/stylus/components/_grid.styl +171 -0
  367. package/src/stylus/components/_icons.styl +32 -0
  368. package/src/stylus/components/_input-groups.styl +310 -0
  369. package/src/stylus/components/_lists.styl +263 -0
  370. package/src/stylus/components/_menus.styl +87 -0
  371. package/src/stylus/components/_navigation-drawer.styl +150 -0
  372. package/src/stylus/components/_overlay.styl +42 -0
  373. package/src/stylus/components/_pagination.styl +95 -0
  374. package/src/stylus/components/_parallax.styl +35 -0
  375. package/src/stylus/components/_pickers.styl +66 -0
  376. package/src/stylus/components/_progress-circular.styl +58 -0
  377. package/src/stylus/components/_progress-linear.styl +104 -0
  378. package/src/stylus/components/_radio-group.styl +23 -0
  379. package/src/stylus/components/_ripples.styl +31 -0
  380. package/src/stylus/components/_select.styl +153 -0
  381. package/src/stylus/components/_selection-controls.styl +122 -0
  382. package/src/stylus/components/_sliders.styl +234 -0
  383. package/src/stylus/components/_small-dialog.styl +37 -0
  384. package/src/stylus/components/_snackbars.styl +110 -0
  385. package/src/stylus/components/_speed-dial.styl +78 -0
  386. package/src/stylus/components/_steppers.styl +216 -0
  387. package/src/stylus/components/_subheaders.styl +18 -0
  388. package/src/stylus/components/_switch.styl +89 -0
  389. package/src/stylus/components/_system-bars.styl +49 -0
  390. package/src/stylus/components/_tables.styl +103 -0
  391. package/src/stylus/components/_tabs.styl +159 -0
  392. package/src/stylus/components/_text-fields.styl +243 -0
  393. package/src/stylus/components/_time-picker.styl +199 -0
  394. package/src/stylus/components/_toolbar.styl +148 -0
  395. package/src/stylus/components/_tooltips.styl +25 -0
  396. package/src/stylus/elements/_blockquote.styl +5 -0
  397. package/src/stylus/elements/_code.styl +20 -0
  398. package/src/stylus/elements/_global.styl +31 -0
  399. package/src/stylus/elements/_headings.styl +17 -0
  400. package/src/stylus/elements/_lists.styl +2 -0
  401. package/src/stylus/elements/_typography.styl +54 -0
  402. package/src/stylus/generic/_bootstrap.styl +49 -0
  403. package/src/stylus/generic/_reset.styl +332 -0
  404. package/src/stylus/generic/_transitions.styl +116 -0
  405. package/src/stylus/main.styl +2 -0
  406. package/src/stylus/settings/_colors.styl +339 -0
  407. package/src/stylus/settings/_elevations.styl +111 -0
  408. package/src/stylus/settings/_theme.styl +201 -0
  409. package/src/stylus/settings/_variables.styl +396 -0
  410. package/src/stylus/theme.styl +24 -0
  411. package/src/stylus/tools/_animations.styl +9 -0
  412. package/src/stylus/tools/_colors.styl +17 -0
  413. package/src/stylus/tools/_elevations.styl +7 -0
  414. package/src/stylus/trumps/_display.styl +14 -0
  415. package/src/stylus/trumps/_helpers.styl +5 -0
  416. package/src/stylus/trumps/_spacing.styl +37 -0
  417. package/src/stylus/trumps/_text.styl +13 -0
  418. package/src/util/breakpoint.js +134 -0
  419. package/src/util/helpers.d.ts +21 -0
  420. package/src/util/helpers.js +125 -0
  421. package/src/util/load.js +13 -0
  422. package/src/util/mask.js +138 -0
  423. package/src/util/testing.js +154 -0
  424. package/src/util/to-have-been-warned.js +68 -0
  425. package/src/util/touchSupport.js +12 -0
@@ -0,0 +1,180 @@
1
+ require('../stylus/components/_overlay.styl')
2
+
3
+ export default {
4
+ data () {
5
+ return {
6
+ overlay: null,
7
+ overlayOffset: 0,
8
+ overlayTimeout: null,
9
+ overlayTransitionDuration: 500 + 150 // transition + delay
10
+ }
11
+ },
12
+
13
+ props: {
14
+ hideOverlay: Boolean
15
+ },
16
+
17
+ beforeDestroy () {
18
+ this.removeOverlay()
19
+ },
20
+
21
+ methods: {
22
+ genOverlay () {
23
+ // If fn is called and timeout is active
24
+ // or overlay already exists
25
+ // cancel removal of overlay and re-add active
26
+ if ((!this.isActive || this.hideOverlay) ||
27
+ (this.isActive && this.overlayTimeout) ||
28
+ this.overlay
29
+ ) {
30
+ clearTimeout(this.overlayTimeout)
31
+
32
+ return this.overlay &&
33
+ this.overlay.classList.add('overlay--active')
34
+ }
35
+
36
+ this.overlay = document.createElement('div')
37
+ this.overlay.className = 'overlay'
38
+
39
+ if (this.absolute) this.overlay.className += ' overlay--absolute'
40
+
41
+ this.hideScroll()
42
+
43
+ const parent = this.absolute
44
+ ? this.$el.parentNode
45
+ : document.querySelector('[data-app]')
46
+
47
+ parent.insertBefore(this.overlay, parent.firstChild)
48
+
49
+ this.overlay.clientHeight // Force repaint
50
+ requestAnimationFrame(() => {
51
+ this.overlay.className += ' overlay--active'
52
+
53
+ if (this.activeZIndex !== undefined) {
54
+ this.overlay.style.zIndex = this.activeZIndex - 1
55
+ }
56
+ })
57
+
58
+ return true
59
+ },
60
+ removeOverlay () {
61
+ if (!this.overlay) {
62
+ return this.showScroll()
63
+ }
64
+
65
+ this.overlay.classList.remove('overlay--active')
66
+
67
+ this.overlayTimeout = setTimeout(() => {
68
+ // IE11 Fix
69
+ try {
70
+ this.overlay.parentNode.removeChild(this.overlay)
71
+ this.overlay = null
72
+ this.showScroll()
73
+ } catch (e) {}
74
+
75
+ clearTimeout(this.overlayTimeout)
76
+ this.overlayTimeout = null
77
+ }, this.overlayTransitionDuration)
78
+ },
79
+ /**
80
+ * @param {Event} e
81
+ * @returns void
82
+ */
83
+ scrollListener (e) {
84
+ if (e.type === 'keydown') {
85
+ const up = [38, 33]
86
+ const down = [40, 34]
87
+
88
+ if (up.includes(e.keyCode)) {
89
+ e.deltaY = -1
90
+ } else if (down.includes(e.keyCode)) {
91
+ e.deltaY = 1
92
+ } else {
93
+ return
94
+ }
95
+ }
96
+
97
+ if (e.target === this.overlay ||
98
+ (e.type !== 'keydown' && e.target === document.body) ||
99
+ this.checkPath(e)) e.preventDefault()
100
+ },
101
+ hasScrollbar (el) {
102
+ const style = window.getComputedStyle(el)
103
+ return ['auto', 'scroll'].includes(style['overflow-y']) && el.scrollHeight > el.clientHeight
104
+ },
105
+ shouldScroll (el, delta) {
106
+ if (el.scrollTop === 0 && delta < 0) return true
107
+ return el.scrollTop + el.clientHeight === el.scrollHeight && delta > 0
108
+ },
109
+ isInside (el, parent) {
110
+ if (el === parent) {
111
+ return true
112
+ } else if (el === null || el === document.body) {
113
+ return false
114
+ } else {
115
+ return this.isInside(el.parentNode, parent)
116
+ }
117
+ },
118
+ /**
119
+ * @param {Event} e
120
+ * @returns boolean
121
+ */
122
+ checkPath (e) {
123
+ const path = e.path || this.composedPath(e)
124
+ const delta = e.deltaY || -e.wheelDelta
125
+
126
+ if (e.type === 'keydown' && path[0] === document.body) {
127
+ const dialog = this.$refs.dialog
128
+ const selected = window.getSelection().anchorNode
129
+ if (this.hasScrollbar(dialog) && this.isInside(selected, dialog)) {
130
+ return this.shouldScroll(dialog, delta)
131
+ }
132
+ return true
133
+ }
134
+
135
+ for (const el of path) {
136
+ if ([document, document.documentElement, this.$refs.content].includes(el)) return true
137
+ if (this.hasScrollbar(el)) return this.shouldScroll(el, delta)
138
+ }
139
+
140
+ return true
141
+ },
142
+ /**
143
+ * Polyfill for Event.prototype.composedPath
144
+ * @param {Event} e
145
+ * @returns Element[]
146
+ */
147
+ composedPath (e) {
148
+ if (e.composedPath) return e.composedPath()
149
+
150
+ const path = []
151
+ let el = e.target
152
+
153
+ while (el) {
154
+ path.push(el)
155
+
156
+ if (el.tagName === 'HTML') {
157
+ path.push(document)
158
+ path.push(window)
159
+
160
+ return path
161
+ }
162
+
163
+ el = el.parentElement
164
+ }
165
+ },
166
+ hideScroll () {
167
+ if (this.$kdutify.breakpoint.mdAndDown) {
168
+ document.documentElement.classList.add('overflow-y-hidden')
169
+ } else {
170
+ window.addEventListener('wheel', this.scrollListener)
171
+ window.addEventListener('keydown', this.scrollListener)
172
+ }
173
+ },
174
+ showScroll () {
175
+ document.documentElement.classList.remove('overflow-y-hidden')
176
+ window.removeEventListener('wheel', this.scrollListener)
177
+ window.removeEventListener('keydown', this.scrollListener)
178
+ }
179
+ }
180
+ }
@@ -0,0 +1,35 @@
1
+ import Themeable from './themeable'
2
+
3
+ export default {
4
+ mixins: [Themeable],
5
+
6
+ data () {
7
+ return {
8
+ isSaving: false
9
+ }
10
+ },
11
+
12
+ props: {
13
+ actions: Boolean,
14
+ autosave: Boolean,
15
+ landscape: Boolean,
16
+ noTitle: Boolean,
17
+ scrollable: Boolean,
18
+ value: {
19
+ required: true
20
+ },
21
+ light: Boolean,
22
+ dark: Boolean
23
+ },
24
+
25
+ methods: {
26
+ save () {},
27
+ cancel () {},
28
+ genSlot () {
29
+ return this.$scopedSlots.default({
30
+ save: this.save,
31
+ cancel: this.cancel
32
+ })
33
+ }
34
+ }
35
+ }
@@ -0,0 +1,10 @@
1
+ export default {
2
+ props: {
3
+ absolute: Boolean,
4
+ bottom: Boolean,
5
+ fixed: Boolean,
6
+ left: Boolean,
7
+ right: Boolean,
8
+ top: Boolean
9
+ }
10
+ }
@@ -0,0 +1,21 @@
1
+ import Ripple from '../directives/ripple'
2
+
3
+ /** @mixin */
4
+ export default {
5
+ directives: { Ripple },
6
+
7
+ methods: {
8
+ genRipple () {
9
+ return this.$createElement('div', {
10
+ 'class': this.rippleClasses || 'input-group--selection-controls__ripple',
11
+ on: Object.assign({}, {
12
+ click: this.toggle
13
+ }, this.$listeners),
14
+ directives: [{
15
+ name: 'ripple',
16
+ value: !this.disabled && { center: true }
17
+ }]
18
+ })
19
+ }
20
+ }
21
+ }
@@ -0,0 +1,66 @@
1
+ import Ripple from '../directives/ripple'
2
+
3
+ export default {
4
+ directives: {
5
+ Ripple
6
+ },
7
+
8
+ props: {
9
+ activeClass: String,
10
+ append: Boolean,
11
+ disabled: Boolean,
12
+ exact: Boolean,
13
+ href: [String, Object],
14
+ to: [String, Object],
15
+ nuxt: Boolean,
16
+ replace: Boolean,
17
+ ripple: Boolean,
18
+ tag: String,
19
+ target: String
20
+ },
21
+
22
+ methods: {
23
+ click () {},
24
+ generateRouteLink () {
25
+ let exact = this.exact
26
+ let tag
27
+
28
+ const data = {
29
+ attrs: { disabled: this.disabled },
30
+ class: this.classes,
31
+ props: {},
32
+ directives: [{
33
+ name: 'ripple',
34
+ value: this.ripple || false
35
+ }],
36
+ on: {
37
+ ...(this.$listeners || {}),
38
+ click: this.click
39
+ }
40
+ }
41
+
42
+ if (typeof this.exact === 'undefined') {
43
+ exact = this.to === '/' ||
44
+ (this.to === Object(this.to) && this.to.path === '/')
45
+ }
46
+
47
+ if (this.to) {
48
+ tag = this.nuxt ? 'nuxt-link' : 'router-link'
49
+ data.props.to = this.to
50
+ data.props.exact = exact
51
+ data.props.activeClass = this.activeClass
52
+ data.props.append = this.append
53
+ data.props.replace = this.replace
54
+ } else {
55
+ tag = this.href && 'a' || this.tag || 'a'
56
+
57
+ if (tag === 'a') {
58
+ data.attrs.href = this.href || 'javascript:;'
59
+ if (this.target) data.attrs.target = this.target
60
+ }
61
+ }
62
+
63
+ return { tag, data }
64
+ }
65
+ }
66
+ }
@@ -0,0 +1,84 @@
1
+ import Colorable from './colorable'
2
+ import Input from './input'
3
+
4
+ export default {
5
+ mixins: [Input, Colorable],
6
+
7
+ model: {
8
+ prop: 'inputValue',
9
+ event: 'change'
10
+ },
11
+
12
+ props: {
13
+ id: String,
14
+ inputValue: null,
15
+ falseValue: null,
16
+ trueValue: null
17
+ },
18
+
19
+ computed: {
20
+ isActive () {
21
+ if ((Array.isArray(this.inputValue))
22
+ ) {
23
+ return this.inputValue.indexOf(this.value) !== -1
24
+ }
25
+
26
+ if (!this.trueValue || !this.falseValue) {
27
+ return this.value
28
+ ? this.value === this.inputValue
29
+ : Boolean(this.inputValue)
30
+ }
31
+
32
+ return this.inputValue === this.trueValue
33
+ },
34
+ isDirty () {
35
+ return this.isActive
36
+ }
37
+ },
38
+
39
+ watch: {
40
+ indeterminate (val) {
41
+ this.inputIndeterminate = val
42
+ }
43
+ },
44
+
45
+ methods: {
46
+ genLabel () {
47
+ return this.$createElement('label', {
48
+ on: { click: this.toggle },
49
+ attrs: {
50
+ for: this.id
51
+ }
52
+ }, this.$slots.label || this.label)
53
+ },
54
+ toggle () {
55
+ if (this.disabled) {
56
+ return
57
+ }
58
+
59
+ let input = this.inputValue
60
+ if (Array.isArray(input)) {
61
+ input = input.slice()
62
+ const i = input.indexOf(this.value)
63
+
64
+ if (i === -1) {
65
+ input.push(this.value)
66
+ } else {
67
+ input.splice(i, 1)
68
+ }
69
+ } else if (this.trueValue || this.falseValue) {
70
+ input = input === this.trueValue ? this.falseValue : this.trueValue
71
+ } else if (this.value) {
72
+ input = this.value === this.inputValue
73
+ ? null
74
+ : this.value
75
+ } else {
76
+ input = !input
77
+ }
78
+
79
+ this.validate(true, input)
80
+
81
+ this.$emit('change', input)
82
+ }
83
+ }
84
+ }
@@ -0,0 +1,44 @@
1
+ import { getZIndex } from '../util/helpers'
2
+
3
+ export default {
4
+ data () {
5
+ return {
6
+ stackBase: null,
7
+ stackClass: 'unpecified',
8
+ stackElement: null,
9
+ stackExclude: null,
10
+ stackMinZIndex: 0
11
+ }
12
+ },
13
+ computed: {
14
+ activeZIndex () {
15
+ const content = this.stackElement || this.$refs.content
16
+ // Return current zindex if not active
17
+ if (!this.isActive) return getZIndex(content)
18
+
19
+ // Return max current z-index (excluding self) + 2
20
+ // (2 to leave room for an overlay below, if needed)
21
+ return this.getMaxZIndex(this.stackExclude || [content]) + 2
22
+ }
23
+ },
24
+ methods: {
25
+ getMaxZIndex (exclude = []) {
26
+ const base = this.stackBase || this.$el
27
+ // Start with lowest allowed z-index or z-index of
28
+ // base component's element, whichever is greater
29
+ const zis = [this.stackMinZIndex, getZIndex(base)]
30
+ // Convert the NodeList to an array to
31
+ // prevent an Edge bug with Symbol.iterator
32
+ const activeElements = [...document.getElementsByClassName(this.stackClass)]
33
+
34
+ // Get z-index for all active dialogs
35
+ for (const activeElement of activeElements) {
36
+ if (!exclude.includes(activeElement)) {
37
+ zis.push(getZIndex(activeElement))
38
+ }
39
+ }
40
+
41
+ return Math.max(...zis)
42
+ }
43
+ }
44
+ }
@@ -0,0 +1,7 @@
1
+ export default {
2
+ data () {
3
+ return {
4
+ tabFocused: false
5
+ }
6
+ }
7
+ }
@@ -0,0 +1,15 @@
1
+ export default {
2
+ props: {
3
+ dark: Boolean,
4
+ light: Boolean
5
+ },
6
+
7
+ computed: {
8
+ themeClasses () {
9
+ return {
10
+ 'theme--light': this.light,
11
+ 'theme--dark': this.dark
12
+ }
13
+ }
14
+ }
15
+ }
@@ -0,0 +1,28 @@
1
+ export function factory (prop = 'value', event = 'input') {
2
+ return {
3
+ model: { prop, event },
4
+
5
+ props: {
6
+ [prop]: { required: false }
7
+ },
8
+
9
+ data () {
10
+ return {
11
+ isActive: !!this[prop]
12
+ }
13
+ },
14
+
15
+ watch: {
16
+ [prop] (val) {
17
+ this.isActive = !!val
18
+ },
19
+ isActive (val) {
20
+ !!val !== this[prop] && this.$emit(event, val)
21
+ }
22
+ }
23
+ }
24
+ }
25
+
26
+ const Toggleable = factory()
27
+
28
+ export default Toggleable
@@ -0,0 +1,7 @@
1
+ export default {
2
+ props: {
3
+ mode: String,
4
+ origin: String,
5
+ transition: String
6
+ }
7
+ }
@@ -0,0 +1,67 @@
1
+ export default {
2
+ data () {
3
+ return {
4
+ parallax: null,
5
+ parallaxDist: null,
6
+ percentScrolled: null,
7
+ scrollTop: null,
8
+ windowHeight: null,
9
+ windowBottom: null
10
+ }
11
+ },
12
+
13
+ computed: {
14
+ normalizedHeight () {
15
+ if (this.jumbotron) {
16
+ return isNaN(this.height) ? this.height : `${this.height}px`
17
+ }
18
+
19
+ return Number(this.height.toString().replace(/(^[0-9]*$)/, '$1'))
20
+ },
21
+
22
+ imgHeight () {
23
+ return this.objHeight()
24
+ }
25
+ },
26
+
27
+ mounted () {
28
+ this.$kdutify.load(this.init)
29
+ },
30
+
31
+ beforeDestroy () {
32
+ window.removeEventListener('scroll', this.translate, false)
33
+ window.removeEventListener('resize', this.translate, false)
34
+ },
35
+
36
+ methods: {
37
+ listeners () {
38
+ window.addEventListener('scroll', this.translate, false)
39
+ window.addEventListener('resize', this.translate, false)
40
+ },
41
+
42
+ translate () {
43
+ this.calcDimensions()
44
+
45
+ this.percentScrolled = (
46
+ (this.windowBottom - this.elOffsetTop) /
47
+ (this.normalizedHeight + this.windowHeight)
48
+ )
49
+
50
+ this.parallax = Math.round(this.parallaxDist * this.percentScrolled)
51
+
52
+ if (this.translated) {
53
+ this.translated()
54
+ }
55
+ },
56
+
57
+ calcDimensions () {
58
+ const offset = this.$el.getBoundingClientRect()
59
+
60
+ this.scrollTop = window.pageYOffset
61
+ this.parallaxDist = this.imgHeight - this.normalizedHeight
62
+ this.elOffsetTop = offset.top + this.scrollTop
63
+ this.windowHeight = window.innerHeight
64
+ this.windowBottom = this.scrollTop + this.windowHeight
65
+ }
66
+ }
67
+ }
@@ -0,0 +1,124 @@
1
+ export default {
2
+ data () {
3
+ return {
4
+ errorBucket: [],
5
+ hasFocused: false,
6
+ hasInput: false,
7
+ shouldValidate: false,
8
+ valid: false
9
+ }
10
+ },
11
+
12
+ props: {
13
+ error: {
14
+ type: Boolean
15
+ },
16
+ errorMessages: {
17
+ type: [String, Array],
18
+ default: () => []
19
+ },
20
+ rules: {
21
+ type: Array,
22
+ default: () => []
23
+ },
24
+ validateOnBlur: Boolean
25
+ },
26
+
27
+ computed: {
28
+ validations () {
29
+ if (!Array.isArray(this.errorMessages)) {
30
+ return [this.errorMessages]
31
+ } else if (this.errorMessages.length > 0) {
32
+ return this.errorMessages
33
+ } else if (this.shouldValidate) {
34
+ return this.errorBucket
35
+ } else {
36
+ return []
37
+ }
38
+ },
39
+ hasError () {
40
+ return this.validations.length > 0 ||
41
+ this.errorMessages.length > 0 ||
42
+ this.error
43
+ }
44
+ },
45
+
46
+ watch: {
47
+ rules: {
48
+ handler (newVal, oldVal) {
49
+ // TODO: This handler seems to trigger when input changes, even though
50
+ // rules array stays the same? Solved it like this for now
51
+ if (newVal.length === oldVal.length) return
52
+
53
+ this.validate()
54
+ },
55
+ deep: true
56
+ },
57
+ inputValue (val) {
58
+ // If it's the first time we're setting input,
59
+ // mark it with hasInput
60
+ if (!!val && !this.hasInput) this.hasInput = true
61
+
62
+ if (this.hasInput && !this.validateOnBlur) this.shouldValidate = true
63
+ },
64
+ isFocused (val) {
65
+ // If we're not focused, and it's the first time
66
+ // we're defocusing, set shouldValidate to true
67
+ if (!val && !this.hasFocused) {
68
+ this.hasFocused = true
69
+ this.shouldValidate = true
70
+
71
+ this.$emit('update:error', this.errorBucket.length > 0)
72
+ }
73
+ },
74
+ hasError (val) {
75
+ if (this.shouldValidate) {
76
+ this.$emit('update:error', val)
77
+ }
78
+ },
79
+ error (val) {
80
+ this.shouldValidate = !!val
81
+ }
82
+ },
83
+
84
+ mounted () {
85
+ this.shouldValidate = !!this.error
86
+ this.validate()
87
+ },
88
+
89
+ methods: {
90
+ reset () {
91
+ // TODO: Do this another way!
92
+ // This is so that we can reset all types of inputs
93
+ this.$emit('input', this.isMultiple ? [] : null)
94
+ this.$emit('change', null)
95
+
96
+ this.$nextTick(() => {
97
+ this.shouldValidate = false
98
+ this.hasFocused = false
99
+ this.validate()
100
+ })
101
+ },
102
+ validate (force = false, value = this.inputValue) {
103
+ if (force) this.shouldValidate = true
104
+
105
+ this.errorBucket = []
106
+
107
+ this.rules.forEach(rule => {
108
+ const valid = typeof rule === 'function' ? rule(value) : rule
109
+
110
+ if (valid !== true && !['string', 'boolean'].includes(typeof valid)) {
111
+ throw new TypeError(`Rules should return a string or boolean, received '${typeof valid}' instead`)
112
+ }
113
+
114
+ if (valid !== true) {
115
+ this.errorBucket.push(valid)
116
+ }
117
+ })
118
+
119
+ this.valid = this.errorBucket.length === 0
120
+
121
+ return this.valid
122
+ }
123
+ }
124
+ }
@@ -0,0 +1,6 @@
1
+ @require './settings/*'
2
+ @require './generic/*'
3
+ @require './elements/*'
4
+ @require './tools/*'
5
+ @require './trumps/*'
6
+ @require './components/_tooltips.styl'
@@ -0,0 +1 @@
1
+ @import './settings/*'