general.vue 9.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413
  1. <template>
  2. <view class="index-page">
  3. <view class="index-navbar">
  4. <view style="position: relative;height: 392rpx;">
  5. <image class="index-bg" src="../static/images/index-header.png" mode=""></image>
  6. <u-navbar :fixed="false" bgColor='rgba(0,0,0,0)' placeholder :safeAreaInsetTop="true"
  7. @leftClick="return1"></u-navbar>
  8. <view class="header">
  9. <image style="width: 104rpx;height: 104rpx;" :src="detail.school.logo" mode=""></image>
  10. <view class="font">
  11. <text class="title">{{detail.school.name}}{{detail.title}}</text>
  12. <text
  13. class="active">活动时间:{{(detail.start_time).replaceAll('-','.')}}-{{(detail.end_time).replaceAll("-",".").slice(-5)}}</text>
  14. </view>
  15. </view>
  16. <view class="u-flex" style="box-sizing: border-box; padding: 18rpx 24rpx;height: 70rpx;">
  17. <view class="u-flex" @click="showcity = true">
  18. <text class="font1" style="margin-right: 14rpx;">{{city_name|| '工作城市'}}</text>
  19. <u-icon name="arrow-down-fill" size="8"></u-icon>
  20. </view>
  21. <!-- <view class="u-flex" style="margin-left: 54rpx;">
  22. <text class="font1" style="margin-right: 14rpx;">职位类型</text>
  23. <u-icon name="arrow-down-fill" size="8"></u-icon>
  24. </view> -->
  25. </view>
  26. </view>
  27. <view class="contant">
  28. <view class="list" @click="togongsi(item.id)" v-for="(item,index) in company_list" :key="item.id">
  29. <view class="u-flex u-row-between">
  30. <view class="title">
  31. <text class="title">{{item.company.name}}</text>
  32. <text class="jianjie">{{item.company.categoryindustry.name}} {{item.company.stage.name}}
  33. {{item.company.scale.name}}</text>
  34. </view>
  35. <image style="width: 93rpx;height: 92rpx;" :src="item.company.logo" mode=""></image>
  36. </view>
  37. <view class="bottom">
  38. <view class="u-flex" style="margin-top: 18rpx;">
  39. <image style="width: 28rpx;height: 28rpx;" src="../static/images/address.png" mode="">
  40. </image>
  41. <text class="font" v-for="(city,cityindex) in item.city.slice(0,2)"
  42. :key="city.apply.id">{{city.city}}</text>
  43. <text class="font" v-if="item.city.length == 1">{{item.city.length}}个城市</text>
  44. <text class="font" v-else>等{{item.city.length}}个城市</text>
  45. </view>
  46. <view class="u-flex" style="margin-top: 32rpx;">
  47. <image style="width: 28rpx;height: 28rpx;" src="../static/images/woek.png" mode=""></image>
  48. <text class="font" v-for="(job,index) in item.activityjobinfo.slice(0,2)"
  49. :key="job.apply.id">{{job.job_name}}</text>
  50. <text class="font"
  51. v-if="item.activityjobinfo.length == 1">{{item.activityjobinfo.length}}个岗位</text>
  52. <text class="font" v-else>等{{item.activityjobinfo.length}}个岗位</text>
  53. </view>
  54. </view>
  55. </view>
  56. </view>
  57. <view style="height: 70vh;display: flex;justify-content: center;align-items: center;"
  58. v-if="company_list.length == 0">
  59. <u-empty text="暂无数据" mode="list"></u-empty>
  60. </view>
  61. <u-picker :columns="cityList" ref="uPicker" :show="showcity" keyName="name" @confirm="changecity"
  62. @change="changeHandler" @cancel="showcity = false"></u-picker>
  63. </view>
  64. </view>
  65. </template>
  66. <script>
  67. import {
  68. get_detail,
  69. get_company_list,
  70. getAllArea
  71. } from "@/units/inquire.js"
  72. export default {
  73. data() {
  74. return {
  75. showcity: 0,
  76. id: '',
  77. detail: {
  78. start_time: "",
  79. end_time: ""
  80. },
  81. job_id: "",
  82. city_id: '',
  83. company_list: [],
  84. city_name: '',
  85. cityList:[]
  86. }
  87. },
  88. onLoad(option) {
  89. this.id = option.id
  90. this.getdetail()
  91. this.getcompanylist()
  92. this.getAllArea()
  93. },
  94. onReachBottom() {
  95. },
  96. methods: {
  97. changeHandler(e) {
  98. const {
  99. columnIndex, //当前改变值的列下标
  100. value,
  101. values, // values为当前变化列的数组内容
  102. indexs, //当前地区值下标
  103. picker = this.$refs.uPicker
  104. } = e
  105. //columnIndex代表第几列,意思是下标为0的列发生变化
  106. if (columnIndex === 0) {
  107. picker.setColumnValues(1, this.city[indexs[0]].map(v => {
  108. return {
  109. name: v.name,
  110. id: v.id
  111. }
  112. }))
  113. // picker.setColumnValues(2, this.area[indexs[0]][0].map(v => {
  114. // return {
  115. // name: v.name,
  116. // id: v.id
  117. // }
  118. // }))
  119. }
  120. // if (columnIndex === 1) {
  121. // picker.setColumnValues(2, this.area[indexs[0]][indexs[1]].map(v => {
  122. // return {
  123. // name: v.name,
  124. // id: v.id
  125. // }
  126. // }))
  127. // }
  128. },
  129. changecity(e) {
  130. console.log(e);
  131. let a = e.value[0].name + e.value[1].name
  132. let ids = String(e.value[0].id) + String(e.value[1].id)
  133. this.showcity = false
  134. this.city_id = e.value[1].id
  135. this.city_name = e.value[1].name
  136. this.getcompanylist()
  137. },
  138. getAllArea() {
  139. getAllArea().then(res => {
  140. this.province = res.data.map(t => {
  141. return {
  142. name: t.name,
  143. id: t.id
  144. }
  145. })
  146. this.city = res.data.map(t => t.children.map(v => {
  147. return {
  148. name: v.name,
  149. id: v.id
  150. }
  151. }))
  152. this.area = res.data.map(t => t.children.map(v => v.children.map(i => {
  153. return {
  154. name: i.name,
  155. id: i.id
  156. }
  157. })))
  158. let a = []
  159. let b = []
  160. let c = []
  161. this.province.map(res => {
  162. a.push({
  163. name: res.name,
  164. id: res.id,
  165. })
  166. })
  167. this.city[0].map(res => {
  168. b.push({
  169. name: res.name,
  170. id: res.id,
  171. })
  172. })
  173. this.area[0][0].map(res => {
  174. c.push({
  175. name: res.name,
  176. id: res.id,
  177. })
  178. })
  179. this.cityList = [a, b]
  180. })
  181. },
  182. getcompanylist() {
  183. get_company_list({
  184. id: this.id,
  185. category_job_id: this.job_id,
  186. city_id: this.city_id
  187. }).then(res => {
  188. this.company_list = res.data
  189. })
  190. },
  191. return1() {
  192. uni.navigateBack()
  193. },
  194. togongsi(id) {
  195. uni.navigateTo({
  196. url: "/pagesB/general-info?id=" + id
  197. })
  198. },
  199. getdetail() {
  200. get_detail({
  201. id: this.id
  202. }).then(res => {
  203. this.detail = res.data
  204. })
  205. }
  206. }
  207. }
  208. </script>
  209. <style lang="scss" scoped>
  210. page {}
  211. .index-page {
  212. background-color: #F3F3F3;
  213. min-height: 100vh;
  214. .contant {
  215. background: #F3F3F3;
  216. height: 100%;
  217. padding: 0 24rpx;
  218. .title {
  219. .title {
  220. font-size: 34rpx;
  221. font-family: SFPro-Medium, SFPro;
  222. font-weight: 500;
  223. color: #222222;
  224. display: block;
  225. }
  226. .jianjie {
  227. font-size: 24rpx;
  228. font-family: SFPro-Regular, SFPro;
  229. font-weight: 400;
  230. color: #555555;
  231. display: block;
  232. margin-top: 10rpx;
  233. }
  234. }
  235. .list {
  236. background: #FFFFFF;
  237. border-radius: 16rpx;
  238. padding: 28rpx;
  239. margin-top: 20rpx;
  240. }
  241. .bottom {
  242. margin-top: 32rpx;
  243. border-top: 2rpx solid #F3F3F3;
  244. .font {
  245. margin-left: 14rpx;
  246. font-size: 24rpx;
  247. font-family: SFPro-Regular, SFPro;
  248. font-weight: 400;
  249. color: #888888;
  250. }
  251. }
  252. }
  253. .font1 {
  254. font-size: 24rpx;
  255. font-family: PingFangSC-Regular, PingFang SC;
  256. font-weight: 400;
  257. color: #1A1C24;
  258. }
  259. .header {
  260. height: 144rpx;
  261. border-bottom: 2rpx solid #F3F3F3;
  262. padding: 20rpx 24rpx;
  263. display: flex;
  264. align-items: center;
  265. box-sizing: border-box;
  266. .font {
  267. margin-left: 16rpx;
  268. .title {
  269. width: 534rpx;
  270. height: 44rpx;
  271. font-size: 32rpx;
  272. font-family: PingFangSC-Medium, PingFang SC;
  273. font-weight: 500;
  274. color: #1A1C24;
  275. line-height: 44rpx;
  276. display: block;
  277. }
  278. .active {
  279. height: 34rpx;
  280. font-size: 24rpx;
  281. font-family: SFPro-Regular, SFPro;
  282. font-weight: 400;
  283. color: #444444;
  284. line-height: 28rpx;
  285. display: block;
  286. margin-top: 18rpx;
  287. }
  288. }
  289. }
  290. .index-navbar {
  291. position: sticky;
  292. top: 0;
  293. left: 0;
  294. width: 750rpx;
  295. z-index: 100;
  296. .header-down {
  297. height: 92rpx;
  298. padding: 20rpx 24rpx;
  299. box-sizing: border-box;
  300. .font {
  301. font-size: 40rpx;
  302. font-family: PingFangSC-Medium, PingFang SC;
  303. font-weight: 500;
  304. color: #222222;
  305. }
  306. .right-item {
  307. padding: 0 16rpx;
  308. height: 52rpx;
  309. background: #F3F3F3;
  310. border-radius: 4rpx;
  311. margin-left: 20rpx;
  312. .text {
  313. margin-right: 4rpx;
  314. font-size: 26rpx;
  315. font-family: PingFangSC-Regular, PingFang SC;
  316. font-weight: 400;
  317. color: #666666;
  318. }
  319. }
  320. .down-left {
  321. .text {
  322. margin-right: 4rpx;
  323. font-size: 26rpx;
  324. font-family: PingFangSC-Medium, PingFang SC;
  325. font-weight: 500;
  326. color: #222222;
  327. }
  328. }
  329. }
  330. .index-bg {
  331. position: absolute;
  332. top: 0;
  333. left: 0;
  334. z-index: -1;
  335. width: 750rpx;
  336. height: 392rpx;
  337. }
  338. }
  339. .index-header {
  340. flex: 1;
  341. padding: 0 32rpx;
  342. height: 50rpx;
  343. .index-search {
  344. width: 200rpx;
  345. height: 64rpx;
  346. background: #FFFFFF;
  347. border-radius: 20rpx;
  348. padding: 0 28rpx;
  349. .text1 {
  350. font-size: 24rpx;
  351. font-family: PingFangSC-Regular, PingFang SC;
  352. font-weight: 400;
  353. color: #999999;
  354. margin-left: 16rpx;
  355. }
  356. }
  357. .index-tabs {
  358. text:first-child {
  359. font-size: 36rpx;
  360. font-family: PingFangSC-Medium, PingFang SC;
  361. font-weight: 500;
  362. color: #222222;
  363. }
  364. text:last-child {
  365. width: 76rpx;
  366. height: 12rpx;
  367. background: linear-gradient(270deg, #208EFF 0%, rgba(28, 159, 227, 0) 100%);
  368. margin-top: -20rpx;
  369. border-radius: 100rpx;
  370. }
  371. }
  372. }
  373. }
  374. ::v-deep .u-navbar__content__left {
  375. padding: 0 !important;
  376. }
  377. ::v-deep .u-icon__icon {
  378. margin-left: 11rpx !important;
  379. }
  380. </style>