Merge branch 'main' into main
This commit is contained in:
		
						commit
						9d2d812ea1
					
				
							
								
								
									
										4
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										4
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							@ -1,12 +1,12 @@
 | 
				
			|||||||
{
 | 
					{
 | 
				
			||||||
  "name": "yjs",
 | 
					  "name": "yjs",
 | 
				
			||||||
  "version": "13.5.39",
 | 
					  "version": "13.5.41",
 | 
				
			||||||
  "lockfileVersion": 2,
 | 
					  "lockfileVersion": 2,
 | 
				
			||||||
  "requires": true,
 | 
					  "requires": true,
 | 
				
			||||||
  "packages": {
 | 
					  "packages": {
 | 
				
			||||||
    "": {
 | 
					    "": {
 | 
				
			||||||
      "name": "yjs",
 | 
					      "name": "yjs",
 | 
				
			||||||
      "version": "13.5.39",
 | 
					      "version": "13.5.41",
 | 
				
			||||||
      "license": "MIT",
 | 
					      "license": "MIT",
 | 
				
			||||||
      "dependencies": {
 | 
					      "dependencies": {
 | 
				
			||||||
        "lib0": "^0.2.49"
 | 
					        "lib0": "^0.2.49"
 | 
				
			||||||
 | 
				
			|||||||
@ -1,6 +1,6 @@
 | 
				
			|||||||
{
 | 
					{
 | 
				
			||||||
  "name": "yjs",
 | 
					  "name": "yjs",
 | 
				
			||||||
  "version": "13.5.39",
 | 
					  "version": "13.5.41",
 | 
				
			||||||
  "description": "Shared Editing Library",
 | 
					  "description": "Shared Editing Library",
 | 
				
			||||||
  "main": "./dist/yjs.cjs",
 | 
					  "main": "./dist/yjs.cjs",
 | 
				
			||||||
  "module": "./dist/yjs.mjs",
 | 
					  "module": "./dist/yjs.mjs",
 | 
				
			||||||
 | 
				
			|||||||
@ -211,11 +211,6 @@ export const redoItem = (transaction, item, redoitems, itemsToDelete, ignoreRemo
 | 
				
			|||||||
      while (left !== null && left.redone !== null) {
 | 
					      while (left !== null && left.redone !== null) {
 | 
				
			||||||
        left = getItemCleanStart(transaction, left.redone)
 | 
					        left = getItemCleanStart(transaction, left.redone)
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
      // check wether we were allowed to follow right (indicating that originally this op was replaced by another item)
 | 
					 | 
				
			||||||
      if (left === null || /** @type {AbstractType<any>} */ (left.parent)._item !== parentItem) {
 | 
					 | 
				
			||||||
        // invalid parent; should never happen
 | 
					 | 
				
			||||||
        return null
 | 
					 | 
				
			||||||
      }
 | 
					 | 
				
			||||||
      if (left && left.right !== null) {
 | 
					      if (left && left.right !== null) {
 | 
				
			||||||
        // It is not possible to redo this item because it conflicts with a
 | 
					        // It is not possible to redo this item because it conflicts with a
 | 
				
			||||||
        // change from another client
 | 
					        // change from another client
 | 
				
			||||||
 | 
				
			|||||||
@ -142,6 +142,7 @@ const popStackItem = (undoManager, stack, eventType) => {
 | 
				
			|||||||
 * @property {boolean} [UndoManagerOptions.shouldDestroyUndoManager=true] Disable default destroy behavior if false. Sometimes
 | 
					 * @property {boolean} [UndoManagerOptions.shouldDestroyUndoManager=true] Disable default destroy behavior if false. Sometimes
 | 
				
			||||||
 * when use undoManager to manage multiply components globally, each component (like y-prosemirror.yUndoPlugin...) may call destroy once being removed, then cause the global undoManager being destoryed.
 | 
					 * when use undoManager to manage multiply components globally, each component (like y-prosemirror.yUndoPlugin...) may call destroy once being removed, then cause the global undoManager being destoryed.
 | 
				
			||||||
 * In this case, disable this option maybe be a choice to get the control back to yourself.
 | 
					 * In this case, disable this option maybe be a choice to get the control back to yourself.
 | 
				
			||||||
 | 
					 * @property {Doc} [doc] The document that this UndoManager operates on. Only needed if typeScope is empty.
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/**
 | 
					/**
 | 
				
			||||||
@ -165,6 +166,7 @@ export class UndoManager extends Observable {
 | 
				
			|||||||
    trackedOrigins = new Set([null]),
 | 
					    trackedOrigins = new Set([null]),
 | 
				
			||||||
    ignoreRemoteMapChanges = false,
 | 
					    ignoreRemoteMapChanges = false,
 | 
				
			||||||
    shouldDestroyUndoManager = true
 | 
					    shouldDestroyUndoManager = true
 | 
				
			||||||
 | 
					    doc = /** @type {Doc} */ (array.isArray(typeScope) ? typeScope[0].doc : typeScope.doc)
 | 
				
			||||||
  } = {}) {
 | 
					  } = {}) {
 | 
				
			||||||
    super()
 | 
					    super()
 | 
				
			||||||
    /**
 | 
					    /**
 | 
				
			||||||
@ -192,7 +194,7 @@ export class UndoManager extends Observable {
 | 
				
			|||||||
     */
 | 
					     */
 | 
				
			||||||
    this.undoing = false
 | 
					    this.undoing = false
 | 
				
			||||||
    this.redoing = false
 | 
					    this.redoing = false
 | 
				
			||||||
    this.doc = /** @type {Doc} */ (this.scope[0].doc)
 | 
					    this.doc = doc
 | 
				
			||||||
    this.lastChange = 0
 | 
					    this.lastChange = 0
 | 
				
			||||||
    this.ignoreRemoteMapChanges = ignoreRemoteMapChanges
 | 
					    this.ignoreRemoteMapChanges = ignoreRemoteMapChanges
 | 
				
			||||||
    /**
 | 
					    /**
 | 
				
			||||||
 | 
				
			|||||||
@ -49,6 +49,20 @@ export const testUndoText = tc => {
 | 
				
			|||||||
  t.compare(text0.toDelta(), [{ insert: 'b' }, { insert: 'cxy', attributes: { bold: true } }, { insert: 'z' }])
 | 
					  t.compare(text0.toDelta(), [{ insert: 'b' }, { insert: 'cxy', attributes: { bold: true } }, { insert: 'z' }])
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * Test case to fix #241
 | 
				
			||||||
 | 
					 * @param {t.TestCase} tc
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					export const testEmptyTypeScope = tc => {
 | 
				
			||||||
 | 
					  const ydoc = new Y.Doc()
 | 
				
			||||||
 | 
					  const um = new Y.UndoManager([], { doc: ydoc })
 | 
				
			||||||
 | 
					  const yarray = ydoc.getArray()
 | 
				
			||||||
 | 
					  um.addToScope(yarray)
 | 
				
			||||||
 | 
					  yarray.insert(0, [1])
 | 
				
			||||||
 | 
					  um.undo()
 | 
				
			||||||
 | 
					  t.assert(yarray.length === 0)
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/**
 | 
					/**
 | 
				
			||||||
 * Test case to fix #241
 | 
					 * Test case to fix #241
 | 
				
			||||||
 * @param {t.TestCase} tc
 | 
					 * @param {t.TestCase} tc
 | 
				
			||||||
@ -588,3 +602,32 @@ export const testBehaviorOfIgnoreremotemapchangesProperty = tc => {
 | 
				
			|||||||
  t.assert(map1.get('x') === 2)
 | 
					  t.assert(map1.get('x') === 2)
 | 
				
			||||||
  t.assert(map2.get('x') === 2)
 | 
					  t.assert(map2.get('x') === 2)
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * Special deletion case.
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * @see https://github.com/yjs/yjs/issues/447
 | 
				
			||||||
 | 
					 * @param {t.TestCase} tc
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					export const testSpecialDeletionCase = tc => {
 | 
				
			||||||
 | 
					  const origin = 'undoable'
 | 
				
			||||||
 | 
					  const doc = new Y.Doc()
 | 
				
			||||||
 | 
					  const fragment = doc.getXmlFragment()
 | 
				
			||||||
 | 
					  const undoManager = new Y.UndoManager(fragment, { trackedOrigins: new Set([origin]) })
 | 
				
			||||||
 | 
					  doc.transact(() => {
 | 
				
			||||||
 | 
					    const e = new Y.XmlElement('test')
 | 
				
			||||||
 | 
					    e.setAttribute('a', '1')
 | 
				
			||||||
 | 
					    e.setAttribute('b', '2')
 | 
				
			||||||
 | 
					    fragment.insert(0, [e])
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					  t.compareStrings(fragment.toString(), '<test a="1" b="2"></test>')
 | 
				
			||||||
 | 
					  doc.transact(() => {
 | 
				
			||||||
 | 
					    // change attribute "b" and delete test-node
 | 
				
			||||||
 | 
					    const e = fragment.get(0)
 | 
				
			||||||
 | 
					    e.setAttribute('b', '3')
 | 
				
			||||||
 | 
					    fragment.delete(0)
 | 
				
			||||||
 | 
					  }, origin)
 | 
				
			||||||
 | 
					  t.compareStrings(fragment.toString(), '')
 | 
				
			||||||
 | 
					  undoManager.undo()
 | 
				
			||||||
 | 
					  t.compareStrings(fragment.toString(), '<test a="1" b="2"></test>')
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user