1

tinkering

This commit is contained in:
Evan Pratten 2024-11-27 13:59:37 -05:00
parent ca50099d26
commit 30ec115a73
8 changed files with 301 additions and 14 deletions

View File

@ -23,13 +23,14 @@ feed:
markdown: kramdown markdown: kramdown
kramdown: kramdown:
input: GFM input: GFM
mathjax: true
# Plugins # Plugins
plugins: plugins:
- jekyll-feed - jekyll-feed
# Per-collection settings # Per-collection settings
# collections_dir: _collections collections_dir: collections
collections: collections:
posts: posts:
output: true output: true

View File

@ -13,6 +13,7 @@
<link rel="shortcut icon" type="image/jpg" href="{{ site.profile_photo }}" /> <link rel="shortcut icon" type="image/jpg" href="{{ site.profile_photo }}" />
<link rel="canonical" href="{{ site.url }}{{ page.url | replace: '.html', '' }}" /> <link rel="canonical" href="{{ site.url }}{{ page.url | replace: '.html', '' }}" />
<link rel="stylesheet" href="/assets/css/default_compiled.css"> <link rel="stylesheet" href="/assets/css/default_compiled.css">
<link rel="stylesheet" href="/assets/css/highlight/vs.css">
</head> </head>
<body> <body>
@ -56,6 +57,15 @@
</nav> </nav>
</header> </header>
<main> <main>
{% if page.title %}
<div class="page-title">
<h1>{{ page.title }}</h1>
{% if page.description %}
<span>{{ page.description }}</span>
{% endif %}
</div>
{% endif %}
{{ content }} {{ content }}
</main> </main>
<footer> <footer>

View File

