Skip to content

Commit

Permalink
refactor: automatically sync drawing annotations
Browse files Browse the repository at this point in the history
- Add an `annotation.actualTask` view to drawing tasks and transcription tasks.
- Add an `autorun` listener which observes `self.actualTask.marks`  for changes, and updates the annotation value.
- Remove the manual `annotation.update(newValue)` when a new mark is drawn.

This might be a more robust fix for problems where the classification is not updated properly after a change to a drawing tool. It should keep drawing annotations in sync with their corresponding drawing tools.
  • Loading branch information
eatyourgreens committed May 19, 2024
1 parent 8ca1cb2 commit 43c0205
Show file tree
Hide file tree
Showing 3 changed files with 41 additions and 9 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -105,8 +105,6 @@ function InteractionLayer({
mark.setSubTaskVisibility(false)
// Add a time value for tools that care about time. For most tools, this value is ignored.
mark.setVideoTime(timeStamp, duration)
const markIDs = annotation.value?.map((mark) => mark.id)
annotation.update([...markIDs, mark.id])
}

function onPointerDown(event) {
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import { getRoot, getSnapshot, resolveIdentifier, types } from 'mobx-state-tree'
import { autorun } from 'mobx'
import { addDisposer, getRoot, getSnapshot, resolveIdentifier, types } from 'mobx-state-tree'
import DrawingTask from './DrawingTask'
import Annotation from '../../models/Annotation'
import * as markTypes from '@plugins/drawingTools/models/marks'
Expand All @@ -11,11 +12,17 @@ const Drawing = types.model('Drawing', {
value: types.array(types.safeReference(GenericMark))
})
.views(self => ({
toSnapshot () {
/**
Resolve `annotation.task`, which is a task key, to its corresponding task object.
*/
get actualTask() {
return resolveIdentifier(DrawingTask, getRoot(self), self.task)
},

toSnapshot() {
const snapshot = getSnapshot(self)
// resolve mark references (IDs) in the snapshot to mark snapshots
const actualTask = resolveIdentifier(DrawingTask, getRoot(self), self.task)
const value = actualTask.marks.map(mark => getSnapshot(mark))
const value = self.actualTask.marks.map(mark => getSnapshot(mark))
const drawingSnapshot = Object.assign({}, snapshot, { value })
// flatten subtask annotations into a single annotations array
// then return the flattened array
Expand All @@ -38,6 +45,16 @@ const Drawing = types.model('Drawing', {
return drawingAnnotations
}
}))
.actions(self => ({
afterAttach() {
function _onMarksChange() {
const newAnnotation = self.actualTask.marks.map(mark => mark.id)
self.update(newAnnotation)
}

addDisposer(self, autorun(_onMarksChange))
}
}))

const DrawingAnnotation = types.compose('DrawingAnnotation', Annotation, Drawing)

Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import { getRoot, getSnapshot, resolveIdentifier, types } from 'mobx-state-tree'
import { autorun } from 'mobx'
import { addDisposer, getRoot, getSnapshot, resolveIdentifier, types } from 'mobx-state-tree'
import TranscriptionTask from './TranscriptionTask'
import { TranscriptionLine } from '@plugins/drawingTools/models/marks'
import Annotation from '../../../models/Annotation'
Expand All @@ -8,13 +9,19 @@ const Transcription = types.model('Transcription', {
value: types.array(types.safeReference(TranscriptionLine))
})
.views(self => ({
/**
Resolve `annotation.task`, which is a task key, to its corresponding task object.
*/
get actualTask() {
return resolveIdentifier(TranscriptionTask, getRoot(self), self.task)
},

// This is a copy of DrawingAnnotation's toSnapshot with the exception of
// Changing the task type to TranscriptionTask
toSnapshot() {
const snapshot = getSnapshot(self)
// resolve mark references (IDs) in the snapshot to mark snapshots
const actualTask = resolveIdentifier(TranscriptionTask, getRoot(self), self.task)
const value = actualTask.marks.map(mark => getSnapshot(mark))
const value = self.actualTask.marks.map(mark => getSnapshot(mark))
const drawingSnapshot = Object.assign({}, snapshot, { value })
// flatten subtask annotations into a single annotations array
// then return the flattened array
Expand All @@ -37,6 +44,16 @@ const Transcription = types.model('Transcription', {
return drawingAnnotations
}
}))
.actions(self => ({
afterAttach() {
function _onMarksChange() {
const newAnnotation = self.actualTask.marks.map(mark => mark.id)
self.update(newAnnotation)
}

addDisposer(self, autorun(_onMarksChange))
}
}))

const TranscriptionAnnotation = types.compose('TranscriptionAnnotation', Annotation, Transcription)

Expand Down

0 comments on commit 43c0205

Please sign in to comment.