Skip to content

Migrate the elements and annotation stores to Pinia

Erwan Rouchet requested to merge pinia-elements into release-1.7.0

Closes #1137 (closed), #1142 (closed)

  • useElementsStore is renamed to useElementStore to conform to Pinia's store naming style, which encourages singular nouns.
  • TypeScript has been upgraded, as the newer versions understood some new typing edge cases that I was hitting while migrating, and could detect more errors.
  • Some API helpers have been simplified.
  • Incorrect types in the MetaData APIs and Pinia store have been fixed.
  • The metadata components under src/components/Element/MetaData/ have been rewritten to simplify them and avoid a large amount of typing troubles.

Components

Element

  • Corpus/Datasets/Populate.vue: ...mapVuexState('elements', ['elements']),
  • Element/DetailsPanel.vue: ...mapVuexState('elements', ['elements']),
  • Element/ElementHeader.vue: ...mapVuexState('elements', {
  • Element/Metadata/Metadata.vue: ...mapVuexState('elements', ['elements']),
  • Element/OrientationPanel.vue: ...mapState('elements', ['elements']),
  • HeaderActions.vue: ...mapVuexState('elements', [
  • Navigation/ChildrenTree/TreeItem.vue: ...mapState('elements', ['childrenPagination', 'parents']),
  • Navigation/CorpusSelection.vue: ...mapVuexState('elements', { storeElements: 'elements' }),
  • Navigation/ElementNavigation.vue: ...mapVuexState('elements', { elementObjects: 'elements' }),
  • Navigation/ElementNavigation.vue: ...mapVuexState('elements', ['elementsUpdate']),
  • Navigation/PreviewDropdown.vue: ...mapState('elements', ['elements']),
  • Process/Workers/DeleteResultsModal.vue: ...mapVuexState('elements', ['elements']),
  • Element/EditionFrom.vue

Annotations

  • Image/ElementZone.vue: ...mapState('annotation', ['enabled', 'hoveredId', 'selectedElement', 'batchDeletion']),
  • Navigation/ChildrenTree/TreeItem.vue: ...mapState('annotation', {
  • Navigation/ChildrenTree/TreeItem.vue: ...mapState('annotation', ['visible', 'hoveredId', 'selectedElement']),

Views

  • Element.vue: ...mapVuexState('elements', ['elements', 'links', 'parents', 'neighbors']),
Edited by Bastien Abadie

Merge request reports

Loading