deardesi.js/README.md

142 lines
4.9 KiB
Markdown
Raw Normal View History

2015-01-23 19:19:10 -07:00
<!--
2015-01-21 19:53:57 -07:00
Not a Web Developer?
====================
2015-01-21 19:54:25 -07:00
You're in the wrong place. **Go to <http://dear.desi>** and follow the instructions there.
2015-01-23 19:19:10 -07:00
-->
2020-11-08 20:30:15 -07:00
# Did you mean to come here?
2015-01-23 19:19:10 -07:00
2020-11-08 20:30:15 -07:00
If you're a normal person interested in _Desi, the DIY blog platform for normal people_,
2015-01-23 19:19:10 -07:00
you might have meant to go to [DearDesi](http://dear.desi) instead.
Otherwise, if you're a cyborg, wizzard, or web developer: carry on.
2015-01-21 19:53:57 -07:00
2020-11-08 20:30:15 -07:00
# Dear Desi
2015-01-10 21:58:49 -07:00
2015-01-23 19:19:10 -07:00
These instructions cover the command line only.
2015-01-10 21:59:40 -07:00
2015-01-23 19:19:10 -07:00
If you want instructions for the web interface, head over to [DearDesi](http://dear.desi).
2015-01-13 03:37:21 -07:00
2020-11-08 20:30:15 -07:00
## Command Line Install (for developers)
2015-01-13 03:37:21 -07:00
This assumes that you already have `git` and `node` installed,
otherwise see [node-installer.sh](https://git.coolaj86.com/coolaj86/node-installer.sh)
2015-01-13 03:37:21 -07:00
2015-01-23 19:19:10 -07:00
```
2017-05-18 14:50:04 -06:00
# Install with distributed tools on a decentralized system
2017-05-18 14:51:21 -06:00
npm install -g 'git+https://git.daplie.com/Daplie/deardesi.git#v1'
2017-05-18 14:50:04 -06:00
# Install with the centralized, concentrated hypocrinet
2015-01-23 19:19:10 -07:00
npm install -g desi
```
2015-01-13 03:37:21 -07:00
2015-01-23 19:19:10 -07:00
That was easy
2020-11-08 20:30:15 -07:00
## Quick Usage
2020-11-08 20:30:15 -07:00
- desi init -d ~/Desktop/new-blog
- pushd ~/Desktop/new-blog
- desi post "my first post"
- desi build
- desi serve
2015-01-13 03:37:21 -07:00
2015-01-23 19:19:10 -07:00
<http://local.dear.desi:65080>
**Note**: both through command line and web you need `site.yml` and `authors/xyz.yml` configured in order to create a post (as well as build).
The post commands output the location of post in various formats.
2020-11-08 20:30:15 -07:00
## Initialize your blog (step 1)
2015-01-23 19:19:10 -07:00
You can do this 3 ways:
2015-01-13 03:37:21 -07:00
2015-01-23 19:19:10 -07:00
1. Create a new blog with `desi init -d ~/Desktop/blog`
2. Clone the seed project and themes yourself
3. Clone the seed project and import your posts and themes
### Automated (desi init)
2015-01-13 03:37:21 -07:00
```bash
2015-01-23 19:19:10 -07:00
# initialize (and or create) a blog directory
desi init -d ~/Desktop/blog
# initialize the current directory
pushd ~/Desktop/blog
desi init
2015-01-13 03:37:21 -07:00
```
2015-01-23 19:19:10 -07:00
Note that you cannot initialize a directory that is already in use
(where 'in use' means has at least one non-dotfile).
2015-01-13 03:37:21 -07:00
2015-01-23 19:19:10 -07:00
### Manual (clone yourself)
There are a number of themes available at <https://github.com/DearDesi>,
just look for ones with 'theme' in the description.
```bash
2015-01-13 03:37:21 -07:00
git clone git@github.com:DearDesi/desirae-blog-template.git ~/my-desirae-blog
pushd ~/my-desirae-blog
2015-01-23 19:19:10 -07:00
git submodule add git@github.com:DearDesi/ruhoh-bootstrap-2.git themes/ruhoh-bootstrap-2
2015-01-13 03:37:21 -07:00
```
2015-01-23 19:19:10 -07:00
You will need to make sure that you have some details about your theme in `config.yml`.
Basically that means that you specify a [`datamap`](https://github.com/DearDesi?query=datamap)
and which defaults for a `page` and `post` in the `layouts` folder.
2015-01-13 03:37:21 -07:00
2015-01-23 19:19:10 -07:00
Just open it up, it'll make sense.
2015-01-13 03:37:21 -07:00
2015-01-23 19:19:10 -07:00
### Migrate (import another blog)
2015-01-23 19:19:10 -07:00
Obviously this is a little different for everyone, so here's what I'd recommend:
2015-01-23 19:19:10 -07:00
1. start by following the Automated procedure above
2. copy over your posts/articles folder(s)
3. edit `config.yml` to add a config with a permalink with your collections (posts, articles, essays, whatever you call them)
2020-11-08 20:30:15 -07:00
4. skip ahead to the _Setup your blog_ section and make sure your `site.yml` and `authors/xxx.yml` are correct.
2015-01-23 19:19:10 -07:00
5. run `desi build -d /path/to/blog` to test if there are any issues with your existing yaml
2020-11-08 20:30:15 -07:00
- if there are, you can take a look at the [normalize](https://github.com/DearDesi/desirae/blob/master/lib/transform-core.js#L72) function and perhaps hand-edit a few things (and when you're ready, you can [register your transform](https://github.com/DearDesi/deardesi/blob/master/bin/deardesi.js#L28) for collections.
2015-01-23 19:19:10 -07:00
6. Now copy over your theme and set it to be the default in `site.yml`
7. build again. Your site probably won't look right:
2020-11-08 20:30:15 -07:00
- look for stuff like `urls.base_url`, `host`, `page.url` that might have an extra `/` at the beginning or end or be named slightly differently.
2015-01-13 03:37:21 -07:00
2015-01-23 19:19:10 -07:00
See <https://github.com/DearDesi/desirae/blob/master/GLOSSARY.md> for disambiguation about the meaning of terms in Desi.
2020-11-08 20:30:15 -07:00
## Setup your blog (step 2)
2015-01-23 19:19:10 -07:00
1. Create an authors file in `authors/YOUR_NAME.yml` and model it after [this example](https://github.com/DearDesi/deardesi/blob/master/example/authors/johndoe.yml)
2020-11-08 20:30:15 -07:00
- You don't need to use all of the fields (your template might not even support them all)
2015-01-23 19:19:10 -07:00
2. Create a site file as `site.yml`, similar to [this example](https://github.com/DearDesi/deardesi/blob/master/example/site.yml)
2015-01-13 03:37:21 -07:00
2015-01-23 19:19:10 -07:00
**Important Things**
2015-01-13 03:37:21 -07:00
2020-11-08 20:30:15 -07:00
- `site.yml.base_url` - the point of ownership (usually blog.example.com or example.com)
- `site.yml.base_path` - where the blog is "mounted", relative to the `base_url` (usually `/` or `/blog`)
- `authors/me.yml.name` - most templates use this
- `authors/me.yml.email` - and this
- `authors/me.yml.twitter` - and this
2020-11-08 20:30:15 -07:00
## Build your blog (step 2)
2015-01-13 03:37:21 -07:00
2020-11-08 20:30:15 -07:00
The build _will_ fail if you don't have `site.yml` and `authors/johndoe.yml` configured.
2015-01-23 19:19:10 -07:00
```bash
desi build -d /path/to/blog
desi serve -d /path/to/blog
2015-01-13 03:37:21 -07:00
```
2015-01-23 19:19:10 -07:00
Now open up your evergreen browser to <http://local.dear.desi:65080>
2020-11-08 20:30:23 -07:00
# License
This Source Code Form is subject to the terms of the Mozilla \
Public License, v. 2.0. If a copy of the MPL was not distributed \
with this file, You can obtain one at \
https://mozilla.org/MPL/2.0/.