 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>
		
			
				
	
	
		
			37 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			37 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| import { createNode } from '../doc/createNode.js';
 | |
| import { stringifyPair } from '../stringify/stringifyPair.js';
 | |
| import { addPairToJSMap } from './addPairToJSMap.js';
 | |
| import { NODE_TYPE, PAIR, isNode } from './identity.js';
 | |
| 
 | |
| function createPair(key, value, ctx) {
 | |
|     const k = createNode(key, undefined, ctx);
 | |
|     const v = createNode(value, undefined, ctx);
 | |
|     return new Pair(k, v);
 | |
| }
 | |
| class Pair {
 | |
|     constructor(key, value = null) {
 | |
|         Object.defineProperty(this, NODE_TYPE, { value: PAIR });
 | |
|         this.key = key;
 | |
|         this.value = value;
 | |
|     }
 | |
|     clone(schema) {
 | |
|         let { key, value } = this;
 | |
|         if (isNode(key))
 | |
|             key = key.clone(schema);
 | |
|         if (isNode(value))
 | |
|             value = value.clone(schema);
 | |
|         return new Pair(key, value);
 | |
|     }
 | |
|     toJSON(_, ctx) {
 | |
|         const pair = ctx?.mapAsMap ? new Map() : {};
 | |
|         return addPairToJSMap(ctx, pair, this);
 | |
|     }
 | |
|     toString(ctx, onComment, onChompKeep) {
 | |
|         return ctx?.doc
 | |
|             ? stringifyPair(this, ctx, onComment, onChompKeep)
 | |
|             : JSON.stringify(this);
 | |
|     }
 | |
| }
 | |
| 
 | |
| export { Pair, createPair };
 |