@opentiny/fluent-editor 4.0.0-alpha.1 → 4.0.0-alpha.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (462) hide show
  1. package/README.md +7 -24
  2. package/es/config/editor.utils.es.js +0 -2
  3. package/es/config/editor.utils.es.js.map +1 -1
  4. package/es/config/index.es.js +2 -2
  5. package/es/config/index.es.js.map +1 -1
  6. package/es/config/types/index.es.js +0 -20
  7. package/es/config/types/index.es.js.map +1 -1
  8. package/es/core/fluent-editor.es.js +4 -1
  9. package/es/core/fluent-editor.es.js.map +1 -1
  10. package/es/fluent-editor.es.js +24 -19
  11. package/es/fluent-editor.es.js.map +1 -1
  12. package/es/formats/emoji.es.js +14 -0
  13. package/es/formats/emoji.es.js.map +1 -0
  14. package/es/formats/index.es.js +11 -0
  15. package/es/formats/index.es.js.map +1 -0
  16. package/es/formats/soft-break.es.js +12 -5
  17. package/es/formats/soft-break.es.js.map +1 -1
  18. package/es/formats/strike.es.js +8 -5
  19. package/es/formats/strike.es.js.map +1 -1
  20. package/es/formats/video.es.js +14 -10
  21. package/es/formats/video.es.js.map +1 -1
  22. package/es/index.es.js +90 -31
  23. package/es/index.es.js.map +1 -1
  24. package/es/modules/counter.es.js +8 -3
  25. package/es/modules/counter.es.js.map +1 -1
  26. package/es/modules/custom-clipboard.es.js +20 -22
  27. package/es/modules/custom-clipboard.es.js.map +1 -1
  28. package/es/modules/custom-image/actions/action.es.js +19 -0
  29. package/es/modules/custom-image/actions/action.es.js.map +1 -0
  30. package/es/modules/custom-image/actions/{CustomResizeAction.es.js → custom-resize-action.es.js} +24 -11
  31. package/es/modules/custom-image/actions/{CustomResizeAction.es.js.map → custom-resize-action.es.js.map} +1 -1
  32. package/es/modules/custom-image/actions/{DeleteAction.es.js → delete-action.es.js} +8 -5
  33. package/es/modules/custom-image/actions/delete-action.es.js.map +1 -0
  34. package/es/modules/custom-image/actions/image-toolbar-buttons.es.js +137 -0
  35. package/es/modules/custom-image/actions/image-toolbar-buttons.es.js.map +1 -0
  36. package/es/modules/custom-image/actions/index.es.js +18 -0
  37. package/es/modules/custom-image/actions/index.es.js.map +1 -0
  38. package/es/modules/custom-image/actions/toolbar-action.es.js +33 -0
  39. package/es/modules/custom-image/actions/toolbar-action.es.js.map +1 -0
  40. package/es/modules/custom-image/actions/toolbar.es.js +110 -0
  41. package/es/modules/custom-image/actions/toolbar.es.js.map +1 -0
  42. package/es/modules/custom-image/{BlotFormatter.es.js → blot-formatter.es.js} +23 -49
  43. package/es/modules/custom-image/blot-formatter.es.js.map +1 -0
  44. package/es/modules/custom-image/image.es.js +31 -6
  45. package/es/modules/custom-image/image.es.js.map +1 -1
  46. package/es/modules/custom-image/index.es.js +9 -0
  47. package/es/modules/custom-image/index.es.js.map +1 -0
  48. package/es/modules/custom-image/options.es.js +85 -0
  49. package/es/modules/custom-image/options.es.js.map +1 -0
  50. package/es/modules/custom-image/specs/blot-spec.es.js +33 -0
  51. package/es/modules/custom-image/specs/blot-spec.es.js.map +1 -0
  52. package/es/modules/custom-image/specs/{CustomImageSpec.es.js → custom-image-spec.es.js} +13 -14
  53. package/es/modules/custom-image/specs/custom-image-spec.es.js.map +1 -0
  54. package/es/modules/custom-image/specs/image-spec.es.js +32 -0
  55. package/es/modules/custom-image/specs/image-spec.es.js.map +1 -0
  56. package/es/modules/custom-image/specs/index.es.js +9 -0
  57. package/es/modules/custom-image/specs/index.es.js.map +1 -0
  58. package/es/modules/custom-uploader.es.js +6 -4
  59. package/es/modules/custom-uploader.es.js.map +1 -1
  60. package/es/modules/divider.es.js +8 -7
  61. package/es/modules/divider.es.js.map +1 -1
  62. package/es/modules/emoji.es.js +175 -0
  63. package/es/modules/emoji.es.js.map +1 -0
  64. package/es/modules/file/formats/file.es.js +10 -8
  65. package/es/modules/file/formats/file.es.js.map +1 -1
  66. package/es/modules/file/index.es.js +6 -28
  67. package/es/modules/file/index.es.js.map +1 -1
  68. package/es/modules/file/modules/file-bar.es.js +11 -3
  69. package/es/modules/file/modules/file-bar.es.js.map +1 -1
  70. package/es/modules/file/modules/file-module.es.js +35 -0
  71. package/es/modules/file/modules/file-module.es.js.map +1 -0
  72. package/es/modules/i18n.es.js +6 -3
  73. package/es/modules/i18n.es.js.map +1 -1
  74. package/es/modules/index.es.js +26 -0
  75. package/es/modules/index.es.js.map +1 -0
  76. package/es/modules/link/formats/link.es.js +14 -10
  77. package/es/modules/link/formats/link.es.js.map +1 -1
  78. package/es/modules/link/index.es.js +4 -12
  79. package/es/modules/link/index.es.js.map +1 -1
  80. package/es/modules/link/modules/tooltip.es.js +28 -19
  81. package/es/modules/link/modules/tooltip.es.js.map +1 -1
  82. package/es/modules/mathlive/formats.es.js +10 -7
  83. package/es/modules/mathlive/formats.es.js.map +1 -1
  84. package/es/modules/mathlive/index.es.js +6 -30
  85. package/es/modules/mathlive/index.es.js.map +1 -1
  86. package/es/modules/mathlive/module.es.js +40 -0
  87. package/es/modules/mathlive/module.es.js.map +1 -0
  88. package/es/modules/mathlive/tooltip.es.js +9 -5
  89. package/es/modules/mathlive/tooltip.es.js.map +1 -1
  90. package/es/modules/mention/index.es.js +7 -0
  91. package/es/modules/{emoji/emoji-list → mention}/index.es.js.map +1 -1
  92. package/es/modules/mention/{MentionLink.es.js → mention-link.es.js} +14 -6
  93. package/es/modules/mention/mention-link.es.js.map +1 -0
  94. package/es/modules/mention/{Mention.es.js → mention.es.js} +28 -20
  95. package/es/modules/mention/mention.es.js.map +1 -0
  96. package/es/modules/shortcut-key/index.es.js.map +1 -1
  97. package/es/modules/syntax.es.js +4 -0
  98. package/es/modules/syntax.es.js.map +1 -1
  99. package/es/modules/table-up/index.es.js +4 -0
  100. package/es/modules/table-up/index.es.js.map +1 -1
  101. package/es/modules/toolbar/better-picker.es.js +5 -0
  102. package/es/modules/toolbar/better-picker.es.js.map +1 -1
  103. package/es/modules/toolbar/better-toolbar.es.js +138 -0
  104. package/es/modules/toolbar/better-toolbar.es.js.map +1 -0
  105. package/es/modules/toolbar/index.es.js +5 -135
  106. package/es/modules/toolbar/index.es.js.map +1 -1
  107. package/es/node_modules/.pnpm/@emoji-mart_data@1.2.1/node_modules/@emoji-mart/data/sets/15/native.json.es.js +40145 -0
  108. package/es/node_modules/.pnpm/@emoji-mart_data@1.2.1/node_modules/@emoji-mart/data/sets/15/native.json.es.js.map +1 -0
  109. package/es/node_modules/.pnpm/@floating-ui_core@1.7.2/node_modules/@floating-ui/core/dist/floating-ui.core.es.js +938 -0
  110. package/es/node_modules/.pnpm/@floating-ui_core@1.7.2/node_modules/@floating-ui/core/dist/floating-ui.core.es.js.map +1 -0
  111. package/es/node_modules/.pnpm/@floating-ui_dom@1.7.2/node_modules/@floating-ui/dom/dist/floating-ui.dom.es.js +624 -0
  112. package/es/node_modules/.pnpm/@floating-ui_dom@1.7.2/node_modules/@floating-ui/dom/dist/floating-ui.dom.es.js.map +1 -0
  113. package/es/node_modules/.pnpm/@floating-ui_utils@0.2.10/node_modules/@floating-ui/utils/dist/floating-ui.utils.dom.es.js +174 -0
  114. package/es/node_modules/.pnpm/@floating-ui_utils@0.2.10/node_modules/@floating-ui/utils/dist/floating-ui.utils.dom.es.js.map +1 -0
  115. package/es/node_modules/.pnpm/@floating-ui_utils@0.2.10/node_modules/@floating-ui/utils/dist/floating-ui.utils.es.js +159 -0
  116. package/es/node_modules/.pnpm/@floating-ui_utils@0.2.10/node_modules/@floating-ui/utils/dist/floating-ui.utils.es.js.map +1 -0
  117. package/es/node_modules/.pnpm/emoji-mart@5.6.0/node_modules/emoji-mart/dist/module.es.js +2849 -0
  118. package/es/node_modules/.pnpm/emoji-mart@5.6.0/node_modules/emoji-mart/dist/module.es.js.map +1 -0
  119. package/es/themes/snow.es.js +4 -10
  120. package/es/themes/snow.es.js.map +1 -1
  121. package/es/tools/fullscreen.es.js.map +1 -1
  122. package/es/ui/icons.config.es.js +8 -0
  123. package/es/ui/icons.config.es.js.map +1 -1
  124. package/es/utils/is.es.js.map +1 -1
  125. package/lib/config/editor.utils.cjs.js +0 -2
  126. package/lib/config/editor.utils.cjs.js.map +1 -1
  127. package/lib/config/index.cjs.js +1 -1
  128. package/lib/config/index.cjs.js.map +1 -1
  129. package/lib/config/types/index.cjs.js +0 -20
  130. package/lib/config/types/index.cjs.js.map +1 -1
  131. package/lib/core/fluent-editor.cjs.js +4 -1
  132. package/lib/core/fluent-editor.cjs.js.map +1 -1
  133. package/lib/fluent-editor.cjs.js +33 -28
  134. package/lib/fluent-editor.cjs.js.map +1 -1
  135. package/lib/formats/emoji.cjs.js +14 -0
  136. package/lib/formats/emoji.cjs.js.map +1 -0
  137. package/lib/formats/index.cjs.js +11 -0
  138. package/lib/formats/index.cjs.js.map +1 -0
  139. package/lib/formats/soft-break.cjs.js +13 -6
  140. package/lib/formats/soft-break.cjs.js.map +1 -1
  141. package/lib/formats/strike.cjs.js +9 -6
  142. package/lib/formats/strike.cjs.js.map +1 -1
  143. package/lib/formats/video.cjs.js +15 -11
  144. package/lib/formats/video.cjs.js.map +1 -1
  145. package/lib/index.cjs.js +111 -34
  146. package/lib/index.cjs.js.map +1 -1
  147. package/lib/modules/counter.cjs.js +8 -3
  148. package/lib/modules/counter.cjs.js.map +1 -1
  149. package/lib/modules/custom-clipboard.cjs.js +21 -23
  150. package/lib/modules/custom-clipboard.cjs.js.map +1 -1
  151. package/lib/modules/custom-image/actions/action.cjs.js +19 -0
  152. package/lib/modules/custom-image/actions/action.cjs.js.map +1 -0
  153. package/lib/modules/custom-image/actions/{CustomResizeAction.cjs.js → custom-resize-action.cjs.js} +26 -13
  154. package/lib/modules/custom-image/actions/{CustomResizeAction.cjs.js.map → custom-resize-action.cjs.js.map} +1 -1
  155. package/lib/modules/custom-image/actions/{DeleteAction.cjs.js → delete-action.cjs.js} +10 -7
  156. package/lib/modules/custom-image/actions/delete-action.cjs.js.map +1 -0
  157. package/lib/modules/custom-image/actions/image-toolbar-buttons.cjs.js +137 -0
  158. package/lib/modules/custom-image/actions/image-toolbar-buttons.cjs.js.map +1 -0
  159. package/lib/modules/custom-image/actions/index.cjs.js +18 -0
  160. package/lib/modules/custom-image/actions/index.cjs.js.map +1 -0
  161. package/lib/modules/custom-image/actions/toolbar-action.cjs.js +33 -0
  162. package/lib/modules/custom-image/actions/toolbar-action.cjs.js.map +1 -0
  163. package/lib/modules/custom-image/actions/toolbar.cjs.js +110 -0
  164. package/lib/modules/custom-image/actions/toolbar.cjs.js.map +1 -0
  165. package/lib/modules/custom-image/{BlotFormatter.cjs.js → blot-formatter.cjs.js} +24 -50
  166. package/lib/modules/custom-image/blot-formatter.cjs.js.map +1 -0
  167. package/lib/modules/custom-image/image.cjs.js +32 -7
  168. package/lib/modules/custom-image/image.cjs.js.map +1 -1
  169. package/lib/modules/custom-image/index.cjs.js +9 -0
  170. package/lib/modules/custom-image/index.cjs.js.map +1 -0
  171. package/lib/modules/custom-image/options.cjs.js +85 -0
  172. package/lib/modules/custom-image/options.cjs.js.map +1 -0
  173. package/lib/modules/custom-image/specs/blot-spec.cjs.js +33 -0
  174. package/lib/modules/custom-image/specs/blot-spec.cjs.js.map +1 -0
  175. package/lib/modules/custom-image/specs/{CustomImageSpec.cjs.js → custom-image-spec.cjs.js} +14 -15
  176. package/lib/modules/custom-image/specs/custom-image-spec.cjs.js.map +1 -0
  177. package/lib/modules/custom-image/specs/image-spec.cjs.js +32 -0
  178. package/lib/modules/custom-image/specs/image-spec.cjs.js.map +1 -0
  179. package/lib/modules/custom-image/specs/index.cjs.js +9 -0
  180. package/lib/modules/custom-image/specs/index.cjs.js.map +1 -0
  181. package/lib/modules/custom-uploader.cjs.js +6 -4
  182. package/lib/modules/custom-uploader.cjs.js.map +1 -1
  183. package/lib/modules/divider.cjs.js +9 -8
  184. package/lib/modules/divider.cjs.js.map +1 -1
  185. package/lib/modules/emoji.cjs.js +175 -0
  186. package/lib/modules/emoji.cjs.js.map +1 -0
  187. package/lib/modules/file/formats/file.cjs.js +11 -9
  188. package/lib/modules/file/formats/file.cjs.js.map +1 -1
  189. package/lib/modules/file/index.cjs.js +5 -27
  190. package/lib/modules/file/index.cjs.js.map +1 -1
  191. package/lib/modules/file/modules/file-bar.cjs.js +12 -4
  192. package/lib/modules/file/modules/file-bar.cjs.js.map +1 -1
  193. package/lib/modules/file/modules/file-module.cjs.js +35 -0
  194. package/lib/modules/file/modules/file-module.cjs.js.map +1 -0
  195. package/lib/modules/i18n.cjs.js +6 -3
  196. package/lib/modules/i18n.cjs.js.map +1 -1
  197. package/lib/modules/index.cjs.js +26 -0
  198. package/lib/modules/index.cjs.js.map +1 -0
  199. package/lib/modules/link/formats/link.cjs.js +15 -11
  200. package/lib/modules/link/formats/link.cjs.js.map +1 -1
  201. package/lib/modules/link/index.cjs.js +4 -12
  202. package/lib/modules/link/index.cjs.js.map +1 -1
  203. package/lib/modules/link/modules/tooltip.cjs.js +28 -19
  204. package/lib/modules/link/modules/tooltip.cjs.js.map +1 -1
  205. package/lib/modules/mathlive/formats.cjs.js +11 -8
  206. package/lib/modules/mathlive/formats.cjs.js.map +1 -1
  207. package/lib/modules/mathlive/index.cjs.js +5 -29
  208. package/lib/modules/mathlive/index.cjs.js.map +1 -1
  209. package/lib/modules/mathlive/module.cjs.js +40 -0
  210. package/lib/modules/mathlive/module.cjs.js.map +1 -0
  211. package/lib/modules/mathlive/tooltip.cjs.js +10 -6
  212. package/lib/modules/mathlive/tooltip.cjs.js.map +1 -1
  213. package/lib/modules/mention/index.cjs.js +7 -0
  214. package/lib/modules/{emoji/emoji-list → mention}/index.cjs.js.map +1 -1
  215. package/lib/modules/mention/{MentionLink.cjs.js → mention-link.cjs.js} +15 -7
  216. package/lib/modules/mention/mention-link.cjs.js.map +1 -0
  217. package/lib/modules/mention/{Mention.cjs.js → mention.cjs.js} +30 -22
  218. package/lib/modules/mention/mention.cjs.js.map +1 -0
  219. package/lib/modules/shortcut-key/index.cjs.js.map +1 -1
  220. package/lib/modules/syntax.cjs.js +4 -0
  221. package/lib/modules/syntax.cjs.js.map +1 -1
  222. package/lib/modules/table-up/index.cjs.js +4 -0
  223. package/lib/modules/table-up/index.cjs.js.map +1 -1
  224. package/lib/modules/toolbar/better-picker.cjs.js +5 -0
  225. package/lib/modules/toolbar/better-picker.cjs.js.map +1 -1
  226. package/lib/modules/toolbar/better-toolbar.cjs.js +138 -0
  227. package/lib/modules/toolbar/better-toolbar.cjs.js.map +1 -0
  228. package/lib/modules/toolbar/index.cjs.js +6 -136
  229. package/lib/modules/toolbar/index.cjs.js.map +1 -1
  230. package/lib/node_modules/.pnpm/@emoji-mart_data@1.2.1/node_modules/@emoji-mart/data/sets/15/native.json.cjs.js +40145 -0
  231. package/lib/node_modules/.pnpm/@emoji-mart_data@1.2.1/node_modules/@emoji-mart/data/sets/15/native.json.cjs.js.map +1 -0
  232. package/lib/node_modules/.pnpm/@floating-ui_core@1.7.2/node_modules/@floating-ui/core/dist/floating-ui.core.cjs.js +938 -0
  233. package/lib/node_modules/.pnpm/@floating-ui_core@1.7.2/node_modules/@floating-ui/core/dist/floating-ui.core.cjs.js.map +1 -0
  234. package/lib/node_modules/.pnpm/@floating-ui_dom@1.7.2/node_modules/@floating-ui/dom/dist/floating-ui.dom.cjs.js +624 -0
  235. package/lib/node_modules/.pnpm/@floating-ui_dom@1.7.2/node_modules/@floating-ui/dom/dist/floating-ui.dom.cjs.js.map +1 -0
  236. package/lib/node_modules/.pnpm/@floating-ui_utils@0.2.10/node_modules/@floating-ui/utils/dist/floating-ui.utils.cjs.js +159 -0
  237. package/lib/node_modules/.pnpm/@floating-ui_utils@0.2.10/node_modules/@floating-ui/utils/dist/floating-ui.utils.cjs.js.map +1 -0
  238. package/lib/node_modules/.pnpm/@floating-ui_utils@0.2.10/node_modules/@floating-ui/utils/dist/floating-ui.utils.dom.cjs.js +174 -0
  239. package/lib/node_modules/.pnpm/@floating-ui_utils@0.2.10/node_modules/@floating-ui/utils/dist/floating-ui.utils.dom.cjs.js.map +1 -0
  240. package/lib/node_modules/.pnpm/emoji-mart@5.6.0/node_modules/emoji-mart/dist/module.cjs.js +2847 -0
  241. package/lib/node_modules/.pnpm/emoji-mart@5.6.0/node_modules/emoji-mart/dist/module.cjs.js.map +1 -0
  242. package/lib/themes/snow.cjs.js +5 -11
  243. package/lib/themes/snow.cjs.js.map +1 -1
  244. package/lib/tools/fullscreen.cjs.js.map +1 -1
  245. package/lib/ui/icons.config.cjs.js +8 -0
  246. package/lib/ui/icons.config.cjs.js.map +1 -1
  247. package/lib/utils/is.cjs.js.map +1 -1
  248. package/package.json +8 -7
  249. package/style.css +2 -933
  250. package/types/config/editor.utils.d.ts +0 -1
  251. package/types/config/index.d.ts +1 -0
  252. package/types/config/types/editor-config.interface.d.ts +0 -7
  253. package/types/config/types/editor-modules.interface.d.ts +21 -12
  254. package/types/config/types/index.d.ts +0 -20
  255. package/types/config/types/type.d.ts +0 -4
  256. package/types/core/fluent-editor.d.ts +0 -1
  257. package/types/formats/emoji.d.ts +9 -0
  258. package/types/formats/index.d.ts +4 -0
  259. package/types/formats/soft-break.d.ts +6 -7
  260. package/types/formats/strike.d.ts +6 -4
  261. package/types/formats/video.d.ts +4 -6
  262. package/types/index.d.ts +6 -5
  263. package/types/modules/counter.d.ts +8 -1
  264. package/types/modules/custom-clipboard.d.ts +3 -6
  265. package/types/modules/custom-image/Options.d.ts +34 -23
  266. package/types/modules/custom-image/actions/Action.d.ts +5 -3
  267. package/types/modules/custom-image/actions/custom-resize-action.d.ts +24 -0
  268. package/types/modules/custom-image/actions/delete-action.d.ts +7 -0
  269. package/types/modules/custom-image/actions/image-toolbar-buttons.d.ts +17 -0
  270. package/types/modules/custom-image/actions/index.d.ts +6 -0
  271. package/types/modules/custom-image/actions/toolbar-action.d.ts +12 -0
  272. package/types/modules/custom-image/actions/toolbar.d.ts +20 -0
  273. package/types/modules/custom-image/blot-formatter.d.ts +24 -0
  274. package/types/modules/custom-image/image-bar.d.ts +9 -7
  275. package/types/modules/custom-image/image.d.ts +15 -13
  276. package/types/modules/custom-image/index.d.ts +4 -0
  277. package/types/modules/custom-image/specs/blot-spec.d.ts +13 -0
  278. package/types/modules/custom-image/specs/custom-image-spec.d.ts +18 -0
  279. package/types/modules/custom-image/specs/image-spec.d.ts +9 -0
  280. package/types/modules/custom-image/specs/index.d.ts +3 -0
  281. package/types/modules/custom-uploader.d.ts +41 -0
  282. package/types/modules/divider.d.ts +6 -4
  283. package/types/modules/emoji/formats/emoji-blot.d.ts +9 -7
  284. package/types/modules/emoji/index.d.ts +3 -10
  285. package/types/modules/emoji/modules/emoji.d.ts +6 -6
  286. package/types/modules/emoji/modules/toolbar-emoji.d.ts +7 -6
  287. package/types/modules/emoji.d.ts +35 -0
  288. package/types/modules/file/formats/file.d.ts +2 -2
  289. package/types/modules/file/index.d.ts +3 -11
  290. package/types/modules/file/modules/file-bar.d.ts +1 -1
  291. package/types/modules/file/modules/file-module.d.ts +10 -0
  292. package/types/modules/i18n.d.ts +1 -2
  293. package/types/modules/index.d.ts +15 -0
  294. package/types/modules/link/formats/link.d.ts +5 -5
  295. package/types/modules/link/index.d.ts +2 -6
  296. package/types/modules/link/modules/tooltip.d.ts +5 -10
  297. package/types/modules/mathlive/formats.d.ts +2 -2
  298. package/types/modules/mathlive/index.d.ts +3 -9
  299. package/types/modules/mathlive/module.d.ts +10 -0
  300. package/types/modules/mathlive/tooltip.d.ts +1 -1
  301. package/types/modules/mention/Mention.d.ts +3 -4
  302. package/types/modules/mention/index.d.ts +2 -0
  303. package/types/modules/mention/mention-link.d.ts +17 -0
  304. package/types/modules/shortcut-key/index.d.ts +12 -8
  305. package/types/modules/table-up/index.d.ts +3 -3
  306. package/types/modules/toolbar/better-toolbar.d.ts +8 -0
  307. package/types/modules/toolbar/index.d.ts +2 -8
  308. package/types/tools/fullscreen.d.ts +5 -1
  309. package/types/ui/icons.config.d.ts +1 -0
  310. package/types/utils/is.d.ts +1 -1
  311. package/es/config/types/additional-toolbar-item.interface.es.js +0 -2
  312. package/es/config/types/additional-toolbar-item.interface.es.js.map +0 -1
  313. package/es/config/types/content-change.interface.es.js +0 -2
  314. package/es/config/types/content-change.interface.es.js.map +0 -1
  315. package/es/config/types/content-save.interface.es.js +0 -2
  316. package/es/config/types/content-save.interface.es.js.map +0 -1
  317. package/es/config/types/counter-option.interface.es.js +0 -2
  318. package/es/config/types/counter-option.interface.es.js.map +0 -1
  319. package/es/config/types/editor-toolbar.interface.es.js +0 -2
  320. package/es/config/types/editor-toolbar.interface.es.js.map +0 -1
  321. package/es/config/types/file-operation.interface.es.js +0 -2
  322. package/es/config/types/file-operation.interface.es.js.map +0 -1
  323. package/es/config/types/focus-change.interface.es.js +0 -2
  324. package/es/config/types/focus-change.interface.es.js.map +0 -1
  325. package/es/config/types/fullscreen-module.interface.es.js +0 -2
  326. package/es/config/types/fullscreen-module.interface.es.js.map +0 -1
  327. package/es/config/types/help-panel-item.interface.es.js +0 -2
  328. package/es/config/types/help-panel-item.interface.es.js.map +0 -1
  329. package/es/config/types/help-panel-option.interface.es.js +0 -2
  330. package/es/config/types/help-panel-option.interface.es.js.map +0 -1
  331. package/es/config/types/image-module.interface.es.js +0 -2
  332. package/es/config/types/image-module.interface.es.js.map +0 -1
  333. package/es/config/types/image-upload.interface.es.js +0 -2
  334. package/es/config/types/image-upload.interface.es.js.map +0 -1
  335. package/es/config/types/load-on-demand-module.interface.es.js +0 -2
  336. package/es/config/types/load-on-demand-module.interface.es.js.map +0 -1
  337. package/es/config/types/mention-module.interface.es.js +0 -2
  338. package/es/config/types/mention-module.interface.es.js.map +0 -1
  339. package/es/config/types/paste-change.interface.es.js +0 -2
  340. package/es/config/types/paste-change.interface.es.js.map +0 -1
  341. package/es/config/types/quick-menu-module.interface.es.js +0 -2
  342. package/es/config/types/quick-menu-module.interface.es.js.map +0 -1
  343. package/es/config/types/range.interface.es.js +0 -2
  344. package/es/config/types/range.interface.es.js.map +0 -1
  345. package/es/config/types/registry-options.interface.es.js +0 -2
  346. package/es/config/types/registry-options.interface.es.js.map +0 -1
  347. package/es/config/types/selection-change.interface.es.js +0 -2
  348. package/es/config/types/selection-change.interface.es.js.map +0 -1
  349. package/es/config/types/toolbar-item.interface.es.js +0 -2
  350. package/es/config/types/toolbar-item.interface.es.js.map +0 -1
  351. package/es/config/types/validate-error.interface.es.js +0 -2
  352. package/es/config/types/validate-error.interface.es.js.map +0 -1
  353. package/es/modules/custom-image/BlotFormatter.es.js.map +0 -1
  354. package/es/modules/custom-image/Options.es.js +0 -95
  355. package/es/modules/custom-image/Options.es.js.map +0 -1
  356. package/es/modules/custom-image/actions/Action.es.js +0 -15
  357. package/es/modules/custom-image/actions/Action.es.js.map +0 -1
  358. package/es/modules/custom-image/actions/DeleteAction.es.js.map +0 -1
  359. package/es/modules/custom-image/image-bar.es.js +0 -127
  360. package/es/modules/custom-image/image-bar.es.js.map +0 -1
  361. package/es/modules/custom-image/specs/BlotSpec.es.js +0 -27
  362. package/es/modules/custom-image/specs/BlotSpec.es.js.map +0 -1
  363. package/es/modules/custom-image/specs/CustomImageSpec.es.js.map +0 -1
  364. package/es/modules/custom-image/specs/ImageSpec.es.js +0 -29
  365. package/es/modules/custom-image/specs/ImageSpec.es.js.map +0 -1
  366. package/es/modules/emoji/emoji-list/index.es.js +0 -5
  367. package/es/modules/emoji/emoji-list/people.es.js +0 -114
  368. package/es/modules/emoji/emoji-list/people.es.js.map +0 -1
  369. package/es/modules/emoji/emoji-list.es.js +0 -9
  370. package/es/modules/emoji/emoji-list.es.js.map +0 -1
  371. package/es/modules/emoji/emoji-map.es.js +0 -9
  372. package/es/modules/emoji/emoji-map.es.js.map +0 -1
  373. package/es/modules/emoji/emoji-sprite.es.js +0 -5
  374. package/es/modules/emoji/emoji-sprite.es.js.map +0 -1
  375. package/es/modules/emoji/formats/emoji-blot.es.js +0 -41
  376. package/es/modules/emoji/formats/emoji-blot.es.js.map +0 -1
  377. package/es/modules/emoji/index.es.js +0 -8
  378. package/es/modules/emoji/index.es.js.map +0 -1
  379. package/es/modules/emoji/modules/emoji.es.js +0 -248
  380. package/es/modules/emoji/modules/emoji.es.js.map +0 -1
  381. package/es/modules/emoji/modules/toolbar-emoji.es.js +0 -153
  382. package/es/modules/emoji/modules/toolbar-emoji.es.js.map +0 -1
  383. package/es/modules/emoji/utils.es.js +0 -19
  384. package/es/modules/emoji/utils.es.js.map +0 -1
  385. package/es/modules/mention/Mention.es.js.map +0 -1
  386. package/es/modules/mention/MentionLink.es.js.map +0 -1
  387. package/lib/config/types/additional-toolbar-item.interface.cjs.js +0 -2
  388. package/lib/config/types/additional-toolbar-item.interface.cjs.js.map +0 -1
  389. package/lib/config/types/content-change.interface.cjs.js +0 -2
  390. package/lib/config/types/content-change.interface.cjs.js.map +0 -1
  391. package/lib/config/types/content-save.interface.cjs.js +0 -2
  392. package/lib/config/types/content-save.interface.cjs.js.map +0 -1
  393. package/lib/config/types/counter-option.interface.cjs.js +0 -2
  394. package/lib/config/types/counter-option.interface.cjs.js.map +0 -1
  395. package/lib/config/types/editor-toolbar.interface.cjs.js +0 -2
  396. package/lib/config/types/editor-toolbar.interface.cjs.js.map +0 -1
  397. package/lib/config/types/file-operation.interface.cjs.js +0 -2
  398. package/lib/config/types/file-operation.interface.cjs.js.map +0 -1
  399. package/lib/config/types/focus-change.interface.cjs.js +0 -2
  400. package/lib/config/types/focus-change.interface.cjs.js.map +0 -1
  401. package/lib/config/types/fullscreen-module.interface.cjs.js +0 -2
  402. package/lib/config/types/fullscreen-module.interface.cjs.js.map +0 -1
  403. package/lib/config/types/help-panel-item.interface.cjs.js +0 -2
  404. package/lib/config/types/help-panel-item.interface.cjs.js.map +0 -1
  405. package/lib/config/types/help-panel-option.interface.cjs.js +0 -2
  406. package/lib/config/types/help-panel-option.interface.cjs.js.map +0 -1
  407. package/lib/config/types/image-module.interface.cjs.js +0 -2
  408. package/lib/config/types/image-module.interface.cjs.js.map +0 -1
  409. package/lib/config/types/image-upload.interface.cjs.js +0 -2
  410. package/lib/config/types/image-upload.interface.cjs.js.map +0 -1
  411. package/lib/config/types/load-on-demand-module.interface.cjs.js +0 -2
  412. package/lib/config/types/load-on-demand-module.interface.cjs.js.map +0 -1
  413. package/lib/config/types/mention-module.interface.cjs.js +0 -2
  414. package/lib/config/types/mention-module.interface.cjs.js.map +0 -1
  415. package/lib/config/types/paste-change.interface.cjs.js +0 -2
  416. package/lib/config/types/paste-change.interface.cjs.js.map +0 -1
  417. package/lib/config/types/quick-menu-module.interface.cjs.js +0 -2
  418. package/lib/config/types/quick-menu-module.interface.cjs.js.map +0 -1
  419. package/lib/config/types/range.interface.cjs.js +0 -2
  420. package/lib/config/types/range.interface.cjs.js.map +0 -1
  421. package/lib/config/types/registry-options.interface.cjs.js +0 -2
  422. package/lib/config/types/registry-options.interface.cjs.js.map +0 -1
  423. package/lib/config/types/selection-change.interface.cjs.js +0 -2
  424. package/lib/config/types/selection-change.interface.cjs.js.map +0 -1
  425. package/lib/config/types/toolbar-item.interface.cjs.js +0 -2
  426. package/lib/config/types/toolbar-item.interface.cjs.js.map +0 -1
  427. package/lib/config/types/validate-error.interface.cjs.js +0 -2
  428. package/lib/config/types/validate-error.interface.cjs.js.map +0 -1
  429. package/lib/modules/custom-image/BlotFormatter.cjs.js.map +0 -1
  430. package/lib/modules/custom-image/Options.cjs.js +0 -95
  431. package/lib/modules/custom-image/Options.cjs.js.map +0 -1
  432. package/lib/modules/custom-image/actions/Action.cjs.js +0 -15
  433. package/lib/modules/custom-image/actions/Action.cjs.js.map +0 -1
  434. package/lib/modules/custom-image/actions/DeleteAction.cjs.js.map +0 -1
  435. package/lib/modules/custom-image/image-bar.cjs.js +0 -127
  436. package/lib/modules/custom-image/image-bar.cjs.js.map +0 -1
  437. package/lib/modules/custom-image/specs/BlotSpec.cjs.js +0 -27
  438. package/lib/modules/custom-image/specs/BlotSpec.cjs.js.map +0 -1
  439. package/lib/modules/custom-image/specs/CustomImageSpec.cjs.js.map +0 -1
  440. package/lib/modules/custom-image/specs/ImageSpec.cjs.js +0 -29
  441. package/lib/modules/custom-image/specs/ImageSpec.cjs.js.map +0 -1
  442. package/lib/modules/emoji/emoji-list/index.cjs.js +0 -5
  443. package/lib/modules/emoji/emoji-list/people.cjs.js +0 -114
  444. package/lib/modules/emoji/emoji-list/people.cjs.js.map +0 -1
  445. package/lib/modules/emoji/emoji-list.cjs.js +0 -9
  446. package/lib/modules/emoji/emoji-list.cjs.js.map +0 -1
  447. package/lib/modules/emoji/emoji-map.cjs.js +0 -9
  448. package/lib/modules/emoji/emoji-map.cjs.js.map +0 -1
  449. package/lib/modules/emoji/emoji-sprite.cjs.js +0 -5
  450. package/lib/modules/emoji/emoji-sprite.cjs.js.map +0 -1
  451. package/lib/modules/emoji/formats/emoji-blot.cjs.js +0 -41
  452. package/lib/modules/emoji/formats/emoji-blot.cjs.js.map +0 -1
  453. package/lib/modules/emoji/index.cjs.js +0 -8
  454. package/lib/modules/emoji/index.cjs.js.map +0 -1
  455. package/lib/modules/emoji/modules/emoji.cjs.js +0 -248
  456. package/lib/modules/emoji/modules/emoji.cjs.js.map +0 -1
  457. package/lib/modules/emoji/modules/toolbar-emoji.cjs.js +0 -153
  458. package/lib/modules/emoji/modules/toolbar-emoji.cjs.js.map +0 -1
  459. package/lib/modules/emoji/utils.cjs.js +0 -19
  460. package/lib/modules/emoji/utils.cjs.js.map +0 -1
  461. package/lib/modules/mention/Mention.cjs.js.map +0 -1
  462. package/lib/modules/mention/MentionLink.cjs.js.map +0 -1
