Staticka Console
![Software License][ico-license]
![Coverage Status][ico-coverage]
, (*1)
Console is a terminal-based package of Staticka which allows creating and building of pages through a terminal., (*2)
Installation
Installing the Console package is possible through Composer:, (*3)
``` bash
$ composer require staticka/console, (*4)
## Basic Usage
To create a new page, use the `create` command with its title:
``` bash
$ vendor/bin/staticka create "Hello world!"
[PASS] "Hello world!" page successfully created!
``` md
, (*5)
name: Hello world!
link: /hello-world
title: Hello world!
description:
tags:, (*6)
category:
Hello world!
ciacme/
โโโ pages/
โ โโโ 20241028202552_hello-world.md
โโโ vendor/
โโโ composer.json, (*7)
After adding some text to the newly created page, use the `build` command to compile the `.md` files to `.html`:
``` bash
$ vendor/bin/staticka build
[PASS] Pages successfully compiled!
ciacme/
โโโ build/
โ โโโ hello-world/
โ โโโ index.html
โโโ pages/
โ โโโ 20241028202552_hello-world.md
โโโ vendor/
โโโ composer.json
``` html
, (*8)
Hello world!
> [!NOTE]
> `Console` will try to create the required directories (e.g., `build`, `pages`) if they do not exists in the current working directory.
## Using `staticka.yml`
`Console` typically works out of the box without any configuration. But if there is a need to change the path of its other supported directories or needs to extend the core functionalities of `Console`, the `staticka.yml` file can be used in those kind of scenarios:
``` yaml
# staticka.yml
root_path: %%CURRENT_DIRECTORY%%
timezone: Asia/Manila
assets_path: %%CURRENT_DIRECTORY%%/assets
build_path: %%CURRENT_DIRECTORY%%/build
config_path: %%CURRENT_DIRECTORY%%/config
pages_path: %%CURRENT_DIRECTORY%%/pages
plates_path: %%CURRENT_DIRECTORY%%/plates
scripts_path: %%CURRENT_DIRECTORY%%/scripts
styles_path: %%CURRENT_DIRECTORY%%/styles
To create the said staticka.yml file, simply run the initialize command:, (*9)
``` bash
$ vendor/bin/staticka initialize
[PASS] "staticka.yml" added successfully!, (*10)
After successfully creating the said file, it will provide the following properties below:
### `root_path`
This property specifies the current working directory. By default, it uses the `%%CURRENT_DIRECTORY%%` placeholder that returns the current directory of the `staticka.yml` file:
``` yaml
# staticka.yml
root_path: %%CURRENT_DIRECTORY%%/Sample
# ...
timezone
This allows to change the timezone to be used when creating timestamps of a new page. If not specified, Console will use the default timezone specified in the php.ini file:, (*11)
``` yaml, (*12)
staticka.yml
timezone: Asia/Tokyo, (*13)
...
### `assets_path`
This specifies the path for all other web assets like images (`.jpg`, `.png`) and PDF files (`.pdf`). `Console` does not use this specified path but it might be useful to locate the directory for organizing asset files:
``` yaml
# staticka.yml
assets_path: %%CURRENT_DIRECTORY%%/assets
# ...
build_path
This is the property that will be used by Console to determine the destination directory of the compiled pages:, (*14)
``` yaml, (*15)
staticka.yml
build_path: %%CURRENT_DIRECTORY%%/build, (*16)
...
### `config_path`
One of the properties of `Console` that locates the directory for storing configuration files. If defined, it will load its `.php` files to a `Configuration` class. The said class is useful when creating extensions to `Console`:
``` yaml
# staticka.yml
config_path: %%CURRENT_DIRECTORY%%/config
# ...
``` php
// config/parser.php, (*17)
return array(
/**
* @var \Staticka\Filter\FilterInterface[]
*/
'filters' => array(
'Staticka\Expresso\Filters\GithubFilter',
'Staticka\Expresso\Filters\ReadmeFilter',
),
);, (*18)
``` php
// src/Package.php
namespace Ciacme;
use Rougin\Slytherin\Container\ContainerInterface;
use Rougin\Slytherin\Container\ReflectionContainer;
use Rougin\Slytherin\Integration\Configuration;
use Rougin\Slytherin\Integration\IntegrationInterface;
class Package implements IntegrationInterface
{
public function define(ContainerInterface $container, Configuration $config)
{
// Will try to access the "config/parser.php" file ---
/** @var class-string[] */
$filters = $config->get('parser.filters', array());
// ---------------------------------------------------
// ...
}
}
[!NOTE]
To allow custom packages for Console, kindly add the specified package class in staticka.yml. Please see the Extending Console section below for more information., (*19)
pages_path
This is the location of the generated pages from create command:, (*20)
``` yaml, (*21)
staticka.yml
pages_path: %%CURRENT_DIRECTORY%%/pages, (*22)
...
### `plates_path`
One of the special variables of `Console` to specify a directory that can be used for third-party templating engines (`RenderInterface`):
``` yaml
# staticka.yml
plates_path: %%CURRENT_DIRECTORY%%/plates
# ...
scripts_path
This is the property for the directory path of script files (.js, .ts). Although not being used internally by Console, this property can be used when extending core functionalities (e.g., compiling .js files through Webpack when running the build command):, (*23)
``` yaml, (*24)
staticka.yml
scripts_path: %%CURRENT_DIRECTORY%%/scripts, (*25)
...
### `styles_path`
Same as `scripts_path`, this property specifies the directory path for styling files (`.css`, `.sass`):
``` yaml
# staticka.yml
styles_path: %%CURRENT_DIRECTORY%%/styles
# ...
Extending Console
Console is based on the Slytherin PHP micro-framework which provides an easy way to integrate custom packages through IntegrationInterface. The said interface can be used to create instances related to Staticka:, (*26)
``` php
// src/Package.php, (*27)
namespace Ciacme;, (*28)
use Rougin\Slytherin\Container\ContainerInterface;
use Rougin\Slytherin\Container\ReflectionContainer;
use Rougin\Slytherin\Integration\Configuration;
use Rougin\Slytherin\Integration\IntegrationInterface;
use Staticka\Filter\HtmlMinifier;
use Staticka\Layout;, (*29)
class Package implements IntegrationInterface
{
/**
* This sample package will always minify the compiled HTML files.
*
* @param \Rougin\Slytherin\Container\ContainerInterface $container
* @param \Rougin\Slytherin\Integration\Configuration $config
*
* @return \Rougin\Slytherin\Container\ContainerInterface
*/
public function define(ContainerInterface $container, Configuration $config)
{
$layout = new Layout;, (*30)
$layout->addFilter(new HtmlMinifier);
$container->set(get_class($layout), $layout);
return $container;
}
}, (*31)
To add the specified custom package, kindly add it to the `staticka.yml` file:
``` yaml
# staticka.yml
root_path: %%CURRENT_DIRECTORY%%
# ...
packages:
- Ciacme\Package
Changelog
Please see CHANGELOG for more information what has changed recently., (*32)
Testing
The unit tests of Console can be run using the phpunit command:, (*33)
bash
$ vendor/bin/phpunit, (*34)
Credits
License
The MIT License (MIT). Please see LICENSE for more information., (*35)