create-nextjs-cms 0.5.19 → 0.5.20

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 (272) hide show
  1. package/dist/index.js +7 -0
  2. package/package.json +4 -4
  3. package/templates/default/.uploads/.photos/categories/000e56fada378de1a84a4 +0 -0
  4. package/templates/default/.uploads/.photos/categories/121e7d13ee3b5fa03795b +0 -0
  5. package/templates/default/.uploads/.photos/categories/17a55c5a53eb62293c69e +0 -0
  6. package/templates/default/.uploads/.photos/categories/4c86ad8c1f51f1e3a953b +0 -0
  7. package/templates/default/.uploads/.photos/categories/4d360813741a45744327c +0 -0
  8. package/templates/default/.uploads/.photos/categories/5238fefaa3cbebf388178 +0 -0
  9. package/templates/default/.uploads/.photos/categories/541d7cf8c69895bcb15cd +0 -0
  10. package/templates/default/.uploads/.photos/categories/57a2f689a910a378247ea +0 -0
  11. package/templates/default/.uploads/.photos/categories/6de4bdb341a3e1f70ddc3 +0 -0
  12. package/templates/default/.uploads/.photos/categories/6f52739eaa686441a28f4 +0 -0
  13. package/templates/default/.uploads/.photos/categories/8a21b9fa8ecd88f460a15 +0 -0
  14. package/templates/default/.uploads/.photos/categories/91948abcb073c9445fdec +0 -0
  15. package/templates/default/.uploads/.photos/categories/9ae700d1abfd6b85780e8 +0 -0
  16. package/templates/default/.uploads/.photos/categories/9edee86e932985fc589b5 +0 -0
  17. package/templates/default/.uploads/.photos/categories/a520e77b082f35b575dba +0 -0
  18. package/templates/default/.uploads/.photos/categories/b19c449029330f0a74b20 +0 -0
  19. package/templates/default/.uploads/.photos/categories/b9802010f68afd4edb0e8 +0 -0
  20. package/templates/default/.uploads/.photos/categories/c1d7c3b986739bf496730 +0 -0
  21. package/templates/default/.uploads/.photos/categories/c25dc38567384513ffe93 +0 -0
  22. package/templates/default/.uploads/.photos/categories/cbe3874a3d13afba388df +0 -0
  23. package/templates/default/.uploads/.photos/categories/d450fdeb04f0d070442d6 +0 -0
  24. package/templates/default/.uploads/.photos/categories/f80bf3a4515680ead5a5c +0 -0
  25. package/templates/default/.uploads/.photos/categories/f8639c2d5b0d24cb76fb1 +0 -0
  26. package/templates/default/.uploads/.photos/categories/f8d997149d10aab046e40 +0 -0
  27. package/templates/default/.uploads/.photos/categories/fa2c55690ff96e33a16fe +0 -0
  28. package/templates/default/.uploads/.photos/featured_slider/d00be4edb4c38ca34b5a5 +0 -0
  29. package/templates/default/.uploads/.thumbs/categories/000e56fada378de1a84a4 +0 -0
  30. package/templates/default/.uploads/.thumbs/categories/121e7d13ee3b5fa03795b +0 -0
  31. package/templates/default/.uploads/.thumbs/categories/17a55c5a53eb62293c69e +0 -0
  32. package/templates/default/.uploads/.thumbs/categories/4c86ad8c1f51f1e3a953b +0 -0
  33. package/templates/default/.uploads/.thumbs/categories/4d360813741a45744327c +0 -0
  34. package/templates/default/.uploads/.thumbs/categories/5238fefaa3cbebf388178 +0 -0
  35. package/templates/default/.uploads/.thumbs/categories/541d7cf8c69895bcb15cd +0 -0
  36. package/templates/default/.uploads/.thumbs/categories/57a2f689a910a378247ea +0 -0
  37. package/templates/default/.uploads/.thumbs/categories/6de4bdb341a3e1f70ddc3 +0 -0
  38. package/templates/default/.uploads/.thumbs/categories/6f52739eaa686441a28f4 +0 -0
  39. package/templates/default/.uploads/.thumbs/categories/8a21b9fa8ecd88f460a15 +0 -0
  40. package/templates/default/.uploads/.thumbs/categories/91948abcb073c9445fdec +0 -0
  41. package/templates/default/.uploads/.thumbs/categories/9ae700d1abfd6b85780e8 +0 -0
  42. package/templates/default/.uploads/.thumbs/categories/9edee86e932985fc589b5 +0 -0
  43. package/templates/default/.uploads/.thumbs/categories/a520e77b082f35b575dba +0 -0
  44. package/templates/default/.uploads/.thumbs/categories/b19c449029330f0a74b20 +0 -0
  45. package/templates/default/.uploads/.thumbs/categories/b9802010f68afd4edb0e8 +0 -0
  46. package/templates/default/.uploads/.thumbs/categories/c1d7c3b986739bf496730 +0 -0
  47. package/templates/default/.uploads/.thumbs/categories/c25dc38567384513ffe93 +0 -0
  48. package/templates/default/.uploads/.thumbs/categories/cbe3874a3d13afba388df +0 -0
  49. package/templates/default/.uploads/.thumbs/categories/d450fdeb04f0d070442d6 +0 -0
  50. package/templates/default/.uploads/.thumbs/categories/f80bf3a4515680ead5a5c +0 -0
  51. package/templates/default/.uploads/.thumbs/categories/f8639c2d5b0d24cb76fb1 +0 -0
  52. package/templates/default/.uploads/.thumbs/categories/f8d997149d10aab046e40 +0 -0
  53. package/templates/default/.uploads/.thumbs/categories/fa2c55690ff96e33a16fe +0 -0
  54. package/templates/default/_gitignore +57 -0
  55. package/templates/default/components/form/helpers/_section-hot-reload.ts +11 -0
  56. package/templates/default/next-env.d.ts +6 -0
  57. package/templates/default/package.json +2 -2
  58. package/templates/default/public/tinymce/CHANGELOG.md +3785 -0
  59. package/templates/default/public/tinymce/README.md +77 -0
  60. package/templates/default/public/tinymce/bower.json +27 -0
  61. package/templates/default/public/tinymce/composer.json +52 -0
  62. package/templates/default/public/tinymce/icons/default/icons.js +231 -0
  63. package/templates/default/public/tinymce/icons/default/icons.min.js +1 -0
  64. package/templates/default/public/tinymce/icons/default/index.js +7 -0
  65. package/templates/default/public/tinymce/license.md +6 -0
  66. package/templates/default/public/tinymce/models/dom/index.js +7 -0
  67. package/templates/default/public/tinymce/models/dom/model.js +8994 -0
  68. package/templates/default/public/tinymce/models/dom/model.min.js +1 -0
  69. package/templates/default/public/tinymce/notices.txt +21 -0
  70. package/templates/default/public/tinymce/package.json +32 -0
  71. package/templates/default/public/tinymce/plugins/accordion/index.js +7 -0
  72. package/templates/default/public/tinymce/plugins/accordion/plugin.js +1349 -0
  73. package/templates/default/public/tinymce/plugins/accordion/plugin.min.js +1 -0
  74. package/templates/default/public/tinymce/plugins/advlist/index.js +7 -0
  75. package/templates/default/public/tinymce/plugins/advlist/plugin.js +471 -0
  76. package/templates/default/public/tinymce/plugins/advlist/plugin.min.js +1 -0
  77. package/templates/default/public/tinymce/plugins/anchor/index.js +7 -0
  78. package/templates/default/public/tinymce/plugins/anchor/plugin.js +237 -0
  79. package/templates/default/public/tinymce/plugins/anchor/plugin.min.js +1 -0
  80. package/templates/default/public/tinymce/plugins/autolink/index.js +7 -0
  81. package/templates/default/public/tinymce/plugins/autolink/plugin.js +318 -0
  82. package/templates/default/public/tinymce/plugins/autolink/plugin.min.js +1 -0
  83. package/templates/default/public/tinymce/plugins/autoresize/index.js +7 -0
  84. package/templates/default/public/tinymce/plugins/autoresize/plugin.js +223 -0
  85. package/templates/default/public/tinymce/plugins/autoresize/plugin.min.js +1 -0
  86. package/templates/default/public/tinymce/plugins/autosave/index.js +7 -0
  87. package/templates/default/public/tinymce/plugins/autosave/plugin.js +252 -0
  88. package/templates/default/public/tinymce/plugins/autosave/plugin.min.js +1 -0
  89. package/templates/default/public/tinymce/plugins/charmap/index.js +7 -0
  90. package/templates/default/public/tinymce/plugins/charmap/plugin.js +997 -0
  91. package/templates/default/public/tinymce/plugins/charmap/plugin.min.js +1 -0
  92. package/templates/default/public/tinymce/plugins/code/index.js +7 -0
  93. package/templates/default/public/tinymce/plugins/code/plugin.js +97 -0
  94. package/templates/default/public/tinymce/plugins/code/plugin.min.js +1 -0
  95. package/templates/default/public/tinymce/plugins/codesample/index.js +7 -0
  96. package/templates/default/public/tinymce/plugins/codesample/plugin.js +3654 -0
  97. package/templates/default/public/tinymce/plugins/codesample/plugin.min.js +9 -0
  98. package/templates/default/public/tinymce/plugins/directionality/index.js +7 -0
  99. package/templates/default/public/tinymce/plugins/directionality/plugin.js +636 -0
  100. package/templates/default/public/tinymce/plugins/directionality/plugin.min.js +1 -0
  101. package/templates/default/public/tinymce/plugins/emoticons/index.js +7 -0
  102. package/templates/default/public/tinymce/plugins/emoticons/js/emojiimages.js +1 -0
  103. package/templates/default/public/tinymce/plugins/emoticons/js/emojiimages.min.js +1 -0
  104. package/templates/default/public/tinymce/plugins/emoticons/js/emojis.js +1 -0
  105. package/templates/default/public/tinymce/plugins/emoticons/js/emojis.min.js +1 -0
  106. package/templates/default/public/tinymce/plugins/emoticons/plugin.js +809 -0
  107. package/templates/default/public/tinymce/plugins/emoticons/plugin.min.js +1 -0
  108. package/templates/default/public/tinymce/plugins/fullscreen/index.js +7 -0
  109. package/templates/default/public/tinymce/plugins/fullscreen/plugin.js +1609 -0
  110. package/templates/default/public/tinymce/plugins/fullscreen/plugin.min.js +1 -0
  111. package/templates/default/public/tinymce/plugins/help/index.js +7 -0
  112. package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/ar.js +93 -0
  113. package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/bg_BG.js +93 -0
  114. package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/ca.js +93 -0
  115. package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/cs.js +93 -0
  116. package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/da.js +93 -0
  117. package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/de.js +93 -0
  118. package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/el.js +93 -0
  119. package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/en.js +93 -0
  120. package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/es.js +93 -0
  121. package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/eu.js +93 -0
  122. package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/fa.js +93 -0
  123. package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/fi.js +93 -0
  124. package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/fr_FR.js +93 -0
  125. package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/he_IL.js +93 -0
  126. package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/hi.js +93 -0
  127. package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/hr.js +93 -0
  128. package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/hu_HU.js +93 -0
  129. package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/id.js +93 -0
  130. package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/it.js +93 -0
  131. package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/ja.js +93 -0
  132. package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/kk.js +93 -0
  133. package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/ko_KR.js +93 -0
  134. package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/ms.js +93 -0
  135. package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/nb_NO.js +93 -0
  136. package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/nl.js +93 -0
  137. package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/pl.js +93 -0
  138. package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/pt_BR.js +93 -0
  139. package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/pt_PT.js +93 -0
  140. package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/ro.js +93 -0
  141. package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/ru.js +93 -0
  142. package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/sk.js +93 -0
  143. package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/sl_SI.js +93 -0
  144. package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/sv_SE.js +93 -0
  145. package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/th_TH.js +93 -0
  146. package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/tr.js +93 -0
  147. package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/uk.js +93 -0
  148. package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/vi.js +93 -0
  149. package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/zh_CN.js +87 -0
  150. package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/zh_TW.js +93 -0
  151. package/templates/default/public/tinymce/plugins/help/plugin.js +828 -0
  152. package/templates/default/public/tinymce/plugins/help/plugin.min.js +1 -0
  153. package/templates/default/public/tinymce/plugins/image/index.js +7 -0
  154. package/templates/default/public/tinymce/plugins/image/plugin.js +1689 -0
  155. package/templates/default/public/tinymce/plugins/image/plugin.min.js +1 -0
  156. package/templates/default/public/tinymce/plugins/importcss/index.js +7 -0
  157. package/templates/default/public/tinymce/plugins/importcss/plugin.js +403 -0
  158. package/templates/default/public/tinymce/plugins/importcss/plugin.min.js +1 -0
  159. package/templates/default/public/tinymce/plugins/insertdatetime/index.js +7 -0
  160. package/templates/default/public/tinymce/plugins/insertdatetime/plugin.js +186 -0
  161. package/templates/default/public/tinymce/plugins/insertdatetime/plugin.min.js +1 -0
  162. package/templates/default/public/tinymce/plugins/link/index.js +7 -0
  163. package/templates/default/public/tinymce/plugins/link/plugin.js +1577 -0
  164. package/templates/default/public/tinymce/plugins/link/plugin.min.js +1 -0
  165. package/templates/default/public/tinymce/plugins/lists/index.js +7 -0
  166. package/templates/default/public/tinymce/plugins/lists/plugin.js +2544 -0
  167. package/templates/default/public/tinymce/plugins/lists/plugin.min.js +1 -0
  168. package/templates/default/public/tinymce/plugins/media/index.js +7 -0
  169. package/templates/default/public/tinymce/plugins/media/plugin.js +1450 -0
  170. package/templates/default/public/tinymce/plugins/media/plugin.min.js +1 -0
  171. package/templates/default/public/tinymce/plugins/nonbreaking/index.js +7 -0
  172. package/templates/default/public/tinymce/plugins/nonbreaking/plugin.js +128 -0
  173. package/templates/default/public/tinymce/plugins/nonbreaking/plugin.min.js +1 -0
  174. package/templates/default/public/tinymce/plugins/pagebreak/index.js +7 -0
  175. package/templates/default/public/tinymce/plugins/pagebreak/plugin.js +123 -0
  176. package/templates/default/public/tinymce/plugins/pagebreak/plugin.min.js +1 -0
  177. package/templates/default/public/tinymce/plugins/preview/index.js +7 -0
  178. package/templates/default/public/tinymce/plugins/preview/plugin.js +765 -0
  179. package/templates/default/public/tinymce/plugins/preview/plugin.min.js +1 -0
  180. package/templates/default/public/tinymce/plugins/quickbars/index.js +7 -0
  181. package/templates/default/public/tinymce/plugins/quickbars/plugin.js +654 -0
  182. package/templates/default/public/tinymce/plugins/quickbars/plugin.min.js +1 -0
  183. package/templates/default/public/tinymce/plugins/save/index.js +7 -0
  184. package/templates/default/public/tinymce/plugins/save/plugin.js +136 -0
  185. package/templates/default/public/tinymce/plugins/save/plugin.min.js +1 -0
  186. package/templates/default/public/tinymce/plugins/searchreplace/index.js +7 -0
  187. package/templates/default/public/tinymce/plugins/searchreplace/plugin.js +1370 -0
  188. package/templates/default/public/tinymce/plugins/searchreplace/plugin.min.js +1 -0
  189. package/templates/default/public/tinymce/plugins/table/index.js +7 -0
  190. package/templates/default/public/tinymce/plugins/table/plugin.js +4019 -0
  191. package/templates/default/public/tinymce/plugins/table/plugin.min.js +1 -0
  192. package/templates/default/public/tinymce/plugins/visualblocks/index.js +7 -0
  193. package/templates/default/public/tinymce/plugins/visualblocks/plugin.js +106 -0
  194. package/templates/default/public/tinymce/plugins/visualblocks/plugin.min.js +1 -0
  195. package/templates/default/public/tinymce/plugins/visualchars/index.js +7 -0
  196. package/templates/default/public/tinymce/plugins/visualchars/plugin.js +809 -0
  197. package/templates/default/public/tinymce/plugins/visualchars/plugin.min.js +1 -0
  198. package/templates/default/public/tinymce/plugins/wordcount/index.js +7 -0
  199. package/templates/default/public/tinymce/plugins/wordcount/plugin.js +480 -0
  200. package/templates/default/public/tinymce/plugins/wordcount/plugin.min.js +1 -0
  201. package/templates/default/public/tinymce/skins/content/dark/content.css +75 -0
  202. package/templates/default/public/tinymce/skins/content/dark/content.js +10 -0
  203. package/templates/default/public/tinymce/skins/content/dark/content.min.css +10 -0
  204. package/templates/default/public/tinymce/skins/content/default/content.css +70 -0
  205. package/templates/default/public/tinymce/skins/content/default/content.js +10 -0
  206. package/templates/default/public/tinymce/skins/content/default/content.min.css +10 -0
  207. package/templates/default/public/tinymce/skins/content/document/content.css +75 -0
  208. package/templates/default/public/tinymce/skins/content/document/content.js +10 -0
  209. package/templates/default/public/tinymce/skins/content/document/content.min.css +10 -0
  210. package/templates/default/public/tinymce/skins/content/tinymce-5/content.css +70 -0
  211. package/templates/default/public/tinymce/skins/content/tinymce-5/content.js +10 -0
  212. package/templates/default/public/tinymce/skins/content/tinymce-5/content.min.css +10 -0
  213. package/templates/default/public/tinymce/skins/content/tinymce-5-dark/content.css +75 -0
  214. package/templates/default/public/tinymce/skins/content/tinymce-5-dark/content.js +10 -0
  215. package/templates/default/public/tinymce/skins/content/tinymce-5-dark/content.min.css +10 -0
  216. package/templates/default/public/tinymce/skins/content/writer/content.css +71 -0
  217. package/templates/default/public/tinymce/skins/content/writer/content.js +10 -0
  218. package/templates/default/public/tinymce/skins/content/writer/content.min.css +10 -0
  219. package/templates/default/public/tinymce/skins/ui/oxide/content.css +893 -0
  220. package/templates/default/public/tinymce/skins/ui/oxide/content.inline.css +887 -0
  221. package/templates/default/public/tinymce/skins/ui/oxide/content.inline.js +10 -0
  222. package/templates/default/public/tinymce/skins/ui/oxide/content.inline.min.css +10 -0
  223. package/templates/default/public/tinymce/skins/ui/oxide/content.js +10 -0
  224. package/templates/default/public/tinymce/skins/ui/oxide/content.min.css +10 -0
  225. package/templates/default/public/tinymce/skins/ui/oxide/skin.css +5141 -0
  226. package/templates/default/public/tinymce/skins/ui/oxide/skin.js +1 -0
  227. package/templates/default/public/tinymce/skins/ui/oxide/skin.min.css +1 -0
  228. package/templates/default/public/tinymce/skins/ui/oxide/skin.shadowdom.css +30 -0
  229. package/templates/default/public/tinymce/skins/ui/oxide/skin.shadowdom.js +1 -0
  230. package/templates/default/public/tinymce/skins/ui/oxide/skin.shadowdom.min.css +1 -0
  231. package/templates/default/public/tinymce/skins/ui/oxide-dark/content.css +881 -0
  232. package/templates/default/public/tinymce/skins/ui/oxide-dark/content.inline.css +887 -0
  233. package/templates/default/public/tinymce/skins/ui/oxide-dark/content.inline.js +10 -0
  234. package/templates/default/public/tinymce/skins/ui/oxide-dark/content.inline.min.css +10 -0
  235. package/templates/default/public/tinymce/skins/ui/oxide-dark/content.js +10 -0
  236. package/templates/default/public/tinymce/skins/ui/oxide-dark/content.min.css +10 -0
  237. package/templates/default/public/tinymce/skins/ui/oxide-dark/skin.css +5144 -0
  238. package/templates/default/public/tinymce/skins/ui/oxide-dark/skin.js +1 -0
  239. package/templates/default/public/tinymce/skins/ui/oxide-dark/skin.min.css +1 -0
  240. package/templates/default/public/tinymce/skins/ui/oxide-dark/skin.shadowdom.css +30 -0
  241. package/templates/default/public/tinymce/skins/ui/oxide-dark/skin.shadowdom.js +1 -0
  242. package/templates/default/public/tinymce/skins/ui/oxide-dark/skin.shadowdom.min.css +1 -0
  243. package/templates/default/public/tinymce/skins/ui/tinymce-5/content.css +893 -0
  244. package/templates/default/public/tinymce/skins/ui/tinymce-5/content.inline.css +887 -0
  245. package/templates/default/public/tinymce/skins/ui/tinymce-5/content.inline.js +10 -0
  246. package/templates/default/public/tinymce/skins/ui/tinymce-5/content.inline.min.css +10 -0
  247. package/templates/default/public/tinymce/skins/ui/tinymce-5/content.js +10 -0
  248. package/templates/default/public/tinymce/skins/ui/tinymce-5/content.min.css +10 -0
  249. package/templates/default/public/tinymce/skins/ui/tinymce-5/skin.css +5260 -0
  250. package/templates/default/public/tinymce/skins/ui/tinymce-5/skin.js +1 -0
  251. package/templates/default/public/tinymce/skins/ui/tinymce-5/skin.min.css +1 -0
  252. package/templates/default/public/tinymce/skins/ui/tinymce-5/skin.shadowdom.css +30 -0
  253. package/templates/default/public/tinymce/skins/ui/tinymce-5/skin.shadowdom.js +1 -0
  254. package/templates/default/public/tinymce/skins/ui/tinymce-5/skin.shadowdom.min.css +1 -0
  255. package/templates/default/public/tinymce/skins/ui/tinymce-5-dark/content.css +881 -0
  256. package/templates/default/public/tinymce/skins/ui/tinymce-5-dark/content.inline.css +887 -0
  257. package/templates/default/public/tinymce/skins/ui/tinymce-5-dark/content.inline.js +10 -0
  258. package/templates/default/public/tinymce/skins/ui/tinymce-5-dark/content.inline.min.css +10 -0
  259. package/templates/default/public/tinymce/skins/ui/tinymce-5-dark/content.js +10 -0
  260. package/templates/default/public/tinymce/skins/ui/tinymce-5-dark/content.min.css +10 -0
  261. package/templates/default/public/tinymce/skins/ui/tinymce-5-dark/skin.css +5260 -0
  262. package/templates/default/public/tinymce/skins/ui/tinymce-5-dark/skin.js +1 -0
  263. package/templates/default/public/tinymce/skins/ui/tinymce-5-dark/skin.min.css +1 -0
  264. package/templates/default/public/tinymce/skins/ui/tinymce-5-dark/skin.shadowdom.css +30 -0
  265. package/templates/default/public/tinymce/skins/ui/tinymce-5-dark/skin.shadowdom.js +1 -0
  266. package/templates/default/public/tinymce/skins/ui/tinymce-5-dark/skin.shadowdom.min.css +1 -0
  267. package/templates/default/public/tinymce/themes/silver/index.js +7 -0
  268. package/templates/default/public/tinymce/themes/silver/theme.js +34798 -0
  269. package/templates/default/public/tinymce/themes/silver/theme.min.js +1 -0
  270. package/templates/default/public/tinymce/tinymce.d.ts +3350 -0
  271. package/templates/default/public/tinymce/tinymce.js +38694 -0
  272. package/templates/default/public/tinymce/tinymce.min.js +11 -0
