1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253 |
- <script setup lang="ts">
- import Write from './components/Write.vue'
- import { ContentDetailWrap } from '@/components/ContentDetailWrap'
- import { ref, unref } from 'vue'
- import { ElButton } from 'element-plus'
- import { useI18n } from '@/hooks/web/useI18n'
- import { useRouter } from 'vue-router'
- import { saveTableApi } from '@/api/table'
- import { useEmitt } from '@/hooks/event/useEmitt'
- const { emitter } = useEmitt()
- const { push, go } = useRouter()
- const { t } = useI18n()
- const writeRef = ref<ComponentRef<typeof Write>>()
- const loading = ref(false)
- const save = async () => {
- const write = unref(writeRef)
- const formData = await write?.submit()
- if (formData) {
- loading.value = true
- const res = await saveTableApi(formData)
- .catch(() => {})
- .finally(() => {
- loading.value = false
- })
- if (res) {
- emitter.emit('getList', 'add')
- push('/example/example-page')
- }
- }
- }
- </script>
- <template>
- <ContentDetailWrap :title="t('exampleDemo.add')" @back="push('/example/example-page')">
- <Write ref="writeRef" />
- <template #header>
- <ElButton @click="go(-1)">
- {{ t('common.back') }}
- </ElButton>
- <ElButton type="primary" :loading="loading" @click="save">
- {{ t('exampleDemo.save') }}
- </ElButton>
- </template>
- </ContentDetailWrap>
- </template>
- @/hooks/event/useEmitt
|