1、增加分类切换关联逻辑

master
chris 1 month ago
parent a74f27e56c
commit 4aa1d5604b

@ -2,10 +2,10 @@
<div class="app-container"> <div class="app-container">
<splitpanes :horizontal="appStore.device === 'mobile'" class="default-theme"> <splitpanes :horizontal="appStore.device === 'mobile'" class="default-theme">
<pane size="8"> <pane size="8">
<el-segmented :options="categoryOptions" size="large" v-model="queryParams.pid" direction="vertical"/> <el-segmented :options="categoryOptions" size="large" v-model="queryParams.type" direction="vertical" @change="categoryChange"/>
</pane> </pane>
<pane size="92"> <pane size="92">
<el-form :model="queryParams" ref="queryRef" :inline="true" v-show="showSearch" label-width="68px"> <el-form :model="queryParams" ref="queryRef" :inline="true" v-show="showSearch" label-width="100px">
<el-form-item label="分类名称" prop="name"> <el-form-item label="分类名称" prop="name">
<el-input <el-input
v-model="queryParams.name" v-model="queryParams.name"
@ -14,6 +14,26 @@
@keyup.enter.native="handleQuery" @keyup.enter.native="handleQuery"
/> />
</el-form-item> </el-form-item>
<el-form-item v-if="queryParams.type" :label="levelName">
<el-select
v-model="queryParams.pid"
filterable
remote
placeholder="请输入关键词搜索"
remote-show-suffix
:remote-method="($event) => remoteMethod($event, remoteParent)"
:loading="remoteLoading"
@blur="remoteBlur"
style="width: 200px;"
>
<el-option
v-for="item in parentList"
:key="item.id"
:label="item.name"
:value="item.id"
/>
</el-select>
</el-form-item>
<el-form-item> <el-form-item>
<el-button type="primary" icon="search" @click="handleQuery"></el-button> <el-button type="primary" icon="search" @click="handleQuery"></el-button>
<el-button icon="refresh" @click="resetQuery"></el-button> <el-button icon="refresh" @click="resetQuery"></el-button>
@ -96,12 +116,29 @@
<!-- 添加或修改分类对话框 --> <!-- 添加或修改分类对话框 -->
<el-dialog :title="title" v-model="open" width="500px" append-to-body> <el-dialog :title="title" v-model="open" width="500px" append-to-body>
<el-form ref="formRef" :model="form" :rules="rules" label-width="80px"> <el-form ref="formRef" :model="form" :rules="rules" label-width="100px">
<el-form-item label="分类名称" prop="name"> <el-form-item label="分类名称" prop="name">
<el-input v-model="form.name" placeholder="请输入分类名称" /> <el-input v-model="form.name" placeholder="请输入分类名称" />
</el-form-item> </el-form-item>
<el-form-item label="备注" prop="remark"> <el-form-item :label="levelName" prop="pid" v-if="queryParams.type">
<el-input v-model="form.remark" type="textarea" placeholder="请输入内容" /> <el-select
v-model="form.pid"
filterable
remote
placeholder="请输入关键词搜索"
remote-show-suffix
:remote-method="($event) => remoteMethod($event, remoteParent)"
:loading="remoteLoading"
@blur="remoteBlur"
style="width: 200px;"
>
<el-option
v-for="item in parentList"
:key="item.id"
:label="item.name"
:value="item.id"
/>
</el-select>
</el-form-item> </el-form-item>
</el-form> </el-form>
<div slot="footer" class="dialog-footer"> <div slot="footer" class="dialog-footer">
@ -117,6 +154,7 @@
<script setup> <script setup>
import { listCategory, getCategory, delCategory, addCategory, updateCategory } from "@/api/product/category"; import { listCategory, getCategory, delCategory, addCategory, updateCategory } from "@/api/product/category";
import useForm from '@/hooks/useForm.js'; import useForm from '@/hooks/useForm.js';
import useRemote from '@/hooks/useRemote.js';
import { Splitpanes, Pane } from "splitpanes" import { Splitpanes, Pane } from "splitpanes"
import "splitpanes/dist/splitpanes.css" import "splitpanes/dist/splitpanes.css"
import useAppStore from '@/store/modules/app' import useAppStore from '@/store/modules/app'
@ -124,14 +162,15 @@ import useAppStore from '@/store/modules/app'
const defaultForm = { const defaultForm = {
id: null, id: null,
name: null, name: null,
type: null, type: 0,
remark: null pid: null,
} }
const defaultParams = { const defaultParams = {
pageNum: 1, pageNum: 1,
pageSize: 10, pageSize: 10,
name: null, name: null,
type: 0,
pid: null pid: null
} }
@ -156,6 +195,7 @@ const data = reactive({
total: 0, total: 0,
// //
categoryList: [], categoryList: [],
parentList: [],
categoryOptions: [ categoryOptions: [
{ {
value: 0, value: 0,
@ -179,13 +219,19 @@ const data = reactive({
} }
}) })
const { loading, ids, single, multiple, showSearch, total, categoryList, title, open, rules, categoryOptions } = toRefs(data); const { loading, ids, single, multiple, showSearch, total, categoryList, title, open, rules, categoryOptions, parentList } = toRefs(data);
const { form, validateForm, resetForm } = useForm(formRef, defaultForm) const { form, validateForm, resetForm } = useForm(formRef, defaultForm)
const { form: queryParams, resetForm: resetQueryForm } = useForm(queryRef, defaultParams) const { form: queryParams, resetForm: resetQueryForm } = useForm(queryRef, defaultParams)
const { loading: remoteLoading, remoteMethod } = useRemote()
getList(); getList();
const levelName = computed(() => {
const name = categoryOptions.value.find(item => item.value == queryParams.value.type - 1).label
return `${name}名称`
})
function getList() { function getList() {
loading.value = true; loading.value = true;
listCategory(queryParams.value).then(response => { listCategory(queryParams.value).then(response => {
@ -195,6 +241,28 @@ function getList() {
}); });
} }
function remoteParent (query) {
const params = {
pageNum: 1,
pageSize: 50,
type: queryParams.value.type - 1,
name: query
}
return listCategory(params).then(response => {
parentList.value = response.rows;
});
}
function categoryChange () {
queryParams.value.name = queryParams.value.pid = null;
form.value.type = queryParams.value.type;
handleQuery();
}
function remoteBlur() {
parentList.value = [];
}
// //
function cancel() { function cancel() {
open.value = false; open.value = false;

Loading…
Cancel
Save