Merge feature/Category into develop

This commit is contained in:
2025-07-27 23:14:43 +08:00
4 changed files with 74 additions and 47 deletions

View File

@@ -9,29 +9,41 @@
margin: 0; margin: 0;
padding: 0; padding: 0;
} }
.container { .container {
display: flex; display: flex;
max-width: 1200px; max-width: 1200px;
margin: 0 auto; margin: 0 auto;
padding: 20px; padding: 20px;
/ / : sticky min-height: 100 vh;
} }
.sidebar { .sidebar {
width: 250px; width: 250px;
padding-right: 20px; padding-right: 20px;
border-right: 1px solid #eee; border-right: 1px solid #eee;
/ / : position: -webkit-sticky;
position: sticky;
top: 20px;
align-self: flex-start;
height: fit-content;
} }
.sidebar h3 { .sidebar h3 {
color: #333; color: #333;
border-bottom: 2px solid #007cba; border-bottom: 2px solid #007cba;
padding-bottom: 10px; padding-bottom: 10px;
} }
.sidebar ul { .sidebar ul {
list-style: none; list-style: none;
padding: 0; padding: 0;
} }
.sidebar ul li { .sidebar ul li {
margin: 10px 0; margin: 10px 0;
} }
.sidebar ul li a { .sidebar ul li a {
text-decoration: none; text-decoration: none;
color: #666; color: #666;
@@ -40,14 +52,17 @@
border-radius: 4px; border-radius: 4px;
transition: all 0.3s; transition: all 0.3s;
} }
.sidebar ul li a:hover, .sidebar ul li a:hover,
.sidebar ul li a.active { .sidebar ul li a.active {
background-color: #007cba; background-color: #007cba;
color: white; color: white;
} }
.search-box { .search-box {
margin-bottom: 20px; margin-bottom: 20px;
} }
.search-box input[type="text"] { .search-box input[type="text"] {
width: 100%; width: 100%;
padding: 8px; padding: 8px;
@@ -55,6 +70,7 @@
border-radius: 4px; border-radius: 4px;
box-sizing: border-box; box-sizing: border-box;
} }
.search-box input[type="submit"] { .search-box input[type="submit"] {
width: 100%; width: 100%;
padding: 8px; padding: 8px;
@@ -65,35 +81,43 @@
cursor: pointer; cursor: pointer;
margin-top: 5px; margin-top: 5px;
} }
.search-box input[type="submit"]:hover { .search-box input[type="submit"]:hover {
background-color: #005a87; background-color: #005a87;
} }
.search-type { .search-type {
margin: 10px 0; margin: 10px 0;
} }
.search-type label { .search-type label {
display: block; display: block;
margin: 5px 0; margin: 5px 0;
font-size: 14px; font-size: 14px;
color: #666; color: #666;
} }
.search-type input[type="radio"] { .search-type input[type="radio"] {
margin-right: 5px; margin-right: 5px;
} }
.main-content { .main-content {
flex: 1; flex: 1;
padding-left: 20px; padding-left: 20px;
} }
.main-content h1 { .main-content h1 {
color: #333; color: #333;
border-bottom: 2px solid #eee; border-bottom: 2px solid #eee;
padding-bottom: 10px; padding-bottom: 10px;
} }
.post-meta { .post-meta {
font-size: 14px; font-size: 14px;
color: #999; color: #999;
margin-bottom: 20px; margin-bottom: 20px;
} }
.post-content img { .post-content img {
max-width: 100%; max-width: 100%;
height: auto; height: auto;
@@ -124,6 +148,7 @@
border-radius: 0; border-radius: 0;
font-size: 0.9em; font-size: 0.9em;
} }
footer { footer {
position: fixed; position: fixed;
bottom: 0; bottom: 0;
@@ -147,7 +172,6 @@
<div class="search-box"> <div class="search-box">
<form method="get" action="{% url 'index' %}"> <form method="get" action="{% url 'index' %}">
<input type="text" name="q" placeholder="搜索文章..." value="{{ query|default:'' }}"> <input type="text" name="q" placeholder="搜索文章..." value="{{ query|default:'' }}">
<div class="search-type"> <div class="search-type">
<label> <label>
<input type="radio" name="search_type" value="all" checked> <input type="radio" name="search_type" value="all" checked>

View File

@@ -9,29 +9,41 @@
margin: 0; margin: 0;
padding: 0; padding: 0;
} }
.container { .container {
display: flex; display: flex;
max-width: 1200px; max-width: 1200px;
margin: 0 auto; margin: 0 auto;
padding: 20px; padding: 20px;
min-height: 100vh;
} }
.sidebar { .sidebar {
width: 250px; width: 250px;
padding-right: 20px; padding-right: 20px;
border-right: 1px solid #eee; border-right: 1px solid #eee;
position: -webkit-sticky;
position: sticky;
top: 20px;
align-self: flex-start;
height: fit-content;
} }
.sidebar h3 { .sidebar h3 {
color: #333; color: #333;
border-bottom: 2px solid #007cba; border-bottom: 2px solid #007cba;
padding-bottom: 10px; padding-bottom: 10px;
} }
.sidebar ul { .sidebar ul {
list-style: none; list-style: none;
padding: 0; padding: 0;
} }
.sidebar ul li { .sidebar ul li {
margin: 10px 0; margin: 10px 0;
} }
.sidebar ul li a { .sidebar ul li a {
text-decoration: none; text-decoration: none;
color: #666; color: #666;
@@ -40,14 +52,17 @@
border-radius: 4px; border-radius: 4px;
transition: all 0.3s; transition: all 0.3s;
} }
.sidebar ul li a:hover, .sidebar ul li a:hover,
.sidebar ul li a.active { .sidebar ul li a.active {
background-color: #007cba; background-color: #007cba;
color: white; color: white;
} }
.search-box { .search-box {
margin-bottom: 20px; margin-bottom: 20px;
} }
.search-box input[type="text"] { .search-box input[type="text"] {
width: 100%; width: 100%;
padding: 8px; padding: 8px;
@@ -55,6 +70,7 @@
border-radius: 4px; border-radius: 4px;
box-sizing: border-box; box-sizing: border-box;
} }
.search-box input[type="submit"] { .search-box input[type="submit"] {
width: 100%; width: 100%;
padding: 8px; padding: 8px;
@@ -65,54 +81,67 @@
cursor: pointer; cursor: pointer;
margin-top: 5px; margin-top: 5px;
} }
.search-box input[type="submit"]:hover { .search-box input[type="submit"]:hover {
background-color: #005a87; background-color: #005a87;
} }
.search-type { .search-type {
margin: 10px 0; margin: 10px 0;
} }
.search-type label { .search-type label {
display: block; display: block;
margin: 5px 0; margin: 5px 0;
font-size: 14px; font-size: 14px;
color: #666; color: #666;
} }
.search-type input[type="radio"] { .search-type input[type="radio"] {
margin-right: 5px; margin-right: 5px;
} }
.main-content { .main-content {
flex: 1; flex: 1;
padding-left: 20px; padding-left: 20px;
} }
.main-content h1 { .main-content h1 {
color: #333; color: #333;
border-bottom: 2px solid #eee; border-bottom: 2px solid #eee;
padding-bottom: 10px; padding-bottom: 10px;
} }
.posts-list { .posts-list {
list-style: none; list-style: none;
padding: 0; padding: 0;
} }
.posts-list li { .posts-list li {
padding: 15px 0; padding: 15px 0;
border-bottom: 1px solid #eee; border-bottom: 1px solid #eee;
} }
.posts-list li:last-child { .posts-list li:last-child {
border-bottom: none; border-bottom: none;
} }
.post-title { .post-title {
font-size: 18px; font-size: 18px;
font-weight: bold; font-weight: bold;
margin-bottom: 8px; margin-bottom: 8px;
} }
.post-title a { .post-title a {
text-decoration: none; text-decoration: none;
color: #007cba; color: #007cba;
} }
.post-meta { .post-meta {
font-size: 14px; font-size: 14px;
color: #999; color: #999;
} }
.post-category { .post-category {
display: inline-block; display: inline-block;
background-color: #f0f0f0; background-color: #f0f0f0;
@@ -121,11 +150,13 @@
font-size: 12px; font-size: 12px;
margin-top: 5px; margin-top: 5px;
} }
.post-summary { .post-summary {
margin: 10px 0; margin: 10px 0;
line-height: 1.6; line-height: 1.6;
color: #666; color: #666;
} }
footer { footer {
} }
</style> </style>
@@ -144,15 +175,18 @@
<div class="search-type"> <div class="search-type">
<label> <label>
<input type="radio" name="search_type" value="all" {% if search_type != 'title' and search_type != 'content' %}checked{% endif %}> <input type="radio" name="search_type" value="all"
{% if search_type != 'title' and search_type != 'content' %}checked{% endif %}>
全文搜索 全文搜索
</label> </label>
<label> <label>
<input type="radio" name="search_type" value="title" {% if search_type == 'title' %}checked{% endif %}> <input type="radio" name="search_type" value="title"
{% if search_type == 'title' %}checked{% endif %}>
标题搜索 标题搜索
</label> </label>
<label> <label>
<input type="radio" name="search_type" value="content" {% if search_type == 'content' %}checked{% endif %}> <input type="radio" name="search_type" value="content"
{% if search_type == 'content' %}checked{% endif %}>
内容搜索 内容搜索
</label> </label>
</div> </div>

