Jing 1 долоо хоног өмнө
parent
commit
22c87b43c6

+ 252 - 0
src/api/news.js

@@ -152,6 +152,43 @@ export function getJobHuntingData(data) {
     data
   })
 }
+export function updateGoodStatus(data) {
+  return request({
+    url: '/news/updateGoodStatus',
+    method: 'post',
+    data
+  })
+}
+export function updateJobHuntingStatus(data) {
+  return request({
+    url: '/news/updateJobHuntingStatus',
+    method: 'post',
+    data
+  })
+}
+export function updateNoticeStatus(data) {
+  return request({
+    url: '/news/updateNoticeStatus',
+    method: 'post',
+    data
+  })
+}
+export function updateComplaintStatus(data) {
+  return request({
+    url: '/news/updateComplaintStatus',
+    method: 'post',
+    data
+  })
+}
+export function getDUser(data) {
+  return request({
+    url: '/news/getDUser',
+    method: 'post',
+    data
+  })
+  
+}
+
 //20250306求职
 
 
@@ -270,3 +307,218 @@ export function deleteComplaint(data) {
   })
 }
 //20250324  通知,公告,消息
+ //20250422  书刊音像
+
+export function getBookList(data) {
+  return request({
+    url: '/news/getBookList',
+    method: 'post',
+    data:data 
+  })
+}
+export function addBook(data) {
+  return request({
+    url: '/news/addBook',
+    method: 'post',
+    data:data 
+  })
+}
+export function deleteBook(data) {
+  return request({
+    url: '/news/deleteBook',
+    method: 'post',
+    data:data  
+  })
+}
+export function getBookInfo(data) {
+  return request({
+    url: '/news/getBookInfo',
+    method: 'post',
+    data:data 
+  })
+}
+export function updateBook(data) {
+  return request({
+    url: '/news/updateBook',
+    method: 'post',
+    data:data 
+  })
+
+}
+export function updateBookStatus(data) {
+  return request({
+    url: '/news/updateBookStatus',
+    method: 'post',
+    data:data 
+  })
+}
+export function getJobHuntingApply(data) {
+  return request({
+    url: '/news/getJobHuntingApply',
+    method: 'post',
+    data:data 
+  })
+}
+export function myApplyList(data) {
+  return request({
+    url: '/news/myApplyList',
+    method: 'post',
+    data:data 
+  })
+}
+  //20250422  书刊音像
+//招聘列表 start  fr ------------------------------------->
+
+//1.获取职位列表
+export function getJobRecruitingList(params) {
+    return request({
+    url: '/news/getJobRecruitingList',
+    method: 'get',
+    params
+   })
+  }
+  //2.添加职位
+  export function addJobRecruiting(data) {
+    return request({
+    url: '/news/addJobRecruiting',
+    method: 'post',
+    data
+   })
+  }
+  // 3.获取职位详情
+  export function getJobRecruitingInfo(params) {
+    return request({
+    url: '/news/getJobRecruitingInfo',
+    method: 'get',
+    params
+   }) 
+  }
+  //4.修改职位
+  export function upJobRecruiting(data) {
+    return request({
+    url: '/news/upJobRecruiting',
+    method: 'post',
+    data
+   })
+  }
+  // 5.删除职位
+  export function delJobRecruiting(data) {
+    return request({
+    url: '/news/delJobRecruiting',
+    method: 'post',
+    data
+   })
+  }
+  // 6.获取公司信息
+  export function getJobCompany(params) {
+    return request({
+    url: '/news/getJobCompany',
+    method: 'get',
+    params
+   })
+  }
+  // 7.修改公司信息
+  export function upJobCompany(data) {
+    return request({
+    url: '/news/upJobCompany',
+    method: 'post',
+    data
+   }) 
+  }
+  // 2.1 获取行业分类
+  export function getIndustry(params) {
+    return request({
+    url: '/news/getIndustry',
+    method: 'get',
+    params
+   })
+  }
+  //2.2 获取职位分类
+  export function getPositionList(params) {
+    return request({
+    url: '/news/getPositionList',
+    method: 'get',
+    params
+   })
+  }
+  //2.3 获取地区
+  export function getJobRecruitingArea(params) {
+    return request({
+    url: '/news/getJobRecruitingArea',
+    method: 'get',
+    params
+   })
+  }
+  //2.4 获取职位性质
+  export function getJobNature(params) {
+    return request({
+    url: '/news/getJobNature',
+    method: 'get',
+    params
+   })
+  }
+  //2.5 获取工作经验
+  export function getExperience(params) {
+    return request({
+    url: '/news/getExperience',
+    method: 'get',
+    params
+   })
+  }
+  //2.6 获取学历
+  export function getEducation(params) {
+    return request({
+    url: '/news/getEducation',
+    method: 'get',
+    params
+   }) 
+  }
+  //2.7 获取薪资
+  export function getSalary(params) {
+    return request({
+    url: '/news/getSalary',
+    method: 'get',
+    params
+   }) 
+  }
+  //2.8 获取语种
+  export function getLanguage(params) {
+    return request({
+    url: '/news/getLanguage',
+    method: 'get',
+    params
+   }) 
+  }
+  //2.9 获取语言能力
+  export function getLevel(params) {
+    return request({
+    url: '/news/getLevel',
+    method: 'get',
+    params
+   })
+  }
+  //2.10 获取公司规模
+  export function getCompanySize(params) {
+    return request({
+    url: '/news/getCompanySize',
+    method: 'get',
+    params
+   })
+  }
+  //2.11 获取公司性质
+  export function getCompanyNature(params) {
+    return request({
+    url: '/news/getCompanyNature',
+    method: 'get',
+    params
+   })
+  }
+  // 8.修改职位信息状态(审核通过、拒绝、撤回)
+  export function checkJobRecruiting(data) {
+    return request({
+    url: '/news/checkJobRecruiting',
+    method: 'post',
+    data
+   }) 
+  }
+  // 招聘列表 end  fr ------------------------------------->

+ 48 - 0
src/router/index.js

@@ -716,6 +716,54 @@ export const constantRoutes = [
       }
     ]
   },
