* feat(search): telescope-style search Signed-off-by: Aaron <29749331+aarnphm@users.noreply.github.com> * chore(search): cleanup some basis and borders Signed-off-by: Aaron <29749331+aarnphm@users.noreply.github.com> * fix(search): make sure to set overflow-y Signed-off-by: Aaron <29749331+aarnphm@users.noreply.github.com> * feat(search): shows preview on desktop only search Signed-off-by: Aaron <29749331+aarnphm@users.noreply.github.com> * perf: add options to control layout through config cache memoize results to avoid fetching Signed-off-by: Aaron <29749331+aarnphm@users.noreply.github.com> * chore: use the default configuration * fix: correct minor type for search Signed-off-by: Aaron <29749331+aarnphm@users.noreply.github.com> * fix: use datasets to query for preview Signed-off-by: Aaron <29749331+aarnphm@users.noreply.github.com> * chore: layout changes show preview on normal layout, and only show previous layout in list page. * fix(type): annotate search with types Signed-off-by: Aaron <29749331+aarnphm@users.noreply.github.com> * chore: apply jacky's suggestion Co-authored-by: Jacky Zhao <j.zhao2k19@gmail.com> * chore: using map API and scss Signed-off-by: Aaron <29749331+aarnphm@users.noreply.github.com> * fix: styling on search container view on phones Signed-off-by: Aaron <29749331+aarnphm@users.noreply.github.com> * Update quartz.layout.ts Co-authored-by: Jacky Zhao <j.zhao2k19@gmail.com> --------- Signed-off-by: Aaron <29749331+aarnphm@users.noreply.github.com> Co-authored-by: Jacky Zhao <j.zhao2k19@gmail.com>
		
			
				
	
	
		
			61 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			61 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
import { QuartzComponentConstructor, QuartzComponentProps } from "./types"
 | 
						|
import style from "./styles/search.scss"
 | 
						|
// @ts-ignore
 | 
						|
import script from "./scripts/search.inline"
 | 
						|
import { classNames } from "../util/lang"
 | 
						|
 | 
						|
export interface SearchOptions {
 | 
						|
  enablePreview: boolean
 | 
						|
}
 | 
						|
 | 
						|
const defaultOptions: SearchOptions = {
 | 
						|
  enablePreview: true,
 | 
						|
}
 | 
						|
 | 
						|
export default ((userOpts?: Partial<SearchOptions>) => {
 | 
						|
  function Search({ displayClass }: QuartzComponentProps) {
 | 
						|
    const opts = { ...defaultOptions, ...userOpts }
 | 
						|
 | 
						|
    return (
 | 
						|
      <div class={classNames(displayClass, "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="search-layout" data-preview={opts.enablePreview}></div>
 | 
						|
          </div>
 | 
						|
        </div>
 | 
						|
      </div>
 | 
						|
    )
 | 
						|
  }
 | 
						|
 | 
						|
  Search.afterDOMLoaded = script
 | 
						|
  Search.css = style
 | 
						|
 | 
						|
  return Search
 | 
						|
}) satisfies QuartzComponentConstructor
 |