|  |  |  | 
|---|
|  |  |  | <template> | 
|---|
|  |  |  | <div class="generate-plan"> | 
|---|
|  |  |  | <SearchCommonView ref="searchCommonView" :query-class-options="queryClassOptions" :search-options="searchOptions" /> | 
|---|
|  |  |  | <div class="btn-pager"> | 
|---|
|  |  |  | <PublicFunctionBtnView :operates-list="operatesList" /> | 
|---|
|  |  |  | <PagerView class="page" /> | 
|---|
|  |  |  | <div class="top"> | 
|---|
|  |  |  | <SearchCommonView | 
|---|
|  |  |  | ref="searchCommonView" | 
|---|
|  |  |  | :query-class-options="queryClassOptions" | 
|---|
|  |  |  | :search-options="searchOptions" | 
|---|
|  |  |  | @searchClick="searchClick" | 
|---|
|  |  |  | @resetClick="resetClick" | 
|---|
|  |  |  | /> | 
|---|
|  |  |  | <div class="btn-pager"> | 
|---|
|  |  |  | <PublicFunctionBtnView :operates-list="operatesList" @batchDelete="delClick" /> | 
|---|
|  |  |  | <PagerView class="page" :pager-options="pagerOptions" v-on="pagerEvents" /> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <TableCommonView ref="tableListRef" :table-list="tableList"> | 
|---|
|  |  |  | <TableCommonView | 
|---|
|  |  |  | ref="tableListRef" | 
|---|
|  |  |  | :table-list="tableList" | 
|---|
|  |  |  | @selCommonClick="selCommonClick" | 
|---|
|  |  |  | @getSelectArray="getSelectArray" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <template slot="tableButton"> | 
|---|
|  |  |  | <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> --> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  | </el-table-column> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  | </TableCommonView> | 
|---|
|  |  |  | <!-- 新建/编辑--> | 
|---|
|  |  |  | <AddGeneratePlanDialog v-if="editConfig.visible" :edit-common-config="editConfig" /> | 
|---|
|  |  |  | <!-- 生产计划详情 --> | 
|---|
|  |  |  | <DetailGeneratePlan v-if="planDetail.visible" :plan-detail="planDetail" /> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <script> | 
|---|
|  |  |  | import SearchCommonView from "@/components/makepager/SearchCommonView" | 
|---|
|  |  |  | import PublicFunctionBtnView from "@/components/makepager/PublicFunctionBtnView" | 
|---|
|  |  |  | import PagerView from "@/components/makepager/PagerView" | 
|---|
|  |  |  | import TableCommonView from "@/components/makepager/TableCommonView" | 
|---|
|  |  |  | import AddGeneratePlanDialog from "@/views/sales/generatePlan/AddGeneratePlanDialog" | 
|---|
|  |  |  | import { getPlanList, getDelPlan } from "@/api/sales/generatePlan" | 
|---|
|  |  |  | import pageMixin from "@/components/makepager/pager/mixin/pageMixin" | 
|---|
|  |  |  | import DetailGeneratePlan from "@/views/sales/generatePlan/DetailGeneratePlan" | 
|---|
|  |  |  |  | 
|---|
|  |  |  | export default { | 
|---|
|  |  |  | name: "GeneratePlan", | 
|---|
|  |  |  | props: {}, | 
|---|
|  |  |  | mixins: [pageMixin], | 
|---|
|  |  |  | components: { | 
|---|
|  |  |  | SearchCommonView, | 
|---|
|  |  |  | PublicFunctionBtnView, | 
|---|
|  |  |  | PagerView, | 
|---|
|  |  |  | TableCommonView, | 
|---|
|  |  |  | AddGeneratePlanDialog | 
|---|
|  |  |  | AddGeneratePlanDialog, | 
|---|
|  |  |  | DetailGeneratePlan | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | computed: { | 
|---|
|  |  |  | searchCommonHeight() { | 
|---|
|  |  |  | 
|---|
|  |  |  | visible: false, | 
|---|
|  |  |  | title: "新建", | 
|---|
|  |  |  | infomation: {} | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | planDetail: { | 
|---|
|  |  |  | visible: false, | 
|---|
|  |  |  | infomation: {} | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | selValueList: [], | 
|---|
|  |  |  | search_map: {} | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | created() { | 
|---|
|  |  |  | this.setTable() | 
|---|
|  |  |  | this.getData() | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | methods: { | 
|---|
|  |  |  | setTable() { | 
|---|
|  |  |  | this.tableList = { | 
|---|
|  |  |  | tableInfomation: [ | 
|---|
|  |  |  | { | 
|---|
|  |  |  | documentNumber: "ZDYB04-2", | 
|---|
|  |  |  | owner: "系统管理员", | 
|---|
|  |  |  | approvalStatus: "未提交", | 
|---|
|  |  |  | creator: "系统管理员", | 
|---|
|  |  |  | createTime: "2023-0703 11:22:12" | 
|---|
|  |  |  | } | 
|---|
|  |  |  | ], | 
|---|
|  |  |  | tableInfomation: [], | 
|---|
|  |  |  | tableColumn: [ | 
|---|
|  |  |  | { label: "单据编号", prop: "documentNumber", min: 120 }, | 
|---|
|  |  |  | { label: "负责人", prop: "owner", min: 90 }, | 
|---|
|  |  |  | { label: "单据编号", prop: "number", min: 120, isCommonClick: true }, | 
|---|
|  |  |  | { label: "负责人", prop: "memberId", min: 90 }, | 
|---|
|  |  |  | { label: "审批状态", prop: "approvalStatus" }, | 
|---|
|  |  |  | { label: "创建人", prop: "creator", min: 100 }, | 
|---|
|  |  |  | { label: "创建时间", prop: "createTime" } | 
|---|
|  |  |  | 
|---|
|  |  |  | this.searchOptions.push({ value: (i + 1).toString(), label: label }) | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | // 请求数据 | 
|---|
|  |  |  | async getData() { | 
|---|
|  |  |  | this.loading = true | 
|---|
|  |  |  | await getPlanList({ | 
|---|
|  |  |  | search_map: this.search_map, | 
|---|
|  |  |  | page: this.pagerOptions.currPage, | 
|---|
|  |  |  | pageSize: this.pagerOptions.pageSize | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | .then((res) => { | 
|---|
|  |  |  | console.log(res) | 
|---|
|  |  |  | if (res.code === 200) { | 
|---|
|  |  |  | if (res.data.list && res.data.list.length > 0) { | 
|---|
|  |  |  | const list = res.data.list.map((item) => { | 
|---|
|  |  |  | return { | 
|---|
|  |  |  | ...item | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | this.tableList.tableInfomation = list || [] | 
|---|
|  |  |  | this.pagerOptions.totalCount = res.data.count | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | this.tableList.tableInfomation = [] | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | this.tableList.tableInfomation = [] | 
|---|
|  |  |  | } | 
|---|
|  |  |  | this.loading = false | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | .catch((err) => { | 
|---|
|  |  |  | console.log(err) | 
|---|
|  |  |  | this.tableList.tableInfomation = [] | 
|---|
|  |  |  | this.loading = false | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | // 搜索 | 
|---|
|  |  |  | searchClick(val, content) { | 
|---|
|  |  |  | console.log(val, content) | 
|---|
|  |  |  | this.search_map = { | 
|---|
|  |  |  | [val.value]: content | 
|---|
|  |  |  | } | 
|---|
|  |  |  | this.getData() | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | resetClick() { | 
|---|
|  |  |  | this.search_map = {} | 
|---|
|  |  |  | this.getData() | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | // 新建 | 
|---|
|  |  |  | addBtnClick() { | 
|---|
|  |  |  | this.editConfig.visible = true | 
|---|
|  |  |  | this.editConfig.title = "新建" | 
|---|
|  |  |  | this.editConfig.infomation = { | 
|---|
|  |  |  | customName: "", | 
|---|
|  |  |  | documentNumber: "ZDYBD04-12", | 
|---|
|  |  |  | owner: "", | 
|---|
|  |  |  | subOrder: "", | 
|---|
|  |  |  | salesDetails: "", | 
|---|
|  |  |  | planStartTime: "", | 
|---|
|  |  |  | planDeadline: "", | 
|---|
|  |  |  | approvalWorkflow: "", | 
|---|
|  |  |  | approvalSteps: "", | 
|---|
|  |  |  | approvalPerson: "", | 
|---|
|  |  |  | approvalOpinion: "" | 
|---|
|  |  |  | } | 
|---|
|  |  |  | this.editConfig.infomation = {} | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | // 编辑 | 
|---|
|  |  |  | handleClick(row) { | 
|---|
|  |  |  | console.log(row) | 
|---|
|  |  |  | this.editConfig.visible = true | 
|---|
|  |  |  | this.editConfig.title = "编辑" | 
|---|
|  |  |  | this.editConfig.infomation = { | 
|---|
|  |  |  | customName: "", | 
|---|
|  |  |  | documentNumber: "", | 
|---|
|  |  |  | owner: "", | 
|---|
|  |  |  | subOrder: "", | 
|---|
|  |  |  | salesDetails: "", | 
|---|
|  |  |  | planStartTime: "", | 
|---|
|  |  |  | planDeadline: "", | 
|---|
|  |  |  | approvalWorkflow: "", | 
|---|
|  |  |  | approvalSteps: "", | 
|---|
|  |  |  | approvalPerson: "", | 
|---|
|  |  |  | approvalOpinion: "" | 
|---|
|  |  |  | this.editConfig.infomation = { ...row } | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | // 删除 | 
|---|
|  |  |  | delClick() { | 
|---|
|  |  |  | if (this.selValueList && this.selValueList.length > 0) { | 
|---|
|  |  |  | this.$confirm("是否确认删除?", "警告", { | 
|---|
|  |  |  | confirmButtonText: "确定", | 
|---|
|  |  |  | cancelButtonText: "取消", | 
|---|
|  |  |  | type: "warning" | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | .then(() => { | 
|---|
|  |  |  | getDelPlan({ ids: this.selValueList }).then((response) => { | 
|---|
|  |  |  | if (response.code === 200) { | 
|---|
|  |  |  | this.$message.success("删除成功") | 
|---|
|  |  |  | this.getData() | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | this.$message.warning("删除失败") | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | .catch(() => {}) | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | this.$message.warning("请至少选择一条记录") | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | getSelectArray(val) { | 
|---|
|  |  |  | console.log(val) | 
|---|
|  |  |  | this.selValueList = [] | 
|---|
|  |  |  | const list = val.map((item) => { | 
|---|
|  |  |  | return item.id | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | this.selValueList = list | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | // 合同管理详情 | 
|---|
|  |  |  | selCommonClick(row) { | 
|---|
|  |  |  | console.log(row) | 
|---|
|  |  |  | this.planDetail.visible = true | 
|---|
|  |  |  | this.planDetail.infomation = { ...row } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | <!-- Add "scoped" attribute to limit CSS to this component only --> | 
|---|
|  |  |  | <style lang="scss" scoped> | 
|---|
|  |  |  | .generate-plan { | 
|---|
|  |  |  | .btn-pager { | 
|---|
|  |  |  | display: flex; | 
|---|
|  |  |  | .page { | 
|---|
|  |  |  | margin-left: auto; | 
|---|
|  |  |  | .top { | 
|---|
|  |  |  | margin-bottom: 20px; | 
|---|
|  |  |  | .btn-pager { | 
|---|
|  |  |  | display: flex; | 
|---|
|  |  |  | .page { | 
|---|
|  |  |  | margin-left: auto; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|