aboutsummaryrefslogtreecommitdiff
path: root/FrontEnd/src/app/views/home/TimelineCreateDialog.tsx
diff options
context:
space:
mode:
authorcrupest <crupest@outlook.com>2021-04-16 17:43:16 +0800
committercrupest <crupest@outlook.com>2021-04-16 17:43:16 +0800
commit2981b7fb9002ee424a4e4358f04914de63f60141 (patch)
tree3a94b828f93dd457060999ae989c988ef32f1812 /FrontEnd/src/app/views/home/TimelineCreateDialog.tsx
parent3db441fccf1a933ac8ec9e4f89c19f81efd66052 (diff)
downloadtimeline-2981b7fb9002ee424a4e4358f04914de63f60141.tar.gz
timeline-2981b7fb9002ee424a4e4358f04914de63f60141.tar.bz2
timeline-2981b7fb9002ee424a4e4358f04914de63f60141.zip
...
Diffstat (limited to 'FrontEnd/src/app/views/home/TimelineCreateDialog.tsx')
-rw-r--r--FrontEnd/src/app/views/home/TimelineCreateDialog.tsx53
1 files changed, 0 insertions, 53 deletions
diff --git a/FrontEnd/src/app/views/home/TimelineCreateDialog.tsx b/FrontEnd/src/app/views/home/TimelineCreateDialog.tsx
deleted file mode 100644
index b4e25ba1..00000000
--- a/FrontEnd/src/app/views/home/TimelineCreateDialog.tsx
+++ /dev/null
@@ -1,53 +0,0 @@
-import React from "react";
-import { useHistory } from "react-router";
-
-import { validateTimelineName } from "@/services/timeline";
-import OperationDialog from "../common/OperationDialog";
-import { getHttpTimelineClient, HttpTimelineInfo } from "@/http/timeline";
-
-interface TimelineCreateDialogProps {
- open: boolean;
- close: () => void;
-}
-
-const TimelineCreateDialog: React.FC<TimelineCreateDialogProps> = (props) => {
- const history = useHistory();
-
- return (
- <OperationDialog
- open={props.open}
- close={props.close}
- themeColor="success"
- title="home.createDialog.title"
- inputScheme={
- [
- {
- type: "text",
- label: "home.createDialog.name",
- helperText: "home.createDialog.nameFormat",
- },
- ] as const
- }
- inputValidator={([name]) => {
- if (name.length === 0) {
- return { 0: "home.createDialog.noEmpty" };
- } else if (name.length > 26) {
- return { 0: "home.createDialog.tooLong" };
- } else if (!validateTimelineName(name)) {
- return { 0: "home.createDialog.badFormat" };
- } else {
- return null;
- }
- }}
- onProcess={([name]): Promise<HttpTimelineInfo> =>
- getHttpTimelineClient().postTimeline({ name })
- }
- onSuccessAndClose={(timeline: HttpTimelineInfo) => {
- history.push(`timelines/${timeline.name}`);
- }}
- failurePrompt={(e) => `${e as string}`}
- />
- );
-};
-
-export default TimelineCreateDialog;