edit.vue 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  1. <template>
  2. <component
  3. is="a-modal"
  4. :width="tool.getDevice() === 'mobile' ? '100%' : '600px'"
  5. v-model:visible="visible"
  6. :title="title"
  7. :mask-closable="false"
  8. :ok-loading="loading"
  9. @cancel="close"
  10. @before-ok="submit">
  11. <!-- 表单信息 start -->
  12. <a-form ref="formRef" :model="formData" :rules="rules" :auto-label-width="true"> </a-form>
  13. <!-- 表单信息 end -->
  14. </component>
  15. </template>
  16. <script setup>
  17. import { ref, reactive, computed } from 'vue'
  18. import tool from '@/utils/tool'
  19. import { Message, Modal } from '@arco-design/web-vue'
  20. import api from '../../api/customer/sdkOrder'
  21. const emit = defineEmits(['success'])
  22. // 引用定义
  23. const visible = ref(false)
  24. const loading = ref(false)
  25. const formRef = ref()
  26. const mode = ref('')
  27. let title = computed(() => {
  28. return '用户订单记录' + (mode.value == 'add' ? '-新增' : '-编辑')
  29. })
  30. // 表单初始值
  31. const initialFormData = {
  32. id: null,
  33. }
  34. // 表单信息
  35. const formData = reactive({ ...initialFormData })
  36. // 验证规则
  37. const rules = {
  38. order_id: [{ required: true, message: '订单号必需填写' }],
  39. cp_order_id: [{ required: true, message: '研发订单号必需填写' }],
  40. pay_channel: [{ required: true, message: '充值方式必需填写' }],
  41. money: [{ required: true, message: '金额必需填写' }],
  42. paid_amount: [{ required: true, message: '净额必需填写' }],
  43. game_id: [{ required: true, message: '充值游戏必需填写' }],
  44. media_id: [{ required: true, message: '媒体ID必需填写' }],
  45. auth_id: [{ required: true, message: '负责人ID必需填写' }],
  46. agent_id: [{ required: true, message: '渠道ID必需填写' }],
  47. site_id: [{ required: true, message: '广告位ID必需填写' }],
  48. uid: [{ required: true, message: 'UID必需填写' }],
  49. user_name: [{ required: true, message: '充值账号必需填写' }],
  50. user_ip: [{ required: true, message: '充值IP必需填写' }],
  51. server_id: [{ required: true, message: '服务器ID必需填写' }],
  52. server_name: [{ required: true, message: '充值区服必需填写' }],
  53. role_name: [{ required: true, message: '角色名必需填写' }],
  54. payname: [{ required: true, message: '必需填写' }],
  55. pay_date: [{ required: true, message: '支付时间必需填写' }],
  56. sync_status: [{ required: true, message: '支付状态必需填写' }],
  57. send_status: [{ required: true, message: '发货状态必需填写' }],
  58. product_name: [{ required: true, message: '充值商品名必需填写' }],
  59. }
  60. // 打开弹框
  61. const open = async (type = 'add') => {
  62. mode.value = type
  63. // 重置表单数据
  64. Object.assign(formData, initialFormData)
  65. formRef.value.clearValidate()
  66. visible.value = true
  67. await initPage()
  68. }
  69. // 初始化页面数据
  70. const initPage = async () => {}
  71. // 设置数据
  72. const setFormData = async (data) => {
  73. for (const key in formData) {
  74. if (data[key] != null && data[key] != undefined) {
  75. formData[key] = data[key]
  76. }
  77. }
  78. }
  79. // 数据保存
  80. const submit = async (done) => {
  81. const validate = await formRef.value?.validate()
  82. if (!validate) {
  83. loading.value = true
  84. let data = { ...formData }
  85. let result = {}
  86. if (mode.value === 'add') {
  87. // 添加数据
  88. data.id = undefined
  89. result = await api.save(data)
  90. } else {
  91. // 修改数据
  92. result = await api.update(data.id, data)
  93. }
  94. if (result.code === 200) {
  95. Message.success('操作成功')
  96. emit('success')
  97. done(true)
  98. }
  99. // 防止连续点击提交
  100. setTimeout(() => {
  101. loading.value = false
  102. }, 500)
  103. }
  104. done(false)
  105. }
  106. // 关闭弹窗
  107. const close = () => (visible.value = false)
  108. defineExpose({ open, setFormData })
  109. </script>