 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>
		
			
				
	
	
		
			46 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			46 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| 'use strict';
 | |
| 
 | |
| var Document = require('../doc/Document.js');
 | |
| var composeNode = require('./compose-node.js');
 | |
| var resolveEnd = require('./resolve-end.js');
 | |
| var resolveProps = require('./resolve-props.js');
 | |
| 
 | |
| function composeDoc(options, directives, { offset, start, value, end }, onError) {
 | |
|     const opts = Object.assign({ _directives: directives }, options);
 | |
|     const doc = new Document.Document(undefined, opts);
 | |
|     const ctx = {
 | |
|         atKey: false,
 | |
|         atRoot: true,
 | |
|         directives: doc.directives,
 | |
|         options: doc.options,
 | |
|         schema: doc.schema
 | |
|     };
 | |
|     const props = resolveProps.resolveProps(start, {
 | |
|         indicator: 'doc-start',
 | |
|         next: value ?? end?.[0],
 | |
|         offset,
 | |
|         onError,
 | |
|         parentIndent: 0,
 | |
|         startOnNewline: true
 | |
|     });
 | |
|     if (props.found) {
 | |
|         doc.directives.docStart = true;
 | |
|         if (value &&
 | |
|             (value.type === 'block-map' || value.type === 'block-seq') &&
 | |
|             !props.hasNewline)
 | |
|             onError(props.end, 'MISSING_CHAR', 'Block collection cannot start on same line with directives-end marker');
 | |
|     }
 | |
|     // @ts-expect-error If Contents is set, let's trust the user
 | |
|     doc.contents = value
 | |
|         ? composeNode.composeNode(ctx, value, props, onError)
 | |
|         : composeNode.composeEmptyNode(ctx, props.end, start, null, props, onError);
 | |
|     const contentEnd = doc.contents.range[2];
 | |
|     const re = resolveEnd.resolveEnd(end, contentEnd, false, onError);
 | |
|     if (re.comment)
 | |
|         doc.comment = re.comment;
 | |
|     doc.range = [offset, contentEnd, re.offset];
 | |
|     return doc;
 | |
| }
 | |
| 
 | |
| exports.composeDoc = composeDoc;
 |