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,138 @@
1
+ import {
2
+ KTabTransition,
3
+ KTabReverseTransition
4
+ } from '../transitions'
5
+
6
+ export default {
7
+ name: 'k-stepper-content',
8
+
9
+ components: {
10
+ KTabTransition,
11
+ KTabReverseTransition
12
+ },
13
+
14
+ data () {
15
+ return {
16
+ height: 0,
17
+ isActive: false,
18
+ isReverse: false,
19
+ isVertical: false
20
+ }
21
+ },
22
+
23
+ props: {
24
+ step: {
25
+ type: [Number, String],
26
+ required: true
27
+ }
28
+ },
29
+
30
+ computed: {
31
+ classes () {
32
+ return {
33
+ 'stepper__content': true
34
+ }
35
+ },
36
+ computedTransition () {
37
+ return this.isReverse
38
+ ? 'k-tab-reverse-transition'
39
+ : 'k-tab-transition'
40
+ },
41
+ styles () {
42
+ if (!this.isVertical) return {}
43
+
44
+ return {
45
+ height: !isNaN(this.height) ? `${this.height}px` : this.height
46
+ }
47
+ },
48
+ wrapperClasses () {
49
+ return {
50
+ 'stepper__wrapper': true
51
+ }
52
+ }
53
+ },
54
+
55
+ watch: {
56
+ isActive () {
57
+ if (!this.isVertical) {
58
+ return
59
+ }
60
+
61
+ if (this.isActive) {
62
+ this.enter()
63
+ } else {
64
+ this.leave()
65
+ }
66
+ }
67
+ },
68
+
69
+ mounted () {
70
+ this.$refs.wrapper.addEventListener(
71
+ 'transitionend',
72
+ this.onTransition,
73
+ false
74
+ )
75
+ },
76
+
77
+ beforeDestroy () {
78
+ this.$refs.wrapper.removeEventListener(
79
+ 'transitionend',
80
+ this.onTransition,
81
+ false
82
+ )
83
+ },
84
+
85
+ methods: {
86
+ onTransition () {
87
+ if (!this.isActive) return
88
+
89
+ this.height = 'auto'
90
+ },
91
+ enter () {
92
+ let scrollHeight = 0
93
+
94
+ // Render bug with height
95
+ setTimeout(() => {
96
+ scrollHeight = this.$refs.wrapper.scrollHeight
97
+ }, 0)
98
+
99
+ this.height = 0
100
+
101
+ // Give the collapsing element time to collapse
102
+ setTimeout(() => (this.height = (scrollHeight || 'auto')), 450)
103
+ },
104
+ leave () {
105
+ this.height = this.$refs.wrapper.clientHeight
106
+ setTimeout(() => (this.height = 0), 0)
107
+ },
108
+ toggle (step, reverse) {
109
+ this.isActive = step.toString() === this.step.toString()
110
+ this.isReverse = reverse
111
+ }
112
+ },
113
+
114
+ render (h) {
115
+ const contentData = {
116
+ 'class': this.classes
117
+ }
118
+ const wrapperData = {
119
+ 'class': this.wrapperClasses,
120
+ style: this.styles,
121
+ ref: 'wrapper'
122
+ }
123
+
124
+ if (!this.isVertical) {
125
+ contentData.directives = [{
126
+ name: 'show',
127
+ value: this.isActive
128
+ }]
129
+ }
130
+
131
+ const wrapper = h('div', wrapperData, [this.$slots.default])
132
+ const content = h('div', contentData, [wrapper])
133
+
134
+ return h(this.computedTransition, {
135
+ on: this.$listeners
136
+ }, [content])
137
+ }
138
+ }
@@ -0,0 +1,100 @@
1
+ import KIcon from '../KIcon'
2
+ import Ripple from '../../directives/ripple'
3
+
4
+ export default {
5
+ name: 'k-stepper-step',
6
+
7
+ components: { KIcon },
8
+
9
+ directives: { Ripple },
10
+
11
+ inject: ['stepClick'],
12
+
13
+ data () {
14
+ return {
15
+ isActive: false,
16
+ isInactive: true
17
+ }
18
+ },
19
+
20
+ props: {
21
+ complete: Boolean,
22
+ completeIcon: {
23
+ type: String,
24
+ default: 'check'
25
+ },
26
+ editIcon: {
27
+ type: String,
28
+ default: 'edit'
29
+ },
30
+ errorIcon: {
31
+ type: String,
32
+ default: 'warning'
33
+ },
34
+ editable: Boolean,
35
+ rules: {
36
+ type: Array,
37
+ default: () => []
38
+ },
39
+ step: [Number, String]
40
+ },
41
+
42
+ computed: {
43
+ classes () {
44
+ return {
45
+ 'stepper__step': true,
46
+ 'stepper__step--active': this.isActive,
47
+ 'stepper__step--editable': this.editable,
48
+ 'stepper__step--inactive': this.isInactive,
49
+ 'stepper__step--error': this.hasError,
50
+ 'stepper__step--complete': this.complete
51
+ }
52
+ },
53
+ hasError () {
54
+ return this.rules.some(i => (i() !== true))
55
+ }
56
+ },
57
+
58
+ methods: {
59
+ click (e) {
60
+ e.stopPropagation()
61
+
62
+ if (this.editable) {
63
+ this.stepClick(this.step)
64
+ }
65
+ },
66
+ toggle (step) {
67
+ this.isActive = step.toString() === this.step.toString()
68
+ this.isInactive = Number(step) < Number(this.step)
69
+ }
70
+ },
71
+
72
+ render (h) {
73
+ const data = {
74
+ 'class': this.classes,
75
+ directives: [{
76
+ name: 'ripple',
77
+ value: this.editable
78
+ }],
79
+ on: { click: this.click }
80
+ }
81
+ let stepContent
82
+
83
+ if (this.hasError) {
84
+ stepContent = [h('k-icon', {}, this.errorIcon)]
85
+ } else if (this.complete) {
86
+ if (this.editable) {
87
+ stepContent = [h('k-icon', {}, this.editIcon)]
88
+ } else {
89
+ stepContent = [h('k-icon', {}, this.completeIcon)]
90
+ }
91
+ } else {
92
+ stepContent = this.step
93
+ }
94
+
95
+ const step = h('span', { 'class': 'stepper__step__step' }, stepContent)
96
+ const label = h('div', { 'class': 'stepper__label' }, this.$slots.default)
97
+
98
+ return h('div', data, [step, label])
99
+ }
100
+ }
@@ -0,0 +1,17 @@
1
+ import { createSimpleFunctional } from '../../util/helpers'
2
+ import KStepper from './KStepper'
3
+ import KStepperStep from './KStepperStep'
4
+ import KStepperContent from './KStepperContent'
5
+
6
+ KStepper.install = function install (Kdu) {
7
+ const KStepperHeader = createSimpleFunctional('stepper__header')
8
+ const KStepperItems = createSimpleFunctional('stepper__items')
9
+
10
+ Kdu.component(KStepper.name, KStepper)
11
+ Kdu.component(KStepperContent.name, KStepperContent)
12
+ Kdu.component(KStepperStep.name, KStepperStep)
13
+ Kdu.component(KStepperHeader.name, KStepperHeader)
14
+ Kdu.component(KStepperItems.name, KStepperItems)
15
+ }
16
+
17
+ export default KStepper
@@ -0,0 +1,25 @@
1
+ require('../../stylus/components/_subheaders.styl')
2
+
3
+ import Themeable from '../../mixins/themeable'
4
+
5
+ export default {
6
+ name: 'k-subheader',
7
+
8
+ functional: true,
9
+
10
+ mixins: [Themeable],
11
+
12
+ props: {
13
+ inset: Boolean
14
+ },
15
+
16
+ render (h, { data, children, props }) {
17
+ data.staticClass = (`subheader ${data.staticClass || ''}`).trim()
18
+
19
+ if (props.inset) data.staticClass += ' subheader--inset'
20
+ if (props.light) data.staticClass += ' theme--light'
21
+ if (props.dark) data.staticClass += ' theme--dark'
22
+
23
+ return h('li', data, children)
24
+ }
25
+ }
@@ -0,0 +1,7 @@
1
+ import KSubheader from './KSubheader'
2
+
3
+ KSubheader.install = function install (Kdu) {
4
+ Kdu.component(KSubheader.name, KSubheader)
5
+ }
6
+
7
+ export default KSubheader
@@ -0,0 +1,58 @@
1
+ require('../../stylus/components/_input-groups.styl')
2
+ require('../../stylus/components/_selection-controls.styl')
3
+ require('../../stylus/components/_switch.styl')
4
+
5
+ import Rippleable from '../../mixins/rippleable'
6
+ import Selectable from '../../mixins/selectable'
7
+
8
+ export default {
9
+ name: 'k-switch',
10
+
11
+ mixins: [Rippleable, Selectable],
12
+
13
+ computed: {
14
+ classes () {
15
+ const classes = {
16
+ 'input-group--selection-controls switch': true
17
+ }
18
+
19
+ if (this.hasError) {
20
+ classes['error--text'] = true
21
+ } else {
22
+ return this.addTextColorClassChecks(classes)
23
+ }
24
+
25
+ return classes
26
+ },
27
+ rippleClasses () {
28
+ return {
29
+ 'input-group--selection-controls__ripple': true,
30
+ 'input-group--selection-controls__ripple--active': this.isActive
31
+ }
32
+ },
33
+ containerClasses () {
34
+ return {
35
+ 'input-group--selection-controls__container': true,
36
+ 'input-group--selection-controls__container--light': this.light,
37
+ 'input-group--selection-controls__container--disabled': this.disabled
38
+ }
39
+ },
40
+ toggleClasses () {
41
+ return {
42
+ 'input-group--selection-controls__toggle': true,
43
+ 'input-group--selection-controls__toggle--active': this.isActive
44
+ }
45
+ }
46
+ },
47
+
48
+ render (h) {
49
+ const container = h('div', {
50
+ 'class': this.containerClasses
51
+ }, [
52
+ h('div', { 'class': this.toggleClasses }),
53
+ this.genRipple()
54
+ ])
55
+
56
+ return this.genInputGroup([container])
57
+ }
58
+ }
@@ -0,0 +1,7 @@
1
+ import KSwitch from './KSwitch'
2
+
3
+ KSwitch.install = function install (Kdu) {
4
+ Kdu.component(KSwitch.name, KSwitch)
5
+ }
6
+
7
+ export default KSwitch
@@ -0,0 +1,54 @@
1
+ require('../../stylus/components/_system-bars.styl')
2
+
3
+ import Applicationable from '../../mixins/applicationable'
4
+ import Colorable from '../../mixins/colorable'
5
+ import Themeable from '../../mixins/themeable'
6
+
7
+ export default {
8
+ name: 'k-system-bar',
9
+
10
+ mixins: [Applicationable, Colorable, Themeable],
11
+
12
+ props: {
13
+ lightsOut: Boolean,
14
+ status: Boolean,
15
+ window: Boolean
16
+ },
17
+
18
+ computed: {
19
+ classes () {
20
+ return this.addBackgroundColorClassChecks({
21
+ 'system-bar': true,
22
+ 'system-bar--lights-out': this.lightsOut,
23
+ 'system-bar--status': this.status,
24
+ 'system-bar--window': this.window,
25
+ 'theme--dark': this.dark,
26
+ 'theme--light': this.light
27
+ })
28
+ },
29
+ computedHeight () {
30
+ if (this.window) return 32
31
+
32
+ return 24
33
+ }
34
+ },
35
+
36
+ methods: {
37
+ updateApplication () {
38
+ if (!this.app) return
39
+
40
+ this.$kdutify.application.bar = this.computedHeight
41
+ }
42
+ },
43
+
44
+ render (h) {
45
+ const data = {
46
+ 'class': this.classes,
47
+ style: {
48
+ height: `${this.computedHeight}px`
49
+ }
50
+ }
51
+
52
+ return h('div', data, this.$slots.default)
53
+ }
54
+ }
@@ -0,0 +1,7 @@
1
+ import KSystemBar from './KSystemBar'
2
+
3
+ KSystemBar.install = function install (Kdu) {
4
+ Kdu.component(KSystemBar.name, KSystemBar)
5
+ }
6
+
7
+ export default KSystemBar
@@ -0,0 +1,240 @@
1
+ require('../../stylus/components/_tabs.styl')
2
+
3
+ import Themeable from '../../mixins/themeable'
4
+ import Resize from '../../directives/resize'
5
+
6
+ export default {
7
+ name: 'k-tabs',
8
+
9
+ directives: {
10
+ Resize
11
+ },
12
+
13
+ mixins: [Themeable],
14
+
15
+ provide () {
16
+ return {
17
+ registerContent: this.registerContent,
18
+ unregisterContent: this.unregisterContent,
19
+ registerTabItem: this.registerTabItem,
20
+ unregisterTabItem: this.unregisterTabItem,
21
+ next: this.next,
22
+ prev: this.prev,
23
+ slider: this.slider,
24
+ tabClick: this.tabClick,
25
+ isScrollable: () => this.scrollable,
26
+ isMobile: () => this.isMobile
27
+ }
28
+ },
29
+
30
+ data () {
31
+ return {
32
+ content: [],
33
+ tabItems: [],
34
+ activeIndex: null,
35
+ isBooted: false,
36
+ isMobile: false,
37
+ resizeTimeout: null,
38
+ reverse: false,
39
+ target: null,
40
+ tabsSlider: null,
41
+ targetEl: null,
42
+ tabsContainer: null,
43
+ transitionTime: 300
44
+ }
45
+ },
46
+
47
+ props: {
48
+ centered: Boolean,
49
+ fixed: Boolean,
50
+ grow: Boolean,
51
+ icons: Boolean,
52
+ mobileBreakPoint: {
53
+ type: [Number, String],
54
+ default: 1280
55
+ },
56
+ value: String,
57
+ scrollable: {
58
+ type: Boolean,
59
+ default: true
60
+ }
61
+ },
62
+
63
+ computed: {
64
+ classes () {
65
+ return {
66
+ 'tabs': true,
67
+ 'tabs--centered': this.centered,
68
+ 'tabs--fixed': this.fixed,
69
+ 'tabs--grow': this.grow,
70
+ 'tabs--icons': this.icons,
71
+ 'tabs--mobile': this.isMobile,
72
+ 'tabs--scroll-bars': this.scrollable,
73
+ 'theme--dark': this.dark,
74
+ 'theme--light': this.light
75
+ }
76
+ }
77
+ },
78
+
79
+ watch: {
80
+ value () {
81
+ this.tabClick(this.value)
82
+ },
83
+ activeIndex () {
84
+ this.updateTabs()
85
+ this.$nextTick(() => (this.isBooted = true))
86
+ },
87
+ tabItems (newItems, oldItems) {
88
+ // Tab item got removed
89
+ if (oldItems.length > newItems.length) {
90
+ if (!newItems.find(o => o.id === this.target)) {
91
+ const i = oldItems.findIndex(o => o.id === this.target)
92
+
93
+ this.$nextTick(() => {
94
+ this.activeIndex = this.tabItems[i > 0 ? i - 1 : 0].id
95
+ this.target = this.activeIndex
96
+ })
97
+ }
98
+ }
99
+ this.slider()
100
+ },
101
+ '$kdutify.application.left' () {
102
+ this.onContainerResize()
103
+ },
104
+ '$kdutify.application.right' () {
105
+ this.onContainerResize()
106
+ }
107
+ },
108
+
109
+ mounted () {
110
+ this.$kdutify.load(() => {
111
+ // // This is a workaround to detect if link is active
112
+ // // when being used as a router or nuxt link
113
+ const i = this.tabItems.findIndex(({ el }) => {
114
+ return el.firstChild.classList.contains('tabs__item--active')
115
+ })
116
+
117
+ const tab = this.value || (this.tabItems[i !== -1 ? i : 0] || {}).id
118
+
119
+ tab && this.tabClick(tab) && this.onResize()
120
+ })
121
+ },
122
+
123
+ methods: {
124
+ registerContent (id, toggle) {
125
+ this.content.push({ id, toggle })
126
+ },
127
+ registerTabItem (id, toggle, el) {
128
+ this.tabItems.push({ id, toggle, el })
129
+ },
130
+ unregisterContent (id) {
131
+ this.content = this.content.filter(o => o.id !== id)
132
+ },
133
+ unregisterTabItem (id) {
134
+ this.tabItems = this.tabItems.filter(o => o.id !== id)
135
+ },
136
+ next (cycle) {
137
+ let nextIndex = this.activeIndex + 1
138
+
139
+ if (!this.content[nextIndex]) {
140
+ if (!cycle) return
141
+ nextIndex = 0
142
+ }
143
+
144
+ this.tabClick(this.tabItems[nextIndex].id)
145
+ },
146
+ prev (cycle) {
147
+ let prevIndex = this.activeIndex - 1
148
+
149
+ if (!this.content[prevIndex]) {
150
+ if (!cycle) return
151
+ prevIndex = this.content.length - 1
152
+ }
153
+
154
+ this.tabClick(this.tabItems[prevIndex].id)
155
+ },
156
+ onResize () {
157
+ this.isMobile = window.innerWidth < this.mobileBreakPoint
158
+ this.slider()
159
+ },
160
+ /**
161
+ * When k-navigation-drawer changes the
162
+ * width of the container, call resize
163
+ * after the transition is complete
164
+ *
165
+ * @return {Void}
166
+ */
167
+ onContainerResize () {
168
+ clearTimeout(this.resizeTimeout)
169
+ this.resizeTimeout = setTimeout(this.onResize, this.transitionTime)
170
+ },
171
+ slider (el) {
172
+ this.tabsSlider = this.tabsSlider ||
173
+ this.$el.querySelector('.tabs__slider')
174
+
175
+ this.tabsContainer = this.tabsContainer ||
176
+ this.$el.querySelector('.tabs__container')
177
+
178
+ if (!this.tabsSlider || !this.tabsContainer) return
179
+
180
+ this.targetEl = el || this.targetEl
181
+
182
+ if (!this.targetEl) return
183
+
184
+ // Gives DOM time to paint when
185
+ // processing slider for
186
+ // dynamic tabs
187
+ this.$nextTick(() => {
188
+ // #684 Calculate width as %
189
+ const width = (
190
+ this.targetEl.scrollWidth /
191
+ this.tabsContainer.clientWidth *
192
+ 100
193
+ )
194
+
195
+ this.tabsSlider.style.width = `${width}%`
196
+ this.tabsSlider.style.left = `${this.targetEl.offsetLeft}px`
197
+ })
198
+ },
199
+ tabClick (target) {
200
+ const setActiveIndex = index => {
201
+ if (this.activeIndex === index) {
202
+ // #762 update tabs display
203
+ // In case tabs count got changed but activeIndex didn't
204
+ this.updateTabs()
205
+ } else {
206
+ this.activeIndex = index
207
+ }
208
+ }
209
+
210
+ this.target = target
211
+
212
+ this.$nextTick(() => {
213
+ const nextIndex = this.content.findIndex(o => o.id === target)
214
+ this.reverse = nextIndex < this.activeIndex
215
+ setActiveIndex(nextIndex)
216
+
217
+ this.$emit('input', this.target)
218
+ })
219
+ },
220
+ updateTabs () {
221
+ this.content.forEach(({ toggle }) => {
222
+ toggle(this.target, this.reverse, this.isBooted)
223
+ })
224
+
225
+ this.tabItems.forEach(({ toggle }) => {
226
+ toggle(this.target)
227
+ })
228
+ }
229
+ },
230
+
231
+ render (h) {
232
+ return h('div', {
233
+ 'class': this.classes,
234
+ directives: [{
235
+ name: 'resize',
236
+ value: this.onResize
237
+ }]
238
+ }, this.$slots.default)
239
+ }
240
+ }