apply.vue 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584
  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({
  268. id: this.id
  269. }).then(res => {
  270. console.log(res);
  271. if (res.code == 1) {
  272. } else {
  273. this.$u.toast(res.msg)
  274. this.job_intention.is_pay = 0
  275. this.resumeDetail()
  276. }
  277. })
  278. } else {
  279. this.job_intention.is_pay = 0
  280. }
  281. },
  282. //所有地区
  283. AllArea() {
  284. getAllArea().then((res) => {
  285. // console.log(res);
  286. this.province = res.data.map(t => {
  287. return {
  288. name: t.name,
  289. id: t.id
  290. }
  291. })
  292. // console.log("aaa", this.province);
  293. this.city = res.data.map(t => t.children.map(v => {
  294. return {
  295. name: v.name,
  296. id: v.id
  297. }
  298. }))
  299. this.area = res.data.map(t => t.children.map(v => v.children.map(i => {
  300. return {
  301. name: i.name,
  302. id: i.id
  303. }
  304. })))
  305. //默认显示数据
  306. // this.cityList = [
  307. // this.province.map(res => res.name),
  308. // this.city[0].map(res => res.name),
  309. // this.area[0][0].map(res => res.name)
  310. // ]
  311. let a = []
  312. let b = []
  313. let c = []
  314. this.province.map(res => {
  315. a.push({
  316. name: res.name,
  317. id: res.id,
  318. })
  319. })
  320. this.city[0].map(res => {
  321. b.push({
  322. name: res.name,
  323. id: res.id,
  324. })
  325. })
  326. this.area[0][0].map(res => {
  327. c.push({
  328. name: res.name,
  329. id: res.id,
  330. })
  331. })
  332. this.cityList = [a, b, c]
  333. // if (this.province && this.city && this.area) {
  334. // //省索引
  335. // let pIdx = this.province.findIndex(v => v.name == this.province);
  336. // //根据省索引设置默认市数据
  337. // this.columns[1] = this.city[pIdx].map(res => res.name)
  338. // //市索引
  339. // let cIdx = this.city[pIdx].findIndex(v => v.name == this.city);
  340. // //根据市索引设置默认区数据
  341. // this.columns[2] = this.area[pIdx][cIdx].map(res => res.name)
  342. // //区索引
  343. // let aIdx = this.area[pIdx][cIdx].findIndex(v => v.name == this.area);
  344. // this.indexs = [pIdx, cIdx, aIdx];
  345. // // console.log(pIdx, cIdx, aIdx);
  346. // console.log(this.indexs);
  347. // }
  348. // if (this.addressData.province && this.addressData.city && this.addressData.area) {
  349. // //省索引
  350. // let pIdx = this.province.findIndex(v => v.name == this.addressData.province);
  351. // //根据省索引设置默认市数据
  352. // this.columns[1] = this.city[pIdx].map(res => res.name)
  353. // //市索引
  354. // let cIdx = this.city[pIdx].findIndex(v => v.name == this.addressData.city);
  355. // //根据市索引设置默认区数据
  356. // this.columns[2] = this.area[pIdx][cIdx].map(res => res.name)
  357. // //区索引
  358. // let aIdx = this.area[pIdx][cIdx].findIndex(v => v.name == this.addressData.area);
  359. // this.indexs = [pIdx, cIdx, aIdx];
  360. // // console.log(pIdx, cIdx, aIdx);
  361. // console.log(this.indexs);
  362. // }
  363. })
  364. },
  365. changeHandler(e) {
  366. const {
  367. columnIndex, //当前改变值的列下标
  368. value,
  369. values, // values为当前变化列的数组内容
  370. indexs, //当前地区值下标
  371. picker = this.$refs.uPicker
  372. } = e
  373. //columnIndex代表第几列,意思是下标为0的列发生变化
  374. if (columnIndex === 0) {
  375. picker.setColumnValues(1, this.city[indexs[0]].map(v => {
  376. return {
  377. name: v.name,
  378. id: v.id
  379. }
  380. }))
  381. picker.setColumnValues(2, this.area[indexs[0]][0].map(v => {
  382. return {
  383. name: v.name,
  384. id: v.id
  385. }
  386. }))
  387. }
  388. if (columnIndex === 1) {
  389. picker.setColumnValues(2, this.area[indexs[0]][indexs[1]].map(v => {
  390. return {
  391. name: v.name,
  392. id: v.id
  393. }
  394. }))
  395. }
  396. },
  397. //点击显示时间选择器
  398. birthdayBtn() {
  399. this.birthdayShow = true
  400. //new Date(this.endDate).getTime()为你需要在选择器上显示的时间戳
  401. this.$refs.picker.innerValue = new Date(946656000000).getTime()
  402. },
  403. //出生日期选择器
  404. async birthdayConfirm(e) {
  405. const timeFormat = uni.$u.timeFormat;
  406. let timeValue = await timeFormat(e.value, 'yyyy-mm-dd');
  407. this.job_intention.job_date = timeValue;
  408. this.birthdayShow = false
  409. },
  410. //户口地址
  411. cityconfirm(e) {
  412. let a = e.value[0].name + e.value[1].name + e.value[2].name
  413. let ids = String(e.value[0].id) + String(e.value[1].id) + String(e.value[2].id)
  414. this.job_intention.province_id = e.value[1].id
  415. this.job_intention.city_id = e.value[0].id
  416. // this.city1 = e.value.join("")
  417. this.city1 = a
  418. this.cityShow = false
  419. },
  420. changehangye() {
  421. uni.navigateTo({
  422. url: "/pagesA/change-hangye1",
  423. events: {
  424. changehangye: (res) => {
  425. // this.job_intention.category_one = res[0].id, //行业一级ID
  426. // this.job_intention.category_two = res[1].id, //行业二级ID
  427. this.category_three = res[1].name //行业名称
  428. }
  429. }
  430. })
  431. },
  432. changehangye1() {
  433. uni.navigateTo({
  434. url: "/pagesA/change-hangye1",
  435. events: {
  436. changehangye: (res) => {
  437. // console.log(res);
  438. // res.forEach((item) => {
  439. // this.category_industry_name += item.name + " "
  440. // // this.category_industry_id = item.id
  441. // })
  442. this.category_industry_name = res[1].name
  443. this.job_intention.category_industry_first = res[0].id, //行业一级ID
  444. this.job_intention.category_industry_id = res[1].id //行业二级ID
  445. }
  446. }
  447. })
  448. },
  449. changeright() {
  450. uni.navigateTo({
  451. url: "/pagesA/change-zhiwei",
  452. events: {
  453. changefenlei: (res) => {
  454. this.job_intention.category_job_first = res[0].id //string 职业分类一级ID(求职意向
  455. this.job_intention.category_job_second = res[1].id //string 职业分类二级ID(求职意向
  456. this.job_intention.category_job_id = res[2].id //string 职位分类ID(求职意向
  457. this.category_job_first_name = res[0].name //string 职业分类一级名称(求职意向
  458. this.category_job_second_name = res[1].name //string 职业分类二级名称(求职意向
  459. this.category_job_name = res[2].name
  460. }
  461. }
  462. })
  463. },
  464. changeright1() {
  465. uni.navigateTo({
  466. url: "/pagesA/change-zhiwei",
  467. events: {
  468. changefenlei: (res) => {
  469. this.category_job3 = res[2].name
  470. }
  471. }
  472. })
  473. }
  474. }
  475. }
  476. </script>
  477. <style lang="scss">
  478. .bot {
  479. position: fixed;
  480. bottom: 0;
  481. width: 682rpx;
  482. }
  483. .btn {
  484. background: #0C66C2;
  485. border-radius: 16rpx;
  486. font-size: 32rpx;
  487. font-family: PingFangSC-Regular, PingFang SC;
  488. font-weight: 400;
  489. color: #FFFFFF;
  490. width: 310rpx;
  491. height: 84rpx;
  492. line-height: 84rpx;
  493. text-align: center;
  494. margin-top: 24rpx;
  495. }
  496. //个人信息
  497. .personal {
  498. width: 750rpx;
  499. background: #FFFFFF;
  500. border-radius: 28rpx 28rpx 0rpx 0rpx;
  501. margin-top: -40rpx;
  502. position: relative;
  503. z-index: 99;
  504. padding: 40rpx 32rpx 0;
  505. margin-bottom: 60rpx;
  506. box-sizing: border-box;
  507. .title {
  508. font-size: 48rpx;
  509. font-family: PingFangSC-Medium, PingFang SC;
  510. font-weight: 500;
  511. color: #222222;
  512. }
  513. .titleb {
  514. font-size: 26rpx;
  515. font-family: PingFangSC-Regular, PingFang SC;
  516. font-weight: 400;
  517. color: #777777;
  518. margin-top: 20rpx;
  519. }
  520. .body-input {
  521. height: 150rpx;
  522. border-bottom: 2rpx solid #F4F4F4;
  523. .input-title {
  524. font-size: 26rpx;
  525. font-family: PingFangSC-Regular, PingFang SC;
  526. font-weight: 400;
  527. color: #888888;
  528. margin-top: 30rpx;
  529. box-sizing: border-box;
  530. }
  531. .input-style {
  532. font-size: 32rpx;
  533. font-family: PingFangSC-Regular, PingFang SC;
  534. font-weight: 400;
  535. color: #CACACA;
  536. }
  537. }
  538. .button1 {
  539. width: 256rpx;
  540. background: #F3F3F3;
  541. border-radius: 12rpx;
  542. margin-right: 24rpx;
  543. padding: 20rpx 50rpx;
  544. font-size: 32rpx;
  545. font-family: PingFangSC-Medium, PingFang SC;
  546. font-weight: 500;
  547. color: #333333;
  548. text-align: center;
  549. height: 88rpx !important;
  550. box-sizing: border-box;
  551. }
  552. .button {
  553. flex: 1;
  554. height: 88rpx !important;
  555. background: #0C66C2;
  556. border-radius: 12rpx;
  557. font-size: 32rpx;
  558. font-family: PingFangSC-Medium, PingFang SC;
  559. font-weight: 500;
  560. color: #FFFFFF;
  561. line-height: 88rpx;
  562. display: flex;
  563. justify-content: center;
  564. }
  565. }
  566. </style>