From 028bcec62c3ca019a96783f17eaee1ecce6e092b Mon Sep 17 00:00:00 2001 From: Jacky Zhao Date: Sun, 6 Aug 2023 17:09:29 -0700 Subject: [PATCH] mobile fixes, fix bug when linking to anchor on home, docs --- content/build.md | 22 +++++++++++++ content/configuration.md | 42 ++++++++++++++++++------- content/features/popover previews.md | 2 +- content/features/upcoming features.md | 1 + content/hosting.md | 43 ++++++++++++++++++++++++++ content/index.md | 7 ++--- content/migrating from Quartz 3.md | 26 ++++++++++++++++ content/quartz-layout.png | Bin 0 -> 63222 bytes quartz.layout.ts | 4 +-- quartz/cfg.ts | 1 + quartz/path.ts | 2 +- quartz/plugins/transformers/links.ts | 3 +- quartz/plugins/transformers/ofm.ts | 1 - quartz/styles/base.scss | 4 ++- 14 files changed, 134 insertions(+), 24 deletions(-) create mode 100644 content/quartz-layout.png diff --git a/content/build.md b/content/build.md index 28570571..ac6a410e 100644 --- a/content/build.md +++ b/content/build.md @@ -1,3 +1,25 @@ --- title: "Building your Quartz" --- + +Once you've [[index#🪴 Get Started|initialized]] Quartz, let's see what it looks like locally. + +```bash +npx quartz build --serve +``` + +Then, open a web browser and visit `http://localhost:8080/` to view it! + +Want to change how Quartz looks? You can edit `quartz.config.ts` to customize and configure your Quartz, including styles, layout, and more. Read the [[configuration]] page for more information on what each field in the configuration does. + +Once you're happy with it, let's see how to [[hosting|deploy Quartz to the web]]. + +> [!hint] Flags and options +> For full help options, you can run `npx quartz build --help`. +> +> Most of these have sensible defaults but you can override them if you have a custom setup: +> - `-d` or `--directory`: the content folder. This is normally just `content` +> - `-v` or `--verbose`: print out extra logging information +> - `-o` or `--output`: the output folder. This is normally just `public` +> - `--serve`: run a local hot-reloading server to preview your Quartz +> - `--port`: what port to run the local preview server on \ No newline at end of file diff --git a/content/configuration.md b/content/configuration.md index e31dbc2d..ef0bf9b2 100644 --- a/content/configuration.md +++ b/content/configuration.md @@ -4,11 +4,12 @@ title: Configuration Quartz is meant to be extremely configurable, even if you don't know any coding. Most of the configuration you should need can be done by just editing `quartz.config.ts`. -If you edit this file using a text-editor that has TypeScript language support like VSCode, it will warn you when you you've made an error in your configuration. +> [!tip] +> If you edit this file using a text-editor that has TypeScript language support like VSCode, it will warn you when you you've made an error in your configuration, helping you avoid configuration mistakes! This configuration can be broken down into two main parts: -```ts +```ts title="quartz.config.ts" const config: QuartzConfig = { configuration: { ... }, plugins: { ... }, @@ -81,24 +82,41 @@ If you'd like to make your own plugins, read the guide on [[making plugins]] for Certain emitters may also output [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) files. To enable easy customization, these emitters allow you to fully rearrange the layout of the page. The default page layouts can be found in `quartz.layout.ts`. -Ultimately, each page is composed of multiple different sections which contain `QuartzComponents`. The following code snippet lists all of the valid sections that you can add components to: +Each page is composed of multiple different sections which contain `QuartzComponents`. The following code snippet lists all of the valid sections that you can add components to: ```typescript title="quartz/cfg.ts" export interface FullPageLayout { - head: QuartzComponent - header: QuartzComponent[] - beforeBody: QuartzComponent[] - pageBody: QuartzComponent - left: QuartzComponent[] - right: QuartzComponent[] - footer: QuartzComponent + head: QuartzComponent // single component + header: QuartzComponent[] // laid out horizontally + beforeBody: QuartzComponent[] // laid out vertically + pageBody: QuartzComponent // single component + left: QuartzComponent[] // vertical on desktop, horizontal on mobile + right: QuartzComponent[] // vertical on desktop, horizontal on mobile + footer: QuartzComponent // single component } ``` These correspond to following parts of the page: -### Components +![[quartz-layout.png|800]] -See [a list of all the components](./tags/component) for all available components. +> [!note] +> There are two additional layout fields that are *not* shown in the above diagram. +> 1. `head` is a single component that renders the `` [tag](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/head) in the HTML. This doesn't appear visually on the page and is only is responsible for metadata about the document like the tab title, scripts, and styles. +> 2. `header` is a set of components that are laid out horizontally and appears *before* the `beforeBody` section. This enables you to replicate the old Quartz 3 header bar where the title, search bar, and dark mode toggle. By default, Quartz 4 doesn't place any components in the `header`. + +Quartz **components**, like plugins, can take in additional properties as configuration options. If you're familiar with React terminology, you can think of them as Higher-order Components. + +See [a list of all the components](./tags/component) for all available components along with their configuration options. ### Style +Most meaningful style changes like colour scheme and font can be done simply through the [[#General Configuration|general configuration]] options above. + +However, if you'd like to make more involved style changes, you can do this by writing your own styles. Quartz 4, like Quartz 3, uses [Sass](https://sass-lang.com/guide/) for styling. + +You can see the base style sheet in `quartz/styles/base.scss` and write your own in `quartz/styles/custom.scss`. + +> [!note] +> Some components may provide their own styling as well! For example, `quartz/components/Darkmode.tsx` imports its styles from `quartz/components/styles/darkmode.scss`. If you'd like to customize styling for a specific component, double check the component definition to see how its styles are defined. + +When you're ready, see how [[build|build and preview]] Quartz locally. \ No newline at end of file diff --git a/content/features/popover previews.md b/content/features/popover previews.md index 7bf608e0..f8822240 100644 --- a/content/features/popover previews.md +++ b/content/features/popover previews.md @@ -2,7 +2,7 @@ title: Popover Previews --- -Like Wikipedia, when you hover over a link in Quartz, there is a popup of a page preview that you can scroll to see the entire content. +Like Wikipedia, when you hover over a link in Quartz, there is a popup of a page preview that you can scroll to see the entire content. Links to headers will also scroll the popup to show that specific header in view. By default, Quartz only fetches previews for pages inside your vault due to [CORS](https://developer.mozilla.org/en-US/docs/Web/HTTP/CORS). It does this by selecting all HTML elements with the `popover-hint` class. For most pages, this includes the page title, page metadata like words and time to read, tags, and the actual page content. diff --git a/content/features/upcoming features.md b/content/features/upcoming features.md index 46390bd8..8ab75202 100644 --- a/content/features/upcoming features.md +++ b/content/features/upcoming features.md @@ -7,6 +7,7 @@ draft: true - block links: https://help.obsidian.md/Linking+notes+and+files/Internal+links#Link+to+a+block+in+a+note - note/header/block transcludes: https://help.obsidian.md/Linking+notes+and+files/Embedding+files - static dead link detection +- docker support ## misc diff --git a/content/hosting.md b/content/hosting.md index a7043137..f644e4d6 100644 --- a/content/hosting.md +++ b/content/hosting.md @@ -2,6 +2,49 @@ title: Hosting --- +Quartz effectively turns your Markdown files and other resources into a bundle of HTML, JS, and CSS files (a website!). + +However, if you'd like to publish your site to the world, you need a way to host it online. This guide will detail how to deploy with either GitHub Pages or Cloudflare pages but any service that allows you to deploy static HTML should work as well (e.g. Netlify, Replit, etc.) ## GitHub Pages +Like Quartz 3, you can deploy the site generated by Quartz 4 via GitHub Pages. + +In your local Quartz, create a new file `quartz/.github/workflows/deploy.yaml`: + +```yaml title="quartz/.github/workflows/deploy.yaml" +name: Deploy to GitHub Pages + +on: + push: + branches: + - v4-alpha + +jobs: + deploy: + runs-on: ubuntu-22.04 + steps: + - uses: actions/checkout@v2 + with: + fetch-depth: 0 # Fetch all history for git info + + - uses: actions/setup-node@v3 + with: + node-version: 18.14 + + - name: Install Dependencies + run: npm ci + + - name: Build Quartz + run: npx quartz build + + - name: Deploy + uses: peaceiris/actions-gh-pages@v3 + with: + github_token: ${{ secrets.GITHUB_TOKEN }} + publish_dir: ./public + publish_branch: master # deploying branch + cname: quartz.jzhao.xyz +``` + +Then, the next time you ## Cloudflare Pages diff --git a/content/index.md b/content/index.md index 77f14e1a..0659e881 100644 --- a/content/index.md +++ b/content/index.md @@ -18,11 +18,7 @@ npm i npx quartz create ``` -This will guide you through initializing your Quartz with content. - -When you're ready, you can edit `quartz.config.ts` to customize and configure Quartz more. Read the [[configuration]] page for more information on what each field in the configuration does. - -Then, when you're ready, see how to [[build]] and [[hosting|host]] Quartz. +This will guide you through initializing your Quartz with content. Once you've done so, see how to [[build]] and [[hosting|host]] Quartz. > [!info] > Coming from Quartz 3? See the [[migrating from Quartz 3|migration guide]] for the differences between Quartz 3 and Quartz 4 and how to migrate. @@ -30,6 +26,7 @@ Then, when you're ready, see how to [[build]] and [[hosting|host]] Quartz. ## 🔧 Features - [[full-text search|Full-text search]], [[graph view]], [[backlinks]], [[Latex]], [[syntax highlighting]], [[popover previews]], and many more right out of the box +- Hot-reload for both configuration and content - Simple JSX [[creating components|layouts and page components]] - [[SPA Routing|Ridiculously fast page loads]] and tiny bundle sizes - Fully-customizable parsing, filtering, and page generation through [[making plugins|plugins]] diff --git a/content/migrating from Quartz 3.md b/content/migrating from Quartz 3.md index e69de29b..c2e4c4eb 100644 --- a/content/migrating from Quartz 3.md +++ b/content/migrating from Quartz 3.md @@ -0,0 +1,26 @@ +--- +title: "Migrating from Quartz 3" +--- + +As you already have Quartz locally, you don't need to fork or clone it again. Simply just checkout the alpha branch, install the dependencies, and import your old vault. + +```bash +git checkout v4-alpha +npm i +npx quartz create +``` + +When running `npx quartz create`, you will be prompted as to how to initialize your content folder. Here, you can choose to import or link your previous content folder and Quartz should work just as you expect it to. + +## Key changes + +1. **Removing Hugo and `hugo-obsidian`**: Hugo worked well for earlier versions of Quartz but it also made it hard for people outside of the Golang and Hugo communities to fully understand what Quartz was doing under the hood and be able to properly customize it to their needs. Quartz 4 now uses a Node-based static-site generation process which should lead to a much more helpful error messages and an overall smoother user experience. +2. **Full-hot reload**: The many rough edges of how `hugo-obsidian` integrated with Hugo meant that watch mode didn't re-trigger `hugo-obsidian` to update the content index. This lead to a lot of weird cases where the watch mode output wasn't accurate. Quartz 4 now uses a cohesive parse, filter, and emit pipeline which gets run on every change so hot-reloads are always accurate. +3. **Replacing Go template syntax with JSX**: Quartz 3 used [Go templates](https://pkg.go.dev/text/template) to create layouts for pages. However, the syntax isn't great for doing any sort of complex rendering (like [text processing](https://github.com/jackyzha0/quartz/blob/hugo/layouts/partials/textprocessing.html)) and it got very difficult to make any meaningful layout changes to Quartz 3. Quartz 4 uses an extension of JavaScript syntax called JSX which allows you to write layout code that looks like HTML in JavaScript which is significantly easier to understand and maintain. +4. **A new extensible [[configuration]] and [[configuration#Plugins|plugin]] system**: Quartz 3 was hard to configure without technical knowledge of how Hugo's partials worked. Extensions were even hard to make. Quartz 4's configuration and plugin system is designed to be extended by users while making updating to new versions of Quartz easy. + +## Things to update + +- Some HTML layout may not be the same between Quartz 3 and Quartz 4. If you depended on a particular HTML hierarchy or class names, you may need to update your custom CSS to reflect these changes. +- If you customized the layout of Quartz 3, you may need to translate these changes from Go templates back to JSX as Quartz 4 no longer uses Hugo. For components, check out the guide on [[creating components]] for more details on this. +- You will also need to update your deploy scripts. See the [[hosting]] guide for more details. \ No newline at end of file diff --git a/content/quartz-layout.png b/content/quartz-layout.png new file mode 100644 index 0000000000000000000000000000000000000000..4767b549c2469c65482dde2fc69dfea67c0e781b GIT binary patch literal 63222 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�oFQF7lI>fxZupq*R(>;lRsuhPjwrs_ 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 literal 0 HcmV?d00001 diff --git a/quartz.layout.ts b/quartz.layout.ts index f47b2249..1a3f99fa 100644 --- a/quartz.layout.ts +++ b/quartz.layout.ts @@ -1,8 +1,8 @@ -import { PageLayout } from "./quartz/cfg" +import { PageLayout, SharedLayout } from "./quartz/cfg" import * as Component from "./quartz/components" // components shared across all pages -export const sharedPageComponents = { +export const sharedPageComponents: SharedLayout = { head: Component.Head(), header: [], footer: Component.Footer({ diff --git a/quartz/cfg.ts b/quartz/cfg.ts index d8a14a32..3c9613b7 100644 --- a/quartz/cfg.ts +++ b/quartz/cfg.ts @@ -45,3 +45,4 @@ export interface FullPageLayout { } export type PageLayout = Pick +export type SharedLayout = Pick diff --git a/quartz/path.ts b/quartz/path.ts index 494d3c5d..9af5c7bf 100644 --- a/quartz/path.ts +++ b/quartz/path.ts @@ -228,7 +228,7 @@ function _isRelativeSegment(s: string): boolean { return /^\.{0,2}$/.test(s) } -function _stripSlashes(s: string): string { +export function _stripSlashes(s: string): string { if (s.startsWith("/")) { s = s.substring(1) } diff --git a/quartz/plugins/transformers/links.ts b/quartz/plugins/transformers/links.ts index 07650621..9a9195bb 100644 --- a/quartz/plugins/transformers/links.ts +++ b/quartz/plugins/transformers/links.ts @@ -2,6 +2,7 @@ import { QuartzTransformerPlugin } from "../types" import { CanonicalSlug, RelativeURL, + _stripSlashes, canonicalizeServer, joinSegments, pathToRoot, @@ -35,7 +36,7 @@ export const CrawlLinks: QuartzTransformerPlugin | undefined> = return (tree, file) => { const curSlug = canonicalizeServer(file.data.slug!) const transformLink = (target: string): RelativeURL => { - const targetSlug = transformInternalLink(target).slice("./".length) + const targetSlug = _stripSlashes(transformInternalLink(target).slice(".".length)) let [targetCanonical, targetAnchor] = splitAnchor(targetSlug) if (opts.markdownLinkResolution === "relative") { return targetSlug as RelativeURL diff --git a/quartz/plugins/transformers/ofm.ts b/quartz/plugins/transformers/ofm.ts index 8d8d4573..0904ed12 100644 --- a/quartz/plugins/transformers/ofm.ts +++ b/quartz/plugins/transformers/ofm.ts @@ -225,7 +225,6 @@ export const ObsidianFlavoredMarkdown: QuartzTransformerPlugin } // internal link - // const url = transformInternalLink(fp + anchor) const url = fp + anchor return { type: "link", diff --git a/quartz/styles/base.scss b/quartz/styles/base.scss index 72919396..6bed7ca2 100644 --- a/quartz/styles/base.scss +++ b/quartz/styles/base.scss @@ -81,7 +81,9 @@ a { .page { @media all and (max-width: $fullPageWidth) { - margin: 0 5vw; + margin: 0 auto; + padding: 0 1rem; + max-width: 800px; } & article {