|
1 |
| -import { $, component$, useContext, useSignal } from '@builder.io/qwik'; |
2 |
| -import { useLocation } from '@builder.io/qwik-city'; |
3 |
| -import { version } from '../../../../../package.json'; |
| 1 | +import { |
| 2 | + $, |
| 3 | + component$, |
| 4 | + useComputed$, |
| 5 | + useContext, |
| 6 | + useSignal, |
| 7 | +} from '@builder.io/qwik'; |
| 8 | +import { Link, useLocation } from '@builder.io/qwik-city'; |
| 9 | +// eslint-disable-next-line @nrwl/nx/enforce-module-boundaries |
| 10 | +import { version as headlessVersion } from '../../../../../packages/kit-headless/package.json'; |
| 11 | +// eslint-disable-next-line @nrwl/nx/enforce-module-boundaries |
| 12 | +import { version as tailwindVersion } from '../../../../../packages/kit-tailwind/package.json'; |
4 | 13 | import { CloseIcon } from '../icons/CloseIcon';
|
5 | 14 | import { GitHubIcon } from '../icons/GitHubIcon';
|
6 | 15 | import { MenuIcon } from '../icons/MenuIcon';
|
7 | 16 | import { MoonIcon } from '../icons/MoonIcon';
|
8 | 17 | import { SunIcon } from '../icons/SunIcon';
|
9 | 18 | import { Menu } from '../menu/menu';
|
10 |
| -import { SelectTheme } from '../selectTheme/selectTheme'; |
11 | 19 | import { APP_STATE_CONTEXT_ID } from '../../_state/app-state-context-id';
|
12 |
| -import { useCSSTheme } from '../../_state/use-css-theme'; |
13 | 20 |
|
14 |
| -export default component$(() => { |
15 |
| - const location = useLocation(); |
16 |
| - const appState = useContext(APP_STATE_CONTEXT_ID); |
17 |
| - const menuOpenSignal = useSignal(false); |
| 21 | +export interface HeaderProps { |
| 22 | + showVersion?: boolean; |
| 23 | + showBottomBorder?: boolean; |
| 24 | +} |
18 | 25 |
|
19 |
| - const toggleMenu$ = $(() => { |
20 |
| - menuOpenSignal.value = !menuOpenSignal.value; |
21 |
| - }); |
| 26 | +export default component$( |
| 27 | + ({ showVersion = false, showBottomBorder = false }: HeaderProps) => { |
| 28 | + const location = useLocation(); |
| 29 | + const appState = useContext(APP_STATE_CONTEXT_ID); |
| 30 | + const menuOpenSignal = useSignal(false); |
22 | 31 |
|
23 |
| - const toggleDarkMode = $(() => { |
24 |
| - appState.mode = appState.mode === 'light' ? 'dark' : 'light'; |
25 |
| - }); |
| 32 | + const kitSignal = useComputed$(() => { |
| 33 | + if (location.url.pathname.indexOf('headless') !== -1) { |
| 34 | + return { |
| 35 | + name: 'Headless', |
| 36 | + version: headlessVersion, |
| 37 | + }; |
| 38 | + } |
| 39 | + if (location.url.pathname.indexOf('tailwind') !== -1) { |
| 40 | + return { |
| 41 | + name: 'Tailwind', |
| 42 | + version: tailwindVersion, |
| 43 | + }; |
| 44 | + } |
| 45 | + }); |
26 | 46 |
|
27 |
| - const isDocsRoute = location.url.pathname.indexOf('/docs/') !== -1; |
| 47 | + const toggleMenu$ = $(() => { |
| 48 | + menuOpenSignal.value = !menuOpenSignal.value; |
| 49 | + }); |
28 | 50 |
|
29 |
| - return ( |
30 |
| - <header class="fixed w-full h-20 z-10 flex gap-8 p-4 items-center"> |
31 |
| - <button |
32 |
| - type="button" |
33 |
| - aria-label="Toggle navigation" |
34 |
| - onClick$={toggleMenu$} |
35 |
| - class="block lg:hidden" |
36 |
| - > |
37 |
| - {menuOpenSignal.value ? <CloseIcon /> : <MenuIcon />} |
38 |
| - </button> |
39 |
| - {menuOpenSignal.value && ( |
40 |
| - <aside class="fixed top-0 left-0"> |
41 |
| - <div class="fixed h-screen w-screen bg-gray-900/20 backdrop-blur-sm"></div> |
42 |
| - <div class="fixed h-screen w-80 overflow-y-scroll bg-white"> |
43 |
| - <Menu onClose$={toggleMenu$} /> |
44 |
| - </div> |
45 |
| - </aside> |
46 |
| - )} |
47 |
| - <a href="/" class="lg:ml-8"> |
48 |
| - <img src="/qwik-ui.png" class="h-12 w-auto object-contain" /> |
49 |
| - </a> |
50 |
| - <div data-tip="Qwik-UI Version" class="mr-auto"> |
51 |
| - v.{version} |
52 |
| - </div> |
53 |
| - <nav class="hidden sm:flex gap-4"> |
54 |
| - <a href="/docs">Docs</a> |
55 |
| - <a href="/contact">Contact</a> |
56 |
| - </nav> |
57 |
| - {isDocsRoute && <SelectTheme />} |
58 |
| - <button |
59 |
| - type="button" |
60 |
| - aria-label="Toggle dark mode" |
61 |
| - onClick$={toggleDarkMode} |
62 |
| - > |
63 |
| - {appState.mode === 'dark' ? <MoonIcon /> : <SunIcon />} |
64 |
| - </button> |
65 |
| - <a |
66 |
| - target="_blank" |
67 |
| - href="https://github.com/qwikifiers/qwik-ui" |
68 |
| - aria-label="Qwik-UI GitHub repository" |
69 |
| - class="sm:mr-8" |
| 51 | + const toggleDarkMode = $(() => { |
| 52 | + appState.mode = appState.mode === 'light' ? 'dark' : 'light'; |
| 53 | + }); |
| 54 | + |
| 55 | + return ( |
| 56 | + <header |
| 57 | + class={[ |
| 58 | + `fixed top-0 w-full h-20 z-20 bg-[var(--color-bg)] flex gap-8 p-4 items-center`, |
| 59 | + showBottomBorder |
| 60 | + ? `border-b-[1px] border-slate-300 dark:border-slate-600` |
| 61 | + : ``, |
| 62 | + ]} |
70 | 63 | >
|
71 |
| - <GitHubIcon /> |
72 |
| - </a> |
73 |
| - </header> |
74 |
| - ); |
75 |
| -}); |
| 64 | + <button |
| 65 | + type="button" |
| 66 | + aria-label="Toggle navigation" |
| 67 | + onClick$={toggleMenu$} |
| 68 | + class="block lg:hidden" |
| 69 | + > |
| 70 | + {menuOpenSignal.value ? <CloseIcon /> : <MenuIcon />} |
| 71 | + </button> |
| 72 | + {menuOpenSignal.value && ( |
| 73 | + <aside class="fixed top-0 left-0"> |
| 74 | + <div class="fixed h-screen w-screen bg-gray-900/20 backdrop-blur-sm"></div> |
| 75 | + <div class="fixed h-screen w-80 overflow-y-scroll bg-white"> |
| 76 | + <Menu onClose$={toggleMenu$} /> |
| 77 | + </div> |
| 78 | + </aside> |
| 79 | + )} |
| 80 | + <a href="/" class="lg:ml-8"> |
| 81 | + <img src="/qwik-ui.png" class="h-12 w-auto object-contain" /> |
| 82 | + </a> |
| 83 | + <div data-tip="Qwik-UI Version" class="mr-auto"> |
| 84 | + {showVersion && ( |
| 85 | + <div class="flex flex-col"> |
| 86 | + <span> {kitSignal.value?.name} Kit </span> |
| 87 | + <span> v.{kitSignal.value?.version} </span> |
| 88 | + </div> |
| 89 | + )} |
| 90 | + </div> |
| 91 | + |
| 92 | + <nav class="hidden sm:flex gap-4"> |
| 93 | + <a href="/about">About</a> |
| 94 | + <a href="/docs/headless/introduction">Headless Kit</a> |
| 95 | + <a href="/docs/tailwind/introduction">Tailwind Kit</a> |
| 96 | + <a href="https://discord.gg/PVWUUejrez" target="_blank"> |
| 97 | + Community |
| 98 | + </a> |
| 99 | + {/* <a href="/contact">Contact</a> */} |
| 100 | + </nav> |
| 101 | + |
| 102 | + <button |
| 103 | + type="button" |
| 104 | + aria-label="Toggle dark mode" |
| 105 | + onClick$={toggleDarkMode} |
| 106 | + > |
| 107 | + {appState.mode === 'dark' ? <MoonIcon /> : <SunIcon />} |
| 108 | + </button> |
| 109 | + <a |
| 110 | + target="_blank" |
| 111 | + href="https://github.com/qwikifiers/qwik-ui" |
| 112 | + aria-label="Qwik-UI GitHub repository" |
| 113 | + class="sm:mr-8" |
| 114 | + > |
| 115 | + <GitHubIcon /> |
| 116 | + </a> |
| 117 | + </header> |
| 118 | + ); |
| 119 | + } |
| 120 | +); |
0 commit comments