This comprehensive implementation includes: - FastAPI backend with MCP server integration - React/TypeScript frontend with Vite - PostgreSQL database with Redis caching - Grafana/Prometheus monitoring stack - Docker Compose orchestration - Full MCP protocol support for Claude Code integration Features: - Agent discovery and management across network - Visual workflow editor and execution engine - Real-time task coordination and monitoring - Multi-model support with specialized agents - Distributed development task allocation 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
26 lines
1007 B
JavaScript
26 lines
1007 B
JavaScript
/**
|
|
* Utilities for working with BaseMetadata objects.
|
|
*/
|
|
/**
|
|
* Gets the display name for an object with BaseMetadata.
|
|
* For tools, the precedence is: title → annotations.title → name
|
|
* For other objects: title → name
|
|
* This implements the spec requirement: "if no title is provided, name should be used for display purposes"
|
|
*/
|
|
export function getDisplayName(metadata) {
|
|
var _a;
|
|
// First check for title (not undefined and not empty string)
|
|
if (metadata.title !== undefined && metadata.title !== '') {
|
|
return metadata.title;
|
|
}
|
|
// Then check for annotations.title (only present in Tool objects)
|
|
if ('annotations' in metadata) {
|
|
const metadataWithAnnotations = metadata;
|
|
if ((_a = metadataWithAnnotations.annotations) === null || _a === void 0 ? void 0 : _a.title) {
|
|
return metadataWithAnnotations.annotations.title;
|
|
}
|
|
}
|
|
// Finally fall back to name
|
|
return metadata.name;
|
|
}
|
|
//# sourceMappingURL=metadataUtils.js.map
|