front base init

This commit is contained in:
Gabriel Goldbronn
2025-03-02 21:17:23 +01:00
parent b054c8a316
commit b8e682f333
63 changed files with 22864 additions and 0 deletions

View File

@@ -0,0 +1,65 @@
<script setup lang="ts">
import {lectureListIsOpen, playlistsIsOpen, useSearchStore} from '../stores/globalStore.ts'
import SearchIcon from "../assets/Icons/SearchIcon.vue";
const searchStore = useSearchStore();
const lectureList = lectureListIsOpen();
const playlists = playlistsIsOpen();
const updateSearch = (event: Event) => {
lectureList.closeLectureList();
playlists.closePlaylists();
searchStore.updateSearch((event.target as HTMLInputElement).value);
};
</script>
<template>
<div class="group">
<SearchIcon />
<input placeholder="Search" type="search" class="input" @input="updateSearch">
</div>
</template>
<style scoped>
.group {
display: flex;
line-height: 28px;
align-items: center;
position: relative;
width: 100%;
}
.input {
width: 100%;
height: 40px;
line-height: 28px;
padding: 0 1rem;
padding-left: 2.5rem;
border: 2px solid transparent;
border-radius: 9px;
outline: none;
background-color: var(--neutral-50);
color: var(--neutral-950);
transition: .3s ease;
}
.input::placeholder {
color: var(--neutral-500);
}
.input:focus, input:hover {
outline: none;
border-color: var(--primary-800);
background-color: var(--neutral-100);
box-shadow: 0 0 0 4px rgb(234 76 137 / 10%);
}
.icon {
position: absolute;
left: 1rem;
fill: #9e9ea7;
width: 1rem;
height: 1rem;
}
</style>