Converts Markdown pages to HTML from the terminal.
Console is a terminal-based package of Staticka which allows creating and building of pages through a terminal.
Installing the Console package is possible through Composer:
$ composer require staticka/consoleTo create a new page, use the create command with its title:
$ vendor/bin/staticka create "Hello world!"
[PASS] "Hello world!" page successfully created!<!-- pages/20241028202552_hello-world.md -->
---
name: Hello world!
link: /hello-world
title: Hello world!
description:
tags:
category:
---
# Hello world!ciacme/
├── pages/
│ └── 20241028202552_hello-world.md
├── vendor/
└── composer.jsonAfter adding some text to the newly created page, use the build command to compile the .md files to .html:
$ vendor/bin/staticka build
[PASS] Pages successfully compiled!ciacme/
├── build/
│ └── hello-world/
│ └── index.html
├── pages/
│ └── 20241028202552_hello-world.md
├── vendor/
└── composer.json<!-- build/hello-world/index.html -->
<h1>Hello world!</h1>[!NOTE]
Consolewill try to create the required directories (e.g.,build,pages) if they do not exists in the current working directory.
staticka.ymlConsole 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:
# 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%%/stylesTo create the said staticka.yml file, simply run the initialize command:
$ vendor/bin/staticka initialize
[PASS] "staticka.yml" added successfully!After successfully creating the said file, it will provide the following properties below:
root_pathThis property specifies the current working directory. By default, it uses the %%CURRENT_DIRECTORY%% placeholder that returns the current directory of the staticka.yml file:
# staticka.yml
root_path: %%CURRENT_DIRECTORY%%/Sample
# ...timezoneThis 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:
# staticka.yml
timezone: Asia/Tokyo
# ...assets_pathThis 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:
# staticka.yml
assets_path: %%CURRENT_DIRECTORY%%/assets
# ...build_pathThis is the property that will be used by Console to determine the destination directory of the compiled pages:
# staticka.yml
build_path: %%CURRENT_DIRECTORY%%/build
# ...config_pathOne 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:
# staticka.yml
config_path: %%CURRENT_DIRECTORY%%/config
# ...// config/parser.php
return array(
/**
* @var \Staticka\Filter\FilterInterface[]
*/
'filters' => array(
'Staticka\Expresso\Filters\GithubFilter',
'Staticka\Expresso\Filters\ReadmeFilter',
),
);// 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 instaticka.yml. Please see theExtending Consolesection below for more information.
pages_pathThis is the location of the generated pages from create command:
# staticka.yml
pages_path: %%CURRENT_DIRECTORY%%/pages
# ...plates_pathOne of the special variables of Console to specify a directory that can be used for third-party templating engines (RenderInterface):
# staticka.yml
plates_path: %%CURRENT_DIRECTORY%%/plates
# ...scripts_pathThis 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):
# staticka.yml
scripts_path: %%CURRENT_DIRECTORY%%/scripts
# ...styles_pathSame as scripts_path, this property specifies the directory path for styling files (.css, .sass):
# staticka.yml
styles_path: %%CURRENT_DIRECTORY%%/styles
# ...ConsoleConsole 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:
// 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;
use Staticka\Filter\HtmlMinifier;
use Staticka\Layout;
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;
$layout->addFilter(new HtmlMinifier);
$container->set(get_class($layout), $layout);
return $container;
}
}To add the specified custom package, kindly add it to the staticka.yml file:
# staticka.yml
root_path: %%CURRENT_DIRECTORY%%
# ...
packages:
- Ciacme\Package