index.vue 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185
  1. <template>
  2. <div class="article-lists" v-perms="['goods:list:query']">
  3. <el-card class="!border-none" shadow="never">
  4. <el-form ref="formRef" class="mb-[-16px]" :model="queryParams" :inline="true">
  5. <el-form-item label="商品名称">
  6. <el-input
  7. class="w-[280px]"
  8. v-model="queryParams.title"
  9. clearable
  10. @keyup.enter="resetPage"
  11. />
  12. </el-form-item>
  13. <el-form-item label="商品分类">
  14. <el-select class="w-[280px]" v-model="queryParams.categoryId">
  15. <el-option label="全部" value/>
  16. <el-option
  17. v-for="item in optionsData.goodsCategory"
  18. :key="item.id"
  19. :label="item.name"
  20. :value="item.id"
  21. />
  22. </el-select>
  23. </el-form-item>
  24. <el-form-item label="商品状态">
  25. <el-select class="w-[280px]" v-model="queryParams.auditStatus">
  26. <el-option label="全部" value/>
  27. <el-option label="待审核" :value="0"/>
  28. <el-option label="已通过" :value="1"/>
  29. <el-option label="已驳回" :value="2"/>
  30. </el-select>
  31. </el-form-item>
  32. <el-form-item>
  33. <el-button type="primary" @click="resetPage">查询</el-button>
  34. <el-button @click="resetParams">重置</el-button>
  35. </el-form-item>
  36. </el-form>
  37. </el-card>
  38. <el-card class="!border-none mt-4" shadow="never">
  39. <div>
  40. <router-link v-perms="['goods:list:add', 'goods:list:add/edit']" :to="{ path: getRoutePath('goods:list:add/edit') }">
  41. <el-button class="mr-3" type="primary">
  42. <template #icon>
  43. <icon name="el-icon-Plus"/>
  44. </template>
  45. 添加商品
  46. </el-button>
  47. </router-link>
  48. <!-- <multi-del-btn></multi-del-btn> -->
  49. </div>
  50. <el-table class="mt-4" size="large" v-loading="pager.loading" :data="pager.lists">
  51. <el-table-column label="ID" type="index" min-width="80"/>
  52. <el-table-column label="图片" min-width="100">
  53. <template #default="{ row }">
  54. <image-contain
  55. v-if="row.image"
  56. :src="row.image"
  57. :width="60"
  58. :height="45"
  59. :preview-src-list="[row.image]"
  60. preview-teleported
  61. fit="contain"
  62. />
  63. </template>
  64. </el-table-column>
  65. <el-table-column
  66. label="商品名称"
  67. prop="title"
  68. min-width="160"
  69. show-tooltip-when-overflow
  70. />
  71. <el-table-column label="商品分类" prop="categoryName" min-width="150" show-tooltip-when-overflow/>
  72. <el-table-column label="售价/元" prop="price" min-width="70"/>
  73. <el-table-column
  74. label="审核状态"
  75. prop="auditStatus"
  76. min-width="100"
  77. show-tooltip-when-overflow
  78. >
  79. <template #default="{ row }">
  80. <span v-if="row.auditStatus === 0" class="text-yellow-500">待审核</span>
  81. <span v-else-if="row.auditStatus === 1" class="text-green-500">已通过</span>
  82. <span v-else-if="row.auditStatus === 2" class="text-red-500">已驳回</span>
  83. </template>
  84. </el-table-column>
  85. <el-table-column
  86. label="库存"
  87. prop="stock"
  88. min-width="100"
  89. show-tooltip-when-overflow
  90. />
  91. <el-table-column label="排序" prop="sort" min-width="80"/>
  92. <el-table-column label="添加时间" prop="createTime" min-width="120"/>
  93. <el-table-column label="操作" width="120" fixed="right">
  94. <template #default="{ row }">
  95. <el-button v-perms="['goods:list:edit', 'goods:list:add/edit']" type="primary" link>
  96. <router-link :to="{ path: getRoutePath('goods:list:add/edit'), query: { id: row.id } }">
  97. 编辑
  98. </router-link>
  99. </el-button>
  100. <el-button
  101. v-perms="['goods:list:delete']"
  102. type="danger"
  103. link
  104. @click="handleDelete(row.id)"
  105. >
  106. 删除
  107. </el-button>
  108. </template>
  109. </el-table-column>
  110. </el-table>
  111. <div class="flex justify-end mt-4">
  112. <pagination v-model="pager" @change="getLists"/>
  113. </div>
  114. </el-card>
  115. </div>
  116. </template>
  117. <script lang="ts" setup name="goodsPage">
  118. import {goodsPage} from '@/api/goods/list'
  119. import {goodsCategoryPage} from '@/api/goods/category'
  120. import {useDictOptions} from '@/hooks/useDictOptions'
  121. import {usePaging} from '@/hooks/usePaging'
  122. import {getRoutePath} from '@/router'
  123. import { getShopId } from '@/utils/auth'
  124. import feedback from '@/utils/feedback'
  125. const queryParams = reactive({
  126. title: '',
  127. cid: '',
  128. isShow: '',
  129. shopId: getShopId()
  130. })
  131. const {pager, getLists, resetPage, resetParams} = usePaging({
  132. fetchFun: goodsPage,
  133. params: queryParams
  134. })
  135. const {optionsData} = useDictOptions<{
  136. goodsCategory: any[]
  137. }>({
  138. goodsCategory: {
  139. api: goodsCategoryPage,
  140. params: {pageNo: 1, pageSize: 100},
  141. transformData(data: any) {
  142. return data.lists
  143. }
  144. }
  145. })
  146. const handleDelete = async (id: number) => {
  147. await feedback.confirm('确定要删除?')
  148. // await goodsEdit({id})
  149. feedback.msgSuccess('删除成功')
  150. getLists()
  151. }
  152. onActivated(() => {
  153. getLists()
  154. })
  155. getLists()
  156. </script>
  157. <style lang="scss" scoped>
  158. .remark-text {
  159. display: -webkit-box;
  160. -webkit-box-orient: vertical;
  161. -webkit-line-clamp: 2;
  162. overflow: hidden;
  163. text-overflow: ellipsis;
  164. word-break: break-all;
  165. line-height: 1.5;
  166. max-height: 3em; // 2行的高度
  167. }
  168. .text-yellow-500 {
  169. color: #f59e0b;
  170. }
  171. .text-red-500 {
  172. color: #ef4444;
  173. }
  174. .text-green-500 {
  175. color: #10b981;
  176. }
  177. </style>