|  |  |  | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <!-- 表格和分页 --> | 
|---|
|  |  |  | <template v-slot:table-wrap> | 
|---|
|  |  |  | <ul | 
|---|
|  |  |  | class="toolbar" | 
|---|
|  |  |  | v-permissions="[ | 
|---|
|  |  |  | 'business:carusebook:create', | 
|---|
|  |  |  | 'business:carusebook:exportExcel', | 
|---|
|  |  |  | ]" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <ul class="toolbar" v-permissions="[ | 
|---|
|  |  |  | 'business:carusebook:create', | 
|---|
|  |  |  | 'business:carusebook:exportExcel', | 
|---|
|  |  |  | ]"> | 
|---|
|  |  |  | <li> | 
|---|
|  |  |  | <el-button | 
|---|
|  |  |  | type="primary" | 
|---|
|  |  |  | @click="handleEdit" | 
|---|
|  |  |  | icon="el-icon-plus" | 
|---|
|  |  |  | v-permissions="['business:carusebook:create']" | 
|---|
|  |  |  | >新建</el-button | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <el-button type="primary" @click="handleEdit" icon="el-icon-plus" | 
|---|
|  |  |  | v-permissions="['business:carusebook:create']">新建</el-button> | 
|---|
|  |  |  | </li> | 
|---|
|  |  |  | <li> | 
|---|
|  |  |  | <el-button | 
|---|
|  |  |  | type="primary" | 
|---|
|  |  |  | @click="handleEx" | 
|---|
|  |  |  | v-permissions="['business:carusebook:exportExcel']" | 
|---|
|  |  |  | >导出</el-button | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <el-button type="primary" @click="handleEx" v-permissions="['business:carusebook:exportExcel']">导出</el-button> | 
|---|
|  |  |  | </li> | 
|---|
|  |  |  | </ul> | 
|---|
|  |  |  | <el-table :height="tableHeightNew" v-loading="isWorking.search" :data="tableData.list" stripe | 
|---|
|  |  |  | @selection-change="handleSelectionChange"> | 
|---|
|  |  |  | <el-table-column type="selection" width="55"></el-table-column> | 
|---|
|  |  |  | <el-table-column | 
|---|
|  |  |  | prop="carCode" | 
|---|
|  |  |  | label="车牌号" | 
|---|
|  |  |  | min-width="100px" | 
|---|
|  |  |  | ></el-table-column> | 
|---|
|  |  |  | <el-table-column | 
|---|
|  |  |  | prop="memberName" | 
|---|
|  |  |  | label="提报人" | 
|---|
|  |  |  | min-width="80px" | 
|---|
|  |  |  | ></el-table-column> | 
|---|
|  |  |  | <el-table-column | 
|---|
|  |  |  | prop="memberNames" | 
|---|
|  |  |  | label="乘车人" | 
|---|
|  |  |  | min-width="180px" | 
|---|
|  |  |  | ></el-table-column> | 
|---|
|  |  |  | <el-table-column | 
|---|
|  |  |  | prop="companyName" | 
|---|
|  |  |  | label="所属组织" | 
|---|
|  |  |  | min-width="150px" | 
|---|
|  |  |  | ></el-table-column> | 
|---|
|  |  |  | <el-table-column prop="carCode" label="车牌号" min-width="100px"></el-table-column> | 
|---|
|  |  |  | <el-table-column prop="memberName" label="提报人" min-width="80px"></el-table-column> | 
|---|
|  |  |  | <el-table-column prop="memberNames" label="乘车人" min-width="180px"></el-table-column> | 
|---|
|  |  |  | <el-table-column prop="companyName" label="所属组织" min-width="150px"></el-table-column> | 
|---|
|  |  |  | <el-table-column label="用车时间" min-width="170px"> | 
|---|
|  |  |  | <template slot-scope="{ row }"> | 
|---|
|  |  |  | <span v-if="row.startTime">起:{{ row.startTime.slice(0,16) }}</span | 
|---|
|  |  |  | ><br /> | 
|---|
|  |  |  | <span v-if="row.endTime">止:{{ row.endTime.slice(0,16) }}</span> | 
|---|
|  |  |  | <span v-if="row.startTime">起:{{ row.startTime.slice(0, 16) }}</span><br /> | 
|---|
|  |  |  | <span v-if="row.endTime">止:{{ row.endTime.slice(0, 16) }}</span> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  | </el-table-column> | 
|---|
|  |  |  | <el-table-column | 
|---|
|  |  |  | prop="planUseDate" | 
|---|
|  |  |  | label="出发时间" | 
|---|
|  |  |  | min-width="150px" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <template slot-scope="{ row }"> | 
|---|
|  |  |  | <span v-if="row.planUseDate">{{ row.planUseDate.slice(0,16) }}</span> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  | </el-table-column> | 
|---|
|  |  |  | <el-table-column prop="planUseDate" label="出发时间" min-width="150px"> | 
|---|
|  |  |  | <template slot-scope="{ row }"> | 
|---|
|  |  |  | <span v-if="row.planUseDate">{{ row.planUseDate.slice(0, 16) }}</span> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  | </el-table-column> | 
|---|
|  |  |  | <el-table-column label="目的地" min-width="200px"> | 
|---|
|  |  |  | <template slot-scope="{ row }"> | 
|---|
|  |  |  | <span class="status-green" v-if="row.type === 0">【市内】</span> | 
|---|
|  |  |  | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  | </el-table-column> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <el-table-column | 
|---|
|  |  |  | prop="createDate" | 
|---|
|  |  |  | label="申请时间" | 
|---|
|  |  |  | min-width="150px" | 
|---|
|  |  |  | ></el-table-column> | 
|---|
|  |  |  | <el-table-column | 
|---|
|  |  |  | prop="editDate" | 
|---|
|  |  |  | label="操作时间" | 
|---|
|  |  |  | min-width="150px" | 
|---|
|  |  |  | ></el-table-column> | 
|---|
|  |  |  | <el-table-column | 
|---|
|  |  |  | label="操作" | 
|---|
|  |  |  | min-width="180" | 
|---|
|  |  |  | align="center" | 
|---|
|  |  |  | fixed="right" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <el-table-column prop="createDate" label="申请时间" min-width="150px"></el-table-column> | 
|---|
|  |  |  | <el-table-column prop="editDate" label="操作时间" min-width="150px"></el-table-column> | 
|---|
|  |  |  | <el-table-column label="操作" min-width="180" align="center" fixed="right"> | 
|---|
|  |  |  | <template slot-scope="{ row }"> | 
|---|
|  |  |  | <el-button | 
|---|
|  |  |  | type="text" | 
|---|
|  |  |  | icon="el-icon-edit" | 
|---|
|  |  |  | @click="$refs.OperaDetailsWindow.open('公务车申请详情', row)" | 
|---|
|  |  |  | >查看详情</el-button | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <el-button type="text" icon="el-icon-edit" | 
|---|
|  |  |  | @click="$refs.OperaDetailsWindow.open('公务车申请详情', row)">查看详情</el-button> | 
|---|
|  |  |  | <!-- <el-button v-if="(row.status === 1 || row.status === 2) && new Date().getTime() < new Date(row.startTime).getTime()" type="text" icon="el-icon-delete" @click="rowRevokeClick(row)" >撤销</el-button> --> | 
|---|
|  |  |  | <el-button style="color: red" v-if="row.hasRole ==1"  type="text"  icon="el-icon-delete"   @click="rowRevokeClick(row)" >撤销</el-button> | 
|---|
|  |  |  | <el-button style="color: red" v-if="row.hasRole == 1" type="text" icon="el-icon-delete" | 
|---|
|  |  |  | @click="rowRevokeClick(row)">撤销</el-button> | 
|---|
|  |  |  | <!-- <el-button style="color: red"   v-if="(row.status === 0 && row.creator == userInfo.id)||((row.status === 0 || row.status === 1 ) || ( row.status === 2 && new Date().getTime() < new Date(row.startTime).getTime() ))"  type="text"  icon="el-icon-delete"   @click="rowRevokeClick(row)" >撤销</el-button>--> | 
|---|
|  |  |  | <el-button  style="color: red" type="text"  icon="el-icon-delete"   v-permissions="['business:carusebook:delete']"  @click="deleteById(row)" >删除</el-button> | 
|---|
|  |  |  | <el-button style="color: red" type="text" icon="el-icon-delete" | 
|---|
|  |  |  | v-permissions="['business:carusebook:delete']" @click="deleteById(row)">删除</el-button> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  | </el-table-column> | 
|---|
|  |  |  | </el-table> | 
|---|
|  |  |  | <pagination | 
|---|
|  |  |  | @size-change="handleSizeChange" | 
|---|
|  |  |  | @current-change="handlePageChange" | 
|---|
|  |  |  | :pagination="tableData.pagination" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <pagination @size-change="handleSizeChange" @current-change="handlePageChange" :pagination="tableData.pagination"> | 
|---|
|  |  |  | </pagination> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  | <!--  --> | 
|---|
|  |  |  | <el-dialog title="用车撤销" :visible.sync="isShowBack" width="520px"> | 
|---|
|  |  |  | <el-form | 
|---|
|  |  |  | :model="backParam" | 
|---|
|  |  |  | :rules="rules" | 
|---|
|  |  |  | ref="backForm" | 
|---|
|  |  |  | label-width="100px" | 
|---|
|  |  |  | class="demo-ruleForm" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <el-form :model="backParam" :rules="rules" ref="backForm" label-width="100px" class="demo-ruleForm"> | 
|---|
|  |  |  | <el-form-item label="说明" prop="info"> | 
|---|
|  |  |  | <el-input | 
|---|
|  |  |  | type="textarea" | 
|---|
|  |  |  | :rows="4" | 
|---|
|  |  |  | v-model="backParam.info" | 
|---|
|  |  |  | placeholder="请输入撤销说明" | 
|---|
|  |  |  | ></el-input> | 
|---|
|  |  |  | <el-input type="textarea" :rows="4" v-model="backParam.info" placeholder="请输入撤销说明"></el-input> | 
|---|
|  |  |  | </el-form-item> | 
|---|
|  |  |  | </el-form> | 
|---|
|  |  |  | <span slot="footer" class="dialog-footer"> | 
|---|
|  |  |  | 
|---|
|  |  |  | <el-button type="primary" @click="backSubmit">确定</el-button> | 
|---|
|  |  |  | </span> | 
|---|
|  |  |  | </el-dialog> | 
|---|
|  |  |  | <OperaCarUseBookWindow | 
|---|
|  |  |  | ref="OperaDetailsWindow" | 
|---|
|  |  |  | @success="handlePageChange" | 
|---|
|  |  |  | /> | 
|---|
|  |  |  | <OperaCarUseBookWindow ref="OperaDetailsWindow" @success="handlePageChange" /> | 
|---|
|  |  |  | <OperaCarUseBookParamWindow ref="OperaParamWindow" @success="search" /> | 
|---|
|  |  |  | </TableLayout> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  | 
|---|
|  |  |  | name: 'Empower', | 
|---|
|  |  |  | extends: BaseTable, | 
|---|
|  |  |  | components: { TableLayout, Pagination, OperaCarUseBookWindow, OperaCarUseBookParamWindow }, | 
|---|
|  |  |  | data () { | 
|---|
|  |  |  | data() { | 
|---|
|  |  |  | return { | 
|---|
|  |  |  | // userInfo: this.$store.state.userInfo, | 
|---|
|  |  |  | // 搜索 | 
|---|
|  |  |  | searchForm: { | 
|---|
|  |  |  | memberName: '', | 
|---|
|  |  |  | companyName: '', | 
|---|
|  |  |  | startTime: '', | 
|---|
|  |  |  | endTime: '', | 
|---|
|  |  |  | queryStartTime: '', | 
|---|
|  |  |  | queryEndTime: '', | 
|---|
|  |  |  | type: null, | 
|---|
|  |  |  | status: null, | 
|---|
|  |  |  | radio: 0 | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | created () { | 
|---|
|  |  |  | created() { | 
|---|
|  |  |  | this.config({ | 
|---|
|  |  |  | module: '用车申请管理', | 
|---|
|  |  |  | api: '/business/carUseBook', | 
|---|
|  |  |  | 
|---|
|  |  |  | 'field.main': 'id' | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | // this.search() | 
|---|
|  |  |  | this.changeRadio(0) | 
|---|
|  |  |  | this.changeRadio('0') | 
|---|
|  |  |  | this.loadParams() | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | methods: { | 
|---|
|  |  |  | rowRevokeClick (row) { | 
|---|
|  |  |  | rowRevokeClick(row) { | 
|---|
|  |  |  | this.isShowBack = true | 
|---|
|  |  |  | this.backParam = {} | 
|---|
|  |  |  | this.$set(this.backParam, 'id', row.id) | 
|---|
|  |  |  | 
|---|
|  |  |  | this.$refs.backForm.clearValidate() | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | backSubmit () { | 
|---|
|  |  |  | backSubmit() { | 
|---|
|  |  |  | revokeById({ ...this.backParam }).then(res => { | 
|---|
|  |  |  | this.$tip.success('撤销成功') | 
|---|
|  |  |  | this.isShowBack = false | 
|---|
|  |  |  | this.search() | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | handleEx () { | 
|---|
|  |  |  | handleEx() { | 
|---|
|  |  |  | this.$dialog.exportConfirm('确认导出吗?') | 
|---|
|  |  |  | .then(() => { | 
|---|
|  |  |  | this.exLoading = true | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | this.search() | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | handleEdit () { | 
|---|
|  |  |  | handleEdit() { | 
|---|
|  |  |  | this.$refs.OperaParamWindow.open() | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | loadParams () { | 
|---|
|  |  |  | loadParams() { | 
|---|
|  |  |  | allList({ | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | .then(res => { | 
|---|
|  |  |  | 
|---|
|  |  |  | .finally(() => { | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | seleTime (e) { | 
|---|
|  |  |  | seleTime(e) { | 
|---|
|  |  |  | this.searchForm.queryStartTime = null | 
|---|
|  |  |  | this.searchForm.queryEndTime = null | 
|---|
|  |  |  | if (e != null && e.length >= 2) { | 
|---|
|  |  |  | 
|---|
|  |  |  | this.searchForm.radio = null | 
|---|
|  |  |  | this.search() | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | reset () { | 
|---|
|  |  |  | reset() { | 
|---|
|  |  |  | this.$refs.searchForm.resetFields() | 
|---|
|  |  |  | this.searchForm.radio = 0 | 
|---|
|  |  |  | this.changeRadio(0) | 
|---|
|  |  |  | // this.search() | 
|---|
|  |  |  | this.searchForm = { | 
|---|
|  |  |  | memberName: '', | 
|---|
|  |  |  | companyName: '', | 
|---|
|  |  |  | queryStartTime: '', | 
|---|
|  |  |  | queryEndTime: '', | 
|---|
|  |  |  | type: null, | 
|---|
|  |  |  | status: null, | 
|---|
|  |  |  | radio: '' | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // this.changeRadio(0) | 
|---|
|  |  |  | this.search() | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|