From 39d5c9c0074ae506afd8884157964b3e82ae254a Mon Sep 17 00:00:00 2001 From: Jim O'Donnell Date: Sun, 18 Feb 2024 15:21:59 +0000 Subject: [PATCH] Use annotation.value in classification snapshots Use `annotation.value` to generate mark snapshots for `annotation.toSnapshot()`. --- .../tasks/drawing/models/DrawingAnnotation.js | 28 +++++++++---------- .../models/TranscriptionAnnotation.js | 28 +++++++++---------- 2 files changed, 28 insertions(+), 28 deletions(-) diff --git a/packages/lib-classifier/src/plugins/tasks/drawing/models/DrawingAnnotation.js b/packages/lib-classifier/src/plugins/tasks/drawing/models/DrawingAnnotation.js index 95434af1ebf..3a3bcdc4ada 100644 --- a/packages/lib-classifier/src/plugins/tasks/drawing/models/DrawingAnnotation.js +++ b/packages/lib-classifier/src/plugins/tasks/drawing/models/DrawingAnnotation.js @@ -21,24 +21,24 @@ const Drawing = types.model('Drawing', { toSnapshot() { const snapshot = getSnapshot(self) - // resolve mark references (IDs) in the snapshot to mark snapshots - 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 + // Replace mark references (IDs) with mark snapshots. + const markSnapshots = self.value.map(mark => getSnapshot(mark)) + const drawingSnapshot = { ...snapshot, value: markSnapshots } + // Flatten subtask annotations into a single annotations array + // then return the flattened array. const drawingAnnotations = [drawingSnapshot] - drawingSnapshot.value.forEach((markSnapshot, markIndex) => { - const mark = Object.assign({}, markSnapshot) - // map subtask keys to mark.details + markSnapshots.forEach((markSnapshot, markIndex) => { + const mark = { ...markSnapshot } + // Map subtask keys to mark.details. mark.details = mark.annotations.map(annotation => ({ task: annotation.task })) - // push mark.annotations to the returned array + // Push mark.annotations to the returned array. mark.annotations.forEach(markAnnotation => { - const finalAnnotation = Object.assign({}, markAnnotation, { markIndex }) - // strip annotation IDs - const { id, ...rest } = finalAnnotation - drawingAnnotations.push(rest) + // Strip annotation IDs and add markIndex. + const { id, ...rest } = markAnnotation + const finalAnnotation = { ...rest, markIndex } + drawingAnnotations.push(finalAnnotation) }) - // remove annotations from individual marks + // Remove annotations from individual marks. const { annotations, ...rest } = mark drawingSnapshot.value[markIndex] = rest }) diff --git a/packages/lib-classifier/src/plugins/tasks/experimental/transcription/models/TranscriptionAnnotation.js b/packages/lib-classifier/src/plugins/tasks/experimental/transcription/models/TranscriptionAnnotation.js index 012c2e83a34..ef98af4473e 100644 --- a/packages/lib-classifier/src/plugins/tasks/experimental/transcription/models/TranscriptionAnnotation.js +++ b/packages/lib-classifier/src/plugins/tasks/experimental/transcription/models/TranscriptionAnnotation.js @@ -20,24 +20,24 @@ const Transcription = types.model('Transcription', { // Changing the task type to TranscriptionTask toSnapshot() { const snapshot = getSnapshot(self) - // resolve mark references (IDs) in the snapshot to mark snapshots - 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 + // Replace mark references (IDs) with mark snapshots. + const markSnapshots = self.value.map(mark => getSnapshot(mark)) + const drawingSnapshot = { ...snapshot, value: markSnapshots } + // Flatten subtask annotations into a single annotations array + // then return the flattened array. const drawingAnnotations = [drawingSnapshot] - drawingSnapshot.value.forEach((markSnapshot, markIndex) => { - const mark = Object.assign({}, markSnapshot) - // map subtask keys to mark.details + markSnapshots.forEach((markSnapshot, markIndex) => { + const mark = { ...markSnapshot } + // Map subtask keys to mark.details. mark.details = mark.annotations.map(annotation => ({ task: annotation.task })) - // push mark.annotations to the returned array + // Push mark.annotations to the returned array. mark.annotations.forEach(markAnnotation => { - const finalAnnotation = Object.assign({}, markAnnotation, { markIndex }) - // strip annotation IDs - const { id, ...rest } = finalAnnotation - drawingAnnotations.push(rest) + // Strip annotation IDs and add markIndex. + const { id, ...rest } = markAnnotation + const finalAnnotation = { ...rest, markIndex } + drawingAnnotations.push(finalAnnotation) }) - // remove annotations from individual marks + // Remove annotations from individual marks. const { annotations, ...rest } = mark drawingSnapshot.value[markIndex] = rest })