| | |
| | | @keyup.enter.native="handleQuery" |
| | | /> |
| | | </el-form-item> |
| | | <!-- <el-form-item label="计划类型" prop="planType">--> |
| | | <!-- <el-select v-model="queryParams.planType" placeholder="请选择计划类型" clearable>--> |
| | | <!-- <el-option--> |
| | | <!-- v-for="dict in dict.type.${dictType}"--> |
| | | <!-- :key="dict.value"--> |
| | | <!-- :label="dict.label"--> |
| | | <!-- :value="dict.value"--> |
| | | <!-- />--> |
| | | <!-- </el-select>--> |
| | | <!-- </el-form-item>--> |
| | | <el-form-item label="状态" prop="state"> |
| | | <el-input |
| | | v-model="queryParams.state" |
| | | placeholder="请输入状态" |
| | | clearable |
| | | @keyup.enter.native="handleQuery" |
| | | /> |
| | | <el-form-item label="状态" prop="status"> |
| | | <el-select v-model="queryParams.status" placeholder="请选择状态" clearable> |
| | | <el-option |
| | | v-for="dict in dict.type.plan_status" |
| | | :key="dict.value" |
| | | :label="dict.label" |
| | | :value="dict.value" |
| | | /> |
| | | </el-select> |
| | | </el-form-item> |
| | | <el-form-item label="频率" prop="frequency"> |
| | | <el-input |
| | | v-model="queryParams.frequency" |
| | | placeholder="请输入频率" |
| | | clearable |
| | | @keyup.enter.native="handleQuery" |
| | | /> |
| | | </el-form-item> |
| | | <el-form-item label="维度" prop="dimension"> |
| | | <el-input |
| | | v-model="queryParams.dimension" |
| | | placeholder="请输入维度" |
| | | clearable |
| | | @keyup.enter.native="handleQuery" |
| | | /> |
| | | <el-form-item label-width="130" label="开始时间" prop="startTime"> |
| | | <el-date-picker |
| | | v-model="queryParams.startTime" |
| | | type="datetimerange" |
| | | :picker-options="pickerOptions" |
| | | value-format="yyyy-MM-dd HH:mm:ss" |
| | | range-separator="至" |
| | | start-placeholder="开始日期" |
| | | end-placeholder="结束日期" |
| | | align="right"> |
| | | </el-date-picker> |
| | | </el-form-item> |
| | | <el-form-item style="float: right"> |
| | | <el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button> |
| | |
| | | |
| | | <el-table border v-loading="loading" :data="inspectionPlanList" @selection-change="handleSelectionChange"> |
| | | <el-table-column type="selection" width="55" align="center" /> |
| | | <el-table-column label="ID" align="center" prop="id" /> |
| | | <el-table-column label="计划编号" align="center" prop="planCode"> |
| | | </el-table-column> |
| | | <el-table-column label="计划名称" align="center" prop="planName"> |
| | | </el-table-column> |
| | | <el-table-column label="计划类型" align="center" prop="planType"> |
| | | <el-table-column label="计划编号" align="center" prop="planCode"> |
| | | </el-table-column> |
| | | <el-table-column label="状态" align="center" prop="state"> |
| | | <el-table-column label="计划类型" align="center" prop="planType"> |
| | | </el-table-column> |
| | | <el-table-column label="频率" align="center" prop="frequency"> |
| | | </el-table-column> |
| | | <el-table-column label="维度" align="center" prop="dimension"> |
| | | </el-table-column> |
| | | <el-table-column label="上次生成时间" align="center" prop="lastGenerationTime"> |
| | | </el-table-column> |
| | | <el-table-column label="开始时间" align="center" prop="startTime"> |
| | | </el-table-column> |
| | | <el-table-column label="结束时间" align="center" prop="endTime"> |
| | | </el-table-column> |
| | | <el-table-column label="状态" align="center" prop="state"> |
| | | </el-table-column> |
| | | <el-table-column label="上次生成时间" align="center" prop="lastGenerationTime"> |
| | | </el-table-column> |
| | | <el-table-column label="备注" align="center" prop="remarks"> |
| | | </el-table-column> |
| | |
| | | <el-table-column label="修改时间" align="center" prop="updateTime"> |
| | | </el-table-column> |
| | | <el-table-column label="修改人" align="center" prop="updateUser"> |
| | | </el-table-column> |
| | | <el-table-column fixed="right" width="200" label="操作" align="center" class-name="small-padding fixed-width"> |
| | | <template slot-scope="scope"> |
| | | <el-button |
| | | size="mini" |
| | | type="success" |
| | | plain |
| | | style="width: 72px" |
| | | icon="el-icon-edit" |
| | | @click="handleUpdate(scope.row)" |
| | | v-hasPermi="['em:inspectionPlan:edit']" |
| | | >修改</el-button> |
| | | <el-button |
| | | size="mini" |
| | | type="danger" |
| | | plain |
| | | style="width: 72px" |
| | | icon="el-icon-delete" |
| | | @click="handleDelete(scope.row)" |
| | | v-hasPermi="['em:inspectionPlan:remove']" |
| | | >删除</el-button> |
| | | </template> |
| | | </el-table-column> |
| | | </el-table> |
| | | </el-card> |
| | |
| | | /> |
| | | |
| | | <!-- 添加或修改点检保养计划对话框 --> |
| | | <el-dialog v-dialogpop-up :title="title" :visible.sync="open" width="500px" append-to-body> |
| | | <el-dialog v-dialogpop-up :title="title" :visible.sync="open" width="1200px" append-to-body> |
| | | <span slot="title"> |
| | | <i class="el-icon-s-order"></i> |
| | | {{titleName}} |
| | | </span> |
| | | <el-form ref="form" :model="form" :rules="rules" label-width="80px"> |
| | | <el-form ref="form" inline :model="form" :rules="rules" label-width="80px" > |
| | | <el-form-item label="计划名称" prop="planName" > |
| | | <el-input style="width: 450px" v-model="form.planName" placeholder="请输入计划名称" /> |
| | | </el-form-item> |
| | | <el-form-item label="计划编号" prop="planCode"> |
| | | <el-input v-model="form.planCode" placeholder="请输入计划编号" /> |
| | | <el-input style="width: 450px" v-model="form.planCode" placeholder="请输入计划编号" /> |
| | | </el-form-item> |
| | | <el-form-item label="计划名称" prop="planName"> |
| | | <el-input v-model="form.planName" placeholder="请输入计划名称" /> |
| | | </el-form-item> |
| | | <!-- <el-form-item label="计划类型" prop="planType">--> |
| | | <!-- <el-select v-model="form.planType" placeholder="请选择计划类型">--> |
| | | <!-- <el-option--> |
| | | <!-- v-for="dict in dict.type.${dictType}"--> |
| | | <!-- :key="dict.value"--> |
| | | <!-- :label="dict.label"--> |
| | | <!-- :value="dict.value"--> |
| | | <!-- ></el-option>--> |
| | | <!-- </el-select>--> |
| | | <!-- </el-form-item>--> |
| | | <el-form-item label="状态" prop="state"> |
| | | <el-input v-model="form.state" placeholder="请输入状态" /> |
| | | <el-radio-group style="width: 450px" v-model="form.status"> |
| | | <el-radio |
| | | |
| | | v-for="dict in dict.type.plan_status" |
| | | :key="dict.value" |
| | | :label="dict.value" |
| | | >{{dict.label}}</el-radio> |
| | | </el-radio-group> |
| | | </el-form-item> |
| | | <el-form-item label="计划类型" prop="state"> |
| | | <el-radio-group style="width: 450px" v-model="form.planType"> |
| | | <el-radio |
| | | v-for="dict in dict.type.plan_type" |
| | | :key="dict.value" |
| | | :label="dict.value" |
| | | >{{dict.label}}</el-radio> |
| | | </el-radio-group> |
| | | </el-form-item> |
| | | <el-form-item label="频率" prop="frequency"> |
| | | <el-input v-model="form.frequency" placeholder="请输入频率" /> |
| | | <el-input style="width: 450px" v-model="form.frequency" placeholder="请输入频率" /> |
| | | </el-form-item> |
| | | <el-form-item label="维度" prop="dimension"> |
| | | <el-input v-model="form.dimension" placeholder="请输入维度" /> |
| | | <el-select v-model="form.dimension" placeholder="请选择维度" style="width: 450px"> |
| | | <el-option |
| | | v-for="dict in dict.type.dimension" |
| | | :key="dict.value" |
| | | :label="dict.label" |
| | | :value="dict.value"> |
| | | </el-option> |
| | | </el-select> |
| | | </el-form-item> |
| | | <el-form-item label="开始时间" prop="startTime"> |
| | | <el-date-picker |
| | | style="width: 450px" |
| | | clearable |
| | | v-model="form.startTime" |
| | | type="date" |
| | | value-format="yyyy-MM-dd" |
| | | placeholder="请选择出站时间"> |
| | | </el-date-picker> |
| | | </el-form-item> |
| | | <el-form-item label="结束时间" prop="endTime"> |
| | | <el-date-picker |
| | | style="width: 450px" |
| | | clearable |
| | | v-model="form.endTime" |
| | | type="date" |
| | | value-format="yyyy-MM-dd" |
| | | placeholder="请选择出站时间"> |
| | | </el-date-picker> |
| | | </el-form-item> |
| | | <el-form-item label="备注" prop="remarks"> |
| | | <el-input v-model="form.remarks" placeholder="请输入备注" /> |
| | | <el-input style="width: 1000px" v-model="form.remarks" placeholder="请输入备注" /> |
| | | </el-form-item> |
| | | </el-form> |
| | | <div slot="footer" class="dialog-footer"> |
| | |
| | | |
| | | export default { |
| | | name: "InspectionPlan", |
| | | dicts: ['plan_status','plan_type','dimension'], |
| | | data() { |
| | | return { |
| | | // 遮罩层 |
| | |
| | | // 表单校验 |
| | | rules: { |
| | | id: [ |
| | | { required: true, message: "ID不能为空", trigger: "blur" } |
| | | { required: true, message: "id不能为空", trigger: "blur" } |
| | | ], |
| | | } |
| | | planName: [ |
| | | { required: true, message: "计划名称不能为空", trigger: "blur" } |
| | | ], |
| | | planCode: [ |
| | | { required: true, message: "计划编号不能为空", trigger: "blur" } |
| | | ], |
| | | planType: [ |
| | | { required: true, message: "计划类型不能为空", trigger: "blur" } |
| | | ], |
| | | dimension: [ |
| | | { required: true, message: "维度不能为空", trigger: "blur" } |
| | | ], |
| | | frequency: [ |
| | | { required: true, message: '频率不能为空', trigger: 'blur' }, |
| | | { |
| | | validator: (rule, value, callback) => { |
| | | if (value === '' || value === undefined || value === null) { |
| | | callback(new Error('频率不能为空')); |
| | | } else if (!Number.isInteger(Number(value))) { |
| | | callback(new Error('频率必须是整数')); |
| | | } else { |
| | | callback(); |
| | | } |
| | | }, |
| | | trigger: 'blur' |
| | | } |
| | | ], |
| | | }, |
| | | pickerOptions: { |
| | | shortcuts: [{ |
| | | text: '最近一周', |
| | | onClick(picker) { |
| | | const end = new Date(); |
| | | const start = new Date(); |
| | | start.setTime(start.getTime() - 3600 * 1000 * 24 * 7); |
| | | picker.$emit('pick', [start, end]); |
| | | }, |
| | | class: 'custom-shortcut' // 添加class属性 |
| | | }, { |
| | | text: '最近一个月', |
| | | onClick(picker) { |
| | | const end = new Date(); |
| | | const start = new Date(); |
| | | start.setTime(start.getTime() - 3600 * 1000 * 24 * 30); |
| | | picker.$emit('pick', [start, end]); |
| | | }, |
| | | class: 'custom-shortcut' // 添加class属性 |
| | | }, { |
| | | text: '最近三个月', |
| | | onClick(picker) { |
| | | const end = new Date(); |
| | | const start = new Date(); |
| | | start.setTime(start.getTime() - 3600 * 1000 * 24 * 90); |
| | | picker.$emit('pick', [start, end]); |
| | | }, |
| | | }] |
| | | }, |
| | | }; |
| | | }, |
| | | created() { |