Compare commits

..

No commits in common. "0f744f861b5576018bb9a4676322d2387c2b092b" and "68644842fc002639dfcb0d5d08f60455baff4784" have entirely different histories.

2 changed files with 2916 additions and 3566 deletions

6417
pnpm-lock.yaml generated

File diff suppressed because it is too large Load Diff

View File

@ -94,34 +94,45 @@ export default function Table({ employees }: { employees: Employee[] }) {
setStatus(e.target.value); setStatus(e.target.value);
}; };
const handleSubmit = async () => { const handleSubmit = async () => {
if (!session) { if (selectedIds.length === 0) {
alert("You must be signed in to update status."); if (!session) {
return; alert("You must be signed in to update status.");
} return;
// If no employee is selected and status is not empty } else {
if (selectedIds.length === 0 && employeeStatus.trim() !== '') { const cur_user = employees.find(employee => employee.name === session?.user?.name);
const cur_user = employees.find(employee => employee.name === session.user?.name); if (cur_user) {
if (cur_user) { await fetch('/api/v2/update_status', {
setSelectedIds([cur_user.id]); method: 'POST',
headers: {
'Content-Type': 'application/json',
'Authorization': `Bearer ${process.env.API_KEY}`
},
body: JSON.stringify({ employeeIds: [cur_user.id], newStatus: employeeStatus }),
});
// Optionally refresh data on the client-side after update
const updatedEmployees = await fetchEmployees();
setEmployeeData(updatedEmployees);
setSelectedIds([]);
setStatus('');
}
}
} else if (employeeStatus.trim() === '') {
await fetch('/api/v2/update_status', {
method: 'POST',
headers: {
'Content-Type': 'application/json',
'Authorization': `Bearer ${process.env.API_KEY}`
},
body: JSON.stringify({ employeeIds: selectedIds, newStatus: employeeStatus }),
});
// Optionally refresh data on the client-side after update
const updatedEmployees = await fetchEmployees();
setEmployeeData(updatedEmployees);
setSelectedIds([]);
setStatus('');
} }
} else if (employeeStatus.trim() !== '') { };
await fetch('/api/v2/update_status', {
method: 'POST',
headers: {
'Content-Type': 'application/json',
'Authorization': `Bearer ${process.env.API_KEY}`
},
body: JSON.stringify({ employeeIds: selectedIds, newStatus: employeeStatus }),
});
// Optionally refresh data on the client-side after update
const updatedEmployees = await fetchEmployees();
setEmployeeData(updatedEmployees);
setSelectedIds([]);
setStatus('');
}
};
const handleKeyPress = async (e: React.KeyboardEvent<HTMLInputElement>) => { const handleKeyPress = async (e: React.KeyboardEvent<HTMLInputElement>) => {
if (e.key === 'Enter') { if (e.key === 'Enter') {