subsidy.vue 11 KB

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