migrated to my fork of quartz that uses a json config

This commit is contained in:
Nathan Price 2025-01-17 15:46:39 -05:00
parent 692580d2fe
commit b50490ab44
Signed by: gravityfargo
SSH key fingerprint: SHA256:bjq+uA1U+9bFMd70q2wdNtwaYxGv84IBXalnYvZDKmg
7 changed files with 204 additions and 123 deletions

View file

@ -0,0 +1,7 @@
.vscode/
config/
content/
LICENSE
Makefile
README.md
.env

3
.gitignore vendored
View file

@ -1 +1,2 @@
config/
.env

View file

@ -1,18 +1,18 @@
FROM node:alpine AS build FROM node:alpine AS build
RUN apk --no-cache add git && \ RUN apk --no-cache add git && \
git clone https://github.com/jackyzha0/quartz.git && \ git clone https://code.modernleft.org/gravityfargo/quartz.git && \
cd quartz && git checkout v4.4.0 && cd .. && \ cd quartz && git switch json-config && cd .. && \
mkdir -p /usr/share/nginx/html && \ mkdir -p /usr/share/nginx/html && \
mv quartz/* /usr/share/nginx/html && \ mv quartz/* /usr/share/nginx/html && \
rm -rf /usr/share/nginx/html/docs && \
cd /usr/share/nginx/html && \ cd /usr/share/nginx/html && \
npm ci && npx quartz build && \ npm ci && npx quartz build && \
rm -rf /usr/share/nginx/html/node_modules rm -rf /usr/share/nginx/html/node_modules /usr/share/nginx/html/docs
FROM nginx:stable-alpine3.20 FROM nginx:stable-alpine3.20
COPY --from=build /usr/share/nginx/html /usr/share/nginx/html COPY --from=build /usr/share/nginx/html /usr/share/nginx/html
COPY default.conf.template /etc/nginx/templates/default.conf.template COPY default.conf.template /etc/nginx/templates/default.conf.template
COPY config.json /usr/share/nginx/html/default-config.json
WORKDIR /usr/share/nginx/html WORKDIR /usr/share/nginx/html
@ -20,47 +20,24 @@ RUN apk --no-cache add nodejs npm bash dumb-init git && \
rm -rf /var/cache/apk/* && \ rm -rf /var/cache/apk/* && \
echo "*/5 * * * * cd /usr/share/nginx/html/content && git pull >/dev/null 2>&1 && cd /usr/share/nginx/html && npx quartz build >/dev/null 2>&1" > /etc/crontabs/root echo "*/5 * * * * cd /usr/share/nginx/html/content && git pull >/dev/null 2>&1 && cd /usr/share/nginx/html && npx quartz build >/dev/null 2>&1" > /etc/crontabs/root
RUN ln -s /usr/share/nginx/html/content / && \ RUN mkdir /config && \
ln -s /usr/share/nginx/html/content / && \
chown -R nginx:nginx /usr/share/nginx/html && \ chown -R nginx:nginx /usr/share/nginx/html && \
chown -R nginx:nginx /usr/share/nginx/html/content chown -R nginx:nginx /config
# REQUIRED
ENV NGINX_PORT=80
ENV ENABLE_CRON="false" ENV ENABLE_CRON="false"
ENV BUILD_SCHEDULE="*/5 * * * *" ENV BUILD_SCHEDULE="*/5 * * * *"
ENV NGINX_PORT=80 ENV SERVER_NAME="quartz.zhao.xyz"
ENV BASE_URL="quartz.zhao.xyz" ENV QUARTZ_CONFIG_PATH="/config/config.json"
ENV PAGE_TITLE="Quartz Docker"
ENV ENABLE_SPA="true"
ENV ENABLE_POPOVERS="true"
ENV ANALYTICS_PROVIDER="plausible"
ENV IGNORE_PATTERNS="private,templates"
ENV TYPOGRAPHY_HEADER="Schibsted Grotesk"
ENV TYPOGRAPHY_BODY="Source Sans Pro"
ENV TYPOGRAPHY_CODE="IBM-Plex Mono"
ENV LIGHTMODE_LIGHT="#faf8f8"
ENV LIGHTMODE_LIGHTGRAY="#e5e5e5"
ENV LIGHTMODE_GRAY="#bbbbbb"
ENV LIGHTMODE_DARKGRAY="#4e4e4e"
ENV LIGHTMODE_DARK="#2b2b2b"
ENV LIGHTMODE_SECONDARY="#284b63"
ENV LIGHTMODE_TERTIARY="#84a59d"
ENV LIGHTMODE_HIGHLIGHT="rgba(143,159,169,0.15)"
ENV DARKMODE_LIGHT="#161618"
ENV DARKMODE_LIGHTGRAY="#393639"
ENV DARKMODE_GRAY="#646464"
ENV DARKMODE_DARKGRAY="#4d4d4d"
ENV DARKMODE_DARK="#ebebec"
ENV DARKMODE_SECONDARY="#7b97aa"
ENV DARKMODE_TERTIARY="#84a59d"
ENV DARKMODE_HIGHLIGHT="rgba(143,159,169,0.15)"
COPY entrypoint.sh /entrypoint.sh COPY entrypoint.sh /entrypoint.sh
RUN chmod +x /entrypoint.sh RUN chmod +x /entrypoint.sh
ENTRYPOINT ["dumb-init", "--"] ENTRYPOINT ["dumb-init", "--"]
CMD ["/entrypoint.sh"] CMD ["/entrypoint.sh"]
LABEL org.opencontainers.image.source="https://code.modernleft.org/gravityfargo/quartz-docker" LABEL org.opencontainers.image.source="https://code.modernleft.org/gravityfargo/quartz-docker"
LABEL org.opencontainers.image.url="https://quartz.jzhao.xyz/" LABEL org.opencontainers.image.url="https://quartz.jzhao.xyz/"
LABEL org.opencontainers.image.description="A docker image for Quartz, a static site generator." LABEL org.opencontainers.image.description="A docker image for Quartz, a static site generator."

