| | |
| | | <template> |
| | | <div> |
| | | <a-drawer |
| | | :title="title" |
| | | :visible="visible" |
| | | width="650" |
| | | @ok="handleOk" |
| | | @close="handleCancel" |
| | | > |
| | | <a-modal |
| | | :title="title" |
| | | :visible="visible" |
| | | @ok="handleOk" |
| | | @cancel="handleCancel" |
| | | > |
| | | |
| | | <!--<!– 查询区域 –>--> |
| | | <!--<div class="table-page-search-wrapper">--> |
| | | <!--<a-form layout="inline" @keyup.enter.native="searchQuery">--> |
| | | <!--<a-row :gutter="24">--> |
| | | <a-spin :spinning="loading"> |
| | | <!-- showLine --> |
| | | <a-form> |
| | | <a-form-item label="车间层级:"> |
| | | <a-tree showLine ref="tree" :expandedKeys.sync="expandedKeys" |
| | | :treeData="treeDataSource" checkable @check="onCheck" v-model="checkedKeys" |
| | | @expand="onExpand"> |
| | | </a-tree> |
| | | </a-form-item> |
| | | </a-form> |
| | | |
| | | <!--<a-col :span="10">--> |
| | | <!--<a-form-item label="设备名称">--> |
| | | <!--<a-input placeholder="请输入设备名称" v-model="queryParam.equipmentName"></a-input>--> |
| | | <!--</a-form-item>--> |
| | | <!--</a-col>--> |
| | | <!--<a-col :span="8">--> |
| | | <!--<span style="float: left;overflow: hidden;" class="table-page-search-submitButtons">--> |
| | | <!--<a-button type="primary" @click="searchQuery" icon="search">查询</a-button>--> |
| | | <!--<a-button type="primary" @click="searchReset" icon="reload" style="margin-left: 8px">重置</a-button>--> |
| | | <!--</span>--> |
| | | <!--</a-col>--> |
| | | </a-spin> |
| | | |
| | | <!--</a-row>--> |
| | | <!--</a-form>--> |
| | | <!--</div>--> |
| | | <!--<!– table区域-begin –>--> |
| | | <!--<div>--> |
| | | <!--<a-table--> |
| | | <!--size="small"--> |
| | | <!--bordered--> |
| | | <!--rowKey="equipmentId"--> |
| | | <!--:columns="columns1"--> |
| | | <!--:dataSource="dataSource1"--> |
| | | <!--:pagination="ipagination"--> |
| | | <!--:loading="loading"--> |
| | | <!--:scroll="{ y: 240 }"--> |
| | | <!--:rowSelection="{selectedRowKeys: selectedRowKeys,onSelectAll:onSelectAll,onSelect:onSelect,onChange: onSelectChange}"--> |
| | | <!--@change="handleTableChange">--> |
| | | <!--</a-table>--> |
| | | <!--</div>--> |
| | | <!--<!– table区域-end –>--> |
| | | |
| | | <a-spin :spinning="loading"> |
| | | <!-- showLine --> |
| | | <a-form> |
| | | <a-form-item label="车间层级:"> |
| | | <a-tree showLine ref="tree" :expandedKeys.sync="expandedKeys" |
| | | :treeData="treeDataSource" checkable @check="onCheck" v-model="checkedKeys" |
| | | @expand="onExpand"> |
| | | </a-tree> |
| | | </a-form-item> |
| | | </a-form> |
| | | |
| | | </a-spin> |
| | | |
| | | |
| | | <div class="drawer-bottom-button"> |
| | | <template slot="footer"> |
| | | <div> |
| | | <a-dropdown |
| | | style="float: left" |
| | | :trigger="['click']" |
| | |
| | | >确定 |
| | | </a-button> |
| | | </div> |
| | | </template> |
| | | |
| | | </a-drawer> |
| | | </div> |
| | | </a-modal> |
| | | </template> |
| | | |
| | | <script> |
| | | // import { filterObj } from '@/utils/util' |
| | | // import { getAction } from '@/api/manage' |
| | | import { |
| | | getAction, |
| | | postAction, |
| | |
| | | } from '@/api/manage' |
| | | import BaseTree from '@/views/mdc/common/BaseTree' |
| | | import DepartTree from '@/views/mdc/base/modules/DepartList/DepartListTree/DepartTree' |
| | | import { mapActions } from 'vuex' |
| | | |
| | | export default { |
| | | name: 'SelectDeviceModal', |
| | |
| | | default() { |
| | | return true |
| | | } |
| | | }, |
| | | title: { |
| | | type: String |
| | | }, |
| | | selectedProduction: { |
| | | type: String |
| | | } |
| | | }, |
| | | data() { |
| | | return { |
| | | title: '添加已有设备', |
| | | cardLoading: false, |
| | | loading: false, |
| | | treeDataSource: [], |
| | | expandedKeys: [], |
| | | checkedKeys: [], |
| | | url: { |
| | | getBaseTree: '/mdc/mdcEquipment/queryTreeListByProduction' |
| | | getDeviceTree: '/mdc/mdcEquipment/loadTreeListByProductionIds' |
| | | }, |
| | | selectedWorkshopIds: '', |
| | | dataList: [], |
| | | allTreeKeys: [], |
| | | visible: false, |
| | | dataSource: [] |
| | | |
| | | // names: [], |
| | | // placement: 'right', |
| | | // description: '', |
| | | // // 查询条件 |
| | | // queryParam: {}, |
| | | // // 表头 |
| | | // columns1: [ |
| | | // { |
| | | // title: '#', |
| | | // dataIndex: '', |
| | | // key: 'rowIndex', |
| | | // width: 50, |
| | | // align: 'center', |
| | | // customRender: function(t, r, index) { |
| | | // return parseInt(index) + 1 |
| | | // } |
| | | // }, |
| | | // { |
| | | // title: '设备编号', |
| | | // align: 'center', |
| | | // width: 100, |
| | | // dataIndex: 'equipmentId' |
| | | // }, |
| | | // { |
| | | // title: '设备名称', |
| | | // align: 'center', |
| | | // width: 100, |
| | | // dataIndex: 'equipmentName' |
| | | // }, |
| | | // { |
| | | // title: '设备类型', |
| | | // align: 'center', |
| | | // width: 100, |
| | | // dataIndex: 'equipmentType' |
| | | // }, |
| | | // { |
| | | // title: '驱动类型', |
| | | // align: 'center', |
| | | // width: 100, |
| | | // dataIndex: 'driveType' |
| | | // } |
| | | // ], |
| | | // //数据集 |
| | | // dataSource1: [], |
| | | // dataSource2: [], |
| | | // // 分页参数 |
| | | // ipagination: { |
| | | // current: 1, |
| | | // pageSize: 10, |
| | | // pageSizeOptions: ['10', '20', '30'], |
| | | // showTotal: (total, range) => { |
| | | // return range[0] + '-' + range[1] + ' 共' + total + '条' |
| | | // }, |
| | | // showQuickJumper: true, |
| | | // showSizeChanger: true, |
| | | // total: 0 |
| | | // }, |
| | | // loading: false, |
| | | // selectedRowKeys: [], |
| | | // selectedRows: [], |
| | | // url: { |
| | | // list: '/mdc/mdcEquipment/list' |
| | | // }, |
| | | // activeKey: '1', |
| | | // isDepartType: '' |
| | | } |
| | | }, |
| | | created() { |
| | | // this.loadData() |
| | | this.queryTreeData() |
| | | this.closeAll() |
| | | }, |
| | | methods: { |
| | | ...mapActions(['QueryProduction']), |
| | | |
| | | onExpand(expandedKeys) { |
| | | this.expandedKeys = expandedKeys |
| | | this.autoExpandParent = false |
| | | }, |
| | | |
| | | queryTreeData() { |
| | | queryTreeData(value) { |
| | | this.loading = true |
| | | this.cardLoading = true |
| | | this.QueryProduction().then(res => { |
| | | if (res.success) { |
| | | this.dataList = [] |
| | | this.allTreeKeys = [] |
| | | this.getTreeDataSouce(res.result) |
| | | this.treeDataSource = res.result |
| | | this.generateList(this.treeDataSource) |
| | | console.log('treeDataSource', this.treeDataSource) |
| | | } else { |
| | | this.$message.warn(res.message) |
| | | } |
| | | }).finally(() => { |
| | | this.loading = false |
| | | this.cardLoading = false |
| | | }) |
| | | this.selectedWorkshopIds = value |
| | | getAction(this.url.getDeviceTree, { ids: value }) |
| | | .then(res => { |
| | | if (res.success) { |
| | | this.dataList = [] |
| | | this.allTreeKeys = [] |
| | | this.getTreeDataSouce(res.result) |
| | | this.treeDataSource = res.result |
| | | this.generateList(this.treeDataSource) |
| | | this.expandedKeys = this.allTreeKeys |
| | | } else { |
| | | this.$notification.warning({ |
| | | message: '消息', |
| | | description: res.message |
| | | }) |
| | | } |
| | | }) |
| | | .catch(err => { |
| | | this.$notification.error({ |
| | | message: '消息', |
| | | description: err.message |
| | | }) |
| | | }) |
| | | .finally(() => { |
| | | this.loading = false |
| | | }) |
| | | }, |
| | | |
| | | generateList(data) { |
| | |
| | | this.expandedKeys = ['-1'] |
| | | }, |
| | | refreshTree() { |
| | | this.queryTreeData() |
| | | this.queryTreeData(this.selectedWorkshopIds) |
| | | }, |
| | | onCheck(value) { |
| | | onCheck(value, obj) { |
| | | this.checkedKeys = value |
| | | this.deviceNodes = obj.checkedNodes.filter(item => item.data.props.equipmentId).map(item => item.data.props.equipmentId) |
| | | }, |
| | | handleCancel() { |
| | | this.visible = false |
| | | }, |
| | | handleOk() { |
| | | if (this.checkedKeys.length > 0) { |
| | | this.$emit('selectFinished', this.checkedKeys) |
| | | } |
| | | this.$emit('selectFinished', this.deviceNodes) |
| | | this.visible = false |
| | | } |
| | | |
| | | |
| | | // add() { |
| | | // this.visible = true |
| | | // }, |
| | | // loadData(arg) { |
| | | // //加载数据 若传入参数1则加载第一页的内容 |
| | | // if (arg === 1) { |
| | | // this.ipagination.current = 1 |
| | | // } |
| | | // var params = this.getQueryParams()//查询条件 |
| | | // getAction(this.url.list, params).then((res) => { |
| | | // if (res.success) { |
| | | // this.dataSource1 = res.result.records |
| | | // this.ipagination.total = res.result.total |
| | | // } |
| | | // }) |
| | | // }, |
| | | // getQueryParams() { |
| | | // var param = Object.assign({}, this.queryParam, this.isorter) |
| | | // param.field = this.getQueryField() |
| | | // param.pageNo = this.ipagination.current |
| | | // param.pageSize = this.ipagination.pageSize |
| | | // return filterObj(param) |
| | | // }, |
| | | // getQueryField() { |
| | | // //TODO 字段权限控制 |
| | | // }, |
| | | // onSelectAll(selected, selectedRows, changeRows) { |
| | | // if (selected === true) { |
| | | // for (var a = 0; a < changeRows.length; a++) { |
| | | // this.dataSource2.push(changeRows[a]) |
| | | // } |
| | | // } else { |
| | | // for (var b = 0; b < changeRows.length; b++) { |
| | | // this.dataSource2.splice(this.dataSource2.indexOf(changeRows[b]), 1) |
| | | // } |
| | | // } |
| | | // // console.log(selected, selectedRows, changeRows); |
| | | // }, |
| | | // onSelect(record, selected) { |
| | | // console.log(this.selectedRowKeys) |
| | | // if (selected === true) { |
| | | // this.dataSource2.push(record) |
| | | // } else { |
| | | // var index = this.dataSource2.indexOf(record) |
| | | // //console.log(); |
| | | // if (index >= 0) { |
| | | // this.dataSource2.splice(this.dataSource2.indexOf(record), 1) |
| | | // } |
| | | // } |
| | | // }, |
| | | // onSelectChange(selectedRowKeys, selectedRows) { |
| | | // console.log('selectedRowKeys', selectedRowKeys) |
| | | // this.selectedRowKeys = selectedRowKeys |
| | | // this.selectionRows = selectedRows |
| | | // }, |
| | | // onClearSelected() { |
| | | // this.selectedRowKeys = [] |
| | | // this.selectionRows = [] |
| | | // }, |
| | | // handleDelete: function(record) { |
| | | // this.dataSource2.splice(this.dataSource2.indexOf(record), 1) |
| | | // }, |
| | | // handleTableChange(pagination, filters, sorter) { |
| | | // //分页、排序、筛选变化时触发 |
| | | // console.log(sorter) |
| | | // //TODO 筛选 |
| | | // if (Object.keys(sorter).length > 0) { |
| | | // this.isorter.column = sorter.field |
| | | // this.isorter.order = 'ascend' == sorter.order ? 'asc' : 'desc' |
| | | // } |
| | | // this.ipagination = pagination |
| | | // this.loadData() |
| | | // }, |
| | | |
| | | |
| | | } |
| | | } |