CouponSelect.vue 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192
  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. import { CouponTemplateTakeTypeEnum } from '@/utils/constants'
  119. defineOptions({ name: 'CouponSelect' })
  120. const props = defineProps<{
  121. multipleSelection?: CouponTemplateApi.CouponTemplateVO[]
  122. takeType: number // 领取方式
  123. }>()
  124. const emit = defineEmits<{
  125. (e: 'update:multipleSelection', v: CouponTemplateApi.CouponTemplateVO[]): void
  126. (e: 'change', v: CouponTemplateApi.CouponTemplateVO[]): void
  127. }>()
  128. const dialogVisible = ref(false) // 弹窗的是否展示
  129. const dialogTitle = ref('选择优惠劵') // 弹窗的标题
  130. const formLoading = ref(false) // 表单的加载中:1)修改时的数据加载;2)提交的按钮禁用
  131. const loading = ref(true) // 列表的加载中
  132. const total = ref(0) // 列表的总页数
  133. const list = ref([]) // 字典表格数据
  134. const queryParams = reactive({
  135. pageNo: 1,
  136. pageSize: 10,
  137. name: null,
  138. discountType: null,
  139. canTakeTypes: [CouponTemplateTakeTypeEnum.USER.type] // 只获得直接领取的券
  140. })
  141. const queryFormRef = ref() // 搜索的表单
  142. const selectedCouponList = ref<CouponTemplateApi.CouponTemplateVO[]>([]) // 选择的数据
  143. /** 查询列表 */
  144. const getList = async () => {
  145. loading.value = true
  146. try {
  147. // 执行查询
  148. queryParams.canTakeTypes = [props.takeType] as any
  149. const data = await CouponTemplateApi.getCouponTemplatePage(queryParams)
  150. list.value = data.list
  151. total.value = data.total
  152. } finally {
  153. loading.value = false
  154. }
  155. }
  156. /** 搜索按钮操作 */
  157. const handleQuery = () => {
  158. queryParams.pageNo = 1
  159. getList()
  160. }
  161. /** 重置按钮操作 */
  162. const resetQuery = () => {
  163. queryFormRef?.value?.resetFields()
  164. handleQuery()
  165. }
  166. /** 打开弹窗 */
  167. const open = async () => {
  168. dialogVisible.value = true
  169. resetQuery()
  170. }
  171. defineExpose({ open }) // 提供 open 方法,用于打开弹窗
  172. const handleSelectionChange = (val: CouponTemplateApi.CouponTemplateVO[]) => {
  173. if (props.multipleSelection) {
  174. emit('update:multipleSelection', val)
  175. return
  176. }
  177. selectedCouponList.value = val
  178. }
  179. const submitForm = () => {
  180. dialogVisible.value = false
  181. emit('change', selectedCouponList.value)
  182. }
  183. </script>