xtz 4 年之前
父節點
當前提交
6e6b09ac16

二進制
public/img/logo1.png


+ 1 - 1
src/common/sass/currency.scss

@@ -1,6 +1,6 @@
 $tint-color: rgb(251,251,251);
 $desc-color: #B3C4E0;
-$dark-color: #1D2088;
+$dark-color: #fff;
 $gray-color: rgb(242,243,245);
 $theme-color: rgb(141,144,249);
 /* 改变主题色变量 */

+ 4 - 1
src/components/vAbove/vAbove.scss

@@ -6,13 +6,16 @@ $above-height:65px;
   z-index:100;
   width: calc(100% - 210px);
   box-shadow: 1px 1px 12px rgb(244,244,244);
-  background-color:#fff;
+  background-color:#006df0;
   height:$above-height;
   .avator{
     position: absolute;
     right:30px;
     top:18px;
     cursor: pointer;
+    .name  {
+      color:#fff;
+    }
     .img{
       background-color: rgb(212, 209, 209);
       width:calc(#{$above-height} - 36px);

+ 18 - 17
src/components/vAbove/vAbove.vue

@@ -6,21 +6,21 @@
  * @FilePath     : \ambre-admin-noob\src\components\vAbove\vAbove.vue
 -->
 <template>
-  <div class="vAboveCom">
+<div class="vAboveCom">
     <div class="avator">
-      <el-dropdown trigger="click">
-        <div class="name">
-          {{name||'无昵称'}}
-          <i class="el-icon-caret-bottom"></i>
-        </div>
-        <el-dropdown-menu class="user-dropdown" slot="dropdown">
-          <el-dropdown-item divided>
-            <span @click="logout" style="display:block;">退出</span>
-          </el-dropdown-item>
-        </el-dropdown-menu>
-      </el-dropdown>
+        <el-dropdown trigger="click">
+            <div class="name">
+                {{name||'无昵称'}}
+                <i class="el-icon-caret-bottom" style="color: #fff"></i>
+            </div>
+            <el-dropdown-menu class="user-dropdown" slot="dropdown">
+                <el-dropdown-item divided>
+                    <span @click="logout" style="display:block;">退出</span>
+                </el-dropdown-item>
+            </el-dropdown-menu>
+        </el-dropdown>
     </div>
-  </div>
+</div>
 </template>
 
 <script>
@@ -44,10 +44,11 @@ export default {
 }
 </script>
 
-<style lang='scss' scoped>
+<style lang="scss" scoped>
 @import './vAbove.scss';
-.name{
-  font-size: 20px;
-  float: left;
+
+.name {
+    font-size: 20px;
+    float: left;
 }
 </style>

+ 7 - 5
src/components/vNav/vNav.scss

@@ -13,7 +13,7 @@
     border-right:none;
     .is-active{
       .a_menu{
-        color: #ffffff;
+        color: #757778;
       }
     }
     /deep/.el-submenu{
@@ -38,18 +38,20 @@
     min-width: 80px !important;
   }
   .el-menu-item.is-active{
-    background-color:#2493a7 !important;
-    color:#fff;
+    background-color:rgba(0, 109, 240, 0.1) !important;
+    color: #8D9498!important;
     width:180px;
     min-width: 80px;
 
   }
   .el-menu-item{
     &:hover{
-        background:#2493a7 !important;
+        background:#eee !important;
+        color: #757778!important;
     }
     &:active,&:visited{
-        background:#2493a7 !important;
+        // background:#2493a7 !important;
+        color: #8D9498!important;
     }
   }
   .logo{

+ 8 - 9
src/components/vNav/vNav.vue

@@ -1,10 +1,9 @@
 <template>
 <div class="vNavCom">
     <div class="logo">
-        <!-- <img src="../../../public/img/logo.png" alt=""> -->
-        优创面试后台管理
+        <img src="../../../public/img/logo1.png" alt="">
     </div>
-    <el-menu background-color="#1D2088" @select="handleSelect" text-color="#F1F1F1" unique-opened active-text-color="#fff">
+    <el-menu background-color="#fff" @select="handleSelect" text-color="#8D9498" unique-opened active-text-color="#fff">
         <el-submenu v-for="(item,index) in route||filterOne" :key="index" :index="`${index}`">
             <template slot="title">
                 <span :class="'iconfont '+item.icon"></span>
@@ -163,14 +162,14 @@ export default {
 @import './vNav.scss';
 
 /deep/.el-submenu__title i {
-    color: #ffffff;
+    color: #8D9498;
 }
 
-.logo {
-    color: #ffffff;
-    font-size: 20px;
-    padding: 15% 0 13% 0;
-}
+// .logo {
+//     color: #ffffff;
+//     font-size: 20px;
+//     padding: 15% 0 13% 0;
+// }
 
 // .vNavCom{
 //   overflow-y: scroll;

File diff suppressed because it is too large
+ 514 - 525
src/views/candidateManage/candidateList.vue


+ 11 - 1
src/views/candidateManage/resumeList.vue

@@ -32,7 +32,7 @@
                 </el-select>
                 <!-- <div v-else>{{this.downList1.some(i => i.id === form.processId) ? this.downList1.find(i => i.id === form.processId).processName : ''}}</div> -->
             </el-form-item>
-            <el-form-item label="群发邮箱">139820930@qq.com</el-form-item>
+            <el-form-item label="群发邮箱">{{email}}</el-form-item>
             <el-form-item>
                 <el-button @click="close">取消</el-button>
                 <el-button type="primary" @click="launch">立即发出</el-button>
@@ -99,6 +99,7 @@ export default {
       downList: [],
       form: {},
       uform: {},
+      email: '',
       searchForm: {},
       rules: {
         templateId: [{
@@ -366,6 +367,7 @@ export default {
   mounted () {
     this.queryData()
     this.queryDownList()
+    this.queryEmail()
   },
   methods: {
     queryData (form = {}) {
@@ -425,6 +427,14 @@ export default {
       //     }))
       //   })
     },
+    queryEmail () {
+      this.$api
+        .post('/companyAccount/queryCompanyAccountList', {
+          reqdata: {}
+        }).then(res => {
+          this.email = res.list.some(item => item.useType === 1) ? res.list.find(item => item.useType === 1).cmpMailAccount : ''
+        })
+    },
     search (form) {
       this.queryData(form)
     },

+ 497 - 31
src/views/candidateManage/statistics.vue

@@ -7,25 +7,102 @@
  * @LastEditTime: 2020-08-12 18:37:45
 -->
 <template>
-  <div>
+<div>
     <div class="flex">
-      <div ref="mychart1" :style="{width: '75%', height: '500px'}"></div>
-      <div class="flex1">
-        <div>
-          <div class="num">校招投递简历总数 {{schoolTotal||0}}条</div>
-          <div class="num">社招投递简历总数 {{clubTotal||0}}条</div>
+        <div ref="mychart1" :style="{width: '75%', height: '500px'}"></div>
+        <div class="flex1">
+            <div>
+                <div class="num">校招投递简历总数 {{schoolTotal||0}}条</div>
+                <div class="num">社招投递简历总数 {{clubTotal||0}}条</div>
+            </div>
+            <div>
+                <div class="title">本周</div>
+                <div class="num">校招投递简历数 {{schoolWeek||0}}条</div>
+                <div class="num">社招投递简历数 {{clubWeek||0}}条</div>
+            </div>
         </div>
-        <div>
-          <div class="title">本周</div>
-          <div class="num">校招投递简历数  {{schoolWeek||0}}条</div>
-          <div class="num">社招投递简历数  {{clubWeek||0}}条</div>
-        </div>
-      </div>
     </div>
     <div class="flex">
-      <div ref="mychart2" :style="{width: '75%', height: '300px'}"></div>
+        <div ref="mychart2" :style="{width: '100%', height: '600px', marginTop: '30px'}"></div>
     </div>
-  </div>
+    <el-table :data="resumeTable" border style="width: 100%">
+        <el-table-column prop="name" label="渠道名称">
+        </el-table-column>
+        <el-table-column prop="0" label="已收到简历">
+            <template slot-scope="scope">
+                <span>{{scope.row[0] || 0}}</span>
+            </template>
+        </el-table-column>
+        <el-table-column prop="1" label="已通过建立">
+            <template slot-scope="scope">
+                <span>{{scope.row[1] || 0}}</span>
+            </template>
+        </el-table-column>
+        <el-table-column prop="2" label="已淘汰建立">
+            <template slot-scope="scope">
+                <span>{{scope.row[2] || 0}}</span>
+            </template>
+        </el-table-column>
+        <el-table-column prop="3" label="待定简历">
+            <template slot-scope="scope">
+                <span>{{scope.row[3] || 0}}</span>
+            </template>
+        </el-table-column>
+    </el-table>
+    <div class="title">简历状态统计</div>
+    <el-table :data="tableData" border style="width: 100%">
+        <el-table-column prop="address" label="职位">
+        </el-table-column>
+        <el-table-column prop="0" label="51job">
+        </el-table-column>
+        <el-table-column prop="1" label="智联">
+        </el-table-column>
+        <el-table-column prop="2" label="58同城">
+        </el-table-column>
+        <el-table-column prop="3" label="平台">
+        </el-table-column>
+    </el-table>
+    <div class="title">简历投递职位统计</div>
+    <div ref="mychart3" :style="{width: '100%', height: '600px', marginTop: '30px'}"></div>
+    <el-table :data="interviewTable" border style="width: 100%">
+        <el-table-column prop="name" label="渠道名称">
+        </el-table-column>
+        <el-table-column prop="0" label="已收到简历">
+            <template slot-scope="scope">
+                <span>{{scope.row[0] || 0}}</span>
+            </template>
+        </el-table-column>
+        <el-table-column prop="1" label="已通过建立">
+            <template slot-scope="scope">
+                <span>{{scope.row[1] || 0}}</span>
+            </template>
+        </el-table-column>
+        <el-table-column prop="2" label="已淘汰建立">
+            <template slot-scope="scope">
+                <span>{{scope.row[2] || 0}}</span>
+            </template>
+        </el-table-column>
+        <el-table-column prop="3" label="待定简历">
+            <template slot-scope="scope">
+                <span>{{scope.row[3] || 0}}</span>
+            </template>
+        </el-table-column>
+    </el-table>
+    <div class="title">简历状态统计</div>
+    <el-table :data="tableData" border style="width: 100%">
+        <el-table-column prop="address" label="职位">
+        </el-table-column>
+        <el-table-column prop="date" label="51job">
+        </el-table-column>
+        <el-table-column prop="date" label="智联">
+        </el-table-column>
+        <el-table-column prop="name" label="58同城">
+        </el-table-column>
+        <el-table-column prop="address" label="平台">
+        </el-table-column>
+    </el-table>
+    <div class="title">简历投递职位统计</div>
+</div>
 </template>
 
 <script>
@@ -39,11 +116,19 @@ export default {
       clubTotal: 0,
       schoolTotal: 0,
       clubWeek: 0,
-      schoolWeek: 0
+      schoolWeek: 0,
+      platformList: ['51job', '智联', '58同城', '平台'],
+      resumeList: [],
+      resumeTable: [],
+      interviewList: [],
+      interviewTable: [],
+      tableData: []
     }
   },
   mounted () {
     this.queryData()
+    this.queryData2()
+    this.queryData3()
   },
   methods: {
     queryData () {
@@ -76,6 +161,33 @@ export default {
             })
         })
     },
+    queryData2 () {
+      this.$api
+        .post('/chart/getResumeTotal', {
+          reqdata: {}
+        }).then(res => {
+          this.resumeList = res.list
+          this.resumeTable = res.list.map((item, index) => {
+            item.name = this.platformList[index]
+            return item
+          })
+          console.log((this.resumeList[0]))
+          this.initChart2()
+        })
+    },
+    queryData3 () {
+      this.$api
+        .post('/chart/getInterviewTotal', {
+          reqdata: {}
+        }).then(res => {
+          this.interviewList = res.list
+          this.interviewTable = res.list.map((item, index) => {
+            item.name = this.platformList[index]
+            return item
+          })
+          this.initChart3()
+        })
+    },
     initChart () {
       let myChart = echarts.init(this.$refs.mychart1)
       myChart.setOption({
@@ -111,40 +223,394 @@ export default {
         yAxis: {
           type: 'value'
         },
-        series: [
-          {
-            name: '校招投递简历',
-            type: 'line',
-            data: this.schoolRecruit
+        series: [{
+          name: '校招投递简历',
+          type: 'line',
+          data: this.schoolRecruit
+        },
+        {
+          name: '社招投递简历',
+          type: 'line',
+          data: this.clubRecruit
+        }
+        ]
+      })
+      setTimeout(function () {
+        window.onresize = function () {
+          myChart.resize()
+        }
+      }, 200)
+    },
+    initChart2 () {
+      let myChart = echarts.init(this.$refs.mychart2)
+      let app = {}
+      var posList = [
+        'left', 'right', 'top', 'bottom',
+        'inside',
+        'insideTop', 'insideLeft', 'insideRight', 'insideBottom',
+        'insideTopLeft', 'insideTopRight', 'insideBottomLeft', 'insideBottomRight'
+      ]
+
+      app.configParameters = {
+        rotate: {
+          min: -90,
+          max: 90
+        },
+        align: {
+          options: {
+            left: 'left',
+            center: 'center',
+            right: 'right'
+          }
+        },
+        verticalAlign: {
+          options: {
+            top: 'top',
+            middle: 'middle',
+            bottom: 'bottom'
+          }
+        },
+        position: {
+          options: echarts.util.reduce(posList, function (map, pos) {
+            map[pos] = pos
+            return map
+          }, {})
+        },
+        distance: {
+          min: 0,
+          max: 100
+        }
+      }
+
+      app.config = {
+        rotate: 90,
+        align: 'left',
+        verticalAlign: 'middle',
+        position: 'insideBottom',
+        distance: 15,
+        onChange: function () {
+          var labelOption = {
+            normal: {
+              rotate: app.config.rotate,
+              align: app.config.align,
+              verticalAlign: app.config.verticalAlign,
+              position: app.config.position,
+              distance: app.config.distance
+            }
+          }
+          myChart.setOption({
+            series: [{
+              label: labelOption
+            }, {
+              label: labelOption
+            }, {
+              label: labelOption
+            }, {
+              label: labelOption
+            }]
+          })
+        }
+      }
+
+      let labelOption = {
+        show: true,
+        position: app.config.position,
+        distance: app.config.distance,
+        align: app.config.align,
+        verticalAlign: app.config.verticalAlign,
+        rotate: app.config.rotate,
+        formatter: '{c}  {name|{a}}',
+        fontSize: 16,
+        rich: {
+          name: {
+            textBorderColor: '#fff'
+          }
+        }
+      }
+
+      let option = {
+        title: {
+          text: '招聘渠道分析:简历管理'
+        },
+        color: ['#003366', '#006699', '#4cabce', '#e5323e'],
+        tooltip: {
+          trigger: 'axis',
+          axisPointer: {
+            type: 'shadow'
+          }
+        },
+        legend: {
+          data: ['已收到', '已通过', '已淘汰', '待定']
+        },
+        toolbox: {
+          show: true,
+          orient: 'vertical',
+          left: 'right',
+          top: 'center',
+          feature: {
+            mark: {
+              show: true
+            },
+            dataView: {
+              show: true,
+              readOnly: false
+            },
+            magicType: {
+              show: true,
+              type: ['line', 'bar', 'stack', 'tiled']
+            },
+            restore: {
+              show: true
+            },
+            saveAsImage: {
+              show: true
+            }
+          }
+        },
+        xAxis: [{
+          type: 'category',
+          axisTick: {
+            show: false
           },
-          {
-            name: '社招投递简历',
-            type: 'line',
-            data: this.clubRecruit
+          data: this.platformList
+        }],
+        yAxis: [{
+          type: 'value'
+        }],
+        series: [{
+          name: '已收到',
+          type: 'bar',
+          barGap: 0,
+          label: labelOption,
+          data: [this.resumeList[0]['0'] || 0, this.resumeList[1]['0'] || 0, this.resumeList[2]['0'] || 0, this.resumeList[3]['0'] || 0]
+        },
+        {
+          name: '已通过',
+          type: 'bar',
+          label: labelOption,
+          data: [this.resumeList[0]['1'] || 0, this.resumeList[1]['1'] || 0, this.resumeList[2]['1'] || 0, this.resumeList[3]['1'] || 0]
+        },
+        {
+          name: '已淘汰',
+          type: 'bar',
+          label: labelOption,
+          data: [this.resumeList[0]['2'] || 0, this.resumeList[1]['2'] || 0, this.resumeList[2]['2'] || 0, this.resumeList[3]['2'] || 0]
+        },
+        {
+          name: '待定',
+          type: 'bar',
+          label: labelOption,
+          data: [this.resumeList[0]['3'] || 0, this.resumeList[1]['3'] || 0, this.resumeList[2]['3'] || 0, this.resumeList[3]['3'] || 0]
+        }
+        ]
+      }
+
+      myChart.setOption(option)
+      setTimeout(function () {
+        window.onresize = function () {
+          myChart.resize()
+        }
+      }, 200)
+    },
+    initChart3 () {
+      let myChart = echarts.init(this.$refs.mychart3)
+      let app = {}
+      var posList = [
+        'left', 'right', 'top', 'bottom',
+        'inside',
+        'insideTop', 'insideLeft', 'insideRight', 'insideBottom',
+        'insideTopLeft', 'insideTopRight', 'insideBottomLeft', 'insideBottomRight'
+      ]
+
+      app.configParameters = {
+        rotate: {
+          min: -90,
+          max: 90
+        },
+        align: {
+          options: {
+            left: 'left',
+            center: 'center',
+            right: 'right'
           }
+        },
+        verticalAlign: {
+          options: {
+            top: 'top',
+            middle: 'middle',
+            bottom: 'bottom'
+          }
+        },
+        position: {
+          options: echarts.util.reduce(posList, function (map, pos) {
+            map[pos] = pos
+            return map
+          }, {})
+        },
+        distance: {
+          min: 0,
+          max: 100
+        }
+      }
+
+      app.config = {
+        rotate: 90,
+        align: 'left',
+        verticalAlign: 'middle',
+        position: 'insideBottom',
+        distance: 15,
+        onChange: function () {
+          var labelOption = {
+            normal: {
+              rotate: app.config.rotate,
+              align: app.config.align,
+              verticalAlign: app.config.verticalAlign,
+              position: app.config.position,
+              distance: app.config.distance
+            }
+          }
+          myChart.setOption({
+            series: [{
+              label: labelOption
+            }, {
+              label: labelOption
+            }, {
+              label: labelOption
+            }, {
+              label: labelOption
+            }]
+          })
+        }
+      }
+
+      let labelOption = {
+        show: true,
+        position: app.config.position,
+        distance: app.config.distance,
+        align: app.config.align,
+        verticalAlign: app.config.verticalAlign,
+        rotate: app.config.rotate,
+        formatter: '{c}  {name|{a}}',
+        fontSize: 16,
+        rich: {
+          name: {
+            textBorderColor: '#fff'
+          }
+        }
+      }
+
+      let {
+        interviewList
+      } = this
+
+      let option = {
+        title: {
+          text: '招聘渠道分析:面试管理'
+        },
+        color: ['#003366', '#006699', '#4cabce', '#e5323e'],
+        tooltip: {
+          trigger: 'axis',
+          axisPointer: {
+            type: 'shadow'
+          }
+        },
+        legend: {
+          data: ['已通知', '已通过', '已淘汰', '待定']
+        },
+        toolbox: {
+          show: true,
+          orient: 'vertical',
+          left: 'right',
+          top: 'center',
+          feature: {
+            mark: {
+              show: true
+            },
+            dataView: {
+              show: true,
+              readOnly: false
+            },
+            magicType: {
+              show: true,
+              type: ['line', 'bar', 'stack', 'tiled']
+            },
+            restore: {
+              show: true
+            },
+            saveAsImage: {
+              show: true
+            }
+          }
+        },
+        xAxis: [{
+          type: 'category',
+          axisTick: {
+            show: false
+          },
+          data: this.platformList
+        }],
+        yAxis: [{
+          type: 'value'
+        }],
+        series: [{
+          name: '已通知',
+          type: 'bar',
+          barGap: 0,
+          label: labelOption,
+          data: [interviewList[0]['0'] || 0, interviewList[1]['0'] || 0, interviewList[2]['0'] || 0, interviewList[3]['0'] || 0]
+        },
+        {
+          name: '已通过',
+          type: 'bar',
+          label: labelOption,
+          data: [interviewList[0]['1'] || 0, interviewList[1]['1'] || 0, interviewList[2]['1'] || 0, interviewList[3]['1'] || 0]
+        },
+        {
+          name: '已淘汰',
+          type: 'bar',
+          label: labelOption,
+          data: [interviewList[0]['2'] || 0, interviewList[1]['2'] || 0, interviewList[2]['2'] || 0, interviewList[3]['2'] || 0]
+        },
+        {
+          name: '待定',
+          type: 'bar',
+          label: labelOption,
+          data: [interviewList[0]['3'] || 0, interviewList[1]['3'] || 0, interviewList[2]['3'] || 0, interviewList[3]['3'] || 0]
+        }
         ]
-      })
+      }
+
+      myChart.setOption(option)
       setTimeout(function () {
         window.onresize = function () {
           myChart.resize()
         }
       }, 200)
     }
+
   }
 }
 </script>
 
 <style lang="scss" scoped>
-  .flex {
+.flex {
     display: flex;
-  }
-  .flex1 {
+}
+
+.flex1 {
     width: 200px;
     margin-top: 00px;
     margin-left: 80px;
-  }
-  .num {
+}
+
+.title {
+    margin: 8px;
+    text-align: center;
+    font-size: 16px;
+}
+
+.num {
     margin: 20px;
     font-size: 14px;
-  }
+}
 </style>

+ 23 - 21
src/views/companyManage/basicInfo.vue

@@ -7,24 +7,24 @@
  * @LastEditTime: 2020-07-29 19:38:47
 -->
 <template>
-  <div class="basicInfo">
+<div class="basicInfo">
     <el-card class="box-card">
-      <el-form ref="form" :model="form" label-width="140px" label-position="left">
-        <el-form-item label="公司名称">
-          <el-input v-model.trim="form.companyName"></el-input>
-        </el-form-item>
-        <el-form-item label="公司地址">
-          <el-input v-model.trim="form.companyAddress"></el-input>
-        </el-form-item>
-        <el-form-item label="公司简介">
-          <editor-bar class="editor" v-model.trim="form.companyIntroduce"></editor-bar>
-        </el-form-item>
-        <el-form-item class="button-grounp">
-          <el-button type="primary" @click="determine">确认修改</el-button>
-        </el-form-item>
-      </el-form>
+        <el-form ref="form" :model="form" label-width="140px" label-position="left">
+            <el-form-item label="公司名称">
+                <el-input disabled v-model.trim="form.companyName"></el-input>
+            </el-form-item>
+            <el-form-item label="公司地址">
+                <el-input v-model.trim="form.companyAddress"></el-input>
+            </el-form-item>
+            <el-form-item label="公司简介">
+                <editor-bar class="editor" v-model.trim="form.companyIntroduce"></editor-bar>
+            </el-form-item>
+            <el-form-item class="button-grounp">
+                <el-button type="primary" @click="determine">确认修改</el-button>
+            </el-form-item>
+        </el-form>
     </el-card>
-  </div>
+</div>
 </template>
 
 <script>
@@ -70,14 +70,16 @@ export default {
 
 <style lang="scss" scoped>
 .basicInfo {
-  display: flex;
-  justify-content: center;
-  align-content: center;
+    display: flex;
+    justify-content: center;
+    align-content: center;
 }
+
 .box-card {
-  width: 800rpx;
-  padding: 18px 0;
+    width: 800rpx;
+    padding: 18px 0;
 }
+
 .button-grounp {
     display: flex;
     justify-content: flex-end;