detail.vue 27 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912
  1. <template>
  2. <view class="content">
  3. <view class="top">
  4. <u-navbar title="订单详情" :autoBack="true" bgColor="rgba(0,0,0,0)" @leftClick="leftClick" :placeholder="true" :titleStyle="titleStyle"></u-navbar>
  5. <view class="title" v-if="pageData.status == 1">暂无报价</view>
  6. <view class="title" v-if="pageData.status == 2">已有报价</view>
  7. <view class="title" v-if="pageData.status == 3 && pageData.tab !== 1">已匹配</view>
  8. <!-- <view class="hflex acenter jbetween" v-if="pageData.status == 3 && pageData.tab == 1">
  9. <view class="title">已匹配</view>
  10. <view class="top_down hflex acenter jcenter" @click="select">
  11. <image src="/static/images/common/down2.png" style="width: 36rpx;height: 36rpx;"></image>
  12. <view class="">下载附件</view>
  13. </view>
  14. </view> -->
  15. </view>
  16. <view class="center">
  17. <view class="box">
  18. <view class="title">商品明细</view>
  19. <block v-for="(item,index) in pageData.items" :key="index">
  20. <view class="item_bg">
  21. <view class="item_name">{{item.name}}</view>
  22. <view class="text_style1" v-if="tab !== '4'">规格:{{item.spec}} 数量:{{item.number}}</view>
  23. <view class="text_style1" v-else>数量/吨位:{{item.weight}}</view>
  24. <view v-if="item.enclosure">
  25. <block v-for="(item2,index2) in item.enclosure" :key="index2">
  26. <view class="hflex acenter jbetween enclo">
  27. <view class="enclo_name">{{item2.filename}}</view>
  28. <view class="enclo_down hflex acenter jcenter" @click="open(item2.fileurl)">
  29. <image src="/static/images/common/down_icon.png" style="width: 20rpx;height: 20rpx;"></image>
  30. <view>下载附件</view>
  31. </view>
  32. </view>
  33. </block>
  34. </view>
  35. <view class="text_style1" v-if="item.price">原采购价:<span class="price">¥{{item.price}}</span></view>
  36. <view class="text_style1" v-if="item.standard">质量标准:{{item.standard}}</view>
  37. <view class="hflex acenter jcenter" v-if="!item.is_matched && tab == '1' && item.offers.length == 0">
  38. <view class="item_btn hflex acenter jcenter">暂无报价</view>
  39. </view>
  40. <view class="hflex acenter jbetween offer_bg" v-if="!item.is_matched && tab == '1' && item.offers.length != 0">
  41. <view class="bg_left">已有报价•{{item.offers.length}}条</view>
  42. <view class="hflex acenter" @click="showOffer(index)">
  43. <view class="top_text">{{!item.show?'展开':'隐藏'}}</view>
  44. <u-icon name="arrow-up" color="#555555" size="20rpx" v-if="item.show"></u-icon>
  45. <u-icon name="arrow-down" color="#555555" size="20rpx" v-else></u-icon>
  46. </view>
  47. </view>
  48. <view class="vflex" v-if="item.show">
  49. <block v-for="(item2,index2) in item.offers" :key="index2">
  50. <view class="offer_bg">
  51. <view class="hflex acenter jbetween">
  52. <view class="offer-user hflex acenter">
  53. <image :src="item2.user.headimg" class="offer_avatar"></image>
  54. <view class="user_name text_hide">{{item2.user.nickname}}</view>
  55. <view class="renz hflex acenter jcenter">已认证</view>
  56. </view>
  57. <view class="offer_price">
  58. 报价:<span style="font-size: 36rpx;" v-if="item2.amount">¥{{item2.amount}}</span>
  59. <span style="font-size: 36rpx;" v-else>暂无报价</span>
  60. </view>
  61. </view>
  62. <view class="hflex acenter jbetween offer_center">
  63. <view class="tele">联系电话:{{item2.user.phone}}</view>
  64. <image src="/static/images/common/tele.png" style="width: 32rpx; height: 32rpx;" @click="tele(item2.user.phone)"></image>
  65. </view>
  66. <view class="hflex acenter jend offer_bottom">
  67. <view class="bottom_btn1 hflex acenter jcenter" @click="toDetail(index,index2)">查看详情</view>
  68. <view class="bottom_btn1 hflex acenter jcenter" @click="toDetail(index,index2)">联系报价人</view>
  69. <view class="bottom_btn1 bottom_btn2 hflex acenter jcenter" @click="match(index,index2)">匹配订单</view>
  70. </view>
  71. </view>
  72. </block>
  73. </view>
  74. <view class="offer_bg" v-if="item.is_matched && tab == '1'">
  75. <block v-for="(item1,index1) in item.offers" :key="index1">
  76. <view class="">
  77. <view class="hflex acenter jbetween">
  78. <view class="offer-user hflex acenter">
  79. <image :src="item1.user.headimg" class="offer_avatar"></image>
  80. <view class="user_name text_hide">{{item1.user.nickname}}</view>
  81. <view class="renz hflex acenter jcenter">已认证</view>
  82. </view>
  83. <view class="offer_price">
  84. 报价:<span style="font-size: 36rpx;" v-if="item1.amount">¥{{item1.amount}}</span>
  85. <span style="font-size: 36rpx;" v-else>暂无报价</span>
  86. </view>
  87. </view>
  88. <view class="hflex acenter jbetween offer_center">
  89. <view class="tele">联系电话:{{item1.user.phone}}</view>
  90. <image src="/static/images/common/tele.png" style="width: 32rpx; height: 32rpx;" @click="tele(item1.user.phone)"></image>
  91. </view>
  92. <view class="hflex acenter jend offer_bottom" v-if="item.offer_id == item1.id">
  93. <view class="bottom_btn1 hflex acenter jcenter" @click="open(item.down_word)">下载文件</view>
  94. <view class="bottom_btn1 hflex acenter jcenter" @click="toDetail(index,index1)">查看详情</view>
  95. <view class="bottom_btn1 hflex acenter jcenter" @click="toDetail(index,index1)">联系接单人</view>
  96. <view class="bottom_btn1 bottom_btn2 hflex acenter jcenter" @click="remind(item1.user_id)">提醒完成</view>
  97. </view>
  98. </view>
  99. </block>
  100. </view>
  101. </view>
  102. </block>
  103. <view class="cell">
  104. <view class="right" v-if="pageData.standard_tech">生产技术标准:<span class="left">{{pageData.standard_tech}}</span></view>
  105. </view>
  106. <view class="cell">
  107. <view class="right" v-if="pageData.standard_check">生产验收标准:<span class="left">{{pageData.standard_check}}</span></view>
  108. </view>
  109. <view class="title">上传图片</view>
  110. <view class="hflex acenter fwrap" v-if="pageData.tab == 1">
  111. <block v-for="(item,index) in pageData.images" :key="index">
  112. <image v-if="item.type == 'image'" :src="item.src" class="img"></image>
  113. <video v-else direction="0" :src="item.src" class="img"></video>
  114. </block>
  115. </view>
  116. <view class="hflex acenter fwrap" v-else>
  117. <block v-for="(item,index) in pageData.file" :key="index">
  118. <image v-if="item.type == 'image'" :src="item.src" class="img"></image>
  119. <video v-else direction="0" :src="item.src" class="img"></video>
  120. </block>
  121. </view>
  122. <view class="hflex acenter cell" v-if="pageData.post_address">
  123. <view class="left">交货地址:</view>
  124. <view class="right">{{pageData.post_address}}</view>
  125. </view>
  126. <view class="hflex acenter cell" v-if="pageData.post_time">
  127. <view class="left">交货日期:</view>
  128. <view class="right">{{pageData.post_time}}</view>
  129. </view>
  130. <view class="hflex acenter cell" v-if="pageData.create_time">
  131. <view class="left">发布时间:</view>
  132. <view class="right">{{pageData.create_time}}</view>
  133. </view>
  134. <view class="hflex acenter cell" v-if="pageData.form">
  135. <view class="left">包装形式:</view>
  136. <view class="right">{{pageData.form}}</view>
  137. </view>
  138. <view class="hflex acenter cell" v-if="pageData.wharf_to">
  139. <view class="left">装货码头:</view>
  140. <view class="right">{{pageData.wharf_to}}</view>
  141. </view>
  142. <view class="hflex acenter cell" v-if="pageData.wharf_for">
  143. <view class="left">到港码头:</view>
  144. <view class="right">{{pageData.wharf_for}}</view>
  145. </view>
  146. </view>
  147. <view class="box" v-if="pageData.status == 2 && tab !== '1'">
  148. <view class="hflex acenter jbetween cell2">
  149. <view class="bg_left">已有报价•{{pageData.offers.length}}条</view>
  150. <view class="hflex acenter" @click="showOffer2">
  151. <view class="top_text">{{!show?'展开':'隐藏'}}</view>
  152. <u-icon name="arrow-up" color="#555555" size="20rpx" v-if="show"></u-icon>
  153. <u-icon name="arrow-down" color="#555555" size="20rpx" v-else></u-icon>
  154. </view>
  155. </view>
  156. <view class="vflex box_bg" v-if="show">
  157. <block v-for="(item2,index2) in pageData.offers" :key="index2">
  158. <view class="offer_bg">
  159. <view class="hflex acenter jbetween">
  160. <view class="offer-user hflex acenter">
  161. <image :src="item2.user.headimg" class="offer_avatar"></image>
  162. <view class="user_name text_hide">{{item2.user.nickname}}</view>
  163. <view class="renz hflex acenter jcenter">已认证</view>
  164. </view>
  165. <view class="offer_price">
  166. 报价:<span style="font-size: 36rpx;" v-if="item2.amount">¥{{item2.amount}}</span>
  167. <span style="font-size: 36rpx;" v-else>暂无报价</span>
  168. </view>
  169. </view>
  170. <view class="hflex acenter jbetween offer_center">
  171. <view class="tele">联系电话:{{item2.user.phone}}</view>
  172. <image src="/static/images/common/tele.png" style="width: 32rpx; height: 32rpx;" @click="tele(item2.user.phone)"></image>
  173. </view>
  174. <view class="hflex acenter jend offer_bottom">
  175. <view class="bottom_btn1 hflex acenter jcenter" @click="toDetail1(index2)">查看详情</view>
  176. <view class="bottom_btn1 hflex acenter jcenter" @click="toDetail1(index2)">联系报价人</view>
  177. <view class="bottom_btn1 bottom_btn2 hflex acenter jcenter" @click="match(index,index2)">匹配订单</view>
  178. </view>
  179. </view>
  180. </block>
  181. </view>
  182. </view>
  183. <view class="box" v-if="tab !== '1' && pageData.status == 3">
  184. <view class="bg_left cell2">接单人详情</view>
  185. <block v-for="(item1,index1) in pageData.offers" :key="index1">
  186. <view class="box_bg">
  187. <view class="offer_bg">
  188. <view class="hflex acenter jbetween">
  189. <view class="offer-user hflex acenter">
  190. <image :src="item1.user.headimg" class="offer_avatar"></image>
  191. <view class="user_name text_hide">{{item1.user.nickname}}</view>
  192. <view class="renz hflex acenter jcenter">已认证</view>
  193. </view>
  194. <view class="offer_price">
  195. 报价:<span style="font-size: 36rpx;" v-if="item1.amount">¥{{item1.amount}}</span>
  196. <span style="font-size: 36rpx;" v-else>暂无报价</span>
  197. </view>
  198. </view>
  199. <view class="hflex acenter jbetween offer_center">
  200. <view class="tele">联系电话:{{item1.user.phone}}</view>
  201. <image src="/static/images/common/tele.png" style="width: 32rpx; height: 32rpx;" @click="tele(item1.user.phone)"></image>
  202. </view>
  203. <view class="hflex acenter jend offer_bottom" v-if="item1.id == pageData.offer_id">
  204. <view class="bottom_btn1 hflex acenter jcenter" @click="toDetail1(index1)">查看详情</view>
  205. <view class="bottom_btn1 hflex acenter jcenter" @click="toDetail1(index1)">联系接单人</view>
  206. <view class="bottom_btn1 bottom_btn2 hflex acenter jcenter" @click="remind(item1.user_id)">提醒完成</view>
  207. </view>
  208. </view>
  209. </view>
  210. </block>
  211. </view>
  212. </view>
  213. <view class="bottom hflex jend" v-if="pageData.status == 1">
  214. <view class="btn1 hflex acenter jcenter" @click="cancel(pageData.id)">取消订单</view>
  215. <view class="btn1 btn2 hflex acenter jcenter" v-if="pageData.status == 1" @click="edit(pageData.id)">编辑订单</view>
  216. </view>
  217. <view class="bottom hflex jend" v-if="pageData.status == 3 && pageData.tab != 1">
  218. <view class="btn1 btn2 hflex acenter jcenter" v-if="pageData.status == 3 && pageData.tab != 1" @click="open(pageData.down_word)">下载文件</view>
  219. </view>
  220. <u-popup :show="down_show" mode="center" round="10" @close="close" :safeAreaInsetBottom="false">
  221. <view class="popu">
  222. <view class="popu_top hflex acenter jbetween">
  223. <view></view>
  224. <view class="popu_title">下载文件</view>
  225. <image src="/static/images/common/close_icon.png" style="width: 32rpx;height: 32rpx;" @click="close"></image>
  226. </view>
  227. <view class="file_bg hflex acenter">
  228. <view class="file_name text_hide">{{down_word}}</view>
  229. </view>
  230. <view class="btn_group hflex acenter jbetween">
  231. <view class="left_btn hflex acenter jcenter" @click="copy(down_word)">复制链接</view>
  232. <view class="right_btn hflex acenter jcenter" @click="see(down_word)">预览文件</view>
  233. </view>
  234. <!-- <view class="hflex acenter jcenter text_blue" @click="see(pageData.items[index1].enclosure[index2].fileurl)">预览文件></view> -->
  235. </view>
  236. </u-popup>
  237. <u-popup :show="select_show" mode="center" round="10" @close="close" v-if="pageData.staus==1" :safeAreaInsetBottom="false">
  238. <view class="popu">
  239. <view class="popu_top hflex acenter jbetween">
  240. <view></view>
  241. <view class="popu_title">选择接单人</view>
  242. <image src="/static/images/common/close_icon.png" style="width: 32rpx;height: 32rpx;" @click="close"></image>
  243. </view>
  244. <scroll-view scroll-y="true" style="height: 360rpx;">
  245. <view class="" v-for="(item,index) in pageData.items" :key="index">
  246. <u-radio-group iconPlacement="right">
  247. <view class="hflex acenter jbetween" v-for="(item2,index2) in item.offers" :key="index2">
  248. <view class="hflex acenter ">
  249. <image :src="item2.user.headimg" class="offer_avatar"></image>
  250. <view class="user_name text_hide">{{item2.user.nickname}}</view>
  251. </view>
  252. <u-radio shape="circle" activeColor="#506dff" @change="changge(index,index2)"></u-radio>
  253. </view>
  254. </u-radio-group>
  255. </view>
  256. </scroll-view>
  257. <view class="btn_next hflex acenter jcenter" @click="next">下一步</view>
  258. </view>
  259. </u-popup>
  260. </view>
  261. </template>
  262. <script>
  263. import $api from '@/static/js/api.js'
  264. var that = ''
  265. export default {
  266. data() {
  267. return {
  268. titleStyle: {
  269. fontSize: '36rpx',
  270. color: '#FFFFFF'
  271. },
  272. id: '',
  273. tab: '',
  274. pageData: {},
  275. show: false,
  276. down_show: false,
  277. index1: 0,
  278. index2: 0,
  279. select_show: false,
  280. down_word: '',
  281. }
  282. },
  283. onLoad(options) {
  284. that = this
  285. that.id = options.id
  286. that.tab = options.tab
  287. that.getData()
  288. },
  289. methods: {
  290. leftClick() {
  291. console.log('leftClick');
  292. },
  293. getData() {
  294. $api.req({
  295. url: '/data/api.business.Purchase/show',
  296. data: {
  297. tab: that.tab,
  298. id: that.id
  299. }
  300. }, function(res) {
  301. if(res.code == 1) {
  302. that.pageData = res.data
  303. // console.log(that.pageData);
  304. } else {
  305. $api.info(res.info)
  306. }
  307. })
  308. },
  309. showOffer(index) {
  310. if(that.pageData.items[index].show) {
  311. that.$set(that.pageData.items[index],'show',false)
  312. } else {
  313. that.$set(that.pageData.items[index],'show',true)
  314. }
  315. },
  316. showOffer2() {
  317. that.show = !that.show
  318. },
  319. open(url) {
  320. that.down_word = url
  321. that.down_show = true
  322. },
  323. close() {
  324. that.down_show = false
  325. that.select_show = false
  326. },
  327. /* select() {
  328. that.select_show = true
  329. }, */
  330. next() {
  331. that.select_show = false
  332. that.down_show = true
  333. },
  334. changge(index1,index2) {
  335. that.index1 = index1
  336. that.index2 = index2
  337. },
  338. down(url) {
  339. uni.downloadFile({
  340. url: url, //仅为示例,并非真实的资源
  341. success (res) {
  342. // 只要服务器有响应数据,就会把响应内容写入文件并进入 success 回调,业务需要自行判断是否下载到了想要的内容
  343. if (res.statusCode === 200) {
  344. const filePath = res.tempFilePath
  345. uni.saveFile({
  346. tempFilePath: filePath,
  347. success: function(res) {
  348. // console.log(res);
  349. that.close()
  350. that.see(res.savedFilePath)
  351. }
  352. })
  353. }
  354. }
  355. })
  356. },
  357. see(url) {
  358. uni.downloadFile({
  359. // 示例 url,并非真实存在
  360. url: url,
  361. showMenu: true,
  362. success: function (res) {
  363. const filePath = res.tempFilePath
  364. uni.openDocument({
  365. filePath: filePath,
  366. success: function (res) {
  367. console.log('打开文档成功')
  368. }
  369. })
  370. }
  371. })
  372. },
  373. copy(value) {
  374. uni.setClipboardData({
  375. data: value,
  376. success: function () {
  377. $api.info('复制成功')
  378. }
  379. });
  380. },
  381. tele(value) {
  382. uni.makePhoneCall({
  383. phoneNumber: value
  384. });
  385. },
  386. toDetail(index1,index2) {
  387. $api.jump('/pages/mine/service/purOrder/msg?id=' + that.pageData.id + '&userid=' + that.pageData.items[index1].offers[index2].user_id + '&tab=' + that.pageData.tab + '&offer=' + JSON.stringify(that.pageData.items[index1].offers[index2]))
  388. },
  389. toDetail1(index1) {
  390. $api.jump('/pages/mine/service/purOrder/msg?id=' + that.pageData.id + '&userid=' + that.pageData.offers[index1].user_id + '&tab=' + that.pageData.tab + '&offer=' + JSON.stringify(that.pageData.offers[index1]))
  391. },
  392. remind(id) {
  393. $api.req({
  394. url: '/data/api.business.Purchase/reminder',
  395. data: {
  396. user_id: id
  397. }
  398. }, function(res) {
  399. if(res.code == 1) {
  400. // $api.info(res.info)
  401. $api.info('已发送提醒')
  402. }
  403. })
  404. },
  405. match(index,index2) {
  406. console.log('匹配');
  407. if(that.pageData.tab == 1) {
  408. $api.req({
  409. url: '/data/api.business.Purchase/match',
  410. method: 'POST',
  411. data: {
  412. tab: that.tab,
  413. id: that.pageData.items[index].id,
  414. offer_id: that.pageData.items[index].offers[index2].id
  415. }
  416. }, function(res) {
  417. console.log('匹配',res);
  418. if(res.code == 1) {
  419. console.log(res);
  420. $api.info(res.info)
  421. that.getData()
  422. }
  423. })
  424. } else {
  425. $api.req({
  426. url: '/data/api.business.Purchase/match',
  427. method: 'POST',
  428. data: {
  429. tab: that.tab,
  430. id: that.pageData.id,
  431. offer_id: that.pageData.offers[index2].id
  432. }
  433. }, function(res) {
  434. console.log('匹配',res);
  435. if(res.code == 1) {
  436. console.log(res);
  437. $api.info(res.info)
  438. that.getData()
  439. }
  440. })
  441. }
  442. },
  443. cancel(id) {
  444. $api.req({
  445. url: '/data/api.business.Purchase/cancel',
  446. data: {
  447. tab:that.tab,
  448. id: id
  449. }
  450. }, function(res) {
  451. if(res.code == 1) {
  452. $api.info(res.info)
  453. that.getList()
  454. }
  455. })
  456. },
  457. edit(id) {
  458. var url = ''
  459. switch(that.tab) {
  460. case '1' :
  461. url = '/pages/release/purchase/purchase?id=' + id;
  462. break;
  463. case '2' :
  464. url = '/pages/release/production/production?id=' +id;
  465. break;
  466. case '3' :
  467. url = '/pages/release/waixie/waixie?id=' +id;
  468. break;
  469. case '4':
  470. url = '/pages/release/ocean/ocean?id=' +id;
  471. break;
  472. }
  473. $api.jump(url)
  474. },
  475. },
  476. }
  477. </script>
  478. <style lang="scss" scoped>
  479. .content {
  480. background: #F4F4F4;
  481. position: relative;
  482. .top {
  483. width: 100%;
  484. height: 520rpx;
  485. background: url('/static/images/common/top_bg.png') no-repeat;
  486. background-size: 100%;
  487. box-sizing: border-box;
  488. padding: 0 30rpx;
  489. .title {
  490. padding: 24rpx 0;
  491. font-size: 44rpx;
  492. font-weight: 500;
  493. color: #FFFFFF;
  494. line-height: 60rpx;
  495. }
  496. .top_down {
  497. padding: 0 16rpx;
  498. height: 52rpx;
  499. border-radius: 26rpx;
  500. border: 1rpx solid #FFFFFF;
  501. font-size: 24rpx;
  502. font-weight: 500;
  503. color: #FFFFFF;
  504. line-height: 34rpx;
  505. }
  506. }
  507. .center {
  508. position: absolute;
  509. left: 0;
  510. top: 250rpx;
  511. width: 100%;
  512. box-sizing: border-box;
  513. padding: 0 30rpx;
  514. .box {
  515. width: 100%;
  516. background: #FFFFFF;
  517. border-radius: 20px;
  518. box-sizing: border-box;
  519. padding: 0 20rpx 12rpx;
  520. margin-top: 20rpx;
  521. .title {
  522. font-size: 30rpx;
  523. font-weight: 500;
  524. color: #222222;
  525. line-height: 42rpx;
  526. padding: 28rpx 0;
  527. }
  528. .item_bg {
  529. width: 100%;
  530. background: #F4F4F4;
  531. border-radius: 16rpx;
  532. box-sizing: border-box;
  533. padding: 0 20rpx 13rpx;
  534. margin-bottom: 20rpx;
  535. .item_name {
  536. font-size: 30rpx;
  537. font-weight: 400;
  538. color: #222222;
  539. line-height: 42rpx;
  540. padding: 20rpx 0 14rpx;
  541. }
  542. .text_style1 {
  543. font-size: 24rpx;
  544. font-weight: 400;
  545. color: #888888;
  546. line-height: 34rpx;
  547. padding-bottom: 16rpx;
  548. }
  549. .price {
  550. font-size: 28rpx;
  551. font-weight: 400;
  552. color: #555555;
  553. line-height: 30rpx;
  554. }
  555. .item_btn {
  556. width: 160rpx;
  557. height: 52rpx;
  558. border-radius: 32rpx;
  559. border: 1rpx solid #979797;
  560. font-size: 26rpx;
  561. font-weight: 400;
  562. color: #222222;
  563. margin: 10rpx 0 24rpx;
  564. }
  565. .offer_bg {
  566. width: 100%;
  567. background: #FFFFFF;
  568. border-radius: 16rpx;
  569. width: 100%;
  570. box-sizing: border-box;
  571. padding: 20rpx;
  572. margin-bottom: 20rpx;
  573. .bg_left {
  574. font-size: 26rpx;
  575. font-weight: 500;
  576. color: #222222;
  577. line-height: 36rpx;
  578. }
  579. .top_text {
  580. font-size: 20rpx;
  581. font-weight: 400;
  582. color: #555555;
  583. line-height: 28rpx;
  584. }
  585. .offer-user {
  586. padding: 20rpx 0 16rpx;
  587. .offer_avatar {
  588. width: 72rpx;
  589. height: 72rpx;
  590. border-radius: 50%;
  591. }
  592. .user_name {
  593. max-width: 150rpx;
  594. width: max-content;
  595. font-size: 28rpx;
  596. font-weight: 400;
  597. color: #222222;
  598. line-height: 40rpx;
  599. padding: 0 16rpx;
  600. }
  601. .renz {
  602. height: 28rpx;
  603. background: #506DFF;
  604. border-radius: 14rpx;
  605. font-size: 16rpx;
  606. font-weight: 400;
  607. color: #FFFFFF;
  608. line-height: 22rpx;
  609. padding: 0 12rpx;
  610. }
  611. }
  612. .offer_price {
  613. font-size: 24rpx;
  614. font-weight: 400;
  615. color: #FF4646;
  616. line-height: 34rpx;
  617. }
  618. .offer_center {
  619. padding: 0 0 20rpx;
  620. border-bottom: 1rpx solid #F4F4F4;
  621. .tele {
  622. font-size: 22rpx;
  623. font-weight: 400;
  624. color: #666666;
  625. line-height: 32rpx;
  626. }
  627. }
  628. .offer_bottom {
  629. padding: 20rpx 0 0;
  630. .bottom_btn1 {
  631. margin-left: 10rpx;
  632. // width: 132rpx;
  633. height: 48rpx;
  634. border-radius: 26rpx;
  635. border: 1rpx solid #506DFF;
  636. font-size: 22rpx;
  637. font-weight: 400;
  638. color: #506DFF;
  639. line-height: 32rpx;
  640. padding: 0 15rpx;
  641. }
  642. .bottom_btn2 {
  643. background: #506DFF;
  644. color: #FFFFFF;
  645. }
  646. }
  647. }
  648. .enclo {
  649. padding: 20rpx 0;
  650. border-top: 1rpx solid #ECECEC;
  651. .enclo_name {
  652. font-size: 24rpx;
  653. font-weight: 400;
  654. color: #333333;
  655. line-height: 34rpx;
  656. }
  657. .enclo_down {
  658. padding: 12rpx 16rpx;
  659. border-radius: 22rpx;
  660. border: 1px solid #506DFF;
  661. font-size: 16rpx;
  662. font-weight: 400;
  663. color: #506DFF;
  664. line-height: 22rpx;
  665. }
  666. }
  667. }
  668. .img {
  669. width: 200rpx;
  670. height: 200rpx;
  671. border-radius: 16rpx;
  672. margin: 0 14rpx 20rpx 0;
  673. }
  674. .img:nth-child(3n+3) {
  675. margin: 0 0 20rpx 0;
  676. }
  677. .cell {
  678. margin: 0 0 24rpx;
  679. .left {
  680. font-size: 26rpx;
  681. font-weight: 400;
  682. color: #888888;
  683. line-height: 36rpx;
  684. }
  685. .right {
  686. font-size: 26rpx;
  687. font-family: PingFangSC-Regular, PingFang SC;
  688. font-weight: 400;
  689. color: #333333;
  690. line-height: 36rpx;
  691. }
  692. }
  693. .cell2 {
  694. padding: 20rpx 0;
  695. .bg_left {
  696. font-size: 26rpx;
  697. font-weight: 500;
  698. color: #222222;
  699. line-height: 36rpx;
  700. }
  701. .top_text {
  702. font-size: 20rpx;
  703. font-weight: 400;
  704. color: #555555;
  705. line-height: 28rpx;
  706. }
  707. }
  708. .box_bg {
  709. .offer_bg {
  710. width: 100%;
  711. background: #F4F4F4;
  712. border-radius: 16rpx;
  713. width: 100%;
  714. box-sizing: border-box;
  715. padding: 20rpx;
  716. margin-bottom: 20rpx;
  717. }
  718. .offer-user {
  719. padding: 20rpx 0 16rpx;
  720. .offer_avatar {
  721. width: 72rpx;
  722. height: 72rpx;
  723. border-radius: 50%;
  724. }
  725. .user_name {
  726. max-width: 150rpx;
  727. width: max-content;
  728. font-size: 28rpx;
  729. font-weight: 400;
  730. color: #222222;
  731. line-height: 40rpx;
  732. padding: 0 16rpx;
  733. }
  734. .renz {
  735. height: 28rpx;
  736. background: #506DFF;
  737. border-radius: 14rpx;
  738. font-size: 16rpx;
  739. font-weight: 400;
  740. color: #FFFFFF;
  741. line-height: 22rpx;
  742. padding: 0 12rpx;
  743. }
  744. }
  745. .offer_price {
  746. font-size: 24rpx;
  747. font-weight: 400;
  748. color: #FF4646;
  749. line-height: 34rpx;
  750. }
  751. .offer_center {
  752. padding: 0 0 20rpx;
  753. border-bottom: 1rpx solid #F4F4F4;
  754. .tele {
  755. font-size: 22rpx;
  756. font-weight: 400;
  757. color: #666666;
  758. line-height: 32rpx;
  759. }
  760. }
  761. .offer_bottom {
  762. padding: 20rpx 0 0;
  763. .bottom_btn1 {
  764. margin-left: 20rpx;
  765. // width: 132rpx;
  766. padding: 0 22rpx;
  767. height: 48rpx;
  768. border-radius: 26rpx;
  769. border: 1rpx solid #506DFF;
  770. font-size: 22rpx;
  771. font-weight: 400;
  772. color: #506DFF;
  773. line-height: 32rpx;
  774. }
  775. .bottom_btn2 {
  776. background: #506DFF;
  777. color: #FFFFFF;
  778. }
  779. }
  780. }
  781. }
  782. .box:nth-last-child(1) {
  783. margin-bottom: 186rpx;
  784. }
  785. }
  786. .bottom {
  787. width: 100%;
  788. height: 166rpx;
  789. background: #FFFFFF;
  790. position: fixed;
  791. bottom: 0;
  792. z-index: 99;
  793. box-sizing: border-box;
  794. padding: 12rpx 30rpx 0;
  795. .btn1 {
  796. width: 200rpx;
  797. height: 76rpx;
  798. border-radius: 42rpx;
  799. border: 1rpx solid #979797;
  800. font-size: 32rpx;
  801. font-weight: 400;
  802. color: #222222;
  803. line-height: 44rpx;
  804. margin-left: 40rpx;
  805. }
  806. .btn2 {
  807. border: 1px solid #506DFF;
  808. color: #506DFF;
  809. }
  810. }
  811. .popu {
  812. width: 630rpx;
  813. background: #FFFFFF;
  814. border-radius: 24rpx;
  815. margin: 0 auto;
  816. box-sizing: border-box;
  817. padding: 0 40rpx;
  818. .popu_top {
  819. padding: 32rpx 0 40rpx;
  820. .popu_title {
  821. font-size: 36rpx;
  822. font-weight: 500;
  823. color: #333333;
  824. line-height: 50rpx;
  825. }
  826. }
  827. .btn_next {
  828. width: 310rpx;
  829. height: 88rpx;
  830. background: #506DFF;
  831. border-radius: 44rpx;
  832. font-size: 32rpx;
  833. font-weight: 500;
  834. color: #FFFFFF;
  835. line-height: 44rpx;
  836. margin: 42rpx auto;
  837. }
  838. .file_bg {
  839. width: 550rpx;
  840. height: 100rpx;
  841. background: #F4F4F4;
  842. border-radius: 16rpx;
  843. margin: 0 0 42rpx;
  844. }
  845. .file_icon {
  846. width: 48rpx;
  847. height: 60rpx;
  848. }
  849. .file_name {
  850. padding-left: 14rpx;
  851. font-size: 28rpx;
  852. font-weight: 400;
  853. color: #333333;
  854. line-height: 40rpx;
  855. }
  856. .btn_group {
  857. width: 100%;
  858. padding: 0 0 20rpx;
  859. .left_btn {
  860. width: 260rpx;
  861. height: 76rpx;
  862. background: #ECEFFE;
  863. border-radius: 40rpx;
  864. font-size: 30rpx;
  865. font-weight: 500;
  866. color: #506DFF;
  867. line-height: 42rpx;
  868. }
  869. .right_btn {
  870. width: 260rpx;
  871. height: 76rpx;
  872. background: #506DFF;
  873. border-radius: 40rpx;
  874. font-size: 30rpx;
  875. font-weight: 500;
  876. color: #FFFFFF;
  877. line-height: 42rpx;
  878. }
  879. }
  880. .text_blue {
  881. font-size: 30rpx;
  882. font-weight: 400;
  883. color: #506DFF;
  884. line-height: 42rpx;
  885. padding: 28rpx 0 46rpx;
  886. }
  887. .offer_avatar {
  888. width: 72rpx;
  889. height: 72rpx;
  890. border-radius: 50%;
  891. }
  892. .user_name {
  893. max-width: 150rpx;
  894. width: max-content;
  895. font-size: 28rpx;
  896. font-weight: 400;
  897. color: #222222;
  898. line-height: 40rpx;
  899. padding: 0 16rpx;
  900. }
  901. }
  902. }
  903. </style>