@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,739 +0,0 @@
|
|
|
1
|
-
import { useState, useEffect } from 'react';
|
|
2
|
-
import {
|
|
3
|
-
CheckCircleIcon,
|
|
4
|
-
ExclamationTriangleIcon,
|
|
5
|
-
XCircleIcon,
|
|
6
|
-
ClockIcon,
|
|
7
|
-
ArrowPathIcon,
|
|
8
|
-
ChartBarIcon,
|
|
9
|
-
ShieldCheckIcon,
|
|
10
|
-
BeakerIcon,
|
|
11
|
-
} from '../../../icons/heroicons';
|
|
12
|
-
import { CubeIcon } from '../../../icons/heroicons';
|
|
13
|
-
import { monorepoService } from '../../../services/monorepoService';
|
|
14
|
-
import { DASHBOARD_ERROR_MESSAGES } from '../../../constants/messages';
|
|
15
|
-
|
|
16
|
-
// interface HealthMetric {
|
|
17
|
-
// name: string;
|
|
18
|
-
// value: number;
|
|
19
|
-
// unit: string;
|
|
20
|
-
// status: 'healthy' | 'warning' | 'error';
|
|
21
|
-
// trend: 'up' | 'down' | 'stable';
|
|
22
|
-
// lastUpdated: string;
|
|
23
|
-
// }
|
|
24
|
-
|
|
25
|
-
// interface PackageHealth {
|
|
26
|
-
// name: string;
|
|
27
|
-
// overallScore: number;
|
|
28
|
-
// buildStatus: 'success' | 'failed' | 'building' | 'unknown';
|
|
29
|
-
// testCoverage: number;
|
|
30
|
-
// lintStatus: 'pass' | 'warn' | 'fail';
|
|
31
|
-
// securityAudit: 'pass' | 'warn' | 'fail';
|
|
32
|
-
// dependencies: 'up-to-date' | 'outdated' | 'vulnerable';
|
|
33
|
-
// lastBuild: string;
|
|
34
|
-
// lastTest: string;
|
|
35
|
-
// }
|
|
36
|
-
|
|
37
|
-
// const mockHealthMetrics: HealthMetric[] = [
|
|
38
|
-
// {
|
|
39
|
-
// name: 'Build Success Rate',
|
|
40
|
-
// value: 95,
|
|
41
|
-
// unit: '%',
|
|
42
|
-
// status: 'healthy',
|
|
43
|
-
// trend: 'up',
|
|
44
|
-
// lastUpdated: '2 hours ago',
|
|
45
|
-
// },
|
|
46
|
-
// {
|
|
47
|
-
// name: 'Test Coverage',
|
|
48
|
-
// value: 87,
|
|
49
|
-
// unit: '%',
|
|
50
|
-
// status: 'warning',
|
|
51
|
-
// trend: 'stable',
|
|
52
|
-
// lastUpdated: '1 hour ago',
|
|
53
|
-
// },
|
|
54
|
-
// {
|
|
55
|
-
// name: 'Lint Pass Rate',
|
|
56
|
-
// value: 98,
|
|
57
|
-
// unit: '%',
|
|
58
|
-
// status: 'healthy',
|
|
59
|
-
// trend: 'up',
|
|
60
|
-
// lastUpdated: '30 min ago',
|
|
61
|
-
// },
|
|
62
|
-
// {
|
|
63
|
-
// name: 'Security Score',
|
|
64
|
-
// value: 92,
|
|
65
|
-
// unit: '/100',
|
|
66
|
-
// status: 'healthy',
|
|
67
|
-
// trend: 'stable',
|
|
68
|
-
// lastUpdated: '1 hour ago',
|
|
69
|
-
// },
|
|
70
|
-
// {
|
|
71
|
-
// name: 'Dependency Health',
|
|
72
|
-
// value: 89,
|
|
73
|
-
// unit: '%',
|
|
74
|
-
// status: 'warning',
|
|
75
|
-
// trend: 'down',
|
|
76
|
-
// lastUpdated: '2 hours ago',
|
|
77
|
-
// },
|
|
78
|
-
// {
|
|
79
|
-
// name: 'Performance Score',
|
|
80
|
-
// value: 94,
|
|
81
|
-
// unit: '/100',
|
|
82
|
-
// status: 'healthy',
|
|
83
|
-
// trend: 'up',
|
|
84
|
-
// lastUpdated: '45 min ago',
|
|
85
|
-
// },
|
|
86
|
-
// ];
|
|
87
|
-
|
|
88
|
-
// const mockPackageHealth: PackageHealth[] = [
|
|
89
|
-
// {
|
|
90
|
-
// name: 'dashboard',
|
|
91
|
-
// overallScore: 95,
|
|
92
|
-
// buildStatus: 'success',
|
|
93
|
-
// testCoverage: 92,
|
|
94
|
-
// lintStatus: 'pass',
|
|
95
|
-
// securityAudit: 'pass',
|
|
96
|
-
// dependencies: 'up-to-date',
|
|
97
|
-
// lastBuild: '2 hours ago',
|
|
98
|
-
// lastTest: '1 hour ago',
|
|
99
|
-
// },
|
|
100
|
-
// {
|
|
101
|
-
// name: 'backend',
|
|
102
|
-
// overallScore: 88,
|
|
103
|
-
// buildStatus: 'success',
|
|
104
|
-
// testCoverage: 85,
|
|
105
|
-
// lintStatus: 'pass',
|
|
106
|
-
// securityAudit: 'pass',
|
|
107
|
-
// dependencies: 'outdated',
|
|
108
|
-
// lastBuild: '3 hours ago',
|
|
109
|
-
// lastTest: '2 hours ago',
|
|
110
|
-
// },
|
|
111
|
-
// {
|
|
112
|
-
// name: 'utils',
|
|
113
|
-
// overallScore: 78,
|
|
114
|
-
// buildStatus: 'success',
|
|
115
|
-
// testCoverage: 75,
|
|
116
|
-
// lintStatus: 'warn',
|
|
117
|
-
// securityAudit: 'pass',
|
|
118
|
-
// dependencies: 'vulnerable',
|
|
119
|
-
// lastBuild: '1 day ago',
|
|
120
|
-
// lastTest: '1 day ago',
|
|
121
|
-
// },
|
|
122
|
-
// {
|
|
123
|
-
// name: 'ci-status',
|
|
124
|
-
// overallScore: 92,
|
|
125
|
-
// buildStatus: 'success',
|
|
126
|
-
// testCoverage: 88,
|
|
127
|
-
// lintStatus: 'pass',
|
|
128
|
-
// securityAudit: 'pass',
|
|
129
|
-
// dependencies: 'up-to-date',
|
|
130
|
-
// lastBuild: '4 hours ago',
|
|
131
|
-
// lastTest: '3 hours ago',
|
|
132
|
-
// },
|
|
133
|
-
// {
|
|
134
|
-
// name: 'monorepo-scanner',
|
|
135
|
-
// overallScore: 65,
|
|
136
|
-
// buildStatus: 'failed',
|
|
137
|
-
// testCoverage: 60,
|
|
138
|
-
// lintStatus: 'fail',
|
|
139
|
-
// securityAudit: 'warn',
|
|
140
|
-
// dependencies: 'outdated',
|
|
141
|
-
// lastBuild: '2 days ago',
|
|
142
|
-
// lastTest: '2 days ago',
|
|
143
|
-
// },
|
|
144
|
-
// ];
|
|
145
|
-
interface HealthData {
|
|
146
|
-
packages: Array<{
|
|
147
|
-
packageName: string;
|
|
148
|
-
health: {
|
|
149
|
-
buildStatus: string;
|
|
150
|
-
testCoverage: number;
|
|
151
|
-
lintStatus: string;
|
|
152
|
-
securityAudit: string;
|
|
153
|
-
overallScore: number;
|
|
154
|
-
};
|
|
155
|
-
isHealthy: boolean;
|
|
156
|
-
}>;
|
|
157
|
-
summary: {
|
|
158
|
-
total: number;
|
|
159
|
-
healthy: number;
|
|
160
|
-
unhealthy: number;
|
|
161
|
-
averageScore: number;
|
|
162
|
-
};
|
|
163
|
-
}
|
|
164
|
-
|
|
165
|
-
export default function HealthStatus() {
|
|
166
|
-
// const [selectedMetric, setSelectedMetric] = useState<string>('all');
|
|
167
|
-
const [refreshKey, setRefreshKey] = useState(0);
|
|
168
|
-
const [healthData, setHealthData] = useState<HealthData | null>(null);
|
|
169
|
-
const [loading, setLoading] = useState(true);
|
|
170
|
-
const [error, setError] = useState<string | null>(null);
|
|
171
|
-
const [refreshing, setRefreshing] = useState(false);
|
|
172
|
-
|
|
173
|
-
useEffect(() => {
|
|
174
|
-
const fetchHealthData = async () => {
|
|
175
|
-
try {
|
|
176
|
-
setLoading(true);
|
|
177
|
-
const data = await monorepoService.getHealthStatus();
|
|
178
|
-
// console.log('Health data from inside useEffect:', data);
|
|
179
|
-
setHealthData(data);
|
|
180
|
-
setError(null);
|
|
181
|
-
} catch (err) {
|
|
182
|
-
setError(DASHBOARD_ERROR_MESSAGES.UNKNOWN_ERROR);
|
|
183
|
-
console.error('Error fetching health data:', err);
|
|
184
|
-
} finally {
|
|
185
|
-
setLoading(false);
|
|
186
|
-
}
|
|
187
|
-
};
|
|
188
|
-
|
|
189
|
-
fetchHealthData();
|
|
190
|
-
}, [refreshKey]);
|
|
191
|
-
// console.log('Health data from outside of useEffect:', healthData);
|
|
192
|
-
|
|
193
|
-
const refreshData = async () => {
|
|
194
|
-
try {
|
|
195
|
-
setRefreshing(true);
|
|
196
|
-
setError(null);
|
|
197
|
-
setLoading(true);
|
|
198
|
-
try {
|
|
199
|
-
const data = await monorepoService.refreshHealthStatus();
|
|
200
|
-
// console.log('Health data:', data);
|
|
201
|
-
setHealthData(data);
|
|
202
|
-
setError(null);
|
|
203
|
-
} catch (err) {
|
|
204
|
-
setError(DASHBOARD_ERROR_MESSAGES.UNKNOWN_ERROR);
|
|
205
|
-
console.error('Error fetching health data:', err);
|
|
206
|
-
} finally {
|
|
207
|
-
setLoading(false);
|
|
208
|
-
}
|
|
209
|
-
|
|
210
|
-
// // Call the refresh API endpoint
|
|
211
|
-
// const response = await fetch('/api/health/refresh', {
|
|
212
|
-
// method: 'POST',
|
|
213
|
-
// headers: {
|
|
214
|
-
// 'Content-Type': 'application/json',
|
|
215
|
-
// },
|
|
216
|
-
// });
|
|
217
|
-
|
|
218
|
-
// if (!response.ok) {
|
|
219
|
-
// throw new Error('Refresh failed');
|
|
220
|
-
// }
|
|
221
|
-
|
|
222
|
-
// // Refresh the health data after successful refresh
|
|
223
|
-
// const data = await monorepoService.getHealthStatus();
|
|
224
|
-
// setHealthData(data);
|
|
225
|
-
} catch (err) {
|
|
226
|
-
setError(DASHBOARD_ERROR_MESSAGES.UNKNOWN_ERROR);
|
|
227
|
-
console.error('Error refreshing health data:', err);
|
|
228
|
-
} finally {
|
|
229
|
-
setRefreshing(false);
|
|
230
|
-
}
|
|
231
|
-
};
|
|
232
|
-
|
|
233
|
-
const retryFetchData = () => {
|
|
234
|
-
setRefreshKey(prev => prev + 1);
|
|
235
|
-
};
|
|
236
|
-
|
|
237
|
-
// const refreshData = () => {
|
|
238
|
-
// setRefreshKey(prev => prev + 1);
|
|
239
|
-
// setHealthData(null);
|
|
240
|
-
// };
|
|
241
|
-
|
|
242
|
-
// Get status color and icon
|
|
243
|
-
const getStatusColor = (status: string) => {
|
|
244
|
-
switch (status) {
|
|
245
|
-
case 'healthy':
|
|
246
|
-
case 'success':
|
|
247
|
-
case 'pass':
|
|
248
|
-
case 'up-to-date':
|
|
249
|
-
return 'bg-green-100 text-green-800';
|
|
250
|
-
case 'warning':
|
|
251
|
-
case 'warn':
|
|
252
|
-
case 'outdated':
|
|
253
|
-
return 'bg-yellow-100 text-yellow-800';
|
|
254
|
-
case 'error':
|
|
255
|
-
case 'failed':
|
|
256
|
-
case 'fail':
|
|
257
|
-
case 'vulnerable':
|
|
258
|
-
return 'bg-red-100 text-red-800';
|
|
259
|
-
default:
|
|
260
|
-
return 'bg-gray-100 text-gray-800';
|
|
261
|
-
}
|
|
262
|
-
};
|
|
263
|
-
|
|
264
|
-
const getStatusIcon = (status: string) => {
|
|
265
|
-
switch (status) {
|
|
266
|
-
case 'healthy':
|
|
267
|
-
case 'success':
|
|
268
|
-
case 'pass':
|
|
269
|
-
case 'up-to-date':
|
|
270
|
-
return <CheckCircleIcon className="h-5 w-5 text-green-500" />;
|
|
271
|
-
case 'warning':
|
|
272
|
-
case 'warn':
|
|
273
|
-
case 'outdated':
|
|
274
|
-
return <ExclamationTriangleIcon className="h-5 w-5 text-yellow-500" />;
|
|
275
|
-
case 'error':
|
|
276
|
-
case 'failed':
|
|
277
|
-
case 'fail':
|
|
278
|
-
case 'vulnerable':
|
|
279
|
-
return <XCircleIcon className="h-5 w-5 text-red-500" />;
|
|
280
|
-
default:
|
|
281
|
-
return <ClockIcon className="h-5 w-5 text-gray-500" />;
|
|
282
|
-
}
|
|
283
|
-
};
|
|
284
|
-
|
|
285
|
-
const getTrendIcon = (trend: string) => {
|
|
286
|
-
switch (trend) {
|
|
287
|
-
case 'up':
|
|
288
|
-
return (
|
|
289
|
-
<ArrowPathIcon className="h-4 w-4 text-green-500 transform rotate-90" />
|
|
290
|
-
);
|
|
291
|
-
case 'down':
|
|
292
|
-
return (
|
|
293
|
-
<ArrowPathIcon className="h-4 w-4 text-red-500 transform -rotate-90" />
|
|
294
|
-
);
|
|
295
|
-
default:
|
|
296
|
-
return <ArrowPathIcon className="h-4 w-4 text-gray-500" />;
|
|
297
|
-
}
|
|
298
|
-
};
|
|
299
|
-
|
|
300
|
-
const getBuildStatusIcon = (status: string) => {
|
|
301
|
-
switch (status) {
|
|
302
|
-
case 'success':
|
|
303
|
-
return <CheckCircleIcon className="h-5 w-5 text-green-500" />;
|
|
304
|
-
case 'failed':
|
|
305
|
-
return <XCircleIcon className="h-5 w-5 text-red-500" />;
|
|
306
|
-
case 'building':
|
|
307
|
-
return (
|
|
308
|
-
<div className="h-5 w-5 animate-spin rounded-full border-2 border-blue-500 border-t-transparent" />
|
|
309
|
-
);
|
|
310
|
-
default:
|
|
311
|
-
return <ClockIcon className="h-5 w-5 text-gray-500" />;
|
|
312
|
-
}
|
|
313
|
-
};
|
|
314
|
-
|
|
315
|
-
// Calculate overall health
|
|
316
|
-
if (loading && !healthData) {
|
|
317
|
-
return (
|
|
318
|
-
<div className="flex items-center justify-center h-64">
|
|
319
|
-
<div className="text-center">
|
|
320
|
-
<div className="animate-spin rounded-full h-12 w-12 border-b-2 border-blue-600 mx-auto"></div>
|
|
321
|
-
<p className="mt-4 text-gray-600">Loading health data...</p>
|
|
322
|
-
</div>
|
|
323
|
-
</div>
|
|
324
|
-
);
|
|
325
|
-
}
|
|
326
|
-
|
|
327
|
-
if (error) {
|
|
328
|
-
return (
|
|
329
|
-
<div className="flex items-center justify-center h-64">
|
|
330
|
-
<div className="text-center">
|
|
331
|
-
<ExclamationTriangleIcon className="w-12 h-12 text-red-500 mx-auto" />
|
|
332
|
-
<p className="mt-4 text-red-600">{error}</p>
|
|
333
|
-
<button
|
|
334
|
-
onClick={retryFetchData}
|
|
335
|
-
className="mt-4 bg-blue-600 text-white px-4 py-2 rounded-lg hover:bg-blue-700 transition-colors"
|
|
336
|
-
>
|
|
337
|
-
Retry
|
|
338
|
-
</button>
|
|
339
|
-
</div>
|
|
340
|
-
</div>
|
|
341
|
-
);
|
|
342
|
-
}
|
|
343
|
-
|
|
344
|
-
const overallHealth = healthData ? healthData.summary?.averageScore : 0;
|
|
345
|
-
const healthyPackages = healthData
|
|
346
|
-
? healthData?.packages?.filter(pkg => pkg.health.overallScore >= 80).length
|
|
347
|
-
: 0;
|
|
348
|
-
const warningPackages = healthData
|
|
349
|
-
? healthData?.packages?.filter(
|
|
350
|
-
pkg => pkg.health.overallScore >= 60 && pkg.health.overallScore < 80
|
|
351
|
-
).length
|
|
352
|
-
: 0;
|
|
353
|
-
const errorPackages = healthData
|
|
354
|
-
? healthData?.packages?.filter(pkg => pkg.health.overallScore < 60).length
|
|
355
|
-
: 0;
|
|
356
|
-
|
|
357
|
-
const packagesHealth = [
|
|
358
|
-
{
|
|
359
|
-
name: 'Package Health',
|
|
360
|
-
value: healthyPackages || 0,
|
|
361
|
-
status: (() => {
|
|
362
|
-
const healthy = healthyPackages || 0;
|
|
363
|
-
const total = healthData?.packages.length || 0;
|
|
364
|
-
if (total === 0) return 'healthy';
|
|
365
|
-
const ratio = healthy / total;
|
|
366
|
-
if (ratio >= 0.8) return 'healthy';
|
|
367
|
-
if (ratio >= 0.6) return 'warning';
|
|
368
|
-
return 'error';
|
|
369
|
-
})(),
|
|
370
|
-
description: `${healthyPackages || 0} healthy packages out of ${healthData?.packages.length || 0}`,
|
|
371
|
-
},
|
|
372
|
-
{
|
|
373
|
-
name: 'Overall Score',
|
|
374
|
-
value: Math.round(overallHealth),
|
|
375
|
-
status:
|
|
376
|
-
Math.round(overallHealth) >= 80
|
|
377
|
-
? 'healthy'
|
|
378
|
-
: Math.round(overallHealth) >= 60
|
|
379
|
-
? 'warning'
|
|
380
|
-
: 'error',
|
|
381
|
-
description: `Average health score: ${Math.round(overallHealth)}/100`,
|
|
382
|
-
},
|
|
383
|
-
{
|
|
384
|
-
name: 'Unhealthy Packages',
|
|
385
|
-
value: warningPackages + errorPackages || 0,
|
|
386
|
-
status:
|
|
387
|
-
(warningPackages + errorPackages || 0) === 0
|
|
388
|
-
? 'healthy'
|
|
389
|
-
: (warningPackages + errorPackages || 0) <= 2
|
|
390
|
-
? 'warning'
|
|
391
|
-
: 'error',
|
|
392
|
-
description: `${warningPackages + errorPackages || 0} packages need attention`,
|
|
393
|
-
},
|
|
394
|
-
];
|
|
395
|
-
|
|
396
|
-
return (
|
|
397
|
-
<div className="">
|
|
398
|
-
{/* Header */}
|
|
399
|
-
|
|
400
|
-
<div className="flex items-center justify-between my-3">
|
|
401
|
-
<div>
|
|
402
|
-
<h1 className="text-2xl font-bold text-gray-900">Health Status</h1>
|
|
403
|
-
<p className="text-gray-600 mt-1">
|
|
404
|
-
Monitor the health and performance of your monorepo packages
|
|
405
|
-
</p>
|
|
406
|
-
</div>
|
|
407
|
-
<button
|
|
408
|
-
onClick={refreshData}
|
|
409
|
-
disabled={refreshing}
|
|
410
|
-
className="bg-blue-600 text-white px-4 py-2 rounded-lg hover:bg-blue-700 disabled:bg-blue-400 disabled:cursor-not-allowed flex items-center space-x-2 transition-colors"
|
|
411
|
-
>
|
|
412
|
-
{refreshing ? (
|
|
413
|
-
<div className="animate-spin rounded-full h-4 w-4 border-b-2 border-white" />
|
|
414
|
-
) : (
|
|
415
|
-
<ArrowPathIcon className="w-5 h-5" />
|
|
416
|
-
)}
|
|
417
|
-
<span>{refreshing ? 'Refreshing...' : 'Refresh'}</span>
|
|
418
|
-
</button>
|
|
419
|
-
</div>
|
|
420
|
-
|
|
421
|
-
{/* Show refreshing overlay when refreshing with existing data */}
|
|
422
|
-
{refreshing && healthData && (
|
|
423
|
-
<div className="fixed inset-0 bg-black bg-opacity-70 flex items-center justify-center z-50">
|
|
424
|
-
<div className="bg-white p-6 rounded-lg shadow-lg text-center">
|
|
425
|
-
<div className="animate-spin rounded-full h-12 w-12 border-b-2 border-blue-600 mx-auto"></div>
|
|
426
|
-
<p className="mt-4 text-gray-700">Refreshing health data...</p>
|
|
427
|
-
</div>
|
|
428
|
-
</div>
|
|
429
|
-
)}
|
|
430
|
-
|
|
431
|
-
{/* Overall Health Score */}
|
|
432
|
-
<div className="my-3 bg-gradient-to-r from-blue-500 to-purple-600 rounded-lg p-6 text-white">
|
|
433
|
-
<div className="flex items-center justify-between">
|
|
434
|
-
<div>
|
|
435
|
-
<h2 className="text-xl font-semibold">Overall Monorepo Health</h2>
|
|
436
|
-
<p className="text-blue-100 mt-1">
|
|
437
|
-
Based on all package metrics and recent activity
|
|
438
|
-
</p>
|
|
439
|
-
</div>
|
|
440
|
-
<div className="text-right">
|
|
441
|
-
<div className="text-4xl font-bold">
|
|
442
|
-
{overallHealth?.toFixed(2)}
|
|
443
|
-
</div>
|
|
444
|
-
<div className="text-blue-100">out of 100</div>
|
|
445
|
-
</div>
|
|
446
|
-
</div>
|
|
447
|
-
<div className="mt-4 flex space-x-4">
|
|
448
|
-
<div className="flex items-center space-x-2">
|
|
449
|
-
<CheckCircleIcon className="w-5 h-5 text-green-300" />
|
|
450
|
-
<span>{healthyPackages} Healthy</span>
|
|
451
|
-
</div>
|
|
452
|
-
<div className="flex items-center space-x-2">
|
|
453
|
-
<ExclamationTriangleIcon className="w-5 h-5 text-yellow-300" />
|
|
454
|
-
<span>{warningPackages} Warnings</span>
|
|
455
|
-
</div>
|
|
456
|
-
<div className="flex items-center space-x-2">
|
|
457
|
-
<XCircleIcon className="w-5 h-5 text-red-300" />
|
|
458
|
-
<span>{errorPackages} Errors</span>
|
|
459
|
-
</div>
|
|
460
|
-
</div>
|
|
461
|
-
</div>
|
|
462
|
-
|
|
463
|
-
{/* Health Metrics Grid */}
|
|
464
|
-
<div className="my-3 grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-6">
|
|
465
|
-
{packagesHealth.map(metric => (
|
|
466
|
-
<div
|
|
467
|
-
key={metric.name}
|
|
468
|
-
className="bg-white p-6 rounded-lg shadow border"
|
|
469
|
-
>
|
|
470
|
-
<div className="flex items-center justify-between mb-4">
|
|
471
|
-
<h3 className="text-lg font-medium text-gray-900">
|
|
472
|
-
{metric.name}
|
|
473
|
-
</h3>
|
|
474
|
-
<div
|
|
475
|
-
className={`w-3 h-3 rounded-full ${
|
|
476
|
-
metric.status === 'healthy'
|
|
477
|
-
? 'bg-green-500'
|
|
478
|
-
: metric.status === 'warning'
|
|
479
|
-
? 'bg-yellow-500'
|
|
480
|
-
: 'bg-red-500'
|
|
481
|
-
}`}
|
|
482
|
-
/>
|
|
483
|
-
</div>
|
|
484
|
-
<div className="flex items-end space-x-2">
|
|
485
|
-
<span className="text-3xl font-bold text-gray-900">
|
|
486
|
-
{metric.value}
|
|
487
|
-
</span>
|
|
488
|
-
</div>
|
|
489
|
-
<div className="mt-4 flex items-center justify-between">
|
|
490
|
-
<span
|
|
491
|
-
className={`inline-flex px-2 py-1 text-xs font-semibold rounded-full ${getStatusColor(metric.status)}`}
|
|
492
|
-
>
|
|
493
|
-
{metric.status}
|
|
494
|
-
</span>
|
|
495
|
-
<span className="text-sm text-gray-500">
|
|
496
|
-
{metric.description}
|
|
497
|
-
</span>
|
|
498
|
-
</div>
|
|
499
|
-
</div>
|
|
500
|
-
))}
|
|
501
|
-
</div>
|
|
502
|
-
|
|
503
|
-
{/* Package Health Table */}
|
|
504
|
-
<div className="my-3 bg-white rounded-lg shadow border overflow-hidden">
|
|
505
|
-
<div className="px-6 py-4 border-b border-gray-200">
|
|
506
|
-
<h3 className="text-lg font-medium text-gray-900">
|
|
507
|
-
Package Health Details
|
|
508
|
-
</h3>
|
|
509
|
-
</div>
|
|
510
|
-
|
|
511
|
-
<div className="overflow-x-auto">
|
|
512
|
-
<table className="min-w-full divide-y divide-gray-200">
|
|
513
|
-
<thead className="bg-gray-50">
|
|
514
|
-
<tr>
|
|
515
|
-
<th className="px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider">
|
|
516
|
-
Package
|
|
517
|
-
</th>
|
|
518
|
-
<th className="px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider">
|
|
519
|
-
Overall Score
|
|
520
|
-
</th>
|
|
521
|
-
<th className="px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider">
|
|
522
|
-
Build Status
|
|
523
|
-
</th>
|
|
524
|
-
<th className="hidden px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider">
|
|
525
|
-
Test Coverage
|
|
526
|
-
</th>
|
|
527
|
-
<th className="px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider">
|
|
528
|
-
Lint Status
|
|
529
|
-
</th>
|
|
530
|
-
<th className="px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider">
|
|
531
|
-
Security
|
|
532
|
-
</th>
|
|
533
|
-
<th className="px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider">
|
|
534
|
-
Dependencies
|
|
535
|
-
</th>
|
|
536
|
-
<th className="hidden px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider">
|
|
537
|
-
Actions
|
|
538
|
-
</th>
|
|
539
|
-
</tr>
|
|
540
|
-
</thead>
|
|
541
|
-
<tbody className="bg-white divide-y divide-gray-200">
|
|
542
|
-
{healthData?.packages?.map(pkg => (
|
|
543
|
-
<tr key={pkg.packageName} className="hover:bg-gray-50">
|
|
544
|
-
{/* package name */}
|
|
545
|
-
<td className="px-6 py-4 whitespace-nowrap">
|
|
546
|
-
<div className="flex items-center">
|
|
547
|
-
<div className="h-8 w-8 rounded-lg bg-gray-100 flex items-center justify-center">
|
|
548
|
-
<div className="text-sm"><CubeIcon className="w-6 h-6 text-primary-600" /></div>
|
|
549
|
-
</div>
|
|
550
|
-
<div className="ml-3">
|
|
551
|
-
<div className="text-sm font-medium text-gray-900">
|
|
552
|
-
{pkg.packageName}
|
|
553
|
-
</div>
|
|
554
|
-
<div className="text-sm text-gray-500">
|
|
555
|
-
Score: {pkg.health.overallScore}/100
|
|
556
|
-
</div>
|
|
557
|
-
</div>
|
|
558
|
-
</div>
|
|
559
|
-
</td>
|
|
560
|
-
|
|
561
|
-
{/* overall score */}
|
|
562
|
-
<td className="px-6 py-4 whitespace-nowrap">
|
|
563
|
-
<div className="flex items-center">
|
|
564
|
-
<div className="w-16 bg-gray-200 rounded-full h-2 mr-2">
|
|
565
|
-
<div
|
|
566
|
-
className={`h-2 rounded-full ${
|
|
567
|
-
pkg.health.overallScore >= 80
|
|
568
|
-
? 'bg-green-500'
|
|
569
|
-
: pkg.health.overallScore >= 60
|
|
570
|
-
? 'bg-yellow-500'
|
|
571
|
-
: 'bg-red-500'
|
|
572
|
-
}`}
|
|
573
|
-
style={{ width: `${pkg.health.overallScore}%` }}
|
|
574
|
-
/>
|
|
575
|
-
</div>
|
|
576
|
-
<span className="text-sm font-medium text-gray-900">
|
|
577
|
-
{pkg.health.overallScore}
|
|
578
|
-
</span>
|
|
579
|
-
</div>
|
|
580
|
-
</td>
|
|
581
|
-
|
|
582
|
-
{/* build status */}
|
|
583
|
-
<td className="px-6 py-4 whitespace-nowrap">
|
|
584
|
-
<div className="flex items-center">
|
|
585
|
-
<div
|
|
586
|
-
className={`w-3 h-3 rounded-full ${
|
|
587
|
-
pkg.health.buildStatus === 'success'
|
|
588
|
-
? 'bg-green-500'
|
|
589
|
-
: pkg.health.buildStatus === 'unknown'
|
|
590
|
-
? 'bg-yellow-500'
|
|
591
|
-
: 'bg-red-500'
|
|
592
|
-
}`}
|
|
593
|
-
/>
|
|
594
|
-
<span
|
|
595
|
-
className={`ml-2 inline-flex px-2 py-1 text-xs font-semibold rounded-full ${getStatusColor(
|
|
596
|
-
pkg.health.buildStatus === 'success'
|
|
597
|
-
? 'healthy'
|
|
598
|
-
: pkg.health.buildStatus === 'unknown'
|
|
599
|
-
? 'warning'
|
|
600
|
-
: 'error'
|
|
601
|
-
)}`}
|
|
602
|
-
>
|
|
603
|
-
{pkg.health.buildStatus === 'success'
|
|
604
|
-
? 'healthy'
|
|
605
|
-
: pkg.health.buildStatus === 'unknown'
|
|
606
|
-
? 'warning'
|
|
607
|
-
: 'error'}
|
|
608
|
-
</span>
|
|
609
|
-
</div>
|
|
610
|
-
</td>
|
|
611
|
-
|
|
612
|
-
{/* test coverage */}
|
|
613
|
-
<td className="hidden px-6 py-4 whitespace-nowrap">
|
|
614
|
-
<div className="flex items-center">
|
|
615
|
-
<BeakerIcon className="w-4 h-4 text-gray-400 mr-1" />
|
|
616
|
-
<span className="text-sm text-gray-900">-</span>
|
|
617
|
-
</div>
|
|
618
|
-
</td>
|
|
619
|
-
|
|
620
|
-
{/* lint status */}
|
|
621
|
-
<td className="px-6 py-4 whitespace-nowrap">
|
|
622
|
-
<span
|
|
623
|
-
className={`inline-flex px-2 py-1 text-xs font-semibold rounded-full ${getStatusColor(
|
|
624
|
-
pkg.health.lintStatus === 'pass'
|
|
625
|
-
? 'pass'
|
|
626
|
-
: pkg.health.lintStatus === 'unknown'
|
|
627
|
-
? 'warn'
|
|
628
|
-
: 'fail'
|
|
629
|
-
)}`}
|
|
630
|
-
>
|
|
631
|
-
{pkg.health.lintStatus === 'pass'
|
|
632
|
-
? 'pass'
|
|
633
|
-
: pkg.health.lintStatus === 'unknown'
|
|
634
|
-
? 'warn'
|
|
635
|
-
: 'fail'}
|
|
636
|
-
</span>
|
|
637
|
-
</td>
|
|
638
|
-
|
|
639
|
-
{/* security */}
|
|
640
|
-
<td className="px-6 py-4 whitespace-nowrap">
|
|
641
|
-
<div className="flex items-center">
|
|
642
|
-
{/* <ShieldCheckIcon className="w-4 h-4 text-gray-400 mr-1" /> */}
|
|
643
|
-
<span
|
|
644
|
-
className={`inline-flex px-2 py-1 text-xs font-semibold rounded-full ${getStatusColor(
|
|
645
|
-
pkg.health.securityAudit === 'pass'
|
|
646
|
-
? 'pass'
|
|
647
|
-
: pkg.health.securityAudit === 'unknown'
|
|
648
|
-
? 'warn'
|
|
649
|
-
: 'fail'
|
|
650
|
-
)}`}
|
|
651
|
-
>
|
|
652
|
-
{pkg.health.securityAudit === 'pass'
|
|
653
|
-
? 'pass'
|
|
654
|
-
: pkg.health.securityAudit === 'unknown'
|
|
655
|
-
? 'warn'
|
|
656
|
-
: 'fail'}
|
|
657
|
-
</span>
|
|
658
|
-
</div>
|
|
659
|
-
</td>
|
|
660
|
-
|
|
661
|
-
{/* dependencies */}
|
|
662
|
-
<td className="px-6 py-4 whitespace-nowrap">
|
|
663
|
-
<span
|
|
664
|
-
className={`inline-flex px-2 py-1 text-xs font-semibold rounded-full ${getStatusColor(
|
|
665
|
-
pkg.health.overallScore >= 80
|
|
666
|
-
? 'up-to-date'
|
|
667
|
-
: pkg.health.overallScore >= 60
|
|
668
|
-
? 'outdated'
|
|
669
|
-
: 'vulnerable'
|
|
670
|
-
)}`}
|
|
671
|
-
>
|
|
672
|
-
{pkg.health.overallScore >= 80
|
|
673
|
-
? 'up-to-date'
|
|
674
|
-
: pkg.health.overallScore >= 60
|
|
675
|
-
? 'outdated'
|
|
676
|
-
: 'vulnerable'}
|
|
677
|
-
</span>
|
|
678
|
-
</td>
|
|
679
|
-
|
|
680
|
-
{/* actions */}
|
|
681
|
-
<td className="hidden px-6 py-4 whitespace-nowrap text-sm font-medium">
|
|
682
|
-
<div className="flex space-x-2">
|
|
683
|
-
<button className="text-blue-600 hover:text-blue-900">
|
|
684
|
-
Details
|
|
685
|
-
</button>
|
|
686
|
-
</div>
|
|
687
|
-
</td>
|
|
688
|
-
</tr>
|
|
689
|
-
))}
|
|
690
|
-
</tbody>
|
|
691
|
-
</table>
|
|
692
|
-
</div>
|
|
693
|
-
</div>
|
|
694
|
-
|
|
695
|
-
{/* Health Recommendations */}
|
|
696
|
-
<div className="hidden bg-white rounded-lg shadow border p-6">
|
|
697
|
-
<h3 className="text-lg font-medium text-gray-900 mb-4">
|
|
698
|
-
Health Recommendations
|
|
699
|
-
</h3>
|
|
700
|
-
<div className="space-y-3">
|
|
701
|
-
<div className="flex items-start space-x-3 p-3 bg-yellow-50 rounded-lg border border-yellow-200">
|
|
702
|
-
<ExclamationTriangleIcon className="w-5 h-5 text-yellow-600 mt-0.5" />
|
|
703
|
-
<div>
|
|
704
|
-
<p className="text-sm font-medium text-yellow-800">
|
|
705
|
-
Test Coverage Below Target
|
|
706
|
-
</p>
|
|
707
|
-
<p className="text-sm text-yellow-700">
|
|
708
|
-
Consider adding more tests to improve coverage above 90%
|
|
709
|
-
</p>
|
|
710
|
-
</div>
|
|
711
|
-
</div>
|
|
712
|
-
<div className="flex items-start space-x-3 p-3 bg-red-50 rounded-lg border border-red-200">
|
|
713
|
-
<XCircleIcon className="w-5 h-5 text-red-600 mt-0.5" />
|
|
714
|
-
<div>
|
|
715
|
-
<p className="text-sm font-medium text-red-800">
|
|
716
|
-
Build Failures Detected
|
|
717
|
-
</p>
|
|
718
|
-
<p className="text-sm text-red-700">
|
|
719
|
-
monorepo-scanner package has build failures that need immediate
|
|
720
|
-
attention
|
|
721
|
-
</p>
|
|
722
|
-
</div>
|
|
723
|
-
</div>
|
|
724
|
-
<div className="flex items-start space-x-3 p-3 bg-blue-50 rounded-lg border border-blue-200">
|
|
725
|
-
<ChartBarIcon className="w-5 h-5 text-blue-600 mt-0.5" />
|
|
726
|
-
<div>
|
|
727
|
-
<p className="text-sm font-medium text-blue-800">
|
|
728
|
-
Performance Improvements Available
|
|
729
|
-
</p>
|
|
730
|
-
<p className="text-sm text-blue-700">
|
|
731
|
-
Consider optimizing build times and dependency resolution
|
|
732
|
-
</p>
|
|
733
|
-
</div>
|
|
734
|
-
</div>
|
|
735
|
-
</div>
|
|
736
|
-
</div>
|
|
737
|
-
</div>
|
|
738
|
-
);
|
|
739
|
-
}
|