| | |
| | | :rules="formRules" label-width="100px"> |
| | | <el-row> |
| | | <el-col :span="12"> |
| | | <el-form-item label="指标编码" prop="itemNo"> |
| | | <el-input v-model="formData.itemNo" disabled/> |
| | | </el-form-item> |
| | | </el-col> |
| | | <el-col :span="12"> |
| | | <el-form-item label="指标名称" prop="itemName"> |
| | | <el-input v-model="formData.itemName"/> |
| | | </el-form-item> |
| | | </el-col> |
| | | </el-row> |
| | | <el-row> |
| | | <el-col :span="12"> |
| | | <el-form-item label="原子指标" prop="atomItem.itemId"> |
| | | <el-select v-model="formData.atomItem.itemId" clearable placeholder="请选择原子指标" |
| | | <el-select v-model="formData.atomItem.itemId" filterable |
| | | allow-create clearable placeholder="请选择原子指标" |
| | | @change="handleChange($event)"> |
| | | <el-option |
| | | v-for="item in atomItemList" |
| | |
| | | </el-row> |
| | | <el-row> |
| | | <el-col :span="12"> |
| | | <el-form-item label="指标编码" prop="itemNo"> |
| | | <el-input v-model="formData.itemNo" disabled/> |
| | | </el-form-item> |
| | | </el-col> |
| | | <el-col :span="12"> |
| | | <el-form-item label="指标名称" prop="itemName"> |
| | | <el-input v-model="formData.itemName"/> |
| | | </el-form-item> |
| | | </el-col> |
| | | </el-row> |
| | | <el-row> |
| | | <el-col :span="12"> |
| | | <el-form-item label="指标分类" prop="itemCategory"> |
| | | <el-select v-model="formData.itemCategory" clearable placeholder="请选择指标分类"> |
| | | <el-option |
| | | v-for="item in dataCategoryList" |
| | | :key="item.id" |
| | | :label="item.label" |
| | | :value="item.id + ''" |
| | | /> |
| | | </el-select> |
| | | <el-tree-select |
| | | v-model="formData.itemCategory" |
| | | :data="dataCategoryList" |
| | | :default-expanded-keys="[0]" |
| | | :props="defaultProps" |
| | | check-strictly |
| | | node-key="id" |
| | | /> |
| | | </el-form-item> |
| | | </el-col> |
| | | <el-col :span="12"> |
| | |
| | | <el-row> |
| | | <el-col :span="6"> |
| | | <el-form-item label="时间标识" prop="timeLabel"> |
| | | <el-select v-model="formData.derItem.timeLabel" clearable placeholder="请选择时间标识"> |
| | | <el-select v-model="formData.derItem.timeLabel" allow-create filterable clearable placeholder="请选择时间标识"> |
| | | <el-option |
| | | v-for="item in dataSetFieldList" |
| | | :key="item.id" |
| | | :label="item.fieldCode" |
| | | :value="item.id + ''" |
| | | :value="item.fieldCode" |
| | | /> |
| | | </el-select> |
| | | </el-form-item> |
| | |
| | | <el-row> |
| | | <el-col :span="24"> |
| | | <el-form-item label="分析维度" prop="dimension"> |
| | | <el-select v-model="formData.derItem.dimension" clearable placeholder="请选择分析维度" multiple> |
| | | <el-select v-model="formData.derItem.dimension" filterable |
| | | allow-create clearable placeholder="请选择分析维度" multiple> |
| | | <el-option |
| | | v-for="item in dataSetFieldList" |
| | | :key="item.id" |
| | | :label="item.fieldCode" |
| | | :value="item.id + ''" |
| | | :value="item.fieldCode" |
| | | /> |
| | | </el-select> |
| | | </el-form-item> |
| | |
| | | import {PageParam} from "@/api/data/ind/item/item"; |
| | | import * as CategoryApi from "@/api/data/ind/category"; |
| | | import * as DataSetFieldApi from "@/api/data/ind/data/data.field"; |
| | | import {handleTree} from "@/utils/tree"; |
| | | |
| | | defineOptions({name: 'IndDataSetForm'}) |
| | | |
| | |
| | | const formRef = ref() // 表单 Ref |
| | | const atomItemList = ref([] as ItemApi.ItemVO[]) |
| | | const showTimeChange = ref(false) |
| | | const dataCategoryList = ref([] as CategoryApi.IndItemCategoryVO[]) |
| | | const dataSetFieldList = ref([] as DataSetFieldApi.DataSetFieldVO[]) |
| | | const dataCategoryList = ref<Tree[]>([]) |
| | | |
| | | const getCategoryTree = async () => { |
| | | dataCategoryList.value = [] |
| | | const res = await CategoryApi.getCategoryListAllSimple() |
| | | let category: Tree = {id: 0, label: '主类目', children: []} |
| | | category.children = handleTree(res, 'id', 'pid') |
| | | dataCategoryList.value.push(category) |
| | | } |
| | | /** 打开弹窗 */ |
| | | const open = async (type: string, id?: string) => { |
| | | dialogVisible.value = true |
| | |
| | | formType.value = type |
| | | resetForm() |
| | | // 加载数据源列表 |
| | | dataCategoryList.value = await CategoryApi.getCategoryListAllSimple() |
| | | await getCategoryTree() |
| | | const queryParams = reactive({ |
| | | itemType: 'ATOM' |
| | | }) |
| | |
| | | }else { |
| | | formData.value.derItem.dimension = "" |
| | | } |
| | | showTimeChange.value = formData.value.derItem.timeLimit === 'CUSTOM' |
| | | await handleChange(formData.value.derItem.atomItemId) |
| | | } finally { |
| | | formLoading.value = false |