Browse Source

修改首页展示

dev
caoyizhong 2 years ago
parent
commit
521023aeea
  1. 2
      src/utils/request.js
  2. 137
      src/views/dashboard/HomePage.vue
  3. 6
      src/views/description/ProcessDescriptionList.vue
  4. 40
      src/views/modules/oss/OSSFileList.vue
  5. 87
      src/views/statisticanalysis/costecharts/ItemCost.vue

2
src/utils/request.js

@ -17,7 +17,7 @@ let apiBaseUrl = window._CONFIG['domianURL'] || "/jeecg-boot";
const service = axios.create({ const service = axios.create({
//baseURL: '/jeecg-boot', //baseURL: '/jeecg-boot',
baseURL: apiBaseUrl, // api base_url baseURL: apiBaseUrl, // api base_url
timeout: 50000 // 请求超时时间 timeout: 100000 // 请求超时时间
}) })
const err = (error) => { const err = (error) => {

137
src/views/dashboard/HomePage.vue

@ -5,39 +5,90 @@
<a-card id="todo" style="float: left; width: 33%; height: 100%;padding-bottom: 10px;" :body-style="{height: '95%', overflow:'hidden'}"> <a-card id="todo" style="float: left; width: 33%; height: 100%;padding-bottom: 10px;" :body-style="{height: '95%', overflow:'hidden'}">
<div style="height: 40px;font-weight: 600; font-size: 16px;line-height: 40px"> <div style="height: 40px;font-weight: 600; font-size: 16px;line-height: 40px">
待办 公司风采
</div> </div>
<div id="todoDiv" style="height: 250px;overflow-y: auto;margin: 0 0 0 0;" @scroll="heightScrollTodo()"> <div id="messageDiv" style="height: 280px;overflow-y: auto;margin: 0 0 0 0;" >
<a-table <!-- <div id="messageDiv" style="height: 250px;overflow-y: auto;margin: 0 0 0 0;" @scroll="heightScrollTodo()">-->
rowKey="id" <!-- <a-table-->
:loading="loading" <!-- rowKey="id"-->
:show-header="false" <!-- :loading="loading"-->
:columns="columns" <!-- :show-header="false"-->
:dataSource="tasks" <!-- :columns="columns"-->
:pagination="false" <!-- :dataSource="tasks"-->
:customRow="rowClick" <!-- :pagination="false"-->
> <!-- :customRow="rowClick"-->
</a-table> <!-- >-->
<!-- </a-table>-->
<!-- <a-carousel arrows autoplay>-->
<!-- <div-->
<!-- slot="prevArrow"-->
<!-- slot-scope="props"-->
<!-- class="custom-slick-arrow"-->
<!-- style="left: 10px;zIndex: 1"-->
<!-- >-->
<!-- <a-icon type="left-circle" />-->
<!-- </div>-->
<!-- <div slot="nextArrow" slot-scope="props" class="custom-slick-arrow" style="right: 10px">-->
<!-- <a-icon type="right-circle" />-->
<!-- </div>-->
<!--&lt;!&ndash; <a slot="customPaging" slot-scope="props">&ndash;&gt;-->
<!--&lt;!&ndash; <img :src="getImgUrl(props.i)" />&ndash;&gt;-->
<!--&lt;!&ndash; </a>&ndash;&gt;-->
<!-- <div class="rightullidiv" v-for="item in this.listMien">-->
<!-- <img :src="item.url" />-->
<!-- </div>-->
<!-- </a-carousel>-->
<a-carousel arrows autoplay >
<div
slot="prevArrow"
slot-scope="props"
class="custom-slick-arrow"
style="left: 10px;zIndex: 1"
>
<a-icon type="left-circle" />
</div>
<div slot="nextArrow" slot-scope="props" class="custom-slick-arrow" style="right: 10px">
<a-icon type="right-circle" />
</div>
<div v-for="item in this.listMien" style="height: 260px" >
<img class="rightulliimg" :src="item.url" />
</div>
</a-carousel>
</div> </div>
</a-card> </a-card>
<!--站内消息--> <!--站内消息-->
<a-card id="message" style="width: 32%; height: 100%;margin: 0px 1%;padding-bottom: 10px;" :body-style="{height: '95%', overflow:'hidden'}"> <a-card id="message" style="width: 32%; height: 100%;margin: 0px 1%;padding-bottom: 10px;" :body-style="{height: '95%', overflow:'hidden'}">
<!-- <div style="height: 40px;font-weight: 600; font-size: 16px;line-height: 40px">-->
<!-- 站内消息-->
<!-- </div>-->
<!-- <div id="messageDiv" style="height: 250px;overflow-y: auto;margin: 0 0 0 0;" @scroll="heightScrollMessage()">-->
<!-- <a-table-->
<!-- rowKey="id"-->
<!-- :loading="loading"-->
<!-- :show-header="false"-->
<!-- :columns="msgColumns"-->
<!-- :dataSource="msgContent"-->
<!-- :pagination="false"-->
<!-- :customRow="rowClickToDo"-->
<!-- >-->
<!-- </a-table>-->
<!-- </div>-->
<!-- <show-announcement ref="ShowAnnouncement" @ok="modalFormOk"></show-announcement>-->
<div style="height: 40px;font-weight: 600; font-size: 16px;line-height: 40px"> <div style="height: 40px;font-weight: 600; font-size: 16px;line-height: 40px">
站内消息 待办
</div> </div>
<div id="messageDiv" style="height: 250px;overflow-y: auto;margin: 0 0 0 0;" @scroll="heightScrollMessage()"> <div id="todoDiv" style="height: 250px;overflow-y: auto;margin: 0 0 0 0;" @scroll="heightScrollTodo()">
<a-table <a-table
rowKey="id" rowKey="id"
:loading="loading" :loading="loading"
:show-header="false" :show-header="false"
:columns="msgColumns" :columns="columns"
:dataSource="msgContent" :dataSource="tasks"
:pagination="false" :pagination="false"
:customRow="rowClickToDo" :customRow="rowClick"
> >
</a-table> </a-table>
</div> </div>
<show-announcement ref="ShowAnnouncement" @ok="modalFormOk"></show-announcement>
</a-card> </a-card>
<!--登录日志--> <!--登录日志-->
<a-card id="log" style="width: 33%; height: 100%;padding-bottom: 10px;" :body-style="{height: '95%', overflow:'hidden'}"> <a-card id="log" style="width: 33%; height: 100%;padding-bottom: 10px;" :body-style="{height: '95%', overflow:'hidden'}">
@ -119,7 +170,6 @@ import KeyApplications from '@views/dashboard/KeyApplications'
// import { mixinDevice } from '@/utils/mixin' // import { mixinDevice } from '@/utils/mixin'
// import { JeecgListMixin } from '@/mixins/JeecgListMixin' // import { JeecgListMixin } from '@/mixins/JeecgListMixin'
export default { export default {
name: 'HomePage', name: 'HomePage',
// mixins:[JeecgListMixin,mixinDevice], // mixins:[JeecgListMixin,mixinDevice],
@ -142,6 +192,7 @@ export default {
keyApplications: '/keyApplications/processKeyApplications/list', keyApplications: '/keyApplications/processKeyApplications/list',
addKeyApplications: '/keyApplications/processKeyApplications/add', addKeyApplications: '/keyApplications/processKeyApplications/add',
lists: '/sys/log/listHomePage', lists: '/sys/log/listHomePage',
listMien: "/sys/oss/file/list",
listMseeage: '/sys/sysAnnouncementSend/getMyAnnouncementSend', listMseeage: '/sys/sysAnnouncementSend/getMyAnnouncementSend',
editCementSend:"/sys/sysAnnouncementSend/editByAnntIdAndUserId", editCementSend:"/sys/sysAnnouncementSend/editByAnntIdAndUserId",
}, },
@ -204,6 +255,7 @@ export default {
keyApplic:false, keyApplic:false,
// //
userMean:[], userMean:[],
listMien:[],
// //
userChildren:[], userChildren:[],
keyChildren:[], keyChildren:[],
@ -219,6 +271,13 @@ export default {
// console.log("res===========",res.result); // console.log("res===========",res.result);
this.KeyApplicationsChildren = res.result; this.KeyApplicationsChildren = res.result;
} }
}) ;
this.listMien = [];
getAction(this.url.listMien,{status:1}).then((res) => {
if (res.success) {
console.log("sfdvzdf", res.result.records||res.result);
this.listMien = res.result.records||res.result;
}
}) })
this.todoList(); this.todoList();
this.loginList(); this.loginList();
@ -231,6 +290,7 @@ export default {
}, },
methods: { methods: {
expandedRowKeys(row){ expandedRowKeys(row){
console.log("=====",row); console.log("=====",row);
this.selectRowKeys = row; this.selectRowKeys = row;
@ -505,6 +565,45 @@ export default {
</script> </script>
<style scoped> <style scoped>
.ant-carousel >>> .slick-slide img {
border: 5px solid #fff;
display: block;
margin: 5px auto;
height: 90%;
width: 85%;
/* 水平垂直居中 */
}
.ant-carousel >>> .slick-slide {
text-align: center;
height: 260px;
line-height: 160px;
background: #364d79;
overflow: hidden;
}
.ant-carousel >>> .custom-slick-arrow {
width: 25px;
height: 25px;
font-size: 25px;
color: #fff;
background-color: rgba(31, 45, 61, 0.11);
opacity: 0.3;
}
.ant-carousel >>> .custom-slick-arrow:before {
display: none;
}
.ant-carousel >>> .custom-slick-arrow:hover {
opacity: 0.5;
}
.ant-carousel >>> .slick-slide h3 {
color: #fff;
}
@import url("/src/assets/css/ali.css"); @import url("/src/assets/css/ali.css");
.iconfont { .iconfont {

6
src/views/description/ProcessDescriptionList.vue

@ -99,11 +99,11 @@
</template> </template>
<span slot="action" slot-scope="text, record"> <span slot="action" slot-scope="text, record">
<a @click="handleEdit(record)" v-has="'description:edit'" v-h="'merchandiseNews:edit'">编辑</a> <a @click="handleEdit(record)" v-has="'merchandiseNews:edit'">编辑</a>
<a-divider type="vertical" v-h="'merchandiseNews:delete'"/> <a-divider type="vertical" v-has="'merchandiseNews:delete'"/>
<a-popconfirm title="确定删除吗?" @confirm="() => handleDelete(record.id)"> <a-popconfirm title="确定删除吗?" @confirm="() => handleDelete(record.id)">
<a v-h="'merchandiseNews:delete'">删除</a> <a v-has="'merchandiseNews:delete'">删除</a>
</a-popconfirm> </a-popconfirm>
<!-- <a-dropdown>--> <!-- <a-dropdown>-->
<!-- <a class="ant-dropdown-link">更多 <a-icon type="down" /></a>--> <!-- <a class="ant-dropdown-link">更多 <a-icon type="down" /></a>-->

40
src/views/modules/oss/OSSFileList.vue

@ -32,8 +32,8 @@
</div> </div>
<!-- 操作按钮区域 --> <!-- 操作按钮区域 -->
<!-- <div class="table-operator">--> <div class="table-operator">
<!-- &lt;!&ndash; <a-button type="primary" icon="download" @click="handleExportXls('文件列表')">导出</a-button>&ndash;&gt;--> <!-- <a-button type="primary" icon="download" @click="handleExportXls('文件列表')">导出</a-button>-->
<!-- <a-upload--> <!-- <a-upload-->
<!-- name="file"--> <!-- name="file"-->
<!-- :multiple="false"--> <!-- :multiple="false"-->
@ -48,20 +48,20 @@
<!-- </a-button>--> <!-- </a-button>-->
<!-- </a-upload>--> <!-- </a-upload>-->
<!-- <a-upload--> <a-upload
<!-- name="file"--> name="file"
<!-- :multiple="false"--> :multiple="false"
<!-- :action="minioUploadAction"--> :action="minioUploadAction"
<!-- :headers="tokenHeader"--> :headers="tokenHeader"
<!-- :showUploadList="false"--> :showUploadList="false"
<!-- :beforeUpload="beforeUpload"--> :beforeUpload="beforeUpload"
<!-- @change="handleChange">--> @change="handleChange">
<!-- <a-button>--> <a-button>
<!-- <a-icon type="upload"/>--> <a-icon type="upload"/>
<!-- MINIO文件上传--> 公司风采上传
<!-- </a-button>--> </a-button>
<!-- </a-upload>--> </a-upload>
<!-- </div>--> </div>
<!-- table区域-begin --> <!-- table区域-begin -->
<div> <div>
@ -92,10 +92,10 @@
<span slot="action" slot-scope="text, record"> <span slot="action" slot-scope="text, record">
<a @click="handlePreview(record)">预览</a> <a @click="handlePreview(record)">预览</a>
<a-divider type="vertical"/> <a-divider type="vertical"/>
<a @click="downloadFile(record.url)">下载</a> <a @click="downloadFile(record.url)">下载</a>
<a-divider type="vertical"/>
<!-- <a @click="ossDelete(record.id)">删除</a>--> <a @click="ossDelete(record.id)" v-if="!!record.status">删除</a>
</span> </span>
</a-table> </a-table>
@ -176,7 +176,7 @@
{ {
title: '操作', title: '操作',
dataIndex: 'action', dataIndex: 'action',
width: 100, width: 150,
align: "center", align: "center",
scopedSlots: {customRender: 'action'}, scopedSlots: {customRender: 'action'},
} }

87
src/views/statisticanalysis/costecharts/ItemCost.vue

@ -3,25 +3,11 @@
<div style="width: 95%;height:100% ;background-color: #ffffff;margin-top: 2%;border-radius: 10px"> <div style="width: 95%;height:100% ;background-color: #ffffff;margin-top: 2%;border-radius: 10px">
<div style="height: 20%;margin-left: 6%;padding-top: 2%"> <div style="height: 20%;margin-left: 6%;padding-top: 2%">
<div style="font-size: 25px;margin-bottom: 5px;margin-bottom: 2%">项目部成本 <div style="font-size: 25px;margin-bottom: 5px;margin-bottom: 2%">项目部成本
<span style="margin: 0% 4%"> <a-month-picker :disabled-date="disabledDate" placeholder="选择日期" /> </span> <span style="margin: 0% 4%"> <a-month-picker placeholder="选择日期" @change="disabledDate" v-model="this.formData.dateItem"/> </span>
<j-dict-select-tag type="list" v-model="materialType" style="width: 30%" <j-dict-select-tag type="list" v-model="formData.materialType" style="width: 30%"
:trigger-change="true" dictCode="material_type" dictCode="material_type" placeholder="请选择物资类型" @input="handleChange"/>
placeholder="请选择物资类型" @change="handleChange"/>
</div> </div>
<!-- <div style="color: #ffffff;font-size: 19px;margin-bottom: 5px">项目部成本</div>-->
<!-- <div style="display: flex;align-items: center;justify-content: flex-start">-->
<!-- <div class="xian"></div>-->
<!-- <div class="xian">季度</div>-->
<!-- <div class="xian">半年</div>-->
<!-- <div class="xian"></div>-->
<!-- </div>-->
<!-- <div style="display: flex;align-items: center;justify-content: flex-start">-->
<!-- <div class="zi">生产类物资</div>-->
<!-- <div class="zi">非生产类物资</div>-->
<!-- <div class="zi">人员工资</div>-->
<!-- </div>-->
</div> </div>
<div id="myItemCost" style="width: 95%; height: 80%"></div> <div id="myItemCost" style="width: 95%; height: 80%"></div>
</div> </div>
@ -30,6 +16,7 @@
<script> <script>
import * as echarts from 'echarts'; import * as echarts from 'echarts';
import moment from 'moment'
// //
// let echarts = require('echarts/lib/echarts') // let echarts = require('echarts/lib/echarts')
@ -42,21 +29,75 @@ export default {
name: 'ItemCost', name: 'ItemCost',
data() { data() {
return { return {
moment,
msg: '我的echarts图表', msg: '我的echarts图表',
value2: '', timeNum: [], //
materialType: null, formData:{
dateItem: moment(new Date(), 'YYYY-MM'),
materialType: 1,
}
} }
}, },
mounted() { mounted() {
this.echartsInit() this.getList();
this.echartsInit();
}, },
methods:{ methods:{
getList() {
let date = new Date()
this.timeNum = this.getRecentMonth(date.getMonth() + 1)
// console.log(ss,"sdasDFsd");
},
/**
* 根据当前月份获取其前12个月的月份
* @param month
* @return {Array|*}
*/
getRecentMonth(month) {
let arr = []
for(let i = 11;i > 0;i --) {
let sixMonth = month - i
if(sixMonth <= 0) {
sixMonth = 12 + sixMonth
}
arr.push(sixMonth + '月')
}
arr.push(month + '月')
return arr;
},
//
filterTime(time,type) {
var date = new Date(time);
var y = date.getFullYear();
var m = date.getMonth() + 1;
m = m < 10 ? "0" + m : m;
if(!!type){
return y + "-" + m;
}
var d = date.getDate();
d = d < 10 ? "0" + d : d;
var h = date.getHours();
h = h < 10 ? "0" + h : h;
var minute = date.getMinutes();
minute = minute < 10 ? "0" + minute : minute;
var s = date.getSeconds();
s = s < 10 ? "0" + s : s;
return y + "-" + m + "-" + d + " " + h + ":" + minute + ":" + s;
},
disabledDate(current) { disabledDate(current) {
// Can not select days before today and today // console.log("curzdsf",current);
return current && current < moment().endOf('day'); let newTime = this.filterTime( current._d,1);
console.log(newTime);// 2022-02-16 00:00:00
this.formData.dateItem = newTime;
}, },
handleChange(value) { handleChange(value) {
console.log(`selected ${value}`); console.log('selected',value);
}, },
handleBlur() { handleBlur() {
console.log('blur'); console.log('blur');

Loading…
Cancel
Save