Compare commits
No commits in common. "dev" and "main" have entirely different histories.
1
.gitignore
vendored
1
.gitignore
vendored
@ -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
|
||||||
|
2
pom.xml
2
pom.xml
@ -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/>
|
||||||
|
@ -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);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -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);
|
|
||||||
}
|
}
|
||||||
|
@ -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();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -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();
|
|
||||||
}
|
|
||||||
}
|
|
@ -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 <= #{end}
|
AND r.end_time < #{end}
|
||||||
GROUP BY d.id
|
GROUP BY d.id
|
||||||
ORDER BY totalUsageDays DESC
|
ORDER BY totalUsageDays DESC
|
||||||
</select>
|
</select>
|
||||||
|
Loading…
x
Reference in New Issue
Block a user