File size: 2,407 Bytes
8d3471e
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
import { Lock } from 'lucide-react'

export default function SecuritySection({
    t,
    form,
    setForm,
    newPassword,
    setNewPassword,
    changingPassword,
    onUpdatePassword,
}) {
    return (
        <div className="bg-card border border-border rounded-xl p-5 space-y-4">
            <h3 className="font-semibold">{t('settings.securityTitle')}</h3>
            <div className="grid grid-cols-1 md:grid-cols-2 gap-4">
                <label className="text-sm space-y-2">
                    <span className="text-muted-foreground">{t('settings.jwtExpireHours')}</span>
                    <input
                        type="number"
                        min={1}
                        max={720}
                        value={form.admin.jwt_expire_hours}
                        onChange={(e) => setForm((prev) => ({
                            ...prev,
                            admin: { ...prev.admin, jwt_expire_hours: Number(e.target.value || 1) },
                        }))}
                        className="w-full bg-background border border-border rounded-lg px-3 py-2"
                    />
                </label>
                <label className="text-sm space-y-2">
                    <span className="text-muted-foreground">{t('settings.newPassword')}</span>
                    <div className="flex gap-2">
                        <input
                            type="password"
                            value={newPassword}
                            onChange={(e) => setNewPassword(e.target.value)}
                            placeholder={t('settings.newPasswordPlaceholder')}
                            className="w-full bg-background border border-border rounded-lg px-3 py-2"
                        />
                        <button
                            type="button"
                            onClick={onUpdatePassword}
                            disabled={changingPassword}
                            className="px-3 py-2 rounded-lg bg-secondary border border-border hover:bg-secondary/80 text-sm flex items-center gap-1"
                        >
                            <Lock className="w-4 h-4" />
                            {changingPassword ? t('settings.updating') : t('settings.updatePassword')}
                        </button>
                    </div>
                </label>
            </div>
        </div>
    )
}