CouponSelect.vue 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224
  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 label="优惠券状态" prop="status">
  37. <el-select
  38. v-model="queryParams.status"
  39. class="!w-240px"
  40. clearable
  41. placeholder="请选择优惠券状态"
  42. >
  43. <el-option
  44. v-for="dict in getIntDictOptions(DICT_TYPE.COMMON_STATUS)"
  45. :key="dict.value"
  46. :label="dict.label"
  47. :value="dict.value"
  48. />
  49. </el-select>
  50. </el-form-item>
  51. <el-form-item label="创建时间" prop="createTime">
  52. <el-date-picker
  53. v-model="queryParams.createTime"
  54. :default-time="[new Date('1 00:00:00'), new Date('1 23:59:59')]"
  55. class="!w-240px"
  56. end-placeholder="结束日期"
  57. start-placeholder="开始日期"
  58. type="daterange"
  59. value-format="YYYY-MM-DD HH:mm:ss"
  60. />
  61. </el-form-item>
  62. <el-form-item>
  63. <el-button @click="handleQuery">
  64. <Icon class="mr-5px" icon="ep:search" />
  65. 搜索
  66. </el-button>
  67. <el-button @click="resetQuery">
  68. <Icon class="mr-5px" icon="ep:refresh" />
  69. 重置
  70. </el-button>
  71. </el-form-item>
  72. </el-form>
  73. </ContentWrap>
  74. <!-- 列表 -->
  75. <ContentWrap>
  76. <el-table v-loading="loading" :data="list" @selection-change="handleSelectionChange">
  77. <el-table-column type="selection" width="55" />
  78. <el-table-column label="优惠券名称" min-width="140" prop="name" />
  79. <el-table-column label="类型" min-width="80" prop="productScope">
  80. <template #default="scope">
  81. <dict-tag :type="DICT_TYPE.PROMOTION_PRODUCT_SCOPE" :value="scope.row.productScope" />
  82. </template>
  83. </el-table-column>
  84. <el-table-column label="优惠" min-width="100" prop="discount">
  85. <template #default="scope">
  86. <dict-tag :type="DICT_TYPE.PROMOTION_DISCOUNT_TYPE" :value="scope.row.discountType" />
  87. {{ discountFormat(scope.row) }}
  88. </template>
  89. </el-table-column>
  90. <el-table-column label="领取方式" min-width="100" prop="takeType">
  91. <template #default="scope">
  92. <dict-tag :type="DICT_TYPE.PROMOTION_COUPON_TAKE_TYPE" :value="scope.row.takeType" />
  93. </template>
  94. </el-table-column>
  95. <el-table-column
  96. :formatter="validityTypeFormat"
  97. align="center"
  98. label="使用时间"
  99. prop="validityType"
  100. width="185"
  101. />
  102. <el-table-column align="center" label="发放数量" prop="totalCount" />
  103. <el-table-column
  104. :formatter="remainedCountFormat"
  105. align="center"
  106. label="剩余数量"
  107. prop="totalCount"
  108. />
  109. <el-table-column
  110. :formatter="takeLimitCountFormat"
  111. align="center"
  112. label="领取上限"
  113. prop="takeLimitCount"
  114. />
  115. <el-table-column align="center" label="状态" prop="status">
  116. <template #default="scope">
  117. <dict-tag :type="DICT_TYPE.COMMON_STATUS" :value="scope.row.status" />
  118. </template>
  119. </el-table-column>
  120. <el-table-column
  121. :formatter="dateFormatter"
  122. align="center"
  123. label="创建时间"
  124. prop="createTime"
  125. width="180"
  126. />
  127. </el-table>
  128. <!-- 分页 -->
  129. <Pagination
  130. v-model:limit="queryParams.pageSize"
  131. v-model:page="queryParams.pageNo"
  132. :total="total"
  133. @pagination="getList"
  134. />
  135. </ContentWrap>
  136. <template #footer>
  137. <el-button :disabled="formLoading" type="primary" @click="submitForm">确 定</el-button>
  138. <el-button @click="dialogVisible = false">取 消</el-button>
  139. </template>
  140. </Dialog>
  141. </template>
  142. <script lang="ts" setup>
  143. import { DICT_TYPE, getIntDictOptions } from '@/utils/dict'
  144. import {
  145. discountFormat,
  146. remainedCountFormat,
  147. takeLimitCountFormat,
  148. validityTypeFormat
  149. } from '@/views/mall/promotion/coupon/formatter'
  150. import { dateFormatter } from '@/utils/formatTime'
  151. import * as CouponTemplateApi from '@/api/mall/promotion/coupon/couponTemplate'
  152. defineOptions({ name: 'CouponSelect' })
  153. const props = defineProps<{
  154. multipleSelection?: CouponTemplateApi.CouponTemplateVO[]
  155. }>()
  156. const emit = defineEmits<{
  157. (e: 'update:multipleSelection', v: CouponTemplateApi.CouponTemplateVO[]): void
  158. (e: 'change', v: CouponTemplateApi.CouponTemplateVO[]): void
  159. }>()
  160. const dialogVisible = ref(false) // 弹窗的是否展示
  161. const dialogTitle = ref('选择优惠卷') // 弹窗的标题
  162. const formLoading = ref(false) // 表单的加载中:1)修改时的数据加载;2)提交的按钮禁用
  163. const loading = ref(true) // 列表的加载中
  164. const total = ref(0) // 列表的总页数
  165. const list = ref([]) // 字典表格数据
  166. const queryParams = reactive({
  167. pageNo: 1,
  168. pageSize: 10,
  169. name: null,
  170. status: null,
  171. discountType: null,
  172. type: null,
  173. createTime: []
  174. })
  175. const queryFormRef = ref() // 搜索的表单
  176. /** 查询列表 */
  177. const getList = async () => {
  178. loading.value = true
  179. try {
  180. // 执行查询
  181. const data = await CouponTemplateApi.getCouponTemplatePage(queryParams)
  182. list.value = data.list
  183. total.value = data.total
  184. } finally {
  185. loading.value = false
  186. }
  187. }
  188. /** 搜索按钮操作 */
  189. const handleQuery = () => {
  190. queryParams.pageNo = 1
  191. getList()
  192. }
  193. /** 重置按钮操作 */
  194. const resetQuery = () => {
  195. queryFormRef?.value?.resetFields()
  196. handleQuery()
  197. }
  198. /** 打开弹窗 */
  199. const open = async () => {
  200. dialogVisible.value = true
  201. resetQuery()
  202. }
  203. defineExpose({ open }) // 提供 open 方法,用于打开弹窗
  204. const handleSelectionChange = (val: CouponTemplateApi.CouponTemplateVO[]) => {
  205. if (props.multipleSelection) {
  206. emit('update:multipleSelection', val)
  207. return
  208. }
  209. emit('change', val)
  210. }
  211. const submitForm = () => {
  212. dialogVisible.value = false
  213. }
  214. // TODO @puhui999:提前 todo,先不用改;未来单独成组件,其它模块可以服用;例如说,满减送,可以选择优惠劵;
  215. </script>