Преглед на файлове

Merge branch 'feature/1221-suggest' into develop-new

# Conflicts:
#	cooleshow-app/src/main/java/com/yonge/cooleshow/admin/controller/SysSuggestionTypeController.java
#	cooleshow-user/user-biz/src/main/java/com/yonge/cooleshow/biz/dal/enums/MessageTypeEnum.java
yuanliang преди 1 година
родител
ревизия
860fbd85df

+ 27 - 25
cooleshow-app/src/main/java/com/yonge/cooleshow/admin/controller/SysSuggestionTypeController.java

@@ -33,13 +33,12 @@ import java.util.HashMap;
 import java.util.List;
 import java.util.List;
 import java.util.Map;
 import java.util.Map;
 import java.util.Objects;
 import java.util.Objects;
-import java.util.function.Function;
 import java.util.stream.Collectors;
 import java.util.stream.Collectors;
 
 
 @Slf4j
 @Slf4j
 @Validated
 @Validated
 @RestController
 @RestController
-@RequestMapping("/sysSuggestionType")
+@RequestMapping("${app-config.url.admin:}/sysSuggestionType")
 @Api(tags = "平台建议类型表")
 @Api(tags = "平台建议类型表")
 public class SysSuggestionTypeController {
 public class SysSuggestionTypeController {
 
 
@@ -53,7 +52,7 @@ public class SysSuggestionTypeController {
     private SysUserService sysUserService;
     private SysUserService sysUserService;
 
 
     @ApiOperation(value = "详情", notes = "平台建议类型表-根据详情ID查询单条, 传入id")
     @ApiOperation(value = "详情", notes = "平台建议类型表-根据详情ID查询单条, 传入id")
-    @PreAuthorize("@pcs.hasPermissions('sysSuggestionType/detail', {'BACKEND'})")
+    @PreAuthorize("@pcs.hasPermissions('sysSuggestionType/detail')")
     @GetMapping("/detail/{id}")
     @GetMapping("/detail/{id}")
     public R<SysSuggestionType> detail(@PathVariable("id") Long id) {
     public R<SysSuggestionType> detail(@PathVariable("id") Long id) {
 
 
@@ -63,7 +62,7 @@ public class SysSuggestionTypeController {
     }
     }
 
 
     @ApiOperation(value = "查询分页", notes = "平台建议类型表- 传入 SysSuggestionTypeWrapper.SysSuggestionTypeQuery")
     @ApiOperation(value = "查询分页", notes = "平台建议类型表- 传入 SysSuggestionTypeWrapper.SysSuggestionTypeQuery")
-    @PreAuthorize("@pcs.hasPermissions('sysSuggestionType/page', {'BACKEND'})")
+    @PreAuthorize("@pcs.hasPermissions('sysSuggestionType/page')")
     @PostMapping("/page")
     @PostMapping("/page")
     public R<PageInfo<SysSuggestionTypeWrapper.SysSuggestionType>> page(@RequestBody SysSuggestionTypeWrapper.SysSuggestionTypeQuery query) {
     public R<PageInfo<SysSuggestionTypeWrapper.SysSuggestionType>> page(@RequestBody SysSuggestionTypeWrapper.SysSuggestionTypeQuery query) {
 
 
@@ -71,13 +70,14 @@ public class SysSuggestionTypeController {
 
 
         Map<Long, com.yonge.cooleshow.biz.dal.entity.SysUser> idEmpMap = new HashMap<>();
         Map<Long, com.yonge.cooleshow.biz.dal.entity.SysUser> idEmpMap = new HashMap<>();
         List<Long> updateIds = pages.getRecords().stream().map(SysSuggestionType::getUpdateBy)
         List<Long> updateIds = pages.getRecords().stream().map(SysSuggestionType::getUpdateBy)
-                .filter(Objects::nonNull).distinct().collect(Collectors.toList());
+            .filter(Objects::nonNull).distinct().collect(Collectors.toList());
         if (!updateIds.isEmpty()) {
         if (!updateIds.isEmpty()) {
-            idEmpMap.putAll(sysUserService.getMapByIds(updateIds));
+            Map<Long, com.yonge.cooleshow.biz.dal.entity.SysUser> idEmpMapTmp = sysUserService.getMapByIds(updateIds);
+            idEmpMap.putAll(idEmpMapTmp);
         }
         }
         List<SysSuggestionTypeWrapper.SysSuggestionType> rows = pages.getRecords().stream().map(next -> {
         List<SysSuggestionTypeWrapper.SysSuggestionType> rows = pages.getRecords().stream().map(next -> {
             SysSuggestionTypeWrapper.SysSuggestionType type =
             SysSuggestionTypeWrapper.SysSuggestionType type =
-                    JSON.parseObject(JSON.toJSONString(next), SysSuggestionTypeWrapper.SysSuggestionType.class);
+                JSON.parseObject(JSON.toJSONString(next), SysSuggestionTypeWrapper.SysSuggestionType.class);
             if (type.getUpdateBy() != null) {
             if (type.getUpdateBy() != null) {
                 type.setOperator(idEmpMap.getOrDefault(type.getUpdateBy(), new com.yonge.cooleshow.biz.dal.entity.SysUser()).getUsername());
                 type.setOperator(idEmpMap.getOrDefault(type.getUpdateBy(), new com.yonge.cooleshow.biz.dal.entity.SysUser()).getUsername());
             }
             }
@@ -87,21 +87,22 @@ public class SysSuggestionTypeController {
     }
     }
 
 
     @ApiOperation(value = "新增", notes = "平台建议类型表- 传入 SysSuggestionTypeWrapper.SysSuggestionType")
     @ApiOperation(value = "新增", notes = "平台建议类型表- 传入 SysSuggestionTypeWrapper.SysSuggestionType")
-    @PreAuthorize("@pcs.hasPermissions('sysSuggestionType/save', {'BACKEND'})")
+    @PreAuthorize("@pcs.hasPermissions('sysSuggestionType/save')")
     @PostMapping("/save")
     @PostMapping("/save")
     public R<JSONObject> add(@Validated @RequestBody SysSuggestionTypeVo.SysSuggestionType sysSuggestionType) {
     public R<JSONObject> add(@Validated @RequestBody SysSuggestionTypeVo.SysSuggestionType sysSuggestionType) {
+
         Integer count = sysSuggestionTypeService.lambdaQuery()
         Integer count = sysSuggestionTypeService.lambdaQuery()
-                .eq(SysSuggestionType::getName, sysSuggestionType.getName())
-                .eq(SysSuggestionType::getDelFlag, false)
-                .count();
+            .eq(SysSuggestionType::getName, sysSuggestionType.getName())
+            .eq(SysSuggestionType::getDelFlag, false)
+            .count();
         if (count > 0) {
         if (count > 0) {
             throw new BizException("建议类型已存在");
             throw new BizException("建议类型已存在");
         }
         }
-        SysUser userInfo = sysUserFeignService.queryUserInfo();
+        SysUser sysUser = sysUserFeignService.queryUserInfo();
         SysSuggestionType suggestionType = new SysSuggestionType();
         SysSuggestionType suggestionType = new SysSuggestionType();
         suggestionType.setName(sysSuggestionType.getName());
         suggestionType.setName(sysSuggestionType.getName());
-        suggestionType.setCreateBy(userInfo.getId());
-        suggestionType.setUpdateBy(userInfo.getId());
+        suggestionType.setCreateBy(sysUser.getId());
+        suggestionType.setUpdateBy(sysUser.getId());
         suggestionType.setDelFlag(false);
         suggestionType.setDelFlag(false);
         // 新增数据
         // 新增数据
         sysSuggestionTypeService.save(suggestionType);
         sysSuggestionTypeService.save(suggestionType);
@@ -110,23 +111,24 @@ public class SysSuggestionTypeController {
     }
     }
 
 
     @ApiOperation(value = "修改", notes = "平台建议类型表- 传入 SysSuggestionTypeWrapper.SysSuggestionType")
     @ApiOperation(value = "修改", notes = "平台建议类型表- 传入 SysSuggestionTypeWrapper.SysSuggestionType")
-    @PreAuthorize("@pcs.hasPermissions('sysSuggestionType/update', {'BACKEND'})")
+    @PreAuthorize("@pcs.hasPermissions('sysSuggestionType/update')")
     @PostMapping("/update")
     @PostMapping("/update")
     public R<JSONObject> update(@Validated @RequestBody SysSuggestionTypeVo.SysSuggestionType sysSuggestionType) {
     public R<JSONObject> update(@Validated @RequestBody SysSuggestionTypeVo.SysSuggestionType sysSuggestionType) {
-        SysUser userInfo = sysUserFeignService.queryUserInfo();
+
         Integer count = sysSuggestionTypeService.lambdaQuery()
         Integer count = sysSuggestionTypeService.lambdaQuery()
-                .eq(SysSuggestionType::getName, sysSuggestionType.getName())
-                .eq(SysSuggestionType::getDelFlag, false)
-                .ne(SysSuggestionType::getId, sysSuggestionType.getId())
-                .count();
+            .eq(SysSuggestionType::getName, sysSuggestionType.getName())
+            .eq(SysSuggestionType::getDelFlag, false)
+            .ne(SysSuggestionType::getId, sysSuggestionType.getId())
+            .count();
         if (count > 0) {
         if (count > 0) {
             throw new BizException("建议类型已存在");
             throw new BizException("建议类型已存在");
         }
         }
 
 
+        SysUser sysUser = sysUserFeignService.queryUserInfo();
         SysSuggestionType suggestionType = new SysSuggestionType();
         SysSuggestionType suggestionType = new SysSuggestionType();
         suggestionType.setId(sysSuggestionType.getId());
         suggestionType.setId(sysSuggestionType.getId());
         suggestionType.setName(sysSuggestionType.getName());
         suggestionType.setName(sysSuggestionType.getName());
-        suggestionType.setUpdateBy(userInfo.getId());
+        suggestionType.setUpdateBy(sysUser.getId());
         suggestionType.setDelFlag(false);
         suggestionType.setDelFlag(false);
         // 更新数据
         // 更新数据
         sysSuggestionTypeService.updateById(suggestionType);
         sysSuggestionTypeService.updateById(suggestionType);
@@ -135,13 +137,13 @@ public class SysSuggestionTypeController {
     }
     }
 
 
     @ApiOperation(value = "删除", notes = "平台建议类型表- 传入id")
     @ApiOperation(value = "删除", notes = "平台建议类型表- 传入id")
-    @PreAuthorize("@pcs.hasPermissions('sysSuggestionType/remove', {'BACKEND'})")
+    @PreAuthorize("@pcs.hasPermissions('sysSuggestionType/remove')")
     @PostMapping("/remove")
     @PostMapping("/remove")
     public R<JSONObject> remove(@RequestParam Long id) {
     public R<JSONObject> remove(@RequestParam Long id) {
         sysSuggestionTypeService.lambdaUpdate()
         sysSuggestionTypeService.lambdaUpdate()
-                .set(SysSuggestionType::getDelFlag, true)
-                .eq(SysSuggestionType::getId, id)
-                .update();
+            .set(SysSuggestionType::getDelFlag, true)
+            .eq(SysSuggestionType::getId, id)
+            .update();
         return R.defaultR();
         return R.defaultR();
     }
     }
 }
 }

+ 79 - 0
cooleshow-app/src/main/java/com/yonge/cooleshow/student/controller/SysSuggestionTypeController.java

@@ -0,0 +1,79 @@
+package com.yonge.cooleshow.student.controller;
+
+import com.alibaba.fastjson.JSON;
+import com.baomidou.mybatisplus.core.metadata.IPage;
+import com.microsvc.toolkit.common.response.paging.PageInfo;
+import com.microsvc.toolkit.common.response.paging.QueryInfo;
+import com.microsvc.toolkit.common.response.template.R;
+import com.yonge.cooleshow.biz.dal.entity.SysSuggestionType;
+import com.yonge.cooleshow.biz.dal.service.SysSuggestionTypeService;
+import com.yonge.cooleshow.biz.dal.service.SysUserService;
+import com.yonge.cooleshow.biz.dal.wrapper.SysSuggestionTypeWrapper;
+import io.swagger.annotations.Api;
+import io.swagger.annotations.ApiOperation;
+import lombok.extern.slf4j.Slf4j;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.security.access.prepost.PreAuthorize;
+import org.springframework.validation.annotation.Validated;
+import org.springframework.web.bind.annotation.GetMapping;
+import org.springframework.web.bind.annotation.PathVariable;
+import org.springframework.web.bind.annotation.PostMapping;
+import org.springframework.web.bind.annotation.RequestBody;
+import org.springframework.web.bind.annotation.RequestMapping;
+import org.springframework.web.bind.annotation.RestController;
+
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+import java.util.Objects;
+import java.util.stream.Collectors;
+
+@Slf4j
+@Validated
+@RestController
+@RequestMapping("${app-config.url.student:}/sysSuggestionType")
+@Api(tags = "平台建议类型表")
+public class SysSuggestionTypeController {
+
+    @Autowired
+    private SysSuggestionTypeService sysSuggestionTypeService;
+
+    @Autowired
+    private SysUserService sysUserService;
+
+    @ApiOperation(value = "详情", notes = "平台建议类型表-根据详情ID查询单条, 传入id")
+    @PreAuthorize("@pcs.hasPermissions('sysSuggestionType/detail')")
+    @GetMapping("/detail/{id}")
+    public R<SysSuggestionType> detail(@PathVariable("id") Long id) {
+
+        SysSuggestionType wrapper = sysSuggestionTypeService.detail(id);
+
+        return R.from(wrapper);
+    }
+
+    @ApiOperation(value = "查询分页", notes = "平台建议类型表- 传入 SysSuggestionTypeWrapper.SysSuggestionTypeQuery")
+    @PreAuthorize("@pcs.hasPermissions('sysSuggestionType/page')")
+    @PostMapping("/page")
+    public R<PageInfo<SysSuggestionTypeWrapper.SysSuggestionType>> page(@RequestBody SysSuggestionTypeWrapper.SysSuggestionTypeQuery query) {
+
+        IPage<SysSuggestionType> pages = sysSuggestionTypeService.selectPage(QueryInfo.getPage(query), query);
+
+        Map<Long, com.yonge.cooleshow.biz.dal.entity.SysUser> idEmpMap = new HashMap<>();
+        List<Long> updateIds = pages.getRecords().stream().map(SysSuggestionType::getUpdateBy)
+            .filter(Objects::nonNull).distinct().collect(Collectors.toList());
+        if (!updateIds.isEmpty()) {
+            Map<Long, com.yonge.cooleshow.biz.dal.entity.SysUser> idEmpMapTmp = sysUserService.getMapByIds(updateIds);
+            idEmpMap.putAll(idEmpMapTmp);
+        }
+        List<SysSuggestionTypeWrapper.SysSuggestionType> rows = pages.getRecords().stream().map(next -> {
+            SysSuggestionTypeWrapper.SysSuggestionType type =
+                JSON.parseObject(JSON.toJSONString(next), SysSuggestionTypeWrapper.SysSuggestionType.class);
+            if (type.getUpdateBy() != null) {
+                type.setOperator(idEmpMap.getOrDefault(type.getUpdateBy(), new com.yonge.cooleshow.biz.dal.entity.SysUser()).getUsername());
+            }
+            return type;
+        }).collect(Collectors.toList());
+        return R.from(QueryInfo.pageInfo(pages, rows));
+    }
+
+}

+ 79 - 0
cooleshow-app/src/main/java/com/yonge/cooleshow/teacher/controller/SysSuggestionTypeController.java

@@ -0,0 +1,79 @@
+package com.yonge.cooleshow.teacher.controller;
+
+import com.alibaba.fastjson.JSON;
+import com.baomidou.mybatisplus.core.metadata.IPage;
+import com.microsvc.toolkit.common.response.paging.PageInfo;
+import com.microsvc.toolkit.common.response.paging.QueryInfo;
+import com.microsvc.toolkit.common.response.template.R;
+import com.yonge.cooleshow.biz.dal.entity.SysSuggestionType;
+import com.yonge.cooleshow.biz.dal.service.SysSuggestionTypeService;
+import com.yonge.cooleshow.biz.dal.service.SysUserService;
+import com.yonge.cooleshow.biz.dal.wrapper.SysSuggestionTypeWrapper;
+import io.swagger.annotations.Api;
+import io.swagger.annotations.ApiOperation;
+import lombok.extern.slf4j.Slf4j;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.security.access.prepost.PreAuthorize;
+import org.springframework.validation.annotation.Validated;
+import org.springframework.web.bind.annotation.GetMapping;
+import org.springframework.web.bind.annotation.PathVariable;
+import org.springframework.web.bind.annotation.PostMapping;
+import org.springframework.web.bind.annotation.RequestBody;
+import org.springframework.web.bind.annotation.RequestMapping;
+import org.springframework.web.bind.annotation.RestController;
+
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+import java.util.Objects;
+import java.util.stream.Collectors;
+
+@Slf4j
+@Validated
+@RestController
+@RequestMapping("${app-config.url.teacher:}/sysSuggestionType")
+@Api(tags = "平台建议类型表")
+public class SysSuggestionTypeController {
+
+    @Autowired
+    private SysSuggestionTypeService sysSuggestionTypeService;
+
+    @Autowired
+    private SysUserService sysUserService;
+
+    @ApiOperation(value = "详情", notes = "平台建议类型表-根据详情ID查询单条, 传入id")
+    @PreAuthorize("@pcs.hasPermissions('sysSuggestionType/detail')")
+    @GetMapping("/detail/{id}")
+    public R<SysSuggestionType> detail(@PathVariable("id") Long id) {
+
+        SysSuggestionType wrapper = sysSuggestionTypeService.detail(id);
+
+        return R.from(wrapper);
+    }
+
+    @ApiOperation(value = "查询分页", notes = "平台建议类型表- 传入 SysSuggestionTypeWrapper.SysSuggestionTypeQuery")
+    @PreAuthorize("@pcs.hasPermissions('sysSuggestionType/page')")
+    @PostMapping("/page")
+    public R<PageInfo<SysSuggestionTypeWrapper.SysSuggestionType>> page(@RequestBody SysSuggestionTypeWrapper.SysSuggestionTypeQuery query) {
+
+        IPage<SysSuggestionType> pages = sysSuggestionTypeService.selectPage(QueryInfo.getPage(query), query);
+
+        Map<Long, com.yonge.cooleshow.biz.dal.entity.SysUser> idEmpMap = new HashMap<>();
+        List<Long> updateIds = pages.getRecords().stream().map(SysSuggestionType::getUpdateBy)
+            .filter(Objects::nonNull).distinct().collect(Collectors.toList());
+        if (!updateIds.isEmpty()) {
+            Map<Long, com.yonge.cooleshow.biz.dal.entity.SysUser> idEmpMapTmp = sysUserService.getMapByIds(updateIds);
+            idEmpMap.putAll(idEmpMapTmp);
+        }
+        List<SysSuggestionTypeWrapper.SysSuggestionType> rows = pages.getRecords().stream().map(next -> {
+            SysSuggestionTypeWrapper.SysSuggestionType type =
+                JSON.parseObject(JSON.toJSONString(next), SysSuggestionTypeWrapper.SysSuggestionType.class);
+            if (type.getUpdateBy() != null) {
+                type.setOperator(idEmpMap.getOrDefault(type.getUpdateBy(), new com.yonge.cooleshow.biz.dal.entity.SysUser()).getUsername());
+            }
+            return type;
+        }).collect(Collectors.toList());
+        return R.from(QueryInfo.pageInfo(pages, rows));
+    }
+
+}

+ 3 - 0
cooleshow-user/user-biz/src/main/java/com/yonge/cooleshow/biz/dal/enums/MessageTypeEnum.java

@@ -135,6 +135,9 @@ public enum MessageTypeEnum implements BaseEnum<String, MessageTypeEnum> {
     TEACHER_UNBIND_TENANT("老师解绑机构"),
     TEACHER_UNBIND_TENANT("老师解绑机构"),
 
 
     USER_TENANT_ALBUM_VIP("后台添加专辑时长"),
     USER_TENANT_ALBUM_VIP("后台添加专辑时长"),
+
+    SYS_SUGGEST_FEEDBACK_STUDENT("意见反馈推送"),
+    SYS_SUGGEST_FEEDBACK_TEACHER("意见反馈推送"),
     ;
     ;
 
 
     MessageTypeEnum(String msg) {
     MessageTypeEnum(String msg) {

+ 6 - 3
cooleshow-user/user-biz/src/main/java/com/yonge/cooleshow/biz/dal/service/SysMessageService.java

@@ -29,10 +29,13 @@ public interface SysMessageService extends BaseService<Long, SysMessage> {
 	 */
 	 */
 	public void batchSendMessage(MessageSender messageSender, MessageTypeEnum messageType, Map<Long, String> receivers, Date triggerTime,
 	public void batchSendMessage(MessageSender messageSender, MessageTypeEnum messageType, Map<Long, String> receivers, Date triggerTime,
 			Integer readStatus, String url,String jpushType, Object... args);
 			Integer readStatus, String url,String jpushType, Object... args);
-	
-	
+
+
+	void batchSendMessage(MessageSender messageSender, MessageTypeEnum type, Map<Long, String> receivers, Date triggerTime, Integer readStatus,
+						  String url, String jpushType, String title, Object... args);
+
 	public void batchSendMessage(MessageSender messageSender, String title, String content, Map<Long, String> receivers, Date triggerTime,
 	public void batchSendMessage(MessageSender messageSender, String title, String content, Map<Long, String> receivers, Date triggerTime,
-			Integer readStatus, String url,String jpushType, Object... args);
+								 Integer readStatus, String url, String jpushType, Object... args);
 
 
 
 
 	/**
 	/**

+ 12 - 4
cooleshow-user/user-biz/src/main/java/com/yonge/cooleshow/biz/dal/service/impl/SysMessageServiceImpl.java

@@ -136,7 +136,12 @@ public class SysMessageServiceImpl extends BaseServiceImpl<Long, SysMessage> imp
 
 
 	@Override
 	@Override
 	public void batchSendMessage(MessageSender messageSender, MessageTypeEnum type, Map<Long, String> receivers, Date triggerTime, Integer readStatus,
 	public void batchSendMessage(MessageSender messageSender, MessageTypeEnum type, Map<Long, String> receivers, Date triggerTime, Integer readStatus,
-			String url,String jpushType, Object... args) {
+								 String url, String jpushType, Object... args) {
+		batchSendMessage(messageSender, type, receivers, triggerTime, readStatus, url, jpushType, null, args);
+	}
+	@Override
+	public void batchSendMessage(MessageSender messageSender, MessageTypeEnum type, Map<Long, String> receivers, Date triggerTime, Integer readStatus,
+			String url,String jpushType,String title, Object... args) {
 		LOGGER.info("batchSendMessage msgSender {}, type {}, receivers {} ", messageSender, type, receivers);
 		LOGGER.info("batchSendMessage msgSender {}, type {}, receivers {} ", messageSender, type, receivers);
 		if (receivers == null || receivers.size() == 0) {
 		if (receivers == null || receivers.size() == 0) {
 			LOGGER.error("接收地址不能为空");
 			LOGGER.error("接收地址不能为空");
@@ -167,13 +172,16 @@ public class SysMessageServiceImpl extends BaseServiceImpl<Long, SysMessage> imp
 		Date date = new Date();
 		Date date = new Date();
 		SendStatusEnum status = SendStatusEnum.WAIT;
 		SendStatusEnum status = SendStatusEnum.WAIT;
 		String errorMsg = null;
 		String errorMsg = null;
+		String msgTitle = title;
+		if(StringUtils.isEmpty(msgTitle)){
+			msgTitle = messageConfig.getDescription();
+		}
 		// 立即发送
 		// 立即发送
 		if (triggerTime == null || date.after(triggerTime)) {
 		if (triggerTime == null || date.after(triggerTime)) {
 			status = SendStatusEnum.SENDING;
 			status = SendStatusEnum.SENDING;
 			try {
 			try {
-
 				if (isSendRemoteMessage(messageSender)) {
 				if (isSendRemoteMessage(messageSender)) {
-					errorMsg = messageSenderPluginContext.batchSend(messageSender, messageConfig.getDescription(),
+					errorMsg = messageSenderPluginContext.batchSend(messageSender, msgTitle,
 														 MessageFormatter.arrayFormat(messageConfig.getContent(), args), tos, url,jpushType,"default",null);
 														 MessageFormatter.arrayFormat(messageConfig.getContent(), args), tos, url,jpushType,"default",null);
 					if (StringUtils.isEmpty(errorMsg)) {
 					if (StringUtils.isEmpty(errorMsg)) {
 						status = SendStatusEnum.SUCCESSED;
 						status = SendStatusEnum.SUCCESSED;
@@ -197,7 +205,7 @@ public class SysMessageServiceImpl extends BaseServiceImpl<Long, SysMessage> imp
         if (ClientEnum.TENANT_STUDENT.getCode().equals(jpushType)) {
         if (ClientEnum.TENANT_STUDENT.getCode().equals(jpushType)) {
             jpushType = ClientEnum.STUDENT.getCode();
             jpushType = ClientEnum.STUDENT.getCode();
         }
         }
-		addMessage(receivers, messageConfig.getDescription(), MessageFormatter.arrayFormat(messageConfig.getContent(), args), triggerTime, mode, status, errorMsg, readStatus,
+		addMessage(receivers, title, MessageFormatter.arrayFormat(messageConfig.getContent(), args), triggerTime, mode, status, errorMsg, readStatus,
 				url, messageConfig.getGroup(),jpushType,messageConfig.getId());
 				url, messageConfig.getGroup(),jpushType,messageConfig.getId());
 	}
 	}
 
 

+ 43 - 1
cooleshow-user/user-biz/src/main/java/com/yonge/cooleshow/biz/dal/service/impl/SysSuggestionV2ServiceImpl.java

@@ -3,15 +3,31 @@ package com.yonge.cooleshow.biz.dal.service.impl;
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.microsvc.toolkit.common.webportal.exception.BizException;
 import com.microsvc.toolkit.common.webportal.exception.BizException;
+import com.yonge.cooleshow.auth.api.client.SysUserFeignService;
+import com.yonge.cooleshow.auth.api.entity.SysUser;
+import com.yonge.cooleshow.biz.dal.entity.SysSuggestionType;
 import com.yonge.cooleshow.biz.dal.entity.SysSuggestionV2;
 import com.yonge.cooleshow.biz.dal.entity.SysSuggestionV2;
+import com.yonge.cooleshow.biz.dal.enums.ClientEnum;
+import com.yonge.cooleshow.biz.dal.enums.MessageTypeEnum;
+import com.yonge.cooleshow.biz.dal.mapper.SysSuggestionTypeMapper;
 import com.yonge.cooleshow.biz.dal.mapper.SysSuggestionV2Mapper;
 import com.yonge.cooleshow.biz.dal.mapper.SysSuggestionV2Mapper;
+import com.yonge.cooleshow.biz.dal.service.SysMessageService;
+import com.yonge.cooleshow.biz.dal.service.SysSuggestionTypeService;
 import com.yonge.cooleshow.biz.dal.service.SysSuggestionV2Service;
 import com.yonge.cooleshow.biz.dal.service.SysSuggestionV2Service;
 import com.yonge.cooleshow.biz.dal.wrapper.SysSuggestionWrapper;
 import com.yonge.cooleshow.biz.dal.wrapper.SysSuggestionWrapper;
+import com.yonge.toolset.thirdparty.message.MessageSenderPluginContext;
 import lombok.extern.slf4j.Slf4j;
 import lombok.extern.slf4j.Slf4j;
+import org.apache.commons.lang3.StringUtils;
+import org.apache.commons.lang3.time.DateFormatUtils;
+import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 import org.springframework.transaction.annotation.Transactional;
 
 
+import javax.annotation.Resource;
 import java.util.Date;
 import java.util.Date;
+import java.util.HashMap;
+import java.util.Map;
+import java.util.Optional;
 
 
 /**
 /**
  * 平台建议表
  * 平台建议表
@@ -21,6 +37,11 @@ import java.util.Date;
 @Service
 @Service
 public class SysSuggestionV2ServiceImpl extends ServiceImpl<SysSuggestionV2Mapper, SysSuggestionV2> implements SysSuggestionV2Service {
 public class SysSuggestionV2ServiceImpl extends ServiceImpl<SysSuggestionV2Mapper, SysSuggestionV2> implements SysSuggestionV2Service {
 
 
+    @Autowired
+    private SysMessageService sysMessageService;
+
+    @Autowired
+    private SysSuggestionTypeMapper sysSuggestionTypeMapper;
 
 
 	/**
 	/**
      * 查询详情
      * 查询详情
@@ -85,9 +106,11 @@ public class SysSuggestionV2ServiceImpl extends ServiceImpl<SysSuggestionV2Mappe
         if (Boolean.TRUE.equals(handleStatus)) {
         if (Boolean.TRUE.equals(handleStatus)) {
             throw new BizException("反馈意见已经处理");
             throw new BizException("反馈意见已经处理");
         }
         }
+
+        Date handTime = new Date();
         this.lambdaUpdate()
         this.lambdaUpdate()
             .set(SysSuggestionV2::getHandleStatus, true)
             .set(SysSuggestionV2::getHandleStatus, true)
-            .set(SysSuggestionV2::getHandleTime, new Date())
+            .set(SysSuggestionV2::getHandleTime, handTime)
             .set(SysSuggestionV2::getFeedback, handleSuggestion.getFeedback())
             .set(SysSuggestionV2::getFeedback, handleSuggestion.getFeedback())
             .set(SysSuggestionV2::getFeedbackContent, handleSuggestion.getFeedbackContent())
             .set(SysSuggestionV2::getFeedbackContent, handleSuggestion.getFeedbackContent())
             .set(SysSuggestionV2::getHandleBy,handleSuggestion.getHandleBy())
             .set(SysSuggestionV2::getHandleBy,handleSuggestion.getHandleBy())
@@ -95,6 +118,25 @@ public class SysSuggestionV2ServiceImpl extends ServiceImpl<SysSuggestionV2Mappe
             .eq(SysSuggestionV2::getId, handleSuggestion.getId())
             .eq(SysSuggestionV2::getId, handleSuggestion.getId())
             .eq(SysSuggestionV2::getHandleStatus, false)
             .eq(SysSuggestionV2::getHandleStatus, false)
             .update();
             .update();
+
+        Boolean feedback = handleSuggestion.getFeedback();
+        if (feedback && StringUtils.isNotEmpty(handleSuggestion.getFeedbackContent())) {
+            // 推送消息
+            try {
+                Map<Long, String> receivers = new HashMap<>();
+                receivers.put(suggestion.getUserId(), suggestion.getMobileNo());
+                MessageTypeEnum messageType = MessageTypeEnum.SYS_SUGGEST_FEEDBACK_STUDENT;
+                if (ClientEnum.TEACHER.equals(suggestion.getClientType())) {
+                    messageType = MessageTypeEnum.SYS_SUGGEST_FEEDBACK_TEACHER;
+                }
+                SysSuggestionType type = Optional.ofNullable(sysSuggestionTypeMapper.selectById(suggestion.getSuggestionTypeId())).orElse(new SysSuggestionType());
+                String title = "【" + Optional.ofNullable(type.getName()).orElse("") + "】" + DateFormatUtils.format(handTime, "yyyy-MM-dd");
+                sysMessageService.batchSendMessage(MessageSenderPluginContext.MessageSender.JIGUANG, messageType,
+                        receivers, null, 0, null, null, title, handleSuggestion.getFeedbackContent());
+            } catch (Exception e) {
+                log.warn("意见反馈推送发送失败,{}", e.getMessage());
+            }
+        }
         return true;
         return true;
     }
     }
 }
 }