clear search button

This commit is contained in:
Simon
2026-02-09 21:40:34 +00:00
parent d2e1e3adea
commit 3d81b6aae7
3 changed files with 57 additions and 1 deletions

View File

@@ -98,11 +98,12 @@ body.theme-light .top-bar {
.search-container { .search-container {
flex: 1; flex: 1;
max-width: 500px; max-width: 500px;
position: relative;
} }
.search-container input { .search-container input {
width: 100%; width: 100%;
padding: 10px 16px; padding: 10px 44px 10px 16px;
background: var(--bg-tertiary); background: var(--bg-tertiary);
border: 1px solid var(--border); border: 1px solid var(--border);
border-radius: 999px; border-radius: 999px;
@@ -122,6 +123,38 @@ body.theme-light .top-bar {
color: var(--text-secondary); color: var(--text-secondary);
} }
.search-clear-btn {
position: absolute;
top: 50%;
right: 12px;
transform: translateY(-50%);
width: 26px;
height: 26px;
border: none;
border-radius: 50%;
background: var(--bg-secondary);
color: var(--text-secondary);
cursor: pointer;
display: flex;
align-items: center;
justify-content: center;
font-size: 16px;
line-height: 1;
opacity: 0;
pointer-events: none;
transition: opacity 0.2s ease, background 0.2s ease, color 0.2s ease;
}
.search-clear-btn.is-visible {
opacity: 1;
pointer-events: auto;
}
.search-clear-btn:hover {
background: var(--bg-tertiary);
color: var(--text-primary);
}
.actions { .actions {
display: flex; display: flex;
gap: 12px; gap: 12px;

View File

@@ -15,6 +15,7 @@
<div class="logo">Jacuzzi</div> <div class="logo">Jacuzzi</div>
<div class="search-container"> <div class="search-container">
<input type="text" id="search-input" placeholder="Search videos..." oninput="handleSearch(this.value)"> <input type="text" id="search-input" placeholder="Search videos..." oninput="handleSearch(this.value)">
<button class="search-clear-btn" id="search-clear-btn" type="button" aria-label="Clear search" title="Clear search"></button>
</div> </div>
<div class="actions"> <div class="actions">
<button class="icon-btn reload-toggle" id="reload-channel-btn" title="Reload Channel"> <button class="icon-btn reload-toggle" id="reload-channel-btn" title="Reload Channel">

View File

@@ -489,6 +489,28 @@ App.ui = App.ui || {};
window.closePlayer = App.player.close; window.closePlayer = App.player.close;
window.handleSearch = App.videos.handleSearch; window.handleSearch = App.videos.handleSearch;
const searchInput = document.getElementById('search-input');
const clearSearchBtn = document.getElementById('search-clear-btn');
if (searchInput && clearSearchBtn) {
const updateClearVisibility = () => {
const hasValue = searchInput.value.trim().length > 0;
clearSearchBtn.classList.toggle('is-visible', hasValue);
clearSearchBtn.disabled = !hasValue;
};
clearSearchBtn.addEventListener('click', (event) => {
event.preventDefault();
if (!searchInput.value) return;
searchInput.value = '';
updateClearVisibility();
App.videos.handleSearch('');
searchInput.focus();
});
searchInput.addEventListener('input', updateClearVisibility);
updateClearVisibility();
}
document.addEventListener('keydown', (event) => { document.addEventListener('keydown', (event) => {
if (event.key === 'Escape') { if (event.key === 'Escape') {
App.ui.closeDrawers(); App.ui.closeDrawers();