@vendure/admin-ui 1.7.4 → 1.8.1

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 (228) hide show
  1. package/bundles/vendure-admin-ui-catalog.umd.js +902 -74
  2. package/bundles/vendure-admin-ui-catalog.umd.js.map +1 -1
  3. package/bundles/vendure-admin-ui-core.umd.js +2392 -820
  4. package/bundles/vendure-admin-ui-core.umd.js.map +1 -1
  5. package/bundles/vendure-admin-ui-customer.umd.js +4 -3
  6. package/bundles/vendure-admin-ui-customer.umd.js.map +1 -1
  7. package/bundles/vendure-admin-ui-dashboard.umd.js +3 -1
  8. package/bundles/vendure-admin-ui-dashboard.umd.js.map +1 -1
  9. package/bundles/vendure-admin-ui-order.umd.js +781 -175
  10. package/bundles/vendure-admin-ui-order.umd.js.map +1 -1
  11. package/bundles/vendure-admin-ui-settings.umd.js +5 -4
  12. package/bundles/vendure-admin-ui-settings.umd.js.map +1 -1
  13. package/bundles/vendure-admin-ui-system.umd.js +1 -1
  14. package/catalog/catalog.module.d.ts +3 -0
  15. package/catalog/components/assign-to-channel-dialog/assign-to-channel-dialog.component.d.ts +17 -0
  16. package/catalog/components/bulk-add-facet-values-dialog/bulk-add-facet-values-dialog.component.d.ts +38 -0
  17. package/catalog/components/bulk-add-facet-values-dialog/bulk-add-facet-values-dialog.graphql.d.ts +4 -0
  18. package/catalog/components/collection-list/collection-list-bulk-actions.d.ts +6 -0
  19. package/catalog/components/collection-list/collection-list.component.d.ts +7 -5
  20. package/catalog/components/collection-tree/collection-tree-node.component.d.ts +8 -4
  21. package/catalog/components/collection-tree/collection-tree.component.d.ts +2 -1
  22. package/catalog/components/facet-list/facet-list-bulk-actions.d.ts +5 -0
  23. package/catalog/components/facet-list/facet-list.component.d.ts +2 -1
  24. package/catalog/components/product-list/product-list-bulk-actions.d.ts +6 -0
  25. package/catalog/components/product-list/product-list.component.d.ts +2 -1
  26. package/catalog/public_api.d.ts +6 -0
  27. package/catalog/vendure-admin-ui-catalog.metadata.json +1 -1
  28. package/core/common/component-registry-types.d.ts +1 -1
  29. package/core/common/generated-types.d.ts +609 -3
  30. package/core/common/utilities/bulk-action-utils.d.ts +19 -0
  31. package/core/common/utilities/selection-manager.d.ts +7 -0
  32. package/core/common/version.d.ts +1 -1
  33. package/core/data/definitions/collection-definitions.d.ts +3 -0
  34. package/core/data/definitions/facet-definitions.d.ts +3 -0
  35. package/core/data/definitions/order-definitions.d.ts +12 -0
  36. package/core/data/definitions/product-definitions.d.ts +1 -0
  37. package/core/data/providers/collection-data.service.d.ts +4 -1
  38. package/core/data/providers/facet-data.service.d.ts +4 -1
  39. package/core/data/providers/order-data.service.d.ts +18 -1
  40. package/core/data/providers/product-data.service.d.ts +1 -0
  41. package/core/providers/bulk-action-registry/bulk-action-registry.service.d.ts +6 -0
  42. package/core/providers/bulk-action-registry/bulk-action-types.d.ts +149 -0
  43. package/core/providers/bulk-action-registry/register-bulk-action.d.ts +53 -0
  44. package/core/providers/modal/modal.service.d.ts +2 -0
  45. package/core/providers/nav-builder/nav-builder-types.d.ts +1 -0
  46. package/core/public_api.d.ts +18 -1
  47. package/core/shared/components/asset-gallery/asset-gallery.component.d.ts +3 -3
  48. package/core/shared/components/bulk-action-menu/bulk-action-menu.component.d.ts +29 -0
  49. package/core/shared/components/data-table/data-table.component.d.ts +26 -7
  50. package/core/shared/components/dropdown/dropdown-menu.component.d.ts +1 -0
  51. package/core/shared/components/radio-card/radio-card-fieldset.component.d.ts +21 -0
  52. package/core/shared/components/radio-card/radio-card.component.d.ts +19 -0
  53. package/core/shared/components/rich-text-editor/prosemirror/context-menu/context-menu.component.d.ts +28 -0
  54. package/core/shared/components/rich-text-editor/prosemirror/context-menu/context-menu.service.d.ts +31 -0
  55. package/core/shared/components/rich-text-editor/prosemirror/custom-nodes.d.ts +4 -0
  56. package/core/shared/components/rich-text-editor/prosemirror/inputrules.d.ts +5 -5
  57. package/core/shared/components/rich-text-editor/prosemirror/menu/links.d.ts +1 -1
  58. package/core/shared/components/rich-text-editor/prosemirror/menu/menu-common.d.ts +12 -0
  59. package/core/shared/components/rich-text-editor/prosemirror/menu/menu-plugin.d.ts +9 -0
  60. package/core/shared/components/rich-text-editor/prosemirror/menu/sub-menu-with-icon.d.ts +14 -0
  61. package/core/shared/components/rich-text-editor/prosemirror/plugins/image-plugin.d.ts +7 -0
  62. package/core/shared/components/rich-text-editor/prosemirror/plugins/link-select-plugin.d.ts +1 -1
  63. package/core/shared/components/rich-text-editor/prosemirror/plugins/raw-editor-plugin.d.ts +7 -0
  64. package/core/shared/components/rich-text-editor/prosemirror/plugins/tables-plugin.d.ts +13 -0
  65. package/core/shared/components/rich-text-editor/prosemirror/prosemirror.service.d.ts +7 -3
  66. package/core/shared/components/rich-text-editor/prosemirror/types.d.ts +0 -2
  67. package/core/shared/components/rich-text-editor/raw-html-dialog/raw-html-dialog.component.d.ts +18 -0
  68. package/core/shared/components/rich-text-editor/rich-text-editor.component.d.ts +6 -2
  69. package/core/shared/dynamic-form-inputs/code-editor-form-input/base-code-editor-form-input.component.d.ts +27 -0
  70. package/core/shared/dynamic-form-inputs/code-editor-form-input/html-editor-form-input.component.d.ts +19 -0
  71. package/core/shared/dynamic-form-inputs/code-editor-form-input/json-editor-form-input.component.d.ts +5 -17
  72. package/core/shared/dynamic-form-inputs/register-dynamic-input-components.d.ts +2 -1
  73. package/core/vendure-admin-ui-core.metadata.json +1 -1
  74. package/customer/components/customer-group-member-list/customer-group-member-list.component.d.ts +11 -4
  75. package/customer/vendure-admin-ui-customer.metadata.json +1 -1
  76. package/esm2015/catalog/catalog.module.js +25 -2
  77. package/esm2015/catalog/components/assign-products-to-channel-dialog/assign-products-to-channel-dialog.component.js +4 -1
  78. package/esm2015/catalog/components/assign-to-channel-dialog/assign-to-channel-dialog.component.js +51 -0
  79. package/esm2015/catalog/components/bulk-add-facet-values-dialog/bulk-add-facet-values-dialog.component.js +89 -0
  80. package/esm2015/catalog/components/bulk-add-facet-values-dialog/bulk-add-facet-values-dialog.graphql.js +69 -0
  81. package/esm2015/catalog/components/collection-detail/collection-detail.component.js +3 -3
  82. package/esm2015/catalog/components/collection-list/collection-list-bulk-actions.js +147 -0
  83. package/esm2015/catalog/components/collection-list/collection-list.component.js +17 -8
  84. package/esm2015/catalog/components/collection-tree/collection-tree-node.component.js +16 -7
  85. package/esm2015/catalog/components/collection-tree/collection-tree.component.js +3 -2
  86. package/esm2015/catalog/components/facet-list/facet-list-bulk-actions.js +208 -0
  87. package/esm2015/catalog/components/facet-list/facet-list.component.js +13 -4
  88. package/esm2015/catalog/components/product-detail/product-detail.component.js +35 -23
  89. package/esm2015/catalog/components/product-list/product-list-bulk-actions.js +173 -0
  90. package/esm2015/catalog/components/product-list/product-list.component.js +10 -5
  91. package/esm2015/catalog/components/product-variants-list/product-variants-list.component.js +2 -2
  92. package/esm2015/catalog/providers/routing/collection-resolver.js +2 -1
  93. package/esm2015/catalog/public_api.js +7 -1
  94. package/esm2015/core/common/component-registry-types.js +1 -1
  95. package/esm2015/core/common/generated-types.js +5 -1
  96. package/esm2015/core/common/introspection-result.js +296 -191
  97. package/esm2015/core/common/utilities/bulk-action-utils.js +44 -0
  98. package/esm2015/core/common/utilities/selection-manager.js +33 -1
  99. package/esm2015/core/common/version.js +2 -2
  100. package/esm2015/core/components/breadcrumb/breadcrumb.component.js +1 -1
  101. package/esm2015/core/data/definitions/collection-definitions.js +30 -1
  102. package/esm2015/core/data/definitions/facet-definitions.js +31 -1
  103. package/esm2015/core/data/definitions/order-definitions.js +114 -1
  104. package/esm2015/core/data/definitions/product-definitions.js +15 -1
  105. package/esm2015/core/data/providers/collection-data.service.js +17 -2
  106. package/esm2015/core/data/providers/customer-data.service.js +8 -4
  107. package/esm2015/core/data/providers/facet-data.service.js +18 -2
  108. package/esm2015/core/data/providers/order-data.service.js +38 -2
  109. package/esm2015/core/data/providers/product-data.service.js +7 -2
  110. package/esm2015/core/data/utils/remove-readonly-custom-fields.js +5 -1
  111. package/esm2015/core/providers/bulk-action-registry/bulk-action-registry.service.js +27 -0
  112. package/esm2015/core/providers/bulk-action-registry/bulk-action-types.js +2 -0
  113. package/esm2015/core/providers/bulk-action-registry/register-bulk-action.js +63 -0
  114. package/esm2015/core/providers/dashboard-widget/dashboard-widget.service.js +1 -4
  115. package/esm2015/core/providers/modal/modal.service.js +2 -1
  116. package/esm2015/core/providers/nav-builder/nav-builder-types.js +1 -1
  117. package/esm2015/core/public_api.js +19 -2
  118. package/esm2015/core/shared/components/action-bar/action-bar.component.js +4 -8
  119. package/esm2015/core/shared/components/asset-gallery/asset-gallery.component.js +2 -2
  120. package/esm2015/core/shared/components/bulk-action-menu/bulk-action-menu.component.js +99 -0
  121. package/esm2015/core/shared/components/data-table/data-table.component.js +64 -15
  122. package/esm2015/core/shared/components/dropdown/dropdown-menu.component.js +4 -3
  123. package/esm2015/core/shared/components/facet-value-selector/facet-value-selector.component.js +2 -2
  124. package/esm2015/core/shared/components/language-selector/language-selector.component.js +2 -2
  125. package/esm2015/core/shared/components/order-state-label/order-state-label.component.js +2 -1
  126. package/esm2015/core/shared/components/product-search-input/product-search-input.component.js +1 -1
  127. package/esm2015/core/shared/components/product-selector/product-selector.component.js +1 -1
  128. package/esm2015/core/shared/components/radio-card/radio-card-fieldset.component.js +57 -0
  129. package/esm2015/core/shared/components/radio-card/radio-card.component.js +54 -0
  130. package/esm2015/core/shared/components/rich-text-editor/external-image-dialog/external-image-dialog.component.js +2 -2
  131. package/esm2015/core/shared/components/rich-text-editor/prosemirror/context-menu/context-menu.component.js +140 -0
  132. package/esm2015/core/shared/components/rich-text-editor/prosemirror/context-menu/context-menu.service.js +45 -0
  133. package/esm2015/core/shared/components/rich-text-editor/prosemirror/custom-nodes.js +60 -0
  134. package/esm2015/core/shared/components/rich-text-editor/prosemirror/menu/links.js +4 -4
  135. package/esm2015/core/shared/components/rich-text-editor/prosemirror/menu/menu-common.js +23 -1
  136. package/esm2015/core/shared/components/rich-text-editor/prosemirror/menu/menu-plugin.js +12 -0
  137. package/esm2015/core/shared/components/rich-text-editor/prosemirror/menu/menu.js +73 -18
  138. package/esm2015/core/shared/components/rich-text-editor/prosemirror/menu/sub-menu-with-icon.js +16 -0
  139. package/esm2015/core/shared/components/rich-text-editor/prosemirror/plugins/image-plugin.js +100 -0
  140. package/esm2015/core/shared/components/rich-text-editor/prosemirror/plugins/raw-editor-plugin.js +97 -0
  141. package/esm2015/core/shared/components/rich-text-editor/prosemirror/plugins/tables-plugin.js +166 -0
  142. package/esm2015/core/shared/components/rich-text-editor/prosemirror/prosemirror.service.js +47 -17
  143. package/esm2015/core/shared/components/rich-text-editor/prosemirror/types.js +1 -1
  144. package/esm2015/core/shared/components/rich-text-editor/raw-html-dialog/raw-html-dialog.component.js +57 -0
  145. package/esm2015/core/shared/components/rich-text-editor/rich-text-editor.component.js +20 -9
  146. package/esm2015/core/shared/components/simple-dialog/simple-dialog.component.js +2 -2
  147. package/esm2015/core/shared/dynamic-form-inputs/code-editor-form-input/base-code-editor-form-input.component.js +59 -0
  148. package/esm2015/core/shared/dynamic-form-inputs/code-editor-form-input/html-editor-form-input.component.js +66 -0
  149. package/esm2015/core/shared/dynamic-form-inputs/code-editor-form-input/json-editor-form-input.component.js +47 -84
  150. package/esm2015/core/shared/dynamic-form-inputs/dynamic-form-input/dynamic-form-input.component.js +3 -3
  151. package/esm2015/core/shared/dynamic-form-inputs/register-dynamic-input-components.js +3 -1
  152. package/esm2015/core/shared/pipes/state-i18n-token.pipe.js +2 -1
  153. package/esm2015/core/shared/shared.module.js +13 -1
  154. package/esm2015/customer/components/customer-group-list/customer-group-list.component.js +2 -2
  155. package/esm2015/customer/components/customer-group-member-list/customer-group-member-list.component.js +6 -6
  156. package/esm2015/customer/components/customer-list/customer-list.component.js +2 -2
  157. package/esm2015/dashboard/dashboard.module.js +6 -2
  158. package/esm2015/order/components/coupon-code-selector/coupon-code-selector.component.js +42 -0
  159. package/esm2015/order/components/draft-order-detail/draft-order-detail.component.js +195 -0
  160. package/esm2015/order/components/draft-order-variant-selector/draft-order-variant-selector.component.js +59 -0
  161. package/esm2015/order/components/order-detail/order-detail.component.js +2 -2
  162. package/esm2015/order/components/order-editor/order-editor.component.js +5 -11
  163. package/esm2015/order/components/order-list/order-list.component.js +20 -4
  164. package/esm2015/order/components/order-table/order-table.component.js +16 -5
  165. package/esm2015/order/components/select-address-dialog/select-address-dialog.component.js +91 -0
  166. package/esm2015/order/components/select-address-dialog/select-address-dialog.graphql.js +14 -0
  167. package/esm2015/order/components/select-customer-dialog/select-customer-dialog.component.js +59 -0
  168. package/esm2015/order/components/select-shipping-method-dialog/select-shipping-method-dialog.component.js +30 -0
  169. package/esm2015/order/order.module.js +13 -1
  170. package/esm2015/order/order.routes.js +26 -7
  171. package/esm2015/order/providers/routing/order-resolver.js +29 -12
  172. package/esm2015/order/providers/routing/order.guard.js +41 -0
  173. package/esm2015/order/public_api.js +9 -1
  174. package/esm2015/settings/components/country-list/country-list.component.js +2 -2
  175. package/esm2015/settings/components/profile/profile.component.js +2 -2
  176. package/esm2015/settings/components/zone-list/zone-list.component.js +2 -2
  177. package/esm2015/settings/components/zone-member-list/zone-member-list.component.js +2 -2
  178. package/esm2015/system/components/health-check/health-check.component.js +1 -1
  179. package/fesm2015/vendure-admin-ui-catalog.js +835 -61
  180. package/fesm2015/vendure-admin-ui-catalog.js.map +1 -1
  181. package/fesm2015/vendure-admin-ui-core.js +3122 -1514
  182. package/fesm2015/vendure-admin-ui-core.js.map +1 -1
  183. package/fesm2015/vendure-admin-ui-customer.js +7 -7
  184. package/fesm2015/vendure-admin-ui-customer.js.map +1 -1
  185. package/fesm2015/vendure-admin-ui-dashboard.js +5 -1
  186. package/fesm2015/vendure-admin-ui-dashboard.js.map +1 -1
  187. package/fesm2015/vendure-admin-ui-order.js +780 -232
  188. package/fesm2015/vendure-admin-ui-order.js.map +1 -1
  189. package/fesm2015/vendure-admin-ui-settings.js +4 -4
  190. package/fesm2015/vendure-admin-ui-settings.js.map +1 -1
  191. package/fesm2015/vendure-admin-ui-system.js +1 -1
  192. package/order/components/coupon-code-selector/coupon-code-selector.component.d.ts +18 -0
  193. package/order/components/draft-order-detail/draft-order-detail.component.d.ts +49 -0
  194. package/order/components/draft-order-variant-selector/draft-order-variant-selector.component.d.ts +21 -0
  195. package/order/components/order-editor/order-editor.component.d.ts +1 -6
  196. package/order/components/order-list/order-list.component.d.ts +1 -0
  197. package/order/components/order-table/order-table.component.d.ts +11 -2
  198. package/order/components/select-address-dialog/select-address-dialog.component.d.ts +24 -0
  199. package/order/components/select-address-dialog/select-address-dialog.graphql.d.ts +1 -0
  200. package/order/components/select-customer-dialog/select-customer-dialog.component.d.ts +22 -0
  201. package/order/components/select-shipping-method-dialog/select-shipping-method-dialog.component.d.ts +16 -0
  202. package/order/providers/routing/order-resolver.d.ts +8 -5
  203. package/order/providers/routing/order.guard.d.ts +9 -0
  204. package/order/public_api.d.ts +8 -0
  205. package/order/vendure-admin-ui-order.metadata.json +1 -1
  206. package/package.json +13 -12
  207. package/settings/components/zone-member-list/zone-member-list.component.d.ts +3 -1
  208. package/settings/vendure-admin-ui-settings.metadata.json +1 -1
  209. package/static/i18n-messages/cs.json +33 -0
  210. package/static/i18n-messages/de.json +33 -0
  211. package/static/i18n-messages/en.json +36 -4
  212. package/static/i18n-messages/es.json +33 -0
  213. package/static/i18n-messages/fr.json +33 -0
  214. package/static/i18n-messages/it.json +33 -0
  215. package/static/i18n-messages/pl.json +33 -0
  216. package/static/i18n-messages/pt_BR.json +33 -0
  217. package/static/i18n-messages/pt_PT.json +33 -0
  218. package/static/i18n-messages/ru.json +33 -0
  219. package/static/i18n-messages/uk.json +33 -0
  220. package/static/i18n-messages/zh_Hans.json +33 -0
  221. package/static/i18n-messages/zh_Hant.json +33 -0
  222. package/static/styles/global/_forms.scss +4 -2
  223. package/static/styles/global/_overrides.scss +1 -1
  224. package/static/styles/global/_utilities.scss +4 -0
  225. package/static/theme.min.css +1 -1
  226. package/system/vendure-admin-ui-system.metadata.json +1 -1
  227. package/core/shared/components/rich-text-editor/prosemirror/menu/images.d.ts +0 -4
  228. package/esm2015/core/shared/components/rich-text-editor/prosemirror/menu/images.js +0 -36
