import React, { useState, useEffect } from 'react';
import { 
  CreditCard, 
  Send, 
  QrCode, 
  User, 
  History, 
  Eye, 
  EyeOff,
  ArrowLeft,
  Check,
  X,
  Smartphone,
  Shield,
  Zap
} from 'lucide-react';

const UPIPaymentApp = () =&gt; {
  const [currentScreen, setCurrentScreen] = useState('home');
  const [showBalance, setShowBalance] = useState(false);
  const [balance, setBalance] = useState(25430.50);
  const [pin, setPin] = useState('');
  const [paymentAmount, setPaymentAmount] = useState('');
  const [recipient, setRecipient] = useState('');
  const [isProcessing, setIsProcessing] = useState(false);
  const [showSuccess, setShowSuccess] = useState(false);
  const [cameraActive, setCameraActive] = useState(false);
  const [scannedData, setScannedData] = useState(null);
  const [stream, setStream] = useState(null);
  const [scanError, setScanError] = useState('');

  const [transactions] = useState([
    { id: 1, type: 'sent', amount: 500, recipient: 'John Doe', time: '10:30 AM', status: 'success' },
    { id: 2, type: 'received', amount: 1200, sender: 'Sarah Wilson', time: '9:15 AM', status: 'success' },
    { id: 3, type: 'sent', amount: 300, recipient: 'Coffee Shop', time: 'Yesterday', status: 'success' },
    { id: 4, type: 'received', amount: 2500, sender: 'Freelance Payment', time: '2 days ago', status: 'success' }
  ]);

  const handlePayment = () =&gt; {
    if (paymentAmount &amp;&amp; recipient &amp;&amp; pin === '1234') {
      setIsProcessing(true);
      setTimeout(() =&gt; {
        setBalance(prev =&gt; prev - parseFloat(paymentAmount));
        setIsProcessing(false);
        setShowSuccess(true);
        setTimeout(() =&gt; {
          setShowSuccess(false);
          setCurrentScreen('home');
          setPaymentAmount('');
          setRecipient('');
          setPin('');
        }, 2000);
      }, 2000);
    }
  };

  const HomeScreen = () =&gt; (
    &lt;div className=&quot;min-h-screen bg-gradient-to-br from-blue-50 to-indigo-100&quot;&gt;
      {/* Header */}
      &lt;div className=&quot;bg-gradient-to-r from-blue-600 to-indigo-700 text-white p-6 pb-8&quot;&gt;
        &lt;div className=&quot;flex items-center justify-between mb-6&quot;&gt;
          &lt;div className=&quot;flex items-center space-x-3&quot;&gt;
            &lt;div className=&quot;w-10 h-10 bg-white/20 rounded-full flex items-center justify-center&quot;&gt;
              &lt;Zap className=&quot;w-6 h-6&quot; /&gt;
            &lt;/div&gt;
            &lt;div&gt;
              &lt;h1 className=&quot;text-xl font-bold&quot;&gt;PayEasy&lt;/h1&gt;
              &lt;p className=&quot;text-blue-100 text-sm&quot;&gt;Your UPI Wallet&lt;/p&gt;
            &lt;/div&gt;
          &lt;/div&gt;
          &lt;div className=&quot;w-10 h-10 bg-white/20 rounded-full flex items-center justify-center&quot;&gt;
            &lt;User className=&quot;w-6 h-6&quot; /&gt;
          &lt;/div&gt;
        &lt;/div&gt;

        {/* Balance Card */}
        &lt;div className=&quot;bg-white/10 backdrop-blur-sm rounded-xl p-4 border border-white/20&quot;&gt;
          &lt;div className=&quot;flex items-center justify-between&quot;&gt;
            &lt;div&gt;
              &lt;p className=&quot;text-blue-100 text-sm mb-1&quot;&gt;Total Balance&lt;/p&gt;
              &lt;div className=&quot;flex items-center space-x-2&quot;&gt;
                &lt;span className=&quot;text-2xl font-bold&quot;&gt;
                  {showBalance ? `₹${balance.toLocaleString()}` : '₹&bull;&bull;&bull;&bull;&bull;&bull;'}
                &lt;/span&gt;
                &lt;button
                  onClick={() =&gt; setShowBalance(!showBalance)}
                  className=&quot;p-1 hover:bg-white/10 rounded&quot;
                &gt;
                  {showBalance ? &lt;EyeOff className=&quot;w-4 h-4&quot; /&gt; : &lt;Eye className=&quot;w-4 h-4&quot; /&gt;}
                &lt;/button&gt;
              &lt;/div&gt;
            &lt;/div&gt;
            &lt;div className=&quot;w-12 h-12 bg-gradient-to-br from-green-400 to-emerald-500 rounded-xl flex items-center justify-center&quot;&gt;
              &lt;CreditCard className=&quot;w-6 h-6 text-white&quot; /&gt;
            &lt;/div&gt;
          &lt;/div&gt;
        &lt;/div&gt;
      &lt;/div&gt;

      {/* Quick Actions */}
      &lt;div className=&quot;px-6 -mt-4 mb-6&quot;&gt;
        &lt;div className=&quot;bg-white rounded-xl shadow-lg p-6&quot;&gt;
          &lt;h3 className=&quot;text-lg font-semibold mb-4 text-gray-800&quot;&gt;Quick Actions&lt;/h3&gt;
          &lt;div className=&quot;grid grid-cols-2 gap-4&quot;&gt;
            &lt;button
              onClick={() =&gt; setCurrentScreen('send')}
              className=&quot;flex flex-col items-center p-4 bg-gradient-to-br from-blue-50 to-blue-100 rounded-xl hover:shadow-md transition-all duration-200 group&quot;
            &gt;
              &lt;div className=&quot;w-12 h-12 bg-blue-500 rounded-xl flex items-center justify-center mb-2 group-hover:scale-110 transition-transform&quot;&gt;
                &lt;Send className=&quot;w-6 h-6 text-white&quot; /&gt;
              &lt;/div&gt;
              &lt;span className=&quot;font-medium text-gray-800&quot;&gt;Send Money&lt;/span&gt;
            &lt;/button&gt;
            &lt;button
              onClick={() =&gt; setCurrentScreen('scan')}
              className=&quot;flex flex-col items-center p-4 bg-gradient-to-br from-purple-50 to-purple-100 rounded-xl hover:shadow-md transition-all duration-200 group&quot;
            &gt;
              &lt;div className=&quot;w-12 h-12 bg-purple-500 rounded-xl flex items-center justify-center mb-2 group-hover:scale-110 transition-transform&quot;&gt;
                &lt;QrCode className=&quot;w-6 h-6 text-white&quot; /&gt;
              &lt;/div&gt;
              &lt;span className=&quot;font-medium text-gray-800&quot;&gt;Scan &amp; Pay&lt;/span&gt;
            &lt;/button&gt;
          &lt;/div&gt;
        &lt;/div&gt;
      &lt;/div&gt;

      {/* Recent Transactions */}
      &lt;div className=&quot;px-6&quot;&gt;
        &lt;div className=&quot;bg-white rounded-xl shadow-lg p-6&quot;&gt;
          &lt;div className=&quot;flex items-center justify-between mb-4&quot;&gt;
            &lt;h3 className=&quot;text-lg font-semibold text-gray-800&quot;&gt;Recent Transactions&lt;/h3&gt;
            &lt;button
              onClick={() =&gt; setCurrentScreen('history')}
              className=&quot;text-blue-600 text-sm font-medium hover:text-blue-700&quot;
            &gt;
              View All
            &lt;/button&gt;
          &lt;/div&gt;
          &lt;div className=&quot;space-y-3&quot;&gt;
            {transactions.slice(0, 3).map((transaction) =&gt; (
              &lt;div key={transaction.id} className=&quot;flex items-center justify-between p-3 bg-gray-50 rounded-lg&quot;&gt;
                &lt;div className=&quot;flex items-center space-x-3&quot;&gt;
                  &lt;div className={`w-10 h-10 rounded-full flex items-center justify-center ${
                    transaction.type === 'sent' ? 'bg-red-100' : 'bg-green-100'
                  }`}&gt;
                    &lt;Send className={`w-5 h-5 ${
                      transaction.type === 'sent' ? 'text-red-600 rotate-45' : 'text-green-600 -rotate-45'
                    }`} /&gt;
                  &lt;/div&gt;
                  &lt;div&gt;
                    &lt;p className=&quot;font-medium text-gray-800&quot;&gt;
                      {transaction.type === 'sent' ? transaction.recipient : transaction.sender}
                    &lt;/p&gt;
                    &lt;p className=&quot;text-sm text-gray-500&quot;&gt;{transaction.time}&lt;/p&gt;
                  &lt;/div&gt;
                &lt;/div&gt;
                &lt;span className={`font-semibold ${
                  transaction.type === 'sent' ? 'text-red-600' : 'text-green-600'
                }`}&gt;
                  {transaction.type === 'sent' ? '-' : '+'}₹{transaction.amount}
                &lt;/span&gt;
              &lt;/div&gt;
            ))}
          &lt;/div&gt;
        &lt;/div&gt;
      &lt;/div&gt;
    &lt;/div&gt;
  );

  const SendMoneyScreen = () =&gt; (
    &lt;div className=&quot;min-h-screen bg-gray-50&quot;&gt;
      &lt;div className=&quot;bg-white shadow-sm p-4 flex items-center space-x-4&quot;&gt;
        &lt;button
          onClick={() =&gt; setCurrentScreen('home')}
          className=&quot;p-2 hover:bg-gray-100 rounded-full&quot;
        &gt;
          &lt;ArrowLeft className=&quot;w-6 h-6&quot; /&gt;
        &lt;/button&gt;
        &lt;h2 className=&quot;text-lg font-semibold&quot;&gt;Send Money&lt;/h2&gt;
      &lt;/div&gt;

      &lt;div className=&quot;p-6 space-y-6&quot;&gt;
        &lt;div className=&quot;bg-white rounded-xl shadow-sm p-6&quot;&gt;
          &lt;h3 className=&quot;text-lg font-semibold mb-4&quot;&gt;Enter Details&lt;/h3&gt;
          
          &lt;div className=&quot;space-y-4&quot;&gt;
            &lt;div&gt;
              &lt;label className=&quot;block text-sm font-medium text-gray-700 mb-2&quot;&gt;
                Recipient (UPI ID or Phone)
              &lt;/label&gt;
              &lt;input
                type=&quot;text&quot;
                value={recipient}
                onChange={(e) =&gt; setRecipient(e.target.value)}
                placeholder=&quot;john@paytm or 9876543210&quot;
                className=&quot;w-full p-3 border border-gray-300 rounded-lg focus:ring-2 focus:ring-blue-500 focus:border-transparent&quot;
              /&gt;
            &lt;/div&gt;

            &lt;div&gt;
              &lt;label className=&quot;block text-sm font-medium text-gray-700 mb-2&quot;&gt;
                Amount (₹)
              &lt;/label&gt;
              &lt;input
                type=&quot;number&quot;
                value={paymentAmount}
                onChange={(e) =&gt; setPaymentAmount(e.target.value)}
                placeholder=&quot;Enter amount&quot;
                className=&quot;w-full p-3 border border-gray-300 rounded-lg focus:ring-2 focus:ring-blue-500 focus:border-transparent&quot;
              /&gt;
            &lt;/div&gt;

            &lt;div&gt;
              &lt;label className=&quot;block text-sm font-medium text-gray-700 mb-2&quot;&gt;
                UPI PIN
              &lt;/label&gt;
              &lt;input
                type=&quot;password&quot;
                value={pin}
                onChange={(e) =&gt; setPin(e.target.value)}
                placeholder=&quot;Enter 4-digit PIN&quot;
                maxLength=&quot;4&quot;
                className=&quot;w-full p-3 border border-gray-300 rounded-lg focus:ring-2 focus:ring-blue-500 focus:border-transparent&quot;
              /&gt;
              &lt;p className=&quot;text-xs text-gray-500 mt-1&quot;&gt;Demo PIN: 1234&lt;/p&gt;
            &lt;/div&gt;
          &lt;/div&gt;

          &lt;button
            onClick={handlePayment}
            disabled={!paymentAmount || !recipient || !pin || isProcessing}
            className=&quot;w-full mt-6 bg-gradient-to-r from-blue-600 to-indigo-600 text-white py-3 rounded-lg font-semibold hover:from-blue-700 hover:to-indigo-700 disabled:opacity-50 disabled:cursor-not-allowed flex items-center justify-center space-x-2&quot;
          &gt;
            {isProcessing ? (
              &lt;&gt;
                &lt;div className=&quot;w-5 h-5 border-2 border-white border-t-transparent rounded-full animate-spin&quot;&gt;&lt;/div&gt;
                &lt;span&gt;Processing...&lt;/span&gt;
              &lt;/&gt;
            ) : (
              &lt;&gt;
                &lt;Send className=&quot;w-5 h-5&quot; /&gt;
                &lt;span&gt;Send Money&lt;/span&gt;
              &lt;/&gt;
            )}
          &lt;/button&gt;
        &lt;/div&gt;

        &lt;div className=&quot;bg-blue-50 border border-blue-200 rounded-xl p-4&quot;&gt;
          &lt;div className=&quot;flex items-start space-x-3&quot;&gt;
            &lt;Shield className=&quot;w-5 h-5 text-blue-600 mt-0.5&quot; /&gt;
            &lt;div&gt;
              &lt;h4 className=&quot;font-medium text-blue-900&quot;&gt;Secure Transaction&lt;/h4&gt;
              &lt;p className=&quot;text-sm text-blue-700&quot;&gt;Your payment is protected with bank-grade security&lt;/p&gt;
            &lt;/div&gt;
          &lt;/div&gt;
        &lt;/div&gt;
      &lt;/div&gt;
    &lt;/div&gt;
  );

  const simulateQRScan = () =&gt; {
    // Simulate QR code detection
    const mockQRData = {
      merchantName: &quot;Coffee House&quot;,
      upiId: &quot;coffehouse@paytm&quot;,
      amount: 150
    };
    
    setCameraActive(true);
    setTimeout(() =&gt; {
      setScannedData(mockQRData);
      setCameraActive(false);
    }, 3000);
  };

  const ScanPayScreen = () =&gt; {
    if (scannedData) {
      return (
        &lt;div className=&quot;min-h-screen bg-gray-50&quot;&gt;
          &lt;div className=&quot;bg-white shadow-sm p-4 flex items-center space-x-4&quot;&gt;
            &lt;button
              onClick={() =&gt; {
                setScannedData(null);
                setCurrentScreen('home');
              }}
              className=&quot;p-2 hover:bg-gray-100 rounded-full&quot;
            &gt;
              &lt;ArrowLeft className=&quot;w-6 h-6&quot; /&gt;
            &lt;/button&gt;
            &lt;h2 className=&quot;text-lg font-semibold&quot;&gt;Payment Details&lt;/h2&gt;
          &lt;/div&gt;

          &lt;div className=&quot;p-6 space-y-6&quot;&gt;
            &lt;div className=&quot;bg-white rounded-xl shadow-sm p-6&quot;&gt;
              &lt;div className=&quot;text-center mb-6&quot;&gt;
                &lt;div className=&quot;w-16 h-16 bg-green-100 rounded-full flex items-center justify-center mx-auto mb-4&quot;&gt;
                  &lt;Check className=&quot;w-8 h-8 text-green-600&quot; /&gt;
                &lt;/div&gt;
                &lt;h3 className=&quot;text-lg font-semibold text-gray-800&quot;&gt;QR Code Scanned Successfully&lt;/h3&gt;
              &lt;/div&gt;

              &lt;div className=&quot;bg-gray-50 rounded-lg p-4 mb-6&quot;&gt;
                &lt;div className=&quot;flex justify-between items-center mb-2&quot;&gt;
                  &lt;span className=&quot;text-gray-600&quot;&gt;Merchant:&lt;/span&gt;
                  &lt;span className=&quot;font-semibold&quot;&gt;{scannedData.merchantName}&lt;/span&gt;
                &lt;/div&gt;
                &lt;div className=&quot;flex justify-between items-center

  const TransactionHistory = () =&gt; (
    &lt;div className=&quot;min-h-screen bg-gray-50&quot;&gt;
      &lt;div className=&quot;bg-white shadow-sm p-4 flex items-center space-x-4&quot;&gt;
        &lt;button
          onClick={() =&gt; setCurrentScreen('home')}
          className=&quot;p-2 hover:bg-gray-100 rounded-full&quot;
        &gt;
          &lt;ArrowLeft className=&quot;w-6 h-6&quot; /&gt;
        &lt;/button&gt;
        &lt;h2 className=&quot;text-lg font-semibold&quot;&gt;Transaction History&lt;/h2&gt;
      &lt;/div&gt;

      &lt;div className=&quot;p-6&quot;&gt;
        &lt;div className=&quot;bg-white rounded-xl shadow-sm&quot;&gt;
          &lt;div className=&quot;p-6 border-b border-gray-200&quot;&gt;
            &lt;h3 className=&quot;text-lg font-semibold&quot;&gt;All Transactions&lt;/h3&gt;
          &lt;/div&gt;
          &lt;div className=&quot;divide-y divide-gray-200&quot;&gt;
            {transactions.map((transaction) =&gt; (
              &lt;div key={transaction.id} className=&quot;p-6 flex items-center justify-between&quot;&gt;
                &lt;div className=&quot;flex items-center space-x-4&quot;&gt;
                  &lt;div className={`w-12 h-12 rounded-full flex items-center justify-center ${
                    transaction.type === 'sent' ? 'bg-red-100' : 'bg-green-100'
                  }`}&gt;
                    &lt;Send className={`w-6 h-6 ${
                      transaction.type === 'sent' ? 'text-red-600 rotate-45' : 'text-green-600 -rotate-45'
                    }`} /&gt;
                  &lt;/div&gt;
                  &lt;div&gt;
                    &lt;p className=&quot;font-medium text-gray-800&quot;&gt;
                      {transaction.type === 'sent' ? `To ${transaction.recipient}` : `From ${transaction.sender}`}
                    &lt;/p&gt;
                    &lt;p className=&quot;text-sm text-gray-500&quot;&gt;{transaction.time}&lt;/p&gt;
                    &lt;div className=&quot;flex items-center space-x-1 mt-1&quot;&gt;
                      &lt;Check className=&quot;w-3 h-3 text-green-500&quot; /&gt;
                      &lt;span className=&quot;text-xs text-green-600&quot;&gt;Success&lt;/span&gt;
                    &lt;/div&gt;
                  &lt;/div&gt;
                &lt;/div&gt;
                &lt;span className={`text-lg font-semibold ${
                  transaction.type === 'sent' ? 'text-red-600' : 'text-green-600'
                }`}&gt;
                  {transaction.type === 'sent' ? '-' : '+'}₹{transaction.amount}
                &lt;/span&gt;
              &lt;/div&gt;
            ))}
          &lt;/div&gt;
        &lt;/div&gt;
      &lt;/div&gt;
    &lt;/div&gt;
  );

  const SuccessScreen = () =&gt; (
    &lt;div className=&quot;min-h-screen bg-gradient-to-br from-green-50 to-emerald-100 flex items-center justify-center p-6&quot;&gt;
      &lt;div className=&quot;bg-white rounded-xl shadow-lg p-8 text-center max-w-sm w-full&quot;&gt;
        &lt;div className=&quot;w-20 h-20 bg-gradient-to-br from-green-500 to-emerald-500 rounded-full flex items-center justify-center mx-auto mb-6&quot;&gt;
          &lt;Check className=&quot;w-10 h-10 text-white&quot; /&gt;
        &lt;/div&gt;
        
        &lt;h3 className=&quot;text-2xl font-bold text-gray-800 mb-2&quot;&gt;Payment Successful!&lt;/h3&gt;
        &lt;p className=&quot;text-gray-600 mb-4&quot;&gt;₹{paymentAmount} sent to {recipient}&lt;/p&gt;
        
        &lt;div className=&quot;bg-gray-50 rounded-lg p-4 mb-6&quot;&gt;
          &lt;p className=&quot;text-sm text-gray-500&quot;&gt;Transaction ID&lt;/p&gt;
          &lt;p className=&quot;font-mono text-sm font-medium&quot;&gt;UPI{Date.now()}&lt;/p&gt;
        &lt;/div&gt;
        
        &lt;div className=&quot;w-full h-1 bg-green-200 rounded-full overflow-hidden&quot;&gt;
          &lt;div className=&quot;h-full bg-green-500 rounded-full animate-pulse&quot;&gt;&lt;/div&gt;
        &lt;/div&gt;
      &lt;/div&gt;
    &lt;/div&gt;
  );

  if (showSuccess) return &lt;SuccessScreen /&gt;;

  switch (currentScreen) {
    case 'home':
      return &lt;HomeScreen /&gt;;
    case 'send':
      return &lt;SendMoneyScreen /&gt;;
    case 'scan':
      return &lt;ScanPayScreen /&gt;;
    case 'history':
      return &lt;TransactionHistory /&gt;;
    default:
      return &lt;HomeScreen /&gt;;
  }
};

export default UPIPaymentApp;
import React, { useState, useEffect } from 'react';
import {
CreditCard,
Send,
QrCode,
User,
History,
Eye,
EyeOff,
ArrowLeft,
Check,
X,
Smartphone,
Shield,
Zap
} from 'lucide-react';
const UPIPaymentApp = () => {
const [currentScreen, setCurrentScreen] = useState('home');
const [showBalance, setShowBalance] = useState(false);
const [balance, setBalance] = useState(25430.50);
const [pin, setPin] = useState('');
const [paymentAmount, setPaymentAmount] = useState('');
const [recipient, setRecipient] = useState('');
const [isProcessing, setIsProcessing] = useState(false);
const [showSuccess, setShowSuccess] = useState(false);
const [cameraActive, setCameraActive] = useState(false);
const [scannedData, setScannedData] = useState(null);
const [stream, setStream] = useState(null);
const [scanError, setScanError] = useState('');
const [transactions] = useState([
{ id: 1, type: 'sent', amount: 500, recipient: 'John Doe', time: '10:30 AM', status: 'success' },
{ id: 2, type: 'received', amount: 1200, sender: 'Sarah Wilson', time: '9:15 AM', status: 'success' },
{ id: 3, type: 'sent', amount: 300, recipient: 'Coffee Shop', time: 'Yesterday', status: 'success' },
{ id: 4, type: 'received', amount: 2500, sender: 'Freelance Payment', time: '2 days ago', status: 'success' }
]);
const handlePayment = () => {
if (paymentAmount && recipient && pin === '1234') {
setIsProcessing(true);
setTimeout(() => {
setBalance(prev => prev - parseFloat(paymentAmount));
setIsProcessing(false);
setShowSuccess(true);
setTimeout(() => {
setShowSuccess(false);
setCurrentScreen('home');
setPaymentAmount('');
setRecipient('');
setPin('');
}, 2000);
}, 2000);
}
};
const HomeScreen = () => (
<div className="min-h-screen bg-gradient-to-br from-blue-50 to-indigo-100">
{/* Header */}
<div className="bg-gradient-to-r from-blue-600 to-indigo-700 text-white p-6 pb-8">
<div className="flex items-center justify-between mb-6">
<div className="flex items-center space-x-3">
<div className="w-10 h-10 bg-white/20 rounded-full flex items-center justify-center">
<Zap className="w-6 h-6" />
</div>
<div>
<h1 className="text-xl font-bold">PayEasy</h1>
<p className="text-blue-100 text-sm">Your UPI Wallet</p>
</div>
</div>
<div className="w-10 h-10 bg-white/20 rounded-full flex items-center justify-center">
<User className="w-6 h-6" />
</div>
</div>
{/* Balance Card */}
<div className="bg-white/10 backdrop-blur-sm rounded-xl p-4 border border-white/20">
<div className="flex items-center justify-between">
<div>
<p className="text-blue-100 text-sm mb-1">Total Balance</p>
<div className="flex items-center space-x-2">
<span className="text-2xl font-bold">
{showBalance ? `₹${balance.toLocaleString()}` : '₹••••••'}
</span>
<button
onClick={() => setShowBalance(!showBalance)}
className="p-1 hover:bg-white/10 rounded"
>
{showBalance ? <EyeOff className="w-4 h-4" /> : <Eye className="w-4 h-4" />}
</button>
</div>
</div>
<div className="w-12 h-12 bg-gradient-to-br from-green-400 to-emerald-500 rounded-xl flex items-center justify-center">
<CreditCard className="w-6 h-6 text-white" />
</div>
</div>
</div>
</div>
{/* Quick Actions */}
<div className="px-6 -mt-4 mb-6">
<div className="bg-white rounded-xl shadow-lg p-6">
<h3 className="text-lg font-semibold mb-4 text-gray-800">Quick Actions</h3>
<div className="grid grid-cols-2 gap-4">
<button
onClick={() => setCurrentScreen('send')}
className="flex flex-col items-center p-4 bg-gradient-to-br from-blue-50 to-blue-100 rounded-xl hover:shadow-md transition-all duration-200 group"
>
<div className="w-12 h-12 bg-blue-500 rounded-xl flex items-center justify-center mb-2 group-hover:scale-110 transition-transform">
<Send className="w-6 h-6 text-white" />
</div>
<span className="font-medium text-gray-800">Send Money</span>
</button>
<button
onClick={() => setCurrentScreen('scan')}
className="flex flex-col items-center p-4 bg-gradient-to-br from-purple-50 to-purple-100 rounded-xl hover:shadow-md transition-all duration-200 group"
>
<div className="w-12 h-12 bg-purple-500 rounded-xl flex items-center justify-center mb-2 group-hover:scale-110 transition-transform">
<QrCode className="w-6 h-6 text-white" />
</div>
<span className="font-medium text-gray-800">Scan & Pay</span>
</button>
</div>
</div>
</div>
{/* Recent Transactions */}
<div className="px-6">
<div className="bg-white rounded-xl shadow-lg p-6">
<div className="flex items-center justify-between mb-4">
<h3 className="text-lg font-semibold text-gray-800">Recent Transactions</h3>
<button
onClick={() => setCurrentScreen('history')}
className="text-blue-600 text-sm font-medium hover:text-blue-700"
>
View All
</button>
</div>
<div className="space-y-3">
{transactions.slice(0, 3).map((transaction) => (
<div key={transaction.id} className="flex items-center justify-between p-3 bg-gray-50 rounded-lg">
<div className="flex items-center space-x-3">
<div className={`w-10 h-10 rounded-full flex items-center justify-center ${
transaction.type === 'sent' ? 'bg-red-100' : 'bg-green-100'
}`}>
<Send className={`w-5 h-5 ${
transaction.type === 'sent' ? 'text-red-600 rotate-45' : 'text-green-600 -rotate-45'
}`} />
</div>
<div>
<p className="font-medium text-gray-800">
{transaction.type === 'sent' ? transaction.recipient : transaction.sender}
</p>
<p className="text-sm text-gray-500">{transaction.time}</p>
</div>
</div>
<span className={`font-semibold ${
transaction.type === 'sent' ? 'text-red-600' : 'text-green-600'
}`}>
{transaction.type === 'sent' ? '-' : '+'}₹{transaction.amount}
</span>
</div>
))}
</div>
</div>
</div>
</div>
);
const SendMoneyScreen = () => (
<div className="min-h-screen bg-gray-50">
<div className="bg-white shadow-sm p-4 flex items-center space-x-4">
<button
onClick={() => setCurrentScreen('home')}
className="p-2 hover:bg-gray-100 rounded-full"
>
<ArrowLeft className="w-6 h-6" />
</button>
<h2 className="text-lg font-semibold">Send Money</h2>
</div>
<div className="p-6 space-y-6">
<div className="bg-white rounded-xl shadow-sm p-6">
<h3 className="text-lg font-semibold mb-4">Enter Details</h3>
<div className="space-y-4">
<div>
<label className="block text-sm font-medium text-gray-700 mb-2">
Recipient (UPI ID or Phone)
</label>
<input
type="text"
value={recipient}
onChange={(e) => setRecipient(e.target.value)}
placeholder="john@paytm or 9876543210"
className="w-full p-3 border border-gray-300 rounded-lg focus:ring-2 focus:ring-blue-500 focus:border-transparent"
/>
</div>
<div>
<label className="block text-sm font-medium text-gray-700 mb-2">
Amount (₹)
</label>
<input
type="number"
value={paymentAmount}
onChange={(e) => setPaymentAmount(e.target.value)}
placeholder="Enter amount"
className="w-full p-3 border border-gray-300 rounded-lg focus:ring-2 focus:ring-blue-500 focus:border-transparent"
/>
</div>
<div>
<label className="block text-sm font-medium text-gray-700 mb-2">
UPI PIN
</label>
<input
type="password"
value={pin}
onChange={(e) => setPin(e.target.value)}
placeholder="Enter 4-digit PIN"
maxLength="4"
className="w-full p-3 border border-gray-300 rounded-lg focus:ring-2 focus:ring-blue-500 focus:border-transparent"
/>
<p className="text-xs text-gray-500 mt-1">Demo PIN: 1234</p>
</div>
</div>
<button
onClick={handlePayment}
disabled={!paymentAmount || !recipient || !pin || isProcessing}
className="w-full mt-6 bg-gradient-to-r from-blue-600 to-indigo-600 text-white py-3 rounded-lg font-semibold hover:from-blue-700 hover:to-indigo-700 disabled:opacity-50 disabled:cursor-not-allowed flex items-center justify-center space-x-2"
>
{isProcessing ? (
<>
<div className="w-5 h-5 border-2 border-white border-t-transparent rounded-full animate-spin"></div>
<span>Processing...</span>
</>
) : (
<>
<Send className="w-5 h-5" />
<span>Send Money</span>
</>
)}
</button>
</div>
<div className="bg-blue-50 border border-blue-200 rounded-xl p-4">
<div className="flex items-start space-x-3">
<Shield className="w-5 h-5 text-blue-600 mt-0.5" />
<div>
<h4 className="font-medium text-blue-900">Secure Transaction</h4>
<p className="text-sm text-blue-700">Your payment is protected with bank-grade security</p>
</div>
</div>
</div>
</div>
</div>
);
const simulateQRScan = () => {
// Simulate QR code detection
const mockQRData = {
merchantName: "Coffee House",
upiId: "coffehouse@paytm",
amount: 150
};
setCameraActive(true);
setTimeout(() => {
setScannedData(mockQRData);
setCameraActive(false);
}, 3000);
};
const ScanPayScreen = () => {
if (scannedData) {
return (
<div className="min-h-screen bg-gray-50">
<div className="bg-white shadow-sm p-4 flex items-center space-x-4">
<button
onClick={() => {
setScannedData(null);
setCurrentScreen('home');
}}
className="p-2 hover:bg-gray-100 rounded-full"
>
<ArrowLeft className="w-6 h-6" />
</button>
<h2 className="text-lg font-semibold">Payment Details</h2>
</div>
<div className="p-6 space-y-6">
<div className="bg-white rounded-xl shadow-sm p-6">
<div className="text-center mb-6">
<div className="w-16 h-16 bg-green-100 rounded-full flex items-center justify-center mx-auto mb-4">
<Check className="w-8 h-8 text-green-600" />
</div>
<h3 className="text-lg font-semibold text-gray-800">QR Code Scanned Successfully</h3>
</div>
<div className="bg-gray-50 rounded-lg p-4 mb-6">
<div className="flex justify-between items-center mb-2">
<span className="text-gray-600">Merchant:</span>
<span className="font-semibold">{scannedData.merchantName}</span>
</div>
<div className="flex justify-between items-center
const TransactionHistory = () => (
<div className="min-h-screen bg-gray-50">
<div className="bg-white shadow-sm p-4 flex items-center space-x-4">
<button
onClick={() => setCurrentScreen('home')}
className="p-2 hover:bg-gray-100 rounded-full"
>
<ArrowLeft className="w-6 h-6" />
</button>
<h2 className="text-lg font-semibold">Transaction History</h2>
</div>
<div className="p-6">
<div className="bg-white rounded-xl shadow-sm">
<div className="p-6 border-b border-gray-200">
<h3 className="text-lg font-semibold">All Transactions</h3>
</div>
<div className="divide-y divide-gray-200">
{transactions.map((transaction) => (
<div key={transaction.id} className="p-6 flex items-center justify-between">
<div className="flex items-center space-x-4">
<div className={`w-12 h-12 rounded-full flex items-center justify-center ${
transaction.type === 'sent' ? 'bg-red-100' : 'bg-green-100'
}`}>
<Send className={`w-6 h-6 ${
transaction.type === 'sent' ? 'text-red-600 rotate-45' : 'text-green-600 -rotate-45'
}`} />
</div>
<div>
<p className="font-medium text-gray-800">
{transaction.type === 'sent' ? `To ${transaction.recipient}` : `From ${transaction.sender}`}
</p>
<p className="text-sm text-gray-500">{transaction.time}</p>
<div className="flex items-center space-x-1 mt-1">
<Check className="w-3 h-3 text-green-500" />
<span className="text-xs text-green-600">Success</span>
</div>
</div>
</div>
<span className={`text-lg font-semibold ${
transaction.type === 'sent' ? 'text-red-600' : 'text-green-600'
}`}>
{transaction.type === 'sent' ? '-' : '+'}₹{transaction.amount}
</span>
</div>
))}
</div>
</div>
</div>
</div>
);
const SuccessScreen = () => (
<div className="min-h-screen bg-gradient-to-br from-green-50 to-emerald-100 flex items-center justify-center p-6">
<div className="bg-white rounded-xl shadow-lg p-8 text-center max-w-sm w-full">
<div className="w-20 h-20 bg-gradient-to-br from-green-500 to-emerald-500 rounded-full flex items-center justify-center mx-auto mb-6">
<Check className="w-10 h-10 text-white" />
</div>
<h3 className="text-2xl font-bold text-gray-800 mb-2">Payment Successful!</h3>
<p className="text-gray-600 mb-4">₹{paymentAmount} sent to {recipient}</p>
<div className="bg-gray-50 rounded-lg p-4 mb-6">
<p className="text-sm text-gray-500">Transaction ID</p>
<p className="font-mono text-sm font-medium">UPI{Date.now()}</p>
</div>
<div className="w-full h-1 bg-green-200 rounded-full overflow-hidden">
<div className="h-full bg-green-500 rounded-full animate-pulse"></div>
</div>
</div>
</div>
);
if (showSuccess) return <SuccessScreen />;
switch (currentScreen) {
case 'home':
return <HomeScreen />;
case 'send':
return <SendMoneyScreen />;
case 'scan':
return <ScanPayScreen />;
case 'history':
return <TransactionHistory />;
default:
return <HomeScreen />;
}
};
export default UPIPaymentApp;