subsidy.vue 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459
  1. <template>
  2. <!-- 百万补贴 -->
  3. <view style="position: relative;">
  4. <image src="static/images/back.png"
  5. style="width: 750rpx;height: 468rpx;position: absolute;top: 0;left: 0;z-index: -1;" mode=""></image>
  6. <u-navbar :safeAreaInsetTop="true" bgColor="rgba(255,68,54,1)" :placeholder='true'>
  7. <view class="u-nav-slot u-flex" slot="left">
  8. <u-icon @click="retur" name="arrow-left" size="19" color='rgba(253, 252, 251, 1)'></u-icon>
  9. <view class="input" style="width: 400rpx;">
  10. <u-icon name="search" color="rgba(153, 153, 153, 1)" size="32"></u-icon>
  11. <input type="text" :placeholder="i18n.Pleaseproductname" v-model="keyword" @input="search" />
  12. </view>
  13. </view>
  14. </u-navbar>
  15. <!-- 标签 -->
  16. <view class=" u-row-center" style="margin-top: 52rpx;display: flex;flex-direction: column;align-items: center;">
  17. <image v-if="show==1 && language =='zh-CN'" src="static/images/img1.png"
  18. style="width: 484rpx;height: 52rpx;" mode=""></image>
  19. <image v-if="show==1 && language =='en-US'" src="/pageA/static/images/Million.png"
  20. style="width: 484rpx;height: 50rpx;" mode=""></image>
  21. <image v-if="show==1 && language =='es-ES'" src="/pageA/static/images/Millones1.png"
  22. style="width: 484rpx;height: 50rpx;" mode=""></image>
  23. <image v-if="show==1 && language =='it-IT'" src="/pageA/static/images/Milliones2.png"
  24. style="width: 484rpx;height: 50rpx;" mode=""></image>
  25. <image v-if="show==2 && language =='zh-CN'" src="static/images/img2.png"
  26. style="width: 346rpx;height: 64rpx;" mode=""></image>
  27. <image v-if="show==2 && language =='en-US'" src="/pageA/static/images/kg1.png"
  28. style="width: 346rpx;height: 50rpx;" mode=""></image>
  29. <image v-if="show==2 && language =='es-ES'" src="/pageA/static/images/kg2.png"
  30. style="width: 346rpx;height: 40rpx;" mode=""></image>
  31. <image v-if="show==2 && language =='it-IT'" src="/pageA/static/images/kg3.png"
  32. style="width: 346rpx;height: 50rpx;" mode=""></image>
  33. <image v-if="show==3 && language =='zh-CN'" src="static/images/goshop.png"
  34. style="width: 382rpx;height: 50rpx;" mode=""></image>
  35. <image v-if="show==3 && language =='en-US'" src="/pageA/static/images/Free1.png"
  36. style="width: 382rpx;height: 52rpx;" mode=""></image>
  37. <image v-if="show==3 && language =='es-ES'" src="/pageA/static/images/Free2.png"
  38. style="width: 382rpx;height: 52rpx;" mode=""></image>
  39. <image v-if="show==3 && language =='it-IT'" src="/pageA/static/images/Free3.png"
  40. style="width: 382rpx;height: 52rpx;" mode=""></image>
  41. <!-- <image src="static/images/img1.png" style="width: 484rpx;height: 52rpx;" mode=""></image> -->
  42. <view class="biaopqian" style="margin-top: 20rpx;">
  43. <text>{{i18n.Goodgoods}}</text>
  44. <text style='margin-left:20rpx;margin-right:20rpx'>|</text>
  45. <text>{{i18n.Saveeverything}}</text>
  46. <text style='margin-left:20rpx;margin-right:20rpx'>|</text>
  47. <text>{{i18n.willpay}}</text>
  48. </view>
  49. </view>
  50. <!-- 商品 -->
  51. <view class="box">
  52. <view class="" style="margin-left: -22rpx;">
  53. <u-tabs :activeStyle="{
  54. color: 'rgba(248, 53, 39, 1)',
  55. fontWeight: 'bold',
  56. transform: 'scale(1.05)'
  57. }" :list="list1" lineColor='rgba(248, 53, 39, 1)' @change='changetab'></u-tabs>
  58. </view>
  59. <view class="item u-flex" v-for="(child,index) in list" @click="todetail(child.id)">
  60. <image :src="child.image" style="width: 232rpx;height: 232rpx;" mode=""></image>
  61. <view class="u-row-between"
  62. style="height: 232rpx;display: flex;flex-direction: column;margin-left: 20rpx;">
  63. <view class="">
  64. <view class="titl" v-if="language =='zh-CN'">
  65. {{child.name_cn}}
  66. </view>
  67. <view class="titl" v-if="language =='en-US'">
  68. {{child.name_en}}
  69. </view>
  70. <view class="titl" v-if="language =='es-ES'">
  71. {{child.name_es}}
  72. </view>
  73. <view class="titl" v-if="language =='it-IT'">
  74. {{child.name_ita}}
  75. </view>
  76. <view class="u-flex" style="margin-top: 18rpx;column-gap: 18rpx;">
  77. <text v-if="language =='zh-CN'" class="tabs" v-for="(item,idx) in child.label_arr"
  78. :key="idx">
  79. {{item.name_cn}}
  80. </text>
  81. <text v-if="language =='en-US'" class="tabs" v-for="(item,idx) in child.label_arr"
  82. :key="idx">
  83. {{item.name_en}}
  84. </text>
  85. <text v-if="language =='es-ES'" class="tabs" v-for="(item,idx) in child.label_arr"
  86. :key="idx">
  87. {{item.name_es}}
  88. </text>
  89. <text v-if="language =='it-IT'" class="tabs" v-for="(item,idx) in child.label_arr"
  90. :key="idx">
  91. {{item.name_ita}}
  92. </text>
  93. </view>
  94. </view>
  95. <view class="backimg" style="position: relative;">
  96. <image src="./static/images/tab.png"
  97. style="width: 100%;height: 100%;position: absolute;left: 0;top: 0;z-index: 0;" mode="">
  98. </image>
  99. <view v-if="show==1" class="u-flex u-row-between"
  100. style="position: relative;z-index: 1;padding:0 24rpx ;text-align: center;line-height: 68rpx;">
  101. <view class="">
  102. <text class="textone">{{i18n.Subsidized}}</text>
  103. <text class='texttwo' style="margin-left: 12rpx;">¥</text>
  104. <text class='texttwo' style="font-size: 40rpx;">{{child.price.slice(0,-3)}}</text>
  105. <text class='texttwo'>{{child.price.slice(-3)}}</text>
  106. </view>
  107. <view class="">
  108. <text class="textthree">{{i18n.fill}}</text>
  109. <text class='textfour' style="margin-left: 8rpx;">¥</text>
  110. <text class='textfour'
  111. style="font-size: 28rpx;">{{(child.price*1000 - child.discount_price*1000)/1000}}</text>
  112. </view>
  113. </view>
  114. <view v-if="show==2 || show==3" class="u-flex u-row-between"
  115. style="position: relative;z-index: 1;padding:0 60rpx 0 24rpx ;text-align: center;line-height: 68rpx;">
  116. <view class="">
  117. <text v-if="show==2" class="textone">{{i18n.Subsidized}}</text>
  118. <text v-if="show==3" class="textone">{{i18n.postage}}</text>
  119. <text class='texttwo' style="margin-left: 12rpx;">¥</text>
  120. <text class='texttwo' style="font-size: 40rpx;">{{child.price.slice(0,-3)}}</text>
  121. <text class='texttwo'>{{child.price.slice(-3)}}</text>
  122. </view>
  123. <view class="u-flex">
  124. <image v-if="language =='zh-CN'" src="static/images/qiang.png" style="width: 48rpx;height: 38rpx;" mode="">
  125. </image>
  126. <image v-if="language =='en-US'" src="static/images/qiang1.png" style="width: 44rpx;height: 22rpx;" mode="">
  127. </image>
  128. <image v-if="language =='es-ES'" src="static/images/qiang2.png" style="width: 86rpx;height: 24rpx;" mode="">
  129. </image>
  130. <image v-if="language =='it-IT'" src="static/images/qiang1.png" style="width: 44rpx;height: 22rpx;" mode="">
  131. </image>
  132. </view>
  133. </view>
  134. </view>
  135. </view>
  136. </view>
  137. </view>
  138. </view>
  139. </template>
  140. <script>
  141. export default {
  142. data() {
  143. return {
  144. list1: [],
  145. show: 1,
  146. list: [], //数据
  147. Pleaseproductname: '', //搜索内容
  148. language: 'zh-CN', //语言
  149. keyword: '',
  150. parent_id: '',
  151. page: 1,
  152. limit: 10,
  153. last_page: 1,
  154. };
  155. },
  156. onReachBottom() {
  157. if (this.page < this.last_page) {
  158. // if (this.current != 0) {
  159. this.page++
  160. if (this.show == 1) {
  161. this.subsid() //百万补贴
  162. }
  163. if (this.show == 2) {
  164. this.pack() //拼包好物
  165. }
  166. if (this.show == 3) {
  167. this.shipp() //海外包邮
  168. }
  169. // }
  170. } else {
  171. this.$u.toast(this.i18n.Nofurtherdata)
  172. }
  173. },
  174. computed: {
  175. i18n() {
  176. return this.$t('index')
  177. }
  178. },
  179. onLoad(options) {
  180. this.show = options.show
  181. },
  182. onShow() {
  183. if (uni.getStorageSync('language') != '') {
  184. this.language = uni.getStorageSync('language')
  185. }
  186. if (this.show == 1) {
  187. this.subsid('') //百万补贴
  188. }
  189. if (this.show == 2) {
  190. this.pack('') //拼包好物
  191. }
  192. if (this.show == 3) {
  193. this.shipp('') //海外包邮
  194. }
  195. this.category()
  196. },
  197. methods: {
  198. retur() {
  199. uni.navigateBack()
  200. },
  201. //跳转详情
  202. todetail(id) {
  203. console.log(id);
  204. uni.navigateTo({
  205. url: '/pageA/productdetails?id=' + id
  206. })
  207. },
  208. //标签切换
  209. changetab(e) {
  210. this.parent_id = e.id
  211. if (this.show == 1) {
  212. this.subsid(e.id) //百万补贴
  213. }
  214. if (this.show == 2) {
  215. this.pack(e.id) //拼包好物
  216. }
  217. if (this.show == 3) {
  218. this.shipp(e.id) //海外包邮
  219. }
  220. },
  221. search(e) {
  222. if (this.show == 1) {
  223. this.subsid(this.parent_id) //百万补贴
  224. }
  225. if (this.show == 2) {
  226. this.pack(this.parent_id) //拼包好物
  227. }
  228. if (this.show == 3) {
  229. this.shipp(this.parent_id) //海外包邮
  230. }
  231. },
  232. //商品分类列表
  233. category() {
  234. uni.$u.http.get('/api/goods/category', {
  235. params: {
  236. parent_id: 0
  237. }
  238. }).then((res) => {
  239. const categoryArr = res
  240. this.list1 = [{
  241. name: '',
  242. category_id: ''
  243. }]
  244. if (this.language == 'en-US') {
  245. categoryArr.forEach(item => {
  246. item.name = item.name_en
  247. })
  248. this.list1[0].name = 'selection'
  249. }
  250. if (this.language == 'es-ES') {
  251. categoryArr.forEach(item => {
  252. item.name = item.name_es
  253. })
  254. this.list1[0].name = 'Una selección de'
  255. }
  256. if (this.language == 'it-IT') {
  257. categoryArr.forEach(item => {
  258. item.name = item.name_ita
  259. })
  260. this.list1[0].name = 'selezionate'
  261. }
  262. if (this.language == 'zh-CN') {
  263. categoryArr.forEach(item => {
  264. item.name = item.name_cn
  265. })
  266. this.list1[0].name = '精选'
  267. }
  268. this.list1 = this.list1.concat(categoryArr)
  269. console.log(this.list1);
  270. }).catch(() => {
  271. })
  272. },
  273. //海外包邮接口
  274. shipp(id) {
  275. uni.$u.http.post('api/goods/shipping', {
  276. page: this.page,
  277. limit: this.limit,
  278. parent_id: id,
  279. keyword: this.keyword
  280. }).then((res) => {
  281. this.last_page = res.last_page
  282. if (this.page == 1) {
  283. this.list = res.data
  284. } else {
  285. this.list = this.list.concat(res.data)
  286. }
  287. }).catch(() => {
  288. })
  289. },
  290. //拼包好物接口
  291. pack(id) {
  292. uni.$u.http.post('/api/goods/pack', {
  293. page: this.page,
  294. limit: this.limit,
  295. parent_id: id,
  296. keyword: this.keyword
  297. }).then((res) => {
  298. this.last_page = res.last_page
  299. if (this.page == 1) {
  300. this.list = res.data
  301. } else {
  302. this.list = this.list.concat(res.data)
  303. }
  304. }).catch(() => {
  305. })
  306. },
  307. //百万补贴接口
  308. subsid(id) {
  309. uni.$u.http.post('/api/goods/subsidy', {
  310. page: this.page,
  311. limit: this.limit,
  312. parent_id: id,
  313. keyword: this.keyword
  314. }).then((res) => {
  315. this.last_page = res.last_page
  316. if (this.page == 1) {
  317. this.list = res.data
  318. } else {
  319. this.list = this.list.concat(res.data)
  320. }
  321. }).catch(() => {
  322. })
  323. },
  324. }
  325. }
  326. </script>
  327. <style lang="scss" scoped>
  328. .titl {
  329. font-family: PingFangSC, PingFang SC;
  330. font-weight: 500;
  331. font-size: 30rpx;
  332. color: #444444;
  333. line-height: 42rpx;
  334. text-align: left;
  335. font-style: normal;
  336. width: 400rpx;
  337. overflow: hidden;
  338. text-overflow: ellipsis;
  339. white-space: nowrap;
  340. word-break: break-all;
  341. }
  342. .box {
  343. width: 750rpx;
  344. height: 1266rpx;
  345. background: #F4F4F4;
  346. border-radius: 24rpx 24rpx 0rpx 0rpx;
  347. margin-top: 36rpx;
  348. padding: 32rpx;
  349. box-sizing: border-box;
  350. .baoyou {
  351. font-family: PingFangSC, PingFang SC;
  352. font-weight: 400;
  353. font-size: 20rpx;
  354. color: #FFFFFF;
  355. line-height: 28rpx;
  356. text-align: left;
  357. font-style: normal;
  358. }
  359. .textone {
  360. font-family: PingFangSC, PingFang SC;
  361. font-weight: 400;
  362. font-size: 20rpx;
  363. color: #F83224;
  364. line-height: 28rpx;
  365. text-align: left;
  366. font-style: normal;
  367. }
  368. .texttwo {
  369. font-family: HarmonyOS_Sans_Medium;
  370. font-size: 24rpx;
  371. color: #F83224;
  372. line-height: 34rpx;
  373. text-align: left;
  374. font-style: normal;
  375. }
  376. .textthree {
  377. font-family: PingFangSC, PingFang SC;
  378. font-weight: 400;
  379. font-size: 20rpx;
  380. color: #FDFCFB;
  381. line-height: 28rpx;
  382. text-align: left;
  383. font-style: normal;
  384. }
  385. .textfour {
  386. font-family: PingFangSC, PingFang SC;
  387. font-weight: 400;
  388. font-size: 20rpx;
  389. color: #FDFCFB;
  390. line-height: 28rpx;
  391. text-align: left;
  392. font-style: normal;
  393. }
  394. .backimg {
  395. width: 418rpx;
  396. height: 68rpx;
  397. }
  398. .item {
  399. margin-top: 36rpx;
  400. background: #FDFCFB;
  401. border-radius: 16rpx;
  402. width: 702rpx;
  403. padding: 28rpx 16rpx;
  404. box-sizing: border-box;
  405. // height: 256rpx;
  406. }
  407. .tabs {
  408. padding: 0 8rpx;
  409. height: 32rpx;
  410. border-radius: 4rpx;
  411. border: 1rpx solid #E5BC78;
  412. font-family: PingFangSC, PingFang SC;
  413. font-weight: 400;
  414. font-size: 20rpx;
  415. color: #D48700;
  416. line-height: 28rpx;
  417. text-align: center;
  418. font-style: normal;
  419. }
  420. }
  421. .input {
  422. width: 458rpx;
  423. height: 64rpx;
  424. background: #FDFCFB;
  425. border-radius: 36rpx;
  426. padding: 0 24rpx;
  427. box-sizing: border-box;
  428. margin-left: 16rpx;
  429. display: flex;
  430. align-items: center;
  431. }
  432. .biaopqian {
  433. font-family: PingFangSC, PingFang SC;
  434. font-weight: 400;
  435. font-size: 24rpx;
  436. color: #FFFFFF;
  437. line-height: 34rpx;
  438. text-align: left;
  439. font-style: normal;
  440. }
  441. </style>