freework_level.vue 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509
  1. <template>
  2. <el-drawer title="技术认证审核" size="80%" v-loading="loading" :visible.sync="drawer" :wrapper-closable="true" @close="close" :direction="direction">
  3. <div :style="`height: 100vh;opacity: `+opacity+`;overflow:scroll;margin-left:20px;margin-right:20px`">
  4. <el-row style="border-bottom: 1px solid red">
  5. <el-col :span="12">
  6. <div class="title">申请信息</div>
  7. <div>
  8. <span class="sub-title">认证费用:</span>
  9. <span class="i-content">
  10. <span>{{form.pay_money}}</span>
  11. </span>
  12. </div>
  13. <div>
  14. <span class="sub-title">付款日期:</span>
  15. <span class="i-content">
  16. <span>{{form.addtime}}</span>
  17. </span>
  18. </div>
  19. <div>
  20. <span class="sub-title">认证领域:</span>
  21. <span class="i-content">
  22. <span>{{form.occupation_name}} / {{form.direction_name}}</span>
  23. </span>
  24. </div>
  25. <div>
  26. <span class="sub-title">认证等级:</span>
  27. <span class="i-content">
  28. <span>{{form.item_id}}
  29. <el-select size="small" style="width:120px" v-model="form.confirm_item_id" placeholder="请选择用户最终的面试等级">
  30. <el-option v-for="item in freeworklevel" :key="item.item_id" :label="item.name" :value="item.item_id">
  31. </el-option>
  32. </el-select>
  33. <el-button v-if="form.order_status==2 || form.order_status==3 || form.order_status==4 || form.order_status==5" @click="confirm_item_id" size="small" type="success">确定</el-button>
  34. </span>
  35. </span>
  36. </div>
  37. <!-- <div>
  38. <span class="sub-title">面试时间:</span>
  39. <span class="i-content">
  40. <span>{{form.memo}}</span>
  41. </span>
  42. </div> -->
  43. <div>
  44. <span class="sub-title">认证文件:</span>
  45. <span class="i-content">
  46. <span><a style="margin-right: 15px" v-for="(item, index) in form.file" :href="item" target="_blank">文件{{index+1}}</a></span>
  47. </span>
  48. </div>
  49. <div>
  50. <span class="sub-title">薪资现状:</span>
  51. <span class="i-content">
  52. <span>{{form.extend_memo? form.extend_memo.now_money:'' }}</span>
  53. </span>
  54. </div>
  55. <div>
  56. <span class="sub-title">面试时间\其他补充:</span>
  57. <span class="i-content">
  58. <span>{{form.extend_memo? form.extend_memo.memo:''}}</span>
  59. </span>
  60. </div>
  61. <div>
  62. <span class="sub-title">审核日期:</span>
  63. <span class="i-content">
  64. <span><a :href="form.apply_info.url" target="_blank">{{form.checktime}}</a></span>
  65. </span>
  66. </div>
  67. <div>
  68. <span class="sub-title">审核人:</span>
  69. <span class="i-content">
  70. <span><a :href="form.apply_info.url" target="_blank">{{form.check_name}}</a></span>
  71. </span>
  72. </div>
  73. </el-col>
  74. <el-col :span="12">
  75. <div class="title">用户基本信息</div>
  76. <el-image style="width: 60px;height: 60px;border-radius: 50%;margin-left: 32px;" :src="form.apply_info.icon_url"></el-image>
  77. <div>
  78. <span class="sub-title">申请人昵称:</span>
  79. <span class="i-content">
  80. <span>{{form.apply_info.nickname}}({{form.uid}})</span>
  81. </span>
  82. </div>
  83. <div>
  84. <span class="sub-title">申请人真名:</span>
  85. <span class="i-content">
  86. <span>{{form.apply_info.realname}}</span>
  87. </span>
  88. </div>
  89. <div>
  90. <span class="sub-title">申请人手机:</span>
  91. <span class="i-content">
  92. <span>{{form.apply_info.login_mobile}}</span>
  93. </span>
  94. </div>
  95. <div>
  96. <span class="sub-title">申请人微信:</span>
  97. <span class="i-content">
  98. <span>{{form.apply_info.weixin}}</span>
  99. </span>
  100. </div>
  101. <div>
  102. <span class="sub-title">申请人主页:</span>
  103. <span class="i-content">
  104. <span><a :href="form.apply_info.url" target="_blank">{{form.apply_info.url}}</a></span>
  105. </span>
  106. </div>
  107. </el-col>
  108. </el-row>
  109. <el-row v-if="form.order_status==2 || form.order_status==3 || form.order_status==4 || form.order_status==5" style="border-bottom: 1px solid red;padding: 20px">
  110. <el-col :span="24">
  111. <el-input size="small" style="width: 220px" v-model="form.interview_uid" placeholder="UID"></el-input>
  112. <el-button size="small" @click="appoint" type="success">对接面试官</el-button>
  113. <el-button size="small" @click="refuse" type="danger">拒绝申请</el-button>
  114. <el-button size="small" @click="end" type="success">完成审核</el-button>
  115. </el-col>
  116. </el-row>
  117. <el-row v-for="item in form.interview_list" style="border-bottom: 1px solid red;">
  118. <el-col :span="8">
  119. <div style="margin-top: 20px">
  120. <span class="sub-title">面试官工资:</span>
  121. <span class="i-content">
  122. <span>
  123. <el-input size="small" v-model="item.pay_money" style="width:100px" placeholder="面试官工资"></el-input>
  124. <el-button size="small" @click="set_item(item)" v-if="form.order_status==2 || form.order_status==3 || form.order_status==4 || form.order_status==5" type="success">设置工资</el-button>
  125. <el-button size="small" @click="pay(item)" v-if="form.order_status==7 && form.interview_status==1" type="success">结算工资</el-button>
  126. <el-button size="small" @click="del_invite(item)" v-if="form.order_status==2 || form.order_status==3 || form.order_status==4 || form.order_status==5" type="success">删除</el-button>
  127. </span>
  128. </span>
  129. </div>
  130. <div>
  131. <span class="sub-title">面试官昵称:</span>
  132. <span class="i-content">
  133. <span>{{item.userInfo.nickname}}({{item.userInfo.uid}})</span>
  134. </span>
  135. </div>
  136. <div>
  137. <span class="sub-title">面试官真名:</span>
  138. <span class="i-content">
  139. <span>{{item.userInfo.realname}}</span>
  140. </span>
  141. </div>
  142. <div>
  143. <span class="sub-title">面试官电话:</span>
  144. <span class="i-content">
  145. <span>{{item.userInfo.login_mobile}}</span>
  146. </span>
  147. </div>
  148. <div>
  149. <span class="sub-title">面试官主页:</span>
  150. <span class="i-content">
  151. <span><a :href="item.userInfo.url" target="_blank">{{item.userInfo.url}}</a></span>
  152. </span>
  153. </div>
  154. <div>
  155. <span class="sub-title">面试时间:</span>
  156. <span class="i-content">
  157. <el-date-picker v-model="item.interview_time" size="small" style="width:190px" align="right" value-format="yyyy-MM-dd HH:mm:ss" type="datetime" placeholder="选择日期" :picker-options="pickerOptions">
  158. </el-date-picker>
  159. <el-button size="small" @click="set_item(item)" v-if="form.order_status==2 || form.order_status==3 || form.order_status==4 || form.order_status==5" type="success">设置</el-button>
  160. <el-button size="small" @click="end_invite(item)" v-if="item.interview_status!=2" type="success">完成面试</el-button>
  161. </span>
  162. </div>
  163. <div>
  164. <span class="sub-title">面试录屏:</span>
  165. <span class="i-content">
  166. <span>
  167. <upload_file style="padding: 20px" @click="save_file" :id="item.id" :fileList="item.fileList"></upload_file>
  168. <a v-if="item.inter_video" target="_blank" :href="item.inter_video">浏览上传文件</a>
  169. </span>
  170. </span>
  171. </div>
  172. </el-col>
  173. <el-col :span="8" style="padding-right: 20px">
  174. <div class="title">面试官评价<span><a :href="item.invite_comment_url" style="color:#409EFF" target="_blank">(点击查看评价链接)</a></span><span class="ma-copy" @click="copy(item.invite_comment_url)">复制</span></div>
  175. <div>
  176. <span class="sub-title">技术栈评分:</span>
  177. <span class="i-content">
  178. <span>{{item.dev_study?item.dev_study:"暂无"}}</span>
  179. </span>
  180. </div>
  181. <div>
  182. <span class="sub-title">项目能力评分:</span>
  183. <span class="i-content">
  184. <span>{{item.dev_skill_base?item.dev_skill_base:"暂无"}}</span>
  185. </span>
  186. </div>
  187. <div>
  188. <span class="sub-title">非技术能力评分:</span>
  189. <span class="i-content">
  190. <span>{{item.dev_experience?item.dev_experience:"暂无"}}</span>
  191. </span>
  192. </div>
  193. <div>
  194. <span class="sub-title">面试评价:</span>
  195. <span class="i-content"><span>{{item.dev_memo?item.dev_memo:"暂无"}}</span></span>
  196. </div>
  197. <div>
  198. <span class="sub-title">面试定级:</span>
  199. <span class="i-content"><span style="color: red">{{item.level?item.level:"暂无"}}</span></span>
  200. </div>
  201. </el-col>
  202. <el-col :span="8">
  203. <div class="title">开发者评价<span><a :href="item.dev_comment_url" target="_blank" style="color:#409EFF">(点击查看评价链接)</a></span><span class="ma-copy" @click="copy(item.dev_comment_url)">复制</span></div>
  204. <div>
  205. <span class="sub-title">面试水平:</span>
  206. <span class="i-content"><span>{{item.invite_experience?item.invite_experience:"暂无"}}</span></span>
  207. </div>
  208. <div>
  209. <span class="sub-title">技术专业度:</span>
  210. <span class="i-content">
  211. <span>{{item.invite_skill?item.invite_skill:"暂无"}}</span>
  212. </span>
  213. </div>
  214. <div>
  215. <span class="sub-title">面试评价:</span>
  216. <span class="i-content"><span>{{item.inter_memo?item.inter_memo:"暂无"}}</span></span>
  217. </div>
  218. </el-col>
  219. </el-row>
  220. <el-row style="border-bottom: 1px solid red;padding-bottom: 20px">
  221. <el-col :span="8">
  222. <div v-for="(item,index) in form.skill" style="margin-top: 20px">
  223. <span class="sub-title">{{item.skill_name}}:</span>
  224. <span class="i-content">
  225. <span>
  226. {{item.skill_level}}分
  227. </span>
  228. </span>
  229. </div>
  230. </el-col>
  231. </el-row>
  232. </div>
  233. </el-drawer>
  234. </template>
  235. <script>
  236. import upload_file from "@/components/public/upload_file"
  237. export default {
  238. components: {
  239. upload_file
  240. },
  241. data() {
  242. return {
  243. loading: false,
  244. opacity: "0",
  245. // id:0,
  246. // drawer_state: false,
  247. direction: 'rtl',
  248. freeworklevel: [],
  249. form: {
  250. apply_info: {},
  251. interview_info: {},
  252. skill: [],
  253. }
  254. }
  255. },
  256. props: {
  257. 'id': {
  258. type: Number,
  259. },
  260. 'drawer': {
  261. type: Boolean,
  262. }
  263. },
  264. computed: {
  265. },
  266. watch: {
  267. 'drawer': {
  268. handler: function () {
  269. this.$nextTick(() => {
  270. if (this.drawer) {
  271. this.get_freeworklevel();
  272. this.getDetail()
  273. }
  274. })
  275. }
  276. }
  277. },
  278. methods: {
  279. close() {
  280. this.$parent.getList();
  281. this.$parent.setDrawer(false);
  282. },
  283. async get_freeworklevel() {
  284. let res = await this.$post("/uapi/pub/freeworklevel");
  285. if (res && res.status === 1) {
  286. this.freeworklevel = res.data.list;
  287. }
  288. },
  289. async del_invite(item) {
  290. var invite_id = item.id;
  291. let res = await this.$post("/uapi/cert/del_invite", {
  292. invite_id: invite_id,
  293. id: this.form.id
  294. });
  295. if (res && res.status === 1) {
  296. this.$message({
  297. type: 'success',
  298. message: '删除成功!'
  299. });
  300. this.getDetail(this.form.id);
  301. this.$parent.getList(true);
  302. }
  303. },
  304. async end_invite(item) {
  305. var invite_id = item.id;
  306. let res = await this.$post("/uapi/cert/end_invite", {
  307. invite_id: invite_id,
  308. id: this.form.id
  309. });
  310. if (res && res.status === 1) {
  311. this.$message({
  312. type: 'success',
  313. message: '操作成功!'
  314. });
  315. this.getDetail(this.form.id);
  316. this.$parent.getList(true);
  317. }
  318. },
  319. async appoint() {
  320. let res = await this.$post("/uapi/cert/agree", {
  321. id: this.form.id,
  322. interview_uid: this.form.interview_uid
  323. });
  324. if (res && res.status === 1) {
  325. this.$message({
  326. type: 'success',
  327. message: '面试官对接成功!'
  328. });
  329. this.getDetail(this.form.id);
  330. this.$parent.getList(true);
  331. }
  332. },
  333. async confirm_item_id() {
  334. let res = await this.$post("/uapi/cert/confirm_item_id", {
  335. id: this.form.id,
  336. confirm_item_id: this.form.confirm_item_id
  337. });
  338. if (res && res.status === 1) {
  339. this.$message({
  340. type: 'success',
  341. message: '定级成功!'
  342. });
  343. this.$parent.getList(true);
  344. }
  345. },
  346. async end() {
  347. let res = await this.$post("/uapi/cert/end", {
  348. id: this.form.id
  349. });
  350. if (res && res.status === 1) {
  351. this.$message({
  352. type: 'success',
  353. message: '已完成审核'
  354. });
  355. this.getDetail(this.form.id);
  356. this.$parent.getList(true);
  357. }
  358. },
  359. async refuse() {
  360. let res = await this.$post("/uapi/cert/refuse", {
  361. id: this.form.id
  362. });
  363. if (res && res.status === 1) {
  364. this.$message({
  365. type: 'success',
  366. message: '拒绝成功,购买资金已经退回到申请人余额账户!'
  367. });
  368. this.getDetail(this.form.id);
  369. this.$parent.getList(true);
  370. }
  371. },
  372. async pay(item) {
  373. var invite_id = item.id;
  374. let res = await this.$post("/uapi/cert/pay", {
  375. invite_id: invite_id,
  376. id: this.form.id
  377. });
  378. if (res && res.status === 1) {
  379. this.$message({
  380. type: 'success',
  381. message: '结算成功!'
  382. });
  383. this.getDetail(this.form.id);
  384. this.$parent.getList(true);
  385. }
  386. },
  387. async save_file(interview_id, file) { //保存文件
  388. let item = {};
  389. item.inter_video = file;
  390. item.id = interview_id;
  391. this.set_item(item);
  392. this.getDetail(this.form.id)
  393. },
  394. async set_item(item) {
  395. let value = JSON.stringify(item);
  396. let data = {
  397. item: value,
  398. order_id: this.form.id,
  399. interview_id: item.id
  400. }
  401. let res = await this.$post("/uapi/cert/cert.freework.level.interview.update", data);
  402. if (res && res.status === 1) this.$message({
  403. type: 'success',
  404. message: '设置成功!'
  405. });
  406. this.$parent.getList(true);
  407. },
  408. async getDetail() {
  409. this.opacity = "0";
  410. this.loading = true;
  411. let id = this.id;
  412. if (!id) return false;
  413. let res = await this.$post("/uapi/cert/info_admin", {
  414. id: id
  415. });
  416. this.opacity = "1";
  417. if (res && res.status === 1) {
  418. this.form = res.data;
  419. }
  420. this.loading = false;
  421. },
  422. copy(text){
  423. if (navigator.clipboard) {
  424. navigator.clipboard.writeText(text);
  425. } else {
  426. var textarea = document.createElement('textarea');
  427. document.body.appendChild(textarea);
  428. // 隐藏此输入框
  429. textarea.style.position = 'fixed';
  430. textarea.style.clip = 'rect(0 0 0 0)';
  431. textarea.style.top = '10px';
  432. // 赋值
  433. textarea.value = text;
  434. // 选中
  435. textarea.select();
  436. // 复制
  437. document.execCommand('copy', true);
  438. // 移除输入框
  439. document.body.removeChild(textarea);
  440. }
  441. this.$message.success("复制成功")
  442. }
  443. }
  444. };
  445. </script>
  446. <style scoped>
  447. .el-dialog__wrapper {
  448. overflow: hidden;
  449. }
  450. .container {
  451. height: 100%;
  452. }
  453. .title {
  454. font-size: 18px;
  455. font-weight: 700;
  456. line-height: 64px;
  457. }
  458. .sub-title {
  459. font-size: 14px;
  460. font-weight: 700;
  461. line-height: 35px;
  462. padding-left: 32px;
  463. }
  464. .i-content {
  465. line-height: 25px;
  466. }
  467. .content {
  468. padding-left: 32px;
  469. font-size: 12px;
  470. }
  471. .i-head-content div {
  472. height: 22px;
  473. }
  474. .i-content {
  475. font-size: 12px;
  476. }
  477. .ma-copy{
  478. cursor: pointer;
  479. }
  480. </style>