apply.vue 18 KB

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