Skip to content

Commit

Permalink
Widgets: make widget names unique
Browse files Browse the repository at this point in the history
  • Loading branch information
Williangalvani committed Dec 10, 2024
1 parent 009b27c commit dcfe920
Showing 1 changed file with 32 additions and 3 deletions.
35 changes: 32 additions & 3 deletions src/components/EditMenu.vue
Original file line number Diff line number Diff line change
Expand Up @@ -472,7 +472,7 @@
<v-btn
type="flat"
class="bg-[#FFFFFF33] text-white w-[95%]"
@click="store.addWidget(WidgetType.CustomWidgetBase, store.currentView)"
@click="store.addWidget(makeNewWidget(WidgetType.CustomWidgetBase), store.currentView)"
>Add widget base
</v-btn>
</div>
Expand Down Expand Up @@ -719,6 +719,35 @@ const emit = defineEmits<{
(e: 'update:editMode', editMode: boolean): void
}>()
const findUniqueName = (name: string): string => {
let newName = name
let i = 1
const existingNames = store.currentView.widgets.map((widget) => widget.name)
while (existingNames.includes(newName)) {
newName = `${name} ${i}`
i++
}
return newName
}
/*
* Makes a new widget with an unique name
*/
const makeNewWidget = (widget: WidgetType, name?: string, options?: Record<string, any>): ExtendedWidget => {
const newName = name || widget
return {
name: findUniqueName(newName),
component: widget,
options: options || {},
}
}
const makeWidgetUnique = (widget: ExtendedWidget): ExtendedWidget => {
return {
...widget,
name: findUniqueName(widget.name),
}
}
const availableWidgetTypes = computed(() =>
Object.values(WidgetType).map((widgetType) => {
return {
Expand Down Expand Up @@ -1023,8 +1052,8 @@ const onRegularWidgetDragStart = (event: DragEvent): void => {
}
}
const onRegularWidgetDragEnd = (widgetType: ExtendedWidget): void => {
store.addWidget(widgetType, store.currentView)
const onRegularWidgetDragEnd = (widget: ExtendedWidget): void => {
store.addWidget(makeWidgetUnique(widget), store.currentView)
const widgetCards = document.querySelectorAll('[draggable="true"]')
widgetCards.forEach((card) => {
Expand Down

0 comments on commit dcfe920

Please sign in to comment.