|
1 | | -{% extends '_base.html' %} |
2 | | -{% load page_tags %} |
| 1 | +{% extends 'account/_settings_base.html' %} |
3 | 2 |
|
4 | 3 | {% block title %}个人资料{% endblock %} |
5 | 4 |
|
6 | | -{% block content %} |
7 | | -{% page_header title breadcrumbs %} |
8 | | - |
9 | | -<div class="grid grid-cols-1 lg:grid-cols-3 gap-4"> |
10 | | - <div class="card bg-base-100 shadow-sm border border-base-200 lg:col-span-2"> |
11 | | - <div class="card-body"> |
12 | | - <h2 class="card-title">基本信息</h2> |
13 | | - <form method="post" class="space-y-4" enctype="multipart/form-data" novalidate> |
14 | | - {% csrf_token %} |
15 | | - |
16 | | - <div class="space-y-1"> |
17 | | - <label class="label" for="{{ form.full_name.id_for_label }}"> |
18 | | - <span class="label-text">{{ form.full_name.label }}</span> |
19 | | - </label> |
20 | | - {{ form.full_name }} |
21 | | - {% if form.full_name.errors %} |
22 | | - <p class="text-sm text-error">{{ form.full_name.errors|join:', ' }}</p> |
23 | | - {% endif %} |
| 5 | +{% block settings_content %} |
| 6 | +<div class="card bg-base-100 shadow-sm border border-base-200"> |
| 7 | + <div class="card-body"> |
| 8 | + <h2 class="card-title text-xl mb-4">基本信息</h2> |
| 9 | + |
| 10 | + <form method="post" enctype="multipart/form-data" novalidate class="space-y-6"> |
| 11 | + {% csrf_token %} |
| 12 | + |
| 13 | + <!-- Avatar Section --> |
| 14 | + <div class="flex flex-col sm:flex-row items-center gap-6"> |
| 15 | + <div class="avatar placeholder"> |
| 16 | + <div class="w-24 rounded-full bg-neutral text-neutral-content ring ring-base-200 ring-offset-base-100 ring-offset-2 overflow-hidden"> |
| 17 | + {% if user.profile.avatar %} |
| 18 | + <img src="{{ user.profile.avatar.url }}" alt="{{ user.username }}" class="object-cover" /> |
| 19 | + {% else %} |
| 20 | + <span class="text-3xl">{{ user.username|slice:":1"|upper }}</span> |
| 21 | + {% endif %} |
| 22 | + </div> |
24 | 23 | </div> |
25 | | - |
26 | | - <div class="space-y-1"> |
27 | | - <label class="label" for="{{ form.gender.id_for_label }}"> |
28 | | - <span class="label-text">{{ form.gender.label }}</span> |
| 24 | + <div class="form-control w-full max-w-xs"> |
| 25 | + <label class="label"> |
| 26 | + <span class="label-text font-medium">更换头像</span> |
29 | 27 | </label> |
30 | | - {{ form.gender }} |
31 | | - {% if form.gender.errors %} |
32 | | - <p class="text-sm text-error">{{ form.gender.errors|join:', ' }}</p> |
| 28 | + {{ form.avatar }} |
| 29 | + {% if form.avatar.errors %} |
| 30 | + <p class="text-sm text-error mt-1">{{ form.avatar.errors|join:', ' }}</p> |
33 | 31 | {% endif %} |
| 32 | + <p class="text-xs text-base-content/50 mt-1">支持 JPG, PNG, GIF 格式。</p> |
34 | 33 | </div> |
| 34 | + </div> |
35 | 35 |
|
36 | | - <div class="space-y-1"> |
37 | | - <label class="label" for="{{ form.phone.id_for_label }}"> |
38 | | - <span class="label-text">{{ form.phone.label }}</span> |
39 | | - </label> |
40 | | - {{ form.phone }} |
41 | | - {% if form.phone.errors %} |
42 | | - <p class="text-sm text-error">{{ form.phone.errors|join:', ' }}</p> |
43 | | - {% endif %} |
44 | | - </div> |
| 36 | + <div class="divider"></div> |
45 | 37 |
|
46 | | - <div class="card-actions justify-end"> |
47 | | - <button type="submit" class="btn btn-primary">保存</button> |
48 | | - </div> |
49 | | - </form> |
50 | | - </div> |
51 | | - </div> |
| 38 | + <div class="grid grid-cols-1 md:grid-cols-2 gap-6"> |
| 39 | + {% include 'account/_components/form_field.html' with field=form.full_name %} |
| 40 | + {% include 'account/_components/form_field.html' with field=form.title %} |
| 41 | + </div> |
52 | 42 |
|
53 | | - <div class="card bg-base-100 shadow-sm border border-base-200"> |
54 | | - <div class="card-body"> |
55 | | - <h2 class="card-title">账号信息</h2> |
56 | | - <div class="space-y-3 text-sm"> |
57 | | - <div class="flex items-center justify-between gap-4"> |
58 | | - <span class="opacity-70">用户名</span> |
59 | | - <span class="font-medium">{{ request.user.username }}</span> |
60 | | - </div> |
61 | | - <div class="flex items-center justify-between gap-4"> |
62 | | - <span class="opacity-70">邮箱</span> |
63 | | - <span class="font-medium">{{ request.user.email|default:"—" }}</span> |
64 | | - </div> |
65 | | - <div class="flex items-center justify-between gap-4"> |
66 | | - <span class="opacity-70">加入时间</span> |
67 | | - <span class="font-medium">{{ request.user.date_joined|date:"Y-m-d H:i" }}</span> |
68 | | - </div> |
| 43 | + {% include 'account/_components/form_field.html' with field=form.bio %} |
| 44 | + |
| 45 | + <div class="grid grid-cols-1 md:grid-cols-2 gap-6"> |
| 46 | + {% include 'account/_components/form_field.html' with field=form.phone %} |
| 47 | + {% include 'account/_components/form_field.html' with field=form.gender %} |
69 | 48 | </div> |
70 | | - <div class="divider"></div> |
71 | | - <a class="btn btn-ghost btn-block" href="{% url 'account:settings' %}"> |
72 | | - <i class="fa-solid fa-gear"></i> |
73 | | - 打开设置 |
74 | | - </a> |
75 | | - </div> |
| 49 | + |
| 50 | + <div class="card-actions justify-end mt-4"> |
| 51 | + <button type="submit" class="btn btn-primary">保存更改</button> |
| 52 | + </div> |
| 53 | + </form> |
76 | 54 | </div> |
77 | 55 | </div> |
78 | 56 | {% endblock %} |
79 | | - |
0 commit comments