服装智能制造软件平台V3.0
http://182.92.169.222/hhxy/#/user/login
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.
473 lines
16 KiB
473 lines
16 KiB
/** |
|
* 新增修改完成调用 modalFormOk方法 编辑弹框组件ref定义为modalForm |
|
* 高级查询按钮调用 superQuery方法 高级查询组件ref定义为superQueryModal |
|
* data中url定义 list为查询列表 delete为删除单条记录 deleteBatch为批量删除 |
|
*/ |
|
import { filterObj } from '@/utils/util'; |
|
import { deleteAction, getAction,downFile,getFileAccessHttpUrl } from '@/api/manage' |
|
import Vue from 'vue' |
|
import { ACCESS_TOKEN, TENANT_ID } from "@/store/mutation-types" |
|
import store from '@/store' |
|
import {Modal} from 'ant-design-vue' |
|
import type from "@views/exception/type"; |
|
|
|
export const JeecgListMixin = { |
|
data(){ |
|
return { |
|
/* 查询条件-请不要在queryParam中声明非字符串值的属性 */ |
|
queryParam: {}, |
|
/* 数据源 */ |
|
dataSource:[], |
|
/* 分页参数 */ |
|
ipagination:{ |
|
current: 1, |
|
pageSize: 10, |
|
pageSizeOptions: ['10', '20', '30'], |
|
showTotal: (total, range) => { |
|
return range[0] + "-" + range[1] + " 共" + total + "条" |
|
}, |
|
showQuickJumper: true, |
|
showSizeChanger: true, |
|
total: 0 |
|
}, |
|
/* 排序参数 */ |
|
isorter:{ |
|
column: 'createTime', |
|
order: 'desc', |
|
}, |
|
/* 筛选参数 */ |
|
filters: {}, |
|
/* table加载状态 */ |
|
loading:false, |
|
/* table选中keys*/ |
|
selectedRowKeys: [], |
|
/* table选中records*/ |
|
selectionRows: [], |
|
/* 查询折叠 */ |
|
toggleSearchStatus:false, |
|
/* 高级查询条件生效状态 */ |
|
superQueryFlag:false, |
|
/* 高级查询条件 */ |
|
superQueryParams: '', |
|
/** 高级查询拼接方式 */ |
|
superQueryMatchType: 'and', |
|
} |
|
}, |
|
created() { |
|
if(!this.disableMixinCreated){ |
|
console.log(' -- mixin created -- ') |
|
this.loadData(); |
|
//初始化字典配置 在自己页面定义 |
|
this.initDictConfig(); |
|
} |
|
}, |
|
computed: { |
|
//token header |
|
tokenHeader(){ |
|
let head = {'X-Access-Token': Vue.ls.get(ACCESS_TOKEN)} |
|
let tenantid = Vue.ls.get(TENANT_ID) |
|
if(tenantid){ |
|
head['tenant-id'] = tenantid |
|
} |
|
return head; |
|
} |
|
}, |
|
methods:{ |
|
loadData(arg) { |
|
if(!this.url.list){ |
|
this.$message.error("请设置url.list属性!") |
|
return |
|
} |
|
//加载数据 若传入参数1则加载第一页的内容 |
|
if (arg === 1) { |
|
this.ipagination.current = 1; |
|
} |
|
var params = this.getQueryParams();//查询条件 |
|
this.loading = true; |
|
getAction(this.url.list, params).then((res) => { |
|
if (res.success) { |
|
//update-begin---author:zhangyafei Date:20201118 for:适配不分页的数据列表------------ |
|
this.dataSource = res.result.records||res.result; |
|
if(res.result.total) |
|
{ |
|
this.ipagination.total = res.result.total; |
|
}else{ |
|
this.ipagination.total = 0; |
|
} |
|
//update-end---author:zhangyafei Date:20201118 for:适配不分页的数据列表------------ |
|
} |
|
if(res.code===510){ |
|
this.$message.warning(res.message) |
|
} |
|
this.loading = false; |
|
}) |
|
}, |
|
initDictConfig(){ |
|
console.log("--这是一个假的方法!") |
|
}, |
|
handleSuperQuery(params, matchType) { |
|
//高级查询方法 |
|
if(!params){ |
|
this.superQueryParams='' |
|
this.superQueryFlag = false |
|
}else{ |
|
this.superQueryFlag = true |
|
this.superQueryParams=JSON.stringify(params) |
|
this.superQueryMatchType = matchType |
|
} |
|
this.loadData(1) |
|
}, |
|
getQueryParams() { |
|
//获取查询条件 |
|
let sqp = {} |
|
if(this.superQueryParams){ |
|
sqp['superQueryParams']=encodeURI(this.superQueryParams) |
|
sqp['superQueryMatchType'] = this.superQueryMatchType |
|
} |
|
var param = Object.assign(sqp, this.queryParam, this.isorter ,this.filters); |
|
param.field = this.getQueryField(); |
|
param.pageNo = this.ipagination.current; |
|
param.pageSize = this.ipagination.pageSize; |
|
return filterObj(param); |
|
}, |
|
getQueryField() { |
|
//TODO 字段权限控制 |
|
var str = "id,"; |
|
this.columns.forEach(function (value) { |
|
str += "," + value.dataIndex; |
|
}); |
|
return str; |
|
}, |
|
|
|
onSelectChange(selectedRowKeys, selectionRows) { |
|
this.selectedRowKeys = selectedRowKeys; |
|
this.selectionRows = selectionRows; |
|
}, |
|
onClearSelected() { |
|
this.selectedRowKeys = []; |
|
this.selectionRows = []; |
|
}, |
|
searchQuery() { |
|
this.loadData(1); |
|
}, |
|
superQuery() { |
|
this.$refs.superQueryModal.show(); |
|
}, |
|
searchReset() { |
|
this.queryParam = {} |
|
this.loadData(1); |
|
}, |
|
batchDel: function () { |
|
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; |
|
that.$confirm('是否删除选中数据?', '确认删除', { |
|
confirmButtonText: '确定', |
|
cancelButtonText: '取消', |
|
type: 'warning' |
|
}).then(() => { |
|
that.loading = true; |
|
deleteAction(that.url.deleteBatch, {ids: ids}).then((res) => { |
|
if (res.success) { |
|
//重新计算分页问题 |
|
that.reCalculatePage(that.selectedRowKeys.length) |
|
that.$message.success(res.message); |
|
that.loadData(); |
|
that.onClearSelected(); |
|
} else { |
|
that.$message.warning(res.message); |
|
} |
|
}).finally(() => { |
|
that.loading = false; |
|
}); |
|
}).catch(() => { |
|
this.$message({ |
|
type: 'info', |
|
message: '已取消' |
|
}); |
|
}); |
|
|
|
// that.$confirm({ |
|
// title:"确认删除", |
|
// content:"是否删除选中数据?", |
|
// onOk: function(){ |
|
// that.loading = true; |
|
// deleteAction(that.url.deleteBatch, {ids: ids}).then((res) => { |
|
// if (res.success) { |
|
// //重新计算分页问题 |
|
// that.reCalculatePage(that.selectedRowKeys.length) |
|
// that.$message.success(res.message); |
|
// that.loadData(); |
|
// that.onClearSelected(); |
|
// } else { |
|
// that.$message.warning(res.message); |
|
// } |
|
// }).finally(() => { |
|
// that.loading = false; |
|
// }); |
|
// } |
|
// }); |
|
} |
|
}, |
|
handleDelete: function (id) { |
|
if(!this.url.delete){ |
|
this.$message.error("请设置url.delete属性!") |
|
return |
|
} |
|
var that = this; |
|
deleteAction(that.url.delete, {id: id}).then((res) => { |
|
if (res.success) { |
|
//重新计算分页问题 |
|
that.reCalculatePage(1) |
|
that.$message.success(res.message); |
|
that.loadData(); |
|
} else { |
|
that.$message.warning(res.message); |
|
} |
|
}); |
|
}, |
|
reCalculatePage(count){ |
|
//总数量-count |
|
let total=this.ipagination.total-count; |
|
//获取删除后的分页数 |
|
let currentIndex=Math.ceil(total/this.ipagination.pageSize); |
|
//删除后的分页数<所在当前页 |
|
if(currentIndex<this.ipagination.current){ |
|
this.ipagination.current=currentIndex; |
|
} |
|
console.log('currentIndex',currentIndex) |
|
}, |
|
handleEdit: function (record) { |
|
this.$refs.modalForm.edit(record); |
|
this.$refs.modalForm.title = "编辑"; |
|
this.$refs.modalForm.disableSubmit = false; |
|
}, |
|
handleEdit1: function (record,code) { |
|
this.$refs.modalForm.edit1(record,code); |
|
this.$refs.modalForm.title = "编辑"; |
|
this.$refs.modalForm.disableSubmit = false; |
|
}, |
|
fuzhi: function (record) { |
|
|
|
record.codes=1; |
|
record.id=""; |
|
// var s=rest.processCode.substring(10,rest.processCode.length) |
|
// rest.processCode=(parseInt(s,10)+1).toString() |
|
// while(rest.processCode.length<6){ |
|
// rest.processCode="0"+rest.processCode |
|
// } |
|
// rest.processCode=rest.styleId+rest.processCode |
|
// console.log(record.process_code) |
|
|
|
this.$refs.modalForm.edit(record); |
|
this.$refs.modalForm.title = "复制"; |
|
this.$refs.modalForm.disableSubmit = false; |
|
}, |
|
fuzhi1:function (record) { |
|
|
|
record.id='' |
|
record.codes=1; |
|
// var s=rest.fabricNumber.substring(7,rest.fabricNumber.length) |
|
// var t=rest.fabricNumber.substring(0,7) |
|
// rest.fabricNumber=(parseInt(s,10)+1).toString() |
|
// while(rest.fabricNumber.length<10){ |
|
// rest.fabricNumber="0"+rest.fabricNumber |
|
// } |
|
// rest.fabricNumber=t+rest.fabricNumber |
|
// console.log(rest.fabricNumber) |
|
this.$refs.modalForm.edit(record); |
|
this.$refs.modalForm.title = "复制"; |
|
this.$refs.modalForm.disableSubmit = false; |
|
}, |
|
dongzuo: function (id,name) { |
|
this.$refs.modalForm1.edit(id); |
|
this.$refs.modalForm1.title = name+"工序动作管理"; |
|
this.$refs.modalForm1.disableSubmit = false; |
|
}, |
|
shebei: function (id,name) { |
|
this.$refs.modalForm2.edit(id); |
|
this.$refs.modalForm2.title = name+"工序设备管理"; |
|
this.$refs.modalForm2.disableSubmit = false; |
|
}, |
|
fuliao: function (id,name) { |
|
this.$refs.modalForm3.edit(id); |
|
this.$refs.modalForm3.title = name+"工序面料管理"; |
|
this.$refs.modalForm3.disableSubmit = false; |
|
}, |
|
gongju: function (id,name) { |
|
this.$refs.modalForm4.edit(id); |
|
this.$refs.modalForm4.title = name+"工序工具管理"; |
|
this.$refs.modalForm4.disableSubmit = false; |
|
}, |
|
mianliao: function (id,name) { |
|
this.$refs.modalForm5.edit(id); |
|
this.$refs.modalForm5.title = name+"工序辅料管理"; |
|
this.$refs.modalForm5.disableSubmit = false; |
|
}, |
|
handleAdd: function () { |
|
this.$refs.modalForm.add(); |
|
this.$refs.modalForm.title = "新增"; |
|
this.$refs.modalForm.disableSubmit = false; |
|
}, |
|
zyStyleFabricHandleAdd: function (id) { |
|
this.$refs.modalForm.add(id); |
|
this.$refs.modalForm.title = "新增"; |
|
//console.log("js层id的传递"+id); |
|
this.$refs.modalForm.disableSubmit = false; |
|
}, |
|
styleModuleHandleAdd: function (id,typeId,styleNames) { |
|
this.$refs.modalForm.add(id,typeId); |
|
this.$refs.modalForm.title = "服装款式 "+styleNames+" 新增"; |
|
this.$refs.modalForm.disableSubmit = false; |
|
}, |
|
handleAdd1: function (id) { |
|
this.$refs.modalForm.add1(id); |
|
this.$refs.modalForm.title = "新增"; |
|
this.$refs.modalForm.disableSubmit = false; |
|
}, |
|
handleTableChange(pagination, filters, sorter) { |
|
//分页、排序、筛选变化时触发 |
|
//TODO 筛选 |
|
console.log(pagination) |
|
if (Object.keys(sorter).length > 0) { |
|
this.isorter.column = sorter.field; |
|
this.isorter.order = "ascend" == sorter.order ? "asc" : "desc" |
|
} |
|
this.ipagination = pagination; |
|
this.loadData(); |
|
}, |
|
handleToggleSearch(){ |
|
this.toggleSearchStatus = !this.toggleSearchStatus; |
|
}, |
|
// 给popup查询使用(查询区域不支持回填多个字段,限制只返回一个字段) |
|
getPopupField(fields){ |
|
return fields.split(',')[0] |
|
}, |
|
modalFormOk() { |
|
// 新增/修改 成功时,重载列表 |
|
this.loadData(); |
|
//清空列表选中 |
|
this.onClearSelected() |
|
}, |
|
handleDetail:function(record){ |
|
this.$refs.modalForm.edit(record); |
|
this.$refs.modalForm.title="详情"; |
|
this.$refs.modalForm.disableSubmit = true; |
|
}, |
|
/* 导出 */ |
|
handleExportXls2(){ |
|
let paramsStr = encodeURI(JSON.stringify(this.getQueryParams())); |
|
let url = `${window._CONFIG['domianURL']}/${this.url.exportXlsUrl}?paramsStr=${paramsStr}`; |
|
window.location.href = url; |
|
}, |
|
handleExportXls(fileName){ |
|
if(!fileName || typeof fileName != "string"){ |
|
fileName = "导出文件" |
|
} |
|
let param = this.getQueryParams(); |
|
if(this.selectedRowKeys && this.selectedRowKeys.length>0){ |
|
param['selections'] = this.selectedRowKeys.join(",") |
|
} |
|
console.log("导出参数",param) |
|
downFile(this.url.exportXlsUrl,param).then((data)=>{ |
|
if (!data) { |
|
this.$message.warning("文件下载失败") |
|
return |
|
} |
|
if (typeof window.navigator.msSaveBlob !== 'undefined') { |
|
window.navigator.msSaveBlob(new Blob([data],{type: 'application/vnd.ms-excel'}), fileName+'.xls') |
|
}else{ |
|
let url = window.URL.createObjectURL(new Blob([data],{type: 'application/vnd.ms-excel'})) |
|
let link = document.createElement('a') |
|
link.style.display = 'none' |
|
link.href = url |
|
link.setAttribute('download', fileName+'.xls') |
|
document.body.appendChild(link) |
|
link.click() |
|
document.body.removeChild(link); //下载完成移除元素 |
|
window.URL.revokeObjectURL(url); //释放掉blob对象 |
|
} |
|
}) |
|
}, |
|
/* 导入 */ |
|
handleImportExcel(info){ |
|
if (info.file.status !== 'uploading') { |
|
console.log(info.file, info.fileList); |
|
} |
|
if (info.file.status === 'done') { |
|
if (info.file.response.success) { |
|
// this.$message.success(`${info.file.name} 文件上传成功`); |
|
if (info.file.response.code === 201) { |
|
let { message, result: { msg, fileUrl, fileName } } = info.file.response |
|
let href = window._CONFIG['domianURL'] + fileUrl |
|
this.$warning({ |
|
title: message, |
|
content: (<div> |
|
<span>{msg}</span><br/> |
|
<span>具体详情请 <a href={href} target="_blank" download={fileName}>点击下载</a> </span> |
|
</div> |
|
) |
|
}) |
|
} else { |
|
this.$message.success(info.file.response.message || `${info.file.name} 文件上传成功`) |
|
} |
|
this.loadData() |
|
} else { |
|
this.$message.error(`${info.file.name} ${info.file.response.message}.`); |
|
} |
|
} else if (info.file.status === 'error') { |
|
if (info.file.response.status === 500) { |
|
let data = info.file.response |
|
const token = Vue.ls.get(ACCESS_TOKEN) |
|
if (token && data.message.includes("Token失效")) { |
|
Modal.error({ |
|
title: '登录已过期', |
|
content: '很抱歉,登录已过期,请重新登录', |
|
okText: '重新登录', |
|
mask: false, |
|
onOk: () => { |
|
store.dispatch('Logout').then(() => { |
|
Vue.ls.remove(ACCESS_TOKEN) |
|
window.location.reload(); |
|
}) |
|
} |
|
}) |
|
} |
|
} else { |
|
this.$message.error(`文件上传失败: ${info.file.msg} `); |
|
} |
|
} |
|
}, |
|
/* 图片预览 */ |
|
getImgView(text){ |
|
if(text && text.indexOf(",")>0){ |
|
text = text.substring(0,text.indexOf(",")) |
|
} |
|
return getFileAccessHttpUrl(text) |
|
}, |
|
/* 文件下载 */ |
|
// update--autor:lvdandan-----date:20200630------for:修改下载文件方法名uploadFile改为downloadFile------ |
|
downloadFile(text){ |
|
if(!text){ |
|
this.$message.warning("未知的文件") |
|
return; |
|
} |
|
if(text.indexOf(",")>0){ |
|
text = text.substring(0,text.indexOf(",")) |
|
} |
|
let url = getFileAccessHttpUrl(text) |
|
window.open(url); |
|
}, |
|
} |
|
|
|
} |