+  {
+    path: '/addBook',
+    component: Layout,
+    children: [
+      {
+        name: '',
+        path: '',
+        component: () => import('@/views/news/addBook'),
+        meta: {
+          title: '添加书刊音像',
+          hidden: true,
+          breadcrumb: true
+        }
+      }
+    ]
+  },
+  {
+    path: '/bookList',
+    component: Layout,
+    children: [
+      {
+        name: '',
+        path: '',
+        component: () => import('@/views/news/bookList'),
+        meta: {
+          title: '书刊音像列表',
+          hidden: true,
+          breadcrumb: true
+        }
+      }
+    ]
+  },
+  {
+    path: '/bookListApply',
+    component: Layout,
+    children: [
+      {
+        name: '',
+        path: '',
+        component: () => import('@/views/news/bookListApply'),
+        meta: {
+          title: '书刊音像待审核列表',
+          hidden: true,
+          breadcrumb: true
+        }
+      }
+    ]
+  },
 ]
 
 /**

+ 371 - 2
src/store/modules/news.js

@@ -3,7 +3,10 @@ import { getArticleList, addArticle, delArticle, getArticleInfo, updateArticle,
   getGoodInfo, updateGood, websiteList, getWebsiteNavList, getWebsiteNavPool, getWebsiteNavPoolSite,
   getSurveyList,getSurveyInfo, getJobHuntingList, getJobHuntingInfo,addJobHunting,delJobHunting,updateJobHunting,getJobHuntingData,
   getComplaintList,
-  getComplaintInfo, updateComplaint, deleteComplaint,  addComplaint1,  getMSG,  getNoticeList, getNoticeInfo, addNotice, updateNotice, deleteNotice
+  getComplaintInfo, updateComplaint, deleteComplaint,  addComplaint1,    getMSG,  getNoticeList, getNoticeInfo, addNotice, updateNotice, deleteNotice,
+  updateGoodStatus, updateJobHuntingStatus, updateNoticeStatus, updateComplaintStatus,getDUser,
+  getJobRecruitingList, addJobRecruiting,getJobRecruitingInfo, upJobRecruiting, delJobRecruiting,getIndustry, getJobCompany, upJobCompany, getPositionList, getJobRecruitingArea, getJobNature, getExperience, getEducation, getSalary, getLanguage, getLevel, getCompanySize, getCompanyNature,checkJobRecruiting,
+  getBookList, getBookInfo, addBook, deleteBook, updateBook, updateBookStatus ,getJobHuntingApply ,myApplyList
 } from '@/api/news'
 
 const state = {
@@ -209,6 +212,107 @@ const actions = {
       })
     })
   },
+  updateGoodStatus
+  ({ commit }, data)  {
+    return new Promise((resolve, reject) => {
+      updateGoodStatus(data).then(response => {
+        resolve(response)
+      }).catch(error => {
+        reject(error)
+      })
+    })
+  },
+  updateJobHuntingStatus
+  ({ commit }, data)  {
+    return new Promise((resolve, reject) => {
+      updateJobHuntingStatus(data).then(response => {
+        resolve(response)
+      }).catch(error => {
+        reject(error)
+      })
+    })
+  },
+  updateNoticeStatus
+  ({ commit }, data)  {
+    return new Promise((resolve, reject) => {
+      updateNoticeStatus(data).then(response => {
+        resolve(response)
+      }).catch(error => {
+        reject(error)
+      })
+    })
+
+  }
+  ,
+  updateComplaintStatus
+  ({ commit }, data)  {
+    return new Promise((resolve, reject) => {
+      updateComplaintStatus(data).then(response => {
+        resolve(response)
+      }).catch(error => {
+        reject(error)
+      })
+    })
+  },
+  getComplaintList({ commit }, data) {
+    return new Promise((resolve, reject) => {
+      getComplaintList(data).then(response => {
+        resolve(response)
+      }).catch(error => {
+        reject(error)
+      })
+    }) 
+  }
+,
+  getComplaintInfo({ commit }, data) {
+    return new Promise((resolve, reject) => {
+      getComplaintInfo(data).then(response => {
+        resolve(response)
+      }).catch(error => {
+        reject(error)
+      })
+    })
+  },
+  updateComplaint({ commit }, data) {
+   
+    return new Promise((resolve, reject) => {
+      updateComplaint(data).then(response => {
+        resolve(response)
+      }).catch(error => {
+        reject(error)
+ 
+      }) 
+    })
+  }
+,
+  deleteComplaint({ commit }, data) {
+    return new Promise((resolve, reject) => {
+      deleteComplaint(data).then(response => {
+        resolve(response)
+      }).catch(error => {
+        reject(error)
+      })
+    })
+  },
+  addComplaint({ commit }, data) {
+    
+    return new Promise((resolve, reject) => {
+      addComplaint(data).then(response => {
+        resolve(response)
+      }).catch(error => {
+        reject(error)
+      })
+    })
+  },
+  getDUser({ commit }, data) {
+    return new Promise((resolve, reject) => {
+      getDUser(data).then(response => {
+        resolve(response)
+      }).catch(error => {
+        reject(error)
+      })
+    })
+  },
   //20250306  求职信息
 
 
@@ -360,7 +464,272 @@ const actions = {
     })
   },
   //20250324  通知,公告,消息
-
+   //20250422  书刊音像
+   getBookList({commit},data) {
+    return new Promise((resolve, reject) => {
+      getBookList(data).then(response => {
+        resolve(response)
+      }).catch(error => {
+        reject(error)
+      })
+    })
+  },
+  getBookInfo({commit},data) {
+    return new Promise((resolve, reject) => {
+      getBookInfo(data).then(response => {
+        resolve(response)
+      }).catch(error => {
+        reject(error)
+      })
+    })
+  },
+  addBook({commit},data) {
+    return new Promise((resolve, reject) => {
+      addBook(data).then(response => {
+        resolve(response)
+      }).catch(error => {
+        reject(error)
+      })
+    })
+  },
+  deleteBook({commit},data) {
+    return new Promise((resolve, reject) => {
+      deleteBook(data).then(response => {
+        resolve(response)
+      }).catch(error => {
+        reject(error)
+      })
+    })
+  },
+  updateBook({commit},data) {
+    return new Promise((resolve, reject) => {
+      updateBook(data).then(response => {
+        resolve(response)
+      }).catch(error => {
+        reject(error)
+      })
+    })
+  },
+  updateBookStatus({commit},data) {
+    return new Promise((resolve, reject) => {
+      updateBookStatus(data).then(response => {
+        resolve(response)
+      }).catch(error => {
+        reject(error)
+      })
+    })
+  },
+  getJobHuntingApply({commit},data) {
+    return new Promise((resolve, reject) => {
+      getJobHuntingApply(data).then(response => {
+        resolve(response)
+      }).catch(error => {
+        reject(error)
+      })
+    })
+  },
+  myApplyList({commit},data) {
+    return new Promise((resolve, reject) => {
+      myApplyList(data).then(response => {
+        resolve(response)
+      }).catch(error => {
+        reject(error)
+      })
+    })
+  },
+    //20250422  书刊音像
+  //招聘列表 start  fr ------------------------------------->
+  //1.获取职位列表
+  getJobRecruitingList({commit},data) {
+        return new Promise((resolve, reject) => {
+          getJobRecruitingList(data).then(response => {
+            resolve(response)
+          }).catch(error => {
+            reject(error)
+          })
+        })
+      },
+      //2.添加职位
+      addJobRecruiting({commit},data) {
+        return new Promise((resolve, reject) => {
+          addJobRecruiting(data).then(response => {
+            resolve(response)
+          }).catch(error => {
+            reject(error)
+          })
+        })
+      },
+      // 3.获取职位详情
+      getJobRecruitingInfo({commit},data) {
+        return new Promise((resolve, reject) => {
+          getJobRecruitingInfo(data).then(response => {
+            resolve(response)
+          }).catch(error => {
+            reject(error)
+          })
+        })
+      },
+      //4.修改职位
+      upJobRecruiting({commit},data) {
+        return new Promise((resolve, reject) => {
+          upJobRecruiting(data).then(response => {
+            resolve(response)
+          }).catch(error => {
+            reject(error)
+          })
+        }) 
+      },
+      // 5.删除职位
+      delJobRecruiting({commit},data) {
+        return new Promise((resolve, reject) => {
+          delJobRecruiting(data).then(response => {
+            resolve(response)
+          }).catch(error => {
+            reject(error)
+          })
+        })
+      },
+      // 6.获取公司信息
+      getJobCompany({commit},data) {
+        return new Promise((resolve, reject) => {
+          getJobCompany(data).then(response => {
+            resolve(response)
+          }).catch(error => {
+            reject(error)
+          })
+        }) 
+      },
+      // 7.修改公司信息
+      upJobCompany({commit},data) {
+        return new Promise((resolve, reject) => {
+          upJobCompany(data).then(response => {
+            resolve(response)
+          }).catch(error => {
+            reject(error)
+          })
+        })
+      },
+      // 2.0 获取行业
+      getIndustry({commit},data) {
+        return new Promise((resolve, reject) => {
+          getIndustry(data).then(response => {
+            resolve(response)
+          }).catch(error => {
+            reject(error)
+          })
+        })
+      },
+      // 2.1 获取职位分类
+      getPositionList({commit},data) {
+        return new Promise((resolve, reject) => {
+          getPositionList(data).then(response => {
+            resolve(response)
+          }).catch(error => {
+            reject(error)
+          })
+        })
+      },
+      // 2.2 获取工作区域
+      getJobRecruitingArea({commit},data) {
+        return new Promise((resolve, reject) => {
+          getJobRecruitingArea(data).then(response => {
+            resolve(response) 
+          }) .catch(error => {
+            reject(error)
+          })
+        }) 
+      },
+      // 2.3 获取工作性质
+      getJobNature({commit},data) {
+        return new Promise((resolve, reject) => {
+          getJobNature(data).then(response => {
+            resolve(response)
+          }).catch(error => {
+            reject(error)
+          })
+        })
+      },
+      // 2.4 获取工作经验
+      getExperience({commit},data) {
+        return new Promise((resolve, reject) => {
+          getExperience(data).then(response => {
+            resolve(response) 
+          }) .catch(error => {
+            reject(error)
+          })
+        }) 
+      },
+      // 2.5 获取教育程度
+      getEducation({commit},data) {
+        return new Promise((resolve, reject) => {
+          getEducation(data).then(response => {
+            resolve(response)
+          }).catch(error => {
+            reject(error)
+          })
+        })
+      },
+      // 2.6 获取薪资
+      getSalary({commit},data) {
+        return new Promise((resolve, reject) => {
+          getSalary(data).then(response => {
+            resolve(response)
+          }).catch(error => {
+            reject(error)
+          })
+        })
+      },
+      // 2.7 获取语言
+      getLanguage({commit},data) {
+        return new Promise((resolve, reject) => {
+          getLanguage(data).then(response => {
+            resolve(response) 
+          }) .catch(error => {
+            reject(error)
+          })
+        }) 
+      },
+      // 2.8 获取级别
+      getLevel({commit},data) {
+        return new Promise((resolve, reject) => {
+          getLevel(data).then(response => {
+            resolve(response)
+          }).catch(error => {
+            reject(error)
+          })
+        })
+      },
+      // 2.9 获取公司规模
+      getCompanySize({commit},data) {
+        return new Promise((resolve, reject) => {
+          getCompanySize(data).then(response => {
+            resolve(response) 
+          }) .catch(error => {
+            reject(error)
+          })
+        }) 
+      },
+      // 2.10 获取公司性质
+      getCompanyNature({commit},data) {
+        return new Promise((resolve, reject) => {
+          getCompanyNature(data).then(response => {
+            resolve(response)
+          }).catch(error => {
+            reject(error)
+          })
+        })
+      },
+      // 8.修改职位信息状态(审核通过、拒绝、撤回)
+      checkJobRecruiting({commit},data) {
+        return new Promise((resolve, reject) => {
+          checkJobRecruiting(data).then(response => {
+            resolve(response)
+          }).catch(error => {
+            reject(error)
+          })
+        })
+      },
+      // 招聘列表 end  fr ------------------------------------->
 }
 
 

+ 4 - 4
src/views/menu/menulist.vue

@@ -37,7 +37,7 @@
             <el-table-column fixed="right" label="操作" width="200"  header-align="center">
               <template slot-scope="scope">
                 <div class="listBtnBox">
-                  <div class="listDeleteBtn" @click="deleteRow(scope.row.id)"><i class="el-icon-delete"></i>除</div>
+                  <div class="listDeleteBtn" @click="deleteRow(scope.row.id)"><i class="el-icon-delete"></i>除</div>
                   <div class="listEditBtn" @click="editRow(scope.row)"><i class="el-icon-edit-outline"></i>编辑</div>
                 </div>
               </template>
@@ -65,7 +65,7 @@
           <el-form-item label="父级菜单名称" :label-width="formLabelWidth" prop="pid_arr" class="custom-align-right" v-if="radio === '2'">
             <el-cascader :key="parentKey" v-model="form.pid_arr" :props="{checkStrictly:true}" :options="pidArrData" clearable></el-cascader>
           </el-form-item>
-          <el-form-item label="默认图标" :label-width="formLabelWidth" prop="icon" class="custom-align-right">
+          <el-form-item label="默认图标" :label-width="formLabelWidth" prop="icon" class="custom-align-right" v-if="radio == '1'">
              <!--图片上传组件 start ------------------------------------------------------------>
               <div class="uploaderBox">
                 <div class="avatar-upload-container" @mouseenter="hovering = true" @mouseleave="hovering = false">
@@ -88,7 +88,7 @@
               </div>
               <!--图片上传组件 end ------------------------------------------------------------>
           </el-form-item>
-          <el-form-item label="选中时图标" :label-width="formLabelWidth" prop="selected_icon" class="custom-align-right">
+          <el-form-item label="选中时图标" :label-width="formLabelWidth" prop="selected_icon" class="custom-align-right" v-if="radio == '1'">
             <!--图片上传组件 start ------------------------------------------------------------>
             <div class="uploaderBox">
               <div class="avatar-upload-container" @mouseenter="hoveringTwo = true" @mouseleave="hoveringTwo = false">
@@ -252,7 +252,7 @@ export default {
           }else{
             this.$message({
               type: 'warning',
-              message: '请先除子菜单!'
+              message: '请先除子菜单!'
             });
           }
         }).catch(() => {

+ 20 - 3
src/views/news/GoodList.vue

@@ -99,9 +99,13 @@
 
             <el-table-column prop="updated_at" label="修改时间" width=""></el-table-column>
 
-            <el-table-column fixed="right" label="操作" width="200" header-align="center">
+            <el-table-column fixed="right" label="操作" width="300" header-align="center">
               <template slot-scope="scope">
                 <div class="listBtnBox">
+
+                  <div class="listUpBtn" @click="returnRow(scope.row.id, tableData)"><i
+                      class="el-icon-refresh-right"></i>撤回</div>
+
                   <div class="listDeleteBtn" @click="deleteRow(scope.row.id, tableData)"><i
                       class="el-icon-delete"></i>删除
                   </div>
@@ -133,6 +137,8 @@
 <script>
 //表格标题
 import tableTitle from './components/tableTitle';
+import { getUseType } from '@/utils/auth'
+
 //引入公用样式
 import '@/styles/global.less';
 
@@ -162,7 +168,17 @@ export default {
     }
   },
   methods: {
-    //1.列表和分页相关 start ------------------------------------------------------------>
+    //1.列表和分页相关 start ------------------------------------------------------------>  
+    returnRow(id) {
+      this.$confirm('确定要撤回吗?', '提示', {
+        confirmButtonText: '撤回',
+        cancelButtonText: '取消',
+        type: 'warning'
+      }).then(() => {
+        //撤回,把文章状态修改为0,重新进行审核
+        this.upRow(id, 1)
+      })
+    },
     //1.1 开始请求列表信息方法
     getData(type) {
       if (type == "search") {
@@ -224,12 +240,13 @@ export default {
         id: id,
         status: status
       }
-      this.$store.dispatch('news/upArticleStatus', data).then(res => {
+      this.$store.dispatch('news/updateGoodStatus', data).then(res => {
         if (res.code == 200) {
           this.$message({
             type: 'success',
             message: '商品状态已修改!'
           });
+          this.getData();
         }
       }).catch(() => {
         this.$message({

+ 830 - 0
src/views/news/addBook.vue

@@ -0,0 +1,830 @@
+<template>
+
+
+  <div class="mainBox">
+    <div class="layerBox">
+      <tableTitle :name="tableDivTitle" />
+      <el-form :model="form" ref="form" :rules="formRules" label-position="left" label-width="135px">
+        <div class="formDiv">
+
+          <el-form-item label="站点名称:" prop="website_id" class="custom-align-right" v-if="userType == 10000">
+            <el-select v-model="form.website_id" placeholder="请选择站点名称" filterable clearable>
+              <el-option v-for="item in websiteOptions" :key="item.value" :label="item.label" :value="item.value">
+              </el-option>
+            </el-select>
+          </el-form-item>
+
+          <el-form-item label="展示名称:" prop="cat_arr_id" class="custom-align-right">
+            <el-cascader :key="parentKey" v-model="form.cat_arr_id" placeholder="请选择要绑定的展示名称" :props="parentData"
+              filterable clearable></el-cascader>
+          </el-form-item>
+          <el-form-item label="书刊音像标题:" prop="title" class="custom-align-right">
+            <el-input v-model="form.title" autocomplete="off" placeholder="请输入书刊音像标题"></el-input>
+          </el-form-item>
+          <el-form-item label="行政区划:" prop="city_arr_id" class="custom-align-right">
+            <el-cascader :key="cascaderKey" v-model="form.city_arr_id" placeholder="请选择行政区划" :props="cityData"
+              filterable clearable></el-cascader>
+          </el-form-item>
+          <!-- <el-form-item label="行政职能:" prop="department_arr_id" class="custom-align-right">
+            <el-cascader :key="searchDepartmentKey" v-model="form.department_arr_id" placeholder="请选择行政职能"
+              popper-class="my_cascader" :props="searchDepartmentData" filterable clearable></el-cascader>
+          </el-form-item> -->
+
+          <el-form-item label="市场价:" prop="price" class="custom-align-right">
+            <el-input type="number" v-model="form.price" autocomplete="off" placeholder="请输入商品单价">
+              <template #suffix>
+                元
+              </template>
+            </el-input>
+          </el-form-item>
+          <el-form-item label="现售价:" prop="market_price" class="custom-align-right">
+            <el-input type="number" v-model="form.market_price" autocomplete="off" placeholder="请输入现售价">
+              <template #suffix>
+                元
+              </template>
+            </el-input>
+          </el-form-item>
+          <el-form-item label="页数:" prop="page" class="custom-align-right">
+            <el-input type="number" v-model="form.page" autocomplete="off" placeholder="请输入页数">
+            </el-input>
+          </el-form-item>
+
+          <el-form-item label="开本:" prop="format" class="custom-align-right">
+            <el-input v-model="form.format" autocomplete="off" placeholder="请输入开本">
+            </el-input>
+          </el-form-item>
+          <el-form-item label="纸张:" prop="paper" class="custom-align-right">
+            <el-input v-model="form.paper" autocomplete="off" placeholder="请输入纸张">
+            </el-input>
+          </el-form-item>
+          <el-form-item label="包装:" prop="package" class="custom-align-right">
+            <el-input v-model="form.package" autocomplete="off" placeholder="请输入包装">
+            </el-input>
+          </el-form-item>
+          <el-form-item label="出版社:" prop="publishing_house" class="custom-align-right">
+            <el-input v-model="form.publishing_house" autocomplete="off" placeholder="请输入出版社">
+            </el-input>
+          </el-form-item>
+
+          <el-form-item label="出版时间:" prop="publish_" class="custom-align-right">
+            <el-date-picker v-model="form.publish_time" placeholder="请选择出版时间">
+            </el-date-picker>
+          </el-form-item>
+          <el-form-item label="ISBN:" prop="ISBN" class="custom-align-right">
+            <el-input v-model="form.ISBN" autocomplete="off" placeholder="请输入ISBN">
+            </el-input>
+          </el-form-item>
+
+          <el-form-item label="国内统一刊号CN:" prop="CN" class="custom-align-right">
+            <el-input v-model="form.CN" autocomplete="off" placeholder="请输入国内统一刊号CN">
+            </el-input>
+          </el-form-item>
+          <el-form-item label="缩略图:" class="custom-align-right" prop="">
+            <div class="uploaderBox" @mouseenter="hovering = true" mouseleave="hovering = false">
+              <el-upload class="avatar-uploader" action="#" :show-file-list="false" :before-upload="beforeAvatarUpload">
+                <!-- 预览图片 -->
+                <img v-if="img_url" :src="img_url" class="avatar">
+                <div v-else class="chooseImgDiv">
+                  <div>
+                    <img src="@/assets/public/upload/noImage.png">
+                    <div>选择图片</div>
+                  </div>
+                </div>
+              </el-upload>
+              <input type="hidden" v-model="form.img_url">
+              <span class="photo_tips">推荐图片长宽比例为 3:4,大小不能超过 500 K。</span>
+              <div v-if="hovering && img_url" class="delete-button" @click="handleDelete">
+                <i class="el-icon-delete"></i>
+              </div>
+            </div>
+          </el-form-item>
+
+
+          <el-form-item label="商品关键词:" prop="keyword" class="custom-align-right">
+            <template #label>
+              <span class="askBox">
+                商品关键词:
+                <el-tooltip class="item" effect="dark" content="商品关键词,如:三农市场网、全国三农、信息一体化。" placement="top">
+                  <i class="el-icon-question"></i>
+                </el-tooltip>
+              </span>
+            </template>
+            <tagInput :initialTags="tags" @tags-updated="updateTags"></tagInput>
+          </el-form-item>
+          <el-form-item label="商品描述:" prop="description" class="custom-align-right">
+            <el-input v-model="form.description" maxlength="300" autocomplete="off" placeholder="请输入商品描述"
+              type="textarea" :rows="10"></el-input>
+          </el-form-item>
+          <el-form-item label="是否为原创:" prop="is_original" class="custom-align-right">
+            <el-radio-group v-model="form.is_original" @change="changeIsOriginal">
+              <el-radio :label="1">是</el-radio>
+              <el-radio :label="0">否</el-radio>
+            </el-radio-group>
+          </el-form-item>
+          <div v-if="form.is_original == 0">
+            <el-form-item label="来源名称:" prop="source" class="custom-align-right">
+              <el-input v-model="form.source" autocomplete="off" placeholder="请输入来源名称"></el-input>
+            </el-form-item>
+            <el-form-item label="来源链接:" prop="source_url" class="custom-align-right">
+              <el-input v-model="form.source_url" autocomplete="off" placeholder="请输入来源链接"></el-input>
+            </el-form-item>
+            <div class="disclaimerBox">
+              <div class="disclaimerTitle">
+                <img src="@/assets/public/check.png" />同意《免责声明》:
+              </div>
+              <div class="disclaimerText">
+                本文来源于网络转载,仅供学习交流使用,不构成商业目的。版权归原作者所有,如涉及作品内容、版权和其他问题,请在30日内与本站联系,我们将在第一时间处理。</div>
+            </div>
+          </div>
+          <div v-if="form.is_original == 1">
+            <el-form-item label="来源名称:" prop="source" class="custom-align-right">
+              <el-input v-model="form.source" autocomplete="off" placeholder="请输入来源名称" disabled="disabled"></el-input>
+            </el-form-item>
+          </div>
+
+          <el-form-item label="详情说明:" prop="detail" class="custom-align-right">
+            <!--这里是富文本-->
+            <myEditor ref="myEditor" v-model="form.detail"></myEditor>
+          </el-form-item>
+
+
+
+
+        </div>
+      </el-form>
+    </div>
+    <div class="bottomBtnBox" v-if="readStatus == false">
+      <el-button type="info" @click="returnPage">返回</el-button>
+      <el-button type="primary" @click="editToServe" v-if="editStatus == true">确定</el-button>
+      <el-button type="primary" @click="addToServe" v-else>发布</el-button>
+    </div>
+  </div>
+</template>
+
+<script>
+//表格标题
+import tableTitle from './components/tableTitle';
+//引入公用样式
+import '@/styles/global.less';
+//引入富文本编辑器
+import myEditor from '../../components/edit/myEditor.vue';
+//引入tag标签组件
+import tagInput from '../../components/InputTag/index.vue';
+
+//格式化时间
+import { formatLocalDate } from '@/utils/public';
+
+export default {
+  components: {
+    tableTitle,
+    myEditor,
+    tagInput
+  },
+  data() {
+    //0.全局操作 start ------------------------------------------------------------>
+    //表单验证
+    const validateNull = (rule, value, callback) => {
+      console.log(value, '-------------------------------')
+      if (value == '' || value == undefined || value == null) {
+        callback(new Error('该项不能为空!'))
+      } else {
+        callback()
+      }
+    }
+    const validateEmpty = (rule, value, callback) => {
+      console.log(value, '-------------------------------')
+      if (value.length == 0) {
+        callback(new Error('该项不能为空!'))
+      } else {
+        callback()
+      }
+    }
+    const validateArray = (rule, value, callback) => {
+      if (value.length == 0) {
+        callback(new Error('该项不能为空!'))
+      } else {
+        callback()
+      }
+    }
+    const validateRadio = (rule, value, callback) => {
+      if (value != '1' || value != '0') {
+        callback()
+      } else {
+        callback()
+      }
+    }
+    let self = this;
+    //0.全局操作 end ------------------------------------------------------------>
+    return {
+      websiteOptions: [], //网站列表
+      formLabelWidth: '80px',//表单的长度
+      //1.表单项 start ------------------------------------------------------------>
+      editStatus: false,
+      readStatus: false,
+      tableDivTitle: "添加书刊音像",
+      searchCascaderKey: 0, //列表缓存key
+      hovering: false, // 鼠标悬浮状态 悬浮时显示删除
+      website_id: '', //网站id,
+      file: '',
+      userType: 1, //用户类型 1:普通用户,
+      img_url: '', //图片路径
+      pickerOptions: {
+        selectableRange: '1900-01-01 to 2100-12-31', // 允许选择的日期范围
+      },
+      tags: [], // 存储标签的数q
+
+      //提交表单
+      form: {
+        //1.1使用了外链
+        title: '',//书刊音像标题
+        price: '',//市场价
+        market_price: '',//现售价
+        page: '',//页数
+        format: '',//开本
+        paper: '',//纸张
+        package: '',//包装
+        publishing_house: '',//出版社
+        publish_time: '',//出版时间
+        ISBN: '',//ISBN
+        CN: '',//国内统一刊号CN
+        img_url: '',//缩略图路径
+        city_arr_id: [],//行政区划
+        city_id: '',//城市id
+        detail: "",
+        // department_arr_id: [],//部门id
+        // department_id: '',//部门id
+        website_id: '',//网站id
+        cat_arr_id: [],//导航池id
+        cat_id: '',//导航池id
+        description: '',//商品描述
+        keyword: [],//商品关键词
+        is_original: 1,//是否为原创 0非 1是
+        source: "本网",//来源名称
+        source_url: "",//来源地址
+        status: 0,//状态 0待发布 1已发布 404已删除  如果是普通用户,这里始终为0
+      },
+      //1.2 表单验证规则
+      formRules: {
+        title: [{ required: true, trigger: 'blur', validator: validateEmpty }],
+        type: [{ required: true, trigger: 'blur', validator: validateEmpty }],
+        city_arr_id: [{ required: true, trigger: 'blur', validator: validateArray }],
+        // department_arr_id: [{ required: true, trigger: 'blur', validator: validateArray }],
+        address: [{ required: true, trigger: 'blur', validator: validateEmpty }],
+        website_id: [{ required: true, trigger: 'blur', validator: validateEmpty }],
+        cat_arr_id: [{ required: true, trigger: 'blur', validator: validateArray }],
+        //是否原创不能为空
+        is_original: [{ required: true, trigger: 'blur', validator: validateRadio }],
+        //来源名称和地址不能为空
+        source: [{ required: true, trigger: 'blur', validator: validateEmpty }],
+        source_url: [{ required: true, trigger: 'blur', validator: validateEmpty }],
+      },
+      //1.3富文本编辑器配置
+      showHtml: false, //用于保存源码内容
+      editorHtml: '',
+      cascaderKey: 0,//弹窗用的key
+      websiteData: {
+        lazy: true,
+        checkStrictly: true,
+        async lazyLoad(node, resolve) {
+          const { level, data } = node;
+          if (data && data.children && data.children.length !== 0) {
+            return resolve(node)
+          }
+          console.log(level)
+          let parentId = level == 0 ? 0 : data.value
+          let parames = {
+            'page': 1,
+            'pageSize': 1000,
+          }
+          self.$store.dispatch('news/websiteList', parames).then(res => {
+            if (res.data) {
+              const nodes = res.data.rows.map(item => ({
+                value: item.id,
+                label: item.website_name,
+                leaf: level >= 3,
+                children: []
+              }))
+              console.log(nodes, 'leaf')
+              resolve(nodes)
+            }
+          })
+        },
+      },
+
+      cityData: {
+        checkStrictly: true,
+        lazy: true,
+        async lazyLoad(node, resolve) {
+          const { level, data } = node;
+          if (data && data.children && data.children.length !== 0) {
+            return resolve(node)
+          }
+          console.log(level, '====level-----')
+          let parentId = level == 0 ? 0 : data.value
+          let parames = {
+            'pid': parentId
+          }
+          self.$store.dispatch('pool/getcityList', parames).then(res => {
+            if (res.data) {
+              const nodes = res.data.map(item => ({
+                value: item.id,
+                label: item.name,
+                leaf: level >= 3,
+                children: []
+              }))
+              resolve(nodes)
+            }
+          })
+        }
+      },
+
+
+      //获取父级导航池
+      parentKey: 0,//获取父级导航
+      parentData: {
+        checkStrictly: true,
+        lazy: true,
+        async lazyLoad(node, resolve) {
+          console.log(resolve, 'node')
+          const { level, data } = node;
+          if (data && data.children && data.children.length !== 0) {
+            return resolve(node)
+          }
+          console.log(level, 'level--1--');
+          let pid = level == 0 ? 0 : data.value
+          let website_id = self.form.website_id == '' ? 2 : self.form.website_id;
+          console.log(website_id, 'website_id--111-----');
+          let parames = {
+            'website_id': website_id,
+            'pid': pid
+          }
+          self.$store.dispatch('news/getWebsiteNavList', parames).then(res => {
+            if (res.data) {
+              const nodes = res.data.map(item => ({
+                value: item.category_id,
+                label: item.name,
+                leaf: level >= 3,
+                children: []
+              }))
+              resolve(nodes)
+            } else {
+              //输出报错原因
+              console.log(res.msg, 'getWebsiteNavList--1--');
+
+            }
+          })
+        }
+      },
+      //行政职能部门
+      searchDepartmentKey: 0, //列表缓存key
+      searchDepartmentData: {
+        checkStrictly: true,
+        lazy: true,
+        async lazyLoad(node, resolve) {
+          const { level, data } = node;
+          if (data && data.children && data.children.length !== 0) {
+            return resolve(node)
+          }
+          console.log(level)
+          let parentId = level == 0 ? 0 : data.value
+          let parames = {
+            'pid': parentId
+          }
+          self.$store.dispatch('pool/getDepartment', parames).then(res => {
+            if (res.data) {
+              const nodes = res.data.map(item => ({
+                value: item.id,
+                label: item.name,
+                leaf: level >= 3,
+                children: []
+              }))
+              resolve(nodes)
+            }
+          })
+        }
+      },
+      inputList: [
+        { value: '' }
+      ]
+      //表单项 end ------------------------------------------------------------>
+    };
+  },
+  methods: {
+    //获取行政人员
+    async fetchWebsiteOptions() {
+      try {
+        const response = await this.$store.dispatch('news/websiteList', { page: 1, pageSize: 1000 });
+        if (response && response.data) {
+          this.websiteOptions = response.data.rows.map(item => ({
+            value: item.id,
+            label: item.website_name,
+          }));
+        }
+      } catch (error) {
+        console.error('获取网站列表失败:', error);
+      }
+    },
+    //获取用户身份信息
+    getUserInfo() {
+      this.$store.dispatch('public/getInfo').then(res => {
+        console.log(res)
+        this.userType = res.data.type_id;
+
+        //个人会员=1 政务会员=2 企业会员=3 调研员=4 管理员=10000 游客=20000
+      }).catch(() => {
+        this.$message({
+          type: 'info',
+          message: '网络错误,请重试!'
+        });
+      })
+    },
+    //1.提交表单 start ------------------------------------------------------------>
+    beforeAvatarUpload(file) {
+      const isJPG = file.type === 'image/jpeg';
+      const isPNG = file.type === 'image/png';
+      const isLt2M = file.size / 1024 / 1024 < 2;
+      if (!isJPG && !isPNG) {
+        this.$message.error('上传缩略图只能是 JPG 或 PNG 格式!');
+        return false;
+      }
+      if (!isLt2M) {
+        this.$message.error('上传缩略图大小不能超过 2MB!');
+        return false;
+      }
+      const formData = new FormData();
+      formData.append('file', file);
+      this.$store.dispatch('pool/uploadFile', formData).then(res => {
+        this.img_url = res.data.imgUrl;//显示缩略图
+        this.form.img_url = res.data.imgUrl;//提供表单地址
+        console.log(res.data.imgUrl)
+      }).catch(() => {
+        this.$message({
+          type: 'info',
+          message: '网络错误,请重试!'
+        });
+      })
+      // 阻止默认的上传行为
+      return false;
+    },
+    deleteImage(index) { // 删除图片
+      this.file.splice(index, 1);
+    },
+    //1.2 提交表单
+    addToServe() {
+      //先进行验证
+      this.$refs.form.validate(valid => {
+        if (valid) {
+          if (this.form.publish_time) {
+            this.form.publish_time = formatLocalDate(this.form.publish_time);
+          }
+          // if (this.form.department_arr_id.length == 0) {
+          //   this.form.department_id = 0;
+          // }
+          if (this.form.city_arr_id.length == 0) {
+            this.form.city_id = 0;
+          }
+          if (this.form.cat_arr_id.length == 0) {
+            this.form.cat_id = 0;
+          }
+          if (typeof this.form.city_arr_id == 'object') {
+            this.form.city_id = this.form.city_arr_id.at(-1) || 0;
+          }
+          if (typeof this.form.department_arr_id == 'object') {
+            this.form.department_id = this.form.department_arr_id.at(-1) || 0;
+          }
+          if (typeof this.form.cat_arr_id == 'object') {
+            this.form.cat_id = this.form.cat_arr_id.at(-1) || 0;
+          }
+          if (this.userType == 10000) {
+            this.form.status = 2
+          } else {
+            this.form.status = 1
+          }
+          this.form.price == '' ? this.form.price = 0 : this.form.price = this.form.price;
+          this.form.market_price == '' ? this.form.market_price = 0 : this.form.market_price = this.form.market_price;
+          this.form.page == '' ? this.form.page = 0 : this.form.page = this.form.page;
+          this.$store.dispatch('news/addBook', this.form).then(res => {
+            if (res.code == 200) {
+              //汇报结果
+              if (this.userType == 10000) {
+                this.$message({
+                  type: 'success',
+                  message: '已成功添加书刊音像!'
+                });
+                //返回列表页
+                this.returnPage()
+              } else {
+                this.$message({
+                  type: 'success',
+                  message: '待管理员审核!'
+                });
+                //返回列表页
+                this.returnPage()
+              }
+              this.cleatForm();
+            } else {
+              this.$message({
+                type: 'error',
+                message: "书刊音像发布失败,请稍后再试!"
+              });
+            }
+          })
+        }
+      })
+    },
+    formatDate(date) {
+      if (date instanceof Date) {
+        return date.toISOString().slice(0, 19).replace('T', ' ');
+      } else if (typeof date === 'string') {
+        // 将 ISO 8601 格式的字符串转换为 MySQL 期望的格式
+        const parsedDate = new Date(date);
+        return parsedDate.toISOString().slice(0, 19).replace('T', ' ');
+      } else {
+        return date;
+      }
+    },
+    //1.3 清理表单
+    cleatForm() {
+    },
+    //1.4 修改是否原创
+    changeIsOriginal() {
+      if (this.form.is_original == 1) {
+        this.form.source = "本网";
+      } else {
+        this.form.source = "";
+        this.form.source_url = "";
+      }
+    },
+    //提交表单 end ------------------------------------------------------------>
+
+    //2.跳转操作 start ------------------------------------------------------------>
+    returnPage() {
+      this.$router.push({
+        path: '/bookList',
+      });
+    },
+    //跳转操作 end ------------------------------------------------------------>
+
+    //3.回显操作 ------------------------------------------------------------>
+    //3.1回显数据
+    getMainData() {
+      let data = {
+        id: this.$route.query.id
+      };
+      this.$store.dispatch('news/getBookInfo', data).then(res => {
+        console.log(res);
+        this.form.name = res.data.name;
+        // 回显导航池
+        this.form.cat_arr_id = Array.isArray(res.data.cat_arr_id) ? res.data.cat_arr_id : JSON.parse(res.data.cat_arr_id);
+        this.form.city_arr_id = Array.isArray(res.data.city_arr_id) ? res.data.city_arr_id : JSON.parse(res.data.city_arr_id);
+        this.parentKey += 1; // 触发级联选择器重新加载
+        this.loadCascaderPath(this.form.cat_arr_id); // 加载路径数据
+        //回显推荐等级
+        this.form.title = res.data.title;
+        this.form.website_id = res.data.website_id;
+        // this.form.department_arr_id = Array.isArray(res.data.department_arr_id) ? res.data.department_arr_id : JSON.parse(res.data.department_arr_id);
+        this.form.city_id = res.data.city_id;
+        this.form.department_id = res.data.department_id;
+        this.form.cat_id = res.data.cat_id == '' ? 0 : res.data.cat_id;
+        this.form.img_url = res.data.img_url;
+        this.img_url = res.data.img_url;
+        this.form.price = res.data.price == '' || res.data.price == 0 ? '' : res.data.price;
+        this.form.market_price = res.data.market_price == '' || res.data.market_price == 0 ? '' : res.data.market_price;
+        this.form.page = res.data.page == '' || res.data.page == 0 ? '' : res.data.page;
+        this.form.format = res.data.format;
+        this.form.paper = res.data.paper;
+        this.form.package = res.data.package;
+        this.form.publishing_house = res.data.publishing_house;
+        this.form.ISBN = res.data.ISBN;
+        this.form.CN = res.data.CN;
+        this.form.description = res.data.description;
+        this.form.detail = res.data.detail;
+        this.tags = res.data.keyword ? res.data.keyword.split(",") : [];
+        this.form.keyword = res.data.keyword;
+        this.form.publish_time = res.data.publish_time;
+        this.form.is_original = res.data.is_original;
+        this.form.source = res.data.source;
+        this.form.source_url = res.data.source_url;
+        // this.form.re_user_ids = Array.isArray(res.data.re_user_ids) ? res.data.re_user_ids : JSON.parse(res.data.re_user_ids);
+      })
+    },
+    async loadCascaderPath(path) {
+      for (let i = 0; i < path.length; i++) {
+        const parentId = path[i - 1] || 0; // 获取当前层级的父级ID
+        const level = i; // 当前层级的索引
+        // self.$store.dispatch('news/getWebsiteNavList', parames).then(res => {
+        //     if (res.data) {
+        //       const nodes = res.data.map(item => ({
+        //         value: item.category_id,
+        //         label: item.name,
+        //         leaf: level >= 3,
+        //         children: []
+        //       }))
+        //       resolve(nodes)
+        await this.$store.dispatch('pool/categoryList', { pid: parentId })
+          .then((res) => {
+            const nodes = res.data.map(item => ({
+              value: item.id,
+              label: item.name,
+              leaf: level >= 3, // 假设4层结构,设置叶子节点标记
+            }));
+            // 级联选择器加载数据
+            if (level === path.length - 1) {
+              this.form.cat_arr_id = path; // 确保最后一级路径正确设置
+              this.parentKey += 1; // 强制刷新 cascader
+            }
+          });
+      }
+    },
+    //1.3提交修改
+    editToServe() {
+      console.log(this.form)
+      //添加要修改的id
+      this.form.id = this.editId;
+      //先进行验证
+      this.$refs.form.validate(valid => {
+        if (valid) {
+          if (this.form.publish_time) {
+            this.form.publish_time = formatLocalDate(this.form.publish_time);
+          }
+          // if (this.form.department_arr_id.length == 0) {
+          //   this.form.department_id = 0;
+          // }
+          if (this.form.city_arr_id.length == 0) {
+            this.form.city_id = 0;
+          }
+          if (this.form.cat_arr_id.length == 0) {
+            this.form.cat_id = 0;
+          }
+          if (typeof this.form.city_arr_id == 'object') {
+            this.form.city_id = this.form.city_arr_id.at(-1) || 0;
+          }
+          if (typeof this.form.department_arr_id == 'object') {
+            this.form.department_id = this.form.department_arr_id.at(-1) || 0;
+          }
+          if (typeof this.form.cat_arr_id == 'object') {
+            this.form.cat_id = this.form.cat_arr_id.at(-1) || 0;
+          }
+          if (this.userType == 10000) {
+            this.form.status = 2
+          } else {
+            this.form.status = 1
+          }
+          this.form.price == '' ? this.form.price = 0 : this.form.price = this.form.price;
+          this.form.market_price == '' ? this.form.market_price = 0 : this.form.market_price = this.form.market_price;
+          this.form.page == '' ? this.form.page = 0 : this.form.page = this.form.page;
+
+          this.$store.dispatch('news/updateBook', this.form).then(res => {
+            if (res.code != 200) {
+              this.$message.error("修改失败,请稍后再试!");
+            } else {
+              //汇报结果
+              if (this.userType == 10000) {
+                this.$message({
+                  type: 'success',
+                  message: '已成功编辑书刊音像!'
+                });
+                //返回列表页
+                this.returnPage()
+              } else {
+                this.$message({
+                  type: 'success',
+                  message: '待管理员审核!'
+                });
+                //返回列表页
+                this.returnPage()
+              }
+              this.cleatForm();
+            }
+          }).catch(() => {
+            this.$message({
+              type: 'info',
+              message: '网络错误,请重试!'
+            });
+          })
+        }
+      })
+    },
+    //商品关键词
+    updateTags(newTags) {
+      this.tags = newTags;
+      this.form.keyword = newTags.join(',');
+    },
+    handleDelete() {
+      // 删除图片
+      this.img_url = ''; // 清空图片 URL
+      this.form.img_url = ''; // 清空表单中的图片 URL
+    },
+
+  },
+  watch: {
+
+    '$route'(to, from) {
+      console.log(from, '---------------------------------------');
+      // 监听路由参数中的 id 变化,若变化则更新页面状态并获取数据
+      if (to.query.id) {
+        this.getMainData();
+      }
+    },
+    //website_id
+    'form.website_id'(newVal, oldVal) {
+      if (newVal != oldVal) {
+        this.parentKey += 1; // 触发级联选择器重新加载
+      }
+    }
+
+  },
+  mounted() {
+    //1.判断是新建还是回显
+    if (this.$route.query.id != undefined) {
+      this.editId = this.$route.query.id;
+      this.editStatus = true;
+      this.tableDivTitle = "编辑书刊音像";
+      console.log("编辑书刊音像")
+      this.getMainData();
+    } else {
+      this.editStatus = false;
+      console.log("添加书刊音像!")
+    }
+    if (this.$route.query.read == 1) {
+      this.readStatus = true;;
+    } else {
+      this.readStatus = false;
+    }
+    this.fetchWebsiteOptions();
+    this.getUserInfo();
+
+    //复制内容到富文本 start ------------------------------------------------------------>
+    //复制富文本 end ------------------------------------------------------------>
+  },
+};
+</script>
+<style scoped lang="less">
+//执行v-deep穿透scope选择器 start------------------------------------------------------------>*/
+::v-deep .custom-form-item>.el-form-item__label {
+  line-height: 140px !important;
+}
+
+::v-deep .custom-textarea .el-textarea__inner {
+  resize: none;
+  /* 禁止用户拖拽调整大小 */
+}
+
+::v-deep .custom-align-right .el-form-item__label {
+  text-align: right;
+  /* 设置标签文字右对齐 */
+}
+
+::v-deep .el-select {
+  width: 100%;
+  /* 禁止用户拖拽调整大小 */
+}
+
+::v-deep .el-input-group__prepend {
+  color: black !important;
+}
+
+.formLabelFloatBox {
+  margin-bottom: 10px;
+  position: relative;
+
+  .formLabeladdIcon {
+    position: absolute;
+    right: 45px;
+    top: 5px;
+    width: 38px;
+    height: 24px;
+  }
+
+  .formLabelDelIcon {
+    position: absolute;
+    right: 5px;
+    top: 5px;
+    width: 38px;
+    height: 24px;
+  }
+}
+
+//该项不能为空几个字的位置
+::v-deep .el-form-item__error {
+  color: #ff4949;
+  font-size: 12px;
+  line-height: 1;
+  padding-top: 4px;
+  position: relative;
+  // top: 22%;
+  // left: 93%;
+}
+
+//输入框距离底部的距离
+::v-deep .el-form-item {
+  margin-bottom: 5px;
+}
+
+//图片提示文字样式
+.photo_tips {
+  font-size: 12px;
+  color: #999;
+}
+
+//执行v-deep穿透scope选择器 end------------------------------------------------------------>*/</style>

