16 changed files with 1018 additions and 3 deletions
@ -0,0 +1,105 @@ |
|||
package org.dromara.platform.controller; |
|||
|
|||
import java.util.List; |
|||
|
|||
import lombok.RequiredArgsConstructor; |
|||
import jakarta.servlet.http.HttpServletResponse; |
|||
import jakarta.validation.constraints.*; |
|||
import cn.dev33.satoken.annotation.SaCheckPermission; |
|||
import org.springframework.web.bind.annotation.*; |
|||
import org.springframework.validation.annotation.Validated; |
|||
import org.dromara.common.idempotent.annotation.RepeatSubmit; |
|||
import org.dromara.common.log.annotation.Log; |
|||
import org.dromara.common.web.core.BaseController; |
|||
import org.dromara.common.mybatis.core.page.PageQuery; |
|||
import org.dromara.common.core.domain.R; |
|||
import org.dromara.common.core.validate.AddGroup; |
|||
import org.dromara.common.core.validate.EditGroup; |
|||
import org.dromara.common.log.enums.BusinessType; |
|||
import org.dromara.common.excel.utils.ExcelUtil; |
|||
import org.dromara.platform.domain.vo.MaterialInfoVo; |
|||
import org.dromara.platform.domain.bo.MaterialInfoBo; |
|||
import org.dromara.platform.service.IMaterialInfoService; |
|||
import org.dromara.common.mybatis.core.page.TableDataInfo; |
|||
|
|||
/** |
|||
* 材料库-信息 |
|||
* |
|||
* @author gejunhao |
|||
* @date 2025-04-17 |
|||
*/ |
|||
@Validated |
|||
@RequiredArgsConstructor |
|||
@RestController |
|||
@RequestMapping("/platform/matrialInfo") |
|||
public class MaterialInfoController extends BaseController { |
|||
|
|||
private final IMaterialInfoService materialInfoService; |
|||
|
|||
/** |
|||
* 查询材料库-信息列表 |
|||
*/ |
|||
@SaCheckPermission("platform:matrialInfo:list") |
|||
@GetMapping("/list") |
|||
public TableDataInfo<MaterialInfoVo> list(MaterialInfoBo bo, PageQuery pageQuery) { |
|||
return materialInfoService.queryPageList(bo, pageQuery); |
|||
} |
|||
|
|||
/** |
|||
* 导出材料库-信息列表 |
|||
*/ |
|||
@SaCheckPermission("platform:matrialInfo:export") |
|||
@Log(title = "材料库-信息", businessType = BusinessType.EXPORT) |
|||
@PostMapping("/export") |
|||
public void export(MaterialInfoBo bo, HttpServletResponse response) { |
|||
List<MaterialInfoVo> list = materialInfoService.queryList(bo); |
|||
ExcelUtil.exportExcel(list, "材料库-信息", MaterialInfoVo.class, response); |
|||
} |
|||
|
|||
/** |
|||
* 获取材料库-信息详细信息 |
|||
* |
|||
* @param id 主键 |
|||
*/ |
|||
@SaCheckPermission("platform:matrialInfo:query") |
|||
@GetMapping("/{id}") |
|||
public R<MaterialInfoVo> getInfo(@NotNull(message = "主键不能为空") |
|||
@PathVariable String id) { |
|||
return R.ok(materialInfoService.queryById(id)); |
|||
} |
|||
|
|||
/** |
|||
* 新增材料库-信息 |
|||
*/ |
|||
@SaCheckPermission("platform:matrialInfo:add") |
|||
@Log(title = "材料库-信息", businessType = BusinessType.INSERT) |
|||
@RepeatSubmit() |
|||
@PostMapping() |
|||
public R<Void> add(@Validated(AddGroup.class) @RequestBody MaterialInfoBo bo) { |
|||
return toAjax(materialInfoService.insertByBo(bo)); |
|||
} |
|||
|
|||
/** |
|||
* 修改材料库-信息 |
|||
*/ |
|||
@SaCheckPermission("platform:matrialInfo:edit") |
|||
@Log(title = "材料库-信息", businessType = BusinessType.UPDATE) |
|||
@RepeatSubmit() |
|||
@PutMapping() |
|||
public R<Void> edit(@Validated(EditGroup.class) @RequestBody MaterialInfoBo bo) { |
|||
return toAjax(materialInfoService.updateByBo(bo)); |
|||
} |
|||
|
|||
/** |
|||
* 删除材料库-信息 |
|||
* |
|||
* @param ids 主键串 |
|||
*/ |
|||
@SaCheckPermission("platform:matrialInfo:remove") |
|||
@Log(title = "材料库-信息", businessType = BusinessType.DELETE) |
|||
@DeleteMapping("/{ids}") |
|||
public R<Void> remove(@NotEmpty(message = "主键不能为空") |
|||
@PathVariable String[] ids) { |
|||
return toAjax(materialInfoService.deleteWithValidByIds(List.of(ids), true)); |
|||
} |
|||
} |
@ -0,0 +1,105 @@ |
|||
package org.dromara.platform.controller; |
|||
|
|||
import java.util.List; |
|||
|
|||
import lombok.RequiredArgsConstructor; |
|||
import jakarta.servlet.http.HttpServletResponse; |
|||
import jakarta.validation.constraints.*; |
|||
import cn.dev33.satoken.annotation.SaCheckPermission; |
|||
import org.springframework.web.bind.annotation.*; |
|||
import org.springframework.validation.annotation.Validated; |
|||
import org.dromara.common.idempotent.annotation.RepeatSubmit; |
|||
import org.dromara.common.log.annotation.Log; |
|||
import org.dromara.common.web.core.BaseController; |
|||
import org.dromara.common.mybatis.core.page.PageQuery; |
|||
import org.dromara.common.core.domain.R; |
|||
import org.dromara.common.core.validate.AddGroup; |
|||
import org.dromara.common.core.validate.EditGroup; |
|||
import org.dromara.common.log.enums.BusinessType; |
|||
import org.dromara.common.excel.utils.ExcelUtil; |
|||
import org.dromara.platform.domain.vo.OrganizationTypeVo; |
|||
import org.dromara.platform.domain.bo.OrganizationTypeBo; |
|||
import org.dromara.platform.service.IOrganizationTypeService; |
|||
import org.dromara.common.mybatis.core.page.TableDataInfo; |
|||
|
|||
/** |
|||
* 所属机构-类别 |
|||
* |
|||
* @author gejunhao |
|||
* @date 2025-04-17 |
|||
*/ |
|||
@Validated |
|||
@RequiredArgsConstructor |
|||
@RestController |
|||
@RequestMapping("/platform/organizationType") |
|||
public class OrganizationTypeController extends BaseController { |
|||
|
|||
private final IOrganizationTypeService organizationTypeService; |
|||
|
|||
/** |
|||
* 查询所属机构-类别列表 |
|||
*/ |
|||
@SaCheckPermission("platform:organizationType:list") |
|||
@GetMapping("/list") |
|||
public TableDataInfo<OrganizationTypeVo> list(OrganizationTypeBo bo, PageQuery pageQuery) { |
|||
return organizationTypeService.queryPageList(bo, pageQuery); |
|||
} |
|||
|
|||
/** |
|||
* 导出所属机构-类别列表 |
|||
*/ |
|||
@SaCheckPermission("platform:organizationType:export") |
|||
@Log(title = "所属机构-类别", businessType = BusinessType.EXPORT) |
|||
@PostMapping("/export") |
|||
public void export(OrganizationTypeBo bo, HttpServletResponse response) { |
|||
List<OrganizationTypeVo> list = organizationTypeService.queryList(bo); |
|||
ExcelUtil.exportExcel(list, "所属机构-类别", OrganizationTypeVo.class, response); |
|||
} |
|||
|
|||
/** |
|||
* 获取所属机构-类别详细信息 |
|||
* |
|||
* @param id 主键 |
|||
*/ |
|||
@SaCheckPermission("platform:organizationType:query") |
|||
@GetMapping("/{id}") |
|||
public R<OrganizationTypeVo> getInfo(@NotNull(message = "主键不能为空") |
|||
@PathVariable String id) { |
|||
return R.ok(organizationTypeService.queryById(id)); |
|||
} |
|||
|
|||
/** |
|||
* 新增所属机构-类别 |
|||
*/ |
|||
@SaCheckPermission("platform:organizationType:add") |
|||
@Log(title = "所属机构-类别", businessType = BusinessType.INSERT) |
|||
@RepeatSubmit() |
|||
@PostMapping() |
|||
public R<Void> add(@Validated(AddGroup.class) @RequestBody OrganizationTypeBo bo) { |
|||
return toAjax(organizationTypeService.insertByBo(bo)); |
|||
} |
|||
|
|||
/** |
|||
* 修改所属机构-类别 |
|||
*/ |
|||
@SaCheckPermission("platform:organizationType:edit") |
|||
@Log(title = "所属机构-类别", businessType = BusinessType.UPDATE) |
|||
@RepeatSubmit() |
|||
@PutMapping() |
|||
public R<Void> edit(@Validated(EditGroup.class) @RequestBody OrganizationTypeBo bo) { |
|||
return toAjax(organizationTypeService.updateByBo(bo)); |
|||
} |
|||
|
|||
/** |
|||
* 删除所属机构-类别 |
|||
* |
|||
* @param ids 主键串 |
|||
*/ |
|||
@SaCheckPermission("platform:organizationType:remove") |
|||
@Log(title = "所属机构-类别", businessType = BusinessType.DELETE) |
|||
@DeleteMapping("/{ids}") |
|||
public R<Void> remove(@NotEmpty(message = "主键不能为空") |
|||
@PathVariable String[] ids) { |
|||
return toAjax(organizationTypeService.deleteWithValidByIds(List.of(ids), true)); |
|||
} |
|||
} |
@ -0,0 +1,72 @@ |
|||
package org.dromara.platform.domain; |
|||
|
|||
import org.dromara.common.tenant.core.TenantEntity; |
|||
import com.baomidou.mybatisplus.annotation.*; |
|||
import lombok.Data; |
|||
import lombok.EqualsAndHashCode; |
|||
|
|||
import java.io.Serial; |
|||
|
|||
/** |
|||
* 材料库-信息对象 material_info |
|||
* |
|||
* @author gejunhao |
|||
* @date 2025-04-17 |
|||
*/ |
|||
@Data |
|||
@EqualsAndHashCode(callSuper = true) |
|||
@TableName("material_info") |
|||
public class MaterialInfo extends TenantEntity { |
|||
|
|||
@Serial |
|||
private static final long serialVersionUID = 1L; |
|||
|
|||
/** |
|||
* 唯一标识符 |
|||
*/ |
|||
@TableId(value = "id") |
|||
private String id; |
|||
|
|||
/** |
|||
* 名称 |
|||
*/ |
|||
private String name; |
|||
|
|||
/** |
|||
* 规格 |
|||
*/ |
|||
private String standards; |
|||
|
|||
/** |
|||
* 数量 |
|||
*/ |
|||
private String amount; |
|||
|
|||
/** |
|||
* 单位 |
|||
*/ |
|||
private String unit; |
|||
|
|||
/** |
|||
* 备注 |
|||
*/ |
|||
private String remark; |
|||
|
|||
/** |
|||
* 项目id |
|||
*/ |
|||
private String projectId; |
|||
|
|||
/** |
|||
* 当前状态 |
|||
*/ |
|||
private Long status; |
|||
|
|||
/** |
|||
* 删除标志(0代表存在 2代表删除) |
|||
*/ |
|||
@TableLogic |
|||
private String delFlag; |
|||
|
|||
|
|||
} |
@ -0,0 +1,47 @@ |
|||
package org.dromara.platform.domain; |
|||
|
|||
import org.dromara.common.tenant.core.TenantEntity; |
|||
import com.baomidou.mybatisplus.annotation.*; |
|||
import lombok.Data; |
|||
import lombok.EqualsAndHashCode; |
|||
|
|||
import java.io.Serial; |
|||
|
|||
/** |
|||
* 所属机构-类别对象 organization_type |
|||
* |
|||
* @author gejunhao |
|||
* @date 2025-04-17 |
|||
*/ |
|||
@Data |
|||
@EqualsAndHashCode(callSuper = true) |
|||
@TableName("organization_type") |
|||
public class OrganizationType extends TenantEntity { |
|||
|
|||
@Serial |
|||
private static final long serialVersionUID = 1L; |
|||
|
|||
/** |
|||
* 唯一标识符 |
|||
*/ |
|||
@TableId(value = "id") |
|||
private String id; |
|||
|
|||
/** |
|||
* 组织机构名称 |
|||
*/ |
|||
private String organizationName; |
|||
|
|||
/** |
|||
* 当前状态 |
|||
*/ |
|||
private Long status; |
|||
|
|||
/** |
|||
* 删除标志(0代表存在 2代表删除) |
|||
*/ |
|||
@TableLogic |
|||
private String delFlag; |
|||
|
|||
|
|||
} |
@ -0,0 +1,72 @@ |
|||
package org.dromara.platform.domain.bo; |
|||
|
|||
import org.dromara.platform.domain.MaterialInfo; |
|||
import org.dromara.common.mybatis.core.domain.BaseEntity; |
|||
import org.dromara.common.core.validate.AddGroup; |
|||
import org.dromara.common.core.validate.EditGroup; |
|||
import io.github.linpeilie.annotations.AutoMapper; |
|||
import lombok.Data; |
|||
import lombok.EqualsAndHashCode; |
|||
import jakarta.validation.constraints.*; |
|||
|
|||
/** |
|||
* 材料库-信息业务对象 material_info |
|||
* |
|||
* @author gejunhao |
|||
* @date 2025-04-17 |
|||
*/ |
|||
@Data |
|||
@EqualsAndHashCode(callSuper = true) |
|||
@AutoMapper(target = MaterialInfo.class, reverseConvertGenerate = false) |
|||
public class MaterialInfoBo extends BaseEntity { |
|||
|
|||
/** |
|||
* 唯一标识符 |
|||
*/ |
|||
@NotBlank(message = "唯一标识符不能为空", groups = { EditGroup.class }) |
|||
private String id; |
|||
|
|||
/** |
|||
* 名称 |
|||
*/ |
|||
@NotBlank(message = "名称不能为空", groups = { AddGroup.class, EditGroup.class }) |
|||
private String name; |
|||
|
|||
/** |
|||
* 规格 |
|||
*/ |
|||
@NotBlank(message = "规格不能为空", groups = { AddGroup.class, EditGroup.class }) |
|||
private String standards; |
|||
|
|||
/** |
|||
* 数量 |
|||
*/ |
|||
@NotBlank(message = "数量不能为空", groups = { AddGroup.class, EditGroup.class }) |
|||
private String amount; |
|||
|
|||
/** |
|||
* 单位 |
|||
*/ |
|||
@NotBlank(message = "单位不能为空", groups = { AddGroup.class, EditGroup.class }) |
|||
private String unit; |
|||
|
|||
/** |
|||
* 备注 |
|||
*/ |
|||
//@NotBlank(message = "备注不能为空", groups = { AddGroup.class, EditGroup.class })
|
|||
private String remark; |
|||
|
|||
/** |
|||
* 项目id |
|||
*/ |
|||
@NotBlank(message = "项目id不能为空", groups = { AddGroup.class, EditGroup.class }) |
|||
private String projectId; |
|||
|
|||
/** |
|||
* 当前状态 |
|||
*/ |
|||
@NotNull(message = "当前状态不能为空", groups = { AddGroup.class, EditGroup.class }) |
|||
private Long status; |
|||
|
|||
|
|||
} |
@ -0,0 +1,42 @@ |
|||
package org.dromara.platform.domain.bo; |
|||
|
|||
import org.dromara.platform.domain.OrganizationType; |
|||
import org.dromara.common.mybatis.core.domain.BaseEntity; |
|||
import org.dromara.common.core.validate.AddGroup; |
|||
import org.dromara.common.core.validate.EditGroup; |
|||
import io.github.linpeilie.annotations.AutoMapper; |
|||
import lombok.Data; |
|||
import lombok.EqualsAndHashCode; |
|||
import jakarta.validation.constraints.*; |
|||
|
|||
/** |
|||
* 所属机构-类别业务对象 organization_type |
|||
* |
|||
* @author gejunhao |
|||
* @date 2025-04-17 |
|||
*/ |
|||
@Data |
|||
@EqualsAndHashCode(callSuper = true) |
|||
@AutoMapper(target = OrganizationType.class, reverseConvertGenerate = false) |
|||
public class OrganizationTypeBo extends BaseEntity { |
|||
|
|||
/** |
|||
* 唯一标识符 |
|||
*/ |
|||
@NotBlank(message = "唯一标识符不能为空", groups = { EditGroup.class }) |
|||
private String id; |
|||
|
|||
/** |
|||
* 组织机构名称 |
|||
*/ |
|||
@NotBlank(message = "组织机构名称不能为空", groups = { AddGroup.class, EditGroup.class }) |
|||
private String organizationName; |
|||
|
|||
/** |
|||
* 当前状态 |
|||
*/ |
|||
@NotNull(message = "当前状态不能为空", groups = { AddGroup.class, EditGroup.class }) |
|||
private Long status; |
|||
|
|||
|
|||
} |
@ -0,0 +1,80 @@ |
|||
package org.dromara.platform.domain.vo; |
|||
|
|||
import org.dromara.platform.domain.MaterialInfo; |
|||
import com.alibaba.excel.annotation.ExcelIgnoreUnannotated; |
|||
import com.alibaba.excel.annotation.ExcelProperty; |
|||
import org.dromara.common.excel.annotation.ExcelDictFormat; |
|||
import org.dromara.common.excel.convert.ExcelDictConvert; |
|||
import io.github.linpeilie.annotations.AutoMapper; |
|||
import lombok.Data; |
|||
|
|||
import java.io.Serial; |
|||
import java.io.Serializable; |
|||
import java.util.Date; |
|||
|
|||
|
|||
|
|||
/** |
|||
* 材料库-信息视图对象 material_info |
|||
* |
|||
* @author gejunhao |
|||
* @date 2025-04-17 |
|||
*/ |
|||
@Data |
|||
@ExcelIgnoreUnannotated |
|||
@AutoMapper(target = MaterialInfo.class) |
|||
public class MaterialInfoVo implements Serializable { |
|||
|
|||
@Serial |
|||
private static final long serialVersionUID = 1L; |
|||
|
|||
/** |
|||
* 唯一标识符 |
|||
*/ |
|||
@ExcelProperty(value = "唯一标识符") |
|||
private String id; |
|||
|
|||
/** |
|||
* 名称 |
|||
*/ |
|||
@ExcelProperty(value = "名称") |
|||
private String name; |
|||
|
|||
/** |
|||
* 规格 |
|||
*/ |
|||
@ExcelProperty(value = "规格") |
|||
private String standards; |
|||
|
|||
/** |
|||
* 数量 |
|||
*/ |
|||
@ExcelProperty(value = "数量") |
|||
private String amount; |
|||
|
|||
/** |
|||
* 单位 |
|||
*/ |
|||
@ExcelProperty(value = "单位") |
|||
private String unit; |
|||
|
|||
/** |
|||
* 备注 |
|||
*/ |
|||
@ExcelProperty(value = "备注") |
|||
private String remark; |
|||
|
|||
/** |
|||
* 项目id |
|||
*/ |
|||
@ExcelProperty(value = "项目id") |
|||
private String projectId; |
|||
|
|||
/** |
|||
* 当前状态 |
|||
*/ |
|||
@ExcelProperty(value = "当前状态") |
|||
private Long status; |
|||
|
|||
|
|||
} |
@ -0,0 +1,50 @@ |
|||
package org.dromara.platform.domain.vo; |
|||
|
|||
import org.dromara.platform.domain.OrganizationType; |
|||
import com.alibaba.excel.annotation.ExcelIgnoreUnannotated; |
|||
import com.alibaba.excel.annotation.ExcelProperty; |
|||
import org.dromara.common.excel.annotation.ExcelDictFormat; |
|||
import org.dromara.common.excel.convert.ExcelDictConvert; |
|||
import io.github.linpeilie.annotations.AutoMapper; |
|||
import lombok.Data; |
|||
|
|||
import java.io.Serial; |
|||
import java.io.Serializable; |
|||
import java.util.Date; |
|||
|
|||
|
|||
|
|||
/** |
|||
* 所属机构-类别视图对象 organization_type |
|||
* |
|||
* @author gejunhao |
|||
* @date 2025-04-17 |
|||
*/ |
|||
@Data |
|||
@ExcelIgnoreUnannotated |
|||
@AutoMapper(target = OrganizationType.class) |
|||
public class OrganizationTypeVo implements Serializable { |
|||
|
|||
@Serial |
|||
private static final long serialVersionUID = 1L; |
|||
|
|||
/** |
|||
* 唯一标识符 |
|||
*/ |
|||
@ExcelProperty(value = "唯一标识符") |
|||
private String id; |
|||
|
|||
/** |
|||
* 组织机构名称 |
|||
*/ |
|||
@ExcelProperty(value = "组织机构名称") |
|||
private String organizationName; |
|||
|
|||
/** |
|||
* 当前状态 |
|||
*/ |
|||
@ExcelProperty(value = "当前状态") |
|||
private Long status; |
|||
|
|||
|
|||
} |
@ -0,0 +1,15 @@ |
|||
package org.dromara.platform.mapper; |
|||
|
|||
import org.dromara.platform.domain.MaterialInfo; |
|||
import org.dromara.platform.domain.vo.MaterialInfoVo; |
|||
import org.dromara.common.mybatis.core.mapper.BaseMapperPlus; |
|||
|
|||
/** |
|||
* 材料库-信息Mapper接口 |
|||
* |
|||
* @author gejunhao |
|||
* @date 2025-04-17 |
|||
*/ |
|||
public interface MaterialInfoMapper extends BaseMapperPlus<MaterialInfo, MaterialInfoVo> { |
|||
|
|||
} |
@ -0,0 +1,15 @@ |
|||
package org.dromara.platform.mapper; |
|||
|
|||
import org.dromara.platform.domain.OrganizationType; |
|||
import org.dromara.platform.domain.vo.OrganizationTypeVo; |
|||
import org.dromara.common.mybatis.core.mapper.BaseMapperPlus; |
|||
|
|||
/** |
|||
* 所属机构-类别Mapper接口 |
|||
* |
|||
* @author gejunhao |
|||
* @date 2025-04-17 |
|||
*/ |
|||
public interface OrganizationTypeMapper extends BaseMapperPlus<OrganizationType, OrganizationTypeVo> { |
|||
|
|||
} |
@ -0,0 +1,68 @@ |
|||
package org.dromara.platform.service; |
|||
|
|||
import org.dromara.platform.domain.vo.MaterialInfoVo; |
|||
import org.dromara.platform.domain.bo.MaterialInfoBo; |
|||
import org.dromara.common.mybatis.core.page.TableDataInfo; |
|||
import org.dromara.common.mybatis.core.page.PageQuery; |
|||
|
|||
import java.util.Collection; |
|||
import java.util.List; |
|||
|
|||
/** |
|||
* 材料库-信息Service接口 |
|||
* |
|||
* @author gejunhao |
|||
* @date 2025-04-17 |
|||
*/ |
|||
public interface IMaterialInfoService { |
|||
|
|||
/** |
|||
* 查询材料库-信息 |
|||
* |
|||
* @param id 主键 |
|||
* @return 材料库-信息 |
|||
*/ |
|||
MaterialInfoVo queryById(String id); |
|||
|
|||
/** |
|||
* 分页查询材料库-信息列表 |
|||
* |
|||
* @param bo 查询条件 |
|||
* @param pageQuery 分页参数 |
|||
* @return 材料库-信息分页列表 |
|||
*/ |
|||
TableDataInfo<MaterialInfoVo> queryPageList(MaterialInfoBo bo, PageQuery pageQuery); |
|||
|
|||
/** |
|||
* 查询符合条件的材料库-信息列表 |
|||
* |
|||
* @param bo 查询条件 |
|||
* @return 材料库-信息列表 |
|||
*/ |
|||
List<MaterialInfoVo> queryList(MaterialInfoBo bo); |
|||
|
|||
/** |
|||
* 新增材料库-信息 |
|||
* |
|||
* @param bo 材料库-信息 |
|||
* @return 是否新增成功 |
|||
*/ |
|||
Boolean insertByBo(MaterialInfoBo bo); |
|||
|
|||
/** |
|||
* 修改材料库-信息 |
|||
* |
|||
* @param bo 材料库-信息 |
|||
* @return 是否修改成功 |
|||
*/ |
|||
Boolean updateByBo(MaterialInfoBo bo); |
|||
|
|||
/** |
|||
* 校验并批量删除材料库-信息信息 |
|||
* |
|||
* @param ids 待删除的主键集合 |
|||
* @param isValid 是否进行有效性校验 |
|||
* @return 是否删除成功 |
|||
*/ |
|||
Boolean deleteWithValidByIds(Collection<String> ids, Boolean isValid); |
|||
} |
@ -0,0 +1,68 @@ |
|||
package org.dromara.platform.service; |
|||
|
|||
import org.dromara.platform.domain.vo.OrganizationTypeVo; |
|||
import org.dromara.platform.domain.bo.OrganizationTypeBo; |
|||
import org.dromara.common.mybatis.core.page.TableDataInfo; |
|||
import org.dromara.common.mybatis.core.page.PageQuery; |
|||
|
|||
import java.util.Collection; |
|||
import java.util.List; |
|||
|
|||
/** |
|||
* 所属机构-类别Service接口 |
|||
* |
|||
* @author gejunhao |
|||
* @date 2025-04-17 |
|||
*/ |
|||
public interface IOrganizationTypeService { |
|||
|
|||
/** |
|||
* 查询所属机构-类别 |
|||
* |
|||
* @param id 主键 |
|||
* @return 所属机构-类别 |
|||
*/ |
|||
OrganizationTypeVo queryById(String id); |
|||
|
|||
/** |
|||
* 分页查询所属机构-类别列表 |
|||
* |
|||
* @param bo 查询条件 |
|||
* @param pageQuery 分页参数 |
|||
* @return 所属机构-类别分页列表 |
|||
*/ |
|||
TableDataInfo<OrganizationTypeVo> queryPageList(OrganizationTypeBo bo, PageQuery pageQuery); |
|||
|
|||
/** |
|||
* 查询符合条件的所属机构-类别列表 |
|||
* |
|||
* @param bo 查询条件 |
|||
* @return 所属机构-类别列表 |
|||
*/ |
|||
List<OrganizationTypeVo> queryList(OrganizationTypeBo bo); |
|||
|
|||
/** |
|||
* 新增所属机构-类别 |
|||
* |
|||
* @param bo 所属机构-类别 |
|||
* @return 是否新增成功 |
|||
*/ |
|||
Boolean insertByBo(OrganizationTypeBo bo); |
|||
|
|||
/** |
|||
* 修改所属机构-类别 |
|||
* |
|||
* @param bo 所属机构-类别 |
|||
* @return 是否修改成功 |
|||
*/ |
|||
Boolean updateByBo(OrganizationTypeBo bo); |
|||
|
|||
/** |
|||
* 校验并批量删除所属机构-类别信息 |
|||
* |
|||
* @param ids 待删除的主键集合 |
|||
* @param isValid 是否进行有效性校验 |
|||
* @return 是否删除成功 |
|||
*/ |
|||
Boolean deleteWithValidByIds(Collection<String> ids, Boolean isValid); |
|||
} |
@ -0,0 +1,134 @@ |
|||
package org.dromara.platform.service.impl; |
|||
|
|||
import org.dromara.common.core.utils.MapstructUtils; |
|||
import org.dromara.common.core.utils.StringUtils; |
|||
import org.dromara.common.mybatis.core.page.TableDataInfo; |
|||
import org.dromara.common.mybatis.core.page.PageQuery; |
|||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page; |
|||
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; |
|||
import com.baomidou.mybatisplus.core.toolkit.Wrappers; |
|||
import lombok.RequiredArgsConstructor; |
|||
import org.springframework.stereotype.Service; |
|||
import org.dromara.platform.domain.bo.MaterialInfoBo; |
|||
import org.dromara.platform.domain.vo.MaterialInfoVo; |
|||
import org.dromara.platform.domain.MaterialInfo; |
|||
import org.dromara.platform.mapper.MaterialInfoMapper; |
|||
import org.dromara.platform.service.IMaterialInfoService; |
|||
|
|||
import java.util.List; |
|||
import java.util.Map; |
|||
import java.util.Collection; |
|||
|
|||
/** |
|||
* 材料库-信息Service业务层处理 |
|||
* |
|||
* @author gejunhao |
|||
* @date 2025-04-17 |
|||
*/ |
|||
@RequiredArgsConstructor |
|||
@Service |
|||
public class MaterialInfoServiceImpl implements IMaterialInfoService { |
|||
|
|||
private final MaterialInfoMapper baseMapper; |
|||
|
|||
/** |
|||
* 查询材料库-信息 |
|||
* |
|||
* @param id 主键 |
|||
* @return 材料库-信息 |
|||
*/ |
|||
@Override |
|||
public MaterialInfoVo queryById(String id){ |
|||
return baseMapper.selectVoById(id); |
|||
} |
|||
|
|||
/** |
|||
* 分页查询材料库-信息列表 |
|||
* |
|||
* @param bo 查询条件 |
|||
* @param pageQuery 分页参数 |
|||
* @return 材料库-信息分页列表 |
|||
*/ |
|||
@Override |
|||
public TableDataInfo<MaterialInfoVo> queryPageList(MaterialInfoBo bo, PageQuery pageQuery) { |
|||
LambdaQueryWrapper<MaterialInfo> lqw = buildQueryWrapper(bo); |
|||
Page<MaterialInfoVo> result = baseMapper.selectVoPage(pageQuery.build(), lqw); |
|||
return TableDataInfo.build(result); |
|||
} |
|||
|
|||
/** |
|||
* 查询符合条件的材料库-信息列表 |
|||
* |
|||
* @param bo 查询条件 |
|||
* @return 材料库-信息列表 |
|||
*/ |
|||
@Override |
|||
public List<MaterialInfoVo> queryList(MaterialInfoBo bo) { |
|||
LambdaQueryWrapper<MaterialInfo> lqw = buildQueryWrapper(bo); |
|||
return baseMapper.selectVoList(lqw); |
|||
} |
|||
|
|||
private LambdaQueryWrapper<MaterialInfo> buildQueryWrapper(MaterialInfoBo bo) { |
|||
Map<String, Object> params = bo.getParams(); |
|||
LambdaQueryWrapper<MaterialInfo> lqw = Wrappers.lambdaQuery(); |
|||
lqw.like(StringUtils.isNotBlank(bo.getName()), MaterialInfo::getName, bo.getName()); |
|||
lqw.eq(StringUtils.isNotBlank(bo.getStandards()), MaterialInfo::getStandards, bo.getStandards()); |
|||
lqw.eq(StringUtils.isNotBlank(bo.getAmount()), MaterialInfo::getAmount, bo.getAmount()); |
|||
lqw.eq(StringUtils.isNotBlank(bo.getUnit()), MaterialInfo::getUnit, bo.getUnit()); |
|||
lqw.eq(StringUtils.isNotBlank(bo.getProjectId()), MaterialInfo::getProjectId, bo.getProjectId()); |
|||
lqw.eq(bo.getStatus() != null, MaterialInfo::getStatus, bo.getStatus()); |
|||
return lqw; |
|||
} |
|||
|
|||
/** |
|||
* 新增材料库-信息 |
|||
* |
|||
* @param bo 材料库-信息 |
|||
* @return 是否新增成功 |
|||
*/ |
|||
@Override |
|||
public Boolean insertByBo(MaterialInfoBo bo) { |
|||
MaterialInfo add = MapstructUtils.convert(bo, MaterialInfo.class); |
|||
validEntityBeforeSave(add); |
|||
boolean flag = baseMapper.insert(add) > 0; |
|||
if (flag) { |
|||
bo.setId(add.getId()); |
|||
} |
|||
return flag; |
|||
} |
|||
|
|||
/** |
|||
* 修改材料库-信息 |
|||
* |
|||
* @param bo 材料库-信息 |
|||
* @return 是否修改成功 |
|||
*/ |
|||
@Override |
|||
public Boolean updateByBo(MaterialInfoBo bo) { |
|||
MaterialInfo update = MapstructUtils.convert(bo, MaterialInfo.class); |
|||
validEntityBeforeSave(update); |
|||
return baseMapper.updateById(update) > 0; |
|||
} |
|||
|
|||
/** |
|||
* 保存前的数据校验 |
|||
*/ |
|||
private void validEntityBeforeSave(MaterialInfo entity){ |
|||
//TODO 做一些数据校验,如唯一约束
|
|||
} |
|||
|
|||
/** |
|||
* 校验并批量删除材料库-信息信息 |
|||
* |
|||
* @param ids 待删除的主键集合 |
|||
* @param isValid 是否进行有效性校验 |
|||
* @return 是否删除成功 |
|||
*/ |
|||
@Override |
|||
public Boolean deleteWithValidByIds(Collection<String> ids, Boolean isValid) { |
|||
if(isValid){ |
|||
//TODO 做一些业务上的校验,判断是否需要校验
|
|||
} |
|||
return baseMapper.deleteByIds(ids) > 0; |
|||
} |
|||
} |
@ -0,0 +1,130 @@ |
|||
package org.dromara.platform.service.impl; |
|||
|
|||
import org.dromara.common.core.utils.MapstructUtils; |
|||
import org.dromara.common.core.utils.StringUtils; |
|||
import org.dromara.common.mybatis.core.page.TableDataInfo; |
|||
import org.dromara.common.mybatis.core.page.PageQuery; |
|||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page; |
|||
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; |
|||
import com.baomidou.mybatisplus.core.toolkit.Wrappers; |
|||
import lombok.RequiredArgsConstructor; |
|||
import org.springframework.stereotype.Service; |
|||
import org.dromara.platform.domain.bo.OrganizationTypeBo; |
|||
import org.dromara.platform.domain.vo.OrganizationTypeVo; |
|||
import org.dromara.platform.domain.OrganizationType; |
|||
import org.dromara.platform.mapper.OrganizationTypeMapper; |
|||
import org.dromara.platform.service.IOrganizationTypeService; |
|||
|
|||
import java.util.List; |
|||
import java.util.Map; |
|||
import java.util.Collection; |
|||
|
|||
/** |
|||
* 所属机构-类别Service业务层处理 |
|||
* |
|||
* @author gejunhao |
|||
* @date 2025-04-17 |
|||
*/ |
|||
@RequiredArgsConstructor |
|||
@Service |
|||
public class OrganizationTypeServiceImpl implements IOrganizationTypeService { |
|||
|
|||
private final OrganizationTypeMapper baseMapper; |
|||
|
|||
/** |
|||
* 查询所属机构-类别 |
|||
* |
|||
* @param id 主键 |
|||
* @return 所属机构-类别 |
|||
*/ |
|||
@Override |
|||
public OrganizationTypeVo queryById(String id){ |
|||
return baseMapper.selectVoById(id); |
|||
} |
|||
|
|||
/** |
|||
* 分页查询所属机构-类别列表 |
|||
* |
|||
* @param bo 查询条件 |
|||
* @param pageQuery 分页参数 |
|||
* @return 所属机构-类别分页列表 |
|||
*/ |
|||
@Override |
|||
public TableDataInfo<OrganizationTypeVo> queryPageList(OrganizationTypeBo bo, PageQuery pageQuery) { |
|||
LambdaQueryWrapper<OrganizationType> lqw = buildQueryWrapper(bo); |
|||
Page<OrganizationTypeVo> result = baseMapper.selectVoPage(pageQuery.build(), lqw); |
|||
return TableDataInfo.build(result); |
|||
} |
|||
|
|||
/** |
|||
* 查询符合条件的所属机构-类别列表 |
|||
* |
|||
* @param bo 查询条件 |
|||
* @return 所属机构-类别列表 |
|||
*/ |
|||
@Override |
|||
public List<OrganizationTypeVo> queryList(OrganizationTypeBo bo) { |
|||
LambdaQueryWrapper<OrganizationType> lqw = buildQueryWrapper(bo); |
|||
return baseMapper.selectVoList(lqw); |
|||
} |
|||
|
|||
private LambdaQueryWrapper<OrganizationType> buildQueryWrapper(OrganizationTypeBo bo) { |
|||
Map<String, Object> params = bo.getParams(); |
|||
LambdaQueryWrapper<OrganizationType> lqw = Wrappers.lambdaQuery(); |
|||
lqw.like(StringUtils.isNotBlank(bo.getOrganizationName()), OrganizationType::getOrganizationName, bo.getOrganizationName()); |
|||
lqw.eq(bo.getStatus() != null, OrganizationType::getStatus, bo.getStatus()); |
|||
return lqw; |
|||
} |
|||
|
|||
/** |
|||
* 新增所属机构-类别 |
|||
* |
|||
* @param bo 所属机构-类别 |
|||
* @return 是否新增成功 |
|||
*/ |
|||
@Override |
|||
public Boolean insertByBo(OrganizationTypeBo bo) { |
|||
OrganizationType add = MapstructUtils.convert(bo, OrganizationType.class); |
|||
validEntityBeforeSave(add); |
|||
boolean flag = baseMapper.insert(add) > 0; |
|||
if (flag) { |
|||
bo.setId(add.getId()); |
|||
} |
|||
return flag; |
|||
} |
|||
|
|||
/** |
|||
* 修改所属机构-类别 |
|||
* |
|||
* @param bo 所属机构-类别 |
|||
* @return 是否修改成功 |
|||
*/ |
|||
@Override |
|||
public Boolean updateByBo(OrganizationTypeBo bo) { |
|||
OrganizationType update = MapstructUtils.convert(bo, OrganizationType.class); |
|||
validEntityBeforeSave(update); |
|||
return baseMapper.updateById(update) > 0; |
|||
} |
|||
|
|||
/** |
|||
* 保存前的数据校验 |
|||
*/ |
|||
private void validEntityBeforeSave(OrganizationType entity){ |
|||
//TODO 做一些数据校验,如唯一约束
|
|||
} |
|||
|
|||
/** |
|||
* 校验并批量删除所属机构-类别信息 |
|||
* |
|||
* @param ids 待删除的主键集合 |
|||
* @param isValid 是否进行有效性校验 |
|||
* @return 是否删除成功 |
|||
*/ |
|||
@Override |
|||
public Boolean deleteWithValidByIds(Collection<String> ids, Boolean isValid) { |
|||
if(isValid){ |
|||
//TODO 做一些业务上的校验,判断是否需要校验
|
|||
} |
|||
return baseMapper.deleteByIds(ids) > 0; |
|||
} |
|||
} |
Loading…
Reference in new issue