From 426d3d33f23bd04e7cafda728cdcc82f11d5baa3 Mon Sep 17 00:00:00 2001
From: odc.xiaohui <xiaohui@Q1>
Date: 星期二, 21 二月 2023 17:09:07 +0800
Subject: [PATCH] Merge branch 'dev1.0' of http://42.193.1.25:9521/r/sccg_ui into dev1.0
---
src/views/systemSetting/device/loudspeaker/index.vue | 203 +++++++++++++++++++++++++++++---------------------
1 files changed, 119 insertions(+), 84 deletions(-)
diff --git a/src/views/systemSetting/device/loudspeaker/index.vue b/src/views/systemSetting/device/loudspeaker/index.vue
index 7a427c8..3f323ca 100644
--- a/src/views/systemSetting/device/loudspeaker/index.vue
+++ b/src/views/systemSetting/device/loudspeaker/index.vue
@@ -4,7 +4,11 @@
<div class="header-content">
<div class="search">
<span style="padding-right: 20px">绛涢�夋潯浠�:</span>
- <el-select v-model="context" placeholder="绛涢�夋潯浠�">
+ <el-select
+ v-model="context"
+ placeholder="绛涢�夋潯浠�"
+ @change="handleStateChange"
+ >
<el-option
v-for="item in options"
:key="item.value"
@@ -14,30 +18,31 @@
</el-option>
</el-select>
</div>
+ <div class="main-title">
+ <el-button
+ class="el-icon-plus button-addition"
+ type="primary"
+ @click="handleAdd"
+ >娣诲姞</el-button
+ >
+ </div>
</div>
</header>
<main>
<div class="main-content">
- <div class="main-title">
- <el-button
- class="el-icon-plus"
- type="primary"
- @click="dialogCreate = true"
- >娣诲姞</el-button
- >
- </div>
<!-- 鏁版嵁灞曠ず -->
<el-table
+ border
+ stripe
ref="multipleTable"
:header-cell-style="{
- background: '#06122c',
- 'font-size': '12px',
- color: '#4b9bb7',
+ background: '#F5F5F5',
'font-weight': '650',
'line-height': '45px',
}"
:data="list"
style="width: 100%"
+ :row-class-name="tableRowClassName"
>
<el-table-column type="selection" min-width="5"> </el-table-column>
<el-table-column prop="name" label="闊虫煴鍚嶇О" min-width="10">
@@ -67,7 +72,7 @@
</el-table-column>
<el-table-column prop="operation" label="鎿嶄綔" min-width="20">
<template slot-scope="scope">
- <div class="btn">
+ <div class="operation">
<span @click="handleEdit(scope.row)">缂栬緫</span>
<span class="line">|</span>
<span @click="handleDelete(scope.row)">鍒犻櫎</span>
@@ -75,6 +80,24 @@
</template>
</el-table-column>
</el-table>
+
+ <!-- tools -->
+ <div class="tools">
+ <div class="funs"></div>
+ <div class="pagination">
+ <el-pagination
+ background
+ :current-page="currentPage"
+ layout="prev, pager, next"
+ :total="totalNum"
+ :page-size="pageSize"
+ @current-change="changeCurrentPage"
+ @prev-click="handlePrev"
+ @next-click="handleNext"
+ >
+ </el-pagination>
+ </div>
+ </div>
</div>
</main>
<footer>
@@ -85,7 +108,7 @@
width="60%"
:before-close="handleClose"
>
- <MyForm :info="loudspeakerInfo" :closeDialog="null"></MyForm>
+ <MyForm :info="loudspeakerInfo" @closeDialog="handleCallBack"></MyForm>
</el-dialog>
</footer>
</div>
@@ -102,7 +125,7 @@
data() {
return {
dialogCreate: false,
- context: 0,
+ context: null,
options: [
{
value: null,
@@ -118,16 +141,11 @@
},
],
list: [],
- current: 1,
- size: 10,
- loudspeakerInfo: {
- id: 0,
- name: "",
- code: "",
- power: "",
- frequencyResponse: "",
- fullRangeSpeaker: "",
- },
+ totalNum: 0,
+ pageSize: 10,
+ currentPage: 1,
+ renderFlag: false,
+ loudspeakerInfo: {},
};
},
created() {
@@ -138,9 +156,50 @@
"getLoudspeakerList",
"saveLoudspeaker",
"updateLoudspeaker",
+ "deleteLoudspeaker",
]),
+ handleAdd() {
+ this.loudspeakerInfo = {
+ id: 0,
+ name: "",
+ code: "",
+ power: "",
+ frequencyResponse: "",
+ fullRangeSpeaker: "",
+ };
+ this.dialogCreate = true;
+ },
+ handleEdit(row) {
+ this.loudspeakerInfo = row;
+ this.dialogCreate = true;
+ },
+ handleDelete(row) {
+ this.$confirm("纭鍒犻櫎锛�").then((_) => {
+ this.deleteLoudspeaker(row.id).then((res) => {
+ this.$message({
+ type: "success",
+ message: "鍒犻櫎鎴愬姛锛�",
+ });
+ this.setTableData();
+ });
+ });
+ },
formatSate(row, column) {
return row.state == 1 ? "鍦ㄧ嚎" : "绂荤嚎";
+ },
+ handleCallBack(e) {
+ this.currentPage = 1;
+ this.dialogCreate = false;
+ this.setTableData();
+ },
+ // 璁剧疆琛ㄦ牸鏂戦┈绾�
+ tableRowClassName({ row, rowIndex }) {
+ if ((rowIndex + 1) % 2 == 0) {
+ return "warning-row";
+ } else {
+ return "success-row";
+ }
+ return "";
},
// 寮圭獥鍏抽棴
handleClose(done) {
@@ -150,13 +209,34 @@
},
// 璁剧疆tableData
setTableData() {
- const { current, size, context } = this;
- let arr = this.getLoudspeakerList({
- current,
- size,
+ const { currentPage, pageSize, context } = this;
+ this.getLoudspeakerList({
+ currentPage,
+ pageSize,
+ state: context,
}).then((res) => {
- this.list = arr.data.data;
+ this.list = res.records;
+ this.totalNum = res.total;
});
+ },
+ handleStateChange(e) {
+ this.currentPage = 1;
+ this.setTableData();
+ },
+ // 褰撳墠椤垫敼鍙樿Е鍙戜簨浠�
+ changeCurrentPage(page) {
+ this.currentPage = page;
+ this.setTableData();
+ },
+ // 涓婁竴椤电偣鍑讳簨浠�
+ handlePrev(page) {
+ this.currentPage = page;
+ this.setTableData();
+ },
+ // 涓嬩竴椤电偣鍑讳簨浠�
+ handleNext(page) {
+ this.currentPage = page;
+ this.setTableData();
},
},
};
@@ -164,15 +244,11 @@
<style lang="scss" scoped>
.list {
text-align: left;
- margin: 10px 20px;
- color: #4b9bb7;
-
+ padding: 10px 20px;
+ border: 1px solid #ccc;
header {
- background-color: #09152f;
- border: 1pox solid #fff;
-
.header-content {
- padding: 0 40px;
+ padding: 0px;
display: flex;
line-height: 100px;
justify-content: space-between;
@@ -188,27 +264,17 @@
.el-input {
flex: 2;
- color: #1d3f57;
-
- &::v-deep .el-input__inner {
- background-color: #09152f;
- border: 1px solid #17324c;
- }
}
+ }
+ .main-title {
+ line-height: 60px;
+ padding: 0;
}
}
}
main {
- background-color: #09152f;
- margin-top: 20px;
padding-bottom: 50px;
- border: 1pox solid #fff;
-
- .main-title {
- line-height: 60px;
- padding: 10px 20px;
- }
.tools {
display: flex;
@@ -223,7 +289,6 @@
line-height: 28px;
display: flex;
align-items: center;
- border: 1px solid #17324c;
border-radius: 4px;
font-size: 12px;
margin-left: 10px;
@@ -236,19 +301,6 @@
.el-select {
width: 120px;
}
-
- &::v-deep .el-input__inner {
- border: none;
- background-color: #09152f;
- }
-
- &:hover {
- border: 1px solid #4b9bb7;
- }
-
- &:hover .el-checkbox {
- color: #4b9bb7;
- }
}
}
@@ -257,30 +309,13 @@
display: flex;
line-height: 50px;
justify-content: center;
-
- .el-pagination {
- &::v-deep li,
- &::v-deep .btn-prev,
- &::v-deep .btn-next {
- background-color: #071f39;
- color: #4b9bb7;
- }
-
- &::v-deep .active {
- background-color: #409eff;
- color: #fff;
- }
- }
}
}
.el-table {
- color: #4b9bb7;
- font-size: 10px;
-
.operation {
display: flex;
-
+ color: var(--operation-color);
.line {
padding: 0 5px;
}
@@ -292,4 +327,4 @@
}
}
}
-</style>
\ No newline at end of file
+</style>
--
Gitblit v1.8.0