Add hits to searchModal

This commit is contained in:
philipp lang 2024-07-03 17:20:47 +02:00
parent c65a25ed2a
commit fd9aff25fe
1 changed files with 16 additions and 20 deletions

View File

@ -1,24 +1,24 @@
<template> <template>
<div class="fixed z-40 top-0 left-0 w-full h-full flex items-start pt-12 justify-center p-6 bg-black/60" <div class="fixed z-40 top-0 left-0 w-full h-full flex items-start pt-12 justify-center p-6 bg-black/60" @click.self="emit('close')">
@click.self="emit('close')"> <div class="relative rounded-lg p-4 sm:p-8 shadow-2xl shadow-black border border-sky-700/30 bg-sky-800/10 border-solid w-full max-w-[50rem] overflow-auto backdrop-blur-lg">
<div
class="relative rounded-lg p-4 sm:p-8 shadow-2xl shadow-black border border-sky-700/30 bg-sky-800/10 border-solid w-full max-w-[50rem] overflow-auto backdrop-blur-lg">
<div class="relative"> <div class="relative">
<input ref="searchInput" v-model="searchString" type="text" <input
ref="searchInput"
v-model="searchString"
type="text"
class="w-full px-3 sm:px-5 py-2 sm:py-3 pl-12 sm:pl-16 rounded-xl sm:rounded-2xl border-sky-200/40 text-sky-200 sm:text-xl placeholder-sky-200/40 bg-sky-600/20" class="w-full px-3 sm:px-5 py-2 sm:py-3 pl-12 sm:pl-16 rounded-xl sm:rounded-2xl border-sky-200/40 text-sky-200 sm:text-xl placeholder-sky-200/40 bg-sky-600/20"
placeholder="Wer suchet, der findet …" /> placeholder="Wer suchet, der findet …"
/>
<div class="absolute flex items-center h-full top-0 left-4"> <div class="absolute flex items-center h-full top-0 left-4">
<ui-sprite src="search" class="w-5 h-5 sm:w-7 sm:h-7 text-sky-200/20" /> <ui-sprite src="search" class="w-5 h-5 sm:w-7 sm:h-7 text-sky-200/20" />
</div> </div>
</div> </div>
<div v-if="results !== null" class="mt-5 sm:mt-10 space-y-2"> <div v-if="results.hits.length" class="mt-5 sm:mt-10 space-y-2">
<div v-for="member in results.hits" :key="member.id"> <div v-for="member in results.hits" :key="member.id">
<div <div class="flex items-center justify-between hover:bg-sky-600/20 transition text-sky-300 px-3 sm:px-6 py-1 sm:py-3 rounded-lg">
class="flex items-center justify-between hover:bg-sky-600/20 transition text-sky-300 px-3 sm:px-6 py-1 sm:py-3 rounded-lg">
<div class="flex space-x-2 items-center"> <div class="flex space-x-2 items-center">
<div class="w-5 sm:w-16 flex flex-none"> <div class="w-5 sm:w-16 flex flex-none">
<ui-age-groups icon-class="w-4 h-4 sm:w-6 sm:h-6" class="flex-col sm:flex-row" <ui-age-groups icon-class="w-4 h-4 sm:w-6 sm:h-6" class="flex-col sm:flex-row" :member="member"></ui-age-groups>
:member="member"></ui-age-groups>
</div> </div>
<div class="flex items-baseline flex-col md:flex-row"> <div class="flex items-baseline flex-col md:flex-row">
<span class="text-lg" v-text="member.fullname"></span> <span class="text-lg" v-text="member.fullname"></span>
@ -26,12 +26,8 @@
</div> </div>
</div> </div>
<div class="flex space-x-2"> <div class="flex space-x-2">
<i-link v-tooltip="`Details`" :href="member.links.show" <i-link v-tooltip="`Details`" :href="member.links.show" class="inline-flex btn btn-primary btn-sm" @click="emit('close')"><ui-sprite src="eye"></ui-sprite></i-link>
class="inline-flex btn btn-primary btn-sm" @click="emit('close')"><ui-sprite <i-link v-tooltip="`Bearbeiten`" :href="member.links.edit" class="inline-flex btn btn-warning btn-sm" @click="emit('close')"><ui-sprite src="pencil"></ui-sprite></i-link>
src="eye"></ui-sprite></i-link>
<i-link v-tooltip="`Bearbeiten`" :href="member.links.edit"
class="inline-flex btn btn-warning btn-sm" @click="emit('close')"><ui-sprite
src="pencil"></ui-sprite></i-link>
</div> </div>
</div> </div>
</div> </div>
@ -40,7 +36,7 @@
</div> </div>
</template> </template>
<script setup> <script lang="js" setup>
import { computed, ref, onMounted } from 'vue'; import { computed, ref, onMounted } from 'vue';
import useSearch from '../../composables/useSearch.js'; import useSearch from '../../composables/useSearch.js';
const emit = defineEmits(['close']); const emit = defineEmits(['close']);
@ -48,7 +44,7 @@ const emit = defineEmits(['close']);
const { search } = useSearch(); const { search } = useSearch();
const realSearchString = ref(''); const realSearchString = ref('');
const results = ref(null); const results = ref({ hits: [] });
const searchInput = ref(null); const searchInput = ref(null);
onMounted(() => { onMounted(() => {
@ -61,7 +57,7 @@ const searchString = computed({
realSearchString.value = v; realSearchString.value = v;
if (!v.length) { if (!v.length) {
results.value = null; results.value = { hits: [] };
return; return;
} }
results.value = await search(v, [], { limit: 10 }); results.value = await search(v, [], { limit: 10 });