Compare commits

..

No commits in common. "dev" and "main" have entirely different histories.
dev ... main

7 changed files with 18 additions and 89 deletions

1
.gitignore vendored
View File

@ -25,7 +25,6 @@ Thumbs.db
/.mvn/ /.mvn/
/**/target/ /**/target/
!src/**/target/keepme.txt # 可选:防止误删有用文件夹 !src/**/target/keepme.txt # 可选:防止误删有用文件夹
pom.xml.versionsBackup
# Maven Wrapper # Maven Wrapper
mvnw mvnw

View File

@ -10,7 +10,7 @@
</parent> </parent>
<groupId>github.benjamin</groupId> <groupId>github.benjamin</groupId>
<artifactId>equip-reserve-backend</artifactId> <artifactId>equip-reserve-backend</artifactId>
<version>1.0.2-SNAPSHOT</version> <version>1.0.1</version>
<name>equip-reserve-backend</name> <name>equip-reserve-backend</name>
<description>equip-reserve-backend</description> <description>equip-reserve-backend</description>
<url/> <url/>

View File

@ -6,7 +6,11 @@ import github.benjamin.equipreservebackend.entity.Device;
import github.benjamin.equipreservebackend.response.ResponseResult; import github.benjamin.equipreservebackend.response.ResponseResult;
import github.benjamin.equipreservebackend.service.DeviceService; import github.benjamin.equipreservebackend.service.DeviceService;
import github.benjamin.equipreservebackend.service.ReservationService; import github.benjamin.equipreservebackend.service.ReservationService;
import github.benjamin.equipreservebackend.vo.*; import github.benjamin.equipreservebackend.vo.DeviceAdminVO;
import github.benjamin.equipreservebackend.vo.DeviceStatsVO;
import github.benjamin.equipreservebackend.vo.DeviceUserVO;
import github.benjamin.equipreservebackend.vo.TimeRangeVO;
import jakarta.servlet.http.HttpServlet;
import jakarta.servlet.http.HttpServletResponse; import jakarta.servlet.http.HttpServletResponse;
import lombok.RequiredArgsConstructor; import lombok.RequiredArgsConstructor;
import org.springframework.format.annotation.DateTimeFormat; import org.springframework.format.annotation.DateTimeFormat;
@ -50,7 +54,7 @@ public class DeviceController {
@PreAuthorize("hasRole('DEVICE_ADMIN')") @PreAuthorize("hasRole('DEVICE_ADMIN')")
@PostMapping("/{userId}") @PostMapping("/{userId}")
public ResponseResult<DeviceAdminVO> addDevice(@PathVariable("userId") Long userId, public ResponseResult<DeviceAdminVO> addDevice(@PathVariable("userId") Long userId,
@RequestBody Device device) { @RequestBody Device device) {
deviceService.addDevice(userId, device); deviceService.addDevice(userId, device);
return ResponseResult.success(new DeviceAdminVO(device)); return ResponseResult.success(new DeviceAdminVO(device));
} }
@ -65,7 +69,7 @@ public class DeviceController {
@PreAuthorize("hasRole('DEVICE_ADMIN')") @PreAuthorize("hasRole('DEVICE_ADMIN')")
@PutMapping("/{id}") @PutMapping("/{id}")
public ResponseResult<DeviceAdminVO> updateDevice(@PathVariable("id") Long id, public ResponseResult<DeviceAdminVO> updateDevice(@PathVariable("id") Long id,
@RequestBody Device device) { @RequestBody Device device) {
device.setId(id); device.setId(id);
Device updatedDevice = deviceService.updateDevice(device); Device updatedDevice = deviceService.updateDevice(device);
return ResponseResult.success(new DeviceAdminVO(updatedDevice)); return ResponseResult.success(new DeviceAdminVO(updatedDevice));
@ -116,30 +120,4 @@ public class DeviceController {
.sheet("设备使用统计") .sheet("设备使用统计")
.doWrite(data); .doWrite(data);
} }
@PreAuthorize("hasRole('ADMIN')")
@GetMapping("/detail-stats")
public ResponseResult<List<DeviceDetailStatsVO>> getDeviceDetailStats(@RequestParam Long deviceId,
@RequestParam @DateTimeFormat(pattern = "yyyy-MM-dd") LocalDate start,
@RequestParam @DateTimeFormat(pattern = "yyyy-MM-dd") LocalDate end) {
return ResponseResult.success(reservationService.getDeviceDetailStats(deviceId, start, end));
}
@PreAuthorize("hasRole('ADMIN')")
@GetMapping("/detail-stats/export")
public void exportDeviceDetailStats(@RequestParam Long deviceId,
@RequestParam @DateTimeFormat(pattern = "yyyy-MM-dd") LocalDate start,
@RequestParam @DateTimeFormat(pattern = "yyyy-MM-dd") LocalDate end,
HttpServletResponse response) throws IOException {
response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
response.setCharacterEncoding("utf-8");
// 查询数据
List<DeviceDetailStatsVO> data = reservationService.getDeviceDetailStats(deviceId, start, end);
// 使用EasyExcel写入response流
EasyExcel.write(response.getOutputStream(), DeviceDetailStatsVO.class)
.sheet("设备使用详情")
.doWrite(data);
}
} }

View File

@ -2,7 +2,10 @@ package github.benjamin.equipreservebackend.service;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import github.benjamin.equipreservebackend.entity.Reservation; import github.benjamin.equipreservebackend.entity.Reservation;
import github.benjamin.equipreservebackend.vo.*; import github.benjamin.equipreservebackend.vo.ReservationStatsVO;
import github.benjamin.equipreservebackend.vo.ReservationVO;
import github.benjamin.equipreservebackend.vo.TimeRangeVO;
import github.benjamin.equipreservebackend.vo.UserReservationVO;
import java.time.LocalDate; import java.time.LocalDate;
import java.util.List; import java.util.List;
@ -20,6 +23,4 @@ public interface ReservationService {
Page<ReservationVO> getReservationVO(Long userId, Integer page, Integer size); Page<ReservationVO> getReservationVO(Long userId, Integer page, Integer size);
List<ReservationStatsVO> getReservationStats(LocalDate start, LocalDate end); List<ReservationStatsVO> getReservationStats(LocalDate start, LocalDate end);
List<DeviceDetailStatsVO> getDeviceDetailStats(Long deviceId, LocalDate start, LocalDate end);
} }

