ShareModal.vue
1.73 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
<script lang="ts" setup>
import { BasicForm, useForm } from '/@/components/Form';
import { BasicModal, useModalInner } from '/@/components/Modal';
import { FieldsEnum, schemas } from '../config/share';
import { DataBoardRecord } from '/@/api/dataBoard/model';
import { Alert } from 'ant-design-vue';
import { ref, unref } from 'vue';
import { shareBoard } from '/@/api/dataBoard';
import { ViewType } from '../config/panelDetail';
import { nextTick } from 'vue';
const loading = ref(false);
const record = ref<DataBoardRecord>({} as unknown as DataBoardRecord);
const [register, { closeModal }] = useModalInner(async (data: DataBoardRecord) => {
record.value = data;
await nextTick();
setFieldsValue({
[FieldsEnum.IS_SHARE]: data.viewType === ViewType.PUBLIC_VIEW,
[FieldsEnum.ACCESS_CREDENTIALS]: data.accessCredentials,
});
});
const [registerForm, { getFieldsValue, setFieldsValue }] = useForm({
schemas,
showActionButtonGroup: false,
layout: 'inline',
labelWidth: 120,
});
const emit = defineEmits(['register', 'success']);
const handleSubmit = async () => {
try {
loading.value = true;
const value = getFieldsValue();
const { id } = unref(record);
await shareBoard({ id, ...value });
closeModal();
emit('success');
} finally {
loading.value = false;
}
};
</script>
<template>
<BasicModal title="分享" @register="register" @ok="handleSubmit" :loading="loading">
<Alert
class="!mb-4"
type="info"
message="私有视图只有项目成员可以浏览,公开视图拥有一个公开的 URL,任何人无需登录即可浏览."
/>
<BasicForm @register="registerForm" />
</BasicModal>
</template>