From 7f23b7888b2eda1bd413e513c6e31d52be40086c Mon Sep 17 00:00:00 2001 From: Innocent-akim Date: Wed, 6 Nov 2024 22:54:38 +0200 Subject: [PATCH 1/3] feat:Implement EditTaskModal component with enhanced task editing UI and state management --- .../[memberId]/components/EditTaskModal.tsx | 225 ++++++++++++++++++ .../[memberId]/components/TimesheetAction.tsx | 6 + .../components/TimesheetFilterDate.tsx | 2 +- .../timesheet/[memberId]/components/index.tsx | 3 +- .../calendar/table-time-sheet.tsx | 70 +++--- .../lib/features/multiple-select/index.tsx | 63 +++++ 6 files changed, 340 insertions(+), 29 deletions(-) create mode 100644 apps/web/app/[locale]/timesheet/[memberId]/components/EditTaskModal.tsx diff --git a/apps/web/app/[locale]/timesheet/[memberId]/components/EditTaskModal.tsx b/apps/web/app/[locale]/timesheet/[memberId]/components/EditTaskModal.tsx new file mode 100644 index 000000000..37b2cbd5b --- /dev/null +++ b/apps/web/app/[locale]/timesheet/[memberId]/components/EditTaskModal.tsx @@ -0,0 +1,225 @@ +import { Button, Modal, statusColor } from "@/lib/components"; +import { IoMdArrowDropdown } from "react-icons/io"; +import { FaRegClock } from "react-icons/fa"; +import { DatePickerFilter } from "./TimesheetFilterDate"; +import { useState } from "react"; +import { useTranslations } from "next-intl"; +import { clsxm } from "@/app/utils"; +import { Item, ManageOrMemberComponent, getNestedValue } from "@/lib/features/manual-time/manage-member-component"; +import { useTeamTasks } from "@/app/hooks"; +import { CustomSelect } from "@/lib/features"; +import { statusTable } from "./TimesheetAction"; + +export interface IEditTaskModalProps { + isOpen: boolean; + closeModal: () => void; + +} +export function EditTaskModal({ isOpen, closeModal }: IEditTaskModalProps) { + const { activeTeam } = useTeamTasks(); + const t = useTranslations(); + const [dateRange, setDateRange] = useState<{ from: Date | null }>({ + from: new Date(), + }); + const [endTime, setEndTime] = useState(''); + const [startTime, setStartTime] = useState(''); + const [isBillable, setIsBillable] = useState(false); + const [reason, setReason] = useState(''); + const memberItemsLists = { + Project: activeTeam?.projects as [], + }; + const handleSelectedValuesChange = (values: { [key: string]: Item | null }) => { + console.log(values); + }; + const selectedValues = { + Teams: null, + }; + + const handleChange = (field: string, selectedItem: Item | null) => { + console.log(`Field: ${field}, Selected Item:`, selectedItem); + }; + + const fields = [ + { + label: 'Project', + placeholder: 'Select a project', + isRequired: true, + valueKey: 'id', + displayKey: 'name', + element: 'Project' + }, + ]; + + const handleFromChange = (fromDate: Date | null) => { + setDateRange((prev) => ({ ...prev, from: fromDate })); + }; + return ( + +
+
+ #321 Spike for creating calendar views on mobile +
+ for + Savannah Nguyen + +
+
+
+
+ Task Time +
+ + 08:10h +
+
+
+
+ + setStartTime(e.target.value)} + className="w-full p-1 border font-normal border-slate-300 dark:border-slate-600 dark:bg-dark--theme-light rounded-md" + required + /> +
+ +
+ + + setEndTime(e.target.value)} + className="w-full p-1 border font-normal border-slate-300 dark:border-slate-600 dark:bg-dark--theme-light rounded-md" + required + /> +
+ +
+
+ Date + +
+
+ getNestedValue(item, displayKey) || ''} + itemToValue={(item, valueKey) => getNestedValue(item, valueKey) || ''} + /> +
+
+ +
+
+
setIsBillable && setIsBillable(!isBillable)} + style={ + isBillable + ? { background: 'linear-gradient(to right, #9d91efb7, #8a7bedb7)' } + : { background: '#6c57f4b7' } + } > +
+
+ {t('pages.timesheet.BILLABLE.YES')} +
+
+
setIsBillable && setIsBillable(!isBillable)} + style={ + isBillable + ? { background: 'linear-gradient(to right, #9d91efb7, #8a7bedb7)' } + : { background: '#6c57f4b7' } + } > +
+
+ {t('pages.timesheet.BILLABLE.NO')} +
+ +
+
+
+ Notes +