diff options
| author | Terry Truong <terry06890@gmail.com> | 2022-10-18 00:42:33 +1100 |
|---|---|---|
| committer | Terry Truong <terry06890@gmail.com> | 2022-10-18 00:42:33 +1100 |
| commit | 15035fe65e7dd54db83337da3d2b055d8bb668e9 (patch) | |
| tree | 71f6bee28d0709faaca0a6ea9ba45e68f88b92a0 /src/App.vue | |
| parent | 78ab026ffacbfd14992c2bfda1b9e290ace25cbf (diff) | |
Use RBTree to store events, and lookup by date range
Currently produces TypeErrors from rbtree.ts's single_rotate() saying
'save is null'. This also happens when using minimally-adapted rbtree.js.
Not sure how to resolve this.
Diffstat (limited to 'src/App.vue')
| -rw-r--r-- | src/App.vue | 12 |
1 files changed, 6 insertions, 6 deletions
diff --git a/src/App.vue b/src/App.vue index 9ac8e3f..abbe2b4 100644 --- a/src/App.vue +++ b/src/App.vue @@ -19,7 +19,7 @@ <div class="grow min-h-0 flex" :class="{'flex-col': !vert}" :style="{backgroundColor: store.color.bg}" ref="contentAreaRef"> <time-line v-for="(state, idx) in timelines" :key="state.id" - :vert="vert" :initialState="state" :eventMap="eventMap" + :vert="vert" :initialState="state" :eventTree="eventTree" class="grow basis-full min-h-0 outline outline-1" @remove="onTimelineRemove(idx)" @state-chg="onTimelineChg($event, idx)" @event-req="onEventReq"/> <base-line :vert="vert" :timelines="timelines"/> @@ -38,8 +38,9 @@ import PlusIcon from './components/icon/PlusIcon.vue'; import SettingsIcon from './components/icon/SettingsIcon.vue'; import HelpIcon from './components/icon/HelpIcon.vue'; // Other -import {HistDate, TimelineState, HistEvent, queryServer, HistEventJson, jsonToHistEvent} from './lib'; +import {HistDate, TimelineState, HistEvent, queryServer, HistEventJson, jsonToHistEvent, cmpHistEvent} from './lib'; import {useStore} from './store'; +import {RBTree} from './rbtree'; // Refs const contentAreaRef = ref(null as HTMLElement | null); @@ -99,7 +100,7 @@ function onTimelineRemove(idx: number){ } // Event data -const eventMap: Ref<Map<number, HistEvent>> = ref(new Map()); // Maps event IDs to HistEvents +const eventTree: Ref<RBTree<HistEvent>> = ref(new RBTree(cmpHistEvent)); // Used to look up events by date range async function onEventReq(startDate: HistDate, endDate: HistDate){ // Get events from server let urlParams = new URLSearchParams({type: 'events', range: `${startDate}.${endDate}`, limit: '10'}); @@ -109,9 +110,8 @@ async function onEventReq(startDate: HistDate, endDate: HistDate){ } // Add to map for (let eventObj of responseObj){ - if (!eventMap.value.has(eventObj.id)){ - eventMap.value.set(eventObj.id, jsonToHistEvent(eventObj)); - } + let event = jsonToHistEvent(eventObj); + eventTree.value.insert(event); } } |
