All files / src/components/settings SourceItem.tsx

100% Statements 2/2
100% Branches 8/8
100% Functions 2/2
100% Lines 2/2

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48                      10x                                         1x                              
import { Loader2, ToggleLeft, ToggleRight } from 'lucide-react'
import type { Source } from '../../api/client'
import { cn } from '../../lib/utils'
 
interface SourceItemProps {
  source: Source
  toggling: boolean
  onToggle: (sourceId: number) => void
}
 
export default function SourceItem({ source, toggling, onToggle }: SourceItemProps) {
  return (
    <div
      className={cn(
        'flex items-center justify-between rounded-lg border p-4 transition-colors',
        source.is_enabled
          ? 'border-border bg-card'
          : 'border-border/50 bg-muted/30'
      )}
    >
      <div className="flex-1">
        <div className="flex items-center gap-2">
          <span className="font-medium text-foreground">{source.name}</span>
          {source.is_enabled && (
            <span className="rounded bg-green-500/10 px-2 py-0.5 text-xs font-medium text-green-600 dark:text-green-400">
              Active
            </span>
          )}
        </div>
        <p className="text-sm text-muted-foreground">{source.host}</p>
      </div>
      <button
        onClick={() => onToggle(source.id)}
        disabled={toggling}
        className="text-muted-foreground transition-colors hover:text-foreground disabled:opacity-50"
      >
        {toggling ? (
          <Loader2 className="h-6 w-6 animate-spin" />
        ) : source.is_enabled ? (
          <ToggleRight className="h-8 w-8 text-primary" />
        ) : (
          <ToggleLeft className="h-8 w-8" />
        )}
      </button>
    </div>
  )
}
 
← Back to Dashboard