rocket-pinboard/README.md

57 lines
1.8 KiB
Markdown

# Wishlists
A [Rocket](https://rocket.rs) based web application written in Rust for
maintaining a board of wishlists for a family or group of friends.
Similarly to a Wiki, all lists can be edited by everyone, as a board with
physical lists would also allow.
## Building
Because Rocket still requires a nightly version of Rust, Wishlist also
requires it. The application has been tested with `nightly-2017-12-21`.
Wishlists uses a customized Bootstrap-style, to compile this, the
Ruby implementation of Sass
```
$ gem install sass
...
$ scss static/scss/wishlists.scss:static/csss/wishlists.css
```
## Usage
The lists are stored as plain text files (in Markdown format) under the
`lists` subdirectory. As an administrator of the application, you should
touch a file with the extension `.list` in this subdirectory to create
lists. The resulting list names are the title cased version of the snake
cased filenames. For example to create a list for "John Doe":
```
$ touch lists/john_doe.list
```
After creating new lists, start (or restart) the application and then visit:
http://localhost:8000/.
For setting up production or staging environments, see the
[Rocket documentation](https://rocket.rs/guide/configuration/) about
configuring different environments.
## To Do
There are still quite some things left to do. Here are some points of
improvement for the future:
* Use a Rust-implementation for Sass
* Support different sets of lists (for different environments)
* Get rid of hardcoded strings in the UI (for example the name of my family)
* Add i18n to support several languages
* Support locking a list while editing it in the client so other clients
cannot edit it
## License
Wishlists is licensed under the MIT license
([LICENSE-MIT](LICENSE-MIT) or http://opensource.org/licenses/MIT).