@@ -0,0 +1,33 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
3
+ var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
4
+ import { Action } from "./action.es.js";
5
+ import { ImageToolbarButtons } from "./image-toolbar-buttons.es.js";
6
+ import { ImageToolbar } from "./toolbar.es.js";
7
+ class ImageToolbarAction extends Action {
8
+ constructor(formatter) {
9
+ super(formatter);
10
+ __publicField(this, "toolbar");
11
+ __publicField(this, "buttons");
12
+ this.buttons = new ImageToolbarButtons({
13
+ buttons: formatter.options.toolbar.buttons
14
+ });
15
+ this.toolbar = new ImageToolbar();
16
+ }
17
+ onCreate() {
18
+ const toolbar = this.toolbar.create(this.formatter, this.buttons);
19
+ this.formatter.overlay.appendChild(toolbar);
20
+ }
21
+ onDestroy() {
22
+ const toolbar = this.toolbar.getElement();
23
+ if (!toolbar) {
24
+ return;
25
+ }
26
+ this.formatter.overlay.removeChild(toolbar);
27
+ this.toolbar.destroy();
28
+ }
29
+ }
30
+ export {
31
+ ImageToolbarAction
32
+ };
33
+ //# sourceMappingURL=toolbar-action.es.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"toolbar-action.es.js","sources":["../../../../../src/modules/custom-image/actions/toolbar-action.ts"],"sourcesContent":["import type { BlotFormatter } from '../blot-formatter'\r\nimport { Action } from './action'\r\nimport { ImageToolbarButtons } from './image-toolbar-buttons'\r\nimport { ImageToolbar } from './toolbar'\r\n\r\nexport class ImageToolbarAction extends Action {\r\n toolbar: ImageToolbar\r\n buttons: ImageToolbarButtons\r\n\r\n constructor(formatter: BlotFormatter) {\r\n super(formatter)\r\n this.buttons = new ImageToolbarButtons({\r\n buttons: formatter.options.toolbar.buttons,\r\n })\r\n this.toolbar = new ImageToolbar()\r\n }\r\n\r\n onCreate() {\r\n const toolbar = this.toolbar.create(this.formatter, this.buttons)\r\n this.formatter.overlay.appendChild(toolbar)\r\n }\r\n\r\n onDestroy() {\r\n const toolbar = this.toolbar.getElement()\r\n if (!toolbar) {\r\n return\r\n }\r\n\r\n this.formatter.overlay.removeChild(toolbar)\r\n this.toolbar.destroy()\r\n }\r\n}\r\n"],"names":[],"mappings":";;;;;;AAKO,MAAM,2BAA2B,OAAO;AAAA,EAI7C,YAAY,WAA0B;AACpC,UAAM,SAAS;AAJjB;AACA;AAIO,SAAA,UAAU,IAAI,oBAAoB;AAAA,MACrC,SAAS,UAAU,QAAQ,QAAQ;AAAA,IAAA,CACpC;AACI,SAAA,UAAU,IAAI,aAAa;AAAA,EAAA;AAAA,EAGlC,WAAW;AACT,UAAM,UAAU,KAAK,QAAQ,OAAO,KAAK,WAAW,KAAK,OAAO;AAC3D,SAAA,UAAU,QAAQ,YAAY,OAAO;AAAA,EAAA;AAAA,EAG5C,YAAY;AACJ,UAAA,UAAU,KAAK,QAAQ,WAAW;AACxC,QAAI,CAAC,SAAS;AACZ;AAAA,IAAA;AAGG,SAAA,UAAU,QAAQ,YAAY,OAAO;AAC1C,SAAK,QAAQ,QAAQ;AAAA,EAAA;AAEzB;"}
@@ -0,0 +1,110 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
3
+ var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
4
+ class ImageToolbar {
5
+ constructor() {
6
+ __publicField(this, "toolbar");
7
+ __publicField(this, "buttons");
8
+ this.toolbar = null;
9
+ this.buttons = [];
10
+ }
11
+ create(formatter, toolButton) {
12
+ const toolbar = document.createElement("div");
13
+ toolbar.classList.add(formatter.options.toolbar.mainClassName);
14
+ this.addToolbarStyle(formatter, toolbar);
15
+ this.addButtons(formatter, toolbar, toolButton);
16
+ this.toolbar = toolbar;
17
+ return this.toolbar;
18
+ }
19
+ destroy() {
20
+ this.toolbar = null;
21
+ this.buttons = [];
22
+ }
23
+ getElement() {
24
+ return this.toolbar;
25
+ }
26
+ addToolbarStyle(formatter, toolbar) {
27
+ if (formatter.options.toolbar.mainStyle) {
28
+ Object.assign(toolbar.style, formatter.options.toolbar.mainStyle);
29
+ }
30
+ }
31
+ addButtonStyle(button, index, formatter) {
32
+ if (formatter.options.toolbar.buttonStyle) {
33
+ Object.assign(button.style, formatter.options.toolbar.buttonStyle);
34
+ if (index > 0) {
35
+ button.style.borderLeftWidth = "0";
36
+ }
37
+ }
38
+ if (formatter.options.toolbar.svgStyle) {
39
+ Object.assign(button.children[0].style, formatter.options.toolbar.svgStyle);
40
+ }
41
+ }
42
+ addButtons(formatter, toolbar, toolButton) {
43
+ toolButton.getItems().forEach((tool, i) => {
44
+ const button = document.createElement("span");
45
+ button.classList.add(formatter.options.toolbar.buttonClassName);
46
+ button.innerHTML = tool.icon;
47
+ button.addEventListener("click", () => {
48
+ this.onButtonClick(button, formatter, tool, toolButton);
49
+ });
50
+ this.preselectButton(button, tool, formatter, toolButton);
51
+ this.addButtonStyle(button, i, formatter);
52
+ this.buttons.push(button);
53
+ toolbar.appendChild(button);
54
+ });
55
+ }
56
+ preselectButton(button, toolButtonOption, formatter, toolButton) {
57
+ if (!formatter.currentSpec) {
58
+ return;
59
+ }
60
+ const target = formatter.currentSpec.getTargetElement();
61
+ if (!target) {
62
+ return;
63
+ }
64
+ if (toolButtonOption.isActive && toolButtonOption.isActive(target)) {
65
+ this.selectButton(formatter, button);
66
+ }
67
+ }
68
+ onButtonClick(button, formatter, toolButtonOption, toolButton) {
69
+ if (!formatter.currentSpec) {
70
+ return;
71
+ }
72
+ const target = formatter.currentSpec.getTargetElement();
73
+ if (!target || target.tagName.toLowerCase() !== "img") {
74
+ return;
75
+ }
76
+ this.clickButton(button, target, formatter, toolButtonOption, toolButton);
77
+ }
78
+ clickButton(button, target, formatter, toolButtonOption, toolButton) {
79
+ if (!toolButtonOption.isActive) {
80
+ toolButtonOption.apply.call(this, target, toolButton);
81
+ } else {
82
+ this.buttons.forEach((b) => {
83
+ this.deselectButton(formatter, b);
84
+ });
85
+ if (toolButtonOption.isActive(target)) {
86
+ toolButton.clear(target);
87
+ } else {
88
+ this.selectButton(formatter, button);
89
+ toolButtonOption.apply.call(this, target, toolButton);
90
+ }
91
+ }
92
+ formatter.update();
93
+ }
94
+ selectButton(formatter, button) {
95
+ button.classList.add("is-selected");
96
+ if (formatter.options.toolbar.addButtonSelectStyle) {
97
+ button.style.setProperty("filter", "invert(20%)");
98
+ }
99
+ }
100
+ deselectButton(formatter, button) {
101
+ button.classList.remove("is-selected");
102
+ if (formatter.options.toolbar.addButtonSelectStyle) {
103
+ button.style.removeProperty("filter");
104
+ }
105
+ }
106
+ }
107
+ export {
108
+ ImageToolbar
109
+ };
110
+ //# sourceMappingURL=toolbar.es.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"toolbar.es.js","sources":["../../../../../src/modules/custom-image/actions/toolbar.ts"],"sourcesContent":["import type { BlotFormatter } from '../blot-formatter'\r\nimport type { ToolButtonOption } from '../options'\r\nimport type { ImageToolbarButtons } from './image-toolbar-buttons'\r\n\r\nexport class ImageToolbar {\r\n toolbar?: HTMLElement\r\n buttons: HTMLElement[]\r\n\r\n constructor() {\r\n this.toolbar = null\r\n this.buttons = []\r\n }\r\n\r\n create(formatter: BlotFormatter, toolButton: ImageToolbarButtons): HTMLElement {\r\n const toolbar = document.createElement('div')\r\n toolbar.classList.add(formatter.options.toolbar.mainClassName)\r\n this.addToolbarStyle(formatter, toolbar)\r\n this.addButtons(formatter, toolbar, toolButton)\r\n\r\n this.toolbar = toolbar\r\n return this.toolbar\r\n }\r\n\r\n destroy() {\r\n this.toolbar = null\r\n this.buttons = []\r\n }\r\n\r\n getElement() {\r\n return this.toolbar\r\n }\r\n\r\n addToolbarStyle(formatter: BlotFormatter, toolbar: HTMLElement) {\r\n if (formatter.options.toolbar.mainStyle) {\r\n Object.assign(toolbar.style, formatter.options.toolbar.mainStyle)\r\n }\r\n }\r\n\r\n addButtonStyle(button: HTMLElement, index: number, formatter: BlotFormatter) {\r\n if (formatter.options.toolbar.buttonStyle) {\r\n Object.assign(button.style, formatter.options.toolbar.buttonStyle)\r\n if (index > 0) {\r\n button.style.borderLeftWidth = '0'\r\n }\r\n }\r\n\r\n if (formatter.options.toolbar.svgStyle) {\r\n Object.assign((button.children[0] as HTMLElement).style, formatter.options.toolbar.svgStyle)\r\n }\r\n }\r\n\r\n addButtons(formatter: BlotFormatter, toolbar: HTMLElement, toolButton: ImageToolbarButtons) {\r\n toolButton.getItems().forEach((tool, i) => {\r\n const button = document.createElement('span')\r\n button.classList.add(formatter.options.toolbar.buttonClassName)\r\n button.innerHTML = tool.icon\r\n button.addEventListener('click', () => {\r\n this.onButtonClick(button, formatter, tool, toolButton)\r\n })\r\n this.preselectButton(button, tool, formatter, toolButton)\r\n this.addButtonStyle(button, i, formatter)\r\n this.buttons.push(button)\r\n toolbar.appendChild(button)\r\n })\r\n }\r\n\r\n preselectButton(\r\n button: HTMLElement,\r\n toolButtonOption: ToolButtonOption,\r\n formatter: BlotFormatter,\r\n toolButton: ImageToolbarButtons,\r\n ) {\r\n if (!formatter.currentSpec) {\r\n return\r\n }\r\n\r\n const target = formatter.currentSpec.getTargetElement()\r\n if (!target) {\r\n return\r\n }\r\n\r\n if (toolButtonOption.isActive && toolButtonOption.isActive(target)) {\r\n this.selectButton(formatter, button)\r\n }\r\n }\r\n\r\n onButtonClick(\r\n button: HTMLElement,\r\n formatter: BlotFormatter,\r\n toolButtonOption: ToolButtonOption,\r\n toolButton: ImageToolbarButtons,\r\n ) {\r\n if (!formatter.currentSpec) {\r\n return\r\n }\r\n\r\n const target = formatter.currentSpec.getTargetElement()\r\n if (!target || target.tagName.toLowerCase() !== 'img') {\r\n return\r\n }\r\n\r\n this.clickButton(button, target as HTMLImageElement, formatter, toolButtonOption, toolButton)\r\n }\r\n\r\n clickButton(\r\n button: HTMLElement,\r\n target: HTMLImageElement,\r\n formatter: BlotFormatter,\r\n toolButtonOption: ToolButtonOption,\r\n toolButton: ImageToolbarButtons,\r\n ) {\r\n if (!toolButtonOption.isActive) {\r\n toolButtonOption.apply.call(this, target, toolButton)\r\n }\r\n else {\r\n this.buttons.forEach((b) => {\r\n this.deselectButton(formatter, b)\r\n })\r\n\r\n if (toolButtonOption.isActive(target)) {\r\n toolButton.clear(target)\r\n }\r\n else {\r\n this.selectButton(formatter, button)\r\n toolButtonOption.apply.call(this, target, toolButton)\r\n }\r\n }\r\n\r\n formatter.update()\r\n }\r\n\r\n selectButton(formatter: BlotFormatter, button: HTMLElement) {\r\n button.classList.add('is-selected')\r\n if (formatter.options.toolbar.addButtonSelectStyle) {\r\n button.style.setProperty('filter', 'invert(20%)')\r\n }\r\n }\r\n\r\n deselectButton(formatter: BlotFormatter, button: HTMLElement) {\r\n button.classList.remove('is-selected')\r\n if (formatter.options.toolbar.addButtonSelectStyle) {\r\n button.style.removeProperty('filter')\r\n }\r\n }\r\n}\r\n"],"names":[],"mappings":"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"}
@@ -1,52 +1,26 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
3
+ var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
1
4
  import { merge } from "lodash-es";
