From 4e5ba2a8f544e353cdce7c1e2c2cb9e07f935384 Mon Sep 17 00:00:00 2001 From: Chris Jordan Date: Wed, 2 Oct 2024 12:13:29 -0400 Subject: [PATCH] displaying annotation tags in annotation list --- src/ui/annotations.css | 2 +- src/ui/annotations.ts | 20 ++++++++++++++++++++ 2 files changed, 21 insertions(+), 1 deletion(-) diff --git a/src/ui/annotations.css b/src/ui/annotations.css index da60e397d..3e2b22a44 100644 --- a/src/ui/annotations.css +++ b/src/ui/annotations.css @@ -61,7 +61,7 @@ padding-right: 5px; } -.neuroglancer-annotation-description { +.neuroglancer-annotation-description, .neuroglancer-annotation-tags { grid-column: dim / -1; text-overflow: ellipsis; overflow: hidden; diff --git a/src/ui/annotations.ts b/src/ui/annotations.ts index a0b56c109..1b3f45400 100644 --- a/src/ui/annotations.ts +++ b/src/ui/annotations.ts @@ -2253,6 +2253,26 @@ export function makeAnnotationListElement( description.textContent = annotation.description; element.appendChild(description); } + const { + properties: { value: properties }, + } = state.source; + const activeTags: string[] = []; + for (let i = 0, count = properties.length; i < count; ++i) { + const property = properties[i]; + const value = annotation.properties[i]; + activeTags; + if (isAnnotationTagPropertySpec(property) && property.tag) { + if (value !== 0) { + activeTags.push(property.tag); + } + } + } + if (activeTags.length) { + const tags = document.createElement("div"); + tags.classList.add("neuroglancer-annotation-tags"); + tags.textContent = activeTags.map((x) => `#${x}`).join(" "); + element.appendChild(tags); + } icon.style.gridRow = `span ${numRows}`; if (deleteButton !== undefined) { deleteButton.style.gridRow = `span ${numRows}`;