 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>
		
			
				
	
	
		
			52 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			52 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| "use strict";
 | |
| 
 | |
| Object.defineProperty(exports, "__esModule", {
 | |
|   value: true
 | |
| });
 | |
| exports.default = void 0;
 | |
| var _helperPluginUtils = require("@babel/helper-plugin-utils");
 | |
| var _core = require("@babel/core");
 | |
| const TRACE_ID = "__source";
 | |
| const FILE_NAME_VAR = "_jsxFileName";
 | |
| const createNodeFromNullish = (val, fn) => val == null ? _core.types.nullLiteral() : fn(val);
 | |
| var _default = exports.default = (0, _helperPluginUtils.declare)(api => {
 | |
|   api.assertVersion(7);
 | |
|   function makeTrace(fileNameIdentifier, {
 | |
|     line,
 | |
|     column
 | |
|   }) {
 | |
|     const fileLineLiteral = createNodeFromNullish(line, _core.types.numericLiteral);
 | |
|     const fileColumnLiteral = createNodeFromNullish(column, c => _core.types.numericLiteral(c + 1));
 | |
|     return _core.template.expression.ast`{
 | |
|       fileName: ${fileNameIdentifier},
 | |
|       lineNumber: ${fileLineLiteral},
 | |
|       columnNumber: ${fileColumnLiteral},
 | |
|     }`;
 | |
|   }
 | |
|   const isSourceAttr = attr => _core.types.isJSXAttribute(attr) && attr.name.name === TRACE_ID;
 | |
|   return {
 | |
|     name: "transform-react-jsx-source",
 | |
|     visitor: {
 | |
|       JSXOpeningElement(path, state) {
 | |
|         const {
 | |
|           node
 | |
|         } = path;
 | |
|         if (!node.loc || path.node.attributes.some(isSourceAttr)) {
 | |
|           return;
 | |
|         }
 | |
|         if (!state.fileNameIdentifier) {
 | |
|           const fileNameId = path.scope.generateUidIdentifier(FILE_NAME_VAR);
 | |
|           state.fileNameIdentifier = fileNameId;
 | |
|           path.scope.getProgramParent().push({
 | |
|             id: fileNameId,
 | |
|             init: _core.types.stringLiteral(state.filename || "")
 | |
|           });
 | |
|         }
 | |
|         node.attributes.push(_core.types.jsxAttribute(_core.types.jsxIdentifier(TRACE_ID), _core.types.jsxExpressionContainer(makeTrace(_core.types.cloneNode(state.fileNameIdentifier), node.loc.start))));
 | |
|       }
 | |
|     }
 | |
|   };
 | |
| });
 | |
| 
 | |
| //# sourceMappingURL=index.js.map
 |