| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175 |
- import { useEffect, useState } from "react";
- import { Divider, Space, Tag, Typography, message } from "antd";
- import { CodeSandboxOutlined } from "@ant-design/icons";
- import { ITaskData, ITaskResponse, ITaskUpdateRequest } from "../api/task";
- import { get, patch } from "../../request";
- import MdView from "../template/MdView";
- import User from "../auth/User";
- import TimeShow from "../general/TimeShow";
- import TaskEditButton, { TRelation } from "./TaskEditButton";
- import PreTask from "./PreTask";
- import Like from "../like/Like";
- import Assignees from "./Assignees";
- const { Title } = Typography;
- export const Milestone = ({ task }: { task?: ITaskData }) => {
- return task?.is_milestone ? (
- <Tag icon={<CodeSandboxOutlined />} color="error">
- 里程碑
- </Tag>
- ) : null;
- };
- export const Status = ({ task }: { task?: ITaskData }) => {
- return task?.status === "pending" ? (
- <Tag color="default">未发布</Tag>
- ) : task?.status === "published" ? (
- <Tag color="warning">待领取</Tag>
- ) : task?.status === "running" ? (
- <Tag color="processing">进行中</Tag>
- ) : task?.status === "done" ? (
- <Tag color="success">已完成</Tag>
- ) : task?.status === "restarted" ? (
- <Tag color="error">已重启</Tag>
- ) : null;
- };
- interface IWidget {
- taskId?: string;
- onChange?: (data: ITaskData[]) => void;
- onEdit?: () => void;
- }
- const TaskReader = ({ taskId, onChange, onEdit }: IWidget) => {
- const [openPreTask, setOpenPreTask] = useState(false);
- const [openNextTask, setOpenNextTask] = useState(false);
- const [task, setTask] = useState<ITaskData>();
- useEffect(() => {
- const url = `/v2/task/${taskId}`;
- console.info("task api request", url);
- get<ITaskResponse>(url).then((json) => {
- console.info("task api response", json);
- if (json.ok) {
- setTask(json.data);
- }
- });
- }, [taskId]);
- const updatePreTask = (type: TRelation, data?: ITaskData | null) => {
- if (!taskId || !data) {
- return;
- }
- let setting: ITaskUpdateRequest = {
- id: taskId,
- studio_name: "",
- };
- if (type === "pre") {
- const hasPre = task?.pre_task?.find((value) => value.id === data.id);
- if (hasPre) {
- setting.pre_task_id = task?.pre_task
- ?.filter((value) => value.id !== data.id)
- .map((item) => item.id)
- .join();
- } else {
- const newRelation = task?.pre_task
- ? [...task.pre_task.map((item) => item.id), data.id]
- : [data.id];
- setting.pre_task_id = newRelation.join();
- }
- } else if (type === "next") {
- const hasPre = task?.next_task?.find((value) => value.id === data.id);
- if (hasPre) {
- setting.next_task_id = task?.next_task
- ?.filter((value) => value.id !== data.id)
- .map((item) => item.id)
- .join();
- } else {
- const newRelation = task?.next_task
- ? [...task.next_task.map((item) => item.id), data.id]
- : [data.id];
- setting.next_task_id = newRelation.join();
- }
- }
- const url = `/v2/task/${setting.id}`;
- console.info("api request", url, setting);
- patch<ITaskUpdateRequest, ITaskResponse>(url, setting).then((json) => {
- console.info("api response", json);
- if (json.ok) {
- message.success("Success");
- setTask(json.data);
- onChange && onChange([json.data]);
- } else {
- message.error(json.message);
- }
- });
- };
- return (
- <div>
- <div style={{ display: "flex", justifyContent: "space-between" }}>
- <Space>
- <Status task={task} />
- <Milestone task={task} />
- <PreTask
- task={task}
- open={openPreTask}
- type="pre"
- onClick={(data) => {
- updatePreTask("pre", data);
- setOpenPreTask(false);
- }}
- onTagClick={() => setOpenPreTask(true)}
- onClose={() => setOpenPreTask(false)}
- />
- <PreTask
- task={task}
- open={openNextTask}
- type="next"
- onClick={(data) => {
- updatePreTask("next", data);
- setOpenNextTask(false);
- }}
- onClose={() => setOpenNextTask(false)}
- onTagClick={() => setOpenNextTask(true)}
- />
- </Space>
- <div>
- <TaskEditButton
- task={task}
- onChange={(tasks: ITaskData[]) => {
- setTask(tasks.find((value) => value.id === taskId));
- onChange && onChange(tasks);
- }}
- onEdit={onEdit}
- onPreTask={(type: TRelation) => {
- if (type === "pre") {
- setOpenPreTask(true);
- } else if (type === "next") {
- setOpenNextTask(true);
- }
- }}
- />
- </div>
- </div>
- <Title>{task?.title}</Title>
- <div>
- <div>
- <Space>
- <User {...task?.editor} />
- <TimeShow updatedAt={task?.updated_at} />
- <Like resId={task?.id} resType="task" />
- </Space>
- </div>
- <div>
- <Assignees task={task} showIcon={true} onChange={onChange} />
- </div>
- </div>
- <Divider />
- <MdView html={task?.html} />
- </div>
- );
- };
- export default TaskReader;
|