| | |
| | | import { QuartzComponent, QuartzComponentConstructor, QuartzComponentProps } from "./types" |
| | | import explorerStyle from "./styles/explorer.scss" |
| | | import style from "./styles/explorer.scss" |
| | | |
| | | // @ts-ignore |
| | | import script from "./scripts/explorer.inline" |
| | |
| | | lastBuildId = ctx.buildId |
| | | constructFileTree(allFiles) |
| | | } |
| | | |
| | | return ( |
| | | <div class={classNames(displayClass, "explorer")}> |
| | | <button |
| | | type="button" |
| | | id="explorer" |
| | | id="mobile-explorer" |
| | | class="collapsed hide-until-loaded" |
| | | data-behavior={opts.folderClickBehavior} |
| | | data-collapsed={opts.folderDefaultState} |
| | | data-savestate={opts.useSavedState} |
| | | data-tree={jsonTree} |
| | | data-mobile={true} |
| | | aria-controls="explorer-content" |
| | | aria-expanded={opts.folderDefaultState === "open"} |
| | | aria-expanded={false} |
| | | > |
| | | <svg |
| | | xmlns="http://www.w3.org/2000/svg" |
| | | width="24" |
| | | height="24" |
| | | viewBox="0 0 24 24" |
| | | stroke-width="2" |
| | | stroke-linecap="round" |
| | | stroke-linejoin="round" |
| | | class="lucide lucide-menu" |
| | | > |
| | | <line x1="4" x2="20" y1="12" y2="12" /> |
| | | <line x1="4" x2="20" y1="6" y2="6" /> |
| | | <line x1="4" x2="20" y1="18" y2="18" /> |
| | | </svg> |
| | | </button> |
| | | <button |
| | | type="button" |
| | | id="desktop-explorer" |
| | | class="title-button" |
| | | data-behavior={opts.folderClickBehavior} |
| | | data-collapsed={opts.folderDefaultState} |
| | | data-savestate={opts.useSavedState} |
| | | data-tree={jsonTree} |
| | | data-mobile={false} |
| | | aria-controls="explorer-content" |
| | | aria-expanded={true} |
| | | > |
| | | <h2>{opts.title ?? i18n(cfg.locale).components.explorer.title}</h2> |
| | | <svg |
| | |
| | | ) |
| | | } |
| | | |
| | | Explorer.css = explorerStyle |
| | | Explorer.css = style |
| | | Explorer.afterDOMLoaded = script |
| | | return Explorer |
| | | }) satisfies QuartzComponentConstructor |