fix: preserve selected persona after sorting

This commit is contained in:
bangonicdd
2025-04-19 15:34:52 +09:00
parent 9af38ced76
commit a7aebab65c

View File

@@ -14,13 +14,17 @@
import { setDatabase } from "src/ts/storage/database.svelte"; import { setDatabase } from "src/ts/storage/database.svelte";
import { DBState } from 'src/ts/stores.svelte'; import { DBState } from 'src/ts/stores.svelte';
import { get } from "svelte/store"; import { get } from "svelte/store";
import { v4 } from "uuid"
let stb: Sortable = null let stb: Sortable = null
let ele: HTMLDivElement = $state() let ele: HTMLDivElement = $state()
let sorted = $state(0) let sorted = $state(0)
let selectedId:string = null
const createStb = () => { const createStb = () => {
stb = Sortable.create(ele, { stb = Sortable.create(ele, {
onStart: async () => { onStart: async () => {
DBState.db.personas[DBState.db.selectedPersona].id ??= v4()
selectedId = DBState.db.personas[DBState.db.selectedPersona].id
saveUserPersona() saveUserPersona()
}, },
onEnd: async () => { onEnd: async () => {
@@ -39,7 +43,8 @@
newValue.push(DBState.db.personas[i]) newValue.push(DBState.db.personas[i])
}) })
DBState.db.personas = newValue DBState.db.personas = newValue
changeUserPersona(0, 'noSave') const selectedPersona = DBState.db.personas.findIndex((e) => e.id === selectedId)
changeUserPersona(selectedPersona !== -1 ? selectedPersona : 0, 'noSave')
try { try {
stb.destroy() stb.destroy()
} catch (error) {} } catch (error) {}