144
config.json Normal file
View file

@ -0,0 +1,144 @@
{
"configuration": {
"pageTitle": "quartz-docker ;)",
"pageTitleSuffix": "",
"enableSPA": true,
"enablePopovers": true,
"analytics": {
"provider": "plausible"
},
"locale": "en-US",
"baseUrl": "quartz.jzhao.xyz",
"ignorePatterns": [
"private",
"templates",
".obsidian"
],
"defaultDateType": "created",
"generateSocialImages": false,
"theme": {
"fontOrigin": "googleFonts",
"cdnCaching": true,
"typography": {
"header": "Schibsted Grotesk",
"body": "Source Sans Pro",
"code": "IBM Plex Mono"
},
"colors": {
"lightMode": {
"light": "#faf8f8",
"lightgray": "#e5e5e5",
"gray": "#b8b8b8",
"darkgray": "#4e4e4e",
"dark": "#2b2b2b",
"secondary": "#284b63",
"tertiary": "#84a59d",
"highlight": "rgba(143, 159, 169, 0.15)",
"textHighlight": "#fff23688"
},
"darkMode": {
"light": "#161618",
"lightgray": "#393639",
"gray": "#646464",
"darkgray": "#d4d4d4",
"dark": "#ebebec",
"secondary": "#7b97aa",
"tertiary": "#84a59d",
"highlight": "rgba(143, 159, 169, 0.15)",
"textHighlight": "#b3aa0288"
}
}
}
},
"plugins": {
"transformers": [
{
"name": "FrontMatter"
},
{
"name": "CreatedModifiedDate",
"config": {
"priority": [
"frontmatter",
"filesystem"
]
}
},
{
"name": "SyntaxHighlighting",
"config": {
"theme": {
"light": "github-light",
"dark": "github-dark"
},
"keepBackground": false
}
},
{
"name": "ObsidianFlavoredMarkdown",
"config": {
"enableInHtmlEmbed": false
}
},
{
"name": "GitHubFlavoredMarkdown"
},
{
"name": "TableOfContents"
},
{
"name": "CrawlLinks",
"config": {
"markdownLinkResolution": "shortest"
}
},
{
"name": "Description"
},
{
"name": "Latex",
"config": {
"renderEngine": "katex"
}
}
],
"filters": [
{
"name": "RemoveDrafts"
}
],
"emitters": [
{
"name": "AliasRedirects"
},
{
"name": "ComponentResources"
},
{
"name": "ContentPage"
},
{
"name": "FolderPage"
},
{
"name": "TagPage"
},
{
"name": "ContentIndex",
"config": {
"enableSiteMap": true,
"enableRSS": true
}
},
{
"name": "Assets"
},
{
"name": "Static"
},
{
"name": "NotFoundPage"
}
]
}
}

