@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,34 @@
1
+ import KTUtils from './utils';
2
+ var KTDelegatedEventHandlers = {};
3
+ var KTEventHandler = {
4
+ on: function (element, selector, eventName, handler) {
5
+ var _this = this;
6
+ if (element === null) {
7
+ return null;
8
+ }
9
+ var eventId = KTUtils.geUID('event');
10
+ KTDelegatedEventHandlers[eventId] = function (event) {
11
+ var targets = element.querySelectorAll(selector);
12
+ var target = event.target;
13
+ while (target && target !== element) {
14
+ for (var i = 0, j = targets.length; i < j; i++) {
15
+ if (target === targets[i]) {
16
+ handler.call(_this, event, target);
17
+ }
18
+ }
19
+ target = target.parentNode;
20
+ }
21
+ };
22
+ element.addEventListener(eventName, KTDelegatedEventHandlers[eventId]);
23
+ return eventId;
24
+ },
25
+ off: function (element, eventName, eventId) {
26
+ if (!element || KTDelegatedEventHandlers[eventId] === null) {
27
+ return;
28
+ }
29
+ element.removeEventListener(eventName, KTDelegatedEventHandlers[eventId]);
30
+ delete KTDelegatedEventHandlers[eventId];
31
+ }
32
+ };
33
+ export default KTEventHandler;
34
+ //# sourceMappingURL=event-handler.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"event-handler.js","sourceRoot":"","sources":["../../../src/helpers/event-handler.ts"],"names":[],"mappings":"AACA,OAAO,OAAO,MAAM,SAAS,CAAC;AAM9B,IAAM,wBAAwB,GAAsC,EAAE,CAAC;AAEvE,IAAM,cAAc,GAAG;IACrB,EAAE,EAAE,UAAS,OAAoB,EAAE,QAAgB,EAAE,SAAiB,EAAE,OAAuB;QAA3F,iBAyBH;QAxBC,IAAK,OAAO,KAAK,IAAI,EAAG,CAAC;YACvB,OAAO,IAAI,CAAC;QACd,CAAC;QAED,IAAM,OAAO,GAAG,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QAEvC,wBAAwB,CAAC,OAAO,CAAC,GAAG,UAAC,KAAoC;YACvE,IAAM,OAAO,GAAG,OAAO,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC;YACnD,IAAI,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC;YAE1B,OAAO,MAAM,IAAI,MAAM,KAAK,OAAO,EAAE,CAAC;gBACpC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAG,CAAC;oBAChD,IAAI,MAAM,KAAK,OAAO,CAAC,CAAC,CAAC,EAAG,CAAC;wBAC3B,OAAO,CAAC,IAAI,CAAC,KAAI,EAAE,KAAK,EAAE,MAAM,CAAC,CAAC;oBACpC,CAAC;gBACH,CAAC;gBAED,MAAM,GAAG,MAAM,CAAC,UAAyB,CAAC;YAC5C,CAAC;QACH,CAAC,CAAC;QAEF,OAAO,CAAC,gBAAgB,CAAC,SAAS,EAAE,wBAAwB,CAAC,OAAO,CAAC,CAAC,CAAC;QAEvE,OAAO,OAAO,CAAC;IACjB,CAAC;IAED,GAAG,YAAC,OAAoB,EAAE,SAAiB,EAAE,OAAe;QAC1D,IAAI,CAAC,OAAO,IAAI,wBAAwB,CAAC,OAAO,CAAC,KAAK,IAAI,EAAE,CAAC;YAC3D,OAAO;QACT,CAAC;QAED,OAAO,CAAC,mBAAmB,CAAC,SAAS,EAAE,wBAAwB,CAAC,OAAO,CAAC,CAAC,CAAC;QAE1E,OAAO,wBAAwB,CAAC,OAAO,CAAC,CAAC;IAC3C,CAAC;CACF,CAAC;AAEF,eAAe,cAAc,CAAC"}
@@ -0,0 +1,92 @@
1
+ var KTUtils = {
2
+ geUID: function (prefix) {
3
+ if (prefix === void 0) { prefix = ''; }
4
+ return prefix + Math.floor(Math.random() * (new Date()).getTime());
5
+ },
6
+ getBreakpoint: function (breakpoint) {
7
+ var value = KTUtils.getCssVar("--tw-".concat(breakpoint));
8
+ if (value) {
9
+ return parseInt(value.trim());
10
+ }
11
+ else {
12
+ return -1;
13
+ }
14
+ },
15
+ getCssVar: function (variable) {
16
+ var hex = getComputedStyle(document.documentElement).getPropertyValue(variable);
17
+ if (hex && hex.length > 0) {
18
+ hex = hex.trim();
19
+ }
20
+ return hex;
21
+ },
22
+ parseDataAttribute: function (value) {
23
+ if (value === 'true') {
24
+ return true;
25
+ }
26
+ if (value === 'false') {
27
+ return false;
28
+ }
29
+ if (value === Number(value).toString()) {
30
+ return Number(value);
31
+ }
32
+ if (value === '' || value === 'null') {
33
+ return null;
34
+ }
35
+ if (typeof value !== 'string') {
36
+ return value;
37
+ }
38
+ try {
39
+ return KTUtils.parseJson(value);
40
+ }
41
+ catch (_a) {
42
+ return value;
43
+ }
44
+ },
45
+ parseJson: function (value) {
46
+ return value && value.length > 0 ? JSON.parse(decodeURIComponent(value)) : null;
47
+ },
48
+ parseSelector: function (selector) {
49
+ if (selector && window.CSS && window.CSS.escape) {
50
+ // Escape any IDs in the selector using CSS.escape
51
+ selector = selector.replace(/#([^\s"#']+)/g, function (match, id) { return "#".concat(window.CSS.escape(id)); });
52
+ }
53
+ return selector;
54
+ },
55
+ capitalize: function (value) {
56
+ return value.charAt(0).toUpperCase() + value.slice(1);
57
+ },
58
+ uncapitalize: function (value) {
59
+ return value.charAt(0).toLowerCase() + value.slice(1);
60
+ },
61
+ camelCase: function (value) {
62
+ return value.replace(/-([a-z])/g, function (match, letter) {
63
+ return letter.toUpperCase();
64
+ });
65
+ },
66
+ isRTL: function () {
67
+ var htmlElement = document.querySelector('html');
68
+ return Boolean(htmlElement && htmlElement.getAttribute('direction') === 'rtl');
69
+ },
70
+ throttle: function (timer, func, delay) {
71
+ // If setTimeout is already scheduled, no need to do anything
72
+ if (timer) {
73
+ return;
74
+ }
75
+ // Schedule a setTimeout after delay seconds
76
+ timer = setTimeout(function () {
77
+ func();
78
+ // Once setTimeout function execution is finished, timerId = undefined so that in <br>
79
+ // the next scroll event function execution can be scheduled by the setTimeout
80
+ clearTimeout(timer);
81
+ }, delay);
82
+ },
83
+ checksum: function (value) {
84
+ var hash = 0;
85
+ for (var i = 0; i < value.length; i++) {
86
+ hash = ((hash << 5) - hash + value.charCodeAt(i)) | 0;
87
+ }
88
+ return ('0000000' + (hash >>> 0).toString(16)).slice(-8);
89
+ },
90
+ };
91
+ export default KTUtils;
92
+ //# sourceMappingURL=utils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/helpers/utils.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,79 @@
1
+ /*
2
+ * Index
3
+ * @version: 1.0.0
4
+ * @author: Keenthemes
5
+ * Copyright 2024 Keenthemes
6
+ */
7
+ import KTDom from './helpers/dom';
8
+ import { KTMenu } from './components/menu';
9
+ import { KTDropdown } from './components/dropdown';
10
+ import { KTModal } from './components/modal';
11
+ import { KTDrawer } from './components/drawer';
12
+ import { KTCollapse } from './components/collapse';
13
+ import { KTDismiss } from './components/dismiss';
14
+ import { KTTabs } from './components/tabs';
15
+ import { KTAccordion } from './components/accordion';
16
+ import { KTScrollspy } from './components/scrollspy';
17
+ import { KTScrollable } from './components/scrollable';
18
+ import { KTScrollto } from './components/scrollto';
19
+ import { KTSticky } from './components/sticky';
20
+ import { KTReparent } from './components/reparent';
21
+ import { KTToggle } from './components/toggle';
22
+ import { KTTooltip } from './components/tooltip';
23
+ import { KTStepper } from './components/stepper';
24
+ import { KTTheme } from './components/theme';
25
+ import { KTImageInput } from './components/image-input';
26
+ import { KTTogglePassword } from './components/toggle-password';
27
+ import { KTDataTable } from './components/datatable';
28
+ export { default as KTUtils } from './helpers/utils';
29
+ export { default as KTDom } from './helpers/dom';
30
+ export { default as KTEventHandler } from './helpers/event-handler';
31
+ export { KTMenu } from './components/menu';
32
+ export { KTDropdown } from './components/dropdown';
33
+ export { KTModal } from './components/modal';
34
+ export { KTDrawer } from './components/drawer';
35
+ export { KTCollapse } from './components/collapse';
36
+ export { KTDismiss } from './components/dismiss';
37
+ export { KTTabs } from './components/tabs';
38
+ export { KTAccordion } from './components/accordion';
39
+ export { KTScrollspy } from './components/scrollspy';
40
+ export { KTScrollable } from './components/scrollable';
41
+ export { KTScrollto } from './components/scrollto';
42
+ export { KTSticky } from './components/sticky';
43
+ export { KTReparent } from './components/reparent';
44
+ export { KTToggle } from './components/toggle';
45
+ export { KTTooltip } from './components/tooltip';
46
+ export { KTStepper } from './components/stepper';
47
+ export { KTTheme } from './components/theme';
48
+ export { KTImageInput } from './components/image-input';
49
+ export { KTTogglePassword } from './components/toggle-password';
50
+ export { KTDataTable } from './components/datatable';
51
+ var KTComponents = {
52
+ init: function () {
53
+ KTMenu.init();
54
+ KTDropdown.init();
55
+ KTModal.init();
56
+ KTDrawer.init();
57
+ KTCollapse.init();
58
+ KTDismiss.init();
59
+ KTTabs.init();
60
+ KTAccordion.init();
61
+ KTScrollspy.init();
62
+ KTScrollable.init();
63
+ KTScrollto.init();
64
+ KTSticky.init();
65
+ KTReparent.init();
66
+ KTToggle.init();
67
+ KTTooltip.init();
68
+ KTStepper.init();
69
+ KTTheme.init();
70
+ KTImageInput.init();
71
+ KTTogglePassword.init();
72
+ KTDataTable.init();
73
+ }
74
+ };
75
+ export default KTComponents;
76
+ KTDom.ready(function () {
77
+ KTComponents.init();
78
+ });
79
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":""}
package/package.json ADDED
@@ -0,0 +1,85 @@
1
+ {
2
+ "name": "@keenthemes/ktui",
3
+ "version": "1.0.3",
4
+ "description": "Free & Open-Source Tailwind UI Components by Keenthemes",
5
+ "homepage": "https://ktui.io",
6
+ "keywords": [
7
+ "reui",
8
+ "keenthemes",
9
+ "tailwind",
10
+ "tailwind css",
11
+ "tailwind examples",
12
+ "tailwind components",
13
+ "tailwind application",
14
+ "tailwind dashboard",
15
+ "tailwind data management",
16
+ "tailwind layouts",
17
+ "tailwind javascript",
18
+ "tailwind typescript",
19
+ "tailwind react",
20
+ "tailwind nextjs",
21
+ "tailwind vue",
22
+ "tailwind angular",
23
+ "tailwind laravel",
24
+ "tailwind menu",
25
+ "tailwind megamenu",
26
+ "tailwind buttons",
27
+ "tailwind forms",
28
+ "tailwind tabs",
29
+ "tailwind datatable",
30
+ "tailwind scrollspy",
31
+ "tailwind scrollto",
32
+ "tailwind stepper",
33
+ "tailwind accordion",
34
+ "tailwind collapse",
35
+ "tailwind dismiss",
36
+ "tailwind toggle",
37
+ "tailwind reparent",
38
+ "tailwind theme",
39
+ "tailwind drawer",
40
+ "tailwind modal",
41
+ "tailwind tooltip",
42
+ "tailwind popover",
43
+ "tailwind image input",
44
+ "tailwind toggle password",
45
+ "tailwind scrollable",
46
+ "tailwind sticky",
47
+ "tailwind apexcharts",
48
+ "tailwind clipboard"
49
+ ],
50
+ "author": "@keenthemes",
51
+ "types": "lib/esm/index.d.ts",
52
+ "scripts": {
53
+ "test": "echo \"Error: no test specified\" && exit 1",
54
+ "build": "npx webpack --mode=development",
55
+ "build:prod": "npx webpack --env production",
56
+ "build:lib": "tsc --outDir lib/cjs && tsc -m es6 --outDir lib/esm",
57
+ "lint": "npx eslint src --ext .ts",
58
+ "format": "prettier --write src"
59
+ },
60
+ "devDependencies": {
61
+ "@babel/core": "^7.26.10",
62
+ "@babel/preset-env": "^7.26.9",
63
+ "@eslint/js": "^9.25.1",
64
+ "@types/node": "^22.15.3",
65
+ "autoprefixer": "^10.4.21",
66
+ "babel-loader": "^10.0.0",
67
+ "clean-webpack-plugin": "^4.0.0",
68
+ "eslint": "^9.25.1",
69
+ "mini-svg-data-uri": "^1.4.4",
70
+ "prettier": "^3.5.3",
71
+ "source-map-loader": "^5.0.0",
72
+ "terser-webpack-plugin": "^5.3.14",
73
+ "ts-loader": "^9.5.2",
74
+ "typescript": "^5.8.3",
75
+ "webpack": "^5.99.7",
76
+ "webpack-cli": "^6.0.1",
77
+ "webpack-merge-and-include-globally": "^2.3.4"
78
+ },
79
+ "dependencies": {
80
+ "@popperjs/core": "^2.11.8"
81
+ },
82
+ "publishConfig": {
83
+ "access": "public"
84
+ }
85
+ }
@@ -0,0 +1,9 @@
1
+ const config = {
2
+ useTabs: true,
3
+ tabWidth: 2,
4
+ singleQuote: true,
5
+ bracketSameLine: true,
6
+ arrowParens: 'always',
7
+ };
8
+
9
+ module.exports = config;
@@ -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
+
7
+ /* Base Styles (LTR, Light Mode) */
8
+ @layer components {
9
+ .kt-accordion-menu {
10
+ @apply flex flex-col gap-y-1 w-full;
11
+ }
12
+
13
+ .kt-accordion-menu-content {
14
+ @apply transition-[height] overflow-hidden ps-6;
15
+ }
16
+
17
+ .kt-accordion-menu-sub {
18
+ @apply gap-y-1 w-full;
19
+ }
20
+
21
+ .kt-accordion-menu-item {
22
+ @apply space-y-1 w-full;
23
+ }
24
+
25
+ .kt-accordion-menu-toggle {
26
+ @apply w-full flex items-center gap-x-2.5 py-2 px-2.5 rounded-md font-medium text-sm text-foreground hover:bg-accent kt-accordion-active:bg-accent disabled:opacity-50 disabled:pointer-events-none;
27
+
28
+ svg {
29
+ @apply shrink-0 size-4 text-muted-foreground;
30
+ }
31
+ }
32
+
33
+ .kt-accordion-menu-link {
34
+ @apply w-full flex items-center gap-x-2.5 py-2 px-2.5 rounded-md font-medium text-sm text-foreground hover:bg-accent kt-accordion-selected:bg-accent disabled:opacity-50 disabled:pointer-events-none;
35
+
36
+ svg {
37
+ @apply shrink-0 size-4 text-muted-foreground;
38
+ }
39
+ }
40
+
41
+ .kt-accordion-menu-indicator {
42
+ @apply text-muted-foreground ms-auto size-3.5 shrink-0 kt-accordion-active:rotate-180;
43
+ }
44
+ }
45
+
46
+ /* RTL Styles */
47
+ @layer components {
48
+ [dir='rtl'] .kt-accordion-menu-indicator {
49
+ @apply kt-accordion-active:-rotate-180;
50
+ }
51
+ }
@@ -0,0 +1,86 @@
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-accordion-item {
8
+ @apply border-b last:border-b-0 border-border;
9
+ }
10
+
11
+ .kt-accordion-toggle {
12
+ @apply flex items-center justify-between text-start gap-2.5 w-full py-4 cursor-pointer;
13
+ }
14
+
15
+ .kt-accordion-title {
16
+ @apply text-base text-mono font-medium;
17
+ }
18
+
19
+ .kt-accordion-content {
20
+ @apply transition-[height] overflow-hidden;
21
+ }
22
+
23
+ .kt-accordion-wrapper {
24
+ @apply text-base text-foreground pb-4;
25
+ }
26
+
27
+ .kt-accordion-indicator {
28
+ @apply inline-flex items-center size-3 text-muted-foreground;
29
+ }
30
+
31
+ .kt-accordion-indicator-on {
32
+ @apply size-3.5 shrink-0 kt-accordion-active:hidden block;
33
+ }
34
+
35
+ .kt-accordion-indicator-off {
36
+ @apply size-3.5 shrink-0 kt-accordion-active:block hidden;
37
+ }
38
+
39
+ .kt-accordion.kt-accordion-outline {
40
+ @apply flex flex-col gap-3.5;
41
+
42
+ .kt-accordion-item {
43
+ @apply rounded-lg border border-border;
44
+ }
45
+
46
+ .kt-accordion-content {
47
+ @apply border-t border-border;
48
+ }
49
+
50
+ .kt-accordion-toggle {
51
+ @apply p-4;
52
+ }
53
+
54
+ .kt-accordion-wrapper {
55
+ @apply p-4;
56
+ }
57
+ }
58
+ }
59
+
60
+ @custom-variant kt-accordion-active {
61
+ &[data-kt-accordion-item].active {
62
+ @slot;
63
+ }
64
+
65
+ [data-kt-accordion-item].active > [data-kt-accordion-toggle] & {
66
+ @slot;
67
+ }
68
+
69
+ [data-kt-accordion-item].active > [data-kt-accordion-toggle]& {
70
+ @slot;
71
+ }
72
+ }
73
+
74
+ @custom-variant kt-accordion-selected {
75
+ [data-kt-accordion-initialized] .selected {
76
+ @slot;
77
+ }
78
+
79
+ [data-kt-accordion-initialized] .selected & {
80
+ @slot;
81
+ }
82
+
83
+ [data-kt-accordion-initialized] &.selected {
84
+ @slot;
85
+ }
86
+ }
@@ -0,0 +1,221 @@
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 KTComponent from '../component';
10
+ import { KTAccordionInterface, KTAccordionConfigInterface } from './types';
11
+
12
+ declare global {
13
+ interface Window {
14
+ KT_ACCORDION_INITIALIZED: boolean;
15
+ KTAccordion: typeof KTAccordion;
16
+ }
17
+ }
18
+
19
+ export class KTAccordion extends KTComponent implements KTAccordionInterface {
20
+ protected override _name: string = 'accordion';
21
+ protected override _defaultConfig: KTAccordionConfigInterface = {
22
+ hiddenClass: 'hidden',
23
+ activeClass: 'active',
24
+ expandAll: false,
25
+ };
26
+ protected override _config: KTAccordionConfigInterface = this._defaultConfig;
27
+ protected _accordionElements: NodeListOf<HTMLElement>;
28
+
29
+ constructor(element: HTMLElement, config?: KTAccordionConfigInterface) {
30
+ super();
31
+
32
+ if (KTData.has(element as HTMLElement, this._name)) return;
33
+
34
+ this._init(element);
35
+ this._buildConfig(config);
36
+ this._handlers();
37
+ }
38
+
39
+ protected _handlers(): void {
40
+ KTEventHandler.on(
41
+ this._element,
42
+ '[data-kt-accordion-toggle]',
43
+ 'click',
44
+ (event: Event, target: HTMLElement) => {
45
+ event.preventDefault();
46
+ const accordionElement = target.closest(
47
+ '[data-kt-accordion-item]',
48
+ ) as HTMLElement;
49
+
50
+ if (accordionElement) this._toggle(accordionElement);
51
+ },
52
+ );
53
+ }
54
+
55
+ protected _toggle(accordionElement: HTMLElement): void {
56
+ const payload = { cancel: false };
57
+ this._fireEvent('toggle', payload);
58
+ this._dispatchEvent('toggle', payload);
59
+ if (payload.cancel === true) {
60
+ return;
61
+ }
62
+
63
+ if (accordionElement.classList.contains('active')) {
64
+ this._hide(accordionElement);
65
+ } else {
66
+ this._show(accordionElement);
67
+ }
68
+ }
69
+
70
+ protected _show(accordionElement: HTMLElement): void {
71
+ if (
72
+ accordionElement.hasAttribute('animating') ||
73
+ accordionElement.classList.contains(
74
+ this._getOption('activeClass') as string,
75
+ )
76
+ )
77
+ return;
78
+
79
+ const toggleElement = KTDom.child(
80
+ accordionElement,
81
+ '[data-kt-accordion-toggle]',
82
+ );
83
+ if (!toggleElement) return;
84
+
85
+ const contentElement = KTDom.getElement(
86
+ `#${toggleElement.getAttribute('aria-controls')}`,
87
+ );
88
+ if (!contentElement) return;
89
+
90
+ const payload = { cancel: false };
91
+ this._fireEvent('show', payload);
92
+ this._dispatchEvent('show', payload);
93
+ if (payload.cancel === true) {
94
+ return;
95
+ }
96
+
97
+ if ((this._getOption('expandAll') as boolean) === false) {
98
+ this._hideSiblings(accordionElement);
99
+ }
100
+
101
+ accordionElement.setAttribute('aria-expanded', 'true');
102
+ accordionElement.classList.add(this._getOption('activeClass') as string);
103
+
104
+ accordionElement.setAttribute('animating', 'true');
105
+ contentElement.classList.remove(this._getOption('hiddenClass') as string);
106
+ contentElement.style.height = `0px`;
107
+ KTDom.reflow(contentElement);
108
+ contentElement.style.height = `${contentElement.scrollHeight}px`;
109
+
110
+ KTDom.transitionEnd(contentElement, () => {
111
+ accordionElement.removeAttribute('animating');
112
+ contentElement.style.height = '';
113
+
114
+ this._fireEvent('shown');
115
+ this._dispatchEvent('shown');
116
+ });
117
+ }
118
+
119
+ protected _hide(accordionElement: HTMLElement): void {
120
+ if (
121
+ accordionElement.hasAttribute('animating') ||
122
+ !accordionElement.classList.contains(
123
+ this._getOption('activeClass') as string,
124
+ )
125
+ )
126
+ return;
127
+
128
+ const toggleElement = KTDom.child(
129
+ accordionElement,
130
+ '[data-kt-accordion-toggle]',
131
+ );
132
+ if (!toggleElement) return;
133
+
134
+ const contentElement = KTDom.getElement(
135
+ `#${toggleElement.getAttribute('aria-controls')}`,
136
+ );
137
+ if (!contentElement) return;
138
+
139
+ const payload = { cancel: false };
140
+ this._fireEvent('hide', payload);
141
+ this._dispatchEvent('hide', payload);
142
+ if (payload.cancel === true) {
143
+ return;
144
+ }
145
+
146
+ accordionElement.setAttribute('aria-expanded', 'false');
147
+
148
+ contentElement.style.height = `${contentElement.scrollHeight}px`;
149
+ KTDom.reflow(contentElement);
150
+ contentElement.style.height = '0px';
151
+ accordionElement.setAttribute('animating', 'true');
152
+
153
+ KTDom.transitionEnd(contentElement, () => {
154
+ accordionElement.removeAttribute('animating');
155
+ accordionElement.classList.remove(
156
+ this._getOption('activeClass') as string,
157
+ );
158
+ contentElement.classList.add(this._getOption('hiddenClass') as string);
159
+
160
+ this._fireEvent('hidden');
161
+ this._dispatchEvent('hidden');
162
+ });
163
+ }
164
+
165
+ protected _hideSiblings(accordionElement: HTMLElement): void {
166
+ const siblings = KTDom.siblings(accordionElement);
167
+
168
+ siblings?.forEach((sibling) => {
169
+ this._hide(sibling as HTMLElement);
170
+ });
171
+ }
172
+
173
+ public show(accordionElement: HTMLElement): void {
174
+ this._show(accordionElement);
175
+ }
176
+
177
+ public hide(accordionElement: HTMLElement): void {
178
+ this._hide(accordionElement);
179
+ }
180
+
181
+ public toggle(accordionElement: HTMLElement): void {
182
+ this._toggle(accordionElement);
183
+ }
184
+
185
+ public static getInstance(element: HTMLElement): KTAccordion {
186
+ if (!element) return null;
187
+
188
+ if (KTData.has(element, 'accordion')) {
189
+ return KTData.get(element, 'accordion') as KTAccordion;
190
+ }
191
+
192
+ if (element.getAttribute('data-kt-accordion-initialized') === 'true') {
193
+ return new KTAccordion(element);
194
+ }
195
+
196
+ return null;
197
+ }
198
+
199
+ public static getOrCreateInstance(
200
+ element: HTMLElement,
201
+ config?: KTAccordionConfigInterface,
202
+ ): KTAccordion {
203
+ return this.getInstance(element) || new KTAccordion(element, config);
204
+ }
205
+
206
+ public static createInstances(): void {
207
+ const elements = document.querySelectorAll('[data-kt-accordion]');
208
+
209
+ elements.forEach((element) => {
210
+ new KTAccordion(element as HTMLElement);
211
+ });
212
+ }
213
+
214
+ public static init(): void {
215
+ KTAccordion.createInstances();
216
+ }
217
+ }
218
+
219
+ if (typeof window !== 'undefined') {
220
+ window.KTAccordion = KTAccordion;
221
+ }