@ -0,0 +1,218 @@
# coding: utf-8
# Generate pages from individual records in yml files
# (c) 2014-2020 Adolfo Villafiorita
# Distributed under the conditions of the MIT License
module Jekyll
module Sanitizer
# strip characters and whitespace to create valid filenames, also lowercase
def sanitize_filename(name)
if(name.is_a? Integer)
return name.to_s
end
return name.tr(
"ÀÁÂÃÄÅàáâãäåĀāĂ㥹ÇçĆćĈĉĊċČčÐðĎďĐđÈÉÊËèéêëĒēĔĕĖėĘęĚěĜĝĞğĠġĢģĤĥĦħÌÍÎÏìíîïĨĩĪīĬĭĮįİıĴĵĶķĸĹĺĻļĽľĿŀŁłÑñŃńŅņŇňʼnŊŋÑñÒÓÔÕÖØòóôõöøŌōŎŏŐőŔŕŖŗŘřŚśŜŝŞşŠšſŢţŤťŦŧÙÚÛÜùúûüŨũŪūŬŭŮůŰűŲųŴŵÝýÿŶŷŸŹźŻżŽž",
"AAAAAAaaaaaaAaAaAaCcCcCcCcCcDdDdDdEEEEeeeeEeEeEeEeEeGgGgGgGgHhHhIIIIiiiiIiIiIiIiIiJjKkkLlLlLlLlLlNnNnNnNnnNnNnOOOOOOooooooOoOoOoRrRrRrSsSsSsSssTtTtTtUUUUuuuuUuUuUuUuUuUuWwYyyYyYZzZzZz"
).downcase.strip.gsub(' ', '-').gsub(/[^\w.-]/, '')
end
end
# this class is used to tell Jekyll to generate a page
class DataPage < Page
include Sanitizer
# - site and base are copied from other plugins: to be honest, I am not sure what they do
#
# - `index_files` specifies if we want to generate named folders (true) or not (false)
# - `dir` is the default output directory
# - `page_data_prefix` is the prefix used to output the page data
# - `data` is the data of the record for which we are generating a page
# - `name` is the key in `data` which determines the output filename
# - `name_expr` is an expression for generating the output filename
# - `title` is the key in `data` which determines the page title
# - `title_expr` is an expression for generating the page title
# - `template` is the name of the template for generating the page
# - `extension` is the extension for the generated file
def initialize(site, base, index_files, dir, page_data_prefix, data, name, name_expr, title, title_expr, template, extension, debug)
@site = site
@base = base
if debug
puts "debug (datapage-gen) Record read:"
puts ">> #{data}"
puts "debug (datapage-gen) Configuration variables:"
[:index_files, :dir, :page_data_prefix, :name, :name_expr, :title, :title_expr, :template, :extension].each do |variable|
puts ">> #{variable}: #{eval(variable.to_s)}"
end
end
# @dir is the directory where we want to output the page
# @name is the name of the page to generate
# @name_expr is an expression for generating the name of the page
#
# the value of these variables changes according to whether we
# want to generate named folders or not
if name_expr
record = data
raw_filename = eval(name_expr)
if raw_filename == nil
puts "error (datapage-gen). name_expr '#{name_expr}' generated an empty value in record #{data}"
return
end
puts "debug (datapage-gen). using name_expr: '#{raw_filename}' (sanitized) will be used as the filename" if debug
else
raw_filename = data[name]
if raw_filename == nil
puts "error (datapage-gen). empty value for field '#{name}' in record #{data}"
return
end
puts "debug (datapage-gen). using name field: '#{raw_filename}' (sanitized) will be used as the filename" if debug
end
if title_expr
record = data
raw_title = eval(title_expr)
if raw_title == nil
puts "error (datapage-gen). title_expr '#{title_expr}' generated an empty value in record #{data}"
return
end
puts "debug (datapage-gen). using title_expr: '#{raw_title}' will be used the page title" if debug
else
raw_title = data[title]
if raw_title == nil
raw_title = raw_filename # for backwards compatibility
puts "debug (datapage-gen). empty title field: falling back to filename for the page title" if debug
end
puts "debug (datapage-gen). will use '#{raw_title}' as the page title" if debug
end
filename = sanitize_filename(raw_filename).to_s
@dir = dir + (index_files ? "/" + filename + "/" : "")
@name = (index_files ? "index" : filename)
if extension
@name += "." + extension.to_s
end
self.process(@name)
if @site.layouts[template].path.end_with? 'html'
@path = @site.layouts[template].path.dup
else
@path = File.join(@site.layouts[template].path, @site.layouts[template].name)
end
base_path = @site.layouts[template].path
base_path.slice! @site.layouts[template].name
self.read_yaml(base_path, @site.layouts[template].name)
self.data['title'] = raw_title
# add all the information defined in _data for the current record to the
# current page (so that we can access it with liquid tags)
if page_data_prefix
self.data[page_data_prefix] = data
else
if data.key?('name')
data['_name'] = data['name']
end
self.data.merge!(data)
end
end
end
class JekyllDatapageGenerator < Generator
safe true
# the function =generate= loops over the =_config.yml/page_gen=
# specification, determining what sets of pages have to be generated,
# reading the data for each set and invoking the =DataPage=
# constructor for each record found in the data
def generate(site)
# page_gen-dirs is a global option which determines whether we want to
# generate index pages (name/index.html) or HTML files (name.html) for
# all sets
index_files = site.config['page_gen-dirs'] == true
# data contains the specification of all the datasets for which we want
# to generate individual pages (look at the README file for its documentation)
data = site.config['page_gen']
if data
data.each do |data_spec|
index_files_for_this_data = data_spec['index_files'] != nil ? data_spec['index_files'] : index_files
template = data_spec['template'] || data_spec['data']
name = data_spec['name']
name_expr = data_spec['name_expr']
title = data_spec['title']
title_expr = data_spec['title_expr']
dir = data_spec['dir'] || data_spec['data']
page_data_prefix = data_spec['page_data_prefix']
debug = data_spec['debug']
unless data_spec.key? 'extension'
data_spec['extension'] = 'html'
end
if not site.layouts.key? template
puts "error (datapage-gen). could not find template #{template}. Skipping dataset #{name}."
else
# records is the list of records for which we want to generate
# individual pages
records = nil
data_spec['data'].split('.').each do |level|
if records.nil?
records = site.data[level]
else
records = records[level]
end
end
if (records.kind_of?(Hash))
records = records.values
end
# apply filtering conditions:
# - filter requires the name of a boolean field
# - filter_condition evals a ruby expression which can use =record= as argument
records = records.select { |record| record[data_spec['filter']] } if data_spec['filter']
records = records.select { |record| eval(data_spec['filter_condition']) } if data_spec['filter_condition']
# we now have the list of all records for which we want to generate individual pages
# iterate and call the constructor
records.each do |record|
site.pages << DataPage.new(site, site.source, index_files_for_this_data, dir, page_data_prefix, record, name, name_expr, title, title_expr, template, data_spec['extension'], debug)
end
end
end
end
end
end
module DataPageLinkGenerator
include Sanitizer
# use it like this: {{input | datapage_url: dir}}
# to generate a link to a data_page.
#
# the filter is smart enough to generate different link styles
# according to the data_page-dirs directive ...
#
# ... however, the filter is not smart enough to support different
# extensions for filenames.
#
# Thus, if you use the `extension` feature of this plugin, you
# need to generate the links by hand
def datapage_url(input, dir)
extension = @context.registers[:site].config['page_gen-dirs'] ? '/' : '.html'
"#{dir}/#{sanitize_filename(input)}#{extension}"
end
end
end
Liquid::Template.register_filter(Jekyll::DataPageLinkGenerator)

