This commit is contained in:
yuanteng 2024-12-04 09:38:32 +08:00
parent d1cdb9df2b
commit 8b40389be5

View File

@ -2,13 +2,8 @@
<!-- 修改前请注释以前的 --> <!-- 修改前请注释以前的 -->
<!-- 搜索 --> <!-- 搜索 -->
<div> <div>
<el-input style="width: 200px; height: 30px; margin-right: 10px;" suffix-icon="Search" placeholder="请输入商品名称" <el-input style="width: 200px; height: 30px; margin-right: 10px;" suffix-icon="Search" placeholder="请输入课程名称"
v-model="productName"></el-input> v-model="productName"></el-input>
<el-form-item label="商品类型" style="width: 200px; margin-right: 10px;display: inline-block">
<el-select v-model="editForm.type" @change="(event: any) => searchByType(event)" placeholder="请选择">
<el-option v-for="item in typeList" :key="item.value" :label="item.label" :value="item.value1" />
</el-select>
</el-form-item>
<el-form-item label="商品状态" style="width: 200px;margin-right: 10px;display: inline-block"> <el-form-item label="商品状态" style="width: 200px;margin-right: 10px;display: inline-block">
<el-select v-model="state" placeholder="请选择" @change="(event: any) => searchByState(event)"> <el-select v-model="state" placeholder="请选择" @change="(event: any) => searchByState(event)">
<el-option label="已上架" value="1" /> <el-option label="已上架" value="1" />
@ -33,25 +28,40 @@
:cell-style="{ 'text-align': 'center', 'font-size': '16px' }" @selection-change="handleSelectionChange" :cell-style="{ 'text-align': 'center', 'font-size': '16px' }" @selection-change="handleSelectionChange"
:header-cell-style="{ 'text-align': 'center' }"> :header-cell-style="{ 'text-align': 'center' }">
<el-table-column type="selection" width="55"></el-table-column> <el-table-column type="selection" width="55"></el-table-column>
<el-table-column prop="id" label="商品编号" width="80"> <el-table-column prop="id" label="课程编号" width="80">
<template #default="{ $index }"> <template #default="{ $index }">
{{ $index + 1 }} {{ $index + 1 }}
</template> </template>
</el-table-column> </el-table-column>
<el-table-column prop="goodImg" label="商品图片"> <el-table-column prop="goodImg" label="课程图片">
<template #default="scope"> <template #default="scope">
<div> <div>
<img :src="scope.row.goodImg" alt="" style="height: 50px;"> <img :src="scope.row.goodImg" alt="" style="height: 50px;">
</div> </div>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column prop="name" label="商品名称"></el-table-column> <el-table-column prop="name" label="课程名称"></el-table-column>
<el-table-column prop="price" label="商品价格" width="180"></el-table-column> <el-table-column prop="price" label="单次价格" width="100"></el-table-column>
<el-table-column prop="type" label="商品类型"></el-table-column> <el-table-column label="展开时间段" type="expand" width="80">
<el-table-column prop="inventory" label="商品数量"></el-table-column> <template #default="props">
<el-table-column prop="createTime" label="创建时间"></el-table-column> <!-- 放后端传来的预约时间 -->
<el-table-column prop="updateTime" label="更新时间"></el-table-column> <el-table :data="props.row.appointmentDateVOS" :header-cell-style="{ 'text-align': 'center' }" :cell-style="{ 'text-align': 'center' }">
<el-table-column label="商品状态"> <el-table-column label="日期" prop="specificDate" />
<el-table-column label="人数范围" prop="numberRange" />
<el-table-column label="时间段" prop="timeSlot"/>
<el-table-column label="此段课程人数" prop=""/>
<el-table-column label="操作">
<el-button size="small" @click="">
编辑
</el-button>
<el-button size="small" @click="" type="danger">
删除
</el-button>
</el-table-column>
</el-table>
</template>
</el-table-column>
<el-table-column label="商品状态" width="80">
<template #default="scope"> <template #default="scope">
<div> <div>
<span style="margin-left: 10px" v-if="scope.row.isShelves == 1">上架</span> <span style="margin-left: 10px" v-if="scope.row.isShelves == 1">上架</span>
@ -174,48 +184,49 @@
</span> </span>
</template> </template>
</el-dialog> </el-dialog>
</template> </template>
<script setup lang="ts"> <script setup lang="ts">
import { ElMessage , type UploadProps , genFileId ,type UploadRawFile } from 'element-plus'; import { ElMessage , type UploadProps , genFileId ,type UploadRawFile } from 'element-plus';
import { ref, onMounted, inject } from 'vue'; import { ref, onMounted, inject } from 'vue';
import myAxios from "@/api/myAxios"; import myAxios from "@/api/myAxios";
const total = ref(0); // const total = ref(0); //
const idList = ref([]); const idList = ref([]);
const searchParams: any = ref({ // const searchParams: any = ref({ //
current: 1, // current: 1, //
pageSize: 5, // pageSize: 5, //
sortField: "id", //ID sortField: "id", //ID
sortOrder: "descend" // sortOrder: "descend" //
}) })
const fileSimple = ref() const fileSimple = ref()
const disabled = ref(true) const disabled = ref(true)
const title = ref('') // const title = ref('') //
const productName = ref(''); const productName = ref('');
const DialogVisible = ref(false); const DialogVisible = ref(false);
const state = ref(''); //select const state = ref(''); //select
const tableData : any= ref([]); const tableData : any= ref([]);
const editForm : any = ref({}); const editForm : any = ref({});
const reload : any = inject("reload") // const reload : any = inject("reload") //
const uploadProductImg : any = ref() //ref const uploadProductImg : any = ref() //ref
const uploadProductDetail : any = ref() //ref const uploadProductDetail : any = ref() //ref
const typeList: any = ref([ const typeList: any = ref([
{ {
value1: '', value1: '',
label: '' label: ''
} }
]) ])
onMounted(() => { // onMounted(() => { //
getProductList() getProductList()
getTypeList() })
}) const getProductList = async () => {
const getProductList = async () => {
try { try {
const res = await myAxios.post('/goods/list/page', { ...searchParams.value }); const res = await myAxios.post('/goods/service/list/page', { ...searchParams.value });
// console.log(res.data) // console.log(res.data)
if (res.data.code === 1) { if (res.data.code === 1) {
tableData.value = res.data.data.records; tableData.value = res.data.data.records;
total.value = parseInt(res.data.data.total) // total.value = parseInt(res.data.data.total) //
console.log(tableData.value);
} else { } else {
ElMessage({ ElMessage({
message: '获取数据失败', message: '获取数据失败',
@ -227,40 +238,16 @@
message: '发生错误', message: '发生错误',
}); });
} }
} }
const getTypeList = async () => { const saveEdit = async () => { //
const res = await myAxios.post('/category/list', {}) // }
for (let key in res.data.data) { // const searchByState = (event : any) => { ///
typeList.value[key] = {
value1: res.data.data[key].typeName,
label: res.data.data[key].typeName
}
}
}
const saveEdit = async () => { //
const res = await myAxios.post('/goods/update',{...editForm.value})
if( res.data.code === 1 ) {
ElMessage({
type: 'success',
message: '更新成功'
})
DialogVisible.value = false
} else {
ElMessage.error('更新失败,请检查字段')
}
}
const searchByType =(event : any)=>{ //
searchParams.value.type = event
searchParams.value.current = 1
getProductList()
}
const searchByState = (event : any) => { ///
searchParams.value.isShelves = event searchParams.value.isShelves = event
searchParams.value.current = 1 searchParams.value.current = 1
getProductList() getProductList()
} }
// //
const deleteProduct = async (index: number) => { const deleteProduct = async (index: number) => {
console.log(typeof index) console.log(typeof index)
const res = await myAxios.post('/goods/delete', { id: index }) const res = await myAxios.post('/goods/delete', { id: index })
console.log(res) console.log(res)
@ -271,18 +258,17 @@
}) })
getProductList() getProductList()
} }
getTypeList() }
} //--->
//---> //
// const ReviseOrView = (index: number, row: any , flag : number) => {
const ReviseOrView = (index: number, row: any , flag : number) => {
//flag disabled //flag disabled
flag ? (title.value = "编辑商品" , disabled.value = false) : (title.value = "商品详情" , disabled.value = true) flag ? (title.value = "编辑商品" , disabled.value = false) : (title.value = "商品详情" , disabled.value = true)
DialogVisible.value = true; DialogVisible.value = true;
editForm.value = row; editForm.value = row;
}; };
//() //()
const handleOff = async (index: number, row: any) => { const handleOff = async (index: number, row: any) => {
row.isShelves ? row.isShelves = 0 : row.isShelves = 1 // row.isShelves ? row.isShelves = 0 : row.isShelves = 1 //
editForm.value = row; editForm.value = row;
const res = await myAxios.post('/goods/update',{...editForm.value}) const res = await myAxios.post('/goods/update',{...editForm.value})
@ -292,43 +278,43 @@
message:'更新成功' message:'更新成功'
}) })
} }
} }
// //
const handleSizeChange = (newSize: any) => { const handleSizeChange = (newSize: any) => {
searchParams.value.pageSize = newSize // searchParams.value.pageSize = newSize //
getProductList() getProductList()
} }
// //
const handleCurrentChange = (Current: any) => { const handleCurrentChange = (Current: any) => {
searchParams.value.current = Current searchParams.value.current = Current
getProductList() getProductList()
} }
// //
const reset = () => { const reset = () => {
reload() reload()
}; };
// -- // --
const handleRemove: UploadProps['onRemove'] = (uploadFile, uploadFiles) => { const handleRemove: UploadProps['onRemove'] = (uploadFile, uploadFiles) => {
console.log(uploadFile, uploadFiles) console.log(uploadFile, uploadFiles)
} }
const Exceed_ProductImg: UploadProps['onExceed'] = (files , flag) => { // const Exceed_ProductImg: UploadProps['onExceed'] = (files , flag) => { //
uploadProductImg.value!.clearFiles() uploadProductImg.value!.clearFiles()
const file = files[0] as UploadRawFile const file = files[0] as UploadRawFile
file.uid = genFileId() file.uid = genFileId()
uploadProductImg.value!.handleStart(file) uploadProductImg.value!.handleStart(file)
} }
const Exceed_ProductDetail: UploadProps['onExceed'] = (files) => { // const Exceed_ProductDetail: UploadProps['onExceed'] = (files) => { //
uploadProductDetail.value!.clearFiles() uploadProductDetail.value!.clearFiles()
const file = files[0] as UploadRawFile const file = files[0] as UploadRawFile
file.uid = genFileId() file.uid = genFileId()
uploadProductDetail.value!.handleStart(file) uploadProductDetail.value!.handleStart(file)
} }
// //
const loadForm = (value: any, flag: number) => { const loadForm = (value: any, flag: number) => {
flag ? editForm.value.type = value : editForm.value.festivalOrder = value // flag=1 "" flag=0 flag ? editForm.value.type = value : editForm.value.festivalOrder = value // flag=1 "" flag=0
} }
// //
const handleChange = async (file: any, flag: number) => { const handleChange = async (file: any, flag: number) => {
fileSimple.value = file fileSimple.value = file
let formData = new FormData() // FormData let formData = new FormData() // FormData
formData.append("file", fileSimple.value.raw) //fileSimple.value.raw formData formData.append("file", fileSimple.value.raw) //fileSimple.value.raw formData
@ -347,14 +333,14 @@
// flag0 flag1 // flag0 flag1
flag ? editForm.value.detailImg = res.data.data : editForm.value.goodImg = res.data.data flag ? editForm.value.detailImg = res.data.data : editForm.value.goodImg = res.data.data
} }
} }
const onSearch = (data : String)=>{ // const onSearch = (data : String)=>{ //
searchParams.value.name = data searchParams.value.name = data
searchParams.value.current = 1 searchParams.value.current = 1
getProductList() getProductList()
} }
// //
const delBatch = async ()=>{ const delBatch = async ()=>{
console.log(idList.value); console.log(idList.value);
const res = await myAxios.post('/goods/delBatch',{ const res = await myAxios.post('/goods/delBatch',{
idList: idList.value idList: idList.value
@ -369,12 +355,12 @@
} else { } else {
ElMessage.error('删除失败') ElMessage.error('删除失败')
} }
} }
const handleSelectionChange =()=>{} const handleSelectionChange =()=>{}
</script> </script>
<style scoped> <style scoped>
.headerBg { .headerBg {
background-color: #eee !important; background-color: #eee !important;
} }
</style> </style>