|
@@ -18,7 +18,11 @@
|
|
|
</template>
|
|
|
</Minheader>
|
|
|
<div class="form-wrapper">
|
|
|
- <el-form :model="serviceForm" class="w100 flex-wrap">
|
|
|
+ <el-form
|
|
|
+ :model="serviceForm"
|
|
|
+ class="w100 flex-wrap"
|
|
|
+ label-width="100px"
|
|
|
+ >
|
|
|
<div class="w20 pd30">
|
|
|
<el-form-item label="名称" prop="serviceName" size="default">
|
|
|
<el-input
|
|
@@ -37,7 +41,7 @@
|
|
|
<el-option :value="4" label="业务后端" />
|
|
|
</el-select>
|
|
|
</el-form-item>
|
|
|
- <el-form-item class="isAsynchronous" size="default">
|
|
|
+ <el-form-item class="isAsynchronous" prop="isAsynchronous" size="default" label-width="0">
|
|
|
<el-select
|
|
|
v-model="serviceForm.isAsynchronous"
|
|
|
style="width: 80px"
|
|
@@ -94,15 +98,26 @@
|
|
|
</template>
|
|
|
</Minheader>
|
|
|
<div class="form-wrapper">
|
|
|
- <el-form :model="serviceForm" class="w100 flex-wrap">
|
|
|
+ <el-form
|
|
|
+ :model="serviceForm"
|
|
|
+ class="w100 flex-wrap"
|
|
|
+ label-width="100px"
|
|
|
+ >
|
|
|
<div class="w20 pd30">
|
|
|
- <el-form-item label="数据源" prop="dataSourceID" size="default">
|
|
|
+ <el-form-item
|
|
|
+ v-if="selectOptionMap[queryTemplateIDMap.dataSourceID]"
|
|
|
+ label="数据源"
|
|
|
+ prop="dataSourceID"
|
|
|
+ size="default"
|
|
|
+ >
|
|
|
<el-select v-model="serviceForm.dataSourceID" clearable>
|
|
|
<el-option
|
|
|
- v-for="dataSource in dataSourceList"
|
|
|
- :key="dataSource.dataSourceID"
|
|
|
- :value="dataSource.dataSourceID"
|
|
|
- :label="dataSource.dataSourceName"
|
|
|
+ v-for="option in selectOptionMap[
|
|
|
+ queryTemplateIDMap.dataSourceID
|
|
|
+ ]"
|
|
|
+ :key="option[option.setvalue]"
|
|
|
+ :value="option[option.setvalue]"
|
|
|
+ :label="option[option.setlabel]"
|
|
|
/>
|
|
|
</el-select>
|
|
|
</el-form-item>
|
|
@@ -194,7 +209,11 @@
|
|
|
</template>
|
|
|
</Minheader>
|
|
|
<div class="form-wrapper">
|
|
|
- <el-form :model="serviceForm" class="w100 flex-wrap">
|
|
|
+ <el-form
|
|
|
+ :model="serviceForm"
|
|
|
+ class="w100 flex-wrap"
|
|
|
+ label-width="100px"
|
|
|
+ >
|
|
|
<div class="w50 pd30">
|
|
|
<el-form-item
|
|
|
label="生命周期编号"
|
|
@@ -282,19 +301,26 @@
|
|
|
</template>
|
|
|
</Minheader>
|
|
|
<div class="form-wrapper">
|
|
|
- <el-form :model="serviceForm" class="w100 flex-wrap">
|
|
|
+ <el-form
|
|
|
+ :model="serviceForm"
|
|
|
+ class="w100 flex-wrap"
|
|
|
+ label-width="110px"
|
|
|
+ >
|
|
|
<div class="w50 pd30">
|
|
|
<el-form-item
|
|
|
+ v-if="selectOptionMap[queryTemplateIDMap.dataSourceID]"
|
|
|
label="日志存储数据源"
|
|
|
prop="logDataSourceID"
|
|
|
size="default"
|
|
|
>
|
|
|
<el-select v-model="serviceForm.logDataSourceID">
|
|
|
<el-option
|
|
|
- v-for="dataSource in dataSourceList"
|
|
|
- :key="dataSource.dataSourceID"
|
|
|
- :value="dataSource.dataSourceID"
|
|
|
- :label="dataSource.dataSourceName"
|
|
|
+ v-for="option in selectOptionMap[
|
|
|
+ queryTemplateIDMap.dataSourceID
|
|
|
+ ]"
|
|
|
+ :key="option[option.setvalue]"
|
|
|
+ :value="option[option.setvalue]"
|
|
|
+ :label="option[option.setlabel]"
|
|
|
/>
|
|
|
</el-select>
|
|
|
</el-form-item>
|
|
@@ -478,6 +504,8 @@
|
|
|
:table-data="slotTableData"
|
|
|
:table-btn-group="slotTableButtonGroups"
|
|
|
selection-enable
|
|
|
+ :table-property="{ headerCellClassName: 'hide-header-check' }"
|
|
|
+ class="slot-table"
|
|
|
@select="slotSelectHandler"
|
|
|
@btnClick="slotTableButtonClickHandler"
|
|
|
/>
|
|
@@ -490,20 +518,12 @@
|
|
|
@reset-form="editSlotDialogHide"
|
|
|
>
|
|
|
<div class="form-wrapper">
|
|
|
- <el-form :model="soltForm">
|
|
|
- <el-form-item label="插槽名称" prop="deployNodeName" size="default">
|
|
|
- <el-input
|
|
|
- v-model="soltForm.deployNodeName"
|
|
|
- placeholder="请输入插槽名称"
|
|
|
- />
|
|
|
- </el-form-item>
|
|
|
- <el-form-item label="插槽地址" prop="serviceURL" size="default">
|
|
|
- <el-input
|
|
|
- v-model="soltForm.serviceURL"
|
|
|
- placeholder="请输入插槽地址"
|
|
|
- />
|
|
|
- </el-form-item>
|
|
|
- </el-form>
|
|
|
+ <AutoForm
|
|
|
+ :model="slotForm"
|
|
|
+ :items="slotTableColumns"
|
|
|
+ :select-option-map="selectOptionMap"
|
|
|
+ label-width="100px"
|
|
|
+ />
|
|
|
</div>
|
|
|
</Dialog>
|
|
|
<Dialog
|
|
@@ -517,68 +537,11 @@
|
|
|
@del-rest="outputDialogHide"
|
|
|
>
|
|
|
<div class="form-wrapper">
|
|
|
- <el-form :model="outputForm">
|
|
|
- <el-row :gutter="24">
|
|
|
- <el-col>
|
|
|
- <el-form-item
|
|
|
- label="输出数据源"
|
|
|
- prop="dataSourceID"
|
|
|
- size="default"
|
|
|
- >
|
|
|
- <el-select v-model="outputForm.dataSourceID" class="w100">
|
|
|
- <el-option
|
|
|
- v-for="dataSource in dataSourceList"
|
|
|
- :key="dataSource.dataSourceID"
|
|
|
- :value="dataSource.dataSourceID"
|
|
|
- :label="dataSource.dataSourceName"
|
|
|
- />
|
|
|
- </el-select>
|
|
|
- </el-form-item>
|
|
|
- </el-col>
|
|
|
- <el-col>
|
|
|
- <el-form-item
|
|
|
- label="详细位置"
|
|
|
- prop="sourceObjectName"
|
|
|
- size="default"
|
|
|
- >
|
|
|
- <el-input
|
|
|
- v-model="outputForm.sourceObjectName"
|
|
|
- placeholder="请输入详细位置"
|
|
|
- clearable
|
|
|
- />
|
|
|
- </el-form-item>
|
|
|
- </el-col>
|
|
|
- <el-col>
|
|
|
- <el-form-item
|
|
|
- label="数据结构"
|
|
|
- prop="dataStructureID"
|
|
|
- size="default"
|
|
|
- >
|
|
|
- <el-select v-model="outputForm.dataStructureID" class="w100">
|
|
|
- <el-option
|
|
|
- v-for="dataStructure in dataStructureList"
|
|
|
- :key="dataStructure.dataStructureID"
|
|
|
- :value="dataStructure.dataStructureID"
|
|
|
- :label="dataStructure.structureName"
|
|
|
- />
|
|
|
- </el-select>
|
|
|
- </el-form-item>
|
|
|
- </el-col>
|
|
|
- <el-col>
|
|
|
- <el-form-item
|
|
|
- label="输出条件"
|
|
|
- prop="outputCondition"
|
|
|
- size="default"
|
|
|
- >
|
|
|
- <el-input
|
|
|
- v-model="outputForm.outputCondition"
|
|
|
- placeholder="请输入输出条件"
|
|
|
- clearable
|
|
|
- />
|
|
|
- </el-form-item>
|
|
|
- </el-col>
|
|
|
- </el-row>
|
|
|
- </el-form>
|
|
|
+ <AutoForm
|
|
|
+ :model="outputForm"
|
|
|
+ :items="outputTableColumns"
|
|
|
+ :select-option-map="selectOptionMap"
|
|
|
+ />
|
|
|
</div>
|
|
|
</Dialog>
|
|
|
</div>
|
|
@@ -588,32 +551,34 @@
|
|
|
import Minheader from '@/components/minheader/index.vue'
|
|
|
import DataTable from '@/components/tableTemp/index.vue'
|
|
|
import Dialog from '@/components/dialog/index.vue'
|
|
|
-import { CommonTableColumn, SelectOptionQueryResult } from '~/common'
|
|
|
+import AutoForm from '../components/AutoForm.vue'
|
|
|
+import {
|
|
|
+ CommonTableColumn,
|
|
|
+ SelectOptionQueryResult,
|
|
|
+ SelectOption,
|
|
|
+ FormData,
|
|
|
+} from '~/common'
|
|
|
import { ElMessage } from 'element-plus'
|
|
|
import { Query, GeneralDataReception } from '@/api/webApi'
|
|
|
|
|
|
-interface DataSource {
|
|
|
- dataSourceID: string | number
|
|
|
- dataSourceName: string
|
|
|
-}
|
|
|
-interface DataStructure {
|
|
|
- dataStructureID: string | number
|
|
|
- structureName: string
|
|
|
-}
|
|
|
-
|
|
|
-// 数据源列表
|
|
|
-const dataSourceList = ref<DataSource[]>([])
|
|
|
-const getDataSourceList = async () => {
|
|
|
- dataSourceList.value = (await getSelectOptions(
|
|
|
- DATACONTENT_ID.dataSourceOptions
|
|
|
- )) as DataSource[]
|
|
|
-}
|
|
|
-// 数据结构列表
|
|
|
-const dataStructureList = ref<DataStructure[]>([])
|
|
|
-const getDataStructureList = async () => {
|
|
|
- dataStructureList.value = (await getSelectOptions(
|
|
|
- DATACONTENT_ID.dataStructOptions
|
|
|
- )) as DataStructure[]
|
|
|
+const queryTemplateIDMap = reactive<{
|
|
|
+ [x: string]: number
|
|
|
+}>({})
|
|
|
+const selectOptionMap = reactive<{
|
|
|
+ [id: number]: SelectOption[]
|
|
|
+}>({})
|
|
|
+const getSelectOptionOfColumn = (columns: CommonTableColumn[]) => {
|
|
|
+ columns.forEach(async ({ columnName, listqueryTemplateID }) => {
|
|
|
+ if (listqueryTemplateID !== null && !queryTemplateIDMap[columnName]) {
|
|
|
+ queryTemplateIDMap[columnName] = listqueryTemplateID
|
|
|
+ if (!selectOptionMap[listqueryTemplateID]) {
|
|
|
+ selectOptionMap[listqueryTemplateID] = []
|
|
|
+ selectOptionMap[listqueryTemplateID] = await getSelectOptions(
|
|
|
+ listqueryTemplateID
|
|
|
+ )
|
|
|
+ }
|
|
|
+ }
|
|
|
+ })
|
|
|
}
|
|
|
const getSelectOptions = async (id: number) => {
|
|
|
try {
|
|
@@ -628,9 +593,13 @@ const getSelectOptions = async (id: number) => {
|
|
|
if (Number(code) !== 0) {
|
|
|
throw new Error(message ?? '失败')
|
|
|
}
|
|
|
- const options = listValues.map(item => ({
|
|
|
- [item.setlabel]: item.k,
|
|
|
- [item.setvalue]: item.v,
|
|
|
+ const options = listValues.map(({ k, v, setlabel, setvalue }) => ({
|
|
|
+ k,
|
|
|
+ v,
|
|
|
+ setlabel,
|
|
|
+ setvalue,
|
|
|
+ [setlabel]: k,
|
|
|
+ [setvalue]: v,
|
|
|
}))
|
|
|
return options
|
|
|
} catch (error) {
|
|
@@ -638,10 +607,6 @@ const getSelectOptions = async (id: number) => {
|
|
|
return []
|
|
|
}
|
|
|
}
|
|
|
-onMounted(() => {
|
|
|
- getDataSourceList()
|
|
|
- getDataStructureList()
|
|
|
-})
|
|
|
|
|
|
const route = useRoute()
|
|
|
const serviceID = Number(route.query.serviceID)
|
|
@@ -753,6 +718,7 @@ const getOutputTable = async () => {
|
|
|
if (Number(code) !== 0) {
|
|
|
throw new Error(message ?? '失败')
|
|
|
}
|
|
|
+ getSelectOptionOfColumn(columnSet)
|
|
|
outputTableColumns.value = columnSet
|
|
|
outputTableData.value = listValues
|
|
|
} catch (error) {
|
|
@@ -794,7 +760,10 @@ const outputDialogVisible = ref(false)
|
|
|
const outputDialogType = ref('')
|
|
|
const outputDialogTitle = ref('')
|
|
|
const serviceOutputID = ref<string | number>()
|
|
|
-const outputDialogShow = (operate: number = 1, row: any) => {
|
|
|
+const outputDialogShow = (
|
|
|
+ operate: number = 1,
|
|
|
+ row: { [x: string]: string | number | null }
|
|
|
+) => {
|
|
|
switch (operate) {
|
|
|
case 1:
|
|
|
outputDialogType.value = 'add'
|
|
@@ -803,29 +772,17 @@ const outputDialogShow = (operate: number = 1, row: any) => {
|
|
|
case 2:
|
|
|
outputDialogType.value = 'edit'
|
|
|
outputDialogTitle.value = '编辑输出'
|
|
|
- Object.keys(outputForm).forEach(key => {
|
|
|
- switch (key) {
|
|
|
- case 'dataSourceID': {
|
|
|
- const dataSource = dataSourceList.value.find(
|
|
|
- dataSource => dataSource.dataSourceName === row.dataSourceName
|
|
|
- )
|
|
|
- if (dataSource) {
|
|
|
- outputForm[key] = dataSource[key]
|
|
|
- }
|
|
|
- break
|
|
|
- }
|
|
|
- case 'dataStructureID': {
|
|
|
- const dataStructure = dataStructureList.value.find(
|
|
|
- dataStructure => dataStructure.structureName === row.structureName
|
|
|
- )
|
|
|
- if (dataStructure) {
|
|
|
- outputForm[key] = dataStructure[key]
|
|
|
- }
|
|
|
- break
|
|
|
+ Object.entries(row).forEach(([key, value]) => {
|
|
|
+ const column = outputTableColumns.value.find(
|
|
|
+ column => column.columnName === key
|
|
|
+ )
|
|
|
+ outputForm[key] = value
|
|
|
+ if (typeof column?.listqueryTemplateID === 'number') {
|
|
|
+ const selectOptions = selectOptionMap[column.listqueryTemplateID]
|
|
|
+ const option = selectOptions.find(option => option.k === value)
|
|
|
+ if (option) {
|
|
|
+ outputForm[option.setvalue] = option.v
|
|
|
}
|
|
|
- default:
|
|
|
- outputForm[key] = row[key]
|
|
|
- break
|
|
|
}
|
|
|
})
|
|
|
break
|
|
@@ -841,18 +798,11 @@ const outputDialogShow = (operate: number = 1, row: any) => {
|
|
|
}
|
|
|
const outputDialogHide = () => {
|
|
|
outputDialogVisible.value = false
|
|
|
+ Object.keys(outputForm).forEach(key => {
|
|
|
+ outputForm[key] = null
|
|
|
+ })
|
|
|
}
|
|
|
-const outputForm = reactive<{
|
|
|
- dataSourceID: string | number | null
|
|
|
- sourceObjectName: string
|
|
|
- dataStructureID: string | number | null
|
|
|
- outputCondition: string
|
|
|
-}>({
|
|
|
- dataSourceID: null,
|
|
|
- sourceObjectName: '',
|
|
|
- dataStructureID: null,
|
|
|
- outputCondition: '',
|
|
|
-})
|
|
|
+const outputForm = reactive<FormData>({})
|
|
|
const outputSubmitHandler = async () => {
|
|
|
try {
|
|
|
const dataContent = {}
|
|
@@ -879,12 +829,15 @@ const outputSubmitHandler = async () => {
|
|
|
default:
|
|
|
break
|
|
|
}
|
|
|
+ console.log(dataContent)
|
|
|
+ return
|
|
|
const { code, message } = await GeneralDataReception({
|
|
|
- serviceID: SERVICE_ID.sysServiceOutTable,
|
|
|
+ serviceID: DATACONTENT_ID.sysServiceOutTable,
|
|
|
dataContent: JSON.stringify(dataContent),
|
|
|
})
|
|
|
if (Number(code) === 0) {
|
|
|
ElMessage.success(message ?? '成功')
|
|
|
+ outputDialogHide()
|
|
|
} else {
|
|
|
throw new Error(message ?? '失败')
|
|
|
}
|
|
@@ -995,6 +948,7 @@ const getSlotTable = async () => {
|
|
|
if (Number(code) !== 0) {
|
|
|
throw new Error(message ?? '失败')
|
|
|
}
|
|
|
+ getSelectOptionOfColumn(columnSet)
|
|
|
slotTableColumns.value = columnSet
|
|
|
slotTableData.value = listValues
|
|
|
} catch (error) {
|
|
@@ -1033,10 +987,7 @@ const editSlotDialogShow = () => {
|
|
|
const editSlotDialogHide = () => {
|
|
|
editSlotDialogVisible.value = false
|
|
|
}
|
|
|
-const soltForm = reactive({
|
|
|
- deployNodeName: '',
|
|
|
- serviceURL: '',
|
|
|
-})
|
|
|
+const slotForm = reactive<FormData>({})
|
|
|
const editSlotSubmitHandler = () => {
|
|
|
editSlotDialogHide()
|
|
|
}
|
|
@@ -1097,9 +1048,6 @@ const logCopy = index => {
|
|
|
box-shadow: 0px 3px 3px 0px rgba(0, 0, 0, 0.1);
|
|
|
border-radius: 4px;
|
|
|
padding: 24px;
|
|
|
- :deep .el-form-item__label {
|
|
|
- width: 110px;
|
|
|
- }
|
|
|
}
|
|
|
|
|
|
.form-wrapper {
|
|
@@ -1131,13 +1079,17 @@ const logCopy = index => {
|
|
|
height: 170px;
|
|
|
}
|
|
|
|
|
|
-:deep .el-form-item__label {
|
|
|
- width: 100px;
|
|
|
-}
|
|
|
.interfaceLog {
|
|
|
padding: 0 24px 24px 24px;
|
|
|
}
|
|
|
.logcont {
|
|
|
padding: 0 24px 0px 24px;
|
|
|
}
|
|
|
+:deep
|
|
|
+ .slot-table
|
|
|
+ .el-table__header
|
|
|
+ .el-table__cell.hide-header-check:first-child
|
|
|
+ .el-checkbox {
|
|
|
+ display: none;
|
|
|
+}
|
|
|
</style>
|