index.vue 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192
  1. <template>
  2. <div class="article-lists">
  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.cid">
  15. <el-option label="全部" value />
  16. <el-option
  17. v-for="item in optionsData.articleCate"
  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.isShow">
  26. <el-option label="全部" value />
  27. <el-option label="显示" :value="1" />
  28. <el-option label="隐藏" :value="0" />
  29. </el-select>
  30. </el-form-item>
  31. <el-form-item>
  32. <el-button type="primary" @click="resetPage">查询</el-button>
  33. <el-button @click="resetParams">重置</el-button>
  34. </el-form-item>
  35. </el-form>
  36. </el-card>
  37. <el-card class="!border-none mt-4" shadow="never">
  38. <div>
  39. <router-link
  40. v-perms="['dish:add', 'dish:add/edit']"
  41. :to="{
  42. path: getRoutePath('dish:add/edit')
  43. }"
  44. >
  45. <el-button class="mr-3" type="primary">
  46. <template #icon>
  47. <icon name="el-icon-Plus" />
  48. </template>
  49. 添加菜品
  50. </el-button>
  51. </router-link>
  52. <!-- <multi-del-btn></multi-del-btn> -->
  53. </div>
  54. <el-table class="mt-4" size="large" v-loading="pager.loading" :data="pager.lists">
  55. <!-- <el-table-column type="selection" width="55" /> -->
  56. <el-table-column label="ID" type="index" min-width="80" />
  57. <el-table-column label="图片" min-width="100">
  58. <template #default="{ row }">
  59. <image-contain
  60. v-if="row.image"
  61. :src="row.image"
  62. :width="60"
  63. :height="45"
  64. :preview-src-list="[row.image]"
  65. preview-teleported
  66. fit="contain"
  67. />
  68. </template>
  69. </el-table-column>
  70. <el-table-column
  71. label="菜品名称"
  72. prop="title"
  73. min-width="160"
  74. show-tooltip-when-overflow
  75. />
  76. <el-table-column label="菜品分类" prop="category" min-width="150" show-tooltip-when-overflow />
  77. <!-- <el-table-column label="菜品分类" prop="category" min-width="100">
  78. <template #default="{ row }">
  79. <div class="remark-text">
  80. {{row.category}}
  81. </div>
  82. </template>
  83. </el-table-column> -->
  84. <el-table-column label="价格" prop="summary" min-width="70" />
  85. <el-table-column
  86. label="菜品描述"
  87. prop="intro"
  88. min-width="150"
  89. show-tooltip-when-overflow
  90. />
  91. <el-table-column label="状态" min-width="90">
  92. <template #default="{ row }">
  93. <el-switch
  94. v-model="row.isShow"
  95. :active-value="1"
  96. :inactive-value="0"
  97. @change="changeStatus(row.id)"
  98. />
  99. </template>
  100. </el-table-column>
  101. <el-table-column label="排序" prop="sort" min-width="80" />
  102. <el-table-column label="添加时间" prop="createTime" min-width="170" />
  103. <el-table-column label="操作" width="120" fixed="right">
  104. <template #default="{ row }">
  105. <el-button v-perms="['dish:edit', 'dish:add/edit']" type="primary" link>
  106. <router-link
  107. :to="{
  108. path: getRoutePath('dish:add/edit'),
  109. query: {
  110. id: row.id
  111. }
  112. }"
  113. >
  114. 编辑
  115. </router-link>
  116. </el-button>
  117. <el-button
  118. v-perms="['dish:del']"
  119. type="danger"
  120. link
  121. @click="handleDelete(row.id)"
  122. >
  123. 删除
  124. </el-button>
  125. </template>
  126. </el-table-column>
  127. </el-table>
  128. <div class="flex justify-end mt-4">
  129. <pagination v-model="pager" @change="getLists" />
  130. </div>
  131. </el-card>
  132. </div>
  133. </template>
  134. <script lang="ts" setup name="articleLists">
  135. import { articleLists, articleDelete, articleStatus, articleCateAll } from '@/api/article'
  136. import { useDictOptions } from '@/hooks/useDictOptions'
  137. import { usePaging } from '@/hooks/usePaging'
  138. import { getRoutePath } from '@/router'
  139. import feedback from '@/utils/feedback'
  140. const queryParams = reactive({
  141. title: '',
  142. cid: '',
  143. isShow: ''
  144. })
  145. const { pager, getLists, resetPage, resetParams } = usePaging({
  146. fetchFun: articleLists,
  147. params: queryParams
  148. })
  149. const { optionsData } = useDictOptions<{
  150. articleCate: any[]
  151. }>({
  152. articleCate: {
  153. api: articleCateAll
  154. }
  155. })
  156. const changeStatus = async (id: number) => {
  157. try {
  158. await articleStatus({ id })
  159. feedback.msgSuccess('修改成功')
  160. getLists()
  161. } catch (error) {
  162. getLists()
  163. }
  164. }
  165. const handleDelete = async (id: number) => {
  166. await feedback.confirm('确定要删除?')
  167. await articleDelete({ id })
  168. feedback.msgSuccess('删除成功')
  169. getLists()
  170. }
  171. onActivated(() => {
  172. getLists()
  173. })
  174. getLists()
  175. </script>
  176. <style lang="scss" scoped>
  177. .remark-text {
  178. display: -webkit-box;
  179. -webkit-box-orient: vertical;
  180. -webkit-line-clamp: 2;
  181. overflow: hidden;
  182. text-overflow: ellipsis;
  183. word-break: break-all;
  184. line-height: 1.5;
  185. max-height: 3em; // 2行的高度
  186. }
  187. </style>