feat: ✨ add search box with fzf
This commit is contained in:
parent
4e3b4f94e3
commit
18507fb69c
|
@ -151,29 +151,6 @@ header details {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.components__header__search {
|
|
||||||
padding: var(--_gap-half) var(--_gap);
|
|
||||||
align-self: center;
|
|
||||||
border: var(--_border-size) solid transparent;
|
|
||||||
background-color: var(--_translucent);
|
|
||||||
min-width: fit-content;
|
|
||||||
outline: none;
|
|
||||||
|
|
||||||
&:focus-visible {
|
|
||||||
border: var(--_border-size) solid currentColor;
|
|
||||||
}
|
|
||||||
|
|
||||||
@media (width < 800px) {
|
|
||||||
& {
|
|
||||||
background-color: transparent;
|
|
||||||
}
|
|
||||||
|
|
||||||
& span {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.components__header__nav_button {
|
.components__header__nav_button {
|
||||||
color: var(--_font-color);
|
color: var(--_font-color);
|
||||||
display: inline-block;
|
display: inline-block;
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
import { asset } from '$fresh/runtime.ts'
|
import { asset } from '$fresh/runtime.ts'
|
||||||
|
import SearchBox from '../islands/SearchBox.tsx'
|
||||||
import ThemePicker from '../islands/ThemePicker.tsx'
|
import ThemePicker from '../islands/ThemePicker.tsx'
|
||||||
|
|
||||||
export function Header() {
|
export function Header() {
|
||||||
|
@ -61,10 +62,7 @@ export function Header() {
|
||||||
</details>
|
</details>
|
||||||
</li>
|
</li>
|
||||||
</nav>
|
</nav>
|
||||||
<button class='components__header__search'>
|
<SearchBox />
|
||||||
<i class='ri-search-line'></i>
|
|
||||||
<span> Rechercher</span>
|
|
||||||
</button>
|
|
||||||
<ThemePicker />
|
<ThemePicker />
|
||||||
</div>
|
</div>
|
||||||
</header>
|
</header>
|
||||||
|
|
64
islands/SearchBox.css
Normal file
64
islands/SearchBox.css
Normal file
|
@ -0,0 +1,64 @@
|
||||||
|
.islands__search_box__button {
|
||||||
|
padding: var(--_gap-half) var(--_gap);
|
||||||
|
border: var(--_border-size) solid transparent;
|
||||||
|
background-color: var(--_translucent);
|
||||||
|
min-width: fit-content;
|
||||||
|
outline: none;
|
||||||
|
|
||||||
|
&:focus-visible {
|
||||||
|
border: var(--_border-size) solid currentColor;
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (width < 800px) {
|
||||||
|
& {
|
||||||
|
background-color: transparent;
|
||||||
|
}
|
||||||
|
|
||||||
|
& span {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.islands__search_box__dialog {
|
||||||
|
width: var(--_wide-screen);
|
||||||
|
height: 80%;
|
||||||
|
overflow-y: scroll;
|
||||||
|
border: var(--_border-size) solid currentColor;
|
||||||
|
background: var(--_background-image) repeat top left / 800px;
|
||||||
|
background-color: var(--_background-color);
|
||||||
|
padding: var(--_gap);
|
||||||
|
gap: var(--_gap);
|
||||||
|
grid-template-rows: auto 1fr;
|
||||||
|
|
||||||
|
&[open] {
|
||||||
|
display: grid;
|
||||||
|
}
|
||||||
|
|
||||||
|
&::backdrop {
|
||||||
|
backdrop-filter: blur(var(--_blur));
|
||||||
|
}
|
||||||
|
|
||||||
|
& input {
|
||||||
|
padding: var(--_gap-half) var(--_gap);
|
||||||
|
border: var(--_border-size) solid transparent;
|
||||||
|
background-color: var(--_translucent);
|
||||||
|
height: fit-content;
|
||||||
|
outline: none;
|
||||||
|
position: sticky;
|
||||||
|
top: 0;
|
||||||
|
|
||||||
|
&:focus-visible {
|
||||||
|
border: var(--_border-size) solid currentColor;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.islands__search_box__dialog__content {
|
||||||
|
padding: var(--_gap-half);
|
||||||
|
width: 100%;
|
||||||
|
height: 100%;
|
||||||
|
text-align: left;
|
||||||
|
text-wrap: balance;
|
||||||
|
display: grid;
|
||||||
|
}
|
54
islands/SearchBox.tsx
Normal file
54
islands/SearchBox.tsx
Normal file
|
@ -0,0 +1,54 @@
|
||||||
|
import { useEffect, useRef } from 'preact/hooks'
|
||||||
|
|
||||||
|
export default function SearchBox() {
|
||||||
|
const dialog = useRef<HTMLDialogElement>(null)
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
dialog.current?.addEventListener('click', (event) => {
|
||||||
|
if (event.target === dialog.current) {
|
||||||
|
dialog.current?.close()
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}, [])
|
||||||
|
|
||||||
|
return (
|
||||||
|
<>
|
||||||
|
<button
|
||||||
|
class='islands__search_box__button'
|
||||||
|
onClick={() => dialog.current?.showModal()}
|
||||||
|
>
|
||||||
|
<i class='ri-search-line'></i>
|
||||||
|
<span> Rechercher</span>
|
||||||
|
</button>
|
||||||
|
<dialog ref={dialog} class='islands__search_box__dialog'>
|
||||||
|
<input type='search' name='' id='' placeholder='Rechercher' autoFocus />
|
||||||
|
<div class='islands__search_box__dialog__content'>
|
||||||
|
<h3>Machines</h3>
|
||||||
|
<ul>
|
||||||
|
<li>machine 1</li>
|
||||||
|
<li>machine 2</li>
|
||||||
|
<li>machine 3</li>
|
||||||
|
</ul>
|
||||||
|
<h3>Projets</h3>
|
||||||
|
<ul>
|
||||||
|
<li>projet 1</li>
|
||||||
|
<li>projet 2</li>
|
||||||
|
<li>projet 3</li>
|
||||||
|
</ul>
|
||||||
|
<h3>Blog</h3>
|
||||||
|
<ul>
|
||||||
|
<li>news 1</li>
|
||||||
|
<li>news 2</li>
|
||||||
|
<li>news 3</li>
|
||||||
|
</ul>
|
||||||
|
<h3>Usager</h3>
|
||||||
|
<ul>
|
||||||
|
<li>Alice</li>
|
||||||
|
<li>Bob</li>
|
||||||
|
<li>Chloé</li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</dialog>
|
||||||
|
</>
|
||||||
|
)
|
||||||
|
}
|
|
@ -4,3 +4,4 @@
|
||||||
@import url('../../components/SponsorCards.css');
|
@import url('../../components/SponsorCards.css');
|
||||||
@import url('../../components/CohabitInfoTable.css');
|
@import url('../../components/CohabitInfoTable.css');
|
||||||
@import url('../../islands/ThemePicker.css');
|
@import url('../../islands/ThemePicker.css');
|
||||||
|
@import url('../../islands/SearchBox.css');
|
||||||
|
|
Loading…
Reference in a new issue