quicknotes/README.md

2.5 KiB

QuickNotes

QuickNotes is a personal knowledge management application that allows you to create, manage, and interlink your notes, save articles for later reading, subscribe to RSS/Atom feeds, upload and view PDF documents, and perform a unified full-text search across all your content.

Features

  • Notes: Create, edit, and delete notes with Markdown support. Interlink notes using wiki-style syntax and visualize connections with an interactive graph.
  • Readlist: Save and view articles for later reading with automatic content extraction.
  • Feeds: Subscribe to and manage RSS/Atom feeds, and view feed entries with options to mark them as read or unread.
  • Documents: Upload and view PDF documents directly within the app without needing to download them.
  • Omnisearch: Perform unified full-text searches across notes, feed entries, readlist items, and documents.

Technology Stack

  • Backend: Go with the Gin web framework and GORM; SQLite for data storage.
  • Frontend: Svelte with SvelteKit, styled with Bulma CSS and FontAwesome for icons.
  • Search: Bleve for full-text search capabilities.
  • PDF Viewing: Integrated PDF.js-like viewer for inline document viewing.
  • Package Management: Bun for frontend dependencies and Go modules for backend dependencies.
  • Testing: Go testing framework for backend and Playwright for end-to-end frontend testing.

Installation

  1. Server Setup:

    • Ensure Go is installed.
    • Build the backend server using go build or the provided build.sh script.
    • Ensure Bun is installed and run bun install in the frontend directory.
    • Start the backend server (default URL: http://localhost:3000).
  2. Frontend:

    • The SvelteKit frontend is served by the Go backend after being built, or can be run separately for development.
    • Access the application via your web browser at http://localhost:3000.

Usage

  • Navigate using dedicated pages for Notes, Readlist, Feeds, Documents, and Omnisearch.
  • Use the Omnisearch page to perform full-text searches across all content domains.

Documentation

For detailed specifications, see:

License

This project is licensed under the MIT License.