@manojkmfsi/monodog 1.1.37 → 1.1.39
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +12 -0
- package/monodog-dashboard/dist/assets/index-C08ciT3A.js +20 -0
- package/monodog-dashboard/dist/assets/index-C08ciT3A.js.map +1 -0
- package/monodog-dashboard/dist/assets/index-Dc2vaUOq.css +1 -0
- package/monodog-dashboard/{index.html → dist/index.html} +2 -1
- package/monodog-dashboard/package.json +0 -3
- package/package.json +2 -2
- package/monodog-dashboard/THEME_SYSTEM.md +0 -309
- package/monodog-dashboard/__tests__/AuthCallbackPage.test.ts +0 -138
- package/monodog-dashboard/__tests__/ConfigInspector.test.ts +0 -33
- package/monodog-dashboard/__tests__/DependencyGraph.test.ts +0 -72
- package/monodog-dashboard/__tests__/HealthStatus.test.ts +0 -69
- package/monodog-dashboard/__tests__/LoginPage.test.ts +0 -79
- package/monodog-dashboard/__tests__/PackageDetail.test.ts +0 -22
- package/monodog-dashboard/__tests__/ReleaseManager.test.tsx +0 -510
- package/monodog-dashboard/__tests__/api-client.test.ts +0 -475
- package/monodog-dashboard/__tests__/components.test.ts +0 -117
- package/monodog-dashboard/__tests__/dashboard.utils.test.ts +0 -144
- package/monodog-dashboard/__tests__/dependency.utils.test.ts +0 -125
- package/monodog-dashboard/__tests__/monorepoService.unit.test.ts +0 -103
- package/monodog-dashboard/__tests__/packages.utils.test.ts +0 -37
- package/monodog-dashboard/__tests__/pages.test.ts +0 -103
- package/monodog-dashboard/package-lock.json +0 -4587
- package/monodog-dashboard/postcss.config.js +0 -6
- package/monodog-dashboard/src/components/App.tsx +0 -36
- package/monodog-dashboard/src/components/LoadingState.tsx +0 -18
- package/monodog-dashboard/src/components/PermissionGuard.tsx +0 -92
- package/monodog-dashboard/src/components/ProtectedRoute.tsx +0 -24
- package/monodog-dashboard/src/components/configuration/Configuration.tsx +0 -91
- package/monodog-dashboard/src/components/configuration/components/BrandingSettings.tsx +0 -128
- package/monodog-dashboard/src/components/configuration/components/ConfigurationHeader.tsx +0 -34
- package/monodog-dashboard/src/components/configuration/components/ConfigurationModal.tsx +0 -20
- package/monodog-dashboard/src/components/configuration/components/ConfigurationTabs.tsx +0 -30
- package/monodog-dashboard/src/components/configuration/components/FeatureToggles.tsx +0 -66
- package/monodog-dashboard/src/components/configuration/components/GeneralSettings.tsx +0 -77
- package/monodog-dashboard/src/components/configuration/components/MonorepoSettings.tsx +0 -179
- package/monodog-dashboard/src/components/configuration/components/index.ts +0 -8
- package/monodog-dashboard/src/components/configuration/types/config.types.ts +0 -52
- package/monodog-dashboard/src/components/configuration/utils/config.utils.tsx +0 -115
- package/monodog-dashboard/src/components/main-dashboard/Dashboard.tsx +0 -242
- package/monodog-dashboard/src/components/main-dashboard/Layout.tsx +0 -112
- package/monodog-dashboard/src/components/main-dashboard/components/Header.tsx +0 -47
- package/monodog-dashboard/src/components/main-dashboard/components/PackageDistribution.tsx +0 -35
- package/monodog-dashboard/src/components/main-dashboard/components/PackageSearchFilter.tsx +0 -47
- package/monodog-dashboard/src/components/main-dashboard/components/PackageTable.tsx +0 -87
- package/monodog-dashboard/src/components/main-dashboard/components/QuickActions.tsx +0 -60
- package/monodog-dashboard/src/components/main-dashboard/components/StatsCards.tsx +0 -73
- package/monodog-dashboard/src/components/main-dashboard/components/index.ts +0 -7
- package/monodog-dashboard/src/components/main-dashboard/types/dashboard.types.ts +0 -33
- package/monodog-dashboard/src/components/main-dashboard/utils/dashboard.utils.tsx +0 -70
- package/monodog-dashboard/src/components/modules/ci-integration/CIIntegration.tsx +0 -277
- package/monodog-dashboard/src/components/modules/ci-integration/components/BuildDetails.tsx +0 -228
- package/monodog-dashboard/src/components/modules/ci-integration/components/BuildList.tsx +0 -212
- package/monodog-dashboard/src/components/modules/ci-integration/components/BuildOverview.tsx +0 -158
- package/monodog-dashboard/src/components/modules/ci-integration/components/CIIntegrationHeader.tsx +0 -38
- package/monodog-dashboard/src/components/modules/ci-integration/components/ErrorState.tsx +0 -25
- package/monodog-dashboard/src/components/modules/ci-integration/components/LoadingState.tsx +0 -16
- package/monodog-dashboard/src/components/modules/ci-integration/components/PipelineStatus.tsx +0 -223
- package/monodog-dashboard/src/components/modules/ci-integration/components/index.ts +0 -8
- package/monodog-dashboard/src/components/modules/ci-integration/types/ci.types.ts +0 -97
- package/monodog-dashboard/src/components/modules/ci-integration/utils/ci.utils.tsx +0 -264
- package/monodog-dashboard/src/components/modules/config-inspector/ConfigInspector.tsx +0 -324
- package/monodog-dashboard/src/components/modules/config-inspector/components/ConfigEditor.tsx +0 -93
- package/monodog-dashboard/src/components/modules/config-inspector/components/ConfigInspectorHeader.tsx +0 -36
- package/monodog-dashboard/src/components/modules/config-inspector/components/ConfigPreview.tsx +0 -89
- package/monodog-dashboard/src/components/modules/config-inspector/components/ConfigSidebar.tsx +0 -141
- package/monodog-dashboard/src/components/modules/config-inspector/components/ConfigToolbar.tsx +0 -184
- package/monodog-dashboard/src/components/modules/config-inspector/components/ErrorState.tsx +0 -25
- package/monodog-dashboard/src/components/modules/config-inspector/components/LoadingState.tsx +0 -16
- package/monodog-dashboard/src/components/modules/config-inspector/components/ValidationPanel.tsx +0 -155
- package/monodog-dashboard/src/components/modules/config-inspector/components/index.ts +0 -9
- package/monodog-dashboard/src/components/modules/config-inspector/types/config.types.ts +0 -100
- package/monodog-dashboard/src/components/modules/config-inspector/utils/config.utils.tsx +0 -704
- package/monodog-dashboard/src/components/modules/dependency-graph/DependencyGraph.tsx +0 -224
- package/monodog-dashboard/src/components/modules/dependency-graph/components/CircularDependencies.tsx +0 -177
- package/monodog-dashboard/src/components/modules/dependency-graph/components/DependencyDetails.tsx +0 -192
- package/monodog-dashboard/src/components/modules/dependency-graph/components/DependencyGraphHeader.tsx +0 -30
- package/monodog-dashboard/src/components/modules/dependency-graph/components/DependencyList.tsx +0 -177
- package/monodog-dashboard/src/components/modules/dependency-graph/components/ErrorState.tsx +0 -25
- package/monodog-dashboard/src/components/modules/dependency-graph/components/GraphLegend.tsx +0 -89
- package/monodog-dashboard/src/components/modules/dependency-graph/components/GraphStats.tsx +0 -141
- package/monodog-dashboard/src/components/modules/dependency-graph/components/GraphToolbar.tsx +0 -107
- package/monodog-dashboard/src/components/modules/dependency-graph/components/GraphVisualization.tsx +0 -179
- package/monodog-dashboard/src/components/modules/dependency-graph/components/LoadingState.tsx +0 -16
- package/monodog-dashboard/src/components/modules/dependency-graph/components/index.ts +0 -11
- package/monodog-dashboard/src/components/modules/dependency-graph/types/dependency.types.ts +0 -105
- package/monodog-dashboard/src/components/modules/dependency-graph/utils/dependency.utils.tsx +0 -433
- package/monodog-dashboard/src/components/modules/health-status/HealthStatus.tsx +0 -739
- package/monodog-dashboard/src/components/modules/health-status/components/ErrorState.tsx +0 -25
- package/monodog-dashboard/src/components/modules/health-status/components/HealthActions.tsx +0 -122
- package/monodog-dashboard/src/components/modules/health-status/components/HealthAlerts.tsx +0 -151
- package/monodog-dashboard/src/components/modules/health-status/components/HealthMetrics.tsx +0 -132
- package/monodog-dashboard/src/components/modules/health-status/components/HealthStatusHeader.tsx +0 -30
- package/monodog-dashboard/src/components/modules/health-status/components/LoadingState.tsx +0 -16
- package/monodog-dashboard/src/components/modules/health-status/components/OverallHealthScore.tsx +0 -122
- package/monodog-dashboard/src/components/modules/health-status/components/PackageHealthList.tsx +0 -195
- package/monodog-dashboard/src/components/modules/health-status/types/health.types.ts +0 -80
- package/monodog-dashboard/src/components/modules/health-status/utils/health.utils.tsx +0 -220
- package/monodog-dashboard/src/components/modules/packages/PackageDetail.tsx +0 -255
- package/monodog-dashboard/src/components/modules/packages/PackagesOverview.tsx +0 -166
- package/monodog-dashboard/src/components/modules/packages/components/ConfigurationTab.tsx +0 -311
- package/monodog-dashboard/src/components/modules/packages/components/DependenciesTab.tsx +0 -154
- package/monodog-dashboard/src/components/modules/packages/components/ErrorState.tsx +0 -21
- package/monodog-dashboard/src/components/modules/packages/components/HealthMetricsTab.tsx +0 -275
- package/monodog-dashboard/src/components/modules/packages/components/LoadingState.tsx +0 -14
- package/monodog-dashboard/src/components/modules/packages/components/PackageDetailHeader.tsx +0 -167
- package/monodog-dashboard/src/components/modules/packages/components/PackageDetailTabs.tsx +0 -49
- package/monodog-dashboard/src/components/modules/packages/components/PackageStats.tsx +0 -70
- package/monodog-dashboard/src/components/modules/packages/components/PackagesTable.tsx +0 -163
- package/monodog-dashboard/src/components/modules/packages/components/RecentCommitsTab.tsx +0 -90
- package/monodog-dashboard/src/components/modules/packages/components/SearchAndFilter.tsx +0 -66
- package/monodog-dashboard/src/components/modules/packages/components/index.ts +0 -12
- package/monodog-dashboard/src/components/modules/packages/types/packages.types.ts +0 -101
- package/monodog-dashboard/src/components/modules/packages/utils/packages.utils.tsx +0 -178
- package/monodog-dashboard/src/components/pipeline/JobsList.tsx +0 -83
- package/monodog-dashboard/src/components/pipeline/LogViewer.tsx +0 -392
- package/monodog-dashboard/src/components/pipeline/PipelineManager.tsx +0 -562
- package/monodog-dashboard/src/components/pipeline/WorkflowRunsList.tsx +0 -272
- package/monodog-dashboard/src/components/pipeline/WorkflowTrigger.tsx +0 -182
- package/monodog-dashboard/src/components/pipeline/utils/pipeline.utils.tsx +0 -11
- package/monodog-dashboard/src/components/publish-control/PublishControl.tsx +0 -229
- package/monodog-dashboard/src/components/publish-control/components/ChangelogViewer.tsx +0 -103
- package/monodog-dashboard/src/components/publish-control/components/ErrorState.tsx +0 -23
- package/monodog-dashboard/src/components/publish-control/components/LoadingState.tsx +0 -10
- package/monodog-dashboard/src/components/publish-control/components/PackageReleaseTable.tsx +0 -140
- package/monodog-dashboard/src/components/publish-control/components/PublishHeader.tsx +0 -30
- package/monodog-dashboard/src/components/publish-control/components/QuickActionCards.tsx +0 -56
- package/monodog-dashboard/src/components/publish-control/components/ReleaseSchedule.tsx +0 -104
- package/monodog-dashboard/src/components/publish-control/components/index.ts +0 -8
- package/monodog-dashboard/src/components/publish-control/types/publish.types.ts +0 -39
- package/monodog-dashboard/src/components/publish-control/utils/publish.utils.ts +0 -59
- package/monodog-dashboard/src/components/release-manager/ReleaseManager.tsx +0 -342
- package/monodog-dashboard/src/components/release-manager/components/ChangesetPreview.tsx +0 -123
- package/monodog-dashboard/src/components/release-manager/components/ErrorState.tsx +0 -38
- package/monodog-dashboard/src/components/release-manager/components/LoadingState.tsx +0 -18
- package/monodog-dashboard/src/components/release-manager/components/PackageSelector.tsx +0 -137
- package/monodog-dashboard/src/components/release-manager/components/PublishConfirmation.tsx +0 -150
- package/monodog-dashboard/src/components/release-manager/components/ReleaseValidation.tsx +0 -138
- package/monodog-dashboard/src/components/release-manager/components/VersionBumpSelector.tsx +0 -142
- package/monodog-dashboard/src/components/release-manager/types/index.ts +0 -9
- package/monodog-dashboard/src/components/release-manager/types/release-manager.types.ts +0 -29
- package/monodog-dashboard/src/components/setup-guide/SetupGuide.tsx +0 -96
- package/monodog-dashboard/src/components/setup-guide/components/SetupHeader.tsx +0 -24
- package/monodog-dashboard/src/components/setup-guide/components/SetupModal.tsx +0 -24
- package/monodog-dashboard/src/components/setup-guide/components/SetupProgress.tsx +0 -29
- package/monodog-dashboard/src/components/setup-guide/components/StepContent.tsx +0 -272
- package/monodog-dashboard/src/components/setup-guide/components/StepNavigation.tsx +0 -62
- package/monodog-dashboard/src/components/setup-guide/components/index.ts +0 -6
- package/monodog-dashboard/src/components/setup-guide/types/setup.types.ts +0 -38
- package/monodog-dashboard/src/components/setup-guide/utils/setup.utils.ts +0 -79
- package/monodog-dashboard/src/constants/api-config.ts +0 -81
- package/monodog-dashboard/src/constants/index.ts +0 -9
- package/monodog-dashboard/src/constants/messages.ts +0 -40
- package/monodog-dashboard/src/icons/heroicons.ts +0 -65
- package/monodog-dashboard/src/icons/index.tsx +0 -1788
- package/monodog-dashboard/src/index.css +0 -175
- package/monodog-dashboard/src/main.tsx +0 -9
- package/monodog-dashboard/src/pages/AuthCallbackPage.tsx +0 -103
- package/monodog-dashboard/src/pages/CIPage.tsx +0 -6
- package/monodog-dashboard/src/pages/ConfigPage.tsx +0 -6
- package/monodog-dashboard/src/pages/DashboardPage.tsx +0 -6
- package/monodog-dashboard/src/pages/DependenciesPage.tsx +0 -6
- package/monodog-dashboard/src/pages/HealthPage.tsx +0 -6
- package/monodog-dashboard/src/pages/LoginPage.tsx +0 -77
- package/monodog-dashboard/src/pages/PackageDetailPage.tsx +0 -6
- package/monodog-dashboard/src/pages/PackagesPage.tsx +0 -6
- package/monodog-dashboard/src/pages/PipelinePage.tsx +0 -22
- package/monodog-dashboard/src/pages/PublishPage.tsx +0 -6
- package/monodog-dashboard/src/pages/ReleaseManagerPage.tsx +0 -9
- package/monodog-dashboard/src/pages/index.ts +0 -28
- package/monodog-dashboard/src/routes/AppRouter.tsx +0 -89
- package/monodog-dashboard/src/routes/AppRouterPages.tsx +0 -56
- package/monodog-dashboard/src/routes/index.ts +0 -10
- package/monodog-dashboard/src/routes/routes.config.ts +0 -94
- package/monodog-dashboard/src/services/api/api-client.ts +0 -189
- package/monodog-dashboard/src/services/api/index.ts +0 -30
- package/monodog-dashboard/src/services/api/types/api.types.ts +0 -63
- package/monodog-dashboard/src/services/auth-context.tsx +0 -344
- package/monodog-dashboard/src/services/monorepoService.ts +0 -733
- package/monodog-dashboard/src/services/permission-context.tsx +0 -193
- package/monodog-dashboard/src/theme/COMPONENT_UPDATES.md +0 -273
- package/monodog-dashboard/src/theme/INTEGRATION.md +0 -381
- package/monodog-dashboard/src/theme/README.md +0 -239
- package/monodog-dashboard/src/theme/examples.tsx +0 -386
- package/monodog-dashboard/src/theme/index.ts +0 -402
- package/monodog-dashboard/src/theme/migration-guide.md +0 -335
- package/monodog-dashboard/src/types/auth-context.types.ts +0 -51
- package/monodog-dashboard/src/types/component.types.ts +0 -96
- package/monodog-dashboard/src/types/icons.types.ts +0 -13
- package/monodog-dashboard/src/types/index.ts +0 -68
- package/monodog-dashboard/src/types/monorepo-service.types.ts +0 -53
- package/monodog-dashboard/src/types/permission-context.types.ts +0 -49
- package/monodog-dashboard/src/types/pipeline.types.ts +0 -89
- package/monodog-dashboard/src/types/routes.types.ts +0 -12
- package/monodog-dashboard/src/utils/cookies.ts +0 -47
- package/monodog-dashboard/tailwind.config.js +0 -68
- package/monodog-dashboard/tsconfig.app.json +0 -14
- package/monodog-dashboard/tsconfig.json +0 -17
- package/monodog-dashboard/tsconfig.node.json +0 -10
- package/monodog-dashboard/vite.config.ts +0 -9
|
@@ -1,212 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
CheckCircleIcon,
|
|
3
|
-
XCircleIcon,
|
|
4
|
-
ClockIcon,
|
|
5
|
-
StopIcon,
|
|
6
|
-
FunnelIcon,
|
|
7
|
-
} from '../../../../icons/heroicons';
|
|
8
|
-
import { BuildListProps } from '../types/ci.types';
|
|
9
|
-
import {
|
|
10
|
-
getStatusColor,
|
|
11
|
-
formatDuration,
|
|
12
|
-
formatRelativeTime,
|
|
13
|
-
getBuildProgress,
|
|
14
|
-
getShortCommitHash,
|
|
15
|
-
getUniquePackages,
|
|
16
|
-
getUniqueStatuses,
|
|
17
|
-
} from '../utils/ci.utils';
|
|
18
|
-
|
|
19
|
-
export default function BuildList({
|
|
20
|
-
builds,
|
|
21
|
-
selectedBuild,
|
|
22
|
-
onBuildSelect,
|
|
23
|
-
filters,
|
|
24
|
-
onFiltersChange,
|
|
25
|
-
}: BuildListProps) {
|
|
26
|
-
const availablePackages = getUniquePackages(builds);
|
|
27
|
-
const availableStatuses = getUniqueStatuses(builds);
|
|
28
|
-
|
|
29
|
-
const getStatusIcon = (status: string) => {
|
|
30
|
-
switch (status) {
|
|
31
|
-
case 'success':
|
|
32
|
-
return <CheckCircleIcon className="h-5 w-5 text-green-500" />;
|
|
33
|
-
case 'running':
|
|
34
|
-
return (
|
|
35
|
-
<div className="h-5 w-5 animate-spin rounded-full border-2 border-blue-500 border-t-transparent" />
|
|
36
|
-
);
|
|
37
|
-
case 'pending':
|
|
38
|
-
return <ClockIcon className="h-5 w-5 text-yellow-500" />;
|
|
39
|
-
case 'failed':
|
|
40
|
-
return <XCircleIcon className="h-5 w-5 text-red-500" />;
|
|
41
|
-
case 'cancelled':
|
|
42
|
-
return <StopIcon className="h-5 w-5 text-red-500" />;
|
|
43
|
-
default:
|
|
44
|
-
return <ClockIcon className="h-5 w-5 text-gray-500" />;
|
|
45
|
-
}
|
|
46
|
-
};
|
|
47
|
-
|
|
48
|
-
return (
|
|
49
|
-
<div className="space-y-4">
|
|
50
|
-
{/* Filters */}
|
|
51
|
-
<div className="bg-white p-4 rounded-lg shadow border">
|
|
52
|
-
<div className="flex items-center space-x-4">
|
|
53
|
-
<div className="flex items-center space-x-2">
|
|
54
|
-
<FunnelIcon className="h-4 w-4 text-gray-400" />
|
|
55
|
-
<select
|
|
56
|
-
value={filters.package}
|
|
57
|
-
onChange={e =>
|
|
58
|
-
onFiltersChange({ ...filters, package: e.target.value })
|
|
59
|
-
}
|
|
60
|
-
className="border border-gray-300 rounded-md px-3 py-2 text-sm focus:ring-2 focus:ring-blue-500 focus:border-transparent"
|
|
61
|
-
>
|
|
62
|
-
<option value="all">All Packages</option>
|
|
63
|
-
{availablePackages.map(pkg => (
|
|
64
|
-
<option key={pkg} value={pkg}>
|
|
65
|
-
{pkg}
|
|
66
|
-
</option>
|
|
67
|
-
))}
|
|
68
|
-
</select>
|
|
69
|
-
</div>
|
|
70
|
-
|
|
71
|
-
<select
|
|
72
|
-
value={filters.status}
|
|
73
|
-
onChange={e =>
|
|
74
|
-
onFiltersChange({ ...filters, status: e.target.value })
|
|
75
|
-
}
|
|
76
|
-
className="border border-gray-300 rounded-md px-3 py-2 text-sm focus:ring-2 focus:ring-blue-500 focus:border-transparent"
|
|
77
|
-
>
|
|
78
|
-
<option value="all">All Statuses</option>
|
|
79
|
-
{availableStatuses.map(status => (
|
|
80
|
-
<option key={status} value={status}>
|
|
81
|
-
{status.charAt(0).toUpperCase() + status.slice(1)}
|
|
82
|
-
</option>
|
|
83
|
-
))}
|
|
84
|
-
</select>
|
|
85
|
-
|
|
86
|
-
<select
|
|
87
|
-
value={filters.dateRange}
|
|
88
|
-
onChange={e =>
|
|
89
|
-
onFiltersChange({ ...filters, dateRange: e.target.value })
|
|
90
|
-
}
|
|
91
|
-
className="border border-gray-300 rounded-md px-3 py-2 text-sm focus:ring-2 focus:ring-blue-500 focus:border-transparent"
|
|
92
|
-
>
|
|
93
|
-
<option value="all">All Time</option>
|
|
94
|
-
<option value="today">Today</option>
|
|
95
|
-
<option value="week">This Week</option>
|
|
96
|
-
<option value="month">This Month</option>
|
|
97
|
-
</select>
|
|
98
|
-
</div>
|
|
99
|
-
</div>
|
|
100
|
-
|
|
101
|
-
{/* Build List */}
|
|
102
|
-
<div className="bg-white rounded-lg shadow border">
|
|
103
|
-
<div className="p-4 border-b border-gray-200">
|
|
104
|
-
<h3 className="text-lg font-medium text-gray-900">Recent Builds</h3>
|
|
105
|
-
<p className="text-sm text-gray-500 mt-1">
|
|
106
|
-
{builds.length} build{builds.length !== 1 ? 's' : ''} found
|
|
107
|
-
</p>
|
|
108
|
-
</div>
|
|
109
|
-
|
|
110
|
-
{builds.length === 0 ? (
|
|
111
|
-
<div className="p-8 text-center">
|
|
112
|
-
<div className="text-gray-400 text-4xl mb-2">🔨</div>
|
|
113
|
-
<p className="text-gray-500">
|
|
114
|
-
No builds found matching your filters
|
|
115
|
-
</p>
|
|
116
|
-
</div>
|
|
117
|
-
) : (
|
|
118
|
-
<div className="divide-y divide-gray-200">
|
|
119
|
-
{builds.map(build => {
|
|
120
|
-
const progress = getBuildProgress(build);
|
|
121
|
-
const isSelected = selectedBuild === build.id;
|
|
122
|
-
|
|
123
|
-
return (
|
|
124
|
-
<div
|
|
125
|
-
key={build.id}
|
|
126
|
-
className={`p-4 cursor-pointer transition-colors ${
|
|
127
|
-
isSelected
|
|
128
|
-
? 'bg-blue-50 border-l-4 border-blue-500'
|
|
129
|
-
: 'hover:bg-gray-50'
|
|
130
|
-
}`}
|
|
131
|
-
onClick={() => onBuildSelect(isSelected ? null : build.id)}
|
|
132
|
-
>
|
|
133
|
-
<div className="flex items-center justify-between">
|
|
134
|
-
<div className="flex items-center space-x-4">
|
|
135
|
-
{getStatusIcon(build.status)}
|
|
136
|
-
<div>
|
|
137
|
-
<div className="flex items-center space-x-2">
|
|
138
|
-
<h4 className="text-sm font-medium text-gray-900">
|
|
139
|
-
{build.packageName}
|
|
140
|
-
</h4>
|
|
141
|
-
<span className="inline-flex items-center px-2 py-0.5 rounded text-xs font-medium bg-gray-100 text-gray-800">
|
|
142
|
-
{build.branch}
|
|
143
|
-
</span>
|
|
144
|
-
<span className="text-xs text-gray-500 font-mono">
|
|
145
|
-
{getShortCommitHash(build.commit)}
|
|
146
|
-
</span>
|
|
147
|
-
</div>
|
|
148
|
-
<div className="flex items-center space-x-2 mt-1">
|
|
149
|
-
<span
|
|
150
|
-
className={`inline-flex px-2 py-1 text-xs font-semibold rounded-full ${getStatusColor(build.status)}`}
|
|
151
|
-
>
|
|
152
|
-
{build.status}
|
|
153
|
-
</span>
|
|
154
|
-
<span className="text-xs text-gray-500">
|
|
155
|
-
by {build.triggeredBy}
|
|
156
|
-
</span>
|
|
157
|
-
<span className="text-xs text-gray-500">
|
|
158
|
-
{formatRelativeTime(build.startTime)}
|
|
159
|
-
</span>
|
|
160
|
-
</div>
|
|
161
|
-
</div>
|
|
162
|
-
</div>
|
|
163
|
-
|
|
164
|
-
<div className="text-right">
|
|
165
|
-
{build.duration && (
|
|
166
|
-
<div className="text-sm font-medium text-gray-900">
|
|
167
|
-
{formatDuration(build.duration)}
|
|
168
|
-
</div>
|
|
169
|
-
)}
|
|
170
|
-
{build.status === 'running' && (
|
|
171
|
-
<div className="mt-1">
|
|
172
|
-
<div className="flex items-center space-x-2">
|
|
173
|
-
<div className="w-20 bg-gray-200 rounded-full h-2">
|
|
174
|
-
<div
|
|
175
|
-
className="bg-blue-500 h-2 rounded-full transition-all duration-300"
|
|
176
|
-
style={{ width: `${progress}%` }}
|
|
177
|
-
/>
|
|
178
|
-
</div>
|
|
179
|
-
<span className="text-xs text-gray-500">
|
|
180
|
-
{progress}%
|
|
181
|
-
</span>
|
|
182
|
-
</div>
|
|
183
|
-
</div>
|
|
184
|
-
)}
|
|
185
|
-
</div>
|
|
186
|
-
</div>
|
|
187
|
-
|
|
188
|
-
{/* Build Stages Preview */}
|
|
189
|
-
{isSelected && build.stages.length > 0 && (
|
|
190
|
-
<div className="mt-4 pt-4 border-t border-gray-100">
|
|
191
|
-
<div className="flex items-center space-x-2">
|
|
192
|
-
{build.stages.map((stage, index) => (
|
|
193
|
-
<div
|
|
194
|
-
key={stage.name}
|
|
195
|
-
className={`flex items-center px-2 py-1 text-xs rounded ${getStatusColor(stage.status)}`}
|
|
196
|
-
title={`${stage.name}: ${stage.status}`}
|
|
197
|
-
>
|
|
198
|
-
{stage.name}
|
|
199
|
-
</div>
|
|
200
|
-
))}
|
|
201
|
-
</div>
|
|
202
|
-
</div>
|
|
203
|
-
)}
|
|
204
|
-
</div>
|
|
205
|
-
);
|
|
206
|
-
})}
|
|
207
|
-
</div>
|
|
208
|
-
)}
|
|
209
|
-
</div>
|
|
210
|
-
</div>
|
|
211
|
-
);
|
|
212
|
-
}
|
package/monodog-dashboard/src/components/modules/ci-integration/components/BuildOverview.tsx
DELETED
|
@@ -1,158 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
CheckCircleIcon,
|
|
3
|
-
XCircleIcon,
|
|
4
|
-
ClockIcon,
|
|
5
|
-
ArrowPathIcon,
|
|
6
|
-
ChartBarIcon,
|
|
7
|
-
} from '../../../../icons/heroicons';
|
|
8
|
-
import { BuildOverviewProps } from '../types/ci.types';
|
|
9
|
-
import { formatDuration } from '../utils/ci.utils';
|
|
10
|
-
|
|
11
|
-
export default function BuildOverview({
|
|
12
|
-
stats,
|
|
13
|
-
onRefresh,
|
|
14
|
-
loading = false,
|
|
15
|
-
}: BuildOverviewProps) {
|
|
16
|
-
return (
|
|
17
|
-
<div className="space-y-6">
|
|
18
|
-
{/* Header */}
|
|
19
|
-
<div className="flex items-center justify-between">
|
|
20
|
-
<h2 className="text-heading text-lg">Build Statistics</h2>
|
|
21
|
-
<button onClick={onRefresh} disabled={loading} className="btn-ghost">
|
|
22
|
-
<ArrowPathIcon
|
|
23
|
-
className={`w-4 h-4 mr-2 ${loading ? 'animate-spin' : ''}`}
|
|
24
|
-
/>
|
|
25
|
-
Refresh
|
|
26
|
-
</button>
|
|
27
|
-
</div>
|
|
28
|
-
|
|
29
|
-
{/* Stats Grid */}
|
|
30
|
-
<div className="grid grid-cols-1 md:grid-cols-5 gap-4">
|
|
31
|
-
{/* Total Builds */}
|
|
32
|
-
<div className="card p-4">
|
|
33
|
-
<div className="flex items-center">
|
|
34
|
-
<div className="p-2 bg-primary-100 rounded-lg">
|
|
35
|
-
<ChartBarIcon className="w-6 h-6 text-primary-600" />
|
|
36
|
-
</div>
|
|
37
|
-
<div className="ml-4">
|
|
38
|
-
<p className="text-caption font-medium">Total Builds</p>
|
|
39
|
-
<p className="text-heading text-2xl">{stats.total}</p>
|
|
40
|
-
</div>
|
|
41
|
-
</div>
|
|
42
|
-
</div>
|
|
43
|
-
|
|
44
|
-
{/* Successful Builds */}
|
|
45
|
-
<div className="card p-4">
|
|
46
|
-
<div className="flex items-center">
|
|
47
|
-
<div className="p-2 bg-success-100 rounded-lg">
|
|
48
|
-
<CheckCircleIcon className="w-6 h-6 text-success-600" />
|
|
49
|
-
</div>
|
|
50
|
-
<div className="ml-4">
|
|
51
|
-
<p className="text-caption font-medium">Successful</p>
|
|
52
|
-
<p className="text-heading text-2xl text-success-600">
|
|
53
|
-
{stats.successful}
|
|
54
|
-
</p>
|
|
55
|
-
</div>
|
|
56
|
-
</div>
|
|
57
|
-
</div>
|
|
58
|
-
|
|
59
|
-
{/* Failed Builds */}
|
|
60
|
-
<div className="card p-4">
|
|
61
|
-
<div className="flex items-center">
|
|
62
|
-
<div className="p-2 bg-error-100 rounded-lg">
|
|
63
|
-
<XCircleIcon className="w-6 h-6 text-error-600" />
|
|
64
|
-
</div>
|
|
65
|
-
<div className="ml-4">
|
|
66
|
-
<p className="text-caption font-medium">Failed</p>
|
|
67
|
-
<p className="text-heading text-2xl text-error-600">
|
|
68
|
-
{stats.failed}
|
|
69
|
-
</p>
|
|
70
|
-
</div>
|
|
71
|
-
</div>
|
|
72
|
-
</div>
|
|
73
|
-
|
|
74
|
-
{/* Running Builds */}
|
|
75
|
-
<div className="card p-4">
|
|
76
|
-
<div className="flex items-center">
|
|
77
|
-
<div className="p-2 bg-info-100 rounded-lg">
|
|
78
|
-
<ClockIcon className="w-6 h-6 text-info-600" />
|
|
79
|
-
</div>
|
|
80
|
-
<div className="ml-4">
|
|
81
|
-
<p className="text-caption font-medium">Running</p>
|
|
82
|
-
<p className="text-heading text-2xl text-info-600">
|
|
83
|
-
{stats.running}
|
|
84
|
-
</p>
|
|
85
|
-
</div>
|
|
86
|
-
</div>
|
|
87
|
-
</div>
|
|
88
|
-
|
|
89
|
-
{/* Success Rate */}
|
|
90
|
-
<div className="card p-4">
|
|
91
|
-
<div className="flex items-center justify-between mb-2">
|
|
92
|
-
<p className="text-caption font-medium">Success Rate</p>
|
|
93
|
-
<span
|
|
94
|
-
className={`text-lg font-bold ${
|
|
95
|
-
stats.successRate >= 90
|
|
96
|
-
? 'text-success-600'
|
|
97
|
-
: stats.successRate >= 70
|
|
98
|
-
? 'text-warning-600'
|
|
99
|
-
: 'text-error-600'
|
|
100
|
-
}`}
|
|
101
|
-
>
|
|
102
|
-
{stats.successRate}%
|
|
103
|
-
</span>
|
|
104
|
-
</div>
|
|
105
|
-
<div className="w-full bg-neutral-200 rounded-full h-2">
|
|
106
|
-
<div
|
|
107
|
-
className={`h-2 rounded-full transition-all duration-300 ${
|
|
108
|
-
stats.successRate >= 90
|
|
109
|
-
? 'bg-success-500'
|
|
110
|
-
: stats.successRate >= 70
|
|
111
|
-
? 'bg-warning-500'
|
|
112
|
-
: 'bg-error-500'
|
|
113
|
-
}`}
|
|
114
|
-
style={{ width: `${stats.successRate}%` }}
|
|
115
|
-
/>
|
|
116
|
-
</div>
|
|
117
|
-
</div>
|
|
118
|
-
</div>
|
|
119
|
-
|
|
120
|
-
{/* Additional Metrics */}
|
|
121
|
-
<div className="card p-6">
|
|
122
|
-
<h3 className="text-heading text-lg mb-4">Performance Metrics</h3>
|
|
123
|
-
<div className="grid grid-cols-2 md:grid-cols-4 gap-4">
|
|
124
|
-
<div className="text-center">
|
|
125
|
-
<div className="text-heading text-2xl text-primary-600">
|
|
126
|
-
{formatDuration(stats.avgDuration)}
|
|
127
|
-
</div>
|
|
128
|
-
<div className="text-caption">Avg Duration</div>
|
|
129
|
-
</div>
|
|
130
|
-
<div className="text-center">
|
|
131
|
-
<div className="text-heading text-2xl text-success-600">
|
|
132
|
-
{stats.total > 0
|
|
133
|
-
? Math.round((stats.successful / stats.total) * 100)
|
|
134
|
-
: 0}
|
|
135
|
-
%
|
|
136
|
-
</div>
|
|
137
|
-
<div className="text-caption">Success Rate</div>
|
|
138
|
-
</div>
|
|
139
|
-
<div className="text-center">
|
|
140
|
-
<div className="text-heading text-2xl text-error-600">
|
|
141
|
-
{stats.total > 0
|
|
142
|
-
? Math.round((stats.failed / stats.total) * 100)
|
|
143
|
-
: 0}
|
|
144
|
-
%
|
|
145
|
-
</div>
|
|
146
|
-
<div className="text-caption">Failure Rate</div>
|
|
147
|
-
</div>
|
|
148
|
-
<div className="text-center">
|
|
149
|
-
<div className="text-heading text-2xl text-accent-600">
|
|
150
|
-
{stats.running}
|
|
151
|
-
</div>
|
|
152
|
-
<div className="text-caption">Active Builds</div>
|
|
153
|
-
</div>
|
|
154
|
-
</div>
|
|
155
|
-
</div>
|
|
156
|
-
</div>
|
|
157
|
-
);
|
|
158
|
-
}
|
package/monodog-dashboard/src/components/modules/ci-integration/components/CIIntegrationHeader.tsx
DELETED
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
import { PlayIcon, CpuChipIcon } from '../../../../icons/heroicons';
|
|
2
|
-
|
|
3
|
-
interface CIIntegrationHeaderProps {
|
|
4
|
-
onTriggerBuild: () => void;
|
|
5
|
-
onCreatePipeline: () => void;
|
|
6
|
-
}
|
|
7
|
-
|
|
8
|
-
export default function CIIntegrationHeader({
|
|
9
|
-
onTriggerBuild,
|
|
10
|
-
onCreatePipeline,
|
|
11
|
-
}: CIIntegrationHeaderProps) {
|
|
12
|
-
return (
|
|
13
|
-
<div className="flex items-center justify-between">
|
|
14
|
-
<div>
|
|
15
|
-
<h1 className="text-heading text-2xl">CI/CD Integration</h1>
|
|
16
|
-
<p className="text-body mt-1">
|
|
17
|
-
Monitor and manage continuous integration and deployment pipelines
|
|
18
|
-
</p>
|
|
19
|
-
</div>
|
|
20
|
-
<div className="flex space-x-2">
|
|
21
|
-
<button
|
|
22
|
-
onClick={onTriggerBuild}
|
|
23
|
-
className="btn-secondary flex items-center space-x-2"
|
|
24
|
-
>
|
|
25
|
-
<PlayIcon className="w-5 h-5" />
|
|
26
|
-
<span>Trigger Build</span>
|
|
27
|
-
</button>
|
|
28
|
-
<button
|
|
29
|
-
onClick={onCreatePipeline}
|
|
30
|
-
className="btn-primary flex items-center space-x-2"
|
|
31
|
-
>
|
|
32
|
-
<CpuChipIcon className="w-5 h-5" />
|
|
33
|
-
<span>New Pipeline</span>
|
|
34
|
-
</button>
|
|
35
|
-
</div>
|
|
36
|
-
</div>
|
|
37
|
-
);
|
|
38
|
-
}
|
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
import { ExclamationTriangleIcon } from '../../../../icons/heroicons';
|
|
2
|
-
|
|
3
|
-
interface ErrorStateProps {
|
|
4
|
-
error: string;
|
|
5
|
-
onRetry?: () => void;
|
|
6
|
-
}
|
|
7
|
-
|
|
8
|
-
export default function ErrorState({ error, onRetry }: ErrorStateProps) {
|
|
9
|
-
return (
|
|
10
|
-
<div className="flex items-center justify-center h-64">
|
|
11
|
-
<div className="text-center">
|
|
12
|
-
<ExclamationTriangleIcon className="w-12 h-12 text-red-500 mx-auto" />
|
|
13
|
-
<p className="mt-4 text-red-600">{error}</p>
|
|
14
|
-
{onRetry && (
|
|
15
|
-
<button
|
|
16
|
-
onClick={onRetry}
|
|
17
|
-
className="mt-4 bg-blue-600 text-white px-4 py-2 rounded-lg hover:bg-blue-700 transition-colors"
|
|
18
|
-
>
|
|
19
|
-
Retry
|
|
20
|
-
</button>
|
|
21
|
-
)}
|
|
22
|
-
</div>
|
|
23
|
-
</div>
|
|
24
|
-
);
|
|
25
|
-
}
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
interface LoadingStateProps {
|
|
2
|
-
message?: string;
|
|
3
|
-
}
|
|
4
|
-
|
|
5
|
-
export default function LoadingState({
|
|
6
|
-
message = 'Loading CI/CD data...',
|
|
7
|
-
}: LoadingStateProps) {
|
|
8
|
-
return (
|
|
9
|
-
<div className="flex items-center justify-center h-64">
|
|
10
|
-
<div className="text-center">
|
|
11
|
-
<div className="animate-spin rounded-full h-12 w-12 border-b-2 border-blue-600 mx-auto"></div>
|
|
12
|
-
<p className="mt-4 text-gray-600">{message}</p>
|
|
13
|
-
</div>
|
|
14
|
-
</div>
|
|
15
|
-
);
|
|
16
|
-
}
|
package/monodog-dashboard/src/components/modules/ci-integration/components/PipelineStatus.tsx
DELETED
|
@@ -1,223 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
PlayIcon,
|
|
3
|
-
PauseIcon,
|
|
4
|
-
Cog6ToothIcon,
|
|
5
|
-
CheckCircleIcon,
|
|
6
|
-
ExclamationTriangleIcon,
|
|
7
|
-
XCircleIcon,
|
|
8
|
-
} from '../../../../icons/heroicons';
|
|
9
|
-
import { PipelineStatusProps } from '../types/ci.types';
|
|
10
|
-
import {
|
|
11
|
-
getStatusColor,
|
|
12
|
-
formatDuration,
|
|
13
|
-
formatRelativeTime,
|
|
14
|
-
getPipelineHealth,
|
|
15
|
-
} from '../utils/ci.utils';
|
|
16
|
-
|
|
17
|
-
export default function PipelineStatus({
|
|
18
|
-
pipelines,
|
|
19
|
-
onPipelineSelect,
|
|
20
|
-
onPipelineToggle,
|
|
21
|
-
}: PipelineStatusProps) {
|
|
22
|
-
const getHealthIcon = (health: string) => {
|
|
23
|
-
switch (health) {
|
|
24
|
-
case 'healthy':
|
|
25
|
-
return <CheckCircleIcon className="w-5 h-5 text-green-500" />;
|
|
26
|
-
case 'warning':
|
|
27
|
-
return <ExclamationTriangleIcon className="w-5 h-5 text-yellow-500" />;
|
|
28
|
-
case 'critical':
|
|
29
|
-
return <XCircleIcon className="w-5 h-5 text-red-500" />;
|
|
30
|
-
default:
|
|
31
|
-
return <Cog6ToothIcon className="w-5 h-5 text-gray-500" />;
|
|
32
|
-
}
|
|
33
|
-
};
|
|
34
|
-
|
|
35
|
-
const getHealthColor = (health: string) => {
|
|
36
|
-
switch (health) {
|
|
37
|
-
case 'healthy':
|
|
38
|
-
return 'bg-green-100 text-green-800';
|
|
39
|
-
case 'warning':
|
|
40
|
-
return 'bg-yellow-100 text-yellow-800';
|
|
41
|
-
case 'critical':
|
|
42
|
-
return 'bg-red-100 text-red-800';
|
|
43
|
-
default:
|
|
44
|
-
return 'bg-gray-100 text-gray-800';
|
|
45
|
-
}
|
|
46
|
-
};
|
|
47
|
-
|
|
48
|
-
if (pipelines.length === 0) {
|
|
49
|
-
return (
|
|
50
|
-
<div className="bg-white rounded-lg shadow border p-6">
|
|
51
|
-
<div className="text-center">
|
|
52
|
-
<Cog6ToothIcon className="w-12 h-12 text-gray-400 mx-auto mb-4" />
|
|
53
|
-
<h3 className="text-lg font-medium text-gray-900 mb-2">
|
|
54
|
-
No Pipelines Configured
|
|
55
|
-
</h3>
|
|
56
|
-
<p className="text-gray-600 mb-4">
|
|
57
|
-
Get started by creating your first CI/CD pipeline to automate builds
|
|
58
|
-
and deployments.
|
|
59
|
-
</p>
|
|
60
|
-
<button className="bg-blue-600 text-white px-4 py-2 rounded-lg hover:bg-blue-700 transition-colors">
|
|
61
|
-
Create Pipeline
|
|
62
|
-
</button>
|
|
63
|
-
</div>
|
|
64
|
-
</div>
|
|
65
|
-
);
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
return (
|
|
69
|
-
<div className="bg-white rounded-lg shadow border">
|
|
70
|
-
<div className="p-4 border-b border-gray-200">
|
|
71
|
-
<h3 className="text-lg font-medium text-gray-900">Pipeline Status</h3>
|
|
72
|
-
<p className="text-sm text-gray-500 mt-1">
|
|
73
|
-
{pipelines.length} pipeline{pipelines.length !== 1 ? 's' : ''}{' '}
|
|
74
|
-
configured
|
|
75
|
-
</p>
|
|
76
|
-
</div>
|
|
77
|
-
|
|
78
|
-
<div className="divide-y divide-gray-200">
|
|
79
|
-
{pipelines.map(pipeline => {
|
|
80
|
-
const health = getPipelineHealth(pipeline);
|
|
81
|
-
|
|
82
|
-
return (
|
|
83
|
-
<div
|
|
84
|
-
key={pipeline.id}
|
|
85
|
-
className="p-4 hover:bg-gray-50 transition-colors cursor-pointer"
|
|
86
|
-
onClick={() => onPipelineSelect(pipeline.id)}
|
|
87
|
-
>
|
|
88
|
-
<div className="flex items-center justify-between">
|
|
89
|
-
<div className="flex items-center space-x-4">
|
|
90
|
-
{getHealthIcon(health)}
|
|
91
|
-
<div>
|
|
92
|
-
<div className="flex items-center space-x-2">
|
|
93
|
-
<h4 className="text-sm font-medium text-gray-900">
|
|
94
|
-
{pipeline.name}
|
|
95
|
-
</h4>
|
|
96
|
-
<span className="inline-flex items-center px-2 py-0.5 rounded text-xs font-medium bg-gray-100 text-gray-800">
|
|
97
|
-
{pipeline.packageName}
|
|
98
|
-
</span>
|
|
99
|
-
</div>
|
|
100
|
-
<div className="flex items-center space-x-4 mt-1">
|
|
101
|
-
<span
|
|
102
|
-
className={`inline-flex px-2 py-1 text-xs font-semibold rounded-full ${getStatusColor(pipeline.status)}`}
|
|
103
|
-
>
|
|
104
|
-
{pipeline.status}
|
|
105
|
-
</span>
|
|
106
|
-
<span
|
|
107
|
-
className={`inline-flex px-2 py-1 text-xs font-semibold rounded-full ${getHealthColor(health)}`}
|
|
108
|
-
>
|
|
109
|
-
{health}
|
|
110
|
-
</span>
|
|
111
|
-
</div>
|
|
112
|
-
</div>
|
|
113
|
-
</div>
|
|
114
|
-
|
|
115
|
-
<div className="flex items-center space-x-4">
|
|
116
|
-
{/* Pipeline Toggle */}
|
|
117
|
-
<button
|
|
118
|
-
onClick={e => {
|
|
119
|
-
e.stopPropagation();
|
|
120
|
-
onPipelineToggle(
|
|
121
|
-
pipeline.id,
|
|
122
|
-
pipeline.status !== 'active'
|
|
123
|
-
);
|
|
124
|
-
}}
|
|
125
|
-
className={`p-2 rounded-lg transition-colors ${
|
|
126
|
-
pipeline.status === 'active'
|
|
127
|
-
? 'text-green-600 hover:bg-green-100'
|
|
128
|
-
: 'text-gray-400 hover:bg-gray-100'
|
|
129
|
-
}`}
|
|
130
|
-
title={
|
|
131
|
-
pipeline.status === 'active'
|
|
132
|
-
? 'Pause Pipeline'
|
|
133
|
-
: 'Activate Pipeline'
|
|
134
|
-
}
|
|
135
|
-
>
|
|
136
|
-
{pipeline.status === 'active' ? (
|
|
137
|
-
<PauseIcon className="w-5 h-5" />
|
|
138
|
-
) : (
|
|
139
|
-
<PlayIcon className="w-5 h-5" />
|
|
140
|
-
)}
|
|
141
|
-
</button>
|
|
142
|
-
</div>
|
|
143
|
-
</div>
|
|
144
|
-
|
|
145
|
-
{/* Pipeline Metrics */}
|
|
146
|
-
<div className="mt-3 grid grid-cols-4 gap-4 text-xs">
|
|
147
|
-
<div>
|
|
148
|
-
<span className="text-gray-500">Success Rate:</span>
|
|
149
|
-
<div
|
|
150
|
-
className={`font-medium ${
|
|
151
|
-
pipeline.successRate >= 90
|
|
152
|
-
? 'text-green-600'
|
|
153
|
-
: pipeline.successRate >= 70
|
|
154
|
-
? 'text-yellow-600'
|
|
155
|
-
: 'text-red-600'
|
|
156
|
-
}`}
|
|
157
|
-
>
|
|
158
|
-
{pipeline.successRate}%
|
|
159
|
-
</div>
|
|
160
|
-
</div>
|
|
161
|
-
<div>
|
|
162
|
-
<span className="text-gray-500">Avg Duration:</span>
|
|
163
|
-
<div className="font-medium text-gray-900">
|
|
164
|
-
{formatDuration(pipeline.avgDuration)}
|
|
165
|
-
</div>
|
|
166
|
-
</div>
|
|
167
|
-
<div>
|
|
168
|
-
<span className="text-gray-500">Last Run:</span>
|
|
169
|
-
<div className="font-medium text-gray-900">
|
|
170
|
-
{formatRelativeTime(pipeline.lastRun)}
|
|
171
|
-
</div>
|
|
172
|
-
</div>
|
|
173
|
-
<div>
|
|
174
|
-
<span className="text-gray-500">Triggers:</span>
|
|
175
|
-
<div className="font-medium text-gray-900">
|
|
176
|
-
{pipeline.triggers.length}
|
|
177
|
-
</div>
|
|
178
|
-
</div>
|
|
179
|
-
</div>
|
|
180
|
-
|
|
181
|
-
{/* Success Rate Progress Bar */}
|
|
182
|
-
<div className="mt-3">
|
|
183
|
-
<div className="flex items-center justify-between text-xs mb-1">
|
|
184
|
-
<span className="text-gray-500">Pipeline Health</span>
|
|
185
|
-
<span className="font-medium text-gray-900">
|
|
186
|
-
{pipeline.successRate}%
|
|
187
|
-
</span>
|
|
188
|
-
</div>
|
|
189
|
-
<div className="w-full bg-gray-200 rounded-full h-2">
|
|
190
|
-
<div
|
|
191
|
-
className={`h-2 rounded-full transition-all duration-300 ${
|
|
192
|
-
pipeline.successRate >= 90
|
|
193
|
-
? 'bg-green-500'
|
|
194
|
-
: pipeline.successRate >= 70
|
|
195
|
-
? 'bg-yellow-500'
|
|
196
|
-
: 'bg-red-500'
|
|
197
|
-
}`}
|
|
198
|
-
style={{ width: `${pipeline.successRate}%` }}
|
|
199
|
-
/>
|
|
200
|
-
</div>
|
|
201
|
-
</div>
|
|
202
|
-
|
|
203
|
-
{/* Triggers */}
|
|
204
|
-
<div className="mt-3">
|
|
205
|
-
<div className="flex items-center space-x-1">
|
|
206
|
-
<span className="text-xs text-gray-500">Triggers:</span>
|
|
207
|
-
{pipeline.triggers.map(trigger => (
|
|
208
|
-
<span
|
|
209
|
-
key={trigger}
|
|
210
|
-
className="inline-flex items-center px-2 py-0.5 rounded text-xs font-medium bg-blue-100 text-blue-800"
|
|
211
|
-
>
|
|
212
|
-
{trigger}
|
|
213
|
-
</span>
|
|
214
|
-
))}
|
|
215
|
-
</div>
|
|
216
|
-
</div>
|
|
217
|
-
</div>
|
|
218
|
-
);
|
|
219
|
-
})}
|
|
220
|
-
</div>
|
|
221
|
-
</div>
|
|
222
|
-
);
|
|
223
|
-
}
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
// Export all CI integration components for easier imports
|
|
2
|
-
export { default as LoadingState } from './LoadingState';
|
|
3
|
-
export { default as ErrorState } from './ErrorState';
|
|
4
|
-
export { default as CIIntegrationHeader } from './CIIntegrationHeader';
|
|
5
|
-
export { default as BuildOverview } from './BuildOverview';
|
|
6
|
-
export { default as BuildList } from './BuildList';
|
|
7
|
-
export { default as PipelineStatus } from './PipelineStatus';
|
|
8
|
-
export { default as BuildDetails } from './BuildDetails';
|