243 Commits

Author SHA1 Message Date
a1761afba0 12-19-完善备注 2025-12-19 17:28:57 +08:00
8b4eba041f Merge branch 'dev' into updateMenu 2025-12-19 14:54:11 +08:00
zrl
67979deed8 建管项目列表 项目类型回显 2025-12-19 14:29:58 +08:00
1e3767eed4 Merge remote-tracking branch 'origin/dev' into dev 2025-12-19 12:00:04 +08:00
f19dd20995 12-18-人员管理大屏-修复循环注入版-修复timeType版-消息回复-完善-修复版-优化分包公司查询版-修复数据-优化查询-完善-修改版 2025-12-19 11:59:55 +08:00
zzz
2ce43be23e 建管项目修改 2025-12-18 20:07:35 +08:00
zzz
08b905e074 项目经理推荐及审批列表增加非空判断 2025-12-18 17:01:44 +08:00
b550753d6f 12-18-人员管理大屏-修复循环注入版-修复timeType版-消息回复-完善-修复版-优化分包公司查询版-修复数据-优化查询-完善 2025-12-18 10:29:55 +08:00
lcj
731b8bb1d2 进度大屏 2025-12-18 09:27:02 +08:00
a943398499 12-17-人员管理大屏-修复循环注入版-修复timeType版-消息回复-完善-修复版-优化分包公司查询版-修复数据-优化查询 2025-12-17 21:05:36 +08:00
a4b0ec835e 12-17-人员管理大屏-修复循环注入版-修复timeType版-消息回复-完善-修复版-优化分包公司查询版-修复数据 2025-12-17 20:35:29 +08:00
61c2cdd56a 12-17-人员管理大屏-修复循环注入版-修复timeType版-消息回复-完善-修复版-优化分包公司查询版 2025-12-17 20:09:00 +08:00
c5bf75a6eb 12-17-人员管理大屏-修复循环注入版-修复timeType版-消息回复-完善-修复版 2025-12-17 19:47:48 +08:00
zzz
5de6dff86b 质安管理增加项目判断 2025-12-17 19:43:30 +08:00
lcj
2cdabd7b20 修改 bug 2025-12-17 19:19:33 +08:00
lcj
e7ce0875d4 修改 bug 2025-12-17 19:11:22 +08:00
e36b76f3dc 物资管理大屏仓库实时监控接口优化 2025-12-17 17:35:47 +08:00
lcj
0f2d1bcc38 进度管理 2025-12-17 17:11:47 +08:00
zzz
e134e77d00 质安管理 2025-12-17 17:02:38 +08:00
lcj
4d7df7298a 进度管理大屏 2025-12-17 16:36:08 +08:00
zt
86951d43b4 班组 2025-12-17 14:57:13 +08:00
48117eb5d4 12-17-人员管理大屏-修复循环注入版-修复timeType版-消息回复-完善 2025-12-17 14:47:44 +08:00
zzz
be4e5ba049 质安管理 2025-12-17 11:49:15 +08:00
51a840f750 Merge remote-tracking branch 'origin/dev' into dev 2025-12-17 11:21:59 +08:00
98db0647ca 12-17-人员管理大屏-修复循环注入版-修复timeType版-消息回复 2025-12-17 11:21:41 +08:00
lcj
667a460258 进度管理大屏 2025-12-17 11:16:51 +08:00
2fd1736766 物资管理大屏消耗趋势对比接口优化 2025-12-17 09:28:27 +08:00
zzz
c1f5cc33b0 质安管理 2025-12-16 20:32:21 +08:00
zzz
d3a1f667a7 质安管理 2025-12-16 20:02:58 +08:00
lcj
f9b8ae5dbb 进度管理大屏 2025-12-16 19:10:57 +08:00
5fc35e1a4c 物资管理大屏接口优化 2025-12-16 19:06:44 +08:00
bb63e7464d 12-16-人员管理大屏-修复循环注入版-修复timeType版 2025-12-16 18:49:19 +08:00
zzz
dd6402d8b6 质安管理 2025-12-16 18:46:37 +08:00
zzz
ebb8f09a75 质安管理 2025-12-16 18:31:50 +08:00
7bc2f1c832 12-16-人员管理大屏-修复循环注入版 2025-12-16 18:06:07 +08:00
b35f6d6fd2 12-16-人员管理大屏 2025-12-16 17:25:31 +08:00
ea626dfeff 物资管理大屏接口 2025-12-16 17:09:10 +08:00
lcj
975d3e6f32 修改读取 CAD 桩点逻辑 2025-12-16 16:08:23 +08:00
zzz
e8ee492636 实用工具bug修复 2025-12-16 16:06:09 +08:00
zzz
76595c1510 大屏 2025-12-16 14:59:45 +08:00
zzz
dd5ce4bec4 实用工具,文件中心增加项目id 2025-12-16 14:07:43 +08:00
zzz
de6d100f79 质安管理 2025-12-16 11:34:41 +08:00
lcj
aa3628f041 进度管理大屏,摄像头排序 2025-12-16 10:14:00 +08:00
654623ad15 摄像头设置是否开启全天录像接口 2025-12-15 16:43:06 +08:00
zzz
deef321c1b 质量管理枚举 2025-12-15 16:32:06 +08:00
zzz
ffe6642d1c 大屏枚举 2025-12-15 16:26:09 +08:00
834601daa8 大屏websocket初始化 2025-12-15 16:23:18 +08:00
zzz
c27e793378 Merge remote-tracking branch 'origin/updateMenu' into updateMenu 2025-12-15 09:30:28 +08:00
zzz
fb794de044 bug 2025-12-15 09:30:21 +08:00
lcj
1b184dfb00 个人首页添加项目切换,派单详情,附件 2025-12-13 17:48:19 +08:00
0ffbba57e2 设计工程量清单添加新增修改删除,设计的设计方案增加附件的时候需要给类型 2025-12-13 17:45:19 +08:00
zt
3b580788f1 Merge remote-tracking branch 'origin/updateMenu' into updateMenu 2025-12-12 18:16:20 +08:00
zt
7b6ff3bcc6 优化 2025-12-12 18:16:05 +08:00
zzz
8e5303838e 派单 2025-12-12 18:14:57 +08:00
28f92b6138 增值税发票excel导入 2025-12-12 18:10:42 +08:00
lcj
8ece9617d6 修改 bug 2025-12-12 17:46:35 +08:00
lcj
a5cf647f2b 修改bug 2025-12-12 17:12:04 +08:00
zzz
758e49973b 修改标后分析 2025-12-12 15:58:01 +08:00
zzz
876f8b700d 修改标后分析 2025-12-12 15:48:36 +08:00
zzz
53b777c7af 修改实用工具的模糊查询 2025-12-12 15:02:19 +08:00
5e749f6de6 新中大项目创建时添加建管项目修改 2025-12-12 14:54:35 +08:00
dcd0907cdd 12-12-修改收开票搜索条件 2025-12-12 11:58:04 +08:00
3f16621313 12-12-搭配角色流程列表修改 2025-12-12 11:28:02 +08:00
lcj
03b3c8141a 项目详情 2025-12-12 11:26:35 +08:00
zzz
509683386f 修改机械合同 2025-12-12 11:24:17 +08:00
e3b6c3d8d6 总体计划成本接口修改 2025-12-12 11:15:52 +08:00
29cdd7b3e7 总体计划成本接口修改 2025-12-12 10:40:47 +08:00
zzz
ee864c882a 修改税率 2025-12-12 10:08:30 +08:00
10e449c001 阶段成本分解接口修改 2025-12-12 09:41:22 +08:00
89d60dc528 阶段成本分解接口修改 2025-12-11 22:13:34 +08:00
zt
ce35086316 优化 2025-12-11 20:29:29 +08:00
e7376086f9 将供应商由建管转到新中大供应商,总体计划成本接口修改 2025-12-11 20:28:31 +08:00
zzz
4588f3f4c0 标后分析自动生成项目 2025-12-11 20:15:55 +08:00
lcj
97898aa395 修改权限 2025-12-11 18:56:57 +08:00
lcj
b4a7c6ba90 修改权限 2025-12-11 17:25:06 +08:00
4d6a225f96 12-11-权限修改,排除SuperAdmin 2025-12-11 16:38:31 +08:00
zzz
6d9b5a727d query权限去除 2025-12-11 11:42:25 +08:00
a79e08f6bc 12-11-大屏接口权限修改 2025-12-11 10:11:38 +08:00
lcj
e49ab63a0b 关联项目 2025-12-11 08:52:58 +08:00
lcj
2b3c86e763 Merge remote-tracking branch 'gitea/dev' into updateMenu 2025-12-10 19:02:01 +08:00
zt
1263b4812d 个人首页 2025-12-10 18:58:29 +08:00
lcj
755969b069 Merge branch 'dev' into updateMenu 2025-12-10 18:49:14 +08:00
lcj
dbe8556741 关联项目 2025-12-10 18:48:18 +08:00
lcj
b10e7b4ca1 修改配置 2025-12-10 17:18:03 +08:00
zt
844b3addf3 Merge remote-tracking branch 'origin/dev' into dev 2025-12-10 17:16:23 +08:00
zt
77532caf47 退出班组 2025-12-10 17:15:59 +08:00
lcj
ff9cc76ebc Merge remote-tracking branch 'gitea/updateMenu' into updateMenu 2025-12-10 15:59:50 +08:00
lcj
d125510267 Merge branch 'dev' into updateMenu 2025-12-10 15:56:18 +08:00
lcj
46ac312ddf 创建新项目 2025-12-10 15:53:31 +08:00
c45d98856e 12-10-修改事故 2025-12-10 15:52:05 +08:00
lcj
f2c0932e2e 修改bug 2025-12-10 10:58:25 +08:00
zt
b8334c7764 优化 2025-12-10 10:14:08 +08:00
c709e04c88 标前管理人员任命添加审核状态 2025-12-09 19:31:55 +08:00
509fc8cc28 标前管理-风险信息,人员任命修改 2025-12-09 18:59:18 +08:00
48338278f0 安全事故bug修改和意见箱bug修改 2025-12-09 18:50:20 +08:00
833ea7af7d 标前管理-风险信息,人员任命 2025-12-09 14:33:49 +08:00
f5cea23daa 安全事故接口优化 2025-12-09 09:06:35 +08:00
zt
a29c9c8d4d 优化 2025-12-08 19:57:28 +08:00
511bf33914 12-05-事故管理-事故上报、事故调查-修改-修改部门 2025-12-08 19:36:59 +08:00
4450f82717 12-05-事故管理-事故上报、事故调查-修改 2025-12-08 19:28:29 +08:00
lcj
f62c542684 项目对接 2025-12-08 19:10:04 +08:00
bb8c951651 安全事故接口优化 2025-12-08 18:51:31 +08:00
9f5b3918d0 12-05-事故管理-事故上报、事故调查 2025-12-08 18:48:53 +08:00
zrl
84d9291763 安全技术交底,监控修改 2025-12-08 15:52:24 +08:00
fcbc5a30c4 12-05-事故管理-事故上报、事故调查 2025-12-08 15:26:13 +08:00
zt
6f4eb21deb 危大 2025-12-08 10:43:09 +08:00
387a7488ab Merge branch 'dev' into updateMenu 2025-12-08 10:39:50 +08:00
lg
6819eb5f80 危大工程-技术交底,过程监控 2025-12-06 19:31:19 +08:00
lg
0f1ad34342 危大工程-技术交底,过程监控 2025-12-06 19:07:28 +08:00
zt
35d1cfc668 危大 2025-12-06 18:39:35 +08:00
zt
a6dc40760d 危大 2025-12-06 14:22:07 +08:00
2486bb4c6e 12-05-事故管理-事故上报 2025-12-05 20:47:10 +08:00
a59a452f89 Merge remote-tracking branch 'origin/dev' into dev 2025-12-05 20:10:20 +08:00
930bff6cba 安全事故初始化 2025-12-05 20:10:13 +08:00
lcj
70c9997c82 接入消息队列,处理延迟消息 2025-12-05 19:53:34 +08:00
lg
0db70d3d73 机械安全模块修改 2025-12-05 18:54:36 +08:00
zt
2884699ff2 bug 2025-12-05 18:53:33 +08:00
lcj
849eb802bc 隐患整改 2025-12-05 18:52:52 +08:00
4ce8ea6a3a 安全事故初始化 2025-12-05 16:59:41 +08:00
7e1db73fb0 意见箱修改 2025-12-05 16:45:22 +08:00
lcj
46299e5732 隐患整改 2025-12-05 14:24:17 +08:00
zt
6032869417 奖惩 2025-12-05 14:16:46 +08:00
lg
955d7e39e6 机械安全模块修改 2025-12-05 09:28:05 +08:00
lcj
ecc0595ec3 施工产值,隐患整改 2025-12-05 08:58:40 +08:00
6b22ed8b0a Merge remote-tracking branch 'origin/dev' into dev 2025-12-04 20:21:34 +08:00
9b7db3214e 12-04-人员定位-终版-优化版之修复版 2025-12-04 20:21:24 +08:00
zt
71b3c77028 奖惩 2025-12-04 20:08:53 +08:00
zt
c7bd709240 奖惩 2025-12-04 19:18:49 +08:00
lg
a80c38f87f 机械安全模块 2025-12-04 18:15:49 +08:00
7b91443532 Merge remote-tracking branch 'origin/dev' into dev 2025-12-04 16:27:29 +08:00
lcj
a9b9e12732 修改bug 2025-12-04 15:55:31 +08:00
99ecb29f3c 12-04-人员定位-终版-优化版 2025-12-04 15:39:06 +08:00
lg
4fe7a435c6 机械安全模块 2025-12-04 15:27:35 +08:00
zt
18be0f00a3 奖惩 2025-12-04 15:21:29 +08:00
67bbf94359 12-04-收票登记修改 2025-12-04 15:12:56 +08:00
lg
9dfea176b3 Merge remote-tracking branch 'origin/dev' into dev 2025-12-04 15:11:59 +08:00
lcj
09d3b06e7a 隐患整改 2025-12-04 15:11:27 +08:00
lg
8b60d13c0a 机械安全模块 2025-12-04 15:10:41 +08:00
188172692b 12-03-人员定位-终版 2025-12-04 14:31:48 +08:00
lcj
556f3b6535 隐患规则 2025-12-04 10:18:26 +08:00
0b81a8dc63 Merge remote-tracking branch 'origin/dev' into dev 2025-12-03 22:23:20 +08:00
982ec18490 12-03-人员定位-再版 2025-12-03 22:23:12 +08:00
0c38c42bfe 摄像头回放 2025-12-03 20:28:58 +08:00
zt
2f0b323680 顺序 2025-12-03 20:18:34 +08:00
zt
35d2a10c0e 顺序 2025-12-03 20:09:19 +08:00
zt
9c7f9ad980 隐患 2025-12-03 19:54:45 +08:00
79a2dbfcd3 12-03-人员定位-初版 2025-12-03 18:57:00 +08:00
lg
b5b7324f7c 模块添加 2025-12-03 17:14:31 +08:00
zt
b171ec6af0 隐患 2025-12-03 17:01:37 +08:00
lcj
85c7ded162 隐患规则 2025-12-03 17:00:43 +08:00
lcj
b39aa7be71 施工产值 2025-12-03 15:46:28 +08:00
8ae5614ce9 12-03-人员定位-柱状图数据 2025-12-03 09:34:45 +08:00
03cf7ebac7 12-01-人员定位 2025-12-02 21:57:46 +08:00
lg
3efa899a97 机械维护与故障 2025-12-02 19:07:26 +08:00
zt
bf1b9cf98f Merge branch 'refs/heads/dev' into updateMenu 2025-12-02 17:46:42 +08:00
zt
e800ff3ac9 Merge branch 'refs/heads/dev' into updateMenu 2025-12-02 17:44:27 +08:00
lcj
f0802432ed 修改execl导入校验 2025-12-02 17:43:59 +08:00
zt
c96808efc1 bug 2025-12-02 17:42:35 +08:00
zt
e972efb247 设计权限 2025-12-02 16:24:39 +08:00
zt
f782edd68b 设计权限 2025-12-02 16:24:02 +08:00
zt
45702ef838 设备 2025-12-02 16:22:42 +08:00
lcj
4e3faa7a23 进度识别 2025-12-02 16:12:07 +08:00
zt
40559d4d73 设备 2025-12-02 15:59:06 +08:00
zt
7816fec7aa 设备 2025-12-02 15:57:39 +08:00
lcj
37c95ab0bd 施工产值导出,大图 2025-12-02 15:51:44 +08:00
lg
3e38cf9abb 合同显示bug修改 2025-12-02 10:10:50 +08:00
lg
4aaf384ce8 机械 2025-12-01 20:00:39 +08:00
6a06d8596d 意见箱 2025-12-01 19:49:40 +08:00
be89a6fe9e 12-01-修改 2025-12-01 19:28:21 +08:00
40b51e5e9d 12-01-修改 2025-12-01 19:28:10 +08:00
zt
4b14ea5c7f 设备 2025-12-01 17:09:58 +08:00
a44777d7b2 Merge remote-tracking branch 'origin/updateMenu' into updateMenu 2025-11-28 19:55:38 +08:00
492fba5fd3 11-28-详情权限修改 2025-11-28 19:55:29 +08:00
zt
07b921d630 人员迁移 2025-11-28 19:51:41 +08:00
zt
13d33e9d53 token时间 2025-11-28 19:27:41 +08:00
zt
4f38db5fde bug 2025-11-28 18:56:59 +08:00
a868c7b5cb gps功能优化,添加人员轨迹,补充绑定车辆时历史记录返回车辆名称 2025-11-28 17:49:24 +08:00
d37b41c967 11-28-详情权限修改 2025-11-28 16:05:21 +08:00
b8fb9413de 标前立项bug修改 2025-11-28 15:22:39 +08:00
zt
fa9fcb1167 bug 2025-11-28 11:32:35 +08:00
zt
ebd88a999c bug 2025-11-27 19:17:15 +08:00
97079abdef 11-27-修改推荐审批文件操作 2025-11-27 18:56:33 +08:00
zt
94aaa90775 Merge branch 'refs/heads/dev' into updateMenu 2025-11-27 18:47:51 +08:00
lcj
1e01c53c52 大图 2025-11-27 17:41:36 +08:00
6c9e23e662 修改立项及成本权限 2025-11-27 17:37:25 +08:00
zt
8a27da9975 bug 2025-11-27 15:45:07 +08:00
e160cc5ff3 11-27-修改承包合同信息必填 2025-11-27 15:15:32 +08:00
zt
80b5f94cd4 bug 2025-11-27 11:44:03 +08:00
c9c81bb761 11-27-完善开票单位改为部门公司 2025-11-27 11:14:31 +08:00
zt
af90b0f879 产值及人员 2025-11-27 09:26:30 +08:00
lcj
b51a3ccf28 安全员轨迹信息 2025-11-26 19:57:00 +08:00
f07db8c368 车辆管理菜单修改和物资管理菜单修改 2025-11-26 19:18:52 +08:00
5e9d36400c 11-26-承包合同开票单位改为部门公司 2025-11-26 19:01:14 +08:00
zt
8f4a3e167a 产值及人员 2025-11-26 17:18:04 +08:00
lg
3ccd54a03b 权限字符修改 2025-11-26 16:15:03 +08:00
03177f58f2 11-26-更新供应商sql 2025-11-26 15:22:54 +08:00
zt
b0c875c9c4 班组 2025-11-26 10:25:44 +08:00
zt
bfe74bdb4c 去掉人脸 2025-11-25 19:47:16 +08:00
lg
cad5ba1101 权限字符修改 2025-11-25 19:40:59 +08:00
lcj
45d143ace3 进度计划菜单 2025-11-25 19:37:45 +08:00
zt
df08eb3dd6 Merge remote-tracking branch 'origin/dev' into dev 2025-11-25 19:26:22 +08:00
zt
8c292850c2 去掉人脸 2025-11-25 19:26:02 +08:00
12d3924e8a 11-25-更新收票登记 2025-11-25 19:19:52 +08:00
zt
d32947afe2 人员管理 2025-11-25 19:15:12 +08:00
lcj
9eecf67374 无人机大图 2025-11-25 17:30:31 +08:00
zt
d7fd7d6cc4 人员数据 2025-11-25 16:30:16 +08:00
lcj
77482c71b3 安全菜单修改 2025-11-25 16:16:16 +08:00
zt
66893410e9 菜单 2025-11-25 16:05:58 +08:00
fbbc4846de 车辆管理菜单修改和机械台账菜单修改 2025-11-25 14:53:20 +08:00
lcj
aac6efc568 无人机大图压缩包上传 2025-11-25 14:05:27 +08:00
lcj
209e624fc2 无人机大图压缩包上传 2025-11-25 12:31:25 +08:00
lcj
fe79bf282c 无人机大图压缩包上传 2025-11-25 12:29:57 +08:00
lcj
18cbc0655b 安全 2025-11-25 10:47:18 +08:00
6b59d264b4 Merge remote-tracking branch 'origin/dev' into dev 2025-11-25 10:41:17 +08:00
74785a768e 11-25-报销默认只能看见自己 2025-11-25 10:41:08 +08:00
lcj
32aafaa2db 修改bug 2025-11-25 10:05:00 +08:00
lcj
06617d94a7 修改bug 2025-11-25 09:52:25 +08:00
lcj
1b2f9aa755 安全 2025-11-25 09:42:28 +08:00
lg
04407d2f84 权限字符修改 2025-11-24 20:01:26 +08:00
lcj
c0fef2521f 无人机大图合并优化 2025-11-24 19:32:15 +08:00
04430d8853 综合服务合同vo修改 2025-11-24 16:04:26 +08:00
zt
875b436eea 考勤 2025-11-24 15:25:38 +08:00
2c1ca98e4e 菜单表修改 2025-11-24 14:55:49 +08:00
765490b51c 11-24-修复 2025-11-24 14:49:47 +08:00
lcj
b116db0bcd 更换菜单表 2025-11-24 14:28:36 +08:00
e2892b460b 设计合同付款、设计合同收款优化 2025-11-24 11:54:59 +08:00
30b1586a4a 设计合同付款、设计合同收款优化 2025-11-24 11:42:46 +08:00
lcj
15d86526ac 修改bug 2025-11-24 11:37:54 +08:00
cdf5f8bf5b 设计合同付款、设计合同收款优化 2025-11-24 11:37:07 +08:00
9bb41d903e 11-24-修复 2025-11-24 10:22:00 +08:00
d5f1c22bd4 设计合同进度结算、设计合同竣工结算、设计合同付款、设计合同收款的新增、修改、查询、删除 2025-11-21 20:31:45 +08:00
d2dcf656df Merge remote-tracking branch 'origin/dev' into dev 2025-11-21 20:29:30 +08:00
lcj
7191a60841 分包考勤机 2025-11-21 17:07:09 +08:00
3f21d39653 11-21-还原 2025-11-21 16:11:42 +08:00
b520ea6afe 11-21-添加对应方法2 2025-11-21 11:42:17 +08:00
e6283bee1c 11-21-添加对应方法 2025-11-21 11:15:40 +08:00
f6e1d0c73e 11-21-改善 2025-11-21 10:19:13 +08:00
c7e06ade6d Merge remote-tracking branch 'origin/dev' into dev 2025-11-20 20:00:23 +08:00
3d85b10475 11-20-改善 2025-11-20 20:00:03 +08:00
lg
e26dfc098a 竣工日期回填 2025-11-20 19:47:33 +08:00
lcj
c3ab46c8c8 降低springdoc版本 2025-11-20 19:27:17 +08:00
lcj
e37d118d0c 修改bug 2025-11-20 18:29:41 +08:00
lg
a6c92e8ba9 事务添加,删除sql问题 2025-11-20 16:17:19 +08:00
1067 changed files with 53812 additions and 8681 deletions

View File

@ -54,3 +54,4 @@ docs
/file /file
.idea/ .idea/
chat-memory/ chat-memory/
queries/

View File

@ -49,7 +49,7 @@
<!-- 面向运行时的D-ORM依赖 --> <!-- 面向运行时的D-ORM依赖 -->
<anyline.version>8.7.2-20250101</anyline.version> <anyline.version>8.7.2-20250101</anyline.version>
<!--工作流配置--> <!--工作流配置-->
<warm-flow.version>1.8.2</warm-flow.version> <warm-flow.version>1.7.4</warm-flow.version>
<!-- 插件版本 --> <!-- 插件版本 -->
<maven-jar-plugin.version>3.2.2</maven-jar-plugin.version> <maven-jar-plugin.version>3.2.2</maven-jar-plugin.version>
@ -86,6 +86,15 @@
<activeByDefault>true</activeByDefault> <activeByDefault>true</activeByDefault>
</activation> </activation>
</profile> </profile>
<profile>
<id>menu</id>
<properties>
<profiles.active>menu</profiles.active>
<logging.level>info</logging.level>
<monitor.username>ruoyi</monitor.username>
<monitor.password>123456</monitor.password>
</properties>
</profile>
<profile> <profile>
<id>prod</id> <id>prod</id>
<properties> <properties>

View File

@ -5,6 +5,8 @@ import cn.hutool.captcha.AbstractCaptcha;
import cn.hutool.captcha.generator.CodeGenerator; import cn.hutool.captcha.generator.CodeGenerator;
import cn.hutool.core.util.IdUtil; import cn.hutool.core.util.IdUtil;
import cn.hutool.core.util.RandomUtil; import cn.hutool.core.util.RandomUtil;
import cn.hutool.json.JSONObject;
import cn.hutool.json.JSONUtil;
import jakarta.validation.constraints.NotBlank; import jakarta.validation.constraints.NotBlank;
import lombok.RequiredArgsConstructor; import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.Slf4j;
@ -76,7 +78,7 @@ public class CaptchaController {
SmsResponse smsResponse = smsBlend.sendMessage(phonenumber, map); SmsResponse smsResponse = smsBlend.sendMessage(phonenumber, map);
if (!smsResponse.isSuccess()) { if (!smsResponse.isSuccess()) {
log.error("验证码短信发送异常 => {}", smsResponse); log.error("验证码短信发送异常 => {}", smsResponse);
return R.fail(smsResponse.getData().toString()); return R.fail(parseData(smsResponse));
} }
return R.ok(); return R.ok();
} }
@ -140,4 +142,35 @@ public class CaptchaController {
return R.ok(captchaVo); return R.ok(captchaVo);
} }
public static String parseData(SmsResponse smsResponse ) {
try {
JSONObject json = JSONUtil.parseObj(smsResponse.getData());
// 核心:用 JsonUtil 解析 data通过键路径 "Response.SendStatusSet[0].Code" 提取字段
// 键路径规则:层级用 "." 分隔,列表索引用 "[0]" 表示(第 1 个元素)
String code = json.getByPath("Response.SendStatusSet[0].Code", String.class);
System.out.println("错误码:" + code); // 输出FailedOperation.InsufficientBalanceInSmsPackage
return convert(code);
} catch (Exception e) {
return "短信发送未知错误";
}
}
public static String convert(String code) {
return switch (code) {
case "FailedOperation.InsufficientBalanceInSmsPackage" -> "套餐包余量不足,请购买套餐包";
case "InternalError.SendAndRecvFail" -> "短信收发超时,请检查您的网络是否有波动";
case "InvalidParameterValue.IncorrectPhoneNumber" -> "手机号格式错误";
case "LimitExceeded.AppCountryOrRegionDailyLimit" -> "业务短信国家/地区日下发条数超过设定的上限";
case "LimitExceeded.AppDailyLimit" -> "业务短信日下发条数超过设定的上限";
case "LimitExceeded.PhoneNumberDailyLimit" -> "单个手机号日下发短信条数超过设定的上限";
case "UnauthorizedOperation.ServiceSuspendDueToArrears" -> "欠费被停止服务";
case "UnsupportedOperation.UnsupportedRegion" -> "不支持该地区短信下发";
default -> "短信发送未知错误";
};
}
} }

View File

@ -41,7 +41,7 @@ spring:
api-key: sk-8d8df92fcbac4bd2922edba30b0bb8fa api-key: sk-8d8df92fcbac4bd2922edba30b0bb8fa
chat: chat:
options: options:
model: qwen-plus model: qwen3-max
datasource: datasource:
type: com.zaxxer.hikari.HikariDataSource type: com.zaxxer.hikari.HikariDataSource
# 动态数据源文档 https://www.kancloud.cn/tracy5546/dynamic-datasource/content # 动态数据源文档 https://www.kancloud.cn/tracy5546/dynamic-datasource/content
@ -59,14 +59,14 @@ spring:
driverClassName: com.mysql.cj.jdbc.Driver driverClassName: com.mysql.cj.jdbc.Driver
# jdbc 所有参数配置参考 https://lionli.blog.csdn.net/article/details/122018562 # jdbc 所有参数配置参考 https://lionli.blog.csdn.net/article/details/122018562
# rewriteBatchedStatements=true 批处理优化 大幅提升批量插入更新删除性能(对数据库有性能损耗 使用批量操作应考虑性能问题) # rewriteBatchedStatements=true 批处理优化 大幅提升批量插入更新删除性能(对数据库有性能损耗 使用批量操作应考虑性能问题)
url: jdbc:mysql://192.168.110.2:13386/xinnengyuandev-update?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 url: jdbc:mysql://192.168.110.2:13386/xinnengyuandev?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8
username: xinnengyuandev-update username: xinnengyuandev
password: cp7cAbWLZnRc6wyp password: StRWCZdZirysNSs2
# url: jdbc:mysql://192.168.110.2:13386/xinnengyuan?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 # url: jdbc:mysql://192.168.110.2:13386/xinnengyuan?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8
# username: xinnengyuan # username: xinnengyuan
# password: mEZPC5Sdf3r2HENi # password: mEZPC5Sdf3r2HENi
# 从库数据源 # 从库数据源
# slave: # slave:
# lazy: true # lazy: true
# type: ${spring.datasource.type} # type: ${spring.datasource.type}
# driverClassName: com.mysql.cj.jdbc.Driver # driverClassName: com.mysql.cj.jdbc.Driver
@ -368,3 +368,14 @@ drone:
chat: chat:
server: server:
port: 19099 port: 19099
# rabbitmq 配置
rabbitmq:
exchange-name: dev-normal-exchange
queue-name: dev-normal-queue
routing-key: dev.normal.routing.key
delay-exchange-name: dev-delay-queue
delay-queue-name: dev-delay-exchange
delay-routing-key: dev.delay.routing.key
dead-letter-exchange: dev-dlx-exchange
dead-letter-queue: dev-dlx-queue
dead-letter-routing-key: dev.dlx.routing.key

View File

@ -41,10 +41,10 @@ snail-job:
spring: spring:
ai: ai:
dashscope: dashscope:
api-key: xxx api-key: sk-8d8df92fcbac4bd2922edba30b0bb8fa
chat: chat:
options: options:
model: qwen-plus model: qwen3-max
datasource: datasource:
type: com.zaxxer.hikari.HikariDataSource type: com.zaxxer.hikari.HikariDataSource
# 动态数据源文档 https://www.kancloud.cn/tracy5546/dynamic-datasource/content # 动态数据源文档 https://www.kancloud.cn/tracy5546/dynamic-datasource/content
@ -343,3 +343,14 @@ drone:
chat: chat:
server: server:
port: 18088 port: 18088
# rabbitmq 配置
rabbitmq:
exchange-name: local-normal-exchange
queue-name: local-normal-queue
routing-key: local.normal.routing.key
delay-exchange-name: local-delay-queue
delay-queue-name: local-delay-exchange
delay-routing-key: local.delay.routing.key
dead-letter-exchange: local-dlx-exchange
dead-letter-queue: local-dlx-queue
dead-letter-routing-key: local.dlx.routing.key

View File

