edit.vue 3.6 KB

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