Selaa lähdekoodia

全业务域系统,前端开发业绩对标管理页面(暂未联调,待接口开发后联调);登录页面增加密码隐藏展示功能,增加忘记密码功能;修改月季年考评页面生成报表功能按钮根据新权限展示;
全业务域系统,前端开发业绩对标管理页面接口联调,智能AI交互页面问题修改,部署测试环境进行测试;基础指标对标页面选择器组件更换,数据更换,样式修改,问题修改;

SunZehao 11 kuukautta sitten
vanhempi
commit
6316dc184e

+ 29 - 2
src/api/api.js

@@ -30,8 +30,8 @@ export function apiGetModel(url, params) {
 //获取菜单数据
 export function apiGetMenuData() {
     return httpRequest({
-        url: 'menu/menuList?parentId=10105', // 测试
-        // url: 'menu/menuList?parentId=6802', // 生产
+        // url: 'menu/menuList?parentId=10105', // 测试
+        url: 'menu/menuList?parentId=6802', // 生产
         method: 'post'
     })
 }
@@ -1669,4 +1669,31 @@ export function apiGetappAnnualRankingData(params) {
         method: 'get',
         params: params
     })
+}
+
+//----------------------------------------智能AI------------------------------------------------
+
+//----年度排行榜数据
+export function apiGetAiQuestionData(params) {
+    return httpRequest({
+        url: 'AI',
+        method: 'get',
+        params: params
+    })
+}
+
+//----------------------------------------业绩对标管理------------------------------------------------
+
+//----年度排行榜数据
+export function apiGetbenchmarkingData(params) {
+    return httpRequest({
+        url: 'evaluation-performance-benchmarking/list',
+        method: 'get',
+        params: params
+    })
+}
+
+//----修改定标值
+export function apiGetbenchmarkingupdateData(params) {
+    return httpRequest.post('evaluation-performance-benchmarking/update', params)
 }

+ 1 - 1
src/assets/css/main.css

