Merge remote-tracking branch 'origin/main'
This commit is contained in:
		| @ -350,12 +350,6 @@ | |||||||
|                 <version>${revision}</version> |                 <version>${revision}</version> | ||||||
|             </dependency> |             </dependency> | ||||||
|  |  | ||||||
|             <dependency> |  | ||||||
|                 <groupId>org.dromara</groupId> |  | ||||||
|                 <artifactId>ruoyi-demo</artifactId> |  | ||||||
|                 <version>${revision}</version> |  | ||||||
|             </dependency> |  | ||||||
|  |  | ||||||
|             <!--  工作流模块  --> |             <!--  工作流模块  --> | ||||||
|             <dependency> |             <dependency> | ||||||
|                 <groupId>org.dromara</groupId> |                 <groupId>org.dromara</groupId> | ||||||
|  | |||||||
| @ -81,12 +81,6 @@ | |||||||
|             <artifactId>ruoyi-generator</artifactId> |             <artifactId>ruoyi-generator</artifactId> | ||||||
|         </dependency> |         </dependency> | ||||||
|  |  | ||||||
|         <!--  demo模块  --> |  | ||||||
|         <dependency> |  | ||||||
|             <groupId>org.dromara</groupId> |  | ||||||
|             <artifactId>ruoyi-demo</artifactId> |  | ||||||
|         </dependency> |  | ||||||
|  |  | ||||||
|         <!--  工作流模块  --> |         <!--  工作流模块  --> | ||||||
|         <dependency> |         <dependency> | ||||||
|             <groupId>org.dromara</groupId> |             <groupId>org.dromara</groupId> | ||||||
|  | |||||||
| @ -10,7 +10,6 @@ | |||||||
|     <modelVersion>4.0.0</modelVersion> |     <modelVersion>4.0.0</modelVersion> | ||||||
|  |  | ||||||
|     <modules> |     <modules> | ||||||
|         <module>ruoyi-demo</module> |  | ||||||
|         <module>ruoyi-generator</module> |         <module>ruoyi-generator</module> | ||||||
|         <module>ruoyi-job</module> |         <module>ruoyi-job</module> | ||||||
|         <module>ruoyi-system</module> |         <module>ruoyi-system</module> | ||||||
|  | |||||||
| @ -1,108 +0,0 @@ | |||||||
| <?xml version="1.0" encoding="UTF-8"?> |  | ||||||
| <project xmlns="http://maven.apache.org/POM/4.0.0" |  | ||||||
|          xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" |  | ||||||
|          xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> |  | ||||||
|     <parent> |  | ||||||
|         <groupId>org.dromara</groupId> |  | ||||||
|         <artifactId>ruoyi-modules</artifactId> |  | ||||||
|         <version>${revision}</version> |  | ||||||
|     </parent> |  | ||||||
|     <modelVersion>4.0.0</modelVersion> |  | ||||||
|  |  | ||||||
|     <artifactId>ruoyi-demo</artifactId> |  | ||||||
|  |  | ||||||
|     <description> |  | ||||||
|         demo模块 |  | ||||||
|     </description> |  | ||||||
|  |  | ||||||
|     <dependencies> |  | ||||||
|  |  | ||||||
|         <!-- 通用工具--> |  | ||||||
|         <dependency> |  | ||||||
|             <groupId>org.dromara</groupId> |  | ||||||
|             <artifactId>ruoyi-common-core</artifactId> |  | ||||||
|         </dependency> |  | ||||||
|  |  | ||||||
|         <dependency> |  | ||||||
|             <groupId>org.dromara</groupId> |  | ||||||
|             <artifactId>ruoyi-common-doc</artifactId> |  | ||||||
|         </dependency> |  | ||||||
|  |  | ||||||
|         <dependency> |  | ||||||
|             <groupId>org.dromara</groupId> |  | ||||||
|             <artifactId>ruoyi-common-sms</artifactId> |  | ||||||
|         </dependency> |  | ||||||
|  |  | ||||||
|         <dependency> |  | ||||||
|             <groupId>org.dromara</groupId> |  | ||||||
|             <artifactId>ruoyi-common-mail</artifactId> |  | ||||||
|         </dependency> |  | ||||||
|  |  | ||||||
|         <dependency> |  | ||||||
|             <groupId>org.dromara</groupId> |  | ||||||
|             <artifactId>ruoyi-common-redis</artifactId> |  | ||||||
|         </dependency> |  | ||||||
|  |  | ||||||
|         <dependency> |  | ||||||
|             <groupId>org.dromara</groupId> |  | ||||||
|             <artifactId>ruoyi-common-idempotent</artifactId> |  | ||||||
|         </dependency> |  | ||||||
|  |  | ||||||
|         <dependency> |  | ||||||
|             <groupId>org.dromara</groupId> |  | ||||||
|             <artifactId>ruoyi-common-mybatis</artifactId> |  | ||||||
|         </dependency> |  | ||||||
|  |  | ||||||
|         <dependency> |  | ||||||
|             <groupId>org.dromara</groupId> |  | ||||||
|             <artifactId>ruoyi-common-log</artifactId> |  | ||||||
|         </dependency> |  | ||||||
|  |  | ||||||
|         <dependency> |  | ||||||
|             <groupId>org.dromara</groupId> |  | ||||||
|             <artifactId>ruoyi-common-excel</artifactId> |  | ||||||
|         </dependency> |  | ||||||
|  |  | ||||||
|         <dependency> |  | ||||||
|             <groupId>org.dromara</groupId> |  | ||||||
|             <artifactId>ruoyi-common-security</artifactId> |  | ||||||
|         </dependency> |  | ||||||
|  |  | ||||||
|         <dependency> |  | ||||||
|             <groupId>org.dromara</groupId> |  | ||||||
|             <artifactId>ruoyi-common-web</artifactId> |  | ||||||
|         </dependency> |  | ||||||
|  |  | ||||||
|         <dependency> |  | ||||||
|             <groupId>org.dromara</groupId> |  | ||||||
|             <artifactId>ruoyi-common-ratelimiter</artifactId> |  | ||||||
|         </dependency> |  | ||||||
|  |  | ||||||
|         <dependency> |  | ||||||
|             <groupId>org.dromara</groupId> |  | ||||||
|             <artifactId>ruoyi-common-translation</artifactId> |  | ||||||
|         </dependency> |  | ||||||
|  |  | ||||||
|         <dependency> |  | ||||||
|             <groupId>org.dromara</groupId> |  | ||||||
|             <artifactId>ruoyi-common-sensitive</artifactId> |  | ||||||
|         </dependency> |  | ||||||
|  |  | ||||||
|         <dependency> |  | ||||||
|             <groupId>org.dromara</groupId> |  | ||||||
|             <artifactId>ruoyi-common-encrypt</artifactId> |  | ||||||
|         </dependency> |  | ||||||
|  |  | ||||||
|         <dependency> |  | ||||||
|             <groupId>org.dromara</groupId> |  | ||||||
|             <artifactId>ruoyi-common-tenant</artifactId> |  | ||||||
|         </dependency> |  | ||||||
|  |  | ||||||
|         <dependency> |  | ||||||
|             <groupId>org.dromara</groupId> |  | ||||||
|             <artifactId>ruoyi-common-websocket</artifactId> |  | ||||||
|         </dependency> |  | ||||||
|  |  | ||||||
|     </dependencies> |  | ||||||
|  |  | ||||||
| </project> |  | ||||||
| @ -1,70 +0,0 @@ | |||||||
| package org.dromara.demo.controller; |  | ||||||
|  |  | ||||||
| import cn.dev33.satoken.annotation.SaIgnore; |  | ||||||
| import lombok.RequiredArgsConstructor; |  | ||||||
| import org.dromara.common.core.domain.R; |  | ||||||
| import org.dromara.common.mail.utils.MailUtils; |  | ||||||
| import org.springframework.validation.annotation.Validated; |  | ||||||
| import org.springframework.web.bind.annotation.GetMapping; |  | ||||||
| import org.springframework.web.bind.annotation.RequestMapping; |  | ||||||
| import org.springframework.web.bind.annotation.RestController; |  | ||||||
|  |  | ||||||
| import java.io.File; |  | ||||||
| import java.util.Arrays; |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * 邮件发送案例 |  | ||||||
|  * |  | ||||||
|  * @author Michelle.Chung |  | ||||||
|  */ |  | ||||||
| @SaIgnore |  | ||||||
| @Validated |  | ||||||
| @RequiredArgsConstructor |  | ||||||
| @RestController |  | ||||||
| @RequestMapping("/demo/mail") |  | ||||||
| public class MailController { |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 发送邮件 |  | ||||||
|      * |  | ||||||
|      * @param to      接收人 |  | ||||||
|      * @param subject 标题 |  | ||||||
|      * @param text    内容 |  | ||||||
|      */ |  | ||||||
|     @GetMapping("/sendSimpleMessage") |  | ||||||
|     public R<Void> sendSimpleMessage(String to, String subject, String text) { |  | ||||||
|         MailUtils.sendText(to, subject, text); |  | ||||||
|         return R.ok(); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 发送邮件(带附件) |  | ||||||
|      * |  | ||||||
|      * @param to       接收人 |  | ||||||
|      * @param subject  标题 |  | ||||||
|      * @param text     内容 |  | ||||||
|      * @param filePath 附件路径 |  | ||||||
|      */ |  | ||||||
|     @GetMapping("/sendMessageWithAttachment") |  | ||||||
|     public R<Void> sendMessageWithAttachment(String to, String subject, String text, String filePath) { |  | ||||||
|         MailUtils.sendText(to, subject, text, new File(filePath)); |  | ||||||
|         return R.ok(); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 发送邮件(多附件) |  | ||||||
|      * |  | ||||||
|      * @param to       接收人 |  | ||||||
|      * @param subject  标题 |  | ||||||
|      * @param text     内容 |  | ||||||
|      * @param paths    附件路径 |  | ||||||
|      */ |  | ||||||
|     @GetMapping("/sendMessageWithAttachments") |  | ||||||
|     public R<Void> sendMessageWithAttachments(String to, String subject, String text, String[] paths) { |  | ||||||
|         File[] array = Arrays.stream(paths).map(File::new).toArray(File[]::new); |  | ||||||
|         MailUtils.sendText(to, subject, text, array); |  | ||||||
|         return R.ok(); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } |  | ||||||
| @ -1,92 +0,0 @@ | |||||||
| package org.dromara.demo.controller; |  | ||||||
|  |  | ||||||
| import cn.hutool.core.thread.ThreadUtil; |  | ||||||
| import org.dromara.common.core.constant.CacheNames; |  | ||||||
| import org.dromara.common.core.domain.R; |  | ||||||
| import org.dromara.common.redis.utils.RedisUtils; |  | ||||||
| import lombok.RequiredArgsConstructor; |  | ||||||
| import org.springframework.cache.annotation.CacheEvict; |  | ||||||
| import org.springframework.cache.annotation.CachePut; |  | ||||||
| import org.springframework.cache.annotation.Cacheable; |  | ||||||
| import org.springframework.web.bind.annotation.GetMapping; |  | ||||||
| import org.springframework.web.bind.annotation.RequestMapping; |  | ||||||
| import org.springframework.web.bind.annotation.RestController; |  | ||||||
|  |  | ||||||
| import java.time.Duration; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * spring-cache 演示案例 |  | ||||||
|  * |  | ||||||
|  * @author Lion Li |  | ||||||
|  */ |  | ||||||
| // 类级别 缓存统一配置 |  | ||||||
| //@CacheConfig(cacheNames = CacheNames.DEMO_CACHE) |  | ||||||
| @RequiredArgsConstructor |  | ||||||
| @RestController |  | ||||||
| @RequestMapping("/demo/cache") |  | ||||||
| public class RedisCacheController { |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 测试 @Cacheable |  | ||||||
|      * <p> |  | ||||||
|      * 表示这个方法有了缓存的功能,方法的返回值会被缓存下来 |  | ||||||
|      * 下一次调用该方法前,会去检查是否缓存中已经有值 |  | ||||||
|      * 如果有就直接返回,不调用方法 |  | ||||||
|      * 如果没有,就调用方法,然后把结果缓存起来 |  | ||||||
|      * 这个注解「一般用在查询方法上」 |  | ||||||
|      * <p> |  | ||||||
|      * 重点说明: 缓存注解严谨与其他筛选数据功能一起使用 |  | ||||||
|      * 例如: 数据权限注解 会造成 缓存击穿 与 数据不一致问题 |  | ||||||
|      * <p> |  | ||||||
|      * cacheNames 命名规则 查看 {@link CacheNames} 注释 支持多参数 |  | ||||||
|      */ |  | ||||||
|     @Cacheable(cacheNames = "demo:cache#60s#10m#20", key = "#key", condition = "#key != null") |  | ||||||
|     @GetMapping("/test1") |  | ||||||
|     public R<String> test1(String key, String value) { |  | ||||||
|         return R.ok("操作成功", value); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 测试 @CachePut |  | ||||||
|      * <p> |  | ||||||
|      * 加了@CachePut注解的方法,会把方法的返回值put到缓存里面缓存起来,供其它地方使用 |  | ||||||
|      * 它「通常用在新增或者实时更新方法上」 |  | ||||||
|      * <p> |  | ||||||
|      * cacheNames 命名规则 查看 {@link CacheNames} 注释 支持多参数 |  | ||||||
|      */ |  | ||||||
|     @CachePut(cacheNames = CacheNames.DEMO_CACHE, key = "#key", condition = "#key != null") |  | ||||||
|     @GetMapping("/test2") |  | ||||||
|     public R<String> test2(String key, String value) { |  | ||||||
|         return R.ok("操作成功", value); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 测试 @CacheEvict |  | ||||||
|      * <p> |  | ||||||
|      * 使用了CacheEvict注解的方法,会清空指定缓存 |  | ||||||
|      * 「一般用在删除的方法上」 |  | ||||||
|      * <p> |  | ||||||
|      * cacheNames 命名规则 查看 {@link CacheNames} 注释 支持多参数 |  | ||||||
|      */ |  | ||||||
|     @CacheEvict(cacheNames = CacheNames.DEMO_CACHE, key = "#key", condition = "#key != null") |  | ||||||
|     @GetMapping("/test3") |  | ||||||
|     public R<String> test3(String key, String value) { |  | ||||||
|         return R.ok("操作成功", value); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 测试设置过期时间 |  | ||||||
|      * 手动设置过期时间10秒 |  | ||||||
|      * 11秒后获取 判断是否相等 |  | ||||||
|      */ |  | ||||||
|     @GetMapping("/test6") |  | ||||||
|     public R<Boolean> test6(String key, String value) { |  | ||||||
|         RedisUtils.setCacheObject(key, value); |  | ||||||
|         boolean flag = RedisUtils.expire(key, Duration.ofSeconds(10)); |  | ||||||
|         System.out.println("***********" + flag); |  | ||||||
|         ThreadUtil.sleep(11 * 1000); |  | ||||||
|         Object obj = RedisUtils.getCacheObject(key); |  | ||||||
|         return R.ok(value.equals(obj)); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } |  | ||||||
| @ -1,64 +0,0 @@ | |||||||
| package org.dromara.demo.controller; |  | ||||||
|  |  | ||||||
| import cn.hutool.core.thread.ThreadUtil; |  | ||||||
| import com.baomidou.lock.LockInfo; |  | ||||||
| import com.baomidou.lock.LockTemplate; |  | ||||||
| import com.baomidou.lock.annotation.Lock4j; |  | ||||||
| import com.baomidou.lock.executor.RedissonLockExecutor; |  | ||||||
| import org.dromara.common.core.domain.R; |  | ||||||
| import lombok.extern.slf4j.Slf4j; |  | ||||||
| import org.springframework.beans.factory.annotation.Autowired; |  | ||||||
| import org.springframework.web.bind.annotation.GetMapping; |  | ||||||
| import org.springframework.web.bind.annotation.RequestMapping; |  | ||||||
| import org.springframework.web.bind.annotation.RestController; |  | ||||||
|  |  | ||||||
| import java.time.LocalTime; |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * 测试分布式锁的样例 |  | ||||||
|  * |  | ||||||
|  * @author shenxinquan |  | ||||||
|  */ |  | ||||||
| @Slf4j |  | ||||||
| @RestController |  | ||||||
| @RequestMapping("/demo/redisLock") |  | ||||||
| public class RedisLockController { |  | ||||||
|  |  | ||||||
|     @Autowired |  | ||||||
|     private LockTemplate lockTemplate; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 测试lock4j 注解 |  | ||||||
|      */ |  | ||||||
|     @Lock4j(keys = {"#key"}) |  | ||||||
|     @GetMapping("/testLock4j") |  | ||||||
|     public R<String> testLock4j(String key, String value) { |  | ||||||
|         System.out.println("start:" + key + ",time:" + LocalTime.now()); |  | ||||||
|         ThreadUtil.sleep(10000); |  | ||||||
|         System.out.println("end :" + key + ",time:" + LocalTime.now()); |  | ||||||
|         return R.ok("操作成功", value); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 测试lock4j 工具 |  | ||||||
|      */ |  | ||||||
|     @GetMapping("/testLock4jLockTemplate") |  | ||||||
|     public R<String> testLock4jLockTemplate(String key, String value) { |  | ||||||
|         final LockInfo lockInfo = lockTemplate.lock(key, 30000L, 5000L, RedissonLockExecutor.class); |  | ||||||
|         if (null == lockInfo) { |  | ||||||
|             throw new RuntimeException("业务处理中,请稍后再试"); |  | ||||||
|         } |  | ||||||
|         // 获取锁成功,处理业务 |  | ||||||
|         try { |  | ||||||
|             ThreadUtil.sleep(8000); |  | ||||||
|             System.out.println("执行简单方法1 , 当前线程:" + Thread.currentThread().getName()); |  | ||||||
|         } finally { |  | ||||||
|             //释放锁 |  | ||||||
|             lockTemplate.releaseLock(lockInfo); |  | ||||||
|         } |  | ||||||
|         //结束 |  | ||||||
|         return R.ok("操作成功", value); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } |  | ||||||
| @ -1,47 +0,0 @@ | |||||||
| package org.dromara.demo.controller; |  | ||||||
|  |  | ||||||
| import org.dromara.common.core.domain.R; |  | ||||||
| import org.dromara.common.redis.utils.RedisUtils; |  | ||||||
| import lombok.RequiredArgsConstructor; |  | ||||||
| import org.springframework.web.bind.annotation.GetMapping; |  | ||||||
| import org.springframework.web.bind.annotation.RequestMapping; |  | ||||||
| import org.springframework.web.bind.annotation.RestController; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * Redis 发布订阅 演示案例 |  | ||||||
|  * |  | ||||||
|  * @author Lion Li |  | ||||||
|  */ |  | ||||||
| @RequiredArgsConstructor |  | ||||||
| @RestController |  | ||||||
| @RequestMapping("/demo/redis/pubsub") |  | ||||||
| public class RedisPubSubController { |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 发布消息 |  | ||||||
|      * |  | ||||||
|      * @param key   通道Key |  | ||||||
|      * @param value 发送内容 |  | ||||||
|      */ |  | ||||||
|     @GetMapping("/pub") |  | ||||||
|     public R<Void> pub(String key, String value) { |  | ||||||
|         RedisUtils.publish(key, value, consumer -> { |  | ||||||
|             System.out.println("发布通道 => " + key + ", 发送值 => " + value); |  | ||||||
|         }); |  | ||||||
|         return R.ok("操作成功"); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 订阅消息 |  | ||||||
|      * |  | ||||||
|      * @param key 通道Key |  | ||||||
|      */ |  | ||||||
|     @GetMapping("/sub") |  | ||||||
|     public R<Void> sub(String key) { |  | ||||||
|         RedisUtils.subscribe(key, String.class, msg -> { |  | ||||||
|             System.out.println("订阅通道 => " + key + ", 接收值 => " + msg); |  | ||||||
|         }); |  | ||||||
|         return R.ok("操作成功"); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } |  | ||||||
| @ -1,64 +0,0 @@ | |||||||
| package org.dromara.demo.controller; |  | ||||||
|  |  | ||||||
| import org.dromara.common.core.domain.R; |  | ||||||
| import org.dromara.common.ratelimiter.annotation.RateLimiter; |  | ||||||
| import org.dromara.common.ratelimiter.enums.LimitType; |  | ||||||
| import lombok.extern.slf4j.Slf4j; |  | ||||||
| import org.springframework.web.bind.annotation.GetMapping; |  | ||||||
| import org.springframework.web.bind.annotation.RequestMapping; |  | ||||||
| import org.springframework.web.bind.annotation.RestController; |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * 测试分布式限流样例 |  | ||||||
|  * |  | ||||||
|  * @author Lion Li |  | ||||||
|  */ |  | ||||||
| @Slf4j |  | ||||||
| @RestController |  | ||||||
| @RequestMapping("/demo/rateLimiter") |  | ||||||
| public class RedisRateLimiterController { |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 测试全局限流 |  | ||||||
|      * 全局影响 |  | ||||||
|      */ |  | ||||||
|     @RateLimiter(count = 2, time = 10) |  | ||||||
|     @GetMapping("/test") |  | ||||||
|     public R<String> test(String value) { |  | ||||||
|         return R.ok("操作成功", value); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 测试请求IP限流 |  | ||||||
|      * 同一IP请求受影响 |  | ||||||
|      */ |  | ||||||
|     @RateLimiter(count = 2, time = 10, limitType = LimitType.IP) |  | ||||||
|     @GetMapping("/testip") |  | ||||||
|     public R<String> testip(String value) { |  | ||||||
|         return R.ok("操作成功", value); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 测试集群实例限流 |  | ||||||
|      * 启动两个后端服务互不影响 |  | ||||||
|      */ |  | ||||||
|     @RateLimiter(count = 2, time = 10, limitType = LimitType.CLUSTER) |  | ||||||
|     @GetMapping("/testcluster") |  | ||||||
|     public R<String> testcluster(String value) { |  | ||||||
|         return R.ok("操作成功", value); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 测试请求IP限流(key基于参数获取) |  | ||||||
|      * 同一IP请求受影响 |  | ||||||
|      * |  | ||||||
|      * 简单变量获取 #变量 复杂表达式 #{#变量 != 1 ? 1 : 0} |  | ||||||
|      */ |  | ||||||
|     @RateLimiter(count = 2, time = 10, limitType = LimitType.IP, key = "#value") |  | ||||||
|     @GetMapping("/testObj") |  | ||||||
|     public R<String> testObj(String value) { |  | ||||||
|         return R.ok("操作成功", value); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } |  | ||||||
| @ -1,82 +0,0 @@ | |||||||
| package org.dromara.demo.controller; |  | ||||||
|  |  | ||||||
| import lombok.RequiredArgsConstructor; |  | ||||||
| import org.dromara.common.core.domain.R; |  | ||||||
| import org.dromara.sms4j.api.SmsBlend; |  | ||||||
| import org.dromara.sms4j.api.entity.SmsResponse; |  | ||||||
| import org.dromara.sms4j.core.factory.SmsFactory; |  | ||||||
| import org.springframework.validation.annotation.Validated; |  | ||||||
| import org.springframework.web.bind.annotation.GetMapping; |  | ||||||
| import org.springframework.web.bind.annotation.RequestMapping; |  | ||||||
| import org.springframework.web.bind.annotation.RestController; |  | ||||||
|  |  | ||||||
| import java.util.LinkedHashMap; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * 短信演示案例 |  | ||||||
|  * 请先阅读文档 否则无法使用 |  | ||||||
|  * |  | ||||||
|  * @author Lion Li |  | ||||||
|  * @version 4.2.0 |  | ||||||
|  */ |  | ||||||
| @Validated |  | ||||||
| @RequiredArgsConstructor |  | ||||||
| @RestController |  | ||||||
| @RequestMapping("/demo/sms") |  | ||||||
| public class SmsController { |  | ||||||
|     /** |  | ||||||
|      * 发送短信Aliyun |  | ||||||
|      * |  | ||||||
|      * @param phones     电话号 |  | ||||||
|      * @param templateId 模板ID |  | ||||||
|      */ |  | ||||||
|     @GetMapping("/sendAliyun") |  | ||||||
|     public R<Object> sendAliyun(String phones, String templateId) { |  | ||||||
|         LinkedHashMap<String, String> map = new LinkedHashMap<>(1); |  | ||||||
|         map.put("code", "1234"); |  | ||||||
|         SmsBlend smsBlend = SmsFactory.getSmsBlend("config1"); |  | ||||||
|         SmsResponse smsResponse = smsBlend.sendMessage(phones, templateId, map); |  | ||||||
|         return R.ok(smsResponse); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 发送短信Tencent |  | ||||||
|      * |  | ||||||
|      * @param phones     电话号 |  | ||||||
|      * @param templateId 模板ID |  | ||||||
|      */ |  | ||||||
|     @GetMapping("/sendTencent") |  | ||||||
|     public R<Object> sendTencent(String phones, String templateId) { |  | ||||||
|         LinkedHashMap<String, String> map = new LinkedHashMap<>(1); |  | ||||||
| //        map.put("2", "测试测试"); |  | ||||||
|         map.put("1", "1234"); |  | ||||||
|         SmsBlend smsBlend = SmsFactory.getSmsBlend("config2"); |  | ||||||
|         SmsResponse smsResponse = smsBlend.sendMessage(phones, templateId, map); |  | ||||||
|         return R.ok(smsResponse); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 添加黑名单 |  | ||||||
|      * |  | ||||||
|      * @param phone 手机号 |  | ||||||
|      */ |  | ||||||
|     @GetMapping("/addBlacklist") |  | ||||||
|     public R<Object> addBlacklist(String phone){ |  | ||||||
|         SmsBlend smsBlend = SmsFactory.getSmsBlend("config1"); |  | ||||||
|         smsBlend.joinInBlacklist(phone); |  | ||||||
|         return R.ok(); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 移除黑名单 |  | ||||||
|      * |  | ||||||
|      * @param phone 手机号 |  | ||||||
|      */ |  | ||||||
|     @GetMapping("/removeBlacklist") |  | ||||||
|     public R<Object> removeBlacklist(String phone){ |  | ||||||
|         SmsBlend smsBlend = SmsFactory.getSmsBlend("config1"); |  | ||||||
|         smsBlend.removeFromBlacklist(phone); |  | ||||||
|         return R.ok(); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } |  | ||||||
| @ -1,31 +0,0 @@ | |||||||
| package org.dromara.demo.controller; |  | ||||||
|  |  | ||||||
| import org.dromara.common.core.domain.R; |  | ||||||
| import org.springframework.http.MediaType; |  | ||||||
| import org.springframework.web.bind.annotation.PostMapping; |  | ||||||
| import org.springframework.web.bind.annotation.RequestMapping; |  | ||||||
| import org.springframework.web.bind.annotation.RequestPart; |  | ||||||
| import org.springframework.web.bind.annotation.RestController; |  | ||||||
| import org.springframework.web.multipart.MultipartFile; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * swagger3 用法示例 |  | ||||||
|  * |  | ||||||
|  * @author Lion Li |  | ||||||
|  */ |  | ||||||
| @RestController |  | ||||||
| @RequestMapping("/swagger/demo") |  | ||||||
| public class Swagger3DemoController { |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 上传请求 |  | ||||||
|      * 必须使用 @RequestPart 注解标注为文件 |  | ||||||
|      * |  | ||||||
|      * @param file 文件 |  | ||||||
|      */ |  | ||||||
|     @PostMapping(value = "/upload", consumes = MediaType.MULTIPART_FORM_DATA_VALUE) |  | ||||||
|     public R<String> upload(@RequestPart("file") MultipartFile file) { |  | ||||||
|         return R.ok("操作成功", file.getOriginalFilename()); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } |  | ||||||
| @ -1,90 +0,0 @@ | |||||||
| package org.dromara.demo.controller; |  | ||||||
|  |  | ||||||
| import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; |  | ||||||
| import org.dromara.common.core.domain.R; |  | ||||||
| import org.dromara.common.web.core.BaseController; |  | ||||||
| import org.dromara.demo.domain.TestDemo; |  | ||||||
| import org.dromara.demo.mapper.TestDemoMapper; |  | ||||||
| import lombok.RequiredArgsConstructor; |  | ||||||
| import org.springframework.web.bind.annotation.DeleteMapping; |  | ||||||
| import org.springframework.web.bind.annotation.PostMapping; |  | ||||||
| import org.springframework.web.bind.annotation.RequestMapping; |  | ||||||
| import org.springframework.web.bind.annotation.RestController; |  | ||||||
|  |  | ||||||
| import java.util.ArrayList; |  | ||||||
| import java.util.List; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * 测试批量方法 |  | ||||||
|  * |  | ||||||
|  * @author Lion Li |  | ||||||
|  * @date 2021-05-30 |  | ||||||
|  */ |  | ||||||
| @RequiredArgsConstructor |  | ||||||
| @RestController |  | ||||||
| @RequestMapping("/demo/batch") |  | ||||||
| public class TestBatchController extends BaseController { |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 为了便于测试 直接引入mapper |  | ||||||
|      */ |  | ||||||
|     private final TestDemoMapper testDemoMapper; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 新增批量方法 可完美替代 saveBatch 秒级插入上万数据 (对mysql负荷较大) |  | ||||||
|      * <p> |  | ||||||
|      * 3.5.0 版本 增加 rewriteBatchedStatements=true 批处理参数 使 MP 原生批处理可以达到同样的速度 |  | ||||||
|      */ |  | ||||||
|     @PostMapping("/add") |  | ||||||
| //    @DS("slave") |  | ||||||
|     public R<Void> add() { |  | ||||||
|         List<TestDemo> list = new ArrayList<>(); |  | ||||||
|         for (int i = 0; i < 1000; i++) { |  | ||||||
|             TestDemo testDemo = new TestDemo(); |  | ||||||
|             testDemo.setOrderNum(-1); |  | ||||||
|             testDemo.setTestKey("批量新增"); |  | ||||||
|             testDemo.setValue("测试新增"); |  | ||||||
|             list.add(testDemo); |  | ||||||
|         } |  | ||||||
|         return toAjax(testDemoMapper.insertBatch(list)); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 新增或更新 可完美替代 saveOrUpdateBatch 高性能 |  | ||||||
|      * <p> |  | ||||||
|      * 3.5.0 版本 增加 rewriteBatchedStatements=true 批处理参数 使 MP 原生批处理可以达到同样的速度 |  | ||||||
|      */ |  | ||||||
|     @PostMapping("/addOrUpdate") |  | ||||||
| //    @DS("slave") |  | ||||||
|     public R<Void> addOrUpdate() { |  | ||||||
|         List<TestDemo> list = new ArrayList<>(); |  | ||||||
|         for (int i = 0; i < 1000; i++) { |  | ||||||
|             TestDemo testDemo = new TestDemo(); |  | ||||||
|             testDemo.setOrderNum(-1); |  | ||||||
|             testDemo.setTestKey("批量新增"); |  | ||||||
|             testDemo.setValue("测试新增"); |  | ||||||
|             list.add(testDemo); |  | ||||||
|         } |  | ||||||
|         testDemoMapper.insertBatch(list); |  | ||||||
|         for (int i = 0; i < list.size(); i++) { |  | ||||||
|             TestDemo testDemo = list.get(i); |  | ||||||
|             testDemo.setTestKey("批量新增或修改"); |  | ||||||
|             testDemo.setValue("批量新增或修改"); |  | ||||||
|             if (i % 2 == 0) { |  | ||||||
|                 testDemo.setId(null); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         return toAjax(testDemoMapper.insertOrUpdateBatch(list)); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 删除批量方法 |  | ||||||
|      */ |  | ||||||
|     @DeleteMapping() |  | ||||||
| //    @DS("slave") |  | ||||||
|     public R<Void> remove() { |  | ||||||
|         return toAjax(testDemoMapper.delete(new LambdaQueryWrapper<TestDemo>() |  | ||||||
|             .eq(TestDemo::getOrderNum, -1L))); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } |  | ||||||
| @ -1,147 +0,0 @@ | |||||||
| package org.dromara.demo.controller; |  | ||||||
|  |  | ||||||
| import cn.dev33.satoken.annotation.SaCheckPermission; |  | ||||||
| import org.dromara.common.core.domain.R; |  | ||||||
| import org.dromara.common.core.utils.MapstructUtils; |  | ||||||
| import org.dromara.common.core.utils.ValidatorUtils; |  | ||||||
| import org.dromara.common.core.validate.AddGroup; |  | ||||||
| import org.dromara.common.core.validate.EditGroup; |  | ||||||
| import org.dromara.common.core.validate.QueryGroup; |  | ||||||
| import org.dromara.common.web.core.BaseController; |  | ||||||
| import org.dromara.common.idempotent.annotation.RepeatSubmit; |  | ||||||
| import org.dromara.common.mybatis.core.page.PageQuery; |  | ||||||
| import org.dromara.common.mybatis.core.page.TableDataInfo; |  | ||||||
| import org.dromara.common.excel.core.ExcelResult; |  | ||||||
| import org.dromara.common.excel.utils.ExcelUtil; |  | ||||||
| import org.dromara.common.log.annotation.Log; |  | ||||||
| import org.dromara.common.log.enums.BusinessType; |  | ||||||
| import org.dromara.demo.domain.TestDemo; |  | ||||||
| import org.dromara.demo.domain.bo.TestDemoBo; |  | ||||||
| import org.dromara.demo.domain.bo.TestDemoImportVo; |  | ||||||
| import org.dromara.demo.domain.vo.TestDemoVo; |  | ||||||
| import org.dromara.demo.service.ITestDemoService; |  | ||||||
| import lombok.RequiredArgsConstructor; |  | ||||||
| import org.springframework.http.MediaType; |  | ||||||
| import org.springframework.validation.annotation.Validated; |  | ||||||
| import org.springframework.web.bind.annotation.*; |  | ||||||
| import org.springframework.web.multipart.MultipartFile; |  | ||||||
|  |  | ||||||
| import jakarta.servlet.http.HttpServletResponse; |  | ||||||
| import jakarta.validation.constraints.NotEmpty; |  | ||||||
| import jakarta.validation.constraints.NotNull; |  | ||||||
|  |  | ||||||
| import java.util.*; |  | ||||||
| import java.util.concurrent.TimeUnit; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * 测试单表Controller |  | ||||||
|  * |  | ||||||
|  * @author Lion Li |  | ||||||
|  * @date 2021-07-26 |  | ||||||
|  */ |  | ||||||
| @Validated |  | ||||||
| @RequiredArgsConstructor |  | ||||||
| @RestController |  | ||||||
| @RequestMapping("/demo/demo") |  | ||||||
| public class TestDemoController extends BaseController { |  | ||||||
|  |  | ||||||
|     private final ITestDemoService testDemoService; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 查询测试单表列表 |  | ||||||
|      */ |  | ||||||
|     @SaCheckPermission("demo:demo:list") |  | ||||||
|     @GetMapping("/list") |  | ||||||
|     public TableDataInfo<TestDemoVo> list(@Validated(QueryGroup.class) TestDemoBo bo, PageQuery pageQuery) { |  | ||||||
|         return testDemoService.queryPageList(bo, pageQuery); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 自定义分页查询 |  | ||||||
|      */ |  | ||||||
|     @SaCheckPermission("demo:demo:list") |  | ||||||
|     @GetMapping("/page") |  | ||||||
|     public TableDataInfo<TestDemoVo> page(@Validated(QueryGroup.class) TestDemoBo bo, PageQuery pageQuery) { |  | ||||||
|         return testDemoService.customPageList(bo, pageQuery); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 导入数据 |  | ||||||
|      * |  | ||||||
|      * @param file 导入文件 |  | ||||||
|      */ |  | ||||||
|     @Log(title = "测试单表", businessType = BusinessType.IMPORT) |  | ||||||
|     @SaCheckPermission("demo:demo:import") |  | ||||||
|     @PostMapping(value = "/importData", consumes = MediaType.MULTIPART_FORM_DATA_VALUE) |  | ||||||
|     public R<Void> importData(@RequestPart("file") MultipartFile file) throws Exception { |  | ||||||
|         ExcelResult<TestDemoImportVo> excelResult = ExcelUtil.importExcel(file.getInputStream(), TestDemoImportVo.class, true); |  | ||||||
|         List<TestDemo> list = MapstructUtils.convert(excelResult.getList(), TestDemo.class); |  | ||||||
|         testDemoService.saveBatch(list); |  | ||||||
|         return R.ok(excelResult.getAnalysis()); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 导出测试单表列表 |  | ||||||
|      */ |  | ||||||
|     @SaCheckPermission("demo:demo:export") |  | ||||||
|     @Log(title = "测试单表", businessType = BusinessType.EXPORT) |  | ||||||
|     @PostMapping("/export") |  | ||||||
|     public void export(@Validated TestDemoBo bo, HttpServletResponse response) { |  | ||||||
|         List<TestDemoVo> list = testDemoService.queryList(bo); |  | ||||||
|         // 测试雪花id导出 |  | ||||||
| //        for (TestDemoVo vo : list) { |  | ||||||
| //            vo.setId(1234567891234567893L); |  | ||||||
| //        } |  | ||||||
|         ExcelUtil.exportExcel(list, "测试单表", TestDemoVo.class, response); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 获取测试单表详细信息 |  | ||||||
|      * |  | ||||||
|      * @param id 测试ID |  | ||||||
|      */ |  | ||||||
|     @SaCheckPermission("demo:demo:query") |  | ||||||
|     @GetMapping("/{id}") |  | ||||||
|     public R<TestDemoVo> getInfo(@NotNull(message = "主键不能为空") |  | ||||||
|                                  @PathVariable("id") Long id) { |  | ||||||
|         return R.ok(testDemoService.queryById(id)); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 新增测试单表 |  | ||||||
|      */ |  | ||||||
|     @SaCheckPermission("demo:demo:add") |  | ||||||
|     @Log(title = "测试单表", businessType = BusinessType.INSERT) |  | ||||||
|     @RepeatSubmit(interval = 2, timeUnit = TimeUnit.SECONDS, message = "{repeat.submit.message}") |  | ||||||
|     @PostMapping() |  | ||||||
|     public R<Void> add(@RequestBody TestDemoBo bo) { |  | ||||||
|         // 使用校验工具对标 @Validated(AddGroup.class) 注解 |  | ||||||
|         // 用于在非 Controller 的地方校验对象 |  | ||||||
|         ValidatorUtils.validate(bo, AddGroup.class); |  | ||||||
|         return toAjax(testDemoService.insertByBo(bo)); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 修改测试单表 |  | ||||||
|      */ |  | ||||||
|     @SaCheckPermission("demo:demo:edit") |  | ||||||
|     @Log(title = "测试单表", businessType = BusinessType.UPDATE) |  | ||||||
|     @RepeatSubmit |  | ||||||
|     @PutMapping() |  | ||||||
|     public R<Void> edit(@Validated(EditGroup.class) @RequestBody TestDemoBo bo) { |  | ||||||
|         return toAjax(testDemoService.updateByBo(bo)); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 删除测试单表 |  | ||||||
|      * |  | ||||||
|      * @param ids 测试ID串 |  | ||||||
|      */ |  | ||||||
|     @SaCheckPermission("demo:demo:remove") |  | ||||||
|     @Log(title = "测试单表", businessType = BusinessType.DELETE) |  | ||||||
|     @DeleteMapping("/{ids}") |  | ||||||
|     public R<Void> remove(@NotEmpty(message = "主键不能为空") |  | ||||||
|                           @PathVariable Long[] ids) { |  | ||||||
|         return toAjax(testDemoService.deleteWithValidByIds(Arrays.asList(ids), true)); |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @ -1,55 +0,0 @@ | |||||||
| package org.dromara.demo.controller; |  | ||||||
|  |  | ||||||
| import org.dromara.common.core.domain.R; |  | ||||||
| import org.dromara.demo.domain.TestDemoEncrypt; |  | ||||||
| import org.dromara.demo.mapper.TestDemoEncryptMapper; |  | ||||||
| import org.springframework.beans.factory.annotation.Autowired; |  | ||||||
| import org.springframework.beans.factory.annotation.Value; |  | ||||||
| import org.springframework.validation.annotation.Validated; |  | ||||||
| import org.springframework.web.bind.annotation.GetMapping; |  | ||||||
| import org.springframework.web.bind.annotation.RequestMapping; |  | ||||||
| import org.springframework.web.bind.annotation.RestController; |  | ||||||
|  |  | ||||||
| import java.util.HashMap; |  | ||||||
| import java.util.Map; |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * 测试数据库加解密功能 |  | ||||||
|  * |  | ||||||
|  * @author Lion Li |  | ||||||
|  */ |  | ||||||
| @Validated |  | ||||||
| @RestController |  | ||||||
| @RequestMapping("/demo/encrypt") |  | ||||||
| public class TestEncryptController { |  | ||||||
|  |  | ||||||
|     @Autowired |  | ||||||
|     private TestDemoEncryptMapper mapper; |  | ||||||
|     @Value("${mybatis-encryptor.enable}") |  | ||||||
|     private Boolean encryptEnable; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 测试数据库加解密 |  | ||||||
|      * |  | ||||||
|      * @param key   测试key |  | ||||||
|      * @param value 测试value |  | ||||||
|      */ |  | ||||||
|     @GetMapping() |  | ||||||
|     public R<Map<String, TestDemoEncrypt>> test(String key, String value) { |  | ||||||
|         if (!encryptEnable) { |  | ||||||
|             throw new RuntimeException("加密功能未开启!"); |  | ||||||
|         } |  | ||||||
|         Map<String, TestDemoEncrypt> map = new HashMap<>(2); |  | ||||||
|         TestDemoEncrypt demo = new TestDemoEncrypt(); |  | ||||||
|         demo.setTestKey(key); |  | ||||||
|         demo.setValue(value); |  | ||||||
|         mapper.insert(demo); |  | ||||||
|         map.put("加密", demo); |  | ||||||
|         TestDemoEncrypt testDemo = mapper.selectById(demo.getId()); |  | ||||||
|         map.put("解密", testDemo); |  | ||||||
|         return R.ok(map); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| } |  | ||||||
| @ -1,160 +0,0 @@ | |||||||
| package org.dromara.demo.controller; |  | ||||||
|  |  | ||||||
| import cn.hutool.core.collection.CollUtil; |  | ||||||
| import jakarta.servlet.http.HttpServletResponse; |  | ||||||
| import lombok.AllArgsConstructor; |  | ||||||
| import lombok.Data; |  | ||||||
| import lombok.RequiredArgsConstructor; |  | ||||||
| import org.dromara.common.excel.core.ExcelResult; |  | ||||||
| import org.dromara.common.excel.utils.ExcelUtil; |  | ||||||
| import org.dromara.demo.domain.vo.ExportDemoVo; |  | ||||||
| import org.dromara.demo.listener.ExportDemoListener; |  | ||||||
| import org.dromara.demo.service.IExportExcelService; |  | ||||||
| import org.springframework.http.MediaType; |  | ||||||
| import org.springframework.web.bind.annotation.*; |  | ||||||
| import org.springframework.web.multipart.MultipartFile; |  | ||||||
|  |  | ||||||
| import java.util.ArrayList; |  | ||||||
| import java.util.HashMap; |  | ||||||
| import java.util.List; |  | ||||||
| import java.util.Map; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * 测试Excel功能 |  | ||||||
|  * |  | ||||||
|  * @author Lion Li |  | ||||||
|  */ |  | ||||||
| @RequiredArgsConstructor |  | ||||||
| @RestController |  | ||||||
| @RequestMapping("/demo/excel") |  | ||||||
| public class TestExcelController { |  | ||||||
|  |  | ||||||
|     private final IExportExcelService exportExcelService; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 单列表多数据 |  | ||||||
|      */ |  | ||||||
|     @GetMapping("/exportTemplateOne") |  | ||||||
|     public void exportTemplateOne(HttpServletResponse response) { |  | ||||||
|         Map<String, String> map = new HashMap<>(); |  | ||||||
|         map.put("title", "单列表多数据"); |  | ||||||
|         map.put("test1", "数据测试1"); |  | ||||||
|         map.put("test2", "数据测试2"); |  | ||||||
|         map.put("test3", "数据测试3"); |  | ||||||
|         map.put("test4", "数据测试4"); |  | ||||||
|         map.put("testTest", "666"); |  | ||||||
|         List<TestObj> list = new ArrayList<>(); |  | ||||||
|         list.add(new TestObj("单列表测试1", "列表测试1", "列表测试2", "列表测试3", "列表测试4")); |  | ||||||
|         list.add(new TestObj("单列表测试2", "列表测试5", "列表测试6", "列表测试7", "列表测试8")); |  | ||||||
|         list.add(new TestObj("单列表测试3", "列表测试9", "列表测试10", "列表测试11", "列表测试12")); |  | ||||||
|         ExcelUtil.exportTemplate(CollUtil.newArrayList(map, list), "单列表.xlsx", "excel/单列表.xlsx", response); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 多列表多数据 |  | ||||||
|      */ |  | ||||||
|     @GetMapping("/exportTemplateMuliti") |  | ||||||
|     public void exportTemplateMuliti(HttpServletResponse response) { |  | ||||||
|         Map<String, String> map = new HashMap<>(); |  | ||||||
|         map.put("title1", "标题1"); |  | ||||||
|         map.put("title2", "标题2"); |  | ||||||
|         map.put("title3", "标题3"); |  | ||||||
|         map.put("title4", "标题4"); |  | ||||||
|         map.put("author", "Lion Li"); |  | ||||||
|         List<TestObj1> list1 = new ArrayList<>(); |  | ||||||
|         list1.add(new TestObj1("list1测试1", "list1测试2", "list1测试3")); |  | ||||||
|         list1.add(new TestObj1("list1测试4", "list1测试5", "list1测试6")); |  | ||||||
|         list1.add(new TestObj1("list1测试7", "list1测试8", "list1测试9")); |  | ||||||
|         List<TestObj1> list2 = new ArrayList<>(); |  | ||||||
|         list2.add(new TestObj1("list2测试1", "list2测试2", "list2测试3")); |  | ||||||
|         list2.add(new TestObj1("list2测试4", "list2测试5", "list2测试6")); |  | ||||||
|         List<TestObj1> list3 = new ArrayList<>(); |  | ||||||
|         list3.add(new TestObj1("list3测试1", "list3测试2", "list3测试3")); |  | ||||||
|         List<TestObj1> list4 = new ArrayList<>(); |  | ||||||
|         list4.add(new TestObj1("list4测试1", "list4测试2", "list4测试3")); |  | ||||||
|         list4.add(new TestObj1("list4测试4", "list4测试5", "list4测试6")); |  | ||||||
|         list4.add(new TestObj1("list4测试7", "list4测试8", "list4测试9")); |  | ||||||
|         list4.add(new TestObj1("list4测试10", "list4测试11", "list4测试12")); |  | ||||||
|         Map<String, Object> multiListMap = new HashMap<>(); |  | ||||||
|         multiListMap.put("map", map); |  | ||||||
|         multiListMap.put("data1", list1); |  | ||||||
|         multiListMap.put("data2", list2); |  | ||||||
|         multiListMap.put("data3", list3); |  | ||||||
|         multiListMap.put("data4", list4); |  | ||||||
|         ExcelUtil.exportTemplateMultiList(multiListMap, "多列表.xlsx", "excel/多列表.xlsx", response); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 导出下拉框 |  | ||||||
|      * |  | ||||||
|      * @param response / |  | ||||||
|      */ |  | ||||||
|     @GetMapping("/exportWithOptions") |  | ||||||
|     public void exportWithOptions(HttpServletResponse response) { |  | ||||||
|         exportExcelService.exportWithOptions(response); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 多个sheet导出 |  | ||||||
|      */ |  | ||||||
|     @GetMapping("/exportTemplateMultiSheet") |  | ||||||
|     public void exportTemplateMultiSheet(HttpServletResponse response) { |  | ||||||
|         List<TestObj1> list1 = new ArrayList<>(); |  | ||||||
|         list1.add(new TestObj1("list1测试1", "list1测试2", "list1测试3")); |  | ||||||
|         list1.add(new TestObj1("list1测试4", "list1测试5", "list1测试6")); |  | ||||||
|         List<TestObj1> list2 = new ArrayList<>(); |  | ||||||
|         list2.add(new TestObj1("list2测试1", "list2测试2", "list2测试3")); |  | ||||||
|         list2.add(new TestObj1("list2测试4", "list2测试5", "list2测试6")); |  | ||||||
|         List<TestObj1> list3 = new ArrayList<>(); |  | ||||||
|         list3.add(new TestObj1("list3测试1", "list3测试2", "list3测试3")); |  | ||||||
|         list3.add(new TestObj1("list3测试4", "list3测试5", "list3测试6")); |  | ||||||
|         List<TestObj1> list4 = new ArrayList<>(); |  | ||||||
|         list4.add(new TestObj1("list4测试1", "list4测试2", "list4测试3")); |  | ||||||
|         list4.add(new TestObj1("list4测试4", "list4测试5", "list4测试6")); |  | ||||||
|  |  | ||||||
|         List<Map<String, Object>> list = new ArrayList<>(); |  | ||||||
|         Map<String, Object> sheetMap1 = new HashMap<>(); |  | ||||||
|         sheetMap1.put("data1", list1); |  | ||||||
|         Map<String, Object> sheetMap2 = new HashMap<>(); |  | ||||||
|         sheetMap2.put("data2", list2); |  | ||||||
|         Map<String, Object> sheetMap3 = new HashMap<>(); |  | ||||||
|         sheetMap3.put("data3", list3); |  | ||||||
|         Map<String, Object> sheetMap4 = new HashMap<>(); |  | ||||||
|         sheetMap4.put("data4", list4); |  | ||||||
|  |  | ||||||
|         list.add(sheetMap1); |  | ||||||
|         list.add(sheetMap2); |  | ||||||
|         list.add(sheetMap3); |  | ||||||
|         list.add(sheetMap4); |  | ||||||
|         ExcelUtil.exportTemplateMultiSheet(list, "多sheet列表", "excel/多sheet列表.xlsx", response); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 导入表格 |  | ||||||
|      */ |  | ||||||
|     @PostMapping(value = "/importWithOptions", consumes = MediaType.MULTIPART_FORM_DATA_VALUE) |  | ||||||
|     public List<ExportDemoVo> importWithOptions(@RequestPart("file") MultipartFile file) throws Exception { |  | ||||||
|         // 处理解析结果 |  | ||||||
|         ExcelResult<ExportDemoVo> excelResult = ExcelUtil.importExcel(file.getInputStream(), ExportDemoVo.class, new ExportDemoListener()); |  | ||||||
|         return excelResult.getList(); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Data |  | ||||||
|     @AllArgsConstructor |  | ||||||
|     static class TestObj1 { |  | ||||||
|         private String test1; |  | ||||||
|         private String test2; |  | ||||||
|         private String test3; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Data |  | ||||||
|     @AllArgsConstructor |  | ||||||
|     static class TestObj { |  | ||||||
|         private String name; |  | ||||||
|         private String list1; |  | ||||||
|         private String list2; |  | ||||||
|         private String list3; |  | ||||||
|         private String list4; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } |  | ||||||
| @ -1,71 +0,0 @@ | |||||||
| package org.dromara.demo.controller; |  | ||||||
|  |  | ||||||
| import org.dromara.common.core.domain.R; |  | ||||||
| import org.dromara.common.core.utils.MessageUtils; |  | ||||||
| import lombok.Data; |  | ||||||
| import org.hibernate.validator.constraints.Range; |  | ||||||
| import org.springframework.validation.annotation.Validated; |  | ||||||
| import org.springframework.web.bind.annotation.GetMapping; |  | ||||||
| import org.springframework.web.bind.annotation.RequestMapping; |  | ||||||
| import org.springframework.web.bind.annotation.RestController; |  | ||||||
|  |  | ||||||
| import jakarta.validation.constraints.NotBlank; |  | ||||||
| import jakarta.validation.constraints.NotNull; |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * 测试国际化 |  | ||||||
|  * |  | ||||||
|  * @author Lion Li |  | ||||||
|  */ |  | ||||||
| @Validated |  | ||||||
| @RestController |  | ||||||
| @RequestMapping("/demo/i18n") |  | ||||||
| public class TestI18nController { |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 通过code获取国际化内容 |  | ||||||
|      * code为 messages.properties 中的 key |  | ||||||
|      * <p> |  | ||||||
|      * 测试使用 user.register.success |  | ||||||
|      * |  | ||||||
|      * @param code 国际化code |  | ||||||
|      */ |  | ||||||
|     @GetMapping() |  | ||||||
|     public R<Void> get(String code) { |  | ||||||
|         return R.ok(MessageUtils.message(code)); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * Validator 校验国际化 |  | ||||||
|      * 不传值 分别查看异常返回 |  | ||||||
|      * <p> |  | ||||||
|      * 测试使用 not.null |  | ||||||
|      */ |  | ||||||
|     @GetMapping("/test1") |  | ||||||
|     public R<Void> test1(@NotBlank(message = "{not.null}") String str) { |  | ||||||
|         return R.ok(str); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * Bean 校验国际化 |  | ||||||
|      * 不传值 分别查看异常返回 |  | ||||||
|      * <p> |  | ||||||
|      * 测试使用 not.null |  | ||||||
|      */ |  | ||||||
|     @GetMapping("/test2") |  | ||||||
|     public R<TestI18nBo> test2(@Validated TestI18nBo bo) { |  | ||||||
|         return R.ok(bo); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Data |  | ||||||
|     public static class TestI18nBo { |  | ||||||
|  |  | ||||||
|         @NotBlank(message = "{not.null}") |  | ||||||
|         private String name; |  | ||||||
|  |  | ||||||
|         @NotNull(message = "{not.null}") |  | ||||||
|         @Range(min = 0, max = 100, message = "{length.not.valid}") |  | ||||||
|         private Integer age; |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @ -1,76 +0,0 @@ | |||||||
| package org.dromara.demo.controller; |  | ||||||
|  |  | ||||||
| import org.dromara.common.core.domain.R; |  | ||||||
| import org.dromara.common.web.core.BaseController; |  | ||||||
| import org.dromara.common.sensitive.annotation.Sensitive; |  | ||||||
| import org.dromara.common.sensitive.core.SensitiveStrategy; |  | ||||||
| import lombok.Data; |  | ||||||
| import org.dromara.common.sensitive.core.SensitiveService; |  | ||||||
| import org.springframework.web.bind.annotation.GetMapping; |  | ||||||
| import org.springframework.web.bind.annotation.RequestMapping; |  | ||||||
| import org.springframework.web.bind.annotation.RestController; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * 测试数据脱敏控制器 |  | ||||||
|  * <p> |  | ||||||
|  * 默认管理员不过滤 |  | ||||||
|  * 需自行根据业务重写实现 |  | ||||||
|  * |  | ||||||
|  * @author Lion Li |  | ||||||
|  * @version 3.6.0 |  | ||||||
|  * @see SensitiveService |  | ||||||
|  */ |  | ||||||
| @RestController |  | ||||||
| @RequestMapping("/demo/sensitive") |  | ||||||
| public class TestSensitiveController extends BaseController { |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 测试数据脱敏 |  | ||||||
|      */ |  | ||||||
|     @GetMapping("/test") |  | ||||||
|     public R<TestSensitive> test() { |  | ||||||
|         TestSensitive testSensitive = new TestSensitive(); |  | ||||||
|         testSensitive.setIdCard("210397198608215431"); |  | ||||||
|         testSensitive.setPhone("17640125371"); |  | ||||||
|         testSensitive.setAddress("北京市朝阳区某某四合院1203室"); |  | ||||||
|         testSensitive.setEmail("17640125371@163.com"); |  | ||||||
|         testSensitive.setBankCard("6226456952351452853"); |  | ||||||
|         return R.ok(testSensitive); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Data |  | ||||||
|     static class TestSensitive { |  | ||||||
|  |  | ||||||
|         /** |  | ||||||
|          * 身份证 |  | ||||||
|          */ |  | ||||||
|         @Sensitive(strategy = SensitiveStrategy.ID_CARD) |  | ||||||
|         private String idCard; |  | ||||||
|  |  | ||||||
|         /** |  | ||||||
|          * 电话 |  | ||||||
|          */ |  | ||||||
|         @Sensitive(strategy = SensitiveStrategy.PHONE, roleKey = "common") |  | ||||||
|         private String phone; |  | ||||||
|  |  | ||||||
|         /** |  | ||||||
|          * 地址 |  | ||||||
|          */ |  | ||||||
|         @Sensitive(strategy = SensitiveStrategy.ADDRESS, perms = "system:user:query") |  | ||||||
|         private String address; |  | ||||||
|  |  | ||||||
|         /** |  | ||||||
|          * 邮箱 |  | ||||||
|          */ |  | ||||||
|         @Sensitive(strategy = SensitiveStrategy.EMAIL, roleKey = "common", perms = "system:user:query1") |  | ||||||
|         private String email; |  | ||||||
|  |  | ||||||
|         /** |  | ||||||
|          * 银行卡 |  | ||||||
|          */ |  | ||||||
|         @Sensitive(strategy = SensitiveStrategy.BANK_CARD, roleKey = "common1", perms = "system:user:query") |  | ||||||
|         private String bankCard; |  | ||||||
|  |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } |  | ||||||
| @ -1,107 +0,0 @@ | |||||||
| package org.dromara.demo.controller; |  | ||||||
|  |  | ||||||
| import cn.dev33.satoken.annotation.SaCheckPermission; |  | ||||||
| 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.core.validate.QueryGroup; |  | ||||||
| import org.dromara.common.web.core.BaseController; |  | ||||||
| import org.dromara.common.excel.utils.ExcelUtil; |  | ||||||
| import org.dromara.common.idempotent.annotation.RepeatSubmit; |  | ||||||
| import org.dromara.common.log.annotation.Log; |  | ||||||
| import org.dromara.common.log.enums.BusinessType; |  | ||||||
| import org.dromara.demo.domain.bo.TestTreeBo; |  | ||||||
| import org.dromara.demo.domain.vo.TestTreeVo; |  | ||||||
| import org.dromara.demo.service.ITestTreeService; |  | ||||||
| import lombok.RequiredArgsConstructor; |  | ||||||
| import org.springframework.validation.annotation.Validated; |  | ||||||
| import org.springframework.web.bind.annotation.*; |  | ||||||
|  |  | ||||||
| import jakarta.servlet.http.HttpServletResponse; |  | ||||||
| import jakarta.validation.constraints.NotEmpty; |  | ||||||
| import jakarta.validation.constraints.NotNull; |  | ||||||
| import java.util.Arrays; |  | ||||||
| import java.util.List; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * 测试树表Controller |  | ||||||
|  * |  | ||||||
|  * @author Lion Li |  | ||||||
|  * @date 2021-07-26 |  | ||||||
|  */ |  | ||||||
| @Validated |  | ||||||
| @RequiredArgsConstructor |  | ||||||
| @RestController |  | ||||||
| @RequestMapping("/demo/tree") |  | ||||||
| public class TestTreeController extends BaseController { |  | ||||||
|  |  | ||||||
|     private final ITestTreeService testTreeService; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 查询测试树表列表 |  | ||||||
|      */ |  | ||||||
|     @SaCheckPermission("demo:tree:list") |  | ||||||
|     @GetMapping("/list") |  | ||||||
|     public R<List<TestTreeVo>> list(@Validated(QueryGroup.class) TestTreeBo bo) { |  | ||||||
|         List<TestTreeVo> list = testTreeService.queryList(bo); |  | ||||||
|         return R.ok(list); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 导出测试树表列表 |  | ||||||
|      */ |  | ||||||
|     @SaCheckPermission("demo:tree:export") |  | ||||||
|     @Log(title = "测试树表", businessType = BusinessType.EXPORT) |  | ||||||
|     @GetMapping("/export") |  | ||||||
|     public void export(@Validated TestTreeBo bo, HttpServletResponse response) { |  | ||||||
|         List<TestTreeVo> list = testTreeService.queryList(bo); |  | ||||||
|         ExcelUtil.exportExcel(list, "测试树表", TestTreeVo.class, response); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 获取测试树表详细信息 |  | ||||||
|      * |  | ||||||
|      * @param id 测试树ID |  | ||||||
|      */ |  | ||||||
|     @SaCheckPermission("demo:tree:query") |  | ||||||
|     @GetMapping("/{id}") |  | ||||||
|     public R<TestTreeVo> getInfo(@NotNull(message = "主键不能为空") |  | ||||||
|                                  @PathVariable("id") Long id) { |  | ||||||
|         return R.ok(testTreeService.queryById(id)); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 新增测试树表 |  | ||||||
|      */ |  | ||||||
|     @SaCheckPermission("demo:tree:add") |  | ||||||
|     @Log(title = "测试树表", businessType = BusinessType.INSERT) |  | ||||||
|     @RepeatSubmit |  | ||||||
|     @PostMapping() |  | ||||||
|     public R<Void> add(@Validated(AddGroup.class) @RequestBody TestTreeBo bo) { |  | ||||||
|         return toAjax(testTreeService.insertByBo(bo)); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 修改测试树表 |  | ||||||
|      */ |  | ||||||
|     @SaCheckPermission("demo:tree:edit") |  | ||||||
|     @Log(title = "测试树表", businessType = BusinessType.UPDATE) |  | ||||||
|     @RepeatSubmit |  | ||||||
|     @PutMapping() |  | ||||||
|     public R<Void> edit(@Validated(EditGroup.class) @RequestBody TestTreeBo bo) { |  | ||||||
|         return toAjax(testTreeService.updateByBo(bo)); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 删除测试树表 |  | ||||||
|      * |  | ||||||
|      * @param ids 测试树ID串 |  | ||||||
|      */ |  | ||||||
|     @SaCheckPermission("demo:tree:remove") |  | ||||||
|     @Log(title = "测试树表", businessType = BusinessType.DELETE) |  | ||||||
|     @DeleteMapping("/{ids}") |  | ||||||
|     public R<Void> remove(@NotEmpty(message = "主键不能为空") |  | ||||||
|                           @PathVariable Long[] ids) { |  | ||||||
|         return toAjax(testTreeService.deleteWithValidByIds(Arrays.asList(ids), true)); |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @ -1,33 +0,0 @@ | |||||||
| package org.dromara.demo.controller; |  | ||||||
|  |  | ||||||
| import org.dromara.common.core.domain.R; |  | ||||||
| import org.dromara.common.websocket.dto.WebSocketMessageDto; |  | ||||||
| import org.dromara.common.websocket.utils.WebSocketUtils; |  | ||||||
| import lombok.RequiredArgsConstructor; |  | ||||||
| import lombok.extern.slf4j.Slf4j; |  | ||||||
| import org.springframework.web.bind.annotation.GetMapping; |  | ||||||
| import org.springframework.web.bind.annotation.RequestMapping; |  | ||||||
| import org.springframework.web.bind.annotation.RestController; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * WebSocket 演示案例 |  | ||||||
|  * |  | ||||||
|  * @author zendwang |  | ||||||
|  */ |  | ||||||
| @RequiredArgsConstructor |  | ||||||
| @RestController |  | ||||||
| @RequestMapping("/demo/websocket") |  | ||||||
| @Slf4j |  | ||||||
| public class WeSocketController { |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 发布消息 |  | ||||||
|      * |  | ||||||
|      * @param dto 发送内容 |  | ||||||
|      */ |  | ||||||
|     @GetMapping("/send") |  | ||||||
|     public R<Void> send(WebSocketMessageDto dto) throws InterruptedException { |  | ||||||
|         WebSocketUtils.publishMessage(dto); |  | ||||||
|         return R.ok("操作成功"); |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @ -1 +0,0 @@ | |||||||
| package org.dromara.demo.controller; |  | ||||||
| @ -1,92 +0,0 @@ | |||||||
| package org.dromara.demo.controller.queue; |  | ||||||
|  |  | ||||||
| import cn.dev33.satoken.annotation.SaIgnore; |  | ||||||
| import org.dromara.common.core.domain.R; |  | ||||||
| import org.dromara.common.redis.utils.QueueUtils; |  | ||||||
| import lombok.RequiredArgsConstructor; |  | ||||||
| import lombok.extern.slf4j.Slf4j; |  | ||||||
| import org.redisson.api.RBoundedBlockingQueue; |  | ||||||
| import org.springframework.web.bind.annotation.GetMapping; |  | ||||||
| import org.springframework.web.bind.annotation.RequestMapping; |  | ||||||
| import org.springframework.web.bind.annotation.RestController; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * 有界队列 演示案例 |  | ||||||
|  * <p> |  | ||||||
|  * 轻量级队列 重量级数据量 请使用 MQ |  | ||||||
|  * <p> |  | ||||||
|  * 集群测试通过 同一个数据只会被消费一次 做好事务补偿 |  | ||||||
|  * 集群测试流程 在其中一台发送数据 两端分别调用获取接口 一次获取一条 |  | ||||||
|  * |  | ||||||
|  * @author Lion Li |  | ||||||
|  * @version 3.6.0 |  | ||||||
|  */ |  | ||||||
| @Slf4j |  | ||||||
| @RequiredArgsConstructor |  | ||||||
| @RestController |  | ||||||
| @RequestMapping("/demo/queue/bounded") |  | ||||||
| public class BoundedQueueController { |  | ||||||
|  |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 添加队列数据 |  | ||||||
|      * |  | ||||||
|      * @param queueName 队列名 |  | ||||||
|      * @param capacity  容量 |  | ||||||
|      */ |  | ||||||
|     @GetMapping("/add") |  | ||||||
|     public R<Void> add(String queueName, int capacity) { |  | ||||||
|         // 用完了一定要销毁 否则会一直存在 |  | ||||||
|         boolean b = QueueUtils.destroyBoundedQueue(queueName); |  | ||||||
|         log.info("通道: {} , 删除: {}", queueName, b); |  | ||||||
|         // 初始化设置一次即可 |  | ||||||
|         if (QueueUtils.trySetBoundedQueueCapacity(queueName, capacity)) { |  | ||||||
|             log.info("通道: {} , 设置容量: {}", queueName, capacity); |  | ||||||
|         } else { |  | ||||||
|             log.info("通道: {} , 设置容量失败", queueName); |  | ||||||
|             return R.fail("操作失败"); |  | ||||||
|         } |  | ||||||
|         for (int i = 0; i < 11; i++) { |  | ||||||
|             String data = "data-" + i; |  | ||||||
|             boolean flag = QueueUtils.addBoundedQueueObject(queueName, data); |  | ||||||
|             if (flag == false) { |  | ||||||
|                 log.info("通道: {} , 发送数据: {} 失败, 通道已满", queueName, data); |  | ||||||
|             } else { |  | ||||||
|                 log.info("通道: {} , 发送数据: {}", queueName, data); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         return R.ok("操作成功"); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 删除队列数据 |  | ||||||
|      * |  | ||||||
|      * @param queueName 队列名 |  | ||||||
|      */ |  | ||||||
|     @GetMapping("/remove") |  | ||||||
|     public R<Void> remove(String queueName) { |  | ||||||
|         String data = "data-" + 5; |  | ||||||
|         if (QueueUtils.removeBoundedQueueObject(queueName, data)) { |  | ||||||
|             log.info("通道: {} , 删除数据: {}", queueName, data); |  | ||||||
|         } else { |  | ||||||
|             return R.fail("操作失败"); |  | ||||||
|         } |  | ||||||
|         return R.ok("操作成功"); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 获取队列数据 |  | ||||||
|      * |  | ||||||
|      * @param queueName 队列名 |  | ||||||
|      */ |  | ||||||
|     @GetMapping("/get") |  | ||||||
|     public R<Void> get(String queueName) { |  | ||||||
|         String data; |  | ||||||
|         do { |  | ||||||
|             data = QueueUtils.getBoundedQueueObject(queueName); |  | ||||||
|             log.info("通道: {} , 获取数据: {}", queueName, data); |  | ||||||
|         } while (data != null); |  | ||||||
|         return R.ok("操作成功"); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } |  | ||||||
| @ -1,97 +0,0 @@ | |||||||
| package org.dromara.demo.controller.queue; |  | ||||||
|  |  | ||||||
| import cn.dev33.satoken.annotation.SaIgnore; |  | ||||||
| import lombok.RequiredArgsConstructor; |  | ||||||
| import lombok.extern.slf4j.Slf4j; |  | ||||||
| import org.dromara.common.core.domain.R; |  | ||||||
| import org.dromara.common.redis.utils.QueueUtils; |  | ||||||
| import org.springframework.web.bind.annotation.GetMapping; |  | ||||||
| import org.springframework.web.bind.annotation.RequestMapping; |  | ||||||
| import org.springframework.web.bind.annotation.RestController; |  | ||||||
|  |  | ||||||
| import java.util.concurrent.CompletableFuture; |  | ||||||
| import java.util.concurrent.TimeUnit; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * 延迟队列 演示案例 |  | ||||||
|  * <p> |  | ||||||
|  * 轻量级队列 重量级数据量 请使用 MQ |  | ||||||
|  * 例如: 创建订单30分钟后过期处理 |  | ||||||
|  * <p> |  | ||||||
|  * 集群测试通过 同一个数据只会被消费一次 做好事务补偿 |  | ||||||
|  * 集群测试流程 两台集群分别开启订阅 在其中一台发送数据 观察接收消息的规律 |  | ||||||
|  * |  | ||||||
|  * @author Lion Li |  | ||||||
|  * @version 3.6.0 |  | ||||||
|  */ |  | ||||||
| @SaIgnore |  | ||||||
| @Slf4j |  | ||||||
| @RequiredArgsConstructor |  | ||||||
| @RestController |  | ||||||
| @RequestMapping("/demo/queue/delayed") |  | ||||||
| public class DelayedQueueController { |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 订阅队列 |  | ||||||
|      * |  | ||||||
|      * @param queueName 队列名 |  | ||||||
|      */ |  | ||||||
|     @GetMapping("/subscribe") |  | ||||||
|     public R<Void> subscribe(String queueName) { |  | ||||||
|         log.info("通道: {} 监听中......", queueName); |  | ||||||
|         // 项目初始化设置一次即可 |  | ||||||
|         QueueUtils.subscribeBlockingQueue(queueName, (String orderNum) -> { |  | ||||||
|             // 观察接收时间 |  | ||||||
|             log.info("通道: {}, 收到数据: {}", queueName, orderNum); |  | ||||||
|             return CompletableFuture.runAsync(() -> { |  | ||||||
|                 // 异步处理数据逻辑 不要在上方处理业务逻辑 |  | ||||||
|                 log.info("数据处理: {}", orderNum); |  | ||||||
|             }); |  | ||||||
|         }, true); |  | ||||||
|         return R.ok("操作成功"); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 添加队列数据 |  | ||||||
|      * |  | ||||||
|      * @param queueName 队列名 |  | ||||||
|      * @param orderNum  订单号 |  | ||||||
|      * @param time      延迟时间(秒) |  | ||||||
|      */ |  | ||||||
|     @GetMapping("/add") |  | ||||||
|     public R<Void> add(String queueName, String orderNum, Long time) { |  | ||||||
|         QueueUtils.addDelayedQueueObject(queueName, orderNum, time, TimeUnit.SECONDS); |  | ||||||
|         // 观察发送时间 |  | ||||||
|         log.info("通道: {} , 发送数据: {}", queueName, orderNum); |  | ||||||
|         return R.ok("操作成功"); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 删除队列数据 |  | ||||||
|      * |  | ||||||
|      * @param queueName 队列名 |  | ||||||
|      * @param orderNum  订单号 |  | ||||||
|      */ |  | ||||||
|     @GetMapping("/remove") |  | ||||||
|     public R<Void> remove(String queueName, String orderNum) { |  | ||||||
|         if (QueueUtils.removeDelayedQueueObject(queueName, orderNum)) { |  | ||||||
|             log.info("通道: {} , 删除数据: {}", queueName, orderNum); |  | ||||||
|         } else { |  | ||||||
|             return R.fail("操作失败"); |  | ||||||
|         } |  | ||||||
|         return R.ok("操作成功"); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 销毁队列 |  | ||||||
|      * |  | ||||||
|      * @param queueName 队列名 |  | ||||||
|      */ |  | ||||||
|     @GetMapping("/destroy") |  | ||||||
|     public R<Void> destroy(String queueName) { |  | ||||||
|         // 用完了一定要销毁 否则会一直存在 |  | ||||||
|         QueueUtils.destroyDelayedQueue(queueName); |  | ||||||
|         return R.ok("操作成功"); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } |  | ||||||
| @ -1,22 +0,0 @@ | |||||||
| package org.dromara.demo.controller.queue; |  | ||||||
|  |  | ||||||
| import lombok.Data; |  | ||||||
| import lombok.NoArgsConstructor; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * 实体类 注意不允许使用内部类 否则会找不到类 |  | ||||||
|  * |  | ||||||
|  * @author Lion Li |  | ||||||
|  * @version 3.6.0 |  | ||||||
|  */ |  | ||||||
| @Data |  | ||||||
| @NoArgsConstructor |  | ||||||
| public class PriorityDemo implements Comparable<PriorityDemo> { |  | ||||||
|     private String name; |  | ||||||
|     private Integer orderNum; |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public int compareTo(PriorityDemo other) { |  | ||||||
|         return Integer.compare(getOrderNum(), other.getOrderNum()); |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @ -1,89 +0,0 @@ | |||||||
| package org.dromara.demo.controller.queue; |  | ||||||
|  |  | ||||||
| import cn.hutool.core.util.RandomUtil; |  | ||||||
| import org.dromara.common.core.domain.R; |  | ||||||
| import org.dromara.common.redis.utils.QueueUtils; |  | ||||||
| import lombok.RequiredArgsConstructor; |  | ||||||
| import lombok.extern.slf4j.Slf4j; |  | ||||||
| import org.springframework.web.bind.annotation.GetMapping; |  | ||||||
| import org.springframework.web.bind.annotation.RequestMapping; |  | ||||||
| import org.springframework.web.bind.annotation.RestController; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * 优先队列 演示案例 |  | ||||||
|  * <p> |  | ||||||
|  * 轻量级队列 重量级数据量 请使用 MQ |  | ||||||
|  * <p> |  | ||||||
|  * 集群测试通过 同一个消息只会被消费一次 做好事务补偿 |  | ||||||
|  * 集群测试流程 在其中一台发送数据 两端分别调用获取接口 一次获取一条 |  | ||||||
|  * |  | ||||||
|  * @author Lion Li |  | ||||||
|  * @version 3.6.0 |  | ||||||
|  */ |  | ||||||
| @Slf4j |  | ||||||
| @RequiredArgsConstructor |  | ||||||
| @RestController |  | ||||||
| @RequestMapping("/demo/queue/priority") |  | ||||||
| public class PriorityQueueController { |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 添加队列数据 |  | ||||||
|      * |  | ||||||
|      * @param queueName 队列名 |  | ||||||
|      */ |  | ||||||
|     @GetMapping("/add") |  | ||||||
|     public R<Void> add(String queueName) { |  | ||||||
|         // 用完了一定要销毁 否则会一直存在 |  | ||||||
|         boolean b = QueueUtils.destroyPriorityQueue(queueName); |  | ||||||
|         log.info("通道: {} , 删除: {}", queueName, b); |  | ||||||
|  |  | ||||||
|         for (int i = 0; i < 10; i++) { |  | ||||||
|             int randomNum = RandomUtil.randomInt(10); |  | ||||||
|             PriorityDemo data = new PriorityDemo(); |  | ||||||
|             data.setName("data-" + i); |  | ||||||
|             data.setOrderNum(randomNum); |  | ||||||
|             if (QueueUtils.addPriorityQueueObject(queueName, data)) { |  | ||||||
|                 log.info("通道: {} , 发送数据: {}", queueName, data); |  | ||||||
|             } else { |  | ||||||
|                 log.info("通道: {} , 发送数据: {}, 发送失败", queueName, data); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         return R.ok("操作成功"); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 删除队列数据 |  | ||||||
|      * |  | ||||||
|      * @param queueName 队列名 |  | ||||||
|      * @param name      对象名 |  | ||||||
|      * @param orderNum  排序号 |  | ||||||
|      */ |  | ||||||
|     @GetMapping("/remove") |  | ||||||
|     public R<Void> remove(String queueName, String name, Integer orderNum) { |  | ||||||
|         PriorityDemo data = new PriorityDemo(); |  | ||||||
|         data.setName(name); |  | ||||||
|         data.setOrderNum(orderNum); |  | ||||||
|         if (QueueUtils.removePriorityQueueObject(queueName, data)) { |  | ||||||
|             log.info("通道: {} , 删除数据: {}", queueName, data); |  | ||||||
|         } else { |  | ||||||
|             return R.fail("操作失败"); |  | ||||||
|         } |  | ||||||
|         return R.ok("操作成功"); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 获取队列数据 |  | ||||||
|      * |  | ||||||
|      * @param queueName 队列名 |  | ||||||
|      */ |  | ||||||
|     @GetMapping("/get") |  | ||||||
|     public R<Void> get(String queueName) { |  | ||||||
|         PriorityDemo data; |  | ||||||
|         do { |  | ||||||
|             data = QueueUtils.getPriorityQueueObject(queueName); |  | ||||||
|             log.info("通道: {} , 获取数据: {}", queueName, data); |  | ||||||
|         } while (data != null); |  | ||||||
|         return R.ok("操作成功"); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } |  | ||||||
| @ -1,68 +0,0 @@ | |||||||
| package org.dromara.demo.domain; |  | ||||||
|  |  | ||||||
| import com.baomidou.mybatisplus.annotation.*; |  | ||||||
| import org.dromara.common.tenant.core.TenantEntity; |  | ||||||
| import lombok.Data; |  | ||||||
| import lombok.EqualsAndHashCode; |  | ||||||
|  |  | ||||||
| import java.io.Serial; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * 测试单表对象 test_demo |  | ||||||
|  * |  | ||||||
|  * @author Lion Li |  | ||||||
|  * @date 2021-07-26 |  | ||||||
|  */ |  | ||||||
| @Data |  | ||||||
| @EqualsAndHashCode(callSuper = true) |  | ||||||
| @TableName("test_demo") |  | ||||||
| public class TestDemo extends TenantEntity { |  | ||||||
|  |  | ||||||
|     @Serial |  | ||||||
|     private static final long serialVersionUID = 1L; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 主键 |  | ||||||
|      */ |  | ||||||
|     @TableId(value = "id") |  | ||||||
|     private Long id; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 部门id |  | ||||||
|      */ |  | ||||||
|     private Long deptId; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 用户id |  | ||||||
|      */ |  | ||||||
|     private Long userId; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 排序号 |  | ||||||
|      */ |  | ||||||
|     @OrderBy(asc = false, sort = 1) |  | ||||||
|     private Integer orderNum; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * key键 |  | ||||||
|      */ |  | ||||||
|     private String testKey; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 值 |  | ||||||
|      */ |  | ||||||
|     private String value; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 版本 |  | ||||||
|      */ |  | ||||||
|     @Version |  | ||||||
|     private Long version; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 删除标志 |  | ||||||
|      */ |  | ||||||
|     @TableLogic |  | ||||||
|     private Long delFlag; |  | ||||||
|  |  | ||||||
| } |  | ||||||
| @ -1,29 +0,0 @@ | |||||||
| package org.dromara.demo.domain; |  | ||||||
|  |  | ||||||
| import com.baomidou.mybatisplus.annotation.TableName; |  | ||||||
| import org.dromara.common.encrypt.annotation.EncryptField; |  | ||||||
| import org.dromara.common.encrypt.enumd.AlgorithmType; |  | ||||||
| import lombok.Data; |  | ||||||
| import lombok.EqualsAndHashCode; |  | ||||||
|  |  | ||||||
| @Data |  | ||||||
| @EqualsAndHashCode(callSuper = true) |  | ||||||
| @TableName("test_demo") |  | ||||||
| public class TestDemoEncrypt extends TestDemo { |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * key键 |  | ||||||
|      */ |  | ||||||
|     // @EncryptField(algorithm=AlgorithmType.SM2, privateKey = "MIGTAgEAMBMGByqGSM49AgEGCCqBHM9VAYItBHkwdwIBAQQgZSlOvw8FBiH+aFJWLYZP/VRjg9wjfRarTkGBZd/T3N+gCgYIKoEcz1UBgi2hRANCAAR5DGuQwJqkxnbCsP+iPSDoHWIF4RwcR5EsSvT8QPxO1wRkR2IhCkzvRb32x2CUgJFdvoqVqfApFDPZzShqzBwX", publicKey = "MFkwEwYHKoZIzj0CAQYIKoEcz1UBgi0DQgAEeQxrkMCapMZ2wrD/oj0g6B1iBeEcHEeRLEr0/ED8TtcEZEdiIQpM70W99sdglICRXb6KlanwKRQz2c0oaswcFw==") |  | ||||||
|     @EncryptField(algorithm = AlgorithmType.RSA, privateKey = "MIICdQIBADANBgkqhkiG9w0BAQEFAASCAl8wggJbAgEAAoGBANBBEeueWlXlkkj2+WY5l+IWe42d8b5K28g+G/CFKC/yYAEHtqGlCsBOrb+YBkG9mPzmuYA/n9k0NFIc8E8yY5vZQaroyFBrTTWEzG9RY2f7Y3svVyybs6jpXSUs4xff8abo7wL1Y/wUaeatTViamxYnyTvdTmLm3d+JjRij68rxAgMBAAECgYAB0TnhXraSopwIVRfmboea1b0upl+BUdTJcmci412UjrKr5aE695ZLPkXbFXijVu7HJlyyv94NVUdaMACV7Ku/S2RuNB70M7YJm8rAjHFC3/i2ZeIM60h1Ziy4QKv0XM3pRATlDCDNhC1WUrtQCQSgU8kcp6eUUppruOqDzcY04QJBAPm9+sBP9CwDRgy3e5+V8aZtJkwDstb0lVVV/KY890cydVxiCwvX3fqVnxKMlb+x0YtH0sb9v+71xvK2lGobaRECQQDVePU6r/cCEfpc+nkWF6osAH1f8Mux3rYv2DoBGvaPzV2BGfsLed4neRfCwWNCKvGPCdW+L0xMJg8+RwaoBUPhAkAT5kViqXxFPYWJYd1h2+rDXhMdH3ZSlm6HvDBDdrwlWinr0Iwcx3iSjPV93uHXwm118aUj4fg3LDJMCKxOwBxhAkByrQXfvwOMYygBprRBf/j0plazoWFrbd6lGR0f1uI5IfNnFRPdeFw1DEINZ2Hw+6zEUF44SqRMC+4IYJNc02dBAkBCgy7RvfyV/A7N6kKXxTHauY0v6XwSSvpeKtRJkbIcRWOdIYvaHO9L7cklj3vIEdwjSUp9K4VTBYYlmAz1xh03", publicKey = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQDQQRHrnlpV5ZJI9vlmOZfiFnuNnfG+StvIPhvwhSgv8mABB7ahpQrATq2/mAZBvZj85rmAP5/ZNDRSHPBPMmOb2UGq6MhQa001hMxvUWNn+2N7L1csm7Oo6V0lLOMX3/Gm6O8C9WP8FGnmrU1YmpsWJ8k73U5i5t3fiY0Yo+vK8QIDAQAB") |  | ||||||
|     private String testKey; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 值 |  | ||||||
|      */ |  | ||||||
|     // @EncryptField // 什么也不写走默认yml配置 |  | ||||||
|     // @EncryptField(algorithm = AlgorithmType.SM4, password = "10rfylhtccpuyke5") |  | ||||||
|     @EncryptField(algorithm = AlgorithmType.AES, password = "10rfylhtccpuyke5") |  | ||||||
|     private String value; |  | ||||||
|  |  | ||||||
| } |  | ||||||
| @ -1,65 +0,0 @@ | |||||||
| package org.dromara.demo.domain; |  | ||||||
|  |  | ||||||
| import com.baomidou.mybatisplus.annotation.TableId; |  | ||||||
| import com.baomidou.mybatisplus.annotation.TableLogic; |  | ||||||
| import com.baomidou.mybatisplus.annotation.TableName; |  | ||||||
| import com.baomidou.mybatisplus.annotation.Version; |  | ||||||
| import org.dromara.common.tenant.core.TenantEntity; |  | ||||||
| import lombok.Data; |  | ||||||
| import lombok.EqualsAndHashCode; |  | ||||||
|  |  | ||||||
| import java.io.Serial; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * 测试树表对象 test_tree |  | ||||||
|  * |  | ||||||
|  * @author Lion Li |  | ||||||
|  * @date 2021-07-26 |  | ||||||
|  */ |  | ||||||
| @Data |  | ||||||
| @EqualsAndHashCode(callSuper = true) |  | ||||||
| @TableName("test_tree") |  | ||||||
| public class TestTree extends TenantEntity { |  | ||||||
|  |  | ||||||
|     @Serial |  | ||||||
|     private static final long serialVersionUID = 1L; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 主键 |  | ||||||
|      */ |  | ||||||
|     @TableId(value = "id") |  | ||||||
|     private Long id; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 父ID |  | ||||||
|      */ |  | ||||||
|     private Long parentId; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 部门id |  | ||||||
|      */ |  | ||||||
|     private Long deptId; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 用户id |  | ||||||
|      */ |  | ||||||
|     private Long userId; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 树节点名 |  | ||||||
|      */ |  | ||||||
|     private String treeName; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 版本 |  | ||||||
|      */ |  | ||||||
|     @Version |  | ||||||
|     private Long version; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 删除标志 |  | ||||||
|      */ |  | ||||||
|     @TableLogic |  | ||||||
|     private Long delFlag; |  | ||||||
|  |  | ||||||
| } |  | ||||||
| @ -1,62 +0,0 @@ | |||||||
| package org.dromara.demo.domain.bo; |  | ||||||
|  |  | ||||||
| import org.dromara.common.core.validate.AddGroup; |  | ||||||
| import org.dromara.common.core.validate.EditGroup; |  | ||||||
| import org.dromara.common.mybatis.core.domain.BaseEntity; |  | ||||||
| import org.dromara.demo.domain.TestDemo; |  | ||||||
| import io.github.linpeilie.annotations.AutoMapper; |  | ||||||
| import lombok.Data; |  | ||||||
| import lombok.EqualsAndHashCode; |  | ||||||
|  |  | ||||||
| import jakarta.validation.constraints.NotBlank; |  | ||||||
| import jakarta.validation.constraints.NotNull; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * 测试单表业务对象 test_demo |  | ||||||
|  * |  | ||||||
|  * @author Lion Li |  | ||||||
|  * @date 2021-07-26 |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| @Data |  | ||||||
| @EqualsAndHashCode(callSuper = true) |  | ||||||
| @AutoMapper(target = TestDemo.class, reverseConvertGenerate = false) |  | ||||||
| public class TestDemoBo extends BaseEntity { |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 主键 |  | ||||||
|      */ |  | ||||||
|     @NotNull(message = "主键不能为空", groups = {EditGroup.class}) |  | ||||||
|     private Long id; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 部门id |  | ||||||
|      */ |  | ||||||
|     @NotNull(message = "部门id不能为空", groups = {AddGroup.class, EditGroup.class}) |  | ||||||
|     private Long deptId; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 用户id |  | ||||||
|      */ |  | ||||||
|     @NotNull(message = "用户id不能为空", groups = {AddGroup.class, EditGroup.class}) |  | ||||||
|     private Long userId; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 排序号 |  | ||||||
|      */ |  | ||||||
|     @NotNull(message = "排序号不能为空", groups = {AddGroup.class, EditGroup.class}) |  | ||||||
|     private Integer orderNum; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * key键 |  | ||||||
|      */ |  | ||||||
|     @NotBlank(message = "key键不能为空", groups = {AddGroup.class, EditGroup.class}) |  | ||||||
|     private String testKey; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 值 |  | ||||||
|      */ |  | ||||||
|     @NotBlank(message = "值不能为空", groups = {AddGroup.class, EditGroup.class}) |  | ||||||
|     private String value; |  | ||||||
|  |  | ||||||
| } |  | ||||||
| @ -1,53 +0,0 @@ | |||||||
| package org.dromara.demo.domain.bo; |  | ||||||
|  |  | ||||||
| import com.alibaba.excel.annotation.ExcelProperty; |  | ||||||
| import lombok.Data; |  | ||||||
|  |  | ||||||
| import jakarta.validation.constraints.NotBlank; |  | ||||||
| import jakarta.validation.constraints.NotNull; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * 测试单表业务对象 test_demo |  | ||||||
|  * |  | ||||||
|  * @author Lion Li |  | ||||||
|  * @date 2021-07-26 |  | ||||||
|  */ |  | ||||||
| @Data |  | ||||||
| public class TestDemoImportVo { |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 部门id |  | ||||||
|      */ |  | ||||||
|     @NotNull(message = "部门id不能为空") |  | ||||||
|     @ExcelProperty(value = "部门id") |  | ||||||
|     private Long deptId; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 用户id |  | ||||||
|      */ |  | ||||||
|     @NotNull(message = "用户id不能为空") |  | ||||||
|     @ExcelProperty(value = "用户id") |  | ||||||
|     private Long userId; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 排序号 |  | ||||||
|      */ |  | ||||||
|     @NotNull(message = "排序号不能为空") |  | ||||||
|     @ExcelProperty(value = "排序号") |  | ||||||
|     private Long orderNum; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * key键 |  | ||||||
|      */ |  | ||||||
|     @NotBlank(message = "key键不能为空") |  | ||||||
|     @ExcelProperty(value = "key键") |  | ||||||
|     private String testKey; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 值 |  | ||||||
|      */ |  | ||||||
|     @NotBlank(message = "值不能为空") |  | ||||||
|     @ExcelProperty(value = "值") |  | ||||||
|     private String value; |  | ||||||
|  |  | ||||||
| } |  | ||||||
| @ -1,54 +0,0 @@ | |||||||
| package org.dromara.demo.domain.bo; |  | ||||||
|  |  | ||||||
| import org.dromara.common.core.validate.AddGroup; |  | ||||||
| import org.dromara.common.core.validate.EditGroup; |  | ||||||
| import org.dromara.common.mybatis.core.domain.BaseEntity; |  | ||||||
| import org.dromara.demo.domain.TestTree; |  | ||||||
| import io.github.linpeilie.annotations.AutoMapper; |  | ||||||
| import jakarta.validation.constraints.NotBlank; |  | ||||||
| import jakarta.validation.constraints.NotNull; |  | ||||||
| import lombok.Data; |  | ||||||
| import lombok.EqualsAndHashCode; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * 测试树表业务对象 test_tree |  | ||||||
|  * |  | ||||||
|  * @author Lion Li |  | ||||||
|  * @date 2021-07-26 |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| @Data |  | ||||||
| @EqualsAndHashCode(callSuper = true) |  | ||||||
| @AutoMapper(target = TestTree.class, reverseConvertGenerate = false) |  | ||||||
| public class TestTreeBo extends BaseEntity { |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 主键 |  | ||||||
|      */ |  | ||||||
|     @NotNull(message = "主键不能为空", groups = {EditGroup.class}) |  | ||||||
|     private Long id; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 父ID |  | ||||||
|      */ |  | ||||||
|     private Long parentId; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 部门id |  | ||||||
|      */ |  | ||||||
|     @NotNull(message = "部门id不能为空", groups = {AddGroup.class, EditGroup.class}) |  | ||||||
|     private Long deptId; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 用户id |  | ||||||
|      */ |  | ||||||
|     @NotNull(message = "用户id不能为空", groups = {AddGroup.class, EditGroup.class}) |  | ||||||
|     private Long userId; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 树节点名 |  | ||||||
|      */ |  | ||||||
|     @NotBlank(message = "树节点名不能为空", groups = {AddGroup.class, EditGroup.class}) |  | ||||||
|     private String treeName; |  | ||||||
|  |  | ||||||
| } |  | ||||||
| @ -1 +0,0 @@ | |||||||
| package org.dromara.demo.domain; |  | ||||||
| @ -1,122 +0,0 @@ | |||||||
| package org.dromara.demo.domain.vo; |  | ||||||
|  |  | ||||||
| import com.alibaba.excel.annotation.ExcelIgnoreUnannotated; |  | ||||||
| import com.alibaba.excel.annotation.ExcelProperty; |  | ||||||
| import jakarta.validation.constraints.NotEmpty; |  | ||||||
| import jakarta.validation.constraints.NotNull; |  | ||||||
| import lombok.AllArgsConstructor; |  | ||||||
| import lombok.Data; |  | ||||||
| import lombok.NoArgsConstructor; |  | ||||||
| import org.dromara.common.core.enums.UserStatus; |  | ||||||
| import org.dromara.common.core.validate.AddGroup; |  | ||||||
| import org.dromara.common.core.validate.EditGroup; |  | ||||||
| import org.dromara.common.excel.annotation.ExcelDictFormat; |  | ||||||
| import org.dromara.common.excel.annotation.ExcelEnumFormat; |  | ||||||
| import org.dromara.common.excel.convert.ExcelDictConvert; |  | ||||||
| import org.dromara.common.excel.convert.ExcelEnumConvert; |  | ||||||
|  |  | ||||||
| import java.io.Serial; |  | ||||||
| import java.io.Serializable; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * 带有下拉选的Excel导出 |  | ||||||
|  * |  | ||||||
|  * @author Emil.Zhang |  | ||||||
|  */ |  | ||||||
| @Data |  | ||||||
| @ExcelIgnoreUnannotated |  | ||||||
| @AllArgsConstructor |  | ||||||
| @NoArgsConstructor |  | ||||||
| public class ExportDemoVo implements Serializable { |  | ||||||
|  |  | ||||||
|     @Serial |  | ||||||
|     private static final long serialVersionUID = 1L; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 用户昵称 |  | ||||||
|      */ |  | ||||||
|     @ExcelProperty(value = "用户名", index = 0) |  | ||||||
|     @NotEmpty(message = "用户名不能为空", groups = AddGroup.class) |  | ||||||
|     private String nickName; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 用户类型 |  | ||||||
|      * </p> |  | ||||||
|      * 使用ExcelEnumFormat注解需要进行下拉选的部分 |  | ||||||
|      */ |  | ||||||
|     @ExcelProperty(value = "用户类型", index = 1, converter = ExcelEnumConvert.class) |  | ||||||
|     @ExcelEnumFormat(enumClass = UserStatus.class, textField = "info") |  | ||||||
|     @NotEmpty(message = "用户类型不能为空", groups = AddGroup.class) |  | ||||||
|     private String userStatus; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 性别 |  | ||||||
|      * <p> |  | ||||||
|      * 使用ExcelDictFormat注解需要进行下拉选的部分 |  | ||||||
|      */ |  | ||||||
|     @ExcelProperty(value = "性别", index = 2, converter = ExcelDictConvert.class) |  | ||||||
|     @ExcelDictFormat(dictType = "sys_user_sex") |  | ||||||
|     @NotEmpty(message = "性别不能为空", groups = AddGroup.class) |  | ||||||
|     private String gender; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 手机号 |  | ||||||
|      */ |  | ||||||
|     @ExcelProperty(value = "手机号", index = 3) |  | ||||||
|     @NotEmpty(message = "手机号不能为空", groups = AddGroup.class) |  | ||||||
|     private String phoneNumber; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * Email |  | ||||||
|      */ |  | ||||||
|     @ExcelProperty(value = "Email", index = 4) |  | ||||||
|     @NotEmpty(message = "Email不能为空", groups = AddGroup.class) |  | ||||||
|     private String email; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 省 |  | ||||||
|      * <p> |  | ||||||
|      * 级联下拉,仅判断是否选了 |  | ||||||
|      */ |  | ||||||
|     @ExcelProperty(value = "省", index = 5) |  | ||||||
|     @NotNull(message = "省不能为空", groups = AddGroup.class) |  | ||||||
|     private String province; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 数据库中的省ID |  | ||||||
|      * </p> |  | ||||||
|      * 处理完毕后再判断是否市正确的值 |  | ||||||
|      */ |  | ||||||
|     @NotNull(message = "请勿手动输入", groups = EditGroup.class) |  | ||||||
|     private Integer provinceId; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 市 |  | ||||||
|      * <p> |  | ||||||
|      * 级联下拉 |  | ||||||
|      */ |  | ||||||
|     @ExcelProperty(value = "市", index = 6) |  | ||||||
|     @NotNull(message = "市不能为空", groups = AddGroup.class) |  | ||||||
|     private String city; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 数据库中的市ID |  | ||||||
|      */ |  | ||||||
|     @NotNull(message = "请勿手动输入", groups = EditGroup.class) |  | ||||||
|     private Integer cityId; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 县 |  | ||||||
|      * <p> |  | ||||||
|      * 级联下拉 |  | ||||||
|      */ |  | ||||||
|     @ExcelProperty(value = "县", index = 7) |  | ||||||
|     @NotNull(message = "县不能为空", groups = AddGroup.class) |  | ||||||
|     private String area; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 数据库中的县ID |  | ||||||
|      */ |  | ||||||
|     @NotNull(message = "请勿手动输入", groups = EditGroup.class) |  | ||||||
|     private Integer areaId; |  | ||||||
| } |  | ||||||
| @ -1,111 +0,0 @@ | |||||||
| package org.dromara.demo.domain.vo; |  | ||||||
|  |  | ||||||
| import com.alibaba.excel.annotation.ExcelIgnoreUnannotated; |  | ||||||
| import com.alibaba.excel.annotation.ExcelProperty; |  | ||||||
| import org.dromara.common.excel.annotation.ExcelNotation; |  | ||||||
| import org.dromara.common.excel.annotation.ExcelRequired; |  | ||||||
| import org.dromara.common.translation.annotation.Translation; |  | ||||||
| import org.dromara.common.translation.constant.TransConstant; |  | ||||||
| import org.dromara.demo.domain.TestDemo; |  | ||||||
| import io.github.linpeilie.annotations.AutoMapper; |  | ||||||
| import lombok.Data; |  | ||||||
|  |  | ||||||
| import java.io.Serial; |  | ||||||
| import java.io.Serializable; |  | ||||||
| import java.util.Date; |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * 测试单表视图对象 test_demo |  | ||||||
|  * |  | ||||||
|  * @author Lion Li |  | ||||||
|  * @date 2021-07-26 |  | ||||||
|  */ |  | ||||||
| @Data |  | ||||||
| @ExcelIgnoreUnannotated |  | ||||||
| @AutoMapper(target = TestDemo.class) |  | ||||||
| public class TestDemoVo implements Serializable { |  | ||||||
|  |  | ||||||
|     @Serial |  | ||||||
|     private static final long serialVersionUID = 1L; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 主键 |  | ||||||
|      */ |  | ||||||
|     @ExcelProperty(value = "主键") |  | ||||||
|     private Long id; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 部门id |  | ||||||
|      */ |  | ||||||
|     @ExcelRequired |  | ||||||
|     @ExcelProperty(value = "部门id") |  | ||||||
|     private Long deptId; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 用户id |  | ||||||
|      */ |  | ||||||
|     @ExcelRequired |  | ||||||
|     @ExcelProperty(value = "用户id") |  | ||||||
|     private Long userId; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 排序号 |  | ||||||
|      */ |  | ||||||
|     @ExcelRequired |  | ||||||
|     @ExcelProperty(value = "排序号") |  | ||||||
|     private Integer orderNum; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * key键 |  | ||||||
|      */ |  | ||||||
|     @ExcelNotation(value = "测试key") |  | ||||||
|     @ExcelProperty(value = "key键") |  | ||||||
|     private String testKey; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 值 |  | ||||||
|      */ |  | ||||||
|     @ExcelNotation(value = "测试value") |  | ||||||
|     @ExcelProperty(value = "值") |  | ||||||
|     private String value; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 创建时间 |  | ||||||
|      */ |  | ||||||
|     @ExcelProperty(value = "创建时间") |  | ||||||
|     private Date createTime; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 创建人 |  | ||||||
|      */ |  | ||||||
|     @ExcelProperty(value = "创建人") |  | ||||||
|     private Long createBy; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 创建人账号 |  | ||||||
|      */ |  | ||||||
|     @Translation(type = TransConstant.USER_ID_TO_NAME, mapper = "createBy") |  | ||||||
|     @ExcelProperty(value = "创建人账号") |  | ||||||
|     private String createByName; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 更新时间 |  | ||||||
|      */ |  | ||||||
|     @ExcelProperty(value = "更新时间") |  | ||||||
|     private Date updateTime; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 更新人 |  | ||||||
|      */ |  | ||||||
|     @ExcelProperty(value = "更新人") |  | ||||||
|     private Long updateBy; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 更新人账号 |  | ||||||
|      */ |  | ||||||
|     @Translation(type = TransConstant.USER_ID_TO_NAME, mapper = "updateBy") |  | ||||||
|     @ExcelProperty(value = "更新人账号") |  | ||||||
|     private String updateByName; |  | ||||||
|  |  | ||||||
| } |  | ||||||
| @ -1,64 +0,0 @@ | |||||||
| package org.dromara.demo.domain.vo; |  | ||||||
|  |  | ||||||
| import com.alibaba.excel.annotation.ExcelIgnoreUnannotated; |  | ||||||
| import com.alibaba.excel.annotation.ExcelProperty; |  | ||||||
| import org.dromara.demo.domain.TestTree; |  | ||||||
| import io.github.linpeilie.annotations.AutoMapper; |  | ||||||
| import lombok.Data; |  | ||||||
|  |  | ||||||
| import java.io.Serial; |  | ||||||
| import java.io.Serializable; |  | ||||||
| import java.util.Date; |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * 测试树表视图对象 test_tree |  | ||||||
|  * |  | ||||||
|  * @author Lion Li |  | ||||||
|  * @date 2021-07-26 |  | ||||||
|  */ |  | ||||||
| @Data |  | ||||||
| @ExcelIgnoreUnannotated |  | ||||||
| @AutoMapper(target = TestTree.class) |  | ||||||
| public class TestTreeVo implements Serializable { |  | ||||||
|  |  | ||||||
|     @Serial |  | ||||||
|     private static final long serialVersionUID = 1L; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 主键 |  | ||||||
|      */ |  | ||||||
|     private Long id; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 父id |  | ||||||
|      */ |  | ||||||
|     @ExcelProperty(value = "父id") |  | ||||||
|     private Long parentId; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 部门id |  | ||||||
|      */ |  | ||||||
|     @ExcelProperty(value = "部门id") |  | ||||||
|     private Long deptId; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 用户id |  | ||||||
|      */ |  | ||||||
|     @ExcelProperty(value = "用户id") |  | ||||||
|     private Long userId; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 树节点名 |  | ||||||
|      */ |  | ||||||
|     @ExcelProperty(value = "树节点名") |  | ||||||
|     private String treeName; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 创建时间 |  | ||||||
|      */ |  | ||||||
|     @ExcelProperty(value = "创建时间") |  | ||||||
|     private Date createTime; |  | ||||||
|  |  | ||||||
|  |  | ||||||
| } |  | ||||||
| @ -1,68 +0,0 @@ | |||||||
| package org.dromara.demo.listener; |  | ||||||
|  |  | ||||||
| import cn.hutool.core.util.NumberUtil; |  | ||||||
| import com.alibaba.excel.context.AnalysisContext; |  | ||||||
| import org.dromara.common.core.utils.ValidatorUtils; |  | ||||||
| import org.dromara.common.core.validate.AddGroup; |  | ||||||
| import org.dromara.common.core.validate.EditGroup; |  | ||||||
| import org.dromara.common.excel.core.DefaultExcelListener; |  | ||||||
| import org.dromara.common.excel.core.DropDownOptions; |  | ||||||
| import org.dromara.demo.domain.vo.ExportDemoVo; |  | ||||||
|  |  | ||||||
| import java.util.List; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * Excel带下拉框的解析处理器 |  | ||||||
|  * |  | ||||||
|  * @author Emil.Zhang |  | ||||||
|  */ |  | ||||||
| public class ExportDemoListener extends DefaultExcelListener<ExportDemoVo> { |  | ||||||
|  |  | ||||||
|     public ExportDemoListener() { |  | ||||||
|         // 显示使用构造函数,否则将导致空指针 |  | ||||||
|         super(true); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public void invoke(ExportDemoVo data, AnalysisContext context) { |  | ||||||
|         // 先校验必填 |  | ||||||
|         ValidatorUtils.validate(data, AddGroup.class); |  | ||||||
|  |  | ||||||
|         // 处理级联下拉的部分 |  | ||||||
|         String province = data.getProvince(); |  | ||||||
|         String city = data.getCity(); |  | ||||||
|         String area = data.getArea(); |  | ||||||
|         // 本行用户选择的省 |  | ||||||
|         List<String> thisRowSelectedProvinceOption = DropDownOptions.analyzeOptionValue(province); |  | ||||||
|         if (thisRowSelectedProvinceOption.size() == 2) { |  | ||||||
|             String provinceIdStr = thisRowSelectedProvinceOption.get(1); |  | ||||||
|             if (NumberUtil.isNumber(provinceIdStr)) { |  | ||||||
|                 // 严格要求数据的话可以在这里做与数据库相关的判断 |  | ||||||
|                 // 例如判断省信息是否在数据库中存在等,建议结合RedisCache做缓存10s,减少数据库调用 |  | ||||||
|                 data.setProvinceId(Integer.parseInt(provinceIdStr)); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         // 本行用户选择的市 |  | ||||||
|         List<String> thisRowSelectedCityOption = DropDownOptions.analyzeOptionValue(city); |  | ||||||
|         if (thisRowSelectedCityOption.size() == 2) { |  | ||||||
|             String cityIdStr = thisRowSelectedCityOption.get(1); |  | ||||||
|             if (NumberUtil.isNumber(cityIdStr)) { |  | ||||||
|                 data.setCityId(Integer.parseInt(cityIdStr)); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         // 本行用户选择的县 |  | ||||||
|         List<String> thisRowSelectedAreaOption = DropDownOptions.analyzeOptionValue(area); |  | ||||||
|         if (thisRowSelectedAreaOption.size() == 2) { |  | ||||||
|             String areaIdStr = thisRowSelectedAreaOption.get(1); |  | ||||||
|             if (NumberUtil.isNumber(areaIdStr)) { |  | ||||||
|                 data.setAreaId(Integer.parseInt(areaIdStr)); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         // 处理完毕以后判断是否符合规则 |  | ||||||
|         ValidatorUtils.validate(data, EditGroup.class); |  | ||||||
|  |  | ||||||
|         // 添加到处理结果中 |  | ||||||
|         getExcelResult().getList().add(data); |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @ -1,13 +0,0 @@ | |||||||
| package org.dromara.demo.mapper; |  | ||||||
|  |  | ||||||
| import org.dromara.common.mybatis.core.mapper.BaseMapperPlus; |  | ||||||
| import org.dromara.demo.domain.TestDemoEncrypt; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * 测试加密功能 |  | ||||||
|  * |  | ||||||
|  * @author Lion Li |  | ||||||
|  */ |  | ||||||
| public interface TestDemoEncryptMapper extends BaseMapperPlus<TestDemoEncrypt, TestDemoEncrypt> { |  | ||||||
|  |  | ||||||
| } |  | ||||||
| @ -1,64 +0,0 @@ | |||||||
| package org.dromara.demo.mapper; |  | ||||||
|  |  | ||||||
| import com.baomidou.mybatisplus.core.conditions.Wrapper; |  | ||||||
| import com.baomidou.mybatisplus.core.metadata.IPage; |  | ||||||
| import com.baomidou.mybatisplus.core.toolkit.Constants; |  | ||||||
| import com.baomidou.mybatisplus.extension.plugins.pagination.Page; |  | ||||||
| import org.apache.ibatis.annotations.Param; |  | ||||||
| import org.dromara.common.mybatis.annotation.DataColumn; |  | ||||||
| import org.dromara.common.mybatis.annotation.DataPermission; |  | ||||||
| import org.dromara.common.mybatis.core.mapper.BaseMapperPlus; |  | ||||||
| import org.dromara.demo.domain.TestDemo; |  | ||||||
| import org.dromara.demo.domain.vo.TestDemoVo; |  | ||||||
|  |  | ||||||
| import java.io.Serializable; |  | ||||||
| import java.util.Collection; |  | ||||||
| import java.util.List; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * 测试单表Mapper接口 |  | ||||||
|  * |  | ||||||
|  * @author Lion Li |  | ||||||
|  * @date 2021-07-26 |  | ||||||
|  */ |  | ||||||
| public interface TestDemoMapper extends BaseMapperPlus<TestDemo, TestDemoVo> { |  | ||||||
|  |  | ||||||
|     @DataPermission({ |  | ||||||
|         @DataColumn(key = "deptName", value = "dept_id"), |  | ||||||
|         @DataColumn(key = "userName", value = "user_id") |  | ||||||
|     }) |  | ||||||
|     Page<TestDemoVo> customPageList(@Param("page") Page<TestDemo> page, @Param("ew") Wrapper<TestDemo> wrapper); |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     @DataPermission({ |  | ||||||
|         @DataColumn(key = "deptName", value = "dept_id"), |  | ||||||
|         @DataColumn(key = "userName", value = "user_id") |  | ||||||
|     }) |  | ||||||
|     default <P extends IPage<TestDemoVo>> P selectVoPage(IPage<TestDemo> page, Wrapper<TestDemo> wrapper) { |  | ||||||
|         return selectVoPage(page, wrapper, this.currentVoClass()); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     @DataPermission({ |  | ||||||
|         @DataColumn(key = "deptName", value = "dept_id"), |  | ||||||
|         @DataColumn(key = "userName", value = "user_id") |  | ||||||
|     }) |  | ||||||
|     default List<TestDemoVo> selectVoList(Wrapper<TestDemo> wrapper) { |  | ||||||
|         return selectVoList(wrapper, this.currentVoClass()); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     @DataPermission(value = { |  | ||||||
|         @DataColumn(key = "deptName", value = "dept_id"), |  | ||||||
|         @DataColumn(key = "userName", value = "user_id") |  | ||||||
|     }, joinStr = "AND") |  | ||||||
|     List<TestDemo> selectByIds(@Param(Constants.COLL) Collection<? extends Serializable> idList); |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     @DataPermission({ |  | ||||||
|         @DataColumn(key = "deptName", value = "dept_id"), |  | ||||||
|         @DataColumn(key = "userName", value = "user_id") |  | ||||||
|     }) |  | ||||||
|     int updateById(@Param(Constants.ENTITY) TestDemo entity); |  | ||||||
|  |  | ||||||
| } |  | ||||||
| @ -1,21 +0,0 @@ | |||||||
| package org.dromara.demo.mapper; |  | ||||||
|  |  | ||||||
| import org.dromara.common.mybatis.annotation.DataColumn; |  | ||||||
| import org.dromara.common.mybatis.annotation.DataPermission; |  | ||||||
| import org.dromara.common.mybatis.core.mapper.BaseMapperPlus; |  | ||||||
| import org.dromara.demo.domain.TestTree; |  | ||||||
| import org.dromara.demo.domain.vo.TestTreeVo; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * 测试树表Mapper接口 |  | ||||||
|  * |  | ||||||
|  * @author Lion Li |  | ||||||
|  * @date 2021-07-26 |  | ||||||
|  */ |  | ||||||
| @DataPermission({ |  | ||||||
|     @DataColumn(key = "deptName", value = "dept_id"), |  | ||||||
|     @DataColumn(key = "userName", value = "user_id") |  | ||||||
| }) |  | ||||||
| public interface TestTreeMapper extends BaseMapperPlus<TestTree, TestTreeVo> { |  | ||||||
|  |  | ||||||
| } |  | ||||||
| @ -1 +0,0 @@ | |||||||
| package org.dromara.demo.mapper; |  | ||||||
| @ -1,18 +0,0 @@ | |||||||
| package org.dromara.demo.service; |  | ||||||
|  |  | ||||||
| import jakarta.servlet.http.HttpServletResponse; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * 导出下拉框Excel示例 |  | ||||||
|  * |  | ||||||
|  * @author Emil.Zhang |  | ||||||
|  */ |  | ||||||
| public interface IExportExcelService { |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 导出下拉框 |  | ||||||
|      * |  | ||||||
|      * @param response / |  | ||||||
|      */ |  | ||||||
|     void exportWithOptions(HttpServletResponse response); |  | ||||||
| } |  | ||||||
| @ -1,71 +0,0 @@ | |||||||
| package org.dromara.demo.service; |  | ||||||
|  |  | ||||||
| import org.dromara.common.mybatis.core.page.PageQuery; |  | ||||||
| import org.dromara.common.mybatis.core.page.TableDataInfo; |  | ||||||
| import org.dromara.demo.domain.TestDemo; |  | ||||||
| import org.dromara.demo.domain.bo.TestDemoBo; |  | ||||||
| import org.dromara.demo.domain.vo.TestDemoVo; |  | ||||||
|  |  | ||||||
| import java.util.Collection; |  | ||||||
| import java.util.List; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * 测试单表Service接口 |  | ||||||
|  * |  | ||||||
|  * @author Lion Li |  | ||||||
|  * @date 2021-07-26 |  | ||||||
|  */ |  | ||||||
| public interface ITestDemoService { |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 查询单个 |  | ||||||
|      * |  | ||||||
|      * @return |  | ||||||
|      */ |  | ||||||
|     TestDemoVo queryById(Long id); |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 查询列表 |  | ||||||
|      */ |  | ||||||
|     TableDataInfo<TestDemoVo> queryPageList(TestDemoBo bo, PageQuery pageQuery); |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 自定义分页查询 |  | ||||||
|      */ |  | ||||||
|     TableDataInfo<TestDemoVo> customPageList(TestDemoBo bo, PageQuery pageQuery); |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 查询列表 |  | ||||||
|      */ |  | ||||||
|     List<TestDemoVo> queryList(TestDemoBo bo); |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 根据新增业务对象插入测试单表 |  | ||||||
|      * |  | ||||||
|      * @param bo 测试单表新增业务对象 |  | ||||||
|      * @return |  | ||||||
|      */ |  | ||||||
|     Boolean insertByBo(TestDemoBo bo); |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 根据编辑业务对象修改测试单表 |  | ||||||
|      * |  | ||||||
|      * @param bo 测试单表编辑业务对象 |  | ||||||
|      * @return |  | ||||||
|      */ |  | ||||||
|     Boolean updateByBo(TestDemoBo bo); |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 校验并删除数据 |  | ||||||
|      * |  | ||||||
|      * @param ids     主键集合 |  | ||||||
|      * @param isValid 是否校验,true-删除前校验,false-不校验 |  | ||||||
|      * @return |  | ||||||
|      */ |  | ||||||
|     Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid); |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 批量保存 |  | ||||||
|      */ |  | ||||||
|     Boolean saveBatch(List<TestDemo> list); |  | ||||||
| } |  | ||||||
| @ -1,52 +0,0 @@ | |||||||
| package org.dromara.demo.service; |  | ||||||
|  |  | ||||||
| import org.dromara.demo.domain.bo.TestTreeBo; |  | ||||||
| import org.dromara.demo.domain.vo.TestTreeVo; |  | ||||||
|  |  | ||||||
| import java.util.Collection; |  | ||||||
| import java.util.List; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * 测试树表Service接口 |  | ||||||
|  * |  | ||||||
|  * @author Lion Li |  | ||||||
|  * @date 2021-07-26 |  | ||||||
|  */ |  | ||||||
| public interface ITestTreeService { |  | ||||||
|     /** |  | ||||||
|      * 查询单个 |  | ||||||
|      * |  | ||||||
|      * @return |  | ||||||
|      */ |  | ||||||
|     TestTreeVo queryById(Long id); |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 查询列表 |  | ||||||
|      */ |  | ||||||
|     List<TestTreeVo> queryList(TestTreeBo bo); |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 根据新增业务对象插入测试树表 |  | ||||||
|      * |  | ||||||
|      * @param bo 测试树表新增业务对象 |  | ||||||
|      * @return |  | ||||||
|      */ |  | ||||||
|     Boolean insertByBo(TestTreeBo bo); |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 根据编辑业务对象修改测试树表 |  | ||||||
|      * |  | ||||||
|      * @param bo 测试树表编辑业务对象 |  | ||||||
|      * @return |  | ||||||
|      */ |  | ||||||
|     Boolean updateByBo(TestTreeBo bo); |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 校验并删除数据 |  | ||||||
|      * |  | ||||||
|      * @param ids     主键集合 |  | ||||||
|      * @param isValid 是否校验,true-删除前校验,false-不校验 |  | ||||||
|      * @return |  | ||||||
|      */ |  | ||||||
|     Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid); |  | ||||||
| } |  | ||||||
| @ -1,236 +0,0 @@ | |||||||
| package org.dromara.demo.service.impl; |  | ||||||
|  |  | ||||||
| import cn.hutool.core.util.RandomUtil; |  | ||||||
| import cn.hutool.core.util.StrUtil; |  | ||||||
| import jakarta.servlet.http.HttpServletResponse; |  | ||||||
| import lombok.Data; |  | ||||||
| import lombok.RequiredArgsConstructor; |  | ||||||
| import org.dromara.common.core.constant.SystemConstants; |  | ||||||
| import org.dromara.common.core.utils.StreamUtils; |  | ||||||
| import org.dromara.common.excel.core.DropDownOptions; |  | ||||||
| import org.dromara.common.excel.utils.ExcelUtil; |  | ||||||
| import org.dromara.demo.domain.vo.ExportDemoVo; |  | ||||||
| import org.dromara.demo.service.IExportExcelService; |  | ||||||
| import org.springframework.stereotype.Service; |  | ||||||
|  |  | ||||||
| import java.util.ArrayList; |  | ||||||
| import java.util.List; |  | ||||||
| import java.util.Map; |  | ||||||
| import java.util.stream.Collectors; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * 导出下拉框Excel示例 |  | ||||||
|  * |  | ||||||
|  * @author Emil.Zhang |  | ||||||
|  */ |  | ||||||
| @Service |  | ||||||
| @RequiredArgsConstructor |  | ||||||
| public class ExportExcelServiceImpl implements IExportExcelService { |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public void exportWithOptions(HttpServletResponse response) { |  | ||||||
|         // 创建表格数据,业务中一般通过数据库查询 |  | ||||||
|         List<ExportDemoVo> excelDataList = new ArrayList<>(); |  | ||||||
|         for (int i = 0; i < 3; i++) { |  | ||||||
|             // 模拟数据库中的一条数据 |  | ||||||
|             ExportDemoVo everyRowData = new ExportDemoVo(); |  | ||||||
|             everyRowData.setNickName("用户-" + i); |  | ||||||
|             everyRowData.setUserStatus(SystemConstants.NORMAL); |  | ||||||
|             everyRowData.setGender("1"); |  | ||||||
|             everyRowData.setPhoneNumber(String.format("175%08d", i)); |  | ||||||
|             everyRowData.setEmail(String.format("175%08d", i) + "@163.com"); |  | ||||||
|             everyRowData.setProvinceId(i); |  | ||||||
|             everyRowData.setCityId(i); |  | ||||||
|             everyRowData.setAreaId(i); |  | ||||||
|             excelDataList.add(everyRowData); |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         // 通过@ExcelIgnoreUnannotated配合@ExcelProperty合理显示需要的列 |  | ||||||
|         // 并通过@DropDown注解指定下拉值,或者通过创建ExcelOptions来指定下拉框 |  | ||||||
|         // 使用ExcelOptions时建议指定列index,防止出现下拉列解析不对齐 |  | ||||||
|  |  | ||||||
|         // 首先从数据库中查询下拉框内的可选项 |  | ||||||
|         // 这里模拟查询结果 |  | ||||||
|         List<DemoCityData> provinceList = getProvinceList(), |  | ||||||
|             cityList = getCityList(provinceList), |  | ||||||
|             areaList = getAreaList(cityList); |  | ||||||
|         int provinceIndex = 5, cityIndex = 6, areaIndex = 7; |  | ||||||
|  |  | ||||||
|         DropDownOptions provinceToCity = DropDownOptions.buildLinkedOptions( |  | ||||||
|             provinceList, |  | ||||||
|             provinceIndex, |  | ||||||
|             cityList, |  | ||||||
|             cityIndex, |  | ||||||
|             DemoCityData::getId, |  | ||||||
|             DemoCityData::getPid, |  | ||||||
|             everyOptions -> DropDownOptions.createOptionValue( |  | ||||||
|                 everyOptions.getName(), |  | ||||||
|                 everyOptions.getId() |  | ||||||
|             ) |  | ||||||
|         ); |  | ||||||
|  |  | ||||||
|         DropDownOptions cityToArea = DropDownOptions.buildLinkedOptions( |  | ||||||
|             cityList, |  | ||||||
|             cityIndex, |  | ||||||
|             areaList, |  | ||||||
|             areaIndex, |  | ||||||
|             DemoCityData::getId, |  | ||||||
|             DemoCityData::getPid, |  | ||||||
|             everyOptions -> DropDownOptions.createOptionValue( |  | ||||||
|                 everyOptions.getName(), |  | ||||||
|                 everyOptions.getId() |  | ||||||
|             ) |  | ||||||
|         ); |  | ||||||
|  |  | ||||||
|         // 把所有的下拉框存储 |  | ||||||
|         List<DropDownOptions> options = new ArrayList<>(); |  | ||||||
|         options.add(provinceToCity); |  | ||||||
|         options.add(cityToArea); |  | ||||||
|  |  | ||||||
|         // 到此为止所有的下拉框可选项已全部配置完毕 |  | ||||||
|  |  | ||||||
|         // 接下来需要将Excel中的展示数据转换为对应的下拉选 |  | ||||||
|         List<ExportDemoVo> outList = StreamUtils.toList(excelDataList, everyRowData -> { |  | ||||||
|             // 只需要处理没有使用@ExcelDictFormat注解的下拉框 |  | ||||||
|             // 一般来说,可以直接在数据库查询即查询出省市县信息,这里通过模拟操作赋值 |  | ||||||
|             everyRowData.setProvince(buildOptions(provinceList, everyRowData.getProvinceId())); |  | ||||||
|             everyRowData.setCity(buildOptions(cityList, everyRowData.getCityId())); |  | ||||||
|             everyRowData.setArea(buildOptions(areaList, everyRowData.getAreaId())); |  | ||||||
|             return everyRowData; |  | ||||||
|         }); |  | ||||||
|  |  | ||||||
|         ExcelUtil.exportExcel(outList, "下拉框示例", ExportDemoVo.class, response, options); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private String buildOptions(List<DemoCityData> cityDataList, Integer id) { |  | ||||||
|         Map<Integer, List<DemoCityData>> groupByIdMap = |  | ||||||
|             cityDataList.stream().collect(Collectors.groupingBy(DemoCityData::getId)); |  | ||||||
|         if (groupByIdMap.containsKey(id)) { |  | ||||||
|             DemoCityData demoCityData = groupByIdMap.get(id).get(0); |  | ||||||
|             return DropDownOptions.createOptionValue(demoCityData.getName(), demoCityData.getId()); |  | ||||||
|         } else { |  | ||||||
|             return StrUtil.EMPTY; |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 模拟查询数据库操作 |  | ||||||
|      * |  | ||||||
|      * @return / |  | ||||||
|      */ |  | ||||||
|     private List<DemoCityData> getProvinceList() { |  | ||||||
|         List<DemoCityData> provinceList = new ArrayList<>(); |  | ||||||
|  |  | ||||||
|         // 实际业务中一般采用数据库读取的形式,这里直接拼接创建 |  | ||||||
|         provinceList.add(new DemoCityData(0, null, "P100000")); |  | ||||||
|         provinceList.add(new DemoCityData(1, null, "P200000")); |  | ||||||
|         provinceList.add(new DemoCityData(2, null, "P300000")); |  | ||||||
|  |  | ||||||
|         return provinceList; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 模拟查找数据库操作,需要连带查询出省的数据 |  | ||||||
|      * |  | ||||||
|      * @param provinceList 模拟的父省数据 |  | ||||||
|      * @return / |  | ||||||
|      */ |  | ||||||
|     private List<DemoCityData> getCityList(List<DemoCityData> provinceList) { |  | ||||||
|         List<DemoCityData> cityList = new ArrayList<>(); |  | ||||||
|  |  | ||||||
|         // 实际业务中一般采用数据库读取的形式,这里直接拼接创建 |  | ||||||
|         cityList.add(new DemoCityData(0, 0, "C110000")); |  | ||||||
|         cityList.add(new DemoCityData(1, 0, "C120000")); |  | ||||||
|         cityList.add(new DemoCityData(2, 1, "C210000")); |  | ||||||
|         cityList.add(new DemoCityData(3, 1, "C220000")); |  | ||||||
|         cityList.add(new DemoCityData(4, 1, "C230000")); |  | ||||||
|  |  | ||||||
|         selectParentData(provinceList, cityList); |  | ||||||
|  |  | ||||||
|         return cityList; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 模拟查找数据库操作,需要连带查询出市的数据 |  | ||||||
|      * |  | ||||||
|      * @param cityList 模拟的父市数据 |  | ||||||
|      * @return / |  | ||||||
|      */ |  | ||||||
|     private List<DemoCityData> getAreaList(List<DemoCityData> cityList) { |  | ||||||
|         List<DemoCityData> areaList = new ArrayList<>(); |  | ||||||
|  |  | ||||||
|         int minCount = 500; |  | ||||||
|         int maxCount = 10000; |  | ||||||
|  |  | ||||||
|         // 实际业务中一般采用数据库读取的形式,这里直接拼接创建 |  | ||||||
|         for (int i = 0; i < RandomUtil.randomInt(minCount, maxCount); i++) { |  | ||||||
|             areaList.add(new DemoCityData(areaList.size(), 0, String.format("A11%04d", i))); |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         for (int i = 0; i < RandomUtil.randomInt(minCount, maxCount); i++) { |  | ||||||
|             areaList.add(new DemoCityData(areaList.size(), 1, String.format("A12%04d", i))); |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         for (int i = 0; i < RandomUtil.randomInt(minCount, maxCount); i++) { |  | ||||||
|             areaList.add(new DemoCityData(areaList.size(), 2, String.format("A21%04d", i))); |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         for (int i = 0; i < RandomUtil.randomInt(minCount, maxCount); i++) { |  | ||||||
|             areaList.add(new DemoCityData(areaList.size(), 3, String.format("A22%04d", i))); |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         for (int i = 0; i < RandomUtil.randomInt(minCount, maxCount); i++) { |  | ||||||
|             areaList.add(new DemoCityData(areaList.size(), 4, String.format("A23%04d", i))); |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         selectParentData(cityList, areaList); |  | ||||||
|  |  | ||||||
|         return areaList; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 模拟数据库的查询父数据操作 |  | ||||||
|      * |  | ||||||
|      * @param parentList / |  | ||||||
|      * @param sonList    / |  | ||||||
|      */ |  | ||||||
|     private void selectParentData(List<DemoCityData> parentList, List<DemoCityData> sonList) { |  | ||||||
|         Map<Integer, List<DemoCityData>> parentGroupByIdMap = |  | ||||||
|             parentList.stream().collect(Collectors.groupingBy(DemoCityData::getId)); |  | ||||||
|  |  | ||||||
|         sonList.forEach(everySon -> { |  | ||||||
|             if (parentGroupByIdMap.containsKey(everySon.getPid())) { |  | ||||||
|                 everySon.setPData(parentGroupByIdMap.get(everySon.getPid()).get(0)); |  | ||||||
|             } |  | ||||||
|         }); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 模拟的数据库省市县 |  | ||||||
|      */ |  | ||||||
|     @Data |  | ||||||
|     private static class DemoCityData { |  | ||||||
|         /** |  | ||||||
|          * 数据库id字段 |  | ||||||
|          */ |  | ||||||
|         private Integer id; |  | ||||||
|         /** |  | ||||||
|          * 数据库pid字段 |  | ||||||
|          */ |  | ||||||
|         private Integer pid; |  | ||||||
|         /** |  | ||||||
|          * 数据库name字段 |  | ||||||
|          */ |  | ||||||
|         private String name; |  | ||||||
|         /** |  | ||||||
|          * MyBatisPlus连带查询父数据 |  | ||||||
|          */ |  | ||||||
|         private DemoCityData pData; |  | ||||||
|  |  | ||||||
|         public DemoCityData(Integer id, Integer pid, String name) { |  | ||||||
|             this.id = id; |  | ||||||
|             this.pid = pid; |  | ||||||
|             this.name = name; |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @ -1,116 +0,0 @@ | |||||||
| package org.dromara.demo.service.impl; |  | ||||||
|  |  | ||||||
| import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; |  | ||||||
| import com.baomidou.mybatisplus.core.toolkit.Wrappers; |  | ||||||
| import com.baomidou.mybatisplus.extension.plugins.pagination.Page; |  | ||||||
| import lombok.RequiredArgsConstructor; |  | ||||||
| import org.dromara.common.core.exception.ServiceException; |  | ||||||
| import org.dromara.common.core.utils.MapstructUtils; |  | ||||||
| import org.dromara.common.core.utils.StringUtils; |  | ||||||
| import org.dromara.common.mybatis.core.page.PageQuery; |  | ||||||
| import org.dromara.common.mybatis.core.page.TableDataInfo; |  | ||||||
| import org.dromara.demo.domain.TestDemo; |  | ||||||
| import org.dromara.demo.domain.bo.TestDemoBo; |  | ||||||
| import org.dromara.demo.domain.vo.TestDemoVo; |  | ||||||
| import org.dromara.demo.mapper.TestDemoMapper; |  | ||||||
| import org.dromara.demo.service.ITestDemoService; |  | ||||||
| import org.springframework.stereotype.Service; |  | ||||||
|  |  | ||||||
| import java.util.Collection; |  | ||||||
| import java.util.List; |  | ||||||
| import java.util.Map; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * 测试单表Service业务层处理 |  | ||||||
|  * |  | ||||||
|  * @author Lion Li |  | ||||||
|  * @date 2021-07-26 |  | ||||||
|  */ |  | ||||||
| @RequiredArgsConstructor |  | ||||||
| @Service |  | ||||||
| public class TestDemoServiceImpl implements ITestDemoService { |  | ||||||
|  |  | ||||||
|     private final TestDemoMapper baseMapper; |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public TestDemoVo queryById(Long id) { |  | ||||||
|         return baseMapper.selectVoById(id); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public TableDataInfo<TestDemoVo> queryPageList(TestDemoBo bo, PageQuery pageQuery) { |  | ||||||
|         LambdaQueryWrapper<TestDemo> lqw = buildQueryWrapper(bo); |  | ||||||
|         Page<TestDemoVo> result = baseMapper.selectVoPage(pageQuery.build(), lqw); |  | ||||||
|         return TableDataInfo.build(result); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 自定义分页查询 |  | ||||||
|      */ |  | ||||||
|     @Override |  | ||||||
|     public TableDataInfo<TestDemoVo> customPageList(TestDemoBo bo, PageQuery pageQuery) { |  | ||||||
|         LambdaQueryWrapper<TestDemo> lqw = buildQueryWrapper(bo); |  | ||||||
|         Page<TestDemoVo> result = baseMapper.customPageList(pageQuery.build(), lqw); |  | ||||||
|         return TableDataInfo.build(result); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public List<TestDemoVo> queryList(TestDemoBo bo) { |  | ||||||
|         return baseMapper.selectVoList(buildQueryWrapper(bo)); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private LambdaQueryWrapper<TestDemo> buildQueryWrapper(TestDemoBo bo) { |  | ||||||
|         Map<String, Object> params = bo.getParams(); |  | ||||||
|         LambdaQueryWrapper<TestDemo> lqw = Wrappers.lambdaQuery(); |  | ||||||
|         lqw.like(StringUtils.isNotBlank(bo.getTestKey()), TestDemo::getTestKey, bo.getTestKey()); |  | ||||||
|         lqw.eq(StringUtils.isNotBlank(bo.getValue()), TestDemo::getValue, bo.getValue()); |  | ||||||
|         lqw.between(params.get("beginCreateTime") != null && params.get("endCreateTime") != null, |  | ||||||
|             TestDemo::getCreateTime, params.get("beginCreateTime"), params.get("endCreateTime")); |  | ||||||
|         lqw.orderByAsc(TestDemo::getId); |  | ||||||
|         return lqw; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public Boolean insertByBo(TestDemoBo bo) { |  | ||||||
|         TestDemo add = MapstructUtils.convert(bo, TestDemo.class); |  | ||||||
|         validEntityBeforeSave(add); |  | ||||||
|         boolean flag = baseMapper.insert(add) > 0; |  | ||||||
|         if (flag) { |  | ||||||
|             bo.setId(add.getId()); |  | ||||||
|         } |  | ||||||
|         return flag; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public Boolean updateByBo(TestDemoBo bo) { |  | ||||||
|         TestDemo update = MapstructUtils.convert(bo, TestDemo.class); |  | ||||||
|         validEntityBeforeSave(update); |  | ||||||
|         return baseMapper.updateById(update) > 0; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 保存前的数据校验 |  | ||||||
|      * |  | ||||||
|      * @param entity 实体类数据 |  | ||||||
|      */ |  | ||||||
|     private void validEntityBeforeSave(TestDemo entity) { |  | ||||||
|         //TODO 做一些数据校验,如唯一约束 |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid) { |  | ||||||
|         if (isValid) { |  | ||||||
|             // 做一些业务上的校验,判断是否需要校验 |  | ||||||
|             List<TestDemo> list = baseMapper.selectByIds(ids); |  | ||||||
|             if (list.size() != ids.size()) { |  | ||||||
|                 throw new ServiceException("您没有删除权限!"); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         return baseMapper.deleteByIds(ids) > 0; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public Boolean saveBatch(List<TestDemo> list) { |  | ||||||
|         return baseMapper.insertBatch(list); |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @ -1,88 +0,0 @@ | |||||||
| package org.dromara.demo.service.impl; |  | ||||||
|  |  | ||||||
| import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; |  | ||||||
| import com.baomidou.mybatisplus.core.toolkit.Wrappers; |  | ||||||
| import org.dromara.common.core.utils.MapstructUtils; |  | ||||||
| import org.dromara.common.core.utils.StringUtils; |  | ||||||
| import org.dromara.demo.domain.TestTree; |  | ||||||
| import org.dromara.demo.domain.bo.TestTreeBo; |  | ||||||
| import org.dromara.demo.domain.vo.TestTreeVo; |  | ||||||
| import org.dromara.demo.mapper.TestTreeMapper; |  | ||||||
| import org.dromara.demo.service.ITestTreeService; |  | ||||||
| import lombok.RequiredArgsConstructor; |  | ||||||
| import org.springframework.stereotype.Service; |  | ||||||
|  |  | ||||||
| import java.util.Collection; |  | ||||||
| import java.util.List; |  | ||||||
| import java.util.Map; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * 测试树表Service业务层处理 |  | ||||||
|  * |  | ||||||
|  * @author Lion Li |  | ||||||
|  * @date 2021-07-26 |  | ||||||
|  */ |  | ||||||
| // @DS("slave") // 切换从库查询 |  | ||||||
| @RequiredArgsConstructor |  | ||||||
| @Service |  | ||||||
| public class TestTreeServiceImpl implements ITestTreeService { |  | ||||||
|  |  | ||||||
|     private final TestTreeMapper baseMapper; |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public TestTreeVo queryById(Long id) { |  | ||||||
|         return baseMapper.selectVoById(id); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     // @DS("slave") // 切换从库查询 |  | ||||||
|     @Override |  | ||||||
|     public List<TestTreeVo> queryList(TestTreeBo bo) { |  | ||||||
|         LambdaQueryWrapper<TestTree> lqw = buildQueryWrapper(bo); |  | ||||||
|         return baseMapper.selectVoList(lqw); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private LambdaQueryWrapper<TestTree> buildQueryWrapper(TestTreeBo bo) { |  | ||||||
|         Map<String, Object> params = bo.getParams(); |  | ||||||
|         LambdaQueryWrapper<TestTree> lqw = Wrappers.lambdaQuery(); |  | ||||||
|         lqw.like(StringUtils.isNotBlank(bo.getTreeName()), TestTree::getTreeName, bo.getTreeName()); |  | ||||||
|         lqw.between(params.get("beginCreateTime") != null && params.get("endCreateTime") != null, |  | ||||||
|             TestTree::getCreateTime, params.get("beginCreateTime"), params.get("endCreateTime")); |  | ||||||
|         lqw.orderByAsc(TestTree::getId); |  | ||||||
|         return lqw; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public Boolean insertByBo(TestTreeBo bo) { |  | ||||||
|         TestTree add = MapstructUtils.convert(bo, TestTree.class); |  | ||||||
|         validEntityBeforeSave(add); |  | ||||||
|         boolean flag = baseMapper.insert(add) > 0; |  | ||||||
|         if (flag) { |  | ||||||
|             bo.setId(add.getId()); |  | ||||||
|         } |  | ||||||
|         return flag; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public Boolean updateByBo(TestTreeBo bo) { |  | ||||||
|         TestTree update = MapstructUtils.convert(bo, TestTree.class); |  | ||||||
|         validEntityBeforeSave(update); |  | ||||||
|         return baseMapper.updateById(update) > 0; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 保存前的数据校验 |  | ||||||
|      * |  | ||||||
|      * @param entity 实体类数据 |  | ||||||
|      */ |  | ||||||
|     private void validEntityBeforeSave(TestTree entity) { |  | ||||||
|         //TODO 做一些数据校验,如唯一约束 |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid) { |  | ||||||
|         if (isValid) { |  | ||||||
|             //TODO 做一些业务上的校验,判断是否需要校验 |  | ||||||
|         } |  | ||||||
|         return baseMapper.deleteByIds(ids) > 0; |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @ -1 +0,0 @@ | |||||||
| package org.dromara.demo.service.impl; |  | ||||||
| @ -1 +0,0 @@ | |||||||
| package org.dromara.demo.service; |  | ||||||
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							| @ -1,11 +0,0 @@ | |||||||
| <?xml version="1.0" encoding="UTF-8" ?> |  | ||||||
| <!DOCTYPE mapper |  | ||||||
| PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" |  | ||||||
| "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> |  | ||||||
| <mapper namespace="org.dromara.demo.mapper.TestDemoMapper"> |  | ||||||
|  |  | ||||||
|     <select id="customPageList" resultType="org.dromara.demo.domain.vo.TestDemoVo"> |  | ||||||
|         SELECT * FROM test_demo ${ew.customSqlSegment} |  | ||||||
|     </select> |  | ||||||
|  |  | ||||||
| </mapper> |  | ||||||
| @ -1,3 +0,0 @@ | |||||||
| java包使用 `.` 分割 resource 目录使用 `/` 分割 |  | ||||||
| <br> |  | ||||||
| 此文件目的 防止文件夹粘连找不到 `xml` 文件 |  | ||||||
| @ -0,0 +1,112 @@ | |||||||
|  | package org.dromara.materials.controller; | ||||||
|  |  | ||||||
|  | import cn.dev33.satoken.annotation.SaCheckPermission; | ||||||
|  | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||||
|  | import jakarta.servlet.http.HttpServletResponse; | ||||||
|  | import jakarta.validation.constraints.NotEmpty; | ||||||
|  | import jakarta.validation.constraints.NotNull; | ||||||
|  | import lombok.RequiredArgsConstructor; | ||||||
|  | import org.dromara.common.core.constant.HttpStatus; | ||||||
|  | import org.dromara.common.core.domain.R; | ||||||
|  | import org.dromara.common.core.exception.ServiceException; | ||||||
|  | import org.dromara.common.core.validate.AddGroup; | ||||||
|  | import org.dromara.common.core.validate.EditGroup; | ||||||
|  | import org.dromara.common.excel.utils.ExcelUtil; | ||||||
|  | import org.dromara.common.idempotent.annotation.RepeatSubmit; | ||||||
|  | import org.dromara.common.log.annotation.Log; | ||||||
|  | import org.dromara.common.log.enums.BusinessType; | ||||||
|  | import org.dromara.common.web.core.BaseController; | ||||||
|  | import org.dromara.materials.domain.req.company.CompanyCreateReq; | ||||||
|  | import org.dromara.materials.domain.req.company.CompanyQueryReq; | ||||||
|  | import org.dromara.materials.domain.req.company.CompanyUpdateReq; | ||||||
|  | import org.dromara.materials.domain.vo.BusCompanyVo; | ||||||
|  | import org.dromara.materials.service.IBusCompanyService; | ||||||
|  | import org.springframework.validation.annotation.Validated; | ||||||
|  | import org.springframework.web.bind.annotation.*; | ||||||
|  |  | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 公司 | ||||||
|  |  * | ||||||
|  |  * @author lcj | ||||||
|  |  * @date 2025-03-06 | ||||||
|  |  */ | ||||||
|  | @Validated | ||||||
|  | @RequiredArgsConstructor | ||||||
|  | @RestController | ||||||
|  | @RequestMapping("/materials/company") | ||||||
|  | public class BusCompanyController extends BaseController { | ||||||
|  |  | ||||||
|  |     private final IBusCompanyService busCompanyService; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 查询公司列表 | ||||||
|  |      */ | ||||||
|  |     @SaCheckPermission("materials:company:list") | ||||||
|  |     @GetMapping("/list") | ||||||
|  |     public Page<BusCompanyVo> list(CompanyQueryReq req) { | ||||||
|  |         return busCompanyService.queryPageList(req); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 导出公司列表 | ||||||
|  |      */ | ||||||
|  |     @SaCheckPermission("materials:company:export") | ||||||
|  |     @Log(title = "公司", businessType = BusinessType.EXPORT) | ||||||
|  |     @PostMapping("/export") | ||||||
|  |     public void export(CompanyQueryReq req, HttpServletResponse response) { | ||||||
|  |         List<BusCompanyVo> list = busCompanyService.queryList(req); | ||||||
|  |         ExcelUtil.exportExcel(list, "公司", BusCompanyVo.class, response); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 获取公司详细信息 | ||||||
|  |      * | ||||||
|  |      * @param id 主键 | ||||||
|  |      */ | ||||||
|  |     @SaCheckPermission("materials:company:query") | ||||||
|  |     @GetMapping("/{id}") | ||||||
|  |     public R<BusCompanyVo> getInfo(@NotNull(message = "主键不能为空") | ||||||
|  |                                    @PathVariable Long id) { | ||||||
|  |         return R.ok(busCompanyService.queryById(id)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 新增公司 | ||||||
|  |      */ | ||||||
|  |     @SaCheckPermission("materials:company:add") | ||||||
|  |     @Log(title = "公司", businessType = BusinessType.INSERT) | ||||||
|  |     @RepeatSubmit() | ||||||
|  |     @PostMapping() | ||||||
|  |     public R<Long> add(@Validated(AddGroup.class) @RequestBody CompanyCreateReq req) { | ||||||
|  |         if (req == null) { | ||||||
|  |             throw new ServiceException("参数不能为空", HttpStatus.BAD_REQUEST); | ||||||
|  |         } | ||||||
|  |         return R.ok(busCompanyService.insertByBo(req)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 修改公司 | ||||||
|  |      */ | ||||||
|  |     @SaCheckPermission("materials:company:edit") | ||||||
|  |     @Log(title = "公司", businessType = BusinessType.UPDATE) | ||||||
|  |     @RepeatSubmit() | ||||||
|  |     @PutMapping() | ||||||
|  |     public R<Void> edit(@Validated(EditGroup.class) @RequestBody CompanyUpdateReq req) { | ||||||
|  |         return toAjax(busCompanyService.updateByBo(req)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 删除公司 | ||||||
|  |      * | ||||||
|  |      * @param ids 主键串 | ||||||
|  |      */ | ||||||
|  |     @SaCheckPermission("materials:company:remove") | ||||||
|  |     @Log(title = "公司", businessType = BusinessType.DELETE) | ||||||
|  |     @DeleteMapping("/{ids}") | ||||||
|  |     public R<Void> remove(@NotEmpty(message = "主键不能为空") | ||||||
|  |                           @PathVariable Long[] ids) { | ||||||
|  |         return toAjax(busCompanyService.deleteWithValidByIds(List.of(ids), true)); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -0,0 +1,107 @@ | |||||||
|  | package org.dromara.materials.controller; | ||||||
|  |  | ||||||
|  | import cn.dev33.satoken.annotation.SaCheckPermission; | ||||||
|  | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||||
|  | import jakarta.servlet.http.HttpServletResponse; | ||||||
|  | import jakarta.validation.constraints.NotEmpty; | ||||||
|  | import jakarta.validation.constraints.NotNull; | ||||||
|  | import lombok.RequiredArgsConstructor; | ||||||
|  | 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.excel.utils.ExcelUtil; | ||||||
|  | import org.dromara.common.idempotent.annotation.RepeatSubmit; | ||||||
|  | import org.dromara.common.log.annotation.Log; | ||||||
|  | import org.dromara.common.log.enums.BusinessType; | ||||||
|  | import org.dromara.common.web.core.BaseController; | ||||||
|  | import org.dromara.materials.domain.req.materials.MaterialsCreateReq; | ||||||
|  | import org.dromara.materials.domain.req.materials.MaterialsQueryReq; | ||||||
|  | import org.dromara.materials.domain.req.materials.MaterialsUpdateReq; | ||||||
|  | import org.dromara.materials.domain.vo.BusMaterialsVo; | ||||||
|  | import org.dromara.materials.service.IBusMaterialsService; | ||||||
|  | import org.springframework.validation.annotation.Validated; | ||||||
|  | import org.springframework.web.bind.annotation.*; | ||||||
|  |  | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 材料 | ||||||
|  |  * | ||||||
|  |  * @author lcj | ||||||
|  |  * @date 2025-03-06 | ||||||
|  |  */ | ||||||
|  | @Validated | ||||||
|  | @RequiredArgsConstructor | ||||||
|  | @RestController | ||||||
|  | @RequestMapping("/materials/materials") | ||||||
|  | public class BusMaterialsController extends BaseController { | ||||||
|  |  | ||||||
|  |     private final IBusMaterialsService busMaterialsService; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 查询材料列表 | ||||||
|  |      */ | ||||||
|  |     @SaCheckPermission("materials:materials:list") | ||||||
|  |     @GetMapping("/list") | ||||||
|  |     public Page<BusMaterialsVo> list(MaterialsQueryReq req) { | ||||||
|  |         return busMaterialsService.queryPageList(req); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 导出材料列表 | ||||||
|  |      */ | ||||||
|  |     @SaCheckPermission("materials:materials:export") | ||||||
|  |     @Log(title = "材料", businessType = BusinessType.EXPORT) | ||||||
|  |     @PostMapping("/export") | ||||||
|  |     public void export(MaterialsQueryReq req, HttpServletResponse response) { | ||||||
|  |         List<BusMaterialsVo> list = busMaterialsService.queryList(req); | ||||||
|  |         ExcelUtil.exportExcel(list, "材料名称", BusMaterialsVo.class, response); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 获取材料详细信息 | ||||||
|  |      * | ||||||
|  |      * @param id 主键 | ||||||
|  |      */ | ||||||
|  |     @SaCheckPermission("materials:materials:query") | ||||||
|  |     @GetMapping("/{id}") | ||||||
|  |     public R<BusMaterialsVo> getInfo(@NotNull(message = "主键不能为空") | ||||||
|  |                                      @PathVariable Long id) { | ||||||
|  |         return R.ok(busMaterialsService.queryById(id)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 新增材料 | ||||||
|  |      */ | ||||||
|  |     @SaCheckPermission("materials:materials:add") | ||||||
|  |     @Log(title = "材料", businessType = BusinessType.INSERT) | ||||||
|  |     @RepeatSubmit() | ||||||
|  |     @PostMapping() | ||||||
|  |     public R<Long> add(@Validated(AddGroup.class) @RequestBody MaterialsCreateReq req) { | ||||||
|  |         return R.ok(busMaterialsService.insertByBo(req)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 修改材料 | ||||||
|  |      */ | ||||||
|  |     @SaCheckPermission("materials:materials:edit") | ||||||
|  |     @Log(title = "材料", businessType = BusinessType.UPDATE) | ||||||
|  |     @RepeatSubmit() | ||||||
|  |     @PutMapping() | ||||||
|  |     public R<Void> edit(@Validated(EditGroup.class) @RequestBody MaterialsUpdateReq req) { | ||||||
|  |         return toAjax(busMaterialsService.updateByBo(req)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 删除材料 | ||||||
|  |      * | ||||||
|  |      * @param ids 主键串 | ||||||
|  |      */ | ||||||
|  |     @SaCheckPermission("materials:materials:remove") | ||||||
|  |     @Log(title = "材料", businessType = BusinessType.DELETE) | ||||||
|  |     @DeleteMapping("/{ids}") | ||||||
|  |     public R<Void> remove(@NotEmpty(message = "主键不能为空") | ||||||
|  |                           @PathVariable Long[] ids) { | ||||||
|  |         return toAjax(busMaterialsService.deleteWithValidByIds(List.of(ids), true)); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -0,0 +1,107 @@ | |||||||
|  | package org.dromara.materials.controller; | ||||||
|  |  | ||||||
|  | import cn.dev33.satoken.annotation.SaCheckPermission; | ||||||
|  | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||||
|  | import jakarta.servlet.http.HttpServletResponse; | ||||||
|  | import jakarta.validation.constraints.NotEmpty; | ||||||
|  | import jakarta.validation.constraints.NotNull; | ||||||
|  | import lombok.RequiredArgsConstructor; | ||||||
|  | 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.excel.utils.ExcelUtil; | ||||||
|  | import org.dromara.common.idempotent.annotation.RepeatSubmit; | ||||||
|  | import org.dromara.common.log.annotation.Log; | ||||||
|  | import org.dromara.common.log.enums.BusinessType; | ||||||
|  | import org.dromara.common.web.core.BaseController; | ||||||
|  | import org.dromara.materials.domain.req.materialsinventory.MaterialsInventoryCreateReq; | ||||||
|  | import org.dromara.materials.domain.req.materialsinventory.MaterialsInventoryQueryReq; | ||||||
|  | import org.dromara.materials.domain.req.materialsinventory.MaterialsInventoryUpdateReq; | ||||||
|  | import org.dromara.materials.domain.vo.BusMaterialsInventoryVo; | ||||||
|  | import org.dromara.materials.service.IBusMaterialsInventoryService; | ||||||
|  | import org.springframework.validation.annotation.Validated; | ||||||
|  | import org.springframework.web.bind.annotation.*; | ||||||
|  |  | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 材料出/入库 | ||||||
|  |  * | ||||||
|  |  * @author lcj | ||||||
|  |  * @date 2025-03-06 | ||||||
|  |  */ | ||||||
|  | @Validated | ||||||
|  | @RequiredArgsConstructor | ||||||
|  | @RestController | ||||||
|  | @RequestMapping("/materials/materialsInventory") | ||||||
|  | public class BusMaterialsInventoryController extends BaseController { | ||||||
|  |  | ||||||
|  |     private final IBusMaterialsInventoryService busMaterialsInventoryService; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 查询材料出/入库列表 | ||||||
|  |      */ | ||||||
|  |     @SaCheckPermission("materials:materialsInventory:list") | ||||||
|  |     @GetMapping("/list") | ||||||
|  |     public Page<BusMaterialsInventoryVo> list(MaterialsInventoryQueryReq req) { | ||||||
|  |         return busMaterialsInventoryService.queryPageList(req); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 导出材料出/入库列表 | ||||||
|  |      */ | ||||||
|  |     @SaCheckPermission("materials:materialsInventory:export") | ||||||
|  |     @Log(title = "材料出/入库", businessType = BusinessType.EXPORT) | ||||||
|  |     @PostMapping("/export") | ||||||
|  |     public void export(MaterialsInventoryQueryReq req, HttpServletResponse response) { | ||||||
|  |         List<BusMaterialsInventoryVo> list = busMaterialsInventoryService.queryList(req); | ||||||
|  |         ExcelUtil.exportExcel(list, "材料出/入库", BusMaterialsInventoryVo.class, response); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 获取材料出/入库详细信息 | ||||||
|  |      * | ||||||
|  |      * @param id 主键 | ||||||
|  |      */ | ||||||
|  |     @SaCheckPermission("materials:materialsInventory:query") | ||||||
|  |     @GetMapping("/{id}") | ||||||
|  |     public R<BusMaterialsInventoryVo> getInfo(@NotNull(message = "主键不能为空") | ||||||
|  |                                               @PathVariable Long id) { | ||||||
|  |         return R.ok(busMaterialsInventoryService.queryById(id)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 新增材料出/入库 | ||||||
|  |      */ | ||||||
|  |     @SaCheckPermission("materials:materialsInventory:add") | ||||||
|  |     @Log(title = "材料出/入库", businessType = BusinessType.INSERT) | ||||||
|  |     @RepeatSubmit() | ||||||
|  |     @PostMapping() | ||||||
|  |     public R<Long> add(@Validated(AddGroup.class) @RequestBody MaterialsInventoryCreateReq req) { | ||||||
|  |         return R.ok(busMaterialsInventoryService.insertByBo(req)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 修改材料出/入库 | ||||||
|  |      */ | ||||||
|  |     @SaCheckPermission("materials:materialsInventory:edit") | ||||||
|  |     @Log(title = "材料出/入库", businessType = BusinessType.UPDATE) | ||||||
|  |     @RepeatSubmit() | ||||||
|  |     @PutMapping() | ||||||
|  |     public R<Void> edit(@Validated(EditGroup.class) @RequestBody MaterialsInventoryUpdateReq req) { | ||||||
|  |         return toAjax(busMaterialsInventoryService.updateByBo(req)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 删除材料出/入库 | ||||||
|  |      * | ||||||
|  |      * @param ids 主键串 | ||||||
|  |      */ | ||||||
|  |     @SaCheckPermission("materials:materialsInventory:remove") | ||||||
|  |     @Log(title = "材料出/入库", businessType = BusinessType.DELETE) | ||||||
|  |     @DeleteMapping("/{ids}") | ||||||
|  |     public R<Void> remove(@NotEmpty(message = "主键不能为空") | ||||||
|  |                           @PathVariable Long[] ids) { | ||||||
|  |         return toAjax(busMaterialsInventoryService.deleteWithValidByIds(List.of(ids), true)); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -0,0 +1,69 @@ | |||||||
|  | package org.dromara.materials.domain; | ||||||
|  |  | ||||||
|  | import org.dromara.common.mybatis.core.domain.BaseEntity; | ||||||
|  | import com.baomidou.mybatisplus.annotation.*; | ||||||
|  | import lombok.Data; | ||||||
|  | import lombok.EqualsAndHashCode; | ||||||
|  | import java.util.Date; | ||||||
|  | import com.fasterxml.jackson.annotation.JsonFormat; | ||||||
|  |  | ||||||
|  | import java.io.Serial; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 公司对象 bus_company | ||||||
|  |  * | ||||||
|  |  * @author lcj | ||||||
|  |  * @date 2025-03-06 | ||||||
|  |  */ | ||||||
|  | @Data | ||||||
|  | @EqualsAndHashCode(callSuper = true) | ||||||
|  | @TableName("bus_company") | ||||||
|  | public class BusCompany extends BaseEntity { | ||||||
|  |  | ||||||
|  |     @Serial | ||||||
|  |     private static final long serialVersionUID = 1L; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 主键id | ||||||
|  |      */ | ||||||
|  |     @TableId(value = "id") | ||||||
|  |     private Long id; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 公司名称 | ||||||
|  |      */ | ||||||
|  |     private String companyName; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 项目id | ||||||
|  |      */ | ||||||
|  |     private Long projectId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 帐号状态(0正常 1停用) | ||||||
|  |      */ | ||||||
|  |     private String status; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 备注 | ||||||
|  |      */ | ||||||
|  |     private String remark; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 资质情况 | ||||||
|  |      */ | ||||||
|  |     private String qualification; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 删除时间 | ||||||
|  |      */ | ||||||
|  |     private Date deletedAt; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 是否删除(0正常 1删除) | ||||||
|  |      */ | ||||||
|  |     @TableLogic | ||||||
|  |     private Long isDelete; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | } | ||||||
| @ -0,0 +1,134 @@ | |||||||
|  | package org.dromara.materials.domain; | ||||||
|  |  | ||||||
|  | import org.dromara.common.mybatis.core.domain.BaseEntity; | ||||||
|  | import com.baomidou.mybatisplus.annotation.*; | ||||||
|  | import lombok.Data; | ||||||
|  | import lombok.EqualsAndHashCode; | ||||||
|  | import java.util.Date; | ||||||
|  | import com.fasterxml.jackson.annotation.JsonFormat; | ||||||
|  |  | ||||||
|  | import java.io.Serial; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 材料名称对象 bus_materials | ||||||
|  |  * | ||||||
|  |  * @author lcj | ||||||
|  |  * @date 2025-03-06 | ||||||
|  |  */ | ||||||
|  | @Data | ||||||
|  | @EqualsAndHashCode(callSuper = true) | ||||||
|  | @TableName("bus_materials") | ||||||
|  | public class BusMaterials extends BaseEntity { | ||||||
|  |  | ||||||
|  |     @Serial | ||||||
|  |     private static final long serialVersionUID = 1L; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 主键id | ||||||
|  |      */ | ||||||
|  |     @TableId(value = "id") | ||||||
|  |     private Long id; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 材料名称 | ||||||
|  |      */ | ||||||
|  |     private String materialsName; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 公司id | ||||||
|  |      */ | ||||||
|  |     private Long companyId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 项目id | ||||||
|  |      */ | ||||||
|  |     private Long projectId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 规格型号名称 | ||||||
|  |      */ | ||||||
|  |     private String typeSpecificationName; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 规格型号文件路径 | ||||||
|  |      */ | ||||||
|  |     private String typeSpecificationUrl; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 合格证编号名称 | ||||||
|  |      */ | ||||||
|  |     private String certificateConformityName; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 合格证编号文件路径 | ||||||
|  |      */ | ||||||
|  |     private String certificateConformityUrl; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 质量说明书编号 | ||||||
|  |      */ | ||||||
|  |     private String qualityName; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 质量说明书文件路径 | ||||||
|  |      */ | ||||||
|  |     private String qualityUrl; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 检验报告编号 | ||||||
|  |      */ | ||||||
|  |     private String inspectionReportName; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 检验报告文件路径 | ||||||
|  |      */ | ||||||
|  |     private String inspectionReportUrl; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 复试报告编号 | ||||||
|  |      */ | ||||||
|  |     private String reexamineReportName; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 复试报告文件路径 | ||||||
|  |      */ | ||||||
|  |     private String reexamineReportUrl; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 使用部位 | ||||||
|  |      */ | ||||||
|  |     private String usePart; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 计量单位 | ||||||
|  |      */ | ||||||
|  |     private String weightId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 备注 | ||||||
|  |      */ | ||||||
|  |     private String remark; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 预计材料数量 | ||||||
|  |      */ | ||||||
|  |     private String quantityCount; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 状态(0正常 1停用) | ||||||
|  |      */ | ||||||
|  |     private String status; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 删除时间 | ||||||
|  |      */ | ||||||
|  |     private Date deletedAt; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 是否删除(0正常 1删除) | ||||||
|  |      */ | ||||||
|  |     @TableLogic | ||||||
|  |     private Long isDelete; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | } | ||||||
| @ -0,0 +1,104 @@ | |||||||
|  | package org.dromara.materials.domain; | ||||||
|  |  | ||||||
|  | import org.dromara.common.mybatis.core.domain.BaseEntity; | ||||||
|  | import com.baomidou.mybatisplus.annotation.*; | ||||||
|  | import lombok.Data; | ||||||
|  | import lombok.EqualsAndHashCode; | ||||||
|  | import java.util.Date; | ||||||
|  | import com.fasterxml.jackson.annotation.JsonFormat; | ||||||
|  |  | ||||||
|  | import java.io.Serial; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 材料出/入库对象 bus_materials_inventory | ||||||
|  |  * | ||||||
|  |  * @author lcj | ||||||
|  |  * @date 2025-03-06 | ||||||
|  |  */ | ||||||
|  | @Data | ||||||
|  | @EqualsAndHashCode(callSuper = true) | ||||||
|  | @TableName("bus_materials_inventory") | ||||||
|  | public class BusMaterialsInventory extends BaseEntity { | ||||||
|  |  | ||||||
|  |     @Serial | ||||||
|  |     private static final long serialVersionUID = 1L; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 主键id | ||||||
|  |      */ | ||||||
|  |     @TableId(value = "id") | ||||||
|  |     private Long id; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 材料id | ||||||
|  |      */ | ||||||
|  |     private Long materialsId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 项目id | ||||||
|  |      */ | ||||||
|  |     private Long projectId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 出入库状态 | ||||||
|  |      */ | ||||||
|  |     private String outPut; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 出/入库的数量 | ||||||
|  |      */ | ||||||
|  |     private Long number; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 出/入库操作时间 | ||||||
|  |      */ | ||||||
|  |     private Date outPutTime; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 剩余库存数量(记录最后一次操作留下的库存数) | ||||||
|  |      */ | ||||||
|  |     private Long residue; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 操作人(入库人、领料人) | ||||||
|  |      */ | ||||||
|  |     private String operator; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 材料出入证明 | ||||||
|  |      */ | ||||||
|  |     private String path; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 处理方式 | ||||||
|  |      */ | ||||||
|  |     private String disposition; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 交接单位(班组) | ||||||
|  |      */ | ||||||
|  |     private String recipient; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 领用人 | ||||||
|  |      */ | ||||||
|  |     private String shipper; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 备注 | ||||||
|  |      */ | ||||||
|  |     private String remark; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 删除时间 | ||||||
|  |      */ | ||||||
|  |     private Date deletedAt; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 是否删除(0正常 1删除) | ||||||
|  |      */ | ||||||
|  |     @TableLogic | ||||||
|  |     private Long isDelete; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | } | ||||||
| @ -0,0 +1,38 @@ | |||||||
|  | package org.dromara.materials.domain.req.company; | ||||||
|  |  | ||||||
|  | import lombok.Data; | ||||||
|  |  | ||||||
|  | import java.io.Serial; | ||||||
|  | import java.io.Serializable; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @author lilemy | ||||||
|  |  * @date 2025/3/5 14:05 | ||||||
|  |  */ | ||||||
|  | @Data | ||||||
|  | public class CompanyCreateReq implements Serializable { | ||||||
|  |  | ||||||
|  |     @Serial | ||||||
|  |     private static final long serialVersionUID = -7603153089205421154L; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 公司名称 | ||||||
|  |      */ | ||||||
|  |     private String companyName; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 项目id | ||||||
|  |      */ | ||||||
|  |     private Long projectId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 备注 | ||||||
|  |      */ | ||||||
|  |     private String remark; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 资质情况 | ||||||
|  |      */ | ||||||
|  |     private String qualification; | ||||||
|  |  | ||||||
|  | } | ||||||
| @ -0,0 +1,51 @@ | |||||||
|  | package org.dromara.materials.domain.req.company; | ||||||
|  |  | ||||||
|  | import lombok.Data; | ||||||
|  | import lombok.EqualsAndHashCode; | ||||||
|  | import org.dromara.common.core.common.PageRequest; | ||||||
|  |  | ||||||
|  | import java.io.Serial; | ||||||
|  | import java.io.Serializable; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @author lilemy | ||||||
|  |  * @date 2025/3/5 14:31 | ||||||
|  |  */ | ||||||
|  | @EqualsAndHashCode(callSuper = true) | ||||||
|  | @Data | ||||||
|  | public class CompanyQueryReq extends PageRequest implements Serializable { | ||||||
|  |  | ||||||
|  |     @Serial | ||||||
|  |     private static final long serialVersionUID = 5563677643070664671L; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 主键id | ||||||
|  |      */ | ||||||
|  |     private Long id; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 公司名称 | ||||||
|  |      */ | ||||||
|  |     private String companyName; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 项目id | ||||||
|  |      */ | ||||||
|  |     private Long projectId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 帐号状态(0正常 1停用) | ||||||
|  |      */ | ||||||
|  |     private String status; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 备注 | ||||||
|  |      */ | ||||||
|  |     private String remark; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 资质情况 | ||||||
|  |      */ | ||||||
|  |     private String qualification; | ||||||
|  |  | ||||||
|  | } | ||||||
| @ -0,0 +1,48 @@ | |||||||
|  | package org.dromara.materials.domain.req.company; | ||||||
|  |  | ||||||
|  | import lombok.Data; | ||||||
|  |  | ||||||
|  | import java.io.Serial; | ||||||
|  | import java.io.Serializable; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @author lilemy | ||||||
|  |  * @date 2025/3/5 15:04 | ||||||
|  |  */ | ||||||
|  | @Data | ||||||
|  | public class CompanyUpdateReq implements Serializable { | ||||||
|  |  | ||||||
|  |     @Serial | ||||||
|  |     private static final long serialVersionUID = 3431952359907567659L; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 主键id | ||||||
|  |      */ | ||||||
|  |     private Long id; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 公司名称 | ||||||
|  |      */ | ||||||
|  |     private String companyName; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 项目id | ||||||
|  |      */ | ||||||
|  |     private Long projectId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 帐号状态(0正常 1停用) | ||||||
|  |      */ | ||||||
|  |     private String status; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 备注 | ||||||
|  |      */ | ||||||
|  |     private String remark; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 资质情况 | ||||||
|  |      */ | ||||||
|  |     private String qualification; | ||||||
|  |  | ||||||
|  | } | ||||||
| @ -0,0 +1,103 @@ | |||||||
|  | package org.dromara.materials.domain.req.materials; | ||||||
|  |  | ||||||
|  | import lombok.Data; | ||||||
|  |  | ||||||
|  | import java.io.Serial; | ||||||
|  | import java.io.Serializable; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @author lilemy | ||||||
|  |  * @date 2025/3/5 14:05 | ||||||
|  |  */ | ||||||
|  | @Data | ||||||
|  | public class MaterialsCreateReq implements Serializable { | ||||||
|  |  | ||||||
|  |     @Serial | ||||||
|  |     private static final long serialVersionUID = -7603153089205421154L; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 材料名称 | ||||||
|  |      */ | ||||||
|  |     private String materialsName; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 公司id | ||||||
|  |      */ | ||||||
|  |     private Long companyId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 项目id | ||||||
|  |      */ | ||||||
|  |     private Long projectId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 规格型号名称 | ||||||
|  |      */ | ||||||
|  |     private String typeSpecificationName; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 规格型号文件路径 | ||||||
|  |      */ | ||||||
|  |     private String typeSpecificationUrl; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 合格证编号名称 | ||||||
|  |      */ | ||||||
|  |     private String certificateConformityName; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 合格证编号文件路径 | ||||||
|  |      */ | ||||||
|  |     private String certificateConformityUrl; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 质量说明书编号 | ||||||
|  |      */ | ||||||
|  |     private String qualityName; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 质量说明书文件路径 | ||||||
|  |      */ | ||||||
|  |     private String qualityUrl; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 检验报告编号 | ||||||
|  |      */ | ||||||
|  |     private String inspectionReportName; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 检验报告文件路径 | ||||||
|  |      */ | ||||||
|  |     private String inspectionReportUrl; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 复试报告编号 | ||||||
|  |      */ | ||||||
|  |     private String reexamineReportName; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 复试报告文件路径 | ||||||
|  |      */ | ||||||
|  |     private String reexamineReportUrl; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 使用部位 | ||||||
|  |      */ | ||||||
|  |     private String usePart; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 计量单位 | ||||||
|  |      */ | ||||||
|  |     private String weightId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 备注 | ||||||
|  |      */ | ||||||
|  |     private String remark; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 预计材料数量 | ||||||
|  |      */ | ||||||
|  |     private String quantityCount; | ||||||
|  |  | ||||||
|  | } | ||||||
| @ -0,0 +1,66 @@ | |||||||
|  | package org.dromara.materials.domain.req.materials; | ||||||
|  |  | ||||||
|  | import lombok.Data; | ||||||
|  | import lombok.EqualsAndHashCode; | ||||||
|  | import org.dromara.common.core.common.PageRequest; | ||||||
|  |  | ||||||
|  | import java.io.Serial; | ||||||
|  | import java.io.Serializable; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @author lilemy | ||||||
|  |  * @date 2025/3/5 14:31 | ||||||
|  |  */ | ||||||
|  | @EqualsAndHashCode(callSuper = true) | ||||||
|  | @Data | ||||||
|  | public class MaterialsQueryReq extends PageRequest implements Serializable { | ||||||
|  |  | ||||||
|  |     @Serial | ||||||
|  |     private static final long serialVersionUID = 5563677643070664671L; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 主键id | ||||||
|  |      */ | ||||||
|  |     private Long id; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 材料名称 | ||||||
|  |      */ | ||||||
|  |     private String materialsName; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 公司id | ||||||
|  |      */ | ||||||
|  |     private Long companyId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 项目id | ||||||
|  |      */ | ||||||
|  |     private Long projectId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 使用部位 | ||||||
|  |      */ | ||||||
|  |     private String usePart; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 计量单位 | ||||||
|  |      */ | ||||||
|  |     private String weightId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 备注 | ||||||
|  |      */ | ||||||
|  |     private String remark; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 预计材料数量 | ||||||
|  |      */ | ||||||
|  |     private String quantityCount; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 状态(0正常 1停用) | ||||||
|  |      */ | ||||||
|  |     private String status; | ||||||
|  |  | ||||||
|  | } | ||||||
| @ -0,0 +1,113 @@ | |||||||
|  | package org.dromara.materials.domain.req.materials; | ||||||
|  |  | ||||||
|  | import lombok.Data; | ||||||
|  |  | ||||||
|  | import java.io.Serial; | ||||||
|  | import java.io.Serializable; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @author lilemy | ||||||
|  |  * @date 2025/3/5 15:04 | ||||||
|  |  */ | ||||||
|  | @Data | ||||||
|  | public class MaterialsUpdateReq implements Serializable { | ||||||
|  |  | ||||||
|  |     @Serial | ||||||
|  |     private static final long serialVersionUID = 3431952359907567659L; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 主键id | ||||||
|  |      */ | ||||||
|  |     private Long id; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 材料名称 | ||||||
|  |      */ | ||||||
|  |     private String materialsName; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 公司id | ||||||
|  |      */ | ||||||
|  |     private Long companyId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 项目id | ||||||
|  |      */ | ||||||
|  |     private Long projectId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 规格型号名称 | ||||||
|  |      */ | ||||||
|  |     private String typeSpecificationName; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 规格型号文件路径 | ||||||
|  |      */ | ||||||
|  |     private String typeSpecificationUrl; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 合格证编号名称 | ||||||
|  |      */ | ||||||
|  |     private String certificateConformityName; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 合格证编号文件路径 | ||||||
|  |      */ | ||||||
|  |     private String certificateConformityUrl; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 质量说明书编号 | ||||||
|  |      */ | ||||||
|  |     private String qualityName; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 质量说明书文件路径 | ||||||
|  |      */ | ||||||
|  |     private String qualityUrl; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 检验报告编号 | ||||||
|  |      */ | ||||||
|  |     private String inspectionReportName; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 检验报告文件路径 | ||||||
|  |      */ | ||||||
|  |     private String inspectionReportUrl; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 复试报告编号 | ||||||
|  |      */ | ||||||
|  |     private String reexamineReportName; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 复试报告文件路径 | ||||||
|  |      */ | ||||||
|  |     private String reexamineReportUrl; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 使用部位 | ||||||
|  |      */ | ||||||
|  |     private String usePart; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 计量单位 | ||||||
|  |      */ | ||||||
|  |     private String weightId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 备注 | ||||||
|  |      */ | ||||||
|  |     private String remark; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 预计材料数量 | ||||||
|  |      */ | ||||||
|  |     private String quantityCount; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 状态(0正常 1停用) | ||||||
|  |      */ | ||||||
|  |     private String status; | ||||||
|  |  | ||||||
|  | } | ||||||
| @ -0,0 +1,74 @@ | |||||||
|  | package org.dromara.materials.domain.req.materialsinventory; | ||||||
|  |  | ||||||
|  | import lombok.Data; | ||||||
|  |  | ||||||
|  | import java.io.Serial; | ||||||
|  | import java.io.Serializable; | ||||||
|  | import java.util.Date; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @author lilemy | ||||||
|  |  * @date 2025/3/5 14:05 | ||||||
|  |  */ | ||||||
|  | @Data | ||||||
|  | public class MaterialsInventoryCreateReq implements Serializable { | ||||||
|  |  | ||||||
|  |     @Serial | ||||||
|  |     private static final long serialVersionUID = -7603153089205421154L; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 材料id | ||||||
|  |      */ | ||||||
|  |     private Long materialsId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 项目id | ||||||
|  |      */ | ||||||
|  |     private Long projectId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 出入库状态 | ||||||
|  |      */ | ||||||
|  |     private String outPut; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 出/入库的数量 | ||||||
|  |      */ | ||||||
|  |     private Long number; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 出/入库操作时间 | ||||||
|  |      */ | ||||||
|  |     private Date outPutTime; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 剩余库存数量(记录最后一次操作留下的库存数) | ||||||
|  |      */ | ||||||
|  |     private Long residue; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 材料出入证明 | ||||||
|  |      */ | ||||||
|  |     private String path; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 处理方式 | ||||||
|  |      */ | ||||||
|  |     private String disposition; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 交接单位(班组) | ||||||
|  |      */ | ||||||
|  |     private String recipient; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 领用人 | ||||||
|  |      */ | ||||||
|  |     private String shipper; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 备注 | ||||||
|  |      */ | ||||||
|  |     private String remark; | ||||||
|  |  | ||||||
|  | } | ||||||
| @ -0,0 +1,82 @@ | |||||||
|  | package org.dromara.materials.domain.req.materialsinventory; | ||||||
|  |  | ||||||
|  | import lombok.Data; | ||||||
|  | import lombok.EqualsAndHashCode; | ||||||
|  | import org.dromara.common.core.common.PageRequest; | ||||||
|  |  | ||||||
|  | import java.io.Serial; | ||||||
|  | import java.io.Serializable; | ||||||
|  | import java.util.Date; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @author lilemy | ||||||
|  |  * @date 2025/3/5 14:31 | ||||||
|  |  */ | ||||||
|  | @EqualsAndHashCode(callSuper = true) | ||||||
|  | @Data | ||||||
|  | public class MaterialsInventoryQueryReq extends PageRequest implements Serializable { | ||||||
|  |  | ||||||
|  |     @Serial | ||||||
|  |     private static final long serialVersionUID = 5563677643070664671L; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 主键id | ||||||
|  |      */ | ||||||
|  |     private Long id; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 材料id | ||||||
|  |      */ | ||||||
|  |     private Long materialsId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 项目id | ||||||
|  |      */ | ||||||
|  |     private Long projectId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 出入库状态 | ||||||
|  |      */ | ||||||
|  |     private String outPut; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 出/入库的数量 | ||||||
|  |      */ | ||||||
|  |     private Long number; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 出/入库操作时间 | ||||||
|  |      */ | ||||||
|  |     private Date outPutTime; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 剩余库存数量(记录最后一次操作留下的库存数) | ||||||
|  |      */ | ||||||
|  |     private Long residue; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 操作人(入库人、领料人) | ||||||
|  |      */ | ||||||
|  |     private String operator; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 处理方式 | ||||||
|  |      */ | ||||||
|  |     private String disposition; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 交接单位(班组) | ||||||
|  |      */ | ||||||
|  |     private String recipient; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 领用人 | ||||||
|  |      */ | ||||||
|  |     private String shipper; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 备注 | ||||||
|  |      */ | ||||||
|  |     private String remark; | ||||||
|  |  | ||||||
|  | } | ||||||
| @ -0,0 +1,79 @@ | |||||||
|  | package org.dromara.materials.domain.req.materialsinventory; | ||||||
|  |  | ||||||
|  | import lombok.Data; | ||||||
|  |  | ||||||
|  | import java.io.Serial; | ||||||
|  | import java.io.Serializable; | ||||||
|  | import java.util.Date; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @author lilemy | ||||||
|  |  * @date 2025/3/5 15:04 | ||||||
|  |  */ | ||||||
|  | @Data | ||||||
|  | public class MaterialsInventoryUpdateReq implements Serializable { | ||||||
|  |  | ||||||
|  |     @Serial | ||||||
|  |     private static final long serialVersionUID = 3431952359907567659L; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 主键id | ||||||
|  |      */ | ||||||
|  |     private Long id; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 材料id | ||||||
|  |      */ | ||||||
|  |     private Long materialsId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 项目id | ||||||
|  |      */ | ||||||
|  |     private Long projectId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 出入库状态 | ||||||
|  |      */ | ||||||
|  |     private String outPut; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 出/入库的数量 | ||||||
|  |      */ | ||||||
|  |     private Long number; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 出/入库操作时间 | ||||||
|  |      */ | ||||||
|  |     private Date outPutTime; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 剩余库存数量(记录最后一次操作留下的库存数) | ||||||
|  |      */ | ||||||
|  |     private Long residue; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 材料出入证明 | ||||||
|  |      */ | ||||||
|  |     private String path; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 处理方式 | ||||||
|  |      */ | ||||||
|  |     private String disposition; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 交接单位(班组) | ||||||
|  |      */ | ||||||
|  |     private String recipient; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 领用人 | ||||||
|  |      */ | ||||||
|  |     private String shipper; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 备注 | ||||||
|  |      */ | ||||||
|  |     private String remark; | ||||||
|  |  | ||||||
|  | } | ||||||
| @ -0,0 +1,71 @@ | |||||||
|  | package org.dromara.materials.domain.vo; | ||||||
|  |  | ||||||
|  | import java.util.Date; | ||||||
|  | import com.fasterxml.jackson.annotation.JsonFormat; | ||||||
|  | import org.dromara.materials.domain.BusCompany; | ||||||
|  | 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; | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 公司视图对象 bus_company | ||||||
|  |  * | ||||||
|  |  * @author lcj | ||||||
|  |  * @date 2025-03-06 | ||||||
|  |  */ | ||||||
|  | @Data | ||||||
|  | @ExcelIgnoreUnannotated | ||||||
|  | @AutoMapper(target = BusCompany.class) | ||||||
|  | public class BusCompanyVo implements Serializable { | ||||||
|  |  | ||||||
|  |     @Serial | ||||||
|  |     private static final long serialVersionUID = 1L; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 主键id | ||||||
|  |      */ | ||||||
|  |     @ExcelProperty(value = "主键id") | ||||||
|  |     private Long id; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 公司名称 | ||||||
|  |      */ | ||||||
|  |     @ExcelProperty(value = "公司名称") | ||||||
|  |     private String companyName; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 项目id | ||||||
|  |      */ | ||||||
|  |     @ExcelProperty(value = "项目id") | ||||||
|  |     private Long projectId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 帐号状态(0正常 1停用) | ||||||
|  |      */ | ||||||
|  |     @ExcelProperty(value = "帐号状态", converter = ExcelDictConvert.class) | ||||||
|  |     @ExcelDictFormat(readConverterExp = "0=正常,1=停用") | ||||||
|  |     private String status; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 备注 | ||||||
|  |      */ | ||||||
|  |     @ExcelProperty(value = "备注") | ||||||
|  |     private String remark; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 资质情况 | ||||||
|  |      */ | ||||||
|  |     @ExcelProperty(value = "资质情况") | ||||||
|  |     private String qualification; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | } | ||||||
| @ -0,0 +1,115 @@ | |||||||
|  | package org.dromara.materials.domain.vo; | ||||||
|  |  | ||||||
|  | import java.util.Date; | ||||||
|  | import com.fasterxml.jackson.annotation.JsonFormat; | ||||||
|  | import org.dromara.materials.domain.BusMaterialsInventory; | ||||||
|  | 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; | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 材料出/入库视图对象 bus_materials_inventory | ||||||
|  |  * | ||||||
|  |  * @author lcj | ||||||
|  |  * @date 2025-03-06 | ||||||
|  |  */ | ||||||
|  | @Data | ||||||
|  | @ExcelIgnoreUnannotated | ||||||
|  | @AutoMapper(target = BusMaterialsInventory.class) | ||||||
|  | public class BusMaterialsInventoryVo implements Serializable { | ||||||
|  |  | ||||||
|  |     @Serial | ||||||
|  |     private static final long serialVersionUID = 1L; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 主键id | ||||||
|  |      */ | ||||||
|  |     @ExcelProperty(value = "主键id") | ||||||
|  |     private Long id; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 材料id | ||||||
|  |      */ | ||||||
|  |     @ExcelProperty(value = "材料id") | ||||||
|  |     private Long materialsId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 项目id | ||||||
|  |      */ | ||||||
|  |     @ExcelProperty(value = "项目id") | ||||||
|  |     private Long projectId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 出入库状态 | ||||||
|  |      */ | ||||||
|  |     @ExcelProperty(value = "出入库状态") | ||||||
|  |     private String outPut; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 出/入库的数量 | ||||||
|  |      */ | ||||||
|  |     @ExcelProperty(value = "出/入库的数量") | ||||||
|  |     private Long number; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 出/入库操作时间 | ||||||
|  |      */ | ||||||
|  |     @ExcelProperty(value = "出/入库操作时间") | ||||||
|  |     private Date outPutTime; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 剩余库存数量(记录最后一次操作留下的库存数) | ||||||
|  |      */ | ||||||
|  |     @ExcelProperty(value = "剩余库存数量", converter = ExcelDictConvert.class) | ||||||
|  |     @ExcelDictFormat(readConverterExp = "记=录最后一次操作留下的库存数") | ||||||
|  |     private Long residue; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 操作人(入库人、领料人) | ||||||
|  |      */ | ||||||
|  |     @ExcelProperty(value = "操作人", converter = ExcelDictConvert.class) | ||||||
|  |     @ExcelDictFormat(readConverterExp = "入=库人、领料人") | ||||||
|  |     private String operator; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 材料出入证明 | ||||||
|  |      */ | ||||||
|  |     @ExcelProperty(value = "材料出入证明") | ||||||
|  |     private String path; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 处理方式 | ||||||
|  |      */ | ||||||
|  |     @ExcelProperty(value = "处理方式") | ||||||
|  |     private String disposition; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 交接单位(班组) | ||||||
|  |      */ | ||||||
|  |     @ExcelProperty(value = "交接单位", converter = ExcelDictConvert.class) | ||||||
|  |     @ExcelDictFormat(readConverterExp = "班=组") | ||||||
|  |     private String recipient; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 领用人 | ||||||
|  |      */ | ||||||
|  |     @ExcelProperty(value = "领用人") | ||||||
|  |     private String shipper; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 备注 | ||||||
|  |      */ | ||||||
|  |     @ExcelProperty(value = "备注") | ||||||
|  |     private String remark; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | } | ||||||
| @ -0,0 +1,151 @@ | |||||||
|  | package org.dromara.materials.domain.vo; | ||||||
|  |  | ||||||
|  | import com.alibaba.excel.annotation.ExcelIgnoreUnannotated; | ||||||
|  | import com.alibaba.excel.annotation.ExcelProperty; | ||||||
|  | import io.github.linpeilie.annotations.AutoMapper; | ||||||
|  | import lombok.Data; | ||||||
|  | import org.dromara.common.excel.annotation.ExcelDictFormat; | ||||||
|  | import org.dromara.common.excel.convert.ExcelDictConvert; | ||||||
|  | import org.dromara.materials.domain.BusMaterials; | ||||||
|  |  | ||||||
|  | import java.io.Serial; | ||||||
|  | import java.io.Serializable; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 材料名称视图对象 bus_materials | ||||||
|  |  * | ||||||
|  |  * @author lcj | ||||||
|  |  * @date 2025-03-06 | ||||||
|  |  */ | ||||||
|  | @Data | ||||||
|  | @ExcelIgnoreUnannotated | ||||||
|  | @AutoMapper(target = BusMaterials.class) | ||||||
|  | public class BusMaterialsVo implements Serializable { | ||||||
|  |  | ||||||
|  |     @Serial | ||||||
|  |     private static final long serialVersionUID = 1L; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 主键id | ||||||
|  |      */ | ||||||
|  |     @ExcelProperty(value = "主键id") | ||||||
|  |     private Long id; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 材料名称 | ||||||
|  |      */ | ||||||
|  |     @ExcelProperty(value = "材料名称") | ||||||
|  |     private String materialsName; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 公司id | ||||||
|  |      */ | ||||||
|  |     @ExcelProperty(value = "公司id") | ||||||
|  |     private Long companyId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 公司信息 | ||||||
|  |      */ | ||||||
|  |     @ExcelProperty(value = "公司信息") | ||||||
|  |     private BusCompanyVo companyVo; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 项目id | ||||||
|  |      */ | ||||||
|  |     @ExcelProperty(value = "项目id") | ||||||
|  |     private Long projectId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 规格型号名称 | ||||||
|  |      */ | ||||||
|  |     @ExcelProperty(value = "规格型号名称") | ||||||
|  |     private String typeSpecificationName; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 规格型号文件路径 | ||||||
|  |      */ | ||||||
|  |     @ExcelProperty(value = "规格型号文件路径") | ||||||
|  |     private String typeSpecificationUrl; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 合格证编号名称 | ||||||
|  |      */ | ||||||
|  |     @ExcelProperty(value = "合格证编号名称") | ||||||
|  |     private String certificateConformityName; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 合格证编号文件路径 | ||||||
|  |      */ | ||||||
|  |     @ExcelProperty(value = "合格证编号文件路径") | ||||||
|  |     private String certificateConformityUrl; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 质量说明书编号 | ||||||
|  |      */ | ||||||
|  |     @ExcelProperty(value = "质量说明书编号") | ||||||
|  |     private String qualityName; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 质量说明书文件路径 | ||||||
|  |      */ | ||||||
|  |     @ExcelProperty(value = "质量说明书文件路径") | ||||||
|  |     private String qualityUrl; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 检验报告编号 | ||||||
|  |      */ | ||||||
|  |     @ExcelProperty(value = "检验报告编号") | ||||||
|  |     private String inspectionReportName; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 检验报告文件路径 | ||||||
|  |      */ | ||||||
|  |     @ExcelProperty(value = "检验报告文件路径") | ||||||
|  |     private String inspectionReportUrl; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 复试报告编号 | ||||||
|  |      */ | ||||||
|  |     @ExcelProperty(value = "复试报告编号") | ||||||
|  |     private String reexamineReportName; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 复试报告文件路径 | ||||||
|  |      */ | ||||||
|  |     @ExcelProperty(value = "复试报告文件路径") | ||||||
|  |     private String reexamineReportUrl; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 使用部位 | ||||||
|  |      */ | ||||||
|  |     @ExcelProperty(value = "使用部位") | ||||||
|  |     private String usePart; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 计量单位 | ||||||
|  |      */ | ||||||
|  |     @ExcelProperty(value = "计量单位") | ||||||
|  |     private String weightId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 备注 | ||||||
|  |      */ | ||||||
|  |     @ExcelProperty(value = "备注") | ||||||
|  |     private String remark; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 预计材料数量 | ||||||
|  |      */ | ||||||
|  |     @ExcelProperty(value = "预计材料数量") | ||||||
|  |     private String quantityCount; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 状态(0正常 1停用) | ||||||
|  |      */ | ||||||
|  |     @ExcelProperty(value = "状态", converter = ExcelDictConvert.class) | ||||||
|  |     @ExcelDictFormat(readConverterExp = "0=正常,1=停用") | ||||||
|  |     private String status; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | } | ||||||
| @ -0,0 +1,15 @@ | |||||||
|  | package org.dromara.materials.mapper; | ||||||
|  |  | ||||||
|  | import org.dromara.materials.domain.BusCompany; | ||||||
|  | import org.dromara.materials.domain.vo.BusCompanyVo; | ||||||
|  | import org.dromara.common.mybatis.core.mapper.BaseMapperPlus; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 公司Mapper接口 | ||||||
|  |  * | ||||||
|  |  * @author lcj | ||||||
|  |  * @date 2025-03-06 | ||||||
|  |  */ | ||||||
|  | public interface BusCompanyMapper extends BaseMapperPlus<BusCompany, BusCompanyVo> { | ||||||
|  |  | ||||||
|  | } | ||||||
| @ -0,0 +1,15 @@ | |||||||
|  | package org.dromara.materials.mapper; | ||||||
|  |  | ||||||
|  | import org.dromara.materials.domain.BusMaterialsInventory; | ||||||
|  | import org.dromara.materials.domain.vo.BusMaterialsInventoryVo; | ||||||
|  | import org.dromara.common.mybatis.core.mapper.BaseMapperPlus; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 材料出/入库Mapper接口 | ||||||
|  |  * | ||||||
|  |  * @author lcj | ||||||
|  |  * @date 2025-03-06 | ||||||
|  |  */ | ||||||
|  | public interface BusMaterialsInventoryMapper extends BaseMapperPlus<BusMaterialsInventory, BusMaterialsInventoryVo> { | ||||||
|  |  | ||||||
|  | } | ||||||
| @ -0,0 +1,15 @@ | |||||||
|  | package org.dromara.materials.mapper; | ||||||
|  |  | ||||||
|  | import org.dromara.materials.domain.BusMaterials; | ||||||
|  | import org.dromara.materials.domain.vo.BusMaterialsVo; | ||||||
|  | import org.dromara.common.mybatis.core.mapper.BaseMapperPlus; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 材料名称Mapper接口 | ||||||
|  |  * | ||||||
|  |  * @author lcj | ||||||
|  |  * @date 2025-03-06 | ||||||
|  |  */ | ||||||
|  | public interface BusMaterialsMapper extends BaseMapperPlus<BusMaterials, BusMaterialsVo> { | ||||||
|  |  | ||||||
|  | } | ||||||
| @ -0,0 +1,87 @@ | |||||||
|  | package org.dromara.materials.service; | ||||||
|  |  | ||||||
|  | import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | ||||||
|  | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||||
|  | import com.baomidou.mybatisplus.extension.service.IService; | ||||||
|  | import org.dromara.materials.domain.BusCompany; | ||||||
|  | import org.dromara.materials.domain.req.company.CompanyCreateReq; | ||||||
|  | import org.dromara.materials.domain.req.company.CompanyQueryReq; | ||||||
|  | import org.dromara.materials.domain.req.company.CompanyUpdateReq; | ||||||
|  | import org.dromara.materials.domain.vo.BusCompanyVo; | ||||||
|  |  | ||||||
|  | import java.util.Collection; | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 公司Service接口 | ||||||
|  |  * | ||||||
|  |  * @author lcj | ||||||
|  |  * @date 2025-03-06 | ||||||
|  |  */ | ||||||
|  | public interface IBusCompanyService extends IService<BusCompany> { | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 查询公司 | ||||||
|  |      * | ||||||
|  |      * @param id 主键 | ||||||
|  |      * @return 公司 | ||||||
|  |      */ | ||||||
|  |     BusCompanyVo queryById(Long id); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 分页查询公司列表 | ||||||
|  |      * | ||||||
|  |      * @param req 查询条件 | ||||||
|  |      * @return 公司分页列表 | ||||||
|  |      */ | ||||||
|  |     Page<BusCompanyVo> queryPageList(CompanyQueryReq req); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 查询符合条件的公司列表 | ||||||
|  |      * | ||||||
|  |      * @param req 查询条件 | ||||||
|  |      * @return 公司列表 | ||||||
|  |      */ | ||||||
|  |     List<BusCompanyVo> queryList(CompanyQueryReq req); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 新增公司 | ||||||
|  |      * | ||||||
|  |      * @param req 公司 | ||||||
|  |      * @return 新增公司id | ||||||
|  |      */ | ||||||
|  |     Long insertByBo(CompanyCreateReq req); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 修改公司 | ||||||
|  |      * | ||||||
|  |      * @param req 公司 | ||||||
|  |      * @return 是否修改成功 | ||||||
|  |      */ | ||||||
|  |     Boolean updateByBo(CompanyUpdateReq req); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 校验并批量删除公司信息 | ||||||
|  |      * | ||||||
|  |      * @param ids     待删除的主键集合 | ||||||
|  |      * @param isValid 是否进行有效性校验 | ||||||
|  |      * @return 是否删除成功 | ||||||
|  |      */ | ||||||
|  |     Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 构建查询条件封装 | ||||||
|  |      * | ||||||
|  |      * @param req 查询条件 | ||||||
|  |      * @return 查询条件封装 | ||||||
|  |      */ | ||||||
|  |     QueryWrapper<BusCompany> getQueryWrapper(CompanyQueryReq req); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 获取公司分页对象视图 | ||||||
|  |      * | ||||||
|  |      * @param companyPage 公司分页对象 | ||||||
|  |      * @return 公司分页对象视图 | ||||||
|  |      */ | ||||||
|  |     Page<BusCompanyVo> getCompanyVoPage(Page<BusCompany> companyPage); | ||||||
|  | } | ||||||
| @ -0,0 +1,88 @@ | |||||||
|  | package org.dromara.materials.service; | ||||||
|  |  | ||||||
|  | import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | ||||||
|  | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||||
|  | import com.baomidou.mybatisplus.extension.service.IService; | ||||||
|  | import org.dromara.materials.domain.BusMaterialsInventory; | ||||||
|  | import org.dromara.materials.domain.req.materialsinventory.MaterialsInventoryCreateReq; | ||||||
|  | import org.dromara.materials.domain.req.materialsinventory.MaterialsInventoryQueryReq; | ||||||
|  | import org.dromara.materials.domain.req.materialsinventory.MaterialsInventoryUpdateReq; | ||||||
|  | import org.dromara.materials.domain.vo.BusMaterialsInventoryVo; | ||||||
|  |  | ||||||
|  | import java.util.Collection; | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 材料出/入库Service接口 | ||||||
|  |  * | ||||||
|  |  * @author lcj | ||||||
|  |  * @date 2025-03-06 | ||||||
|  |  */ | ||||||
|  | public interface IBusMaterialsInventoryService extends IService<BusMaterialsInventory> { | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 查询材料出/入库 | ||||||
|  |      * | ||||||
|  |      * @param id 主键 | ||||||
|  |      * @return 材料出/入库 | ||||||
|  |      */ | ||||||
|  |     BusMaterialsInventoryVo queryById(Long id); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 分页查询材料出/入库列表 | ||||||
|  |      * | ||||||
|  |      * @param req 查询条件 | ||||||
|  |      * @return 材料出/入库分页列表 | ||||||
|  |      */ | ||||||
|  |     Page<BusMaterialsInventoryVo> queryPageList(MaterialsInventoryQueryReq req); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 查询符合条件的材料出/入库列表 | ||||||
|  |      * | ||||||
|  |      * @param req 查询条件 | ||||||
|  |      * @return 材料出/入库列表 | ||||||
|  |      */ | ||||||
|  |     List<BusMaterialsInventoryVo> queryList(MaterialsInventoryQueryReq req); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 新增材料出/入库 | ||||||
|  |      * | ||||||
|  |      * @param req 材料出/入库 | ||||||
|  |      * @return 是否新增成功 | ||||||
|  |      */ | ||||||
|  |     Long insertByBo(MaterialsInventoryCreateReq req); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 修改材料出/入库 | ||||||
|  |      * | ||||||
|  |      * @param req 材料出/入库 | ||||||
|  |      * @return 是否修改成功 | ||||||
|  |      */ | ||||||
|  |     Boolean updateByBo(MaterialsInventoryUpdateReq req); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 校验并批量删除材料出/入库信息 | ||||||
|  |      * | ||||||
|  |      * @param ids     待删除的主键集合 | ||||||
|  |      * @param isValid 是否进行有效性校验 | ||||||
|  |      * @return 是否删除成功 | ||||||
|  |      */ | ||||||
|  |     Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 构建查询条件封装 | ||||||
|  |      * | ||||||
|  |      * @param req 查询条件 | ||||||
|  |      * @return 查询条件封装 | ||||||
|  |      */ | ||||||
|  |     QueryWrapper<BusMaterialsInventory> getQueryWrapper(MaterialsInventoryQueryReq req); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 获取材料出/入库分页对象视图 | ||||||
|  |      * | ||||||
|  |      * @param materialsInventoryPage 材料出/入库分页对象 | ||||||
|  |      * @return 材料出/入库分页对象视图 | ||||||
|  |      */ | ||||||
|  |     Page<BusMaterialsInventoryVo> getMaterialsInventoryVoPage(Page<BusMaterialsInventory> materialsInventoryPage); | ||||||
|  |  | ||||||
|  | } | ||||||
| @ -0,0 +1,95 @@ | |||||||
|  | package org.dromara.materials.service; | ||||||
|  |  | ||||||
|  | import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | ||||||
|  | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||||
|  | import com.baomidou.mybatisplus.extension.service.IService; | ||||||
|  | import org.dromara.materials.domain.BusMaterials; | ||||||
|  | import org.dromara.materials.domain.req.materials.MaterialsCreateReq; | ||||||
|  | import org.dromara.materials.domain.req.materials.MaterialsQueryReq; | ||||||
|  | import org.dromara.materials.domain.req.materials.MaterialsUpdateReq; | ||||||
|  | import org.dromara.materials.domain.vo.BusMaterialsVo; | ||||||
|  |  | ||||||
|  | import java.util.Collection; | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 材料名称Service接口 | ||||||
|  |  * | ||||||
|  |  * @author lcj | ||||||
|  |  * @date 2025-03-06 | ||||||
|  |  */ | ||||||
|  | public interface IBusMaterialsService extends IService<BusMaterials> { | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 查询材料名称 | ||||||
|  |      * | ||||||
|  |      * @param id 主键 | ||||||
|  |      * @return 材料名称 | ||||||
|  |      */ | ||||||
|  |     BusMaterialsVo queryById(Long id); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 分页查询材料名称列表 | ||||||
|  |      * | ||||||
|  |      * @param req 查询条件 | ||||||
|  |      * @return 材料名称分页列表 | ||||||
|  |      */ | ||||||
|  |     Page<BusMaterialsVo> queryPageList(MaterialsQueryReq req); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 查询符合条件的材料名称列表 | ||||||
|  |      * | ||||||
|  |      * @param req 查询条件 | ||||||
|  |      * @return 材料名称列表 | ||||||
|  |      */ | ||||||
|  |     List<BusMaterialsVo> queryList(MaterialsQueryReq req); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 新增材料名称 | ||||||
|  |      * | ||||||
|  |      * @param req 材料名称 | ||||||
|  |      * @return 是否新增成功 | ||||||
|  |      */ | ||||||
|  |     Long insertByBo(MaterialsCreateReq req); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 修改材料名称 | ||||||
|  |      * | ||||||
|  |      * @param req 材料名称 | ||||||
|  |      * @return 是否修改成功 | ||||||
|  |      */ | ||||||
|  |     Boolean updateByBo(MaterialsUpdateReq req); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 校验并批量删除材料名称信息 | ||||||
|  |      * | ||||||
|  |      * @param ids     待删除的主键集合 | ||||||
|  |      * @param isValid 是否进行有效性校验 | ||||||
|  |      * @return 是否删除成功 | ||||||
|  |      */ | ||||||
|  |     Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 获取材料视图 | ||||||
|  |      * | ||||||
|  |      * @param Materials 材料 | ||||||
|  |      * @return 材料视图 | ||||||
|  |      */ | ||||||
|  |     BusMaterialsVo getBusMaterialsVo(BusMaterials Materials); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 构建查询条件封装 | ||||||
|  |      * | ||||||
|  |      * @param req 查询条件 | ||||||
|  |      * @return 查询条件封装 | ||||||
|  |      */ | ||||||
|  |     QueryWrapper<BusMaterials> getQueryWrapper(MaterialsQueryReq req); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 获取材料分页对象视图 | ||||||
|  |      * | ||||||
|  |      * @param materialsPage 材料分页对象 | ||||||
|  |      * @return 材料分页对象视图 | ||||||
|  |      */ | ||||||
|  |     Page<BusMaterialsVo> getMaterialsVoPage(Page<BusMaterials> materialsPage); | ||||||
|  | } | ||||||
| @ -0,0 +1,211 @@ | |||||||
|  | package org.dromara.materials.service.impl; | ||||||
|  |  | ||||||
|  | import cn.hutool.core.collection.CollUtil; | ||||||
|  | import cn.hutool.core.util.StrUtil; | ||||||
|  | import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | ||||||
|  | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||||
|  | import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | ||||||
|  | import jakarta.annotation.Resource; | ||||||
|  | import org.dromara.common.core.constant.CommonConstant; | ||||||
|  | import org.dromara.common.core.constant.HttpStatus; | ||||||
|  | import org.dromara.common.core.exception.ServiceException; | ||||||
|  | import org.dromara.common.core.utils.ObjectUtils; | ||||||
|  | import org.dromara.common.core.utils.StringUtils; | ||||||
|  | import org.dromara.common.core.utils.sql.SqlUtil; | ||||||
|  | import org.dromara.materials.domain.BusCompany; | ||||||
|  | import org.dromara.materials.domain.req.company.CompanyCreateReq; | ||||||
|  | import org.dromara.materials.domain.req.company.CompanyQueryReq; | ||||||
|  | import org.dromara.materials.domain.req.company.CompanyUpdateReq; | ||||||
|  | import org.dromara.materials.domain.vo.BusCompanyVo; | ||||||
|  | import org.dromara.materials.mapper.BusCompanyMapper; | ||||||
|  | import org.dromara.materials.service.IBusCompanyService; | ||||||
|  | import org.springframework.beans.BeanUtils; | ||||||
|  | import org.springframework.stereotype.Service; | ||||||
|  |  | ||||||
|  | import java.util.Collection; | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 公司Service业务层处理 | ||||||
|  |  * | ||||||
|  |  * @author lcj | ||||||
|  |  * @date 2025-03-06 | ||||||
|  |  */ | ||||||
|  | @Service | ||||||
|  | public class BusCompanyServiceImpl extends ServiceImpl<BusCompanyMapper, BusCompany> | ||||||
|  |     implements IBusCompanyService { | ||||||
|  |  | ||||||
|  |     @Resource | ||||||
|  |     private BusCompanyMapper baseMapper; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 查询公司 | ||||||
|  |      * | ||||||
|  |      * @param id 主键 | ||||||
|  |      * @return 公司 | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public BusCompanyVo queryById(Long id) { | ||||||
|  |         return baseMapper.selectVoById(id); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 分页查询公司列表 | ||||||
|  |      * | ||||||
|  |      * @param req 查询条件 | ||||||
|  |      * @return 公司分页列表 | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public Page<BusCompanyVo> queryPageList(CompanyQueryReq req) { | ||||||
|  |         long current = req.getCurrent(); | ||||||
|  |         long size = req.getPageSize(); | ||||||
|  |         // 查询数据库 | ||||||
|  |         Page<BusCompany> result = this.page(new Page<>(current, size), this.getQueryWrapper(req)); | ||||||
|  |         return this.getCompanyVoPage(result); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 查询符合条件的公司列表 | ||||||
|  |      * | ||||||
|  |      * @param req 查询条件 | ||||||
|  |      * @return 公司列表 | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public List<BusCompanyVo> queryList(CompanyQueryReq req) { | ||||||
|  |         QueryWrapper<BusCompany> queryWrapper = this.getQueryWrapper(req); | ||||||
|  |         return baseMapper.selectVoList(queryWrapper); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 新增公司 | ||||||
|  |      * | ||||||
|  |      * @param req 公司 | ||||||
|  |      * @return 新增公司id | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public Long insertByBo(CompanyCreateReq req) { | ||||||
|  |         // 将实体类和 DTO 进行转换 | ||||||
|  |         BusCompany company = new BusCompany(); | ||||||
|  |         BeanUtils.copyProperties(req, company); | ||||||
|  |         // 数据校验 | ||||||
|  |         validEntityBeforeSave(company); | ||||||
|  |         // 写入数据库 | ||||||
|  |         boolean save = this.save(company); | ||||||
|  |         if (!save) { | ||||||
|  |             throw new ServiceException("新增公司失败,数据库异常", HttpStatus.ERROR); | ||||||
|  |         } | ||||||
|  |         return company.getId(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 修改公司 | ||||||
|  |      * | ||||||
|  |      * @param req 公司 | ||||||
|  |      * @return 是否修改成功 | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public Boolean updateByBo(CompanyUpdateReq req) { | ||||||
|  |         // 将实体类和 DTO 进行转换 | ||||||
|  |         BusCompany company = new BusCompany(); | ||||||
|  |         BeanUtils.copyProperties(req, company); | ||||||
|  |         // 数据校验 | ||||||
|  |         validEntityBeforeSave(company); | ||||||
|  |         // 判断是否存在 | ||||||
|  |         BusCompany oldCompany = this.getById(company.getId()); | ||||||
|  |         if (oldCompany == null) { | ||||||
|  |             throw new ServiceException("修改公司失败,数据不存在", HttpStatus.NOT_FOUND); | ||||||
|  |         } | ||||||
|  |         // 操作数据库 | ||||||
|  |         return this.updateById(company); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 保存前的数据校验 | ||||||
|  |      */ | ||||||
|  |     private void validEntityBeforeSave(BusCompany entity) { | ||||||
|  |         // TODO 做一些数据校验,如唯一约束 | ||||||
|  |         String companyName = entity.getCompanyName(); | ||||||
|  |         Long projectId = entity.getProjectId(); | ||||||
|  |         if (StringUtils.isBlank(companyName)) { | ||||||
|  |             throw new ServiceException("公司名称不能为空", HttpStatus.BAD_REQUEST); | ||||||
|  |         } | ||||||
|  |         if (projectId == null) { | ||||||
|  |             throw new ServiceException("项目 id 不能为空", HttpStatus.BAD_REQUEST); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 校验并批量删除公司信息 | ||||||
|  |      * | ||||||
|  |      * @param ids     待删除的主键集合 | ||||||
|  |      * @param isValid 是否进行有效性校验 | ||||||
|  |      * @return 是否删除成功 | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid) { | ||||||
|  |         if (isValid) { | ||||||
|  |             //TODO 做一些业务上的校验,判断是否需要校验 | ||||||
|  |         } | ||||||
|  |         return baseMapper.deleteByIds(ids) > 0; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 构建查询条件封装 | ||||||
|  |      * | ||||||
|  |      * @param req 查询条件 | ||||||
|  |      * @return 查询条件封装 | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public QueryWrapper<BusCompany> getQueryWrapper(CompanyQueryReq req) { | ||||||
|  |         QueryWrapper<BusCompany> queryWrapper = new QueryWrapper<>(); | ||||||
|  |         if (req == null) { | ||||||
|  |             return queryWrapper; | ||||||
|  |         } | ||||||
|  |         // 从对象中取值 | ||||||
|  |         Long id = req.getId(); | ||||||
|  |         String companyName = req.getCompanyName(); | ||||||
|  |         Long projectId = req.getProjectId(); | ||||||
|  |         String status = req.getStatus(); | ||||||
|  |         String remark = req.getRemark(); | ||||||
|  |         String qualification = req.getQualification(); | ||||||
|  |         String sortField = req.getSortField(); | ||||||
|  |         String sortOrder = req.getSortOrder(); | ||||||
|  |         String underlineSortField = StrUtil.toUnderlineCase(sortField); | ||||||
|  |         // 模糊查询 | ||||||
|  |         queryWrapper.like(StringUtils.isNotBlank(companyName), "company_name", companyName); | ||||||
|  |         queryWrapper.like(StringUtils.isNotBlank(qualification), "qualification", qualification); | ||||||
|  |         queryWrapper.like(StringUtils.isNotBlank(remark), "remark", remark); | ||||||
|  |         // 精确查询 | ||||||
|  |         queryWrapper.eq(ObjectUtils.isNotEmpty(status), "status", status); | ||||||
|  |         queryWrapper.eq(ObjectUtils.isNotEmpty(id), "id", id); | ||||||
|  |         queryWrapper.eq(ObjectUtils.isNotEmpty(projectId), "project_id", projectId); | ||||||
|  |         // 排序规则 | ||||||
|  |         queryWrapper.orderBy(SqlUtil.validSortField(sortField), | ||||||
|  |             sortOrder.equals(CommonConstant.SORT_ORDER_ASC), | ||||||
|  |             underlineSortField); | ||||||
|  |         return queryWrapper; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 获取公司分页对象视图 | ||||||
|  |      * | ||||||
|  |      * @param companyPage 公司分页对象 | ||||||
|  |      * @return 公司分页对象视图 | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public Page<BusCompanyVo> getCompanyVoPage(Page<BusCompany> companyPage) { | ||||||
|  |         List<BusCompany> companyList = companyPage.getRecords(); | ||||||
|  |         Page<BusCompanyVo> companyVoPage = new Page<>(companyPage.getCurrent(), companyPage.getSize(), companyPage.getTotal()); | ||||||
|  |         if (CollUtil.isEmpty(companyList)) { | ||||||
|  |             return companyVoPage; | ||||||
|  |         } | ||||||
|  |         // 对象列表 => 封装对象列表 | ||||||
|  |         List<BusCompanyVo> companyVoList = companyList.stream().map(company -> { | ||||||
|  |             BusCompanyVo companyVo = new BusCompanyVo(); | ||||||
|  |             BeanUtils.copyProperties(company, companyVo); | ||||||
|  |             return companyVo; | ||||||
|  |         }).toList(); | ||||||
|  |         companyVoPage.setRecords(companyVoList); | ||||||
|  |         return companyVoPage; | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -0,0 +1,219 @@ | |||||||
|  | package org.dromara.materials.service.impl; | ||||||
|  |  | ||||||
|  | import cn.hutool.core.collection.CollUtil; | ||||||
|  | import cn.hutool.core.util.StrUtil; | ||||||
|  | import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | ||||||
|  | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||||
|  | import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | ||||||
|  | import jakarta.annotation.Resource; | ||||||
|  | import org.dromara.common.core.constant.CommonConstant; | ||||||
|  | import org.dromara.common.core.constant.HttpStatus; | ||||||
|  | import org.dromara.common.core.exception.ServiceException; | ||||||
|  | import org.dromara.common.core.utils.ObjectUtils; | ||||||
|  | import org.dromara.common.core.utils.StringUtils; | ||||||
|  | import org.dromara.common.core.utils.sql.SqlUtil; | ||||||
|  | import org.dromara.materials.domain.BusMaterialsInventory; | ||||||
|  | import org.dromara.materials.domain.req.materialsinventory.MaterialsInventoryCreateReq; | ||||||
|  | import org.dromara.materials.domain.req.materialsinventory.MaterialsInventoryQueryReq; | ||||||
|  | import org.dromara.materials.domain.req.materialsinventory.MaterialsInventoryUpdateReq; | ||||||
|  | import org.dromara.materials.domain.vo.BusMaterialsInventoryVo; | ||||||
|  | import org.dromara.materials.mapper.BusMaterialsInventoryMapper; | ||||||
|  | import org.dromara.materials.service.IBusMaterialsInventoryService; | ||||||
|  | import org.springframework.beans.BeanUtils; | ||||||
|  | import org.springframework.stereotype.Service; | ||||||
|  |  | ||||||
|  | import java.util.Collection; | ||||||
|  | import java.util.Date; | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 材料出/入库Service业务层处理 | ||||||
|  |  * | ||||||
|  |  * @author lcj | ||||||
|  |  * @date 2025-03-06 | ||||||
|  |  */ | ||||||
|  | @Service | ||||||
|  | public class BusMaterialsInventoryServiceImpl extends ServiceImpl<BusMaterialsInventoryMapper, BusMaterialsInventory> | ||||||
|  |     implements IBusMaterialsInventoryService { | ||||||
|  |  | ||||||
|  |     @Resource | ||||||
|  |     private BusMaterialsInventoryMapper baseMapper; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 查询材料出/入库 | ||||||
|  |      * | ||||||
|  |      * @param id 主键 | ||||||
|  |      * @return 材料出/入库 | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public BusMaterialsInventoryVo queryById(Long id) { | ||||||
|  |         return baseMapper.selectVoById(id); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 分页查询材料出/入库列表 | ||||||
|  |      * | ||||||
|  |      * @param req 查询条件 | ||||||
|  |      * @return 材料出/入库分页列表 | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public Page<BusMaterialsInventoryVo> queryPageList(MaterialsInventoryQueryReq req) { | ||||||
|  |         long current = req.getCurrent(); | ||||||
|  |         long size = req.getPageSize(); | ||||||
|  |         // 查询数据库 | ||||||
|  |         Page<BusMaterialsInventory> result = this.page(new Page<>(current, size), this.getQueryWrapper(req)); | ||||||
|  |         return this.getMaterialsInventoryVoPage(result); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 查询符合条件的材料出/入库列表 | ||||||
|  |      * | ||||||
|  |      * @param req 查询条件 | ||||||
|  |      * @return 材料出/入库列表 | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public List<BusMaterialsInventoryVo> queryList(MaterialsInventoryQueryReq req) { | ||||||
|  |         QueryWrapper<BusMaterialsInventory> queryWrapper = this.getQueryWrapper(req); | ||||||
|  |         return baseMapper.selectVoList(queryWrapper); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 新增材料出/入库 | ||||||
|  |      * | ||||||
|  |      * @param req 材料出/入库 | ||||||
|  |      * @return 是否新增成功 | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public Long insertByBo(MaterialsInventoryCreateReq req) { | ||||||
|  |         // 将实体类和 DTO 进行转换 | ||||||
|  |         BusMaterialsInventory materialsInventory = new BusMaterialsInventory(); | ||||||
|  |         BeanUtils.copyProperties(req, materialsInventory); | ||||||
|  |         // 数据校验 | ||||||
|  |         validEntityBeforeSave(materialsInventory); | ||||||
|  |         // 操作数据库 | ||||||
|  |         boolean save = this.save(materialsInventory); | ||||||
|  |         if (!save) { | ||||||
|  |             throw new ServiceException("新增材料出/入库失败,数据库异常", HttpStatus.ERROR); | ||||||
|  |         } | ||||||
|  |         return materialsInventory.getId(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 修改材料出/入库 | ||||||
|  |      * | ||||||
|  |      * @param req 材料出/入库 | ||||||
|  |      * @return 是否修改成功 | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public Boolean updateByBo(MaterialsInventoryUpdateReq req) { | ||||||
|  |         // 将实体类和 DTO 进行转换 | ||||||
|  |         BusMaterialsInventory materialsInventory = new BusMaterialsInventory(); | ||||||
|  |         BeanUtils.copyProperties(req, materialsInventory); | ||||||
|  |         // 数据校验 | ||||||
|  |         validEntityBeforeSave(materialsInventory); | ||||||
|  |         // 判断是否存在 | ||||||
|  |         BusMaterialsInventory oldBusMaterialsInventory = this.getById(materialsInventory.getId()); | ||||||
|  |         if (oldBusMaterialsInventory == null) { | ||||||
|  |             throw new ServiceException("修改材料出/入库失败,数据不存在", HttpStatus.NOT_FOUND); | ||||||
|  |         } | ||||||
|  |         // 操作数据库 | ||||||
|  |         return this.updateById(materialsInventory); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 保存前的数据校验 | ||||||
|  |      */ | ||||||
|  |     private void validEntityBeforeSave(BusMaterialsInventory entity) { | ||||||
|  |         //TODO 做一些数据校验,如唯一约束 | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 校验并批量删除材料出/入库信息 | ||||||
|  |      * | ||||||
|  |      * @param ids     待删除的主键集合 | ||||||
|  |      * @param isValid 是否进行有效性校验 | ||||||
|  |      * @return 是否删除成功 | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid) { | ||||||
|  |         if (isValid) { | ||||||
|  |             //TODO 做一些业务上的校验,判断是否需要校验 | ||||||
|  |         } | ||||||
|  |         return baseMapper.deleteByIds(ids) > 0; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 构建查询条件封装 | ||||||
|  |      * | ||||||
|  |      * @param req 查询条件 | ||||||
|  |      * @return 查询条件封装 | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public QueryWrapper<BusMaterialsInventory> getQueryWrapper(MaterialsInventoryQueryReq req) { | ||||||
|  |         QueryWrapper<BusMaterialsInventory> queryWrapper = new QueryWrapper<>(); | ||||||
|  |         if (req == null) { | ||||||
|  |             return queryWrapper; | ||||||
|  |         } | ||||||
|  |         // 从对象中取值 | ||||||
|  |         Long id = req.getId(); | ||||||
|  |         Long materialsId = req.getMaterialsId(); | ||||||
|  |         Long projectId = req.getProjectId(); | ||||||
|  |         String outPut = req.getOutPut(); | ||||||
|  |         Long number = req.getNumber(); | ||||||
|  |         Date outPutTime = req.getOutPutTime(); | ||||||
|  |         Long residue = req.getResidue(); | ||||||
|  |         String operator = req.getOperator(); | ||||||
|  |         String disposition = req.getDisposition(); | ||||||
|  |         String recipient = req.getRecipient(); | ||||||
|  |         String shipper = req.getShipper(); | ||||||
|  |         String remark = req.getRemark(); | ||||||
|  |         String sortField = req.getSortField(); | ||||||
|  |         String sortOrder = req.getSortOrder(); | ||||||
|  |         String underlineSortField = StrUtil.toUnderlineCase(sortField); | ||||||
|  |         // 模糊查询 | ||||||
|  |         queryWrapper.like(StringUtils.isNotBlank(outPut), "out_put", outPut); | ||||||
|  |         queryWrapper.like(StringUtils.isNotBlank(operator), "operator", operator); | ||||||
|  |         queryWrapper.like(StringUtils.isNotBlank(remark), "remark", remark); | ||||||
|  |         queryWrapper.like(StringUtils.isNotBlank(disposition), "disposition", disposition); | ||||||
|  |         queryWrapper.like(StringUtils.isNotBlank(recipient), recipient, recipient); | ||||||
|  |         queryWrapper.like(StringUtils.isNotBlank(shipper), shipper, shipper); | ||||||
|  |         // 精确查询 | ||||||
|  |         queryWrapper.eq(ObjectUtils.isNotEmpty(id), "id", id); | ||||||
|  |         queryWrapper.eq(ObjectUtils.isNotEmpty(projectId), "project_id", projectId); | ||||||
|  |         queryWrapper.eq(ObjectUtils.isNotEmpty(materialsId), "materials_id", materialsId); | ||||||
|  |         queryWrapper.eq(ObjectUtils.isNotEmpty(number), "number", number); | ||||||
|  |         queryWrapper.eq(ObjectUtils.isNotEmpty(outPutTime), "out_put_time", outPutTime); | ||||||
|  |         queryWrapper.eq(ObjectUtils.isNotEmpty(residue), "residue", residue); | ||||||
|  |         // 排序规则 | ||||||
|  |         queryWrapper.orderBy(SqlUtil.validSortField(sortField), | ||||||
|  |             sortOrder.equals(CommonConstant.SORT_ORDER_ASC), | ||||||
|  |             underlineSortField); | ||||||
|  |         return queryWrapper; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 获取材料出/入库分页对象视图 | ||||||
|  |      * | ||||||
|  |      * @param materialsInventoryPage 材料出/入库分页对象 | ||||||
|  |      * @return 材料出/入库分页对象视图 | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public Page<BusMaterialsInventoryVo> getMaterialsInventoryVoPage(Page<BusMaterialsInventory> materialsInventoryPage) { | ||||||
|  |         List<BusMaterialsInventory> materialsInventoryList = materialsInventoryPage.getRecords(); | ||||||
|  |         Page<BusMaterialsInventoryVo> materialsInventoryVoPage = new Page<>( | ||||||
|  |             materialsInventoryPage.getCurrent(), | ||||||
|  |             materialsInventoryPage.getSize(), | ||||||
|  |             materialsInventoryPage.getTotal()); | ||||||
|  |         if (CollUtil.isEmpty(materialsInventoryList)) { | ||||||
|  |             return materialsInventoryVoPage; | ||||||
|  |         } | ||||||
|  |         // 对象列表 => 封装对象列表 | ||||||
|  |         List<BusMaterialsInventoryVo> materialsInventoryVoList = materialsInventoryList.stream().map(materialsInventory -> { | ||||||
|  |             BusMaterialsInventoryVo materialsInventoryVo = new BusMaterialsInventoryVo(); | ||||||
|  |             BeanUtils.copyProperties(materialsInventory, materialsInventoryVo); | ||||||
|  |             return materialsInventoryVo; | ||||||
|  |         }).toList(); | ||||||
|  |         materialsInventoryVoPage.setRecords(materialsInventoryVoList); | ||||||
|  |         return materialsInventoryVoPage; | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -0,0 +1,248 @@ | |||||||
|  | package org.dromara.materials.service.impl; | ||||||
|  |  | ||||||
|  | import cn.hutool.core.collection.CollUtil; | ||||||
|  | import cn.hutool.core.util.StrUtil; | ||||||
|  | import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | ||||||
|  | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||||
|  | import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | ||||||
|  | import jakarta.annotation.Resource; | ||||||
|  | import lombok.RequiredArgsConstructor; | ||||||
|  | import org.dromara.common.core.constant.CommonConstant; | ||||||
|  | import org.dromara.common.core.constant.HttpStatus; | ||||||
|  | import org.dromara.common.core.exception.ServiceException; | ||||||
|  | import org.dromara.common.core.utils.ObjectUtils; | ||||||
|  | import org.dromara.common.core.utils.StringUtils; | ||||||
|  | import org.dromara.common.core.utils.sql.SqlUtil; | ||||||
|  | import org.dromara.materials.domain.BusMaterials; | ||||||
|  | import org.dromara.materials.domain.req.materials.MaterialsCreateReq; | ||||||
|  | import org.dromara.materials.domain.req.materials.MaterialsQueryReq; | ||||||
|  | import org.dromara.materials.domain.req.materials.MaterialsUpdateReq; | ||||||
|  | import org.dromara.materials.domain.vo.BusMaterialsVo; | ||||||
|  | import org.dromara.materials.mapper.BusMaterialsMapper; | ||||||
|  | import org.dromara.materials.service.IBusCompanyService; | ||||||
|  | import org.dromara.materials.service.IBusMaterialsService; | ||||||
|  | import org.springframework.beans.BeanUtils; | ||||||
|  | import org.springframework.stereotype.Service; | ||||||
|  |  | ||||||
|  | import java.util.Collection; | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 材料名称Service业务层处理 | ||||||
|  |  * | ||||||
|  |  * @author lcj | ||||||
|  |  * @date 2025-03-06 | ||||||
|  |  */ | ||||||
|  | @RequiredArgsConstructor | ||||||
|  | @Service | ||||||
|  | public class BusMaterialsServiceImpl extends ServiceImpl<BusMaterialsMapper, BusMaterials> | ||||||
|  |     implements IBusMaterialsService { | ||||||
|  |  | ||||||
|  |     @Resource | ||||||
|  |     private BusMaterialsMapper baseMapper; | ||||||
|  |  | ||||||
|  |     @Resource | ||||||
|  |     private IBusCompanyService companyService; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 查询材料名称 | ||||||
|  |      * | ||||||
|  |      * @param id 主键 | ||||||
|  |      * @return 材料名称 | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public BusMaterialsVo queryById(Long id) { | ||||||
|  |         return baseMapper.selectVoById(id); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 分页查询材料名称列表 | ||||||
|  |      * | ||||||
|  |      * @param req 查询条件 | ||||||
|  |      * @return 材料名称分页列表 | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public Page<BusMaterialsVo> queryPageList(MaterialsQueryReq req) { | ||||||
|  |         long current = req.getCurrent(); | ||||||
|  |         long size = req.getPageSize(); | ||||||
|  |         // 查询数据库 | ||||||
|  |         Page<BusMaterials> result = this.page(new Page<>(current, size), this.getQueryWrapper(req)); | ||||||
|  |         return this.getMaterialsVoPage(result); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 查询符合条件的材料名称列表 | ||||||
|  |      * | ||||||
|  |      * @param req 查询条件 | ||||||
|  |      * @return 材料名称列表 | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public List<BusMaterialsVo> queryList(MaterialsQueryReq req) { | ||||||
|  |         QueryWrapper<BusMaterials> queryWrapper = this.getQueryWrapper(req); | ||||||
|  |         return baseMapper.selectVoList(queryWrapper); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 新增材料名称 | ||||||
|  |      * | ||||||
|  |      * @param req 材料名称 | ||||||
|  |      * @return 新增材料信息id | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public Long insertByBo(MaterialsCreateReq req) { | ||||||
|  |         // 将实体类和 DTO 进行转换 | ||||||
|  |         BusMaterials materials = new BusMaterials(); | ||||||
|  |         BeanUtils.copyProperties(req, materials); | ||||||
|  |         // 数据校验 | ||||||
|  |         validEntityBeforeSave(materials); | ||||||
|  |         // 写入数据库 | ||||||
|  |         boolean save = this.save(materials); | ||||||
|  |         if (!save) { | ||||||
|  |             throw new ServiceException("新增材料信息失败,数据库异常", HttpStatus.ERROR); | ||||||
|  |         } | ||||||
|  |         // 返回新写入的数据 | ||||||
|  |         return materials.getId(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 修改材料名称 | ||||||
|  |      * | ||||||
|  |      * @param req 材料名称 | ||||||
|  |      * @return 是否修改成功 | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public Boolean updateByBo(MaterialsUpdateReq req) { | ||||||
|  |         // 将实体类和 DTO 进行转换 | ||||||
|  |         BusMaterials materials = new BusMaterials(); | ||||||
|  |         BeanUtils.copyProperties(req, materials); | ||||||
|  |         // 数据校验 | ||||||
|  |         validEntityBeforeSave(materials); | ||||||
|  |         // 判断是否存在 | ||||||
|  |         BusMaterials oldMaterials = this.getById(materials.getId()); | ||||||
|  |         if (oldMaterials == null) { | ||||||
|  |             throw new ServiceException("修改材料信息失败,数据不存在", HttpStatus.NOT_FOUND); | ||||||
|  |         } | ||||||
|  |         // 操作数据库 | ||||||
|  |         return this.updateById(materials); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 保存前的数据校验 | ||||||
|  |      */ | ||||||
|  |     private void validEntityBeforeSave(BusMaterials entity) { | ||||||
|  |         // TODO 做一些数据校验,如唯一约束 | ||||||
|  |         String materialsName = entity.getMaterialsName(); | ||||||
|  |         Long companyId = entity.getCompanyId(); | ||||||
|  |         Long projectId = entity.getProjectId(); | ||||||
|  |         if (StringUtils.isEmpty(materialsName)) { | ||||||
|  |             throw new ServiceException("请填写材料名称", HttpStatus.BAD_REQUEST); | ||||||
|  |         } | ||||||
|  |         if (companyId == null) { | ||||||
|  |             throw new ServiceException("请填写公司ID", HttpStatus.BAD_REQUEST); | ||||||
|  |         } | ||||||
|  |         if (projectId == null) { | ||||||
|  |             throw new ServiceException("请填写项目ID", HttpStatus.BAD_REQUEST); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 校验并批量删除材料名称信息 | ||||||
|  |      * | ||||||
|  |      * @param ids     待删除的主键集合 | ||||||
|  |      * @param isValid 是否进行有效性校验 | ||||||
|  |      * @return 是否删除成功 | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid) { | ||||||
|  |         if (isValid) { | ||||||
|  |             //TODO 做一些业务上的校验,判断是否需要校验 | ||||||
|  |         } | ||||||
|  |         return baseMapper.deleteByIds(ids) > 0; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 获取材料视图 | ||||||
|  |      * | ||||||
|  |      * @param Materials 材料 | ||||||
|  |      * @return 材料视图 | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public BusMaterialsVo getBusMaterialsVo(BusMaterials Materials) { | ||||||
|  |         // 对象转封装类 | ||||||
|  |         BusMaterialsVo materialsVo = new BusMaterialsVo(); | ||||||
|  |         if (Materials == null) { | ||||||
|  |             return materialsVo; | ||||||
|  |         } | ||||||
|  |         BeanUtils.copyProperties(Materials, materialsVo); | ||||||
|  |         // 关联查询项目信息 | ||||||
|  |         Long companyId = Materials.getCompanyId(); | ||||||
|  |         if (companyId != null) { | ||||||
|  |             materialsVo.setCompanyVo(companyService.queryById(companyId)); | ||||||
|  |         } | ||||||
|  |         return materialsVo; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 构建查询条件封装 | ||||||
|  |      * | ||||||
|  |      * @param req 查询条件 | ||||||
|  |      * @return 查询条件封装 | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public QueryWrapper<BusMaterials> getQueryWrapper(MaterialsQueryReq req) { | ||||||
|  |         QueryWrapper<BusMaterials> queryWrapper = new QueryWrapper<>(); | ||||||
|  |         if (req == null) { | ||||||
|  |             return queryWrapper; | ||||||
|  |         } | ||||||
|  |         // 从对象中取值 | ||||||
|  |         Long id = req.getId(); | ||||||
|  |         String materialsName = req.getMaterialsName(); | ||||||
|  |         Long companyId = req.getCompanyId(); | ||||||
|  |         Long projectId = req.getProjectId(); | ||||||
|  |         String usePart = req.getUsePart(); | ||||||
|  |         String weightId = req.getWeightId(); | ||||||
|  |         String remark = req.getRemark(); | ||||||
|  |         String quantityCount = req.getQuantityCount(); | ||||||
|  |         String status = req.getStatus(); | ||||||
|  |         String sortField = req.getSortField(); | ||||||
|  |         String sortOrder = req.getSortOrder(); | ||||||
|  |         String underlineSortField = StrUtil.toUnderlineCase(sortField); | ||||||
|  |         // 模糊查询 | ||||||
|  |         queryWrapper.like(StringUtils.isNotBlank(materialsName), "materials_name", materialsName); | ||||||
|  |         queryWrapper.like(StringUtils.isNotBlank(usePart), "use_part", usePart); | ||||||
|  |         queryWrapper.like(StringUtils.isNotBlank(remark), "remark", remark); | ||||||
|  |         queryWrapper.like(StringUtils.isNotBlank(weightId), "weight_id", weightId); | ||||||
|  |         queryWrapper.like(StringUtils.isNotBlank(quantityCount), "quantity_count", quantityCount); | ||||||
|  |         // 精确查询 | ||||||
|  |         queryWrapper.eq(ObjectUtils.isNotEmpty(status), "status", status); | ||||||
|  |         queryWrapper.eq(ObjectUtils.isNotEmpty(id), "id", id); | ||||||
|  |         queryWrapper.eq(ObjectUtils.isNotEmpty(projectId), "project_id", projectId); | ||||||
|  |         queryWrapper.eq(ObjectUtils.isNotEmpty(companyId), "company_id", companyId); | ||||||
|  |         // 排序规则 | ||||||
|  |         queryWrapper.orderBy(SqlUtil.validSortField(sortField), | ||||||
|  |             sortOrder.equals(CommonConstant.SORT_ORDER_ASC), | ||||||
|  |             underlineSortField); | ||||||
|  |         return queryWrapper; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 获取材料分页对象视图 | ||||||
|  |      * | ||||||
|  |      * @param materialsPage 材料分页对象 | ||||||
|  |      * @return 材料分页对象视图 | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public Page<BusMaterialsVo> getMaterialsVoPage(Page<BusMaterials> materialsPage) { | ||||||
|  |         // 获取材料数据 | ||||||
|  |         List<BusMaterials> materialsList = materialsPage.getRecords(); | ||||||
|  |         // 添加分页信息 | ||||||
|  |         Page<BusMaterialsVo> materialsVoPage = new Page<>(materialsPage.getCurrent(), materialsPage.getSize(), materialsPage.getTotal()); | ||||||
|  |         if (CollUtil.isEmpty(materialsList)) { | ||||||
|  |             return materialsVoPage; | ||||||
|  |         } | ||||||
|  |         // 对象列表 => 封装对象列表 | ||||||
|  |         List<BusMaterialsVo> materialsVoList = materialsList.stream().map(this::getBusMaterialsVo).toList(); | ||||||
|  |         materialsVoPage.setRecords(materialsVoList); | ||||||
|  |         return materialsVoPage; | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -16,7 +16,6 @@ import org.dromara.common.idempotent.annotation.RepeatSubmit; | |||||||
| import org.dromara.common.log.annotation.Log; | import org.dromara.common.log.annotation.Log; | ||||||
| import org.dromara.common.log.enums.BusinessType; | import org.dromara.common.log.enums.BusinessType; | ||||||
| import org.dromara.common.web.core.BaseController; | import org.dromara.common.web.core.BaseController; | ||||||
| import org.dromara.project.domain.bo.ProjectBo; |  | ||||||
| import org.dromara.project.domain.req.project.ProjectCreateReq; | import org.dromara.project.domain.req.project.ProjectCreateReq; | ||||||
| import org.dromara.project.domain.req.project.ProjectQueryReq; | import org.dromara.project.domain.req.project.ProjectQueryReq; | ||||||
| import org.dromara.project.domain.req.project.ProjectUpdateReq; | import org.dromara.project.domain.req.project.ProjectUpdateReq; | ||||||
| @ -56,8 +55,8 @@ public class ProjectController extends BaseController { | |||||||
|     @SaCheckPermission("project:project:export") |     @SaCheckPermission("project:project:export") | ||||||
|     @Log(title = "项目", businessType = BusinessType.EXPORT) |     @Log(title = "项目", businessType = BusinessType.EXPORT) | ||||||
|     @PostMapping("/export") |     @PostMapping("/export") | ||||||
|     public void export(ProjectBo bo, HttpServletResponse response) { |     public void export(ProjectQueryReq req, HttpServletResponse response) { | ||||||
|         List<ProjectVo> list = projectService.queryList(bo); |         List<ProjectVo> list = projectService.queryList(req); | ||||||
|         ExcelUtil.exportExcel(list, "项目", ProjectVo.class, response); |         ExcelUtil.exportExcel(list, "项目", ProjectVo.class, response); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  | |||||||
| @ -1,6 +1,7 @@ | |||||||
| package org.dromara.project.controller; | package org.dromara.project.controller; | ||||||
|  |  | ||||||
| import cn.dev33.satoken.annotation.SaCheckPermission; | import cn.dev33.satoken.annotation.SaCheckPermission; | ||||||
|  | import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | ||||||
| import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||||
| import io.swagger.v3.oas.annotations.tags.Tag; | import io.swagger.v3.oas.annotations.tags.Tag; | ||||||
| import jakarta.servlet.http.HttpServletResponse; | import jakarta.servlet.http.HttpServletResponse; | ||||||
| @ -14,12 +15,10 @@ import org.dromara.common.excel.utils.ExcelUtil; | |||||||
| import org.dromara.common.idempotent.annotation.RepeatSubmit; | import org.dromara.common.idempotent.annotation.RepeatSubmit; | ||||||
| import org.dromara.common.log.annotation.Log; | import org.dromara.common.log.annotation.Log; | ||||||
| import org.dromara.common.log.enums.BusinessType; | import org.dromara.common.log.enums.BusinessType; | ||||||
| import org.dromara.common.mybatis.core.page.PageQuery; |  | ||||||
| import org.dromara.common.mybatis.core.page.TableDataInfo; | import org.dromara.common.mybatis.core.page.TableDataInfo; | ||||||
| import org.dromara.common.satoken.utils.LoginHelper; | import org.dromara.common.satoken.utils.LoginHelper; | ||||||
| import org.dromara.common.web.core.BaseController; | import org.dromara.common.web.core.BaseController; | ||||||
| import org.dromara.project.domain.UserProjectRelevancy; | import org.dromara.project.domain.UserProjectRelevancy; | ||||||
| import org.dromara.project.domain.bo.UserProjectRelevancyBo; |  | ||||||
| import org.dromara.project.domain.req.project.ProjectBatchByProjectListReq; | import org.dromara.project.domain.req.project.ProjectBatchByProjectListReq; | ||||||
| import org.dromara.project.domain.req.userprojectrelevancy.UserProjectRelevancyCreateReq; | import org.dromara.project.domain.req.userprojectrelevancy.UserProjectRelevancyCreateReq; | ||||||
| import org.dromara.project.domain.req.userprojectrelevancy.UserProjectRelevancyQueryReq; | import org.dromara.project.domain.req.userprojectrelevancy.UserProjectRelevancyQueryReq; | ||||||
| @ -30,7 +29,6 @@ import org.dromara.project.service.IUserProjectRelevancyService; | |||||||
| import org.springframework.validation.annotation.Validated; | import org.springframework.validation.annotation.Validated; | ||||||
| import org.springframework.web.bind.annotation.*; | import org.springframework.web.bind.annotation.*; | ||||||
|  |  | ||||||
| import java.util.Arrays; |  | ||||||
| import java.util.List; | import java.util.List; | ||||||
|  |  | ||||||
| /** | /** | ||||||
| @ -53,8 +51,8 @@ public class UserProjectRelevancyController extends BaseController { | |||||||
|     @Tag(name = "查询用户与项目关联列表") |     @Tag(name = "查询用户与项目关联列表") | ||||||
|     @SaCheckPermission("project:projectRelevancy:list") |     @SaCheckPermission("project:projectRelevancy:list") | ||||||
|     @GetMapping("/list") |     @GetMapping("/list") | ||||||
|     public TableDataInfo<UserProjectRelevancyVo> list(UserProjectRelevancyBo bo, PageQuery pageQuery) { |     public Page<UserProjectRelevancyVo> list(UserProjectRelevancyQueryReq req) { | ||||||
|         return userProjectRelevancyService.queryPageList(bo, pageQuery); |         return userProjectRelevancyService.queryPageList(req); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
| @ -86,8 +84,8 @@ public class UserProjectRelevancyController extends BaseController { | |||||||
|     @SaCheckPermission("project:projectRelevancy:export") |     @SaCheckPermission("project:projectRelevancy:export") | ||||||
|     @Log(title = "系统用户与项目关联", businessType = BusinessType.EXPORT) |     @Log(title = "系统用户与项目关联", businessType = BusinessType.EXPORT) | ||||||
|     @PostMapping("/export") |     @PostMapping("/export") | ||||||
|     public void export(UserProjectRelevancyBo bo, HttpServletResponse response) { |     public void export(UserProjectRelevancyQueryReq req, HttpServletResponse response) { | ||||||
|         List<UserProjectRelevancyVo> list = userProjectRelevancyService.queryList(bo); |         List<UserProjectRelevancyVo> list = userProjectRelevancyService.queryList(req); | ||||||
|         ExcelUtil.exportExcel(list, "系统用户与项目关联", UserProjectRelevancyVo.class, response); |         ExcelUtil.exportExcel(list, "系统用户与项目关联", UserProjectRelevancyVo.class, response); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @ -140,13 +138,16 @@ public class UserProjectRelevancyController extends BaseController { | |||||||
|     public R<Boolean> removeBatchByProjectList(@RequestBody ProjectBatchByProjectListReq req) { |     public R<Boolean> removeBatchByProjectList(@RequestBody ProjectBatchByProjectListReq req) { | ||||||
|         Long userId = req.getUserId(); |         Long userId = req.getUserId(); | ||||||
|         Long[] projectIdList = req.getProjectIdList(); |         Long[] projectIdList = req.getProjectIdList(); | ||||||
|         List<UserProjectRelevancy> userProjectRelevancyList = Arrays.stream(projectIdList).map(projectId -> { |         QueryWrapper<UserProjectRelevancy> wrapper = new QueryWrapper<>(); | ||||||
|  |         wrapper.eq("user_id", userId).in("project_id", (Object[]) projectIdList); | ||||||
|  |         boolean result = userProjectRelevancyService.remove(wrapper); | ||||||
|  | /*        List<UserProjectRelevancy> userProjectRelevancyList = Arrays.stream(projectIdList).map(projectId -> { | ||||||
|             UserProjectRelevancy userProjectRelevancy = new UserProjectRelevancy(); |             UserProjectRelevancy userProjectRelevancy = new UserProjectRelevancy(); | ||||||
|             userProjectRelevancy.setUserId(userId); |             userProjectRelevancy.setUserId(userId); | ||||||
|             userProjectRelevancy.setProjectId(projectId); |             userProjectRelevancy.setProjectId(projectId); | ||||||
|             return userProjectRelevancy; |             return userProjectRelevancy; | ||||||
|         }).toList(); |         }).toList(); | ||||||
|         boolean result = userProjectRelevancyService.removeBatchByIds(userProjectRelevancyList); |         boolean result = userProjectRelevancyService.removeBatchByIds(userProjectRelevancyList);*/ | ||||||
|         return R.ok(result); |         return R.ok(result); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  | |||||||
| @ -1,141 +0,0 @@ | |||||||
| package org.dromara.project.domain.bo; |  | ||||||
|  |  | ||||||
| import org.dromara.project.domain.Project; |  | ||||||
| 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.*; |  | ||||||
| import java.util.Date; |  | ||||||
| import com.fasterxml.jackson.annotation.JsonFormat; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * 项目业务对象 project |  | ||||||
|  * |  | ||||||
|  * @author lcj |  | ||||||
|  * @date 2025-03-04 |  | ||||||
|  */ |  | ||||||
| @Data |  | ||||||
| @EqualsAndHashCode(callSuper = true) |  | ||||||
| @AutoMapper(target = Project.class, reverseConvertGenerate = false) |  | ||||||
| public class ProjectBo extends BaseEntity { |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 项目id |  | ||||||
|      */ |  | ||||||
|     @NotNull(message = "不能为空", groups = { EditGroup.class }) |  | ||||||
|     private Long id; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 项目名称 |  | ||||||
|      */ |  | ||||||
|     private String projectName; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 项目简称 |  | ||||||
|      */ |  | ||||||
|     private String shortName; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 父项目id |  | ||||||
|      */ |  | ||||||
|     private Long pId; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 状态(0正常 1停用) |  | ||||||
|      */ |  | ||||||
|     private Long status; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 项目图片 |  | ||||||
|      */ |  | ||||||
|     private String picUrl; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 备注 |  | ||||||
|      */ |  | ||||||
|     private String remark; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 项目类型 |  | ||||||
|      */ |  | ||||||
|     private String type; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 项目类型(1光伏 2风电) |  | ||||||
|      */ |  | ||||||
|     private Long isType; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 删除时间 |  | ||||||
|      */ |  | ||||||
|     private Date deletedAt; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 项目地址 |  | ||||||
|      */ |  | ||||||
|     private String projectSite; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 负责人 |  | ||||||
|      */ |  | ||||||
|     private String principal; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 负责人电话 |  | ||||||
|      */ |  | ||||||
|     private String principalPhone; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 实际容量 |  | ||||||
|      */ |  | ||||||
|     private String actual; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 计划容量 |  | ||||||
|      */ |  | ||||||
|     private String plan; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 开工时间 |  | ||||||
|      */ |  | ||||||
|     private String onStreamTime; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 打卡范围(09:00,18:00) |  | ||||||
|      */ |  | ||||||
|     @NotBlank(message = "打卡范围(09:00,18:00)不能为空", groups = { AddGroup.class, EditGroup.class }) |  | ||||||
|     private String punchRange; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 设计总量 |  | ||||||
|      */ |  | ||||||
|     @NotNull(message = "设计总量不能为空", groups = { AddGroup.class, EditGroup.class }) |  | ||||||
|     private Long designTotal; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 安全协议书 |  | ||||||
|      */ |  | ||||||
|     private String securityAgreement; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 排序字段 |  | ||||||
|      */ |  | ||||||
|     @NotNull(message = "排序字段不能为空", groups = { AddGroup.class, EditGroup.class }) |  | ||||||
|     private Long sort; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 显示隐藏(0显示 1隐藏) |  | ||||||
|      */ |  | ||||||
|     private Long showHidden; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 是否删除(0正常 1删除) |  | ||||||
|      */ |  | ||||||
|     @NotNull(message = "是否删除(0正常 1删除)不能为空", groups = { EditGroup.class }) |  | ||||||
|     private Long isDelete; |  | ||||||
|  |  | ||||||
|  |  | ||||||
| } |  | ||||||
| @ -1,49 +0,0 @@ | |||||||
| package org.dromara.project.domain.bo; |  | ||||||
|  |  | ||||||
| import org.dromara.project.domain.UserProjectRelevancy; |  | ||||||
| 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.*; |  | ||||||
| import java.util.Date; |  | ||||||
| import com.fasterxml.jackson.annotation.JsonFormat; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * 系统用户与项目关联业务对象 user_project_relevancy |  | ||||||
|  * |  | ||||||
|  * @author lcj |  | ||||||
|  * @date 2025-03-04 |  | ||||||
|  */ |  | ||||||
| @Data |  | ||||||
| @EqualsAndHashCode(callSuper = true) |  | ||||||
| @AutoMapper(target = UserProjectRelevancy.class, reverseConvertGenerate = false) |  | ||||||
| public class UserProjectRelevancyBo extends BaseEntity { |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 主键ID |  | ||||||
|      */ |  | ||||||
|     @NotNull(message = "主键ID不能为空", groups = { EditGroup.class }) |  | ||||||
|     private Long id; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 用户ID |  | ||||||
|      */ |  | ||||||
|     @NotNull(message = "用户ID不能为空", groups = { AddGroup.class, EditGroup.class }) |  | ||||||
|     private Long userId; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 项目ID |  | ||||||
|      */ |  | ||||||
|     @NotNull(message = "项目ID不能为空", groups = { AddGroup.class, EditGroup.class }) |  | ||||||
|     private Long projectId; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 删除时间 |  | ||||||
|      */ |  | ||||||
|     private Date deletedAt; |  | ||||||
|  |  | ||||||
|  |  | ||||||
| } |  | ||||||
| @ -3,10 +3,7 @@ package org.dromara.project.service; | |||||||
| import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | ||||||
| import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||||
| import com.baomidou.mybatisplus.extension.service.IService; | import com.baomidou.mybatisplus.extension.service.IService; | ||||||
| import org.dromara.common.mybatis.core.page.PageQuery; |  | ||||||
| import org.dromara.common.mybatis.core.page.TableDataInfo; |  | ||||||
| import org.dromara.project.domain.Project; | import org.dromara.project.domain.Project; | ||||||
| import org.dromara.project.domain.bo.ProjectBo; |  | ||||||
| import org.dromara.project.domain.req.project.ProjectCreateReq; | import org.dromara.project.domain.req.project.ProjectCreateReq; | ||||||
| import org.dromara.project.domain.req.project.ProjectQueryReq; | import org.dromara.project.domain.req.project.ProjectQueryReq; | ||||||
| import org.dromara.project.domain.req.project.ProjectUpdateReq; | import org.dromara.project.domain.req.project.ProjectUpdateReq; | ||||||
| @ -58,10 +55,10 @@ public interface IProjectService extends IService<Project> { | |||||||
|     /** |     /** | ||||||
|      * 查询符合条件的项目列表 |      * 查询符合条件的项目列表 | ||||||
|      * |      * | ||||||
|      * @param bo 查询条件 |      * @param req 查询条件 | ||||||
|      * @return 项目列表 |      * @return 项目列表 | ||||||
|      */ |      */ | ||||||
|     List<ProjectVo> queryList(ProjectBo bo); |     List<ProjectVo> queryList(ProjectQueryReq req); | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 获取项目分页对象视图 |      * 获取项目分页对象视图 | ||||||
|  | |||||||
| @ -3,10 +3,7 @@ package org.dromara.project.service; | |||||||
| import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | ||||||
| import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||||
| import com.baomidou.mybatisplus.extension.service.IService; | import com.baomidou.mybatisplus.extension.service.IService; | ||||||
| import org.dromara.common.mybatis.core.page.PageQuery; |  | ||||||
| import org.dromara.common.mybatis.core.page.TableDataInfo; |  | ||||||
| import org.dromara.project.domain.UserProjectRelevancy; | import org.dromara.project.domain.UserProjectRelevancy; | ||||||
| import org.dromara.project.domain.bo.UserProjectRelevancyBo; |  | ||||||
| import org.dromara.project.domain.req.project.ProjectBatchByProjectListReq; | import org.dromara.project.domain.req.project.ProjectBatchByProjectListReq; | ||||||
| import org.dromara.project.domain.req.userprojectrelevancy.UserProjectRelevancyCreateReq; | import org.dromara.project.domain.req.userprojectrelevancy.UserProjectRelevancyCreateReq; | ||||||
| import org.dromara.project.domain.req.userprojectrelevancy.UserProjectRelevancyQueryReq; | import org.dromara.project.domain.req.userprojectrelevancy.UserProjectRelevancyQueryReq; | ||||||
| @ -52,19 +49,18 @@ public interface IUserProjectRelevancyService extends IService<UserProjectReleva | |||||||
|     /** |     /** | ||||||
|      * 分页查询系统用户与项目关联列表 |      * 分页查询系统用户与项目关联列表 | ||||||
|      * |      * | ||||||
|      * @param bo        查询条件 |      * @param req 查询条件 | ||||||
|      * @param pageQuery 分页参数 |  | ||||||
|      * @return 系统用户与项目关联分页列表 |      * @return 系统用户与项目关联分页列表 | ||||||
|      */ |      */ | ||||||
|     TableDataInfo<UserProjectRelevancyVo> queryPageList(UserProjectRelevancyBo bo, PageQuery pageQuery); |     Page<UserProjectRelevancyVo> queryPageList(UserProjectRelevancyQueryReq req); | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 查询符合条件的系统用户与项目关联列表 |      * 查询符合条件的系统用户与项目关联列表 | ||||||
|      * |      * | ||||||
|      * @param bo 查询条件 |      * @param req 查询条件 | ||||||
|      * @return 系统用户与项目关联列表 |      * @return 系统用户与项目关联列表 | ||||||
|      */ |      */ | ||||||
|     List<UserProjectRelevancyVo> queryList(UserProjectRelevancyBo bo); |     List<UserProjectRelevancyVo> queryList(UserProjectRelevancyQueryReq req); | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 新增系统用户与项目关联 |      * 新增系统用户与项目关联 | ||||||
|  | |||||||
| @ -2,9 +2,7 @@ package org.dromara.project.service.impl; | |||||||
|  |  | ||||||
| import cn.hutool.core.collection.CollUtil; | import cn.hutool.core.collection.CollUtil; | ||||||
| import cn.hutool.core.util.StrUtil; | import cn.hutool.core.util.StrUtil; | ||||||
| import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; |  | ||||||
| import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | ||||||
| import com.baomidou.mybatisplus.core.toolkit.Wrappers; |  | ||||||
| import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||||
| import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | ||||||
| import jakarta.annotation.Resource; | import jakarta.annotation.Resource; | ||||||
| @ -17,7 +15,6 @@ import org.dromara.common.core.utils.sql.SqlUtil; | |||||||
| import org.dromara.common.satoken.utils.LoginHelper; | import org.dromara.common.satoken.utils.LoginHelper; | ||||||
| import org.dromara.project.domain.Project; | import org.dromara.project.domain.Project; | ||||||
| import org.dromara.project.domain.UserProjectRelevancy; | import org.dromara.project.domain.UserProjectRelevancy; | ||||||
| import org.dromara.project.domain.bo.ProjectBo; |  | ||||||
| import org.dromara.project.domain.req.project.ProjectCreateReq; | import org.dromara.project.domain.req.project.ProjectCreateReq; | ||||||
| import org.dromara.project.domain.req.project.ProjectQueryReq; | import org.dromara.project.domain.req.project.ProjectQueryReq; | ||||||
| import org.dromara.project.domain.req.project.ProjectUpdateReq; | import org.dromara.project.domain.req.project.ProjectUpdateReq; | ||||||
| @ -25,7 +22,6 @@ import org.dromara.project.domain.vo.ProjectVo; | |||||||
| import org.dromara.project.mapper.ProjectMapper; | import org.dromara.project.mapper.ProjectMapper; | ||||||
| import org.dromara.project.service.IProjectService; | import org.dromara.project.service.IProjectService; | ||||||
| import org.dromara.project.service.IUserProjectRelevancyService; | import org.dromara.project.service.IUserProjectRelevancyService; | ||||||
| import org.dromara.system.service.ISysUserService; |  | ||||||
| import org.springframework.beans.BeanUtils; | import org.springframework.beans.BeanUtils; | ||||||
| import org.springframework.context.annotation.Lazy; | import org.springframework.context.annotation.Lazy; | ||||||
| import org.springframework.stereotype.Service; | import org.springframework.stereotype.Service; | ||||||
| @ -46,9 +42,6 @@ public class ProjectServiceImpl extends ServiceImpl<ProjectMapper, Project> | |||||||
|     @Resource |     @Resource | ||||||
|     private ProjectMapper baseMapper; |     private ProjectMapper baseMapper; | ||||||
|  |  | ||||||
|     @Resource |  | ||||||
|     private ISysUserService userService; |  | ||||||
|  |  | ||||||
|     @Lazy |     @Lazy | ||||||
|     @Resource |     @Resource | ||||||
|     private IUserProjectRelevancyService userProjectRelevancyService; |     private IUserProjectRelevancyService userProjectRelevancyService; | ||||||
| @ -152,13 +145,13 @@ public class ProjectServiceImpl extends ServiceImpl<ProjectMapper, Project> | |||||||
|     /** |     /** | ||||||
|      * 查询符合条件的项目列表 |      * 查询符合条件的项目列表 | ||||||
|      * |      * | ||||||
|      * @param bo 查询条件 |      * @param req 查询条件 | ||||||
|      * @return 项目列表 |      * @return 项目列表 | ||||||
|      */ |      */ | ||||||
|     @Override |     @Override | ||||||
|     public List<ProjectVo> queryList(ProjectBo bo) { |     public List<ProjectVo> queryList(ProjectQueryReq req) { | ||||||
|         LambdaQueryWrapper<Project> lqw = buildQueryWrapper(bo); |         QueryWrapper<Project> queryWrapper = this.getQueryWrapper(req); | ||||||
|         return baseMapper.selectVoList(lqw); |         return baseMapper.selectVoList(queryWrapper); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
| @ -174,31 +167,6 @@ public class ProjectServiceImpl extends ServiceImpl<ProjectMapper, Project> | |||||||
|         return projectVoPage; |         return projectVoPage; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private LambdaQueryWrapper<Project> buildQueryWrapper(ProjectBo bo) { |  | ||||||
|         LambdaQueryWrapper<Project> lqw = Wrappers.lambdaQuery(); |  | ||||||
|         lqw.orderByAsc(Project::getId); |  | ||||||
|         lqw.like(StringUtils.isNotBlank(bo.getProjectName()), Project::getProjectName, bo.getProjectName()); |  | ||||||
|         lqw.like(StringUtils.isNotBlank(bo.getShortName()), Project::getShortName, bo.getShortName()); |  | ||||||
|         lqw.eq(bo.getPId() != null, Project::getPId, bo.getPId()); |  | ||||||
|         lqw.eq(bo.getStatus() != null, Project::getStatus, bo.getStatus()); |  | ||||||
|         lqw.eq(StringUtils.isNotBlank(bo.getPicUrl()), Project::getPicUrl, bo.getPicUrl()); |  | ||||||
|         lqw.eq(StringUtils.isNotBlank(bo.getType()), Project::getType, bo.getType()); |  | ||||||
|         lqw.eq(bo.getIsType() != null, Project::getIsType, bo.getIsType()); |  | ||||||
|         lqw.eq(bo.getDeletedAt() != null, Project::getDeletedAt, bo.getDeletedAt()); |  | ||||||
|         lqw.eq(StringUtils.isNotBlank(bo.getProjectSite()), Project::getProjectSite, bo.getProjectSite()); |  | ||||||
|         lqw.eq(StringUtils.isNotBlank(bo.getPrincipal()), Project::getPrincipal, bo.getPrincipal()); |  | ||||||
|         lqw.eq(StringUtils.isNotBlank(bo.getPrincipalPhone()), Project::getPrincipalPhone, bo.getPrincipalPhone()); |  | ||||||
|         lqw.eq(StringUtils.isNotBlank(bo.getActual()), Project::getActual, bo.getActual()); |  | ||||||
|         lqw.eq(StringUtils.isNotBlank(bo.getPlan()), Project::getPlan, bo.getPlan()); |  | ||||||
|         lqw.eq(StringUtils.isNotBlank(bo.getOnStreamTime()), Project::getOnStreamTime, bo.getOnStreamTime()); |  | ||||||
|         lqw.eq(StringUtils.isNotBlank(bo.getPunchRange()), Project::getPunchRange, bo.getPunchRange()); |  | ||||||
|         lqw.eq(bo.getDesignTotal() != null, Project::getDesignTotal, bo.getDesignTotal()); |  | ||||||
|         lqw.eq(StringUtils.isNotBlank(bo.getSecurityAgreement()), Project::getSecurityAgreement, bo.getSecurityAgreement()); |  | ||||||
|         lqw.eq(bo.getSort() != null, Project::getSort, bo.getSort()); |  | ||||||
|         lqw.eq(bo.getShowHidden() != null, Project::getShowHidden, bo.getShowHidden()); |  | ||||||
|         return lqw; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 新增项目 |      * 新增项目 | ||||||
|      * |      * | ||||||
|  | |||||||
| @ -13,12 +13,8 @@ import org.dromara.common.core.constant.HttpStatus; | |||||||
| import org.dromara.common.core.exception.ServiceException; | import org.dromara.common.core.exception.ServiceException; | ||||||
| import org.dromara.common.core.utils.ObjectUtils; | import org.dromara.common.core.utils.ObjectUtils; | ||||||
| import org.dromara.common.core.utils.sql.SqlUtil; | import org.dromara.common.core.utils.sql.SqlUtil; | ||||||
| import org.dromara.common.mybatis.core.page.PageQuery; |  | ||||||
| import org.dromara.common.mybatis.core.page.TableDataInfo; |  | ||||||
| import org.dromara.common.satoken.utils.LoginHelper; |  | ||||||
| import org.dromara.project.domain.Project; | import org.dromara.project.domain.Project; | ||||||
| import org.dromara.project.domain.UserProjectRelevancy; | import org.dromara.project.domain.UserProjectRelevancy; | ||||||
| import org.dromara.project.domain.bo.UserProjectRelevancyBo; |  | ||||||
| import org.dromara.project.domain.req.project.ProjectBatchByProjectListReq; | import org.dromara.project.domain.req.project.ProjectBatchByProjectListReq; | ||||||
| import org.dromara.project.domain.req.userprojectrelevancy.UserProjectRelevancyCreateReq; | import org.dromara.project.domain.req.userprojectrelevancy.UserProjectRelevancyCreateReq; | ||||||
| import org.dromara.project.domain.req.userprojectrelevancy.UserProjectRelevancyQueryReq; | import org.dromara.project.domain.req.userprojectrelevancy.UserProjectRelevancyQueryReq; | ||||||
| @ -102,41 +98,29 @@ public class UserProjectRelevancyServiceImpl extends ServiceImpl<UserProjectRele | |||||||
|     /** |     /** | ||||||
|      * 分页查询系统用户与项目关联列表 |      * 分页查询系统用户与项目关联列表 | ||||||
|      * |      * | ||||||
|      * @param bo        查询条件 |      * @param req 查询条件 | ||||||
|      * @param pageQuery 分页参数 |  | ||||||
|      * @return 系统用户与项目关联分页列表 |      * @return 系统用户与项目关联分页列表 | ||||||
|      */ |      */ | ||||||
|     @Override |     @Override | ||||||
|     public TableDataInfo<UserProjectRelevancyVo> queryPageList(UserProjectRelevancyBo bo, PageQuery pageQuery) { |     public Page<UserProjectRelevancyVo> queryPageList(UserProjectRelevancyQueryReq req) { | ||||||
|         Page<UserProjectRelevancyVo> resultVo = pageQuery.build(); |         long current = req.getCurrent(); | ||||||
|         LambdaQueryWrapper<UserProjectRelevancy> lqw = buildQueryWrapper(bo); |         long size = req.getPageSize(); | ||||||
|         Page<UserProjectRelevancy> result = this.page(pageQuery.build(), lqw); |         QueryWrapper<UserProjectRelevancy> queryWrapper = this.getQueryWrapper(req); | ||||||
|         if (CollUtil.isEmpty(result.getRecords())) { |         // 查询数据库 | ||||||
|             return TableDataInfo.build(resultVo); |         Page<UserProjectRelevancy> result = this.page(new Page<>(current, size), this.getQueryWrapper(req)); | ||||||
|         } |         return this.getUserProjectRelevancyVoPage(result); | ||||||
|         List<UserProjectRelevancyVo> userProjectRelevancyVos = result.getRecords().stream().map(this::getUserProjectRelevancyVo).toList(); |  | ||||||
|         resultVo.setRecords(userProjectRelevancyVos); |  | ||||||
|         return TableDataInfo.build(resultVo); |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 查询符合条件的系统用户与项目关联列表 |      * 查询符合条件的系统用户与项目关联列表 | ||||||
|      * |      * | ||||||
|      * @param bo 查询条件 |      * @param req 查询条件 | ||||||
|      * @return 系统用户与项目关联列表 |      * @return 系统用户与项目关联列表 | ||||||
|      */ |      */ | ||||||
|     @Override |     @Override | ||||||
|     public List<UserProjectRelevancyVo> queryList(UserProjectRelevancyBo bo) { |     public List<UserProjectRelevancyVo> queryList(UserProjectRelevancyQueryReq req) { | ||||||
|         LambdaQueryWrapper<UserProjectRelevancy> lqw = buildQueryWrapper(bo); |         QueryWrapper<UserProjectRelevancy> queryWrapper = this.getQueryWrapper(req); | ||||||
|         return baseMapper.selectVoList(lqw); |         return baseMapper.selectVoList(queryWrapper); | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private LambdaQueryWrapper<UserProjectRelevancy> buildQueryWrapper(UserProjectRelevancyBo bo) { |  | ||||||
|         LambdaQueryWrapper<UserProjectRelevancy> lqw = Wrappers.lambdaQuery(); |  | ||||||
|         lqw.orderByAsc(UserProjectRelevancy::getId); |  | ||||||
|         lqw.eq(bo.getUserId() != null, UserProjectRelevancy::getUserId, bo.getUserId()); |  | ||||||
|         lqw.eq(bo.getProjectId() != null, UserProjectRelevancy::getProjectId, bo.getProjectId()); |  | ||||||
|         return lqw; |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
| @ -234,10 +218,7 @@ public class UserProjectRelevancyServiceImpl extends ServiceImpl<UserProjectRele | |||||||
|     public List<LoginUserProjectRelevancyResp> queryListByUserId(Long userId) { |     public List<LoginUserProjectRelevancyResp> queryListByUserId(Long userId) { | ||||||
|         // 添加查询条件,根据当前用户,获取数据 |         // 添加查询条件,根据当前用户,获取数据 | ||||||
|         LambdaQueryWrapper<UserProjectRelevancy> queryWrapper = Wrappers.lambdaQuery(); |         LambdaQueryWrapper<UserProjectRelevancy> queryWrapper = Wrappers.lambdaQuery(); | ||||||
|         // 如果是超级管理员查看所有 |         queryWrapper.eq(UserProjectRelevancy::getUserId, userId); | ||||||
|         if (!LoginHelper.isSuperAdmin()) { |  | ||||||
|             queryWrapper.eq(UserProjectRelevancy::getUserId, userId); |  | ||||||
|         } |  | ||||||
|         // 查询数据库,获取数据 |         // 查询数据库,获取数据 | ||||||
|         List<UserProjectRelevancy> list = this.list(queryWrapper); |         List<UserProjectRelevancy> list = this.list(queryWrapper); | ||||||
|         // 获取封装 |         // 获取封装 | ||||||
| @ -266,11 +247,8 @@ public class UserProjectRelevancyServiceImpl extends ServiceImpl<UserProjectRele | |||||||
|     public Page<UserProjectRelevancyVo> queryPageByUserId(Long userId, UserProjectRelevancyQueryReq req) { |     public Page<UserProjectRelevancyVo> queryPageByUserId(Long userId, UserProjectRelevancyQueryReq req) { | ||||||
|         long current = req.getCurrent(); |         long current = req.getCurrent(); | ||||||
|         long size = req.getPageSize(); |         long size = req.getPageSize(); | ||||||
|         // 如果是超级管理员查看所有 |         // 添加查询条件 | ||||||
|         if (!LoginHelper.isSuperAdmin()) { |         req.setUserId(userId); | ||||||
|             // 添加查询条件 |  | ||||||
|             req.setUserId(userId); |  | ||||||
|         } |  | ||||||
|         QueryWrapper<UserProjectRelevancy> queryWrapper = this.getQueryWrapper(req); |         QueryWrapper<UserProjectRelevancy> queryWrapper = this.getQueryWrapper(req); | ||||||
|         // 查询数据库 |         // 查询数据库 | ||||||
|         Page<UserProjectRelevancy> result = this.page(new Page<>(current, size), queryWrapper); |         Page<UserProjectRelevancy> result = this.page(new Page<>(current, size), queryWrapper); | ||||||
|  | |||||||
| @ -2,6 +2,6 @@ | |||||||
| <!DOCTYPE mapper | <!DOCTYPE mapper | ||||||
| PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" | PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" | ||||||
| "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> | "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> | ||||||
| <mapper namespace="org.dromara.demo.mapper.TestTreeMapper"> | <mapper namespace="org.dromara.materials.mapper.BusCompanyMapper"> | ||||||
| 
 | 
 | ||||||
| </mapper> | </mapper> | ||||||
| @ -0,0 +1,7 @@ | |||||||
|  | <?xml version="1.0" encoding="UTF-8" ?> | ||||||
|  | <!DOCTYPE mapper | ||||||
|  | PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" | ||||||
|  | "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> | ||||||
|  | <mapper namespace="org.dromara.materials.mapper.BusMaterialsInventoryMapper"> | ||||||
|  |  | ||||||
|  | </mapper> | ||||||
| @ -0,0 +1,7 @@ | |||||||
|  | <?xml version="1.0" encoding="UTF-8" ?> | ||||||
|  | <!DOCTYPE mapper | ||||||
|  | PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" | ||||||
|  | "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> | ||||||
|  | <mapper namespace="org.dromara.materials.mapper.BusMaterialsMapper"> | ||||||
|  |  | ||||||
|  | </mapper> | ||||||
| @ -9,16 +9,11 @@ create table `project` | |||||||
|     `p_id`               bigint                                null comment '父项目id', |     `p_id`               bigint                                null comment '父项目id', | ||||||
|     `status`             tinyint(4)  default 0                 null comment '状态(0正常 1停用)', |     `status`             tinyint(4)  default 0                 null comment '状态(0正常 1停用)', | ||||||
|     `pic_url`            varchar(255)                          null comment '项目图片', |     `pic_url`            varchar(255)                          null comment '项目图片', | ||||||
|     `lng`                varchar(20)                           null COMMENT '经度', |     `lng`                varchar(20)                           null comment '经度', | ||||||
|     `lat`                varchar(20)                           null COMMENT '纬度', |     `lat`                varchar(20)                           null comment '纬度', | ||||||
|     `remark`             varchar(500)                          null comment '备注', |     `remark`             varchar(500)                          null comment '备注', | ||||||
|     `type`               varchar(20)                           null comment '项目类型', |     `type`               varchar(20)                           null comment '项目类型', | ||||||
|     `is_type`            tinyint(4)                            null comment '项目类型(1光伏 2风电)', |     `is_type`            tinyint(4)                            null comment '项目类型(1光伏 2风电)', | ||||||
|     `create_by`          bigint                                null comment '创建者', |  | ||||||
|     `update_by`          bigint                                null comment '更新者', |  | ||||||
|     `create_time`        datetime    default CURRENT_TIMESTAMP null comment '创建时间', |  | ||||||
|     `update_time`        datetime    default CURRENT_TIMESTAMP null ON UPDATE CURRENT_TIMESTAMP comment '更新时间', |  | ||||||
|     `deleted_at`         datetime                              null comment '删除时间', |  | ||||||
|     `project_site`       varchar(255)                          null comment '项目地址', |     `project_site`       varchar(255)                          null comment '项目地址', | ||||||
|     `principal`          varchar(50)                           null comment '负责人', |     `principal`          varchar(50)                           null comment '负责人', | ||||||
|     `principal_phone`    varchar(50)                           null comment '负责人电话', |     `principal_phone`    varchar(50)                           null comment '负责人电话', | ||||||
| @ -30,6 +25,11 @@ create table `project` | |||||||
|     `security_agreement` varchar(255)                          null comment '安全协议书', |     `security_agreement` varchar(255)                          null comment '安全协议书', | ||||||
|     `sort`               bigint      default 0                 not null comment '排序字段', |     `sort`               bigint      default 0                 not null comment '排序字段', | ||||||
|     `show_hidden`        tinyint(4)  default 0                 not null comment '显示隐藏(0显示 1隐藏)', |     `show_hidden`        tinyint(4)  default 0                 not null comment '显示隐藏(0显示 1隐藏)', | ||||||
|  |     `create_by`          bigint                                null comment '创建者', | ||||||
|  |     `update_by`          bigint                                null comment '更新者', | ||||||
|  |     `create_time`        datetime    default CURRENT_TIMESTAMP null comment '创建时间', | ||||||
|  |     `update_time`        datetime    default CURRENT_TIMESTAMP null on update CURRENT_TIMESTAMP comment '更新时间', | ||||||
|  |     `deleted_at`         datetime                              null comment '删除时间', | ||||||
|     `is_delete`          tinyint(4)  default 0                 not null comment '是否删除(0正常 1删除)', |     `is_delete`          tinyint(4)  default 0                 not null comment '是否删除(0正常 1删除)', | ||||||
|     PRIMARY KEY (`id`) USING BTREE |     PRIMARY KEY (`id`) USING BTREE | ||||||
| ) ENGINE = InnoDB | ) ENGINE = InnoDB | ||||||
| @ -41,23 +41,110 @@ create table `project` | |||||||
| DROP TABLE IF EXISTS `user_project_relevancy`; | DROP TABLE IF EXISTS `user_project_relevancy`; | ||||||
| CREATE TABLE `user_project_relevancy` | CREATE TABLE `user_project_relevancy` | ||||||
| ( | ( | ||||||
|     `id`          bigint                             not null AUTO_INCREMENT COMMENT '主键ID', |     `id`          bigint                             not null AUTO_INCREMENT comment '主键ID', | ||||||
|     `user_id`     bigint                             not null comment '用户ID', |     `user_id`     bigint                             not null comment '用户ID', | ||||||
|     `project_id`  bigint                             not null comment '项目ID', |     `project_id`  bigint                             not null comment '项目ID', | ||||||
|     `create_by`   varchar(50)                        null comment '创建人', |     `create_by`   varchar(50)                        null comment '创建人', | ||||||
|     `update_by`   varchar(50)                        null comment '更新人', |     `update_by`   varchar(50)                        null comment '更新人', | ||||||
|     `create_time` datetime default CURRENT_TIMESTAMP null comment '创建时间', |     `create_time` datetime default CURRENT_TIMESTAMP null comment '创建时间', | ||||||
|     `update_time` datetime default CURRENT_TIMESTAMP null ON UPDATE CURRENT_TIMESTAMP comment '更新时间', |     `update_time` datetime default CURRENT_TIMESTAMP null on update CURRENT_TIMESTAMP comment '更新时间', | ||||||
|     PRIMARY KEY (`id`) USING BTREE, |     PRIMARY KEY (`id`) USING BTREE, | ||||||
|     INDEX `user_id` (`user_id` ASC) USING BTREE COMMENT '用户id', |     INDEX `idx_user_id` (`user_id` ASC) USING BTREE comment '用户id', | ||||||
|     INDEX `project_id` (`project_id` ASC) USING BTREE COMMENT '项目id' |     INDEX `idx_project_id` (`project_id` ASC) USING BTREE comment '项目id' | ||||||
| ) ENGINE = InnoDB | ) ENGINE = InnoDB | ||||||
|   AUTO_INCREMENT = 1365 |   AUTO_INCREMENT = 1365 | ||||||
|   CHARACTER SET = utf8mb4 |   CHARACTER SET = utf8mb4 | ||||||
|   COLLATE = utf8mb4_general_ci COMMENT = '系统用户与项目关联' |   COLLATE = utf8mb4_general_ci comment = '系统用户与项目关联表' | ||||||
|   ROW_FORMAT = DYNAMIC; |   ROW_FORMAT = DYNAMIC; | ||||||
|  |  | ||||||
|  | DROP TABLE IF EXISTS `bus_company`; | ||||||
|  | CREATE TABLE `bus_company` | ||||||
|  | ( | ||||||
|  |     `id`            bigint                               not null auto_increment, | ||||||
|  |     `company_name`  varchar(64)                          null comment '公司名称', | ||||||
|  |     `project_id`    bigint                               null comment '项目id', | ||||||
|  |     `status`        char(1)    default 0                 null comment '帐号状态(0正常 1停用)', | ||||||
|  |     `remark`        varchar(255)                         null comment '备注', | ||||||
|  |     `qualification` varchar(255)                         null comment '资质情况', | ||||||
|  |     `create_by`     varchar(64)                          null comment '创建者', | ||||||
|  |     `update_by`     varchar(64)                          null comment '更新者', | ||||||
|  |     `create_time`   datetime   default CURRENT_TIMESTAMP null comment '创建时间', | ||||||
|  |     `update_time`   datetime   default CURRENT_TIMESTAMP null on update CURRENT_TIMESTAMP comment '更新时间', | ||||||
|  |     `deleted_at`    datetime                             null comment '删除时间', | ||||||
|  |     `is_delete`     tinyint(4) default 0                 not null comment '是否删除(0正常 1删除)', | ||||||
|  |     PRIMARY KEY (`id`) USING BTREE, | ||||||
|  |     INDEX `idx_project_id` (`project_id` ASC) USING BTREE comment '项目id' | ||||||
|  | ) ENGINE = InnoDB | ||||||
|  |   AUTO_INCREMENT = 52 | ||||||
|  |   CHARACTER SET = utf8mb4 | ||||||
|  |   COLLATE = utf8mb4_general_ci comment = '公司表' | ||||||
|  |   ROW_FORMAT = DYNAMIC; | ||||||
|  |  | ||||||
|  | DROP TABLE IF EXISTS `bus_materials`; | ||||||
|  | CREATE TABLE `bus_materials` | ||||||
|  | ( | ||||||
|  |     `id`                          bigint                               not null auto_increment, | ||||||
|  |     `materials_name`              varchar(64)                          null comment '材料名称', | ||||||
|  |     `company_id`                  bigint                               null comment '公司id', | ||||||
|  |     `project_id`                  bigint                               null comment '项目id', | ||||||
|  |     `type_specification_name`     varchar(64)                          null comment '规格型号名称', | ||||||
|  |     `type_specification_url`      varchar(255)                         null comment '规格型号文件路径', | ||||||
|  |     `certificate_conformity_name` varchar(64)                          null comment '合格证编号名称', | ||||||
|  |     `certificate_conformity_url`  varchar(255)                         null comment '合格证编号文件路径', | ||||||
|  |     `quality_name`                varchar(64)                          null comment '质量说明书编号', | ||||||
|  |     `quality_url`                 varchar(255)                         null comment '质量说明书文件路径', | ||||||
|  |     `inspection_report_name`      varchar(64)                          null comment '检验报告编号', | ||||||
|  |     `inspection_report_url`       varchar(255)                         null comment '检验报告文件路径', | ||||||
|  |     `reexamine_report_name`       varchar(64)                          null comment '复试报告编号', | ||||||
|  |     `reexamine_report_url`        varchar(255)                         null comment '复试报告文件路径', | ||||||
|  |     `use_part`                    varchar(64)                          null comment '使用部位', | ||||||
|  |     `weight_id`                   varchar(64)                          null comment '计量单位', | ||||||
|  |     `remark`                      varchar(255)                         null comment '备注', | ||||||
|  |     `quantity_count`              varchar(64)                          null comment '预计材料数量', | ||||||
|  |     `status`                      char(1)                              null comment '状态(0正常 1停用)', | ||||||
|  |     `create_by`                   varchar(64)                          null comment '创建者', | ||||||
|  |     `update_by`                   varchar(64)                          null comment '更新者', | ||||||
|  |     `create_time`                 datetime   default CURRENT_TIMESTAMP null comment '创建时间', | ||||||
|  |     `update_time`                 datetime   default CURRENT_TIMESTAMP null on update CURRENT_TIMESTAMP comment '更新时间', | ||||||
|  |     `deleted_at`                  datetime                             null comment '删除时间', | ||||||
|  |     `is_delete`                   tinyint(4) default 0                 not null comment '是否删除(0正常 1删除)', | ||||||
|  |     PRIMARY KEY (`id`) USING BTREE, | ||||||
|  |     INDEX `idx_project_id` (`project_id` ASC) USING BTREE comment '项目id' | ||||||
|  | ) ENGINE = InnoDB | ||||||
|  |   AUTO_INCREMENT = 348 | ||||||
|  |   CHARACTER SET = utf8mb4 | ||||||
|  |   COLLATE = utf8mb4_general_ci comment = '材料名称表' | ||||||
|  |   ROW_FORMAT = DYNAMIC; | ||||||
|  |  | ||||||
|  | DROP TABLE IF EXISTS `bus_materials_inventory`; | ||||||
|  | CREATE TABLE `bus_materials_inventory` | ||||||
|  | ( | ||||||
|  |     `id`           bigint                               not null auto_increment comment '主键id', | ||||||
|  |     `materials_id` bigint                               not null comment '材料id', | ||||||
|  |     `project_id`   bigint                               null comment '项目id', | ||||||
|  |     `out_put`      char(1)                              null comment '出入库状态', | ||||||
|  |     `number`       int        default 0                 null comment '出/入库的数量', | ||||||
|  |     `out_put_time` datetime                             null comment '出/入库操作时间', | ||||||
|  |     `residue`      int        default 0                 null comment '剩余库存数量(记录最后一次操作留下的库存数)', | ||||||
|  |     `operator`     varchar(255)                         null comment '操作人(入库人、领料人)', | ||||||
|  |     `path`         varchar(512)                         null comment '材料出入证明', | ||||||
|  |     `disposition`  varchar(255)                         null comment '处理方式', | ||||||
|  |     `recipient`    varchar(255)                         null comment '交接单位(班组)', | ||||||
|  |     `shipper`      varchar(255)                         null comment '领用人', | ||||||
|  |     `remark`       varchar(255)                         null comment '备注', | ||||||
|  |     `create_by`    varchar(64)                          null comment '创建者', | ||||||
|  |     `update_by`    varchar(64)                          null comment '更新者', | ||||||
|  |     `create_time`  datetime   default CURRENT_TIMESTAMP null comment '创建时间', | ||||||
|  |     `update_time`  datetime   default CURRENT_TIMESTAMP null on update CURRENT_TIMESTAMP comment '更新时间', | ||||||
|  |     `deleted_at`   datetime                             null comment '删除时间', | ||||||
|  |     `is_delete`    tinyint(4) default 0                 not null comment '是否删除(0正常 1删除)', | ||||||
|  |     PRIMARY KEY (`id`) USING BTREE, | ||||||
|  |     INDEX `idx_project_id` (`project_id` ASC) USING BTREE comment '项目ID' | ||||||
|  | ) ENGINE = InnoDB | ||||||
|  |   AUTO_INCREMENT = 965 | ||||||
|  |   CHARACTER SET = utf8mb4 | ||||||
|  |   COLLATE = utf8mb4_general_ci comment = '材料出/入库表' | ||||||
|  |   ROW_FORMAT = DYNAMIC; | ||||||
|  |  | ||||||
| -- 菜单 SQL | -- 菜单 SQL | ||||||
| insert into sys_menu (menu_id, menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, | insert into sys_menu (menu_id, menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, | ||||||
| @ -122,3 +209,64 @@ insert into sys_menu (menu_id, menu_name, parent_id, order_num, path, component, | |||||||
|                       status, perms, icon, create_dept, create_by, create_time, update_by, update_time, remark) |                       status, perms, icon, create_dept, create_by, create_time, update_by, update_time, remark) | ||||||
| values (1896949180526047238, '系统用户与项目关联导出', 1896949180526047233, '5', '#', '', 1, 0, 'F', '0', '0', | values (1896949180526047238, '系统用户与项目关联导出', 1896949180526047233, '5', '#', '', 1, 0, 'F', '0', '0', | ||||||
|         'project:projectRelevancy:export', '#', 103, 1, sysdate(), null, null, ''); |         'project:projectRelevancy:export', '#', 103, 1, sysdate(), null, null, ''); | ||||||
|  |  | ||||||
|  | -- 菜单 SQL | ||||||
|  | insert into sys_menu (menu_id, menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_dept, create_by, create_time, update_by, update_time, remark) | ||||||
|  | values(1897479771016716290, '公司', '1', '1', 'company', 'materials/company/index', 1, 0, 'C', '0', '0', 'materials:company:list', '#', 103, 1, sysdate(), null, null, '公司菜单'); | ||||||
|  |  | ||||||
|  | -- 按钮 SQL | ||||||
|  | insert into sys_menu (menu_id, menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_dept, create_by, create_time, update_by, update_time, remark) | ||||||
|  | values(1897479771016716291, '公司查询', 1897479771016716290, '1',  '#', '', 1, 0, 'F', '0', '0', 'materials:company:query',        '#', 103, 1, sysdate(), null, null, ''); | ||||||
|  |  | ||||||
|  | insert into sys_menu (menu_id, menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_dept, create_by, create_time, update_by, update_time, remark) | ||||||
|  | values(1897479771016716292, '公司新增', 1897479771016716290, '2',  '#', '', 1, 0, 'F', '0', '0', 'materials:company:add',          '#', 103, 1, sysdate(), null, null, ''); | ||||||
|  |  | ||||||
|  | insert into sys_menu (menu_id, menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_dept, create_by, create_time, update_by, update_time, remark) | ||||||
|  | values(1897479771016716293, '公司修改', 1897479771016716290, '3',  '#', '', 1, 0, 'F', '0', '0', 'materials:company:edit',         '#', 103, 1, sysdate(), null, null, ''); | ||||||
|  |  | ||||||
|  | insert into sys_menu (menu_id, menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_dept, create_by, create_time, update_by, update_time, remark) | ||||||
|  | values(1897479771016716294, '公司删除', 1897479771016716290, '4',  '#', '', 1, 0, 'F', '0', '0', 'materials:company:remove',       '#', 103, 1, sysdate(), null, null, ''); | ||||||
|  |  | ||||||
|  | insert into sys_menu (menu_id, menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_dept, create_by, create_time, update_by, update_time, remark) | ||||||
|  | values(1897479771016716295, '公司导出', 1897479771016716290, '5',  '#', '', 1, 0, 'F', '0', '0', 'materials:company:export',       '#', 103, 1, sysdate(), null, null, ''); | ||||||
|  |  | ||||||
|  | -- 菜单 SQL | ||||||
|  | insert into sys_menu (menu_id, menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_dept, create_by, create_time, update_by, update_time, remark) | ||||||
|  | values(1897479769502572546, '材料出/入库', '1', '1', 'materialsInventory', 'materials/materialsInventory/index', 1, 0, 'C', '0', '0', 'materials:materialsInventory:list', '#', 103, 1, sysdate(), null, null, '材料出/入库菜单'); | ||||||
|  |  | ||||||
|  | -- 按钮 SQL | ||||||
|  | insert into sys_menu (menu_id, menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_dept, create_by, create_time, update_by, update_time, remark) | ||||||
|  | values(1897479769502572547, '材料出/入库查询', 1897479769502572546, '1',  '#', '', 1, 0, 'F', '0', '0', 'materials:materialsInventory:query',        '#', 103, 1, sysdate(), null, null, ''); | ||||||
|  |  | ||||||
|  | insert into sys_menu (menu_id, menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_dept, create_by, create_time, update_by, update_time, remark) | ||||||
|  | values(1897479769502572548, '材料出/入库新增', 1897479769502572546, '2',  '#', '', 1, 0, 'F', '0', '0', 'materials:materialsInventory:add',          '#', 103, 1, sysdate(), null, null, ''); | ||||||
|  |  | ||||||
|  | insert into sys_menu (menu_id, menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_dept, create_by, create_time, update_by, update_time, remark) | ||||||
|  | values(1897479769502572549, '材料出/入库修改', 1897479769502572546, '3',  '#', '', 1, 0, 'F', '0', '0', 'materials:materialsInventory:edit',         '#', 103, 1, sysdate(), null, null, ''); | ||||||
|  |  | ||||||
|  | insert into sys_menu (menu_id, menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_dept, create_by, create_time, update_by, update_time, remark) | ||||||
|  | values(1897479769502572550, '材料出/入库删除', 1897479769502572546, '4',  '#', '', 1, 0, 'F', '0', '0', 'materials:materialsInventory:remove',       '#', 103, 1, sysdate(), null, null, ''); | ||||||
|  |  | ||||||
|  | insert into sys_menu (menu_id, menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_dept, create_by, create_time, update_by, update_time, remark) | ||||||
|  | values(1897479769502572551, '材料出/入库导出', 1897479769502572546, '5',  '#', '', 1, 0, 'F', '0', '0', 'materials:materialsInventory:export',       '#', 103, 1, sysdate(), null, null, ''); | ||||||
|  |  | ||||||
|  | -- 菜单 SQL | ||||||
|  | insert into sys_menu (menu_id, menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_dept, create_by, create_time, update_by, update_time, remark) | ||||||
|  | values(1897479770626646018, '材料名称', '1', '1', 'materials', 'materials/materials/index', 1, 0, 'C', '0', '0', 'materials:materials:list', '#', 103, 1, sysdate(), null, null, '材料名称菜单'); | ||||||
|  |  | ||||||
|  | -- 按钮 SQL | ||||||
|  | insert into sys_menu (menu_id, menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_dept, create_by, create_time, update_by, update_time, remark) | ||||||
|  | values(1897479770626646019, '材料名称查询', 1897479770626646018, '1',  '#', '', 1, 0, 'F', '0', '0', 'materials:materials:query',        '#', 103, 1, sysdate(), null, null, ''); | ||||||
|  |  | ||||||
|  | insert into sys_menu (menu_id, menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_dept, create_by, create_time, update_by, update_time, remark) | ||||||
|  | values(1897479770626646020, '材料名称新增', 1897479770626646018, '2',  '#', '', 1, 0, 'F', '0', '0', 'materials:materials:add',          '#', 103, 1, sysdate(), null, null, ''); | ||||||
|  |  | ||||||
|  | insert into sys_menu (menu_id, menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_dept, create_by, create_time, update_by, update_time, remark) | ||||||
|  | values(1897479770626646021, '材料名称修改', 1897479770626646018, '3',  '#', '', 1, 0, 'F', '0', '0', 'materials:materials:edit',         '#', 103, 1, sysdate(), null, null, ''); | ||||||
|  |  | ||||||
|  | insert into sys_menu (menu_id, menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_dept, create_by, create_time, update_by, update_time, remark) | ||||||
|  | values(1897479770626646022, '材料名称删除', 1897479770626646018, '4',  '#', '', 1, 0, 'F', '0', '0', 'materials:materials:remove',       '#', 103, 1, sysdate(), null, null, ''); | ||||||
|  |  | ||||||
|  | insert into sys_menu (menu_id, menu_name, parent_id, order_num, path, component, is_frame, is_cache, menu_type, visible, status, perms, icon, create_dept, create_by, create_time, update_by, update_time, remark) | ||||||
|  | values(1897479770626646023, '材料名称导出', 1897479770626646018, '5',  '#', '', 1, 0, 'F', '0', '0', 'materials:materials:export',       '#', 103, 1, sysdate(), null, null, ''); | ||||||
|  |  | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user
	 zhuer
					zhuer