@keenthemes/ktui 1.0.3

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 (426) hide show
  1. package/CONTRIBUTING.md +88 -0
  2. package/LICENSE.md +21 -0
  3. package/README.md +124 -0
  4. package/dist/ktui.js +19201 -0
  5. package/dist/ktui.min.js +2 -0
  6. package/dist/ktui.min.js.map +1 -0
  7. package/lib/cjs/components/accordion/accordion.js +168 -0
  8. package/lib/cjs/components/accordion/accordion.js.map +1 -0
  9. package/lib/cjs/components/accordion/index.js +6 -0
  10. package/lib/cjs/components/accordion/index.js.map +1 -0
  11. package/lib/cjs/components/accordion/types.js +3 -0
  12. package/lib/cjs/components/accordion/types.js.map +1 -0
  13. package/lib/cjs/components/collapse/collapse.js +169 -0
  14. package/lib/cjs/components/collapse/collapse.js.map +1 -0
  15. package/lib/cjs/components/collapse/index.js +6 -0
  16. package/lib/cjs/components/collapse/index.js.map +1 -0
  17. package/lib/cjs/components/collapse/types.js +3 -0
  18. package/lib/cjs/components/collapse/types.js.map +1 -0
  19. package/lib/cjs/components/component.js +135 -0
  20. package/lib/cjs/components/component.js.map +1 -0
  21. package/lib/cjs/components/config.js +26 -0
  22. package/lib/cjs/components/config.js.map +1 -0
  23. package/lib/cjs/components/config.umd.js +23 -0
  24. package/lib/cjs/components/config.umd.js.map +1 -0
  25. package/lib/cjs/components/constants.js +15 -0
  26. package/lib/cjs/components/constants.js.map +1 -0
  27. package/lib/cjs/components/datatable/datatable.js +1464 -0
  28. package/lib/cjs/components/datatable/datatable.js.map +1 -0
  29. package/lib/cjs/components/datatable/index.js +6 -0
  30. package/lib/cjs/components/datatable/index.js.map +1 -0
  31. package/lib/cjs/components/datatable/types.js +3 -0
  32. package/lib/cjs/components/datatable/types.js.map +1 -0
  33. package/lib/cjs/components/dismiss/dismiss.js +131 -0
  34. package/lib/cjs/components/dismiss/dismiss.js.map +1 -0
  35. package/lib/cjs/components/dismiss/index.js +6 -0
  36. package/lib/cjs/components/dismiss/index.js.map +1 -0
  37. package/lib/cjs/components/dismiss/types.js +3 -0
  38. package/lib/cjs/components/dismiss/types.js.map +1 -0
  39. package/lib/cjs/components/drawer/drawer.js +347 -0
  40. package/lib/cjs/components/drawer/drawer.js.map +1 -0
  41. package/lib/cjs/components/drawer/index.js +6 -0
  42. package/lib/cjs/components/drawer/index.js.map +1 -0
  43. package/lib/cjs/components/drawer/types.js +3 -0
  44. package/lib/cjs/components/drawer/types.js.map +1 -0
  45. package/lib/cjs/components/dropdown/dropdown.js +403 -0
  46. package/lib/cjs/components/dropdown/dropdown.js.map +1 -0
  47. package/lib/cjs/components/dropdown/index.js +6 -0
  48. package/lib/cjs/components/dropdown/index.js.map +1 -0
  49. package/lib/cjs/components/dropdown/types.js +3 -0
  50. package/lib/cjs/components/dropdown/types.js.map +1 -0
  51. package/lib/cjs/components/image-input/image-input.js +191 -0
  52. package/lib/cjs/components/image-input/image-input.js.map +1 -0
  53. package/lib/cjs/components/image-input/index.js +6 -0
  54. package/lib/cjs/components/image-input/index.js.map +1 -0
  55. package/lib/cjs/components/image-input/types.js +3 -0
  56. package/lib/cjs/components/image-input/types.js.map +1 -0
  57. package/lib/cjs/components/menu/index.js +6 -0
  58. package/lib/cjs/components/menu/index.js.map +1 -0
  59. package/lib/cjs/components/menu/menu.js +1021 -0
  60. package/lib/cjs/components/menu/menu.js.map +1 -0
  61. package/lib/cjs/components/menu/types.js +3 -0
  62. package/lib/cjs/components/menu/types.js.map +1 -0
  63. package/lib/cjs/components/modal/index.js +6 -0
  64. package/lib/cjs/components/modal/index.js.map +1 -0
  65. package/lib/cjs/components/modal/modal.js +316 -0
  66. package/lib/cjs/components/modal/modal.js.map +1 -0
  67. package/lib/cjs/components/modal/types.js +3 -0
  68. package/lib/cjs/components/modal/types.js.map +1 -0
  69. package/lib/cjs/components/reparent/index.js +6 -0
  70. package/lib/cjs/components/reparent/index.js.map +1 -0
  71. package/lib/cjs/components/reparent/reparent.js +93 -0
  72. package/lib/cjs/components/reparent/reparent.js.map +1 -0
  73. package/lib/cjs/components/reparent/types.js +3 -0
  74. package/lib/cjs/components/reparent/types.js.map +1 -0
  75. package/lib/cjs/components/scrollable/index.js +6 -0
  76. package/lib/cjs/components/scrollable/index.js.map +1 -0
  77. package/lib/cjs/components/scrollable/scrollable.js +259 -0
  78. package/lib/cjs/components/scrollable/scrollable.js.map +1 -0
  79. package/lib/cjs/components/scrollable/types.js +3 -0
  80. package/lib/cjs/components/scrollable/types.js.map +1 -0
  81. package/lib/cjs/components/scrollspy/index.js +6 -0
  82. package/lib/cjs/components/scrollspy/index.js.map +1 -0
  83. package/lib/cjs/components/scrollspy/scrollspy.js +174 -0
  84. package/lib/cjs/components/scrollspy/scrollspy.js.map +1 -0
  85. package/lib/cjs/components/scrollspy/types.js +3 -0
  86. package/lib/cjs/components/scrollspy/types.js.map +1 -0
  87. package/lib/cjs/components/scrollto/index.js +6 -0
  88. package/lib/cjs/components/scrollto/index.js.map +1 -0
  89. package/lib/cjs/components/scrollto/scrollto.js +103 -0
  90. package/lib/cjs/components/scrollto/scrollto.js.map +1 -0
  91. package/lib/cjs/components/scrollto/types.js +3 -0
  92. package/lib/cjs/components/scrollto/types.js.map +1 -0
  93. package/lib/cjs/components/stepper/index.js +6 -0
  94. package/lib/cjs/components/stepper/index.js.map +1 -0
  95. package/lib/cjs/components/stepper/stepper.js +258 -0
  96. package/lib/cjs/components/stepper/stepper.js.map +1 -0
  97. package/lib/cjs/components/stepper/types.js +3 -0
  98. package/lib/cjs/components/stepper/types.js.map +1 -0
  99. package/lib/cjs/components/sticky/index.js +6 -0
  100. package/lib/cjs/components/sticky/index.js.map +1 -0
  101. package/lib/cjs/components/sticky/sticky.js +297 -0
  102. package/lib/cjs/components/sticky/sticky.js.map +1 -0
  103. package/lib/cjs/components/sticky/types.js +3 -0
  104. package/lib/cjs/components/sticky/types.js.map +1 -0
  105. package/lib/cjs/components/tabs/index.js +6 -0
  106. package/lib/cjs/components/tabs/index.js.map +1 -0
  107. package/lib/cjs/components/tabs/tabs.js +146 -0
  108. package/lib/cjs/components/tabs/tabs.js.map +1 -0
  109. package/lib/cjs/components/tabs/types.js +3 -0
  110. package/lib/cjs/components/tabs/types.js.map +1 -0
  111. package/lib/cjs/components/theme/index.js +6 -0
  112. package/lib/cjs/components/theme/index.js.map +1 -0
  113. package/lib/cjs/components/theme/theme.js +147 -0
  114. package/lib/cjs/components/theme/theme.js.map +1 -0
  115. package/lib/cjs/components/theme/types.js +3 -0
  116. package/lib/cjs/components/theme/types.js.map +1 -0
  117. package/lib/cjs/components/toggle/index.js +6 -0
  118. package/lib/cjs/components/toggle/index.js.map +1 -0
  119. package/lib/cjs/components/toggle/toggle.js +139 -0
  120. package/lib/cjs/components/toggle/toggle.js.map +1 -0
  121. package/lib/cjs/components/toggle/types.js +3 -0
  122. package/lib/cjs/components/toggle/types.js.map +1 -0
  123. package/lib/cjs/components/toggle-password/index.js +6 -0
  124. package/lib/cjs/components/toggle-password/index.js.map +1 -0
  125. package/lib/cjs/components/toggle-password/toggle-password.js +131 -0
  126. package/lib/cjs/components/toggle-password/toggle-password.js.map +1 -0
  127. package/lib/cjs/components/toggle-password/types.js +3 -0
  128. package/lib/cjs/components/toggle-password/types.js.map +1 -0
  129. package/lib/cjs/components/tooltip/index.js +6 -0
  130. package/lib/cjs/components/tooltip/index.js.map +1 -0
  131. package/lib/cjs/components/tooltip/tooltip.js +271 -0
  132. package/lib/cjs/components/tooltip/tooltip.js.map +1 -0
  133. package/lib/cjs/components/tooltip/types.js +3 -0
  134. package/lib/cjs/components/tooltip/types.js.map +1 -0
  135. package/lib/cjs/helpers/data.js +33 -0
  136. package/lib/cjs/helpers/data.js.map +1 -0
  137. package/lib/cjs/helpers/dom.js +297 -0
  138. package/lib/cjs/helpers/dom.js.map +1 -0
  139. package/lib/cjs/helpers/event-handler.js +36 -0
  140. package/lib/cjs/helpers/event-handler.js.map +1 -0
  141. package/lib/cjs/helpers/utils.js +94 -0
  142. package/lib/cjs/helpers/utils.js.map +1 -0
  143. package/lib/cjs/index.js +105 -0
  144. package/lib/cjs/index.js.map +1 -0
  145. package/lib/cjs/types.js +3 -0
  146. package/lib/cjs/types.js.map +1 -0
  147. package/lib/esm/components/accordion/accordion.js +165 -0
  148. package/lib/esm/components/accordion/accordion.js.map +1 -0
  149. package/lib/esm/components/accordion/index.js +2 -0
  150. package/lib/esm/components/accordion/index.js.map +1 -0
  151. package/lib/esm/components/accordion/types.js +2 -0
  152. package/lib/esm/components/accordion/types.js.map +1 -0
  153. package/lib/esm/components/collapse/collapse.js +166 -0
  154. package/lib/esm/components/collapse/collapse.js.map +1 -0
  155. package/lib/esm/components/collapse/index.js +2 -0
  156. package/lib/esm/components/collapse/index.js.map +1 -0
  157. package/lib/esm/components/collapse/types.js +2 -0
  158. package/lib/esm/components/collapse/types.js.map +1 -0
  159. package/lib/esm/components/component.js +133 -0
  160. package/lib/esm/components/component.js.map +1 -0
  161. package/lib/esm/components/config.js +24 -0
  162. package/lib/esm/components/config.js.map +1 -0
  163. package/lib/esm/components/config.umd.js +23 -0
  164. package/lib/esm/components/config.umd.js.map +1 -0
  165. package/lib/esm/components/constants.js +12 -0
  166. package/lib/esm/components/constants.js.map +1 -0
  167. package/lib/esm/components/datatable/datatable.js +1461 -0
  168. package/lib/esm/components/datatable/datatable.js.map +1 -0
  169. package/lib/esm/components/datatable/index.js +2 -0
  170. package/lib/esm/components/datatable/index.js.map +1 -0
  171. package/lib/esm/components/datatable/types.js +2 -0
  172. package/lib/esm/components/datatable/types.js.map +1 -0
  173. package/lib/esm/components/dismiss/dismiss.js +128 -0
  174. package/lib/esm/components/dismiss/dismiss.js.map +1 -0
  175. package/lib/esm/components/dismiss/index.js +2 -0
  176. package/lib/esm/components/dismiss/index.js.map +1 -0
  177. package/lib/esm/components/dismiss/types.js +2 -0
  178. package/lib/esm/components/dismiss/types.js.map +1 -0
  179. package/lib/esm/components/drawer/drawer.js +344 -0
  180. package/lib/esm/components/drawer/drawer.js.map +1 -0
  181. package/lib/esm/components/drawer/index.js +2 -0
  182. package/lib/esm/components/drawer/index.js.map +1 -0
  183. package/lib/esm/components/drawer/types.js +2 -0
  184. package/lib/esm/components/drawer/types.js.map +1 -0
  185. package/lib/esm/components/dropdown/dropdown.js +400 -0
  186. package/lib/esm/components/dropdown/dropdown.js.map +1 -0
  187. package/lib/esm/components/dropdown/index.js +2 -0
  188. package/lib/esm/components/dropdown/index.js.map +1 -0
  189. package/lib/esm/components/dropdown/types.js +2 -0
  190. package/lib/esm/components/dropdown/types.js.map +1 -0
  191. package/lib/esm/components/image-input/image-input.js +188 -0
  192. package/lib/esm/components/image-input/image-input.js.map +1 -0
  193. package/lib/esm/components/image-input/index.js +2 -0
  194. package/lib/esm/components/image-input/index.js.map +1 -0
  195. package/lib/esm/components/image-input/types.js +2 -0
  196. package/lib/esm/components/image-input/types.js.map +1 -0
  197. package/lib/esm/components/menu/index.js +2 -0
  198. package/lib/esm/components/menu/index.js.map +1 -0
  199. package/lib/esm/components/menu/menu.js +1018 -0
  200. package/lib/esm/components/menu/menu.js.map +1 -0
  201. package/lib/esm/components/menu/types.js +2 -0
  202. package/lib/esm/components/menu/types.js.map +1 -0
  203. package/lib/esm/components/modal/index.js +2 -0
  204. package/lib/esm/components/modal/index.js.map +1 -0
  205. package/lib/esm/components/modal/modal.js +313 -0
  206. package/lib/esm/components/modal/modal.js.map +1 -0
  207. package/lib/esm/components/modal/types.js +2 -0
  208. package/lib/esm/components/modal/types.js.map +1 -0
  209. package/lib/esm/components/reparent/index.js +2 -0
  210. package/lib/esm/components/reparent/index.js.map +1 -0
  211. package/lib/esm/components/reparent/reparent.js +90 -0
  212. package/lib/esm/components/reparent/reparent.js.map +1 -0
  213. package/lib/esm/components/reparent/types.js +2 -0
  214. package/lib/esm/components/reparent/types.js.map +1 -0
  215. package/lib/esm/components/scrollable/index.js +2 -0
  216. package/lib/esm/components/scrollable/index.js.map +1 -0
  217. package/lib/esm/components/scrollable/scrollable.js +256 -0
  218. package/lib/esm/components/scrollable/scrollable.js.map +1 -0
  219. package/lib/esm/components/scrollable/types.js +2 -0
  220. package/lib/esm/components/scrollable/types.js.map +1 -0
  221. package/lib/esm/components/scrollspy/index.js +2 -0
  222. package/lib/esm/components/scrollspy/index.js.map +1 -0
  223. package/lib/esm/components/scrollspy/scrollspy.js +171 -0
  224. package/lib/esm/components/scrollspy/scrollspy.js.map +1 -0
  225. package/lib/esm/components/scrollspy/types.js +2 -0
  226. package/lib/esm/components/scrollspy/types.js.map +1 -0
  227. package/lib/esm/components/scrollto/index.js +2 -0
  228. package/lib/esm/components/scrollto/index.js.map +1 -0
  229. package/lib/esm/components/scrollto/scrollto.js +100 -0
  230. package/lib/esm/components/scrollto/scrollto.js.map +1 -0
  231. package/lib/esm/components/scrollto/types.js +2 -0
  232. package/lib/esm/components/scrollto/types.js.map +1 -0
  233. package/lib/esm/components/stepper/index.js +2 -0
  234. package/lib/esm/components/stepper/index.js.map +1 -0
  235. package/lib/esm/components/stepper/stepper.js +255 -0
  236. package/lib/esm/components/stepper/stepper.js.map +1 -0
  237. package/lib/esm/components/stepper/types.js +2 -0
  238. package/lib/esm/components/stepper/types.js.map +1 -0
  239. package/lib/esm/components/sticky/index.js +2 -0
  240. package/lib/esm/components/sticky/index.js.map +1 -0
  241. package/lib/esm/components/sticky/sticky.js +294 -0
  242. package/lib/esm/components/sticky/sticky.js.map +1 -0
  243. package/lib/esm/components/sticky/types.js +2 -0
  244. package/lib/esm/components/sticky/types.js.map +1 -0
  245. package/lib/esm/components/tabs/index.js +2 -0
  246. package/lib/esm/components/tabs/index.js.map +1 -0
  247. package/lib/esm/components/tabs/tabs.js +143 -0
  248. package/lib/esm/components/tabs/tabs.js.map +1 -0
  249. package/lib/esm/components/tabs/types.js +2 -0
  250. package/lib/esm/components/tabs/types.js.map +1 -0
  251. package/lib/esm/components/theme/index.js +2 -0
  252. package/lib/esm/components/theme/index.js.map +1 -0
  253. package/lib/esm/components/theme/theme.js +144 -0
  254. package/lib/esm/components/theme/theme.js.map +1 -0
  255. package/lib/esm/components/theme/types.js +2 -0
  256. package/lib/esm/components/theme/types.js.map +1 -0
  257. package/lib/esm/components/toggle/index.js +2 -0
  258. package/lib/esm/components/toggle/index.js.map +1 -0
  259. package/lib/esm/components/toggle/toggle.js +136 -0
  260. package/lib/esm/components/toggle/toggle.js.map +1 -0
  261. package/lib/esm/components/toggle/types.js +2 -0
  262. package/lib/esm/components/toggle/types.js.map +1 -0
  263. package/lib/esm/components/toggle-password/index.js +2 -0
  264. package/lib/esm/components/toggle-password/index.js.map +1 -0
  265. package/lib/esm/components/toggle-password/toggle-password.js +128 -0
  266. package/lib/esm/components/toggle-password/toggle-password.js.map +1 -0
  267. package/lib/esm/components/toggle-password/types.js +2 -0
  268. package/lib/esm/components/toggle-password/types.js.map +1 -0
  269. package/lib/esm/components/tooltip/index.js +2 -0
  270. package/lib/esm/components/tooltip/index.js.map +1 -0
  271. package/lib/esm/components/tooltip/tooltip.js +268 -0
  272. package/lib/esm/components/tooltip/tooltip.js.map +1 -0
  273. package/lib/esm/components/tooltip/types.js +2 -0
  274. package/lib/esm/components/tooltip/types.js.map +1 -0
  275. package/lib/esm/helpers/data.js +31 -0
  276. package/lib/esm/helpers/data.js.map +1 -0
  277. package/lib/esm/helpers/dom.js +295 -0
  278. package/lib/esm/helpers/dom.js.map +1 -0
  279. package/lib/esm/helpers/event-handler.js +34 -0
  280. package/lib/esm/helpers/event-handler.js.map +1 -0
  281. package/lib/esm/helpers/utils.js +92 -0
  282. package/lib/esm/helpers/utils.js.map +1 -0
  283. package/lib/esm/index.js +79 -0
  284. package/lib/esm/index.js.map +1 -0
  285. package/lib/esm/types.js +2 -0
  286. package/lib/esm/types.js.map +1 -0
  287. package/package.json +85 -0
  288. package/prettier.config.js +9 -0
  289. package/src/components/accordion/accordion-menu.css +51 -0
  290. package/src/components/accordion/accordion.css +86 -0
  291. package/src/components/accordion/accordion.ts +221 -0
  292. package/src/components/accordion/index.ts +7 -0
  293. package/src/components/accordion/types.ts +16 -0
  294. package/src/components/alert/alert.css +282 -0
  295. package/src/components/avatar/avatar.css +46 -0
  296. package/src/components/badge/badge.css +176 -0
  297. package/src/components/breadcrumb/breadcrumb.css +38 -0
  298. package/src/components/btn/btn.css +227 -0
  299. package/src/components/card/card.css +158 -0
  300. package/src/components/checkbox/checkbox.css +74 -0
  301. package/src/components/collapse/collapse.css +14 -0
  302. package/src/components/collapse/collapse.ts +200 -0
  303. package/src/components/collapse/index.ts +7 -0
  304. package/src/components/collapse/types.ts +16 -0
  305. package/src/components/component.ts +132 -0
  306. package/src/components/constants.ts +16 -0
  307. package/src/components/datatable/datatable-checkbox.ts +236 -0
  308. package/src/components/datatable/datatable-sort.ts +154 -0
  309. package/src/components/datatable/datatable.css +110 -0
  310. package/src/components/datatable/datatable.ts +1657 -0
  311. package/src/components/datatable/index.ts +19 -0
  312. package/src/components/datatable/types.ts +203 -0
  313. package/src/components/datepicker/calendar.ts +1397 -0
  314. package/src/components/datepicker/config.ts +368 -0
  315. package/src/components/datepicker/datepicker.css +7 -0
  316. package/src/components/datepicker/datepicker.ts +1287 -0
  317. package/src/components/datepicker/dropdown.ts +757 -0
  318. package/src/components/datepicker/events.ts +149 -0
  319. package/src/components/datepicker/index.ts +10 -0
  320. package/src/components/datepicker/keyboard.ts +646 -0
  321. package/src/components/datepicker/locales.ts +80 -0
  322. package/src/components/datepicker/templates.ts +792 -0
  323. package/src/components/datepicker/types.ts +154 -0
  324. package/src/components/datepicker/utils.ts +631 -0
  325. package/src/components/dismiss/dismiss.css +10 -0
  326. package/src/components/dismiss/dismiss.ts +152 -0
  327. package/src/components/dismiss/index.ts +7 -0
  328. package/src/components/dismiss/types.ts +17 -0
  329. package/src/components/drawer/drawer.css +97 -0
  330. package/src/components/drawer/drawer.ts +437 -0
  331. package/src/components/drawer/index.ts +7 -0
  332. package/src/components/drawer/types.ts +25 -0
  333. package/src/components/dropdown/dropdown-menu.css +56 -0
  334. package/src/components/dropdown/dropdown.css +46 -0
  335. package/src/components/dropdown/dropdown.ts +549 -0
  336. package/src/components/dropdown/index.ts +7 -0
  337. package/src/components/dropdown/types.ts +28 -0
  338. package/src/components/form/form.css +54 -0
  339. package/src/components/image-input/image-input.css +56 -0
  340. package/src/components/image-input/image-input.ts +249 -0
  341. package/src/components/image-input/index.ts +10 -0
  342. package/src/components/image-input/types.ts +12 -0
  343. package/src/components/input/input-group.css +42 -0
  344. package/src/components/input/input.css +136 -0
  345. package/src/components/kbd/kbd.css +30 -0
  346. package/src/components/label/label.css +20 -0
  347. package/src/components/link/link.css +81 -0
  348. package/src/components/modal/index.ts +7 -0
  349. package/src/components/modal/modal.css +73 -0
  350. package/src/components/modal/modal.ts +382 -0
  351. package/src/components/modal/types.ts +21 -0
  352. package/src/components/pagination/pagination.css +26 -0
  353. package/src/components/popover/popover.css +22 -0
  354. package/src/components/progress/progress.css +51 -0
  355. package/src/components/radio/radio.css +51 -0
  356. package/src/components/reparent/index.ts +7 -0
  357. package/src/components/reparent/reparent.ts +109 -0
  358. package/src/components/reparent/types.ts +15 -0
  359. package/src/components/scrollable/index.ts +10 -0
  360. package/src/components/scrollable/scrollable.css +29 -0
  361. package/src/components/scrollable/scrollable.ts +297 -0
  362. package/src/components/scrollable/types.ts +16 -0
  363. package/src/components/scrollspy/index.ts +7 -0
  364. package/src/components/scrollspy/scrollspy.css +13 -0
  365. package/src/components/scrollspy/scrollspy.ts +224 -0
  366. package/src/components/scrollspy/types.ts +15 -0
  367. package/src/components/scrollto/index.ts +7 -0
  368. package/src/components/scrollto/scrollto.ts +127 -0
  369. package/src/components/scrollto/types.ts +15 -0
  370. package/src/components/select/combobox.ts +305 -0
  371. package/src/components/select/config.ts +324 -0
  372. package/src/components/select/dropdown.ts +510 -0
  373. package/src/components/select/index.ts +13 -0
  374. package/src/components/select/option.ts +43 -0
  375. package/src/components/select/remote.ts +477 -0
  376. package/src/components/select/search.ts +430 -0
  377. package/src/components/select/select.css +105 -0
  378. package/src/components/select/select.ts +1916 -0
  379. package/src/components/select/tags.ts +123 -0
  380. package/src/components/select/templates.ts +531 -0
  381. package/src/components/select/types.ts +36 -0
  382. package/src/components/select/utils.ts +747 -0
  383. package/src/components/select/variants.css +5 -0
  384. package/src/components/separator/separator.css +14 -0
  385. package/src/components/skeleton/skeleton.css +10 -0
  386. package/src/components/stepper/index.ts +7 -0
  387. package/src/components/stepper/stepper.css +49 -0
  388. package/src/components/stepper/stepper.ts +308 -0
  389. package/src/components/stepper/types.ts +13 -0
  390. package/src/components/sticky/index.ts +7 -0
  391. package/src/components/sticky/sticky.css +22 -0
  392. package/src/components/sticky/sticky.ts +381 -0
  393. package/src/components/sticky/types.ts +23 -0
  394. package/src/components/switch/switch.css +110 -0
  395. package/src/components/table/table.css +168 -0
  396. package/src/components/tabs/index.ts +7 -0
  397. package/src/components/tabs/tabs.css +40 -0
  398. package/src/components/tabs/tabs.ts +190 -0
  399. package/src/components/tabs/types.ts +13 -0
  400. package/src/components/textarea/textarea.css +35 -0
  401. package/src/components/theme-switch/index.ts +10 -0
  402. package/src/components/theme-switch/theme-switch.css +22 -0
  403. package/src/components/theme-switch/theme-switch.ts +176 -0
  404. package/src/components/theme-switch/types.ts +15 -0
  405. package/src/components/toggle/index.ts +7 -0
  406. package/src/components/toggle/toggle.css +13 -0
  407. package/src/components/toggle/toggle.ts +173 -0
  408. package/src/components/toggle/types.ts +18 -0
  409. package/src/components/toggle-group/toggle-group.css +55 -0
  410. package/src/components/toggle-password/index.ts +10 -0
  411. package/src/components/toggle-password/toggle-password.css +13 -0
  412. package/src/components/toggle-password/toggle-password.ts +159 -0
  413. package/src/components/toggle-password/types.ts +13 -0
  414. package/src/components/tooltip/index.ts +7 -0
  415. package/src/components/tooltip/tooltip.css +18 -0
  416. package/src/components/tooltip/tooltip.ts +361 -0
  417. package/src/components/tooltip/types.ts +28 -0
  418. package/src/helpers/data.ts +46 -0
  419. package/src/helpers/dom.ts +405 -0
  420. package/src/helpers/event-handler.ts +61 -0
  421. package/src/helpers/utils.ts +183 -0
  422. package/src/index.ts +113 -0
  423. package/src/types.ts +23 -0
  424. package/styles.css +48 -0
  425. package/tsconfig.json +17 -0
  426. package/webpack.config.js +113 -0
