initial
This commit is contained in:
parent
2c9d03bc44
commit
b040598c56
2
.gitignore
vendored
Normal file
2
.gitignore
vendored
Normal file
|
@ -0,0 +1,2 @@
|
|||
.env
|
||||
out/
|
10
generate.sh
Executable file
10
generate.sh
Executable file
|
@ -0,0 +1,10 @@
|
|||
#!/usr/bin/env bash
|
||||
|
||||
if [ -f ".env" ]; then
|
||||
source .env
|
||||
rm -rf "${OUT}/*"
|
||||
../roxy-cli/target/debug/roxy_cli ${IN} ${OUT}
|
||||
echo "$CNAME" > "${OUT}/CNAME"
|
||||
fi
|
||||
|
||||
|
15
gh-pages.sh
Executable file
15
gh-pages.sh
Executable file
|
@ -0,0 +1,15 @@
|
|||
#!/usr/bin/env bash
|
||||
|
||||
if [ -f ".env" ]; then
|
||||
source .env
|
||||
|
||||
rm -rf "$OUT"
|
||||
git worktree add "$OUT" "$GH_PAGES_BRANCH"
|
||||
./generate.sh
|
||||
(cd "$OUT"; git add -f .)
|
||||
(cd "$OUT"; git commit -m "Built from $(git log '--format=format:%H' main -1)")
|
||||
git push origin "$GH_PAGES_BRANCH"
|
||||
git worktree remove "$OUT"
|
||||
fi
|
||||
|
||||
|
6
in/index.md
Normal file
6
in/index.md
Normal file
|
@ -0,0 +1,6 @@
|
|||
{% extends "../layouts/index.tera" %}
|
||||
|
||||
{% block main %}
|
||||
# Roxy
|
||||
{% endblock main %}
|
||||
|
0
in/index.toml
Normal file
0
in/index.toml
Normal file
19
in/pages/guides/configuration.md
Normal file
19
in/pages/guides/configuration.md
Normal file
|
@ -0,0 +1,19 @@
|
|||
{% extends "../../../layouts/topic.tera" %}
|
||||
|
||||
{% block content %}
|
||||
`roxy-cli` uses a configuration file in the root of the project directory, `config.toml`.
|
||||
|
||||
```toml
|
||||
[roxy]
|
||||
slug_word_limit = 8 # the max word limit for a slug
|
||||
|
||||
[syntect]
|
||||
theme = "base16-ocean.dark" # the name of the theme for syntax highlighting
|
||||
theme_dir = "./themes" # directory to load themes into syntect
|
||||
```
|
||||
|
||||
* `roxy.slug_wold_limit` limits the amount of words during slug generation
|
||||
* `syntect.theme` is the key that should be used for syntax highlighting
|
||||
* `syntect.theme_dir` is the directory that should be read and loaded to find syntax themes
|
||||
{% endblock content %}
|
||||
|
4
in/pages/guides/configuration.toml
Normal file
4
in/pages/guides/configuration.toml
Normal file
|
@ -0,0 +1,4 @@
|
|||
title = "Configuration"
|
||||
type = "page"
|
||||
order = 0
|
||||
|
0
in/pages/guides/index.md
Normal file
0
in/pages/guides/index.md
Normal file
4
in/pages/guides/index.toml
Normal file
4
in/pages/guides/index.toml
Normal file
|
@ -0,0 +1,4 @@
|
|||
title = "Guides"
|
||||
type = "category"
|
||||
order = 3
|
||||
|
13
in/pages/overview.md
Normal file
13
in/pages/overview.md
Normal file
|
@ -0,0 +1,13 @@
|
|||
{% extends "../../layouts/topic.tera" %}
|
||||
|
||||
{% block content %}
|
||||
Roxy is a static site generator. The hope is that using it will reduce the amount of boilerplate HTML that usually comes with handwriting static websites.
|
||||
|
||||
[roxy-cli](https://fem.mint.lgbt/kitsunecafe/roxy-cli) is a tool written using the [roxy-core](https://fem.mint.lgbt/kitsunecafe/roxy-core) which achieves the above goal by using markdown and templating. The default parsers are
|
||||
* [pulldown_cmark](https://docs.rs/pulldown-cmark/0.10.0/pulldown_cmark/) for Markdown to HTML
|
||||
* [Tera](https://docs.rs/tera/1.19.1/tera/index.html) for templating
|
||||
* [Syntect](https://docs.rs/syntect/5.2.0/syntect/index.html) for syntax highlighting
|
||||
|
||||
This tool was written for my use case and there is a high chance it may not support yours. In that case, do some combination of the following things: open an issue against `roxy-cli`, write your own generator using `roxy-core`, or find another generator (it won't hurt my feelings, promise).
|
||||
{% endblock content %}
|
||||
|
4
in/pages/overview.toml
Normal file
4
in/pages/overview.toml
Normal file
|
@ -0,0 +1,4 @@
|
|||
title = "Overview"
|
||||
type = "page"
|
||||
order = 0
|
||||
|
84
in/pages/quick-start.md
Normal file
84
in/pages/quick-start.md
Normal file
|
@ -0,0 +1,84 @@
|
|||
{% extends "../../layouts/topic.tera" %}
|
||||
|
||||
{% block content %}
|
||||
|
||||
## Your first page
|
||||
We're going to speedrun making your first site with Roxy.
|
||||
|
||||
Create a new directory for the project.
|
||||
|
||||
```bash
|
||||
mkdir my-new-site
|
||||
cd my-new-site
|
||||
```
|
||||
|
||||
Create two direcroties in your new project, one for input and one for output.
|
||||
|
||||
```bash
|
||||
mkdir {input,output}
|
||||
```
|
||||
|
||||
Create a new file with some markdown content in `input` to add a page.
|
||||
|
||||
```bash
|
||||
touch input/index.md
|
||||
cat << EOF > input/index.md
|
||||
# Hello, world!
|
||||
This is my new site!
|
||||
EOF
|
||||
```
|
||||
|
||||
Build the site with `roxy-cli`.
|
||||
|
||||
```bash
|
||||
roxy-cli ./input/ ./output/
|
||||
```
|
||||
|
||||
Host the content and view it.
|
||||
|
||||
```bash
|
||||
cd output
|
||||
python3 -m http.server # visit localhost:8000 with your browser
|
||||
```
|
||||
|
||||
## Adding a layout
|
||||
At the top level of your project, create a new directory and add a new file. We don't want this being built with the rest of the content.
|
||||
|
||||
```bash
|
||||
mkdir layouts
|
||||
touch layouts/base.tera
|
||||
```
|
||||
|
||||
Let's add some boilerplate HTML to `layouts/base.tera`
|
||||
```html
|
||||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="UTF-8">
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||
<meta http-equiv="X-UA-Compatible" content="ie=edge">
|
||||
<title>My New Site!</title>
|
||||
</head>
|
||||
<body>{% raw -%}
|
||||
{% block body %}{% endblock body %}{% endraw %}
|
||||
</body>
|
||||
</html>
|
||||
```
|
||||
|
||||
The `{% raw %}{% ... %}{% endraw %}` bit is the [Tera templating language](https://keats.github.io/tera/docs/) (it's meant to look like Jinja, if you're familiar with that). This syntax is how we do fun templating things -- in this case, we're creating a `block` that other pages can fill later.
|
||||
|
||||
Let's go back to `input/index.md` and use this layout.
|
||||
|
||||
```md
|
||||
{%- raw -%}{% extends "../layouts/base.tera" %}
|
||||
{% block body %}{% endraw -%}
|
||||
# Hello, world!
|
||||
This is my new site!{% raw -%}
|
||||
{% endblock body %}{% endraw -%}
|
||||
```
|
||||
|
||||
Build the site again, host it, and look at the result. There should be a title that says "My New Site!" and the content should be the same. Check out the `output` folder to get an idea of how Roxy builds and structures files.
|
||||
|
||||
Tera has many more features to explore, so I'd highly recommend looking at the [documentation](https://keats.github.io/tera/docs/).
|
||||
{% endblock content %}
|
||||
|
4
in/pages/quick-start.toml
Normal file
4
in/pages/quick-start.toml
Normal file
|
@ -0,0 +1,4 @@
|
|||
title = "Quick start"
|
||||
type = "page"
|
||||
order = 1
|
||||
|
108
in/static/css/nav.css
Normal file
108
in/static/css/nav.css
Normal file
|
@ -0,0 +1,108 @@
|
|||
aside.navigation {
|
||||
background-color: var(--primary-color);
|
||||
color: var(--font-color-primary);
|
||||
padding-left: 2rem;
|
||||
padding-right: 2rem;
|
||||
width: 100%;
|
||||
}
|
||||
|
||||
.logo {
|
||||
display: inline-block;
|
||||
font-weight: bold;
|
||||
}
|
||||
|
||||
.hamburger {
|
||||
--size: 4rem;
|
||||
width: var(--size);
|
||||
height: var(--size);
|
||||
cursor: pointer;
|
||||
float: right;
|
||||
padding: 36px 20px;
|
||||
}
|
||||
|
||||
.hamburger-line {
|
||||
background: var(--white);
|
||||
display: block;
|
||||
height: 2px;
|
||||
position: relative;
|
||||
width: 24px;
|
||||
}
|
||||
|
||||
.hamburger-line::before,
|
||||
.hamburger-line::after{
|
||||
background: var(--white);
|
||||
content: '';
|
||||
display: block;
|
||||
height: 100%;
|
||||
position: absolute;
|
||||
transition: all .2s ease-out;
|
||||
width: 100%;
|
||||
}
|
||||
.hamburger-line::before{
|
||||
top: 5px;
|
||||
}
|
||||
.hamburger-line::after{
|
||||
top: -5px;
|
||||
}
|
||||
|
||||
.menu {
|
||||
max-height: 0;
|
||||
transition: height .5s ease-out;
|
||||
overflow: hidden;
|
||||
}
|
||||
|
||||
.logo {
|
||||
padding-top: 1rem;
|
||||
}
|
||||
|
||||
#menu-toggle {
|
||||
display: none;
|
||||
}
|
||||
|
||||
#menu-toggle:checked ~ nav.menu {
|
||||
max-height: 100%;
|
||||
}
|
||||
|
||||
#menu-toggle:checked ~ .hamburger .hamburger-line {
|
||||
background: transparent;
|
||||
}
|
||||
|
||||
#menu-toggle:checked ~ .hamburger .hamburger-line::before {
|
||||
transform: rotate(-45deg);
|
||||
top: 0;
|
||||
}
|
||||
|
||||
#menu-toggle:checked ~ .hamburger .hamburger-line::after {
|
||||
transform: rotate(45deg);
|
||||
top: 0;
|
||||
}
|
||||
|
||||
.menu-item-list {
|
||||
list-style: none;
|
||||
padding-left: 2rem;
|
||||
font-size: calc(var(--default-font-size) * 1.1);
|
||||
border-left: 1px solid var(--softer-white);
|
||||
line-height: 4rem;
|
||||
}
|
||||
|
||||
.menu-item-list a {
|
||||
text-decoration: none;
|
||||
}
|
||||
|
||||
/* Desktop styling */
|
||||
@media only screen and (min-width: 768px) {
|
||||
aside.navigation {
|
||||
height: 100%;
|
||||
max-width: 25rem;
|
||||
}
|
||||
|
||||
.menu {
|
||||
max-height: 100%;
|
||||
max-width: 25rem;
|
||||
}
|
||||
|
||||
#menu-toggle, .hamburger {
|
||||
display: none;
|
||||
}
|
||||
}
|
||||
|
129
in/static/css/style.css
Normal file
129
in/static/css/style.css
Normal file
|
@ -0,0 +1,129 @@
|
|||
@import "/static/fonts/roboto_regular/stylesheet.css";
|
||||
@import "/static/fonts/spacemono_bold/stylesheet.css";
|
||||
@import "/static/css/nav.css";
|
||||
|
||||
/* Variables */
|
||||
:root {
|
||||
--black: #000000;
|
||||
--soft-black: #181a1b;
|
||||
--softer-black: #282828;
|
||||
--softest-black: #323232;
|
||||
--white: #ffffff;
|
||||
--soft-white: #d7d3ce;
|
||||
--softer-white: #969696;
|
||||
--indigo: #4b0082;
|
||||
|
||||
--background-color: var(--soft-black);
|
||||
--foreground-color: var(--softest-black);
|
||||
--primary-color: var(--indigo);
|
||||
|
||||
--default-font-size: 1.4rem;
|
||||
--desktop-font-size: 1.8rem;
|
||||
--font-color-primary: var(--white);
|
||||
--font-family-paragraph: "robotoregular", sans-serif;
|
||||
|
||||
--font-color-secondary: var(--white);
|
||||
--font-family-header: sans-serif;
|
||||
|
||||
--link-color: var(--soft-white);
|
||||
}
|
||||
|
||||
/* Boilerplate */
|
||||
@media (prefers-reduced-motion: no-preference) {
|
||||
html {
|
||||
scroll-behavior: smooth;
|
||||
}
|
||||
}
|
||||
|
||||
:focus:not(:focus-visible) {
|
||||
outline: none;
|
||||
}
|
||||
|
||||
*,
|
||||
*::before,
|
||||
*::after {
|
||||
box-sizing: border-box;
|
||||
}
|
||||
|
||||
html, body {
|
||||
margin: 0;
|
||||
padding: 0;
|
||||
height: 100%;
|
||||
text-rendering: optimizeLegibility;
|
||||
font-kerning: normal;
|
||||
line-height: 2rem;
|
||||
}
|
||||
|
||||
html {
|
||||
font-size: 62.5%;
|
||||
}
|
||||
|
||||
|
||||
a {
|
||||
text-underline-position: under;
|
||||
text-decoration-thickness: 8;
|
||||
}
|
||||
|
||||
pre {
|
||||
padding: 0.5rem;
|
||||
}
|
||||
|
||||
img {
|
||||
display: block;
|
||||
max-width: 100%;
|
||||
}
|
||||
|
||||
label,
|
||||
button,
|
||||
select,
|
||||
summary,
|
||||
[type=radio],
|
||||
[type=submit],
|
||||
[type=checkbox] {
|
||||
cursor: pointer;
|
||||
}
|
||||
|
||||
article ol,
|
||||
article ul {
|
||||
list-style-position: inside;
|
||||
}
|
||||
|
||||
/* Styling */
|
||||
body {
|
||||
background-color: var(--background-color);
|
||||
color: var(--font-color-primary);
|
||||
font-family: var(--font-family-paragraph);
|
||||
font-size: var(--default-font-size);
|
||||
|
||||
-webkit-text-size-adjust: none;
|
||||
text-size-adjust: none;
|
||||
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
}
|
||||
|
||||
@media only screen and (min-width: 768px) {
|
||||
body {
|
||||
flex-direction: row;
|
||||
font-size: var(--desktop-font-size);
|
||||
}
|
||||
}
|
||||
|
||||
h1, h2, h3, h4, h5, h6 {
|
||||
font-family: var(--font-family-header);
|
||||
}
|
||||
|
||||
main {
|
||||
padding: 2rem;
|
||||
width: 100%;
|
||||
overflow: auto;
|
||||
padding-bottom: 8rem;
|
||||
}
|
||||
|
||||
|
||||
a { color: var(--link-color); }
|
||||
a:hover { color: var(--link-color); }
|
||||
a:visited { color: var(--link-color); }
|
||||
a:active { color: var(--link-color); }
|
||||
|
||||
|
BIN
in/static/fonts/roboto_regular/Roboto-Regular-webfont.woff
Normal file
BIN
in/static/fonts/roboto_regular/Roboto-Regular-webfont.woff
Normal file
Binary file not shown.
Binary file not shown.
After Width: | Height: | Size: 84 KiB |
|
@ -0,0 +1,129 @@
|
|||
/*Notes about grid:
|
||||
Columns: 12
|
||||
Grid Width: 825px
|
||||
Column Width: 55px
|
||||
Gutter Width: 15px
|
||||
-------------------------------*/
|
||||
|
||||
|
||||
|
||||
.section {margin-bottom: 18px;
|
||||
}
|
||||
.section:after {content: ".";display: block;height: 0;clear: both;visibility: hidden;}
|
||||
.section {*zoom: 1;}
|
||||
|
||||
.section .firstcolumn,
|
||||
.section .firstcol {margin-left: 0;}
|
||||
|
||||
|
||||
/* Border on left hand side of a column. */
|
||||
.border {
|
||||
padding-left: 7px;
|
||||
margin-left: 7px;
|
||||
border-left: 1px solid #eee;
|
||||
}
|
||||
|
||||
/* Border with more whitespace, spans one column. */
|
||||
.colborder {
|
||||
padding-left: 42px;
|
||||
margin-left: 42px;
|
||||
border-left: 1px solid #eee;
|
||||
}
|
||||
|
||||
|
||||
|
||||
/* The Grid Classes */
|
||||
.grid1, .grid1_2cols, .grid1_3cols, .grid1_4cols, .grid2, .grid2_3cols, .grid2_4cols, .grid3, .grid3_2cols, .grid3_4cols, .grid4, .grid4_3cols, .grid5, .grid5_2cols, .grid5_3cols, .grid5_4cols, .grid6, .grid6_4cols, .grid7, .grid7_2cols, .grid7_3cols, .grid7_4cols, .grid8, .grid8_3cols, .grid9, .grid9_2cols, .grid9_4cols, .grid10, .grid10_3cols, .grid10_4cols, .grid11, .grid11_2cols, .grid11_3cols, .grid11_4cols, .grid12
|
||||
{margin-left: 15px;float: left;display: inline; overflow: hidden;}
|
||||
|
||||
|
||||
.width1, .grid1, .span-1 {width: 55px;}
|
||||
.width1_2cols,.grid1_2cols {width: 20px;}
|
||||
.width1_3cols,.grid1_3cols {width: 8px;}
|
||||
.width1_4cols,.grid1_4cols {width: 2px;}
|
||||
.input_width1 {width: 49px;}
|
||||
|
||||
.width2, .grid2, .span-2 {width: 125px;}
|
||||
.width2_3cols,.grid2_3cols {width: 31px;}
|
||||
.width2_4cols,.grid2_4cols {width: 20px;}
|
||||
.input_width2 {width: 119px;}
|
||||
|
||||
.width3, .grid3, .span-3 {width: 195px;}
|
||||
.width3_2cols,.grid3_2cols {width: 90px;}
|
||||
.width3_4cols,.grid3_4cols {width: 37px;}
|
||||
.input_width3 {width: 189px;}
|
||||
|
||||
.width4, .grid4, .span-4 {width: 265px;}
|
||||
.width4_3cols,.grid4_3cols {width: 78px;}
|
||||
.input_width4 {width: 259px;}
|
||||
|
||||
.width5, .grid5, .span-5 {width: 335px;}
|
||||
.width5_2cols,.grid5_2cols {width: 160px;}
|
||||
.width5_3cols,.grid5_3cols {width: 101px;}
|
||||
.width5_4cols,.grid5_4cols {width: 72px;}
|
||||
.input_width5 {width: 329px;}
|
||||
|
||||
.width6, .grid6, .span-6 {width: 405px;}
|
||||
.width6_4cols,.grid6_4cols {width: 90px;}
|
||||
.input_width6 {width: 399px;}
|
||||
|
||||
.width7, .grid7, .span-7 {width: 475px;}
|
||||
.width7_2cols,.grid7_2cols {width: 230px;}
|
||||
.width7_3cols,.grid7_3cols {width: 148px;}
|
||||
.width7_4cols,.grid7_4cols {width: 107px;}
|
||||
.input_width7 {width: 469px;}
|
||||
|
||||
.width8, .grid8, .span-8 {width: 545px;}
|
||||
.width8_3cols,.grid8_3cols {width: 171px;}
|
||||
.input_width8 {width: 539px;}
|
||||
|
||||
.width9, .grid9, .span-9 {width: 615px;}
|
||||
.width9_2cols,.grid9_2cols {width: 300px;}
|
||||
.width9_4cols,.grid9_4cols {width: 142px;}
|
||||
.input_width9 {width: 609px;}
|
||||
|
||||
.width10, .grid10, .span-10 {width: 685px;}
|
||||
.width10_3cols,.grid10_3cols {width: 218px;}
|
||||
.width10_4cols,.grid10_4cols {width: 160px;}
|
||||
.input_width10 {width: 679px;}
|
||||
|
||||
.width11, .grid11, .span-11 {width: 755px;}
|
||||
.width11_2cols,.grid11_2cols {width: 370px;}
|
||||
.width11_3cols,.grid11_3cols {width: 241px;}
|
||||
.width11_4cols,.grid11_4cols {width: 177px;}
|
||||
.input_width11 {width: 749px;}
|
||||
|
||||
.width12, .grid12, .span-12 {width: 825px;}
|
||||
.input_width12 {width: 819px;}
|
||||
|
||||
/* Subdivided grid spaces */
|
||||
.emptycols_left1, .prepend-1 {padding-left: 70px;}
|
||||
.emptycols_right1, .append-1 {padding-right: 70px;}
|
||||
.emptycols_left2, .prepend-2 {padding-left: 140px;}
|
||||
.emptycols_right2, .append-2 {padding-right: 140px;}
|
||||
.emptycols_left3, .prepend-3 {padding-left: 210px;}
|
||||
.emptycols_right3, .append-3 {padding-right: 210px;}
|
||||
.emptycols_left4, .prepend-4 {padding-left: 280px;}
|
||||
.emptycols_right4, .append-4 {padding-right: 280px;}
|
||||
.emptycols_left5, .prepend-5 {padding-left: 350px;}
|
||||
.emptycols_right5, .append-5 {padding-right: 350px;}
|
||||
.emptycols_left6, .prepend-6 {padding-left: 420px;}
|
||||
.emptycols_right6, .append-6 {padding-right: 420px;}
|
||||
.emptycols_left7, .prepend-7 {padding-left: 490px;}
|
||||
.emptycols_right7, .append-7 {padding-right: 490px;}
|
||||
.emptycols_left8, .prepend-8 {padding-left: 560px;}
|
||||
.emptycols_right8, .append-8 {padding-right: 560px;}
|
||||
.emptycols_left9, .prepend-9 {padding-left: 630px;}
|
||||
.emptycols_right9, .append-9 {padding-right: 630px;}
|
||||
.emptycols_left10, .prepend-10 {padding-left: 700px;}
|
||||
.emptycols_right10, .append-10 {padding-right: 700px;}
|
||||
.emptycols_left11, .prepend-11 {padding-left: 770px;}
|
||||
.emptycols_right11, .append-11 {padding-right: 770px;}
|
||||
.pull-1 {margin-left: -70px;}
|
||||
.push-1 {margin-right: -70px;margin-left: 18px;float: right;}
|
||||
.pull-2 {margin-left: -140px;}
|
||||
.push-2 {margin-right: -140px;margin-left: 18px;float: right;}
|
||||
.pull-3 {margin-left: -210px;}
|
||||
.push-3 {margin-right: -210px;margin-left: 18px;float: right;}
|
||||
.pull-4 {margin-left: -280px;}
|
||||
.push-4 {margin-right: -280px;margin-left: 18px;float: right;}
|
|
@ -0,0 +1,396 @@
|
|||
@import url('grid_12-825-55-15.css');
|
||||
|
||||
/*
|
||||
CSS Reset by Eric Meyer - Released under Public Domain
|
||||
http://meyerweb.com/eric/tools/css/reset/
|
||||
*/
|
||||
html, body, div, span, applet, object, iframe,
|
||||
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
|
||||
a, abbr, acronym, address, big, cite, code,
|
||||
del, dfn, em, font, img, ins, kbd, q, s, samp,
|
||||
small, strike, strong, sub, sup, tt, var,
|
||||
b, u, i, center, dl, dt, dd, ol, ul, li,
|
||||
fieldset, form, label, legend, table,
|
||||
caption, tbody, tfoot, thead, tr, th, td
|
||||
{margin: 0;padding: 0;border: 0;outline: 0;
|
||||
font-size: 100%;vertical-align: baseline;
|
||||
background: transparent;}
|
||||
body {line-height: 1;}
|
||||
ol, ul {list-style: none;}
|
||||
blockquote, q {quotes: none;}
|
||||
blockquote:before, blockquote:after,
|
||||
q:before, q:after {content: ''; content: none;}
|
||||
:focus {outline: 0;}
|
||||
ins {text-decoration: none;}
|
||||
del {text-decoration: line-through;}
|
||||
table {border-collapse: collapse;border-spacing: 0;}
|
||||
|
||||
|
||||
|
||||
|
||||
body {
|
||||
color: #000;
|
||||
background-color: #dcdcdc;
|
||||
}
|
||||
|
||||
a {
|
||||
text-decoration: none;
|
||||
color: #1883ba;
|
||||
}
|
||||
|
||||
h1{
|
||||
font-size: 32px;
|
||||
font-weight: normal;
|
||||
font-style: normal;
|
||||
margin-bottom: 18px;
|
||||
}
|
||||
|
||||
h2{
|
||||
font-size: 18px;
|
||||
}
|
||||
|
||||
#container {
|
||||
width: 865px;
|
||||
margin: 0px auto;
|
||||
}
|
||||
|
||||
|
||||
#header {
|
||||
padding: 20px;
|
||||
font-size: 36px;
|
||||
background-color: #000;
|
||||
color: #fff;
|
||||
}
|
||||
|
||||
#header span {
|
||||
color: #666;
|
||||
}
|
||||
#main_content {
|
||||
background-color: #fff;
|
||||
padding: 60px 20px 20px;
|
||||
}
|
||||
|
||||
|
||||
#footer p {
|
||||
margin: 0;
|
||||
padding-top: 10px;
|
||||
padding-bottom: 50px;
|
||||
color: #333;
|
||||
font: 10px Arial, sans-serif;
|
||||
}
|
||||
|
||||
.tabs {
|
||||
width: 100%;
|
||||
height: 31px;
|
||||
background-color: #444;
|
||||
}
|
||||
.tabs li {
|
||||
float: left;
|
||||
margin: 0;
|
||||
overflow: hidden;
|
||||
background-color: #444;
|
||||
}
|
||||
.tabs li a {
|
||||
display: block;
|
||||
color: #fff;
|
||||
text-decoration: none;
|
||||
font: bold 11px/11px 'Arial';
|
||||
text-transform: uppercase;
|
||||
padding: 10px 15px;
|
||||
border-right: 1px solid #fff;
|
||||
}
|
||||
|
||||
.tabs li a:hover {
|
||||
background-color: #00b3ff;
|
||||
|
||||
}
|
||||
|
||||
.tabs li.active a {
|
||||
color: #000;
|
||||
background-color: #fff;
|
||||
}
|
||||
|
||||
|
||||
|
||||
div.huge {
|
||||
|
||||
font-size: 300px;
|
||||
line-height: 1em;
|
||||
padding: 0;
|
||||
letter-spacing: -.02em;
|
||||
overflow: hidden;
|
||||
}
|
||||
div.glyph_range {
|
||||
font-size: 72px;
|
||||
line-height: 1.1em;
|
||||
}
|
||||
|
||||
.size10{ font-size: 10px; }
|
||||
.size11{ font-size: 11px; }
|
||||
.size12{ font-size: 12px; }
|
||||
.size13{ font-size: 13px; }
|
||||
.size14{ font-size: 14px; }
|
||||
.size16{ font-size: 16px; }
|
||||
.size18{ font-size: 18px; }
|
||||
.size20{ font-size: 20px; }
|
||||
.size24{ font-size: 24px; }
|
||||
.size30{ font-size: 30px; }
|
||||
.size36{ font-size: 36px; }
|
||||
.size48{ font-size: 48px; }
|
||||
.size60{ font-size: 60px; }
|
||||
.size72{ font-size: 72px; }
|
||||
.size90{ font-size: 90px; }
|
||||
|
||||
|
||||
.psample_row1 { height: 120px;}
|
||||
.psample_row1 { height: 120px;}
|
||||
.psample_row2 { height: 160px;}
|
||||
.psample_row3 { height: 160px;}
|
||||
.psample_row4 { height: 160px;}
|
||||
|
||||
.psample {
|
||||
overflow: hidden;
|
||||
position: relative;
|
||||
}
|
||||
.psample p {
|
||||
line-height: 1.3em;
|
||||
display: block;
|
||||
overflow: hidden;
|
||||
margin: 0;
|
||||
}
|
||||
|
||||
.psample span {
|
||||
margin-right: .5em;
|
||||
}
|
||||
|
||||
.white_blend {
|
||||
width: 100%;
|
||||
height: 61px;
|
||||
background-image: url();
|
||||
position: absolute;
|
||||
bottom: 0;
|
||||
}
|
||||
.black_blend {
|
||||
width: 100%;
|
||||
height: 61px;
|
||||
background-image: url();
|
||||
position: absolute;
|
||||
bottom: 0;
|
||||
}
|
||||
.fullreverse {
|
||||
background: #000 !important;
|
||||
color: #fff !important;
|
||||
margin-left: -20px;
|
||||
padding-left: 20px;
|
||||
margin-right: -20px;
|
||||
padding-right: 20px;
|
||||
padding: 20px;
|
||||
margin-bottom:0;
|
||||
}
|
||||
|
||||
|
||||
.sample_table td {
|
||||
padding-top: 3px;
|
||||
padding-bottom:5px;
|
||||
padding-left: 5px;
|
||||
vertical-align: middle;
|
||||
line-height: 1.2em;
|
||||
}
|
||||
|
||||
.sample_table td:first-child {
|
||||
background-color: #eee;
|
||||
text-align: right;
|
||||
padding-right: 5px;
|
||||
padding-left: 0;
|
||||
padding: 5px;
|
||||
font: 11px/12px "Courier New", Courier, mono;
|
||||
}
|
||||
|
||||
code {
|
||||
white-space: pre;
|
||||
background-color: #eee;
|
||||
display: block;
|
||||
padding: 10px;
|
||||
margin-bottom: 18px;
|
||||
overflow: auto;
|
||||
}
|
||||
|
||||
|
||||
.bottom,.last {margin-bottom:0 !important; padding-bottom:0 !important;}
|
||||
|
||||
.box {
|
||||
padding: 18px;
|
||||
margin-bottom: 18px;
|
||||
background: #eee;
|
||||
}
|
||||
|
||||
.reverse,.reversed { background: #000 !important;color: #fff !important; border: none !important;}
|
||||
|
||||
#bodycomparison {
|
||||
position: relative;
|
||||
overflow: hidden;
|
||||
font-size: 72px;
|
||||
height: 90px;
|
||||
white-space: nowrap;
|
||||
}
|
||||
|
||||
#bodycomparison div{
|
||||
font-size: 72px;
|
||||
line-height: 90px;
|
||||
display: inline;
|
||||
margin: 0 15px 0 0;
|
||||
padding: 0;
|
||||
}
|
||||
|
||||
#bodycomparison div span{
|
||||
font: 10px Arial;
|
||||
position: absolute;
|
||||
left: 0;
|
||||
}
|
||||
#xheight {
|
||||
float: none;
|
||||
position: absolute;
|
||||
color: #d9f3ff;
|
||||
font-size: 72px;
|
||||
line-height: 90px;
|
||||
}
|
||||
|
||||
.fontbody {
|
||||
position: relative;
|
||||
}
|
||||
.arialbody{
|
||||
font-family: Arial;
|
||||
position: relative;
|
||||
}
|
||||
.verdanabody{
|
||||
font-family: Verdana;
|
||||
position: relative;
|
||||
}
|
||||
.georgiabody{
|
||||
font-family: Georgia;
|
||||
position: relative;
|
||||
}
|
||||
|
||||
/* @group Layout page
|
||||
*/
|
||||
|
||||
#layout h1 {
|
||||
font-size: 36px;
|
||||
line-height: 42px;
|
||||
font-weight: normal;
|
||||
font-style: normal;
|
||||
}
|
||||
|
||||
#layout h2 {
|
||||
font-size: 24px;
|
||||
line-height: 23px;
|
||||
font-weight: normal;
|
||||
font-style: normal;
|
||||
}
|
||||
|
||||
#layout h3 {
|
||||
font-size: 22px;
|
||||
line-height: 1.4em;
|
||||
margin-top: 1em;
|
||||
font-weight: normal;
|
||||
font-style: normal;
|
||||
}
|
||||
|
||||
|
||||
#layout p.byline {
|
||||
font-size: 12px;
|
||||
margin-top: 18px;
|
||||
line-height: 12px;
|
||||
margin-bottom: 0;
|
||||
}
|
||||
#layout p {
|
||||
font-size: 14px;
|
||||
line-height: 21px;
|
||||
margin-bottom: .5em;
|
||||
}
|
||||
|
||||
#layout p.large{
|
||||
font-size: 18px;
|
||||
line-height: 26px;
|
||||
}
|
||||
|
||||
#layout .sidebar p{
|
||||
font-size: 12px;
|
||||
line-height: 1.4em;
|
||||
}
|
||||
|
||||
#layout p.caption {
|
||||
font-size: 10px;
|
||||
margin-top: -16px;
|
||||
margin-bottom: 18px;
|
||||
}
|
||||
|
||||
/* @end */
|
||||
|
||||
/* @group Glyphs */
|
||||
|
||||
#glyph_chart div{
|
||||
background-color: #d9f3ff;
|
||||
color: black;
|
||||
float: left;
|
||||
font-size: 36px;
|
||||
height: 1.2em;
|
||||
line-height: 1.2em;
|
||||
margin-bottom: 1px;
|
||||
margin-right: 1px;
|
||||
text-align: center;
|
||||
width: 1.2em;
|
||||
position: relative;
|
||||
padding: .6em .2em .2em;
|
||||
}
|
||||
|
||||
#glyph_chart div p {
|
||||
position: absolute;
|
||||
left: 0;
|
||||
top: 0;
|
||||
display: block;
|
||||
text-align: center;
|
||||
font: bold 9px Arial, sans-serif;
|
||||
background-color: #3a768f;
|
||||
width: 100%;
|
||||
color: #fff;
|
||||
padding: 2px 0;
|
||||
}
|
||||
|
||||
|
||||
#glyphs h1 {
|
||||
font-family: Arial, sans-serif;
|
||||
}
|
||||
/* @end */
|
||||
|
||||
/* @group Installing */
|
||||
|
||||
#installing {
|
||||
font: 13px Arial, sans-serif;
|
||||
}
|
||||
|
||||
#installing p,
|
||||
#glyphs p{
|
||||
line-height: 1.2em;
|
||||
margin-bottom: 18px;
|
||||
font: 13px Arial, sans-serif;
|
||||
}
|
||||
|
||||
|
||||
|
||||
#installing h3{
|
||||
font-size: 15px;
|
||||
margin-top: 18px;
|
||||
}
|
||||
|
||||
/* @end */
|
||||
|
||||
#rendering h1 {
|
||||
font-family: Arial, sans-serif;
|
||||
}
|
||||
.render_table td {
|
||||
font: 11px "Courier New", Courier, mono;
|
||||
vertical-align: middle;
|
||||
}
|
||||
|
||||
|
12
in/static/fonts/roboto_regular/stylesheet.css
Normal file
12
in/static/fonts/roboto_regular/stylesheet.css
Normal file
|
@ -0,0 +1,12 @@
|
|||
@font-face {
|
||||
font-family: 'robotoregular';
|
||||
src: url('roboto-regular-webfont.eot');
|
||||
src: url('roboto-regular-webfont.eot?#iefix') format('embedded-opentype'),
|
||||
url('roboto-regular-webfont.woff') format('woff'),
|
||||
url('roboto-regular-webfont.ttf') format('truetype'),
|
||||
url('roboto-regular-webfont.svg#robotoregular') format('svg');
|
||||
font-weight: normal;
|
||||
font-style: normal;
|
||||
|
||||
}
|
||||
|
23
includes/macros.html
Normal file
23
includes/macros.html
Normal file
|
@ -0,0 +1,23 @@
|
|||
{% macro menu_items(key="") %}
|
||||
{% for page in pages | get(key=key, default=pages) | unzip | filter(attribute="1.order") | sort(attribute="1.order") %}
|
||||
{% set parent = key %}
|
||||
{% set key = page.0 %}
|
||||
{% set value = page.1 %}
|
||||
{% if value.type and value.type == "page" %}
|
||||
<li><a href="{{value.path}}">{{value.title}}</a></li>
|
||||
{% elif value.type and value.type == "category" %}
|
||||
{% set next = [parent, key] | join(sep=".") | trim_start_matches(pat=".") %}
|
||||
</menu>
|
||||
<details open>
|
||||
<summary>
|
||||
{{value.title}}
|
||||
</summary>
|
||||
<menu class="menu-item-list">
|
||||
{{ self::menu_items(key=next) }}
|
||||
</menu>
|
||||
</details>
|
||||
<menu class="menu-item-list">
|
||||
{% endif %}
|
||||
{% endfor %}
|
||||
{% endmacro category %}
|
||||
|
2
includes/menu-toggle.html
Normal file
2
includes/menu-toggle.html
Normal file
|
@ -0,0 +1,2 @@
|
|||
<input type="checkbox" id="menu-toggle"/>
|
||||
<label class="hamburger" for="menu-toggle"><span class="hamburger-line"></span></label>
|
14
includes/nav.html
Normal file
14
includes/nav.html
Normal file
|
@ -0,0 +1,14 @@
|
|||
{% import "macros.html" as macros %}
|
||||
|
||||
<aside class="navigation">
|
||||
<div class="logo">
|
||||
<h1>Roxy</h1>
|
||||
</div>
|
||||
|
||||
{% include "menu-toggle.html" %}
|
||||
<nav class="menu">
|
||||
<menu class="menu-item-list">
|
||||
{{ macros::menu_items() }}
|
||||
</menu>
|
||||
</nav>
|
||||
</aside>
|
27
inotify.sh
Executable file
27
inotify.sh
Executable file
|
@ -0,0 +1,27 @@
|
|||
#!/usr/bin/env bash
|
||||
|
||||
if [ -f ".env" ]; then
|
||||
source .env
|
||||
|
||||
if [ -z "$(which inotifywait)" ]; then
|
||||
echo "inotifywait not installed."
|
||||
echo "In most distros, it is available in the inotify-tools package."
|
||||
exit 1
|
||||
fi
|
||||
|
||||
counter=0;
|
||||
|
||||
function execute() {
|
||||
counter=$((counter+1))
|
||||
echo "Detected change n. $counter"
|
||||
"$@"
|
||||
}
|
||||
|
||||
echo "watching $WATCH"
|
||||
inotifywait --recursive --monitor --format "%e %w%f" \
|
||||
--event modify,move,create,delete $(echo $WATCH) \
|
||||
| while read changed; do
|
||||
echo $changed
|
||||
"$@"
|
||||
done
|
||||
fi
|
18
layouts/base.tera
Normal file
18
layouts/base.tera
Normal file
|
@ -0,0 +1,18 @@
|
|||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
{% block head %}
|
||||
<meta charset="UTF-8">
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||
<meta http-equiv="X-UA-Compatible" content="ie=edge">
|
||||
<title>{% block title %}Roxy{% endblock title %}</title>
|
||||
<link rel="stylesheet" href="/static/css/style.css">
|
||||
<link rel="icon" href="./favicon.ico" type="image/x-icon">
|
||||
{% endblock head %}
|
||||
</head>
|
||||
<body>
|
||||
{% block body %}
|
||||
{% endblock body %}
|
||||
</body>
|
||||
</html>
|
||||
|
11
layouts/index.tera
Normal file
11
layouts/index.tera
Normal file
|
@ -0,0 +1,11 @@
|
|||
{% extends "../layouts/base.tera" %}
|
||||
{% import "../includes/macros.html" as macros %}
|
||||
|
||||
{% block body %}
|
||||
{% include "../includes/nav.html" %}
|
||||
<main>
|
||||
{% block main %}
|
||||
{% endblock main %}
|
||||
</main>
|
||||
{% endblock body %}
|
||||
|
9
layouts/topic.tera
Normal file
9
layouts/topic.tera
Normal file
|
@ -0,0 +1,9 @@
|
|||
{% extends "index.tera" %}
|
||||
|
||||
{% block main %}
|
||||
<h1>{% block title %}{{ this.title }}{% endblock title %}</h1>
|
||||
<div>
|
||||
{% block content %}{% endblock content %}
|
||||
</div>
|
||||
{% endblock main %}
|
||||
|
Loading…
Reference in a new issue