Skip to content

Commit

Permalink
feat(ToolLabelEditor): warn if label name is not unique
Browse files Browse the repository at this point in the history
Still allows duplicate names if user presses "Done".

New labels are created with unique names suffixed with a number.

New labels loop through the confgi.ts:TOOL_COLORS.
  • Loading branch information
PaulHax committed Dec 21, 2023
1 parent 2acba1f commit a019c4f
Show file tree
Hide file tree
Showing 3 changed files with 46 additions and 6 deletions.
17 changes: 16 additions & 1 deletion src/components/LabelControls.vue
Original file line number Diff line number Diff line change
Expand Up @@ -42,8 +42,22 @@ const editingLabel = computed(() => {
return props.labelsStore.labels[editingLabelID.value];
});
const makeUniqueName = (name: string) => {
const existingNames = new Set(
Object.values(props.labelsStore.labels).map((label) => label.labelName)
);
let uniqueName = name;
let i = 1;
while (existingNames.has(uniqueName)) {
uniqueName = `${name} (${i})`;
i++;
}
return uniqueName;
};
const createLabel = () => {
editingLabelID.value = props.labelsStore.addLabel();
const labelName = makeUniqueName('New Label');
editingLabelID.value = props.labelsStore.addLabel({ labelName });
};
function startEditing(label: LabelID) {
Expand Down Expand Up @@ -114,6 +128,7 @@ function deleteEditingLabel() {
@delete="deleteEditingLabel"
@cancel="stopEditing(false)"
@done="stopEditing(true)"
:labelsStore="labelsStore"
/>
</isolated-dialog>
</template>
Expand Down
30 changes: 25 additions & 5 deletions src/components/ToolLabelEditor.vue
Original file line number Diff line number Diff line change
@@ -1,5 +1,8 @@
<script setup lang="ts">
import { computed } from 'vue';
import LabelEditor from '@/src/components/LabelEditor.vue';
import type { LabelsStore } from '../store/tools/useLabels';
import type { AnnotationTool } from '../types/annotation-tool';
defineEmits([
'done',
Expand All @@ -10,11 +13,27 @@ defineEmits([
'update:color',
]);
defineProps({
name: String,
strokeWidth: Number,
color: String,
});
const props = defineProps<{
name: string;
strokeWidth: number;
color: string;
labelsStore: LabelsStore<Pick<AnnotationTool, 'strokeWidth'>>;
}>();
const existingNames = computed(
() =>
new Set(
Object.values(props.labelsStore.labels).map((label) => label.labelName)
)
);
function isUniqueEditingName(name: string) {
return !existingNames.value.has(name);
}
function uniqueNameRule(name: string) {
return isUniqueEditingName(name) || 'Name is not unique';
}
</script>

<template>
Expand All @@ -37,6 +56,7 @@ defineProps({
:model-value="name"
@update:model-value="$emit('update:name', $event)"
@keydown.stop.enter="done"
:rules="[uniqueNameRule]"
/>
<v-text-field
label="Stroke Width"
Expand Down
5 changes: 5 additions & 0 deletions src/store/tools/useLabels.ts
Original file line number Diff line number Diff line change
Expand Up @@ -27,14 +27,19 @@ export const useLabels = <Props>(newLabelDefault: Props) => {
activeLabel.value = id;
};

let nextToolColorIndex = 0;

const addLabel = (label: ToolLabel = {}) => {
const id = useIdStore().nextId();
labels.value[id] = {
...labelDefault,
...newLabelDefault,
color: TOOL_COLORS[nextToolColorIndex],
...label,
};

nextToolColorIndex = (nextToolColorIndex + 1) % TOOL_COLORS.length;

setActiveLabel(id);
return id;
};
Expand Down

0 comments on commit a019c4f

Please sign in to comment.