|  |  |  | 
|---|
|  |  |  | <div v-else class="filter"> | 
|---|
|  |  |  | <div class="filter-card"> | 
|---|
|  |  |  | <CommonSearch | 
|---|
|  |  |  | :show-add="false" | 
|---|
|  |  |  | :show-download="false" | 
|---|
|  |  |  | :amount-view="false" | 
|---|
|  |  |  | :show-action-btn="false" | 
|---|
|  |  |  | placeholder="请输入服务单编号" | 
|---|
|  |  |  | @searchClick="onFilterSearch" | 
|---|
|  |  |  | :show-add="false" | 
|---|
|  |  |  | :show-download="false" | 
|---|
|  |  |  | :amount-view="false" | 
|---|
|  |  |  | :show-action-btn="false" | 
|---|
|  |  |  | placeholder="请输入服务单编号" | 
|---|
|  |  |  | @searchClick="onFilterSearch" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <template slot="leftButton"> | 
|---|
|  |  |  | <el-button size="small" type="primary"  @click="addBtnClick">新建</el-button> | 
|---|
|  |  |  | <el-button size="small"  @click="delClick">删除</el-button> | 
|---|
|  |  |  | <el-button size="small" type="primary" @click="addBtnClick">新建</el-button> | 
|---|
|  |  |  | <!-- <el-button size="small" @click="delClick">删除</el-button> --> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  | </CommonSearch> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | 
|---|
|  |  |  | <TableCommonView | 
|---|
|  |  |  | ref="tableListRef" | 
|---|
|  |  |  | :table-list="tableList" | 
|---|
|  |  |  | :select-box="!isDetail" | 
|---|
|  |  |  | @selClientClick="selClientClick" | 
|---|
|  |  |  | @selCommonClick="selCommonClick" | 
|---|
|  |  |  | @getSelectArray="getSelectArray" | 
|---|
|  |  |  | @selTableCol="selTableCol" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <template slot="tableButton"> | 
|---|
|  |  |  | <el-table-column label="操作" width="60"> | 
|---|
|  |  |  | <el-table-column label="操作" width="100"> | 
|---|
|  |  |  | <template slot-scope="scope"> | 
|---|
|  |  |  | <el-button @click="handleClick(scope.row)" type="text" size="small">编辑</el-button> | 
|---|
|  |  |  | <!-- <el-button @click="delClick(scope.row.id)" type="text" size="small">删除</el-button> --> | 
|---|
|  |  |  | <el-button @click="delClick(scope.row.id)" type="text" size="small">删除</el-button> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  | </el-table-column> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  | 
|---|
|  |  |  | <div class="btn-pager"> | 
|---|
|  |  |  | <PagerView class="page" :pager-options="pagerOptions" v-on="pagerEvents" /> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | selValueList: [], | 
|---|
|  |  |  | keyword: "", | 
|---|
|  |  |  | keywordType: "" | 
|---|
|  |  |  | keywordType: "", | 
|---|
|  |  |  | tableColumn: [ | 
|---|
|  |  |  | { label: "服务单编号", prop: "serviceNumber", min: 100, isCommonClick: true, default: true }, // 服务单编号 | 
|---|
|  |  |  | { label: "主题", prop: "subject" }, // 主题 | 
|---|
|  |  |  | { label: "客户名称", prop: "client_name", min: 130, isClientClick: true }, // 客户名称 | 
|---|
|  |  |  | { label: "实际处理时间", prop: "realTime" }, // 实际处理时间 | 
|---|
|  |  |  | { label: "服务人员", prop: "serviceMan_name" }, // 服务人员 | 
|---|
|  |  |  | { label: "服务方式", prop: "serviceType_name" }, // 服务方式 | 
|---|
|  |  |  | // { label: "产品类别", prop: "reportSourceId" }, // 产品类别 | 
|---|
|  |  |  | { label: "故障类别", prop: "faultType_name" } // 故障类别 | 
|---|
|  |  |  | ], | 
|---|
|  |  |  | showCol: ["服务单编号", "主题", "客户名称", "实际处理时间", "服务人员", "服务方式", "故障类别"] | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | created() { | 
|---|
|  |  |  | 
|---|
|  |  |  | methods: { | 
|---|
|  |  |  | setTable() { | 
|---|
|  |  |  | this.tableList = { | 
|---|
|  |  |  | selectIndex: true, | 
|---|
|  |  |  | tableInfomation: [], | 
|---|
|  |  |  | tableColumn: [ | 
|---|
|  |  |  | { label: "服务单编号", prop: "serviceNumber", min: 100, isCommonClick: true }, // 服务单编号 | 
|---|
|  |  |  | { label: "主题", prop: "subject" }, // 主题 | 
|---|
|  |  |  | { label: "客户名称", prop: "client_name", min: 130, isClientClick: true }, // 客户名称 | 
|---|
|  |  |  | { label: "实际处理时间", prop: "realTime" }, // 实际处理时间 | 
|---|
|  |  |  | { label: "服务人员", prop: "serviceMan_name" }, // 服务人员 | 
|---|
|  |  |  | { label: "服务方式", prop: "serviceType_name" }, // 服务方式 | 
|---|
|  |  |  | // { label: "产品类别", prop: "reportSourceId" }, // 产品类别 | 
|---|
|  |  |  | { label: "故障类别", prop: "faultType_name" } // 故障类别 | 
|---|
|  |  |  | ] | 
|---|
|  |  |  | allcol: [], | 
|---|
|  |  |  | showcol: this.showCol, | 
|---|
|  |  |  | tableColumn: this.setColumnVisible(this.showCol) | 
|---|
|  |  |  | } | 
|---|
|  |  |  | this.tableList.allcol = this.tableList.tableColumn.filter((ele) => !ele.default).map((ele) => ele.label) | 
|---|
|  |  |  | this.searchOptions = [] | 
|---|
|  |  |  | for (let i = 0; i < this.tableList.tableColumn.length; i++) { | 
|---|
|  |  |  | const label = this.tableList.tableColumn[i].label | 
|---|
|  |  |  | const value = this.tableList.tableColumn[i].prop | 
|---|
|  |  |  | this.searchOptions.push({ value: value, label: label }) | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | setColumnVisible(showCol) { | 
|---|
|  |  |  | return this.tableColumn.map((ele) => { | 
|---|
|  |  |  | return { | 
|---|
|  |  |  | ...ele, | 
|---|
|  |  |  | isShowColumn: showCol.includes(ele.label) | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | selTableCol(val) { | 
|---|
|  |  |  | this.showcol = val | 
|---|
|  |  |  | this.tableList.tableColumn = this.setColumnVisible(val) | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | // 请求数据 | 
|---|
|  |  |  | async getData() { | 
|---|
|  |  |  | 
|---|
|  |  |  | keywordType: this.keywordType, | 
|---|
|  |  |  | page: this.pagerOptions.currPage, | 
|---|
|  |  |  | pageSize: this.pagerOptions.pageSize, | 
|---|
|  |  |  | salesDetailsId: 0, | 
|---|
|  |  |  | serviceContractId: 0 | 
|---|
|  |  |  | sourceId: this.addConfig.id | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | .then((res) => { | 
|---|
|  |  |  | console.log(res) | 
|---|
|  |  |  | 
|---|
|  |  |  | console.log(tab, event) | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | // 搜索 | 
|---|
|  |  |  | onFilterSearch(searchText){ | 
|---|
|  |  |  | onFilterSearch(searchText) { | 
|---|
|  |  |  | this.keyword = searchText ?? "" | 
|---|
|  |  |  | this.keywordType =searchText ? "服务单编号" : '' | 
|---|
|  |  |  | this.keywordType = searchText ? "服务单编号" : "" | 
|---|
|  |  |  | this.pagerOptions.currPage = 1 | 
|---|
|  |  |  | this.getData() | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | 
|---|
|  |  |  | addBtnClick() { | 
|---|
|  |  |  | this.editConfig.visible = true | 
|---|
|  |  |  | this.editConfig.title = "新建" | 
|---|
|  |  |  | this.editConfig.infomation = {} | 
|---|
|  |  |  | this.editConfig.infomation = { | 
|---|
|  |  |  | client_name: "", | 
|---|
|  |  |  | serviceContract_Number: "", | 
|---|
|  |  |  | number: "", | 
|---|
|  |  |  | productName: "", | 
|---|
|  |  |  | contact_name: "", | 
|---|
|  |  |  | sale_chance_name: "" | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | // 编辑 | 
|---|
|  |  |  | handleClick(row) { | 
|---|
|  |  |  | console.log(row) | 
|---|
|  |  |  | this.editConfig.visible = true | 
|---|
|  |  |  | this.editConfig.title = "编辑" | 
|---|
|  |  |  | this.editConfig.infomation = { ...row, contact_name: row.Contact.name, service_number: row.serviceContractId } | 
|---|
|  |  |  | this.editConfig.infomation = { | 
|---|
|  |  |  | ...row, | 
|---|
|  |  |  | contact_name: row.Contact.name, | 
|---|
|  |  |  | service_number: row.serviceContractId, | 
|---|
|  |  |  | number: row.SalesDetails.number, | 
|---|
|  |  |  | sale_chance_name: row.SaleChance.name | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | // 删除 | 
|---|
|  |  |  | delClick() { | 
|---|
|  |  |  | if (this.selValueList && this.selValueList.length > 0) { | 
|---|
|  |  |  | this.$confirm("是否确认删除?", "警告", { | 
|---|
|  |  |  | confirmButtonText: "确定", | 
|---|
|  |  |  | cancelButtonText: "取消", | 
|---|
|  |  |  | type: "warning" | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | .then(() => { | 
|---|
|  |  |  | getDelServiceOrder({ ids: this.selValueList }).then((response) => { | 
|---|
|  |  |  | if (response.code === 200) { | 
|---|
|  |  |  | this.$message.success("删除成功") | 
|---|
|  |  |  | this.getData() | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | this.$message.warning("删除失败") | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | delClick(id) { | 
|---|
|  |  |  | // if (this.selValueList && this.selValueList.length > 0) { | 
|---|
|  |  |  | this.$confirm("是否确认删除?", "警告", { | 
|---|
|  |  |  | confirmButtonText: "确定", | 
|---|
|  |  |  | cancelButtonText: "取消", | 
|---|
|  |  |  | type: "warning" | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | .then(() => { | 
|---|
|  |  |  | getDelServiceOrder({ ids: [id] }).then((response) => { | 
|---|
|  |  |  | if (response.code === 200) { | 
|---|
|  |  |  | this.$message.success("删除成功") | 
|---|
|  |  |  | this.getData() | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | this.$message.warning("删除失败") | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | .catch(() => {}) | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | this.$message.warning("请至少选择一条记录") | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | .catch(() => {}) | 
|---|
|  |  |  | // } else { | 
|---|
|  |  |  | //   this.$message.warning("请至少选择一条记录") | 
|---|
|  |  |  | // } | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | getSelectArray(val) { | 
|---|
|  |  |  | console.log(val) | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .sales-lead{ | 
|---|
|  |  |  | .sales-lead { | 
|---|
|  |  |  | height: 100%; | 
|---|
|  |  |  | overflow: hidden; | 
|---|
|  |  |  | .filter{ | 
|---|
|  |  |  | .filter { | 
|---|
|  |  |  | height: 80px; | 
|---|
|  |  |  | display: flex; | 
|---|
|  |  |  | align-items: center; | 
|---|
|  |  |  | padding: 12px 20px 0 20px; | 
|---|
|  |  |  | &-card{ | 
|---|
|  |  |  | &-card { | 
|---|
|  |  |  | height: 80px; | 
|---|
|  |  |  | display: flex; | 
|---|
|  |  |  | align-items: center; | 
|---|
|  |  |  | 
|---|
|  |  |  | background-color: #fff; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | .body{ | 
|---|
|  |  |  | .body { | 
|---|
|  |  |  | box-sizing: border-box; | 
|---|
|  |  |  | padding: 10px 20px; | 
|---|
|  |  |  | border-radius: 12px; | 
|---|