update
This commit is contained in:
parent
6807c632da
commit
bcf8591719
@ -143,7 +143,6 @@ const ResourcePage = ({ topics }) => {
|
|||||||
const htmlContent = useMemo(() => {
|
const htmlContent = useMemo(() => {
|
||||||
let fileContent = content || "**No Data!**";
|
let fileContent = content || "**No Data!**";
|
||||||
fileContent = marked.parse(fileContent);
|
fileContent = marked.parse(fileContent);
|
||||||
console.log({ content, fileContent });
|
|
||||||
|
|
||||||
fileContent = `
|
fileContent = `
|
||||||
<!DOCTYPE html>
|
<!DOCTYPE html>
|
||||||
|
|||||||
@ -161,6 +161,115 @@ app.post(
|
|||||||
}),
|
}),
|
||||||
);
|
);
|
||||||
|
|
||||||
|
app.post(
|
||||||
|
"/resources/duplicate",
|
||||||
|
verifyToken,
|
||||||
|
asyncHandler(async (req, res) => {
|
||||||
|
try {
|
||||||
|
const { sourceResourceSeq, targetResourceSeq } = req.body;
|
||||||
|
|
||||||
|
if (!sourceResourceSeq || !targetResourceSeq) {
|
||||||
|
res
|
||||||
|
.status(400)
|
||||||
|
.json({ message: "Missing sourceResourceSeq or targetResourceSeq" });
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (
|
||||||
|
typeof sourceResourceSeq !== "number" ||
|
||||||
|
typeof targetResourceSeq !== "number"
|
||||||
|
) {
|
||||||
|
res
|
||||||
|
.status(400)
|
||||||
|
.json({ message: "Invalid body - sequences must be numbers" });
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (sourceResourceSeq === targetResourceSeq) {
|
||||||
|
res
|
||||||
|
.status(400)
|
||||||
|
.json({
|
||||||
|
message: "Source and target resource sequences cannot be the same",
|
||||||
|
});
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const sourceResourceIdx = sourceResourceSeq - 1;
|
||||||
|
const targetResourceIdx = targetResourceSeq - 1;
|
||||||
|
|
||||||
|
const topics = await getStructure();
|
||||||
|
|
||||||
|
// Validate resource sequences exist (check against first topic to get max resources)
|
||||||
|
if (
|
||||||
|
sourceResourceIdx < 0 ||
|
||||||
|
targetResourceIdx < 0 ||
|
||||||
|
sourceResourceIdx >= topics[0].resources.length ||
|
||||||
|
targetResourceIdx >= topics[0].resources.length
|
||||||
|
) {
|
||||||
|
res
|
||||||
|
.status(400)
|
||||||
|
.json({ message: "Invalid resource sequence - out of bounds" });
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
let duplicatedCount = 0;
|
||||||
|
let skippedCount = 0;
|
||||||
|
const timestamp = Date.now();
|
||||||
|
|
||||||
|
// Process all topics with Promise.all to handle async operations properly
|
||||||
|
await Promise.all(
|
||||||
|
topics.map(async (topic) => {
|
||||||
|
const sourceResource = topic.resources[sourceResourceIdx];
|
||||||
|
const targetResource = topic.resources[targetResourceIdx];
|
||||||
|
|
||||||
|
// Skip if source resource has no content
|
||||||
|
if (!sourceResource || !sourceResource.filename) {
|
||||||
|
skippedCount++;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
// Read content from source file
|
||||||
|
const sourceFilePath = path.join(
|
||||||
|
STATIC_DIR,
|
||||||
|
sourceResource.filename,
|
||||||
|
);
|
||||||
|
const content = await fs.readFile(sourceFilePath, "utf8");
|
||||||
|
|
||||||
|
// Create new filename for target resource
|
||||||
|
const newFilename = `F_${targetResource.id}_${timestamp}.md`;
|
||||||
|
const targetFilePath = path.join(STATIC_DIR, newFilename);
|
||||||
|
|
||||||
|
// Write content to new file
|
||||||
|
await fs.writeFile(targetFilePath, content, "utf8");
|
||||||
|
|
||||||
|
// Update target resource filename
|
||||||
|
targetResource.filename = newFilename;
|
||||||
|
duplicatedCount++;
|
||||||
|
} catch (fileError) {
|
||||||
|
console.error(
|
||||||
|
`Failed to duplicate resource for topic ${topic.id}:`,
|
||||||
|
fileError,
|
||||||
|
);
|
||||||
|
skippedCount++;
|
||||||
|
}
|
||||||
|
}),
|
||||||
|
);
|
||||||
|
|
||||||
|
res.json({
|
||||||
|
success: true,
|
||||||
|
duplicatedCount,
|
||||||
|
skippedCount,
|
||||||
|
message: `Successfully duplicated ${duplicatedCount} resources from sequence ${sourceResourceSeq} to ${targetResourceSeq}. Skipped ${skippedCount} resources.`,
|
||||||
|
structure: topics,
|
||||||
|
});
|
||||||
|
} catch (error) {
|
||||||
|
console.error("Duplicate resources error:", error);
|
||||||
|
res.status(500).json({ error: "Failed to duplicate resources" });
|
||||||
|
}
|
||||||
|
}),
|
||||||
|
);
|
||||||
|
|
||||||
app.use(errorRequestHandler);
|
app.use(errorRequestHandler);
|
||||||
|
|
||||||
const PORT = process.env.PORT || 3000;
|
const PORT = process.env.PORT || 3000;
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user