mirror of
https://github.com/AutoMaker-Org/automaker.git
synced 2026-01-31 06:42:03 +00:00
merge: resolve conflicts with upstream/v0.13.0rc
This commit is contained in:
@@ -1,6 +1,6 @@
|
||||
import { Folder, LucideIcon } from 'lucide-react';
|
||||
import * as LucideIcons from 'lucide-react';
|
||||
import { cn } from '@/lib/utils';
|
||||
import { cn, sanitizeForTestId } from '@/lib/utils';
|
||||
import { getAuthenticatedImageUrl } from '@/lib/api-fetch';
|
||||
import type { Project } from '@/lib/electron';
|
||||
|
||||
@@ -37,10 +37,15 @@ export function ProjectSwitcherItem({
|
||||
const IconComponent = getIconComponent();
|
||||
const hasCustomIcon = !!project.customIconPath;
|
||||
|
||||
// Combine project.id with sanitized name for uniqueness and readability
|
||||
// Format: project-switcher-{id}-{sanitizedName}
|
||||
const testId = `project-switcher-${project.id}-${sanitizeForTestId(project.name)}`;
|
||||
|
||||
return (
|
||||
<button
|
||||
onClick={onClick}
|
||||
onContextMenu={onContextMenu}
|
||||
data-testid={testId}
|
||||
className={cn(
|
||||
'group w-full aspect-square rounded-xl flex items-center justify-center relative overflow-hidden',
|
||||
'transition-all duration-200 ease-out',
|
||||
@@ -60,7 +65,6 @@ export function ProjectSwitcherItem({
|
||||
'hover:scale-105 active:scale-95'
|
||||
)}
|
||||
title={project.name}
|
||||
data-testid={`project-switcher-${project.id}`}
|
||||
>
|
||||
{hasCustomIcon ? (
|
||||
<img
|
||||
|
||||
@@ -125,6 +125,34 @@ export const isMac =
|
||||
(/Mac/.test(navigator.userAgent) ||
|
||||
(navigator.platform ? navigator.platform.toLowerCase().includes('mac') : false));
|
||||
|
||||
/**
|
||||
* Sanitize a string for use in data-testid attributes.
|
||||
* Creates a deterministic, URL-safe identifier from any input string.
|
||||
*
|
||||
* Transformations:
|
||||
* - Convert to lowercase
|
||||
* - Replace spaces with hyphens
|
||||
* - Remove all non-alphanumeric characters (except hyphens)
|
||||
* - Collapse multiple consecutive hyphens into a single hyphen
|
||||
* - Trim leading/trailing hyphens
|
||||
*
|
||||
* @param name - The string to sanitize (e.g., project name, feature title)
|
||||
* @returns A sanitized string safe for CSS selectors and test IDs
|
||||
*
|
||||
* @example
|
||||
* sanitizeForTestId("My Awesome Project!") // "my-awesome-project"
|
||||
* sanitizeForTestId("test-project-123") // "test-project-123"
|
||||
* sanitizeForTestId(" Foo Bar ") // "foo-bar"
|
||||
*/
|
||||
export function sanitizeForTestId(name: string): string {
|
||||
return name
|
||||
.toLowerCase()
|
||||
.replace(/\s+/g, '-')
|
||||
.replace(/[^a-z0-9-]/g, '')
|
||||
.replace(/-+/g, '-')
|
||||
.replace(/^-|-$/g, '');
|
||||
}
|
||||
|
||||
/**
|
||||
* Generate a UUID v4 string.
|
||||
*
|
||||
|
||||
Reference in New Issue
Block a user