* Add GitLab integration components Introduced PushToGitLabDialog and GitlabConnection components to handle GitLab project connections and push functionality. Includes user authentication, project handling, and UI for seamless integration with GitLab. * Add components for GitLab connection and push dialog Introduce `GitlabConnection` and `PushToGitLabDialog` components to handle GitLab integration. These components allow users to connect their GitLab account, manage recent projects, and push code to a GitLab repository with detailed configurations and feedback. * Fix GitLab personal access tokens link to use correct URL * Update GitHub push call to use new pushToRepository method * Enhance GitLab integration with performance improvements - Add comprehensive caching system for repositories and user data - Implement pagination and search/filter functionality with debouncing - Add skeleton loaders and improved loading states - Implement retry logic for API calls with exponential backoff - Add background refresh capabilities - Improve error handling and user feedback - Optimize API calls to reduce loading times * feat: implement GitLab integration with connection management and repository handling - Add GitLab connection UI components - Implement GitLab API service for repository operations - Add GitLab connection store for state management - Update existing connection components (Vercel, Netlify) - Add repository listing and statistics display - Refactor GitLab components into organized folder structure * fix: resolve GitLab deployment issues and improve user experience - Fix DialogTitle accessibility warnings for screen readers - Remove CORS-problematic attributes from avatar images to prevent loading errors - Enhance GitLab API error handling with detailed error messages - Fix project creation settings to prevent initial commit conflicts - Add automatic GitLab connection state initialization on app startup - Improve deployment dialog UI with better error handling and user feedback - Add GitLab deployment source type to action runner system - Clean up deprecated push dialog files and consolidate deployment components 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com> * feat: implement GitHub clone repository dialog functionality This commit fixes the missing GitHub repository selection dialog in the "Clone a repo" feature by implementing the same elegant interface pattern used by GitLab. Key Changes: - Added onCloneRepository prop support to GitHubConnection component - Updated RepositoryCard to generate proper GitHub clone URLs (https://github.com/{full_name}.git) - Implemented full GitHub repository selection dialog in GitCloneButton.tsx - Added proper dialog close handling after successful clone operations - Maintained existing GitHub connection settings page functionality Technical Details: - Follows same component patterns as GitLab implementation - Uses proper TypeScript interfaces for clone URL handling - Includes professional dialog styling with loading states - Supports repository search, pagination, and authentication flow The GitHub clone experience now matches GitLab's functionality, providing users with a unified and intuitive repository selection interface across both providers. 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com> * Clean up unused connection components - Remove ConnectionForm.tsx (unused GitHub form component) - Remove CreateBranchDialog.tsx (unused branch creation dialog) - Remove RepositoryDialogContext.tsx (unused context provider) - Remove empty components/ directory These files were not referenced anywhere in the codebase and were leftover from development. * Remove environment variables info section from ConnectionsTab - Remove collapsible environment variables section - Clean up unused state and imports - Simplify the connections tab UI * Reorganize connections folder structure - Create netlify/ folder and move NetlifyConnection.tsx - Create vercel/ folder and move VercelConnection.tsx - Add index.ts files for both netlify and vercel folders - Update imports in ConnectionsTab.tsx to use new folder structure - All connection components now follow consistent folder organization --------- Co-authored-by: Hayat Bourgi <hayat.bourgi@montyholding.com> Co-authored-by: Hayat55 <53140162+Hayat55@users.noreply.github.com> Co-authored-by: Claude <noreply@anthropic.com>
80 lines
3.3 KiB
TypeScript
80 lines
3.3 KiB
TypeScript
import React from 'react';
|
|
import type { GitLabProjectInfo } from '~/types/GitLab';
|
|
|
|
interface RepositoryCardProps {
|
|
repo: GitLabProjectInfo;
|
|
onClone?: (repo: GitLabProjectInfo) => void;
|
|
}
|
|
|
|
export function RepositoryCard({ repo, onClone }: RepositoryCardProps) {
|
|
return (
|
|
<a
|
|
key={repo.name}
|
|
href={repo.http_url_to_repo}
|
|
target="_blank"
|
|
rel="noopener noreferrer"
|
|
className="group block p-4 rounded-lg bg-bolt-elements-background-depth-1 border border-bolt-elements-borderColor hover:border-bolt-elements-borderColorActive transition-all duration-200"
|
|
>
|
|
<div className="space-y-3">
|
|
<div className="flex items-start justify-between">
|
|
<div className="flex items-center gap-2">
|
|
<div className="i-ph:git-repository w-4 h-4 text-bolt-elements-icon-info" />
|
|
<h5 className="text-sm font-medium text-bolt-elements-textPrimary group-hover:text-bolt-elements-item-contentAccent transition-colors">
|
|
{repo.name}
|
|
</h5>
|
|
</div>
|
|
<div className="flex items-center gap-3 text-xs text-bolt-elements-textSecondary">
|
|
<span className="flex items-center gap-1" title="Stars">
|
|
<div className="i-ph:star w-3.5 h-3.5 text-bolt-elements-icon-warning" />
|
|
{repo.star_count.toLocaleString()}
|
|
</span>
|
|
<span className="flex items-center gap-1" title="Forks">
|
|
<div className="i-ph:git-fork w-3.5 h-3.5 text-bolt-elements-icon-info" />
|
|
{repo.forks_count.toLocaleString()}
|
|
</span>
|
|
</div>
|
|
</div>
|
|
|
|
{repo.description && (
|
|
<p className="text-xs text-bolt-elements-textSecondary line-clamp-2">{repo.description}</p>
|
|
)}
|
|
|
|
<div className="flex items-center gap-3 text-xs text-bolt-elements-textSecondary">
|
|
<span className="flex items-center gap-1" title="Default Branch">
|
|
<div className="i-ph:git-branch w-3.5 h-3.5" />
|
|
{repo.default_branch}
|
|
</span>
|
|
<span className="flex items-center gap-1" title="Last Updated">
|
|
<div className="i-ph:clock w-3.5 h-3.5" />
|
|
{new Date(repo.updated_at).toLocaleDateString(undefined, {
|
|
year: 'numeric',
|
|
month: 'short',
|
|
day: 'numeric',
|
|
})}
|
|
</span>
|
|
<div className="flex items-center gap-2 ml-auto">
|
|
{onClone && (
|
|
<button
|
|
onClick={(e) => {
|
|
e.preventDefault();
|
|
e.stopPropagation();
|
|
onClone(repo);
|
|
}}
|
|
className="flex items-center gap-1 px-2 py-1 rounded text-xs bg-bolt-elements-background-depth-2 hover:bg-bolt-elements-background-depth-3 text-bolt-elements-textSecondary hover:text-bolt-elements-textPrimary transition-colors"
|
|
title="Clone repository"
|
|
>
|
|
<div className="i-ph:git-branch w-3.5 h-3.5" />
|
|
Clone
|
|
</button>
|
|
)}
|
|
<span className="flex items-center gap-1 group-hover:text-bolt-elements-item-contentAccent transition-colors">
|
|
<div className="i-ph:arrow-square-out w-3.5 h-3.5" />
|
|
View
|
|
</span>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</a>
|
|
);
|
|
}
|