2
5
  import Quill from "quill";
3
- import CustomImage from "./image.es.js";
4
- import ImageBar from "./image-bar.es.js";
5
- import DefaultOptions from "./Options.es.js";
6
- import { CustomImageSpec } from "./specs/CustomImageSpec.es.js";
6
+ import { CustomImage } from "./image.es.js";
7
+ import DefaultOptions from "./options.es.js";
8
+ import "./specs/index.es.js";
9
+ import { CustomImageSpec } from "./specs/custom-image-spec.es.js";
7
10
  const dontMerge = (_destination, source) => source;
8
11
  class BlotFormatter {
9
12
  constructor(quill, options = {}) {
10
- this.debounceTimer = null;
11
- this.onClick = () => {
13
+ __publicField(this, "options");
14
+ __publicField(this, "currentSpec");
15
+ __publicField(this, "specs");
16
+ __publicField(this, "overlay");
17
+ __publicField(this, "actions");
18
+ __publicField(this, "observer");
19
+ __publicField(this, "onClick", () => {
12
20
  this.hide();
13
- this.hideImageBar();
14
- };
15
- this.onMouseOver = (event) => {
16
- if (this.debounceTimer) {
17
- clearTimeout(this.debounceTimer);
18
- }
19
- this.debounceTimer = window.setTimeout(() => {
20
- if (event.target.tagName === "IMG") {
21
- const target = event.target;
22
- if (target) {
23
- if (this.imageBar) {
24
- this.imageBar.destroy();
25
- }
26
- this.imageBar = new ImageBar(this.quill, target);
27
- }
28
- } else {
29
- this.hideImageBar();
30
- }
31
- }, 150);
32
- };
33
- this.hideImageBar = () => {
34
- if (this.imageBar) {
35
- this.imageBar.destroy();
36
- this.imageBar = null;
37
- }
38
- };
39
- this.hideImageOverlay = (event) => {
40
- var _a;
41
- const target = event.target;
42
- const isBlotFormatter = (_a = target == null ? void 0 : target.classList) == null ? void 0 : _a.contains("blot-formatter__overlay");
43
- if (!isBlotFormatter) {
44
- this.hide();
45
- }
46
- document.body.removeEventListener("click", this.hideImageOverlay);
47
- };
21
+ });
48
22
  this.quill = quill;
49
- this.options = merge(DefaultOptions, options, { arrayMerge: dontMerge });
23
+ this.options = merge({}, DefaultOptions, options, { arrayMerge: dontMerge });
50
24
  this.currentSpec = null;
51
25
  this.actions = [];
52
26
  this.overlay = document.createElement("div");
@@ -56,13 +30,14 @@ class BlotFormatter {
56
30
  }
57
31
  document.execCommand("enableObjectResizing", false, "false");
58
32
  this.quill.root.addEventListener("click", this.onClick);
59
- this.quill.root.addEventListener("mouseover", (event) => this.onMouseOver(event));
60
33
  this.specs = this.options.specs.map((SpecClass) => new SpecClass(this));
61
34
  this.specs.forEach((spec) => spec.init());
62
35
  }
63
36
  static register() {
64
- Quill.register("formats/image", CustomImage, true);
65
- Quill.register("modules/image-spec", CustomImageSpec, true);
37
+ Quill.register({
38
+ "formats/image": CustomImage,
39
+ "modules/image-spec": CustomImageSpec
40
+ }, true);
66
41
  }
67
42
  show(spec) {
68
43
  this.currentSpec = spec;
@@ -90,7 +65,6 @@ class BlotFormatter {
90
65
  attributeOldValue: true,
91
66
  subtree: true
92
67
  });
93
- document.body.addEventListener("click", this.hideImageOverlay, true);
94
68
  }
