journal/Journal.App
Jacob Schmidt c7933aeeec Lists & todos backend, editor refactor, inline create, UX improvements
- 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>
2026-02-26 17:33:27 -06:00
..
2026-02-24 22:16:51 -06:00
2026-02-24 22:16:51 -06:00
2026-02-24 22:16:51 -06:00
2026-02-24 22:16:51 -06:00
2026-02-24 22:16:51 -06:00
2026-02-24 22:16:51 -06:00

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
  • src/lib/stores/fragments.ts
    • state: fragmentsStore
    • helpers: parse/serialize + fragment CRUD helpers (createFragmentItem, updateFragmentItem, prependFragmentItem, removeFragmentItem)
  • src/lib/stores/todos.ts
    • state: todoListsStore, todosStore
    • helpers: parse/serialize + todo list/item CRUD helpers
  • src/lib/stores/lists.ts
    • state: listsStore
    • helpers: createListDraft
  • src/lib/stores/settings.ts
    • state: settingsTags, settingsFragmentTypes

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

  1. Move settings CRUD helpers into settings.ts (currently add/edit/remove logic lives in routes/settings/+page.svelte).
  2. Add full CRUD helpers for entries and lists stores (update/remove/reorder and optional find-by-id helpers).
  3. Consolidate todo state into a single custom store API (or a single store object) so todoListsStore and todosStore updates are atomic.
  4. Move calendar-created notes into a dedicated calendar store (currently local to SidePanel.svelte).
  5. 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

VS Code + Svelte + Tauri + rust-analyzer.