@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,103 +0,0 @@
|
|
|
1
|
-
import { DocumentTextIcon, TagIcon } from '../../../icons/heroicons';
|
|
2
|
-
|
|
3
|
-
interface ChangelogEntry {
|
|
4
|
-
id: string;
|
|
5
|
-
packageName: string;
|
|
6
|
-
version: string;
|
|
7
|
-
date: string;
|
|
8
|
-
changes: string[];
|
|
9
|
-
author: string;
|
|
10
|
-
type: 'feature' | 'bugfix' | 'breaking' | 'docs';
|
|
11
|
-
}
|
|
12
|
-
|
|
13
|
-
export default function ChangelogViewer() {
|
|
14
|
-
const mockChangelogs: ChangelogEntry[] = [
|
|
15
|
-
{
|
|
16
|
-
id: '1',
|
|
17
|
-
packageName: 'dashboard',
|
|
18
|
-
version: '1.0.0',
|
|
19
|
-
date: '2024-01-15',
|
|
20
|
-
changes: [
|
|
21
|
-
'Added new dashboard layout',
|
|
22
|
-
'Improved search functionality',
|
|
23
|
-
'Fixed responsive design issues',
|
|
24
|
-
],
|
|
25
|
-
author: 'team-frontend',
|
|
26
|
-
type: 'feature',
|
|
27
|
-
},
|
|
28
|
-
{
|
|
29
|
-
id: '2',
|
|
30
|
-
packageName: 'backend',
|
|
31
|
-
version: '1.2.0',
|
|
32
|
-
date: '2024-01-14',
|
|
33
|
-
changes: [
|
|
34
|
-
'Added authentication middleware',
|
|
35
|
-
'Implemented rate limiting',
|
|
36
|
-
'Fixed database connection pool',
|
|
37
|
-
],
|
|
38
|
-
author: 'team-backend',
|
|
39
|
-
type: 'feature',
|
|
40
|
-
},
|
|
41
|
-
];
|
|
42
|
-
|
|
43
|
-
const getChangeTypeColor = (type: string) => {
|
|
44
|
-
switch (type) {
|
|
45
|
-
case 'feature':
|
|
46
|
-
return 'bg-green-100 text-green-800';
|
|
47
|
-
case 'bugfix':
|
|
48
|
-
return 'bg-blue-100 text-blue-800';
|
|
49
|
-
case 'breaking':
|
|
50
|
-
return 'bg-red-100 text-red-800';
|
|
51
|
-
case 'docs':
|
|
52
|
-
return 'bg-gray-100 text-gray-800';
|
|
53
|
-
default:
|
|
54
|
-
return 'bg-gray-100 text-gray-800';
|
|
55
|
-
}
|
|
56
|
-
};
|
|
57
|
-
|
|
58
|
-
return (
|
|
59
|
-
<div className="bg-white rounded-lg shadow border overflow-hidden">
|
|
60
|
-
<div className="px-6 py-4 border-b border-gray-200">
|
|
61
|
-
<h3 className="text-lg font-medium text-gray-900">Recent Changelogs</h3>
|
|
62
|
-
</div>
|
|
63
|
-
|
|
64
|
-
<div className="p-6">
|
|
65
|
-
<div className="space-y-6">
|
|
66
|
-
{mockChangelogs.map(changelog => (
|
|
67
|
-
<div key={changelog.id} className="border-l-4 border-blue-500 pl-4">
|
|
68
|
-
<div className="flex items-center justify-between mb-2">
|
|
69
|
-
<div className="flex items-center space-x-3">
|
|
70
|
-
<div className="h-8 w-8 rounded-lg bg-blue-100 flex items-center justify-center">
|
|
71
|
-
<TagIcon className="w-4 h-4 text-blue-600" />
|
|
72
|
-
</div>
|
|
73
|
-
<div>
|
|
74
|
-
<div className="text-sm font-medium text-gray-900">
|
|
75
|
-
{changelog.packageName} v{changelog.version}
|
|
76
|
-
</div>
|
|
77
|
-
<div className="text-sm text-gray-500">
|
|
78
|
-
{changelog.date} • by {changelog.author}
|
|
79
|
-
</div>
|
|
80
|
-
</div>
|
|
81
|
-
</div>
|
|
82
|
-
<span
|
|
83
|
-
className={`inline-flex px-2 py-1 text-xs font-semibold rounded-full ${getChangeTypeColor(changelog.type)}`}
|
|
84
|
-
>
|
|
85
|
-
{changelog.type}
|
|
86
|
-
</span>
|
|
87
|
-
</div>
|
|
88
|
-
|
|
89
|
-
<div className="space-y-1">
|
|
90
|
-
{changelog.changes.map((change, index) => (
|
|
91
|
-
<div key={index} className="flex items-start space-x-2">
|
|
92
|
-
<DocumentTextIcon className="w-4 h-4 text-gray-400 mt-0.5 flex-shrink-0" />
|
|
93
|
-
<span className="text-sm text-gray-700">{change}</span>
|
|
94
|
-
</div>
|
|
95
|
-
))}
|
|
96
|
-
</div>
|
|
97
|
-
</div>
|
|
98
|
-
))}
|
|
99
|
-
</div>
|
|
100
|
-
</div>
|
|
101
|
-
</div>
|
|
102
|
-
);
|
|
103
|
-
}
|
|
@@ -1,23 +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
|
-
<button
|
|
15
|
-
onClick={onRetry}
|
|
16
|
-
className="mt-4 bg-blue-600 text-white px-4 py-2 rounded-lg hover:bg-blue-700 transition-colors"
|
|
17
|
-
>
|
|
18
|
-
Retry
|
|
19
|
-
</button>
|
|
20
|
-
</div>
|
|
21
|
-
</div>
|
|
22
|
-
);
|
|
23
|
-
}
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
export default function LoadingState() {
|
|
2
|
-
return (
|
|
3
|
-
<div className="flex items-center justify-center h-64">
|
|
4
|
-
<div className="text-center">
|
|
5
|
-
<div className="animate-spin rounded-full h-12 w-12 border-b-2 border-blue-600 mx-auto"></div>
|
|
6
|
-
<p className="mt-4 text-gray-600">Loading package data...</p>
|
|
7
|
-
</div>
|
|
8
|
-
</div>
|
|
9
|
-
);
|
|
10
|
-
}
|
|
@@ -1,140 +0,0 @@
|
|
|
1
|
-
import { TagIcon, ClockIcon } from '../../../icons/heroicons';
|
|
2
|
-
import { Package } from '../types/publish.types';
|
|
3
|
-
import { getStatusColor, getPublishTypeColor } from '../utils/publish.utils';
|
|
4
|
-
|
|
5
|
-
interface PackageReleaseTableProps {
|
|
6
|
-
packages: Package[];
|
|
7
|
-
selectedPackage: string;
|
|
8
|
-
onPackageChange: (packageName: string) => void;
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
export default function PackageReleaseTable({
|
|
12
|
-
packages,
|
|
13
|
-
selectedPackage,
|
|
14
|
-
onPackageChange,
|
|
15
|
-
}: PackageReleaseTableProps) {
|
|
16
|
-
return (
|
|
17
|
-
<div className="bg-white rounded-lg shadow border overflow-hidden">
|
|
18
|
-
<div className="px-6 py-4 border-b border-gray-200">
|
|
19
|
-
<div className="flex items-center justify-between">
|
|
20
|
-
<h3 className="text-lg font-medium text-gray-900">
|
|
21
|
-
Package Release Status
|
|
22
|
-
</h3>
|
|
23
|
-
<div className="flex items-center space-x-2">
|
|
24
|
-
<span className="text-sm text-gray-500">Filter by package:</span>
|
|
25
|
-
<select
|
|
26
|
-
value={selectedPackage}
|
|
27
|
-
onChange={e => onPackageChange(e.target.value)}
|
|
28
|
-
className="px-3 py-1 border border-gray-300 rounded text-sm focus:ring-2 focus:ring-blue-500 focus:border-transparent"
|
|
29
|
-
>
|
|
30
|
-
<option value="all">All Packages</option>
|
|
31
|
-
{[...new Set(packages.map(p => p.name))].map(name => (
|
|
32
|
-
<option key={name} value={name}>
|
|
33
|
-
{name}
|
|
34
|
-
</option>
|
|
35
|
-
))}
|
|
36
|
-
</select>
|
|
37
|
-
</div>
|
|
38
|
-
</div>
|
|
39
|
-
</div>
|
|
40
|
-
|
|
41
|
-
<div className="overflow-x-auto">
|
|
42
|
-
<table className="min-w-full divide-y divide-gray-200">
|
|
43
|
-
<thead className="bg-gray-50">
|
|
44
|
-
<tr>
|
|
45
|
-
<th className="px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider">
|
|
46
|
-
Package
|
|
47
|
-
</th>
|
|
48
|
-
<th className="px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider">
|
|
49
|
-
Current Version
|
|
50
|
-
</th>
|
|
51
|
-
<th className="px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider">
|
|
52
|
-
Next Version
|
|
53
|
-
</th>
|
|
54
|
-
<th className="px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider">
|
|
55
|
-
Type
|
|
56
|
-
</th>
|
|
57
|
-
<th className="px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider">
|
|
58
|
-
Status
|
|
59
|
-
</th>
|
|
60
|
-
<th className="px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider">
|
|
61
|
-
Commits
|
|
62
|
-
</th>
|
|
63
|
-
<th className="px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider">
|
|
64
|
-
Last Published
|
|
65
|
-
</th>
|
|
66
|
-
<th className="px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider">
|
|
67
|
-
Actions
|
|
68
|
-
</th>
|
|
69
|
-
</tr>
|
|
70
|
-
</thead>
|
|
71
|
-
<tbody className="bg-white divide-y divide-gray-200">
|
|
72
|
-
{packages.map(pkg => (
|
|
73
|
-
<tr key={pkg.name} className="hover:bg-gray-50">
|
|
74
|
-
<td className="px-6 py-4 whitespace-nowrap">
|
|
75
|
-
<div className="flex items-center">
|
|
76
|
-
<div className="h-8 w-8 rounded-lg bg-gray-100 flex items-center justify-center">
|
|
77
|
-
<TagIcon className="w-4 h-4 text-gray-600" />
|
|
78
|
-
</div>
|
|
79
|
-
<div className="ml-3">
|
|
80
|
-
<div className="text-sm font-medium text-gray-900">
|
|
81
|
-
{pkg.name}
|
|
82
|
-
</div>
|
|
83
|
-
<div className="text-sm text-gray-500">
|
|
84
|
-
{Object.keys(pkg.dependencies).length} dependencies
|
|
85
|
-
</div>
|
|
86
|
-
</div>
|
|
87
|
-
</div>
|
|
88
|
-
</td>
|
|
89
|
-
<td className="px-6 py-4 whitespace-nowrap text-sm text-gray-900">
|
|
90
|
-
{pkg.currentVersion}
|
|
91
|
-
</td>
|
|
92
|
-
<td className="px-6 py-4 whitespace-nowrap text-sm text-gray-900">
|
|
93
|
-
{pkg.nextVersion}
|
|
94
|
-
</td>
|
|
95
|
-
<td className="px-6 py-4 whitespace-nowrap">
|
|
96
|
-
<span
|
|
97
|
-
className={`inline-flex px-2 py-1 text-xs font-semibold rounded-full ${getPublishTypeColor(pkg.publishType)}`}
|
|
98
|
-
>
|
|
99
|
-
{pkg.publishType}
|
|
100
|
-
</span>
|
|
101
|
-
</td>
|
|
102
|
-
<td className="px-6 py-4 whitespace-nowrap">
|
|
103
|
-
<span
|
|
104
|
-
className={`inline-flex px-2 py-1 text-xs font-semibold rounded-full ${getStatusColor(pkg.status)}`}
|
|
105
|
-
>
|
|
106
|
-
{pkg.status}
|
|
107
|
-
</span>
|
|
108
|
-
</td>
|
|
109
|
-
<td className="px-6 py-4 whitespace-nowrap text-sm text-gray-900">
|
|
110
|
-
{pkg.commits}
|
|
111
|
-
</td>
|
|
112
|
-
<td className="px-6 py-4 whitespace-nowrap">
|
|
113
|
-
<div className="flex items-center text-sm text-gray-900">
|
|
114
|
-
<ClockIcon className="w-4 h-4 mr-1 text-gray-400" />
|
|
115
|
-
{pkg.lastPublished}
|
|
116
|
-
</div>
|
|
117
|
-
</td>
|
|
118
|
-
<td className="px-6 py-4 whitespace-nowrap text-sm font-medium">
|
|
119
|
-
<div className="flex space-x-2">
|
|
120
|
-
{pkg.status === 'ready' && (
|
|
121
|
-
<button className="text-green-600 hover:text-green-900">
|
|
122
|
-
Publish
|
|
123
|
-
</button>
|
|
124
|
-
)}
|
|
125
|
-
<button className="text-blue-600 hover:text-blue-900">
|
|
126
|
-
Details
|
|
127
|
-
</button>
|
|
128
|
-
<button className="text-purple-600 hover:text-purple-900">
|
|
129
|
-
Changelog
|
|
130
|
-
</button>
|
|
131
|
-
</div>
|
|
132
|
-
</td>
|
|
133
|
-
</tr>
|
|
134
|
-
))}
|
|
135
|
-
</tbody>
|
|
136
|
-
</table>
|
|
137
|
-
</div>
|
|
138
|
-
</div>
|
|
139
|
-
);
|
|
140
|
-
}
|
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
import { CloudArrowUpIcon } from '../../../icons/heroicons';
|
|
2
|
-
|
|
3
|
-
interface PublishHeaderProps {
|
|
4
|
-
packageCount: number;
|
|
5
|
-
onNewRelease: () => void;
|
|
6
|
-
}
|
|
7
|
-
|
|
8
|
-
export default function PublishHeader({
|
|
9
|
-
packageCount,
|
|
10
|
-
onNewRelease,
|
|
11
|
-
}: PublishHeaderProps) {
|
|
12
|
-
return (
|
|
13
|
-
<div className="flex items-center justify-between">
|
|
14
|
-
<div>
|
|
15
|
-
<h1 className="text-2xl font-bold text-gray-900">Publish Control</h1>
|
|
16
|
-
<p className="text-gray-600 mt-1">
|
|
17
|
-
Manage package releases and versioning across your monorepo (
|
|
18
|
-
{packageCount} packages)
|
|
19
|
-
</p>
|
|
20
|
-
</div>
|
|
21
|
-
<button
|
|
22
|
-
onClick={onNewRelease}
|
|
23
|
-
className="bg-blue-600 text-white px-4 py-2 rounded-lg hover:bg-blue-700 flex items-center space-x-2"
|
|
24
|
-
>
|
|
25
|
-
<CloudArrowUpIcon className="w-5 h-5" />
|
|
26
|
-
<span>New Release</span>
|
|
27
|
-
</button>
|
|
28
|
-
</div>
|
|
29
|
-
);
|
|
30
|
-
}
|
|
@@ -1,56 +0,0 @@
|
|
|
1
|
-
import { PlayIcon, RocketLaunchIcon } from '../../../icons/heroicons';
|
|
2
|
-
import { PublishStats } from '../types/publish.types';
|
|
3
|
-
|
|
4
|
-
interface QuickActionCardsProps {
|
|
5
|
-
stats: PublishStats;
|
|
6
|
-
}
|
|
7
|
-
|
|
8
|
-
export default function QuickActionCards({ stats }: QuickActionCardsProps) {
|
|
9
|
-
return (
|
|
10
|
-
<div className="grid grid-cols-1 md:grid-cols-3 gap-6">
|
|
11
|
-
<div className="bg-white p-6 rounded-lg shadow border">
|
|
12
|
-
<div className="flex items-center">
|
|
13
|
-
<div className="p-2 bg-green-100 rounded-lg">
|
|
14
|
-
<PlayIcon className="w-6 h-6 text-green-600" />
|
|
15
|
-
</div>
|
|
16
|
-
<div className="ml-4">
|
|
17
|
-
<p className="text-sm font-medium text-gray-600">
|
|
18
|
-
Ready to Publish
|
|
19
|
-
</p>
|
|
20
|
-
<p className="text-2xl font-semibold text-gray-900">
|
|
21
|
-
{stats.readyToPublish}
|
|
22
|
-
</p>
|
|
23
|
-
</div>
|
|
24
|
-
</div>
|
|
25
|
-
</div>
|
|
26
|
-
|
|
27
|
-
<div className="bg-white p-6 rounded-lg shadow border">
|
|
28
|
-
<div className="flex items-center">
|
|
29
|
-
<div className="p-2 bg-blue-100 rounded-lg">
|
|
30
|
-
<div className="h-6 w-6 animate-spin rounded-full border-2 border-blue-500 border-t-transparent" />
|
|
31
|
-
</div>
|
|
32
|
-
<div className="ml-4">
|
|
33
|
-
<p className="text-sm font-medium text-gray-600">In Progress</p>
|
|
34
|
-
<p className="text-2xl font-semibold text-gray-900">
|
|
35
|
-
{stats.inProgress}
|
|
36
|
-
</p>
|
|
37
|
-
</div>
|
|
38
|
-
</div>
|
|
39
|
-
</div>
|
|
40
|
-
|
|
41
|
-
<div className="bg-white p-6 rounded-lg shadow border">
|
|
42
|
-
<div className="flex items-center">
|
|
43
|
-
<div className="p-2 bg-purple-100 rounded-lg">
|
|
44
|
-
<span className="text-2xl"><RocketLaunchIcon className="w-6 h-6 text-primary-600" /></span>
|
|
45
|
-
</div>
|
|
46
|
-
<div className="ml-4">
|
|
47
|
-
<p className="text-sm font-medium text-gray-600">Published Today</p>
|
|
48
|
-
<p className="text-2xl font-semibold text-gray-900">
|
|
49
|
-
{stats.published}
|
|
50
|
-
</p>
|
|
51
|
-
</div>
|
|
52
|
-
</div>
|
|
53
|
-
</div>
|
|
54
|
-
</div>
|
|
55
|
-
);
|
|
56
|
-
}
|
|
@@ -1,104 +0,0 @@
|
|
|
1
|
-
import { CalendarIcon, ClockIcon } from '../../../icons/heroicons';
|
|
2
|
-
import { Release } from '../types/publish.types';
|
|
3
|
-
import { getStatusColor } from '../utils/publish.utils';
|
|
4
|
-
|
|
5
|
-
interface ReleaseScheduleProps {
|
|
6
|
-
releases: Release[];
|
|
7
|
-
selectedStatus: string;
|
|
8
|
-
onStatusChange: (status: string) => void;
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
export default function ReleaseSchedule({
|
|
12
|
-
releases,
|
|
13
|
-
selectedStatus,
|
|
14
|
-
onStatusChange,
|
|
15
|
-
}: ReleaseScheduleProps) {
|
|
16
|
-
const mockReleases: Release[] = [
|
|
17
|
-
{
|
|
18
|
-
id: '1',
|
|
19
|
-
packageName: 'dashboard',
|
|
20
|
-
version: '1.0.1',
|
|
21
|
-
status: 'scheduled',
|
|
22
|
-
scheduledFor: '2024-01-16 10:00 AM',
|
|
23
|
-
changelog: 'Bug fixes and performance improvements',
|
|
24
|
-
author: 'team-frontend',
|
|
25
|
-
},
|
|
26
|
-
{
|
|
27
|
-
id: '2',
|
|
28
|
-
packageName: 'backend',
|
|
29
|
-
version: '1.3.0',
|
|
30
|
-
status: 'in-progress',
|
|
31
|
-
scheduledFor: '2024-01-16 11:00 AM',
|
|
32
|
-
startedAt: '2024-01-16 11:05 AM',
|
|
33
|
-
changelog: 'New API endpoints and enhanced security',
|
|
34
|
-
author: 'team-backend',
|
|
35
|
-
},
|
|
36
|
-
];
|
|
37
|
-
|
|
38
|
-
return (
|
|
39
|
-
<div className="bg-white rounded-lg shadow border overflow-hidden">
|
|
40
|
-
<div className="px-6 py-4 border-b border-gray-200">
|
|
41
|
-
<div className="flex items-center justify-between">
|
|
42
|
-
<h3 className="text-lg font-medium text-gray-900">
|
|
43
|
-
Release Schedule
|
|
44
|
-
</h3>
|
|
45
|
-
<div className="flex items-center space-x-2">
|
|
46
|
-
<span className="text-sm text-gray-500">Filter by status:</span>
|
|
47
|
-
<select
|
|
48
|
-
value={selectedStatus}
|
|
49
|
-
onChange={e => onStatusChange(e.target.value)}
|
|
50
|
-
className="px-3 py-1 border border-gray-300 rounded text-sm focus:ring-2 focus:ring-blue-500 focus:border-transparent"
|
|
51
|
-
>
|
|
52
|
-
<option value="all">All Status</option>
|
|
53
|
-
<option value="scheduled">Scheduled</option>
|
|
54
|
-
<option value="in-progress">In Progress</option>
|
|
55
|
-
<option value="completed">Completed</option>
|
|
56
|
-
<option value="failed">Failed</option>
|
|
57
|
-
</select>
|
|
58
|
-
</div>
|
|
59
|
-
</div>
|
|
60
|
-
</div>
|
|
61
|
-
|
|
62
|
-
<div className="p-6">
|
|
63
|
-
<div className="space-y-4">
|
|
64
|
-
{mockReleases.map(release => (
|
|
65
|
-
<div
|
|
66
|
-
key={release.id}
|
|
67
|
-
className="border rounded-lg p-4 hover:bg-gray-50"
|
|
68
|
-
>
|
|
69
|
-
<div className="flex items-center justify-between">
|
|
70
|
-
<div className="flex items-center space-x-3">
|
|
71
|
-
<div className="h-8 w-8 rounded-lg bg-purple-100 flex items-center justify-center">
|
|
72
|
-
<CalendarIcon className="w-4 h-4 text-purple-600" />
|
|
73
|
-
</div>
|
|
74
|
-
<div>
|
|
75
|
-
<div className="text-sm font-medium text-gray-900">
|
|
76
|
-
{release.packageName} v{release.version}
|
|
77
|
-
</div>
|
|
78
|
-
<div className="text-sm text-gray-500">
|
|
79
|
-
by {release.author}
|
|
80
|
-
</div>
|
|
81
|
-
</div>
|
|
82
|
-
</div>
|
|
83
|
-
<div className="flex items-center space-x-3">
|
|
84
|
-
<span
|
|
85
|
-
className={`inline-flex px-2 py-1 text-xs font-semibold rounded-full ${getStatusColor(release.status)}`}
|
|
86
|
-
>
|
|
87
|
-
{release.status}
|
|
88
|
-
</span>
|
|
89
|
-
<div className="text-sm text-gray-500 flex items-center">
|
|
90
|
-
<ClockIcon className="w-4 h-4 mr-1" />
|
|
91
|
-
{release.scheduledFor}
|
|
92
|
-
</div>
|
|
93
|
-
</div>
|
|
94
|
-
</div>
|
|
95
|
-
<div className="mt-3 text-sm text-gray-700">
|
|
96
|
-
{release.changelog}
|
|
97
|
-
</div>
|
|
98
|
-
</div>
|
|
99
|
-
))}
|
|
100
|
-
</div>
|
|
101
|
-
</div>
|
|
102
|
-
</div>
|
|
103
|
-
);
|
|
104
|
-
}
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
// Export all publish control components for easier imports
|
|
2
|
-
export { default as PublishHeader } from './PublishHeader';
|
|
3
|
-
export { default as QuickActionCards } from './QuickActionCards';
|
|
4
|
-
export { default as PackageReleaseTable } from './PackageReleaseTable';
|
|
5
|
-
export { default as ReleaseSchedule } from './ReleaseSchedule';
|
|
6
|
-
export { default as ChangelogViewer } from './ChangelogViewer';
|
|
7
|
-
export { default as LoadingState } from './LoadingState';
|
|
8
|
-
export { default as ErrorState } from './ErrorState';
|
|
@@ -1,39 +0,0 @@
|
|
|
1
|
-
// Shared types for publish control components
|
|
2
|
-
|
|
3
|
-
export interface Package {
|
|
4
|
-
name: string;
|
|
5
|
-
currentVersion: string;
|
|
6
|
-
nextVersion: string;
|
|
7
|
-
status: 'ready' | 'building' | 'testing' | 'published' | 'failed';
|
|
8
|
-
lastPublished: string;
|
|
9
|
-
changelog: string;
|
|
10
|
-
commits: number;
|
|
11
|
-
dependencies: string[];
|
|
12
|
-
publishType: 'patch' | 'minor' | 'major' | 'prerelease';
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
export interface Release {
|
|
16
|
-
id: string;
|
|
17
|
-
packageName: string;
|
|
18
|
-
version: string;
|
|
19
|
-
status: 'scheduled' | 'in-progress' | 'completed' | 'failed';
|
|
20
|
-
scheduledFor: string;
|
|
21
|
-
startedAt?: string;
|
|
22
|
-
completedAt?: string;
|
|
23
|
-
changelog: string;
|
|
24
|
-
author: string;
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
export interface PublishStats {
|
|
28
|
-
readyToPublish: number;
|
|
29
|
-
inProgress: number;
|
|
30
|
-
published: number;
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
export interface PublishControlState {
|
|
34
|
-
packages: Package[];
|
|
35
|
-
selectedPackage: string;
|
|
36
|
-
selectedStatus: string;
|
|
37
|
-
loading: boolean;
|
|
38
|
-
error: string | null;
|
|
39
|
-
}
|
|
@@ -1,59 +0,0 @@
|
|
|
1
|
-
import { Package, PublishStats } from '../types/publish.types';
|
|
2
|
-
|
|
3
|
-
// Calculate publish statistics
|
|
4
|
-
export const calculatePublishStats = (packages: Package[]): PublishStats => {
|
|
5
|
-
return {
|
|
6
|
-
readyToPublish: packages.filter(p => p.status === 'ready').length,
|
|
7
|
-
inProgress: packages.filter(
|
|
8
|
-
p => p.status === 'building' || p.status === 'testing'
|
|
9
|
-
).length,
|
|
10
|
-
published: packages.filter(p => p.status === 'published').length,
|
|
11
|
-
};
|
|
12
|
-
};
|
|
13
|
-
|
|
14
|
-
// Get status color for package status
|
|
15
|
-
export const getStatusColor = (status: string): string => {
|
|
16
|
-
switch (status) {
|
|
17
|
-
case 'ready':
|
|
18
|
-
case 'completed':
|
|
19
|
-
return 'bg-green-100 text-green-800';
|
|
20
|
-
case 'building':
|
|
21
|
-
case 'testing':
|
|
22
|
-
case 'in-progress':
|
|
23
|
-
return 'bg-blue-100 text-blue-800';
|
|
24
|
-
case 'published':
|
|
25
|
-
return 'bg-purple-100 text-purple-800';
|
|
26
|
-
case 'failed':
|
|
27
|
-
return 'bg-red-100 text-red-800';
|
|
28
|
-
case 'scheduled':
|
|
29
|
-
return 'bg-yellow-100 text-yellow-800';
|
|
30
|
-
default:
|
|
31
|
-
return 'bg-gray-100 text-gray-800';
|
|
32
|
-
}
|
|
33
|
-
};
|
|
34
|
-
|
|
35
|
-
// Get publish type color
|
|
36
|
-
export const getPublishTypeColor = (type: string): string => {
|
|
37
|
-
switch (type) {
|
|
38
|
-
case 'patch':
|
|
39
|
-
return 'bg-green-100 text-green-800';
|
|
40
|
-
case 'minor':
|
|
41
|
-
return 'bg-blue-100 text-blue-800';
|
|
42
|
-
case 'major':
|
|
43
|
-
return 'bg-red-100 text-red-800';
|
|
44
|
-
case 'prerelease':
|
|
45
|
-
return 'bg-yellow-100 text-yellow-800';
|
|
46
|
-
default:
|
|
47
|
-
return 'bg-gray-100 text-gray-800';
|
|
48
|
-
}
|
|
49
|
-
};
|
|
50
|
-
|
|
51
|
-
// Filter packages by name
|
|
52
|
-
export const filterPackagesByName = (
|
|
53
|
-
packages: Package[],
|
|
54
|
-
selectedPackage: string
|
|
55
|
-
): Package[] => {
|
|
56
|
-
return selectedPackage === 'all'
|
|
57
|
-
? packages
|
|
58
|
-
: packages.filter(pkg => pkg.name === selectedPackage);
|
|
59
|
-
};
|