resume.vue 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578
  1. <template>
  2. <view>
  3. <view class="resumepage">
  4. <view class="u-flex u-row-between">
  5. <view class="">
  6. <view class="u-flex">
  7. <text style="margin-right: 20rpx;">{{from.name}}</text>
  8. <u-icon @click="onchange" name="edit-pen-fill" color="#777" size="22"></u-icon>
  9. </view>
  10. <view class="" style="margin-top: 20rpx;">
  11. <text style="margin-right: 12rpx;">{{from.experience}}年工作经验</text>|
  12. <text style="margin-left: 12rpx;margin-right: 12rpx;">{{from.birthday_text}}岁</text>|
  13. <text style="margin-left: 12rpx;">{{}}</text>
  14. </view>
  15. </view>
  16. <image style="width: 136rpx;height: 136rpx;border-radius:50%;" :src="from.avatar" mode=""></image>
  17. </view>
  18. <view class="" style="margin-top: 30rpx;">
  19. <view class="u-flex u-row-between">
  20. <text class="title">个人优势</text>
  21. <u-icon name="edit-pen-fill" color="#777" size="22" @click="toadvantage"></u-icon>
  22. </view>
  23. <view class="mar">
  24. <input type="text" placeholder="编辑优势亮点,展示我的独特态度" v-model="from.personal_advantage">
  25. </view>
  26. </view>
  27. <view class="" style="border-top:2rpx solid #F0F0F0;margin-top: 32rpx;">
  28. <view class="u-flex ">
  29. <text class="title">求职状态</text>
  30. </view>
  31. <view class="u-flex u-row-between" style="margin-top: 20rpx;">
  32. <input type="text" placeholder="请选择你的求职状态" v-model="from.job_status_name">
  33. <u-icon name="arrow-right" @click="show =true" size="12" class="address"></u-icon>
  34. </view>
  35. </view>
  36. <view class="" style="border-top:2rpx solid #F0F0F0;margin-top: 32rpx;">
  37. <view class="u-flex u-row-between">
  38. <text class="title">求职意向</text>
  39. <u-icon @click="toapply(1)" name="plus-circle" size="20"></u-icon>
  40. </view>
  41. <view class="" style="margin-top: 40rpx;margin-bottom: 20rpx;" v-for="(item,index) in job_intention1"
  42. :key="item.id" @click="toapply(2,item.id)">
  43. <view class="u-flex u-row-between">
  44. <view class="">
  45. <text>{{item.category_job_name}}</text>
  46. <text style="margin-left: 28rpx;">{{item.salary}}k</text>
  47. </view>
  48. <u-icon name="arrow-right" size="12"></u-icon>
  49. </view>
  50. <text
  51. style="margin-top: 20rpx;font-size: 28rpx;font-family: PingFangSC-Regular, PingFang SC;font-weight: 400;color: #777777;">{{item.city}}·{{item.category_industry_name}}</text>
  52. </view>
  53. </view>
  54. <view class="" style="border-top:2rpx solid #F0F0F0;margin-top: 32rpx;">
  55. <view class="u-flex u-row-between">
  56. <text class="title">工作经历</text>
  57. <u-icon name="plus-circle" size="20" @click="towork(1)"></u-icon>
  58. </view>
  59. <view class="" v-for="(item,index) in job_experience1" :key="item.id" @click="towork(2,item.id)">
  60. <view class="u-flex u-row-between" style="margin-top:40rpx ;">
  61. <text>{{item.company_name}}</text>
  62. <view class="u-flex">
  63. <text>{{item.start_time}}-{{item.end_time}}</text>
  64. <u-icon name="arrow-right" size="12"></u-icon>
  65. </view>
  66. </view>
  67. <view class="" style="margin-top: 20rpx;font-size: 28rpx;
  68. font-family: PingFangSC-Regular, PingFang SC;
  69. font-weight: 400;
  70. color: #333333;">
  71. <text>{{item.job_name}}|</text>
  72. <text>{{item.department}}</text>
  73. </view>
  74. <view class="concent">
  75. {{item.work_content}}
  76. </view>
  77. </view>
  78. </view>
  79. <view class="" style="margin-top: 40rpx;border-top: 2rpx solid #F0F0F0;">
  80. <view class="u-flex u-row-between">
  81. <text class="title">项目经历</text>
  82. <u-icon name="plus-circle" size="20" @click="toproject(1)"></u-icon>
  83. </view>
  84. <view class="" style="margin-top: 40rpx;" v-for="(item,index) in project_experience1" :key="item.id"
  85. @click="toproject(2,item.id)">
  86. <view class="u-flex u-row-between">
  87. <text>{{item.company_name}}</text>
  88. <view class="u-flex">
  89. <text>{{item.start_time}}-{{item.end_time}}</text>
  90. <u-icon name="arrow-right" size="12"></u-icon>
  91. </view>
  92. </view>
  93. <view class="mar">
  94. <text>{{item.role}}</text>
  95. </view>
  96. <view class="concent">
  97. {{item.description}}
  98. </view>
  99. </view>
  100. <view class=""></view>
  101. </view>
  102. <view class="" style="margin-top: 40rpx;border-top: 2rpx solid #F0F0F0;">
  103. <view class="u-flex u-row-between">
  104. <text class="title">教育经历</text>
  105. <u-icon name="plus-circle" size="20" @click="toteach(1)"></u-icon>
  106. </view>
  107. <view class="" style="margin-top: 40rpx;" v-for="(item,index) in education_experience1" :key="item.id"
  108. @click="toteach(2,item.id)">
  109. <view class="u-flex u-row-between">
  110. <text>{{item.name}}</text>
  111. <view class="u-flex">
  112. <text>{{item.start_time}}-{{item.end_time}}</text>
  113. <u-icon name="arrow-right" size="12"></u-icon>
  114. </view>
  115. </view>
  116. <view class="">
  117. <text>{{item.major}}</text>
  118. </view>
  119. </view>
  120. </view>
  121. <view class="" style="margin-top: 40rpx;border-top: 2rpx solid #F0F0F0;">
  122. <view class="u-flex u-row-between">
  123. <text class="title">语言能力</text>
  124. <u-icon name="plus-circle" size="20" @click="tolanguage(1)"></u-icon>
  125. </view>
  126. <view class="mar" v-for="(item,index) in language1" @click="tolanguage(2,item.id)">
  127. <view class="u-flex u-row-between">
  128. <text>{{item.language_name}}</text>
  129. <view class="u-flex">
  130. <text>{{item.level_name}}</text>
  131. <u-icon name="arrow-right" size="12"></u-icon>
  132. </view>
  133. </view>
  134. </view>
  135. </view>
  136. <view class="" style="margin-top: 40rpx;border-top: 2rpx solid #F0F0F0;">
  137. <view class="u-flex u-row-between">
  138. <text class="title">专业技能与证书</text>
  139. <u-icon name="plus-circle" size="20" @click="tocertificate()"></u-icon>
  140. </view>
  141. <view class="mar u-flex">
  142. <!-- <view style="flex: 1;" class="item">{{certificate.professional_skill}}</view> -->
  143. <view class="texta item" v-for="(item,index) in professional_skill" :key="index">
  144. {{item}}
  145. </view>
  146. </view>
  147. <view style="margin-top: 32rpx;" class="u-flex u-row-between" v-for="(item,index) in certificate1"
  148. :key="index">
  149. <text>{{item.certificate}}</text>
  150. <text>{{item.certificate_date}}</text>
  151. </view>
  152. </view>
  153. <view class="" style="margin-top: 40rpx;border-top: 2rpx solid #F0F0F0;margin-bottom:118rpx ;">
  154. <view class="u-flex u-row-between">
  155. <text class="title">附加信息</text>
  156. <!-- <u-icon name="plus-circle" size="20"></u-icon> -->
  157. </view>
  158. <view class="mar">
  159. <input type="text" placeholder="请输入附加消息">
  160. </view>
  161. </view>
  162. <view class="" style="height: 60rpx;"></view>
  163. </view>
  164. <view class="back u-flex" style="margin-top: 118rpx;">
  165. <view class="left" @click="jianlishow = true">
  166. 简历导入
  167. </view>
  168. <view class="right" @click="preview">
  169. <text style="opacity: 1;color: #0C66C2;">预览</text>
  170. </view>
  171. <view class="safe-area-inset-bottom"></view>
  172. </view>
  173. <view class="safe-area-inset-bottom"></view>
  174. <!-- <u-picker :show="jobshow" :columns="joblist"></u-picker> -->
  175. <u-picker @cancel="show = false" :show="show" :columns="columns" keyName="name" @confirm="enter"></u-picker>
  176. <u-popup customStyle="padding:32rpx 32rpx 6rpx" :show="jianlishow" mode="bottom" @close="close" @open="open"
  177. :closeable="true">
  178. <view class="">
  179. <view class="u-flex u-row-center">
  180. <text class="one">已有简历直接导入</text>
  181. </view>
  182. <view class="u-flex u-row-center">
  183. <text class="two">智能解析、快捷导入,提升在线简历完整度</text>
  184. </view>
  185. <view class="" style="margin-top: 72rpx;">
  186. <u-radio-group v-model="radiovalue1" placement="column" @change="groupChange">
  187. <view class="u-flex u-row-between">
  188. <view class="u-flex">
  189. <image style="width: 80rpx;height: 80rpx;" src="/static/images/pdf.png" mode=""></image>
  190. <view class="">
  191. <text class="three">姜濛的简历.pdf</text>
  192. <view class="fore">2023.04.02上传</view>
  193. </view>
  194. </view>
  195. <view class="">
  196. <u-radio :name="item.name">
  197. </u-radio>
  198. </view>
  199. </view>
  200. <view class="updata u-flex u-row-center" @click="toupload">
  201. 上传新简历
  202. </view>
  203. <view class="enter u-flex u-row-center">
  204. 确定
  205. </view>
  206. </u-radio-group>
  207. </view>
  208. </view>
  209. </u-popup>
  210. </view>
  211. </template>
  212. <script setup>
  213. import {
  214. resumeDetail,
  215. get_job_status,
  216. update,
  217. } from "@/units/inquire.js"
  218. export default {
  219. data() {
  220. return {
  221. jianlishow: false,
  222. jlid: '',
  223. show: false,
  224. columns: [
  225. []
  226. ],
  227. certificate1: [],
  228. professional_skill: [],
  229. from: {
  230. avatar: "",
  231. name: "",
  232. birthday_text: "",
  233. personal_advantage: "", //个人优势
  234. additional_info: "", //附加信息
  235. experience: "",
  236. job_status_id: "", //string 求职状态ID
  237. job_status_name: "" //求职状态名称
  238. },
  239. //求职意向
  240. job_intention: {
  241. job_date: "", //date 求职时间(求职意向
  242. province_id: "", //string 期望省份ID(求职意向
  243. city_id: "", //string 期望城市ID(求职意向
  244. province: "", //string 期望省份名称(求职意向
  245. city: "", //string 期望城市名称(求职意向
  246. salary_type: "", //string 薪资类型: year=年薪;month=月薪(求职意向
  247. salary: "", //string 薪水(求职意向
  248. salary_month: "", //string 一年多少薪(求职意向
  249. category_field_id: "", //string 领域ID(求职意向
  250. category_field_name: "", //string 领域名称(求职意向
  251. category_industry_first: "", //string 行业一级ID(求职意向
  252. category_industry_id: "", //string 行业ID(求职意向
  253. category_industry_first_name: "", //string 行业一级名称(求职意向
  254. category_industry_name: "", //string 行业名称(求职意向
  255. category_job_first: "", //string 职业分类一级ID(求职意向
  256. category_job_second: "", //string 职业分类二级ID(求职意向
  257. category_job_id: "", //string 职位分类ID(求职意向
  258. category_job_first_name: "", //string 职业分类一级名称(求职意向
  259. category_job_second_name: "", //string 职业分类二级名称(求职意向
  260. category_job_name: "", //string 职位分类名称(求职意向)
  261. is_pay: "",
  262. },
  263. //工作经历
  264. job_experience: {
  265. company_name: "", // string 公司名称(工作经历
  266. industry_id: "", //string 公司行业ID(工作经历
  267. department: "", //tring 所属部门(工作经历
  268. job_name: "", //ing 职位名称(工作经历
  269. underling_count: "", //unt string 下属数量(工作经历
  270. report_to: "", //ring 汇报对象(工作经历
  271. start_time: "", //ate 在职开始时间: 如 2019-01-01(工作经历
  272. end_time: "", //e 在职结束时间: 如 2019-01-01(工作经历
  273. level_reason: "", // string 离职原因(工作经历
  274. work_content: "", // string 工作内容(工作经历
  275. },
  276. //项目经历
  277. project_experience: {
  278. name: "", //string 项目名称(项目经历
  279. company_name: "", //string 公司名称(项目经历
  280. role: "", // string 项目角色(项目经历
  281. start_time: "", //tring 开始时间(项目经历
  282. end_time: "", //string 结束时间(项目经历
  283. description: "", // string 项目描述(项目经
  284. },
  285. //教育经历
  286. education_experience: {
  287. name: "", //string 学校名称(教育经历
  288. is_recruit: "", //string 是否统招: 1.是, 0.不是(教育经历
  289. education_id: "", //string 学历ID(教育经历
  290. education_name: "", //string 学历名称(教育经历
  291. major: "", //string 专业(教育经历
  292. start_time: "", //string 开始时间 如 2019-01-01(教育经历
  293. end_time: "", //string 结束时间 如 2019-01-01(教育经历
  294. },
  295. //语言能力
  296. language: {
  297. language_id: "", // tring 语言ID(语言能力
  298. level_id: "", // ng 水平ID(语言能力
  299. language_name: "", // string 语言名称(语言能力
  300. level_name: "", // ring 水平名称(语言能力
  301. },
  302. certificate: {
  303. certificate: "",
  304. certificate_date: ""
  305. },
  306. //附件简历
  307. file: {
  308. file: "", //string 附件(附件简历
  309. title: "", //string 附件名称(附件简历
  310. },
  311. education_experience1: [], //教育经历
  312. job_experience1: [], //工作经历
  313. job_intention1: [], //教育经历
  314. project_experience1: [], //项目经历
  315. language1: [], //语言能力
  316. joblist: [],
  317. }
  318. },
  319. onLoad() {
  320. this.get_job_status()
  321. // this.resumeDetail()
  322. },
  323. onShow() {
  324. this.resumeDetail()
  325. },
  326. methods: {
  327. toupload(){
  328. uni.navigateTo({
  329. url:"/pagesD/upload"
  330. })
  331. },
  332. open() {
  333. // console.log('open');
  334. },
  335. close() {
  336. this.jianlishow = false
  337. // console.log('close');
  338. },
  339. preview() {
  340. uni.navigateTo({
  341. url: "/pagesD/preview"
  342. })
  343. },
  344. tocertificate() {
  345. uni.navigateTo({
  346. url: "/pagesD/certificate"
  347. })
  348. },
  349. tolanguage(type, id) {
  350. uni.navigateTo({
  351. url: "/pagesD/language?type=" + type + "&id=" + id
  352. })
  353. },
  354. toteach(type, id) {
  355. uni.navigateTo({
  356. url: "/pagesD/teach?type=" + type + "&id=" + id
  357. })
  358. },
  359. toproject(type, id) {
  360. uni.navigateTo({
  361. url: "/pagesD/project?type=" + type + "&id=" + id
  362. })
  363. },
  364. enter(e) {
  365. this.from.job_status_name = e.value[0].name
  366. this.from.job_status_id = e.value[0].id
  367. this.show = false
  368. },
  369. get_job_status() {
  370. get_job_status().then(res => {
  371. this.columns[0] = res.data
  372. })
  373. },
  374. toadvantage() {
  375. uni.navigateTo({
  376. url: "/pagesD/advantage",
  377. events: {
  378. todcp: (res) => {
  379. this.from.personal_advantage = res
  380. update({
  381. personal_advantage: this.from.personal_advantage,
  382. source_type: "resume",
  383. source_id: this.jlid
  384. }).then(res => {
  385. this.resumeDetail()
  386. })
  387. }
  388. }
  389. })
  390. },
  391. // get_job_status() {
  392. // get_job_status().then(res => {
  393. // this.joblist = res.data
  394. // })
  395. // },
  396. toapply(type, id) {
  397. uni.navigateTo({
  398. url: "/pagesD/apply?type=" + type + "&id=" + id,
  399. events: {
  400. apply: (res) => {
  401. console.log(res);
  402. }
  403. }
  404. })
  405. },
  406. towork(type, id) {
  407. uni.navigateTo({
  408. url: "/pagesD/work?key=" + type + "&id=" + id,
  409. events: {
  410. work: (res) => {
  411. console.log(res);
  412. }
  413. }
  414. })
  415. },
  416. resumeDetail() {
  417. resumeDetail().then(res => {
  418. this.from.avatar = res.data.avatar
  419. this.from.personal_advantage = res.data.personal_advantage
  420. this.jlid = res.data.id
  421. this.from.name = res.data.name,
  422. this.from.birthday_text = res.data.birthday_text,
  423. // this.job_intention.province = res.data.job_intention[0].province,
  424. this.from.experience = res.data.experience
  425. this.education_experience1 = res.data.education_experience
  426. this.job_experience1 = res.data.job_experience
  427. this.job_intention1 = res.data.job_intention
  428. this.language1 = res.data.language
  429. this.project_experience1 = res.data.project_experience
  430. this.from.job_status_name = res.data.job_status_name
  431. this.from.job_status_id = res.data.job_status_id
  432. this.certificate.certificate = res.data.certificate.certificate
  433. this.certificate.certificate_date = res.data.certificate.certificate_date
  434. this.certificate1 = res.data.certificate
  435. this.professional_skill = res.data.certificate[0].professional_skill.split("、")
  436. console.log("pppppppp", this.professional_skill);
  437. })
  438. },
  439. onchange() {
  440. uni.navigateTo({
  441. url: "/pagesD/personal-infor?id=" + this.jlid
  442. })
  443. }
  444. }
  445. }
  446. </script>
  447. <style lang="scss">
  448. .enter {
  449. background: #0C66C2;
  450. border-radius: 12rpx;
  451. margin-top: 68rpx;
  452. font-size: 32rpx;
  453. font-family: PingFangSC-Medium, PingFang SC;
  454. font-weight: 500;
  455. color: #FFFFFF;
  456. height: 84rpx;
  457. }
  458. .updata {
  459. height: 88rpx;
  460. font-size: 32rpx;
  461. font-family: PingFangSC-Medium, PingFang SC;
  462. font-weight: 500;
  463. color: #0C66C2;
  464. background: rgba(12, 102, 194, 0.1);
  465. border-radius: 8rpx;
  466. margin-top: 60rpx;
  467. }
  468. .texta {
  469. margin-right: 20rpx;
  470. }
  471. .three {
  472. font-size: 32rpx;
  473. font-family: PingFangSC-Regular, PingFang SC;
  474. font-weight: 400;
  475. color: #222222;
  476. }
  477. .fore {
  478. font-size: 24rpx;
  479. font-family: SFPro-Regular, SFPro;
  480. font-weight: 400;
  481. color: #777777;
  482. }
  483. .one {
  484. font-size: 36rpx;
  485. font-family: PingFangSC-Medium, PingFang SC;
  486. font-weight: 500;
  487. color: #222222;
  488. }
  489. .two {
  490. font-size: 26rpx;
  491. font-family: PingFangSC-Regular, PingFang SC;
  492. font-weight: 400;
  493. color: #555555;
  494. margin-top: 24rpx;
  495. }
  496. .concent {
  497. font-size: 28rpx;
  498. font-family: PingFangSC-Regular, PingFang SC;
  499. font-weight: 400;
  500. color: #555555;
  501. margin-top: 20rpx;
  502. }
  503. .mar {
  504. margin-top: 20rpx;
  505. }
  506. .title {
  507. font-size: 32rpx;
  508. font-family: PingFangSC-Medium, PingFang SC;
  509. font-weight: 500;
  510. color: #222222;
  511. margin-top: 34rpx;
  512. }
  513. .item {
  514. height: 48rpx;
  515. background: #F4F4F4;
  516. border-radius: 6rpx;
  517. padding: 5rpx 14rpx;
  518. box-sizing: border-box;
  519. line-height: 48rpx;
  520. }
  521. .resumepage {
  522. padding: 0 32rpx;
  523. background-color: #fff;
  524. }
  525. .back {
  526. padding: 16rpx 32rpx;
  527. background: #FFFFFF;
  528. height: 166rpx;
  529. box-sizing: border-box;
  530. position: fixed;
  531. bottom: 0;
  532. left: 0;
  533. .left {
  534. width: 356rpx;
  535. background: #0C66C2;
  536. border-radius: 12rpx;
  537. font-size: 32rpx;
  538. font-family: PingFangSC-Medium, PingFang SC;
  539. font-weight: 500;
  540. color: #FFFFFF;
  541. height: 88rpx;
  542. line-height: 88rpx;
  543. margin-right: 24rpx;
  544. text-align: center;
  545. }
  546. .right {
  547. width: 304rpx;
  548. // opacity: 0.1;
  549. // background: #0C66C2;
  550. border-radius: 12rpx;
  551. font-size: 32rpx;
  552. font-family: PingFangSC-Medium, PingFang SC;
  553. font-weight: 500;
  554. color: #0C66C2;
  555. height: 88rpx;
  556. line-height: 88rpx;
  557. text-align: center;
  558. background-color: rgba(12, 102, 194, 0.1);
  559. }
  560. }
  561. </style>