完善部分组件;增加公告系列组件

This commit is contained in:
LiYang 2016-08-01 22:22:26 +08:00
parent 80afc30e6c
commit 1e045d073c
9 changed files with 215 additions and 23 deletions

View File

@ -2,6 +2,8 @@
from rest_framework import serializers from rest_framework import serializers
from account.models import User from account.models import User
from utils.serializers import DateTimeTZField
from .models import Announcement from .models import Announcement
@ -11,6 +13,8 @@ class CreateAnnouncementSerializer(serializers.Serializer):
class AnnouncementSerializer(serializers.ModelSerializer): class AnnouncementSerializer(serializers.ModelSerializer):
create_time = DateTimeTZField()
last_update_time = DateTimeTZField
class UserSerializer(serializers.ModelSerializer): class UserSerializer(serializers.ModelSerializer):
class Meta: class Meta:

View File

@ -1,7 +1,7 @@
<template> <template>
<div> <div>
<back></back> <back></back>
<h3>修改用户信息</h3> <h3>{{ $t("user.editUser") }}</h3>
<form v-on:submit="submit"> <form v-on:submit="submit">
<div class="row"> <div class="row">
<div class="form-group col-md-4"><label>ID</label> <div class="form-group col-md-4"><label>ID</label>
@ -20,7 +20,7 @@
<div class="form-group col-md-4"> <div class="form-group col-md-4">
<label>{{ $t("user.newPassword") }}</label> <label>{{ $t("user.newPassword") }}</label>
<input type="password" class="form-control" <input type="password" class="form-control"
placeholder='{{ $t("user.leaveBlankIfDoNotChangePassword")}}' v-model="newPassword"> placeholder='{{ $t("user.leaveBlankIfDoNotChangePassword")}}' v-model="newPassword" minlength="6">
</div> </div>
<div class="form-group col-md-4"> <div class="form-group col-md-4">
<label>{{ $t("user.email") }}</label> <label>{{ $t("user.email") }}</label>
@ -51,19 +51,19 @@
<h4>{{ $t("user.adminExtraPermission") }}</h4> <h4>{{ $t("user.adminExtraPermission") }}</h4>
<div class="row"> <div class="row">
<div class="form-group col-md-3"> <div class="form-group col-md-3">
<label>{{ $t("adminUtils.createPublicContest") }}</label> <label>{{ $t("user.createPublicContest") }}</label>
<input type="checkbox" class="form-control" v-model="permission.createPublicContest"> <input type="checkbox" class="form-control" v-model="permission.createPublicContest">
</div> </div>
<div class="form-group col-md-3"> <div class="form-group col-md-3">
<label>{{ $t("adminUtils.manageAllContest") }}</label> <label>{{ $t("user.manageAllContest") }}</label>
<input type="checkbox" class="form-control" v-model="permission.manageAllContest"> <input type="checkbox" class="form-control" v-model="permission.manageAllContest">
</div> </div>
<div class="form-group col-md-3"> <div class="form-group col-md-3">
<label>{{ $t("adminUtils.manageOwnProblem") }}</label> <label>{{ $t("user.manageOwnProblem") }}</label>
<input type="checkbox" class="form-control" v-model="permission.manageOwnProblem"> <input type="checkbox" class="form-control" v-model="permission.manageOwnProblem">
</div> </div>
<div class="form-group col-md-3"> <div class="form-group col-md-3">
<label>{{ $t("adminUtils.manageAllProblem") }}</label> <label>{{ $t("user.manageAllProblem") }}</label>
<input type="checkbox" class="form-control" v-model="permission.manageAllProblem"> <input type="checkbox" class="form-control" v-model="permission.manageAllProblem">
</div> </div>
</div> </div>
@ -81,9 +81,9 @@
export default { export default {
data() { data() {
return { return {
adminType: [{name: "adminUtils.regularUser", value: 0}, adminType: [{name: "user.regularUser", value: 0},
{name: "adminUtils.admin", "value": 1}, {name: "user.admin", "value": 1},
{name: "adminUtils.superAdmin", value: 2}], {name: "user.superAdmin", value: 2}],
user: {}, user: {},
permission: { permission: {
manageAllContest: false, createPublicContest: false, manageAllContest: false, createPublicContest: false,

View File

@ -1,6 +1,7 @@
<template> <template>
<div> <div>
<div class="right"> <h3>{{ $t("user.userList") }}</h3>
<div>
<form class="form-inline" onsubmit="return false;"> <form class="form-inline" onsubmit="return false;">
<div class="form-group-sm"> <div class="form-group-sm">
<label>{{ $t("adminUtils.search") }}</label> <label>{{ $t("adminUtils.search") }}</label>
@ -54,7 +55,7 @@
return { return {
keyword: "", keyword: "",
userList: [], userList: [],
adminType: ["adminUtils.regularUser", "adminUtils.admin", "adminUtils.superAdmin"], adminType: ["user.regularUser", "user.admin", "user.superAdmin"],
showAdminOnly: false, showAdminOnly: false,
pagination: { pagination: {

View File

@ -0,0 +1,74 @@
<template>
<h3>{{ $t("announcement.announcementList") }}</h3>
<table class="table table-striped">
<tr>
<th>ID</th>
<th>{{ $t("announcement.title") }}</th>
<th>{{ $t("announcement.createTime") }}</th>
<th>{{ $t("announcement.lastUpdateTime") }}</th>
<th>{{ $t("announcement.createdBy") }}</th>
<th>{{ $t("announcement.isVisible") }}</th>
<th>{{ $t("announcement.management") }}</th>
</tr>
<tr v-for="announcement in announcementList">
<td>{{ announcement.id }}</td>
<td>{{ announcement.title }}</td>
<td>{{ announcement.create_time }}</td>
<td>{{ announcement.last_update_time }}</td>
<td>{{ announcement.created_by.username }}</td>
<td>{{ $t(announcementStatus[announcement.visible?1:0]) }}</td>
<td>
<button class="btn-sm btn-info" v-on:click="edit(announcement.id)">{{ $t("announcement.edit") }}</button>
</td>
</tr>
</table>
<pager :pagination="pagination" :callback="loadData"></pager>
<create-announcement></create-announcement>
</template>
<script>
import pager from "../utils/pager.vue"
import createAnnouncement from "./createAnnouncement.vue"
export default({
data() {
return {
announcementStatus: ["announcement.visible", "announcement.invisible"],
announcementList: [],
pagination: {
currentPage: 1,
totalPages: 10
}
}
},
methods: {
loadData() {
this.request({
url: "/api/admin/announcement/?paging=true&page_size=2&page=" + this.pagination.currentPage,
method: "GET",
success: (data)=> {
this.announcementList = data.data.results;
this.pagination.totalPages = data.data.total_page;
}
})
},
edit(announcementId){
this.$router.go("/announcement/edit/" + announcementId)
},
},
route: {
data(){
this.loadData();
}
},
components: {
pager,
createAnnouncement
}
})
</script>
<style>
</style>

View File

@ -0,0 +1,37 @@
<template>
<h3>
{{ $t("announcement.createAnnouncement") }}
</h3>
<form v-on:submit="submit">
<div class="row">
<div class="form-group col-md-12">
<label>{{ $t("announcement.title") }}</label>
<input type="text" class="form-control">
</div>
<div class="form-group col-md-12">
<simditor editorid="createAnnouncement"></simditor>
</div>
</div>
<div class="form-group">
<input type="submit" class="btn btn-primary" value='{{ $t("adminUtils.submit") }}'>
</div>
</form>
</template>
<script>
import simditor from "../utils/simditor.vue"
export default({
data() {
return {}
},
methods: {
submit() {
}
},
components: {
simditor
}
})
</script>

View File

@ -0,0 +1,40 @@
<template>
<back></back>
<h3>
{{ $t("announcement.editAnnouncement") }}
</h3>
<form v-on:submit="submit">
<div class="row">
<div class="form-group col-md-12">
<label>{{ $t("announcement.title") }}</label>
<input type="text" class="form-control">
</div>
<div class="form-group col-md-12">
<simditor editorid="editAnnouncement"></simditor>
</div>
</div>
<div class="form-group">
<input type="submit" class="btn btn-success" value='{{ $t("adminUtils.saveChanges") }}'>
</div>
</form>
</template>
<script>
import simditor from "../utils/simditor.vue"
import back from "../utils/back.vue"
export default({
data() {
return {}
},
methods: {
submit() {
}
},
components: {
simditor,
back
}
})
</script>

View File

@ -3,7 +3,8 @@
<ul class="list-group"> <ul class="list-group">
<li class="list-group-header">name</li> <li class="list-group-header">name</li>
<li class="list-group-item"> <li class="list-group-item">
<a v-link="{path: '/user'}">{{ $t("nav.UserManagement") }}</a> <a v-link="{path: '/user'}">{{ $t("nav.userManagement") }}</a>
<a v-link="{path: '/announcement'}">{{ $t("nav.announcementManagement") }}</a>
</li> </li>
</ul> </ul>
</div> </div>

View File

@ -5,7 +5,8 @@ export default {
OK: "确定" OK: "确定"
}, },
nav: { nav: {
UserManagement: "用户管理" userManagement: "用户管理",
announcementManagement: "公告管理"
}, },
pagination: { pagination: {
first: "首页", first: "首页",
@ -16,6 +17,8 @@ export default {
succeeded: "操作成功" succeeded: "操作成功"
}, },
user: { user: {
userList: "用户列表",
editUser: "编辑用户信息",
username: "用户名", username: "用户名",
email: "邮箱", email: "邮箱",
realName: "真实姓名", realName: "真实姓名",
@ -30,21 +33,39 @@ export default {
tfaAuth: "两步验证", tfaAuth: "两步验证",
isDisabled: "禁用用户", isDisabled: "禁用用户",
adminExtraPermission: "普通管理员额外权限", adminExtraPermission: "普通管理员额外权限",
showAdminOnly: "只显示管理员" showAdminOnly: "只显示管理员",
},
adminUtils: {
search: "搜索",
inputKeyword: "输入关键词",
regularUser: "普通用户", regularUser: "普通用户",
admin: "普通管理员", admin: "普通管理员",
superAdmin: "超级管理员", superAdmin: "超级管理员",
UserDoesNotExist: "用户不存在", UserDoesNotExist: "用户不存在",
back: "返回",
saveChanges: "保存修改",
createPublicContest: "创建公开比赛", createPublicContest: "创建公开比赛",
manageAllContest: "管理所有比赛", manageAllContest: "管理所有比赛",
manageAllProblem: "管理所有题目", manageAllProblem: "管理所有题目",
manageOwnProblem: "管理自己创建的题目", manageOwnProblem: "管理自己创建的题目",
},
announcement: {
announcementList: "公告列表",
editAnnouncement: "编辑公告",
createAnnouncement: "创建公告",
title: "标题",
createTime: "创建时间",
lastUpdateTime: "最后更新",
createdBy: "创建人",
isVisible: "是否可见",
visible: "可见",
invisible: "隐藏",
management: "管理",
edit: "编辑",
},
adminUtils: {
search: "搜索",
inputKeyword: "输入关键词",
submit: "提交",
back: "返回",
saveChanges: "保存修改",
unsupportedBrowserWarningMsg: "当前网页 <strong>不支持</strong> 你正在使用的浏览器, 为了正常的访问,请到 <a href=\"http://browsehappy.com/\"> 升级你的浏览器</a>" unsupportedBrowserWarningMsg: "当前网页 <strong>不支持</strong> 你正在使用的浏览器, 为了正常的访问,请到 <a href=\"http://browsehappy.com/\"> 升级你的浏览器</a>"
} }
} }

View File

@ -3,14 +3,18 @@ import App from './App'
import VueRouter from "vue-router" import VueRouter from "vue-router"
import VueI18n from "vue-i18n" import VueI18n from "vue-i18n"
import "expose?$!expose?jQuery!jquery"
import "bootstrap"
import bootbox from "bootbox"
import locale from "./locales" import locale from "./locales"
import userList from "./components/account/userList.vue" import userList from "./components/account/userList.vue"
import editUser from "./components/account/editUser.vue" import editUser from "./components/account/editUser.vue"
import problem from "./components/problem/problem.vue" import problem from "./components/problem/problem.vue"
import "expose?$!expose?jQuery!jquery" import announcementList from "./components/announcement/announcementList.vue"
import "bootstrap" import editAnnouncement from "./components/announcement/editAnnouncement.vue"
import bootbox from "bootbox"
// i18n settings // i18n settings
Vue.use(VueI18n); Vue.use(VueI18n);
@ -100,6 +104,14 @@ router.map({
"/problem/create": { "/problem/create": {
name: "createProblem", name: "createProblem",
component: problem component: problem
},
"/announcement/:page": {
name: "announcementList",
component: announcementList
},
"/announcement/edit/:announcementId": {
name: "editAnnouncement",
component: editAnnouncement
} }
}); });
@ -122,5 +134,7 @@ function bootboxAlert(content) {
window.alert = bootboxAlert; window.alert = bootboxAlert;
router.redirect({"/user": "/user/1"}); router.redirect({"/user": "/user/1"});
router.redirect({"/announcement": "/announcement/1"});
router.start(App, '#app'); router.start(App, '#app');