123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948 |
- <template>
- <div class="content-main-manage">
- <div class="search-list">
- <div class="search-left">
- <Form class="common-form common-form-list" ref="tableParams" :model="tableParams" inline>
- <FormItem label="" prop="lineId">
- <Select v-model="tableParams.lineId" placeholder="来源应用" @on-select="selectLine">
- <Option v-for="item in lineTypeData" :value="String(item.id)" :key="item.id">{{ item.lineName }}</Option>
- </Select>
- </FormItem>
- <FormItem label="" prop="stationId">
- <Select v-model="tableParams.stationId" placeholder="设备类型">
- <Option v-for="item in stationTypeData" :value="String(item.id)" :key="item.id">{{ item.stationName }}</Option>
- </Select>
- </FormItem>
- <FormItem label="" prop="equipmentStatus">
- <Select v-model="tableParams.equipmentStatus" placeholder="策略覆盖告警等级数量">
- <Option v-for="item in indicatorsNum" :value="item.value" :key="item.value">{{ item.label }}</Option>
- </Select>
- </FormItem>
- <!-- <FormItem label="" prop="equipmentType">
- <Select v-model="tableParams.equipmentType" placeholder="设备类型">
- <Option v-for="item in equipTypeData" :value="(item.id)" :key="item.id">{{ item.name }}</Option>
- </Select>
- </FormItem> -->
- <FormItem label="" prop="equipmentName">
- <Input placeholder="请输入关键字查询" clearable search v-model="tableParams.equipmentName" />
- </FormItem>
- <FormItem label="" >
- <Button type="primary" class="common-btn-search" @click="searchClick">
- <Icon type="ios-search" style="margin-right:4px;font-size: 16px"/> 筛选
- </Button>
- <Button type="primary" class="common-btn-search" style="margin-left:10px" @click="resetClick('tableParams')">
- <Icon type="ios-search" style="margin-right:4px;font-size: 16px"/> 重置
- </Button>
- </FormItem>
- </Form>
- </div>
- </div>
- <div class="btn-container">
- <Button icon="ios-add" class="common-add-btn" @click="addClick">新增策略</Button>
- </div>
- <div class="manage-main-center">
- <Table :columns="columns" :data="tableData" class="common-table app-table" no-data-text="" :row-class-name="rowClassName" :loading="loading">
- <template slot="loading">
- <Loading-animation></Loading-animation>
- </template>
- <template slot-scope="{ row }" slot="action">
- <Tooltip content="详情" placement="top">
- <i class="iconfont icon-xiangqingmingxi" style="cursor:pointer;color:#B8B532;fontSize:20px;marginRight:6px" @click="detailClick(row)"></i>
- </Tooltip>
- <Tooltip content="编辑" placement="top">
- <i class="iconfont icon-bianji" style="cursor:pointer;color:#64ACFE;fontSize:20px;marginRight:6px" @click="editClick(row)"></i>
- </Tooltip>
- <Tooltip content="删除" placement="top">
- <i class="iconfont icon-shanchu" style="cursor:pointer;color:#E92E2E;fontSize:20px;marginRight:6px" @click="delClick(row)"></i>
- </Tooltip>
- </template>
- </Table>
- </div>
- <Page :total="tableTotal" :current="tableParams.pageNum" :page-size="tableParams.pageSize" @on-change="changePage" @on-page-size-change="sizeChange" show-elevator class="common-page"/>
- <Modal
- v-model="showModal"
- :title="title"
- width="40"
- ref="modalGrag"
- draggable
- reset-drag-position
- @on-visible-change="modalChange"
- :mask-closable="false"
- class-name="common-modal">
- <div class="common-modal-top">
- <span class="common-modal-top-text">基础信息</span>
- </div>
- <Form class="common-form" ref="formOption" :model="formOption" :rules="ruleValidate" :label-width="95" label-position="left">
- <FormItem label="策略名称" prop="name" style="width:100%">
- <Input v-model.trim="formOption.name" maxlength="20" show-word-limit />
- </FormItem>
- <FormItem label="来源应用:" prop="equipmentType" style="width:100%">
- <Select v-model="formOption.equipmentType" placeholder="来源应用">
- <Option v-for="item in equipTypeModalData" :value="item.equipmentTypeId" :key="item.equipmentTypeId">{{ item.equipmentName }}</Option>
- </Select>
- </FormItem>
- <FormItem label="设备类型:" prop="equipmentType" style="width:100%">
- <Select v-model="formOption.equipmentType" placeholder="设备类型">
- <Option v-for="item in equipTypeModalData" :value="item.equipmentTypeId" :key="item.equipmentTypeId">{{ item.equipmentName }}</Option>
- </Select>
- </FormItem>
- </Form>
- <div class="common-modal-top">
- <span class="common-modal-top-text">处理策略</span>
- </div>
- <Form ref="formDynamic" :model="formCustom" :label-width="0" class="strategy-form">
- <Row v-for="(item, index) in formCustom.formDynamic" :key="index">
- <Col span="4" :class="{'row-first': index == 0}" class="row-first-es">{{ item.name + (index + 1) }}</Col>
- <Col span="4" :class="{'row-first': index == 0}" class="row-first-es row-second-es">告警等级</Col>
- <Col span="5" :class="{'row-first': index == 0}" class="row-select">
- <FormItem
- :prop="'formDynamic.'+index+'.alarmType'" :rules="{required: true,message: '请选择告警等级',trigger: 'change'}">
- <Select v-model="item.alarmType" style="width: 100%" placeholder="告警等级" :disabled="item.disabled">
- <Option v-for="firstitem in indicatorsNum" :value="firstitem.value" :key="firstitem.value">{{ firstitem.label }}</Option>
- </Select>
- </FormItem>
- </Col>
- <Col span="5" :class="{'row-first': index == 0}" class="row-first-es">自动确认为</Col>
- <Col span="5" :class="{'row-first': index == 0}" class="row-select row-es-last">
- <FormItem
- :prop="'formDynamic.'+index+'.alarmType'" :rules="{required: true,message: '请选择确认动作',trigger: 'change'}">
- <Select v-model="item.alarmType" style="width: 100%" placeholder="确认动作" :disabled="item.disabled">
- <Option v-for="firstitem in indicatorsNum" :value="firstitem.value" :key="firstitem.value">{{ firstitem.label }}</Option>
- </Select>
- </FormItem>
- </Col>
- <Col span="1" class="ivu-col-btn">
- <i class="iconfont icon-tianjia" style="cursor:pointer;color:#2DA0F8;padding-left:10px" @click="handleAdd('formDynamic')" v-if="index == formCustom.formDynamic.length - 1 &&title=='新增策略'"></i>
- <i class="iconfont icon-shanchu ivu-col-del" style="cursor:pointer; color:#BC2020;padding-left:10px" v-if="title=='编辑策略'" @click="handleRemove(index)" disabled></i>
- </Col>
- </Row>
- <!-- <div class="sub-add">
- <span>新增一条子策略 子策略与现有子策略间为</span>
- <FormItem prop="logical" :rules="{required: clickbtn==2 ? true: false,message: '请选择逻辑判断',trigger: 'change'}">
- <Select v-model="formCustom.logical" placeholder="逻辑判断" style="width: 200px;padding: 0 6px">
- <Option v-for="item in indicatorsNum" :value="item.value" :key="item.value">{{ item.label }}</Option>
- </Select>
- </FormItem>
- 关系
- <i class="iconfont icon-tianjia" style="cursor:pointer;color:#43B843;padding-left:10px" @click="handleAddSub('formDynamic')"></i>
- </div> -->
- </Form>
- <div slot="footer">
- <Button @click="modalCancel">取消</Button>
- <Button type="primary" @click="modalOk">确定</Button>
- </div>
- </Modal>
- <Modal
- v-model="modalStatus"
- :title="commonTitle"
- width="30"
- ref="modalGrag"
- draggable
- reset-drag-position
- :mask-closable="false"
- class-name="common-modal">
- <Icon type="ios-information-circle" :style="{ color: activeColor}" class="modal-icon"></Icon>
- <span class="modal-text">{{modalTitle}}</span>
- <div slot="footer">
- <Button @click="commonCancel">取消</Button>
- <Button type="primary" @click="commonOk">确定</Button>
- </div>
- </Modal>
- <Modal
- v-model="detailStatus"
- title="自动确认策略详情"
- width="45"
- ref="modalGrag"
- draggable
- reset-drag-position
- footer-hide
- :mask-closable="false"
- class-name="common-modal">
- <div v-for="(item,index) in detailLabel" :key="index">
- <div class="common-modal-top">
- <span class="common-modal-top-text">{{item.name}}</span>
- </div>
- <div class="common-modal-content">
- <div class="modal-content-item" v-for="(val,i) in item.value" :key="i" :class="{'item-especial': val.name == '说明' && item.value.length%2!=0,'item-especial-bot':(i==item.value.length-1 || i==item.value.length-2) && item.value.length%2==0}">
- <span class="modal-content-item-name">
- {{val.name}}
- </span>
- <span class="modal-content-item-value" v-if="val.name == '归属线路' || val.name == '归属站点'">{{!val.value ? '/' : val.value}}</span>
- <span class="modal-content-item-value" v-else>{{val.value}}</span>
- </div>
- </div>
- </div>
- </Modal>
- </div>
- </template>
- <script>
- const defaultFrom = {lineId: '',stationId: '',appId:'',equipmentName: '',equipmentType:'',equipmentStatus: '',equipmentVersion: '',supplier: '',remark: ''}
- export default {
- name: "AlarmAcknowledgConfig",
- components:{
- },
- data() {
- return {
- applicationParams: {
- level: '',
- lineId: '',
- stationId: '',
- equipmentCheck: '',
- instrumentCheck: '',
- pageNum: 1,
- pageSize: 9999
- },
- appParams: {
- applicationId: '',
- equipmentTypeId: '',
- keywords: '',
- pageNum: 1,
- pageSize: 9999
- },
- loading: true,
- dateRange: [],
- tableParams: {
- lineId: '',
- stationId: '',
- equipmentStatus: '',
- keywords: '',
- applicationId:'',
- equipmentType: '',
- useDateBegin: '',
- useDateEnd: '',
- equipmentName: '',
- pageNum: 1,
- pageSize: 10
- },
- tableData: [],
- tableTotal: 0,
- rowObj: {},
- indicatorsNum: [
- {
- value: '-1',
- label: '监测指标数量'
- },
- {
- value: '1',
- label: '有'
- },
- {
- value: '0',
- label: '无'
- },
- ],
- lineTypeData: [],
- stationTypeData: [],
- equipStateData: [],
- equipStateModalData: [],
- equipTypeData: [],
- equipTypeModalData: [],
- equipAppModalData: [],
- columns: [
- // {
- // type: 'selection',
- // width: 60,
- // align: 'center'
- // },
- {
- title: '来源应用',
- key: 'equipmentName',
- align: 'center',
- ellipsis: true,
- tooltip: true
- },
- {
- title: '设备类型',
- key: 'equipmentTypeName',
- align: 'center'
- },
- {
- title: '覆盖告警等级',
- key: 'appName',
- align: 'center'
- },
- {
- title: '是否启用',
- key: 'enabled',
- align: 'center',
- width: 120,
- render: (h, params) => {
- return h('div', [
- h('i-switch', {
- props: { value: params.row.enabled,'true-color': '#57C44F', trueValue:1,falseValue: 0
- },
- nativeOn:{
- "mousedown":(event)=>{ // 监听组件原生事件mousedown,此事件在click之前触发
- this.rowObj = params.row
- if (params.row.enabled == 0) {
- this.commonTitle = '确认启用'
- this.activeColor = '#57C44F'
- this.activeClass = 'icon-qiyong'
- this.modalTitle = '当前时间点后所有告警信息,将使用策略自动判定。'
- this.modalStatus = true
- } else {
- this.commonTitle = '确认关闭'
- this.activeColor = '#E92E2E'
- this.activeClass = 'icon-guanbi'
- this.modalTitle = '可能影响新数据判断结果。'
- this.modalStatus = true
- }
- },
- }
- }),
- ])
- }
- },
- {
- title: '操作',
- align: 'center',
- slot: 'action',
- width: 120,
- }
- ],
- showModal: false,
- detailStatus: false,
- modalStatus: false,
- title: '新增策略',
- commonTitle: "确认删除",
- activeColor: '#E92E2E',
- activeClass: '',
- modalTitle: '',
- formOption: {lineId: '',stationId: '',appId:'',equipmentName: '',equipmentType:'',equipmentStatus: '',useDate:'',equipmentVersion: '',supplier: '',remark: ''},
- ruleValidate: {
- lineId: [{
- required: true,
- message: '请选择所属线路',
- trigger: 'change'
- }],
- stationId: [{
- required: true,
- message: '请选择所属站点',
- trigger: 'change'
- }],
- appId: [{
- required: true,
- message: '请选择归属应用',
- trigger: 'change'
- }],
- equipmentName: [{
- required: true,
- message: '请输入设备名称',
- trigger: 'change'
- }],
- appName: [{
- required: true,
- message: '请输入设备名称',
- trigger: 'blur'
- }],
- equipmentType: [{
- required: true,
- type: 'number',
- message: '请选择设备类型',
- trigger: 'change'
- }],
- equipmentStatus: [{
- required: true,
- type: 'number',
- message: '请选择设备状态',
- trigger: 'change'
- }]
- },
- detailLabel: [],
- formCustom: {
- formDynamic: [
- {
- name: "策略",
- alarmType: "",
- },
- ],
- },
- clickbtn: 1, // 1点击策略增加按钮 2点击子策略增加按钮 3点击子策略删除按钮
- };
- },
- mounted() {
- this.getType()
- this.getTableData()
- },
- methods: {
- go (){
- // this.$router.push({path:'//ApplicationManage'})
- // this.$router.push({path:'/MainPage/ApplicationManage/2'})
- this.$router.push({ name: 'ApplicationManage', params: { type:2 }}) // -> /home/123
- },
- changePicker (date) {
- this.tableParams.useDateBegin = date[0]
- this.tableParams.useDateEnd = date[1]
- },
- rowClassName(row, index) {
- if (index % 2 == 0) {
- return "ivu-table-stripe-even";
- } else {
- return "ivu-table-stripe-odd";
- }
- },
- // 分页
- changePage (val) {
- this.tableParams.pageNum = val
- this.getTableData()
- },
- //跳转
- sizeChange (val) {
- this.tableParams.pageSize = val
- this.getTableData()
- },
- getType () {
- //获取所属线路
- this.$get('metroapi/lineStation/queryLine', {lineName:''}).then(res=>{
- if (res.httpCode == 1 ){
- this.lineTypeData = res.data
- this.lineTypeData.unshift({ id: '-1', lineName: '线路' })
- this.getStationData ('-1')
- } else {
- this.lineTypeData = []
- }
- })
- // 获取设备状态
- this.$get('metroapi/dic/queryDictionary', {name:'设备状态'}).then(res=>{
- if (res.httpCode == 1 ){
- this.equipStateModalData = JSON.parse(JSON.stringify(res.data))
- this.equipStateData = res.data
- this.equipStateData.unshift({ id: '-1', value: '设备状态' })
- } else {
- this.equipStateData = []
- this.equipStateModalData = []
- }
- })
- // 获取归属应用
- this.$get('metroapi/application/info/list', this.applicationParams).then(res=>{
- if (res.httpCode == 1 ){
- this.equipAppModalData = res.data.data
- } else {
- this.equipAppModalData = []
- }
- })
- // // 获取设备类型
- // this.$get('metroapi/equipment/queryEquipmentType', {name:''}).then(res=>{
- // if (res.httpCode == 1 ){
- // this.equipTypeModalData = JSON.parse(JSON.stringify(res.data))
- // this.equipTypeData = res.data
- // this.equipTypeData.unshift({ id: '-1', name: '设备类型' })
- // } else {
- // this.equipTypeData = []
- // this.equipTypeModalData = []
- // }
- // })
- },
- selectLine (val) {
- // 获取站点类型
- this.tableParams.stationId = ''
- this.tableParams.lineId = val.value
- if (this.tableParams.lineId) {
- this.getStationData(val.value)
- }
- },
- // 获取所属站点
- getStationData (lineId) {
- if(lineId == '-1') {
- this.stationTypeData = [{ id: '-1', stationName: '站点' }]
- } else {
- this.$get('metroapi/lineStation/queryStationByLineId', {lineId:lineId}).then(res=>{
- if (res.httpCode == 1 ){
- this.stationTypeData = res.data
- this.stationTypeData.unshift({ id: '-1', stationName: '站点' })
- }
- })
- }
- },
- // selectChange (selection) {
- // console.log(selection)
- // let user = selection.map(item => item.id)
- // console.log(user)
- // },
- // 获取表格数据
- getTableData (keywords,arr,level) {
- if (level) {
- this.tableParams.keywords = ''
- if (level == 2) {
- this.tableParams.applicationId = arr[arr.length-1]
- this.tableParams.equipmentType = ''
- } else if (level == 3) {
- this.tableParams.applicationId = arr[arr.length-2]
- this.tableParams.equipmentType = arr[arr.length-1]
- } else {
- this.tableParams.applicationId = ''
- this.tableParams.equipmentType = ''
- }
- } else {
- this.tableParams.applicationId = ''
- this.tableParams.equipmentType = ''
- if (keywords == '合肥轨道交通' || keywords == '' || !keywords) {
- this.tableParams.keywords = ''
- } else {
- this.tableParams.keywords = keywords
- }
- }
- let params = JSON.parse(JSON.stringify(this.tableParams))
- params.lineId = params.lineId == '-1' ? '':params.lineId
- params.stationId = params.stationId == '-1' ?'':params.stationId
- this.loading = true
- this.$get('metroapi/equipment/queryEquipmentPage', params).then(res=>{
- this.loading = false
- if (res.httpCode == 1 ){
- this.tableData = res.data.data
- this.tableTotal = res.data.count
- if (res.data.data.length==0 && this.tableParams.pageNum>1) {
- this.tableParams.pageNum--
- return this.getTableData()
- }
- } else {
- this.tableData = []
- this.tableTotal = 0
- }
- })
- },
- selectModalLine (val) {
- this.formOption.stationId = ''
- if (val) {
- this.getStationData(val.value)
- }
- },
- selectModalStation (val) {
- if (val) {
- this.formOption.stationId =val.value
- }
- },
- selectModalApp (val) {
- this.appParams.applicationId = val
- this.formOption.equipmentType = ''
- if (val) {
- this.getAddEquipType( this.appParams)
- }
- },
- // 获取新增设备类型
- getAddEquipType (params) {
- this.$get('metroapi/application/equipmentTypeInfo', params).then(res=>{
- if (res.httpCode == 1 ){
- this.equipTypeModalData = res.data.data
- } else {
- this.equipTypeModalData = []
- }
- })
- },
- searchClick () {
- this.getTableData()
- // this.$router.push({ path: '/MainPage/ApplicationManage', query: {deptName: "2"}})
- },
- resetClick (name) {
- this.dateRange = []
- this.tableParams.useDateBegin = ''
- this.tableParams.useDateEnd = ''
- this.$refs[name].resetFields()
- this.getTableData()
- },
- changeMoldaPicker (val) {
- this.formOption.useDate = val
- },
- addClick () {
- this.formOption = JSON.parse(JSON.stringify(defaultFrom))
- this.formCustom.formDynamic = [{
- name: "策略",
- alarmType: "",
- }];
- this.title = '新增策略'
- this.showModal = true
- },
- detailClick (row) {
- this.rowObj = row
- this.detailStatus = true
- this.$get('metroapi/equipment/equipmentDetail', {equipmentId:row.id}).then(res=>{
- if ( res.httpCode == 1 ){
- this.detailLabel = res.data
- } else {
- this.$Message.info(res.msg)
- }
- })
- },
- editClick (row) {
- this.rowObj = row
- this.formOption = JSON.parse(JSON.stringify(row));
- this.formOption.lineId = this.formOption.lineId ? String(this.formOption.lineId) : '-1'
- this.formOption.stationId = this.formOption.stationId ? String(this.formOption.stationId) : '-1'
- this.getStationData(this.formOption.lineId)
- this.appParams.applicationId = this.formOption.appId
- this.getAddEquipType(this.appParams)
- this.title = '编辑策略'
- this.showModal = true
- },
- delClick (row) {
- this.rowObj = row
- this.commonTitle = '确认删除'
- this.activeColor = '#E92E2E'
- this.activeClass = ''
- this.modalTitle = '删除的同时将解绑所有运营数据,且数据不可恢复,请慎重操作。'
- this.modalStatus = true
- },
- modalChange (modalStatus) {
- if (!modalStatus) {
- this.$refs.formOption.resetFields();
- this.$refs.formDynamic.resetFields();
- }
- },
- modalOk () {
- var obj = Object.assign({}, this.formOption, this.formCustom); // 合并对象 注意目标对象自身也会改变。假设目标对象{}是之前里的对象,他的值跟obj一样
- this.clickbtn = 1
- this.$nextTick(()=> {
- let params = JSON.parse(JSON.stringify(this.formOption)) //把对象中的数据给了某个变量,改变一个对象的值,另一个对象也变化的解决方法
- params.lineId = params.lineId == '-1' ? '':params.lineId
- params.stationId = params.stationId == '-1' ? '':params.stationId
- // 多个form表单验证
- const p1 = new Promise((resolve,reject)=>{
- this.$refs['formOption'].validate(valid=>{
- if(valid) resolve()
- })
- })
- const p2 = new Promise((resolve,reject)=>{
- this.$refs['formDynamic'].validate(valid=>{
- if(valid) resolve()
- })
- })
- if (this.title == '新增策略') {
- Promise.all([p1,p2]).then(()=>{
- console.log('验证通过,提交表单')
- })
- // this.$refs['formOption'].validate((valid) => {
- // if (valid) {
- // this.$post('metroapi/equipment/addEquipment', params).then(res=>{
- // if ( res.httpCode == 1 ){
- // this.showModal = false
- // this.$Message.info(res.msg)
- // this.getTableData()
- // } else {
- // this.$Message.info(res.msg)
- // }
- // })
- // } else {
- // this.showModal = true
- // }
- // })
- } else {
- // this.$refs['formOption'].validate((valid) => {
- // if (valid) {
- // this.$post('metroapi/equipment/editEquipment', params).then(res=>{
- // if (res.httpCode == 1 ){
- // this.showModal = false
- // this.$Message.info(res.msg)
- // this.getTableData()
- // } else {
- // this.$Message.info(res.msg)
- // }
- // })
- // } else {
- // this.showModal = true
- // }
- // })
- }
- })
- },
- modalCancel () {
- this.showModal = false
- },
- commonOk () {
- let params = {
- id: this.rowObj.id
- }
- this.delData(params)
- },
- commonCancel () {
- this.modalStatus = false
- },
- // 删除接口
- delData (params) {
- this.$get('metroapi/equipment/delEquipment',params).then(res=>{
- if (res.httpCode == 1 ){
- this.modalStatus = false
- this.$Message.info(res.msg)
- this.getTableData()
- } else {
- this.$Message.info(res.msg)
- }
- })
- },
- handleAdd(name) {
- this.$nextTick(()=> {
- this.$refs[name].validate((valid) => {
- if (valid) {
- this.formCustom.formDynamic.push({
- alarmType: "",
- name: '策略'
- });
- }
- });
- console.log(this.formCustom.formDynamic)
- })
- },
- handleRemove(i) {
- if (this.formCustom.formDynamic.length == 1) {
- this.$Message['error']({
- background: true,
- content: '请至少保留一条非空策略'
- });
- } else {
- this.formCustom.formDynamic.splice(i,1)
- }
- // this.$nextTick(()=> {
- // this.formCustom.formDynamic[this.formCustom.formDynamic.length - 1].formItems.splice(i, 1) //因为删除选值的下拉框,没选值的下拉框的值会变成undefined 所以加个状态值(clickbtn=3)
- // })
- // this.formCustom.formDynamic[this.formCustom.formDynamic.length - 1].formItems[i].status = 0
- },
- // getTree(arr) {
- // return arr.map((v,index) => {
- // console.log(v)
- // if (v.baohan == undefined) {
- // console.log(34343)
- // v.baohan = ''
- // }
- // if (v.formItems) v.formItems = this.getTree(v.formItems);
- // return v;
- // });
- // },
- }
- };
- </script>
- <style scoped lang="stylus">
- .content-main-manage {
- position: relative;
- height: calc(100% - 50px);
- }
- .search-list {
- display: flex;
- padding: 10px 0;
- }
- .search-left {
- display: flex;
- align-items: center;
- .ivu-select {
- width: 155px;
- padding-right: 10px;
- height: 32px;
- }
- .ivu-select-single .ivu-select-selection {
- height: 100%;
- }
- >>> .ivu-input {
- width: 160px;
- height: 32px;
- }
- >>> .ivu-input-prefix, >>> .ivu-input-suffix {
- height: 32px;
- line-height: 32px;
- }
- >>> .ivu-input-icon {
- height: 32px;
- line-height: 32px;
- }
- >>> .date-picker-main .ivu-date-picker-header {
- border-bottom: 0.0052083333rem solid #204384;
- }
- }
- .btn-container {
- display: flex;
- justify-content: flex-end;
- padding-bottom: 10px;
- }
- .common-form {
- display: flex;
- flex-wrap: wrap;
- justify-content: space-between;
- }
- >>> .common-form-list .ivu-form-item {
- margin-bottom: 0;
- }
- .manage-main-center {
- width: 100%;
- height: calc(100% - 150px);
- }
- .common-table {
- max-height: 100%;
- }
- >>> .common-table .ivu-table th {
- height: 51px;
- }
- >>> .common-table .ivu-table td {
- height: 51px;
- }
- >>> .common-table .ivu-spin-fix {
- top: 51px;
- }
- >>> .app-table .ivu-spin-fix {
- height: calc(100vh - 375px);
- }
- >>> .ivu-table-tip {
- background: url('../../../assets/images/noData.png') no-repeat center;
- }
- >>> .app-table .ivu-table-tip {
- height: calc(100vh - 375px);
- }
- >>> .common-table .ivu-table-tip table {
- display: none;
- }
- >>> .modal-table {
- overflow: auto !important;
- }
- >>> .modal-table .ivu-spin-fix {
- height: 200px;
- }
- >>> .modal-table .ivu-table-tip {
- height: 200px;
- }
- .common-page {
- margin-top: 15px;
- display: flex;
- justify-content: flex-end;
- position: absolute;
- bottom: 0;
- right: 0;
- }
- >>> .modal-tabs-item {
- margin-top: 10px;
- }
- >>> .common-modal-top-text {
- font-size: 14px;
- font-weight: bold;
- color: #29A0FF;
- line-height: 42px;
- border-left: 3px solid #1590F1;
- padding-left: 12px;
- }
- >>> .common-modal-content {
- display: flex;
- width: 100%;
- justify-content: space-between;
- flex-wrap: wrap;
- margin-bottom: 15px;
- border-right: 1px solid #21437B;
- }
- >>> .modal-content-item {
- width: 50%;
- display: flex;
- }
- >>> .item-especial {
- width: 100%;
- }
- >>> .modal-content-item-name {
- width: 50%;
- height: 45px;
- line-height: 45px;
- background: #13305F;
- border-top: 1px solid #21437B;
- border-left: 1px solid #21437B;
- font-size: 14px;
- color: #F5F5F5;
- padding-left: 20px;
- }
- >>> .modal-content-item-value {
- width: 50%;
- height: 45px;
- line-height: 45px;
- background: #06214D;
- border-top: 1px solid #21437B;
- border-left: 1px solid #21437B;
- font-size: 14px;
- color: #F5F5F5;
- padding-left: 20px;
- }
- >>> .item-especial .modal-content-item-name{
- width: 25%;
- height: auto;
- min-height: 45px;
- border-bottom: 1px solid #21437B;
- display: flex;
- align-items: center;
- }
- >>> .item-especial .modal-content-item-value{
- width: 75%;
- height: auto;
- min-height: 45px;
- border-bottom: 1px solid #21437B;
- display: flex;
- align-items: center;
- line-height: 22px;
- }
- >>> .item-especial-bot .modal-content-item-name {
- border-bottom: 1px solid #21437B;
- }
- >>> .item-especial-bot .modal-content-item-value {
- border-bottom: 1px solid #21437B;
- }
- >>> .strategy-form .ivu-col{
- // position: initial;
- color: #2B8EE2;
- font-size: 14PX;
- }
- >>> .row-first-es {
- border-left: 1px solid #21437B;
- border-bottom: 1px solid #21437B;
- border-right: 1px solid #21437B;
- display: flex;
- align-items: center;
- justify-content: center;
- background: #13305F;
- }
- >>> .strategy-form .row-first{
- border-top: 1px solid #21437B;
- }
- >>> .strategy-form .row-second-es {
- border-left: none;
- }
- >>> .strategy-form .ivu-form-item{
- height: 100%;
- margin-bottom: 0;
- }
- >>> .strategy-form .row-es-text {
- border-left: none;
- border-bottom: 1px solid #21437B;
- border-right: 1px solid #21437B;
- display: flex;
- align-items: center;
- justify-content: center;
- background: #13305F;
- }
- >>> .row-select .ivu-form-item {
- height: 100%;
- border-bottom: 1px solid #21437B;
- .ivu-form-item-content {
- padding: 10px 5px;
- }
- }
- >>> .strategy-form .row-es-last {
- border-right: 1px solid #21437B;
- }
- >>> .ivu-col-del {
- cursor:pointer;
- color:#BC2020;
- padding-left:10px;
- }
- >>> .strategy-form .ivu-col-btn {
- display: flex;
- align-items: center;
- border-top: none;
- border-bottom: none;
- }
- >>> .strategy-form .ivu-form-item-error-tip {
- padding-left: 6px;
- }
- /deep/ .ivu-input::-webkit-input-placeholder{
- color: #718EBD;
- }
- /deep/ .ivu-input::-moz-placeholder{ /* Mozilla Firefox 19+ */
- color: #718EBD;
- }
- /deep/ .ivu-input::-moz-placeholder{ /* Mozilla Firefox 4 to 18 */
- color: #718EBD;
- }
- /deep/ .ivu-input::-ms-input-placeholder{ /* Internet Explorer 10-11 */
- color: #718EBD;
- }
- </style>
|