fix: 轮播图样式处理

This commit is contained in:
lzhizhao 2025-10-01 20:26:20 +08:00
parent 477519867e
commit e33b666e2f
2 changed files with 230 additions and 534 deletions

View File

@ -1,130 +1,64 @@
<template>
<div>
<div style="height: calc(100vh - 200px)">
<obj-table-plus
ref="oTable"
style="height: 100%"
:tableCols="tableCols"
:tableProp="tableProp"
@query="queryList"
v-model="dataList"
:tableEvent="tableEvent"
>
<template slot="tableTop">
<el-form :inline="true" :model="formInline" class="demo-form-inline">
<!-- <el-form-item label="模块">
<el-select
@change="changeModule"
class="filter-item"
style="width: 200px"
v-model="formInline.module"
placeholder="请选择模块"
>
<el-option
v-for="item in [
{
label: '菜市场',
value: 'market',
},
{
label: '摊铺',
value: 'shop',
},
]"
:key="item.value"
:label="item.label"
:value="item.value"
>
</el-option>
</el-select>
</el-form-item>
<el-form-item
v-if="storeList.length > 1 && formInline.module === 'shop'"
label="摊铺"
>
<el-select
class="filter-item"
style="width: 200px"
v-model="formInline.ownerId"
placeholder="请选择摊铺"
>
<el-option
v-for="item in storeList"
:key="item.shopId"
:label="item.shopName"
:value="item.shopId"
>
</el-option>
</el-select>
</el-form-item>
<el-form-item label="类型">
<el-select
class="filter-item"
style="width: 200px"
v-model="formInline.type"
placeholder="请选择分类类型"
>
<el-option
v-for="item in type"
:key="item.value"
:label="item.label"
:value="item.value"
>
</el-option>
</el-select>
</el-form-item> -->
<el-form-item label="应用">
<el-select
class="filter-item"
style="width: 200px"
v-model="formInline.app"
placeholder="请选择应用"
>
<el-option
v-for="item in application"
:key="item.value"
:label="item.label"
:value="item.value"
>
</el-option>
</el-select>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="$refs.oTable.reload()"
>查询</el-button
>
<el-button type="primary" @click="Reset">重置</el-button>
</el-form-item>
</el-form>
<!-- <el-tabs v-model="activeName" @tab-click="handleClick">
<el-tab-pane
v-for="item in statusList"
:key="item.value"
:label="item.label"
:name="item.value"
></el-tab-pane>
</el-tabs> -->
<div class="mb-2">
<el-button type="primary" size="small" @click="addBanner"
>新增轮播图</el-button
>
<el-button type="primary" size="small" @click="setSort"
>排序</el-button
>
</div>
</template>
</obj-table-plus>
<div class="page-container">
<el-card class="search-card" shadow="never">
<el-form :model="formInline" :inline="true" ref="searchForm" class="search-form" size="small">
<el-form-item label="应用" prop="app">
<el-select v-model="formInline.app" placeholder="请选择应用" style="width: 200px">
<el-option v-for="item in application" :key="item.value" :label="item.label" :value="item.value"></el-option>
</el-select>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="handleQuery" icon="el-icon-search" size="small">查询</el-button>
<el-button @click="Reset" icon="el-icon-refresh" size="small">重置</el-button>
</el-form-item>
</el-form>
</el-card>
<div class="table-container">
<div style="margin-bottom: 15px">
<el-button type="primary" size="small" @click="addBanner">新增轮播图</el-button>
<el-button type="primary" size="small" @click="setSort">排序</el-button>
</div>
<el-table :data="dataList" style="width: 100%">
<el-table-column type="index" width="60" align="center" label="序号" />
<el-table-column prop="title" label="名称" align="center" />
<el-table-column label="轮播图" align="center">
<template slot-scope="scope">
<el-image style="width: 60px; height: 60px" :src="scope.row.img.split(',')[0]" :preview-src-list="scope.row.img.split(',')"></el-image>
</template>
</el-table-column>
<el-table-column label="状态" align="center">
<template slot-scope="scope">
<el-tag :type="scope.row.status ? 'success' : 'info'">{{ scope.row.status ? "已启用" : "已禁用" }}</el-tag>
</template>
</el-table-column>
<el-table-column label="操作" fixed="right" align="center" width="220">
<template slot-scope="scope">
<el-button style="margin-right: 10px" size="mini" type="primary" @click="updateBanner(scope.row)">编辑</el-button>
<el-popconfirm @onConfirm="deleteBanner(scope.row)" confirm-button-text="确定" cancel-button-text="取消" icon="el-icon-info" icon-color="red" title="确定删除吗?">
<el-button size="mini" type="danger" slot="reference">删除</el-button>
</el-popconfirm>
</template>
</el-table-column>
</el-table>
<el-pagination
@size-change="handleSizeChange"
@current-change="handleCurrentChange"
:current-page="page"
:page-sizes="[10, 20, 50, 100]"
:page-size="limit"
layout="total, sizes, prev, pager, next, jumper"
:total="total"
class="pagination-container"
></el-pagination>
</div>
<!-- 轮播图 -->
<addOrUpdate
ref="addOrUpdate"
@queryList="$refs.oTable.reload()"
></addOrUpdate>
<addOrUpdate ref="addOrUpdate" @queryList="queryList"></addOrUpdate>
<!-- 排序 -->
<setSorting
@queryList="$refs.oTable.reload()"
ref="setSorting"
></setSorting>
<setSorting @queryList="queryList" ref="setSorting"></setSorting>
</div>
</template>
@ -136,32 +70,16 @@ export default {
components: { addOrUpdate, setSorting },
data() {
return {
activeName: "5",
advanceSellStatus: "",
dataList: [],
formInline: {
type: 0,
ownerId: "",
module: "",
app: 1,
},
tableProp: {
"auto-resize": true,
border: true,
height: "auto",
"row-id": "id",
"show-overflow": false,
},
selectList: [],
type: [
{
value: 0,
label: "菜市场分类",
},
{
value: 1,
label: "云店分类",
},
],
page: 1,
limit: 10,
total: 0,
application: [
{ label: "用户端", value: 1 },
{
@ -176,9 +94,7 @@ export default {
};
},
created() {
if (
JSON.parse(sessionStorage.getItem("userInfo")).role === "ROLE_MANAGER"
) {
if (JSON.parse(sessionStorage.getItem("userInfo")).role === "ROLE_MANAGER") {
this.formInline = {
type: 0,
ownerId: this.marketId,
@ -193,170 +109,90 @@ export default {
app: 1,
};
}
this.$nextTick(() => {
this.$refs.oTable.reload();
});
this.queryList();
},
methods: {
// getData() {
// this.$api.mer_admin
// .storeList({ marketId: this.formInline.marketId })
// .then((res) => {
// this.storeList = res.data.data;
// this.formInline.shopId = res.data.data[0].shopId;
// this.$nextTick(() => {
// this.$refs.oTable.reload();
// });
// });
// },
addBanner() {
this.$refs.addOrUpdate.toggle().add(this.formInline);
handleQuery() {
this.page = 1;
this.queryList();
},
changeModule(e) {
if (e === "shop") {
this.formInline.ownerId = this.shopId;
} else {
this.formInline.ownerId = this.marketId;
}
console.log(e);
},
queryList(pageNo, pageSize) {
queryList() {
this.$api.mer_admin
.bannerPage({
pageNumber: pageNo,
pageSize: pageSize,
pageNumber: this.page,
pageSize: this.limit,
...this.formInline,
})
.then((res) => {
console.log(res);
this.$refs.oTable.complete(
res.data.data.data,
Number(res.data.data.total)
);
})
.catch((err) => {
this.$refs.oTable.complete(false);
this.dataList = res.data.data.data;
this.total = Number(res.data.data.total);
});
},
Reset() {
this.formInline = {
type: 0,
ownerId: this.shopId,
module: "shop",
app: 1,
};
this.$refs.oTable.reload();
addBanner() {
this.$refs.addOrUpdate.toggle().add(this.formInline);
},
updateBanner(row) {
this.$refs.addOrUpdate.toggle(row).update();
},
deleteBanner(row) {
this.$api.mer_admin.bannerDelete({ id: row.id }).then((res) => {
this.queryList();
});
},
Reset() {
if (JSON.parse(sessionStorage.getItem("userInfo")).role === "ROLE_MANAGER") {
this.formInline = {
type: 0,
ownerId: this.marketId,
module: "market",
app: 1,
};
} else {
this.formInline = {
type: 0,
ownerId: this.shopId,
module: "shop",
app: 1,
};
}
this.handleQuery();
},
//
setSort() {
this.$refs.setSorting.init(this.dataList);
},
handleSizeChange(val) {
this.limit = val;
this.queryList();
},
handleCurrentChange(val) {
this.page = val;
this.queryList();
},
},
computed: {
tableCols() {
return [
// { type: "checkbox", width: "60px", fixed: "left" },
{ type: "seq", width: "60px", align: "center", title: "序号" },
{
title: "名称",
align: "center",
width: "120px",
field: "title",
},
{
title: "轮播图",
align: "center",
field: "startTime",
type: "jsx",
render: ({ row }) => {
return (
<el-image
style="width: 60px; height: 60px"
src={row.img.split(",")[0]}
preview-src-list={row.img.split(",")}
></el-image>
);
},
},
{
title: "状态",
align: "center",
field: "status",
type: "jsx",
render: ({ row }) => {
return <span>{row.status ? "已启用" : "已禁用"}</span>;
},
},
{
title: "操作",
fixed: "right",
type: "jsx",
align: "center",
width: "220px",
render: ({ row }) => {
let updateBanner = () => {
this.$refs.addOrUpdate.toggle(row).update();
};
let deleteBanner = () => {
this.$api.mer_admin
.bannerDelete({ id: row.id })
.then((res) => {
this.$refs.oTable.reload();
})
.catch((err) => {
this.$refs.oTable.reload();
});
};
let onCancel = () => {};
return (
<div>
<el-button
style="margin-right:10px"
size="mini"
type="primary"
onClick={updateBanner}
>
编辑
</el-button>
<el-popconfirm
onConfirm={deleteBanner}
onCancel={onCancel}
confirm-button-text="确定"
cancel-button-text="取消"
icon="el-icon-info"
icon-color="red"
title="确定删除吗?"
>
<el-button size="mini" type="danger" slot="reference">
删除
</el-button>
</el-popconfirm>
</div>
);
},
},
];
},
tableEvent() {
return {
"checkbox-all": ({ records, reserves }) => {
this.selectList = [...records, ...reserves];
},
"checkbox-change": ({ records, reserves }) => {
this.selectList = [...records, ...reserves];
},
};
},
...mapState("userData", [
"isMerchant",
"marketList",
"storeList",
"marketId",
"shopId",
]),
...mapState("userData", ["isMerchant", "marketList", "storeList", "marketId", "shopId"]),
},
};
</script>
<style lang="scss" scoped></style>
<style scoped>
.page-container {
}
.search-card {
margin-bottom: 15px;
}
.search-form .el-form-item {
margin-bottom: 0;
}
.pagination-container {
margin-top: 20px;
text-align: right;
}
</style>
<style>
.search-form .el-form-item__label {
padding-bottom: 0px !important;
font-size: 14px;
line-height: 32px;
}
</style>

View File

@ -1,62 +1,80 @@
<template>
<div>
<obj-modal
ref="modal"
labelWidth="150px"
class="popup"
:modalCols="modalCols"
:modalConfig="modalConfig"
:modalData="modalData"
:modalHandles="modalHandles"
>
<template slot="dialog__after"> </template>
</obj-modal>
</div>
<el-dialog :title="modalConfig.title" :visible.sync="modalConfig.show" width="700px" @close="handleClose">
<el-form ref="dataForm" :model="modalData" :rules="rules" label-width="150px">
<el-form-item label="轮播图名称" prop="title">
<el-input v-model="modalData.title" placeholder="请输入轮播图名称" maxlength="30" style="width: 100%;"></el-input>
</el-form-item>
<el-form-item label="状态" prop="status">
<el-switch v-model="modalData.status" active-text="启用" inactive-text="禁用"></el-switch>
</el-form-item>
<el-form-item label="应用" prop="app">
<el-select v-model="modalData.app" placeholder="请选择应用" style="width: 100%;">
<el-option v-for="item in applicationOptions" :key="item.value" :label="item.label" :value="item.value"></el-option>
</el-select>
</el-form-item>
<el-form-item label="轮播图" prop="img">
<div :class="{ 'hide-uploader': fileList.length > 0 }">
<el-upload
class="upload-demo"
:action="$api.mer_admin.uploadFile()"
:headers="{ token: 'Bearer ' + $cookie.get('token') }"
:on-success="handleAvatarSuccess"
:on-remove="handleRemove"
:file-list="fileList"
list-type="picture-card"
:limit="1"
>
<i class="el-icon-plus"></i>
<div slot="tip" class="el-upload__tip">只能上传jpg/png文件且不超过500kb</div>
</el-upload>
</div>
</el-form-item>
</el-form>
<span slot="footer" class="dialog-footer">
<el-button @click="modalConfig.show = false"> </el-button>
<el-button type="primary" @click="submitForm"> </el-button>
</span>
</el-dialog>
</template>
<script>
import { debounce, cloneDeep } from "lodash";
import { Divider } from "element-ui";
import { cloneDeep } from "lodash";
export default {
components: {},
data() {
return {
isAdd: true,
//
modalConfig: {
title: "",
show: false,
width: "700px",
},
modalData: {},
settingId: "",
form: {},
modalData: {
title: "",
status: true,
app: 1,
img: "",
},
fileList: [],
applicationOptions: [
{ label: "用户", value: 1 },
{ label: "商家", value: 2 },
{ label: "专员", value: 3 },
],
rules: {
title: [{ required: true, message: "请输入轮播图名称", trigger: "blur" }],
app: [{ required: true, message: "请选择应用", trigger: "change" }],
img: [{ required: true, message: "请上传商品图片", trigger: "change" }],
},
};
},
watch: {
"modalConfig.show"(newVal) {
if (!newVal) {
//
setTimeout(() => {
this.$refs.modal.resetFields();
});
}
},
},
methods: {
queryTableData(pageNo, pageSize) {},
toggle(e) {
if (this.modalConfig.show == false) {
this.modalConfig.show = true;
} else {
this.modalConfig.show = false;
}
this.modalConfig.show = !this.modalConfig.show;
if (e) {
this.init(cloneDeep(e));
}
return {
add: (row) => {
console.log(row);
this.modalData = {
ownerId: row.ownerId,
title: "",
@ -78,213 +96,55 @@ export default {
},
init(row) {
this.modalData = row;
this.fileList = row.img.split(",").map((item) => {
return {
name: "轮播图",
url: item,
};
this.fileList = row.img
? [{
name: "轮播图",
url: row.img,
}]
: [];
},
handleClose() {
this.$refs.dataForm.resetFields();
this.fileList = [];
this.modalData = {
title: "",
status: true,
app: 1,
img: "",
};
},
handleAvatarSuccess(res, file) {
this.modalData.img = res.data;
this.fileList = [{ name: file.name, url: res.data }];
this.$refs.dataForm.validateField("img");
},
handleRemove(file, fileList) {
this.modalData.img = "";
this.fileList = [];
this.$refs.dataForm.validateField("img");
},
submitForm() {
this.$refs.dataForm.validate((valid) => {
if (valid) {
const apiCall = this.isAdd ? this.$api.mer_admin.bannerAdd(this.modalData) : this.$api.mer_admin.bannerUpdate(this.modalData);
apiCall.then(() => {
this.modalConfig.show = false;
this.$emit("queryList");
this.$message.success(`${this.isAdd ? "添加" : "编辑"}成功`);
});
}
});
},
},
computed: {
modalCols() {
return [
{
label: "轮播图名称",
prop: "title",
type: "Input",
required: true,
maxlength: "30",
rules: {
required: true,
message: "请输入轮播图名称",
trigger: "blur",
},
},
// {
// label: "",
// prop: "type",
// maxlength: "30",
// rules: {
// required: true,
// message: "",
// trigger: "blur",
// },
// type: "jsx",
// render: () => {
// return (
// <el-select
// v-model={this.modalData.type}
// placeholder=""
// >
// {[
// { label: "", value: 0 },
// {
// label: "",
// value: 1,
// },
// ].map((item) => {
// return (
// <el-option
// label={item.label}
// value={item.value}
// ></el-option>
// );
// })}
// </el-select>
// );
// },
// },
{
label: "状态",
prop: "status",
maxlength: "30",
type: "jsx",
render: () => {
return (
<el-switch
v-model={this.modalData.status}
active-text="启用"
inactive-text="禁用"
/>
);
},
},
{
label: "应用",
prop: "app",
maxlength: "30",
rules: {
required: true,
message: "请输入轮播图名称",
trigger: "blur",
},
type: "jsx",
render: () => {
return (
<el-select
v-model={this.modalData.app}
placeholder="请选择销售单位"
>
{[
{ label: "用户", value: 1 },
{
label: "商家",
value: 2,
},
{
label: "专员",
value: 3,
},
].map((item) => {
return (
<el-option
label={item.label}
value={item.value}
></el-option>
);
})}
</el-select>
);
},
},
{
label: "轮播图",
prop: "img",
required: true,
rules: {
required: true,
message: "请上传商品图片",
trigger: "blur",
},
type: "jsx",
render: () => {
const handleAvatarSuccess = (res, file, fileList) => {
console.log(res, fileList);
this.modalData.img = fileList
.map((item) => {
return item.response.data;
})
.join(",");
console.log(this.modalData.img);
this.$refs.modal.validate();
};
const handleRemove = (file, fileList) => {
console.log(file, fileList);
this.modalData.img = fileList
.map((item) => {
return item.response.data;
})
.join(",");
};
return (
<el-upload
class="upload-demo"
drag
limit={3}
action={this.$api.mer_admin.uploadFile()}
{...{
props: {
"on-success": handleAvatarSuccess,
"on-remove": handleRemove,
},
}}
headers={{
token: "Bearer " + this.$cookie.get("token"),
}}
multiple={true}
file-list={this.fileList}
list-type="picture"
>
<i class="el-icon-upload"></i>
<div class="el-upload__text">
将文件拖到此处<em>点击上传</em>
</div>
<div class="el-upload__tip" slot="tip">
只能上传jpg/png文件且不超过500kb
</div>
</el-upload>
);
},
},
];
},
modalHandles() {
return [
{
label: "取消",
handle: () => {
this.toggle();
},
},
{
label: "确认",
type: "primary",
submit: true,
handle: () => {
console.log(this.modalData);
if (this.isAdd) {
this.$api.mer_admin.bannerAdd(this.modalData).then((res) => {
this.toggle();
this.$emit("queryList");
});
} else {
this.$api.mer_admin.bannerUpdate(this.modalData).then((res) => {
this.toggle();
this.$emit("queryList");
});
}
},
},
];
},
},
asyncComputed: {},
};
</script>
<style lang="scss" scoped>
.popup ::v-deep .el-dialog__body {
overflow-y: scroll !important;
height: 65vh !important;
.el-select,
.el-input {
width: 100%;
}
</style>
.hide-uploader ::v-deep .el-upload--picture-card {
display: none;
}
</style>