Spaces:
Sleeping
Sleeping
File size: 4,345 Bytes
70ed4fd f074415 70ed4fd f074415 70ed4fd f074415 70ed4fd f074415 70ed4fd |
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 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 |
import React from 'react';
import { motion } from 'framer-motion';
import { Flag, Globe, Info, MapPin, CheckCircle, PenLine, User } from 'lucide-react';
const ExampleCard = ({ example, index = 0 }) => {
const cardVariants = {
hidden: { opacity: 0, y: 10 },
visible: {
opacity: 1,
y: 0,
transition: {
duration: 0.3,
delay: index * 0.05,
},
},
};
const StatusIcon = example.status === 'verified' ? CheckCircle : PenLine;
// Detect if this is a Chinese-to-English example (no taiwan field or isChineseToEnglish flag)
const isChineseToEnglish = example.isChineseToEnglish || !example.taiwan;
return (
<motion.div
className="example-card"
variants={cardVariants}
initial="visible"
animate="visible"
whileHover={{ scale: 1.02 }}
>
<div className="example-header">
<div className="example-header-left">
<span className="example-brand">{example.brand}</span>
<span className="example-category">{example.category}</span>
</div>
<div className="example-header-right">
{example.contributor && (
<div className="contributor" title={`Added by ${example.contributor}`}>
<User size={14} />
<span>{example.contributor}</span>
</div>
)}
<StatusIcon
size={16}
className={example.status === 'verified' ? 'status-verified' : 'status-pending'}
title={example.status === 'verified' ? 'Verified Example' : 'Pending Review'}
/>
</div>
</div>
{isChineseToEnglish ? (
<>
{/* Chinese to English layout */}
<div className="language-section">
<div className="language-label">
<Flag size={16} />
Chinese (Original)
</div>
<div className="language-text chinese-text">
{example.mainland}
</div>
</div>
<div className="language-section">
<div className="language-label">
<Globe size={16} />
English Translation
</div>
<div className="language-text">
{example.english}
</div>
</div>
</>
) : (
<>
{/* English to Chinese layout */}
<div className="language-section">
<div className="language-label">
<Flag size={16} />
English (Original)
</div>
<div className="language-text">
{example.english}
</div>
</div>
<div className="language-section">
<div className="language-label">
<MapPin size={16} />
<span>Mainland China</span>
</div>
<div className="language-text chinese-text">
{example.mainland}
</div>
</div>
<div className="language-section">
<div className="language-label">
<Globe size={16} />
<span>Taiwan</span>
</div>
<div className="language-text chinese-text">
{example.taiwan}
</div>
</div>
</>
)}
{example.description && (
<div className="example-description">
<div className="language-label">
<Info size={16} />
Description
</div>
{example.description}
</div>
)}
<style jsx>{`
.example-header {
display: flex;
justify-content: space-between;
align-items: center;
margin-bottom: 1.5rem;
}
.example-header-left {
display: flex;
align-items: center;
gap: 0.75rem;
}
.example-header-right {
display: flex;
align-items: center;
gap: 1rem;
}
.contributor {
display: flex;
align-items: center;
gap: 0.25rem;
font-size: 0.85rem;
color: #666;
}
.status-verified {
color: #10b981;
}
.status-pending {
color: #6b7280;
}
`}</style>
</motion.div>
);
};
export default ExampleCard; |