Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/owmacohe/pantry
A tag-based wiki system inspired by TiddlyWiki. I use this framework for my worldbuilding planning.
https://github.com/owmacohe/pantry
articles markdown markdown-to-html tag tagging tags tiddlywiki wiki worldbuilding
Last synced: about 1 month ago
JSON representation
A tag-based wiki system inspired by TiddlyWiki. I use this framework for my worldbuilding planning.
- Host: GitHub
- URL: https://github.com/owmacohe/pantry
- Owner: Owmacohe
- License: mit
- Created: 2021-12-21T19:11:58.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2023-11-26T17:47:27.000Z (about 1 year ago)
- Last Synced: 2024-11-05T12:24:18.389Z (3 months ago)
- Topics: articles, markdown, markdown-to-html, tag, tagging, tags, tiddlywiki, wiki, worldbuilding
- Language: JavaScript
- Homepage:
- Size: 137 KB
- Stars: 3
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Pantry
Pantry is a tag-based wiki system. Operating purely through Javascript magic, it turns MarkDown files into hypertext articles, which can be tagged, linked to, and generated as dynamic lists. Pantry is inspired by [TiddlyWiki](https://tiddlywiki.com), and is an attempt to simplify and streamline many of that system's features. It requires no programming knowledge, save for some understanding of the system's modified MarkDown language *(see below for more)*, and the ability to edit `.md` and `.txt` files. I use it for my TTRPG worldbuilding, personal databases, and for complex note-taking. Please reach out and let me know if you use the system for any of your porojects!
***Disclaimer:*** A Pantry wiki can only load properly when either hosted on a website or loaded through a local server, such as Jetbrains's Built-In Preview feature. It will not load properly when simply opening the local `index.html` file in a browser.
## Setup
1. Install and extract the repository
2. Navigate to the `settings.txt` file. After the colon on each line, fill in the following:
1. The title of the wiki
2. The name of the creator
3. The date(s) of creation of the wiki
4. The name of the default 'splash page' article
5. Whether this wiki is in private mode *(set to `false` if you have no private articles/tags)*
6. The names of the private tags used to exclude sensitive articles from the public mode *(leave empty if you have no private articles/tags)**e.g.*
```
title:WikiTitle
creator:Your Name
date:2023
default:Introduction
private:false
private_tags:private,todo
```3. Navigate to the `registry.txt` file, and write the names of each article in your wiki (not including the file extension) on a separate new line
*e.g.*
```
article1
article2
article3
...
```## Usage
Before writing any articles, create a folder named `articles`, and place it in the root directory here. Place any article files you write inside this folder (make sure to write their names in the `registry.txt` file!). Articles are written in a modified form of [Markdown](https://www.markdownguide.org). Here are the rules for writing articles:
- **Naming**
- Articles are saved as `.md` files, with the name of the file corresponding to the title of the article
- Slashes (`/`) and colons (`:`) aren't permitted in titles of articles. Use either underscores (`_`) are spaces to represent these characters *(other special characters in file names may also break the wiki)*
- **Header**
- The first line should be a level 1 header of the name of the article
- The third line should be a list of the tags of the article, separated by commas and wrapped in curly braces (`{}`) *(these tags represent the 'groups' of articles that the article may pertain to)*
- **Body**
- Plain text should be written as-is
- Line breaks / new lines will be preserved
- Write `---` in a new line to add a **horizontal rule**
- Write `> ` before any line to turn it into a **quote block** *(quotes can be multi-line)* *(see quote example below)*
- Write `- ` or `1. ` before any line to write **unordered** or **ordered list**s (respectively) *(see list example below)*
- Multi-hierarchy lists can be written in a similar fashion by including three spaces before the list marker *(see list example below)*
- Write any number of `#`s and a space before any line to turn it into a **header** of that respective level *(e.g. `## Header2`)*
- Write `^` before and after any link/path to an image in a new line to insert an **image** *(can be a local or external image)* *(e.g. `^path/to/image/img.jpg^`)*
- Write `%` before and after any list of comma-separated article names / tags in a new line to insert an **automatic list** of articles tagged with those tags *(write `|` after the list and another comma-separated list to *exclude* those tags from the automatic list)* *(e.g. `%important,research|private,todo%`)*
- Write `*` before and after text to make it **italic**, and `**` for **bold** *(these can be combined for bold-italic)*
- Write `~~` before and after any text to make it **strikethrough**
- Write square brackets (`[]`) around any article name / tag to turn it into a clickable **button** *(you can write `|` before the end bracket followed by a display name for the button)* *(e.g. `[Display Name|article1]`)*
- Write square brackets (`[]`) followed immediately by normal brackets (`()`) to insert a **link** *(the display name for the link should go in the square brackets, and the link should go in the normal brackets)* *(can be a local or external link)* *(e.g. `[Display Name|path/to/webpage/index.html]`)*Your wiki is now ready to go! Simply open the `pantry` folder or the `index.html` file in a web browser of your choice to view it in action *(see the disclaimer above for more info about loading the wiki)*. As **Pantry** is a web-built system, it can also be hosted on a website, and viewed publicly (just remember to set the `private` field in `settings.txt` to `false` before you publish it, if you have any private tags).
## Quote example
```
> Line 1
>
> Line 2
> Line 3
>
> Line 5
>
> Line 7
```## List example
```
1. Element 1
- Sub-element 1.1
- Sub-element 1.2
- Sub-sub-element 1.2.1
- Sub-sub-element 1.2.2
- Sub-element 1.3
2. Element 2
1. Sub-element 2.1
2. Sub-element 2.2
3. Element 3
```## Colour customization
Wiki colours can be customized. Simply change the hex values of the various CSS `:root` variables in the `style.css` file, in the `scripts` folder. Various other CSS elements can of course also be changed in the same file.