diff --git a/editors/demo/src/Editoria/config/config.js b/editors/demo/src/Editoria/config/config.js index 332bad0418d997014e9678510d312e33c3061b01..5cc22496654502259e273a5874f1b40c93253104 100644 --- a/editors/demo/src/Editoria/config/config.js +++ b/editors/demo/src/Editoria/config/config.js @@ -44,6 +44,7 @@ import { CustomTagBlockToolGroupService, CustomTagService, YjsService, + disallowPasteImagesPlugin, } from 'wax-prosemirror-services'; import { EditoriaSchema } from 'wax-prosemirror-core'; @@ -72,6 +73,10 @@ const updateTrackStatus = status => { // console.log('status', status); }; +const onWarning = message => { + alert(message); +}; + export default { MenuService: [ { @@ -140,7 +145,16 @@ export default { reject: true, }, }, - PmPlugins: [columnResizing(), tableEditing(), invisibles([hardBreak()])], + PmPlugins: [ + columnResizing(), + tableEditing(), + invisibles([hardBreak()]), + disallowPasteImagesPlugin(() => + onWarning( + 'Images are not allowed. Please upload them through filemanager', + ), + ), + ], ImageService: { showAlt: true }, CustomTagService: { tags: [ diff --git a/package.json b/package.json index 04dcb6545ab61e96f3f050203c56e636062cb7cc..faae4dd53510c42e5f70b3e028e68c65ab67312f 100644 --- a/package.json +++ b/package.json @@ -37,7 +37,10 @@ } }, "resolutions": { - "prosemirror-view": "1.23.7", + "prosemirror-view": "1.30.2", + "prosemirror-model": "1.19.0", + "prosemirror-state": "1.4.2", + "prosemirror-transform": "1.7.1", "styled-components": "5.3.1" }, "devDependencies": { diff --git a/wax-prosemirror-core/package.json b/wax-prosemirror-core/package.json index b6f07d66adc194cb9a8544f94ba8c2d161ed658f..9e480b4a221f8e980e5a854a3daa2e4044e9ffe2 100644 --- a/wax-prosemirror-core/package.json +++ b/wax-prosemirror-core/package.json @@ -21,17 +21,17 @@ "lodash": "^4.17.4", "moment": "^2.29.0", "prop-types": "^15.7.2", - "prosemirror-commands": "1.2.1", - "prosemirror-dropcursor": "1.6.1", - "prosemirror-gapcursor": "1.2.2", - "prosemirror-history": "1.2.0", - "prosemirror-inputrules": "1.1.3", - "prosemirror-keymap": "1.1.5", - "prosemirror-model": "1.16.1", + "prosemirror-commands": "1.5.1", + "prosemirror-dropcursor": "1.7.1", + "prosemirror-gapcursor": "1.3.1", + "prosemirror-history": "1.3.0", + "prosemirror-inputrules": "1.2.0", + "prosemirror-keymap": "1.2.1", + "prosemirror-model": "1.19.0", "prosemirror-schema-list": "^1.1.6", - "prosemirror-state": "1.3.3", - "prosemirror-transform": "1.3.4", - "prosemirror-view": "1.23.7", + "prosemirror-state": "1.4.2", + "prosemirror-transform": "1.7.1", + "prosemirror-view": "1.30.2", "reflect-metadata": "^0.1.13", "uuid": "^7.0.3" }, diff --git a/wax-prosemirror-core/src/utilities/track-changes/helpers/markDeletion.js b/wax-prosemirror-core/src/utilities/track-changes/helpers/markDeletion.js index 2599ef535aa0c2585c346207b29eb5a962aefc38..8b4dce4c8ac1a5e8edc4cef349a7052f9614a894 100644 --- a/wax-prosemirror-core/src/utilities/track-changes/helpers/markDeletion.js +++ b/wax-prosemirror-core/src/utilities/track-changes/helpers/markDeletion.js @@ -1,6 +1,10 @@ +/* eslint-disable prefer-object-spread */ +/* eslint-disable consistent-return */ import { Selection, TextSelection } from 'prosemirror-state'; +import { v4 as uuidv4 } from 'uuid'; import { Slice } from 'prosemirror-model'; import { ReplaceStep, Mapping } from 'prosemirror-transform'; +import removeNode from './removeNode'; const markDeletion = (tr, from, to, user, date, group, viewId) => { const deletionMark = tr.doc.type.schema.marks.deletion.create({ @@ -53,11 +57,15 @@ const markDeletion = (tr, from, to, user, date, group, viewId) => { ) ) { let removeStep; + if (node.isTextblock && node.nodeSize === 2) { + return removeNode(tr, node, pos, deletionMap); + } if (node.isTextblock && to < pos + node.nodeSize) { const selectionBefore = Selection.findFrom(tr.doc.resolve(pos), -1); if (selectionBefore instanceof TextSelection) { removeStep = new ReplaceStep( - deletionMap.map(selectionBefore.$anchor.pos), + // deletionMap.map(selectionBefore.$anchor.pos), + deletionMap.map(Math.min(to, pos + node.nodeSize)), deletionMap.map(to), Slice.empty, ); @@ -91,13 +99,19 @@ const markDeletion = (tr, from, to, user, date, group, viewId) => { user: user.userId, username: user.username, style: `color: ${user.userColor.deletion};`, - - // date + date, + group, + viewid: viewId, }); tr.setNodeMarkup( deletionMap.map(pos), null, - Object.assign(node.attrs.track, { track }), + Object.assign({}, node.attrs, { + track, + group, + id: uuidv4(), + }), + // Object.assign(node.attrs.track, { track }), node.marks, ); } diff --git a/wax-prosemirror-core/src/utilities/track-changes/helpers/markInsertion.js b/wax-prosemirror-core/src/utilities/track-changes/helpers/markInsertion.js index 21ff69f48ff5207c291bcec18a33b9be2d11f7e3..d66ad1ae3732616d853af968fdcab78c5143f7d6 100644 --- a/wax-prosemirror-core/src/utilities/track-changes/helpers/markInsertion.js +++ b/wax-prosemirror-core/src/utilities/track-changes/helpers/markInsertion.js @@ -1,3 +1,4 @@ +/* eslint-disable no-else-return */ import { v4 as uuidv4 } from 'uuid'; const markInsertion = (tr, from, to, user, date, group, viewId) => { @@ -39,10 +40,12 @@ const markInsertion = (tr, from, to, user, date, group, viewId) => { tr.setNodeMarkup( pos, null, + // eslint-disable-next-line prefer-object-spread Object.assign({}, node.attrs, { track, group, id: uuidv4(), + viewid: viewId, }), node.marks, ); diff --git a/wax-prosemirror-core/src/utilities/track-changes/helpers/replaceAroundStep.js b/wax-prosemirror-core/src/utilities/track-changes/helpers/replaceAroundStep.js index db8f7c2f14da9af34168a243dc6b2c7a1f1dc95a..44cba88381c7d53c908d6d666583d1a7b7ef4214 100644 --- a/wax-prosemirror-core/src/utilities/track-changes/helpers/replaceAroundStep.js +++ b/wax-prosemirror-core/src/utilities/track-changes/helpers/replaceAroundStep.js @@ -21,7 +21,7 @@ const replaceAroundStep = ( newTr.step(step); const from = step.getMap().map(step.from, -1); const to = step.getMap().map(step.gapFrom); - markInsertion(newTr, from, to, user, date, group); + markInsertion(newTr, from, to, user, date, group, viewId); } else if (!step.slice.size || step.slice.content.content.length === 2) { const invertStep = originalStep.invert(tr.docs[originalStepIndex]).map(map); // unwrapped from something diff --git a/wax-prosemirror-core/src/utilities/track-changes/helpers/replaceStep.js b/wax-prosemirror-core/src/utilities/track-changes/helpers/replaceStep.js index e26da3edccd2761869525cd14903bad7c937d532..98fd4204711fea0b3230761d7ef656eb6ee6a77d 100644 --- a/wax-prosemirror-core/src/utilities/track-changes/helpers/replaceStep.js +++ b/wax-prosemirror-core/src/utilities/track-changes/helpers/replaceStep.js @@ -44,7 +44,15 @@ const replaceStep = ( } const mappedNewStepTo = newStep.getMap().map(newStep.to); - markInsertion(trTemp, newStep.from, mappedNewStepTo, user, date, group); + markInsertion( + trTemp, + newStep.from, + mappedNewStepTo, + user, + date, + group, + viewId, + ); // We condense it down to a single replace step. const condensedStep = new ReplaceStep( newStep.from, diff --git a/wax-prosemirror-core/src/utilities/track-changes/trackedTransaction.js b/wax-prosemirror-core/src/utilities/track-changes/trackedTransaction.js index fcb0c961394ba129f034d6dbb227bed374f9a77b..36c00d8152e5ce7062df89072f39580bf67d0722 100644 --- a/wax-prosemirror-core/src/utilities/track-changes/trackedTransaction.js +++ b/wax-prosemirror-core/src/utilities/track-changes/trackedTransaction.js @@ -60,7 +60,6 @@ const trackedTransaction = ( const step = originalStep.map(map); const { doc } = newTr; if (!step) return; - switch (step.constructor) { case ReplaceStep: replaceStep( diff --git a/wax-prosemirror-services/index.js b/wax-prosemirror-services/index.js index f58d39841de99d028fcd65b3eaf3f57e7d52f012..e413c6e6ad8de85cc606246d4baa92c0eab4d3db 100644 --- a/wax-prosemirror-services/index.js +++ b/wax-prosemirror-services/index.js @@ -68,3 +68,7 @@ export { default as QuestionsDropDownToolGroupService } from './src/WaxToolGroup export { default as OENContainersToolGroupService } from './src/WaxToolGroups/OENContainersToolGroupService/OENContainersToolGroupService'; export { default as OENLeftToolGroupService } from './src/WaxToolGroups/OENLeftToolGroupService/OENLeftToolGroupService'; export { default as FindAndReplaceToolGroupService } from './src/WaxToolGroups/FindAndReplaceToolGroupService/FindAndReplaceToolGroupService'; + +/* Plugins */ + +export { default as disallowPasteImagesPlugin } from './src/ImageService/plugins/disallowPasteImagesPlugin'; diff --git a/wax-prosemirror-services/package.json b/wax-prosemirror-services/package.json index b2567e55ede0a6680c532b16b7282a5a12bea67e..0970a17c6f3b46b4b81eb27a770b858136939876 100644 --- a/wax-prosemirror-services/package.json +++ b/wax-prosemirror-services/package.json @@ -21,17 +21,17 @@ "lodash": "^4.17.4", "mathjax-full": "3.1.4", "prop-types": "^15.7.2", - "prosemirror-commands": "1.2.1", + "prosemirror-commands": "1.5.1", "prosemirror-highlightjs": "^0.2.0", - "prosemirror-history": "1.2.0", - "prosemirror-inputrules": "1.1.3", - "prosemirror-keymap": "1.1.5", - "prosemirror-model": "1.16.1", + "prosemirror-history": "1.3.0", + "prosemirror-inputrules": "1.2.0", + "prosemirror-keymap": "1.2.1", + "prosemirror-model": "1.19.0", "prosemirror-schema-list": "1.1.6", - "prosemirror-state": "1.3.3", + "prosemirror-state": "1.4.2", "prosemirror-tables": "^1.1.1", - "prosemirror-transform": "1.3.4", - "prosemirror-view": "1.23.7", + "prosemirror-transform": "1.7.1", + "prosemirror-view": "1.30.2", "rc-switch": "^3.2.2", "react-dropdown": "^1.6.2", "use-deep-compare-effect": "^1.3.1", diff --git a/wax-prosemirror-services/src/CommentsService/components/ConnectedTrackChange.js b/wax-prosemirror-services/src/CommentsService/components/ConnectedTrackChange.js index 8c8ea1b2c56c410be7bb63a04f7e67aad6c006af..042ea5e1a9d56ccd1b7a8cf3a7a6c26a591b91e7 100644 --- a/wax-prosemirror-services/src/CommentsService/components/ConnectedTrackChange.js +++ b/wax-prosemirror-services/src/CommentsService/components/ConnectedTrackChange.js @@ -26,6 +26,7 @@ export default ({ trackChangeId, top, recalculateTops, trackChange }) => { const viewId = trackChange.attrs ? trackChange.attrs.viewid : trackChange.node.attrs.viewid; + const styles = { top: `${top}px`, }; diff --git a/wax-prosemirror-services/src/ImageService/plugins/disallowPasteImagesPlugin.js b/wax-prosemirror-services/src/ImageService/plugins/disallowPasteImagesPlugin.js new file mode 100644 index 0000000000000000000000000000000000000000..bc562c059eefd2571eb5c0b5af9754da7600274d --- /dev/null +++ b/wax-prosemirror-services/src/ImageService/plugins/disallowPasteImagesPlugin.js @@ -0,0 +1,33 @@ +/* eslint-disable no-param-reassign */ +import { Plugin, PluginKey } from 'prosemirror-state'; + +const disallowPasteImagesPlugin = new PluginKey('disallowPasteImagesPlugin'); + +export default onWarning => { + return new Plugin({ + key: disallowPasteImagesPlugin, + props: { + transformPasted: slice => { + const { + content: { content }, + } = slice; + + let imageFound = false; + content.forEach(node => { + if (node.type.name === 'image') { + node.attrs.src = ''; + node.attrs.alt = ''; + imageFound = true; + } + if (node.type.name === 'figure') { + node.lastChild.attrs.src = ''; + node.lastChild.attrs.alt = ''; + imageFound = true; + } + }); + if (imageFound) onWarning(); + return slice; + }, + }, + }); +}; diff --git a/wax-prosemirror-services/src/ImageService/schema/imageNode.js b/wax-prosemirror-services/src/ImageService/schema/imageNode.js index f009e4f13b98457c1f92935b4814a50aee5e504a..f8141b8f0206b1ee63b97df4e1d90a662123d0c8 100644 --- a/wax-prosemirror-services/src/ImageService/schema/imageNode.js +++ b/wax-prosemirror-services/src/ImageService/schema/imageNode.js @@ -42,7 +42,10 @@ const imageNode = { hook.value = [ 'img', { - src, + src: + src !== '' + ? src + : '', alt, title, 'data-id': id, diff --git a/wax-prosemirror-services/src/TrackChangeService/plugins/FindSelectedChanges.js b/wax-prosemirror-services/src/TrackChangeService/plugins/FindSelectedChanges.js index 91cc07aea34ccaeba90dde16be4bdc6a89dd3f28..82905816e9ce1acde4e50520468d31c46bb789ed 100644 --- a/wax-prosemirror-services/src/TrackChangeService/plugins/FindSelectedChanges.js +++ b/wax-prosemirror-services/src/TrackChangeService/plugins/FindSelectedChanges.js @@ -41,6 +41,47 @@ const findSelectedChanges = state => { formatChangePos = selection.from; } } + + /* TEMP */ + state.doc.nodesBetween(selection.from, selection.to, (node, pos) => { + if (!insertionMark) { + insertionMark = node.attrs.track + ? node.attrs.track.find(trackAttr => trackAttr.type === 'insertion') + : node.marks.find( + mark => mark.type.name === 'insertion' && !mark.attrs.approved, + ); + if (insertionMark) { + insertionPos = pos; + if (!node.isInline) { + insertionSize = node.nodeSize; + } + } + } + if (!deletionMark) { + deletionMark = node.attrs.track + ? node.attrs.track.find(trackAttr => trackAttr.type === 'deletion') + : node.marks.find(mark => mark.type.name === 'deletion'); + if (deletionMark) { + deletionPos = pos; + if (!node.isInline) { + deletionSize = node.nodeSize; + } + } + } + if (!formatChangeMark) { + formatChangeMark = node.marks.find( + mark => mark.type.name === 'format_change', + ); + if (formatChangeMark) { + formatChangePos = pos; + if (!node.isInline) { + formatChangeSize = node.nodeSize; + } + } + } + return false; + }); + /* TILL HERE */ } else { state.doc.nodesBetween(selection.from, selection.to, (node, pos) => { if (pos < selection.from) { @@ -105,7 +146,7 @@ const findSelectedChanges = state => { 'format_change', ); } + return selectedChanges; }; - export default findSelectedChanges; diff --git a/wax-prosemirror-services/src/TrackChangeService/plugins/TrackChangePlugin.js b/wax-prosemirror-services/src/TrackChangeService/plugins/TrackChangePlugin.js index 450507216cb7e82e443d3c109a57cc0cfc64058c..bd396b0b7fad9324ae5177190eb70a51ca6db484 100644 --- a/wax-prosemirror-services/src/TrackChangeService/plugins/TrackChangePlugin.js +++ b/wax-prosemirror-services/src/TrackChangeService/plugins/TrackChangePlugin.js @@ -31,7 +31,6 @@ export default options => { const { insertion, deletion, formatChange } = findSelectedChanges( state, ); - const decoType = tr.selection.node ? Decoration.node : Decoration.inline; @@ -39,7 +38,12 @@ export default options => { state.doc.nodesBetween(from, to, (node, pos) => { if ( node.attrs.track && - node.attrs.track.find(track => track.type === 'block_change') + node.attrs.track.find( + track => + track.type === 'block_change' || + track.type === 'insertion' || + track.type === 'deletion', + ) ) { let nodeSize = pos; node.descendants((childNode, childPos) => { diff --git a/yarn.lock b/yarn.lock index 6a25848b77cf48beb8c65aa728772a40009644c9..853628cd5ac76a0aa1f98a7e818feff41e216294 100644 --- a/yarn.lock +++ b/yarn.lock @@ -10416,10 +10416,10 @@ optionator@^0.8.1, optionator@^0.8.3: type-check "~0.3.2" word-wrap "~1.2.3" -orderedmap@^1.1.0: - version "1.1.1" - resolved "https://registry.yarnpkg.com/orderedmap/-/orderedmap-1.1.1.tgz#c618e77611b3b21d0fe3edc92586265e0059c789" - integrity sha512-3Ux8um0zXbVacKUkcytc0u3HgC0b0bBLT+I60r2J/En72cI0nZffqrA7Xtf2Hqs27j1g82llR5Mhbd0Z1XW4AQ== +orderedmap@^2.0.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/orderedmap/-/orderedmap-2.1.0.tgz#819457082fa3a06abd316d83a281a1ca467437cd" + integrity sha512-/pIFexOm6S70EPdznemIz3BQZoJ4VTFrhqzu0ACBqBgeLsLxq8e6Jim63ImIfwW/zAD1AlXpRMlOv3aghmo4dA== original@^1.0.0: version "1.0.2" @@ -11995,28 +11995,28 @@ prop-types@^15.6.1, prop-types@^15.7.2: object-assign "^4.1.1" react-is "^16.8.1" -prosemirror-commands@1.2.1: - version "1.2.1" - resolved "https://registry.yarnpkg.com/prosemirror-commands/-/prosemirror-commands-1.2.1.tgz#eae0cb714df695260659b78ff5d201d3a037e50d" - integrity sha512-S/IkpXfpuLFsRynC2HQ5iYROUPiZskKS1+ClcWycGJvj4HMb/mVfeEkQrixYxgTl96EAh+RZQNWPC06GZXk5tQ== +prosemirror-commands@1.5.1: + version "1.5.1" + resolved "https://registry.yarnpkg.com/prosemirror-commands/-/prosemirror-commands-1.5.1.tgz#89ddfa14e144dcc7fb0938aa0e2568c7fdde306f" + integrity sha512-ga1ga/RkbzxfAvb6iEXYmrEpekn5NCwTb8w1dr/gmhSoaGcQ0VPuCzOn5qDEpC45ql2oDkKoKQbRxLJwKLpMTQ== dependencies: prosemirror-model "^1.0.0" prosemirror-state "^1.0.0" prosemirror-transform "^1.0.0" -prosemirror-dropcursor@1.6.1: - version "1.6.1" - resolved "https://registry.yarnpkg.com/prosemirror-dropcursor/-/prosemirror-dropcursor-1.6.1.tgz#31f696172105f232bd17543ccf305e0f33e59d1d" - integrity sha512-LtyqQpkIknaT7NnZl3vDr3TpkNcG4ABvGRXx37XJ8tJNUGtcrZBh40A0344rDwlRTfUEmynQS/grUsoSWz+HgA== +prosemirror-dropcursor@1.7.1: + version "1.7.1" + resolved "https://registry.yarnpkg.com/prosemirror-dropcursor/-/prosemirror-dropcursor-1.7.1.tgz#b6921ef866ca95b6f6c8b197767f60dc39598416" + integrity sha512-GmWk9bAwhfHwA8xmJhBFjPcebxUG9zAPYtqpIr7NTDigWZZEJCgUYyUQeqgyscLr8ZHoh9aeprX9kW7BihUT+w== dependencies: prosemirror-state "^1.0.0" prosemirror-transform "^1.1.0" prosemirror-view "^1.1.0" -prosemirror-gapcursor@1.2.2: - version "1.2.2" - resolved "https://registry.yarnpkg.com/prosemirror-gapcursor/-/prosemirror-gapcursor-1.2.2.tgz#7394613ba4a1601fad1f36f1cff8961968c22ffa" - integrity sha512-7YzuRBbu9W7HGQde84kCHfIjaRLNcAdeijbgqrm/R9dsdTWkV+rrdcmic/sCc+bptiNpvjCEE+R6hrbT8zFQeQ== +prosemirror-gapcursor@1.3.1: + version "1.3.1" + resolved "https://registry.yarnpkg.com/prosemirror-gapcursor/-/prosemirror-gapcursor-1.3.1.tgz#8cfd874592e4504d63720e14ed680c7866e64554" + integrity sha512-GKTeE7ZoMsx5uVfc51/ouwMFPq0o8YrZ7Hx4jTF4EeGbXxBveUV8CGv46mSHuBBeXGmvu50guoV2kSnOeZZnUA== dependencies: prosemirror-keymap "^1.0.0" prosemirror-model "^1.0.0" @@ -12028,27 +12028,27 @@ prosemirror-highlightjs@^0.2.0: resolved "https://registry.yarnpkg.com/prosemirror-highlightjs/-/prosemirror-highlightjs-0.2.0.tgz#601932dea9060f72d9e4701ce2531140d03c735c" integrity sha512-2qI/M6FTSfhtshAWfUC+tiCgJzReGQGSLc6EtXtxe5lgiqFUqfsICiyna69x8GUrO30zr5JW9acsearX8/r37w== -prosemirror-history@1.2.0: - version "1.2.0" - resolved "https://registry.yarnpkg.com/prosemirror-history/-/prosemirror-history-1.2.0.tgz#04cc4df8d2f7b2a46651a2780de191ada6d465ea" - integrity sha512-B9v9xtf4fYbKxQwIr+3wtTDNLDZcmMMmGiI3TAPShnUzvo+Rmv1GiUrsQChY1meetHl7rhML2cppF3FTs7f7UQ== +prosemirror-history@1.3.0: + version "1.3.0" + resolved "https://registry.yarnpkg.com/prosemirror-history/-/prosemirror-history-1.3.0.tgz#bf5a1ff7759aca759ddf0c722c2fa5b14fb0ddc1" + integrity sha512-qo/9Wn4B/Bq89/YD+eNWFbAytu6dmIM85EhID+fz9Jcl9+DfGEo8TTSrRhP15+fFEoaPqpHSxlvSzSEbmlxlUA== dependencies: prosemirror-state "^1.2.2" prosemirror-transform "^1.0.0" rope-sequence "^1.3.0" -prosemirror-inputrules@1.1.3: - version "1.1.3" - resolved "https://registry.yarnpkg.com/prosemirror-inputrules/-/prosemirror-inputrules-1.1.3.tgz#93f9199ca02473259c30d7e352e4c14022d54638" - integrity sha512-ZaHCLyBtvbyIHv0f5p6boQTIJjlD6o2NPZiEaZWT2DA+j591zS29QQEMT4lBqwcLW3qRSf7ZvoKNbf05YrsStw== +prosemirror-inputrules@1.2.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/prosemirror-inputrules/-/prosemirror-inputrules-1.2.0.tgz#476dde2dc244050b3aca00cf58a82adfad6749e7" + integrity sha512-eAW/M/NTSSzpCOxfR8Abw6OagdG0MiDAiWHQMQveIsZtoKVYzm0AflSPq/ymqJd56/Su1YPbwy9lM13wgHOFmQ== dependencies: prosemirror-state "^1.0.0" prosemirror-transform "^1.0.0" -prosemirror-keymap@1.1.5: - version "1.1.5" - resolved "https://registry.yarnpkg.com/prosemirror-keymap/-/prosemirror-keymap-1.1.5.tgz#b5984c7d30f5c75956c853126c54e9e624c0327b" - integrity sha512-8SZgPH3K+GLsHL2wKuwBD9rxhsbnVBTwpHCO4VUO5GmqUQlxd/2GtBVWTsyLq4Dp3N9nGgPd3+lZFKUDuVp+Vw== +prosemirror-keymap@1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/prosemirror-keymap/-/prosemirror-keymap-1.2.1.tgz#3839e7db66cecddae7451f4246e73bdd8489be1d" + integrity sha512-kVK6WGC+83LZwuSJnuCb9PsADQnFZllt94qPP3Rx/vLcOUV65+IbBeH2nS5cFggPyEVJhGkGrgYFRrG250WhHQ== dependencies: prosemirror-state "^1.0.0" w3c-keyname "^2.2.0" @@ -12061,12 +12061,12 @@ prosemirror-keymap@^1.0.0, prosemirror-keymap@^1.1.2: prosemirror-state "^1.0.0" w3c-keyname "^2.2.0" -prosemirror-model@1.16.1, prosemirror-model@^1.0.0, prosemirror-model@^1.16.0, prosemirror-model@^1.2.0, prosemirror-model@^1.8.1: - version "1.16.1" - resolved "https://registry.yarnpkg.com/prosemirror-model/-/prosemirror-model-1.16.1.tgz#fb388270bc9609b66298d6a7e15d0cc1d6c61253" - integrity sha512-r1/w0HDU40TtkXp0DyKBnFPYwd8FSlUSJmGCGFv4DeynfeSlyQF2FD0RQbVEMOe6P3PpUSXM6LZBV7W/YNZ4mA== +prosemirror-model@1.19.0, prosemirror-model@^1.0.0, prosemirror-model@^1.16.0, prosemirror-model@^1.2.0, prosemirror-model@^1.8.1: + version "1.19.0" + resolved "https://registry.yarnpkg.com/prosemirror-model/-/prosemirror-model-1.19.0.tgz#d7ad9a65ada0bb12196f64fe0dd4fc392c841c29" + integrity sha512-/CvFGJnwc41EJSfDkQLly1cAJJJmBpZwwUJtwZPTjY2RqZJfM8HVbCreOY/jti8wTRbVyjagcylyGoeJH/g/3w== dependencies: - orderedmap "^1.1.0" + orderedmap "^2.0.0" prosemirror-schema-basic@^1.0.0: version "1.1.2" @@ -12091,13 +12091,14 @@ prosemirror-schema-list@^1.0.0: prosemirror-model "^1.0.0" prosemirror-transform "^1.0.0" -prosemirror-state@1.3.3, prosemirror-state@^1.0.0, prosemirror-state@^1.2.2, prosemirror-state@^1.3.1: - version "1.3.3" - resolved "https://registry.yarnpkg.com/prosemirror-state/-/prosemirror-state-1.3.3.tgz#b2862866b14dec2b3ae1ab18229f2bd337651a2c" - integrity sha512-PLXh2VJsIgvlgSTH6I2Yg6vk1CzPDp21DFreVpQtDMY2S6WaMmrQgDTLRcsrD8X38v8Yc873H7+ogdGzyIPn+w== +prosemirror-state@1.4.2, prosemirror-state@^1.0.0, prosemirror-state@^1.2.2, prosemirror-state@^1.3.1: + version "1.4.2" + resolved "https://registry.yarnpkg.com/prosemirror-state/-/prosemirror-state-1.4.2.tgz#f93bd8a33a4454efab917ba9b738259d828db7e5" + integrity sha512-puuzLD2mz/oTdfgd8msFbe0A42j5eNudKAAPDB0+QJRw8cO1ygjLmhLrg9RvDpf87Dkd6D4t93qdef00KKNacQ== dependencies: prosemirror-model "^1.0.0" prosemirror-transform "^1.0.0" + prosemirror-view "^1.27.0" prosemirror-tables@^1.1.1: version "1.1.1" @@ -12119,17 +12120,17 @@ prosemirror-test-builder@^1.0.1: prosemirror-schema-basic "^1.0.0" prosemirror-schema-list "^1.0.0" -prosemirror-transform@1.3.4, prosemirror-transform@^1.0.0, prosemirror-transform@^1.1.0, prosemirror-transform@^1.2.1: - version "1.3.4" - resolved "https://registry.yarnpkg.com/prosemirror-transform/-/prosemirror-transform-1.3.4.tgz#1d1997009b7b145c2aa2773f7f670c8a3d4cb46f" - integrity sha512-gTsg3UIeaFuEY6+YmNPMgTpEkCKPedkFIUnsPpOMbclU701fEVI/e4VOXACXh3BO5rZJaBbEBwrnzB0mLp6eBA== +prosemirror-transform@1.7.1, prosemirror-transform@^1.0.0, prosemirror-transform@^1.1.0, prosemirror-transform@^1.2.1: + version "1.7.1" + resolved "https://registry.yarnpkg.com/prosemirror-transform/-/prosemirror-transform-1.7.1.tgz#b516e818c3add0bdf960f4ca8ccb9d057a3ba21b" + integrity sha512-VteoifAfpt46z0yEt6Fc73A5OID9t/y2QIeR5MgxEwTuitadEunD/V0c9jQW8ziT8pbFM54uTzRLJ/nLuQjMxg== dependencies: prosemirror-model "^1.0.0" -prosemirror-view@1.23.7, prosemirror-view@^1.0.0, prosemirror-view@^1.1.0, prosemirror-view@^1.13.3, prosemirror-view@^1.5.1: - version "1.23.7" - resolved "https://registry.yarnpkg.com/prosemirror-view/-/prosemirror-view-1.23.7.tgz#f003af94445ef456e397c18cf4bb995e7072097f" - integrity sha512-ugY+g/4UI2Ree1zzdvbyQWF2KpbFa7kxKMLHaEJcxiPaErnZiD5wZFqIgFinc7fY2v/QM3DLnJ++2I45ULRdrg== +prosemirror-view@1.30.2, prosemirror-view@^1.0.0, prosemirror-view@^1.1.0, prosemirror-view@^1.13.3, prosemirror-view@^1.27.0, prosemirror-view@^1.5.1: + version "1.30.2" + resolved "https://registry.yarnpkg.com/prosemirror-view/-/prosemirror-view-1.30.2.tgz#57a9d15c5baa454f0d0f4a3028ddbd9be1e8ed9b" + integrity sha512-nTNzZvalQf9kHeEyO407LiV6DoOs/pXsid88UqW9Vvybo4ozJW2PJhkfZUxCUF1hR/9vJLdhxX84wuw9P9HsXA== dependencies: prosemirror-model "^1.16.0" prosemirror-state "^1.0.0"