| | |
| | | // @ts-ignore |
| | | import spaRouterScript from "../../components/scripts/spa.inline" |
| | | // @ts-ignore |
| | | import plausibleScript from "../../components/scripts/plausible.inline" |
| | | // @ts-ignore |
| | | import popoverScript from "../../components/scripts/popover.inline" |
| | | import styles from "../../styles/custom.scss" |
| | | import popoverStyle from "../../components/styles/popover.scss" |
| | |
| | | import { QuartzComponent } from "../../components/types" |
| | | import { googleFontHref, joinStyles } from "../../util/theme" |
| | | import { Features, transform } from "lightningcss" |
| | | import { transform as transpile } from "esbuild" |
| | | import { write } from "./helpers" |
| | | |
| | | type ComponentResources = { |
| | | css: string[] |
| | |
| | | } |
| | | } |
| | | |
| | | function joinScripts(scripts: string[]): string { |
| | | async function joinScripts(scripts: string[]): Promise<string> { |
| | | // wrap with iife to prevent scope collision |
| | | return scripts.map((script) => `(function () {${script}})();`).join("\n") |
| | | const script = scripts.map((script) => `(function () {${script}})();`).join("\n") |
| | | |
| | | // minify with esbuild |
| | | const res = await transpile(script, { |
| | | minify: true, |
| | | }) |
| | | |
| | | return res.code |
| | | } |
| | | |
| | | function addGlobalPageResources( |
| | |
| | | function gtag() { dataLayer.push(arguments); } |
| | | gtag("js", new Date()); |
| | | gtag("config", "${tagId}", { send_page_view: false }); |
| | | |
| | | |
| | | document.addEventListener("nav", () => { |
| | | gtag("event", "page_view", { |
| | | page_title: document.title, |
| | |
| | | }); |
| | | });`) |
| | | } else if (cfg.analytics?.provider === "plausible") { |
| | | componentResources.afterDOMLoaded.push(plausibleScript) |
| | | const plausibleHost = cfg.analytics.host ?? "https://plausible.io" |
| | | componentResources.afterDOMLoaded.push(` |
| | | const plausibleScript = document.createElement("script") |
| | | plausibleScript.src = "${plausibleHost}/js/script.manual.js" |
| | | plausibleScript.setAttribute("data-domain", location.hostname) |
| | | plausibleScript.defer = true |
| | | document.head.appendChild(plausibleScript) |
| | | |
| | | window.plausible = window.plausible || function() { (window.plausible.q = window.plausible.q || []).push(arguments) } |
| | | |
| | | document.addEventListener("nav", () => { |
| | | plausible("pageview") |
| | | }) |
| | | `) |
| | | } else if (cfg.analytics?.provider === "umami") { |
| | | componentResources.afterDOMLoaded.push(` |
| | | const umamiScript = document.createElement("script") |
| | | umamiScript.src = "https://analytics.umami.is/script.js" |
| | | umamiScript.src = cfg.analytics.host ?? "https://analytics.umami.is/script.js" |
| | | umamiScript.setAttribute("data-website-id", "${cfg.analytics.websiteId}") |
| | | umamiScript.async = true |
| | | |
| | | |
| | | document.head.appendChild(umamiScript) |
| | | `) |
| | | } |
| | |
| | | componentResources.afterDOMLoaded.push(spaRouterScript) |
| | | } else { |
| | | componentResources.afterDOMLoaded.push(` |
| | | window.spaNavigate = (url, _) => window.location.assign(url) |
| | | const event = new CustomEvent("nav", { detail: { url: document.body.dataset.slug } }) |
| | | document.dispatchEvent(event)`) |
| | | window.spaNavigate = (url, _) => window.location.assign(url) |
| | | window.addCleanup = () => {} |
| | | const event = new CustomEvent("nav", { detail: { url: document.body.dataset.slug } }) |
| | | document.dispatchEvent(event) |
| | | `) |
| | | } |
| | | |
| | | let wsUrl = `ws://localhost:${ctx.argv.wsPort}` |
| | |
| | | loadTime: "afterDOMReady", |
| | | contentType: "inline", |
| | | script: ` |
| | | const socket = new WebSocket('${wsUrl}') |
| | | socket.addEventListener('message', () => document.location.reload()) |
| | | `, |
| | | const socket = new WebSocket('${wsUrl}') |
| | | socket.addEventListener('message', () => document.location.reload()) |
| | | `, |
| | | }) |
| | | } |
| | | } |
| | |
| | | getQuartzComponents() { |
| | | return [] |
| | | }, |
| | | async emit(ctx, _content, resources, emit): Promise<FilePath[]> { |
| | | async emit(ctx, _content, resources): Promise<FilePath[]> { |
| | | // component specific scripts and styles |
| | | const componentResources = getComponentResources(ctx) |
| | | // important that this goes *after* component scripts |
| | |
| | | addGlobalPageResources(ctx, resources, componentResources) |
| | | |
| | | const stylesheet = joinStyles(ctx.cfg.configuration.theme, ...componentResources.css, styles) |
| | | const prescript = joinScripts(componentResources.beforeDOMLoaded) |
| | | const postscript = joinScripts(componentResources.afterDOMLoaded) |
| | | const [prescript, postscript] = await Promise.all([ |
| | | joinScripts(componentResources.beforeDOMLoaded), |
| | | joinScripts(componentResources.afterDOMLoaded), |
| | | ]) |
| | | |
| | | const fps = await Promise.all([ |
| | | emit({ |
| | | write({ |
| | | ctx, |
| | | slug: "index" as FullSlug, |
| | | ext: ".css", |
| | | content: transform({ |
| | |
| | | include: Features.MediaQueries, |
| | | }).code.toString(), |
| | | }), |
| | | emit({ |
| | | write({ |
| | | ctx, |
| | | slug: "prescript" as FullSlug, |
| | | ext: ".js", |
| | | content: prescript, |
| | | }), |
| | | emit({ |
| | | write({ |
| | | ctx, |
| | | slug: "postscript" as FullSlug, |
| | | ext: ".js", |
| | | content: postscript, |