subsidy.vue 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389
  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. };
  125. },
  126. computed: {
  127. i18n() {
  128. return this.$t('index')
  129. }
  130. },
  131. onLoad(options) {
  132. this.show = options.show
  133. },
  134. onShow() {
  135. if (uni.getStorageSync('language') != '') {
  136. this.language = uni.getStorageSync('language')
  137. }
  138. if (this.show == 1) {
  139. this.subsid('') //百万补贴
  140. }
  141. if (this.show == 2) {
  142. this.pack('') //拼包好物
  143. }
  144. if (this.show == 3) {
  145. this.shipp('') //海外包邮
  146. }
  147. this.category()
  148. },
  149. methods: {
  150. retur() {
  151. uni.navigateBack()
  152. },
  153. //跳转详情
  154. todetail(id) {
  155. console.log(id);
  156. uni.navigateTo({
  157. url: '/pageA/productdetails?id=' + id
  158. })
  159. },
  160. //标签切换
  161. changetab(e) {
  162. this.parent_id = e.id
  163. if (this.show == 1) {
  164. this.subsid(e.id) //百万补贴
  165. }
  166. if (this.show == 2) {
  167. this.pack(e.id) //拼包好物
  168. }
  169. if (this.show == 3) {
  170. this.shipp(e.id) //海外包邮
  171. }
  172. },
  173. search(e) {
  174. if (this.show == 1) {
  175. this.subsid(this.parent_id) //百万补贴
  176. }
  177. if (this.show == 2) {
  178. this.pack(this.parent_id) //拼包好物
  179. }
  180. if (this.show == 3) {
  181. this.shipp(this.parent_id) //海外包邮
  182. }
  183. },
  184. //商品分类列表
  185. category() {
  186. uni.$u.http.get('/api/goods/category', {
  187. params: {
  188. parent_id: 0
  189. }
  190. }).then((res) => {
  191. const categoryArr = res
  192. this.list1 = [{
  193. name: '',
  194. category_id: ''
  195. }]
  196. if (this.language == 'en-US') {
  197. categoryArr.forEach(item => {
  198. item.name = item.name_en
  199. })
  200. this.list1[0].name = 'selection'
  201. }
  202. if (this.language == 'es-ES') {
  203. categoryArr.forEach(item => {
  204. item.name = item.name_es
  205. })
  206. this.list1[0].name = 'Una selección de'
  207. }
  208. if (this.language == 'it-IT') {
  209. categoryArr.forEach(item => {
  210. item.name = item.name_ita
  211. })
  212. this.list1[0].name = 'selezionate'
  213. }
  214. if (this.language == 'zh-CN') {
  215. categoryArr.forEach(item => {
  216. item.name = item.name_cn
  217. })
  218. this.list1[0].name = '精选'
  219. }
  220. this.list1 = this.list1.concat(categoryArr)
  221. console.log(this.list1);
  222. }).catch(() => {
  223. })
  224. },
  225. //海外包邮接口
  226. shipp(id) {
  227. uni.$u.http.post('api/goods/shipping', {
  228. parent_id: id,
  229. keyword: this.keyword
  230. }).then((res) => {
  231. this.list = res
  232. }).catch(() => {
  233. })
  234. },
  235. //拼包好物接口
  236. pack(id) {
  237. uni.$u.http.post('/api/goods/pack', {
  238. parent_id: id,
  239. keyword: this.keyword
  240. }).then((res) => {
  241. this.list = res
  242. }).catch(() => {
  243. })
  244. },
  245. //百万补贴接口
  246. subsid(id) {
  247. uni.$u.http.post('/api/goods/subsidy', {
  248. parent_id: id,
  249. keyword: this.keyword
  250. }).then((res) => {
  251. this.list = res
  252. }).catch(() => {
  253. })
  254. },
  255. }
  256. }
  257. </script>
  258. <style lang="scss" scoped>
  259. .titl {
  260. font-family: PingFangSC, PingFang SC;
  261. font-weight: 500;
  262. font-size: 30rpx;
  263. color: #444444;
  264. line-height: 42rpx;
  265. text-align: left;
  266. font-style: normal;
  267. width: 400rpx;
  268. overflow: hidden;
  269. text-overflow: ellipsis;
  270. white-space: nowrap;
  271. }
  272. .box {
  273. width: 750rpx;
  274. height: 1266rpx;
  275. background: #F4F4F4;
  276. border-radius: 24rpx 24rpx 0rpx 0rpx;
  277. margin-top: 36rpx;
  278. padding: 32rpx;
  279. box-sizing: border-box;
  280. .baoyou {
  281. font-family: PingFangSC, PingFang SC;
  282. font-weight: 400;
  283. font-size: 20rpx;
  284. color: #FFFFFF;
  285. line-height: 28rpx;
  286. text-align: left;
  287. font-style: normal;
  288. }
  289. .textone {
  290. font-family: PingFangSC, PingFang SC;
  291. font-weight: 400;
  292. font-size: 20rpx;
  293. color: #F83224;
  294. line-height: 28rpx;
  295. text-align: left;
  296. font-style: normal;
  297. }
  298. .texttwo {
  299. font-family: HarmonyOS_Sans_Medium;
  300. font-size: 24rpx;
  301. color: #F83224;
  302. line-height: 34rpx;
  303. text-align: left;
  304. font-style: normal;
  305. }
  306. .textthree {
  307. font-family: PingFangSC, PingFang SC;
  308. font-weight: 400;
  309. font-size: 20rpx;
  310. color: #FDFCFB;
  311. line-height: 28rpx;
  312. text-align: left;
  313. font-style: normal;
  314. }
  315. .textfour {
  316. font-family: PingFangSC, PingFang SC;
  317. font-weight: 400;
  318. font-size: 20rpx;
  319. color: #FDFCFB;
  320. line-height: 28rpx;
  321. text-align: left;
  322. font-style: normal;
  323. }
  324. .backimg {
  325. width: 418rpx;
  326. height: 68rpx;
  327. }
  328. .item {
  329. margin-top: 36rpx;
  330. background: #FDFCFB;
  331. border-radius: 16rpx;
  332. width: 702rpx;
  333. padding: 28rpx 16rpx;
  334. box-sizing: border-box;
  335. // height: 256rpx;
  336. }
  337. .tabs {
  338. padding: 0 8rpx;
  339. height: 32rpx;
  340. border-radius: 4rpx;
  341. border: 1rpx solid #E5BC78;
  342. font-family: PingFangSC, PingFang SC;
  343. font-weight: 400;
  344. font-size: 20rpx;
  345. color: #D48700;
  346. line-height: 28rpx;
  347. text-align: center;
  348. font-style: normal;
  349. }
  350. }
  351. .input {
  352. width: 458rpx;
  353. height: 64rpx;
  354. background: #FDFCFB;
  355. border-radius: 36rpx;
  356. padding: 0 24rpx;
  357. box-sizing: border-box;
  358. margin-left: 16rpx;
  359. display: flex;
  360. align-items: center;
  361. }
  362. .biaopqian {
  363. font-family: PingFangSC, PingFang SC;
  364. font-weight: 400;
  365. font-size: 24rpx;
  366. color: #FFFFFF;
  367. line-height: 34rpx;
  368. text-align: left;
  369. font-style: normal;
  370. }
  371. </style>