prepare editor page

Signed-off-by: Puqns67 <me@puqns67.icu>
This commit is contained in:
Puqns67 2023-09-16 00:47:01 +08:00
parent a541931772
commit 2f8246cfdf
Signed by: Puqns67
GPG Key ID: 9669DF042554F536
10 changed files with 237 additions and 134 deletions

View File

@ -0,0 +1,9 @@
package team8.fruitable.controller.action
import org.springframework.stereotype.Controller
import org.springframework.web.bind.annotation.RequestMapping
@Controller
@RequestMapping("/action/edit/item")
class ItemEditor {
}

View File

@ -0,0 +1,9 @@
package team8.fruitable.controller.action
import org.springframework.stereotype.Controller
import org.springframework.web.bind.annotation.RequestMapping
@Controller
@RequestMapping("/action/edit/user")
class UserEditor {
}

View File

@ -0,0 +1,89 @@
package team8.fruitable.controller.page
import org.springframework.data.domain.PageRequest
import org.springframework.stereotype.Controller
import org.springframework.ui.Model
import org.springframework.ui.set
import org.springframework.web.bind.annotation.CookieValue
import org.springframework.web.bind.annotation.RequestMapping
import org.springframework.web.bind.annotation.RequestParam
import org.springframework.web.servlet.mvc.support.RedirectAttributes
import team8.fruitable.controller.util.Util
import team8.fruitable.datebase.entity.User
import team8.fruitable.datebase.repository.AccountRepository
import team8.fruitable.datebase.repository.PagebleAccountRepository
@Controller
class Editor(
private val accountRepository: AccountRepository,
private val pagebleAccountRepository: PagebleAccountRepository
) {
private fun getCurrentUser(token: String?): User? {
return token?.let(accountRepository::findByToken)
}
private fun hasAdminPermissions(user: User?): Boolean {
return user?.isAdmin ?: false
}
private fun hasAdminPermissions(token: String?): Boolean {
return this.hasAdminPermissions(this.getCurrentUser(token))
}
private final val editorTabs: Array<Pair<String, String>> = arrayOf(
"user" to "用户",
"item" to "商品"
)
private final val editorSearchTypesForUser: Array<Pair<String, String>> = arrayOf(
"ALL" to "全部",
"ID" to "ID",
"NAME" to "名称",
"CREATE_DATE" to "注册时间",
"LAST_LOGIN_DATE" to "最后登录时间",
"AGE" to "年龄",
"GENDER" to "性别",
"PHONE" to "手机号码",
"EMAIL" to "邮箱",
"ADDRESS" to "地址",
"IS_ADMIN" to "管理员状态"
)
private final val editorSearchTypesForItem: Array<Pair<String, String>> = arrayOf(
"ALL" to "全部",
"ID" to "ID",
"NAME" to "名称",
"DESCRIPTION" to "描述",
"PRICE" to "价格"
)
@RequestMapping("/editor")
fun editor(
model: Model,
attributes: RedirectAttributes,
@CookieValue("TOKEN", required = false) token: String?,
@RequestParam("use", defaultValue = "user") use: String,
@RequestParam("search_type", required = false) searchType: String?,
@RequestParam("search_content", required = false) searchContent: String?,
@RequestParam("page", required = false) page: Int?,
): String {
val user = this.getCurrentUser(token) ?: return Util.error(attributes, "更新", "账户未登录", "/login")
if (!this.hasAdminPermissions(user)) return Util.error(attributes, "编辑", "账户无权限编辑网站")
model["tabs"] = editorTabs
if (searchContent != null) model["searching"] = searchContent
when (use) {
"item" -> {
model["useItemEditor"] = true
model["selects"] = editorSearchTypesForItem
}
else -> {
model["useUserEditor"] = true
model["selects"] = editorSearchTypesForUser
model["data"] = pagebleAccountRepository.findAll(PageRequest.of(page ?: 0, 10))
}
}
return "editor"
}
}

View File

