import { MAX_ARRAY_ITEMS } from './common';
import { renderGenericContent } from './genericRenderer';
/**
* Renders content for 'progress' document type.
*/
export function renderProgressContent(content: Record<string, unknown>): string {
// Renderer trace logging
// console.log("[Renderer] Rendering 'progress' type");
let mdString = '';
try {
if (!content || typeof content !== 'object') {
return '_(Invalid or empty progress content)_';
}
if (content.status) {
mdString += `**Status:** ${content.status}\n\n`;
}
// Removed extra brace from line 18
if (content.completionPercentage !== undefined && typeof content.completionPercentage === 'number') {
const percentage = Math.max(0, Math.min(100, content.completionPercentage));
const filledCount = Math.round(percentage / 10);
const _emptyCount = 10 - filledCount; // 未使用変数
}
if (Array.isArray(content.workingFeatures) && content.workingFeatures.length > 0) {
mdString += `### Working Features\n`;
const displayFeatures = content.workingFeatures.slice(0, MAX_ARRAY_ITEMS);
const remainingFeatures = content.workingFeatures.length - displayFeatures.length;
mdString += displayFeatures.map((feature: Record<string, unknown>) => {
const status = feature.status || 'in-progress';
const check = status === 'completed' ? '[x]' : '[ ]';
return `- ${check} ${feature.description || feature.id || 'N/A'} _(${status})_`;
}).join('\n');
if (remainingFeatures > 0) {
mdString += `\n- ... (${remainingFeatures} more features)`;
}
mdString += '\n\n';
}
if (Array.isArray(content.pendingImplementation) && content.pendingImplementation.length > 0) {
mdString += `### Pending Implementation\n`;
const grouped: { [key: string]: Record<string, unknown>[] } = {};
content.pendingImplementation.forEach((item: Record<string, unknown>) => {
const priority = item.priority || 'medium';
if (!grouped[priority]) grouped[priority] = [];
grouped[priority].push(item);
});
['high', 'medium', 'low'].forEach(priority => {
if (grouped[priority] && grouped[priority].length > 0) {
mdString += `**Priority: ${priority.toUpperCase()}**\n`;
const displayItems = grouped[priority].slice(0, MAX_ARRAY_ITEMS);
const remainingItems = grouped[priority].length - displayItems.length;
mdString += displayItems.map((item: Record<string, unknown>) => `- ${item.description || item.id || 'N/A'}`).join('\n');
if (remainingItems > 0) {
mdString += `\n- ... (${remainingItems} more items)`;
}
mdString += '\n';
}
});
mdString += '\n';
}
if (Array.isArray(content.knownIssues) && content.knownIssues.length > 0) {
mdString += `### Known Issues\n`;
const displayIssues = content.knownIssues.slice(0, MAX_ARRAY_ITEMS);
const remainingIssues = content.knownIssues.length - displayIssues.length;
mdString += displayIssues.map((issue: Record<string, unknown>) => {
let issueStr = `- **${issue.id || 'Issue'}:** ${issue.description || 'No description'} _(Status: ${issue.status || 'open'})_`;
if (issue.solution) {
issueStr += `\n - **Solution:** ${issue.solution}`;
}
return issueStr;
}).join('\n\n');
if (remainingIssues > 0) {
mdString += `\n\n- ... (${remainingIssues} more issues)`;
}
mdString += '\n\n';
}
const handledKeys = ['status', 'completionPercentage', 'workingFeatures', 'pendingImplementation', 'knownIssues'];
const remainingContent: Record<string, unknown> = {};
for (const key in content) {
if (Object.prototype.hasOwnProperty.call(content, key) && !handledKeys.includes(key)) {
remainingContent[key] = content[key];
}
}
if (Object.keys(remainingContent).length > 0) {
mdString += `### Other Information\n\n`;
mdString += renderGenericContent(remainingContent);
}
return mdString || '_(Progress content seems empty)_';
} catch (error) {
// エラーログ(デバッガーやテスト時に役立つ)
// console.error(`[Renderer Error - progress] Failed to render progress content:`, error);
const errorMessage = error instanceof Error ? error.message : String(error);
return `### Rendering Error (Progress)\n\nAn error occurred while rendering the progress content:\n\n\`\`\`\n${errorMessage}\n\`\`\`\n\n**Original Content:**\n\n\`\`\`json\n${JSON.stringify(content, null, 2)}\n\`\`\`\n`;
}
}