quicknotes/SPECS.md

2 KiB

QuickNotes Application Specifications

This document provides an overview of the QuickNotes application specifications. QuickNotes is a personal knowledge management system that allows users to create and manage notes, read later items, and RSS/Atom feeds.

Overview

QuickNotes is built with a Go backend and a Svelte frontend. It uses SQLite for data storage and provides a RESTful API for communication between the frontend and backend.

Specification Documents

The following table lists all the specification documents for the QuickNotes application:

Domain Description Link
Architecture Overall system architecture Architecture
Notes Note creation, management, and linking Notes
Readlist Read later functionality Readlist
Feeds RSS/Atom feed management Feeds
Database Database schema and relationships Database
API API endpoints and communication API
Frontend User interface and client-side features Frontend
Authentication User authentication (if applicable) Authentication
Emacs Integration Emacs mode for QuickNotes Emacs Integration

Key Features

  • Create, edit, and delete notes with Markdown support
  • Link notes together using wiki-style [[note-title]] syntax
  • Visualize note connections with an interactive graph
  • Save articles for later reading with automatic content extraction
  • Manage and read RSS/Atom feeds
  • Import notes from Obsidian vaults
  • Emacs integration for accessing QuickNotes features

Technology Stack

  • Backend: Go with Gin web framework
  • Frontend: Svelte with SvelteKit
  • Database: SQLite with GORM
  • Package Management: Bun (frontend), Go modules (backend)
  • Testing: Go testing framework, Playwright for frontend testing