xtz 4 tahun lalu
induk
melakukan
e5701a3501

+ 2 - 2
.env.development

@@ -1,8 +1,8 @@
 // 本地环境
 module.exports={
   NODE_ENV = development
-  VUE_APP_API = https://api.yc1min.com
-  VUE_APP_IMG = https://cdn.yc1min.com
+  VUE_APP_API = http://118.24.176.28:7785
+  VUE_APP_IMG = http://cdn.info666.com
   VUE_APP_VER = 0.0.1
   VUE_APP_DAT = new Date().getTime()
   VUE_APP_DOMAIN = 127.0.0.1

+ 1 - 1
.env.test

@@ -1,7 +1,7 @@
 // 测试环境
 module.exports={
   NODE_ENV = test
-  VUE_APP_API = http://47.100.59.52:7785
+  VUE_APP_API = http://118.24.176.28:7785
   VUE_APP_IMG = http://cdn.info666.com
   VUE_APP_VER = 0.0.1
   VUE_APP_DAT = new Date().getTime()

+ 24 - 33
package-lock.json

@@ -1388,16 +1388,6 @@
       "integrity": "sha512-Jus9s4CDbqwocc5pOAnh8ShfrnMcPHuJYzVcSUU7lrh8Ni5HuIqX3oilL86p3dlTrk0LzHRCgA/GQ7uNCw6l2Q==",
       "dev": true
     },
-    "@types/mini-css-extract-plugin": {
-      "version": "0.9.1",
-      "resolved": "https://registry.npmjs.org/@types/mini-css-extract-plugin/-/mini-css-extract-plugin-0.9.1.tgz",
-      "integrity": "sha512-+mN04Oszdz9tGjUP/c1ReVwJXxSniLd7lF++sv+8dkABxVNthg6uccei+4ssKxRHGoMmPxdn7uBdJWONSJGTGQ==",
-      "dev": true,
-      "optional": true,
-      "requires": {
-        "@types/webpack": "*"
-      }
-    },
     "@types/minimatch": {
       "version": "3.0.3",
       "resolved": "https://registry.npmjs.org/@types/minimatch/-/minimatch-3.0.3.tgz",
@@ -12240,35 +12230,31 @@
       }
     },
     "vue-loader-v16": {
-      "version": "npm:vue-loader@16.0.0-beta.5",
-      "resolved": "https://registry.npmjs.org/vue-loader/-/vue-loader-16.0.0-beta.5.tgz",
-      "integrity": "sha512-ciWfzNefqWlmzKznCWY9hl+fPP4KlQ0A9MtHbJ/8DpyY+dAM8gDrjufIdxwTgC4szE4EZC3A6ip/BbrqM84GqA==",
+      "version": "npm:vue-loader@16.1.1",
+      "resolved": "https://registry.npmjs.org/vue-loader/-/vue-loader-16.1.1.tgz",
+      "integrity": "sha512-wz/+HFg/3SBayHWAlZXARcnDTl3VOChrfW9YnxvAweiuyKX/7IGx1ad/4yJHmwhgWlOVYMAbTiI7GV8G33PfGQ==",
       "dev": true,
       "optional": true,
       "requires": {
-        "@types/mini-css-extract-plugin": "^0.9.1",
-        "chalk": "^3.0.0",
+        "chalk": "^4.1.0",
         "hash-sum": "^2.0.0",
-        "loader-utils": "^1.2.3",
-        "merge-source-map": "^1.1.0",
-        "source-map": "^0.6.1"
+        "loader-utils": "^2.0.0"
       },
       "dependencies": {
         "ansi-styles": {
-          "version": "4.2.1",
-          "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.2.1.tgz",
-          "integrity": "sha512-9VGjrMsG1vePxcSweQsN20KY/c4zN0h9fLjqAbwbPfahM3t+NL+M9HC8xeXG2I8pX5NoamTGNuomEUFI7fcUjA==",
+          "version": "4.3.0",
+          "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+          "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
           "dev": true,
           "optional": true,
           "requires": {
-            "@types/color-name": "^1.1.1",
             "color-convert": "^2.0.1"
           }
         },
         "chalk": {
-          "version": "3.0.0",
-          "resolved": "https://registry.npmjs.org/chalk/-/chalk-3.0.0.tgz",
-          "integrity": "sha512-4D3B6Wf41KOYRFdszmDqMCGq5VV/uMAB273JILmO+3jAlh8X4qDtdtgCR3fxtbLEMzSx22QdhnDcJvu2u1fVwg==",
+          "version": "4.1.0",
+          "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz",
+          "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==",
           "dev": true,
           "optional": true,
           "requires": {
@@ -12300,17 +12286,22 @@
           "dev": true,
           "optional": true
         },
-        "source-map": {
-          "version": "0.6.1",
-          "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz",
-          "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==",
+        "loader-utils": {
+          "version": "2.0.0",
+          "resolved": "https://registry.npmjs.org/loader-utils/-/loader-utils-2.0.0.tgz",
+          "integrity": "sha512-rP4F0h2RaWSvPEkD7BLDFQnvSf+nK+wr3ESUjNTyAGobqrijmW92zc+SO6d4p4B1wh7+B/Jg1mkQe5NYUEHtHQ==",
           "dev": true,
-          "optional": true
+          "optional": true,
+          "requires": {
+            "big.js": "^5.2.2",
+            "emojis-list": "^3.0.0",
+            "json5": "^2.1.2"
+          }
         },
         "supports-color": {
-          "version": "7.1.0",
-          "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.1.0.tgz",
-          "integrity": "sha512-oRSIpR8pxT1Wr2FquTNnGet79b3BWljqOuoW/h4oBhxJ/HUbX5nX6JSruTkvXDCFMwDPvsaTTbvMLKZWSy0R5g==",
+          "version": "7.2.0",
+          "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+          "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
           "dev": true,
           "optional": true,
           "requires": {

+ 0 - 5
src/common/api/axios.js

@@ -25,7 +25,6 @@ const service = axios.create({
 
 service.interceptors.request.use(
   config => {
-    console.log(config.url)
     if (!fileUpload.includes(config.url)) {
       let data = {
         'from': 0,
@@ -53,7 +52,6 @@ service.interceptors.request.use(
     if (config.url === '/addr/all_addr') {
       config.baseURL = process.env.VUE_APP_API
     }
-    console.log(config)
 
     config.headers['Authorization'] = localStorage.getItem('token')
     api = config.url
@@ -66,16 +64,13 @@ service.interceptors.request.use(
 
 service.interceptors.response.use(
   res => {
-    console.log(res)
     let a = false
     return new Promise((resolve, reject) => {
       allowList.forEach(item => {
-        console.log(res.config.url)
         if (res.config.url.includes(item)) {
           // resolve(res.data)
           const content = res.data
           const blob = new Blob([content])
-          console.log(blob)
           const fileName = '人才库.xls'
           if ('download' in document.createElement('a')) { // 非IE下载
             const elink = document.createElement('a')

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

@@ -28,12 +28,9 @@ export default {
   data () {
     return {
       headImg: '',
-      name
+      name: localStorage.getItem('companyName')
     }
   },
-  mounted () {
-    this.name = localStorage.getItem('companyName')
-  },
   methods: {
     logout () {
       localStorage.clear()

+ 0 - 1
src/components/vBread/vBread.vue

@@ -43,7 +43,6 @@ export default {
   },
   methods: {
     getBreadcrumb () {
-      console.log(this.nav, this.$route)
       let parentName = []
       this.nav.forEach(item => {
         parentName.push({

+ 5 - 0
src/components/vNav/vNav.vue

@@ -128,6 +128,11 @@ export default {
             name: '数据统计',
             menuid: 515,
             to: 'statistics'
+          },
+          {
+            name: '系统信息',
+            menuid: 516,
+            to: 'systemInfo'
           }
           ]
         }

+ 1 - 1
src/components/vTable/vTable.vue

@@ -52,7 +52,7 @@
         <el-table-column label="操作" v-if="table.handle" :fixed="table.fixed && 'right'" :width="table.width" align="center">
             <template slot-scope="scope">
                 <el-dropdown v-if="table.button" @command="dropdownMethods">
-                    <el-button style="background: #00a0e9;color:#fff">
+                    <el-button style="background: #00a0e9;border-color:#00a0e9;color:#fff">
                         更多操作<i class="el-icon-arrow-down el-icon--right"></i>
                     </el-button>
                     <el-dropdown-menu slot="dropdown">

+ 0 - 2
src/components/wangEnduit/wangEnduit.vue

@@ -94,7 +94,6 @@ export default {
       // this.editor.customConfig.debug = true
 
       this.editor.customConfig.customUploadImg = (files, insert) => {
-        console.log(files, '@todo upload')
         this.loading = this.$loading({
           lock: true,
           text: 'Loading',
@@ -117,7 +116,6 @@ export default {
       let file = Array.from(files)
       this.$api.post('/upload/uploadImg', formData).then(res => {
         this.loading.close()
-        console.log(res, 'upload is finally')
         const img = this.$img + res
         insert(img)
         file.shift()

+ 5 - 0
src/router/index.js

@@ -82,6 +82,11 @@ const routes = [
     name: 'templateManage',
     component: () => import('@/views/companyManage/templateManage')
   },
+  {
+    path: '/systemInfo',
+    name: 'systemInfo',
+    component: () => import('@/views/systemManage/systemInfo')
+  },
   // error
   {
     path: '*',

+ 5 - 3
src/views/candidateManage/candidateAll.vue

@@ -165,6 +165,10 @@ export default {
         {
           label: '平台',
           value: 3
+        },
+        {
+          label: 'boss直聘',
+          value: 4
         }
         ]
       }
@@ -200,7 +204,7 @@ export default {
         {
           label: '简历来源',
           props: 'resumeFrom',
-          options: ['51job', '智联招聘', '58同城', '平台'],
+          options: ['51job', '智联招聘', '58同城', '平台', 'boss直聘'],
           width: 80
         },
         {
@@ -316,7 +320,6 @@ export default {
     },
     update (row) {
       this.openDia()
-      console.log(row)
       this.form = Object.assign({}, row)
     },
     submit () {
@@ -349,7 +352,6 @@ export default {
           reqdata: this.searchForm
         })
         .then((res) => {
-          console.log(res)
         })
     },
     openDia () {

+ 213 - 185
src/views/candidateManage/candidateList.vue

@@ -14,9 +14,10 @@
         <el-radio-button :label="1">已通过候选人</el-radio-button>
         <el-radio-button :label="2">已淘汰候选人</el-radio-button>
         <el-radio-button :label="3">待定候选人</el-radio-button>
+        <el-radio-button :label="4">已评分</el-radio-button>
     </el-radio-group><br />
     <el-dropdown v-if="table.button" @command="dropdownMethods">
-        <el-button style="background: #00a0e9;color:#fff">
+        <el-button style="background: #00a0e9;border-color:#00a0e9;color:#fff">
             更多操作<i class="el-icon-arrow-down el-icon--right"></i>
         </el-button>
         <el-dropdown-menu slot="dropdown">
@@ -24,7 +25,7 @@
         </el-dropdown-menu>
     </el-dropdown>
     <div style="height:20px"></div>
-    <v-table :key="isCollapse" :table="isCollapse===1?table1:isCollapse===2?table2:isCollapse===3?table3:table" :tableList="tableList" :sortType="true" :form="searchForm" :queryData="queryData" @details="details" @eliminate="eliminate" @through="through" @notice="notice" @del="del" @undetermined="undetermined" @openDia="openDia" @update="update" @selection-change="selection" @sendMail="sendMail" id="id" :all="true"></v-table>
+    <v-table :key="isCollapse" :table="isCollapse===1?table1:isCollapse===2?table2:isCollapse===3?table3:table" :tableList="tableList" :sortType="true" :form="searchForm" :queryData="queryData" @score="score" @details="details" @eliminate="eliminate" @through="through" @notice="notice" @del="del" @undetermined="undetermined" @openDia="openDia" @update="update" @selection-change="selection" @sendMail="sendMail" id="id" :all="true"></v-table>
     <v-pager @page="callPage" :total="totalrecords"></v-pager>
     <el-dialog :visible.sync="dialogFormVisible" width="600px" :before-close="close" :close-on-click-modal="false">
         <el-form :model="form" ref="form" label-width="140px" :rules="rules" label-position="left">
@@ -102,7 +103,7 @@
             </el-form-item>
         </el-form>
     </el-dialog>
-    <resume :dialogFormVisible="visibleTwo" :close="closeTwo" :info="infoTwo" :searchForm="searchForm" :queryData="queryData"></resume>
+    <resume :dialogFormVisible="visibleTwo" :type="resumeType" :close="closeTwo" :info="infoTwo" :searchForm="searchForm" :queryData="queryData"></resume>
 </div>
 </template>
 
@@ -121,18 +122,19 @@ export default {
       }
     }
     return {
-      dialogFormVisible: false,
-      dialogVisible: false,
-      visible: false,
-      visibleTwo: false,
+      dialogFormVisible: false, // 通知群发列表
+      dialogVisible: false, // 面试视频
+      visible: false, // 修改信息
+      visibleTwo: false, // 候选人信息
+      resumeType: false, // 简历评分 false:查看简历 true:简历评分
       tableList: [],
       page: 1,
-      isCollapse: 0,
-      totalrecords: 0,
-      pickList: [],
+      isCollapse: 0, // tab选择状态
+      totalrecords: 0, // 列表长度
+      pickList: [], // 被选中列表
       copyPickList: [],
-      downList: [],
-      positionList: [],
+      downList: [], // 下拉数据
+      positionList: [], // 应聘职位
       errorlist: [],
       searchForm: {},
       form: {},
@@ -189,54 +191,59 @@ export default {
           trigger: 'change'
         }]
       },
-      list: [{
-        placeholder: '请输入关键字查询',
-        props: 'condition'
-      },
-      {
-        type: 'select',
-        placeholder: '性别',
-        props: 'delivererSex',
-        options: [{
-          label: '全部',
-          value: null
-        }, {
-          label: '男',
-          value: 1
-        }, {
-          label: '女',
-          value: 0
-        }]
-      },
-      {
-        type: 'select',
-        placeholder: '来源',
-        props: 'resumeFrom',
-        options: [{
-          label: '全部',
-          value: null
-        },
-        {
-          label: '51job',
-          value: 0
-        },
+      list: [
         {
-          label: '智联',
-          value: 1
+          placeholder: '请输入关键字查询',
+          props: 'condition'
         },
         {
-          label: '58同城',
-          value: 2
+          type: 'select',
+          placeholder: '性别',
+          props: 'delivererSex',
+          options: [{
+            label: '全部',
+            value: null
+          }, {
+            label: '男',
+            value: 1
+          }, {
+            label: '女',
+            value: 0
+          }]
+        },
+        {
+          type: 'select',
+          placeholder: '来源',
+          props: 'resumeFrom',
+          options: [{
+            label: '全部',
+            value: null
+          },
+          {
+            label: '51job',
+            value: 0
+          },
+          {
+            label: '智联',
+            value: 1
+          },
+          {
+            label: '58同城',
+            value: 2
+          },
+          {
+            label: '平台',
+            value: 3
+          },
+          {
+            label: 'boss直聘',
+            value: 4
+          }
+          ]
         },
         {
-          label: '平台',
-          value: 3
+          type: 'date'
         }
-        ]
-      },
-      {
-        type: 'date'
-      }
       ],
       btn0: [{
         name: '确定',
@@ -319,99 +326,110 @@ export default {
       ],
       table: {
         selection: true,
-        column: [{
-          label: this.$t('field.serialNumber'),
-          props: 'serialNumber'
-        },
-        {
-          label: '姓名',
-          props: 'delivererName'
-        },
-        {
-          label: '性别',
-          props: 'delivererSex',
-          options: ['女', '男']
-        },
-        {
-          label: '简历来源',
-          props: 'resumeFrom',
-          options: ['51job', '智联招聘', '58同城', '平台']
-        },
-        {
-          label: '招聘类型',
-          props: 'recruitType',
-          options: ['社招', '校招', '直接校招']
-        },
-        // {
-        //   label: '简历投递职位',
-        //   props: 'positionApplied'
-        // },
-        {
-          label: '应聘职位',
-          props: 'positionName'
-        },
-        {
-          label: '工作年限',
-          props: 'delivererWorkExp'
-        },
-        {
-          label: '学历',
-          props: 'delivererEducation'
-        },
-        {
-          label: '联系电话',
-          props: 'delivererPhone'
-        },
-        {
-          label: '邮箱',
-          props: 'delivererMail'
-        },
-        {
-          label: '通知时间',
-          props: 'sendMailTime'
-        },
-        {
-          label: '完成时间',
-          props: 'confirmInterviewTime'
-        }
+        column: [
+          {
+            label: this.$t('field.serialNumber'),
+            props: 'serialNumber'
+          },
+          {
+            label: '姓名',
+            props: 'delivererName'
+          },
+          {
+            label: '性别',
+            props: 'delivererSex',
+            options: ['女', '男']
+          },
+          {
+            label: '简历来源',
+            props: 'resumeFrom',
+            options: ['51job', '智联招聘', '58同城', '平台', 'boss直聘']
+          },
+          {
+            label: '招聘类型',
+            props: 'recruitType',
+            options: ['社招', '校招', '直接校招']
+          },
+          // {
+          //   label: '简历投递职位',
+          //   props: 'positionApplied'
+          // },
+          {
+            label: '应聘职位',
+            props: 'positionName'
+          },
+          {
+            label: '工作年限',
+            props: 'delivererWorkExp'
+          },
+          {
+            label: '学历',
+            props: 'delivererEducation'
+          },
+          {
+            label: '联系电话',
+            props: 'delivererPhone'
+          },
+          {
+            label: '邮箱',
+            props: 'delivererMail'
+          },
+          {
+            label: '通知时间',
+            props: 'sendMailTime'
+          },
+          {
+            label: '完成时间',
+            props: 'confirmInterviewTime'
+          },
+          {
+            label: '评分状态',
+            props: ''
+          }
         ],
         width: 150,
         button: true,
-        handle: [{
-          title: '查看',
-          method: 'details',
-          type: 'info'
-        },
-        // {
-        //   title: '查看视频',
-        //   method: 'openDia',
-        //   type: 'info'
-        // },
-        {
-          title: '通过',
-          method: 'through',
-          type: 'success'
-        },
-        {
-          title: '淘汰',
-          method: 'eliminate',
-          type: 'danger'
-        },
-        {
-          title: '待定',
-          method: 'undetermined',
-          type: 'warning'
-        },
-        {
-          title: '修改',
-          method: 'update',
-          type: 'warning'
-        },
-        {
-          title: '邮件通知',
-          method: 'sendMail',
-          type: 'success'
-        }
+        handle: [
+          {
+            title: '评分',
+            method: 'score',
+            type: 'info'
+          },
+          {
+            title: '查看',
+            method: 'details',
+            type: 'info'
+          },
+          // {
+          //   title: '查看视频',
+          //   method: 'openDia',
+          //   type: 'info'
+          // },
+          {
+            title: '通过',
+            method: 'through',
+            type: 'success'
+          },
+          {
+            title: '淘汰',
+            method: 'eliminate',
+            type: 'danger'
+          },
+          {
+            title: '待定',
+            method: 'undetermined',
+            type: 'warning'
+          },
+          {
+            title: '修改',
+            method: 'update',
+            type: 'warning'
+          },
+          {
+            title: '邮件通知',
+            method: 'sendMail',
+            type: 'success'
+          }
         ]
       },
       table1: {
@@ -432,7 +450,7 @@ export default {
         {
           label: '简历来源',
           props: 'resumeFrom',
-          options: ['51job', '智联招聘', '58同城', '平台']
+          options: ['51job', '智联招聘', '58同城', '平台', 'boss直聘']
         },
         {
           label: '招聘类型',
@@ -519,7 +537,7 @@ export default {
         {
           label: '简历来源',
           props: 'resumeFrom',
-          options: ['51job', '智联招聘', '58同城', '平台']
+          options: ['51job', '智联招聘', '58同城', '平台', 'boss直聘']
         },
         // {
         //   label: '简历投递职位',
@@ -601,7 +619,7 @@ export default {
         {
           label: '简历来源',
           props: 'resumeFrom',
-          options: ['51job', '智联招聘', '58同城', '平台']
+          options: ['51job', '智联招聘', '58同城', '平台', 'boss直聘']
         },
         // {
         //   label: '简历投递职位',
@@ -675,7 +693,6 @@ export default {
     dropdownMethods ({
       method
     }) {
-      console.log(method)
       this[method + 'All']()
     },
     queryData (form = {}) {
@@ -735,12 +752,18 @@ export default {
     search (form) {
       this.queryData(form)
     },
+    score (row) {
+      this.openTwo()
+      this.resumeType = true
+      this.infoTwo = row
+    },
     details (row) {
       // row.filePath ? window.open(this.$img + row.filePath) : this.$message({
       //   type: 'info',
       //   message: '无此人简历'
       // })
       this.openTwo()
+      this.resumeType = false
       this.infoTwo = row
     },
     launch () {
@@ -913,7 +936,6 @@ export default {
     },
     update (row) {
       this.openVisible()
-      console.log(row)
       this.uform = Object.assign({}, row)
     },
     submit () {
@@ -959,7 +981,7 @@ export default {
       this.dialogFormVisible = false
       this.form = {}
       this.queryData(this.searchForm)
-      this.copyPickList = Array.from(this.pickList)
+      this.copyPickList = Array.from(this.pickList) // 浅拷贝
     },
     closeDia () {
       this.dialogVisible = false
@@ -992,41 +1014,47 @@ export default {
     isCollapse () {
       this.queryData(this.searchForm)
       this.isCollapse === 0 && this.$set(this.table, 'handle',
-        [{
-          title: '查看',
-          method: 'details',
-          type: 'info'
-        },
-        // {
-        //   title: '查看视频',
-        //   method: 'openDia',
-        //   type: 'info'
-        // },
-        {
-          title: '通过',
-          method: 'through',
-          type: 'success'
-        },
-        {
-          title: '淘汰',
-          method: 'eliminate',
-          type: 'danger'
-        },
-        {
-          title: '待定',
-          method: 'undetermined',
-          type: 'warning'
-        },
-        {
-          title: '修改',
-          method: 'update',
-          type: 'warning'
-        },
-        {
-          title: '邮件通知',
-          method: 'sendMail',
-          type: 'success'
-        }
+        [
+          {
+            title: '评分',
+            method: 'score',
+            type: 'info'
+          },
+          {
+            title: '查看',
+            method: 'details',
+            type: 'info'
+          },
+          // {
+          //   title: '查看视频',
+          //   method: 'openDia',
+          //   type: 'info'
+          // },
+          {
+            title: '通过',
+            method: 'through',
+            type: 'success'
+          },
+          {
+            title: '淘汰',
+            method: 'eliminate',
+            type: 'danger'
+          },
+          {
+            title: '待定',
+            method: 'undetermined',
+            type: 'warning'
+          },
+          {
+            title: '修改',
+            method: 'update',
+            type: 'warning'
+          },
+          {
+            title: '邮件通知',
+            method: 'sendMail',
+            type: 'success'
+          }
         ]
       )
     },

+ 0 - 1
src/views/candidateManage/mailManage.vue

@@ -101,7 +101,6 @@ export default {
         })
         .then((res) => {
           let list = res.list.filter(item => item.useType !== 1)
-          console.log(list[0])
           // this.$set(this.$data, 'form51', list[0] ? list[0] : this.form51)
           // this.$set(this.$data, 'formzl', list[1] ? list[1] : this.formzl)
           // this.$set(this.$data, 'form58', list[2] ? list[2] : this.form58)

+ 288 - 8
src/views/candidateManage/resume.vue

@@ -40,13 +40,13 @@
             <div class="title">简历备注:</div>
             <el-input type="textarea" :rows="4" resize="none" placeholder="请输入内容" v-model="remark"></el-input>
           </div>
-          <div class="footer">
+          <div v-if="!type" class="footer">
             <el-button type="primary" @click="submit">提交备注</el-button>
             <el-button type="danger" @click="through(2)">标记为未通过</el-button>
             <el-button type="success" @click="through(1)">标记为通过</el-button>
           </div>
         </div>
-        <div class="right">
+        <div class="resune">
           <el-form label-width="140px" label-position="right" v-if="info.resumeFrom===3">
             <el-form-item v-for="item in formConfig" :key="item.id" :label="item.configName">
                 <!-- {{item.type === 2 ? ['女', '男'][info[item.fieldName]] : item.type === 8 ? ['女', '男'][info[item.fieldName]] : info[item.fieldName]}} -->
@@ -67,6 +67,95 @@
           </el-form>
           <iframe v-else width="100%" height="100%" :src="$img + info.filePath"></iframe>
         </div>
+        <div class="score" v-if="type">
+          <div class="resume-score">
+            <el-card class="box-card">
+              <el-table
+                :data="resumeScore"
+                style="width: 100%">
+                <el-table-column
+                  prop="label"
+                  label="简历打分"
+                  align="center">
+                </el-table-column>
+                <el-table-column
+                  align="right">
+                  <template slot="header" slot-scope>
+                    <div class="header-color-grounp">
+                      <div class="success"></div>
+                      <div class="warning"></div>
+                      <div class="danger"></div>
+                    </div>
+                  </template>
+                  <template slot-scope="scope">
+                    <div class="content-color-grounp">
+                      <div :class="scope.row.value === 1 && 'success'" @click="changeScore(scope.$index, 1, 'resumeScore')"></div>
+                      <div :class="scope.row.value === 2 && 'warning'" @click="changeScore(scope.$index, 2, 'resumeScore')"></div>
+                      <div :class="scope.row.value === 3 && 'danger'" @click="changeScore(scope.$index, 3, 'resumeScore')"></div>
+                    </div>
+                  </template>
+                </el-table-column>
+              </el-table>
+            </el-card>
+          </div>
+          <div class="interview-score">
+            <el-card class="box-card">
+              <el-table
+                :data="interviewScore"
+                style="width: 100%">
+                <el-table-column
+                  prop="label"
+                  label="面试打分"
+                  align="center">
+                </el-table-column>
+                <el-table-column
+                  align="center">
+                  <template slot="header" slot-scope>
+                    <div class="header-color-grounp">
+                      <div class="success"></div>
+                      <div class="warning"></div>
+                      <div class="danger"></div>
+                    </div>
+                  </template>
+                  <template slot-scope="scope">
+                    <div class="content-color-grounp">
+                      <div :class="scope.row.value === 1 && 'success'" @click="changeScore(scope.$index, 1, 'interviewScore')"></div>
+                      <div :class="scope.row.value === 2 && 'warning'" @click="changeScore(scope.$index, 2, 'interviewScore')"></div>
+                      <div :class="scope.row.value === 3 && 'danger'" @click="changeScore(scope.$index, 3, 'interviewScore')"></div>
+                    </div>
+                  </template>
+                </el-table-column>
+              </el-table>
+            </el-card>
+          </div>
+          <div class="comprehensive">
+            <div class="rate-grounp">
+              综合评分:<el-rate :value="score.totalScore" disabled />
+            </div>
+          </div>
+          <div class="score-form">
+            <el-form :model="score" ref="scoreForm" label-position="top" label-width="80px">
+              <el-form-item label="简历修改建议">
+                <el-input
+                  type="textarea"
+                  resize="none"
+                  placeholder="请输入简历修改建议"
+                  v-model="score.resumePropose" />
+              </el-form-item>
+              <el-form-item label="面试修改建议">
+                <el-input
+                  type="textarea"
+                  resize="none"
+                  placeholder="请输入面试修改建议"
+                  v-model="score.interviewPropose" />
+              </el-form-item>
+            </el-form>
+          </div>
+          <div class="score-footer">
+            <el-button @click="resetForm">重置</el-button>
+            <el-button type="primary" @click="submitForm" style="background: #00a0e9;border-color:#00a0e9">确定</el-button>
+          </div>
+        </div>
       </div>
     </el-dialog>
   </div>
@@ -79,7 +168,58 @@ export default {
       remark: '',
       active: 0,
       formConfig: [],
-      form: {}
+      form: {},
+      score: {},
+      scoreId: null,
+      resumeScore:
+      [
+        {
+          label: '基本背景',
+          value: 0
+        },
+        {
+          label: '教育背景',
+          value: 0
+        },
+        {
+          label: '工作&实习经历',
+          value: 0
+        },
+        {
+          label: '求职意向',
+          value: 0
+        },
+        {
+          label: '技能',
+          value: 0
+        },
+        {
+          label: '自我评价',
+          value: 0
+        },
+        {
+          label: '其他',
+          value: 0
+        }
+      ],
+      interviewScore: [
+        {
+          label: '个人介绍',
+          value: 0
+        },
+        {
+          label: '自我评价',
+          value: 0
+        },
+        // {
+        //   label: '问题',
+        //   value: 0
+        // },
+        {
+          label: '其他',
+          value: 0
+        }
+      ]
     }
   },
   props: {
@@ -87,17 +227,21 @@ export default {
       type: Boolean,
       default: false
     },
+    type: {
+      type: Boolean,
+      default: false
+    },
     close: {
       type: Function,
       default: () => {}
     },
     info: {
       type: Object,
-      default: () => {}
+      default: () => ({})
     },
     searchForm: {
       type: Object,
-      default: () => {}
+      default: () => ({})
     },
     queryData: {
       type: Function,
@@ -152,8 +296,81 @@ export default {
           this.form = res.object
         })
     },
+    getScore (id) {
+      this.$api
+        .post('/resumeScore/queryResumeScore', {
+          reqdata: {
+            resumeId: id
+          }
+        })
+        .then((res) => {
+          const { object } = res
+          const { id, resumePropose, interviewPropose, resumeScore, interviewScore } = object || {}
+          this.score = { resumePropose, interviewPropose }
+          this.scoreId = id
+          this.resumeScore = resumeScore
+            ? JSON.parse(resumeScore)
+            : this.resumeScore.map(item => {
+              item.value = 0
+              return item
+            })
+          // console.log(this.resumeScore)
+          const list = this.interviewScore
+          this.interviewScore = interviewScore
+            ? JSON.parse(interviewScore)
+            : (() => {
+              const num = this.info.answerVideoList ? this.info.answerVideoList.length : 0
+              let arr = []
+              for (let index = 0; index < num; index++) {
+                arr.push(
+                  {
+                    label: '问题' + (index + 1),
+                    value: 0
+                  }
+                )
+              }
+              list.splice(2, 0, ...arr)
+              return list.map(item => {
+                item.value = 0
+                return item
+              })
+            })()
+            // this.interviewScore.map(item => {
+            //   item.value = 0
+            //   return item
+            // })
+            // info.answerVideoList && info.answerVideoList.length
+        })
+    },
     openNewPage (url) {
       window.open(url)
+    },
+    resetForm () {
+      this.score = {}
+      this.resumeScore.forEach(item => (item.value = 0))
+      this.interviewScore.forEach(item => (item.value = 0))
+    },
+    submitForm () {
+      const { score, resumeScore, interviewScore, scoreId } = this
+      const url = scoreId ? '/resumeScore/updateResumeScore' : '/resumeScore/createResumeScore'
+      this.$api
+        .post(url, {
+          reqdata: {
+            ...score,
+            resumeId: this.info.id,
+            interviewScore: JSON.stringify(interviewScore),
+            resumeScore: JSON.stringify(resumeScore),
+            totalScore: 0
+          }
+        })
+        .then((res) => {
+          this.close()
+          this.queryData(this.searchForm)
+        })
+    },
+    changeScore (index, val, arr) {
+      // console.log(index, val)
+      this.$set(this[arr][index], 'value', val)
     }
   },
   watch: {
@@ -164,7 +381,9 @@ export default {
       }
     },
     dialogFormVisible (val) {
+      this.resetForm()
       val || (this.active = 0)
+      this.type && this.getScore(this.info.id)
     }
   }
 }
@@ -175,7 +394,7 @@ export default {
   display: flex;
   justify-content: space-between;
   .left {
-    flex: 1;
+    flex: 3;
     margin-right: 20px;
     .top {
       .title {
@@ -211,9 +430,9 @@ export default {
       justify-content: center;
     }
   }
-  .right {
+  .resune {
     overflow: scroll;
-    width: 770px;
+    flex: 3;
     max-height: 770px;
     iframe {
       border: none;
@@ -221,6 +440,47 @@ export default {
         width: 100%;
       }
     }
+    &::-webkit-scrollbar {
+      width: 0!important;
+    }
+  }
+  .score {
+    flex: 2;
+    .header-color-grounp {
+      display: flex;
+      justify-content: space-between;
+      > div {
+        width: 13px;
+        margin: 0 6px;
+        height: 13px;
+        border-radius: 20px;
+      }
+    }
+    .content-color-grounp {
+      display: flex;
+      justify-content: space-between;
+      > div {
+        cursor: pointer;
+        width: 25px;
+        height: 13px;
+        border-radius: 4px;
+        background: rgba(144, 147, 153, .5);
+      }
+    }
+    .success {
+      background: #67c23a!important;
+    }
+    .warning {
+      background: #e6a23c!important;
+    }
+    .danger {
+      background: #f56c6c!important;
+    }
+    .score-footer {
+      margin-top: 12px;
+      display: flex;
+      justify-content: flex-end;
+    }
   }
 }
 .prompt {
@@ -230,4 +490,24 @@ export default {
   font-size: 20px;
   color: #888;
 }
+.rate-grounp {
+  display: flex;
+  padding: 10px;
+}
+::v-deep .el-table th,::v-deep  .el-table td {
+  padding: 5px 0 !important;
+  font-size: 12px;
+}
+::v-deep .el-card__body {
+  padding: 10px;
+}
+::v-deep .el-card {
+  margin: 5px 0;
+}
+::v-deep .el-form-item {
+  margin: 0;
+}
+::v-deep .el-form-item__label {
+  padding: 0;
+}
 </style>

+ 8 - 5
src/views/candidateManage/resumeList.vue

@@ -17,7 +17,7 @@
         <el-radio-button :label="4">已通知</el-radio-button>
     </el-radio-group><br />
     <el-dropdown v-if="table.button" @command="dropdownMethods">
-        <el-button style="background: #00a0e9;color:#fff">
+        <el-button style="background: #00a0e9;border-color:#00a0e9;color:#fff">
             更多操作<i class="el-icon-arrow-down el-icon--right"></i>
         </el-button>
         <el-dropdown-menu slot="dropdown">
@@ -234,6 +234,10 @@ export default {
         {
           label: '平台',
           value: 3
+        },
+        {
+          label: 'boss直聘',
+          value: 4
         }
         ]
       }
@@ -282,7 +286,7 @@ export default {
         {
           label: '简历来源',
           props: 'resumeFrom',
-          options: ['51job', '智联招聘', '58同城', '平台']
+          options: ['51job', '智联招聘', '58同城', '平台', 'boss直聘']
         },
         {
           label: '投递时间',
@@ -365,7 +369,7 @@ export default {
         {
           label: '简历来源',
           props: 'resumeFrom',
-          options: ['51job', '智联招聘', '58同城', '平台']
+          options: ['51job', '智联招聘', '58同城', '平台', 'boss直聘']
         },
         {
           label: '投递时间',
@@ -443,7 +447,7 @@ export default {
         {
           label: '简历来源',
           props: 'resumeFrom',
-          options: ['51job', '智联招聘', '58同城', '平台']
+          options: ['51job', '智联招聘', '58同城', '平台', 'boss直聘']
         },
         {
           label: '投递时间',
@@ -521,7 +525,6 @@ export default {
     dropdownMethods ({
       method
     }) {
-      console.log(method)
       this[method + 'All']()
     },
     queryData (form = {}) {

+ 0 - 2
src/views/candidateManage/statistics.vue

@@ -148,7 +148,6 @@ export default {
           }
         })
         .then((res) => {
-          console.log(res)
           this.timeList = res.object.weekList || []
           this.clubRecruit = res.object.countList || []
           this.clubTotal = res.object.countTotal
@@ -181,7 +180,6 @@ export default {
             item.name = this.platformList[index]
             return item
           })
-          console.log((this.resumeList[0]))
           this.initChart2()
         })
     },

+ 0 - 6
src/views/companyManage/basicInfo.vue

@@ -103,7 +103,6 @@ export default {
         })
     },
     determine () {
-      console.log(this.form.cmpMailAccount)
       let a
       this.$refs['form'].validate((valid) => {
         a = valid
@@ -144,22 +143,17 @@ export default {
   watch: {
     'form.companyAddress' (val) {
       this.show = this.info.companyAddress !== val
-      console.log(this.info.companyAddress)
     },
     'form.cmpMailAccount' (val) {
-      console.log(this.show)
       this.show = this.email.cmpMailAccount !== val
     },
     'form.cmpMailPassword' (val) {
-      console.log(this.show)
       this.show = this.email.cmpMailPassword !== val
     },
     'form.cmpMailType' (val) {
-      console.log(this.show)
       this.show = this.email.cmpMailType !== val
     },
     'form.companyIntroduce' (val) {
-      console.log(this.show)
       this.show = this.info.companyIntroduce !== val
     },
     'email.cmpMailAccount' (val) {

+ 0 - 4
src/views/companyManage/formManage.vue

@@ -184,10 +184,8 @@ export default {
     }
   },
   created () {
-    console.log(this.options)
     this.queryData()
     this.queryFormConfigList()
-    console.log(this.languageList)
   },
   methods: {
     queryData (form = {}) {
@@ -271,7 +269,6 @@ export default {
       })
     },
     determine () {
-      console.log(this.form)
       let a
       this.$refs['form'].validate((valid) => {
         a = valid
@@ -285,7 +282,6 @@ export default {
       this.form.checkList.forEach(item => {
         array.push(this.formConfigList.find(i => i.id === item))
       })
-      console.log(this.form)
       let url = this.state ? '/form/updateForm' : '/form/saveForm'
       let reqdata = this.form
       reqdata.formConfig = JSON.stringify(Array.from(new Set(array)))

+ 0 - 5
src/views/companyManage/procedureManage.vue

@@ -177,11 +177,9 @@ export default {
         })
     },
     updateActive (item, index, j) {
-      console.log(item, index, j)
       // this.form.questionList[index].active = j
       item.active = j
       this.$set(this.form.questionList, index, item)
-      console.log(this.form.questionList[index].active)
     },
     add () {
       this.open()
@@ -202,7 +200,6 @@ export default {
             item.active = 0
             return item
           })
-          console.log(this.form)
         })
     },
     addVideo () {
@@ -272,7 +269,6 @@ export default {
               b++
               item.id = res.object.id
               // this.form.questionList[this.form.questionList.length - index - 1].id = res.object.id
-              console.log(this.form)
               // console.log(b, num)
               if (b === list.length) {
                 this.determine()
@@ -331,7 +327,6 @@ export default {
         })
       }, 200)
       // this.$forceUpdate()
-      console.log(this.form)
     },
     addDomain () {
       this.form.questionList.push({

+ 0 - 4
src/views/companyManage/templateManage.vue

@@ -83,7 +83,6 @@
 export default {
   data () {
     let validator = (rule, value, callback) => {
-      console.log(rule, value, callback)
       if (!value) {
         return callback(new Error('请输入邀约岗位!'))
       } else if (this.restaurants.map(item => item.value).filter(item => item !== this.form.name).includes(value)) {
@@ -291,7 +290,6 @@ export default {
           .then((res) => {
             num++
             this['downList' + index] = res.list
-            console.log(this['downList' + index])
             num === 3 && this.queryData()
           })
       })
@@ -387,7 +385,6 @@ export default {
         })
     },
     qrCode (row) {
-      console.log(row)
       this.codeForm.templateId = row.id
       this.openDia()
       this.$api
@@ -482,7 +479,6 @@ export default {
       })
     },
     handleSelect (val) {
-      console.log(val)
     },
     open () {
       this.dialogFormVisible = true

+ 0 - 1
src/views/companyManage/videoManage.vue

@@ -136,7 +136,6 @@ export default {
       this.state = 0
     },
     getDetails (row) {
-      console.log(row)
       let reqdata = {
         id: row.id
       }

+ 0 - 1
src/views/index.vue

@@ -80,7 +80,6 @@ export default {
           }
         })
         .then((res) => {
-          console.log(res)
           this.timeList = res.object.weekList || []
           this.clubRecruit = res.object.countList || []
           this.clubTotal = res.object.countTotal

+ 0 - 1
src/views/login.vue

@@ -219,7 +219,6 @@ export default {
               password
             }
           }).then(res => {
-            console.log(res)
             this.$message.success({
               message: '登录成功'
             })

+ 45 - 0
src/views/systemManage/systemInfo.vue

@@ -0,0 +1,45 @@
+<template>
+<div class="passwordSettings">
+    <el-card class="box-card">
+        <el-form ref="form" label-width="140px" label-position="left">
+            <el-form-item label="平台使用期限:">
+                <div>{{info.startTime}} ~ {{info.endTime}}</div>
+            </el-form-item>
+            <el-form-item label="视频使用情况:">
+                <div><span>{{info.usedVideoSize}}</span> /{{info.videoSize}}</div>
+            </el-form-item>
+        </el-form>
+    </el-card>
+</div>
+</template>
+
+<script>
+export default {
+  data () {
+    return {
+      info: {}
+    }
+  },
+  created () {
+    this.querySystemInfo()
+  },
+  methods: {
+    querySystemInfo () {
+      this.$api
+        .post('/companyInfo/querySystemInfo')
+        .then((res) => {
+          this.info = res.object
+        })
+    }
+  }
+}
+</script>
+
+<style lang="scss" scoped>
+
+.box-card {
+    width: 800rpx;
+    padding: 18px 0;
+}
+
+</style>

+ 5 - 0
yarn.lock

@@ -8494,6 +8494,11 @@ vue-hot-reload-api@^2.3.0:
   resolved "https://registry.yarnpkg.com/vue-hot-reload-api/-/vue-hot-reload-api-2.3.4.tgz#532955cc1eb208a3d990b3a9f9a70574657e08f2"
   integrity sha512-BXq3jwIagosjgNVae6tkHzzIk6a8MHFtzAdwhnV5VlvPTFxDCvIttgSiHWjdGoTJvXtmRu5HacExfdarRcFhog==
 
+vue-i18n@^8.21.0:
+  version "8.21.1"
+  resolved "https://registry.npm.taobao.org/vue-i18n/download/vue-i18n-8.21.1.tgz#afa8e6390a5de3b65bd17533c4269181f86f1d61"
+  integrity sha1-r6jmOQpd47Zb0XUzxCaRgfhvHWE=
+
 vue-loader@^15.7.2:
   version "15.8.3"
   resolved "https://registry.yarnpkg.com/vue-loader/-/vue-loader-15.8.3.tgz#857cb9e30eb5fc25e66db48dce7e4f768602a23c"