@def title = "Franklin Example" @def tags = ["syntax", "code"]
\tableofcontents
This section is meant as a refresher if you're new to Franklin.
Have a look at both how the website renders and the corresponding markdown (index.md
).
Modify at will to get a feeling for how things work!
Ps: if you want to modify the header or footer or the general look of the website, adjust the files in
src/_css/
andsrc/_html_parts/
.
The standard markdown syntax can be used such as titles using #
, lists:
- element with bold
- element with emph
or code-blocks inline
or with highlighting (note the @def hascode = true
in the source to allow highlight.js to do its job):
abstract type Point end
struct PointR2{T<:Real} <: Point
x::T
y::T
end
struct PointR3{T<:Real} <: Point
x::T
y::T
z::T
end
function len(p::T) where T<:Point
sqrt(sum(getfield(p, η)^2 for η ∈ fieldnames(T)))
end
You can also quote stuff
You must have chaos within you to ...
or have tables:
English | Mandarin |
---|---|
winnie the pooh | 维尼熊 |
Note that you may have to do a bit of CSS-styling to get these elements to look the way you want them (the same holds for the whole page in fact).
If you want a dollar sign you have to escape it like so: $, you can also use html entities like so: → or π or, if you're using Juno for instance, you can use \pi[TAB]
to insert the symbol as is: π (it will be converted to a html entity).1
If you want to show a backslash, just use it like so: \ ; if you want to force a line break, use a \\
like \ so (this is on a new line).2
If you want to show a backtick, escape it like so: ` and if you want to show a tick in inline code use double backticks like so ` ...
.
Footnotes are nice too:
It is sometimes useful to have a short way to make a part of the page belong to a div so that it can be styled separately.
You can do this easily with Franklin by using @@divname ... @@
.
For instance, you could want a blue background behind some text.
@@colbox-blue Here we go! (this is styled in the css sheet with name "colbox-blue"). @@
Since it's just a <div>
block, you can put this construction wherever you like and locally style your text.
Essentially three things are imitated from LaTeX
- you can introduce definitions using
\newcommand
- you can use hyper-references with
\eqref
,\cite
, ... - you can show nice maths (via KaTeX)
The definitions can be introduced in the page or in the config.md
(in which case they're available everywhere as opposed to just in that page).
For instance, the commands \scal
and \R
are defined in the config file (see src/config.md
) and can directly be used whereas the command \E
is defined below (and therefore only available on this page):
\newcommand{\E}[1]{\mathbb E\left[#1\right]}
Now we can write something like
since we've given it the label \label{equation blah}
, we can refer it like so: \eqref{equation blah} which can be convenient for pages that are math-heavy.
In a similar vein you can cite references that would be at the bottom of the page: \citep{noether15, bezanson17}.
Note: the LaTeX commands you define can also incorporate standard markdown (though not in a math environment) so for instance let's define a silly \bolditalic
command.
\newcommand{\bolditalic}[1]{!#1}
and use it \bolditalic{here for example}.
Here's another quick one, a command to change the color:
\newcommand{\col}[2]{~~~~~~!#2~~~~~~}
This is \col{blue}{in blue} or \col{#bf37bc}{in #bf37bc}.
For most commands you will use #k
to refer to the !#k
which will not introduce that whitespace.
It's probably easier to see this in action:
\newcommand{\pathwith}[1]{/usr/local/bin/#1
}
\newcommand{\pathwithout}[1]{/usr/local/bin/!#1
}
- with: \pathwith{script.jl}, there's a whitespace you don't want 🚫
- without: \pathwithout{script.jl} here there isn't ✅
You can include raw HTML by just surrounding a block with ~~~
.
Not much more to add.
This may be useful for local custom layouts like having a photo next to a text in a specific way.
<div class="row">
<div class="container">
<img class="left" src="/assets/rndimg.jpg">
<p>
Marine iguanas are truly splendid creatures. They're found on the Gálapagos islands, have skin that basically acts as a solar panel, can swim and may have the ability to adapt their body size depending on whether there's food or not.
</p>
<p>
Evolution is cool.
</p>
<div style="clear: both"></div>
</div>
</div>
Note 1: again, entire such blocks can be made into latex-like commands via \newcommand{\mynewblock}[1]{...}
.
Note 2: whatever is in a raw HTML block is not further processed (so you can't have LaTeX in there for instance). A partial way around this is to use @@...
blocks which will be recursively parsed. The following code gives the same result as above with the small difference that there is LaTeX being processed in the inner div.
@@row
@@container
@@left @@
@@
Marine iguanas are truly splendid creatures. They're not found in equations like
<div style="clear: both"></div>
@@
Here are a few empty pages connecting to the menu links to show where files can go and the resulting paths. (It's probably best if you look at the source folder for this).
- \biblabel{noether15}{Noether (1915)} Noether, Körper und Systeme rationaler Funktionen, 1915.
- \biblabel{bezanson17}{Bezanson et al. (2017)} Bezanson, Edelman, Karpinski and Shah, Julia: a fresh approach to numerical computing, SIAM review 2017.
As you can see here at the bottom of the page, there is a footer which you may want on all pages but for instance you may want the date of last modification to be displayed. In a fashion heavily inspired by Hugo, you can write things like
Last modified: {{ fill fd_mtime }}.
(cf. src/_html_parts/page_foot.html
) which will then replace these braces with the content of a dictionary of variables at the key fd_mtime
.
This dictionary of variables is accessed locally by pages through @def varname = value
and globally through the config.md
page via the same syntax.
There's a few other such functions of the form {{fname p₁ p₂}}
as well as support for conditional blocks. If you wander through the src/_html_parts/
folder and its content, you should be able to see those in action.
Footnotes
-
this is the text for the first footnote, you can style all this looking at
.fndef
elements; note that the whole footnote definition is expected to be on the same line. ↩ -
and this is a longer footnote with some blah from veggie ipsum: turnip greens yarrow ricebean rutabaga endive cauliflower sea lettuce kohlrabi amaranth water spinach avocado daikon napa cabbage asparagus winter purslane kale. Celery potato scallion desert raisin horseradish spinach carrot soko. ↩