@worktile/theia 18.0.15 → 18.1.0

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 (370) hide show
  1. package/constants/node-types.d.ts +1 -0
  2. package/core/toolbar-item/base-toolbar-item.d.ts +2 -2
  3. package/fesm2022/worktile-theia.mjs +304 -311
  4. package/fesm2022/worktile-theia.mjs.map +1 -1
  5. package/interfaces/view-base.d.ts +1 -1
  6. package/package.json +2 -4
  7. package/plugins/code/code.component.scss +1 -2
  8. package/plugins/image/image.component.d.ts +1 -1
  9. package/plugins/link/link.component.d.ts +1 -1
  10. package/plugins/mention/suggestion.component.d.ts +1 -1
  11. package/plugins/vertical-align/toolbar-item.component.d.ts +3 -2
  12. package/esm2022/components/action/prevent-default.mjs +0 -21
  13. package/esm2022/components/column-resize/column-resize-notifier.mjs +0 -31
  14. package/esm2022/components/column-resize/column-resize.directive.mjs +0 -124
  15. package/esm2022/components/column-resize/event-dispatcher.mjs +0 -56
  16. package/esm2022/components/column-resize/overlay-handle.component.mjs +0 -144
  17. package/esm2022/components/column-resize/resize-ref.mjs +0 -26
  18. package/esm2022/components/column-resize/resizing.store.mjs +0 -92
  19. package/esm2022/components/column-resize/selectors.mjs +0 -4
  20. package/esm2022/components/contextmenu/contextmenu.component.mjs +0 -99
  21. package/esm2022/components/conversion-hint/conversion-hint.component.mjs +0 -56
  22. package/esm2022/components/element/element.component.mjs +0 -23
  23. package/esm2022/components/index.mjs +0 -24
  24. package/esm2022/components/inline-toolbar/inline-toolbar.component.mjs +0 -131
  25. package/esm2022/components/listbox/listbox.mjs +0 -380
  26. package/esm2022/components/listbox/listbox.type.mjs +0 -5
  27. package/esm2022/components/plugin-menu/plugin-menu.component.mjs +0 -272
  28. package/esm2022/components/table-select/table-select.component.mjs +0 -49
  29. package/esm2022/components/template/template.component.mjs +0 -62
  30. package/esm2022/components/text/text.component.mjs +0 -57
  31. package/esm2022/components/toolbar/toolbar.component.mjs +0 -262
  32. package/esm2022/components/toolbar-dropdown/toolbar-dropdown.component.mjs +0 -137
  33. package/esm2022/components/toolbar-group/toolbar-group.component.mjs +0 -125
  34. package/esm2022/components/toolbar-item/toolbar-item.component.mjs +0 -80
  35. package/esm2022/constants/auto-format-rules.mjs +0 -167
  36. package/esm2022/constants/code.mjs +0 -85
  37. package/esm2022/constants/color-select.mjs +0 -3
  38. package/esm2022/constants/default.mjs +0 -11
  39. package/esm2022/constants/error.mjs +0 -7
  40. package/esm2022/constants/index.mjs +0 -9
  41. package/esm2022/constants/node-types.mjs +0 -136
  42. package/esm2022/constants/plugin-menu.mjs +0 -311
  43. package/esm2022/constants/selector.mjs +0 -3
  44. package/esm2022/constants/toolbar.mjs +0 -53
  45. package/esm2022/core/create-plugin.mjs +0 -5
  46. package/esm2022/core/create-toolbar.mjs +0 -55
  47. package/esm2022/core/index.mjs +0 -6
  48. package/esm2022/core/toolbar-item/base-toolbar-item.mjs +0 -95
  49. package/esm2022/core/utils/combine-plugins.mjs +0 -10
  50. package/esm2022/core/utils/flatten-deep-plugins.mjs +0 -19
  51. package/esm2022/core/utils/get-plugin-options.mjs +0 -3
  52. package/esm2022/core/utils/get-plugin.mjs +0 -2
  53. package/esm2022/core/utils/get-plugins.mjs +0 -4
  54. package/esm2022/core/utils/index.mjs +0 -12
  55. package/esm2022/core/utils/merge-array.mjs +0 -18
  56. package/esm2022/core/utils/merge-deep-plugins.mjs +0 -14
  57. package/esm2022/core/utils/merge-options.mjs +0 -25
  58. package/esm2022/core/utils/nested-structure-by-key.mjs +0 -11
  59. package/esm2022/core/utils/plugin-menu.mjs +0 -63
  60. package/esm2022/core/utils/plugins-by-key.mjs +0 -10
  61. package/esm2022/core/with-theia.mjs +0 -25
  62. package/esm2022/custom-types.mjs +0 -2
  63. package/esm2022/editor.component.mjs +0 -488
  64. package/esm2022/editor.module.mjs +0 -18
  65. package/esm2022/i18n/i18n.mjs +0 -10
  66. package/esm2022/i18n/i18n.service.mjs +0 -46
  67. package/esm2022/i18n/i18n.token.mjs +0 -9
  68. package/esm2022/i18n/index.mjs +0 -10
  69. package/esm2022/i18n/locales/de-de.mjs +0 -102
  70. package/esm2022/i18n/locales/en-us.mjs +0 -102
  71. package/esm2022/i18n/locales/ja-jp.mjs +0 -102
  72. package/esm2022/i18n/locales/ru-ru.mjs +0 -102
  73. package/esm2022/i18n/locales/zh-hans.mjs +0 -102
  74. package/esm2022/i18n/locales/zh-hant.mjs +0 -102
  75. package/esm2022/interfaces/auto-format.mjs +0 -2
  76. package/esm2022/interfaces/editor.mjs +0 -26
  77. package/esm2022/interfaces/element.mjs +0 -2
  78. package/esm2022/interfaces/image.mjs +0 -3
  79. package/esm2022/interfaces/index.mjs +0 -11
  80. package/esm2022/interfaces/plugins/index.mjs +0 -6
  81. package/esm2022/interfaces/plugins/no-infer.mjs +0 -2
  82. package/esm2022/interfaces/plugins/plugin-key.mjs +0 -42
  83. package/esm2022/interfaces/plugins/plugin-menu.mjs +0 -19
  84. package/esm2022/interfaces/plugins/plugins.mjs +0 -2
  85. package/esm2022/interfaces/plugins/with-override.mjs +0 -2
  86. package/esm2022/interfaces/preset.mjs +0 -3
  87. package/esm2022/interfaces/reset-block-type-plugin-options.mjs +0 -2
  88. package/esm2022/interfaces/toolbar.mjs +0 -12
  89. package/esm2022/interfaces/upload.mjs +0 -2
  90. package/esm2022/interfaces/utility/index.mjs +0 -4
  91. package/esm2022/interfaces/utility/nested-structure-by-key.mjs +0 -2
  92. package/esm2022/interfaces/utility/override-by-key.mjs +0 -2
  93. package/esm2022/interfaces/utility/types.mjs +0 -2
  94. package/esm2022/interfaces/valid-children-types.mjs +0 -36
  95. package/esm2022/interfaces/view-base.mjs +0 -38
  96. package/esm2022/pipes.mjs +0 -61
  97. package/esm2022/plugins/align/align.editor.mjs +0 -41
  98. package/esm2022/plugins/align/align.plugin.mjs +0 -64
  99. package/esm2022/plugins/autoformat/autoformat.plugin.mjs +0 -109
  100. package/esm2022/plugins/autoformat/transforms/auto-format-block.mjs +0 -14
  101. package/esm2022/plugins/autoformat/transforms/auto-format-inline.mjs +0 -78
  102. package/esm2022/plugins/blockquote/blockquote.component.mjs +0 -16
  103. package/esm2022/plugins/blockquote/blockquote.editor.mjs +0 -20
  104. package/esm2022/plugins/blockquote/blockquote.plugin.mjs +0 -84
  105. package/esm2022/plugins/code/code.component.mjs +0 -255
  106. package/esm2022/plugins/code/code.editor.mjs +0 -59
  107. package/esm2022/plugins/code/code.plugin.mjs +0 -67
  108. package/esm2022/plugins/color/color.editor.mjs +0 -27
  109. package/esm2022/plugins/color/color.plugin.mjs +0 -32
  110. package/esm2022/plugins/color/toolbar-item.component.mjs +0 -99
  111. package/esm2022/plugins/common/block-card.plugin.mjs +0 -330
  112. package/esm2022/plugins/common/common.plugin.mjs +0 -49
  113. package/esm2022/plugins/common/get-fragment.plugin.mjs +0 -24
  114. package/esm2022/plugins/common/history.plugin.mjs +0 -31
  115. package/esm2022/plugins/common/insert-data-by-invalid-type.mjs +0 -23
  116. package/esm2022/plugins/common/move-selection.plugin.mjs +0 -105
  117. package/esm2022/plugins/common/remove-empty.plugin.mjs +0 -61
  118. package/esm2022/plugins/common/remove-void.plugin.mjs +0 -60
  119. package/esm2022/plugins/common/reset-type.plugin.mjs +0 -35
  120. package/esm2022/plugins/deserialize/deserialize-html.plugin.mjs +0 -61
  121. package/esm2022/plugins/deserialize/deserialize-md.plugin.mjs +0 -142
  122. package/esm2022/plugins/font-size/font-size.editor.mjs +0 -98
  123. package/esm2022/plugins/heading/heading.editor.mjs +0 -54
  124. package/esm2022/plugins/heading/heading.plugin.mjs +0 -136
  125. package/esm2022/plugins/hr/hr.component.mjs +0 -37
  126. package/esm2022/plugins/hr/hr.editor.mjs +0 -16
  127. package/esm2022/plugins/hr/hr.plugin.mjs +0 -56
  128. package/esm2022/plugins/image/image.component.mjs +0 -474
  129. package/esm2022/plugins/image/image.editor.mjs +0 -116
  130. package/esm2022/plugins/image/image.plugin.mjs +0 -90
  131. package/esm2022/plugins/indent/indent.editor.mjs +0 -78
  132. package/esm2022/plugins/indent/indent.plugin.mjs +0 -59
  133. package/esm2022/plugins/indent/on-keydown-indent.mjs +0 -59
  134. package/esm2022/plugins/index.mjs +0 -73
  135. package/esm2022/plugins/inline-code/inline-code.component.mjs +0 -28
  136. package/esm2022/plugins/inline-code/inline-code.editor.mjs +0 -49
  137. package/esm2022/plugins/inline-code/inline-code.plugin.mjs +0 -67
  138. package/esm2022/plugins/link/edit/link-edit.component.mjs +0 -104
  139. package/esm2022/plugins/link/hover/link-hover.component.mjs +0 -38
  140. package/esm2022/plugins/link/link.component.mjs +0 -170
  141. package/esm2022/plugins/link/link.editor.mjs +0 -87
  142. package/esm2022/plugins/link/link.plugin.mjs +0 -89
  143. package/esm2022/plugins/link/link.types.mjs +0 -12
  144. package/esm2022/plugins/list/components/bulleted-list.component.mjs +0 -28
  145. package/esm2022/plugins/list/components/list-item.component.mjs +0 -88
  146. package/esm2022/plugins/list/components/numbered-list.component.mjs +0 -37
  147. package/esm2022/plugins/list/list.editor.mjs +0 -128
  148. package/esm2022/plugins/list/list.plugin.mjs +0 -302
  149. package/esm2022/plugins/list/normalizers/get-list-normalizer.mjs +0 -39
  150. package/esm2022/plugins/list/normalizers/normalize-list-item.mjs +0 -18
  151. package/esm2022/plugins/list/normalizers/normalize-no.mjs +0 -43
  152. package/esm2022/plugins/list/on-key-down-list.mjs +0 -33
  153. package/esm2022/plugins/list/queries/get-list-item-entry.mjs +0 -28
  154. package/esm2022/plugins/list/queries/get-list-item-sublist.mjs +0 -12
  155. package/esm2022/plugins/list/queries/get-list-types.mjs +0 -5
  156. package/esm2022/plugins/list/queries/get-start-list-item.mjs +0 -27
  157. package/esm2022/plugins/list/queries/has-list-in-list-item.mjs +0 -27
  158. package/esm2022/plugins/list/queries/is-in-list.mjs +0 -6
  159. package/esm2022/plugins/list/queries/is-list-nested.mjs +0 -10
  160. package/esm2022/plugins/list/queries/is-list.mjs +0 -5
  161. package/esm2022/plugins/list/queries/is-node-type-list.mjs +0 -5
  162. package/esm2022/plugins/list/queries/is-selection-at-list-item-start.mjs +0 -13
  163. package/esm2022/plugins/list/queries/is-selection-in-same-list-item.mjs +0 -17
  164. package/esm2022/plugins/list/queries/is-single-list-item.mjs +0 -9
  165. package/esm2022/plugins/list/transforms/insert-list-data.mjs +0 -72
  166. package/esm2022/plugins/list/transforms/insert-list-item.mjs +0 -73
  167. package/esm2022/plugins/list/transforms/move-list-item-down.mjs +0 -41
  168. package/esm2022/plugins/list/transforms/move-list-item-sublist-items-to-list-item-sublist.mjs +0 -43
  169. package/esm2022/plugins/list/transforms/move-list-item-sublist-items-to-list.mjs +0 -30
  170. package/esm2022/plugins/list/transforms/move-list-item-up.mjs +0 -78
  171. package/esm2022/plugins/list/transforms/unwrap-list.mjs +0 -10
  172. package/esm2022/plugins/list/types.mjs +0 -2
  173. package/esm2022/plugins/mark/mark.editor.mjs +0 -28
  174. package/esm2022/plugins/mark/mark.plugin.mjs +0 -105
  175. package/esm2022/plugins/mention/index.mjs +0 -5
  176. package/esm2022/plugins/mention/mention.editor.mjs +0 -179
  177. package/esm2022/plugins/mention/mention.plugin.mjs +0 -92
  178. package/esm2022/plugins/mention/mention.type.mjs +0 -2
  179. package/esm2022/plugins/mention/suggestion.component.mjs +0 -22
  180. package/esm2022/plugins/node-id/node-id.plugin.mjs +0 -78
  181. package/esm2022/plugins/normalizers/insert-paragraph-nodes.mjs +0 -28
  182. package/esm2022/plugins/normalizers/remove-empty-nodes.mjs +0 -18
  183. package/esm2022/plugins/normalizers/trailing-node.plugin.mjs +0 -33
  184. package/esm2022/plugins/paint-format/paint-format.editor.mjs +0 -126
  185. package/esm2022/plugins/public-api.mjs +0 -20
  186. package/esm2022/plugins/quick-insert/components/quick-insert.component.mjs +0 -126
  187. package/esm2022/plugins/quick-insert/index.mjs +0 -4
  188. package/esm2022/plugins/quick-insert/quick-insert.editor.mjs +0 -70
  189. package/esm2022/plugins/quick-insert/quick-insert.plugin.mjs +0 -109
  190. package/esm2022/plugins/soft-break/soft-break.plugin.mjs +0 -36
  191. package/esm2022/plugins/soft-break/soft-break.types.mjs +0 -2
  192. package/esm2022/plugins/table/components/insert-mark/insert-mark.component.mjs +0 -132
  193. package/esm2022/plugins/table/components/row/row.component.mjs +0 -93
  194. package/esm2022/plugins/table/components/table.component.mjs +0 -887
  195. package/esm2022/plugins/table/components/td/td.component.mjs +0 -610
  196. package/esm2022/plugins/table/components/toolbar/table-options.component.mjs +0 -102
  197. package/esm2022/plugins/table/components/toolbar/table-toolbar.component.mjs +0 -179
  198. package/esm2022/plugins/table/table.editor.mjs +0 -301
  199. package/esm2022/plugins/table/table.pipe.mjs +0 -66
  200. package/esm2022/plugins/table/table.plugin.mjs +0 -556
  201. package/esm2022/plugins/table/table.service.mjs +0 -122
  202. package/esm2022/plugins/table/table.store.mjs +0 -417
  203. package/esm2022/plugins/table/table.types.mjs +0 -68
  204. package/esm2022/plugins/table/toolbar-item.component.mjs +0 -95
  205. package/esm2022/plugins/table/transforms/clear-cell.mjs +0 -14
  206. package/esm2022/plugins/table/transforms/clear-table-node.mjs +0 -27
  207. package/esm2022/plugins/table/transforms/index.mjs +0 -8
  208. package/esm2022/plugins/table/transforms/insert-column.mjs +0 -69
  209. package/esm2022/plugins/table/transforms/insert-row.mjs +0 -50
  210. package/esm2022/plugins/table/transforms/insert-table.mjs +0 -15
  211. package/esm2022/plugins/table/transforms/move-selection-from-cell.mjs +0 -91
  212. package/esm2022/plugins/table/transforms/remove-column.mjs +0 -51
  213. package/esm2022/plugins/table/transforms/remove-row.mjs +0 -48
  214. package/esm2022/plugins/table/transforms/remove-table.mjs +0 -49
  215. package/esm2022/plugins/table/utils/add-columns.mjs +0 -38
  216. package/esm2022/plugins/table/utils/calc-anchor-position.mjs +0 -26
  217. package/esm2022/plugins/table/utils/calc-span.mjs +0 -73
  218. package/esm2022/plugins/table/utils/calculate-table.mjs +0 -116
  219. package/esm2022/plugins/table/utils/cell-position.mjs +0 -57
  220. package/esm2022/plugins/table/utils/create-cell.mjs +0 -19
  221. package/esm2022/plugins/table/utils/create-row.mjs +0 -12
  222. package/esm2022/plugins/table/utils/create-table-position.mjs +0 -10
  223. package/esm2022/plugins/table/utils/create-table.mjs +0 -15
  224. package/esm2022/plugins/table/utils/get-grid-columns.mjs +0 -79
  225. package/esm2022/plugins/table/utils/get-min-max-cell-index.mjs +0 -69
  226. package/esm2022/plugins/table/utils/get-next-cell.mjs +0 -44
  227. package/esm2022/plugins/table/utils/get-select-cell-node.mjs +0 -16
  228. package/esm2022/plugins/table/utils/handle-cell.mjs +0 -25
  229. package/esm2022/plugins/table/utils/index.mjs +0 -16
  230. package/esm2022/plugins/table/utils/is-header-row.mjs +0 -15
  231. package/esm2022/plugins/table/utils/is-legal-table.mjs +0 -26
  232. package/esm2022/plugins/table/utils/is-range-in-table.mjs +0 -16
  233. package/esm2022/plugins/table/utils/is-selection-in-table.mjs +0 -51
  234. package/esm2022/plugins/table/utils/is-virtual-key.mjs +0 -13
  235. package/esm2022/plugins/table/utils/merge-cell.mjs +0 -110
  236. package/esm2022/plugins/table/utils/next-path.mjs +0 -5
  237. package/esm2022/plugins/table/utils/normalize-table.mjs +0 -31
  238. package/esm2022/plugins/table/utils/remove-columns.mjs +0 -23
  239. package/esm2022/plugins/table/utils/remove-row-column.mjs +0 -45
  240. package/esm2022/plugins/table/utils/set-menu-cell-invisibility.mjs +0 -45
  241. package/esm2022/plugins/table/utils/split-cell.mjs +0 -29
  242. package/esm2022/plugins/table/utils/table-entry.mjs +0 -21
  243. package/esm2022/plugins/table/utils/table-position.mjs +0 -251
  244. package/esm2022/plugins/table/utils/table-viewport.mjs +0 -41
  245. package/esm2022/plugins/todo-item/todo-item.component.mjs +0 -65
  246. package/esm2022/plugins/todo-item/todo-item.editor.mjs +0 -32
  247. package/esm2022/plugins/todo-item/todo-item.plugin.mjs +0 -93
  248. package/esm2022/plugins/vertical-align/toolbar-item.component.mjs +0 -89
  249. package/esm2022/plugins/vertical-align/vertical-align.editor.mjs +0 -59
  250. package/esm2022/public-api.mjs +0 -22
  251. package/esm2022/queries/anchor-block-entry.mjs +0 -13
  252. package/esm2022/queries/anchor-block.mjs +0 -6
  253. package/esm2022/queries/anchor-inline-entry.mjs +0 -10
  254. package/esm2022/queries/find-descendant.mjs +0 -47
  255. package/esm2022/queries/find-node.mjs +0 -45
  256. package/esm2022/queries/find-path.mjs +0 -28
  257. package/esm2022/queries/get-above-by-type.mjs +0 -14
  258. package/esm2022/queries/get-above.mjs +0 -9
  259. package/esm2022/queries/get-anchor-block-entry.mjs +0 -8
  260. package/esm2022/queries/get-block-above.mjs +0 -10
  261. package/esm2022/queries/get-block-card-above.mjs +0 -10
  262. package/esm2022/queries/get-block-card-cursor.mjs +0 -9
  263. package/esm2022/queries/get-container-blocks.mjs +0 -12
  264. package/esm2022/queries/get-directly-parent.mjs +0 -12
  265. package/esm2022/queries/get-insert-elements-path.mjs +0 -46
  266. package/esm2022/queries/get-last-child-path.mjs +0 -9
  267. package/esm2022/queries/get-last-node.mjs +0 -17
  268. package/esm2022/queries/get-next-sibling-nodes.mjs +0 -17
  269. package/esm2022/queries/get-node.mjs +0 -10
  270. package/esm2022/queries/get-nodes-by-type.mjs +0 -15
  271. package/esm2022/queries/get-nodes.mjs +0 -7
  272. package/esm2022/queries/get-parent.mjs +0 -12
  273. package/esm2022/queries/get-plain-text.mjs +0 -16
  274. package/esm2022/queries/get-plugin-by-toolbar.mjs +0 -13
  275. package/esm2022/queries/get-point-before.mjs +0 -62
  276. package/esm2022/queries/get-point-from-location.mjs +0 -15
  277. package/esm2022/queries/get-previous-path.mjs +0 -9
  278. package/esm2022/queries/get-rang-from-block-start.mjs +0 -16
  279. package/esm2022/queries/get-range-before.mjs +0 -17
  280. package/esm2022/queries/get-selection-marks.mjs +0 -18
  281. package/esm2022/queries/get-selection-nodes-by-type.mjs +0 -30
  282. package/esm2022/queries/get-text.mjs +0 -9
  283. package/esm2022/queries/get-toolbar-disabled.mjs +0 -13
  284. package/esm2022/queries/index.mjs +0 -62
  285. package/esm2022/queries/is-across-blocks.mjs +0 -7
  286. package/esm2022/queries/is-ancestor-empty.mjs +0 -6
  287. package/esm2022/queries/is-ancestor.mjs +0 -3
  288. package/esm2022/queries/is-block-above-empty.mjs +0 -11
  289. package/esm2022/queries/is-block-active.mjs +0 -8
  290. package/esm2022/queries/is-block-card-cursor.mjs +0 -16
  291. package/esm2022/queries/is-block-text-empty-after-selection.mjs +0 -31
  292. package/esm2022/queries/is-collapsed.mjs +0 -7
  293. package/esm2022/queries/is-contain-nested-type.mjs +0 -29
  294. package/esm2022/queries/is-container-type.mjs +0 -3
  295. package/esm2022/queries/is-descendant.mjs +0 -3
  296. package/esm2022/queries/is-empty-content-filter.mjs +0 -22
  297. package/esm2022/queries/is-empty-content.mjs +0 -15
  298. package/esm2022/queries/is-empty-paragraph-by-path.mjs +0 -7
  299. package/esm2022/queries/is-empty-paragraph.mjs +0 -28
  300. package/esm2022/queries/is-first-child.mjs +0 -5
  301. package/esm2022/queries/is-global-collapsed.mjs +0 -5
  302. package/esm2022/queries/is-include-types.mjs +0 -12
  303. package/esm2022/queries/is-node-type-in.mjs +0 -9
  304. package/esm2022/queries/is-node-type.mjs +0 -15
  305. package/esm2022/queries/is-paragraph.mjs +0 -9
  306. package/esm2022/queries/is-point-at-root.mjs +0 -2
  307. package/esm2022/queries/is-range-across-blocks.mjs +0 -22
  308. package/esm2022/queries/is-range-at-root.mjs +0 -3
  309. package/esm2022/queries/is-root-path.mjs +0 -2
  310. package/esm2022/queries/is-start.mjs +0 -6
  311. package/esm2022/queries/some-node.mjs +0 -9
  312. package/esm2022/services/context.service.mjs +0 -140
  313. package/esm2022/services/table-contextmenu.service.mjs +0 -288
  314. package/esm2022/services/toolbar.service.mjs +0 -47
  315. package/esm2022/shortcuts/index.mjs +0 -5
  316. package/esm2022/shortcuts/mark.mjs +0 -25
  317. package/esm2022/test/basic/basic.component.mjs +0 -61
  318. package/esm2022/test/faker/data-transfer-faker.mjs +0 -13
  319. package/esm2022/test/faker/tethys-icon-faker.mjs +0 -22
  320. package/esm2022/test/index.mjs +0 -7
  321. package/esm2022/test/utils/mock-plugins.mjs +0 -104
  322. package/esm2022/test/utils/preset-config.mjs +0 -17
  323. package/esm2022/test/utils/with-plugin.mjs +0 -11
  324. package/esm2022/transforms/apply-deep-to-nodes.mjs +0 -22
  325. package/esm2022/transforms/clear-marks.mjs +0 -23
  326. package/esm2022/transforms/delete-element.mjs +0 -12
  327. package/esm2022/transforms/delete-node-by-type.mjs +0 -10
  328. package/esm2022/transforms/handle-continual-delete-backward.mjs +0 -18
  329. package/esm2022/transforms/handle-continual-insert-break.mjs +0 -20
  330. package/esm2022/transforms/index.mjs +0 -19
  331. package/esm2022/transforms/insert-elements.mjs +0 -55
  332. package/esm2022/transforms/insert-paragraph.mjs +0 -6
  333. package/esm2022/transforms/merge-deep-to-nodes.mjs +0 -9
  334. package/esm2022/transforms/move-children.mjs +0 -22
  335. package/esm2022/transforms/on-keydown-reset-block-type.mjs +0 -23
  336. package/esm2022/transforms/set-end-selection.mjs +0 -10
  337. package/esm2022/transforms/set-marks.mjs +0 -9
  338. package/esm2022/transforms/set-node-by-type.mjs +0 -10
  339. package/esm2022/transforms/set-node.mjs +0 -6
  340. package/esm2022/transforms/un-hang-range.mjs +0 -11
  341. package/esm2022/transforms/un-wrap.mjs +0 -12
  342. package/esm2022/transforms/unwrap-nodes-by-type.mjs +0 -14
  343. package/esm2022/utils/auto-focus.mjs +0 -24
  344. package/esm2022/utils/blob.mjs +0 -16
  345. package/esm2022/utils/cast-array.mjs +0 -7
  346. package/esm2022/utils/color-picker.mjs +0 -15
  347. package/esm2022/utils/common.mjs +0 -11
  348. package/esm2022/utils/copy-node.mjs +0 -38
  349. package/esm2022/utils/create-empty-paragraph.mjs +0 -14
  350. package/esm2022/utils/data-transform.mjs +0 -48
  351. package/esm2022/utils/dom.mjs +0 -56
  352. package/esm2022/utils/editor-uuid.mjs +0 -8
  353. package/esm2022/utils/fragment.mjs +0 -82
  354. package/esm2022/utils/get-editable-element-height.mjs +0 -6
  355. package/esm2022/utils/get-mode.mjs +0 -14
  356. package/esm2022/utils/get-toolbar-class.mjs +0 -6
  357. package/esm2022/utils/id-creator.mjs +0 -11
  358. package/esm2022/utils/index.mjs +0 -23
  359. package/esm2022/utils/insert-data-by-invalid-type.mjs +0 -70
  360. package/esm2022/utils/is-clean-empty-paragraph.mjs +0 -37
  361. package/esm2022/utils/is-inline.mjs +0 -9
  362. package/esm2022/utils/lodash.mjs +0 -3
  363. package/esm2022/utils/match.mjs +0 -32
  364. package/esm2022/utils/merge-element-options.mjs +0 -19
  365. package/esm2022/utils/normalize.mjs +0 -61
  366. package/esm2022/utils/refocus.mjs +0 -47
  367. package/esm2022/utils/scrolling.mjs +0 -43
  368. package/esm2022/utils/update-popover-position.mjs +0 -26
  369. package/esm2022/utils/weak-maps.mjs +0 -9
  370. package/esm2022/worktile-theia.mjs +0 -5