@ -5,6 +5,7 @@ import org.springframework.ui.Model
import org.springframework.ui.set import org.springframework.ui.set
import org.springframework.web.bind.annotation.CookieValue import org.springframework.web.bind.annotation.CookieValue
import org.springframework.web.bind.annotation.RequestMapping import org.springframework.web.bind.annotation.RequestMapping
import org.springframework.web.bind.annotation.RequestParam
import org.springframework.web.servlet.mvc.support.RedirectAttributes import org.springframework.web.servlet.mvc.support.RedirectAttributes
import team8.fruitable.controller.util.Util.Companion.error import team8.fruitable.controller.util.Util.Companion.error
import team8.fruitable.datebase.entity.User import team8.fruitable.datebase.entity.User
@ -16,10 +17,6 @@ class Pages(private val repository: AccountRepository) {
return token?.let(repository::findByToken) return token?.let(repository::findByToken)
} }
private fun hasAdminPermissions(token: String?): Boolean {
return this.getCurrentUser(token)?.isAdmin ?: false
}
@RequestMapping("/") @RequestMapping("/")
fun index( fun index(
model: Model, model: Model,

View File

@ -0,0 +1,10 @@
package team8.fruitable.datebase.repository
import org.springframework.data.repository.CrudRepository
import org.springframework.data.repository.PagingAndSortingRepository
import team8.fruitable.datebase.entity.User
interface PagebleAccountRepository : PagingAndSortingRepository<User, Long> {
fun findByName(name: String): User?
fun findByToken(token: String): User?
}

View File

@ -15,14 +15,18 @@ div {
} }
#Contents { #Contents {
flex-direction: row; flex-direction: column;
width: 100%; width: 100%;
height: 500px; height: 500px;
} }
#Contents > .Title {
justify-content: space-between;
}
#Contents > .Editors { #Contents > .Editors {
flex: 4 0 0; flex: 4 0 0;
flex-direction: column; flex-direction: row;
justify-content: space-between; justify-content: space-between;
width: auto; width: auto;
margin: 5px; margin: 5px;
@ -32,47 +36,27 @@ div {
border-radius: 15px; border-radius: 15px;
} }
#Contents > .Editors > .Title { #Contents > .Editors > .ResultPanel {
justify-content: space-between;
}
#Contents > .Editors > .Result {
color: wheat; color: wheat;
border: 3px solid skyblue; border: 3px solid skyblue;
border-spacing: 0; border-spacing: 0;
border-radius: 10px; border-radius: 10px;
} }
#Contents > .Editors > .Result td { #Contents > .Editors > .ResultPanel td {
white-space: nowrap; white-space: nowrap;
border: 1px solid cornflowerblue; border: 1px solid cornflowerblue;
} }
#Contents > .Editors > .Result > thead { #Contents > .Editors > .ResultPanel > thead {
background-color: #044488; background-color: #044488;
} }
#Contents > .Editors > .Result > tbody { #Contents > .Editors > .ResultPanel > tbody {
background-color: #008080; background-color: #008080;
} }
#Contents > .Editors > .Pages > * { #Contents > .Editors > .EditPanel {
color: wheat;
margin-right: 3px;
border: 3px solid skyblue;
border-radius: 10px;
background-color: cadetblue;
}
#Contents > .Editors > .Pages > *:last-child {
margin-right: inherit;
}
#Contents > .Editors > .Pages > span {
color: green;
}
#Contents > .EditPanel {
flex: 1 0 0; flex: 1 0 0;
margin: 5px; margin: 5px;
padding: 5px; padding: 5px;
@ -81,10 +65,26 @@ div {
border-radius: 15px; border-radius: 15px;
} }
#Contents > .EditPanel > .Panel { #Contents > .Editors > .EditPanel > .Panel {
border: 0; border: 0;
} }
#Contents > .Pages > * {
color: wheat;
margin-right: 3px;
border: 3px solid skyblue;
border-radius: 10px;
background-color: cadetblue;
}
#Contents > .Pages > *:last-child {
margin-right: inherit;
}
#Contents > .Pages > span {
color: green;
}
@media (min-width: 1280px) { @media (min-width: 1280px) {
#Contents { #Contents {
width: 1280px; width: 1280px;

View File

@ -27,17 +27,41 @@
<!-- 页面内容 --> <!-- 页面内容 -->
<div id="Contents"> <div id="Contents">
<div class="Editors"> <div class="Title">
{{# userEditor }} <div class="Tabs">
{{> editor/user }} {{# tabs }}
{{/ userEditor }} <a href="/editor?use={{ first }}">{{ second }}</a>
{{# itemEditor }} {{/ tabs }}
{{> editor/item }}
{{/ itemEditor }}
</div> </div>
<div class="EditPanel"> <form class="Search" action="/editor" method="post">
<iframe id="Panel" class="Panel" name="panel"></iframe> <input type="hidden" name="use" value="user"/>
<label>
<select name="search_type">
{{# selects }}
<option value="{{ first }}">{{ second }}</option>
{{/ selects }}
</select>
搜索
</label>
<label>
<input name="search_content" placeholder="请在此处输入你想要搜索的内容..."
{{# searching }}value="{{ searching }}"{{/ searching }}/>
</label>
<button type="submit">搜索</button>
</form>
<button onclick="location.reload();">刷新</button>
</div>
<div class="Editors">
{{# useUserEditor }}
{{> editor/user }}
{{/ useUserEditor }}
{{# useItemEditor }}
{{> editor/item }}
{{/ useItemEditor }}
</div> </div>
</div> </div>

View File

@ -1,37 +1,39 @@
{{> header }} <table class="ResultPanel">
<thead>
<tr>
<td>ID</td>
<td>用户名</td>
<td>帐户创建时间</td>
<td>最后登录时间</td>
<td>年龄</td>
<td>性别</td>
<td>邮箱</td>
<td>管理员</td>
<td>操作</td>
</tr>
</thead>
<tbody>
{{# Users }}
<tr id="{{ Id }}">
<td>{{ Id }}</td>
<td>{{ UserName }}</td>
<td>{{ CreateDate }}</td>
<td>{{ LastLoginDate }}</td>
<td>{{ Age }}</td>
<td>{{ Gender }}</td>
<td>{{ Phone }}</td>
<td>{{ Email }}</td>
<td>{{ Address }}</td>
<td>{{ IsAdmin }}</td>
<td>
<button class="update">编辑</button>
<button class="remove">删除</button>
</td>
</tr>
{{/ Users }}
</tbody>
</table>
<!-- 页面内容 --> <div class="EditPanel">
<div id="Contents"> <!-- <iframe id="Panel" class="Panel" name="panel"></iframe>-->
<div class="Item">
<div class="Picture">
<img alt="商品图片" src=""/>
</div> </div>
<div class="Infos">
<span class="Title"></span>
<div class="Prices">
<div class="VipPrice"></div>
<div class="Price"></div>
</div>
<span class="Description"></span>
<div class="Options">
<div class="Option">
<div class="Title">数量</div>
<div class="Contents">
<div class="Option" selected>&nbsp;1&nbsp;</div>
<div class="Option">&nbsp;2&nbsp;</div>
<div class="Option">&nbsp;3&nbsp;</div>
<div class="Option">&nbsp;4&nbsp;</div>
<div class="Option">&nbsp;5&nbsp;</div>
<div class="Option">&nbsp;6&nbsp;</div>
</div>
</div>
</div>
<div class="Buttons">
<span class="Button">立即购买</span>
<span class="Button">加入购物车</span>
</div>
</div>
</div>
</div>
{{> footer }}

View File

@ -1,24 +1,4 @@
<div class="Title"> <table class="ResultPanel">
<form class="Search" action="edit" method="post">
<input type="hidden" name="edit" value="user"/>
{{!
list="#{'ALL': '搜索全部', 'ID': '以ID搜索', 'USERNAME': '以用户名搜索', 'CREATE_DATE': '以帐户注册时间搜索', 'LAST_LOGIN_DATE': '以最后登录时间搜索', 'AGE': '以年龄搜索', 'GENDER': '以性别搜索', 'EMAIL': '以邮箱搜索', 'IS_ADMIN': '以管理员状态搜索'}"
}}
<select name="type">
{{#Editor.Selects}}
<option value="{{key}}">{{value}}</option>
{{/Editor.Selects}}
</select>
<label>
<input name="search" placeholder="请在此处输入你想要搜索的内容..." value="{{Editor.Searching}}"/>
</label>
<button type="submit">搜索</button>
</form>
<button onclick="location.reload();">刷新</button>
</div>
<table class="Result">
<thead> <thead>
<tr> <tr>
<td>ID</td> <td>ID</td>
@ -27,43 +7,35 @@
<td>最后登录时间</td> <td>最后登录时间</td>
<td>年龄</td> <td>年龄</td>
<td>性别</td> <td>性别</td>
<td>手机号码</td>
<td>邮箱</td> <td>邮箱</td>
<td>地址</td>
<td>管理员</td> <td>管理员</td>
<td>操作</td> <td>操作</td>
</tr> </tr>
</thead> </thead>
<tbody> <tbody>
{{#Users}} {{# data }}
<tr id="{{ Id }}"> <tr id="{{ id }}">
<td>{{ Id }}</td> <td>{{ id }}</td>
<td>{{ UserName }}</td> <td>{{ name }}</td>
<td>{{ CreateDate }}</td> <td>{{ createTime }}</td>
<td>{{ LastLoginDate }}</td> <td>{{ loginTime }}</td>
<td>{{ Age }}</td> <td>{{# age }}{{ age }}{{/ age }}</td>
<td>{{ Gender }}</td> <td>{{# gender }}{{ gender }}{{/ gender }}</td>
<td>{{ Phone }}</td> <td>{{# phone }}{{ phone }}{{/ phone }}</td>
<td>{{ Email }}</td> <td>{{# email }}{{ email }}{{/ email }}</td>
<td>{{ Address }}</td> <td>{{# address }}{{ address }}{{/ address }}</td>
<td>{{ IsAdmin }}</td> <td>{{# isAdmin }}是{{/ isAdmin }}{{^ isAdmin }}否{{/ isAdmin }}</td>
<td> <td>
<button class="update">编辑</button> <button class="update">编辑</button>
<button class="remove">删除</button> <button class="remove">删除</button>
</td> </td>
</tr> </tr>
{{/Users}} {{/ data }}
</tbody> </tbody>
</table> </table>
<div class="Pages"> <div class="EditPanel">
<a href="edit?page=0">首页</a> <!-- <iframe id="Panel" class="Panel" name="panel"></iframe>-->
<s:iterator begin="%{#EditInfo.StartPage}" end="%{#EditInfo.StopPage}" var="PageNumber">
<s:if test="%{#PageNumber == #EditInfo.NowPageStr}">
<span>第 <s:property value="%{#PageNumber + 1}" 页</span>
</s:if>
<s:else>
<a href=" edit.jsp?page=<s:property value="%{#PageNumber} }}">第 <s:property
value="%{#PageNumber + 1}"/> 页</a>
</s:else>
</s:iterator>
<a href="edit.jsp?page=<s:property value=" %{#EditInfo.EndPage} }}">尾页</a>
</div> </div>

View File

@ -17,14 +17,5 @@
<div id="Floater"> <div id="Floater">
<!-- 回到顶层 --> <!-- 回到顶层 -->
<div class="TOP"></div> <div class="TOP"></div>
<canvas <canvas class="fireworks" style="position: fixed; left: 0; top: 0; z-index: 1; pointer-events: none;"></canvas>
class="fireworks"
style="
position: fixed;
left: 0;
top: 0;
z-index: 1;
pointer-events: none;
"
></canvas>
</div> </div>