mirror of
https://gitlab.com/mbugroup/lti-web-client.git
synced 2026-05-24 15:25:46 +00:00
Merge branch 'development' into fix/project-flock
This commit is contained in:
@@ -0,0 +1,17 @@
|
||||
import Button from '@/components/Button';
|
||||
|
||||
const PageNotFound = () => {
|
||||
return (
|
||||
<div className='w-full h-full flex-1 flex flex-col justify-center items-center gap-4'>
|
||||
<h2 className='text-2xl font-bold text-error'>Halaman Tidak Ditemukan</h2>
|
||||
<p className='text-gray-600 text-center'>
|
||||
Halaman atau data yang anda cari tidak ditemukan.
|
||||
</p>
|
||||
<Button href='/dashboard' className='text-base-100'>
|
||||
Kembali ke Dashboard
|
||||
</Button>
|
||||
</div>
|
||||
);
|
||||
};
|
||||
|
||||
export default PageNotFound;
|
||||
@@ -1,5 +1,6 @@
|
||||
import Alert from '@/components/Alert';
|
||||
import Button from '@/components/Button';
|
||||
import { cn } from '@/lib/helper';
|
||||
import { Icon } from '@iconify/react';
|
||||
import { useState } from 'react';
|
||||
|
||||
@@ -10,34 +11,68 @@ import { useState } from 'react';
|
||||
*/
|
||||
const AlertErrorList = ({
|
||||
formErrorList,
|
||||
className,
|
||||
onClose,
|
||||
title,
|
||||
}: {
|
||||
formErrorList: string[];
|
||||
className?: {
|
||||
alert?: string;
|
||||
button?: string;
|
||||
headerWrapper?: string;
|
||||
headerIcon?: string;
|
||||
headerText?: string;
|
||||
titleWrapper?: string;
|
||||
ul?: string;
|
||||
li?: string;
|
||||
};
|
||||
onClose: () => void;
|
||||
title?: string;
|
||||
}) => {
|
||||
if (formErrorList.length === 0) return null;
|
||||
|
||||
return (
|
||||
<Alert color='error' className='w-full flex flex-col gap-2 px-4'>
|
||||
<div className='flex justify-between items-center gap-2 w-full'>
|
||||
<div className='flex items-center gap-2'>
|
||||
<Icon icon='material-symbols:error-outline' width={24} height={24} />
|
||||
<span className='font-semibold'>
|
||||
Terdapat {formErrorList.length} error pada form:
|
||||
<Alert
|
||||
color='error'
|
||||
className={cn(
|
||||
'w-full flex flex-col gap-2 px-3 rounded-lg',
|
||||
className?.alert
|
||||
)}
|
||||
>
|
||||
<div
|
||||
className={cn(
|
||||
'flex justify-between items-center gap-2 w-full',
|
||||
className?.headerWrapper
|
||||
)}
|
||||
>
|
||||
<div className={cn('flex items-center gap-2', className?.titleWrapper)}>
|
||||
<Icon
|
||||
icon='material-symbols:error-outline'
|
||||
className={cn(className?.headerIcon)}
|
||||
width={20}
|
||||
height={20}
|
||||
/>
|
||||
<span className={cn('font-semibold text-sm', className?.headerText)}>
|
||||
{title || `Terdapat ${formErrorList.length} error pada form:`}
|
||||
</span>
|
||||
</div>
|
||||
<Button
|
||||
onClick={onClose}
|
||||
variant='link'
|
||||
className='ml-auto p-0 w-fit text-white'
|
||||
className={cn('ml-auto p-0 w-fit text-white', className?.button)}
|
||||
color='none'
|
||||
>
|
||||
<Icon icon='material-symbols:close' width={24} height={24} />
|
||||
<Icon icon='material-symbols:close' width={20} height={20} />
|
||||
</Button>
|
||||
</div>
|
||||
<ul className='list-disc list-inside pl-8 space-y-1 w-full'>
|
||||
<ul
|
||||
className={cn(
|
||||
'list-disc list-inside pl-4 space-y-1.5 w-full',
|
||||
className?.ul
|
||||
)}
|
||||
>
|
||||
{formErrorList.map((error, index) => (
|
||||
<li key={index} className='text-sm'>
|
||||
<li key={index} className={cn('text-sm', className?.li)}>
|
||||
{error}
|
||||
</li>
|
||||
))}
|
||||
|
||||
Reference in New Issue
Block a user