 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>
		
			
				
	
	
		
			27 lines
		
	
	
		
			998 B
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			27 lines
		
	
	
		
			998 B
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| "use strict";
 | |
| Object.defineProperty(exports, "__esModule", {
 | |
|     value: true
 | |
| });
 | |
| Object.defineProperty(exports, "backgroundSize", {
 | |
|     enumerable: true,
 | |
|     get: function() {
 | |
|         return backgroundSize;
 | |
|     }
 | |
| });
 | |
| const _dataTypes = require("./dataTypes");
 | |
| const _splitAtTopLevelOnly = require("./splitAtTopLevelOnly");
 | |
| function backgroundSize(value) {
 | |
|     let keywordValues = [
 | |
|         "cover",
 | |
|         "contain"
 | |
|     ];
 | |
|     // the <length-percentage> type will probably be a css function
 | |
|     // so we have to use `splitAtTopLevelOnly`
 | |
|     return (0, _splitAtTopLevelOnly.splitAtTopLevelOnly)(value, ",").every((part)=>{
 | |
|         let sizes = (0, _splitAtTopLevelOnly.splitAtTopLevelOnly)(part, "_").filter(Boolean);
 | |
|         if (sizes.length === 1 && keywordValues.includes(sizes[0])) return true;
 | |
|         if (sizes.length !== 1 && sizes.length !== 2) return false;
 | |
|         return sizes.every((size)=>(0, _dataTypes.length)(size) || (0, _dataTypes.percentage)(size) || size === "auto");
 | |
|     });
 | |
| }
 |