3 Commits

Author SHA1 Message Date
lixuan
1ccc6803e7 Merge branch 'xiaozy_产品列表' of http://121.196.213.68:3000/xiaozhiyong/refinery-admin into lixuan 2023-02-20 11:18:30 +08:00
lixuan
608f5cdb98 xiugai 2023-02-20 11:18:26 +08:00
xiaozhiyong
492e3c3748 更新 2023-02-20 10:45:44 +08:00
8 changed files with 133 additions and 39 deletions

View File

@@ -39,7 +39,7 @@ const getRefineryCompanyList = (params) => {
// 下单 // 下单
const orderSave = (params) => { const orderSave = (params) => {
return request.postJson( return request.postJson(
"/oil_refinery/xoilRefineryOrder/save", "/oil-refinery/xoilRefineryOrder/save",
params params
); );
}; };

View File

@@ -1,5 +1,5 @@
<template> <template>
<el-autocomplete <!-- <el-autocomplete
v-model="text" v-model="text"
:fetch-suggestions="querySearchAsync" :fetch-suggestions="querySearchAsync"
:value-key="config.valueKey" :value-key="config.valueKey"
@@ -7,7 +7,26 @@
clearable clearable
@select="selectAutocomplete" @select="selectAutocomplete"
@clear="params[config.querykey] = ''" @clear="params[config.querykey] = ''"
></el-autocomplete> ></el-autocomplete> -->
<el-select
v-model="params[config.querykey]"
filterable
remote
clearable
reserve-keyword
:placeholder="config.placeholder"
:remote-method="remoteMethod"
@clear="list = []"
>
<el-option
v-for="(item, index) in list"
:key="item.id + index"
:label="item[config.labelKey]"
:value="item[config.valueKey]"
>
</el-option>
</el-select>
</template> </template>
<script> <script>
@@ -17,37 +36,67 @@ export default {
config: Object, config: Object,
// config: { // config: {
// serveTarget: {}, // 远程搜索接口 // serveTarget: {}, // 远程搜索接口
// autocomplateKey: "", //远程搜索接口参数名 // autocompleteKey: "", //远程搜索接口参数名
// labelKey: "", //接口返回数据label名
// valueKey: "", //接口返回数据唯一值
// querykey: "", //查询接口参数名 // querykey: "", //查询接口参数名
// }, // },
}, },
data() { data() {
return { return {
text: "", text: "",
list: [],
}; };
}, },
created() { watch: {
console.log("params", this.params); "config.echoId": {
handler(nval, oval) {
if (nval) {
console.log(nval);
this.remoteMethod(this.config.echoName);
}
},
deep: true,
immediate: true,
},
}, },
methods: { methods: {
// 远程搜索 // 远程搜索
querySearchAsync(queryString, cb) { remoteMethod(query) {
if (queryString) { if (query !== "") {
this.loading = true;
let params = {}; let params = {};
params[this.config.autocompleteKey] = queryString; params[this.config.autocompleteKey] = query;
this.config.serveTarget(params).then((res) => { this.config.serveTarget(params).then((res) => {
let timeInstance = setTimeout(() => { let timeInstance = setTimeout(() => {
this.loading = false;
clearTimeout(timeInstance); clearTimeout(timeInstance);
if (res.data.length) { if (res.data.length) {
cb(res.data); this.list = res.data;
} else cb([]); } else this.list = [];
}, 1000 * Math.random()); }, 1000 * Math.random());
}); });
} else cb([]); } else {
}, this.list = [];
selectAutocomplete(item) { }
this.params[this.config.querykey] = item.id;
}, },
// querySearchAsync(queryString, cb) {
// if (queryString) {
// let params = {};
// params[this.config.autocompleteKey] = queryString;
// this.config.serveTarget(params).then((res) => {
// let timeInstance = setTimeout(() => {
// clearTimeout(timeInstance);
// if (res.data.length) {
// cb(res.data);
// } else cb([]);
// }, 1000 * Math.random());
// });
// } else cb([]);
// },
// selectAutocomplete(item) {
// this.params[this.config.querykey] = item.id;
// },
}, },
}; };
</script> </script>

View File

