Redesign login page - mobile-friendly with step-by-step guide
This commit is contained in:
parent
3d90735c4a
commit
7f7b41ff05
1 changed files with 102 additions and 65 deletions
|
|
@ -585,83 +585,120 @@ export const Feed: React.FC = () => {
|
|||
// ========== LOGIN VIEW ==========
|
||||
if (viewState === 'login') {
|
||||
return (
|
||||
<div className="min-h-screen bg-gradient-to-br from-gray-950 via-black to-gray-950 flex items-center justify-center p-6">
|
||||
<div className="w-full max-w-md">
|
||||
{/* Logo */}
|
||||
<div className="text-center mb-10">
|
||||
<div className="relative inline-block mb-4">
|
||||
<div className="w-20 h-20 bg-gradient-to-r from-cyan-400 to-pink-500 rounded-2xl rotate-12 absolute -inset-1 blur-lg opacity-50" />
|
||||
<div className="relative w-20 h-20 bg-gradient-to-r from-cyan-400 to-pink-500 rounded-2xl flex items-center justify-center">
|
||||
<svg className="w-10 h-10 text-white" viewBox="0 0 24 24" fill="currentColor">
|
||||
<path d="M12 3v10.55c-.59-.34-1.27-.55-2-.55-2.21 0-4 1.79-4 4s1.79 4 4 4 4-1.79 4-4V7h4V3h-6z" />
|
||||
</svg>
|
||||
<div className="min-h-screen bg-gradient-to-br from-gray-950 via-black to-gray-950 flex flex-col">
|
||||
{/* Header */}
|
||||
<div className="flex-shrink-0 pt-12 pb-6 px-6 text-center">
|
||||
<div className="relative inline-block mb-4">
|
||||
<div className="w-16 h-16 bg-gradient-to-r from-cyan-400 to-pink-500 rounded-2xl rotate-12 absolute -inset-1 blur-lg opacity-50" />
|
||||
<div className="relative w-16 h-16 bg-gradient-to-r from-cyan-400 to-pink-500 rounded-2xl flex items-center justify-center">
|
||||
<svg className="w-8 h-8 text-white" viewBox="0 0 24 24" fill="currentColor">
|
||||
<path d="M12 3v10.55c-.59-.34-1.27-.55-2-.55-2.21 0-4 1.79-4 4s1.79 4 4 4 4-1.79 4-4V7h4V3h-6z" />
|
||||
</svg>
|
||||
</div>
|
||||
</div>
|
||||
<h1 className="text-2xl font-bold text-white mb-1">PureStream</h1>
|
||||
<p className="text-gray-500 text-sm">Ad-free TikTok viewing</p>
|
||||
</div>
|
||||
|
||||
{/* Scrollable Content */}
|
||||
<div className="flex-1 overflow-y-auto px-5 pb-8">
|
||||
<div className="max-w-sm mx-auto">
|
||||
{error && (
|
||||
<div className="mb-5 p-4 bg-red-500/10 border border-red-500/20 rounded-2xl text-red-400 text-sm text-center">
|
||||
{error}
|
||||
</div>
|
||||
)}
|
||||
|
||||
{/* How to Login - Step by Step */}
|
||||
<div className="mb-6">
|
||||
<h2 className="text-white font-semibold text-lg mb-4 text-center">How to Login</h2>
|
||||
|
||||
<div className="space-y-3">
|
||||
<div className="flex items-start gap-3 p-3 bg-white/5 rounded-xl">
|
||||
<div className="w-7 h-7 bg-cyan-500 rounded-full flex items-center justify-center flex-shrink-0 text-white font-bold text-sm">1</div>
|
||||
<div>
|
||||
<p className="text-white text-sm font-medium">Open TikTok in browser</p>
|
||||
<p className="text-gray-500 text-xs mt-0.5">Use Chrome/Safari on your phone or computer</p>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div className="flex items-start gap-3 p-3 bg-white/5 rounded-xl">
|
||||
<div className="w-7 h-7 bg-pink-500 rounded-full flex items-center justify-center flex-shrink-0 text-white font-bold text-sm">2</div>
|
||||
<div>
|
||||
<p className="text-white text-sm font-medium">Export your cookies</p>
|
||||
<p className="text-gray-500 text-xs mt-0.5">Use "Cookie-Editor" extension (Chrome/Firefox)</p>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div className="flex items-start gap-3 p-3 bg-white/5 rounded-xl">
|
||||
<div className="w-7 h-7 bg-purple-500 rounded-full flex items-center justify-center flex-shrink-0 text-white font-bold text-sm">3</div>
|
||||
<div>
|
||||
<p className="text-white text-sm font-medium">Paste cookies below</p>
|
||||
<p className="text-gray-500 text-xs mt-0.5">Copy the JSON and paste it here</p>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<h1 className="text-3xl font-bold text-white mb-2">PureStream</h1>
|
||||
<p className="text-gray-500">Distraction-free TikTok viewing</p>
|
||||
</div>
|
||||
|
||||
{error && (
|
||||
<div className="mb-6 p-4 bg-red-500/10 border border-red-500/20 rounded-xl text-red-400 text-sm text-center">
|
||||
{error}
|
||||
{/* Cookie Input */}
|
||||
<div className="mb-4">
|
||||
<textarea
|
||||
value={jsonInput}
|
||||
onChange={(e) => setJsonInput(e.target.value)}
|
||||
placeholder='Paste your cookie JSON here...'
|
||||
className="w-full h-32 bg-black/60 border-2 border-white/10 rounded-2xl p-4 text-white text-sm font-mono resize-none focus:outline-none focus:border-cyan-500/50 placeholder:text-gray-600"
|
||||
/>
|
||||
</div>
|
||||
)}
|
||||
|
||||
{/* Info for Docker/Server users */}
|
||||
<div className="mb-6 p-4 bg-cyan-500/10 border border-cyan-500/20 rounded-xl">
|
||||
<p className="text-cyan-400 text-sm text-center mb-2">
|
||||
🐳 <strong>Docker/Server Users</strong>
|
||||
</p>
|
||||
<p className="text-gray-400 text-xs text-center">
|
||||
Use the <strong>Manual Login</strong> below. Browser login only works on local machines with a display.
|
||||
</p>
|
||||
</div>
|
||||
|
||||
{/* Manual Login - Primary for Docker */}
|
||||
<div className="p-4 bg-white/5 rounded-xl border border-white/10 mb-4">
|
||||
<label className="block text-gray-300 text-sm font-medium mb-3">
|
||||
📋 Paste TikTok Cookies (Recommended)
|
||||
</label>
|
||||
<textarea
|
||||
value={jsonInput}
|
||||
onChange={(e) => setJsonInput(e.target.value)}
|
||||
placeholder='{"http": {"headers": {...}, "cookies": {...}}}'
|
||||
className="w-full h-28 bg-black/50 border border-white/10 rounded-lg p-3 text-white text-xs font-mono resize-none focus:outline-none focus:border-cyan-500/50 mb-3"
|
||||
/>
|
||||
{/* Connect Button */}
|
||||
<button
|
||||
onClick={handleJsonLogin}
|
||||
className="w-full py-3 bg-gradient-to-r from-cyan-500 to-pink-500 hover:from-cyan-400 hover:to-pink-400 text-white font-semibold rounded-xl transition-all transform hover:scale-[1.02] active:scale-[0.98] shadow-lg shadow-pink-500/20"
|
||||
disabled={!jsonInput.trim()}
|
||||
className={`w-full py-4 text-white font-semibold rounded-2xl transition-all transform active:scale-[0.98] shadow-lg text-base ${jsonInput.trim()
|
||||
? 'bg-gradient-to-r from-cyan-500 to-pink-500 hover:from-cyan-400 hover:to-pink-400 shadow-pink-500/20'
|
||||
: 'bg-gray-700 cursor-not-allowed'
|
||||
}`}
|
||||
>
|
||||
Connect with Cookies
|
||||
Connect to TikTok
|
||||
</button>
|
||||
<p className="text-gray-500 text-xs text-center mt-3">
|
||||
Export cookies from TikTok using a browser extension like "EditThisCookie" or "Cookie-Editor"
|
||||
</p>
|
||||
</div>
|
||||
|
||||
{/* Browser Login - Alternative */}
|
||||
<div className="text-center">
|
||||
<button
|
||||
onClick={() => setShowAdvanced(!showAdvanced)}
|
||||
className="text-gray-500 hover:text-gray-400 text-sm py-2"
|
||||
>
|
||||
{showAdvanced ? '▲ Hide Browser Login' : '▼ Try Browser Login (Local Only)'}
|
||||
</button>
|
||||
</div>
|
||||
|
||||
{showAdvanced && (
|
||||
<div className="mt-4">
|
||||
<button
|
||||
onClick={handleBrowserLogin}
|
||||
className="w-full py-3 px-6 bg-white/10 hover:bg-white/20 text-white rounded-xl transition-all text-sm"
|
||||
{/* Help Link */}
|
||||
<div className="mt-6 text-center">
|
||||
<a
|
||||
href="https://chrome.google.com/webstore/detail/cookie-editor/hlkenndednhfkekhgcdicdfddnkalmdm"
|
||||
target="_blank"
|
||||
rel="noopener noreferrer"
|
||||
className="text-cyan-400 text-sm underline"
|
||||
>
|
||||
Open TikTok Login Window
|
||||
</button>
|
||||
<p className="text-center text-gray-600 text-xs mt-2">
|
||||
⚠️ Only works when running locally with a display
|
||||
</p>
|
||||
Get Cookie-Editor Extension →
|
||||
</a>
|
||||
</div>
|
||||
)}
|
||||
|
||||
{/* Desktop Browser Login - Hidden by default */}
|
||||
<div className="mt-8 pt-6 border-t border-white/10">
|
||||
<button
|
||||
onClick={() => setShowAdvanced(!showAdvanced)}
|
||||
className="w-full text-gray-500 hover:text-gray-400 text-sm py-2 flex items-center justify-center gap-2"
|
||||
>
|
||||
<span>{showAdvanced ? '▲' : '▼'}</span>
|
||||
<span>Desktop Browser Login</span>
|
||||
</button>
|
||||
|
||||
{showAdvanced && (
|
||||
<div className="mt-3 p-4 bg-white/5 rounded-xl">
|
||||
<p className="text-gray-400 text-xs text-center mb-3">
|
||||
⚠️ Only works on local machines with a display
|
||||
</p>
|
||||
<button
|
||||
onClick={handleBrowserLogin}
|
||||
className="w-full py-3 bg-white/10 hover:bg-white/20 text-white rounded-xl transition-all text-sm"
|
||||
>
|
||||
Open TikTok Login Window
|
||||
</button>
|
||||
</div>
|
||||
)}
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
);
|
||||
|
|
|
|||
Loading…
Reference in a new issue