@alotool/bloggerpack v1.0.0-beta.6
Features
- Nunjucks
- Sass and ES6+
- CSS and JS linter
- CSS and JS minification
- and more
Usage
Folder structure
.
├── dist/ (g)
| └── theme.xml <---------------------------+ # compiled <---+
├── src/ | |
| ├── dist/ (i)(g) | # source ----->|
| | ├── js.js <---------------+ |
| | ├── sass.css <------------|---+ |
| | └── skin.css <------------|---|---+ |
| ├── js/ │ | | |
| | ├── js-in-template.js (g) | | | |
| | └── index.js ------------>| | | |
| ├── sass/ | | |
| | ├── _sass-in-template.scss (g)| | |
| | └── index.scss -------------->| | |
| ├── skin/ | |
| | ├── skin-in-template.css (g) | |
| | └── index.css ------------------->| | # (i) = Must be included in template (see `{% asset %}` tag)
| ├── template/ (n) | # (n) = Not specify or can be renamed or moved
| ├── index.njk --------------------------->| # (g) = Auto-generated
| └── layout.njk (n)
├── .browserslistrc
├── .eslintrc.json
├── .stylelintrc
├── banner.txt
├── data.json
└── package.json
Config files
.browserslistrc
The config to share target browsers. Learn more about Browserslist.
.eslintrc.json
The default config is recommended, but if you want to change the config you can read the ESLint docs.
.stylelintrc
The default config is recommended, but if you want to change the config you can read the Stylelint docs.
banner.txt
The header for compiled Sass, Skin and JS. You can access data from data.json
using <%= data.keyName %>
.
Example:
/*!
* <%= data.theme.name %> v<%= data.theme.version %>
*/
data.json
Store your theme config in this file. This is Nunjucks template context, which means it can be accessed in template files using {{ data.keyName }}
. You can also access data from package.json
using {{ pkg.keyName }}
. See Nunjucks variables.
package.json
Use this file to manage and install Bloggerpack and other packages. You also will need to add Bloggerpack commands and tasks.
Template
We uses Nunjucks for its template engine. File extension for template files is .njk
.
Paths
./example.njk
- Relative to file's directory.../example.njk
- Relative to file's parent directory.example.njk
- Relative to theindex.njk
directory.
Template tag
Wrap the markup with <template to='bp-template'>
-</template>
tag in .njk
files.
<template to='bp-template'>
<p>example</p>
</template>
Including template
Do not use the default Nunjucks {% include %}
tag, use {% template %}
tag instead.
src/example-dir/example.njk:
<template to='bp-template'>
<div>
<p>example</p>
</div>
</template>
src/index.njk:
<template to='bp-template'>
{% template "./example-dir/example.njk" %}
</template>
Output:
<div>
<p>example</p>
</div>
Including template from node modules
You can also include template from node modules:
<template to='bp-template'>
{% template "package-name/path/to/file.njk" %}
</template>
Learn how to create plugin for Bloggerpack by reading this section below.
Including assets
Use this tag to include compiled Sass, Skin, JS, and other CSS and JS assets:
{% asset type="skin|style|script", "./path/to/file" %}
Example:
<template to='bp-template'>
<head>
{# Auto style tag #}
{% asset type="style", "./dist/sass.css" %}
{# Auto skin tag #}
{% asset type="skin", "./dist/skin.css" %}
</head>
<body>
...
{# Auto script tag #}
{% asset type="script", "./dist/js.js" %}
</body>
</template>
Custom tag_start
and tag_end
:
{%
asset
tag_start="<b:if cond='!data:view.isLayoutMode'>\n<style>",
"./path/to/file.css",
tag_end="</style>\n</b:if>"
%}
{%
asset
tag_start="<script>\n//<![CDATA[",
"./path/to/file.js",
tag_end="//]]>\n</script>"
%}
Block tag:
{% asset %}
<b:if cond='!data:view.isLayoutMode'>
<style>
.element {
display: block;
}
</style>
</b:if>
{% endasset %}
{% asset %}
<script>
//<![CDATA[
console.log('Hello');
//]]>
</script>
{% endasset %}
Block tag with files:
Use {? asset ?}
tag.
{% asset %}
<b:if cond='!data:view.isLayoutMode'>
<style>
{? asset "./path/to/file1.css" ?}
{? asset "./path/to/file2.css" ?}
</style>
</b:if>
{% endasset %}
{% asset %}
<script>
//<![CDATA[
{? asset "./path/to/file1.js" ?}
{? asset "./path/to/file2.js" ?}
//]]>
</script>
{% endasset %}
Including assets from node modules
You can also include assets from node modules:
{% asset type="style", "package-name/path/to/file.css" %}
Extending template
Use Nunjucks {% extends %}
tag. See Nunjucks template inheritance.
src/layout.njk:
<template to='bp-template'>
<header>
{% block header %}{% endblock %}
</header>
<main>
{% block main %}{% endblock %}
</main>
<footer>
{% block footer %}{% endblock %}
</footer>
</template>
src/index.njk:
<template to='bp-template'>
{% extends "./layout.njk" %}
{% block header %}
This is header content.
{% endblock %}
{% block main %}
This is main content.
{% endblock %}
{% block footer %}
This is footer content.
{% endblock %}
</template>
Output:
<header>
This is header content.
</header>
<main>
This is main content.
</main>
<footer>
This is footer content.
</footer>
More Template example
Sass
Write your styles with Sass. You can also import Sass package from node modules.
Partialize
Do not write styles in src/sass/index.scss
directly. Add a new file (e.g., _my-component.scss
) within src/sass/
and than import the file to src/sass/index.scss
.
@import "my-component";
Sass-in-Template
You can write CSS for specific template in the template file directly using <style to='bp-sass'>
tag.
<template to='bp-template'>
<h1 class='example'>Example</h1>
</template>
<style to='bp-sass'>
$heading-color: #fff !default;
.example {
color: $heading-color;
}
</style>
The styles within the tag would be automatically extracted to src/sass/_sass-in-template.scss
.
More Sass example
Skin
Skin is CSS that support Blogger's skin variables to allow your theme to be able to customize through the Blogger theme designer.
Partialize
Do not write styles in src/skin/index.css
directly. Add a new file (e.g., my-component.css
) within src/skin/
and than import the file to src/skin/index.css
.
@import "my-component";
Skin-in-Template
You can write skin CSS for specific template in the template file directly using <style to='bp-skin'>
tag.
<template to='bp-template'>
<h1 class='example'>Example</h1>
</template>
<style to='bp-skin'>
/*
<Variable name="heading.color"
description="Heading color"
type="color"
default="#ffffff"
value="#ffffff"/>
*/
.example {
color: $(heading.color);
}
</style>
The styles within the tag would be automatically extracted to src/skin/skin-in-template.css
.
More Skin example
JS
The JavaScript. You can write your script with ES6+ and you can also import package from node modules.
Partialize
Do not write scripts in src/js/index.js
directly. Add a new file (e.g., util.js
) within src/js/
and than import the file to src/js/index.js
.
import './util';
JS-in-Template
You can write JavaScript for specific template in the template file directly using <script to='bp-js'>
tag.
<template to='bp-template'>
<h1 class='example' id='example'>Example</h1>
</template>
<script to='bp-js'>
var example = document.getElementById('example');
</script>
The JavaScript within the tag would be automatically extracted to src/js/js-in-template.js
.
More JS example
Creating theme variants
You may want to create a variants of theme with shared components and styles, and it can even be completely different.
To create a theme variant, just create a file named index-*.njk
in src
folder (e.g., src/index-variant-name.njk
).
The src/index-*.njk
would be compiled to dist/theme-*.xml
.
Example:
.
├── dist/
| ├── theme.xml <------------+
| ├── theme-one-column.xml <-|---+
| └── theme-offcanvas.xml <--|---|---+
└── src/ | | |
├── index.njk ------------>| | |
├── index-one-column.njk ----->| |
└── index-offcanvas.njk ---------->|
Feature removal
Remove Sass feature
If you don't need to use the Sass feature, just remove the src/sass
folder.
Note: you need to remove {% asset type="style", "./dist/sass.css" %}
(or similar) in your template.
Remove Skin feature
If you don't need to use the Skin feature, just remove the src/skin
folder.
Note: you need to remove {% asset type="skin", "./dist/skin.css" %}
(or similar) in your template.
Remove JS feature
If you don't need to use the JS feature, just remove the src/js
folder.
Note: you need to remove {% asset type="script", "./dist/js.js" %}
(or similar) in your template.
Remove linter
- CSS: To disable CSS linter, just remove the
.stylelintrc
file. - JS: To disable JS linter, just remove the
.eslintrc.json
file.
Creating plugins
You just need to write Bloggerpack's Template, Sass, Skin, and JS in a file with .njk
extension.
Example (my-plugin.njk
):
<template to='bp-template'>
Template here
</template>
<style to='bp-sass'>
CSS for the template here
</style>
<style to='bp-skin'>
Skin for the template here
</style>
<script to='bp-js'>
JS for the template here
</script>
The Sass, Skin, and JS are optional.
You can also create a standard .css
and .js
files.
Plugin package name
Plugin package names must start with bloggerpack-plugin-*
to automatically extract the Sass, Skin, and JS in template.
Learn how to include template from node modules by reading this section above. Read this section to include CSS and JS files.
Learn how to create npm package by reading its documentation.
Changelog
See CHANGELOG.
License
Licensed under MIT.
4 years ago