 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>
		
			
				
	
	
		
			40 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			40 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| "use strict";
 | |
| Object.defineProperty(exports, "__esModule", {
 | |
|     value: true
 | |
| });
 | |
| Object.defineProperty(exports, /**
 | |
|  * @template {string | import('postcss-selector-parser').Root} T
 | |
|  *
 | |
|  * Prefix all classes in the selector with the given prefix
 | |
|  *
 | |
|  * It can take either a string or a selector AST and will return the same type
 | |
|  *
 | |
|  * @param {string} prefix
 | |
|  * @param {T} selector
 | |
|  * @param {boolean} prependNegative
 | |
|  * @returns {T}
 | |
|  */ "default", {
 | |
|     enumerable: true,
 | |
|     get: function() {
 | |
|         return _default;
 | |
|     }
 | |
| });
 | |
| const _postcssselectorparser = /*#__PURE__*/ _interop_require_default(require("postcss-selector-parser"));
 | |
| function _interop_require_default(obj) {
 | |
|     return obj && obj.__esModule ? obj : {
 | |
|         default: obj
 | |
|     };
 | |
| }
 | |
| function _default(prefix, selector, prependNegative = false) {
 | |
|     if (prefix === "") {
 | |
|         return selector;
 | |
|     }
 | |
|     /** @type {import('postcss-selector-parser').Root} */ let ast = typeof selector === "string" ? (0, _postcssselectorparser.default)().astSync(selector) : selector;
 | |
|     ast.walkClasses((classSelector)=>{
 | |
|         let baseClass = classSelector.value;
 | |
|         let shouldPlaceNegativeBeforePrefix = prependNegative && baseClass.startsWith("-");
 | |
|         classSelector.value = shouldPlaceNegativeBeforePrefix ? `-${prefix}${baseClass.slice(1)}` : `${prefix}${baseClass}`;
 | |
|     });
 | |
|     return typeof selector === "string" ? ast.toString() : ast;
 | |
| }
 |