import React, { memo, useState, useEffect } from 'react';
import { Space, Tag, ConfigProvider, Button, Row, Col, Card, Input } from 'antd';
import {
PlusOutlined,
EditOutlined,
DeleteOutlined,
EyeOutlined,
SearchOutlined,
CheckOutlined,
CloseOutlined,
} from '@ant-design/icons';
import { NotifAlert, NotifOk, NotifConfirmDialog } from '../../../components/Global/ToastNotif';
import { useNavigate } from 'react-router-dom';
import { deleteUser, getAllUser } from '../../../api/user';
import TableList from '../../../components/Global/TableList';
const columns = (showPreviewModal, showEditModal, showDeleteDialog, showApproveDialog) => [
{
title: 'ID',
dataIndex: 'user_id',
key: 'user_id',
width: '5%',
hidden: 'true',
},
{
title: 'Username',
dataIndex: 'username',
key: 'username',
width: '12%',
},
{
title: 'Nama Lengkap',
dataIndex: 'fullname',
key: 'fullname',
width: '15%',
},
{
title: 'Nomor WA',
dataIndex: 'whatsapp_number',
key: 'whatsapp_number',
width: '12%',
},
{
title: 'Level',
dataIndex: 'level',
key: 'level',
width: '8%',
align: 'center',
},
{
title: 'Nama Role',
dataIndex: 'role_name',
key: 'role_name',
width: '12%',
render: (_, { role_name }) => (
<>
{role_name === 'administrator' && (
Administrator
)}
{role_name === 'operator' && (
Operator
)}
{role_name === 'engineer' && (
Engineer
)}
{role_name === 'guest' && (
Guest
)}
>
),
},
{
title: 'Status',
dataIndex: 'status',
key: 'status',
width: '10%',
align: 'center',
render: (_, { status }) => (
<>
{status === 'active' && (
Active
)}
{status === 'pending' && (
Pending
)}
{status === 'inactive' && (
Inactive
)}
{status === 'rejected' && (
Rejected
)}
>
),
},
{
title: 'Aksi',
key: 'aksi',
align: 'center',
width: '15%',
render: (_, record) => (
}
onClick={() => showPreviewModal(record)}
/>
{record.status === 'pending' && (
}
onClick={() => showApproveDialog(record)}
/>
)}
}
onClick={() => showEditModal(record)}
/>
}
onClick={() => showDeleteDialog(record)}
/>
),
},
];
const ListUser = memo(function ListUser(props) {
const [showFilter, setShowFilter] = useState(false);
const [trigerFilter, setTrigerFilter] = useState(false);
const defaultFilter = { search: '' };
const [formDataFilter, setFormDataFilter] = useState(defaultFilter);
const [searchValue, setSearchValue] = useState('');
const navigate = useNavigate();
useEffect(() => {
const token = localStorage.getItem('token');
if (token) {
if (props.actionMode == 'list') {
setFormDataFilter(defaultFilter);
doFilter();
}
} else {
navigate('/signin');
}
}, [props.actionMode]);
const toggleFilter = () => {
setFormDataFilter(defaultFilter);
setShowFilter((prev) => !prev);
};
const doFilter = () => {
setTrigerFilter((prev) => !prev);
};
const handleSearch = () => {
setFormDataFilter({ search: searchValue });
setTrigerFilter((prev) => !prev);
};
const handleSearchClear = () => {
setSearchValue('');
setFormDataFilter({ search: '' });
setTrigerFilter((prev) => !prev);
};
const showPreviewModal = (param) => {
props.setSelectedData(param);
props.setActionMode('preview');
};
const showEditModal = (param = null) => {
props.setSelectedData(param);
props.setActionMode('edit');
};
const showAddModal = (param = null) => {
props.setSelectedData(param);
props.setActionMode('add');
};
const showApproveDialog = (param) => {
NotifConfirmDialog({
icon: 'question',
title: 'Konfirmasi Approve User',
message: 'Apakah anda yakin approve user "' + param.fullname + '" ?',
onConfirm: () => handleApprove(param.user_id),
onCancel: () => props.setSelectedData(null),
});
};
const showDeleteDialog = (param) => {
NotifConfirmDialog({
icon: 'question',
title: 'Konfirmasi',
message: 'Apakah anda yakin hapus user "' + param.fullname + '" ?',
onConfirm: () => handleDelete(param.user_id),
onCancel: () => props.setSelectedData(null),
});
};
const handleApprove = async (user_id) => {
// TODO: Implement approve user API call
NotifAlert({
icon: 'info',
title: 'Info',
message: 'Approve user akan diimplementasikan dengan API',
});
// const response = await approveUser(user_id);
// if (response.statusCode == 200) {
// NotifAlert({
// icon: 'success',
// title: 'Berhasil',
// message: 'User berhasil diapprove.',
// });
// doFilter();
// }
};
const handleDelete = async (user_id) => {
const response = await deleteUser(user_id);
if (response.statusCode == 200) {
NotifAlert({
icon: 'success',
title: 'Berhasil',
message: 'User "' + response.data.fullname + '" berhasil dihapus.',
});
doFilter();
} else {
NotifOk({
icon: 'error',
title: 'Gagal',
message: 'Gagal Menghapus User',
});
}
};
return (
{
const value = e.target.value;
setSearchValue(value);
// Auto search when clearing by backspace/delete
if (value === '') {
setFormDataFilter({ search: '' });
setTrigerFilter((prev) => !prev);
}
}}
onSearch={handleSearch}
allowClear={{
clearIcon: ✕,
}}
enterButton={
}
style={{
backgroundColor: '#23A55A',
borderColor: '#23A55A',
}}
>
Search
}
size="large"
/>
}
onClick={() => showAddModal()}
size="large"
>
Tambah User
);
});
export default ListUser;