@kopexa/tiptap 17.6.18 → 17.7.2

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 (428) hide show
  1. package/dist/index.d.mts +691 -24
  2. package/dist/index.d.ts +691 -24
  3. package/dist/index.js +1478 -786
  4. package/dist/index.mjs +7987 -112
  5. package/package.json +57 -52
  6. package/dist/chunk-2SI7MRAE.mjs +0 -64
  7. package/dist/chunk-2U5CQUZH.mjs +0 -91
  8. package/dist/chunk-2UDCL55K.mjs +0 -55
  9. package/dist/chunk-2V6VOAPI.mjs +0 -139
  10. package/dist/chunk-2Z2QVW67.mjs +0 -1
  11. package/dist/chunk-32SUXCAQ.mjs +0 -115
  12. package/dist/chunk-33QD5PYJ.mjs +0 -63
  13. package/dist/chunk-3VRQUYYW.mjs +0 -169
  14. package/dist/chunk-42HKGCOO.mjs +0 -129
  15. package/dist/chunk-4ALV4UA5.mjs +0 -1
  16. package/dist/chunk-4CDZ547I.mjs +0 -185
  17. package/dist/chunk-4HO7BWDC.mjs +0 -89
  18. package/dist/chunk-4JRYQZ4A.mjs +0 -174
  19. package/dist/chunk-552JLRNB.mjs +0 -35
  20. package/dist/chunk-5SMDMQDF.mjs +0 -34
  21. package/dist/chunk-6552DQWB.mjs +0 -416
  22. package/dist/chunk-7FDDRVUE.mjs +0 -143
  23. package/dist/chunk-7VGROP26.mjs +0 -262
  24. package/dist/chunk-7VW67NVL.mjs +0 -80
  25. package/dist/chunk-AAV7ZNBP.mjs +0 -83
  26. package/dist/chunk-ATRHILCH.mjs +0 -1
  27. package/dist/chunk-B7WJOQ3X.mjs +0 -103
  28. package/dist/chunk-BEV5U2DK.mjs +0 -131
  29. package/dist/chunk-BXHPO3T7.mjs +0 -152
  30. package/dist/chunk-BXJYNSWQ.mjs +0 -30
  31. package/dist/chunk-C5RQWJKE.mjs +0 -155
  32. package/dist/chunk-CNVACBGT.mjs +0 -51
  33. package/dist/chunk-DQK6PA4U.mjs +0 -276
  34. package/dist/chunk-DSBJFMHK.mjs +0 -38
  35. package/dist/chunk-DT7ML2P4.mjs +0 -42
  36. package/dist/chunk-DZLGLP7R.mjs +0 -99
  37. package/dist/chunk-EAAQE5ZV.mjs +0 -283
  38. package/dist/chunk-EHY2NAW7.mjs +0 -120
  39. package/dist/chunk-EIIWU5FR.mjs +0 -61
  40. package/dist/chunk-ERPGWXFK.mjs +0 -163
  41. package/dist/chunk-F73FCUD5.mjs +0 -1
  42. package/dist/chunk-FRJX2F4T.mjs +0 -55
  43. package/dist/chunk-GYIYX2JH.mjs +0 -73
  44. package/dist/chunk-H6LC4LDQ.mjs +0 -63
  45. package/dist/chunk-H7MS2UMO.mjs +0 -168
  46. package/dist/chunk-HLLA2HRV.mjs +0 -1
  47. package/dist/chunk-HTJ2RXOG.mjs +0 -32
  48. package/dist/chunk-IFXRPGIJ.mjs +0 -98
  49. package/dist/chunk-IOB3REX6.mjs +0 -173
  50. package/dist/chunk-IQERE7KP.mjs +0 -115
  51. package/dist/chunk-JCV5SEKN.mjs +0 -65
  52. package/dist/chunk-JVSH5T4B.mjs +0 -72
  53. package/dist/chunk-KK4K43WM.mjs +0 -59
  54. package/dist/chunk-KR42JAVB.mjs +0 -60
  55. package/dist/chunk-KYLBKQ2E.mjs +0 -203
  56. package/dist/chunk-L5RDMV3H.mjs +0 -216
  57. package/dist/chunk-LNVWG34E.mjs +0 -165
  58. package/dist/chunk-LVNUU67N.mjs +0 -1
  59. package/dist/chunk-MNTOOEHA.mjs +0 -1
  60. package/dist/chunk-N3JE67CS.mjs +0 -81
  61. package/dist/chunk-N4CT5RNC.mjs +0 -123
  62. package/dist/chunk-OEVR5N7X.mjs +0 -65
  63. package/dist/chunk-P55PLOHR.mjs +0 -34
  64. package/dist/chunk-Q5FK7SFY.mjs +0 -75
  65. package/dist/chunk-Q7DFJ5NI.mjs +0 -153
  66. package/dist/chunk-QIELBKP3.mjs +0 -104
  67. package/dist/chunk-R2GM4A3T.mjs +0 -71
  68. package/dist/chunk-REJEJXOZ.mjs +0 -10
  69. package/dist/chunk-RFWNKE7D.mjs +0 -238
  70. package/dist/chunk-TAM3VMJT.mjs +0 -80
  71. package/dist/chunk-TDFS3DCZ.mjs +0 -79
  72. package/dist/chunk-TLM5ALHZ.mjs +0 -1
  73. package/dist/chunk-TZQQ6C2Q.mjs +0 -101
  74. package/dist/chunk-U5XAL46P.mjs +0 -39
  75. package/dist/chunk-UJ4BNZ63.mjs +0 -178
  76. package/dist/chunk-UVHVCION.mjs +0 -168
  77. package/dist/chunk-V6TAZMQN.mjs +0 -105
  78. package/dist/chunk-VF3G2URZ.mjs +0 -83
  79. package/dist/chunk-VRQ6OSAZ.mjs +0 -76
  80. package/dist/chunk-VTKJPVNM.mjs +0 -148
  81. package/dist/chunk-VX3HSJ76.mjs +0 -73
  82. package/dist/chunk-W2FLOOJ6.mjs +0 -75
  83. package/dist/chunk-XGAABDMW.mjs +0 -159
  84. package/dist/chunk-Y2KSWMG5.mjs +0 -1
  85. package/dist/chunk-YJAHZXLG.mjs +0 -92
  86. package/dist/chunk-Z365KVQY.mjs +0 -34
  87. package/dist/chunk-ZVTJ6XD7.mjs +0 -88
  88. package/dist/chunk-ZZ4OU46C.mjs +0 -131
  89. package/dist/context/editor-context.d.mts +0 -10
  90. package/dist/context/editor-context.d.ts +0 -10
  91. package/dist/context/editor-context.js +0 -34
  92. package/dist/context/editor-context.mjs +0 -9
  93. package/dist/context/editor-file-context.d.mts +0 -70
  94. package/dist/context/editor-file-context.d.ts +0 -70
  95. package/dist/context/editor-file-context.js +0 -96
  96. package/dist/context/editor-file-context.mjs +0 -12
  97. package/dist/extensions/callout/callout-settings.d.mts +0 -13
  98. package/dist/extensions/callout/callout-settings.d.ts +0 -13
  99. package/dist/extensions/callout/callout-settings.js +0 -206
  100. package/dist/extensions/callout/callout-settings.mjs +0 -9
  101. package/dist/extensions/callout/callout-view.d.mts +0 -12
  102. package/dist/extensions/callout/callout-view.d.ts +0 -12
  103. package/dist/extensions/callout/callout-view.js +0 -273
  104. package/dist/extensions/callout/callout-view.mjs +0 -12
  105. package/dist/extensions/callout/index.d.mts +0 -44
  106. package/dist/extensions/callout/index.d.ts +0 -44
  107. package/dist/extensions/callout/index.js +0 -380
  108. package/dist/extensions/callout/index.mjs +0 -13
  109. package/dist/extensions/callout/messages.d.mts +0 -59
  110. package/dist/extensions/callout/messages.d.ts +0 -59
  111. package/dist/extensions/callout/messages.js +0 -88
  112. package/dist/extensions/callout/messages.mjs +0 -7
  113. package/dist/extensions/image/image-view.d.mts +0 -15
  114. package/dist/extensions/image/image-view.d.ts +0 -15
  115. package/dist/extensions/image/image-view.js +0 -255
  116. package/dist/extensions/image/image-view.mjs +0 -12
  117. package/dist/extensions/image/index.d.mts +0 -29
  118. package/dist/extensions/image/index.d.ts +0 -29
  119. package/dist/extensions/image/index.js +0 -282
  120. package/dist/extensions/image/index.mjs +0 -16
  121. package/dist/extensions/image/messages.d.mts +0 -28
  122. package/dist/extensions/image/messages.d.ts +0 -28
  123. package/dist/extensions/image/messages.js +0 -57
  124. package/dist/extensions/image/messages.mjs +0 -7
  125. package/dist/extensions/image-upload/image-upload-view.d.mts +0 -12
  126. package/dist/extensions/image-upload/image-upload-view.d.ts +0 -12
  127. package/dist/extensions/image-upload/image-upload-view.js +0 -338
  128. package/dist/extensions/image-upload/image-upload-view.mjs +0 -12
  129. package/dist/extensions/image-upload/index.d.mts +0 -46
  130. package/dist/extensions/image-upload/index.d.ts +0 -46
  131. package/dist/extensions/image-upload/index.js +0 -414
  132. package/dist/extensions/image-upload/index.mjs +0 -16
  133. package/dist/extensions/image-upload/messages.d.mts +0 -32
  134. package/dist/extensions/image-upload/messages.d.ts +0 -32
  135. package/dist/extensions/image-upload/messages.js +0 -61
  136. package/dist/extensions/image-upload/messages.mjs +0 -7
  137. package/dist/extensions/link/index.d.mts +0 -6
  138. package/dist/extensions/link/index.d.ts +0 -6
  139. package/dist/extensions/link/index.js +0 -94
  140. package/dist/extensions/link/index.mjs +0 -7
  141. package/dist/extensions/math/index.d.mts +0 -38
  142. package/dist/extensions/math/index.d.ts +0 -38
  143. package/dist/extensions/math/index.js +0 -544
  144. package/dist/extensions/math/index.mjs +0 -17
  145. package/dist/extensions/math/inline-math-view.d.mts +0 -12
  146. package/dist/extensions/math/inline-math-view.d.ts +0 -12
  147. package/dist/extensions/math/inline-math-view.js +0 -232
  148. package/dist/extensions/math/inline-math-view.mjs +0 -11
  149. package/dist/extensions/math/inline-math.d.mts +0 -32
  150. package/dist/extensions/math/inline-math.d.ts +0 -32
  151. package/dist/extensions/math/inline-math.js +0 -304
  152. package/dist/extensions/math/inline-math.mjs +0 -12
  153. package/dist/extensions/math/math-block-view.d.mts +0 -11
  154. package/dist/extensions/math/math-block-view.d.ts +0 -11
  155. package/dist/extensions/math/math-block-view.js +0 -248
  156. package/dist/extensions/math/math-block-view.mjs +0 -11
  157. package/dist/extensions/math/messages.d.mts +0 -49
  158. package/dist/extensions/math/messages.d.ts +0 -49
  159. package/dist/extensions/math/messages.js +0 -78
  160. package/dist/extensions/math/messages.mjs +0 -7
  161. package/dist/extensions/selection/index.d.mts +0 -5
  162. package/dist/extensions/selection/index.d.ts +0 -5
  163. package/dist/extensions/selection/index.js +0 -62
  164. package/dist/extensions/selection/index.mjs +0 -7
  165. package/dist/extensions/toc/index.d.mts +0 -53
  166. package/dist/extensions/toc/index.d.ts +0 -53
  167. package/dist/extensions/toc/index.js +0 -501
  168. package/dist/extensions/toc/index.mjs +0 -13
  169. package/dist/extensions/toc/messages.d.mts +0 -74
  170. package/dist/extensions/toc/messages.d.ts +0 -74
  171. package/dist/extensions/toc/messages.js +0 -103
  172. package/dist/extensions/toc/messages.mjs +0 -7
  173. package/dist/extensions/toc/toc-settings.d.mts +0 -13
  174. package/dist/extensions/toc/toc-settings.d.ts +0 -13
  175. package/dist/extensions/toc/toc-settings.js +0 -283
  176. package/dist/extensions/toc/toc-settings.mjs +0 -9
  177. package/dist/extensions/toc/toc-view.d.mts +0 -12
  178. package/dist/extensions/toc/toc-view.d.ts +0 -12
  179. package/dist/extensions/toc/toc-view.js +0 -411
  180. package/dist/extensions/toc/toc-view.mjs +0 -12
  181. package/dist/extensions/trailing-node/index.d.mts +0 -9
  182. package/dist/extensions/trailing-node/index.d.ts +0 -9
  183. package/dist/extensions/trailing-node/index.js +0 -86
  184. package/dist/extensions/trailing-node/index.mjs +0 -7
  185. package/dist/extensions/ui-state/index.d.mts +0 -34
  186. package/dist/extensions/ui-state/index.d.ts +0 -34
  187. package/dist/extensions/ui-state/index.js +0 -84
  188. package/dist/extensions/ui-state/index.mjs +0 -9
  189. package/dist/extensions/variable/extract-variables.d.mts +0 -16
  190. package/dist/extensions/variable/extract-variables.d.ts +0 -16
  191. package/dist/extensions/variable/extract-variables.js +0 -58
  192. package/dist/extensions/variable/extract-variables.mjs +0 -7
  193. package/dist/extensions/variable/index.d.mts +0 -38
  194. package/dist/extensions/variable/index.d.ts +0 -38
  195. package/dist/extensions/variable/index.js +0 -190
  196. package/dist/extensions/variable/index.mjs +0 -11
  197. package/dist/extensions/variable/messages.d.mts +0 -69
  198. package/dist/extensions/variable/messages.d.ts +0 -69
  199. package/dist/extensions/variable/messages.js +0 -98
  200. package/dist/extensions/variable/messages.mjs +0 -7
  201. package/dist/extensions/variable/variable-context.d.mts +0 -56
  202. package/dist/extensions/variable/variable-context.d.ts +0 -56
  203. package/dist/extensions/variable/variable-context.js +0 -70
  204. package/dist/extensions/variable/variable-context.mjs +0 -12
  205. package/dist/extensions/variable/variable-filler-dialog.d.mts +0 -43
  206. package/dist/extensions/variable/variable-filler-dialog.d.ts +0 -43
  207. package/dist/extensions/variable/variable-filler-dialog.js +0 -207
  208. package/dist/extensions/variable/variable-filler-dialog.mjs +0 -9
  209. package/dist/extensions/variable/variable-suggestion.d.mts +0 -31
  210. package/dist/extensions/variable/variable-suggestion.d.ts +0 -31
  211. package/dist/extensions/variable/variable-suggestion.js +0 -615
  212. package/dist/extensions/variable/variable-suggestion.mjs +0 -14
  213. package/dist/extensions/variable/variable-view.d.mts +0 -13
  214. package/dist/extensions/variable/variable-view.d.ts +0 -13
  215. package/dist/extensions/variable/variable-view.js +0 -110
  216. package/dist/extensions/variable/variable-view.mjs +0 -11
  217. package/dist/hooks/use-create-editor.d.mts +0 -46
  218. package/dist/hooks/use-create-editor.d.ts +0 -46
  219. package/dist/hooks/use-create-editor.js +0 -2726
  220. package/dist/hooks/use-create-editor.mjs +0 -37
  221. package/dist/hooks/use-cursor-visibility.d.mts +0 -37
  222. package/dist/hooks/use-cursor-visibility.d.ts +0 -37
  223. package/dist/hooks/use-cursor-visibility.js +0 -140
  224. package/dist/hooks/use-cursor-visibility.mjs +0 -8
  225. package/dist/hooks/use-floating-element.d.mts +0 -43
  226. package/dist/hooks/use-floating-element.d.ts +0 -43
  227. package/dist/hooks/use-floating-element.js +0 -88
  228. package/dist/hooks/use-floating-element.mjs +0 -8
  229. package/dist/hooks/use-floating-toolbar-visibility.d.mts +0 -32
  230. package/dist/hooks/use-floating-toolbar-visibility.d.ts +0 -32
  231. package/dist/hooks/use-floating-toolbar-visibility.js +0 -115
  232. package/dist/hooks/use-floating-toolbar-visibility.mjs +0 -13
  233. package/dist/hooks/use-menu-navigation.d.mts +0 -55
  234. package/dist/hooks/use-menu-navigation.d.ts +0 -55
  235. package/dist/hooks/use-menu-navigation.js +0 -163
  236. package/dist/hooks/use-menu-navigation.mjs +0 -8
  237. package/dist/hooks/use-tiptap-editor.d.mts +0 -20
  238. package/dist/hooks/use-tiptap-editor.d.ts +0 -20
  239. package/dist/hooks/use-tiptap-editor.js +0 -58
  240. package/dist/hooks/use-tiptap-editor.mjs +0 -8
  241. package/dist/hooks/use-ui-editor-state.d.mts +0 -7
  242. package/dist/hooks/use-ui-editor-state.d.ts +0 -7
  243. package/dist/hooks/use-ui-editor-state.js +0 -107
  244. package/dist/hooks/use-ui-editor-state.mjs +0 -11
  245. package/dist/hooks/use-window-size.d.mts +0 -12
  246. package/dist/hooks/use-window-size.d.ts +0 -12
  247. package/dist/hooks/use-window-size.js +0 -75
  248. package/dist/hooks/use-window-size.mjs +0 -7
  249. package/dist/presets/basic/editor-header.d.mts +0 -23
  250. package/dist/presets/basic/editor-header.d.ts +0 -23
  251. package/dist/presets/basic/editor-header.js +0 -2750
  252. package/dist/presets/basic/editor-header.mjs +0 -43
  253. package/dist/presets/basic/index.d.mts +0 -38
  254. package/dist/presets/basic/index.d.ts +0 -38
  255. package/dist/presets/basic/index.js +0 -6891
  256. package/dist/presets/basic/index.mjs +0 -85
  257. package/dist/ui/blockquote-button/blockquote-button.d.mts +0 -20
  258. package/dist/ui/blockquote-button/blockquote-button.d.ts +0 -20
  259. package/dist/ui/blockquote-button/blockquote-button.js +0 -247
  260. package/dist/ui/blockquote-button/blockquote-button.mjs +0 -9
  261. package/dist/ui/blockquote-button/index.d.mts +0 -6
  262. package/dist/ui/blockquote-button/index.d.ts +0 -6
  263. package/dist/ui/blockquote-button/index.js +0 -259
  264. package/dist/ui/blockquote-button/index.mjs +0 -21
  265. package/dist/ui/blockquote-button/use-blockquote.d.mts +0 -85
  266. package/dist/ui/blockquote-button/use-blockquote.d.ts +0 -85
  267. package/dist/ui/blockquote-button/use-blockquote.js +0 -192
  268. package/dist/ui/blockquote-button/use-blockquote.mjs +0 -17
  269. package/dist/ui/bubble-menu/index.d.mts +0 -13
  270. package/dist/ui/bubble-menu/index.d.ts +0 -13
  271. package/dist/ui/bubble-menu/index.js +0 -673
  272. package/dist/ui/bubble-menu/index.mjs +0 -16
  273. package/dist/ui/codeblock-button/code-block-button.d.mts +0 -20
  274. package/dist/ui/codeblock-button/code-block-button.d.ts +0 -20
  275. package/dist/ui/codeblock-button/code-block-button.js +0 -237
  276. package/dist/ui/codeblock-button/code-block-button.mjs +0 -9
  277. package/dist/ui/codeblock-button/index.d.mts +0 -6
  278. package/dist/ui/codeblock-button/index.d.ts +0 -6
  279. package/dist/ui/codeblock-button/index.js +0 -249
  280. package/dist/ui/codeblock-button/index.mjs +0 -21
  281. package/dist/ui/codeblock-button/use-code-block.d.mts +0 -92
  282. package/dist/ui/codeblock-button/use-code-block.d.ts +0 -92
  283. package/dist/ui/codeblock-button/use-code-block.js +0 -192
  284. package/dist/ui/codeblock-button/use-code-block.mjs +0 -17
  285. package/dist/ui/color-highlight-button/color-highlight-button.d.mts +0 -25
  286. package/dist/ui/color-highlight-button/color-highlight-button.d.ts +0 -25
  287. package/dist/ui/color-highlight-button/color-highlight-button.js +0 -266
  288. package/dist/ui/color-highlight-button/color-highlight-button.mjs +0 -9
  289. package/dist/ui/color-highlight-button/index.d.mts +0 -6
  290. package/dist/ui/color-highlight-button/index.d.ts +0 -6
  291. package/dist/ui/color-highlight-button/index.js +0 -342
  292. package/dist/ui/color-highlight-button/index.mjs +0 -27
  293. package/dist/ui/color-highlight-button/use-color-highlight.d.mts +0 -64
  294. package/dist/ui/color-highlight-button/use-color-highlight.d.ts +0 -64
  295. package/dist/ui/color-highlight-button/use-color-highlight.js +0 -247
  296. package/dist/ui/color-highlight-button/use-color-highlight.mjs +0 -23
  297. package/dist/ui/color-highlight-popover/color-highlight-popover.d.mts +0 -29
  298. package/dist/ui/color-highlight-popover/color-highlight-popover.d.ts +0 -29
  299. package/dist/ui/color-highlight-popover/color-highlight-popover.js +0 -590
  300. package/dist/ui/color-highlight-popover/color-highlight-popover.mjs +0 -17
  301. package/dist/ui/color-highlight-popover/index.d.mts +0 -6
  302. package/dist/ui/color-highlight-popover/index.d.ts +0 -6
  303. package/dist/ui/color-highlight-popover/index.js +0 -591
  304. package/dist/ui/color-highlight-popover/index.mjs +0 -17
  305. package/dist/ui/copy-anchor-link-button/use-scroll-to-hash.d.mts +0 -30
  306. package/dist/ui/copy-anchor-link-button/use-scroll-to-hash.d.ts +0 -30
  307. package/dist/ui/copy-anchor-link-button/use-scroll-to-hash.js +0 -171
  308. package/dist/ui/copy-anchor-link-button/use-scroll-to-hash.mjs +0 -10
  309. package/dist/ui/heading-button/index.d.mts +0 -45
  310. package/dist/ui/heading-button/index.d.ts +0 -45
  311. package/dist/ui/heading-button/index.js +0 -222
  312. package/dist/ui/heading-button/index.mjs +0 -16
  313. package/dist/ui/heading-button/utils.d.mts +0 -17
  314. package/dist/ui/heading-button/utils.d.ts +0 -17
  315. package/dist/ui/heading-button/utils.js +0 -92
  316. package/dist/ui/heading-button/utils.mjs +0 -19
  317. package/dist/ui/heading-dropdown-menu/index.d.mts +0 -14
  318. package/dist/ui/heading-dropdown-menu/index.d.ts +0 -14
  319. package/dist/ui/heading-dropdown-menu/index.js +0 -308
  320. package/dist/ui/heading-dropdown-menu/index.mjs +0 -10
  321. package/dist/ui/link-bubble/index.d.mts +0 -13
  322. package/dist/ui/link-bubble/index.d.ts +0 -13
  323. package/dist/ui/link-bubble/index.js +0 -183
  324. package/dist/ui/link-bubble/index.mjs +0 -10
  325. package/dist/ui/link-popover/index.d.mts +0 -7
  326. package/dist/ui/link-popover/index.d.ts +0 -7
  327. package/dist/ui/link-popover/index.js +0 -512
  328. package/dist/ui/link-popover/index.mjs +0 -30
  329. package/dist/ui/link-popover/link-popover.d.mts +0 -85
  330. package/dist/ui/link-popover/link-popover.d.ts +0 -85
  331. package/dist/ui/link-popover/link-popover.js +0 -498
  332. package/dist/ui/link-popover/link-popover.mjs +0 -16
  333. package/dist/ui/link-popover/use-link-popover.d.mts +0 -123
  334. package/dist/ui/link-popover/use-link-popover.d.ts +0 -123
  335. package/dist/ui/link-popover/use-link-popover.js +0 -259
  336. package/dist/ui/link-popover/use-link-popover.mjs +0 -20
  337. package/dist/ui/list-button/index.d.mts +0 -50
  338. package/dist/ui/list-button/index.d.ts +0 -50
  339. package/dist/ui/list-button/index.js +0 -232
  340. package/dist/ui/list-button/index.mjs +0 -24
  341. package/dist/ui/list-dropdown-menu/index.d.mts +0 -45
  342. package/dist/ui/list-dropdown-menu/index.d.ts +0 -45
  343. package/dist/ui/list-dropdown-menu/index.js +0 -361
  344. package/dist/ui/list-dropdown-menu/index.mjs +0 -21
  345. package/dist/ui/mark-button/index.d.mts +0 -59
  346. package/dist/ui/mark-button/index.d.ts +0 -59
  347. package/dist/ui/mark-button/index.js +0 -217
  348. package/dist/ui/mark-button/index.mjs +0 -26
  349. package/dist/ui/reset-all-formatting-button/index.d.mts +0 -7
  350. package/dist/ui/reset-all-formatting-button/index.d.ts +0 -7
  351. package/dist/ui/reset-all-formatting-button/index.js +0 -286
  352. package/dist/ui/reset-all-formatting-button/index.mjs +0 -26
  353. package/dist/ui/reset-all-formatting-button/reset-all-formatting-button.d.mts +0 -30
  354. package/dist/ui/reset-all-formatting-button/reset-all-formatting-button.d.ts +0 -30
  355. package/dist/ui/reset-all-formatting-button/reset-all-formatting-button.js +0 -271
  356. package/dist/ui/reset-all-formatting-button/reset-all-formatting-button.mjs +0 -12
  357. package/dist/ui/reset-all-formatting-button/use-reset-all-formatting.d.mts +0 -103
  358. package/dist/ui/reset-all-formatting-button/use-reset-all-formatting.d.ts +0 -103
  359. package/dist/ui/reset-all-formatting-button/use-reset-all-formatting.js +0 -211
  360. package/dist/ui/reset-all-formatting-button/use-reset-all-formatting.mjs +0 -21
  361. package/dist/ui/slash-dropdown-menu/index.d.mts +0 -10
  362. package/dist/ui/slash-dropdown-menu/index.d.ts +0 -10
  363. package/dist/ui/slash-dropdown-menu/index.js +0 -1056
  364. package/dist/ui/slash-dropdown-menu/index.mjs +0 -19
  365. package/dist/ui/slash-dropdown-menu/slash-dropdown-menu.d.mts +0 -16
  366. package/dist/ui/slash-dropdown-menu/slash-dropdown-menu.d.ts +0 -16
  367. package/dist/ui/slash-dropdown-menu/slash-dropdown-menu.js +0 -1053
  368. package/dist/ui/slash-dropdown-menu/slash-dropdown-menu.mjs +0 -16
  369. package/dist/ui/slash-dropdown-menu/use-slash-dropdown-menu.d.mts +0 -162
  370. package/dist/ui/slash-dropdown-menu/use-slash-dropdown-menu.d.ts +0 -162
  371. package/dist/ui/slash-dropdown-menu/use-slash-dropdown-menu.js +0 -457
  372. package/dist/ui/slash-dropdown-menu/use-slash-dropdown-menu.mjs +0 -10
  373. package/dist/ui/suggestion-menu/index.d.mts +0 -10
  374. package/dist/ui/suggestion-menu/index.d.ts +0 -10
  375. package/dist/ui/suggestion-menu/index.js +0 -489
  376. package/dist/ui/suggestion-menu/index.mjs +0 -17
  377. package/dist/ui/suggestion-menu/suggestion-menu-types.d.mts +0 -89
  378. package/dist/ui/suggestion-menu/suggestion-menu-types.d.ts +0 -89
  379. package/dist/ui/suggestion-menu/suggestion-menu-types.js +0 -19
  380. package/dist/ui/suggestion-menu/suggestion-menu-types.mjs +0 -1
  381. package/dist/ui/suggestion-menu/suggestion-menu-utils.d.mts +0 -27
  382. package/dist/ui/suggestion-menu/suggestion-menu-utils.d.ts +0 -27
  383. package/dist/ui/suggestion-menu/suggestion-menu-utils.js +0 -75
  384. package/dist/ui/suggestion-menu/suggestion-menu-utils.mjs +0 -9
  385. package/dist/ui/suggestion-menu/suggestion-menu.d.mts +0 -15
  386. package/dist/ui/suggestion-menu/suggestion-menu.d.ts +0 -15
  387. package/dist/ui/suggestion-menu/suggestion-menu.js +0 -453
  388. package/dist/ui/suggestion-menu/suggestion-menu.mjs +0 -12
  389. package/dist/ui/table-button/index.d.mts +0 -15
  390. package/dist/ui/table-button/index.d.ts +0 -15
  391. package/dist/ui/table-button/index.js +0 -202
  392. package/dist/ui/table-button/index.mjs +0 -9
  393. package/dist/ui/table-button/use-table.d.mts +0 -51
  394. package/dist/ui/table-button/use-table.d.ts +0 -51
  395. package/dist/ui/table-button/use-table.js +0 -146
  396. package/dist/ui/table-button/use-table.mjs +0 -14
  397. package/dist/ui/text-align-button/index.d.mts +0 -6
  398. package/dist/ui/text-align-button/index.d.ts +0 -6
  399. package/dist/ui/text-align-button/index.js +0 -235
  400. package/dist/ui/text-align-button/index.mjs +0 -29
  401. package/dist/ui/text-align-button/text-align-button.d.mts +0 -20
  402. package/dist/ui/text-align-button/text-align-button.d.ts +0 -20
  403. package/dist/ui/text-align-button/text-align-button.js +0 -215
  404. package/dist/ui/text-align-button/text-align-button.mjs +0 -9
  405. package/dist/ui/text-align-button/use-text-align.d.mts +0 -106
  406. package/dist/ui/text-align-button/use-text-align.d.ts +0 -106
  407. package/dist/ui/text-align-button/use-text-align.js +0 -169
  408. package/dist/ui/text-align-button/use-text-align.mjs +0 -24
  409. package/dist/ui/undo-redo-button/index.d.mts +0 -6
  410. package/dist/ui/undo-redo-button/index.d.ts +0 -6
  411. package/dist/ui/undo-redo-button/index.js +0 -202
  412. package/dist/ui/undo-redo-button/index.mjs +0 -25
  413. package/dist/ui/undo-redo-button/undo-redo-button.d.mts +0 -23
  414. package/dist/ui/undo-redo-button/undo-redo-button.d.ts +0 -23
  415. package/dist/ui/undo-redo-button/undo-redo-button.js +0 -187
  416. package/dist/ui/undo-redo-button/undo-redo-button.mjs +0 -10
  417. package/dist/ui/undo-redo-button/use-undo-redo.d.mts +0 -95
  418. package/dist/ui/undo-redo-button/use-undo-redo.d.ts +0 -95
  419. package/dist/ui/undo-redo-button/use-undo-redo.js +0 -146
  420. package/dist/ui/undo-redo-button/use-undo-redo.mjs +0 -21
  421. package/dist/utils/index.d.mts +0 -38
  422. package/dist/utils/index.d.ts +0 -38
  423. package/dist/utils/index.js +0 -128
  424. package/dist/utils/index.mjs +0 -15
  425. package/dist/utils/safe-parse.d.mts +0 -14
  426. package/dist/utils/safe-parse.d.ts +0 -14
  427. package/dist/utils/safe-parse.js +0 -203
  428. package/dist/utils/safe-parse.mjs +0 -8
