apply.vue 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582
  1. <template>
  2. <view class="personal">
  3. <view class="">
  4. <text class="title">{{bigtitle}}求职意向</text>
  5. <view class="titleb">不同的求职期望,推荐啊的职位也会不同。</view>
  6. </view>
  7. <view class="body-input u-flex-col u-row-center" @click="birthdayBtn">
  8. <text class="input-title">求职时间</text>
  9. <u--input :disabled="true" disabledColor="#fff" customStyle="padding:0 !important" type="text"
  10. placeholder="请选择您的求职时间" border placeholderClass='input-style' suffixIcon="arrow-right"
  11. suffixIconStyle="font-size: 32rpx;font-weight: 400;color: #CACACA;"
  12. v-model="job_intention.job_date"></u--input>
  13. </view>
  14. <view class="body-input u-flex-col u-row-center" @click="cityShow = true">
  15. <text class="input-title">期望城市</text>
  16. <u--input :disabled="true" disabledColor="#fff" customStyle="padding:0 !important" type="text"
  17. placeholder="请选择您的期望城市" border placeholderClass='input-style' suffixIcon="arrow-right"
  18. suffixIconStyle="font-size: 32rpx;font-weight: 400;color: #CACACA;" v-model="city1"></u--input>
  19. </view>
  20. <view class="body-input u-flex-col u-row-center" @click="show = true">
  21. <text class="input-title">期望薪资</text>
  22. <u--input :value="label" :disabled="true" disabledColor="#fff" customStyle="padding:0 !important"
  23. type="text" placeholder="请选择您的期望薪资" border placeholderClass='input-style' suffixIcon="arrow-right"
  24. suffixIconStyle="font-size: 32rpx;font-weight: 400;color: #CACACA;"></u--input>
  25. </view>
  26. <!-- <view class="body-input u-flex-col u-row-center" @click="changehangye">
  27. <text class="input-title">当前行业</text>
  28. <u--input :disabled="true" disabledColor="#fff" customStyle="padding:0 !important" type="text"
  29. placeholder="请选择您的当前行业" border placeholderClass='input-style' suffixIcon="arrow-right"
  30. suffixIconStyle="font-size: 32rpx;font-weight: 400;color: #CACACA;" v-model="category_three"></u--input>
  31. </view> -->
  32. <view class="body-input u-flex-col u-row-center" @click="changehangye1">
  33. <text class="input-title">期望行业</text>
  34. <u--input :disabled="true" disabledColor="#fff" customStyle="padding:0 !important" type="text"
  35. placeholder="请选择您的期望行业" border placeholderClass='input-style' suffixIcon="arrow-right"
  36. suffixIconStyle="font-size: 32rpx;font-weight: 400;color: #CACACA;"
  37. v-model="category_industry_name"></u--input>
  38. </view>
  39. <!-- <view class="body-input u-flex-col u-row-center" @click="changeright1">
  40. <text class="input-title">当前职位</text>
  41. <u--input :disabled="true" disabledColor="#fff" customStyle="padding:0 !important" type="text"
  42. placeholder="请选择您的当前职位" border placeholderClass='input-style' suffixIcon="arrow-right"
  43. suffixIconStyle="font-size: 32rpx;font-weight: 400;color: #CACACA;" v-model="category_job3"></u--input>
  44. </view> -->
  45. <view class="body-input u-flex-col u-row-center" @click="changeright">
  46. <text class="input-title">期望职位</text>
  47. <u--input :disabled="true" disabledColor="#fff" customStyle="padding:0 !important" type="text"
  48. placeholder="请选择您的期望职位" border placeholderClass='input-style' suffixIcon="arrow-right"
  49. suffixIconStyle="font-size: 32rpx;font-weight: 400;color: #CACACA;"
  50. v-model="category_job_name"></u--input>
  51. </view>
  52. <view class="u-flex u-row-between" style="margin-top: 30rpx;">
  53. <view class="u-flex">
  54. <text>付费求职</text>
  55. <image @click="propshow=true" style="width: 32rpx;height: 32rpx;" src="/static/images/xiangguan.png"
  56. mode=""></image>
  57. </view>
  58. <u-switch v-model="button" @change="change"></u-switch>
  59. </view>
  60. <view class="u-flex u-row-between bot" style="height: 166rpx;">
  61. <view class="safe-area-inset-bottom"></view>
  62. <view v-if="type==2" class="button1" @click="dele">
  63. 删除
  64. </view>
  65. <view class="button" @click="next">
  66. 保存
  67. </view>
  68. <view class="safe-area-inset-bottom"></view>
  69. </view>
  70. <u-datetime-picker ref="picker" title="求职时间" :minDate="minDate" @confirm="birthdayConfirm" :show="birthdayShow"
  71. mode="date" @cancel='birthdayShow = false'></u-datetime-picker>
  72. <u-picker ref="uPicker" keyName="name" title="期望城市" :defaultIndex="indexs" :show="cityShow" :columns="cityList"
  73. @confirm="cityconfirm" @cancel="cityShow = false" @change="changeHandler"></u-picker>
  74. <u-popup :show="propshow" mode="center" @close="propshow = false" round="20">
  75. <view style="width:570rpx ;padding: 32rpx;border-radius: 20rpx;">
  76. <text>感谢您使用平安健康保险App,我们非常重视您的信息和隐私</text>
  77. <view class="u-flex" style="justify-content: center;">
  78. <view class="btn" @click="propshow=false">
  79. 我知道了
  80. </view>
  81. </view>
  82. </view>
  83. </u-popup>
  84. <u-modal :showCancelButton="true" :show="delec" :title="title" :content='content' @confirm="confirm"
  85. @cancel="delec = false"></u-modal>
  86. <u-picker keyName="label" title="期待薪资" :show="show" :columns="xinzilist" @confirm="xin"
  87. @cancel="show = false"></u-picker>
  88. </view>
  89. </template>
  90. <script setup>
  91. import {
  92. getAllArea,
  93. update,
  94. resumeDetail,
  95. destroy,
  96. pay
  97. } from "@/units/inquire.js"
  98. export default {
  99. data() {
  100. return {
  101. label: "",
  102. show: false,
  103. title: "您确定要删除该求职意向吗?",
  104. delec: false,
  105. type: 2,
  106. bigtitle: "添加",
  107. button: false,
  108. propshow: false,
  109. province: [], //省数据
  110. city: [], //市数据
  111. area: [], //区数据
  112. provinceid: "", //省数据
  113. cityid: "", //市数据
  114. areaid: "", //区数据
  115. indexs: [], //默认地区下标
  116. //选择器状态
  117. birthdayShow: false, //出生年月
  118. workShow: false, //工作时间
  119. cityShow: false, //户口所在地
  120. jobShow: false, //工作显示
  121. cityList: [], //数据地址
  122. cityids: [], //数据地址
  123. joblist: [],
  124. id: "",
  125. category_three: "",
  126. category_job3: "",
  127. city1: "", //string 期望城市名称(求职意向
  128. category_industry_name: "", //string 行业名称(求职意向
  129. category_job_first_name: "", //string 职业分类一级名称(求职意向
  130. category_job_second_name: "", //string 职业分类二级名称(求职意向
  131. category_job_name: "", //string 职位分类名称(求职意向
  132. category_field_name: "", //string 领域名称(求职意向
  133. job_intention: {
  134. category_field_first: 10,
  135. category_field_id: 44,
  136. job_date: "", //date 求职时间(求职意向
  137. province_id: "", //string 期望省份ID(求职意向
  138. city_id: "", //string 期望城市ID(求职意向
  139. salary_type: "month", //string 薪资类型: year=年薪;month=月薪(求职意向
  140. salary: "", //string 薪水(求职意向
  141. // salary_month: "", //string 一年多少薪(求职意向
  142. // category_field_id: "", //string 领域ID(求职意向
  143. category_industry_first: "", //string 行业一级ID(求职意向
  144. category_industry_id: "", //string 行业ID(求职意向
  145. category_job_first: "", //string 职业分类一级ID(求职意向
  146. category_job_second: "", //string 职业分类二级ID(求职意向
  147. category_job_id: "", //string 职位分类ID(求职意向
  148. is_pay: 0,
  149. // city1: "",
  150. source_id: this.id
  151. },
  152. xinzilist: [
  153. ]
  154. }
  155. },
  156. onLoad(opsition) {
  157. this.AllArea()
  158. this.xinzi()
  159. this.id = opsition.id
  160. // console.log(this.id);
  161. this.type = opsition.type
  162. // console.log(this.type);
  163. if (opsition.type == 1) {
  164. this.bigtitle = "添加"
  165. } else {
  166. this.bigtitle = "编辑"
  167. this.resumeDetail()
  168. }
  169. },
  170. methods: {
  171. xin(e) {
  172. this.job_intention.salary_month = e.value[0].value
  173. this.label = e.value[0].label
  174. this.show = false
  175. },
  176. xinzi() {
  177. var xinzilist = []
  178. for (var i = 1; i <= 100; i++) {
  179. xinzilist.push({
  180. label: `${i}K`,
  181. value: i
  182. })
  183. }
  184. this.xinzilist.push(xinzilist)
  185. },
  186. dele() {
  187. this.delec = true
  188. },
  189. confirm() {
  190. destroy({
  191. source_type: "job_intention",
  192. source_id: this.id
  193. }).then(res => {
  194. this.$u.toast("删除成功")
  195. setTimeout(() => {
  196. const eventChannel = this.getOpenerEventChannel()
  197. eventChannel.emit("refresh", "")
  198. uni.navigateBack()
  199. }, 800)
  200. })
  201. },
  202. resumeDetail() {
  203. resumeDetail().then(res => {
  204. res.data.job_intention.forEach((item) => {
  205. if (item.id == this.id) {
  206. this.job_intention.category_field_first = item.category_field_first
  207. this.label = item.salary_month+"k"
  208. this.job_intention.category_field_id = item.category_field_id
  209. this.category_field_name = item.category_field_name
  210. this.job_intention.category_industry_first = item.category_industry_first
  211. this.job_intention.category_industry_id = item.category_industry_id
  212. this.category_industry_name = item.category_industry_name
  213. this.job_intention.category_job_first = item.category_job_first
  214. this.job_intention.category_job_first_name = item.category_job_first_name
  215. this.job_intention.category_job_id = item.category_job_id
  216. this.category_job_name = item.category_job_name
  217. this.job_intention.category_job_second = item.category_job_second
  218. this.category_job_second_name = item.category_job_second_name
  219. this.city1 = item.province + item.city
  220. this.job_intention.city_id = item.city_id
  221. this.job_intention.is_pay = item.is_pay
  222. if (this.job_intention.is_pay == 0) {
  223. this.button = false
  224. } else {
  225. this.button = true
  226. }
  227. this.job_intention.job_date = item.job_date
  228. this.job_intention.province_id = item.province_id
  229. this.job_intention.salary = item.salary
  230. this.job_intention.salary_month = item.salary_month
  231. this.job_intention.salary_type = item.salary_type
  232. this.job_intention.source_id = this.id
  233. }
  234. })
  235. })
  236. },
  237. //保存
  238. next() {
  239. // if (!this.job_intention.job_date) {
  240. // this.$u.toast("请选择求职时间")
  241. // return
  242. // }
  243. if (!this.city1) {
  244. this.$u.toast("请选择期望城市")
  245. return
  246. }
  247. if (!this.category_industry_name) {
  248. this.$u.toast("请选择期望行业")
  249. return
  250. }
  251. if (!this.category_job_name) {
  252. this.$u.toast("请选择职位")
  253. return
  254. }
  255. update({
  256. source_type: "job_intention",
  257. ...this.job_intention
  258. }).then(res => {
  259. const eventChannel = this.getOpenerEventChannel();
  260. eventChannel.emit('refresh', '');
  261. uni.navigateBack()
  262. })
  263. },
  264. change(e) {
  265. if (e) {
  266. this.job_intention.is_pay = 1
  267. pay({id:this.id}).then(res=>{
  268. console.log(res);
  269. if(res.code==1){
  270. }else{
  271. this.$u.toast(res.msg)
  272. this.job_intention.is_pay = 0
  273. this.resumeDetail()
  274. }
  275. })
  276. } else {
  277. this.job_intention.is_pay = 0
  278. }
  279. },
  280. //所有地区
  281. AllArea() {
  282. getAllArea().then((res) => {
  283. // console.log(res);
  284. this.province = res.data.map(t => {
  285. return {
  286. name: t.name,
  287. id: t.id
  288. }
  289. })
  290. // console.log("aaa", this.province);
  291. this.city = res.data.map(t => t.children.map(v => {
  292. return {
  293. name: v.name,
  294. id: v.id
  295. }
  296. }))
  297. this.area = res.data.map(t => t.children.map(v => v.children.map(i => {
  298. return {
  299. name: i.name,
  300. id: i.id
  301. }
  302. })))
  303. //默认显示数据
  304. // this.cityList = [
  305. // this.province.map(res => res.name),
  306. // this.city[0].map(res => res.name),
  307. // this.area[0][0].map(res => res.name)
  308. // ]
  309. let a = []
  310. let b = []
  311. let c = []
  312. this.province.map(res => {
  313. a.push({
  314. name: res.name,
  315. id: res.id,
  316. })
  317. })
  318. this.city[0].map(res => {
  319. b.push({
  320. name: res.name,
  321. id: res.id,
  322. })
  323. })
  324. this.area[0][0].map(res => {
  325. c.push({
  326. name: res.name,
  327. id: res.id,
  328. })
  329. })
  330. this.cityList = [a, b, c]
  331. // if (this.province && this.city && this.area) {
  332. // //省索引
  333. // let pIdx = this.province.findIndex(v => v.name == this.province);
  334. // //根据省索引设置默认市数据
  335. // this.columns[1] = this.city[pIdx].map(res => res.name)
  336. // //市索引
  337. // let cIdx = this.city[pIdx].findIndex(v => v.name == this.city);
  338. // //根据市索引设置默认区数据
  339. // this.columns[2] = this.area[pIdx][cIdx].map(res => res.name)
  340. // //区索引
  341. // let aIdx = this.area[pIdx][cIdx].findIndex(v => v.name == this.area);
  342. // this.indexs = [pIdx, cIdx, aIdx];
  343. // // console.log(pIdx, cIdx, aIdx);
  344. // console.log(this.indexs);
  345. // }
  346. // if (this.addressData.province && this.addressData.city && this.addressData.area) {
  347. // //省索引
  348. // let pIdx = this.province.findIndex(v => v.name == this.addressData.province);
  349. // //根据省索引设置默认市数据
  350. // this.columns[1] = this.city[pIdx].map(res => res.name)
  351. // //市索引
  352. // let cIdx = this.city[pIdx].findIndex(v => v.name == this.addressData.city);
  353. // //根据市索引设置默认区数据
  354. // this.columns[2] = this.area[pIdx][cIdx].map(res => res.name)
  355. // //区索引
  356. // let aIdx = this.area[pIdx][cIdx].findIndex(v => v.name == this.addressData.area);
  357. // this.indexs = [pIdx, cIdx, aIdx];
  358. // // console.log(pIdx, cIdx, aIdx);
  359. // console.log(this.indexs);
  360. // }
  361. })
  362. },
  363. changeHandler(e) {
  364. const {
  365. columnIndex, //当前改变值的列下标
  366. value,
  367. values, // values为当前变化列的数组内容
  368. indexs, //当前地区值下标
  369. picker = this.$refs.uPicker
  370. } = e
  371. //columnIndex代表第几列,意思是下标为0的列发生变化
  372. if (columnIndex === 0) {
  373. picker.setColumnValues(1, this.city[indexs[0]].map(v => {
  374. return {
  375. name: v.name,
  376. id: v.id
  377. }
  378. }))
  379. picker.setColumnValues(2, this.area[indexs[0]][0].map(v => {
  380. return {
  381. name: v.name,
  382. id: v.id
  383. }
  384. }))
  385. }
  386. if (columnIndex === 1) {
  387. picker.setColumnValues(2, this.area[indexs[0]][indexs[1]].map(v => {
  388. return {
  389. name: v.name,
  390. id: v.id
  391. }
  392. }))
  393. }
  394. },
  395. //点击显示时间选择器
  396. birthdayBtn() {
  397. this.birthdayShow = true
  398. //new Date(this.endDate).getTime()为你需要在选择器上显示的时间戳
  399. this.$refs.picker.innerValue = new Date(946656000000).getTime()
  400. },
  401. //出生日期选择器
  402. async birthdayConfirm(e) {
  403. const timeFormat = uni.$u.timeFormat;
  404. let timeValue = await timeFormat(e.value, 'yyyy-mm-dd');
  405. this.job_intention.job_date = timeValue;
  406. this.birthdayShow = false
  407. },
  408. //户口地址
  409. cityconfirm(e) {
  410. let a = e.value[0].name + e.value[1].name + e.value[2].name
  411. let ids = String(e.value[0].id) + String(e.value[1].id) + String(e.value[2].id)
  412. this.job_intention.province_id = e.value[1].id
  413. this.job_intention.city_id = e.value[0].id
  414. // this.city1 = e.value.join("")
  415. this.city1 = a
  416. this.cityShow = false
  417. },
  418. changehangye() {
  419. uni.navigateTo({
  420. url: "/pagesA/change-hangye1",
  421. events: {
  422. changehangye: (res) => {
  423. // this.job_intention.category_one = res[0].id, //行业一级ID
  424. // this.job_intention.category_two = res[1].id, //行业二级ID
  425. this.category_three = res[1].name //行业名称
  426. }
  427. }
  428. })
  429. },
  430. changehangye1() {
  431. uni.navigateTo({
  432. url: "/pagesA/change-hangye1",
  433. events: {
  434. changehangye: (res) => {
  435. // console.log(res);
  436. // res.forEach((item) => {
  437. // this.category_industry_name += item.name + " "
  438. // // this.category_industry_id = item.id
  439. // })
  440. this.category_industry_name = res[1].name
  441. this.job_intention.category_industry_first = res[0].id, //行业一级ID
  442. this.job_intention.category_industry_id = res[1].id //行业二级ID
  443. }
  444. }
  445. })
  446. },
  447. changeright() {
  448. uni.navigateTo({
  449. url: "/pagesA/change-zhiwei",
  450. events: {
  451. changefenlei: (res) => {
  452. this.job_intention.category_job_first = res[0].id //string 职业分类一级ID(求职意向
  453. this.job_intention.category_job_second = res[1].id //string 职业分类二级ID(求职意向
  454. this.job_intention.category_job_id = res[2].id //string 职位分类ID(求职意向
  455. this.category_job_first_name = res[0].name //string 职业分类一级名称(求职意向
  456. this.category_job_second_name = res[1].name //string 职业分类二级名称(求职意向
  457. this.category_job_name = res[2].name
  458. }
  459. }
  460. })
  461. },
  462. changeright1() {
  463. uni.navigateTo({
  464. url: "/pagesA/change-zhiwei",
  465. events: {
  466. changefenlei: (res) => {
  467. this.category_job3 = res[2].name
  468. }
  469. }
  470. })
  471. }
  472. }
  473. }
  474. </script>
  475. <style lang="scss">
  476. .bot {
  477. position: fixed;
  478. bottom: 0;
  479. width: 682rpx;
  480. }
  481. .btn {
  482. background: #0C66C2;
  483. border-radius: 16rpx;
  484. font-size: 32rpx;
  485. font-family: PingFangSC-Regular, PingFang SC;
  486. font-weight: 400;
  487. color: #FFFFFF;
  488. width: 310rpx;
  489. height: 84rpx;
  490. line-height: 84rpx;
  491. text-align: center;
  492. margin-top: 24rpx;
  493. }
  494. //个人信息
  495. .personal {
  496. width: 750rpx;
  497. background: #FFFFFF;
  498. border-radius: 28rpx 28rpx 0rpx 0rpx;
  499. margin-top: -40rpx;
  500. position: relative;
  501. z-index: 99;
  502. padding: 40rpx 32rpx 0;
  503. margin-bottom: 60rpx;
  504. box-sizing: border-box;
  505. .title {
  506. font-size: 48rpx;
  507. font-family: PingFangSC-Medium, PingFang SC;
  508. font-weight: 500;
  509. color: #222222;
  510. }
  511. .titleb {
  512. font-size: 26rpx;
  513. font-family: PingFangSC-Regular, PingFang SC;
  514. font-weight: 400;
  515. color: #777777;
  516. margin-top: 20rpx;
  517. }
  518. .body-input {
  519. height: 150rpx;
  520. border-bottom: 2rpx solid #F4F4F4;
  521. .input-title {
  522. font-size: 26rpx;
  523. font-family: PingFangSC-Regular, PingFang SC;
  524. font-weight: 400;
  525. color: #888888;
  526. margin-top: 30rpx;
  527. box-sizing: border-box;
  528. }
  529. .input-style {
  530. font-size: 32rpx;
  531. font-family: PingFangSC-Regular, PingFang SC;
  532. font-weight: 400;
  533. color: #CACACA;
  534. }
  535. }
  536. .button1 {
  537. width: 256rpx;
  538. background: #F3F3F3;
  539. border-radius: 12rpx;
  540. margin-right: 24rpx;
  541. padding: 20rpx 50rpx;
  542. font-size: 32rpx;
  543. font-family: PingFangSC-Medium, PingFang SC;
  544. font-weight: 500;
  545. color: #333333;
  546. text-align: center;
  547. height: 88rpx !important;
  548. box-sizing: border-box;
  549. }
  550. .button {
  551. flex: 1;
  552. height: 88rpx !important;
  553. background: #0C66C2;
  554. border-radius: 12rpx;
  555. font-size: 32rpx;
  556. font-family: PingFangSC-Medium, PingFang SC;
  557. font-weight: 500;
  558. color: #FFFFFF;
  559. line-height: 88rpx;
  560. display: flex;
  561. justify-content: center;
  562. }
  563. }
  564. </style>