@@ -233,7 +233,7 @@ a {
 /* 文字提示 */
 .el-popper{
     min-width: 120px !important;
-    max-width: 325px;
+    /* max-width: 325px; */
 }
 .el-popper .el-select-dropdown {
     min-width: 0 !important;

BIN
src/assets/menuImg/robot.png


BIN
src/assets/menuImg/robotAns.png


BIN
src/assets/menuImg/robotMsg.png


BIN
src/assets/menuImg/user.png


+ 394 - 326
src/components/assessment/benchmarkingIndicBasicPage.vue

@@ -2,65 +2,54 @@
     <div class="benchmarkBasicPage">
         <div class="benchmarkBasicPageBtn">
             <div class="collectSeach" :style="$utils.collectSeachSty()">
-                <div class="exceed">
+                <div class="exceed exceedCas">
                     <span class="exceedSpan" style="width: 50px">机构:</span>
-                    <el-select v-model="orgVal" placeholder="请选择机构" multiple collapse-tags>
+                    <!-- <el-select v-model="orgVal" placeholder="请选择机构" multiple collapse-tags>
                         <el-option
                         v-for="item in orgSelectArr"
                         :key="item.orgCode"
                         :label="item.orgName"
                         :value="item.orgCode">
                         </el-option>
-                    </el-select>
+                    </el-select> -->
+                    <el-cascader v-model="orgVal" :options="orgSelectArr" :props="props2" clearable multiple
+                        collapse-tags />
                 </div>
                 <div class="exceed exceedWidth">
                     <span class="exceedSpan" style="width: 50px">指标:</span>
                     <el-select v-model="itemVal" placeholder="请选择指标" @change="changeItemVal">
-                        <el-option
-                        v-for="item in itemSelectArr"
-                        :key="item.irn"
-                        :label="item.itemFieldName"
-                        :value="item.irn">
+                        <el-option v-for="item in itemSelectArr" :key="item.irn" :label="item.itemFieldName"
+                            :value="item.irn">
                         </el-option>
                     </el-select>
                 </div>
                 <div class="exceed">
                     <span class="exceedSpan" style="width: 70px">指标项:</span>
                     <el-select v-model="evalVal" placeholder="请选择指标项" filterable>
-                        <el-option
-                        v-for="item in evalSelectArr"
-                        :key="item.itemsCode"
-                        :label="item.itemsName"
-                        :value="item.itemsCode">
+                        <el-option v-for="item in evalSelectArr" :key="item.itemsCode" :label="item.itemsName"
+                            :value="item.itemsCode">
                         </el-option>
                     </el-select>
                 </div>
                 <div class="exceed exceedWidth">
                     <span class="exceedSpan" style="width: 50px">频度:</span>
                     <el-select v-model="rangeVal" placeholder="请选择频度" filterable>
-                        <el-option
-                        v-for="item in rangeArr"
-                        :key="item.value"
-                        :label="item.label"
-                        :value="item.value">
+                        <el-option v-for="item in rangeArr" :key="item.value" :label="item.label" :value="item.value">
                         </el-option>
                     </el-select>
                 </div>
                 <div class="exceed">
                     <span class="exceedSpan" style="width: 50px">时间:</span>
-                    <el-date-picker
-                        v-model="resAnnual"
-                        value-format="YYYY-MM-DD"
-                        type="daterange"
-                        placeholder="请选择时间"
-                    />
+                    <el-date-picker v-model="resAnnual" value-format="YYYY-MM-DD" type="daterange"
+                        placeholder="请选择时间" />
                 </div>
                 <seachs @handleSeach="getSeachData" :showRest="false"></seachs>
             </div>
             <div class="benchmarkBasicPageTableData">
                 <el-table :data="benchmarkBasicPageData" style="width: 100%" :class="unitRatingTableSty()">
                     <el-table-column type="index" label="序号" align="center"></el-table-column>
-                    <el-table-column  v-for="(it, index) in benchmarkBasicHeader" :key="index" :label="it.name" align="center">
+                    <el-table-column v-for="(it, index) in benchmarkBasicHeader" :key="index" :label="it.name"
+                        align="center">
                         <template #default="scope">
                             <span>{{scope.row[it.code]}}</span>
                         </template>
@@ -73,348 +62,427 @@
 </template>
 
 <script>
-import seachs from '../seachGroup.vue'
-import {apiPostbenchmarkBasicList, apiPostTreeSelectList1015, apiPostTreeSelectList1019, apiPostTreeSelectList1020} from '../../api/api'
-export default {
-    components: {
-        seachs
-    },
-    data() {
-        return {
-            statesVisible: false,
-            benchmarkBasicPageData:[],
-            benchmarkBasicHeader: [],
-            orgVal: [],
-            itemVal: '',
-            evalVal: '',
-            rangeVal: 'M',
-            resAnnual: [],
-            orgSelectArr: [],
-            itemSelectArr: [],
-            evalSelectArr: [],
-            rangeArr: [],
-            winPix: window.devicePixelRatio,
-            innerWidth: window.innerWidth
-        }
-    },
-    created() {
-        this.rangeArr = [
-            {
-                label: '日',
-                value: 'D'
-            },
-            {
-                label: '月',
-                value: 'M'
-            },
-            {
-                label: '年',
-                value: 'Y'
-            }
-        ]
-    },
-    mounted() {
-        this.getorgSelectList()
-        this.getEchartsData()
-        this.resAnnual = [this.getTime(new Date(new Date().getTime() - 6*30*24*60*60*1000)), this.getTime(new Date(new Date().getTime()))]
-    },
-    methods:{
-        // 获取组织机构数据
-        getorgSelectList() {
-            let that = this
-            let params = {
-                type: 1015,
-                map: {
-                    orgLevel: "3"
-                }
-            }
-            apiPostTreeSelectList1015(params).then(datas =>{
-                if (datas && datas.data.data) {          
-                    that.orgSelectArr = datas.data.data
-                    that.orgVal = [datas.data.data[0].orgCode, datas.data.data[1].orgCode]
-                    that.getfiledDatatypeList()
-                }
-            })
+    import seachs from '../seachGroup.vue'
+    import {
+        apiPostbenchmarkBasicList,
+        apiPostTreeSelectList1015,
+        apiPostTreeSelectList1019,
+        apiPostTreeSelectList1020
+    } from '../../api/api'
+    export default {
+        components: {
+            seachs
         },
-        changeItemVal(val) {
-            this.evalSelectArr = []
-            this.getevalDatatypeList(val)
-        },
-        //查询主题域
-        getfiledDatatypeList() {
-            let that = this
-            let params = {
-                type: 1019,
-                map: {
-                    pId: ""
-                }
+        data() {
+            return {
+                statesVisible: false,
+                benchmarkBasicPageData: [],
+                benchmarkBasicHeader: [],
+                orgVal: [],
+                itemVal: '',
+                evalVal: '',
+                rangeVal: 'M',
+                resAnnual: [],
+                orgSelectArr: [],
+                itemSelectArr: [],
+                evalSelectArr: [],
+                rangeArr: [],
+                props2: {
+                    multiple: true,
+                    checkStrictly: true,
+                },
+                winPix: window.devicePixelRatio,
+                innerWidth: window.innerWidth
             }
-            apiPostTreeSelectList1019(params).then(datas =>{
-                if (datas && datas.data.data) {          
-                    that.itemSelectArr = datas.data.data
-                    // that.itemVal = datas.data.data[0].itemFieldCode
-                    that.itemVal = datas.data.data[1].irn
-                    that.getevalDatatypeList(that.itemVal)
+        },
+        created() {
+            this.rangeArr = [{
+                    label: '日',
+                    value: 'D'
+                },
+                {
+                    label: '月',
+                    value: 'M'
+                },
+                {
+                    label: '年',
+                    value: 'Y'
                 }
-            })
+            ]
         },
-        //查询指标项
-        getevalDatatypeList(val) {
-            let that = this
-            let params = {
-                type: 1020,
-                map: {
-                    irn: val
+        mounted() {
+            this.getorgSelectList()
+            this.getEchartsData()
+            this.resAnnual = [this.getTime(new Date(new Date().getTime() - 6 * 30 * 24 * 60 * 60 * 1000)), this.getTime(
+                new Date(new Date().getTime()))]
+        },
+        methods: {
+            // 获取组织机构数据
+            getorgSelectList() {
+                let that = this
+                let params = {
+                    type: 1015,
+                    map: {
+                        orgLevel: "3"
+                    }
                 }
-            }
-            apiPostTreeSelectList1020(params).then(datas =>{
-                if (datas && datas.data.data) {          
-                    that.evalSelectArr = datas.data.data
-                    that.evalVal = datas.data.data[0].itemsCode
-                    that.getbenchmarkBasicList()
+                apiPostTreeSelectList1015(params).then(datas => {
+                    if (datas && datas.data) {
+                        let arr = []
+                        datas.data.forEach(it => {
+                            let obj = {
+                                value: it.orgCode,
+                                label: it.orgName,
+                                children: it.children ? that.changeSelect(it.children) : []
+                            }
+                            arr.push(obj)
+                        })
+                        that.orgSelectArr = arr
+                        that.orgVal = [datas.data[0].orgCode, datas.data[1].orgCode]
+                        that.getfiledDatatypeList()
+                    }
+                })
+            },
+            changeSelect(child) {
+                let arr = []
+                child.forEach(it => {
+                    let obj = {
+                        value: it.orgCode,
+                        label: it.orgName,
+                        children: it.children ? this.changeSelect(it.children) : []
+                    }
+                    arr.push(obj)
+                })
+                return arr
+            },
+            changeItemVal(val) {
+                this.evalSelectArr = []
+                this.getevalDatatypeList(val)
+            },
+            //查询主题域
+            getfiledDatatypeList() {
+                let that = this
+                let params = {
+                    type: 1019,
+                    map: {
+                        pId: ""
+                    }
                 }
-            })
-        },
-        //获取指标数据
-        getbenchmarkBasicList() {
-            let that = this
-            let params = {
-                type: '1011',
-                map: {
-                    sysCode: that.orgVal,
-                    itemCode: [that.evalVal],
-                    fdlx: [
-                        "FDLX100",
-                        "FDLX400",
-                        "FDLX200"
-                    ],
-                    range: that.rangeVal,
-                    dataType: '429668',
-                    kj: 'JT',
-                    startTime: that.resAnnual[0],
-                    endTime: that.resAnnual[1]
+                apiPostTreeSelectList1019(params).then(datas => {
+                    if (datas && datas.data.data) {
+                        that.itemSelectArr = datas.data.data
+                        // that.itemVal = datas.data.data[0].itemFieldCode
+                        that.itemVal = datas.data.data[1].irn
+                        that.getevalDatatypeList(that.itemVal)
+                    }
+                })
+            },
+            //查询指标项
+            getevalDatatypeList(val) {
+                let that = this
+                let params = {
+                    type: 1020,
+                    map: {
+                        irn: val
+                    }
                 }
-            }
-            apiPostbenchmarkBasicList(params).then(datas =>{
-                if (datas && datas.data) {          
-                    if (datas.data.title) {
-                        that.benchmarkBasicHeader = datas.data.title
+                apiPostTreeSelectList1020(params).then(datas => {
+                    if (datas && datas.data.data) {
+                        that.evalSelectArr = datas.data.data
+                        that.evalVal = datas.data.data[0].itemsCode
+                        that.getbenchmarkBasicList()
                     }
-                    if (datas.data.list) {
-                        that.benchmarkBasicPageData = datas.data.list
-                        let xaxisArr = []
-                        let seriesArr = []
-                        that.benchmarkBasicPageData.forEach(it => {
-                            xaxisArr.push(it.time)
-                            
-                        })
-                        that.benchmarkBasicHeader.forEach(iv =>{
-                            if (iv.code !== 'time') {
-                                let seriesitemArr = []
-                                that.benchmarkBasicPageData.forEach(item => {
-                                    seriesitemArr.push(item[iv.code])
-                                })
-                                let obj = {
-                                    name: iv.name,
-                                    type: 'line',
-                                    symbol: 'none',
-                                    data: seriesitemArr
+                })
+            },
+            //获取指标数据
+            getbenchmarkBasicList() {
+                let that = this
+                let params = {
+                    type: '1011',
+                    map: {
+                        sysCode: that.orgVal,
+                        itemCode: [that.evalVal],
+                        fdlx: [
+                            "FDLX100",
+                            "FDLX400",
+                            "FDLX200"
+                        ],
+                        range: that.rangeVal,
+                        dataType: '429668',
+                        kj: 'JT',
+                        startTime: that.resAnnual[0],
+                        endTime: that.resAnnual[1]
+                    }
+                }
+                apiPostbenchmarkBasicList(params).then(datas => {
+                    if (datas && datas.data) {
+                        if (datas.data.title) {
+                            that.benchmarkBasicHeader = datas.data.title
+                        }
+                        if (datas.data.list) {
+                            that.benchmarkBasicPageData = datas.data.list
+                            let xaxisArr = []
+                            let seriesArr = []
+                            that.benchmarkBasicPageData.forEach(it => {
+                                xaxisArr.push(it.time)
+
+                            })
+                            that.benchmarkBasicHeader.forEach(iv => {
+                                if (iv.code !== 'time') {
+                                    let seriesitemArr = []
+                                    that.benchmarkBasicPageData.forEach(item => {
+                                        seriesitemArr.push(item[iv.code])
+                                    })
+                                    let obj = {
+                                        name: iv.name,
+                                        type: 'line',
+                                        symbol: 'none',
+                                        data: seriesitemArr
+                                    }
+                                    seriesArr.push(obj)
                                 }
-                                seriesArr.push(obj)
-                            }
-                        })
-                        that.getEchartsData(xaxisArr, seriesArr)
+                            })
+                            that.getEchartsData(xaxisArr, seriesArr)
+                        }
                     }
+                })
+            },
+            //获取echarts数据
+            getEchartsData(xaxisArr, seriesArr) {
+                let option = {
+                    tooltip: {
+                        trigger: 'axis'
+                    },
+                    grid: {
+                        left: '5%',
+                        right: '5%'
+                    },
+                    xAxis: {
+                        type: 'category',
+                        data: xaxisArr
+                    },
+                    yAxis: {
+                        type: 'value'
+                    },
+                    series: seriesArr
+                }
+                let dom = document.getElementById('basicEcharts');
+                dom.removeAttribute("_echarts_instance_") ? dom.removeAttribute("_echarts_instance_") : ''
+                let chat = this.$echarts.init(dom)
+                chat.setOption(option);
+                window.addEventListener("resize", function () {
+                    chat.resize()
+                })
+            },
+            getTime(date) {
+                var y = date.getFullYear();
+                var m = date.getMonth() + 1;
+                m = m < 10 ? ('0' + m) : m;
+                var d = date.getDate();
+                d = d < 10 ? ('0' + d) : d;
+                let timeF = y + '-' + m + '-' + d
+                return timeF
+            },
+            getSeachData() {
+                this.getbenchmarkBasicList()
+            },
+            unitRatingTableSty() {
+                if (this.winPix === 1.25 || this.innerWidth < 1800) {
+                    return 'unitRating125Table'
+                } else {
+                    return 'unitRating100Table'
                 }
-            })
-        },
-        //获取echarts数据
-        getEchartsData(xaxisArr, seriesArr) {
-            let option = {
-                tooltip: {
-                    trigger: 'axis'
-                },
-                grid: {
-                    left: '5%',
-                    right: '5%'
-                },
-                xAxis: {
-                    type: 'category',
-                    data: xaxisArr
-                },
-                yAxis: {
-                    type: 'value'
-                },
-                series: seriesArr
-            }
-            let dom = document.getElementById('basicEcharts');
-            dom.removeAttribute("_echarts_instance_") ? dom.removeAttribute("_echarts_instance_") : ''
-            let chat = this.$echarts.init(dom)
-            chat.setOption(option);
-            window.addEventListener("resize", function() {
-                chat.resize()
-            })
-        },
-        getTime(date){
-            var y = date.getFullYear();  
-            var m = date.getMonth() + 1;  
-            m = m < 10 ? ('0' + m) : m;  
-            var d = date.getDate();  
-            d = d < 10 ? ('0' + d) : d;  
-            let timeF = y + '-' + m + '-' + d
-            return timeF
-        },
-        getSeachData() {
-            this.getbenchmarkBasicList()
-        },
-        unitRatingTableSty() {
-            if (this.winPix === 1.25 || this.innerWidth < 1800) {
-                return 'unitRating125Table'
-            } else {
-                return 'unitRating100Table'
             }
         }
     }
-}
 </script>
 
 <style lang="less">
-.benchmarkBasicPage{
-    .benchmarkBasicPageBtn{
-        .collectSeach{
-            display: flex;
-            padding: 24px 20px;
-            border-bottom: 1px solid#D6DBEA;
-            .exceed{
+    .benchmarkBasicPage {
+        .benchmarkBasicPageBtn {
+            .collectSeach {
                 display: flex;
-                .exceedSpan{
-                    width: 100px;
-                    height: 12px;
-                    font-size: 14px;
-                    font-family: Microsoft YaHei;
-                    font-weight: 400;
-                    color: #8991B0;
-                    line-height: 12px;
-                    margin-top: 14px;
-                }
-                .el-input{
-                    margin-right:10px;
-                    height: 40px;
-                    .el-input__inner{
-                        height:40px;
+                padding: 24px 20px;
+                border-bottom: 1px solid#D6DBEA;
+
+                .exceed {
+                    display: flex;
+
+                    .exceedSpan {
+                        width: 100px;
+                        height: 12px;
+                        font-size: 14px;
+                        font-family: Microsoft YaHei;
+                        font-weight: 400;
+                        color: #8991B0;
+                        line-height: 12px;
+                        margin-top: 14px;
                     }
-                    .el-input__suffix{
-                        .el-select__caret{
-                            line-height:30px;
+
+                    .el-input {
+                        margin-right: 10px;
+                        height: 40px;
+
+                        .el-input__inner {
+                            height: 40px;
+                        }
+
+                        .el-input__suffix {
+                            .el-select__caret {
+                                line-height: 30px;
+                            }
                         }
                     }
+
+                    .el-date-editor {
+                        height: 40px;
+                    }
                 }
-                .el-date-editor{
-                    height: 40px;
-                }
-            }
-            .exceedWidth{
-                .el-select{
-                    width: 70px;
+
+                .exceedWidth {
+                    .el-select {
+                        width: 70px;
+                    }
                 }
-            }
-            .el-select{
-                margin-right:10px;
-                .el-input__inner{
-                    height:30px;
+
+                .exceedCas {
+                    .el-cascader {
+                        width: 230px;
+
+                        .el-cascader__tags {
+                            .el-tag {
+                                .el-tag__content {
+                                    width: 30px;
+                                }
+                            }
+
+                            .is-closable {
+                                .el-tag__content {
+                                    width: 100px;
+                                }
+                            }
+                        }
+                    }
                 }
-                .el-input__suffix{
-                    .el-select__caret{
-                        line-height:30px;
+
+                .el-select {
+                    margin-right: 10px;
+
+                    .el-input__inner {
+                        height: 30px;
+                    }
+
+                    .el-input__suffix {
+                        .el-select__caret {
+                            line-height: 30px;
+                        }
                     }
                 }
             }
-        }
-        span{
-            font-size:14px;
-        }
-        .PeriodBtn{
-            display: flex;
-            justify-content: flex-end;
-            padding: 20px 0;
-        }
-        .el-button{
-            height: 30px;
-            // width:100px;
-            padding: 0 20px ;
-            // padding-top: 8px;
-            span{
-                margin:0;
+
+            span {
+                font-size: 14px;
             }
-        }
-        .benchmarkBasicPageTableData{
-            .unitRating125Table{
-                .el-table__body-wrapper{
-                    height: 30vh !important;
-                }
+
+            .PeriodBtn {
+                display: flex;
+                justify-content: flex-end;
+                padding: 20px 0;
             }
-            .unitRating100Table{
-                .el-table__body-wrapper{
-                    height: 35vh !important;
+
+            .el-button {
+                height: 30px;
+                // width:100px;
+                padding: 0 20px;
+
+                // padding-top: 8px;
+                span {
+                    margin: 0;
                 }
             }
-            .el-table{
-                .el-input__inner{
-                    height: 30px !important;
-                }
-                .el-radio__label{
-                    display: none;
-                }
-                .tooltipCC{
-                    width: 300px !important;
-                    display: inline-block;
-                    overflow: hidden;
-                    text-overflow: ellipsis;
-                    white-space: nowrap;
+
+            .benchmarkBasicPageTableData {
+                .unitRating125Table {
+                    .el-table__body-wrapper {
+                        height: 30vh !important;
+                    }
                 }
-                .tooltipCCDes{
-                    width: 50px;
-                    display: inline-block;
-                    overflow: hidden;
-                    text-overflow: ellipsis;
-                    white-space: nowrap;
+
+                .unitRating100Table {
+                    .el-table__body-wrapper {
+                        height: 35vh !important;
+                    }
                 }
-                .indicitem{
-                    color: #409EFF;
-                    font-size: 12px;
-                    margin-right: 20px;
-                    cursor:pointer;
-                    &:hover{
-                        text-decoration: underline;
+
+                .el-table {
+                    .el-input__inner {
+                        height: 30px !important;
+                    }
+
+                    .el-radio__label {
+                        display: none;
+                    }
+
+                    .tooltipCC {
+                        width: 300px !important;
+                        display: inline-block;
+                        overflow: hidden;
+                        text-overflow: ellipsis;
+                        white-space: nowrap;
+                    }
+
+                    .tooltipCCDes {
+                        width: 50px;
+                        display: inline-block;
+                        overflow: hidden;
+                        text-overflow: ellipsis;
+                        white-space: nowrap;
+                    }
+
+                    .indicitem {
+                        color: #409EFF;
+                        font-size: 12px;
+                        margin-right: 20px;
+                        cursor: pointer;
+
+                        &:hover {
+                            text-decoration: underline;
+                        }
                     }
                 }
+
+                .el-pagination {
+                    margin-top: 20px;
+                    text-align: end;
+                    position: relative;
+                }
             }
-            .el-pagination{
-                margin-top: 20px;
-                text-align: end;
-                position: relative;
-            }
-        }
-        .el-overlay{
-            .startToDia{
-                .el-dialog__body{
-                    padding: 30px 60px 30px 20px !important;
-                    .periodFrom{
-                        .el-select, .el-input{
-                            width: 100%;
+
+            .el-overlay {
+                .startToDia {
+                    .el-dialog__body {
+                        padding: 30px 60px 30px 20px !important;
+
+                        .periodFrom {
+
+                            .el-select,
+                            .el-input {
+                                width: 100%;
+                            }
+
+                            .el-input {
+                                height: 30px;
+                            }
                         }
-                        .el-input{
-                            height: 30px;
+
+                        .flowSty {
+                            width: 100%;
+                            height: 70vh;
                         }
                     }
-                    .flowSty{
-                        width: 100%;
-                        height: 70vh;
-                    }
                 }
             }
         }
+
     }
-    
-}
 </style>

+ 624 - 0
src/components/assessment/evaluationBenchmarkManagePage.vue

@@ -0,0 +1,624 @@
+<template>
+    <div class="benchmarkingIndicator">
+        <div class="benchmarkingIndicatorBtn">
+            <div class="collectSeach" :style="$utils.collectSeachSty()">
+                <div style="display: flex;width:35%">
+                    <div class="exceed">
+                        <span class="exceedSpan" style="margin-left: 10px;width: 50px">类型:</span>
+                        <el-select v-model="timeStr" placeholder="请选择时间类型" @change="changeTime">
+                            <el-option v-for="item in timerData" :key="item.value" :label="item.label"
+                                :value="item.value">
+                            </el-option>
+                        </el-select>
+                    </div>
+                    <div class="exceed">
+                        <span class="exceedSpan" style="margin-left: 10px;width: 50px">时间:</span>
+                        <el-date-picker v-model="timeIds" type="year" value-format="YYYY" placeholder="选择时间"
+                            v-if="timeStr === 'NDKP'" @change="changTimeDate" />
+                        <el-date-picker v-model="timeIds" type="month" value-format="YYYY-MM" placeholder="选择时间" v-else
+                            @change="changTimeDate" />
+                    </div>
+                </div>
+                <seachs @handleSeach="getSeachData" @handleRest="resetSeach"></seachs>
+                <el-button type="warning" icon="Upload" size="mini" @click="handleImport" style="margin-left:30px">导入
+                </el-button>
+                <el-button type="info" icon="Download" size="mini" @click="handleExport" style="margin-left:10px">导出
+                </el-button>
+            </div>
+            <div class="radioButton">
+                <el-radio-group v-model="tabPosition" style="margin: 10px 0" size="large" @change="changeRadio">
+                    <el-radio-button value="寻标" label="寻标"></el-radio-button>
+                    <el-radio-button value="立标" label="立标"></el-radio-button>
+                    <el-radio-button value="标杆" label="标杆"></el-radio-button>
+                    <el-radio-button value="达标" label="达标"></el-radio-button>
+                    <el-radio-button value="超标" label="超标"></el-radio-button>
+                </el-radio-group>
+            </div>
+            <div class="benchmarkingIndicatorTableData">
+                <div class="tableMain">
+                    <el-table :data="BenchManageData" style="width: 100%">
+                        <el-table-column type="index" label="序号" align="center"></el-table-column>
+                        <el-table-column label="考评单位" prop="companyShort" width="200" />
+                        <el-table-column label="装机容量" prop="installCapacity" />
+                        <el-table-column label="指标" prop="indexName" />
+                        <el-table-column label="计划值" prop="plannedValue" />
+                        <el-table-column label="实际完成值" prop="completeValue" />
+                        <el-table-column label="推荐值" prop="recommendedValue" />
+                        <el-table-column label="定标值" prop="scalingValue">
+                            <template #default="scope">
+                                <el-input-number v-model="scope.row.scalingValue"
+                                    @blur="scalingValueBlur(scope.row.scalingValue, scope.row)"
+                                    @change="scalingValueBlur(scope.row.scalingValue, scope.row)"
+                                    v-if="tabPosition === '立标'" />
+                                <span v-else>{{scope.row.scalingValue}}</span>
+                            </template>
+                        </el-table-column>
+                        <el-table-column label="是否标杆" prop="isBg">
+                            <template #default="scope">
+                                <span>{{scope.row.isBg === 0 ? '否' : '是'}}</span>
+                            </template>
+                        </el-table-column>
+                    </el-table>
+                    <el-pagination @size-change="handleSizeChange" @current-change="handleCurrentChange"
+                        :current-page="page.currentPage" :page-size="page.pagesize"
+                        layout="total, prev, pager, next, jumper" :total="page.total">
+                    </el-pagination>
+                </div>
+                <div class="tableSeach">
+                    <div class="seachType" v-for="item in titleMsgArr" :key="item.isName"
+                        :class="item.showClick? 'seachTypeCha':''" @click="changType(item)">
+                        <img :src="item.img" alt="" v-if="!item.showClick">
+                        <img :src="item.clickImg" alt="" v-else>
+                        <p :style="item.showClick? 'color: #3B7AD1' : ''">{{item.isName}}</p>
+                    </div>
+                </div>
+            </div>
+        </div>
+        <import-dailog ref="importPage" @successImport="successImport" @importLoading="importLoading"></import-dailog>
+    </div>
+</template>
+
+<script>
+    import importDailog from '../importPage/importDailog.vue'
+    import btns from '../elbuttonS.vue'
+    import seachs from '../seachGroup.vue'
+
+    import * as XLSX from 'xlsx'
+    import {
+        saveAs
+    } from 'file-saver'
+    import * as XLSXD from 'xlsx-js-style'
+
+    import huoDef from '../../assets/benchmarkImg/huoDef.png'
+    import shuiDef from '../../assets/benchmarkImg/shuiDef.png'
+    import xinDef from '../../assets/benchmarkImg/xinDef.png'
+    import meiDef from '../../assets/benchmarkImg/meiDef.png'
+    import guoDef from '../../assets/benchmarkImg/guoDef.png'
+    import zongDef from '../../assets/benchmarkImg/zongDef.png'
+
+    import huoCha from '../../assets/benchmarkImg/huoCha.png'
+    import shuiCha from '../../assets/benchmarkImg/shuiCha.png'
+    import xinCha from '../../assets/benchmarkImg/xinCha.png'
+    import meiCha from '../../assets/benchmarkImg/meiCha.png'
+    import guoCha from '../../assets/benchmarkImg/guoCha.png'
+    import zongCha from '../../assets/benchmarkImg/zongCha.png'
+    import {
+        apiGetbenchmarkingData,
+        apiGetbenchmarkingupdateData,
+        apiGetExportMsg
+    } from '../../api/api'
+    export default {
+        components: {
+            importDailog,
+            btns,
+            seachs
+        },
+        data() {
+            return {
+                BenchManageData: [],
+                indicatorTypeData: [],
+                stageData: [],
+                companyDatas: [],
+                timeIds: '',
+                timeStr: 'NDKP',
+                binSectionStr: '火电',
+                page: {
+                    pagesize: 12,
+                    currentPage: 1,
+                    total: 0
+                },
+                titleMsgArr: [],
+                timerData: [],
+                tabPosition: '寻标',
+                yearStr: '',
+                dateStr: ''
+            }
+        },
+        created() {
+            this.timeIds = (new Date().getFullYear() - 1).toString()
+            this.timerData = [{
+                    label: '年度',
+                    value: 'NDKP'
+                },
+                {
+                    label: '季度',
+                    value: 'JDKP'
+                },
+                {
+                    label: '月度',
+                    value: 'YDKP'
+                }
+            ]
+            this.titleMsgYear = [{
+                    isClass: 'huoDef',
+                    isClassC: 'huoCha',
+                    isName: '火电',
+                    img: huoDef,
+                    clickImg: huoCha,
+                    showClick: true
+                },
+                {
+                    isClass: 'shuiDef',
+                    isClassC: 'shuiCha',
+                    isName: '水电',
+                    img: shuiDef,
+                    clickImg: shuiCha,
+                    showClick: false
+                },
+                {
+                    isClass: 'xinDef',
+                    isClassC: 'xinCha',
+                    isName: '新能源',
+                    img: xinDef,
+                    clickImg: xinCha,
+                    showClick: false
+                },
+                {
+                    isClass: 'meiDef',
+                    isClassC: 'meiCha',
+                    isName: '煤电',
+                    img: meiDef,
+                    clickImg: meiCha,
+                    showClick: false
+                },
+                {
+                    isClass: 'guoDef',
+                    isClassC: 'guoCha',
+                    isName: '海外',
+                    img: guoDef,
+                    clickImg: guoCha,
+                    showClick: false
+                },
+                {
+                    isClass: 'zongDef',
+                    isClassC: 'zongCha',
+                    isName: '综合',
+                    img: zongDef,
+                    clickImg: zongCha,
+                    showClick: false
+                }
+            ]
+            this.titleMsgNoYear = [{
+                    isClass: 'huoDef',
+                    isClassC: 'huoCha',
+                    isName: '火电',
+                    img: huoDef,
+                    clickImg: huoCha,
+                    showClick: true
+                },
+                {
+                    isClass: 'shuiDef',
+                    isClassC: 'shuiCha',
+                    isName: '水电',
+                    img: shuiDef,
+                    clickImg: shuiCha,
+                    showClick: false
+                },
+                {
+                    isClass: 'xinDef',
+                    isClassC: 'xinCha',
+                    isName: '风电',
+                    img: xinDef,
+                    clickImg: xinCha,
+                    showClick: false
+                },
+                {
+                    isClass: 'xinDef',
+                    isClassC: 'xinCha',
+                    isName: '光伏',
+                    img: xinDef,
+                    clickImg: xinCha,
+                    showClick: false
+                },
+                {
+                    isClass: 'meiDef',
+                    isClassC: 'meiCha',
+                    isName: '煤电',
+                    img: meiDef,
+                    clickImg: meiCha,
+                    showClick: false
+                },
+                {
+                    isClass: 'guoDef',
+                    isClassC: 'guoCha',
+                    isName: '海外',
+                    img: guoDef,
+                    clickImg: guoCha,
+                    showClick: false
+                },
+                {
+                    isClass: 'zongDef',
+                    isClassC: 'zongCha',
+                    isName: '综合',
+                    img: zongDef,
+                    clickImg: zongCha,
+                    showClick: false
+                }
+            ]
+            this.titleMsgArr = this.titleMsgYear
+            this.getBenchManageData()
+        },
+        methods: {
+            //获取业绩对标数据
+            getBenchManageData() {
+                let that = this
+                let params = {
+                    pageNum: that.page.currentPage,
+                    pageSize: that.page.pagesize,
+                    toolCategory: that.tabPosition,
+                    manageCategory: that.binSectionStr,
+                    checkCycle: that.timeStr
+                }
+                if (that.timeStr === 'NDKP') {
+                    params.degreeYear = that.timeIds * 1
+                } else {
+                    params.degreeYear = that.yearStr
+                    params.quarterlyMonth = that.dateStr
+                }
+                apiGetbenchmarkingData(params).then(datas => {
+                    if (datas && datas.data) {
+                        that.BenchManageData = datas.data.records
+                        that.page.total = datas.data.total
+                    }
+                })
+            },
+            changeTime(val) {
+                if (val !== 'NDKP') {
+                    this.titleMsgArr = this.titleMsgNoYear
+                    let year = new Date().getFullYear() - 1
+                    let month = new Date().getMonth() + 1
+                    if (month < 10) {
+                        this.timeIds = (year + '-0' + month).toString()
+                    } else {
+                        this.timeIds = (year + '-' + month).toString()
+                    }
+                    this.changTimeDate(this.timeIds)
+                }
+            },
+            scalingValueBlur(val, row) {
+                let that = this
+                let params = {
+                    id: row.id,
+                    scalingValue: val
+                }
+                apiGetbenchmarkingupdateData(params).then(datas => {
+                    if (datas) {
+                        that.getBenchManageData()
+                    }
+                })
+            },
+            changeRadio(val) {
+                this.getBenchManageData()
+            },
+            changTimeDate(val) {
+                this.yearStr = ''
+                this.dateStr = ''
+                if (this.timeStr === 'JDKP') {
+                    let str = ''
+                    str = val.substring(val.indexOf('-') + 1, val.length)
+                    this.yearStr = val.substring(0, val.indexOf('-')) * 1
+                    if (str === '01' || str === '02' || str === '03') {
+                        this.dateStr = 1
+                    } else if (str === '04' || str === '05' || str === '06') {
+                        this.dateStr = 2
+                    } else if (str === '07' || str === '08' || str === '09') {
+                        this.dateStr = 3
+                    } else if (str === '10' || str === '11' || str === '12') {
+                        this.dateStr = 4
+                    }
+                } else if (this.timeStr === 'YDKP') {
+                    this.dateStr = val.substring(val.indexOf('-') + 1, val.length) * 1
+                    this.yearStr = val.substring(0, val.indexOf('-')) * 1
+                }
+            },
+            changType(data) {
+                this.titleMsgArr.forEach(it => {
+                    it.showClick = false
+                    if (it.isName === data.isName) {
+                        it.showClick = true
+                        this.binSectionStr = it.isName
+                    }
+                })
+                this.getBenchManageData()
+            },
+            getSeachData() {
+                this.page.currentPage = 1
+
+                this.getBenchManageData()
+            },
+            resetSeach() {
+                this.page.currentPage = 1
+                this.getBenchManageData()
+            },
+            handleSizeChange(val) {
+                this.page.pagesize = val
+                this.getBenchManageData()
+            },
+            handleCurrentChange(val) {
+                this.page.currentPage = val
+                this.getBenchManageData()
+            },
+            handleExport() {
+                let that = this
+                let url = 'evaluation-performance-benchmarking/exportExcel'
+                let params = {
+                    toolCategory: that.tabPosition,
+                    manageCategory: that.binSectionStr,
+                    checkCycle: that.timeStr,
+                }
+                if (that.timeStr === 'NDKP') {
+                    params.degreeYear = that.timeIds * 1
+                } else {
+                    params.degreeYear = that.yearStr
+                    params.quarterlyMonth = that.dateStr
+                }
+                apiGetExportMsg(url, params).then(datas => {
+                    let blob = new Blob([datas])
+                    saveAs(blob, '业绩对标管理数据导出.xlsx')
+                }).catch((r) => {
+                    console.error(r)
+                })
+            },
+            handleImport() {
+                this.$refs.importPage.upload.title = "业绩对标管理数据导入"
+                this.$refs.importPage.upload.open = true
+                // this.$refs.importPage.upload.data = {
+                //     isQuantified: this.activeName === 'first' ? '是' : '否'
+                // }
+                this.$refs.importPage.upload.url = `/evaluation-performance-benchmarking/importExcel`
+            },
+            successImport(val) {
+                this.getBenchManageData()
+            },
+        }
+    }
+</script>
+
+<style lang="less">
+    .benchmarkingIndicator {
+        .benchmarkingIndicatorBtn {
+            .collectSeach {
+                display: flex;
+                padding: 24px 20px;
+                border-bottom: 1px solid#D6DBEA;
+
+                .exceed {
+                    display: flex;
+
+                    .exceedSpan {
+                        width: 100px;
+                        height: 12px;
+                        font-size: 14px;
+                        font-family: Microsoft YaHei;
+                        font-weight: 400;
+                        color: #8991B0;
+                        line-height: 12px;
+                        margin-top: 14px;
+                    }
+
+                    .el-date-editor {
+                        width: 68%;
+                    }
+
+                    .el-select {
+                        width: 70%;
+                    }
+
+                    .el-input {
+                        margin-right: 10px;
+
+                        .el-input__inner {
+                            height: 30px;
+                        }
+
+                        .el-input__suffix {
+                            .el-select__caret {
+                                line-height: 30px;
+                            }
+                        }
+                    }
+
+                    .el-select {
+                        line-height: 40px !important;
+
+                        .el-input__inner,
+                        .is-disabled {
+                            height: 40px !important;
+                        }
+
+                        .el-input__suffix {
+                            .el-select__caret {
+                                line-height: 40px;
+                            }
+                        }
+                    }
+
+                    .el-date-editor--month,
+                    .el-date-editor--year {
+                        height: 40px;
+                    }
+                }
+
+            }
+
+            .radioButton {
+                width: 100%;
+
+                .el-radio-group {
+                    position: relative;
+                    left: 73%;
+                }
+            }
+
+            span {
+                font-size: 14px;
+            }
+
+            .PeriodBtn {
+                display: flex;
+                justify-content: flex-end;
+                padding: 20px 0;
+            }
+
+            .el-button {
+                height: 30px;
+                // width:100px;
+                padding: 0 30px;
+
+                // padding-top: 8px;
+                span {
+                    margin: 0;
+                }
+            }
+
+            .indexdialog {
+                .el-overlay {
+                    .el-dialog {
+                        .el-dialog__body {
+                            padding: 30px 60px 30px 20px !important;
+
+                            .periodFrom {
+
+                                .el-select,
+                                .el-input {
+                                    width: 100%;
+                                }
+
+                                .el-input {
+                                    height: 30px;
+                                }
+                            }
+                        }
+                    }
+                }
+            }
+        }
+
+        .benchmarkingIndicatorTableData {
+            display: flex;
+            width: 100%;
+
+            .tableMain {
+                width: calc(100% - 100px);
+
+                .el-table {
+                    .el-table__header-wrapper {
+                        .el-table__header {
+                            .el-table__cell {
+                                border-bottom: none !important;
+                            }
+
+                            thead {
+                                tr {
+                                    th {
+                                        .cell {
+                                            line-height: 16px;
+                                        }
+                                    }
+                                }
+                            }
+                        }
+                    }
+
+                    .el-table__body-wrapper {
+                        height: 60vh !important;
+
+                        .el-scrollbar {
+                            .is-horizontal {
+                                .el-scrollbar__thumb {
+                                    width: 100% !important;
+                                }
+                            }
+
+                            .el-table__body {
+                                tr {
+                                    td {
+                                        padding: 0;
+
+                                        .cell {
+                                            // background: #F6F7FA;
+                                            line-height: 47px;
+                                            height: 47px;
+                                        }
+                                    }
+
+                                    td:hover {
+                                        line-height: 45px;
+                                        height: 45px;
+                                    }
+                                }
+                            }
+                        }
+                    }
+
+                    .el-table--border .el-table__cell {
+                        border: none;
+                    }
+
+                    .el-table thead.is-group th.el-table__cell {
+                        background: transparent;
+                    }
+                }
+
+                .el-pagination {
+                    margin-top: 20px;
+                    text-align: end;
+                    position: relative;
+                }
+            }
+
+            .tableSeach {
+                width: 81px;
+                height: 100%;
+                margin-left: 10px;
+                border: 1px solid #D6DBEA;
+                padding: 5px 0;
+                border-radius: 5px;
+
+                .seachType {
+                    width: 78px;
+                    height: 78px;
+                    cursor: pointer;
+                    border-left: 3px solid transparent;
+
+                    img {
+                        margin-top: 17px;
+                        margin-left: 27px;
+                    }
+
+                    p {
+                        text-align: center;
+                        font-size: 14px;
+                    }
+                }
+
+                .seachTypeCha {
+                    background: #E6EBF5;
+                    cursor: pointer;
+                    border-left: 3px solid #3B7AD1;
+                }
+            }
+        }
+
+    }
+</style>

+ 1 - 1
src/components/assessment/evaluationMonthPage.vue

@@ -96,7 +96,7 @@
                                 <el-col :span="8" v-if="scope.row.instId && scope.row.stage !== '流程已结束'">
                                     <p class="indicitem" @click="calculateScore(scope.row)">计算得分</p>
                                 </el-col>
-                                <el-col :span="8" v-if="scope.row.instId">
+                                <el-col :span="8" v-if="scope.row.instId && scope.row.stage !== '流程已结束'">
                                     <p class="indicitem" style="cursor: no-drop;color: #d9d9d9" v-if="isReportshow">生成报表</p>
                                     <p class="indicitem" v-else @click="generateReport(scope.row)">生成报表</p>
                                 </el-col>

+ 1 - 1
src/components/assessment/evaluationQuarterPage.vue

@@ -96,7 +96,7 @@
                                 <el-col :span="8" v-if="scope.row.instId && scope.row.stage !== '流程已结束'">
                                     <p class="indicitem" @click="calculateScore(scope.row)">计算得分</p>
                                 </el-col>
-                                <el-col :span="8" v-if="scope.row.instId">
+                                <el-col :span="8" v-if="scope.row.instId && scope.row.stage !== '流程已结束'">
                                     <p class="indicitem" style="cursor: no-drop;color: #d9d9d9" v-if="isReportshow">生成报表</p>
                                     <p class="indicitem" v-else @click="generateReport(scope.row)">生成报表</p>
                                 </el-col>

+ 1 - 1
src/components/assessment/evaluationYearPage.vue

@@ -94,7 +94,7 @@
                                 <el-col :span="8" v-if="scope.row.instId && scope.row.stage !== '流程已结束'">
                                     <p class="indicitem" @click="calculateScore(scope.row)">计算得分</p>
                                 </el-col>
-                                <el-col :span="8" v-if="scope.row.instId">
+                                <el-col :span="8" v-if="scope.row.instId && scope.row.stage !== '流程已结束'">
                                     <p class="indicitem" style="cursor: no-drop;color: #d9d9d9" v-if="isReportshow">生成报表</p>
                                     <p class="indicitem" v-else @click="generateReport(scope.row)">生成报表</p>
                                 </el-col>

+ 269 - 0
src/components/robotAi/robotAiPage.vue

@@ -0,0 +1,269 @@
+<template>
+    <div class="robotAi">
+        <div class="robotAiMain" id="robotAiMain">
+            <div class="robotAiNoMessage" v-if="questionAndAnswerData.length === 0">
+                <img :src="robotIcon" alt="">
+                <span class="noMsg1">您好,我是全业务域智能AI模型 </span>
+                <span class="noMsg2">我可以把我知道的都告诉你哦~</span>
+            </div>
+            <div class="robotAiMessage" v-else v-for="it in questionAndAnswerData" :key="it.id">
+                <div class="questionMes">
+                    <img :src="userIcon" alt="">
+                    <div class="questionStyle">{{it.question}}</div>
+                </div>
+                <div class="answerMes">
+                    <img :src="robotIcon" alt="">
+                    <div class="answerStyle">
+                        <div class="answerStyleDiv"><span class="answerStyleSC">该回答由全业务域生成</span></div>
+                        <div class="answerStyleSS" :style="{ whiteSpace: 'pre-wrap' }"
+                            v-if="it.id !== questionAndAnswerData.length">{{it.answer}}</div>
+                        <div class="answerStyleSS" :style="{ whiteSpace: 'pre-wrap' }" v-else>
+                            <span v-html="showAnswer"></span>
+                        </div>
+                    </div>
+                </div>
+            </div>
+        </div>
+        <div class="robotAiQuestion">
+            <div class="questionTop">
+                <img :src="messageIcon" alt="">
+                <span>全新对话</span>
+            </div>
+            <div class="questionBot">
+                <el-input v-model="textareaAi" :rows="4" type="textarea" resize="none"
+                    placeholder="在此输入您想要了解的内容,shift可进行换行" />
+                <el-button type="primary" size="small" @click="findAnswer" :disabled="!textareaAi">发送</el-button>
+            </div>
+        </div>
+    </div>
+</template>
+
+<script>
+    import messageIcon from '../../assets/menuImg/robotMsg.png'
+    import userIcon from '../../assets/menuImg/user.png'
+    import robotIcon from '../../assets/menuImg/robotAns.png'
+    import {
+        apiGetAiQuestionData,
+    } from '../../api/api'
+    export default {
+        data() {
+            return {
+                winPix: window.devicePixelRatio,
+                innerWidth: window.innerWidth,
+                messageIcon: messageIcon,
+                userIcon: userIcon,
+                robotIcon: robotIcon,
+                textareaAi: '',
+                showAnswer: '',
+                questionAndAnswerData: [],
+                timer: null
+            }
+        },
+        created() {},
+        updated() {
+            this.scrollToBottom()
+        },
+        methods: {
+            findAnswer() {
+                let that = this
+                let params = {
+                    question: this.textareaAi
+                }
+                apiGetAiQuestionData(params).then(datas => {
+                    if (datas) {
+                        let obj = {
+                            id: that.questionAndAnswerData.length + 1,
+                            question: that.textareaAi,
+                            // answer: '等撒谎的卡斯蒂撒比的安徽省对三都撒旦等撒谎的卡斯蒂撒比的安徽省对三都撒旦等撒谎的卡斯'
+                            answer: datas.data
+                        }
+                        that.questionAndAnswerData.push(obj)
+                        that.textareaAi = ''
+                        that.appear(obj.answer)
+                    }
+                })
+            },
+            appear(content) {
+                const _this = this;
+
+                this.showAnswer = "";
+                clearTimeout(this.timer);
+
+                var speed = 50; //设置定时的速度 越来越快
+                var count = 1;
+
+
+
+                content = content.replace(/\/n/g, '<br/>');
+
+                function changeContent() {
+                    _this.showAnswer = content.substring(0, count); //截取字符串
+                    count++;
+
+                    if (count != content.length + 1) {
+                        speed -= 1;
+                        if (speed < 5) speed = 5;
+
+                        _this.timer = setTimeout(changeContent, speed);
+                    }
+                }
+                changeContent();
+            },
+            scrollToBottom() {
+                this.$nextTick(() => {
+                    let scroll = document.getElementById("robotAiMain")
+                    scroll.scrollTop = scroll.scrollHeight
+                })
+            }
+        },
+    }
+</script>
+
+<style lang="less">
+    .robotAi {
+        height: 100%;
+        padding: 20px 20% 0 20%;
+        background: #f3f6f9;
+
+        .robotAiMain {
+            height: 78%;
+            overflow-y: auto;
+            // background: #fff;
+            margin-bottom: 10px;
+
+            .robotAiNoMessage {
+                position: relative;
+                top: 40%;
+                text-align: center;
+
+                img {
+                    width: 30px;
+                    height: 30px;
+                    margin-right: 10px;
+                }
+
+                .noMsg1 {
+                    position: relative;
+                    top: -10px;
+                    font-size: 20px;
+                    font-weight: 900;
+                    font-family: '微软雅黑';
+                    /* 设置文字颜色为透明,以便背景渐变颜色可见 */
+                    color: transparent;
+                    /* 设置背景渐变 */
+                    background-image: linear-gradient(to right, #2c6feb, #4c96f3);
+                    /* 设置背景渐变填充文字区域 */
+                    background-clip: text;
+                }
+
+                .noMsg2 {
+                    position: relative;
+                    top: -10px;
+                    font-size: 14px;
+                    margin-left: 10px;
+                }
+            }
+
+            .robotAiMessage {
+                width: 100%;
+
+                .questionMes {
+                    display: flex;
+                    margin-bottom: 8px;
+
+                    img {
+                        width: 24px;
+                        height: 24px;
+                        margin-right: 5px;
+                    }
+
+                    .questionStyle {
+                        font-size: 14px;
+                    }
+                }
+
+                .answerMes {
+                    display: flex;
+                    margin-bottom: 20px;
+
+                    img {
+                        width: 24px;
+                        height: 24px;
+                        margin-right: 5px;
+                    }
+
+                    .answerStyle {
+                        font-size: 14px;
+                        background: #fff;
+                        padding: 10px;
+                        border-radius: 10px;
+                        width: 100%;
+
+                        .answerStyleDiv {
+                            width: 100%;
+
+                            .answerStyleSC {
+                                height: 15px;
+                                width: 14%;
+                                padding: 2px 3px;
+                                display: inline-block;
+                                position: relative;
+                                left: 86%;
+                                font-size: 12px;
+                                color: #c1cad8;
+                                background: #f6faff;
+                                text-align: center;
+                            }
+                        }
+
+                        .answerStyleSS {
+                            display: inline-block;
+
+                        }
+                    }
+
+                }
+            }
+        }
+
+        .robotAiQuestion {
+            height: 20%;
+
+            .questionTop {
+                display: flex;
+                width: 10%;
+                text-align: center;
+                background: #fff;
+                border-radius: 15px;
+                margin-bottom: 5px;
+
+                span {
+                    font-size: 12px;
+                    color: #535875;
+                    position: relative;
+                    left: 6px;
+                    top: 3px;
+                }
+            }
+
+            .questionBot {
+                background: #fff;
+                border-radius: 10px;
+                padding: 5px;
+
+                .el-textarea {
+                    resize: none;
+                }
+
+                .el-button {
+                    width: 70px !important;
+                    height: 30px !important;
+                    margin-top: 5px;
+                    position: relative;
+                    left: 93%;
+                }
+            }
+        }
+
+    }
+</style>

+ 22 - 0
src/router/index.js

@@ -57,6 +57,17 @@ const routes = [
                     ),
             },
             {
+                path: '/robotAi',
+                name: 'robotAi',
+                meta: {
+                    title: '智能AI交互',
+                },
+                component: () =>
+                    import(
+                        '../components/robotAi/robotAiPage.vue'
+                    ),
+            },
+            {
                 path: '/assessment',
                 name: 'assessment',
                 meta: {
@@ -174,6 +185,17 @@ const routes = [
                             ),
                     },
                     {
+                        path: '/assessment/evaluationBenchmarkManage',
+                        name: 'evaluationBenchmarkManage',
+                        meta: {
+                            title: '业绩对标管理',
+                        },
+                        component: () =>
+                            import(
+                                '../components/assessment/evaluationBenchmarkManagePage.vue'
+                            ),
+                    },
+                    {
                         path: '/assessment/benchmarkingIndicBasic',
                         name: 'benchmarkingIndicBasic',
                         meta: {

+ 4 - 4
src/utils/baseUrl.js

@@ -10,15 +10,15 @@ switch (process.env.NODE_ENV) {
     case 'development': 
         baseUrl.ROOT = "/api"  //开发环境url
         // baseUrl.URL = "http://10.65.59.67:28800"
-        // baseUrl.URL = "http://192.168.2.6:28800"
-        baseUrl.URL = "http://10.65.78.23:28800"  //测试环境
+        baseUrl.URL = "http://192.168.2.127:28800"
+        // baseUrl.URL = "http://10.65.78.23:28800"  //测试环境
         // baseUrl.URL = "http://10.65.78.81:28800"  // 正式环境
         break
  
     case 'production': 
         // baseUrl.ROOT = "http://123.60.219.66:28800/"
-        baseUrl.ROOT = "http://10.65.78.23:28800/" //测试环境
-        // baseUrl.ROOT = "http://10.65.78.81:28800/"  // 正式环境
+        // baseUrl.ROOT = "http://10.65.78.23:28800/" //测试环境
+        baseUrl.ROOT = "http://10.65.78.81:28800/"  // 正式环境
         break 
 }
 

+ 19 - 2
src/views/Login.vue

@@ -9,10 +9,11 @@
                 </div>
                 <div class="loginCom" style="margin-bottom: 16px">
                     <img class="passwordIcon" src="../assets/loginImage/passwordIcon.png" alt="">
-                    <el-input type="password" v-model="inputMima" placeholder="请输入密码" />
+                    <el-input type="password" v-model="inputMima" placeholder="请输入密码" show-password />
                 </div>
                 <div class="remeber">
                     <el-checkbox v-model="ememberMe" @change="changeBox">记住密码</el-checkbox>
+                    <span class="forgetPass" @click="forgetPassFn">忘记密码</span>
                 </div>
                 <!-- v-if="!loginLoading"  v-else -->
                 <div class="loginBtn" @click="handleLogin" v-if="!loginLoading">
@@ -100,6 +101,15 @@ export default {
         
     },
     methods:{
+        forgetPassFn() {
+            let url = ''
+            if (window.location.href.includes('10.65.78.23')) {
+                url = 'http://10.65.78.23:81/#/modifyPassword'
+            } else {
+                url = 'http://10.65.79.83:81/#/modifyPassword'
+            }
+            window.open(url, 'blank')
+        },
         handleLogin() {
             if (this.inputUser !== '' && this.inputMima !== '') {
                 this.loginLoading = true
@@ -284,7 +294,9 @@ export default {
                 }
             }
             .remeber{
-                margin: 0 0 0 50px;
+                margin: 0 50px;
+                display: flex;
+                justify-content: space-between;
                 .el-checkbox{
                     .el-checkbox__label{
                         color: #fff;
@@ -292,6 +304,11 @@ export default {
                         padding-left:6px;
                     }
                 }
+                .forgetPass{
+                    cursor: pointer;
+                    font-size: 12px;
+                    color: #fff;
+                }
             }
             .loginBtn{
                 margin: 48px 0 0 43px;

+ 33 - 17
src/views/homePage.vue

@@ -39,6 +39,7 @@
     import zhishikuImg from '../assets/menuImg/zhishiku.png'
     import quanxianImg from '../assets/menuImg/quanxian.png'
     import tonggaoImg from '../assets/menuImg/tonggao.png'
+    import robotImg from '../assets/menuImg/robot.png'
     import benbuImg from '../assets/menuImg/benbu.png'
     import renyuanImg from '../assets/menuImg/renyuan.png'
     import closeBtn from '../assets/getwayImg/closeBtn.png'
@@ -81,10 +82,10 @@
                 this.userName = obj.name
                 this.getPersonMsg(obj.id)
             }
-            if (!this.$route?.query?.taskInfo) {
+            if (!this.$route ?.query ?.taskInfo) {
                 if (window.sessionStorage.getItem('routeTags')) {
                     this.routeTags = JSON.parse(window.sessionStorage.getItem('routeTags'))
-                    if (this.$route?.path === '/') {
+                    if (this.$route ?.path === '/') {
                         this.$router.push({
                             path: this.routeTags[0].index
                         })
@@ -100,10 +101,13 @@
                     window.sessionStorage.setItem('routeTags', JSON.stringify(this.routeTags))
                 }
             } else {
-                this.$router.push({ path: "/taskCenter", query: this.$route.query})
+                this.$router.push({
+                    path: "/taskCenter",
+                    query: this.$route.query
+                })
             }
-            
-            
+
+
             // this.forecastDatas = [{
             //         index: '/home',
             //         name: '考评首页',
@@ -120,11 +124,15 @@
             //         img: tonggaoImg
             //     },
             //     {
+            //         index: '/robotAi',
+            //         name: '智能AI交互',
+            //         img: robotImg
+            //     },
+            //     {
             //         index: '1',
             //         name: '考评体系配置',
             //         img: tixiImg,
-            //         children: [
-            //             {
+            //         children: [{
             //                 index: '/evaluationSystem/systemWarning',
             //                 name: '考评体系预警',
             //             },
@@ -199,6 +207,10 @@
             //                 name: '基础指标对标'
             //             },
             //             {
+            //                 index: '/assessment/evaluationBenchmarkManage',
+            //                 name: '业绩对标管理'
+            //             },
+            //             {
             //                 index: '/assessment/evaluationWarning',
             //                 name: '考评预警'
             //             },
@@ -216,8 +228,7 @@
             //         index: '3',
             //         name: '本部考评业务',
             //         img: benbuImg,
-            //         children: [
-            //             {
+            //         children: [{
             //                 index: '/assessment/assessmentApplication',
             //                 name: '月度绩效考核结果申报'
             //             },
@@ -242,7 +253,7 @@
             //         children: [{
             //                 index: '/baseInfomation/baseDataDictionary',
             //                 name: '数据字典配置',
-            //             },{
+            //             }, {
             //                 index: '/baseInfomation/baseBinSection',
             //                 name: '业务属性配置',
             //             },
@@ -284,7 +295,7 @@
             //         ]
             //     },
             // ]
-            
+
         },
         mounted() {
 
@@ -338,9 +349,10 @@
                             }
                             // if (item.name === '考评首页') {
                             //     obj.img = homeImg
-                            // } else if (item.name === '任务中心') {
-                            //     obj.img = taskImg
                             // } else 
+                            if (item.name === '智能AI交互') {
+                                obj.img = robotImg
+                            } else 
                             if (item.name === '通告管理') {
                                 obj.img = tonggaoImg
                             } else if (item.name === '考评体系配置') {
@@ -379,7 +391,8 @@
                 apiGetUserPostList(params).then(datas => {
                     if (datas.data && datas.data.records.length > 0) {
                         datas.data.records.forEach(it => {
-                            if (it.posName.indexOf('组织人事部') !== -1 || it.deptName.indexOf('组织人事部') !== -1) {
+                            if (it.posName.indexOf('组织人事部') !== -1 || it.deptName.indexOf('组织人事部') !== -
+                                1) {
                                 window.sessionStorage.setItem('ispersonDept', true)
                             }
                         })
@@ -604,12 +617,13 @@
                 }
             }
 
-            .menuList100{
+            .menuList100 {
                 .el-sub-menu {
                     .el-menu-item {
                         position: relative;
                         left: 10%;
                     }
+
                     .el-menu-item:hover,
                     .el-menu-item.is-active {
                         position: relative;
@@ -617,12 +631,14 @@
                     }
                 }
             }
-            .menuList125{
+
+            .menuList125 {
                 .el-sub-menu {
                     .el-menu-item {
                         position: relative;
                         left: 7%;
                     }
+
                     .el-menu-item:hover,
                     .el-menu-item.is-active {
                         position: relative;
@@ -686,7 +702,7 @@
                 }
 
                 .mainMessage {
-                    width: 100%;
+                    width: calc(100% - 20px);
                     height: 91vh;
                     // padding: 0 10px;
                     // background: #fff;