@jackuait/blok 0.4.1-beta.1 → 0.4.1-beta.12

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 (403) hide show
  1. package/README.md +138 -17
  2. package/codemod/README.md +45 -7
  3. package/codemod/migrate-editorjs-to-blok.js +960 -92
  4. package/codemod/test.js +780 -77
  5. package/dist/blok.mjs +5 -2
  6. package/dist/chunks/blok-BU6NwVkN.mjs +13239 -0
  7. package/dist/chunks/i18next-CugVlwWp.mjs +1292 -0
  8. package/dist/chunks/i18next-loader-D8GzSwio.mjs +43 -0
  9. package/dist/{index-CEXLTV6f.mjs → chunks/index-C5e_WLFg.mjs} +2 -2
  10. package/dist/chunks/inline-tool-convert-CLUxkCe_.mjs +1990 -0
  11. package/dist/chunks/messages-0tDXLuyH.mjs +48 -0
  12. package/dist/chunks/messages-2_xedlYw.mjs +48 -0
  13. package/dist/chunks/messages-AHESHJm_.mjs +48 -0
  14. package/dist/chunks/messages-B5hdXZwA.mjs +48 -0
  15. package/dist/chunks/messages-B5jGUnOy.mjs +48 -0
  16. package/dist/chunks/messages-B5puUm7R.mjs +48 -0
  17. package/dist/chunks/messages-B66ZSDCJ.mjs +48 -0
  18. package/dist/chunks/messages-B9Oba7sq.mjs +48 -0
  19. package/dist/chunks/messages-BA0rcTCY.mjs +48 -0
  20. package/dist/chunks/messages-BBJgd5jG.mjs +48 -0
  21. package/dist/chunks/messages-BPqWKx5Z.mjs +48 -0
  22. package/dist/chunks/messages-Bdv-IkfG.mjs +48 -0
  23. package/dist/chunks/messages-BeUhMpsr.mjs +48 -0
  24. package/dist/chunks/messages-Bf6Y3_GI.mjs +48 -0
  25. package/dist/chunks/messages-BiExzWJv.mjs +48 -0
  26. package/dist/chunks/messages-BlpqL8vG.mjs +48 -0
  27. package/dist/chunks/messages-BmKCChWZ.mjs +48 -0
  28. package/dist/chunks/messages-Bn253WWC.mjs +48 -0
  29. package/dist/chunks/messages-BrJHUxQL.mjs +48 -0
  30. package/dist/chunks/messages-C5b7hr_E.mjs +48 -0
  31. package/dist/chunks/messages-C7I_AVH2.mjs +48 -0
  32. package/dist/chunks/messages-CJoBtXU6.mjs +48 -0
  33. package/dist/chunks/messages-CQj2JU2j.mjs +48 -0
  34. package/dist/chunks/messages-CUZ1x1QD.mjs +48 -0
  35. package/dist/chunks/messages-CUy1vn-b.mjs +48 -0
  36. package/dist/chunks/messages-CVeWVKsV.mjs +48 -0
  37. package/dist/chunks/messages-CXHd9SUK.mjs +48 -0
  38. package/dist/chunks/messages-CbMyJSzS.mjs +48 -0
  39. package/dist/chunks/messages-CbhuIWRJ.mjs +48 -0
  40. package/dist/chunks/messages-CeCjVKMW.mjs +48 -0
  41. package/dist/chunks/messages-Cj-t1bdy.mjs +48 -0
  42. package/dist/chunks/messages-CkFT2gle.mjs +48 -0
  43. package/dist/chunks/messages-Cm9aLHeX.mjs +48 -0
  44. package/dist/chunks/messages-CnvW8Slp.mjs +48 -0
  45. package/dist/chunks/messages-Cr-RJ7YB.mjs +48 -0
  46. package/dist/chunks/messages-CrsJ1TEJ.mjs +48 -0
  47. package/dist/chunks/messages-Cu08aLS3.mjs +48 -0
  48. package/dist/chunks/messages-CvaqJFN-.mjs +48 -0
  49. package/dist/chunks/messages-CyDU5lz9.mjs +48 -0
  50. package/dist/chunks/messages-CySyfkMU.mjs +48 -0
  51. package/dist/chunks/messages-Cyi2AMmz.mjs +48 -0
  52. package/dist/chunks/messages-D00OjS2n.mjs +48 -0
  53. package/dist/chunks/messages-DDLgIPDF.mjs +48 -0
  54. package/dist/chunks/messages-DMQIHGRj.mjs +48 -0
  55. package/dist/chunks/messages-DOlC_Tty.mjs +48 -0
  56. package/dist/chunks/messages-DV6shA9b.mjs +48 -0
  57. package/dist/chunks/messages-DY94ykcE.mjs +48 -0
  58. package/dist/chunks/messages-DbVquYKN.mjs +48 -0
  59. package/dist/chunks/messages-DcKOuncK.mjs +48 -0
  60. package/dist/chunks/messages-Dg92dXZ5.mjs +48 -0
  61. package/dist/chunks/messages-DnbbyJT3.mjs +48 -0
  62. package/dist/chunks/messages-DteYq0rv.mjs +48 -0
  63. package/dist/chunks/messages-GC2PhgV3.mjs +48 -0
  64. package/dist/chunks/messages-JGsXAReJ.mjs +48 -0
  65. package/dist/chunks/messages-JZUhXTuV.mjs +48 -0
  66. package/dist/chunks/messages-LvFKBBPa.mjs +48 -0
  67. package/dist/chunks/messages-NP1myMGI.mjs +48 -0
  68. package/dist/chunks/messages-Q4kc_ZtL.mjs +48 -0
  69. package/dist/chunks/messages-RvMHb2Ht.mjs +48 -0
  70. package/dist/chunks/messages-ftMcCEuO.mjs +48 -0
  71. package/dist/chunks/messages-o24dK6CU.mjs +48 -0
  72. package/dist/chunks/messages-pA5TvcAj.mjs +48 -0
  73. package/dist/chunks/messages-rRSHQDCX.mjs +48 -0
  74. package/dist/chunks/messages-srxrv8Yh.mjs +48 -0
  75. package/dist/chunks/messages-wdqp4610.mjs +48 -0
  76. package/dist/chunks/messages-zS1AXZ0y.mjs +48 -0
  77. package/dist/chunks/messages-zSzDzXej.mjs +48 -0
  78. package/dist/full.mjs +50 -0
  79. package/dist/locales.mjs +228 -0
  80. package/dist/messages-0tDXLuyH.mjs +48 -0
  81. package/dist/messages-2_xedlYw.mjs +48 -0
  82. package/dist/messages-AHESHJm_.mjs +48 -0
  83. package/dist/messages-B5hdXZwA.mjs +48 -0
  84. package/dist/messages-B5jGUnOy.mjs +48 -0
  85. package/dist/messages-B5puUm7R.mjs +48 -0
  86. package/dist/messages-B66ZSDCJ.mjs +48 -0
  87. package/dist/messages-B9Oba7sq.mjs +48 -0
  88. package/dist/messages-BA0rcTCY.mjs +48 -0
  89. package/dist/messages-BBJgd5jG.mjs +48 -0
  90. package/dist/messages-BPqWKx5Z.mjs +48 -0
  91. package/dist/messages-Bdv-IkfG.mjs +48 -0
  92. package/dist/messages-BeUhMpsr.mjs +48 -0
  93. package/dist/messages-Bf6Y3_GI.mjs +48 -0
  94. package/dist/messages-BiExzWJv.mjs +48 -0
  95. package/dist/messages-BlpqL8vG.mjs +48 -0
  96. package/dist/messages-BmKCChWZ.mjs +48 -0
  97. package/dist/messages-Bn253WWC.mjs +48 -0
  98. package/dist/messages-BrJHUxQL.mjs +48 -0
  99. package/dist/messages-C5b7hr_E.mjs +48 -0
  100. package/dist/messages-C7I_AVH2.mjs +48 -0
  101. package/dist/messages-CJoBtXU6.mjs +48 -0
  102. package/dist/messages-CQj2JU2j.mjs +48 -0
  103. package/dist/messages-CUZ1x1QD.mjs +48 -0
  104. package/dist/messages-CUy1vn-b.mjs +48 -0
  105. package/dist/messages-CVeWVKsV.mjs +48 -0
  106. package/dist/messages-CXHd9SUK.mjs +48 -0
  107. package/dist/messages-CbMyJSzS.mjs +48 -0
  108. package/dist/messages-CbhuIWRJ.mjs +48 -0
  109. package/dist/messages-CeCjVKMW.mjs +48 -0
  110. package/dist/messages-Cj-t1bdy.mjs +48 -0
  111. package/dist/messages-CkFT2gle.mjs +48 -0
  112. package/dist/messages-Cm9aLHeX.mjs +48 -0
  113. package/dist/messages-CnvW8Slp.mjs +48 -0
  114. package/dist/messages-Cr-RJ7YB.mjs +48 -0
  115. package/dist/messages-CrsJ1TEJ.mjs +48 -0
  116. package/dist/messages-Cu08aLS3.mjs +48 -0
  117. package/dist/messages-CvaqJFN-.mjs +48 -0
  118. package/dist/messages-CyDU5lz9.mjs +48 -0
  119. package/dist/messages-CySyfkMU.mjs +48 -0
  120. package/dist/messages-Cyi2AMmz.mjs +48 -0
  121. package/dist/messages-D00OjS2n.mjs +48 -0
  122. package/dist/messages-DDLgIPDF.mjs +48 -0
  123. package/dist/messages-DMQIHGRj.mjs +48 -0
  124. package/dist/messages-DOlC_Tty.mjs +48 -0
  125. package/dist/messages-DV6shA9b.mjs +48 -0
  126. package/dist/messages-DY94ykcE.mjs +48 -0
  127. package/dist/messages-DbVquYKN.mjs +48 -0
  128. package/dist/messages-DcKOuncK.mjs +48 -0
  129. package/dist/messages-Dg92dXZ5.mjs +48 -0
  130. package/dist/messages-DnbbyJT3.mjs +48 -0
  131. package/dist/messages-DteYq0rv.mjs +48 -0
  132. package/dist/messages-GC2PhgV3.mjs +48 -0
  133. package/dist/messages-JGsXAReJ.mjs +48 -0
  134. package/dist/messages-JZUhXTuV.mjs +48 -0
  135. package/dist/messages-LvFKBBPa.mjs +48 -0
  136. package/dist/messages-NP1myMGI.mjs +48 -0
  137. package/dist/messages-Q4kc_ZtL.mjs +48 -0
  138. package/dist/messages-RvMHb2Ht.mjs +48 -0
  139. package/dist/messages-ftMcCEuO.mjs +48 -0
  140. package/dist/messages-o24dK6CU.mjs +48 -0
  141. package/dist/messages-pA5TvcAj.mjs +48 -0
  142. package/dist/messages-rRSHQDCX.mjs +48 -0
  143. package/dist/messages-srxrv8Yh.mjs +48 -0
  144. package/dist/messages-wdqp4610.mjs +48 -0
  145. package/dist/messages-zS1AXZ0y.mjs +48 -0
  146. package/dist/messages-zSzDzXej.mjs +48 -0
  147. package/dist/tools.mjs +3126 -0
  148. package/dist/vendor.LICENSE.txt +26 -225
  149. package/package.json +63 -24
  150. package/src/blok.ts +267 -0
  151. package/src/components/__module.ts +139 -0
  152. package/src/components/block/api.ts +155 -0
  153. package/src/components/block/index.ts +1428 -0
  154. package/src/components/block-tunes/block-tune-delete.ts +51 -0
  155. package/src/components/blocks.ts +352 -0
  156. package/src/components/constants/data-attributes.ts +344 -0
  157. package/src/components/constants.ts +76 -0
  158. package/src/components/core.ts +392 -0
  159. package/src/components/dom.ts +773 -0
  160. package/src/components/domIterator.ts +189 -0
  161. package/src/components/errors/critical.ts +5 -0
  162. package/src/components/events/BlockChanged.ts +16 -0
  163. package/src/components/events/BlockHovered.ts +21 -0
  164. package/src/components/events/BlockSettingsClosed.ts +12 -0
  165. package/src/components/events/BlockSettingsOpened.ts +12 -0
  166. package/src/components/events/BlokMobileLayoutToggled.ts +15 -0
  167. package/src/components/events/FakeCursorAboutToBeToggled.ts +17 -0
  168. package/src/components/events/FakeCursorHaveBeenSet.ts +17 -0
  169. package/src/components/events/HistoryStateChanged.ts +19 -0
  170. package/src/components/events/RedactorDomChanged.ts +14 -0
  171. package/src/components/events/index.ts +46 -0
  172. package/src/components/flipper.ts +497 -0
  173. package/src/components/i18n/i18next-loader.ts +84 -0
  174. package/src/components/i18n/lightweight-i18n.ts +86 -0
  175. package/src/components/i18n/locales/TRANSLATION_GUIDELINES.md +113 -0
  176. package/src/components/i18n/locales/am/messages.json +45 -0
  177. package/src/components/i18n/locales/ar/messages.json +45 -0
  178. package/src/components/i18n/locales/az/messages.json +45 -0
  179. package/src/components/i18n/locales/bg/messages.json +45 -0
  180. package/src/components/i18n/locales/bn/messages.json +45 -0
  181. package/src/components/i18n/locales/bs/messages.json +45 -0
  182. package/src/components/i18n/locales/cs/messages.json +45 -0
  183. package/src/components/i18n/locales/da/messages.json +45 -0
  184. package/src/components/i18n/locales/de/messages.json +45 -0
  185. package/src/components/i18n/locales/dv/messages.json +45 -0
  186. package/src/components/i18n/locales/el/messages.json +45 -0
  187. package/src/components/i18n/locales/en/messages.json +45 -0
  188. package/src/components/i18n/locales/es/messages.json +45 -0
  189. package/src/components/i18n/locales/et/messages.json +45 -0
  190. package/src/components/i18n/locales/fa/messages.json +45 -0
  191. package/src/components/i18n/locales/fi/messages.json +45 -0
  192. package/src/components/i18n/locales/fil/messages.json +45 -0
  193. package/src/components/i18n/locales/fr/messages.json +45 -0
  194. package/src/components/i18n/locales/gu/messages.json +45 -0
  195. package/src/components/i18n/locales/he/messages.json +45 -0
  196. package/src/components/i18n/locales/hi/messages.json +45 -0
  197. package/src/components/i18n/locales/hr/messages.json +45 -0
  198. package/src/components/i18n/locales/hu/messages.json +45 -0
  199. package/src/components/i18n/locales/hy/messages.json +45 -0
  200. package/src/components/i18n/locales/id/messages.json +45 -0
  201. package/src/components/i18n/locales/index.ts +231 -0
  202. package/src/components/i18n/locales/it/messages.json +45 -0
  203. package/src/components/i18n/locales/ja/messages.json +45 -0
  204. package/src/components/i18n/locales/ka/messages.json +45 -0
  205. package/src/components/i18n/locales/km/messages.json +45 -0
  206. package/src/components/i18n/locales/kn/messages.json +45 -0
  207. package/src/components/i18n/locales/ko/messages.json +45 -0
  208. package/src/components/i18n/locales/ku/messages.json +45 -0
  209. package/src/components/i18n/locales/lo/messages.json +45 -0
  210. package/src/components/i18n/locales/lt/messages.json +45 -0
  211. package/src/components/i18n/locales/lv/messages.json +45 -0
  212. package/src/components/i18n/locales/mk/messages.json +45 -0
  213. package/src/components/i18n/locales/ml/messages.json +45 -0
  214. package/src/components/i18n/locales/mn/messages.json +45 -0
  215. package/src/components/i18n/locales/mr/messages.json +45 -0
  216. package/src/components/i18n/locales/ms/messages.json +45 -0
  217. package/src/components/i18n/locales/my/messages.json +45 -0
  218. package/src/components/i18n/locales/ne/messages.json +45 -0
  219. package/src/components/i18n/locales/nl/messages.json +45 -0
  220. package/src/components/i18n/locales/no/messages.json +45 -0
  221. package/src/components/i18n/locales/pa/messages.json +45 -0
  222. package/src/components/i18n/locales/pl/messages.json +45 -0
  223. package/src/components/i18n/locales/ps/messages.json +45 -0
  224. package/src/components/i18n/locales/pt/messages.json +45 -0
  225. package/src/components/i18n/locales/ro/messages.json +45 -0
  226. package/src/components/i18n/locales/ru/messages.json +45 -0
  227. package/src/components/i18n/locales/sd/messages.json +45 -0
  228. package/src/components/i18n/locales/si/messages.json +45 -0
  229. package/src/components/i18n/locales/sk/messages.json +45 -0
  230. package/src/components/i18n/locales/sl/messages.json +45 -0
  231. package/src/components/i18n/locales/sq/messages.json +45 -0
  232. package/src/components/i18n/locales/sr/messages.json +45 -0
  233. package/src/components/i18n/locales/sv/messages.json +45 -0
  234. package/src/components/i18n/locales/sw/messages.json +45 -0
  235. package/src/components/i18n/locales/ta/messages.json +45 -0
  236. package/src/components/i18n/locales/te/messages.json +45 -0
  237. package/src/components/i18n/locales/th/messages.json +45 -0
  238. package/src/components/i18n/locales/tr/messages.json +45 -0
  239. package/src/components/i18n/locales/ug/messages.json +45 -0
  240. package/src/components/i18n/locales/uk/messages.json +45 -0
  241. package/src/components/i18n/locales/ur/messages.json +45 -0
  242. package/src/components/i18n/locales/vi/messages.json +45 -0
  243. package/src/components/i18n/locales/yi/messages.json +45 -0
  244. package/src/components/i18n/locales/zh/messages.json +45 -0
  245. package/src/components/icons/index.ts +242 -0
  246. package/src/components/inline-tools/inline-tool-bold.ts +2213 -0
  247. package/src/components/inline-tools/inline-tool-convert.ts +142 -0
  248. package/src/components/inline-tools/inline-tool-italic.ts +500 -0
  249. package/src/components/inline-tools/inline-tool-link.ts +540 -0
  250. package/src/components/modules/api/blocks.ts +377 -0
  251. package/src/components/modules/api/caret.ts +125 -0
  252. package/src/components/modules/api/events.ts +51 -0
  253. package/src/components/modules/api/history.ts +73 -0
  254. package/src/components/modules/api/i18n.ts +35 -0
  255. package/src/components/modules/api/index.ts +39 -0
  256. package/src/components/modules/api/inlineToolbar.ts +33 -0
  257. package/src/components/modules/api/listeners.ts +56 -0
  258. package/src/components/modules/api/notifier.ts +46 -0
  259. package/src/components/modules/api/readonly.ts +39 -0
  260. package/src/components/modules/api/sanitizer.ts +30 -0
  261. package/src/components/modules/api/saver.ts +52 -0
  262. package/src/components/modules/api/selection.ts +48 -0
  263. package/src/components/modules/api/styles.ts +72 -0
  264. package/src/components/modules/api/toolbar.ts +79 -0
  265. package/src/components/modules/api/tools.ts +16 -0
  266. package/src/components/modules/api/tooltip.ts +67 -0
  267. package/src/components/modules/api/ui.ts +36 -0
  268. package/src/components/modules/blockEvents.ts +1591 -0
  269. package/src/components/modules/blockManager.ts +1356 -0
  270. package/src/components/modules/blockSelection.ts +708 -0
  271. package/src/components/modules/caret.ts +853 -0
  272. package/src/components/modules/crossBlockSelection.ts +329 -0
  273. package/src/components/modules/dragManager.ts +1204 -0
  274. package/src/components/modules/history.ts +1098 -0
  275. package/src/components/modules/i18n.ts +332 -0
  276. package/src/components/modules/index.ts +139 -0
  277. package/src/components/modules/modificationsObserver.ts +147 -0
  278. package/src/components/modules/paste.ts +1092 -0
  279. package/src/components/modules/readonly.ts +136 -0
  280. package/src/components/modules/rectangleSelection.ts +711 -0
  281. package/src/components/modules/renderer.ts +155 -0
  282. package/src/components/modules/saver.ts +283 -0
  283. package/src/components/modules/toolbar/blockSettings.ts +782 -0
  284. package/src/components/modules/toolbar/index.ts +1296 -0
  285. package/src/components/modules/toolbar/inline.ts +956 -0
  286. package/src/components/modules/tools.ts +625 -0
  287. package/src/components/modules/ui.ts +1283 -0
  288. package/src/components/polyfills.ts +113 -0
  289. package/src/components/selection.ts +1179 -0
  290. package/src/components/tools/base.ts +301 -0
  291. package/src/components/tools/block.ts +339 -0
  292. package/src/components/tools/collection.ts +67 -0
  293. package/src/components/tools/factory.ts +138 -0
  294. package/src/components/tools/inline.ts +71 -0
  295. package/src/components/tools/tune.ts +33 -0
  296. package/src/components/ui/toolbox.ts +610 -0
  297. package/src/components/utils/announcer.ts +205 -0
  298. package/src/components/utils/api.ts +20 -0
  299. package/src/components/utils/bem.ts +26 -0
  300. package/src/components/utils/blocks.ts +284 -0
  301. package/src/components/utils/caret.ts +1067 -0
  302. package/src/components/utils/data-model-transform.ts +382 -0
  303. package/src/components/utils/events.ts +117 -0
  304. package/src/components/utils/keyboard.ts +60 -0
  305. package/src/components/utils/listeners.ts +296 -0
  306. package/src/components/utils/mutations.ts +39 -0
  307. package/src/components/utils/notifier/draw.ts +190 -0
  308. package/src/components/utils/notifier/index.ts +66 -0
  309. package/src/components/utils/notifier/types.ts +1 -0
  310. package/src/components/utils/notifier.ts +77 -0
  311. package/src/components/utils/placeholder.ts +140 -0
  312. package/src/components/utils/popover/components/hint/hint.const.ts +10 -0
  313. package/src/components/utils/popover/components/hint/hint.ts +46 -0
  314. package/src/components/utils/popover/components/hint/index.ts +6 -0
  315. package/src/components/utils/popover/components/popover-header/index.ts +2 -0
  316. package/src/components/utils/popover/components/popover-header/popover-header.const.ts +8 -0
  317. package/src/components/utils/popover/components/popover-header/popover-header.ts +80 -0
  318. package/src/components/utils/popover/components/popover-header/popover-header.types.ts +14 -0
  319. package/src/components/utils/popover/components/popover-item/index.ts +13 -0
  320. package/src/components/utils/popover/components/popover-item/popover-item-default/popover-item-default.const.ts +50 -0
  321. package/src/components/utils/popover/components/popover-item/popover-item-default/popover-item-default.ts +680 -0
  322. package/src/components/utils/popover/components/popover-item/popover-item-html/popover-item-html.const.ts +14 -0
  323. package/src/components/utils/popover/components/popover-item/popover-item-html/popover-item-html.ts +136 -0
  324. package/src/components/utils/popover/components/popover-item/popover-item-separator/popover-item-separator.const.ts +20 -0
  325. package/src/components/utils/popover/components/popover-item/popover-item-separator/popover-item-separator.ts +117 -0
  326. package/src/components/utils/popover/components/popover-item/popover-item.ts +197 -0
  327. package/src/components/utils/popover/components/search-input/index.ts +2 -0
  328. package/src/components/utils/popover/components/search-input/search-input.const.ts +8 -0
  329. package/src/components/utils/popover/components/search-input/search-input.ts +178 -0
  330. package/src/components/utils/popover/components/search-input/search-input.types.ts +59 -0
  331. package/src/components/utils/popover/index.ts +13 -0
  332. package/src/components/utils/popover/popover-abstract.ts +457 -0
  333. package/src/components/utils/popover/popover-desktop.ts +682 -0
  334. package/src/components/utils/popover/popover-inline.ts +338 -0
  335. package/src/components/utils/popover/popover-mobile.ts +201 -0
  336. package/src/components/utils/popover/popover.const.ts +81 -0
  337. package/src/components/utils/popover/utils/popover-states-history.ts +72 -0
  338. package/src/components/utils/promise-queue.ts +43 -0
  339. package/src/components/utils/sanitizer.ts +537 -0
  340. package/src/components/utils/scroll-locker.ts +87 -0
  341. package/src/components/utils/shortcut.ts +231 -0
  342. package/src/components/utils/shortcuts.ts +113 -0
  343. package/src/components/utils/tools.ts +110 -0
  344. package/src/components/utils/tooltip.ts +591 -0
  345. package/src/components/utils/tw.ts +241 -0
  346. package/src/components/utils.ts +1081 -0
  347. package/src/env.d.ts +13 -0
  348. package/src/full.ts +69 -0
  349. package/src/locales.ts +51 -0
  350. package/src/stories/Block.stories.ts +498 -0
  351. package/src/stories/EditorModes.stories.ts +505 -0
  352. package/src/stories/Header.stories.ts +137 -0
  353. package/src/stories/InlineToolbar.stories.ts +498 -0
  354. package/src/stories/List.stories.ts +259 -0
  355. package/src/stories/Notifier.stories.ts +340 -0
  356. package/src/stories/Paragraph.stories.ts +112 -0
  357. package/src/stories/Placeholder.stories.ts +319 -0
  358. package/src/stories/Popover.stories.ts +759 -0
  359. package/src/stories/Selection.stories.ts +250 -0
  360. package/src/stories/StubBlock.stories.ts +156 -0
  361. package/src/stories/Toolbar.stories.ts +223 -0
  362. package/src/stories/Toolbox.stories.ts +166 -0
  363. package/src/stories/Tooltip.stories.ts +198 -0
  364. package/src/stories/helpers.ts +463 -0
  365. package/src/styles/main.css +126 -0
  366. package/src/tools/header/index.ts +647 -0
  367. package/src/tools/index.ts +45 -0
  368. package/src/tools/list/index.ts +1826 -0
  369. package/src/tools/paragraph/index.ts +412 -0
  370. package/src/tools/stub/index.ts +107 -0
  371. package/src/types-internal/blok-modules.d.ts +87 -0
  372. package/src/types-internal/html-janitor.d.ts +28 -0
  373. package/src/types-internal/module-config.d.ts +11 -0
  374. package/src/variants/all-locales.ts +155 -0
  375. package/src/variants/blok-maximum.ts +20 -0
  376. package/src/variants/blok-minimum.ts +243 -0
  377. package/types/api/blocks.d.ts +9 -1
  378. package/types/api/history.d.ts +7 -0
  379. package/types/api/i18n.d.ts +22 -3
  380. package/types/api/selection.d.ts +6 -0
  381. package/types/api/styles.d.ts +23 -10
  382. package/types/configs/blok-config.d.ts +29 -0
  383. package/types/configs/i18n-config.d.ts +52 -2
  384. package/types/configs/i18n-dictionary.d.ts +16 -90
  385. package/types/configs/sanitizer-config.d.ts +25 -1
  386. package/types/data-attributes.d.ts +170 -0
  387. package/types/data-formats/output-data.d.ts +15 -0
  388. package/types/full.d.ts +80 -0
  389. package/types/index.d.ts +30 -13
  390. package/types/locales.d.ts +59 -0
  391. package/types/tools/adapters/inline-tool-adapter.d.ts +10 -0
  392. package/types/tools/block-tool.d.ts +11 -2
  393. package/types/tools/header.d.ts +18 -0
  394. package/types/tools/index.d.ts +1 -0
  395. package/types/tools/list.d.ts +91 -0
  396. package/types/tools/paragraph.d.ts +71 -0
  397. package/types/tools/tool-settings.d.ts +99 -6
  398. package/types/tools/tool.d.ts +6 -0
  399. package/types/tools-entry.d.ts +49 -0
  400. package/types/utils/popover/popover-item.d.ts +24 -5
  401. package/types/utils/popover/popover.d.ts +13 -0
  402. package/dist/blok-C8XbyLHh.mjs +0 -25795
  403. package/dist/blok.umd.js +0 -181
