feat : update search

Deskripsi:
- add api search

No Issue
This commit is contained in:
lukman
2024-08-28 17:39:53 +08:00
committed by amel
parent 2d31379382
commit 0fe48f0f30
4 changed files with 139 additions and 1 deletions

View File

@@ -0,0 +1,6 @@
export const funGetSearchAll = async (path?: string) => {
const response = await fetch(`/api/home/search${(path) ? path : ''}`, { next: { tags: ['search'] } });
return await response.json().catch(() => null);
}

View File

View File

@@ -1,9 +1,33 @@
"use client"
import { LayoutNavbarNew, WARNA } from '@/module/_global';
import { Box, TextInput } from '@mantine/core';
import React from 'react';
import React, { useState } from 'react';
import { HiMagnifyingGlass } from 'react-icons/hi2';
import { funGetSearchAll } from '../lib/api_search';
import { useShallowEffect } from '@mantine/hooks';
export default function ViewSearch() {
const [search, setSearch] = useState('');
const [dataUser, setDataUser] = useState([]);
const [dataProject, setDataProject] = useState([]);
const [dataDivision, setDataDivision] = useState([]);
async function featchSearch() {
try {
const res = await funGetSearchAll('?search=' + search);
setDataUser(res.data.user);
setDataProject(res.data.project);
setDataDivision(res.data.division);
} catch (error) {
console.error(error)
throw new Error("Error")
}
}
useShallowEffect(() => {
featchSearch()
}, [search])
return (
<>
<LayoutNavbarNew back='/home' title='Pencarian' menu={<></>} />
@@ -20,7 +44,12 @@ export default function ViewSearch() {
radius={30}
leftSection={<HiMagnifyingGlass size={20} />}
placeholder="Pencarian"
onChange={(e) => setSearch(e.target.value)}
/>
<pre>{JSON.stringify(dataUser, null, 1)}</pre>
<pre>{JSON.stringify(dataProject, null, 1)}</pre>
<pre>{JSON.stringify(dataDivision, null, 1)}</pre>
</Box>
</>
);