@jackuait/blok 0.4.1-beta.0 → 0.4.1-beta.11

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 (402) 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-oNSQ3HA6.mjs +13217 -0
  7. package/dist/chunks/i18next-CugVlwWp.mjs +1292 -0
  8. package/dist/chunks/i18next-loader-BdNRw4n4.mjs +43 -0
  9. package/dist/{index-OwEtDFlk.mjs → chunks/index-DHgXmfki.mjs} +2 -2
  10. package/dist/chunks/inline-tool-convert-CRqgjRim.mjs +1989 -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 +3117 -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 +141 -0
  248. package/src/components/inline-tools/inline-tool-italic.ts +500 -0
  249. package/src/components/inline-tools/inline-tool-link.ts +539 -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 +781 -0
  284. package/src/components/modules/toolbar/index.ts +1315 -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 +601 -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 +186 -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 +676 -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 +844 -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 +123 -0
  366. package/src/tools/header/index.ts +646 -0
  367. package/src/tools/index.ts +45 -0
  368. package/src/tools/list/index.ts +1819 -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/data-attributes.d.ts +170 -0
  386. package/types/data-formats/output-data.d.ts +15 -0
  387. package/types/full.d.ts +80 -0
  388. package/types/index.d.ts +30 -13
  389. package/types/locales.d.ts +59 -0
  390. package/types/tools/adapters/inline-tool-adapter.d.ts +10 -0
  391. package/types/tools/block-tool.d.ts +9 -0
  392. package/types/tools/header.d.ts +18 -0
  393. package/types/tools/index.d.ts +1 -0
  394. package/types/tools/list.d.ts +91 -0
  395. package/types/tools/paragraph.d.ts +71 -0
  396. package/types/tools/tool-settings.d.ts +92 -6
  397. package/types/tools/tool.d.ts +6 -0
  398. package/types/tools-entry.d.ts +49 -0
  399. package/types/utils/popover/popover-item.d.ts +18 -5
  400. package/types/utils/popover/popover.d.ts +7 -0
  401. package/dist/blok-D_baBvTG.mjs +0 -25795
  402. package/dist/blok.umd.js +0 -181
