Frontend Enhancements: - Complete React TypeScript frontend with modern UI components - Distributed workflows management interface with real-time updates - Socket.IO integration for live agent status monitoring - Agent management dashboard with cluster visualization - Project management interface with metrics and task tracking - Responsive design with proper error handling and loading states Backend Infrastructure: - Distributed coordinator for multi-agent workflow orchestration - Cluster management API with comprehensive agent operations - Enhanced database models for agents and projects - Project service for filesystem-based project discovery - Performance monitoring and metrics collection - Comprehensive API documentation and error handling Documentation: - Complete distributed development guide (README_DISTRIBUTED.md) - Comprehensive development report with architecture insights - System configuration templates and deployment guides The platform now provides a complete web interface for managing the distributed AI cluster with real-time monitoring, workflow orchestration, and agent coordination capabilities. 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
38 lines
1.2 KiB
JavaScript
38 lines
1.2 KiB
JavaScript
import { hasAnchor } from './identity.js';
|
|
|
|
/**
|
|
* Recursively convert any node or its contents to native JavaScript
|
|
*
|
|
* @param value - The input value
|
|
* @param arg - If `value` defines a `toJSON()` method, use this
|
|
* as its first argument
|
|
* @param ctx - Conversion context, originally set in Document#toJS(). If
|
|
* `{ keep: true }` is not set, output should be suitable for JSON
|
|
* stringification.
|
|
*/
|
|
function toJS(value, arg, ctx) {
|
|
// eslint-disable-next-line @typescript-eslint/no-unsafe-return
|
|
if (Array.isArray(value))
|
|
return value.map((v, i) => toJS(v, String(i), ctx));
|
|
if (value && typeof value.toJSON === 'function') {
|
|
// eslint-disable-next-line @typescript-eslint/no-unsafe-call
|
|
if (!ctx || !hasAnchor(value))
|
|
return value.toJSON(arg, ctx);
|
|
const data = { aliasCount: 0, count: 1, res: undefined };
|
|
ctx.anchors.set(value, data);
|
|
ctx.onCreate = res => {
|
|
data.res = res;
|
|
delete ctx.onCreate;
|
|
};
|
|
const res = value.toJSON(arg, ctx);
|
|
if (ctx.onCreate)
|
|
ctx.onCreate(res);
|
|
return res;
|
|
}
|
|
if (typeof value === 'bigint' && !ctx?.keep)
|
|
return Number(value);
|
|
return value;
|
|
}
|
|
|
|
export { toJS };
|