@@ -0,0 +1,809 @@
1
+ /**
2
+ * TinyMCE version 7.9.1 (2025-05-29)
3
+ */
4
+
5
+ (function () {
6
+ 'use strict';
7
+
8
+ /* eslint-disable @typescript-eslint/no-wrapper-object-types */
9
+ const hasProto = (v, constructor, predicate) => {
10
+ var _a;
11
+ if (predicate(v, constructor.prototype)) {
12
+ return true;
13
+ }
14
+ else {
15
+ // String-based fallback time
16
+ return ((_a = v.constructor) === null || _a === void 0 ? void 0 : _a.name) === constructor.name;
17
+ }
18
+ };
19
+ const typeOf = (x) => {
20
+ const t = typeof x;
21
+ if (x === null) {
22
+ return 'null';
23
+ }
24
+ else if (t === 'object' && Array.isArray(x)) {
25
+ return 'array';
26
+ }
27
+ else if (t === 'object' && hasProto(x, String, (o, proto) => proto.isPrototypeOf(o))) {
28
+ return 'string';
29
+ }
30
+ else {
31
+ return t;
32
+ }
33
+ };
34
+ const isType$1 = (type) => (value) => typeOf(value) === type;
35
+ const isSimpleType = (type) => (value) => typeof value === type;
36
+ const eq = (t) => (a) => t === a;
37
+ const isString = isType$1('string');
38
+ const isObject = isType$1('object');
39
+ const isNull = eq(null);
40
+ const isBoolean = isSimpleType('boolean');
41
+ const isNullable = (a) => a === null || a === undefined;
42
+ const isNonNullable = (a) => !isNullable(a);
43
+ const isFunction = isSimpleType('function');
44
+ const isNumber = isSimpleType('number');
45
+
46
+ /**
47
+ * The `Optional` type represents a value (of any type) that potentially does
48
+ * not exist. Any `Optional<T>` can either be a `Some<T>` (in which case the
49
+ * value does exist) or a `None` (in which case the value does not exist). This
50
+ * module defines a whole lot of FP-inspired utility functions for dealing with
51
+ * `Optional` objects.
52
+ *
53
+ * Comparison with null or undefined:
54
+ * - We don't get fancy null coalescing operators with `Optional`
55
+ * - We do get fancy helper functions with `Optional`
56
+ * - `Optional` support nesting, and allow for the type to still be nullable (or
57
+ * another `Optional`)
58
+ * - There is no option to turn off strict-optional-checks like there is for
59
+ * strict-null-checks
60
+ */
61
+ class Optional {
62
+ // The internal representation has a `tag` and a `value`, but both are
63
+ // private: able to be console.logged, but not able to be accessed by code
64
+ constructor(tag, value) {
65
+ this.tag = tag;
66
+ this.value = value;
67
+ }
68
+ // --- Identities ---
69
+ /**
70
+ * Creates a new `Optional<T>` that **does** contain a value.
71
+ */
72
+ static some(value) {
73
+ return new Optional(true, value);
74
+ }
75
+ /**
76
+ * Create a new `Optional<T>` that **does not** contain a value. `T` can be
77
+ * any type because we don't actually have a `T`.
78
+ */
79
+ static none() {
80
+ return Optional.singletonNone;
81
+ }
82
+ /**
83
+ * Perform a transform on an `Optional` type. Regardless of whether this
84
+ * `Optional` contains a value or not, `fold` will return a value of type `U`.
85
+ * If this `Optional` does not contain a value, the `U` will be created by
86
+ * calling `onNone`. If this `Optional` does contain a value, the `U` will be
87
+ * created by calling `onSome`.
88
+ *
89
+ * For the FP enthusiasts in the room, this function:
90
+ * 1. Could be used to implement all of the functions below
91
+ * 2. Forms a catamorphism
92
+ */
93
+ fold(onNone, onSome) {
94
+ if (this.tag) {
95
+ return onSome(this.value);
96
+ }
97
+ else {
98
+ return onNone();
99
+ }
100
+ }
101
+ /**
102
+ * Determine if this `Optional` object contains a value.
103
+ */
104
+ isSome() {
105
+ return this.tag;
106
+ }
107
+ /**
108
+ * Determine if this `Optional` object **does not** contain a value.
109
+ */
110
+ isNone() {
111
+ return !this.tag;
112
+ }
113
+ // --- Functor (name stolen from Haskell / maths) ---
114
+ /**
115
+ * Perform a transform on an `Optional` object, **if** there is a value. If
116
+ * you provide a function to turn a T into a U, this is the function you use
117
+ * to turn an `Optional<T>` into an `Optional<U>`. If this **does** contain
118
+ * a value then the output will also contain a value (that value being the
119
+ * output of `mapper(this.value)`), and if this **does not** contain a value
120
+ * then neither will the output.
121
+ */
122
+ map(mapper) {
123
+ if (this.tag) {
124
+ return Optional.some(mapper(this.value));
125
+ }
126
+ else {
127
+ return Optional.none();
128
+ }
129
+ }
130
+ // --- Monad (name stolen from Haskell / maths) ---
131
+ /**
132
+ * Perform a transform on an `Optional` object, **if** there is a value.
133
+ * Unlike `map`, here the transform itself also returns an `Optional`.
134
+ */
135
+ bind(binder) {
136
+ if (this.tag) {
137
+ return binder(this.value);
138
+ }
139
+ else {
140
+ return Optional.none();
141
+ }
142
+ }
143
+ // --- Traversable (name stolen from Haskell / maths) ---
144
+ /**
145
+ * For a given predicate, this function finds out if there **exists** a value
146
+ * inside this `Optional` object that meets the predicate. In practice, this
147
+ * means that for `Optional`s that do not contain a value it returns false (as
148
+ * no predicate-meeting value exists).
149
+ */
150
+ exists(predicate) {
151
+ return this.tag && predicate(this.value);
152
+ }
153
+ /**
154
+ * For a given predicate, this function finds out if **all** the values inside
155
+ * this `Optional` object meet the predicate. In practice, this means that
156
+ * for `Optional`s that do not contain a value it returns true (as all 0
157
+ * objects do meet the predicate).
158
+ */
159
+ forall(predicate) {
160
+ return !this.tag || predicate(this.value);
161
+ }
162
+ filter(predicate) {
163
+ if (!this.tag || predicate(this.value)) {
164
+ return this;
165
+ }
166
+ else {
167
+ return Optional.none();
168
+ }
169
+ }
170
+ // --- Getters ---
171
+ /**
172
+ * Get the value out of the inside of the `Optional` object, using a default
173
+ * `replacement` value if the provided `Optional` object does not contain a
174
+ * value.
175
+ */
176
+ getOr(replacement) {
177
+ return this.tag ? this.value : replacement;
178
+ }
179
+ /**
180
+ * Get the value out of the inside of the `Optional` object, using a default
181
+ * `replacement` value if the provided `Optional` object does not contain a
182
+ * value. Unlike `getOr`, in this method the `replacement` object is also
183
+ * `Optional` - meaning that this method will always return an `Optional`.
184
+ */
185
+ or(replacement) {
186
+ return this.tag ? this : replacement;
187
+ }
188
+ /**
189
+ * Get the value out of the inside of the `Optional` object, using a default
190
+ * `replacement` value if the provided `Optional` object does not contain a
191
+ * value. Unlike `getOr`, in this method the `replacement` value is
192
+ * "thunked" - that is to say that you don't pass a value to `getOrThunk`, you
193
+ * pass a function which (if called) will **return** the `value` you want to
194
+ * use.
195
+ */
196
+ getOrThunk(thunk) {
197
+ return this.tag ? this.value : thunk();
198
+ }
199
+ /**
200
+ * Get the value out of the inside of the `Optional` object, using a default
201
+ * `replacement` value if the provided Optional object does not contain a
202
+ * value.
203
+ *
204
+ * Unlike `or`, in this method the `replacement` value is "thunked" - that is
205
+ * to say that you don't pass a value to `orThunk`, you pass a function which
206
+ * (if called) will **return** the `value` you want to use.
207
+ *
208
+ * Unlike `getOrThunk`, in this method the `replacement` value is also
209
+ * `Optional`, meaning that this method will always return an `Optional`.
210
+ */
211
+ orThunk(thunk) {
212
+ return this.tag ? this : thunk();
213
+ }
214
+ /**
215
+ * Get the value out of the inside of the `Optional` object, throwing an
216
+ * exception if the provided `Optional` object does not contain a value.
217
+ *
218
+ * WARNING:
219
+ * You should only be using this function if you know that the `Optional`
220
+ * object **is not** empty (otherwise you're throwing exceptions in production
221
+ * code, which is bad).
222
+ *
223
+ * In tests this is more acceptable.
224
+ *
225
+ * Prefer other methods to this, such as `.each`.
226
+ */
227
+ getOrDie(message) {
228
+ if (!this.tag) {
229
+ throw new Error(message !== null && message !== void 0 ? message : 'Called getOrDie on None');
230
+ }
231
+ else {
232
+ return this.value;
233
+ }
234
+ }
235
+ // --- Interop with null and undefined ---
236
+ /**
237
+ * Creates an `Optional` value from a nullable (or undefined-able) input.
238
+ * Null, or undefined, is converted to `None`, and anything else is converted
239
+ * to `Some`.
240
+ */
241
+ static from(value) {
242
+ return isNonNullable(value) ? Optional.some(value) : Optional.none();
243
+ }
244
+ /**
245
+ * Converts an `Optional` to a nullable type, by getting the value if it
246
+ * exists, or returning `null` if it does not.
247
+ */
248
+ getOrNull() {
249
+ return this.tag ? this.value : null;
250
+ }
251
+ /**
252
+ * Converts an `Optional` to an undefined-able type, by getting the value if
253
+ * it exists, or returning `undefined` if it does not.
254
+ */
255
+ getOrUndefined() {
256
+ return this.value;
257
+ }
258
+ // --- Utilities ---
259
+ /**
260
+ * If the `Optional` contains a value, perform an action on that value.
261
+ * Unlike the rest of the methods on this type, `.each` has side-effects. If
262
+ * you want to transform an `Optional<T>` **into** something, then this is not
263
+ * the method for you. If you want to use an `Optional<T>` to **do**
264
+ * something, then this is the method for you - provided you're okay with not
265
+ * doing anything in the case where the `Optional` doesn't have a value inside
266
+ * it. If you're not sure whether your use-case fits into transforming
267
+ * **into** something or **doing** something, check whether it has a return
268
+ * value. If it does, you should be performing a transform.
269
+ */
270
+ each(worker) {
271
+ if (this.tag) {
272
+ worker(this.value);
273
+ }
274
+ }
275
+ /**
276
+ * Turn the `Optional` object into an array that contains all of the values
277
+ * stored inside the `Optional`. In practice, this means the output will have
278
+ * either 0 or 1 elements.
279
+ */
280
+ toArray() {
281
+ return this.tag ? [this.value] : [];
282
+ }
283
+ /**
284
+ * Turn the `Optional` object into a string for debugging or printing. Not
285
+ * recommended for production code, but good for debugging. Also note that
286
+ * these days an `Optional` object can be logged to the console directly, and
287
+ * its inner value (if it exists) will be visible.
288
+ */
289
+ toString() {
290
+ return this.tag ? `some(${this.value})` : 'none()';
291
+ }
292
+ }
293
+ // Sneaky optimisation: every instance of Optional.none is identical, so just
294
+ // reuse the same object
295
+ Optional.singletonNone = new Optional(false);
296
+
297
+ /* eslint-disable @typescript-eslint/unbound-method */
298
+ const nativeSlice = Array.prototype.slice;
299
+ const map = (xs, f) => {
300
+ // pre-allocating array size when it's guaranteed to be known
301
+ // http://jsperf.com/push-allocated-vs-dynamic/22
302
+ const len = xs.length;
303
+ const r = new Array(len);
304
+ for (let i = 0; i < len; i++) {
305
+ const x = xs[i];
306
+ r[i] = f(x, i);
307
+ }
308
+ return r;
309
+ };
310
+ // Unwound implementing other functions in terms of each.
311
+ // The code size is roughly the same, and it should allow for better optimisation.
312
+ // const each = function<T, U>(xs: T[], f: (x: T, i?: number, xs?: T[]) => void): void {
313
+ const each$1 = (xs, f) => {
314
+ for (let i = 0, len = xs.length; i < len; i++) {
315
+ const x = xs[i];
316
+ f(x, i);
317
+ }
318
+ };
319
+ const filter = (xs, pred) => {
320
+ const r = [];
321
+ for (let i = 0, len = xs.length; i < len; i++) {
322
+ const x = xs[i];
323
+ if (pred(x, i)) {
324
+ r.push(x);
325
+ }
326
+ }
327
+ return r;
328
+ };
329
+ isFunction(Array.from) ? Array.from : (x) => nativeSlice.call(x);
330
+
331
+ // There are many variations of Object iteration that are faster than the 'for-in' style:
332
+ // http://jsperf.com/object-keys-iteration/107
333
+ //
334
+ // Use the native keys if it is available (IE9+), otherwise fall back to manually filtering
335
+ const keys = Object.keys;
336
+ const each = (obj, f) => {
337
+ const props = keys(obj);
338
+ for (let k = 0, len = props.length; k < len; k++) {
339
+ const i = props[k];
340
+ const x = obj[i];
341
+ f(x, i);
342
+ }
343
+ };
344
+
345
+ const Cell = (initial) => {
346
+ let value = initial;
347
+ const get = () => {
348
+ return value;
349
+ };
350
+ const set = (v) => {
351
+ value = v;
352
+ };
353
+ return {
354
+ get,
355
+ set
356
+ };
357
+ };
358
+
359
+ // Use window object as the global if it's available since CSP will block script evals
360
+ // eslint-disable-next-line @typescript-eslint/no-implied-eval
361
+ const Global = typeof window !== 'undefined' ? window : Function('return this;')();
362
+
363
+ /** path :: ([String], JsObj?) -> JsObj */
364
+ const path = (parts, scope) => {
365
+ let o = scope !== undefined && scope !== null ? scope : Global;
366
+ for (let i = 0; i < parts.length && o !== undefined && o !== null; ++i) {
367
+ o = o[parts[i]];
368
+ }
369
+ return o;
370
+ };
371
+ /** resolve :: (String, JsObj?) -> JsObj */
372
+ const resolve = (p, scope) => {
373
+ const parts = p.split('.');
374
+ return path(parts, scope);
375
+ };
376
+
377
+ // Run a function fn after rate ms. If another invocation occurs
378
+ // during the time it is waiting, ignore it completely.
379
+ const first = (fn, rate) => {
380
+ let timer = null;
381
+ const cancel = () => {
382
+ if (!isNull(timer)) {
383
+ clearTimeout(timer);
384
+ timer = null;
385
+ }
386
+ };
387
+ const throttle = (...args) => {
388
+ if (isNull(timer)) {
389
+ timer = setTimeout(() => {
390
+ timer = null;
391
+ fn.apply(null, args);
392
+ }, rate);
393
+ }
394
+ };
395
+ return {
396
+ cancel,
397
+ throttle
398
+ };
399
+ };
400
+
401
+ var global = tinymce.util.Tools.resolve('tinymce.PluginManager');
402
+
403
+ const get$2 = (toggleState) => {
404
+ const isEnabled = () => {
405
+ return toggleState.get();
406
+ };
407
+ return {
408
+ isEnabled
409
+ };
410
+ };
411
+
412
+ const fireVisualChars = (editor, state) => {
413
+ return editor.dispatch('VisualChars', { state });
414
+ };
415
+
416
+ const fromHtml = (html, scope) => {
417
+ const doc = scope || document;
418
+ const div = doc.createElement('div');
419
+ div.innerHTML = html;
420
+ if (!div.hasChildNodes() || div.childNodes.length > 1) {
421
+ const message = 'HTML does not have a single root node';
422
+ // eslint-disable-next-line no-console
423
+ console.error(message, html);
424
+ throw new Error(message);
425
+ }
426
+ return fromDom(div.childNodes[0]);
427
+ };
428
+ const fromTag = (tag, scope) => {
429
+ const doc = scope || document;
430
+ const node = doc.createElement(tag);
431
+ return fromDom(node);
432
+ };
433
+ const fromText = (text, scope) => {
434
+ const doc = scope || document;
435
+ const node = doc.createTextNode(text);
436
+ return fromDom(node);
437
+ };
438
+ const fromDom = (node) => {
439
+ // TODO: Consider removing this check, but left atm for safety
440
+ if (node === null || node === undefined) {
441
+ throw new Error('Node cannot be null or undefined');
442
+ }
443
+ return {
444
+ dom: node
445
+ };
446
+ };
447
+ const fromPoint = (docElm, x, y) => Optional.from(docElm.dom.elementFromPoint(x, y)).map(fromDom);
448
+ // tslint:disable-next-line:variable-name
449
+ const SugarElement = {
450
+ fromHtml,
451
+ fromTag,
452
+ fromText,
453
+ fromDom,
454
+ fromPoint
455
+ };
456
+
457
+ const ELEMENT = 1;
458
+ const TEXT = 3;
459
+
460
+ const unsafe = (name, scope) => {
461
+ return resolve(name, scope);
462
+ };
463
+ const getOrDie = (name, scope) => {
464
+ const actual = unsafe(name, scope);
465
+ if (actual === undefined || actual === null) {
466
+ throw new Error(name + ' not available on this browser');
467
+ }
468
+ return actual;
469
+ };
470
+
471
+ const getPrototypeOf = Object.getPrototypeOf;
472
+ /*
473
+ * IE9 and above
474
+ *
475
+ * MDN no use on this one, but here's the link anyway:
476
+ * https://developer.mozilla.org/en/docs/Web/API/HTMLElement
477
+ */
478
+ const sandHTMLElement = (scope) => {
479
+ return getOrDie('HTMLElement', scope);
480
+ };
481
+ const isPrototypeOf = (x) => {
482
+ // use Resolve to get the window object for x and just return undefined if it can't find it.
483
+ // undefined scope later triggers using the global window.
484
+ const scope = resolve('ownerDocument.defaultView', x);
485
+ // TINY-7374: We can't rely on looking at the owner window HTMLElement as the element may have
486
+ // been constructed in a different window and then appended to the current window document.
487
+ return isObject(x) && (sandHTMLElement(scope).prototype.isPrototypeOf(x) || /^HTML\w*Element$/.test(getPrototypeOf(x).constructor.name));
488
+ };
489
+
490
+ const type = (element) => element.dom.nodeType;
491
+ const value = (element) => element.dom.nodeValue;
492
+ const isType = (t) => (element) => type(element) === t;
493
+ const isHTMLElement = (element) => isElement(element) && isPrototypeOf(element.dom);
494
+ const isElement = isType(ELEMENT);
495
+ const isText = isType(TEXT);
496
+
497
+ const rawSet = (dom, key, value) => {
498
+ /*
499
+ * JQuery coerced everything to a string, and silently did nothing on text node/null/undefined.
500
+ *
501
+ * We fail on those invalid cases, only allowing numbers and booleans.
502
+ */
503
+ if (isString(value) || isBoolean(value) || isNumber(value)) {
504
+ dom.setAttribute(key, value + '');
505
+ }
506
+ else {
507
+ // eslint-disable-next-line no-console
508
+ console.error('Invalid call to Attribute.set. Key ', key, ':: Value ', value, ':: Element ', dom);
509
+ throw new Error('Attribute value was not simple');
510
+ }
511
+ };
512
+ const set = (element, key, value) => {
513
+ rawSet(element.dom, key, value);
514
+ };
515
+ const get$1 = (element, key) => {
516
+ const v = element.dom.getAttribute(key);
517
+ // undefined is the more appropriate value for JS, and this matches JQuery
518
+ return v === null ? undefined : v;
519
+ };
520
+ const remove$3 = (element, key) => {
521
+ element.dom.removeAttribute(key);
522
+ };
523
+
524
+ // Methods for handling attributes that contain a list of values <div foo="alpha beta theta">
525
+ const read = (element, attr) => {
526
+ const value = get$1(element, attr);
527
+ return value === undefined || value === '' ? [] : value.split(' ');
528
+ };
529
+ const add$2 = (element, attr, id) => {
530
+ const old = read(element, attr);
531
+ const nu = old.concat([id]);
532
+ set(element, attr, nu.join(' '));
533
+ return true;
534
+ };
535
+ const remove$2 = (element, attr, id) => {
536
+ const nu = filter(read(element, attr), (v) => v !== id);
537
+ if (nu.length > 0) {
538
+ set(element, attr, nu.join(' '));
539
+ }
540
+ else {
541
+ remove$3(element, attr);
542
+ }
543
+ return false;
544
+ };
545
+
546
+ // IE11 Can return undefined for a classList on elements such as math, so we make sure it's not undefined before attempting to use it.
547
+ const supports = (element) => element.dom.classList !== undefined;
548
+ const get = (element) => read(element, 'class');
549
+ const add$1 = (element, clazz) => add$2(element, 'class', clazz);
550
+ const remove$1 = (element, clazz) => remove$2(element, 'class', clazz);
551
+
552
+ /*
553
+ * ClassList is IE10 minimum:
554
+ * https://developer.mozilla.org/en-US/docs/Web/API/Element.classList
555
+ *
556
+ * Note that IE doesn't support the second argument to toggle (at all).
557
+ * If it did, the toggler could be better.
558
+ */
559
+ const add = (element, clazz) => {
560
+ if (supports(element)) {
561
+ element.dom.classList.add(clazz);
562
+ }
563
+ else {
564
+ add$1(element, clazz);
565
+ }
566
+ };
567
+ const cleanClass = (element) => {
568
+ const classList = supports(element) ? element.dom.classList : get(element);
569
+ // classList is a "live list", so this is up to date already
570
+ if (classList.length === 0) {
571
+ // No more classes left, remove the class attribute as well
572
+ remove$3(element, 'class');
573
+ }
574
+ };
575
+ const remove = (element, clazz) => {
576
+ if (supports(element)) {
577
+ const classList = element.dom.classList;
578
+ classList.remove(clazz);
579
+ }
580
+ else {
581
+ remove$1(element, clazz);
582
+ }
583
+ cleanClass(element);
584
+ };
585
+
586
+ const getRaw = (element) => element.dom.contentEditable;
587
+
588
+ const charMap = {
589
+ '\u00a0': 'nbsp',
590
+ '\u00ad': 'shy'
591
+ };
592
+ const charMapToRegExp = (charMap, global) => {
593
+ let regExp = '';
594
+ each(charMap, (_value, key) => {
595
+ regExp += key;
596
+ });
597
+ return new RegExp('[' + regExp + ']', global ? 'g' : '');
598
+ };
599
+ const charMapToSelector = (charMap) => {
600
+ let selector = '';
601
+ each(charMap, (value) => {
602
+ if (selector) {
603
+ selector += ',';
604
+ }
605
+ selector += 'span.mce-' + value;
606
+ });
607
+ return selector;
608
+ };
609
+ const regExp = charMapToRegExp(charMap);
610
+ const regExpGlobal = charMapToRegExp(charMap, true);
611
+ const selector = charMapToSelector(charMap);
612
+ const nbspClass = 'mce-nbsp';
613
+
614
+ const wrapCharWithSpan = (value) => '<span data-mce-bogus="1" class="mce-' + charMap[value] + '">' + value + '</span>';
615
+
616
+ const isWrappedNbsp = (node) => node.nodeName.toLowerCase() === 'span' && node.classList.contains('mce-nbsp-wrap');
617
+ const isMatch = (n) => {
618
+ const value$1 = value(n);
619
+ return isText(n) &&
620
+ isString(value$1) &&
621
+ regExp.test(value$1);
622
+ };
623
+ const isContentEditableFalse = (node) => isHTMLElement(node) && getRaw(node) === 'false';
624
+ const isChildEditable = (node, currentState) => {
625
+ if (isHTMLElement(node) && !isWrappedNbsp(node.dom)) {
626
+ const value = getRaw(node);
627
+ if (value === 'true') {
628
+ return true;
629
+ }
630
+ else if (value === 'false') {
631
+ return false;
632
+ }
633
+ }
634
+ return currentState;
635
+ };
636
+ // inlined sugars PredicateFilter.descendants for file size but also make it only act on editable nodes it changes the current editable state when it traveses down
637
+ const filterEditableDescendants = (scope, predicate, editable) => {
638
+ let result = [];
639
+ const dom = scope.dom;
640
+ const children = map(dom.childNodes, SugarElement.fromDom);
641
+ const isEditable = (node) => isWrappedNbsp(node.dom) || !isContentEditableFalse(node);
642
+ each$1(children, (x) => {
643
+ if (editable && isEditable(x) && predicate(x)) {
644
+ result = result.concat([x]);
645
+ }
646
+ result = result.concat(filterEditableDescendants(x, predicate, isChildEditable(x, editable)));
647
+ });
648
+ return result;
649
+ };
650
+ const findParentElm = (elm, rootElm) => {
651
+ while (elm.parentNode) {
652
+ if (elm.parentNode === rootElm) {
653
+ return rootElm;
654
+ }
655
+ elm = elm.parentNode;
656
+ }
657
+ return undefined;
658
+ };
659
+ const replaceWithSpans = (text) => text.replace(regExpGlobal, wrapCharWithSpan);
660
+
661
+ const show = (editor, rootElm) => {
662
+ const dom = editor.dom;
663
+ const nodeList = filterEditableDescendants(SugarElement.fromDom(rootElm), isMatch, editor.dom.isEditable(rootElm));
664
+ each$1(nodeList, (n) => {
665
+ var _a;
666
+ const parent = n.dom.parentNode;
667
+ if (isWrappedNbsp(parent)) {
668
+ add(SugarElement.fromDom(parent), nbspClass);
669
+ }
670
+ else {
671
+ const withSpans = replaceWithSpans(dom.encode((_a = value(n)) !== null && _a !== void 0 ? _a : ''));
672
+ const div = dom.create('div', {}, withSpans);
673
+ let node;
674
+ while ((node = div.lastChild)) {
675
+ dom.insertAfter(node, n.dom);
676
+ }
677
+ editor.dom.remove(n.dom);
678
+ }
679
+ });
680
+ };
681
+ const hide = (editor, rootElm) => {
682
+ const nodeList = editor.dom.select(selector, rootElm);
683
+ each$1(nodeList, (node) => {
684
+ if (isWrappedNbsp(node)) {
685
+ remove(SugarElement.fromDom(node), nbspClass);
686
+ }
687
+ else {
688
+ editor.dom.remove(node, true);
689
+ }
690
+ });
691
+ };
692
+ const toggle = (editor) => {
693
+ const body = editor.getBody();
694
+ const bookmark = editor.selection.getBookmark();
695
+ let parentNode = findParentElm(editor.selection.getNode(), body);
696
+ // if user does select all the parentNode will be undefined
697
+ parentNode = parentNode !== undefined ? parentNode : body;
698
+ hide(editor, parentNode);
699
+ show(editor, parentNode);
700
+ editor.selection.moveToBookmark(bookmark);
701
+ };
702
+
703
+ const applyVisualChars = (editor, toggleState) => {
704
+ fireVisualChars(editor, toggleState.get());
705
+ const body = editor.getBody();
706
+ if (toggleState.get() === true) {
707
+ show(editor, body);
708
+ }
709
+ else {
710
+ hide(editor, body);
711
+ }
712
+ };
713
+ // Toggle state and save selection bookmark before applying visualChars
714
+ const toggleVisualChars = (editor, toggleState) => {
715
+ toggleState.set(!toggleState.get());
716
+ const bookmark = editor.selection.getBookmark();
717
+ applyVisualChars(editor, toggleState);
718
+ editor.selection.moveToBookmark(bookmark);
719
+ };
720
+
721
+ const register$2 = (editor, toggleState) => {
722
+ editor.addCommand('mceVisualChars', () => {
723
+ toggleVisualChars(editor, toggleState);
724
+ });
725
+ };
726
+
727
+ const option = (name) => (editor) => editor.options.get(name);
728
+ const register$1 = (editor) => {
729
+ const registerOption = editor.options.register;
730
+ registerOption('visualchars_default_state', {
731
+ processor: 'boolean',
732
+ default: false
733
+ });
734
+ };
735
+ const isEnabledByDefault = option('visualchars_default_state');
736
+
737
+ const setup$1 = (editor, toggleState) => {
738
+ /*
739
+ Note: applyVisualChars does not place a bookmark before modifying the DOM on init.
740
+ This will cause a loss of selection if the following conditions are met:
741
+ - Autofocus enabled, or editor is manually focused on init
742
+ - The first piece of text in the editor must be a nbsp
743
+ - Integrator has manually set the selection before init
744
+
745
+ Another improvement would be to ensure DOM elements aren't destroyed/recreated,
746
+ but rather wrapped/unwrapped when applying styling for visualchars so that selection
747
+ is not lost.
748
+ */
749
+ editor.on('init', () => {
750
+ applyVisualChars(editor, toggleState);
751
+ });
752
+ };
753
+
754
+ const setup = (editor, toggleState) => {
755
+ const debouncedToggle = first(() => {
756
+ toggle(editor);
757
+ }, 300);
758
+ editor.on('keydown', (e) => {
759
+ if (toggleState.get() === true) {
760
+ e.keyCode === 13 ? toggle(editor) : debouncedToggle.throttle();
761
+ }
762
+ });
763
+ editor.on('remove', debouncedToggle.cancel);
764
+ };
765
+
766
+ const toggleActiveState = (editor, enabledStated) => (api) => {
767
+ api.setActive(enabledStated.get());
768
+ const editorEventCallback = (e) => api.setActive(e.state);
769
+ editor.on('VisualChars', editorEventCallback);
770
+ return () => editor.off('VisualChars', editorEventCallback);
771
+ };
772
+ const register = (editor, toggleState) => {
773
+ const onAction = () => editor.execCommand('mceVisualChars');
774
+ editor.ui.registry.addToggleButton('visualchars', {
775
+ tooltip: 'Show invisible characters',
776
+ icon: 'visualchars',
777
+ onAction,
778
+ onSetup: toggleActiveState(editor, toggleState),
779
+ context: 'any'
780
+ });
781
+ editor.ui.registry.addToggleMenuItem('visualchars', {
782
+ text: 'Show invisible characters',
783
+ icon: 'visualchars',
784
+ onAction,
785
+ onSetup: toggleActiveState(editor, toggleState),
786
+ context: 'any'
787
+ });
788
+ };
789
+
790
+ var Plugin = () => {
791
+ global.add('visualchars', (editor) => {
792
+ register$1(editor);
793
+ const toggleState = Cell(isEnabledByDefault(editor));
794
+ register$2(editor, toggleState);
795
+ register(editor, toggleState);
796
+ setup(editor, toggleState);
797
+ setup$1(editor, toggleState);
798
+ return get$2(toggleState);
799
+ });
800
+ };
801
+
802
+ Plugin();
803
+ /** *****
804
+ * DO NOT EXPORT ANYTHING
805
+ *
806
+ * IF YOU DO ROLLUP WILL LEAVE A GLOBAL ON THE PAGE
807
+ *******/
808
+
809
+ })();