优化商品分类,隐藏没用的楼层装修弹窗的样式

master
lemon橪 2021-06-30 14:28:50 +08:00
parent f87306f6de
commit 4340b1a5b7
2 changed files with 77 additions and 49 deletions

View File

@ -2,13 +2,8 @@
<div class="wrapper"> <div class="wrapper">
<div class="operation"> <div class="operation">
<Button @click="addParent" icon="md-add">添加一级分类</Button> <Button @click="addParent" icon="md-add">添加一级分类</Button>
选择分类:
<Select @on-change="changeSortCate" v-model="sortCate" style="width:200px">
<Option v-for="item in sortCateList" :value="item.value" :key="item.value">{{ item.label }}</Option>
</Select>
</div> </div>
<tree-table ref="treeTable" size="default" :loading="loading" :data="tableData" :columns="columns" :border="true" :show-index="false" :is-fold="true" :expand-type="false" primary-key="id"> <Table size="default" :load-data="handleLoadData" row-key="id" :loading="loading" :data="tableData" :columns="columns">
<template slot="action" slot-scope="scope"> <template slot="action" slot-scope="scope">
<Dropdown v-show="scope.row.level == 2" transfer="true" trigger="click"> <Dropdown v-show="scope.row.level == 2" transfer="true" trigger="click">
@ -53,7 +48,7 @@
<Badge text="禁用" status="error"></Badge> <Badge text="禁用" status="error"></Badge>
</div> </div>
</template> </template>
</tree-table> </Table>
<Modal :title="modalTitle" v-model="modalVisible" :mask-closable="false" :width="500"> <Modal :title="modalTitle" v-model="modalVisible" :mask-closable="false" :width="500">
<Form ref="form" :model="formAdd" :label-width="100" :rules="formValidate"> <Form ref="form" :model="formAdd" :label-width="100" :rules="formValidate">
@ -132,19 +127,17 @@ import {
saveCategorySpec, saveCategorySpec,
getCategoryTree, getCategoryTree,
} from "@/api/goods"; } from "@/api/goods";
import TreeTable from "@/views/my-components/tree-table/Table/Table";
import uploadPicInput from "@/views/my-components/lili/upload-pic-input"; import uploadPicInput from "@/views/my-components/lili/upload-pic-input";
export default { export default {
name: "lili-components", name: "lili-components",
components: { components: {
TreeTable,
uploadPicInput, uploadPicInput,
}, },
data() { data() {
return { return {
categoryList: [], // categoryList: [], //
sortCateList: [], //
sortCate: "", // sortCate: "", //
loading: false, // loading: false, //
selectCount: 0, // selectCount: 0, //
@ -184,47 +177,44 @@ export default {
{ {
title: "分类名称", title: "分类名称",
key: "name", key: "name",
minWidth: "120px", tree: true,
}, },
{ {
title: "状态", title: "状态",
key: "deleteFlag", key: "deleteFlag",
headerAlign: "center",
type: "template", slot: "deleteFlag",
template: "deleteFlag",
}, },
{ {
title: "佣金(%)", title: "佣金",
key: "commissionRate", key: "commissionRate",
headerAlign: "center",
type: "template", slot: "commissionRate",
template: "commissionRate",
}, },
{ {
fixed: "right", fixed: "right",
title: "操作", title: "操作",
key: "action", key: "action",
align: "left",
headerAlign: "center", slot: "action",
type: "template",
template: "action",
}, },
], ],
tableData: [], tableData: [],
categoryIndex: 0, categoryIndex: 0,
checkedCategoryChildren: "", //
}; };
}, },
methods: { methods: {
changeSortCate(val) { // changeSortCate(val) {
let way = this.categoryList.find((item, index) => { // let way = this.categoryList.find((item, index) => {
if (item.name == val) { // if (item.name == val) {
this.categoryIndex = index; // this.categoryIndex = index;
console.log((this.categoryIndex = index)); // console.log((this.categoryIndex = index));
return item.name == val; // return item.name == val;
} // }
}); // });
this.tableData = [way]; // this.tableData = [way];
}, // },
init() { init() {
this.getAllList(0); this.getAllList(0);
this.getBrandList(); this.getBrandList();
@ -240,7 +230,6 @@ export default {
getSpecList() { getSpecList() {
getSpecificationList().then((res) => { getSpecificationList().then((res) => {
if (res.length != 0) { if (res.length != 0) {
this.specifications = res; this.specifications = res;
} }
}); });
@ -379,26 +368,64 @@ export default {
}, },
}); });
}, },
//
handleLoadData(item, callback) {
console.warn(item);
if (item.level == 0) {
let categoryList = JSON.parse(JSON.stringify(this.categoryList));
categoryList.forEach((val) => {
if (val.id == item.id) {
val.children.map((child) => {
child._loading = false;
child.children = [];
});
//
setTimeout(() => {
callback(val.children);
}, 1000);
}
});
} else {
this.deepCategoryChildren(item.id, this.categoryList);
console.log(this.checkedCategoryChildren);
setTimeout(() => {
callback(this.checkedCategoryChildren);
}, 1000);
}
},
// children
deepCategoryChildren(id, list) {
if (id != "0" && list.length != 0) {
for (let i = 0; i < list.length; i++) {
let item = list[i];
if (item.id == id) {
this.checkedCategoryChildren = item.children;
return;
} else {
this.deepCategoryChildren(id, item.children);
}
}
}
},
getAllList(parent_id) { getAllList(parent_id) {
this.sortCateList = [];
this.loading = true; this.loading = true;
getCategoryTree(parent_id).then((res) => { getCategoryTree(parent_id).then((res) => {
this.loading = false; this.loading = false;
if (res.success) { if (res.success) {
localStorage.setItem("category", JSON.stringify(res.result)); localStorage.setItem("category", JSON.stringify(res.result));
res.result.forEach((e, index, arr) => { this.categoryList = JSON.parse(JSON.stringify(res.result));
this.sortCateList.push({ this.tableData = res.result.map((item) => {
label: e.name, if (item.children.length != 0) {
value: e.name, item.children = [];
}); item._loading = false;
this.sortCate = arr[0].name; }
return item;
}); });
this.categoryList = res.result; console.log(this.tableData);
this.$nextTick(() => {
this.$set(this, "tableData", [res.result[this.categoryIndex]]);
});
} }
}); });
}, },

View File

@ -1,10 +1,11 @@
<template> <template>
<div class="wrapper"> <div class="wrapper">
<div class="list"> <!-- TODO 目前数据少暂且不用 -->
<!-- <div class="list">
<div class="list-item active"> <div class="list-item active">
文章页 文章页
</div> </div>
</div> </div> -->
<div class="content"> <div class="content">
<Article @callbacked="callbackArticle" :selected="true" /> <Article @callbacked="callbackArticle" :selected="true" />
</div> </div>
@ -36,7 +37,7 @@ export default {
height: 414px; height: 414px;
overflow: auto; overflow: auto;
} }
.ivu-table-wrapper ivu-table-wrapper-with-border{ .ivu-table-wrapper ivu-table-wrapper-with-border {
height: 300px !important; height: 300px !important;
} }
.list { .list {