@@ -0,0 +1,392 @@
1
+ import { Dom as $ } from './dom';
2
+ import { LogLevels, isEmpty, isFunction, isObject, isString, log, setLogLevel } from './utils';
3
+ import type { BlokConfig, SanitizerConfig } from '../../types';
4
+ import type { BlokModules } from '../types-internal/blok-modules';
5
+ import { CriticalError } from './errors/critical';
6
+ import { EventsDispatcher } from './utils/events';
7
+ import { Modules } from './modules';
8
+ import type { BlokEventMap } from './events';
9
+ import type { Renderer } from './modules/renderer';
10
+
11
+ /**
12
+ * Blok core class. Bootstraps modules.
13
+ */
14
+ export class Core {
15
+ /**
16
+ * Blok configuration passed by user to the constructor
17
+ */
18
+ public config: BlokConfig;
19
+
20
+ /**
21
+ * Object with core modules instances
22
+ */
23
+ public moduleInstances: BlokModules = {} as BlokModules;
24
+
25
+ /**
26
+ * Promise that resolves when all core modules are prepared and UI is rendered on the page
27
+ */
28
+ public isReady: Promise<void>;
29
+
30
+ /**
31
+ * Common Blok Event Bus
32
+ */
33
+ private eventsDispatcher: EventsDispatcher<BlokEventMap> = new EventsDispatcher();
34
+
35
+ /**
36
+ * @param {BlokConfig} config - user configuration
37
+ */
38
+ constructor(config?: BlokConfig|string) {
39
+ /**
40
+ * Ready promise. Resolved if Blok is ready to work, rejected otherwise
41
+ */
42
+ // Initialize config to satisfy TypeScript's definite assignment check
43
+ // The setter will properly assign and process the config
44
+ this.config = {};
45
+
46
+ this.isReady = new Promise((resolve, reject) => {
47
+ Promise.resolve()
48
+ .then(async () => {
49
+ this.configuration = config;
50
+ this.validate();
51
+ this.init();
52
+ await this.start();
53
+ await this.render();
54
+
55
+ const { BlockManager, Caret, UI, ModificationsObserver, History } = this.moduleInstances;
56
+
57
+ UI.checkEmptiness();
58
+ ModificationsObserver.enable();
59
+
60
+ // Capture initial state for undo/redo after rendering
61
+ await History.captureInitialState();
62
+
63
+ if ((this.configuration as BlokConfig).autofocus === true && this.configuration.readOnly !== true) {
64
+ Caret.setToBlock(BlockManager.blocks[0], Caret.positions.START);
65
+ }
66
+
67
+ resolve();
68
+ })
69
+ .catch((error) => {
70
+ log(`Blok is not ready because of ${error}`, 'error');
71
+
72
+ /**
73
+ * Reject this.isReady promise
74
+ */
75
+ reject(error);
76
+ });
77
+ });
78
+ }
79
+
80
+ /**
81
+ * Setting for configuration
82
+ * @param {BlokConfig|string|undefined} config - Blok's config to set
83
+ */
84
+ public set configuration(config: BlokConfig|string|undefined) {
85
+ /**
86
+ * Place config into the class property
87
+ * @type {BlokConfig}
88
+ */
89
+ if (isObject(config)) {
90
+ this.config = {
91
+ ...config,
92
+ };
93
+ } else {
94
+ /**
95
+ * Process zero-configuration or with only holder
96
+ * Make config object
97
+ */
98
+ this.config = {
99
+ holder: config,
100
+ };
101
+ }
102
+
103
+ /**
104
+ * If holder is empty then set a default value
105
+ */
106
+ if (this.config.holder == null) {
107
+ this.config.holder = 'blok';
108
+ }
109
+
110
+ if (this.config.logLevel == null) {
111
+ this.config.logLevel = LogLevels.VERBOSE;
112
+ }
113
+
114
+ setLogLevel(this.config.logLevel);
115
+
116
+ /**
117
+ * If default Block's Tool was not passed, use the Paragraph Tool
118
+ */
119
+ this.config.defaultBlock = this.config.defaultBlock ?? 'paragraph';
120
+
121
+ const toolsConfig = this.config.tools;
122
+ const defaultBlockName = this.config.defaultBlock;
123
+ const hasDefaultBlockTool = toolsConfig != null &&
124
+ Object.prototype.hasOwnProperty.call(toolsConfig, defaultBlockName ?? '');
125
+ const initialBlocks = this.config.data?.blocks;
126
+ const hasInitialBlocks = Array.isArray(initialBlocks) && initialBlocks.length > 0;
127
+
128
+ if (
129
+ defaultBlockName &&
130
+ defaultBlockName !== 'paragraph' &&
131
+ !hasDefaultBlockTool &&
132
+ !hasInitialBlocks
133
+ ) {
134
+ log(
135
+ `Default block "${defaultBlockName}" is not configured. Falling back to "paragraph" tool.`,
136
+ 'warn'
137
+ );
138
+
139
+ this.config.defaultBlock = 'paragraph';
140
+
141
+ const existingTools = this.config.tools as Record<string, unknown> | undefined;
142
+ const updatedTools: Record<string, unknown> = {
143
+ ...(existingTools ?? {}),
144
+ };
145
+ const paragraphEntry = updatedTools.paragraph;
146
+
147
+ updatedTools.paragraph = this.createParagraphToolConfig(paragraphEntry);
148
+
149
+ this.config.tools = updatedTools as BlokConfig['tools'];
150
+ }
151
+
152
+ /**
153
+ * Height of Blok's bottom area that allows to set focus on the last Block
154
+ * @type {number}
155
+ */
156
+
157
+ this.config.minHeight = this.config.minHeight !== undefined ? this.config.minHeight : 300;
158
+
159
+ /**
160
+ * Default block type
161
+ * Uses in case when there is no blocks passed
162
+ * @type {{type: (*), data: {text: null}}}
163
+ */
164
+ const defaultBlockData = {
165
+ type: this.config.defaultBlock,
166
+ data: {},
167
+ };
168
+
169
+ if (this.config.placeholder === undefined) {
170
+ this.config.placeholder = false;
171
+ }
172
+ this.config.sanitizer = this.config.sanitizer ?? {} as SanitizerConfig;
173
+
174
+ this.config.hideToolbar = this.config.hideToolbar ?? false;
175
+ this.config.tools = this.config.tools || {};
176
+ this.config.i18n = this.config.i18n || {};
177
+ this.config.data = this.config.data || { blocks: [] };
178
+
179
+ this.config.onReady = this.config.onReady || ((): void => {});
180
+
181
+ this.config.onChange = this.config.onChange || ((): void => {});
182
+ this.config.inlineToolbar = this.config.inlineToolbar !== undefined ? this.config.inlineToolbar : true;
183
+
184
+ /**
185
+ * Initialize default Block to pass data to the Renderer
186
+ */
187
+ if (isEmpty(this.config.data) || !this.config.data.blocks || this.config.data.blocks.length === 0) {
188
+ this.config.data = { blocks: [ defaultBlockData ] };
189
+ }
190
+
191
+ this.config.readOnly = this.config.readOnly as boolean || false;
192
+ }
193
+
194
+ /**
195
+ * Returns private property
196
+ * @returns {BlokConfig}
197
+ */
198
+ public get configuration(): BlokConfig {
199
+ return this.config;
200
+ }
201
+
202
+ /**
203
+ * Checks for required fields in Blok's config
204
+ */
205
+ public validate(): void {
206
+ const { holder } = this.config;
207
+
208
+ /**
209
+ * Check for a holder element's existence
210
+ */
211
+ if (isString(holder) && !$.get(holder)) {
212
+ throw Error(`element with ID «${holder}» is missing. Pass correct holder's ID.`);
213
+ }
214
+
215
+ if (Boolean(holder) && isObject(holder) && !$.isElement(holder)) {
216
+ throw Error('«holder» value must be an Element node');
217
+ }
218
+ }
219
+
220
+ /**
221
+ * Initializes modules:
222
+ * - make and save instances
223
+ * - configure
224
+ */
225
+ public init(): void {
226
+ /**
227
+ * Make modules instances and save it to the @property this.moduleInstances
228
+ */
229
+ this.constructModules();
230
+
231
+ /**
232
+ * Modules configuration
233
+ */
234
+ this.configureModules();
235
+ }
236
+
237
+ /**
238
+ * Start Blok!
239
+ *
240
+ * Get list of modules that needs to be prepared and return a sequence (Promise)
241
+ * @returns {Promise<void>}
242
+ */
243
+ public async start(): Promise<void> {
244
+ const modulesToPrepare = [
245
+ 'I18n',
246
+ 'Tools',
247
+ 'UI',
248
+ 'BlockManager',
249
+ 'Paste',
250
+ 'BlockSelection',
251
+ 'RectangleSelection',
252
+ 'CrossBlockSelection',
253
+ 'ReadOnly',
254
+ 'History',
255
+ ];
256
+
257
+ await modulesToPrepare.reduce(
258
+ (promise, module) => promise.then(async () => {
259
+ // log(`Preparing ${module} module`, 'time');
260
+
261
+ try {
262
+ const moduleInstance = this.moduleInstances[module as keyof BlokModules] as { prepare: () => Promise<void> | void };
263
+
264
+ await moduleInstance.prepare();
265
+ } catch (e) {
266
+ /**
267
+ * CriticalError's will not be caught
268
+ * It is used when Blok is rendering in read-only mode with unsupported plugin
269
+ */
270
+ if (e instanceof CriticalError) {
271
+ throw new Error(e.message);
272
+ }
273
+ log(`Module ${module} was skipped because of %o`, 'warn', e);
274
+ }
275
+ // log(`Preparing ${module} module`, 'timeEnd');
276
+ }),
277
+ Promise.resolve()
278
+ );
279
+ }
280
+
281
+ /**
282
+ * Render initial data
283
+ */
284
+ private render(): Promise<void> {
285
+ const renderer = this.moduleInstances['Renderer' as keyof BlokModules] as Renderer | undefined;
286
+
287
+ if (!renderer) {
288
+ throw new CriticalError('Renderer module is not initialized');
289
+ }
290
+
291
+ if (!this.config.data) {
292
+ throw new CriticalError('Blok data is not initialized');
293
+ }
294
+
295
+ return renderer.render(this.config.data.blocks);
296
+ }
297
+
298
+ /**
299
+ * Make modules instances and save it to the @property this.moduleInstances
300
+ */
301
+ private constructModules(): void {
302
+ Object.entries(Modules).forEach(([key, module]) => {
303
+ try {
304
+ (this.moduleInstances as unknown as Record<string, BlokModules[keyof BlokModules]>)[key] = new module({
305
+ config: this.configuration,
306
+ eventsDispatcher: this.eventsDispatcher,
307
+ }) as BlokModules[keyof BlokModules];
308
+ } catch (e) {
309
+ log(`[constructModules] Module ${key} skipped because`, 'error', e);
310
+ }
311
+ });
312
+ }
313
+
314
+ /**
315
+ * Modules instances configuration:
316
+ * - pass other modules to the 'state' property
317
+ * - ...
318
+ */
319
+ private configureModules(): void {
320
+ for (const name in this.moduleInstances) {
321
+ if (Object.prototype.hasOwnProperty.call(this.moduleInstances, name)) {
322
+ /**
323
+ * Module does not need self-instance
324
+ */
325
+ this.moduleInstances[name as keyof BlokModules].state = this.getModulesDiff(name);
326
+ }
327
+ }
328
+ }
329
+
330
+ /**
331
+ * Creates paragraph tool configuration with preserveBlank setting
332
+ * @param {unknown} paragraphEntry - existing paragraph entry from tools config
333
+ * @returns {Record<string, unknown>} paragraph tool configuration
334
+ */
335
+ private createParagraphToolConfig(paragraphEntry: unknown): Record<string, unknown> {
336
+ if (paragraphEntry === undefined) {
337
+ return {
338
+ config: {
339
+ preserveBlank: true,
340
+ },
341
+ };
342
+ }
343
+
344
+ if (isFunction(paragraphEntry)) {
345
+ return {
346
+ class: paragraphEntry,
347
+ config: {
348
+ preserveBlank: true,
349
+ },
350
+ };
351
+ }
352
+
353
+ if (isObject(paragraphEntry)) {
354
+ const paragraphSettings = paragraphEntry as Record<string, unknown>;
355
+ const existingConfig = paragraphSettings.config;
356
+
357
+ return {
358
+ ...paragraphSettings,
359
+ config: {
360
+ ...(isObject(existingConfig) ? existingConfig as Record<string, unknown> : {}),
361
+ preserveBlank: true,
362
+ },
363
+ };
364
+ }
365
+
366
+ return {
367
+ config: {
368
+ preserveBlank: true,
369
+ },
370
+ };
371
+ }
372
+
373
+ /**
374
+ * Return modules without passed name
375
+ * @param {string} name - module for witch modules difference should be calculated
376
+ */
377
+ private getModulesDiff(name: string): BlokModules {
378
+ const diff = {} as BlokModules;
379
+
380
+ for (const moduleName in this.moduleInstances) {
381
+ /**
382
+ * Skip module with passed name
383
+ */
384
+ if (moduleName === name) {
385
+ continue;
386
+ }
387
+ (diff as unknown as Record<string, BlokModules[keyof BlokModules]>)[moduleName] = this.moduleInstances[moduleName as keyof BlokModules] as BlokModules[keyof BlokModules];
388
+ }
389
+
390
+ return diff;
391
+ }
392
+ }