@@ -0,0 +1,166 @@
1
+ /**
2
+ * Toolbox.stories.ts - Stories demonstrating toolbox customization.
3
+ *
4
+ * This file demonstrates how to set custom icons for all available tools
5
+ * in the toolbox using the tool settings configuration.
6
+ */
7
+ import type { Meta, StoryObj } from '@storybook/html-vite';
8
+ import { waitFor, expect } from 'storybook/test';
9
+ import type { OutputData, ToolSettings, BlockToolConstructable } from '@/types';
10
+ import { createEditorContainer, simulateClick, waitForToolbar, TOOLBAR_TESTID } from './helpers';
11
+ import type { EditorFactoryOptions } from './helpers';
12
+ import { Header } from '../tools/header';
13
+ import { Paragraph } from '../tools/paragraph';
14
+
15
+ interface ToolboxArgs extends EditorFactoryOptions {
16
+ minHeight: number;
17
+ data: OutputData | undefined;
18
+ }
19
+
20
+ // Constants
21
+ const BLOCK_TESTID = '[data-blok-testid="block-wrapper"]';
22
+ const PLUS_BUTTON_TESTID = '[data-blok-testid="plus-button"]';
23
+ const TOOLBOX_OPENED_SELECTOR = '[data-blok-toolbox-opened="true"]';
24
+ const POPOVER_ITEM_TESTID = '[data-blok-testid="popover-item"]';
25
+
26
+ const TIMEOUT_INIT = { timeout: 5000 };
27
+ const TIMEOUT_ACTION = { timeout: 5000 };
28
+
29
+ // Custom SVG icons for demonstration
30
+ const CustomIcons = {
31
+ // Star icon for Paragraph
32
+ star: `<svg width="20" height="20" viewBox="0 0 20 20" fill="none">
33
+ <path d="M10 2L12.09 7.26L18 7.97L13.82 11.64L15.18 17.5L10 14.27L4.82 17.5L6.18 11.64L2 7.97L7.91 7.26L10 2Z" stroke="currentColor" stroke-linecap="round" stroke-linejoin="round"/>
34
+ </svg>`,
35
+
36
+ // Crown icon for Heading
37
+ crown: `<svg width="20" height="20" viewBox="0 0 20 20" fill="none">
38
+ <path d="M3 15L4 7L7 10L10 5L13 10L16 7L17 15H3Z" stroke="currentColor" stroke-linecap="round" stroke-linejoin="round"/>
39
+ <path d="M3 15H17V17H3V15Z" stroke="currentColor" stroke-linecap="round" stroke-linejoin="round"/>
40
+ </svg>`,
41
+ };
42
+
43
+ const sampleData: OutputData = {
44
+ time: Date.now(),
45
+ version: '1.0.0',
46
+ blocks: [
47
+ {
48
+ id: 'toolbox-block-1',
49
+ type: 'paragraph',
50
+ data: { text: 'Click the plus button to see the toolbox with custom icons.' },
51
+ },
52
+ ],
53
+ };
54
+
55
+ const createEditor = (args: ToolboxArgs): HTMLElement => createEditorContainer(args);
56
+
57
+ const meta: Meta<ToolboxArgs> = {
58
+ title: 'Components/Toolbox',
59
+ tags: ['autodocs'],
60
+ args: {
61
+ minHeight: 300,
62
+ data: sampleData,
63
+ },
64
+ render: createEditor,
65
+ };
66
+
67
+ export default meta;
68
+
69
+
70
+ type Story = StoryObj<ToolboxArgs>;
71
+
72
+ /**
73
+ * Toolbox with custom icons for all tools.
74
+ *
75
+ * This story demonstrates how to override the default toolbox icons
76
+ * for both Paragraph and Header tools using the `toolbox` configuration
77
+ * in tool settings.
78
+ *
79
+ * To customize icons, use the `toolbox` property in tool settings:
80
+ * ```typescript
81
+ * tools: {
82
+ * paragraph: {
83
+ * class: Paragraph,
84
+ * toolbox: {
85
+ * icon: '<svg>...</svg>',
86
+ * title: 'Custom Title'
87
+ * }
88
+ * }
89
+ * }
90
+ * ```
91
+ */
92
+ export const CustomIconsForAllTools: Story = {
93
+ args: {
94
+ data: sampleData,
95
+ tools: {
96
+ paragraph: {
97
+ class: Paragraph as unknown as BlockToolConstructable,
98
+ toolbox: {
99
+ icon: CustomIcons.star,
100
+ title: 'Paragraph',
101
+ },
102
+ } as ToolSettings,
103
+ header: {
104
+ class: Header as unknown as BlockToolConstructable,
105
+ toolbox: {
106
+ icon: CustomIcons.crown,
107
+ title: 'Header',
108
+ },
109
+ } as ToolSettings,
110
+ },
111
+ },
112
+ play: async ({ canvasElement, step }) => {
113
+ await step('Wait for editor and toolbar to initialize', async () => {
114
+ await waitFor(
115
+ () => {
116
+ const block = canvasElement.querySelector(BLOCK_TESTID);
117
+
118
+ expect(block).toBeInTheDocument();
119
+ },
120
+ TIMEOUT_INIT
121
+ );
122
+ await waitForToolbar(canvasElement);
123
+ });
124
+
125
+ await step('Click block to show toolbar', async () => {
126
+ const block = canvasElement.querySelector(BLOCK_TESTID);
127
+
128
+ if (block) {
129
+ simulateClick(block);
130
+ }
131
+
132
+ await waitFor(
133
+ () => {
134
+ const toolbar = canvasElement.querySelector(TOOLBAR_TESTID);
135
+
136
+ expect(toolbar).toHaveAttribute('data-blok-opened', 'true');
137
+ },
138
+ TIMEOUT_ACTION
139
+ );
140
+ });
141
+
142
+ await step('Open toolbox to see custom icons', async () => {
143
+ const plusButton = canvasElement.querySelector(PLUS_BUTTON_TESTID);
144
+
145
+ if (plusButton) {
146
+ simulateClick(plusButton);
147
+ }
148
+
149
+ await waitFor(
150
+ () => {
151
+ const editor = canvasElement.querySelector(TOOLBOX_OPENED_SELECTOR);
152
+
153
+ expect(editor).toBeInTheDocument();
154
+
155
+ // Verify popover items are rendered
156
+ const items = document.querySelectorAll(POPOVER_ITEM_TESTID);
157
+
158
+ expect(items.length).toBeGreaterThan(0);
159
+ },
160
+ TIMEOUT_ACTION
161
+ );
162
+ });
163
+ },
164
+ };
165
+
166
+
@@ -0,0 +1,198 @@
1
+ /**
2
+ * Tooltip.stories.ts - Stories for tooltip component states.
3
+ *
4
+ * This file covers tooltip positioning and visibility states:
5
+ * - Default (hidden)
6
+ * - Shown at bottom, top, left, right positions
7
+ */
8
+ import type { Meta, StoryObj } from '@storybook/html-vite';
9
+ import { waitFor, expect } from 'storybook/test';
10
+ import { hide, show } from '../components/utils/tooltip';
11
+
12
+ interface TooltipArgs {
13
+ placement: 'top' | 'bottom' | 'left' | 'right';
14
+ content: string;
15
+ delay: number;
16
+ }
17
+
18
+ const TIMEOUT_ACTION = { timeout: 5000 };
19
+ const TOOLTIP_TESTID = '[data-blok-testid="tooltip"]';
20
+
21
+ const createTooltipDemo = (_args: TooltipArgs): HTMLElement => {
22
+ const container = document.createElement('div');
23
+
24
+ container.style.display = 'flex';
25
+ container.style.alignItems = 'center';
26
+ container.style.justifyContent = 'center';
27
+ container.style.minHeight = '300px';
28
+ container.style.padding = '80px';
29
+ container.style.backgroundColor = '#fff';
30
+
31
+ const button = document.createElement('button');
32
+
33
+ button.textContent = 'Hover me for tooltip';
34
+ button.style.padding = '12px 24px';
35
+ button.style.fontSize = '14px';
36
+ button.style.borderRadius = '6px';
37
+ button.style.border = '1px solid #ddd';
38
+ button.style.cursor = 'pointer';
39
+ button.style.backgroundColor = '#f8f8f8';
40
+ button.setAttribute('data-blok-testid', 'tooltip-trigger');
41
+
42
+ container.appendChild(button);
43
+
44
+ return container;
45
+ };
46
+
47
+ const createAllStatesDemo = (): HTMLElement => {
48
+ const placements: TooltipArgs['placement'][] = ['bottom', 'top', 'left', 'right'];
49
+ const container = document.createElement('div');
50
+
51
+ container.style.display = 'grid';
52
+ container.style.gridTemplateColumns = 'repeat(auto-fit, minmax(180px, 1fr))';
53
+ container.style.gap = '32px';
54
+ container.style.alignItems = 'center';
55
+ container.style.justifyItems = 'center';
56
+ container.style.minHeight = '400px';
57
+ container.style.padding = '80px';
58
+ container.style.backgroundColor = '#fff';
59
+
60
+ const makeTrigger = (label: string, testId: string): HTMLButtonElement => {
61
+ const button = document.createElement('button');
62
+
63
+ button.textContent = label;
64
+ button.style.padding = '12px 24px';
65
+ button.style.fontSize = '14px';
66
+ button.style.borderRadius = '6px';
67
+ button.style.border = '1px solid #ddd';
68
+ button.style.cursor = 'pointer';
69
+ button.style.backgroundColor = '#f8f8f8';
70
+ button.setAttribute('data-blok-testid', testId);
71
+
72
+ return button;
73
+ };
74
+
75
+ const defaultTrigger = makeTrigger('Default (hidden)', 'tooltip-trigger-default');
76
+ const placementTriggers = placements.map((placement) =>
77
+ makeTrigger(`Shown ${placement}`, `tooltip-trigger-${placement}`)
78
+ );
79
+
80
+ container.appendChild(defaultTrigger);
81
+ placementTriggers.forEach((trigger) => container.appendChild(trigger));
82
+
83
+ return container;
84
+ };
85
+
86
+ const meta: Meta<TooltipArgs> = {
87
+ title: 'Components/Tooltip',
88
+ tags: ['autodocs'],
89
+ args: {
90
+ placement: 'bottom',
91
+ content: 'This is a tooltip',
92
+ delay: 0,
93
+ },
94
+ argTypes: {
95
+ placement: {
96
+ control: 'select',
97
+ options: ['top', 'bottom', 'left', 'right'],
98
+ description: 'Tooltip placement relative to trigger element',
99
+ },
100
+ content: {
101
+ control: 'text',
102
+ description: 'Tooltip content text',
103
+ },
104
+ delay: {
105
+ control: { type: 'number', min: 0, max: 1000, step: 50 },
106
+ description: 'Delay before showing tooltip (ms)',
107
+ },
108
+ },
109
+ render: createTooltipDemo,
110
+ };
111
+
112
+ export default meta;
113
+
114
+
115
+ type Story = StoryObj<TooltipArgs>;
116
+
117
+ export const TooltipStates: Story = {
118
+ args: {
119
+ placement: 'bottom',
120
+ content: 'This is a tooltip',
121
+ delay: 0,
122
+ },
123
+ render: createAllStatesDemo,
124
+ play: async ({ canvasElement, step }) => {
125
+ const placements: TooltipArgs['placement'][] = ['bottom', 'top', 'left', 'right'];
126
+ const triggerDefault = canvasElement.querySelector('[data-blok-testid="tooltip-trigger-default"]') as HTMLElement;
127
+
128
+ expect(triggerDefault).toBeInTheDocument();
129
+
130
+ const showAndClone = async (placement: TooltipArgs['placement']) => {
131
+ const trigger = canvasElement.querySelector(`[data-blok-testid="tooltip-trigger-${placement}"]`) as HTMLElement;
132
+
133
+ expect(trigger).toBeInTheDocument();
134
+
135
+ show(trigger, `Tooltip at ${placement}`, { placement, delay: 0 });
136
+
137
+ await waitFor(
138
+ () => {
139
+ const tooltip = document.querySelector(TOOLTIP_TESTID) as HTMLElement;
140
+
141
+ expect(tooltip).toBeInTheDocument();
142
+ expect(tooltip).toHaveAttribute('data-blok-shown', 'true');
143
+ expect(tooltip).toHaveAttribute('data-blok-placement', placement);
144
+ },
145
+ TIMEOUT_ACTION
146
+ );
147
+
148
+ const tooltip = document.querySelector(TOOLTIP_TESTID) as HTMLElement;
149
+ const clone = tooltip.cloneNode(true) as HTMLElement;
150
+
151
+ clone.setAttribute('data-blok-testid', `tooltip-${placement}`);
152
+ document.body.appendChild(clone);
153
+ };
154
+
155
+ await step('Show all placements', async () => {
156
+ for (const placement of placements) {
157
+ await showAndClone(placement);
158
+ }
159
+
160
+ hide();
161
+ });
162
+ },
163
+ };
164
+
165
+ /**
166
+ * Tooltip with HTML content.
167
+ */
168
+ export const WithHTMLContent: Story = {
169
+ args: {
170
+ placement: 'bottom',
171
+ content: '<strong>Bold</strong> tooltip',
172
+ delay: 0,
173
+ },
174
+ play: async ({ canvasElement, step }) => {
175
+ await step('Show tooltip with HTML content', async () => {
176
+ const trigger = canvasElement.querySelector('[data-blok-testid="tooltip-trigger"]') as HTMLElement;
177
+
178
+ expect(trigger).toBeInTheDocument();
179
+
180
+ if (trigger) {
181
+ const content = document.createElement('span');
182
+
183
+ content.innerHTML = '<strong>Bold</strong> and <em>italic</em>';
184
+ show(trigger, content, { placement: 'bottom', delay: 0 });
185
+ }
186
+
187
+ await waitFor(
188
+ () => {
189
+ const tooltip = document.querySelector(TOOLTIP_TESTID);
190
+
191
+ expect(tooltip).toBeInTheDocument();
192
+ expect(tooltip).toHaveAttribute('data-blok-shown', 'true');
193
+ },
194
+ TIMEOUT_ACTION
195
+ );
196
+ });
197
+ },
198
+ };