 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>
		
			
				
	
	
		
			45 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			45 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| "use client";
 | |
| 
 | |
| // src/useMutation.ts
 | |
| import * as React from "react";
 | |
| import {
 | |
|   MutationObserver,
 | |
|   noop,
 | |
|   notifyManager,
 | |
|   shouldThrowError
 | |
| } from "@tanstack/query-core";
 | |
| import { useQueryClient } from "./QueryClientProvider.js";
 | |
| function useMutation(options, queryClient) {
 | |
|   const client = useQueryClient(queryClient);
 | |
|   const [observer] = React.useState(
 | |
|     () => new MutationObserver(
 | |
|       client,
 | |
|       options
 | |
|     )
 | |
|   );
 | |
|   React.useEffect(() => {
 | |
|     observer.setOptions(options);
 | |
|   }, [observer, options]);
 | |
|   const result = React.useSyncExternalStore(
 | |
|     React.useCallback(
 | |
|       (onStoreChange) => observer.subscribe(notifyManager.batchCalls(onStoreChange)),
 | |
|       [observer]
 | |
|     ),
 | |
|     () => observer.getCurrentResult(),
 | |
|     () => observer.getCurrentResult()
 | |
|   );
 | |
|   const mutate = React.useCallback(
 | |
|     (variables, mutateOptions) => {
 | |
|       observer.mutate(variables, mutateOptions).catch(noop);
 | |
|     },
 | |
|     [observer]
 | |
|   );
 | |
|   if (result.error && shouldThrowError(observer.options.throwOnError, [result.error])) {
 | |
|     throw result.error;
 | |
|   }
 | |
|   return { ...result, mutate, mutateAsync: result.mutate };
 | |
| }
 | |
| export {
 | |
|   useMutation
 | |
| };
 | |
| //# sourceMappingURL=useMutation.js.map
 |