presentations/building-static-websites-sculpin/slides/slides.rst

724 lines
12 KiB
ReStructuredText
Raw Permalink Normal View History

2021-08-19 21:12:39 +01:00
Building static websites with Sculpin
#####################################
|
.. class:: titleslideinfo
2025-04-11 18:15:40 +01:00
Oliver Davies
.. raw:: pdf
2021-08-19 21:12:39 +01:00
2025-04-11 18:15:40 +01:00
PageBreak imagePage
2021-08-19 21:12:39 +01:00
2024-04-21 23:08:08 +01:00
.. image:: images/druplicon.png
2021-08-19 21:12:39 +01:00
:width: 10cm
.. raw:: pdf
PageBreak
2025-04-11 18:15:40 +01:00
TextAnnotation "I primarily work with Drupal and have been a Drupal developer since 2007/8."
TextAnnotation "Drupal, WordPress, etc need PHP and a database to run."
TextAnnotation "Difficult for new Developers."
TextAnnotation "Complex for personal projects."
TextAnnotation "Hosting can be expensive."
2021-08-19 21:12:39 +01:00
2024-04-21 23:08:08 +01:00
.. image:: images/sculpin.png
2021-08-19 21:12:39 +01:00
:width: 10cm
2025-04-11 18:15:40 +01:00
.. raw:: pdf
TextAnnotation "Sculpin - a static site generator written in PHP."
TextAnnotation "Not a Sculpin vs. x talk, but I'll make comparisons and comments based on my own experience."
PageBreak
2021-08-19 21:12:39 +01:00
2024-08-28 13:00:00 +01:00
What is a static website?
=========================
.. code::
.htaccess
assets/images/od-logo.jpg
2025-04-11 18:15:40 +01:00
bco/index.html
2024-08-28 13:00:00 +01:00
build/tailwind.css
call/index.html
daily/2024/03/18/automated-drupal-11-compatibility-fixes/index.html
drupal-upgrade/index.html
favicon.ico
index.html
podcast/19-sam-mortenson/index.html
pricing/index.html
talks/taking-flight-with-tailwind-css/index.html
talks/tdd-test-driven-drupal/index.html
.. raw:: pdf
2025-04-11 18:15:40 +01:00
TextAnnotation "Before I talk about static site generators, let's talk about static websites."
TextAnnotation "Some of the files from my website."
2024-08-28 13:00:00 +01:00
TextAnnotation "HTML, CSS, JS. No PHP or server-side code."
TextAnnotation "How I started building websites."
TextAnnotation "The things you usually have a CMS or framework generate."
2021-08-19 21:12:39 +01:00
What is Sculpin?
================
2025-04-11 18:15:40 +01:00
* Static site generator.
* Developed by Beau Simensen.
* Maintained by Kevin Boyd (beryllium).
* CLI tool.
* Built on Symfony components.
* Markdown + Twig = Static HTML.
2024-05-23 17:09:30 +01:00
.. raw:: pdf
TextAnnotation "Uses various Symfony components - Console, config, DI, Filesystem, Finder, HttpKernel, YAML."
TextAnnotation "Uses Twig - Symfony's templating language."
TextAnnotation ""
TextAnnotation "Transforms markdown files and Twig templates into static HTML websites, 'generates' a static website that can easily be deployed."
Why use a static site generator?
================================
- Rapid development.
2024-08-28 13:00:00 +01:00
- Templating.
2024-05-23 17:09:30 +01:00
- Security.
- Performance.
- Easy and cheap to host.
2025-04-11 18:15:40 +01:00
- Fun vs. work.
2024-05-23 17:09:30 +01:00
.. raw:: pdf
2024-08-28 13:00:00 +01:00
TextAnnotation "Leveraging templating features, such as conditionals, loops, partials and includes, template inheritance."
2024-05-23 17:09:30 +01:00
TextAnnotation "Static websites are fast and secure as they don't have a database and only need a simple hosting environment with a basic web server."
2024-08-28 13:00:00 +01:00
TextAnnotation "Works with a simple Apache, Nginx or Caddy server, or with services like Vercel and Netlify."
2021-08-19 21:12:39 +01:00
What do I use it for?
=====================
2025-04-11 18:15:40 +01:00
* My personal website.
2024-05-23 17:09:30 +01:00
* Some client websites.
* HTML prototypes and testing.
* Learning YAML and Twig (and some Symfony).
2021-08-19 21:12:39 +01:00
Installation
============
``composer require sculpin/sculpin``
2021-09-07 17:43:42 +01:00
|
``composer create-project sculpin/blog-skeleton my-blog``
|
``composer create-project opdavies/sculpin-skeleton my-site``
2021-08-19 21:12:39 +01:00
Using Sculpin
=============
2024-05-23 17:09:30 +01:00
* Configuration in ``app/config``
* Source files in ``source``.
* Templates in ``source/_templates`` or ``source/_layouts``.
* Includes in ``source/_includes`` or ``source/_partials``.
.. raw:: pdf
PageBreak
.. code-block::
:include: ./code/project-structure.txt
.. raw:: pdf
TextAnnotation "The file structure of a Sculpin project."
PageBreak
2024-08-28 13:00:00 +01:00
.. code-block:: bash
2024-05-23 17:09:30 +01:00
:include: ./code/project-structure.txt
2024-08-28 13:00:00 +01:00
:hl_lines: 5,6,13
2024-05-23 17:09:30 +01:00
.. raw:: pdf
TextAnnotation "PHP-based project."
PageBreak
2024-08-28 13:00:00 +01:00
.. code-block:: bash
2024-05-23 17:09:30 +01:00
:include: ./code/project-structure.txt
2024-08-28 13:00:00 +01:00
:hl_lines: 1,2,3,4
2024-05-23 17:09:30 +01:00
.. raw:: pdf
TextAnnotation "Configuration."
PageBreak
.. code-block:: shell
:include: ./code/project-structure.txt
2024-08-28 13:00:00 +01:00
:hl_lines: 9,10,11,12
2024-05-23 17:09:30 +01:00
.. raw:: pdf
TextAnnotation "Source files."
PageBreak
2024-08-28 13:00:00 +01:00
.. code-block:: bash
2024-05-23 17:09:30 +01:00
:include: ./code/project-structure.txt
2024-08-28 13:00:00 +01:00
:hl_lines: 7,8
2024-05-23 17:09:30 +01:00
.. raw:: pdf
TextAnnotation "Output directories with generated files."
2021-08-19 21:12:39 +01:00
Generate a site
===============
2021-09-07 17:43:42 +01:00
* ``vendor/bin/sculpin generate``
2021-08-19 21:12:39 +01:00
* ``--server``
* ``--watch``
* ``--env``
source/index.md
===============
2024-08-28 13:00:00 +01:00
.. code-block::
2021-08-19 21:12:39 +01:00
:include: code/index.md.txt
2024-05-23 17:09:30 +01:00
source/index.md
===============
2024-08-28 13:00:00 +01:00
.. code-block:: bash
2024-05-23 17:09:30 +01:00
:include: code/index.md.txt
:hl_lines: 1,2,3,4
source/index.md
===============
2024-08-28 13:00:00 +01:00
.. code-block:: bash
2024-05-23 17:09:30 +01:00
:include: code/index.md.txt
:hl_lines: 2
source/index.md
===============
2024-08-28 13:00:00 +01:00
.. code-block:: bash
2024-05-23 17:09:30 +01:00
:include: code/index.md.txt
:hl_lines: 3
source/index.md
===============
2024-08-28 13:00:00 +01:00
.. code-block:: bash
2024-05-23 17:09:30 +01:00
:include: code/index.md.txt
:hl_lines: 6
2021-08-19 21:12:39 +01:00
2021-09-07 17:43:42 +01:00
output_dev/index.html
=====================
.. code-block:: html
2024-05-23 17:09:30 +01:00
:include: ./code/index.html.txt
2021-09-07 17:43:42 +01:00
2024-05-23 17:09:30 +01:00
output_dev/index.html
=====================
.. code-block:: html
:include: ./code/index.html.txt
:hl_lines: 4
output_dev/index.html
=====================
.. code-block:: html
:include: ./code/index.html.txt
:hl_lines: 7
2021-09-07 17:43:42 +01:00
2021-08-19 21:12:39 +01:00
Configuration
=============
- Stored in ``app/config``
2024-05-23 17:09:30 +01:00
- ``sculpin_site.yml``
- ``sculpin_site_{env}.yml``
2021-08-19 21:12:39 +01:00
- Key-value pairs
2024-05-23 17:09:30 +01:00
|
2021-09-07 17:43:42 +01:00
.. code-block:: yaml
2021-08-19 21:12:39 +01:00
:include: code/configuration.txt
2021-09-07 17:43:42 +01:00
Using on pages
==============
.. code-block:: html
<!DOCTYPE html>
2024-05-23 17:09:30 +01:00
<html>
<head>
<title>{{ site.name }}</title>
</head>
</html>
2021-09-07 17:43:42 +01:00
2021-08-19 21:12:39 +01:00
YAML front matter
=================
.. code-block:: yaml
2024-05-23 17:09:30 +01:00
:include: ./code/front-matter1.txt
2021-08-19 21:12:39 +01:00
2024-05-23 17:09:30 +01:00
YAML front matter
=================
2021-08-19 21:12:39 +01:00
2024-05-23 17:09:30 +01:00
.. code-block:: yaml
:include: ./code/front-matter1.txt
:hl_lines: 2
YAML front matter
=================
.. code-block:: yaml
:include: ./code/front-matter1.txt
:hl_lines: 3
YAML front matter
=================
.. code-block:: yaml
:include: ./code/front-matter1.txt
:hl_lines: 4
.. raw:: pdf
2024-08-28 13:00:00 +01:00
TextAnnotation "Draft pages aren't generated when env=prod".
2021-08-19 21:12:39 +01:00
More front matter
=================
.. code-block:: yaml
2024-05-23 17:09:30 +01:00
:hl_lines: 5,6,7,8
2021-08-19 21:12:39 +01:00
---
layout: post
title: New blog post
draft: yes
tags:
2024-08-28 13:00:00 +01:00
- drupal
- php
- sculpin
2021-08-19 21:12:39 +01:00
---
Even more front matter
======================
.. code-block:: yaml
2024-05-23 17:09:30 +01:00
:hl_lines: 9,10
2021-08-19 21:12:39 +01:00
---
layout: post
title: New blog post
draft: yes
tags:
2024-08-28 13:00:00 +01:00
- drupal
- php
- sculpin
2021-08-19 21:12:39 +01:00
tweets: yes
foo: bar
---
Using on pages
==============
.. code-block:: twig
2024-05-23 17:09:30 +01:00
:include: ./code/front-matter-on-pages.txt
2021-08-19 21:12:39 +01:00
2024-05-23 17:09:30 +01:00
.. raw:: pdf
2021-08-19 21:12:39 +01:00
2024-05-23 17:09:30 +01:00
PageBreak
Using on pages
==============
.. code-block:: bash
:include: ./code/front-matter-on-pages.txt
:hl_lines: 3
.. raw:: pdf
PageBreak
Using on pages
==============
.. code-block:: bash
:include: ./code/front-matter-on-pages.txt
:hl_lines: 4,5,6
.. raw:: pdf
PageBreak
Using on pages
==============
.. code-block:: bash
:include: ./code/front-matter-on-pages.txt
:hl_lines: 9,12
.. raw:: pdf
PageBreak
Using on pages
==============
.. code-block:: bash
:include: ./code/front-matter-on-pages.txt
:hl_lines: 10
Using on pages
==============
.. code-block:: bash
:include: ./code/front-matter-on-pages.txt
:hl_lines: 11
.. raw:: pdf
TextAnnotation "`page.` instead of `site.`."
Layouts
=======
.. code-block:: twig
:include: ./code/layout-base.txt
2021-08-19 21:12:39 +01:00
2021-09-07 17:43:42 +01:00
Layouts
=======
.. code-block:: twig
2024-05-23 17:09:30 +01:00
:include: ./code/layout-base.txt
:hl_lines: 4,6
2021-09-07 17:43:42 +01:00
2024-05-23 17:09:30 +01:00
Layouts
=======
2021-09-07 17:43:42 +01:00
2024-05-23 17:09:30 +01:00
.. code-block:: twig
:include: ./code/layout-base.txt
:hl_lines: 9
2021-09-07 17:43:42 +01:00
Layouts
=======
.. code-block:: twig
2024-05-23 17:09:30 +01:00
:include: ./code/layout-page.txt
2021-09-07 17:43:42 +01:00
2024-05-23 17:09:30 +01:00
Layouts
=======
.. code-block:: twig
:include: ./code/layout-page.txt
:hl_lines: 3
Layouts
=======
.. code-block:: twig
:include: ./code/layout-page.txt
:hl_lines: 5,7
2021-09-07 17:43:42 +01:00
2024-05-23 17:09:30 +01:00
Layouts
=======
2021-09-07 17:43:42 +01:00
2024-05-23 17:09:30 +01:00
.. code-block:: twig
:include: ./code/layout-page.txt
:hl_lines: 6
2021-09-07 17:43:42 +01:00
Includes
========
.. code-block:: twig
{% include 'about-author' with {
avatar: site.avatar,
work: site.work,
} only %}
{% for link in links %}
{% include 'menu-link' with { link } only %}
{% endfor %}
2021-08-19 21:12:39 +01:00
Content types
=============
.. code-block:: yaml
# app/config/sculpin_kernel.yml
sculpin_content_types:
2024-08-28 13:00:00 +01:00
daily_emails:
permalink: daily/:slug_title/
2024-05-23 17:09:30 +01:00
.. raw:: pdf
TextAnnotation "A way to segregate content into different types - e.g. pages, talks, daily emails. Something that was familiar from working with Drupal."
2021-08-19 21:12:39 +01:00
Accessing custom content types
==============================
.. code-block:: yaml
2024-05-23 17:09:30 +01:00
:include: ./code/content-types.txt
2021-08-19 21:12:39 +01:00
2024-05-23 17:09:30 +01:00
Accessing custom content types
==============================
2021-09-07 17:43:42 +01:00
2024-05-23 17:09:30 +01:00
.. code-block:: yaml
:include: ./code/content-types.txt
:hl_lines: 4,5
Accessing custom content types
==============================
.. code-block:: yaml
:include: ./code/content-types.txt
:hl_lines: 8,9,10
.. raw:: pdf
PageBreak titlePage
.. class:: centredtitle
Making things more dynamic
.. raw:: pdf
PageBreak standardPage
.. code-block:: twig
:include: ./code/twig-1.txt
:hl_lines: 1
.. raw:: pdf
TextAnnotation "'today' as a string."
PageBreak
.. code-block:: twig
:include: ./code/twig-1.txt
:hl_lines: 3
.. raw:: pdf
TextAnnotation "Current date as a string."
PageBreak
.. code-block:: twig
:include: ./code/twig-1.txt
:hl_lines: 5
.. raw:: pdf
TextAnnotation "Current year."
PageBreak
.. code-block:: twig
:include: ./code/twig-1.txt
:hl_lines: 7
.. raw:: pdf
PageBreak
2024-09-06 01:40:48 +01:00
.. code-block:: twig
---
title: Daily Email Archive
use: [daily_emails]
---
This is an archive of the {{ data.daily_emails|length }}
email messages I have sent to my daily email list
since the 12th of August, 2022.
|
|
2025-04-11 18:15:40 +01:00
This is an archive of the 775 email messages I have sent to my daily email list since the 12th of August, 2022.
2024-09-06 01:40:48 +01:00
.. raw:: pdf
TextAnnotation "Get the emails via their content type and use the `length` filter to get the number of emails."
PageBreak
2024-05-23 17:09:30 +01:00
.. code-block:: php
:include: ./code/twig-2.txt
:end-before: // end yaml
.. raw:: pdf
PageBreak
.. code-block:: twig
:include: ./code/twig-2.txt
:start-after: // start twig
.. raw:: pdf
PageBreak
.. code-block:: twig
:include: ./code/twig-2.txt
:start-after: // start twig
:hl_lines: 1
.. raw:: pdf
PageBreak
.. code-block:: javascript
:include: ./code/twig-2.txt
:hl_lines: 3,7
:start-after: // start twig
.. raw:: pdf
TextAnnotation "Get each talk from the talk content type."
PageBreak
.. code-block:: twig
:include: ./code/twig-2.txt
:start-after: // start twig
:hl_lines: 4,6
.. raw:: pdf
PageBreak
.. code-block:: twig
:include: ./code/twig-2.txt
:start-after: // start twig
:hl_lines: 5
.. raw:: pdf
PageBreak
2024-09-06 01:40:48 +01:00
.. code-block:: twig
2024-05-23 17:09:30 +01:00
:include: ./code/twig-2.txt
:start-after: // start twig
:hl_lines: 9
.. raw:: pdf
PageBreak
.. code-block:: javascript
:include: ./code/twig-3.txt
2024-08-28 13:00:00 +01:00
.. raw:: pdf
PageBreak
.. code-block:: javascript
:include: ./code/twig-3.txt
:hl_lines: 1,3,15
.. raw:: pdf
PageBreak
.. code-block:: javascript
:include: ./code/twig-3.txt
:hl_lines: 5
2024-05-23 17:09:30 +01:00
.. raw:: pdf
PageBreak
.. code-block:: javascript
:include: ./code/twig-3.txt
2024-08-28 13:00:00 +01:00
:hl_lines: 9,11
2024-05-23 17:09:30 +01:00
.. raw:: pdf
PageBreak
.. code-block:: javascript
:include: ./code/twig-3.txt
2024-08-28 13:00:00 +01:00
:hl_lines: 10
2021-08-19 21:12:39 +01:00
2025-04-11 18:15:40 +01:00
.. raw:: pdf
PageBreak titlePage
2021-09-07 17:43:42 +01:00
.. class:: centredtitle
Demo
2025-04-11 18:15:40 +01:00
.. raw:: pdf
PageBreak standardPage
2021-09-07 17:43:42 +01:00
2021-08-19 21:12:39 +01:00
Extending Sculpin
=================
2021-09-07 17:43:42 +01:00
.. code-block:: yaml
# app/config/sculpin_kernel.yml
...
services:
2024-08-28 13:00:00 +01:00
App\TwigExtension\TalkExtension:
tags:
- { name: twig.extension }
2021-09-07 17:43:42 +01:00
2025-04-11 18:15:40 +01:00
.. raw:: pdf
PageBreak imagePage
2021-09-07 17:43:42 +01:00
.. image:: images/packagist.png
:width: 22cm
2025-04-11 18:15:40 +01:00
.. raw:: pdf
PageBreak standardPage
2021-09-07 17:43:42 +01:00
.. code-block:: php
:startinline: true
// app/SculpinKernel.php
use Opdavies\Sculpin\Bundle\TwigMarkdownBundle\SculpinTwigMarkdownBundle;
use Sculpin\Bundle\SculpinBundle\HttpKernel\AbstractKernel;
final class SculpinKernel extends AbstractKernel
{
protected function getAdditionalSculpinBundles(): array
{
return [
SculpinTwigMarkdownBundle::class,
];
}
}
2021-08-19 21:12:39 +01:00
Thanks!
=======
References:
2024-08-28 13:00:00 +01:00
|
2025-04-11 18:15:40 +01:00
* https://sculpin.io
* https://github.com/sculpin/sculpin
* https://code.oliverdavies.uk/opdavies/sculpin-demo
* https://code.oliverdavies.uk/opdavies/oliverdavies.uk
2021-08-19 21:12:39 +01:00
|
Me:
* https://www.oliverdavies.uk
2025-04-11 18:15:40 +01:00
* ``@opdavies@mastodon.social``