recss #1
|
@ -4,7 +4,7 @@
|
||||||
v-if="!headerBarFixed"
|
v-if="!headerBarFixed"
|
||||||
:class="[
|
:class="[
|
||||||
fixedHeader && 'ant-header-fixedHeader',
|
fixedHeader && 'ant-header-fixedHeader',
|
||||||
sidebarOpened ? 'ant-header-side-opened' : 'ant-header-side-closed',
|
//sidebarOpened ? 'ant-header-side-opened' : 'ant-header-side-closed',
|
||||||
]"
|
]"
|
||||||
:style="{ padding: '0' }"
|
:style="{ padding: '0' }"
|
||||||
>
|
>
|
||||||
|
|
|
@ -1,28 +1,7 @@
|
||||||
<template>
|
<template>
|
||||||
<a-layout class="layout" :class="[device]">
|
<a-layout class="layout" :class="[device]">
|
||||||
<template v-if="layoutMode === 'sidemenu'">
|
<!-- <template v-if="layoutMode === 'sidemenu'">
|
||||||
<a-drawer
|
|
||||||
v-if="device === 'mobile'"
|
|
||||||
:wrapClassName="'drawer-sider ' + navTheme"
|
|
||||||
placement="left"
|
|
||||||
@close="() => (this.collapsed = false)"
|
|
||||||
:closable="false"
|
|
||||||
:visible="collapsed"
|
|
||||||
width="200px"
|
|
||||||
>
|
|
||||||
<side-menu
|
|
||||||
mode="inline"
|
|
||||||
v-if="device === 'mobile'"
|
|
||||||
:menus="menus"
|
|
||||||
@menuSelect="menuSelect"
|
|
||||||
:theme="navTheme"
|
|
||||||
:collapsed="false"
|
|
||||||
:collapsible="true"
|
|
||||||
></side-menu>
|
|
||||||
</a-drawer>
|
|
||||||
|
|
||||||
<side-menu
|
<side-menu
|
||||||
v-show="device === 'desktop'"
|
|
||||||
mode="inline"
|
mode="inline"
|
||||||
:menus="menus"
|
:menus="menus"
|
||||||
@menuSelect="myMenuSelect"
|
@menuSelect="myMenuSelect"
|
||||||
|
@ -30,28 +9,7 @@
|
||||||
:collapsed="collapsed"
|
:collapsed="collapsed"
|
||||||
:collapsible="true"
|
:collapsible="true"
|
||||||
></side-menu>
|
></side-menu>
|
||||||
</template>
|
</template> -->
|
||||||
<!-- 下次优化这些代码 -->
|
|
||||||
<template v-else>
|
|
||||||
<a-drawer
|
|
||||||
v-if="device === 'mobile'"
|
|
||||||
:wrapClassName="'drawer-sider ' + navTheme"
|
|
||||||
placement="left"
|
|
||||||
@close="() => (this.collapsed = false)"
|
|
||||||
:closable="false"
|
|
||||||
:visible="collapsed"
|
|
||||||
width="200px"
|
|
||||||
>
|
|
||||||
<side-menu
|
|
||||||
mode="inline"
|
|
||||||
:menus="menus"
|
|
||||||
@menuSelect="menuSelect"
|
|
||||||
:theme="navTheme"
|
|
||||||
:collapsed="false"
|
|
||||||
:collapsible="true"
|
|
||||||
></side-menu>
|
|
||||||
</a-drawer>
|
|
||||||
</template>
|
|
||||||
|
|
||||||
<a-layout
|
<a-layout
|
||||||
:class="[layoutMode, `content-width-${contentWidth}`]"
|
:class="[layoutMode, `content-width-${contentWidth}`]"
|
||||||
|
|
|
@ -1,37 +1,5 @@
|
||||||
<template>
|
<template>
|
||||||
<div class="user-wrapper" :class="theme" style="min-width:460px">
|
<div class="user-wrapper" :class="theme" style="min-width:460px">
|
||||||
<!-- update_begin author:zhaoxin date:20191129 for: 做头部菜单栏导航 -->
|
|
||||||
<!-- update-begin author:sunjianlei date:20191@20 for: 解决全局样式冲突的问题 -->
|
|
||||||
<!-- <span class="action" @click="showClick">
|
|
||||||
<a-icon type="search"></a-icon>
|
|
||||||
</span> -->
|
|
||||||
<!-- update-begin author:sunjianlei date:20200219 for: 菜单搜索改为动态组件,在手机端呈现出弹出框 -->
|
|
||||||
<!-- <component :is="searchMenuComp" v-show="searchMenuVisible || isMobile()" class="borders" :visible="searchMenuVisible" title="搜索菜单" :footer="null" @cancel="searchMenuVisible=false">
|
|
||||||
<a-select
|
|
||||||
class="search-input"
|
|
||||||
showSearch
|
|
||||||
:showArrow="false"
|
|
||||||
placeholder="搜索菜单"
|
|
||||||
optionFilterProp="children"
|
|
||||||
:filterOption="filterOption"
|
|
||||||
:open="isMobile()?true:null"
|
|
||||||
:getPopupContainer="(node) => node.parentNode"
|
|
||||||
:style="isMobile()?{width: '100%',marginBottom:'50px'}:{}"
|
|
||||||
@change="searchMethods"
|
|
||||||
@blur="hiddenClick"
|
|
||||||
>
|
|
||||||
<a-select-option v-for="(site,index) in searchMenuOptions" :key="index" :value="site.id">{{site.meta.title}}</a-select-option>
|
|
||||||
</a-select>
|
|
||||||
</component> -->
|
|
||||||
<!-- update-end author:sunjianlei date:20200219 for: 菜单搜索改为动态组件,在手机端呈现出弹出框 -->
|
|
||||||
<!-- update-end author:sunjianlei date:20191220 for: 解决全局样式冲突的问题 -->
|
|
||||||
<!-- update_end author:zhaoxin date:20191129 for: 做头部菜单栏导航 -->
|
|
||||||
<!-- <span class="action">
|
|
||||||
<a class="logout_title" target="_blank" href="http://doc.jeecg.com">
|
|
||||||
<a-icon type="question-circle-o"></a-icon>
|
|
||||||
</a>
|
|
||||||
</span> -->
|
|
||||||
<!-- <header-notice class="action"/> -->
|
|
||||||
<a-dropdown>
|
<a-dropdown>
|
||||||
<span class="action action-full ant-dropdown-link user-dropdown-menu" >
|
<span class="action action-full ant-dropdown-link user-dropdown-menu" >
|
||||||
<!-- <a-avatar class="avatar" size="small" :src="getAvatar()"/> -->
|
<!-- <a-avatar class="avatar" size="small" :src="getAvatar()"/> -->
|
||||||
|
@ -39,12 +7,6 @@
|
||||||
<span v-if="isDesktop()" style="color:#00c3ff">欢迎您,{{ nickname() }}</span>
|
<span v-if="isDesktop()" style="color:#00c3ff">欢迎您,{{ nickname() }}</span>
|
||||||
</span>
|
</span>
|
||||||
</a-dropdown>
|
</a-dropdown>
|
||||||
<span class="action">
|
|
||||||
<a class="logout_title" href="../../codeInstructions/index.html" target="_blank">
|
|
||||||
<!-- <a class="target" href="../../codeInstructions/index.html" target="_blank">函数文档</a>-->
|
|
||||||
<span v-if="isDesktop()" style="color:#00c3ff"> 函数文档</span>
|
|
||||||
</a>
|
|
||||||
</span>
|
|
||||||
<span class="action">
|
<span class="action">
|
||||||
<a class="logout_title" href="javascript:;" @click="handleLogout">
|
<a class="logout_title" href="javascript:;" @click="handleLogout">
|
||||||
<!-- <a-icon type="logout"/> -->
|
<!-- <a-icon type="logout"/> -->
|
||||||
|
|
123
src/views/data/dataManage.vue
Normal file
123
src/views/data/dataManage.vue
Normal file
|
@ -0,0 +1,123 @@
|
||||||
|
<template>
|
||||||
|
<a-card :bordered="false">
|
||||||
|
|
||||||
|
<!-- 查询区域 -->
|
||||||
|
<div class="table-page-search-wrapper">
|
||||||
|
<a-form layout="inline">
|
||||||
|
<a-row :gutter="30">
|
||||||
|
|
||||||
|
<a-col :md="6" :sm="10" >
|
||||||
|
<span style="float: left;overflow: hidden;" class="table-page-search-submitButtons">
|
||||||
|
<a-button @click="dataAdd" type="primary" v-has="'cont:btn'" icon="plus">发布到专题库</a-button>
|
||||||
|
</span>
|
||||||
|
</a-col>
|
||||||
|
</a-row>
|
||||||
|
</a-form>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- table区域-begin -->
|
||||||
|
<div style="height:900px;overflow-y:auto;">
|
||||||
|
<a-progress :percent="percent" status="active" />
|
||||||
|
<a-list bordered :data-source="contentList">
|
||||||
|
<template #renderItem="{ item }">
|
||||||
|
<a-list-item>{{ item }}</a-list-item>
|
||||||
|
</template>
|
||||||
|
</a-list>
|
||||||
|
</div>
|
||||||
|
<!-- table区域-end -->
|
||||||
|
|
||||||
|
<!-- 表单区域 -->
|
||||||
|
|
||||||
|
</a-card>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
|
||||||
|
import { JeecgListMixin } from '@/mixins/JeecgListMixin'
|
||||||
|
import JEllipsis from "@/components/jeecg/JEllipsis";
|
||||||
|
import {getAction} from '@/api/manage'
|
||||||
|
|
||||||
|
export default {
|
||||||
|
name: "dataManage",
|
||||||
|
mixins:[JeecgListMixin],
|
||||||
|
components: {
|
||||||
|
taskModal,
|
||||||
|
JEllipsis,
|
||||||
|
contentList:[],
|
||||||
|
percent:0,
|
||||||
|
VNodes: {
|
||||||
|
functional: true,
|
||||||
|
render: (h, ctx) => ctx.props.vnodes,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
data () {
|
||||||
|
return {
|
||||||
|
description: '数据发布',
|
||||||
|
}
|
||||||
|
},
|
||||||
|
mounted() {
|
||||||
|
//初始化websocket
|
||||||
|
this.initWebSocket()
|
||||||
|
},
|
||||||
|
computed: {
|
||||||
|
},
|
||||||
|
destroyed: function () { // 离开页面生命周期函数
|
||||||
|
this.websocketclose();
|
||||||
|
},
|
||||||
|
created () {
|
||||||
|
this.loadData();
|
||||||
|
},
|
||||||
|
methods: {
|
||||||
|
initWebSocket: function () {
|
||||||
|
// WebSocket与普通的请求所用协议有所不同,ws等同于http,wss等同于https
|
||||||
|
var userId = store.getters.userInfo.id;
|
||||||
|
var url = window._CONFIG['domianURL'].replace("https://","ws://").replace("http://","ws://")+"/websocket/1/data_distribute";
|
||||||
|
this.websock = new WebSocket(url);
|
||||||
|
this.websock.onopen = this.websocketonopen;
|
||||||
|
this.websock.onerror = this.websocketonerror;
|
||||||
|
this.websock.onmessage = this.websocketonmessage;
|
||||||
|
this.websock.onclose = this.websocketclose;
|
||||||
|
},
|
||||||
|
websocketonopen: function () {
|
||||||
|
console.log("WebSocket连接成功");
|
||||||
|
},
|
||||||
|
websocketonerror: function (e) {
|
||||||
|
console.log("WebSocket连接发生错误");
|
||||||
|
},
|
||||||
|
websocketonmessage: function (e) {
|
||||||
|
var data = eval("(" + e.data + ")");
|
||||||
|
console.log(e);
|
||||||
|
//处理订阅信息
|
||||||
|
this.contentList.push(data.content);
|
||||||
|
this.percent = data.currProgress
|
||||||
|
},
|
||||||
|
websocketclose: function (e) {
|
||||||
|
console.log("connection closed (" + e.code + ")");
|
||||||
|
},
|
||||||
|
dataAdd(){
|
||||||
|
getAction("/dataSpecial/special").then((res) => {
|
||||||
|
if (res.success) {
|
||||||
|
this.$message.success(res.message);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
},
|
||||||
|
loadData() {
|
||||||
|
taskPageList(this.queryParam).then((res) => {
|
||||||
|
if (res.success) {
|
||||||
|
this.dataSource = res.result.rows||res.result;
|
||||||
|
if(res.result.total)
|
||||||
|
{
|
||||||
|
this.ipagination.total = res.result.total;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
this.$message.warning(res.message);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
},
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
<style scoped>
|
||||||
|
@import '~@assets/less/common.less';
|
||||||
|
</style>
|
Loading…
Reference in New Issue
Block a user