| | |
| | | <template> |
| | | <el-dialog title="数据点" v-model="visible" :width="'80%'" destroy-on-close @closed="$emit('closed')"> |
| | | <p style="margin-bottom: 14px;"> |
| | | <p style="margin-bottom: 14px;display: flex;align-items: center;"> |
| | | <span style="margin-right: 8px;">类型</span> |
| | | <el-select v-model="type" placeholder="Select" size="small" style="width: 240px" @change="changeType"> |
| | | <el-select v-model="type" placeholder="类型" size="small" style="width: 240px" @change="changeType"> |
| | | <el-option v-for="item in typeList" :key="item.id" :label="item.name" :value="item.id" /> |
| | | </el-select> |
| | | <span style="margin-right: 8px;margin-left: auto;">IOT应用ID</span> |
| | | <el-input v-model="appId" placeholder="IOT应用ID" style="width: 240px"></el-input> |
| | | </p> |
| | | |
| | | <scFormTable v-show="type" ref="table1" v-model="tabledata" stripe hideDelete :hideAdd="!type" |
| | |
| | | <template #default="scope"> |
| | | <el-button-group> |
| | | <el-button text type="primary" size="small" @click="table_edit(scope.row)">编辑</el-button> |
| | | <!-- <el-button text type="primary" size="small">复制</el-button> --> |
| | | <el-button text type="primary" size="small" @click="copy(scope.row)">复制</el-button> |
| | | <el-popconfirm width="220" title="确定将选择的数据删除" @confirm="del(scope.$index)"> |
| | | <template #reference> |
| | | <el-button text type="primary" size="small">删除</el-button> |
| | |
| | | status: '2' // 不存在已保存 1: 正在编辑 2: 新增 |
| | | }, |
| | | type: '', |
| | | typeList: [] |
| | | |
| | | typeList: [], |
| | | appId: '' |
| | | } |
| | | }, |
| | | created() { |
| | |
| | | }, |
| | | methods: { |
| | | changeType(val) { |
| | | this.$confirm(`切换类型将删除所有已配置数据点`, '提示', { |
| | | type: 'warning' |
| | | }).then(() => { |
| | | if (this.tabledata.length > 0) { |
| | | this.$confirm(`切换类型将删除所有已配置数据点`, '提示', { |
| | | type: 'warning' |
| | | }).then(() => { |
| | | try { |
| | | this.cols = JSON.parse(this.typeList.find(v => v.id === val).dpHeadFull) |
| | | this.tabledata = [] |
| | | } catch (error) { |
| | | this.cols = [] |
| | | } |
| | | }).catch(() => { |
| | | |
| | | }) |
| | | } else { |
| | | try { |
| | | this.cols = JSON.parse(this.typeList.find(v => v.id === val).dpHeadFull) |
| | | this.table = [] |
| | | } catch (error) { |
| | | this.cols = [] |
| | | } |
| | | }).catch(() => { |
| | | } |
| | | |
| | | }) |
| | | |
| | | }, |
| | | //显示 |
| | |
| | | this.$HTTP.get(`/api/blade-cps/workstation/listDatapointsByWorkstationId`, {}, { params }).then(res => { |
| | | try { |
| | | this.cols = JSON.parse(res.data.dpHead) |
| | | console.log(this.cols, 'cols') |
| | | if (this.cols.filter(v => v.prop === 'dplabel').length === 0) { |
| | | this.cols.unshift( |
| | | { |
| | | label: "显示名称", |
| | | prop: "dplabel", |
| | | isRequired: true, |
| | | } |
| | | ) |
| | | } |
| | | } catch (error) { |
| | | this.cols = [] |
| | | } |
| | |
| | | this.tabledata = [] |
| | | } |
| | | this.type = res.data.type |
| | | |
| | | this.appId = res.data.appId |
| | | // return res |
| | | }) |
| | | }, |
| | |
| | | }, |
| | | del(index) { |
| | | this.tabledata.splice(index, 1) |
| | | }, |
| | | copy(row) { |
| | | this.tabledata.push(Object.assign({}, row, { status: '1' })) |
| | | }, |
| | | //表单提交方法 |
| | | submit() { |
| | |
| | | return v |
| | | })), |
| | | workstationId: this.params.id, |
| | | type: this.type |
| | | type: this.type, |
| | | appId: this.appId |
| | | }).then(res => { |
| | | if (res.code === 200) { |
| | | this.getList({ |