View File

@ -3,15 +3,15 @@ package github.benjamin.equipreservebackend.service.impl;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import github.benjamin.equipreservebackend.constant.ReservationStatus; import github.benjamin.equipreservebackend.constant.ReservationStatus;
import github.benjamin.equipreservebackend.entity.Device; import github.benjamin.equipreservebackend.entity.*;
import github.benjamin.equipreservebackend.entity.Reservation;
import github.benjamin.equipreservebackend.entity.Role;
import github.benjamin.equipreservebackend.entity.User;
import github.benjamin.equipreservebackend.exception.ApiException; import github.benjamin.equipreservebackend.exception.ApiException;
import github.benjamin.equipreservebackend.mapper.*; import github.benjamin.equipreservebackend.mapper.*;
import github.benjamin.equipreservebackend.service.ReservationService; import github.benjamin.equipreservebackend.service.ReservationService;
import github.benjamin.equipreservebackend.utils.PageUtil; import github.benjamin.equipreservebackend.utils.PageUtil;
import github.benjamin.equipreservebackend.vo.*; import github.benjamin.equipreservebackend.vo.ReservationStatsVO;
import github.benjamin.equipreservebackend.vo.ReservationVO;
import github.benjamin.equipreservebackend.vo.TimeRangeVO;
import github.benjamin.equipreservebackend.vo.UserReservationVO;
import lombok.RequiredArgsConstructor; import lombok.RequiredArgsConstructor;
import org.springframework.beans.factory.annotation.Value; import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
@ -152,14 +152,4 @@ public class ReservationServiceImpl implements ReservationService {
public List<ReservationStatsVO> getReservationStats(LocalDate start, LocalDate end) { public List<ReservationStatsVO> getReservationStats(LocalDate start, LocalDate end) {
return reservationMapper.getReservationStats(start, end); return reservationMapper.getReservationStats(start, end);
} }
@Override
public List<DeviceDetailStatsVO> getDeviceDetailStats(Long deviceId, LocalDate start, LocalDate end) {
return reservationMapper.selectList(new LambdaQueryWrapper<Reservation>()
.eq(Reservation::getDeviceId, deviceId)
.in(Reservation::getStatus, List.of("APPROVED", "APPROVED_ASSIST"))
.ge(Reservation::getStartTime, start)
.le(Reservation::getEndTime, end)
.orderByAsc(Reservation::getApplicantName, Reservation::getStartTime)).stream().map(DeviceDetailStatsVO::new).toList();
}
} }

View File

@ -1,39 +0,0 @@
package github.benjamin.equipreservebackend.vo;
import com.alibaba.excel.annotation.ExcelProperty;
import com.alibaba.excel.annotation.write.style.ColumnWidth;
import github.benjamin.equipreservebackend.entity.Reservation;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import java.time.LocalDate;
@Data
@NoArgsConstructor
@AllArgsConstructor
public class DeviceDetailStatsVO {
@ExcelProperty("使用人")
@ColumnWidth(15)
private String applicantName;
@ExcelProperty("所属团队")
@ColumnWidth(15)
private String applicantTeam;
@ExcelProperty("开始日期")
@ColumnWidth(15)
private LocalDate startDay;
@ExcelProperty("结束日期")
@ColumnWidth(15)
private LocalDate endDay;
public DeviceDetailStatsVO(Reservation r) {
this.applicantName = r.getApplicantName();
this.applicantTeam = r.getApplicantTeam();
this.startDay = r.getStartTime();
this.endDay = r.getEndTime();
}
}

View File

@ -14,7 +14,7 @@
JOIN devices d ON r.device_id = d.id JOIN devices d ON r.device_id = d.id
WHERE r.status IN ('APPROVED', 'APPROVED_ASSIST') WHERE r.status IN ('APPROVED', 'APPROVED_ASSIST')
AND r.start_time >= #{start} AND r.start_time >= #{start}
AND r.end_time &lt;= #{end} AND r.end_time &lt; #{end}
GROUP BY d.id GROUP BY d.id
ORDER BY totalUsageDays DESC ORDER BY totalUsageDays DESC
</select> </select>