Merge branch '108' of https://github.com/HBAI-Ltd/Toonflow-app into 108
# Conflicts: # src/router.ts # src/types/database.d.ts
This commit is contained in:
commit
0de504a138
@ -167,7 +167,6 @@ export default (toolCpnfig: ToolConfig) => {
|
|||||||
ids: z.array(z.number()).describe("必须获取真实的分镜ID,支持批量生成"),
|
ids: z.array(z.number()).describe("必须获取真实的分镜ID,支持批量生成"),
|
||||||
}),
|
}),
|
||||||
execute: async ({ ids }) => {
|
execute: async ({ ids }) => {
|
||||||
console.log("%c Line:176 🍒 ids", "background:#ea7e5c", ids);
|
|
||||||
const thinking = msg.thinking("正在生成分镜...");
|
const thinking = msg.thinking("正在生成分镜...");
|
||||||
new Promise((resolve) => socket.emit("generateStoryboard", { ids }, (res: any) => resolve(res)))
|
new Promise((resolve) => socket.emit("generateStoryboard", { ids }, (res: any) => resolve(res)))
|
||||||
.then((res) => {
|
.then((res) => {
|
||||||
|
|||||||
232
src/router.ts
232
src/router.ts
@ -1,4 +1,4 @@
|
|||||||
// @routes-hash 3e7dcd2b8abd8bd40ca932a2c27249da
|
// @routes-hash 74dea22f03cd475b3b00fd48e38fd9df
|
||||||
import { Express } from "express";
|
import { Express } from "express";
|
||||||
|
|
||||||
import route1 from "./routes/agents/clearMemory";
|
import route1 from "./routes/agents/clearMemory";
|
||||||
@ -70,65 +70,64 @@ import route66 from "./routes/production/storyboard/previewImage";
|
|||||||
import route67 from "./routes/production/storyboard/removeFrame";
|
import route67 from "./routes/production/storyboard/removeFrame";
|
||||||
import route68 from "./routes/production/storyboard/updateStoryboardUrl";
|
import route68 from "./routes/production/storyboard/updateStoryboardUrl";
|
||||||
import route69 from "./routes/production/workbench/addTrack";
|
import route69 from "./routes/production/workbench/addTrack";
|
||||||
import route70 from "./routes/production/workbench/confirmSelection";
|
import route70 from "./routes/production/workbench/delVideo";
|
||||||
import route71 from "./routes/production/workbench/delVideo";
|
import route71 from "./routes/production/workbench/generateVideo";
|
||||||
import route72 from "./routes/production/workbench/generateVideo";
|
import route72 from "./routes/production/workbench/generateVideoPrompt";
|
||||||
import route73 from "./routes/production/workbench/generateVideoPrompt";
|
import route73 from "./routes/production/workbench/getGenerateData";
|
||||||
import route74 from "./routes/production/workbench/getGenerateData";
|
import route74 from "./routes/production/workbench/getVideoList";
|
||||||
import route75 from "./routes/production/workbench/getVideoModelDetail";
|
import route75 from "./routes/production/workbench/getVideoModelDetail";
|
||||||
import route76 from "./routes/production/workbench/videoPolling";
|
import route76 from "./routes/project/addProject";
|
||||||
import route77 from "./routes/project/addProject";
|
import route77 from "./routes/project/addVisual";
|
||||||
import route78 from "./routes/project/addVisual";
|
import route78 from "./routes/project/addVisualManual";
|
||||||
import route79 from "./routes/project/addVisualManual";
|
import route79 from "./routes/project/deleteVisualManual";
|
||||||
import route80 from "./routes/project/deleteVisualManual";
|
import route80 from "./routes/project/delProject";
|
||||||
import route81 from "./routes/project/delProject";
|
import route81 from "./routes/project/editProject";
|
||||||
import route82 from "./routes/project/editProject";
|
import route82 from "./routes/project/editVisualManual";
|
||||||
import route83 from "./routes/project/editVisualManual";
|
import route83 from "./routes/project/getProject";
|
||||||
import route84 from "./routes/project/getProject";
|
import route84 from "./routes/project/getVisualManual";
|
||||||
import route85 from "./routes/project/getVisualManual";
|
import route85 from "./routes/project/visualManual";
|
||||||
import route86 from "./routes/project/visualManual";
|
import route86 from "./routes/script/addScript";
|
||||||
import route87 from "./routes/script/addScript";
|
import route87 from "./routes/script/delScript";
|
||||||
import route88 from "./routes/script/delScript";
|
import route88 from "./routes/script/exportScript";
|
||||||
import route89 from "./routes/script/exportScript";
|
import route89 from "./routes/script/extractAssets";
|
||||||
import route90 from "./routes/script/extractAssets";
|
import route90 from "./routes/script/getScrptApi";
|
||||||
import route91 from "./routes/script/getScrptApi";
|
import route91 from "./routes/script/pollScriptAssets";
|
||||||
import route92 from "./routes/script/pollScriptAssets";
|
import route92 from "./routes/script/updateScript";
|
||||||
import route93 from "./routes/script/updateScript";
|
import route93 from "./routes/scriptAgent/getPlanData";
|
||||||
import route94 from "./routes/scriptAgent/getPlanData";
|
import route94 from "./routes/scriptAgent/setPlanData";
|
||||||
import route95 from "./routes/scriptAgent/setPlanData";
|
import route95 from "./routes/scriptAgent/updateData";
|
||||||
import route96 from "./routes/scriptAgent/updateData";
|
import route96 from "./routes/setting/about/checkUpdate";
|
||||||
import route97 from "./routes/setting/about/checkUpdate";
|
import route97 from "./routes/setting/about/downloadApp";
|
||||||
import route98 from "./routes/setting/about/downloadApp";
|
import route98 from "./routes/setting/agentDeploy/agentSetKey";
|
||||||
import route99 from "./routes/setting/agentDeploy/agentSetKey";
|
import route99 from "./routes/setting/agentDeploy/deployAgentModel";
|
||||||
import route100 from "./routes/setting/agentDeploy/deployAgentModel";
|
import route100 from "./routes/setting/agentDeploy/getAgentDeploy";
|
||||||
import route101 from "./routes/setting/agentDeploy/getAgentDeploy";
|
import route101 from "./routes/setting/dbConfig/clearData";
|
||||||
import route102 from "./routes/setting/dbConfig/clearData";
|
import route102 from "./routes/setting/dev/getSwitchAiDevTool";
|
||||||
import route103 from "./routes/setting/dev/getSwitchAiDevTool";
|
import route103 from "./routes/setting/dev/updateSwitchAiDevTool";
|
||||||
import route104 from "./routes/setting/dev/updateSwitchAiDevTool";
|
import route104 from "./routes/setting/fileManagement/openFolder";
|
||||||
import route105 from "./routes/setting/fileManagement/openFolder";
|
import route105 from "./routes/setting/getTextModel";
|
||||||
import route106 from "./routes/setting/getTextModel";
|
import route106 from "./routes/setting/loginConfig/getUser";
|
||||||
import route107 from "./routes/setting/loginConfig/getUser";
|
import route107 from "./routes/setting/loginConfig/updateUserPwd";
|
||||||
import route108 from "./routes/setting/loginConfig/updateUserPwd";
|
import route108 from "./routes/setting/memoryConfig/delAllMemory";
|
||||||
import route109 from "./routes/setting/memoryConfig/delAllMemory";
|
import route109 from "./routes/setting/memoryConfig/getMemory";
|
||||||
import route110 from "./routes/setting/memoryConfig/getMemory";
|
import route110 from "./routes/setting/memoryConfig/sureMemory";
|
||||||
import route111 from "./routes/setting/memoryConfig/sureMemory";
|
import route111 from "./routes/setting/promptManage/getPrompt";
|
||||||
import route112 from "./routes/setting/promptManage/getPrompt";
|
import route112 from "./routes/setting/promptManage/updatePrompt";
|
||||||
import route113 from "./routes/setting/promptManage/updatePrompt";
|
import route113 from "./routes/setting/skillManagement/getSkillContent";
|
||||||
import route114 from "./routes/setting/skillManagement/getSkillContent";
|
import route114 from "./routes/setting/skillManagement/getSkillList";
|
||||||
import route115 from "./routes/setting/skillManagement/getSkillList";
|
import route115 from "./routes/setting/skillManagement/saveSkillContent";
|
||||||
import route116 from "./routes/setting/skillManagement/saveSkillContent";
|
import route116 from "./routes/setting/vendorConfig/addVendor";
|
||||||
import route117 from "./routes/setting/vendorConfig/addVendor";
|
import route117 from "./routes/setting/vendorConfig/deleteVendor";
|
||||||
import route118 from "./routes/setting/vendorConfig/deleteVendor";
|
import route118 from "./routes/setting/vendorConfig/enableEnglishVendor";
|
||||||
import route119 from "./routes/setting/vendorConfig/enableEnglishVendor";
|
import route119 from "./routes/setting/vendorConfig/getVendorList";
|
||||||
import route120 from "./routes/setting/vendorConfig/getVendorList";
|
import route120 from "./routes/setting/vendorConfig/modelTest";
|
||||||
import route121 from "./routes/setting/vendorConfig/modelTest";
|
import route121 from "./routes/setting/vendorConfig/updateCode";
|
||||||
import route122 from "./routes/setting/vendorConfig/updateCode";
|
import route122 from "./routes/setting/vendorConfig/updateVendor";
|
||||||
import route123 from "./routes/setting/vendorConfig/updateVendor";
|
import route123 from "./routes/task/getProject";
|
||||||
import route124 from "./routes/task/getProject";
|
import route124 from "./routes/task/getTaskApi";
|
||||||
import route125 from "./routes/task/getTaskApi";
|
import route125 from "./routes/task/getTaskCategories";
|
||||||
import route126 from "./routes/task/getTaskCategories";
|
import route126 from "./routes/task/taskDetails";
|
||||||
import route127 from "./routes/task/taskDetails";
|
import route127 from "./routes/test/test";
|
||||||
import route128 from "./routes/test/test";
|
|
||||||
|
|
||||||
export default async (app: Express) => {
|
export default async (app: Express) => {
|
||||||
app.use("/api/agents/clearMemory", route1);
|
app.use("/api/agents/clearMemory", route1);
|
||||||
@ -200,63 +199,62 @@ export default async (app: Express) => {
|
|||||||
app.use("/api/production/storyboard/removeFrame", route67);
|
app.use("/api/production/storyboard/removeFrame", route67);
|
||||||
app.use("/api/production/storyboard/updateStoryboardUrl", route68);
|
app.use("/api/production/storyboard/updateStoryboardUrl", route68);
|
||||||
app.use("/api/production/workbench/addTrack", route69);
|
app.use("/api/production/workbench/addTrack", route69);
|
||||||
app.use("/api/production/workbench/confirmSelection", route70);
|
app.use("/api/production/workbench/delVideo", route70);
|
||||||
app.use("/api/production/workbench/delVideo", route71);
|
app.use("/api/production/workbench/generateVideo", route71);
|
||||||
app.use("/api/production/workbench/generateVideo", route72);
|
app.use("/api/production/workbench/generateVideoPrompt", route72);
|
||||||
app.use("/api/production/workbench/generateVideoPrompt", route73);
|
app.use("/api/production/workbench/getGenerateData", route73);
|
||||||
app.use("/api/production/workbench/getGenerateData", route74);
|
app.use("/api/production/workbench/getVideoList", route74);
|
||||||
app.use("/api/production/workbench/getVideoModelDetail", route75);
|
app.use("/api/production/workbench/getVideoModelDetail", route75);
|
||||||
app.use("/api/production/workbench/videoPolling", route76);
|
app.use("/api/project/addProject", route76);
|
||||||
app.use("/api/project/addProject", route77);
|
app.use("/api/project/addVisual", route77);
|
||||||
app.use("/api/project/addVisual", route78);
|
app.use("/api/project/addVisualManual", route78);
|
||||||
app.use("/api/project/addVisualManual", route79);
|
app.use("/api/project/deleteVisualManual", route79);
|
||||||
app.use("/api/project/deleteVisualManual", route80);
|
app.use("/api/project/delProject", route80);
|
||||||
app.use("/api/project/delProject", route81);
|
app.use("/api/project/editProject", route81);
|
||||||
app.use("/api/project/editProject", route82);
|
app.use("/api/project/editVisualManual", route82);
|
||||||
app.use("/api/project/editVisualManual", route83);
|
app.use("/api/project/getProject", route83);
|
||||||
app.use("/api/project/getProject", route84);
|
app.use("/api/project/getVisualManual", route84);
|
||||||
app.use("/api/project/getVisualManual", route85);
|
app.use("/api/project/visualManual", route85);
|
||||||
app.use("/api/project/visualManual", route86);
|
app.use("/api/script/addScript", route86);
|
||||||
app.use("/api/script/addScript", route87);
|
app.use("/api/script/delScript", route87);
|
||||||
app.use("/api/script/delScript", route88);
|
app.use("/api/script/exportScript", route88);
|
||||||
app.use("/api/script/exportScript", route89);
|
app.use("/api/script/extractAssets", route89);
|
||||||
app.use("/api/script/extractAssets", route90);
|
app.use("/api/script/getScrptApi", route90);
|
||||||
app.use("/api/script/getScrptApi", route91);
|
app.use("/api/script/pollScriptAssets", route91);
|
||||||
app.use("/api/script/pollScriptAssets", route92);
|
app.use("/api/script/updateScript", route92);
|
||||||
app.use("/api/script/updateScript", route93);
|
app.use("/api/scriptAgent/getPlanData", route93);
|
||||||
app.use("/api/scriptAgent/getPlanData", route94);
|
app.use("/api/scriptAgent/setPlanData", route94);
|
||||||
app.use("/api/scriptAgent/setPlanData", route95);
|
app.use("/api/scriptAgent/updateData", route95);
|
||||||
app.use("/api/scriptAgent/updateData", route96);
|
app.use("/api/setting/about/checkUpdate", route96);
|
||||||
app.use("/api/setting/about/checkUpdate", route97);
|
app.use("/api/setting/about/downloadApp", route97);
|
||||||
app.use("/api/setting/about/downloadApp", route98);
|
app.use("/api/setting/agentDeploy/agentSetKey", route98);
|
||||||
app.use("/api/setting/agentDeploy/agentSetKey", route99);
|
app.use("/api/setting/agentDeploy/deployAgentModel", route99);
|
||||||
app.use("/api/setting/agentDeploy/deployAgentModel", route100);
|
app.use("/api/setting/agentDeploy/getAgentDeploy", route100);
|
||||||
app.use("/api/setting/agentDeploy/getAgentDeploy", route101);
|
app.use("/api/setting/dbConfig/clearData", route101);
|
||||||
app.use("/api/setting/dbConfig/clearData", route102);
|
app.use("/api/setting/dev/getSwitchAiDevTool", route102);
|
||||||
app.use("/api/setting/dev/getSwitchAiDevTool", route103);
|
app.use("/api/setting/dev/updateSwitchAiDevTool", route103);
|
||||||
app.use("/api/setting/dev/updateSwitchAiDevTool", route104);
|
app.use("/api/setting/fileManagement/openFolder", route104);
|
||||||
app.use("/api/setting/fileManagement/openFolder", route105);
|
app.use("/api/setting/getTextModel", route105);
|
||||||
app.use("/api/setting/getTextModel", route106);
|
app.use("/api/setting/loginConfig/getUser", route106);
|
||||||
app.use("/api/setting/loginConfig/getUser", route107);
|
app.use("/api/setting/loginConfig/updateUserPwd", route107);
|
||||||
app.use("/api/setting/loginConfig/updateUserPwd", route108);
|
app.use("/api/setting/memoryConfig/delAllMemory", route108);
|
||||||
app.use("/api/setting/memoryConfig/delAllMemory", route109);
|
app.use("/api/setting/memoryConfig/getMemory", route109);
|
||||||
app.use("/api/setting/memoryConfig/getMemory", route110);
|
app.use("/api/setting/memoryConfig/sureMemory", route110);
|
||||||
app.use("/api/setting/memoryConfig/sureMemory", route111);
|
app.use("/api/setting/promptManage/getPrompt", route111);
|
||||||
app.use("/api/setting/promptManage/getPrompt", route112);
|
app.use("/api/setting/promptManage/updatePrompt", route112);
|
||||||
app.use("/api/setting/promptManage/updatePrompt", route113);
|
app.use("/api/setting/skillManagement/getSkillContent", route113);
|
||||||
app.use("/api/setting/skillManagement/getSkillContent", route114);
|
app.use("/api/setting/skillManagement/getSkillList", route114);
|
||||||
app.use("/api/setting/skillManagement/getSkillList", route115);
|
app.use("/api/setting/skillManagement/saveSkillContent", route115);
|
||||||
app.use("/api/setting/skillManagement/saveSkillContent", route116);
|
app.use("/api/setting/vendorConfig/addVendor", route116);
|
||||||
app.use("/api/setting/vendorConfig/addVendor", route117);
|
app.use("/api/setting/vendorConfig/deleteVendor", route117);
|
||||||
app.use("/api/setting/vendorConfig/deleteVendor", route118);
|
app.use("/api/setting/vendorConfig/enableEnglishVendor", route118);
|
||||||
app.use("/api/setting/vendorConfig/enableEnglishVendor", route119);
|
app.use("/api/setting/vendorConfig/getVendorList", route119);
|
||||||
app.use("/api/setting/vendorConfig/getVendorList", route120);
|
app.use("/api/setting/vendorConfig/modelTest", route120);
|
||||||
app.use("/api/setting/vendorConfig/modelTest", route121);
|
app.use("/api/setting/vendorConfig/updateCode", route121);
|
||||||
app.use("/api/setting/vendorConfig/updateCode", route122);
|
app.use("/api/setting/vendorConfig/updateVendor", route122);
|
||||||
app.use("/api/setting/vendorConfig/updateVendor", route123);
|
app.use("/api/task/getProject", route123);
|
||||||
app.use("/api/task/getProject", route124);
|
app.use("/api/task/getTaskApi", route124);
|
||||||
app.use("/api/task/getTaskApi", route125);
|
app.use("/api/task/getTaskCategories", route125);
|
||||||
app.use("/api/task/getTaskCategories", route126);
|
app.use("/api/task/taskDetails", route126);
|
||||||
app.use("/api/task/taskDetails", route127);
|
app.use("/api/test/test", route127);
|
||||||
app.use("/api/test/test", route128);
|
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,19 +0,0 @@
|
|||||||
import express from "express";
|
|
||||||
import u from "@/utils";
|
|
||||||
import { z } from "zod";
|
|
||||||
import { success } from "@/lib/responseFormat";
|
|
||||||
import { validateFields } from "@/middleware/middleware";
|
|
||||||
const router = express.Router();
|
|
||||||
|
|
||||||
export default router.post(
|
|
||||||
"/",
|
|
||||||
validateFields({
|
|
||||||
storyboardId: z.number(),
|
|
||||||
videoId: z.number(),
|
|
||||||
}),
|
|
||||||
async (req, res) => {
|
|
||||||
const { storyboardId, videoId } = req.body;
|
|
||||||
await u.db("o_videoConfig").where("storyboardId", storyboardId).update({ videoId, updateTime: Date.now() });
|
|
||||||
res.status(200).send(success({ message: "选择确认成功" }));
|
|
||||||
},
|
|
||||||
);
|
|
||||||
@ -22,21 +22,22 @@ export default router.post(
|
|||||||
resolution: z.string(),
|
resolution: z.string(),
|
||||||
duration: z.number(),
|
duration: z.number(),
|
||||||
audio: z.boolean().optional(),
|
audio: z.boolean().optional(),
|
||||||
|
trackId: z.number(),
|
||||||
}),
|
}),
|
||||||
async (req, res) => {
|
async (req, res) => {
|
||||||
const { scriptId, projectId, prompt, uploadData, model, duration, resolution, audio, mode } = req.body;
|
const { scriptId, projectId, prompt, uploadData, model, duration, resolution, audio, mode, trackId } = req.body;
|
||||||
//获取生成视频比例
|
//获取生成视频比例
|
||||||
const ratio = await u.db("o_project").select("videoRatio").where("id", projectId).first();
|
const ratio = await u.db("o_project").select("videoRatio").where("id", projectId).first();
|
||||||
const videoPath = `/${projectId}/video/${uuidv4()}.mp4`; //视频保存路径
|
const videoPath = `/${projectId}/video/${uuidv4()}.mp4`; //视频保存路径
|
||||||
//新增
|
//新增
|
||||||
const videoData = {
|
const [videoId] = await u.db("o_video").insert({
|
||||||
filePath: videoPath,
|
filePath: videoPath,
|
||||||
time: Date.now(),
|
time: Date.now(),
|
||||||
state: "生成中",
|
state: "生成中",
|
||||||
scriptId,
|
scriptId,
|
||||||
projectId,
|
projectId,
|
||||||
};
|
videoTrackId: trackId,
|
||||||
const [videoId] = await u.db("o_video").insert(videoData);
|
});
|
||||||
//查询出图片数据
|
//查询出图片数据
|
||||||
const images = await Promise.all(
|
const images = await Promise.all(
|
||||||
uploadData.map(async (item: { id: number; type: string }) => {
|
uploadData.map(async (item: { id: number; type: string }) => {
|
||||||
|
|||||||
@ -8,25 +8,31 @@ const router = express.Router();
|
|||||||
export default router.post(
|
export default router.post(
|
||||||
"/",
|
"/",
|
||||||
validateFields({
|
validateFields({
|
||||||
|
trackId: z.number(),
|
||||||
projectId: z.number(),
|
projectId: z.number(),
|
||||||
prompt: z.array(z.string()),
|
prompt: z.array(z.string()),
|
||||||
model: z.string(),
|
model: z.string(),
|
||||||
}),
|
}),
|
||||||
async (req, res) => {
|
async (req, res) => {
|
||||||
const { projectId, prompt, model } = req.body;
|
const { trackId, projectId, prompt, model } = req.body;
|
||||||
const [id, modelData] = model.split(":");
|
const [id, modelData] = model.split(":");
|
||||||
const projectData = await u.db("o_project").select("*").where({ id: projectId }).first();
|
const projectData = await u.db("o_project").select("*").where({ id: projectId }).first();
|
||||||
const artStyle = projectData?.artStyle || "无";
|
const artStyle = projectData?.artStyle || "无";
|
||||||
const visualManual = await u.getArtPrompt(artStyle, "art_storyboard_video");
|
const visualManual = u.getArtPrompt(artStyle, "art_storyboard_video");
|
||||||
const { text } = await u.Ai.Text("universalAi").invoke({
|
const { text } = await u.Ai.Text("universalAi").invoke({
|
||||||
system: visualManual,
|
system: visualManual,
|
||||||
messages: [
|
messages: [
|
||||||
{
|
{
|
||||||
role: "user",
|
role: "user",
|
||||||
content: `你是一个专业的${modelData}视频生成助手。请根据以下提示词,生成一段完整的、可直接用于视频生成模型的中文提示词。${prompt.join(",")}`,
|
content: `你是一个专业的${modelData}视频生成助手。请根据以下提示词,生成一段完整的、可直接用于视频生成模型的中文提示词。${prompt.join(
|
||||||
|
",",
|
||||||
|
)}`,
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
});
|
});
|
||||||
|
await u.db("o_videoTrack").where({ id: trackId }).update({
|
||||||
|
prompt: text,
|
||||||
|
});
|
||||||
res.status(200).send(success(text));
|
res.status(200).send(success(text));
|
||||||
},
|
},
|
||||||
);
|
);
|
||||||
|
|||||||
@ -15,10 +15,14 @@ interface TrackMedia {
|
|||||||
src: string;
|
src: string;
|
||||||
id?: number;
|
id?: number;
|
||||||
fileType: "image" | "video" | "audio";
|
fileType: "image" | "video" | "audio";
|
||||||
|
prompt?: string;
|
||||||
}
|
}
|
||||||
|
|
||||||
interface TrackItem {
|
interface TrackItem {
|
||||||
id?: number;
|
id?: number;
|
||||||
|
prompt: string;
|
||||||
|
state: "未生成" | "生成中" | "已完成" | "生成失败";
|
||||||
|
reason?: string;
|
||||||
medias: TrackMedia[];
|
medias: TrackMedia[];
|
||||||
videoList: VideoItem[];
|
videoList: VideoItem[];
|
||||||
}
|
}
|
||||||
@ -31,21 +35,59 @@ export default router.post(
|
|||||||
}),
|
}),
|
||||||
async (req, res) => {
|
async (req, res) => {
|
||||||
const { projectId, scriptId } = req.body;
|
const { projectId, scriptId } = req.body;
|
||||||
// const data = await u.db("o_videoTrack").where({ projectId, scriptId });
|
const storyboardList = await u.db("o_storyboard").where({ scriptId, projectId }).orderBy("index", "asc");
|
||||||
const storyboardList = await u.db("o_storyboard").where({ scriptId }).orderBy("index", "asc");
|
const videoList = await u.db("o_video").whereIn(
|
||||||
console.log("%c Line:17 🥝 storyboardList", "background:#ea7e5c", storyboardList);
|
"videoTrackId",
|
||||||
// const data = await u.db("o_video").where({ projectId, scriptId });
|
storyboardList.map((s) => s.trackId),
|
||||||
const trackList: TrackItem[] = [
|
);
|
||||||
{
|
console.log("%c Line:40 🌽 videoList", "background:#ffdd4d", videoList);
|
||||||
id: 1,
|
const trackData = await u.db("o_videoTrack").whereIn(
|
||||||
medias: [{ src: "https://example.com/image1.jpg", fileType: "image", id: 1 }],
|
//@ts-ignore
|
||||||
videoList: [
|
"id",
|
||||||
{ id: 1, src: "https://example.com/video1.mp4", state: "已完成" },
|
storyboardList.map((s) => s.trackId),
|
||||||
{ id: 2, src: "https://example.com/video2.mp4", state: "生成中" },
|
);
|
||||||
],
|
|
||||||
},
|
|
||||||
];
|
|
||||||
|
|
||||||
res.status(200).send(success(trackList));
|
const trackList: TrackItem[] = [];
|
||||||
|
const trackIdMap = [...new Set<number>(storyboardList.map((s) => s.trackId!))];
|
||||||
|
for (const trackId of trackIdMap) {
|
||||||
|
const item = trackData.find((t) => t.id === trackId);
|
||||||
|
trackList.push({
|
||||||
|
id: trackId,
|
||||||
|
prompt: item?.prompt || "",
|
||||||
|
state: (item?.state as "未生成" | "生成中" | "已完成" | "生成失败") ?? "未生成",
|
||||||
|
reason: item?.reason ?? "",
|
||||||
|
medias: await Promise.all(
|
||||||
|
storyboardList
|
||||||
|
.filter((s) => s.trackId === trackId)
|
||||||
|
.map(async (s): Promise<TrackMedia> => ({
|
||||||
|
src: s.filePath ? await u.oss.getFileUrl(s.filePath) : "",
|
||||||
|
fileType: "image",
|
||||||
|
...(s.prompt != null ? { prompt: s.prompt } : {}),
|
||||||
|
...(s.id != null ? { id: s.id } : {}),
|
||||||
|
})),
|
||||||
|
),
|
||||||
|
videoList: await Promise.all(
|
||||||
|
videoList
|
||||||
|
.filter((v) => v.videoTrackId === trackId)
|
||||||
|
.map(async (v) => ({
|
||||||
|
id: v.id!,
|
||||||
|
src: v.filePath ? await u.oss.getFileUrl(v.filePath) : "",
|
||||||
|
state: v.state === "done" ? "已完成" : v.state === "generating" ? "生成中" : v.state === "error" ? "生成失败" : "未生成",
|
||||||
|
})),
|
||||||
|
),
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
res.status(200).send(
|
||||||
|
success({
|
||||||
|
storyboardList: await Promise.all(
|
||||||
|
storyboardList.map(async (s) => ({
|
||||||
|
...s,
|
||||||
|
src: s.filePath ? await u.oss.getFileUrl(s.filePath) : "",
|
||||||
|
})),
|
||||||
|
),
|
||||||
|
trackList,
|
||||||
|
}),
|
||||||
|
);
|
||||||
},
|
},
|
||||||
);
|
);
|
||||||
|
|||||||
32
src/routes/production/workbench/getVideoList.ts
Normal file
32
src/routes/production/workbench/getVideoList.ts
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
import express from "express";
|
||||||
|
import u from "@/utils";
|
||||||
|
import { z } from "zod";
|
||||||
|
import { success } from "@/lib/responseFormat";
|
||||||
|
import { validateFields } from "@/middleware/middleware";
|
||||||
|
const router = express.Router();
|
||||||
|
|
||||||
|
export default router.post(
|
||||||
|
"/",
|
||||||
|
validateFields({
|
||||||
|
projectId: z.number(),
|
||||||
|
scriptId: z.number(),
|
||||||
|
}),
|
||||||
|
async (req, res) => {
|
||||||
|
const { projectId, scriptId } = req.body;
|
||||||
|
const storyboardList = await u.db("o_storyboard").where({ scriptId, projectId }).orderBy("index", "asc");
|
||||||
|
const videoList = await u.db("o_video").whereIn(
|
||||||
|
"videoTrackId",
|
||||||
|
storyboardList.map((s) => s.trackId),
|
||||||
|
);
|
||||||
|
res.status(200).send(
|
||||||
|
success(
|
||||||
|
await Promise.all(
|
||||||
|
videoList.map(async (s) => ({
|
||||||
|
...s,
|
||||||
|
src: s.filePath ? await u.oss.getFileUrl(s.filePath) : "",
|
||||||
|
})),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
},
|
||||||
|
);
|
||||||
@ -1,19 +0,0 @@
|
|||||||
import express from "express";
|
|
||||||
import u from "@/utils";
|
|
||||||
import { z } from "zod";
|
|
||||||
import { success } from "@/lib/responseFormat";
|
|
||||||
import { validateFields } from "@/middleware/middleware";
|
|
||||||
const router = express.Router();
|
|
||||||
|
|
||||||
export default router.post(
|
|
||||||
"/",
|
|
||||||
validateFields({
|
|
||||||
id: z.number(),
|
|
||||||
specifyIds: z.array(z.number()),
|
|
||||||
}),
|
|
||||||
async (req, res) => {
|
|
||||||
const { id, specifyIds } = req.body;
|
|
||||||
const data = await u.db("o_video").where("id", id).whereIn("id", specifyIds).andWhere("state", "生成中").select("*");
|
|
||||||
res.status(200).send(success(data));
|
|
||||||
},
|
|
||||||
);
|
|
||||||
25
src/types/database.d.ts
vendored
25
src/types/database.d.ts
vendored
@ -1,11 +1,21 @@
|
|||||||
// @db-hash f82eb99171699f051830710c1f816b59
|
<<<<<<< HEAD
|
||||||
|
// @db-hash 2c7f828da2621d74d1b0d147d4ba4342
|
||||||
|
=======
|
||||||
|
// @db-hash a27fff5b05e1c9ef490898f17703079a
|
||||||
|
>>>>>>> bf124d07e35f3d45958f5c2e64a650df7249f737
|
||||||
//该文件由脚本自动生成,请勿手动修改
|
//该文件由脚本自动生成,请勿手动修改
|
||||||
|
|
||||||
export interface _o_videoTrack_old_20260401 {
|
export interface _o_vendorConfig_old_20260401 {
|
||||||
'id'?: number;
|
'author'?: string | null;
|
||||||
'projectId'?: number | null;
|
'code'?: string | null;
|
||||||
'scriptId'?: number | null;
|
'createTime'?: number | null;
|
||||||
'videoId'?: number | null;
|
'description'?: string | null;
|
||||||
|
'icon'?: string | null;
|
||||||
|
'id'?: string;
|
||||||
|
'inputs'?: string | null;
|
||||||
|
'inputValues'?: string | null;
|
||||||
|
'models'?: string | null;
|
||||||
|
'name'?: string | null;
|
||||||
}
|
}
|
||||||
export interface memories {
|
export interface memories {
|
||||||
'content': string;
|
'content': string;
|
||||||
@ -203,6 +213,7 @@ export interface o_vendorConfig {
|
|||||||
'code'?: string | null;
|
'code'?: string | null;
|
||||||
'createTime'?: number | null;
|
'createTime'?: number | null;
|
||||||
'description'?: string | null;
|
'description'?: string | null;
|
||||||
|
'enableEnglish'?: number | null;
|
||||||
'icon'?: string | null;
|
'icon'?: string | null;
|
||||||
'id'?: string;
|
'id'?: string;
|
||||||
'inputs'?: string | null;
|
'inputs'?: string | null;
|
||||||
@ -231,7 +242,7 @@ export interface o_videoTrack {
|
|||||||
}
|
}
|
||||||
|
|
||||||
export interface DB {
|
export interface DB {
|
||||||
"_o_videoTrack_old_20260401": _o_videoTrack_old_20260401;
|
"_o_vendorConfig_old_20260401": _o_vendorConfig_old_20260401;
|
||||||
"memories": memories;
|
"memories": memories;
|
||||||
"o_agentDeploy": o_agentDeploy;
|
"o_agentDeploy": o_agentDeploy;
|
||||||
"o_agentWorkData": o_agentWorkData;
|
"o_agentWorkData": o_agentWorkData;
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user