Compare commits
	
		
			40 Commits
		
	
	
		
			1276dc4adb
			...
			wangjunpin
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | ce76b2f98d | ||
| 8fbca1a898 | |||
| d548215123 | |||
| 953d17dc8c | |||
|   | b71a21ea5c | ||
|   | 0a20b5e34e | ||
| 388425084e | |||
| 51ee8d1b43 | |||
|   | d29d56e712 | ||
|   | 9084ddaa98 | ||
|   | be6d5c1ccc | ||
| 1bba9e598a | |||
| d58a5e8ab3 | |||
| e6ffb7101f | |||
|   | 48b2188cf9 | ||
|   | 8bc5d45976 | ||
| 04f6e7e960 | |||
| 8fb58bdab8 | |||
|   | fdfe5334a1 | ||
|   | 66b99009e6 | ||
|   | 2c7456531d | ||
|   | cede47f342 | ||
|   | 8ad2d6ebbb | ||
|   | dd0090a2a8 | ||
|   | e4c5f36f2e | ||
|   | f515bb8fbb | ||
|   | bd3874b3c7 | ||
|   | 8dc6faff0b | ||
|   | d23a594a4b | ||
|   | c8014404f1 | ||
|   | 38785887b1 | ||
|   | 08f539dc72 | ||
|   | 6987963840 | ||
|   | 2a75448a30 | ||
|   | 72176f67cc | ||
|   | 155df0c917 | ||
|   | 00208c5f79 | ||
|   | db9d790435 | ||
|   | 99773d092e | ||
|   | 0dbed951d2 | 
| @@ -4,7 +4,7 @@ | |||||||
|  |  | ||||||
|   |   | ||||||
|  |  | ||||||
| 天天开源致⼒于打造中国应⽤管理软件开源⽣态,⾯向医疗、企业、教育三⼤⾏业信息化需求,提供优质的开源软件产品与解决⽅案。平台现已发布OpenHIS、OpenCOM、OpenEDU系列开源产品,并持续招募⽣态合作伙伴,期待共同构建开源创新的⾏业协作模式,加速⾏业的数字化进程。 | 天天开源致⼒于打造中国应⽤管理 软件开源⽣态,⾯向医疗、企业、教育三⼤⾏业信息化需求,提供优质的开源软件产品与解决⽅案。平台现已发布OpenHIS、OpenCOM、OpenEDU系列开源产品,并持续招募⽣态合作伙伴,期待共同构建开源创新的⾏业协作模式,加速⾏业的数字化进程。 | ||||||
|  |  | ||||||
| 天天开源的前⾝是新致开源,最早于2022年6⽉发布开源医疗软件平台OpenHIS.org.cn,于2023年6⽉发布开源企业软件平台OpenCOM.com.cn。2025年7⽉,新致开源品牌更新为天天开源,我们始终秉持开源、专业、协作的理念,致⼒于为医疗、教育、中⼩企业等⾏业提供优质的开源解决⽅案。 | 天天开源的前⾝是新致开源,最早于2022年6⽉发布开源医疗软件平台OpenHIS.org.cn,于2023年6⽉发布开源企业软件平台OpenCOM.com.cn。2025年7⽉,新致开源品牌更新为天天开源,我们始终秉持开源、专业、协作的理念,致⼒于为医疗、教育、中⼩企业等⾏业提供优质的开源解决⽅案。 | ||||||
|  |  | ||||||
|   | |||||||
| @@ -36,13 +36,11 @@ | |||||||
|         <dependency> |         <dependency> | ||||||
|             <groupId>io.swagger</groupId> |             <groupId>io.swagger</groupId> | ||||||
|             <artifactId>swagger-models</artifactId> |             <artifactId>swagger-models</artifactId> | ||||||
|             <version>1.6.2</version> |  | ||||||
|         </dependency> |         </dependency> | ||||||
|  |  | ||||||
|         <!-- Mysql驱动包 --> |  | ||||||
|         <dependency> |         <dependency> | ||||||
|             <groupId>mysql</groupId> |             <groupId>com.mysql</groupId> | ||||||
|             <artifactId>mysql-connector-java</artifactId> |             <artifactId>mysql-connector-j</artifactId> | ||||||
|         </dependency> |         </dependency> | ||||||
|  |  | ||||||
|         <!-- 核心模块--> |         <!-- 核心模块--> | ||||||
|   | |||||||
| @@ -77,6 +77,10 @@ | |||||||
|             <groupId>com.alibaba.fastjson2</groupId> |             <groupId>com.alibaba.fastjson2</groupId> | ||||||
|             <artifactId>fastjson2</artifactId> |             <artifactId>fastjson2</artifactId> | ||||||
|         </dependency> |         </dependency> | ||||||
|  |         <dependency> | ||||||
|  |             <groupId>com.alibaba</groupId> | ||||||
|  |             <artifactId>fastjson</artifactId> | ||||||
|  |         </dependency> | ||||||
|  |  | ||||||
|         <!-- io常用工具类 --> |         <!-- io常用工具类 --> | ||||||
|         <dependency> |         <dependency> | ||||||
| @@ -136,7 +140,6 @@ | |||||||
|         <dependency> |         <dependency> | ||||||
|             <groupId>com.belerweb</groupId> |             <groupId>com.belerweb</groupId> | ||||||
|             <artifactId>pinyin4j</artifactId> |             <artifactId>pinyin4j</artifactId> | ||||||
|             <version>2.5.1</version> |  | ||||||
|         </dependency> |         </dependency> | ||||||
|  |  | ||||||
|     </dependencies> |     </dependencies> | ||||||
|   | |||||||
| @@ -5,10 +5,7 @@ import java.util.concurrent.TimeUnit; | |||||||
|  |  | ||||||
| import com.core.common.exception.UtilException; | import com.core.common.exception.UtilException; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; | import org.springframework.beans.factory.annotation.Autowired; | ||||||
| import org.springframework.data.redis.core.BoundSetOperations; | import org.springframework.data.redis.core.*; | ||||||
| import org.springframework.data.redis.core.HashOperations; |  | ||||||
| import org.springframework.data.redis.core.RedisTemplate; |  | ||||||
| import org.springframework.data.redis.core.ValueOperations; |  | ||||||
| import org.springframework.stereotype.Component; | import org.springframework.stereotype.Component; | ||||||
|  |  | ||||||
| /** | /** | ||||||
| @@ -256,4 +253,28 @@ public class RedisCache { | |||||||
|             return this.redisTemplate.opsForValue().increment(key, delta); |             return this.redisTemplate.opsForValue().increment(key, delta); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |     /** | ||||||
|  |      * 获取所有String类型的键值对(开发环境下使用) | ||||||
|  |      */ | ||||||
|  |     public Map<String, Object> getAllDictDataWithKeys(String pattern) { | ||||||
|  |         pattern+="*"; | ||||||
|  |         Map<String, Object> allDict = new HashMap<>(); | ||||||
|  |         // 1. 获取所有键("*"匹配所有键) | ||||||
|  |         Set<String> allKeys = redisTemplate.keys(pattern); | ||||||
|  |         if (allKeys == null || allKeys.isEmpty()) { | ||||||
|  |             return allDict; | ||||||
|  |         } | ||||||
|  |         // 2. 批量获取值(使用multiGet高效批量查询) | ||||||
|  |         ValueOperations<String, Object> valueOps = redisTemplate.opsForValue(); | ||||||
|  |         List<Object> values = valueOps.multiGet(allKeys); | ||||||
|  |         // 3. 组装键值对 | ||||||
|  |         Iterator<String> keyIter = allKeys.iterator(); | ||||||
|  |         for (Object value : values) { | ||||||
|  |             if (keyIter.hasNext()) { | ||||||
|  |                 allDict.put(keyIter.next(), value); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         return allDict; | ||||||
|  |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -197,7 +197,39 @@ public enum TenantOptionDict { | |||||||
|     /** |     /** | ||||||
|      * PACSAppSecret |      * PACSAppSecret | ||||||
|      */ |      */ | ||||||
|     FORWARD_SWITCH("forwardSwitch", "电子发票中转服务开关", 47); |     FORWARD_SWITCH("forwardSwitch", "电子发票中转服务开关", 47), | ||||||
|  |     /** | ||||||
|  |      * 食源性开关 | ||||||
|  |      */ | ||||||
|  |     FOODBORNE_SWITCH("foodborneSwitch", "食源性开关", 48), | ||||||
|  |     /** | ||||||
|  |      * 食源性接口地址 ../goto(格式如下:http://172.16.7.247/infections/goto 需指定到/goto) | ||||||
|  |      */ | ||||||
|  |     FOODBORNE_API_URL("foodborneApiUrl", "食源性接口地址 ../goto", 49), | ||||||
|  |     /** | ||||||
|  |      * 食源性医疗机构 | ||||||
|  |      */ | ||||||
|  |     FOODBORNE_HOSPITAL("foodborneHospital", "食源性医疗机构", 50), | ||||||
|  |     /** | ||||||
|  |      * 食源性登录账号 | ||||||
|  |      */ | ||||||
|  |     FOODBORNE_USER_NAME("foodborneUserName", "食源性登录账号", 51), | ||||||
|  |     /** | ||||||
|  |      * BPC商户号 | ||||||
|  |      */ | ||||||
|  |     BPC_MID("bpcMid", "BPC商户号", 52), | ||||||
|  |     /** | ||||||
|  |      * BPC终端号 | ||||||
|  |      */ | ||||||
|  |     BPC_TID("bpcTid", "BPC终端号", 53), | ||||||
|  |     /** | ||||||
|  |      * BPCMD5签名密钥 | ||||||
|  |      */ | ||||||
|  |     BPC_MD5_SHARED_SECRET("bpcMd5SharedSecret", "BPCMD5签名密钥", 54), | ||||||
|  |     /** | ||||||
|  |      * BPC请求URL | ||||||
|  |      */ | ||||||
|  |     BPC_REQUEST_URL("bpcRequestUrl", "BPC请求URL", 55); | ||||||
|  |  | ||||||
|     private final String code; |     private final String code; | ||||||
|     private final String name; |     private final String name; | ||||||
|   | |||||||
| @@ -80,7 +80,6 @@ | |||||||
|         <dependency> |         <dependency> | ||||||
|             <groupId>com.googlecode.aviator</groupId> |             <groupId>com.googlecode.aviator</groupId> | ||||||
|             <artifactId>aviator</artifactId> |             <artifactId>aviator</artifactId> | ||||||
|             <version>5.3.3</version> |  | ||||||
|         </dependency> |         </dependency> | ||||||
|  |  | ||||||
|     </dependencies> |     </dependencies> | ||||||
|   | |||||||
| @@ -1,5 +1,9 @@ | |||||||
| package com.core.framework.config; | package com.core.framework.config; | ||||||
|  |  | ||||||
|  | import com.core.framework.config.properties.PermitAllUrlProperties; | ||||||
|  | import com.core.framework.security.filter.JwtAuthenticationTokenFilter; | ||||||
|  | import com.core.framework.security.handle.AuthenticationEntryPointImpl; | ||||||
|  | import com.core.framework.security.handle.LogoutSuccessHandlerImpl; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; | import org.springframework.beans.factory.annotation.Autowired; | ||||||
| import org.springframework.context.annotation.Bean; | import org.springframework.context.annotation.Bean; | ||||||
| import org.springframework.context.annotation.Configuration; | import org.springframework.context.annotation.Configuration; | ||||||
| @@ -7,7 +11,7 @@ import org.springframework.http.HttpMethod; | |||||||
| import org.springframework.security.authentication.AuthenticationManager; | import org.springframework.security.authentication.AuthenticationManager; | ||||||
| import org.springframework.security.authentication.ProviderManager; | import org.springframework.security.authentication.ProviderManager; | ||||||
| import org.springframework.security.authentication.dao.DaoAuthenticationProvider; | import org.springframework.security.authentication.dao.DaoAuthenticationProvider; | ||||||
| import org.springframework.security.config.annotation.method.configuration.EnableMethodSecurity; | import org.springframework.security.config.annotation.method.configuration.EnableGlobalMethodSecurity; | ||||||
| import org.springframework.security.config.annotation.web.builders.HttpSecurity; | import org.springframework.security.config.annotation.web.builders.HttpSecurity; | ||||||
| import org.springframework.security.config.http.SessionCreationPolicy; | import org.springframework.security.config.http.SessionCreationPolicy; | ||||||
| import org.springframework.security.core.userdetails.UserDetailsService; | import org.springframework.security.core.userdetails.UserDetailsService; | ||||||
| @@ -17,17 +21,12 @@ import org.springframework.security.web.authentication.UsernamePasswordAuthentic | |||||||
| import org.springframework.security.web.authentication.logout.LogoutFilter; | import org.springframework.security.web.authentication.logout.LogoutFilter; | ||||||
| import org.springframework.web.filter.CorsFilter; | import org.springframework.web.filter.CorsFilter; | ||||||
|  |  | ||||||
| import com.core.framework.config.properties.PermitAllUrlProperties; |  | ||||||
| import com.core.framework.security.filter.JwtAuthenticationTokenFilter; |  | ||||||
| import com.core.framework.security.handle.AuthenticationEntryPointImpl; |  | ||||||
| import com.core.framework.security.handle.LogoutSuccessHandlerImpl; |  | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * spring security配置 |  * spring security配置 | ||||||
|  *  |  * | ||||||
|  * @author system |  * @author system | ||||||
|  */ |  */ | ||||||
| @EnableMethodSecurity(prePostEnabled = true, securedEnabled = true) | @EnableGlobalMethodSecurity(prePostEnabled = true, securedEnabled = true) | ||||||
| @Configuration | @Configuration | ||||||
| public class SecurityConfig { | public class SecurityConfig { | ||||||
|     /** |     /** | ||||||
| @@ -86,38 +85,38 @@ public class SecurityConfig { | |||||||
|     @Bean |     @Bean | ||||||
|     protected SecurityFilterChain filterChain(HttpSecurity httpSecurity) throws Exception { |     protected SecurityFilterChain filterChain(HttpSecurity httpSecurity) throws Exception { | ||||||
|         return httpSecurity |         return httpSecurity | ||||||
|             // CSRF禁用,因为不使用session |                 // CSRF禁用,因为不使用session | ||||||
|             .csrf(csrf -> csrf.disable()) |                 .csrf(csrf -> csrf.disable()) | ||||||
|             // 禁用HTTP响应标头 |                 // 禁用HTTP响应标头 | ||||||
|             .headers((headersCustomizer) -> { |                 .headers((headersCustomizer) -> { | ||||||
|                 headersCustomizer.cacheControl(cache -> cache.disable()).frameOptions(options -> options.sameOrigin()); |                     headersCustomizer.cacheControl(cache -> cache.disable()).frameOptions(options -> options.sameOrigin()); | ||||||
|             }) |                 }) | ||||||
|             // 认证失败处理类 |                 // 认证失败处理类 | ||||||
|             .exceptionHandling(exception -> exception.authenticationEntryPoint(unauthorizedHandler)) |                 .exceptionHandling(exception -> exception.authenticationEntryPoint(unauthorizedHandler)) | ||||||
|             // 基于token,所以不需要session |                 // 基于token,所以不需要session | ||||||
|             .sessionManagement(session -> session.sessionCreationPolicy(SessionCreationPolicy.STATELESS)) |                 .sessionManagement(session -> session.sessionCreationPolicy(SessionCreationPolicy.STATELESS)) | ||||||
|             // 注解标记允许匿名访问的url |                 // 注解标记允许匿名访问的url | ||||||
|             .authorizeHttpRequests((requests) -> { |                 .authorizeHttpRequests((requests) -> { | ||||||
|                 permitAllUrl.getUrls().forEach(url -> requests.antMatchers(url).permitAll()); |                     permitAllUrl.getUrls().forEach(url -> requests.antMatchers(url).permitAll()); | ||||||
|                 // 对于登录login 注册register 验证码captchaImage 允许匿名访问 |                     // 对于登录login 注册register 验证码captchaImage 允许匿名访问 | ||||||
|                 requests.antMatchers("/login", "/register", "/captchaImage").permitAll() |                     requests.antMatchers("/login", "/register", "/captchaImage").permitAll() | ||||||
|                     // 静态资源,可匿名访问 |                             // 静态资源,可匿名访问 | ||||||
|                     .antMatchers(HttpMethod.GET, "/", "/*.html", "/**/*.html", "/**/*.css", "/**/*.js", "/profile/**") |                             .antMatchers(HttpMethod.GET, "/", "/*.html", "/**/*.html", "/**/*.css", "/**/*.js", "/profile/**") | ||||||
|                     .permitAll() |                             .permitAll() | ||||||
|                     .antMatchers("/swagger-ui.html", "/swagger-resources/**", "/webjars/**", "/*/api-docs", "/druid/**") |                             .antMatchers("/swagger-ui.html", "/swagger-resources/**", "/webjars/**", "/*/api-docs", "/druid/**") | ||||||
|                     .permitAll() |                             .permitAll() | ||||||
|                     .antMatchers("/patientmanage/information/**") |                             .antMatchers("/patientmanage/information/**") | ||||||
|                     .permitAll() |                             .permitAll() | ||||||
|                     // 除上面外的所有请求全部需要鉴权认证 |                             // 除上面外的所有请求全部需要鉴权认证 | ||||||
|                     .anyRequest().authenticated(); |                             .anyRequest().authenticated(); | ||||||
|             }) |                 }) | ||||||
|             // 添加Logout filter |                 // 添加Logout filter | ||||||
|             .logout(logout -> logout.logoutUrl("/logout").logoutSuccessHandler(logoutSuccessHandler)) |                 .logout(logout -> logout.logoutUrl("/logout").logoutSuccessHandler(logoutSuccessHandler)) | ||||||
|             // 添加JWT filter |                 // 添加JWT filter | ||||||
|             .addFilterBefore(authenticationTokenFilter, UsernamePasswordAuthenticationFilter.class) |                 .addFilterBefore(authenticationTokenFilter, UsernamePasswordAuthenticationFilter.class) | ||||||
|             // 添加CORS filter |                 // 添加CORS filter | ||||||
|             .addFilterBefore(corsFilter, JwtAuthenticationTokenFilter.class) |                 .addFilterBefore(corsFilter, JwtAuthenticationTokenFilter.class) | ||||||
|             .addFilterBefore(corsFilter, LogoutFilter.class).build(); |                 .addFilterBefore(corsFilter, LogoutFilter.class).build(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|   | |||||||
| @@ -273,7 +273,7 @@ public class SysLoginService { | |||||||
|         Optional<SysTenant> currentTenantOptional = |         Optional<SysTenant> currentTenantOptional = | ||||||
|             bindTenantList.getData().stream().filter(e -> tenantId.equals(e.getId())).findFirst(); |             bindTenantList.getData().stream().filter(e -> tenantId.equals(e.getId())).findFirst(); | ||||||
|         if (currentTenantOptional.isEmpty()) { |         if (currentTenantOptional.isEmpty()) { | ||||||
|             throw new ServiceException("所属医院非法"); |             throw new ServiceException("所属医院无权限"); | ||||||
|         } |         } | ||||||
|         // 租户状态校验 |         // 租户状态校验 | ||||||
|         SysTenant currentTenant = currentTenantOptional.get(); |         SysTenant currentTenant = currentTenantOptional.get(); | ||||||
|   | |||||||
| @@ -23,15 +23,11 @@ | |||||||
|             <groupId>com.core</groupId> |             <groupId>com.core</groupId> | ||||||
|             <artifactId>core-common</artifactId> |             <artifactId>core-common</artifactId> | ||||||
|         </dependency> |         </dependency> | ||||||
|         <dependency> |  | ||||||
|             <groupId>org.projectlombok</groupId> |  | ||||||
|             <artifactId>lombok</artifactId> |  | ||||||
|             <optional>true</optional> |  | ||||||
|         </dependency> |  | ||||||
|         <dependency> |         <dependency> | ||||||
|             <groupId>io.swagger</groupId> |             <groupId>io.swagger</groupId> | ||||||
|             <artifactId>swagger-annotations</artifactId> |             <artifactId>swagger-annotations</artifactId> | ||||||
|             <scope>compile</scope> |  | ||||||
|         </dependency> |         </dependency> | ||||||
|  |  | ||||||
|         <!-- postgresql  --> |         <!-- postgresql  --> | ||||||
|   | |||||||
| @@ -23,18 +23,21 @@ | |||||||
|             <optional>true</optional> |             <optional>true</optional> | ||||||
|         </dependency> |         </dependency> | ||||||
|  |  | ||||||
|  |         <dependency> | ||||||
|  |             <groupId>cn.hutool</groupId> | ||||||
|  |             <artifactId>hutool-all</artifactId> | ||||||
|  |         </dependency> | ||||||
|  |  | ||||||
|         <!-- 领域--> |         <!-- 领域--> | ||||||
|         <dependency> |         <dependency> | ||||||
|             <groupId>com.openhis</groupId> |             <groupId>com.openhis</groupId> | ||||||
|             <artifactId>openhis-domain</artifactId> |             <artifactId>openhis-domain</artifactId> | ||||||
|             <version>0.0.1-SNAPSHOT</version> |  | ||||||
|         </dependency> |         </dependency> | ||||||
|  |  | ||||||
|         <!-- liteflow--> |         <!-- liteflow--> | ||||||
|         <dependency> |         <dependency> | ||||||
|             <groupId>com.yomahub</groupId> |             <groupId>com.yomahub</groupId> | ||||||
|             <artifactId>liteflow-spring-boot-starter</artifactId> |             <artifactId>liteflow-spring-boot-starter</artifactId> | ||||||
|             <version>2.12.4.1</version> |  | ||||||
|         </dependency> |         </dependency> | ||||||
|  |  | ||||||
|         <!-- junit--> |         <!-- junit--> | ||||||
| @@ -43,11 +46,10 @@ | |||||||
|             <artifactId>junit</artifactId> |             <artifactId>junit</artifactId> | ||||||
|             <scope>test</scope> |             <scope>test</scope> | ||||||
|         </dependency> |         </dependency> | ||||||
|  |  | ||||||
|         <dependency> |         <dependency> | ||||||
|             <groupId>com.alibaba</groupId> |             <groupId>com.alibaba.fastjson2</groupId> | ||||||
|             <artifactId>fastjson</artifactId> |             <artifactId>fastjson2</artifactId> | ||||||
|             <version>2.0.43</version> |  | ||||||
|             <scope>compile</scope> |  | ||||||
|         </dependency> |         </dependency> | ||||||
|         <dependency> |         <dependency> | ||||||
|             <groupId>org.apache.httpcomponents</groupId> |             <groupId>org.apache.httpcomponents</groupId> | ||||||
| @@ -61,7 +63,6 @@ | |||||||
|             <plugin> |             <plugin> | ||||||
|                 <groupId>org.springframework.boot</groupId> |                 <groupId>org.springframework.boot</groupId> | ||||||
|                 <artifactId>spring-boot-maven-plugin</artifactId> |                 <artifactId>spring-boot-maven-plugin</artifactId> | ||||||
|                 <version>2.5.15</version> |  | ||||||
|                 <configuration> |                 <configuration> | ||||||
|                     <fork>true</fork> <!-- 如果没有该配置,devtools不会生效 --> |                     <fork>true</fork> <!-- 如果没有该配置,devtools不会生效 --> | ||||||
|                 </configuration> |                 </configuration> | ||||||
| @@ -76,20 +77,12 @@ | |||||||
|             <plugin> |             <plugin> | ||||||
|                 <groupId>org.apache.maven.plugins</groupId> |                 <groupId>org.apache.maven.plugins</groupId> | ||||||
|                 <artifactId>maven-war-plugin</artifactId> |                 <artifactId>maven-war-plugin</artifactId> | ||||||
|                 <version>3.1.0</version> |                 <version>${maven-war-plugin.version}</version> | ||||||
|                 <configuration> |                 <configuration> | ||||||
|                     <failOnMissingWebXml>false</failOnMissingWebXml> |                     <failOnMissingWebXml>false</failOnMissingWebXml> | ||||||
|                     <warName>${project.artifactId}</warName> |                     <warName>${project.artifactId}</warName> | ||||||
|                 </configuration> |                 </configuration> | ||||||
|             </plugin> |             </plugin> | ||||||
|             <plugin> |  | ||||||
|                 <groupId>org.apache.maven.plugins</groupId> |  | ||||||
|                 <artifactId>maven-compiler-plugin</artifactId> |  | ||||||
|                 <configuration> |  | ||||||
|                     <source>17</source> |  | ||||||
|                     <target>17</target> |  | ||||||
|                 </configuration> |  | ||||||
|             </plugin> |  | ||||||
|         </plugins> |         </plugins> | ||||||
|         <finalName>${project.artifactId}</finalName> |         <finalName>${project.artifactId}</finalName> | ||||||
|     </build> |     </build> | ||||||
|   | |||||||
| @@ -0,0 +1,22 @@ | |||||||
|  | package com.openhis.web.adjustprice.appservice; | ||||||
|  |  | ||||||
|  | import com.openhis.web.adjustprice.dto.SupplyListDto; | ||||||
|  |  | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Desc: | ||||||
|  |  * @Author raymond | ||||||
|  |  * @Date 16:09 2025/10/15 | ||||||
|  |  * @return | ||||||
|  |  **/ | ||||||
|  | public interface ISupplyService { | ||||||
|  |     /** | ||||||
|  |      * Desc: | ||||||
|  |      * @param | ||||||
|  |      * @Author raymond | ||||||
|  |      * @Date 17:10 2025/10/15 | ||||||
|  |      * @return java.util.List<com.openhis.web.paymentmanage.dto.SupplyListDto> | ||||||
|  |      **/ | ||||||
|  |     List<SupplyListDto> searchAllSupplyList(); | ||||||
|  | } | ||||||
| @@ -0,0 +1,28 @@ | |||||||
|  | package com.openhis.web.adjustprice.appservice.impl; | ||||||
|  |  | ||||||
|  | import com.openhis.web.adjustprice.appservice.ISupplyService; | ||||||
|  | import com.openhis.web.adjustprice.dto.SupplyListDto; | ||||||
|  | import com.openhis.web.adjustprice.mapper.SupplyMapper; | ||||||
|  | import org.springframework.stereotype.Component; | ||||||
|  |  | ||||||
|  | import javax.annotation.Resource; | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @ClassName ChangePriceImpl | ||||||
|  |  * @Description TODO | ||||||
|  |  * @Author raymond | ||||||
|  |  * @Date 2025/10/15 16:10 | ||||||
|  |  * @Version 1.0 | ||||||
|  |  **/ | ||||||
|  | @Component | ||||||
|  | public class SupplyServiceImpl implements ISupplyService { | ||||||
|  |  | ||||||
|  |     @Resource | ||||||
|  |     private SupplyMapper supplyMapper; | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public List<SupplyListDto> searchAllSupplyList() { | ||||||
|  |         return this.supplyMapper.searchAllSupplyList(); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -0,0 +1,112 @@ | |||||||
|  | package com.openhis.web.adjustprice.controller; | ||||||
|  |  | ||||||
|  | import javax.annotation.Resource; | ||||||
|  | import javax.servlet.http.HttpServletRequest; | ||||||
|  |  | ||||||
|  | import org.springframework.web.bind.annotation.*; | ||||||
|  |  | ||||||
|  | import com.core.common.core.domain.R; | ||||||
|  | import com.openhis.web.adjustprice.appservice.ISupplyService; | ||||||
|  | import com.openhis.web.datadictionary.dto.MedicationSearchParam; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @ClassName ChargePriceController | ||||||
|  |  * @Description 调价修改药品、耗材、诊疗、挂号接口类 | ||||||
|  |  * @Author raymond | ||||||
|  |  * @Date 2025/10/14 16:56 | ||||||
|  |  * @Version 1.0 | ||||||
|  |  **/ | ||||||
|  | @RestController | ||||||
|  | @RequestMapping("/change/price") | ||||||
|  | public class ChangePriceController { | ||||||
|  |     @Resource | ||||||
|  |     private ISupplyService supplyService; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Desc: 查询所有供应商集合 | ||||||
|  |      *  | ||||||
|  |      * @param | ||||||
|  |      * @Author raymond | ||||||
|  |      * @Date 16:55 2025/10/15 | ||||||
|  |      * @return com.core.common.core.domain.R<?> | ||||||
|  |      **/ | ||||||
|  |     @GetMapping(value = "searchAllSupply") | ||||||
|  |     public R<?> searchAllSupply() { | ||||||
|  |         return R.ok(this.supplyService.searchAllSupplyList()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Desc: 根据供应商和药品名称加载要修改的药品数据 | ||||||
|  |      *  | ||||||
|  |      * @Author raymond | ||||||
|  |      * @Date 08:47 2025/10/15 | ||||||
|  |      * @return com.core.common.core.domain.R<?> | ||||||
|  |      **/ | ||||||
|  |     @PostMapping(value = "searchMedicineListToPage") | ||||||
|  |     public R<?> searchMedicineListToPage() { | ||||||
|  |         return R.ok(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Desc: | ||||||
|  |      *  | ||||||
|  |      * @param medicationSearchParam | ||||||
|  |      * @param searchKey | ||||||
|  |      * @param pageNo | ||||||
|  |      * @param pageSize | ||||||
|  |      * @param request | ||||||
|  |      * @Author raymond | ||||||
|  |      * @Date 13:41 2025/10/15 | ||||||
|  |      * @return com.core.common.core.domain.R<?> | ||||||
|  |      **/ | ||||||
|  |     @PostMapping(value = "searchConsumablesListToPage") | ||||||
|  |     public R<?> searchConsumablesListToPage(MedicationSearchParam medicationSearchParam, | ||||||
|  |         @RequestParam(value = "searchKey", defaultValue = "") String searchKey, | ||||||
|  |         @RequestParam(value = "pageNo", defaultValue = "1") Integer pageNo, | ||||||
|  |         @RequestParam(value = "pageSize", defaultValue = "10") Integer pageSize, HttpServletRequest request) { | ||||||
|  |  | ||||||
|  |         return null; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Desc: | ||||||
|  |      *  | ||||||
|  |      * @param medicationSearchParam | ||||||
|  |      * @param searchKey | ||||||
|  |      * @param pageNo | ||||||
|  |      * @param pageSize | ||||||
|  |      * @param request | ||||||
|  |      * @Author raymond | ||||||
|  |      * @Date 13:41 2025/10/15 | ||||||
|  |      * @return com.core.common.core.domain.R<?> | ||||||
|  |      **/ | ||||||
|  |     @PostMapping(value = "searchDiagnosisListToPage") | ||||||
|  |     public R<?> searchDiagnosisListToPage(MedicationSearchParam medicationSearchParam, | ||||||
|  |         @RequestParam(value = "searchKey", defaultValue = "") String searchKey, | ||||||
|  |         @RequestParam(value = "pageNo", defaultValue = "1") Integer pageNo, | ||||||
|  |         @RequestParam(value = "pageSize", defaultValue = "10") Integer pageSize, HttpServletRequest request) { | ||||||
|  |  | ||||||
|  |         return null; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Desc: | ||||||
|  |      *  | ||||||
|  |      * @param medicationSearchParam | ||||||
|  |      * @param searchKey | ||||||
|  |      * @param pageNo | ||||||
|  |      * @param pageSize | ||||||
|  |      * @param request | ||||||
|  |      * @Author raymond | ||||||
|  |      * @Date 13:41 2025/10/15 | ||||||
|  |      * @return com.core.common.core.domain.R<?> | ||||||
|  |      **/ | ||||||
|  |     @PostMapping(value = "searchHealthCareListToPage") | ||||||
|  |     public R<?> searchRegisterListToPage(MedicationSearchParam medicationSearchParam, | ||||||
|  |         @RequestParam(value = "searchKey", defaultValue = "") String searchKey, | ||||||
|  |         @RequestParam(value = "pageNo", defaultValue = "1") Integer pageNo, | ||||||
|  |         @RequestParam(value = "pageSize", defaultValue = "10") Integer pageSize, HttpServletRequest request) { | ||||||
|  |  | ||||||
|  |         return null; | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -0,0 +1,22 @@ | |||||||
|  | package com.openhis.web.adjustprice.dto; | ||||||
|  |  | ||||||
|  | import lombok.Data; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @ClassName SupplyListDto | ||||||
|  |  * @Description TODO | ||||||
|  |  * @Author raymond | ||||||
|  |  * @Date 2025/10/15 16:56 | ||||||
|  |  * @Version 1.0 | ||||||
|  |  **/ | ||||||
|  | @Data | ||||||
|  | public class SupplyListDto { | ||||||
|  |     /** | ||||||
|  |      * 供应商ID | ||||||
|  |      */ | ||||||
|  |     private Long supplyId; | ||||||
|  |     /** | ||||||
|  |      * 供应商名称 | ||||||
|  |      */ | ||||||
|  |     private String supplyName; | ||||||
|  | } | ||||||
| @@ -0,0 +1,25 @@ | |||||||
|  | package com.openhis.web.adjustprice.mapper; | ||||||
|  |  | ||||||
|  | import com.openhis.web.adjustprice.dto.SupplyListDto; | ||||||
|  | import org.springframework.stereotype.Component; | ||||||
|  |  | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Desc: | ||||||
|  |  * @Author raymond | ||||||
|  |  * @Date 14:37 2025/10/15 | ||||||
|  |  * @return | ||||||
|  |  **/ | ||||||
|  | @Component | ||||||
|  | public interface SupplyMapper { | ||||||
|  |     /** | ||||||
|  |      * Desc: | ||||||
|  |      * @param | ||||||
|  |      * @Author raymond | ||||||
|  |      * @Date 17:10 2025/10/15 | ||||||
|  |      * @return java.util.List<com.openhis.web.paymentmanage.dto.SupplyListDto> | ||||||
|  |      **/ | ||||||
|  |     List<SupplyListDto> searchAllSupplyList(); | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -7,6 +7,7 @@ import java.util.stream.Collectors; | |||||||
|  |  | ||||||
| import javax.annotation.Resource; | import javax.annotation.Resource; | ||||||
|  |  | ||||||
|  | import com.openhis.common.enums.AdministrativeGender; | ||||||
| import org.springframework.stereotype.Service; | import org.springframework.stereotype.Service; | ||||||
|  |  | ||||||
| import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | ||||||
| @@ -70,6 +71,8 @@ public class PractitionerAppServiceImpl implements IPractitionerAppService { | |||||||
|         String nickName = userAndPractitionerDto.getNickName(); |         String nickName = userAndPractitionerDto.getNickName(); | ||||||
|         String phonenumber = userAndPractitionerDto.getPhonenumber(); |         String phonenumber = userAndPractitionerDto.getPhonenumber(); | ||||||
|         String pharPracCertNo = userAndPractitionerDto.getPharPracCertNo(); // 职业证件编号 |         String pharPracCertNo = userAndPractitionerDto.getPharPracCertNo(); // 职业证件编号 | ||||||
|  |         String signature = userAndPractitionerDto.getSignature(); // 签名图片 | ||||||
|  |         String drProfttlCode = userAndPractitionerDto.getDrProfttlCode(); // 职称编码 | ||||||
|         String sex = userAndPractitionerDto.getSex(); |         String sex = userAndPractitionerDto.getSex(); | ||||||
|         // 账号唯一性 |         // 账号唯一性 | ||||||
|         long count = iBizUserService.count(new LambdaQueryWrapper<BizUser>().eq(BizUser::getUserName, userName)); |         long count = iBizUserService.count(new LambdaQueryWrapper<BizUser>().eq(BizUser::getUserName, userName)); | ||||||
| @@ -106,7 +109,7 @@ public class PractitionerAppServiceImpl implements IPractitionerAppService { | |||||||
|         Practitioner practitioner = new Practitioner(); |         Practitioner practitioner = new Practitioner(); | ||||||
|         practitioner.setActiveFlag(AccountStatus.ACTIVE.getValue()); // 活动标记 |         practitioner.setActiveFlag(AccountStatus.ACTIVE.getValue()); // 活动标记 | ||||||
|         practitioner.setName(nickName); // 姓名 |         practitioner.setName(nickName); // 姓名 | ||||||
|         practitioner.setGenderEnum(Integer.parseInt(sex)); // 性别 |         practitioner.setGenderEnum(sex==null? AdministrativeGender.UNKNOWN.getValue() : Integer.parseInt(sex)); // 性别 | ||||||
|         practitioner.setBirthDate(userAndPractitionerDto.getBirthDate()); // 出生日期 |         practitioner.setBirthDate(userAndPractitionerDto.getBirthDate()); // 出生日期 | ||||||
|         practitioner.setPhone(phonenumber); // 电话 |         practitioner.setPhone(phonenumber); // 电话 | ||||||
|         practitioner.setAddress(userAndPractitionerDto.getAddress()); // 地址 |         practitioner.setAddress(userAndPractitionerDto.getAddress()); // 地址 | ||||||
| @@ -119,6 +122,8 @@ public class PractitionerAppServiceImpl implements IPractitionerAppService { | |||||||
|         practitioner.setPyStr(ChineseConvertUtils.toPinyinFirstLetter(nickName)); // 拼音码 |         practitioner.setPyStr(ChineseConvertUtils.toPinyinFirstLetter(nickName)); // 拼音码 | ||||||
|         practitioner.setWbStr(ChineseConvertUtils.toWBFirstLetter(nickName)); // 五笔码 |         practitioner.setWbStr(ChineseConvertUtils.toWBFirstLetter(nickName)); // 五笔码 | ||||||
|         practitioner.setPharPracCertNo(pharPracCertNo); // 职业证件编号 |         practitioner.setPharPracCertNo(pharPracCertNo); // 职业证件编号 | ||||||
|  |         practitioner.setSignature(signature); // 签名图片 | ||||||
|  |         practitioner.setDrProfttlCode(drProfttlCode); // 职称编码 | ||||||
|         iPractitionerService.save(practitioner); |         iPractitionerService.save(practitioner); | ||||||
|         Long practitionerId = practitioner.getId();// 参与者id |         Long practitionerId = practitioner.getId();// 参与者id | ||||||
|         // 新增 adm_practitioner_role |         // 新增 adm_practitioner_role | ||||||
| @@ -276,6 +281,8 @@ public class PractitionerAppServiceImpl implements IPractitionerAppService { | |||||||
|         String phonenumber = userAndPractitionerDto.getPhonenumber(); |         String phonenumber = userAndPractitionerDto.getPhonenumber(); | ||||||
|         String sex = userAndPractitionerDto.getSex(); |         String sex = userAndPractitionerDto.getSex(); | ||||||
|         String pharPracCertNo = userAndPractitionerDto.getPharPracCertNo(); // 职业证件编号 |         String pharPracCertNo = userAndPractitionerDto.getPharPracCertNo(); // 职业证件编号 | ||||||
|  |         String signature = userAndPractitionerDto.getSignature(); // 签名图片 | ||||||
|  |         String drProfttlCode = userAndPractitionerDto.getDrProfttlCode(); // 职称编码 | ||||||
|         // 编辑 sys_user |         // 编辑 sys_user | ||||||
|         BizUser bizUser = new BizUser(); |         BizUser bizUser = new BizUser(); | ||||||
|         bizUser.setNickName(nickName); // 昵称 |         bizUser.setNickName(nickName); // 昵称 | ||||||
| @@ -299,7 +306,7 @@ public class PractitionerAppServiceImpl implements IPractitionerAppService { | |||||||
|         Practitioner practitioner = new Practitioner(); |         Practitioner practitioner = new Practitioner(); | ||||||
|         practitioner.setId(practitionerId); |         practitioner.setId(practitionerId); | ||||||
|         practitioner.setName(nickName); // 姓名 |         practitioner.setName(nickName); // 姓名 | ||||||
|         practitioner.setGenderEnum(Integer.parseInt(sex)); // 性别 |         practitioner.setGenderEnum(sex==null? AdministrativeGender.UNKNOWN.getValue() : Integer.parseInt(sex)); // 性别 | ||||||
|         practitioner.setBirthDate(userAndPractitionerDto.getBirthDate()); // 出生日期 |         practitioner.setBirthDate(userAndPractitionerDto.getBirthDate()); // 出生日期 | ||||||
|         practitioner.setPhone(phonenumber); // 电话 |         practitioner.setPhone(phonenumber); // 电话 | ||||||
|         practitioner.setAddress(userAndPractitionerDto.getAddress()); // 地址 |         practitioner.setAddress(userAndPractitionerDto.getAddress()); // 地址 | ||||||
| @@ -312,6 +319,8 @@ public class PractitionerAppServiceImpl implements IPractitionerAppService { | |||||||
|         practitioner.setPyStr(ChineseConvertUtils.toPinyinFirstLetter(nickName)); // 拼音码 |         practitioner.setPyStr(ChineseConvertUtils.toPinyinFirstLetter(nickName)); // 拼音码 | ||||||
|         practitioner.setWbStr(ChineseConvertUtils.toWBFirstLetter(nickName)); // 五笔码 |         practitioner.setWbStr(ChineseConvertUtils.toWBFirstLetter(nickName)); // 五笔码 | ||||||
|         practitioner.setPharPracCertNo(pharPracCertNo);// 职业证件编号 |         practitioner.setPharPracCertNo(pharPracCertNo);// 职业证件编号 | ||||||
|  |         practitioner.setSignature(signature); // 签名图片 | ||||||
|  |         practitioner.setDrProfttlCode(drProfttlCode); // 职称编码 | ||||||
|         iPractitionerService.updateById(practitioner); |         iPractitionerService.updateById(practitioner); | ||||||
|         // 先删除,再新增 adm_practitioner_role |         // 先删除,再新增 adm_practitioner_role | ||||||
|         practitionerAppAppMapper.delPractitionerRole(practitionerId); |         practitionerAppAppMapper.delPractitionerRole(practitionerId); | ||||||
|   | |||||||
| @@ -99,6 +99,12 @@ public class UserAndPractitionerDto { | |||||||
|      */ |      */ | ||||||
|     private String pharPracCertNo; |     private String pharPracCertNo; | ||||||
|  |  | ||||||
|  |     /** 签名图片 */ | ||||||
|  |     private String signature; | ||||||
|  |  | ||||||
|  |     /** 职称编码 */ | ||||||
|  |     private String drProfttlCode ; | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 机构id |      * 机构id | ||||||
|      */ |      */ | ||||||
|   | |||||||
| @@ -126,7 +126,6 @@ public class OutpatientChargeAppServiceImpl implements IOutpatientChargeAppServi | |||||||
|         }); |         }); | ||||||
|         return prescriptionDtoList; |         return prescriptionDtoList; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 医保转自费 |      * 医保转自费 | ||||||
|      * |      * | ||||||
|   | |||||||
| @@ -3,6 +3,7 @@ | |||||||
|  */ |  */ | ||||||
| package com.openhis.web.chargemanage.appservice.impl; | package com.openhis.web.chargemanage.appservice.impl; | ||||||
|  |  | ||||||
|  | import java.math.BigDecimal; | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
| import java.util.Arrays; | import java.util.Arrays; | ||||||
| import java.util.HashSet; | import java.util.HashSet; | ||||||
| @@ -272,7 +273,7 @@ public class OutpatientRefundAppServiceImpl implements IOutpatientRefundAppServi | |||||||
|                     medicationRequest.setId(null); // 药品请求id |                     medicationRequest.setId(null); // 药品请求id | ||||||
|                     medicationRequest |                     medicationRequest | ||||||
|                         .setBusNo(assignSeqUtil.getSeqByDay(AssignSeqEnum.MEDICATION_RES_NO.getPrefix(), 4)); // 药品请求编码 |                         .setBusNo(assignSeqUtil.getSeqByDay(AssignSeqEnum.MEDICATION_RES_NO.getPrefix(), 4)); // 药品请求编码 | ||||||
|                     medicationRequest.setQuantity(dto.getQuantity() * (-1)); // 请求数量 |                     medicationRequest.setQuantity(dto.getQuantity().multiply(new BigDecimal("-1"))); // 请求数量 | ||||||
|                     medicationRequest.setUnitCode(dto.getUnitCode()); // 请求单位编码 |                     medicationRequest.setUnitCode(dto.getUnitCode()); // 请求单位编码 | ||||||
|                     medicationRequest.setStatusEnum(RequestStatus.CANCELLED.getValue()); // 请求状态 |                     medicationRequest.setStatusEnum(RequestStatus.CANCELLED.getValue()); // 请求状态 | ||||||
|                     medicationRequest.setRefundMedicineId(dto.getRequestId()); // 退药id |                     medicationRequest.setRefundMedicineId(dto.getRequestId()); // 退药id | ||||||
| @@ -298,7 +299,7 @@ public class OutpatientRefundAppServiceImpl implements IOutpatientRefundAppServi | |||||||
|                     // 生成服务请求(取消服务) |                     // 生成服务请求(取消服务) | ||||||
|                     serviceRequest.setId(null); // 服务请求id |                     serviceRequest.setId(null); // 服务请求id | ||||||
|                     serviceRequest.setBusNo(assignSeqUtil.getSeqByDay(AssignSeqEnum.SERVICE_RES_NO.getPrefix(), 4)); // 服务请求编码 |                     serviceRequest.setBusNo(assignSeqUtil.getSeqByDay(AssignSeqEnum.SERVICE_RES_NO.getPrefix(), 4)); // 服务请求编码 | ||||||
|                     serviceRequest.setQuantity(dto.getQuantity() * (-1)); // 请求数量 |                     serviceRequest.setQuantity(dto.getQuantity().multiply(new BigDecimal("-1"))); // 请求数量 | ||||||
|                     serviceRequest.setUnitCode(dto.getUnitCode()); // 请求单位编码 |                     serviceRequest.setUnitCode(dto.getUnitCode()); // 请求单位编码 | ||||||
|                     serviceRequest.setStatusEnum(RequestStatus.CANCELLED.getValue()); // 请求状态 |                     serviceRequest.setStatusEnum(RequestStatus.CANCELLED.getValue()); // 请求状态 | ||||||
|                     serviceRequest.setRefundServiceId(dto.getRequestId()); // 退药id |                     serviceRequest.setRefundServiceId(dto.getRequestId()); // 退药id | ||||||
| @@ -321,7 +322,7 @@ public class OutpatientRefundAppServiceImpl implements IOutpatientRefundAppServi | |||||||
|                         // 生成耗材请求(退耗材) |                         // 生成耗材请求(退耗材) | ||||||
|                         deviceRequest.setId(null); // 耗材请求id |                         deviceRequest.setId(null); // 耗材请求id | ||||||
|                         deviceRequest.setBusNo(assignSeqUtil.getSeqByDay(AssignSeqEnum.DEVICE_RES_NO.getPrefix(), 4)); // 耗材请求编码 |                         deviceRequest.setBusNo(assignSeqUtil.getSeqByDay(AssignSeqEnum.DEVICE_RES_NO.getPrefix(), 4)); // 耗材请求编码 | ||||||
|                         deviceRequest.setQuantity(dto.getQuantity() * (-1)); // 请求数量 |                         deviceRequest.setQuantity(dto.getQuantity().multiply(new BigDecimal("-1"))); // 请求数量 | ||||||
|                         deviceRequest.setUnitCode(dto.getUnitCode()); // 请求单位编码 |                         deviceRequest.setUnitCode(dto.getUnitCode()); // 请求单位编码 | ||||||
|                         deviceRequest.setStatusEnum(RequestStatus.CANCELLED.getValue()); // 请求状态 |                         deviceRequest.setStatusEnum(RequestStatus.CANCELLED.getValue()); // 请求状态 | ||||||
|                         deviceRequest.setRefundDeviceId(dto.getRequestId()); // 退药id |                         deviceRequest.setRefundDeviceId(dto.getRequestId()); // 退药id | ||||||
| @@ -374,11 +375,11 @@ public class OutpatientRefundAppServiceImpl implements IOutpatientRefundAppServi | |||||||
|                 CommonConstants.FieldName.EncounterBusNo, CommonConstants.FieldName.idCard)), |                 CommonConstants.FieldName.EncounterBusNo, CommonConstants.FieldName.idCard)), | ||||||
|             request); |             request); | ||||||
|         // 就诊患者分页列表 |         // 就诊患者分页列表 | ||||||
|         Page<EncounterPatientPageDto> encounterPatientPage = |         Page<EncounterPatientPageDto> encounterPatientPage = outpatientRefundAppMapper.selectBilledEncounterPatientPage( | ||||||
|             outpatientRefundAppMapper.selectBilledEncounterPatientPage(new Page<>(pageNo, pageSize), queryWrapper, |             new Page<>(pageNo, pageSize), queryWrapper, ChargeItemStatus.BILLED.getValue(), | ||||||
|                 ChargeItemStatus.BILLED.getValue(), ChargeItemStatus.REFUNDING.getValue(), |             ChargeItemStatus.REFUNDING.getValue(), ChargeItemStatus.REFUNDED.getValue(), | ||||||
|                 ChargeItemStatus.REFUNDED.getValue(), ChargeItemStatus.PART_REFUND.getValue(), |             ChargeItemStatus.PART_REFUND.getValue(), AccountType.MEDICAL_ELECTRONIC_CERTIFICATE.getCode(), | ||||||
|                 AccountType.MEDICAL_ELECTRONIC_CERTIFICATE.getCode(), EncounterClass.AMB.getValue()); |             EncounterClass.AMB.getValue(), ChargeItemContext.REGISTER.getValue()); | ||||||
|  |  | ||||||
|         encounterPatientPage.getRecords().forEach(e -> { |         encounterPatientPage.getRecords().forEach(e -> { | ||||||
|             // 性别枚举 |             // 性别枚举 | ||||||
| @@ -386,9 +387,9 @@ public class OutpatientRefundAppServiceImpl implements IOutpatientRefundAppServi | |||||||
|             // 收费状态枚举 |             // 收费状态枚举 | ||||||
|             e.setStatusEnum_enumText(EnumUtils.getInfoByValue(ChargeItemStatus.class, e.getStatusEnum())); |             e.setStatusEnum_enumText(EnumUtils.getInfoByValue(ChargeItemStatus.class, e.getStatusEnum())); | ||||||
|             // 计算年龄 |             // 计算年龄 | ||||||
|             e.setAge(AgeCalculatorUtil.getAge(e.getBirthDate())); |             if (e.getBirthDate() != null) { | ||||||
|             // 合同类型枚举 |                 e.setAge(AgeCalculatorUtil.getAge(e.getBirthDate())); | ||||||
|             e.setCategoryEnum_enumText(EnumUtils.getInfoByValue(ContractCategory.class, e.getCategoryEnum())); |             } | ||||||
|         }); |         }); | ||||||
|         return R.ok(encounterPatientPage); |         return R.ok(encounterPatientPage); | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -119,6 +119,12 @@ public class OutpatientRegistrationAppServiceImpl implements IOutpatientRegistra | |||||||
|             // 初复诊 |             // 初复诊 | ||||||
|             e.setFirstEnum_enumText(patientIdList.contains(e.getId()) ? EncounterType.FOLLOW_UP.getInfo() |             e.setFirstEnum_enumText(patientIdList.contains(e.getId()) ? EncounterType.FOLLOW_UP.getInfo() | ||||||
|                 : EncounterType.INITIAL.getInfo()); |                 : EncounterType.INITIAL.getInfo()); | ||||||
|  |             // 患者标识 | ||||||
|  |             PatientIdentifier patientIdentifier = patientIdentifierService | ||||||
|  |                     .getOne(new LambdaQueryWrapper<PatientIdentifier>().eq(PatientIdentifier::getPatientId, e.getId())); | ||||||
|  |             if (patientIdentifier != null) { | ||||||
|  |                 e.setIdentifierNo(patientIdentifier.getIdentifierNo()); | ||||||
|  |             } | ||||||
|  |  | ||||||
|         }); |         }); | ||||||
|         return patientMetadataPage; |         return patientMetadataPage; | ||||||
|   | |||||||
| @@ -2,15 +2,12 @@ package com.openhis.web.chargemanage.dto; | |||||||
|  |  | ||||||
| import com.fasterxml.jackson.databind.annotation.JsonSerialize; | import com.fasterxml.jackson.databind.annotation.JsonSerialize; | ||||||
| import com.fasterxml.jackson.databind.ser.std.ToStringSerializer; | import com.fasterxml.jackson.databind.ser.std.ToStringSerializer; | ||||||
| import com.openhis.common.enums.EncounterLocationStatus; | import com.openhis.common.enums.EncounterActivityStatus; | ||||||
| import com.openhis.common.enums.LocationForm; | import com.openhis.common.enums.LocationForm; | ||||||
|  |  | ||||||
| import lombok.Data; | import lombok.Data; | ||||||
| import lombok.experimental.Accessors; | import lombok.experimental.Accessors; | ||||||
|  |  | ||||||
| import javax.validation.constraints.NotBlank; |  | ||||||
| import javax.validation.constraints.NotNull; |  | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * 就诊位置 表单数据 |  * 就诊位置 表单数据 | ||||||
|  */ |  */ | ||||||
| @@ -39,7 +36,7 @@ public class EncounterLocationFormData { | |||||||
|      * 设置默认值 |      * 设置默认值 | ||||||
|      */ |      */ | ||||||
|     public EncounterLocationFormData() { |     public EncounterLocationFormData() { | ||||||
|         this.statusEnum = EncounterLocationStatus.PLANNED.getValue(); |         this.statusEnum = EncounterActivityStatus.PLANNED.getValue(); | ||||||
|         this.formEnum = LocationForm.ROOM.getValue(); |         this.formEnum = LocationForm.ROOM.getValue(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -79,13 +79,6 @@ public class EncounterPatientPageDto { | |||||||
|      */ |      */ | ||||||
|     private Date birthDate; |     private Date birthDate; | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 账户类型编码 |  | ||||||
|      */ |  | ||||||
|     @Dict(dictCode = "account_code") |  | ||||||
|     private String typeCode; |  | ||||||
|     private String typeCode_dictText; |  | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 账户余额 |      * 账户余额 | ||||||
|      */ |      */ | ||||||
| @@ -120,10 +113,6 @@ public class EncounterPatientPageDto { | |||||||
|      */ |      */ | ||||||
|     private BigDecimal totalAmount; |     private BigDecimal totalAmount; | ||||||
|  |  | ||||||
|     /** 合同类型 */ |  | ||||||
|     private Integer categoryEnum; |  | ||||||
|     private String categoryEnum_enumText; |  | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 结算时间 |      * 结算时间 | ||||||
|      */ |      */ | ||||||
| @@ -135,4 +124,9 @@ public class EncounterPatientPageDto { | |||||||
|      */ |      */ | ||||||
|     @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") |     @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") | ||||||
|     private Date startTime; |     private Date startTime; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 科室名称 | ||||||
|  |      */ | ||||||
|  |     private String organizationName; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -9,6 +9,7 @@ import java.util.Date; | |||||||
| import com.fasterxml.jackson.databind.annotation.JsonSerialize; | import com.fasterxml.jackson.databind.annotation.JsonSerialize; | ||||||
| import com.fasterxml.jackson.databind.ser.std.ToStringSerializer; | import com.fasterxml.jackson.databind.ser.std.ToStringSerializer; | ||||||
| import com.openhis.common.annotation.Dict; | import com.openhis.common.annotation.Dict; | ||||||
|  |  | ||||||
| import lombok.Data; | import lombok.Data; | ||||||
| import lombok.experimental.Accessors; | import lombok.experimental.Accessors; | ||||||
|  |  | ||||||
| @@ -103,4 +104,9 @@ public class EncounterPatientPrescriptionDto { | |||||||
|  |  | ||||||
|     /** 服务所在表 */ |     /** 服务所在表 */ | ||||||
|     private String serviceTable; |     private String serviceTable; | ||||||
|  |  | ||||||
|  |     /** 服务所在表对应的id */ | ||||||
|  |     @JsonSerialize(using = ToStringSerializer.class) | ||||||
|  |     private Long serviceId; | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -56,4 +56,8 @@ public class PatientMetadata { | |||||||
|      */ |      */ | ||||||
|     private String firstEnum_enumText; |     private String firstEnum_enumText; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 就诊卡号 | ||||||
|  |      */ | ||||||
|  |    private String identifierNo; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -42,7 +42,7 @@ public class RefundItemDto { | |||||||
|     private String prescriptionNo; |     private String prescriptionNo; | ||||||
|  |  | ||||||
|     /** 请求数量 */ |     /** 请求数量 */ | ||||||
|     private Integer quantity; |     private BigDecimal quantity; | ||||||
|  |  | ||||||
|     /** 请求单位编码 */ |     /** 请求单位编码 */ | ||||||
|     @Dict(dictCode = "unit_code") |     @Dict(dictCode = "unit_code") | ||||||
|   | |||||||
| @@ -56,4 +56,5 @@ public interface OutpatientChargeAppMapper { | |||||||
|         @Param("register") Integer register, @Param("planned") Integer planned, @Param("billable") Integer billable, |         @Param("register") Integer register, @Param("planned") Integer planned, @Param("billable") Integer billable, | ||||||
|         @Param("billed") Integer billed, @Param("refunding") Integer refunding, @Param("refunded") Integer refunded, |         @Param("billed") Integer billed, @Param("refunding") Integer refunding, @Param("refunded") Integer refunded, | ||||||
|         @Param("partRefund") Integer partRefund); |         @Param("partRefund") Integer partRefund); | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -61,12 +61,14 @@ public interface OutpatientRefundAppMapper { | |||||||
|      * @param partRefund 收费状态:部分退费 |      * @param partRefund 收费状态:部分退费 | ||||||
|      * @param insurance 账户类型:医保 |      * @param insurance 账户类型:医保 | ||||||
|      * @param amb 就诊类型:门诊 |      * @param amb 就诊类型:门诊 | ||||||
|  |      * @param register 账单类型:挂号费 | ||||||
|      * @return 已结算就诊患者分页列表 |      * @return 已结算就诊患者分页列表 | ||||||
|      */ |      */ | ||||||
|     Page<EncounterPatientPageDto> selectBilledEncounterPatientPage(@Param("page") Page<EncounterPatientPageDto> page, |     Page<EncounterPatientPageDto> selectBilledEncounterPatientPage(@Param("page") Page<EncounterPatientPageDto> page, | ||||||
|         @Param(Constants.WRAPPER) QueryWrapper<EncounterPatientPageParam> queryWrapper, @Param("billed") Integer billed, |         @Param(Constants.WRAPPER) QueryWrapper<EncounterPatientPageParam> queryWrapper, @Param("billed") Integer billed, | ||||||
|         @Param("refunding") Integer refunding, @Param("refunded") Integer refunded, |         @Param("refunding") Integer refunding, @Param("refunded") Integer refunded, | ||||||
|         @Param("partRefund") Integer partRefund, @Param("insurance") String insurance, @Param("amb") Integer amb); |         @Param("partRefund") Integer partRefund, @Param("insurance") String insurance, @Param("amb") Integer amb, | ||||||
|  |         @Param("register") Integer register); | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 查询患者退费项目 |      * 查询患者退费项目 | ||||||
|   | |||||||
| @@ -149,4 +149,21 @@ public interface ICommonService { | |||||||
|      * @return 病区列表 |      * @return 病区列表 | ||||||
|      */ |      */ | ||||||
|     List<LocationDto> getPractitionerWard(); |     List<LocationDto> getPractitionerWard(); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 查询参与者下拉列表 | ||||||
|  |      * | ||||||
|  |      * @param searchKey 模糊查询关键字 | ||||||
|  |      * @return 参与者下拉列表 | ||||||
|  |      */ | ||||||
|  |     R<?> getPractitionerList(String searchKey); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 查询医嘱打印信息 | ||||||
|  |      * | ||||||
|  |      * @param requestIds 请求ids | ||||||
|  |      * @param isPrescription 是否为处方 | ||||||
|  |      * @return 医嘱打印单 | ||||||
|  |      */ | ||||||
|  |     R<?> getAdvicePrintInfo(List<Long> requestIds, String isPrescription); | ||||||
| } | } | ||||||
|   | |||||||
| @@ -15,10 +15,12 @@ import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | |||||||
| import com.baomidou.mybatisplus.core.metadata.IPage; | import com.baomidou.mybatisplus.core.metadata.IPage; | ||||||
| import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||||
| import com.core.common.core.domain.R; | import com.core.common.core.domain.R; | ||||||
|  | import com.core.common.utils.AgeCalculatorUtil; | ||||||
| import com.core.common.utils.SecurityUtils; | import com.core.common.utils.SecurityUtils; | ||||||
| import com.core.common.utils.StringUtils; | import com.core.common.utils.StringUtils; | ||||||
| import com.core.common.utils.bean.BeanUtils; | import com.core.common.utils.bean.BeanUtils; | ||||||
| import com.openhis.administration.domain.Location; | import com.openhis.administration.domain.Location; | ||||||
|  | import com.openhis.administration.domain.Organization; | ||||||
| import com.openhis.administration.domain.TraceNoManage; | import com.openhis.administration.domain.TraceNoManage; | ||||||
| import com.openhis.administration.mapper.TraceNoManageMapper; | import com.openhis.administration.mapper.TraceNoManageMapper; | ||||||
| import com.openhis.administration.service.ILocationService; | import com.openhis.administration.service.ILocationService; | ||||||
| @@ -36,7 +38,6 @@ import com.openhis.web.common.dto.*; | |||||||
| import com.openhis.web.common.mapper.CommonAppMapper; | import com.openhis.web.common.mapper.CommonAppMapper; | ||||||
| import com.openhis.workflow.domain.InventoryItem; | import com.openhis.workflow.domain.InventoryItem; | ||||||
| import com.openhis.workflow.service.IInventoryItemService; | import com.openhis.workflow.service.IInventoryItemService; | ||||||
| import com.openhis.administration.domain.Organization; |  | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * app常用接口 |  * app常用接口 | ||||||
| @@ -301,7 +302,7 @@ public class CommonServiceImpl implements ICommonService { | |||||||
|      * @return 科室列表 |      * @return 科室列表 | ||||||
|      */ |      */ | ||||||
|     @Override |     @Override | ||||||
|     public List<Organization> departmentList(){ |     public List<Organization> departmentList() { | ||||||
|         return organizationService.getList(OrganizationType.DEPARTMENT.getValue(), null); |         return organizationService.getList(OrganizationType.DEPARTMENT.getValue(), null); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -451,4 +452,43 @@ public class CommonServiceImpl implements ICommonService { | |||||||
|         } |         } | ||||||
|         return locationDtoList; |         return locationDtoList; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 查询参与者下拉列表 | ||||||
|  |      * | ||||||
|  |      * @param searchKey 模糊查询关键字 | ||||||
|  |      * @return 参与者下拉列表 | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public R<?> getPractitionerList(String searchKey) { | ||||||
|  |         return R.ok(commonAppMapper.getPractitionerList(searchKey)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 查询医嘱打印信息 | ||||||
|  |      * | ||||||
|  |      * @param requestIds 请求ids | ||||||
|  |      * @param isPrescription 是否为处方 | ||||||
|  |      * @return 医嘱打印单 | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public R<?> getAdvicePrintInfo(List<Long> requestIds, String isPrescription) { | ||||||
|  |         AdvicePrintInfoDto advicePrintInfoDto; | ||||||
|  |         if (Whether.YES.getCode().equals(isPrescription)) { | ||||||
|  |             // 查询处方单 | ||||||
|  |             advicePrintInfoDto = commonAppMapper.selectPrescriptionPrintInfo(requestIds); | ||||||
|  |         } else { | ||||||
|  |             // 查询处置单 | ||||||
|  |             advicePrintInfoDto = commonAppMapper.selectTreatmentPrintInfo(requestIds); | ||||||
|  |         } | ||||||
|  |         advicePrintInfoDto | ||||||
|  |             .setAge(advicePrintInfoDto.getBirthDate() != null | ||||||
|  |                 ? AgeCalculatorUtil.getAge(advicePrintInfoDto.getBirthDate()) : "") | ||||||
|  |             .setGenderEnum_enumText( | ||||||
|  |                 EnumUtils.getInfoByValue(AdministrativeGender.class, advicePrintInfoDto.getGenderEnum())) | ||||||
|  |             .setEncounterYbClass_enumText( | ||||||
|  |                 EnumUtils.getInfoByValue(EncounterYbClass.class, advicePrintInfoDto.getEncounterYbClass())); | ||||||
|  |         return R.ok(advicePrintInfoDto); | ||||||
|  |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -7,6 +7,8 @@ import java.util.List; | |||||||
|  |  | ||||||
| import javax.annotation.Resource; | import javax.annotation.Resource; | ||||||
|  |  | ||||||
|  | import com.openhis.common.enums.Whether; | ||||||
|  | import com.openhis.web.common.dto.AdvicePrintInfoDto; | ||||||
| import org.springframework.web.bind.annotation.GetMapping; | import org.springframework.web.bind.annotation.GetMapping; | ||||||
| import org.springframework.web.bind.annotation.RequestMapping; | import org.springframework.web.bind.annotation.RequestMapping; | ||||||
| import org.springframework.web.bind.annotation.RequestParam; | import org.springframework.web.bind.annotation.RequestParam; | ||||||
| @@ -198,4 +200,28 @@ public class CommonAppController { | |||||||
|     public List<LocationDto> getPractitionerWard() { |     public List<LocationDto> getPractitionerWard() { | ||||||
|         return commonService.getPractitionerWard(); |         return commonService.getPractitionerWard(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 查询参与者下拉列表 | ||||||
|  |      *  | ||||||
|  |      * @param searchKey 模糊查询关键字 | ||||||
|  |      * @return 参与者下拉列表 | ||||||
|  |      */ | ||||||
|  |     @GetMapping(value = "/practitioner-list") | ||||||
|  |     public R<?> getPractitionerList(@RequestParam(value = "searchKey", required = false) String searchKey) { | ||||||
|  |         return commonService.getPractitionerList(searchKey); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 查询医嘱打印信息 | ||||||
|  |      * | ||||||
|  |      * @param requestIds 请求ids | ||||||
|  |      * @param isPrescription 是否为处方 | ||||||
|  |      * @return 医嘱打印单 | ||||||
|  |      */ | ||||||
|  |     @GetMapping("/advice-print") | ||||||
|  |     public R<?> getAdvicePrintInfo(@RequestParam(value = "requestIds") List<Long> requestIds, String isPrescription) { | ||||||
|  |         return commonService.getAdvicePrintInfo(requestIds,isPrescription); | ||||||
|  |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -0,0 +1,95 @@ | |||||||
|  | /* | ||||||
|  |  * Copyright ©2023 CJB-CNIT Team. All rights reserved | ||||||
|  |  */ | ||||||
|  | package com.openhis.web.common.dto; | ||||||
|  |  | ||||||
|  | import java.math.BigDecimal; | ||||||
|  |  | ||||||
|  | import com.openhis.common.annotation.Dict; | ||||||
|  |  | ||||||
|  | import lombok.Data; | ||||||
|  | import lombok.experimental.Accessors; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 医嘱项目打印信息 | ||||||
|  |  * | ||||||
|  |  * @author zwh | ||||||
|  |  * @date 2025-09-16 | ||||||
|  |  */ | ||||||
|  | @Data | ||||||
|  | @Accessors(chain = true) | ||||||
|  | public class AdviceItemPrintInfoDto { | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 数量 | ||||||
|  |      */ | ||||||
|  |     private Integer quantity; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 单价 | ||||||
|  |      */ | ||||||
|  |     private BigDecimal unitPrice; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 总价 | ||||||
|  |      */ | ||||||
|  |     private BigDecimal totalPrice; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 项目名称 | ||||||
|  |      */ | ||||||
|  |     private String itemName; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 规格 | ||||||
|  |      */ | ||||||
|  |     private String totalVolume; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 单次剂量 | ||||||
|  |      */ | ||||||
|  |     private BigDecimal dose; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 用药频次 | ||||||
|  |      */ | ||||||
|  |     @Dict(dictCode = "rate_code") | ||||||
|  |     private String rateCode; | ||||||
|  |     private String rateCode_dictText; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 用法 | ||||||
|  |      */ | ||||||
|  |     @Dict(dictCode = "method_code") | ||||||
|  |     private String methodCode; | ||||||
|  |     private String methodCode_dictText; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 剂量单位 | ||||||
|  |      */ | ||||||
|  |     @Dict(dictCode = "unit_code") | ||||||
|  |     private String doseUnitCode; | ||||||
|  |     private String doseUnitCode_dictText; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 单位 | ||||||
|  |      */ | ||||||
|  |     @Dict(dictCode = "unit_code") | ||||||
|  |     private String unitCode; | ||||||
|  |     private String unitCode_dictText; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 处方号 | ||||||
|  |      */ | ||||||
|  |     private String prescriptionNo; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 分组号 | ||||||
|  |      */ | ||||||
|  |     private Long groupId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 排序号 | ||||||
|  |      */ | ||||||
|  |     private Integer sortNumber; | ||||||
|  | } | ||||||
| @@ -0,0 +1,100 @@ | |||||||
|  | /* | ||||||
|  |  * Copyright ©2023 CJB-CNIT Team. All rights reserved | ||||||
|  |  */ | ||||||
|  | package com.openhis.web.common.dto; | ||||||
|  |  | ||||||
|  | import java.util.Date; | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  | import com.fasterxml.jackson.annotation.JsonFormat; | ||||||
|  | import com.fasterxml.jackson.databind.annotation.JsonSerialize; | ||||||
|  | import com.fasterxml.jackson.databind.ser.std.ToStringSerializer; | ||||||
|  |  | ||||||
|  | import com.openhis.common.annotation.Dict; | ||||||
|  | import lombok.Data; | ||||||
|  | import lombok.experimental.Accessors; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 处方信息 | ||||||
|  |  * | ||||||
|  |  * @author zwh | ||||||
|  |  * @date 2025-09-16 | ||||||
|  |  */ | ||||||
|  | @Data | ||||||
|  | @Accessors(chain = true) | ||||||
|  | public class AdvicePrintInfoDto { | ||||||
|  |  | ||||||
|  |     /** 科室 */ | ||||||
|  |     private String departmentName; | ||||||
|  |  | ||||||
|  |     /** 患者姓名 */ | ||||||
|  |     private String patientName; | ||||||
|  |  | ||||||
|  |     /** 电话 */ | ||||||
|  |     private String phone; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 就诊编码 | ||||||
|  |      */ | ||||||
|  |     private String encounterNo; | ||||||
|  |  | ||||||
|  |     /** 性别 */ | ||||||
|  |     private Integer genderEnum; | ||||||
|  |     private String genderEnum_enumText; | ||||||
|  |  | ||||||
|  |     /** 年龄 */ | ||||||
|  |     private String age; | ||||||
|  |  | ||||||
|  |     /** 生日 */ | ||||||
|  |     private Date birthDate; | ||||||
|  |  | ||||||
|  |     /** 开具日期 */ | ||||||
|  |     @JsonFormat(shape = JsonFormat.Shape.STRING, pattern = "yyyy-MM-dd HH:mm:ss") | ||||||
|  |     private Date reqTime; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 费用性质 | ||||||
|  |      */ | ||||||
|  |     private String contractName; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 诊断名称 | ||||||
|  |      */ | ||||||
|  |     private String conditionName; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 开单医生 | ||||||
|  |      */ | ||||||
|  |     private String doctorName; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 发药医生 | ||||||
|  |      */ | ||||||
|  |     private String dispenseDoctorName; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 配药医生 | ||||||
|  |      */ | ||||||
|  |     private String preparerDoctorName; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 收费医生 | ||||||
|  |      */ | ||||||
|  |     private String chargeDoctorName; | ||||||
|  |  | ||||||
|  |     /** 就诊类型 */ | ||||||
|  |     private Integer encounterYbClass; | ||||||
|  |     private String encounterYbClass_enumText; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 单位 | ||||||
|  |      */ | ||||||
|  |     @Dict(dictCode = "unit_code") | ||||||
|  |     private String unitCode; | ||||||
|  |     private String unitCode_dictText; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 医嘱项目打印列表 | ||||||
|  |      */ | ||||||
|  |     private List<AdviceItemPrintInfoDto> adviceItemList; | ||||||
|  | } | ||||||
| @@ -26,10 +26,6 @@ public class PerformInfoDto { | |||||||
|     @JsonSerialize(using = ToStringSerializer.class) |     @JsonSerialize(using = ToStringSerializer.class) | ||||||
|     private Long requestId; |     private Long requestId; | ||||||
|  |  | ||||||
|     /** 医嘱项目id */ |  | ||||||
|     @JsonSerialize(using = ToStringSerializer.class) |  | ||||||
|     private Long itemId; |  | ||||||
|  |  | ||||||
|     /** 住院id */ |     /** 住院id */ | ||||||
|     @JsonSerialize(using = ToStringSerializer.class) |     @JsonSerialize(using = ToStringSerializer.class) | ||||||
|     private Long encounterId; |     private Long encounterId; | ||||||
| @@ -45,20 +41,20 @@ public class PerformInfoDto { | |||||||
|     /** 请求所在表 */ |     /** 请求所在表 */ | ||||||
|     private String requestTable; |     private String requestTable; | ||||||
|  |  | ||||||
|  |     /** 执行时间列表 */ | ||||||
|  |     private List<String> executeTimes; | ||||||
|  |  | ||||||
|     /** 执行位置 */ |     /** 执行位置 */ | ||||||
|     @JsonSerialize(using = ToStringSerializer.class) |     @JsonSerialize(using = ToStringSerializer.class) | ||||||
|     private Long locationId; |     private Long locationId; | ||||||
|  |  | ||||||
|  |     /** 分组id */ | ||||||
|  |     @JsonSerialize(using = ToStringSerializer.class) | ||||||
|  |     private Long groupId; | ||||||
|  |  | ||||||
|     /** 执行开始时间 */ |     /** 执行开始时间 */ | ||||||
|     private Date exeStartTime; |     private Date exeStartTime; | ||||||
|  |  | ||||||
|     /** 执行结束时间 */ |     /** 执行结束时间 */ | ||||||
|     private Date exeEndTime; |     private Date exeEndTime; | ||||||
|  |  | ||||||
|     /** 组号 */ |  | ||||||
|     @JsonSerialize(using = ToStringSerializer.class) |  | ||||||
|     private Long groupId; |  | ||||||
|  |  | ||||||
|     /** 执行时间列表 */ |  | ||||||
|     private List<String> executeTimes; |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -5,6 +5,7 @@ package com.openhis.web.common.dto; | |||||||
|  |  | ||||||
| import java.util.Date; | import java.util.Date; | ||||||
|  |  | ||||||
|  | import com.fasterxml.jackson.annotation.JsonFormat; | ||||||
| import com.fasterxml.jackson.databind.annotation.JsonSerialize; | import com.fasterxml.jackson.databind.annotation.JsonSerialize; | ||||||
| import com.fasterxml.jackson.databind.ser.std.ToStringSerializer; | import com.fasterxml.jackson.databind.ser.std.ToStringSerializer; | ||||||
|  |  | ||||||
| @@ -30,6 +31,7 @@ public class PerformRecordDto { | |||||||
|     private String statusEnum_enumText; |     private String statusEnum_enumText; | ||||||
|  |  | ||||||
|     /** 执行时间 */ |     /** 执行时间 */ | ||||||
|  |     @JsonFormat(shape = JsonFormat.Shape.STRING, pattern = "yyyy-MM-dd HH:mm:ss") | ||||||
|     private Date occurrenceTime; |     private Date occurrenceTime; | ||||||
|  |  | ||||||
|     /** 执行位置 */ |     /** 执行位置 */ | ||||||
|   | |||||||
| @@ -0,0 +1,38 @@ | |||||||
|  | /* | ||||||
|  |  * Copyright ©2023 CJB-CNIT Team. All rights reserved | ||||||
|  |  */ | ||||||
|  | package com.openhis.web.common.dto; | ||||||
|  |  | ||||||
|  | import com.fasterxml.jackson.databind.annotation.JsonSerialize; | ||||||
|  | import com.fasterxml.jackson.databind.ser.std.ToStringSerializer; | ||||||
|  |  | ||||||
|  | import lombok.Data; | ||||||
|  | import lombok.experimental.Accessors; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 参与者dto | ||||||
|  |  * | ||||||
|  |  * @author zwh | ||||||
|  |  * @date 2025-04-01 | ||||||
|  |  */ | ||||||
|  | @Data | ||||||
|  | @Accessors(chain = true) | ||||||
|  | public class PractitionerInfoDto { | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 参与者id | ||||||
|  |      */ | ||||||
|  |     @JsonSerialize(using = ToStringSerializer.class) | ||||||
|  |     private Long practitionerId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 参与者名称 | ||||||
|  |      */ | ||||||
|  |     private String practitionerName; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 科室名称 | ||||||
|  |      */ | ||||||
|  |     private String organizationName; | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -5,7 +5,6 @@ package com.openhis.web.common.mapper; | |||||||
|  |  | ||||||
| import java.util.List; | import java.util.List; | ||||||
|  |  | ||||||
| import com.openhis.administration.domain.TraceNoManage; |  | ||||||
| import org.apache.ibatis.annotations.Param; | import org.apache.ibatis.annotations.Param; | ||||||
| import org.springframework.stereotype.Repository; | import org.springframework.stereotype.Repository; | ||||||
|  |  | ||||||
| @@ -13,9 +12,8 @@ import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | |||||||
| import com.baomidou.mybatisplus.core.metadata.IPage; | import com.baomidou.mybatisplus.core.metadata.IPage; | ||||||
| import com.baomidou.mybatisplus.core.toolkit.Constants; | import com.baomidou.mybatisplus.core.toolkit.Constants; | ||||||
| import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||||
| import com.openhis.web.common.dto.InventoryItemDto; | import com.openhis.administration.domain.TraceNoManage; | ||||||
| import com.openhis.web.common.dto.InventoryItemParam; | import com.openhis.web.common.dto.*; | ||||||
| import com.openhis.web.common.dto.LocationInventoryDto; |  | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * app常用接口 mapper |  * app常用接口 mapper | ||||||
| @@ -62,8 +60,32 @@ public interface CommonAppMapper { | |||||||
|     /** |     /** | ||||||
|      * 查询追溯码信息 |      * 查询追溯码信息 | ||||||
|      * |      * | ||||||
|      * @param traceNo  追溯码 |      * @param traceNo 追溯码 | ||||||
|      * @return |      * @return | ||||||
|      */ |      */ | ||||||
|     TraceNoManage getInfoByTraceNo(@Param("traceNo") String traceNo); |     TraceNoManage getInfoByTraceNo(@Param("traceNo") String traceNo); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 查询参与者下拉列表 | ||||||
|  |      * | ||||||
|  |      * @param searchKey 模糊查询关键字 | ||||||
|  |      * @return 参与者下拉列表 | ||||||
|  |      */ | ||||||
|  |     List<PractitionerInfoDto> getPractitionerList(@Param("searchKey") String searchKey); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 查询处方打印信息 | ||||||
|  |      * | ||||||
|  |      * @param requestIds 请求ids | ||||||
|  |      * @return 处方打印信息 | ||||||
|  |      */ | ||||||
|  |     AdvicePrintInfoDto selectPrescriptionPrintInfo(@Param("requestIds") List<Long> requestIds); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 查询处置打印信息 | ||||||
|  |      * | ||||||
|  |      * @param requestIds 请求ids | ||||||
|  |      * @return 处置打印信息 | ||||||
|  |      */ | ||||||
|  |     AdvicePrintInfoDto selectTreatmentPrintInfo(@Param("requestIds") List<Long> requestIds); | ||||||
| } | } | ||||||
|   | |||||||
| @@ -6,15 +6,15 @@ package com.openhis.web.datadictionary.appservice; | |||||||
| import java.util.List; | import java.util.List; | ||||||
|  |  | ||||||
| import javax.servlet.http.HttpServletRequest; | import javax.servlet.http.HttpServletRequest; | ||||||
|  | import javax.servlet.http.HttpServletResponse; | ||||||
|  |  | ||||||
| import org.springframework.web.bind.annotation.GetMapping; |  | ||||||
| import org.springframework.web.bind.annotation.PathVariable; |  | ||||||
| import org.springframework.web.bind.annotation.RequestBody; | import org.springframework.web.bind.annotation.RequestBody; | ||||||
|  | import org.springframework.web.bind.annotation.RequestParam; | ||||||
|  | import org.springframework.web.multipart.MultipartFile; | ||||||
|  |  | ||||||
| import com.core.common.core.domain.R; | import com.core.common.core.domain.R; | ||||||
| import com.openhis.web.datadictionary.dto.DeviceManageSelParam; | import com.openhis.web.datadictionary.dto.DeviceManageSelParam; | ||||||
| import com.openhis.web.datadictionary.dto.DeviceManageUpDto; | import com.openhis.web.datadictionary.dto.DeviceManageUpDto; | ||||||
| import org.springframework.web.bind.annotation.RequestParam; |  | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * 器材目录 service |  * 器材目录 service | ||||||
| @@ -80,4 +80,19 @@ public interface IDeviceManageAppService { | |||||||
|      * @return |      * @return | ||||||
|      */ |      */ | ||||||
|     R<?> editDeviceStart(@RequestBody List<Long> ids); |     R<?> editDeviceStart(@RequestBody List<Long> ids); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 导入器材目录 | ||||||
|  |      * | ||||||
|  |      * @param file 文件 | ||||||
|  |      * @return 结果 | ||||||
|  |      */ | ||||||
|  |     R<?> importData(MultipartFile file); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 获取导入模板 | ||||||
|  |      * | ||||||
|  |      * @param response 响应 | ||||||
|  |      */ | ||||||
|  |     void importTemplate(HttpServletResponse response); | ||||||
| } | } | ||||||
|   | |||||||
| @@ -3,6 +3,9 @@ package com.openhis.web.datadictionary.appservice; | |||||||
| import java.util.List; | import java.util.List; | ||||||
|  |  | ||||||
| import javax.servlet.http.HttpServletRequest; | import javax.servlet.http.HttpServletRequest; | ||||||
|  | import javax.servlet.http.HttpServletResponse; | ||||||
|  |  | ||||||
|  | import org.springframework.web.multipart.MultipartFile; | ||||||
|  |  | ||||||
| import com.core.common.core.domain.R; | import com.core.common.core.domain.R; | ||||||
| import com.openhis.web.datadictionary.dto.DiagnosisTreatmentSelParam; | import com.openhis.web.datadictionary.dto.DiagnosisTreatmentSelParam; | ||||||
| @@ -75,4 +78,18 @@ public interface IDiagTreatMAppService { | |||||||
|      */ |      */ | ||||||
|     R<?> addDiseaseTreatment(DiagnosisTreatmentUpDto diagnosisTreatmentUpDto); |     R<?> addDiseaseTreatment(DiagnosisTreatmentUpDto diagnosisTreatmentUpDto); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 导入诊疗目录 | ||||||
|  |      * | ||||||
|  |      * @param file 文件 | ||||||
|  |      * @return 结果 | ||||||
|  |      */ | ||||||
|  |     R<?> importData(MultipartFile file); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 获取导入模板 | ||||||
|  |      * | ||||||
|  |      * @param response 响应 | ||||||
|  |      */ | ||||||
|  |     void importTemplate(HttpServletResponse response); | ||||||
| } | } | ||||||
| @@ -3,38 +3,46 @@ | |||||||
|  */ |  */ | ||||||
| package com.openhis.web.datadictionary.appservice.impl; | package com.openhis.web.datadictionary.appservice.impl; | ||||||
|  |  | ||||||
| import java.util.Arrays; | import java.math.BigDecimal; | ||||||
| import java.util.HashSet; | import java.util.*; | ||||||
| import java.util.List; |  | ||||||
| import java.util.concurrent.CopyOnWriteArrayList; | import java.util.concurrent.CopyOnWriteArrayList; | ||||||
| import java.util.stream.Collectors; | import java.util.stream.Collectors; | ||||||
| import java.util.stream.Stream; | import java.util.stream.Stream; | ||||||
|  |  | ||||||
| import javax.annotation.Resource; | import javax.annotation.Resource; | ||||||
| import javax.servlet.http.HttpServletRequest; | import javax.servlet.http.HttpServletRequest; | ||||||
|  | import javax.servlet.http.HttpServletResponse; | ||||||
|  |  | ||||||
| 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 org.springframework.validation.annotation.Validated; | import org.springframework.validation.annotation.Validated; | ||||||
| import org.springframework.web.bind.annotation.RequestBody; | import org.springframework.web.bind.annotation.RequestBody; | ||||||
| import org.springframework.web.bind.annotation.RequestParam; | import org.springframework.web.bind.annotation.RequestParam; | ||||||
|  | import org.springframework.web.multipart.MultipartFile; | ||||||
|  |  | ||||||
|  | import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | ||||||
| import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | ||||||
| import com.baomidou.mybatisplus.core.metadata.IPage; | import com.baomidou.mybatisplus.core.metadata.IPage; | ||||||
| import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||||
| import com.core.common.core.domain.R; | import com.core.common.core.domain.R; | ||||||
| import com.core.common.core.domain.entity.SysDictData; | import com.core.common.core.domain.entity.SysDictData; | ||||||
|  | import com.core.common.enums.DeleteFlag; | ||||||
| import com.core.common.utils.*; | import com.core.common.utils.*; | ||||||
| import com.core.common.utils.bean.BeanUtils; | import com.core.common.utils.bean.BeanUtils; | ||||||
|  | import com.core.common.utils.poi.ExcelUtil; | ||||||
| import com.core.system.service.ISysDictTypeService; | import com.core.system.service.ISysDictTypeService; | ||||||
| import com.openhis.administration.domain.ChargeItemDefinition; | import com.openhis.administration.domain.ChargeItemDefinition; | ||||||
| import com.openhis.administration.domain.DeviceDefinition; | import com.openhis.administration.domain.DeviceDefinition; | ||||||
|  | import com.openhis.administration.domain.Location; | ||||||
| import com.openhis.administration.domain.Supplier; | import com.openhis.administration.domain.Supplier; | ||||||
|  | import com.openhis.administration.service.IChargeItemDefinitionService; | ||||||
| import com.openhis.administration.service.IDeviceDefinitionService; | import com.openhis.administration.service.IDeviceDefinitionService; | ||||||
|  | import com.openhis.administration.service.ILocationService; | ||||||
| import com.openhis.administration.service.ISupplierService; | import com.openhis.administration.service.ISupplierService; | ||||||
| import com.openhis.common.constant.CommonConstants; | import com.openhis.common.constant.CommonConstants; | ||||||
| import com.openhis.common.constant.PromptMsgConstant; | import com.openhis.common.constant.PromptMsgConstant; | ||||||
| import com.openhis.common.enums.*; | import com.openhis.common.enums.*; | ||||||
|  | import com.openhis.common.utils.CommonUtil; | ||||||
| import com.openhis.common.utils.EnumUtils; | import com.openhis.common.utils.EnumUtils; | ||||||
| import com.openhis.common.utils.HisQueryUtils; | import com.openhis.common.utils.HisQueryUtils; | ||||||
| import com.openhis.sys.service.IOperationRecordService; | import com.openhis.sys.service.IOperationRecordService; | ||||||
| @@ -60,6 +68,12 @@ public class DeviceManageAppServiceImpl implements IDeviceManageAppService { | |||||||
|     @Autowired |     @Autowired | ||||||
|     private IDeviceDefinitionService deviceDefinitionService; |     private IDeviceDefinitionService deviceDefinitionService; | ||||||
|  |  | ||||||
|  |     @Autowired | ||||||
|  |     private IChargeItemDefinitionService chargeItemDefinitionService; | ||||||
|  |  | ||||||
|  |     @Autowired | ||||||
|  |     private ILocationService locationService; | ||||||
|  |  | ||||||
|     @Resource |     @Resource | ||||||
|     private DeviceManageMapper deviceManageMapper; |     private DeviceManageMapper deviceManageMapper; | ||||||
|  |  | ||||||
| @@ -185,11 +199,11 @@ public class DeviceManageAppServiceImpl implements IDeviceManageAppService { | |||||||
|      */ |      */ | ||||||
|     @Override |     @Override | ||||||
|     public R<?> editDevice(DeviceManageUpDto deviceManageDto) { |     public R<?> editDevice(DeviceManageUpDto deviceManageDto) { | ||||||
| //        // 校验是否可以编辑 |         // 校验是否可以编辑 | ||||||
| //        boolean result = supplyRequestService.verifyAbleEdit(deviceManageDto.getId()); |         boolean result = supplyRequestService.verifyAbleEdit(deviceManageDto.getId()); | ||||||
| //        if (result) { |         if (result) { | ||||||
| //            return R.fail("该耗材已经发生过业务,不可编辑"); |             return R.fail("该耗材已经发生过业务,不可编辑"); | ||||||
| //        } |         } | ||||||
|         DeviceDefinition deviceDefinition = new DeviceDefinition(); |         DeviceDefinition deviceDefinition = new DeviceDefinition(); | ||||||
|         BeanUtils.copyProperties(deviceManageDto, deviceDefinition); |         BeanUtils.copyProperties(deviceManageDto, deviceDefinition); | ||||||
|         // 拼音码 |         // 拼音码 | ||||||
| @@ -363,4 +377,245 @@ public class DeviceManageAppServiceImpl implements IDeviceManageAppService { | |||||||
|  |  | ||||||
|         return R.fail(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00008, null)); |         return R.fail(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00008, null)); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 导入器材目录 | ||||||
|  |      * | ||||||
|  |      * @param file 文件 | ||||||
|  |      * @return 结果 | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public R<?> importData(MultipartFile file) { | ||||||
|  |         // 读取文件 | ||||||
|  |         R<List<DeviceImportDto>> readResult = CommonUtil.readImportedExcelFile(file, DeviceImportDto.class); | ||||||
|  |         if (R.SUCCESS != readResult.getCode()) { | ||||||
|  |             return readResult; | ||||||
|  |         } | ||||||
|  |         List<DeviceImportDto> importDtoList = readResult.getData(); | ||||||
|  |         // 导入信息校验 | ||||||
|  |         R<?> validateResult = validateImportDtoList(importDtoList); | ||||||
|  |         if (R.SUCCESS != validateResult.getCode()) { | ||||||
|  |             return validateResult; | ||||||
|  |         } | ||||||
|  |         // 查询机构ID、位置信息供后续使用 | ||||||
|  |         Long orgId = SecurityUtils.getLoginUser().getOrgId(); | ||||||
|  |         List<Location> locationList = locationService.list(new LambdaQueryWrapper<Location>() | ||||||
|  |             .eq(Location::getDeleteFlag, DeleteFlag.NOT_DELETED.getCode()).orderByAsc(Location::getId)); | ||||||
|  |         Long defaultLocationId = locationList.stream().findFirst().orElse(new Location()).getId(); | ||||||
|  |         Map<String, List<Location>> locationNameMap = | ||||||
|  |             locationList.stream().collect(Collectors.groupingBy(Location::getName)); | ||||||
|  |         // 创建表数据 | ||||||
|  |         for (DeviceImportDto importDto : importDtoList) { | ||||||
|  |             // 创建器材定义 | ||||||
|  |             DeviceDefinition deviceDefinition = | ||||||
|  |                 createDeviceDefinitionEntity(importDto, orgId, defaultLocationId, locationNameMap); | ||||||
|  |             deviceDefinitionService.save(deviceDefinition); | ||||||
|  |             // 创建费用定价和详情 | ||||||
|  |             chargeItemDefinitionService.addChargeItemDefinitionAndDetail(importDto.getName(), importDto.getTypeCode(), | ||||||
|  |                 importDto.getYbType(), importDto.getUnitCode(), importDto.getPurchasePrice(), | ||||||
|  |                 importDto.getRetailPrice(), importDto.getMaximumRetailPrice(), orgId, | ||||||
|  |                 CommonConstants.TableName.ADM_DEVICE_DEFINITION, deviceDefinition.getId()); | ||||||
|  |         } | ||||||
|  |         return R.ok(null, "导入成功!"); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 获取导入模板 | ||||||
|  |      * | ||||||
|  |      * @param response 响应 | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public void importTemplate(HttpServletResponse response) { | ||||||
|  |         ExcelUtil<DeviceImportDto> util = new ExcelUtil<>(DeviceImportDto.class); | ||||||
|  |         util.importTemplateExcel(response, "器材目录数据"); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 导入信息校验 | ||||||
|  |      * | ||||||
|  |      * @param importDtoList 器材目录导入数据列表 | ||||||
|  |      */ | ||||||
|  |     private R<?> validateImportDtoList(List<DeviceImportDto> importDtoList) { | ||||||
|  |         // 字段校验(必填及数值类型) | ||||||
|  |         List<String> fieldValidateMsgList = new ArrayList<>(); | ||||||
|  |         for (int i = 0; i < importDtoList.size(); i++) { | ||||||
|  |             DeviceImportDto importDto = importDtoList.get(i); | ||||||
|  |             importDto.setLineNumber(i + 2); | ||||||
|  |             List<String> lineValidateMsgList = new ArrayList<>(); | ||||||
|  |             if (StringUtils.isEmpty(importDto.getName())) { | ||||||
|  |                 lineValidateMsgList.add("器材名称必填"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getCategoryCode())) { | ||||||
|  |                 lineValidateMsgList.add("器材分类必填"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getUnitCode())) { | ||||||
|  |                 lineValidateMsgList.add("包装单位必填"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getSize())) { | ||||||
|  |                 lineValidateMsgList.add("包装规格必填"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getItemMinQuantityStr())) { | ||||||
|  |                 lineValidateMsgList.add("最小库存警戒数量(常规单位)必填"); | ||||||
|  |             } | ||||||
|  |             BigDecimal itemMinQuantity; | ||||||
|  |             try { | ||||||
|  |                 itemMinQuantity = new BigDecimal(importDto.getItemMinQuantityStr()); | ||||||
|  |                 importDto.setItemMinQuantity(itemMinQuantity); | ||||||
|  |             } catch (Exception e) { | ||||||
|  |                 lineValidateMsgList.add("最小库存警戒数量(常规单位)应为数值类型"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getItemMaxQuantityStr())) { | ||||||
|  |                 lineValidateMsgList.add("最大库存警戒数量(常规单位)必填"); | ||||||
|  |             } | ||||||
|  |             BigDecimal itemMaxQuantity; | ||||||
|  |             try { | ||||||
|  |                 itemMaxQuantity = new BigDecimal(importDto.getItemMaxQuantityStr()); | ||||||
|  |                 importDto.setItemMaxQuantity(itemMaxQuantity); | ||||||
|  |             } catch (Exception e) { | ||||||
|  |                 lineValidateMsgList.add("最大库存警戒数量(常规单位)应为数值类型"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getPartPercentStr())) { | ||||||
|  |                 lineValidateMsgList.add("拆零比必填"); | ||||||
|  |             } | ||||||
|  |             BigDecimal partPercent; | ||||||
|  |             try { | ||||||
|  |                 partPercent = new BigDecimal(importDto.getPartPercentStr()); | ||||||
|  |                 importDto.setPartPercent(partPercent); | ||||||
|  |             } catch (Exception e) { | ||||||
|  |                 lineValidateMsgList.add("拆零比应为数值类型"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getLocationName())) { | ||||||
|  |                 lineValidateMsgList.add("所在位置名称必填"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getHvcmFlag())) { | ||||||
|  |                 lineValidateMsgList.add("高值器材标志必填"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getYbFlag())) { | ||||||
|  |                 lineValidateMsgList.add("医保标记必填"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getYbMatchFlag())) { | ||||||
|  |                 lineValidateMsgList.add("医保对码标记必填"); | ||||||
|  |             } | ||||||
|  |             if (Whether.YES.getCode().equals(importDto.getYbMatchFlag()) && StringUtils.isEmpty(importDto.getYbNo())) { | ||||||
|  |                 lineValidateMsgList.add("医保对码时,医保编码必填"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getAllergenFlag())) { | ||||||
|  |                 lineValidateMsgList.add("过敏标记必填"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getRxFlag())) { | ||||||
|  |                 lineValidateMsgList.add("处方标志必填"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getTypeCode())) { | ||||||
|  |                 lineValidateMsgList.add("财务类别必填"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getYbType())) { | ||||||
|  |                 lineValidateMsgList.add("医保费用类别必填"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getPurchasePriceStr())) { | ||||||
|  |                 lineValidateMsgList.add("购入价必填"); | ||||||
|  |             } | ||||||
|  |             BigDecimal purchasePrice; | ||||||
|  |             try { | ||||||
|  |                 purchasePrice = new BigDecimal(importDto.getPurchasePriceStr()); | ||||||
|  |                 importDto.setPurchasePrice(purchasePrice); | ||||||
|  |             } catch (Exception e) { | ||||||
|  |                 lineValidateMsgList.add("购入价应为数值类型"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getRetailPriceStr())) { | ||||||
|  |                 lineValidateMsgList.add("零售价必填"); | ||||||
|  |             } | ||||||
|  |             BigDecimal retailPrice; | ||||||
|  |             try { | ||||||
|  |                 retailPrice = new BigDecimal(importDto.getRetailPriceStr()); | ||||||
|  |                 importDto.setRetailPrice(retailPrice); | ||||||
|  |             } catch (Exception e) { | ||||||
|  |                 lineValidateMsgList.add("零售价应为数值类型"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getMaximumRetailPriceStr())) { | ||||||
|  |                 lineValidateMsgList.add("最高零售价必填"); | ||||||
|  |             } | ||||||
|  |             BigDecimal maximumRetailPrice; | ||||||
|  |             try { | ||||||
|  |                 maximumRetailPrice = new BigDecimal(importDto.getMaximumRetailPriceStr()); | ||||||
|  |                 importDto.setMaximumRetailPrice(maximumRetailPrice); | ||||||
|  |             } catch (Exception e) { | ||||||
|  |                 lineValidateMsgList.add("最高零售价应为数值类型"); | ||||||
|  |             } | ||||||
|  |             if (!lineValidateMsgList.isEmpty()) { | ||||||
|  |                 fieldValidateMsgList | ||||||
|  |                     .add("■ 第" + importDto.getLineNumber() + "行:" + String.join(",", lineValidateMsgList) + ";"); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         if (!fieldValidateMsgList.isEmpty()) { | ||||||
|  |             return R.fail("导入失败!器材信息填写有误:" + String.join(" ", fieldValidateMsgList)); | ||||||
|  |         } | ||||||
|  |         // 重复校验(文件行重复) | ||||||
|  |         List<String> lineRepeatedValidateMsgList = new ArrayList<>(); | ||||||
|  |         List<List<DeviceImportDto>> importDtoGroupList = new ArrayList<>(importDtoList.stream() | ||||||
|  |             .collect(Collectors.groupingBy(e -> e.getName() + e.getManufacturerText() + e.getSize())).values()); | ||||||
|  |         for (List<DeviceImportDto> importDtoGroup : importDtoGroupList) { | ||||||
|  |             if (importDtoGroup.size() > 1) { | ||||||
|  |                 lineRepeatedValidateMsgList.add( | ||||||
|  |                     "■ 第" + importDtoGroup.stream().map(DeviceImportDto::getLineNumber).sorted().map(Object::toString) | ||||||
|  |                         .collect(Collectors.joining(",")) + "行的【" + importDtoGroup.get(0).getName() + "】重复;"); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         if (!lineRepeatedValidateMsgList.isEmpty()) { | ||||||
|  |             return R.fail("导入失败!文件中存在重复器材:" + String.join(" ", lineRepeatedValidateMsgList)); | ||||||
|  |         } | ||||||
|  |         // 重复校验(文件与数据库重复) | ||||||
|  |         List<String> dbRepeatedValidateMsgList = new ArrayList<>(); | ||||||
|  |         for (DeviceImportDto importDto : importDtoList) { | ||||||
|  |             List<DeviceDefinition> deviceDefinitionList = deviceDefinitionService | ||||||
|  |                 .list(new LambdaQueryWrapper<DeviceDefinition>().eq(DeviceDefinition::getName, importDto.getName()) | ||||||
|  |                     .eq(DeviceDefinition::getManufacturerText, importDto.getManufacturerText()) | ||||||
|  |                     .eq(DeviceDefinition::getSize, importDto.getSize())); | ||||||
|  |             if (!deviceDefinitionList.isEmpty()) { | ||||||
|  |                 dbRepeatedValidateMsgList | ||||||
|  |                     .add("■ 第" + importDto.getLineNumber() + "行的【" + importDto.getName() + "】在系统中已存在;"); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         if (!dbRepeatedValidateMsgList.isEmpty()) { | ||||||
|  |             return R.fail("导入失败!系统中存在重复器材:" + String.join(" ", dbRepeatedValidateMsgList)); | ||||||
|  |         } | ||||||
|  |         return R.ok(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 创建器材定义实体 | ||||||
|  |      * | ||||||
|  |      * @param importDto 器材目录导入Dto | ||||||
|  |      * @param orgId 机构ID | ||||||
|  |      * @param defaultLocationId 默认位置ID | ||||||
|  |      * @param locationNameMap 位置名称匹配分组Map | ||||||
|  |      * @return 器材定义实体 | ||||||
|  |      */ | ||||||
|  |     private DeviceDefinition createDeviceDefinitionEntity(DeviceImportDto importDto, Long orgId, Long defaultLocationId, | ||||||
|  |         Map<String, List<Location>> locationNameMap) { | ||||||
|  |         DeviceDefinition deviceDefinition = new DeviceDefinition(); | ||||||
|  |         // 根据输入的所在位置名称获取位置ID | ||||||
|  |         List<Location> mapLocationList = locationNameMap.get(importDto.getLocationName()); | ||||||
|  |         if (mapLocationList == null || mapLocationList.isEmpty()) { | ||||||
|  |             deviceDefinition.setLocationId(defaultLocationId); | ||||||
|  |         } else { | ||||||
|  |             deviceDefinition.setLocationId(mapLocationList.get(0).getId()); | ||||||
|  |         } | ||||||
|  |         deviceDefinition.setBusNo(assignSeqUtil.getSeq(AssignSeqEnum.DEVICE_NUM.getPrefix(), 10)) | ||||||
|  |             .setName(importDto.getName()).setPyStr(ChineseConvertUtils.toPinyinFirstLetter(importDto.getName())) | ||||||
|  |             .setWbStr(ChineseConvertUtils.toWBFirstLetter(importDto.getName())) | ||||||
|  |             .setCategoryCode(importDto.getCategoryCode()).setTypeCode(importDto.getTypeCode()) | ||||||
|  |             .setUnitCode(importDto.getUnitCode()).setSize(importDto.getSize()) | ||||||
|  |             .setItemMinQuantity(importDto.getItemMinQuantity()).setItemMaxQuantity(importDto.getItemMaxQuantity()) | ||||||
|  |             .setPartPercent(importDto.getPartPercent()).setMinUnitCode(importDto.getMinUnitCode()).setOrgId(orgId) | ||||||
|  |             .setHvcmFlag(CommonUtil.tryParseInt(importDto.getHvcmFlag())).setSalesUnitCode(importDto.getSalesUnitCode()) | ||||||
|  |             .setApprovalNumber(importDto.getApprovalNumber()).setYbFlag(CommonUtil.tryParseInt(importDto.getYbFlag())) | ||||||
|  |             .setYbNo(importDto.getYbNo()).setYbOrgNo(importDto.getYbOrgNo()) | ||||||
|  |             .setYbMatchFlag(CommonUtil.tryParseInt(importDto.getYbMatchFlag())) | ||||||
|  |             .setChrgitmLv(CommonUtil.tryParseInt(importDto.getChrgitmLv())) | ||||||
|  |             .setStatusEnum(PublicationStatus.ACTIVE.getValue()).setManufacturerText(importDto.getManufacturerText()) | ||||||
|  |             .setAllergenFlag(CommonUtil.tryParseInt(importDto.getAllergenFlag())) | ||||||
|  |             .setRxFlag(CommonUtil.tryParseInt(importDto.getRxFlag())); | ||||||
|  |         return deviceDefinition; | ||||||
|  |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,5 +1,6 @@ | |||||||
| package com.openhis.web.datadictionary.appservice.impl; | package com.openhis.web.datadictionary.appservice.impl; | ||||||
|  |  | ||||||
|  | import java.math.BigDecimal; | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
| import java.util.Arrays; | import java.util.Arrays; | ||||||
| import java.util.HashSet; | import java.util.HashSet; | ||||||
| @@ -10,10 +11,11 @@ import java.util.stream.Stream; | |||||||
|  |  | ||||||
| import javax.annotation.Resource; | import javax.annotation.Resource; | ||||||
| import javax.servlet.http.HttpServletRequest; | import javax.servlet.http.HttpServletRequest; | ||||||
|  | import javax.servlet.http.HttpServletResponse; | ||||||
|  |  | ||||||
| import com.openhis.yb.service.YbManager; |  | ||||||
| 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 org.springframework.web.multipart.MultipartFile; | ||||||
|  |  | ||||||
| import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | ||||||
| import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | ||||||
| @@ -23,13 +25,16 @@ import com.core.common.core.domain.R; | |||||||
| import com.core.common.core.domain.entity.SysDictData; | import com.core.common.core.domain.entity.SysDictData; | ||||||
| import com.core.common.utils.*; | import com.core.common.utils.*; | ||||||
| import com.core.common.utils.bean.BeanUtils; | import com.core.common.utils.bean.BeanUtils; | ||||||
|  | import com.core.common.utils.poi.ExcelUtil; | ||||||
| import com.core.system.service.ISysDictTypeService; | import com.core.system.service.ISysDictTypeService; | ||||||
| import com.openhis.administration.domain.ChargeItemDefinition; | import com.openhis.administration.domain.ChargeItemDefinition; | ||||||
| import com.openhis.administration.domain.Organization; | import com.openhis.administration.domain.Organization; | ||||||
|  | import com.openhis.administration.service.IChargeItemDefinitionService; | ||||||
| import com.openhis.administration.service.IOrganizationService; | import com.openhis.administration.service.IOrganizationService; | ||||||
| import com.openhis.common.constant.CommonConstants; | import com.openhis.common.constant.CommonConstants; | ||||||
| import com.openhis.common.constant.PromptMsgConstant; | import com.openhis.common.constant.PromptMsgConstant; | ||||||
| import com.openhis.common.enums.*; | import com.openhis.common.enums.*; | ||||||
|  | import com.openhis.common.utils.CommonUtil; | ||||||
| import com.openhis.common.utils.EnumUtils; | import com.openhis.common.utils.EnumUtils; | ||||||
| import com.openhis.common.utils.HisQueryUtils; | import com.openhis.common.utils.HisQueryUtils; | ||||||
| import com.openhis.sys.service.IOperationRecordService; | import com.openhis.sys.service.IOperationRecordService; | ||||||
| @@ -41,6 +46,7 @@ import com.openhis.web.datadictionary.mapper.ActivityDefinitionManageMapper; | |||||||
| import com.openhis.workflow.domain.ActivityDefinition; | import com.openhis.workflow.domain.ActivityDefinition; | ||||||
| import com.openhis.workflow.mapper.ActivityDefinitionMapper; | import com.openhis.workflow.mapper.ActivityDefinitionMapper; | ||||||
| import com.openhis.workflow.service.IActivityDefinitionService; | import com.openhis.workflow.service.IActivityDefinitionService; | ||||||
|  | import com.openhis.yb.service.YbManager; | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * 诊疗实现类 |  * 诊疗实现类 | ||||||
| @@ -52,7 +58,9 @@ import com.openhis.workflow.service.IActivityDefinitionService; | |||||||
| public class DiagTreatMAppServiceImpl implements IDiagTreatMAppService { | public class DiagTreatMAppServiceImpl implements IDiagTreatMAppService { | ||||||
|  |  | ||||||
|     @Autowired |     @Autowired | ||||||
|     private IActivityDefinitionService iActivityDefinitionService; |     private IActivityDefinitionService activityDefinitionService; | ||||||
|  |     @Autowired | ||||||
|  |     private IChargeItemDefinitionService chargeItemDefinitionService; | ||||||
|     @Autowired |     @Autowired | ||||||
|     private ActivityDefinitionMapper activityDefinitionMapper; |     private ActivityDefinitionMapper activityDefinitionMapper; | ||||||
|     @Autowired |     @Autowired | ||||||
| @@ -110,15 +118,15 @@ public class DiagTreatMAppServiceImpl implements IDiagTreatMAppService { | |||||||
|             .collect(Collectors.toList()); |             .collect(Collectors.toList()); | ||||||
|         diagnosisTreatmentInitDto.setDiagnosisCategoryOptions(diagnosisCategories); |         diagnosisTreatmentInitDto.setDiagnosisCategoryOptions(diagnosisCategories); | ||||||
|  |  | ||||||
|         // 查询医疗服务项类型 |         // // 查询医疗服务项类型 | ||||||
|         List<SysDictData> medical_service_items = |         // List<SysDictData> medical_service_items = | ||||||
|             iSysDictTypeService.selectDictDataByType(ActivityDefCategory.MEDICAL_SERVICE_ITEM.getCode()); |         // iSysDictTypeService.selectDictDataByType(ActivityDefCategory.MEDICAL_SERVICE_ITEM.getCode()); | ||||||
|         // 获取医疗服务项List |         // // 获取医疗服务项List | ||||||
|         List<DiagnosisTreatmentInitDto.diseaseTreatmentType> diseaseTreatmentCategoryList = medical_service_items |         // List<DiagnosisTreatmentInitDto.diseaseTreatmentType> diseaseTreatmentCategoryList = medical_service_items | ||||||
|             .stream().map(status -> new DiagnosisTreatmentInitDto.diseaseTreatmentType(status.getDictValue(), |         // .stream().map(status -> new DiagnosisTreatmentInitDto.diseaseTreatmentType(status.getDictValue(), | ||||||
|                 status.getDictLabel())) |         // status.getDictLabel())) | ||||||
|             .collect(Collectors.toList()); |         // .toList(); | ||||||
|         List<DiagnosisTreatmentInitDto.diseaseTreatmentCategory> diseaseTreatmentCategories = new ArrayList<>(); |         // List<DiagnosisTreatmentInitDto.diseaseTreatmentCategory> diseaseTreatmentCategories = new ArrayList<>(); | ||||||
|         // |         // | ||||||
|         // //获取目录分类 |         // //获取目录分类 | ||||||
|         // DiagnosisTreatmentInitDto.diseaseTreatmentCategory diseaseTreatmentCategory = |         // DiagnosisTreatmentInitDto.diseaseTreatmentCategory diseaseTreatmentCategory = | ||||||
| @@ -233,10 +241,10 @@ public class DiagTreatMAppServiceImpl implements IDiagTreatMAppService { | |||||||
|         activityDefinition.setWbStr(ChineseConvertUtils.toWBFirstLetter(activityDefinition.getName())); |         activityDefinition.setWbStr(ChineseConvertUtils.toWBFirstLetter(activityDefinition.getName())); | ||||||
|  |  | ||||||
|         // 更新诊疗信息 |         // 更新诊疗信息 | ||||||
|         if (iActivityDefinitionService.updateById(activityDefinition)) { |         if (activityDefinitionService.updateById(activityDefinition)) { | ||||||
|             // 调用医保目录对照接口 |             // 调用医保目录对照接口 | ||||||
|             String ybSwitch = SecurityUtils.getLoginUser().getOptionJson().getString(CommonConstants.Option.YB_SWITCH); // 医保开关 |             String ybSwitch = SecurityUtils.getLoginUser().getOptionJson().getString(CommonConstants.Option.YB_SWITCH); // 医保开关 | ||||||
|             if (Whether.YES.getCode().equals(ybSwitch)  && StringUtils.isNotEmpty(activityDefinition.getYbNo()) ) { |             if (Whether.YES.getCode().equals(ybSwitch) && StringUtils.isNotEmpty(activityDefinition.getYbNo())) { | ||||||
|                 R<?> r = ybService.directoryCheck(CommonConstants.TableName.WOR_ACTIVITY_DEFINITION, |                 R<?> r = ybService.directoryCheck(CommonConstants.TableName.WOR_ACTIVITY_DEFINITION, | ||||||
|                     activityDefinition.getId()); |                     activityDefinition.getId()); | ||||||
|                 if (200 != r.getCode()) { |                 if (200 != r.getCode()) { | ||||||
| @@ -294,7 +302,7 @@ public class DiagTreatMAppServiceImpl implements IDiagTreatMAppService { | |||||||
|         iOperationRecordService.addIdsOperationRecord(DbOpType.STOP.getCode(), |         iOperationRecordService.addIdsOperationRecord(DbOpType.STOP.getCode(), | ||||||
|             CommonConstants.TableName.WOR_ACTIVITY_DEFINITION, ids); |             CommonConstants.TableName.WOR_ACTIVITY_DEFINITION, ids); | ||||||
|         // 更新诊疗信息 |         // 更新诊疗信息 | ||||||
|         return iActivityDefinitionService.updateBatchById(ActivityDefinitionList) |         return activityDefinitionService.updateBatchById(ActivityDefinitionList) | ||||||
|             ? R.ok(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00002, new Object[] {"诊疗目录"})) |             ? R.ok(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00002, new Object[] {"诊疗目录"})) | ||||||
|             : R.fail(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00007, null)); |             : R.fail(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00007, null)); | ||||||
|  |  | ||||||
| @@ -322,7 +330,7 @@ public class DiagTreatMAppServiceImpl implements IDiagTreatMAppService { | |||||||
|         iOperationRecordService.addIdsOperationRecord(DbOpType.START.getCode(), |         iOperationRecordService.addIdsOperationRecord(DbOpType.START.getCode(), | ||||||
|             CommonConstants.TableName.WOR_ACTIVITY_DEFINITION, ids); |             CommonConstants.TableName.WOR_ACTIVITY_DEFINITION, ids); | ||||||
|         // 更新诊疗信息 |         // 更新诊疗信息 | ||||||
|         return iActivityDefinitionService.updateBatchById(ActivityDefinitionList) |         return activityDefinitionService.updateBatchById(ActivityDefinitionList) | ||||||
|             ? R.ok(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00002, new Object[] {"诊疗目录"})) |             ? R.ok(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00002, new Object[] {"诊疗目录"})) | ||||||
|             : R.fail(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00007, null)); |             : R.fail(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00007, null)); | ||||||
|  |  | ||||||
| @@ -355,10 +363,10 @@ public class DiagTreatMAppServiceImpl implements IDiagTreatMAppService { | |||||||
|  |  | ||||||
|         // 新增外来诊疗目录 |         // 新增外来诊疗目录 | ||||||
|         activityDefinition.setStatusEnum(PublicationStatus.ACTIVE.getValue()); |         activityDefinition.setStatusEnum(PublicationStatus.ACTIVE.getValue()); | ||||||
|         if (iActivityDefinitionService.addDiagnosisTreatment(activityDefinition)) { |         if (activityDefinitionService.addDiagnosisTreatment(activityDefinition)) { | ||||||
|             // 调用医保目录对照接口 |             // 调用医保目录对照接口 | ||||||
|             String ybSwitch = SecurityUtils.getLoginUser().getOptionJson().getString(CommonConstants.Option.YB_SWITCH); // 医保开关 |             String ybSwitch = SecurityUtils.getLoginUser().getOptionJson().getString(CommonConstants.Option.YB_SWITCH); // 医保开关 | ||||||
|             if (Whether.YES.getCode().equals(ybSwitch)  && StringUtils.isNotEmpty(activityDefinition.getYbNo()) ) { |             if (Whether.YES.getCode().equals(ybSwitch) && StringUtils.isNotEmpty(activityDefinition.getYbNo())) { | ||||||
|                 R<?> r = ybService.directoryCheck(CommonConstants.TableName.WOR_ACTIVITY_DEFINITION, |                 R<?> r = ybService.directoryCheck(CommonConstants.TableName.WOR_ACTIVITY_DEFINITION, | ||||||
|                     activityDefinition.getId()); |                     activityDefinition.getId()); | ||||||
|                 if (200 != r.getCode()) { |                 if (200 != r.getCode()) { | ||||||
| @@ -387,4 +395,169 @@ public class DiagTreatMAppServiceImpl implements IDiagTreatMAppService { | |||||||
|  |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 导入诊疗目录 | ||||||
|  |      * | ||||||
|  |      * @param file 文件 | ||||||
|  |      * @return 结果 | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public R<?> importData(MultipartFile file) { | ||||||
|  |         // 读取文件 | ||||||
|  |         R<List<DiagnosisTreatmentImportDto>> readResult = | ||||||
|  |             CommonUtil.readImportedExcelFile(file, DiagnosisTreatmentImportDto.class); | ||||||
|  |         if (R.SUCCESS != readResult.getCode()) { | ||||||
|  |             return readResult; | ||||||
|  |         } | ||||||
|  |         List<DiagnosisTreatmentImportDto> importDtoList = readResult.getData(); | ||||||
|  |         // 导入信息校验 | ||||||
|  |         R<?> validateResult = validateImportDtoList(importDtoList); | ||||||
|  |         if (R.SUCCESS != validateResult.getCode()) { | ||||||
|  |             return validateResult; | ||||||
|  |         } | ||||||
|  |         // 查询机构ID供后续使用 | ||||||
|  |         Long orgId = SecurityUtils.getLoginUser().getOrgId(); | ||||||
|  |         // 创建表数据 | ||||||
|  |         for (DiagnosisTreatmentImportDto importDto : importDtoList) { | ||||||
|  |             // 创建诊疗定义 | ||||||
|  |             ActivityDefinition activityDefinition = createActivityDefinitionEntity(importDto, orgId); | ||||||
|  |             activityDefinitionService.save(activityDefinition); | ||||||
|  |             // 创建费用定价和详情 | ||||||
|  |             chargeItemDefinitionService.addChargeItemDefinitionAndDetail(importDto.getName(), importDto.getTypeCode(), | ||||||
|  |                 importDto.getYbType(), importDto.getPermittedUnitCode(), null, importDto.getRetailPrice(), | ||||||
|  |                 importDto.getMaximumRetailPrice(), orgId, CommonConstants.TableName.WOR_ACTIVITY_DEFINITION, | ||||||
|  |                 activityDefinition.getId()); | ||||||
|  |         } | ||||||
|  |         return R.ok(null, "导入成功!"); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 获取导入模板 | ||||||
|  |      * | ||||||
|  |      * @param response 响应 | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public void importTemplate(HttpServletResponse response) { | ||||||
|  |         ExcelUtil<DiagnosisTreatmentImportDto> util = new ExcelUtil<>(DiagnosisTreatmentImportDto.class); | ||||||
|  |         util.importTemplateExcel(response, "诊疗目录数据"); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 导入信息校验 | ||||||
|  |      * | ||||||
|  |      * @param importDtoList 器材目录导入数据列表 | ||||||
|  |      */ | ||||||
|  |     private R<?> validateImportDtoList(List<DiagnosisTreatmentImportDto> importDtoList) { | ||||||
|  |         // 字段校验(必填及数值类型) | ||||||
|  |         List<String> fieldValidateMsgList = new ArrayList<>(); | ||||||
|  |         for (int i = 0; i < importDtoList.size(); i++) { | ||||||
|  |             DiagnosisTreatmentImportDto importDto = importDtoList.get(i); | ||||||
|  |             importDto.setLineNumber(i + 2); | ||||||
|  |             List<String> lineValidateMsgList = new ArrayList<>(); | ||||||
|  |             if (StringUtils.isEmpty(importDto.getName())) { | ||||||
|  |                 lineValidateMsgList.add("诊疗名称必填"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getCategoryCode())) { | ||||||
|  |                 lineValidateMsgList.add("目录类别必填"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getPermittedUnitCode())) { | ||||||
|  |                 lineValidateMsgList.add("使用单位必填"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getYbFlag())) { | ||||||
|  |                 lineValidateMsgList.add("医保标记必填"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getYbMatchFlag())) { | ||||||
|  |                 lineValidateMsgList.add("医保对码标记必填"); | ||||||
|  |             } | ||||||
|  |             if (Whether.YES.getCode().equals(importDto.getYbMatchFlag()) && StringUtils.isEmpty(importDto.getYbNo())) { | ||||||
|  |                 lineValidateMsgList.add("医保对码时,医保编码必填"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getChrgitmLv())) { | ||||||
|  |                 lineValidateMsgList.add("医保等级必填"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getTypeCode())) { | ||||||
|  |                 lineValidateMsgList.add("财务类别必填"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getYbType())) { | ||||||
|  |                 lineValidateMsgList.add("医保费用类别必填"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getRetailPriceStr())) { | ||||||
|  |                 lineValidateMsgList.add("零售价必填"); | ||||||
|  |             } | ||||||
|  |             BigDecimal retailPrice; | ||||||
|  |             try { | ||||||
|  |                 retailPrice = new BigDecimal(importDto.getRetailPriceStr()); | ||||||
|  |                 importDto.setRetailPrice(retailPrice); | ||||||
|  |             } catch (Exception e) { | ||||||
|  |                 lineValidateMsgList.add("零售价应为数值类型"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getMaximumRetailPriceStr())) { | ||||||
|  |                 lineValidateMsgList.add("最高零售价必填"); | ||||||
|  |             } | ||||||
|  |             BigDecimal maximumRetailPrice; | ||||||
|  |             try { | ||||||
|  |                 maximumRetailPrice = new BigDecimal(importDto.getMaximumRetailPriceStr()); | ||||||
|  |                 importDto.setMaximumRetailPrice(maximumRetailPrice); | ||||||
|  |             } catch (Exception e) { | ||||||
|  |                 lineValidateMsgList.add("最高零售价应为数值类型"); | ||||||
|  |             } | ||||||
|  |             if (!lineValidateMsgList.isEmpty()) { | ||||||
|  |                 fieldValidateMsgList | ||||||
|  |                     .add("■ 第" + importDto.getLineNumber() + "行:" + String.join(",", lineValidateMsgList) + ";"); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         if (!fieldValidateMsgList.isEmpty()) { | ||||||
|  |             return R.fail("导入失败!诊疗信息填写有误:" + String.join(" ", fieldValidateMsgList)); | ||||||
|  |         } | ||||||
|  |         // 重复校验(文件行重复) | ||||||
|  |         List<String> lineRepeatedValidateMsgList = new ArrayList<>(); | ||||||
|  |         List<List<DiagnosisTreatmentImportDto>> importDtoGroupList = new ArrayList<>( | ||||||
|  |             importDtoList.stream().collect(Collectors.groupingBy(DiagnosisTreatmentImportDto::getName)).values()); | ||||||
|  |         for (List<DiagnosisTreatmentImportDto> importDtoGroup : importDtoGroupList) { | ||||||
|  |             if (importDtoGroup.size() > 1) { | ||||||
|  |                 lineRepeatedValidateMsgList.add("■ 第" | ||||||
|  |                     + importDtoGroup.stream().map(DiagnosisTreatmentImportDto::getLineNumber).sorted() | ||||||
|  |                         .map(Object::toString).collect(Collectors.joining(",")) | ||||||
|  |                     + "行的【" + importDtoGroup.get(0).getName() + "】重复;"); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         if (!lineRepeatedValidateMsgList.isEmpty()) { | ||||||
|  |             return R.fail("导入失败!文件中存在重复诊疗:" + String.join(" ", lineRepeatedValidateMsgList)); | ||||||
|  |         } | ||||||
|  |         // 重复校验(文件与数据库重复) | ||||||
|  |         List<String> dbRepeatedValidateMsgList = new ArrayList<>(); | ||||||
|  |         for (DiagnosisTreatmentImportDto importDto : importDtoList) { | ||||||
|  |             List<ActivityDefinition> deviceDefinitionList = activityDefinitionService.list( | ||||||
|  |                 new LambdaQueryWrapper<ActivityDefinition>().eq(ActivityDefinition::getName, importDto.getName())); | ||||||
|  |             if (!deviceDefinitionList.isEmpty()) { | ||||||
|  |                 dbRepeatedValidateMsgList | ||||||
|  |                     .add("■ 第" + importDto.getLineNumber() + "行的【" + importDto.getName() + "】在系统中已存在;"); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         if (!dbRepeatedValidateMsgList.isEmpty()) { | ||||||
|  |             return R.fail("导入失败!系统中存在重复诊疗:" + String.join(" ", dbRepeatedValidateMsgList)); | ||||||
|  |         } | ||||||
|  |         return R.ok(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 创建诊疗定义实体 | ||||||
|  |      * | ||||||
|  |      * @param importDto 器材目录导入Dto | ||||||
|  |      * @param orgId 机构ID | ||||||
|  |      * @return 诊疗定义实体 | ||||||
|  |      */ | ||||||
|  |     private ActivityDefinition createActivityDefinitionEntity(DiagnosisTreatmentImportDto importDto, Long orgId) { | ||||||
|  |         ActivityDefinition activityDefinition = new ActivityDefinition(); | ||||||
|  |         activityDefinition.setBusNo(assignSeqUtil.getSeq(AssignSeqEnum.ACTIVITY_DEFINITION_NUM.getPrefix(), 10)) | ||||||
|  |             .setName(importDto.getName()).setCategoryCode(importDto.getCategoryCode()) | ||||||
|  |             .setPyStr(ChineseConvertUtils.toPinyinFirstLetter(importDto.getName())) | ||||||
|  |             .setWbStr(ChineseConvertUtils.toWBFirstLetter(importDto.getName())) | ||||||
|  |             .setPermittedUnitCode(importDto.getPermittedUnitCode()).setOrgId(orgId) | ||||||
|  |             .setYbFlag(CommonUtil.tryParseInt(importDto.getYbFlag())).setYbNo(importDto.getYbNo()) | ||||||
|  |             .setYbMatchFlag(CommonUtil.tryParseInt(importDto.getYbMatchFlag())) | ||||||
|  |             .setStatusEnum(PublicationStatus.ACTIVE.getValue()) | ||||||
|  |             .setChrgitmLv(CommonUtil.tryParseInt(importDto.getChrgitmLv())); | ||||||
|  |         return activityDefinition; | ||||||
|  |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -63,13 +63,13 @@ public class DiseaseManageAppServiceImpl implements IDiseaseManageAppService { | |||||||
|         DiseaseManageInitDto diseaseManageInitDto = new DiseaseManageInitDto(); |         DiseaseManageInitDto diseaseManageInitDto = new DiseaseManageInitDto(); | ||||||
|         // 获取疾病目录种类 |         // 获取疾病目录种类 | ||||||
|         List<DiseaseManageInitDto.diseaseCategory> diseaseCategoryList = Stream.of(ConditionDefinitionSource.values()) |         List<DiseaseManageInitDto.diseaseCategory> diseaseCategoryList = Stream.of(ConditionDefinitionSource.values()) | ||||||
|             .map(status -> new DiseaseManageInitDto.diseaseCategory(status.getValue(), status.getInfo())) |                 .map(status -> new DiseaseManageInitDto.diseaseCategory(status.getValue(), status.getInfo())) | ||||||
|             .collect(Collectors.toList()); |                 .collect(Collectors.toList()); | ||||||
|         diseaseManageInitDto.setDiseaseCategoryList(diseaseCategoryList); |         diseaseManageInitDto.setDiseaseCategoryList(diseaseCategoryList); | ||||||
|         // 获取状态 |         // 获取状态 | ||||||
|         List<DiseaseManageInitDto.statusEnumOption> statusEnumOptions = Stream.of(PublicationStatus.values()) |         List<DiseaseManageInitDto.statusEnumOption> statusEnumOptions = Stream.of(PublicationStatus.values()) | ||||||
|             .map(status -> new DiseaseManageInitDto.statusEnumOption(status.getValue(), status.getInfo())) |                 .map(status -> new DiseaseManageInitDto.statusEnumOption(status.getValue(), status.getInfo())) | ||||||
|             .collect(Collectors.toList()); |                 .collect(Collectors.toList()); | ||||||
|         diseaseManageInitDto.setStatusFlagOptions(statusEnumOptions); |         diseaseManageInitDto.setStatusFlagOptions(statusEnumOptions); | ||||||
|  |  | ||||||
|         return R.ok(diseaseManageInitDto); |         return R.ok(diseaseManageInitDto); | ||||||
| @@ -79,22 +79,22 @@ public class DiseaseManageAppServiceImpl implements IDiseaseManageAppService { | |||||||
|      * 查询病种目录分页列表 |      * 查询病种目录分页列表 | ||||||
|      * |      * | ||||||
|      * @param diseaseManageSelParam 查询条件 |      * @param diseaseManageSelParam 查询条件 | ||||||
|      * @param searchKey 查询条件-模糊查询 |      * @param searchKey             查询条件-模糊查询 | ||||||
|      * @param pageNo 当前页码 |      * @param pageNo                当前页码 | ||||||
|      * @param pageSize 查询条数 |      * @param pageSize              查询条数 | ||||||
|      * @return |      * @return | ||||||
|      */ |      */ | ||||||
|     public R<?> getDiseaseList(DiseaseManageSelParam diseaseManageSelParam, String searchKey, Integer pageNo, |     public R<?> getDiseaseList(DiseaseManageSelParam diseaseManageSelParam, String searchKey, Integer pageNo, | ||||||
|         Integer pageSize, HttpServletRequest request) { |                                Integer pageSize, HttpServletRequest request) { | ||||||
|  |  | ||||||
|         // 构建查询条件 |         // 构建查询条件 | ||||||
|         QueryWrapper<ConditionDefinition> queryWrapper = HisQueryUtils.buildQueryWrapper(diseaseManageSelParam, |         QueryWrapper<ConditionDefinition> queryWrapper = HisQueryUtils.buildQueryWrapper(diseaseManageSelParam, | ||||||
|             searchKey, new HashSet<>(Arrays.asList("condition_code", "name", "py_str", "wb_str")), request); |                 searchKey, new HashSet<>(Arrays.asList("condition_code", "name", "py_str", "wb_str")), request); | ||||||
|         // 设置排序 |         // 设置排序 | ||||||
|         queryWrapper.orderByAsc("condition_code"); |         queryWrapper.orderByAsc("condition_code"); | ||||||
|         // 分页查询 |         // 分页查询 | ||||||
|         Page<DiseaseManageDto> diseasePage = |         Page<DiseaseManageDto> diseasePage = | ||||||
|             HisPageUtils.selectPage(conditionDefinitionMapper, queryWrapper, pageNo, pageSize, DiseaseManageDto.class); |                 HisPageUtils.selectPage(conditionDefinitionMapper, queryWrapper, pageNo, pageSize, DiseaseManageDto.class); | ||||||
|  |  | ||||||
|         diseasePage.getRecords().forEach(e -> { |         diseasePage.getRecords().forEach(e -> { | ||||||
|             // 医保对码枚举类回显赋值 |             // 医保对码枚举类回显赋值 | ||||||
| @@ -142,8 +142,8 @@ public class DiseaseManageAppServiceImpl implements IDiseaseManageAppService { | |||||||
|  |  | ||||||
|         // 更新病种信息 |         // 更新病种信息 | ||||||
|         return ConditionDefinitionService.updateById(conditionDefinition) |         return ConditionDefinitionService.updateById(conditionDefinition) | ||||||
|             ? R.ok(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00002, new Object[] {"疾病目录"})) |                 ? R.ok(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00002, new Object[]{"疾病目录"})) | ||||||
|             : R.fail(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00007, null)); |                 : R.fail(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00007, null)); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
| @@ -159,13 +159,13 @@ public class DiseaseManageAppServiceImpl implements IDiseaseManageAppService { | |||||||
|         for (Long detail : ids) { |         for (Long detail : ids) { | ||||||
|             ConditionDefinition conditionDefinition = new ConditionDefinition(); |             ConditionDefinition conditionDefinition = new ConditionDefinition(); | ||||||
|             conditionDefinition.setId(detail); |             conditionDefinition.setId(detail); | ||||||
|             conditionDefinition.setStatusEnum(PublicationStatus.ACTIVE.getValue()); |             conditionDefinition.setStatusEnum(PublicationStatus.RETIRED.getValue()); | ||||||
|             conditionDefinitionList.add(conditionDefinition); |             conditionDefinitionList.add(conditionDefinition); | ||||||
|         } |         } | ||||||
|         // 更新病种信息 |         // 更新病种信息 | ||||||
|         return ConditionDefinitionService.updateBatchById(conditionDefinitionList) |         return ConditionDefinitionService.updateBatchById(conditionDefinitionList) | ||||||
|             ? R.ok(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00002, new Object[] {"疾病目录"})) |                 ? R.ok(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00002, new Object[]{"疾病目录"})) | ||||||
|             : R.fail(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00007, null)); |                 : R.fail(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00007, null)); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
| @@ -186,8 +186,8 @@ public class DiseaseManageAppServiceImpl implements IDiseaseManageAppService { | |||||||
|         } |         } | ||||||
|         // 更新病种信息 |         // 更新病种信息 | ||||||
|         return ConditionDefinitionService.updateBatchById(conditionDefinitionList) |         return ConditionDefinitionService.updateBatchById(conditionDefinitionList) | ||||||
|             ? R.ok(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00002, new Object[] {"疾病目录"})) |                 ? R.ok(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00002, new Object[]{"疾病目录"})) | ||||||
|             : R.fail(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00007, null)); |                 : R.fail(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00007, null)); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
| @@ -210,8 +210,8 @@ public class DiseaseManageAppServiceImpl implements IDiseaseManageAppService { | |||||||
|         // 五笔码 |         // 五笔码 | ||||||
|         conditionDefinition.setWbStr(ChineseConvertUtils.toWBFirstLetter(conditionDefinition.getName())); |         conditionDefinition.setWbStr(ChineseConvertUtils.toWBFirstLetter(conditionDefinition.getName())); | ||||||
|         return ConditionDefinitionService.addDisease(conditionDefinition) |         return ConditionDefinitionService.addDisease(conditionDefinition) | ||||||
|             ? R.ok(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00002, new Object[] {"疾病目录"})) |                 ? R.ok(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00002, new Object[]{"疾病目录"})) | ||||||
|             : R.fail(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00008, null)); |                 : R.fail(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00008, null)); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -3,11 +3,8 @@ | |||||||
|  */ |  */ | ||||||
| package com.openhis.web.datadictionary.appservice.impl; | package com.openhis.web.datadictionary.appservice.impl; | ||||||
|  |  | ||||||
| import java.io.IOException; | import java.math.BigDecimal; | ||||||
| import java.util.ArrayList; | import java.util.*; | ||||||
| import java.util.Arrays; |  | ||||||
| import java.util.HashSet; |  | ||||||
| import java.util.List; |  | ||||||
| import java.util.stream.Collectors; | import java.util.stream.Collectors; | ||||||
| import java.util.stream.Stream; | import java.util.stream.Stream; | ||||||
|  |  | ||||||
| @@ -21,23 +18,27 @@ import org.springframework.web.bind.annotation.RequestBody; | |||||||
| import org.springframework.web.bind.annotation.RequestParam; | import org.springframework.web.bind.annotation.RequestParam; | ||||||
| import org.springframework.web.multipart.MultipartFile; | import org.springframework.web.multipart.MultipartFile; | ||||||
|  |  | ||||||
|  | import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | ||||||
| import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | ||||||
| import com.baomidou.mybatisplus.core.metadata.IPage; | import com.baomidou.mybatisplus.core.metadata.IPage; | ||||||
| import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||||
| import com.core.common.core.domain.R; | import com.core.common.core.domain.R; | ||||||
| import com.core.common.core.domain.entity.SysDictData; | import com.core.common.core.domain.entity.SysDictData; | ||||||
|  | import com.core.common.enums.DeleteFlag; | ||||||
| import com.core.common.utils.*; | import com.core.common.utils.*; | ||||||
| import com.core.common.utils.bean.BeanUtils; | import com.core.common.utils.bean.BeanUtils; | ||||||
| import com.core.common.utils.poi.ExcelUtil; | import com.core.common.utils.poi.ExcelUtil; | ||||||
| import com.core.system.service.ISysDictTypeService; | import com.core.system.service.ISysDictTypeService; | ||||||
| import com.openhis.administration.domain.ChargeItemDefinition; | import com.openhis.administration.domain.ChargeItemDefinition; | ||||||
|  | import com.openhis.administration.domain.Location; | ||||||
| import com.openhis.administration.domain.Supplier; | import com.openhis.administration.domain.Supplier; | ||||||
| import com.openhis.administration.service.IChargeItemDefDetailService; |  | ||||||
| import com.openhis.administration.service.IChargeItemDefinitionService; | import com.openhis.administration.service.IChargeItemDefinitionService; | ||||||
|  | import com.openhis.administration.service.ILocationService; | ||||||
| import com.openhis.administration.service.ISupplierService; | import com.openhis.administration.service.ISupplierService; | ||||||
| import com.openhis.common.constant.CommonConstants; | import com.openhis.common.constant.CommonConstants; | ||||||
| import com.openhis.common.constant.PromptMsgConstant; | import com.openhis.common.constant.PromptMsgConstant; | ||||||
| import com.openhis.common.enums.*; | import com.openhis.common.enums.*; | ||||||
|  | import com.openhis.common.utils.CommonUtil; | ||||||
| import com.openhis.common.utils.EnumUtils; | import com.openhis.common.utils.EnumUtils; | ||||||
| import com.openhis.common.utils.HisQueryUtils; | import com.openhis.common.utils.HisQueryUtils; | ||||||
| import com.openhis.medication.domain.Medication; | import com.openhis.medication.domain.Medication; | ||||||
| @@ -70,10 +71,10 @@ public class MedicationManageAppServiceImpl implements IMedicationManageAppServi | |||||||
|     private IMedicationDefinitionService medicationDefinitionService; |     private IMedicationDefinitionService medicationDefinitionService; | ||||||
|  |  | ||||||
|     @Autowired |     @Autowired | ||||||
|     IChargeItemDefinitionService chargeItemDefinitionService; |     private IChargeItemDefinitionService chargeItemDefinitionService; | ||||||
|  |  | ||||||
|     @Autowired |     @Autowired | ||||||
|     IChargeItemDefDetailService chargeItemDefDetailService; |     private ILocationService locationService; | ||||||
|  |  | ||||||
|     @Autowired |     @Autowired | ||||||
|     private MedicationManageSearchMapper medicationManageSearchMapper; |     private MedicationManageSearchMapper medicationManageSearchMapper; | ||||||
| @@ -246,16 +247,11 @@ public class MedicationManageAppServiceImpl implements IMedicationManageAppServi | |||||||
|      */ |      */ | ||||||
|     @Override |     @Override | ||||||
|     public R<?> editMedication(@Validated @RequestBody MedicationManageUpDto medicationManageUpDto) { |     public R<?> editMedication(@Validated @RequestBody MedicationManageUpDto medicationManageUpDto) { | ||||||
|         // // 校验是否可以编辑 |         // 校验是否可以编辑 | ||||||
|         // boolean result = supplyRequestService.verifyAbleEdit(medicationManageUpDto.getMedicationDefId()); |         boolean result = supplyRequestService.verifyAbleEdit(medicationManageUpDto.getMedicationDefId()); | ||||||
|         // if (result) { |         if (result) { | ||||||
|         // return R.fail("该药品已经发生过业务,不可编辑"); |             return R.fail("该药品已经发生过业务,不可编辑"); | ||||||
|         // } |         } | ||||||
|         // boolean result = medicationDispenseService.verifyAbleEdit(medicationManageUpDto.getMedicationDefId()); |  | ||||||
|         // if (result) { |  | ||||||
|         // return R.fail("该药品已经发生过业务,不可编辑"); |  | ||||||
|         // } |  | ||||||
|  |  | ||||||
|         // Todo:用Medication和medicationDefinition的domainservice来创造新的实例,根据业务需求,使用构造函数; |         // Todo:用Medication和medicationDefinition的domainservice来创造新的实例,根据业务需求,使用构造函数; | ||||||
|         // 如果小于5哥变量,就用基本类型传递,如果大于5哥,在domain层定义构造方法的入参 |         // 如果小于5哥变量,就用基本类型传递,如果大于5哥,在domain层定义构造方法的入参 | ||||||
|  |  | ||||||
| @@ -472,15 +468,40 @@ public class MedicationManageAppServiceImpl implements IMedicationManageAppServi | |||||||
|      */ |      */ | ||||||
|     @Override |     @Override | ||||||
|     public R<?> importData(MultipartFile file) { |     public R<?> importData(MultipartFile file) { | ||||||
|         ExcelUtil<MedicationImportDto> util = new ExcelUtil<>(MedicationImportDto.class); |         // 读取文件 | ||||||
|         List<MedicationImportDto> dtoList; |         R<List<MedicationImportDto>> readResult = CommonUtil.readImportedExcelFile(file, MedicationImportDto.class); | ||||||
|         try { |         if (R.SUCCESS != readResult.getCode()) { | ||||||
|             dtoList = util.importExcel(file.getInputStream()); |             return readResult; | ||||||
|         } catch (IOException e) { |  | ||||||
|             return R.fail("文件读取失败"); |  | ||||||
|         } |         } | ||||||
|  |         List<MedicationImportDto> importDtoList = readResult.getData(); | ||||||
|         return null; |         // 导入信息校验 | ||||||
|  |         R<?> validateResult = validateImportDtoList(importDtoList); | ||||||
|  |         if (R.SUCCESS != validateResult.getCode()) { | ||||||
|  |             return validateResult; | ||||||
|  |         } | ||||||
|  |         // 查询机构ID、位置信息供后续使用 | ||||||
|  |         Long orgId = SecurityUtils.getLoginUser().getOrgId(); | ||||||
|  |         List<Location> locationList = locationService.list(new LambdaQueryWrapper<Location>() | ||||||
|  |             .eq(Location::getDeleteFlag, DeleteFlag.NOT_DELETED.getCode()).orderByAsc(Location::getId)); | ||||||
|  |         Long defaultLocationId = locationList.stream().findFirst().orElse(new Location()).getId(); | ||||||
|  |         Map<String, List<Location>> locationNameMap = | ||||||
|  |             locationList.stream().collect(Collectors.groupingBy(Location::getName)); | ||||||
|  |         // 创建表数据 | ||||||
|  |         for (MedicationImportDto importDto : importDtoList) { | ||||||
|  |             // 创建药品定义 | ||||||
|  |             MedicationDefinition medicationDefinition = createMedicationDefinitionEntity(importDto); | ||||||
|  |             medicationDefinitionService.save(medicationDefinition); | ||||||
|  |             // 创建药品 | ||||||
|  |             Medication medication = | ||||||
|  |                 createMedicationEntity(importDto, medicationDefinition.getId(), defaultLocationId, locationNameMap); | ||||||
|  |             medicationService.save(medication); | ||||||
|  |             // 创建费用定价和详情 | ||||||
|  |             chargeItemDefinitionService.addChargeItemDefinitionAndDetail(importDto.getName(), importDto.getTypeCode(), | ||||||
|  |                 importDto.getYbType(), importDto.getUnitCode(), importDto.getPurchasePrice(), | ||||||
|  |                 importDto.getRetailPrice(), importDto.getMaximumRetailPrice(), orgId, | ||||||
|  |                 CommonConstants.TableName.MED_MEDICATION_DEFINITION, medicationDefinition.getId()); | ||||||
|  |         } | ||||||
|  |         return R.ok(null, "导入成功!"); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
| @@ -494,4 +515,307 @@ public class MedicationManageAppServiceImpl implements IMedicationManageAppServi | |||||||
|         util.importTemplateExcel(response, "药品目录数据"); |         util.importTemplateExcel(response, "药品目录数据"); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 导入信息校验 | ||||||
|  |      *  | ||||||
|  |      * @param importDtoList 药品目录导入数据列表 | ||||||
|  |      */ | ||||||
|  |     private R<?> validateImportDtoList(List<MedicationImportDto> importDtoList) { | ||||||
|  |         // 字段校验(必填及数值类型) | ||||||
|  |         List<String> fieldValidateMsgList = new ArrayList<>(); | ||||||
|  |         for (int i = 0; i < importDtoList.size(); i++) { | ||||||
|  |             MedicationImportDto importDto = importDtoList.get(i); | ||||||
|  |             importDto.setLineNumber(i + 2); | ||||||
|  |             List<String> lineValidateMsgList = new ArrayList<>(); | ||||||
|  |             if (StringUtils.isEmpty(importDto.getName())) { | ||||||
|  |                 lineValidateMsgList.add("药品名称必填"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getCategoryCode())) { | ||||||
|  |                 lineValidateMsgList.add("药品分类必填"); | ||||||
|  |             } | ||||||
|  |             if (Whether.YES.getCode().equals(importDto.getYbMatchFlag()) | ||||||
|  |                 && !MedCategoryCode.TRADITIONAL_CHINESE_MEDICINE.getValue().equals(importDto.getCategoryCode()) | ||||||
|  |                 && !MedCategoryCode.WESTERN_MEDICINE.getValue().equals(importDto.getCategoryCode()) | ||||||
|  |                 && !MedCategoryCode.CHINESE_HERBAL_MEDICINE.getValue().equals(importDto.getCategoryCode())) { | ||||||
|  |                 lineValidateMsgList.add("医保药的药品分类只能选择中成药、西药或中草药;"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getMerchandiseName())) { | ||||||
|  |                 lineValidateMsgList.add("商品名称必填"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getUnitCode())) { | ||||||
|  |                 lineValidateMsgList.add("药品单位必填"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getMinUnitCode())) { | ||||||
|  |                 lineValidateMsgList.add("最小单位必填"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getPartPercentStr())) { | ||||||
|  |                 lineValidateMsgList.add("拆零比必填"); | ||||||
|  |             } | ||||||
|  |             BigDecimal partPercent; | ||||||
|  |             try { | ||||||
|  |                 partPercent = new BigDecimal(importDto.getPartPercentStr()); | ||||||
|  |                 importDto.setPartPercent(partPercent); | ||||||
|  |             } catch (Exception e) { | ||||||
|  |                 lineValidateMsgList.add("拆零比应为数值类型"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getDoseFrom())) { | ||||||
|  |                 lineValidateMsgList.add("剂量形式必填"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getYbMatchFlag())) { | ||||||
|  |                 lineValidateMsgList.add("医保是否对码必填"); | ||||||
|  |             } | ||||||
|  |             if (Whether.YES.getCode().equals(importDto.getYbMatchFlag()) && StringUtils.isEmpty(importDto.getYbNo())) { | ||||||
|  |                 lineValidateMsgList.add("医保对码时,医保编码必填"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getSkinTestFlag())) { | ||||||
|  |                 lineValidateMsgList.add("是否皮试必填"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getInjectFlag())) { | ||||||
|  |                 lineValidateMsgList.add("是否为注射药物必填"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getRestrictedFlag())) { | ||||||
|  |                 lineValidateMsgList.add("是否限制使用必填"); | ||||||
|  |             } | ||||||
|  |             if (Whether.YES.getCode().equals(importDto.getRestrictedFlag()) | ||||||
|  |                 && StringUtils.isEmpty(importDto.getRestrictedScope())) { | ||||||
|  |                 lineValidateMsgList.add("限制使用时,限制使用范围必填"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getChildrenFlag())) { | ||||||
|  |                 lineValidateMsgList.add("儿童用药标志必填"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getPartAttributeEnum())) { | ||||||
|  |                 lineValidateMsgList.add("拆分属性必填"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getAntibioticFlag())) { | ||||||
|  |                 lineValidateMsgList.add("是否抗生素必填"); | ||||||
|  |             } | ||||||
|  |             if (Whether.YES.getCode().equals(importDto.getAntibioticFlag()) | ||||||
|  |                 && StringUtils.isEmpty(importDto.getAntibioticCode())) { | ||||||
|  |                 lineValidateMsgList.add("为抗生素时,抗生素分类必填"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getSelfFlag())) { | ||||||
|  |                 lineValidateMsgList.add("是否自制必填"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getBasicFlag())) { | ||||||
|  |                 lineValidateMsgList.add("基药标识必填"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getManufacturerText())) { | ||||||
|  |                 lineValidateMsgList.add("生产厂商文本必填"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getThoPartAttributeEnum())) { | ||||||
|  |                 lineValidateMsgList.add("住院临时医嘱拆分属性必填"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getUnitConversionRatioStr())) { | ||||||
|  |                 lineValidateMsgList.add("剂量单位换算比必填"); | ||||||
|  |             } | ||||||
|  |             BigDecimal unitConversionRatio; | ||||||
|  |             try { | ||||||
|  |                 unitConversionRatio = new BigDecimal(importDto.getUnitConversionRatioStr()); | ||||||
|  |                 importDto.setUnitConversionRatio(unitConversionRatio); | ||||||
|  |             } catch (Exception e) { | ||||||
|  |                 lineValidateMsgList.add("剂量单位换算比应为数值类型"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getChrgitmLv())) { | ||||||
|  |                 lineValidateMsgList.add("医保等级必填"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getRxFlag())) { | ||||||
|  |                 lineValidateMsgList.add("处方标志必填"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getItemMinQuantityStr())) { | ||||||
|  |                 lineValidateMsgList.add("最小库存警戒数量(常规单位)必填"); | ||||||
|  |             } | ||||||
|  |             BigDecimal itemMinQuantity; | ||||||
|  |             try { | ||||||
|  |                 itemMinQuantity = new BigDecimal(importDto.getItemMinQuantityStr()); | ||||||
|  |                 importDto.setItemMinQuantity(itemMinQuantity); | ||||||
|  |             } catch (Exception e) { | ||||||
|  |                 lineValidateMsgList.add("最小库存警戒数量(常规单位)应为数值类型"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getItemMaxQuantityStr())) { | ||||||
|  |                 lineValidateMsgList.add("最大库存警戒数量(常规单位)必填"); | ||||||
|  |             } | ||||||
|  |             BigDecimal itemMaxQuantity; | ||||||
|  |             try { | ||||||
|  |                 itemMaxQuantity = new BigDecimal(importDto.getItemMaxQuantityStr()); | ||||||
|  |                 importDto.setItemMaxQuantity(itemMaxQuantity); | ||||||
|  |             } catch (Exception e) { | ||||||
|  |                 lineValidateMsgList.add("最大库存警戒数量(常规单位)应为数值类型"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getLocationName())) { | ||||||
|  |                 lineValidateMsgList.add("所在位置名称必填"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getTotalVolume())) { | ||||||
|  |                 lineValidateMsgList.add("规格必填"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isNotEmpty(importDto.getDoseStr())) { | ||||||
|  |                 BigDecimal dose; | ||||||
|  |                 try { | ||||||
|  |                     dose = new BigDecimal(importDto.getDoseStr()); | ||||||
|  |                     importDto.setDose(dose); | ||||||
|  |                 } catch (Exception e) { | ||||||
|  |                     lineValidateMsgList.add("单次剂量应为数值类型"); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isNotEmpty(importDto.getMaxUnitStr())) { | ||||||
|  |                 BigDecimal maxUnit; | ||||||
|  |                 try { | ||||||
|  |                     maxUnit = new BigDecimal(importDto.getMaxUnitStr()); | ||||||
|  |                     importDto.setMaxUnit(maxUnit); | ||||||
|  |                 } catch (Exception e) { | ||||||
|  |                     lineValidateMsgList.add("单次最大剂量应为数值类型"); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getTypeCode())) { | ||||||
|  |                 lineValidateMsgList.add("财务类别必填"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getYbType())) { | ||||||
|  |                 lineValidateMsgList.add("医保费用类别必填"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getPurchasePriceStr())) { | ||||||
|  |                 lineValidateMsgList.add("购入价必填"); | ||||||
|  |             } | ||||||
|  |             BigDecimal purchasePrice; | ||||||
|  |             try { | ||||||
|  |                 purchasePrice = new BigDecimal(importDto.getPurchasePriceStr()); | ||||||
|  |                 importDto.setPurchasePrice(purchasePrice); | ||||||
|  |             } catch (Exception e) { | ||||||
|  |                 lineValidateMsgList.add("购入价应为数值类型"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getRetailPriceStr())) { | ||||||
|  |                 lineValidateMsgList.add("零售价必填"); | ||||||
|  |             } | ||||||
|  |             BigDecimal retailPrice; | ||||||
|  |             try { | ||||||
|  |                 retailPrice = new BigDecimal(importDto.getRetailPriceStr()); | ||||||
|  |                 importDto.setRetailPrice(retailPrice); | ||||||
|  |             } catch (Exception e) { | ||||||
|  |                 lineValidateMsgList.add("零售价应为数值类型"); | ||||||
|  |             } | ||||||
|  |             if (StringUtils.isEmpty(importDto.getMaximumRetailPriceStr())) { | ||||||
|  |                 lineValidateMsgList.add("最高零售价必填"); | ||||||
|  |             } | ||||||
|  |             BigDecimal maximumRetailPrice; | ||||||
|  |             try { | ||||||
|  |                 maximumRetailPrice = new BigDecimal(importDto.getMaximumRetailPriceStr()); | ||||||
|  |                 importDto.setMaximumRetailPrice(maximumRetailPrice); | ||||||
|  |             } catch (Exception e) { | ||||||
|  |                 lineValidateMsgList.add("最高零售价应为数值类型"); | ||||||
|  |             } | ||||||
|  |             if (!lineValidateMsgList.isEmpty()) { | ||||||
|  |                 fieldValidateMsgList | ||||||
|  |                     .add("■ 第" + importDto.getLineNumber() + "行:" + String.join(",", lineValidateMsgList) + ";"); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         if (!fieldValidateMsgList.isEmpty()) { | ||||||
|  |             return R.fail("导入失败!药品信息填写有误:" + String.join(" ", fieldValidateMsgList)); | ||||||
|  |         } | ||||||
|  |         // 重复校验(文件行重复) | ||||||
|  |         List<String> lineRepeatedValidateMsgList = new ArrayList<>(); | ||||||
|  |         List<List<MedicationImportDto>> importDtoGroupList = new ArrayList<>(importDtoList.stream() | ||||||
|  |             .collect(Collectors.groupingBy(e -> e.getName() + e.getManufacturerText() + e.getTotalVolume())).values()); | ||||||
|  |         for (List<MedicationImportDto> importDtoGroup : importDtoGroupList) { | ||||||
|  |             if (importDtoGroup.size() > 1) { | ||||||
|  |                 lineRepeatedValidateMsgList | ||||||
|  |                     .add( | ||||||
|  |                         "■ 第" | ||||||
|  |                             + importDtoGroup.stream().map(MedicationImportDto::getLineNumber).sorted() | ||||||
|  |                                 .map(Object::toString).collect(Collectors.joining(",")) | ||||||
|  |                             + "行的【" + importDtoGroup.get(0).getName() + "】重复;"); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         if (!lineRepeatedValidateMsgList.isEmpty()) { | ||||||
|  |             return R.fail("导入失败!文件中存在重复药品:" + String.join(" ", lineRepeatedValidateMsgList)); | ||||||
|  |         } | ||||||
|  |         // 重复校验(文件与数据库重复) | ||||||
|  |         List<String> dbRepeatedValidateMsgList = new ArrayList<>(); | ||||||
|  |         for (MedicationImportDto importDto : importDtoList) { | ||||||
|  |             List<MedicationDefinition> medicationDefinitionList = medicationDefinitionService.list( | ||||||
|  |                 new LambdaQueryWrapper<MedicationDefinition>().eq(MedicationDefinition::getName, importDto.getName()) | ||||||
|  |                     .eq(MedicationDefinition::getManufacturerText, importDto.getManufacturerText())); | ||||||
|  |             if (!medicationDefinitionList.isEmpty()) { | ||||||
|  |                 List<Medication> medicationList = | ||||||
|  |                     medicationService.list(new LambdaQueryWrapper<Medication>() | ||||||
|  |                         .in(Medication::getMedicationDefId, | ||||||
|  |                             medicationDefinitionList.stream().map(MedicationDefinition::getId) | ||||||
|  |                                 .collect(Collectors.toList())) | ||||||
|  |                         .eq(Medication::getTotalVolume, importDto.getTotalVolume())); | ||||||
|  |                 if (!medicationList.isEmpty()) { | ||||||
|  |                     dbRepeatedValidateMsgList | ||||||
|  |                         .add("■ 第" + importDto.getLineNumber() + "行的【" + importDto.getName() + "】在系统中已存在;"); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         if (!dbRepeatedValidateMsgList.isEmpty()) { | ||||||
|  |             return R.fail("导入失败!系统中存在重复药品:" + String.join(" ", dbRepeatedValidateMsgList)); | ||||||
|  |         } | ||||||
|  |         return R.ok(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 创建药品定义实体 | ||||||
|  |      *  | ||||||
|  |      * @param importDto 药品目录导入Dto | ||||||
|  |      * @return 药品定义实体 | ||||||
|  |      */ | ||||||
|  |     private MedicationDefinition createMedicationDefinitionEntity(MedicationImportDto importDto) { | ||||||
|  |         MedicationDefinition medicationDefinition = new MedicationDefinition(); | ||||||
|  |         medicationDefinition.setName(importDto.getName()) | ||||||
|  |             .setBusNo(assignSeqUtil.getSeq(AssignSeqEnum.MEDICATION_NUM.getPrefix(), 10)).setDomainEnum(1) | ||||||
|  |             .setVersion(importDto.getVersion()).setNameEn(importDto.getNameEn()) | ||||||
|  |             .setPyStr(ChineseConvertUtils.toPinyinFirstLetter(importDto.getName())) | ||||||
|  |             .setWbStr(ChineseConvertUtils.toWBFirstLetter(importDto.getName())) | ||||||
|  |             .setCategoryCode(importDto.getCategoryCode()).setMerchandiseName(importDto.getMerchandiseName()) | ||||||
|  |             .setMerchandisePyStr(ChineseConvertUtils.toPinyinFirstLetter(importDto.getMerchandiseName())) | ||||||
|  |             .setMerchandiseWbStr(ChineseConvertUtils.toPinyinFirstLetter(importDto.getMerchandiseName())) | ||||||
|  |             .setUnitCode(importDto.getUnitCode()).setMinUnitCode(importDto.getMinUnitCode()) | ||||||
|  |             .setPartPercent(importDto.getPartPercent()).setDoseFrom(CommonUtil.tryParseInt(importDto.getDoseFrom())) | ||||||
|  |             .setApprovalNumber(importDto.getApprovalNumber()) | ||||||
|  |             .setYbMatchFlag(CommonUtil.tryParseInt(importDto.getYbMatchFlag())).setYbNo(importDto.getYbNo()) | ||||||
|  |             .setPharmacologyCategoryCode("1").setSkinTestFlag(CommonUtil.tryParseInt(importDto.getSkinTestFlag())) | ||||||
|  |             .setInjectFlag(CommonUtil.tryParseInt(importDto.getInjectFlag())) | ||||||
|  |             .setManufacturerText(importDto.getManufacturerText()) | ||||||
|  |             .setRestrictedFlag(CommonUtil.tryParseInt(importDto.getRestrictedFlag())) | ||||||
|  |             .setRestrictedScope(importDto.getRestrictedScope()).setActiveFlag(Whether.YES.getValue()) | ||||||
|  |             .setChildrenFlag(CommonUtil.tryParseInt(importDto.getChildrenFlag())) | ||||||
|  |             .setNationalDrugCode(importDto.getNationalDrugCode()) | ||||||
|  |             .setPartAttributeEnum(CommonUtil.tryParseInt(importDto.getPartAttributeEnum())) | ||||||
|  |             .setAntibioticCode(importDto.getAntibioticCode()) | ||||||
|  |             .setSelfFlag(CommonUtil.tryParseInt(importDto.getSelfFlag())) | ||||||
|  |             .setAntibioticFlag(CommonUtil.tryParseInt(importDto.getAntibioticFlag())) | ||||||
|  |             .setBasicFlag(CommonUtil.tryParseInt(importDto.getBasicFlag())) | ||||||
|  |             .setThoPartAttributeEnum(CommonUtil.tryParseInt(importDto.getThoPartAttributeEnum())) | ||||||
|  |             .setUnitConversionRatio(importDto.getUnitConversionRatio()) | ||||||
|  |             .setChrgitmLv(CommonUtil.tryParseInt(importDto.getChrgitmLv())) | ||||||
|  |             .setRxFlag(CommonUtil.tryParseInt(importDto.getRxFlag())).setItemMinQuantity(importDto.getItemMinQuantity()) | ||||||
|  |             .setItemMaxQuantity(importDto.getItemMaxQuantity()); | ||||||
|  |         return medicationDefinition; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 创建药品基本实体 | ||||||
|  |      *  | ||||||
|  |      * @param importDto 药品目录导入Dto | ||||||
|  |      * @param medicationDefId 药品定义ID | ||||||
|  |      * @param defaultLocationId 默认位置ID | ||||||
|  |      * @param locationNameMap 位置名称匹配分组Map | ||||||
|  |      * @return 药品基本实体 | ||||||
|  |      */ | ||||||
|  |     private Medication createMedicationEntity(MedicationImportDto importDto, Long medicationDefId, | ||||||
|  |         Long defaultLocationId, Map<String, List<Location>> locationNameMap) { | ||||||
|  |         Medication medication = new Medication(); | ||||||
|  |         // 根据输入的所在位置名称获取位置ID | ||||||
|  |         List<Location> mapLocationList = locationNameMap.get(importDto.getLocationName()); | ||||||
|  |         if (mapLocationList == null || mapLocationList.isEmpty()) { | ||||||
|  |             medication.setLocationId(defaultLocationId); | ||||||
|  |         } else { | ||||||
|  |             medication.setLocationId(mapLocationList.get(0).getId()); | ||||||
|  |         } | ||||||
|  |         medication.setMedicationDefId(medicationDefId).setStatusEnum(PublicationStatus.ACTIVE.getValue()) | ||||||
|  |             .setDoseFormCode(importDto.getDoseFrom()).setTotalVolume(importDto.getTotalVolume()) | ||||||
|  |             .setActiveFlag(Whether.YES.getValue()).setMethodCode(importDto.getMethodCode()) | ||||||
|  |             .setRateCode(importDto.getRateCode()).setDose(importDto.getDose()) | ||||||
|  |             .setDoseUnitCode(importDto.getDoseUnitCode()).setMaxUnit(importDto.getMaxUnit()); | ||||||
|  |         return medication; | ||||||
|  |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -3,10 +3,12 @@ package com.openhis.web.datadictionary.controller; | |||||||
| import java.util.List; | import java.util.List; | ||||||
|  |  | ||||||
| import javax.servlet.http.HttpServletRequest; | import javax.servlet.http.HttpServletRequest; | ||||||
|  | import javax.servlet.http.HttpServletResponse; | ||||||
|  |  | ||||||
| import org.springframework.beans.factory.annotation.Autowired; | import org.springframework.beans.factory.annotation.Autowired; | ||||||
| import org.springframework.validation.annotation.Validated; | import org.springframework.validation.annotation.Validated; | ||||||
| import org.springframework.web.bind.annotation.*; | import org.springframework.web.bind.annotation.*; | ||||||
|  | import org.springframework.web.multipart.MultipartFile; | ||||||
|  |  | ||||||
| import com.core.common.core.domain.R; | import com.core.common.core.domain.R; | ||||||
| import com.openhis.web.datadictionary.appservice.IDeviceManageAppService; | import com.openhis.web.datadictionary.appservice.IDeviceManageAppService; | ||||||
| @@ -138,4 +140,25 @@ public class DeviceManageController { | |||||||
|     public R<?> exportDevice(@RequestBody DeviceManageDto DeviceManageDto) { |     public R<?> exportDevice(@RequestBody DeviceManageDto DeviceManageDto) { | ||||||
|         return null; |         return null; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 导入器材目录 | ||||||
|  |      * | ||||||
|  |      * @param file 文件 | ||||||
|  |      * @return 结果 | ||||||
|  |      */ | ||||||
|  |     @PostMapping("/import-data") | ||||||
|  |     public R<?> importData(MultipartFile file) { | ||||||
|  |         return deviceManageAppService.importData(file); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 获取导入模板 | ||||||
|  |      * | ||||||
|  |      * @param response 响应 | ||||||
|  |      */ | ||||||
|  |     @PostMapping("/import-template") | ||||||
|  |     public void importTemplate(HttpServletResponse response) { | ||||||
|  |         deviceManageAppService.importTemplate(response); | ||||||
|  |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -3,10 +3,12 @@ package com.openhis.web.datadictionary.controller; | |||||||
| import java.util.List; | import java.util.List; | ||||||
|  |  | ||||||
| import javax.servlet.http.HttpServletRequest; | import javax.servlet.http.HttpServletRequest; | ||||||
|  | import javax.servlet.http.HttpServletResponse; | ||||||
|  |  | ||||||
| import org.springframework.beans.factory.annotation.Autowired; | import org.springframework.beans.factory.annotation.Autowired; | ||||||
| import org.springframework.validation.annotation.Validated; | import org.springframework.validation.annotation.Validated; | ||||||
| import org.springframework.web.bind.annotation.*; | import org.springframework.web.bind.annotation.*; | ||||||
|  | import org.springframework.web.multipart.MultipartFile; | ||||||
|  |  | ||||||
| import com.core.common.core.domain.R; | import com.core.common.core.domain.R; | ||||||
| import com.openhis.web.datadictionary.appservice.IDiagTreatMAppService; | import com.openhis.web.datadictionary.appservice.IDiagTreatMAppService; | ||||||
| @@ -56,8 +58,8 @@ public class DiagnosisTreatmentController { | |||||||
|         @RequestParam(value = "searchKey", defaultValue = "") String searchKey, |         @RequestParam(value = "searchKey", defaultValue = "") String searchKey, | ||||||
|         @RequestParam(value = "pageNo", defaultValue = "1") Integer pageNo, |         @RequestParam(value = "pageNo", defaultValue = "1") Integer pageNo, | ||||||
|         @RequestParam(value = "pageSize", defaultValue = "10") Integer pageSize, HttpServletRequest request) { |         @RequestParam(value = "pageSize", defaultValue = "10") Integer pageSize, HttpServletRequest request) { | ||||||
|         return diagTreatMAppService.getDiseaseTreatmentPage(DiagnosisTreatmentSelParam, searchKey, pageNo, |         return diagTreatMAppService.getDiseaseTreatmentPage(DiagnosisTreatmentSelParam, searchKey, pageNo, pageSize, | ||||||
|             pageSize, request); |             request); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
| @@ -136,4 +138,25 @@ public class DiagnosisTreatmentController { | |||||||
|     public R<?> exportDiseaseTreatment(@RequestBody DiagnosisTreatmentDto diagnosisTreatmentDto) { |     public R<?> exportDiseaseTreatment(@RequestBody DiagnosisTreatmentDto diagnosisTreatmentDto) { | ||||||
|         return null; |         return null; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 导入诊疗目录 | ||||||
|  |      * | ||||||
|  |      * @param file 文件 | ||||||
|  |      * @return 结果 | ||||||
|  |      */ | ||||||
|  |     @PostMapping("/import-data") | ||||||
|  |     public R<?> importData(MultipartFile file) { | ||||||
|  |         return diagTreatMAppService.importData(file); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 获取导入模板 | ||||||
|  |      * | ||||||
|  |      * @param response 响应 | ||||||
|  |      */ | ||||||
|  |     @PostMapping("/import-template") | ||||||
|  |     public void importTemplate(HttpServletResponse response) { | ||||||
|  |         diagTreatMAppService.importTemplate(response); | ||||||
|  |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -20,7 +20,7 @@ import lombok.AllArgsConstructor; | |||||||
| import lombok.extern.slf4j.Slf4j; | import lombok.extern.slf4j.Slf4j; | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * TODO:病种目录 |  * 病种目录 | ||||||
|  * |  * | ||||||
|  * @author lpt |  * @author lpt | ||||||
|  * @date 2025-02-20 |  * @date 2025-02-20 | ||||||
|   | |||||||
| @@ -6,6 +6,8 @@ import com.fasterxml.jackson.databind.ser.std.ToStringSerializer; | |||||||
| import lombok.Data; | import lombok.Data; | ||||||
| import lombok.experimental.Accessors; | import lombok.experimental.Accessors; | ||||||
|  |  | ||||||
|  | import java.math.BigDecimal; | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * 诊疗子项JSON |  * 诊疗子项JSON | ||||||
|  */ |  */ | ||||||
| @@ -20,6 +22,6 @@ public class ActivityChildJsonDto { | |||||||
|     /** |     /** | ||||||
|      * 子项请求数量 |      * 子项请求数量 | ||||||
|      */ |      */ | ||||||
|     private Integer childrenRequestNum; |     private BigDecimal childrenRequestNum; | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -0,0 +1,134 @@ | |||||||
|  | package com.openhis.web.datadictionary.dto; | ||||||
|  |  | ||||||
|  | import java.math.BigDecimal; | ||||||
|  |  | ||||||
|  | import com.core.common.annotation.Excel; | ||||||
|  |  | ||||||
|  | import lombok.Data; | ||||||
|  | import lombok.experimental.Accessors; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 器材目录导入Dto | ||||||
|  |  * | ||||||
|  |  * @author GuoRui | ||||||
|  |  * @date 2025-09-24 | ||||||
|  |  */ | ||||||
|  | @Data | ||||||
|  | @Accessors(chain = true) | ||||||
|  | public class DeviceImportDto { | ||||||
|  |  | ||||||
|  |     /** 行号 */ | ||||||
|  |     private Integer lineNumber; | ||||||
|  |  | ||||||
|  |     // ---------------------- 器材定义 adm_device_definition ------------------------------------- | ||||||
|  |  | ||||||
|  |     /** 器材名称 */ | ||||||
|  |     @Excel(name = "器材名称", prompt = "必填") | ||||||
|  |     private String name; | ||||||
|  |  | ||||||
|  |     /** 器材分类 */ | ||||||
|  |     @Excel(name = "器材分类", prompt = "必填", dictType = "device_category_code", comboReadDict = true) | ||||||
|  |     private String categoryCode; | ||||||
|  |  | ||||||
|  |     /** 包装单位 */ | ||||||
|  |     @Excel(name = "包装单位", prompt = "必填", dictType = "unit_code", comboReadDict = true) | ||||||
|  |     private String unitCode; | ||||||
|  |  | ||||||
|  |     /** 包装规格 */ | ||||||
|  |     @Excel(name = "包装规格", prompt = "必填") | ||||||
|  |     private String size; | ||||||
|  |  | ||||||
|  |     /** 最小库存警戒数量(常规单位) */ | ||||||
|  |     @Excel(name = "最小库存警戒数量(常规单位)", width = 25, prompt = "必填,数值类型") | ||||||
|  |     private String itemMinQuantityStr; | ||||||
|  |     private BigDecimal itemMinQuantity; | ||||||
|  |  | ||||||
|  |     /** 最大库存警戒数量(常规单位) */ | ||||||
|  |     @Excel(name = "最大库存警戒数量(常规单位)", width = 25, prompt = "必填,数值类型") | ||||||
|  |     private String itemMaxQuantityStr; | ||||||
|  |     private BigDecimal itemMaxQuantity; | ||||||
|  |  | ||||||
|  |     /** 拆零比 */ | ||||||
|  |     @Excel(name = "拆零比", prompt = "必填,数值类型") | ||||||
|  |     private String partPercentStr; | ||||||
|  |     private BigDecimal partPercent; | ||||||
|  |  | ||||||
|  |     /** 最小使用单位 */ | ||||||
|  |     @Excel(name = "最小使用单位", prompt = "必填", dictType = "unit_code", comboReadDict = true) | ||||||
|  |     private String minUnitCode; | ||||||
|  |  | ||||||
|  |     /** 所在位置名称(locationId) */ | ||||||
|  |     @Excel(name = "所在位置名称", prompt = "必填") | ||||||
|  |     private String locationName; | ||||||
|  |  | ||||||
|  |     /** 高值器材标志 */ | ||||||
|  |     @Excel(name = "高值器材标志", prompt = "必填", readConverterExp = "0=否,1=是", combo = "否,是") | ||||||
|  |     private String hvcmFlag; | ||||||
|  |  | ||||||
|  |     /** 销售单位 */ | ||||||
|  |     @Excel(name = "销售单位", prompt = "必填", dictType = "unit_code", comboReadDict = true) | ||||||
|  |     private String salesUnitCode; | ||||||
|  |  | ||||||
|  |     /** 批准文号 */ | ||||||
|  |     @Excel(name = "批准文号") | ||||||
|  |     private String approvalNumber; | ||||||
|  |  | ||||||
|  |     /** 医保标记 */ | ||||||
|  |     @Excel(name = "医保标记", prompt = "必填", readConverterExp = "0=否,1=是", combo = "否,是") | ||||||
|  |     private String ybFlag; | ||||||
|  |  | ||||||
|  |     /** 医保对码标记 */ | ||||||
|  |     @Excel(name = "医保对码标记", prompt = "必填", readConverterExp = "0=否,1=是", combo = "否,是") | ||||||
|  |     private String ybMatchFlag; | ||||||
|  |  | ||||||
|  |     /** 医保编码 */ | ||||||
|  |     @Excel(name = "医保编码", prompt = "医保对码时必填") | ||||||
|  |     private String ybNo; | ||||||
|  |  | ||||||
|  |     /** 医药机构目录编码 */ | ||||||
|  |     @Excel(name = "医药机构目录编码") | ||||||
|  |     private String ybOrgNo; | ||||||
|  |  | ||||||
|  |     /** 医保等级 */ | ||||||
|  |     @Excel(name = "医保等级", prompt = "必填", dictType = "chrgitm_lv", comboReadDict = true) | ||||||
|  |     private String chrgitmLv; | ||||||
|  |  | ||||||
|  |     /** 生产厂家 */ | ||||||
|  |     @Excel(name = "生产厂家文本", prompt = "必填") | ||||||
|  |     private String manufacturerText; | ||||||
|  |  | ||||||
|  |     /** 过敏标记 */ | ||||||
|  |     @Excel(name = "过敏标记", prompt = "必填", readConverterExp = "0=否,1=是", combo = "否,是") | ||||||
|  |     private String allergenFlag; | ||||||
|  |  | ||||||
|  |     /** 处方标志 */ | ||||||
|  |     @Excel(name = "处方标志", prompt = "必填", readConverterExp = "0=否,1=是", combo = "否,是") | ||||||
|  |     private String rxFlag; | ||||||
|  |  | ||||||
|  |     // ---------------------- 费用定价 adm_charge_item_definition ---------------------------------------------- | ||||||
|  |  | ||||||
|  |     /** 财务类别 */ | ||||||
|  |     @Excel(name = "财务类别", prompt = "必填", dictType = "fin_type_code", comboReadDict = true) | ||||||
|  |     private String typeCode; | ||||||
|  |  | ||||||
|  |     /** 医保费用类别 */ | ||||||
|  |     @Excel(name = "医保费用类别", prompt = "必填", dictType = "med_chrgitm_type", comboReadDict = true) | ||||||
|  |     private String ybType; | ||||||
|  |  | ||||||
|  |     // ---------------------- 费用定价子表 adm_charge_item_def_detail ---------------------------------------------- | ||||||
|  |  | ||||||
|  |     /** 购入价 */ | ||||||
|  |     @Excel(name = "购入价", prompt = "必填,数值类型") | ||||||
|  |     private String purchasePriceStr; | ||||||
|  |     private BigDecimal purchasePrice; | ||||||
|  |  | ||||||
|  |     /** 零售价 */ | ||||||
|  |     @Excel(name = "零售价", prompt = "必填,数值类型") | ||||||
|  |     private String retailPriceStr; | ||||||
|  |     private BigDecimal retailPrice; | ||||||
|  |  | ||||||
|  |     /** 最高零售价 */ | ||||||
|  |     @Excel(name = "最高零售价", prompt = "必填,数值类型") | ||||||
|  |     private String maximumRetailPriceStr; | ||||||
|  |     private BigDecimal maximumRetailPrice; | ||||||
|  | } | ||||||
| @@ -0,0 +1,75 @@ | |||||||
|  | package com.openhis.web.datadictionary.dto; | ||||||
|  |  | ||||||
|  | import java.math.BigDecimal; | ||||||
|  |  | ||||||
|  | import com.core.common.annotation.Excel; | ||||||
|  |  | ||||||
|  | import lombok.Data; | ||||||
|  | import lombok.experimental.Accessors; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 诊疗目录导入Dto | ||||||
|  |  * | ||||||
|  |  * @author GuoRui | ||||||
|  |  * @date 2025-09-29 | ||||||
|  |  */ | ||||||
|  | @Data | ||||||
|  | @Accessors(chain = true) | ||||||
|  | public class DiagnosisTreatmentImportDto { | ||||||
|  |  | ||||||
|  |     /** 行号 */ | ||||||
|  |     private Integer lineNumber; | ||||||
|  |  | ||||||
|  |     // ---------------------- 诊疗定义 wor_activity_definition ------------------------------------- | ||||||
|  |  | ||||||
|  |     /** 诊疗名称 */ | ||||||
|  |     @Excel(name = "诊疗名称", prompt = "必填") | ||||||
|  |     private String name; | ||||||
|  |  | ||||||
|  |     /** 目录类别 */ | ||||||
|  |     @Excel(name = "目录类别", prompt = "必填", dictType = "activity_category_code", comboReadDict = true) | ||||||
|  |     private String categoryCode; | ||||||
|  |  | ||||||
|  |     /** 使用单位 */ | ||||||
|  |     @Excel(name = "使用单位", prompt = "必填", dictType = "unit_code", comboReadDict = true) | ||||||
|  |     private String permittedUnitCode; | ||||||
|  |  | ||||||
|  |     /** 医保标记 */ | ||||||
|  |     @Excel(name = "医保标记", prompt = "必填", readConverterExp = "0=否,1=是", combo = "否,是") | ||||||
|  |     private String ybFlag; | ||||||
|  |  | ||||||
|  |     /** 医保对码标记 */ | ||||||
|  |     @Excel(name = "医保对码标记", prompt = "必填", readConverterExp = "0=否,1=是", combo = "否,是") | ||||||
|  |     private String ybMatchFlag; | ||||||
|  |  | ||||||
|  |     /** 医保编码 */ | ||||||
|  |     @Excel(name = "医保编码", prompt = "医保对码时必填") | ||||||
|  |     private String ybNo; | ||||||
|  |  | ||||||
|  |     /** 医保等级 */ | ||||||
|  |     @Excel(name = "医保等级", prompt = "必填", dictType = "chrgitm_lv", comboReadDict = true) | ||||||
|  |     private String chrgitmLv; | ||||||
|  |  | ||||||
|  |     // ---------------------- 费用定价 adm_charge_item_definition ---------------------------------------------- | ||||||
|  |  | ||||||
|  |     /** 财务类别 */ | ||||||
|  |     @Excel(name = "财务类别", prompt = "必填", dictType = "fin_type_code", comboReadDict = true) | ||||||
|  |     private String typeCode; | ||||||
|  |  | ||||||
|  |     /** 医保费用类别 */ | ||||||
|  |     @Excel(name = "医保费用类别", prompt = "必填", dictType = "med_chrgitm_type", comboReadDict = true) | ||||||
|  |     private String ybType; | ||||||
|  |  | ||||||
|  |     // ---------------------- 费用定价子表 adm_charge_item_def_detail ---------------------------------------------- | ||||||
|  |  | ||||||
|  |     /** 零售价 */ | ||||||
|  |     @Excel(name = "零售价", prompt = "必填,数值类型") | ||||||
|  |     private String retailPriceStr; | ||||||
|  |     private BigDecimal retailPrice; | ||||||
|  |  | ||||||
|  |     /** 最高零售价 */ | ||||||
|  |     @Excel(name = "最高零售价", prompt = "必填,数值类型") | ||||||
|  |     private String maximumRetailPriceStr; | ||||||
|  |     private BigDecimal maximumRetailPrice; | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -17,10 +17,13 @@ import lombok.experimental.Accessors; | |||||||
| @Accessors(chain = true) | @Accessors(chain = true) | ||||||
| public class MedicationImportDto { | public class MedicationImportDto { | ||||||
|  |  | ||||||
|  |     /** 行号 */ | ||||||
|  |     private Integer lineNumber; | ||||||
|  |  | ||||||
|     // ---------------------- 药品定义 med_medication_definition ------------------------------------- |     // ---------------------- 药品定义 med_medication_definition ------------------------------------- | ||||||
|  |  | ||||||
|     /** 药品名称 */ |     /** 药品名称 */ | ||||||
|     @Excel(name = "药品名称") |     @Excel(name = "药品名称", prompt = "必填") | ||||||
|     private String name; |     private String name; | ||||||
|  |  | ||||||
|     /** 药品版本 */ |     /** 药品版本 */ | ||||||
| @@ -32,27 +35,28 @@ public class MedicationImportDto { | |||||||
|     private String nameEn; |     private String nameEn; | ||||||
|  |  | ||||||
|     /** 药品分类 */ |     /** 药品分类 */ | ||||||
|     @Excel(name = "药品分类", dictType = "med_category_code", comboReadDict = true) |     @Excel(name = "药品分类", prompt = "必填", dictType = "med_category_code", comboReadDict = true) | ||||||
|     private String categoryCode; |     private String categoryCode; | ||||||
|  |  | ||||||
|     /** 商品名称 */ |     /** 商品名称 */ | ||||||
|     @Excel(name = "商品名称") |     @Excel(name = "商品名称", prompt = "必填") | ||||||
|     private String merchandiseName; |     private String merchandiseName; | ||||||
|  |  | ||||||
|     /** 药品单位 */ |     /** 药品单位 */ | ||||||
|     @Excel(name = "药品单位", dictType = "unit_code", comboReadDict = true) |     @Excel(name = "药品单位", prompt = "必填", dictType = "unit_code", comboReadDict = true) | ||||||
|     private String unitCode; |     private String unitCode; | ||||||
|  |  | ||||||
|     /** 最小单位 */ |     /** 最小单位 */ | ||||||
|     @Excel(name = "最小单位", dictType = "unit_code", comboReadDict = true) |     @Excel(name = "最小单位", prompt = "必填", dictType = "unit_code", comboReadDict = true) | ||||||
|     private String minUnitCode; |     private String minUnitCode; | ||||||
|  |  | ||||||
|     /** 拆零比 */ |     /** 拆零比 */ | ||||||
|     @Excel(name = "拆零比") |     @Excel(name = "拆零比", prompt = "必填,数值类型") | ||||||
|  |     private String partPercentStr; | ||||||
|     private BigDecimal partPercent; |     private BigDecimal partPercent; | ||||||
|  |  | ||||||
|     /** 剂量形式 */ |     /** 剂量形式 */ | ||||||
|     @Excel(name = "剂量形式", dictType = "dose_from_code", comboReadDict = true) |     @Excel(name = "剂量形式", prompt = "必填", dictType = "dose_form_code", comboReadDict = true) | ||||||
|     private String doseFrom; |     private String doseFrom; | ||||||
|  |  | ||||||
|     /** 批准文号 */ |     /** 批准文号 */ | ||||||
| @@ -60,35 +64,31 @@ public class MedicationImportDto { | |||||||
|     private String approvalNumber; |     private String approvalNumber; | ||||||
|  |  | ||||||
|     /** 医保是否对码 */ |     /** 医保是否对码 */ | ||||||
|     @Excel(name = "医保是否对码", readConverterExp = "0=否,1=是", combo = "否,是") |     @Excel(name = "医保是否对码", prompt = "必填", readConverterExp = "0=否,1=是", combo = "否,是") | ||||||
|     private String ybMatchFlag; |     private String ybMatchFlag; | ||||||
|  |  | ||||||
|     /** 医保编码 */ |     /** 医保编码 */ | ||||||
|     @Excel(name = "医保编码") |     @Excel(name = "医保编码", prompt = "医保对码时必填") | ||||||
|     private String ybNo; |     private String ybNo; | ||||||
|  |  | ||||||
|     /** 是否皮试 */ |     /** 是否皮试 */ | ||||||
|     @Excel(name = "是否皮试", readConverterExp = "0=否,1=是", combo = "否,是") |     @Excel(name = "是否皮试", prompt = "必填", readConverterExp = "0=否,1=是", combo = "否,是") | ||||||
|     private String skinTestFlag; |     private String skinTestFlag; | ||||||
|  |  | ||||||
|     /** 是否为注射药物 */ |     /** 是否为注射药物 */ | ||||||
|     @Excel(name = "是否为注射药物", readConverterExp = "0=否,1=是", combo = "否,是") |     @Excel(name = "是否为注射药物", prompt = "必填", readConverterExp = "0=否,1=是", combo = "否,是") | ||||||
|     private String injectFlag; |     private String injectFlag; | ||||||
|  |  | ||||||
|     /** 生产厂商文本 */ |  | ||||||
|     @Excel(name = "生产厂商文本") |  | ||||||
|     private String manufacturerText; |  | ||||||
|  |  | ||||||
|     /** 是否限制使用 */ |     /** 是否限制使用 */ | ||||||
|     @Excel(name = "是否限制使用", readConverterExp = "0=否,1=是", combo = "否,是") |     @Excel(name = "是否限制使用", prompt = "必填", readConverterExp = "0=否,1=是", combo = "否,是") | ||||||
|     private String restrictedFlag; |     private String restrictedFlag; | ||||||
|  |  | ||||||
|     /** 限制使用范围 */ |     /** 限制使用范围 */ | ||||||
|     @Excel(name = "限制使用范围") |     @Excel(name = "限制使用范围", prompt = "限制使用时必填") | ||||||
|     private String restrictedScope; |     private String restrictedScope; | ||||||
|  |  | ||||||
|     /** 儿童用药标志 */ |     /** 儿童用药标志 */ | ||||||
|     @Excel(name = "儿童用药标志", readConverterExp = "0=否,1=是", combo = "否,是") |     @Excel(name = "儿童用药标志", prompt = "必填", readConverterExp = "0=否,1=是", combo = "否,是") | ||||||
|     private String childrenFlag; |     private String childrenFlag; | ||||||
|  |  | ||||||
|     /** 贯标国家编码 */ |     /** 贯标国家编码 */ | ||||||
| @@ -96,56 +96,68 @@ public class MedicationImportDto { | |||||||
|     private String nationalDrugCode; |     private String nationalDrugCode; | ||||||
|  |  | ||||||
|     /** 拆分属性 */ |     /** 拆分属性 */ | ||||||
|     @Excel(name = "拆分属性", readConverterExp = "1=门诊按最小单位每次量向上取整,2=门诊按包装单位不可拆分,3=门诊按最小单位总量向上取整,4=门诊按包装单位每次量向上取整", |     @Excel(name = "拆分属性", prompt = "必填", | ||||||
|  |         readConverterExp = "1=门诊按最小单位每次量向上取整,2=门诊按包装单位不可拆分,3=门诊按最小单位总量向上取整,4=门诊按包装单位每次量向上取整", | ||||||
|         combo = "门诊按最小单位每次量向上取整,门诊按包装单位不可拆分,门诊按最小单位总量向上取整,门诊按包装单位每次量向上取整") |         combo = "门诊按最小单位每次量向上取整,门诊按包装单位不可拆分,门诊按最小单位总量向上取整,门诊按包装单位每次量向上取整") | ||||||
|     private String partAttributeEnum; |     private String partAttributeEnum; | ||||||
|  |  | ||||||
|     /** 是否抗生素 */ |     /** 是否抗生素 */ | ||||||
|     @Excel(name = "是否抗生素", readConverterExp = "0=否,1=是", combo = "否,是") |     @Excel(name = "是否抗生素", prompt = "必填", readConverterExp = "0=否,1=是", combo = "否,是") | ||||||
|     private String antibioticFlag; |     private String antibioticFlag; | ||||||
|  |  | ||||||
|     /** 抗生素分类 */ |     /** 抗生素分类 */ | ||||||
|     @Excel(name = "抗生素分类", dictType = "antibiotic_type_code", comboReadDict = true) |     @Excel(name = "抗生素分类", prompt = "抗生素时必填", dictType = "antibiotic_type_code", comboReadDict = true) | ||||||
|     private String antibioticCode; |     private String antibioticCode; | ||||||
|  |  | ||||||
|     /** 权限限制 */ |  | ||||||
|     @Excel(name = "权限限制", readConverterExp = "1=非限制使用,2=限制使用,3=特殊使用", combo = "非限制使用,限制使用,特殊使用") |  | ||||||
|     private String restrictedEnum; |  | ||||||
|  |  | ||||||
|     /** 是否自制 */ |     /** 是否自制 */ | ||||||
|     @Excel(name = "是否自制", readConverterExp = "0=否,1=是", combo = "否,是") |     @Excel(name = "是否自制", prompt = "必填", readConverterExp = "0=否,1=是", combo = "否,是") | ||||||
|     private String selfFlag; |     private String selfFlag; | ||||||
|  |  | ||||||
|     /** 基药标识 */ |     /** 基药标识 */ | ||||||
|     @Excel(name = "基药标识", readConverterExp = "0=否,1=是", combo = "否,是") |     @Excel(name = "基药标识", prompt = "必填", readConverterExp = "0=否,1=是", combo = "否,是") | ||||||
|     private String basicFlag; |     private String basicFlag; | ||||||
|  |  | ||||||
|  |     /** 生产厂商文本 */ | ||||||
|  |     @Excel(name = "生产厂商文本", prompt = "必填") | ||||||
|  |     private String manufacturerText; | ||||||
|  |  | ||||||
|     /** 住院临时医嘱拆分属性 */ |     /** 住院临时医嘱拆分属性 */ | ||||||
|     @Excel(name = "住院临时医嘱拆分属性", |     @Excel(name = "住院临时医嘱拆分属性", prompt = "必填", width = 20, | ||||||
|         readConverterExp = "1=临时医嘱按最小单位每次量向上取整,2=临时医嘱按包装单位开立,3=临时医嘱按最小单位总量向上取整,4=临时医嘱按包装单位每次量向上取整", |         readConverterExp = "1=临时医嘱按最小单位每次量向上取整,2=临时医嘱按包装单位开立,3=临时医嘱按最小单位总量向上取整,4=临时医嘱按包装单位每次量向上取整", | ||||||
|         combo = "临时医嘱按最小单位每次量向上取整,临时医嘱按包装单位开立,临时医嘱按最小单位总量向上取整,临时医嘱按包装单位每次量向上取整") |         combo = "临时医嘱按最小单位每次量向上取整,临时医嘱按包装单位开立,临时医嘱按最小单位总量向上取整,临时医嘱按包装单位每次量向上取整") | ||||||
|     private String thoPartAttributeEnum; |     private String thoPartAttributeEnum; | ||||||
|  |  | ||||||
|     /** 剂量单位换算比 */ |     /** 剂量单位换算比 */ | ||||||
|     @Excel(name = "剂量单位换算比") |     @Excel(name = "剂量单位换算比", prompt = "必填,数值类型") | ||||||
|  |     private String unitConversionRatioStr; | ||||||
|     private BigDecimal unitConversionRatio; |     private BigDecimal unitConversionRatio; | ||||||
|  |  | ||||||
|     /** 医保等级 */ |     /** 医保等级 */ | ||||||
|     @Excel(name = "医保等级", dictType = "chrgitm_lv", comboReadDict = true) |     @Excel(name = "医保等级", prompt = "必填", dictType = "chrgitm_lv", comboReadDict = true) | ||||||
|     private String chrgitmLv; |     private String chrgitmLv; | ||||||
|  |  | ||||||
|     /** 处方标志 */ |     /** 处方标志 */ | ||||||
|     @Excel(name = "处方标志", readConverterExp = "0=否,1=是", combo = "否,是") |     @Excel(name = "处方标志", prompt = "必填", readConverterExp = "0=否,1=是", combo = "否,是") | ||||||
|     private String rxFlag; |     private String rxFlag; | ||||||
|  |  | ||||||
|  |     /** 最小库存警戒数量(常规单位) */ | ||||||
|  |     @Excel(name = "最小库存警戒数量(常规单位)", width = 25, prompt = "必填,数值类型") | ||||||
|  |     private String itemMinQuantityStr; | ||||||
|  |     private BigDecimal itemMinQuantity; | ||||||
|  |  | ||||||
|  |     /** 最大库存警戒数量(常规单位) */ | ||||||
|  |     @Excel(name = "最大库存警戒数量(常规单位)", width = 25, prompt = "必填,数值类型") | ||||||
|  |     private String itemMaxQuantityStr; | ||||||
|  |     private BigDecimal itemMaxQuantity; | ||||||
|  |  | ||||||
|     // ---------------------- 药品基本信息 med_medication ---------------------------------------------- |     // ---------------------- 药品基本信息 med_medication ---------------------------------------------- | ||||||
|  |  | ||||||
|     /** 所在位置名称(locationId) */ |     /** 所在位置名称(locationId) */ | ||||||
|     @Excel(name = "所在位置名称") |     @Excel(name = "所在位置名称", prompt = "必填") | ||||||
|     private String locationName; |     private String locationName; | ||||||
|  |  | ||||||
|     /** 规格 */ |     /** 规格 */ | ||||||
|     @Excel(name = "规格") |     @Excel(name = "规格", prompt = "必填") | ||||||
|     private String totalVolume; |     private String totalVolume; | ||||||
|  |  | ||||||
|     /** 用法 */ |     /** 用法 */ | ||||||
| @@ -157,7 +169,8 @@ public class MedicationImportDto { | |||||||
|     private String rateCode; |     private String rateCode; | ||||||
|  |  | ||||||
|     /** 单次剂量 */ |     /** 单次剂量 */ | ||||||
|     @Excel(name = "单次剂量") |     @Excel(name = "单次剂量", prompt = "数值类型") | ||||||
|  |     private String doseStr; | ||||||
|     private BigDecimal dose; |     private BigDecimal dose; | ||||||
|  |  | ||||||
|     /** 剂量单位 */ |     /** 剂量单位 */ | ||||||
| @@ -165,31 +178,35 @@ public class MedicationImportDto { | |||||||
|     private String doseUnitCode; |     private String doseUnitCode; | ||||||
|  |  | ||||||
|     /** 单次最大剂量 */ |     /** 单次最大剂量 */ | ||||||
|     @Excel(name = "单次最大剂量") |     @Excel(name = "单次最大剂量", prompt = "数值类型") | ||||||
|  |     private String maxUnitStr; | ||||||
|     private BigDecimal maxUnit; |     private BigDecimal maxUnit; | ||||||
|  |  | ||||||
|     // ---------------------- 费用定价 adm_charge_item_definition ---------------------------------------------- |     // ---------------------- 费用定价 adm_charge_item_definition ---------------------------------------------- | ||||||
|  |  | ||||||
|     /** 财务类别 */ |     /** 财务类别 */ | ||||||
|     @Excel(name = "财务类别", dictType = "fin_type_code", comboReadDict = true) |     @Excel(name = "财务类别", prompt = "必填", dictType = "fin_type_code", comboReadDict = true) | ||||||
|     private String typeCode; |     private String typeCode; | ||||||
|  |  | ||||||
|     /** 医保费用类别 */ |     /** 医保费用类别 */ | ||||||
|     @Excel(name = "医保费用类别", dictType = "med_chrgitm_type", comboReadDict = true) |     @Excel(name = "医保费用类别", prompt = "必填", dictType = "med_chrgitm_type", comboReadDict = true) | ||||||
|     private String ybType; |     private String ybType; | ||||||
|  |  | ||||||
|     // ---------------------- 费用定价子表 adm_charge_item_def_detail ---------------------------------------------- |     // ---------------------- 费用定价子表 adm_charge_item_def_detail ---------------------------------------------- | ||||||
|  |  | ||||||
|     /** 购入价 */ |     /** 购入价 */ | ||||||
|     @Excel(name = "购入价") |     @Excel(name = "购入价", prompt = "必填,数值类型") | ||||||
|  |     private String purchasePriceStr; | ||||||
|     private BigDecimal purchasePrice; |     private BigDecimal purchasePrice; | ||||||
|  |  | ||||||
|     /** 零售价 */ |     /** 零售价 */ | ||||||
|     @Excel(name = "零售价") |     @Excel(name = "零售价", prompt = "必填,数值类型") | ||||||
|  |     private String retailPriceStr; | ||||||
|     private BigDecimal retailPrice; |     private BigDecimal retailPrice; | ||||||
|  |  | ||||||
|     /** 最高零售价 */ |     /** 最高零售价 */ | ||||||
|     @Excel(name = "最高零售价") |     @Excel(name = "最高零售价", prompt = "必填,数值类型") | ||||||
|  |     private String maximumRetailPriceStr; | ||||||
|     private BigDecimal maximumRetailPrice; |     private BigDecimal maximumRetailPrice; | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -185,11 +185,8 @@ public class DepartmentReceiptApprovalServiceImpl implements IDepartmentReceiptA | |||||||
|             } |             } | ||||||
|  |  | ||||||
|             // 追加追溯码信息 |             // 追加追溯码信息 | ||||||
|             boolean flg = traceNoAppService.addTraceNoManage(supplyItemDetailList, TraceNoStatus.IN.getValue(), |             traceNoAppService.addTraceNoManage(supplyItemDetailList, TraceNoStatus.IN.getValue(), | ||||||
|                 SupplyType.PURCHASE_STOCKIN.getValue()); |                 SupplyType.PURCHASE_STOCKIN.getValue()); | ||||||
|             if (!flg) { |  | ||||||
|                 return R.fail(MessageUtils.createMessage(PromptMsgConstant.Common.M00007, null)); |  | ||||||
|             } |  | ||||||
|  |  | ||||||
|             // 调用医保商品采购接口 todo 科室材料相关医保接口未对应 |             // 调用医保商品采购接口 todo 科室材料相关医保接口未对应 | ||||||
|             String ybSwitch = SecurityUtils.getLoginUser().getOptionJson().getString(CommonConstants.Option.YB_SWITCH); // 医保开关 |             String ybSwitch = SecurityUtils.getLoginUser().getOptionJson().getString(CommonConstants.Option.YB_SWITCH); // 医保开关 | ||||||
| @@ -275,11 +272,9 @@ public class DepartmentReceiptApprovalServiceImpl implements IDepartmentReceiptA | |||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|             // 追加追溯码信息 |             // 追加追溯码信息 | ||||||
|             boolean flg = traceNoAppService.addTraceNoManage(supplyItemDetailList, TraceNoStatus.OUT.getValue(), |             traceNoAppService.addTraceNoManage(supplyItemDetailList, TraceNoStatus.OUT.getValue(), | ||||||
|                 SupplyType.PURCHASE_RETURN.getValue()); |                 SupplyType.PURCHASE_RETURN.getValue()); | ||||||
|             if (!flg) { |  | ||||||
|                 return R.fail(MessageUtils.createMessage(PromptMsgConstant.Common.M00007, null)); |  | ||||||
|             } |  | ||||||
|             // 调用医保采购退货接口 |             // 调用医保采购退货接口 | ||||||
|             String ybSwitch = SecurityUtils.getLoginUser().getOptionJson().getString(CommonConstants.Option.YB_SWITCH); // 医保开关 |             String ybSwitch = SecurityUtils.getLoginUser().getOptionJson().getString(CommonConstants.Option.YB_SWITCH); // 医保开关 | ||||||
|             if (Whether.YES.getCode().equals(ybSwitch)) { |             if (Whether.YES.getCode().equals(ybSwitch)) { | ||||||
| @@ -642,11 +637,9 @@ public class DepartmentReceiptApprovalServiceImpl implements IDepartmentReceiptA | |||||||
|                 inventoryItemService.stockIn(inventoryItemList); |                 inventoryItemService.stockIn(inventoryItemList); | ||||||
|             } |             } | ||||||
|             // 追加追溯码信息 |             // 追加追溯码信息 | ||||||
|             boolean flg = traceNoAppService.addTraceNoManage(supplyItemDetailList, TraceNoStatus.IN.getValue(), |             traceNoAppService.addTraceNoManage(supplyItemDetailList, TraceNoStatus.IN.getValue(), | ||||||
|                 SupplyType.PURCHASE_TRANSFERIN.getValue()); |                 SupplyType.PURCHASE_TRANSFERIN.getValue()); | ||||||
|             if (!flg) { |  | ||||||
|                 return R.fail(MessageUtils.createMessage(PromptMsgConstant.Common.M00007, null)); |  | ||||||
|             } |  | ||||||
|         } |         } | ||||||
|         return R.ok(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00004, null)); |         return R.ok(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00004, null)); | ||||||
|  |  | ||||||
| @@ -721,11 +714,9 @@ public class DepartmentReceiptApprovalServiceImpl implements IDepartmentReceiptA | |||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|             // 追加追溯码信息 |             // 追加追溯码信息 | ||||||
|             boolean flg = traceNoAppService.addTraceNoManage(supplyItemDetailList, TraceNoStatus.OUT.getValue(), |             traceNoAppService.addTraceNoManage(supplyItemDetailList, TraceNoStatus.OUT.getValue(), | ||||||
|                 SupplyType.PURCHASE_TRANSFEROUT.getValue()); |                 SupplyType.PURCHASE_TRANSFEROUT.getValue()); | ||||||
|             if (!flg) { |  | ||||||
|                 return R.fail(MessageUtils.createMessage(PromptMsgConstant.Common.M00007, null)); |  | ||||||
|             } |  | ||||||
|         } |         } | ||||||
|         return R.ok(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00004, null)); |         return R.ok(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00004, null)); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -4,6 +4,7 @@ import java.util.List; | |||||||
|  |  | ||||||
| import com.baomidou.mybatisplus.core.metadata.IPage; | import com.baomidou.mybatisplus.core.metadata.IPage; | ||||||
| import com.core.common.core.domain.R; | import com.core.common.core.domain.R; | ||||||
|  | import com.openhis.web.doctorstation.dto.ActivityBindDeviceDto; | ||||||
| import com.openhis.web.doctorstation.dto.AdviceBaseDto; | import com.openhis.web.doctorstation.dto.AdviceBaseDto; | ||||||
| import com.openhis.web.doctorstation.dto.AdviceSaveParam; | import com.openhis.web.doctorstation.dto.AdviceSaveParam; | ||||||
| import com.openhis.web.doctorstation.dto.UpdateGroupIdParam; | import com.openhis.web.doctorstation.dto.UpdateGroupIdParam; | ||||||
| @@ -31,6 +32,14 @@ public interface IDoctorStationAdviceAppService { | |||||||
|         List<Long> adviceDefinitionIdParamList, Long organizationId, Integer pageNo, Integer pageSize, |         List<Long> adviceDefinitionIdParamList, Long organizationId, Integer pageNo, Integer pageSize, | ||||||
|         Integer pricingFlag, List<Integer> adviceTypes); |         Integer pricingFlag, List<Integer> adviceTypes); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 查询诊疗绑定耗材信息 | ||||||
|  |      * | ||||||
|  |      * @param activityId 诊疗id | ||||||
|  |      * @return 诊疗绑定耗材信息 | ||||||
|  |      */ | ||||||
|  |     ActivityBindDeviceDto getActivityBindDevice(Long activityId); | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 门诊保存医嘱 |      * 门诊保存医嘱 | ||||||
|      * |      * | ||||||
|   | |||||||
| @@ -1,5 +1,7 @@ | |||||||
| package com.openhis.web.doctorstation.appservice; | package com.openhis.web.doctorstation.appservice; | ||||||
|  |  | ||||||
|  | import javax.servlet.http.HttpServletRequest; | ||||||
|  |  | ||||||
| import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||||
| import com.core.common.core.domain.R; | import com.core.common.core.domain.R; | ||||||
| import com.openhis.web.doctorstation.dto.ConditionDefinitionMetadata; | import com.openhis.web.doctorstation.dto.ConditionDefinitionMetadata; | ||||||
| @@ -91,4 +93,12 @@ public interface IDoctorStationDiagnosisAppService { | |||||||
|      */ |      */ | ||||||
|     R<?> delEncounterDiagnosis(Long conditionId); |     R<?> delEncounterDiagnosis(Long conditionId); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 查询诊断信息 | ||||||
|  |      *  | ||||||
|  |      * @param searchKey 目标字符 | ||||||
|  |      * @param request 请求 | ||||||
|  |      * @return 查询结果 | ||||||
|  |      */ | ||||||
|  |     R<?> getDiagnosisList(String searchKey, HttpServletRequest request); | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,5 +1,6 @@ | |||||||
| package com.openhis.web.doctorstation.appservice.impl; | package com.openhis.web.doctorstation.appservice.impl; | ||||||
|  |  | ||||||
|  | import java.math.BigDecimal; | ||||||
| import java.util.*; | import java.util.*; | ||||||
| import java.util.stream.Collectors; | import java.util.stream.Collectors; | ||||||
|  |  | ||||||
| @@ -137,6 +138,8 @@ public class DoctorStationAdviceAppServiceImpl implements IDoctorStationAdviceAp | |||||||
|         // 预减库存 |         // 预减库存 | ||||||
|         List<AdviceInventoryDto> adviceInventory = |         List<AdviceInventoryDto> adviceInventory = | ||||||
|             adviceUtils.subtractInventory(adviceInventoryList, adviceDraftInventoryList); |             adviceUtils.subtractInventory(adviceInventoryList, adviceDraftInventoryList); | ||||||
|  |         // 查询取药科室配置 | ||||||
|  |         List<AdviceInventoryDto> medLocationConfig = doctorStationAdviceAppMapper.getMedLocationConfig(organizationId); | ||||||
|         // 费用定价子表信息 |         // 费用定价子表信息 | ||||||
|         List<AdvicePriceDto> childCharge = doctorStationAdviceAppMapper |         List<AdvicePriceDto> childCharge = doctorStationAdviceAppMapper | ||||||
|             .getChildCharge(ConditionCode.LOT_NUMBER_COST.getCode(), chargeItemDefinitionIdList); |             .getChildCharge(ConditionCode.LOT_NUMBER_COST.getCode(), chargeItemDefinitionIdList); | ||||||
| @@ -162,9 +165,29 @@ public class DoctorStationAdviceAppServiceImpl implements IDoctorStationAdviceAp | |||||||
|                                 .collect(Collectors.toList()); |                                 .collect(Collectors.toList()); | ||||||
|                     // 库存信息 |                     // 库存信息 | ||||||
|                     baseDto.setInventoryList(inventoryList); |                     baseDto.setInventoryList(inventoryList); | ||||||
|                     // 如果有库存信息,设置默认产品批号 |                     // 设置默认产品批号 | ||||||
|                     if (!inventoryList.isEmpty()) { |                     if (!inventoryList.isEmpty()) { | ||||||
|                         baseDto.setDefaultLotNumber(inventoryList.get(0).getLotNumber()); |                         // 库存大于0 | ||||||
|  |                         List<AdviceInventoryDto> hasInventoryList = inventoryList.stream() | ||||||
|  |                             .filter(e -> e.getQuantity().compareTo(BigDecimal.ZERO) > 0).collect(Collectors.toList()); | ||||||
|  |                         if (!hasInventoryList.isEmpty()) { | ||||||
|  |                             baseDto.setDefaultLotNumber(hasInventoryList.get(0).getLotNumber()); | ||||||
|  |                         } | ||||||
|  |                     } | ||||||
|  |                     if (!inventoryList.isEmpty() && !medLocationConfig.isEmpty()) { | ||||||
|  |                         // 第一步:在medLocationConfig中匹配categoryCode | ||||||
|  |                         AdviceInventoryDto result1 = medLocationConfig.stream() | ||||||
|  |                             .filter(dto -> baseDto.getCategoryCode().equals(dto.getCategoryCode())).findFirst() | ||||||
|  |                             .orElse(null); | ||||||
|  |                         if (result1 != null) { | ||||||
|  |                             // 第二步:在inventoryList中匹配locationId | ||||||
|  |                             AdviceInventoryDto result2 = inventoryList.stream() | ||||||
|  |                                 .filter(dto -> result1.getLocationId().equals(dto.getLocationId())).findFirst() | ||||||
|  |                                 .orElse(null); | ||||||
|  |                             if (result2 != null && result2.getLotNumber() != null) { | ||||||
|  |                                 baseDto.setDefaultLotNumber(result2.getLotNumber()); | ||||||
|  |                             } | ||||||
|  |                         } | ||||||
|                     } |                     } | ||||||
|                     unitCode = baseDto.getUnitCode(); |                     unitCode = baseDto.getUnitCode(); | ||||||
|                     chargeItemDefinitionId = baseDto.getChargeItemDefinitionId(); |                     chargeItemDefinitionId = baseDto.getChargeItemDefinitionId(); | ||||||
| @@ -201,6 +224,43 @@ public class DoctorStationAdviceAppServiceImpl implements IDoctorStationAdviceAp | |||||||
|         return adviceBaseInfo; |         return adviceBaseInfo; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 查询诊疗绑定耗材信息 | ||||||
|  |      * | ||||||
|  |      * @param activityId 诊疗id | ||||||
|  |      * @return 诊疗绑定耗材信息 | ||||||
|  |      */ | ||||||
|  |     public ActivityBindDeviceDto getActivityBindDevice(Long activityId) { | ||||||
|  |         ActivityBindDeviceDto activityBindDeviceDto = new ActivityBindDeviceDto(); | ||||||
|  |         List<ActivityBindDeviceDetailDto> activityBindDevice = doctorStationAdviceAppMapper.getActivityBindDevice( | ||||||
|  |             activityId + "", PublicationStatus.ACTIVE.getValue(), CommonConstants.TableName.ADM_DEVICE_DEFINITION); | ||||||
|  |         // 详细信息赋值 | ||||||
|  |         if (!activityBindDevice.isEmpty()) { | ||||||
|  |             // 耗材id集合 | ||||||
|  |             List<Long> deviceIds = | ||||||
|  |                 activityBindDevice.stream().map(ActivityBindDeviceDetailDto::getDeviceId).collect(Collectors.toList()); | ||||||
|  |             // 耗材医嘱信息 | ||||||
|  |             List<AdviceBaseDto> deviceRecords = | ||||||
|  |                 this.getAdviceBaseInfo(null, null, null, deviceIds, 0L, 1, 100, Whether.NO.getValue(), List.of(1, 2, 3)) | ||||||
|  |                     .getRecords(); | ||||||
|  |             Map<Long, AdviceBaseDto> adviceMap = deviceRecords.stream().collect(Collectors | ||||||
|  |                 .toMap(AdviceBaseDto::getAdviceDefinitionId, advice -> advice, (existing, replacement) -> existing // 如果有重复key,保留第一个 | ||||||
|  |                 )); | ||||||
|  |             activityBindDeviceDto.setActivityBindDeviceInfos(activityBindDevice); | ||||||
|  |             for (ActivityBindDeviceDetailDto activityBindDeviceInfo : activityBindDeviceDto | ||||||
|  |                 .getActivityBindDeviceInfos()) { | ||||||
|  |                 Long deviceId = activityBindDeviceInfo.getDeviceId(); | ||||||
|  |                 if (deviceId != null) { | ||||||
|  |                     AdviceBaseDto matchedAdvice = adviceMap.get(deviceId); | ||||||
|  |                     if (matchedAdvice != null) { | ||||||
|  |                         activityBindDeviceInfo.setOrderDetailInfos(matchedAdvice); | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         return activityBindDeviceDto; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 门诊保存/签发医嘱 |      * 门诊保存/签发医嘱 | ||||||
|      * |      * | ||||||
| @@ -297,6 +357,18 @@ public class DoctorStationAdviceAppServiceImpl implements IDoctorStationAdviceAp | |||||||
|         // 删除 |         // 删除 | ||||||
|         List<AdviceSaveDto> deleteList = medicineList.stream() |         List<AdviceSaveDto> deleteList = medicineList.stream() | ||||||
|             .filter(e -> DbOpType.DELETE.getCode().equals(e.getDbOpType())).collect(Collectors.toList()); |             .filter(e -> DbOpType.DELETE.getCode().equals(e.getDbOpType())).collect(Collectors.toList()); | ||||||
|  |         // 校验删除的医嘱是否已经收费 | ||||||
|  |         List<Long> delRequestIdList = deleteList.stream().map(AdviceSaveDto::getRequestId).collect(Collectors.toList()); | ||||||
|  |         if (!delRequestIdList.isEmpty()) { | ||||||
|  |             List<ChargeItem> chargeItemList = iChargeItemService.getChargeItemInfoByReqId(delRequestIdList); | ||||||
|  |             if (chargeItemList != null && !chargeItemList.isEmpty()) { | ||||||
|  |                 for (ChargeItem ci : chargeItemList) { | ||||||
|  |                     if (ChargeItemStatus.BILLED.getValue().equals(ci.getStatusEnum())) { | ||||||
|  |                         throw new ServiceException("已收费的项目无法删除,请刷新页面后重试"); | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|         for (AdviceSaveDto adviceSaveDto : deleteList) { |         for (AdviceSaveDto adviceSaveDto : deleteList) { | ||||||
|             iMedicationRequestService.removeById(adviceSaveDto.getRequestId()); |             iMedicationRequestService.removeById(adviceSaveDto.getRequestId()); | ||||||
|             // 删除已经产生的药品发放信息 |             // 删除已经产生的药品发放信息 | ||||||
| @@ -511,6 +583,18 @@ public class DoctorStationAdviceAppServiceImpl implements IDoctorStationAdviceAp | |||||||
|         // 删除 |         // 删除 | ||||||
|         List<AdviceSaveDto> deleteList = deviceList.stream() |         List<AdviceSaveDto> deleteList = deviceList.stream() | ||||||
|             .filter(e -> DbOpType.DELETE.getCode().equals(e.getDbOpType())).collect(Collectors.toList()); |             .filter(e -> DbOpType.DELETE.getCode().equals(e.getDbOpType())).collect(Collectors.toList()); | ||||||
|  |         // 校验删除的医嘱是否已经收费 | ||||||
|  |         List<Long> delRequestIdList = deleteList.stream().map(AdviceSaveDto::getRequestId).collect(Collectors.toList()); | ||||||
|  |         if (!delRequestIdList.isEmpty()) { | ||||||
|  |             List<ChargeItem> chargeItemList = iChargeItemService.getChargeItemInfoByReqId(delRequestIdList); | ||||||
|  |             if (chargeItemList != null && !chargeItemList.isEmpty()) { | ||||||
|  |                 for (ChargeItem ci : chargeItemList) { | ||||||
|  |                     if (ChargeItemStatus.BILLED.getValue().equals(ci.getStatusEnum())) { | ||||||
|  |                         throw new ServiceException("已收费的项目无法删除,请刷新页面后重试"); | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|         for (AdviceSaveDto adviceSaveDto : deleteList) { |         for (AdviceSaveDto adviceSaveDto : deleteList) { | ||||||
|             iDeviceRequestService.removeById(adviceSaveDto.getRequestId()); |             iDeviceRequestService.removeById(adviceSaveDto.getRequestId()); | ||||||
|             // 删除已经产生的耗材发放信息 |             // 删除已经产生的耗材发放信息 | ||||||
| @@ -606,8 +690,22 @@ public class DoctorStationAdviceAppServiceImpl implements IDoctorStationAdviceAp | |||||||
|         // 删除 |         // 删除 | ||||||
|         List<AdviceSaveDto> deleteList = activityList.stream() |         List<AdviceSaveDto> deleteList = activityList.stream() | ||||||
|             .filter(e -> DbOpType.DELETE.getCode().equals(e.getDbOpType())).collect(Collectors.toList()); |             .filter(e -> DbOpType.DELETE.getCode().equals(e.getDbOpType())).collect(Collectors.toList()); | ||||||
|  |         // 校验删除的医嘱是否已经收费 | ||||||
|  |         List<Long> delRequestIdList = deleteList.stream().map(AdviceSaveDto::getRequestId).collect(Collectors.toList()); | ||||||
|  |         if (!delRequestIdList.isEmpty()) { | ||||||
|  |             List<ChargeItem> chargeItemList = iChargeItemService.getChargeItemInfoByReqId(delRequestIdList); | ||||||
|  |             if (chargeItemList != null && !chargeItemList.isEmpty()) { | ||||||
|  |                 for (ChargeItem ci : chargeItemList) { | ||||||
|  |                     if (ChargeItemStatus.BILLED.getValue().equals(ci.getStatusEnum())) { | ||||||
|  |                         throw new ServiceException("已收费的项目无法删除,请刷新页面后重试"); | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|         for (AdviceSaveDto adviceSaveDto : deleteList) { |         for (AdviceSaveDto adviceSaveDto : deleteList) { | ||||||
|             iServiceRequestService.removeById(adviceSaveDto.getRequestId()); |             iServiceRequestService.removeById(adviceSaveDto.getRequestId());// 删除诊疗 | ||||||
|  |             iServiceRequestService.remove( | ||||||
|  |                 new LambdaQueryWrapper<ServiceRequest>().eq(ServiceRequest::getParentId, adviceSaveDto.getRequestId()));// 删除诊疗套餐对应的子项 | ||||||
|             // 删除费用项 |             // 删除费用项 | ||||||
|             iChargeItemService.deleteByServiceTableAndId(CommonConstants.TableName.WOR_SERVICE_REQUEST, |             iChargeItemService.deleteByServiceTableAndId(CommonConstants.TableName.WOR_SERVICE_REQUEST, | ||||||
|                 adviceSaveDto.getRequestId()); |                 adviceSaveDto.getRequestId()); | ||||||
| @@ -683,6 +781,7 @@ public class DoctorStationAdviceAppServiceImpl implements IDoctorStationAdviceAp | |||||||
|                         activityChildrenJsonParams.setEncounterId(serviceRequest.getEncounterId()); // 就诊id |                         activityChildrenJsonParams.setEncounterId(serviceRequest.getEncounterId()); // 就诊id | ||||||
|                         activityChildrenJsonParams.setAccountId(chargeItem.getAccountId()); // 账户id |                         activityChildrenJsonParams.setAccountId(chargeItem.getAccountId()); // 账户id | ||||||
|                         activityChildrenJsonParams.setChargeItemId(chargeItem.getId()); // 费用项id |                         activityChildrenJsonParams.setChargeItemId(chargeItem.getId()); // 费用项id | ||||||
|  |                         activityChildrenJsonParams.setParentId(serviceRequest.getId());// 子项诊疗的父id | ||||||
|                         adviceUtils.handleActivityChild(childrenJson, organizationId, activityChildrenJsonParams); |                         adviceUtils.handleActivityChild(childrenJson, organizationId, activityChildrenJsonParams); | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|   | |||||||
| @@ -246,7 +246,7 @@ public class DoctorStationChineseMedicalAppServiceImpl implements IDoctorStation | |||||||
|         List<Long> adviceDefinitionIdParamList, Long organizationId, Integer pageNo, Integer pageSize, |         List<Long> adviceDefinitionIdParamList, Long organizationId, Integer pageNo, Integer pageSize, | ||||||
|         Integer pricingFlag) { |         Integer pricingFlag) { | ||||||
|         adviceBaseDto.setAdviceType(1); // 医嘱类型为药品 |         adviceBaseDto.setAdviceType(1); // 医嘱类型为药品 | ||||||
|         adviceBaseDto.setCategoryCode(medCategoryCode.CHINESE_HERBAL_MEDICINE.getValue());// 中草药 |         adviceBaseDto.setCategoryCode(MedCategoryCode.CHINESE_HERBAL_MEDICINE.getValue());// 中草药 | ||||||
|         return iDoctorStationAdviceAppService.getAdviceBaseInfo(adviceBaseDto, searchKey, locationId, |         return iDoctorStationAdviceAppService.getAdviceBaseInfo(adviceBaseDto, searchKey, locationId, | ||||||
|             adviceDefinitionIdParamList, organizationId, pageNo, pageSize, pricingFlag, List.of(1, 2, 3)); |             adviceDefinitionIdParamList, organizationId, pageNo, pageSize, pricingFlag, List.of(1, 2, 3)); | ||||||
|     } |     } | ||||||
| @@ -320,7 +320,7 @@ public class DoctorStationChineseMedicalAppServiceImpl implements IDoctorStation | |||||||
|         String signCode = assignSeqUtil.getSeq(AssignSeqEnum.ADVICE_SIGN.getPrefix(), 10); |         String signCode = assignSeqUtil.getSeq(AssignSeqEnum.ADVICE_SIGN.getPrefix(), 10); | ||||||
|         for (AdviceSaveDto adviceSaveDto : insertOrUpdateList) { |         for (AdviceSaveDto adviceSaveDto : insertOrUpdateList) { | ||||||
|             // 中药付数 |             // 中药付数 | ||||||
|             Integer chineseHerbsDoseQuantity = adviceSaveDto.getChineseHerbsDoseQuantity(); |             BigDecimal chineseHerbsDoseQuantity = adviceSaveDto.getChineseHerbsDoseQuantity(); | ||||||
|             medicationRequest = new MedicationRequest(); |             medicationRequest = new MedicationRequest(); | ||||||
|             medicationRequest.setTcmFlag(Whether.YES.getValue());// 中医标识 |             medicationRequest.setTcmFlag(Whether.YES.getValue());// 中医标识 | ||||||
|             medicationRequest.setId(adviceSaveDto.getRequestId()); // 主键id |             medicationRequest.setId(adviceSaveDto.getRequestId()); // 主键id | ||||||
| @@ -335,7 +335,7 @@ public class DoctorStationChineseMedicalAppServiceImpl implements IDoctorStation | |||||||
|                 medicationRequest.setBusNo(assignSeqUtil.getSeq(AssignSeqEnum.MEDICATION_RES_NO.getPrefix(), 4)); |                 medicationRequest.setBusNo(assignSeqUtil.getSeq(AssignSeqEnum.MEDICATION_RES_NO.getPrefix(), 4)); | ||||||
|                 medicationRequest.setChineseHerbsDoseQuantity(chineseHerbsDoseQuantity); // 中药付数 |                 medicationRequest.setChineseHerbsDoseQuantity(chineseHerbsDoseQuantity); // 中药付数 | ||||||
|                 medicationRequest.setSufferingFlag(sufferingFlag); // 代煎标识 |                 medicationRequest.setSufferingFlag(sufferingFlag); // 代煎标识 | ||||||
|                 medicationRequest.setQuantity(adviceSaveDto.getQuantity() * chineseHerbsDoseQuantity); // 请求数量 |                 medicationRequest.setQuantity(adviceSaveDto.getQuantity().multiply(chineseHerbsDoseQuantity)); // 请求数量 | ||||||
|                 medicationRequest.setUnitCode(adviceSaveDto.getUnitCode()); // 请求单位编码 |                 medicationRequest.setUnitCode(adviceSaveDto.getUnitCode()); // 请求单位编码 | ||||||
|                 medicationRequest.setLotNumber(adviceSaveDto.getLotNumber()); // 产品批号 |                 medicationRequest.setLotNumber(adviceSaveDto.getLotNumber()); // 产品批号 | ||||||
|                 medicationRequest.setCategoryEnum(adviceSaveDto.getCategoryEnum()); // 请求类型 |                 medicationRequest.setCategoryEnum(adviceSaveDto.getCategoryEnum()); // 请求类型 | ||||||
| @@ -388,7 +388,7 @@ public class DoctorStationChineseMedicalAppServiceImpl implements IDoctorStation | |||||||
|                 chargeItem.setQuantityUnit(medicationRequest.getUnitCode()); // 单位 |                 chargeItem.setQuantityUnit(medicationRequest.getUnitCode()); // 单位 | ||||||
|                 chargeItem.setUnitPrice(adviceSaveDto.getUnitPrice()); // 单价 |                 chargeItem.setUnitPrice(adviceSaveDto.getUnitPrice()); // 单价 | ||||||
|                 // 计算总价,保留4位小数 |                 // 计算总价,保留4位小数 | ||||||
|                 BigDecimal qty = new BigDecimal(chargeItem.getQuantityValue()); |                 BigDecimal qty = chargeItem.getQuantityValue(); | ||||||
|                 chargeItem.setTotalPrice(qty.multiply(chargeItem.getUnitPrice()).setScale(4, RoundingMode.HALF_UP)); // 总价 |                 chargeItem.setTotalPrice(qty.multiply(chargeItem.getUnitPrice()).setScale(4, RoundingMode.HALF_UP)); // 总价 | ||||||
|                 chargeItem.setTotalPrice(adviceSaveDto.getTotalPrice()); // 总价 |                 chargeItem.setTotalPrice(adviceSaveDto.getTotalPrice()); // 总价 | ||||||
|  |  | ||||||
| @@ -411,7 +411,7 @@ public class DoctorStationChineseMedicalAppServiceImpl implements IDoctorStation | |||||||
|             iActivityDefinitionService.getAppointActivityDefinitionId(CommonConstants.BusinessName.SUFFERING_TCM); |             iActivityDefinitionService.getAppointActivityDefinitionId(CommonConstants.BusinessName.SUFFERING_TCM); | ||||||
|         // 签发时,生成中药代煎的账单,只生成一次 |         // 签发时,生成中药代煎的账单,只生成一次 | ||||||
|         if (Whether.YES.getValue().equals(sufferingFlag) && is_sign) { |         if (Whether.YES.getValue().equals(sufferingFlag) && is_sign) { | ||||||
|             Integer quantity = 1; // 请求数量 |             BigDecimal quantity = new BigDecimal("1"); // 请求数量 | ||||||
|  |  | ||||||
|             AdviceBaseDto adviceBaseDto = new AdviceBaseDto(); |             AdviceBaseDto adviceBaseDto = new AdviceBaseDto(); | ||||||
|             adviceBaseDto.setAdviceDefinitionId(sufferingDefinitionId); // 医嘱定义id |             adviceBaseDto.setAdviceDefinitionId(sufferingDefinitionId); // 医嘱定义id | ||||||
| @@ -449,7 +449,7 @@ public class DoctorStationChineseMedicalAppServiceImpl implements IDoctorStation | |||||||
|                         chargeItem.setQuantityUnit(activityAdviceBaseDto.getUnitCode()); // 单位 |                         chargeItem.setQuantityUnit(activityAdviceBaseDto.getUnitCode()); // 单位 | ||||||
|                         chargeItem.setUnitPrice(advicePriceDto.getPrice()); // 单价 |                         chargeItem.setUnitPrice(advicePriceDto.getPrice()); // 单价 | ||||||
|                         // 计算总价,保留4位小数 |                         // 计算总价,保留4位小数 | ||||||
|                         BigDecimal qty = new BigDecimal(quantity); |                         BigDecimal qty = quantity; | ||||||
|                         chargeItem |                         chargeItem | ||||||
|                             .setTotalPrice(qty.multiply(advicePriceDto.getPrice()).setScale(4, RoundingMode.HALF_UP)); // 总价 |                             .setTotalPrice(qty.multiply(advicePriceDto.getPrice()).setScale(4, RoundingMode.HALF_UP)); // 总价 | ||||||
|                         chargeItem.setTcmFlag(Whether.YES.getValue());// 中医标识 |                         chargeItem.setTcmFlag(Whether.YES.getValue());// 中医标识 | ||||||
|   | |||||||
| @@ -6,6 +6,7 @@ import java.util.HashSet; | |||||||
| import java.util.List; | import java.util.List; | ||||||
|  |  | ||||||
| import javax.annotation.Resource; | import javax.annotation.Resource; | ||||||
|  | import javax.servlet.http.HttpServletRequest; | ||||||
|  |  | ||||||
| import org.springframework.beans.BeanUtils; | import org.springframework.beans.BeanUtils; | ||||||
| import org.springframework.stereotype.Service; | import org.springframework.stereotype.Service; | ||||||
| @@ -23,6 +24,7 @@ import com.openhis.clinical.domain.Condition; | |||||||
| import com.openhis.clinical.domain.ConditionDefinition; | import com.openhis.clinical.domain.ConditionDefinition; | ||||||
| import com.openhis.clinical.domain.DiagnosisBelongBinding; | import com.openhis.clinical.domain.DiagnosisBelongBinding; | ||||||
| import com.openhis.clinical.mapper.ConditionDefinitionMapper; | import com.openhis.clinical.mapper.ConditionDefinitionMapper; | ||||||
|  | import com.openhis.clinical.service.IConditionDefinitionService; | ||||||
| import com.openhis.clinical.service.IConditionService; | import com.openhis.clinical.service.IConditionService; | ||||||
| import com.openhis.clinical.service.IDiagnosisBelongBindingService; | import com.openhis.clinical.service.IDiagnosisBelongBindingService; | ||||||
| import com.openhis.common.constant.CommonConstants; | import com.openhis.common.constant.CommonConstants; | ||||||
| @@ -56,6 +58,9 @@ public class DoctorStationDiagnosisAppServiceImpl implements IDoctorStationDiagn | |||||||
|     @Resource |     @Resource | ||||||
|     IEncounterDiagnosisService iEncounterDiagnosisService; |     IEncounterDiagnosisService iEncounterDiagnosisService; | ||||||
|  |  | ||||||
|  |     @Resource | ||||||
|  |     IConditionDefinitionService conditionDefinitionService; | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 新增诊断归属绑定 |      * 新增诊断归属绑定 | ||||||
|      * |      * | ||||||
| @@ -67,7 +72,7 @@ public class DoctorStationDiagnosisAppServiceImpl implements IDoctorStationDiagn | |||||||
|         // 如果绑定类型是个人,objectId 存储当前登录账号id |         // 如果绑定类型是个人,objectId 存储当前登录账号id | ||||||
|         if (BindingType.PERSONAL.getValue().equals(diagnosisBelongBindingDto.getBindingEnum())) { |         if (BindingType.PERSONAL.getValue().equals(diagnosisBelongBindingDto.getBindingEnum())) { | ||||||
|             diagnosisBelongBindingDto.setObjectId(SecurityUtils.getLoginUser().getUserId()); |             diagnosisBelongBindingDto.setObjectId(SecurityUtils.getLoginUser().getUserId()); | ||||||
|         } else if (BindingType.DEFINITION.getValue().equals(diagnosisBelongBindingDto.getBindingEnum())) { |         } else if (BindingType.ORGANIZATION.getValue().equals(diagnosisBelongBindingDto.getBindingEnum())) { | ||||||
|             diagnosisBelongBindingDto.setObjectId(SecurityUtils.getLoginUser().getOrgId()); |             diagnosisBelongBindingDto.setObjectId(SecurityUtils.getLoginUser().getOrgId()); | ||||||
|         } |         } | ||||||
|         DiagnosisBelongBinding diagnosisBelongBinding = new DiagnosisBelongBinding(); |         DiagnosisBelongBinding diagnosisBelongBinding = new DiagnosisBelongBinding(); | ||||||
| @@ -128,7 +133,7 @@ public class DoctorStationDiagnosisAppServiceImpl implements IDoctorStationDiagn | |||||||
|             diagnosisBelongBindingDto, searchKey, new HashSet<>(Arrays.asList("definition_name", "object_name")), null); |             diagnosisBelongBindingDto, searchKey, new HashSet<>(Arrays.asList("definition_name", "object_name")), null); | ||||||
|         IPage<DiagnosisBelongBindingDto> diagnosisBelongBindingPage = |         IPage<DiagnosisBelongBindingDto> diagnosisBelongBindingPage = | ||||||
|             doctorStationDiagnosisAppMapper.getDiagnosisBelongBindingPage(new Page<>(pageNo, pageSize), |             doctorStationDiagnosisAppMapper.getDiagnosisBelongBindingPage(new Page<>(pageNo, pageSize), | ||||||
|                 BindingType.PERSONAL.getValue(), BindingType.DEFINITION.getValue(), queryWrapper); |                 BindingType.PERSONAL.getValue(), BindingType.ORGANIZATION.getValue(), queryWrapper); | ||||||
|         diagnosisBelongBindingPage.getRecords().forEach(e -> { |         diagnosisBelongBindingPage.getRecords().forEach(e -> { | ||||||
|             // 诊断绑定类型 |             // 诊断绑定类型 | ||||||
|             e.setBindingEnum_enumText(EnumUtils.getInfoByValue(BindingType.class, e.getBindingEnum())); |             e.setBindingEnum_enumText(EnumUtils.getInfoByValue(BindingType.class, e.getBindingEnum())); | ||||||
| @@ -167,6 +172,7 @@ public class DoctorStationDiagnosisAppServiceImpl implements IDoctorStationDiagn | |||||||
|         conditionDefinition.setStatusEnum(PublicationStatus.ACTIVE.getValue()); |         conditionDefinition.setStatusEnum(PublicationStatus.ACTIVE.getValue()); | ||||||
|         QueryWrapper<ConditionDefinition> queryWrapper = HisQueryUtils.buildQueryWrapper(conditionDefinition, searchKey, |         QueryWrapper<ConditionDefinition> queryWrapper = HisQueryUtils.buildQueryWrapper(conditionDefinition, searchKey, | ||||||
|             new HashSet<>(Arrays.asList("name", "py_str", "wb_str")), null); |             new HashSet<>(Arrays.asList("name", "py_str", "wb_str")), null); | ||||||
|  |         queryWrapper.eq("status_enum", PublicationStatus.ACTIVE.getValue()); | ||||||
|         // 设置排序 |         // 设置排序 | ||||||
|         queryWrapper.orderByDesc("update_time"); |         queryWrapper.orderByDesc("update_time"); | ||||||
|         // 拼接 用于区分 西医诊断 [1] 中医诊断 [2] 的查询条件 |         // 拼接 用于区分 西医诊断 [1] 中医诊断 [2] 的查询条件 | ||||||
| @@ -263,7 +269,7 @@ public class DoctorStationDiagnosisAppServiceImpl implements IDoctorStationDiagn | |||||||
|         // 科室诊断 |         // 科室诊断 | ||||||
|         Long currentUserOrganizationId = SecurityUtils.getLoginUser().getOrgId(); |         Long currentUserOrganizationId = SecurityUtils.getLoginUser().getOrgId(); | ||||||
|         List<ConditionDefinitionMetadata> organizationList = doctorStationDiagnosisAppMapper.getOrganizationList( |         List<ConditionDefinitionMetadata> organizationList = doctorStationDiagnosisAppMapper.getOrganizationList( | ||||||
|             PublicationStatus.ACTIVE.getValue(), BindingType.DEFINITION.getValue(), currentUserOrganizationId); |             PublicationStatus.ACTIVE.getValue(), BindingType.ORGANIZATION.getValue(), currentUserOrganizationId); | ||||||
|         this.handleConditionDefinitionMetadata(organizationList); |         this.handleConditionDefinitionMetadata(organizationList); | ||||||
|         conditionDefinitionBusinessClass.setOrganizationList(organizationList); |         conditionDefinitionBusinessClass.setOrganizationList(organizationList); | ||||||
|         return R.ok(conditionDefinitionBusinessClass); |         return R.ok(conditionDefinitionBusinessClass); | ||||||
| @@ -337,4 +343,19 @@ public class DoctorStationDiagnosisAppServiceImpl implements IDoctorStationDiagn | |||||||
|         }); |         }); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 查询诊断信息 | ||||||
|  |      * | ||||||
|  |      * @param searchKey 目标字符 | ||||||
|  |      * @param request 请求 | ||||||
|  |      * @return 查询结果 | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public R<?> getDiagnosisList(String searchKey, HttpServletRequest request) { | ||||||
|  |  | ||||||
|  |         List<ConditionDefinition> conditionDefinitionListBySearchKey = | ||||||
|  |             conditionDefinitionService.getConditionDefinitionListBySearchKey(searchKey, request); | ||||||
|  |  | ||||||
|  |         return R.ok(conditionDefinitionListBySearchKey); | ||||||
|  |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -6,52 +6,46 @@ import java.util.stream.Stream; | |||||||
|  |  | ||||||
| import javax.annotation.Resource; | import javax.annotation.Resource; | ||||||
|  |  | ||||||
|  | import org.springframework.beans.BeanUtils; | ||||||
|  | import org.springframework.beans.factory.annotation.Autowired; | ||||||
|  | import org.springframework.stereotype.Service; | ||||||
|  |  | ||||||
| import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | ||||||
| import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper; | import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper; | ||||||
|  | import com.baomidou.mybatisplus.core.metadata.IPage; | ||||||
|  | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||||
|  | import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | ||||||
|  | import com.core.common.core.domain.R; | ||||||
| import com.core.common.core.domain.model.LoginUser; | import com.core.common.core.domain.model.LoginUser; | ||||||
|  | import com.core.common.utils.AssignSeqUtil; | ||||||
| import com.core.common.utils.DateUtils; | import com.core.common.utils.DateUtils; | ||||||
|  | import com.core.common.utils.MessageUtils; | ||||||
| import com.core.common.utils.SecurityUtils; | import com.core.common.utils.SecurityUtils; | ||||||
| import com.openhis.administration.domain.Practitioner; | import com.openhis.administration.domain.Practitioner; | ||||||
| import com.openhis.administration.service.IPractitionerService; | import com.openhis.administration.service.IPractitionerService; | ||||||
| import com.openhis.common.constant.CommonConstants; | import com.openhis.common.constant.PromptMsgConstant; | ||||||
| import com.openhis.common.constant.YbCommonConstants; | import com.openhis.common.enums.AssignSeqEnum; | ||||||
|  | import com.openhis.common.enums.PrescriptionType; | ||||||
|  | import com.openhis.common.enums.RequestStatus; | ||||||
| import com.openhis.common.enums.ybenums.YbRxItemTypeCode; | import com.openhis.common.enums.ybenums.YbRxItemTypeCode; | ||||||
|  | import com.openhis.common.utils.EnumUtils; | ||||||
| import com.openhis.common.utils.HisQueryUtils; | import com.openhis.common.utils.HisQueryUtils; | ||||||
| import com.openhis.financial.domain.Contract; |  | ||||||
| import com.openhis.web.doctorstation.appservice.IDoctorStationElepPrescriptionService; | import com.openhis.web.doctorstation.appservice.IDoctorStationElepPrescriptionService; | ||||||
|  | import com.openhis.web.doctorstation.dto.*; | ||||||
| import com.openhis.web.doctorstation.mapper.DoctorStationElepPrescriptionMapper; | import com.openhis.web.doctorstation.mapper.DoctorStationElepPrescriptionMapper; | ||||||
| import com.openhis.web.inventorymanage.dto.ProductStocktakingInitDto; |  | ||||||
| import com.openhis.web.reportmanage.dto.ChargeReportSearchParam; |  | ||||||
| import com.openhis.workflow.domain.ElepMedicationRequest; | import com.openhis.workflow.domain.ElepMedicationRequest; | ||||||
| import com.openhis.workflow.domain.InventoryItem; |  | ||||||
| import com.openhis.workflow.domain.SupplyRequest; |  | ||||||
| import com.openhis.workflow.mapper.InventoryItemMapper; |  | ||||||
| import com.openhis.workflow.service.IElepMedicationRequestService; | import com.openhis.workflow.service.IElepMedicationRequestService; | ||||||
| import com.openhis.ybcatalog.domain.CatalogDrugInfo; | import com.openhis.ybcatalog.domain.CatalogDrugInfo; | ||||||
| import com.openhis.ybcatalog.domain.CatalogDrugInfoUsual; | import com.openhis.ybcatalog.domain.CatalogDrugInfoUsual; | ||||||
| import com.openhis.ybcatalog.mapper.CatalogDrugInfoUsualMapper; | import com.openhis.ybcatalog.mapper.CatalogDrugInfoUsualMapper; | ||||||
| import com.openhis.ybcatalog.service.ICatalogDrugInfoService; |  | ||||||
| import com.openhis.ybcatalog.service.ICatalogDrugInfoUsualService; | import com.openhis.ybcatalog.service.ICatalogDrugInfoUsualService; | ||||||
| import org.springframework.beans.BeanUtils; |  | ||||||
| import org.springframework.beans.factory.annotation.Autowired; |  | ||||||
| import org.springframework.stereotype.Service; |  | ||||||
| import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; |  | ||||||
| import com.baomidou.mybatisplus.core.metadata.IPage; |  | ||||||
| import com.baomidou.mybatisplus.extension.plugins.pagination.Page; |  | ||||||
| import com.core.common.core.domain.R; |  | ||||||
| import com.core.common.utils.AssignSeqUtil; |  | ||||||
| import com.core.common.utils.MessageUtils; |  | ||||||
| import com.openhis.common.constant.PromptMsgConstant; |  | ||||||
| import com.openhis.common.enums.*; |  | ||||||
| import com.openhis.common.utils.EnumUtils; |  | ||||||
| import com.openhis.web.doctorstation.dto.*; |  | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * 医生站-电子处方 应用实现类 |  * 医生站-电子处方 应用实现类 | ||||||
|  */ |  */ | ||||||
| @Service | @Service | ||||||
| public class DoctorStationElepPrescriptionServiceImpl extends ServiceImpl<CatalogDrugInfoUsualMapper, CatalogDrugInfoUsual> | public class DoctorStationElepPrescriptionServiceImpl extends | ||||||
|         implements IDoctorStationElepPrescriptionService { |     ServiceImpl<CatalogDrugInfoUsualMapper, CatalogDrugInfoUsual> implements IDoctorStationElepPrescriptionService { | ||||||
|     @Autowired |     @Autowired | ||||||
|     ICatalogDrugInfoUsualService catalogDrugInfoUsualService; |     ICatalogDrugInfoUsualService catalogDrugInfoUsualService; | ||||||
|     @Autowired |     @Autowired | ||||||
| @@ -75,15 +69,17 @@ public class DoctorStationElepPrescriptionServiceImpl extends ServiceImpl<Catalo | |||||||
|  |  | ||||||
|         // 处方类别 |         // 处方类别 | ||||||
|         List<ElepPrescriptionInitDto.commonStatusOption> rxTypeCodeListOptions = Stream.of(YbRxItemTypeCode.values()) |         List<ElepPrescriptionInitDto.commonStatusOption> rxTypeCodeListOptions = Stream.of(YbRxItemTypeCode.values()) | ||||||
|                 .map(prescriptionType -> new ElepPrescriptionInitDto.commonStatusOption(prescriptionType.getValue(), |             .map(prescriptionType -> new ElepPrescriptionInitDto.commonStatusOption(prescriptionType.getValue(), | ||||||
|                         prescriptionType.getDescription())) |                 prescriptionType.getDescription())) | ||||||
|                 .collect(Collectors.toList()); |             .collect(Collectors.toList()); | ||||||
| //        //获取诊断信息 |         // //获取诊断信息 | ||||||
| //        List<ElepPrescriptionInitConditionDto> conditionInfoList = elepPrescriptionMapper.selectConditionInfo(encounterId); |         // List<ElepPrescriptionInitConditionDto> conditionInfoList = | ||||||
| //        // 诊断列表 |         // elepPrescriptionMapper.selectConditionInfo(encounterId); | ||||||
| //        List<ElepPrescriptionInitDto.conditionStatusOption> conditionListOptions = conditionInfoList.stream() |         // // 诊断列表 | ||||||
| //                .map(conditionInfo -> new ElepPrescriptionInitDto.conditionStatusOption(conditionInfo.getConditionId(), conditionInfo.getConditionName())) |         // List<ElepPrescriptionInitDto.conditionStatusOption> conditionListOptions = conditionInfoList.stream() | ||||||
| //                .collect(Collectors.toList()); |         // .map(conditionInfo -> new ElepPrescriptionInitDto.conditionStatusOption(conditionInfo.getConditionId(), | ||||||
|  |         // conditionInfo.getConditionName())) | ||||||
|  |         // .collect(Collectors.toList()); | ||||||
|  |  | ||||||
|         initDto.setRxTypeCodeListOptions(rxTypeCodeListOptions); |         initDto.setRxTypeCodeListOptions(rxTypeCodeListOptions); | ||||||
|         return R.ok(initDto); |         return R.ok(initDto); | ||||||
| @@ -92,35 +88,37 @@ public class DoctorStationElepPrescriptionServiceImpl extends ServiceImpl<Catalo | |||||||
|     /** |     /** | ||||||
|      * 获取药品信息 |      * 获取药品信息 | ||||||
|      * |      * | ||||||
|      * @param pageNo    当前页 |      * @param pageNo 当前页 | ||||||
|      * @param pageSize  每页多少条 |      * @param pageSize 每页多少条 | ||||||
|      * @param searchKey 模糊查询关键字 |      * @param searchKey 模糊查询关键字 | ||||||
|      * @return 药品信息 |      * @return 药品信息 | ||||||
|      */ |      */ | ||||||
|     @Override |     @Override | ||||||
|     public R<?> getAllMedicationUsualInfo(String searchKey, Integer pageNo, Integer pageSize) { |     public R<?> getAllMedicationUsualInfo(String searchKey, Integer pageNo, Integer pageSize) { | ||||||
|         //从yb_catalog_drug_info_usual表中取数据 |         // 从yb_catalog_drug_info_usual表中取数据 | ||||||
|         IPage<CatalogDrugInfoUsual> medicationUsualInfo = catalogDrugInfoUsualService.selectCatalogDrugInfoUsual(pageNo, pageSize, searchKey); |         IPage<CatalogDrugInfoUsual> medicationUsualInfo = | ||||||
|  |             catalogDrugInfoUsualService.selectCatalogDrugInfoUsual(pageNo, pageSize, searchKey); | ||||||
|         return R.ok(medicationUsualInfo); |         return R.ok(medicationUsualInfo); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 获取药品信息 |      * 获取药品信息 | ||||||
|      * |      * | ||||||
|      * @param pageNo    当前页 |      * @param pageNo 当前页 | ||||||
|      * @param pageSize  每页多少条 |      * @param pageSize 每页多少条 | ||||||
|      * @param searchKey 模糊查询关键字 |      * @param searchKey 模糊查询关键字 | ||||||
|      * @return 药品信息 |      * @return 药品信息 | ||||||
|      */ |      */ | ||||||
|     @Override |     @Override | ||||||
|     public R<?> getAllMedicationInfo(String searchKey, Integer pageNo, Integer pageSize) { |     public R<?> getAllMedicationInfo(String searchKey, Integer pageNo, Integer pageSize) { | ||||||
|         // 构建查询条件 |         // 构建查询条件 | ||||||
|         QueryWrapper<String> queryWrapper = |         QueryWrapper<String> queryWrapper = HisQueryUtils.buildQueryWrapper(null, searchKey, | ||||||
|                 HisQueryUtils.buildQueryWrapper(null, searchKey, |             new HashSet<>( | ||||||
|                         new HashSet<>(Arrays.asList("registered_name", "pinyin_code", "wubi_code", "approval_no")), |                 Arrays.asList("registered_name", "pinyin_code", "wubi_code", "approval_no", "manufacturer_name")), | ||||||
|                         null); |             null); | ||||||
|         //从yb_catalog_drug_info表中取数据 |         // 从yb_catalog_drug_info表中取数据 | ||||||
|         IPage<CatalogDrugInfo> medicationInfo = elepPrescriptionMapper.selectCatalogDrugInfo(new Page<>(pageNo, pageSize), queryWrapper); |         IPage<CatalogDrugInfo> medicationInfo = | ||||||
|  |             elepPrescriptionMapper.selectCatalogDrugInfo(new Page<>(pageNo, pageSize), queryWrapper); | ||||||
|         return R.ok(medicationInfo); |         return R.ok(medicationInfo); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -128,15 +126,15 @@ public class DoctorStationElepPrescriptionServiceImpl extends ServiceImpl<Catalo | |||||||
|      * 获取处方信息 |      * 获取处方信息 | ||||||
|      * |      * | ||||||
|      * @param patientId 患者id |      * @param patientId 患者id | ||||||
|      * @param pageNo    当前页 |      * @param pageNo 当前页 | ||||||
|      * @param pageSize  每页多少条 |      * @param pageSize 每页多少条 | ||||||
|      * @return 药品信息 |      * @return 药品信息 | ||||||
|      */ |      */ | ||||||
|     @Override |     @Override | ||||||
|     public R<?> getPrescriptionInfo(Long patientId, Integer pageNo, Integer pageSize) { |     public R<?> getPrescriptionInfo(Long patientId, Integer pageNo, Integer pageSize) { | ||||||
|         // 处方信息查询 |         // 处方信息查询 | ||||||
|         IPage<ElepPrescriptionInfoDto> prescriptionInfo = |         IPage<ElepPrescriptionInfoDto> prescriptionInfo = | ||||||
|                 elepPrescriptionMapper.selectElepPrescriptionInfo(new Page<>(pageNo, pageSize), patientId); |             elepPrescriptionMapper.selectElepPrescriptionInfo(new Page<>(pageNo, pageSize), patientId); | ||||||
|         // 状态转换 |         // 状态转换 | ||||||
|         prescriptionInfo.getRecords().forEach(infoDto -> { |         prescriptionInfo.getRecords().forEach(infoDto -> { | ||||||
|             infoDto.setStatusEnum_enumText(EnumUtils.getInfoByValue(RequestStatus.class, infoDto.getStatusEnum())); |             infoDto.setStatusEnum_enumText(EnumUtils.getInfoByValue(RequestStatus.class, infoDto.getStatusEnum())); | ||||||
| @@ -149,15 +147,15 @@ public class DoctorStationElepPrescriptionServiceImpl extends ServiceImpl<Catalo | |||||||
|      * 获取药品信息 |      * 获取药品信息 | ||||||
|      * |      * | ||||||
|      * @param prescriptionNo 处方号 |      * @param prescriptionNo 处方号 | ||||||
|      * @param pageNo         当前页 |      * @param pageNo 当前页 | ||||||
|      * @param pageSize       每页多少条 |      * @param pageSize 每页多少条 | ||||||
|      * @return 药品详细信息 |      * @return 药品详细信息 | ||||||
|      */ |      */ | ||||||
|     @Override |     @Override | ||||||
|     public R<?> getMedicationInfo(String prescriptionNo, Integer pageNo, Integer pageSize) { |     public R<?> getMedicationInfo(String prescriptionNo, Integer pageNo, Integer pageSize) { | ||||||
|         // 药品详细查询 |         // 药品详细查询 | ||||||
|         IPage<ElepMedicationInfoDto> medicationInfo = |         IPage<ElepMedicationInfoDto> medicationInfo = | ||||||
|                 elepPrescriptionMapper.selectMedicationInfo(new Page<>(pageNo, pageSize), prescriptionNo); |             elepPrescriptionMapper.selectMedicationInfo(new Page<>(pageNo, pageSize), prescriptionNo); | ||||||
|         return R.ok(medicationInfo); |         return R.ok(medicationInfo); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -189,7 +187,8 @@ public class DoctorStationElepPrescriptionServiceImpl extends ServiceImpl<Catalo | |||||||
|         Date now = DateUtils.getNowDate(); |         Date now = DateUtils.getNowDate(); | ||||||
|  |  | ||||||
|         // 根据处方号查询处方信息 |         // 根据处方号查询处方信息 | ||||||
|         List<ElepMedicationRequest> requestList = elepMedicationRequestService.selectElepMedicationRequestByPrescriptionNo(prescriptionInfo.getPrescriptionNo()); |         List<ElepMedicationRequest> requestList = elepMedicationRequestService | ||||||
|  |             .selectElepMedicationRequestByPrescriptionNo(prescriptionInfo.getPrescriptionNo()); | ||||||
|         if (!requestList.isEmpty()) { |         if (!requestList.isEmpty()) { | ||||||
|             List<Long> idList = requestList.stream().map(ElepMedicationRequest::getId).collect(Collectors.toList()); |             List<Long> idList = requestList.stream().map(ElepMedicationRequest::getId).collect(Collectors.toList()); | ||||||
|             // 处方信息删除 |             // 处方信息删除 | ||||||
| @@ -205,68 +204,72 @@ public class DoctorStationElepPrescriptionServiceImpl extends ServiceImpl<Catalo | |||||||
|         for (ElepMedicationInfoDto item : prescriptionInfo.getMedicationInfoList()) { |         for (ElepMedicationInfoDto item : prescriptionInfo.getMedicationInfoList()) { | ||||||
|             elepMedicationRequest = new ElepMedicationRequest(); |             elepMedicationRequest = new ElepMedicationRequest(); | ||||||
|             elepMedicationRequest |             elepMedicationRequest | ||||||
|                     // ID |                 // ID | ||||||
|                     .setId(null) |                 .setId(null) | ||||||
|                     // 医院内部处方编号 |                 // 医院内部处方编号 | ||||||
|                     .setPrescriptionNo(prescriptionInfo.getPrescriptionNo()) |                 .setPrescriptionNo(prescriptionInfo.getPrescriptionNo()) | ||||||
|                     // 医院id |                 // 医院id | ||||||
|                     .setOrganizationId(info.getOrganizationId()) |                 .setOrganizationId(info.getOrganizationId()) | ||||||
|                     // 门诊/住院病历号 |                 // 门诊/住院病历号 | ||||||
|                     .setIptOtpNo(info.getIptOtpNo()) |                 .setIptOtpNo(info.getIptOtpNo()) | ||||||
|                     // 科室病区 |                 // 科室病区 | ||||||
|                     .setDepartmentWard(info.getDepartmentWard()) |                 .setDepartmentWard(info.getDepartmentWard()) | ||||||
|                     // 医保类型 |                 // 医保类型 | ||||||
|                     .setInsuranceEnum(info.getInsuranceEnum()) |                 .setInsuranceEnum(info.getInsuranceEnum()) | ||||||
|                     // 开具日期 |                 // 开具日期 | ||||||
|                     .setIssueTime(now) |                 .setIssueTime(now) | ||||||
|                     // 开具科室 |                 // 开具科室 | ||||||
|                     .setOrgId(user.getOrgId()) |                 .setOrgId(user.getOrgId()) | ||||||
|                     // 患者 |                 // 患者 | ||||||
|                     .setPatientId(prescriptionInfo.getPatientId()) |                 .setPatientId(prescriptionInfo.getPatientId()) | ||||||
|                     // 就诊id |                 // 就诊id | ||||||
|                     .setEncounterId(prescriptionInfo.getEncounterId()) |                 .setEncounterId(prescriptionInfo.getEncounterId()) | ||||||
|                     // 诊断id |                 // 诊断id | ||||||
|                     .setConditionId(prescriptionInfo.getConditionId()) |                 .setConditionId(prescriptionInfo.getConditionId()) | ||||||
|                     // 有效天数 |                 // 诊断定义id | ||||||
|                     .setValidityDays(prescriptionInfo.getValidityDays()) |                 .setConditionDefId(prescriptionInfo.getConditionDefId()) | ||||||
|                     // 药品定义id |                 // 慢病字段 普通门诊存空串,慢病存MXXXX | ||||||
|                     .setMedicationId(item.getMedicationId()) |                 .setOpspDiseCode(prescriptionInfo.getOpspDiseCode()) | ||||||
|                     // 药品剂量 |                 // 有效天数 | ||||||
|                     .setMedDosage(item.getMedDosage()) |                 .setValidityDays(prescriptionInfo.getValidityDays()) | ||||||
|                     // 药品剂量单位 |                 // 药品定义id | ||||||
|                     .setMedDosageUnitCode(item.getMedDosageUnitCode()) |                 .setMedicationId(item.getMedicationId()) | ||||||
|                     // 药品频率 |                 // 药品剂量 | ||||||
|                     .setMedFrequency(item.getMedFrequency()) |                 .setMedDosage(item.getMedDosage()) | ||||||
|                     // 药品途径 |                 // 药品剂量单位 | ||||||
|                     .setMedRoute(item.getMedRoute()) |                 .setMedDosageUnitCode(item.getMedDosageUnitCode()) | ||||||
|                     // 请求数量 |                 // 药品频率 | ||||||
|                     .setQuantity(item.getQuantity()) |                 .setMedFrequency(item.getMedFrequency()) | ||||||
|                     // 请求单位 |                 // 药品途径 | ||||||
|                     .setUnitCode(item.getUnitCode()) |                 .setMedRoute(item.getMedRoute()) | ||||||
|                     // 开方医师 |                 // 请求数量 | ||||||
|                     .setPrescribingDrId(user.getId()) |                 .setQuantity(item.getQuantity()) | ||||||
|                     // 处方状态 |                 // 请求单位 | ||||||
|                     .setStatusEnum(RequestStatus.DRAFT.getValue()) |                 .setUnitCode(item.getUnitCode()) | ||||||
|                     // 延长原因 |                 // 开方医师 | ||||||
|                     .setExtensionReason(prescriptionInfo.getExtensionReason()) |                 .setPrescribingDrId(user.getId()) | ||||||
|                     // 处方类别 |                 // 处方状态 | ||||||
|                     .setRxTypeCode(item.getRxTypeCode()) |                 .setStatusEnum(RequestStatus.DRAFT.getValue()) | ||||||
|                     // 处方详细类别 |                 // 延长原因 | ||||||
|                     .setRxItemTypeCode(item.getRxItemTypeCode()) |                 .setExtensionReason(prescriptionInfo.getExtensionReason()) | ||||||
|                     // 支持用药信息 |                 // 处方类别 | ||||||
|                     .setSupportInfo(item.getSupportInfo()) |                 .setRxTypeCode(item.getRxTypeCode()) | ||||||
|                     // 服药时间(开始) |                 // 处方详细类别 | ||||||
|                     .setEffectiveDoseStart(item.getEffectiveDoseStart()) |                 .setRxItemTypeCode(item.getRxItemTypeCode()) | ||||||
|                     // 服药时间(结束) |                 // 支持用药信息 | ||||||
|                     .setEffectiveDoseEnd(item.getEffectiveDoseEnd()) |                 .setSupportInfo(item.getSupportInfo()) | ||||||
|                     // 给药间隔 |                 // 服药时间(开始) | ||||||
|                     .setDispenseInterval(item.getDispenseInterval()) |                 .setEffectiveDoseStart(item.getEffectiveDoseStart()) | ||||||
|                     // 单次发药数 |                 // 服药时间(结束) | ||||||
|                     .setDispensePerQuantity(item.getDispensePerQuantity()) |                 .setEffectiveDoseEnd(item.getEffectiveDoseEnd()) | ||||||
|                     // 每次发药供应天数 |                 // 给药间隔 | ||||||
|                     .setDispensePerDuration(item.getDispensePerDuration()) |                 .setDispenseInterval(item.getDispenseInterval()) | ||||||
|                     // 药品版本号 |                 // 单次发药数 | ||||||
|                     .setVersion(item.getVersion()); |                 .setDispensePerQuantity(item.getDispensePerQuantity()) | ||||||
|  |                 // 每次发药供应天数 | ||||||
|  |                 .setDispensePerDuration(item.getDispensePerDuration()) | ||||||
|  |                 // 药品版本号 | ||||||
|  |                 .setVersion(item.getVersion()); | ||||||
|             elepMedicationRequestList.add(elepMedicationRequest); |             elepMedicationRequestList.add(elepMedicationRequest); | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @@ -281,7 +284,8 @@ public class DoctorStationElepPrescriptionServiceImpl extends ServiceImpl<Catalo | |||||||
|         CatalogDrugInfo drugInfo; |         CatalogDrugInfo drugInfo; | ||||||
|         for (ElepMedicationInfoDto item : prescriptionInfo.getMedicationInfoList()) { |         for (ElepMedicationInfoDto item : prescriptionInfo.getMedicationInfoList()) { | ||||||
|             // 保存常用药品 |             // 保存常用药品 | ||||||
|             usualInfo = baseMapper.selectOne(new LambdaUpdateWrapper<CatalogDrugInfoUsual>().eq(CatalogDrugInfoUsual::getMedicalCatalogCode, item.getMedicationId())); |             usualInfo = baseMapper.selectOne(new LambdaUpdateWrapper<CatalogDrugInfoUsual>() | ||||||
|  |                 .eq(CatalogDrugInfoUsual::getMedicalCatalogCode, item.getMedicationId())); | ||||||
|             if (usualInfo == null) { |             if (usualInfo == null) { | ||||||
|                 drugInfo = elepPrescriptionMapper.selectCatalogDrugInfoByNo(item.getMedicationId(), item.getVersion()); |                 drugInfo = elepPrescriptionMapper.selectCatalogDrugInfoByNo(item.getMedicationId(), item.getVersion()); | ||||||
|                 BeanUtils.copyProperties(drugInfo, usualInfoInsert); |                 BeanUtils.copyProperties(drugInfo, usualInfoInsert); | ||||||
| @@ -292,7 +296,7 @@ public class DoctorStationElepPrescriptionServiceImpl extends ServiceImpl<Catalo | |||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         return R.ok(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00002, new Object[]{"电子处方"})); |         return R.ok(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00002, new Object[] {"电子处方"})); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
| @@ -316,25 +320,25 @@ public class DoctorStationElepPrescriptionServiceImpl extends ServiceImpl<Catalo | |||||||
|         // 修改处方信息 |         // 修改处方信息 | ||||||
|         if (prescriptionInfo.getId() == null) { |         if (prescriptionInfo.getId() == null) { | ||||||
|             elepMedicationRequestList = elepMedicationRequestService |             elepMedicationRequestList = elepMedicationRequestService | ||||||
|                     .selectElepMedicationRequestByPrescriptionNo(prescriptionInfo.getPrescriptionNo()); |                 .selectElepMedicationRequestByPrescriptionNo(prescriptionInfo.getPrescriptionNo()); | ||||||
|             // 判断信息是否存在 |             // 判断信息是否存在 | ||||||
|             if (elepMedicationRequestList == null) { |             if (elepMedicationRequestList == null) { | ||||||
|                 return R.fail(MessageUtils.createMessage(PromptMsgConstant.Common.M00006, null)); |                 return R.fail(MessageUtils.createMessage(PromptMsgConstant.Common.M00006, null)); | ||||||
|             } |             } | ||||||
|             for (ElepMedicationRequest item : elepMedicationRequestList) { |             for (ElepMedicationRequest item : elepMedicationRequestList) { | ||||||
|                 item |                 item | ||||||
|                         // 开具日期 |                     // 开具日期 | ||||||
|                         .setIssueTime(now) |                     .setIssueTime(now) | ||||||
|                         // 开具科室 |                     // 开具科室 | ||||||
|                         .setOrgId(user.getOrgId()) |                     .setOrgId(user.getOrgId()) | ||||||
|                         // 开方医师 |                     // 开方医师 | ||||||
|                         .setPrescribingDrId(user.getId()) |                     .setPrescribingDrId(user.getId()) | ||||||
|                         // 有效天数 |                     // 有效天数 | ||||||
|                         .setValidityDays(prescriptionInfo.getValidityDays()) |                     .setValidityDays(prescriptionInfo.getValidityDays()) | ||||||
|                         // 延长原因 |                     // 延长原因 | ||||||
|                         .setExtensionReason(prescriptionInfo.getExtensionReason()) |                     .setExtensionReason(prescriptionInfo.getExtensionReason()) | ||||||
|                         // 处方类别 |                     // 处方类别 | ||||||
|                         .setRxTypeCode(prescriptionInfo.getRxTypeCode()); |                     .setRxTypeCode(prescriptionInfo.getRxTypeCode()); | ||||||
|             } |             } | ||||||
|             // 修改处方 |             // 修改处方 | ||||||
|             boolean flg = elepMedicationRequestService.updateBatchById(elepMedicationRequestList); |             boolean flg = elepMedicationRequestService.updateBatchById(elepMedicationRequestList); | ||||||
| @@ -350,44 +354,48 @@ public class DoctorStationElepPrescriptionServiceImpl extends ServiceImpl<Catalo | |||||||
|                 return R.fail(MessageUtils.createMessage(PromptMsgConstant.Common.M00006, null)); |                 return R.fail(MessageUtils.createMessage(PromptMsgConstant.Common.M00006, null)); | ||||||
|             } |             } | ||||||
|             elepMedicationRequest |             elepMedicationRequest | ||||||
|                     // 开具日期 |                 // 开具日期 | ||||||
|                     .setIssueTime(now) |                 .setIssueTime(now) | ||||||
|                     // 开具科室 |                 // 开具科室 | ||||||
|                     .setOrgId(user.getOrgId()) |                 .setOrgId(user.getOrgId()) | ||||||
|                     // 开方医师 |                 // 开方医师 | ||||||
|                     .setPrescribingDrId(user.getId()) |                 .setPrescribingDrId(user.getId()) | ||||||
|                     // 药品定义id |                 // 药品定义id | ||||||
|                     .setMedicationId(prescriptionInfo.getMedicationId()) |                 .setMedicationId(prescriptionInfo.getMedicationId()) | ||||||
|                     // 诊断id |                 // 诊断id | ||||||
|                     .setConditionId(prescriptionInfo.getConditionId()) |                 .setConditionId(prescriptionInfo.getConditionId()) | ||||||
|                     // 药品剂量 |                 // 诊断定义id | ||||||
|                     .setMedDosage(prescriptionInfo.getMedDosage()) |                 .setConditionDefId(prescriptionInfo.getConditionDefId()) | ||||||
|                     // 药品剂量单位 |                 // 慢病字段 普通门诊存空串,慢病存MXXXX | ||||||
|                     .setMedDosageUnitCode(prescriptionInfo.getMedDosageUnitCode()) |                 .setOpspDiseCode(prescriptionInfo.getOpspDiseCode()) | ||||||
|                     // 药品频率 |                 // 药品剂量 | ||||||
|                     .setMedFrequency(prescriptionInfo.getMedFrequency()) |                 .setMedDosage(prescriptionInfo.getMedDosage()) | ||||||
|                     // 药品途径 |                 // 药品剂量单位 | ||||||
|                     .setMedRoute(prescriptionInfo.getMedRoute()) |                 .setMedDosageUnitCode(prescriptionInfo.getMedDosageUnitCode()) | ||||||
|                     // 请求数量 |                 // 药品频率 | ||||||
|                     .setQuantity(prescriptionInfo.getQuantity()) |                 .setMedFrequency(prescriptionInfo.getMedFrequency()) | ||||||
|                     // 请求单位 |                 // 药品途径 | ||||||
|                     .setUnitCode(prescriptionInfo.getUnitCode()) |                 .setMedRoute(prescriptionInfo.getMedRoute()) | ||||||
|                     // 支持用药信息 |                 // 请求数量 | ||||||
|                     .setSupportInfo(prescriptionInfo.getSupportInfo()) |                 .setQuantity(prescriptionInfo.getQuantity()) | ||||||
|                     // 服药时间(开始) |                 // 请求单位 | ||||||
|                     .setEffectiveDoseStart(prescriptionInfo.getEffectiveDoseStart()) |                 .setUnitCode(prescriptionInfo.getUnitCode()) | ||||||
|                     // 服药时间(结束) |                 // 支持用药信息 | ||||||
|                     .setEffectiveDoseEnd(prescriptionInfo.getEffectiveDoseEnd()) |                 .setSupportInfo(prescriptionInfo.getSupportInfo()) | ||||||
|                     // 给药间隔 |                 // 服药时间(开始) | ||||||
|                     .setDispenseInterval(prescriptionInfo.getDispenseInterval()) |                 .setEffectiveDoseStart(prescriptionInfo.getEffectiveDoseStart()) | ||||||
|                     // 单次发药数 |                 // 服药时间(结束) | ||||||
|                     .setDispensePerQuantity(prescriptionInfo.getDispensePerQuantity()) |                 .setEffectiveDoseEnd(prescriptionInfo.getEffectiveDoseEnd()) | ||||||
|                     // 处方详细类别 |                 // 给药间隔 | ||||||
|                     .setRxItemTypeCode(prescriptionInfo.getRxItemTypeCode()) |                 .setDispenseInterval(prescriptionInfo.getDispenseInterval()) | ||||||
|                     // 每次发药供应天数 |                 // 单次发药数 | ||||||
|                     .setDispensePerDuration(prescriptionInfo.getDispensePerDuration()) |                 .setDispensePerQuantity(prescriptionInfo.getDispensePerQuantity()) | ||||||
|                     // 药品版本号 |                 // 处方详细类别 | ||||||
|                     .setVersion(prescriptionInfo.getVersion()); |                 .setRxItemTypeCode(prescriptionInfo.getRxItemTypeCode()) | ||||||
|  |                 // 每次发药供应天数 | ||||||
|  |                 .setDispensePerDuration(prescriptionInfo.getDispensePerDuration()) | ||||||
|  |                 // 药品版本号 | ||||||
|  |                 .setVersion(prescriptionInfo.getVersion()); | ||||||
|  |  | ||||||
|             // 修改处方 |             // 修改处方 | ||||||
|             boolean flg = elepMedicationRequestService.updateById(elepMedicationRequest); |             boolean flg = elepMedicationRequestService.updateById(elepMedicationRequest); | ||||||
| @@ -396,7 +404,7 @@ public class DoctorStationElepPrescriptionServiceImpl extends ServiceImpl<Catalo | |||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         return R.ok(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00002, new Object[]{"电子处方"})); |         return R.ok(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00002, new Object[] {"电子处方"})); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
| @@ -413,20 +421,20 @@ public class DoctorStationElepPrescriptionServiceImpl extends ServiceImpl<Catalo | |||||||
|  |  | ||||||
|         if (deletePrescriptionInfoParam.getIdList().isEmpty()) { |         if (deletePrescriptionInfoParam.getIdList().isEmpty()) { | ||||||
|             elepMedicationRequestList = elepMedicationRequestService |             elepMedicationRequestList = elepMedicationRequestService | ||||||
|                     .selectElepMedicationRequestByPrescriptionNoList(deletePrescriptionInfoParam.getPrescriptionNoList()); |                 .selectElepMedicationRequestByPrescriptionNoList(deletePrescriptionInfoParam.getPrescriptionNoList()); | ||||||
|             // 判断信息是否存在 |             // 判断信息是否存在 | ||||||
|             if (elepMedicationRequestList == null) { |             if (elepMedicationRequestList == null) { | ||||||
|                 return R.fail(MessageUtils.createMessage(PromptMsgConstant.Common.M00006, null)); |                 return R.fail(MessageUtils.createMessage(PromptMsgConstant.Common.M00006, null)); | ||||||
|             } |             } | ||||||
|             // 删除处方 |             // 删除处方 | ||||||
|             boolean flg = elepMedicationRequestService |             boolean flg = elepMedicationRequestService | ||||||
|                     .deleteElepMedicationRequestByPrescriptionNo(deletePrescriptionInfoParam.getPrescriptionNoList()); |                 .deleteElepMedicationRequestByPrescriptionNo(deletePrescriptionInfoParam.getPrescriptionNoList()); | ||||||
|             if (!flg) { |             if (!flg) { | ||||||
|                 return R.fail(MessageUtils.createMessage(PromptMsgConstant.Common.M00011, null)); |                 return R.fail(MessageUtils.createMessage(PromptMsgConstant.Common.M00011, null)); | ||||||
|             } |             } | ||||||
|         } else { |         } else { | ||||||
|             elepMedicationRequestList = |             elepMedicationRequestList = | ||||||
|                     elepMedicationRequestService.selectElepMedicationRequestById(deletePrescriptionInfoParam.getIdList()); |                 elepMedicationRequestService.selectElepMedicationRequestById(deletePrescriptionInfoParam.getIdList()); | ||||||
|             // 判断信息是否存在 |             // 判断信息是否存在 | ||||||
|             if (elepMedicationRequestList == null) { |             if (elepMedicationRequestList == null) { | ||||||
|                 return R.fail(MessageUtils.createMessage(PromptMsgConstant.Common.M00006, null)); |                 return R.fail(MessageUtils.createMessage(PromptMsgConstant.Common.M00006, null)); | ||||||
| @@ -437,7 +445,7 @@ public class DoctorStationElepPrescriptionServiceImpl extends ServiceImpl<Catalo | |||||||
|                 return R.fail(MessageUtils.createMessage(PromptMsgConstant.Common.M00011, null)); |                 return R.fail(MessageUtils.createMessage(PromptMsgConstant.Common.M00011, null)); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         return R.ok(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00005, new Object[]{"电子处方"})); |         return R.ok(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00005, new Object[] {"电子处方"})); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
| @@ -450,14 +458,19 @@ public class DoctorStationElepPrescriptionServiceImpl extends ServiceImpl<Catalo | |||||||
|     public R<?> issuancePrescription(List<String> prescriptionNoList) { |     public R<?> issuancePrescription(List<String> prescriptionNoList) { | ||||||
|         // 搜索处方信息 |         // 搜索处方信息 | ||||||
|         List<ElepMedicationRequest> elepMedicationRequestList = |         List<ElepMedicationRequest> elepMedicationRequestList = | ||||||
|                 elepMedicationRequestService.selectElepMedicationRequestByPrescriptionNoList(prescriptionNoList); |             elepMedicationRequestService.selectElepMedicationRequestByPrescriptionNoList(prescriptionNoList); | ||||||
|         // 判断处方是否存在 |         // 判断处方是否存在 | ||||||
|         if (elepMedicationRequestList == null) { |         if (elepMedicationRequestList == null) { | ||||||
|             return R.fail(MessageUtils.createMessage(PromptMsgConstant.Common.M00006, null)); |             return R.fail(MessageUtils.createMessage(PromptMsgConstant.Common.M00006, null)); | ||||||
|         } |         } | ||||||
|         for (ElepMedicationRequest item : elepMedicationRequestList) { |         for (ElepMedicationRequest item : elepMedicationRequestList) { | ||||||
|             // 处方状态 |             if (Objects.equals(item.getStatusEnum(), RequestStatus.DRAFT.getValue()) | ||||||
|             item.setStatusEnum(RequestStatus.ACTIVE.getValue()); |                 || Objects.equals(item.getStatusEnum(), RequestStatus.ENDED.getValue())) { | ||||||
|  |                 // 处方状态 | ||||||
|  |                 item.setStatusEnum(RequestStatus.ACTIVE.getValue()); | ||||||
|  |             } else { | ||||||
|  |                 return R.fail("选择了不能签发的处方"); | ||||||
|  |             } | ||||||
|         } |         } | ||||||
|         // 签发处方 |         // 签发处方 | ||||||
|         boolean flg = elepMedicationRequestService.updateBatchById(elepMedicationRequestList); |         boolean flg = elepMedicationRequestService.updateBatchById(elepMedicationRequestList); | ||||||
| @@ -465,6 +478,6 @@ public class DoctorStationElepPrescriptionServiceImpl extends ServiceImpl<Catalo | |||||||
|             return R.fail(MessageUtils.createMessage(PromptMsgConstant.Common.M00011, null)); |             return R.fail(MessageUtils.createMessage(PromptMsgConstant.Common.M00011, null)); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         return R.ok(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00004, new Object[]{"电子处方"})); |         return R.ok(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00004, new Object[] {"电子处方"})); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -136,7 +136,7 @@ public class DoctorStationEmrAppServiceImpl implements IDoctorStationEmrAppServi | |||||||
|         BeanUtils.copyProperties(emrTemplateDto, emrTemplate); |         BeanUtils.copyProperties(emrTemplateDto, emrTemplate); | ||||||
|         if (BindingType.PERSONAL.getValue().toString().equals(emrTemplateDto.getUseScopeCode())) { |         if (BindingType.PERSONAL.getValue().toString().equals(emrTemplateDto.getUseScopeCode())) { | ||||||
|             emrTemplate.setUserId(SecurityUtils.getLoginUser().getUserId()); |             emrTemplate.setUserId(SecurityUtils.getLoginUser().getUserId()); | ||||||
|         } else if (BindingType.DEFINITION.getValue().toString().equals(emrTemplateDto.getUseScopeCode())) { |         } else if (BindingType.ORGANIZATION.getValue().toString().equals(emrTemplateDto.getUseScopeCode())) { | ||||||
|             emrTemplate.setUserId(SecurityUtils.getLoginUser().getOrgId()); |             emrTemplate.setUserId(SecurityUtils.getLoginUser().getOrgId()); | ||||||
|         } else if (BindingType.HOSPITAL.getValue().toString().equals(emrTemplateDto.getUseScopeCode())) { |         } else if (BindingType.HOSPITAL.getValue().toString().equals(emrTemplateDto.getUseScopeCode())) { | ||||||
|             emrTemplate.setUserId(null); |             emrTemplate.setUserId(null); | ||||||
|   | |||||||
| @@ -62,8 +62,8 @@ public class DoctorStationMainAppServiceImpl implements IDoctorStationMainAppSer | |||||||
|         // 当前登录账号ID |         // 当前登录账号ID | ||||||
|         Long userId = SecurityUtils.getLoginUser().getUserId(); |         Long userId = SecurityUtils.getLoginUser().getUserId(); | ||||||
|         Long currentUserOrganizationId = SecurityUtils.getLoginUser().getOrgId(); |         Long currentUserOrganizationId = SecurityUtils.getLoginUser().getOrgId(); | ||||||
|         // 不是待诊的情况,需要参与者账户id(接诊医生)的条件 |         // 在诊的情况,需要参与者账户id(接诊医生)的条件 | ||||||
|         if (!EncounterStatus.PLANNED.getValue().equals(patientInfoDto.getStatusEnum())) { |         if (EncounterStatus.IN_PROGRESS.getValue().equals(patientInfoDto.getStatusEnum())) { | ||||||
|             patientInfoDto.setJzPractitionerUserId(userId); |             patientInfoDto.setJzPractitionerUserId(userId); | ||||||
|         } |         } | ||||||
|         // 划价时 |         // 划价时 | ||||||
| @@ -83,7 +83,7 @@ public class DoctorStationMainAppServiceImpl implements IDoctorStationMainAppSer | |||||||
|         IPage<PatientInfoDto> patientInfo = doctorStationMainAppMapper.getPatientInfo(new Page<>(pageNo, pageSize), |         IPage<PatientInfoDto> patientInfo = doctorStationMainAppMapper.getPatientInfo(new Page<>(pageNo, pageSize), | ||||||
|             ParticipantType.REGISTRATION_DOCTOR.getCode(), ParticipantType.ADMITTER.getCode(), |             ParticipantType.REGISTRATION_DOCTOR.getCode(), ParticipantType.ADMITTER.getCode(), | ||||||
|             ClinicalStatus.INACTIVE.getValue(), userId, currentUserOrganizationId, pricingFlag, |             ClinicalStatus.INACTIVE.getValue(), userId, currentUserOrganizationId, pricingFlag, | ||||||
|             EncounterStatus.PLANNED.getValue(), queryWrapper); |             EncounterStatus.PLANNED.getValue(), EncounterActivityStatus.ACTIVE.getValue(), queryWrapper); | ||||||
|         patientInfo.getRecords().forEach(e -> { |         patientInfo.getRecords().forEach(e -> { | ||||||
|             // 性别 |             // 性别 | ||||||
|             e.setGenderEnum_enumText(EnumUtils.getInfoByValue(AdministrativeGender.class, e.getGenderEnum())); |             e.setGenderEnum_enumText(EnumUtils.getInfoByValue(AdministrativeGender.class, e.getGenderEnum())); | ||||||
| @@ -108,11 +108,18 @@ public class DoctorStationMainAppServiceImpl implements IDoctorStationMainAppSer | |||||||
|                 .set(Encounter::getReceptionTime, new Date()) |                 .set(Encounter::getReceptionTime, new Date()) | ||||||
|                 .set(Encounter::getStatusEnum, EncounterStatus.IN_PROGRESS.getValue()) |                 .set(Encounter::getStatusEnum, EncounterStatus.IN_PROGRESS.getValue()) | ||||||
|                 .set(Encounter::getSubjectStatusEnum, EncounterSubjectStatus.RECEIVING_CARE.getValue())); |                 .set(Encounter::getSubjectStatusEnum, EncounterSubjectStatus.RECEIVING_CARE.getValue())); | ||||||
|  |         // 先把之前的接诊记录更新为已完成 | ||||||
|  |         iEncounterParticipantService.update(new LambdaUpdateWrapper<EncounterParticipant>() | ||||||
|  |             .eq(EncounterParticipant::getTypeCode, ParticipantType.ADMITTER.getCode()) | ||||||
|  |             .eq(EncounterParticipant::getEncounterId, encounterId) | ||||||
|  |             .set(EncounterParticipant::getStatusEnum, EncounterActivityStatus.COMPLETED.getValue())); | ||||||
|  |  | ||||||
|         // 插入接诊医生参与记录 |         // 插入接诊医生参与记录 | ||||||
|         EncounterParticipant encounterParticipant = new EncounterParticipant(); |         EncounterParticipant encounterParticipant = new EncounterParticipant(); | ||||||
|         encounterParticipant.setEncounterId(encounterId); |         encounterParticipant.setEncounterId(encounterId); | ||||||
|         encounterParticipant.setTypeCode(ParticipantType.ADMITTER.getCode());// 接诊医生 |         encounterParticipant.setTypeCode(ParticipantType.ADMITTER.getCode());// 接诊医生 | ||||||
|         encounterParticipant.setPractitionerId(SecurityUtils.getLoginUser().getPractitionerId()); |         encounterParticipant.setPractitionerId(SecurityUtils.getLoginUser().getPractitionerId()); | ||||||
|  |         encounterParticipant.setStatusEnum(EncounterActivityStatus.ACTIVE.getValue()); // 状态 | ||||||
|         iEncounterParticipantService.save(encounterParticipant); |         iEncounterParticipantService.save(encounterParticipant); | ||||||
|         return update > 0 ? R.ok() : R.fail(); |         return update > 0 ? R.ok() : R.fail(); | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -45,7 +45,12 @@ public class ReservationRecordAppServiceImpl implements IReservationRecordAppSer | |||||||
|         // 当前登录账号的科室id |         // 当前登录账号的科室id | ||||||
|         Long orgId = SecurityUtils.getLoginUser().getOrgId(); |         Long orgId = SecurityUtils.getLoginUser().getOrgId(); | ||||||
|         // 参与者id |         // 参与者id | ||||||
|         Long practitionerId = SecurityUtils.getLoginUser().getPractitionerId(); |         Long practitionerId; | ||||||
|  |         if (reservationRecordDto.getPractitionerId() != null) { | ||||||
|  |             practitionerId = reservationRecordDto.getPractitionerId(); | ||||||
|  |         } else { | ||||||
|  |             practitionerId = SecurityUtils.getLoginUser().getPractitionerId(); | ||||||
|  |         } | ||||||
|  |  | ||||||
|         ReservationRecord reservationRecord = new ReservationRecord(); |         ReservationRecord reservationRecord = new ReservationRecord(); | ||||||
|  |  | ||||||
| @@ -54,6 +59,7 @@ public class ReservationRecordAppServiceImpl implements IReservationRecordAppSer | |||||||
|         reservationRecord.setChiefComplaint(reservationRecordDto.getChiefComplaint()); // 主诉 |         reservationRecord.setChiefComplaint(reservationRecordDto.getChiefComplaint()); // 主诉 | ||||||
|         reservationRecord.setReservationTime(reservationRecordDto.getReservationTime());// 就诊预约时间 |         reservationRecord.setReservationTime(reservationRecordDto.getReservationTime());// 就诊预约时间 | ||||||
|         reservationRecord.setRemark(reservationRecordDto.getRemark()); // 备注 |         reservationRecord.setRemark(reservationRecordDto.getRemark()); // 备注 | ||||||
|  |         reservationRecord.setToothPosition(reservationRecordDto.getToothPosition()); // 牙位 | ||||||
|         reservationRecord.setOrgId(orgId); // 预约科室id |         reservationRecord.setOrgId(orgId); // 预约科室id | ||||||
|         reservationRecord.setPractitionerId(practitionerId); // 预约医生id |         reservationRecord.setPractitionerId(practitionerId); // 预约医生id | ||||||
|         iReservationRecordService.save(reservationRecord); |         iReservationRecordService.save(reservationRecord); | ||||||
| @@ -72,7 +78,12 @@ public class ReservationRecordAppServiceImpl implements IReservationRecordAppSer | |||||||
|         // 当前登录账号的科室id |         // 当前登录账号的科室id | ||||||
|         Long orgId = SecurityUtils.getLoginUser().getOrgId(); |         Long orgId = SecurityUtils.getLoginUser().getOrgId(); | ||||||
|         // 参与者id |         // 参与者id | ||||||
|         Long practitionerId = SecurityUtils.getLoginUser().getPractitionerId(); |         Long practitionerId; | ||||||
|  |         if (reservationRecordDto.getPractitionerId() != null) { | ||||||
|  |             practitionerId = reservationRecordDto.getPractitionerId(); | ||||||
|  |         } else { | ||||||
|  |             practitionerId = SecurityUtils.getLoginUser().getPractitionerId(); | ||||||
|  |         } | ||||||
|  |  | ||||||
|         ReservationRecord reservationRecord = new ReservationRecord(); |         ReservationRecord reservationRecord = new ReservationRecord(); | ||||||
|  |  | ||||||
| @@ -82,6 +93,7 @@ public class ReservationRecordAppServiceImpl implements IReservationRecordAppSer | |||||||
|         reservationRecord.setChiefComplaint(reservationRecordDto.getChiefComplaint()); // 主诉 |         reservationRecord.setChiefComplaint(reservationRecordDto.getChiefComplaint()); // 主诉 | ||||||
|         reservationRecord.setReservationTime(reservationRecordDto.getReservationTime());// 就诊预约时间 |         reservationRecord.setReservationTime(reservationRecordDto.getReservationTime());// 就诊预约时间 | ||||||
|         reservationRecord.setRemark(reservationRecordDto.getRemark()); // 备注 |         reservationRecord.setRemark(reservationRecordDto.getRemark()); // 备注 | ||||||
|  |         reservationRecord.setToothPosition(reservationRecordDto.getToothPosition()); // 牙位 | ||||||
|         reservationRecord.setOrgId(orgId); // 预约科室id |         reservationRecord.setOrgId(orgId); // 预约科室id | ||||||
|         reservationRecord.setPractitionerId(practitionerId); // 预约医生id |         reservationRecord.setPractitionerId(practitionerId); // 预约医生id | ||||||
|         iReservationRecordService.updateById(reservationRecord); |         iReservationRecordService.updateById(reservationRecord); | ||||||
| @@ -114,17 +126,12 @@ public class ReservationRecordAppServiceImpl implements IReservationRecordAppSer | |||||||
|     @Override |     @Override | ||||||
|     public IPage<ReservationRecordDto> getReservationInfo(ReservationRecordDto reservationRecordDto, String searchKey, |     public IPage<ReservationRecordDto> getReservationInfo(ReservationRecordDto reservationRecordDto, String searchKey, | ||||||
|         Integer pageNo, Integer pageSize, HttpServletRequest request) { |         Integer pageNo, Integer pageSize, HttpServletRequest request) { | ||||||
|         // 当前登录账号的科室id |  | ||||||
|         Long orgId = SecurityUtils.getLoginUser().getOrgId(); |  | ||||||
|         // 参与者id |  | ||||||
|         Long practitionerId = SecurityUtils.getLoginUser().getPractitionerId(); |  | ||||||
|  |  | ||||||
|         // 构建查询条件 |         // 构建查询条件 | ||||||
|         QueryWrapper<ReservationRecordDto> queryWrapper = HisQueryUtils.buildQueryWrapper(reservationRecordDto, |         QueryWrapper<ReservationRecordDto> queryWrapper = HisQueryUtils.buildQueryWrapper(reservationRecordDto, | ||||||
|             searchKey, new HashSet<>(Arrays.asList("patient_name", "chief_complaint", "patient_tel")), request); |             searchKey, new HashSet<>(Arrays.asList("patient_name", "chief_complaint", "patient_tel")), request); | ||||||
|  |  | ||||||
|         return reservationRecordAppMapper.getReservationInfo(new Page<>(pageNo, pageSize), orgId, practitionerId, |         return reservationRecordAppMapper.getReservationInfo(new Page<>(pageNo, pageSize), queryWrapper); | ||||||
|             queryWrapper); |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -47,14 +47,25 @@ public class DoctorStationAdviceController { | |||||||
|         @RequestParam(value = "searchKey", defaultValue = "") String searchKey, |         @RequestParam(value = "searchKey", defaultValue = "") String searchKey, | ||||||
|         @RequestParam(value = "locationId", required = false) Long locationId, |         @RequestParam(value = "locationId", required = false) Long locationId, | ||||||
|         @RequestParam(value = "adviceDefinitionIdParamList", required = false) List<Long> adviceDefinitionIdParamList, |         @RequestParam(value = "adviceDefinitionIdParamList", required = false) List<Long> adviceDefinitionIdParamList, | ||||||
|         @RequestParam(value = "organizationId") Long organizationId, |         @RequestParam(value = "organizationId", defaultValue = "0") Long organizationId, | ||||||
|         @RequestParam(value = "adviceTypes") List<Integer> adviceTypes, |         @RequestParam(value = "adviceTypes", defaultValue = "1,2,3") List<Integer> adviceTypes, | ||||||
|         @RequestParam(value = "pageNo", defaultValue = "1") Integer pageNo, |         @RequestParam(value = "pageNo", defaultValue = "1") Integer pageNo, | ||||||
|         @RequestParam(value = "pageSize", defaultValue = "10") Integer pageSize) { |         @RequestParam(value = "pageSize", defaultValue = "10") Integer pageSize) { | ||||||
|         return R.ok(iDoctorStationAdviceAppService.getAdviceBaseInfo(adviceBaseDto, searchKey, locationId, |         return R.ok(iDoctorStationAdviceAppService.getAdviceBaseInfo(adviceBaseDto, searchKey, locationId, | ||||||
|             adviceDefinitionIdParamList, organizationId, pageNo, pageSize, Whether.NO.getValue(), adviceTypes)); |             adviceDefinitionIdParamList, organizationId, pageNo, pageSize, Whether.NO.getValue(), adviceTypes)); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 查询诊疗绑定耗材信息 | ||||||
|  |      *  | ||||||
|  |      * @param activityId 诊疗id | ||||||
|  |      * @return 诊疗绑定耗材信息 | ||||||
|  |      */ | ||||||
|  |     @GetMapping(value = "/activity-bind-device-info") | ||||||
|  |     public R<?> getActivityBindDevice(@RequestParam(value = "activityId") Long activityId) { | ||||||
|  |         return R.ok(iDoctorStationAdviceAppService.getActivityBindDevice(activityId)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 门诊保存医嘱 |      * 门诊保存医嘱 | ||||||
|      *  |      *  | ||||||
|   | |||||||
| @@ -7,6 +7,8 @@ import java.util.List; | |||||||
| import java.util.stream.Collectors; | import java.util.stream.Collectors; | ||||||
| import java.util.stream.Stream; | import java.util.stream.Stream; | ||||||
|  |  | ||||||
|  | import javax.servlet.http.HttpServletRequest; | ||||||
|  |  | ||||||
| import org.springframework.validation.annotation.Validated; | import org.springframework.validation.annotation.Validated; | ||||||
| import org.springframework.web.bind.annotation.*; | import org.springframework.web.bind.annotation.*; | ||||||
|  |  | ||||||
| @@ -160,6 +162,18 @@ public class DoctorStationDiagnosisController { | |||||||
|         return iDoctorStationDiagnosisAppService.getEncounterDiagnosis(encounterId); |         return iDoctorStationDiagnosisAppService.getEncounterDiagnosis(encounterId); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 查询就诊诊断信息 | ||||||
|  |      * | ||||||
|  |      * @param searchKey 目标字符 | ||||||
|  |      * @return 就诊诊断信息 | ||||||
|  |      */ | ||||||
|  |     @GetMapping(value = "/get-diagnosis-list") | ||||||
|  |     public R<?> getDiagnosisList(@RequestParam(value = "searchKey", required = false) String searchKey, | ||||||
|  |         HttpServletRequest request) { | ||||||
|  |         return iDoctorStationDiagnosisAppService.getDiagnosisList(searchKey, request); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 删除就诊诊断信息 |      * 删除就诊诊断信息 | ||||||
|      * |      * | ||||||
|   | |||||||
| @@ -0,0 +1,51 @@ | |||||||
|  | package com.openhis.web.doctorstation.dto; | ||||||
|  |  | ||||||
|  | import java.math.BigDecimal; | ||||||
|  |  | ||||||
|  | import com.fasterxml.jackson.databind.annotation.JsonSerialize; | ||||||
|  | import com.fasterxml.jackson.databind.ser.std.ToStringSerializer; | ||||||
|  | import com.openhis.common.annotation.Dict; | ||||||
|  |  | ||||||
|  | import lombok.Data; | ||||||
|  | import lombok.experimental.Accessors; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 诊疗绑定耗材 详情dto | ||||||
|  |  */ | ||||||
|  | @Data | ||||||
|  | @Accessors(chain = true) | ||||||
|  | public class ActivityBindDeviceDetailDto { | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 用于搭配Dict切面,无实际业务意义 | ||||||
|  |      */ | ||||||
|  |     @Dict(dictCode = "test_field") | ||||||
|  |     private String testField; | ||||||
|  |     private String testField_dictText; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 诊疗id | ||||||
|  |      */ | ||||||
|  |     @JsonSerialize(using = ToStringSerializer.class) | ||||||
|  |     private Long activityId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 耗材id | ||||||
|  |      */ | ||||||
|  |     @JsonSerialize(using = ToStringSerializer.class) | ||||||
|  |     private Long deviceId; | ||||||
|  |  | ||||||
|  |     /** 数量 */ | ||||||
|  |     private BigDecimal quantity; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 单位 | ||||||
|  |      */ | ||||||
|  |     private String unitCode; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 耗材详细信息 | ||||||
|  |      */ | ||||||
|  |     private AdviceBaseDto orderDetailInfos; | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -0,0 +1,28 @@ | |||||||
|  | package com.openhis.web.doctorstation.dto; | ||||||
|  |  | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  | import com.openhis.common.annotation.Dict; | ||||||
|  | import lombok.Data; | ||||||
|  | import lombok.experimental.Accessors; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 诊疗绑定耗材 dto | ||||||
|  |  */ | ||||||
|  | @Data | ||||||
|  | @Accessors(chain = true) | ||||||
|  | public class ActivityBindDeviceDto { | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 用于搭配Dict切面,无实际业务意义 | ||||||
|  |      */ | ||||||
|  |     @Dict(dictCode = "test_field") | ||||||
|  |     private String testField; | ||||||
|  |     private String testField_dictText; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 诊疗绑定耗材详情 | ||||||
|  |      */ | ||||||
|  |     private List<ActivityBindDeviceDetailDto> activityBindDeviceInfos; | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -36,4 +36,10 @@ public class ActivityChildrenJsonParams { | |||||||
|     @JsonSerialize(using = ToStringSerializer.class) |     @JsonSerialize(using = ToStringSerializer.class) | ||||||
|     private Long chargeItemId; |     private Long chargeItemId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 诊疗子项对应的上级ServiceRequestId | ||||||
|  |      */ | ||||||
|  |     @JsonSerialize(using = ToStringSerializer.class) | ||||||
|  |     private Long parentId; | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -133,6 +133,10 @@ public class AdviceBaseDto { | |||||||
|      */ |      */ | ||||||
|     private String supplier; |     private String supplier; | ||||||
|  |  | ||||||
|  |     /** 供应商ID */ | ||||||
|  |     @JsonSerialize(using = ToStringSerializer.class) | ||||||
|  |     private Long supplierId; | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 生产厂家 |      * 生产厂家 | ||||||
|      */ |      */ | ||||||
|   | |||||||
| @@ -23,6 +23,9 @@ public class AdviceInventoryDto { | |||||||
|     @JsonSerialize(using = ToStringSerializer.class) |     @JsonSerialize(using = ToStringSerializer.class) | ||||||
|     private Long itemId; |     private Long itemId; | ||||||
|  |  | ||||||
|  |     /** 目录类别 */ | ||||||
|  |     private String categoryCode; | ||||||
|  |  | ||||||
|     /** 库存id */ |     /** 库存id */ | ||||||
|     @JsonSerialize(using = ToStringSerializer.class) |     @JsonSerialize(using = ToStringSerializer.class) | ||||||
|     private Long inventoryId; |     private Long inventoryId; | ||||||
|   | |||||||
| @@ -70,7 +70,7 @@ public class AdviceSaveDto { | |||||||
|     private String prescriptionNo; |     private String prescriptionNo; | ||||||
|  |  | ||||||
|     /** 请求数量 */ |     /** 请求数量 */ | ||||||
|     private Integer quantity; |     private BigDecimal quantity; | ||||||
|  |  | ||||||
|     /** 每次发药供应天数 */ |     /** 每次发药供应天数 */ | ||||||
|     private Integer dispensePerDuration; |     private Integer dispensePerDuration; | ||||||
| @@ -218,7 +218,7 @@ public class AdviceSaveDto { | |||||||
|     /** |     /** | ||||||
|      * 中药付数 |      * 中药付数 | ||||||
|      */ |      */ | ||||||
|     private Integer chineseHerbsDoseQuantity; |     private BigDecimal chineseHerbsDoseQuantity; | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 代煎标识 | 0:否 , 1:是 |      * 代煎标识 | 0:否 , 1:是 | ||||||
| @@ -234,7 +234,7 @@ public class AdviceSaveDto { | |||||||
|      * 设置默认值 |      * 设置默认值 | ||||||
|      */ |      */ | ||||||
|     public AdviceSaveDto() { |     public AdviceSaveDto() { | ||||||
|         this.chineseHerbsDoseQuantity = 1; |         this.chineseHerbsDoseQuantity = new BigDecimal("1"); | ||||||
|         this.therapyEnum = TherapyTimeType.TEMPORARY.getValue(); |         this.therapyEnum = TherapyTimeType.TEMPORARY.getValue(); | ||||||
|         this.practitionerId = SecurityUtils.getLoginUser().getPractitionerId(); |         this.practitionerId = SecurityUtils.getLoginUser().getPractitionerId(); | ||||||
|         this.founderOrgId = SecurityUtils.getLoginUser().getOrgId(); // 开方人科室 |         this.founderOrgId = SecurityUtils.getLoginUser().getOrgId(); // 开方人科室 | ||||||
|   | |||||||
| @@ -4,19 +4,13 @@ import java.math.BigDecimal; | |||||||
| import java.util.Date; | import java.util.Date; | ||||||
| import java.util.List; | import java.util.List; | ||||||
|  |  | ||||||
| import com.baomidou.mybatisplus.annotation.IdType; |  | ||||||
| import com.baomidou.mybatisplus.annotation.TableId; |  | ||||||
| import com.fasterxml.jackson.annotation.JsonFormat; | import com.fasterxml.jackson.annotation.JsonFormat; | ||||||
|  |  | ||||||
| import com.fasterxml.jackson.databind.annotation.JsonSerialize; | import com.fasterxml.jackson.databind.annotation.JsonSerialize; | ||||||
| import com.fasterxml.jackson.databind.ser.std.ToStringSerializer; | import com.fasterxml.jackson.databind.ser.std.ToStringSerializer; | ||||||
|  |  | ||||||
| import lombok.Data; | import lombok.Data; | ||||||
| import lombok.experimental.Accessors; | import lombok.experimental.Accessors; | ||||||
|  |  | ||||||
| import javax.validation.constraints.NotBlank; |  | ||||||
| import javax.validation.constraints.NotNull; |  | ||||||
| import javax.validation.constraints.Positive; |  | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * 电子处方 dto |  * 电子处方 dto | ||||||
|  */ |  */ | ||||||
| @@ -24,104 +18,82 @@ import javax.validation.constraints.Positive; | |||||||
| @Accessors(chain = true) | @Accessors(chain = true) | ||||||
| public class ElepPrescriptionInfoParam { | public class ElepPrescriptionInfoParam { | ||||||
|  |  | ||||||
|  |     /** 药品信息 */ | ||||||
|  |     List<ElepMedicationInfoDto> medicationInfoList; | ||||||
|     /** ID */ |     /** ID */ | ||||||
|     @JsonSerialize(using = ToStringSerializer.class) |     @JsonSerialize(using = ToStringSerializer.class) | ||||||
|     private Integer id; |     private Integer id; | ||||||
|  |  | ||||||
|     /** 医院内部处方编号 */ |     /** 医院内部处方编号 */ | ||||||
|     private String prescriptionNo; |     private String prescriptionNo; | ||||||
|  |  | ||||||
|     /** 医院id (前台不传) */ |     /** 医院id (前台不传) */ | ||||||
|     @JsonSerialize(using = ToStringSerializer.class) |     @JsonSerialize(using = ToStringSerializer.class) | ||||||
|     private Long organizationId; |     private Long organizationId; | ||||||
|  |  | ||||||
|     /** 门诊/住院病历号 (前台不传) */ |     /** 门诊/住院病历号 (前台不传) */ | ||||||
|     private String iptOtpNo; |     private String iptOtpNo; | ||||||
|  |  | ||||||
|     /** 科室病区 (前台不传) */ |     /** 科室病区 (前台不传) */ | ||||||
|     private String departmentWard; |     private String departmentWard; | ||||||
|  |  | ||||||
|     /** 医保类型 (前台不传) */ |     /** 医保类型 (前台不传) */ | ||||||
|     private Integer insuranceEnum; |     private Integer insuranceEnum; | ||||||
|  |  | ||||||
|     /** 开具日期 (前台不传) */ |     /** 开具日期 (前台不传) */ | ||||||
|     private Date issueTime; |     private Date issueTime; | ||||||
|  |  | ||||||
|     /** 开具科室 (前台不传) */ |     /** 开具科室 (前台不传) */ | ||||||
|     @JsonSerialize(using = ToStringSerializer.class) |     @JsonSerialize(using = ToStringSerializer.class) | ||||||
|     private Long orgId; |     private Long orgId; | ||||||
|  |  | ||||||
|     /** 患者 */ |     /** 患者 */ | ||||||
|     @JsonSerialize(using = ToStringSerializer.class) |     @JsonSerialize(using = ToStringSerializer.class) | ||||||
|     private Long patientId; |     private Long patientId; | ||||||
|  |  | ||||||
|     /** 就诊id */ |     /** 就诊id */ | ||||||
|     @JsonSerialize(using = ToStringSerializer.class) |     @JsonSerialize(using = ToStringSerializer.class) | ||||||
|     private Long encounterId; |     private Long encounterId; | ||||||
|  |  | ||||||
|     /** 诊断id */ |     /** 诊断id */ | ||||||
|     @JsonSerialize(using = ToStringSerializer.class) |     @JsonSerialize(using = ToStringSerializer.class) | ||||||
|     private Long conditionId; |     private Long conditionId; | ||||||
|  |     /** 诊断id */ | ||||||
|  |     @JsonSerialize(using = ToStringSerializer.class) | ||||||
|  |     private Long conditionDefId; | ||||||
|  |     /** 慢病字段 */ | ||||||
|  |     private String opspDiseCode; | ||||||
|     /** 有效天数 */ |     /** 有效天数 */ | ||||||
|     private Integer validityDays; |     private Integer validityDays; | ||||||
|  |  | ||||||
|     /** 药品定义id */ |     /** 药品定义id */ | ||||||
|     private String medicationId; |     private String medicationId; | ||||||
|  |  | ||||||
|     /** 药品剂量 */ |     /** 药品剂量 */ | ||||||
|     private BigDecimal medDosage; |     private BigDecimal medDosage; | ||||||
|     /** 药品剂量单位 */ |     /** 药品剂量单位 */ | ||||||
|     private String medDosageUnitCode; |     private String medDosageUnitCode; | ||||||
|  |  | ||||||
|     /** 药品频率 */ |     /** 药品频率 */ | ||||||
|     private String medFrequency; |     private String medFrequency; | ||||||
|  |  | ||||||
|     /** 药品途径 */ |     /** 药品途径 */ | ||||||
|     private String medRoute; |     private String medRoute; | ||||||
|  |  | ||||||
|     /** 开方医师 (前台不传) */ |     /** 开方医师 (前台不传) */ | ||||||
|     @JsonSerialize(using = ToStringSerializer.class) |     @JsonSerialize(using = ToStringSerializer.class) | ||||||
|     private Long prescribingDrId; |     private Long prescribingDrId; | ||||||
|  |  | ||||||
|     /** 延长原因 */ |     /** 延长原因 */ | ||||||
|     private String extensionReason; |     private String extensionReason; | ||||||
|  |  | ||||||
|     /** 处方状态 (前台不传) */ |     /** 处方状态 (前台不传) */ | ||||||
|     private Integer statusEnum; |     private Integer statusEnum; | ||||||
|  |  | ||||||
|     /** 请求数量 */ |     /** 请求数量 */ | ||||||
|     private Integer quantity; |     private Integer quantity; | ||||||
|  |  | ||||||
|     /** 请求单位 */ |     /** 请求单位 */ | ||||||
|     private String unitCode; |     private String unitCode; | ||||||
|  |  | ||||||
|     /** 处方类别 */ |     /** 处方类别 */ | ||||||
|     private Integer rxTypeCode; |     private Integer rxTypeCode; | ||||||
|     /** 处方类别 */ |     /** 处方类别 */ | ||||||
|     private Integer rxItemTypeCode; |     private Integer rxItemTypeCode; | ||||||
|  |  | ||||||
|     /** 支持用药信息 */ |     /** 支持用药信息 */ | ||||||
|     private String supportInfo; |     private String supportInfo; | ||||||
|     /** 服药时间(开始) */ |     /** 服药时间(开始) */ | ||||||
|     @JsonFormat(shape = JsonFormat.Shape.STRING, pattern = "yyyy-MM-dd HH:mm:ss") |     @JsonFormat(shape = JsonFormat.Shape.STRING, pattern = "yyyy-MM-dd HH:mm:ss") | ||||||
|     private Date effectiveDoseStart; |     private Date effectiveDoseStart; | ||||||
|  |  | ||||||
|     /** 服药时间(结束) */ |     /** 服药时间(结束) */ | ||||||
|     @JsonFormat(shape = JsonFormat.Shape.STRING, pattern = "yyyy-MM-dd HH:mm:ss") |     @JsonFormat(shape = JsonFormat.Shape.STRING, pattern = "yyyy-MM-dd HH:mm:ss") | ||||||
|     private Date effectiveDoseEnd; |     private Date effectiveDoseEnd; | ||||||
|     /** 给药间隔 */ |     /** 给药间隔 */ | ||||||
|     private String dispenseInterval; |     private String dispenseInterval; | ||||||
|  |  | ||||||
|     /** 单次发药数 */ |     /** 单次发药数 */ | ||||||
|     private Integer dispensePerQuantity; |     private Integer dispensePerQuantity; | ||||||
|  |  | ||||||
|     /** 每次发药供应天数 */ |     /** 每次发药供应天数 */ | ||||||
|     private Integer dispensePerDuration; |     private Integer dispensePerDuration; | ||||||
|  |  | ||||||
|     /** 药品版本号 */ |     /** 药品版本号 */ | ||||||
|     private String version; |     private String version; | ||||||
|  |  | ||||||
|     /** 药品信息 */ |  | ||||||
|     List<ElepMedicationInfoDto> medicationInfoList; |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -40,6 +40,11 @@ public class PatientInfoDto { | |||||||
|     @JsonSerialize(using = ToStringSerializer.class) |     @JsonSerialize(using = ToStringSerializer.class) | ||||||
|     private Long orgId; |     private Long orgId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 科室名称 | ||||||
|  |      */ | ||||||
|  |     private String organizationName; | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 患者姓名 |      * 患者姓名 | ||||||
|      */ |      */ | ||||||
|   | |||||||
| @@ -64,4 +64,9 @@ public class ReservationRecordDto { | |||||||
|      */ |      */ | ||||||
|     private String remark; |     private String remark; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 牙位 | ||||||
|  |      */ | ||||||
|  |     private String toothPosition; | ||||||
|  |  | ||||||
| } | } | ||||||
| @@ -68,6 +68,14 @@ public interface DoctorStationAdviceAppMapper { | |||||||
|         @Param("deviceTableName") String deviceTableName, @Param("status1") Integer status1, |         @Param("deviceTableName") String deviceTableName, @Param("status1") Integer status1, | ||||||
|         @Param("status2") Integer status2); |         @Param("status2") Integer status2); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 查询取药科室配置 | ||||||
|  |      *  | ||||||
|  |      * @param organizationId 患者挂号对应的科室id | ||||||
|  |      * @return 取药科室配置 | ||||||
|  |      */ | ||||||
|  |     List<AdviceInventoryDto> getMedLocationConfig(@Param("organizationId") Long organizationId); | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 查询 费用定价子表 |      * 查询 费用定价子表 | ||||||
|      *  |      *  | ||||||
| @@ -112,4 +120,15 @@ public interface DoctorStationAdviceAppMapper { | |||||||
|      */ |      */ | ||||||
|     List<EncounterContractDto> getEncounterContract(@Param("encounterId") Long encounterId); |     List<EncounterContractDto> getEncounterContract(@Param("encounterId") Long encounterId); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 查询诊疗绑定耗材 | ||||||
|  |      *  | ||||||
|  |      * @param activityId 诊疗id | ||||||
|  |      * @param status 启用状态 | ||||||
|  |      * @param tableName 表名 | ||||||
|  |      * @return 诊疗绑定耗材 | ||||||
|  |      */ | ||||||
|  |     List<ActivityBindDeviceDetailDto> getActivityBindDevice(@Param("activityId") String activityId, | ||||||
|  |         @Param("status") Integer status, @Param("tableName") String tableName); | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -30,6 +30,7 @@ public interface DoctorStationMainAppMapper { | |||||||
|      * @param currentUserOrganizationId 当前登录账号所属的科室ID |      * @param currentUserOrganizationId 当前登录账号所属的科室ID | ||||||
|      * @param pricingFlag 划价标记 |      * @param pricingFlag 划价标记 | ||||||
|      * @param encounterStatus 就诊状态 |      * @param encounterStatus 就诊状态 | ||||||
|  |      * @param activityStatus 活跃状态 | ||||||
|      * @param queryWrapper 查询条件 |      * @param queryWrapper 查询条件 | ||||||
|      * @return 就诊患者信息 |      * @return 就诊患者信息 | ||||||
|      */ |      */ | ||||||
| @@ -38,6 +39,7 @@ public interface DoctorStationMainAppMapper { | |||||||
|         @Param("ClinicalStatus") Integer ClinicalStatus, @Param("userId") Long userId, |         @Param("ClinicalStatus") Integer ClinicalStatus, @Param("userId") Long userId, | ||||||
|         @Param("currentUserOrganizationId") Long currentUserOrganizationId, @Param("pricingFlag") Integer pricingFlag, |         @Param("currentUserOrganizationId") Long currentUserOrganizationId, @Param("pricingFlag") Integer pricingFlag, | ||||||
|         @Param("encounterStatus") Integer encounterStatus, |         @Param("encounterStatus") Integer encounterStatus, | ||||||
|  |         @Param("activityStatus") Integer activityStatus, | ||||||
|         @Param(Constants.WRAPPER) QueryWrapper<PatientInfoDto> queryWrapper); |         @Param(Constants.WRAPPER) QueryWrapper<PatientInfoDto> queryWrapper); | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|   | |||||||
| @@ -19,13 +19,10 @@ public interface ReservationRecordAppMapper { | |||||||
|      * 查询 预约记录 |      * 查询 预约记录 | ||||||
|      *  |      *  | ||||||
|      * @param page 分页参数 |      * @param page 分页参数 | ||||||
|      * @param orgId 科室id |  | ||||||
|      * @param practitionerId 参与者id |  | ||||||
|      * @param queryWrapper 查询条件 |      * @param queryWrapper 查询条件 | ||||||
|      * @return 预约记录 |      * @return 预约记录 | ||||||
|      */ |      */ | ||||||
|     IPage<ReservationRecordDto> getReservationInfo(@Param("page") Page<ReservationRecordDto> page, |     IPage<ReservationRecordDto> getReservationInfo(@Param("page") Page<ReservationRecordDto> page, | ||||||
|         @Param("orgId") Long orgId, @Param("practitionerId") Long practitionerId, |  | ||||||
|         @Param(Constants.WRAPPER) QueryWrapper<ReservationRecordDto> queryWrapper); |         @Param(Constants.WRAPPER) QueryWrapper<ReservationRecordDto> queryWrapper); | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -2,10 +2,7 @@ package com.openhis.web.doctorstation.utils; | |||||||
|  |  | ||||||
| import java.math.BigDecimal; | import java.math.BigDecimal; | ||||||
| import java.math.RoundingMode; | import java.math.RoundingMode; | ||||||
| import java.util.ArrayList; | import java.util.*; | ||||||
| import java.util.Date; |  | ||||||
| import java.util.List; |  | ||||||
| import java.util.Map; |  | ||||||
| import java.util.stream.Collectors; | import java.util.stream.Collectors; | ||||||
|  |  | ||||||
| import javax.annotation.Resource; | import javax.annotation.Resource; | ||||||
| @@ -28,6 +25,7 @@ import com.openhis.web.datadictionary.dto.ActivityChildJsonDto; | |||||||
| import com.openhis.web.doctorstation.appservice.IDoctorStationAdviceAppService; | import com.openhis.web.doctorstation.appservice.IDoctorStationAdviceAppService; | ||||||
| import com.openhis.web.doctorstation.dto.*; | import com.openhis.web.doctorstation.dto.*; | ||||||
| import com.openhis.web.doctorstation.mapper.DoctorStationAdviceAppMapper; | import com.openhis.web.doctorstation.mapper.DoctorStationAdviceAppMapper; | ||||||
|  | import com.openhis.web.inhospitalnursestation.dto.MedicationRequestUseExe; | ||||||
| import com.openhis.web.personalization.dto.ActivityDeviceDto; | import com.openhis.web.personalization.dto.ActivityDeviceDto; | ||||||
| import com.openhis.workflow.domain.DeviceRequest; | import com.openhis.workflow.domain.DeviceRequest; | ||||||
| import com.openhis.workflow.domain.ServiceRequest; | import com.openhis.workflow.domain.ServiceRequest; | ||||||
| @@ -102,11 +100,10 @@ public class AdviceUtils { | |||||||
|                     matched = true; |                     matched = true; | ||||||
|                     // 检查库存是否充足 |                     // 检查库存是否充足 | ||||||
|                     BigDecimal minUnitQuantity = saveDto.getMinUnitQuantity(); |                     BigDecimal minUnitQuantity = saveDto.getMinUnitQuantity(); | ||||||
|                     Integer chineseHerbsDoseQuantity = saveDto.getChineseHerbsDoseQuantity(); // 中药付数 |                     BigDecimal chineseHerbsDoseQuantity = saveDto.getChineseHerbsDoseQuantity(); // 中药付数 | ||||||
|                     // 中草药医嘱的情况 |                     // 中草药医嘱的情况 | ||||||
|                     if (chineseHerbsDoseQuantity != null && chineseHerbsDoseQuantity > 0) { |                     if (chineseHerbsDoseQuantity != null && chineseHerbsDoseQuantity.compareTo(BigDecimal.ZERO) > 0) { | ||||||
|                         minUnitQuantity = |                         minUnitQuantity = minUnitQuantity.multiply(chineseHerbsDoseQuantity); | ||||||
|                             minUnitQuantity.multiply(BigDecimal.valueOf(chineseHerbsDoseQuantity.longValue())); |  | ||||||
|                     } |                     } | ||||||
|                     if (minUnitQuantity.compareTo(inventoryDto.getQuantity()) > 0) { |                     if (minUnitQuantity.compareTo(inventoryDto.getQuantity()) > 0) { | ||||||
|                         return saveDto.getAdviceName() + "在" + inventoryDto.getLocationName() + "库存不足"; |                         return saveDto.getAdviceName() + "在" + inventoryDto.getLocationName() + "库存不足"; | ||||||
| @@ -122,6 +119,56 @@ public class AdviceUtils { | |||||||
|         return null; // 校验通过 |         return null; // 校验通过 | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 执行住院医嘱,校验药品库存 | ||||||
|  |      * | ||||||
|  |      * @param medUseExeList 药品请求信息 | ||||||
|  |      * @return 结果 | ||||||
|  |      */ | ||||||
|  |     public String checkExeMedInventory(List<MedicationRequestUseExe> medUseExeList) { | ||||||
|  |         // 医嘱定义id集合 | ||||||
|  |         List<Long> adviceDefinitionIdList = | ||||||
|  |             medUseExeList.stream().map(MedicationRequestUseExe::getMedicationId).collect(Collectors.toList()); | ||||||
|  |         // 医嘱库存集合 | ||||||
|  |         List<AdviceInventoryDto> adviceInventoryList = | ||||||
|  |             doctorStationAdviceAppMapper.getAdviceInventory(null, adviceDefinitionIdList, | ||||||
|  |                 CommonConstants.SqlCondition.ABOUT_INVENTORY_TABLE_STR, PublicationStatus.ACTIVE.getValue()); | ||||||
|  |         // 待发放个数信息 | ||||||
|  |         List<AdviceInventoryDto> adviceDraftInventoryList = doctorStationAdviceAppMapper.getAdviceDraftInventory( | ||||||
|  |             CommonConstants.TableName.MED_MEDICATION_DEFINITION, CommonConstants.TableName.ADM_DEVICE_DEFINITION, | ||||||
|  |             DispenseStatus.DRAFT.getValue(), DispenseStatus.PREPARATION.getValue()); | ||||||
|  |         // 预减库存 | ||||||
|  |         List<AdviceInventoryDto> adviceInventory = | ||||||
|  |             this.subtractInventory(adviceInventoryList, adviceDraftInventoryList); | ||||||
|  |         // 生命提示信息集合 | ||||||
|  |         List<String> tipsList = new ArrayList<>(); | ||||||
|  |         for (MedicationRequestUseExe medicationRequestUseExe : medUseExeList) { | ||||||
|  |             Optional<AdviceInventoryDto> matchedInventory = adviceInventory.stream() | ||||||
|  |                 .filter(inventoryDto -> medicationRequestUseExe.getMedicationId().equals(inventoryDto.getItemId()) | ||||||
|  |                     && CommonConstants.TableName.MED_MEDICATION_DEFINITION.equals(inventoryDto.getItemTable()) | ||||||
|  |                     && medicationRequestUseExe.getPerformLocation().equals(inventoryDto.getLocationId()) | ||||||
|  |                     && medicationRequestUseExe.getLotNumber().equals(inventoryDto.getLotNumber())) | ||||||
|  |                 .findFirst(); | ||||||
|  |             // 匹配到库存信息 | ||||||
|  |             if (matchedInventory.isPresent()) { | ||||||
|  |                 AdviceInventoryDto inventoryDto = matchedInventory.get(); | ||||||
|  |                 if ((medicationRequestUseExe.getExecuteTimesNum() | ||||||
|  |                     .multiply(medicationRequestUseExe.getMinUnitQuantity())) | ||||||
|  |                         .compareTo(inventoryDto.getQuantity()) > 0) { | ||||||
|  |                     tipsList | ||||||
|  |                         .add("【" + medicationRequestUseExe.getBusNo() + "】在" + inventoryDto.getLocationName() + "库存不足"); | ||||||
|  |                 } | ||||||
|  |             } else { | ||||||
|  |                 tipsList.add("【" + medicationRequestUseExe.getBusNo() + "】未匹配到库存信息"); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         if (!tipsList.isEmpty()) { | ||||||
|  |             // 返回库存不足提示信息 | ||||||
|  |             return String.join(";", tipsList); | ||||||
|  |         } | ||||||
|  |         return null; // 校验通过 | ||||||
|  |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 预减库存 |      * 预减库存 | ||||||
|      * |      * | ||||||
| @@ -176,12 +223,12 @@ public class AdviceUtils { | |||||||
|         AdviceBaseDto adviceBaseDto; |         AdviceBaseDto adviceBaseDto; | ||||||
|         ServiceRequest serviceRequest; |         ServiceRequest serviceRequest; | ||||||
|         AdviceBaseDto activityAdviceBaseDto; |         AdviceBaseDto activityAdviceBaseDto; | ||||||
|         Integer quantity; |         BigDecimal quantity; | ||||||
|         ChargeItem chargeItem; |         ChargeItem chargeItem; | ||||||
|         DeviceRequest deviceRequest; |         DeviceRequest deviceRequest; | ||||||
|         // 生成皮试检查对应的请求和账单;生成皮试检查这个诊疗自身的请求,以及皮试检查诊疗绑定的耗材(包括发放) |         // 生成皮试检查对应的请求和账单;生成皮试检查这个诊疗自身的请求,以及皮试检查诊疗绑定的耗材(包括发放) | ||||||
|         if (isSkinTest) { |         if (isSkinTest) { | ||||||
|             quantity = 1; // 请求数量 |             quantity = new BigDecimal("1"); // 请求数量 | ||||||
|             // 皮试检查的诊疗定义id |             // 皮试检查的诊疗定义id | ||||||
|             Long skinTestInspectionDefinitionId = iActivityDefinitionService |             Long skinTestInspectionDefinitionId = iActivityDefinitionService | ||||||
|                 .getAppointActivityDefinitionId(CommonConstants.BusinessName.SKIN_TEST_INSPECTION); |                 .getAppointActivityDefinitionId(CommonConstants.BusinessName.SKIN_TEST_INSPECTION); | ||||||
| @@ -235,7 +282,7 @@ public class AdviceUtils { | |||||||
|                         chargeItem.setQuantityUnit(activityAdviceBaseDto.getUnitCode()); // 单位 |                         chargeItem.setQuantityUnit(activityAdviceBaseDto.getUnitCode()); // 单位 | ||||||
|                         chargeItem.setUnitPrice(advicePriceDto.getPrice()); // 单价 |                         chargeItem.setUnitPrice(advicePriceDto.getPrice()); // 单价 | ||||||
|                         // 计算总价,保留4位小数 |                         // 计算总价,保留4位小数 | ||||||
|                         BigDecimal qty = new BigDecimal(quantity); |                         BigDecimal qty = quantity; | ||||||
|                         chargeItem |                         chargeItem | ||||||
|                             .setTotalPrice(qty.multiply(advicePriceDto.getPrice()).setScale(4, RoundingMode.HALF_UP)); // 总价 |                             .setTotalPrice(qty.multiply(advicePriceDto.getPrice()).setScale(4, RoundingMode.HALF_UP)); // 总价 | ||||||
|                         iChargeItemService.save(chargeItem); |                         iChargeItemService.save(chargeItem); | ||||||
| @@ -301,7 +348,7 @@ public class AdviceUtils { | |||||||
|                         chargeItem.setQuantityUnit(activityAdviceBaseDto.getUnitCode()); // 单位 |                         chargeItem.setQuantityUnit(activityAdviceBaseDto.getUnitCode()); // 单位 | ||||||
|                         chargeItem.setUnitPrice(advicePriceDto.getPrice()); // 单价 |                         chargeItem.setUnitPrice(advicePriceDto.getPrice()); // 单价 | ||||||
|                         // 计算总价,保留4位小数 |                         // 计算总价,保留4位小数 | ||||||
|                         BigDecimal qty = new BigDecimal(quantity); |                         BigDecimal qty = quantity; | ||||||
|                         chargeItem |                         chargeItem | ||||||
|                             .setTotalPrice(qty.multiply(advicePriceDto.getPrice()).setScale(4, RoundingMode.HALF_UP)); // 总价 |                             .setTotalPrice(qty.multiply(advicePriceDto.getPrice()).setScale(4, RoundingMode.HALF_UP)); // 总价 | ||||||
|                         iChargeItemService.save(chargeItem); |                         iChargeItemService.save(chargeItem); | ||||||
| @@ -321,7 +368,7 @@ public class AdviceUtils { | |||||||
|             List<ActivityDeviceDto> tmpActivityList = outpatientRegistrationAppMapper.getTmpActivityList(methodCode, |             List<ActivityDeviceDto> tmpActivityList = outpatientRegistrationAppMapper.getTmpActivityList(methodCode, | ||||||
|                 CommonConstants.TableName.WOR_ACTIVITY_DEFINITION); |                 CommonConstants.TableName.WOR_ACTIVITY_DEFINITION); | ||||||
|             for (ActivityDeviceDto activityDeviceDto : tmpActivityList) { |             for (ActivityDeviceDto activityDeviceDto : tmpActivityList) { | ||||||
|                 quantity = activityDeviceDto.getQuantity() * executeNum; // 请求数量 |                 quantity = activityDeviceDto.getQuantity().multiply(new BigDecimal(executeNum)); // 请求数量 | ||||||
|                 adviceBaseDto = new AdviceBaseDto(); |                 adviceBaseDto = new AdviceBaseDto(); | ||||||
|                 adviceBaseDto.setAdviceDefinitionId(activityDeviceDto.getDevActId()); |                 adviceBaseDto.setAdviceDefinitionId(activityDeviceDto.getDevActId()); | ||||||
|                 // 对应的诊疗医嘱信息 |                 // 对应的诊疗医嘱信息 | ||||||
| @@ -379,7 +426,7 @@ public class AdviceUtils { | |||||||
|                             chargeItem.setQuantityUnit(activityAdviceBaseDto.getUnitCode()); // 单位 |                             chargeItem.setQuantityUnit(activityAdviceBaseDto.getUnitCode()); // 单位 | ||||||
|                             chargeItem.setUnitPrice(advicePriceDto.getPrice()); // 单价 |                             chargeItem.setUnitPrice(advicePriceDto.getPrice()); // 单价 | ||||||
|                             // 计算总价,保留4位小数 |                             // 计算总价,保留4位小数 | ||||||
|                             BigDecimal qty = new BigDecimal(quantity); |                             BigDecimal qty = quantity; | ||||||
|                             chargeItem.setTotalPrice( |                             chargeItem.setTotalPrice( | ||||||
|                                 qty.multiply(advicePriceDto.getPrice()).setScale(4, RoundingMode.HALF_UP)); // 总价 |                                 qty.multiply(advicePriceDto.getPrice()).setScale(4, RoundingMode.HALF_UP)); // 总价 | ||||||
|                             iChargeItemService.saveOrUpdate(chargeItem); |                             iChargeItemService.saveOrUpdate(chargeItem); | ||||||
| @@ -410,7 +457,7 @@ public class AdviceUtils { | |||||||
|                 objectMapper.readValue(childrenJson, new TypeReference<>() {}); |                 objectMapper.readValue(childrenJson, new TypeReference<>() {}); | ||||||
|             // 创建子项的诊疗请求 |             // 创建子项的诊疗请求 | ||||||
|             Long adviceDefinitionId; // 诊疗医嘱定义ID |             Long adviceDefinitionId; // 诊疗医嘱定义ID | ||||||
|             Integer quantity; // 子项请求数量 |             BigDecimal quantity; // 子项请求数量 | ||||||
|             List<ChargeItem> chargeItemList = new ArrayList<>(); // 子项账单集合 |             List<ChargeItem> chargeItemList = new ArrayList<>(); // 子项账单集合 | ||||||
|             ServiceRequest serviceRequest; |             ServiceRequest serviceRequest; | ||||||
|             ChargeItem chargeItem; |             ChargeItem chargeItem; | ||||||
| @@ -443,6 +490,7 @@ public class AdviceUtils { | |||||||
|                         serviceRequest.setEncounterId(activityChildrenJsonParams.getEncounterId()); // 就诊id |                         serviceRequest.setEncounterId(activityChildrenJsonParams.getEncounterId()); // 就诊id | ||||||
|                         serviceRequest.setAuthoredTime(curDate); // 请求签发时间 |                         serviceRequest.setAuthoredTime(curDate); // 请求签发时间 | ||||||
|                         serviceRequest.setOrgId(organizationId); // 执行科室 |                         serviceRequest.setOrgId(organizationId); // 执行科室 | ||||||
|  |                         serviceRequest.setParentId(activityChildrenJsonParams.getParentId()); // 子项诊疗的父id | ||||||
|  |  | ||||||
|                         iServiceRequestService.save(serviceRequest); |                         iServiceRequestService.save(serviceRequest); | ||||||
|  |  | ||||||
| @@ -471,7 +519,7 @@ public class AdviceUtils { | |||||||
|                             chargeItem.setQuantityUnit(activityAdviceBaseDto.getUnitCode()); // 单位 |                             chargeItem.setQuantityUnit(activityAdviceBaseDto.getUnitCode()); // 单位 | ||||||
|                             chargeItem.setUnitPrice(advicePriceDto.getPrice()); // 单价 |                             chargeItem.setUnitPrice(advicePriceDto.getPrice()); // 单价 | ||||||
|                             // 计算总价,保留4位小数 |                             // 计算总价,保留4位小数 | ||||||
|                             BigDecimal qty = new BigDecimal(quantity); |                             BigDecimal qty = quantity; | ||||||
|                             chargeItem.setTotalPrice( |                             chargeItem.setTotalPrice( | ||||||
|                                 qty.multiply(advicePriceDto.getPrice()).setScale(4, RoundingMode.HALF_UP)); // 总价 |                                 qty.multiply(advicePriceDto.getPrice()).setScale(4, RoundingMode.HALF_UP)); // 总价 | ||||||
|                             chargeItemList.add(chargeItem); |                             chargeItemList.add(chargeItem); | ||||||
|   | |||||||
| @@ -14,8 +14,8 @@ import com.openhis.administration.domain.Practitioner; | |||||||
| import com.openhis.administration.service.IOrganizationService; | import com.openhis.administration.service.IOrganizationService; | ||||||
| import com.openhis.administration.service.IPatientService; | import com.openhis.administration.service.IPatientService; | ||||||
| import com.openhis.administration.service.IPractitionerService; | import com.openhis.administration.service.IPractitionerService; | ||||||
| import com.openhis.common.enums.ActivityType; | import com.openhis.common.enums.ActivityDefCategory; | ||||||
| import com.openhis.common.enums.ybenums.YbGender; | import com.openhis.common.enums.AdministrativeGender; | ||||||
| import com.openhis.crosssystem.dto.LisApplyDto; | import com.openhis.crosssystem.dto.LisApplyDto; | ||||||
| import com.openhis.crosssystem.dto.LisApplyGroupDto; | import com.openhis.crosssystem.dto.LisApplyGroupDto; | ||||||
| import com.openhis.crosssystem.dto.PacsApplyDto; | import com.openhis.crosssystem.dto.PacsApplyDto; | ||||||
| @@ -93,15 +93,15 @@ public class DoctorStationSendApplyUtil { | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         // 检验,发送LIS申请 |         // 检验,发送LIS申请 | ||||||
|         if (ActivityType.PROOF.getValue().equals(activityDefinition.getTypeEnum())) { |         if (ActivityDefCategory.PROOF.getCode().equals(activityDefinition.getCategoryCode())) { | ||||||
|             // LIS性别转换 |             // LIS性别转换 | ||||||
|             LisPatientSex lisPatientSex; |             LisPatientSex lisPatientSex; | ||||||
|             if (patient.getGenderEnum() == null) { |             if (patient.getGenderEnum() == null) { | ||||||
|                 lisPatientSex = LisPatientSex.UNKNOWN; |                 lisPatientSex = LisPatientSex.UNKNOWN; | ||||||
|             } else { |             } else { | ||||||
|                 if (YbGender.MALE.getValue().equals(patient.getGenderEnum().toString())) { |                 if (AdministrativeGender.MALE.getValue().equals(patient.getGenderEnum())) { | ||||||
|                     lisPatientSex = LisPatientSex.MALE; |                     lisPatientSex = LisPatientSex.MALE; | ||||||
|                 } else if (YbGender.FEMALE.getValue().equals(patient.getGenderEnum().toString())) { |                 } else if (AdministrativeGender.FEMALE.getValue().equals(patient.getGenderEnum())) { | ||||||
|                     lisPatientSex = LisPatientSex.FEMALE; |                     lisPatientSex = LisPatientSex.FEMALE; | ||||||
|                 } else { |                 } else { | ||||||
|                     lisPatientSex = LisPatientSex.UNKNOWN; |                     lisPatientSex = LisPatientSex.UNKNOWN; | ||||||
| @@ -122,15 +122,15 @@ public class DoctorStationSendApplyUtil { | |||||||
|             crossSystemSendApplyUtil.sendApplyToLis(lisApplyDto); |             crossSystemSendApplyUtil.sendApplyToLis(lisApplyDto); | ||||||
|  |  | ||||||
|             // 检查,发送PACS申请 |             // 检查,发送PACS申请 | ||||||
|         } else if (ActivityType.TEST.getValue().equals(activityDefinition.getTypeEnum())) { |         } else if (ActivityDefCategory.TEST.getCode().equals(activityDefinition.getCategoryCode())) { | ||||||
|             // PACS性别转换 |             // PACS性别转换 | ||||||
|             PacsPatientSex pacsPatientSex; |             PacsPatientSex pacsPatientSex; | ||||||
|             if (patient.getGenderEnum() == null) { |             if (patient.getGenderEnum() == null) { | ||||||
|                 pacsPatientSex = PacsPatientSex.UNKNOWN; |                 pacsPatientSex = PacsPatientSex.UNKNOWN; | ||||||
|             } else { |             } else { | ||||||
|                 if (YbGender.MALE.getValue().equals(patient.getGenderEnum().toString())) { |                 if (AdministrativeGender.MALE.getValue().equals(patient.getGenderEnum())) { | ||||||
|                     pacsPatientSex = PacsPatientSex.MALE; |                     pacsPatientSex = PacsPatientSex.MALE; | ||||||
|                 } else if (YbGender.FEMALE.getValue().equals(patient.getGenderEnum().toString())) { |                 } else if (AdministrativeGender.FEMALE.getValue().equals(patient.getGenderEnum())) { | ||||||
|                     pacsPatientSex = PacsPatientSex.FEMALE; |                     pacsPatientSex = PacsPatientSex.FEMALE; | ||||||
|                 } else { |                 } else { | ||||||
|                     pacsPatientSex = PacsPatientSex.UNKNOWN; |                     pacsPatientSex = PacsPatientSex.UNKNOWN; | ||||||
|   | |||||||
| @@ -103,7 +103,7 @@ public class PrescriptionUtils { | |||||||
|         BigDecimal currentTotal = BigDecimal.ZERO; |         BigDecimal currentTotal = BigDecimal.ZERO; | ||||||
|         for (AdviceSaveDto medicine : medicines) { |         for (AdviceSaveDto medicine : medicines) { | ||||||
|             // 计算单个药品总金额 |             // 计算单个药品总金额 | ||||||
|             BigDecimal medicinePrice = medicine.getUnitPrice().multiply(new BigDecimal(medicine.getQuantity())); |             BigDecimal medicinePrice = medicine.getUnitPrice().multiply(medicine.getQuantity()); | ||||||
|             // 特殊处理:单药品金额超限 |             // 特殊处理:单药品金额超限 | ||||||
|             if (medicinePrice.compareTo(MAX_SINGLE_PRESCRIPTION_PRICE) > 0) { |             if (medicinePrice.compareTo(MAX_SINGLE_PRESCRIPTION_PRICE) > 0) { | ||||||
|                 // 先保存当前组(如果有药品) |                 // 先保存当前组(如果有药品) | ||||||
|   | |||||||
| @@ -26,6 +26,8 @@ public interface IDocDefinitionAppService { | |||||||
|      */ |      */ | ||||||
|     R<?> updateDefinition(DocDefinitionDto definitionDto); |     R<?> updateDefinition(DocDefinitionDto definitionDto); | ||||||
|  |  | ||||||
|  |     R<?> deleteDefinition(Long id); | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 获取文书定义列表 树形结构 |      * 获取文书定义列表 树形结构 | ||||||
|      * |      * | ||||||
|   | |||||||
| @@ -28,7 +28,7 @@ public interface IDocRecordAppService { | |||||||
|     /** |     /** | ||||||
|      * 根据患者ID或就诊ID获取文书记录列表,只针对不需返回患者具体信息的列表,体温单除外,单独处理 |      * 根据患者ID或就诊ID获取文书记录列表,只针对不需返回患者具体信息的列表,体温单除外,单独处理 | ||||||
|      */ |      */ | ||||||
|     R<?> getRecordByEncounterIdList(DocRecordQueryParam docRecordQueryParam, Integer IsPage, Integer pageNo, Integer pageSize, String searchKey, HttpServletRequest request); |     R<?> getRecordByEncounterIdList(DocRecordQueryParam docRecordQueryParam, Integer isPage, Integer pageNo, Integer pageSize, String searchKey, HttpServletRequest request); | ||||||
|  |  | ||||||
|     R<?> getRecordPageList(DocRecordPatientQueryParam docRecordPatientQueryParam, List<Integer> primaryMenuEnumList, Integer pageNo, Integer pageSize, String searchKey, HttpServletRequest request); |     R<?> getRecordPageList(DocRecordPatientQueryParam docRecordPatientQueryParam, List<Integer> primaryMenuEnumList, Integer pageNo, Integer pageSize, String searchKey, HttpServletRequest request); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -2,8 +2,11 @@ package com.openhis.web.document.appservice; | |||||||
|  |  | ||||||
| import com.core.common.core.domain.R; | import com.core.common.core.domain.R; | ||||||
| import com.openhis.document.domain.DocStatistics; | import com.openhis.document.domain.DocStatistics; | ||||||
|  | import com.openhis.web.document.dto.DocRecordQueryParam; | ||||||
| import com.openhis.web.document.dto.DocStatisticsDto; | import com.openhis.web.document.dto.DocStatisticsDto; | ||||||
|  | import com.openhis.web.document.dto.DocStatisticsQueryParam; | ||||||
|  |  | ||||||
|  | import javax.servlet.http.HttpServletRequest; | ||||||
| import java.util.List; | import java.util.List; | ||||||
|  |  | ||||||
| /** | /** | ||||||
| @@ -20,4 +23,6 @@ public interface IDocStatisticsAppService { | |||||||
|  |  | ||||||
|     public R<?> queryByEncounterId(Long encounterId); |     public R<?> queryByEncounterId(Long encounterId); | ||||||
|  |  | ||||||
|  |     R<?> getStatisticsList(DocStatisticsQueryParam queryParam, Integer isPage, Integer pageNo, Integer pageSize, String searchKey, HttpServletRequest request); | ||||||
|  |  | ||||||
| } | } | ||||||
| @@ -38,8 +38,9 @@ public interface IDocStatisticsDefinitionAppService { | |||||||
|      */ |      */ | ||||||
|     public List<DocStatisticsDefinitionDto> getList(Integer isStatistics); |     public List<DocStatisticsDefinitionDto> getList(Integer isStatistics); | ||||||
|  |  | ||||||
|  |     List<DocStatisticsDefinitionDto> getListWithOptionList(Integer isStatistics); | ||||||
|     /** |     /** | ||||||
|      * 获取文档统计定义选项列表并按指定格式返回 |      * 过时obsolete 获取文档统计定义选项列表并按指定格式返回 (key-value) | ||||||
|      * |      * | ||||||
|      * @return 封装了处理结果的响应对象 |      * @return 封装了处理结果的响应对象 | ||||||
|      */ |      */ | ||||||
| @@ -53,22 +54,4 @@ public interface IDocStatisticsDefinitionAppService { | |||||||
|  |  | ||||||
|     public R<?> deleteDocStatisticsDefinition(Long id); |     public R<?> deleteDocStatisticsDefinition(Long id); | ||||||
|  |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 根据id获取文档统计定义 |  | ||||||
|      * |  | ||||||
|      * @param id |  | ||||||
|      * @return 封装了处理结果的响应对象 |  | ||||||
|      */ |  | ||||||
|     public R<?> getDocStatisticsDefinitionById(Long id); |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 根据code获取文档统计定义 |  | ||||||
|      * |  | ||||||
|      * @param code |  | ||||||
|      * @return 封装了处理结果的响应对象 |  | ||||||
|      */ |  | ||||||
|     public R<?> getDocStatisticsDefinitionByCode(String code); |  | ||||||
|  |  | ||||||
|  |  | ||||||
| } | } | ||||||
| @@ -1,36 +0,0 @@ | |||||||
| package com.openhis.web.document.appservice; |  | ||||||
|  |  | ||||||
|  |  | ||||||
| import com.core.common.core.domain.AjaxResult; |  | ||||||
| import com.core.common.core.domain.R; |  | ||||||
| import com.openhis.web.document.dto.DocStatisticsDefinitionOptionDto; |  | ||||||
| import com.openhis.web.document.dto.DocStatisticsDefinitionOptionList; |  | ||||||
|  |  | ||||||
| import java.util.List; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * 文档模板 业务接口 |  | ||||||
|  */ |  | ||||||
| public interface IDocStatisticsDefinitionOptionAppService { |  | ||||||
|  |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 新增、修改文档模板 统计项选项 |  | ||||||
|      * |  | ||||||
|      * @param docStatisticsDefinitionOptionList |  | ||||||
|      */ |  | ||||||
|     public R<?> add(DocStatisticsDefinitionOptionList docStatisticsDefinitionOptionList); |  | ||||||
|  |  | ||||||
|     public R<?> createOrEdit(DocStatisticsDefinitionOptionList docStatisticsDefinitionOptionList); |  | ||||||
|  |  | ||||||
|     public R<?> deleteDocStatisticsDefinitionOptionById(Long id); |  | ||||||
|  |  | ||||||
|     public DocStatisticsDefinitionOptionList getDocStatisticsDefinitionOptionByDefinitionId(Long docStatisticsDefinitionId); |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 获取文档模板 统计项选项列表 |  | ||||||
|      */ |  | ||||||
|     public AjaxResult getDocStatisticsDefinitionOptionList(); |  | ||||||
|  |  | ||||||
|  |  | ||||||
| } |  | ||||||
| @@ -58,6 +58,9 @@ public class DocDefinitionAppServiceImpl implements IDocDefinitionAppService { | |||||||
|         if (definitionDto.getVueRouter() == null || definitionDto.getVueRouter().trim().isEmpty()) { |         if (definitionDto.getVueRouter() == null || definitionDto.getVueRouter().trim().isEmpty()) { | ||||||
|             return R.fail("新增文书定义失败:文书路由不能为空(或不能为空白字符)"); |             return R.fail("新增文书定义失败:文书路由不能为空(或不能为空白字符)"); | ||||||
|         } |         } | ||||||
|  |         if (definitionDto.getUseRangeEnum() != null && DocUseRangeEnum.DEPT_USE.getValue().equals(definitionDto.getUseRangeEnum()) && definitionDto.getOrganizationIds() == null) { | ||||||
|  |             return R.fail("新增文书定义失败:科室分配时,科室不能为空"); | ||||||
|  |         } | ||||||
|  |  | ||||||
|         // 2. 校验"名称+版本号"唯一性(避免重复创建) |         // 2. 校验"名称+版本号"唯一性(避免重复创建) | ||||||
|         long duplicateCount = docDefinitionService.lambdaQuery() |         long duplicateCount = docDefinitionService.lambdaQuery() | ||||||
| @@ -146,7 +149,9 @@ public class DocDefinitionAppServiceImpl implements IDocDefinitionAppService { | |||||||
|         if (definitionDto.getBusNo() == null || definitionDto.getBusNo().trim().isEmpty()) { |         if (definitionDto.getBusNo() == null || definitionDto.getBusNo().trim().isEmpty()) { | ||||||
|             return R.fail("修改文书定义失败:文书业务编号不能为空(或不能为空白字符)"); |             return R.fail("修改文书定义失败:文书业务编号不能为空(或不能为空白字符)"); | ||||||
|         } |         } | ||||||
|  |         if (definitionDto.getUseRangeEnum() != null && DocUseRangeEnum.DEPT_USE.getValue().equals(definitionDto.getUseRangeEnum()) && definitionDto.getOrganizationIds() == null) { | ||||||
|  |             return R.fail("修改文书定义失败:科室分配时,科室不能为空"); | ||||||
|  |         } | ||||||
|         // 2. 校验文书是否存在 |         // 2. 校验文书是否存在 | ||||||
|         DocDefinition existingDoc = docDefinitionService.getById(definitionDto.getId()); |         DocDefinition existingDoc = docDefinitionService.getById(definitionDto.getId()); | ||||||
|         if (existingDoc == null) { |         if (existingDoc == null) { | ||||||
| @@ -193,15 +198,31 @@ public class DocDefinitionAppServiceImpl implements IDocDefinitionAppService { | |||||||
|             log.error("修改文书定义失败:数据库更新异常(ID={}, 业务编号={}", |             log.error("修改文书定义失败:数据库更新异常(ID={}, 业务编号={}", | ||||||
|                     definitionDto.getId(), definitionDto.getBusNo()); |                     definitionDto.getId(), definitionDto.getBusNo()); | ||||||
|             return R.fail("修改文书定义失败:数据库更新操作异常"); |             return R.fail("修改文书定义失败:数据库更新操作异常"); | ||||||
|  |         } else { | ||||||
|  |             // 7. 更新科室分配(仅当使用范围为"科室级"时执行) | ||||||
|  |             DocDefinitionOrganizationDto orgDto = new DocDefinitionOrganizationDto(); | ||||||
|  |             orgDto.setBusNo(existingDoc.getBusNo()); | ||||||
|  |             orgDto.setDefinitionId(existingDoc.getId()); | ||||||
|  |             orgDto.setOrganizationIds(definitionDto.getOrganizationIds()); | ||||||
|  |             // 复用科室分配服务的更新逻辑(先删后加,全量覆盖) | ||||||
|  |             return docDefinitionOrganizationAppService.updateOrganization(orgDto); | ||||||
|         } |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|         // 7. 更新科室分配(仅当使用范围为"科室级"时执行) |     @Override | ||||||
|         DocDefinitionOrganizationDto orgDto = new DocDefinitionOrganizationDto(); |     public R<?> deleteDefinition(Long id) { | ||||||
|         orgDto.setBusNo(existingDoc.getBusNo()); |         // 1. 参数校验 | ||||||
|         orgDto.setDefinitionId(existingDoc.getId()); |         if (id == null) { | ||||||
|         orgDto.setOrganizationIds(definitionDto.getOrganizationIds()); |             return R.fail("删除文书定义失败:文书ID不能为空"); | ||||||
|         // 复用科室分配服务的更新逻辑(先删后加,全量覆盖) |         } | ||||||
|         return docDefinitionOrganizationAppService.updateOrganization(orgDto); |         boolean result = docDefinitionService.removeById(id); | ||||||
|  |         if (result) { | ||||||
|  |             log.info("删除文书定义成功:ID={}", id); | ||||||
|  |             return R.ok("删除文书定义成功"); | ||||||
|  |         } else { | ||||||
|  |             log.error("删除文书定义失败:数据库删除异常(ID={})", id); | ||||||
|  |             return R.fail("删除文书定义失败:数据库删除操作异常"); | ||||||
|  |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|   | |||||||
| @@ -129,9 +129,6 @@ public class DocDefinitionOrganizationAppServiceImpl implements IDocDefinitionOr | |||||||
|         if (definitionOrganizationDto == null) { |         if (definitionOrganizationDto == null) { | ||||||
|             return R.fail("文书科室分配更新失败:请求参数不能为空"); |             return R.fail("文书科室分配更新失败:请求参数不能为空"); | ||||||
|         } |         } | ||||||
|         if (definitionOrganizationDto.getOrganizationIds() == null || definitionOrganizationDto.getOrganizationIds().isEmpty()) { |  | ||||||
|             return R.fail("文书科室分配更新失败:科室ID列表不能为空"); |  | ||||||
|         } |  | ||||||
|         if (definitionOrganizationDto.getDefinitionId() == null || definitionOrganizationDto.getDefinitionId() == 0) { |         if (definitionOrganizationDto.getDefinitionId() == null || definitionOrganizationDto.getDefinitionId() == 0) { | ||||||
|             return R.fail("文书科室分配更新失败:文书定义ID不能为空(或不能为0)"); |             return R.fail("文书科室分配更新失败:文书定义ID不能为空(或不能为0)"); | ||||||
|         } |         } | ||||||
| @@ -140,34 +137,38 @@ public class DocDefinitionOrganizationAppServiceImpl implements IDocDefinitionOr | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         // 2. 先删除原有分配关系 |         // 2. 先删除原有分配关系 | ||||||
|         LambdaQueryWrapper<DocDefinitionOrganization> deleteWrapper = new LambdaQueryWrapper<>(); |         LambdaQueryWrapper<DocDefinitionOrganization> wrapper = new LambdaQueryWrapper<>(); | ||||||
|         deleteWrapper.eq(DocDefinitionOrganization::getDefinitionId, definitionOrganizationDto.getDefinitionId()) |         wrapper.eq(DocDefinitionOrganization::getDefinitionId, definitionOrganizationDto.getDefinitionId()) | ||||||
|                 .eq(DocDefinitionOrganization::getBusNo, definitionOrganizationDto.getBusNo().trim()); |                 .eq(DocDefinitionOrganization::getBusNo, definitionOrganizationDto.getBusNo().trim()); | ||||||
|  |         Long count = docDefinitionOrganizationService.count(wrapper); | ||||||
|         boolean deleteSuccess = docDefinitionOrganizationService.remove(deleteWrapper); |         if (count > 0) { | ||||||
|         if (!deleteSuccess) { |             boolean deleteSuccess = docDefinitionOrganizationService.remove(wrapper); | ||||||
|             log.error("文书科室分配更新失败:删除原有分配记录异常(文书定义ID={}, 业务编号={}", |             if (!deleteSuccess) { | ||||||
|                     definitionOrganizationDto.getDefinitionId(), definitionOrganizationDto.getBusNo()); |                 log.error("文书科室分配更新失败:删除原有分配记录异常(文书定义ID={}, 业务编号={}", | ||||||
|             return R.fail("文书科室分配更新失败:删除原有分配记录异常"); |                         definitionOrganizationDto.getDefinitionId(), definitionOrganizationDto.getBusNo()); | ||||||
|  |                 return R.fail("文书科室分配更新失败:删除原有分配记录异常"); | ||||||
|  |             } | ||||||
|         } |         } | ||||||
|  |         if (definitionOrganizationDto.getOrganizationIds() == null || definitionOrganizationDto.getOrganizationIds().isEmpty()) { | ||||||
|         // 3. 再新增新的分配关系 |  | ||||||
|         List<DocDefinitionOrganization> newOrgList = new ArrayList<>(); |  | ||||||
|         for (Long orgId : definitionOrganizationDto.getOrganizationIds()) { |  | ||||||
|             DocDefinitionOrganization docOrg = new DocDefinitionOrganization(); |  | ||||||
|             docOrg.setDefinitionId(definitionOrganizationDto.getDefinitionId()); |  | ||||||
|             docOrg.setBusNo(definitionOrganizationDto.getBusNo().trim()); |  | ||||||
|             docOrg.setOrganizationId(orgId); |  | ||||||
|             newOrgList.add(docOrg); |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         boolean saveSuccess = docDefinitionOrganizationService.saveBatch(newOrgList); |  | ||||||
|         if (saveSuccess) { |  | ||||||
|             return R.ok("文书科室分配更新成功"); |             return R.ok("文书科室分配更新成功"); | ||||||
|         } else { |         } else { | ||||||
|             log.error("文书科室分配更新失败:新增新分配记录异常(文书定义ID={}, 业务编号={}", |             // 3. 再新增新的分配关系 | ||||||
|                     definitionOrganizationDto.getDefinitionId(), definitionOrganizationDto.getBusNo()); |             List<DocDefinitionOrganization> newOrgList = new ArrayList<>(); | ||||||
|             return R.fail("文书科室分配更新失败:新增新分配记录异常"); |             for (Long orgId : definitionOrganizationDto.getOrganizationIds()) { | ||||||
|  |                 DocDefinitionOrganization docOrg = new DocDefinitionOrganization(); | ||||||
|  |                 docOrg.setDefinitionId(definitionOrganizationDto.getDefinitionId()); | ||||||
|  |                 docOrg.setBusNo(definitionOrganizationDto.getBusNo().trim()); | ||||||
|  |                 docOrg.setOrganizationId(orgId); | ||||||
|  |                 newOrgList.add(docOrg); | ||||||
|  |             } | ||||||
|  |             boolean saveSuccess = docDefinitionOrganizationService.saveBatch(newOrgList); | ||||||
|  |             if (saveSuccess) { | ||||||
|  |                 return R.ok("文书科室分配更新成功"); | ||||||
|  |             } else { | ||||||
|  |                 log.error("文书科室分配更新失败:新增新分配记录异常(文书定义ID={}, 业务编号={}", | ||||||
|  |                         definitionOrganizationDto.getDefinitionId(), definitionOrganizationDto.getBusNo()); | ||||||
|  |                 return R.fail("文书科室分配更新失败:新增新分配记录异常"); | ||||||
|  |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -1,5 +1,8 @@ | |||||||
| package com.openhis.web.document.appservice.impl; | package com.openhis.web.document.appservice.impl; | ||||||
|  |  | ||||||
|  | import com.alibaba.fastjson.JSON; | ||||||
|  | import com.alibaba.fastjson.JSONArray; | ||||||
|  | import com.alibaba.fastjson.JSONObject; | ||||||
| import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | ||||||
| import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | ||||||
| import com.baomidou.mybatisplus.core.metadata.IPage; | import com.baomidou.mybatisplus.core.metadata.IPage; | ||||||
| @@ -19,15 +22,15 @@ import com.openhis.document.mapper.DocRecordMapper; | |||||||
| import com.openhis.document.service.IDocRecordService; | import com.openhis.document.service.IDocRecordService; | ||||||
| import com.openhis.web.document.appservice.IDocDefinitionAppService; | import com.openhis.web.document.appservice.IDocDefinitionAppService; | ||||||
| import com.openhis.web.document.appservice.IDocRecordAppService; | import com.openhis.web.document.appservice.IDocRecordAppService; | ||||||
| import com.openhis.web.document.dto.DocDefinitionDto; | import com.openhis.web.document.appservice.IDocStatisticsAppService; | ||||||
| import com.openhis.web.document.dto.DocRecordDto; | import com.openhis.web.document.appservice.IDocStatisticsDefinitionAppService; | ||||||
| import com.openhis.web.document.dto.DocRecordPatientDto; | import com.openhis.web.document.dto.*; | ||||||
| import com.openhis.web.document.dto.DocRecordPatientQueryParam; |  | ||||||
| import com.openhis.web.document.dto.DocRecordQueryParam; |  | ||||||
| import com.openhis.web.document.mapper.DocRecordAppMapper; | import com.openhis.web.document.mapper.DocRecordAppMapper; | ||||||
|  | import com.openhis.web.document.util.ConvertToDocStatistics; | ||||||
| import com.openhis.web.document.util.PermissionProcessor; | import com.openhis.web.document.util.PermissionProcessor; | ||||||
| import lombok.extern.slf4j.Slf4j; | import lombok.extern.slf4j.Slf4j; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; | import org.springframework.beans.factory.annotation.Autowired; | ||||||
|  | import org.springframework.format.annotation.DateTimeFormat; | ||||||
| import org.springframework.jdbc.core.BatchPreparedStatementSetter; | import org.springframework.jdbc.core.BatchPreparedStatementSetter; | ||||||
| import org.springframework.jdbc.core.JdbcTemplate; | import org.springframework.jdbc.core.JdbcTemplate; | ||||||
| import org.springframework.stereotype.Service; | import org.springframework.stereotype.Service; | ||||||
| @@ -37,6 +40,9 @@ import javax.servlet.http.HttpServletRequest; | |||||||
| import java.sql.PreparedStatement; | import java.sql.PreparedStatement; | ||||||
| import java.sql.SQLException; | import java.sql.SQLException; | ||||||
| import java.sql.Timestamp; | import java.sql.Timestamp; | ||||||
|  | import java.text.SimpleDateFormat; | ||||||
|  | import java.time.LocalDateTime; | ||||||
|  | import java.time.format.DateTimeFormatter; | ||||||
| import java.util.*; | import java.util.*; | ||||||
|  |  | ||||||
| @Slf4j | @Slf4j | ||||||
| @@ -51,6 +57,12 @@ public class DocRecordAppServiceImpl implements IDocRecordAppService { | |||||||
|     private IDocDefinitionAppService docDefinitionAppService; |     private IDocDefinitionAppService docDefinitionAppService; | ||||||
|     @Resource |     @Resource | ||||||
|     private DocRecordAppMapper docRecordAppMapper; |     private DocRecordAppMapper docRecordAppMapper; | ||||||
|  |     @Resource | ||||||
|  |     private IDocStatisticsDefinitionAppService docStatisticsDefinitionAppService; | ||||||
|  |     @Resource | ||||||
|  |     private IDocStatisticsAppService docStatisticsAppService; | ||||||
|  |     @Resource | ||||||
|  |     ConvertToDocStatistics convertToDocStatistics; | ||||||
|     @Autowired |     @Autowired | ||||||
|     private JdbcTemplate jdbcTemplate; // 使用 JdbcTemplate 执行 SQL |     private JdbcTemplate jdbcTemplate; // 使用 JdbcTemplate 执行 SQL | ||||||
|  |  | ||||||
| @@ -198,6 +210,27 @@ public class DocRecordAppServiceImpl implements IDocRecordAppService { | |||||||
|         return ""; |         return ""; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 文书统计 - 新增、编辑记录 | ||||||
|  |      * | ||||||
|  |      * @param docRecordDto | ||||||
|  |      * @return | ||||||
|  |      */ | ||||||
|  |     private R<?> createOrUpdateStatistics(DocRecordDto docRecordDto) { | ||||||
|  |         if (docRecordDto == null) { | ||||||
|  |             return R.fail("插入文书统计数据失败:原始文书记录不能为空"); | ||||||
|  |         } | ||||||
|  |         if (docRecordDto.getContentJson() == null) { | ||||||
|  |             return R.fail("插入文书统计数据失败:原始文书记录内容不能为空"); | ||||||
|  |         } | ||||||
|  |         List<DocStatisticsDto> list = convertToDocStatistics.convertToStatisticsDtoList(docRecordDto); | ||||||
|  |         if (list == null || list.isEmpty()) { | ||||||
|  |             return R.fail("插入文书统计数据失败:统计数据为空"); | ||||||
|  |         } | ||||||
|  |         return docStatisticsAppService.createOrUpdte(list); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 新增记录 |      * 新增记录 | ||||||
|      * |      * | ||||||
| @@ -213,7 +246,6 @@ public class DocRecordAppServiceImpl implements IDocRecordAppService { | |||||||
|         docRecord.setDefinitionId(docRecordDto.getDefinitionId()); |         docRecord.setDefinitionId(docRecordDto.getDefinitionId()); | ||||||
|         docRecord.setDefinitionBusNo(docRecordDto.getDefinitionBusNo()); |         docRecord.setDefinitionBusNo(docRecordDto.getDefinitionBusNo()); | ||||||
|         docRecord.setContentJson(docRecordDto.getContentJson()); |         docRecord.setContentJson(docRecordDto.getContentJson()); | ||||||
|         // 状态默认设为草稿(修复原逻辑:原代码先判断再覆盖,导致默认值无效) |  | ||||||
|         docRecord.setStatusEnum(docRecordDto.getStatusEnum() == null ? DocStatusEnum.DRAFT.getValue() : docRecordDto.getStatusEnum()); |         docRecord.setStatusEnum(docRecordDto.getStatusEnum() == null ? DocStatusEnum.DRAFT.getValue() : docRecordDto.getStatusEnum()); | ||||||
|         docRecord.setOrganizationId(SecurityUtils.getLoginUser().getOrgId()); |         docRecord.setOrganizationId(SecurityUtils.getLoginUser().getOrgId()); | ||||||
|         docRecord.setEncounterId(docRecordDto.getEncounterId()); |         docRecord.setEncounterId(docRecordDto.getEncounterId()); | ||||||
| @@ -222,6 +254,8 @@ public class DocRecordAppServiceImpl implements IDocRecordAppService { | |||||||
|         docRecord.setIsEdit(0); |         docRecord.setIsEdit(0); | ||||||
|         boolean saveSuccess = docRecordService.save(docRecord); |         boolean saveSuccess = docRecordService.save(docRecord); | ||||||
|         if (saveSuccess) { |         if (saveSuccess) { | ||||||
|  |             docRecordDto.setId(docRecord.getId()); | ||||||
|  |             createOrUpdateStatistics(docRecordDto); | ||||||
|             return R.ok("新增患者文书记录成功"); |             return R.ok("新增患者文书记录成功"); | ||||||
|         } else { |         } else { | ||||||
|             return R.fail("新增患者文书记录失败"); |             return R.fail("新增患者文书记录失败"); | ||||||
| @@ -259,7 +293,6 @@ public class DocRecordAppServiceImpl implements IDocRecordAppService { | |||||||
|         docRecord.setPatientId(docRecordDto.getPatientId()); |         docRecord.setPatientId(docRecordDto.getPatientId()); | ||||||
|         docRecord.setRecordTime(docRecordDto.getRecordTime()); |         docRecord.setRecordTime(docRecordDto.getRecordTime()); | ||||||
|         docRecord.setIsEdit(0); |         docRecord.setIsEdit(0); | ||||||
|  |  | ||||||
|         // 执行修改 |         // 执行修改 | ||||||
|         boolean updateSuccess = docRecordService.updateById(docRecord); |         boolean updateSuccess = docRecordService.updateById(docRecord); | ||||||
|         if (updateSuccess) { |         if (updateSuccess) { | ||||||
| @@ -268,6 +301,7 @@ public class DocRecordAppServiceImpl implements IDocRecordAppService { | |||||||
|             if (!logSuccess) { |             if (!logSuccess) { | ||||||
|                 return R.fail("修改患者文书记录成功,但插入文档操作日志失败"); |                 return R.fail("修改患者文书记录成功,但插入文档操作日志失败"); | ||||||
|             } |             } | ||||||
|  |             createOrUpdateStatistics(docRecordDto); | ||||||
|             return R.ok("修改患者文书记录成功"); |             return R.ok("修改患者文书记录成功"); | ||||||
|         } else { |         } else { | ||||||
|             return R.fail("修改患者文书记录失败"); |             return R.fail("修改患者文书记录失败"); | ||||||
| @@ -287,19 +321,16 @@ public class DocRecordAppServiceImpl implements IDocRecordAppService { | |||||||
|             return R.fail("患者文书记录:患者ID和就诊ID不能同时为空"); |             return R.fail("患者文书记录:患者ID和就诊ID不能同时为空"); | ||||||
|         } |         } | ||||||
|         if (docRecordQueryParam.getDefinitionId() == null) { |         if (docRecordQueryParam.getDefinitionId() == null) { | ||||||
|             return R.fail("患者文书记录:文书类型ID不能为空"); |             return R.fail("患者文书记录:文书类型(定义)ID不能为空"); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         // 2. 分页查询逻辑 |         // 2. 分页查询逻辑 | ||||||
|         if (isPage != null && isPage == 1) { |         if (isPage != null && isPage == 1) { | ||||||
|             QueryWrapper<DocRecord> queryWrapper = HisQueryUtils.buildQueryWrapper( |             QueryWrapper<DocRecordDto> queryWrapper = HisQueryUtils.buildQueryWrapper( | ||||||
|                     docRecordQueryParam, null, null, request); |                     docRecordQueryParam, null, null, request); | ||||||
|             // 按记录时间倒序(最新记录在前) |             IPage<DocRecordDto> pageResult = docRecordAppMapper.getRecordPageListByEncounterId( | ||||||
|             queryWrapper.lambda().orderByDesc(DocRecord::getRecordTime); |                     new Page<>(pageNo, pageSize), queryWrapper); | ||||||
|  |             return R.ok(pageResult, "获取患者文书记录列表成功"); | ||||||
|             Page<DocRecordDto> recordPage = HisPageUtils.selectPage( |  | ||||||
|                     docRecordMapper, queryWrapper, pageNo, pageSize, DocRecordDto.class); |  | ||||||
|             return R.ok(recordPage, "获取患者文书记录列表成功"); |  | ||||||
|         } |         } | ||||||
|         // 3. 不分页查询逻辑 |         // 3. 不分页查询逻辑 | ||||||
|         else { |         else { | ||||||
| @@ -319,12 +350,15 @@ public class DocRecordAppServiceImpl implements IDocRecordAppService { | |||||||
|                 queryWrapper.eq(DocRecord::getOrganizationId, docRecordQueryParam.getOrganizationId()); |                 queryWrapper.eq(DocRecord::getOrganizationId, docRecordQueryParam.getOrganizationId()); | ||||||
|             } |             } | ||||||
|  |  | ||||||
|  |    DocDefinitionDto docDefinitionDto = docDefinitionAppService.getDefinitionById(docRecordQueryParam.getDefinitionId()); | ||||||
|             // 实体转DTO |             // 实体转DTO | ||||||
|             List<DocRecordDto> dtoList = new ArrayList<>(); |             List<DocRecordDto> dtoList = new ArrayList<>(); | ||||||
|             List<DocRecord> recordList = docRecordService.list(queryWrapper); |             List<DocRecord> recordList = docRecordService.list(queryWrapper); | ||||||
|             for (DocRecord record : recordList) { |             for (DocRecord record : recordList) { | ||||||
|                 DocRecordDto dto = new DocRecordDto(); |                 DocRecordDto dto = new DocRecordDto(); | ||||||
|                 BeanUtils.copyProperties(record, dto); |                 BeanUtils.copyProperties(record, dto); | ||||||
|  |                 dto.setName(docDefinitionDto!=null?docDefinitionDto.getName():""); | ||||||
|  |                 dto.setVersion(docDefinitionDto!=null?docDefinitionDto.getVersion():""); | ||||||
|                 dtoList.add(dto); |                 dtoList.add(dto); | ||||||
|             } |             } | ||||||
|             return R.ok(dtoList, "获取患者文书记录列表成功"); |             return R.ok(dtoList, "获取患者文书记录列表成功"); | ||||||
|   | |||||||
| @@ -1,16 +1,25 @@ | |||||||
| package com.openhis.web.document.appservice.impl; | package com.openhis.web.document.appservice.impl; | ||||||
|  |  | ||||||
| import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | ||||||
|  | import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | ||||||
|  | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||||
| import com.core.common.core.domain.R; | import com.core.common.core.domain.R; | ||||||
|  | import com.core.common.utils.SecurityUtils; | ||||||
|  | import com.core.common.utils.bean.BeanUtils; | ||||||
|  | import com.openhis.common.utils.HisPageUtils; | ||||||
|  | import com.openhis.common.utils.HisQueryUtils; | ||||||
| import com.openhis.document.domain.DocStatistics; | import com.openhis.document.domain.DocStatistics; | ||||||
|  | import com.openhis.document.mapper.DocStatisticsMapper; | ||||||
| import com.openhis.document.service.IDocStatisticsService; | import com.openhis.document.service.IDocStatisticsService; | ||||||
| import com.openhis.web.document.appservice.IDocStatisticsAppService; | import com.openhis.web.document.appservice.IDocStatisticsAppService; | ||||||
| import com.openhis.web.document.appservice.IDocTemplateAppService; |  | ||||||
| import com.openhis.web.document.dto.DocStatisticsDto; | import com.openhis.web.document.dto.DocStatisticsDto; | ||||||
|  | import com.openhis.web.document.dto.DocStatisticsQueryParam; | ||||||
| import lombok.extern.slf4j.Slf4j; | import lombok.extern.slf4j.Slf4j; | ||||||
| import org.springframework.stereotype.Service; | import org.springframework.stereotype.Service; | ||||||
|  |  | ||||||
| import javax.annotation.Resource; | import javax.annotation.Resource; | ||||||
|  | import javax.servlet.http.HttpServletRequest; | ||||||
|  | import java.util.ArrayList; | ||||||
| import java.util.List; | import java.util.List; | ||||||
|  |  | ||||||
| /** | /** | ||||||
| @@ -22,6 +31,9 @@ public class DocStatisticsAppServiceImpl implements IDocStatisticsAppService { | |||||||
|  |  | ||||||
|     @Resource |     @Resource | ||||||
|     private IDocStatisticsService docStatisticsService; |     private IDocStatisticsService docStatisticsService; | ||||||
|  |     @Resource | ||||||
|  |     private DocStatisticsMapper docStatisticsMapper; | ||||||
|  |  | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public R<?> createOrUpdte(List<DocStatisticsDto> docStatisticsList) { |     public R<?> createOrUpdte(List<DocStatisticsDto> docStatisticsList) { | ||||||
| @@ -31,12 +43,13 @@ public class DocStatisticsAppServiceImpl implements IDocStatisticsAppService { | |||||||
|         //根据recordId和statisticDefinitionId判断是否存在,存在则更新,不存在则新增 |         //根据recordId和statisticDefinitionId判断是否存在,存在则更新,不存在则新增 | ||||||
|         LambdaQueryWrapper<DocStatistics> queryWrapper = new LambdaQueryWrapper<>(); |         LambdaQueryWrapper<DocStatistics> queryWrapper = new LambdaQueryWrapper<>(); | ||||||
|         queryWrapper.eq(DocStatistics::getRecordId, docStatisticsList.get(0).getRecordId()); |         queryWrapper.eq(DocStatistics::getRecordId, docStatisticsList.get(0).getRecordId()); | ||||||
|         queryWrapper.eq(DocStatistics::getStatisticDefinitionId, docStatisticsList.get(0).getStatisticDefinitionId()); | //        queryWrapper.eq(DocStatistics::getStatisticDefinitionId, docStatisticsList.get(0).getStatisticDefinitionId()); | ||||||
|         List<DocStatistics> docStatisticsOldList = docStatisticsService.list(queryWrapper); |         List<DocStatistics> docStatisticsOldList = docStatisticsService.list(queryWrapper); | ||||||
|         if (docStatisticsOldList.size() > 0) { |         if (docStatisticsOldList.size() > 0) { | ||||||
|             //批量删除 |             //批量删除 | ||||||
|             docStatisticsService.removeByIds(docStatisticsOldList.stream().map(DocStatistics::getId).toList()); |             docStatisticsService.removeByIds(docStatisticsOldList.stream().map(DocStatistics::getId).toList()); | ||||||
|         } |         } | ||||||
|  |         List<DocStatistics> docStatisticsInsertList = new ArrayList<>(); | ||||||
|         //批量新增 |         //批量新增 | ||||||
|         for (DocStatisticsDto docStatisticsDto : docStatisticsList) { |         for (DocStatisticsDto docStatisticsDto : docStatisticsList) { | ||||||
|             DocStatistics docStatistics = new DocStatistics(); |             DocStatistics docStatistics = new DocStatistics(); | ||||||
| @@ -45,13 +58,18 @@ public class DocStatisticsAppServiceImpl implements IDocStatisticsAppService { | |||||||
|             docStatistics.setEncounterId(docStatisticsDto.getEncounterId()); |             docStatistics.setEncounterId(docStatisticsDto.getEncounterId()); | ||||||
|             docStatistics.setPatientId(docStatisticsDto.getPatientId()); |             docStatistics.setPatientId(docStatisticsDto.getPatientId()); | ||||||
|             docStatistics.setStatisticDefinitionCode(docStatisticsDto.getStatisticDefinitionCode()); |             docStatistics.setStatisticDefinitionCode(docStatisticsDto.getStatisticDefinitionCode()); | ||||||
|             docStatistics.setOrgnizationId(docStatisticsDto.getOrgnizationId());     //TODO: 待确定 |             docStatistics.setOrganizationId(SecurityUtils.getLoginUser().getOrgId()); | ||||||
|             docStatistics.setValue(docStatisticsDto.getValue()); |             docStatistics.setValue(docStatisticsDto.getValue()); | ||||||
|             docStatistics.setRecordingDate(docStatisticsDto.getRecordingDate()); |             docStatistics.setRecordTime(docStatisticsDto.getRecordTime()); | ||||||
|             docStatistics.setRecordingTime(docStatisticsDto.getRecordingTime()); |  | ||||||
|             docStatistics.setSource(docStatisticsDto.getSource()); |             docStatistics.setSource(docStatisticsDto.getSource()); | ||||||
|  |             docStatisticsInsertList.add(docStatistics); | ||||||
|  |         } | ||||||
|  |         boolean result = docStatisticsService.saveBatch(docStatisticsInsertList); | ||||||
|  |         if (result) { | ||||||
|  |             return R.ok(); | ||||||
|  |         } else { | ||||||
|  |             return R.fail("新增或更新文档统计数据失败"); | ||||||
|         } |         } | ||||||
|         return null; |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
| @@ -66,6 +84,68 @@ public class DocStatisticsAppServiceImpl implements IDocStatisticsAppService { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public R<?> queryByEncounterId(Long encounterId) { |     public R<?> queryByEncounterId(Long encounterId) { | ||||||
|         return null; |         LambdaQueryWrapper<DocStatistics> queryWrapper = new LambdaQueryWrapper(); | ||||||
|  |         queryWrapper.eq(DocStatistics::getEncounterId, encounterId); | ||||||
|  |         List<DocStatistics> docStatisticsList = docStatisticsService.list(queryWrapper); | ||||||
|  |         List<DocStatisticsDto> docStatisticsDtoList = new ArrayList<>(); | ||||||
|  |         for (DocStatistics docStatistics : docStatisticsList) { | ||||||
|  |             DocStatisticsDto docStatisticsDto = new DocStatisticsDto(); | ||||||
|  |             docStatisticsDto.setId(docStatistics.getId()); | ||||||
|  |             docStatisticsDto.setRecordId(docStatistics.getRecordId()); | ||||||
|  |             docStatisticsDto.setStatisticDefinitionId(docStatistics.getStatisticDefinitionId()); | ||||||
|  |             docStatisticsDto.setEncounterId(docStatistics.getEncounterId()); | ||||||
|  |             docStatisticsDto.setPatientId(docStatistics.getPatientId()); | ||||||
|  |             docStatisticsDto.setStatisticDefinitionCode(docStatistics.getStatisticDefinitionCode()); | ||||||
|  |             docStatisticsDto.setOrganizationId(docStatistics.getOrganizationId()); | ||||||
|  |             docStatisticsDto.setValue(docStatistics.getValue()); | ||||||
|  |             docStatisticsDto.setRecordTime(docStatistics.getRecordTime()); | ||||||
|  |             docStatisticsDto.setSource(docStatistics.getSource()); | ||||||
|  |             docStatisticsDtoList.add(docStatisticsDto); | ||||||
|  |         } | ||||||
|  |         return R.ok(docStatisticsDtoList); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public R<?> getStatisticsList(DocStatisticsQueryParam queryParam, Integer isPage, Integer pageNo, Integer pageSize, String searchKey, HttpServletRequest request) { | ||||||
|  |         // 1. 分页查询逻辑 | ||||||
|  |         if (isPage != null && isPage == 1) { | ||||||
|  |             QueryWrapper<DocStatistics> queryWrapper = HisQueryUtils.buildQueryWrapper( | ||||||
|  |                     queryParam, null, null, request); | ||||||
|  |             // 按记录时间倒序(最新记录在前) | ||||||
|  |             queryWrapper.lambda().orderByDesc(DocStatistics::getRecordTime); | ||||||
|  |  | ||||||
|  |             Page<DocStatisticsDto> recordPage = HisPageUtils.selectPage( | ||||||
|  |                     docStatisticsMapper, queryWrapper, pageNo, pageSize, DocStatisticsDto.class); | ||||||
|  |             return R.ok(recordPage, "获取患者文书统计数据成功"); | ||||||
|  |         } | ||||||
|  |         //2. 不分页查询逻辑 | ||||||
|  |         else { | ||||||
|  |             LambdaQueryWrapper<DocStatistics> queryWrapper = new LambdaQueryWrapper<>(); | ||||||
|  |             // 患者ID查询条件 | ||||||
|  |             if (queryParam.getPatientId() != null) { | ||||||
|  |                 queryWrapper.eq(DocStatistics::getPatientId, queryParam.getPatientId()); | ||||||
|  |             } | ||||||
|  |             // 就诊ID查询条件(修复原逻辑:原代码字段匹配错误,用EncounterId匹配DefinitionBusNo) | ||||||
|  |             if (queryParam.getEncounterId() != null) { | ||||||
|  |                 queryWrapper.eq(DocStatistics::getEncounterId, queryParam.getEncounterId()); | ||||||
|  |             } | ||||||
|  |             // 科室ID查询条件(修复原逻辑:原代码字段匹配错误,用OrganizationId匹配EncounterId) | ||||||
|  |             if (queryParam.getOrganizationId() != null) { | ||||||
|  |                 queryWrapper.eq(DocStatistics::getOrganizationId, queryParam.getOrganizationId()); | ||||||
|  |             } | ||||||
|  |             if (queryParam.getStatisticsDefinitionCode() != null) { | ||||||
|  |                 queryWrapper.eq(DocStatistics::getStatisticDefinitionCode, queryParam.getStatisticsDefinitionCode()); | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             // 实体转DTO | ||||||
|  |             List<DocStatisticsDto> dtoList = new ArrayList<>(); | ||||||
|  |             List<DocStatistics> statisticsList = docStatisticsService.list(queryWrapper); | ||||||
|  |             for (DocStatistics statistics : statisticsList) { | ||||||
|  |                 DocStatisticsDto dto = new DocStatisticsDto(); | ||||||
|  |                 BeanUtils.copyProperties(statistics, dto); | ||||||
|  |                 dtoList.add(dto); | ||||||
|  |             } | ||||||
|  |             return R.ok(dtoList, "获取患者文书统计数据成功"); | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -3,7 +3,10 @@ package com.openhis.web.document.appservice.impl; | |||||||
| import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | ||||||
| import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | ||||||
| import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||||
|  | import com.core.common.constant.CacheConstants; | ||||||
| import com.core.common.core.domain.R; | import com.core.common.core.domain.R; | ||||||
|  | import com.core.common.core.domain.entity.SysDictData; | ||||||
|  | import com.core.common.core.redis.RedisCache; | ||||||
| import com.core.common.utils.bean.BeanUtils; | import com.core.common.utils.bean.BeanUtils; | ||||||
| import com.openhis.common.utils.HisPageUtils; | import com.openhis.common.utils.HisPageUtils; | ||||||
| import com.openhis.common.utils.HisQueryUtils; | import com.openhis.common.utils.HisQueryUtils; | ||||||
| @@ -11,13 +14,11 @@ import com.openhis.document.domain.DocStatisticsDefinition; | |||||||
| import com.openhis.document.mapper.DocStatisticsDefinitionMapper; | import com.openhis.document.mapper.DocStatisticsDefinitionMapper; | ||||||
| import com.openhis.document.service.IDocStatisticsDefinitionService; | import com.openhis.document.service.IDocStatisticsDefinitionService; | ||||||
| import com.openhis.web.document.appservice.IDocStatisticsDefinitionAppService; | import com.openhis.web.document.appservice.IDocStatisticsDefinitionAppService; | ||||||
| import com.openhis.web.document.appservice.IDocStatisticsDefinitionOptionAppService; |  | ||||||
| import com.openhis.web.document.dto.DocDefinitionOrganizationDto; |  | ||||||
| import com.openhis.web.document.dto.DocStatisticsDefinitionDto; | import com.openhis.web.document.dto.DocStatisticsDefinitionDto; | ||||||
| import com.openhis.web.document.dto.DocStatisticsDefinitionOptionList; |  | ||||||
| import com.openhis.web.document.dto.OptionDto; | import com.openhis.web.document.dto.OptionDto; | ||||||
| import com.openhis.web.document.mapper.DocStatisticsDefinitionAppMapper; | import com.openhis.web.document.mapper.DocStatisticsDefinitionAppMapper; | ||||||
| import lombok.extern.slf4j.Slf4j; | import lombok.extern.slf4j.Slf4j; | ||||||
|  | import org.springframework.beans.factory.annotation.Autowired; | ||||||
| import org.springframework.stereotype.Service; | import org.springframework.stereotype.Service; | ||||||
|  |  | ||||||
| import javax.annotation.Resource; | import javax.annotation.Resource; | ||||||
| @@ -35,12 +36,11 @@ public class DocStatisticsDefinitionAppServiceImpl implements IDocStatisticsDefi | |||||||
|     @Resource |     @Resource | ||||||
|     private IDocStatisticsDefinitionService iDocStatisticsDefinitionService; |     private IDocStatisticsDefinitionService iDocStatisticsDefinitionService; | ||||||
|     @Resource |     @Resource | ||||||
|     private IDocStatisticsDefinitionOptionAppService iDocStaticsDefinitionOptionAppService; |  | ||||||
|     @Resource |  | ||||||
|     private DocStatisticsDefinitionMapper docStatisticsDefinitionMapper; |     private DocStatisticsDefinitionMapper docStatisticsDefinitionMapper; | ||||||
|     @Resource |     @Resource | ||||||
|     private DocStatisticsDefinitionAppMapper docStatisticsDefinitionAppMapper; |     private DocStatisticsDefinitionAppMapper docStatisticsDefinitionAppMapper; | ||||||
|  |     @Autowired | ||||||
|  |     private RedisCache redisCache; | ||||||
|     @Override |     @Override | ||||||
|     public R<?> createOrEdit(DocStatisticsDefinitionDto docStatisticsDefinitionDto) { |     public R<?> createOrEdit(DocStatisticsDefinitionDto docStatisticsDefinitionDto) { | ||||||
|         if (docStatisticsDefinitionDto == null) { |         if (docStatisticsDefinitionDto == null) { | ||||||
| @@ -95,15 +95,10 @@ public class DocStatisticsDefinitionAppServiceImpl implements IDocStatisticsDefi | |||||||
|         docStatisticsDefinition.setIsStatistics(docStatisticsDefinitionDto.getIsStatistics()); |         docStatisticsDefinition.setIsStatistics(docStatisticsDefinitionDto.getIsStatistics()); | ||||||
|         docStatisticsDefinition.setDisplayOrder(docStatisticsDefinitionDto.getDisplayOrder()); |         docStatisticsDefinition.setDisplayOrder(docStatisticsDefinitionDto.getDisplayOrder()); | ||||||
|         docStatisticsDefinition.setUnit(docStatisticsDefinitionDto.getUnit()); |         docStatisticsDefinition.setUnit(docStatisticsDefinitionDto.getUnit()); | ||||||
|  |         docStatisticsDefinition.setDictType(docStatisticsDefinitionDto.getDictType()); | ||||||
|  |         docStatisticsDefinition.setDictName(docStatisticsDefinitionDto.getDictName()); | ||||||
|         boolean saveResult = iDocStatisticsDefinitionService.save(docStatisticsDefinition); |         boolean saveResult = iDocStatisticsDefinitionService.save(docStatisticsDefinition); | ||||||
|         if (saveResult) { |         if (saveResult) { | ||||||
|             // 同步保存选项列表(如有) |  | ||||||
|             if (docStatisticsDefinitionDto.getOptionList() != null && !docStatisticsDefinitionDto.getOptionList().getOptions().isEmpty()) { |  | ||||||
|                 docStatisticsDefinitionDto.getOptionList().setDocStatisticsDefinitionId(docStatisticsDefinition.getId()); |  | ||||||
|                 return iDocStaticsDefinitionOptionAppService.add(docStatisticsDefinitionDto.getOptionList()); |  | ||||||
|             } |  | ||||||
|             return R.ok("文档统计定义新增成功"); |             return R.ok("文档统计定义新增成功"); | ||||||
|         } else { |         } else { | ||||||
|             return R.fail("文档统计定义新增失败"); |             return R.fail("文档统计定义新增失败"); | ||||||
| @@ -131,10 +126,12 @@ public class DocStatisticsDefinitionAppServiceImpl implements IDocStatisticsDefi | |||||||
|         existingData.setIsStatistics(docStatisticsDefinitionDto.getIsStatistics()); |         existingData.setIsStatistics(docStatisticsDefinitionDto.getIsStatistics()); | ||||||
|         existingData.setDisplayOrder(docStatisticsDefinitionDto.getDisplayOrder()); |         existingData.setDisplayOrder(docStatisticsDefinitionDto.getDisplayOrder()); | ||||||
|         existingData.setUnit(docStatisticsDefinitionDto.getUnit()); |         existingData.setUnit(docStatisticsDefinitionDto.getUnit()); | ||||||
|  |         existingData.setDictType(docStatisticsDefinitionDto.getDictType()); | ||||||
|  |         existingData.setDictName(docStatisticsDefinitionDto.getDictName()); | ||||||
|         boolean updateResult = iDocStatisticsDefinitionService.updateById(existingData); |         boolean updateResult = iDocStatisticsDefinitionService.updateById(existingData); | ||||||
|         if (updateResult) { |         if (updateResult) { | ||||||
|             // 同步更新选项列表 |             // 同步更新选项列表 | ||||||
|             return iDocStaticsDefinitionOptionAppService.createOrEdit(docStatisticsDefinitionDto.getOptionList()); |             return R.ok("文档统计定义更新成功"); | ||||||
|         } else { |         } else { | ||||||
|             return R.fail("文档统计定义更新失败"); |             return R.fail("文档统计定义更新失败"); | ||||||
|         } |         } | ||||||
| @@ -168,12 +165,12 @@ public class DocStatisticsDefinitionAppServiceImpl implements IDocStatisticsDefi | |||||||
|      */ |      */ | ||||||
|     @Override |     @Override | ||||||
|     public R<?> getPageList(Integer pageNo, Integer pageSize, String searchKey, HttpServletRequest request) { |     public R<?> getPageList(Integer pageNo, Integer pageSize, String searchKey, HttpServletRequest request) { | ||||||
|  | //        Map<String, Object>  keyMap =  redisCache.getAllDictDataWithKeys(CacheConstants.SYS_DICT_KEY); | ||||||
|         // 构建查询条件(支持多字段搜索) |         // 构建查询条件(支持多字段搜索) | ||||||
|         QueryWrapper<DocStatisticsDefinition> queryWrapper = HisQueryUtils.buildQueryWrapper( |         QueryWrapper<DocStatisticsDefinition> queryWrapper = HisQueryUtils.buildQueryWrapper( | ||||||
|                 null, searchKey, new HashSet<>(Arrays.asList("name", "code")), request); |                 null, searchKey, new HashSet<>(Arrays.asList("name", "code")), request); | ||||||
|         // 按记录时间倒序(最新记录在前) |         // 按记录时间倒序(最新记录在前) | ||||||
|         queryWrapper.lambda().orderByDesc(DocStatisticsDefinition::getDisplayOrder); |         queryWrapper.lambda().orderByDesc(DocStatisticsDefinition::getDisplayOrder); | ||||||
|  |  | ||||||
|         Page<DocStatisticsDefinitionDto> recordPage = HisPageUtils.selectPage( |         Page<DocStatisticsDefinitionDto> recordPage = HisPageUtils.selectPage( | ||||||
|                 docStatisticsDefinitionMapper, queryWrapper, pageNo, pageSize, DocStatisticsDefinitionDto.class); |                 docStatisticsDefinitionMapper, queryWrapper, pageNo, pageSize, DocStatisticsDefinitionDto.class); | ||||||
|         // 转换为分页结果 |         // 转换为分页结果 | ||||||
| @@ -181,13 +178,14 @@ public class DocStatisticsDefinitionAppServiceImpl implements IDocStatisticsDefi | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 获取文档统计定义列表(不分页) |      * 获取文档统计定义列表(不分页,不包含options) | ||||||
|      * |      * | ||||||
|      * @param isStatistics 是否统计 |      * @param isStatistics 是否统计 | ||||||
|      * @return 文档统计定义列表 |      * @return 文档统计定义列表 | ||||||
|      */ |      */ | ||||||
|     @Override |     @Override | ||||||
|     public List<DocStatisticsDefinitionDto> getList(Integer isStatistics) { |     public List<DocStatisticsDefinitionDto> getList(Integer isStatistics) { | ||||||
|  |         Map<String, Object>  keyMap =  redisCache.getAllDictDataWithKeys(CacheConstants.SYS_DICT_KEY); | ||||||
|         LambdaQueryWrapper<DocStatisticsDefinition> queryWrapper = new LambdaQueryWrapper<>(); |         LambdaQueryWrapper<DocStatisticsDefinition> queryWrapper = new LambdaQueryWrapper<>(); | ||||||
|         if (isStatistics != null) { |         if (isStatistics != null) { | ||||||
|             queryWrapper.eq(DocStatisticsDefinition::getIsStatistics, isStatistics); |             queryWrapper.eq(DocStatisticsDefinition::getIsStatistics, isStatistics); | ||||||
| @@ -201,7 +199,28 @@ public class DocStatisticsDefinitionAppServiceImpl implements IDocStatisticsDefi | |||||||
|         } |         } | ||||||
|         return resultList; |         return resultList; | ||||||
|     } |     } | ||||||
|  |     @Override | ||||||
|  |     public List<DocStatisticsDefinitionDto> getListWithOptionList(Integer isStatistics) { | ||||||
|  |         //从redis中获取所有字典数据 | ||||||
|  |         Map<String, Object>  keyMap =  redisCache.getAllDictDataWithKeys(CacheConstants.SYS_DICT_KEY); | ||||||
|  |         LambdaQueryWrapper<DocStatisticsDefinition> queryWrapper = new LambdaQueryWrapper<>(); | ||||||
|  |         if (isStatistics != null) { | ||||||
|  |             queryWrapper.eq(DocStatisticsDefinition::getIsStatistics, isStatistics); | ||||||
|  |         } | ||||||
|  |         List<DocStatisticsDefinition> dataList = iDocStatisticsDefinitionService.list(queryWrapper); | ||||||
|  |         List<DocStatisticsDefinitionDto> resultList = new ArrayList<>(); | ||||||
|  |         for (DocStatisticsDefinition data : dataList) { | ||||||
|  |             DocStatisticsDefinitionDto dto = new DocStatisticsDefinitionDto(); | ||||||
|  |             BeanUtils.copyProperties(data, dto); | ||||||
|  |             if(keyMap.containsKey(CacheConstants.SYS_DICT_KEY+data.getDictType())) | ||||||
|  |             { | ||||||
|  |                 List<SysDictData> dictData = (List<SysDictData>) keyMap.get(CacheConstants.SYS_DICT_KEY+data.getDictType()); | ||||||
|  |                 dto.setOptionList(dictData); | ||||||
|  |             } | ||||||
|  |             resultList.add(dto); | ||||||
|  |         } | ||||||
|  |         return resultList; | ||||||
|  |     } | ||||||
|     /** |     /** | ||||||
|      * 获取文档统计定义选项列表并按指定格式返回 |      * 获取文档统计定义选项列表并按指定格式返回 | ||||||
|      * |      * | ||||||
| @@ -276,62 +295,12 @@ public class DocStatisticsDefinitionAppServiceImpl implements IDocStatisticsDefi | |||||||
|         } |         } | ||||||
|         boolean deleteResult = iDocStatisticsDefinitionService.removeById(id); |         boolean deleteResult = iDocStatisticsDefinitionService.removeById(id); | ||||||
|         if (deleteResult) { |         if (deleteResult) { | ||||||
|             // 同步删除选项列表 |  | ||||||
|             iDocStaticsDefinitionOptionAppService.deleteDocStatisticsDefinitionOptionById(id); |  | ||||||
|             return R.ok("文档统计定义删除成功"); |             return R.ok("文档统计定义删除成功"); | ||||||
|         } else { |         } else { | ||||||
|             return R.fail("文档统计定义删除失败"); |             return R.fail("文档统计定义删除失败"); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 获取文档统计定义详情 |  | ||||||
|      * |  | ||||||
|      * @param id 文档统计定义ID |  | ||||||
|      * @return 封装了处理结果的响应对象 |  | ||||||
|      */ |  | ||||||
|     @Override |  | ||||||
|     public R<?> getDocStatisticsDefinitionById(Long id) { |  | ||||||
|         if (id == null) { |  | ||||||
|             return R.fail("获取文档统计定义,参数ID不能为空"); |  | ||||||
|         } |  | ||||||
|         DocStatisticsDefinition data = iDocStatisticsDefinitionService.getById(id); |  | ||||||
|         if (data == null) { |  | ||||||
|             return R.fail("获取文档统计定义失败,目标数据不存在"); |  | ||||||
|         } |  | ||||||
|         // 转换为DTO返回 |  | ||||||
|         DocStatisticsDefinitionDto dto = new DocStatisticsDefinitionDto(); |  | ||||||
|         BeanUtils.copyProperties(data, dto); |  | ||||||
|         DocStatisticsDefinitionOptionList optionList = iDocStaticsDefinitionOptionAppService.getDocStatisticsDefinitionOptionByDefinitionId(id); |  | ||||||
|         dto.setOptionList(optionList); |  | ||||||
|         return R.ok(dto, "文档统计定义获取成功"); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 根据代码获取文档统计定义详情 |  | ||||||
|      * |  | ||||||
|      * @param code 文档统计定义代码 |  | ||||||
|      * @return 封装了处理结果的响应对象 |  | ||||||
|      */ |  | ||||||
|     @Override |  | ||||||
|     public R<?> getDocStatisticsDefinitionByCode(String code) { |  | ||||||
|         if (code == null || code.trim().isEmpty()) { |  | ||||||
|             return R.fail("获取文档统计定义,参数代码不能为空"); |  | ||||||
|         } |  | ||||||
|         // 按代码查询 |  | ||||||
|         LambdaQueryWrapper<DocStatisticsDefinition> queryWrapper = new LambdaQueryWrapper<>(); |  | ||||||
|         queryWrapper.eq(DocStatisticsDefinition::getCode, code); |  | ||||||
|         DocStatisticsDefinition data = iDocStatisticsDefinitionService.getOne(queryWrapper); |  | ||||||
|         if (data == null) { |  | ||||||
|             return R.fail("获取文档统计定义失败,目标数据不存在"); |  | ||||||
|         } |  | ||||||
|         DocStatisticsDefinitionDto dto = new DocStatisticsDefinitionDto(); |  | ||||||
|         if (data != null) { |  | ||||||
|             BeanUtils.copyProperties(data, dto); |  | ||||||
|         } |  | ||||||
|         DocStatisticsDefinitionOptionList optionList = iDocStaticsDefinitionOptionAppService.getDocStatisticsDefinitionOptionByDefinitionId(data.getId()); |  | ||||||
|         dto.setOptionList(optionList); |  | ||||||
|         return R.ok(dto, "文档统计定义获取成功"); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } | } | ||||||
| @@ -1,229 +0,0 @@ | |||||||
| package com.openhis.web.document.appservice.impl; |  | ||||||
|  |  | ||||||
| import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; |  | ||||||
| import com.core.common.core.domain.AjaxResult; |  | ||||||
| import com.core.common.core.domain.R; |  | ||||||
| import com.core.common.utils.bean.BeanUtils; |  | ||||||
| import com.openhis.document.domain.DocStatisticsDefinitionOption; |  | ||||||
| import com.openhis.document.mapper.DocStatisticsDefinitionOptionMapper; |  | ||||||
| import com.openhis.document.service.IDocStatisticsDefinitionOptionService; |  | ||||||
| import com.openhis.web.document.appservice.IDocStatisticsDefinitionOptionAppService; |  | ||||||
| import com.openhis.web.document.dto.DocStatisticsDefinitionOptionDto; |  | ||||||
| import com.openhis.web.document.dto.DocStatisticsDefinitionOptionList; |  | ||||||
| import lombok.extern.slf4j.Slf4j; |  | ||||||
| import org.springframework.stereotype.Service; |  | ||||||
|  |  | ||||||
| import javax.annotation.Resource; |  | ||||||
| import java.util.*; |  | ||||||
| import java.util.stream.Collectors; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * 文档统计定义选项 业务实现类 |  | ||||||
|  */ |  | ||||||
| @Slf4j |  | ||||||
| @Service |  | ||||||
| public class DocStatisticsDefinitionOptionAppServiceImpl implements IDocStatisticsDefinitionOptionAppService { |  | ||||||
|  |  | ||||||
|     @Resource |  | ||||||
|     private DocStatisticsDefinitionOptionMapper docStatisticsDefinitonOptionMapper; |  | ||||||
|     @Resource |  | ||||||
|     private IDocStatisticsDefinitionOptionService docStatisticsDefinitionOptionService; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 新增文档统计定义选项 |  | ||||||
|      * |  | ||||||
|      * @param docStatisticsDefinitionOptionList 选项列表DTO |  | ||||||
|      */ |  | ||||||
|     @Override |  | ||||||
|     public R<?> add(DocStatisticsDefinitionOptionList docStatisticsDefinitionOptionList) { |  | ||||||
|         // 参数校验 |  | ||||||
|         if (docStatisticsDefinitionOptionList == null) { |  | ||||||
|             return R.fail("统计项选项列表为空,请选择统计项选项"); |  | ||||||
|         } |  | ||||||
|         if (docStatisticsDefinitionOptionList.getOptions() == null || docStatisticsDefinitionOptionList.getOptions().isEmpty()) { |  | ||||||
|             return R.fail("统计项选项不允许为空,请正确填写统计项选项"); |  | ||||||
|         } |  | ||||||
|         if (docStatisticsDefinitionOptionList.getDocStatisticsDefinitionId() == null) { |  | ||||||
|             return R.fail("统计项定义ID为空,请选择统计项定义ID"); |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         // DTO转实体 |  | ||||||
|         List<DocStatisticsDefinitionOption> optionList = new ArrayList<>(); |  | ||||||
|         for (DocStatisticsDefinitionOptionDto dto : docStatisticsDefinitionOptionList.getOptions()) { |  | ||||||
|             DocStatisticsDefinitionOption option = new DocStatisticsDefinitionOption(); |  | ||||||
|             option.setDocStatisticsDefinitionId(docStatisticsDefinitionOptionList.getDocStatisticsDefinitionId()); |  | ||||||
|             option.setOption(dto.getOption()); |  | ||||||
|             option.setDisplayOrder(dto.getDisplayOrder()); |  | ||||||
|             optionList.add(option); |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         // 批量新增 |  | ||||||
|         boolean saveSuccess = docStatisticsDefinitionOptionService.saveBatch(optionList); |  | ||||||
|         if (saveSuccess) { |  | ||||||
|             return R.ok(optionList, "统计项选项保存成功"); |  | ||||||
|         } else { |  | ||||||
|             return R.fail("统计项选项保存失败"); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 新增/编辑文档统计定义选项(区分增删改) |  | ||||||
|      * |  | ||||||
|      * @param docStatisticsDefinitionOptionList 选项列表DTO |  | ||||||
|      */ |  | ||||||
|     @Override |  | ||||||
|     public R<?> createOrEdit(DocStatisticsDefinitionOptionList docStatisticsDefinitionOptionList) { |  | ||||||
|         // 参数校验 |  | ||||||
|         if (docStatisticsDefinitionOptionList == null) { |  | ||||||
|             return R.fail("统计项选项列表为空,请选择统计项选项"); |  | ||||||
|         } |  | ||||||
|         Long definitionId = docStatisticsDefinitionOptionList.getDocStatisticsDefinitionId(); |  | ||||||
|         if (definitionId == null) { |  | ||||||
|             return R.fail("统计项定义ID为空,请选择统计项定义ID"); |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         // 1. 查询原数据列表(按统计定义ID关联) |  | ||||||
|         List<DocStatisticsDefinitionOption> oldList = docStatisticsDefinitonOptionMapper.selectList( |  | ||||||
|                 new LambdaQueryWrapper<DocStatisticsDefinitionOption>() |  | ||||||
|                         .eq(DocStatisticsDefinitionOption::getDocStatisticsDefinitionId, definitionId)); |  | ||||||
|         oldList = oldList == null ? Collections.emptyList() : oldList; |  | ||||||
|  |  | ||||||
|         // 2. 处理新数据列表(DTO转实体,避免空指针) |  | ||||||
|         List<DocStatisticsDefinitionOption> newList = new ArrayList<>(); |  | ||||||
|         if (docStatisticsDefinitionOptionList.getOptions() != null && !docStatisticsDefinitionOptionList.getOptions().isEmpty()) { |  | ||||||
|             for (DocStatisticsDefinitionOptionDto dto : docStatisticsDefinitionOptionList.getOptions()) { |  | ||||||
|                 DocStatisticsDefinitionOption option = new DocStatisticsDefinitionOption(); |  | ||||||
|                 BeanUtils.copyProperties(dto, option); // 改用BeanUtils简化赋值 |  | ||||||
|                 option.setDocStatisticsDefinitionId(definitionId); // 强制关联父ID,确保数据一致性 |  | ||||||
|                 newList.add(option); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         newList = newList == null ? Collections.emptyList() : newList; |  | ||||||
|  |  | ||||||
|         // 3. 构建原数据ID映射(快速查找) |  | ||||||
|         Map<Long, DocStatisticsDefinitionOption> oldIdMap = oldList.stream() |  | ||||||
|                 .filter(Objects::nonNull) |  | ||||||
|                 .filter(item -> item.getId() != null) |  | ||||||
|                 .collect(Collectors.toMap(DocStatisticsDefinitionOption::getId, item -> item)); |  | ||||||
|  |  | ||||||
|         // 4. 提取新数据中的有效ID集合 |  | ||||||
|         Set<Long> newIds = newList.stream() |  | ||||||
|                 .map(DocStatisticsDefinitionOption::getId) |  | ||||||
|                 .filter(Objects::nonNull) |  | ||||||
|                 .collect(Collectors.toSet()); |  | ||||||
|  |  | ||||||
|         // 5. 确定需要删除的项(原数据存在但新数据不存在) |  | ||||||
|         List<Long> deleteIds = oldList.stream() |  | ||||||
|                 .map(DocStatisticsDefinitionOption::getId) |  | ||||||
|                 .filter(id -> !newIds.contains(id)) |  | ||||||
|                 .collect(Collectors.toList()); |  | ||||||
|  |  | ||||||
|         // 6. 区分新增和修改的项 |  | ||||||
|         List<DocStatisticsDefinitionOption> addList = new ArrayList<>(); |  | ||||||
|         List<DocStatisticsDefinitionOption> updateList = new ArrayList<>(); |  | ||||||
|         for (DocStatisticsDefinitionOption newItem : newList) { |  | ||||||
|             Long newItemId = newItem.getId(); |  | ||||||
|             if (newItemId != null && oldIdMap.containsKey(newItemId)) { |  | ||||||
|                 // 有ID且原数据存在 → 修改 |  | ||||||
|                 updateList.add(newItem); |  | ||||||
|             } else { |  | ||||||
|                 // 无ID或原数据不存在 → 新增 |  | ||||||
|                 addList.add(newItem); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         // 7. 执行删除操作 |  | ||||||
|         if (!deleteIds.isEmpty()) { |  | ||||||
|             boolean deleteSuccess = docStatisticsDefinitionOptionService.removeByIds(deleteIds); |  | ||||||
|             if (!deleteSuccess) { |  | ||||||
|                 return R.fail("统计项选项删除失败"); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         // 8. 执行修改操作 |  | ||||||
|         if (!updateList.isEmpty()) { |  | ||||||
|             boolean updateSuccess = docStatisticsDefinitionOptionService.updateBatchById(updateList); |  | ||||||
|             if (!updateSuccess) { |  | ||||||
|                 return R.fail("统计项选项更新失败"); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         // 9. 执行新增操作 |  | ||||||
|         if (!addList.isEmpty()) { |  | ||||||
|             boolean addSuccess = docStatisticsDefinitionOptionService.saveBatch(addList); |  | ||||||
|             if (!addSuccess) { |  | ||||||
|                 return R.fail("统计项选项新增失败"); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         return R.ok("统计项选项更新成功"); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 删除单个统计项选项 |  | ||||||
|      * |  | ||||||
|      * @param id 选项ID |  | ||||||
|      */ |  | ||||||
|     @Override |  | ||||||
|     public R<?> deleteDocStatisticsDefinitionOptionById(Long id) { |  | ||||||
|         if (id == null) { |  | ||||||
|             return R.fail("统计项选项ID为空,请选择要删除的统计项选项"); |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         // 先校验数据是否存在 |  | ||||||
|         DocStatisticsDefinitionOption existingOption = docStatisticsDefinitionOptionService.getById(id); |  | ||||||
|         if (existingOption == null) { |  | ||||||
|             return R.fail("统计项选项不存在,删除失败"); |  | ||||||
|         } |  | ||||||
|         // 执行删除 |  | ||||||
|         boolean deleteSuccess = docStatisticsDefinitionOptionService.removeById(id); |  | ||||||
|         if (deleteSuccess) { |  | ||||||
|             return R.ok("统计项选项删除成功"); |  | ||||||
|         } else { |  | ||||||
|             return R.fail("统计项选项删除失败"); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 根据统计定义ID查询选项列表 |  | ||||||
|      * |  | ||||||
|      * @param docStatisticsDefinitionId 统计定义ID |  | ||||||
|      */ |  | ||||||
|     @Override |  | ||||||
|     public DocStatisticsDefinitionOptionList getDocStatisticsDefinitionOptionByDefinitionId(Long docStatisticsDefinitionId) { |  | ||||||
|  |  | ||||||
|         // 修复原查询条件错误:原逻辑用ID查ID,改为用统计定义ID查关联选项 |  | ||||||
|         LambdaQueryWrapper<DocStatisticsDefinitionOption> queryWrapper = new LambdaQueryWrapper<>(); |  | ||||||
|         queryWrapper.eq(DocStatisticsDefinitionOption::getDocStatisticsDefinitionId, docStatisticsDefinitionId) |  | ||||||
|                 .orderByAsc(DocStatisticsDefinitionOption::getDisplayOrder); // 按显示顺序排序 |  | ||||||
|  |  | ||||||
|         List<DocStatisticsDefinitionOption> optionList = docStatisticsDefinitonOptionMapper.selectList(queryWrapper); |  | ||||||
|         if (optionList == null || optionList.isEmpty()) { |  | ||||||
|             return null; |  | ||||||
|         } |  | ||||||
|         // 实体转DTO |  | ||||||
|         List<DocStatisticsDefinitionOptionDto> dtoList = new ArrayList<>(); |  | ||||||
|         for (DocStatisticsDefinitionOption option : optionList) { |  | ||||||
|             DocStatisticsDefinitionOptionDto dto = new DocStatisticsDefinitionOptionDto(); |  | ||||||
|             dto.setId(option.getId()); |  | ||||||
|             dto.setOption(option.getOption()); |  | ||||||
|             dto.setDisplayOrder(option.getDisplayOrder()); |  | ||||||
|             dtoList.add(dto); |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         // 封装返回结果 |  | ||||||
|         DocStatisticsDefinitionOptionList resultList = new DocStatisticsDefinitionOptionList(); |  | ||||||
|         resultList.setDocStatisticsDefinitionId(docStatisticsDefinitionId); |  | ||||||
|         resultList.setOptions(dtoList); |  | ||||||
|  |  | ||||||
|         return resultList; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 获取文档模板 统计项选项列表 |  | ||||||
|      */ |  | ||||||
|     @Override |  | ||||||
|     public AjaxResult getDocStatisticsDefinitionOptionList() { |  | ||||||
|         return null; |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @@ -84,6 +84,19 @@ public class DocDefinitionController { | |||||||
|         return iDocDefinitionAppService.getDefinitionDetailById(id); |         return iDocDefinitionAppService.getDefinitionDetailById(id); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 获取文书定义详情 | ||||||
|  |      * | ||||||
|  |      * @param id 文书定义ID | ||||||
|  |      * @return 文书定义详情 | ||||||
|  |      */ | ||||||
|  |     @DeleteMapping("/delete/{id}") | ||||||
|  |     public R<?> deleteDefinition(@PathVariable("id") Long id) { | ||||||
|  |         log.info("删除文书定义,ID={}", id); | ||||||
|  |         // 调用删除服务(注意:方法名应改为删除相关,如removeById) | ||||||
|  |         return iDocDefinitionAppService.deleteDefinition(id); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 查询获取文书定义列表 树形结构 |      * 查询获取文书定义列表 树形结构 | ||||||
|      * |      * | ||||||
|   | |||||||
| @@ -90,11 +90,11 @@ public class DocRecordController { | |||||||
|      */ |      */ | ||||||
|     @GetMapping("/getRecordByEncounterIdList") |     @GetMapping("/getRecordByEncounterIdList") | ||||||
|     R<?> getRecordByEncounterIdList(DocRecordQueryParam docRecordQueryParam, |     R<?> getRecordByEncounterIdList(DocRecordQueryParam docRecordQueryParam, | ||||||
|                                     @RequestParam(value = "IsPage", defaultValue = "1") Integer IsPage, |                                     @RequestParam(value = "isPage", defaultValue = "1") Integer isPage, | ||||||
|                                     @RequestParam(value = "pageNo", defaultValue = "1") Integer pageNo, |                                     @RequestParam(value = "pageNo", defaultValue = "1") Integer pageNo, | ||||||
|                                     @RequestParam(value = "pageSize", defaultValue = "10") Integer pageSize, |                                     @RequestParam(value = "pageSize", defaultValue = "10") Integer pageSize, | ||||||
|                                     @RequestParam(name = "searchKey", required = false) String searchKey, HttpServletRequest request) { |                                     @RequestParam(name = "searchKey", required = false) String searchKey, HttpServletRequest request) { | ||||||
|         return docRecordAppService.getRecordByEncounterIdList(docRecordQueryParam, IsPage, pageNo, pageSize, searchKey, request); |         return docRecordAppService.getRecordByEncounterIdList(docRecordQueryParam, isPage, pageNo, pageSize, searchKey, request); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|   | |||||||
| @@ -1,24 +1,59 @@ | |||||||
| package com.openhis.web.document.controller; | package com.openhis.web.document.controller; | ||||||
|  |  | ||||||
|  | import com.core.common.core.domain.R; | ||||||
| import com.openhis.web.document.appservice.IDocRecordAppService; | import com.openhis.web.document.appservice.IDocRecordAppService; | ||||||
|  | import com.openhis.web.document.appservice.IDocStatisticsAppService; | ||||||
|  | import com.openhis.web.document.dto.DocStatisticsDto; | ||||||
|  | import com.openhis.web.document.dto.DocStatisticsQueryParam; | ||||||
| import lombok.AllArgsConstructor; | import lombok.AllArgsConstructor; | ||||||
| import lombok.extern.slf4j.Slf4j; | import lombok.extern.slf4j.Slf4j; | ||||||
| import org.springframework.web.bind.annotation.RequestMapping; | import org.springframework.web.bind.annotation.*; | ||||||
| import org.springframework.web.bind.annotation.RestController; |  | ||||||
|  | import javax.servlet.http.HttpServletRequest; | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * 文档模板-病历另存为模板使用  controller |  * DocStatistics文书统计  controller | ||||||
|  * |  * | ||||||
|  * @author wanghaiming |  * @author wanghaiming | ||||||
|  * @date 2025-08-12 |  * @date 2025-08-12 | ||||||
|  */ |  */ | ||||||
| @RestController | @RestController | ||||||
| @RequestMapping("/document/template") | @RequestMapping("/document/statistics") | ||||||
| @Slf4j | @Slf4j | ||||||
| @AllArgsConstructor | @AllArgsConstructor | ||||||
| public class DocStatisticsController { | public class DocStatisticsController { | ||||||
|  |  | ||||||
|     private final IDocRecordAppService docRecordAppService; |     private final IDocStatisticsAppService docStatisticsAppService; | ||||||
|  |  | ||||||
|  |     @PostMapping("/createOrUpdte") | ||||||
|  |     public R<?> createOrUpdte(List<DocStatisticsDto> docStatisticsList) { | ||||||
|  |         return docStatisticsAppService.createOrUpdte(docStatisticsList); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @DeleteMapping("/delete") | ||||||
|  |     public R<?> delete(List<Long> ids) { | ||||||
|  |         return docStatisticsAppService.delete(ids); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @GetMapping("/queryByRecordId") | ||||||
|  |     public R<?> queryByRecordId(Long recordId) { | ||||||
|  |         return docStatisticsAppService.queryByRecordId(recordId); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @GetMapping("/queryByEncounterId") | ||||||
|  |     public R<?> queryByEncounterId(Long encounterId) { | ||||||
|  |         return docStatisticsAppService.queryByEncounterId(encounterId); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @GetMapping("/getStatisticsList") | ||||||
|  |     R<?> getStatisticsList(DocStatisticsQueryParam queryParam, | ||||||
|  |                            @RequestParam(value = "isPage", defaultValue = "1") Integer isPage, | ||||||
|  |                            @RequestParam(value = "pageNo", defaultValue = "1") Integer pageNo, | ||||||
|  |                            @RequestParam(value = "pageSize", defaultValue = "10") Integer pageSize, | ||||||
|  |                            @RequestParam(name = "searchKey", required = false) String searchKey, HttpServletRequest request) { | ||||||
|  |         return docStatisticsAppService.getStatisticsList(queryParam, isPage, pageNo, pageSize, searchKey, request); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -11,6 +11,7 @@ import org.springframework.web.bind.annotation.*; | |||||||
|  |  | ||||||
| import javax.servlet.http.HttpServletRequest; | import javax.servlet.http.HttpServletRequest; | ||||||
| import java.util.HashMap; | import java.util.HashMap; | ||||||
|  | import java.util.List; | ||||||
| import java.util.Map; | import java.util.Map; | ||||||
|  |  | ||||||
| /** | /** | ||||||
| @@ -78,29 +79,6 @@ public class DocStatisticsDefinitionController { | |||||||
|     public R<?> deleteDocStatisticsDefinition(Long id) { |     public R<?> deleteDocStatisticsDefinition(Long id) { | ||||||
|         return docStatisticsDefinitionAppService.deleteDocStatisticsDefinition(id); |         return docStatisticsDefinitionAppService.deleteDocStatisticsDefinition(id); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 根据id获取统计定义详情 |  | ||||||
|      * |  | ||||||
|      * @param id |  | ||||||
|      * @return |  | ||||||
|      */ |  | ||||||
|     @GetMapping("/getDocStatisticsDefinitionById") |  | ||||||
|     public R<?> getDocStatisticsDefinitionById(Long id) { |  | ||||||
|         return docStatisticsDefinitionAppService.getDocStatisticsDefinitionById(id); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 根据code获取统计定义详情 |  | ||||||
|      * |  | ||||||
|      * @param code |  | ||||||
|      * @return |  | ||||||
|      */ |  | ||||||
|     @GetMapping("/getDocStatisticsDefinitionByCode") |  | ||||||
|     public R<?> getDocStatisticsDefinitionByCode(String code) { |  | ||||||
|         return docStatisticsDefinitionAppService.getDocStatisticsDefinitionByCode(code); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 分页查询列表-不包含options |      * 分页查询列表-不包含options | ||||||
|      * |      * | ||||||
| @@ -116,9 +94,30 @@ public class DocStatisticsDefinitionController { | |||||||
|                             @RequestParam(name = "searchKey", required = false) String searchKey, HttpServletRequest request) { |                             @RequestParam(name = "searchKey", required = false) String searchKey, HttpServletRequest request) { | ||||||
|         return docStatisticsDefinitionAppService.getPageList(pageNo, pageSize, searchKey, request); |         return docStatisticsDefinitionAppService.getPageList(pageNo, pageSize, searchKey, request); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 获取文档统计定义选项列表并按指定格式返回 |      * 获取文档统计定义列表-不包含options,即字典数据 | ||||||
|  |      * | ||||||
|  |      * @param isStatistics 文档统计定义是否启用   0:不统计  1:统计 可不传 | ||||||
|  |      * @return | ||||||
|  |      */ | ||||||
|  |     @GetMapping("/getList") | ||||||
|  |     public R<?> getList(Integer isStatistics){ | ||||||
|  |         List<DocStatisticsDefinitionDto> list = docStatisticsDefinitionAppService.getList(isStatistics); | ||||||
|  |         return R.ok(list); | ||||||
|  |     } | ||||||
|  |     /** | ||||||
|  |      * 获取文档统计定义列表(包含options,即字典数据) | ||||||
|  |      * | ||||||
|  |      * @param isStatistics 文档统计定义是否启用   0:不统计  1:统计 可不传 | ||||||
|  |      * @return | ||||||
|  |      */ | ||||||
|  |     @GetMapping("/getListWithOptionList") | ||||||
|  |     public R<?>getListWithOptionList(Integer isStatistics){ | ||||||
|  |         List<DocStatisticsDefinitionDto> list = docStatisticsDefinitionAppService.getListWithOptionList(isStatistics); | ||||||
|  |         return R.ok(list); | ||||||
|  |     } | ||||||
|  |     /** | ||||||
|  |      * 获取文档统计定义选项列表并按指定格式返回-已作废 | ||||||
|      * |      * | ||||||
|      * @return |      * @return | ||||||
|      */ |      */ | ||||||
|   | |||||||
| @@ -1,25 +0,0 @@ | |||||||
| package com.openhis.web.document.controller; |  | ||||||
|  |  | ||||||
| import com.openhis.web.document.appservice.IDocRecordAppService; |  | ||||||
| import com.openhis.web.document.appservice.IDocStatisticsDefinitionOptionAppService; |  | ||||||
| import lombok.AllArgsConstructor; |  | ||||||
| import lombok.extern.slf4j.Slf4j; |  | ||||||
| import org.springframework.web.bind.annotation.RequestMapping; |  | ||||||
| import org.springframework.web.bind.annotation.RestController; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * 文文统计选项 controller |  | ||||||
|  * |  | ||||||
|  * @author wanghaiming |  | ||||||
|  * @date 2025-08-12 |  | ||||||
|  */ |  | ||||||
| @RestController |  | ||||||
| @RequestMapping("/document/statisticsOption") |  | ||||||
| @Slf4j |  | ||||||
| @AllArgsConstructor |  | ||||||
| public class DocStatisticsOptionController { |  | ||||||
|  |  | ||||||
|     private final IDocStatisticsDefinitionOptionAppService docStatisticsDefinitionOptionAppService; |  | ||||||
|  |  | ||||||
|  |  | ||||||
| } |  | ||||||
| @@ -18,7 +18,7 @@ import lombok.extern.slf4j.Slf4j; | |||||||
| import javax.servlet.http.HttpServletRequest; | import javax.servlet.http.HttpServletRequest; | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * DOC模板 controller |  * 文书模板 controller | ||||||
|  * |  * | ||||||
|  * @author wanghaiming |  * @author wanghaiming | ||||||
|  * @date 2025-08-12 |  * @date 2025-08-12 | ||||||
|   | |||||||
| @@ -1,5 +1,7 @@ | |||||||
| package com.openhis.web.document.dto; | package com.openhis.web.document.dto; | ||||||
|  |  | ||||||
|  | import com.fasterxml.jackson.databind.annotation.JsonSerialize; | ||||||
|  | import com.fasterxml.jackson.databind.ser.std.ToStringSerializer; | ||||||
| import lombok.Data; | import lombok.Data; | ||||||
| import lombok.experimental.Accessors; | import lombok.experimental.Accessors; | ||||||
|  |  | ||||||
| @@ -12,6 +14,8 @@ public class DirectoryNode { | |||||||
|     private String name; |     private String name; | ||||||
|     private int level; |     private int level; | ||||||
|     private DocDefinitionDto document; |     private DocDefinitionDto document; | ||||||
|  |     @JsonSerialize(using = ToStringSerializer.class) | ||||||
|  |     private Long id; | ||||||
|     private List<DirectoryNode> children = new ArrayList<>(); |     private List<DirectoryNode> children = new ArrayList<>(); | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -81,5 +81,7 @@ public class DocDefinitionDto { | |||||||
|      * 文书权限  0-不限制 1-查看 2- 编辑 |      * 文书权限  0-不限制 1-查看 2- 编辑 | ||||||
|      */ |      */ | ||||||
|     private Integer pharmacistPermissionEnum; |     private Integer pharmacistPermissionEnum; | ||||||
|  |     // 关键:通过contentUsing指定集合中元素的序列化器 | ||||||
|  |     @JsonSerialize(contentUsing = ToStringSerializer.class) | ||||||
|     private List<Long> organizationIds; |     private List<Long> organizationIds; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -19,6 +19,6 @@ public class DocDefinitionOrganizationDto { | |||||||
|     @JsonSerialize(using = ToStringSerializer.class) |     @JsonSerialize(using = ToStringSerializer.class) | ||||||
|     private Long definitionId; |     private Long definitionId; | ||||||
|     private String busNo; |     private String busNo; | ||||||
|     @JsonSerialize(using = ToStringSerializer.class) |     @JsonSerialize(contentUsing = ToStringSerializer.class) | ||||||
|     private List<Long> organizationIds; |     private List<Long> organizationIds; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -17,8 +17,5 @@ public class DocDefinitonParam { | |||||||
|     @JsonSerialize(using = ToStringSerializer.class) |     @JsonSerialize(using = ToStringSerializer.class) | ||||||
|     private Long organizationId; |     private Long organizationId; | ||||||
|     private String name; |     private String name; | ||||||
|     @JsonSerialize(using = ToStringSerializer.class) |  | ||||||
|     private List<Integer> useRanges; |     private List<Integer> useRanges; | ||||||
|  |  | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -53,4 +53,10 @@ public class DocRecordDto { | |||||||
|     @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") |     @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") | ||||||
|     private Date recordTime; |     private Date recordTime; | ||||||
|     private String createBy; |     private String createBy; | ||||||
|  |     private String source; | ||||||
|  |     /** | ||||||
|  |      * 记录名称 | ||||||
|  |      */ | ||||||
|  |     private String name; | ||||||
|  |     private String version; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -60,7 +60,7 @@ public class DocRecordPatientDto extends DocRecordDto { | |||||||
|     /** |     /** | ||||||
|      * 病历名称 |      * 病历名称 | ||||||
|      */ |      */ | ||||||
|     private String docName; |     private String name; | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 主菜单枚举值/病历类型 |      * 主菜单枚举值/病历类型 | ||||||
|   | |||||||
| @@ -1,5 +1,7 @@ | |||||||
| package com.openhis.web.document.dto; | package com.openhis.web.document.dto; | ||||||
|  |  | ||||||
|  | import com.core.common.annotation.Excel; | ||||||
|  | import com.core.common.core.domain.entity.SysDictData; | ||||||
| import com.fasterxml.jackson.databind.annotation.JsonSerialize; | import com.fasterxml.jackson.databind.annotation.JsonSerialize; | ||||||
| import com.fasterxml.jackson.databind.ser.std.ToStringSerializer; | import com.fasterxml.jackson.databind.ser.std.ToStringSerializer; | ||||||
| import lombok.Data; | import lombok.Data; | ||||||
| @@ -48,9 +50,16 @@ public class DocStatisticsDefinitionDto { | |||||||
|     */ |     */ | ||||||
|     private Integer displayOrder; |     private Integer displayOrder; | ||||||
|  |  | ||||||
|     /* |     private String defaultValue; | ||||||
|      统计类型定义选项值 |  | ||||||
|     */ | //    /* | ||||||
|     private DocStatisticsDefinitionOptionList optionList; | //     统计类型定义选项值 | ||||||
|  | //    */ | ||||||
|  |     private List<SysDictData> optionList; | ||||||
|  |     /** 字典名称 */ | ||||||
|  |     private String dictName; | ||||||
|  |  | ||||||
|  |     /** 字典类型 */ | ||||||
|  |     private String dictType; | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user