2 changed files with 248 additions and 1 deletions
@ -0,0 +1,232 @@ |
|||||||
|
<template> |
||||||
|
<div class="content_box" v-loading='ServiceTypeLoading'> |
||||||
|
<div class="header"> |
||||||
|
|
||||||
|
<!-- <div class="el_Template"> |
||||||
|
<span class="name">模板名称</span> |
||||||
|
<el-input v-model="form.TemplateName" style="width: 240px" placeholder="请输入模板名称" /> |
||||||
|
</div> |
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<div class="el_Service"> |
||||||
|
<span class="name">品牌</span> |
||||||
|
<el-select |
||||||
|
v-model="form.brand" |
||||||
|
filterable |
||||||
|
placeholder="请选择品牌" |
||||||
|
:popper-append-to-body="false" |
||||||
|
style="width: 340px" |
||||||
|
> |
||||||
|
<el-option |
||||||
|
v-for="item in brand" |
||||||
|
:key="item.value" |
||||||
|
:label="item.brandName" |
||||||
|
:value="item.id" |
||||||
|
> |
||||||
|
</el-option> |
||||||
|
</el-select> |
||||||
|
</div> --> |
||||||
|
|
||||||
|
<!-- 服务类型 --> |
||||||
|
<div class="el_Service"> |
||||||
|
<span class="name">服务类型</span> |
||||||
|
<el-select |
||||||
|
v-model="form.ServiceType" |
||||||
|
filterable |
||||||
|
placeholder="请选择服务类型" |
||||||
|
:popper-append-to-body="false" |
||||||
|
style="width: 340px" |
||||||
|
multiple |
||||||
|
@remove-tag="removeTag" |
||||||
|
:loading='ServiceTypeLoading' |
||||||
|
> |
||||||
|
<el-option |
||||||
|
v-for="item in ServiceList" |
||||||
|
:key="item.value" |
||||||
|
:label="item.label" |
||||||
|
:value="item.value" |
||||||
|
> |
||||||
|
<el-checkbox v-model="item.check" @change="isChecked(item)"> |
||||||
|
{{ item.label }} |
||||||
|
</el-checkbox> |
||||||
|
</el-option> |
||||||
|
</el-select> |
||||||
|
</div> |
||||||
|
</div> |
||||||
|
|
||||||
|
<!-- 模板内容 --> |
||||||
|
<div class="content" > |
||||||
|
<el-tabs type="border-card" v-model="Tabmenu"> |
||||||
|
<template v-for="item in ServiceList" :key="item.label"> |
||||||
|
<el-tab-pane :name="item.label" v-if="item.state" :label="item.label"> |
||||||
|
<span v-if="item.label == '提货'"><FinancialBill /></span> |
||||||
|
<span v-if="item.label == '干线'"><FinancialTrunkLine @request-data="provideData" :templateData="templateInfo"/></span> |
||||||
|
<span v-if="item.label == '仓储'" |
||||||
|
><FinancialWarehousing @request-data="provideData" :templateData="templateInfo" |
||||||
|
/></span> |
||||||
|
<span v-if="item.label == '配送'"><FinancialDelivery @request-data="provideData" :templateData="templateInfo"/></span> |
||||||
|
<span v-if="item.label == '安装'">安装</span> |
||||||
|
</el-tab-pane> |
||||||
|
</template> |
||||||
|
</el-tabs> |
||||||
|
</div> |
||||||
|
</div> |
||||||
|
</template> |
||||||
|
|
||||||
|
<script setup> |
||||||
|
import { ref, defineAsyncComponent } from 'vue'; |
||||||
|
import { getDictionaryBiz } from '@/api/system/dict'; //字典 |
||||||
|
import { $_basicdataBrande} from '@/api/financialsector/index'; //价格模板 |
||||||
|
//仓储模板 |
||||||
|
const FinancialWarehousing = defineAsyncComponent(() => |
||||||
|
import('@/views/financialsector/Financialse/FinancialWarehousing.vue') |
||||||
|
); |
||||||
|
/** 提货模板 */ |
||||||
|
const FinancialBill = defineAsyncComponent(() => |
||||||
|
import('@/views/financialsector/Financialse/FinancialBill.vue') |
||||||
|
); |
||||||
|
/** 干线模板 */ |
||||||
|
const FinancialTrunkLine = defineAsyncComponent(() => |
||||||
|
import('@/views/financialsector/Financialse/FinancialTrunkLine.vue') |
||||||
|
); |
||||||
|
// 配送模板 |
||||||
|
const FinancialDelivery = defineAsyncComponent(() => |
||||||
|
import('@/views/financialsector/Financialse/FinancialDelivery.vue') |
||||||
|
); |
||||||
|
const ServiceTypeLoading=ref(true);//菜单加载 |
||||||
|
const form = ref({}); |
||||||
|
const brand=ref([]);//品牌 |
||||||
|
const Tabmenu = ref('仓储'); |
||||||
|
const templateInfo = ref({}); |
||||||
|
// 菜单列表 |
||||||
|
const ServiceList = ref([]); |
||||||
|
// 字典公共函数 |
||||||
|
function updateDictionary(targetArray, dictionaryType) { |
||||||
|
getDictionaryBiz(dictionaryType).then(res => { |
||||||
|
console.log(res, '字典'); |
||||||
|
if(res.data.code ==200){ |
||||||
|
if(res.data.data.length){ |
||||||
|
res.data.data.forEach(item => { |
||||||
|
targetArray.push({ |
||||||
|
value: item.dictKey, |
||||||
|
label: item.dictValue, |
||||||
|
id:item.id, |
||||||
|
}); |
||||||
|
}); |
||||||
|
} |
||||||
|
} |
||||||
|
}).catch(()=>{ |
||||||
|
}).finally(()=>{ |
||||||
|
ServiceTypeLoading.value=false; |
||||||
|
}); |
||||||
|
} |
||||||
|
// 页面初始化必要请求 |
||||||
|
const onLoad=()=>{ |
||||||
|
updateDictionary(ServiceList.value,'service_type');//菜单加载 |
||||||
|
let data={ |
||||||
|
current:1, |
||||||
|
size:1000, |
||||||
|
} |
||||||
|
$_basicdataBrande(data).then(res=>{ |
||||||
|
console.log(res,'品牌'); |
||||||
|
if(res.data.code == 200){ |
||||||
|
brand.value=res.data.data |
||||||
|
} |
||||||
|
}) |
||||||
|
} |
||||||
|
onLoad() |
||||||
|
// 点击菜单 |
||||||
|
const isChecked = val => { |
||||||
|
//菜单隐藏/显示 |
||||||
|
val.state = !val.state; |
||||||
|
//设置激活菜单 |
||||||
|
Tabmenu.value = val.label; |
||||||
|
// 如果当前菜单被关闭则显示最新菜单 |
||||||
|
if (!val.state && form.value.ServiceType.length) { |
||||||
|
Tabmenu.value = ServiceList.value.find(res => res.state).label; |
||||||
|
} |
||||||
|
}; |
||||||
|
// 点击移除 |
||||||
|
const removeTag = value => { |
||||||
|
ServiceList.value.find(res => res.value == value).check = false; |
||||||
|
ServiceList.value.find(res => res.value == value).state = false; |
||||||
|
// 激活菜单设置为已经存在的 |
||||||
|
if (form.value.ServiceType.length) { |
||||||
|
Tabmenu.value = ServiceList.value.find(res => res.state).label; |
||||||
|
} |
||||||
|
}; |
||||||
|
|
||||||
|
// 给子页面传递数据 |
||||||
|
const provideData = (data) => { |
||||||
|
console.log(data,'来自子页面的数据'); |
||||||
|
console.log(form.value,'form.value'); |
||||||
|
|
||||||
|
templateInfo.value = form.value; |
||||||
|
if(data){ |
||||||
|
templateInfo.value.code=data;//接收来自子页面第一次保存的返回值 |
||||||
|
} |
||||||
|
}; |
||||||
|
</script> |
||||||
|
|
||||||
|
<style scoped lang="scss"> |
||||||
|
.content_box { |
||||||
|
width: 100%; |
||||||
|
height: 100%; |
||||||
|
} |
||||||
|
.header { |
||||||
|
border-bottom: 1px solid #ccc; |
||||||
|
padding: 10px; |
||||||
|
box-shadow: -1px -1px 3px; |
||||||
|
.el_Template { |
||||||
|
display: flex; |
||||||
|
align-items: center; |
||||||
|
.name { |
||||||
|
font-size: 16px; |
||||||
|
margin-right: 10px; |
||||||
|
} |
||||||
|
} |
||||||
|
display: flex; |
||||||
|
.el_Service { |
||||||
|
margin-left: 30px; |
||||||
|
display: flex; |
||||||
|
align-items: center; |
||||||
|
.name { |
||||||
|
margin-right: 10px; |
||||||
|
} |
||||||
|
.el-checkbox { |
||||||
|
width: 100% !important; |
||||||
|
padding: 0 30px; |
||||||
|
.el-checkbox__label { |
||||||
|
width: 100%; |
||||||
|
margin-left: 20px; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
.name { |
||||||
|
font-size: 16px; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
.el-checkbox { |
||||||
|
width: 100% !important; |
||||||
|
padding-left: 10px; |
||||||
|
box-sizing: border-box; |
||||||
|
.el-checkbox__label { |
||||||
|
margin-left: 20px; |
||||||
|
} |
||||||
|
} |
||||||
|
.el-select-dropdown__item { |
||||||
|
padding: 0; |
||||||
|
} |
||||||
|
.el-select-dropdown__item::after { |
||||||
|
content: ''; |
||||||
|
display: none; |
||||||
|
} |
||||||
|
.content { |
||||||
|
margin-top: 6px; |
||||||
|
height: 100%; |
||||||
|
} |
||||||
|
</style> |
||||||
|
|
Loading…
Reference in new issue