@@ -110,10 +110,13 @@ export default {
refineryList: [], refineryList: [],
configAutocomplete: { configAutocomplete: {
serveTarget: refineryInfoServe.findByEntity, serveTarget: refineryInfoServe.findByEntity,
autocomplateKey: "refineryName", autocompleteKey: "refineryName",
valueKey: "refineryName", labelKey: "refineryName",
valueKey: "id",
placeholder: "炼厂名称", placeholder: "炼厂名称",
querykey: "refineryId", querykey: "refineryId",
echoId: "",
echoName: "",
}, },
productTypeList: [ productTypeList: [
{ {
@@ -170,6 +173,8 @@ export default {
if (id) { if (id) {
//回显 //回显
this.form = JSON.parse(JSON.stringify(this.controlWindows.addInfo)); this.form = JSON.parse(JSON.stringify(this.controlWindows.addInfo));
this.configAutocomplete.echoId = id;
this.configAutocomplete.echoName = this.form.refineryName;
console.log("this.form", this.form.floorPrice); console.log("this.form", this.form.floorPrice);
} }
}, },

View File

@@ -37,7 +37,7 @@
<autocomplete :params="form" :config="configAutocomplete" /> <autocomplete :params="form" :config="configAutocomplete" />
</el-form-item> </el-form-item>
<el-form-item label="产品类型" prop="productType"> <el-form-item label="产品类型" prop="productType">
<el-select v-model="form.productType" filterable reserve-keyword remote :remote-method="productData" placeholder="请选择产品类型"> <el-select v-model="form.productType" @change="productChange" placeholder="请选择产品类型">
<el-option <el-option
v-for="(item, index) in productTypeList" v-for="(item, index) in productTypeList"
:key="index" :key="index"
@@ -47,11 +47,19 @@
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item label="产品名称"> <el-form-item label="产品名称">
<el-input <el-select v-model="form.productId" placeholder="请选择产品类型">
<el-option
v-for="(item, index) in productNameList"
:key="index"
:label="item.productName"
:value="item.id"
></el-option>
</el-select>
<!-- <el-input
maxlength="50" maxlength="50"
v-model="form.productName" v-model="form.productName"
placeholder="请输入产品名称" placeholder="请输入产品名称"
></el-input> ></el-input> -->
</el-form-item> </el-form-item>
<el-form-item label="销售价"> <el-form-item label="销售价">
<el-input <el-input
@@ -98,6 +106,22 @@ export default {
controlWindows: Object, controlWindows: Object,
// refineryTypeEnum: Array, // refineryTypeEnum: Array,
}, },
watch:{
"form.salePrice": {
handler(n, o) {
if(n){
this.form.actAmount = this.form.salePrice*(this.form.preQuantity?this.form.preQuantity:0)
}
},
},
"form.preQuantity": {
handler(n, o) {
if(n){
this.form.actAmount = this.form.preQuantity*(this.form.salePrice?this.form.salePrice:0)
}
},
}
},
data() { data() {
let validatorRefineryId = (rule, value, callback) => { let validatorRefineryId = (rule, value, callback) => {
if (this.form.refineryId) callback(); if (this.form.refineryId) callback();
@@ -105,12 +129,16 @@ export default {
}; };
return { return {
customList:[], customList:[],
form: {}, form: {
actAmount:0
},
productNameList:[],
refineryList: [], refineryList: [],
configAutocomplete: { configAutocomplete: {
serveTarget: refineryInfoServe.findByEntity, serveTarget: refineryInfoServe.findByEntity,
autocomplateKey: "refineryName", autocompleteKey: "refineryName",
valueKey: "refineryName", labelKey: "refineryName",
valueKey: "id",
placeholder: "炼厂名称", placeholder: "炼厂名称",
querykey: "refineryId", querykey: "refineryId",
}, },
@@ -149,21 +177,28 @@ export default {
}; };
}, },
methods: { methods: {
productChange(){
this.productData()
},
//搜索炼厂 //搜索炼厂
refineryData(value){ refineryData(value){
if (value) { if (value) {
serve.findByEntity({refineryName:value}).then((res) => { serve.findByEntity({refineryName:value}).then((res) => {
this.refineryList = res.data; this.refineryList = res.data;
}); });
this.productData()
} }
}, },
//搜索产品 //搜索产品
productData(value){ productData(){
if (value) { let data = {
serve.getRefineryProductList({productType:value}).then((res) => { refineryId:this.form.refineryId,
this.customList = res.data; productType:this.form.productType,
}); enableMark:'ENABLE'
} }
serve.getRefineryProductList(data).then((res) => {
this.productNameList = res.data;
})
}, },
//搜索客户 //搜索客户
customData(value){ customData(value){
@@ -187,9 +222,10 @@ export default {
}); });
}, },
judgeInterface(form) { judgeInterface(form) {
let { id } = this.controlWindows.addInfo; // let { id } = this.controlWindows.addInfo;
if (id) return serve.update(form); // if (id) return serve.update(form);
else return serve.save(form); // else
return serve.orderSave(form);
}, },
//炼厂list //炼厂list
// findByEntity() { // findByEntity() {

View File

@@ -224,8 +224,9 @@ export default {
}, },
configAutocomplete: { configAutocomplete: {
serveTarget: refineryInfoServe.findByEntity, serveTarget: refineryInfoServe.findByEntity,
autocomplateKey: "refineryName", autocompleteKey: "refineryName",
valueKey: "refineryName", labelKey: "refineryName",
valueKey: "id",
placeholder: "炼厂名称", placeholder: "炼厂名称",
querykey: "refineryId", querykey: "refineryId",
}, },

View File

@@ -70,8 +70,9 @@ export default {
refineryList: [], refineryList: [],
configAutocomplete: { configAutocomplete: {
serveTarget: refineryInfoServe.findByEntity, serveTarget: refineryInfoServe.findByEntity,
autocomplateKey: "refineryName", autocompleteKey: "refineryName",
valueKey: "refineryName", labelKey: "refineryName",
valueKey: "id",
placeholder: "炼厂名称", placeholder: "炼厂名称",
querykey: "refineryId", querykey: "refineryId",
}, },

View File

@@ -162,8 +162,9 @@ export default {
}, },
configAutocomplete: { configAutocomplete: {
serveTarget: refineryInfoServe.findByEntity, serveTarget: refineryInfoServe.findByEntity,
autocomplateKey: "refineryName", autocompleteKey: "refineryName",
valueKey: "refineryName", labelKey: "refineryName",
valueKey: "id",
placeholder: "炼厂名称", placeholder: "炼厂名称",
querykey: "refineryId", querykey: "refineryId",
}, },

View File

@@ -189,8 +189,9 @@ export default {
}, },
configAutocomplete: { configAutocomplete: {
serveTarget: serve.findByEntity, serveTarget: serve.findByEntity,
autocomplateKey: "refineryName", autocompleteKey: "refineryName",
valueKey: "refineryName", labelKey: "refineryName",
valueKey: "id",
placeholder: "炼厂名称", placeholder: "炼厂名称",
querykey: "refineryId", querykey: "refineryId",
}, },