@@ -1,99 +0,0 @@
1
- import { NgClass } from '@angular/common';
2
- import { Component } from '@angular/core';
3
- import { FormsModule } from '@angular/forms';
4
- import { ThyAction, ThyActions } from 'ngx-tethys/action';
5
- import { ThyColorPickerDirective } from 'ngx-tethys/color-picker';
6
- import { ThyIcon } from 'ngx-tethys/icon';
7
- import { ThyTooltipDirective } from 'ngx-tethys/tooltip';
8
- import { Editor, Transforms } from 'slate';
9
- import { AngularEditor } from 'slate-angular';
10
- import { MarkTypes } from '../../constants';
11
- import { TheBaseToolbarItem } from '../../core';
12
- import { isCollapsed } from '../../queries';
13
- import { reSelection } from '../../utils';
14
- import { THE_EDITOR_BG_COLOR, THE_EDITOR_COLOR } from '../../utils/weak-maps';
15
- import { ColorEditor } from './color.editor';
16
- import * as i0 from "@angular/core";
17
- import * as i1 from "@angular/forms";
18
- export class TheColorToolbarItem extends TheBaseToolbarItem {
19
- get lastTextColor() {
20
- return THE_EDITOR_COLOR.get(this.editor) ?? '#FF0100';
21
- }
22
- get lastBackgroundColor() {
23
- return THE_EDITOR_BG_COLOR.get(this.editor) ?? '#FFDA00';
24
- }
25
- constructor() {
26
- super();
27
- this.pickerActive = false;
28
- }
29
- ngOnInit() {
30
- this.setSelectedColor();
31
- }
32
- selectionChange() {
33
- super.selectionChange();
34
- this.setSelectedColor();
35
- }
36
- setSelectedColor() {
37
- this.selectedColor = ColorEditor.getActiveColor(this.editor, this.toolbarItem.key);
38
- }
39
- preventDefault(event) {
40
- event.preventDefault();
41
- event.stopPropagation();
42
- }
43
- getDefaultColor() {
44
- if (this.toolbarItem.key === MarkTypes.color) {
45
- return this.lastTextColor;
46
- }
47
- else if (this.toolbarItem.key === MarkTypes.backgroundColor) {
48
- return this.lastBackgroundColor;
49
- }
50
- }
51
- selectColor(event) {
52
- const color = this.getDefaultColor() ?? this.selectedColor;
53
- this.preventDefault(event);
54
- this.changeColor(color);
55
- }
56
- changeColor(color) {
57
- if (!this.editor.selection) {
58
- reSelection(this.editor);
59
- }
60
- // 无填充色
61
- if (color === 'transparent') {
62
- this.selectedColor = '';
63
- }
64
- else {
65
- this.selectedColor = color;
66
- }
67
- if (this.toolbarItem.key === MarkTypes.color) {
68
- THE_EDITOR_COLOR.set(this.editor, this.selectedColor);
69
- }
70
- else if (this.toolbarItem.key === MarkTypes.backgroundColor) {
71
- THE_EDITOR_BG_COLOR.set(this.editor, this.selectedColor);
72
- }
73
- ColorEditor.setColor(this.editor, this.selectedColor, this.toolbarItem.key);
74
- }
75
- colorPanelOpen(event) {
76
- this.panelOpenSelection = this.editor?.selection;
77
- }
78
- colorPanelClose() {
79
- this.pickerActive = false;
80
- setTimeout(() => {
81
- Editor.withoutNormalizing(this.editor, () => {
82
- if (isCollapsed(this.panelOpenSelection)) {
83
- const selection = Editor.after(this.editor, this.panelOpenSelection.focus);
84
- Transforms.select(this.editor, selection);
85
- }
86
- AngularEditor.focus(this.editor);
87
- });
88
- });
89
- }
90
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: TheColorToolbarItem, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
91
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: TheColorToolbarItem, isStandalone: true, selector: "the-color-toolbar-item", host: { classAttribute: "the-color-toolbar-item" }, usesInheritance: true, ngImport: i0, template: "<thy-actions\n class=\"d-flex p-0\"\n thySize=\"zero\"\n thyTooltipPlacement=\"top\"\n [thyTooltip]=\"toolbarItem.name\"\n [ngClass]=\"{ 'thy-default-picker-active': pickerActive }\"\n>\n <a href=\"javascript:;\" class=\"color\" thyAction (mousedown)=\"selectColor($event)\">\n <thy-icon\n thyIconType=\"twotone\"\n [thyIconName]=\"toolbarItem.icon\"\n [thyTwotoneColor]=\"toolbarItem.key === 'color' ? lastTextColor : lastBackgroundColor\"\n (mousedown)=\"selectColor($event)\"\n ></thy-icon>\n </a>\n <a\n class=\"pl-0 pr-0 caret-down\"\n href=\"javascript:;\"\n thyAction\n thyColorPicker\n thyPlacement=\"bottomLeft\"\n [(ngModel)]=\"selectedColor\"\n (thyPanelOpen)=\"pickerActive = true\"\n (thyPanelOpen)=\"colorPanelOpen($event)\"\n (thyPanelClose)=\"colorPanelClose()\"\n (ngModelChange)=\"changeColor($event)\"\n (mousedown)=\"preventDefault($event)\"\n >\n <thy-icon class=\"link-down-icon font-size-sm text-desc\" thyIconName=\"caret-down\"></thy-icon>\n </a>\n</thy-actions>\n", dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: ThyAction, selector: "thy-action, [thyAction]", inputs: ["thyType", "thyIcon", "thyActionIcon", "thyActive", "thyActionActive", "thyTheme", "thyHoverIcon", "thyDisabled"] }, { kind: "component", type: ThyActions, selector: "thy-actions", inputs: ["thySize"] }, { kind: "directive", type: ThyColorPickerDirective, selector: "[thyColorPicker]", inputs: ["thyOffset", "thyHasBackdrop", "thyDefaultColor", "thyTransparentColorSelectable", "thyPresetColors", "thyPlacement", "thyTrigger", "thyShowDelay", "thyHideDelay", "thyDisabled"], outputs: ["thyPanelOpen", "thyPanelClose"] }, { kind: "directive", type: ThyTooltipDirective, selector: "[thyTooltip],[thy-tooltip]", inputs: ["thyTooltip", "thyTooltipPlacement", "thyTooltipClass", "thyTooltipShowDelay", "thyTooltipHideDelay", "thyTooltipTrigger", "thyTooltipDisabled", "thyTooltipTemplateContext", "thyTooltipOffset", "thyTooltipPin"], exportAs: ["thyTooltip"] }, { kind: "component", type: ThyIcon, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }] }); }
92
- }
93
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: TheColorToolbarItem, decorators: [{
94
- type: Component,
95
- args: [{ selector: 'the-color-toolbar-item', host: {
96
- class: 'the-color-toolbar-item'
97
- }, standalone: true, imports: [NgClass, FormsModule, ThyAction, ThyActions, ThyColorPickerDirective, ThyTooltipDirective, ThyIcon], template: "<thy-actions\n class=\"d-flex p-0\"\n thySize=\"zero\"\n thyTooltipPlacement=\"top\"\n [thyTooltip]=\"toolbarItem.name\"\n [ngClass]=\"{ 'thy-default-picker-active': pickerActive }\"\n>\n <a href=\"javascript:;\" class=\"color\" thyAction (mousedown)=\"selectColor($event)\">\n <thy-icon\n thyIconType=\"twotone\"\n [thyIconName]=\"toolbarItem.icon\"\n [thyTwotoneColor]=\"toolbarItem.key === 'color' ? lastTextColor : lastBackgroundColor\"\n (mousedown)=\"selectColor($event)\"\n ></thy-icon>\n </a>\n <a\n class=\"pl-0 pr-0 caret-down\"\n href=\"javascript:;\"\n thyAction\n thyColorPicker\n thyPlacement=\"bottomLeft\"\n [(ngModel)]=\"selectedColor\"\n (thyPanelOpen)=\"pickerActive = true\"\n (thyPanelOpen)=\"colorPanelOpen($event)\"\n (thyPanelClose)=\"colorPanelClose()\"\n (ngModelChange)=\"changeColor($event)\"\n (mousedown)=\"preventDefault($event)\"\n >\n <thy-icon class=\"link-down-icon font-size-sm text-desc\" thyIconName=\"caret-down\"></thy-icon>\n </a>\n</thy-actions>\n" }]
98
- }], ctorParameters: () => [] });
99
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toolbar-item.component.js","sourceRoot":"","sources":["../../../../../packages/src/plugins/color/toolbar-item.component.ts","../../../../../packages/src/plugins/color/toolbar-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgClass } from '@angular/common';\nimport { Component, OnInit } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { ThyAction, ThyActions } from 'ngx-tethys/action';\nimport { ThyColorPickerDirective, ThyColorPickerPanel } from 'ngx-tethys/color-picker';\nimport { ThyIcon } from 'ngx-tethys/icon';\nimport { ThyPopoverRef } from 'ngx-tethys/popover';\nimport { ThyTooltipDirective } from 'ngx-tethys/tooltip';\nimport { Editor, Range, Transforms } from 'slate';\nimport { AngularEditor } from 'slate-angular';\nimport { MarkTypes } from '../../constants';\nimport { TheBaseToolbarItem } from '../../core';\nimport { isCollapsed } from '../../queries';\nimport { reSelection } from '../../utils';\nimport { THE_EDITOR_BG_COLOR, THE_EDITOR_COLOR } from '../../utils/weak-maps';\nimport { ColorEditor } from './color.editor';\n\n@Component({\n    selector: 'the-color-toolbar-item',\n    templateUrl: './toolbar-item.component.html',\n    host: {\n        class: 'the-color-toolbar-item'\n    },\n    standalone: true,\n    imports: [NgClass, FormsModule, ThyAction, ThyActions, ThyColorPickerDirective, ThyTooltipDirective, ThyIcon]\n})\nexport class TheColorToolbarItem extends TheBaseToolbarItem implements OnInit {\n    selectedColor: string;\n\n    pickerActive = false;\n\n    private panelOpenSelection: Range;\n\n    get lastTextColor(): string {\n        return THE_EDITOR_COLOR.get(this.editor) ?? '#FF0100';\n    }\n\n    get lastBackgroundColor(): string {\n        return THE_EDITOR_BG_COLOR.get(this.editor) ?? '#FFDA00';\n    }\n\n    constructor() {\n        super();\n    }\n\n    ngOnInit(): void {\n        this.setSelectedColor();\n    }\n\n    selectionChange() {\n        super.selectionChange();\n        this.setSelectedColor();\n    }\n\n    setSelectedColor() {\n        this.selectedColor = ColorEditor.getActiveColor(this.editor, this.toolbarItem.key as MarkTypes.color & MarkTypes.backgroundColor);\n    }\n\n    preventDefault(event: Event) {\n        event.preventDefault();\n        event.stopPropagation();\n    }\n\n    private getDefaultColor() {\n        if (this.toolbarItem.key === MarkTypes.color) {\n            return this.lastTextColor;\n        } else if (this.toolbarItem.key === MarkTypes.backgroundColor) {\n            return this.lastBackgroundColor;\n        }\n    }\n\n    selectColor(event: Event) {\n        const color = this.getDefaultColor() ?? this.selectedColor;\n        this.preventDefault(event);\n        this.changeColor(color);\n    }\n\n    changeColor(color: string) {\n        if (!this.editor.selection) {\n            reSelection(this.editor);\n        }\n        // 无填充色\n        if (color === 'transparent') {\n            this.selectedColor = '';\n        } else {\n            this.selectedColor = color;\n        }\n\n        if (this.toolbarItem.key === MarkTypes.color) {\n            THE_EDITOR_COLOR.set(this.editor, this.selectedColor);\n        } else if (this.toolbarItem.key === MarkTypes.backgroundColor) {\n            THE_EDITOR_BG_COLOR.set(this.editor, this.selectedColor);\n        }\n\n        ColorEditor.setColor(this.editor, this.selectedColor, this.toolbarItem.key as MarkTypes.color & MarkTypes.backgroundColor);\n    }\n\n    colorPanelOpen(event: ThyPopoverRef<ThyColorPickerPanel>) {\n        this.panelOpenSelection = this.editor?.selection;\n    }\n\n    colorPanelClose() {\n        this.pickerActive = false;\n        setTimeout(() => {\n            Editor.withoutNormalizing(this.editor, () => {\n                if (isCollapsed(this.panelOpenSelection)) {\n                    const selection = Editor.after(this.editor, this.panelOpenSelection.focus);\n                    Transforms.select(this.editor, selection);\n                }\n                AngularEditor.focus(this.editor);\n            });\n        });\n    }\n}\n","<thy-actions\n  class=\"d-flex p-0\"\n  thySize=\"zero\"\n  thyTooltipPlacement=\"top\"\n  [thyTooltip]=\"toolbarItem.name\"\n  [ngClass]=\"{ 'thy-default-picker-active': pickerActive }\"\n>\n  <a href=\"javascript:;\" class=\"color\" thyAction (mousedown)=\"selectColor($event)\">\n    <thy-icon\n      thyIconType=\"twotone\"\n      [thyIconName]=\"toolbarItem.icon\"\n      [thyTwotoneColor]=\"toolbarItem.key === 'color' ? lastTextColor : lastBackgroundColor\"\n      (mousedown)=\"selectColor($event)\"\n    ></thy-icon>\n  </a>\n  <a\n    class=\"pl-0 pr-0 caret-down\"\n    href=\"javascript:;\"\n    thyAction\n    thyColorPicker\n    thyPlacement=\"bottomLeft\"\n    [(ngModel)]=\"selectedColor\"\n    (thyPanelOpen)=\"pickerActive = true\"\n    (thyPanelOpen)=\"colorPanelOpen($event)\"\n    (thyPanelClose)=\"colorPanelClose()\"\n    (ngModelChange)=\"changeColor($event)\"\n    (mousedown)=\"preventDefault($event)\"\n  >\n    <thy-icon class=\"link-down-icon font-size-sm text-desc\" thyIconName=\"caret-down\"></thy-icon>\n  </a>\n</thy-actions>\n"]}
@@ -1,330 +0,0 @@
1
- import { Editor, Node, Path, Range, Transforms } from 'slate';
2
- import { AngularEditor, FAKE_RIGHT_BLOCK_CARD_OFFSET, hasBlockCard, hotkeys, isCardLeft } from 'slate-angular';
3
- import { HistoryEditor } from 'slate-history';
4
- import { createPluginFactory } from '../../core';
5
- import { PluginKeys } from '../../interfaces';
6
- import * as TheQueries from '../../queries';
7
- import * as TheTransforms from '../../transforms';
8
- import { insertParagraph } from '../../transforms/insert-paragraph';
9
- import { createEmptyParagraph } from '../../utils/create-empty-paragraph';
10
- import { coercePixelsFromCssValue } from '../../utils/dom';
11
- export const withBlockCard = (editor) => {
12
- const { insertBreak, deleteBackward, onKeydown, deleteForward, insertData, insertText, mousedown } = editor;
13
- editor.insertBreak = () => {
14
- const domSelection = window.getSelection();
15
- const anchorNode = domSelection.anchorNode;
16
- if (domSelection && domSelection.isCollapsed && hasBlockCard(domSelection)) {
17
- const isLeftCursor = isCardLeft(anchorNode);
18
- const cardEntry = AngularEditor.toSlateCardEntry(editor, anchorNode);
19
- const cursorRootPath = cardEntry[1];
20
- TheTransforms.insertParagraph(editor, isLeftCursor ? cursorRootPath : Path.next(cursorRootPath));
21
- if (!isLeftCursor) {
22
- Transforms.select(editor, Path.next(cursorRootPath));
23
- }
24
- return;
25
- }
26
- insertBreak();
27
- };
28
- editor.deleteBackward = unit => {
29
- const domSelection = window.getSelection();
30
- const anchorNode = domSelection.anchorNode;
31
- if (domSelection && domSelection.isCollapsed && hasBlockCard(domSelection)) {
32
- const isLeftCursor = isCardLeft(anchorNode);
33
- const cardEntry = AngularEditor.toSlateCardEntry(editor, anchorNode);
34
- const cursorRootPath = cardEntry[1];
35
- if (isLeftCursor) {
36
- const previousPath = Path.hasPrevious(cursorRootPath) && Path.previous(cursorRootPath);
37
- if (!previousPath) {
38
- return;
39
- }
40
- if (previousPath && TheQueries.isEmptyParagraphByPath(editor, previousPath)) {
41
- Transforms.removeNodes(editor, {
42
- at: previousPath
43
- });
44
- return;
45
- }
46
- HistoryEditor.withoutMerging(editor, () => {
47
- Transforms.select(editor, Editor.end(editor, previousPath));
48
- });
49
- return;
50
- }
51
- else {
52
- TheTransforms.insertParagraph(editor, cursorRootPath);
53
- Transforms.select(editor, cursorRootPath);
54
- Transforms.removeNodes(editor, { at: Path.next(cursorRootPath) });
55
- return;
56
- }
57
- }
58
- const blockCard = TheQueries.getBlockCardAbove(editor);
59
- const beforePoint = Editor.before(editor, editor.selection.anchor);
60
- const beforeBlockCard = TheQueries.getBlockCardAbove(editor, { at: beforePoint });
61
- if (!blockCard && beforeBlockCard) {
62
- if (TheQueries.isBlockAboveEmpty(editor)) {
63
- const [node, path] = Editor.parent(editor, editor.selection.anchor.path);
64
- HistoryEditor.withoutMerging(editor, () => {
65
- const rightCursor = { path: beforeBlockCard[1], offset: FAKE_RIGHT_BLOCK_CARD_OFFSET };
66
- Transforms.select(editor, { anchor: rightCursor, focus: rightCursor });
67
- });
68
- Transforms.delete(editor, { at: path });
69
- return;
70
- }
71
- else {
72
- Transforms.delete(editor, { at: beforeBlockCard[1] });
73
- }
74
- return;
75
- }
76
- deleteBackward(unit);
77
- };
78
- editor.deleteForward = unit => {
79
- const domSelection = window.getSelection();
80
- const anchorNode = domSelection.anchorNode;
81
- if (domSelection && domSelection.isCollapsed && hasBlockCard(domSelection)) {
82
- const isLeftCursor = isCardLeft(anchorNode);
83
- const cardEntry = AngularEditor.toSlateCardEntry(editor, anchorNode);
84
- const cursorRootPath = cardEntry[1];
85
- if (isLeftCursor) {
86
- TheTransforms.insertParagraph(editor, cursorRootPath);
87
- Transforms.select(editor, cursorRootPath);
88
- Transforms.removeNodes(editor, { at: Path.next(cursorRootPath) });
89
- return;
90
- }
91
- else {
92
- const nextPath = Path.next(cursorRootPath);
93
- HistoryEditor.withoutMerging(editor, () => {
94
- Transforms.select(editor, Editor.start(editor, nextPath));
95
- });
96
- return;
97
- }
98
- }
99
- const blockCard = TheQueries.getBlockCardAbove(editor);
100
- const afterPoint = Editor.after(editor, editor.selection.anchor);
101
- const afterBlockCard = TheQueries.getBlockCardAbove(editor, { at: afterPoint });
102
- if (!blockCard && afterBlockCard) {
103
- if (TheQueries.isBlockAboveEmpty(editor)) {
104
- HistoryEditor.withoutMerging(editor, () => {
105
- const leftCursor = { path: afterBlockCard[1], offset: -1 };
106
- Transforms.select(editor, { anchor: leftCursor, focus: leftCursor });
107
- });
108
- Transforms.delete(editor, { at: Path.previous(afterBlockCard[1]) });
109
- return;
110
- }
111
- return;
112
- }
113
- deleteForward(unit);
114
- };
115
- editor.onKeydown = (event) => {
116
- const domSelection = window.getSelection();
117
- const anchorNode = domSelection.anchorNode;
118
- const nativeEvent = event;
119
- const { selection } = editor;
120
- const isMoveBackward = hotkeys.isMoveBackward(nativeEvent);
121
- const isMoveForward = hotkeys.isMoveForward(nativeEvent);
122
- const isMoveUp = hotkeys.isMoveUp(nativeEvent);
123
- const isMoveDown = hotkeys.isMoveDown(nativeEvent);
124
- const isCollapsed = selection && Range.isCollapsed(selection);
125
- const anchorEntry = TheQueries.anchorBlockEntry(editor);
126
- // block card cursor
127
- if (anchorNode && hasBlockCard(domSelection)) {
128
- const isCardLeftCursor = isCardLeft(anchorNode);
129
- if (isMoveUp) {
130
- const [, path] = AngularEditor.toSlateCardEntry(editor, anchorNode);
131
- const previousPath = Path.hasPrevious(path) && Path.previous(path);
132
- const previousNode = previousPath && TheQueries.getNode(editor, previousPath);
133
- if (previousNode && editor.isBlockCard(previousNode)) {
134
- AngularEditor.moveBlockCard(editor, previousNode, { direction: isCardLeftCursor ? 'left' : 'right' });
135
- }
136
- else {
137
- const before = Editor.before(editor, path);
138
- if (before) {
139
- Transforms.select(editor, before);
140
- }
141
- }
142
- nativeEvent.preventDefault();
143
- return;
144
- }
145
- if (isMoveDown) {
146
- const [, path] = AngularEditor.toSlateCardEntry(editor, anchorNode);
147
- const nextPath = Path.next(path);
148
- const nextNode = TheQueries.getNode(editor, nextPath);
149
- if (nextNode && editor.isBlockCard(nextNode)) {
150
- AngularEditor.moveBlockCard(editor, nextNode, { direction: isCardLeftCursor ? 'left' : 'right' });
151
- }
152
- else {
153
- const after = Editor.after(editor, path);
154
- if (after) {
155
- Transforms.select(editor, Editor.after(editor, path));
156
- }
157
- }
158
- nativeEvent.preventDefault();
159
- return;
160
- }
161
- // → + right-block-card
162
- if (isMoveForward && !isCardLeftCursor) {
163
- nativeEvent.preventDefault();
164
- const [, path] = AngularEditor.toSlateCardEntry(editor, anchorNode);
165
- const nextPath = Path.next(path);
166
- const nextNode = TheQueries.getNode(editor, nextPath);
167
- if (nextNode && editor.isBlockCard(nextNode)) {
168
- event.preventDefault();
169
- AngularEditor.moveBlockCard(editor, nextNode, { direction: 'left' });
170
- return;
171
- }
172
- const after = Editor.after(editor, path);
173
- if (after) {
174
- Transforms.select(editor, Editor.after(editor, path));
175
- }
176
- return;
177
- }
178
- // ← + left-block-card
179
- if (isMoveBackward && isCardLeftCursor) {
180
- nativeEvent.preventDefault();
181
- const [, path] = AngularEditor.toSlateCardEntry(editor, anchorNode);
182
- const previousPath = Path.hasPrevious(path) && Path.previous(path);
183
- const previousNode = previousPath && TheQueries.getNode(editor, previousPath);
184
- if (previousNode && editor.isBlockCard(previousNode)) {
185
- event.preventDefault();
186
- AngularEditor.moveBlockCard(editor, previousNode, { direction: 'right' });
187
- return;
188
- }
189
- const before = Editor.before(editor, path);
190
- if (before) {
191
- Transforms.select(editor, before);
192
- }
193
- return;
194
- }
195
- // move to card center
196
- if ((isCardLeftCursor && isMoveForward) || (!isCardLeftCursor && isMoveBackward)) {
197
- nativeEvent.preventDefault();
198
- const [, path] = AngularEditor.toSlateCardEntry(editor, anchorNode);
199
- Transforms.select(editor, isCardLeftCursor ? Editor.start(editor, path) : Editor.end(editor, path));
200
- return;
201
- }
202
- }
203
- // block card center
204
- if (isCollapsed && (isMoveUp || isMoveDown) && anchorEntry) {
205
- const [block, path] = anchorEntry;
206
- if (editor.isBlockCard(block)) {
207
- event.preventDefault();
208
- Transforms.select(editor, isMoveUp ? Editor.before(editor, path) : Editor.after(editor, path));
209
- return;
210
- }
211
- }
212
- if (isCollapsed && (isMoveBackward || isMoveForward) && anchorEntry) {
213
- const [block] = anchorEntry;
214
- if (editor.isBlockCard(block)) {
215
- event.preventDefault();
216
- AngularEditor.moveBlockCard(editor, block, { direction: isMoveBackward ? 'left' : 'right' });
217
- return;
218
- }
219
- }
220
- // move to block card cursor
221
- if (isCollapsed && isMoveBackward && Editor.isStart(editor, selection.anchor, selection.anchor.path.slice(0, 1))) {
222
- const currentPath = selection.anchor.path.slice(0, 1);
223
- if (currentPath[0] > 0) {
224
- const previousNode = Node.get(editor, Path.previous(currentPath));
225
- if (previousNode && editor.isBlockCard(previousNode)) {
226
- event.preventDefault();
227
- AngularEditor.moveBlockCard(editor, previousNode, { direction: 'right' });
228
- return;
229
- }
230
- }
231
- }
232
- if (isCollapsed && isMoveForward && Editor.isEnd(editor, selection.anchor, selection.anchor.path.slice(0, 1))) {
233
- const currentPath = selection.anchor.path.slice(0, 1);
234
- if (currentPath[0] < editor.children.length - 1) {
235
- const previousNode = Node.get(editor, Path.next(currentPath));
236
- if (previousNode && editor.isBlockCard(previousNode)) {
237
- event.preventDefault();
238
- AngularEditor.moveBlockCard(editor, previousNode, { direction: 'left' });
239
- return;
240
- }
241
- }
242
- }
243
- onKeydown(event);
244
- };
245
- editor.insertData = (data) => {
246
- const domSelection = window.getSelection();
247
- const anchorNode = domSelection.anchorNode;
248
- if (domSelection && domSelection.isCollapsed && hasBlockCard(domSelection)) {
249
- const isLeftCursor = isCardLeft(anchorNode);
250
- const cardEntry = AngularEditor.toSlateCardEntry(editor, anchorNode);
251
- const cursorRootPath = cardEntry[1];
252
- if (isLeftCursor) {
253
- Transforms.insertNodes(editor, createEmptyParagraph(), { at: cursorRootPath });
254
- Transforms.select(editor, cursorRootPath);
255
- }
256
- else {
257
- Transforms.insertNodes(editor, createEmptyParagraph(), { at: Path.next(cursorRootPath) });
258
- Transforms.select(editor, Path.next(cursorRootPath));
259
- }
260
- }
261
- insertData(data);
262
- };
263
- editor.insertText = (text) => {
264
- const domSelection = window.getSelection();
265
- const anchorNode = domSelection?.anchorNode;
266
- if (AngularEditor.isBlockCardLeftCursor(editor) || AngularEditor.isBlockCardRightCursor(editor)) {
267
- const isLeftCursor = isCardLeft(anchorNode);
268
- const cardEntry = AngularEditor.toSlateCardEntry(editor, anchorNode);
269
- const cursorRootPath = cardEntry[1];
270
- if (isLeftCursor) {
271
- insertParagraph(editor, cursorRootPath);
272
- Transforms.select(editor, cursorRootPath);
273
- }
274
- else {
275
- const nextPath = Path.next(cursorRootPath);
276
- insertParagraph(editor, nextPath);
277
- Transforms.select(editor, nextPath);
278
- }
279
- }
280
- insertText(text);
281
- };
282
- editor.mousedown = (event) => {
283
- const editableElement = AngularEditor.toDOMNode(editor, editor);
284
- const absoluteElement = document.elementFromPoint(event.x, event.y);
285
- if (editableElement.isEqualNode(absoluteElement)) {
286
- const rectEditable = editableElement.getBoundingClientRect();
287
- let { paddingRight } = window.getComputedStyle(editableElement, null);
288
- const paddingRightPixels = coercePixelsFromCssValue(paddingRight);
289
- const fakeRightX = rectEditable.right - paddingRightPixels - 50;
290
- let relativeElement = document.elementFromPoint(fakeRightX, event.y);
291
- let relativeBlockCardElement = relativeElement.closest('.slate-block-card');
292
- if (relativeBlockCardElement) {
293
- const centerX = rectEditable.x + rectEditable.width / 2;
294
- const blockCardEntry = AngularEditor.toSlateCardEntry(editor, relativeBlockCardElement.firstElementChild);
295
- if (blockCardEntry && editor.isBlockCard(blockCardEntry[0])) {
296
- const parentBlockCardEntry = Editor.above(editor, {
297
- at: blockCardEntry[1],
298
- mode: 'highest',
299
- match: node => editor.isBlockCard(node)
300
- });
301
- event.preventDefault();
302
- if (parentBlockCardEntry) {
303
- AngularEditor.moveBlockCard(editor, parentBlockCardEntry[0], { direction: event.x < centerX ? 'left' : 'right' });
304
- }
305
- else {
306
- AngularEditor.moveBlockCard(editor, blockCardEntry[0], { direction: event.x < centerX ? 'left' : 'right' });
307
- }
308
- }
309
- }
310
- return;
311
- }
312
- const innerBlockCardElement = absoluteElement.querySelector('[card-target="card-center"]');
313
- if (innerBlockCardElement) {
314
- const blockCardEntry = AngularEditor.toSlateCardEntry(editor, innerBlockCardElement.firstElementChild);
315
- if (blockCardEntry && editor.isBlockCard(blockCardEntry[0])) {
316
- const { x, width } = innerBlockCardElement.getBoundingClientRect();
317
- const centerX = x + width / 2;
318
- event.preventDefault();
319
- AngularEditor.moveBlockCard(editor, blockCardEntry[0], { direction: event.x < centerX ? 'left' : 'right' });
320
- }
321
- }
322
- mousedown(event);
323
- };
324
- return editor;
325
- };
326
- export const createBlockCardPlugin = createPluginFactory({
327
- key: PluginKeys.blockCard,
328
- withOverrides: withBlockCard
329
- });
330
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"block-card.plugin.js","sourceRoot":"","sources":["../../../../../packages/src/plugins/common/block-card.plugin.ts"],"names":[],"mappings":"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","sourcesContent":["import { Editor, Node, Path, Range, Transforms } from 'slate';\nimport { AngularEditor, FAKE_RIGHT_BLOCK_CARD_OFFSET, hasBlockCard, hotkeys, isCardLeft } from 'slate-angular';\nimport { HistoryEditor } from 'slate-history';\nimport { createPluginFactory } from '../../core';\nimport { PluginKeys } from '../../interfaces';\nimport * as TheQueries from '../../queries';\nimport * as TheTransforms from '../../transforms';\nimport { insertParagraph } from '../../transforms/insert-paragraph';\nimport { createEmptyParagraph } from '../../utils/create-empty-paragraph';\nimport { coercePixelsFromCssValue } from '../../utils/dom';\n\nexport const withBlockCard = <T extends Editor>(editor: T): T => {\n    const { insertBreak, deleteBackward, onKeydown, deleteForward, insertData, insertText, mousedown } = editor;\n\n    editor.insertBreak = () => {\n        const domSelection = window.getSelection();\n        const anchorNode = domSelection.anchorNode;\n        if (domSelection && domSelection.isCollapsed && hasBlockCard(domSelection)) {\n            const isLeftCursor = isCardLeft(anchorNode);\n            const cardEntry = AngularEditor.toSlateCardEntry(editor, anchorNode);\n            const cursorRootPath = cardEntry[1];\n            TheTransforms.insertParagraph(editor, isLeftCursor ? cursorRootPath : Path.next(cursorRootPath));\n            if (!isLeftCursor) {\n                Transforms.select(editor, Path.next(cursorRootPath));\n            }\n            return;\n        }\n        insertBreak();\n    };\n\n    editor.deleteBackward = unit => {\n        const domSelection = window.getSelection();\n        const anchorNode = domSelection.anchorNode;\n        if (domSelection && domSelection.isCollapsed && hasBlockCard(domSelection)) {\n            const isLeftCursor = isCardLeft(anchorNode);\n            const cardEntry = AngularEditor.toSlateCardEntry(editor, anchorNode);\n            const cursorRootPath = cardEntry[1];\n            if (isLeftCursor) {\n                const previousPath = Path.hasPrevious(cursorRootPath) && Path.previous(cursorRootPath);\n                if (!previousPath) {\n                    return;\n                }\n                if (previousPath && TheQueries.isEmptyParagraphByPath(editor, previousPath)) {\n                    Transforms.removeNodes(editor, {\n                        at: previousPath\n                    });\n                    return;\n                }\n                HistoryEditor.withoutMerging(editor, () => {\n                    Transforms.select(editor, Editor.end(editor, previousPath));\n                });\n                return;\n            } else {\n                TheTransforms.insertParagraph(editor, cursorRootPath);\n                Transforms.select(editor, cursorRootPath);\n                Transforms.removeNodes(editor, { at: Path.next(cursorRootPath) });\n                return;\n            }\n        }\n\n        const blockCard = TheQueries.getBlockCardAbove(editor);\n        const beforePoint = Editor.before(editor, editor.selection.anchor);\n        const beforeBlockCard = TheQueries.getBlockCardAbove(editor, { at: beforePoint });\n        if (!blockCard && beforeBlockCard) {\n            if (TheQueries.isBlockAboveEmpty(editor)) {\n                const [node, path] = Editor.parent(editor, editor.selection.anchor.path);\n                HistoryEditor.withoutMerging(editor, () => {\n                    const rightCursor = { path: beforeBlockCard[1], offset: FAKE_RIGHT_BLOCK_CARD_OFFSET };\n                    Transforms.select(editor, { anchor: rightCursor, focus: rightCursor });\n                });\n                Transforms.delete(editor, { at: path });\n                return;\n            } else {\n                Transforms.delete(editor, { at: beforeBlockCard[1] });\n            }\n            return;\n        }\n\n        deleteBackward(unit);\n    };\n\n    editor.deleteForward = unit => {\n        const domSelection = window.getSelection();\n        const anchorNode = domSelection.anchorNode;\n        if (domSelection && domSelection.isCollapsed && hasBlockCard(domSelection)) {\n            const isLeftCursor = isCardLeft(anchorNode);\n            const cardEntry = AngularEditor.toSlateCardEntry(editor, anchorNode);\n            const cursorRootPath = cardEntry[1];\n            if (isLeftCursor) {\n                TheTransforms.insertParagraph(editor, cursorRootPath);\n                Transforms.select(editor, cursorRootPath);\n                Transforms.removeNodes(editor, { at: Path.next(cursorRootPath) });\n                return;\n            } else {\n                const nextPath = Path.next(cursorRootPath);\n                HistoryEditor.withoutMerging(editor, () => {\n                    Transforms.select(editor, Editor.start(editor, nextPath));\n                });\n                return;\n            }\n        }\n\n        const blockCard = TheQueries.getBlockCardAbove(editor);\n        const afterPoint = Editor.after(editor, editor.selection.anchor);\n        const afterBlockCard = TheQueries.getBlockCardAbove(editor, { at: afterPoint });\n        if (!blockCard && afterBlockCard) {\n            if (TheQueries.isBlockAboveEmpty(editor)) {\n                HistoryEditor.withoutMerging(editor, () => {\n                    const leftCursor = { path: afterBlockCard[1], offset: -1 };\n                    Transforms.select(editor, { anchor: leftCursor, focus: leftCursor });\n                });\n                Transforms.delete(editor, { at: Path.previous(afterBlockCard[1]) });\n                return;\n            }\n            return;\n        }\n\n        deleteForward(unit);\n    };\n\n    editor.onKeydown = (event: KeyboardEvent) => {\n        const domSelection = window.getSelection();\n        const anchorNode = domSelection.anchorNode;\n        const nativeEvent = event;\n        const { selection } = editor;\n\n        const isMoveBackward = hotkeys.isMoveBackward(nativeEvent);\n        const isMoveForward = hotkeys.isMoveForward(nativeEvent);\n        const isMoveUp = hotkeys.isMoveUp(nativeEvent);\n        const isMoveDown = hotkeys.isMoveDown(nativeEvent);\n        const isCollapsed = selection && Range.isCollapsed(selection);\n        const anchorEntry = TheQueries.anchorBlockEntry(editor);\n\n        // block card cursor\n        if (anchorNode && hasBlockCard(domSelection)) {\n            const isCardLeftCursor = isCardLeft(anchorNode);\n            if (isMoveUp) {\n                const [, path] = AngularEditor.toSlateCardEntry(editor, anchorNode);\n                const previousPath = Path.hasPrevious(path) && Path.previous(path);\n                const previousNode = previousPath && TheQueries.getNode(editor, previousPath);\n                if (previousNode && editor.isBlockCard(previousNode)) {\n                    AngularEditor.moveBlockCard(editor, previousNode, { direction: isCardLeftCursor ? 'left' : 'right' });\n                } else {\n                    const before = Editor.before(editor, path);\n                    if (before) {\n                        Transforms.select(editor, before);\n                    }\n                }\n                nativeEvent.preventDefault();\n                return;\n            }\n            if (isMoveDown) {\n                const [, path] = AngularEditor.toSlateCardEntry(editor, anchorNode);\n                const nextPath = Path.next(path);\n                const nextNode = TheQueries.getNode(editor, nextPath);\n                if (nextNode && editor.isBlockCard(nextNode)) {\n                    AngularEditor.moveBlockCard(editor, nextNode, { direction: isCardLeftCursor ? 'left' : 'right' });\n                } else {\n                    const after = Editor.after(editor, path);\n                    if (after) {\n                        Transforms.select(editor, Editor.after(editor, path));\n                    }\n                }\n                nativeEvent.preventDefault();\n                return;\n            }\n            // → + right-block-card\n            if (isMoveForward && !isCardLeftCursor) {\n                nativeEvent.preventDefault();\n                const [, path] = AngularEditor.toSlateCardEntry(editor, anchorNode);\n                const nextPath = Path.next(path);\n                const nextNode = TheQueries.getNode(editor, nextPath);\n                if (nextNode && editor.isBlockCard(nextNode)) {\n                    event.preventDefault();\n                    AngularEditor.moveBlockCard(editor, nextNode, { direction: 'left' });\n                    return;\n                }\n                const after = Editor.after(editor, path);\n                if (after) {\n                    Transforms.select(editor, Editor.after(editor, path));\n                }\n                return;\n            }\n            // ← + left-block-card\n            if (isMoveBackward && isCardLeftCursor) {\n                nativeEvent.preventDefault();\n                const [, path] = AngularEditor.toSlateCardEntry(editor, anchorNode);\n                const previousPath = Path.hasPrevious(path) && Path.previous(path);\n                const previousNode = previousPath && TheQueries.getNode(editor, previousPath);\n                if (previousNode && editor.isBlockCard(previousNode)) {\n                    event.preventDefault();\n                    AngularEditor.moveBlockCard(editor, previousNode, { direction: 'right' });\n                    return;\n                }\n                const before = Editor.before(editor, path);\n                if (before) {\n                    Transforms.select(editor, before);\n                }\n                return;\n            }\n            // move to card center\n            if ((isCardLeftCursor && isMoveForward) || (!isCardLeftCursor && isMoveBackward)) {\n                nativeEvent.preventDefault();\n                const [, path] = AngularEditor.toSlateCardEntry(editor, anchorNode);\n                Transforms.select(editor, isCardLeftCursor ? Editor.start(editor, path) : Editor.end(editor, path));\n                return;\n            }\n        }\n        // block card center\n        if (isCollapsed && (isMoveUp || isMoveDown) && anchorEntry) {\n            const [block, path] = anchorEntry;\n            if (editor.isBlockCard(block)) {\n                event.preventDefault();\n                Transforms.select(editor, isMoveUp ? Editor.before(editor, path) : Editor.after(editor, path));\n                return;\n            }\n        }\n        if (isCollapsed && (isMoveBackward || isMoveForward) && anchorEntry) {\n            const [block] = anchorEntry;\n            if (editor.isBlockCard(block)) {\n                event.preventDefault();\n                AngularEditor.moveBlockCard(editor, block, { direction: isMoveBackward ? 'left' : 'right' });\n                return;\n            }\n        }\n        // move to block card cursor\n        if (isCollapsed && isMoveBackward && Editor.isStart(editor, selection.anchor, selection.anchor.path.slice(0, 1))) {\n            const currentPath = selection.anchor.path.slice(0, 1);\n            if (currentPath[0] > 0) {\n                const previousNode = Node.get(editor, Path.previous(currentPath));\n                if (previousNode && editor.isBlockCard(previousNode)) {\n                    event.preventDefault();\n                    AngularEditor.moveBlockCard(editor, previousNode, { direction: 'right' });\n                    return;\n                }\n            }\n        }\n        if (isCollapsed && isMoveForward && Editor.isEnd(editor, selection.anchor, selection.anchor.path.slice(0, 1))) {\n            const currentPath = selection.anchor.path.slice(0, 1);\n            if (currentPath[0] < editor.children.length - 1) {\n                const previousNode = Node.get(editor, Path.next(currentPath));\n                if (previousNode && editor.isBlockCard(previousNode)) {\n                    event.preventDefault();\n                    AngularEditor.moveBlockCard(editor, previousNode, { direction: 'left' });\n                    return;\n                }\n            }\n        }\n\n        onKeydown(event);\n    };\n\n    editor.insertData = (data: DataTransfer) => {\n        const domSelection = window.getSelection();\n        const anchorNode = domSelection.anchorNode;\n        if (domSelection && domSelection.isCollapsed && hasBlockCard(domSelection)) {\n            const isLeftCursor = isCardLeft(anchorNode);\n            const cardEntry = AngularEditor.toSlateCardEntry(editor, anchorNode);\n            const cursorRootPath = cardEntry[1];\n            if (isLeftCursor) {\n                Transforms.insertNodes(editor, createEmptyParagraph(), { at: cursorRootPath });\n                Transforms.select(editor, cursorRootPath);\n            } else {\n                Transforms.insertNodes(editor, createEmptyParagraph(), { at: Path.next(cursorRootPath) });\n                Transforms.select(editor, Path.next(cursorRootPath));\n            }\n        }\n        insertData(data);\n    };\n\n    editor.insertText = (text: string) => {\n        const domSelection = window.getSelection();\n        const anchorNode = domSelection?.anchorNode;\n        if (AngularEditor.isBlockCardLeftCursor(editor) || AngularEditor.isBlockCardRightCursor(editor)) {\n            const isLeftCursor = isCardLeft(anchorNode);\n            const cardEntry = AngularEditor.toSlateCardEntry(editor, anchorNode);\n            const cursorRootPath = cardEntry[1];\n            if (isLeftCursor) {\n                insertParagraph(editor, cursorRootPath);\n                Transforms.select(editor, cursorRootPath);\n            } else {\n                const nextPath = Path.next(cursorRootPath);\n                insertParagraph(editor, nextPath);\n                Transforms.select(editor, nextPath);\n            }\n        }\n        insertText(text);\n    };\n\n    editor.mousedown = (event: MouseEvent) => {\n        const editableElement = AngularEditor.toDOMNode(editor, editor);\n        const absoluteElement = document.elementFromPoint(event.x, event.y);\n        if (editableElement.isEqualNode(absoluteElement)) {\n            const rectEditable = editableElement.getBoundingClientRect();\n            let { paddingRight } = window.getComputedStyle(editableElement, null);\n            const paddingRightPixels = coercePixelsFromCssValue(paddingRight);\n            const fakeRightX = rectEditable.right - paddingRightPixels - 50;\n            let relativeElement = document.elementFromPoint(fakeRightX, event.y);\n            let relativeBlockCardElement = relativeElement.closest('.slate-block-card');\n            if (relativeBlockCardElement) {\n                const centerX = rectEditable.x + rectEditable.width / 2;\n                const blockCardEntry = AngularEditor.toSlateCardEntry(editor, relativeBlockCardElement.firstElementChild);\n                if (blockCardEntry && editor.isBlockCard(blockCardEntry[0])) {\n                    const parentBlockCardEntry = Editor.above(editor, {\n                        at: blockCardEntry[1],\n                        mode: 'highest',\n                        match: node => editor.isBlockCard(node)\n                    });\n                    event.preventDefault();\n                    if (parentBlockCardEntry) {\n                        AngularEditor.moveBlockCard(editor, parentBlockCardEntry[0], { direction: event.x < centerX ? 'left' : 'right' });\n                    } else {\n                        AngularEditor.moveBlockCard(editor, blockCardEntry[0], { direction: event.x < centerX ? 'left' : 'right' });\n                    }\n                }\n            }\n            return;\n        }\n        const innerBlockCardElement = absoluteElement.querySelector('[card-target=\"card-center\"]');\n        if (innerBlockCardElement) {\n            const blockCardEntry = AngularEditor.toSlateCardEntry(editor, innerBlockCardElement.firstElementChild);\n            if (blockCardEntry && editor.isBlockCard(blockCardEntry[0])) {\n                const { x, width } = innerBlockCardElement.getBoundingClientRect();\n                const centerX = x + width / 2;\n                event.preventDefault();\n                AngularEditor.moveBlockCard(editor, blockCardEntry[0], { direction: event.x < centerX ? 'left' : 'right' });\n            }\n        }\n        mousedown(event);\n    };\n\n    return editor;\n};\n\nexport const createBlockCardPlugin = createPluginFactory({\n    key: PluginKeys.blockCard,\n    withOverrides: withBlockCard\n});\n"]}
@@ -1,49 +0,0 @@
1
- import { ThyPopover } from 'ngx-tethys/popover';
2
- import { DropdownMode, ElementKinds, MarkTypes, ToolbarActionTypes } from '../../constants';
3
- import { createPluginFactory } from '../../core';
4
- import { PluginKeys, ToolbarItemType } from '../../interfaces';
5
- import { isColorIndicator, isColorInput, isColorPanel } from '../../utils';
6
- export const withInternalCommon = (editor) => {
7
- const { globalMousedown, onKeydown } = editor;
8
- editor.globalMousedown = (event) => {
9
- const target = event.target;
10
- if (isColorIndicator(target)) {
11
- event.stopPropagation();
12
- return;
13
- }
14
- if (isColorInput(target)) {
15
- return;
16
- }
17
- if (isColorPanel(target)) {
18
- event.preventDefault();
19
- }
20
- globalMousedown(event);
21
- };
22
- editor.onKeydown = (event) => {
23
- const isColorPanel = document.querySelector('.thy-color-picker-panel') || document.querySelector('.thy-color-picker-custom-panel');
24
- if (editor.selection && isColorPanel) {
25
- const popover = editor.injector.get(ThyPopover);
26
- popover.close();
27
- }
28
- onKeydown(event);
29
- };
30
- return editor;
31
- };
32
- export const createCommonPlugin = (locale) => createPluginFactory({
33
- key: PluginKeys.internalCommon,
34
- withOverrides: withInternalCommon,
35
- toolbarItems: [
36
- {
37
- key: ToolbarActionTypes.group,
38
- name: locale().more,
39
- icon: 'more',
40
- type: ToolbarItemType.dropdown,
41
- dropdownMode: DropdownMode.icon,
42
- dropdownItemKey: ToolbarActionTypes.group,
43
- dropdownFixedIcon: true,
44
- isHideDropdownActionIcon: true,
45
- includes: [MarkTypes.underline, MarkTypes.strike, ElementKinds.inlineCode]
46
- }
47
- ]
48
- })();
49
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9uLnBsdWdpbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3NyYy9wbHVnaW5zL2NvbW1vbi9jb21tb24ucGx1Z2luLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUVoRCxPQUFPLEVBQUUsWUFBWSxFQUFFLFlBQVksRUFBRSxTQUFTLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUM1RixPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFDakQsT0FBTyxFQUFFLFVBQVUsRUFBRSxlQUFlLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUMvRCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsWUFBWSxFQUFFLFlBQVksRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUkzRSxNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBRyxDQUFtQixNQUFTLEVBQUssRUFBRTtJQUNqRSxNQUFNLEVBQUUsZUFBZSxFQUFFLFNBQVMsRUFBRSxHQUFHLE1BQU0sQ0FBQztJQUU5QyxNQUFNLENBQUMsZUFBZSxHQUFHLENBQUMsS0FBaUIsRUFBRSxFQUFFO1FBQzNDLE1BQU0sTUFBTSxHQUFHLEtBQUssQ0FBQyxNQUFxQixDQUFDO1FBQzNDLElBQUksZ0JBQWdCLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQztZQUMzQixLQUFLLENBQUMsZUFBZSxFQUFFLENBQUM7WUFDeEIsT0FBTztRQUNYLENBQUM7UUFDRCxJQUFJLFlBQVksQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDO1lBQ3ZCLE9BQU87UUFDWCxDQUFDO1FBQ0QsSUFBSSxZQUFZLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQztZQUN2QixLQUFLLENBQUMsY0FBYyxFQUFFLENBQUM7UUFDM0IsQ0FBQztRQUNELGVBQWUsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUMzQixDQUFDLENBQUM7SUFFRixNQUFNLENBQUMsU0FBUyxHQUFHLENBQUMsS0FBb0IsRUFBRSxFQUFFO1FBQ3hDLE1BQU0sWUFBWSxHQUFHLFFBQVEsQ0FBQyxhQUFhLENBQUMseUJBQXlCLENBQUMsSUFBSSxRQUFRLENBQUMsYUFBYSxDQUFDLGdDQUFnQyxDQUFDLENBQUM7UUFDbkksSUFBSSxNQUFNLENBQUMsU0FBUyxJQUFJLFlBQVksRUFBRSxDQUFDO1lBQ25DLE1BQU0sT0FBTyxHQUFHLE1BQU0sQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLFVBQVUsQ0FBQyxDQUFDO1lBQ2hELE9BQU8sQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUNwQixDQUFDO1FBQ0QsU0FBUyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3JCLENBQUMsQ0FBQztJQUVGLE9BQU8sTUFBTSxDQUFDO0FBQ2xCLENBQUMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHLENBQUMsTUFBa0MsRUFBRSxFQUFFLENBQ3JFLG1CQUFtQixDQUFDO0lBQ2hCLEdBQUcsRUFBRSxVQUFVLENBQUMsY0FBYztJQUM5QixhQUFhLEVBQUUsa0JBQWtCO0lBQ2pDLFlBQVksRUFBRTtRQUNWO1lBQ0ksR0FBRyxFQUFFLGtCQUFrQixDQUFDLEtBQUs7WUFDN0IsSUFBSSxFQUFFLE1BQU0sRUFBRSxDQUFDLElBQUk7WUFDbkIsSUFBSSxFQUFFLE1BQU07WUFDWixJQUFJLEVBQUUsZUFBZSxDQUFDLFFBQVE7WUFDOUIsWUFBWSxFQUFFLFlBQVksQ0FBQyxJQUFJO1lBQy9CLGVBQWUsRUFBRSxrQkFBa0IsQ0FBQyxLQUFLO1lBQ3pDLGlCQUFpQixFQUFFLElBQUk7WUFDdkIsd0JBQXdCLEVBQUUsSUFBSTtZQUM5QixRQUFRLEVBQUUsQ0FBQyxTQUFTLENBQUMsU0FBUyxFQUFFLFNBQVMsQ0FBQyxNQUFNLEVBQUUsWUFBWSxDQUFDLFVBQVUsQ0FBQztTQUM3RTtLQUNKO0NBQ0osQ0FBQyxFQUFFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUaHlQb3BvdmVyIH0gZnJvbSAnbmd4LXRldGh5cy9wb3BvdmVyJztcbmltcG9ydCB7IEVkaXRvciB9IGZyb20gJ3NsYXRlJztcbmltcG9ydCB7IERyb3Bkb3duTW9kZSwgRWxlbWVudEtpbmRzLCBNYXJrVHlwZXMsIFRvb2xiYXJBY3Rpb25UeXBlcyB9IGZyb20gJy4uLy4uL2NvbnN0YW50cyc7XG5pbXBvcnQgeyBjcmVhdGVQbHVnaW5GYWN0b3J5IH0gZnJvbSAnLi4vLi4vY29yZSc7XG5pbXBvcnQgeyBQbHVnaW5LZXlzLCBUb29sYmFySXRlbVR5cGUgfSBmcm9tICcuLi8uLi9pbnRlcmZhY2VzJztcbmltcG9ydCB7IGlzQ29sb3JJbmRpY2F0b3IsIGlzQ29sb3JJbnB1dCwgaXNDb2xvclBhbmVsIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IHsgU2lnbmFsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUaGVJMThuVHJhbnNsYXRpb24gfSBmcm9tICcuLi8uLi9pMThuJztcblxuZXhwb3J0IGNvbnN0IHdpdGhJbnRlcm5hbENvbW1vbiA9IDxUIGV4dGVuZHMgRWRpdG9yPihlZGl0b3I6IFQpOiBUID0+IHtcbiAgICBjb25zdCB7IGdsb2JhbE1vdXNlZG93biwgb25LZXlkb3duIH0gPSBlZGl0b3I7XG5cbiAgICBlZGl0b3IuZ2xvYmFsTW91c2Vkb3duID0gKGV2ZW50OiBNb3VzZUV2ZW50KSA9PiB7XG4gICAgICAgIGNvbnN0IHRhcmdldCA9IGV2ZW50LnRhcmdldCBhcyBIVE1MRWxlbWVudDtcbiAgICAgICAgaWYgKGlzQ29sb3JJbmRpY2F0b3IodGFyZ2V0KSkge1xuICAgICAgICAgICAgZXZlbnQuc3RvcFByb3BhZ2F0aW9uKCk7XG4gICAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cbiAgICAgICAgaWYgKGlzQ29sb3JJbnB1dCh0YXJnZXQpKSB7XG4gICAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cbiAgICAgICAgaWYgKGlzQ29sb3JQYW5lbCh0YXJnZXQpKSB7XG4gICAgICAgICAgICBldmVudC5wcmV2ZW50RGVmYXVsdCgpO1xuICAgICAgICB9XG4gICAgICAgIGdsb2JhbE1vdXNlZG93bihldmVudCk7XG4gICAgfTtcblxuICAgIGVkaXRvci5vbktleWRvd24gPSAoZXZlbnQ6IEtleWJvYXJkRXZlbnQpID0+IHtcbiAgICAgICAgY29uc3QgaXNDb2xvclBhbmVsID0gZG9jdW1lbnQucXVlcnlTZWxlY3RvcignLnRoeS1jb2xvci1waWNrZXItcGFuZWwnKSB8fCBkb2N1bWVudC5xdWVyeVNlbGVjdG9yKCcudGh5LWNvbG9yLXBpY2tlci1jdXN0b20tcGFuZWwnKTtcbiAgICAgICAgaWYgKGVkaXRvci5zZWxlY3Rpb24gJiYgaXNDb2xvclBhbmVsKSB7XG4gICAgICAgICAgICBjb25zdCBwb3BvdmVyID0gZWRpdG9yLmluamVjdG9yLmdldChUaHlQb3BvdmVyKTtcbiAgICAgICAgICAgIHBvcG92ZXIuY2xvc2UoKTtcbiAgICAgICAgfVxuICAgICAgICBvbktleWRvd24oZXZlbnQpO1xuICAgIH07XG5cbiAgICByZXR1cm4gZWRpdG9yO1xufTtcblxuZXhwb3J0IGNvbnN0IGNyZWF0ZUNvbW1vblBsdWdpbiA9IChsb2NhbGU6IFNpZ25hbDxUaGVJMThuVHJhbnNsYXRpb24+KSA9PlxuICAgIGNyZWF0ZVBsdWdpbkZhY3Rvcnkoe1xuICAgICAgICBrZXk6IFBsdWdpbktleXMuaW50ZXJuYWxDb21tb24sXG4gICAgICAgIHdpdGhPdmVycmlkZXM6IHdpdGhJbnRlcm5hbENvbW1vbixcbiAgICAgICAgdG9vbGJhckl0ZW1zOiBbXG4gICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAga2V5OiBUb29sYmFyQWN0aW9uVHlwZXMuZ3JvdXAsXG4gICAgICAgICAgICAgICAgbmFtZTogbG9jYWxlKCkubW9yZSxcbiAgICAgICAgICAgICAgICBpY29uOiAnbW9yZScsXG4gICAgICAgICAgICAgICAgdHlwZTogVG9vbGJhckl0ZW1UeXBlLmRyb3Bkb3duLFxuICAgICAgICAgICAgICAgIGRyb3Bkb3duTW9kZTogRHJvcGRvd25Nb2RlLmljb24sXG4gICAgICAgICAgICAgICAgZHJvcGRvd25JdGVtS2V5OiBUb29sYmFyQWN0aW9uVHlwZXMuZ3JvdXAsXG4gICAgICAgICAgICAgICAgZHJvcGRvd25GaXhlZEljb246IHRydWUsXG4gICAgICAgICAgICAgICAgaXNIaWRlRHJvcGRvd25BY3Rpb25JY29uOiB0cnVlLFxuICAgICAgICAgICAgICAgIGluY2x1ZGVzOiBbTWFya1R5cGVzLnVuZGVybGluZSwgTWFya1R5cGVzLnN0cmlrZSwgRWxlbWVudEtpbmRzLmlubGluZUNvZGVdXG4gICAgICAgICAgICB9XG4gICAgICAgIF1cbiAgICB9KSgpO1xuIl19
@@ -1,24 +0,0 @@
1
- import { Element } from 'slate';
2
- import { createPluginFactory, getPluginOptions } from '../../core';
3
- import { PluginKeys } from '../../interfaces';
4
- import * as TheQueries from '../../queries';
5
- export const withGetFragment = (editor) => {
6
- const { getFragment } = editor;
7
- const elementKinds = getPluginOptions(editor, PluginKeys.getFragment)?.types ?? [];
8
- editor.getFragment = () => {
9
- const { selection } = editor;
10
- const containerBlocks = [...elementKinds, ...TheQueries.getContainerBlocks(editor)];
11
- if (selection && selection.anchor.path[0] === selection.focus.path[0]) {
12
- const fragmentData = getFragment();
13
- const nodes = TheQueries.getSelectionNodesByType(editor, fragmentData, containerBlocks);
14
- return nodes && Element.isElement(nodes) ? nodes.children : fragmentData;
15
- }
16
- return getFragment();
17
- };
18
- return editor;
19
- };
20
- export const createGetFragmentPlugin = createPluginFactory({
21
- key: PluginKeys.getFragment,
22
- withOverrides: withGetFragment
23
- });
24
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0LWZyYWdtZW50LnBsdWdpbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3NyYy9wbHVnaW5zL2NvbW1vbi9nZXQtZnJhZ21lbnQucGx1Z2luLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBVSxPQUFPLEVBQUUsTUFBTSxPQUFPLENBQUM7QUFDeEMsT0FBTyxFQUFFLG1CQUFtQixFQUFFLGdCQUFnQixFQUFFLE1BQU0sWUFBWSxDQUFDO0FBRW5FLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUM5QyxPQUFPLEtBQUssVUFBVSxNQUFNLGVBQWUsQ0FBQztBQU01QyxNQUFNLENBQUMsTUFBTSxlQUFlLEdBQUcsQ0FBbUIsTUFBUyxFQUFFLEVBQUU7SUFDM0QsTUFBTSxFQUFFLFdBQVcsRUFBRSxHQUFHLE1BQU0sQ0FBQztJQUMvQixNQUFNLFlBQVksR0FBRyxnQkFBZ0IsQ0FBMkIsTUFBTSxFQUFFLFVBQVUsQ0FBQyxXQUFXLENBQUMsRUFBRSxLQUFLLElBQUksRUFBRSxDQUFDO0lBRTdHLE1BQU0sQ0FBQyxXQUFXLEdBQUcsR0FBRyxFQUFFO1FBQ3RCLE1BQU0sRUFBRSxTQUFTLEVBQUUsR0FBRyxNQUFNLENBQUM7UUFDN0IsTUFBTSxlQUFlLEdBQUcsQ0FBQyxHQUFHLFlBQVksRUFBRSxHQUFHLFVBQVUsQ0FBQyxrQkFBa0IsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDO1FBQ3BGLElBQUksU0FBUyxJQUFJLFNBQVMsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxLQUFLLFNBQVMsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7WUFDcEUsTUFBTSxZQUFZLEdBQUcsV0FBVyxFQUFFLENBQUM7WUFDbkMsTUFBTSxLQUFLLEdBQUcsVUFBVSxDQUFDLHVCQUF1QixDQUFDLE1BQU0sRUFBRSxZQUFZLEVBQUUsZUFBZSxDQUFDLENBQUM7WUFDeEYsT0FBTyxLQUFLLElBQUksT0FBTyxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsWUFBWSxDQUFDO1FBQzdFLENBQUM7UUFDRCxPQUFPLFdBQVcsRUFBRSxDQUFDO0lBQ3pCLENBQUMsQ0FBQztJQUVGLE9BQU8sTUFBTSxDQUFDO0FBQ2xCLENBQUMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLHVCQUF1QixHQUFHLG1CQUFtQixDQUEyQjtJQUNqRixHQUFHLEVBQUUsVUFBVSxDQUFDLFdBQVc7SUFDM0IsYUFBYSxFQUFFLGVBQWU7Q0FDakMsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRWRpdG9yLCBFbGVtZW50IH0gZnJvbSAnc2xhdGUnO1xuaW1wb3J0IHsgY3JlYXRlUGx1Z2luRmFjdG9yeSwgZ2V0UGx1Z2luT3B0aW9ucyB9IGZyb20gJy4uLy4uL2NvcmUnO1xuaW1wb3J0IHsgQ3VzdG9tRWxlbWVudEtpbmRzIH0gZnJvbSAnLi4vLi4vY3VzdG9tLXR5cGVzJztcbmltcG9ydCB7IFBsdWdpbktleXMgfSBmcm9tICcuLi8uLi9pbnRlcmZhY2VzJztcbmltcG9ydCAqIGFzIFRoZVF1ZXJpZXMgZnJvbSAnLi4vLi4vcXVlcmllcyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgR2V0RnJhZ21lbnRQbHVnaW5PcHRpb25zIHtcbiAgICB0eXBlcz86IEN1c3RvbUVsZW1lbnRLaW5kc1tdO1xufVxuXG5leHBvcnQgY29uc3Qgd2l0aEdldEZyYWdtZW50ID0gPFQgZXh0ZW5kcyBFZGl0b3I+KGVkaXRvcjogVCkgPT4ge1xuICAgIGNvbnN0IHsgZ2V0RnJhZ21lbnQgfSA9IGVkaXRvcjtcbiAgICBjb25zdCBlbGVtZW50S2luZHMgPSBnZXRQbHVnaW5PcHRpb25zPEdldEZyYWdtZW50UGx1Z2luT3B0aW9ucz4oZWRpdG9yLCBQbHVnaW5LZXlzLmdldEZyYWdtZW50KT8udHlwZXMgPz8gW107XG5cbiAgICBlZGl0b3IuZ2V0RnJhZ21lbnQgPSAoKSA9PiB7XG4gICAgICAgIGNvbnN0IHsgc2VsZWN0aW9uIH0gPSBlZGl0b3I7XG4gICAgICAgIGNvbnN0IGNvbnRhaW5lckJsb2NrcyA9IFsuLi5lbGVtZW50S2luZHMsIC4uLlRoZVF1ZXJpZXMuZ2V0Q29udGFpbmVyQmxvY2tzKGVkaXRvcildO1xuICAgICAgICBpZiAoc2VsZWN0aW9uICYmIHNlbGVjdGlvbi5hbmNob3IucGF0aFswXSA9PT0gc2VsZWN0aW9uLmZvY3VzLnBhdGhbMF0pIHtcbiAgICAgICAgICAgIGNvbnN0IGZyYWdtZW50RGF0YSA9IGdldEZyYWdtZW50KCk7XG4gICAgICAgICAgICBjb25zdCBub2RlcyA9IFRoZVF1ZXJpZXMuZ2V0U2VsZWN0aW9uTm9kZXNCeVR5cGUoZWRpdG9yLCBmcmFnbWVudERhdGEsIGNvbnRhaW5lckJsb2Nrcyk7XG4gICAgICAgICAgICByZXR1cm4gbm9kZXMgJiYgRWxlbWVudC5pc0VsZW1lbnQobm9kZXMpID8gbm9kZXMuY2hpbGRyZW4gOiBmcmFnbWVudERhdGE7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIGdldEZyYWdtZW50KCk7XG4gICAgfTtcblxuICAgIHJldHVybiBlZGl0b3I7XG59O1xuXG5leHBvcnQgY29uc3QgY3JlYXRlR2V0RnJhZ21lbnRQbHVnaW4gPSBjcmVhdGVQbHVnaW5GYWN0b3J5PEdldEZyYWdtZW50UGx1Z2luT3B0aW9ucz4oe1xuICAgIGtleTogUGx1Z2luS2V5cy5nZXRGcmFnbWVudCxcbiAgICB3aXRoT3ZlcnJpZGVzOiB3aXRoR2V0RnJhZ21lbnRcbn0pO1xuIl19