 85bf1341f3
			
		
	
	85bf1341f3
	
	
	
		
			
			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>
		
			
				
	
	
		
			39 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			39 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| import { applyReviver } from '../doc/applyReviver.js';
 | |
| import { NODE_TYPE, isDocument } from './identity.js';
 | |
| import { toJS } from './toJS.js';
 | |
| 
 | |
| class NodeBase {
 | |
|     constructor(type) {
 | |
|         Object.defineProperty(this, NODE_TYPE, { value: type });
 | |
|     }
 | |
|     /** Create a copy of this node.  */
 | |
|     clone() {
 | |
|         const copy = Object.create(Object.getPrototypeOf(this), Object.getOwnPropertyDescriptors(this));
 | |
|         if (this.range)
 | |
|             copy.range = this.range.slice();
 | |
|         return copy;
 | |
|     }
 | |
|     /** A plain JavaScript representation of this node. */
 | |
|     toJS(doc, { mapAsMap, maxAliasCount, onAnchor, reviver } = {}) {
 | |
|         if (!isDocument(doc))
 | |
|             throw new TypeError('A document argument is required');
 | |
|         const ctx = {
 | |
|             anchors: new Map(),
 | |
|             doc,
 | |
|             keep: true,
 | |
|             mapAsMap: mapAsMap === true,
 | |
|             mapKeyWarned: false,
 | |
|             maxAliasCount: typeof maxAliasCount === 'number' ? maxAliasCount : 100
 | |
|         };
 | |
|         const res = toJS(this, '', ctx);
 | |
|         if (typeof onAnchor === 'function')
 | |
|             for (const { count, res } of ctx.anchors.values())
 | |
|                 onAnchor(res, count);
 | |
|         return typeof reviver === 'function'
 | |
|             ? applyReviver(reviver, { '': res }, '', res)
 | |
|             : res;
 | |
|     }
 | |
| }
 | |
| 
 | |
| export { NodeBase };
 |