ExampleAdd.vue 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. <script setup lang="ts">
  2. import Write from './components/Write.vue'
  3. import { ContentWrap } from '@/components/ContentWrap'
  4. import { ref, unref } from 'vue'
  5. import { ElButton } from 'element-plus'
  6. import { useI18n } from '@/hooks/web/useI18n'
  7. import { useRouter } from 'vue-router'
  8. import { saveTableApi } from '@/api/table'
  9. import { TableData } from '@/api/table/types'
  10. import { useEmitt } from '@/hooks/web/useEmitt'
  11. const { emitter } = useEmitt()
  12. const { push } = useRouter()
  13. const { t } = useI18n()
  14. const writeRef = ref<ComponentRef<typeof Write>>()
  15. const loading = ref(false)
  16. const save = async () => {
  17. const write = unref(writeRef)
  18. const validate = await write?.elFormRef?.validate()?.catch(() => {})
  19. if (validate) {
  20. loading.value = true
  21. const data = (await write?.getFormData()) as TableData
  22. const res = await saveTableApi({
  23. data
  24. })
  25. .catch(() => {})
  26. .finally(() => {
  27. loading.value = false
  28. })
  29. if (res) {
  30. emitter.emit('getList', 'add')
  31. push('/example/example-page')
  32. }
  33. }
  34. }
  35. </script>
  36. <template>
  37. <ContentWrap :title="t('exampleDemo.add')">
  38. <Write ref="writeRef" />
  39. <div class="text-center">
  40. <ElButton type="primary" :loading="loading" @click="save">
  41. {{ t('exampleDemo.save') }}
  42. </ElButton>
  43. <ElButton @click="push('/example/example-page')">{{ t('dialogDemo.close') }}</ElButton>
  44. </div>
  45. </ContentWrap>
  46. </template>