@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,73 @@
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
+ .kt-modal {
8
+ @apply fixed inset-0 overflow-auto p-4;
9
+
10
+ &:not(.open) {
11
+ @apply hidden;
12
+ }
13
+ }
14
+
15
+ .kt-modal-backdrop {
16
+ @apply transition-all duration-300 fixed inset-0 bg-black/30 [backdrop-filter:blur(4px)];
17
+ }
18
+
19
+ /* Alert Close */
20
+ .kt-modal-close {
21
+ @apply shrink-0 size-6 cursor-pointer -me-2.5;
22
+
23
+ > svg {
24
+ @apply size-3.5 opacity-70;
25
+ }
26
+
27
+ &:focus,
28
+ &:hover {
29
+ > svg {
30
+ @apply opacity-100;
31
+ }
32
+ }
33
+ }
34
+
35
+ .kt-modal-dialog {
36
+ @apply hidden fixed overflow-auto top-1/2 start-1/2 -translate-x-1/2 -translate-y-1/2 p-4;
37
+ }
38
+
39
+ .kt-modal-content {
40
+ @apply relative flex flex-col mx-auto rounded-lg shadow-md bg-popover text-popover-foreground;
41
+ }
42
+
43
+ .kt-modal-header {
44
+ @apply flex items-center justify-between gap-2 px-5 py-4 border-b border-border;
45
+ }
46
+
47
+ .kt-modal-title {
48
+ @apply text-base font-semibold text-mono;
49
+ }
50
+
51
+ .kt-modal-body {
52
+ @apply overflow-y-auto px-5 py-4;
53
+ }
54
+
55
+ .kt-modal-footer {
56
+ @apply flex items-center justify-between gap-2 px-5 py-4 border-t border-border;
57
+ }
58
+
59
+ .kt-modal-center {
60
+ .kt-modal-content {
61
+ @apply top-1/2 -translate-y-1/2;
62
+ }
63
+ }
64
+ }
65
+
66
+ @custom-variant kt-modal-open {
67
+ &[data-kt-modal-initialized].open {
68
+ @slot;
69
+ }
70
+ [data-kt-modal-initialized].open & {
71
+ @slot;
72
+ }
73
+ }
@@ -0,0 +1,382 @@
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 KTEventHandler from '../../helpers/event-handler';
9
+ import KTUtils from '../../helpers/utils';
10
+ import KTComponent from '../component';
11
+ import { KTModalInterface, KTModalConfigInterface } from './types';
12
+
13
+ declare global {
14
+ interface Window {
15
+ KT_MODAL_INITIALIZED: boolean;
16
+ KTModal: typeof KTModal;
17
+ }
18
+ }
19
+
20
+ export class KTModal extends KTComponent implements KTModalInterface {
21
+ protected override _name: string = 'modal';
22
+ protected override _defaultConfig: KTModalConfigInterface = {
23
+ zindex: '90',
24
+ backdrop: true,
25
+ backdropClass: 'kt-modal-backdrop',
26
+ backdropStatic: false,
27
+ keyboard: true,
28
+ disableScroll: true,
29
+ persistent: false,
30
+ focus: true,
31
+ hiddenClass: 'hidden',
32
+ };
33
+ protected override _config: KTModalConfigInterface = this._defaultConfig;
34
+ protected _isOpen: boolean = false;
35
+ protected _isTransitioning: boolean = false;
36
+ protected _backdropElement: HTMLElement | null = null;
37
+ protected _targetElement: HTMLElement | null = null;
38
+
39
+ constructor(element: HTMLElement, config?: KTModalConfigInterface) {
40
+ super();
41
+
42
+ if (KTData.has(element as HTMLElement, this._name)) return;
43
+
44
+ this._init(element);
45
+ this._buildConfig(config);
46
+ this._handlers();
47
+ }
48
+
49
+ protected _handlers() {
50
+ this._element.addEventListener('click', (event: Event) => {
51
+ if (this._element !== event.target) return;
52
+
53
+ if (this._getOption('backdropStatic') === false) {
54
+ this._hide();
55
+ }
56
+ });
57
+ }
58
+
59
+ protected _toggle(targetElement?: HTMLElement): void {
60
+ const payload = { cancel: false };
61
+ this._fireEvent('toggle', payload);
62
+ this._dispatchEvent('toggle', payload);
63
+ if (payload.cancel === true) {
64
+ return;
65
+ }
66
+
67
+ if (this._isOpen === true) {
68
+ this._hide();
69
+ } else {
70
+ this._show(targetElement);
71
+ }
72
+ }
73
+
74
+ protected _show(targetElement?: HTMLElement): void {
75
+ if (this._isOpen || this._isTransitioning) {
76
+ return;
77
+ }
78
+
79
+ //const beforeScroll = this.fireEvent('beforeScroll', this.el);
80
+ //this.dispatch('beforeScroll.hs.scrollspy', this.el, this.el);
81
+ //if (beforeScroll instanceof Promise) beforeScroll.then(() => scrollFn());
82
+ //else scrollFn();
83
+
84
+ if (targetElement) this._targetElement = targetElement;
85
+
86
+ const payload = { cancel: false };
87
+ this._fireEvent('show', payload);
88
+ this._dispatchEvent('show', payload);
89
+ if (payload.cancel === true) {
90
+ return;
91
+ }
92
+
93
+ KTModal.hide();
94
+
95
+ if (!this._element) return;
96
+ this._isTransitioning = true;
97
+ this._element.setAttribute('role', 'dialog');
98
+ this._element.setAttribute('aria-modal', 'true');
99
+ this._element.setAttribute('tabindex', '-1');
100
+
101
+ this._setZindex();
102
+ if (this._getOption('backdrop') === true) this._createBackdrop();
103
+
104
+ if (this._getOption('disableScroll')) {
105
+ document.body.style.overflow = 'hidden';
106
+ }
107
+
108
+ this._element.style.display = 'block';
109
+ KTDom.reflow(this._element);
110
+ this._element.classList.add('open');
111
+ this._element.classList.remove(this._getOption('hiddenClass') as string);
112
+
113
+ KTDom.transitionEnd(this._element, () => {
114
+ this._isTransitioning = false;
115
+ this._isOpen = true;
116
+
117
+ if (this._getOption('focus') === true) {
118
+ this._autoFocus();
119
+ }
120
+
121
+ this._fireEvent('shown');
122
+ this._dispatchEvent('shown');
123
+ });
124
+ }
125
+
126
+ protected _hide(): void {
127
+ if (!this._element) return;
128
+ if (this._isOpen === false || this._isTransitioning) {
129
+ return;
130
+ }
131
+
132
+ const payload = { cancel: false };
133
+ this._fireEvent('hide', payload);
134
+ this._dispatchEvent('hide', payload);
135
+ if (payload.cancel === true) {
136
+ return;
137
+ }
138
+
139
+ this._isTransitioning = true;
140
+ this._element.removeAttribute('role');
141
+ this._element.removeAttribute('aria-modal');
142
+ this._element.removeAttribute('tabindex');
143
+ if (this._getOption('disableScroll')) {
144
+ document.body.style.overflow = '';
145
+ }
146
+
147
+ KTDom.reflow(this._element);
148
+ this._element.classList.remove('open');
149
+
150
+ if (this._getOption('backdrop') === true) {
151
+ this._deleteBackdrop();
152
+ }
153
+
154
+ KTDom.transitionEnd(this._element, () => {
155
+ if (!this._element) return;
156
+
157
+ this._isTransitioning = false;
158
+ this._isOpen = false;
159
+ this._element.style.display = '';
160
+ this._element.classList.add(this._getOption('hiddenClass') as string);
161
+
162
+ this._fireEvent('hidden');
163
+ this._dispatchEvent('hidden');
164
+ });
165
+ }
166
+
167
+ protected _setZindex(): void {
168
+ let zindex: number = parseInt(this._getOption('zindex') as string);
169
+
170
+ if (parseInt(KTDom.getCssProp(this._element, 'z-index')) > zindex) {
171
+ zindex = parseInt(KTDom.getCssProp(this._element, 'z-index'));
172
+ }
173
+
174
+ if (KTDom.getHighestZindex(this._element) > zindex) {
175
+ zindex = KTDom.getHighestZindex(this._element) + 1;
176
+ }
177
+
178
+ this._element.style.zIndex = String(zindex);
179
+ }
180
+
181
+ protected _autoFocus(): void {
182
+ if (!this._element) return;
183
+ const input: HTMLInputElement | null = this._element.querySelector(
184
+ '[data-kt-modal-input-focus]',
185
+ );
186
+ if (!input) return;
187
+ else input.focus();
188
+ }
189
+
190
+ protected _createBackdrop(): void {
191
+ if (!this._element) return;
192
+ const zindex: number = parseInt(KTDom.getCssProp(this._element, 'z-index'));
193
+ this._backdropElement = document.createElement('DIV');
194
+ this._backdropElement.setAttribute('data-kt-modal-backdrop', 'true');
195
+ this._backdropElement.style.zIndex = (zindex - 1).toString();
196
+ document.body.append(this._backdropElement);
197
+ KTDom.reflow(this._backdropElement);
198
+ KTDom.addClass(
199
+ this._backdropElement,
200
+ this._getOption('backdropClass') as string,
201
+ );
202
+ }
203
+
204
+ protected _deleteBackdrop(): void {
205
+ if (!this._backdropElement) return;
206
+
207
+ KTDom.reflow(this._backdropElement);
208
+ this._backdropElement.style.opacity = '0';
209
+
210
+ KTDom.transitionEnd(this._backdropElement, () => {
211
+ if (!this._backdropElement) return;
212
+ KTDom.remove(this._backdropElement);
213
+ });
214
+ }
215
+
216
+ public toggle(targetElement?: HTMLElement): void {
217
+ return this._toggle(targetElement);
218
+ }
219
+
220
+ public show(targetElement?: HTMLElement): void {
221
+ return this._show(targetElement);
222
+ }
223
+
224
+ public hide(): void {
225
+ return this._hide();
226
+ }
227
+
228
+ public getTargetElement(): HTMLElement | null {
229
+ return this._targetElement;
230
+ }
231
+
232
+ public isOpen(): boolean {
233
+ return this._isOpen;
234
+ }
235
+
236
+ public static getInstance(element: HTMLElement): KTModal {
237
+ if (!element) return null;
238
+
239
+ if (KTData.has(element, 'modal')) {
240
+ return KTData.get(element, 'modal') as KTModal;
241
+ }
242
+
243
+ if (element.getAttribute('data-kt-modal')) {
244
+ return new KTModal(element);
245
+ }
246
+
247
+ return null;
248
+ }
249
+
250
+ public static getOrCreateInstance(
251
+ element: HTMLElement,
252
+ config?: KTModalConfigInterface,
253
+ ): KTModal {
254
+ return this.getInstance(element) || new KTModal(element, config);
255
+ }
256
+
257
+ public static hide(): void {
258
+ const elements = document.querySelectorAll('[data-kt-modal-initialized]');
259
+
260
+ elements.forEach((element) => {
261
+ const modal = KTModal.getInstance(element as HTMLElement);
262
+
263
+ if (modal && modal.isOpen()) {
264
+ modal.hide();
265
+ }
266
+ });
267
+ }
268
+
269
+ public static handleToggle(): void {
270
+ KTEventHandler.on(
271
+ document.body,
272
+ '[data-kt-modal-toggle]',
273
+ 'click',
274
+ (event: Event, target: HTMLElement) => {
275
+ event.stopPropagation();
276
+
277
+ const selector = target.getAttribute('data-kt-modal-toggle');
278
+ if (!selector) return;
279
+
280
+ const modalElement = document.querySelector(selector);
281
+ const modal = KTModal.getInstance(modalElement as HTMLElement);
282
+ if (modal) {
283
+ modal.toggle(target);
284
+ }
285
+ },
286
+ );
287
+ }
288
+
289
+ public static handleDismiss(): void {
290
+ KTEventHandler.on(
291
+ document.body,
292
+ '[data-kt-modal-dismiss]',
293
+ 'click',
294
+ (event: Event, target: HTMLElement) => {
295
+ event.stopPropagation();
296
+
297
+ const modalElement = target.closest(
298
+ '[data-kt-modal-initialized]',
299
+ ) as HTMLElement;
300
+ if (modalElement) {
301
+ const modal = KTModal.getInstance(modalElement);
302
+ if (modal) {
303
+ modal.hide();
304
+ }
305
+ }
306
+ },
307
+ );
308
+ }
309
+
310
+ public static handleClickAway() {
311
+ document.addEventListener('click', (event: Event) => {
312
+ const modalElement = document.querySelector(
313
+ '.open[data-kt-modal-initialized]',
314
+ );
315
+ if (!modalElement) return;
316
+
317
+ const modal = KTModal.getInstance(modalElement as HTMLElement);
318
+ if (!modal) return;
319
+
320
+ if (KTUtils.stringToBoolean(modal.getOption('persistent')) === true)
321
+ return;
322
+
323
+ if (KTUtils.stringToBoolean(modal.getOption('backdrop')) === true) return;
324
+
325
+ if (
326
+ modalElement !== event.target &&
327
+ modal.getTargetElement() !== event.target &&
328
+ modalElement.contains(event.target as HTMLElement) === false
329
+ ) {
330
+ modal.hide();
331
+ }
332
+ });
333
+ }
334
+
335
+ public static handleKeyword() {
336
+ document.addEventListener('keydown', (event: KeyboardEvent) => {
337
+ const modalElement = document.querySelector(
338
+ '.open[data-kt-modal-initialized]',
339
+ );
340
+ const modal = KTModal.getInstance(modalElement as HTMLElement);
341
+ if (!modal) {
342
+ return;
343
+ }
344
+
345
+ // if esc key was not pressed in combination with ctrl or alt or shift
346
+ if (
347
+ event.key === 'Escape' &&
348
+ !(event.ctrlKey || event.altKey || event.shiftKey)
349
+ ) {
350
+ modal.hide();
351
+ }
352
+
353
+ if (event.code === 'Tab' && !event.metaKey) {
354
+ return;
355
+ }
356
+ });
357
+ }
358
+
359
+ public static createInstances(): void {
360
+ const elements = document.querySelectorAll('[data-kt-modal]');
361
+
362
+ elements.forEach((element) => {
363
+ new KTModal(element as HTMLElement);
364
+ });
365
+ }
366
+
367
+ public static init(): void {
368
+ KTModal.createInstances();
369
+
370
+ if (window.KT_MODAL_INITIALIZED !== true) {
371
+ KTModal.handleToggle();
372
+ KTModal.handleDismiss();
373
+ KTModal.handleClickAway();
374
+ KTModal.handleKeyword();
375
+ window.KT_MODAL_INITIALIZED = true;
376
+ }
377
+ }
378
+ }
379
+
380
+ if (typeof window !== 'undefined') {
381
+ window.KTModal = KTModal;
382
+ }
@@ -0,0 +1,21 @@
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 KTModalConfigInterface {
7
+ zindex?: string;
8
+ backdrop: boolean;
9
+ backdropClass: string;
10
+ backdropStatic: boolean;
11
+ keyboard: boolean;
12
+ disableScroll: boolean;
13
+ persistent: boolean;
14
+ focus: boolean;
15
+ hiddenClass: string;
16
+ }
17
+ export interface KTModalInterface {
18
+ show(): void;
19
+ hide(): void;
20
+ toggle(): void;
21
+ }
@@ -0,0 +1,26 @@
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
+ .kt-pagination {
8
+ @apply flex items-center gap-1;
9
+ }
10
+
11
+ .kt-pagination-item {
12
+ @apply flex flex-row items-center gap-1 shrink-0;
13
+
14
+ svg {
15
+ @apply text-muted-foreground size-4;
16
+ }
17
+ }
18
+
19
+ .kt-pagination-ellipsis {
20
+ @apply flex h-9 w-9 items-center justify-center;
21
+
22
+ svg {
23
+ @apply text-muted-foreground size-4;
24
+ }
25
+ }
26
+ }
@@ -0,0 +1,22 @@
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
+ .kt-popover {
8
+ @apply rounded-md shadow-md shadow-[rgba(0,0,0,0.05)] bg-popover text-popover-foreground border border-border text-sm;
9
+
10
+ &:not(.show) {
11
+ @apply hidden;
12
+ }
13
+ }
14
+
15
+ .kt-popover-header {
16
+ @apply text-mono font-semibold px-2.5 py-2 border-b border-border;
17
+ }
18
+
19
+ .kt-popover-content {
20
+ @apply px-2.5 py-2;
21
+ }
22
+ }
@@ -0,0 +1,51 @@
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
+ .kt-progress {
8
+ @apply relative h-1 w-full overflow-hidden rounded-full bg-secondary;
9
+ }
10
+
11
+ .kt-progress-indicator {
12
+ @apply h-full w-full flex-1 bg-primary rounded-full transition-all transform-[translateX:(calc(100-var(--progress-value)))];
13
+ }
14
+
15
+ /* Variants */
16
+ .kt-progress-primary {
17
+ .kt-progress-indicator {
18
+ @apply bg-primary;
19
+ }
20
+ }
21
+
22
+ .kt-progress-success {
23
+ .kt-progress-indicator {
24
+ @apply bg-green-500;
25
+ }
26
+ }
27
+
28
+ .kt-progress-warning {
29
+ .kt-progress-indicator {
30
+ @apply bg-yellow-500;
31
+ }
32
+ }
33
+
34
+ .kt-progress-info {
35
+ .kt-progress-indicator {
36
+ @apply bg-violet-500;
37
+ }
38
+ }
39
+
40
+ .kt-progress-destructive {
41
+ .kt-progress-indicator {
42
+ @apply bg-destructive;
43
+ }
44
+ }
45
+
46
+ .kt-progress-mono {
47
+ .kt-progress-indicator {
48
+ @apply bg-mono;
49
+ }
50
+ }
51
+ }
@@ -0,0 +1,51 @@
1
+ /**
2
+ * KTUI - Free & Open-Source Tailwind UI Components by Keenthemes
3
+ * Copyright 2025 by Keenthemes Inc
4
+ * @version: 1.0.0
5
+ */
6
+ /* Base Styles */
7
+ @layer components {
8
+ /* Base */
9
+ .kt-radio {
10
+ @apply cursor-pointer appearance-none bg-no-repeat bg-center;
11
+ @apply rounded-full bg-background shrink-0 border border-input ring-offset-background focus-visible:outline-none;
12
+ @apply focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50;
13
+ @apply aria-invalid:border-destructive/60 aria-invalid:ring-destructive/10 dark:aria-invalid:border-destructive dark:aria-invalid:ring-destructive/20;
14
+ }
15
+
16
+ .kt-radio {
17
+ @apply [&:checked]:bg-primary [&:checked]:border-primary [&:checked]:text-primary-foreground [&:indeterminate]:bg-primary [&:indeterminate]:border-primary [&:indeterminate]:text-primary-foreground;
18
+ }
19
+
20
+ .kt-radio {
21
+ &:checked,
22
+ &[aria-checked='true'] {
23
+ background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 22 22' fill='none'%3E%3Ccircle cx='10.9995' cy='11' r='5.86667' fill='white'/%3E%3C/svg%3E");
24
+ }
25
+ }
26
+
27
+ /* Size */
28
+ .kt-radio {
29
+ @apply size-5;
30
+ }
31
+
32
+ .kt-radio-sm {
33
+ @apply size-4.5;
34
+ }
35
+
36
+ .kt-radio-lg {
37
+ @apply size-5.5;
38
+ }
39
+
40
+ /* Mono */
41
+ .kt-radio-mono {
42
+ @apply [&:checked]:bg-mono [&:checked]:border-mono [&:checked]:text-mono-foreground [&:indeterminate]:bg-mono [&:indeterminate]:border-mono [&:indeterminate]:text-mono-foreground;
43
+ }
44
+ }
45
+
46
+ /* Dark Mode Styles */
47
+ @layer components {
48
+ .dark .kt-radio {
49
+ @apply aria-invalid:border-destructive aria-invalid:ring-destructive/20;
50
+ }
51
+ }
@@ -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 { KTReparent } from './reparent';
7
+ export type { KTReparentConfigInterface, KTReparentInterface } from './types';