@@ -0,0 +1,109 @@
1
+ /**
2
+ * KTUI - Free & Open-Source Tailwind UI Components by Keenthemes
3
+ * Copyright 2025 by Keenthemes Inc
4
+ * @version: 1.0.0
5
+ */
6
+ import KTData from '../../helpers/data';
7
+ import KTDom from '../../helpers/dom';
8
+ import KTUtils from '../../helpers/utils';
9
+ import KTComponent from '../component';
10
+ import { KTReparentInterface, KTReparentConfigInterface } from './types';
11
+
12
+ declare global {
13
+ interface Window {
14
+ KT_REPARENT_INITIALIZED: boolean;
15
+ KTReparent: typeof KTReparent;
16
+ }
17
+ }
18
+
19
+ export class KTReparent extends KTComponent implements KTReparentInterface {
20
+ protected override _name: string = 'reparent';
21
+ protected override _defaultConfig: KTReparentConfigInterface = {
22
+ mode: '',
23
+ target: '',
24
+ };
25
+
26
+ constructor(
27
+ element: HTMLElement,
28
+ config: KTReparentConfigInterface | null = null,
29
+ ) {
30
+ super();
31
+
32
+ if (KTData.has(element as HTMLElement, this._name)) return;
33
+
34
+ this._init(element);
35
+ this._buildConfig(config);
36
+ this._update();
37
+ }
38
+
39
+ protected _update(): void {
40
+ if (!this._element) return;
41
+ const target = this._getOption('target') as string;
42
+ const targetEl = KTDom.getElement(target);
43
+ const mode = this._getOption('mode');
44
+
45
+ if (targetEl && this._element.parentNode !== targetEl) {
46
+ if (mode === 'prepend') {
47
+ targetEl.prepend(this._element);
48
+ } else if (mode === 'append') {
49
+ targetEl.append(this._element);
50
+ }
51
+ }
52
+ }
53
+
54
+ public update(): void {
55
+ this._update();
56
+ }
57
+
58
+ public static handleResize(): void {
59
+ window.addEventListener('resize', () => {
60
+ let timer;
61
+
62
+ KTUtils.throttle(
63
+ timer,
64
+ () => {
65
+ document
66
+ .querySelectorAll('[data-kt-reparent-initialized]')
67
+ .forEach((element) => {
68
+ const reparent = KTReparent.getInstance(element as HTMLElement);
69
+ console.log('reparent update');
70
+ reparent?.update();
71
+ });
72
+ },
73
+ 200,
74
+ );
75
+ });
76
+ }
77
+
78
+ public static getInstance(element: HTMLElement): KTReparent {
79
+ return KTData.get(element, 'reparent') as KTReparent;
80
+ }
81
+
82
+ public static getOrCreateInstance(
83
+ element: HTMLElement,
84
+ config?: KTReparentConfigInterface,
85
+ ): KTReparent {
86
+ return this.getInstance(element) || new KTReparent(element, config);
87
+ }
88
+
89
+ public static createInstances(): void {
90
+ const elements = document.querySelectorAll('[data-kt-reparent]');
91
+
92
+ elements.forEach((element) => {
93
+ new KTReparent(element as HTMLElement);
94
+ });
95
+ }
96
+
97
+ public static init(): void {
98
+ KTReparent.createInstances();
99
+
100
+ if (window.KT_REPARENT_INITIALIZED !== true) {
101
+ KTReparent.handleResize();
102
+ window.KT_REPARENT_INITIALIZED = true;
103
+ }
104
+ }
105
+ }
106
+
107
+ if (typeof window !== 'undefined') {
108
+ window.KTReparent = KTReparent;
109
+ }
@@ -0,0 +1,15 @@
1
+ /**
2
+ * KTUI - Free & Open-Source Tailwind UI Components by Keenthemes
3
+ * Copyright 2025 by Keenthemes Inc
4
+ * @version: 1.0.0
5
+ */
6
+ export declare type KTOverlayModeType = 'drawer' | 'modal' | 'popover';
7
+
8
+ export interface KTReparentConfigInterface {
9
+ mode: string;
10
+ target: string;
11
+ }
12
+
13
+ export interface KTReparentInterface {
14
+ update(): void;
15
+ }
@@ -0,0 +1,10 @@
1
+ /**
2
+ * KTUI - Free & Open-Source Tailwind UI Components by Keenthemes
3
+ * Copyright 2025 by Keenthemes Inc
4
+ * @version: 1.0.0
5
+ */
6
+ export { KTScrollable } from './scrollable';
7
+ export type {
8
+ KTScrollableConfigInterface,
9
+ KTScrollableInterface,
10
+ } from './types';
@@ -0,0 +1,29 @@
1
+ /**
2
+ * KTUI - Free & Open-Source Tailwind UI Components by Keenthemes
3
+ * Copyright 2025 by Keenthemes Inc
4
+ * @version: 1.0.0
5
+ */
6
+ @layer components {
7
+ :root {
8
+ --kt-scrollable-scrollbar-size: 5px;
9
+ --kt-scrollable-thumb-color: var(--color-accent);
10
+ }
11
+
12
+ .kt-scrollable::-webkit-scrollbar {
13
+ width: var(--kt-scrollable-scrollbar-size);
14
+ }
15
+
16
+ .kt-scrollable::-webkit-scrollbar-track {
17
+ background: transparent;
18
+ }
19
+
20
+ .kt-scrollable::-webkit-scrollbar-thumb {
21
+ background: var(--kt-scrollable-thumb-color);
22
+ border-radius: var(--kt-scrollable-scrollbar-size);
23
+ }
24
+
25
+ .kt-scrollable {
26
+ scrollbar-width: thin;
27
+ scrollbar-color: var(--kt-scrollable-thumb-color) transparent;
28
+ }
29
+ }
@@ -0,0 +1,297 @@
1
+ /**
2
+ * KTUI - Free & Open-Source Tailwind UI Components by Keenthemes
3
+ * Copyright 2025 by Keenthemes Inc
4
+ * @version: 1.0.0
5
+ */
6
+ import KTData from '../../helpers/data';
7
+ import KTDom from '../../helpers/dom';
8
+ import KTUtils from '../../helpers/utils';
9
+ import KTComponent from '../component';
10
+ import { KTScrollableInterface, KTScrollableConfigInterface } from './types';
11
+
12
+ declare global {
13
+ interface Window {
14
+ KT_SCROLLABLE_INITIALIZED: boolean;
15
+ KTScrollable: typeof KTScrollable;
16
+ }
17
+ }
18
+
19
+ export class KTScrollable extends KTComponent implements KTScrollableInterface {
20
+ protected override _name: string = 'scrollable';
21
+ protected override _defaultConfig: KTScrollableConfigInterface = {
22
+ save: true,
23
+ dependencies: '',
24
+ wrappers: '',
25
+ offset: '',
26
+ };
27
+ protected override _config: KTScrollableConfigInterface = this._defaultConfig;
28
+ protected _elementId: string | null = null;
29
+
30
+ constructor(element: HTMLElement, config?: KTScrollableConfigInterface) {
31
+ super();
32
+
33
+ if (KTData.has(element as HTMLElement, this._name)) return;
34
+
35
+ this._init(element);
36
+ this._buildConfig(config);
37
+
38
+ if (!this._element) return;
39
+ this._elementId = this._element.getAttribute('id');
40
+ this._handlers();
41
+ this._update();
42
+ }
43
+
44
+ protected _handlers(): void {
45
+ if (!this._element) return;
46
+ this._element.addEventListener('scroll', () => {
47
+ if (!this._element) return;
48
+ localStorage.setItem(
49
+ `${this._elementId}st`,
50
+ this._element.scrollTop.toString(),
51
+ );
52
+ });
53
+ }
54
+
55
+ protected _update(): void {
56
+ this._setupHeight();
57
+ this._setupState();
58
+ }
59
+
60
+ protected _setupHeight(): void {
61
+ if (!this._element) return;
62
+
63
+ const heightType = this._getHeightType();
64
+ const height = this._getHeight();
65
+
66
+ // Set height
67
+ if (height && height != '0' && height.length > 0) {
68
+ this._element.style.setProperty(heightType, height);
69
+ } else {
70
+ this._element.style.setProperty(heightType, '');
71
+ }
72
+ }
73
+
74
+ protected _setupState(): void {
75
+ if (!this._element) return;
76
+ const stateEnabled = this._getOption('state') === true;
77
+ const elementIdExists = Boolean(this._elementId);
78
+
79
+ if (stateEnabled && elementIdExists) {
80
+ const storedPosition = localStorage.getItem(this._elementId + 'st');
81
+
82
+ if (storedPosition) {
83
+ const pos = parseInt(storedPosition);
84
+
85
+ if (pos > 0) {
86
+ this._element.scroll({
87
+ top: pos,
88
+ behavior: 'instant',
89
+ });
90
+ }
91
+ }
92
+ }
93
+ }
94
+
95
+ protected _getHeight(): string {
96
+ const height = this._getHeightOption();
97
+
98
+ if (
99
+ height !== null &&
100
+ typeof height === 'string' &&
101
+ height.toLowerCase() === 'auto'
102
+ ) {
103
+ return this._getAutoHeight();
104
+ } else if (height) {
105
+ return parseInt(height).toString() + 'px';
106
+ } else {
107
+ return '0';
108
+ }
109
+ }
110
+
111
+ protected _getAutoHeight(): string {
112
+ if (!this._element) return '';
113
+ let height = KTDom.getViewPort().height;
114
+ const dependencies = this._getOption('dependencies') as string;
115
+ const wrappers = this._getOption('wrappers') as string;
116
+ const offset = this._getOption('offset') as string;
117
+ height -= this._getElementSpacing(this._element);
118
+
119
+ if (dependencies && dependencies.length > 0) {
120
+ const elements = document.querySelectorAll(dependencies);
121
+ elements.forEach((element) => {
122
+ if (KTDom.getCssProp(element as HTMLElement, 'display') === 'none') {
123
+ return;
124
+ }
125
+ height -= this._getElementHeight(element as HTMLElement);
126
+ });
127
+ }
128
+
129
+ if (wrappers && wrappers.length > 0) {
130
+ const elements = document.querySelectorAll(wrappers);
131
+ elements.forEach((element) => {
132
+ if (KTDom.getCssProp(element as HTMLElement, 'display') === 'none') {
133
+ return;
134
+ }
135
+ height -= this._getElementSpacing(element as HTMLElement);
136
+ });
137
+ }
138
+
139
+ if (offset && offset.length > 0) {
140
+ height -= parseInt(offset);
141
+ }
142
+
143
+ return height.toString() + 'px';
144
+ }
145
+
146
+ protected _getElementHeight(element: HTMLElement): number {
147
+ let height = 0;
148
+
149
+ if (!element) {
150
+ return height;
151
+ }
152
+
153
+ const computedStyle = window.getComputedStyle(element);
154
+ if (computedStyle.height) {
155
+ height += parseInt(computedStyle.height);
156
+ }
157
+ if (computedStyle.marginTop) {
158
+ height += parseInt(computedStyle.marginTop);
159
+ }
160
+ if (computedStyle.marginBottom) {
161
+ height += parseInt(computedStyle.marginBottom);
162
+ }
163
+ if (computedStyle.borderTopWidth) {
164
+ height += parseInt(computedStyle.borderTopWidth);
165
+ }
166
+ if (computedStyle.borderBottomWidth) {
167
+ height += parseInt(computedStyle.borderBottomWidth);
168
+ }
169
+
170
+ return height;
171
+ }
172
+
173
+ protected _getElementSpacing(element: HTMLElement): number {
174
+ let spacing: number = 0;
175
+
176
+ if (!element) {
177
+ return spacing;
178
+ }
179
+
180
+ const computedStyle = window.getComputedStyle(element);
181
+ if (computedStyle.marginTop) {
182
+ spacing += parseInt(computedStyle.marginTop);
183
+ }
184
+ if (computedStyle.marginBottom) {
185
+ spacing += parseInt(computedStyle.marginBottom);
186
+ }
187
+ if (computedStyle.paddingTop) {
188
+ spacing += parseInt(computedStyle.paddingTop);
189
+ }
190
+ if (computedStyle.paddingBottom) {
191
+ spacing += parseInt(computedStyle.paddingBottom);
192
+ }
193
+ if (computedStyle.borderTopWidth) {
194
+ spacing += parseInt(computedStyle.borderTopWidth);
195
+ }
196
+ if (computedStyle.borderBottomWidth) {
197
+ spacing += parseInt(computedStyle.borderBottomWidth);
198
+ }
199
+
200
+ return spacing;
201
+ }
202
+
203
+ protected _getHeightType(): string {
204
+ if (this._getOption('minHeight')) {
205
+ return 'min-height';
206
+ }
207
+ if (this._getOption('maxHeight')) {
208
+ return 'max-height';
209
+ } else {
210
+ return 'height';
211
+ }
212
+ }
213
+
214
+ protected _getHeightOption(): string {
215
+ const heightType = this._getHeightType();
216
+
217
+ if (heightType == 'min-height') {
218
+ return this._getOption('minHeight') as string;
219
+ }
220
+ if (heightType == 'max-height') {
221
+ return this._getOption('maxHeight') as string;
222
+ } else {
223
+ return this._getOption('height') as string;
224
+ }
225
+ }
226
+
227
+ public update(): void {
228
+ return this._update();
229
+ }
230
+
231
+ public getHeight(): string {
232
+ return this._getHeight();
233
+ }
234
+
235
+ public static getInstance(element: HTMLElement): KTScrollable {
236
+ if (!element) return null;
237
+
238
+ if (KTData.has(element, 'scrollable')) {
239
+ return KTData.get(element, 'scrollable') as KTScrollable;
240
+ }
241
+
242
+ if (element.getAttribute('data-kt-scrollable')) {
243
+ return new KTScrollable(element);
244
+ }
245
+
246
+ return null;
247
+ }
248
+
249
+ public static getOrCreateInstance(
250
+ element: HTMLElement,
251
+ config?: KTScrollableConfigInterface,
252
+ ): KTScrollable {
253
+ return this.getInstance(element) || new KTScrollable(element, config);
254
+ }
255
+
256
+ public static createInstances(): void {
257
+ const elements = document.querySelectorAll('[data-kt-scrollable]');
258
+
259
+ elements.forEach((element) => {
260
+ new KTScrollable(element as HTMLElement);
261
+ });
262
+ }
263
+
264
+ public static handleResize(): void {
265
+ window.addEventListener('resize', () => {
266
+ let timer;
267
+
268
+ KTUtils.throttle(
269
+ timer,
270
+ function () {
271
+ // Locate and update scrollable instances on window resize
272
+ const elements = document.querySelectorAll(
273
+ '[data-kt-scrollable-initialized]',
274
+ );
275
+ elements.forEach((element) => {
276
+ KTScrollable.getInstance(element as HTMLElement)?.update();
277
+ });
278
+ },
279
+ 200,
280
+ );
281
+ });
282
+ }
283
+
284
+ public static init(): void {
285
+ KTScrollable.createInstances();
286
+
287
+ if (window.KT_SCROLLABLE_INITIALIZED !== true) {
288
+ KTScrollable.handleResize();
289
+
290
+ window.KT_SCROLLABLE_INITIALIZED = true;
291
+ }
292
+ }
293
+ }
294
+
295
+ if (typeof window !== 'undefined') {
296
+ window.KTScrollable = KTScrollable;
297
+ }
@@ -0,0 +1,16 @@
1
+ /**
2
+ * KTUI - Free & Open-Source Tailwind UI Components by Keenthemes
3
+ * Copyright 2025 by Keenthemes Inc
4
+ * @version: 1.0.0
5
+ */
6
+ export interface KTScrollableConfigInterface {
7
+ save: boolean;
8
+ dependencies: string;
9
+ wrappers: string;
10
+ offset: string;
11
+ }
12
+
13
+ export interface KTScrollableInterface {
14
+ update(): void;
15
+ getHeight(): string;
16
+ }
@@ -0,0 +1,7 @@
1
+ /**
2
+ * KTUI - Free & Open-Source Tailwind UI Components by Keenthemes
3
+ * Copyright 2025 by Keenthemes Inc
4
+ * @version: 1.0.0
5
+ */
6
+ export { KTScrollspy } from './scrollspy';
7
+ export type { KTScrollspyConfigInterface, KTScrollspyInterface } from './types';
@@ -0,0 +1,13 @@
1
+ /**
2
+ * KTUI - Free & Open-Source Tailwind UI Components by Keenthemes
3
+ * Copyright 2025 by Keenthemes Inc
4
+ * @version: 1.0.0
5
+ */
6
+ @custom-variant kt-scrollspy-active {
7
+ &[data-kt-scrollspy-anchor].active {
8
+ @slot;
9
+ }
10
+ [data-kt-scrollspy-anchor].active & {
11
+ @slot;
12
+ }
13
+ }