diff --git a/apps/app/components/project/cycles/cycle-issues-list-modal.tsx b/apps/app/components/project/cycles/cycle-issues-list-modal.tsx index 4b033c444..54e526d8b 100644 --- a/apps/app/components/project/cycles/cycle-issues-list-modal.tsx +++ b/apps/app/components/project/cycles/cycle-issues-list-modal.tsx @@ -28,7 +28,7 @@ type Props = { }; type FormInput = { - issue_ids: string[]; + issues: string[]; }; const CycleIssuesListModal: React.FC = ({ @@ -56,12 +56,12 @@ const CycleIssuesListModal: React.FC = ({ formState: { isSubmitting }, } = useForm({ defaultValues: { - issue_ids: [], + issues: [], }, }); const handleAddToCycle: SubmitHandler = (data) => { - if (!data.issue_ids || data.issue_ids.length === 0) { + if (!data.issues || data.issues.length === 0) { setToastAlert({ title: "Error", type: "error", @@ -72,7 +72,7 @@ const CycleIssuesListModal: React.FC = ({ if (activeWorkspace && activeProject) { issuesServices - .bulkAddIssuesToCycle(activeWorkspace.slug, activeProject.id, cycleId, data) + .addIssueToCycle(activeWorkspace.slug, activeProject.id, cycleId, data) .then((res) => { console.log(res); mutate(CYCLE_ISSUES(cycleId)); @@ -120,7 +120,7 @@ const CycleIssuesListModal: React.FC = ({
(
diff --git a/apps/app/components/project/cycles/stats-view/single-stat.tsx b/apps/app/components/project/cycles/stats-view/single-stat.tsx index e3795e83c..dba327e3b 100644 --- a/apps/app/components/project/cycles/stats-view/single-stat.tsx +++ b/apps/app/components/project/cycles/stats-view/single-stat.tsx @@ -63,7 +63,7 @@ const SingleStat: React.FC = ({ cycle, handleEditCycle, handleDeleteCycle return ( <> -
+
@@ -74,7 +74,15 @@ const SingleStat: React.FC = ({ cycle, handleEditCycle, handleDeleteCycle
- + endDate + ? "text-red-500 border-red-500" + : "text-green-500 border-green-500" + }`} + > {today < startDate ? "Not started" : today > endDate ? "Over" : "Active"}
@@ -86,20 +94,19 @@ const SingleStat: React.FC = ({ cycle, handleEditCycle, handleDeleteCycle
- -
+
Cycle dates
-
+
{renderShortNumericDateFormat(startDate)} - {renderShortNumericDateFormat(endDate)}
Created by
-
+
{cycle.owned_by.avatar && cycle.owned_by.avatar !== "" ? ( = ({ cycle, handleEditCycle, handleDeleteCycle Active members
-
+
- - -
- -
-
- - + Edit + + { + handleDeleteIssue(issue.id); + }} + > + Delete permanently + +
); diff --git a/apps/app/components/project/memberInvitations.tsx b/apps/app/components/project/member-invitations.tsx similarity index 85% rename from apps/app/components/project/memberInvitations.tsx rename to apps/app/components/project/member-invitations.tsx index bd25db10a..4bc44f632 100644 --- a/apps/app/components/project/memberInvitations.tsx +++ b/apps/app/components/project/member-invitations.tsx @@ -3,14 +3,13 @@ import React, { useState } from "react"; // next import Link from "next/link"; import useSWR from "swr"; +import { useRouter } from "next/router"; +// services +import projectService from "lib/services/project.service"; // hooks import useUser from "lib/hooks/useUser"; -// Services -import projectService from "lib/services/project.service"; -// fetch keys -import { PROJECT_MEMBERS } from "constants/fetch-keys"; -// commons -import { renderShortNumericDateFormat } from "constants/common"; +// ui +import { Button } from "ui"; // icons import { CalendarDaysIcon, @@ -20,9 +19,15 @@ import { PencilIcon, PlusIcon, TrashIcon, + ClipboardDocumentListIcon, } from "@heroicons/react/24/outline"; // types import type { IProject } from "types"; +// fetch-keys +import { PROJECT_MEMBERS } from "constants/fetch-keys"; +// common +import { renderShortNumericDateFormat } from "constants/common"; + type Props = { project: IProject; slug: string; @@ -40,6 +45,8 @@ const ProjectMemberInvitations: React.FC = ({ }) => { const { user } = useUser(); + const router = useRouter(); + const { data: members } = useSWR(PROJECT_MEMBERS(project.id), () => projectService.projectMembers(slug, project.id) ); @@ -93,13 +100,13 @@ const ProjectMemberInvitations: React.FC = ({ {isMember ? (
- + )} - - - - View - - +
diff --git a/apps/app/components/project/settings/control.tsx b/apps/app/components/project/settings/control.tsx deleted file mode 100644 index eea215256..000000000 --- a/apps/app/components/project/settings/control.tsx +++ /dev/null @@ -1,197 +0,0 @@ -// react -import React from "react"; -// swr -import useSWR from "swr"; -// react-hook-form -import { Control, Controller } from "react-hook-form"; -// services -import workspaceService from "lib/services/workspace.service"; -// hooks -import useUser from "lib/hooks/useUser"; -// headless ui -import { Listbox, Transition } from "@headlessui/react"; -// ui -import { Button } from "ui"; -// icons -import { CheckIcon, ChevronDownIcon } from "@heroicons/react/24/outline"; -// types -import { IProject } from "types"; -// fetch-keys -import { WORKSPACE_MEMBERS } from "constants/fetch-keys"; - -type Props = { - control: Control; - isSubmitting: boolean; -}; - -const ControlSettings: React.FC = ({ control, isSubmitting }) => { - const { activeWorkspace } = useUser(); - - const { data: people } = useSWR( - activeWorkspace ? WORKSPACE_MEMBERS : null, - activeWorkspace ? () => workspaceService.workspaceMembers(activeWorkspace.slug) : null - ); - return ( - <> -
-
-

Control

-

Set the control for the project.

-
-
-
-

Project Lead

-

Select the project leader.

- ( - - {({ open }) => ( - <> -
- - - {people?.find((person) => person.member.id === value)?.member - .first_name ?? "Select Lead"} - - - - - - {people?.map((person) => ( - - `${ - active ? "bg-indigo-50" : "" - } text-gray-900 cursor-default select-none relative px-3 py-2` - } - value={person.member.id} - > - {({ selected, active }) => ( - <> - - {person.member.first_name !== "" - ? person.member.first_name - : person.member.email} - - - {selected ? ( - - - ) : null} - - )} - - ))} - - -
- - )} -
- )} - /> -
-
-

Default Assignee

-

- Select the default assignee for the project. -

- ( - - {({ open }) => ( - <> -
- - - {people?.find((p) => p.member.id === value)?.member.first_name ?? - "Select Default Assignee"} - - - - - - {people?.map((person) => ( - - `${ - active ? "bg-indigo-50" : "" - } text-gray-900 cursor-default select-none relative px-3 py-2` - } - value={person.member.id} - > - {({ selected, active }) => ( - <> - - {person.member.first_name !== "" - ? person.member.first_name - : person.member.email} - - - {selected ? ( - - - ) : null} - - )} - - ))} - - -
- - )} -
- )} - /> -
-
-
- -
-
- - ); -}; - -export default ControlSettings; diff --git a/apps/app/components/project/settings/general.tsx b/apps/app/components/project/settings/general.tsx deleted file mode 100644 index 0330ef9d6..000000000 --- a/apps/app/components/project/settings/general.tsx +++ /dev/null @@ -1,158 +0,0 @@ -// react -import { useCallback } from "react"; -// react-hook-form -import { Controller } from "react-hook-form"; -import type { Control, UseFormRegister, UseFormSetError } from "react-hook-form"; -// services -import projectServices from "lib/services/project.service"; -// hooks -import useUser from "lib/hooks/useUser"; -// ui -import { Button, Input, Select, TextArea, EmojiIconPicker } from "ui"; -// types -import { IProject } from "types"; -// constants -import { debounce } from "constants/common"; - -type Props = { - register: UseFormRegister; - errors: any; - setError: UseFormSetError; - isSubmitting: boolean; - control: Control; -}; - -const NETWORK_CHOICES = { "0": "Secret", "2": "Public" }; - -const GeneralSettings: React.FC = ({ - register, - errors, - setError, - isSubmitting, - control, -}) => { - const { activeWorkspace } = useUser(); - - const checkIdentifier = (slug: string, value: string) => { - projectServices.checkProjectIdentifierAvailability(slug, value).then((response) => { - console.log(response); - if (response.exists) setError("identifier", { message: "Identifier already exists" }); - }); - }; - - // eslint-disable-next-line react-hooks/exhaustive-deps - const checkIdentifierAvailability = useCallback(debounce(checkIdentifier, 1500), []); - - return ( - <> -
-
-

General

-

- This information will be displayed to every member of the project. -

-
-
-
-

Icon & Name

-

Select an icon and a name for the project.

-
- ( - - )} - /> - -
-
-
-

Description

-

Give a description to the project.

-