index.vue 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171
  1. <template>
  2. <ContentWrap>
  3. <!-- 搜索工作栏 -->
  4. <el-form
  5. class="-mb-15px"
  6. :model="queryParams"
  7. ref="queryFormRef"
  8. :inline="true"
  9. label-width="68px"
  10. >
  11. <el-form-item>
  12. <el-button
  13. type="primary"
  14. plain
  15. @click="openForm('create')"
  16. v-hasPermi="['score:ads:create']"
  17. >
  18. <Icon icon="ep:plus" class="mr-5px" /> {{t('action.add')}}
  19. </el-button>
  20. </el-form-item>
  21. </el-form>
  22. </ContentWrap>
  23. <!-- 列表 -->
  24. <ContentWrap>
  25. <el-table v-loading="loading" :data="list" :stripe="true" :show-overflow-tooltip="true">
  26. <el-table-column label="id" align="center" prop="id" />
  27. <el-table-column :label="t('score.picture')" align="center" prop="image">
  28. <template #default="score">
  29. <el-image style="width: 100px; height: 50px" :src="convertImageUrl(score.row.image)" />
  30. </template>
  31. </el-table-column>
  32. <el-table-column :label="t('score.availability')" align="center" prop="isSwitch">
  33. <template #default="score">
  34. <span v-if="score.row.isSwitch == 1">{{t('common.yes')}}</span>
  35. <span v-else>{{t('common.no')}}</span>
  36. </template>
  37. </el-table-column>
  38. <el-table-column :label="t('score.weight')" align="center" prop="weigh" />
  39. <el-table-column
  40. :label="t('public.addTime')"
  41. align="center"
  42. prop="createTime"
  43. :formatter="dateFormatter"
  44. width="180px"
  45. />
  46. <el-table-column :label="t('public.operate')" align="center">
  47. <template #default="score">
  48. <el-button
  49. link
  50. type="primary"
  51. @click="openForm('update', score.row.id)"
  52. v-hasPermi="['score:ads:update']"
  53. >
  54. {{t('action.edit')}}
  55. </el-button>
  56. <el-button
  57. link
  58. type="danger"
  59. @click="handleDelete(score.row.id)"
  60. v-hasPermi="['score:ads:delete']"
  61. >
  62. {{ t('public.delete') }}
  63. </el-button>
  64. </template>
  65. </el-table-column>
  66. </el-table>
  67. <!-- 分页 -->
  68. <Pagination
  69. :total="total"
  70. v-model:page="queryParams.pageNo"
  71. v-model:limit="queryParams.pageSize"
  72. @pagination="getList"
  73. />
  74. </ContentWrap>
  75. <!-- 表单弹窗:添加/修改 -->
  76. <AdsForm ref="formRef" @success="getList" />
  77. </template>
  78. <script setup lang="ts">
  79. import { dateFormatter } from '@/utils/formatTime'
  80. import download from '@/utils/download'
  81. import { AdsApi, AdsVO } from '@/api/score/scoreads'
  82. import AdsForm from './AdsForm.vue'
  83. import { convertImageUrl } from '@/utils/image-helper'
  84. /** 积分商城广告图管理 列表 */
  85. defineOptions({ name: 'ScoreAds' })
  86. const message = useMessage() // 消息弹窗
  87. const { t } = useI18n() // 国际化
  88. const loading = ref(true) // 列表的加载中
  89. const list = ref<AdsVO[]>([]) // 列表的数据
  90. const total = ref(0) // 列表的总页数
  91. const queryParams = reactive({
  92. pageNo: 1,
  93. pageSize: 10,
  94. image: undefined,
  95. isSwitch: undefined,
  96. weigh: undefined,
  97. shopName: undefined,
  98. createTime: []
  99. })
  100. const queryFormRef = ref() // 搜索的表单
  101. const exportLoading = ref(false) // 导出的加载中
  102. /** 查询列表 */
  103. const getList = async () => {
  104. loading.value = true
  105. try {
  106. const data = await AdsApi.getAdsPage(queryParams)
  107. list.value = data.list
  108. total.value = data.total
  109. } finally {
  110. loading.value = false
  111. }
  112. }
  113. /** 搜索按钮操作 */
  114. const handleQuery = () => {
  115. queryParams.pageNo = 1
  116. getList()
  117. }
  118. /** 重置按钮操作 */
  119. const resetQuery = () => {
  120. queryFormRef.value.resetFields()
  121. handleQuery()
  122. }
  123. /** 添加/修改操作 */
  124. const formRef = ref()
  125. const openForm = (type: string, id?: number) => {
  126. formRef.value.open(type, id)
  127. }
  128. /** 删除按钮操作 */
  129. const handleDelete = async (id: number) => {
  130. try {
  131. // 删除的二次确认
  132. await message.delConfirm()
  133. // 发起删除
  134. await AdsApi.deleteAds(id)
  135. message.success(t('common.delSuccess'))
  136. // 刷新列表
  137. await getList()
  138. } catch {}
  139. }
  140. /** 导出按钮操作 */
  141. const handleExport = async () => {
  142. try {
  143. // 导出的二次确认
  144. await message.exportConfirm()
  145. // 发起导出
  146. exportLoading.value = true
  147. const data = await AdsApi.exportAds(queryParams)
  148. download.excel(data, t('score.pointsMallAdvertisementMapManagementXls'))
  149. } catch {
  150. } finally {
  151. exportLoading.value = false
  152. }
  153. }
  154. /** 初始化 **/
  155. onMounted(() => {
  156. getList()
  157. })
  158. </script>