服装智能制造软件平台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.
474 lines
16 KiB
474 lines
16 KiB
<template> |
|
|
|
<a-card :bordered="false"> |
|
<p style="font-size: 30px;color:#333;padding-left: 40%">{{biaoTi}}</p> |
|
<!-- 查询区域 --> |
|
<!-- <div class="table-page-search-wrapper">--> |
|
<!-- <a-form layout="inline" @keyup.enter.native="searchQuery">--> |
|
<!-- <a-row :gutter="24">--> |
|
<!-- <a-col>--> |
|
<!-- <a-button type="primary">{{biaoTi}}</a-button>--> |
|
<!-- </a-col>--> |
|
<!-- </a-row>--> |
|
<!-- </a-form>--> |
|
<!-- </div>--> |
|
<!-- 查询区域-END --> |
|
|
|
<!-- <a-button type="primary" icon="rollback" @click="fanHui()">返回</a-button>--> |
|
<!-- table区域-begin --> |
|
<div> |
|
<j-vxe-table |
|
toolbar |
|
:toolbarConfig="toolbarConfig" |
|
row-number |
|
row-selection |
|
keep-source |
|
async-remove |
|
|
|
:height="340" |
|
:loading="loading" |
|
:columns="columns" |
|
:dataSource="dataSource" |
|
:pagination="pagination" |
|
style="margin-top: 8px;" |
|
@pageChange="handlePageChange" |
|
@valueChange="handleValueChange" |
|
@added="added" |
|
> |
|
<template v-slot:toolbarSuffix> |
|
<a-button type="primary" icon="rollback" @click="fanHui()">返回</a-button> |
|
<!-- <a-tooltip placement="top" title="获取值,忽略表单验证" :autoAdjustOverflow="true">--> |
|
<!-- <a-button @click="handleTableGet">获取值</a-button>--> |
|
<!-- </a-tooltip>--> |
|
<!-- <a-tooltip placement="top" title="模拟加载1000条数据" :autoAdjustOverflow="true">--> |
|
<!-- <a-button @click="handleTableSet">设置值</a-button>--> |
|
<!-- </a-tooltip>--> |
|
</template> |
|
|
|
<template v-slot:action="props"> |
|
<!-- <a @click="submitForm(props)">保存</a>--> |
|
<!-- <a-divider type="vertical"/>--> |
|
<a @click="viewDetail(props.rowId)">详情</a> |
|
<a-divider type="vertical"/> |
|
<a-popconfirm title="确定删除吗?" @confirm="handleDelete(props.rowId)"> |
|
<a>删除</a> |
|
</a-popconfirm> |
|
</template> |
|
</j-vxe-table> |
|
</div> |
|
|
|
<zy-style-model-modal ref="modalForm" @ok="modalFormOk"></zy-style-model-modal> |
|
<ZyStyleModelListDetails ref="ZyStyleModelListDetails"></ZyStyleModelListDetails> |
|
</a-card> |
|
</template> |
|
|
|
<script> |
|
|
|
import '@/assets/less/TableExpand.less' |
|
import {JVXETypes} from '@/components/jeecg/JVxeTable' |
|
import {mixinDevice} from '@/utils/mixin' |
|
import {JeecgListMixin} from '@/mixins/JeecgListMixin' |
|
import ZyStyleModelModal from './modules/ZyStyleModelModal' |
|
import {deleteAction, getAction, postAction, putAction, postFormAction, httpAction} from "@api/manage"; |
|
import store from "@/store"; |
|
import {filterObj, validateDuplicateValue} from '@/utils/util' |
|
import ZyStyleModelListDetails from "@views/zystylemodel/modules/ZyStyleModelListDetails"; |
|
|
|
export default { |
|
name: 'ZyStyleModelList', |
|
mixins: [JeecgListMixin, mixinDevice], |
|
components: { |
|
ZyStyleModelListDetails, |
|
ZyStyleModelModal |
|
}, |
|
data() { |
|
return { |
|
description: 'zy_style_model管理页面', |
|
biaoTi: '', |
|
// 表头 |
|
// 工具栏的按钮配置 |
|
toolbarConfig: { |
|
// add 新增按钮;remove 删除按钮;clearSelection 清空选择按钮 |
|
btn: ['add'], |
|
}, |
|
// validatorRules: { |
|
// styleId: [ |
|
// {required: true, message: '请选择服装类型!'}, |
|
// ], |
|
// }, |
|
// 是否正在加载 |
|
loading: false, |
|
// 分页器参数 |
|
pagination: { |
|
// 当前页码 |
|
current: 1, |
|
// 每页的条数 |
|
pageSize: 10, |
|
// 可切换的条数 |
|
pageSizeOptions: ['10', '20', '30', '100', '200'], |
|
// 数据总数(目前并不知道真实的总数,所以先填写0,在后台查出来后再赋值) |
|
total: 0, |
|
showQuickJumper: true, |
|
showSizeChanger: true, |
|
id: null |
|
}, |
|
|
|
// 数据源,控制表格的数据 |
|
|
|
columns: [ |
|
{ |
|
title: '服装款式', width: '100px', fixed: 'left', key: 'styleId', |
|
type: JVXETypes.normal, |
|
placeholder: '请输入${title}', |
|
//dictCode: 'zy_cloths_style,style_names,id', |
|
// validateRules: [ |
|
// {required: true, message: '${title}不能为空'}, |
|
// ], |
|
disabled: true, |
|
}, |
|
{ |
|
title: '是否默认尺码', align: "center", width: '130px', key: 'isdefault', |
|
type: JVXETypes.select, |
|
dictCode: 'isdefault', |
|
defaultValue: 0, |
|
}, |
|
{ |
|
key: 'modelNumber', title: '型号编码', dictCode: 'modenumber', width: '100px', |
|
type: JVXETypes.select |
|
}, |
|
{ |
|
key: 'size', title: '码数', width: '85px', dictCode: 'size', |
|
type: JVXETypes.select |
|
}, |
|
{ |
|
key: 'anumbers', title: '型', width: '85px', dictCode: 'hsize', |
|
type: JVXETypes.select |
|
}, |
|
{ |
|
key: 'bnumbers', title: '号', width: '85px', dictCode: 'xsize', |
|
type: JVXETypes.select |
|
}, |
|
{ |
|
key: 'collarLarge', |
|
title: '领大', width: '70px', |
|
type: JVXETypes.inputNumber, |
|
validateRules: [ |
|
{ |
|
required: false, // 选填 |
|
message: '${title}只能输入数字类型' // 提示的文本 |
|
}, |
|
{ |
|
pattern: /[^\d]/g, message: '${title}只能输入数字类型', |
|
}, |
|
], |
|
}, |
|
{ |
|
key: 'bust', title: '胸围', width: '80px', |
|
type: JVXETypes.inputNumber, |
|
validateRules: [ |
|
{ |
|
required: false, // 选填 |
|
message: '${title}只能输入数字类型' // 提示的文本 |
|
}, |
|
{ |
|
pattern: /\D/g, message: '${title}只能输入数字类型', |
|
}, |
|
] |
|
}, |
|
{ |
|
key: 'sleeveLength', title: '袖长', width: '80px', |
|
type: JVXETypes.inputNumber, |
|
validateRules: [ |
|
{ |
|
required: false, // 选填 |
|
message: '${title}只能输入数字类型' // 提示的文本 |
|
}, |
|
{ |
|
pattern: /[^\d]/g, message: '${title}只能输入数字类型', |
|
}, |
|
] |
|
}, |
|
{ |
|
key: 'shslLength', title: '连肩袖长', width: '100px', |
|
type: JVXETypes.inputNumber, |
|
validateRules: [ |
|
{ |
|
required: false, // 选填 |
|
message: '${title}只能输入数字类型' // 提示的文本 |
|
}, |
|
{ |
|
pattern: /[^\d]/g, message: '${title}只能输入数字类型', |
|
}, |
|
], |
|
}, |
|
|
|
{ |
|
key: 'tsWidth', title: '总肩宽', width: '80px', |
|
type: JVXETypes.inputNumber, |
|
validateRules: [ |
|
{ |
|
required: false, // 选填 |
|
message: '${title}只能输入数字类型' // 提示的文本 |
|
}, |
|
{ |
|
pattern: /[^\d]/g, message: '${title}只能输入数字类型', |
|
}, |
|
], |
|
}, |
|
{ |
|
key: 'cuff', title: '袖口', width: '80px', |
|
type: JVXETypes.inputNumber, |
|
validateRules: [ |
|
{ |
|
required: false, // 选填 |
|
message: '${title}只能输入数字类型' // 提示的文本 |
|
}, |
|
{ |
|
pattern: /[^\d]/g, message: '${title}只能输入数字类型', |
|
}, |
|
], |
|
}, |
|
{ |
|
key: 'waistline', title: '腰围', width: '80px', |
|
type: JVXETypes.inputNumber, |
|
validateRules: [ |
|
{ |
|
required: false, // 选填 |
|
message: '${title}只能输入数字类型' // 提示的文本 |
|
}, |
|
{pattern: /[^\d]/g, message: '${title}只能输入数字类型'}, |
|
], |
|
}, |
|
{ |
|
key: 'hem', title: '下摆', width: '80px', |
|
type: JVXETypes.inputNumber, |
|
validateRules: [ |
|
{ required: false, // 选填 |
|
message: '${title}只能输入数字类型' // 提示的文本 |
|
}, |
|
{ |
|
pattern: /[^\d]/g, message: '${title}只能输入数字类型', |
|
}, |
|
], |
|
}, |
|
{key: 'createTime', title: '创建时间', width: '60px', type: JVXETypes.datetime}, |
|
|
|
{ |
|
title: '操作', |
|
key: 'action', |
|
type: JVXETypes.slot, |
|
fixed: 'right', |
|
minWidth: '100px', |
|
align: 'center', |
|
slotName: 'action', |
|
} |
|
], |
|
url: { |
|
list: "/zystylemodel/zyStyleModel/list", |
|
delete: "/zystylemodel/zyStyleModel/delete", |
|
add: "/zystylemodel/zyStyleModel/add", |
|
edit: "/zystylemodel/zyStyleModel/edit", |
|
deleteBatch: "/zystylemodel/zyStyleModel/deleteBatch", |
|
exportXlsUrl: "/zystylemodel/zyStyleModel/exportXls", |
|
importExcelUrl: "zystylemodel/zyStyleModel/importExcel", |
|
}, |
|
//参数 |
|
styleId: '', |
|
loadRouteType: false, |
|
id: null, |
|
rowId: '', |
|
dictOptions: {}, |
|
superFieldList: [], |
|
} |
|
}, |
|
created() { |
|
//this.loadData(); |
|
this.loadParameter(); |
|
//备份model原始值 |
|
//this.modelDefault = JSON.parse(JSON.stringify(this.model)); |
|
}, |
|
computed: { |
|
importExcelUrl: function () { |
|
return `${window._CONFIG['domianURL']}/${this.url.importExcelUrl}`; |
|
}, |
|
}, |
|
methods: { |
|
|
|
//新增触发事件 |
|
added(event) { |
|
//this.styleId = this.$route.query.id; |
|
event.row.styleId = this.$route.query.id; |
|
console.log("新增触发事件", event) |
|
let httpUrl = this.url.add; |
|
let method = 'post'; |
|
let that = this; |
|
httpAction(httpUrl, event.row, method).then((res) => { |
|
if (res.success) { |
|
that.reCalculatePage(1); |
|
that.$message.success(res.message); |
|
this.$emit('ok'); |
|
that.loadData(); |
|
} else { |
|
this.$message.warning(res.message); |
|
} |
|
}) |
|
}, |
|
//数据发生变化时事件 即 编辑 |
|
async handleValueChange(event) { |
|
//this.submitForm(event) |
|
console.log("//数据发生变化时事件", event); |
|
//const str = event.row.id; |
|
let httpUrl = this.url.edit; |
|
let method = 'put'; |
|
await httpAction(httpUrl, event.row, method).then((res) => { |
|
if (res.success) { |
|
this.$message.success(res.message); |
|
this.$emit('ok'); |
|
} else { |
|
this.$message.warning(res.message); |
|
} |
|
}) |
|
}, |
|
// 详情 |
|
viewDetail(id) { |
|
this.$refs.ZyStyleModelListDetails.showModal(id) |
|
}, |
|
fanHui() { |
|
this.$router.push({ |
|
path: '/src/views/zyclothsstyle/ZyClothsStyleList', |
|
// query: { // 路由携带参数 |
|
// 'id': record.id, |
|
// 'typeId': record.typeId, |
|
// } |
|
// }); |
|
}); |
|
}, |
|
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); |
|
} |
|
}); |
|
}, |
|
submitForm(props) { |
|
this.model = Object.assign({}, props); |
|
var str = props.rowId; |
|
let httpurl = ''; |
|
let method = ''; |
|
if (str.search("row") !== -1) { |
|
httpurl += this.url.add; |
|
method = 'post'; |
|
} else { |
|
httpurl += this.url.edit; |
|
method = 'put'; |
|
} |
|
httpAction(httpurl, props.row, method).then((res) => { |
|
if (res.success) { |
|
this.$message.success(res.message); |
|
this.$emit('ok'); |
|
} else { |
|
this.$message.warning(res.message); |
|
} |
|
}) |
|
}, |
|
//加载传递参数 |
|
loadParameter() { |
|
if (this.loadRouteType === false) { |
|
this.id = this.$route.query.id; |
|
//this.styleId = this.id; |
|
this.biaoTi = this.$route.query.styleNames + "款式型号管理"; |
|
//console.log("**********传递到此层的id:" + this.id); |
|
this.loadRouteType = true; |
|
} |
|
}, |
|
// 加载数据 |
|
loadData(arg) { |
|
//加载数据 若传入参数1则加载第一页的内容 |
|
if (arg === 1) { |
|
this.pagination.current = 1; |
|
} |
|
// 调用查询数据接口 |
|
this.loadParameter(); |
|
var params = this.getQueryParams();//查询条件 |
|
this.loading = true; |
|
getAction(this.url.list, params).then(res => { |
|
if (res.success) { |
|
/*// 后台查询回来的 total,数据总数量 |
|
this.pagination.total = res.result.total*/ |
|
// 将查询的数据赋值给 dataSource |
|
this.dataSource = res.result.records || res.result; |
|
console.log(this.dataSource, 'abc') |
|
if (res.result.total) { |
|
this.pagination.total = res.result.total; |
|
} else { |
|
this.pagination.total = 0; |
|
} |
|
//this.dataSource = res.result.records |
|
|
|
} else { |
|
this.$error({title: '主表查询失败', content: res.message}) |
|
} |
|
}).finally(() => { |
|
// 这里是无论成功或失败都会执行的方法,在这里关闭loading |
|
this.loading = false |
|
}) |
|
}, |
|
|
|
// 当分页参数变化时触发的事件 |
|
handlePageChange(event) { |
|
// 重新赋值 |
|
this.pagination.current = event.current |
|
this.pagination.pageSize = event.pageSize |
|
// 查询数据 |
|
this.loadData() |
|
}, |
|
initDictConfig() { |
|
}, |
|
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; |
|
param.styleId = this.id |
|
return filterObj(param); |
|
}, |
|
getSuperFieldList() { |
|
let fieldList = []; |
|
fieldList.push({type: 'string', value: 'styleId', text: '款式id', dictCode: ''}) |
|
fieldList.push({type: 'int', value: 'isdefault', text: '是否默认尺码', dictCode: ''}) |
|
fieldList.push({type: 'int', value: 'modelNumber', text: '型号编码', dictCode: ''}) |
|
fieldList.push({type: 'int', value: 'size', text: '码数', dictCode: ''}) |
|
fieldList.push({type: 'string', value: 'anumbers', text: '型', dictCode: ''}) |
|
fieldList.push({type: 'string', value: 'bnumbers', text: '号', dictCode: ''}) |
|
fieldList.push({type: 'double', value: 'collarLarge', text: '领大', dictCode: ''}) |
|
fieldList.push({type: 'double', value: 'bust', text: '胸围', dictCode: ''}) |
|
fieldList.push({type: 'double', value: 'sleeveLength', text: '袖长', dictCode: ''}) |
|
fieldList.push({type: 'double', value: 'shslLength', text: '连肩袖长', dictCode: ''}) |
|
fieldList.push({type: 'double', value: 'tsWidth', text: '总肩宽', dictCode: ''}) |
|
fieldList.push({type: 'double', value: 'cuff', text: '袖口', dictCode: ''}) |
|
fieldList.push({type: 'double', value: 'waistline', text: '腰围', dictCode: ''}) |
|
fieldList.push({type: 'double', value: 'hem', text: '下摆', dictCode: ''}) |
|
this.superFieldList = fieldList |
|
} |
|
} |
|
} |
|
</script> |
|
<style scoped> |
|
@import '~@assets/less/common.less'; |
|
</style> |