From c538c151c7462ad0395ff2c15c5e11e89e362aa8 Mon Sep 17 00:00:00 2001
From: Striven <sg.striven@cutecat.club>
Date: Sat, 04 Apr 2026 19:47:16 +0000
Subject: [PATCH] Initial commit
---
quartz/components/Search.tsx | 60 +++++++++++++++++++++++++++++++++++++++---------------------
1 files changed, 39 insertions(+), 21 deletions(-)
diff --git a/quartz/components/Search.tsx b/quartz/components/Search.tsx
index f8dd804..6e932d2 100644
--- a/quartz/components/Search.tsx
+++ b/quartz/components/Search.tsx
@@ -1,31 +1,49 @@
-import { QuartzComponentConstructor } from "./types"
+import { QuartzComponent, QuartzComponentConstructor, QuartzComponentProps } from "./types"
import style from "./styles/search.scss"
// @ts-ignore
import script from "./scripts/search.inline"
+import { classNames } from "../util/lang"
+import { i18n } from "../i18n"
-export default (() => {
- function Search() {
- return <div class="search">
- <div id="search-icon">
- <p>Search</p>
- <div></div>
- <svg tabIndex={0} aria-labelledby="title desc" role="img" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 19.9 19.7">
- <title id="title">Search</title>
- <desc id="desc">Search</desc>
- <g class="search-path" fill="none">
- <path stroke-linecap="square" d="M18.5 18.3l-5.4-5.4" />
- <circle cx="8" cy="8" r="7" />
- </g>
- </svg>
- </div>
- <div id="search-container">
- <div id="search-space">
- <input autocomplete="off" id="search-bar" name="search" type="text" aria-label="Search for something" placeholder="Search for something" />
- <div id="results-container">
+export interface SearchOptions {
+ enablePreview: boolean
+}
+
+const defaultOptions: SearchOptions = {
+ enablePreview: true,
+}
+
+export default ((userOpts?: Partial<SearchOptions>) => {
+ const Search: QuartzComponent = ({ displayClass, cfg }: QuartzComponentProps) => {
+ const opts = { ...defaultOptions, ...userOpts }
+ const searchPlaceholder = i18n(cfg.locale).components.search.searchBarPlaceholder
+ return (
+ <div class={classNames(displayClass, "search")}>
+ <button class="search-button">
+ <svg role="img" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 19.9 19.7">
+ <title>Search</title>
+ <g class="search-path" fill="none">
+ <path stroke-linecap="square" d="M18.5 18.3l-5.4-5.4" />
+ <circle cx="8" cy="8" r="7" />
+ </g>
+ </svg>
+ <p>{i18n(cfg.locale).components.search.title}</p>
+ </button>
+ <div class="search-container">
+ <div class="search-space">
+ <input
+ autocomplete="off"
+ class="search-bar"
+ name="search"
+ type="text"
+ aria-label={searchPlaceholder}
+ placeholder={searchPlaceholder}
+ />
+ <div class="search-layout" data-preview={opts.enablePreview}></div>
</div>
</div>
</div>
- </div>
+ )
}
Search.afterDOMLoaded = script
--
Gitblit v1.10.0