CouponSelect.vue 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191
  1. <template>
  2. <Dialog v-model="dialogVisible" :title="dialogTitle" width="65%">
  3. <!-- 搜索工作栏 -->
  4. <ContentWrap>
  5. <el-form
  6. ref="queryFormRef"
  7. :inline="true"
  8. :model="queryParams"
  9. class="-mb-15px"
  10. label-width="82px"
  11. >
  12. <el-form-item label="优惠券名称" prop="name">
  13. <el-input
  14. v-model="queryParams.name"
  15. class="!w-240px"
  16. clearable
  17. placeholder="请输入优惠劵名"
  18. @keyup="handleQuery"
  19. />
  20. </el-form-item>
  21. <el-form-item label="优惠类型" prop="discountType">
  22. <el-select
  23. v-model="queryParams.discountType"
  24. class="!w-240px"
  25. clearable
  26. placeholder="请选择优惠券类型"
  27. >
  28. <el-option
  29. v-for="dict in getIntDictOptions(DICT_TYPE.PROMOTION_DISCOUNT_TYPE)"
  30. :key="dict.value"
  31. :label="dict.label"
  32. :value="dict.value"
  33. />
  34. </el-select>
  35. </el-form-item>
  36. <el-form-item>
  37. <el-button @click="handleQuery">
  38. <Icon class="mr-5px" icon="ep:search" />
  39. 搜索
  40. </el-button>
  41. <el-button @click="resetQuery">
  42. <Icon class="mr-5px" icon="ep:refresh" />
  43. 重置
  44. </el-button>
  45. </el-form-item>
  46. </el-form>
  47. </ContentWrap>
  48. <!-- 列表 -->
  49. <ContentWrap>
  50. <el-table v-loading="loading" :data="list" @selection-change="handleSelectionChange">
  51. <el-table-column type="selection" width="55" />
  52. <el-table-column label="优惠券名称" min-width="140" prop="name" />
  53. <el-table-column label="类型" min-width="80" prop="productScope">
  54. <template #default="scope">
  55. <dict-tag :type="DICT_TYPE.PROMOTION_PRODUCT_SCOPE" :value="scope.row.productScope" />
  56. </template>
  57. </el-table-column>
  58. <el-table-column label="优惠" min-width="100" prop="discount">
  59. <template #default="scope">
  60. <dict-tag :type="DICT_TYPE.PROMOTION_DISCOUNT_TYPE" :value="scope.row.discountType" />
  61. {{ discountFormat(scope.row) }}
  62. </template>
  63. </el-table-column>
  64. <el-table-column label="领取方式" min-width="100" prop="takeType">
  65. <template #default="scope">
  66. <dict-tag :type="DICT_TYPE.PROMOTION_COUPON_TAKE_TYPE" :value="scope.row.takeType" />
  67. </template>
  68. </el-table-column>
  69. <el-table-column
  70. :formatter="validityTypeFormat"
  71. align="center"
  72. label="使用时间"
  73. prop="validityType"
  74. width="185"
  75. />
  76. <el-table-column align="center" label="发放数量" prop="totalCount" />
  77. <el-table-column
  78. :formatter="remainedCountFormat"
  79. align="center"
  80. label="剩余数量"
  81. prop="totalCount"
  82. />
  83. <el-table-column
  84. :formatter="takeLimitCountFormat"
  85. align="center"
  86. label="领取上限"
  87. prop="takeLimitCount"
  88. />
  89. <el-table-column align="center" label="状态" prop="status">
  90. <template #default="scope">
  91. <dict-tag :type="DICT_TYPE.COMMON_STATUS" :value="scope.row.status" />
  92. </template>
  93. </el-table-column>
  94. </el-table>
  95. <!-- 分页 -->
  96. <Pagination
  97. v-model:limit="queryParams.pageSize"
  98. v-model:page="queryParams.pageNo"
  99. :total="total"
  100. @pagination="getList"
  101. />
  102. </ContentWrap>
  103. <template #footer>
  104. <el-button :disabled="formLoading" type="primary" @click="submitForm">确 定</el-button>
  105. <el-button @click="dialogVisible = false">取 消</el-button>
  106. </template>
  107. </Dialog>
  108. </template>
  109. <script lang="ts" setup>
  110. import { DICT_TYPE, getIntDictOptions } from '@/utils/dict'
  111. import {
  112. discountFormat,
  113. remainedCountFormat,
  114. takeLimitCountFormat,
  115. validityTypeFormat
  116. } from '@/views/mall/promotion/coupon/formatter'
  117. import * as CouponTemplateApi from '@/api/mall/promotion/coupon/couponTemplate'
  118. defineOptions({ name: 'CouponSelect' })
  119. const props = defineProps<{
  120. multipleSelection?: CouponTemplateApi.CouponTemplateVO[]
  121. takeType: number // 领取方式
  122. }>()
  123. const emit = defineEmits<{
  124. (e: 'update:multipleSelection', v: CouponTemplateApi.CouponTemplateVO[]): void
  125. (e: 'change', v: CouponTemplateApi.CouponTemplateVO[]): void
  126. }>()
  127. const dialogVisible = ref(false) // 弹窗的是否展示
  128. const dialogTitle = ref('选择优惠卷') // 弹窗的标题
  129. const formLoading = ref(false) // 表单的加载中:1)修改时的数据加载;2)提交的按钮禁用
  130. const loading = ref(true) // 列表的加载中
  131. const total = ref(0) // 列表的总页数
  132. const list = ref([]) // 字典表格数据
  133. const queryParams = reactive({
  134. pageNo: 1,
  135. pageSize: 10,
  136. name: null,
  137. discountType: null,
  138. canTakeTypes: null
  139. })
  140. const queryFormRef = ref() // 搜索的表单
  141. const selectedCouponList = ref<CouponTemplateApi.CouponTemplateVO[]>([]) // 选择的数据
  142. /** 查询列表 */
  143. const getList = async () => {
  144. loading.value = true
  145. try {
  146. // 执行查询
  147. queryParams.canTakeTypes = [props.takeType] as any
  148. const data = await CouponTemplateApi.getCouponTemplatePage(queryParams)
  149. list.value = data.list
  150. total.value = data.total
  151. } finally {
  152. loading.value = false
  153. }
  154. }
  155. /** 搜索按钮操作 */
  156. const handleQuery = () => {
  157. queryParams.pageNo = 1
  158. getList()
  159. }
  160. /** 重置按钮操作 */
  161. const resetQuery = () => {
  162. queryFormRef?.value?.resetFields()
  163. handleQuery()
  164. }
  165. /** 打开弹窗 */
  166. const open = async () => {
  167. dialogVisible.value = true
  168. resetQuery()
  169. }
  170. defineExpose({ open }) // 提供 open 方法,用于打开弹窗
  171. const handleSelectionChange = (val: CouponTemplateApi.CouponTemplateVO[]) => {
  172. if (props.multipleSelection) {
  173. emit('update:multipleSelection', val)
  174. return
  175. }
  176. selectedCouponList.value = val
  177. }
  178. const submitForm = () => {
  179. dialogVisible.value = false
  180. emit('change', selectedCouponList.value)
  181. }
  182. </script>