+ 25 - 10
src/views/news/addGood.vue

@@ -233,7 +233,7 @@ export default {
       // imgurl: ['http://192.168.1.127:9501/image/20250227/1740674706184955.jpg', 'http://192.168.1.127:9501/image/20250227/1740674706184955.jpg'],//图片路径
       website_id: "",
       tags: [],//标签数组
-
+      imgUrl: [],//图片数组
       //提交表单
       form: {
         //1.1使用了外链
@@ -480,7 +480,6 @@ export default {
         if (this.userType != 10000) {
           this.form.website_id = getWebSiteId()
         }
-
         //if(res.data.type_id==10000){}//管理员
         //if(res.data.type_id==4){}//调研员
         //个人会员=1 政务会员=2 企业会员=3 调研员=4 管理员=10000 游客=20000
@@ -528,7 +527,9 @@ export default {
     //1.2 提交表单
     addToServe() {
 
-      this.form.website_id = getWebSiteId();
+      if (this.userType != 10000) {
+        this.form.website_id = getWebSiteId()
+      }
       console.log("提交时获取网站id:", this.form.website_id)
       //先进行验证
       this.$refs.form.validate(valid => {
@@ -574,13 +575,24 @@ export default {
           this.$store.dispatch('news/addGood', this.form).then(res => {
             if (res.code == 200) {
               //汇报结果
-              this.$message({
-                type: 'success',
-                message: '已成功添加商品!'
-              });
-              this.cleatForm();
-              //返回列表页
-              this.returnPage()
+              if (this.type_id == 10000) {
+                this.$message({
+                  type: 'success',
+                  message: '已成功添加商品!'
+                });
+                this.cleatForm();
+                //返回列表页
+                this.returnPage()
+              } else {
+                this.$message({
+                  type: 'success',
+                  message: '待管理员审核!'
+                });
+                this.cleatForm();
+                //返回列表页
+                this.returnPage()
+              }
+
             } else {
               this.$message({
                 type: 'error',
@@ -832,6 +844,9 @@ export default {
     'form.website_id': {
       handler(newVal, oldVal) {
         if (newVal !== oldVal) {
+          console.log('website_id变化了', newVal);
+          console.log('website_id变化了', oldVal);
+          console.log('website_id变化了', this.form.cat_arr_id);
           this.form.cat_arr_id = [];
           this.form.catid = "";
           this.parentKey += 1;

+ 169 - 98
src/views/news/addJobHunting.vue

@@ -6,13 +6,12 @@
       <div class="menu-item" @click="scrollToSection('personalInfo')">个人信息</div>
       <div class="menu-item" @click="scrollToSection('jobIntentions')">求职意向</div>
       <div class="menu-item" @click="scrollToSection('professionalSkills')">专业技能</div>
-      <div class="menu-item" @click="scrollToSection('workExperience')">工作经</div>
+      <div class="menu-item" @click="scrollToSection('workExperience')">工作经</div>
       <div class="menu-item" @click="scrollToSection('educationExperience')">教育经历</div>
     </div>
     <div class="layerBox">
-
       <div id="personalInfo">
-        <tableTitle name="个人信息" />
+        <tableTitle1 name="个人信息" />
         <!-- 个人信息表单内容 -->
       </div>
       <el-form :model="form" ref="form" :rules="formRules" label-position="left" label-width="120px">
@@ -32,10 +31,9 @@
                     <div>选择图片</div>
                   </div>
                 </div>
-
               </el-upload>
-              <div class="imgBox" style="color:red;margin-left: 00px ;margin-bottom: 0px; padding-top: 0px;">
-                请添加图片,上传格式要求jpg、gif、png,不大于500 k</div>
+              <div class="photo_tips">
+                请添加图片,上传格式要求jpg、gif、png,不大于500k</div>
             </div>
           </el-form-item>
           <el-form-item label="姓名:" prop="name" class="custom-align-right">
@@ -78,6 +76,16 @@
             <el-date-picker v-model="form.jobtime" type="date" placeholder="选择参加工作时间">
             </el-date-picker>
           </el-form-item>
+          <!-- {{ years }}
+          {{ form.experience }} -->
+          <el-form-item label="工作经验:" prop="experience" class="custom-align-right" style="width: 100%;">
+            <el-select v-model="form.experience" placeholder="请选择工作经验">
+              <el-option v-for="item in years" :key="item.evalue" :label="item.ename" :value="item.evalue"></el-option>
+            </el-select>
+          </el-form-item>
+
+
+
           <el-form-item label="手机号:" prop="phone" class="custom-align-right">
             <el-input v-model="form.phone" autocomplete="off" placeholder="请输入手机号"></el-input>
           </el-form-item>
@@ -89,10 +97,10 @@
             <el-date-picker v-model="form.birth" type="date" placeholder="选择出生年月">
             </el-date-picker>
           </el-form-item>
-
           <el-form-item label="最高学历:" class="custom-align-right" style="width: 100%;">
             <el-select v-model="form.educational" placeholder="请选择最高学历" @change='changeCompanyNature()'>
-              <el-option v-for="item in educations" :key="item.id" :label="item.ename" :value="item.id"></el-option>
+              <el-option v-for="item in educations" :key="item.evalue" :label="item.ename"
+                :value="item.evalue"></el-option>
             </el-select>
           </el-form-item>
 
@@ -110,10 +118,12 @@
 
           <el-form-item label="语言能力:" class="custom-align-right" style="width: 100%; display: inline;">
             <el-select v-model="form.language" placeholder="请选择语种" style="width: 40%;" @change='changeCompanyNature()'>
-              <el-option v-for="item in languages" :key="item.id" :label="item.ename" :value="item.id"></el-option>
+              <el-option v-for="item in languages" :key="item.evalue" :label="item.ename"
+                :value="item.evalue"></el-option>
             </el-select>
             <el-select v-model="form.level" placeholder="请选择掌握程度" style="width: 40%;" @change='changeCompanyNature()'>
-              <el-option v-for="item in languagetypes" :key="item.id" :label="item.ename" :value="item.id"></el-option>
+              <el-option v-for="item in languagetypes" :key="item.evalue" :label="item.ename"
+                :value="item.evalue"></el-option>
             </el-select>
           </el-form-item>
           <!-- <el-divider content-position="right"> </el-divider> -->
@@ -121,29 +131,42 @@
             <tableTitle name="求职意向" />
             <!-- 求职意向表单内容 -->
           </div>
-          <el-form-item label="发布地点:" prop="city_arr_id" class="custom-align-right">
-            <el-cascader :key="cascaderKey" v-model="form.city_arr_id" placeholder="请选择发布地区" :props="cityData"
+          <el-form-item label="工作地点:" prop="city_arr_id" class="custom-align-right">
+            <el-cascader :key="cascaderKey" v-model="form.city_arr_id" placeholder="请选择工作地点" :props="cityData"
               filterable clearable></el-cascader>
           </el-form-item>
 
           <el-form-item label="职位性质:" class="custom-align-right" style="width: 100%;">
             <el-select v-model="form.politic" placeholder="请选择职位性质" @change='changeCompanyNature()'>
-              <el-option v-for="item in natures" :key="item.id" :label="item.ename" :value="item.id"></el-option>
+              <el-option v-for="item in natures" :key="item.evalue" :label="item.ename"
+                :value="item.evalue"></el-option>
             </el-select>
           </el-form-item>
+
+
+
           <el-form-item label="所属行业:" prop="industry" class="custom-align-right" style="width: 100%;">
             <el-select v-model="form.industry" placeholder="请选择所属行业">
               <el-option v-for="item in jobIndustry" :key="item.hyid" :label="item.hyname"
                 :value="item.hyid"></el-option>
             </el-select>
           </el-form-item>
-          <el-form-item label="职位名称:" prop="job" class="custom-align-right">
-            <el-select v-model="form.job" placeholder="请选择职位名称">
+
+          <el-form-item label="职位类别:" prop="job" class="custom-align-right">
+            <el-select v-model="form.job" placeholder="请选择职位类别" @change="changeJobname">
               <el-option v-for="item in jobPosition" :key="item.zwid" :label="item.zwname"
                 :value="item.zwid"></el-option>
-
             </el-select>
           </el-form-item>
+          <el-form-item label="具体职位:" prop="job_name_get" class="custom-align-right">
+            <el-select v-model="form.job_name_get" placeholder="请选择具体职位">
+              <el-option v-for="item in job_name_arr" :key="item.zwid" :label="item.zwname"
+                :value="item.zwid"></el-option>
+            </el-select>
+          </el-form-item>
+
+
+
           <el-form-item label="公司性质:" v-if="jobNature" prop="company_nature" class="custom-align-right">
             <el-select v-model="form.company_nature" placeholder="请选择公司性质" @change='changeCompanyNature()'>
               <el-option v-for="item in jobNature" :key="item.id" :label="item.nature_name" :value="item.id">
@@ -153,7 +176,8 @@
           </el-form-item>
           <el-form-item label="薪资范围:" prop="salary" class="custom-align-right">
             <el-select v-model="form.salary" placeholder="请选择薪资范围" @change='changeCompanyNature()'>
-              <el-option v-for="item in incomes" :key="item.id" :label="item.ename" :value="item.id"></el-option>
+              <el-option v-for="item in incomes" :key="item.evalue" :label="item.ename"
+                :value="item.evalue"></el-option>
             </el-select>
           </el-form-item>
           <el-form-item label="个人评价:" prop="self_evaluation" class="custom-align-right">
@@ -163,27 +187,22 @@
           <!-- <el-divider content-position="right"> </el-divider> -->
           <div id="professionalSkills">
             <tableTitle name="专业技能" />
+            <el-button type="primary" class="addBtn" @click="addSkill">
+              +添加
+            </el-button>
             <!-- 专业技能表单内容 -->
           </div>
-          <el-form-item style="margin: 0px;">
-            <el-button type="primary" @click="addSkill" style="display:inline-block;float: right;margin-bottom: 0px;">
-              +
-              添加</el-button>
-          </el-form-item>
           <el-form-item v-for="(item, index) in form.skillList" :key="index" :label="'技能' + (index + 1) + ':'"
             prop="skillList" class="custom-align-right">
             <el-input v-model="form.skillList[index].skill" autocomplete="off" placeholder="请输入专业技能"></el-input>
           </el-form-item>
+
           <div id="workExperience">
             <tableTitle name="工作经历" />
+            <el-button type="primary" class="addBtn" @click="addExperience">
+              +添加
+            </el-button>
           </div>
-          <el-form-item style="margin: 0px;">
-            <el-button type="primary" @click="addExperience"
-              style="display:inline-block  ;float: right;margin-bottom: 0px;">
-              +
-              添加</el-button>
-          </el-form-item>
-
 
           <div v-for="(item, index) in form.job_experience" :key="index">
 
@@ -200,12 +219,17 @@
                   :value="item.hyid"></el-option>
               </el-select>
             </el-form-item>
-            <el-form-item label="职位名称:" prop="job_name" class="custom-align-right">
-              <el-select v-model="form.job_experience[index].job_name" placeholder="请选择职位名称"
-                @change='changeCompanyNature()'>
+            <el-form-item label="职位类别:" prop="job_typename" class="custom-align-right">
+              <el-select v-model="form.job_experience[index].job_typename" placeholder="请选择职位类别"
+                @change="changeCompanyJobname">
                 <el-option v-for="item in jobPosition" :key="item.zwid" :label="item.zwname"
                   :value="item.zwid"></el-option>
-
+              </el-select>
+            </el-form-item>
+            <el-form-item label="具体职位:" prop="job_name" class="custom-align-right">
+              <el-select v-model="form.job_experience[index].job_name" placeholder="请选择具体职位">
+                <el-option v-for="item in company_jobname_arr" :key="item.zwid" :label="item.zwname"
+                  :value="item.zwid"></el-option>
               </el-select>
             </el-form-item>
             <el-form-item label="所属部门:" prop="department" class="custom-align-right">
@@ -232,23 +256,21 @@
 
           <div id="educationExperience">
             <tableTitle name="教育经历" />
+            <el-button type="primary" class="addBtn" @click="addEducation">
+              +添加
+            </el-button>
             <!-- 教育经历表单内容 -->
           </div>
-          <el-form-item style="margin: 0px;">
-            <el-button type="primary" @click="addEducation"
-              style="display:inline-block  ;float: right;margin-bottom: 0px;">
-              +
-              添加</el-button>
-          </el-form-item>
           <div v-for="(item, index) in form.education_experience" :key="index">
-            <el-form-item label="学校名称:" prop="school_name" class="custom-align-right">
+            <el-form-item label="学校名称:" prop="school_name" class="custom-align-right">
               <el-input v-model="form.education_experience[index].school_name" autocomplete="off"
                 placeholder="请输入学校名称"></el-input>
             </el-form-item>
             <el-form-item label="学历:" prop="school_education" class="custom-align-right" style="width: 100%;">
               <el-select v-model="form.education_experience[index].school_education" placeholder="请选择学历"
                 @change='changeCompanyNature()'>
-                <el-option v-for="item in educations" :key="item.id" :label="item.ename" :value="item.id"></el-option>
+                <el-option v-for="item in educations" :key="item.evalue" :label="item.ename"
+                  :value="item.evalue"></el-option>
               </el-select>
             </el-form-item>
             <el-form-item label="专业:" prop="school_major" class="custom-align-right">
@@ -262,7 +284,7 @@
                 range-separator="至" start-placeholder="开始日期" end-placeholder="结束日期" :picker-options="pickerOptions">
               </el-date-picker>
             </el-form-item>
-            <el-form-item label="在校经历:" prop="school_experience" class="custom-align-right">
+            <el-form-item label="在校经历" prop="school_experience" class="custom-align-right">
               <el-input v-model="form.education_experience[index].school_experience" autocomplete="off" type="textarea"
                 aria-rowspan="6" placeholder="请输入在校经历"></el-input>
             </el-form-item>
@@ -285,6 +307,7 @@
 import { getWebSiteId, getUseType } from '@/utils/auth'
 //表格标题
 import tableTitle from './components/tableTitle';
+import tableTitle1 from './components/tableTitle1';
 //引入公用样式
 import '@/styles/global.less';
 //格式化时间
@@ -292,7 +315,8 @@ import { formatLocalDate } from '@/utils/public';
 
 export default {
   components: {
-    tableTitle
+    tableTitle,
+    tableTitle1
   },
   data() {
 
@@ -408,8 +432,8 @@ export default {
       natures: [],
       maritals: [],
       incomes: [],
-
-
+      job_name_arr: [],//职位名称
+      company_jobname_arr: [],//公司职位名称
       timeList: [],
       // imgurl: "http://img.bjzxtw.org.cn/dev/image/jpeg/20250220/1740044079754901.png",
       imgUrl: "",
@@ -427,21 +451,25 @@ export default {
       disclaimer: true,//免责声明
       //提交表单
       creatNews_user_type: 0,//判断用户类型'
+
       form: {
-        industry: 1,//行业
-        job: 1,//职位
+        experience: '',//工作经验
+        industry: '',//行业
+        job: '',//职位
         self_evaluation: '',//自我评价
         city_arr_id: [],
         skillList: [{ 'skill': '' }],
         job_experience: [{
           company_name: '',
-          job_industry: 1,
-          job_name: 1,
+          job_industry: '',
+          job_name: '',
+          job_typename: '',
           department: '',
           // job_timeList: ['2025-02-21 00:00:00', '2025-02-29 00:00:00'],
           job_timeList: [],
           performance: '',
           job_content: ''
+
         }],//工作经验
         education_experience: [{
           school_name: '',
@@ -461,16 +489,21 @@ export default {
         jobtime: "",//工作时间
         origin: "",
         //校验专用
+        industry: '',//行业
+        job: '',//职位名称
         company_name: [],//公司名称
         job_industry: [],//行业
-        job_name: [],//职位名称
+        job_name: [],//具体职位-工作经验
+        job_typename: [],//职位类别-工作经验
         department: [],//所属部门
         job_timeList: [],//工作时间
         job_content: [],//工作内容
+        job_name_get: '',
       },
       //1.2 表单验证规则
       formRules: {
         skillList: [{ required: true, trigger: 'blur', validator: validateArraySkill }],
+        salary: [{ required: true, trigger: 'blur', validator: validateEmpty }],
         //求职名称不能为空
         name: [{ required: true, trigger: 'blur', validator: validateEmpty }],
         imgUrl: [{ required: true, trigger: 'blur', validator: validateEmpty }],
@@ -483,10 +516,11 @@ export default {
         slelf_evaluation: [{ required: true, trigger: 'blur', validator: validateEmpty }],
         company_name: [{ required: true, trigger: 'blur', validator: validateCompanyNameEmpty }],
         job_industry: [{ required: true, trigger: 'blur', validator: validateJobIndustryEmpty }],
-        job_name: [{ required: true, trigger: 'blur', validator: validateJobNameEmpty }],
-        job_timeList: [{ required: true, trigger: 'blur', validator: validateJobTimeListEmpty }],
-        job_content: [{ required: true, trigger: 'blur', validator: validateJobContentEmpty }],
+        // job_name: [{ required: true, trigger: 'blur', validator: validateEmpty }],
+        job_timeList: [{ required: true, trigger: 'blur', validator: validateArray }],
+        job_content: [{ required: true, trigger: 'blur', validator: validateArray }],
         cat_arr_id: [{ required: true, trigger: 'blur', validator: validateArray }],
+        job_typename: [{ required: true, trigger: 'blur', validator: validateArray }],
       },
       //1.3富文本编辑器配置
 
@@ -502,7 +536,7 @@ export default {
           if (data && data.children && data.children.length !== 0) {
             return resolve(node)
           }
-          console.log(level)
+          // console.log(level)
           let parentId = level == 0 ? 0 : data.value
           let parames = {
             'pid': parentId
@@ -537,23 +571,18 @@ export default {
           if (data && data.children && data.children.length !== 0) {
             return resolve(node)
           }
-
           let parentId;
-
           if (data != undefined) {
             parentId = data.value;
           } else {
             parentId = self.creatNews_pid_num.toString();
           }
-
           let parames = {
             'website_id': self.form.web_site_id ? self.form.web_site_id : self.websiteid,
             'pid': parentId
 
           }
-
           self.$store.dispatch('pool/get_creatNews_nav_son_actions', parames).then(res => {
-
             if (res.data) {
               const nodes = res.data.map(item => ({
                 value: item.category_id,
@@ -566,7 +595,6 @@ export default {
           })
         }
       },
-
       cityData: {
         checkStrictly: true,
         lazy: true,
@@ -603,6 +631,23 @@ export default {
     changeCompanyNature(val) {
       this.$forceUpdate();
     },
+    changeJobname(value) {
+      // 修改此处,确保传递的是正确的参数对象
+      this.form.job_name_get = ''; // 清空具体职位选择
+      this.$store.dispatch('news/getPositionList', { zwpid: value }).then(res => {
+        console.log(res.data, '-----res.job_name_arr----------------------')
+        this.job_name_arr = res.data;
+      })
+    },
+    changeCompanyJobname(value) {
+      // 修改此处,确保传递的是正确的参数对象
+      this.form.job_name = ''; // 清空具体职位选择
+      this.$store.dispatch('news/getPositionList', { zwpid: value }).then(res => {
+        // console.log(res.data, '-----changeCompanyJobname.getPositionList----------------------') 
+        this.company_jobname_arr = res.data;
+        console.log(this.company_jobname_arr, '-----changeCompanyJobname.getPositionList----------------------')
+      })
+    },
     getJobHuntingData() {
       this.$store.dispatch('news/getJobHuntingData', {}).then(res => {
         if (res.code == 200) {
@@ -613,10 +658,13 @@ export default {
           this.natures = this.jobEnum.filter(item => item.egroup === 'nature');
           this.maritals = this.jobEnum.filter(item => item.egroup === 'marital');
           this.incomes = this.jobEnum.filter(item => item.egroup === 'income');
-
+          this.years = this.jobEnum.filter(item => item.egroup === 'years');
           this.jobIndustry = res.data.jobIndustry;
           this.jobNature = res.data.jobNature;
-          this.jobPosition = res.data.jobPosition;
+          console.log(this.educations, '-----this.jobNature----------------------')
+          this.jobPosition = res.data.jobPosition.filter(item => item.zwpid == 0);
+          //具体职位
+          this.jobPosition1 = res.data.jobPosition.filter(item => item.zwpid !== 0);
         }
       })
     },
@@ -637,7 +685,8 @@ export default {
     },
     addExperience() {
       const hasEmptyExperience = this.form.job_experience.some(item => {
-        if (item.company_name == '' || item.job_industry == '' || item.job_name == '' || item.job_timeList == '' || item.job_content == '') {
+        // console.log(item, '-------------item--------')
+        if (item.company_name == '' || item.job_industry == '' || item.job_name == '' || item.job_timeList == '' || item.job_content == '' || item.job_typename == '') {
           this.$message.error('请先填写工作经历');
           return true; // 返回 true 表示找到了空的 skill
         }
@@ -650,6 +699,7 @@ export default {
         company_name: '',
         job_industry: '',
         job_name: '',
+        job_typename: '',
         department: '',
         job_timeList: '',
         performance: '',
@@ -799,6 +849,7 @@ export default {
         company_name: [],//公司名称
         job_industry: [],//行业
         job_name: [],//职位名称
+        job_typename: [],//职位类别-工作经验
         department: [],//所属部门
         job_timeList: [],//工作时间
         job_content: [],//工作内容
@@ -837,8 +888,12 @@ export default {
         this.form.company_nature = res.data.company_nature;
         this.form.salary = res.data.salary;
         this.form.self_evaluation = res.data.self_evaluation;
+        this.form.job = parseInt(res.data.job);
+        this.form.industry = res.data.industry;
+        this.form.experience = res.data.experience;
 
-        this.form.educational = res.data.educational;
+
+        this.form.educational = res.data.educationa == null ? "" : parseInt(res.data.educational);
         this.form.politic = res.data.politic;
         this.form.language = res.data.language;
         this.form.level = res.data.level;
@@ -854,8 +909,10 @@ export default {
         this.form.origin = res.data.origin;
         this.form.city_arr_id = Array.isArray(res.data.city_arr_id) ? res.data.city_arr_id : JSON.parse(res.data.city_arr_id);
         this.form.job_experience = JSON.parse(res.data.job_experience);
+        // console.log(this.form.job_experience, '-----------------this.form.job_experience----------------------')
         this.form.education_experience = JSON.parse(res.data.education_experience);
         this.form.skillList = JSON.parse(res.data.skillList);
+        this.form.job_name_get = res.data.job_name_get == null ? '' : parseInt(res.data.job_name_get);
 
       }).catch(() => {
         this.$message({
@@ -1001,49 +1058,25 @@ export default {
           message: '网络错误,请重试!'
         });
       })
-
     },
-    creatNews_nav_pool_change_fun() {
-
-      //xx  导航池级
-      let that = this;
-
-      this.form.web_site_id = this.form.web_site_id[0]
-
-      that.parentKey_2 += 1;
-
-      this.$store.dispatch('pool/get_creatNews_nav_son_actions', { pid: String(this.creatNews_pid_num), website_id: String(this.form.web_site_id) }).then(res => {
-
-
+    creatNews_nav_pool_change_fun() {      //xx  导航池级
+      let that = this; this.form.web_site_id = this.form.web_site_id[0]
+      that.parentKey_2 += 1; this.$store.dispatch('pool/get_creatNews_nav_son_actions', { pid: String(this.creatNews_pid_num), website_id: String(this.form.web_site_id) }).then(res => {
         if (res.data.length == 0) {//没有导航池子级
           // alert("没有导航池子级");
           return
-        }
-
-        this.creatNews_add_nav_pool_arr = res.data;
-
-        this.creatNews_add_nav_pool_arr.forEach((per_obj) => {
+        } this.creatNews_add_nav_pool_arr = res.data; this.creatNews_add_nav_pool_arr.forEach((per_obj) => {
           per_obj.label = per_obj.name,
-            per_obj.value = per_obj.id,
-
-            this.creatNews_pid_num = per_obj.category_id
+            per_obj.value = per_obj.id, this.creatNews_pid_num = per_obj.category_id
         })
-
-
       }).catch(() => {
         this.$message({
           type: 'info',
           message: '网络错误,请重试!'
         });
       })
-
-
     },
-
-
-
   },
-
   mounted() {
     this.creatNews_user_type = getUseType()
     this.websiteid = getWebSiteId()
@@ -1064,7 +1097,9 @@ export default {
   },
   watch: {
     'form.job_experience': {
+      // console.log(form.job_experience, ',-=-------job_typename---------');
       handler(newVal, oldVal) {
+        // console.log(oldVal, ',-=-------job_typename---------');
         newVal.forEach((item, index) => {
           // 确保每个对象都有默认值
           // if (!item.company_name) item.job_industry = '';
@@ -1074,18 +1109,19 @@ export default {
           // if (!item.job_content) item.job_content = '';
           // if (!item.performance) item.performance = '';
           // 检查 company_name 是否发生变化
-          console.log(newVal[index].company_name, oldVal[index].company_name);
-          console.log(newVal[index].job_industry, '---job_industry---');
+          // console.log(newVal[index].job_typename, oldVal[index].job_typename, '---job_typename---');
+          // console.log(newVal[index].job_industry, '---job_industry---');
           this.form.company_name[index] = item.company_name;
           this.form.job_industry[index] = item.job_industry;
           this.form.job_name[index] = item.job_name;
+          this.form.job_typename[index] = item.job_typename;
           this.form.department[index] = item.department;
           this.form.job_timeList[index] = item.job_timeList;
           this.form.job_content[index] = item.job_content;
 
-          console.log(this.form.company_name[index], '-=-------company_name---------');
-          console.log(this.form.job_industry, '-=-------job_industry---------');
-          console.log(this.form.company_name, '-=-------job_name---------');
+
+          // console.log(this.form.job_industry, '-=-------job_industry---------');
+          // console.log(this.form.company_name, '-=-------job_name---------');
           // if (oldVal[index] && oldVal[index].company_name !== item.company_name) {
           //   // 如果发生变化,就修改this.form.company_name相应的值
           // }
@@ -1167,4 +1203,39 @@ export default {
 
 }
 
+//该项不能为空几个字的位置
+::v-deep .el-form-item__error {
+  color: #ff4949;
+  font-size: 12px;
+  line-height: 1;
+  padding-top: 4px;
+  position: relative;
+}
+
+//输入框距离底部的距离
+::v-deep .el-form-item {
+  margin-bottom: 5px;
+}
+
+//图片提示文字样式
+.photo_tips {
+  font-size: 14px;
+  color: #999;
+}
+
+#educationExperience,
+#workExperience,
+#professionalSkills {
+  position: relative;
+}
+
+.addBtn {
+  position: absolute;
+  right: 0px;
+  top: -8px;
+  width: 78px;
+  // display: inline-block;
+  // margin-bottom: 0px;
+}
+
 //执行v-deep穿透scope选择器 end------------------------------------------------------------>*/</style>

+ 1 - 0
src/views/news/addNcomplaint.vue

@@ -138,6 +138,7 @@ export default {
     let self = this;
     //0.全局操作 end ------------------------------------------------------------>
     return {
+      hovering: false, // 鼠标悬浮状态 悬浮时显示删除
       formLabelWidth: '80px',//表单的长度
       //1.表单项 start ------------------------------------------------------------>
       editStatus: false,

+ 1 - 0
src/views/news/addNotice.vue

@@ -127,6 +127,7 @@ export default {
     let self = this;
     //0.全局操作 end ------------------------------------------------------------>
     return {
+      hovering: false, // 鼠标悬浮状态 悬浮时显示删除
       formLabelWidth: '80px',//表单的长度
       //1.表单项 start ------------------------------------------------------------>
       editStatus: false,

+ 269 - 0
src/views/news/bookList.vue

@@ -0,0 +1,269 @@
+<template>
+  <div class="mainBox">
+    <!--搜索功能 start------------------------------------------------------------>
+    <div class="layerBox_search">
+      <div class="layerBoxLine">
+        <el-row>
+
+          <el-col :span="6">
+            <div class="searchBox">
+              <div class="searchTitle">标题名称:</div>
+              <el-input placeholder="请输入标题名称" autocomplete="off" v-model="getApiData.title" />
+            </div>
+          </el-col>
+          <el-col :span="6">
+            <div class="searchBox">
+              <div class="searchTitle">网站名称:</div>
+              <el-input placeholder="请输入网站名称" autocomplete="off" v-model="getApiData.website_name" />
+            </div>
+          </el-col>
+
+          <!-- <el-col :span="6">
+            <div class="searchBox">
+              <div class="searchTitle">审核:</div>
+              <el-select v-model="getApiData.status" placeholder="请处理状态..">
+                <el-option label="未审核" value="1"></el-option>
+                <el-option label="已审核" value='2'></el-option>
+                <el-option label=" 已拒绝" value="3"></el-option>
+              </el-select>
+            </div>
+          </el-col> -->
+
+        </el-row>
+      </div>
+
+    </div>
+
+    <div class="layerBoxNoBg">
+      <div>
+        <el-button type="primary" @click="goCreat">发布书刊音像</el-button>
+      </div>
+      <div>
+        <el-button @click="clearSearchList">重置</el-button>
+        <el-button type="primary" @click="getData('search')">搜索</el-button>
+      </div>
+    </div>
+    <!--搜索功能 end------------------------------------------------------------>
+
+    <!--表格内容 start------------------------------------------------------------>
+    <div class="layerBox">
+      <tableTitle :name="tableDivTitle" />
+      <el-row>
+        <template>
+          <el-table :data="tableData" style="width: 100%">
+            <el-table-column fixed prop="id" label="编号" width="50"></el-table-column>
+            <el-table-column prop="title" label="标题名称" width="">
+            </el-table-column>
+            <el-table-column prop="city_name" label="行政区划" width="">
+            </el-table-column>
+            <el-table-column prop="website_name" label="网站名称" width="">
+            </el-table-column>
+            <el-table-column prop="cat_name" label="栏目名称" width="">
+            </el-table-column>
+
+            <el-table-column prop="status" label="审核状态" width="">
+              <template slot-scope="scope">
+                <span v-if="scope.row.status == 1">
+                  未审核
+                </span>
+                <span v-if="scope.row.status == 2">
+                  已审核
+                </span>
+                <span v-if="scope.row.status == 3">
+                  已拒绝
+                </span>
+              </template>
+            </el-table-column>
+
+
+            <el-table-column prop="updated_at" label="修改时间" width=""></el-table-column>
+
+            <el-table-column fixed="right" label="操作" width="300" header-align="center">
+              <template slot-scope="scope">
+                <div class="listBtnBox">
+                  <div class="listUpBtn" v-if="type_id == 10000" @click="returnRow(scope.row.id, tableData)"><i
+                      class="el-icon-refresh-right"></i>撤回</div>
+                  <div class="listDeleteBtn" @click="deleteRow(scope.row.id, tableData)"><i
+                      class="el-icon-delete"></i>删除</div>
+                  <div class="listEditBtn" @click="goEdit(scope.row.id, tableData)"><i
+                      class="el-icon-edit-outline"></i>编辑</div>
+                </div>
+              </template>
+            </el-table-column>
+          </el-table>
+        </template>
+      </el-row>
+    </div>
+    <!--分页 start------------------------------------------------------------>
+    <div class="alignBox">
+      <el-row>
+        <el-col :span="24">
+          <el-pagination @size-change="handleSizeChange" :current-page="getApiData.page"
+            @current-change="handleCurrentChange" :page-size="10" layout="total, prev, pager, next, jumper"
+            :total="allCount"></el-pagination>
+        </el-col>
+      </el-row>
+    </div>
+    <!--分页 end------------------------------------------------------------>
+    <!--表格内容 end------------------------------------------------------------>
+  </div>
+</template>
+
+<script>
+//表格标题
+import tableTitle from './components/tableTitle';
+
+//获得用户身份
+import { getUseType } from '@/utils/auth'
+
+//引入公用样式
+import '@/styles/global.less';
+
+export default {
+  components: {
+    tableTitle,//表格标题
+  },
+  data() {
+    return {
+      //1.列表和分页相关 start ------------------------------------------------------------>
+      tableDivTitle: "书刊音像列表",
+      tableData: [],//内容
+      editId: 0,//要修改的网站id
+      getApiData: {
+        title: "",//标题
+        website_name: "",//网站名称
+        status: 2,//发布状态
+        page: 1,//当前是第几页
+        page_size: 10,//一共多少条
+      },
+      allCount: 0,//总条数
+      type_id: 0,
+      //分页相关 end ------------------------------------------------------------>
+
+    }
+  },
+  methods: {
+    //1.列表和分页相关 start ------------------------------------------------------------>
+    //1.1 开始请求列表信息方法
+    getData(type) {
+      if (type == "search") {
+        this.getApiData.page = 1;
+      }
+      console.log(this.getApiData, '---1--')
+      this.$store.dispatch('news/getBookList', this.getApiData).then(res => {
+        console.log(this.getApiData, '---2-')
+        let data = [];
+        for (let item of res.data.rows) {
+          data.push(item)
+        }
+        this.tableData = res.data.rows; //给与内容
+        this.allCount = res.data.count; //给与总条数
+      })
+    },
+    // 1.2.1 撤回
+    returnRow(id) {
+      this.$confirm('确定要撤回吗?', '提示', {
+        confirmButtonText: '撤回',
+        cancelButtonText: '取消',
+        type: 'warning'
+      }).then(() => {
+        //撤回,把文章状态修改为0,重新进行审核
+        this.upRow(id, 1)
+      })
+    },
+    //1.2 删除内容
+    deleteRow(id) {
+      this.$confirm('此操作将永久删除该条数据, 是否继续?', '提示', {
+        confirmButtonText: '确定',
+        cancelButtonText: '取消',
+        type: 'warning'
+      }).then(() => {
+        console.log("当前删除:" + id)
+        this.$store.dispatch('news/deleteBook', { id: id }).then(res => {
+          this.getData();
+          this.$message({
+            type: 'success',
+            message: '删除成功!'
+          });
+        }).catch(() => {
+          this.$message({
+            type: 'warning',
+            message: '网络错误,请重试!'
+          });
+        })
+      }).catch(() => {
+        this.$message({
+          type: 'warning',
+          message: '已取消删除'
+        });
+      });
+    },
+    //1.3 修改网站状态
+    upRow(id, status) {
+      let data = {
+        id: id,
+        status: status
+      }
+      this.$store.dispatch('news/updateBookStatus', data).then(res => {
+        if (res.code == 200) {
+          this.$message({
+            type: 'success',
+            message: '审核状态已修改!'
+          });
+          this.getData();
+        }
+      }).catch(() => {
+        this.$message({
+          type: 'warning',
+          message: '已取消删除'
+        });
+      });
+    },
+    //1.4 列表内容分页
+    //直接跳转
+    handleSizeChange(val) {
+      this.getApiData.page = val;
+      this.getData();
+    },
+    //1.5 点击分页
+    handleCurrentChange(val) {
+      this.getApiData.page = val;
+      this.getData();
+    },
+    //1.6 重置按钮
+    clearSearchList() {
+      this.tableData = [];
+      this.getApiData.title = "";
+      this.getApiData.level = "";
+
+      this.getApiData.page = 1;
+      this.getApiData.pageSize = 10;
+      this.getData();
+    },
+    //列表和分页相关 end ------------------------------------------------------------>
+    //2.添加新闻 start ------------------------------------------------------------>
+    //跳转到通知发布页面
+    goCreat() {
+      this.$router.push({
+        path: '/addBook',
+      });
+    },
+    goEdit(id) {
+      let data = {
+        id: id
+      }
+      this.$router.push({
+        path: '/addBook',
+        query: data
+      });
+    }
+    //添加新闻 end ------------------------------------------------------------>
+  },
+  mounted() {
+    this.type_id = getUseType()
+    //1.获得初始数据
+    this.getData();
+  }
+}
+</script>
+<style scoped lang="less"></style>

+ 354 - 0
src/views/news/bookListApply.vue

@@ -0,0 +1,354 @@
+<template>
+  <div class="mainBox">
+    <!--搜索功能 start------------------------------------------------------------>
+    <div class="layerBox_search">
+      <div class="layerBoxLine">
+        <el-row>
+
+          <el-col :span="6">
+            <div class="searchBox">
+              <div class="searchTitle">标题名称:</div>
+              <el-input placeholder="请输入标题名称" autocomplete="off" v-model="getApiData.title" />
+            </div>
+          </el-col>
+          <el-col :span="6">
+            <div class="searchBox">
+              <div class="searchTitle">网站名称:</div>
+              <el-input placeholder="请输入网站名称" autocomplete="off" v-model="getApiData.website_name" />
+            </div>
+          </el-col>
+
+          <!-- <el-col :span="6">
+            <div class="searchBox">
+              <div class="searchTitle">审核:</div>
+              <el-select v-model="getApiData.status" placeholder="请处理状态..">
+                <el-option label="未审核" value="1"></el-option>
+                <el-option label="已审核" value='2'></el-option>
+                <el-option label=" 已拒绝" value="3"></el-option>
+              </el-select>
+            </div>
+          </el-col> -->
+
+        </el-row>
+      </div>
+
+    </div>
+
+    <div class="layerBoxNoBg">
+      <div>
+        <!-- <el-button type="primary" @click="goCreat">发布书刊音像</el-button> -->
+      </div>
+      <div>
+        <el-button @click="clearSearchList">重置</el-button>
+        <el-button type="primary" @click="getData('search')">搜索</el-button>
+      </div>
+    </div>
+    <!--搜索功能 end------------------------------------------------------------>
+
+    <!--表格内容 start------------------------------------------------------------>
+    <div class="layerBox">
+      <tableTitle :name="tableDivTitle" />
+      <el-row>
+        <template>
+          <el-table :data="tableData" style="width: 100%">
+            <el-table-column fixed prop="id" label="编号" width="50"></el-table-column>
+            <el-table-column prop="title" label="标题名称" width="">
+            </el-table-column>
+            <el-table-column prop="city_name" label="行政区划" width="">
+            </el-table-column>
+            <el-table-column prop="website_name" label="网站名称" width="">
+            </el-table-column>
+            <el-table-column prop="cat_name" label="栏目名称" width="">
+            </el-table-column>
+
+            <el-table-column prop="status" label="审核状态" width="">
+              <template slot-scope="scope">
+                <span v-if="scope.row.status == 1">
+                  未审核
+                </span>
+                <span v-if="scope.row.status == 2">
+                  已审核
+                </span>
+                <span v-if="scope.row.status == 3">
+                  已拒绝
+                </span>
+              </template>
+            </el-table-column>
+
+
+            <el-table-column prop="updated_at" label="修改时间" width=""></el-table-column>
+
+            <el-table-column fixed="right" label="操作" width="300" header-align="center">
+              <template slot-scope="scope">
+                <div class="listBtnBox">
+                  <div class="listMainBtn" v-if="type_id == 10000" @click="getUpRow(scope.row.id, tableData)">
+                    <i class="el-icon-check"></i>审核
+                  </div>
+
+                  <div class="listDeleteBtn" @click="deleteRow(scope.row.id, tableData)"><i
+                      class="el-icon-delete"></i>删除</div>
+                  <div class="listEditBtn" @click="goEdit(scope.row.id, tableData)"><i
+                      class="el-icon-edit-outline"></i>编辑</div>
+                </div>
+              </template>
+            </el-table-column>
+          </el-table>
+        </template>
+      </el-row>
+    </div>
+    <!--弹出框1:外部表单弹出框 start------------------------------------------------------------>
+    <el-dialog title="请输入驳回理由" :visible.sync="examineWindow" :close-on-click-modal="false">
+      <el-form :model="form" ref="form" :rules="formRules" label-position="left">
+        <div class="formDiv">
+          <el-form-item label="驳回原因:" :label-width="formLabelWidth" prop="reason" class="custom-align-right">
+            <el-input type="textarea" v-model="form.reason" class="custom-textarea" placeholder="请输入驳回原因"
+              :rows="3"></el-input>
+          </el-form-item>
+        </div>
+      </el-form>
+      <div slot="footer" class="dialog-footer">
+        <div>
+          <el-button type="info" @click="examineWindow = false">取消</el-button>
+          <el-button type="primary" @click="examineToServe">确定</el-button>
+        </div>
+      </div>
+    </el-dialog>
+    <!--弹出框1:外部表单弹出框 end------------------------------------------------------------>
+
+    <!--分页 start------------------------------------------------------------>
+    <div class="alignBox">
+      <el-row>
+        <el-col :span="24">
+          <el-pagination @size-change="handleSizeChange" :current-page="getApiData.page"
+            @current-change="handleCurrentChange" :page-size="10" layout="total, prev, pager, next, jumper"
+            :total="allCount"></el-pagination>
+        </el-col>
+      </el-row>
+    </div>
+    <!--分页 end------------------------------------------------------------>
+    <!--表格内容 end------------------------------------------------------------>
+  </div>
+</template>
+
+<script>
+//表格标题
+import tableTitle from './components/tableTitle';
+
+//获得用户身份
+import { getUseType } from '@/utils/auth'
+
+//引入公用样式
+import '@/styles/global.less';
+
+export default {
+  components: {
+    tableTitle,//表格标题
+  },
+  data() {
+    return {
+      //1.列表和分页相关 start ------------------------------------------------------------>
+      tableDivTitle: "书刊音像待审核列表",
+      tableData: [],//内容
+      editId: 0,//要修改的网站id
+      getApiData: {
+        title: "",//标题
+        website_name: "",//网站名称
+        status1: 1,//发布状态
+        page: 1,//当前是第几页
+        page_size: 10,//一共多少条
+      },
+      formRules: {
+
+      },
+      form: {
+        reason: ""
+      },
+      allCount: 0,//总条数
+      type_id: 0,
+      examineWindow: false,//审核窗口
+      //分页相关 end ------------------------------------------------------------>
+
+    }
+  },
+  methods: {
+    //1.列表和分页相关 start ------------------------------------------------------------>
+    //提交驳回内容
+    examineToServe(id) {
+      this.$refs.form.validate(valid => {
+        if (valid) {
+          let data = {
+            id: this.editId,
+            status: 3,//驳回status
+            reason: this.form.reason
+          }
+          this.$store.dispatch('news/updateBookStatus', data).then(res => {
+            if (res.code == 200) {
+              this.$message({
+                type: 'success',
+                message: '审核状态已修改!'
+              });
+              this.getData();
+              this.form.reason = "";//清空上一次的输入
+              this.examineWindow = false;
+            }
+          })
+        } else {
+          this.$message.error("驳回理由不能为空!")
+        }
+      })
+    },
+    getUpRow(id) {
+      //设置待审核的id
+      this.editId = id;
+      console.log(id)
+      this.$confirm('将此通过审核吗?', '提示', {
+        confirmButtonText: '通过',
+        cancelButtonText: '拒绝',
+        distinguishCancelAndClose: true,  // 关键配置项,用于区分取消和关闭按钮的行为
+        type: 'warning'
+      }).then(() => {
+        this.upRow(id, 2)
+        this.getData();
+      }).catch((the_reback) => {
+        //输入驳回理由
+        console.log("val=",the_reback)
+        if (the_reback == "cancel") {
+          //输入驳回理由
+          // console.log("驳回" )
+          this.examineWindow = true;
+        }
+
+      })
+    },
+    upRow(id, status) {
+      let data = {
+        id: id,
+        status: status
+      }
+      this.$store.dispatch('news/updateBookStatus', data).then(res => {
+        if (res.code == 200) {
+          this.$message({
+            type: 'success',
+            message: '状态已修改!'
+          });
+          this.getData();
+        }
+      }).catch(() => {
+        this.$message({
+          type: 'warning',
+          message: '已取消删除'
+        });
+      });
+    },
+    //1.1 开始请求列表信息方法
+    getData(type) {
+      if (type == "search") {
+        this.getApiData.page = 1;
+      }
+      console.log(this.getApiData, '---1--')
+      this.$store.dispatch('news/getBookList', this.getApiData).then(res => {
+        console.log(this.getApiData, '---2-')
+        let data = [];
+        for (let item of res.data.rows) {
+          data.push(item)
+        }
+        this.tableData = res.data.rows; //给与内容
+        this.allCount = res.data.count; //给与总条数
+      })
+    },
+    //1.2 删除内容
+    deleteRow(id) {
+      this.$confirm('此操作将永久删除该条数据, 是否继续?', '提示', {
+        confirmButtonText: '确定',
+        cancelButtonText: '取消',
+        type: 'warning'
+      }).then(() => {
+        console.log("当前删除:" + id)
+        this.$store.dispatch('news/deleteBook', { id: id }).then(res => {
+          this.getData();
+          this.$message({
+            type: 'success',
+            message: '删除成功!'
+          });
+        }).catch(() => {
+          this.$message({
+            type: 'warning',
+            message: '网络错误,请重试!'
+          });
+        })
+      }).catch(() => {
+        this.$message({
+          type: 'warning',
+          message: '已取消删除'
+        });
+      });
+    },
+    //1.3 修改网站状态
+    upRow(id, status) {
+      let data = {
+        id: id,
+        status: status
+      }
+      this.$store.dispatch('news/updateBookStatus', data).then(res => {
+        if (res.code == 200) {
+          this.$message({
+            type: 'success',
+            message: '审核状态已修改!'
+          });
+          this.getData();
+        }
+      }).catch(() => {
+        this.$message({
+          type: 'warning',
+          message: '已取消删除'
+        });
+      });
+    },
+    //1.4 列表内容分页
+    //直接跳转
+    handleSizeChange(val) {
+      this.getApiData.page = val;
+      this.getData();
+    },
+    //1.5 点击分页
+    handleCurrentChange(val) {
+      this.getApiData.page = val;
+      this.getData();
+    },
+    //1.6 重置按钮
+    clearSearchList() {
+      this.tableData = [];
+      this.getApiData.title = "";
+      this.getApiData.level = "";
+
+      this.getApiData.page = 1;
+      this.getApiData.pageSize = 10;
+      this.getData();
+    },
+    //列表和分页相关 end ------------------------------------------------------------>
+    //2.添加新闻 start ------------------------------------------------------------>
+    //跳转到通知发布页面
+    goCreat() {
+      this.$router.push({
+        path: '/addBook',
+      });
+    },
+    goEdit(id) {
+      let data = {
+        id: id
+      }
+      this.$router.push({
+        path: '/addBook',
+        query: data
+      });
+    }
+    //添加新闻 end ------------------------------------------------------------>
+  },
+  mounted() {
+    this.type_id = getUseType()
+    //1.获得初始数据
+    this.getData();
+  }
+}
+</script>
+<style scoped lang="less"></style>

+ 16 - 14
src/views/news/components/tableTitle.vue

@@ -1,7 +1,7 @@
 <template>
   <div class="tableTitle">
     <span class="tableFloatLine"></span>
-    {{name}}
+    {{ name }}
   </div>
 </template>
 
@@ -22,18 +22,20 @@ export default {
 </script>
 
 <style scoped lang="less">
-  .tableTitle {
-    color:#333333;
-    position: relative;
-    padding-bottom: 20px;
-    .tableFloatLine {
-      width: 3px;
-      height:16px;
-      background:#5570F1;
-      display: block;
-      position: absolute;
-      left:-20px;
-      top:1px;
-    }
+.tableTitle {
+  color: #333333;
+  position: relative;
+  padding-bottom: 20px;
+  margin-top: 20px;
+
+  .tableFloatLine {
+    width: 3px;
+    height: 16px;
+    background: #5570F1;
+    display: block;
+    position: absolute;
+    left: -20px;
+    top: 1px;
   }
+}
 </style>

+ 40 - 0
src/views/news/components/tableTitle1.vue

@@ -0,0 +1,40 @@
+<template>
+  <div class="tableTitle">
+    <span class="tableFloatLine"></span>
+    {{ name }}
+  </div>
+</template>
+
+<script>
+export default {
+  props: {
+    name: {
+      type: String,
+      required: true,
+    },
+  },
+  data() {
+    return {
+      someData: '',
+    };
+  },
+};
+</script>
+
+<style scoped lang="less">
+.tableTitle {
+  color: #333333;
+  position: relative;
+  padding-bottom: 20px;
+
+  .tableFloatLine {
+    width: 3px;
+    height: 16px;
+    background: #5570F1;
+    display: block;
+    position: absolute;
+    left: -20px;
+    top: 1px;
+  }
+}
+</style>

+ 46 - 27
src/views/news/creatNews.vue

@@ -7,8 +7,8 @@
           <el-form-item label="资讯题目:" prop="title" class="custom-align-right">
             <el-input v-model="form.title" autocomplete="off" placeholder="请输入资讯标题"></el-input>
             <!-- <el-checkbox v-model="form.islink">是否使用外链</el-checkbox> -->
-            <el-checkbox v-model="form.islink" v-if="creatNews_user_type == 10000">是否使用外链</el-checkbox> 
-             
+            <el-checkbox v-model="form.islink" v-if="creatNews_user_type == 10000">是否使用外链</el-checkbox>
+
           </el-form-item>
           <div v-if="form.islink == true">
             <el-form-item label="站点名称:" prop="web_site_id" class="custom-align-right">
@@ -605,22 +605,32 @@ export default {
 
           this.$store.dispatch('news/addArticle', formData).then(res => {//
             if (res.code == 200) {
-               console.log("资讯发布成功!200")   
+              console.log("资讯发布成功!200")
               //汇报结果
-              this.$message({
-                type: 'success',
-                message: '已成功添加资讯!'
-              });
-              this.cleatForm(2);
-              //返回列表页
-              this.returnPage()
+              if (this.creatNews_user_type == 10000) {
+                this.$message({
+                  type: 'success',
+                  message: '已成功添加资讯!'
+                });
+                this.cleatForm(2);
+                //返回列表页
+                this.returnPage()
+              } else {
+                this.$message({
+                  type: 'success',
+                  message: '待管理员审核!'
+                });
+                this.cleatForm(2);
+                //返回列表页
+                this.returnPage()
+              }
             } else {
-              
               this.$message({
-                              type: 'error',
-                              message: res.message
-                        }); 
- 
+                type: 'error',
+                message: res.message
+              });
+
+
             }
           }).catch(() => {
             this.$message({
@@ -905,21 +915,30 @@ export default {
           this.$store.dispatch('news/updateArticle', formData).then(res => {
             if (res.code != 200) {
 
-              this.$message.error(res.message);
-
-
-            } else {
-              //汇报结果
               this.$message({
-                type: 'success',
-                message: '已成功编辑资讯!'
+                type: 'error',
+                message: res.message
               });
-              this.cleatForm(2);
-              //返回列表页
-              this.returnPage()
-              console.log(this.form);
 
-              // this.form.level=JSON.parse(this.form.level);
+            } else {
+              //汇报结果
+              if (this.creatNews_user_type == 10000) {
+                this.$message({
+                  type: 'success',
+                  message: '已成功编辑资讯!'
+                });
+                this.cleatForm(2);
+                //返回列表页
+                this.returnPage()
+              } else {
+                this.$message({
+                  type: 'success',
+                  message: '待管理员审核!'
+                });
+                this.cleatForm(2);
+                //返回列表页
+                this.returnPage()
+              }
             }
           }).catch(() => {
             this.$message({

+ 9 - 3
src/views/news/examine.vue

@@ -313,13 +313,19 @@ export default {
       this.$confirm('将此文章通过审核吗?', '提示', {
         confirmButtonText: '通过',
         cancelButtonText: '拒绝',
+        distinguishCancelAndClose: true,  // 关键配置项,用于区分取消和关闭按钮
         type: 'warning'
       }).then(() => {
         this.upRow(id, 1)
-      }).catch(() => {
+      }).catch((the_reback) => {
         //输入驳回理由
-        console.log("驳回")
-        this.examineWindow = true;
+        
+        if (the_reback == "cancel") {
+          //输入驳回理由
+          // console.log("驳回" )
+          this.examineWindow = true;
+        }
+
       })
     },
     //1.5 修改文章状态

+ 1657 - 0
src/views/news/jobHuntingApplyDetil.vue

@@ -0,0 +1,1657 @@
+<template>
+    <div class="mainBox">
+        <div class="layerBox">
+            <div id="personalInfo">
+                <tableTitle name="简历详情" />
+                <div class="job_color_box">
+                    <div class="index_1 clearfix">
+                        <div class="seek_head_box clearfix">
+                            <div class="seek_head_left">
+                                <a class="seek_head_a seek_head_only" title="">个人简历</a>
+                            </div>
+                            <div class="seek_head_right_box clearfix">
+                                <span class="seek_head_right_text">更新时间:{{ updated_time }}</span>
+                            </div>
+                        </div>
+                        <div class="index_1_left clearfix">
+                            <div class="seek_introduce_box clearfix">
+                                <div class="seek_introduce_left clearfix">
+                                    <div class="seek_introduce_head clearfix">
+                                        <h4 class="seek_introduce_h4">{{ form.name }}</h4>
+                                    </div>
+                                    <div class="seek_introduce_title_box clearfix">
+                                        <span class="seek_introduce_label">期望岗位:</span>
+                                        <!-- <span class="seek_introduce_title">编辑 记者 网站编辑 </span> -->
+                                        <span class="seek_introduce_title"> {{ job_name_str }} </span>
+                                        <span class="seek_introduce_label">待遇:</span>
+                                        <span class="seek_introduce_title">{{ salary_str }}</span>
+                                    </div>
+                                </div>
+                            </div>
+                            <div class="seek_introduce_foot clearfix">
+                                <span class="seek_introduce_foot_text">{{ form.sexy == 1 ? '男' : '女' }}</span>
+                                <span class="seek_introduce_foot_text">{{ birth_str }}</span>
+                                <span class="seek_introduce_foot_text">籍贯:{{ form.origin }}</span>
+                                <span class="seek_introduce_foot_text"> {{ educat_top_str }}</span>
+                                <span class="seek_introduce_foot_text">{{ job_experience_str }}</span>
+                                <span class="seek_introduce_foot_text"> 工作地点:{{ work_city_str }} </span>
+                                <span class="seek_introduce_foot_text"> {{ language_str }}</span>
+                            </div>
+                        </div>
+                        <div class="index_1_right clearfix">
+                            <img class="index_1_right_img" :src="imgUrl" title="" alt="">
+                        </div>
+                    </div>
+                    <div class="index_2 clearfix">
+                        <div class="seek_head_box clearfix">
+                            <div class="seek_head_left">
+                                <a class="seek_head_a seek_head_only" title="">自我介绍</a>
+                            </div>
+                        </div>
+                        <article class="seek_article">
+                            {{ my_introduce }}
+                        </article>
+                    </div>
+                    <div class="index_3 clearfix">
+                        <div class="seek_head_box clearfix">
+                            <div class="seek_head_left">
+                                <a class="seek_head_a seek_head_only" title="">工作经历</a>
+                            </div>
+                        </div>
+                        <div class="seek_in clearfix" v-for="(per_obj, per_index) in job_experience_introduce_arr"
+                            :key="per_obj">
+                            <div class="seek_in_head clearfix">
+                                <span class="seek_in_head_text">{{ per_index + 1 }}{{ per_obj.company_name }}</span>
+                                <span class="seek_in_head_text">职位类别:{{ per_obj.job_typename }} </span>
+                                <span class="seek_in_head_text">具体职位:{{ per_obj.job_name }} </span>
+                                <span class="seek_in_head_text">{{ per_obj.job_timeList }}</span>
+                            </div>
+                            <div class="seek_in_ul clearfix">
+                                <div class="seek_in_li clearfix">
+                                    <label class="seek_in_label">工作内容:</label>
+                                    <div class="seek_in_li_text">
+                                        {{ per_obj.job_content }}
+                                    </div>
+                                </div>
+                                <div class="seek_in_li clearfix">
+                                    <label class="seek_in_label">工作业绩:</label>
+                                    <div class="seek_in_li_text">{{ per_obj.performance }}</div>
+                                </div>
+                            </div>
+                        </div>
+                    </div>
+                    <div class="index_4 clearfix">
+                        <div class="seek_head_box clearfix">
+                            <div class="seek_head_left">
+                                <a class="seek_head_a seek_head_only" title="">教育背景</a>
+                            </div>
+                        </div>
+                        <div class="seek_in clearfix" v-for="(per_obj, per_index) in education_experience_introduce_arr"
+                            :key="per_obj">
+                            <div class="seek_in_head clearfix">
+                                <span class="seek_in_head_text">{{ per_index + 1 }} {{ per_obj.school_name }}</span>
+                                <span class="seek_in_head_text">{{ per_obj.school_education }}</span>
+                                <span class="seek_in_head_text">{{ per_obj.school_major }}</span>
+                                <span class="seek_in_head_text">{{ per_obj.school_timeList }}</span>
+                            </div>
+                            <div class="seek_in_ul clearfix">
+                                <div class="seek_in_li clearfix">
+                                    <label class="seek_in_label">在校经历:</label>
+                                    <div class="seek_in_li_text">{{ per_obj.school_experience }}</div>
+                                </div>
+                            </div>
+                        </div>
+                    </div>
+                    <div class="index_5 clearfix">
+                        <div class="seek_head_box clearfix">
+                            <div class="seek_head_left">
+                                <a class="seek_head_a seek_head_only" title="">专业技能</a>
+                            </div>
+                        </div>
+                        <div class="seek_in clearfix">
+                            <div class="seek_in_ul clearfix">
+                                <div class="seek_in_li clearfix" v-for="(per_obj, per_index) in profession_skill_arr"
+                                    :key="per_obj">
+                                    <label class="seek_in_label">技能:</label>
+                                    <div class="seek_in_li_text"> {{ per_obj.skill }}</div>
+                                </div>
+                            </div>
+                        </div>
+                    </div>
+                    <div class="index_6 clearfix">
+                        <div class="seek_head_box clearfix">
+                            <div class="seek_head_left">
+                                <a class="seek_head_a seek_head_only" title="">联系方式</a>
+                            </div>
+                        </div>
+                        <div class="seek_in clearfix">
+                            <article class="seek_article_2">
+                                {{ contact_way_phone }}
+                            </article>
+                        </div>
+                    </div>
+                </div>
+            </div>
+            <el-row>
+                <el-button @click="$router.go(-1);" class="job_foot_btn" type="info" round>
+                    返回
+                </el-button>
+            </el-row>
+        </div>
+        <!-- 浮动目录 -->
+        <div class="floating-menu"
+            style="position: fixed; top: 20%; right: 130px; transform: translate(-50%, -50%); z-index: 222; opacity: 0.8; display: none;">
+            <div class="menu-item" @click="scrollToSection('personalInfo')">5个人信息</div>
+            <div class="menu-item" @click="scrollToSection('jobIntentions')">求职意向</div>
+            <div class="menu-item" @click="scrollToSection('professionalSkills')">专业技能</div>
+            <div class="menu-item" @click="scrollToSection('workExperience')">工作经验</div>
+            <div class="menu-item" @click="scrollToSection('educationExperience')">教育经历</div>
+        </div>
+        <div class="layerBox" style="display: none;">
+            <div id="personalInfo">
+                <tableTitle name="个人信息" />
+                <!-- 个人信息表单内容 -->
+            </div>
+            <el-form :model="form" ref="form" :rules="formRules" label-position="left" label-width="120px">
+                <div class="formDiv">
+                    <el-form-item label="头像:" class="custom-align-right" prop="imgUrl">
+                        <div class="uploaderBox">
+                            <el-upload class="avatar-uploader" action="#" :show-file-list="false"
+                                :before-upload="beforeAvatarUpload">
+                                <!-- <img v-if="imgUrl" :src="imgUrl" class="avatar">
+                  <i v-else class="el-icon-plus avatar-uploader-icon"></i> -->
+                                <!-- 预览图片 -->
+                                <img v-if="imgUrl" :src="imgUrl" class="avatar">
+                                <!-- 上传图标 -->
+                                <!-- <i v-else class="el-icon-plus avatar-uploader-icon"></i> -->
+                                <div v-else class="chooseImgDiv">
+                                    <div>
+                                        <img src="@/assets/public/upload/noImage.png">
+                                        <div>选择图片</div>
+                                    </div>
+                                </div>
+                            </el-upload>
+                            <div class="imgBox"
+                                style="color:red;margin-left: 00px ;margin-bottom: 0px; padding-top: 0px;">
+                                请添加图片,上传格式要求jpg、gif、png,不大于500 k</div>
+                        </div>
+                    </el-form-item>
+                    <el-form-item label="姓名:" prop="name" class="custom-align-right">
+                        <template #label>
+                            <span class="askBox">
+                                姓名:
+                            </span>
+                        </template>
+                        <el-input v-model="form.name" autocomplete="off" placeholder="请输入姓名"></el-input>
+                    </el-form-item>
+                    <div v-if="creatNews_user_type != 10000">
+                        <el-form-item label="展示名称:" prop="cat_arr_id" class="custom-align-right">
+                            <el-cascader :key="parentKey" v-model="form.cat_arr_id" placeholder="请选择要绑定的展示名称"
+                                :props="parentData" filterable clearable></el-cascader>
+                        </el-form-item>
+                    </div>
+                    <div v-if="creatNews_user_type == 10000">
+                        <el-form-item label="站点名称:" prop="cat_arr_id" class="custom-align-right">
+                            <el-cascader :key="parentKey" v-model="form.web_site_id" placeholder="请选择站点名称"
+                                :options="creatNews_nav_pool_arr"
+                                @change="creatNews_nav_pool_change_fun(form.web_site_id)" filterable
+                                clearable></el-cascader>
+                        </el-form-item>
+                        <el-form-item label="展示名称:" prop="cat_arr_id" class="custom-align-right">
+                            <el-cascader :key="parentKey_2" v-model="form.cat_arr_id" placeholder="请选择要绑定的父级导航"
+                                :props="parentData_2" filterable clearable></el-cascader>
+                        </el-form-item>
+                    </div>
+                    <el-form-item label="性别:" prop="sexy" class="custom-align-right">
+                        <el-radio-group v-model="form.sexy">
+                            <el-radio :label="1">男</el-radio>
+                            <el-radio :label="2">女</el-radio>
+                        </el-radio-group>
+                    </el-form-item>
+                    <el-form-item label="参加工作时间:" prop="jobtime" class="custom-align-right">
+                        <el-date-picker v-model="form.jobtime" type="date" placeholder="选择参加工作时间">
+                        </el-date-picker>
+                    </el-form-item>
+                    <!-- {{ years }}
+          {{ form.experience }} -->
+                    <el-form-item label="工作经验:" prop="experience" class="custom-align-right" style="width: 100%;">
+                        <el-select v-model="form.experience" placeholder="请选择工作经验">
+                            <el-option v-for="item in years" :key="item.evalue" :label="item.ename"
+                                :value="item.evalue"></el-option>
+                        </el-select>
+                    </el-form-item>
+                    <el-form-item label="手机号:" prop="phone" class="custom-align-right">
+                        <el-input v-model="form.phone" autocomplete="off" placeholder="请输入手机号"></el-input>
+                    </el-form-item>
+                    <el-form-item label="微信号:" prop="wx" class="custom-align-right">
+                        <el-input v-model="form.wx" autocomplete="off" placeholder="请输入微信号"></el-input>
+                    </el-form-item>
+                    <el-form-item label="出生年月:" prop="validity" class="custom-align-right">
+                        <el-date-picker v-model="form.birth" type="date" placeholder="选择出生年月">
+                        </el-date-picker>
+                    </el-form-item>
+                    <el-form-item label="最高学历:" class="custom-align-right" style="width: 100%;">
+                        <el-select v-model="form.educational" placeholder="请选择最高学历" @change='changeCompanyNature()'>
+                            <el-option v-for="item in educations" :key="item.evalue" :label="item.ename"
+                                :value="item.evalue"></el-option>
+                        </el-select>
+                    </el-form-item>
+                    <el-form-item label="政治面貌:" class="custom-align-right" style="width: 100%;">
+                        <el-select v-model="form.politic" placeholder="请选择政治面貌">
+                            <el-option label="群众" :value="1"></el-option>
+                            <el-option label="团员" :value="2"></el-option>
+                            <el-option label="党员" :value="3"></el-option>
+                            <el-option label="其他" :value="4"></el-option>
+                        </el-select>
+                    </el-form-item>
+                    <el-form-item label="籍贯:" prop="origin" class="custom-align-right">
+                        <el-input v-model="form.origin" autocomplete="off" placeholder="请输入籍贯"></el-input>
+                    </el-form-item>
+                    <el-form-item label="语言能力:" class="custom-align-right" style="width: 100%; display: inline;">
+                        <el-select v-model="form.language" placeholder="请选择语种" style="width: 40%;"
+                            @change='changeCompanyNature()'>
+                            <el-option v-for="item in languages" :key="item.evalue" :label="item.ename"
+                                :value="item.evalue"></el-option>
+                        </el-select>
+                        <el-select v-model="form.level" placeholder="请选择掌握程度" style="width: 40%;"
+                            @change='changeCompanyNature()'>
+                            <el-option v-for="item in languagetypes" :key="item.evalue" :label="item.ename"
+                                :value="item.evalue"></el-option>
+                        </el-select>
+                    </el-form-item>
+                    <!-- <el-divider content-position="right"> </el-divider> -->
+                    <div id="jobIntentions" style="margin: 10px 0px;">
+                        <tableTitle name="求职意向" />
+                        <!-- 求职意向表单内容 -->
+                    </div>
+                    <el-form-item label="工作地点:" prop="city_arr_id" class="custom-align-right">
+                        <el-cascader :key="cascaderKey" v-model="form.city_arr_id" placeholder="请选择工作地点"
+                            :props="cityData" filterable clearable></el-cascader>
+                    </el-form-item>
+                    <el-form-item label="职位性质:" class="custom-align-right" style="width: 100%;">
+                        <el-select v-model="form.politic" placeholder="请选择职位性质" @change='changeCompanyNature()'>
+                            <el-option v-for="item in natures" :key="item.evalue" :label="item.ename"
+                                :value="item.evalue"></el-option>
+                        </el-select>
+                    </el-form-item>
+                    <el-form-item label="所属行业:" prop="industry" class="custom-align-right" style="width: 100%;">
+                        <el-select v-model="form.industry" placeholder="请选择所属行业">
+                            <el-option v-for="item in jobIndustry" :key="item.hyid" :label="item.hyname"
+                                :value="item.hyid"></el-option>
+                        </el-select>
+                    </el-form-item>
+                    <el-form-item label="职位分类:" prop="job" class="custom-align-right">
+                        <el-select v-model="form.job" placeholder="请选择职位名称">
+                            <el-option v-for="item in jobPosition" :key="item.zwid" :label="item.zwname"
+                                :value="item.zwid"></el-option>
+                        </el-select>
+                    </el-form-item>
+                    <el-form-item label="职位名称:" prop="job_name_get" class="custom-align-right">
+                        <el-input v-model="form.job_name_get" autocomplete="off" placeholder="请输入职位名称"></el-input>
+                    </el-form-item>
+                    <el-form-item label="公司性质:" v-if="jobNature" prop="company_nature" class="custom-align-right">
+                        <el-select v-model="form.company_nature" placeholder="请选择公司性质" @change='changeCompanyNature()'>
+                            <el-option v-for="item in jobNature" :key="item.evalue" :label="item.nature_name"
+                                :value="item.evalue">
+                            </el-option>
+                        </el-select>
+                    </el-form-item>
+                    <el-form-item label="薪资范围:" prop="salary" class="custom-align-right">
+                        <el-select v-model="form.salary" placeholder="请选择薪资范围" @change='changeCompanyNature()'>
+                            <el-option v-for="item in incomes" :key="item.evalue" :label="item.ename"
+                                :value="item.evalue"></el-option>
+                        </el-select>
+                    </el-form-item>
+                    <el-form-item label="个人评价:" prop="self_evaluation" class="custom-align-right">
+                        <el-input v-model="form.self_evaluation" autocomplete="off" type="textarea" aria-rowspan="6"
+                            placeholder="请输入个人评价"></el-input>
+                    </el-form-item>
+                    <!-- <el-divider content-position="right"> </el-divider> -->
+                    <div id="professionalSkills">
+                        <tableTitle name="专业技能" />
+                        <!-- 专业技能表单内容 -->
+                    </div>
+                    <el-form-item style="margin: 0px;">
+                        <el-button type="primary" @click="addSkill"
+                            style="display:inline-block;float: right;margin-bottom: 0px;">
+                            +
+                            添加</el-button>
+                    </el-form-item>
+                    <el-form-item v-for="(item, index) in form.skillList" :key="index" :label="'技能' + (index + 1) + ':'"
+                        prop="skillList" class="custom-align-right">
+                        <el-input v-model="form.skillList[index].skill" autocomplete="off"
+                            placeholder="请输入专业技能"></el-input>
+                    </el-form-item>
+                    <div id="workExperience">
+                        <tableTitle name="工作经历" />
+                    </div>
+                    <el-form-item style="margin: 0px;">
+                        <el-button type="primary" @click="addExperience"
+                            style="display:inline-block  ;float: right;margin-bottom: 0px;">
+                            +
+                            添加</el-button>
+                    </el-form-item>
+                    <div v-for="(item, index) in form.job_experience" :key="index">
+                        <el-form-item label="公司名称:" prop="company_name" class="custom-align-right" style="width: 100%;">
+                            <el-input v-model="form.job_experience[index].company_name" autocomplete="off"
+                                placeholder="请输入公司名称"></el-input>
+                        </el-form-item>
+                        <el-form-item label="所属行业:" prop="job_industry" class="custom-align-right" style="width: 100%;">
+                            <el-select v-model="form.job_experience[index].job_industry" placeholder="请选择所属行业"
+                                @change='changeCompanyNature()'>
+                                <el-option v-for="item in jobIndustry" :key="item.hyid" :label="item.hyname"
+                                    :value="item.hyid"></el-option>
+                            </el-select>
+                        </el-form-item>
+                        <el-form-item label="职位名称:" prop="job_name" class="custom-align-right">
+                            <el-select v-model="form.job_experience[index].job_name" placeholder="请选择职位名称"
+                                @change='changeCompanyNature()'>
+                                <el-option v-for="item in jobPosition" :key="item.zwid" :label="item.zwname"
+                                    :value="item.zwid"></el-option>
+                            </el-select>
+                        </el-form-item>
+                        <el-form-item label="所属部门:" prop="department" class="custom-align-right">
+                            <el-input v-model="form.job_experience[index].department" autocomplete="off"
+                                placeholder="请输入所属部门"></el-input>
+                        </el-form-item>
+                        <el-form-item label="在职时间:" prop="job_timeList" class="custom-align-right">
+                            <el-date-picker v-model="form.job_experience[index].job_timeList" type="daterange"
+                                range-separator="至" start-placeholder="开始日期" end-placeholder="结束日期"
+                                :picker-options="pickerOptions">
+                            </el-date-picker>
+                        </el-form-item>
+                        <el-form-item label="工作内容:" prop="job_content" class="custom-align-right">
+                            <el-input v-model="form.job_experience[index].job_content" autocomplete="off"
+                                type="textarea" aria-rowspan="6" placeholder="请输入工作内容"></el-input>
+                        </el-form-item>
+                        <el-form-item label="工作业绩:" prop="performance" class="custom-align-right">
+                            <el-input v-model="form.job_experience[index].performance" autocomplete="off"
+                                type="textarea" aria-rowspan="6" placeholder="请输入工作业绩"></el-input>
+                        </el-form-item>
+                        <el-divider></el-divider>
+                    </div>
+                    <div id="educationExperience">
+                        <tableTitle name="教育经历" />
+                        <!-- 教育经历表单内容 -->
+                    </div>
+                    <el-form-item style="margin: 0px;">
+                        <el-button type="primary" @click="addEducation"
+                            style="display:inline-block  ;float: right;margin-bottom: 0px;">
+                            +
+                            添加</el-button>
+                    </el-form-item>
+                    <div v-for="(item, index) in form.education_experience" :key="index">
+                        <el-form-item label="学校名称:" prop="school_name" class="custom-align-right">
+                            <el-input v-model="form.education_experience[index].school_name" autocomplete="off"
+                                placeholder="请输入学校名称"></el-input>
+                        </el-form-item>
+                        <el-form-item label="学历:" prop="school_education" class="custom-align-right"
+                            style="width: 100%;">
+                            <el-select v-model="form.education_experience[index].school_education" placeholder="请选择学历"
+                                @change='changeCompanyNature()'>
+                                <el-option v-for="item in educations" :key="item.evalue" :label="item.ename"
+                                    :value="item.evalue"></el-option>
+                            </el-select>
+                        </el-form-item>
+                        <el-form-item label="专业:" prop="school_major" class="custom-align-right">
+                            <el-input v-model="form.education_experience[index].school_major" autocomplete="off"
+                                placeholder="请输入专业"></el-input>
+                        </el-form-item>
+                        <el-form-item label="时间段:" prop="school_timeList" class="custom-align-right">
+                            <el-date-picker v-model="form.education_experience[index].school_timeList" type="daterange"
+                                range-separator="至" start-placeholder="开始日期" end-placeholder="结束日期"
+                                :picker-options="pickerOptions">
+                            </el-date-picker>
+                        </el-form-item>
+                        <el-form-item label="在校经历:" prop="school_experience" class="custom-align-right">
+                            <el-input v-model="form.education_experience[index].school_experience" autocomplete="off"
+                                type="textarea" aria-rowspan="6" placeholder="请输入在校经历"></el-input>
+                        </el-form-item>
+                        <!-- <el-divider content-position="right"> </el-divider> -->
+                    </div>
+                </div>
+            </el-form>
+        </div>
+    </div>
+</template>
+<script>
+import { getWebSiteId, getUseType } from '@/utils/auth'
+//表格标题
+import tableTitle from './components/tableTitle';
+//引入公用样式
+import '@/styles/global.less';
+//格式化时间
+import { formatLocalDate } from '@/utils/public';
+import { get_creatNews_nav_api } from '@/api/pool';
+export default {
+    components: {
+        tableTitle
+    },
+    data() {
+        //0.全局操作 start ------------------------------------------------------------>
+        //表单验证
+        const validateEmpty = (rule, value, callback) => {
+            console.log(value, '-------------value--------')
+            console.log(rule, '-------------rule--------')
+            if (value == '') {
+                callback(new Error('该项不能为空!'))
+            } else {
+                callback()
+            }
+        }
+        const validateArray = (rule, value, callback) => {
+            console.log(value, '-------------value--------')
+            if (value.length == 0) {
+                callback(new Error('该项不能为空!'))
+            } else {
+                callback()
+            }
+        }
+        const validateArraySkill = (rule, value, callback) => {
+            console.log(value, '-------------value--------')
+            //查看value中的skill是不是为空
+            let $values = value.filter(item => {
+                return item.skill == ''
+            })
+            if ($values.length > 0) {
+                callback(new Error('技能项不能有空!'))
+            } else {
+                callback()
+            }
+        }
+        const validateCompanyNameEmpty = (rule, value, callback) => {
+            console.log(value, '-------------value--------')
+            if (value.length == 0) {
+                callback(new Error('该项不能为空!'))
+            }
+            value.forEach(item => {
+                if (item == '') {
+                    callback(new Error('公司名称不能为空!'))
+                }
+            })
+            callback()
+        }
+        const validateJobIndustryEmpty = (rule, value, callback) => {
+            console.log(value, '-------------value--------')
+            if (value == '') {
+                callback(new Error('该项不能为空!'))
+            }
+            value.forEach(item => {
+                if (item == '') {
+                    callback(new Error('所属行业不能为空!'))
+                }
+            })
+            callback()
+        }
+        const validateJobContentEmpty = (rule, value, callback) => {
+            console.log(value, '-------------value--------')
+            if (value.length == 0) {
+                callback(new Error('该项不能为空!'))
+            }
+            value.forEach(item => {
+                if (item == '') {
+                    callback(new Error('工作内容不能为空!'))
+                }
+            })
+            callback()
+        }
+        const validateJobNameEmpty = (rule, value, callback) => {
+            console.log(value, '--------1-----value--------')
+            if (value == '') {
+                callback(new Error('该项不能为空!'))
+            }
+            value.forEach(item => {
+                if (item == '') {
+                    callback(new Error('职位名称不能为空!'))
+                }
+            })
+            callback()
+        }
+        const validateJobTimeListEmpty = (rule, value, callback) => {
+            console.log(value, '-------------value--------')
+            if (value == '') {
+                callback(new Error('该项不能为空!'))
+            }
+            value.forEach(item => {
+                if (item == '') {
+                    callback(new Error('工作时间不能为空!'))
+                }
+            })
+            callback()
+        }
+        const validateNumber = (rule, value, callback) => {
+            console.log(value, '-------------value--------')
+            if (value == '') {
+                callback(new Error('该项不能为空!'))
+            } else if (isNaN(value)) {
+            }
+        }
+        let self = this;
+        //0.全局操作 end ------------------------------------------------------------>
+        return {
+            jobIndustry: {},
+            jobNature: [],
+            jobPosition: {},
+            jobEnum: {},
+            educations: [],
+            languages: [],
+            languagetypes: [],
+            natures: [],
+            maritals: [],
+            incomes: [],
+            timeList: [],
+            // imgurl: "http://img.bjzxtw.org.cn/dev/image/jpeg/20250220/1740044079754901.png",
+            imgUrl: "",
+            websiteid: 0,
+            cascaderKey: 0,//弹窗用的key
+            creatNews_pid_num: "0",//请求子导航用的pid
+            creatNews_nav_pool_arr: [],//
+            creatNews_add_nav_pool_arr: [],//
+            creatNews_son_website_id_num: "",
+            checked: false,
+            formLabelWidth: '80px',//表单的长度
+            //1.表单项 start ------------------------------------------------------------>
+            editStatus: false,
+            tableDivTitle: "添加求职",
+            disclaimer: true,//免责声明
+            //提交表单
+            creatNews_user_type: 0,//判断用户类型'
+            moon_arr: ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'],
+            birth_str: "",//生日  
+            educat_top_arr: [], //最高学历  
+            educat_top_num: 0, //最高学历  
+            educat_top_str: "",//最高学历
+            job_experience_str: "",//工作工作经验
+            job_experience_num: 0,//工作工作经验
+            job_experience_year_arr: [],//工作工作经验
+            language_arr: [], //语言
+            language_num: 0, //语言
+            language_str: "",//语言
+            // 期望薪资
+            salary_arr: [],//期望薪资
+            salary_num: 0,//期望薪资
+            salary_str: "",//待遇
+            //  更新时间
+            updated_time: "",
+            // 自我介绍
+            my_introduce: "",
+            // 期望岗位
+            job_name_str: "",//期望岗位
+            job_name_num: 0,//期望岗位
+            job_name_arr: [],//期望岗位
+            //工作经历-自我介绍
+            // my_introduce_industry_arr:[],//工作经历-自我介绍-行业
+            job_experience_introduce_arr: [],//工作经历-自我介绍
+            //教育经历 -自我介绍
+            education_experience_introduce_arr: [],
+            educations_level_arr: [],
+            //专业技能-自我介绍
+            profession_skill_arr: [],
+            // 联系方式
+            contact_way_phone: "",//联系方式
+            contact_way_wx: "",//联系方式
+            // 工作地点
+            work_place_arr: [],//工作地点
+            city_id_arr: [],
+            work_city_str: "",//工作地点
+            form: {
+                experience: '',//工作经验
+                industry: 1,//行业
+                job: 1,//职位
+                self_evaluation: '',//自我评价
+                city_arr_id: [],
+                skillList: [{ 'skill': '' }],
+                job_experience: [{
+                    company_name: '',
+                    job_industry: 1,
+                    job_name: 1,
+                    department: '',
+                    // job_timeList: ['2025-02-21 00:00:00', '2025-02-29 00:00:00'],
+                    job_timeList: [],
+                    performance: '',
+                    job_content: ''
+                }],//工作经验
+                education_experience: [{
+                    school_name: '',
+                    school_education: '',
+                    school_major: '',
+                    school_timeList: '',
+                    school_experience: ''
+                }],//教育经历
+                // 用于存储所有专业技能
+                slelf_evaluation: '',//自我评价
+                cat_arr_id: [],//导航池名称
+                web_site_id: 0,
+                name: "",
+                sexy: 1,
+                // jobtime: "2025-02-21 00:00:00",//工作时间
+                jobtime: "",//工作时间
+                origin: "",
+                //校验专用
+                industry: '',//行业
+                job_name: [],//职位名称
+                job: '',//职位名称
+                company_name: [],//公司名称
+                job_industry: [],//行业
+                job_name: [],//职位名称
+                department: [],//所属部门
+                job_timeList: [],//工作时间
+                job_content: [],//工作内容
+            },
+            //1.2 表单验证规则
+            formRules: {
+                skillList: [{ required: true, trigger: 'blur', validator: validateArraySkill }],
+                salary: [{ required: true, trigger: 'blur', validator: validateEmpty }],
+                //求职名称不能为空
+                name: [{ required: true, trigger: 'blur', validator: validateEmpty }],
+                imgUrl: [{ required: true, trigger: 'blur', validator: validateEmpty }],
+                sexy: [{ required: true, trigger: 'blur', validator: validateEmpty }],
+                jobtime: [{ required: true, trigger: 'blur', validator: validateEmpty }],
+                origin: [{ required: true, trigger: 'blur', validator: validateEmpty }],
+                city_arr_id: [{ required: true, trigger: 'blur', validator: validateEmpty }],
+                industry: [{ required: true, trigger: 'blur', validator: validateEmpty }],
+                job: [{ required: true, trigger: 'blur', validator: validateEmpty }],
+                slelf_evaluation: [{ required: true, trigger: 'blur', validator: validateEmpty }],
+                company_name: [{ required: true, trigger: 'blur', validator: validateCompanyNameEmpty }],
+                job_industry: [{ required: true, trigger: 'blur', validator: validateJobIndustryEmpty }],
+                job_name: [{ required: true, trigger: 'blur', validator: validateJobNameEmpty }],
+                job_timeList: [{ required: true, trigger: 'blur', validator: validateJobTimeListEmpty }],
+                job_content: [{ required: true, trigger: 'blur', validator: validateJobContentEmpty }],
+                cat_arr_id: [{ required: true, trigger: 'blur', validator: validateArray }],
+            },
+            //1.3富文本编辑器配置
+            //1.4图片上传
+            //获取父级导航池
+            parentKey: 0,//获取父级导航
+            parentData: {
+                checkStrictly: true,
+                lazy: true,
+                async lazyLoad(node, resolve) {
+                    const { level, data } = node;
+                    if (data && data.children && data.children.length !== 0) {
+                        return resolve(node)
+                    }
+                    console.log(level)
+                    let parentId = level == 0 ? 0 : data.value
+                    let parames = {
+                        'pid': parentId
+                    }
+                    self.$store.dispatch('pool/categoryList', parames).then(res => {
+                        if (res.data) {
+                            const nodes = res.data.map(item => ({
+                                value: item.id,
+                                label: item.name,
+                                leaf: level >= 3,
+                                children: []
+                            }))
+                            resolve(nodes)
+                        }
+                    })
+                }
+            },
+            //时间跨度
+            pickerOptions: {
+                selectableRange: '1900-01-01 to 2100-12-31', // 允许选择的日期范围
+                // disabledDate(time) {
+                //   return time.getTime() < Date.now() - 86400000; // 禁用今天之前的日期
+                // },
+            },
+            parentKey_2: 0,//获取父级导航
+            parentData_2: {
+                checkStrictly: true,
+                lazy: true,
+                async lazyLoad(node, resolve) {
+                    const { level, data } = node;
+                    if (data && data.children && data.children.length !== 0) {
+                        return resolve(node)
+                    }
+                    let parentId;
+                    if (data != undefined) {
+                        parentId = data.value;
+                    } else {
+                        parentId = self.creatNews_pid_num.toString();
+                    }
+                    let parames = {
+                        'website_id': self.form.web_site_id ? self.form.web_site_id : self.websiteid,
+                        'pid': parentId
+                    }
+                    self.$store.dispatch('pool/get_creatNews_nav_son_actions', parames).then(res => {
+                        if (res.data) {
+                            const nodes = res.data.map(item => ({
+                                value: item.category_id,
+                                label: item.name,
+                                leaf: level >= 3,
+                                children: []
+                            }))
+                            resolve(nodes)
+                        }
+                    })
+                }
+            },
+            cityData: {//
+                checkStrictly: true,
+                lazy: true,
+                async lazyLoad(node, resolve) {
+                    const { level, data } = node;
+                    if (data && data.children && data.children.length !== 0) {
+                        return resolve(node)
+                    }
+                    // console.log(level, '====level-----')
+                    let parentId = level == 0 ? 0 : data.value
+                    let parames = {
+                        'pid': parentId
+                    }
+                    self.$store.dispatch('pool/getcityList', parames).then(res => {
+                        if (res.data) {
+                            const nodes = res.data.map(item => ({
+                                value: item.id,
+                                label: item.name,
+                                leaf: level >= 3,
+                                children: []
+                            }))
+                            res.data.forEach((per_obj, per_index) => {//工作地点 
+                                if (self.city_id_arr[level] == per_obj.id) {
+                                    if (level == 0) {
+                                        self.work_city_str = self.work_city_str + "" + per_obj.name;
+                                    } else {
+                                        self.work_city_str = self.work_city_str + ">>" + per_obj.name;
+                                    }
+                                }
+                                return
+                            })
+                            resolve(nodes)
+                        }
+                    })
+                }
+            },
+            inputList: [
+                { value: '' }
+            ]
+            //表单项 end ------------------------------------------------------------>
+        };
+    },
+    methods: {
+        changeCompanyNature(val) {
+            this.$forceUpdate();
+        },
+        getJobHuntingData() {//xx xx
+            this.$store.dispatch('news/getJobHuntingData', {}).then(res => {
+                if (res.code == 200) {
+                    this.jobEnum = res.data.jobEnum;
+                    this.educations = this.jobEnum.filter(item => item.egroup === 'education');
+                    this.languages = this.jobEnum.filter(item => item.egroup === 'language');
+                    this.languagetypes = this.jobEnum.filter(item => item.egroup === 'languagetype');
+                    this.natures = this.jobEnum.filter(item => item.egroup === 'nature');
+                    this.maritals = this.jobEnum.filter(item => item.egroup === 'marital');
+                    this.incomes = this.jobEnum.filter(item => item.egroup === 'income');
+                    this.years = this.jobEnum.filter(item => item.egroup === 'years');
+                    this.jobIndustry = res.data.jobIndustry;
+                    this.jobNature = res.data.jobNature;
+                    this.jobPosition = res.data.jobPosition;
+                    //   最高学历
+                    this.educat_top_arr = this.jobEnum.filter(item => item.egroup === 'education');
+                    this.educat_top_arr.map((val, index, arr) => {
+                        if (val.evalue == this.educat_top_num) {
+                            this.educat_top_str = val.ename;
+                        }
+                    });
+                    // 工作工作经验  
+                    this.job_experience_year_arr = this.jobEnum.filter(item => item.egroup === 'years');
+                    this.job_experience_year_arr.map((val, index, arr) => {
+                        if (val.evalue == this.job_experience_num) {
+                            this.job_experience_str = val.ename;
+                        }
+                    });
+                    // 语言能力 
+                    this.language_arr = this.jobEnum.filter(item => item.egroup === 'language');
+                    this.language_arr.map((val, index, arr) => {
+                        if (val.evalue == this.language_num) {
+                            this.language_str = val.ename;
+                        }
+                    });
+                    // 期望岗位
+                    this.job_name_arr = res.data.jobPosition;
+                    this.job_name_arr.map((val, index, arr) => {
+                        if (val.zwid == this.job_name_num) {
+                            this.job_name_str = val.zwname;
+                        }
+                    });
+                    // 薪资范围
+                    this.salary_arr = this.jobEnum.filter(item => item.egroup === 'income');
+                    this.salary_arr.map((val, index, arr) => {
+                        if (val.evalue == this.salary_num) {
+                            this.salary_str = val.ename;
+                        }
+                    });
+                    // 工作经历-自我介绍 
+                    this.job_experience_introduce_arr.map((val, index, arr) => {
+                        //工作经历-自我介绍-时间
+                        let open_job_time = val.job_timeList[0].split("T")[0]
+                        let over_job_time = val.job_timeList[1].split("T")[0]
+                        val.job_timeList = open_job_time + "--" + over_job_time;
+                        let the_num = val.job_name//工作经历-自我介绍-具体职位
+                        this.job_name_arr.map((val_2, index_2, arr_2) => {
+                            if (val_2.zwid == the_num) {
+                                val.job_name = val_2.zwname;
+                            }
+                        })
+                        let the_num_3 = val.job_typename//工作经历-自我介绍-职位类别
+                        this.job_name_arr.map((val_3, index_3, arr_3) => {
+                            if (val_3.zwid == the_num_3) {
+                                val.job_typename = val_3.zwname;
+                            }
+                        })
+                        // let the_num_4 = val.job_industry
+                        // this.job_name_arr.map((val_4,index_4,arr_4) => {//工作经历-自我介绍-具体职位
+                        //   if (val_4.zwid == the_num_4) {
+                        //     val.job_industry = val_4.zwname+"?";
+                        //   }
+                        // })
+                    });
+                    // 教育背景-自我介绍 
+                    this.educations_level_arr = this.jobEnum.filter(item => item.egroup === 'education');
+                    this.education_experience_introduce_arr.map((val, index, arr) => {
+                        //教育背景-自我介绍-时间
+                        let open_school_time = val.school_timeList[0].split("T")[0]
+                        let over_school_time = val.school_timeList[1].split("T")[0]
+                        val.school_timeList = open_school_time + "--" + over_school_time;
+                        this.educations_level_arr.map((val_1, index_1, arr_1) => {
+                            if (val_1.evalue == val.school_education) {
+                                val.school_education = val_1.ename;
+                            }
+                        })
+                    })
+                }
+            })
+        },
+        // ... 其他方法
+        addSkill() {
+            //判断skill是不是为空,为空则不能添加
+            const hasEmptySkill = this.form.skillList.some(item => {
+                if (item.skill == '') {
+                    this.$message.error('请先填写专业技能');
+                    return true; // 返回 true 表示找到了空的 skill
+                }
+                return false; // 返回 false 表示没有找到空的 skill
+            });
+            if (hasEmptySkill) {
+                return; // 如果有空的 skill,则提前结束 addSkill 方法
+            }
+            this.form.skillList.push({ skill: '' });
+        },
+        addExperience() {
+            const hasEmptyExperience = this.form.job_experience.some(item => {
+                if (item.company_name == '' || item.job_industry == '' || item.job_name == '' || item.job_timeList == '' || item.job_content == '') {
+                    this.$message.error('请先填写工作经历');
+                    return true; // 返回 true 表示找到了空的 skill
+                }
+                return false;
+            })
+            if (hasEmptyExperience) {
+                return; // 如果有空的 skill,则提前结束 addSkill 方法
+            }
+            this.form.job_experience.push({
+                company_name: '',
+                job_industry: '',
+                job_name: '',
+                department: '',
+                job_timeList: '',
+                performance: '',
+                job_content: ''
+            });
+        },
+        addEducation() {
+            const hasEmptyEducation = this.form.education_experience.some(item => {
+                if (item.school_name == '') {
+                    this.$message.error('请先填写学校名称');
+                    return true; // 返回 true 表示找到了空的 skill
+                }
+            })
+            if (hasEmptyEducation) {
+                return; // 如果有空的 skill,则提前结束 addSkill 方法
+            }
+            this.form.education_experience.push({
+                school_name: '',
+                degree: '',
+                major: '',
+                graduation_time: ''
+            });
+        },
+        scrollToSection(id) {
+            const element = document.getElementById(id);
+            if (element) {
+                element.scrollIntoView({ behavior: 'smooth' });
+            }
+        },
+        //1.提交表单 start ------------------------------------------------------------>
+        //1.1 直接上传图片
+        beforeAvatarUpload(file) {
+            const isJPG = file.type === 'image/jpeg';
+            const isPNG = file.type === 'image/png';
+            const isLt2M = file.size / 1024 / 1024 < 2;
+            if (!isJPG && !isPNG) {
+                this.$message.error('上传缩略图只能是 JPG 或 PNG 格式!');
+                return false;
+            }
+            if (!isLt2M) {
+                this.$message.error('上传缩略图大小不能超过 2MB!');
+                return false;
+            }
+            const formData = new FormData();
+            formData.append('file', file);
+            this.$store.dispatch('pool/uploadFile', formData).then(res => {
+                this.imgUrl = res.data.imgUrl;//显示缩略图
+                this.form.imgUrl = res.data.imgUrl;//提供表单地址
+                // this.$set(this, 'imgUrl', res.data.imgUrl); // 设置 imgUrl
+                // this.$set(this.form, 'imgurl', res.data.imgUrl); // 设置 form.imgurl
+                console.log(res.data.imgUrl)
+                console.log(this.imgurl, '-------------imgurl-----2---')
+                console.log(this.form.imgUrl, '-------------form.imgurl--------')
+            })
+            // 阻止默认的上传行为
+            return false;
+        },
+        //1.2 提交表单
+        addToServe() {
+            //先进行验证
+            console.log(this.form, '-------------form1--------');
+            this.$refs.form.validate(valid => {
+                if (valid) {
+                    // 创建 form 对象的深拷贝
+                    const formCopy = JSON.parse(JSON.stringify(this.form));
+                    // 在副本上进行 JSON 转换
+                    formCopy.job_experience = JSON.stringify(formCopy.job_experience);
+                    formCopy.education_experience = JSON.stringify(formCopy.education_experience);
+                    formCopy.skillList = JSON.stringify(formCopy.skillList);
+                    formCopy.city_arr_id = JSON.stringify(formCopy.city_arr_id);
+                    formCopy.cat_arr_id = JSON.stringify(formCopy.cat_arr_id);
+                    formCopy.website_id = formCopy.web_site_id == 0 ? this.websiteid : formCopy.web_site_id;
+                    // 去掉 formCopy.web_site_id
+                    delete formCopy.web_site_id;
+                    if (formCopy.website_id == 0) {
+                        this.$message.error('请选择站点名称');
+                        return;
+                    }
+                    if (formCopy.jobtime != '' && formCopy.jobtime != null && formCopy.jobtime != undefined) {
+                        formCopy.jobtime = formatLocalDate(formCopy.jobtime);
+                    } else {
+                        formCopy.jobtime = null;
+                    }
+                    console.log(formCopy.birth, "-----------------birth----------");
+                    if (formCopy.birth != '' && formCopy.birth != null && formCopy.birth != undefined) {
+                        formCopy.birth = formatLocalDate(formCopy.birth);
+                    } else {
+                        formCopy.birth = null;
+                    }
+                    formCopy.job_timeList.forEach(item => {
+                        item = formatLocalDate(item);
+                    });
+                    console.log(new Date().getTime(), '-------------------校验结束------------------');
+                    //判断用户身份
+                    if (this.creatNews_user_type == 10000) {
+                        console.log("用户身份为管理员,无需审核直接发布!")
+                        this.form.status = 2;
+                    } else {
+                        console.log("用户身份为其他用户,提交到审核!")
+                        this.form.status = 1;
+                    }
+                    this.$store.dispatch('news/addJobHunting', formCopy).then(res => {
+                        if (res.code == 200) {
+                            //汇报结果
+                            this.$message({
+                                type: 'success',
+                                message: '已成功添加求职!'
+                            });
+                            this.cleatForm(2);
+                            //返回列表页
+                            this.returnPage()
+                        } else {
+                            this.$message({
+                                type: 'error',
+                                message: "求职发布失败,请稍后再试!"
+                            });
+                        }
+                    }).catch(() => {
+                        this.$message({
+                            type: 'info',
+                            message: '网络错误,请重试!'
+                        });
+                    })
+                }
+            })
+        },
+        //1.3 清理表单
+        cleatForm(type) {
+            this.form = {
+                title: '',//求职标题
+                islink: 0,//是否使用外链 0非 1是
+                linkurl: "",//外链地址
+                //1.2没有使用外链
+                cat_arr_id: '',//导航池名称
+                level: "",//推荐等级
+                web_site_id: 0,
+                name: "",
+                sexy: 1,
+                jobtime: "",//工作时间
+                //校验专用
+                company_name: [],//公司名称
+                job_industry: [],//行业
+                job_name: [],//职位名称
+                department: [],//所属部门
+                job_timeList: [],//工作时间
+                job_content: [],//工作内容
+            };
+            this.imgUrl = "";
+        },
+        //提交表单 end ------------------------------------------------------------>
+        //2.跳转操作 start ------------------------------------------------------------>
+        returnPage() {
+            this.$router.push({
+                path: '/jobHuntingList',
+            });
+        },
+        //跳转操作 end ------------------------------------------------------------>
+        //3.回显操作 ------------------------------------------------------------>
+        //3.1回显数据xx
+        getMainData() {
+            let data = {
+                id: this.$route.query.id
+            };
+            this.$store.dispatch('news/getJobHuntingInfo', data).then(res => {
+                this.form.cat_arr_id = Array.isArray(res.data.cat_arr_id) ? res.data.cat_arr_id : JSON.parse(res.data.cat_arr_id);
+                this.parentKey += 1; // 触发级联选择器重新加载
+                this.loadCascaderPath(this.form.cat_arr_id); // 加载路径数据
+                this.form.name = res.data.name;
+                this.form.sexy = res.data.sexy;
+                this.form.age = res.data.age;
+                this.form.phone = res.data.phone;
+                this.form.email = res.data.email;
+                this.form.wx = res.data.wx;
+                this.form.company_nature = res.data.company_nature;
+                this.form.salary = res.data.salary;
+                this.form.self_evaluation = res.data.self_evaluation;
+                this.form.job = parseInt(res.data.job);
+                this.form.industry = res.data.industry;
+                this.form.experience = res.data.experience;
+                this.form.educational = res.data.educational;
+                this.form.politic = res.data.politic;
+                this.form.language = res.data.language;
+                this.form.level = res.data.level;
+                this.form.address = res.data.address;
+                this.form.content = res.data.content;
+                this.form.imgUrl = res.data.imgurl;
+                this.imgUrl = res.data.imgurl;
+                this.form.web_site_id = res.data.website_id;
+                this.form.jobtime = res.data.jobtime ? new Date(res.data.jobtime) : '';
+                this.form.birth = res.data.birth ? new Date(res.data.birth) : '';
+                this.form.origin = res.data.origin;
+                this.form.city_arr_id = Array.isArray(res.data.city_arr_id) ? res.data.city_arr_id : JSON.parse(res.data.city_arr_id);
+                this.form.job_experience = JSON.parse(res.data.job_experience);
+                this.form.education_experience = JSON.parse(res.data.education_experience);
+                this.form.skillList = JSON.parse(res.data.skillList);
+                this.birth_str = res.data.birth ? new Date(res.data.birth) : '';
+                if (this.birth_str == "") {// 生日  
+                } else {
+                    let birth_arr = String(this.birth_str).split(" ");
+                    this.moon_arr.map((val, index, arr) => {
+                        if (birth_arr[1] == this.moon_arr[index]) {
+                            birth_arr[1] = index + 1
+                        }
+                    });
+                    this.birth_str = birth_arr[3] + "-" + birth_arr[1] + "-" + birth_arr[2];
+                }
+                // 最高学历
+                this.educat_top_num = +(res.data.educational);
+                //工作工作经验
+                this.job_experience_num = res.data.experience;//工作经验
+                //工作经历-自我介绍
+                this.job_experience_introduce_arr = JSON.parse(res.data.job_experience);//工作经验
+                //语言
+                this.language_num = res.data.language;//语言
+                // 期望岗位
+                this.job_name_num = res.data.job_name_get;
+                //  薪资范围
+                this.salary_num = res.data.salary;
+                //  更新时间
+                this.updated_time = res.data.updated_at ? res.data.updated_at : '';
+                // 自我介绍
+                // this.my_introduce_industry_num= res.data.industry //工作经历-自我介绍-行业
+                this.my_introduce = res.data.self_evaluation ? res.data.self_evaluation : '';
+                // 教育背景-自我介绍
+                this.education_experience_introduce_arr = JSON.parse(res.data.education_experience);
+                //专业技能-自我介绍
+                this.profession_skill_arr = JSON.parse(res.data.skillList);
+                //联系方式
+                this.contact_way_phone = res.data.phone;
+                // 工作地点
+                this.city_id_arr = Array.isArray(res.data.city_arr_id) ? res.data.city_arr_id : JSON.parse(res.data.city_arr_id);
+            }).catch(() => {
+                this.$message({
+                    type: 'info',
+                    message: '网络错误,请重试!'
+                });
+            })
+        },
+        async loadCascaderPath(path) {
+            for (let i = 0; i < path.length; i++) {
+                const parentId = path[i - 1] || 0; // 获取当前层级的父级ID
+                const level = i; // 当前层级的索引
+                await this.$store.dispatch('pool/categoryList', { pid: parentId })
+                    .then((res) => {
+                        const nodes = res.data.map(item => ({
+                            value: item.id,
+                            label: item.name,
+                            leaf: level >= 3, // 假设4层结构,设置叶子节点标记
+                        }));
+                        // 级联选择器加载数据
+                        if (level === path.length - 1) {
+                            this.form.cat_arr_id = path; // 确保最后一级路径正确设置
+                            this.parentKey += 1; // 强制刷新 cascader
+                        }
+                    });
+            }
+        },
+        //1.3提交修改
+        editToServe() {
+            //提交之前先判断是否为外链
+            //如果使用了外链,清理掉除了外链以外的内容
+            //添加要修改的id
+            this.form.id = this.editId;
+            //先进行验证
+            let startTime = new Date().getTime();
+            console.log(startTime, '-------------------开始------------------');
+            this.$refs.form.validate(valid => {
+                //记录开始时间
+                let startTime1 = new Date().getTime();
+                console.log(startTime1, '-------------------校验开始------------------');
+                if (valid) {
+                    console.log(this.form)
+                    // 创建 form 对象的深拷贝
+                    const formCopy = JSON.parse(JSON.stringify(this.form));
+                    // 在副本上进行 JSON 转换
+                    formCopy.job_experience = JSON.stringify(formCopy.job_experience);
+                    formCopy.education_experience = JSON.stringify(formCopy.education_experience);
+                    formCopy.skillList = JSON.stringify(formCopy.skillList);
+                    formCopy.city_arr_id = JSON.stringify(formCopy.city_arr_id);
+                    formCopy.cat_arr_id = JSON.stringify(formCopy.cat_arr_id);
+                    formCopy.website_id = formCopy.web_site_id == 0 ? this.websiteid : formCopy.web_site_id;
+                    // 去掉 formCopy.web_site_id
+                    delete formCopy.web_site_id;
+                    if (formCopy.website_id == 0) {
+                        this.$message.error('请选择站点名称');
+                        return;
+                    }
+                    if (formCopy.jobtime != '' && formCopy.jobtime != null && formCopy.jobtime != undefined) {
+                        formCopy.jobtime = formatLocalDate(formCopy.jobtime);
+                    } else {
+                        formCopy.jobtime = null;
+                    }
+                    console.log(formCopy.birth, "-----------------birth----------");
+                    if (formCopy.birth != '' && formCopy.birth != null && formCopy.birth != undefined) {
+                        formCopy.birth = formatLocalDate(formCopy.birth);
+                    } else {
+                        formCopy.birth = null;
+                    }
+                    formCopy.job_timeList.forEach(item => {
+                        item = formatLocalDate(item);
+                    });
+                    console.log(new Date().getTime(), '-------------------校验结束------------------');
+                    //判断用户身份
+                    if (this.creatNews_user_type == 10000) {
+                        console.log("用户身份为管理员,无需审核直接发布!")
+                        this.form.status = 2;
+                    } else {
+                        console.log("用户身份为其他用户,提交到审核!")
+                        this.form.status = 1;
+                    }
+                    this.$store.dispatch('news/updateJobHunting', formCopy).then(res => {
+                        //记录结束时间
+                        let endTime = new Date().getTime(); //计算时间差
+                        console.log(endTime, '-------------------结束------------------');
+                        let time = endTime - this.startTime;
+                        //记录时间差
+                        console.log('时间差'.time, '------------------2--------');
+                        if (res.code != 200) {
+                            this.$message.error("修改失败,请稍后再试!");
+                        } else {
+                            //汇报结果
+                            this.$message({
+                                type: 'success',
+                                message: '已成功编辑求职!'
+                            });
+                            this.cleatForm(2);
+                            //返回列表页
+                            this.returnPage()
+                        }
+                    }).catch(() => {
+                        this.$message({
+                            type: 'info',
+                            message: '网络错误,请重试!'
+                        });
+                    })
+                }
+            })
+        },
+        //跳转操作 end ------------------------------------------------------------>
+        get_creatNews_form_id_fun() {//判断用户类型ajax
+            this.$store.dispatch('public/getInfo').then(res => {
+                //     console.log("res======",res)
+                // this.form.user_type = res.data.type_id;
+            }).catch(() => {
+                this.$message({
+                    type: 'info',
+                    message: '网络错误,请重试!'
+                });
+            })
+            // console.log("this.form.user_type==",this.form);
+            // console.log("this.form.user_type==2",this.form.user_type);
+        },
+        get_creatNews_nav_pool_arr_fun() {
+            this.$store.dispatch('pool/get_creatNews_nav_actions', { page: 1, pageSize: 666666 }).then(res => {
+                res.data.rows.forEach((per_obj) => {
+                    let new_per = {
+                        label: per_obj.website_name,
+                        value: per_obj.id,
+                    }
+                    this.creatNews_nav_pool_arr.push(new_per)
+                })
+            }).catch(() => {
+                this.$message({
+                    type: 'info',
+                    message: '网络错误,请重试!'
+                });
+            })
+        },
+        creatNews_nav_pool_change_fun() {      //xx  导航池级
+            let that = this; this.form.web_site_id = this.form.web_site_id[0]
+            that.parentKey_2 += 1; this.$store.dispatch('pool/get_creatNews_nav_son_actions', { pid: String(this.creatNews_pid_num), website_id: String(this.form.web_site_id) }).then(res => {
+                if (res.data.length == 0) {//没有导航池子级
+                    // alert("没有导航池子级");
+                    return
+                } this.creatNews_add_nav_pool_arr = res.data; this.creatNews_add_nav_pool_arr.forEach((per_obj) => {
+                    per_obj.label = per_obj.name,
+                        per_obj.value = per_obj.id, this.creatNews_pid_num = per_obj.category_id
+                })
+            }).catch(() => {
+                this.$message({
+                    type: 'info',
+                    message: '网络错误,请重试!'
+                });
+            })
+        },
+    },
+    created() {
+    },
+    mounted() {
+        this.creatNews_user_type = getUseType()
+        this.websiteid = getWebSiteId()
+        this.get_creatNews_form_id_fun()//
+        this.get_creatNews_nav_pool_arr_fun()//
+        this.getJobHuntingData()
+        // console.log(this.websiteid, '-------websiteid-------');
+        //1.判断是新建还是回显
+        if (this.$route.query.id != undefined) {
+            this.editId = this.$route.query.id;
+            this.editStatus = true;
+            // console.log("编辑新闻!")
+            this.getMainData();
+        } else {
+            this.editStatus = false;
+            // console.log("添加新闻!")
+        }
+    },
+    watch: {
+        '$route'(to, from) {
+            console.log(from, '---------------------------------------');
+            // 监听路由参数中的 id 变化,若变化则更新页面状态并获取数据
+            if (to.query.id) {
+                this.getMainData();
+            }
+        },
+        'form.job_experience': {
+            handler(newVal, oldVal) {
+
+                newVal.forEach((item, index) => {
+                    // 确保每个对象都有默认值
+                    // if (!item.company_name) item.job_industry = '';
+                    // if (!item.job_name) item.job_name = '';
+                    // if (!item.department) item.department = '';
+                    // if (!item.job_timeList) item.job_timeList = '';
+                    // if (!item.job_content) item.job_content = '';
+                    // if (!item.performance) item.performance = '';
+                    // 检查 company_name 是否发生变化
+                    console.log(newVal[index].company_name, oldVal[index].company_name);
+                    console.log(newVal[index].job_industry, '---job_industry---');
+                    this.form.company_name[index] = item.company_name;
+                    this.form.job_industry[index] = item.job_industry;
+                    this.form.job_name[index] = item.job_name;
+                    this.form.department[index] = item.department;
+                    this.form.job_timeList[index] = item.job_timeList;
+                    this.form.job_content[index] = item.job_content;
+                    console.log(this.form.company_name[index], '-=-------company_name---------');
+                    console.log(this.form.job_industry, '-=-------job_industry---------');
+                    console.log(this.form.company_name, '-=-------job_name---------');
+                    // if (oldVal[index] && oldVal[index].company_name !== item.company_name) {
+                    //   // 如果发生变化,就修改this.form.company_name相应的值
+                    // }
+                });
+            },
+            deep: true // 深度监听数组内部对象的变化
+        }
+    },
+
+};
+</script>
+<style scoped lang="less">
+.floating-menu {
+    position: fixed;
+    top: 50%;
+    right: 20px;
+    transform: translateY(-50%);
+    background-color: #f8f8f8;
+    border: 1px solid #ddd;
+    padding: 10px;
+    border-radius: 4px;
+    z-index: 222;
+}
+
+.menu-item {
+    cursor: pointer;
+    margin-bottom: 5px;
+    font-size: 14px;
+}
+
+.menu-item:hover {
+    color: #409eff;
+}
+
+//执行v-deep穿透scope选择器 start------------------------------------------------------------>*/
+::v-deep .custom-form-item>.el-form-item__label {
+    line-height: 140px !important;
+}
+
+::v-deep .custom-textarea .el-textarea__inner {
+    resize: none;
+    /* 禁止用户拖拽调整大小 */
+}
+
+::v-deep .custom-align-right .el-form-item__label {
+    text-align: right;
+    /* 设置标签文字右对齐 */
+}
+
+::v-deep .el-select {
+    width: 100%;
+    /* 禁止用户拖拽调整大小 */
+}
+
+::v-deep .el-input-group__prepend {
+    color: black !important;
+}
+
+.formLabelFloatBox {
+    margin-bottom: 10px;
+    position: relative;
+
+    .formLabeladdIcon {
+        position: absolute;
+        right: 45px;
+        top: 5px;
+        width: 38px;
+        height: 24px;
+    }
+
+    .formLabelDelIcon {
+        position: absolute;
+        right: 5px;
+        top: 5px;
+        width: 38px;
+        height: 24px;
+    }
+}
+
+//执行v-deep穿透scope选择器 end------------------------------------------------------------>*/
+.job_color_box {
+    background: #F5F7FB;
+    margin: 0px auto;
+    padding: 0px 30px;
+}
+
+.seek_head_box {
+    border-bottom: solid 1px #D9D9D9;
+
+    .seek_head_left {
+        float: left;
+    }
+
+    .seek_head_a {
+        float: left;
+        height: 55px;
+        line-height: 55px;
+        color: #333;
+        font-weight: bold;
+        font-size: 22px;
+        border-bottom: solid 3px rgba(0, 0, 0, 0);
+        margin-right: 40px;
+    }
+
+    .seek_head_only {
+        float: left;
+        height: 55px;
+        line-height: 55px;
+        color: #5570F1;
+        font-weight: bold;
+        font-size: 22px;
+        border-bottom: solid 3px #5570F1;
+    }
+
+    .seek_head_right_box {
+        float: right;
+        margin-top: 19px;
+    }
+
+    .seek_head_right_text {
+        float: left;
+        height: 21px;
+        line-height: 21px;
+        color: #999;
+        font-size: 16px;
+        margin-left: 22px;
+    }
+}
+
+.index_1_left {
+    float: left;
+    width: 70%;
+}
+
+.index_1_right {
+    float: right;
+    width: 28%;
+}
+
+.index_1_right_img {
+    float: right;
+    width: 130px;
+    height: 130px;
+    margin-top: 28px;
+    opacity: .6;
+}
+
+.seek_introduce_box {
+    .seek_introduce_left {
+        float: left;
+        width: 77%;
+    }
+
+    .seek_introduce_head {}
+
+    .seek_introduce_h4 {
+        height: 37px;
+        line-height: 37px;
+        color: #333;
+        font-size: 28px;
+        margin-right: 15px;
+        float: left;
+    }
+
+    .seek_introduce_tag {
+        float: left;
+        height: 25px;
+        line-height: 25px;
+        padding: 0px 8px 0px 36px;
+        // background: url(../public/img/13.png) no-repeat 10px center #f2f7ed;
+        background-size: 16px 16px;
+        border: solid 1px #9CD26B;
+        color: #ADCF8B;
+        font-size: 16px;
+        border-radius: 3px;
+        margin: 10px 5px 0px 0px;
+    }
+
+    .seek_introduce_text {
+        height: 25px;
+        line-height: 25px;
+        color: #999;
+        font-size: 16px;
+        margin-top: 10px;
+        float: left;
+    }
+
+    .seek_introduce_num {
+        color: #9CD26B;
+    }
+
+    .seek_introduce_title_box {}
+
+    .seek_introduce_label {
+        margin-right: 11px;
+        line-height: 21px;
+        color: #333;
+        font-size: 16px;
+        font-weight: bold;
+    }
+
+    .seek_introduce_title {
+        margin-right: 40px;
+        line-height: 21px;
+        color: #333;
+        font-size: 16px;
+        font-weight: bold;
+    }
+}
+
+.seek_introduce_foot {
+    margin-top: 32px;
+
+    .seek_introduce_foot_text {
+        height: 16px;
+        line-height: 16px;
+        float: left;
+        color: #999;
+        font-size: 16px;
+        padding-right: 10px;
+        margin-right: 10px;
+        border-right: solid 1px #999;
+    }
+
+    .seek_introduce_foot_text:nth-last-of-type(1) {
+        border: 0px;
+    }
+}
+
+.index_2 {
+    margin-top: 15px;
+}
+
+.seek_article {
+    margin-top: 33px;
+}
+
+.index_3 {
+    margin-top: 15px;
+}
+
+.seek_in {
+    .seek_in_head {
+        margin: 31px 0px 10px;
+    }
+
+    .seek_in_head_text {
+        float: left;
+        height: 35px;
+        line-height: 35px;
+        color: #333;
+        font-size: 18px;
+        margin-right: 40px;
+    }
+
+    .seek_in_head_text:nth-last-of-type(1) {
+        margin-right: 0px;
+        float: right;
+    }
+}
+
+.seek_in_ul {
+    .seek_in_li {
+        display: flex;
+        margin-bottom: 10px;
+    }
+
+    .seek_in_label {
+        font-weight: 500;
+        height: 35px;
+        line-height: 35px;
+        color: #333;
+        font-size: 18px;
+        word-break: keep-all;
+        white-space: nowrap;
+    }
+
+    .seek_in_li_text {
+        height: 35px;
+        line-height: 35px;
+        color: #333;
+        font-size: 18px;
+    }
+
+    .seek_in_li:nth-last-of-type(1) {
+        margin-bottom: 0px;
+    }
+}
+
+.index_4 {
+    margin-top: 13px;
+}
+
+.index_5 {
+    margin-top: 13px;
+}
+
+.index_5 .seek_in {
+    margin-top: 33px;
+}
+
+.index_6 {
+    margin-top: 13px;
+}
+
+.index_6 .seek_in {
+    margin: 33px auto;
+}
+
+.seek_article_2 {
+    color: #333;
+    font-size: 18px;
+}
+
+.job_foot_btn {
+    float: none;
+    display: block;
+    margin: 10px auto;
+    width: 180px;
+    padding: 10px 0px;
+    text-align: center;
+    font-size: 20px;
+}
+</style>

+ 230 - 0
src/views/news/jobHuntingApplyList.vue

@@ -0,0 +1,230 @@
+<template>
+  <div class="mainBox">
+    <!--搜索功能 start------------------------------------------------------------>
+    <div class="layerBox_search">
+      <div class="layerBoxLine">
+        <el-row>
+          <el-col :span="6">
+            <div class="searchBox">
+              <div class="searchTitle">标题名称</div>
+              <el-input placeholder="请输入标题名称" autocomplete="off" v-model="getApiData.username" />
+            </div>
+          </el-col>
+          <el-col :span="6">
+            <div class="searchBox">
+              <div class="searchTitle">薪资范围</div>
+              <el-select v-model="getApiData.salary" placeholder="请选择薪资范围" style="width: 100%;">
+                <el-option v-for="item in incomes" :key="item.evalue" :label="item.ename" :value="item.evalue">
+                </el-option>
+              </el-select>
+            </div>
+          </el-col>
+
+        </el-row>
+      </div>
+    </div>
+    <div class=" " style="padding:0px 40px 0px 0px; overflow:hidden;">
+      <div style="float:right;">
+        <el-button @click="clearSearchList">重置</el-button>
+        <el-button type="primary" @click="getData('search')">搜索</el-button>
+      </div>
+    </div>
+    <!--搜索功能 end------------------------------------------------------------>
+
+    <!--表格内容 start------------------------------------------------------------>
+    <div class="layerBox">
+      <tableTitle :name="tableDivTitle" />
+      <el-row>
+        <template>
+          <el-table :data="tableData" style="width: 100%">
+            <el-table-column fixed prop="id" label="编号" width="50"></el-table-column>
+            <el-table-column prop="username" label="标题名称" width=""></el-table-column>
+            <el-table-column prop="job_name" label="具体职位" width=""></el-table-column>
+            <el-table-column prop="cityname" label="工作地点" width=""></el-table-column>
+            <el-table-column prop="salary_name" label="薪资范围" width=""></el-table-column>
+            <el-table-column prop="updated_at" label="更新时间" width=""></el-table-column>
+            <el-table-column fixed="right" label="操作" width="200" header-align="center">
+              <template slot-scope="scope">
+                <div class="listBtnBox">
+                  <div class="listEditBtn" @click="goDetail(scope.row.hunt_id, tableData)"><i
+                      class="el-icon-edit-outline"></i>详情</div>
+                </div>
+              </template>
+            </el-table-column>
+          </el-table>
+        </template>
+      </el-row>
+    </div>
+    <!--分页 start------------------------------------------------------------>
+    <div class="alignBox">
+      <el-row>
+        <el-col :span="24">
+          <el-pagination @size-change="handleSizeChange" :current-page="getApiData.page"
+            @current-change="handleCurrentChange" :page-size="10" layout="total, prev, pager, next, jumper"
+            :total="allCount"></el-pagination>
+        </el-col>
+      </el-row>
+    </div>
+    <!--分页 end------------------------------------------------------------>
+    <!--表格内容 end------------------------------------------------------------>
+  </div>
+</template>
+
+<script>
+//表格标题
+import tableTitle from './components/tableTitle';
+//引入公用样式
+import '@/styles/global.less';
+
+export default {
+  components: {
+    tableTitle,//表格标题
+  },
+  data() {
+    return {
+      //1.列表和分页相关 start ------------------------------------------------------------>
+      tableDivTitle: "求职信息列表",
+      tableData: [],//内容
+      editId: 0,//要修改的网站id
+      incomes: [],//薪资范围
+      getApiData: {
+        username: "",//标题
+        salary: "",//导航池id
+        status: 2,//状态
+
+        page: 1,//当前是第几页
+        page_size: 10,//一共多少条
+      },
+      allCount: 0,//总条数
+      //分页相关 end ------------------------------------------------------------>
+    }
+  },
+  methods: {
+    //1.列表和分页相关 start ------------------------------------------------------------>
+    //1.1 开始请求列表信息方法
+    getData(type) {
+      if (type == "search") {
+        this.getApiData.page = 1;
+      }
+      console.log(this.getApiData, '---1--')
+      this.$store.dispatch('news/getJobHuntingApply', this.getApiData).then(res => {
+        //格式化:islink=0为不使用外面 islink=1为使用外链
+        //status=1为显示 status=2为不显示
+        console.log(res.data, '---2-')
+        let data = [];
+        for (let item of res.data.rows) {
+          item.username = item.username + '简历'
+          item.category_name = '求职信息'
+          // if(item.status==0){item.status="隐藏"}
+          // if(item.status==1){item.status="显示"}
+          // if(item.status==404){item.status="已删除"}
+          // if (item.islink == 0) { item.islink = "否" }
+          // if (item.islink == 1) { item.islink = "是" }
+          data.push(item)
+        }
+        this.tableData = res.data.rows; //给与内容
+        this.allCount = res.data.count; //给与总条数
+      }).catch(() => {
+        this.$message({
+          type: 'warning',
+          message: '网络错误,请重试!'
+        });
+      })
+    },
+    //1.2 删除内容
+    deleteRow(id) {
+      this.$confirm('此操作将永久删除该条数据, 是否继续?', '提示', {
+        confirmButtonText: '确定',
+        cancelButtonText: '取消',
+        type: 'warning'
+      }).then(() => {
+        console.log("当前删除:" + id)
+        this.$store.dispatch('news/delJobHunting', { id: id }).then(res => {
+          this.getData();
+          this.$message({
+            type: 'success',
+            message: '删除成功!'
+          });
+        }).catch(() => {
+          this.$message({
+            type: 'warning',
+            message: '网络错误,请重试!'
+          });
+        })
+      }).catch(() => {
+        this.$message({
+          type: 'warning',
+          message: '已取消删除'
+        });
+      });
+    },
+
+    //1.4 列表内容分页
+    //直接跳转
+    handleSizeChange(val) {
+      this.getApiData.page = val;
+      this.getData();
+    },
+    //1.5 点击分页
+    handleCurrentChange(val) {
+      this.getApiData.page = val;
+      this.getData();
+    },
+    //1.6 重置按钮
+    clearSearchList() {
+      this.tableData = [];
+      this.getApiData.username = "";
+      this.getApiData.salary = ""; //导航池id
+      this.getApiData.page = 1;
+      this.getApiData.pageSize = 10;
+      this.getData();
+    },
+    //列表和分页相关 end ------------------------------------------------------------>
+
+    //2.添加求职信息start ------------------------------------------------------------>
+    //跳转到求职信息发布页面
+    goCreat() {
+      this.$router.push({
+        path: '/addJobHunting',
+      });
+    },
+    goDetail(id) {
+      console.log(id, '---3--')
+      let data = {
+        id: id
+      }
+      this.$router.push({
+        path: '/jobHuntingApplyDetil',
+        query: data
+      });
+    },
+    //添加求职信息end ------------------------------------------------------------>
+    getJobHuntingData() {
+      this.$store.dispatch('news/getJobHuntingData', {}).then(res => {
+        if (res.code == 200) {
+          this.jobEnum = res.data.jobEnum;
+          this.educations = this.jobEnum.filter(item => item.egroup === 'education');
+          this.languages = this.jobEnum.filter(item => item.egroup === 'language');
+          this.languagetypes = this.jobEnum.filter(item => item.egroup === 'languagetype');
+          this.natures = this.jobEnum.filter(item => item.egroup === 'nature');
+          this.maritals = this.jobEnum.filter(item => item.egroup === 'marital');
+          this.incomes = this.jobEnum.filter(item => item.egroup === 'income');
+          this.years = this.jobEnum.filter(item => item.egroup === 'years');
+
+          this.jobIndustry = res.data.jobIndustry;
+          this.jobNature = res.data.jobNature;
+          this.jobPosition = res.data.jobPosition;
+        }
+      })
+    },
+
+  },
+  mounted() {
+    //1.获得初始数据
+    this.getData();
+    this.getJobHuntingData();
+  }
+}
+</script>
+
+<style scoped lang="less"></style>

+ 2 - 2
src/views/news/jobHuntingList.vue

@@ -6,8 +6,8 @@
         <el-row>
           <el-col :span="8">
             <div class="searchBox">
-              <div class="searchTitle">标名称</div>
-              <el-input placeholder="请输入标名称" autocomplete="off" v-model="getApiData.username" />
+              <div class="searchTitle">标名称</div>
+              <el-input placeholder="请输入标名称" autocomplete="off" v-model="getApiData.username" />
             </div>
           </el-col>
 

+ 10 - 3
src/views/news/jobHuntingListApply.vue

@@ -4,10 +4,17 @@
     <div class="layerBox_search">
       <div class="layerBoxLine">
         <el-row>
-          <el-col :span="8">
+          <el-col :span="6">
             <div class="searchBox">
-              <div class="searchTitle">标签名称</div>
-              <el-input placeholder="请输入标签名称" autocomplete="off" v-model="getApiData.username" />
+              <div class="searchTitle">标题名称</div>
+              <el-input placeholder="请输入标题名称" autocomplete="off" v-model="getApiData.username" />
+            </div>
+          </el-col>
+
+          <el-col :span="6">
+            <div class="searchBox">
+              <div class="searchTitle">标题名称</div>
+              <el-input placeholder="请输入标题名称" autocomplete="off" v-model="getApiData.username" />
             </div>
           </el-col>
 

+ 185 - 0
src/views/news/myApplyList.vue

@@ -0,0 +1,185 @@
+<template>
+    <div class="mainBox">
+        <!--搜索功能 start------------------------------------------------------------>
+        <div class="layerBox_search">
+            <div class="layerBoxLine">
+                <el-row>
+                    <el-col :span="6">
+                        <div class="searchBox">
+                            <div class="searchTitle">公司名称</div>
+                            <el-input placeholder="请输入公司名称" autocomplete="off" v-model="getApiData.business_name" />
+                        </div>
+                    </el-col>
+                    <el-col :span="6">
+                        <div class="searchBox">
+                            <div class="searchTitle">工作经验</div>
+                            <el-select v-model="getApiData.experience" placeholder="请选择工作经验" style="width: 100%;">
+                                <el-option v-for="item in experience" :key="item.evalue" :label="item.ename"
+                                    :value="item.evalue">
+                                </el-option>
+                            </el-select>
+                        </div>
+                    </el-col>
+                    <el-col :span="6">
+                        <div class="searchBox">
+                            <div class="searchTitle">薪资范围</div>
+                            <el-select v-model="getApiData.salary" placeholder="请选择薪资范围" style="width: 100%;">
+                                <el-option v-for="item in salary" :key="item.evalue" :label="item.ename"
+                                    :value="item.evalue">
+                                </el-option>
+                            </el-select>
+                        </div>
+                    </el-col>
+                </el-row>
+            </div>
+        </div>
+        <div class=" " style="padding:0px 40px 0px 0px; overflow:hidden;">
+            <div style="float:right;">
+                <el-button @click="clearSearchList">重置</el-button>
+                <el-button type="primary" @click="getData">搜索</el-button>
+            </div>
+        </div>
+        <!--搜索功能 end------------------------------------------------------------>
+
+        <!--表格内容 start------------------------------------------------------------>
+        <div class="layerBox">
+            <tableTitle :name="tableDivTitle" />
+            <el-row>
+                <template>
+                    <el-table :data="tableData" style="width: 100%">
+                        <el-table-column fixed prop="id" label="编号" width="50"></el-table-column>
+                        <el-table-column prop="business_name" label="公司名称" width=""></el-table-column>
+                        <el-table-column prop="title" label="招聘职位名称" width=""></el-table-column>
+                        <el-table-column prop="experience_ename" label="工作经验" width=""></el-table-column>
+                        <el-table-column prop="salary_ename" label="薪资范围" width=""></el-table-column>
+                        <el-table-column prop="updated_at" label="更新时间" width=""></el-table-column>
+                        <el-table-column fixed="right" label="操作" width="200" header-align="center">
+                            <template slot-scope="scope">
+                                <div class="listBtnBox">
+                                    <div class="listEditBtn" @click="goDetail(scope.row.id, tableData)">
+                                        <i class="el-icon-edit-outline"></i>查看
+                                    </div>
+                                </div>
+                            </template>
+                        </el-table-column>
+                    </el-table>
+                </template>
+            </el-row>
+        </div>
+        <!--分页 start------------------------------------------------------------>
+        <div class="alignBox">
+            <el-row>
+                <el-col :span="24">
+                    <el-pagination @size-change="handleSizeChange" :current-page="getApiData.page"
+                        @current-change="handleCurrentChange" :page-size="10" layout="total, prev, pager, next, jumper"
+                        :total="allCount">
+                    </el-pagination>
+                </el-col>
+            </el-row>
+        </div>
+        <!--分页 end------------------------------------------------------------>
+        <!--表格内容 end------------------------------------------------------------>
+    </div>
+</template>
+
+<script>
+//表格标题
+import tableTitle from './components/tableTitle';
+//引入公用样式
+import '@/styles/global.less';
+
+export default {
+    components: {
+        tableTitle,//表格标题
+    },
+    data() {
+        return {
+            //1.列表和分页相关 start ------------------------------------------------------------>
+            tableDivTitle: "求职信息列表",
+            tableData: [],//内容
+            experience: [],//工作经验列表
+            salary: [],//薪资范围列表
+            getApiData: {
+                business_name: "",//公司名称
+                experience: "",//工作经验
+                salary: "",//薪资
+                page: 1,//当前是第几页
+                pageSize: 10,//一共多少条
+            },
+            allCount: 0,//总条数
+            //分页相关 end ------------------------------------------------------------>
+        }
+    },
+    methods: {
+        //1.列表和分页相关 start ------------------------------------------------------------>
+        //1.1 开始请求列表信息方法
+        getData() {
+            this.$store.dispatch('news/myApplyList', this.getApiData).then(res => {
+                if (res.code == 200) {
+                    this.tableData = res.data.row;//给与内容
+                    this.allCount = res.data.count;//给与总条数
+                } else {
+                    //this.$message.error(res.message)
+                }
+            })
+        },
+        //1.2 获得工作经验
+        getExperience() {
+            this.$store.dispatch('job/getExperience', {}).then(res => {
+                if (res.code == 200) {
+                    this.experience = res.data;
+                }
+            })
+        },
+        //1.3 获得薪资范围
+        getSalary() {
+            this.$store.dispatch('job/getSalary', {}).then(res => {
+                if (res.code == 200) {
+                    this.salary = res.data;
+                }
+            })
+        },
+        //1.4 列表内容分页
+        //直接跳转
+        handleSizeChange(val) {
+            this.getApiData.page = val;
+            this.getData();
+        },
+        //1.5 点击分页
+        handleCurrentChange(val) {
+            this.getApiData.page = val;
+            this.getData();
+        },
+        //1.6 重置按钮
+        clearSearchList() {
+            this.tableData = [];
+            this.getApiData.business_name = "";
+            this.getApiData.experience = "";
+            this.getApiData.salary = "";
+            this.getApiData.page = 1;
+            this.getApiData.pageSize = 10;
+            this.getData();
+        },
+        //列表和分页相关 end ------------------------------------------------------------>
+
+        //2.跳转到详情start ------------------------------------------------------------>
+        goDetail(id) {
+            this.$router.push({
+                path: '/jobOpportunitiesDetails',
+                query: { id: id }
+            });
+        },
+        //添加求职信息end ------------------------------------------------------------>
+    },
+    mounted() {
+        //1.获得初始数据
+        this.getData();
+        //2.获得工作经验
+        this.getExperience();
+        //3.获得薪资范围
+        this.getSalary();
+    }
+}
+</script>
+
+<style scoped lang="less"></style>

+ 1 - 1
src/views/news/ncomplaintListApply.vue

@@ -53,7 +53,7 @@
             <el-table-column fixed prop="id" label="编号" width="50"></el-table-column>
             <el-table-column prop="title" label="投诉主题" width="">
             </el-table-column>
-            <el-table-column prop="title" label="投诉类型" width="">
+            <el-table-column prop="department_name" label="投诉类型" width="">
             </el-table-column>
             <el-table-column prop="cityname" label="接收人" width="">
             </el-table-column>

+ 1 - 1
src/views/news/ncomplaintListDeal.vue

@@ -52,7 +52,7 @@
             <el-table-column fixed prop="id" label="编号" width="50"></el-table-column>
             <el-table-column prop="title" label="投诉主题" width="">
             </el-table-column>
-            <el-table-column prop="title" label="投诉类型" width="">
+            <el-table-column prop="department_name" label="投诉类型" width="">
             </el-table-column>
             <el-table-column prop="cityname" label="接收人" width="">
             </el-table-column>

+ 2 - 2
src/views/news/surveyList.vue

@@ -179,8 +179,8 @@ export default {
                 if (res.code == 200) {
                     this.tableData = res.data.rows;
                     this.total = res.data.count;
-                } else if (res.code == 0) {
-                    
+                } else if(res.code == 0){
+
                 }else {
                     this.$message({
                         type: 'error',