You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
391 lines
14 KiB
391 lines
14 KiB
<template> |
|
|
|
<a-card :bordered="false"> |
|
<!-- 查询区域 --> |
|
<div class="table-page-search-wrapper"> |
|
<a-form layout="inline" @keyup.enter.native="searchQuery"> |
|
<a-row :gutter="24"> |
|
<a-col :xl="5" :lg="7" :md="8" :sm="16"> |
|
<a-form-item label="物料组"> |
|
<a-input placeholder="请输入物料组" v-model="queryParam.itemGroup"></a-input> |
|
</a-form-item> |
|
</a-col> |
|
<a-col :xl="5" :lg="7" :md="8" :sm="16"> |
|
<a-form-item label="物料号"> |
|
<a-input placeholder="请输入物料号" v-model="queryParam.item"/> |
|
</a-form-item> |
|
</a-col> |
|
<a-col :xl="5" :lg="7" :md="8" :sm="16"> |
|
<a-form-item label="物料名称"> |
|
<a-input placeholder="请输入物料名称" v-model="queryParam.itemDescription"/> |
|
</a-form-item> |
|
</a-col> |
|
<a-col :xl="5" :lg="7" :md="8" :sm="16"> |
|
<a-form-item label="核算属性"> |
|
<j-dict-select-tag placeholder="请输入核算属性" v-model="queryParam.accountingAttributes" dictCode="material_type"></j-dict-select-tag> |
|
</a-form-item> |
|
</a-col> |
|
|
|
</a-row> |
|
</a-form> |
|
</div> |
|
<!-- 查询区域-END --> |
|
|
|
<!-- 操作按钮区域 --> |
|
<div class="table-operator"> |
|
<a-button @click="handleAdd" type="primary" icon="plus" v-has="'suppliesstronger:add'">新增</a-button> |
|
<a-button type="primary" icon="download" @click="handleExportXls('物资总库')" v-has="'suppliesstronger:export'">导出</a-button> |
|
<a-upload name="file" :showUploadList="false" :multiple="false" :headers="tokenHeader" :action="importExcelUrl" @change="handleImportExcel"> |
|
<a-button type="primary" icon="import" v-has="'suppliesstronger:import'">导入</a-button> |
|
</a-upload> |
|
<a-button type="primary" icon="download" @click="downloadText('/static/excle/总库导入模板.xlsx','总库导入导入模板.xlsx')" v-has="'suppliesstronger:download'">总库导入模板</a-button> |
|
<a-button type="primary" @click="searchQuery" icon="search">查询</a-button> |
|
<a-button type="primary" @click="searchReset" icon="reload" style="margin-left: 8px">重置</a-button> |
|
<a-dropdown v-if="selectedRowKeys.length > 0" v-has="'suppliesstronger:delete'"> |
|
<!-- <a-menu slot="overlay">--> |
|
<!-- <a-menu-item key="1" @click="batchDel"><a-icon type="delete"/>删除</a-menu-item> <a-icon type="down" />--> |
|
<!-- </a-menu> --> |
|
<a-button style="margin-left: 8px" @click="batchDell"><a-icon type="delete"/> 删除 </a-button> |
|
</a-dropdown> |
|
</div> |
|
|
|
<!-- table区域-begin --> |
|
<div> |
|
<div class="ant-alert ant-alert-info" style="margin-bottom: 16px;"> |
|
<i class="anticon anticon-info-circle ant-alert-icon"></i> 已选择 <a style="font-weight: 600">{{ selectedRowKeys.length }}</a>项 |
|
<a style="margin-left: 24px" @click="onClearSelected">清空</a> |
|
</div> |
|
|
|
<a-table |
|
ref="table" |
|
size="middle" |
|
:scroll="{y:600}" |
|
bordered |
|
rowKey="id" |
|
:columns="columns" |
|
:dataSource="dataSource" |
|
:pagination="ipagination" |
|
:loading="loading" |
|
:rowSelection="{selectedRowKeys: selectedRowKeys, onChange: onSelectChange}" |
|
@change="handleTableChange"> |
|
|
|
<span slot="merchandiseName" slot-scope="text, record"> |
|
<j-ellipsis :value="text" :length="39"/> |
|
</span> |
|
<template slot="htmlSlot" slot-scope="text"> |
|
<div v-html="text"></div> |
|
</template> |
|
<template slot="imgSlot" slot-scope="text"> |
|
<span v-if="!text" style="font-size: 12px;font-style: italic;">无图片</span> |
|
<img v-else :src="getImgView(text)" height="25px" alt="" style="max-width:80px;font-size: 12px;font-style: italic;"/> |
|
</template> |
|
<template slot="fileSlot" slot-scope="text"> |
|
<span v-if="!text" style="font-size: 12px;font-style: italic;">无文件</span> |
|
<a-button |
|
v-else |
|
:ghost="true" |
|
type="primary" |
|
icon="download" |
|
size="small" |
|
@click="downloadFile(text)"> |
|
下载 |
|
</a-button> |
|
</template> |
|
|
|
<span slot="action" slot-scope="text, record" style="overflow: hidden;" class="table-page-search-submitButtons"> |
|
<a-dropdown> |
|
<a class="ant-dropdown-link" @click="handleDetaills(record)"><a-icon type="transaction" /> 明细</a> |
|
</a-dropdown> |
|
</span> |
|
|
|
</a-table> |
|
</div> |
|
|
|
<process-supplies-stronger-modal ref="modalForm" @ok="modalFormOk"></process-supplies-stronger-modal> |
|
</a-card> |
|
</template> |
|
|
|
<script> |
|
|
|
import '@/assets/less/TableExpand.less' |
|
import { mixinDevice } from '@/utils/mixin' |
|
import { JeecgListMixin } from '@/mixins/JeecgListMixin' |
|
import ProcessSuppliesStrongerModal from './modules/ProcessSuppliesStrongerModal' |
|
import JDate from '@/components/jeecg/JDate.vue' |
|
import JSearchSelectTag from '@/components/dict/JSearchSelectTag' |
|
import JSuperQuery from '@/components/jeecg/JSuperQuery.vue' |
|
import { deleteAction, getAction } from '@api/manage' |
|
|
|
|
|
export default { |
|
name: 'ProcessSuppliesStrongerList', |
|
mixins:[JeecgListMixin, mixinDevice], |
|
components: { |
|
JDate, |
|
JSearchSelectTag, |
|
ProcessSuppliesStrongerModal, |
|
JSuperQuery, |
|
}, |
|
data () { |
|
return { |
|
description: '物资总库管理页面', |
|
// 表头 |
|
bigId:[], |
|
columns: [ |
|
{ |
|
title: '序号', |
|
dataIndex: '', |
|
key:'rowIndex', |
|
width:50, |
|
align:"center", |
|
customRender:function (t,r,index) { |
|
return parseInt(index)+1; |
|
} |
|
}, |
|
{ |
|
title:'物料组', |
|
align:"center", |
|
width: 90, |
|
dataIndex: 'materialClassify' |
|
}, |
|
{ |
|
title:'物料号', |
|
align:"center", |
|
width:115, |
|
dataIndex: 'materialsNumber' |
|
}, |
|
|
|
{ |
|
title:'物料名称及规格型号', |
|
width:390, |
|
align:"left", |
|
// align:"conter", |
|
scopedSlots: { customRender: 'merchandiseName' }, |
|
dataIndex: 'merchandiseName' |
|
}, |
|
// { |
|
// title:'规格', |
|
// align:"center", |
|
// dataIndex: 'specification' |
|
// }, |
|
// { |
|
// title:'型号', |
|
// align:"center", |
|
// dataIndex: 'type' |
|
// }, |
|
|
|
{ |
|
title:'计量单位', |
|
align:"center", |
|
width:70, |
|
dataIndex: 'materialsUnit' |
|
}, |
|
{ |
|
title:'分公司库房', |
|
align:"center", |
|
width:90, |
|
dataIndex: 'materialQuantity', |
|
}, |
|
{ |
|
title:'项目部数量', |
|
align:"center", |
|
width:90, |
|
dataIndex: 'itemQuantity', |
|
// customRender:function (t,r,index) { |
|
// console.log(r) |
|
// if(r.itemQuantity === undefined){ |
|
// |
|
// } |
|
// return 0; |
|
// } |
|
}, |
|
// { |
|
// title:'项目部消耗数量', |
|
// align:"center", |
|
// dataIndex: 'usageQuantity', |
|
// customRender:function (t,r,index) { |
|
// // console.log("ergsdfgsd",r,r.usageQuantity) |
|
// if(!!r.usageQuantity && !!r.residueNumber){ |
|
// return parseInt(r.usageQuantity) - parseInt(r.residueNumber); |
|
// } |
|
// return 0; |
|
// } |
|
// }, |
|
// { |
|
// title:'科室消耗数量', |
|
// align:"center", |
|
// dataIndex: 'residueNumber', |
|
// customRender:function (t,r,index) { |
|
// // console.log(r) |
|
// if(r.residueNumber === undefined){ |
|
// return 0; |
|
// }else{ |
|
// return r.residueNumber; |
|
// } |
|
// |
|
// } |
|
// }, |
|
{ |
|
title:'核算属性', |
|
align:"center", |
|
width: 115, |
|
dataIndex: 'accountingAttributes_dictText' |
|
}, |
|
{ |
|
title: '明细', |
|
dataIndex: 'action', |
|
align:"center", |
|
width:90, |
|
scopedSlots: { customRender: 'action' } |
|
} |
|
], |
|
url: { |
|
list: "/suppliesstronger/processSuppliesStronger/list", |
|
delete: "/suppliesstronger/processSuppliesStronger/delete", |
|
deleteBatch: "/suppliesstronger/processSuppliesStronger/deleteBatch", |
|
exportXlsUrl: "/suppliesstronger/processSuppliesStronger/exportXls", |
|
importExcelUrl: "/suppliesstronger/processSuppliesStronger/importExcel", |
|
userRoleUrl: "/sys/user/queryUserRolePart", |
|
|
|
}, |
|
dictOptions:{}, |
|
superFieldList:[], |
|
} |
|
}, |
|
created() { |
|
this.getSuperFieldList(); |
|
}, |
|
computed: { |
|
importExcelUrl: function(){ |
|
return `${window._CONFIG['domianURL']}/${this.url.importExcelUrl}`; |
|
}, |
|
}, |
|
methods: { |
|
batchDell(){ |
|
if(!this.url.deleteBatch){ |
|
this.$message.error("请设置url.deleteBatch属性!!!!") |
|
return |
|
} |
|
if (this.selectedRowKeys.length <= 0) { |
|
this.$message.warning('请选择一条记录!'); |
|
return; |
|
} else { |
|
var ids = ""; |
|
for (var a = 0; a < this.selectedRowKeys.length; a++) { |
|
ids += this.selectedRowKeys[a] + ","; |
|
} |
|
var that = this; |
|
this.$confirm({ |
|
title: "确认删除", |
|
content: "是否删除选中数据?", |
|
onOk: function () { |
|
that.loading = true; |
|
deleteAction(that.url.deleteBatch, {ids: ids}).then((res) => { |
|
if (res.success) { |
|
that.$message.success(res.message); |
|
that.loadData(); |
|
that.onClearSelected(); |
|
} else { |
|
that.$message.warning(res.message); |
|
} |
|
}).finally(() => { |
|
that.loading = false; |
|
}); |
|
} |
|
}); |
|
} |
|
}, |
|
|
|
async loadData (arg) { |
|
if(!this.url.list){ |
|
this.$message.error("请设置url.list属性!") |
|
return |
|
} |
|
//加载数据 若传入参数1则加载第一页的内容 |
|
if (arg === 1) { |
|
this.ipagination.current = 1; |
|
} |
|
let ue= sessionStorage.getItem('USER_INFORMATION'); |
|
let res=JSON.parse(ue); |
|
// console.log("res",res); |
|
let role = { |
|
userid : res.id, |
|
} |
|
let isAdmin = false; |
|
await getAction(this.url.userRoleUrl,role).then(res =>{ |
|
// console.log("res信息",res) |
|
if(res.success){ |
|
let item = res.result; |
|
item.forEach( re =>{ |
|
if(re.roleName === "管理员" || re.roleName === "超级管理员"){ |
|
isAdmin = true; |
|
} |
|
}) |
|
} |
|
}) |
|
if(!isAdmin){ |
|
return ; |
|
} |
|
console.log(res); |
|
var params = this.getQueryParams();//查询条件 |
|
this.loading = true; |
|
getAction(this.url.list, params).then((res) => { |
|
if (res.success) { |
|
this.dataSource = res.result.records||res.result; |
|
if(res.result.total) |
|
{ |
|
this.ipagination.total = res.result.total; |
|
} |
|
} |
|
if(res.code===510){ |
|
this.$message.warning(res.message) |
|
} |
|
this.loading = false; |
|
}) |
|
}, |
|
|
|
|
|
|
|
handleDetaills(record){ |
|
console.log('record>>>>>>>>>>>>>>', record.merchandiseNewsId), |
|
this.$router.push({ |
|
path:'/materials/suppliesstronger_detail', |
|
query:{ |
|
item: record.merchandiseNewsId, |
|
merchandiseName : ' - '+record.merchandiseName.substring(0,10) |
|
} |
|
}) |
|
}, |
|
initDictConfig(){ |
|
}, |
|
getSuperFieldList(){ |
|
let fieldList=[]; |
|
fieldList.push({type:'string',value:'processId',text:'流程表单号'}) |
|
fieldList.push({type:'string',value:'supplier',text:'供应商'}) |
|
fieldList.push({type:'string',value:'supplierDescription',text:'供应商描述'}) |
|
fieldList.push({type:'string',value:'itemGroup',text:'物料组'}) |
|
fieldList.push({type:'string',value:'item',text:'物料'}) |
|
fieldList.push({type:'string',value:'itemDescription',text:'物料描述'}) |
|
fieldList.push({type:'string',value:'unitMeasurement',text:'计量单位'}) |
|
fieldList.push({type:'int',value:'materialQuantity',text:'数量'}) |
|
fieldList.push({type:'BigDecimal',value:'materialPrice',text:'单价'}) |
|
fieldList.push({type:'BigDecimal',value:'rates',text:'金额'}) |
|
fieldList.push({type:'string',value:'unitWasteWarehouseCodeId',text:'仓储地点'}) |
|
fieldList.push({type:'string',value:'freightSpace',text:'存储仓位'}) |
|
fieldList.push({type:'date',value:'productionTime',text:'生产时间'}) |
|
fieldList.push({type:'string',value:'expirationDate',text:'保质期'}) |
|
fieldList.push({type:'string',value:'supplierBatch',text:'批次',dictTable:''}) |
|
fieldList.push({type:'string',value:'arrivalNotice',text:'是否到货'}) |
|
fieldList.push({type:'date',value:'storageTime',text:'入库时间'}) |
|
fieldList.push({type:'string',value:'librarySign',text:'入库人'}) |
|
fieldList.push({type:'int',value:'accountingAttributes',text:'核算属性'}) |
|
this.superFieldList = fieldList |
|
|
|
|
|
} |
|
} |
|
} |
|
</script> |
|
<style scoped> |
|
@import '~@assets/less/common.less'; |
|
</style> |