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

<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>