@@ -1,20 +0,0 @@
1
- import * as react_jsx_runtime from 'react/jsx-runtime';
2
- import { ButtonProps } from '@kopexa/button';
3
- import { UseCodeBlockConfig } from './use-code-block.js';
4
- import '@kopexa/icons';
5
- import '@tiptap/react';
6
-
7
- interface CodeBlockButtonProps extends Omit<ButtonProps, "type">, UseCodeBlockConfig {
8
- /**
9
- * Optional text to display alongside the icon.
10
- */
11
- text?: string;
12
- /**
13
- * Optional show shortcut keys in the button.
14
- * @default false
15
- */
16
- showShortcut?: boolean;
17
- }
18
- declare const CodeBlockButton: ({ editor: providedEditor, text, hideWhenUnavailable, onToggled, showShortcut, onClick, children, ...buttonProps }: CodeBlockButtonProps) => react_jsx_runtime.JSX.Element | null;
19
-
20
- export { CodeBlockButton, type CodeBlockButtonProps };
@@ -1,237 +0,0 @@
1
- "use client";
2
- "use strict";
3
- var __create = Object.create;
4
- var __defProp = Object.defineProperty;
5
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
6
- var __getOwnPropNames = Object.getOwnPropertyNames;
7
- var __getProtoOf = Object.getPrototypeOf;
8
- var __hasOwnProp = Object.prototype.hasOwnProperty;
9
- var __export = (target, all) => {
10
- for (var name in all)
11
- __defProp(target, name, { get: all[name], enumerable: true });
12
- };
13
- var __copyProps = (to, from, except, desc) => {
14
- if (from && typeof from === "object" || typeof from === "function") {
15
- for (let key of __getOwnPropNames(from))
16
- if (!__hasOwnProp.call(to, key) && key !== except)
17
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
18
- }
19
- return to;
20
- };
21
- var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
22
- // If the importer is in node compatibility mode or this is not an ESM
23
- // file that has been converted to a CommonJS file using a Babel-
24
- // compatible transform (i.e. "__esModule" has not been set), then set
25
- // "default" to the CommonJS "module.exports" for node compatibility.
26
- isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
27
- mod
28
- ));
29
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
30
-
31
- // src/ui/codeblock-button/code-block-button.tsx
32
- var code_block_button_exports = {};
33
- __export(code_block_button_exports, {
34
- CodeBlockButton: () => CodeBlockButton
35
- });
36
- module.exports = __toCommonJS(code_block_button_exports);
37
- var import_icons2 = require("@kopexa/icons");
38
- var import_toolbar = require("@kopexa/toolbar");
39
- var import_react3 = require("react");
40
-
41
- // src/hooks/use-tiptap-editor.ts
42
- var import_react = require("@tiptap/react");
43
- var import_react2 = require("react");
44
- function useTiptapEditor(providedEditor) {
45
- const { editor: coreEditor } = (0, import_react.useCurrentEditor)();
46
- const mainEditor = (0, import_react2.useMemo)(
47
- () => providedEditor || coreEditor,
48
- [providedEditor, coreEditor]
49
- );
50
- const editorState = (0, import_react.useEditorState)({
51
- editor: mainEditor,
52
- selector(context) {
53
- if (!context.editor) {
54
- return {
55
- editor: null,
56
- editorState: void 0,
57
- canCommand: void 0
58
- };
59
- }
60
- return {
61
- editor: context.editor,
62
- editorState: context.editor.state,
63
- canCommand: context.editor.can
64
- };
65
- }
66
- });
67
- return editorState || { editor: null };
68
- }
69
-
70
- // src/ui/codeblock-button/use-code-block.ts
71
- var import_editor_utils = require("@kopexa/editor-utils");
72
- var import_icons = require("@kopexa/icons");
73
- var import_state = require("@tiptap/pm/state");
74
- var React = __toESM(require("react"));
75
- var CODE_BLOCK_SHORTCUT_KEY = "mod+alt+c";
76
- function canToggle(editor, turnInto = true) {
77
- var _a;
78
- if (!editor || !editor.isEditable) return false;
79
- if (!(0, import_editor_utils.isNodeInSchema)("codeBlock", editor) || (0, import_editor_utils.isNodeTypeSelected)(editor, ["image"]))
80
- return false;
81
- if (!turnInto) {
82
- return editor.can().toggleNode("codeBlock", "paragraph");
83
- }
84
- try {
85
- const view = editor.view;
86
- const state = view.state;
87
- const selection = state.selection;
88
- if (selection.empty || selection instanceof import_state.TextSelection) {
89
- const pos = (_a = (0, import_editor_utils.findNodePosition)({
90
- editor,
91
- node: state.selection.$anchor.node(1)
92
- })) == null ? void 0 : _a.pos;
93
- if (!(0, import_editor_utils.isValidPosition)(pos)) return false;
94
- }
95
- return true;
96
- } catch {
97
- return false;
98
- }
99
- }
100
- function toggleCodeBlock(editor) {
101
- var _a, _b, _c;
102
- if (!editor || !editor.isEditable) return false;
103
- if (!canToggle(editor)) return false;
104
- try {
105
- const view = editor.view;
106
- let state = view.state;
107
- let tr = state.tr;
108
- if (state.selection.empty || state.selection instanceof import_state.TextSelection) {
109
- const pos = (_a = (0, import_editor_utils.findNodePosition)({
110
- editor,
111
- node: state.selection.$anchor.node(1)
112
- })) == null ? void 0 : _a.pos;
113
- if (!(0, import_editor_utils.isValidPosition)(pos)) return false;
114
- tr = tr.setSelection(import_state.NodeSelection.create(state.doc, pos));
115
- view.dispatch(tr);
116
- state = view.state;
117
- }
118
- const selection = state.selection;
119
- let chain = editor.chain().focus();
120
- if (selection instanceof import_state.NodeSelection) {
121
- const firstChild = (_b = selection.node.firstChild) == null ? void 0 : _b.firstChild;
122
- const lastChild = (_c = selection.node.lastChild) == null ? void 0 : _c.lastChild;
123
- const from = firstChild ? selection.from + firstChild.nodeSize : selection.from + 1;
124
- const to = lastChild ? selection.to - lastChild.nodeSize : selection.to - 1;
125
- chain = chain.setTextSelection({ from, to }).clearNodes();
126
- }
127
- const toggle = editor.isActive("codeBlock") ? chain.setNode("paragraph") : chain.toggleNode("codeBlock", "paragraph");
128
- toggle.run();
129
- editor.chain().focus().selectTextblockEnd().run();
130
- return true;
131
- } catch {
132
- return false;
133
- }
134
- }
135
- function shouldShowButton(props) {
136
- const { editor, hideWhenUnavailable } = props;
137
- if (!editor || !editor.isEditable) return false;
138
- if (!(0, import_editor_utils.isNodeInSchema)("codeBlock", editor)) return false;
139
- if (hideWhenUnavailable && !editor.isActive("code")) {
140
- return canToggle(editor);
141
- }
142
- return true;
143
- }
144
- function useCodeBlock(config) {
145
- const {
146
- editor: providedEditor,
147
- hideWhenUnavailable = false,
148
- onToggled
149
- } = config || {};
150
- const { editor } = useTiptapEditor(providedEditor);
151
- const [isVisible, setIsVisible] = React.useState(true);
152
- const canToggleState = canToggle(editor);
153
- const isActive = (editor == null ? void 0 : editor.isActive("codeBlock")) || false;
154
- React.useEffect(() => {
155
- if (!editor) return;
156
- const handleSelectionUpdate = () => {
157
- setIsVisible(shouldShowButton({ editor, hideWhenUnavailable }));
158
- };
159
- handleSelectionUpdate();
160
- editor.on("selectionUpdate", handleSelectionUpdate);
161
- return () => {
162
- editor.off("selectionUpdate", handleSelectionUpdate);
163
- };
164
- }, [editor, hideWhenUnavailable]);
165
- const handleToggle = React.useCallback(() => {
166
- if (!editor) return false;
167
- const success = toggleCodeBlock(editor);
168
- if (success) {
169
- onToggled == null ? void 0 : onToggled();
170
- }
171
- return success;
172
- }, [editor, onToggled]);
173
- return {
174
- isVisible,
175
- isActive,
176
- handleToggle,
177
- canToggle: canToggleState,
178
- label: "Code Block",
179
- shortcutKeys: CODE_BLOCK_SHORTCUT_KEY,
180
- Icon: import_icons.CodeblockIcon
181
- };
182
- }
183
-
184
- // src/ui/codeblock-button/code-block-button.tsx
185
- var import_jsx_runtime = require("react/jsx-runtime");
186
- var CodeBlockButton = ({
187
- editor: providedEditor,
188
- text,
189
- hideWhenUnavailable = false,
190
- onToggled,
191
- showShortcut = false,
192
- onClick,
193
- children,
194
- ...buttonProps
195
- }) => {
196
- const { editor } = useTiptapEditor(providedEditor);
197
- const { isVisible, canToggle: canToggle2, isActive, handleToggle, label, shortcutKeys } = useCodeBlock({
198
- editor,
199
- hideWhenUnavailable,
200
- onToggled
201
- });
202
- const handleClick = (0, import_react3.useCallback)(
203
- (event) => {
204
- onClick == null ? void 0 : onClick(event);
205
- if (event.defaultPrevented) return;
206
- handleToggle();
207
- },
208
- [handleToggle, onClick]
209
- );
210
- if (!isVisible) {
211
- return null;
212
- }
213
- return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
214
- import_toolbar.ToolbarButton,
215
- {
216
- type: "button",
217
- variant: "ghost",
218
- color: "default",
219
- disabled: !canToggle2,
220
- "data-disabled": !canToggle2,
221
- "data-active-state": isActive ? "on" : "off",
222
- tabIndex: -1,
223
- "aria-label": "codeBlock",
224
- "aria-pressed": isActive,
225
- title: label,
226
- shortcutKeys,
227
- onClick: handleClick,
228
- isIconOnly: true,
229
- ...buttonProps,
230
- children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_icons2.CodeblockIcon, {})
231
- }
232
- );
233
- };
234
- // Annotate the CommonJS export names for ESM import in node:
235
- 0 && (module.exports = {
236
- CodeBlockButton
237
- });
@@ -1,9 +0,0 @@
1
- "use client";
2
- import {
3
- CodeBlockButton
4
- } from "../../chunk-OEVR5N7X.mjs";
5
- import "../../chunk-BEV5U2DK.mjs";
6
- import "../../chunk-P55PLOHR.mjs";
7
- export {
8
- CodeBlockButton
9
- };
@@ -1,6 +0,0 @@
1
- export { CodeBlockButton, CodeBlockButtonProps } from './code-block-button.mjs';
2
- export { CODE_BLOCK_SHORTCUT_KEY, UseCodeBlockConfig, canToggle, shouldShowButton, toggleCodeBlock, useCodeBlock } from './use-code-block.mjs';
3
- import 'react/jsx-runtime';
4
- import '@kopexa/button';
5
- import '@kopexa/icons';
6
- import '@tiptap/react';
@@ -1,6 +0,0 @@
1
- export { CodeBlockButton, CodeBlockButtonProps } from './code-block-button.js';
2
- export { CODE_BLOCK_SHORTCUT_KEY, UseCodeBlockConfig, canToggle, shouldShowButton, toggleCodeBlock, useCodeBlock } from './use-code-block.js';
3
- import 'react/jsx-runtime';
4
- import '@kopexa/button';
5
- import '@kopexa/icons';
6
- import '@tiptap/react';
@@ -1,249 +0,0 @@
1
- "use client";
2
- "use strict";
3
- var __create = Object.create;
4
- var __defProp = Object.defineProperty;
5
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
6
- var __getOwnPropNames = Object.getOwnPropertyNames;
7
- var __getProtoOf = Object.getPrototypeOf;
8
- var __hasOwnProp = Object.prototype.hasOwnProperty;
9
- var __export = (target, all) => {
10
- for (var name in all)
11
- __defProp(target, name, { get: all[name], enumerable: true });
12
- };
13
- var __copyProps = (to, from, except, desc) => {
14
- if (from && typeof from === "object" || typeof from === "function") {
15
- for (let key of __getOwnPropNames(from))
16
- if (!__hasOwnProp.call(to, key) && key !== except)
17
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
18
- }
19
- return to;
20
- };
21
- var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
22
- // If the importer is in node compatibility mode or this is not an ESM
23
- // file that has been converted to a CommonJS file using a Babel-
24
- // compatible transform (i.e. "__esModule" has not been set), then set
25
- // "default" to the CommonJS "module.exports" for node compatibility.
26
- isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
27
- mod
28
- ));
29
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
30
-
31
- // src/ui/codeblock-button/index.tsx
32
- var codeblock_button_exports = {};
33
- __export(codeblock_button_exports, {
34
- CODE_BLOCK_SHORTCUT_KEY: () => CODE_BLOCK_SHORTCUT_KEY,
35
- CodeBlockButton: () => CodeBlockButton,
36
- canToggle: () => canToggle,
37
- shouldShowButton: () => shouldShowButton,
38
- toggleCodeBlock: () => toggleCodeBlock,
39
- useCodeBlock: () => useCodeBlock
40
- });
41
- module.exports = __toCommonJS(codeblock_button_exports);
42
-
43
- // src/ui/codeblock-button/code-block-button.tsx
44
- var import_icons2 = require("@kopexa/icons");
45
- var import_toolbar = require("@kopexa/toolbar");
46
- var import_react3 = require("react");
47
-
48
- // src/hooks/use-tiptap-editor.ts
49
- var import_react = require("@tiptap/react");
50
- var import_react2 = require("react");
51
- function useTiptapEditor(providedEditor) {
52
- const { editor: coreEditor } = (0, import_react.useCurrentEditor)();
53
- const mainEditor = (0, import_react2.useMemo)(
54
- () => providedEditor || coreEditor,
55
- [providedEditor, coreEditor]
56
- );
57
- const editorState = (0, import_react.useEditorState)({
58
- editor: mainEditor,
59
- selector(context) {
60
- if (!context.editor) {
61
- return {
62
- editor: null,
63
- editorState: void 0,
64
- canCommand: void 0
65
- };
66
- }
67
- return {
68
- editor: context.editor,
69
- editorState: context.editor.state,
70
- canCommand: context.editor.can
71
- };
72
- }
73
- });
74
- return editorState || { editor: null };
75
- }
76
-
77
- // src/ui/codeblock-button/use-code-block.ts
78
- var import_editor_utils = require("@kopexa/editor-utils");
79
- var import_icons = require("@kopexa/icons");
80
- var import_state = require("@tiptap/pm/state");
81
- var React = __toESM(require("react"));
82
- var CODE_BLOCK_SHORTCUT_KEY = "mod+alt+c";
83
- function canToggle(editor, turnInto = true) {
84
- var _a;
85
- if (!editor || !editor.isEditable) return false;
86
- if (!(0, import_editor_utils.isNodeInSchema)("codeBlock", editor) || (0, import_editor_utils.isNodeTypeSelected)(editor, ["image"]))
87
- return false;
88
- if (!turnInto) {
89
- return editor.can().toggleNode("codeBlock", "paragraph");
90
- }
91
- try {
92
- const view = editor.view;
93
- const state = view.state;
94
- const selection = state.selection;
95
- if (selection.empty || selection instanceof import_state.TextSelection) {
96
- const pos = (_a = (0, import_editor_utils.findNodePosition)({
97
- editor,
98
- node: state.selection.$anchor.node(1)
99
- })) == null ? void 0 : _a.pos;
100
- if (!(0, import_editor_utils.isValidPosition)(pos)) return false;
101
- }
102
- return true;
103
- } catch {
104
- return false;
105
- }
106
- }
107
- function toggleCodeBlock(editor) {
108
- var _a, _b, _c;
109
- if (!editor || !editor.isEditable) return false;
110
- if (!canToggle(editor)) return false;
111
- try {
112
- const view = editor.view;
113
- let state = view.state;
114
- let tr = state.tr;
115
- if (state.selection.empty || state.selection instanceof import_state.TextSelection) {
116
- const pos = (_a = (0, import_editor_utils.findNodePosition)({
117
- editor,
118
- node: state.selection.$anchor.node(1)
119
- })) == null ? void 0 : _a.pos;
120
- if (!(0, import_editor_utils.isValidPosition)(pos)) return false;
121
- tr = tr.setSelection(import_state.NodeSelection.create(state.doc, pos));
122
- view.dispatch(tr);
123
- state = view.state;
124
- }
125
- const selection = state.selection;
126
- let chain = editor.chain().focus();
127
- if (selection instanceof import_state.NodeSelection) {
128
- const firstChild = (_b = selection.node.firstChild) == null ? void 0 : _b.firstChild;
129
- const lastChild = (_c = selection.node.lastChild) == null ? void 0 : _c.lastChild;
130
- const from = firstChild ? selection.from + firstChild.nodeSize : selection.from + 1;
131
- const to = lastChild ? selection.to - lastChild.nodeSize : selection.to - 1;
132
- chain = chain.setTextSelection({ from, to }).clearNodes();
133
- }
134
- const toggle = editor.isActive("codeBlock") ? chain.setNode("paragraph") : chain.toggleNode("codeBlock", "paragraph");
135
- toggle.run();
136
- editor.chain().focus().selectTextblockEnd().run();
137
- return true;
138
- } catch {
139
- return false;
140
- }
141
- }
142
- function shouldShowButton(props) {
143
- const { editor, hideWhenUnavailable } = props;
144
- if (!editor || !editor.isEditable) return false;
145
- if (!(0, import_editor_utils.isNodeInSchema)("codeBlock", editor)) return false;
146
- if (hideWhenUnavailable && !editor.isActive("code")) {
147
- return canToggle(editor);
148
- }
149
- return true;
150
- }
151
- function useCodeBlock(config) {
152
- const {
153
- editor: providedEditor,
154
- hideWhenUnavailable = false,
155
- onToggled
156
- } = config || {};
157
- const { editor } = useTiptapEditor(providedEditor);
158
- const [isVisible, setIsVisible] = React.useState(true);
159
- const canToggleState = canToggle(editor);
160
- const isActive = (editor == null ? void 0 : editor.isActive("codeBlock")) || false;
161
- React.useEffect(() => {
162
- if (!editor) return;
163
- const handleSelectionUpdate = () => {
164
- setIsVisible(shouldShowButton({ editor, hideWhenUnavailable }));
165
- };
166
- handleSelectionUpdate();
167
- editor.on("selectionUpdate", handleSelectionUpdate);
168
- return () => {
169
- editor.off("selectionUpdate", handleSelectionUpdate);
170
- };
171
- }, [editor, hideWhenUnavailable]);
172
- const handleToggle = React.useCallback(() => {
173
- if (!editor) return false;
174
- const success = toggleCodeBlock(editor);
175
- if (success) {
176
- onToggled == null ? void 0 : onToggled();
177
- }
178
- return success;
179
- }, [editor, onToggled]);
180
- return {
181
- isVisible,
182
- isActive,
183
- handleToggle,
184
- canToggle: canToggleState,
185
- label: "Code Block",
186
- shortcutKeys: CODE_BLOCK_SHORTCUT_KEY,
187
- Icon: import_icons.CodeblockIcon
188
- };
189
- }
190
-
191
- // src/ui/codeblock-button/code-block-button.tsx
192
- var import_jsx_runtime = require("react/jsx-runtime");
193
- var CodeBlockButton = ({
194
- editor: providedEditor,
195
- text,
196
- hideWhenUnavailable = false,
197
- onToggled,
198
- showShortcut = false,
199
- onClick,
200
- children,
201
- ...buttonProps
202
- }) => {
203
- const { editor } = useTiptapEditor(providedEditor);
204
- const { isVisible, canToggle: canToggle2, isActive, handleToggle, label, shortcutKeys } = useCodeBlock({
205
- editor,
206
- hideWhenUnavailable,
207
- onToggled
208
- });
209
- const handleClick = (0, import_react3.useCallback)(
210
- (event) => {
211
- onClick == null ? void 0 : onClick(event);
212
- if (event.defaultPrevented) return;
213
- handleToggle();
214
- },
215
- [handleToggle, onClick]
216
- );
217
- if (!isVisible) {
218
- return null;
219
- }
220
- return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
221
- import_toolbar.ToolbarButton,
222
- {
223
- type: "button",
224
- variant: "ghost",
225
- color: "default",
226
- disabled: !canToggle2,
227
- "data-disabled": !canToggle2,
228
- "data-active-state": isActive ? "on" : "off",
229
- tabIndex: -1,
230
- "aria-label": "codeBlock",
231
- "aria-pressed": isActive,
232
- title: label,
233
- shortcutKeys,
234
- onClick: handleClick,
235
- isIconOnly: true,
236
- ...buttonProps,
237
- children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_icons2.CodeblockIcon, {})
238
- }
239
- );
240
- };
241
- // Annotate the CommonJS export names for ESM import in node:
242
- 0 && (module.exports = {
243
- CODE_BLOCK_SHORTCUT_KEY,
244
- CodeBlockButton,
245
- canToggle,
246
- shouldShowButton,
247
- toggleCodeBlock,
248
- useCodeBlock
249
- });
@@ -1,21 +0,0 @@
1
- "use client";
2
- import "../../chunk-ATRHILCH.mjs";
3
- import {
4
- CodeBlockButton
5
- } from "../../chunk-OEVR5N7X.mjs";
6
- import {
7
- CODE_BLOCK_SHORTCUT_KEY,
8
- canToggle,
9
- shouldShowButton,
10
- toggleCodeBlock,
11
- useCodeBlock
12
- } from "../../chunk-BEV5U2DK.mjs";
13
- import "../../chunk-P55PLOHR.mjs";
14
- export {
15
- CODE_BLOCK_SHORTCUT_KEY,
16
- CodeBlockButton,
17
- canToggle,
18
- shouldShowButton,
19
- toggleCodeBlock,
20
- useCodeBlock
21
- };
@@ -1,92 +0,0 @@
1
- import * as react_jsx_runtime from 'react/jsx-runtime';
2
- import * as _kopexa_icons from '@kopexa/icons';
3
- import { Editor } from '@tiptap/react';
4
-
5
- declare const CODE_BLOCK_SHORTCUT_KEY = "mod+alt+c";
6
- /**
7
- * Configuration for the code block functionality
8
- */
9
- interface UseCodeBlockConfig {
10
- /**
11
- * The Tiptap editor instance.
12
- */
13
- editor?: Editor | null;
14
- /**
15
- * Whether the button should hide when code block is not available.
16
- * @default false
17
- */
18
- hideWhenUnavailable?: boolean;
19
- /**
20
- * Callback function called after a successful code block toggle.
21
- */
22
- onToggled?: () => void;
23
- }
24
- /**
25
- * Checks if code block can be toggled in the current editor state
26
- */
27
- declare function canToggle(editor: Editor | null, turnInto?: boolean): boolean;
28
- /**
29
- * Toggles code block in the editor
30
- */
31
- declare function toggleCodeBlock(editor: Editor | null): boolean;
32
- /**
33
- * Determines if the code block button should be shown
34
- */
35
- declare function shouldShowButton(props: {
36
- editor: Editor | null;
37
- hideWhenUnavailable: boolean;
38
- }): boolean;
39
- /**
40
- * Custom hook that provides code block functionality for Tiptap editor
41
- *
42
- * @example
43
- * ```tsx
44
- * // Simple usage - no params needed
45
- * function MySimpleCodeBlockButton() {
46
- * const { isVisible, isActive, handleToggle } = useCodeBlock()
47
- *
48
- * if (!isVisible) return null
49
- *
50
- * return (
51
- * <button
52
- * onClick={handleToggle}
53
- * aria-pressed={isActive}
54
- * >
55
- * Code Block
56
- * </button>
57
- * )
58
- * }
59
- *
60
- * // Advanced usage with configuration
61
- * function MyAdvancedCodeBlockButton() {
62
- * const { isVisible, isActive, handleToggle, label } = useCodeBlock({
63
- * editor: myEditor,
64
- * hideWhenUnavailable: true,
65
- * onToggled: (isActive) => console.log('Code block toggled:', isActive)
66
- * })
67
- *
68
- * if (!isVisible) return null
69
- *
70
- * return (
71
- * <MyButton
72
- * onClick={handleToggle}
73
- * aria-label={label}
74
- * aria-pressed={isActive}
75
- * >
76
- * Toggle Code Block
77
- * </MyButton>
78
- * )
79
- * }
80
- * ```
81
- */
82
- declare function useCodeBlock(config?: UseCodeBlockConfig): {
83
- isVisible: boolean;
84
- isActive: boolean;
85
- handleToggle: () => boolean;
86
- canToggle: boolean;
87
- label: string;
88
- shortcutKeys: string;
89
- Icon: ({ size, ...props }: _kopexa_icons.IconSvgProps) => react_jsx_runtime.JSX.Element;
90
- };
91
-
92
- export { CODE_BLOCK_SHORTCUT_KEY, type UseCodeBlockConfig, canToggle, shouldShowButton, toggleCodeBlock, useCodeBlock };