From 6e084c2386ae963e20380a52b964d4522c5292cf Mon Sep 17 00:00:00 2001 From: Eric Date: Thu, 4 May 2023 21:41:49 +0800 Subject: [PATCH 1/2] add tag --- components/tag.tsx | 44 ++++++++++ interfaces/message.ts | 5 +- pages/index.tsx | 190 ++++++++++++++++++++++++++++++++++-------- 3 files changed, 203 insertions(+), 36 deletions(-) create mode 100644 components/tag.tsx diff --git a/components/tag.tsx b/components/tag.tsx new file mode 100644 index 0000000..acce46f --- /dev/null +++ b/components/tag.tsx @@ -0,0 +1,44 @@ +import React, { useState } from "react"; +import { Space, Tag } from "antd"; + +const { CheckableTag } = Tag; + +interface Props { + Data: string[]; + onClick?: (tag: string) => void; +} + +const App = ({ Data, onClick }: Props) => { + const [selectedTags, setSelectedTags] = useState([]); + // const tagsData = ["V1", "V2", "V3", "V4"]; + const handleChange = (tag: string, checked: boolean) => { + if (!checked) return; + const nextSelectedTags = checked + ? [...selectedTags, tag] + : selectedTags.filter((t) => t !== tag); + console.log("You are interested in: ", nextSelectedTags); + onClick && onClick(tag); + setSelectedTags(nextSelectedTags); + }; + + return ( + <> + + {Data.map((tag) => ( + handleChange(tag, checked)} + > + {tag} + + ))} + + + ); +}; + +export default App; diff --git a/interfaces/message.ts b/interfaces/message.ts index 585899d..f9125de 100644 --- a/interfaces/message.ts +++ b/interfaces/message.ts @@ -1,4 +1,7 @@ export interface Message { text: string; img: string; -} \ No newline at end of file + msgID?: string; + msgHash?: string; + hasTag: boolean; +} diff --git a/pages/index.tsx b/pages/index.tsx index e5a532b..3c4185c 100644 --- a/pages/index.tsx +++ b/pages/index.tsx @@ -1,73 +1,186 @@ -import React, { useState } from 'react'; -import { Input, Button, List, Image, Typography } from 'antd'; -import { SendOutlined } from '@ant-design/icons'; -import { Imagine } from '../request'; -import { MJMessage } from 'midjourney'; -import { Message } from '../interfaces/message'; - +import React, { useState } from "react"; +import { Input, Button, List, Image, Typography } from "antd"; +import { SendOutlined } from "@ant-design/icons"; +import { Imagine, Upscale, Variation } from "../request"; +import { MJMessage } from "midjourney"; +import { Message } from "../interfaces/message"; +import Tag from "../components/tag"; const { TextArea } = Input; -const { Text } = Typography +const { Text } = Typography; const Index: React.FC = () => { - const [inputValue, setInputValue] = useState(''); + const [inputValue, setInputValue] = useState(""); const [inputDisable, setInputDisable] = useState(false); const [messages, setMessages] = useState([]); const handleMessageSend = async () => { let newMessage: Message = { text: inputValue.trim(), - img: "" + hasTag: false, + img: "", }; if (newMessage.text) { const oldMessages = messages; setInputDisable(true); setMessages([...oldMessages, newMessage]); - console.log("newMessage.text") - await Imagine(JSON.stringify({ prompt: newMessage.text }), (data: MJMessage) => { - console.log(data) - newMessage.img = data.uri; - setMessages([...oldMessages, newMessage]); - }) - setInputValue(''); + console.log("newMessage.text"); + await Imagine( + JSON.stringify({ prompt: newMessage.text }), + (data: MJMessage) => { + console.log(data); + newMessage.img = data.uri; + newMessage.hasTag = true; + newMessage.msgHash = data.hash; + newMessage.msgID = data.id; + setMessages([...oldMessages, newMessage]); + } + ); + setInputValue(""); setInputDisable(false); } }; - const renderMessage = ({ text, img }: Message) => { - // const html = marked(text); + const upscale = async ( + pormpt: string, + msgId: string, + msgHash: string, + index: number + ) => { + let newMessage: Message = { + text: `${pormpt} upscale U${index}`, + hasTag: false, + img: "", + }; + + const oldMessages = messages; + setInputDisable(true); + setMessages([...oldMessages, newMessage]); + await Upscale( + JSON.stringify({ content: pormpt, index, msgId, msgHash }), + (data: MJMessage) => { + newMessage.img = data.uri; + newMessage.msgHash = data.hash; + newMessage.msgID = data.id; + setMessages([...oldMessages, newMessage]); + } + ); + setInputDisable(false); + }; + const variation = async ( + pormpt: string, + msgId: string, + msgHash: string, + index: number + ) => { + let newMessage: Message = { + text: `${pormpt} variation V${index}`, + hasTag: false, + img: "", + }; + + const oldMessages = messages; + setInputDisable(true); + setMessages([...oldMessages, newMessage]); + await Variation( + JSON.stringify({ content: pormpt, index, msgId, msgHash }), + (data: MJMessage) => { + newMessage.img = data.uri; + newMessage.hasTag = true; + newMessage.msgHash = data.hash; + newMessage.msgID = data.id; + setMessages([...oldMessages, newMessage]); + } + ); + setInputDisable(false); + }; + const tagClick = ( + pormpt: string, + msgId: string, + msgHash: string, + tag: string + ) => { + switch (tag) { + case "V1": + variation(pormpt, msgId, msgHash, 1); + break; + case "V2": + variation(pormpt, msgId, msgHash, 2); + break; + case "V3": + variation(pormpt, msgId, msgHash, 3); + break; + case "V4": + variation(pormpt, msgId, msgHash, 4); + break; + case "U1": + upscale(pormpt, msgId, msgHash, 1); + break; + case "U2": + upscale(pormpt, msgId, msgHash, 2); + break; + case "U3": + upscale(pormpt, msgId, msgHash, 3); + break; + case "U4": + upscale(pormpt, msgId, msgHash, 4); + break; + default: + break; + } + }; + const renderMessage = ({ text, img, hasTag, msgHash, msgID }: Message) => { return ( - - {text} - + + {text} + + + {hasTag && ( + + tagClick(text, String(msgID), String(msgHash), tag) + } + /> + )} + {hasTag && ( + + tagClick(text, String(msgID), String(msgHash), tag) + } + /> + )} ); }; return ( -
+
-
+