This is a small script that generates a static website for showcasing visual examples of small Elm programs. An example in the wild is elm-visualization examples.
This program will process stuff in stages:
Generally you will want to make a directory (usually this is called /examples
) full of little Elm programs that you will want to showcase. This script will read every Elm file in the directory and provided that it explicitely exports main
it will consider it an example and process it.
Customized with:
--input-dir <dir>
tells it where to find the examples. Defaults to a directory called/examples
.
These programs should render some output that should all fit into some dimensions (the default is 990x504, but you can adjust the size as long as all examples have the same one). The script will compile each program (for this to work, you will also want to have an elm.json
in the examples directory), compress and optimize it, and write it to a file.
Customized with:
--output-dir <dir>
tells it where to write the output files. Defaults to a directory called/build
--no-compile
will skip this step. Useful mostly for quickly iterating on the templates (see below).
For each program a Chromium instance will navigate to it and take a screenshot of the output. These screenshots are then made into a series of responsive images - the full size screenshot is the 3x version, and a smaller 2x and 1x version is made. These are then written to disk.
Customized with:
--output-dir <dir>
tells it where to write the output files--no-screenshots
will skip this step. Not all example websites are visual and need screenshots.--width <pixels>
and--height <pixels>
set the dimensions of the screenshots (defaults to 990x504.)--debug
runs Chromium visibly so you can see what is going on
Optionally, these programs will be automatically uploaded to Elllie, where users can play with them.
Customized with:
--ellie
enables this step. To be gentle to the Ellie service, only enable this when you need it.--ellie-dep <username/package@version>
allows to add additional dependencies. Typically for development, you will use the parent/src
directory to develop your examples. But once you publish your package, you will want to the Ellies to include the published package.--base-url <url>
the base url where the produced website will be published. This will be used to fix links to external resources like styles and images.
Then, the script will load a template Elm program (by default this program resides in /docs/Docs.elm
) and run it to produce the relevant HTML. It will then compress and optimize this. It will copy any files from /docs/assets
and write this all to the output dir.
Customized with:
--output-dir <dir>
tells it where to write the output files--template-file <file>
tells it the path to the Elm template file used to produce the docs website. Defaults to/docs/Docs.elm
.--asset-path <dir>
this directory will be copied to the output path verbatim. Useful for things like styles or images for the website.
npm i -g elm-example-publisher
elm-example-publisher --help
will show options that can be configured at runtime.
You can most easily modify the output by changing the /docs/Docs.elm
template file. We provide a default template for you (used if /docs/Docs.elm
isn't found), but we recommend you copy this to your project and customize as you see fit. You can find it here.
Finally, you can add @tags
to your examples in the module comment. There are a few built in tags, but you also get access to the tags in your template. You can use that to implement categories for example.
This will cause the screenshot to wait the specifified number of seconds. Useful if you need some time (for example to load some resources) before you want the screenshot taken.
Sometimes example depend on some asset being available - a texture, data file, etc. This attribute ensures that the build time server correctly serves this asset when screenshotting as well as copying the asset to the correct directory. It will also prefix this path with --base-url
when uploading to Ellie.
If the example is an app that can respond to fragment URLs you might want to take screenshots of every screen. You can repeat this tag and a screenshot will be created. For example
{-|
@screenshot foo
@screenshot bar
-}
Will create:
preview@3x.png
,preview@3x.webp
,preview@2x.png
,preview@2x.webp
,preview.png
andpreview.webp
for/example
foo@3x.png
,foo@3x.webp
,foo@2x.png
,foo@2x.webp
,foo.png
andfoo.webp
for/example#foo
bar@3x.png
,bar@3x.webp
,bar@2x.png
,bar@2x.webp
,bar.png
andbar.webp
for/example#bar
MIT