subsidy.vue 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453
  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: 52rpx;" mode=""></image>
  21. <image v-if="show==1 && language =='es-ES'" src="/pageA/static/images/Million.png1"
  22. style="width: 484rpx;height: 52rpx;" mode=""></image>
  23. <image v-if="show==1 && language =='it-IT'" src="/pageA/static/images/Million.png2"
  24. style="width: 484rpx;height: 52rpx;" 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: 64rpx;" mode=""></image>
  29. <image v-if="show==2 && language =='es-ES'" src="/pageA/static/images/kg2.png"
  30. style="width: 346rpx;height: 64rpx;" mode=""></image>
  31. <image v-if="show==2 && language =='it-IT'" src="/pageA/static/images/kg3.png"
  32. style="width: 346rpx;height: 64rpx;" mode=""></image>
  33. <image v-if="show==3 && language =='zh-CN'" src="static/images/goshop.png"
  34. style="width: 382rpx;height: 52rpx;" 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 src="static/images/qiang.png" style="width: 48rpx;height: 38rpx;" mode="">
  125. </image>
  126. </view>
  127. </view>
  128. </view>
  129. </view>
  130. </view>
  131. </view>
  132. </view>
  133. </template>
  134. <script>
  135. export default {
  136. data() {
  137. return {
  138. list1: [],
  139. show: 1,
  140. list: [], //数据
  141. Pleaseproductname: '', //搜索内容
  142. language: 'zh-CN', //语言
  143. keyword: '',
  144. parent_id: '',
  145. page: 1,
  146. limit: 10,
  147. last_page: 1,
  148. };
  149. },
  150. onReachBottom() {
  151. if (this.page < this.last_page) {
  152. // if (this.current != 0) {
  153. this.page++
  154. if (this.show == 1) {
  155. this.subsid() //百万补贴
  156. }
  157. if (this.show == 2) {
  158. this.pack() //拼包好物
  159. }
  160. if (this.show == 3) {
  161. this.shipp() //海外包邮
  162. }
  163. // }
  164. } else {
  165. this.$u.toast(this.i18n.Nofurtherdata)
  166. }
  167. },
  168. computed: {
  169. i18n() {
  170. return this.$t('index')
  171. }
  172. },
  173. onLoad(options) {
  174. this.show = options.show
  175. },
  176. onShow() {
  177. if (uni.getStorageSync('language') != '') {
  178. this.language = uni.getStorageSync('language')
  179. }
  180. if (this.show == 1) {
  181. this.subsid('') //百万补贴
  182. }
  183. if (this.show == 2) {
  184. this.pack('') //拼包好物
  185. }
  186. if (this.show == 3) {
  187. this.shipp('') //海外包邮
  188. }
  189. this.category()
  190. },
  191. methods: {
  192. retur() {
  193. uni.navigateBack()
  194. },
  195. //跳转详情
  196. todetail(id) {
  197. console.log(id);
  198. uni.navigateTo({
  199. url: '/pageA/productdetails?id=' + id
  200. })
  201. },
  202. //标签切换
  203. changetab(e) {
  204. this.parent_id = e.id
  205. if (this.show == 1) {
  206. this.subsid(e.id) //百万补贴
  207. }
  208. if (this.show == 2) {
  209. this.pack(e.id) //拼包好物
  210. }
  211. if (this.show == 3) {
  212. this.shipp(e.id) //海外包邮
  213. }
  214. },
  215. search(e) {
  216. if (this.show == 1) {
  217. this.subsid(this.parent_id) //百万补贴
  218. }
  219. if (this.show == 2) {
  220. this.pack(this.parent_id) //拼包好物
  221. }
  222. if (this.show == 3) {
  223. this.shipp(this.parent_id) //海外包邮
  224. }
  225. },
  226. //商品分类列表
  227. category() {
  228. uni.$u.http.get('/api/goods/category', {
  229. params: {
  230. parent_id: 0
  231. }
  232. }).then((res) => {
  233. const categoryArr = res
  234. this.list1 = [{
  235. name: '',
  236. category_id: ''
  237. }]
  238. if (this.language == 'en-US') {
  239. categoryArr.forEach(item => {
  240. item.name = item.name_en
  241. })
  242. this.list1[0].name = 'selection'
  243. }
  244. if (this.language == 'es-ES') {
  245. categoryArr.forEach(item => {
  246. item.name = item.name_es
  247. })
  248. this.list1[0].name = 'Una selección de'
  249. }
  250. if (this.language == 'it-IT') {
  251. categoryArr.forEach(item => {
  252. item.name = item.name_ita
  253. })
  254. this.list1[0].name = 'selezionate'
  255. }
  256. if (this.language == 'zh-CN') {
  257. categoryArr.forEach(item => {
  258. item.name = item.name_cn
  259. })
  260. this.list1[0].name = '精选'
  261. }
  262. this.list1 = this.list1.concat(categoryArr)
  263. console.log(this.list1);
  264. }).catch(() => {
  265. })
  266. },
  267. //海外包邮接口
  268. shipp(id) {
  269. uni.$u.http.post('api/goods/shipping', {
  270. page: this.page,
  271. limit: this.limit,
  272. parent_id: id,
  273. keyword: this.keyword
  274. }).then((res) => {
  275. this.last_page = res.last_page
  276. if (this.page == 1) {
  277. this.list = res.data
  278. } else {
  279. this.list = this.list.concat(res.data)
  280. }
  281. }).catch(() => {
  282. })
  283. },
  284. //拼包好物接口
  285. pack(id) {
  286. uni.$u.http.post('/api/goods/pack', {
  287. page: this.page,
  288. limit: this.limit,
  289. parent_id: id,
  290. keyword: this.keyword
  291. }).then((res) => {
  292. this.last_page = res.last_page
  293. if (this.page == 1) {
  294. this.list = res.data
  295. } else {
  296. this.list = this.list.concat(res.data)
  297. }
  298. }).catch(() => {
  299. })
  300. },
  301. //百万补贴接口
  302. subsid(id) {
  303. uni.$u.http.post('/api/goods/subsidy', {
  304. page: this.page,
  305. limit: this.limit,
  306. parent_id: id,
  307. keyword: this.keyword
  308. }).then((res) => {
  309. this.last_page = res.last_page
  310. if (this.page == 1) {
  311. this.list = res.data
  312. } else {
  313. this.list = this.list.concat(res.data)
  314. }
  315. }).catch(() => {
  316. })
  317. },
  318. }
  319. }
  320. </script>
  321. <style lang="scss" scoped>
  322. .titl {
  323. font-family: PingFangSC, PingFang SC;
  324. font-weight: 500;
  325. font-size: 30rpx;
  326. color: #444444;
  327. line-height: 42rpx;
  328. text-align: left;
  329. font-style: normal;
  330. width: 400rpx;
  331. overflow: hidden;
  332. text-overflow: ellipsis;
  333. white-space: nowrap;
  334. word-break: break-all;
  335. }
  336. .box {
  337. width: 750rpx;
  338. height: 1266rpx;
  339. background: #F4F4F4;
  340. border-radius: 24rpx 24rpx 0rpx 0rpx;
  341. margin-top: 36rpx;
  342. padding: 32rpx;
  343. box-sizing: border-box;
  344. .baoyou {
  345. font-family: PingFangSC, PingFang SC;
  346. font-weight: 400;
  347. font-size: 20rpx;
  348. color: #FFFFFF;
  349. line-height: 28rpx;
  350. text-align: left;
  351. font-style: normal;
  352. }
  353. .textone {
  354. font-family: PingFangSC, PingFang SC;
  355. font-weight: 400;
  356. font-size: 20rpx;
  357. color: #F83224;
  358. line-height: 28rpx;
  359. text-align: left;
  360. font-style: normal;
  361. }
  362. .texttwo {
  363. font-family: HarmonyOS_Sans_Medium;
  364. font-size: 24rpx;
  365. color: #F83224;
  366. line-height: 34rpx;
  367. text-align: left;
  368. font-style: normal;
  369. }
  370. .textthree {
  371. font-family: PingFangSC, PingFang SC;
  372. font-weight: 400;
  373. font-size: 20rpx;
  374. color: #FDFCFB;
  375. line-height: 28rpx;
  376. text-align: left;
  377. font-style: normal;
  378. }
  379. .textfour {
  380. font-family: PingFangSC, PingFang SC;
  381. font-weight: 400;
  382. font-size: 20rpx;
  383. color: #FDFCFB;
  384. line-height: 28rpx;
  385. text-align: left;
  386. font-style: normal;
  387. }
  388. .backimg {
  389. width: 418rpx;
  390. height: 68rpx;
  391. }
  392. .item {
  393. margin-top: 36rpx;
  394. background: #FDFCFB;
  395. border-radius: 16rpx;
  396. width: 702rpx;
  397. padding: 28rpx 16rpx;
  398. box-sizing: border-box;
  399. // height: 256rpx;
  400. }
  401. .tabs {
  402. padding: 0 8rpx;
  403. height: 32rpx;
  404. border-radius: 4rpx;
  405. border: 1rpx solid #E5BC78;
  406. font-family: PingFangSC, PingFang SC;
  407. font-weight: 400;
  408. font-size: 20rpx;
  409. color: #D48700;
  410. line-height: 28rpx;
  411. text-align: center;
  412. font-style: normal;
  413. }
  414. }
  415. .input {
  416. width: 458rpx;
  417. height: 64rpx;
  418. background: #FDFCFB;
  419. border-radius: 36rpx;
  420. padding: 0 24rpx;
  421. box-sizing: border-box;
  422. margin-left: 16rpx;
  423. display: flex;
  424. align-items: center;
  425. }
  426. .biaopqian {
  427. font-family: PingFangSC, PingFang SC;
  428. font-weight: 400;
  429. font-size: 24rpx;
  430. color: #FFFFFF;
  431. line-height: 34rpx;
  432. text-align: left;
  433. font-style: normal;
  434. }
  435. </style>