You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

215 lines
5.2 KiB

<script setup>
import { ref, reactive, onMounted, toRefs } from "vue";
import { Plus, Edit, Delete, ArrowDown } from "@element-plus/icons-vue";
import AscForm from "./components/Form.vue";
import { getBannerList, deleteBanner, updateBanner } from "@/api/home.js";
const state = reactive({
page: 1,
pageSize: 10,
});
const { page, pageSize } = toRefs(state);
const total = ref(0);
const loading = ref(false);
const showFormDraw = ref(false);
const tableData = ref([]);
onMounted(() => {
getTableData();
});
const getTableData = async () => {
loading.value = true;
let res = await getBannerList(state);
if (res.code === 200) {
tableData.value = res.data;
}
loading.value = false;
};
const handleAdd = () => {
editid.value = 0;
showFormDraw.value = true;
};
const handleEdit = (id) => {
editid.value = id;
showFormDraw.value = true;
};
const handleDelete = (id) => {
ElMessageBox.confirm('確認刪除此紀錄?')
.then(async () => {
let res = await deleteBanner(id);
if (res.code === 200) {
ElMessage({
message: '刪除成功.',
type: 'success',
});
getTableData();
}else{
ElMessage({
message: '刪除失敗.',
type: 'error',
});
}
})
.catch(() => {
})
};
// Pagination
const handleSizeChange = (val) => {
state.pageSize = val;
getTableData();
};
const handleCurrentChange = (val) => {
state.page = val;
getTableData();
};
const handlePrevClick = (val) => {
state.page = val;
getTableData();
};
const handleNextClick = (val) => {
state.page = val;
getTableData();
};
// 編輯排序
const editOrderId = ref(0);
const handleEditItem = (id) => {
editOrderId.value = id;
}
const handleUpdateItem = async (row) => {
let res = await updateBanner(row);
if (res.code === 200) {
ElMessage({
message: '修改成功.',
type: 'success',
});
getTableData();
} else {
ElMessage({
message: '修改失敗.',
type: 'error',
});
}
editOrderId.value = 0;
}
const handleCloseEditItem = () => {
editOrderId.value = 0;
}
// Drawer
const editid = ref(0);
const handleCloseFormDraw = (val) => {
showFormDraw.value = false;
if(val){
getTableData();
}
};
</script>
<template>
<div class="main">
<!-- Breadcrumb: Start -->
<div class="breadcrumb-section">
<div>
<el-breadcrumb separator="/">
<el-breadcrumb-item> 首頁 </el-breadcrumb-item>
<el-breadcrumb-item><a href="/">首頁輪播列表</a></el-breadcrumb-item>
</el-breadcrumb>
</div>
<div>
<el-button
type="primary"
:icon="Plus"
@click="handleAdd"
>
新增輪播
</el-button>
</div>
</div>
<!-- Breadcrumb: End -->
<el-card :body-style="{ padding: '0px' }">
<el-table :data="tableData" style="width: 100%">
<el-table-column prop="id" label="#" width="50" />
<el-table-column label="電腦版背景">
<template #default="scope">
<el-image style="width: 100px; height: 50px" :src="scope.row.imageurl1" fit="cover" :crossorigin="null" />
</template>
</el-table-column>
<el-table-column label="手機版背景">
<template #default="scope">
<el-image style="width: 50px; height: 100px" :src="scope.row.imageurl2" fit="cover" :crossorigin="null" />
</template>
</el-table-column>
<el-table-column prop="slogon" label="標題" />
<el-table-column prop="describe" label="描述" />
<el-table-column prop="sort_order" label="排序" width="80">
<template #default="scope">
<div @dblclick="handleEditItem(scope.row.id)" v-if="scope.row.id !== editOrderId">
{{ scope.row.sort_order }}
</div>
<el-input v-model="scope.row.sort_order" :style="{ width: '50px' }"
@keyup.enter="handleUpdateItem(scope.row)"
@blur="handleCloseEditItem()"
:autoFocus="true"
v-focus="scope.row.id === editOrderId"
v-else />
</template>
</el-table-column>
<el-table-column label="其他項目" width="105" fixed="right">
<template #default="scope">
<el-dropdown>
<el-button type="danger">
操作<el-icon class="el-icon--right"><arrow-down /></el-icon>
</el-button>
<template #dropdown>
<el-dropdown-menu>
<el-dropdown-item :icon="Edit" @click="handleEdit(scope.row.id)">修改</el-dropdown-item>
<el-dropdown-item :icon="Delete" @click="handleDelete(scope.row.id)">刪除</el-dropdown-item>
</el-dropdown-menu>
</template>
</el-dropdown>
</template>
</el-table-column>
</el-table>
</el-card>
</div>
<div>
<el-drawer
ref="drawerRef"
v-model="showFormDraw"
:destroy-on-close="true"
title="首頁輪撥"
direction="rtl"
size="50%">
<asc-form :editid="editid" @close="handleCloseFormDraw"/>
</el-drawer>
</div>
</template>
<style lang="less" scoped>
</style>