95
69
  hide() {
96
70
  if (!this.currentSpec) {
@@ -130,7 +104,7 @@ class BlotFormatter {
130
104
  if (!overlayTarget) {
131
105
  return;
132
106
  }
133
- const parent = this.quill.root.parentNode;
107
+ const parent = this.quill.root.parentElement;
134
108
  const specRect = overlayTarget.getBoundingClientRect();
135
109
  const parentRect = parent.getBoundingClientRect();
136
110
  Object.assign(this.overlay.style, {
@@ -157,6 +131,6 @@ class BlotFormatter {
157
131
  }
158
132
  }
159
133
  export {
160
- BlotFormatter as default
134
+ BlotFormatter
161
135
  };
162
- //# sourceMappingURL=BlotFormatter.es.js.map
136
+ //# sourceMappingURL=blot-formatter.es.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"blot-formatter.es.js","sources":["../../../../src/modules/custom-image/blot-formatter.ts"],"sourcesContent":["import type FluentEditor from '../../core/fluent-editor'\r\nimport type { Action } from './actions'\r\nimport type { BlotFormatterOptions } from './options'\r\nimport type { BlotSpec } from './specs'\r\nimport { merge as deepmerge } from 'lodash-es'\r\nimport Quill from 'quill'\r\nimport { CustomImage } from './image'\r\nimport DefaultOptions from './options'\r\nimport { CustomImageSpec } from './specs'\r\n\r\nconst dontMerge = (_destination: Array<any>, source: Array<any>) => source\r\n\r\nexport class BlotFormatter {\r\n options: BlotFormatterOptions\r\n currentSpec: BlotSpec\r\n specs: BlotSpec[]\r\n overlay: HTMLElement\r\n actions: Action[]\r\n observer: MutationObserver\r\n\r\n static register() {\r\n Quill.register({\r\n 'formats/image': CustomImage,\r\n 'modules/image-spec': CustomImageSpec,\r\n }, true)\r\n }\r\n\r\n constructor(public quill: FluentEditor, options: Partial<BlotFormatterOptions> = {}) {\r\n this.options = deepmerge({}, DefaultOptions, options, { arrayMerge: dontMerge })\r\n this.currentSpec = null\r\n this.actions = []\r\n this.overlay = document.createElement('div')\r\n this.overlay.classList.add(this.options.overlay.className)\r\n if (this.options.overlay.style) {\r\n Object.assign(this.overlay.style, this.options.overlay.style)\r\n }\r\n\r\n // disable native image resizing on firefox\r\n document.execCommand('enableObjectResizing', false, 'false') // eslint-disable-next-line-line no-undef\r\n this.quill.root.addEventListener('click', this.onClick)\r\n this.specs = this.options.specs.map((SpecClass: any) => new SpecClass(this))\r\n this.specs.forEach(spec => spec.init())\r\n }\r\n\r\n show(spec: BlotSpec) {\r\n this.currentSpec = spec\r\n this.currentSpec.setSelection()\r\n this.setUserSelect('none')\r\n this.quill.root.parentNode.appendChild(this.overlay)\r\n this.repositionOverlay()\r\n this.createActions(spec)\r\n\r\n // fix: 图片对齐之后,虚线外框应该跟随移动\r\n const imageDom = spec.getTargetElement()\r\n const win: any = window\r\n const MutationObserver: typeof window.MutationObserver = win.MutationObserver || win.WebKitMutationObserver || win.MozMutationObserver\r\n const element = imageDom.parentNode\r\n this.observer = new MutationObserver((mutationList) => {\r\n for (const mutation of mutationList) {\r\n const target = mutation.target as HTMLElement\r\n const image = target.querySelector('img')\r\n if (image) {\r\n this.repositionOverlay()\r\n }\r\n }\r\n })\r\n this.observer.observe(element, {\r\n attributes: true,\r\n attributeFilter: ['class'],\r\n attributeOldValue: true,\r\n subtree: true,\r\n })\r\n }\r\n\r\n hide() {\r\n if (!this.currentSpec) {\r\n return\r\n }\r\n\r\n const imgDom = this.currentSpec.getTargetElement()\r\n if (imgDom) {\r\n imgDom.classList.remove('current-select-img')\r\n }\r\n\r\n this.currentSpec.onHide()\r\n this.currentSpec = null\r\n this.quill.root.parentNode.removeChild(this.overlay)\r\n this.overlay.style.setProperty('display', 'none')\r\n this.setUserSelect('')\r\n this.destroyActions()\r\n }\r\n\r\n update() {\r\n this.repositionOverlay()\r\n this.actions.forEach(action => action.onUpdate())\r\n }\r\n\r\n createActions(spec: BlotSpec) {\r\n this.actions = spec.getActions().map((ActionClass: any) => {\r\n const action: Action = new ActionClass(this)\r\n action.onCreate()\r\n return action\r\n })\r\n }\r\n\r\n destroyActions() {\r\n this.actions.forEach((action: Action) => action.onDestroy())\r\n this.actions = []\r\n }\r\n\r\n repositionOverlay() {\r\n if (!this.currentSpec) {\r\n return\r\n }\r\n\r\n const overlayTarget = this.currentSpec.getOverlayElement()\r\n if (!overlayTarget) {\r\n return\r\n }\r\n\r\n const parent = this.quill.root.parentElement\r\n const specRect = overlayTarget.getBoundingClientRect()\r\n const parentRect = parent.getBoundingClientRect()\r\n\r\n Object.assign(this.overlay.style, {\r\n display: 'block',\r\n left: `${specRect.left - parentRect.left - 1 + parent.scrollLeft}px`,\r\n top: `${specRect.top - parentRect.top + parent.scrollTop}px`,\r\n width: `${specRect.width}px`,\r\n height: `${specRect.height}px`,\r\n })\r\n }\r\n\r\n setUserSelect(value: string) {\r\n const props: string[] = [\r\n 'userSelect',\r\n 'mozUserSelect',\r\n 'webkitUserSelect',\r\n 'msUserSelect',\r\n ]\r\n\r\n props.forEach((prop: string) => {\r\n // set on contenteditable element and <html>\r\n this.quill.root.style.setProperty(prop, value)\r\n if (document.documentElement) {\r\n document.documentElement.style.setProperty(prop, value)\r\n }\r\n })\r\n }\r\n\r\n onClick = () => {\r\n this.hide()\r\n }\r\n}\r\n"],"names":["deepmerge"],"mappings":"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"}
@@ -1,5 +1,11 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
3
+ var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
1
4
  import Quill from "quill";
2
5
  import { sanitize, isNullOrUndefined } from "../../config/editor.utils.es.js";
6
+ import { isObject } from "../../utils/is.es.js";
7
+ import "./actions/index.es.js";
8
+ import { alignmentHandler, ALIGN_ATTR } from "./actions/image-toolbar-buttons.es.js";
3
9
  const Embed = Quill.import("blots/embed");
4
10
  const ATTRIBUTES = ["alt", "height", "width", "image-id"];
5
11
  const _CustomImage = class _CustomImage extends Embed {
@@ -14,8 +20,19 @@ const _CustomImage = class _CustomImage extends Embed {
14
20
  node.setAttribute("src", imgURL);
15
21
  }
16
22
  node.setAttribute("data-image-id", `img${_CustomImage.ID_SEED++}`);
17
- node.setAttribute("devui-editorx-image", "true");
18
23
  node.style.verticalAlign = "baseline";
24
+ if (isObject(value)) {
25
+ if (value.align && alignmentHandler[value.align]) {
26
+ node.setAttribute(ALIGN_ATTR, value.align);
27
+ alignmentHandler[value.align](node);
28
+ }
29
+ if (value.width) {
30
+ node.setAttribute("width", String(value.width));
31
+ }
32
+ if (value.height) {
33
+ node.setAttribute("height", String(value.height));
34
+ }
35
+ }
19
36
  return node;
20
37
  }
21
38
  static formats(domNode) {
@@ -43,8 +60,16 @@ const _CustomImage = class _CustomImage extends Embed {
43
60
  const formats = {};
44
61
  const imageSrc = domNode.getAttribute("src");
45
62
  formats.src = this.sanitize(imageSrc);
46
- formats.hasExisted = domNode.getAttribute("devui-editorx-image");
47
63
  formats.imageId = domNode.dataset.imageId;
64
+ if (domNode.dataset.align) {
65
+ formats.align = domNode.dataset.align;
66
+ }
67
+ if (domNode.hasAttribute("width")) {
68
+ formats.width = domNode.getAttribute("width");
69
+ }
70
+ if (domNode.hasAttribute("height")) {
71
+ formats.height = domNode.getAttribute("height");
72
+ }
48
73
  return formats;
49
74
  }
50
75
  format(name, value) {
@@ -73,11 +98,11 @@ const _CustomImage = class _CustomImage extends Embed {
73
98
  return wrapper;
74
99
  }
75
100
  };
76
- _CustomImage.ID_SEED = 0;
101
+ __publicField(_CustomImage, "blotName", "image");
102
+ __publicField(_CustomImage, "tagName", "IMG");
103
+ __publicField(_CustomImage, "ID_SEED", 0);
77
104
  let CustomImage = _CustomImage;
78
- CustomImage.blotName = "image";
79
- CustomImage.tagName = "IMG";
80
105
  export {
81
- CustomImage as default
106
+ CustomImage
82
107
  };
83
108
  //# sourceMappingURL=image.es.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"image.es.js","sources":["../../../../src/modules/custom-image/image.ts"],"sourcesContent":["import type TypeEmbed from 'quill/blots/embed'\r\nimport Quill from 'quill'\r\nimport { isNullOrUndefined, sanitize } from '../../config/editor.utils'\r\n\r\nconst Embed = Quill.import('blots/embed') as typeof TypeEmbed\r\nconst ATTRIBUTES = ['alt', 'height', 'width', 'image-id']\r\n\r\nexport type ImageValue = string | { src: string }\r\nclass CustomImage extends Embed {\r\n static ID_SEED = 0\r\n static blotName: string\r\n static tagName: string\r\n domNode: any\r\n parent: any\r\n scroll: any\r\n next: any\r\n static create(value: ImageValue) {\r\n const node = super.create(value) as HTMLElement\r\n const url = typeof value === 'string' ? value : value.src\r\n if (url) {\r\n const imgURL = this.sanitize(url)\r\n if (!imgURL?.startsWith('data:image')) {\r\n node.dataset.src = imgURL\r\n }\r\n node.setAttribute('src', imgURL)\r\n }\r\n node.setAttribute('data-image-id', `img${CustomImage.ID_SEED++}`)\r\n node.setAttribute('devui-editorx-image', 'true')\r\n node.style.verticalAlign = 'baseline'\r\n return node\r\n }\r\n\r\n static formats(domNode) {\r\n return ATTRIBUTES.reduce((formats, attribute) => {\r\n if (domNode.hasAttribute(attribute)) {\r\n formats[attribute] = domNode.getAttribute(attribute)\r\n }\r\n return formats\r\n }, {})\r\n }\r\n\r\n static match(url) {\r\n return /\\.(jpe?g|gif|png)$/.test(url) || /^data:image\\/.+;base64/.test(url)\r\n }\r\n\r\n static register() {\r\n if (/Firefox/i.test(navigator.userAgent)) {\r\n setTimeout(() => {\r\n // Disable image resizing in Firefox\r\n document.execCommand('enableObjectResizing', false, 'false')\r\n }, 1)\r\n }\r\n }\r\n\r\n static sanitize(url) {\r\n return sanitize(url, ['http', 'https', 'blob', 'data']) ? url : '//:0'\r\n }\r\n\r\n static value(domNode) {\r\n const formats: any = {}\r\n const imageSrc = domNode.getAttribute('src')\r\n formats.src = this.sanitize(imageSrc)\r\n formats.hasExisted = domNode.getAttribute('devui-editorx-image')\r\n formats.imageId = domNode.dataset.imageId\r\n return formats\r\n }\r\n\r\n format(name, value) {\r\n if (ATTRIBUTES.includes(name)) {\r\n if (value) {\r\n this.domNode.setAttribute(name, value)\r\n }\r\n else {\r\n this.domNode.removeAttribute(name)\r\n }\r\n }\r\n else {\r\n super.format(name, value)\r\n }\r\n }\r\n\r\n unWrap() {\r\n this.parent.replaceWith(this)\r\n }\r\n\r\n wrap(name, value) {\r\n const wrapper = typeof name === 'string' ? this.scroll.create(name, value) : name\r\n if (!isNullOrUndefined(this.parent)) {\r\n this.parent.insertBefore(wrapper, this.next || undefined)\r\n }\r\n if (typeof wrapper.appendChild !== 'function') {\r\n throw new TypeError(`Cannot wrap ${name}`)\r\n }\r\n wrapper.appendChild(this)\r\n return wrapper\r\n }\r\n}\r\nCustomImage.blotName = 'image'\r\nCustomImage.tagName = 'IMG'\r\n\r\nexport { CustomImage as default }\r\n"],"names":[],"mappings":";;AAIA,MAAM,QAAQ,MAAM,OAAO,aAAa;AACxC,MAAM,aAAa,CAAC,OAAO,UAAU,SAAS,UAAU;AAGxD,MAAM,eAAN,MAAM,qBAAoB,MAAM;AAAA,EAQ9B,OAAO,OAAO,OAAmB;AACzB,UAAA,OAAO,MAAM,OAAO,KAAK;AAC/B,UAAM,MAAM,OAAO,UAAU,WAAW,QAAQ,MAAM;AACtD,QAAI,KAAK;AACD,YAAA,SAAS,KAAK,SAAS,GAAG;AAChC,UAAI,EAAC,iCAAQ,WAAW,gBAAe;AACrC,aAAK,QAAQ,MAAM;AAAA,MAAA;AAEhB,WAAA,aAAa,OAAO,MAAM;AAAA,IAAA;AAEjC,SAAK,aAAa,iBAAiB,MAAM,aAAY,SAAS,EAAE;AAC3D,SAAA,aAAa,uBAAuB,MAAM;AAC/C,SAAK,MAAM,gBAAgB;AACpB,WAAA;AAAA,EAAA;AAAA,EAGT,OAAO,QAAQ,SAAS;AACtB,WAAO,WAAW,OAAO,CAAC,SAAS,cAAc;AAC3C,UAAA,QAAQ,aAAa,SAAS,GAAG;AACnC,gBAAQ,SAAS,IAAI,QAAQ,aAAa,SAAS;AAAA,MAAA;AAE9C,aAAA;AAAA,IACT,GAAG,EAAE;AAAA,EAAA;AAAA,EAGP,OAAO,MAAM,KAAK;AAChB,WAAO,qBAAqB,KAAK,GAAG,KAAK,yBAAyB,KAAK,GAAG;AAAA,EAAA;AAAA,EAG5E,OAAO,WAAW;AAChB,QAAI,WAAW,KAAK,UAAU,SAAS,GAAG;AACxC,iBAAW,MAAM;AAEN,iBAAA,YAAY,wBAAwB,OAAO,OAAO;AAAA,SAC1D,CAAC;AAAA,IAAA;AAAA,EACN;AAAA,EAGF,OAAO,SAAS,KAAK;AACZ,WAAA,SAAS,KAAK,CAAC,QAAQ,SAAS,QAAQ,MAAM,CAAC,IAAI,MAAM;AAAA,EAAA;AAAA,EAGlE,OAAO,MAAM,SAAS;AACpB,UAAM,UAAe,CAAC;AAChB,UAAA,WAAW,QAAQ,aAAa,KAAK;AACnC,YAAA,MAAM,KAAK,SAAS,QAAQ;AAC5B,YAAA,aAAa,QAAQ,aAAa,qBAAqB;AACvD,YAAA,UAAU,QAAQ,QAAQ;AAC3B,WAAA;AAAA,EAAA;AAAA,EAGT,OAAO,MAAM,OAAO;AACd,QAAA,WAAW,SAAS,IAAI,GAAG;AAC7B,UAAI,OAAO;AACJ,aAAA,QAAQ,aAAa,MAAM,KAAK;AAAA,MAAA,OAElC;AACE,aAAA,QAAQ,gBAAgB,IAAI;AAAA,MAAA;AAAA,IACnC,OAEG;AACG,YAAA,OAAO,MAAM,KAAK;AAAA,IAAA;AAAA,EAC1B;AAAA,EAGF,SAAS;AACF,SAAA,OAAO,YAAY,IAAI;AAAA,EAAA;AAAA,EAG9B,KAAK,MAAM,OAAO;AACV,UAAA,UAAU,OAAO,SAAS,WAAW,KAAK,OAAO,OAAO,MAAM,KAAK,IAAI;AAC7E,QAAI,CAAC,kBAAkB,KAAK,MAAM,GAAG;AACnC,WAAK,OAAO,aAAa,SAAS,KAAK,QAAQ,MAAS;AAAA,IAAA;AAEtD,QAAA,OAAO,QAAQ,gBAAgB,YAAY;AAC7C,YAAM,IAAI,UAAU,eAAe,IAAI,EAAE;AAAA,IAAA;AAE3C,YAAQ,YAAY,IAAI;AACjB,WAAA;AAAA,EAAA;AAEX;AAvFE,aAAO,UAAU;AADnB,IAAM,cAAN;AAyFA,YAAY,WAAW;AACvB,YAAY,UAAU;"}
1
+ {"version":3,"file":"image.es.js","sources":["../../../../src/modules/custom-image/image.ts"],"sourcesContent":["import type { Parchment as TypeParchment } from 'quill'\r\nimport type TypeEmbed from 'quill/blots/embed'\r\nimport Quill from 'quill'\r\nimport { isNullOrUndefined, sanitize } from '../../config/editor.utils'\r\nimport { isObject } from '../../utils/is'\r\nimport { ALIGN_ATTR, alignmentHandler } from './actions'\r\n\r\nconst Embed = Quill.import('blots/embed') as typeof TypeEmbed\r\nconst ATTRIBUTES = ['alt', 'height', 'width', 'image-id']\r\n\r\nexport type ImageValue = string | {\r\n src: string\r\n align?: string\r\n height?: number\r\n width?: number\r\n}\r\nexport class CustomImage extends Embed {\r\n static blotName = 'image'\r\n static tagName = 'IMG'\r\n static ID_SEED = 0\r\n declare domNode: HTMLElement\r\n static create(value: ImageValue) {\r\n const node = super.create(value) as HTMLElement\r\n const url = typeof value === 'string' ? value : value.src\r\n if (url) {\r\n const imgURL = this.sanitize(url)\r\n if (!imgURL?.startsWith('data:image')) {\r\n node.dataset.src = imgURL\r\n }\r\n node.setAttribute('src', imgURL)\r\n }\r\n node.setAttribute('data-image-id', `img${CustomImage.ID_SEED++}`)\r\n node.style.verticalAlign = 'baseline'\r\n if (isObject(value)) {\r\n if (value.align && alignmentHandler[value.align]) {\r\n node.setAttribute(ALIGN_ATTR, value.align)\r\n alignmentHandler[value.align](node)\r\n }\r\n if (value.width) {\r\n node.setAttribute('width', String(value.width))\r\n }\r\n if (value.height) {\r\n node.setAttribute('height', String(value.height))\r\n }\r\n }\r\n return node\r\n }\r\n\r\n static formats(domNode: HTMLElement) {\r\n return ATTRIBUTES.reduce((formats, attribute) => {\r\n if (domNode.hasAttribute(attribute)) {\r\n formats[attribute] = domNode.getAttribute(attribute)\r\n }\r\n return formats\r\n }, {})\r\n }\r\n\r\n static match(url: string) {\r\n return /\\.(jpe?g|gif|png)$/.test(url) || /^data:image\\/.+;base64/.test(url)\r\n }\r\n\r\n static register() {\r\n if (/Firefox/i.test(navigator.userAgent)) {\r\n setTimeout(() => {\r\n // Disable image resizing in Firefox\r\n document.execCommand('enableObjectResizing', false, 'false')\r\n }, 1)\r\n }\r\n }\r\n\r\n static sanitize(url: string) {\r\n return sanitize(url, ['http', 'https', 'blob', 'data']) ? url : '//:0'\r\n }\r\n\r\n static value(domNode: HTMLElement) {\r\n const formats: any = {}\r\n const imageSrc = domNode.getAttribute('src')\r\n formats.src = this.sanitize(imageSrc)\r\n formats.imageId = domNode.dataset.imageId\r\n if (domNode.dataset.align) {\r\n formats.align = domNode.dataset.align\r\n }\r\n if (domNode.hasAttribute('width')) {\r\n formats.width = domNode.getAttribute('width')\r\n }\r\n if (domNode.hasAttribute('height')) {\r\n formats.height = domNode.getAttribute('height')\r\n }\r\n return formats\r\n }\r\n\r\n format(name: string, value: any) {\r\n if (ATTRIBUTES.includes(name)) {\r\n if (value) {\r\n this.domNode.setAttribute(name, value)\r\n }\r\n else {\r\n this.domNode.removeAttribute(name)\r\n }\r\n }\r\n else {\r\n super.format(name, value)\r\n }\r\n }\r\n\r\n unWrap() {\r\n this.parent.replaceWith(this as TypeEmbed)\r\n }\r\n\r\n wrap(name: string, value?: any): TypeParchment.Parent\r\n wrap(wrapper: TypeParchment.Parent): TypeParchment.Parent\r\n wrap(name: string | TypeParchment.Parent, value?: any) {\r\n const wrapper = (typeof name === 'string' ? this.scroll.create(name, value) : name) as TypeParchment.Parent\r\n if (!isNullOrUndefined(this.parent)) {\r\n this.parent.insertBefore(wrapper, this.next || undefined)\r\n }\r\n if (typeof wrapper.appendChild !== 'function') {\r\n throw new TypeError(`Cannot wrap ${name}`)\r\n }\r\n wrapper.appendChild(this)\r\n return wrapper\r\n }\r\n}\r\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,9 @@
1
+ import "./actions/index.es.js";
2
+ import { BlotFormatter } from "./blot-formatter.es.js";
3
+ import { CustomImage } from "./image.es.js";
4
+ import "./specs/index.es.js";
5
+ export {
6
+ BlotFormatter,
7
+ CustomImage
8
+ };
9
+ //# sourceMappingURL=index.es.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.es.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;"}
@@ -0,0 +1,85 @@
1
+ import "./specs/index.es.js";
2
+ import { ImageSpec } from "./specs/image-spec.es.js";
3
+ const LEFT_ALIGN = "align-left";
4
+ const CENTER_ALIGN = "align-center";
5
+ const RIGHT_ALIGN = "align-right";
6
+ const COPY = "copy";
7
+ const DOWNLOAD = "download";
8
+ const DefaultOptions = {
9
+ specs: [
10
+ ImageSpec
11
+ ],
12
+ overlay: {
13
+ className: "blot-formatter__overlay",
14
+ style: {
15
+ position: "absolute",
16
+ boxSizing: "border-box",
17
+ border: "1px dashed #444"
18
+ }
19
+ },
20
+ toolbar: {
21
+ mainClassName: "blot-formatter__toolbar",
22
+ mainStyle: {
23
+ position: "absolute",
24
+ top: "-12px",
25
+ right: "0",
26
+ left: "0",
27
+ height: "0",
28
+ minWidth: "120px",
29
+ font: "12px/1.0 Arial, Helvetica, sans-serif",
30
+ textAlign: "center",
31
+ color: "#333",
32
+ boxSizing: "border-box",
33
+ cursor: "default",
34
+ zIndex: "1"
35
+ },
36
+ buttonClassName: "blot-formatter__toolbar-button",
37
+ addButtonSelectStyle: true,
38
+ buttonStyle: {
39
+ display: "inline-flex",
40
+ alignItems: "center",
41
+ justifyContent: "center",
42
+ width: "24px",
43
+ height: "24px",
44
+ background: "white",
45
+ border: "1px solid #999",
46
+ verticalAlign: "middle",
47
+ cursor: "pointer"
48
+ },
49
+ svgStyle: {
50
+ display: "inline-block",
51
+ width: "16px",
52
+ height: "16px",
53
+ background: "white",
54
+ verticalAlign: "middle"
55
+ },
56
+ buttons: {
57
+ [LEFT_ALIGN]: true,
58
+ [CENTER_ALIGN]: true,
59
+ [RIGHT_ALIGN]: true,
60
+ [COPY]: true,
61
+ [DOWNLOAD]: true
62
+ }
63
+ },
64
+ resize: {
65
+ handleClassName: "blot-formatter__resize-handle",
66
+ handleStyle: {
67
+ position: "absolute",
68
+ height: "12px",
69
+ width: "12px",
70
+ backgroundColor: "white",
71
+ border: "1px solid #777",
72
+ boxSizing: "border-box",
73
+ opacity: "0.80"
74
+ }
75
+ }
76
+ };
77
+ export {
78
+ CENTER_ALIGN,
79
+ COPY,
80
+ DOWNLOAD,
81
+ LEFT_ALIGN,
82
+ RIGHT_ALIGN,
83
+ DefaultOptions as default
84
+ };
85
+ //# sourceMappingURL=options.es.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"options.es.js","sources":["../../../../src/modules/custom-image/options.ts"],"sourcesContent":["import type { ImageToolbar, ImageToolbarButtons } from './actions'\r\nimport type { BlotSpec } from './specs'\r\nimport { ImageSpec } from './specs'\r\n\r\nexport interface OverlayOptions {\r\n // classname applied to the overlay element\r\n className: string\r\n // style applied to overlay element, or null to prevent styles\r\n style: Record<string, string>\r\n}\r\n\r\nexport interface ResizeOptions {\r\n // class name applied to the resize handles\r\n handleClassName: string\r\n // style applied to resize handles, or null to prevent styles\r\n handleStyle: Record<string, string>\r\n}\r\n\r\nexport interface ToolButtonOption {\r\n name: string\r\n icon: string\r\n isActive?: (el: HTMLElement) => boolean\r\n apply: (this: ImageToolbar, el: HTMLImageElement, toolbarButtons: ImageToolbarButtons) => void\r\n}\r\n\r\nexport interface ToolbarButtonOptions {\r\n buttons: Record<string, ToolButtonOption | boolean>\r\n}\r\n\r\nexport interface ToolbarOptions extends ToolbarButtonOptions {\r\n // class name applied to the root toolbar element\r\n mainClassName: string\r\n // style applied to root toolbar element, or null to prevent styles\r\n mainStyle: Record<string, unknown>\r\n // class name applied to each button in the toolbar\r\n buttonClassName: string\r\n /* whether or not to add the selected style to the buttons.\r\n they'll always get the is-selected class */\r\n addButtonSelectStyle: boolean\r\n // style applied to buttons, or null to prevent styles\r\n buttonStyle: Record<string, unknown>\r\n // style applied to the svgs in the buttons\r\n svgStyle: Record<string, unknown>\r\n}\r\n\r\nexport interface BlotFormatterOptionsInput {\r\n specs: typeof BlotSpec[]\r\n overlay: Partial<OverlayOptions>\r\n resize: Partial<ResizeOptions>\r\n toolbar: Partial<ToolbarOptions>\r\n}\r\nexport interface BlotFormatterOptions {\r\n specs: typeof BlotSpec[]\r\n overlay: OverlayOptions\r\n resize: ResizeOptions\r\n toolbar: ToolbarOptions\r\n}\r\n\r\nexport const LEFT_ALIGN = 'align-left'\r\nexport const CENTER_ALIGN = 'align-center'\r\nexport const RIGHT_ALIGN = 'align-right'\r\nexport const COPY = 'copy'\r\nexport const DOWNLOAD = 'download'\r\nconst DefaultOptions: BlotFormatterOptions = {\r\n specs: [\r\n ImageSpec,\r\n ],\r\n overlay: {\r\n className: 'blot-formatter__overlay',\r\n style: {\r\n position: 'absolute',\r\n boxSizing: 'border-box',\r\n border: '1px dashed #444',\r\n },\r\n },\r\n toolbar: {\r\n mainClassName: 'blot-formatter__toolbar',\r\n mainStyle: {\r\n position: 'absolute',\r\n top: '-12px',\r\n right: '0',\r\n left: '0',\r\n height: '0',\r\n minWidth: '120px',\r\n font: '12px/1.0 Arial, Helvetica, sans-serif',\r\n textAlign: 'center',\r\n color: '#333',\r\n boxSizing: 'border-box',\r\n cursor: 'default',\r\n zIndex: '1',\r\n },\r\n buttonClassName: 'blot-formatter__toolbar-button',\r\n addButtonSelectStyle: true,\r\n buttonStyle: {\r\n display: 'inline-flex',\r\n alignItems: 'center',\r\n justifyContent: 'center',\r\n width: '24px',\r\n height: '24px',\r\n background: 'white',\r\n border: '1px solid #999',\r\n verticalAlign: 'middle',\r\n cursor: 'pointer',\r\n },\r\n svgStyle: {\r\n display: 'inline-block',\r\n width: '16px',\r\n height: '16px',\r\n background: 'white',\r\n verticalAlign: 'middle',\r\n },\r\n buttons: {\r\n [LEFT_ALIGN]: true,\r\n [CENTER_ALIGN]: true,\r\n [RIGHT_ALIGN]: true,\r\n [COPY]: true,\r\n [DOWNLOAD]: true,\r\n },\r\n },\r\n resize: {\r\n handleClassName: 'blot-formatter__resize-handle',\r\n handleStyle: {\r\n position: 'absolute',\r\n height: '12px',\r\n width: '12px',\r\n backgroundColor: 'white',\r\n border: '1px solid #777',\r\n boxSizing: 'border-box',\r\n opacity: '0.80',\r\n },\r\n },\r\n}\r\n\r\nexport default DefaultOptions\r\n"],"names":[],"mappings":";;AA0DO,MAAM,aAAa;AACnB,MAAM,eAAe;AACrB,MAAM,cAAc;AACpB,MAAM,OAAO;AACb,MAAM,WAAW;AACxB,MAAM,iBAAuC;AAAA,EAC3C,OAAO;AAAA,IACL;AAAA,EACF;AAAA,EACA,SAAS;AAAA,IACP,WAAW;AAAA,IACX,OAAO;AAAA,MACL,UAAU;AAAA,MACV,WAAW;AAAA,MACX,QAAQ;AAAA,IAAA;AAAA,EAEZ;AAAA,EACA,SAAS;AAAA,IACP,eAAe;AAAA,IACf,WAAW;AAAA,MACT,UAAU;AAAA,MACV,KAAK;AAAA,MACL,OAAO;AAAA,MACP,MAAM;AAAA,MACN,QAAQ;AAAA,MACR,UAAU;AAAA,MACV,MAAM;AAAA,MACN,WAAW;AAAA,MACX,OAAO;AAAA,MACP,WAAW;AAAA,MACX,QAAQ;AAAA,MACR,QAAQ;AAAA,IACV;AAAA,IACA,iBAAiB;AAAA,IACjB,sBAAsB;AAAA,IACtB,aAAa;AAAA,MACX,SAAS;AAAA,MACT,YAAY;AAAA,MACZ,gBAAgB;AAAA,MAChB,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,YAAY;AAAA,MACZ,QAAQ;AAAA,MACR,eAAe;AAAA,MACf,QAAQ;AAAA,IACV;AAAA,IACA,UAAU;AAAA,MACR,SAAS;AAAA,MACT,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,YAAY;AAAA,MACZ,eAAe;AAAA,IACjB;AAAA,IACA,SAAS;AAAA,MACP,CAAC,UAAU,GAAG;AAAA,MACd,CAAC,YAAY,GAAG;AAAA,MAChB,CAAC,WAAW,GAAG;AAAA,MACf,CAAC,IAAI,GAAG;AAAA,MACR,CAAC,QAAQ,GAAG;AAAA,IAAA;AAAA,EAEhB;AAAA,EACA,QAAQ;AAAA,IACN,iBAAiB;AAAA,IACjB,aAAa;AAAA,MACX,UAAU;AAAA,MACV,QAAQ;AAAA,MACR,OAAO;AAAA,MACP,iBAAiB;AAAA,MACjB,QAAQ;AAAA,MACR,WAAW;AAAA,MACX,SAAS;AAAA,IAAA;AAAA,EACX;AAEJ;"}
@@ -0,0 +1,33 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
3
+ var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
4
+ import "../actions/index.es.js";
5
+ import { ImageToolbarAction } from "../actions/toolbar-action.es.js";
6
+ import { CustomResizeAction } from "../actions/custom-resize-action.es.js";
7
+ import { DeleteAction } from "../actions/delete-action.es.js";
8
+ class BlotSpec {
9
+ constructor(formatter) {
10
+ __publicField(this, "formatter");
11
+ this.formatter = formatter;
12
+ }
13
+ init() {
14
+ }
15
+ getActions() {
16
+ return [ImageToolbarAction, CustomResizeAction, DeleteAction];
17
+ }
18
+ getTargetElement() {
19
+ return null;
20
+ }
21
+ getOverlayElement() {
22
+ return this.getTargetElement();
23
+ }
24
+ setSelection() {
25
+ this.formatter.quill.setSelection(null);
26
+ }
27
+ onHide() {
28
+ }
29
+ }
30
+ export {
31
+ BlotSpec
32
+ };
33
+ //# sourceMappingURL=blot-spec.es.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"blot-spec.es.js","sources":["../../../../../src/modules/custom-image/specs/blot-spec.ts"],"sourcesContent":["import type { BlotFormatter } from '../blot-formatter'\r\nimport { CustomResizeAction, DeleteAction, ImageToolbarAction } from '../actions'\r\n\r\nexport class BlotSpec {\r\n formatter: BlotFormatter\r\n\r\n constructor(formatter: BlotFormatter) {\r\n this.formatter = formatter\r\n }\r\n\r\n init(): void {}\r\n\r\n getActions() {\r\n return [ImageToolbarAction, CustomResizeAction, DeleteAction]\r\n }\r\n\r\n getTargetElement(): HTMLElement | null {\r\n return null\r\n }\r\n\r\n getOverlayElement() {\r\n return this.getTargetElement()\r\n }\r\n\r\n setSelection(): void {\r\n this.formatter.quill.setSelection(null)\r\n }\r\n\r\n onHide() {}\r\n}\r\n"],"names":[],"mappings":";;;;;;;AAGO,MAAM,SAAS;AAAA,EAGpB,YAAY,WAA0B;AAFtC;AAGE,SAAK,YAAY;AAAA,EAAA;AAAA,EAGnB,OAAa;AAAA,EAAA;AAAA,EAEb,aAAa;AACJ,WAAA,CAAC,oBAAoB,oBAAoB,YAAY;AAAA,EAAA;AAAA,EAG9D,mBAAuC;AAC9B,WAAA;AAAA,EAAA;AAAA,EAGT,oBAAoB;AAClB,WAAO,KAAK,iBAAiB;AAAA,EAAA;AAAA,EAG/B,eAAqB;AACd,SAAA,UAAU,MAAM,aAAa,IAAI;AAAA,EAAA;AAAA,EAGxC,SAAS;AAAA,EAAA;AACX;"}
@@ -1,19 +1,23 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
3
+ var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
1
4
  import { isInside } from "../../../config/editor.utils.es.js";
2
- import CustomResizeAction from "../actions/CustomResizeAction.es.js";
3
- import DeleteAction from "../actions/DeleteAction.es.js";
4
- import ImageSpec from "./ImageSpec.es.js";
5
+ import { ImageSpec } from "./image-spec.es.js";
5
6
  class CustomImageSpec extends ImageSpec {
6
7
  constructor(formatter) {
7
8
  super(formatter);
8
- this.imageMouseout = (event) => {
9
+ __publicField(this, "editorElem");
10
+ __publicField(this, "observer");
11
+ __publicField(this, "oldRootScrollTop");
12
+ __publicField(this, "imageMouseout", (event) => {
9
13
  if (event.target.nodeName === "IMG" || event.target.classList.contains("blot-formatter__overlay")) {
10
14
  const imgDom = event.target;
11
15
  if (!isInside(event, imgDom)) {
12
16
  this.removeImagePreviewOverlay();
13
17
  }
14
18
  }
15
- };
16
- this.onClick = (event) => {
19
+ });
20
+ __publicField(this, "onClick", (event) => {
17
21
  var _a;
18
22
  const el = event.target;
19
23
  const isReadonly = this.formatter.quill.options.readOnly;
@@ -33,13 +37,11 @@ class CustomImageSpec extends ImageSpec {
33
37
  const len = imgBlot.length();
34
38
  quill.setSelection(index, len);
35
39
  }
36
- };
40
+ });
37
41
  this.formatter = formatter;
38
42
  this.oldRootScrollTop = this.formatter.quill.root.scrollTop;
39
43
  this.editorElem = this.formatter.quill.container;
40
- if (this.formatter.quill.root === this.formatter.quill.scrollingContainer) {
41
- this.formatter.quill.root.addEventListener("scroll", this.handleQuillRootScroll.bind(this));
42
- }
44
+ this.formatter.quill.root.addEventListener("scroll", this.handleQuillRootScroll.bind(this));
43
45
  }
44
46
  handleQuillRootScroll() {
45
47
  if (this.formatter.overlay) {
@@ -51,9 +53,6 @@ class CustomImageSpec extends ImageSpec {
51
53
  this.editorElem.addEventListener("mouseout", this.imageMouseout);
52
54
  super.init();
53
55
  }
54
- getActions() {
55
- return [DeleteAction, CustomResizeAction];
56
- }
57
56
  imageMouseOver(event) {
58
57
  var _a;
59
58
  const target = event.target;
@@ -114,4 +113,4 @@ class CustomImageSpec extends ImageSpec {
114
113
  export {
115
114
  CustomImageSpec
116
115
  };
117
- //# sourceMappingURL=CustomImageSpec.es.js.map
116
+ //# sourceMappingURL=custom-image-spec.es.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"custom-image-spec.es.js","sources":["../../../../../src/modules/custom-image/specs/custom-image-spec.ts"],"sourcesContent":["import type { BlotFormatter } from '../blot-formatter'\r\nimport { isInside } from '../../../config/editor.utils'\r\nimport { ImageSpec } from './image-spec'\r\n\r\nexport class CustomImageSpec extends ImageSpec {\r\n editorElem: HTMLElement | undefined\r\n observer: any\r\n oldRootScrollTop: number\r\n\r\n constructor(formatter: BlotFormatter) {\r\n super(formatter)\r\n this.formatter = formatter\r\n this.oldRootScrollTop = this.formatter.quill.root.scrollTop\r\n this.editorElem = this.formatter.quill.container\r\n this.formatter.quill.root.addEventListener('scroll', this.handleQuillRootScroll.bind(this))\r\n }\r\n\r\n handleQuillRootScroll() {\r\n if (this.formatter.overlay) {\r\n this.formatter.overlay.style.marginTop = `${this.oldRootScrollTop - this.formatter.quill.root.scrollTop}px`\r\n }\r\n }\r\n\r\n init(): void {\r\n this.editorElem.addEventListener('mouseover', this.imageMouseOver.bind(this))\r\n this.editorElem.addEventListener('mouseout', this.imageMouseout)\r\n\r\n super.init()\r\n }\r\n\r\n imageMouseOver(event) {\r\n const target = event.target\r\n const isBlotFormatter = target?.classList?.contains('blot-formatter__overlay')\r\n if (target.nodeName === 'IMG' || isBlotFormatter) {\r\n // this.addImagePreviewOverlay(event);\r\n }\r\n }\r\n\r\n imageMouseout = (event) => {\r\n if (event.target.nodeName === 'IMG'\r\n || event.target.classList.contains('blot-formatter__overlay')) {\r\n const imgDom = event.target\r\n if (!isInside(event, imgDom)) {\r\n this.removeImagePreviewOverlay()\r\n }\r\n }\r\n }\r\n\r\n addImagePreviewOverlay(event) {\r\n const target = event.target\r\n const {\r\n left: imgLeft,\r\n width: imgWidth,\r\n } = target.getBoundingClientRect()\r\n // fix: 解决 ql-container 容器设置 calc(100vh - 180px) 这样的视窗相对单位时,滚动视窗导致图片相对视窗的 top 相应改变,从而导致图片预览按钮的位置显示错误\r\n const imgTop = target.getBoundingClientRect().top + this.formatter.quill.container.scrollTop\r\n\r\n const {\r\n left: editorLeft,\r\n top: editorTop,\r\n } = event.currentTarget.getBoundingClientRect()\r\n\r\n const imgRelativeLeft = imgLeft - editorLeft\r\n const imgRelativeTop = imgTop - editorTop\r\n\r\n const maxmizeWidth = 24\r\n const maxmizePadding = 15\r\n const previewLeft = imgRelativeLeft + imgWidth - maxmizeWidth - maxmizePadding\r\n const previewTop = imgRelativeTop + maxmizePadding\r\n\r\n const previewStyle = `\r\n left: ${previewLeft}px;\r\n top: ${previewTop}px;\r\n width: ${maxmizeWidth}px;\r\n `\r\n const imageSrc = target.src || target.getAttribute('data-image')\r\n const imageId = target.getAttribute('data-image-id')\r\n\r\n const previewDom = event.currentTarget.querySelector('.image-preview__overlay')\r\n if (!previewDom) {\r\n event.currentTarget.insertAdjacentHTML('beforeend', `\r\n <div class=\"image-preview__overlay\" style=\"${previewStyle}\">\r\n <i class=\"icon-maxmize\" id=\"btn-image-preview\" data-image-id=\"${imageId}\"\r\n data-image=\"${imageSrc}\"></i>\r\n </div>\r\n `)\r\n }\r\n }\r\n\r\n removeImagePreviewOverlay() {\r\n const previewDom = this.editorElem.querySelector('.image-preview__overlay')\r\n if (previewDom) {\r\n previewDom.parentNode.removeChild(previewDom)\r\n }\r\n }\r\n\r\n onHide() {\r\n this.removeImagePreviewOverlay()\r\n super.onHide()\r\n }\r\n\r\n resetOverlayMarginTop() {\r\n if (this.formatter.overlay) {\r\n this.formatter.overlay.style.marginTop = '0px'\r\n }\r\n }\r\n\r\n onClick = (event: MouseEvent) => {\r\n const el = event.target\r\n const isReadonly = this.formatter.quill.options.readOnly\r\n if (!(el instanceof HTMLElement) || el.tagName !== 'IMG' || isReadonly) {\r\n return\r\n }\r\n\r\n this.img = el as HTMLImageElement\r\n this.oldRootScrollTop = this.formatter.quill.root.scrollTop\r\n this.resetOverlayMarginTop()\r\n this.formatter.show(this)\r\n\r\n // 通过图片dom获取图片选区用以复制,设置 current-select-img::selection 取消选区背景\r\n const imageDom = this.formatter.currentSpec?.getTargetElement()\r\n if (imageDom) {\r\n imageDom.classList.add('current-select-img')\r\n const quill = this.formatter.quill\r\n const imgBlot = quill.scroll.find(this.img)\r\n const index = quill.getIndex(imgBlot)\r\n const len = imgBlot.length()\r\n quill.setSelection(index, len)\r\n }\r\n }\r\n}\r\n"],"names":[],"mappings":"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"}