Added search icon to filter search inputs.

This commit is contained in:
DebaucheryLibrarian 2025-08-27 05:13:07 +02:00
parent 63ee4cae31
commit bd9a794e34
5 changed files with 68 additions and 29 deletions

View File

@ -6,12 +6,16 @@
>Some actors may not be listed, apply a filter or search to narrow down results.</div>
<div class="filters-sort">
<input
v-model="search"
type="search"
:placeholder="`Filter ${availableActors.length} actors`"
class="input input-inline filters-search"
>
<label class="filter-search">
<input
v-model="search"
type="search"
:placeholder="`Filter ${availableActors.length} actors`"
class="input input-inline filters-search"
>
<Icon icon="search" />
</label>
<div
class="filter-sort noselect"

View File

@ -1,12 +1,16 @@
<template>
<div class="filter channels-container">
<div class="filters-sort">
<input
v-model="search"
type="search"
:placeholder="`Filter ${channels.length} channels`"
class="input input-inline filters-search"
>
<label class="filter-search">
<input
v-model="search"
type="search"
:placeholder="`Filter ${channels.length} channels`"
class="input input-inline filters-search"
>
<Icon icon="search" />
</label>
<div
v-show="order === 'name'"

View File

@ -2,13 +2,19 @@
<div
class="countries-container"
>
<input
<label
v-if="!filters.country"
v-model="countryQuery"
type="search"
placeholder="Filter countries"
class="input input-inline countries-search"
class="filter-search"
>
<input
v-model="countryQuery"
type="search"
placeholder="Filter countries"
class="input input-inline countries-search filters-search"
>
<Icon icon="search" />
</label>
<div
v-if="filteredCountries.length > 0"
@ -28,7 +34,10 @@
/>
</div>
<div class="empty">
<div
v-else
class="empty"
>
No matching countries
</div>
</div>
@ -66,13 +75,12 @@ const filteredCountries = computed(() => allCountries.value.filter((country) =>
<style scoped>
.countries-container {
border-bottom: solid 1px var(--shadow-weak-30);
padding: .25rem 0;
padding-bottom: .25rem;
margin-bottom: .5rem;
}
.countries-search {
width: 100%;
margin-bottom: .25rem;
.filter-search {
border-bottom: solid 1px var(--shadow-weak-40);
}

View File

@ -272,7 +272,6 @@ function toggleFilters(state) {
&.order {
padding: 0 .5rem 0 .25rem;
}
.icon {
fill: var(--glass);
}
@ -286,6 +285,26 @@ function toggleFilters(state) {
}
}
.filter-search {
display: flex;
flex-direction: row-reverse;
cursor: pointer;
.icon {
padding: .5rem .25rem .5rem .75rem;
fill: var(--glass-weak-20);
&:hover {
cursor: pointer;
fill: var(--primary);
}
}
.input:focus + .icon {
fill: var(--primary);
}
}
.filter-details {
display: flex;
align-items: stretch;

View File

@ -1,12 +1,16 @@
<template>
<div class="filter tags-container">
<div class="filters-sort">
<input
v-model="search"
type="search"
:placeholder="`Filter ${groupedTags.available.length} tags`"
class="input input-inline filters-search"
>
<label class="filter-search">
<input
v-model="search"
type="search"
:placeholder="`Filter ${groupedTags.available.length} tags`"
class="input input-inline filters-search"
>
<Icon icon="search" />
</label>
<div
v-show="order === 'priority'"