吉安感知网项目-后端
linwei
6 days ago ebeb43ea497fafc448c827d1de6796bcaa4e0b52
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
/*
 *      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 com.alibaba.fastjson.JSON;
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 lombok.extern.slf4j.Slf4j;
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.common.GenericConverter;
import org.sxkj.gd.common.IdParam;
import org.sxkj.gd.workorder.dto.GdDeviceCallDetailExternalSaveDTO;
import org.sxkj.gd.workorder.entity.GdDeviceCallEntity;
import org.sxkj.gd.workorder.param.GdDeviceCallPageParam;
import org.sxkj.gd.workorder.vo.GdDeviceCallVO;
import org.sxkj.gd.workorder.excel.GdDeviceCallExcel;
import org.sxkj.gd.workorder.wrapper.GdDeviceCallWrapper;
import org.sxkj.gd.workorder.service.IGdDeviceCallService;
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 Aix
 * @since 2026-02-26
 */
@Slf4j
@RestController
@AllArgsConstructor
@RequestMapping("workorder/gdDeviceCall")
@Api(value = "设备调用表", tags = "设备调用表接口")
public class GdDeviceCallController extends BladeController {
 
    private final IGdDeviceCallService gdDeviceCallService;
 
    /**
     * 设备调用表 自定义分页
     */
    @GetMapping("/page")
    @ApiOperationSupport(order = 3)
    @ApiOperation(value = "分页", notes = "传入gdDeviceCall")
    public R<IPage<GdDeviceCallVO>> page(GdDeviceCallPageParam param, Query query) {
        IPage<GdDeviceCallVO> pages = gdDeviceCallService.selectGdDeviceCallPage(Condition.getPage(query), GenericConverter.convert(param, GdDeviceCallVO.class));
        return R.data(pages);
    }
 
    /**
     * 设备调用表 新增 - 对外接口
     */
    @PostMapping("/addDeviceCall")
    @ApiOperationSupport(order = 2)
    @ApiOperation(value = "新增设备状态数据(星图对接)", notes = "dtos")
    public R<Boolean> addDeviceCallExternal(@RequestBody List<GdDeviceCallDetailExternalSaveDTO> dtos) {
        log.info("新增设备状态数据-对外接口{}", JSON.toJSONString(dtos));
        return R.status(gdDeviceCallService.saveGdDeviceCallExternal(dtos));
    }
 
    /**
     * 导出数据
     */
    @GetMapping("/export-gdDeviceCall")
    @ApiOperationSupport(order = 9)
    @ApiOperation(value = "导出数据", notes = "传入gdDeviceCall")
    @ApiIgnore
    public void exportGdDeviceCall(@ApiIgnore @RequestParam Map<String, Object> gdDeviceCall, BladeUser bladeUser, HttpServletResponse response) {
        QueryWrapper<GdDeviceCallEntity> queryWrapper = Condition.getQueryWrapper(gdDeviceCall, GdDeviceCallEntity.class);
        //if (!AuthUtil.isAdministrator()) {
        //    queryWrapper.lambda().eq(GdDeviceCall::getTenantId, bladeUser.getTenantId());
        //}
        queryWrapper.lambda().eq(GdDeviceCallEntity::getIsDeleted, BladeConstant.DB_NOT_DELETED);
        List<GdDeviceCallExcel> list = gdDeviceCallService.exportGdDeviceCall(queryWrapper);
        ExcelUtil.export(response, "设备调用表数据" + DateUtil.time(), "设备调用表数据表", list, GdDeviceCallExcel.class);
    }
 
}