 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>
		
			
				
	
	
		
			36 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			36 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| import { useMemo, createElement } from 'react';
 | |
| import { useHTMLProps } from '../html/use-props.mjs';
 | |
| import { filterProps } from './utils/filter-props.mjs';
 | |
| import { isSVGComponent } from './utils/is-svg-component.mjs';
 | |
| import { useSVGProps } from '../svg/use-props.mjs';
 | |
| import { isMotionValue } from '../../value/utils/is-motion-value.mjs';
 | |
| 
 | |
| function createUseRender(forwardMotionProps = false) {
 | |
|     const useRender = (Component, props, ref, { latestValues }, isStatic) => {
 | |
|         const useVisualProps = isSVGComponent(Component)
 | |
|             ? useSVGProps
 | |
|             : useHTMLProps;
 | |
|         const visualProps = useVisualProps(props, latestValues, isStatic, Component);
 | |
|         const filteredProps = filterProps(props, typeof Component === "string", forwardMotionProps);
 | |
|         const elementProps = {
 | |
|             ...filteredProps,
 | |
|             ...visualProps,
 | |
|             ref,
 | |
|         };
 | |
|         /**
 | |
|          * If component has been handed a motion value as its child,
 | |
|          * memoise its initial value and render that. Subsequent updates
 | |
|          * will be handled by the onChange handler
 | |
|          */
 | |
|         const { children } = props;
 | |
|         const renderedChildren = useMemo(() => (isMotionValue(children) ? children.get() : children), [children]);
 | |
|         return createElement(Component, {
 | |
|             ...elementProps,
 | |
|             children: renderedChildren,
 | |
|         });
 | |
|     };
 | |
|     return useRender;
 | |
| }
 | |
| 
 | |
| export { createUseRender };
 |