This is the user documentation for Ansel. The content is authored in markdown and rendered to HTML using Hugo.
This repository tracks the current Ansel development version and can be found at ansel.photos.
git clone https://github.com/aurelienpierreeng/ansel-doc
This site is built with the static site generator Hugo v0.98.0
$ ./hugo version
The theme is imported from the main Ansel website. To force-update it:
$ hugo mod get -u ./...
If you have the repo cloned but need to update things, it helps to make sure everything is up to date (since we are also using a submodule for the base theme).
$ git pull
$ hugo mod get -u ./...
You can build the HTML website locally as follow:
Building the site to test locally can be done from the root of the repo.
$ hugo server -D
The site should then be available at http://localhost:1313/ (you can see the URL in the output of the hugo server
command).
Run the hugo
command:
$ hugo
The static files are now available to deploy to a webhost in the public
directory. This is currently performed automatically when new changes are pushed to the master branch, via github Actions.
The documentation is not a manual or a course. It should answer the questions :
- "what is the GUI doing ?"
- "how can I configure the software ?"
- "what are the bottlenecks, caveats, limitations and traps ?".
The documentation expects the reader to know what to do and will explain how to do it. Start-to-end workflows, tutorials, scientific background etc., aka the what and the why go on the main website.
The content folder is located in the content/
directory and the structure of folders and sub-folders will produce the structure of sections and sub-sections on the website. Files are written in Markdown and end with .md
extension. Each file should have the following header (frontmatter):
---
title: This page title
date: 2022-12-04T02:19:02+01:00
lastmod: 2022-12-31
draft: false
weight: 120
tags: [color science, pipeline]
---
- The title is mandatory. Please use initial capitals, like in real language.
- The date is set once for all at the creation of the page and should never change after.
- Update the
lastmod
date with today's date everytime you update a file, and add it if not present. On the internet, every content is perishable and this helps readers to guess wether the page is still relevant at the time of reading or not. draft
set totrue
means the page will be on the repository (in the source code) but will not appear on the website front-end. Set tofalse
, the page is visible on front-end.tags
are optional but welcome. The content is, by default, organized vertically (hierarchically). Tags help to create horizontal (thematic) links between pages. Relevant tags could be "film processing", "HDR", "monochrome", etc. Reuse existing tags in priority. Tags should always be a list, even when there is only one (otherwise Hugo build breaks).
Internal links should use relative paths from the current file. The upstream darktable-doc is a huge mess in that regard: trying to follow internal links locally in an IDE leads to non-existing files most of the time (typically, they have one ../
too many). For some reason, Hugo is still able to resolve them. Ideally, links should work both in source Markdown (Ctrl + Click on the path, in most IDEs) as in the compiled HTML.
Example of internal link:
[Filmic](../../module-reference/processing-modules/filmic-rgb.md)
The compiled HTML is checked for broken links with 2 different test suites (HTMLTest, written in Golang, and HTMLProofer, written in Ruby), on new pull requests and on each commit on master. The tests are run in the documentation scope (https://github.com/aurelienpierreeng/ansel-doc/) and in the main website scope (https://github.com/aurelienpierreeng/ansel-website), where the documentation is embedded as a Hugo module under $Lang/doc
(where $Lang
is the 2-letters language code). Relative URLs for internal links work automatically in both setups.
If you make links to page anchors, like /my-post.md#some-heading
, be sure to not insert a slash /
between the page slug and the hashtag #
in your Markdown code, or else the file will be taken for a directory and not found.
Also, always link to the Markdown files, like /my-post.md
, instead of /my-post
. If you need to link to sections, like /doc/
(although you should use relative pathes there), always link to their Markdown index, like /doc/_index.md
. While /my-post
and /doc
are technically valid URLs once the website is compiled to HTML, text editors, IDEs, file browsers as well as Hugo at compilation stage are not aware of these URL and only know local text files. Using links to actual text files solves many issues, helps debugging and ensures the robustness of the HTML build.
Many external websites will return HTML codes different than 200
(200 = everything fine) because the CI bot checking broken links is… a bot, and some websites block bots. The affected URLs can be added to the ignored list in .htmltest.yml to prevent false-negative. Anything returning a 404
code (page not found error) should be fixed.
H1 titles (encoded # Title
in Markdown) are reserved for page titles and each page should have exactly one H1. darktable-doc messed up big time here by using H1 as section titles, this is both a SEO and an accessibility mistake. The web is semantic because it's designed for crawlers and screen readers just as much as for humans.
Be aware that Hugo automatically generates anchor links for headings, using the text of the heading. Thus, refrain from using symbols in headings, especially (back)slashes, which will mess-up the anchor links.
Also be aware that these headings anchors may be used in other pages to make direct links. Changing the text of an heading will break its anchor and may break external links. Fortunately, the broken links CI bot also checks for internal anchors, so you just have to keep mind its output.
To avoid breaking anchors in external links, you can change the heading text but force their ID to the previous, like so:
### My New Heading {#my-old-heading}
This will preserve external links to /my-post/#my-old-heading
. See the details…
Images embedded in pages like my-post.md
should be stored in a folder named my-post
and located in the same directory as the original my-post.md
.
This will not work for images embedded in _index.md
files, which will need to be stored directly in the root the directory in which _index.md
is stored.
As for internal links, everything needs to be linked relatively to the source code as hosted on the local filesystem, not relatively to the compiled HTML.
Screenshots are the basics of any front-end software documentation. The darktable-doc maintainers refuse them on the ground that they can't be translated and they will be soon be obsolete given the frequency of GUI hanges, but it's a huge pedagogic mistake. Even in the wrong language, screenshots help to see what to look for in the window. Use them. They will get obsolete and may not be translated, just as the rest of the text.
The Ansel theme from the main website provides shortcodes to create alerts and info boxes using Hugo templating system. Here is the code:
{{< warning >}}
This is where you say what users should be aware of, because what may sound like a good idea in general may be really bad in some circumstances.
{{< /warning >}}
{{< note >}}
Your side note here.
{{< /note >}}
{{< advice >}}
Your friendly advice here.
{{< /advice >}}
{{< danger >}}
This is where you remind users that they are free to do shit but there will be consequences.
{{< /danger >}}
The content of the boxes can use Markdown too.
Again, using Hugo templating system, you can display before/after sliders where both images are overlayed. This resembles the Ansel & darktable darkroom snapshot feature and can efficiently explain the effect of modules and settings in a way that users can reproduce in the GUI. Both before and after images need to have the same size in pixels.
{{< compare after="./img-after.jpg" before="./img-before.jpg" >}}
Your slider legend goes here.
{{</ compare >}}
The docs support MathJax configured for LaTeX syntax support. Though the goal is not to write scientific litterature, there are some algorithms made of multiplications and additions that are more easily shown as equations rather than writing blocks of texts.
Inline LaTeX should be enclosed in $
, block equations enclosed in $$
. If you use LaTeX, you need to notify Hugo to append the Mathjax script on the page by setting latex: true
in the header/frontmatter of the Markdown page.
Ansel makes an heavy use of pipelines, and those are best described with flowcharts. Mermaid.js is now supported natively on Github and within Visual Studio Code and is great for that purpose. You can try it visually here and copy-paste the code of the graphs within Markdown code blocks like this:
```mermaid
graph TD
A[Christmas] -->|Get money| B(Go shopping)
B --> C{Let me think}
C -->|One| D[Laptop]
C -->|Two| E[iPhone]
C -->|Three| F[fa:fa-car Car]
```
On Github, this renders:
graph TD
A[Christmas] -->|Get money| B(Go shopping)
B --> C{Let me think}
C -->|One| D[Laptop]
C -->|Two| E[iPhone]
C -->|Three| F[fa:fa-car Car]
Icons from Font Awesome v5 are supported by Ansel main website and documentation, using the syntax fa:fa-YOUR-ICON-CODE
as shown in the example above. Use Font Awesome v5 search engine to get the fa-
code of the icons you may use.
Mermaid graphs are rendered client-side in SVG at display size and can be translated as text. Hugo is configured to detect these graphs automatically and load the javascript library only when needed.
Sometimes, it makes sense to reorganize the content and to changes the path of some pages. To not break external links, you must record the old url of the new page as an alias, in the frontmatter of the new page like so:
aliases: ["/my-old-url/", "/another-even-older-url"]
The documentation has an RSS localized feed, for now :
This is unusual and is meant to help users keep track of changes and evolutions, by subscribing to the RSS feed or by connecting it with bots.
The date of the documentation pages set in the RSS feed is the lastmod
parameter, aka the time of last modification. Since RSS doesn't have a jast modified date
, it's the best I have found for the time being.
Obsidian is a great editor, open-source, relying on Markdown and Typescript extensions to create personal knowledge bases. It's great to write docs and logbooks with hypertext, node graphs of links and tags. As Ansel doc, it supports Mermaid.js and LaTeX natively, and has helpers to create tables and assign tags. For internal links between files, it uses vanilla relative paths and can detect broken links or create new pages from unexisting links.
You can open the content/
folder as an Obsidian vault and edit Ansel docs with all the graphical helpers Obsidian provides. Just be aware that:
- Hugo Markdown doesn't support Obsidian call-outs. You have to use the alerts boxes shown above as Hugo shortcodes, but they will not render in Obsidian,
- Hugo doesn't support Obsidian wikilinks, so you will have to stick to usual Markdown links with relative pathes. That said, Obsidian provides paths auto-completion for those.
- Obsidian doesn't support definition lists, but you can still use them (they will just not be rendered in previews),
- Obsidian doesn't support headings IDs,
However:
- Obsidian supports Hugo tags in Yaml frontmatter, and implements them in a much nicer way that gives a lot more sense to horizontal content linking,
- Obsidian supports Hugo aliases for pages redirection,
You can start hugo server
in a terminal while editing the content in Obsidian. Once a file is saved in Obsidian, Hugo refreshes the website directly and you only have to keep track of errors in the terminal, to revert your changes if needed.
To see how to best use Obsidian to write Ansel docs, see https://github.com/aurelienpierreeng/ansel-website#open-obsidian.