View file

@ -1,6 +1,6 @@
server { server {
listen ${NGINX_PORT}; listen ${NGINX_PORT};
server_name ${BASE_URL}; server_name ${SERVER_NAME};
root /usr/share/nginx/html/public; root /usr/share/nginx/html/public;
index index.html; index index.html;
error_page 404 /404.html; error_page 404 /404.html;

View file

@ -4,41 +4,17 @@ services:
image: code.modernleft.org/gravityfargo/quartz-docker:dev image: code.modernleft.org/gravityfargo/quartz-docker:dev
ports: ports:
- 80:8080 - 80:8080
env_file:
- .env
environment: environment:
NGINX_PORT: 8080 NGINX_PORT: 8080
ENABLE_CRON: "false" SERVER_NAME: "localhost"
ENABLE_CRON: "true"
BUILD_SCHEDULE: "*/10 * * * *" BUILD_SCHEDULE: "*/10 * * * *"
PAGE_TITLE: "Quartz Docker" QUARTZ_CONFIG_PATH: "/config/config.json"
ENABLE_SPA: "true"
ENABLE_POPOVERS: "true"
ANALYTICS_PROVIDER: "plausible"
BASE_URL: "localhost"
IGNORE_PATTERNS: "private,templates"
TYPOGRAPHY_HEADER: "Schibsted Grotesk"
TYPOGRAPHY_BODY: "Source Sans Pro"
TYPOGRAPHY_CODE: "IBM-Plex Mono"
# Light Mode Colors
LIGHTMODE_LIGHT: "#faf8f8"
LIGHTMODE_LIGHTGRAY: "#e5e5e5"
LIGHTMODE_GRAY: "#bbbbbb"
LIGHTMODE_DARKGRAY: "#4e4e4e"
LIGHTMODE_DARK: "#2b2b2b"
LIGHTMODE_SECONDARY: "#284b63"
LIGHTMODE_TERTIARY: "#84a59d"
LIGHTMODE_HIGHLIGHT: "rgba(143,159,169,0.15)"
# Dark Mode Colors
DARKMODE_LIGHT: "#161618"
DARKMODE_LIGHTGRAY: "#393639"
DARKMODE_GRAY: "#646464"
DARKMODE_DARKGRAY: "#4d4d4d"
DARKMODE_DARK: "#ebebec"
DARKMODE_SECONDARY: "#7b97aa"
DARKMODE_TERTIARY: "#84a59d"
DARKMODE_HIGHLIGHT: "rgba(143,159,169,0.15)"
volumes: volumes:
- /home/nathan/Repositories/modernleft-docs:/content - /home/nathan/Repositories/modernleft-docs:/content
- ./config:/config
- quartz-deps:/usr/share/nginx/html/node_modules - quartz-deps:/usr/share/nginx/html/node_modules
volumes: volumes:

View file

@ -1,69 +1,45 @@
#!/bin/bash #!/bin/bash
set -e set -e
CONFIG_FILE="/usr/share/nginx/html/quartz.config.ts" verify_config_exist() {
TEMP_FILE="${CONFIG_FILE}.tmp" if [[ ! -f "/config/config.json" ]]; then
echo "Config file not found, copying default config..."
replace_text() { cp /usr/share/nginx/html/config.json /config/config.json
local search="$1"
local replace="$2"
# file var with default value
local file="${3:-$CONFIG_FILE}"
if [[ -z "$search" || -z "$replace" ]]; then
echo "Error: Missing arguments"
return 1
fi fi
# Modify a temporary file instead of the original
sed -e "s|${search}|${replace}|g" "$CONFIG_FILE" >"$TEMP_FILE" && mv "$TEMP_FILE" "$CONFIG_FILE"
} }
# Quartz Config setup_cron() {
replace_text 'pageTitle: "🪴 Quartz 4.0",' "pageTitle: \"${PAGE_TITLE}\"," echo "${BUILD_SCHEDULE} cd /usr/share/nginx/html/content && git pull >/dev/null 2>&1 && cd /usr/share/nginx/html && npx quartz build >/dev/null 2>&1" >/etc/crontabs/root
replace_text 'enableSPA: true,' "enableSPA: ${ENABLE_SPA},"
replace_text 'enablePopovers: true,' "enablePopovers: ${ENABLE_POPOVERS},"
replace_text 'provider: "plausible",' "provider: \"${ANALYTICS_PROVIDER}\","
replace_text 'baseUrl: "quartz.zhao.xyz",' "baseUrl: \"${BASE_URL}\","
replace_text 'ignorePatterns: ["private", "templates"],' "ignorePatterns: [\"${IGNORE_PATTERNS//,/\", \"}\"],"
replace_text 'header: "Schibsted Grotesk",' "header: \"${TYPOGRAPHY_HEADER}\","
replace_text 'body: "Source Sans Pro",' "body: \"${TYPOGRAPHY_BODY}\","
replace_text 'code: "IBM-Plex Mono",' "code: \"${TYPOGRAPHY_CODE}\","
replace_text 'light: "#faf8f8",' "light: \"${LIGHTMODE_LIGHT}\","
replace_text 'lightgray: "#e5e5e5",' "lightgray: \"${LIGHTMODE_LIGHTGRAY}\","
replace_text 'gray: "#bbbbbb",' "gray: \"${LIGHTMODE_GRAY}\","
replace_text 'darkgray: "#4e4e4e",' "darkgray: \"${LIGHTMODE_DARKGRAY}\","
replace_text 'dark: "#2b2b2b",' "dark: \"${LIGHTMODE_DARK}\","
replace_text 'secondary: "#284b63",' "secondary: \"${LIGHTMODE_SECONDARY}\","
replace_text 'tertiary: "#84a59d",' "tertiary: \"${LIGHTMODE_TERTIARY}\","
replace_text 'highlight: "rgba(143, 159, 169, 0.15)",' "highlight: \"${LIGHTMODE_HIGHLIGHT}\","
replace_text 'light: "#161618",' "light: \"${DARKMODE_LIGHT}\","
replace_text 'lightgray: "#393639",' "lightgray: \"${DARKMODE_LIGHTGRAY}\","
replace_text 'gray: "#646464",' "gray: \"${DARKMODE_GRAY}\","
replace_text 'darkgray: "#4d4d4d",' "darkgray: \"${DARKMODE_DARKGRAY}\","
replace_text 'dark: "#ebebec",' "dark: \"${DARKMODE_DARK}\","
replace_text 'secondary: "#7b97aa",' "secondary: \"${DARKMODE_SECONDARY}\","
replace_text 'tertiary: "#84a59d",' "tertiary: \"${DARKMODE_TERTIARY}\","
replace_text 'highlight: "rgba(143, 159, 169, 0.15)",' "highlight: \"${DARKMODE_HIGHLIGHT}\","
chown nginx:nginx "$CONFIG_FILE"
echo "${BUILD_SCHEDULE} cd /usr/share/nginx/html/content && git pull >/dev/null 2>&1 && cd /usr/share/nginx/html && npx quartz build >/dev/null 2>&1" >/etc/crontabs/root if [[ "$ENABLE_CRON" == "true" ]]; then
# NGINX script to sub variables in the template
/docker-entrypoint.d/20-envsubst-on-templates.sh
# ENABLE_CRON
if [[ "$ENABLE_CRON" == "true" ]]; then
echo "Cron is enabled" echo "Cron is enabled"
crond -b crond -b
fi else
echo "Cron is disabled"
fi
}
echo "Starting Quartz..." main() {
echo "Installing dependencies..." verify_config_exist
npm i >/dev/null setup_cron
echo "Building Quartz..." chown -R nginx:nginx /usr/share/nginx/html
npx quartz build chown -R "${USER_ID}":"${GROUP_ID}" /content
chown -R "${USER_ID}":"${GROUP_ID}" /config
echo "Starting Nginx..." # NGINX script to sub variables in the template
exec nginx -g "daemon off;" echo "NGINX variable substitution..."
/docker-entrypoint.d/20-envsubst-on-templates.sh
echo "Starting Quartz..."
echo "Installing dependencies..."
npm i >/dev/null
echo "Building Quartz..."
npx quartz build
echo "Starting Nginx..."
exec nginx -g "daemon off;"
}
main