100 lines
3.6 KiB
Java
100 lines
3.6 KiB
Java
package com.gunshi.project.hsz.controller;
|
|
|
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
|
import com.baomidou.mybatisplus.core.toolkit.IdWorker;
|
|
import com.baomidou.mybatisplus.core.toolkit.ObjectUtils;
|
|
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
|
import com.gunshi.core.result.R;
|
|
import com.gunshi.project.hsz.entity.so.GeneralDataPage;
|
|
import com.gunshi.project.hsz.model.AttMeaWeir;
|
|
import com.gunshi.project.hsz.service.AttMeaWeirService;
|
|
import com.gunshi.project.hsz.service.StAddvcdDService;
|
|
import com.gunshi.project.hsz.validate.markers.Insert;
|
|
import com.gunshi.project.hsz.validate.markers.Update;
|
|
import io.swagger.v3.oas.annotations.Operation;
|
|
import io.swagger.v3.oas.annotations.media.Schema;
|
|
import io.swagger.v3.oas.annotations.tags.Tag;
|
|
import org.apache.commons.lang3.StringUtils;
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
import org.springframework.validation.annotation.Validated;
|
|
import org.springframework.web.bind.annotation.*;
|
|
|
|
import java.io.Serializable;
|
|
import java.util.Date;
|
|
import java.util.List;
|
|
import java.util.Objects;
|
|
|
|
/**
|
|
* 描述: 量水堰表
|
|
* author: xusan
|
|
* date: 2024-07-08 17:40:37
|
|
*/
|
|
@Tag(name = "量水堰表")
|
|
@RestController
|
|
@RequestMapping(value="/attMeaWeir")
|
|
public class AttMeaWeirController {
|
|
|
|
@Autowired
|
|
private AttMeaWeirService service;
|
|
|
|
@Autowired
|
|
private StAddvcdDService stAddvcdDService;
|
|
|
|
|
|
@Operation(summary = "新增")
|
|
@PostMapping("/insert")
|
|
public R<AttMeaWeir> insert(@Validated(Insert.class) @RequestBody AttMeaWeir dto) {
|
|
dto.setWeirCode(IdWorker.get32UUID());
|
|
dto.setCreateTime(new Date());
|
|
if (StringUtils.isNotBlank(dto.getAdcd()) && Objects.isNull(stAddvcdDService.getById(dto.getAdcd()))){
|
|
throw new IllegalArgumentException("当前行政区划不存在");
|
|
}
|
|
boolean result = service.save(dto);
|
|
return R.ok(result ? dto : null);
|
|
}
|
|
|
|
@Operation(summary = "修改")
|
|
@PostMapping("/update")
|
|
public R<AttMeaWeir> update(@Validated(Update.class) @RequestBody AttMeaWeir dto) {
|
|
if (Objects.isNull(service.getById(dto.getWeirCode()))) {
|
|
throw new IllegalArgumentException("当前数据不存在");
|
|
}
|
|
|
|
if (StringUtils.isNotBlank(dto.getAdcd()) && Objects.isNull(stAddvcdDService.getById(dto.getAdcd()))){
|
|
throw new IllegalArgumentException("当前行政区划不存在");
|
|
}
|
|
boolean result = service.updateById(dto);
|
|
return R.ok(result ? dto : null);
|
|
}
|
|
|
|
@Operation(summary = "删除")
|
|
@GetMapping("/del/{id}")
|
|
public R<Boolean> del(@Schema(name = "id") @PathVariable("id") Serializable id) {
|
|
if (Objects.isNull(service.getById(id))) {
|
|
throw new IllegalArgumentException("当前数据不存在");
|
|
}
|
|
return R.ok(service.removeById(id));
|
|
}
|
|
|
|
@Operation(summary = "列表")
|
|
@PostMapping("/list")
|
|
public R<List<AttMeaWeir>> list() {
|
|
return R.ok(service.lambdaQuery().list());
|
|
}
|
|
|
|
@Operation(summary = "分页")
|
|
@PostMapping("/page")
|
|
public R<Page<AttMeaWeir>> page(@RequestBody @Validated GeneralDataPage page) {
|
|
LambdaQueryWrapper<AttMeaWeir> query = Wrappers.lambdaQuery();
|
|
|
|
if (ObjectUtils.isNotNull(page.getCode())) {
|
|
query.like(AttMeaWeir::getWeirCode, page.getCode());
|
|
}
|
|
if (ObjectUtils.isNotNull(page.getName())) {
|
|
query.like(AttMeaWeir::getWeirName, page.getName());
|
|
}
|
|
query.orderByDesc(AttMeaWeir::getCreateTime);
|
|
return R.ok(service.page(page.getPageSo().toPage(), query));
|
|
}
|
|
} |