@@ -0,0 +1,100 @@
1
+ import { MenuItem } from 'prosemirror-menu';
2
+ import { NodeSelection, Plugin } from 'prosemirror-state';
3
+ import { ExternalImageDialogComponent, } from '../../external-image-dialog/external-image-dialog.component';
4
+ import { canInsert, renderClarityIcon } from '../menu/menu-common';
5
+ export function insertImageItem(nodeType, modalService) {
6
+ return new MenuItem({
7
+ title: 'Insert image',
8
+ label: 'Image',
9
+ render: renderClarityIcon({ shape: 'image', label: 'Image' }),
10
+ class: '',
11
+ css: '',
12
+ enable(state) {
13
+ return canInsert(state, nodeType);
14
+ },
15
+ run(state, _, view) {
16
+ let attrs;
17
+ if (state.selection instanceof NodeSelection && state.selection.node.type === nodeType) {
18
+ attrs = state.selection.node.attrs;
19
+ }
20
+ modalService
21
+ .fromComponent(ExternalImageDialogComponent, {
22
+ closable: true,
23
+ locals: {
24
+ existing: attrs,
25
+ },
26
+ })
27
+ .subscribe(result => {
28
+ if (result) {
29
+ // tslint:disable-next-line:no-non-null-assertion
30
+ view.dispatch(view.state.tr.replaceSelectionWith(nodeType.createAndFill(result)));
31
+ }
32
+ view.focus();
33
+ });
34
+ },
35
+ });
36
+ }
37
+ export const imageContextMenuPlugin = (contextMenuService, modalService) => new Plugin({
38
+ view: () => {
39
+ return {
40
+ update: view => {
41
+ if (!view.hasFocus()) {
42
+ return;
43
+ }
44
+ const { doc, selection } = view.state;
45
+ let imageNode;
46
+ let imageNodePos = 0;
47
+ doc.nodesBetween(selection.from, selection.to, (n, pos, parent) => {
48
+ if (n.type.name === 'image') {
49
+ imageNode = n;
50
+ imageNodePos = pos;
51
+ return false;
52
+ }
53
+ });
54
+ if (imageNode) {
55
+ const node = view.nodeDOM(imageNodePos);
56
+ if (node instanceof HTMLImageElement) {
57
+ contextMenuService.setContextMenu({
58
+ ref: selection,
59
+ title: 'Image',
60
+ iconShape: 'image',
61
+ element: node,
62
+ coords: view.coordsAtPos(imageNodePos),
63
+ items: [
64
+ {
65
+ enabled: true,
66
+ iconShape: 'image',
67
+ label: 'Image properties',
68
+ onClick: () => {
69
+ contextMenuService.clearContextMenu();
70
+ modalService
71
+ .fromComponent(ExternalImageDialogComponent, {
72
+ closable: true,
73
+ locals: {
74
+ // tslint:disable-next-line:no-non-null-assertion
75
+ existing: imageNode.attrs,
76
+ },
77
+ })
78
+ .subscribe(result => {
79
+ if (result) {
80
+ // tslint:disable-next-line:no-non-null-assertion
81
+ view.dispatch(view.state.tr.replaceSelectionWith(
82
+ // tslint:disable-next-line:no-non-null-assertion
83
+ imageNode.type.createAndFill(result)));
84
+ }
85
+ view.focus();
86
+ });
87
+ },
88
+ },
89
+ ],
90
+ });
91
+ }
92
+ }
93
+ else {
94
+ contextMenuService.clearContextMenu();
95
+ }
96
+ },
97
+ };
98
+ },
99
+ });
100
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image-plugin.js","sourceRoot":"","sources":["../../../../../../../../src/lib/core/src/shared/components/rich-text-editor/prosemirror/plugins/image-plugin.ts"],"names":[],"mappings":"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","sourcesContent":["import { MenuItem } from 'prosemirror-menu';\r\nimport { Node, NodeType } from 'prosemirror-model';\r\nimport { EditorState, NodeSelection, Plugin, Transaction } from 'prosemirror-state';\r\nimport {\r\n    addColumnAfter,\r\n    addColumnBefore,\r\n    addRowAfter,\r\n    addRowBefore,\r\n    deleteColumn,\r\n    deleteRow,\r\n    deleteTable,\r\n    mergeCells,\r\n    splitCell,\r\n    toggleHeaderColumn,\r\n    toggleHeaderRow,\r\n} from 'prosemirror-tables';\r\nimport { EditorView } from 'prosemirror-view';\r\n\r\nimport { ModalService } from '../../../../../providers/modal/modal.service';\r\nimport {\r\n    ExternalImageAttrs,\r\n    ExternalImageDialogComponent,\r\n} from '../../external-image-dialog/external-image-dialog.component';\r\nimport { RawHtmlDialogComponent } from '../../raw-html-dialog/raw-html-dialog.component';\r\nimport { ContextMenuItem, ContextMenuService } from '../context-menu/context-menu.service';\r\nimport { canInsert, renderClarityIcon } from '../menu/menu-common';\r\n\r\nexport function insertImageItem(nodeType: NodeType, modalService: ModalService) {\r\n    return new MenuItem({\r\n        title: 'Insert image',\r\n        label: 'Image',\r\n        render: renderClarityIcon({ shape: 'image', label: 'Image' }),\r\n        class: '',\r\n        css: '',\r\n        enable(state: EditorState) {\r\n            return canInsert(state, nodeType);\r\n        },\r\n        run(state: EditorState, _, view: EditorView) {\r\n            let attrs: ExternalImageAttrs | undefined;\r\n            if (state.selection instanceof NodeSelection && state.selection.node.type === nodeType) {\r\n                attrs = state.selection.node.attrs as ExternalImageAttrs;\r\n            }\r\n            modalService\r\n                .fromComponent(ExternalImageDialogComponent, {\r\n                    closable: true,\r\n                    locals: {\r\n                        existing: attrs,\r\n                    },\r\n                })\r\n                .subscribe(result => {\r\n                    if (result) {\r\n                        // tslint:disable-next-line:no-non-null-assertion\r\n                        view.dispatch(view.state.tr.replaceSelectionWith(nodeType.createAndFill(result)!));\r\n                    }\r\n                    view.focus();\r\n                });\r\n        },\r\n    });\r\n}\r\n\r\nexport const imageContextMenuPlugin = (contextMenuService: ContextMenuService, modalService: ModalService) =>\r\n    new Plugin({\r\n        view: () => {\r\n            return {\r\n                update: view => {\r\n                    if (!view.hasFocus()) {\r\n                        return;\r\n                    }\r\n                    const { doc, selection } = view.state;\r\n                    let imageNode: Node | undefined;\r\n                    let imageNodePos = 0;\r\n                    doc.nodesBetween(selection.from, selection.to, (n, pos, parent) => {\r\n                        if (n.type.name === 'image') {\r\n                            imageNode = n;\r\n                            imageNodePos = pos;\r\n                            return false;\r\n                        }\r\n                    });\r\n                    if (imageNode) {\r\n                        const node = view.nodeDOM(imageNodePos);\r\n                        if (node instanceof HTMLImageElement) {\r\n                            contextMenuService.setContextMenu({\r\n                                ref: selection,\r\n                                title: 'Image',\r\n                                iconShape: 'image',\r\n                                element: node,\r\n                                coords: view.coordsAtPos(imageNodePos),\r\n                                items: [\r\n                                    {\r\n                                        enabled: true,\r\n                                        iconShape: 'image',\r\n                                        label: 'Image properties',\r\n                                        onClick: () => {\r\n                                            contextMenuService.clearContextMenu();\r\n                                            modalService\r\n                                                .fromComponent(ExternalImageDialogComponent, {\r\n                                                    closable: true,\r\n                                                    locals: {\r\n                                                        // tslint:disable-next-line:no-non-null-assertion\r\n                                                        existing: imageNode!.attrs as ExternalImageAttrs,\r\n                                                    },\r\n                                                })\r\n                                                .subscribe(result => {\r\n                                                    if (result) {\r\n                                                        // tslint:disable-next-line:no-non-null-assertion\r\n                                                        view.dispatch(\r\n                                                            view.state.tr.replaceSelectionWith(\r\n                                                                // tslint:disable-next-line:no-non-null-assertion\r\n                                                                imageNode!.type.createAndFill(result)!,\r\n                                                            ),\r\n                                                        );\r\n                                                    }\r\n                                                    view.focus();\r\n                                                });\r\n                                        },\r\n                                    },\r\n                                ],\r\n                            });\r\n                        }\r\n                    } else {\r\n                        contextMenuService.clearContextMenu();\r\n                    }\r\n                },\r\n            };\r\n        },\r\n    });\r\n"]}
@@ -0,0 +1,97 @@
1
+ import { DOMParser, DOMSerializer } from 'prosemirror-model';
2
+ import { Plugin } from 'prosemirror-state';
3
+ import { RawHtmlDialogComponent } from '../../raw-html-dialog/raw-html-dialog.component';
4
+ /**
5
+ * Implements editing of raw HTML for the selected node in the editor.
6
+ */
7
+ export const rawEditorPlugin = (contextMenuService, modalService) => new Plugin({
8
+ view: _view => {
9
+ const domParser = DOMParser.fromSchema(_view.state.schema);
10
+ const domSerializer = DOMSerializer.fromSchema(_view.state.schema);
11
+ return {
12
+ update: view => {
13
+ if (!view.hasFocus()) {
14
+ return;
15
+ }
16
+ let topLevelNode;
17
+ const { doc, selection } = view.state;
18
+ let topLevelNodePos = 0;
19
+ doc.nodesBetween(selection.from, selection.to, (n, pos, parent) => {
20
+ if (parent === doc) {
21
+ topLevelNode = n;
22
+ topLevelNodePos = pos;
23
+ return false;
24
+ }
25
+ });
26
+ if (topLevelNode) {
27
+ const node = view.nodeDOM(topLevelNodePos);
28
+ if (node instanceof HTMLElement) {
29
+ contextMenuService.setContextMenu({
30
+ ref: selection,
31
+ title: '',
32
+ // iconShape: 'ellipsis-vertical',
33
+ element: node,
34
+ coords: view.coordsAtPos(topLevelNodePos),
35
+ items: [
36
+ {
37
+ enabled: true,
38
+ iconShape: 'code',
39
+ label: 'Edit HTML',
40
+ onClick: () => {
41
+ contextMenuService.clearContextMenu();
42
+ const element = domSerializer.serializeNode(
43
+ // tslint:disable-next-line:no-non-null-assertion
44
+ topLevelNode);
45
+ modalService
46
+ .fromComponent(RawHtmlDialogComponent, {
47
+ size: 'xl',
48
+ locals: {
49
+ html: element.outerHTML,
50
+ },
51
+ })
52
+ .subscribe(result => {
53
+ var _a;
54
+ if (result) {
55
+ const domNode = htmlToDomNode(result, (topLevelNode === null || topLevelNode === void 0 ? void 0 : topLevelNode.isLeaf) ? undefined : node);
56
+ if (domNode) {
57
+ let tr = view.state.tr;
58
+ const parsedNodeSlice = domParser.parse(domNode);
59
+ try {
60
+ tr = tr.replaceRangeWith(topLevelNodePos, topLevelNodePos +
61
+ ((_a = topLevelNode === null || topLevelNode === void 0 ? void 0 : topLevelNode.nodeSize) !== null && _a !== void 0 ? _a : 0), parsedNodeSlice);
62
+ }
63
+ catch (err) {
64
+ // tslint:disable-next-line:no-console
65
+ console.error(err);
66
+ }
67
+ view.dispatch(tr);
68
+ view.focus();
69
+ }
70
+ }
71
+ });
72
+ },
73
+ },
74
+ ],
75
+ });
76
+ }
77
+ }
78
+ },
79
+ };
80
+ },
81
+ });
82
+ function htmlToDomNode(html, wrapInParent) {
83
+ html = `${html.trim()}`;
84
+ const template = document.createElement('template');
85
+ if (wrapInParent) {
86
+ const parentClone = wrapInParent.cloneNode(false);
87
+ parentClone.innerHTML = html;
88
+ template.content.appendChild(parentClone);
89
+ }
90
+ else {
91
+ const parent = document.createElement('p');
92
+ parent.innerHTML = html;
93
+ template.content.appendChild(parent);
94
+ }
95
+ return template.content.firstChild;
96
+ }
97
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"raw-editor-plugin.js","sourceRoot":"","sources":["../../../../../../../../src/lib/core/src/shared/components/rich-text-editor/prosemirror/plugins/raw-editor-plugin.ts"],"names":[],"mappings":"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","sourcesContent":["import { DOMParser, DOMSerializer, Node } from 'prosemirror-model';\r\nimport { Plugin } from 'prosemirror-state';\r\nimport { Protocol } from 'puppeteer';\r\n\r\nimport { ModalService } from '../../../../../providers/modal/modal.service';\r\nimport { RawHtmlDialogComponent } from '../../raw-html-dialog/raw-html-dialog.component';\r\nimport { ContextMenuService } from '../context-menu/context-menu.service';\r\n\r\n/**\r\n * Implements editing of raw HTML for the selected node in the editor.\r\n */\r\nexport const rawEditorPlugin = (contextMenuService: ContextMenuService, modalService: ModalService) =>\r\n    new Plugin({\r\n        view: _view => {\r\n            const domParser = DOMParser.fromSchema(_view.state.schema);\r\n            const domSerializer = DOMSerializer.fromSchema(_view.state.schema);\r\n            return {\r\n                update: view => {\r\n                    if (!view.hasFocus()) {\r\n                        return;\r\n                    }\r\n                    let topLevelNode: Node | undefined;\r\n                    const { doc, selection } = view.state;\r\n                    let topLevelNodePos = 0;\r\n                    doc.nodesBetween(selection.from, selection.to, (n, pos, parent) => {\r\n                        if (parent === doc) {\r\n                            topLevelNode = n;\r\n                            topLevelNodePos = pos;\r\n                            return false;\r\n                        }\r\n                    });\r\n                    if (topLevelNode) {\r\n                        const node = view.nodeDOM(topLevelNodePos);\r\n                        if (node instanceof HTMLElement) {\r\n                            contextMenuService.setContextMenu({\r\n                                ref: selection,\r\n                                title: '',\r\n                                // iconShape: 'ellipsis-vertical',\r\n                                element: node,\r\n                                coords: view.coordsAtPos(topLevelNodePos),\r\n                                items: [\r\n                                    {\r\n                                        enabled: true,\r\n                                        iconShape: 'code',\r\n                                        label: 'Edit HTML',\r\n                                        onClick: () => {\r\n                                            contextMenuService.clearContextMenu();\r\n                                            const element = domSerializer.serializeNode(\r\n                                                // tslint:disable-next-line:no-non-null-assertion\r\n                                                topLevelNode!,\r\n                                            ) as HTMLElement;\r\n                                            modalService\r\n                                                .fromComponent(RawHtmlDialogComponent, {\r\n                                                    size: 'xl',\r\n                                                    locals: {\r\n                                                        html: element.outerHTML,\r\n                                                    },\r\n                                                })\r\n                                                .subscribe(result => {\r\n                                                    if (result) {\r\n                                                        const domNode = htmlToDomNode(\r\n                                                            result,\r\n                                                            topLevelNode?.isLeaf ? undefined : node,\r\n                                                        );\r\n                                                        if (domNode) {\r\n                                                            let tr = view.state.tr;\r\n                                                            const parsedNodeSlice = domParser.parse(domNode);\r\n                                                            try {\r\n                                                                tr = tr.replaceRangeWith(\r\n                                                                    topLevelNodePos,\r\n                                                                    topLevelNodePos +\r\n                                                                        (topLevelNode?.nodeSize ?? 0),\r\n                                                                    parsedNodeSlice,\r\n                                                                );\r\n                                                            } catch (err: any) {\r\n                                                                // tslint:disable-next-line:no-console\r\n                                                                console.error(err);\r\n                                                            }\r\n                                                            view.dispatch(tr);\r\n                                                            view.focus();\r\n                                                        }\r\n                                                    }\r\n                                                });\r\n                                        },\r\n                                    },\r\n                                ],\r\n                            });\r\n                        }\r\n                    }\r\n                },\r\n            };\r\n        },\r\n    });\r\n\r\nfunction htmlToDomNode(html: string, wrapInParent?: HTMLElement) {\r\n    html = `${html.trim()}`;\r\n    const template = document.createElement('template');\r\n    if (wrapInParent) {\r\n        const parentClone = wrapInParent.cloneNode(false) as HTMLElement;\r\n        parentClone.innerHTML = html;\r\n        template.content.appendChild(parentClone);\r\n    } else {\r\n        const parent = document.createElement('p');\r\n        parent.innerHTML = html;\r\n        template.content.appendChild(parent);\r\n    }\r\n    return template.content.firstChild;\r\n}\r\n"]}
@@ -0,0 +1,166 @@
1
+ import { MenuItem } from 'prosemirror-menu';
2
+ import { Plugin, TextSelection } from 'prosemirror-state';
3
+ import { addColumnAfter, addColumnBefore, addRowAfter, addRowBefore, deleteColumn, deleteRow, deleteTable, isInTable, mergeCells, splitCell, tableNodes, tableNodeTypes, toggleHeaderCell, toggleHeaderColumn, toggleHeaderRow, } from 'prosemirror-tables';
4
+ import { renderClarityIcon } from '../menu/menu-common';
5
+ export const tableContextMenuPlugin = (contextMenuService) => new Plugin({
6
+ view: () => {
7
+ return {
8
+ update: view => {
9
+ if (!view.hasFocus()) {
10
+ return;
11
+ }
12
+ const { doc, selection } = view.state;
13
+ let tableNode;
14
+ let tableNodePos = 0;
15
+ doc.nodesBetween(selection.from, selection.to, (n, pos, parent) => {
16
+ if (n.type.name === 'table') {
17
+ tableNode = n;
18
+ tableNodePos = pos;
19
+ return false;
20
+ }
21
+ });
22
+ if (tableNode) {
23
+ const node = view.nodeDOM(tableNodePos);
24
+ if (node instanceof Element) {
25
+ function createMenuItem(label, commandFn, iconClass) {
26
+ const enabled = commandFn(view.state);
27
+ return {
28
+ label,
29
+ enabled,
30
+ iconClass,
31
+ onClick: () => {
32
+ contextMenuService.clearContextMenu();
33
+ view.focus();
34
+ commandFn(view.state, view.dispatch);
35
+ },
36
+ };
37
+ }
38
+ const separator = {
39
+ label: '',
40
+ separator: true,
41
+ enabled: true,
42
+ onClick: () => {
43
+ /**/
44
+ },
45
+ };
46
+ contextMenuService.setContextMenu({
47
+ ref: selection,
48
+ title: 'Table',
49
+ iconShape: 'table',
50
+ element: node,
51
+ coords: view.coordsAtPos(tableNodePos),
52
+ items: [
53
+ createMenuItem('Insert column before', addColumnBefore, 'add-column'),
54
+ createMenuItem('Insert column after', addColumnAfter, 'add-column'),
55
+ createMenuItem('Insert row before', addRowBefore, 'add-row'),
56
+ createMenuItem('Insert row after', addRowAfter, 'add-row'),
57
+ createMenuItem('Merge cells', mergeCells),
58
+ createMenuItem('Split cell', splitCell),
59
+ separator,
60
+ createMenuItem('Toggle header column', toggleHeaderColumn),
61
+ createMenuItem('Toggle header row', toggleHeaderRow),
62
+ separator,
63
+ createMenuItem('Delete column', deleteColumn),
64
+ createMenuItem('Delete row', deleteRow),
65
+ createMenuItem('Delete table', deleteTable),
66
+ ],
67
+ });
68
+ }
69
+ }
70
+ else {
71
+ contextMenuService.clearContextMenu();
72
+ }
73
+ },
74
+ };
75
+ },
76
+ });
77
+ export function getTableNodes() {
78
+ return tableNodes({
79
+ tableGroup: 'block',
80
+ cellContent: 'block+',
81
+ cellAttributes: {
82
+ background: {
83
+ default: null,
84
+ getFromDOM(dom) {
85
+ return dom.style.backgroundColor || null;
86
+ },
87
+ setDOMAttr(value, attrs) {
88
+ if (value) {
89
+ attrs.style = (attrs.style || '') + `background-color: ${value};`;
90
+ }
91
+ },
92
+ },
93
+ },
94
+ });
95
+ }
96
+ export function getTableMenu(schema) {
97
+ function item(label, cmd, iconShape) {
98
+ return new MenuItem({
99
+ label,
100
+ select: cmd,
101
+ run: cmd,
102
+ render: iconShape ? renderClarityIcon({ shape: iconShape, label }) : undefined,
103
+ });
104
+ }
105
+ function separator() {
106
+ return new MenuItem({
107
+ select: state => isInTable(state),
108
+ run: state => {
109
+ /**/
110
+ },
111
+ render: view => {
112
+ const el = document.createElement('div');
113
+ el.classList.add('menu-separator');
114
+ return el;
115
+ },
116
+ });
117
+ }
118
+ return [
119
+ item('Insert column before', addColumnBefore),
120
+ item('Insert column after', addColumnAfter),
121
+ item('Insert row before', addRowBefore),
122
+ item('Insert row after', addRowAfter),
123
+ item('Merge cells', mergeCells),
124
+ item('Split cell', splitCell),
125
+ separator(),
126
+ item('Toggle header column', toggleHeaderColumn),
127
+ item('Toggle header row', toggleHeaderRow),
128
+ item('Toggle header cells', toggleHeaderCell),
129
+ separator(),
130
+ item('Delete column', deleteColumn),
131
+ item('Delete row', deleteRow),
132
+ item('Delete table', deleteTable),
133
+ ];
134
+ }
135
+ export function addTable(state, dispatch, { rowsCount, colsCount, withHeaderRow, cellContent }) {
136
+ const offset = state.tr.selection.anchor + 1;
137
+ const nodes = createTable(state, rowsCount, colsCount, withHeaderRow, cellContent);
138
+ const tr = state.tr.replaceSelectionWith(nodes).scrollIntoView();
139
+ const resolvedPos = tr.doc.resolve(offset);
140
+ tr.setSelection(TextSelection.near(resolvedPos));
141
+ dispatch(tr);
142
+ }
143
+ function createTable(state, rowsCount, colsCount, withHeaderRow, cellContent) {
144
+ const types = tableNodeTypes(state.schema);
145
+ const headerCells = [];
146
+ const cells = [];
147
+ const createCell = (cellType, _cellContent) => _cellContent ? cellType.createChecked(null, _cellContent) : cellType.createAndFill();
148
+ for (let index = 0; index < colsCount; index += 1) {
149
+ const cell = createCell(types.cell, cellContent);
150
+ if (cell) {
151
+ cells.push(cell);
152
+ }
153
+ if (withHeaderRow) {
154
+ const headerCell = createCell(types.header_cell, cellContent);
155
+ if (headerCell) {
156
+ headerCells.push(headerCell);
157
+ }
158
+ }
159
+ }
160
+ const rows = [];
161
+ for (let index = 0; index < rowsCount; index += 1) {
162
+ rows.push(types.row.createChecked(null, withHeaderRow && index === 0 ? headerCells : cells));
163
+ }
164
+ return types.table.createChecked(null, rows);
165
+ }
166
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tables-plugin.js","sourceRoot":"","sources":["../../../../../../../../src/lib/core/src/shared/components/rich-text-editor/prosemirror/plugins/tables-plugin.ts"],"names":[],"mappings":"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","sourcesContent":["import { MenuElement, MenuItem } from 'prosemirror-menu';\r\nimport { Node, Schema } from 'prosemirror-model';\r\nimport { EditorState, Plugin, TextSelection, Transaction } from 'prosemirror-state';\r\nimport {\r\n    addColumnAfter,\r\n    addColumnBefore,\r\n    addRowAfter,\r\n    addRowBefore,\r\n    deleteColumn,\r\n    deleteRow,\r\n    deleteTable,\r\n    isInTable,\r\n    mergeCells,\r\n    splitCell,\r\n    tableNodes,\r\n    tableNodeTypes,\r\n    toggleHeaderCell,\r\n    toggleHeaderColumn,\r\n    toggleHeaderRow,\r\n} from 'prosemirror-tables';\r\nimport { Decoration, DecorationSet } from 'prosemirror-view';\r\n\r\nimport { ContextMenuItem, ContextMenuService } from '../context-menu/context-menu.service';\r\nimport { buildMenuItems } from '../menu/menu';\r\nimport { renderClarityIcon } from '../menu/menu-common';\r\n\r\nexport const tableContextMenuPlugin = (contextMenuService: ContextMenuService) =>\r\n    new Plugin({\r\n        view: () => {\r\n            return {\r\n                update: view => {\r\n                    if (!view.hasFocus()) {\r\n                        return;\r\n                    }\r\n                    const { doc, selection } = view.state;\r\n                    let tableNode: Node | undefined;\r\n                    let tableNodePos = 0;\r\n                    doc.nodesBetween(selection.from, selection.to, (n, pos, parent) => {\r\n                        if (n.type.name === 'table') {\r\n                            tableNode = n;\r\n                            tableNodePos = pos;\r\n                            return false;\r\n                        }\r\n                    });\r\n                    if (tableNode) {\r\n                        const node = view.nodeDOM(tableNodePos);\r\n                        if (node instanceof Element) {\r\n                            function createMenuItem(\r\n                                label: string,\r\n                                commandFn: (\r\n                                    state: EditorState,\r\n                                    dispatch?: (tr: Transaction) => void,\r\n                                ) => boolean,\r\n                                iconClass?: string,\r\n                            ): ContextMenuItem {\r\n                                const enabled = commandFn(view.state);\r\n                                return {\r\n                                    label,\r\n                                    enabled,\r\n                                    iconClass,\r\n                                    onClick: () => {\r\n                                        contextMenuService.clearContextMenu();\r\n                                        view.focus();\r\n                                        commandFn(view.state, view.dispatch);\r\n                                    },\r\n                                };\r\n                            }\r\n                            const separator: ContextMenuItem = {\r\n                                label: '',\r\n                                separator: true,\r\n                                enabled: true,\r\n                                onClick: () => {\r\n                                    /**/\r\n                                },\r\n                            };\r\n                            contextMenuService.setContextMenu({\r\n                                ref: selection,\r\n                                title: 'Table',\r\n                                iconShape: 'table',\r\n                                element: node,\r\n                                coords: view.coordsAtPos(tableNodePos),\r\n                                items: [\r\n                                    createMenuItem('Insert column before', addColumnBefore, 'add-column'),\r\n                                    createMenuItem('Insert column after', addColumnAfter, 'add-column'),\r\n                                    createMenuItem('Insert row before', addRowBefore, 'add-row'),\r\n                                    createMenuItem('Insert row after', addRowAfter, 'add-row'),\r\n                                    createMenuItem('Merge cells', mergeCells),\r\n                                    createMenuItem('Split cell', splitCell),\r\n                                    separator,\r\n                                    createMenuItem('Toggle header column', toggleHeaderColumn),\r\n                                    createMenuItem('Toggle header row', toggleHeaderRow),\r\n                                    separator,\r\n                                    createMenuItem('Delete column', deleteColumn),\r\n                                    createMenuItem('Delete row', deleteRow),\r\n                                    createMenuItem('Delete table', deleteTable),\r\n                                ],\r\n                            });\r\n                        }\r\n                    } else {\r\n                        contextMenuService.clearContextMenu();\r\n                    }\r\n                },\r\n            };\r\n        },\r\n    });\r\n\r\nexport function getTableNodes() {\r\n    return tableNodes({\r\n        tableGroup: 'block',\r\n        cellContent: 'block+',\r\n        cellAttributes: {\r\n            background: {\r\n                default: null,\r\n                getFromDOM(dom) {\r\n                    return (dom as HTMLElement).style.backgroundColor || null;\r\n                },\r\n                setDOMAttr(value, attrs) {\r\n                    if (value) {\r\n                        attrs.style = (attrs.style || '') + `background-color: ${value};`;\r\n                    }\r\n                },\r\n            },\r\n        },\r\n    });\r\n}\r\n\r\nexport function getTableMenu(schema: Schema) {\r\n    function item(\r\n        label: string,\r\n        cmd: (state: EditorState, dispatch?: (tr: Transaction) => void) => boolean,\r\n        iconShape?: string,\r\n    ) {\r\n        return new MenuItem({\r\n            label,\r\n            select: cmd,\r\n            run: cmd,\r\n            render: iconShape ? renderClarityIcon({ shape: iconShape, label }) : undefined,\r\n        });\r\n    }\r\n\r\n    function separator(): MenuElement {\r\n        return new MenuItem({\r\n            select: state => isInTable(state),\r\n            run: state => {\r\n                /**/\r\n            },\r\n            render: view => {\r\n                const el = document.createElement('div');\r\n                el.classList.add('menu-separator');\r\n                return el;\r\n            },\r\n        });\r\n    }\r\n\r\n    return [\r\n        item('Insert column before', addColumnBefore),\r\n        item('Insert column after', addColumnAfter),\r\n        item('Insert row before', addRowBefore),\r\n        item('Insert row after', addRowAfter),\r\n        item('Merge cells', mergeCells),\r\n        item('Split cell', splitCell),\r\n        separator(),\r\n        item('Toggle header column', toggleHeaderColumn),\r\n        item('Toggle header row', toggleHeaderRow),\r\n        item('Toggle header cells', toggleHeaderCell),\r\n        separator(),\r\n        item('Delete column', deleteColumn),\r\n        item('Delete row', deleteRow),\r\n        item('Delete table', deleteTable),\r\n    ];\r\n}\r\n\r\nexport function addTable(state, dispatch, { rowsCount, colsCount, withHeaderRow, cellContent }) {\r\n    const offset = state.tr.selection.anchor + 1;\r\n\r\n    const nodes = createTable(state, rowsCount, colsCount, withHeaderRow, cellContent);\r\n    const tr = state.tr.replaceSelectionWith(nodes).scrollIntoView();\r\n    const resolvedPos = tr.doc.resolve(offset);\r\n\r\n    tr.setSelection(TextSelection.near(resolvedPos));\r\n\r\n    dispatch(tr);\r\n}\r\n\r\nfunction createTable(state, rowsCount, colsCount, withHeaderRow, cellContent) {\r\n    const types = tableNodeTypes(state.schema);\r\n    const headerCells: Node[] = [];\r\n    const cells: Node[] = [];\r\n    const createCell = (cellType, _cellContent) =>\r\n        _cellContent ? cellType.createChecked(null, _cellContent) : cellType.createAndFill();\r\n\r\n    for (let index = 0; index < colsCount; index += 1) {\r\n        const cell = createCell(types.cell, cellContent);\r\n\r\n        if (cell) {\r\n            cells.push(cell);\r\n        }\r\n\r\n        if (withHeaderRow) {\r\n            const headerCell = createCell(types.header_cell, cellContent);\r\n\r\n            if (headerCell) {\r\n                headerCells.push(headerCell);\r\n            }\r\n        }\r\n    }\r\n\r\n    const rows: Node[] = [];\r\n\r\n    for (let index = 0; index < rowsCount; index += 1) {\r\n        rows.push(types.row.createChecked(null, withHeaderRow && index === 0 ? headerCells : cells));\r\n    }\r\n\r\n    return types.table.createChecked(null, rows);\r\n}\r\n"]}
@@ -1,27 +1,35 @@
1
- import { Injectable } from '@angular/core';
1
+ import { Injectable, Injector } from '@angular/core';
2
2
  import { baseKeymap } from 'prosemirror-commands';
3
3
  import { dropCursor } from 'prosemirror-dropcursor';
4
4
  import { gapCursor } from 'prosemirror-gapcursor';
5
5
  import { history } from 'prosemirror-history';
6
6
  import { keymap } from 'prosemirror-keymap';
7
- import { menuBar } from 'prosemirror-menu';
8
7
  import { DOMParser, DOMSerializer, Schema } from 'prosemirror-model';
9
8
  import { schema } from 'prosemirror-schema-basic';
10
9
  import { addListNodes } from 'prosemirror-schema-list';
11
10
  import { EditorState, Plugin } from 'prosemirror-state';
11
+ import { columnResizing, fixTables, tableEditing } from 'prosemirror-tables';
12
12
  import { EditorView } from 'prosemirror-view';
13
13
  import { ModalService } from '../../../../providers/modal/modal.service';
14
+ import { ContextMenuService } from './context-menu/context-menu.service';
15
+ import { iframeNode, iframeNodeView } from './custom-nodes';
14
16
  import { buildInputRules } from './inputrules';
15
17
  import { buildKeymap } from './keymap';
16
- import { buildMenuItems } from './menu/menu';
18
+ import { customMenuPlugin } from './menu/menu-plugin';
19
+ import { imageContextMenuPlugin } from './plugins/image-plugin';
17
20
  import { linkSelectPlugin } from './plugins/link-select-plugin';
21
+ import { rawEditorPlugin } from './plugins/raw-editor-plugin';
22
+ import { getTableNodes, tableContextMenuPlugin } from './plugins/tables-plugin';
18
23
  export class ProsemirrorService {
19
- constructor(modalService) {
20
- this.modalService = modalService;
24
+ constructor(injector, contextMenuService) {
25
+ this.injector = injector;
26
+ this.contextMenuService = contextMenuService;
21
27
  // Mix the nodes from prosemirror-schema-list into the basic schema to
22
28
  // create a schema with list support.
23
29
  this.mySchema = new Schema({
24
- nodes: addListNodes(schema.spec.nodes, 'paragraph block*', 'block'),
30
+ nodes: addListNodes(schema.spec.nodes, 'paragraph block*', 'block')
31
+ .append(getTableNodes())
32
+ .addToEnd('iframe', iframeNode),
25
33
  marks: schema.spec.marks,
26
34
  });
27
35
  this.enabled = true;
@@ -40,13 +48,30 @@ export class ProsemirrorService {
40
48
  }
41
49
  },
42
50
  editable: () => options.isReadOnly(),
51
+ handleDOMEvents: {
52
+ focus: view => {
53
+ this.contextMenuService.setVisibility(true);
54
+ },
55
+ blur: view => {
56
+ this.contextMenuService.setVisibility(false);
57
+ },
58
+ },
59
+ nodeViews: {
60
+ iframe: iframeNodeView,
61
+ },
43
62
  });
44
63
  }
45
64
  update(text) {
46
65
  if (this.editorView) {
47
- const state = this.getStateFromText(text);
48
- if (document.body.contains(this.editorView.dom)) {
49
- this.editorView.updateState(state);
66
+ const currentText = this.getTextFromState(this.editorView.state);
67
+ if (text !== currentText) {
68
+ let state = this.getStateFromText(text);
69
+ if (document.body.contains(this.editorView.dom)) {
70
+ const fix = fixTables(state);
71
+ if (fix)
72
+ state = state.apply(fix.setMeta('addToHistory', false));
73
+ this.editorView.updateState(state);
74
+ }
50
75
  }
51
76
  }
52
77
  }
@@ -86,13 +111,17 @@ export class ProsemirrorService {
86
111
  dropCursor(),
87
112
  gapCursor(),
88
113
  linkSelectPlugin,
114
+ columnResizing({}),
115
+ tableEditing({ allowTableNodeSelection: true }),
116
+ tableContextMenuPlugin(this.contextMenuService),
117
+ imageContextMenuPlugin(this.contextMenuService, this.injector.get(ModalService)),
118
+ rawEditorPlugin(this.contextMenuService, this.injector.get(ModalService)),
119
+ customMenuPlugin({
120
+ floatingMenu: options.floatingMenu,
121
+ injector: this.injector,
122
+ schema: options.schema,
123
+ }),
89
124
  ];
90
- if (options.menuBar !== false) {
91
- plugins.push(menuBar({
92
- floating: options.floatingMenu !== false,
93
- content: options.menuContent || buildMenuItems(options.schema, this.modalService).fullMenu,
94
- }));
95
- }
96
125
  if (options.history !== false) {
97
126
  plugins.push(history());
98
127
  }
@@ -107,6 +136,7 @@ ProsemirrorService.decorators = [
107
136
  { type: Injectable }
108
137
  ];
109
138
  ProsemirrorService.ctorParameters = () => [
110
- { type: ModalService }
139
+ { type: Injector },
140
+ { type: ContextMenuService }
111
141
  ];
112
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"prosemirror.service.js","sourceRoot":"","sources":["../../../../../../../src/lib/core/src/shared/components/rich-text-editor/prosemirror/prosemirror.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAC3C,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAClD,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AACpD,OAAO,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAClD,OAAO,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAC9C,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAC5C,OAAO,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAC;AAC3C,OAAO,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAC;AACrE,OAAO,EAAE,MAAM,EAAE,MAAM,0BAA0B,CAAC;AAClD,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AACvD,OAAO,EAAE,WAAW,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAC;AACxD,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAE9C,OAAO,EAAE,YAAY,EAAE,MAAM,2CAA2C,CAAC;AAEzE,OAAO,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAC/C,OAAO,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AACvC,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAC7C,OAAO,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;AAUhE,MAAM,OAAO,kBAAkB;IAW3B,YAAoB,YAA0B;QAA1B,iBAAY,GAAZ,YAAY,CAAc;QAR9C,sEAAsE;QACtE,qCAAqC;QAC7B,aAAQ,GAAG,IAAI,MAAM,CAAC;YAC1B,KAAK,EAAE,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,EAAE,kBAAkB,EAAE,OAAO,CAAC;YACnE,KAAK,EAAE,MAAM,CAAC,IAAI,CAAC,KAAK;SAC3B,CAAC,CAAC;QACK,YAAO,GAAG,IAAI,CAAC;IAE0B,CAAC;IAElD,gBAAgB,CAAC,OAAgC;QAC7C,IAAI,CAAC,UAAU,GAAG,IAAI,UAAU,CAAS,OAAO,CAAC,OAAO,EAAE;YACtD,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,EAAE,CAAC;YAChC,mBAAmB,EAAE,EAAE,CAAC,EAAE;gBACtB,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE;oBACf,OAAO;iBACV;gBACD,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC;gBAC7D,IAAI,EAAE,CAAC,UAAU,EAAE;oBACf,MAAM,OAAO,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;oBAC7D,OAAO,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;iBAChC;YACL,CAAC;YACD,QAAQ,EAAE,GAAG,EAAE,CAAC,OAAO,CAAC,UAAU,EAAE;SACvC,CAAC,CAAC;IACP,CAAC;IAED,MAAM,CAAC,IAAY;QACf,IAAI,IAAI,CAAC,UAAU,EAAE;YACjB,MAAM,KAAK,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC;YAC1C,IAAI,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE;gBAC7C,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;aACtC;SACJ;IACL,CAAC;IAED,OAAO;QACH,IAAI,IAAI,CAAC,UAAU,EAAE;YACjB,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC;SAC7B;IACL,CAAC;IAED,UAAU,CAAC,OAAgB;QACvB,IAAI,IAAI,CAAC,UAAU,EAAE;YACjB,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;YACvB,qDAAqD;YACrD,0DAA0D;YAC1D,SAAS;YACT,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;SACtD;IACL,CAAC;IAEO,gBAAgB,CAAC,IAA+B;QACpD,MAAM,GAAG,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAC1C,GAAG,CAAC,SAAS,GAAG,IAAI,aAAJ,IAAI,cAAJ,IAAI,GAAI,EAAE,CAAC;QAC3B,OAAO,WAAW,CAAC,MAAM,CAAC;YACtB,GAAG,EAAE,SAAS,CAAC,UAAU,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC;YACnD,OAAO,EAAE,IAAI,CAAC,gBAAgB,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,QAAQ,EAAE,YAAY,EAAE,KAAK,EAAE,CAAC;SACjF,CAAC,CAAC;IACP,CAAC;IAEO,gBAAgB,CAAC,KAAkB;QACvC,MAAM,GAAG,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAC1C,MAAM,QAAQ,GAAG,aAAa,CAAC,UAAU,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,iBAAiB,CAAC,KAAK,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;QAE9F,GAAG,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;QAE1B,OAAO,GAAG,CAAC,SAAS,CAAC;IACzB,CAAC;IAEO,gBAAgB,CAAC,OAAqB;QAC1C,MAAM,OAAO,GAAG;YACZ,eAAe,CAAC,OAAO,CAAC,MAAM,CAAC;YAC/B,MAAM,CAAC,WAAW,CAAC,OAAO,CAAC,MAAM,EAAE,OAAO,CAAC,OAAO,CAAC,CAAC;YACpD,MAAM,CAAC,UAAU,CAAC;YAClB,UAAU,EAAE;YACZ,SAAS,EAAE;YACX,gBAAgB;SACnB,CAAC;QACF,IAAI,OAAO,CAAC,OAAO,KAAK,KAAK,EAAE;YAC3B,OAAO,CAAC,IAAI,CACR,OAAO,CAAC;gBACJ,QAAQ,EAAE,OAAO,CAAC,YAAY,KAAK,KAAK;gBACxC,OAAO,EACH,OAAO,CAAC,WAAW,IAAI,cAAc,CAAC,OAAO,CAAC,MAAM,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC,QAAQ;aACxF,CAAC,CACL,CAAC;SACL;QACD,IAAI,OAAO,CAAC,OAAO,KAAK,KAAK,EAAE;YAC3B,OAAO,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;SAC3B;QAED,OAAO,OAAO,CAAC,MAAM,CACjB,IAAI,MAAM,CAAC;YACP,KAAK,EAAE;gBACH,UAAU,EAAE,EAAE,KAAK,EAAE,iBAAiB,EAAE;aAC3C;SACJ,CAAC,CACL,CAAC;IACN,CAAC;;;YAvGJ,UAAU;;;YAdF,YAAY","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport { baseKeymap } from 'prosemirror-commands';\r\nimport { dropCursor } from 'prosemirror-dropcursor';\r\nimport { gapCursor } from 'prosemirror-gapcursor';\r\nimport { history } from 'prosemirror-history';\r\nimport { keymap } from 'prosemirror-keymap';\r\nimport { menuBar } from 'prosemirror-menu';\r\nimport { DOMParser, DOMSerializer, Schema } from 'prosemirror-model';\r\nimport { schema } from 'prosemirror-schema-basic';\r\nimport { addListNodes } from 'prosemirror-schema-list';\r\nimport { EditorState, Plugin } from 'prosemirror-state';\r\nimport { EditorView } from 'prosemirror-view';\r\n\r\nimport { ModalService } from '../../../../providers/modal/modal.service';\r\n\r\nimport { buildInputRules } from './inputrules';\r\nimport { buildKeymap } from './keymap';\r\nimport { buildMenuItems } from './menu/menu';\r\nimport { linkSelectPlugin } from './plugins/link-select-plugin';\r\nimport { SetupOptions } from './types';\r\n\r\nexport interface CreateEditorViewOptions {\r\n    onTextInput: (content: string) => void;\r\n    element: HTMLElement;\r\n    isReadOnly: () => boolean;\r\n}\r\n\r\n@Injectable()\r\nexport class ProsemirrorService {\r\n    editorView: EditorView;\r\n\r\n    // Mix the nodes from prosemirror-schema-list into the basic schema to\r\n    // create a schema with list support.\r\n    private mySchema = new Schema({\r\n        nodes: addListNodes(schema.spec.nodes, 'paragraph block*', 'block'),\r\n        marks: schema.spec.marks,\r\n    });\r\n    private enabled = true;\r\n\r\n    constructor(private modalService: ModalService) {}\r\n\r\n    createEditorView(options: CreateEditorViewOptions) {\r\n        this.editorView = new EditorView<Schema>(options.element, {\r\n            state: this.getStateFromText(''),\r\n            dispatchTransaction: tr => {\r\n                if (!this.enabled) {\r\n                    return;\r\n                }\r\n                this.editorView.updateState(this.editorView.state.apply(tr));\r\n                if (tr.docChanged) {\r\n                    const content = this.getTextFromState(this.editorView.state);\r\n                    options.onTextInput(content);\r\n                }\r\n            },\r\n            editable: () => options.isReadOnly(),\r\n        });\r\n    }\r\n\r\n    update(text: string) {\r\n        if (this.editorView) {\r\n            const state = this.getStateFromText(text);\r\n            if (document.body.contains(this.editorView.dom)) {\r\n                this.editorView.updateState(state);\r\n            }\r\n        }\r\n    }\r\n\r\n    destroy() {\r\n        if (this.editorView) {\r\n            this.editorView.destroy();\r\n        }\r\n    }\r\n\r\n    setEnabled(enabled: boolean) {\r\n        if (this.editorView) {\r\n            this.enabled = enabled;\r\n            // Updating the state causes ProseMirror to check the\r\n            // `editable()` function from the contructor config object\r\n            // newly.\r\n            this.editorView.updateState(this.editorView.state);\r\n        }\r\n    }\r\n\r\n    private getStateFromText(text: string | null | undefined): EditorState {\r\n        const div = document.createElement('div');\r\n        div.innerHTML = text ?? '';\r\n        return EditorState.create({\r\n            doc: DOMParser.fromSchema(this.mySchema).parse(div),\r\n            plugins: this.configurePlugins({ schema: this.mySchema, floatingMenu: false }),\r\n        });\r\n    }\r\n\r\n    private getTextFromState(state: EditorState): string {\r\n        const div = document.createElement('div');\r\n        const fragment = DOMSerializer.fromSchema(this.mySchema).serializeFragment(state.doc.content);\r\n\r\n        div.appendChild(fragment);\r\n\r\n        return div.innerHTML;\r\n    }\r\n\r\n    private configurePlugins(options: SetupOptions) {\r\n        const plugins = [\r\n            buildInputRules(options.schema),\r\n            keymap(buildKeymap(options.schema, options.mapKeys)),\r\n            keymap(baseKeymap),\r\n            dropCursor(),\r\n            gapCursor(),\r\n            linkSelectPlugin,\r\n        ];\r\n        if (options.menuBar !== false) {\r\n            plugins.push(\r\n                menuBar({\r\n                    floating: options.floatingMenu !== false,\r\n                    content:\r\n                        options.menuContent || buildMenuItems(options.schema, this.modalService).fullMenu,\r\n                }),\r\n            );\r\n        }\r\n        if (options.history !== false) {\r\n            plugins.push(history());\r\n        }\r\n\r\n        return plugins.concat(\r\n            new Plugin({\r\n                props: {\r\n                    attributes: { class: 'vdr-prosemirror' },\r\n                },\r\n            }),\r\n        );\r\n    }\r\n}\r\n"]}
142
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"prosemirror.service.js","sourceRoot":"","sources":["../../../../../../../src/lib/core/src/shared/components/rich-text-editor/prosemirror/prosemirror.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Injector } from '@angular/core';\r\nimport { baseKeymap } from 'prosemirror-commands';\r\nimport { dropCursor } from 'prosemirror-dropcursor';\r\nimport { gapCursor } from 'prosemirror-gapcursor';\r\nimport { history } from 'prosemirror-history';\r\nimport { keymap } from 'prosemirror-keymap';\r\nimport { DOMParser, DOMSerializer, Schema } from 'prosemirror-model';\r\nimport { schema } from 'prosemirror-schema-basic';\r\nimport { addListNodes } from 'prosemirror-schema-list';\r\nimport { EditorState, Plugin } from 'prosemirror-state';\r\nimport { columnResizing, fixTables, tableEditing } from 'prosemirror-tables';\r\nimport { EditorView } from 'prosemirror-view';\r\nimport { Observable } from 'rxjs';\r\n\r\nimport { ModalService } from '../../../../providers/modal/modal.service';\r\n\r\nimport { ContextMenuService } from './context-menu/context-menu.service';\r\nimport { iframeNode, iframeNodeView } from './custom-nodes';\r\nimport { buildInputRules } from './inputrules';\r\nimport { buildKeymap } from './keymap';\r\nimport { customMenuPlugin } from './menu/menu-plugin';\r\nimport { imageContextMenuPlugin } from './plugins/image-plugin';\r\nimport { linkSelectPlugin } from './plugins/link-select-plugin';\r\nimport { rawEditorPlugin } from './plugins/raw-editor-plugin';\r\nimport { getTableNodes, tableContextMenuPlugin } from './plugins/tables-plugin';\r\nimport { SetupOptions } from './types';\r\n\r\nexport interface CreateEditorViewOptions {\r\n    onTextInput: (content: string) => void;\r\n    element: HTMLElement;\r\n    isReadOnly: () => boolean;\r\n}\r\n\r\n@Injectable()\r\nexport class ProsemirrorService {\r\n    editorView: EditorView;\r\n\r\n    // Mix the nodes from prosemirror-schema-list into the basic schema to\r\n    // create a schema with list support.\r\n    private mySchema = new Schema({\r\n        nodes: addListNodes(schema.spec.nodes, 'paragraph block*', 'block')\r\n            .append(getTableNodes() as any)\r\n            .addToEnd('iframe', iframeNode),\r\n        marks: schema.spec.marks,\r\n    });\r\n    private enabled = true;\r\n\r\n    constructor(private injector: Injector, private contextMenuService: ContextMenuService) {}\r\n\r\n    contextMenuItems$: Observable<string>;\r\n\r\n    createEditorView(options: CreateEditorViewOptions) {\r\n        this.editorView = new EditorView(options.element, {\r\n            state: this.getStateFromText(''),\r\n            dispatchTransaction: tr => {\r\n                if (!this.enabled) {\r\n                    return;\r\n                }\r\n                this.editorView.updateState(this.editorView.state.apply(tr));\r\n                if (tr.docChanged) {\r\n                    const content = this.getTextFromState(this.editorView.state);\r\n                    options.onTextInput(content);\r\n                }\r\n            },\r\n            editable: () => options.isReadOnly(),\r\n            handleDOMEvents: {\r\n                focus: view => {\r\n                    this.contextMenuService.setVisibility(true);\r\n                },\r\n                blur: view => {\r\n                    this.contextMenuService.setVisibility(false);\r\n                },\r\n            },\r\n            nodeViews: {\r\n                iframe: iframeNodeView,\r\n            },\r\n        });\r\n    }\r\n\r\n    update(text: string) {\r\n        if (this.editorView) {\r\n            const currentText = this.getTextFromState(this.editorView.state);\r\n            if (text !== currentText) {\r\n                let state = this.getStateFromText(text);\r\n                if (document.body.contains(this.editorView.dom)) {\r\n                    const fix = fixTables(state);\r\n                    if (fix) state = state.apply(fix.setMeta('addToHistory', false));\r\n                    this.editorView.updateState(state);\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    destroy() {\r\n        if (this.editorView) {\r\n            this.editorView.destroy();\r\n        }\r\n    }\r\n\r\n    setEnabled(enabled: boolean) {\r\n        if (this.editorView) {\r\n            this.enabled = enabled;\r\n            // Updating the state causes ProseMirror to check the\r\n            // `editable()` function from the contructor config object\r\n            // newly.\r\n            this.editorView.updateState(this.editorView.state);\r\n        }\r\n    }\r\n\r\n    private getStateFromText(text: string | null | undefined): EditorState {\r\n        const div = document.createElement('div');\r\n        div.innerHTML = text ?? '';\r\n        return EditorState.create({\r\n            doc: DOMParser.fromSchema(this.mySchema).parse(div),\r\n            plugins: this.configurePlugins({ schema: this.mySchema, floatingMenu: false }),\r\n        });\r\n    }\r\n\r\n    private getTextFromState(state: EditorState): string {\r\n        const div = document.createElement('div');\r\n        const fragment = DOMSerializer.fromSchema(this.mySchema).serializeFragment(state.doc.content);\r\n\r\n        div.appendChild(fragment);\r\n\r\n        return div.innerHTML;\r\n    }\r\n\r\n    private configurePlugins(options: SetupOptions) {\r\n        const plugins = [\r\n            buildInputRules(options.schema),\r\n            keymap(buildKeymap(options.schema, options.mapKeys)),\r\n            keymap(baseKeymap),\r\n            dropCursor(),\r\n            gapCursor(),\r\n            linkSelectPlugin,\r\n            columnResizing({}),\r\n            tableEditing({ allowTableNodeSelection: true }),\r\n            tableContextMenuPlugin(this.contextMenuService),\r\n            imageContextMenuPlugin(this.contextMenuService, this.injector.get(ModalService)),\r\n            rawEditorPlugin(this.contextMenuService, this.injector.get(ModalService)),\r\n            customMenuPlugin({\r\n                floatingMenu: options.floatingMenu,\r\n                injector: this.injector,\r\n                schema: options.schema,\r\n            }),\r\n        ];\r\n        if (options.history !== false) {\r\n            plugins.push(history());\r\n        }\r\n\r\n        return plugins.concat(\r\n            new Plugin({\r\n                props: {\r\n                    attributes: { class: 'vdr-prosemirror' },\r\n                },\r\n            }),\r\n        );\r\n    }\r\n}\r\n"]}
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvcmUvc3JjL3NoYXJlZC9jb21wb25lbnRzL3JpY2gtdGV4dC1lZGl0b3IvcHJvc2VtaXJyb3IvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1lbnVJdGVtIH0gZnJvbSAncHJvc2VtaXJyb3ItbWVudSc7XHJcbmltcG9ydCB7IFNjaGVtYSB9IGZyb20gJ3Byb3NlbWlycm9yLW1vZGVsJztcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgU2V0dXBPcHRpb25zIHtcclxuICAgIHNjaGVtYTogU2NoZW1hO1xyXG4gICAgbWFwS2V5cz86IEtleW1hcDtcclxuICAgIG1lbnVCYXI/OiBib29sZWFuO1xyXG4gICAgaGlzdG9yeT86IGJvb2xlYW47XHJcbiAgICBmbG9hdGluZ01lbnU/OiBib29sZWFuO1xyXG4gICAgbWVudUNvbnRlbnQ/OiBNZW51SXRlbVtdW107XHJcbn1cclxuXHJcbmV4cG9ydCB0eXBlIEtleW1hcCA9IFJlY29yZDxzdHJpbmcsIHN0cmluZyB8IGZhbHNlPjtcclxuIl19
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvcmUvc3JjL3NoYXJlZC9jb21wb25lbnRzL3JpY2gtdGV4dC1lZGl0b3IvcHJvc2VtaXJyb3IvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1lbnVJdGVtIH0gZnJvbSAncHJvc2VtaXJyb3ItbWVudSc7XHJcbmltcG9ydCB7IFNjaGVtYSB9IGZyb20gJ3Byb3NlbWlycm9yLW1vZGVsJztcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgU2V0dXBPcHRpb25zIHtcclxuICAgIHNjaGVtYTogU2NoZW1hO1xyXG4gICAgbWFwS2V5cz86IEtleW1hcDtcclxuICAgIG1lbnVCYXI/OiBib29sZWFuO1xyXG4gICAgaGlzdG9yeT86IGJvb2xlYW47XHJcbiAgICBmbG9hdGluZ01lbnU/OiBib29sZWFuO1xyXG59XHJcblxyXG5leHBvcnQgdHlwZSBLZXltYXAgPSBSZWNvcmQ8c3RyaW5nLCBzdHJpbmcgfCBmYWxzZT47XHJcbiJdfQ==