Add comprehensive frontend UI and distributed infrastructure

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>
This commit is contained in:
anthonyrawlins
2025-07-10 08:41:59 +10:00
parent fc0eec91ef
commit 85bf1341f3
28348 changed files with 2646896 additions and 69 deletions

View File

@@ -0,0 +1,142 @@
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _index = _interopRequireDefault(require("../../../_lib/buildLocalizeFn/index.js"));
var eraValues = {
narrow: ['Ք', 'Մ'],
abbreviated: ['ՔԱ', 'ՄԹ'],
wide: ['Քրիստոսից առաջ', 'Մեր թվարկության']
};
var quarterValues = {
narrow: ['1', '2', '3', '4'],
abbreviated: ['Ք1', 'Ք2', 'Ք3', 'Ք4'],
wide: ['1֊ին քառորդ', '2֊րդ քառորդ', '3֊րդ քառորդ', '4֊րդ քառորդ']
};
var monthValues = {
narrow: ['Հ', 'Փ', 'Մ', 'Ա', 'Մ', 'Հ', 'Հ', 'Օ', 'Ս', 'Հ', 'Ն', 'Դ'],
abbreviated: ['հուն', 'փետ', 'մար', 'ապր', 'մայ', 'հուն', 'հուլ', 'օգս', 'սեպ', 'հոկ', 'նոյ', 'դեկ'],
wide: ['հունվար', 'փետրվար', 'մարտ', 'ապրիլ', 'մայիս', 'հունիս', 'հուլիս', 'օգոստոս', 'սեպտեմբեր', 'հոկտեմբեր', 'նոյեմբեր', 'դեկտեմբեր']
};
var dayValues = {
narrow: ['Կ', 'Ե', 'Ե', 'Չ', 'Հ', 'Ո', 'Շ'],
short: ['կր', 'եր', 'եք', 'չք', 'հգ', 'ուր', 'շբ'],
abbreviated: ['կիր', 'երկ', 'երք', 'չոր', 'հնգ', 'ուրբ', 'շաբ'],
wide: ['կիրակի', 'երկուշաբթի', 'երեքշաբթի', 'չորեքշաբթի', 'հինգշաբթի', 'ուրբաթ', 'շաբաթ']
};
var dayPeriodValues = {
narrow: {
am: 'a',
pm: 'p',
midnight: 'կեսգշ',
noon: 'կեսօր',
morning: 'առավոտ',
afternoon: 'ցերեկ',
evening: 'երեկո',
night: 'գիշեր'
},
abbreviated: {
am: 'AM',
pm: 'PM',
midnight: 'կեսգիշեր',
noon: 'կեսօր',
morning: 'առավոտ',
afternoon: 'ցերեկ',
evening: 'երեկո',
night: 'գիշեր'
},
wide: {
am: 'a.m.',
pm: 'p.m.',
midnight: 'կեսգիշեր',
noon: 'կեսօր',
morning: 'առավոտ',
afternoon: 'ցերեկ',
evening: 'երեկո',
night: 'գիշեր'
}
};
var formattingDayPeriodValues = {
narrow: {
am: 'a',
pm: 'p',
midnight: 'կեսգշ',
noon: 'կեսօր',
morning: 'առավոտը',
afternoon: 'ցերեկը',
evening: 'երեկոյան',
night: 'գիշերը'
},
abbreviated: {
am: 'AM',
pm: 'PM',
midnight: 'կեսգիշերին',
noon: 'կեսօրին',
morning: 'առավոտը',
afternoon: 'ցերեկը',
evening: 'երեկոյան',
night: 'գիշերը'
},
wide: {
am: 'a.m.',
pm: 'p.m.',
midnight: 'կեսգիշերին',
noon: 'կեսօրին',
morning: 'առավոտը',
afternoon: 'ցերեկը',
evening: 'երեկոյան',
night: 'գիշերը'
}
};
var ordinalNumber = function ordinalNumber(dirtyNumber, _options) {
var number = Number(dirtyNumber);
// If ordinal numbers depend on context, for example,
// if they are different for different grammatical genders,
// use `options.unit`.
//
// `unit` can be 'year', 'quarter', 'month', 'week', 'date', 'dayOfYear',
// 'day', 'hour', 'minute', 'second'.
var rem100 = number % 100;
if (rem100 < 10) {
if (rem100 % 10 === 1) {
return number + '֊ին';
}
}
return number + '֊րդ';
};
var localize = {
ordinalNumber: ordinalNumber,
era: (0, _index.default)({
values: eraValues,
defaultWidth: 'wide'
}),
quarter: (0, _index.default)({
values: quarterValues,
defaultWidth: 'wide',
argumentCallback: function argumentCallback(quarter) {
return quarter - 1;
}
}),
month: (0, _index.default)({
values: monthValues,
defaultWidth: 'wide'
}),
day: (0, _index.default)({
values: dayValues,
defaultWidth: 'wide'
}),
dayPeriod: (0, _index.default)({
values: dayPeriodValues,
defaultWidth: 'wide',
formattingValues: formattingDayPeriodValues,
defaultFormattingWidth: 'wide'
})
};
var _default = localize;
exports.default = _default;
module.exports = exports.default;