25 lines
605 B
JavaScript
25 lines
605 B
JavaScript
|
import { addUniqueItem, removeItem } from '../../utils/array.mjs';
|
||
|
import { compareByDepth } from './compare-by-depth.mjs';
|
||
|
|
||
|
class FlatTree {
|
||
|
constructor() {
|
||
|
this.children = [];
|
||
|
this.isDirty = false;
|
||
|
}
|
||
|
add(child) {
|
||
|
addUniqueItem(this.children, child);
|
||
|
this.isDirty = true;
|
||
|
}
|
||
|
remove(child) {
|
||
|
removeItem(this.children, child);
|
||
|
this.isDirty = true;
|
||
|
}
|
||
|
forEach(callback) {
|
||
|
this.isDirty && this.children.sort(compareByDepth);
|
||
|
this.isDirty = false;
|
||
|
this.children.forEach(callback);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
export { FlatTree };
|