Compare commits

...

6 Commits

Author SHA1 Message Date
Kevin Jahns
ce80cb4a0d 13.4.14 2021-02-02 15:52:37 +01:00
Kevin Jahns
ae3c4cc050 add testHelper to bundle 2021-02-02 15:50:22 +01:00
Kevin Jahns
27a78047c5 13.4.13 2021-02-02 15:12:23 +01:00
Kevin Jahns
7a128c271b add changedParentTypes to undomanager events 2021-02-02 15:09:42 +01:00
Kevin Jahns
baca852733 add relevant relative positions exports 2021-01-13 01:16:21 +01:00
Kevin Jahns
7cbf204143 reduce bundle size #272 2021-01-10 15:13:19 +01:00
6 changed files with 43 additions and 11 deletions

2
package-lock.json generated
View File

@@ -1,6 +1,6 @@
{ {
"name": "yjs", "name": "yjs",
"version": "13.4.12", "version": "13.4.14",
"lockfileVersion": 1, "lockfileVersion": 1,
"requires": true, "requires": true,
"dependencies": { "dependencies": {

View File

@@ -1,6 +1,6 @@
{ {
"name": "yjs", "name": "yjs",
"version": "13.4.12", "version": "13.4.14",
"description": "Shared Editing Library", "description": "Shared Editing Library",
"main": "./dist/yjs.cjs", "main": "./dist/yjs.cjs",
"module": "./dist/yjs.mjs", "module": "./dist/yjs.mjs",
@@ -26,14 +26,13 @@
"postinstall": "node ./sponsor-y.js" "postinstall": "node ./sponsor-y.js"
}, },
"files": [ "files": [
"dist/*", "dist/yjs.*",
"src/*", "dist/src",
"tests/*", "src",
"docs/*", "tests/testHelper.js",
"sponsor-y.js" "sponsor-y.js"
], ],
"dictionaries": { "dictionaries": {
"doc": "docs",
"test": "tests" "test": "tests"
}, },
"standard": { "standard": {

View File

@@ -63,6 +63,9 @@ export {
encodeSnapshotV2, encodeSnapshotV2,
decodeStateVector, decodeStateVector,
decodeStateVectorV2, decodeStateVectorV2,
encodeRelativePosition,
decodeRelativePosition,
relativePositionToJSON,
isDeleted, isDeleted,
isParentOf, isParentOf,
equalSnapshots, equalSnapshots,

View File

@@ -75,13 +75,34 @@ export class RelativePosition {
} }
} }
/**
* @param {RelativePosition} rpos
* @return {any}
*/
export const relativePositionToJSON = rpos => {
const json = {}
if (rpos.type) {
json.type = rpos.type
}
if (rpos.tname) {
json.tname = rpos.tname
}
if (rpos.item) {
json.item = rpos.item
}
if (rpos.assoc != null) {
json.assoc = rpos.assoc
}
return json
}
/** /**
* @param {any} json * @param {any} json
* @return {RelativePosition} * @return {RelativePosition}
* *
* @function * @function
*/ */
export const createRelativePositionFromJSON = json => new RelativePosition(json.type == null ? null : createID(json.type.client, json.type.clock), json.tname || null, json.item == null ? null : createID(json.item.client, json.item.clock)) export const createRelativePositionFromJSON = json => new RelativePosition(json.type == null ? null : createID(json.type.client, json.type.clock), json.tname || null, json.item == null ? null : createID(json.item.client, json.item.clock), json.assoc == null ? 0 : json.assoc)
export class AbsolutePosition { export class AbsolutePosition {
/** /**

View File

@@ -10,7 +10,7 @@ import {
followRedone, followRedone,
getItemCleanStart, getItemCleanStart,
getState, getState,
ID, Transaction, Doc, Item, GC, DeleteSet, AbstractType // eslint-disable-line Transaction, Doc, Item, GC, DeleteSet, AbstractType, YEvent // eslint-disable-line
} from '../internals.js' } from '../internals.js'
import * as time from 'lib0/time.js' import * as time from 'lib0/time.js'
@@ -45,6 +45,11 @@ const popStackItem = (undoManager, stack, eventType) => {
* @type {StackItem?} * @type {StackItem?}
*/ */
let result = null let result = null
/**
* Keep a reference to the transaction so we can fire the event with the changedParentTypes
* @type {any}
*/
let _tr = null
const doc = undoManager.doc const doc = undoManager.doc
const scope = undoManager.scope const scope = undoManager.scope
transact(doc, transaction => { transact(doc, transaction => {
@@ -126,9 +131,11 @@ const popStackItem = (undoManager, stack, eventType) => {
type._searchMarker.length = 0 type._searchMarker.length = 0
} }
}) })
_tr = transaction
}, undoManager) }, undoManager)
if (result != null) { if (result != null) {
undoManager.emit('stack-item-popped', [{ stackItem: result, type: eventType }, undoManager]) const changedParentTypes = _tr.changedParentTypes
undoManager.emit('stack-item-popped', [{ stackItem: result, type: eventType, changedParentTypes }, undoManager])
} }
return result return result
} }
@@ -215,7 +222,7 @@ export class UndoManager extends Observable {
keepItem(item, true) keepItem(item, true)
} }
}) })
this.emit('stack-item-added', [{ stackItem: stack[stack.length - 1], origin: transaction.origin, type: undoing ? 'redo' : 'undo' }, this]) this.emit('stack-item-added', [{ stackItem: stack[stack.length - 1], origin: transaction.origin, type: undoing ? 'redo' : 'undo', changedParentTypes: transaction.changedParentTypes }, this])
}) })
} }

View File

@@ -201,10 +201,12 @@ export const testUndoEvents = tc => {
let receivedMetadata = -1 let receivedMetadata = -1
undoManager.on('stack-item-added', /** @param {any} event */ event => { undoManager.on('stack-item-added', /** @param {any} event */ event => {
t.assert(event.type != null) t.assert(event.type != null)
t.assert(event.changedParentTypes != null && event.changedParentTypes.has(text0))
event.stackItem.meta.set('test', counter++) event.stackItem.meta.set('test', counter++)
}) })
undoManager.on('stack-item-popped', /** @param {any} event */ event => { undoManager.on('stack-item-popped', /** @param {any} event */ event => {
t.assert(event.type != null) t.assert(event.type != null)
t.assert(event.changedParentTypes != null && event.changedParentTypes.has(text0))
receivedMetadata = event.stackItem.meta.get('test') receivedMetadata = event.stackItem.meta.get('test')
}) })
text0.insert(0, 'abc') text0.insert(0, 'abc')