潘志宝
2024-11-22 df90c0c5cfa4de114798015b92120ad8ba8b4826
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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
<template>
  <Dialog v-model="dialogVisible" :title="dialogTitle" width="47%">
    <div class="card" @click="openForm('ATOM')">
      <img src="../img/ATOM.png" alt="Card Image" class="card-img"/>
      <div class="card-body">
        <p class="card-title-text">{{ "原子指标" }}</p>
        <p class="card-text">{{ "从0开始创建一个新指标" }}</p>
      </div>
    </div>
    <div class="card" @click="openForm('DER')">
      <img src="../img/DER.png" alt="Card Image" class="card-img"/>
      <div class="card-body">
        <p class="card-title-text">{{ "派生指标" }}</p>
        <p class="card-text">{{ "基于单个原子指标通过条件过滤派生出的新指标" }}</p>
      </div>
    </div>
    <div class="card" @click="openForm('CAL')">
      <img src="../img/CAL.png" alt="Card Image" class="card-img"/>
      <div class="card-body">
        <p class="card-title-text">{{ "复合指标" }}</p>
        <p class="card-text">{{ "基于一组原子指标通过条件过滤派生出的新指标" }}</p>
      </div>
    </div>
  </Dialog>
  <AtomIndDefineForm ref="atomFormRef" @success="getList" />
  <DerIndDefineForm ref="derFormRef" @success="getList" />
  <CalIndDefineForm ref="calFormRef" @success="getList" />
</template>
<script lang="ts" setup>
  import * as DataSetApi from '@/api/data/ind/data/data.set'
  import AtomIndDefineForm from './AtomIndDefineForm.vue'
  import DerIndDefineForm from './DerIndDefineForm.vue'
  import CalIndDefineForm from './CalIndDefineForm.vue'
 
  defineOptions({ name: 'IndDataSetForm' })
 
  const { t } = useI18n() // 国际化
  const message = useMessage() // 消息弹窗
 
  const dialogVisible = ref(false) // 弹窗的是否展示
  const dialogTitle = ref('') // 弹窗的标题
  const formLoading = ref(false) // 表单的加载中:1)修改时的数据加载;2)提交的按钮禁用
  const formType = ref('') // 表单的类型:create - 新增;update - 修改
 
  /** 打开弹窗 */
  const open = async (type: string) => {
    dialogVisible.value = true
    dialogTitle.value = t('action.' + type)
    formType.value = type
  }
  defineExpose({ open }) // 提供 open 方法,用于打开弹窗
 
  const atomFormRef = ref()
  const derFormRef = ref()
  const calFormRef = ref()
  const openForm = (category: string) => {
    if(category === 'ATOM'){
      atomFormRef.value.open("create",null)
    }else if(category === 'DER'){
      derFormRef.value.open("create",null)
    }else if(category === 'CAL'){
      calFormRef.value.open("create",null)
    }
  }
</script>
 
<style scoped>
  .card {
    width: 25vh;
    margin: 10px 16px;
    display: inline-block;
    vertical-align: top;
    border: 1px solid #ddd;
    border-radius: 4px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
    height: 30vh;
    cursor: pointer;
  }
  .card-img {
    width: 100%;
    height: 150px;
    object-fit: cover;
  }
 
  .card-body {
    padding: 10px;
    text-align: center;
  }
  .card-title-text{
    font-size: larger;
  }
  .card-text {
    font-size: smaller;
    margin: 0;
  }
</style>