@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,275 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
CheckCircleIcon,
|
|
3
|
-
XCircleIcon,
|
|
4
|
-
ExclamationTriangleIcon,
|
|
5
|
-
} from '../../../../icons/heroicons';
|
|
6
|
-
import { PackageDetail } from '../types/packages.types';
|
|
7
|
-
|
|
8
|
-
interface HealthMetricsTabProps {
|
|
9
|
-
packageData: PackageDetail;
|
|
10
|
-
}
|
|
11
|
-
|
|
12
|
-
export default function HealthMetricsTab({
|
|
13
|
-
packageData,
|
|
14
|
-
}: HealthMetricsTabProps) {
|
|
15
|
-
const getHealthScoreColor = (score: number) => {
|
|
16
|
-
if (score >= 80) return 'text-green-600';
|
|
17
|
-
if (score >= 60) return 'text-yellow-600';
|
|
18
|
-
return 'text-red-600';
|
|
19
|
-
};
|
|
20
|
-
|
|
21
|
-
const getHealthScoreBg = (score: number) => {
|
|
22
|
-
if (score >= 80) return 'bg-green-100';
|
|
23
|
-
if (score >= 60) return 'bg-yellow-100';
|
|
24
|
-
return 'bg-red-100';
|
|
25
|
-
};
|
|
26
|
-
|
|
27
|
-
const getBuildStatusIcon = (status: string) => {
|
|
28
|
-
switch (status) {
|
|
29
|
-
case 'success':
|
|
30
|
-
return <CheckCircleIcon className="w-5 h-5 text-green-500" />;
|
|
31
|
-
case 'failed':
|
|
32
|
-
return <XCircleIcon className="w-5 h-5 text-red-500" />;
|
|
33
|
-
case 'running':
|
|
34
|
-
return (
|
|
35
|
-
<div className="w-5 h-5 border-2 border-blue-500 border-t-transparent rounded-full animate-spin" />
|
|
36
|
-
);
|
|
37
|
-
default:
|
|
38
|
-
return <ExclamationTriangleIcon className="w-5 h-5 text-gray-500" />;
|
|
39
|
-
}
|
|
40
|
-
};
|
|
41
|
-
|
|
42
|
-
const getBuildStatusColor = (status: string) => {
|
|
43
|
-
switch (status) {
|
|
44
|
-
case 'success':
|
|
45
|
-
return 'bg-green-100 text-green-800';
|
|
46
|
-
case 'failed':
|
|
47
|
-
return 'bg-red-100 text-red-800';
|
|
48
|
-
case 'running':
|
|
49
|
-
return 'bg-blue-100 text-blue-800';
|
|
50
|
-
default:
|
|
51
|
-
return 'bg-gray-100 text-gray-800';
|
|
52
|
-
}
|
|
53
|
-
};
|
|
54
|
-
|
|
55
|
-
const getLintStatusColor = (status: string) => {
|
|
56
|
-
switch (status) {
|
|
57
|
-
case 'pass':
|
|
58
|
-
return 'bg-green-100 text-green-800';
|
|
59
|
-
case 'fail':
|
|
60
|
-
return 'bg-red-100 text-red-800';
|
|
61
|
-
case 'warning':
|
|
62
|
-
return 'bg-yellow-100 text-yellow-800';
|
|
63
|
-
default:
|
|
64
|
-
return 'bg-gray-100 text-gray-800';
|
|
65
|
-
}
|
|
66
|
-
};
|
|
67
|
-
if (!packageData.packageHealth?.packageOverallScore) {
|
|
68
|
-
return <p className="py-6 text-gray-600">No health data available.</p>;
|
|
69
|
-
}
|
|
70
|
-
return (
|
|
71
|
-
<div className="py-6">
|
|
72
|
-
{/* Health Score Overview */}
|
|
73
|
-
<div className="bg-white border rounded-lg p-6 mb-6">
|
|
74
|
-
<div className="flex items-center justify-between mb-4">
|
|
75
|
-
<h3 className="text-lg font-medium text-gray-900">Health Score</h3>
|
|
76
|
-
<div
|
|
77
|
-
className={`text-3xl font-bold ${getHealthScoreColor(packageData.packageHealth.packageOverallScore)}`}
|
|
78
|
-
>
|
|
79
|
-
{packageData.packageHealth.packageOverallScore}%
|
|
80
|
-
</div>
|
|
81
|
-
</div>
|
|
82
|
-
|
|
83
|
-
<div className="w-full bg-gray-200 rounded-full h-3 mb-4">
|
|
84
|
-
<div
|
|
85
|
-
className={`h-3 rounded-full transition-all duration-300 ${
|
|
86
|
-
packageData.packageHealth.packageOverallScore >= 80
|
|
87
|
-
? 'bg-green-500'
|
|
88
|
-
: packageData.packageHealth.packageOverallScore >= 60
|
|
89
|
-
? 'bg-yellow-500'
|
|
90
|
-
: 'bg-red-500'
|
|
91
|
-
}`}
|
|
92
|
-
style={{
|
|
93
|
-
width: `${packageData.packageHealth.packageOverallScore}%`,
|
|
94
|
-
}}
|
|
95
|
-
/>
|
|
96
|
-
</div>
|
|
97
|
-
|
|
98
|
-
<p className="text-sm text-gray-600">
|
|
99
|
-
{packageData.packageHealth.packageOverallScore >= 80 &&
|
|
100
|
-
'Excellent health - package is in great condition'}
|
|
101
|
-
{packageData.packageHealth.packageOverallScore >= 60 &&
|
|
102
|
-
packageData.packageHealth.packageOverallScore < 80 &&
|
|
103
|
-
'Good health - minor issues detected'}
|
|
104
|
-
{packageData.packageHealth.packageOverallScore < 60 &&
|
|
105
|
-
'Needs attention - several issues require fixing'}
|
|
106
|
-
</p>
|
|
107
|
-
</div>
|
|
108
|
-
|
|
109
|
-
{/* Health Metrics Grid */}
|
|
110
|
-
<div className="grid grid-cols-1 md:grid-cols-3 gap-6 mb-6">
|
|
111
|
-
{/* Build Status */}
|
|
112
|
-
<div className="bg-white border rounded-lg p-6">
|
|
113
|
-
<div className="flex items-center justify-between mb-4">
|
|
114
|
-
<h4 className="text-sm font-medium text-gray-900">Build Status</h4>
|
|
115
|
-
{getBuildStatusIcon(packageData.packageHealth.packageBuildStatus)}
|
|
116
|
-
</div>
|
|
117
|
-
<div className="flex items-center justify-between">
|
|
118
|
-
<span
|
|
119
|
-
className={`inline-flex px-2 py-1 text-xs font-semibold rounded-full ${getBuildStatusColor(packageData.packageHealth.packageBuildStatus)}`}
|
|
120
|
-
>
|
|
121
|
-
{packageData.packageHealth.packageBuildStatus}
|
|
122
|
-
</span>
|
|
123
|
-
<button className="hidden text-blue-600 hover:text-blue-500 text-sm">
|
|
124
|
-
View Logs
|
|
125
|
-
</button>
|
|
126
|
-
</div>
|
|
127
|
-
</div>
|
|
128
|
-
|
|
129
|
-
{/* Test Coverage */}
|
|
130
|
-
<div className="hidden bg-white border rounded-lg p-6">
|
|
131
|
-
<div className="flex items-center justify-between mb-4">
|
|
132
|
-
<h4 className="text-sm font-medium text-gray-900">Test Coverage</h4>
|
|
133
|
-
<div
|
|
134
|
-
className={`text-lg font-semibold ${
|
|
135
|
-
packageData.packageHealth.packageTestCoverage >= 80
|
|
136
|
-
? 'text-green-600'
|
|
137
|
-
: packageData.packageHealth.packageTestCoverage >= 60
|
|
138
|
-
? 'text-yellow-600'
|
|
139
|
-
: 'text-red-600'
|
|
140
|
-
}`}
|
|
141
|
-
>
|
|
142
|
-
{packageData.packageHealth.packageTestCoverage}%
|
|
143
|
-
</div>
|
|
144
|
-
</div>
|
|
145
|
-
<div className="w-full bg-gray-200 rounded-full h-2">
|
|
146
|
-
<div
|
|
147
|
-
className={`h-2 rounded-full ${
|
|
148
|
-
packageData.packageHealth.packageTestCoverage >= 80
|
|
149
|
-
? 'bg-green-500'
|
|
150
|
-
: packageData.packageHealth.packageTestCoverage >= 60
|
|
151
|
-
? 'bg-yellow-500'
|
|
152
|
-
: 'bg-red-500'
|
|
153
|
-
}`}
|
|
154
|
-
style={{
|
|
155
|
-
width: `${packageData.packageHealth.packageTestCoverage}%`,
|
|
156
|
-
}}
|
|
157
|
-
/>
|
|
158
|
-
</div>
|
|
159
|
-
</div>
|
|
160
|
-
|
|
161
|
-
{/* Lint Status */}
|
|
162
|
-
<div className="bg-white border rounded-lg p-6">
|
|
163
|
-
<div className="flex items-center justify-between mb-4">
|
|
164
|
-
<h4 className="text-sm font-medium text-gray-900">Lint Status</h4>
|
|
165
|
-
{packageData.packageHealth.packageLintStatus === 'pass' && (
|
|
166
|
-
<CheckCircleIcon className="w-5 h-5 text-green-500" />
|
|
167
|
-
)}
|
|
168
|
-
{packageData.packageHealth.packageLintStatus === 'fail' && (
|
|
169
|
-
<XCircleIcon className="w-5 h-5 text-red-500" />
|
|
170
|
-
)}
|
|
171
|
-
{packageData.packageHealth.packageLintStatus === 'warning' && (
|
|
172
|
-
<ExclamationTriangleIcon className="w-5 h-5 text-yellow-500" />
|
|
173
|
-
)}
|
|
174
|
-
</div>
|
|
175
|
-
<div className="flex items-center justify-between">
|
|
176
|
-
<span
|
|
177
|
-
className={`inline-flex px-2 py-1 text-xs font-semibold rounded-full ${getLintStatusColor(packageData.packageHealth.packageLintStatus)}`}
|
|
178
|
-
>
|
|
179
|
-
{packageData.packageHealth.packageLintStatus}
|
|
180
|
-
</span>
|
|
181
|
-
<button className="hidden text-blue-600 hover:text-blue-500 text-sm">
|
|
182
|
-
View Issues
|
|
183
|
-
</button>
|
|
184
|
-
</div>
|
|
185
|
-
</div>
|
|
186
|
-
</div>
|
|
187
|
-
|
|
188
|
-
{/* Detailed Metrics */}
|
|
189
|
-
<div className="bg-white border rounded-lg p-6">
|
|
190
|
-
<h4 className="text-lg font-medium text-gray-900 mb-4">
|
|
191
|
-
Detailed Metrics
|
|
192
|
-
</h4>
|
|
193
|
-
|
|
194
|
-
<div className="grid grid-cols-1 md:grid-cols-2 gap-6">
|
|
195
|
-
<div>
|
|
196
|
-
<h5 className="text-sm font-medium text-gray-700 mb-3">
|
|
197
|
-
Dependencies
|
|
198
|
-
</h5>
|
|
199
|
-
<div className="space-y-2 text-sm">
|
|
200
|
-
<div className="flex justify-between">
|
|
201
|
-
<span className="text-gray-600">Total Dependencies:</span>
|
|
202
|
-
<span className="font-medium">
|
|
203
|
-
{Object.keys(packageData.dependenciesInfo).length}
|
|
204
|
-
</span>
|
|
205
|
-
</div>
|
|
206
|
-
<div className="flex justify-between">
|
|
207
|
-
<span className="text-gray-600">Outdated:</span>
|
|
208
|
-
<span className="font-medium text-yellow-600">
|
|
209
|
-
{
|
|
210
|
-
packageData.dependenciesInfo.filter(
|
|
211
|
-
d => d.status === 'outdated'
|
|
212
|
-
).length
|
|
213
|
-
}
|
|
214
|
-
</span>
|
|
215
|
-
</div>
|
|
216
|
-
<div className="flex justify-between">
|
|
217
|
-
<span className="text-gray-600">Major Updates Available:</span>
|
|
218
|
-
<span className="font-medium text-red-600">
|
|
219
|
-
{
|
|
220
|
-
packageData.dependenciesInfo.filter(
|
|
221
|
-
d => d.status === 'major-update'
|
|
222
|
-
).length
|
|
223
|
-
}
|
|
224
|
-
</span>
|
|
225
|
-
</div>
|
|
226
|
-
</div>
|
|
227
|
-
</div>
|
|
228
|
-
|
|
229
|
-
<div>
|
|
230
|
-
<h5 className="text-sm font-medium text-gray-700 mb-3">
|
|
231
|
-
Code Quality
|
|
232
|
-
</h5>
|
|
233
|
-
<div className="space-y-2 text-sm">
|
|
234
|
-
<div className="flex justify-between">
|
|
235
|
-
<span className="text-gray-600">Build Status:</span>
|
|
236
|
-
<span
|
|
237
|
-
className={`font-medium ${
|
|
238
|
-
packageData.packageHealth.packageBuildStatus === 'success'
|
|
239
|
-
? 'text-green-600'
|
|
240
|
-
: packageData.packageHealth.packageBuildStatus ===
|
|
241
|
-
'failed'
|
|
242
|
-
? 'text-red-600'
|
|
243
|
-
: 'text-yellow-600'
|
|
244
|
-
}`}
|
|
245
|
-
>
|
|
246
|
-
{packageData.packageHealth.packageBuildStatus}
|
|
247
|
-
</span>
|
|
248
|
-
</div>
|
|
249
|
-
<div className="hidden flex justify-between">
|
|
250
|
-
<span className="text-gray-600">Test Coverage:</span>
|
|
251
|
-
<span className="font-medium">
|
|
252
|
-
{packageData.packageHealth.packageTestCoverage}%
|
|
253
|
-
</span>
|
|
254
|
-
</div>
|
|
255
|
-
<div className="flex justify-between">
|
|
256
|
-
<span className="text-gray-600">Lint Status:</span>
|
|
257
|
-
<span
|
|
258
|
-
className={`font-medium ${
|
|
259
|
-
packageData.packageHealth.packageLintStatus === 'pass'
|
|
260
|
-
? 'text-green-600'
|
|
261
|
-
: packageData.packageHealth.packageLintStatus === 'fail'
|
|
262
|
-
? 'text-red-600'
|
|
263
|
-
: 'text-yellow-600'
|
|
264
|
-
}`}
|
|
265
|
-
>
|
|
266
|
-
{packageData.packageHealth.packageLintStatus}
|
|
267
|
-
</span>
|
|
268
|
-
</div>
|
|
269
|
-
</div>
|
|
270
|
-
</div>
|
|
271
|
-
</div>
|
|
272
|
-
</div>
|
|
273
|
-
</div>
|
|
274
|
-
);
|
|
275
|
-
}
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import { LoadingStateProps } from '../types/packages.types';
|
|
2
|
-
|
|
3
|
-
export default function LoadingState({
|
|
4
|
-
message = 'Loading packages...',
|
|
5
|
-
}: LoadingStateProps) {
|
|
6
|
-
return (
|
|
7
|
-
<div className="flex items-center justify-center h-64">
|
|
8
|
-
<div className="text-center">
|
|
9
|
-
<div className="animate-spin rounded-full h-12 w-12 border-b-2 border-blue-600 mx-auto"></div>
|
|
10
|
-
<p className="mt-4 text-gray-600">{message}</p>
|
|
11
|
-
</div>
|
|
12
|
-
</div>
|
|
13
|
-
);
|
|
14
|
-
}
|
package/monodog-dashboard/src/components/modules/packages/components/PackageDetailHeader.tsx
DELETED
|
@@ -1,167 +0,0 @@
|
|
|
1
|
-
import { Link } from 'react-router-dom';
|
|
2
|
-
import {
|
|
3
|
-
ArrowLeftIcon,
|
|
4
|
-
CalendarIcon,
|
|
5
|
-
UserIcon,
|
|
6
|
-
TagIcon,
|
|
7
|
-
CheckCircleIcon,
|
|
8
|
-
ExclamationTriangleIcon,
|
|
9
|
-
ClockIcon,
|
|
10
|
-
LinkIcon,
|
|
11
|
-
} from '../../../../icons/heroicons';
|
|
12
|
-
import { PackageDetail } from '../types/packages.types';
|
|
13
|
-
import type { PackageDetailHeaderProps } from '../../../../types';
|
|
14
|
-
import {
|
|
15
|
-
getStatusColor,
|
|
16
|
-
getTypeColor,
|
|
17
|
-
formatDate,
|
|
18
|
-
formatVersion,
|
|
19
|
-
getPackageTypeIcon,
|
|
20
|
-
} from '../utils/packages.utils';
|
|
21
|
-
|
|
22
|
-
export default function PackageDetailHeader({
|
|
23
|
-
packageData,
|
|
24
|
-
}: PackageDetailHeaderProps) {
|
|
25
|
-
const getStatusIcon = (status: string) => {
|
|
26
|
-
switch (status) {
|
|
27
|
-
case 'healthy':
|
|
28
|
-
return <CheckCircleIcon className="h-5 w-5 text-green-500" />;
|
|
29
|
-
case 'warning':
|
|
30
|
-
return <ExclamationTriangleIcon className="h-5 w-5 text-yellow-500" />;
|
|
31
|
-
case 'error':
|
|
32
|
-
return <ExclamationTriangleIcon className="h-5 w-5 text-red-500" />;
|
|
33
|
-
default:
|
|
34
|
-
return <ClockIcon className="h-5 w-5 text-gray-500" />;
|
|
35
|
-
}
|
|
36
|
-
};
|
|
37
|
-
|
|
38
|
-
return (
|
|
39
|
-
<>
|
|
40
|
-
{/* Back Navigation */}
|
|
41
|
-
<div className="mb-6">
|
|
42
|
-
<Link
|
|
43
|
-
to="/packages"
|
|
44
|
-
className="inline-flex items-center text-sm text-gray-500 hover:text-gray-700"
|
|
45
|
-
>
|
|
46
|
-
<ArrowLeftIcon className="mr-2 h-4 w-4" />
|
|
47
|
-
Back to Packages
|
|
48
|
-
</Link>
|
|
49
|
-
</div>
|
|
50
|
-
|
|
51
|
-
{/* Package Header */}
|
|
52
|
-
<div className="bg-white rounded-lg shadow border p-6 mb-6">
|
|
53
|
-
<div className="flex items-start justify-between">
|
|
54
|
-
<div className="flex items-start space-x-4">
|
|
55
|
-
<div className="text-4xl">
|
|
56
|
-
{getPackageTypeIcon(packageData.type)}
|
|
57
|
-
</div>
|
|
58
|
-
<div>
|
|
59
|
-
<h1 className="text-2xl font-bold text-gray-900">
|
|
60
|
-
{packageData.name}
|
|
61
|
-
</h1>
|
|
62
|
-
<p className="text-gray-600 mt-1">{packageData.description}</p>
|
|
63
|
-
|
|
64
|
-
<div className="flex items-center space-x-4 mt-4">
|
|
65
|
-
<div className="flex items-center space-x-2">
|
|
66
|
-
<span className="text-sm font-medium text-gray-500">
|
|
67
|
-
Version:
|
|
68
|
-
</span>
|
|
69
|
-
<span className="text-sm font-mono bg-gray-100 px-2 py-1 rounded">
|
|
70
|
-
{formatVersion(packageData.version)}
|
|
71
|
-
</span>
|
|
72
|
-
</div>
|
|
73
|
-
|
|
74
|
-
<span
|
|
75
|
-
className={`inline-flex px-2 py-1 text-xs font-semibold rounded-full ${getTypeColor(packageData.type)}`}
|
|
76
|
-
>
|
|
77
|
-
{packageData.type}
|
|
78
|
-
</span>
|
|
79
|
-
|
|
80
|
-
<div className="flex items-center space-x-1">
|
|
81
|
-
{getStatusIcon(packageData.status)}
|
|
82
|
-
<span
|
|
83
|
-
className={`inline-flex px-2 py-1 text-xs font-semibold rounded-full ${getStatusColor(packageData.status)}`}
|
|
84
|
-
>
|
|
85
|
-
{packageData.status}
|
|
86
|
-
</span>
|
|
87
|
-
</div>
|
|
88
|
-
</div>
|
|
89
|
-
</div>
|
|
90
|
-
</div>
|
|
91
|
-
|
|
92
|
-
<div className="text-right">
|
|
93
|
-
<div className="text-sm text-gray-500 mb-2">Health Score</div>
|
|
94
|
-
<div className="text-2xl font-bold text-blue-600">
|
|
95
|
-
{packageData.packageHealth?.packageOverallScore ?? ''}%
|
|
96
|
-
</div>
|
|
97
|
-
</div>
|
|
98
|
-
</div>
|
|
99
|
-
|
|
100
|
-
{/* Package Metadata */}
|
|
101
|
-
<div className="grid grid-cols-1 md:grid-cols-4 gap-4 mt-6 pt-6 border-t border-gray-200">
|
|
102
|
-
<div className="flex items-center space-x-2">
|
|
103
|
-
<CalendarIcon className="h-4 w-4 text-gray-400" />
|
|
104
|
-
<div>
|
|
105
|
-
<div className="text-xs text-gray-500">Last Updated</div>
|
|
106
|
-
<div className="text-sm font-medium">
|
|
107
|
-
{formatDate(packageData.lastUpdated)}
|
|
108
|
-
</div>
|
|
109
|
-
</div>
|
|
110
|
-
</div>
|
|
111
|
-
|
|
112
|
-
<div className="hidden flex items-center space-x-2">
|
|
113
|
-
<UserIcon className="h-4 w-4 text-gray-400" />
|
|
114
|
-
<div>
|
|
115
|
-
<div className="text-xs text-gray-500">Maintainers</div>
|
|
116
|
-
<div className="text-sm font-medium">
|
|
117
|
-
{packageData.maintainers.length}
|
|
118
|
-
</div>
|
|
119
|
-
</div>
|
|
120
|
-
</div>
|
|
121
|
-
|
|
122
|
-
<div className="flex items-center space-x-2">
|
|
123
|
-
<TagIcon className="h-4 w-4 text-gray-400" />
|
|
124
|
-
<div>
|
|
125
|
-
<div className="text-xs text-gray-500">License</div>
|
|
126
|
-
<div className="text-sm font-medium">{packageData.license}</div>
|
|
127
|
-
</div>
|
|
128
|
-
</div>
|
|
129
|
-
|
|
130
|
-
<div className="flex items-center space-x-2">
|
|
131
|
-
<div className="h-4 w-4 text-gray-400"><LinkIcon className="h-4 w-4 text-gray-400"></LinkIcon></div>
|
|
132
|
-
<div>
|
|
133
|
-
<div className="text-xs text-gray-500">Repository</div>
|
|
134
|
-
<div className="text-sm font-medium truncate">
|
|
135
|
-
<a
|
|
136
|
-
href={packageData.repository.url || ''}
|
|
137
|
-
target="_blank"
|
|
138
|
-
rel="noopener noreferrer"
|
|
139
|
-
className="text-blue-600 hover:text-blue-500"
|
|
140
|
-
>
|
|
141
|
-
{packageData.repository?.url?.split('/').pop()}
|
|
142
|
-
</a>
|
|
143
|
-
</div>
|
|
144
|
-
</div>
|
|
145
|
-
</div>
|
|
146
|
-
</div>
|
|
147
|
-
|
|
148
|
-
{/* Tags */}
|
|
149
|
-
{packageData.tags?.length > 0 && (
|
|
150
|
-
<div className="mt-4">
|
|
151
|
-
<div className="text-xs text-gray-500 mb-2">Tags</div>
|
|
152
|
-
<div className="flex flex-wrap gap-2">
|
|
153
|
-
{packageData.tags.map(tag => (
|
|
154
|
-
<span
|
|
155
|
-
key={tag}
|
|
156
|
-
className="inline-flex px-2 py-1 text-xs bg-gray-100 text-gray-700 rounded-full"
|
|
157
|
-
>
|
|
158
|
-
{tag}
|
|
159
|
-
</span>
|
|
160
|
-
))}
|
|
161
|
-
</div>
|
|
162
|
-
</div>
|
|
163
|
-
)}
|
|
164
|
-
</div>
|
|
165
|
-
</>
|
|
166
|
-
);
|
|
167
|
-
}
|
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
CubeIcon,
|
|
3
|
-
DocumentTextIcon,
|
|
4
|
-
ClockIcon,
|
|
5
|
-
HeartIcon,
|
|
6
|
-
Cog6ToothIcon,
|
|
7
|
-
} from '../../../../icons/heroicons';
|
|
8
|
-
import { PackageDetailTabsProps } from '../types/packages.types';
|
|
9
|
-
|
|
10
|
-
export default function PackageDetailTabs({
|
|
11
|
-
activeTab,
|
|
12
|
-
onTabChange,
|
|
13
|
-
}: PackageDetailTabsProps) {
|
|
14
|
-
const tabs = [
|
|
15
|
-
{ id: 'overview' as const, label: 'Overview', icon: CubeIcon },
|
|
16
|
-
{
|
|
17
|
-
id: 'dependencies' as const,
|
|
18
|
-
label: 'Dependencies',
|
|
19
|
-
icon: DocumentTextIcon,
|
|
20
|
-
},
|
|
21
|
-
{ id: 'commits' as const, label: 'Recent Commits', icon: ClockIcon },
|
|
22
|
-
{ id: 'health' as const, label: 'Health Metrics', icon: HeartIcon },
|
|
23
|
-
{ id: 'config' as const, label: 'Configuration', icon: Cog6ToothIcon },
|
|
24
|
-
];
|
|
25
|
-
|
|
26
|
-
return (
|
|
27
|
-
<div className="border-b border-gray-200">
|
|
28
|
-
<nav className="flex space-x-8">
|
|
29
|
-
{tabs.map(tab => {
|
|
30
|
-
const Icon = tab.icon;
|
|
31
|
-
return (
|
|
32
|
-
<button
|
|
33
|
-
key={tab.id}
|
|
34
|
-
onClick={() => onTabChange(tab.id)}
|
|
35
|
-
className={`py-4 px-1 border-b-2 font-medium text-sm flex items-center space-x-2 ${
|
|
36
|
-
activeTab === tab.id
|
|
37
|
-
? 'border-blue-500 text-blue-600'
|
|
38
|
-
: 'border-transparent text-gray-500 hover:text-gray-700 hover:border-gray-300'
|
|
39
|
-
}`}
|
|
40
|
-
>
|
|
41
|
-
<Icon className="w-4 h-4" />
|
|
42
|
-
<span>{tab.label}</span>
|
|
43
|
-
</button>
|
|
44
|
-
);
|
|
45
|
-
})}
|
|
46
|
-
</nav>
|
|
47
|
-
</div>
|
|
48
|
-
);
|
|
49
|
-
}
|
|
@@ -1,70 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
CheckCircleIcon,
|
|
3
|
-
ExclamationTriangleIcon,
|
|
4
|
-
XCircleIcon,
|
|
5
|
-
} from '../../../../icons/heroicons';
|
|
6
|
-
import { PackageStats as StatsType } from '../types/packages.types';
|
|
7
|
-
import type { PackageStatsProps } from '../../../../types';
|
|
8
|
-
import { CubeIcon } from '../../../../icons/heroicons';
|
|
9
|
-
|
|
10
|
-
export default function PackageStats({ stats }: PackageStatsProps) {
|
|
11
|
-
return (
|
|
12
|
-
<div className="grid grid-cols-1 md:grid-cols-4 gap-6">
|
|
13
|
-
<div className="bg-gray-100 p-6 rounded-lg shadow border">
|
|
14
|
-
<div className="flex items-center">
|
|
15
|
-
<div className="p-2 rounded-lg">
|
|
16
|
-
<CubeIcon className="w-6 h-6 text-primary-600" />
|
|
17
|
-
</div>
|
|
18
|
-
<div className="ml-4">
|
|
19
|
-
<p className="text-sm font-medium text-gray-600">Total Packages</p>
|
|
20
|
-
<p className="text-2xl font-semibold text-gray-900">
|
|
21
|
-
{stats.total}
|
|
22
|
-
</p>
|
|
23
|
-
</div>
|
|
24
|
-
</div>
|
|
25
|
-
</div>
|
|
26
|
-
|
|
27
|
-
<div className="bg-green-100 p-6 rounded-lg shadow border">
|
|
28
|
-
<div className="flex items-center">
|
|
29
|
-
<div className="p-2 bg-green-100 rounded-lg">
|
|
30
|
-
<CheckCircleIcon className="w-6 h-6 text-primary-600" />
|
|
31
|
-
</div>
|
|
32
|
-
<div className="ml-4">
|
|
33
|
-
<p className="text-sm font-medium text-gray-600">Healthy</p>
|
|
34
|
-
<p className="text-2xl font-semibold text-gray-600">
|
|
35
|
-
{stats.healthy}
|
|
36
|
-
</p>
|
|
37
|
-
</div>
|
|
38
|
-
</div>
|
|
39
|
-
</div>
|
|
40
|
-
|
|
41
|
-
<div className="bg-yellow-100 p-6 rounded-lg shadow border">
|
|
42
|
-
<div className="flex items-center">
|
|
43
|
-
<div className="p-2 bg-yellow-100 rounded-lg">
|
|
44
|
-
<ExclamationTriangleIcon className="w-6 h-6 text-primary-600" />
|
|
45
|
-
</div>
|
|
46
|
-
<div className="ml-4">
|
|
47
|
-
<p className="text-sm font-medium text-gray-600">Warnings</p>
|
|
48
|
-
<p className="text-2xl font-semibold text-gray-600">
|
|
49
|
-
{stats.warnings}
|
|
50
|
-
</p>
|
|
51
|
-
</div>
|
|
52
|
-
</div>
|
|
53
|
-
</div>
|
|
54
|
-
|
|
55
|
-
<div className="bg-red-100 p-6 rounded-lg shadow border">
|
|
56
|
-
<div className="flex items-center">
|
|
57
|
-
<div className="p-2 bg-red-100 rounded-lg">
|
|
58
|
-
<XCircleIcon className="w-6 h-6 text-primary-600" />
|
|
59
|
-
</div>
|
|
60
|
-
<div className="ml-4">
|
|
61
|
-
<p className="text-sm font-medium text-gray-600">Errors</p>
|
|
62
|
-
<p className="text-2xl font-semibold text-gray-600">
|
|
63
|
-
{stats.errors}
|
|
64
|
-
</p>
|
|
65
|
-
</div>
|
|
66
|
-
</div>
|
|
67
|
-
</div>
|
|
68
|
-
</div>
|
|
69
|
-
);
|
|
70
|
-
}
|