潘志宝
6 天以前 adf924e3be3e5d5e7a1f12ae2a2684f7d856f003
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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
<template>
  <Dialog v-model="dialogVisible" :title="dialogTitle">
    <el-form
      ref="formRef"
      :model="formData"
      :rules="formRules"
      label-width="0px"
    >
      <el-form-item prop="pyName">
        <el-input v-model="formData.pyName" readonly />
      </el-form-item>
      <el-form-item prop="remark">
        <el-input
          type="textarea"
          :rows="4"
          placeholder="备注"
          v-model="formData.remark"/>
      </el-form-item>
    </el-form>
    <div style="width: 100%;display: flex;flex-direction: row;justify-content: end;margin-top: 16px">
      <el-button :loading="loading" @click="generatorCode()" type="primary">生成</el-button>
    </div>
  </Dialog>
</template>
<script lang="ts" setup>
  import * as MpkApi from '@/api/model/mpk/mpk'
  import download from "@/utils/download";
  import {formatToDateString} from "@/utils/dateUtil";
 
 
  const { t } = useI18n() // 国际化
  const message = useMessage() // 消息弹窗
 
  const dialogVisible = ref(false) // 弹窗的是否展示
  const dialogTitle = ref('生成代码') // 弹窗的标题
 
  const formData = ref({
    id: undefined,
    pyName: '',
    zipFileName: '',
    remark: ''
  })
  const formRules = reactive({
  })
  const formRef = ref()
 
  /** 打开弹窗 */
  const open = async (modelId: string,pyName: string) => {
    dialogVisible.value = true
    resetForm()
    formData.value.id = modelId
    formData.value.pyName = pyName
    formData.value.zipFileName = pyName + '_' + formatToDateString(new Date()) + '.zip';
  }
  defineExpose({ open }) // 提供 open 方法,用于打开弹窗
 
  // 代码生成loading
  const loading = ref(false)
  /** 提交表单 */
  const generatorCode = async () => {
    try {
      loading.value = true
      const data = await MpkApi.generatorCode(formData.value)
      download.zip(data, formData.value.zipFileName)
    }finally {
      loading.value = false
      dialogVisible.value = false
    }
 
  }
  /** 重置表单 */
  const resetForm = () => {
    formData.value = {
      id: undefined,
      zipFileName: '',
      remark: ''
    }
    formRef.value?.resetFields()
  }
</script>