Comparing version 0.1.1 to 0.1.2
@@ -80,13 +80,6 @@ 'use strict'; | ||
var controller = void 0; | ||
var liveSet = new _liveSet2.default({ | ||
read: function read() { | ||
return new _set2.default(); | ||
}, | ||
listen: function listen(_controller) { | ||
controller = _controller; | ||
} | ||
}); | ||
liveSet.subscribe({}); // force activation | ||
if (!controller) throw new Error(); | ||
var _LiveSet$active = _liveSet2.default.active(), | ||
liveSet = _LiveSet$active.liveSet, | ||
controller = _LiveSet$active.controller; | ||
return [tag, { ownedTags: new _set2.default(), liveSet: liveSet, controller: controller }]; | ||
@@ -209,2 +202,2 @@ })); | ||
module.exports = exports['default']; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/TagTree.js"],"names":["EMPTY_ARRAY","TagTree","init","rootNodeController","value","root","parent","ownedTags","tags","map","tag","executor","controller","_nodeControllers","_lookupTable","Error","set","_allByTag","liveSet","read","listen","_controller","subscribe","forEach","ownedBy","entry","get","owningTag","add","addTaggedValue","tagEntry","node","valueNodes","push","parentController","addOwnedNode","removeTaggedNode","getOwned","values","childNode","remove","getValue","nodes","length","ix","indexOf","splice","delete","removeOwnedNode","end","l","slice","m"],"mappings":"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","file":"TagTree.js","sourcesContent":["/* @flow */\n\nimport LiveSet from 'live-set';\nimport type {LiveSetController} from 'live-set';\n\nimport TagTreeNode from './TagTreeNode';\nimport type {TagTreeNodeController} from './TagTreeNode';\n\nexport type TagTreeController<T> = {\n  addTaggedValue(parent: TagTreeNode<T>, tag: string, value: T): TagTreeNode<T>;\n  removeTaggedNode(parent: TagTreeNode<T>, tag: string, node: TagTreeNode<T>): void;\n  end(): void;\n};\n\nexport type TagTreeInit<T> = {|\n  root: T;\n  tags: Array<{| tag: string, ownedBy?: ?Array<string> |}>;\n  executor: (controller: TagTreeController<T>) => void;\n|};\n\nconst EMPTY_ARRAY = Object.freeze([]);\n\nexport default class TagTree<T> extends TagTreeNode<T> {\n  _nodeControllers: Map<TagTreeNode<T>, TagTreeNodeController<T>> = new Map();\n  _lookupTable: Map<T, Array<TagTreeNode<T>>> = new Map();\n  _allByTag: Map<string, {\n    ownedTags: Set<string>;\n    liveSet: LiveSet<TagTreeNode<T>>;\n    controller: LiveSetController<TagTreeNode<T>>;\n  }>;\n\n  constructor(init: TagTreeInit<T>) {\n    let rootNodeController;\n    super({\n      value: init.root,\n      parent: null,\n      ownedTags: new Set(init.tags.map(({tag}) => tag)),\n      executor: (controller) => {\n        rootNodeController = controller;\n      }\n    });\n    if (!rootNodeController) throw new Error();\n    this._nodeControllers.set(this, rootNodeController);\n\n    this._allByTag = new Map(init.tags.map(({tag}) => {\n      let controller;\n      const liveSet = new LiveSet({\n        read: () => new Set(),\n        listen: _controller => {\n          controller = _controller;\n        }\n      });\n      liveSet.subscribe({}); // force activation\n      if (!controller) throw new Error();\n      return [tag, {ownedTags: new Set(), liveSet, controller}];\n    }));\n\n    init.tags.forEach(({tag, ownedBy}) => {\n      if (!ownedBy) return;\n      ownedBy.forEach(owningTag => {\n        const entry = this._allByTag.get(owningTag);\n        if (!entry) throw new Error(`unknown ownedBy value for ${tag}: ${owningTag}`);\n        entry.ownedTags.add(tag);\n      });\n    });\n\n    const controller = {\n      addTaggedValue: (parent, tag, value) => {\n        const tagEntry = this._allByTag.get(tag);\n        if (!tagEntry) throw new Error(`unknown tag: ${tag}`);\n\n        let controller;\n        const node = new TagTreeNode({\n          value,\n          parent,\n          ownedTags: tagEntry.ownedTags,\n          executor: (_controller) => {\n            controller = _controller;\n          }\n        });\n        if (!controller) throw new Error();\n        this._nodeControllers.set(node, controller);\n\n        tagEntry.controller.add(node);\n\n        const valueNodes = this._lookupTable.get(value);\n        if (valueNodes) {\n          valueNodes.push(node);\n        } else {\n          this._lookupTable.set(value, [node]);\n        }\n\n        const parentController = this._nodeControllers.get(parent);\n        if (!parentController) throw new Error('parent is not part of TagTree');\n        parentController.addOwnedNode(tag, node);\n\n        return node;\n      },\n      removeTaggedNode: (parent, tag, node) => {\n        const tagEntry = this._allByTag.get(tag);\n        if (!tagEntry) throw new Error(`unknown tag: ${tag}`);\n\n        node.getOwned().forEach((liveSet, tag) => {\n          liveSet.values().forEach(childNode => {\n            controller.removeTaggedNode(node, tag, childNode);\n          });\n        });\n\n        tagEntry.controller.remove(node);\n\n        const value = node.getValue();\n        const nodes = this._lookupTable.get(value);\n        if (!nodes) throw new Error('node was missing from lookup table before removal');\n        if (nodes.length > 1) {\n          const ix = nodes.indexOf(node);\n          if (ix < 0) throw new Error('node was missing from list in lookup table before removal');\n          nodes.splice(ix, 1);\n        } else {\n          this._lookupTable.delete(value);\n        }\n\n        const parentController = this._nodeControllers.get(parent);\n        if (!parentController) throw new Error('parent is not part of TagTree');\n        parentController.removeOwnedNode(tag, node);\n\n        this._nodeControllers.delete(node);\n      },\n      end: () => {\n        this._nodeControllers.forEach(controller => {\n          controller.end();\n        });\n      }\n    };\n    init.executor(controller);\n    init.executor = () => {}; // release reference\n  }\n\n  getNodesForValue(value: T): Array<TagTreeNode<T>> {\n    const l = this._lookupTable.get(value);\n    return l ? Object.freeze(l.slice()) : (EMPTY_ARRAY:any);\n  }\n\n  getAllByTag(tag: string): LiveSet<TagTreeNode<T>> {\n    const entry = this._allByTag.get(tag);\n    if (!entry) throw new Error(`tag does not exist in TagTree: ${tag}`);\n    return entry.liveSet;\n  }\n\n  getAll(): Map<string, LiveSet<TagTreeNode<T>>> {\n    const m = new Map();\n    this._allByTag.forEach(({liveSet}, tag) => {\n      m.set(tag, liveSet);\n    });\n    return m;\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/TagTree.js"],"names":["EMPTY_ARRAY","TagTree","init","rootNodeController","value","root","parent","ownedTags","tags","map","tag","executor","controller","_nodeControllers","_lookupTable","Error","set","_allByTag","active","liveSet","forEach","ownedBy","entry","get","owningTag","add","addTaggedValue","tagEntry","node","_controller","valueNodes","push","parentController","addOwnedNode","removeTaggedNode","getOwned","values","childNode","remove","getValue","nodes","length","ix","indexOf","splice","delete","removeOwnedNode","end","l","slice","m"],"mappings":"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","file":"TagTree.js","sourcesContent":["/* @flow */\n\nimport LiveSet from 'live-set';\nimport type {LiveSetController} from 'live-set';\n\nimport TagTreeNode from './TagTreeNode';\nimport type {TagTreeNodeController} from './TagTreeNode';\n\nexport type TagTreeController<T> = {\n  addTaggedValue(parent: TagTreeNode<T>, tag: string, value: T): TagTreeNode<T>;\n  removeTaggedNode(parent: TagTreeNode<T>, tag: string, node: TagTreeNode<T>): void;\n  end(): void;\n};\n\nexport type TagTreeInit<T> = {|\n  root: T;\n  tags: Array<{| tag: string, ownedBy?: ?Array<string> |}>;\n  executor: (controller: TagTreeController<T>) => void;\n|};\n\nconst EMPTY_ARRAY = Object.freeze([]);\n\nexport default class TagTree<T> extends TagTreeNode<T> {\n  _nodeControllers: Map<TagTreeNode<T>, TagTreeNodeController<T>> = new Map();\n  _lookupTable: Map<T, Array<TagTreeNode<T>>> = new Map();\n  _allByTag: Map<string, {\n    ownedTags: Set<string>;\n    liveSet: LiveSet<TagTreeNode<T>>;\n    controller: LiveSetController<TagTreeNode<T>>;\n  }>;\n\n  constructor(init: TagTreeInit<T>) {\n    let rootNodeController;\n    super({\n      value: init.root,\n      parent: null,\n      ownedTags: new Set(init.tags.map(({tag}) => tag)),\n      executor: (controller) => {\n        rootNodeController = controller;\n      }\n    });\n    if (!rootNodeController) throw new Error();\n    this._nodeControllers.set(this, rootNodeController);\n\n    this._allByTag = new Map(init.tags.map(({tag}) => {\n      const {liveSet, controller} = LiveSet.active();\n      return [tag, {ownedTags: new Set(), liveSet, controller}];\n    }));\n\n    init.tags.forEach(({tag, ownedBy}) => {\n      if (!ownedBy) return;\n      ownedBy.forEach(owningTag => {\n        const entry = this._allByTag.get(owningTag);\n        if (!entry) throw new Error(`unknown ownedBy value for ${tag}: ${owningTag}`);\n        entry.ownedTags.add(tag);\n      });\n    });\n\n    const controller = {\n      addTaggedValue: (parent, tag, value) => {\n        const tagEntry = this._allByTag.get(tag);\n        if (!tagEntry) throw new Error(`unknown tag: ${tag}`);\n\n        let controller;\n        const node = new TagTreeNode({\n          value,\n          parent,\n          ownedTags: tagEntry.ownedTags,\n          executor: (_controller) => {\n            controller = _controller;\n          }\n        });\n        if (!controller) throw new Error();\n        this._nodeControllers.set(node, controller);\n\n        tagEntry.controller.add(node);\n\n        const valueNodes = this._lookupTable.get(value);\n        if (valueNodes) {\n          valueNodes.push(node);\n        } else {\n          this._lookupTable.set(value, [node]);\n        }\n\n        const parentController = this._nodeControllers.get(parent);\n        if (!parentController) throw new Error('parent is not part of TagTree');\n        parentController.addOwnedNode(tag, node);\n\n        return node;\n      },\n      removeTaggedNode: (parent, tag, node) => {\n        const tagEntry = this._allByTag.get(tag);\n        if (!tagEntry) throw new Error(`unknown tag: ${tag}`);\n\n        node.getOwned().forEach((liveSet, tag) => {\n          liveSet.values().forEach(childNode => {\n            controller.removeTaggedNode(node, tag, childNode);\n          });\n        });\n\n        tagEntry.controller.remove(node);\n\n        const value = node.getValue();\n        const nodes = this._lookupTable.get(value);\n        if (!nodes) throw new Error('node was missing from lookup table before removal');\n        if (nodes.length > 1) {\n          const ix = nodes.indexOf(node);\n          if (ix < 0) throw new Error('node was missing from list in lookup table before removal');\n          nodes.splice(ix, 1);\n        } else {\n          this._lookupTable.delete(value);\n        }\n\n        const parentController = this._nodeControllers.get(parent);\n        if (!parentController) throw new Error('parent is not part of TagTree');\n        parentController.removeOwnedNode(tag, node);\n\n        this._nodeControllers.delete(node);\n      },\n      end: () => {\n        this._nodeControllers.forEach(controller => {\n          controller.end();\n        });\n      }\n    };\n    init.executor(controller);\n    init.executor = () => {}; // release reference\n  }\n\n  getNodesForValue(value: T): Array<TagTreeNode<T>> {\n    const l = this._lookupTable.get(value);\n    return l ? Object.freeze(l.slice()) : (EMPTY_ARRAY:any);\n  }\n\n  getAllByTag(tag: string): LiveSet<TagTreeNode<T>> {\n    const entry = this._allByTag.get(tag);\n    if (!entry) throw new Error(`tag does not exist in TagTree: ${tag}`);\n    return entry.liveSet;\n  }\n\n  getAll(): Map<string, LiveSet<TagTreeNode<T>>> {\n    const m = new Map();\n    this._allByTag.forEach(({liveSet}, tag) => {\n      m.set(tag, liveSet);\n    });\n    return m;\n  }\n}\n"]} |
@@ -7,6 +7,2 @@ 'use strict'; | ||
var _set = require('babel-runtime/core-js/set'); | ||
var _set2 = _interopRequireDefault(_set); | ||
var _map = require('babel-runtime/core-js/map'); | ||
@@ -74,14 +70,3 @@ | ||
value: function _createTagEntry() { | ||
var controller = void 0; | ||
var liveSet = new _liveSet2.default({ | ||
read: function read() { | ||
return new _set2.default(); | ||
}, | ||
listen: function listen(_controller) { | ||
controller = _controller; | ||
} | ||
}); | ||
liveSet.subscribe({}); // force activation | ||
if (!controller) throw new Error(); | ||
return { liveSet: liveSet, controller: controller }; | ||
return _liveSet2.default.active(); | ||
} | ||
@@ -142,2 +127,2 @@ }, { | ||
module.exports = exports['default']; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9UYWdUcmVlTm9kZS5qcyJdLCJuYW1lcyI6WyJUYWdUcmVlTm9kZSIsImluaXQiLCJfb3duZWROb2RlcyIsIl9vd25lZEJ5VGFnIiwiX2luaXQiLCJleGVjdXRvciIsImFkZE93bmVkTm9kZSIsInRhZyIsIm5vZGUiLCJzZXQiLCJlbnRyeSIsImdldCIsIl9jcmVhdGVUYWdFbnRyeSIsImNvbnRyb2xsZXIiLCJhZGQiLCJyZW1vdmVPd25lZE5vZGUiLCJkZWxldGUiLCJFcnJvciIsInJlbW92ZSIsImVuZCIsImZvckVhY2giLCJsaXZlU2V0IiwicmVhZCIsImxpc3RlbiIsIl9jb250cm9sbGVyIiwic3Vic2NyaWJlIiwidmFsdWUiLCJwYXJlbnQiLCJvd25lZFRhZ3MiLCJoYXMiLCJtIiwiZ2V0VGFnT2ZPd25lZE5vZGUiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFFQTs7Ozs7O0lBZ0JxQkEsVztBQVFuQix1QkFBWUMsSUFBWixFQUFzQztBQUFBOztBQUFBO0FBQUEsU0FOdENDLFdBTXNDLEdBTkssbUJBTUw7QUFBQSxTQUx0Q0MsV0FLc0MsR0FGakMsbUJBRWlDOztBQUNwQyxTQUFLQyxLQUFMLEdBQWFILElBQWI7QUFDQSxTQUFLRyxLQUFMLENBQVdDLFFBQVgsQ0FBb0I7QUFDbEJDLG9CQUFjLHNCQUFDQyxHQUFELEVBQU1DLElBQU4sRUFBZTtBQUMzQixjQUFLTixXQUFMLENBQWlCTyxHQUFqQixDQUFxQkQsSUFBckIsRUFBMkJELEdBQTNCO0FBQ0EsWUFBSUcsUUFBUSxNQUFLUCxXQUFMLENBQWlCUSxHQUFqQixDQUFxQkosR0FBckIsQ0FBWjtBQUNBLFlBQUksQ0FBQ0csS0FBTCxFQUFZO0FBQ1ZBLGtCQUFRLE1BQUtFLGVBQUwsRUFBUjtBQUNBLGdCQUFLVCxXQUFMLENBQWlCTSxHQUFqQixDQUFxQkYsR0FBckIsRUFBMEJHLEtBQTFCO0FBQ0Q7QUFOMEIscUJBT05BLEtBUE07QUFBQSxZQU9wQkcsVUFQb0Is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Y2VzQ29udGVudCI6WyIvKiBAZmxvdyAqL1xuXG5pbXBvcnQgTGl2ZVNldCBmcm9tICdsaXZlLXNldCc7XG5pbXBvcnQgdHlwZSB7TGl2ZVNldENvbnRyb2xsZXJ9IGZyb20gJ2xpdmUtc2V0JztcblxuZXhwb3J0IHR5cGUgVGFnVHJlZU5vZGVDb250cm9sbGVyPFQ+ID0ge1xuICBhZGRPd25lZE5vZGUodGFnOiBzdHJpbmcsIG5vZGU6IFRhZ1RyZWVOb2RlPFQ+KTogdm9pZDtcbiAgcmVtb3ZlT3duZWROb2RlKHRhZzogc3RyaW5nLCBub2RlOiBUYWdUcmVlTm9kZTxUPik6IHZvaWQ7XG4gIGVuZCgpOiB2b2lkO1xufTtcblxuZXhwb3J0IHR5cGUgVGFnVHJlZU5vZGVJbml0PFQ+ID0ge3xcbiAgdmFsdWU6IFQ7XG4gIHBhcmVudDogP1RhZ1RyZWVOb2RlPFQ+O1xuICBvd25lZFRhZ3M6IFNldDxzdHJpbmc+O1xuICBleGVjdXRvcjogKGNvbnRyb2xsZXI6IFRhZ1RyZWVOb2RlQ29udHJvbGxlcjxUPikgPT4gdm9pZDtcbnx9O1xuXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBUYWdUcmVlTm9kZTxUPiB7XG4gIF9pbml0OiBUYWdUcmVlTm9kZUluaXQ8VD47XG4gIF9vd25lZE5vZGVzOiBNYXA8VGFnVHJlZU5vZGU8VD4sIHN0cmluZz4gPSBuZXcgTWFwKCk7XG4gIF9vd25lZEJ5VGFnOiBNYXA8c3RyaW5nLCB7XG4gICAgbGl2ZVNldDogTGl2ZVNldDxUYWdUcmVlTm9kZTxUPj47XG4gICAgY29udHJvbGxlcjogTGl2ZVNldENvbnRyb2xsZXI8VGFnVHJlZU5vZGU8VD4+O1xuICB9PiA9IG5ldyBNYXAoKTtcblxuICBjb25zdHJ1Y3Rvcihpbml0OiBUYWdUcmVlTm9kZUluaXQ8VD4pIHtcbiAgICB0aGlzLl9pbml0ID0gaW5pdDtcbiAgICB0aGlzLl9pbml0LmV4ZWN1dG9yKHtcbiAgICAgIGFkZE93bmVkTm9kZTogKHRhZywgbm9kZSkgPT4ge1xuICAgICAgICB0aGlzLl9vd25lZE5vZGVzLnNldChub2RlLCB0YWcpO1xuICAgICAgICBsZXQgZW50cnkgPSB0aGlzLl9vd25lZEJ5VGFnLmdldCh0YWcpO1xuICAgICAgICBpZiAoIWVudHJ5KSB7XG4gICAgICAgICAgZW50cnkgPSB0aGlzLl9jcmVhdGVUYWdFbnRyeSgpO1xuICAgICAgICAgIHRoaXMuX293bmVkQnlUYWcuc2V0KHRhZywgZW50cnkpO1xuICAgICAgICB9XG4gICAgICAgIGNvbnN0IHtjb250cm9sbGVyfSA9IGVudHJ5O1xuICAgICAgICBjb250cm9sbGVyLmFkZChub2RlKTtcbiAgICAgIH0sXG4gICAgICByZW1vdmVPd25lZE5vZGU6ICh0YWcsIG5vZGUpID0+IHtcbiAgICAgICAgdGhpcy5fb3duZWROb2Rlcy5kZWxldGUobm9kZSk7XG4gICAgICAgIGNvbnN0IGVudHJ5ID0gdGhpcy5fb3duZWRCeVRhZy5nZXQodGFnKTtcbiAgICAgICAgaWYgKCFlbnRyeSkgdGhyb3cgbmV3IEVycm9yKCd0YWcgbm90IG93bmVkJyk7XG4gICAgICAgIGNvbnN0IHtjb250cm9sbGVyfSA9IGVudHJ5O1xuICAgICAgICBjb250cm9sbGVyLnJlbW92ZShub2RlKTtcbiAgICAgIH0sXG4gICAgICBlbmQ6ICgpID0+IHtcbiAgICAgICAgdGhpcy5fb3duZWRCeVRhZy5mb3JFYWNoKCh7Y29udHJvbGxlcn0pID0+IHtcbiAgICAgICAgICBjb250cm9sbGVyLmVuZCgpO1xuICAgICAgICB9KTtcbiAgICAgIH1cbiAgICB9KTtcbiAgICB0aGlzLl9pbml0LmV4ZWN1dG9yID0gKCkgPT4ge307IC8vIHJlbGVhc2UgcmVmZXJlbmNlXG4gIH1cblxuICBfY3JlYXRlVGFnRW50cnkoKTogT2JqZWN0IHtcbiAgICBsZXQgY29udHJvbGxlcjtcbiAgICBjb25zdCBsaXZlU2V0ID0gbmV3IExpdmVTZXQoe1xuICAgICAgcmVhZDogKCkgPT4gbmV3IFNldCgpLFxuICAgICAgbGlzdGVuOiBfY29udHJvbGxlciA9PiB7XG4gICAgICAgIGNvbnRyb2xsZXIgPSBfY29udHJvbGxlcjtcbiAgICAgIH1cbiAgICB9KTtcbiAgICBsaXZlU2V0LnN1YnNjcmliZSh7fSk7IC8vIGZvcmNlIGFjdGl2YXRpb25cbiAgICBpZiAoIWNvbnRyb2xsZXIpIHRocm93IG5ldyBFcnJvcigpO1xuICAgIHJldHVybiB7bGl2ZVNldCwgY29udHJvbGxlcn07XG4gIH1cblxuICBnZXRWYWx1ZSgpOiBUIHtcbiAgICByZXR1cm4gdGhpcy5faW5pdC52YWx1ZTtcbiAgfVxuXG4gIGdldFBhcmVudCgpOiBudWxsfFRhZ1RyZWVOb2RlPFQ+IHtcbiAgICByZXR1cm4gdGhpcy5faW5pdC5wYXJlbnQgfHwgbnVsbDtcbiAgfVxuXG4gIGdldE93bmVkQnlUYWcodGFnOiBzdHJpbmcpOiBMaXZlU2V0PFRhZ1RyZWVOb2RlPFQ+PiB7XG4gICAgbGV0IGVudHJ5ID0gdGhpcy5fb3duZWRCeVRhZy5nZXQodGFnKTtcbiAgICBpZiAoIWVudHJ5KSB7XG4gICAgICBpZiAoIXRoaXMuX2luaXQub3duZWRUYWdzLmhhcyh0YWcpKSB7XG4gICAgICAgIHRocm93IG5ldyBFcnJvcihgdGFnIG5vdCBvd25lZDogJHt0YWd9YCk7XG4gICAgICB9XG4gICAgICBlbnRyeSA9IHRoaXMuX2NyZWF0ZVRhZ0VudHJ5KCk7XG4gICAgICB0aGlzLl9vd25lZEJ5VGFnLnNldCh0YWcsIGVudHJ5KTtcbiAgICB9XG4gICAgcmV0dXJuIGVudHJ5LmxpdmVTZXQ7XG4gIH1cblxuICBnZXRPd25lZCgpOiBNYXA8c3RyaW5nLCBMaXZlU2V0PFRhZ1RyZWVOb2RlPFQ+Pj4ge1xuICAgIGNvbnN0IG0gPSBuZXcgTWFwKCk7XG4gICAgdGhpcy5fb3duZWRCeVRhZy5mb3JFYWNoKCh7bGl2ZVNldH0sIHRhZykgPT4ge1xuICAgICAgbS5zZXQodGFnLCBsaXZlU2V0KTtcbiAgICB9KTtcbiAgICByZXR1cm4gbTtcbiAgfVxuXG4gIGdldFRhZygpOiBudWxsfHN0cmluZyB7XG4gICAgY29uc3Qge3BhcmVudH0gPSB0aGlzLl9pbml0O1xuICAgIHJldHVybiBwYXJlbnQgPyBwYXJlbnQuZ2V0VGFnT2ZPd25lZE5vZGUodGhpcykgOiBudWxsO1xuICB9XG5cbiAgZ2V0VGFnT2ZPd25lZE5vZGUobm9kZTogVGFnVHJlZU5vZGU8VD4pOiBzdHJpbmcge1xuICAgIGNvbnN0IHRhZyA9IHRoaXMuX293bmVkTm9kZXMuZ2V0KG5vZGUpO1xuICAgIGlmICh0YWcgPT0gbnVsbCkgdGhyb3cgbmV3IEVycm9yKCdub2RlIG5vdCBvd25lZCcpO1xuICAgIHJldHVybiB0YWc7XG4gIH1cbn1cbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9UYWdUcmVlTm9kZS5qcyJdLCJuYW1lcyI6WyJUYWdUcmVlTm9kZSIsImluaXQiLCJfb3duZWROb2RlcyIsIl9vd25lZEJ5VGFnIiwiX2luaXQiLCJleGVjdXRvciIsImFkZE93bmVkTm9kZSIsInRhZyIsIm5vZGUiLCJzZXQiLCJlbnRyeSIsImdldCIsIl9jcmVhdGVUYWdFbnRyeSIsImNvbnRyb2xsZXIiLCJhZGQiLCJyZW1vdmVPd25lZE5vZGUiLCJkZWxldGUiLCJFcnJvciIsInJlbW92ZSIsImVuZCIsImZvckVhY2giLCJhY3RpdmUiLCJ2YWx1ZSIsInBhcmVudCIsIm93bmVkVGFncyIsImhhcyIsImxpdmVTZXQiLCJtIiwiZ2V0VGFnT2ZPd25lZE5vZGUiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUVBOzs7Ozs7SUFxQnFCQSxXO0FBS25CLHVCQUFZQyxJQUFaLEVBQXNDO0FBQUE7O0FBQUE7QUFBQSxTQUh0Q0MsV0FHc0MsR0FISyxtQkFHTDtBQUFBLFNBRnRDQyxXQUVzQyxHQUZFLG1CQUVGOztBQUNwQyxTQUFLQyxLQUFMLEdBQWFILElBQWI7QUFDQSxTQUFLRyxLQUFMLENBQVdDLFFBQVgsQ0FBb0I7QUFDbEJDLG9CQUFjLHNCQUFDQyxHQUFELEVBQU1DLElBQU4sRUFBZTtBQUMzQixjQUFLTixXQUFMLENBQWlCTyxHQUFqQixDQUFxQkQsSUFBckIsRUFBMkJELEdBQTNCO0FBQ0EsWUFBSUcsUUFBUSxNQUFLUCxXQUFMLENBQWlCUSxHQUFqQixDQUFxQkosR0FBckIsQ0FBWjtBQUNBLFlBQUksQ0FBQ0csS0FBTCxFQUFZO0FBQ1ZBLGtCQUFRLE1BQUtFLGVBQUwsRUFBUjtBQUNBLGdCQUFLVCxXQUFMLENBQWlCTSxHQUFqQixDQUFxQkYsR0FBckIsRUFBMEJHLEtBQTFCO0FBQ0Q7QUFOMEIscUJBT05BLEtBUE07QUFBQSxZQU9wQkcsVUFQb0IsVUFPcEJBLFVBUG9COztBQVEzQkEsbUJBQVdDLEdBQVgsQ0FBZU4sSUFBZjtBQUNELE9BVmlCO0FBV2xCTyx1QkFBaUIseUJBQUNSLEdBQUQsRUFBTUMsSUFBTixFQUFlO0FBQzlCLGNBQUtOLFdBQUwsQ0FBaUJjLE1BQWpCLENBQXdCUixJQUF4QjtBQUNBLFlBQU1FLFFBQVEsTUFBS1AsV0FBTCxDQUFpQlEsR0FBakIsQ0FBcUJKLEdBQXJCLENBQWQ7QUFDQSxZQUFJLENBQUNHLEtBQUwsRUFBWSxNQUFNLElBQUlPLEtBQUosQ0FBVSxlQUFWLENBQU47QUFIa0IsWUFJdkJKLFVBSnVCLEdBSVRILEtBSlMsQ0FJdkJHLFVBSnVCOztBQUs5QkEsbUJBQVdLLE1BQVgsQ0FBa0JWLElBQWxCO0FBQ0QsT0FqQmlCO0FBa0JsQlcsV0FBSyxlQUFNO0FBQ1QsY0FBS2hCLFdBQUwsQ0FBaUJpQixPQUFqQixDQUF5QixnQkFBa0I7QUFBQSxjQUFoQlAsVUFBZ0IsUUFBaEJBLFVBQWdCOztBQUN6Q0EscUJBQVdNLEdBQVg7QUFDRCxTQUZEO0FBR0Q7QUF0QmlCLEtBQXBCO0FBd0JBLFNBQUtmLEtBQUwsQ0FBV0MsUUFBWCxHQUFzQixZQUFNLENBQUUsQ0FBOUIsQ0ExQm9DLENBMEJKO0FBQ2pDOzs7O3NDQUU4QjtBQUM3QixhQUFPLGtCQUFRZ0IsTUFBUixFQUFQO0FBQ0Q7OzsrQkFFYTtBQUNaLGFBQU8sS0FBS2pCLEtBQUwsQ0FBV2tCLEtBQWxCO0FBQ0Q7OztnQ0FFZ0M7QUFDL0IsYUFBTyxLQUFLbEIsS0FBTCxDQUFXbUIsTUFBWCxJQUFxQixJQUE1QjtBQUNEOzs7a0NBRWFoQixHLEVBQXNDO0FBQ2xELFVBQUlHLFFBQVEsS0FBS1AsV0FBTCxDQUFpQlEsR0FBakIsQ0FBcUJKLEdBQXJCLENBQVo7QUFDQSxVQUFJLENBQUNHLEtBQUwsRUFBWTtBQUNWLFlBQUksQ0FBQyxLQUFLTixLQUFMLENBQVdvQixTQUFYLENBQXFCQyxHQUFyQixDQUF5QmxCLEdBQXpCLENBQUwsRUFBb0M7QUFDbEMsZ0JBQU0sSUFBSVUsS0FBSixxQkFBNEJWLEdBQTVCLENBQU47QUFDRDtBQUNERyxnQkFBUSxLQUFLRSxlQUFMLEVBQVI7QUFDQSxhQUFLVCxXQUFMLENBQWlCTSxHQUFqQixDQUFxQkYsR0FBckIsRUFBMEJHLEtBQTFCO0FBQ0Q7QUFDRCxhQUFPQSxNQUFNZ0IsT0FBYjtBQUNEOzs7K0JBRWdEO0FBQy9DLFVBQU1DLElBQUksbUJBQVY7QUFDQSxXQUFLeEIsV0FBTCxDQUFpQmlCLE9BQWpCLENBQXlCLGlCQUFZYixHQUFaLEVBQW9CO0FBQUEsWUFBbEJtQixPQUFrQixTQUFsQkEsT0FBa0I7O0FBQzNDQyxVQUFFbEIsR0FBRixDQUFNRixHQUFOLEVBQVdtQixPQUFYO0FBQ0QsT0FGRDtBQUdBLGFBQU9DLENBQVA7QUFDRDs7OzZCQUVxQjtBQUFBLFVBQ2JKLE1BRGEsR0FDSCxLQUFLbkIsS0FERixDQUNibUIsTUFEYTs7QUFFcEIsYUFBT0EsU0FBU0EsT0FBT0ssaUJBQVAsQ0FBeUIsSUFBekIsQ0FBVCxHQUEwQyxJQUFqRDtBQUNEOzs7c0NBRWlCcEIsSSxFQUE4QjtBQUM5QyxVQUFNRCxNQUFNLEtBQUtMLFdBQUwsQ0FBaUJTLEdBQWpCLENBQXFCSCxJQUFyQixDQUFaO0FBQ0EsVUFBSUQsT0FBTyxJQUFYLEVBQWlCLE1BQU0sSUFBSVUsS0FBSixDQUFVLGdCQUFWLENBQU47QUFDakIsYUFBT1YsR0FBUDtBQUNEOzs7OztrQkEzRWtCUCxXIiwiZmlsZSI6IlRhZ1RyZWVOb2RlLmpzIiwic291cmNlc0NvbnRlbnQiOlsiLyogQGZsb3cgKi9cblxuaW1wb3J0IExpdmVTZXQgZnJvbSAnbGl2ZS1zZXQnO1xuaW1wb3J0IHR5cGUge0xpdmVTZXRDb250cm9sbGVyfSBmcm9tICdsaXZlLXNldCc7XG5cbmV4cG9ydCB0eXBlIFRhZ1RyZWVOb2RlQ29udHJvbGxlcjxUPiA9IHtcbiAgYWRkT3duZWROb2RlKHRhZzogc3RyaW5nLCBub2RlOiBUYWdUcmVlTm9kZTxUPik6IHZvaWQ7XG4gIHJlbW92ZU93bmVkTm9kZSh0YWc6IHN0cmluZywgbm9kZTogVGFnVHJlZU5vZGU8VD4pOiB2b2lkO1xuICBlbmQoKTogdm9pZDtcbn07XG5cbmV4cG9ydCB0eXBlIFRhZ1RyZWVOb2RlSW5pdDxUPiA9IHt8XG4gIHZhbHVlOiBUO1xuICBwYXJlbnQ6ID9UYWdUcmVlTm9kZTxUPjtcbiAgb3duZWRUYWdzOiBTZXQ8c3RyaW5nPjtcbiAgZXhlY3V0b3I6IChjb250cm9sbGVyOiBUYWdUcmVlTm9kZUNvbnRyb2xsZXI8VD4pID0+IHZvaWQ7XG58fTtcblxudHlwZSBUYWdFbnRyeTxUPiA9IHtcbiAgbGl2ZVNldDogTGl2ZVNldDxUYWdUcmVlTm9kZTxUPj47XG4gIGNvbnRyb2xsZXI6IExpdmVTZXRDb250cm9sbGVyPFRhZ1RyZWVOb2RlPFQ+Pjtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIFRhZ1RyZWVOb2RlPFQ+IHtcbiAgX2luaXQ6IFRhZ1RyZWVOb2RlSW5pdDxUPjtcbiAgX293bmVkTm9kZXM6IE1hcDxUYWdUcmVlTm9kZTxUPiwgc3RyaW5nPiA9IG5ldyBNYXAoKTtcbiAgX293bmVkQnlUYWc6IE1hcDxzdHJpbmcsIFRhZ0VudHJ5PFQ+PiA9IG5ldyBNYXAoKTtcblxuICBjb25zdHJ1Y3Rvcihpbml0OiBUYWdUcmVlTm9kZUluaXQ8VD4pIHtcbiAgICB0aGlzLl9pbml0ID0gaW5pdDtcbiAgICB0aGlzLl9pbml0LmV4ZWN1dG9yKHtcbiAgICAgIGFkZE93bmVkTm9kZTogKHRhZywgbm9kZSkgPT4ge1xuICAgICAgICB0aGlzLl9vd25lZE5vZGVzLnNldChub2RlLCB0YWcpO1xuICAgICAgICBsZXQgZW50cnkgPSB0aGlzLl9vd25lZEJ5VGFnLmdldCh0YWcpO1xuICAgICAgICBpZiAoIWVudHJ5KSB7XG4gICAgICAgICAgZW50cnkgPSB0aGlzLl9jcmVhdGVUYWdFbnRyeSgpO1xuICAgICAgICAgIHRoaXMuX293bmVkQnlUYWcuc2V0KHRhZywgZW50cnkpO1xuICAgICAgICB9XG4gICAgICAgIGNvbnN0IHtjb250cm9sbGVyfSA9IGVudHJ5O1xuICAgICAgICBjb250cm9sbGVyLmFkZChub2RlKTtcbiAgICAgIH0sXG4gICAgICByZW1vdmVPd25lZE5vZGU6ICh0YWcsIG5vZGUpID0+IHtcbiAgICAgICAgdGhpcy5fb3duZWROb2Rlcy5kZWxldGUobm9kZSk7XG4gICAgICAgIGNvbnN0IGVudHJ5ID0gdGhpcy5fb3duZWRCeVRhZy5nZXQodGFnKTtcbiAgICAgICAgaWYgKCFlbnRyeSkgdGhyb3cgbmV3IEVycm9yKCd0YWcgbm90IG93bmVkJyk7XG4gICAgICAgIGNvbnN0IHtjb250cm9sbGVyfSA9IGVudHJ5O1xuICAgICAgICBjb250cm9sbGVyLnJlbW92ZShub2RlKTtcbiAgICAgIH0sXG4gICAgICBlbmQ6ICgpID0+IHtcbiAgICAgICAgdGhpcy5fb3duZWRCeVRhZy5mb3JFYWNoKCh7Y29udHJvbGxlcn0pID0+IHtcbiAgICAgICAgICBjb250cm9sbGVyLmVuZCgpO1xuICAgICAgICB9KTtcbiAgICAgIH1cbiAgICB9KTtcbiAgICB0aGlzLl9pbml0LmV4ZWN1dG9yID0gKCkgPT4ge307IC8vIHJlbGVhc2UgcmVmZXJlbmNlXG4gIH1cblxuICBfY3JlYXRlVGFnRW50cnkoKTogVGFnRW50cnk8VD4ge1xuICAgIHJldHVybiBMaXZlU2V0LmFjdGl2ZSgpO1xuICB9XG5cbiAgZ2V0VmFsdWUoKTogVCB7XG4gICAgcmV0dXJuIHRoaXMuX2luaXQudmFsdWU7XG4gIH1cblxuICBnZXRQYXJlbnQoKTogbnVsbHxUYWdUcmVlTm9kZTxUPiB7XG4gICAgcmV0dXJuIHRoaXMuX2luaXQucGFyZW50IHx8IG51bGw7XG4gIH1cblxuICBnZXRPd25lZEJ5VGFnKHRhZzogc3RyaW5nKTogTGl2ZVNldDxUYWdUcmVlTm9kZTxUPj4ge1xuICAgIGxldCBlbnRyeSA9IHRoaXMuX293bmVkQnlUYWcuZ2V0KHRhZyk7XG4gICAgaWYgKCFlbnRyeSkge1xuICAgICAgaWYgKCF0aGlzLl9pbml0Lm93bmVkVGFncy5oYXModGFnKSkge1xuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoYHRhZyBub3Qgb3duZWQ6ICR7dGFnfWApO1xuICAgICAgfVxuICAgICAgZW50cnkgPSB0aGlzLl9jcmVhdGVUYWdFbnRyeSgpO1xuICAgICAgdGhpcy5fb3duZWRCeVRhZy5zZXQodGFnLCBlbnRyeSk7XG4gICAgfVxuICAgIHJldHVybiBlbnRyeS5saXZlU2V0O1xuICB9XG5cbiAgZ2V0T3duZWQoKTogTWFwPHN0cmluZywgTGl2ZVNldDxUYWdUcmVlTm9kZTxUPj4+IHtcbiAgICBjb25zdCBtID0gbmV3IE1hcCgpO1xuICAgIHRoaXMuX293bmVkQnlUYWcuZm9yRWFjaCgoe2xpdmVTZXR9LCB0YWcpID0+IHtcbiAgICAgIG0uc2V0KHRhZywgbGl2ZVNldCk7XG4gICAgfSk7XG4gICAgcmV0dXJuIG07XG4gIH1cblxuICBnZXRUYWcoKTogbnVsbHxzdHJpbmcge1xuICAgIGNvbnN0IHtwYXJlbnR9ID0gdGhpcy5faW5pdDtcbiAgICByZXR1cm4gcGFyZW50ID8gcGFyZW50LmdldFRhZ09mT3duZWROb2RlKHRoaXMpIDogbnVsbDtcbiAgfVxuXG4gIGdldFRhZ09mT3duZWROb2RlKG5vZGU6IFRhZ1RyZWVOb2RlPFQ+KTogc3RyaW5nIHtcbiAgICBjb25zdCB0YWcgPSB0aGlzLl9vd25lZE5vZGVzLmdldChub2RlKTtcbiAgICBpZiAodGFnID09IG51bGwpIHRocm93IG5ldyBFcnJvcignbm9kZSBub3Qgb3duZWQnKTtcbiAgICByZXR1cm4gdGFnO1xuICB9XG59XG4iXX0= |
{ | ||
"name": "tag-tree", | ||
"version": "0.1.1", | ||
"version": "0.1.2", | ||
"description": "Class representing a changing tree of tagged items.", | ||
@@ -21,3 +21,3 @@ "main": "js/index.js", | ||
"babel-runtime": "^6.22.0", | ||
"live-set": "^0.1.0" | ||
"live-set": "^0.2.0" | ||
}, | ||
@@ -24,0 +24,0 @@ "devDependencies": { |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
40060
275
+ Addedlive-set@0.2.1(transitive)
+ Addedzen-observable@0.4.0(transitive)
- Removedlive-set@0.1.3(transitive)
Updatedlive-set@^0.2.0