2017 © Pedro Pelรกez
 

library console

An easy-to-use console application for Staticka.

image

staticka/console

An easy-to-use console application for Staticka.

  • Sunday, April 8, 2018
  • by rougin
  • Repository
  • 1 Watchers
  • 0 Stars
  • 10 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 0 Forks
  • 0 Open issues
  • 3 Versions
  • 0 % Grown

The README.md

Staticka Console

Latest Version on Packagist ![Software License][ico-license] Build Status ![Coverage Status][ico-coverage] Total Downloads, (*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)

The Versions

08/04 2018

dev-master

9999999-dev https://github.com/staticka/console

An easy-to-use console application for Staticka.

  Sources   Download

MIT

The Requires

 

The Development Requires

console generator static site staticka

08/04 2018

v0.1.1

0.1.1.0 https://github.com/staticka/console

An easy-to-use console application for Staticka.

  Sources   Download

MIT

The Requires

 

The Development Requires

console generator static site staticka

05/04 2018

v0.1.0

0.1.0.0 https://github.com/staticka/console

An easy-to-use console application for Staticka.

  Sources   Download

MIT

The Requires

 

The Development Requires

console generator static site staticka