View File

@ -0,0 +1,5 @@
@import url("https://fonts.googleapis.com/css2?family=IBM+Plex+Serif:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;1,100;1,200;1,300;1,400;1,500;1,600;1,700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Overlock:ital,wght@0,400;0,700;0,900;1,400;1,700;1,900&display=swap");
$title-font: "IBM Plex Serif", serif;
$body-font: "Overlock", sans-serif;

View File

@ -1,6 +1,4 @@
// Fonts @use "common/font.scss" as *;
@import url("https://fonts.googleapis.com/css2?family=IBM+Plex+Serif:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;1,100;1,200;1,300;1,400;1,500;1,600;1,700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Overlock:ital,wght@0,400;0,700;0,900;1,400;1,700;1,900&display=swap");
body { body {
// Keep websites thin! // Keep websites thin!
@ -8,10 +6,10 @@ body {
margin: auto; margin: auto;
// Default font // Default font
font-family: "Overlock", sans-serif; font-family: $body-font;
// Default background color // Default background color
background-color: #f0f0f0; background-color: #f7f7f7;
// Remove all link decoration // Remove all link decoration
a { a {
@ -20,7 +18,7 @@ body {
} }
header { header {
font-family: "IBM Plex Serif", serif; font-family: $title-font;
.title-card { .title-card {
margin: 1em; margin: 1em;
@ -94,12 +92,27 @@ body {
h4, h4,
h5, h5,
h6 { h6 {
font-family: "IBM Plex Serif", serif; font-family: $title-font;
border-bottom: 1px solid #d7dde3; border-bottom: 1px solid #d7dde3;
padding-bottom: 0.3em; padding-bottom: 0.3em;
} }
p,li { .page-title {
margin-bottom: 1em;
h1 {
margin-bottom: 0;
padding-bottom: 0;
}
span {
font-family: $title-font;
font-size: 1.25em;
color: gray;
}
}
p,
li {
font-size: 1.25rem; font-size: 1.25rem;
} }
@ -115,6 +128,14 @@ body {
max-width: 100%; max-width: 100%;
border-radius: 5px; border-radius: 5px;
} }
pre {
width: 100%;
overflow: scroll;
border: 1px solid gray;
border-radius: 5px;
padding: 1em;
}
} }
footer { footer {

View File

@ -1,5 +1,4 @@
@import url("https://fonts.googleapis.com/css2?family=IBM+Plex+Serif:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;1,100;1,200;1,300;1,400;1,500;1,600;1,700&display=swap"); @use "common/font.scss" as *;
@import url("https://fonts.googleapis.com/css2?family=Overlock:ital,wght@0,400;0,700;0,900;1,400;1,700;1,900&display=swap");
body { body {
display: flex; display: flex;
@ -11,7 +10,7 @@ body {
margin: 0; margin: 0;
padding: 0; padding: 0;
font-family: "Overlock", sans-serif; font-family: $body-font;
background-color: #f0f0f0; background-color: #f0f0f0;
main { main {
@ -39,7 +38,7 @@ body {
} }
h1 { h1 {
font-family: "IBM Plex Serif", serif; font-family: $title-font;
margin-bottom: 0; margin-bottom: 0;
} }

View File

@ -0,0 +1,33 @@
.highlight .hll { background-color: #ffffcc }
.highlight .c { color: #008000 } /* Comment */
.highlight .err { border: 1px solid #FF0000 } /* Error */
.highlight .k { color: #0000ff } /* Keyword */
.highlight .cm { color: #008000 } /* Comment.Multiline */
.highlight .cp { color: #0000ff } /* Comment.Preproc */
.highlight .c1 { color: #008000 } /* Comment.Single */
.highlight .cs { color: #008000 } /* Comment.Special */
.highlight .ge { font-style: italic } /* Generic.Emph */
.highlight .gh { font-weight: bold } /* Generic.Heading */
.highlight .gp { font-weight: bold } /* Generic.Prompt */
.highlight .gs { font-weight: bold } /* Generic.Strong */
.highlight .gu { font-weight: bold } /* Generic.Subheading */
.highlight .kc { color: #0000ff } /* Keyword.Constant */
.highlight .kd { color: #0000ff } /* Keyword.Declaration */
.highlight .kn { color: #0000ff } /* Keyword.Namespace */
.highlight .kp { color: #0000ff } /* Keyword.Pseudo */
.highlight .kr { color: #0000ff } /* Keyword.Reserved */
.highlight .kt { color: #2b91af } /* Keyword.Type */
.highlight .s { color: #a31515 } /* Literal.String */
.highlight .nc { color: #2b91af } /* Name.Class */
.highlight .ow { color: #0000ff } /* Operator.Word */
.highlight .sb { color: #a31515 } /* Literal.String.Backtick */
.highlight .sc { color: #a31515 } /* Literal.String.Char */
.highlight .sd { color: #a31515 } /* Literal.String.Doc */
.highlight .s2 { color: #a31515 } /* Literal.String.Double */
.highlight .se { color: #a31515 } /* Literal.String.Escape */
.highlight .sh { color: #a31515 } /* Literal.String.Heredoc */
.highlight .si { color: #a31515 } /* Literal.String.Interpol */
.highlight .sx { color: #a31515 } /* Literal.String.Other */
.highlight .sr { color: #a31515 } /* Literal.String.Regex */
.highlight .s1 { color: #a31515 } /* Literal.String.Single */
.highlight .ss { color: #a31515 } /* Literal.String.Symbol */

View File

@ -13,7 +13,7 @@ Not because I don't like it, I just have a constant urge to refine it.
As I am once again sitting in front of my computer contemplating a major redesign, I figured I could dedicate a post to looking back at the various previous revisions of this website. As I am once again sitting in front of my computer contemplating a major redesign, I figured I could dedicate a post to looking back at the various previous revisions of this website.
&#xb7; <p style="text-align: center;"></p>
This site you are looking at right now, ewpratten.com, was originally the band webpage for RetryLife (a music collective I founded with some friends). The git repo backing the page just happened to eventually evolve into my personal site as time went on. This site you are looking at right now, ewpratten.com, was originally the band webpage for RetryLife (a music collective I founded with some friends). The git repo backing the page just happened to eventually evolve into my personal site as time went on.