- Wire up lists and todos to C# backend with full CRUD persistence - Add models, DTOs, repositories, and services for lists and todo lists/items - Preserve SQLite DB across vault rebuild/load cycles - Add session store for vault password persistence across navigation - Add inline name input for creating lists and todo lists in SidePanel - Clear editor panel on section change with empty state placeholder - Default markdown editor to preview mode on item selection - Decompose EditorPanel into sub-components: - editor/FragmentEditor, editor/TodoEditor, editor/MarkdownEditor - Shared markdown utilities in utils/markdown.ts - Strip verbose console/eprintln logging from frontend and Tauri backend - Add graceful shutdown with vault persistence on window close Co-Authored-By: Oz <oz-agent@warp.dev>
Tauri + SvelteKit + TypeScript
This template should help get you started developing with Tauri, SvelteKit and TypeScript in Vite.
Frontend State Management
This app uses Svelte stores as the source of truth for feature state.
Current Stores
src/lib/stores/entries.ts- state:
entriesStore - helpers:
getDefaultEntry,createEntryDraft
- state:
src/lib/stores/fragments.ts- state:
fragmentsStore - helpers: parse/serialize + fragment CRUD helpers (
createFragmentItem,updateFragmentItem,prependFragmentItem,removeFragmentItem)
- state:
src/lib/stores/todos.ts- state:
todoListsStore,todosStore - helpers: parse/serialize + todo list/item CRUD helpers
- state:
src/lib/stores/lists.ts- state:
listsStore - helpers:
createListDraft
- state:
src/lib/stores/settings.ts- state:
settingsTags,settingsFragmentTypes
- state:
Store-First Rule
- Components should call store helper functions for CRUD operations.
- Components should avoid embedding feature-specific mutation/parsing logic.
- UI components should focus on rendering, local form state, and invoking store operations.
What Still Needs Setup
- Move settings CRUD helpers into
settings.ts(currently add/edit/remove logic lives inroutes/settings/+page.svelte). - Add full CRUD helpers for
entriesandlistsstores (update/remove/reorder and optional find-by-id helpers). - Consolidate todo state into a single custom store API (or a single store object) so
todoListsStoreandtodosStoreupdates are atomic. - Move calendar-created notes into a dedicated calendar store (currently local to
SidePanel.svelte). - Add persistence/hydration layer so store state survives app restart and can be synchronized with backend commands.
Suggested Next Refactor
- Introduce feature service wrappers per store (for example
entriesService,fragmentsService) that handle:- in-memory store mutation
- backend command call (
sendCommand) - optimistic update / rollback policy
- error normalization for UI
Recommended IDE Setup
VS Code + Svelte + Tauri + rust-analyzer.