Jacky Zhao
2024-03-18 daa8796554dea41d6fbf81f4eccea58153a4e850
quartz/components/Search.tsx
@@ -1,15 +1,26 @@
import { QuartzComponentConstructor, QuartzComponentProps } 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({ displayClass }: QuartzComponentProps) {
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")}>
        <div id="search-icon">
          <p>Search</p>
          <p>{i18n(cfg.locale).components.search.title}</p>
          <div></div>
          <svg
            tabIndex={0}
@@ -33,10 +44,10 @@
              id="search-bar"
              name="search"
              type="text"
              aria-label="Search for something"
              placeholder="Search for something"
              aria-label={searchPlaceholder}
              placeholder={searchPlaceholder}
            />
            <div id="results-container"></div>
            <div id="search-layout" data-preview={opts.enablePreview}></div>
          </div>
        </div>
      </div>