View File

@@ -1,31 +0,0 @@
asgiref==3.9.1
asttokens==3.0.0
click==8.2.1
configparser==7.2.0
decorator==5.2.1
executing==2.2.0
h11==0.16.0
ipython==9.4.0
ipython_pygments_lexers==1.1.1
jedi==0.19.2
matplotlib-inline==0.1.7
numpy==2.3.2
packaging==25.0
pandas==2.3.1
parso==0.8.4
pexpect==4.9.0
prompt_toolkit==3.0.51
psutil==7.0.0
ptyprocess==0.7.0
pure_eval==0.2.3
Pygments==2.19.2
python-dateutil==2.9.0.post0
pytz==2025.2
six==1.17.0
sqlparse==0.5.3
stack-data==0.6.3
traitlets==5.14.3
tzdata==2025.2
uv==0.8.3
uvicorn==0.35.0
wcwidth==0.2.13

View File

@@ -5,9 +5,9 @@ certifi==2025.7.14
charset-normalizer==3.4.2 charset-normalizer==3.4.2
click==8.2.1 click==8.2.1
decorator==5.2.1 decorator==5.2.1
Django==5.2.4 Django==5.1
django-mdeditor==0.1.20 django-mdeditor==0.1.20
django-summernote==0.8.20.0 emoji==2.14.1
executing==2.2.0 executing==2.2.0
gunicorn==23.0.0 gunicorn==23.0.0
h11==0.16.0 h11==0.16.0
@@ -15,7 +15,7 @@ idna==3.10
ipython==9.4.0 ipython==9.4.0
ipython_pygments_lexers==1.1.1 ipython_pygments_lexers==1.1.1
jedi==0.19.2 jedi==0.19.2
Markdown Markdown==3.5.2
martor==1.6.45 martor==1.6.45
matplotlib-inline==0.1.7 matplotlib-inline==0.1.7
numpy==2.3.2 numpy==2.3.2