Security News
Node.js EOL Versions CVE Dubbed the "Worst CVE of the Year" by Security Experts
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
@amagaki/amagaki-plugin-page-builder
Advanced tools
[![NPM Version][npm-image]][npm-url] [![GitHub Actions][github-image]][github-url] [![TypeScript Style Guide][gts-image]][gts-url]
An opinionated page builder for Amagaki: the base template for constructing pages from content and templates.
npm install --save @amagaki/amagaki-plugin-page-builder
amagaki.ts
.import {PageBuilder} from '@amagaki/amagaki-plugin-page-builder';
import {Pod} from '@amagaki/amagaki';
export default (pod: Pod) => {
PageBuilder.register(pod);
};
# Page module templates.
/views/partials/{partial}.njk
# Page module JavaScript.
/dist/js/{partial}.js
# Page module CSS.
/dist/css/{partial}.css
Amagaki provides structure around how your site's content and templates are organized, but it doesn't provide any built-in structure for generating the markup used in HTML pages, or loading page modules. That's where this plugin comes in.
To use this plugin, get started by placing content within the /content
directory. A content document should then define a field partials
that lists
the partial content used by a page's modules.
# /content/index.yaml
partials:
- partial: hero
headline: Hello World!
- partial: banner
body: Lorem ipsum dolor sit amet.
In the above content document, we define the index.yaml
page to contain two
partials: hero
and banner
. These partials correspond to files in the
/views
directory, such as:
# /views/partials/hero.njk
<div class="hero">
{{partial.headline}}
</div>
The page builder plugin will render the page by looping over the items in the
partials
field and rendering the individual partial templates.
Furthermore, the page builder manages resource loading. By default, it will look for CSS and JS files corresponding to each partial template, and load them as needed on a per-module basis.
By default, the page builder looks for CSS and JS in the following directories:
/dist/css/{partial}.css
/dist/js/{partial}.js
In addition to rendering page modules using the partial loop, the page builder
also manages the <head>
tag and typical elements, such as elements used for
SEO and sharing metadata, as well as canonical
and alternate
links. These
elements are either configurable or managed automatically.
Refer to the PageBuilderOptions
interface for a full list of options.
The page builder includes a configurable layout grid inspector to simplify comparing a web page to a Figma design. The grid inspector can be configured across various breakpoints, with parameters that align to Figma's options:
See the example in the /example
directory for a full example, or refer to the
configuration below for example usage within amagaki.ts
.
PageBuilder.register(pod, {
head: {
siteName: 'Site Name',
twitterSite: '@username',
icon: pod.staticFile('/src/images/favicon.ico'),
scripts: [pod.staticFile('/dist/js/main.min.js')],
stylesheets: [
'https://fonts.googleapis.com/css?family=Material+Icons|Roboto:400,500,700&display=swap',
pod.staticFile('/dist/css/main.css'),
],
extra: ['/views/head.njk'],
},
body: {
extra: ['/views/body.njk'],
},
});
FAQs
[![NPM Version][npm-image]][npm-url] [![GitHub Actions][github-image]][github-url] [![TypeScript Style Guide][gts-image]][gts-url]
We found that @amagaki/amagaki-plugin-page-builder demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 2 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.