@ -0,0 +1,356 @@
# 开发环境配置
server:
# 服务器的HTTP端口默认为8080
port: 9528
--- # 临时文件存储位置 避免临时文件被系统清理报错
spring.servlet.multipart.location: /ruoyi/server/temp
--- # 监控中心配置
spring.boot.admin.client:
# 增加客户端开关
enabled: false
url: http://localhost:9090/admin
instance:
service-host-type: IP
metadata:
username: ${spring.boot.admin.client.username}
userpassword: ${spring.boot.admin.client.password}
username: @monitor.username@
password: @monitor.password@
--- # snail-job 配置
snail-job:
enabled: false
# 需要在 SnailJob 后台组管理创建对应名称的组,然后创建任务的时候选择对应的组,才能正确分派任务
group: "ruoyi_group"
# SnailJob 接入验证令牌 详见 script/sql/ry_job.sql `sj_group_config`表
token: "SJ_cKqBTPzCsWA3VyuCfFoccmuIEGXjr5KT"
server:
host: 127.0.0.1
port: 17888
# 命名空间UUID 详见 script/sql/ry_job.sql `sj_namespace`表`unique_id`字段
namespace: ${spring.profiles.active}
# 随主应用端口漂移
port: 2${server.port}
# 客户端ip指定
host:
# RPC类型: netty, grpc
rpc-type: grpc
--- # 数据源配置
spring:
ai:
dashscope:
api-key: sk-8d8df92fcbac4bd2922edba30b0bb8fa
chat:
options:
model: qwen3-max
datasource:
type: com.zaxxer.hikari.HikariDataSource
# 动态数据源文档 https://www.kancloud.cn/tracy5546/dynamic-datasource/content
dynamic:
# 性能分析插件(有性能损耗 不建议生产环境使用)
p6spy: false
# 设置默认的数据源或者数据源组,默认值即为 master
primary: master
# 严格模式 匹配不到数据源则报错
strict: true
datasource:
# 主库数据源
master:
type: ${spring.datasource.type}
driverClassName: com.mysql.cj.jdbc.Driver
# jdbc 所有参数配置参考 https://lionli.blog.csdn.net/article/details/122018562
# rewriteBatchedStatements=true 批处理优化 大幅提升批量插入更新删除性能(对数据库有性能损耗 使用批量操作应考虑性能问题)
url: jdbc:mysql://192.168.110.2:13386/xinnengyuanmenu?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8&autoReconnect=true&rewriteBatchedStatements=true&allowPublicKeyRetrieval=true&nullCatalogMeansCurrent=true
username: xinnengyuanmenu
password: 2RkXFG8ZE6r5LL7B
# # 从库数据源
# slave:
# lazy: true
# type: ${spring.datasource.type}
# driverClassName: com.mysql.cj.jdbc.Driver
# url: jdbc:mysql://localhost:3306/ry-vue?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8&autoReconnect=true&rewriteBatchedStatements=true&allowPublicKeyRetrieval=true&nullCatalogMeansCurrent=true
# username:
# password:
# oracle:
# type: ${spring.datasource.type}
# driverClassName: oracle.jdbc.OracleDriver
# url: jdbc:oracle:thin:@//localhost:1521/XE
# username: ROOT
# password: root
# postgres:
# type: ${spring.datasource.type}
# driverClassName: org.postgresql.Driver
# url: jdbc:postgresql://localhost:5432/postgres?useUnicode=true&characterEncoding=utf8&useSSL=true&autoReconnect=true&reWriteBatchedInserts=true
# username: root
# password: root
# sqlserver:
# type: ${spring.datasource.type}
# driverClassName: com.microsoft.sqlserver.jdbc.SQLServerDriver
# url: jdbc:sqlserver://localhost:1433;DatabaseName=tempdb;SelectMethod=cursor;encrypt=false;rewriteBatchedStatements=true
# username: SA
# password: root
hikari:
# 最大连接池数量
maxPoolSize: 20
# 最小空闲线程数量
minIdle: 10
# 配置获取连接等待超时的时间
connectionTimeout: 30000
# 校验超时时间
validationTimeout: 5000
# 空闲连接存活最大时间默认10分钟
idleTimeout: 600000
# 此属性控制池中连接的最长生命周期值0表示无限生命周期默认30分钟
maxLifetime: 1800000
# 多久检查一次连接的活性
keepaliveTime: 30000
--- # redis 单机配置(单机与集群只能开启一个另一个需要注释掉)
spring.data:
redis:
# 地址
host: 192.168.110.2
# 端口默认为6379
port: 9287
# 数据库索引
database: 21
# redis 密码必须配置
password: syar23rdsaagdrsa
# 连接超时时间
timeout: 10s
# 是否开启ssl
ssl.enabled: false
# redisson 配置
redisson:
# redis key前缀
keyPrefix:
# 线程池数量
threads: 16
# Netty线程池数量
nettyThreads: 32
# 单节点配置
singleServerConfig:
# 客户端名称
clientName: ${ruoyi.name}
# 最小空闲连接数
connectionMinimumIdleSize: 32
# 连接池大小
connectionPoolSize: 64
# 连接空闲超时,单位:毫秒
idleConnectionTimeout: 10000
# 命令等待超时,单位:毫秒
timeout: 3000
# 发布和订阅连接池大小
subscriptionConnectionPoolSize: 50
--- # mail 邮件发送
mail:
enabled: false
host: smtp.163.com
port: 465
# 是否需要用户名密码验证
auth: true
# 发送方遵循RFC-822标准
from: xxx@163.com
# 用户名注意如果使用foxmail邮箱此处user为qq号
user: xxx@163.com
# 密码注意某些邮箱需要为SMTP服务单独设置密码详情查看相关帮助
pass: xxxxxxxxxx
# 使用 STARTTLS安全连接STARTTLS是对纯文本通信协议的扩展。
starttlsEnable: true
# 使用SSL安全连接
sslEnable: true
# SMTP超时时长单位毫秒缺省值不超时
timeout: 0
# Socket连接超时值单位毫秒缺省值不超时
connectionTimeout: 0
--- # sms 短信 支持 阿里云 腾讯云 云片 等等各式各样的短信服务商
# https://sms4j.com/doc3/ 差异配置文档地址 支持单厂商多配置,可以配置多个同时使用
sms:
# 配置源类型用于标定配置来源(interface,yaml)
config-type: yaml
# 用于标定yml中的配置是否开启短信拦截接口配置不受此限制
restricted: false
# 短信拦截限制单手机号每分钟最大发送,只对开启了拦截的配置有效
minute-max: 1
# 短信拦截限制单手机号每日最大发送量,只对开启了拦截的配置有效
account-max: 30
# 以下配置来自于 org.dromara.sms4j.provider.config.BaseConfig类中
blends:
# 唯一ID 用于发送短信寻找具体配置 随便定义别用中文即可
# 可以同时存在两个相同厂商 例如: ali1 ali2 两个不同的阿里短信账号 也可用于区分租户
config1:
# 框架定义的厂商名称标识,标定此配置是哪个厂商,详细请看厂商标识介绍部分
supplier: alibaba
# 有些称为accessKey有些称之为apiKey也有称为sdkKey或者appId。
access-key-id: 您的accessKey
# 称为accessSecret有些称之为apiSecret
access-key-secret: 您的accessKeySecret
signature: 您的短信签名
sdk-app-id: 您的sdkAppId
config2:
# 登录
supplier: tencent
access-key-id: AKIDb3JK5dx4wa0DCxWqvxlKejvysZ3ITVJv
access-key-secret: c5LPFsJI8k7GDxTkoeFj4A1ukQr66rPi
signature: 重庆远界大数据研究院
sdk-app-id: 1401018866
template-id: 2491779
config3:
# 注册
supplier: tencent
access-key-id: AKIDb3JK5dx4wa0DCxWqvxlKejvysZ3ITVJv
access-key-secret: c5LPFsJI8k7GDxTkoeFj4A1ukQr66rPi
signature: 重庆远界大数据研究院
sdk-app-id: 1401018866
template-id: 2491776
config4:
# 质量工单逾期
supplier: tencent
access-key-id: AKIDb3JK5dx4wa0DCxWqvxlKejvysZ3ITVJv
access-key-secret: c5LPFsJI8k7GDxTkoeFj4A1ukQr66rPi
signature: 重庆远界大数据研究院
sdk-app-id: 1401018866
template-id: 2534747
config5:
# 设计图纸
supplier: tencent
access-key-id: AKIDb3JK5dx4wa0DCxWqvxlKejvysZ3ITVJv
access-key-secret: c5LPFsJI8k7GDxTkoeFj4A1ukQr66rPi
signature: 重庆远界大数据研究院
sdk-app-id: 1401018866
template-id: 2534750
config6:
# 安全工单
supplier: tencent
access-key-id: AKIDb3JK5dx4wa0DCxWqvxlKejvysZ3ITVJv
access-key-secret: c5LPFsJI8k7GDxTkoeFj4A1ukQr66rPi
signature: 重庆远界大数据研究院
sdk-app-id: 1401018866
template-id: 2534848
--- # 三方授权
justauth:
# 前端外网访问地址
address: http://localhost:80
type:
maxkey:
# maxkey 服务器地址
# 注意 如下均配置均不需要修改 maxkey 已经内置好了数据
server-url: http://sso.maxkey.top
client-id: 876892492581044224
client-secret: x1Y5MTMwNzIwMjMxNTM4NDc3Mzche8
redirect-uri: ${justauth.address}/social-callback?source=maxkey
topiam:
# topiam 服务器地址
server-url: http://127.0.0.1:1989/api/v1/authorize/y0q************spq***********8ol
client-id: 449c4*********937************759
client-secret: ac7***********1e0************28d
redirect-uri: ${justauth.address}/social-callback?source=topiam
scopes: [ openid, email, phone, profile ]
qq:
client-id: 10**********6
client-secret: 1f7d08**********5b7**********29e
redirect-uri: ${justauth.address}/social-callback?source=qq
union-id: false
weibo:
client-id: 10**********6
client-secret: 1f7d08**********5b7**********29e
redirect-uri: ${justauth.address}/social-callback?source=weibo
gitee:
client-id: 91436b7940090d09c72c7daf85b959cfd5f215d67eea73acbf61b6b590751a98
client-secret: 02c6fcfd70342980cd8dd2f2c06c1a350645d76c754d7a264c4e125f9ba915ac
redirect-uri: ${justauth.address}/social-callback?source=gitee
dingtalk:
client-id: 10**********6
client-secret: 1f7d08**********5b7**********29e
redirect-uri: ${justauth.address}/social-callback?source=dingtalk
baidu:
client-id: 10**********6
client-secret: 1f7d08**********5b7**********29e
redirect-uri: ${justauth.address}/social-callback?source=baidu
csdn:
client-id: 10**********6
client-secret: 1f7d08**********5b7**********29e
redirect-uri: ${justauth.address}/social-callback?source=csdn
coding:
client-id: 10**********6
client-secret: 1f7d08**********5b7**********29e
redirect-uri: ${justauth.address}/social-callback?source=coding
coding-group-name: xx
oschina:
client-id: 10**********6
client-secret: 1f7d08**********5b7**********29e
redirect-uri: ${justauth.address}/social-callback?source=oschina
alipay_wallet:
client-id: 10**********6
client-secret: 1f7d08**********5b7**********29e
redirect-uri: ${justauth.address}/social-callback?source=alipay_wallet
alipay-public-key: MIIB**************DAQAB
wechat_open:
client-id: 10**********6
client-secret: 1f7d08**********5b7**********29e
redirect-uri: ${justauth.address}/social-callback?source=wechat_open
wechat_mp:
client-id: 10**********6
client-secret: 1f7d08**********5b7**********29e
redirect-uri: ${justauth.address}/social-callback?source=wechat_mp
wechat_enterprise:
client-id: 10**********6
client-secret: 1f7d08**********5b7**********29e
redirect-uri: ${justauth.address}/social-callback?source=wechat_enterprise
agent-id: 1000002
gitlab:
client-id: 10**********6
client-secret: 1f7d08**********5b7**********29e
redirect-uri: ${justauth.address}/social-callback?source=gitlab
# 和风天气 https://dev.qweather.com/
weather:
key-id: T65EAABUXC
project-id: 2JTHPUQ5YY
private-key: MC4CAQAwBQYDK2VwBCIEIMAglX7IsxYiTeM+FXXnvCUsIggajeP4s8gAllewm6BN
api-host: n35rk53njv.re.qweatherapi.com
# dxf转 geojson 执行文件名
dxf2GeoJson:
file-name: main
ys7:
app-key: xxx
app-secret: xxx
job:
capture-enabled: false # 控制是否启用萤石抓拍任务
device-sync-enabled: false # 控制是否同步萤石设备
# 斯巴达算法
sparta:
url: http://119.3.204.120:8040
client-id: test
client-secret: 115fcb08fa6742a1b086d9bb80a6ad59
# 身份证加密密钥32 位)
id-card:
encrypt-key: 7ae260d150a14027d2238a1cf80a48ef
recognizer:
url: http://192.168.110.5:50071
qrCode:
url: http://xny.yj-3d.com:7788
# 无人机大图
drone:
url: http://192.168.110.2:9512
# 聊天服务
chat:
server:
port: 17077
# rabbitmq 配置
rabbitmq:
exchange-name: menu-normal-exchange
queue-name: menu-normal-queue
routing-key: menu.normal.routing.key
delay-exchange-name: menu-delay-queue
delay-queue-name: menu-delay-exchange
delay-routing-key: menu.delay.routing.key
dead-letter-exchange: menu-dlx-exchange
dead-letter-queue: menu-dlx-queue
dead-letter-routing-key: menu.dlx.routing.key

View File

@ -358,3 +358,14 @@ drone:
chat: chat:
server: server:
port: 19099 port: 19099
# rabbitmq 配置
rabbitmq:
exchange-name: prod-normal-exchange
queue-name: prod-normal-queue
routing-key: prod.normal.routing.key
delay-exchange-name: prod-delay-queue
delay-queue-name: prod-delay-exchange
delay-routing-key: prod.delay.routing.key
dead-letter-exchange: prod-dlx-exchange
dead-letter-queue: prod-dlx-queue
dead-letter-routing-key: prod.dlx.routing.key

View File

@ -76,9 +76,9 @@ spring:
servlet: servlet:
multipart: multipart:
# 单个文件大小 # 单个文件大小
max-file-size: 200MB max-file-size: 1024MB
# 设置总上传的文件大小 # 设置总上传的文件大小
max-request-size: 200MB max-request-size: 1024MB
mvc: mvc:
# 设置静态资源路径 防止所有请求都去查静态资源 # 设置静态资源路径 防止所有请求都去查静态资源
static-path-pattern: /static/** static-path-pattern: /static/**
@ -95,7 +95,13 @@ spring:
deserialization: deserialization:
# 允许对象忽略json中不存在的属性 # 允许对象忽略json中不存在的属性
fail_on_unknown_properties: false fail_on_unknown_properties: false
rabbitmq:
host: 192.168.110.2
port: 5672
username: admin
password: yuanjiexny
publisher-returns: true
publisher-confirm-type: correlated
# Sa-Token配置 # Sa-Token配置
sa-token: sa-token:
# token名称 (同时也是cookie名称) # token名称 (同时也是cookie名称)
@ -109,7 +115,7 @@ sa-token:
# token有效期单位s 默认30天, -1代表永不过期 # token有效期单位s 默认30天, -1代表永不过期
timeout: 2592000 timeout: 2592000
# token临时有效期 (指定时间内无操作就视为token过期) 单位: 秒 # token临时有效期 (指定时间内无操作就视为token过期) 单位: 秒
active-timeout: 86400 active-timeout: 2592000
# 同一账号最大登录数量,-1代表不限 # 同一账号最大登录数量,-1代表不限
max-login-count: -1 max-login-count: -1
@ -176,7 +182,7 @@ mybatis-plus:
# 数据加密 # 数据加密
mybatis-encryptor: mybatis-encryptor:
# 是否开启加密 # 是否开启加密
enable: false enable: true
# 默认加密算法 # 默认加密算法
algorithm: BASE64 algorithm: BASE64
# 编码方式 BASE64/HEX。默认BASE64 # 编码方式 BASE64/HEX。默认BASE64
@ -305,6 +311,12 @@ springdoc:
packages-to-scan: org.dromara.ai packages-to-scan: org.dromara.ai
- group: 31.投标管理模块 - group: 31.投标管理模块
packages-to-scan: org.dromara.bidding packages-to-scan: org.dromara.bidding
- group: 32.设备模块
packages-to-scan: org.dromara.device
- group: 33.摄像头模块
packages-to-scan: org.dromara.other
- group: 34.机械模块
packages-to-scan: org.dromara.mechanical
# knife4j的增强配置不需要增强可以不配 # knife4j的增强配置不需要增强可以不配
knife4j: knife4j:
enable: true enable: true

View File

@ -1,14 +1,23 @@
package org.dromara.test; package org.dromara.test;
import cn.hutool.json.JSONUtil;
import jakarta.annotation.Resource; import jakarta.annotation.Resource;
import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.Slf4j;
import org.dromara.common.core.utils.StringUtils;
import org.dromara.manager.recognizermanager.RecognizerManager; import org.dromara.manager.recognizermanager.RecognizerManager;
import org.dromara.manager.recognizermanager.enums.RecognizerTypeEnum; import org.dromara.manager.recognizermanager.enums.RecognizerTypeEnum;
import org.dromara.manager.recognizermanager.vo.RecognizeVo; import org.dromara.manager.recognizermanager.vo.RecognizeVo;
import org.dromara.progress.domain.PgsProgressPlanDetail;
import org.dromara.progress.domain.vo.progressplandetail.PgsProgressPlanDetailFinishedVo;
import org.dromara.progress.service.IPgsProgressPlanDetailService;
import org.dromara.progress.service.IPgsProgressPlanService;
import org.junit.jupiter.api.Test; import org.junit.jupiter.api.Test;
import org.springframework.boot.test.context.SpringBootTest; import org.springframework.boot.test.context.SpringBootTest;
import java.math.BigDecimal;
import java.util.List; import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;
/** /**
* @author lilemy * @author lilemy
@ -21,6 +30,12 @@ public class RecognizerTest {
@Resource @Resource
private RecognizerManager recognizerManager; private RecognizerManager recognizerManager;
@Resource
private IPgsProgressPlanDetailService progressPlanDetailService;
@Resource
private IPgsProgressPlanService progressPlanService;
@Test @Test
void test() { void test() {
RecognizeVo recognize = recognizerManager.recognize("http://xny.yj-3d.com:7363/file/tif/20250625160218orthophoto.png", List.of(RecognizerTypeEnum.PANEL)); RecognizeVo recognize = recognizerManager.recognize("http://xny.yj-3d.com:7363/file/tif/20250625160218orthophoto.png", List.of(RecognizerTypeEnum.PANEL));
@ -31,4 +46,39 @@ public class RecognizerTest {
void testChange() { void testChange() {
recognizerManager.convertCoordinate("http://xny.yj-3d.com:9000/xinnengyuan-dev/2025/11/11/d48767a62bc04867a552e06ba6712004.tif", List.of()); recognizerManager.convertCoordinate("http://xny.yj-3d.com:9000/xinnengyuan-dev/2025/11/11/d48767a62bc04867a552e06ba6712004.tif", List.of());
} }
@Test
void checkNumber() {
List<PgsProgressPlanDetail> detailList = progressPlanDetailService.list();
List<PgsProgressPlanDetail> planDetailList = detailList.stream()
.filter(detail -> StringUtils.isNotBlank(detail.getFinishedDetail()))
.toList();
Map<String, List<PgsProgressPlanDetail>> collect = planDetailList.stream()
.collect(Collectors.groupingBy(PgsProgressPlanDetail::getFinishedDetail));
// 遍历分组结果,输出重复项
for (Map.Entry<String, List<PgsProgressPlanDetail>> entry : collect.entrySet()) {
String fieldValue = entry.getKey();
List<PgsProgressPlanDetail> duplicates = entry.getValue();
if (duplicates.size() > 1) { // 筛选出有重复的字段值
PgsProgressPlanDetail first = duplicates.getFirst();
Long id = first.getId();
Long planId = first.getProgressPlanId();
progressPlanService.removeById(planId);
progressPlanDetailService.removeById(id);
System.out.println("重复对象的对象:" + duplicates.stream().map(PgsProgressPlanDetail::getId).toList());
}
}
for (PgsProgressPlanDetail detail : detailList) {
BigDecimal aiFill = detail.getFinishedNumber();
String finishedDetail = detail.getFinishedDetail();
if (StringUtils.isBlank(finishedDetail)) {
continue;
}
// log.info("id: {}, finishedDetail: {}", detail.getId(), finishedDetail);
List<PgsProgressPlanDetailFinishedVo> finishedVos = JSONUtil.toList(finishedDetail, PgsProgressPlanDetailFinishedVo.class);
if (aiFill.compareTo(BigDecimal.valueOf(finishedVos.size())) != 0) {
log.info("数量异常:{}{}", detail.getId(), detail.getProgressCategoryId());
}
}
}
} }

View File

@ -59,6 +59,18 @@ public class AsyncConfig implements AsyncConfigurer {
return executor; return executor;
} }
// 解压线程池(大文件操作,不需要太多线程)
@Bean("unzipExecutor")
public Executor unzipExecutor() {
ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();
executor.setCorePoolSize(2);
executor.setMaxPoolSize(4);
executor.setQueueCapacity(10);
executor.setThreadNamePrefix("unzip-");
executor.initialize();
return executor;
}
/** /**
* 异步执行异常处理 * 异步执行异常处理
*/ */

View File

@ -1,45 +0,0 @@
package org.dromara.common.core.domain.dto;
import lombok.Data;
import java.io.Serial;
import java.io.Serializable;
/**
* 流程实例业务扩展对象
*
* @author may
* @date 2025-08-05
*/
@Data
public class FlowInstanceBizExtDTO implements Serializable {
@Serial
private static final long serialVersionUID = 1L;
/**
* 主键
*/
private Long id;
/**
* 流程实例ID
*/
private Long instanceId;
/**
* 业务ID
*/
private String businessId;
/**
* 业务编码
*/
private String businessCode;
/**
* 业务标题
*/
private String businessTitle;
}

View File

@ -1,7 +1,6 @@
package org.dromara.common.core.domain.dto; package org.dromara.common.core.domain.dto;
import cn.hutool.core.util.ObjectUtil;
import lombok.Data; import lombok.Data;
import java.io.Serial; import java.io.Serial;
@ -31,21 +30,11 @@ public class StartProcessDTO implements Serializable {
*/ */
private String flowCode; private String flowCode;
/**
* 办理人(可不填 用于覆盖当前节点办理人)
*/
private String handler;
/** /**
* 流程变量,前端会提交一个元素{'entity': {业务详情数据对象}} * 流程变量,前端会提交一个元素{'entity': {业务详情数据对象}}
*/ */
private Map<String, Object> variables; private Map<String, Object> variables;
/**
* 流程业务扩展信息
*/
private FlowInstanceBizExtDTO bizExt;
public Map<String, Object> getVariables() { public Map<String, Object> getVariables() {
if (variables == null) { if (variables == null) {
return new HashMap<>(16); return new HashMap<>(16);
@ -53,11 +42,4 @@ public class StartProcessDTO implements Serializable {
variables.entrySet().removeIf(entry -> Objects.isNull(entry.getValue())); variables.entrySet().removeIf(entry -> Objects.isNull(entry.getValue()));
return variables; return variables;
} }
public FlowInstanceBizExtDTO getBizExt() {
if (ObjectUtil.isNull(bizExt)) {
bizExt = new FlowInstanceBizExtDTO();
}
return bizExt;
}
} }

View File

@ -52,23 +52,21 @@ public class TaskAssigneeDTO implements Serializable {
*/ */
public static <T> List<TaskHandler> convertToHandlerList( public static <T> List<TaskHandler> convertToHandlerList(
List<T> sourceList, List<T> sourceList,
Function<T, String> storageId, Function<T, Long> storageId,
Function<T, String> handlerCode, Function<T, String> handlerCode,
Function<T, String> handlerName, Function<T, String> handlerName,
Function<T, String> groupName, Function<T, Long> groupName,
Function<T, Date> createTimeMapper) { Function<T, Date> createTimeMapper) {
return sourceList.stream() return sourceList.stream()
.map(item -> new TaskHandler( .map(item -> new TaskHandler(
storageId.apply(item), String.valueOf(storageId.apply(item)),
handlerCode.apply(item), handlerCode.apply(item),
handlerName.apply(item), handlerName.apply(item),
groupName.apply(item), groupName != null ? String.valueOf(groupName.apply(item)) : null,
createTimeMapper.apply(item) createTimeMapper.apply(item)
)).collect(Collectors.toList()); )).collect(Collectors.toList());
} }
@Data @Data
@NoArgsConstructor @NoArgsConstructor
@AllArgsConstructor @AllArgsConstructor

View File

@ -62,10 +62,4 @@ public class ProcessEvent implements Serializable {
*/ */
private Boolean submit; private Boolean submit;
/**
* 实例id
*/
private Long instanceId;
} }

View File

@ -4,7 +4,6 @@ import lombok.Data;
import java.io.Serial; import java.io.Serial;
import java.io.Serializable; import java.io.Serializable;
import java.util.Map;
/** /**
* 流程办理监听 * 流程办理监听
@ -57,14 +56,4 @@ public class ProcessTaskEvent implements Serializable {
*/ */
private String status; private String status;
/**
* 实例id
*/
private Long instanceId;
/**
* 办理参数
*/
private Map<String, Object> params;
} }

View File

@ -1,6 +1,5 @@
package org.dromara.common.core.exception; package org.dromara.common.core.exception;
import cn.hutool.core.text.StrFormatter;
import lombok.*; import lombok.*;
import java.io.Serial; import java.io.Serial;
@ -57,8 +56,4 @@ public final class ServiceException extends RuntimeException {
this.detailMessage = detailMessage; this.detailMessage = detailMessage;
return this; return this;
} }
public ServiceException(String message, Object... args) {
this.message = StrFormatter.format(message, args);
}
} }

View File

@ -82,7 +82,6 @@ public interface WorkflowService {
* completeTask.getVariables().put("ignore", true); * completeTask.getVariables().put("ignore", true);
* *
* @param completeTask 参数 * @param completeTask 参数
* @return 结果
*/ */
boolean completeTask(CompleteTaskDTO completeTask); boolean completeTask(CompleteTaskDTO completeTask);
@ -91,15 +90,6 @@ public interface WorkflowService {
* *
* @param taskId 任务ID * @param taskId 任务ID
* @param message 办理意见 * @param message 办理意见
* @return 结果
*/ */
boolean completeTask(Long taskId, String message); boolean completeTask(Long taskId, String message);
/**
* 启动流程并办理第一个任务
*
* @param startProcess 参数
* @return 结果
*/
boolean startCompleteTask(StartProcessDTO startProcess);
} }

View File

@ -0,0 +1,6 @@
package org.dromara.common.core.service;
public interface XzdSjContractInfoService {
String selectNameByIds(String ids);
}

View File

@ -7,6 +7,7 @@ import lombok.NoArgsConstructor;
import java.util.*; import java.util.*;
import java.util.function.BiFunction; import java.util.function.BiFunction;
import java.util.function.Consumer;
import java.util.function.Function; import java.util.function.Function;
import java.util.function.Predicate; import java.util.function.Predicate;
import java.util.stream.Collectors; import java.util.stream.Collectors;
@ -30,10 +31,8 @@ public class StreamUtils {
if (CollUtil.isEmpty(collection)) { if (CollUtil.isEmpty(collection)) {
return CollUtil.newArrayList(); return CollUtil.newArrayList();
} }
return collection.stream()
.filter(function)
// 注意此处不要使用 .toList() 新语法 因为返回的是不可变List 会导致序列化问题 // 注意此处不要使用 .toList() 新语法 因为返回的是不可变List 会导致序列化问题
.collect(Collectors.toList()); return collection.stream().filter(function).collect(Collectors.toList());
} }
/** /**
@ -41,26 +40,13 @@ public class StreamUtils {
* *
* @param collection 需要查询的集合 * @param collection 需要查询的集合
* @param function 过滤方法 * @param function 过滤方法
* @return 找到符合条件的第一个元素,没有则返回 Optional.empty() * @return 找到符合条件的第一个元素,没有则返回null
*/ */
public static <E> Optional<E> findFirst(Collection<E> collection, Predicate<E> function) { public static <E> E findFirst(Collection<E> collection, Predicate<E> function) {
if (CollUtil.isEmpty(collection)) { if (CollUtil.isEmpty(collection)) {
return Optional.empty(); return null;
} }
return collection.stream() return collection.stream().filter(function).findFirst().orElse(null);
.filter(function)
.findFirst();
}
/**
* 找到流中满足条件的第一个元素值
*
* @param collection 需要查询的集合
* @param function 过滤方法
* @return 找到符合条件的第一个元素,没有则返回 null
*/
public static <E> E findFirstValue(Collection<E> collection, Predicate<E> function) {
return findFirst(collection,function).orElse(null);
} }
/** /**
@ -68,26 +54,13 @@ public class StreamUtils {
* *
* @param collection 需要查询的集合 * @param collection 需要查询的集合
* @param function 过滤方法 * @param function 过滤方法
* @return 找到符合条件的任意一个元素,没有则返回 Optional.empty() * @return 找到符合条件的任意一个元素,没有则返回null
*/ */
public static <E> Optional<E> findAny(Collection<E> collection, Predicate<E> function) { public static <E> Optional<E> findAny(Collection<E> collection, Predicate<E> function) {
if (CollUtil.isEmpty(collection)) { if (CollUtil.isEmpty(collection)) {
return Optional.empty(); return Optional.empty();
} }
return collection.stream() return collection.stream().filter(function).findAny();
.filter(function)
.findAny();
}
/**
* 找到流中任意一个满足条件的元素值
*
* @param collection 需要查询的集合
* @param function 过滤方法
* @return 找到符合条件的任意一个元素没有则返回null
*/
public static <E> E findAnyValue(Collection<E> collection, Predicate<E> function) {
return findAny(collection,function).orElse(null);
} }
/** /**
@ -113,10 +86,7 @@ public class StreamUtils {
if (CollUtil.isEmpty(collection)) { if (CollUtil.isEmpty(collection)) {
return StringUtils.EMPTY; return StringUtils.EMPTY;
} }
return collection.stream() return collection.stream().map(function).filter(Objects::nonNull).collect(Collectors.joining(delimiter));
.map(function)
.filter(Objects::nonNull)
.collect(Collectors.joining(delimiter));
} }
/** /**
@ -130,11 +100,8 @@ public class StreamUtils {
if (CollUtil.isEmpty(collection)) { if (CollUtil.isEmpty(collection)) {
return CollUtil.newArrayList(); return CollUtil.newArrayList();
} }
return collection.stream()
.filter(Objects::nonNull)
.sorted(comparing)
// 注意此处不要使用 .toList() 新语法 因为返回的是不可变List 会导致序列化问题 // 注意此处不要使用 .toList() 新语法 因为返回的是不可变List 会导致序列化问题
.collect(Collectors.toList()); return collection.stream().filter(Objects::nonNull).sorted(comparing).collect(Collectors.toList());
} }
/** /**
@ -151,9 +118,7 @@ public class StreamUtils {
if (CollUtil.isEmpty(collection)) { if (CollUtil.isEmpty(collection)) {
return MapUtil.newHashMap(); return MapUtil.newHashMap();
} }
return collection.stream() return collection.stream().filter(Objects::nonNull).collect(Collectors.toMap(key, Function.identity(), (l, r) -> l));
.filter(Objects::nonNull)
.collect(Collectors.toMap(key, Function.identity(), (l, r) -> l));
} }
/** /**
@ -172,25 +137,7 @@ public class StreamUtils {
if (CollUtil.isEmpty(collection)) { if (CollUtil.isEmpty(collection)) {
return MapUtil.newHashMap(); return MapUtil.newHashMap();
} }
return collection.stream() return collection.stream().filter(Objects::nonNull).collect(Collectors.toMap(key, value, (l, r) -> l));
.filter(Objects::nonNull)
.collect(Collectors.toMap(key, value, (l, r) -> l));
}
/**
* 获取 map 中的数据作为新 Map 的 value key 不变
* @param map 需要处理的map
* @param take 取值函数
* @param <K> map中的key类型
* @param <E> map中的value类型
* @param <V> 新map中的value类型
* @return 新的map
*/
public static <K, E, V> Map<K, V> toMap(Map<K, E> map, BiFunction<K, E, V> take) {
if (CollUtil.isEmpty(map)) {
return MapUtil.newHashMap();
}
return toMap(map.entrySet(), Map.Entry::getKey, entry -> take.apply(entry.getKey(), entry.getValue()));
} }
/** /**
@ -207,8 +154,8 @@ public class StreamUtils {
if (CollUtil.isEmpty(collection)) { if (CollUtil.isEmpty(collection)) {
return MapUtil.newHashMap(); return MapUtil.newHashMap();
} }
return collection.stream() return collection
.filter(Objects::nonNull) .stream().filter(Objects::nonNull)
.collect(Collectors.groupingBy(key, LinkedHashMap::new, Collectors.toList())); .collect(Collectors.groupingBy(key, LinkedHashMap::new, Collectors.toList()));
} }
@ -228,8 +175,8 @@ public class StreamUtils {
if (CollUtil.isEmpty(collection)) { if (CollUtil.isEmpty(collection)) {
return MapUtil.newHashMap(); return MapUtil.newHashMap();
} }
return collection.stream() return collection
.filter(Objects::nonNull) .stream().filter(Objects::nonNull)
.collect(Collectors.groupingBy(key1, LinkedHashMap::new, Collectors.groupingBy(key2, LinkedHashMap::new, Collectors.toList()))); .collect(Collectors.groupingBy(key1, LinkedHashMap::new, Collectors.groupingBy(key2, LinkedHashMap::new, Collectors.toList())));
} }
@ -246,11 +193,11 @@ public class StreamUtils {
* @return 分类后的map * @return 分类后的map
*/ */
public static <E, T, U> Map<T, Map<U, E>> group2Map(Collection<E> collection, Function<E, T> key1, Function<E, U> key2) { public static <E, T, U> Map<T, Map<U, E>> group2Map(Collection<E> collection, Function<E, T> key1, Function<E, U> key2) {
if (CollUtil.isEmpty(collection)) { if (CollUtil.isEmpty(collection) || key1 == null || key2 == null) {
return MapUtil.newHashMap(); return MapUtil.newHashMap();
} }
return collection.stream() return collection
.filter(Objects::nonNull) .stream().filter(Objects::nonNull)
.collect(Collectors.groupingBy(key1, LinkedHashMap::new, Collectors.toMap(key2, Function.identity(), (l, r) -> l))); .collect(Collectors.groupingBy(key1, LinkedHashMap::new, Collectors.toMap(key2, Function.identity(), (l, r) -> l)));
} }
@ -268,7 +215,8 @@ public class StreamUtils {
if (CollUtil.isEmpty(collection)) { if (CollUtil.isEmpty(collection)) {
return CollUtil.newArrayList(); return CollUtil.newArrayList();
} }
return collection.stream() return collection
.stream()
.map(function) .map(function)
.filter(Objects::nonNull) .filter(Objects::nonNull)
// 注意此处不要使用 .toList() 新语法 因为返回的是不可变List 会导致序列化问题 // 注意此处不要使用 .toList() 新语法 因为返回的是不可变List 会导致序列化问题
@ -286,10 +234,11 @@ public class StreamUtils {
* @return 转化后的Set * @return 转化后的Set
*/ */
public static <E, T> Set<T> toSet(Collection<E> collection, Function<E, T> function) { public static <E, T> Set<T> toSet(Collection<E> collection, Function<E, T> function) {
if (CollUtil.isEmpty(collection)) { if (CollUtil.isEmpty(collection) || function == null) {
return CollUtil.newHashSet(); return CollUtil.newHashSet();
} }
return collection.stream() return collection
.stream()
.map(function) .map(function)
.filter(Objects::nonNull) .filter(Objects::nonNull)
.collect(Collectors.toSet()); .collect(Collectors.toSet());
@ -309,20 +258,26 @@ public class StreamUtils {
* @return 合并后的map * @return 合并后的map
*/ */
public static <K, X, Y, V> Map<K, V> merge(Map<K, X> map1, Map<K, Y> map2, BiFunction<X, Y, V> merge) { public static <K, X, Y, V> Map<K, V> merge(Map<K, X> map1, Map<K, Y> map2, BiFunction<X, Y, V> merge) {
if (CollUtil.isEmpty(map1) && CollUtil.isEmpty(map2)) { if (MapUtil.isEmpty(map1) && MapUtil.isEmpty(map2)) {
// 如果两个 map 都为空,则直接返回空的 map
return MapUtil.newHashMap(); return MapUtil.newHashMap();
} else if (CollUtil.isEmpty(map1)) { } else if (MapUtil.isEmpty(map1)) {
// 如果 map1 为空,则直接处理返回 map2 map1 = MapUtil.newHashMap();
return toMap(map2.entrySet(), Map.Entry::getKey, entry -> merge.apply(null, entry.getValue())); } else if (MapUtil.isEmpty(map2)) {
} else if (CollUtil.isEmpty(map2)) { map2 = MapUtil.newHashMap();
// 如果 map2 为空,则直接处理返回 map1
return toMap(map1.entrySet(), Map.Entry::getKey, entry -> merge.apply(entry.getValue(), null));
} }
Set<K> keySet = new HashSet<>(); Set<K> key = new HashSet<>();
keySet.addAll(map1.keySet()); key.addAll(map1.keySet());
keySet.addAll(map2.keySet()); key.addAll(map2.keySet());
return toMap(keySet, key -> key, key -> merge.apply(map1.get(key), map2.get(key))); Map<K, V> map = new HashMap<>();
for (K t : key) {
X x = map1.get(t);
Y y = map2.get(t);
V z = merge.apply(x, y);
if (z != null) {
map.put(t, z);
}
}
return map;
} }
} }

View File

@ -351,14 +351,4 @@ public class StringUtils extends org.apache.commons.lang3.StringUtils {
return noSpaces.matches("\\d+"); return noSpaces.matches("\\d+");
} }
/**
* 将可迭代对象中的元素使用逗号拼接成字符串
*
* @param iterable 可迭代对象,如 List、Set 等
* @return 拼接后的字符串
*/
public static String joinComma(Iterable<?> iterable) {
return StringUtils.join(iterable, SEPARATOR);
}
} }

View File

@ -0,0 +1,146 @@
package org.dromara.common.core.utils;
import cn.hutool.core.date.DatePattern;
import cn.hutool.core.date.DateUtil;
import cn.hutool.core.util.StrUtil;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.TimeZone;
/**
* 时间戳转换工具类(包含时分秒提取)
*/
public class TimestampUtils {
// 默认时区(东八区)
private static final TimeZone DEFAULT_TIME_ZONE = TimeZone.getTimeZone("GMT+8");
// 完整日期格式
private static final String FULL_DATE_FORMAT = "yyyy-MM-dd HH:mm:ss";
// 时分秒格式
private static final String TIME_FORMAT = "HH:mm:ss";
// 日期格式
private static final String DATE_FORMAT = "yyyy-MM-dd";
/**
* 将日期字符串转为秒级时间戳(优化版)
* 支持格式:"2025-12-03 23:59:59"、"2025-12-03"等
* @param dateStr 日期字符串
* @return 秒级时间戳
*/
public static Long parseDateToTimestamp(String dateStr) {
if (StrUtil.isBlank(dateStr)) {
return null;
}
// 使用Hutool的DateUtil进行智能解析推荐
try {
Date date = DateUtil.parse(dateStr);
return date.getTime() / 1000L; // 转为秒级时间戳
} catch (Exception e) {
throw new IllegalArgumentException(
String.format("日期格式错误:%s支持格式yyyy-MM-dd HH:mm:ss、yyyy-MM-dd等", dateStr)
);
}
}
/**
* 将时间戳转换为完整日期格式yyyy-MM-dd HH:mm:ss
*/
public static String formatTimestamp(Object timestamp) {
if (timestamp == null) {
return null;
}
String timestampStr = timestamp.toString().trim();
if (StrUtil.isBlank(timestampStr)) {
return null;
}
Long time = parseToMilliseconds(timestampStr);
SimpleDateFormat sdf = new SimpleDateFormat(FULL_DATE_FORMAT);
sdf.setTimeZone(DEFAULT_TIME_ZONE);
return sdf.format(new Date(time));
}
/**
* 提取时间戳中的时分秒部分HH:mm:ss
*/
public static String extractTime(Object timestamp) {
if (timestamp == null) {
return null;
}
String timestampStr = timestamp.toString().trim();
if (StrUtil.isBlank(timestampStr)) {
return null;
}
Long time = parseToMilliseconds(timestampStr);
SimpleDateFormat sdf = new SimpleDateFormat(TIME_FORMAT);
sdf.setTimeZone(DEFAULT_TIME_ZONE);
return sdf.format(new Date(time));
}
/**
* 提取时间戳中的日期部分yyyy-MM-dd
*/
public static String extractDate(Object timestamp) {
if (timestamp == null) {
return null;
}
String timestampStr = timestamp.toString().trim();
if (StrUtil.isBlank(timestampStr)) {
return null;
}
Long time = parseToMilliseconds(timestampStr);
SimpleDateFormat sdf = new SimpleDateFormat(DATE_FORMAT);
sdf.setTimeZone(DEFAULT_TIME_ZONE);
return sdf.format(new Date(time));
}
/**
* 解析时间戳字符串为毫秒级时间戳
*/
private static Long parseToMilliseconds(String timestampStr) {
try {
Long time = Long.parseLong(timestampStr);
// 10位秒级时间戳转为13位毫秒级
if (timestampStr.length() == 10) {
time = time * 1000;
}
return time;
} catch (NumberFormatException e) {
throw new IllegalArgumentException("时间戳格式错误:" + timestampStr);
}
}
/**
* 获取时间戳对应的小时
*/
public static int getHour(Object timestamp) {
String timeStr = extractTime(timestamp);
return Integer.parseInt(timeStr.split(":")[0]);
}
/**
* 获取时间戳对应的分钟
*/
public static int getMinute(Object timestamp) {
String timeStr = extractTime(timestamp);
return Integer.parseInt(timeStr.split(":")[1]);
}
/**
* 获取时间戳对应的秒
*/
public static int getSecond(Object timestamp) {
String timeStr = extractTime(timestamp);
return Integer.parseInt(timeStr.split(":")[2]);
}
}

