browse.vue 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. <template>
  2. <div class="ml-[20px] min-h-[70vh] px-[20px] py-[30px] w-[1000px] bg-[#fff] rounded-[var(--rounded-big)]">
  3. <div class="full" v-loading="browseData.loading">
  4. <div>
  5. <div class="text-[18px] text-[#333] font-500 leading-[18px] ml-[10px] mb-[27px]">{{ t('title') }}({{ browseData.total }})</div>
  6. <!-- <div class="bg-[#FFF4F4] text-primary text-[12px] h-[32px] leading-[32px] pl-[10px] mb-[20px] rounded-[6px]">共{{ browseData.total }}条记录,{{t('remark')}}</div> -->
  7. <div v-if="browseData.total && !browseData.loading">
  8. <div>
  9. <div v-for="(item, index) in browseData.data" class="mb-30px" :key="index">
  10. <div class="flex items-center ml-[10px] mb-[18px]">
  11. <span class="iconfont icon-riliV6xx text-[16px] mr-[6px]"></span>
  12. <span class="text-[#333] text-[14px]">{{ item.date }}</span>
  13. </div>
  14. <div class="goods-list">
  15. <div class="w-[228px] h-[342px] cursor-pointer border-[1px] border-solid border-[#eee] rounded-[var(--rounded-big)]" v-for="(goodsItem, goodsIndex) in item.list" :key="goodsIndex" @click="toDetail(goodsItem)">
  16. <div class="flex items-center justify-center">
  17. <el-image class="w-[227px] h-[227px] rounded-t-[var(--rounded-big)]" :class="{'opacity-25':goodsItem.goods.status != 1 || goodsItem.goods.delete_time > 0}" :src="img(goodsItem.goods_cover_thumb_mid ? goodsItem.goods_cover_thumb_mid : '')" fit="cover">
  18. <template #error>
  19. <img src="@/assets/images/goods_default.png" class="w-[227px] h-[227px] rounded-t-[var(--rounded-big)]">
  20. </template>
  21. </el-image>
  22. </div>
  23. <div class="pt-[15px] px-[20px] pb-[20px] h-[112px] flex flex-col justify-between">
  24. <div class="text-[14px] text-[#333] multi-hidden leading-[20px]" :class="{'text-[#999]':goodsItem.goods.status != 1 || goodsItem.goods.delete_time > 0}">{{ goodsItem.goods_name }}</div>
  25. <div class="flex justify-between">
  26. <div class="text-[#333] text-[14px] oppoSans-R" v-if="goodsItem.goods.delete_time > 0">
  27. {{t('delete')}}
  28. </div>
  29. <div class="text-[#333] text-[14px] oppoSans-R" v-else-if="goodsItem.goods.status != 1">
  30. {{t('invalid')}}
  31. </div>
  32. <div class="text-primary flex items-baseline" v-else>
  33. <span class="price-font font-600 text-[14px]">¥</span>
  34. <span class="price-font text-[20px] font-600">{{parseFloat(goodsItem.price).toFixed(2)}}</span>
  35. </div>
  36. </div>
  37. </div>
  38. </div>
  39. </div>
  40. </div>
  41. </div>
  42. <div class="mt-[16px] flex justify-end">
  43. <el-pagination v-model:current-page="browseData.page" v-model:page-size="browseData.limit" layout="total, sizes, prev, pager, next, jumper" :total="browseData.total"
  44. @size-change="loadBrowseList()" @current-change="loadBrowseList" />
  45. </div>
  46. </div>
  47. <div class="min-h-[300px]" v-if="!browseData.total && !browseData.loading">
  48. <el-empty :description="t('empty')" :image-size="200" :image="img('static/resource/images/system/empty.png')"/>
  49. </div>
  50. </div>
  51. </div>
  52. </div>
  53. </template>
  54. <script setup lang="ts">
  55. import { reactive } from 'vue'
  56. import { getBrowseList } from '@/addon/mall/api/member'
  57. import { useRouter } from 'vue-router'
  58. const router = useRouter()
  59. const browseData = reactive({
  60. total: 0,
  61. page: 1,
  62. limit: 10,
  63. loading: true,
  64. data: []
  65. })
  66. const loadBrowseList = (page: number = 1) => {
  67. browseData.page = page
  68. browseData.loading = true
  69. getBrowseList({
  70. page: browseData.page,
  71. limit: browseData.limit,
  72. }).then((res: any) => {
  73. browseData.loading = false
  74. browseData.total = res.data.total
  75. let newArr = res.data.data
  76. // 按日期分组
  77. const groupedData = newArr.reduce((acc: any, item: any) => {
  78. const date = item.browse_time.split(' ')[0]; // 提取日期部分
  79. if (!acc[date]) {
  80. acc[date] = [];
  81. }
  82. acc[date].push(item);
  83. return acc;
  84. }, {});
  85. // 转换为所需格式
  86. browseData.data = Object.keys(groupedData).map(date => ({
  87. date: date,
  88. list: groupedData[date]
  89. }));
  90. }).catch(() => {
  91. browseData.loading = false
  92. })
  93. }
  94. loadBrowseList()
  95. const toDetail = (item:any) => {
  96. if(item.goods.delete_time > 0 || item.goods.status != 1) return
  97. router.push(`/goods/detail?id=${item.goods_id}`)
  98. }
  99. </script>
  100. <style lang="scss" scoped>
  101. .goods-list{
  102. grid-row-gap: 16px;
  103. grid-column-gap: 16px;
  104. display: grid;
  105. grid-template-columns: repeat(4,1fr);
  106. grid-template-rows: auto;
  107. position: relative;
  108. }
  109. </style>