Commit a8c31558 by 黄志甲

添加门户 无障碍改造部分页面

parent d543de3c
ENV = 'development' ENV = 'development'
# 接口地址 # 接口地址
VUE_APP_BASE_API = 'http://192.168.3.123:8000' VUE_APP_BASE_API = 'http://106.53.98.217:10003'
VUE_APP_WS_API = 'ws://192.168.3.123:8000' VUE_APP_WS_API = 'ws://106.53.98.217:10003'
# 是否启用 babel-plugin-dynamic-import-node插件 # 是否启用 babel-plugin-dynamic-import-node插件
VUE_CLI_BABEL_TRANSPILE_MODULES = true VUE_CLI_BABEL_TRANSPILE_MODULES = true
...@@ -10,7 +10,7 @@ ELADMIN 前端源码 ...@@ -10,7 +10,7 @@ ELADMIN 前端源码
| 码云 | https://gitee.com/elunez/eladmin | https://gitee.com/elunez/eladmin-web | | 码云 | https://gitee.com/elunez/eladmin | https://gitee.com/elunez/eladmin-web |
#### 开发文档 #### 开发文档
[https://docs.auauz.net/#/](https://docs.auauz.net/#/) [https://el-admin.vip](https://el-admin.vip)
#### 前端模板 #### 前端模板
...@@ -46,6 +46,21 @@ npm run build:prod ...@@ -46,6 +46,21 @@ npm run build:prod
2、加速node-sass安装 2、加速node-sass安装
https://www.ydyno.com/archives/1219.html https://www.ydyno.com/archives/1219.html
#### 特别鸣谢
- 感谢 [JetBrains](https://www.jetbrains.com/) 提供的非商业开源软件开发授权
- 感谢 [PanJiaChen](https://github.com/PanJiaChen/vue-element-admin) 大佬提供的前端模板
- 感谢 [Moxun](https://github.com/moxun1639) 大佬提供的前端 Curd 通用组件
- 感谢 [zhy6599](https://gitee.com/zhy6599) 大佬提供的后端运维管理相关功能
- 感谢 [j.yao.SUSE](https://github.com/everhopingandwaiting) 大佬提供的匿名接口与Redis限流等功能
- 感谢 [d15801543974](https://github.com/d15801543974) 大佬提供的基于注解的通用查询方式
#### 反馈交流 #### 反馈交流
- QQ交流群:891137268 - QQ交流群:891137268
\ No newline at end of file
{ {
"name": "eladmin-web", "name": "eladmin-web",
"version": "2.4.0", "version": "2.5.0",
"description": "EL-ADMIN 前端源码", "description": "EL-ADMIN 前端源码",
"author": "Zheng Jie", "author": "Zheng Jie",
"license": "Apache-2.0", "license": "Apache-2.0",
......
import request from '@/utils/request'
let baseUrl = 'http://portal.project.gxdpf.org.cn/portal'
//查地址
export function getCityAreaList(data) {
return request({
baseUrl:baseUrl,
url: `${baseUrl}/stats/getCityAreaList`,
method: 'post',
data
})
}
...@@ -180,3 +180,273 @@ aside { ...@@ -180,3 +180,273 @@ aside {
.multiselect--active { .multiselect--active {
z-index: 1000 !important; z-index: 1000 !important;
} }
//添加自己的样式
@charset "utf-8";
/*测试*/
.testBorder {
border: 2px solid red;
}
/* flex操作 */
.k-flex {
display: flex
}
/* 占满 */
.k-all {
flex: 1
}
/* 对齐方式 */
.k-row {
flex-direction: row
}
/* 换行 */
.k-wrap {
flex-wrap: wrap
}
/* ===========对齐方式=========== */
/* 左对齐 */
.k-flex-start {
justify-content: flex-start
}
/* 右对齐 */
.k-flex-end {
justify-content: flex-end
}
/* 居中 */
.k-center {
justify-content: center
}
/* 对齐两端 */
.k-space-between {
justify-content: space-between
}
/* 各div间距相等 */
.k-space-around {
justify-content: space-around
}
/* 起点对齐方式 */
/*对齐起点*/
.k-align-start {
align-items: flex-start
}
/*对齐终点*/
.k-align-end {
align-items: flex-end
}
/*中点对齐*/
.k-align-center {
align-items: center
}
/*超集*/
/* 左右间隔为0并水平居中 */
.k-flex-between-center {
display: flex;
justify-content: space-between;
align-items: center
}
/* 上下垂直居中左右间隔相等 */
.k-flex-around-center {
display: flex;
justify-content: space-around;
align-items: center;
}
/* 盒子阴影 */
.k-box-shadow {
box-shadow: 0px 0px 20px #9E9E9E;
}
/* 吸顶超集 */
.k-sticky {
position: sticky;
top: 0;
z-index: 9999;
}
/* fontSize */
.font-18 {
font-size: 18px
}
.font-20 {
font-size: 20px
}
.font-22 {
font-size: 22px
}
.font-24 {
font-size: 24px
}
.font-26 {
font-size: 26px
}
.font-28 {
font-size: 28px
}
.font-30 {
font-size: 30px
}
.font-32 {
font-size: 32px
}
.font-34 {
font-size: 34px
}
.font-26 {
font-size: 36px
}
.font-38 {
font-size: 38px
}
.font-40 {
font-size: 40px
}
.font-42 {
font-size: 42px
}
.font-44 {
font-size: 44px
}
.font-46 {
font-size: 46px
}
.font-48 {
font-size: 48px
}
.font-50 {
font-size: 50px
}
/* font-weight */
.font-weight-500 {
font-weight: 500
}
.font-weight-600 {
font-weight: 600
}
.font-weight-bold {
font-weight: bold
}
.font-weight-bold {
font-weight: bolder
}
/* 背景颜色 */
.bg-FFFFFF {
background-color: #FFFFFF
}
.bg-EEEEEE {
background-color: #EEEEEE
}
.bg-F5F5F5 {
background-color: #F5F5F5
}
/* 字体颜色 */
/* 常用字体黑色色阶向下 */
.color-black2 {
color: #222222
}
.color-black3 {
color: #333333
}
.color-black4 {
color: #444444
}
.color-black6 {
color: #666666
}
.color-black7 {
color: #777777
}
.color-black8 {
color: #888888
}
.color-black9 {
color: #999999
}
/* 常用字体颜色 */
.color-FFFFFF {
color: #FFFFFF
}
/*文字操作 */
/*居中*/
.text-center {
text-align: center
}
/*右对齐*/
.text-right {
text-align: right
}
/*add class*/
/* 向上间距20px */
.el-card-top{
margin-top: 20px;
}
//分页
.paginationClass{
padding: 8px 0;
}
...@@ -19,7 +19,7 @@ $menuHover:#263445; ...@@ -19,7 +19,7 @@ $menuHover:#263445;
$subMenuBg:#1f2d3d; $subMenuBg:#1f2d3d;
$subMenuHover:#001528; $subMenuHover:#001528;
$sideBarWidth: 205px; $sideBarWidth: 225px;
// the :export directive is the magic sauce for webpack // the :export directive is the magic sauce for webpack
// https://www.bluematador.com/blog/how-to-share-variables-between-js-and-sass // https://www.bluematador.com/blog/how-to-share-variables-between-js-and-sass
......
...@@ -89,8 +89,8 @@ ...@@ -89,8 +89,8 @@
全选 全选
</el-checkbox> </el-checkbox>
<el-checkbox <el-checkbox
v-for="item in crud.props.tableColumns" v-for="item in tableColumns"
:key="item.label" :key="item.property"
v-model="item.visible" v-model="item.visible"
@change="handleCheckedTableColumnsChange(item)" @change="handleCheckedTableColumnsChange(item)"
> >
...@@ -102,24 +102,93 @@ ...@@ -102,24 +102,93 @@
</template> </template>
<script> <script>
import CRUD, { crud } from '@crud/crud' import CRUD, { crud } from '@crud/crud'
function sortWithRef(src, ref) {
const result = Object.assign([], ref)
let cursor = -1
src.forEach(e => {
const idx = result.indexOf(e)
if (idx === -1) {
cursor += 1
result.splice(cursor, 0, e)
} else {
cursor = idx
}
})
return result
}
export default { export default {
mixins: [crud()], mixins: [crud()],
props: { props: {
permission: { permission: {
type: Object, type: Object,
default: () => { return {} } default: () => { return {} }
},
hiddenColumns: {
type: Array,
default: () => { return [] }
},
ignoreColumns: {
type: Array,
default: () => { return [] }
} }
}, },
data() { data() {
return { return {
tableColumns: [],
allColumnsSelected: true, allColumnsSelected: true,
allColumnsSelectedIndeterminate: false allColumnsSelectedIndeterminate: false,
tableUnwatcher: null,
// 忽略下次表格列变动
ignoreNextTableColumnsChange: false
}
},
watch: {
'crud.props.table'() {
this.updateTableColumns()
this.tableColumns.forEach(column => {
if (this.hiddenColumns.indexOf(column.property) !== -1) {
column.visible = false
this.updateColumnVisible(column)
}
})
},
'crud.props.table.store.states.columns'() {
this.updateTableColumns()
} }
}, },
created() { created() {
this.crud.updateProp('searchToggle', true) this.crud.updateProp('searchToggle', true)
}, },
methods: { methods: {
updateTableColumns() {
const table = this.crud.getTable()
if (!table) {
this.tableColumns = []
return
}
let cols = null
const columnFilter = e => e && e.type === 'default' && e.property && this.ignoreColumns.indexOf(e.property) === -1
const refCols = table.columns.filter(columnFilter)
if (this.ignoreNextTableColumnsChange) {
this.ignoreNextTableColumnsChange = false
return
}
this.ignoreNextTableColumnsChange = false
const columns = []
const fullTableColumns = table.$children.map(e => e.columnConfig).filter(columnFilter)
cols = sortWithRef(fullTableColumns, refCols)
cols.forEach(config => {
const column = {
property: config.property,
label: config.label,
visible: refCols.indexOf(config) !== -1
}
columns.push(column)
})
this.tableColumns = columns
},
toDelete(datas) { toDelete(datas) {
this.$confirm(`确认删除选中的${datas.length}条数据?`, '提示', { this.$confirm(`确认删除选中的${datas.length}条数据?`, '提示', {
confirmButtonText: '确定', confirmButtonText: '确定',
...@@ -136,7 +205,7 @@ export default { ...@@ -136,7 +205,7 @@ export default {
this.allColumnsSelected = true this.allColumnsSelected = true
return return
} }
this.crud.props.tableColumns.forEach(column => { this.tableColumns.forEach(column => {
if (!column.visible) { if (!column.visible) {
column.visible = true column.visible = true
this.updateColumnVisible(column) this.updateColumnVisible(column)
...@@ -148,7 +217,7 @@ export default { ...@@ -148,7 +217,7 @@ export default {
handleCheckedTableColumnsChange(item) { handleCheckedTableColumnsChange(item) {
let totalCount = 0 let totalCount = 0
let selectedCount = 0 let selectedCount = 0
this.crud.props.tableColumns.forEach(column => { this.tableColumns.forEach(column => {
++totalCount ++totalCount
selectedCount += column.visible ? 1 : 0 selectedCount += column.visible ? 1 : 0
}) })
...@@ -168,16 +237,13 @@ export default { ...@@ -168,16 +237,13 @@ export default {
const vm = table.$children.find(e => e.prop === item.property) const vm = table.$children.find(e => e.prop === item.property)
const columnConfig = vm.columnConfig const columnConfig = vm.columnConfig
if (item.visible) { if (item.visible) {
let columnIndex = -1
// 找出合适的插入点 // 找出合适的插入点
table.store.states.columns.find(e => { const columnIndex = this.tableColumns.indexOf(item)
columnIndex++ vm.owner.store.commit('insertColumn', columnConfig, columnIndex + 1, null)
return e.__index !== undefined && e.__index > columnConfig.__index
})
vm.owner.store.commit('insertColumn', columnConfig, columnIndex, null)
} else { } else {
vm.owner.store.commit('removeColumn', columnConfig, null) vm.owner.store.commit('removeColumn', columnConfig, null)
} }
this.ignoreNextTableColumnsChange = true
}, },
toggleSearch() { toggleSearch() {
this.crud.props.searchToggle = !this.crud.props.searchToggle this.crud.props.searchToggle = !this.crud.props.searchToggle
......
...@@ -133,7 +133,7 @@ function CRUD(options) { ...@@ -133,7 +133,7 @@ function CRUD(options) {
// 请求数据 // 请求数据
initData(crud.url, crud.getQueryParams()).then(data => { initData(crud.url, crud.getQueryParams()).then(data => {
const table = crud.getTable() const table = crud.getTable()
if (table.lazy) { // 懒加载子节点数据,清掉已加载的数据 if (table && table.lazy) { // 懒加载子节点数据,清掉已加载的数据
table.store.states.treeData = {} table.store.states.treeData = {}
table.store.states.lazyTreeNodeMap = {} table.store.states.lazyTreeNodeMap = {}
} }
...@@ -504,22 +504,7 @@ function CRUD(options) { ...@@ -504,22 +504,7 @@ function CRUD(options) {
}, },
attchTable() { attchTable() {
const table = this.getTable() const table = this.getTable()
const columns = []
table.columns.forEach((e, index) => {
if (!e.property || e.type !== 'default') {
return
}
e.__index = index
columns.push({
property: e.property,
index,
label: e.label,
visible: true
})
})
this.updateProp('tableColumns', columns)
this.updateProp('table', table) this.updateProp('table', table)
const that = this const that = this
table.$on('expand-change', (row, expanded) => { table.$on('expand-change', (row, expanded) => {
if (!expanded) { if (!expanded) {
......
...@@ -9,7 +9,7 @@ export default { ...@@ -9,7 +9,7 @@ export default {
name: 'Doc', name: 'Doc',
methods: { methods: {
click() { click() {
window.open('https://docs.auauz.net/guide/', '_blank') window.open('https://el-admin.vip/guide/', '_blank')
} }
} }
} }
......
...@@ -70,7 +70,12 @@ export default { ...@@ -70,7 +70,12 @@ export default {
this.show = false this.show = false
}, },
change(val) { change(val) {
if (this.ishttp(val.path)) {
// http(s):// 路径新窗口打开
window.open(val.path, '_blank')
} else {
this.$router.push(val.path) this.$router.push(val.path)
}
this.search = '' this.search = ''
this.options = [] this.options = []
this.$nextTick(() => { this.$nextTick(() => {
...@@ -104,7 +109,7 @@ export default { ...@@ -104,7 +109,7 @@ export default {
if (router.hidden) { continue } if (router.hidden) { continue }
const data = { const data = {
path: path.resolve(basePath, router.path), path: !this.ishttp(router.path) ? path.resolve(basePath, router.path) : router.path,
title: [...prefixTitle] title: [...prefixTitle]
} }
...@@ -134,6 +139,9 @@ export default { ...@@ -134,6 +139,9 @@ export default {
} else { } else {
this.options = [] this.options = []
} }
},
ishttp(url) {
return url.indexOf('http://') !== -1 || url.indexOf('https://') !== -1
} }
} }
} }
......
...@@ -25,10 +25,9 @@ export default { ...@@ -25,10 +25,9 @@ export default {
}, },
methods: { methods: {
filterIcons() { filterIcons() {
this.iconList = icons
if (this.name) { if (this.name) {
this.iconList = this.iconList.filter(item => item.includes(this.name)) this.iconList = this.iconList.filter(item => item.includes(this.name))
} else {
this.iconList = icons
} }
}, },
selectedIcon(name) { selectedIcon(name) {
......
...@@ -46,7 +46,7 @@ router.beforeEach((to, from, next) => { ...@@ -46,7 +46,7 @@ router.beforeEach((to, from, next) => {
if (whiteList.indexOf(to.path) !== -1) { // 在免登录白名单,直接进入 if (whiteList.indexOf(to.path) !== -1) { // 在免登录白名单,直接进入
next() next()
} else { } else {
next(`/login?redirect=${to.path}`) // 否则全部重定向到登录页 next(`/login?redirect=${to.fullPath}`) // 否则全部重定向到登录页
NProgress.done() NProgress.done()
} }
} }
......
...@@ -61,6 +61,7 @@ export const constantRouterMap = [ ...@@ -61,6 +61,7 @@ export const constantRouterMap = [
] ]
export default new Router({ export default new Router({
// mode: 'hash',
mode: 'history', mode: 'history',
scrollBehavior: () => ({ y: 0 }), scrollBehavior: () => ({ y: 0 }),
routes: constantRouterMap routes: constantRouterMap
......
import axios from 'axios' import axios from 'axios'
import router from '@/router/routers' import router from '@/router/routers'
import { Notification, MessageBox } from 'element-ui' import { Notification } from 'element-ui'
import store from '../store' import store from '../store'
import { getToken } from '@/utils/auth' import { getToken } from '@/utils/auth'
import Config from '@/settings' import Config from '@/settings'
import Cookies from 'js-cookie'
// 创建axios实例 // 创建axios实例
const service = axios.create({ const service = axios.create({
...@@ -55,18 +56,10 @@ service.interceptors.response.use( ...@@ -55,18 +56,10 @@ service.interceptors.response.use(
} }
if (code) { if (code) {
if (code === 401) { if (code === 401) {
MessageBox.confirm(
'登录状态已过期,您可以继续留在该页面,或者重新登录',
'系统提示',
{
confirmButtonText: '重新登录',
cancelButtonText: '取消',
type: 'warning'
}
).then(() => {
store.dispatch('LogOut').then(() => { store.dispatch('LogOut').then(() => {
location.reload() // 为了重新实例化vue-router对象 避免bug // 用户登录界面提示
}) Cookies.set('point', 401)
location.reload()
}) })
} else if (code === 403) { } else if (code === 403) {
router.push({ path: '/401' }) router.push({ path: '/401' })
......
<template>
<div class="app-container">
<el-row>
<el-col :md="{span:18,offset:3}" :sm="{span:24,offset:0}">
<el-card shadow="never">
<div class="k-flex-between-center" slot="header">
<div class="font-weight-bold">搜索条件</div>
</div>
<el-form :inline="true" :model="formInline">
<el-form-item label="年份">
<el-select v-model="formInline.region" placeholder="活动区域">
<el-option label="区域一" value="shanghai"></el-option>
<el-option label="区域二" value="beijing"></el-option>
</el-select>
</el-form-item>
<el-form-item label="行政区域">
<el-select v-model="formInline.region" placeholder="活动区域">
<el-option label="区域一" value="shanghai"></el-option>
<el-option label="区域二" value="beijing"></el-option>
</el-select>
</el-form-item>
<br/>
<el-form-item label="姓名">
<el-input v-model="formInline.region"></el-input>
</el-form-item>
<el-form-item label="残疾证号">
<el-input v-model="formInline.region"></el-input>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="onSubmit" icon="el-icon-search">查询</el-button>
</el-form-item>
</el-form>
</el-card>
<el-card shadow="never" class="el-card-top">
<div class="k-flex-between-center" slot="header">
<div class="font-weight-bold">选择无障碍改造对象</div>
<el-button type="primary">导出表格</el-button>
</div>
<el-table
:data="tableData"
border
style="width: 100%"
size="medium"
:header-cell-style="{background: '#f5f7fa',color:'#606266'}"
header-align="center"
>
<el-table-column prop="date" label="序号"></el-table-column>
<el-table-column prop="name" label="姓名"></el-table-column>
<el-table-column prop="address" label="性别"></el-table-column>
<el-table-column prop="address" label="手机号"></el-table-column>
<el-table-column prop="address" label="地址"></el-table-column>
<el-table-column prop="address" label="伤残级别"></el-table-column>
<el-table-column prop="address" label="伤残类型"></el-table-column>
<el-table-column prop="address" label="申请时间"></el-table-column>
<el-table-column prop="address" label="选择"></el-table-column>
</el-table>
<div class="paginationClass">
<el-pagination
@size-change="handleSizeChange"
@current-change="handleCurrentChange"
:current-page="currentPage4"
:page-sizes="[100, 200, 300, 400]"
:page-size="100"
layout="total, sizes, prev, pager, next, jumper"
:total="400"
></el-pagination>
</div>
</el-card>
</el-col>
</el-row>
</div>
</template>
<script>
export default {
data() {
return {
formInline: {}
};
}
};
</script>
<style>
</style>
\ No newline at end of file
<template>
<div class="app-container">
<el-row>
<el-col :md="{span:18,offset:3}" :sm="{span:24,offset:0}">
<el-card shadow="never">
<div class="k-flex-between-center" slot="header">
<div class="font-weight-bold">搜索条件</div>
</div>
<el-form :inline="true" :model="formInline">
<el-form-item label="年份">
<el-select v-model="formInline.region" placeholder="活动区域">
<el-option label="区域一" value="shanghai"></el-option>
<el-option label="区域二" value="beijing"></el-option>
</el-select>
</el-form-item>
<el-form-item label="行政区域">
<el-select v-model="formInline.region" placeholder="活动区域">
<el-option label="区域一" value="shanghai"></el-option>
<el-option label="区域二" value="beijing"></el-option>
</el-select>
</el-form-item>
<br>
<el-form-item label="姓名">
<el-input v-model="formInline.region"></el-input>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="onSubmit" icon="el-icon-search">查询</el-button>
</el-form-item>
</el-form>
</el-card>
<el-card shadow="never" class="el-card-top">
<div class="k-flex-between-center" slot="header">
<div class="font-weight-bold">选择无障碍改造对象</div>
<el-button type="primary">导出表格</el-button>
</div>
<el-table
:data="tableData"
border
style="width: 100%"
size="medium"
:header-cell-style="{background: '#f5f7fa',color:'#606266'}"
header-align="center"
>
<el-table-column prop="date" label="序号"></el-table-column>
<el-table-column prop="name" label="姓名"></el-table-column>
<el-table-column prop="address" label="性别"></el-table-column>
<el-table-column prop="address" label="手机号"></el-table-column>
<el-table-column prop="address" label="地址"></el-table-column>
<el-table-column prop="address" label="伤残级别"></el-table-column>
<el-table-column prop="address" label="伤残类型"></el-table-column>
<el-table-column prop="address" label="申请时间"></el-table-column>
<el-table-column prop="address" label="选择"></el-table-column>
</el-table>
<div class="paginationClass">
<el-pagination
@size-change="handleSizeChange"
@current-change="handleCurrentChange"
:current-page="currentPage4"
:page-sizes="[100, 200, 300, 400]"
:page-size="100"
layout="total, sizes, prev, pager, next, jumper"
:total="400"
></el-pagination>
</div>
</el-card>
</el-col>
</el-row>
</div>
</template>
<script>
export default {
data() {
return {
formInline: {}
};
}
};
</script>
<style>
</style>
\ No newline at end of file
<template>
<div class="app-container">
<el-row>
<el-col :md="{span:18,offset:3}" :sm="{span:24,offset:0}">
<el-card shadow="never">
<div class="k-flex-between-center" slot="header">
<div class="font-weight-bold">搜索条件</div>
</div>
<el-form :inline="true" :model="formInline">
<el-form-item label="年份">
<el-select v-model="formInline.region" placeholder="活动区域">
<el-option label="区域一" value="shanghai"></el-option>
<el-option label="区域二" value="beijing"></el-option>
</el-select>
</el-form-item>
<el-form-item label="行政区域">
<el-select v-model="formInline.region" placeholder="活动区域">
<el-option label="区域一" value="shanghai"></el-option>
<el-option label="区域二" value="beijing"></el-option>
</el-select>
</el-form-item>
<br/>
<el-form-item label="姓名">
<el-input v-model="formInline.region"></el-input>
</el-form-item>
<el-form-item label="手机号">
<el-input v-model="formInline.region"></el-input>
</el-form-item>
<el-form-item label="状态">
<el-select v-model="formInline.region" placeholder="选择状态">
<el-option label="区域一" value="shanghai"></el-option>
<el-option label="区域二" value="beijing"></el-option>
</el-select>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="onSubmit" icon="el-icon-search">查询</el-button>
</el-form-item>
</el-form>
</el-card>
<el-card shadow="never" class="el-card-top">
<div class="k-flex-between-center" slot="header">
<div class="font-weight-bold">选择无障碍改造对象</div>
<el-button type="primary">导出表格</el-button>
</div>
<el-table
:data="tableData"
border
style="width: 100%"
size="medium"
:header-cell-style="{background: '#f5f7fa',color:'#606266'}"
header-align="center"
>
<el-table-column prop="date" label="序号"></el-table-column>
<el-table-column prop="name" label="姓名"></el-table-column>
<el-table-column prop="address" label="性别"></el-table-column>
<el-table-column prop="address" label="手机号"></el-table-column>
<el-table-column prop="address" label="地址"></el-table-column>
<el-table-column prop="address" label="伤残级别"></el-table-column>
<el-table-column prop="address" label="伤残类型"></el-table-column>
<el-table-column prop="address" label="申请时间"></el-table-column>
<el-table-column prop="address" label="选择"></el-table-column>
</el-table>
<div class="paginationClass">
<el-pagination
@size-change="handleSizeChange"
@current-change="handleCurrentChange"
:current-page="currentPage4"
:page-sizes="[100, 200, 300, 400]"
:page-size="100"
layout="total, sizes, prev, pager, next, jumper"
:total="400"
></el-pagination>
</div>
</el-card>
</el-col>
</el-row>
</div>
</template>
<script>
export default {
data() {
return {
formInline: {}
};
}
};
</script>
<style>
</style>
\ No newline at end of file
<!-- 父级路由组件 -->
<template>
<div>
<!-- xxx html 内容 -->
<router-view />
</div>
</template>
<template>
<div class="app-container">
<el-row>
<el-col :md="{span:18,offset:3}" :sm="{span:24,offset:0}">
<el-card shadow="never">
<div class="k-flex-between-center" slot="header">
<div class="font-weight-bold">搜索条件</div>
<el-button type="primary" @click="publicityShow=true">上传公示名单</el-button>
</div>
<el-form :inline="true" :model="formInline">
<el-form-item label="年份">
<el-select v-model="formInline.region" placeholder="活动区域">
<el-option label="区域一" value="shanghai"></el-option>
<el-option label="区域二" value="beijing"></el-option>
</el-select>
</el-form-item>
<el-form-item label="行政区域">
<el-select v-model="formInline.region" placeholder="活动区域">
<el-option label="区域一" value="shanghai"></el-option>
<el-option label="区域二" value="beijing"></el-option>
</el-select>
</el-form-item>
<br />
<el-form-item label="姓名">
<el-input v-model="formInline.region"></el-input>
</el-form-item>
<el-form-item label="手机号">
<el-input v-model="formInline.region"></el-input>
</el-form-item>
<el-form-item label="状态">
<el-select v-model="formInline.region" placeholder="选择状态">
<el-option label="区域一" value="shanghai"></el-option>
<el-option label="区域二" value="beijing"></el-option>
</el-select>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="onSubmit" icon="el-icon-search">查询</el-button>
</el-form-item>
</el-form>
</el-card>
<el-card shadow="never" class="el-card-top">
<div class="k-flex-between-center" slot="header">
<div class="font-weight-bold">选择无障碍改造对象</div>
<el-button type="primary">导出表格</el-button>
</div>
<el-table
:data="tableData"
border
style="width: 100%"
size="medium"
:header-cell-style="{background: '#f5f7fa',color:'#606266'}"
header-align="center"
>
<el-table-column prop="date" label="序号"></el-table-column>
<el-table-column prop="name" label="姓名"></el-table-column>
<el-table-column prop="address" label="性别"></el-table-column>
<el-table-column prop="address" label="手机号"></el-table-column>
<el-table-column prop="address" label="地址"></el-table-column>
<el-table-column prop="address" label="伤残级别"></el-table-column>
<el-table-column prop="address" label="伤残类型"></el-table-column>
<el-table-column prop="address" label="申请时间"></el-table-column>
<el-table-column prop="address" label="选择"></el-table-column>
</el-table>
<div class="paginationClass">
<el-pagination
@size-change="handleSizeChange"
@current-change="handleCurrentChange"
:current-page="currentPage4"
:page-sizes="[100, 200, 300, 400]"
:page-size="100"
layout="total, sizes, prev, pager, next, jumper"
:total="400"
></el-pagination>
</div>
</el-card>
</el-col>
</el-row>
<!-- 上传公示名单 -->
<el-dialog title="提示" :visible="publicityShow">
<span>这是一段信息</span>
<span slot="footer" class="dialog-footer">
<el-button @click="dialogVisible = false">取 消</el-button>
<el-button type="primary" @click="dialogVisible = false">确 定</el-button>
</span>
</el-dialog>
</div>
</template>
<script>
export default {
data() {
return {
formInline: {},
publicityShow:false
};
}
};
</script>
<style>
</style>
\ No newline at end of file
<template>
<div class="app-container">
<el-row>
<el-col :md="{span:16,offset:4}" :sm="{span:24,offset:0}">
<el-card shadow="never">
<div class="k-flex-between-center" slot="header">
<div class="font-weight-bold">搜索条件</div>
<el-button type="primary">新增</el-button>
</div>
<el-form :inline="true" :model="formInline">
<el-form-item label="区域">
<el-select v-model="formInline.region" placeholder="活动区域">
<el-option label="区域一" value="shanghai"></el-option>
<el-option label="区域二" value="beijing"></el-option>
</el-select>
</el-form-item>
<el-form-item label="年份">
<el-select v-model="formInline.region" placeholder="活动区域">
<el-option label="区域一" value="shanghai"></el-option>
<el-option label="区域二" value="beijing"></el-option>
</el-select>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="onSubmit">查询</el-button>
</el-form-item>
</el-form>
</el-card>
<el-card shadow="never" class="el-card-top">
<div>
<div class="font-22">title</div>
<div>content</div>
</div>
<div class="el-card-top">
<div class="font-22">title</div>
<div>content</div>
</div>
</el-card>
<el-card shadow="never" class="el-card-top">
<div class="k-flex-between-center" slot="header">
<div class="font-weight-bold">项目任务指标</div>
<el-button type="primary">导出表格</el-button>
</div>
<el-table
:data="tableData"
border
style="width: 100%"
size="medium"
:header-cell-style="{background: '#f5f7fa'}"
header-align="center"
>
<el-table-column prop="date" label="序号"></el-table-column>
<el-table-column prop="name" label="姓名"></el-table-column>
<el-table-column prop="address" label="性别"></el-table-column>
<el-table-column prop="address" label="手机号"></el-table-column>
<el-table-column prop="address" label="地址"></el-table-column>
<el-table-column prop="address" label="伤残级别"></el-table-column>
<el-table-column prop="address" label="状态"></el-table-column>
<el-table-column prop="address" label="申请时间"></el-table-column>
<el-table-column prop="address" label="选择"></el-table-column>
</el-table>
<div class="paginationClass">
<el-pagination
@size-change="handleSizeChange"
@current-change="handleCurrentChange"
:current-page="currentPage4"
:page-sizes="[100, 200, 300, 400]"
:page-size="100"
layout="total, sizes, prev, pager, next, jumper"
:total="400"
></el-pagination>
</div>
</el-card>
<el-card shadow="never" class="el-card-top">
<div class="k-flex-between-center" slot="header">
<div class="font-weight-bold">任务指标信息</div>
<el-button type="primary">刷新</el-button>
</div>
<!-- 内容 -->
<el-row :gutter="30">
<el-col :md="{span:12}" :sm="{span:24}">
<el-form :model="formInline" label-width="120px">
<el-form-item label="年份" required>
<el-select v-model="formInline.region" placeholder="活动区域">
<el-option label="区域一" value="shanghai"></el-option>
<el-option label="区域二" value="beijing"></el-option>
</el-select>
</el-form-item>
<el-form-item label="行政区域" required>
<el-select v-model="formInline.region" placeholder="活动区域">
<el-option label="区域一" value="shanghai"></el-option>
<el-option label="区域二" value="beijing"></el-option>
</el-select>
</el-form-item>
<el-form-item label="资金总额(元)" required>
<el-input v-model="formInline.region"></el-input>
</el-form-item>
<el-form-item label="中央资金(元)" required>
<el-input v-model="formInline.region"></el-input>
</el-form-item>
<el-form-item label="自治区资金(元)" required>
<el-input v-model="formInline.region"></el-input>
</el-form-item>
<el-form-item label="市资金(元)" required>
<el-input v-model="formInline.region"></el-input>
</el-form-item>
<el-form-item label="县资金(元)" required>
<el-input v-model="formInline.region"></el-input>
</el-form-item>
<el-form-item label="其他资金(元)" required>
<el-input v-model="formInline.region"></el-input>
</el-form-item>
<el-form-item label="完成时间" required>
<el-date-picker v-model="formInline.time" type="date" placeholder="选择日期"></el-date-picker>
</el-form-item>
<el-form-item label="实施方式">
<el-select v-model="formInline.region" placeholder="活动区域">
<el-option label="区域一" value="shanghai"></el-option>
<el-option label="区域二" value="beijing"></el-option>
</el-select>
</el-form-item>
<el-form-item label="备注">
<el-input
type="textarea"
:autosize="{ minRows: 2, maxRows: 4}"
placeholder="请输入内容"
v-model="formInline.textarea2"
></el-input>
</el-form-item>
</el-form>
</el-col>
<el-col :md="{span:12}" :sm="{span:24}">
<div class="k-flex k-space-between">
<div class="fromTitle">实施方案</div>
<div class="k-all imgdiv">
<img src="http://106.13.160.144/img/%E5%85%B6%E4%BB%96.png" alt />
</div>
</div>
<div class="k-flex k-space-between el-card-top">
<div class="fromTitle">财务凭证</div>
<div class="k-all imgdiv">
<img src="http://106.13.160.144/img/%E5%85%B6%E4%BB%96.png" alt />
</div>
</div>
<div class="k-flex k-space-between el-card-top">
<div class="fromTitle">工作通知</div>
<div class="k-all imgdiv">
<img src="http://106.13.160.144/img/%E5%85%B6%E4%BB%96.png" alt />
</div>
</div>
</el-col>
</el-row>
<div class="k-flex-around-center el-card-top">
<el-button type="primary" size="medium" style="width:30%">保存</el-button>
</div>
</el-card>
</el-col>
</el-row>
</div>
</template>
<script>
export default {
data() {
return {
formInline: {} //from内容
};
}
};
</script>
<style lang="scss">
.fromTitle {
width: 100px;
font-size: 14px;
color: #606266;
font-weight: bold;
}
.imgdiv {
border-radius: 4px;
border: 1px dashed #606266;
height: 150px;
}
.imgdiv > img {
height: 150px;
width: 100%;
}
</style>
\ No newline at end of file
<template>
<div class="app-container">
<el-row>
<el-col :md="{span:16,offset:4}" :sm="{span:12,offset:0}">
<el-card shadow="never">
<div class="k-flex-between-center" slot="header">
<div class="font-weight-bold">搜索条件</div>
</div>
<el-form :inline="true" :model="formInline">
<el-form-item label="年份">
<el-select v-model="formInline.region" placeholder="活动区域">
<el-option label="区域一" value="shanghai"></el-option>
<el-option label="区域二" value="beijing"></el-option>
</el-select>
</el-form-item>
<el-form-item label="筛选区域">
<el-select v-model="formInline.region" placeholder="活动区域">
<el-option label="区域一" value="shanghai"></el-option>
<el-option label="区域二" value="beijing"></el-option>
</el-select>
</el-form-item>
<br>
<el-form-item label="姓名">
<el-input v-model="formInline.user" placeholder="姓名"></el-input>
</el-form-item>
<el-form-item label="手机号">
<el-input v-model="formInline.user" placeholder="手机号"></el-input>
</el-form-item>
<el-form-item label="状态">
<el-select v-model="formInline.region" placeholder="活动区域">
<el-option label="区域一" value="shanghai"></el-option>
<el-option label="区域二" value="beijing"></el-option>
</el-select>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="onSubmit" icon="el-icon-search">查询</el-button>
</el-form-item>
</el-form>
</el-card>
<el-card shadow="never" class="el-card-top">
<div class="k-flex-between-center" slot="header">
<div class="font-weight-bold">选择无障碍改造对象</div>
<el-button type="primary">导出表格</el-button>
</div>
<el-table
:data="tableData"
border
style="width: 100%"
size="medium"
:header-cell-style="{background: '#f5f7fa'}"
header-align="center"
>
<el-table-column prop="date" label="序号"></el-table-column>
<el-table-column prop="name" label="姓名"></el-table-column>
<el-table-column prop="address" label="性别"></el-table-column>
<el-table-column prop="address" label="手机号"></el-table-column>
<el-table-column prop="address" label="地址"></el-table-column>
<el-table-column prop="address" label="伤残级别"></el-table-column>
<el-table-column prop="address" label="状态"></el-table-column>
<el-table-column prop="address" label="申请时间"></el-table-column>
<el-table-column prop="address" label="选择"></el-table-column>
</el-table>
<div class="block">
<el-pagination
@size-change="handleSizeChange"
@current-change="handleCurrentChange"
:current-page="currentPage4"
:page-sizes="[100, 200, 300, 400]"
:page-size="100"
layout="total, sizes, prev, pager, next, jumper"
:total="400"
></el-pagination>
</div>
</el-card>
</el-col>
</el-row>
</div>
</template>
<script>
export default {
data() {
return {
title: "哈哈哈",
formInline: {},
tableData: [
{
date: "2016-05-02",
name: "王小虎",
address: "上海市普陀区金沙江路 1518 弄"
},
{
date: "2016-05-04",
name: "王小虎",
address: "上海市普陀区金沙江路 1517 弄"
},
{
date: "2016-05-01",
name: "王小虎",
address: "上海市普陀区金沙江路 1519 弄"
},
{
date: "2016-05-03",
name: "王小虎",
address: "上海市普陀区金沙江路 1516 弄"
}
]
};
},
created() {},
methods: {}
};
</script>
<style lang="scss">
.block {
padding: 8px 0;
}
</style>
\ No newline at end of file
<template>
<div class="app-container">
<el-row>
<el-col :md="{span:18,offset:3}" :sm="{span:12,offset:0}">
<el-col>
<el-card>
<div slot="header">无障碍改造项目监管监督</div>
<el-card shadow="never">
<div class="k-flex-between-center" slot="header">
<div class="font-weight-bold">通知公告</div>
<el-button type="primary">导出表格</el-button>
</div>
<el-table
:data="tableData"
border
style="width: 100%"
size="medium"
:header-cell-style="{background: '#f5f7fa'}"
header-align="center"
>
<el-table-column prop="date" label="时间"></el-table-column>
<el-table-column prop="name" label="标题"></el-table-column>
<el-table-column prop="address" label="简介"></el-table-column>
<el-table-column prop="address" label="查看">
<template slot-scope="scope">
<el-button
@click="deleteRow(scope.$index,scope.row)"
type="text"
size="small"
>查看详情</el-button>
</template>
</el-table-column>
</el-table>
<div class="block">
<el-pagination
@size-change="handleSizeChange"
@current-change="handleCurrentChange"
:current-page="currentPage4"
:page-sizes="[100, 200, 300, 400]"
:page-size="100"
layout="total, sizes, prev, pager, next, jumper"
:total="400"
></el-pagination>
</div>
</el-card>
<!-- 搜索条件 -->
<el-card shadow="never">
<div slot="header" class="font-weight-bold">搜索条件</div>
<el-form :inline="true" :model="queryData">
<el-form-item label="行政区域">
<el-select v-model="queryData.region" placeholder="活动区域">
<el-option label="区域一" value="shanghai"></el-option>
<el-option label="区域二" value="beijing"></el-option>
</el-select>
</el-form-item>
<el-form-item>
<el-button type="primary" icon="el-icon-search" @click="onSubmit">查询</el-button>
</el-form-item>
</el-form>
</el-card>
<!-- 警告通知 -->
<el-card shadow="never">
<div slot="header" class="font-weight-bold">搜索条件</div>
<el-row :gutter="10">
<el-col :sm="{span:24}" :md="{span:6}" v-for="(item,index) in 4" :key="index">
<div class="text-center box">
<div>数据异常</div>
<div class="font-weight-bold">0</div>
</div>
</el-col>
</el-row>
</el-card>
</el-card>
</el-col>
</el-col>
</el-row>
<!-- 模态框 -->
<el-dialog title="详情" :visible="modalBoxShow" :before-close="handleClose">{{ modalBoxInfo }}</el-dialog>
</div>
</template>
<script>
export default {
data() {
return {
tableData: [
{
date: "2016-05-02",
name: "王小虎",
address: "上海市普陀区金沙江路 1518 弄"
},
{
date: "2016-05-04",
name: "王小虎",
address: "上海市普陀区金沙江路 1517 弄"
},
{
date: "2016-05-01",
name: "王小虎",
address: "上海市普陀区金沙江路 1519 弄"
},
{
date: "2016-05-03",
name: "王小虎",
address: "上海市普陀区金沙江路 1516 弄"
}
],
//模态框
modalBoxShow: false,
modalBoxInfo: {},
//搜索
queryData: {}
};
},
methods: {
deleteRow(index, row) {
console.log(index, row);
this.modalBoxInfo = row;
this.modalBoxShow = true;
},
//关闭模态框
handleClose() {
this.modalBoxShow = false;
}
}
};
</script>
<style rel="stylesheet/scss" lang="scss" scoped>
.top {
padding: 10px 0;
}
.block {
padding: 8px 0;
}
.box div:first-child {
margin-bottom: 30px;
}
</style>
\ No newline at end of file
...@@ -79,8 +79,12 @@ export default { ...@@ -79,8 +79,12 @@ export default {
} }
}, },
created() { created() {
// 获取验证码
this.getCode() this.getCode()
// 获取用户名密码等Cookie
this.getCookie() this.getCookie()
// token 过期提示
this.point()
}, },
methods: { methods: {
getCode() { getCode() {
...@@ -138,6 +142,18 @@ export default { ...@@ -138,6 +142,18 @@ export default {
return false return false
} }
}) })
},
point() {
const point = Cookies.get('point') !== undefined
if (point) {
this.$notify({
title: '提示',
message: '当前登录状态已过期,请重新登录!',
type: 'warning',
duration: 8000
})
Cookies.remove('point')
}
} }
} }
} }
......
...@@ -4,7 +4,14 @@ ...@@ -4,7 +4,14 @@
<div class="head-container"> <div class="head-container">
<div v-if="crud.props.searchToggle"> <div v-if="crud.props.searchToggle">
<!-- 搜索 --> <!-- 搜索 -->
<el-input v-model="query.id" clearable placeholder="输入名称或IP搜索" style="width: 200px" class="filter-item" @keyup.enter.native="crud.toQuery" /> <el-input
v-model="query.id"
clearable
placeholder="输入名称或IP搜索"
style="width: 200px"
class="filter-item"
@keyup.enter.native="crud.toQuery"
/>
<el-date-picker <el-date-picker
v-model="query.createTime" v-model="query.createTime"
:default-time="['00:00:00','23:59:59']" :default-time="['00:00:00','23:59:59']"
...@@ -21,7 +28,14 @@ ...@@ -21,7 +28,14 @@
<crudOperation :permission="permission" /> <crudOperation :permission="permission" />
</div> </div>
<!--表单组件--> <!--表单组件-->
<el-dialog append-to-body :close-on-click-modal="false" :before-close="crud.cancelCU" :visible.sync="crud.status.cu > 0" :title="crud.status.title" width="470px"> <el-dialog
append-to-body
:close-on-click-modal="false"
:before-close="crud.cancelCU"
:visible.sync="crud.status.cu > 0"
:title="crud.status.title"
width="470px"
>
<el-form ref="form" :model="form" :rules="rules" size="small" label-width="55px"> <el-form ref="form" :model="form" :rules="rules" size="small" label-width="55px">
<el-form-item label="名称" prop="name"> <el-form-item label="名称" prop="name">
<el-input v-model="form.name" style="width: 370px" /> <el-input v-model="form.name" style="width: 370px" />
...@@ -30,14 +44,23 @@ ...@@ -30,14 +44,23 @@
<el-input v-model="form.ip" style="width: 370px" /> <el-input v-model="form.ip" style="width: 370px" />
</el-form-item> </el-form-item>
<el-form-item label="端口" prop="port"> <el-form-item label="端口" prop="port">
<el-input-number v-model.number="form.port" controls-position="right" style="width: 370px;" /> <el-input-number
v-model.number="form.port"
controls-position="right"
style="width: 370px;"
/>
</el-form-item> </el-form-item>
<el-form-item label="账号" prop="account"> <el-form-item label="账号" prop="account">
<el-input v-model="form.account" style="width: 370px" /> <el-input v-model="form.account" style="width: 370px" />
</el-form-item> </el-form-item>
<el-form-item label="密码" prop="password"> <el-form-item label="密码" prop="password">
<el-input v-model="form.password" type="password" style="width: 200px" /> <el-input v-model="form.password" type="password" style="width: 200px" />
<el-button :loading="loading" type="success" style="align: right;" @click="testConnectServer">测试连接</el-button> <el-button
:loading="loading"
type="success"
style="align: right;"
@click="testConnectServer"
>测试连接</el-button>
</el-form-item> </el-form-item>
</el-form> </el-form>
<div slot="footer" class="dialog-footer"> <div slot="footer" class="dialog-footer">
...@@ -46,7 +69,13 @@ ...@@ -46,7 +69,13 @@
</div> </div>
</el-dialog> </el-dialog>
<!--表格渲染--> <!--表格渲染-->
<el-table ref="table" v-loading="crud.loading" :data="crud.data" style="width: 100%" @selection-change="crud.selectionChangeHandler"> <el-table
ref="table"
v-loading="crud.loading"
:data="crud.data"
style="width: 100%"
@selection-change="crud.selectionChangeHandler"
>
<el-table-column type="selection" width="55" /> <el-table-column type="selection" width="55" />
<el-table-column prop="name" label="名称" /> <el-table-column prop="name" label="名称" />
<el-table-column prop="ip" label="IP" /> <el-table-column prop="ip" label="IP" />
...@@ -57,12 +86,14 @@ ...@@ -57,12 +86,14 @@
<span>{{ parseTime(scope.row.createTime) }}</span> <span>{{ parseTime(scope.row.createTime) }}</span>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column v-permission="['admin','serverDeploy:edit','serverDeploy:del']" label="操作" width="150px" align="center"> <el-table-column
v-permission="['admin','serverDeploy:edit','serverDeploy:del']"
label="操作"
width="150px"
align="center"
>
<template slot-scope="scope"> <template slot-scope="scope">
<udOperation <udOperation :data="scope.row" :permission="permission" />
:data="scope.row"
:permission="permission"
/>
</template> </template>
</el-table-column> </el-table-column>
</el-table> </el-table>
...@@ -72,22 +103,32 @@ ...@@ -72,22 +103,32 @@
</template> </template>
<script> <script>
import crudServer from "@/api/mnt/serverDeploy";
import { testServerConnect } from "@/api/mnt/connect";
import { validateIP } from "@/utils/validate";
import CRUD, { presenter, header, form, crud } from "@crud/crud";
import rrOperation from "@crud/RR.operation";
import crudOperation from "@crud/CRUD.operation";
import udOperation from "@crud/UD.operation";
import pagination from "@crud/Pagination";
import crudServer from '@/api/mnt/serverDeploy' const defaultForm = {
import { testServerConnect } from '@/api/mnt/connect' id: null,
import { validateIP } from '@/utils/validate' name: null,
import CRUD, { presenter, header, form, crud } from '@crud/crud' ip: null,
import rrOperation from '@crud/RR.operation' port: 22,
import crudOperation from '@crud/CRUD.operation' account: "root",
import udOperation from '@crud/UD.operation' password: null
import pagination from '@crud/Pagination' };
const defaultForm = { id: null, name: null, ip: null, port: 22, account: 'root', password: null }
export default { export default {
name: 'Server', name: "Server",
components: { pagination, crudOperation, rrOperation, udOperation }, components: { pagination, crudOperation, rrOperation, udOperation },
cruds() { cruds() {
return CRUD({ title: '服务器', url: 'api/serverDeploy', crudMethod: { ...crudServer }}) return CRUD({
title: "服务器",
url: "api/serverDeploy",
crudMethod: { ...crudServer }
});
}, },
mixins: [presenter(), header(), form(defaultForm), crud()], mixins: [presenter(), header(), form(defaultForm), crud()],
data() { data() {
...@@ -96,54 +137,55 @@ export default { ...@@ -96,54 +137,55 @@ export default {
accountMap: {}, accountMap: {},
loading: false, loading: false,
permission: { permission: {
add: ['admin', 'serverDeploy:add'], add: ["admin", "serverDeploy:add"],
edit: ['admin', 'serverDeploy:edit'], edit: ["admin", "serverDeploy:edit"],
del: ['admin', 'serverDeploy:del'] del: ["admin", "serverDeploy:del"]
}, },
rules: { rules: {
name: [ name: [{ required: true, message: "请输入名称", trigger: "blur" }],
{ required: true, message: '请输入名称', trigger: 'blur' }
],
ip: [ ip: [
{ required: true, message: '请输入IP', trigger: 'blur' }, { required: true, message: "请输入IP", trigger: "blur" },
{ validator: validateIP, trigger: 'change' } { validator: validateIP, trigger: "change" }
], ],
port: [ port: [
{ required: true, message: '请输入端口', trigger: 'blur', type: 'number' } {
], required: true,
account: [ message: "请输入端口",
{ required: true, message: '请输入账号', trigger: 'blur' } trigger: "blur",
], type: "number"
password: [
{ required: true, message: '请输入密码', trigger: 'blur' }
]
} }
],
account: [{ required: true, message: "请输入账号", trigger: "blur" }],
password: [{ required: true, message: "请输入密码", trigger: "blur" }]
} }
};
}, },
methods: { methods: {
testConnectServer() { testConnectServer() {
this.$refs['form'].validate((valid) => { this.$refs["form"].validate(valid => {
if (valid) { if (valid) {
this.loading = true this.loading = true;
testServerConnect(this.form).then((res) => { testServerConnect(this.form)
this.loading = false .then(res => {
this.loading = false;
this.$notify({ this.$notify({
title: res ? '连接成功' : '连接失败', title: res ? "连接成功" : "连接失败",
type: res ? 'success' : 'error', type: res ? "success" : "error",
duration: 2500 duration: 2500
});
}) })
}).catch(() => { .catch(() => {
this.loading = false this.loading = false;
}) });
} }
}) });
} }
} }
} };
</script> </script>
<style rel="stylesheet/scss" lang="scss" scoped> <style rel="stylesheet/scss" lang="scss" scoped>
/deep/ .el-input-number .el-input__inner { /deep/ .el-input-number .el-input__inner {
text-align: left; text-align: left;
} }
</style> </style>
<template>
<div class="app-container">
<el-row>
<el-col :md="{span:18,offset:3}" :sm="{span:12,offset:0}">
<el-card>
<div slot="header" class="clearfix">
<span class="font-weight-bold font-30">广西全区持证残疾人统计数据(每1个小时更新一次)</span>
</div>
<el-table
:data="tableData"
border
style="width: 100%"
size="medium"
:header-cell-style="{background: '#f5f7fa'}"
header-align="center"
>
<el-table-column prop="date" label="残疾类型"></el-table-column>
<el-table-column prop="name" label="总人数"></el-table-column>
<el-table-column prop="address" label="6-16岁学龄儿童人数"></el-table-column>
</el-table>
</el-card>
</el-col>
</el-row>
</div>
</template>
<script>
export default {
name: "idtkindCount",
data() {
return {
tableData: [
{
date: "2016-05-02",
name: "王小虎",
address: "上海市普陀区金沙江路 1518 弄"
},
{
date: "2016-05-04",
name: "王小虎",
address: "上海市普陀区金沙江路 1517 弄"
},
{
date: "2016-05-01",
name: "王小虎",
address: "上海市普陀区金沙江路 1519 弄"
},
{
date: "2016-05-03",
name: "王小虎",
address: "上海市普陀区金沙江路 1516 弄"
}
]
};
}
};
</script>
<style rel="stylesheet/scss" lang="scss" scoped>
</style>
\ No newline at end of file
<!-- 父级路由组件 -->
<template>
<div>
<!-- xxx html 内容 -->
<router-view />
</div>
</template>
<template>
<div class="app-container">
<el-row>
<el-col :md="{span:18,offset:3}" :sm="{span:12,offset:0}">
<div class="font-weight-bold font-24 text-center title">广西残疾人“十三五”小康进程规划数据指标</div>
<el-table
:data="tableData"
border
style="width: 100%"
size="medium"
:header-cell-style="{background: '#f5f7fa'}"
header-align="center"
>
<el-table-column prop="date" label="序号" width="80" align="center"></el-table-column>
<el-table-column prop="name" label="主要指标" align="center"></el-table-column>
<el-table-column prop="address" label="任务数" width="80" align="center"></el-table-column>
<el-table-column prop="address" label="完成数" width="80" align="center"></el-table-column>
<el-table-column prop="address" label="任务数(含来源、时间、范围)" align="center"></el-table-column>
<el-table-column prop="address" label="完成数(含来源、时间、范围)" align="center"></el-table-column>
<el-table-column prop="address" label="目标值" width="80" align="center"></el-table-column>
<el-table-column prop="address" label="完成率" width="80" align="center"></el-table-column>
</el-table>
</el-col>
</el-row>
</div>
</template>
<script>
export default {
name: "StatisticsReport"
};
</script>
<style rel="stylesheet/scss" lang="scss" scoped>
.title {
padding: 20px 0;
}
</style>
\ No newline at end of file
<template>
<div class="app-container">
<el-row>
<el-col :md="{span:16,offset:4}" :sm="{span:12,offset:0}">
<el-card>
<div class="top">
<div>广西残疾人大数据</div>
<div class="font-weight-bold">包括:广西残疾人办证数据、动态更新数据、建档立卡数据、业务服务数据、区直单位服务残疾人数据</div>
</div>
<el-card shadow="never" v-for="(item,index) in list" :key="index" class="content">
<div slot="header" class="font-weight-bold">{{ item.title }}</div>
<el-row :gutter="10">
<el-col v-for="(v,i) in item.data" :key="i" class="text-center" :md="{span:6}" :sm="{span:12}">
<div class="font-50">
<svg-icon icon-class="database" />
</div>
<div>{{v.name}}</div>
<div class="font-30 font-weight-bold">{{v.num}}</div>
</el-col>
</el-row>
</el-card>
</el-card>
</el-col>
</el-row>
</div>
</template>
<script>
export default {
data() {
return {
list: [
{
title: "残疾人基础信息数据库",
data: [
{
name: "全区持证残疾人",
num: "1992122"
}
]
},
{
title: "历年动态更新数据库",
data: [
{
name: "残疾人动态更新数据库2018",
num: "1409499"
},
{
name: "残疾人动态更新数据库2017",
num: "1409499"
}
]
},
{
title: "建档立卡贫困残疾人数据库",
data: [
{
name: "建档立卡贫困残疾人数据库",
num: "1409499"
}
]
},
{
title: "残疾人两项补贴数据库",
data: [
{
name: "残疾人两项补贴数据库",
num: "1409499"
}
]
}
]
};
},
methods: {}
};
</script>
<style lang="scss" >
.top {
padding: 20px 0;
}
.top div:first-child {
padding-bottom: 20px;
}
.content{
margin-bottom: 30px;
}
.text-center div{
padding-bottom:10px;
}
</style>
\ No newline at end of file
<template>
<div class="app-container">
<el-row :gutter="20">
<el-col :md="14" :sm="24">
<div class="grid-content bg-purple-dark">456</div>
</el-col>
<el-col :md="10" :sm="24">
<el-card>
<el-card shadow="never">
<div slot="header" >
<span>搜索条件</span>
</div>
<el-form ref="form" :model="form" label-width="80px">
<el-form-item label="项目">
<el-select v-model="form.region" placeholder="请选择项目">
<el-option label="区域一" value="shanghai"></el-option>
<el-option label="区域二" value="beijing"></el-option>
</el-select>
</el-form-item>
<el-form-item label="年份">
<el-select v-model="form.region" placeholder="请选择年份">
<el-option label="区域一" value="shanghai"></el-option>
<el-option label="区域二" value="beijing"></el-option>
</el-select>
</el-form-item>
<el-form-item label="地区">
<el-select v-model="form.region" placeholder="请选择地区">
<el-option label="区域一" value="shanghai"></el-option>
<el-option label="区域二" value="beijing"></el-option>
</el-select>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="onSubmit">查询</el-button>
</el-form-item>
</el-form>
</el-card>
<el-table
:data="tableData"
height="450"
border
style="width:100%"
:header-cell-style="{background: '#f5f7fa'}"
header-align="center"
>
<el-table-column prop="addr" label="地区" align="center"></el-table-column>
<el-table-column prop="taskNum" label="任务数" align="center"></el-table-column>
<el-table-column prop="num" label="资金总额" align="center"></el-table-column>
<el-table-column prop="setNum" label="使用资金数" align="center"></el-table-column>
<el-table-column prop="rateNum" label="完成率" align="center"></el-table-column>
<el-table-column prop="state" label="统计情况" align="center"></el-table-column>
</el-table>
</el-card>
</el-col>
</el-row>
</div>
</template>
<script>
export default {
name: "Map",
data() {
return {
tableData: [
{
addr: "南宁",
taskNum: 100,
num: 200,
setNum: 300,
rateNum: "50%",
state: "正常"
},
{
addr: "南宁",
taskNum: 100,
num: 200,
setNum: 300,
rateNum: "50%",
state: "正常"
},
{
addr: "南宁",
taskNum: 100,
num: 200,
setNum: 300,
rateNum: "50%",
state: "正常"
},
{
addr: "南宁",
taskNum: 100,
num: 200,
setNum: 300,
rateNum: "50%",
state: "正常"
}, {
addr: "南宁",
taskNum: 100,
num: 200,
setNum: 300,
rateNum: "50%",
state: "正常"
},
{
addr: "南宁",
taskNum: 100,
num: 200,
setNum: 300,
rateNum: "50%",
state: "正常"
},
{
addr: "南宁",
taskNum: 100,
num: 200,
setNum: 300,
rateNum: "50%",
state: "正常"
},
{
addr: "南宁",
taskNum: 100,
num: 200,
setNum: 300,
rateNum: "50%",
state: "正常"
},
{
addr: "南宁",
taskNum: 100,
num: 200,
setNum: 300,
rateNum: "50%",
state: "正常"
},
{
addr: "南宁",
taskNum: 100,
num: 200,
setNum: 300,
rateNum: "50%",
state: "正常"
},
{
addr: "南宁",
taskNum: 100,
num: 200,
setNum: 300,
rateNum: "50%",
state: "正常"
}
],
tableDataFormat: [
{
prop: "addr",
label: "地区",
align: "center"
},
{
prop: "taskNum",
label: "任务数",
align: "center"
}
],
form:{
region:'shanghai'
}
};
},
methods: {}
};
</script>
<style lang="scss" scoped>
</style>
\ No newline at end of file
<template>
<div class="app-container">
<el-form ref="form" :model="form" label-width="50px">
<el-form-item label="项目">
<el-select v-model="form.project" placeholder="请选择活动区域">
<el-option label="区域一" value="shanghai"></el-option>
<el-option label="区域二" value="beijing"></el-option>
</el-select>
</el-form-item>
<el-form-item label="年份">
<el-date-picker v-model="form.date" type="year" placeholder="选择年"></el-date-picker>
</el-form-item>
<el-form-item label="地区">
<el-select v-model="form.region" placeholder="请选择活动区域">
<el-option label="区域一" value="shanghai"></el-option>
<el-option label="区域二" value="beijing"></el-option>
</el-select>
<el-button type="primary" icon="el-icon-search" @click="onSubmit" class="query">查询</el-button>
</el-form-item>
</el-form>
<el-row :gutter="20">
<el-col :md="8" :sm="12">
<el-card>
<div id="main"></div>
</el-card>
</el-col>
<el-col :md="16" :sm="12">
<el-row :gutter="20" >
<el-col v-for="(item,index) in taskTotal" :key="index" :span="6" class="el-col-margin">
<el-card class="list">
<div>
<count-to :startVal="0" :endVal="item.value" :duration="2000"> </count-to>
</div>
<div>{{item.name}}</div>
</el-card>
</el-col>
</el-row>
</el-col>
</el-row>
<el-row class="foot">
<el-card>
<div id="z"></div>
</el-card>
</el-row>
</div>
</template>
<script>
var echarts = require("echarts");
var main = "";
var myChart = "";
import CountTo from 'vue-count-to'
import { getCityAreaList } from "@/api/portal/task";
export default {
components:{
CountTo
},
data() {
return {
form: {
project: "",
date: "",
region: ""
},
taskTotal: [
{ name: "申请", value: 139, number: 0 },
{ name: "公示", value: 329, number: 1 },
{ name: "拨款", value: 0, number: 0 },
{ name: "完成", value: 0, number: 0 },
{ name: "公示", value: 329, number: 1 },
{ name: "拨款", value: 0, number: 0 },
]
};
},
watch: {},
created() {
this.getCityAreaListFun();
},
mounted() {
this.echart();
this.zfun();
window.onresize = function() {
main.resize();
myChart.resize();
};
},
methods: {
//查询数据
onSubmit() {
console.log(JSON.stringify(this.form));
},
//画环形图
echart() {
main = echarts.init(document.getElementById("main")); //环形图
// 绘制图表
main.setOption({
title: {
text: "项目状态统计",
subtext: "本年度任务数:共计468",
left: "top"
},
tooltip: {
trigger: "item",
formatter: "{a} <br/>{b}: {c} ({d}%)"
},
legend: {
orient: "vertical",
y: "center",
// x: 'right',
x: "70%",
textStyle: { fontSize: 7 },
align: "left",
textStyle: {
rich: {
a: {
fontSize: 20,
align: "left",
padding: [0, 0, 0, 10]
},
b: {
fontSize: 20,
align: "right",
padding: [0, 0, 0, 10],
lineHeight: 25
}
}
},
backgroundColor: "#fff"
},
series: [
{
name: "状态统计",
type: "pie",
radius: [50, 80],
center: ["35%", "50%"],
label: {
normal: {
show: false
},
emphasis: {
show: false
}
},
data: [
{ name: "申请", value: 139, number: 0 },
{ name: "公示", value: 329, number: 1 },
{ name: "拨款", value: 0, number: 0 },
{ name: "完成", value: 0, number: 0 }
]
}
]
});
},
//柱形图
zfun() {
let option = {
title: {
text: "标题",
left: "top"
},
xAxis: {
type: "category",
data: ["Mon", "Tue", "Wed", "Thu", "Fri", "Sat", "Sun"]
},
yAxis: {
type: "value"
},
series: [
{
data: [120, 200, 150, 80, 70, 110, 130],
type: "bar"
}
]
// tooltip: {
// trigger: "axis",
// formatter: function(pa) {
// var params = pa[0];
// if (params.value == undefined || params.value !== params.value) {
// params.value = 0;
// }
// return "完成情况<br />" + params.name + ": " + params.value;
// }
// }
};
myChart = echarts.init(document.getElementById("z")); //柱形图
myChart.setOption(option);
},
//获取地区地址
getCityAreaListFun() {
getCityAreaList().then(res => {
console.log(res);
});
}
}
};
</script>
<style scoped lang="scss">
#main,
#z {
height: 330px;
}
.query {
margin-left: 15px;
}
.el-col-margin {
margin-top: 25px;
height: 150px;
}
.list {
display: flex;
justify-content: center;
flex-direction: column;
height: 150px;
text-align: center;
}
.list div:first-child {
color: red;
font-size: 28px;
}
.list div:last-child {
margin-top: 20px;
color: #333333;
font-size: 13px;
}
.foot {
margin-top: 20px;
}
</style>>
...@@ -55,7 +55,6 @@ ...@@ -55,7 +55,6 @@
<script> <script>
import crudDictDetail from '@/api/system/dictDetail' import crudDictDetail from '@/api/system/dictDetail'
import CRUD, { presenter, header, form } from '@crud/crud' import CRUD, { presenter, header, form } from '@crud/crud'
import pagination from '@crud/Pagination' import pagination from '@crud/Pagination'
import rrOperation from '@crud/RR.operation' import rrOperation from '@crud/RR.operation'
...@@ -69,7 +68,8 @@ export default { ...@@ -69,7 +68,8 @@ export default {
return [ return [
CRUD({ title: '字典详情', url: 'api/dictDetail', query: { dictName: '' }, sort: ['dictSort,asc', 'id,desc'], CRUD({ title: '字典详情', url: 'api/dictDetail', query: { dictName: '' }, sort: ['dictSort,asc', 'id,desc'],
crudMethod: { ...crudDictDetail }, crudMethod: { ...crudDictDetail },
optShow: { add: true, optShow: {
add: true,
edit: true, edit: true,
del: true, del: true,
reset: false reset: false
......
...@@ -72,7 +72,6 @@ export default { ...@@ -72,7 +72,6 @@ export default {
crudMethod: { ...crudJob } crudMethod: { ...crudJob }
}) })
}, },
mixins: [presenter()], mixins: [presenter()],
// 数据字典 // 数据字典
dicts: ['job_status'], dicts: ['job_status'],
...@@ -85,7 +84,6 @@ export default { ...@@ -85,7 +84,6 @@ export default {
} }
} }
}, },
methods: { methods: {
// 改变状态 // 改变状态
changeEnabled(data, val) { changeEnabled(data, val) {
......
<template>
<div>我是新的测试页</div>
</template>
<script>
export default {
name:'new'
}
</script>
<style scoped>
</style>
<template>
<div>我是旧的测试页面</div>
</template>
<script>
export default {
name: "old",
data() {
return {};
},
created() {},
methods: {},
mounted() {}
};
</script>
...@@ -7,14 +7,17 @@ function resolve(dir) { ...@@ -7,14 +7,17 @@ function resolve(dir) {
} }
const name = defaultSettings.title // 网址标题 const name = defaultSettings.title // 网址标题
const port = 8888 // 端口配置 const port = 8013 // 端口配置
// All configuration item explanations can be find in https://cli.vuejs.org/config/ // All configuration item explanations can be find in https://cli.vuejs.org/config/
module.exports = { module.exports = {
// hash 模式下可使用
// publicPath: process.env.NODE_ENV === 'development' ? '/' : './',
publicPath: '/', publicPath: '/',
outputDir: 'dist', outputDir: 'dist',
assetsDir: 'static', assetsDir: 'static',
lintOnSave: process.env.NODE_ENV === 'development', //lintOnSave: process.env.NODE_ENV === 'development',
lintOnSave:false,
productionSourceMap: false, productionSourceMap: false,
devServer: { devServer: {
port: port, port: port,
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment