preview.vue 16 KB

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