jote

package module
v0.0.0-...-ab393ec Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Nov 29, 2023 License: MIT Imports: 15 Imported by: 0

README

Jote

Jote is a simple Markdown notes manager.

Why?

I wanted a simple way of organizing my notes, without being required to use a new editor, or being bound to a specific editor. By design, such a method should at minium be:

  • Frictionless to use, especially when adding a new note
  • Usable by any editor (that can be invoked by the command line)
  • Automatically backed by git
  • Able to support any hierarchy
  • Searchable via custom tags

Installing

For now, the easiest way to install is:

go install github.com/jhuntwork/jote/cmd/jote@latest

Usage

New notes

To create a new note, simply run jote new or just jote. If you have the EDITOR environment variable set, that command will be invoked to open a new file. The EDITOR command should block until the file is closed. For example, the default command is vim --nofork, which means vim launches in the foreground and will block until you close the editor. A similar command for VS Code would be code -w.

On first run, jote will initialize a git repository in ~/.local/share/jote. Because all further actions there are git actions, you can interact with it as you would any other git repository.

New files will contain the following template:

---
title:
tags: []
---

The section between the --- lines is considered front matter and is parsed as yaml. If you provide a title, the file will be saved as [title].md, otherwise the file will be named with a unix timestamp of the current time.

title is interpreted as a relative path in the git repository. This means that notes can support a structured hierarchy. For example:

title: recipes/Asian Food/Spicy Thai Noodles

The resulting file would be named ~/.local/share/jote/recipes/Asian Food/Spicy Thai Noodles.md.

tags is a list of strings, so it can either be specified like this:

tags: [one, two, "another tag"]

or like this:

tags:
  - one
  - two
  - another tag

Everything following the front matter section is the actual Markdown content.

Listing all notes

Run jote ls. This will provide a fzf-like interface (via go-fuzzyfinder) to list all notes. Selecting a note will open it for editing.

Changes made to pre-existing notes via the jote interface will result in a new git commit tracking that change. Changing the title will move the file to the new location.

Searching by tags

Run jote tags. This provides a fzf-like interface of all known tags, showing the associated documents for each tag. Select a tag and the interface will switch to a list of those documents, allowing you to select one for editing.

Future features

  • An opinionated way for syncing to a git remote, allowing for editing across machines. For now, this can be managed through manual git commands in the repository.
  • Outputting results of tag searches to stdout as a list, for consumption by other CLI tools.
  • More advanced searches by content.
  • Support a 'publish' keyword in the front matter. This could then be used by plugins to format and send documents to configured consumers.
  • Deleting notes.

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func DefaultStoreLocation

func DefaultStoreLocation() string

Types

type Entry

type Entry struct {
	Title string   `json:"title"`
	Tags  []string `json:"tags"`
}

type Jote

type Jote struct {
	// contains filtered or unexported fields
}

func NewJote

func NewJote(storePath string, editor exec.Cmd) (Jote, error)

NewJote will create a Jote store in a directory called jote under storePath.

func (*Jote) Add

func (j *Jote) Add() error

func (*Jote) List

func (j *Jote) List() error

func (*Jote) Tags

func (j *Jote) Tags() error

Directories

Path Synopsis
cmd

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL