Simple static site generator. Just it.
Install Situs via npm.
~ $ npm install situs -g 
Go to your static site directory.
~ $ cd your-directory
Then fire the development server! Situs will watch your directory. So if you make change one of your files, Situs will rebuild your static site automatically.
~/your-directory $ situs server
$ situs build
# Build your source directory and place it to destination. (default: ./situs)
$ situs server
# Start development server, watch for changes and rebuild source automatically.
$ situs help
# Print Situs command usage.
$ situs -v
$ situs --version
# Print Situs version.
By default, Situs is able run without any configuration. But, if you want something advance, you can store the configuration on situs.json.
situs.json (default):
{
  "source": "./",
  "destination": "./situs",
  "ignore": [
    "node_modules/**/*"
  ],
  "markdown": false,
  "permalink": false,
  "port": 4000,
  "global": {}
}
| Parameter | Value | Description | 
|---|---|---|
| source | string | Source directory of static site | 
| destination | string | Destination directory of static site for compiled source files | 
| ignore | array | List of glob pattern to prevent files or directory to be compiled by Situs | 
| markdown | boolean | Render markdown to html. If it set false, markdown file will not converted to be html when you build source. | 
| permalink | boolean | Enable permalink/pretty url | 
| port | integer | Port of development server | 
| global | object | Global variable that will be rendered to source files | 
You can also overide default configuration directly from command line.
# Set local development port
$ situs build --port=4000
# Set source directory
$ situs build --source=./path/to/dir
# Set destination directory
$ situs build --destination=./path/to/dir
# Enable markdown parser
$ situs build --markdown
# Enable permalink (pretty-url)
$ situs build --permalink
Situs is using Handlebars to render data and also include some additional helpers function like,
{{#escape}} : Used for escaping html string, especially in html file. Example:
{{#escape}}
<html>
</html>
{{#escape}}
# Will be rendered to
<html>
</html>
{{#code}} : Used for escaping code and also wrapping it inside <pre> and <code>. Example:
{{#code}}
<html>
</html>
{{#code}}
# Will be rendered to
<pre><code><html>
</html>
</code></pre>
# You can also add class in your <code> tag (usually for syntax highlighter)
{{#code class="lang-html"}}
<html>
</html>
{{#code}}
# Will be rendered to
<pre><code class="lang-html"><html>
</html>
</code></pre>
For other Handlebars helper, please visit http://handlebarsjs.com/.
You can include other file inside a file, by passing relative path of the file to @situs-include(). This function is usefull when you needed to put same content in several source files. Situs will raise an error, if included file is not found.
Example:
index.html
<html>
  @situs-include(./header.html)
  <body>
  </body>
</html>header.html
<head>
  <title>Sample situs page</title>
</head>Output:
<html>
  <head>
    <title>Sample situs page</title>
  </head>
  <body>
  </body>
</html>@situs-data() allows you to add local data directly on your file, same as Front Matter does in Jekyll. To use it, you have to insert JSON string as parameter.
Example:
index.html
@situs-data({
  "title": "Sample situs page"
})
<html>
  <head>
    <title>{{ title }}</title>
  </head>
  <body>
  </body>
</html>Output:
<html>
  <head>
    <title>Sample situs page</title>
  </head>
  <body>
  </body>
</html>If you included a file, @situs-data() also render the local data to include file.
Example:
index.html
@situs-data({
  "title": "Sample situs page"
})
<html>
  @situs-include(./header.html)
  <body>
  </body>
</html>header.html
<head>
  <title>{{ title }}</title>
</head>Output:
<html>
  <head>
    <title>Sample situs page</title>
  </head>
  <body>
  </body>
</html>Situs also provide @situs-ignore() if you want to ignore a file manually, without specifying the file in situs.json. Just place @situs-ignore() anywhere inside your file.
Example:
Directory structure (before build)
- \main-directory
    - \destination
      - (empty)
    - \source
      - index.html
      - page.html
page.html
@situs-ignore()
<html>
  <head>
    <title>Sample page</title>
  </head>
  <body>
  </body>
</html>Build your source
~\main-directory $ situs build
Directory structure (after build)
- \main-directory
    - \destination
      - index.html
    - \source
      - index.html
      - page.html
Situs released under MIT license. 2014-2020 © Alfiana Sibuea. All right reserved.
