edit.vue 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  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-item label="所属媒体" field="media_id">
  14. <a-select v-model="formData.media_id" placeholder="请选择媒体ID" allow-clear @change="handleMediaChange">
  15. <a-option v-for="item in mediaOptions" :key="item.id" :value="item.id" :label="`[${item.id}] ${item.name}`" />
  16. </a-select>
  17. </a-form-item>
  18. </a-form>
  19. <!-- 表单信息 end -->
  20. </component>
  21. </template>
  22. <script setup>
  23. import { ref, reactive, computed } from 'vue'
  24. import tool from '@/utils/tool'
  25. import { Message } from '@arco-design/web-vue'
  26. import api from '../../api/advert/gamePackage'
  27. import advertCommonApi from '../../api/advert/common'
  28. const emit = defineEmits(['success'])
  29. // 引用定义
  30. const visible = ref(false)
  31. const loading = ref(false)
  32. const formRef = ref()
  33. const mode = ref('')
  34. const mediaOptions = ref([])
  35. const gameOptions = ref([])
  36. const gameListTree = ref([])
  37. let title = computed(() => {
  38. return '账户授权' + (mode.value == 'add' ? '-新增' : '-编辑')
  39. })
  40. // 表单初始值
  41. const initialFormData = {
  42. id: null,
  43. media_id: null,
  44. game_id: null,
  45. name: '',
  46. package_name: '',
  47. appid: '0',
  48. letter: '',
  49. }
  50. // 表单信息
  51. const formData = reactive({ ...initialFormData })
  52. // 验证规则
  53. const rules = {
  54. media_id: [{ required: true, message: '所属媒体必需选择' }],
  55. }
  56. // 打开弹框
  57. const open = async (type = 'add') => {
  58. mode.value = type
  59. // 重置表单数据
  60. Object.assign(formData, initialFormData)
  61. formRef.value.clearValidate()
  62. visible.value = true
  63. await initPage()
  64. }
  65. // 初始化页面数据
  66. const initPage = async () => {
  67. await getMediaOptions()
  68. }
  69. // 获取媒体列表Options
  70. const getMediaOptions = async () => {
  71. const res = await advertCommonApi.getMediaOptionsApi()
  72. if (res.code == 200) {
  73. mediaOptions.value = res.data
  74. }
  75. }
  76. // 设置数据
  77. const setFormData = async (data) => {
  78. for (const key in formData) {
  79. if (data[key] != null && data[key] != undefined) {
  80. formData[key] = data[key]
  81. }
  82. }
  83. }
  84. // 数据保存
  85. const submit = async (done) => {
  86. const validate = await formRef.value?.validate()
  87. if (!validate) {
  88. loading.value = true
  89. let data = { ...formData }
  90. let result = {}
  91. if (mode.value === 'add') {
  92. // 添加数据
  93. data.id = undefined
  94. result = await api.save(data)
  95. } else {
  96. // 修改数据
  97. result = await api.update(data.id, data)
  98. }
  99. if (result.code === 200) {
  100. Message.success('操作成功')
  101. emit('success')
  102. done(true)
  103. }
  104. // 防止连续点击提交
  105. setTimeout(() => {
  106. loading.value = false
  107. }, 500)
  108. }
  109. done(false)
  110. }
  111. // 关闭弹窗
  112. const close = () => (visible.value = false)
  113. defineExpose({ open, setFormData })
  114. </script>