/* * Copyright (c) 2018-2028, Chill Zhuang All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are met: * * Redistributions of source code must retain the above copyright notice, * this list of conditions and the following disclaimer. * Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * Neither the name of the dreamlu.net developer nor the names of its * contributors may be used to endorse or promote products derived from * this software without specific prior written permission. * Author: Chill 庄骞 (smallchill@163.com) */ package org.sxkj.gd.workorder.controller; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; import io.swagger.annotations.ApiParam; import com.github.xiaoymin.knife4j.annotations.ApiOperationSupport; import lombok.AllArgsConstructor; import javax.validation.Valid; import org.springblade.core.secure.BladeUser; import org.springblade.core.mp.support.Condition; import org.springblade.core.mp.support.Query; import org.springblade.core.tool.api.R; import org.springblade.core.tool.utils.Func; import org.springframework.web.bind.annotation.*; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.core.metadata.IPage; import org.sxkj.gd.workorder.entity.GdWorkOrderEntity; import org.sxkj.gd.workorder.param.WorkOrderAddParam; import org.sxkj.gd.workorder.param.WorkOrderPageParam; import org.sxkj.gd.workorder.param.WorkOrderStatusParam; import org.sxkj.gd.workorder.vo.GdWorkOrderVO; import org.sxkj.gd.workorder.excel.GdWorkOrderExcel; import org.sxkj.gd.workorder.wrapper.GdWorkOrderWrapper; import org.sxkj.gd.workorder.service.IGdWorkOrderService; import org.springblade.core.boot.ctrl.BladeController; import org.springblade.core.tool.utils.DateUtil; import org.springblade.core.excel.util.ExcelUtil; import org.springblade.core.tool.constant.BladeConstant; import springfox.documentation.annotations.ApiIgnore; import java.util.Map; import java.util.List; import javax.servlet.http.HttpServletResponse; /** * 工单任务表 控制器 * * @author lw * @since 2026-01-14 */ @RestController @AllArgsConstructor @RequestMapping("workOrder/gdWorkOrder") @Api(value = "工单任务表", tags = "工单任务表接口") public class GdWorkOrderController extends BladeController { private final IGdWorkOrderService gdWorkOrderService; /** * 工单任务表 详情 * todo 星图 调了个你们的工单详情的接口, 主要就是落geojson 方便画航线, 后面如果有接口改动麻烦通知一下 */ @GetMapping("/detail") @ApiOperationSupport(order = 1) @ApiOperation(value = "详情", notes = "传入gdWorkOrder") public R detail(GdWorkOrderEntity gdWorkOrder) { GdWorkOrderVO detail = gdWorkOrderService.getWorkOrderDetail(gdWorkOrder); return R.data(detail); } /** * 工单任务表 自定义分页 */ @GetMapping("/page") @ApiOperationSupport(order = 3) @ApiOperation(value = "分页", notes = "传入gdWorkOrder") public R> page(WorkOrderPageParam gdWorkOrder, Query query) { IPage pages = gdWorkOrderService.selectGdWorkOrderPage(Condition.getPage(query), gdWorkOrder); return R.data(pages); } /** * 工单任务表 新增 */ @PostMapping("/save") @ApiOperationSupport(order = 4) @ApiOperation(value = "新增", notes = "传入gdWorkOrder") public R save(@Valid @RequestBody WorkOrderAddParam workOrderParam) { return R.status(gdWorkOrderService.saveOrUpdateWorkOrder(workOrderParam)); } // /** * 工单任务表 删除 */ @PostMapping("/remove") @ApiOperationSupport(order = 7) @ApiOperation(value = "逻辑删除", notes = "传入ids") public R remove(@ApiParam(value = "主键集合", required = true) @RequestParam String ids) { return R.status(gdWorkOrderService.deleteLogic(Func.toLongList(ids))); } /** * 处理工单状态变更(接单或拒接接单) */ @PostMapping("/handleStatus") @ApiOperationSupport(order = 8) @ApiOperation(value = "处理工单状态变更(接单或拒接接单)", notes = "传入workOrderStatusParam") public R handleStatus(@Valid @RequestBody WorkOrderStatusParam workOrderStatusParam) { return R.status(gdWorkOrderService.handleWorkOrderStatus(workOrderStatusParam)); } /** * 导出数据 */ @GetMapping("/export-gdWorkOrder") @ApiOperationSupport(order = 9) @ApiIgnore @ApiOperation(value = "导出数据", notes = "传入gdWorkOrder") public void exportGdWorkOrder(@ApiIgnore @RequestParam Map gdWorkOrder, BladeUser bladeUser, HttpServletResponse response) { QueryWrapper queryWrapper = Condition.getQueryWrapper(gdWorkOrder, GdWorkOrderEntity.class); //if (!AuthUtil.isAdministrator()) { // queryWrapper.lambda().eq(GdWorkOrder::getTenantId, bladeUser.getTenantId()); //} queryWrapper.lambda().eq(GdWorkOrderEntity::getIsDeleted, BladeConstant.DB_NOT_DELETED); List list = gdWorkOrderService.exportGdWorkOrder(queryWrapper); ExcelUtil.export(response, "工单任务表数据" + DateUtil.time(), "工单任务表数据表", list, GdWorkOrderExcel.class); } }