searchbar

This commit is contained in:
Abdenasser 2024-11-13 14:46:17 +01:00
parent 596fc19b29
commit b5e4acf13f
2 changed files with 92 additions and 15 deletions

View File

@ -0,0 +1,90 @@
<script lang="ts">
export let searchTerm: string;
</script>
<div class="search-box">
<div class="search-input-wrapper">
<input
type="text"
placeholder="Search processes"
bind:value={searchTerm}
class="search-input"
/>
{#if searchTerm}
<button class="btn-clear" on:click={() => (searchTerm = "")}>
Clear
</button>
{/if}
</div>
</div>
<style>
.search-box {
width: 240px;
}
.search-input-wrapper {
position: relative;
display: flex;
gap: 8px;
align-items: center;
}
.search-input {
width: 100%;
height: 28px;
padding: 0 12px;
padding-right: 70px;
border: 1px solid var(--surface1);
border-radius: 6px;
font-size: 12px;
background-color: var(--surface0);
color: var(--text);
transition: all 0.2s ease;
}
.btn-clear {
position: absolute;
right: 4px;
top: 50%;
transform: translateY(-50%);
padding: 4px 8px;
font-size: 11px;
color: var(--subtext0);
background: var(--surface1);
border: none;
border-radius: 4px;
cursor: pointer;
transition: all 0.2s ease;
}
.btn-clear:hover {
background: var(--surface2);
color: var(--text);
}
.search-input::-webkit-search-cancel-button {
-webkit-appearance: none;
height: 14px;
width: 14px;
margin-right: 4px;
background: var(--overlay0);
-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='18' y1='6' x2='6' y2='18'%3E%3C/line%3E%3Cline x1='6' y1='6' x2='18' y2='18'%3E%3C/line%3E%3C/svg%3E")
no-repeat 50% 50%;
cursor: pointer;
}
.search-input::-webkit-search-cancel-button:hover {
background: var(--text);
}
.search-input:hover {
background-color: var(--surface1);
}
.search-input:focus {
outline: none;
border-color: var(--blue);
box-shadow: 0 0 0 2px color-mix(in srgb, var(--blue) 25%, transparent);
}
</style>

View File

@ -11,6 +11,7 @@
import { configStore } from "$lib/stores/config";
import type { AppConfig } from "$lib/types/config";
import StatusFilter from "./StatusFilter.svelte";
import SearchBox from "./SearchBox.svelte";
export let searchTerm: string;
export let statusFilter: string = "all";
export let itemsPerPage: number;
@ -73,21 +74,7 @@
<div class="toolbar">
<div class="toolbar-content">
<div class="search-box">
<div class="search-input-wrapper">
<input
type="text"
placeholder="Search processes"
bind:value={searchTerm}
class="search-input"
/>
{#if searchTerm}
<button class="btn-clear" on:click={() => (searchTerm = "")}>
Clear
</button>
{/if}
</div>
</div>
<SearchBox bind:searchTerm />
<StatusFilter bind:statusFilter />
<div class="toolbar-spacer"></div>