View File

@ -110,15 +110,6 @@ public class SpringDocConfig {
} }
PlusPaths newPaths = new PlusPaths(); PlusPaths newPaths = new PlusPaths();
oldPaths.forEach((k, v) -> newPaths.addPathItem(finalContextPath + k, v)); oldPaths.forEach((k, v) -> newPaths.addPathItem(finalContextPath + k, v));
newPaths.forEach((s, pathItem) -> {
// 为所有接口添加鉴权
pathItem.readOperations().forEach(operation -> {
operation.addSecurityItem(new SecurityRequirement()
.addList(HttpHeaders.AUTHORIZATION)
.addList("Clientid")
);
});
});
openApi.setPaths(newPaths); openApi.setPaths(newPaths);
}; };
} }

View File

@ -73,8 +73,7 @@ public class ExcelReader {
// 从MultipartFile获取输入流 // 从MultipartFile获取输入流
try (InputStream stream = file.getInputStream(); try (InputStream stream = file.getInputStream();
org.apache.poi.ss.usermodel.Workbook workbook = isXlsx ? Workbook workbook = WorkbookFactory.create(stream)) {
new XSSFWorkbook(stream) : new HSSFWorkbook(stream)) {
for (int sheetIndex = 0; sheetIndex < workbook.getNumberOfSheets(); sheetIndex++) { for (int sheetIndex = 0; sheetIndex < workbook.getNumberOfSheets(); sheetIndex++) {
org.apache.poi.ss.usermodel.Sheet sheet = workbook.getSheetAt(sheetIndex); org.apache.poi.ss.usermodel.Sheet sheet = workbook.getSheetAt(sheetIndex);

View File

@ -91,7 +91,7 @@ public class PlusDataPermissionHandler {
DataPermissionHelper.setVariable("user", currentUser); DataPermissionHelper.setVariable("user", currentUser);
} }
// 如果是超级管理员或租户管理员,则不过滤数据 // 如果是超级管理员或租户管理员,则不过滤数据
if (LoginHelper.isSuperAdmin() || LoginHelper.isTenantAdmin()) { if (LoginHelper.isSuperAdmin()) {
return where; return where;
} }
// 构造数据过滤条件的 SQL 片段 // 构造数据过滤条件的 SQL 片段

View File

@ -82,5 +82,10 @@ public interface TransConstant {
*/ */
String XZD_CBYS_ZJHCB_ID_TO_NAME = "xzd_cbys_zjhcb_id_to_name"; String XZD_CBYS_ZJHCB_ID_TO_NAME = "xzd_cbys_zjhcb_id_to_name";
/**
* 新中大-设计合同信息id转name
*/
String XZD_SJ_CONTRACT_INFO_ID_TO_NAME = "xzd_sj_contract_info_id_to_name";
} }

View File

@ -0,0 +1,24 @@
package org.dromara.common.translation.core.impl;
import lombok.AllArgsConstructor;
import org.dromara.common.core.service.XzdSjContractInfoService;
import org.dromara.common.core.service.XzdSupplierOpenBankService;
import org.dromara.common.translation.annotation.TranslationType;
import org.dromara.common.translation.constant.TransConstant;
import org.dromara.common.translation.core.TranslationInterface;
@AllArgsConstructor
@TranslationType(type = TransConstant.XZD_SJ_CONTRACT_INFO_ID_TO_NAME)
public class XzdSjContractInfoImpl implements TranslationInterface<String> {
private final XzdSjContractInfoService xzdSjContractInfoService;
@Override
public String translation(Object key, String other) {
if (key instanceof String ids) {
return xzdSjContractInfoService.selectNameByIds(ids);
} else if (key instanceof Long id) {
return xzdSjContractInfoService.selectNameByIds(id.toString());
}
return null;
}
}

View File

@ -14,3 +14,4 @@ org.dromara.common.translation.core.impl.XzdSupplierOpenBankImpl
org.dromara.common.translation.core.impl.XzdProjectManagerApprovalImpl org.dromara.common.translation.core.impl.XzdProjectManagerApprovalImpl
org.dromara.common.translation.core.impl.XzdCbysZjhcbImpl org.dromara.common.translation.core.impl.XzdCbysZjhcbImpl
org.dromara.common.translation.core.impl.XzdJXHTTranslation org.dromara.common.translation.core.impl.XzdJXHTTranslation
org.dromara.common.translation.core.impl.XzdSjContractInfoImpl

View File

@ -29,6 +29,10 @@
<dependencies> <dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-amqp</artifactId>
</dependency>
<!-- TwelveMonkeys ImageIO 扩展 --> <!-- TwelveMonkeys ImageIO 扩展 -->
<dependency> <dependency>
<groupId>com.twelvemonkeys.imageio</groupId> <groupId>com.twelvemonkeys.imageio</groupId>

View File

@ -25,14 +25,15 @@ import java.util.concurrent.CompletableFuture;
public class DashScopeChat { public class DashScopeChat {
@Resource @Resource
private SimpleChat simpleChat; private DashScopeSimpleChat dashScopeSimpleChat;
@Resource @Resource
private IAIChatMemoryService chatMemoryService; private IAIChatMemoryService chatMemoryService;
private final ChatClient chatClient; private final ChatClient chatClient;
private static final String DEFAULT_PROMPT = "你叫煤球,是一个博学的智能聊天助手,请根据用户提问回答!"; private static final String DEFAULT_PROMPT =
"你是一名智能助手,代号为“煤球”。回答时不要提及自身身份或角色设定,除非用户主动询问;请直接提供清晰、准确、专业的回答。";
private static final String DEFAULT_FILE_DIR = System.getProperty("user.dir") + "/chat-memory"; private static final String DEFAULT_FILE_DIR = System.getProperty("user.dir") + "/chat-memory";
@ -66,10 +67,8 @@ public class DashScopeChat {
.collectList() .collectList()
.flatMapMany(tokens -> { .flatMapMany(tokens -> {
String aiResponse = String.join("", tokens); String aiResponse = String.join("", tokens);
if (isFirst) {
// 异步生成标题 // 异步生成标题
generateChatTitleAsync(chatId, message, aiResponse, userId); generateChatTitleAsync(chatId, message, aiResponse, userId);
}
// 返回完整的流结果 // 返回完整的流结果
return Flux.fromIterable(tokens); return Flux.fromIterable(tokens);
}); });
@ -100,7 +99,7 @@ public class DashScopeChat {
用户:%s 用户:%s
AI%s AI%s
""", userMessage, aiResponse); """, userMessage, aiResponse);
String title = simpleChat.doChat(prompt); String title = dashScopeSimpleChat.doChat(prompt);
log.info("用户:{} 生成标题成功:{} -> {}", userId, chatId, title); log.info("用户:{} 生成标题成功:{} -> {}", userId, chatId, title);
// 保存对话数据 // 保存对话数据
AIChatMemory memory = new AIChatMemory(); AIChatMemory memory = new AIChatMemory();

View File

@ -9,11 +9,11 @@ import org.springframework.stereotype.Component;
* @date 2025-11-04 15:26 * @date 2025-11-04 15:26
*/ */
@Component @Component
public class SimpleChat { public class DashScopeSimpleChat {
private final ChatClient dashScopeChatClient; private final ChatClient dashScopeChatClient;
public SimpleChat(ChatClient.Builder chatClientBuilder) { public DashScopeSimpleChat(ChatClient.Builder chatClientBuilder) {
this.dashScopeChatClient = chatClientBuilder this.dashScopeChatClient = chatClientBuilder
// 设置 ChatClient ChatModel Options 参数 // 设置 ChatClient ChatModel Options 参数
.defaultOptions( .defaultOptions(

View File

@ -4,6 +4,7 @@ import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.toolkit.Wrappers; 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 lombok.extern.slf4j.Slf4j;
import org.dromara.ai.domain.AIChatMemory; import org.dromara.ai.domain.AIChatMemory;
import org.dromara.ai.domain.dto.AIChatMemoryQueryReq; import org.dromara.ai.domain.dto.AIChatMemoryQueryReq;
import org.dromara.ai.domain.dto.AIChatMemoryUpdateReq; import org.dromara.ai.domain.dto.AIChatMemoryUpdateReq;
@ -13,11 +14,15 @@ import org.dromara.ai.service.IAIChatMemoryService;
import org.dromara.common.core.constant.HttpStatus; 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.StringUtils; import org.dromara.common.core.utils.StringUtils;
import org.dromara.common.core.utils.file.FileUtils;
import org.dromara.common.mybatis.core.page.PageQuery; 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.springframework.beans.BeanUtils; import org.springframework.beans.BeanUtils;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
import java.io.File;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Collection; import java.util.Collection;
import java.util.List; import java.util.List;
@ -27,6 +32,7 @@ import java.util.List;
* @author lilemy * @author lilemy
* @date 2025-11-04 * @date 2025-11-04
*/ */
@Slf4j
@Service @Service
public class AIChatMemoryServiceImpl extends ServiceImpl<AIChatMemoryMapper, AIChatMemory> public class AIChatMemoryServiceImpl extends ServiceImpl<AIChatMemoryMapper, AIChatMemory>
implements IAIChatMemoryService { implements IAIChatMemoryService {
@ -103,9 +109,42 @@ public class AIChatMemoryServiceImpl extends ServiceImpl<AIChatMemoryMapper, AIC
*/ */
@Override @Override
public Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid) { public Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid) {
if (isValid) { List<AIChatMemory> aiChatMemories = this.listByIds(ids);
//TODO 做一些业务上的校验,判断是否需要校验 if (aiChatMemories.size() != ids.size()) {
throw new ServiceException("数据不存在");
} }
return baseMapper.deleteByIds(ids) > 0; // 暂存文件路径
List<File> filesToDelete = new ArrayList<>();
for (AIChatMemory mem : aiChatMemories) {
if (StringUtils.isNotBlank(mem.getFileName())) {
File file = new File(System.getProperty("user.dir")
+ "/chat-memory/", mem.getFileName());
try {
// 防止目录穿越
if (file.getCanonicalPath().startsWith(
new File(System.getProperty("user.dir") + "/chat-memory").getCanonicalPath())) {
filesToDelete.add(file);
} else {
log.warn("危险的 filename 路径被拒绝删除: {}", mem.getFileName());
}
} catch (IOException e) {
log.warn("filename 获取失败: {}", mem.getFileName());
throw new ServiceException("文件获取失败: " + mem.getFileName());
}
}
}
// 删除数据库
boolean b = baseMapper.deleteByIds(ids) > 0;
if (!b) {
throw new ServiceException("数据库删除失败");
}
// 删除文件(非事务,不影响数据库逻辑)
for (File f : filesToDelete) {
if (f.exists() && !FileUtils.del(f)) {
log.warn("文件删除失败: {}", f.getAbsolutePath());
}
}
return true;
} }
} }

View File

@ -2,6 +2,7 @@ package org.dromara.bidding.controller;
import java.util.List; import java.util.List;
import cn.dev33.satoken.annotation.SaMode;
import lombok.RequiredArgsConstructor; import lombok.RequiredArgsConstructor;
import jakarta.servlet.http.HttpServletResponse; import jakarta.servlet.http.HttpServletResponse;
import jakarta.validation.constraints.*; import jakarta.validation.constraints.*;
@ -50,7 +51,7 @@ public class BusBiddingUserController extends BaseController {
/** /**
* 查询招投标人员列表 * 查询招投标人员列表
*/ */
@SaCheckPermission("bidding:biddingUser:getUser") @SaCheckPermission(value = {"bidding:biddingUser:list","bidding:biddingUser:query","bidding:biddingUser:add"},mode = SaMode.OR)
@GetMapping("/getUser") @GetMapping("/getUser")
public R<List<SysUser>> getUser() { public R<List<SysUser>> getUser() {
return R.ok(busBiddingUserService.getUser()); return R.ok(busBiddingUserService.getUser());

View File

@ -1,26 +1,27 @@
package org.dromara.bigscreen.controller; package org.dromara.bigscreen.controller;
import java.util.List;
import lombok.RequiredArgsConstructor;
import jakarta.servlet.http.HttpServletResponse;
import jakarta.validation.constraints.*;
import cn.dev33.satoken.annotation.SaCheckPermission; import cn.dev33.satoken.annotation.SaCheckPermission;
import jakarta.servlet.http.HttpServletResponse;
import jakarta.validation.constraints.NotEmpty;
import jakarta.validation.constraints.NotNull;
import lombok.RequiredArgsConstructor;
import org.dromara.bigscreen.domain.dto.BusBwlBo; import org.dromara.bigscreen.domain.dto.BusBwlBo;
import org.dromara.bigscreen.domain.vo.BusBwlVo; import org.dromara.bigscreen.domain.vo.BusBwlVo;
import org.dromara.bigscreen.service.IBusBwlService; import org.dromara.bigscreen.service.IBusBwlService;
import org.springframework.web.bind.annotation.*;
import org.springframework.validation.annotation.Validated;
import org.dromara.common.idempotent.annotation.RepeatSubmit;
import org.dromara.common.log.annotation.Log;
import org.dromara.common.web.core.BaseController;
import org.dromara.common.mybatis.core.page.PageQuery;
import org.dromara.common.core.domain.R; import org.dromara.common.core.domain.R;
import org.dromara.common.core.validate.AddGroup; import org.dromara.common.core.validate.AddGroup;
import org.dromara.common.core.validate.EditGroup; import org.dromara.common.core.validate.EditGroup;
import org.dromara.common.log.enums.BusinessType;
import org.dromara.common.excel.utils.ExcelUtil; 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.mybatis.core.page.PageQuery;
import org.dromara.common.mybatis.core.page.TableDataInfo; import org.dromara.common.mybatis.core.page.TableDataInfo;
import org.dromara.common.web.core.BaseController;
import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.*;
import java.util.List;
/** /**
* 备忘录 * 备忘录
@ -39,7 +40,7 @@ public class BusBwlController extends BaseController {
/** /**
* 查询备忘录列表 * 查询备忘录列表
*/ */
@SaCheckPermission("bwl:bwl:list") // @SaCheckPermission("bwl:bwl:list")
@GetMapping("/list") @GetMapping("/list")
public TableDataInfo<BusBwlVo> list(BusBwlBo bo, PageQuery pageQuery) { public TableDataInfo<BusBwlVo> list(BusBwlBo bo, PageQuery pageQuery) {
return busBwlService.queryPageList(bo, pageQuery); return busBwlService.queryPageList(bo, pageQuery);

View File

@ -1,27 +1,27 @@
package org.dromara.bigscreen.controller; package org.dromara.bigscreen.controller;
import java.util.List;
import lombok.RequiredArgsConstructor;
import jakarta.servlet.http.HttpServletResponse;
import jakarta.validation.constraints.*;
import cn.dev33.satoken.annotation.SaCheckPermission; import cn.dev33.satoken.annotation.SaCheckPermission;
import jakarta.servlet.http.HttpServletResponse;
import jakarta.validation.constraints.NotEmpty;
import jakarta.validation.constraints.NotNull;
import lombok.RequiredArgsConstructor;
import org.dromara.bigscreen.domain.dto.BusSygjBo; import org.dromara.bigscreen.domain.dto.BusSygjBo;
import org.springframework.web.bind.annotation.*; import org.dromara.bigscreen.domain.vo.BusSygjVo;
import org.springframework.validation.annotation.Validated; import org.dromara.bigscreen.service.IBusSygjService;
import org.dromara.common.idempotent.annotation.RepeatSubmit;
import org.dromara.common.log.annotation.Log;
import org.dromara.common.web.core.BaseController;
import org.dromara.common.mybatis.core.page.PageQuery;
import org.dromara.common.core.domain.R; import org.dromara.common.core.domain.R;
import org.dromara.common.core.validate.AddGroup; import org.dromara.common.core.validate.AddGroup;
import org.dromara.common.core.validate.EditGroup; import org.dromara.common.core.validate.EditGroup;
import org.dromara.common.log.enums.BusinessType;
import org.dromara.common.excel.utils.ExcelUtil; import org.dromara.common.excel.utils.ExcelUtil;
import org.dromara.bigscreen.domain.vo.BusSygjVo; import org.dromara.common.idempotent.annotation.RepeatSubmit;
import org.dromara.common.log.annotation.Log;
import org.dromara.bigscreen.service.IBusSygjService; 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.web.core.BaseController;
import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.*;
import java.util.List;
/** /**
* 实用工具 * 实用工具
@ -40,7 +40,7 @@ public class BusSygjController extends BaseController {
/** /**
* 查询实用工具列表 * 查询实用工具列表
*/ */
@SaCheckPermission("bigscreen:sygj:list") // @SaCheckPermission("bigscreen:sygj:list")
@GetMapping("/list") @GetMapping("/list")
public TableDataInfo<BusSygjVo> list(BusSygjBo bo, PageQuery pageQuery) { public TableDataInfo<BusSygjVo> list(BusSygjBo bo, PageQuery pageQuery) {
return busSygjService.queryPageList(bo, pageQuery); return busSygjService.queryPageList(bo, pageQuery);

View File

@ -1,26 +1,27 @@
package org.dromara.bigscreen.controller; package org.dromara.bigscreen.controller;
import java.util.List;
import lombok.RequiredArgsConstructor;
import jakarta.servlet.http.HttpServletResponse;
import jakarta.validation.constraints.*;
import cn.dev33.satoken.annotation.SaCheckPermission; import cn.dev33.satoken.annotation.SaCheckPermission;
import jakarta.servlet.http.HttpServletResponse;
import jakarta.validation.constraints.NotEmpty;
import jakarta.validation.constraints.NotNull;
import lombok.RequiredArgsConstructor;
import org.dromara.bigscreen.domain.dto.BusWjzxBo; import org.dromara.bigscreen.domain.dto.BusWjzxBo;
import org.springframework.web.bind.annotation.*; import org.dromara.bigscreen.domain.vo.BusWjzxVo;
import org.springframework.validation.annotation.Validated; import org.dromara.bigscreen.service.IBusWjzxService;
import org.dromara.common.idempotent.annotation.RepeatSubmit;
import org.dromara.common.log.annotation.Log;
import org.dromara.common.web.core.BaseController;
import org.dromara.common.mybatis.core.page.PageQuery;
import org.dromara.common.core.domain.R; import org.dromara.common.core.domain.R;
import org.dromara.common.core.validate.AddGroup; import org.dromara.common.core.validate.AddGroup;
import org.dromara.common.core.validate.EditGroup; import org.dromara.common.core.validate.EditGroup;
import org.dromara.common.log.enums.BusinessType;
import org.dromara.common.excel.utils.ExcelUtil; import org.dromara.common.excel.utils.ExcelUtil;
import org.dromara.bigscreen.domain.vo.BusWjzxVo; import org.dromara.common.idempotent.annotation.RepeatSubmit;
import org.dromara.bigscreen.service.IBusWjzxService; import org.dromara.common.log.annotation.Log;
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.web.core.BaseController;
import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.*;
import java.util.List;
/** /**
* 文件中心 * 文件中心
@ -39,7 +40,7 @@ public class BusWjzxController extends BaseController {
/** /**
* 查询文件中心列表 * 查询文件中心列表
*/ */
@SaCheckPermission("bigscreen:wjzx:list") // @SaCheckPermission("bigscreen:wjzx:list")
@GetMapping("/list") @GetMapping("/list")
public TableDataInfo<BusWjzxVo> list(BusWjzxBo bo, PageQuery pageQuery) { public TableDataInfo<BusWjzxVo> list(BusWjzxBo bo, PageQuery pageQuery) {
return busWjzxService.queryPageList(bo, pageQuery); return busWjzxService.queryPageList(bo, pageQuery);

View File

@ -0,0 +1,66 @@
package org.dromara.bigscreen.controller;
import lombok.RequiredArgsConstructor;
import org.dromara.bigscreen.domain.bo.DpznglBo;
import org.dromara.bigscreen.domain.vo.DpznglAqyVo;
import org.dromara.bigscreen.domain.vo.DpznglVo;
import org.dromara.bigscreen.service.DpzaglService;
import org.dromara.common.core.domain.R;
import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import java.util.List;
/**
* 大屏-质安管理
*
* @author Lion Li
* @date 2025-11-05
*/
@Validated
@RequiredArgsConstructor
@RestController
@RequestMapping("/dpzagl")
public class DpzaglController {
private final DpzaglService dpzaglService;
/**
* 查询大屏-质安管理-站班会,巡检工单,整改情况
*/
@GetMapping("/list")
public R<DpznglVo> list(DpznglBo bo) {
return R.ok(dpzaglService.queryList(bo));
}
/**
* 查询大屏-质安管理-站班会
*/
@GetMapping("/listByzbh")
public R<DpznglVo> listByzbh(DpznglBo bo) {
return R.ok(dpzaglService.listByzbh(bo));
}
/**
* 查询大屏-质安管理-安全员分布情况
*/
@GetMapping("/listByAqy")
public R<List<DpznglAqyVo>> listByAqy(DpznglBo bo) {
return R.ok(dpzaglService.listByAqy(bo));
}
}

View File

@ -0,0 +1,133 @@
package org.dromara.bigscreen.controller;
import jakarta.annotation.Resource;
import lombok.RequiredArgsConstructor;
import org.dromara.bigscreen.domain.vo.*;
import org.dromara.bigscreen.service.IMaterialsManagementService;
import org.dromara.cailiaoshebei.domain.vo.BusPurchaseDocVo;
import org.dromara.cailiaoshebei.service.IBusMrpBaseService;
import org.dromara.cailiaoshebei.service.IBusPurchaseDocService;
import org.dromara.common.core.domain.R;
import org.dromara.common.web.core.BaseController;
import org.dromara.manager.ys7manager.Ys7Manager;
import org.dromara.materials.domain.vo.materials.MatMaterialsUseDetailVo;
import org.dromara.materials.service.IMatMaterialsService;
import org.springframework.beans.factory.annotation.Autowired;
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.List;
/**
* 物资管理
*/
@Validated
@RestController
@RequiredArgsConstructor
@RequestMapping("/materialsManagement")
public class MaterialsManagementController extends BaseController {
@Autowired
private IMaterialsManagementService materialsManagementService;
@Autowired
private IBusPurchaseDocService busPurchaseDocService;
@Autowired
private IBusMrpBaseService busMrpBaseService;
@Autowired
private IMatMaterialsService materialsService;
@Resource
private Ys7Manager ys7Manager;
/**
* 库存结构分析
* @return
*/
@GetMapping("/inventoryStructureAnalysis")
public R<InventoryStructureAnalysisVo> inventoryStructureAnalysis(Long projectId) {
return R.ok(materialsManagementService.inventoryStructureAnalysis(projectId));
}
/**
* 采购单
* @return
*/
@GetMapping("/purchaseNote")
public R<List<BusPurchaseDocVo>> purchaseNote(Long projectId) {
return R.ok(busPurchaseDocService.purchaseNote(projectId));
}
/**
* 获取采购单详情
* @return
*/
@GetMapping("/purchaseNoteDetail")
public R<BusPurchaseDocVo> purchaseNoteDetail(Long id) {
return R.ok(busPurchaseDocService.queryById(id));
}
/**
* 获取采购单详情PDF
*/
@GetMapping("/purchaseNoteDetailPdf")
public R<String> purchaseNoteDetailPdf(Long id) {
return R.ok(busPurchaseDocService.queryPicBase64ById(id));
}
/**
* 设计量与到货量对比
*/
@GetMapping("/designAndArrivalComparison")
public R<List<designAndArrivalComparisonVo>> designAndArrivalComparison(Long projectId) {
return R.ok(busMrpBaseService.designAndArrivalComparison(projectId));
}
/**
* 物资需求与实际到货对比
*/
@GetMapping("/wzxqysjdhdb")
public R<List<wzxqysjdhdbVo>> wzxqysjdhdb(Long projectId) {
return R.ok(busMrpBaseService.wzxqysjdhdb(projectId));
}
/**
* 消耗趋势对比
*/
@GetMapping("/xhqsdb")
public R<List<xhqsdbVo>> xhqsdb(Long projectId) {
return R.ok(materialsManagementService.xhqsdb(projectId));
}
/**
* 获取材料使用详情列表
*/
@GetMapping("/listUseDetail")
public R<List<MatMaterialsUseDetailVo>> listUseDetail(Long projectId) {
return R.ok(materialsService.listUseDetail(projectId));
}
/**
* 仓库实时监控
*/
@GetMapping("/warehouseMonitoring")
public R<List<WarehouseMonitoringVo>> warehouseMonitoring(Long projectId) {
return R.ok(materialsManagementService.warehouseMonitoring(projectId));
}
/**
* 监控以及仓库出入库详情
*/
@GetMapping("/warehouseInAndOutDetail")
public R<List<StockInAndStockOutRecordVo>> warehouseInAndOutDetail(Long projectId, Long warehouseId) {
return R.ok(materialsManagementService.warehouseInAndOutDetail(projectId, warehouseId));
}
/**
* 获取YS7摄像头token
*/
@GetMapping("/get/token")
public R<String> getToken() {
return R.ok("操作成功", ys7Manager.getToken());
}
}

View File

@ -28,6 +28,7 @@ import org.dromara.common.core.domain.R;
import org.dromara.common.core.domain.dto.UserDTO; import org.dromara.common.core.domain.dto.UserDTO;
import org.dromara.common.core.enums.BusinessStatusEnum; import org.dromara.common.core.enums.BusinessStatusEnum;
import org.dromara.common.core.utils.StreamUtils; import org.dromara.common.core.utils.StreamUtils;
import org.dromara.common.core.utils.StringUtils;
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;
@ -37,11 +38,13 @@ import org.dromara.common.satoken.utils.LoginHelper;
import org.dromara.common.web.core.BaseController; import org.dromara.common.web.core.BaseController;
import org.dromara.patch.domain.bo.PdMasterBo; import org.dromara.patch.domain.bo.PdMasterBo;
import org.dromara.patch.domain.vo.PdMasterBymiAndQt; import org.dromara.patch.domain.vo.PdMasterBymiAndQt;
import org.dromara.patch.domain.vo.PdMasterVo;
import org.dromara.patch.service.IPdMasterService; import org.dromara.patch.service.IPdMasterService;
import org.dromara.project.domain.BusUserProjectRelevancy;
import org.dromara.project.service.IBusProjectService; import org.dromara.project.service.IBusProjectService;
import org.dromara.project.service.IBusUserProjectRelevancyService;
import org.dromara.system.domain.SysMenu; import org.dromara.system.domain.SysMenu;
import org.dromara.system.domain.vo.RouterVo; import org.dromara.system.domain.vo.RouterVo;
import org.dromara.system.mapper.SysRoleMapper;
import org.dromara.system.service.impl.SysMenuServiceImpl; import org.dromara.system.service.impl.SysMenuServiceImpl;
import org.dromara.system.service.impl.SysUserServiceImpl; import org.dromara.system.service.impl.SysUserServiceImpl;
import org.dromara.warm.flow.core.FlowEngine; import org.dromara.warm.flow.core.FlowEngine;
@ -97,9 +100,10 @@ public class PersonalHomeController extends BaseController {
@Resource @Resource
private IBusProjectService projectService; private IBusProjectService projectService;
private final SysRoleMapper roleMapper;
private final SysMenuServiceImpl sysMenuService; private final SysMenuServiceImpl sysMenuService;
private final IBusUserProjectRelevancyService userProjectRelevancyService;
// region AI 模块 // region AI 模块
/** /**
@ -191,7 +195,7 @@ public class PersonalHomeController extends BaseController {
QueryWrapper<FlowTaskBo> queryWrapper = new QueryWrapper<>(); QueryWrapper<FlowTaskBo> queryWrapper = new QueryWrapper<>();
List<Long> definitionIds = new ArrayList<>(); List<Long> definitionIds = new ArrayList<>();
if (!"0".equals(projectId)) { if (StringUtils.isNotBlank(projectId) && !"0".equals(projectId)) {
List<FlowDefinition> flowDefinitions = flowDefinitionMapper.selectList(new LambdaQueryWrapper<FlowDefinition>() List<FlowDefinition> flowDefinitions = flowDefinitionMapper.selectList(new LambdaQueryWrapper<FlowDefinition>()
.select(FlowDefinition::getId) .select(FlowDefinition::getId)
.like(FlowDefinition::getFlowCode, projectId)); .like(FlowDefinition::getFlowCode, projectId));
@ -200,9 +204,31 @@ public class PersonalHomeController extends BaseController {
definitionIds.add(flowDefinition.getId()); definitionIds.add(flowDefinition.getId());
}); });
} }
if (definitionIds.isEmpty()) { } else {
return null; // 获取当前用户的所有项目
List<BusUserProjectRelevancy> projectRelevancyList = userProjectRelevancyService.lambdaQuery()
.eq(BusUserProjectRelevancy::getUserId, LoginHelper.getUserId())
.list();
List<Long> projectIds = projectRelevancyList.stream().map(BusUserProjectRelevancy::getProjectId).distinct().toList();
if (CollUtil.isEmpty(projectIds)) {
return R.ok();
} }
LambdaQueryWrapper<FlowDefinition> lqw = new LambdaQueryWrapper<>();
lqw.select(FlowDefinition::getId);
lqw.and(w -> {
for (Long id : projectIds) {
w.or().like(FlowDefinition::getFlowCode, id);
}
});
List<FlowDefinition> flowDefinitions = flowDefinitionMapper.selectList(lqw);
if (flowDefinitions != null && !flowDefinitions.isEmpty()) {
flowDefinitions.forEach(flowDefinition -> {
definitionIds.add(flowDefinition.getId());
});
}
}
if (definitionIds.isEmpty()) {
return R.ok();
} }
queryWrapper.eq("t.node_type", NodeType.BETWEEN.getKey()); queryWrapper.eq("t.node_type", NodeType.BETWEEN.getKey());
queryWrapper.in("t.processed_by", LoginHelper.getUserIdStr()); queryWrapper.in("t.processed_by", LoginHelper.getUserIdStr());
@ -231,7 +257,7 @@ public class PersonalHomeController extends BaseController {
taskInfoDto.setTotal((long) page.size()); taskInfoDto.setTotal((long) page.size());
taskInfoDto.setWeekCount((long) weeklyTasks.size()); taskInfoDto.setWeekCount((long) weeklyTasks.size());
BusPdSjVo busPdSjVo = pdMasterService.queryPageListByDate(); BusPdSjVo busPdSjVo = pdMasterService.queryPageListByDate(projectId);
BusWjzxSjDateVo busWjzxSjDateVo = busWjzxService.queryWjzx(); BusWjzxSjDateVo busWjzxSjDateVo = busWjzxService.queryWjzx();
taskInfoDto.setBusWjzxSjDateVo(busWjzxSjDateVo); taskInfoDto.setBusWjzxSjDateVo(busWjzxSjDateVo);
@ -301,6 +327,16 @@ public class PersonalHomeController extends BaseController {
return pdMasterService.queryPageListBy(bo, pageQuery); return pdMasterService.queryPageListBy(bo, pageQuery);
} }
/**
* 获取派单详细信息
*
* @param id 主键
*/
@GetMapping("/pd/{id}")
public R<PdMasterVo> getPdInfo(@NotNull(message = "主键不能为空")
@PathVariable Long id) {
return R.ok(pdMasterService.queryById(id));
}
/** /**
* 查询备忘录列表 * 查询备忘录列表

View File

@ -0,0 +1,80 @@
package org.dromara.bigscreen.controller;
import jakarta.annotation.Resource;
import jakarta.validation.constraints.NotNull;
import lombok.RequiredArgsConstructor;
import org.dromara.bigscreen.domain.dto.ProjectImageProgressDetailReq;
import org.dromara.bigscreen.domain.progress.DesignProgressVo;
import org.dromara.bigscreen.domain.progress.MaterialProgressDetailVo;
import org.dromara.bigscreen.domain.progress.MilestoneProgressVo;
import org.dromara.bigscreen.domain.progress.ProjectTotalProgressVo;
import org.dromara.bigscreen.domain.vo.ProjectImageProgressDetailVo;
import org.dromara.bigscreen.service.ProgressBigScreenService;
import org.dromara.common.core.domain.R;
import org.dromara.common.web.core.BaseController;
import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import java.util.List;
/**
* 进度管理大屏接口
*
* @author lilemy
* @date 2025-12-15 11:35
*/
@Validated
@RestController
@RequiredArgsConstructor
@RequestMapping("/progress/big/screen")
public class ProgressBigScreenController extends BaseController {
@Resource
private ProgressBigScreenService progressBigScreenService;
/**
* 获取项目总进度
*/
@GetMapping("/projectTotalProgress/{projectId}")
public R<ProjectTotalProgressVo> getProjectTotalProgress(@NotNull(message = "项目主键不能为空")
@PathVariable Long projectId) {
return R.ok(progressBigScreenService.getProjectTotalProgress(projectId));
}
/**
* 获取里程碑进度
*/
@GetMapping("/milestoneProgress/{projectId}")
public R<List<MilestoneProgressVo>> getMilestoneProgress(@NotNull(message = "项目主键不能为空")
@PathVariable Long projectId) {
return R.ok(progressBigScreenService.getMilestoneProgress(projectId));
}
/**
* 获取设计进度
*/
@GetMapping("/designProgress/{projectId}")
public R<DesignProgressVo> getDesignProgress(@NotNull(message = "项目主键不能为空")
@PathVariable Long projectId) {
return R.ok(progressBigScreenService.getDesignProgress(projectId));
}
/**
* 获取施工进度详情
*/
@GetMapping("/constructionProgress/detail")
public R<List<ProjectImageProgressDetailVo>> getProjectTotalProgressDetail(@Validated ProjectImageProgressDetailReq req) {
return R.ok(progressBigScreenService.getProjectTotalProgressDetail(req));
}
/**
* 获取材料进度详情
*/
@GetMapping("/materialProgress/detail")
public R<List<MaterialProgressDetailVo>> getMaterialProgressDetail(Long project, String name, String specification) {
return R.ok(progressBigScreenService.getMaterialProgressDetail(project, name, specification));
}
}

View File

@ -44,7 +44,6 @@ public class SysRoleWorkController extends BaseController {
/** /**
* 查询角色流程对应列表 * 查询角色流程对应列表
*/ */
@SaCheckPermission("bigscreen:roleWork:list")
@GetMapping("/list") @GetMapping("/list")
public TableDataInfo<SysRoleWorkVo> list(SysRoleWorkBo bo, PageQuery pageQuery) { public TableDataInfo<SysRoleWorkVo> list(SysRoleWorkBo bo, PageQuery pageQuery) {
return sysRoleWorkService.queryPageList(bo, pageQuery); return sysRoleWorkService.queryPageList(bo, pageQuery);

View File

@ -0,0 +1,39 @@
package org.dromara.bigscreen.controller;
import jakarta.annotation.Resource;
import jakarta.validation.constraints.NotNull;
import lombok.RequiredArgsConstructor;
import org.dromara.bigscreen.domain.vo.ProjectPeopleVo;
import org.dromara.bigscreen.service.ProjectBigScreenService;
import org.dromara.common.core.domain.R;
import org.dromara.project.domain.vo.project.BusProjectVo;
import org.dromara.project.service.IBusProjectService;
import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
/**
* UE大屏
*
* @author Lion Li
* @date 2025-11-04
*/
@Validated
@RequiredArgsConstructor
@RestController
@RequestMapping("/UE/screen")
public class UEController {
@Resource
private IBusProjectService projectService;
@GetMapping("/projectInfo/{projectId}")
public R<BusProjectVo> getProjectPeople(@NotNull(message = "主键不能为空")
@PathVariable Long projectId) {
return R.ok(projectService.selectById(projectId));
}
}

View File

@ -37,6 +37,11 @@ public class BusSygj extends BaseEntity {
*/ */
private String gjUrl; private String gjUrl;
/**
* 项目id
*/
private Long projectId;
/** /**
* 图片id * 图片id

View File

@ -37,6 +37,10 @@ public class BusWjzx extends BaseEntity {
*/ */
private String wjId; private String wjId;
/**
* 项目id
*/
private Long projectId;
/** /**

View File

@ -0,0 +1,41 @@
package org.dromara.bigscreen.domain.bo;
import lombok.Data;
import java.io.Serializable;
import java.time.LocalDate;
@Data
public class DpznglBo implements Serializable {
/**
* 分页大小
*/
private Integer pageSize = 10;
/**
* 当前页数
*/
private Integer pageNum = 1;
/**
* 项目id
*/
private Long projectId;
/**
* 开始时间
*/
private LocalDate startDate;
/**
* 结束时间
*/
private LocalDate endDate;
}

View File

@ -9,6 +9,8 @@ import lombok.Data;
import lombok.EqualsAndHashCode; import lombok.EqualsAndHashCode;
import jakarta.validation.constraints.*; import jakarta.validation.constraints.*;
import java.util.List;
/** /**
* 实用工具业务对象 bus_sygj * 实用工具业务对象 bus_sygj
* *
@ -36,6 +38,11 @@ public class BusSygjBo extends BaseEntity {
*/ */
private String gjUrl; private String gjUrl;
/**
* 项目id
*/
private Long projectId;
private Long imgId; private Long imgId;
/** /**
@ -58,5 +65,10 @@ public class BusSygjBo extends BaseEntity {
*/ */
private String gnms; private String gnms;
/**
* 项目id
*/
private List<Long> collect;
} }

View File

@ -9,6 +9,8 @@ import lombok.Data;
import lombok.EqualsAndHashCode; import lombok.EqualsAndHashCode;
import jakarta.validation.constraints.*; import jakarta.validation.constraints.*;
import java.util.List;
/** /**
* 文件中心业务对象 bus_wjzx * 文件中心业务对象 bus_wjzx
* *
@ -31,6 +33,11 @@ public class BusWjzxBo extends BaseEntity {
*/ */
private String wjm; private String wjm;
/**
* 项目id
*/
private Long projectId;
/** /**
* 文件上传路径 * 文件上传路径
*/ */
@ -51,5 +58,7 @@ public class BusWjzxBo extends BaseEntity {
*/ */
private String auditStatus; private String auditStatus;
private List<Long> collect;
} }

View File

@ -27,4 +27,9 @@ public class ProjectImageProgressDetailReq implements Serializable {
*/ */
@NotNull(message = "进度名称不能为空") @NotNull(message = "进度名称不能为空")
private String progressName; private String progressName;
/**
* 是否查询光伏场区所有数据
*/
private Boolean isAll = false;
} }

View File

@ -0,0 +1,27 @@
package org.dromara.bigscreen.domain.progress;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import java.math.BigDecimal;
/**
* @author lilemy
* @date 2025-12-15 17:30
*/
@Data
@NoArgsConstructor
@AllArgsConstructor
public class DesignProgressMajorVo {
/**
* 专业名称
*/
private String majorName;
/**
* 完成率
*/
private BigDecimal completionRate;
}

View File

@ -0,0 +1,94 @@
package org.dromara.bigscreen.domain.progress;
import lombok.Data;
import java.io.Serial;
import java.io.Serializable;
import java.math.BigDecimal;
import java.util.List;
/**
* @author lilemy
* @date 2025-12-15 17:07
*/
@Data
public class DesignProgressVo implements Serializable {
@Serial
private static final long serialVersionUID = 379443600182489913L;
/**
* 总设计任务进度
*/
private Long totalDesignProgress;
/**
* 当前设计任务进度
*/
private Long currentDesignProgress;
/**
* 设计任务进度趋势
*/
private Boolean designProgressTrend;
/**
* 设计任务进度环比
*/
private BigDecimal designProgressRate;
/**
* 总设计
*/
private Long totalDesign;
/**
* 已审核设计
*/
private Long reviewedDesign;
/**
* 已审核设计进度趋势
*/
private Boolean reviewedDesignTrend;
/**
* 已审核设计进度环比
*/
private BigDecimal reviewedDesignRate;
/**
* 待审核设计
*/
private Long pendingDesignReview;
/**
* 待审核设计进度趋势
*/
private Boolean pendingDesignReviewTrend;
/**
* 待审核设计进度环比
*/
private BigDecimal pendingDesignReviewRate;
/**
* 已逾期设计
*/
private Long delayedDesign;
/**
* 已逾期设计进度趋势
*/
private Boolean delayedDesignTrend;
/**
* 已逾期设计进度环比
*/
private BigDecimal delayedDesignRate;
/**
* 设计专业详情
*/
List<DesignProgressMajorVo> majorList;
}

View File

@ -0,0 +1,73 @@
package org.dromara.bigscreen.domain.progress;
import lombok.Data;
import java.io.Serial;
import java.io.Serializable;
import java.math.BigDecimal;
import java.time.LocalDate;
/**
* @author lilemy
* @date 2025-12-16 17:03
*/
@Data
public class MaterialProgressDetailVo implements Serializable {
@Serial
private static final long serialVersionUID = -4499381537680421083L;
/**
* 主键id
*/
private Long id;
/**
* 名称
*/
private String name;
/**
* 数量
*/
private BigDecimal quantity;
/**
* 验收
*/
private BigDecimal acceptedQuantity;
/**
* 缺件
*/
private BigDecimal shortageQuantity;
// region 接收单数据
/**
* 表单编号
*/
private String formCode;
/**
* 合同名称
*/
private String contractName;
/**
* 订货单位
*/
private String orderingUnit;
/**
* 供货单位
*/
private String supplierUnit;
/**
* 到货时间
*/
private LocalDate arrivalDate;
// endregion
}

View File

@ -0,0 +1,64 @@
package org.dromara.bigscreen.domain.progress;
import lombok.Data;
import java.io.Serial;
import java.io.Serializable;
import java.math.BigDecimal;
import java.time.LocalDate;
/**
* @author lilemy
* @date 2025-12-15 16:15
*/
@Data
public class MilestoneProgressVo implements Serializable {
@Serial
private static final long serialVersionUID = 5731146976460407811L;
/**
* 主键 ID
*/
private Long id;
/**
* 节点名称
*/
private String nodeName;
/**
* 对应项目结构
*/
private Long projectStructure;
/**
* 对应项目结构名称
*/
private String projectStructureName;
/**
* 预计开始时间
*/
private LocalDate planStartDate;
/**
* 预计结束时间
*/
private LocalDate planEndDate;
/**
* 实际开始时间
*/
private LocalDate practicalStartDate;
/**
* 实际结束时间
*/
private LocalDate practicalEndDate;
/**
* 当前进度
*/
private BigDecimal currentProgress;
}

View File

@ -0,0 +1,37 @@
package org.dromara.bigscreen.domain.progress;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import java.math.BigDecimal;
/**
* @author lilemy
* @date 2025-12-15 14:40
*/
@Data
@NoArgsConstructor
@AllArgsConstructor
public class ProjectTotalProgressDetailVo {
/**
* 名称
*/
private String name;
/**
* 实际进度
*/
private BigDecimal actualProgress;
/**
* 计划进度
*/
private BigDecimal planProgress;
/**
* 完成率
*/
private BigDecimal completionRate;
}

View File

@ -0,0 +1,49 @@
package org.dromara.bigscreen.domain.progress;
import lombok.Data;
import java.io.Serial;
import java.io.Serializable;
import java.math.BigDecimal;
import java.util.List;
/**
* @author lilemy
* @date 2025-12-15 14:23
*/
@Data
public class ProjectTotalProgressVo implements Serializable {
@Serial
private static final long serialVersionUID = -5706098940478706815L;
/**
* 总进度
*/
private BigDecimal totalProgress;
/**
* 总计划工期(天)
*/
private Long totalPlannedDuration;
/**
* 当前计划工期(天)
*/
private Long currentPlannedDuration;
/**
* 总完成情况(万元)
*/
private BigDecimal totalCompletionAmount;
/**
* 当前完成情况(万元)
*/
private BigDecimal currentCompletionAmount;
/**
* 详情
*/
private List<ProjectTotalProgressDetailVo> detailList;
}

View File

@ -46,6 +46,11 @@ public class BusSygjVo implements Serializable {
@ExcelProperty(value = "工具路径") @ExcelProperty(value = "工具路径")
private String gjUrl; private String gjUrl;
/**
* 项目id
*/
private Long projectId;
/** /**
* 审核标志 * 审核标志
*/ */

View File

@ -46,6 +46,11 @@ public class BusWjzxVo implements Serializable {
@ExcelProperty(value = "文件上传路径") @ExcelProperty(value = "文件上传路径")
private String wjId; private String wjId;
/**
* 项目id
*/
private Long projectId;
/** /**
* 文件描述 * 文件描述
*/ */

View File

@ -1,36 +1,37 @@
package org.dromara.workflow.domain.vo; package org.dromara.bigscreen.domain.vo;
import com.google.type.Decimal;
import lombok.Data; import lombok.Data;
import org.dromara.common.translation.annotation.Translation; import org.dromara.common.translation.annotation.Translation;
import org.dromara.common.translation.constant.TransConstant; import org.dromara.common.translation.constant.TransConstant;
import java.io.Serial;
import java.io.Serializable; import java.io.Serializable;
import java.math.BigDecimal;
/**
* 抄送对象
*
* @author AprilWind
*/
@Data @Data
public class FlowCopyVo implements Serializable { public class DpznglAqyVo implements Serializable {
@Serial
private static final long serialVersionUID = 1L;
/**
* 用户id
*/
private Long userId; private Long userId;
/**
* 用户名称
*/
@Translation(type = TransConstant.USER_ID_TO_NICKNAME, mapper = "userId") @Translation(type = TransConstant.USER_ID_TO_NICKNAME, mapper = "userId")
private String userName; private String userName;
public FlowCopyVo(Long userId) { /**
this.userId = userId; * 经度
} */
private BigDecimal locLatitude;
/**
* 纬度
*/
private BigDecimal locLongitude;
/**
* 是否在岗
*/
private String sfzg ;
} }

View File

@ -0,0 +1,103 @@
package org.dromara.bigscreen.domain.vo;
import lombok.Data;
import org.dromara.quality.domain.vo.qualityinspection.QltQualityInspectionVo;
import org.dromara.safety.domain.vo.safetyinspection.HseSafetyInspectionVo;
import org.dromara.safety.domain.vo.teammeeting.HseTeamMeetingVo;
import java.io.Serializable;
import java.util.List;
@Data
public class DpznglVo implements Serializable {
/**
* 站班会
*/
private List<HseTeamMeetingVo> zbhList;
// 质量管理
/**
* 质量总数
*/
private Long zlZS;
/**
* 质量数据
*/
private List<QltQualityInspectionVo> zlList;
/**
* 质量 专项检查
*/
private Long zxjcZl;
/**
* 质量 定期检查
*/
private Long dqjcZl;
/**
* 质量 日常巡检
*/
private Long rcxjZl;
/**
* 质量 整改数量
*/
private Long zlZgsl;
/**
* 质量数据-整改
*/
private List<QltQualityInspectionVo> zlZgList;
// 安全管理
/**
* 安全总数
*/
private Long aqZS;
/**
* 安全数据
*/
private List<HseSafetyInspectionVo> aqList;
/**
* 安全 专项检查
*/
private Long zxjcAq;
/**
* 安全定期检查
*/
private Long dqjcAq;
/**
* 安全 日常巡检
*/
private Long rcxjAq;
/**
* 安全 整改数量
*/
private Long aqZgsl;
/**
* 安全数据-整改
*/
private List<HseSafetyInspectionVo> aqZgList;
}

View File

@ -0,0 +1,68 @@
package org.dromara.bigscreen.domain.vo;
import lombok.Data;
import java.io.Serializable;
import java.math.BigDecimal;
@Data
public class InventoryStructureAnalysisVo implements Serializable {
/**
* 本月入库总价
*/
public BigDecimal enterTotalPrices;
/**
* 上月入库总价
*/
public BigDecimal oldEnterTotalPrices;
/**
* 本月出库总价
*/
public BigDecimal leaveTotalPrices;
/**
* 上月出库总价
*/
public BigDecimal oldLeaveTotalPrices;
/**
* 库存总价
*/
public BigDecimal inventoryTotalPrices;
/**
* 出库总价
*/
public BigDecimal outTotalPrices;
/**
* 库存逆变器总价
*/
public BigDecimal inventoryInverterTotalPrices;
/**
* 库存箱变总价
*/
public BigDecimal inventoryBoxTransformerTotalPrices;
/**
* 库存光伏支架总价
*/
public BigDecimal inventoryPhotovoltaicSupportTotalPrices;
/**
* 库存环网柜总价
*/
public BigDecimal inventoryCircuitBreakerTotalPrices;
/**
* 当前库存总价
*/
public BigDecimal nowInventoryTotalPrices;
}

View File

@ -41,6 +41,11 @@ public class ProjectImageProgressDetailVo implements Serializable {
*/ */
private BigDecimal totalProgress; private BigDecimal totalProgress;
/**
* 完成率
*/
private BigDecimal completionRate;
/** /**
* 单位 * 单位
*/ */

View File

@ -0,0 +1,46 @@
package org.dromara.bigscreen.domain.vo;
import lombok.Data;
import java.io.Serializable;
import java.util.Date;
/**
* 仓库出入库列表
*/
@Data
public class StockInAndStockOutRecordVo implements Serializable {
/**
* id
*/
public Long id;
/**
* 材料名称
*/
public String name;
/**
* 库存数量
*/
public Long inventoryNumber;
/**
* 出入库数量
*/
public Long inAndOutNumber;
/**
* 出入库类型0、入库1、出库
*/
public String type;
/**
* 出入库时间
*/
public Date time;
/**
* 操作人
*/
public String operator;
}

View File

@ -0,0 +1,52 @@
package org.dromara.bigscreen.domain.vo;
import lombok.Data;
import java.io.Serializable;
/**
* 物资需求与实际到货对比vo
*/
@Data
public class WarehouseMonitoringVo implements Serializable {
/**
* 摄像头id
*/
public Long cameraId;
/**
* 仓库id
*/
public Long warehouseId;
/**
* 仓库名称
*/
public String name;
/**
* 摄像头序列号
*/
public String cameraSerial;
/**
* 摄像头名称
*/
public String cameraName;
/**
* 设备在线状态(0离线 1在线)
*/
private Integer status;
/**
* 状态0-关闭1-开启
*/
private Integer enable;
/**
* 摄像头最后一张抓图地址
*/
public String imgUrl;
}

View File

@ -0,0 +1,40 @@
package org.dromara.bigscreen.domain.vo;
import lombok.Data;
import java.io.Serializable;
import java.math.BigDecimal;
/**
* 设计量与到货量对比
*/
@Data
public class designAndArrivalComparisonVo implements Serializable {
/**
* 名称
*/
public String name;
/**
* 规格
*/
public String specification;
/**
* 单位
*/
public String unit;
/**
* 设计量
*/
public BigDecimal designTotalPrices;
/**
* 到货量
*/
public BigDecimal arrivalTotalPrices;
}

View File

@ -0,0 +1,35 @@
package org.dromara.bigscreen.domain.vo;
import lombok.Data;
import java.io.Serializable;
import java.math.BigDecimal;
/**
* 物资需求与实际到货对比vo
*/
@Data
public class wzxqysjdhdbVo implements Serializable {
/**
* 名称
*/
public String name;
/**
* 规格
*/
public String specification;
/**
* 设计量
*/
public BigDecimal designTotalPrices;
/**
* 到货量
*/
public BigDecimal arrivalTotalPrices;
}

View File

@ -0,0 +1,35 @@
package org.dromara.bigscreen.domain.vo;
import lombok.Data;
import java.io.Serializable;
import java.math.BigDecimal;
/**
* 物资需求与实际到货对比vo
*/
@Data
public class xhqsdbVo implements Serializable {
/**
* 名称
*/
public String name;
/**
* 规格
*/
public String specification;
/**
* 出库量
*/
public BigDecimal outTotalPrices;
/**
* 使用量
*/
public BigDecimal useTotalPrices;
}

View File

@ -0,0 +1,29 @@
package org.dromara.bigscreen.enums;
public enum DpEnum {
ZLGLLX_ZXGL("专项检查", "1"),
ZLGLLX_DQJC("定期检查", "2"),
ZLGLLX_RCXJ("日常巡检", "3"),
ZLGDZT_ZG("工单状态-整改", "2"),
RYZT_ZG("人员状态-在岗", "1"),
RYZT_LG("工单状态-离岗", "0"),
JSLX_AQY("角色类型-安全员", "SAFETY_OFFICER");
private final String TypeName;
private final String TypeValue;
public String getTypeName() {
return TypeName;
}
public String getTypeValue() {
return TypeValue;
}
DpEnum(String TypeName, String TypeValue) {
this.TypeName = TypeName;
this.TypeValue = TypeValue;
}
}

View File

@ -0,0 +1,22 @@
package org.dromara.bigscreen.enums;
public enum WuZhiEnum {
LBQ("逆变器"),
GFZJ("光伏支架"),
XB("箱变"),
HWG("环网柜");
private final String TypeName;
public String getTypeName() {
return TypeName;
}
WuZhiEnum(String TypeName) {
this.TypeName = TypeName;
}
}

View File

@ -0,0 +1,28 @@
package org.dromara.bigscreen.service;
import org.dromara.bigscreen.domain.bo.DpznglBo;
import org.dromara.bigscreen.domain.vo.DpznglAqyVo;
import org.dromara.bigscreen.domain.vo.DpznglVo;
import java.util.List;
/**
* 大屏-质安管理
*
* @author Lion Li
* @date 2025-11-05
*/
public interface DpzaglService {
/**
* 查询大屏-质安管理-站班会,巡检工单,整改情况
*/
DpznglVo queryList(DpznglBo bo);
/**
* 查询大屏-质安管理-安全员分布情况
*/
List<DpznglAqyVo> listByAqy(DpznglBo bo);
DpznglVo listByzbh(DpznglBo bo);
}

View File

@ -34,7 +34,8 @@ public interface IBusWjzxService extends IService<BusWjzx>{
* @param pageQuery 分页参数 * @param pageQuery 分页参数
* @return 文件中心分页列表 * @return 文件中心分页列表
*/ */
TableDataInfo<BusWjzxVo> queryPageList(BusWjzxBo bo, PageQuery pageQuery); /** TableDataInfo<BusWjzxVo> queryPageList(BusWjzxBo bo, PageQuery pageQuery);
/**
* 分页查询文件中心列表 * 分页查询文件中心列表
* *
* @return 文件中心分页列表 * @return 文件中心分页列表

View File

@ -0,0 +1,45 @@
package org.dromara.bigscreen.service;
import org.dromara.bigscreen.domain.vo.InventoryStructureAnalysisVo;
import org.dromara.bigscreen.domain.vo.StockInAndStockOutRecordVo;
import org.dromara.bigscreen.domain.vo.WarehouseMonitoringVo;
import org.dromara.bigscreen.domain.vo.xhqsdbVo;
import java.util.List;
/**
* 物资管理大屏Service接口
*/
public interface IMaterialsManagementService {
/**
* 库存结构分析
* @param projectId
* @return
*/
InventoryStructureAnalysisVo inventoryStructureAnalysis(Long projectId);
/**
* 消耗趋势对比
* @param projectId
* @return
*/
List<xhqsdbVo> xhqsdb(Long projectId);
/**
* 仓库实时监控
* @param projectId
* @return
*/
List<WarehouseMonitoringVo> warehouseMonitoring(Long projectId);
/**
* 仓库出入库详情
*
* @param projectId
* @param warehouseId
* @return
*/
List<StockInAndStockOutRecordVo> warehouseInAndOutDetail(Long projectId, Long warehouseId);
}

View File

@ -0,0 +1,67 @@
package org.dromara.bigscreen.service;
import org.dromara.bigscreen.domain.dto.ProjectImageProgressDetailReq;
import org.dromara.bigscreen.domain.progress.DesignProgressVo;
import org.dromara.bigscreen.domain.progress.MaterialProgressDetailVo;
import org.dromara.bigscreen.domain.progress.MilestoneProgressVo;
import org.dromara.bigscreen.domain.progress.ProjectTotalProgressVo;
import org.dromara.bigscreen.domain.vo.ProjectImageProgressDetailVo;
import org.dromara.bigscreen.domain.vo.wzxqysjdhdbVo;
import org.springframework.validation.annotation.Validated;
import java.util.List;
/**
* @author lilemy
* @date 2025-12-15 14:18
*/
public interface ProgressBigScreenService {
/**
* 获取项目总进度
*
* @param projectId 项目 id
* @return 项目总进度
*/
ProjectTotalProgressVo getProjectTotalProgress(Long projectId);
/**
* 获取施工进度详情
*
* @param req 请求参数
* @return 施工进度详情
*/
List<ProjectImageProgressDetailVo> getProjectTotalProgressDetail(@Validated ProjectImageProgressDetailReq req);
/**
* 获取里程碑进度
*
* @param projectId 项目 id
* @return 里程碑进度
*/
List<MilestoneProgressVo> getMilestoneProgress(Long projectId);
/**
* 获取设计进度
*
* @param projectId 项目 id
* @return 设计进度
*/
DesignProgressVo getDesignProgress(Long projectId);
/**
* 获取物料进度详情
*
* @param projectId 项目 id
* @return 物料进度详情
*/
List<MaterialProgressDetailVo> getMaterialProgressDetail(Long projectId, String name, String specification);
/**
* 获取物资进度
*
* @param projectId 项目 id
* @return 物资进度
*/
List<wzxqysjdhdbVo> getMaterialProgress(Long projectId);
}

View File

@ -16,6 +16,8 @@ import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import lombok.RequiredArgsConstructor; import lombok.RequiredArgsConstructor;
import org.dromara.project.domain.BusProjectDept;
import org.dromara.project.mapper.BusProjectDeptMapper;
import org.dromara.system.service.impl.SysOssServiceImpl; import org.dromara.system.service.impl.SysOssServiceImpl;
import org.springframework.context.event.EventListener; import org.springframework.context.event.EventListener;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
@ -28,6 +30,8 @@ import java.util.ArrayList;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.Collection; import java.util.Collection;
import java.util.stream.Collectors;
import java.util.stream.Stream;
/** /**
* 实用工具Service业务层处理 * 实用工具Service业务层处理
@ -44,6 +48,8 @@ public class BusSygjServiceImpl extends ServiceImpl<BusSygjMapper, BusSygj> impl
private final SysOssServiceImpl sysOssService; private final SysOssServiceImpl sysOssService;
private final BusProjectDeptMapper busProjectDeptMapper;
/** /**
* 查询实用工具 * 查询实用工具
* *
@ -64,6 +70,12 @@ public class BusSygjServiceImpl extends ServiceImpl<BusSygjMapper, BusSygj> impl
*/ */
@Override @Override
public TableDataInfo<BusSygjVo> queryPageList(BusSygjBo bo, PageQuery pageQuery) { public TableDataInfo<BusSygjVo> queryPageList(BusSygjBo bo, PageQuery pageQuery) {
// 查询改项目下的公司
if (bo.getProjectId() == null)throw new RuntimeException("项目id不能为空");
BusProjectDept busProjectDept = busProjectDeptMapper.selectOne(new LambdaQueryWrapper<BusProjectDept>().eq(BusProjectDept::getProjectId, bo.getProjectId()));
List<BusProjectDept> busProjectDepts = busProjectDeptMapper.selectList(new LambdaQueryWrapper<BusProjectDept>().eq(BusProjectDept::getDeptId, busProjectDept.getDeptId()));
List<Long> collect = busProjectDepts.stream().map(BusProjectDept::getProjectId).collect(Collectors.toList());
bo.setCollect(collect);
LambdaQueryWrapper<BusSygj> lqw = buildQueryWrapper(bo); LambdaQueryWrapper<BusSygj> lqw = buildQueryWrapper(bo);
Page<BusSygjVo> result = baseMapper.selectVoPage(pageQuery.build(), lqw); Page<BusSygjVo> result = baseMapper.selectVoPage(pageQuery.build(), lqw);
return TableDataInfo.build(result); return TableDataInfo.build(result);
@ -85,11 +97,13 @@ public class BusSygjServiceImpl extends ServiceImpl<BusSygjMapper, BusSygj> impl
Map<String, Object> params = bo.getParams(); Map<String, Object> params = bo.getParams();
LambdaQueryWrapper<BusSygj> lqw = Wrappers.lambdaQuery(); LambdaQueryWrapper<BusSygj> lqw = Wrappers.lambdaQuery();
lqw.orderByDesc(BusSygj::getId); lqw.orderByDesc(BusSygj::getId);
lqw.eq(StringUtils.isNotBlank(bo.getGjm()), BusSygj::getGjm, bo.getGjm()); lqw.like(StringUtils.isNotBlank(bo.getGjm()), BusSygj::getGjm, bo.getGjm());
lqw.eq(StringUtils.isNotBlank(bo.getGjUrl()), BusSygj::getGjUrl, bo.getGjUrl()); lqw.eq(StringUtils.isNotBlank(bo.getGjUrl()), BusSygj::getGjUrl, bo.getGjUrl());
lqw.eq(StringUtils.isNotBlank(bo.getAuditStatus()), BusSygj::getAuditStatus, bo.getAuditStatus()); lqw.eq(StringUtils.isNotBlank(bo.getAuditStatus()), BusSygj::getAuditStatus, bo.getAuditStatus());
lqw.eq(StringUtils.isNotBlank(bo.getType()), BusSygj::getType, bo.getType()); lqw.eq(StringUtils.isNotBlank(bo.getType()), BusSygj::getType, bo.getType());
lqw.eq(StringUtils.isNotBlank(bo.getGnms()), BusSygj::getGnms, bo.getGnms()); lqw.eq(StringUtils.isNotBlank(bo.getGnms()), BusSygj::getGnms, bo.getGnms());
// lqw.eq(bo.getProjectId() != null , BusSygj::getProjectId, bo.getProjectId());
lqw.in(bo.getCollect() != null , BusSygj::getProjectId, bo.getCollect());
lqw.eq(bo.getCreateBy() != null, BusSygj::getCreateBy, bo.getCreateBy()); lqw.eq(bo.getCreateBy() != null, BusSygj::getCreateBy, bo.getCreateBy());
return lqw; return lqw;
} }

View File

@ -1,33 +1,36 @@
package org.dromara.bigscreen.service.impl; package org.dromara.bigscreen.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 com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.Slf4j;
import org.dromara.bigscreen.domain.BusSygj;
import org.dromara.bigscreen.domain.BusWjzx;
import org.dromara.bigscreen.domain.dto.BusWjzxBo; import org.dromara.bigscreen.domain.dto.BusWjzxBo;
import org.dromara.bigscreen.domain.vo.BusWjzxSjDateVo; import org.dromara.bigscreen.domain.vo.BusWjzxSjDateVo;
import org.dromara.bigscreen.domain.vo.BusWjzxVo;
import org.dromara.bigscreen.mapper.BusWjzxMapper;
import org.dromara.bigscreen.service.IBusWjzxService;
import org.dromara.common.core.domain.event.ProcessDeleteEvent; import org.dromara.common.core.domain.event.ProcessDeleteEvent;
import org.dromara.common.core.domain.event.ProcessEvent; import org.dromara.common.core.domain.event.ProcessEvent;
import org.dromara.common.core.domain.event.ProcessTaskEvent; import org.dromara.common.core.domain.event.ProcessTaskEvent;
import org.dromara.common.core.utils.MapstructUtils; import org.dromara.common.core.utils.MapstructUtils;
import org.dromara.common.core.utils.StringUtils; import org.dromara.common.core.utils.StringUtils;
import org.dromara.common.mybatis.core.page.TableDataInfo;
import org.dromara.common.mybatis.core.page.PageQuery; import org.dromara.common.mybatis.core.page.PageQuery;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import org.dromara.common.mybatis.core.page.TableDataInfo;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import org.dromara.project.domain.BusProjectDept;
import com.baomidou.mybatisplus.core.toolkit.Wrappers; import org.dromara.project.mapper.BusProjectDeptMapper;
import lombok.RequiredArgsConstructor;
import org.dromara.common.satoken.utils.LoginHelper;
import org.dromara.system.service.impl.SysOssServiceImpl; import org.dromara.system.service.impl.SysOssServiceImpl;
import org.dromara.xzd.biddingManagement.biddingDocument.domain.XzdBiddingFileEstimate;
import org.dromara.xzd.biddingManagement.biddingDocument.domain.vo.XzdBiddingFileEstimateVo;
import org.springframework.context.event.EventListener; import org.springframework.context.event.EventListener;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
import org.dromara.bigscreen.domain.vo.BusWjzxVo;
import org.dromara.bigscreen.domain.BusWjzx;
import org.dromara.bigscreen.mapper.BusWjzxMapper;
import org.dromara.bigscreen.service.IBusWjzxService;
import java.time.LocalDate; import java.time.LocalDate;
import java.util.*; import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors; import java.util.stream.Collectors;
/** /**
@ -45,6 +48,8 @@ public class BusWjzxServiceImpl extends ServiceImpl<BusWjzxMapper, BusWjzx> impl
private final SysOssServiceImpl sysOssService; private final SysOssServiceImpl sysOssService;
private final BusProjectDeptMapper busProjectDeptMapper;
/** /**
* 查询文件中心 * 查询文件中心
@ -53,7 +58,7 @@ public class BusWjzxServiceImpl extends ServiceImpl<BusWjzxMapper, BusWjzx> impl
* @return 文件中心 * @return 文件中心
*/ */
@Override @Override
public BusWjzxVo queryById(Long id){ public BusWjzxVo queryById(Long id) {
return baseMapper.selectVoById(id); return baseMapper.selectVoById(id);
} }
@ -66,6 +71,13 @@ public class BusWjzxServiceImpl extends ServiceImpl<BusWjzxMapper, BusWjzx> impl
*/ */
@Override @Override
public TableDataInfo<BusWjzxVo> queryPageList(BusWjzxBo bo, PageQuery pageQuery) { public TableDataInfo<BusWjzxVo> queryPageList(BusWjzxBo bo, PageQuery pageQuery) {
// 查询改项目下的公司
if (bo.getProjectId() == null)throw new RuntimeException("项目id不能为空");
BusProjectDept busProjectDept = busProjectDeptMapper.selectOne(new LambdaQueryWrapper<BusProjectDept>().eq(BusProjectDept::getProjectId, bo.getProjectId()));
List<BusProjectDept> busProjectDepts = busProjectDeptMapper.selectList(new LambdaQueryWrapper<BusProjectDept>().eq(BusProjectDept::getDeptId, busProjectDept.getDeptId()));
List<Long> collect = busProjectDepts.stream().map(BusProjectDept::getProjectId).collect(Collectors.toList());
bo.setCollect(collect);
LambdaQueryWrapper<BusWjzx> lqw = buildQueryWrapper(bo); LambdaQueryWrapper<BusWjzx> lqw = buildQueryWrapper(bo);
Page<BusWjzxVo> result = baseMapper.selectVoPage(pageQuery.build(), lqw); Page<BusWjzxVo> result = baseMapper.selectVoPage(pageQuery.build(), lqw);
return TableDataInfo.build(result); return TableDataInfo.build(result);
@ -98,8 +110,9 @@ public class BusWjzxServiceImpl extends ServiceImpl<BusWjzxMapper, BusWjzx> impl
Map<String, Object> params = bo.getParams(); Map<String, Object> params = bo.getParams();
LambdaQueryWrapper<BusWjzx> lqw = Wrappers.lambdaQuery(); LambdaQueryWrapper<BusWjzx> lqw = Wrappers.lambdaQuery();
lqw.orderByDesc(BusWjzx::getId); lqw.orderByDesc(BusWjzx::getId);
lqw.eq(StringUtils.isNotBlank(bo.getWjm()), BusWjzx::getWjm, bo.getWjm()); lqw.like(StringUtils.isNotBlank(bo.getWjm()), BusWjzx::getWjm, bo.getWjm());
// lqw.eq(bo.getProjectId() != null, BusWjzx::getProjectId, bo.getProjectId());
lqw.in(bo.getCollect() != null , BusWjzx::getProjectId, bo.getCollect());
lqw.eq(StringUtils.isNotBlank(bo.getAuditStatus()), BusWjzx::getAuditStatus, bo.getAuditStatus()); lqw.eq(StringUtils.isNotBlank(bo.getAuditStatus()), BusWjzx::getAuditStatus, bo.getAuditStatus());
lqw.eq(bo.getCreateBy() != null, BusWjzx::getCreateBy, bo.getCreateBy()); lqw.eq(bo.getCreateBy() != null, BusWjzx::getCreateBy, bo.getCreateBy());
return lqw; return lqw;
@ -115,7 +128,7 @@ public class BusWjzxServiceImpl extends ServiceImpl<BusWjzxMapper, BusWjzx> impl
public Boolean insertByBo(BusWjzxBo bo) { public Boolean insertByBo(BusWjzxBo bo) {
BusWjzx add = MapstructUtils.convert(bo, BusWjzx.class); BusWjzx add = MapstructUtils.convert(bo, BusWjzx.class);
validEntityBeforeSave(add); validEntityBeforeSave(add);
if (add != null && StringUtils.isNotBlank(add.getWjm())){ if (add != null && StringUtils.isNotBlank(add.getWjm())) {
String[] split = add.getWjm().split("\\."); String[] split = add.getWjm().split("\\.");
add.setWjlx(split[split.length - 1]); add.setWjlx(split[split.length - 1]);
} }
@ -142,7 +155,7 @@ public class BusWjzxServiceImpl extends ServiceImpl<BusWjzxMapper, BusWjzx> impl
/** /**
* 保存前的数据校验 * 保存前的数据校验
*/ */
private void validEntityBeforeSave(BusWjzx entity){ private void validEntityBeforeSave(BusWjzx entity) {
//TODO 做一些数据校验,如唯一约束 //TODO 做一些数据校验,如唯一约束
} }
@ -155,7 +168,7 @@ public class BusWjzxServiceImpl extends ServiceImpl<BusWjzxMapper, BusWjzx> impl
*/ */
@Override @Override
public Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid) { public Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid) {
if(isValid){ if (isValid) {
//TODO 做一些业务上的校验,判断是否需要校验 //TODO 做一些业务上的校验,判断是否需要校验
} }
ArrayList<Long> temp = new ArrayList<>(); ArrayList<Long> temp = new ArrayList<>();

View File

@ -0,0 +1,244 @@
package org.dromara.bigscreen.service.impl;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j;
import org.dromara.bigscreen.domain.bo.DpznglBo;
import org.dromara.bigscreen.domain.vo.DpznglAqyVo;
import org.dromara.bigscreen.domain.vo.DpznglVo;
import org.dromara.bigscreen.enums.DpEnum;
import org.dromara.bigscreen.service.DpzaglService;
import org.dromara.common.core.service.UserService;
import org.dromara.common.core.utils.MapstructUtils;
import org.dromara.common.domain.GeoPoint;
import org.dromara.common.mybatis.core.page.PageQuery;
import org.dromara.common.mybatis.core.page.TableDataInfo;
import org.dromara.common.utils.JSTUtil;
import org.dromara.gps.domain.GpsEquipmentSon;
import org.dromara.gps.mapper.GpsEquipmentSonMapper;
import org.dromara.gps.service.IGpsEquipmentSonService;
import org.dromara.project.domain.BusProjectPunchrange;
import org.dromara.project.domain.BusUserProjectRelevancy;
import org.dromara.project.mapper.BusUserProjectRelevancyMapper;
import org.dromara.project.service.IBusProjectPunchrangeService;
import org.dromara.quality.domain.QltQualityInspection;
import org.dromara.quality.domain.dto.qualityinspection.QltQualityInspectionQueryReq;
import org.dromara.quality.domain.vo.qualityinspection.QltQualityInspectionVo;
import org.dromara.quality.service.IQltQualityInspectionService;
import org.dromara.safety.domain.HseSafetyInspection;
import org.dromara.safety.domain.HseTeamMeeting;
import org.dromara.safety.domain.dto.safetyinspection.HseSafetyInspectionQueryReq;
import org.dromara.safety.domain.dto.teammeeting.HseTeamMeetingQueryReq;
import org.dromara.safety.domain.vo.safetyinspection.HseSafetyInspectionVo;
import org.dromara.safety.domain.vo.teammeeting.HseTeamMeetingVo;
import org.dromara.safety.service.IHseSafetyInspectionService;
import org.dromara.safety.service.IHseTeamMeetingService;
import org.dromara.system.domain.SysRole;
import org.dromara.system.domain.SysUserRole;
import org.dromara.system.mapper.SysRoleMapper;
import org.dromara.system.mapper.SysUserRoleMapper;
import org.dromara.system.service.ISysRoleService;
import org.dromara.system.service.ISysUserService;
import org.springframework.stereotype.Service;
import java.util.ArrayList;
import java.util.List;
import java.util.stream.Collectors;
/**
* 大屏-质安管理
*
* @author Lion Li
* @date 2025-11-05
*/
@RequiredArgsConstructor
@Service
@Slf4j
public class DpzaglServiceImpl implements DpzaglService {
//站班会
private final IHseTeamMeetingService teamMeetingService;
//质量-检查工单
private final IQltQualityInspectionService qualityInspectionService;
// 安全工单
private final IHseSafetyInspectionService safetyInspectionService;
private final SysRoleMapper sysRoleMapper;
private final UserService userService;
private final SysUserRoleMapper sysUserRoleMapper;
private final GpsEquipmentSonMapper gpsEquipmentSonMapper;
private final IBusProjectPunchrangeService busProjectPunchrangeService;
private final BusUserProjectRelevancyMapper busUserProjectRelevancyMapper;
@Override
public DpznglVo queryList(DpznglBo bo) {
DpznglVo dpznglVo = new DpznglVo();
PageQuery pageQuery = new PageQuery(bo.getPageSize(),bo.getPageNum());
// 质量
saveZl(pageQuery,dpznglVo,bo);
// 安全
saveAq(pageQuery,dpznglVo,bo);
return dpznglVo;
}
@Override
public List<DpznglAqyVo> listByAqy(DpznglBo bo) {
List<DpznglAqyVo> dpznglAqyVos = new ArrayList<>();
if (bo == null || bo.getProjectId() == null) throw new RuntimeException("项目不能为空");
//// 查询该项目下的人员id
// List<BusUserProjectRelevancy> busUserProjectRelevancies = busUserProjectRelevancyMapper.selectList(new LambdaQueryWrapper<BusUserProjectRelevancy>().eq(BusUserProjectRelevancy::getProjectId, bo.getProjectId()));
// if (busUserProjectRelevancies == null || busUserProjectRelevancies.size() == 0){
// return dpznglAqyVos;
// }
// 查询拥有安全员的角色
List<SysRole> sysRoles = sysRoleMapper.selectList(new LambdaQueryWrapper<SysRole>().eq(SysRole::getRoleIdentity, DpEnum.JSLX_AQY.getTypeValue()));
if (sysRoles == null || sysRoles.size() == 0){
return dpznglAqyVos;
}
// 根据角色查询人员
List<Long> roles = sysRoles.stream().map(SysRole::getRoleId).collect(Collectors.toList());
List<SysUserRole> sysUserRoles = sysUserRoleMapper.selectList(new LambdaQueryWrapper<SysUserRole>().in(SysUserRole::getRoleId, roles).groupBy(SysUserRole::getUserId));
if (sysUserRoles == null && sysUserRoles.size() == 0){
return dpznglAqyVos;
}
// 查询人员的最新经纬度
List<Long> collect = sysUserRoles.stream().map(SysUserRole::getUserId).collect(Collectors.toList());
if (collect == null || collect.size() == 0){
return dpznglAqyVos;
}
List<GpsEquipmentSon> temp = gpsEquipmentSonMapper.listByAqy(collect,bo.getProjectId());
if (temp != null && temp.size() > 0){
// 回填数据
dpznglAqyVos = temp.stream().map(gpsEquipmentSon -> {
DpznglAqyVo dpznglAqyVo = new DpznglAqyVo();
dpznglAqyVo.setUserId(gpsEquipmentSon.getUserId());
dpznglAqyVo.setLocLatitude(gpsEquipmentSon.getLocLatitude());
dpznglAqyVo.setLocLongitude(gpsEquipmentSon.getLocLongitude());
return dpznglAqyVo;
}).collect(Collectors.toList());
// 判断是否离岗
judgeFw(dpznglAqyVos,bo.getProjectId());
}
return dpznglAqyVos;
}
private void judgeFw(List<DpznglAqyVo> dpznglAqyVos, Long projectId) {
// 获取该项目的打卡范围
List<BusProjectPunchrange> busProjectPunchranges = busProjectPunchrangeService.getBaseMapper().selectList(new LambdaQueryWrapper<BusProjectPunchrange>().eq(BusProjectPunchrange::getProjectId, projectId));
if (busProjectPunchranges == null || busProjectPunchranges.size() == 0){
return;
}
//判断是否在岗
for (DpznglAqyVo dpznglAqyVo : dpznglAqyVos) {
dpznglAqyVo.setSfzg(DpEnum.RYZT_LG.getTypeValue());
dpznglAqyVo.setUserName(userService.selectNicknameByIds(dpznglAqyVo.getUserId().toString()));
for (BusProjectPunchrange busProjectPunchrange : busProjectPunchranges) {
List<String> coordinates = List.of(busProjectPunchrange.getPunchRange());
List<GeoPoint> matchingRange = JSTUtil.findMatchingRange(dpznglAqyVo.getLocLatitude().toString(), dpznglAqyVo.getLocLongitude().toString(), coordinates);
if (matchingRange != null && matchingRange.size() > 0){
dpznglAqyVo.setSfzg(DpEnum.RYZT_ZG.getTypeValue());
}
}
}
}
@Override
public DpznglVo listByzbh(DpznglBo bo) {
DpznglVo dpznglVo = new DpznglVo();
// 站班会
HseTeamMeetingQueryReq hseTeamMeetingQueryReq = new HseTeamMeetingQueryReq();
// List<HseTeamMeetingVo> hseTeamMeetingVos = teamMeetingService.queryList(hseTeamMeetingQueryReq);
List<HseTeamMeeting> hseTeamMeetings = teamMeetingService.getBaseMapper().selectList(new LambdaQueryWrapper<HseTeamMeeting>().ge(HseTeamMeeting::getProjectId, bo.getProjectId()));
dpznglVo.setZbhList(MapstructUtils.convert(hseTeamMeetings, HseTeamMeetingVo.class));
dpznglVo.getZbhList().forEach(hseTeamMeetingVo -> {if ( hseTeamMeetingVo.getCompereId() != null){hseTeamMeetingVo.setCompereName(userService.selectNicknameByIds(hseTeamMeetingVo.getCompereId().toString()));}});
return dpznglVo;
}
private void saveAq(PageQuery pageQuery, DpznglVo dpznglVo,DpznglBo bo) {
// 安全 巡检工单,整改情况
HseSafetyInspectionQueryReq req = new HseSafetyInspectionQueryReq();
// 质量展示数据
// TableDataInfo<HseSafetyInspectionVo> anList = safetyInspectionService.queryPageList(req, pageQuery);
// 质量展示数据-整改
// req.setStatus(DpEnum.ZLGDZT_ZG.getTypeValue());
// TableDataInfo<HseSafetyInspectionVo> aqZgList = safetyInspectionService.queryPageList(req, pageQuery);
// 安全总数(用于判断巡检类型)
List<HseSafetyInspection> list = safetyInspectionService.list(new LambdaQueryWrapper<HseSafetyInspection>().eq(HseSafetyInspection::getProjectId, bo.getProjectId()).ge(bo.getStartDate() != null ,HseSafetyInspection::getCreateTime, bo.getStartDate()).le(bo.getEndDate() != null ,HseSafetyInspection::getCreateTime, bo.getEndDate()));
// List<HseSafetyInspectionVo> rows = anList.getRows();
if (list != null && list.size() > 0){
dpznglVo.setAqZS(Long.valueOf(list.size()));
dpznglVo.setAqList(MapstructUtils.convert(list, HseSafetyInspectionVo.class));
dpznglVo.getAqList().forEach(zl ->{zl.setCreatorName(userService.selectNicknameByIds(zl.getCreateBy().toString()));});
dpznglVo.setZxjcAq(list.stream().filter(zl -> DpEnum.ZLGLLX_ZXGL.getTypeValue().equals(zl.getCheckType())).count());
dpznglVo.setDqjcAq(list.stream().filter(zl -> DpEnum.ZLGLLX_DQJC.getTypeValue().equals(zl.getCheckType())).count());
dpznglVo.setRcxjAq(list.stream().filter(zl -> DpEnum.ZLGLLX_RCXJ.getTypeValue().equals(zl.getCheckType())).count());
dpznglVo.setAqZgsl(list.stream().filter(zl -> DpEnum.ZLGDZT_ZG.getTypeValue().equals(zl.getStatus())).count());
List<HseSafetyInspectionVo> convert = MapstructUtils.convert(list.stream().filter(zl -> DpEnum.ZLGDZT_ZG.getTypeValue().equals(zl.getStatus())).collect(Collectors.toList()), HseSafetyInspectionVo.class);
convert.forEach(zl ->{if (zl.getCorrectorId() != null)zl.setCorrectorName(userService.selectNicknameByIds(zl.getCorrectorId().toString()));});
dpznglVo.setAqZgList(convert);
}
// if (aqZgList.getRows() != null && aqZgList.getRows().size() > 0){
// aqZgList.getRows().forEach(zl ->{if (zl.getCorrectorId() != null){zl.setCorrectorName(userService.selectNicknameByIds(zl.getCorrectorId().toString()));}});
// dpznglVo.setAqZgList(aqZgList.getRows());
// }
}
private void saveZl(PageQuery pageQuery,DpznglVo dpznglVo,DpznglBo bo) {
// 质量 巡检工单,整改情况
QltQualityInspectionQueryReq req = new QltQualityInspectionQueryReq();
//// 质量展示数据
// TableDataInfo<QltQualityInspectionVo> zlLists = qualityInspectionService.queryPageList(req, pageQuery);
// 质量展示数据-整改
// req.setInspectionStatus(DpEnum.ZLGDZT_ZG.getTypeValue());
// TableDataInfo<QltQualityInspectionVo> zlZgLists = qualityInspectionService.queryPageList(req, pageQuery);
// 质量总数
List<QltQualityInspection> zsZl = qualityInspectionService.getBaseMapper()
.selectList(new LambdaQueryWrapper<QltQualityInspection>().eq(QltQualityInspection::getProjectId, bo.getProjectId())
.ge(bo.getStartDate() != null ,QltQualityInspection::getCreateTime, bo.getStartDate()).le(bo.getEndDate() != null ,QltQualityInspection::getCreateTime, bo.getEndDate()));
// List<QltQualityInspectionVo> rows = zlLists.getRows();
if (zsZl != null && zsZl.size() > 0){
dpznglVo.setZlZS(Long.valueOf(zsZl.size()));
dpznglVo.setZlList(MapstructUtils.convert(zsZl, QltQualityInspectionVo.class));
dpznglVo.getZlList().forEach(zl ->{zl.setCreateByName(userService.selectNicknameByIds(zl.getCreateBy().toString()));});
dpznglVo.setZxjcZl(zsZl.stream().filter(zl -> DpEnum.ZLGLLX_ZXGL.getTypeValue().equals(zl.getInspectionType())).count());
dpznglVo.setDqjcZl(zsZl.stream().filter(zl -> DpEnum.ZLGLLX_DQJC.getTypeValue().equals(zl.getInspectionType())).count());
dpznglVo.setRcxjZl(zsZl.stream().filter(zl -> DpEnum.ZLGLLX_RCXJ.getTypeValue().equals(zl.getInspectionType())).count());
dpznglVo.setZlZgsl(zsZl.stream().filter(zl -> DpEnum.ZLGDZT_ZG.getTypeValue().equals(zl.getInspectionStatus())).count());
List<QltQualityInspection> collect = zsZl.stream().filter(zl -> DpEnum.ZLGDZT_ZG.getTypeValue().equals(zl.getInspectionStatus())).collect(Collectors.toList());
List<QltQualityInspectionVo> convert = MapstructUtils.convert(collect, QltQualityInspectionVo.class);
convert.forEach(zl ->{if (zl.getCorrectorId() != null)zl.setCorrectorName(userService.selectNicknameByIds(zl.getCorrectorId().toString()));});
dpznglVo.setZlZgList(convert);
}
}
}

View File

@ -0,0 +1,431 @@
package org.dromara.bigscreen.service.impl;
import cn.hutool.core.collection.CollUtil;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import jakarta.annotation.Resource;
import org.dromara.bigscreen.domain.vo.InventoryStructureAnalysisVo;
import org.dromara.bigscreen.domain.vo.StockInAndStockOutRecordVo;
import org.dromara.bigscreen.domain.vo.WarehouseMonitoringVo;
import org.dromara.bigscreen.domain.vo.xhqsdbVo;
import org.dromara.bigscreen.enums.WuZhiEnum;
import org.dromara.bigscreen.service.IMaterialsManagementService;
import org.dromara.materials.domain.*;
import org.dromara.materials.service.*;
import org.dromara.other.domain.OthYs7Device;
import org.dromara.other.domain.OthYs7DeviceImg;
import org.dromara.other.service.IOthYs7DeviceImgService;
import org.dromara.other.service.IOthYs7DeviceService;
import org.dromara.tender.domain.BusBillofquantitiesLimitList;
import org.dromara.tender.service.IBusBillofquantitiesLimitListService;
import org.springframework.context.annotation.Lazy;
import org.springframework.stereotype.Service;
import java.math.BigDecimal;
import java.time.LocalDateTime;
import java.time.temporal.TemporalAdjusters;
import java.util.*;
import java.util.stream.Collectors;
@Service
public class MaterialsManagementServiceImpl implements IMaterialsManagementService {
@Lazy
@Resource
private IMatMaterialReceiveItemService materialReceiveItemService;
@Lazy
@Resource
private IMatMaterialIssueItemService materialIssueItemService;
@Lazy
@Resource
private IMatMaterialsService materialsService;
@Lazy
@Resource
private IBusBillofquantitiesLimitListService billofquantitiesLimitListService;
@Lazy
@Resource
private IMatMaterialsInventoryService materialsInventoryService;
@Lazy
@Resource
private IMatMaterialsUseRecordService matMaterialsUseRecordService;
@Lazy
@Resource
private IMatMaterialIssueService materialIssueService;
@Resource
private IMatWarehouseService warehouseService;
@Lazy
@Resource
private IMatWarehouseCameraService warehouseCameraService;
@Lazy
@Resource
private IOthYs7DeviceService othYs7DeviceService;
@Lazy
@Resource
private IOthYs7DeviceImgService ys7DeviceImgService;
@Lazy
@Resource
private IMatMaterialReceiveService materialReceiveService;
@Override
public InventoryStructureAnalysisVo inventoryStructureAnalysis(Long projectId) {
InventoryStructureAnalysisVo vo = new InventoryStructureAnalysisVo();
// 获取当月第一天
LocalDateTime monthStart = LocalDateTime.now()
// 调整到当月第一天
.with(TemporalAdjusters.firstDayOfMonth())
// 重置时分秒毫秒为0
.withHour(0)
.withMinute(0)
.withSecond(0)
.withNano(0);
// 获取当前时间
LocalDateTime currentTime = LocalDateTime.now();
// 获取上月第一天
LocalDateTime lastMonthFirstDay = LocalDateTime.now()
// 先回退一个月
.minusMonths(1)
// 调整到当月第一天
.with(TemporalAdjusters.firstDayOfMonth())
// 重置时间为 00:00:00.000000000
.withHour(0)
.withMinute(0)
.withSecond(0);
// 获取上月最后一天
LocalDateTime lastMonthLastDay = LocalDateTime.now()
// 先回退一个月
.minusMonths(1)
// 调整到当月最后一天
.with(TemporalAdjusters.lastDayOfMonth())
// 设置时间为 23:59:59.999999999纳秒最大值对应毫秒级的999
.withHour(23)
.withMinute(59)
.withSecond(59);
// 获取当月入库数据
List<MatMaterialReceiveItem> matMaterialReceiveItems = materialReceiveItemService.getBaseMapper().selectList(new LambdaQueryWrapper<MatMaterialReceiveItem>()
.eq(MatMaterialReceiveItem::getProjectId, projectId)
.ne(MatMaterialReceiveItem::getAcceptedQuantity, BigDecimal.ZERO)
.between(MatMaterialReceiveItem::getCreateTime, monthStart, currentTime));
if (CollUtil.isEmpty(matMaterialReceiveItems)) {
vo.setEnterTotalPrices(BigDecimal.ZERO);
} else {
// 计算本月入库金额
BigDecimal enterTotalPrices = matMaterialReceiveItems.stream()
.map(item -> item.getAcceptedQuantity().multiply(item.getUnitPrice() != null ? item.getUnitPrice() : BigDecimal.ZERO))
.reduce(BigDecimal.ZERO, BigDecimal::add);
vo.setEnterTotalPrices(enterTotalPrices.setScale(4, BigDecimal.ROUND_HALF_UP));
}
// 获取上月入库数据
List<MatMaterialReceiveItem> oldMatMaterialReceiveItems = materialReceiveItemService.getBaseMapper().selectList(new LambdaQueryWrapper<MatMaterialReceiveItem>()
.eq(MatMaterialReceiveItem::getProjectId, projectId)
.ne(MatMaterialReceiveItem::getAcceptedQuantity, BigDecimal.ZERO)
.between(MatMaterialReceiveItem::getCreateTime, lastMonthFirstDay, lastMonthLastDay));
if (CollUtil.isEmpty(oldMatMaterialReceiveItems)) {
vo.setOldEnterTotalPrices(BigDecimal.ZERO);
} else {
// 计算上月入库金额
BigDecimal oldEnterTotalPrices = oldMatMaterialReceiveItems.stream()
.map(item -> item.getAcceptedQuantity().multiply(item.getUnitPrice() != null ? item.getUnitPrice() : BigDecimal.ZERO))
.reduce(BigDecimal.ZERO, BigDecimal::add);
vo.setOldEnterTotalPrices(oldEnterTotalPrices.setScale(4, BigDecimal.ROUND_HALF_UP));
}
// 获取当月出库数据
List<MatMaterialIssueItem> matMaterialIssueItems = materialIssueItemService.getBaseMapper()
.selectList(new LambdaQueryWrapper<MatMaterialIssueItem>()
.eq(MatMaterialIssueItem::getProjectId, projectId)
.ne(MatMaterialIssueItem::getIssuedQuantity, BigDecimal.ZERO)
.between(MatMaterialIssueItem::getCreateTime, monthStart, currentTime));
//计算本月出库金额
if (CollUtil.isEmpty(matMaterialIssueItems)) {
vo.setLeaveTotalPrices(BigDecimal.ZERO);
} else {
BigDecimal leaveTotalPrices = matMaterialIssueItems.stream()
.map(item -> item.getIssuedQuantity().multiply(item.getUnitPrice() != null ? item.getUnitPrice() : BigDecimal.ZERO))
.reduce(BigDecimal.ZERO, BigDecimal::add);
vo.setLeaveTotalPrices(leaveTotalPrices.setScale(4, BigDecimal.ROUND_HALF_UP));
}
// 获取上月出库数据
List<MatMaterialIssueItem> oldMatMaterialIssueItems = materialIssueItemService.getBaseMapper()
.selectList(new LambdaQueryWrapper<MatMaterialIssueItem>()
.eq(MatMaterialIssueItem::getProjectId, projectId)
.ne(MatMaterialIssueItem::getIssuedQuantity, BigDecimal.ZERO)
.between(MatMaterialIssueItem::getCreateTime, lastMonthFirstDay, lastMonthLastDay));
//计算上月出库金额
if (CollUtil.isEmpty(oldMatMaterialIssueItems)) {
vo.setOldLeaveTotalPrices(BigDecimal.ZERO);
} else {
BigDecimal oldLeaveTotalPrices = oldMatMaterialIssueItems.stream()
.map(item -> item.getIssuedQuantity().multiply(item.getUnitPrice() != null ? item.getUnitPrice() : BigDecimal.ZERO))
.reduce(BigDecimal.ZERO, BigDecimal::add);
vo.setOldLeaveTotalPrices(oldLeaveTotalPrices.setScale(4, BigDecimal.ROUND_HALF_UP));
}
//获取总入库存金额 入库 * 单价
List<MatMaterialReceiveItem> totalMatMaterialReceiveItems = materialReceiveItemService.getBaseMapper().selectList(new LambdaQueryWrapper<MatMaterialReceiveItem>().eq(MatMaterialReceiveItem::getProjectId, projectId));
if (CollUtil.isEmpty(totalMatMaterialReceiveItems)) {
vo.setInventoryTotalPrices(BigDecimal.ZERO);
} else {
// 计算总入库存金额
BigDecimal inventoryTotalPrices = totalMatMaterialReceiveItems.stream()
.map(item -> item.getAcceptedQuantity().multiply(item.getUnitPrice() != null ? item.getUnitPrice() : BigDecimal.ZERO))
.reduce(BigDecimal.ZERO, BigDecimal::add);
vo.setInventoryTotalPrices(inventoryTotalPrices.setScale(4, BigDecimal.ROUND_HALF_UP));
}
// 获取总出库金额 出库 * 单价
List<MatMaterialIssueItem> totalMatMaterialIssueItems = materialIssueItemService.getBaseMapper().selectList(new LambdaQueryWrapper<MatMaterialIssueItem>().eq(MatMaterialIssueItem::getProjectId, projectId));
if (CollUtil.isEmpty(totalMatMaterialIssueItems)) {
vo.setOutTotalPrices(BigDecimal.ZERO);
} else {
// 计算总出库金额
BigDecimal outTotalPrices = totalMatMaterialIssueItems.stream()
.map(item -> item.getIssuedQuantity().multiply(item.getUnitPrice() != null ? item.getUnitPrice() : BigDecimal.ZERO))
.reduce(BigDecimal.ZERO, BigDecimal::add);
vo.setOutTotalPrices(outTotalPrices.setScale(4, BigDecimal.ROUND_HALF_UP));
}
// 获取施工图一览大类名下所有小类名
List<BusBillofquantitiesLimitList> limitLists = billofquantitiesLimitListService.getBaseMapper().selectList(new LambdaQueryWrapper<BusBillofquantitiesLimitList>()
.eq(BusBillofquantitiesLimitList::getProjectId, projectId)
.eq(BusBillofquantitiesLimitList::getPid, "0")
.eq(BusBillofquantitiesLimitList::getType, "3")
.eq(BusBillofquantitiesLimitList::getName, WuZhiEnum.LBQ.getTypeName()).or()
.eq(BusBillofquantitiesLimitList::getName, WuZhiEnum.GFZJ.getTypeName()).or()
.eq(BusBillofquantitiesLimitList::getName, WuZhiEnum.XB.getTypeName()).or()
.eq(BusBillofquantitiesLimitList::getName, WuZhiEnum.HWG.getTypeName())
);
List<String> lBQNames = new ArrayList<>();
List<String> sFZJNames = new ArrayList<>();
List<String> xBNames = new ArrayList<>();
List<String> hWGNames = new ArrayList<>();
for (BusBillofquantitiesLimitList item : limitLists) {
if (item.getName().equals(WuZhiEnum.LBQ.getTypeName())) {
lBQNames.add(item.getName());
continue;
}
if (item.getName().equals(WuZhiEnum.GFZJ.getTypeName())) {
sFZJNames.add(item.getName());
continue;
}
if (item.getName().equals(WuZhiEnum.XB.getTypeName())) {
xBNames.add(item.getName());
continue;
}
if (item.getName().equals(WuZhiEnum.HWG.getTypeName())) {
hWGNames.add(item.getName());
}
}
//获取库存逆变器总价
BigDecimal inventoryInverterTotalPrices = materialsService.selectTotalPricesByNames(projectId, lBQNames);
vo.setInventoryInverterTotalPrices(inventoryInverterTotalPrices);
//获取库存箱变总价
BigDecimal inventoryBoxTransformerTotalPrices = materialsService.selectTotalPricesByNames(projectId, xBNames);
vo.setInventoryBoxTransformerTotalPrices(inventoryBoxTransformerTotalPrices);
//获取库存光伏支架总价
BigDecimal inventoryPhotovoltaicSupportTotalPrices = materialsService.selectTotalPricesByNames(projectId, sFZJNames);
vo.setInventoryPhotovoltaicSupportTotalPrices(inventoryPhotovoltaicSupportTotalPrices);
//获取库存环网柜总价
BigDecimal inventoryCircuitBreakerTotalPrices = materialsService.selectTotalPricesByNames(projectId, hWGNames);
vo.setInventoryCircuitBreakerTotalPrices(inventoryCircuitBreakerTotalPrices);
//获取当前库存总价
BigDecimal nowInventoryTotalPrices = materialsService.selectTotalPrices(projectId);
vo.setNowInventoryTotalPrices(nowInventoryTotalPrices);
return vo;
}
/**
* 消耗趋势对比
*
* @param projectId
* @return
*/
@Override
public List<xhqsdbVo> xhqsdb(Long projectId) {
List<xhqsdbVo> list = new ArrayList<>();
//获取出库记录
List<MatMaterialIssue> issuesList = materialIssueService.getBaseMapper()
.selectList(new LambdaQueryWrapper<MatMaterialIssue>()
.eq(MatMaterialIssue::getProjectId, projectId)
.eq(MatMaterialIssue::getMaterialSource, "1"));
if (CollUtil.isEmpty(issuesList)) {
return List.of();
}
Set<Long> issueIds = issuesList.stream().map(MatMaterialIssue::getId).collect(Collectors.toSet());
if (CollUtil.isEmpty(issueIds)){
return List.of();
}
//获取领料明细列表
List<MatMaterialIssueItem> issueItems = materialIssueItemService.getBaseMapper().selectList(new LambdaQueryWrapper<MatMaterialIssueItem>()
.in(MatMaterialIssueItem::getIssueId, issueIds));
if (CollUtil.isEmpty(issueItems)){
return List.of();
}
Set<Long> iIds = issueItems.stream().filter(item -> item.getInventoryId() != null).map(MatMaterialIssueItem::getInventoryId).collect(Collectors.toSet());
if (CollUtil.isEmpty(iIds)){
return List.of();
}
//获取出入库表中出库记录
List<MatMaterialsInventory> inventories = materialsInventoryService.getBaseMapper()
.selectList(new LambdaQueryWrapper<MatMaterialsInventory>()
.in(MatMaterialsInventory::getId, iIds));
if (CollUtil.isEmpty(inventories)) {
return List.of();
}
//获取每个材料的库存数量
HashMap<Long, BigDecimal> inventoryHashMap = new HashMap<>();
inventories.forEach(item -> {
if (inventoryHashMap.containsKey(item.getMaterialsId())){
inventoryHashMap.put(item.getMaterialsId(), inventoryHashMap.get(item.getMaterialsId()).add(new BigDecimal(item.getNumber())));
}else {
inventoryHashMap.put(item.getMaterialsId(), new BigDecimal(item.getNumber()));
}
});
Set<Long> mids = inventories.stream().filter(item -> item.getMaterialsId() != null).map(MatMaterialsInventory::getMaterialsId).collect(Collectors.toSet());
if (CollUtil.isEmpty(mids)){
return List.of();
}
//获取材料名称列表
List<MatMaterials> materials = materialsService.getBaseMapper().selectList(new LambdaQueryWrapper<MatMaterials>()
.eq(MatMaterials::getProjectId, projectId)
.in(MatMaterials::getId, mids));
if (CollUtil.isEmpty(materials)) {
return List.of();
}
//获取材料名称
Map<Long, String> map1 = materials.stream()
.collect(Collectors.toMap(MatMaterials::getId, MatMaterials::getMaterialsName));
//获取所有出入库记录id
Set<Long> ids = inventories.stream()
.map(MatMaterialsInventory::getId)
.collect(Collectors.toSet());
if (CollUtil.isEmpty(ids)) {
return List.of();
}
//根据出入库id获取使用记录
List<MatMaterialsUseRecord> useRecords = matMaterialsUseRecordService.getBaseMapper()
.selectList(new LambdaQueryWrapper<MatMaterialsUseRecord>()
.eq(MatMaterialsUseRecord::getProjectId, projectId)
.in(MatMaterialsUseRecord::getInventoryId, ids));
Map<Long, BigDecimal> map = useRecords.stream()
.collect(Collectors.groupingBy(
MatMaterialsUseRecord::getInventoryId,
Collectors.reducing(BigDecimal.ZERO, MatMaterialsUseRecord::getUseNumber, BigDecimal::add)
));
inventoryHashMap.forEach((key, value) -> {
xhqsdbVo vo = new xhqsdbVo();
vo.setName(map1.get(key));
vo.setOutTotalPrices( value);
vo.setUseTotalPrices(map.getOrDefault(key, BigDecimal.ZERO));
list.add(vo);
});
return list;
}
@Override
public List<WarehouseMonitoringVo> warehouseMonitoring(Long projectId) {
List<WarehouseMonitoringVo> list = new ArrayList<>();
//根据项目id获取仓库列表
List<MatWarehouse> warehouseList = warehouseService.getBaseMapper().selectList(new LambdaQueryWrapper<MatWarehouse>()
.eq(MatWarehouse::getProjectId, projectId));
//构建仓库id与仓库对象映射
if (CollUtil.isEmpty(warehouseList)){
return list;
}
Map<Long, MatWarehouse> warehouseMap = warehouseList.stream().collect(Collectors.toMap(MatWarehouse::getId, item -> item));
//根据仓库列表获取仓库id
Set<Long> warehouseIds = warehouseList.stream().map(MatWarehouse::getId).collect(Collectors.toSet());
//根据仓库id获取摄像头id列表
List<MatWarehouseCamera> warehouseCameraList = warehouseCameraService.getBaseMapper().selectList(new LambdaQueryWrapper<MatWarehouseCamera>()
.in(MatWarehouseCamera::getWarehouseId, warehouseIds));
if (CollUtil.isEmpty(warehouseCameraList)){
return list;
}
Set<Long> cameraIds = warehouseCameraList.stream().filter(item -> item.getCameraId() != null).map(MatWarehouseCamera::getCameraId).collect(Collectors.toSet());
//生成摄像头与仓库关系
Map<Long, Long> warehouseCameraMap = warehouseCameraList.stream().collect(Collectors.toMap(MatWarehouseCamera::getCameraId, MatWarehouseCamera::getWarehouseId));
//根据摄像头id列表获取摄像头列表
List<OthYs7Device> cameraList = othYs7DeviceService.getBaseMapper()
.selectList(new LambdaQueryWrapper<OthYs7Device>()
.in(OthYs7Device::getId, cameraIds));
if (CollUtil.isEmpty(cameraList)){
return list;
}
//获取摄像头最后一张抓拍图片
Set<String> deviceSerialSet = cameraList.stream().map(OthYs7Device::getDeviceSerial).collect(Collectors.toSet());
List<OthYs7DeviceImg> deviceImgs = ys7DeviceImgService.getBaseMapper()
.selectList(new LambdaQueryWrapper<OthYs7DeviceImg>()
.in(OthYs7DeviceImg::getDeviceSerial, deviceSerialSet));
Map<String, String> deviceImgMap = new HashMap<>();
if (CollUtil.isNotEmpty(deviceImgs)){
//构建摄像头与图片关系
deviceImgMap = deviceImgs.stream().collect(Collectors.toMap(OthYs7DeviceImg::getDeviceSerial, OthYs7DeviceImg::getUrl));
}
//遍历摄像头列表组装返回数据
for (OthYs7Device item : cameraList) {
WarehouseMonitoringVo vo = new WarehouseMonitoringVo();
vo.setCameraId(item.getId());
vo.setWarehouseId(warehouseCameraMap.get(item.getId()));
vo.setCameraSerial(item.getDeviceSerial());
vo.setCameraName(item.getDeviceName());
vo.setStatus(item.getStatus());
vo.setEnable(item.getEnable());
vo.setName(warehouseMap.get(vo.getWarehouseId()).getWarehouseName());
vo.setImgUrl(deviceImgMap.get(item.getDeviceSerial()) != null ? deviceImgMap.get(item.getDeviceSerial()) : "");
list.add(vo);
}
return list;
}
/**
* 仓库出入库明细
*
* @param projectId
* @param warehouseId
* @return
*/
@Override
public List<StockInAndStockOutRecordVo> warehouseInAndOutDetail(Long projectId, Long warehouseId) {
List<StockInAndStockOutRecordVo> list = new ArrayList<>();
//根据项目id和仓库id获取入库列表
List<MatMaterials> matMaterials = materialsService.getBaseMapper().selectList(new LambdaQueryWrapper<MatMaterials>()
.eq(MatMaterials::getProjectId, projectId)
.eq(MatMaterials::getWarehouseId, warehouseId));
if (CollUtil.isEmpty(matMaterials)) {
return list;
}
//生成材料id与材料名称关系
Map<Long, String> map1 = matMaterials.stream().collect(Collectors.toMap(MatMaterials::getId, MatMaterials::getMaterialsName));
//获取入库的材料id列表
Set<Long> mIds = matMaterials.stream()
.map(MatMaterials::getId)
.collect(Collectors.toSet());
if (CollUtil.isEmpty(mIds)){
return list;
}
//根据材料id列表查询出入库记录表获取到所有材料的出入库记录
List<MatMaterialsInventory> materialsInventoryList = materialsInventoryService.getBaseMapper()
.selectList(new LambdaQueryWrapper<MatMaterialsInventory>()
.in(MatMaterialsInventory::getMaterialsId, mIds)
.orderByDesc(MatMaterialsInventory::getCreateTime));
if (CollUtil.isEmpty(materialsInventoryList)){
return list;
}
//遍历出入库记录列表,组装返回数据
for (MatMaterialsInventory item : materialsInventoryList) {
StockInAndStockOutRecordVo vo = new StockInAndStockOutRecordVo();
vo.setId(item.getId());
vo.setName(map1.get(item.getMaterialsId()));
vo.setInventoryNumber(item.getResidue());
vo.setInAndOutNumber(item.getNumber());
vo.setType(item.getOutPut());
vo.setTime(item.getOutPutTime());
vo.setOperator(item.getOperator());
list.add(vo);
}
return list;
}
}

View File

@ -0,0 +1,403 @@
package org.dromara.bigscreen.service.impl;
import cn.hutool.core.collection.CollUtil;
import jakarta.annotation.Resource;
import lombok.extern.slf4j.Slf4j;
import org.dromara.bigscreen.domain.dto.ProjectImageProgressDetailReq;
import org.dromara.bigscreen.domain.progress.*;
import org.dromara.bigscreen.domain.vo.ProjectImageProgressDetailVo;
import org.dromara.bigscreen.domain.vo.wzxqysjdhdbVo;
import org.dromara.bigscreen.service.ProgressBigScreenService;
import org.dromara.bigscreen.service.ProjectBigScreenService;
import org.dromara.cailiaoshebei.service.IBusMrpBaseService;
import org.dromara.common.core.enums.BusinessStatusEnum;
import org.dromara.common.core.utils.DateUtils;
import org.dromara.common.utils.BigDecimalUtil;
import org.dromara.design.domain.DesVolumeCatalog;
import org.dromara.design.domain.DesVolumeFile;
import org.dromara.design.service.IDesVolumeCatalogService;
import org.dromara.design.service.IDesVolumeFileService;
import org.dromara.materials.domain.MatMaterialReceive;
import org.dromara.materials.domain.MatMaterialReceiveItem;
import org.dromara.materials.service.IMatMaterialReceiveItemService;
import org.dromara.materials.service.IMatMaterialReceiveService;
import org.dromara.materials.service.IMatMaterialsService;
import org.dromara.progress.constant.PgsProgressCategoryConstant;
import org.dromara.progress.domain.PgsConstructionSchedulePlan;
import org.dromara.progress.domain.PgsProgressCategory;
import org.dromara.progress.domain.dto.progressplan.PgsProgressPlanQueryReq;
import org.dromara.progress.domain.vo.progresscategory.PgsProgressCategoryValueTotalVo;
import org.dromara.progress.domain.vo.progressplan.PgsProgressPlanDateVo;
import org.dromara.progress.service.IPgsConstructionSchedulePlanService;
import org.dromara.progress.service.IPgsProgressCategoryService;
import org.dromara.progress.service.IPgsProgressPlanService;
import org.dromara.project.domain.BusProject;
import org.dromara.project.service.IBusProjectService;
import org.dromara.system.domain.vo.SysDictDataVo;
import org.dromara.system.service.ISysDictDataService;
import org.springframework.beans.BeanUtils;
import org.springframework.stereotype.Service;
import java.math.BigDecimal;
import java.math.RoundingMode;
import java.time.LocalDate;
import java.time.LocalDateTime;
import java.time.LocalTime;
import java.time.ZoneId;
import java.time.temporal.ChronoUnit;
import java.util.*;
import java.util.stream.Collectors;
/**
* @author lilemy
* @date 2025-12-15 14:18
*/
@Slf4j
@Service
public class ProgressBigScreenServiceImpl implements ProgressBigScreenService {
@Resource
private ProjectBigScreenService projectBigScreenService;
@Resource
private IBusProjectService projectService;
@Resource
private IPgsProgressCategoryService progressCategoryService;
@Resource
private IPgsProgressPlanService progressPlanService;
@Resource
private IPgsConstructionSchedulePlanService constructionSchedulePlanService;
@Resource
private IDesVolumeCatalogService volumeCatalogService;
@Resource
private IDesVolumeFileService volumeFileService;
@Resource
private ISysDictDataService dictDataService;
@Resource
private IMatMaterialReceiveService materialReceiveService;
@Resource
private IMatMaterialReceiveItemService materialReceiveItemService;
@Resource
private IBusMrpBaseService mrpBaseService;
@Resource
private IMatMaterialsService matMaterialsService;
/**
* 获取项目总进度
*
* @param projectId 项目 id
* @return 项目总进度
*/
@Override
public ProjectTotalProgressVo getProjectTotalProgress(Long projectId) {
ProjectTotalProgressVo vo = new ProjectTotalProgressVo();
// 获取项目和项目子项
BusProject project = projectService.getById(projectId);
if (project == null) {
return vo;
}
List<BusProject> projects = projectService.lambdaQuery()
.eq(BusProject::getPId, projectId)
.list();
projects.add(project);
List<Long> projectIds = projects.stream().map(BusProject::getId).toList();
// 获取当前项目所有父级类别
List<PgsProgressCategory> topList = progressCategoryService.lambdaQuery()
.in(PgsProgressCategory::getProjectId, projectIds)
.eq(PgsProgressCategory::getParentId, PgsProgressCategoryConstant.TOP_PARENT_ID)
.list();
if (CollUtil.isEmpty(topList)) {
return vo;
}
List<Long> topIds = topList.stream().map(PgsProgressCategory::getId).toList();
List<PgsProgressCategory> children = progressCategoryService.getLeafNodesByTopIds(topIds);
BigDecimal completedPercentage = progressCategoryService.getCompletedPercentage(children);
vo.setTotalProgress(completedPercentage);
// 获取总计划工期
PgsProgressPlanQueryReq queryDate = new PgsProgressPlanQueryReq();
queryDate.setProjectId(projectId);
PgsProgressPlanDateVo dateVo = progressPlanService.queryDate(queryDate);
if (dateVo != null && dateVo.getStartDate() != null && dateVo.getEndDate() != null) {
LocalDate startDate = dateVo.getStartDate();
LocalDate endDate = dateVo.getEndDate();
LocalDate now = LocalDate.now();
long totalDays = ChronoUnit.DAYS.between(startDate, endDate);
vo.setTotalPlannedDuration(totalDays);
if (now.isAfter(endDate)) {
vo.setCurrentPlannedDuration(totalDays);
} else if (now.isBefore(startDate)) {
vo.setCurrentPlannedDuration(0L);
} else {
vo.setCurrentPlannedDuration(ChronoUnit.DAYS.between(startDate, now) + 1);
}
}
// 获取整体完成情况
PgsProgressCategoryValueTotalVo valueTotal = progressCategoryService.getValueTotal(children, true);
vo.setTotalCompletionAmount(valueTotal.getTotalValue().divide(BigDecimal.valueOf(10000), 0, RoundingMode.HALF_UP));
vo.setCurrentCompletionAmount(valueTotal.getCurrentValue().divide(BigDecimal.valueOf(10000), 0, RoundingMode.HALF_UP));
// 获取详情
Map<String, List<PgsProgressCategory>> nameMap = topList.stream()
.collect(Collectors.groupingBy(PgsProgressCategory::getName));
List<ProjectTotalProgressDetailVo> detailList = new ArrayList<>();
for (Map.Entry<String, List<PgsProgressCategory>> entry : nameMap.entrySet()) {
ProjectTotalProgressDetailVo detailVo = new ProjectTotalProgressDetailVo();
String name = entry.getKey();
detailVo.setName(name);
List<PgsProgressCategory> value = entry.getValue();
List<Long> top = value.stream().map(PgsProgressCategory::getId).toList();
List<PgsProgressCategory> nameChildren = progressCategoryService.getLeafNodesByTopIds(top, children);
BigDecimal completedTotal = nameChildren.stream().map(PgsProgressCategory::getCompleted)
.reduce(BigDecimal.ZERO, BigDecimal::add);
BigDecimal planTotal = nameChildren.stream().map(PgsProgressCategory::getPlanTotal)
.reduce(BigDecimal.ZERO, BigDecimal::add);
BigDecimal total = nameChildren.stream().map(PgsProgressCategory::getTotal)
.reduce(BigDecimal.ZERO, BigDecimal::add);
detailVo.setActualProgress(completedTotal);
detailVo.setPlanProgress(planTotal);
detailVo.setCompletionRate(BigDecimalUtil.toPercentage(completedTotal, total));
detailList.add(detailVo);
}
vo.setDetailList(detailList);
return vo;
}
/**
* 获取施工进度详情
*
* @param req 请求参数
* @return 施工进度详情
*/
@Override
public List<ProjectImageProgressDetailVo> getProjectTotalProgressDetail(ProjectImageProgressDetailReq req) {
req.setIsAll(true);
return projectBigScreenService.getProjectImageProgressDetail(req);
}
/**
* 获取里程碑进度
*
* @param projectId 项目 id
* @return 里程碑进度
*/
@Override
public List<MilestoneProgressVo> getMilestoneProgress(Long projectId) {
List<MilestoneProgressVo> voList = new ArrayList<>();
List<PgsConstructionSchedulePlan> planList = constructionSchedulePlanService.lambdaQuery()
.eq(PgsConstructionSchedulePlan::getProjectId, projectId)
.list();
if (CollUtil.isEmpty(planList)) {
return voList;
}
List<PgsConstructionSchedulePlan> topList = planList.stream().filter(plan -> plan.getParentId().equals(0L)).toList();
return topList.stream().map(plan -> {
MilestoneProgressVo vo = new MilestoneProgressVo();
BeanUtils.copyProperties(plan, vo);
// 获取子节点
List<PgsConstructionSchedulePlan> allChildren = constructionSchedulePlanService.getAllChildren(plan.getId(), planList);
long count = allChildren.stream().filter(child -> child.getStatus().equals("4")).count();
BigDecimal percentage = BigDecimalUtil.toPercentage(new BigDecimal(count), new BigDecimal(allChildren.size()));
vo.setCurrentProgress(percentage);
return vo;
}).toList();
}
/**
* 获取设计进度
*
* @param projectId 项目 id
* @return 设计进度
*/
@Override
public DesignProgressVo getDesignProgress(Long projectId) {
DesignProgressVo vo = new DesignProgressVo();
List<DesVolumeCatalog> catalogList = volumeCatalogService.lambdaQuery()
.eq(DesVolumeCatalog::getProjectId, projectId).list();
if (CollUtil.isEmpty(catalogList)) {
return vo;
}
LocalDate nowDate = LocalDate.now();
long currentDesignProgress = 0L;
BigDecimal designProgressThisM = BigDecimal.ZERO;
BigDecimal designProgressLastM = BigDecimal.ZERO;
long currentDelay = 0L;
BigDecimal delayThisD = BigDecimal.ZERO;
BigDecimal delayLastD = BigDecimal.ZERO;
// 总数量
vo.setTotalDesignProgress((long) catalogList.size());
LocalDateTime firstDayOfMonth = LocalDateTime.now().withDayOfMonth(1).with(LocalTime.MIN);
LocalDateTime lastMonthFirstDay = LocalDateTime.now().minusMonths(1).withDayOfMonth(1).with(LocalTime.MIN);
for (DesVolumeCatalog catalog : catalogList) {
// 已出图状态
if (catalog.getDesignState().equals("1")) {
currentDesignProgress++;
// 获取当月和上月的完成数量
LocalDateTime finishTime = catalog.getFinishTime();
if (finishTime != null) {
if (finishTime.isAfter(firstDayOfMonth)) {
designProgressThisM = designProgressThisM.add(BigDecimal.ONE);
} else if (finishTime.isBefore(lastMonthFirstDay)) {
designProgressLastM = designProgressLastM.add(BigDecimal.ONE);
}
}
} else if (!catalog.getPlannedCompletion().isAfter(nowDate) && catalog.getDesignState().equals("2")) {
currentDelay++;
if (catalog.getPlannedCompletion().isEqual(nowDate)) {
delayThisD = delayThisD.add(BigDecimal.ONE);
} else if (catalog.getPlannedCompletion().isEqual(nowDate.minusDays(1))) {
delayLastD = delayLastD.add(BigDecimal.ONE);
}
}
}
// 计算完成情况
vo.setCurrentDesignProgress(currentDesignProgress);
vo.setDesignProgressTrend(designProgressThisM.compareTo(designProgressLastM) >= 0);
vo.setDesignProgressRate(BigDecimalUtil.toLoopPercentage(designProgressThisM, designProgressLastM));
// 总逾期数量
vo.setDelayedDesign(currentDelay);
vo.setDelayedDesignTrend(delayThisD.compareTo(delayLastD) >= 0);
vo.setDelayedDesignRate(BigDecimalUtil.toLoopPercentage(delayThisD, delayLastD));
// 获取各专业完成情况
List<DesignProgressMajorVo> majorList = new ArrayList<>();
Map<String, List<DesVolumeCatalog>> specialtyMap = catalogList.stream()
.collect(Collectors.groupingBy(DesVolumeCatalog::getSpecialty));
List<SysDictDataVo> desUserMajor = dictDataService.selectByDictType("des_user_major");
if (CollUtil.isEmpty(desUserMajor)) {
log.error("专业字典 des_user_major 数据不存在");
} else {
Map<String, String> dictMap = desUserMajor.stream()
.collect(Collectors.toMap(SysDictDataVo::getDictValue, SysDictDataVo::getDictLabel));
specialtyMap.forEach((specialty, list) -> {
DesignProgressMajorVo majorVo = new DesignProgressMajorVo();
majorVo.setMajorName(dictMap.getOrDefault(specialty, specialty));
BigDecimal total = new BigDecimal(list.size());
long count = list.stream().filter(catalog -> catalog.getDesignState().equals("1")).count();
majorVo.setCompletionRate(BigDecimalUtil.toPercentage(new BigDecimal(count), total));
majorList.add(majorVo);
});
}
vo.setMajorList(majorList);
// 审核信息
Set<Long> ids = catalogList.stream().map(DesVolumeCatalog::getDesign).collect(Collectors.toSet());
List<DesVolumeFile> fileList = volumeFileService.lambdaQuery()
.in(DesVolumeFile::getVolumeCatalogId, ids)
.list();
long reviewedDesign = 0L;
BigDecimal reviewedDesignThisM = BigDecimal.ZERO;
BigDecimal reviewedDesignLastM = BigDecimal.ZERO;
long pendingReviewDesign = 0L;
BigDecimal pendingReviewDesignThisD = BigDecimal.ZERO;
BigDecimal pendingReviewDesignLastD = BigDecimal.ZERO;
for (DesVolumeFile file : fileList) {
String status = file.getStatus();
if (BusinessStatusEnum.FINISH.getStatus().equals(status)) {
reviewedDesign++;
// 获取当月和上月的完成数量
LocalDateTime finishTime = file.getFinishTime();
if (finishTime != null) {
if (finishTime.isAfter(firstDayOfMonth)) {
reviewedDesignThisM = reviewedDesignThisM.add(BigDecimal.ONE);
} else if (finishTime.isBefore(lastMonthFirstDay)) {
reviewedDesignLastM = reviewedDesignLastM.add(BigDecimal.ONE);
}
}
} else if (BusinessStatusEnum.WAITING.getStatus().equals(status)) {
pendingReviewDesign++;
Date createTime = file.getCreateTime();
LocalDate createDate = createTime.toInstant()
.atZone(ZoneId.systemDefault())
.toLocalDate();
if (createDate.isEqual(nowDate)) {
pendingReviewDesignThisD = pendingReviewDesignThisD.add(BigDecimal.ONE);
} else if (createDate.isEqual(nowDate.minusDays(1))) {
pendingReviewDesignLastD = pendingReviewDesignLastD.add(BigDecimal.ONE);
}
}
}
vo.setTotalDesign((long) fileList.size());
vo.setReviewedDesign(reviewedDesign);
vo.setReviewedDesignTrend(reviewedDesignThisM.compareTo(reviewedDesignLastM) >= 0);
vo.setReviewedDesignRate(BigDecimalUtil.toLoopPercentage(reviewedDesignThisM, reviewedDesignLastM));
vo.setPendingDesignReview(pendingReviewDesign);
vo.setPendingDesignReviewTrend(pendingReviewDesignThisD.compareTo(pendingReviewDesignLastD) >= 0);
vo.setPendingDesignReviewRate(BigDecimalUtil.toLoopPercentage(pendingReviewDesignThisD, pendingReviewDesignLastD));
return vo;
}
/**
* 获取物料进度详情
*
* @param projectId 项目 id
* @return 物料进度详情
*/
@Override
public List<MaterialProgressDetailVo> getMaterialProgressDetail(Long projectId, String name, String specification) {
// 根据名称 规格获取材料
List<MatMaterialReceiveItem> itemList = materialReceiveItemService.lambdaQuery()
.eq(MatMaterialReceiveItem::getName, name)
.eq(MatMaterialReceiveItem::getSpecification, specification)
.list();
if (CollUtil.isEmpty(itemList)) {
return List.of();
}
Set<Long> ids = itemList.stream().map(MatMaterialReceiveItem::getReceiveId).collect(Collectors.toSet());
List<MatMaterialReceive> receiveList = materialReceiveService.lambdaQuery()
.in(MatMaterialReceive::getId, ids)
.list();
Map<Long, MatMaterialReceive> receiveMap = receiveList.stream()
.collect(Collectors.toMap(MatMaterialReceive::getId, receive -> receive));
return itemList.stream().map(item -> {
Long receiveId = item.getReceiveId();
MatMaterialReceive receive = receiveMap.get(receiveId);
if (receive == null) {
return null;
}
MaterialProgressDetailVo vo = new MaterialProgressDetailVo();
vo.setId(item.getId());
vo.setName(item.getName());
vo.setQuantity(item.getQuantity());
vo.setAcceptedQuantity(item.getAcceptedQuantity());
vo.setShortageQuantity(item.getShortageQuantity());
vo.setFormCode(receive.getFormCode());
vo.setContractName(receive.getContractName());
vo.setOrderingUnit(receive.getOrderingUnit());
vo.setSupplierUnit(receive.getSupplierUnit());
vo.setArrivalDate(DateUtils.toLocalDate(receive.getCreateTime()));
return vo;
}).filter(Objects::nonNull).toList();
}
/**
* 获取物资进度
*
* @param projectId 项目 id
* @return 物资进度
*/
@Override
public List<wzxqysjdhdbVo> getMaterialProgress(Long projectId) {
List<wzxqysjdhdbVo> wzxqysjdhdb = mrpBaseService.wzxqysjdhdb(projectId);
Map<String, List<wzxqysjdhdbVo>> map = wzxqysjdhdb.stream()
.collect(Collectors.groupingBy(o -> o.getName() + o.getSpecification()));
List<wzxqysjdhdbVo> wzxqysjdhdbList = new ArrayList<>();
map.forEach((k, v) -> {
wzxqysjdhdbVo vo = new wzxqysjdhdbVo();
vo.setName(v.getFirst().getName());
vo.setSpecification(v.getFirst().getSpecification());
BigDecimal design = v.stream().map(wzxqysjdhdbVo::getDesignTotalPrices).reduce(BigDecimal.ZERO, BigDecimal::add);
vo.setDesignTotalPrices(design);
BigDecimal arrival = v.stream().map(wzxqysjdhdbVo::getArrivalTotalPrices).reduce(BigDecimal.ZERO, BigDecimal::add);
vo.setArrivalTotalPrices(arrival);
wzxqysjdhdbList.add(vo);
});
return wzxqysjdhdbList;
}
}

View File

@ -4,6 +4,7 @@ import cn.hutool.core.collection.CollUtil;
import cn.hutool.json.JSONArray; import cn.hutool.json.JSONArray;
import cn.hutool.json.JSONObject; import cn.hutool.json.JSONObject;
import cn.hutool.json.JSONUtil; import cn.hutool.json.JSONUtil;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import jakarta.annotation.Resource; import jakarta.annotation.Resource;
import org.dromara.bigscreen.domain.dto.ProjectImageProgressDetailReq; import org.dromara.bigscreen.domain.dto.ProjectImageProgressDetailReq;
@ -370,7 +371,7 @@ public class ProjectBigScreenServiceImpl implements ProjectBigScreenService {
// 如果有叶子节点,统计进度和状态;否则初始化为未完成 // 如果有叶子节点,统计进度和状态;否则初始化为未完成
if (CollUtil.isNotEmpty(leafNodesByTopIds)) { if (CollUtil.isNotEmpty(leafNodesByTopIds)) {
topVo.setProgressTotal(progressCategoryService.getCompletedPercentage(leafNodesByTopIds)); topVo.setProgressTotal(progressCategoryService.getCompletedPercentage(leafNodesByTopIds));
topVo.setValueTotal(progressCategoryService.getValueTotal(leafNodesByTopIds, true)); topVo.setValueTotal(progressCategoryService.getValueTotal(leafNodesByTopIds, true).getCurrentValue());
} else { } else {
topVo.setProgressTotal(BigDecimal.ZERO); topVo.setProgressTotal(BigDecimal.ZERO);
topVo.setValueTotal(BigDecimal.ZERO); topVo.setValueTotal(BigDecimal.ZERO);
@ -530,25 +531,38 @@ public class ProjectBigScreenServiceImpl implements ProjectBigScreenService {
Set<Long> projectIds = subProjects.stream().map(BusProject::getId).collect(Collectors.toSet()); Set<Long> projectIds = subProjects.stream().map(BusProject::getId).collect(Collectors.toSet());
projectIds.add(projectId); projectIds.add(projectId);
// 获取对应进度 // 获取对应进度
PgsProgressCategory progressCategory = progressCategoryService.lambdaQuery() List<PgsProgressCategory> progressCategoryList = progressCategoryService.lambdaQuery()
.in(PgsProgressCategory::getProjectId, projectIds) .in(PgsProgressCategory::getProjectId, projectIds)
.eq(PgsProgressCategory::getName, progressName) .eq(PgsProgressCategory::getName, progressName)
.last("limit 1") .list();
.one(); if (CollUtil.isEmpty(progressCategoryList)) {
if (progressCategory == null) {
return List.of(); return List.of();
} }
Long topId = progressCategory.getId();
final List<String> gfcqName = List.of("场地平整", "桩基成孔", "桩基浇筑", "支架安装", "组件安装");
// 查出所有属于该顶级节点的子孙节点 // 查出所有属于该顶级节点的子孙节点
List<PgsProgressCategory> allChildren = progressCategoryService.list( LambdaQueryWrapper<PgsProgressCategory> lqw = new LambdaQueryWrapper<>();
List<PgsProgressCategory> allChildren;
if (progressName.equals("光伏场区")) {
final List<String> gfcqName = List.of("场地平整", "桩基成孔", "桩基浇筑", "支架安装", "组件安装");
List<Long> topIds = progressCategoryList.stream().map(PgsProgressCategory::getId).toList();
// 查出所有属于这些顶级节点的子孙节点
allChildren = progressCategoryService.list(
Wrappers.<PgsProgressCategory>lambdaQuery() Wrappers.<PgsProgressCategory>lambdaQuery()
.in(progressName.equals("光伏场区"), PgsProgressCategory::getName, gfcqName) .in(!req.getIsAll(), PgsProgressCategory::getName, gfcqName)
.and(wrapper -> .and(wrapper -> {
wrapper.like(PgsProgressCategory::getAncestors, "," + topId + ",") for (Long topId : topIds) {
.or() wrapper.or(q -> q.like(PgsProgressCategory::getAncestors, "," + topId + ","))
.like(PgsProgressCategory::getAncestors, "," + topId)) .or(q -> q.like(PgsProgressCategory::getAncestors, "," + topId));
}
})
); );
} else {
PgsProgressCategory first = progressCategoryList.getFirst();
lqw.and(wrapper ->
wrapper.like(PgsProgressCategory::getAncestors, "," + first.getId() + ",")
.or()
.like(PgsProgressCategory::getAncestors, "," + first.getId()));
allChildren = progressCategoryService.list(lqw);
}
if (allChildren.isEmpty()) { if (allChildren.isEmpty()) {
return Collections.emptyList(); return Collections.emptyList();
} }
@ -556,7 +570,6 @@ public class ProjectBigScreenServiceImpl implements ProjectBigScreenService {
Set<Long> parentIds = allChildren.stream() Set<Long> parentIds = allChildren.stream()
.map(PgsProgressCategory::getParentId) .map(PgsProgressCategory::getParentId)
.collect(Collectors.toSet()); .collect(Collectors.toSet());
List<PgsProgressCategory> dierList = allChildren.stream() List<PgsProgressCategory> dierList = allChildren.stream()
.filter(item -> !parentIds.contains(item.getId())) .filter(item -> !parentIds.contains(item.getId()))
.toList(); .toList();
@ -568,6 +581,7 @@ public class ProjectBigScreenServiceImpl implements ProjectBigScreenService {
vo.setPlanProgress(c.getPlanTotal()); vo.setPlanProgress(c.getPlanTotal());
vo.setActualProgress(c.getCompleted()); vo.setActualProgress(c.getCompleted());
vo.setTotalProgress(c.getTotal()); vo.setTotalProgress(c.getTotal());
vo.setCompletionRate(BigDecimalUtil.toPercentage(c.getCompleted(), c.getTotal()));
return vo; return vo;
}).toList(); }).toList();
} }
@ -575,26 +589,48 @@ public class ProjectBigScreenServiceImpl implements ProjectBigScreenService {
Set<Long> parentIds = allChildren.stream() Set<Long> parentIds = allChildren.stream()
.map(PgsProgressCategory::getParentId) .map(PgsProgressCategory::getParentId)
.collect(Collectors.toSet()); .collect(Collectors.toSet());
List<PgsProgressCategory> dierList = allChildren.stream() List<PgsProgressCategory> dierList = allChildren.stream()
.filter(item -> parentIds.contains(item.getId())) .filter(item -> parentIds.contains(item.getId()))
.toList(); .toList();
List<ProjectImageProgressDetailVo> detailVoList = new ArrayList<>();
if (CollUtil.isEmpty(dierList)) { if (CollUtil.isEmpty(dierList)) {
return allChildren.stream().map(c -> { // 根据名称进行分类汇总
Map<String, List<PgsProgressCategory>> childrenMap = allChildren.stream()
.collect(Collectors.groupingBy(PgsProgressCategory::getName));
childrenMap.forEach((name, children) -> {
if (CollUtil.isEmpty(children)) {
return;
}
ProjectImageProgressDetailVo vo = new ProjectImageProgressDetailVo(); ProjectImageProgressDetailVo vo = new ProjectImageProgressDetailVo();
vo.setId(c.getId()); String unit = children.stream().map(PgsProgressCategory::getUnit)
vo.setUnit(c.getUnit()); .filter(Objects::nonNull)
vo.setProgressName(c.getName()); .findFirst().orElse(null);
vo.setPlanProgress(c.getPlanTotal()); vo.setUnit(unit);
vo.setActualProgress(c.getCompleted()); vo.setProgressName(name);
vo.setTotalProgress(c.getTotal()); BigDecimal plan = children.stream().map(PgsProgressCategory::getPlanTotal)
return vo; .reduce(BigDecimal.ZERO, BigDecimal::add);
}).toList(); vo.setPlanProgress(plan);
BigDecimal completed = children.stream().map(PgsProgressCategory::getCompleted)
.reduce(BigDecimal.ZERO, BigDecimal::add);
vo.setActualProgress(completed);
BigDecimal total = children.stream().map(PgsProgressCategory::getTotal)
.reduce(BigDecimal.ZERO, BigDecimal::add);
vo.setTotalProgress(total);
vo.setCompletionRate(BigDecimalUtil.toPercentage(completed, total));
detailVoList.add(vo);
});
} else { } else {
return dierList.stream().map(c -> { // 根据名称进行分类汇总
Map<String, List<PgsProgressCategory>> dierMap = dierList.stream()
.collect(Collectors.groupingBy(PgsProgressCategory::getName));
dierMap.forEach((name, value) -> {
ProjectImageProgressDetailVo vo = new ProjectImageProgressDetailVo();
Set<Long> parentIdSet = value.stream()
.map(PgsProgressCategory::getId)
.collect(Collectors.toSet());
// 获取子集 // 获取子集
List<PgsProgressCategory> children = allChildren.stream() List<PgsProgressCategory> children = allChildren.stream()
.filter(item -> item.getParentId().equals(c.getId())) .filter(item -> parentIdSet.contains(item.getParentId()))
.toList(); .toList();
// 计算 // 计算
BigDecimal plan = children.stream().map(PgsProgressCategory::getPlanTotal) BigDecimal plan = children.stream().map(PgsProgressCategory::getPlanTotal)
@ -603,16 +639,19 @@ public class ProjectBigScreenServiceImpl implements ProjectBigScreenService {
.reduce(BigDecimal.ZERO, BigDecimal::add); .reduce(BigDecimal.ZERO, BigDecimal::add);
BigDecimal total = children.stream().map(PgsProgressCategory::getTotal) BigDecimal total = children.stream().map(PgsProgressCategory::getTotal)
.reduce(BigDecimal.ZERO, BigDecimal::add); .reduce(BigDecimal.ZERO, BigDecimal::add);
ProjectImageProgressDetailVo vo = new ProjectImageProgressDetailVo();
vo.setId(c.getId());
vo.setUnit(c.getUnit());
vo.setProgressName(c.getName());
vo.setPlanProgress(plan); vo.setPlanProgress(plan);
vo.setActualProgress(actual); vo.setActualProgress(actual);
vo.setTotalProgress(total); vo.setTotalProgress(total);
return vo; vo.setProgressName(name);
}).toList(); String unit = value.stream().map(PgsProgressCategory::getUnit)
.filter(Objects::nonNull)
.findFirst().orElse(null);
vo.setUnit(unit);
vo.setCompletionRate(BigDecimalUtil.toPercentage(actual, total));
detailVoList.add(vo);
});
} }
return detailVoList;
} }
/** /**

View File

@ -24,10 +24,7 @@ import org.dromara.system.service.impl.SysRoleServiceImpl;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
import java.util.ArrayList; import java.util.*;
import java.util.Collection;
import java.util.List;
import java.util.Map;
/** /**
* 角色流程对应Service业务层处理 * 角色流程对应Service业务层处理
@ -94,6 +91,7 @@ public class SysRoleWorkServiceImpl extends ServiceImpl<SysRoleWorkMapper, SysRo
LambdaQueryWrapper<SysRoleWork> lqw = Wrappers.lambdaQuery(); LambdaQueryWrapper<SysRoleWork> lqw = Wrappers.lambdaQuery();
lqw.orderByDesc(SysRoleWork::getCreateTime); lqw.orderByDesc(SysRoleWork::getCreateTime);
lqw.eq(bo.getRoleId() != null, SysRoleWork::getRoleId, bo.getRoleId()); lqw.eq(bo.getRoleId() != null, SysRoleWork::getRoleId, bo.getRoleId());
lqw.eq(bo.getProjectId() != null, SysRoleWork::getProjectId, bo.getProjectId());
lqw.eq(StringUtils.isNotBlank(bo.getLcmc()), SysRoleWork::getLcmc, bo.getLcmc()); lqw.eq(StringUtils.isNotBlank(bo.getLcmc()), SysRoleWork::getLcmc, bo.getLcmc());
lqw.eq(StringUtils.isNotBlank(bo.getLcms()), SysRoleWork::getLcms, bo.getLcms()); lqw.eq(StringUtils.isNotBlank(bo.getLcms()), SysRoleWork::getLcms, bo.getLcms());
lqw.eq(StringUtils.isNotBlank(bo.getLcxq()), SysRoleWork::getLcxq, bo.getLcxq()); lqw.eq(StringUtils.isNotBlank(bo.getLcxq()), SysRoleWork::getLcxq, bo.getLcxq());
@ -197,8 +195,10 @@ public class SysRoleWorkServiceImpl extends ServiceImpl<SysRoleWorkMapper, SysRo
* 判断此角色在所有项目下所有角色是否有流程 * 判断此角色在所有项目下所有角色是否有流程
*/ */
public Boolean isHaveValue(Long userId){ public Boolean isHaveValue(Long userId){
//这个用户在所有项目下的角色列表
List<SysUserRole> allRoleList = baseMapper.getAllRoleList(userId); List<SysUserRole> allRoleList = baseMapper.getAllRoleList(userId);
for (SysUserRole sysUserRole : allRoleList) { for (SysUserRole sysUserRole : allRoleList) {
//用这个用户的角色id和项目id去查询角色流程对应
LambdaQueryWrapper<SysRoleWork> lqw = new LambdaQueryWrapper<>(); LambdaQueryWrapper<SysRoleWork> lqw = new LambdaQueryWrapper<>();
lqw.eq(SysRoleWork::getRoleId, sysUserRole.getRoleId()); lqw.eq(SysRoleWork::getRoleId, sysUserRole.getRoleId());
lqw.eq(SysRoleWork::getProjectId,sysUserRole.getProjectId()); lqw.eq(SysRoleWork::getProjectId,sysUserRole.getProjectId());
@ -242,57 +242,57 @@ public class SysRoleWorkServiceImpl extends ServiceImpl<SysRoleWorkMapper, SysRo
Long userId = LoginHelper.getUserId(); Long userId = LoginHelper.getUserId();
// 获取当前登录用户的所有项目及对应所有角色 // 获取当前登录用户的所有项目及对应所有角色
List<SysUserRole> allRoleList = baseMapper.getAllRoleList(userId); List<SysUserRole> allRoleList = baseMapper.getAllRoleList(userId);
// 获取项目
//初始化
// LambdaQueryWrapper<SysRoleWork> lqw = new LambdaQueryWrapper<>();
List<BusProjectVo> busProjectVoList = new ArrayList<>(); List<BusProjectVo> busProjectVoList = new ArrayList<>();
//维护一个该用户的 项目ID:角色ID map
Map<Long,Long> map = new HashMap<>();
//获取到该用户所有有流程的项目 说明在该项目下该用户有角色有所属流程 //获取到该用户所有有流程的项目 说明在该项目下该用户有角色有所属流程
for (SysUserRole sysUserRole : allRoleList) { for (SysUserRole sysUserRole : allRoleList) {
// lqw.clear();
// lqw.eq(SysRoleWork::getProjectId,sysUserRole.getProjectId());
// lqw.eq(SysRoleWork::getRoleId, sysUserRole.getRoleId());
// SysRoleWork one = getOne(lqw);
// if (one != null){
// //先拿到该项目
// BusProjectQueryReq req = new BusProjectQueryReq();
// req.setId(sysUserRole.getProjectId());
// List<BusProjectVo> vos = projectService.queryList(req);
// if (vos != null && !vos.isEmpty()){
// if(!busProjectVoList.contains(vos.getFirst())){
// busProjectVoList.add(vos.getFirst());
// }
// }
// }
BusProjectQueryReq req = new BusProjectQueryReq(); BusProjectQueryReq req = new BusProjectQueryReq();
req.setId(sysUserRole.getProjectId()); req.setId(sysUserRole.getProjectId());
List<BusProjectVo> vos = projectService.queryList(req); List<BusProjectVo> vos = projectService.queryList(req);
if (vos != null && !vos.isEmpty()){ if (vos != null && !vos.isEmpty()){
if(!busProjectVoList.contains(vos.getFirst())){ if(!busProjectVoList.contains(vos.getFirst())){
busProjectVoList.add(vos.getFirst()); busProjectVoList.add(vos.getFirst());
map.put(sysUserRole.getProjectId(),sysUserRole.getRoleId());
} }
} }
} }
//遍历
List<SysRoleWork> roleWorks = this.list();
List<SysRoleVo> roleVos; List<SysRoleVo> roleVos;
for (BusProjectVo projectVo : busProjectVoList) { for (BusProjectVo projectVo : busProjectVoList) {
roleVos = new ArrayList<>(); roleVos = new ArrayList<>();
//通过项目查找所有角色 for (SysRoleWork roleWork : roleWorks) {
LambdaQueryWrapper<SysRoleWork> lqw1 = new LambdaQueryWrapper<>(); if (map.containsKey(projectVo.getId()) && roleWork.getRoleId().equals(map.get(projectVo.getId()))){
lqw1.eq(SysRoleWork::getProjectId,projectVo.getId()); SysRoleVo sysRoleVo = roleService.selectRoleById(roleWork.getRoleId());
//获取角色
List<SysRoleWork> roleWorkList = list(lqw1);
for (SysRoleWork sysRoleWork : roleWorkList) {
SysRoleVo sysRoleVo = roleService.selectRoleById(sysRoleWork.getRoleId());
if (sysRoleVo != null){ if (sysRoleVo != null){
roleVos.add(sysRoleVo); roleVos.add(sysRoleVo);
} }
} }
}
projectVo.setRoleVos(roleVos); projectVo.setRoleVos(roleVos);
} }
//遍历
// for (BusProjectVo projectVo : busProjectVoList) {
// roleVos = new ArrayList<>();
// //通过项目查找所有角色
// LambdaQueryWrapper<SysRoleWork> lqw1 = new LambdaQueryWrapper<>();
// lqw1.eq(SysRoleWork::getProjectId,projectVo.getId());
// List<SysRoleWork> roleWorkList = list(lqw1);
// //遍历
// for (SysRoleWork sysRoleWork : roleWorkList) {
// SysRoleVo sysRoleVo = roleService.selectRoleById(sysRoleWork.getRoleId());
// if (sysRoleVo != null){
// roleVos.add(sysRoleVo);
// }
// }
// projectVo.setRoleVos(roleVos);
// }
return busProjectVoList; return busProjectVoList;
} }

View File

@ -7,17 +7,21 @@ import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.stream.Collectors; import java.util.stream.Collectors;
import cn.dev33.satoken.annotation.SaMode;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import lombok.RequiredArgsConstructor; import lombok.RequiredArgsConstructor;
import jakarta.servlet.http.HttpServletResponse; import jakarta.servlet.http.HttpServletResponse;
import jakarta.validation.constraints.*; import jakarta.validation.constraints.*;
import cn.dev33.satoken.annotation.SaCheckPermission; import cn.dev33.satoken.annotation.SaCheckPermission;
import org.dromara.cailiaoshebei.domain.bo.BusMaterialbatchdemandplanBo;
import org.dromara.cailiaoshebei.domain.bo.BusMrpBaseReq; import org.dromara.cailiaoshebei.domain.bo.BusMrpBaseReq;
import org.dromara.cailiaoshebei.domain.bo.RemainingReq; import org.dromara.cailiaoshebei.domain.bo.RemainingReq;
import org.dromara.cailiaoshebei.domain.dto.BusMrpDto; import org.dromara.cailiaoshebei.domain.dto.BusMrpDto;
import org.dromara.cailiaoshebei.domain.dto.BusMrpExportDto; import org.dromara.cailiaoshebei.domain.dto.BusMrpExportDto;
import org.dromara.cailiaoshebei.domain.vo.BusMaterialbatchdemandplanVo;
import org.dromara.cailiaoshebei.domain.vo.BusMrpVo; import org.dromara.cailiaoshebei.domain.vo.BusMrpVo;
import org.dromara.cailiaoshebei.service.IBusMaterialbatchdemandplanService;
import org.dromara.common.core.enums.BusinessStatusEnum; import org.dromara.common.core.enums.BusinessStatusEnum;
import org.dromara.common.core.exception.ServiceException; import org.dromara.common.core.exception.ServiceException;
import org.dromara.design.domain.BusBillofquantities; import org.dromara.design.domain.BusBillofquantities;
@ -67,6 +71,18 @@ public class BusMrpBaseController extends BaseController {
private final IBusBillofquantitiesService busBillofquantitiesService; private final IBusBillofquantitiesService busBillofquantitiesService;
private final IBusBiddingPlanService busBiddingPlanService; private final IBusBiddingPlanService busBiddingPlanService;
private final IBusMaterialbatchdemandplanService busMaterialbatchdemandplanService;
/**
* 查询物资-批次需求计划列表
*/
@SaCheckPermission("cailiaoshebei:mrpBase:list")
@GetMapping("/getPlanList")
public TableDataInfo<BusMaterialbatchdemandplanVo> list(BusMaterialbatchdemandplanBo bo, PageQuery pageQuery) {
return busMaterialbatchdemandplanService.queryPageList(bo, pageQuery);
}
/** /**
* 查询物资-批次需求计划基础信息列表 * 查询物资-批次需求计划基础信息列表
*/ */
@ -101,7 +117,7 @@ public class BusMrpBaseController extends BaseController {
* *
* @param id 主键 * @param id 主键
*/ */
@SaCheckPermission("cailiaoshebei:mrpBase:query") // @SaCheckPermission("cailiaoshebei:mrpBase:query")
@GetMapping("/{id}") @GetMapping("/{id}")
public R<BusMrpVo> getInfo(@NotNull(message = "主键不能为空") public R<BusMrpVo> getInfo(@NotNull(message = "主键不能为空")
@PathVariable Long id) { @PathVariable Long id) {
@ -146,7 +162,7 @@ public class BusMrpBaseController extends BaseController {
/** /**
* 批量新增或修改 * 批量新增或修改
*/ */
@SaCheckPermission("cailiaoshebei:mrpBase:addbatch") @SaCheckPermission("cailiaoshebei:mrpBase:add")
@RepeatSubmit() @RepeatSubmit()
@PostMapping("/batch") @PostMapping("/batch")
public R<Void> batchAddOrUpdate(@RequestBody BusMrpDto dto) { public R<Void> batchAddOrUpdate(@RequestBody BusMrpDto dto) {
@ -156,6 +172,7 @@ public class BusMrpBaseController extends BaseController {
/** /**
* 获取剩余量 * 获取剩余量
*/ */
@SaCheckPermission(value = {"cailiaoshebei:mrpBase:add","cailiaoshebei:mrpBase:edit"},mode = SaMode.OR)
@GetMapping("/remaining") @GetMapping("/remaining")
public R<List<Map<String,Object>>> remaining( RemainingReq req) { public R<List<Map<String,Object>>> remaining( RemainingReq req) {
String[] split = req.getLimitListId().split(","); String[] split = req.getLimitListId().split(",");
@ -171,7 +188,7 @@ public class BusMrpBaseController extends BaseController {
/** /**
* 导入物资需求批次计划 * 导入物资需求批次计划
*/ */
@SaCheckPermission("cailiaoshebei:mrpBase:import") @SaCheckPermission("cailiaoshebei:mrpBase:add")
@Log(title = "物资-批次需求计划基础信息", businessType = BusinessType.INSERT) @Log(title = "物资-批次需求计划基础信息", businessType = BusinessType.INSERT)
@RepeatSubmit() @RepeatSubmit()
@PostMapping("/import") @PostMapping("/import")
@ -200,7 +217,7 @@ public class BusMrpBaseController extends BaseController {
/** /**
* 获取工程量清单列表 * 获取工程量清单列表
*/ */
@SaCheckPermission("cailiaoshebei:mrpBase:getZhaoBiaoList") @SaCheckPermission(value = {"cailiaoshebei:mrpBase:add","cailiaoshebei:mrpBase:edit"},mode = SaMode.OR)
@GetMapping("/getZhaoBiaoList") @GetMapping("/getZhaoBiaoList")
public R<List<BusBiddingPlanVo>> getZhaoBiaoList(CoryObtainTheListReq req) { public R<List<BusBiddingPlanVo>> getZhaoBiaoList(CoryObtainTheListReq req) {
BusBiddingPlanBo bo = new BusBiddingPlanBo(); BusBiddingPlanBo bo = new BusBiddingPlanBo();
@ -216,7 +233,7 @@ public class BusMrpBaseController extends BaseController {
* @param bo * @param bo
* @return * @return
*/ */
@SaCheckPermission("cailiaoshebei:mrpBase:getMore") @SaCheckPermission("cailiaoshebei:mrpBase:list")
@GetMapping("/getMore") @GetMapping("/getMore")
public R<List<BusBillofquantitiesLimitListVo>> getMore(BusBiddingPlanBo bo) { public R<List<BusBillofquantitiesLimitListVo>> getMore(BusBiddingPlanBo bo) {
if (bo.getId() == null) { if (bo.getId() == null) {

View File

@ -1,6 +1,7 @@
package org.dromara.cailiaoshebei.controller; package org.dromara.cailiaoshebei.controller;
import cn.dev33.satoken.annotation.SaCheckPermission; import cn.dev33.satoken.annotation.SaCheckPermission;
import cn.dev33.satoken.annotation.SaMode;
import cn.hutool.core.collection.CollectionUtil; import cn.hutool.core.collection.CollectionUtil;
import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import jakarta.servlet.http.HttpServletResponse; import jakarta.servlet.http.HttpServletResponse;
@ -8,14 +9,12 @@ import jakarta.validation.constraints.NotEmpty;
import jakarta.validation.constraints.NotNull; import jakarta.validation.constraints.NotNull;
import lombok.RequiredArgsConstructor; import lombok.RequiredArgsConstructor;
import org.dromara.cailiaoshebei.domain.BusPlanDocAssociation; import org.dromara.cailiaoshebei.domain.BusPlanDocAssociation;
import org.dromara.cailiaoshebei.domain.bo.BusMaterialbatchdemandplanBo; import org.dromara.cailiaoshebei.domain.bo.*;
import org.dromara.cailiaoshebei.domain.bo.BusPurchaseDocBo; import org.dromara.cailiaoshebei.domain.vo.BusLtnVo;
import org.dromara.cailiaoshebei.domain.bo.FeedbackDto;
import org.dromara.cailiaoshebei.domain.vo.BusMaterialbatchdemandplanVo; import org.dromara.cailiaoshebei.domain.vo.BusMaterialbatchdemandplanVo;
import org.dromara.cailiaoshebei.domain.vo.BusMrpBaseVo;
import org.dromara.cailiaoshebei.domain.vo.BusPurchaseDocVo; import org.dromara.cailiaoshebei.domain.vo.BusPurchaseDocVo;
import org.dromara.cailiaoshebei.service.IBusMaterialbatchdemandplanService; import org.dromara.cailiaoshebei.service.*;
import org.dromara.cailiaoshebei.service.IBusPlanDocAssociationService;
import org.dromara.cailiaoshebei.service.IBusPurchaseDocService;
import org.dromara.common.core.domain.R; import org.dromara.common.core.domain.R;
import org.dromara.common.core.enums.BusinessStatusEnum; import org.dromara.common.core.enums.BusinessStatusEnum;
import org.dromara.common.core.exception.ServiceException; import org.dromara.common.core.exception.ServiceException;
@ -27,11 +26,18 @@ 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.PageQuery;
import org.dromara.common.mybatis.core.page.TableDataInfo; import org.dromara.common.mybatis.core.page.TableDataInfo;
import org.dromara.common.utils.logistics.LogisticsInquiryDemo;
import org.dromara.common.utils.logistics.LogisticsInquiryUtil;
import org.dromara.common.web.core.BaseController; import org.dromara.common.web.core.BaseController;
import org.dromara.design.domain.BusBillofquantities; import org.dromara.design.domain.BusBillofquantities;
import org.dromara.design.domain.BusBillofquantitiesVersions; import org.dromara.design.domain.BusBillofquantitiesVersions;
import org.dromara.design.service.IBusBillofquantitiesService; import org.dromara.design.service.IBusBillofquantitiesService;
import org.dromara.design.service.IBusBillofquantitiesVersionsService; import org.dromara.design.service.IBusBillofquantitiesVersionsService;
import org.dromara.tender.domain.bo.TenderSupplierInputReq;
import org.dromara.tender.domain.vo.TenderSupplierInputVo;
//import org.dromara.tender.service.ITenderSupplierInputService;
import org.dromara.xzd.domain.vo.XzdSupplierInfoVo;
import org.dromara.xzd.service.IXzdSupplierInfoService;
import org.springframework.validation.annotation.Validated; import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.*; import org.springframework.web.bind.annotation.*;
@ -64,6 +70,39 @@ public class BusPurchaseDocController extends BaseController {
private final IBusBillofquantitiesService busBillofquantitiesService; private final IBusBillofquantitiesService busBillofquantitiesService;
private final IBusMrpBaseService busMrpBaseService;
private final IXzdSupplierInfoService xzdSupplierInfoService;
// private final ITenderSupplierInputService tenderSupplierInputService;
private final IBusLtnService busLtnService;
/**
* 查询物资-物流单号列表
*/
@SaCheckPermission("cailiaoshebei:purchaseDoc:list")
@GetMapping("/getLtnList")
public TableDataInfo<BusLtnVo> getLtnList(BusLtnBo bo, PageQuery pageQuery) {
return busLtnService.queryPageList(bo, pageQuery);
}
/**
* 根据材料名查询物资-批次需求计划基础信息列表
*/
@SaCheckPermission(value = {"cailiaoshebei:purchaseDoc:add","cailiaoshebei:purchaseDoc:edit"},mode = SaMode.OR)
@GetMapping("/getMrpBaseListByName")
public R<List<BusMrpBaseVo>> getListByName(BusMrpBaseReq req) {
return R.ok(busMrpBaseService.getListByName(req));
}
/**
* 根据材料名获取供应商列表
*/
@SaCheckPermission(value = {"cailiaoshebei:purchaseDoc:add","cailiaoshebei:purchaseDoc:edit"},mode = SaMode.OR)
@GetMapping("/getListByName")
public R<List<XzdSupplierInfoVo>> getListByName(TenderSupplierInputReq req) {
return R.ok(xzdSupplierInfoService.getListByName(req));
}
/** /**
* 查询物资-采购联系单列表 * 查询物资-采购联系单列表
*/ */
@ -102,7 +141,7 @@ public class BusPurchaseDocController extends BaseController {
* *
* @param id 主键 * @param id 主键
*/ */
@SaCheckPermission("cailiaoshebei:purchaseDoc:query") // @SaCheckPermission("cailiaoshebei:purchaseDoc:query")
@GetMapping("/{id}") @GetMapping("/{id}")
public R<BusPurchaseDocVo> getInfo(@NotNull(message = "主键不能为空") public R<BusPurchaseDocVo> getInfo(@NotNull(message = "主键不能为空")
@PathVariable Long id) { @PathVariable Long id) {
@ -114,7 +153,7 @@ public class BusPurchaseDocController extends BaseController {
* *
* @param id 主键 * @param id 主键
*/ */
@SaCheckPermission("cailiaoshebei:purchaseDoc:pdf") @SaCheckPermission("cailiaoshebei:purchaseDoc:list")
@GetMapping("/pdf/{id}") @GetMapping("/pdf/{id}")
public R<String> getPic(@NotNull(message = "主键不能为空") public R<String> getPic(@NotNull(message = "主键不能为空")
@PathVariable Long id) { @PathVariable Long id) {

View File

@ -2,10 +2,14 @@ package org.dromara.cailiaoshebei.controller;
import java.util.List; import java.util.List;
import cn.dev33.satoken.annotation.SaMode;
import lombok.RequiredArgsConstructor; import lombok.RequiredArgsConstructor;
import jakarta.servlet.http.HttpServletResponse; import jakarta.servlet.http.HttpServletResponse;
import jakarta.validation.constraints.*; import jakarta.validation.constraints.*;
import cn.dev33.satoken.annotation.SaCheckPermission; import cn.dev33.satoken.annotation.SaCheckPermission;
import org.dromara.system.domain.bo.SysUserBo;
import org.dromara.system.domain.vo.SysUserVo;
import org.dromara.system.service.ISysUserService;
import org.springframework.web.bind.annotation.*; import org.springframework.web.bind.annotation.*;
import org.springframework.validation.annotation.Validated; import org.springframework.validation.annotation.Validated;
import org.dromara.common.idempotent.annotation.RepeatSubmit; import org.dromara.common.idempotent.annotation.RepeatSubmit;
@ -36,6 +40,16 @@ public class BusPurchaseUserController extends BaseController {
private final IBusPurchaseUserService busPurchaseUserService; private final IBusPurchaseUserService busPurchaseUserService;
private final ISysUserService userService;
/**
* 获取系统用户列表
*/
@SaCheckPermission(value = {"cailiaoshebei:purchaseUser:list","cailiaoshebei:purchaseUser:add","cailiaoshebei:purchaseUser:edit"},mode = SaMode.OR)
@GetMapping("/getUserList")
public TableDataInfo<SysUserVo> list(SysUserBo user, PageQuery pageQuery) {
return userService.selectPageUserList(user, pageQuery);
}
/** /**
* 查询物资采购人员列表 * 查询物资采购人员列表
*/ */
@ -61,7 +75,7 @@ public class BusPurchaseUserController extends BaseController {
* *
* @param id 主键 * @param id 主键
*/ */
@SaCheckPermission("cailiaoshebei:purchaseUser:query") // @SaCheckPermission("cailiaoshebei:purchaseUser:query")
@GetMapping("/{id}") @GetMapping("/{id}")
public R<BusPurchaseUserVo> getInfo(@NotNull(message = "主键不能为空") public R<BusPurchaseUserVo> getInfo(@NotNull(message = "主键不能为空")
@PathVariable Long id) { @PathVariable Long id) {
@ -107,7 +121,7 @@ public class BusPurchaseUserController extends BaseController {
/** /**
* 新增或修改物资采购人员 * 新增或修改物资采购人员
*/ */
@SaCheckPermission("cailiaoshebei:purchaseUser:addOrUpdate") @SaCheckPermission(value = {"cailiaoshebei:purchaseUser:add","cailiaoshebei:purchaseUser:edit"},mode = SaMode.OR)
@Log(title = "物资采购人员", businessType = BusinessType.INSERT) @Log(title = "物资采购人员", businessType = BusinessType.INSERT)
@RepeatSubmit() @RepeatSubmit()
@PostMapping("/addOrUpdate") @PostMapping("/addOrUpdate")
@ -121,7 +135,7 @@ public class BusPurchaseUserController extends BaseController {
* *
* @param projectId 项目id * @param projectId 项目id
*/ */
@SaCheckPermission("cailiaoshebei:purchaseUser:byProject") @SaCheckPermission("cailiaoshebei:purchaseUser:list")
@GetMapping("/byProject/{projectId}") @GetMapping("/byProject/{projectId}")
public R<BusPurchaseUserVo> getInfoByProject(@NotNull(message = "主键不能为空") public R<BusPurchaseUserVo> getInfoByProject(@NotNull(message = "主键不能为空")
@PathVariable Long projectId) { @PathVariable Long projectId) {

View File

@ -1,6 +1,7 @@
package org.dromara.cailiaoshebei.controller; package org.dromara.cailiaoshebei.controller;
import cn.dev33.satoken.annotation.SaCheckPermission; import cn.dev33.satoken.annotation.SaCheckPermission;
import cn.dev33.satoken.annotation.SaMode;
import cn.hutool.core.bean.BeanUtil; import cn.hutool.core.bean.BeanUtil;
import jakarta.servlet.http.HttpServletResponse; import jakarta.servlet.http.HttpServletResponse;
import jakarta.validation.constraints.NotNull; import jakarta.validation.constraints.NotNull;
@ -47,7 +48,7 @@ public class BusTotalsupplyplanController extends BaseController {
/** /**
* 获取主数据列表 * 获取主数据列表
*/ */
@SaCheckPermission("design:totalsupplyplan:queryList") @SaCheckPermission("design:totalsupplyplan:list")
@GetMapping("/queryList") @GetMapping("/queryList")
public R<List<BusTotalsupplyplanAuditVo>> queryList(TotalsupplyplanQueryListReq bo) { public R<List<BusTotalsupplyplanAuditVo>> queryList(TotalsupplyplanQueryListReq bo) {
BusTotalsupplyplanAuditBo busTotalsupplyplanAuditBo = BeanUtil.copyProperties(bo, BusTotalsupplyplanAuditBo.class); BusTotalsupplyplanAuditBo busTotalsupplyplanAuditBo = BeanUtil.copyProperties(bo, BusTotalsupplyplanAuditBo.class);
@ -57,7 +58,7 @@ public class BusTotalsupplyplanController extends BaseController {
/** /**
* 根据主数据获取到详情 * 根据主数据获取到详情
*/ */
@SaCheckPermission("design:totalsupplyplan:masterData") @SaCheckPermission(value = {"design:totalsupplyplan:list","design:totalsupplyplan:add","design:totalsupplyplan:edit"},mode = SaMode.OR)
@GetMapping("/masterData") @GetMapping("/masterData")
public R<MasterDataReqDto> masterData(MasterDataReq bo) { public R<MasterDataReqDto> masterData(MasterDataReq bo) {
return R.ok(busTotalsupplyplanService.masterData(bo)); return R.ok(busTotalsupplyplanService.masterData(bo));
@ -86,7 +87,7 @@ public class BusTotalsupplyplanController extends BaseController {
/** /**
* 导入物资-总供应计划数据 * 导入物资-总供应计划数据
*/ */
@SaCheckPermission("design:totalsupplyplan:import") @SaCheckPermission("design:totalsupplyplan:add")
@Log(title = "物资-总供应计划", businessType = BusinessType.IMPORT) @Log(title = "物资-总供应计划", businessType = BusinessType.IMPORT)
@PostMapping("/import") @PostMapping("/import")
public R<Void> importData(@RequestPart("file") MultipartFile file) { public R<Void> importData(@RequestPart("file") MultipartFile file) {
@ -98,7 +99,7 @@ public class BusTotalsupplyplanController extends BaseController {
* *
* @param id 主键 * @param id 主键
*/ */
@SaCheckPermission("design:totalsupplyplan:query") // @SaCheckPermission("design:totalsupplyplan:query")
@GetMapping("/{id}") @GetMapping("/{id}")
public R<BusTotalsupplyplanVo> getInfo(@NotNull(message = "主键不能为空") public R<BusTotalsupplyplanVo> getInfo(@NotNull(message = "主键不能为空")
@PathVariable Long id) { @PathVariable Long id) {
@ -130,7 +131,7 @@ public class BusTotalsupplyplanController extends BaseController {
/** /**
* 批量修改物资-总供应计划 * 批量修改物资-总供应计划
*/ */
@SaCheckPermission("design:totalsupplyplan:batchEdit") @SaCheckPermission("design:totalsupplyplan:edit")
@Log(title = "物资-总供应计划", businessType = BusinessType.UPDATE) @Log(title = "物资-总供应计划", businessType = BusinessType.UPDATE)
@RepeatSubmit() @RepeatSubmit()
@PutMapping("/batchEdit") @PutMapping("/batchEdit")

View File

@ -3,6 +3,7 @@ package org.dromara.cailiaoshebei.controller.app;
import cn.dev33.satoken.annotation.SaCheckPermission; import cn.dev33.satoken.annotation.SaCheckPermission;
import cn.hutool.core.collection.CollectionUtil; import cn.hutool.core.collection.CollectionUtil;
import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import jakarta.annotation.Resource;
import jakarta.servlet.http.HttpServletResponse; import jakarta.servlet.http.HttpServletResponse;
import jakarta.validation.constraints.NotEmpty; import jakarta.validation.constraints.NotEmpty;
import jakarta.validation.constraints.NotNull; import jakarta.validation.constraints.NotNull;
@ -30,7 +31,10 @@ import org.dromara.design.service.IBusBillofquantitiesService;
import org.dromara.design.service.IBusBillofquantitiesVersionsService; import org.dromara.design.service.IBusBillofquantitiesVersionsService;
import org.dromara.tender.domain.bo.TenderSupplierInputBo; import org.dromara.tender.domain.bo.TenderSupplierInputBo;
import org.dromara.tender.domain.vo.TenderSupplierInputVo; import org.dromara.tender.domain.vo.TenderSupplierInputVo;
import org.dromara.tender.service.ITenderSupplierInputService; //import org.dromara.tender.service.ITenderSupplierInputService;
import org.dromara.xzd.domain.bo.XzdSupplierInfoBo;
import org.dromara.xzd.domain.vo.XzdSupplierInfoVo;
import org.dromara.xzd.service.IXzdSupplierInfoService;
import org.springframework.validation.annotation.Validated; import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.*; import org.springframework.web.bind.annotation.*;
@ -63,7 +67,9 @@ public class BusPurchaseDocAppController extends BaseController {
private final IBusBillofquantitiesService busBillofquantitiesService; private final IBusBillofquantitiesService busBillofquantitiesService;
private final ITenderSupplierInputService tenderSupplierInputService; // private final ITenderSupplierInputService tenderSupplierInputService;
@Resource
private IXzdSupplierInfoService supplierInfoService;
/** /**
@ -78,8 +84,8 @@ public class BusPurchaseDocAppController extends BaseController {
* 查询供应商入库列表 * 查询供应商入库列表
*/ */
@GetMapping("/supList") @GetMapping("/supList")
public TableDataInfo<TenderSupplierInputVo> list(TenderSupplierInputBo bo, PageQuery pageQuery) { public TableDataInfo<XzdSupplierInfoVo> list(XzdSupplierInfoBo bo, PageQuery pageQuery) {
return tenderSupplierInputService.queryPageList(bo, pageQuery); return supplierInfoService.queryPageList(bo, pageQuery);
} }
/** /**

View File

@ -94,6 +94,12 @@ public class BusMaterialbatchdemandplan extends BaseEntity {
*/ */
private BigDecimal demandQuantity; private BigDecimal demandQuantity;
/**
* 单价
*/
private BigDecimal unitPrice;
/** /**
* 计划到场时间 * 计划到场时间
*/ */

View File

@ -93,6 +93,11 @@ public class BusMaterialbatchdemandplanBo extends BaseEntity {
*/ */
private BigDecimal demandQuantity; private BigDecimal demandQuantity;
/**
* 单价
*/
private BigDecimal unitPrice;
/** /**
* 计划到场时间 * 计划到场时间
*/ */

View File

@ -118,6 +118,11 @@ public class BusMaterialbatchdemandplanVo implements Serializable {
@ExcelProperty(value = "需求数量") @ExcelProperty(value = "需求数量")
private BigDecimal demandQuantity; private BigDecimal demandQuantity;
/**
* 单价
*/
private BigDecimal unitPrice;
/** /**
* 计划到场时间 * 计划到场时间
*/ */

View File

@ -1,5 +1,7 @@
package org.dromara.cailiaoshebei.service; package org.dromara.cailiaoshebei.service;
import org.dromara.bigscreen.domain.vo.designAndArrivalComparisonVo;
import org.dromara.bigscreen.domain.vo.wzxqysjdhdbVo;
import org.dromara.cailiaoshebei.domain.bo.BusMrpBaseReq; import org.dromara.cailiaoshebei.domain.bo.BusMrpBaseReq;
import org.dromara.cailiaoshebei.domain.dto.BusMrpDto; import org.dromara.cailiaoshebei.domain.dto.BusMrpDto;
import org.dromara.cailiaoshebei.domain.dto.BusMrpExportDto; import org.dromara.cailiaoshebei.domain.dto.BusMrpExportDto;
@ -90,4 +92,14 @@ public interface IBusMrpBaseService extends IService<BusMrpBase>{
Map<String, Object> remaining(Long projectId,Long limitListId,Long mrpBaseId); Map<String, Object> remaining(Long projectId,Long limitListId,Long mrpBaseId);
List<BusMrpBaseVo> getListByName(BusMrpBaseReq req); List<BusMrpBaseVo> getListByName(BusMrpBaseReq req);
/**
* 设计量与到货量对比
*/
List<designAndArrivalComparisonVo> designAndArrivalComparison(Long projectId);
/**
* 物资需求与实际到货对比
*/
List<wzxqysjdhdbVo> wzxqysjdhdb(Long projectId);
} }

View File

@ -105,4 +105,6 @@ public interface IBusPurchaseDocService extends IService<BusPurchaseDoc> {
* @return 是否修改成功 * @return 是否修改成功
*/ */
Boolean updateFeedback(FeedbackDto dto); Boolean updateFeedback(FeedbackDto dto);
List<BusPurchaseDocVo> purchaseNote(Long projectId);
} }

View File

@ -33,7 +33,7 @@ import org.dromara.tender.domain.vo.BusBillofquantitiesLimitListVo;
import org.dromara.tender.domain.vo.BusTenderPlanningLimitListVo; import org.dromara.tender.domain.vo.BusTenderPlanningLimitListVo;
import org.dromara.tender.service.IBusBiddingPlanService; import org.dromara.tender.service.IBusBiddingPlanService;
import org.dromara.tender.service.IBusBillofquantitiesLimitListService; import org.dromara.tender.service.IBusBillofquantitiesLimitListService;
import org.dromara.tender.service.ITenderSupplierInputService; //import org.dromara.tender.service.ITenderSupplierInputService;
import org.springframework.context.annotation.Lazy; import org.springframework.context.annotation.Lazy;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Lazy; import org.springframework.context.annotation.Lazy;

View File

@ -1,20 +1,33 @@
package org.dromara.cailiaoshebei.service.impl; package org.dromara.cailiaoshebei.service.impl;
import cn.hutool.core.bean.BeanUtil; import cn.hutool.core.bean.BeanUtil;
import cn.hutool.core.collection.CollUtil;
import cn.hutool.core.collection.CollectionUtil; import cn.hutool.core.collection.CollectionUtil;
import cn.hutool.core.convert.Convert; import cn.hutool.core.convert.Convert;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
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 lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.Slf4j;
import org.dromara.bigscreen.domain.vo.designAndArrivalComparisonVo;
import org.dromara.bigscreen.domain.vo.wzxqysjdhdbVo;
import org.dromara.cailiaoshebei.domain.BusMaterialbatchdemandplan; import org.dromara.cailiaoshebei.domain.BusMaterialbatchdemandplan;
import org.dromara.cailiaoshebei.domain.BusMrpBase;
import org.dromara.cailiaoshebei.domain.BusPlanDocAssociation; import org.dromara.cailiaoshebei.domain.BusPlanDocAssociation;
import org.dromara.cailiaoshebei.domain.bo.BusMaterialbatchdemandplanBo; import org.dromara.cailiaoshebei.domain.bo.BusMaterialbatchdemandplanBo;
import org.dromara.cailiaoshebei.domain.bo.BusMrpBaseBo;
import org.dromara.cailiaoshebei.domain.bo.BusMrpBaseReq; import org.dromara.cailiaoshebei.domain.bo.BusMrpBaseReq;
import org.dromara.cailiaoshebei.domain.dto.BusMaterialbatchdemandplanExportDto; import org.dromara.cailiaoshebei.domain.dto.BusMaterialbatchdemandplanExportDto;
import org.dromara.cailiaoshebei.domain.dto.BusMrpDto; import org.dromara.cailiaoshebei.domain.dto.BusMrpDto;
import org.dromara.cailiaoshebei.domain.dto.BusMrpExportDto; import org.dromara.cailiaoshebei.domain.dto.BusMrpExportDto;
import org.dromara.cailiaoshebei.domain.vo.BusMaterialbatchdemandplanVo; import org.dromara.cailiaoshebei.domain.vo.BusMaterialbatchdemandplanVo;
import org.dromara.cailiaoshebei.domain.vo.BusMrpBaseVo;
import org.dromara.cailiaoshebei.domain.vo.BusMrpVo; import org.dromara.cailiaoshebei.domain.vo.BusMrpVo;
import org.dromara.cailiaoshebei.mapper.BusMrpBaseMapper;
import org.dromara.cailiaoshebei.service.IBusMaterialbatchdemandplanService; import org.dromara.cailiaoshebei.service.IBusMaterialbatchdemandplanService;
import org.dromara.cailiaoshebei.service.IBusMrpBaseService;
import org.dromara.cailiaoshebei.service.IBusPlanDocAssociationService; import org.dromara.cailiaoshebei.service.IBusPlanDocAssociationService;
import org.dromara.common.core.domain.event.ProcessDeleteEvent; import org.dromara.common.core.domain.event.ProcessDeleteEvent;
import org.dromara.common.core.domain.event.ProcessEvent; import org.dromara.common.core.domain.event.ProcessEvent;
@ -23,26 +36,20 @@ import org.dromara.common.core.enums.BusinessStatusEnum;
import org.dromara.common.core.exception.ServiceException; import org.dromara.common.core.exception.ServiceException;
import org.dromara.common.core.utils.MapstructUtils; import org.dromara.common.core.utils.MapstructUtils;
import org.dromara.common.core.utils.StringUtils; import org.dromara.common.core.utils.StringUtils;
import org.dromara.common.mybatis.core.page.TableDataInfo;
import org.dromara.common.mybatis.core.page.PageQuery; import org.dromara.common.mybatis.core.page.PageQuery;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import org.dromara.common.mybatis.core.page.TableDataInfo;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import lombok.RequiredArgsConstructor;
import org.dromara.common.utils.excel.ExcelDynamicReader; import org.dromara.common.utils.excel.ExcelDynamicReader;
import org.dromara.design.domain.BusBillofquantities; import org.dromara.materials.domain.MatMaterialReceiveItem;
import org.dromara.design.service.IBusBillofquantitiesService; import org.dromara.materials.service.IMatMaterialReceiveItemService;
import org.dromara.tender.domain.BusBillofquantitiesLimitList; import org.dromara.tender.domain.BusBillofquantitiesLimitList;
import org.dromara.tender.domain.BusTenderPlanningLimitList; import org.dromara.tender.domain.BusTenderPlanningLimitList;
import org.dromara.tender.enums.LimitListTypeEnum;
import org.dromara.tender.service.IBusBillofquantitiesLimitListService; import org.dromara.tender.service.IBusBillofquantitiesLimitListService;
import org.dromara.tender.service.IBusTenderPlanningLimitListService; import org.dromara.tender.service.IBusTenderPlanningLimitListService;
import org.jetbrains.annotations.NotNull;
import org.springframework.context.annotation.Lazy;
import org.springframework.context.event.EventListener; import org.springframework.context.event.EventListener;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
import org.dromara.cailiaoshebei.domain.bo.BusMrpBaseBo;
import org.dromara.cailiaoshebei.domain.vo.BusMrpBaseVo;
import org.dromara.cailiaoshebei.domain.BusMrpBase;
import org.dromara.cailiaoshebei.mapper.BusMrpBaseMapper;
import org.dromara.cailiaoshebei.service.IBusMrpBaseService;
import org.springframework.transaction.annotation.Transactional; import org.springframework.transaction.annotation.Transactional;
import java.math.BigDecimal; import java.math.BigDecimal;
@ -70,6 +77,9 @@ public class BusMrpBaseServiceImpl extends ServiceImpl<BusMrpBaseMapper, BusMrpB
private final IBusTenderPlanningLimitListService tenderPlanningLimitListService; private final IBusTenderPlanningLimitListService tenderPlanningLimitListService;
@Lazy
@Resource
private IMatMaterialReceiveItemService matMaterialReceiveItemService;
/** /**
@ -249,7 +259,7 @@ public class BusMrpBaseServiceImpl extends ServiceImpl<BusMrpBaseMapper, BusMrpB
.findFirst() .findFirst()
.map(item -> { .map(item -> {
String name = item.getName() != null ? item.getName() : ""; String name = item.getName() != null ? item.getName() : "";
return "名称:“"+name + ""; return "名称:“" + name + "";
}) })
.orElse("未知物料"); .orElse("未知物料");
throw new ServiceException(itemName + "超出数量"); throw new ServiceException(itemName + "超出数量");
@ -299,7 +309,7 @@ public class BusMrpBaseServiceImpl extends ServiceImpl<BusMrpBaseMapper, BusMrpB
@Override @Override
public Map<String, Object> remaining(Long projectId, Long limitListId,Long mrpBaseId) { public Map<String, Object> remaining(Long projectId, Long limitListId, Long mrpBaseId) {
Map<String, Object> map = new HashMap<>(); Map<String, Object> map = new HashMap<>();
List<BusTenderPlanningLimitList> busTenderPlanningLimitLists = tenderPlanningLimitListService.getBaseMapper() List<BusTenderPlanningLimitList> busTenderPlanningLimitLists = tenderPlanningLimitListService.getBaseMapper()
.selectList(new LambdaQueryWrapper<BusTenderPlanningLimitList>() .selectList(new LambdaQueryWrapper<BusTenderPlanningLimitList>()
@ -313,22 +323,23 @@ public class BusMrpBaseServiceImpl extends ServiceImpl<BusMrpBaseMapper, BusMrpB
// 获取数据库中已有的数量 // 获取数据库中已有的数量
List<BusMaterialbatchdemandplan> existingList = planservice.list( List<BusMaterialbatchdemandplan> existingList = planservice.list(
Wrappers.lambdaQuery(BusMaterialbatchdemandplan.class) Wrappers.lambdaQuery(BusMaterialbatchdemandplan.class)
.eq(BusMaterialbatchdemandplan::getSuppliespriceId ,limitListId) .eq(BusMaterialbatchdemandplan::getSuppliespriceId, limitListId)
.ne(mrpBaseId!=null,BusMaterialbatchdemandplan::getMrpBaseId, mrpBaseId)// 排除当前批次 .ne(mrpBaseId != null, BusMaterialbatchdemandplan::getMrpBaseId, mrpBaseId)// 排除当前批次
); );
BigDecimal reduce = BigDecimal.ZERO; BigDecimal reduce = BigDecimal.ZERO;
if(CollectionUtil.isNotEmpty(existingList)){ if (CollectionUtil.isNotEmpty(existingList)) {
reduce = existingList.stream() reduce = existingList.stream()
.map(BusMaterialbatchdemandplan::getDemandQuantity) .map(BusMaterialbatchdemandplan::getDemandQuantity)
.reduce(BigDecimal.ZERO, BigDecimal::add); .reduce(BigDecimal.ZERO, BigDecimal::add);
} }
map.put("remainingQuantity",quantity.subtract(reduce)); map.put("remainingQuantity", quantity.subtract(reduce));
map.put("suppliespriceId",limitListId); map.put("suppliespriceId", limitListId);
if (busBillofquantities != null) { if (busBillofquantities != null) {
map.put("specification",busBillofquantities.getSpecification()); map.put("specification", busBillofquantities.getSpecification());
map.put("unit",busBillofquantities.getUnit()); map.put("unit", busBillofquantities.getUnit());
map.put("remark",busBillofquantities.getRemark()); map.put("unitPrice", busBillofquantities.getUnitPrice());
map.put("name",busBillofquantities.getName()); map.put("remark", busBillofquantities.getRemark());
map.put("name", busBillofquantities.getName());
} }
return map; return map;
} }
@ -343,7 +354,7 @@ public class BusMrpBaseServiceImpl extends ServiceImpl<BusMrpBaseMapper, BusMrpB
.like(BusMaterialbatchdemandplan::getName, req.getName())); .like(BusMaterialbatchdemandplan::getName, req.getName()));
Iterator<BusMaterialbatchdemandplan> iterator = busMaterialbatchdemandplans.iterator(); Iterator<BusMaterialbatchdemandplan> iterator = busMaterialbatchdemandplans.iterator();
Set<Long> mrpIds = new HashSet<>(); Set<Long> mrpIds = new HashSet<>();
while (iterator.hasNext()){ while (iterator.hasNext()) {
BusMaterialbatchdemandplan next = iterator.next(); BusMaterialbatchdemandplan next = iterator.next();
List<BusPlanDocAssociation> busPlanDocAssociations = planDocAssociationService.getBaseMapper().selectList(new LambdaQueryWrapper<BusPlanDocAssociation>() List<BusPlanDocAssociation> busPlanDocAssociations = planDocAssociationService.getBaseMapper().selectList(new LambdaQueryWrapper<BusPlanDocAssociation>()
.eq(BusPlanDocAssociation::getProjectId, req.getProjectId()) .eq(BusPlanDocAssociation::getProjectId, req.getProjectId())
@ -354,15 +365,93 @@ public class BusMrpBaseServiceImpl extends ServiceImpl<BusMrpBaseMapper, BusMrpB
}); });
if (demandQuantity.compareTo(next.getDemandQuantity()) >= 0) { if (demandQuantity.compareTo(next.getDemandQuantity()) >= 0) {
iterator.remove(); iterator.remove();
}else { } else {
mrpIds.add(next.getMrpBaseId()); mrpIds.add(next.getMrpBaseId());
} }
} }
if (mrpIds.isEmpty()){ if (mrpIds.isEmpty()) {
return null; return null;
} }
return baseMapper.selectVoList(new LambdaQueryWrapper<BusMrpBase>() return baseMapper.selectVoList(new LambdaQueryWrapper<BusMrpBase>()
.eq(BusMrpBase::getStatus,BusinessStatusEnum.FINISH.getStatus()).in(BusMrpBase::getId,mrpIds)); .eq(BusMrpBase::getStatus, BusinessStatusEnum.FINISH.getStatus()).in(BusMrpBase::getId, mrpIds));
}
@Override
public List<designAndArrivalComparisonVo> designAndArrivalComparison(Long projectId) {
// 获取施工图一览的所有材料数据
List<BusBillofquantitiesLimitList> limitLists = busBillofquantitiesService.getBaseMapper().selectList(new LambdaQueryWrapper<BusBillofquantitiesLimitList>()
.eq(BusBillofquantitiesLimitList::getProjectId, projectId)
.eq(BusBillofquantitiesLimitList::getType, LimitListTypeEnum.SPECIAL.getCode())
.isNotNull(BusBillofquantitiesLimitList::getQuantity));
Map<Long, BigDecimal> wuZiMap = getWuZiMap(projectId);
// 根据批次需求计划的物资id获取到施工图一览对应数据
List<designAndArrivalComparisonVo> list = new ArrayList<>();
limitLists.forEach(limitList -> {
designAndArrivalComparisonVo vo = new designAndArrivalComparisonVo();
vo.setName(limitList.getName());
vo.setSpecification(limitList.getSpecification());
vo.setUnit(limitList.getUnit());
vo.setDesignTotalPrices(limitList.getQuantity());
vo.setArrivalTotalPrices(wuZiMap.getOrDefault(limitList.getId(), BigDecimal.ZERO));
list.add(vo);
});
return list;
}
@NotNull
private Map<Long, BigDecimal> getWuZiMap(Long projectId) {
// 获取所有入库数据 mat_material_receive_item
List<MatMaterialReceiveItem> matMaterialReceiveItems = matMaterialReceiveItemService.getBaseMapper()
.selectList(new LambdaQueryWrapper<MatMaterialReceiveItem>()
.eq(MatMaterialReceiveItem::getProjectId, projectId));
//将相同计划批次数据进行分组合并
Set<Long> planIds = matMaterialReceiveItems.stream()
.map(MatMaterialReceiveItem::getPlanId)
.collect(Collectors.toSet());
if (CollUtil.isEmpty(planIds)) {
return new HashMap<>();
}
Map<Long, BigDecimal> planMap = matMaterialReceiveItems.stream()
.filter(matMaterialReceiveItem -> matMaterialReceiveItem.getPlanId() != null)
.collect(Collectors.groupingBy(
MatMaterialReceiveItem::getPlanId,
Collectors.reducing(BigDecimal.ZERO, MatMaterialReceiveItem::getAcceptedQuantity, BigDecimal::add)
));
// 根据入库数据反查批次需求计划数据 bus_materialbatchdemandplan
List<BusMaterialbatchdemandplan> materialbatchdemandplans = planservice.getBaseMapper().selectList(new LambdaQueryWrapper<BusMaterialbatchdemandplan>()
.eq(BusMaterialbatchdemandplan::getProjectId, projectId)
.in(BusMaterialbatchdemandplan::getId, planIds));
Map<Long, BigDecimal> wuZiMap = new HashMap<>();
materialbatchdemandplans.forEach(materialbatchdemandplan -> {
//merge()方法如果键存在则合并值,否则直接放入
wuZiMap.merge(
materialbatchdemandplan.getSuppliespriceId(),
planMap.get(materialbatchdemandplan.getId()),
BigDecimal::add
);
});
return wuZiMap;
}
@Override
public List<wzxqysjdhdbVo> wzxqysjdhdb(Long projectId) {
// 获取施工图一览的所有材料数据
List<BusBillofquantitiesLimitList> limitLists = busBillofquantitiesService.getBaseMapper().selectList(new LambdaQueryWrapper<BusBillofquantitiesLimitList>()
.eq(BusBillofquantitiesLimitList::getProjectId, projectId)
.eq(BusBillofquantitiesLimitList::getType, LimitListTypeEnum.SPECIAL.getCode())
.isNotNull(BusBillofquantitiesLimitList::getQuantity));
Map<Long, BigDecimal> wuZiMap = getWuZiMap(projectId);
// 根据批次需求计划的物资id获取到施工图一览对应数据
List<wzxqysjdhdbVo> list = new ArrayList<>();
limitLists.forEach(limitList -> {
wzxqysjdhdbVo vo = new wzxqysjdhdbVo();
vo.setName(limitList.getName());
vo.setSpecification(limitList.getSpecification());
vo.setDesignTotalPrices(limitList.getQuantity());
vo.setArrivalTotalPrices(wuZiMap.getOrDefault(limitList.getId(), BigDecimal.ZERO));
list.add(vo);
});
return list;
} }
/** /**

View File

@ -111,6 +111,9 @@ public class BusPurchaseDocServiceImpl extends ServiceImpl<BusPurchaseDocMapper,
@Override @Override
public BusPurchaseDocVo queryById(Long id) { public BusPurchaseDocVo queryById(Long id) {
BusPurchaseDocVo busPurchaseDocVo = baseMapper.selectVoById(id); BusPurchaseDocVo busPurchaseDocVo = baseMapper.selectVoById(id);
if (busPurchaseDocVo == null){
return busPurchaseDocVo;
}
BusPlanDocAssociationBo busPlanDocAssociationBo = new BusPlanDocAssociationBo(); BusPlanDocAssociationBo busPlanDocAssociationBo = new BusPlanDocAssociationBo();
busPlanDocAssociationBo.setDocId(id); busPlanDocAssociationBo.setDocId(id);
List<BusPlanDocAssociationVo> busPlanDocAssociationVos = planDocAssociationService.queryList(busPlanDocAssociationBo); List<BusPlanDocAssociationVo> busPlanDocAssociationVos = planDocAssociationService.queryList(busPlanDocAssociationBo);
@ -191,7 +194,7 @@ public class BusPurchaseDocServiceImpl extends ServiceImpl<BusPurchaseDocMapper,
BusPurchaseDoc add = MapstructUtils.convert(bo, BusPurchaseDoc.class); BusPurchaseDoc add = MapstructUtils.convert(bo, BusPurchaseDoc.class);
validEntityBeforeSave(add); validEntityBeforeSave(add);
validNum(bo.getAssociationList(),add.getSupplierId()); validNum(bo.getAssociationList(), add.getSupplierId());
boolean flag = baseMapper.insert(add) > 0; boolean flag = baseMapper.insert(add) > 0;
if (flag) { if (flag) {
bo.setId(add.getId()); bo.setId(add.getId());
@ -212,7 +215,7 @@ public class BusPurchaseDocServiceImpl extends ServiceImpl<BusPurchaseDocMapper,
for (BusPlanDocAssociationBo association : associationList) { for (BusPlanDocAssociationBo association : associationList) {
if(association.getDemandQuantity() == null){ if (association.getDemandQuantity() == null) {
throw new ServiceException("请填写需求数量"); throw new ServiceException("请填写需求数量");
} }
@ -249,13 +252,13 @@ public class BusPurchaseDocServiceImpl extends ServiceImpl<BusPurchaseDocMapper,
busMaterialbatchdemandplans.forEach(busMaterialbatchdemandplan -> { busMaterialbatchdemandplans.forEach(busMaterialbatchdemandplan -> {
planids.add(busMaterialbatchdemandplan.getId()); planids.add(busMaterialbatchdemandplan.getId());
}); });
if (!ids1.isEmpty()){ if (!ids1.isEmpty()) {
List<BusPlanDocAssociation> list1 = planDocAssociationService.list(Wrappers.lambdaQuery(BusPlanDocAssociation.class) List<BusPlanDocAssociation> list1 = planDocAssociationService.list(Wrappers.lambdaQuery(BusPlanDocAssociation.class)
.in(BusPlanDocAssociation::getDocId, ids1)); .in(BusPlanDocAssociation::getDocId, ids1));
//计算材料已存在的数量 //计算材料已存在的数量
BigDecimal cltotal = list1.stream() BigDecimal cltotal = list1.stream()
.filter(Objects::nonNull) .filter(Objects::nonNull)
.filter(item->planids.contains(item.getPlanId())) .filter(item -> planids.contains(item.getPlanId()))
.map(BusPlanDocAssociation::getDemandQuantity) .map(BusPlanDocAssociation::getDemandQuantity)
.reduce(BigDecimal.ZERO, BigDecimal::add); .reduce(BigDecimal.ZERO, BigDecimal::add);
if (cltotal.add(association.getDemandQuantity()).compareTo(quantity) > 0) { if (cltotal.add(association.getDemandQuantity()).compareTo(quantity) > 0) {
@ -411,7 +414,12 @@ public class BusPurchaseDocServiceImpl extends ServiceImpl<BusPurchaseDocMapper,
.eq(BusPlanDocAssociation::getDocId, purchaseDoc.getId()) .eq(BusPlanDocAssociation::getDocId, purchaseDoc.getId())
.list(); .list();
if (CollUtil.isNotEmpty(planDocAssociationList)) { if (CollUtil.isNotEmpty(planDocAssociationList)) {
Map<Long, BigDecimal> map = planDocAssociationList.stream().collect(Collectors.toMap(BusPlanDocAssociation::getPlanId, BusPlanDocAssociation::getDemandQuantity)); Map<Long, BigDecimal> map = planDocAssociationList.stream()
.peek(item -> {
if (item.getDemandQuantity() == null) {
item.setDemandQuantity(BigDecimal.ZERO);
}
}).collect(Collectors.toMap(BusPlanDocAssociation::getPlanId, BusPlanDocAssociation::getDemandQuantity));
items = materialbatchdemandplanService.listByIds(map.keySet()); items = materialbatchdemandplanService.listByIds(map.keySet());
items.forEach(item -> item.setDemandQuantity(map.get(item.getId()))); items.forEach(item -> item.setDemandQuantity(map.get(item.getId())));
} }
@ -575,6 +583,25 @@ public class BusPurchaseDocServiceImpl extends ServiceImpl<BusPurchaseDocMapper,
return updateById(busPurchaseDoc); return updateById(busPurchaseDoc);
} }
@Override
public List<BusPurchaseDocVo> purchaseNote(Long projectId) {
List<BusPurchaseDocVo> busPurchaseDocVos = baseMapper.selectVoList(new LambdaQueryWrapper<BusPurchaseDoc>()
.eq(BusPurchaseDoc::getProjectId, projectId)
.eq(BusPurchaseDoc::getDocType, "1")
.eq(BusPurchaseDoc::getStatus, BusinessStatusEnum.FINISH.getStatus())
.orderByDesc(BusPurchaseDoc::getCreateTime));
if (busPurchaseDocVos == null){
return List.of();
}
busPurchaseDocVos.forEach(v -> {
BusMrpBase byId = mrpBaseService.getById(v.getMrpBaseId());
if (byId != null) {
v.setPlanCode(byId.getPlanCode());
}
});
return busPurchaseDocVos;
}
/** /**
* 根据实体获取替换数据 * 根据实体获取替换数据
* *

View File

@ -1,6 +1,7 @@
package org.dromara.cailiaoshebei.service.impl; package org.dromara.cailiaoshebei.service.impl;
import cn.hutool.core.bean.BeanUtil; import cn.hutool.core.bean.BeanUtil;
import cn.hutool.core.collection.CollUtil;
import com.alibaba.excel.EasyExcel; import com.alibaba.excel.EasyExcel;
import com.alibaba.excel.ExcelReader; import com.alibaba.excel.ExcelReader;
import com.alibaba.excel.read.metadata.ReadSheet; import com.alibaba.excel.read.metadata.ReadSheet;
@ -104,7 +105,7 @@ public class BusTotalsupplyplanServiceImpl extends ServiceImpl<BusTotalsupplypla
private LambdaQueryWrapper<BusTotalsupplyplan> buildQueryWrapper(BusTotalsupplyplanBo bo) { private LambdaQueryWrapper<BusTotalsupplyplan> buildQueryWrapper(BusTotalsupplyplanBo bo) {
Map<String, Object> params = bo.getParams(); Map<String, Object> params = bo.getParams();
LambdaQueryWrapper<BusTotalsupplyplan> lqw = Wrappers.lambdaQuery(); LambdaQueryWrapper<BusTotalsupplyplan> lqw = Wrappers.lambdaQuery();
lqw.eq(bo.getProjectId() != null ,BusTotalsupplyplan::getProjectId,bo.getProjectId()); lqw.eq(bo.getProjectId() != null, BusTotalsupplyplan::getProjectId, bo.getProjectId());
lqw.eq(StringUtils.isNotBlank(bo.getTexture()), BusTotalsupplyplan::getTexture, bo.getTexture()); lqw.eq(StringUtils.isNotBlank(bo.getTexture()), BusTotalsupplyplan::getTexture, bo.getTexture());
lqw.eq(StringUtils.isNotBlank(bo.getBrand()), BusTotalsupplyplan::getBrand, bo.getBrand()); lqw.eq(StringUtils.isNotBlank(bo.getBrand()), BusTotalsupplyplan::getBrand, bo.getBrand());
lqw.eq(StringUtils.isNotBlank(bo.getQualityStandard()), BusTotalsupplyplan::getQualityStandard, bo.getQualityStandard()); lqw.eq(StringUtils.isNotBlank(bo.getQualityStandard()), BusTotalsupplyplan::getQualityStandard, bo.getQualityStandard());
@ -239,7 +240,14 @@ public class BusTotalsupplyplanServiceImpl extends ServiceImpl<BusTotalsupplypla
} }
// 关闭读取器 // 关闭读取器
excelReader.finish(); excelReader.finish();
if (allData.isEmpty()) { if (CollUtil.isEmpty(allData)) {
throw new ServiceException("未读取到有效数据", HttpStatus.BAD_REQUEST);
}
// 过滤 id 为空的数据
allData = allData.stream()
.filter(Objects::nonNull)
.filter(data -> data.getId() != null).toList();
if (CollUtil.isEmpty(allData)) {
throw new ServiceException("未读取到有效数据", HttpStatus.BAD_REQUEST); throw new ServiceException("未读取到有效数据", HttpStatus.BAD_REQUEST);
} }
// 处理导入的数据 // 处理导入的数据
@ -248,7 +256,7 @@ public class BusTotalsupplyplanServiceImpl extends ServiceImpl<BusTotalsupplypla
return this.updateBatchById(list); return this.updateBatchById(list);
} catch (Exception e) { } catch (Exception e) {
log.error("物资供货总计划导入Excel文件失败", e); log.error("物资供货总计划导入Excel文件失败", e);
throw new ServiceException("导入失败: " + e.getMessage(), HttpStatus.ERROR); throw new ServiceException("导入失败, " + e.getMessage(), HttpStatus.ERROR);
} }
} }

View File

@ -1,5 +1,6 @@
package org.dromara.common.utils; package org.dromara.common.utils;
import cn.hutool.core.collection.CollectionUtil;
import jakarta.annotation.Resource; import jakarta.annotation.Resource;
import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.Slf4j;
import org.dromara.common.core.utils.MessageUtils; import org.dromara.common.core.utils.MessageUtils;
@ -9,6 +10,8 @@ import org.dromara.contractor.domain.SubConstructionUser;
import org.dromara.mobileAttendanceMachine.DeviceMessageSender; import org.dromara.mobileAttendanceMachine.DeviceMessageSender;
import org.dromara.mobileAttendanceMachine.KqjEntity; import org.dromara.mobileAttendanceMachine.KqjEntity;
import org.dromara.project.domain.BusAttendanceMachine; import org.dromara.project.domain.BusAttendanceMachine;
import org.dromara.project.domain.BusAttendanceMachineRepeat;
import org.dromara.project.service.IBusAttendanceMachineRepeatService;
import org.dromara.project.service.IBusAttendanceMachineService; import org.dromara.project.service.IBusAttendanceMachineService;
import org.dromara.sms4j.api.SmsBlend; import org.dromara.sms4j.api.SmsBlend;
import org.dromara.sms4j.api.entity.SmsResponse; import org.dromara.sms4j.api.entity.SmsResponse;
@ -19,6 +22,7 @@ import org.springframework.context.annotation.Lazy;
import org.springframework.scheduling.annotation.Async; import org.springframework.scheduling.annotation.Async;
import org.springframework.stereotype.Component; import org.springframework.stereotype.Component;
import java.util.ArrayList;
import java.util.LinkedHashMap; import java.util.LinkedHashMap;
import java.util.List; import java.util.List;
@ -36,6 +40,9 @@ public class AsyncUtil {
@Lazy @Lazy
private IBusAttendanceMachineService attendanceMachineService; private IBusAttendanceMachineService attendanceMachineService;
@Resource
private IBusAttendanceMachineRepeatService busAttendanceMachineRepeatService;
//发送短信 //发送短信
@Async @Async
public void sendSms(List<String> mobileList, String config) { public void sendSms(List<String> mobileList, String config) {
@ -63,22 +70,107 @@ public class AsyncUtil {
public void sendPersonnel(Long teamId, SubConstructionUser constructionUser) { public void sendPersonnel(Long teamId, SubConstructionUser constructionUser) {
SysOssVo byId = ossService.getById(Long.valueOf(constructionUser.getFacePic())); SysOssVo byId = ossService.getById(Long.valueOf(constructionUser.getFacePic()));
List<BusAttendanceMachine> list = attendanceMachineService.lambdaQuery().apply("FIND_IN_SET({0}, teams)", teamId).list(); List<BusAttendanceMachine> list = attendanceMachineService.lambdaQuery().apply("FIND_IN_SET({0}, teams)", teamId).list();
ArrayList<BusAttendanceMachineRepeat> repeats = new ArrayList<>();
for (BusAttendanceMachine machine : list) { for (BusAttendanceMachine machine : list) {
deviceMessageSender.sendPersonnelInformation(machine.getSn(), constructionUser.getSysUserId().toString(), constructionUser.getUserName(), byId.getUrl()); Boolean b = deviceMessageSender.sendPersonnelInformation(machine.getSn(),
constructionUser.getSysUserId().toString(), constructionUser.getUserName(), byId.getUrl());
if (!b) {
//记录下来重连时下发
BusAttendanceMachineRepeat repeat = new BusAttendanceMachineRepeat();
repeat.setSn(machine.getSn());
repeat.setUserId(constructionUser.getSysUserId().toString());
repeat.setUserName(constructionUser.getUserName());
repeat.setUrl(byId.getUrl());
repeat.setType("1");
repeats.add(repeat);
}
}
if (CollectionUtil.isNotEmpty(repeats)) {
busAttendanceMachineRepeatService.saveBatch(repeats);
} }
} }
//删除考勤人员 //删除考勤人员
@Async @Async
public void deletePersonnel(SubConstructionUser constructionUser) { public void deletePersonnel(SubConstructionUser constructionUser) {
ArrayList<BusAttendanceMachineRepeat> repeats = new ArrayList<>();
List<BusAttendanceMachine> list = attendanceMachineService.lambdaQuery().apply("FIND_IN_SET({0}, teams)", constructionUser.getTeamId()).list(); List<BusAttendanceMachine> list = attendanceMachineService.lambdaQuery().apply("FIND_IN_SET({0}, teams)", constructionUser.getTeamId()).list();
for (BusAttendanceMachine machine : list) { for (BusAttendanceMachine machine : list) {
try { try {
deviceMessageSender.deleteUser(machine.getSn(), constructionUser.getSysUserId().toString()); KqjEntity.CommonResponse commonResponse = deviceMessageSender.deleteUser(machine.getSn(), constructionUser.getSysUserId().toString());
int code = commonResponse.getData().getCode();
if (code != 0) {
//记录下来重连时下发
BusAttendanceMachineRepeat repeat = new BusAttendanceMachineRepeat();
repeat.setSn(machine.getSn());
repeat.setUserId(constructionUser.getSysUserId().toString());
repeat.setUserName(constructionUser.getUserName());
repeat.setUrl(null);
repeat.setType("2");
repeats.add(repeat);
}
} catch (Exception e) {
log.error("删除考勤人员异常", e);
BusAttendanceMachineRepeat repeat = new BusAttendanceMachineRepeat();
repeat.setSn(machine.getSn());
repeat.setUserId(constructionUser.getSysUserId().toString());
repeat.setUserName(constructionUser.getUserName());
repeat.setUrl(null);
repeat.setType("2");
repeats.add(repeat);
}
}
if (CollectionUtil.isNotEmpty(repeats)) {
busAttendanceMachineRepeatService.saveBatch(repeats);
}
}
//重新下发人员
@Async
public void repeatSend(String sn) {
List<BusAttendanceMachineRepeat> list = busAttendanceMachineRepeatService.lambdaQuery()
.eq(BusAttendanceMachineRepeat::getSn, sn)
.eq(BusAttendanceMachineRepeat::getType, "1")
.list();
List<Long> repeatIds = new ArrayList<>();
for (BusAttendanceMachineRepeat repeat : list) {
Boolean b = deviceMessageSender.sendPersonnelInformation(repeat.getSn(), repeat.getUserId(), repeat.getUserName(), repeat.getUrl());
if (b) {
//成功删除记录
repeatIds.add(repeat.getId());
}
}
if (CollectionUtil.isNotEmpty(repeatIds)) {
busAttendanceMachineRepeatService.removeByIds(repeatIds);
}
}
//重新删除人员
@Async
public void repeatDelete(String sn) {
List<BusAttendanceMachineRepeat> list = busAttendanceMachineRepeatService.lambdaQuery()
.eq(BusAttendanceMachineRepeat::getSn, sn)
.eq(BusAttendanceMachineRepeat::getType, "2")
.list();
List<Long> repeatIds = new ArrayList<>();
for (BusAttendanceMachineRepeat repeat : list) {
try {
KqjEntity.CommonResponse commonResponse = deviceMessageSender.deleteUser(repeat.getSn(), repeat.getUserId());
int code = commonResponse.getData().getCode();
if (code == 0) {
//成功删除记录
repeatIds.add(repeat.getId());
}
} catch (Exception e) { } catch (Exception e) {
log.error("删除考勤人员异常", e); log.error("删除考勤人员异常", e);
} }
} }
if (CollectionUtil.isNotEmpty(repeatIds)) {
busAttendanceMachineRepeatService.removeByIds(repeatIds);
}
} }
} }

View File

@ -25,4 +25,26 @@ public class BigDecimalUtil {
.divide(divisor, 2, RoundingMode.HALF_UP); .divide(divisor, 2, RoundingMode.HALF_UP);
} }
/**
* 计算环比 = (本次 - 上次) / 上次 × 100% 的绝对值
*
* @param thisNum 本次数量
* @param lastNum 上次数量
* @return 环比 = (本次 - 上次) / 上次 × 100% 的绝对值
*/
public static BigDecimal toLoopPercentage(BigDecimal thisNum, BigDecimal lastNum) {
if (thisNum == null || lastNum == null) {
return BigDecimal.valueOf(0.00);
}
if (lastNum.compareTo(BigDecimal.ZERO) == 0 && thisNum.compareTo(BigDecimal.ZERO) > 0) {
return BigDecimal.valueOf(100.00);
} else if (lastNum.compareTo(BigDecimal.ZERO) == 0) {
return BigDecimal.valueOf(0.00);
}
return thisNum.subtract(lastNum)
.multiply(new BigDecimal("100"))
.divide(lastNum, 2, RoundingMode.HALF_UP)
.abs();
}
} }

View File

@ -8,6 +8,7 @@ import org.dromara.common.constant.GeoJsonConstant;
import org.dromara.common.core.constant.HttpStatus; 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.domain.GeoPoint; import org.dromara.common.domain.GeoPoint;
import org.dromara.facility.domain.FacMatrix;
import org.dromara.facility.domain.FacPhotovoltaicPanel; import org.dromara.facility.domain.FacPhotovoltaicPanel;
import org.dromara.facility.domain.dto.geojson.FacFeatureByPlane; import org.dromara.facility.domain.dto.geojson.FacFeatureByPlane;
import org.dromara.facility.domain.dto.geojson.FacFeatureByPoint; import org.dromara.facility.domain.dto.geojson.FacFeatureByPoint;
@ -338,6 +339,29 @@ public class JSTUtil {
return null; return null;
} }
/**
* 匹配最近方阵,获取该方阵的信息
*
* @param pointEntity 点位
* @param matrices 方阵列表
* @return 最近方阵的信息
*/
public static FacMatrix findContainingMatrix(
RecognizeConvertCoordinateResult pointEntity,
List<FacMatrix> matrices
) {
double lng = Double.parseDouble(pointEntity.getLng());
double lat = Double.parseDouble(pointEntity.getLat());
Point point = geometryFactory.createPoint(new Coordinate(lng, lat));
for (FacMatrix matrix : matrices) {
Polygon polygon = parsePolygon(matrix.getPositions());
if (polygon.covers(point)) { // covers 包含边界}
return matrix;
}
}
return null;
}
/** /**
* 将 FacPhotovoltaicPanel.positions 转成 Polygon * 将 FacPhotovoltaicPanel.positions 转成 Polygon
*/ */
@ -376,7 +400,7 @@ public class JSTUtil {
List<String> list = new ArrayList<>(); List<String> list = new ArrayList<>();
list.add(s); list.add(s);
List<GeoPoint> matchingRange = findMatchingRange("30.247348", "105.729797", list); List<GeoPoint> matchingRange = findMatchingRange("30.247348", "105.729797", list);
System.out.println(matchingRange==null); System.out.println(matchingRange == null);
} }

View File

@ -79,6 +79,38 @@ public class JtsPointMatcher {
return matched; return matched;
} }
/**
* 计算多边形的中心点
*
* @param points 多边形的顶点坐标
* @return 中心点的坐标
*/
public static List<Double> polygonCentroid(List<List<Double>> points) {
double area = 0;
double cx = 0;
double cy = 0;
int size = points.size();
for (int i = 0; i < size - 1; i++) {
double x0 = points.get(i).get(0);
double y0 = points.get(i).get(1);
double x1 = points.get(i + 1).get(0);
double y1 = points.get(i + 1).get(1);
double cross = x0 * y1 - x1 * y0;
area += cross;
cx += (x0 + x1) * cross;
cy += (y0 + y1) * cross;
}
area *= 0.5;
cx /= (6 * area);
cy /= (6 * area);
return List.of(cx, cy);
}
public static void main(String[] args) { public static void main(String[] args) {
// A列表待匹配点 // A列表待匹配点
List<Coordinate> listA = List.of( List<Coordinate> listA = List.of(

View File

@ -0,0 +1,106 @@
package org.dromara.complaintBox.app.controller;
import cn.dev33.satoken.annotation.SaCheckPermission;
import jakarta.validation.constraints.NotNull;
import lombok.RequiredArgsConstructor;
import org.dromara.common.core.domain.R;
import org.dromara.common.core.domain.model.LoginUser;
import org.dromara.common.core.validate.AddGroup;
import org.dromara.common.core.validate.EditGroup;
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.mybatis.core.page.PageQuery;
import org.dromara.common.mybatis.core.page.TableDataInfo;
import org.dromara.common.satoken.utils.LoginHelper;
import org.dromara.common.web.core.BaseController;
import org.dromara.complaintBox.app.domain.vo.AppDetailsOfTheOpinionVo;
import org.dromara.complaintBox.domain.bo.BusComplaintBoxBo;
import org.dromara.complaintBox.domain.bo.BusComplaintBoxMessageLoggingBo;
import org.dromara.complaintBox.domain.vo.BusComplaintBoxVo;
import org.dromara.complaintBox.service.IBusComplaintBoxMessageLoggingService;
import org.dromara.complaintBox.service.IBusComplaintBoxService;
import org.springframework.context.annotation.Lazy;
import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.*;
/**
* 意见箱
*
* @author Lion Li
* @date 2025-11-29
*/
@Validated
@RequiredArgsConstructor
@RestController
@RequestMapping("/app/complaintBox/complaintBox")
public class AppBusComplaintBoxController extends BaseController {
@Lazy
private final IBusComplaintBoxService busComplaintBoxService;
@Lazy
private final IBusComplaintBoxMessageLoggingService busComplaintBoxMessageLoggingService;
/**
* 查询意见箱列表
*/
// @SaCheckPermission("appComplaintBox:complaintBox:list")
@GetMapping("/list")
public TableDataInfo<BusComplaintBoxVo> list(BusComplaintBoxBo bo, PageQuery pageQuery) {
LoginUser loginUser = LoginHelper.getLoginUser();
if (loginUser != null) {
bo.setUserId(loginUser.getUserId());
}
return busComplaintBoxService.appQueryPageList(bo, pageQuery);
}
/**
* 获取意见箱详细信息
*
* @param id 主键
*/
// @SaCheckPermission("appComplaintBox:complaintBox:query")
@GetMapping("/{id}")
public R<AppDetailsOfTheOpinionVo> getInfo(@NotNull(message = "主键不能为空")
@PathVariable Long id) {
return R.ok(busComplaintBoxService.appQueryById(id));
}
/**
* 新增意见箱
*/
// @SaCheckPermission("appComplaintBox:complaintBox:add")
@Log(title = "意见箱", businessType = BusinessType.INSERT)
@RepeatSubmit()
@PostMapping()
public R<Void> add(@Validated(AddGroup.class) @RequestBody BusComplaintBoxBo bo) {
return toAjax(busComplaintBoxService.insertByBo(bo));
}
/**
* 新增意见回复
*/
// @SaCheckPermission("appComplaintBox:complaintBox:add")
@Log(title = "意见箱", businessType = BusinessType.INSERT)
@RepeatSubmit()
@PostMapping("/postAReply")
public R<Void> postAReply(@Validated(AddGroup.class) @RequestBody BusComplaintBoxMessageLoggingBo bo) {
return toAjax(busComplaintBoxMessageLoggingService.insertAppByBo(bo));
}
/**
* 修改意见阅读状态
*/
// @SaCheckPermission("appComplaintBox:complaintBox:edit")
@Log(title = "意见箱", businessType = BusinessType.UPDATE)
@RepeatSubmit()
@PutMapping("/editCheckStatus")
public R<Void> editCheckStatus(@Validated(EditGroup.class) @RequestBody BusComplaintBoxBo bo) {
return toAjax(busComplaintBoxService.editCheckStatus(bo));
}
}

View File

@ -0,0 +1,16 @@
package org.dromara.complaintBox.app.domain.vo;
import lombok.Data;
import org.dromara.complaintBox.domain.vo.BusComplaintBoxMessageLoggingVo;
import org.dromara.complaintBox.domain.vo.BusComplaintBoxVo;
import java.io.Serializable;
import java.util.List;
@Data
public class AppDetailsOfTheOpinionVo implements Serializable {
private BusComplaintBoxVo busComplaintBoxVo;
private List<BusComplaintBoxMessageLoggingVo> messageLoggingVos;
}

View File

@ -0,0 +1,124 @@
package org.dromara.complaintBox.controller;
import lombok.RequiredArgsConstructor;
import jakarta.validation.constraints.*;
import cn.dev33.satoken.annotation.SaCheckPermission;
import org.dromara.complaintBox.domain.bo.BusComplaintBoxDisposeLoggingBo;
import org.dromara.complaintBox.domain.bo.BusComplaintBoxMessageLoggingBo;
import org.dromara.complaintBox.domain.vo.BusComplaintBoxDisposeLoggingVo;
import org.dromara.complaintBox.domain.vo.ComplaintBoxCountVo;
import org.dromara.complaintBox.domain.vo.DetailsOfTheOpinionVo;
import org.dromara.complaintBox.service.IBusComplaintBoxDisposeLoggingService;
import org.dromara.complaintBox.service.IBusComplaintBoxMessageLoggingService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Lazy;
import org.springframework.web.bind.annotation.*;
import org.springframework.validation.annotation.Validated;
import org.dromara.common.idempotent.annotation.RepeatSubmit;
import org.dromara.common.log.annotation.Log;
import org.dromara.common.web.core.BaseController;
import org.dromara.common.mybatis.core.page.PageQuery;
import org.dromara.common.core.domain.R;
import org.dromara.common.core.validate.AddGroup;
import org.dromara.common.core.validate.EditGroup;
import org.dromara.common.log.enums.BusinessType;
import org.dromara.complaintBox.domain.vo.BusComplaintBoxVo;
import org.dromara.complaintBox.domain.bo.BusComplaintBoxBo;
import org.dromara.complaintBox.service.IBusComplaintBoxService;
import org.dromara.common.mybatis.core.page.TableDataInfo;
import java.util.List;
/**
* 意见箱
*
* @author Lion Li
* @date 2025-11-29
*/
@Validated
@RequiredArgsConstructor
@RestController
@RequestMapping("/complaintBox/complaintBox")
public class BusComplaintBoxController extends BaseController {
private final IBusComplaintBoxService busComplaintBoxService;
@Lazy
@Autowired
private IBusComplaintBoxMessageLoggingService busComplaintBoxMessageLoggingService;
@Lazy
@Autowired
private IBusComplaintBoxDisposeLoggingService disposeLoggingService;
/**
* 查询意见箱列表
*/
@SaCheckPermission("complaintBox:complaintBox:list")
@GetMapping("/list")
public TableDataInfo<BusComplaintBoxVo> list(BusComplaintBoxBo bo, PageQuery pageQuery) {
return busComplaintBoxService.queryPageList(bo, pageQuery);
}
/**
* 查询意见处理记录列表
*/
@SaCheckPermission("complaintBox:complaintBox:list")
@GetMapping("/getDisposeLogList")
public TableDataInfo<BusComplaintBoxDisposeLoggingVo> getDisposeLogList(BusComplaintBoxDisposeLoggingBo bo, PageQuery pageQuery) {
return disposeLoggingService.queryPageList(bo, pageQuery);
}
/**
* web获取各个处理状态数量
*/
@SaCheckPermission("complaintBox:complaintBox:list")
@GetMapping("/getCount")
public R<List<ComplaintBoxCountVo>> getCount(BusComplaintBoxBo bo) {
return R.ok(busComplaintBoxService.getCount(bo));
}
/**
* 获取意见箱详细信息
*
* @param id 主键
*/
// @SaCheckPermission("complaintBox:complaintBox:query")
@GetMapping("/{id}")
public R<DetailsOfTheOpinionVo> getInfo(@NotNull(message = "主键不能为空")
@PathVariable Long id) {
return R.ok(busComplaintBoxService.getInfo(id));
}
/**
* 新增意见回复
*/
@SaCheckPermission("complaintBox:complaintBox:add")
@Log(title = "意见箱", businessType = BusinessType.INSERT)
@RepeatSubmit()
@PostMapping("/postAReply")
public R<Void> postAReply(@Validated(AddGroup.class) @RequestBody BusComplaintBoxMessageLoggingBo bo) {
return toAjax(busComplaintBoxMessageLoggingService.insertWebByBo(bo));
}
/**
* 修改意见阅读状态
*/
@SaCheckPermission("complaintBox:complaintBox:edit")
@Log(title = "意见箱", businessType = BusinessType.UPDATE)
@RepeatSubmit()
@PutMapping("/editCheckStatus")
public R<Void> editCheckStatus(@Validated(EditGroup.class) @RequestBody BusComplaintBoxBo bo) {
return toAjax(busComplaintBoxService.editCheckStatus(bo));
}
/**
* 修改意见阅读状态
*/
@SaCheckPermission("complaintBox:complaintBox:edit")
@Log(title = "意见箱", businessType = BusinessType.UPDATE)
@RepeatSubmit()
@PutMapping("/editStatus")
public R<Void> editStatus(@Validated(EditGroup.class) @RequestBody BusComplaintBoxBo bo) {
return toAjax(busComplaintBoxService.editStatus(bo));
}
}

View File

@ -0,0 +1,91 @@
package org.dromara.complaintBox.domain;
import org.dromara.common.mybatis.core.domain.BaseEntity;
import com.baomidou.mybatisplus.annotation.*;
import lombok.Data;
import lombok.EqualsAndHashCode;
import java.io.Serial;
/**
* 意见箱对象 bus_complaint_box
*
* @author Lion Li
* @date 2025-11-29
*/
@Data
@EqualsAndHashCode(callSuper = true)
@TableName("bus_complaint_box")
public class BusComplaintBox extends BaseEntity {
@Serial
private static final long serialVersionUID = 1L;
/**
* 主键ID
*/
@TableId(value = "id")
private Long id;
/**
* 公司id当前登录人的顶层下一级部门id
*/
private Long companyId;
/**
* 项目id
*/
private Long projectId;
/**
* 用户id
*/
private Long userId;
/**
* 用户名
*/
private String userName;
/**
* 头像地址
*/
private Long avatar;
/**
* 标题
*/
private String title;
/**
* 意见类型1、功能建议2、Bug反馈3、体验问题4其他意见
*/
private String opinionType;
/**
* 详细描述
*/
private String detail;
/**
* 上传图片idid之间使用','分割)
*/
private String fileId;
/**
* 是否匿名提交0、否1、是
*/
private String isCryptonym;
/**
* 处理状态0、待处理5、处理中9、已解决10、退回14、不予解决()
*/
private String status;
/**
* 当前处理人id
*/
private Long currentDisposeUserId;
}

View File

@ -0,0 +1,61 @@
package org.dromara.complaintBox.domain;
import org.dromara.common.mybatis.core.domain.BaseEntity;
import com.baomidou.mybatisplus.annotation.*;
import lombok.Data;
import lombok.EqualsAndHashCode;
import java.io.Serial;
/**
* 意见箱-意见处理记录对象 bus_complaint_box_dispose_logging
*
* @author Lion Li
* @date 2025-11-29
*/
@Data
@EqualsAndHashCode(callSuper = true)
@TableName("bus_complaint_box_dispose_logging")
public class BusComplaintBoxDisposeLogging extends BaseEntity {
@Serial
private static final long serialVersionUID = 1L;
/**
* 主键ID
*/
@TableId(value = "id")
private Long id;
/**
* 意见id
*/
private Long complaintId;
/**
* 用户id
*/
private Long userId;
/**
* 用户名
*/
private String userName;
/**
* 头像地址
*/
private Long avatar;
/**
* 是否退回0、否1、是
*/
private String isRefund;
/**
* 退回原因
*/
private String cause;
}

Some files were not shown because too many files have changed in this diff Show More