forked from mystiq/hydrogen-web
finished observable SortedArray to something useable
although not as performant as it could be
This commit is contained in:
parent
f8fbfbff9a
commit
843c94b750
2 changed files with 21 additions and 8 deletions
|
@ -4,6 +4,7 @@ import MappedMap from "./map/MappedMap.js";
|
||||||
import BaseObservableMap from "./map/BaseObservableMap.js";
|
import BaseObservableMap from "./map/BaseObservableMap.js";
|
||||||
// re-export "root" (of chain) collections
|
// re-export "root" (of chain) collections
|
||||||
export { default as ObservableArray } from "./list/ObservableArray.js";
|
export { default as ObservableArray } from "./list/ObservableArray.js";
|
||||||
|
export { default as SortedArray } from "./list/SortedArray.js";
|
||||||
export { default as ObservableMap } from "./map/ObservableMap.js";
|
export { default as ObservableMap } from "./map/ObservableMap.js";
|
||||||
|
|
||||||
// avoid circular dependency between these classes
|
// avoid circular dependency between these classes
|
||||||
|
|
|
@ -8,22 +8,34 @@ export default class SortedArray extends BaseObservableList {
|
||||||
this._items = [];
|
this._items = [];
|
||||||
}
|
}
|
||||||
|
|
||||||
setSortedMany(items) {
|
setManySorted(items) {
|
||||||
|
// TODO: we can make this way faster by only looking up the first and last key,
|
||||||
|
// and merging whatever is inbetween with items
|
||||||
|
// if items is not sorted, 💩🌀 will follow!
|
||||||
|
// should we check?
|
||||||
|
// Also, once bulk events are supported in collections,
|
||||||
|
// we can do a bulk add event here probably if there are no updates
|
||||||
|
// BAD CODE!
|
||||||
|
for(let item of items) {
|
||||||
|
this.set(item);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
set(item) {
|
set(item, updateParams = null) {
|
||||||
const idx = sortedIndex(this._items, item, this._comparator);
|
const idx = sortedIndex(this._items, item, this._comparator);
|
||||||
if (idx < this._items.length || this._comparator(this._items[idx], item) !== 0) {
|
if (idx >= this._items.length || this._comparator(this._items[idx], item) !== 0) {
|
||||||
this._items.splice(idx, 0, item);
|
this._items.splice(idx, 0, item);
|
||||||
//emitAdd
|
this.emitAdd(idx, item)
|
||||||
} else {
|
} else {
|
||||||
this._items[idx] = item;
|
this._items[idx] = item;
|
||||||
//emitRemove
|
this.emitUpdate(idx, item, updateParams);
|
||||||
//emitAdd
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
remove(item) {
|
||||||
|
throw new Error("unimplemented");
|
||||||
|
}
|
||||||
|
|
||||||
get array() {
|
get array() {
|
||||||
return this._items;
|
return this._items;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue