Commit 019e0676 authored by Smile's avatar Smile

fix:app站内信多语言修改

parent ea678a8b
......@@ -2,6 +2,7 @@ package cn.iocoder.yudao.module.customer.service.customer.complaint;
import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.framework.i18n.core.I18nMessage;
import cn.iocoder.yudao.framework.i18n.core.LangEnum;
import cn.iocoder.yudao.framework.mybatis.core.service.AbstractService;
import cn.iocoder.yudao.framework.mybatis.core.util.MyBatisUtils;
import cn.iocoder.yudao.framework.security.core.util.SecurityFrameworkUtils;
......@@ -92,8 +93,12 @@ public class CustomerComplaintServiceImpl extends AbstractService<CustomerCompla
InternalMessageCreateDto dto = InternalMessageCreateDto.builder().toIdList(Arrays.asList(updateReqVO.getCustomerId()))
.fromId("")
.sendTime(new Date())
.title(I18nMessage.getMessage("app.message.customer.complain.title"))
.content(I18nMessage.getMessage("app.message.customer.complain.content"))
.title(I18nMessage.getMessage("app.message.customer.complain.title", LangEnum.ZH.getLang()))
.titleEn(I18nMessage.getMessage("app.message.customer.complain.title", LangEnum.EN.getLang()))
.titleFr(I18nMessage.getMessage("app.message.customer.complain.title", LangEnum.FR.getLang()))
.content(I18nMessage.getMessage("app.message.customer.complain.content", LangEnum.ZH.getLang()))
.contentEn(I18nMessage.getMessage("app.message.customer.complain.content", LangEnum.EN.getLang()))
.contentFr(I18nMessage.getMessage("app.message.customer.complain.content", LangEnum.FR.getLang()))
.type(3).build();
clientInternalMessageApi.createInternalMessage(dto);
}
......
......@@ -28,11 +28,19 @@ public class InternalMessageCreateDto {
@DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND)
private Date sendTime;
@ApiModelProperty(value = "标题")
@ApiModelProperty(value = "标题中文")
private String title;
@ApiModelProperty(value = "标题英文")
private String titleEn;
@ApiModelProperty(value = "标题法文")
private String titleFr;
@ApiModelProperty(value = "内容")
@ApiModelProperty(value = "内容中文")
private String content;
@ApiModelProperty(value = "内容英文")
private String contentEn;
@ApiModelProperty(value = "内容法文")
private String contentFr;
@ApiModelProperty(value = "1订单消息,2出货消息,3提醒消息")
private Integer type;
......
......@@ -35,13 +35,29 @@ public class WebInternalMessageDO extends BaseDO {
*/
private Date sendTime;
/**
* 标题
* 标题中文
*/
private String title;
/**
* 内容
* 标题英文
*/
private String titleEn;
/**
* 标题法文
*/
private String titleFr;
/**
* 内容中文
*/
private String content;
/**
* 内容英文
*/
private String contentEn;
/**
* 内容法文
*/
private String contentFr;
/**
* 1订单消息,2出货消息,3提醒消息
*/
......
......@@ -32,14 +32,30 @@ public class InternalMessageBackVO {
@ApiModelProperty(value = "发送时间")
private Date sendTime;
@ExcelProperty("标题")
@ApiModelProperty(value = "标题")
@ExcelProperty("标题中文")
@ApiModelProperty(value = "标题中文")
private String title;
@ExcelProperty("内容")
@ApiModelProperty(value = "内容")
@ExcelProperty("标题英文")
@ApiModelProperty(value = "标题英文")
private String titleEn;
@ExcelProperty("标题法文")
@ApiModelProperty(value = "标题法文")
private String titleFr;
@ExcelProperty("内容中文")
@ApiModelProperty(value = "内容中文")
private String content;
@ExcelProperty("内容英文")
@ApiModelProperty(value = "内容英文")
private String contentEn;
@ExcelProperty("内容法文")
@ApiModelProperty(value = "内容法文")
private String contentFr;
@ExcelProperty("1订单消息,2出货消息,3提醒消息")
@ApiModelProperty(value = "1订单消息,2出货消息,3提醒消息")
private Integer type;
......
......@@ -24,12 +24,24 @@ public class InternalMessageBaseVO {
@JsonFormat(pattern = FORMAT_YEAR_MONTH_DAY)
private Date sendTime;
@ApiModelProperty(value = "标题")
@ApiModelProperty(value = "标题中文")
private String title;
@ApiModelProperty(value = "内容")
@ApiModelProperty(value = "标题英文")
private String titleEn;
@ApiModelProperty(value = "标题法文")
private String titleFr;
@ApiModelProperty(value = "内容中文")
private String content;
@ApiModelProperty(value = "内容英文")
private String contentEn;
@ApiModelProperty(value = "内容法文")
private String contentFr;
@ApiModelProperty(value = "1订单消息,2出货消息,3提醒消息")
private Integer type;
......
......@@ -24,12 +24,24 @@ public class InternalMessageQueryVO {
@ApiModelProperty(value = "结束发送时间")
private Date endSendTime;
@ApiModelProperty(value = "标题")
@ApiModelProperty(value = "标题中文")
private String title;
@ApiModelProperty(value = "内容")
@ApiModelProperty(value = "标题英文")
private String titleEn;
@ApiModelProperty(value = "标题法文")
private String titleFr;
@ApiModelProperty(value = "内容中文")
private String content;
@ApiModelProperty(value = "内容英文")
private String contentEn;
@ApiModelProperty(value = "内容法文")
private String contentFr;
@ApiModelProperty(value = "1订单消息,2出货消息,3提醒消息")
private Integer type;
......
......@@ -4,6 +4,7 @@ import cn.iocoder.yudao.framework.common.pojo.CommonResult;
import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.framework.excel.util.ExcelUtils;
import cn.iocoder.yudao.framework.i18n.core.I18nMessage;
import cn.iocoder.yudao.framework.i18n.core.LangEnum;
import cn.iocoder.yudao.framework.mybatis.core.query.LambdaQueryWrapperX;
import cn.iocoder.yudao.framework.mybatis.core.vo.PageVO;
import cn.iocoder.yudao.framework.operatelog.core.annotations.OperateLog;
......@@ -295,8 +296,12 @@ public class MemberUserController {
InternalMessageCreateDto dto = InternalMessageCreateDto.builder().toIdList(Arrays.asList(userCardAuth.getUserId()))
.fromId("")
.sendTime(new Date())
.title(I18nMessage.getMessage("app.message.kyc.success.title"))
.content(I18nMessage.getMessage("app.message.kyc.success.content"))
.title(I18nMessage.getMessage("app.message.kyc.success.title", LangEnum.ZH.getLang()))
.titleEn(I18nMessage.getMessage("app.message.kyc.success.title", LangEnum.EN.getLang()))
.titleFr(I18nMessage.getMessage("app.message.kyc.success.title", LangEnum.FR.getLang()))
.content(I18nMessage.getMessage("app.message.kyc.success.content", LangEnum.ZH.getLang()))
.contentEn(I18nMessage.getMessage("app.message.kyc.success.content", LangEnum.EN.getLang()))
.contentFr(I18nMessage.getMessage("app.message.kyc.success.content", LangEnum.FR.getLang()))
.type(3).build();
clientInternalMessageApi.createInternalMessage(dto);
}
......@@ -305,8 +310,12 @@ public class MemberUserController {
InternalMessageCreateDto dto = InternalMessageCreateDto.builder().toIdList(Arrays.asList(userCardAuth.getUserId()))
.fromId("")
.sendTime(new Date())
.title(I18nMessage.getMessage("app.message.kyc.failed.title"))
.content(I18nMessage.getMessage("app.message.kyc.failed.content") + reqVO.getAuditRemark())
.title(I18nMessage.getMessage("app.message.kyc.failed.title", LangEnum.ZH.getLang()))
.titleEn(I18nMessage.getMessage("app.message.kyc.failed.title", LangEnum.EN.getLang()))
.titleFr(I18nMessage.getMessage("app.message.kyc.failed.title", LangEnum.FR.getLang()))
.content(I18nMessage.getMessage("app.message.kyc.failed.content", LangEnum.ZH.getLang()) + reqVO.getAuditRemark())
.contentEn(I18nMessage.getMessage("app.message.kyc.failed.content", LangEnum.EN.getLang()) + reqVO.getAuditRemark())
.contentFr(I18nMessage.getMessage("app.message.kyc.failed.content", LangEnum.FR.getLang()) + reqVO.getAuditRemark())
.type(3).build();
clientInternalMessageApi.createInternalMessage(dto);
}
......@@ -342,8 +351,12 @@ public class MemberUserController {
InternalMessageCreateDto dto = InternalMessageCreateDto.builder().toIdList(Arrays.asList(userCardAuthId))
.fromId("")
.sendTime(new Date())
.title(I18nMessage.getMessage("app.message.kyc.success.title"))
.content(I18nMessage.getMessage("app.message.kyc.success.content"))
.title(I18nMessage.getMessage("app.message.kyc.success.title", LangEnum.ZH.getLang()))
.titleEn(I18nMessage.getMessage("app.message.kyc.success.title", LangEnum.EN.getLang()))
.titleFr(I18nMessage.getMessage("app.message.kyc.success.title", LangEnum.FR.getLang()))
.content(I18nMessage.getMessage("app.message.kyc.success.content", LangEnum.ZH.getLang()))
.contentEn(I18nMessage.getMessage("app.message.kyc.success.content", LangEnum.EN.getLang()))
.contentFr(I18nMessage.getMessage("app.message.kyc.success.content", LangEnum.FR.getLang()))
.type(3).build();
clientInternalMessageApi.createInternalMessage(dto);
}
......
......@@ -9,6 +9,7 @@ import cn.iocoder.yudao.framework.common.util.spring.enums.CommonStatusEnum;
import cn.iocoder.yudao.framework.common.util.spring.enums.UserTypeEnum;
import cn.iocoder.yudao.framework.common.util.validation.PhoneUtil;
import cn.iocoder.yudao.framework.i18n.core.I18nMessage;
import cn.iocoder.yudao.framework.i18n.core.LangEnum;
import cn.iocoder.yudao.framework.security.core.LoginUser;
import cn.iocoder.yudao.framework.security.core.authentication.MultiUsernamePasswordAuthenticationToken;
import cn.iocoder.yudao.module.customer.dal.dataobject.customer.CustomerDO;
......@@ -400,8 +401,12 @@ public class MemberAuthServiceImpl implements MemberAuthService {
InternalMessageCreateDto dto = InternalMessageCreateDto.builder().toIdList(Arrays.asList(userId))
.fromId("")
.sendTime(new Date())
.title(I18nMessage.getMessage("app.message.update.password.title"))
.content(I18nMessage.getMessage("app.message.update.password.content"))
.title(I18nMessage.getMessage("app.message.update.password.title", LangEnum.ZH.getLang()))
.titleEn(I18nMessage.getMessage("app.message.update.password.title", LangEnum.EN.getLang()))
.titleFr(I18nMessage.getMessage("app.message.update.password.title", LangEnum.FR.getLang()))
.content(I18nMessage.getMessage("app.message.update.password.content", LangEnum.ZH.getLang()))
.contentEn(I18nMessage.getMessage("app.message.update.password.content", LangEnum.EN.getLang()))
.contentFr(I18nMessage.getMessage("app.message.update.password.content", LangEnum.FR.getLang()))
.type(3).build();
clientInternalMessageApi.createInternalMessage(dto);
}
......@@ -423,8 +428,12 @@ public class MemberAuthServiceImpl implements MemberAuthService {
InternalMessageCreateDto dto = InternalMessageCreateDto.builder().toIdList(Arrays.asList(userDO.getId()))
.fromId("")
.sendTime(new Date())
.title(I18nMessage.getMessage("app.message.update.password.title"))
.content(I18nMessage.getMessage("app.message.update.password.content"))
.title(I18nMessage.getMessage("app.message.update.password.title", LangEnum.ZH.getLang()))
.titleEn(I18nMessage.getMessage("app.message.update.password.title", LangEnum.EN.getLang()))
.titleFr(I18nMessage.getMessage("app.message.update.password.title", LangEnum.FR.getLang()))
.content(I18nMessage.getMessage("app.message.update.password.content", LangEnum.ZH.getLang()))
.contentEn(I18nMessage.getMessage("app.message.update.password.content", LangEnum.EN.getLang()))
.contentFr(I18nMessage.getMessage("app.message.update.password.content", LangEnum.FR.getLang()))
.type(3).build();
clientInternalMessageApi.createInternalMessage(dto);
}
......@@ -442,8 +451,12 @@ public class MemberAuthServiceImpl implements MemberAuthService {
InternalMessageCreateDto dto = InternalMessageCreateDto.builder().toIdList(Arrays.asList(userId))
.fromId("")
.sendTime(new Date())
.title(I18nMessage.getMessage("app.message.update.control.password.title"))
.content(I18nMessage.getMessage("app.message.update.control.password.content"))
.title(I18nMessage.getMessage("app.message.update.control.password.title", LangEnum.ZH.getLang()))
.titleEn(I18nMessage.getMessage("app.message.update.control.password.title", LangEnum.EN.getLang()))
.titleFr(I18nMessage.getMessage("app.message.update.control.password.title", LangEnum.FR.getLang()))
.content(I18nMessage.getMessage("app.message.update.control.password.content", LangEnum.ZH.getLang()))
.contentEn(I18nMessage.getMessage("app.message.update.control.password.content", LangEnum.EN.getLang()))
.contentFr(I18nMessage.getMessage("app.message.update.control.password.content", LangEnum.FR.getLang()))
.type(3).build();
clientInternalMessageApi.createInternalMessage(dto);
}
......@@ -465,8 +478,12 @@ public class MemberAuthServiceImpl implements MemberAuthService {
InternalMessageCreateDto dto = InternalMessageCreateDto.builder().toIdList(Arrays.asList(userDO.getId()))
.fromId("")
.sendTime(new Date())
.title(I18nMessage.getMessage("app.message.update.control.password.title"))
.content(I18nMessage.getMessage("app.message.update.control.password.content"))
.title(I18nMessage.getMessage("app.message.update.control.password.title", LangEnum.ZH.getLang()))
.titleEn(I18nMessage.getMessage("app.message.update.control.password.title", LangEnum.EN.getLang()))
.titleFr(I18nMessage.getMessage("app.message.update.control.password.title", LangEnum.FR.getLang()))
.content(I18nMessage.getMessage("app.message.update.control.password.content", LangEnum.ZH.getLang()))
.contentEn(I18nMessage.getMessage("app.message.update.control.password.content", LangEnum.EN.getLang()))
.contentFr(I18nMessage.getMessage("app.message.update.control.password.content", LangEnum.FR.getLang()))
.type(3).build();
clientInternalMessageApi.createInternalMessage(dto);
//记录日志
......
......@@ -10,6 +10,7 @@ import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.framework.common.util.date.DateUtils;
import cn.iocoder.yudao.framework.common.util.spring.enums.CommonStatusEnum;
import cn.iocoder.yudao.framework.i18n.core.I18nMessage;
import cn.iocoder.yudao.framework.i18n.core.LangEnum;
import cn.iocoder.yudao.framework.mybatis.core.query.LambdaQueryWrapperX;
import cn.iocoder.yudao.framework.mybatis.core.util.MyBatisUtils;
import cn.iocoder.yudao.framework.mybatis.core.vo.PageVO;
......@@ -230,8 +231,12 @@ public class MemberUserServiceImpl implements MemberUserService {
InternalMessageCreateDto dto = InternalMessageCreateDto.builder().toIdList(Arrays.asList(user.getId()))
.fromId("")
.sendTime(new Date())
.title(I18nMessage.getMessage("app.message.reg.success.title"))
.content(I18nMessage.getMessage("app.message.reg.success.content"))
.title(I18nMessage.getMessage("app.message.reg.success.title", LangEnum.ZH.getLang()))
.titleEn(I18nMessage.getMessage("app.message.reg.success.title", LangEnum.EN.getLang()))
.titleFr(I18nMessage.getMessage("app.message.reg.success.title", LangEnum.FR.getLang()))
.content(I18nMessage.getMessage("app.message.reg.success.content", LangEnum.ZH.getLang()))
.contentEn(I18nMessage.getMessage("app.message.reg.success.content", LangEnum.EN.getLang()))
.contentFr(I18nMessage.getMessage("app.message.reg.success.content", LangEnum.FR.getLang()))
.type(3).build();
clientInternalMessageApi.createInternalMessage(dto);
......
......@@ -4,6 +4,7 @@ import java.util.*;
import javax.annotation.Resource;
import cn.iocoder.yudao.framework.i18n.core.I18nMessage;
import cn.iocoder.yudao.framework.i18n.core.LangEnum;
import cn.iocoder.yudao.module.ecw.api.internalMessage.ClientInternalMessageApi;
import cn.iocoder.yudao.module.ecw.api.internalMessage.dto.InternalMessageCreateDto;
import cn.iocoder.yudao.module.member.enums.UserAuditStatusEnum;
......@@ -72,8 +73,12 @@ public class UserCardAuthServiceImpl extends AbstractService<UserCardAuthMapper,
InternalMessageCreateDto dto = InternalMessageCreateDto.builder().toIdList(Arrays.asList(createReqVO.getUserId()))
.fromId("")
.sendTime(new Date())
.title(I18nMessage.getMessage("app.message.kyc.submit.title"))
.content(I18nMessage.getMessage("app.message.kyc.submit.content"))
.title(I18nMessage.getMessage("app.message.kyc.submit.title", LangEnum.ZH.getLang()))
.titleEn(I18nMessage.getMessage("app.message.kyc.submit.title", LangEnum.EN.getLang()))
.titleFr(I18nMessage.getMessage("app.message.kyc.submit.title", LangEnum.FR.getLang()))
.content(I18nMessage.getMessage("app.message.kyc.submit.content", LangEnum.ZH.getLang()))
.contentEn(I18nMessage.getMessage("app.message.kyc.submit.content", LangEnum.EN.getLang()))
.contentFr(I18nMessage.getMessage("app.message.kyc.submit.content", LangEnum.FR.getLang()))
.type(3).build();
clientInternalMessageApi.createInternalMessage(dto);
......
package cn.iocoder.yudao.module.member.vo.userLevel;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
import javax.validation.constraints.NotNull;
@Data
@ApiModel("管理后台 - 等级规则id请求 VO")
public class IdReqVo {
@ApiModelProperty(value = "主键", required = true)
@NotNull(message = "主键不能为空")
private Long id;
}
......@@ -8,6 +8,7 @@ import cn.iocoder.yudao.framework.common.util.date.DateUtils;
import cn.iocoder.yudao.framework.common.util.spring.enums.UserTypeEnum;
import cn.iocoder.yudao.framework.dict.core.dto.DictDataRespDTO;
import cn.iocoder.yudao.framework.i18n.core.I18nMessage;
import cn.iocoder.yudao.framework.i18n.core.LangEnum;
import cn.iocoder.yudao.framework.mybatis.core.service.AbstractService;
import cn.iocoder.yudao.framework.mybatis.core.util.MyBatisUtils;
import cn.iocoder.yudao.framework.mybatis.core.vo.PageVO;
......@@ -380,8 +381,14 @@ public class OrderCargoControlPickServiceImpl extends AbstractService<OrderCargo
InternalMessageCreateDto dto = InternalMessageCreateDto.builder().toIdList(new ArrayList<>(userIds))
.fromId("")
.sendTime(new Date())
.title(I18nMessage.getMessage("app.message.pick.title"))
.content(MessageFormat.format(I18nMessage.getMessage("app.message.pick.content"),
.title(I18nMessage.getMessage("app.message.pick.title", LangEnum.ZH.getLang()))
.titleEn(I18nMessage.getMessage("app.message.pick.title", LangEnum.EN.getLang()))
.titleFr(I18nMessage.getMessage("app.message.pick.title", LangEnum.FR.getLang()))
.content(MessageFormat.format(I18nMessage.getMessage("app.message.pick.content", LangEnum.ZH.getLang()),
orderDO.getOrderNo(), orderDO.getMarks(), DateUtil.format(now, "yyyy年MM月dd日"), createReqVO.getPickNum()))
.contentEn(MessageFormat.format(I18nMessage.getMessage("app.message.pick.content", LangEnum.EN.getLang()),
orderDO.getOrderNo(), orderDO.getMarks(), DateUtil.format(now, "yyyy年MM月dd日"), createReqVO.getPickNum()))
.contentFr(MessageFormat.format(I18nMessage.getMessage("app.message.pick.content", LangEnum.FR.getLang()),
orderDO.getOrderNo(), orderDO.getMarks(), DateUtil.format(now, "yyyy年MM月dd日"), createReqVO.getPickNum()))
.type(1).build();
clientInternalMessageApi.createInternalMessage(dto);
......
......@@ -11,6 +11,7 @@ import cn.iocoder.yudao.framework.apollo.core.event.LineChannelUpdateAirWeightEv
import cn.iocoder.yudao.framework.common.exception.enums.GlobalErrorCodeConstants;
import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.framework.i18n.core.I18nMessage;
import cn.iocoder.yudao.framework.i18n.core.LangEnum;
import cn.iocoder.yudao.framework.mybatis.core.query.QueryWrapperX;
import cn.iocoder.yudao.framework.mybatis.core.service.AbstractService;
import cn.iocoder.yudao.framework.mybatis.core.util.MyBatisUtils;
......@@ -296,7 +297,17 @@ public class OrderExceptionServiceImpl extends AbstractService<OrderExceptionMap
if (ids.size() > 0 && (orderDO.getInWarehouseState() > 0 || orderDO.getShipmentState() > 0)) {
// 判断入仓状态或出货状态不为0,则表示订单肯定入仓了
//发送站内信
InternalMessageCreateDto dto = InternalMessageCreateDto.builder().toIdList(new ArrayList<>(ids)).fromId("").sendTime(new Date()).title(I18nMessage.getMessage("order.exception.internalmessage.title")).content(StrUtil.format(I18nMessage.getMessage("order.exception.internalmessage.content"), orderDO.getOrderNo(), orderDO.getMarks(), createReqVO.getOrderExceptionDescVO().getDescZh())).type(1).build();
InternalMessageCreateDto dto = InternalMessageCreateDto.builder().toIdList(new ArrayList<>(ids))
.fromId("")
.sendTime(new Date())
.title(I18nMessage.getMessage("order.exception.internalmessage.title", LangEnum.ZH.getLang()))
.titleEn(I18nMessage.getMessage("order.exception.internalmessage.title", LangEnum.EN.getLang()))
.titleFr(I18nMessage.getMessage("order.exception.internalmessage.title", LangEnum.FR.getLang()))
.content(StrUtil.format(I18nMessage.getMessage("order.exception.internalmessage.content", LangEnum.ZH.getLang()), orderDO.getOrderNo(), orderDO.getMarks(), createReqVO.getOrderExceptionDescVO().getDescZh()))
.contentEn(StrUtil.format(I18nMessage.getMessage("order.exception.internalmessage.content", LangEnum.EN.getLang()), orderDO.getOrderNo(), orderDO.getMarks(), createReqVO.getOrderExceptionDescVO().getDescZh()))
.contentFr(StrUtil.format(I18nMessage.getMessage("order.exception.internalmessage.content", LangEnum.FR.getLang()), orderDO.getOrderNo(), orderDO.getMarks(), createReqVO.getOrderExceptionDescVO().getDescZh()))
.type(1)
.build();
clientInternalMessageApi.createInternalMessage(dto);
}
}
......
......@@ -16,6 +16,7 @@ import cn.iocoder.yudao.framework.common.util.date.DateUtils;
import cn.iocoder.yudao.framework.dict.core.dto.DictDataRespDTO;
import cn.iocoder.yudao.framework.dict.core.util.DictFrameworkUtils;
import cn.iocoder.yudao.framework.i18n.core.I18nMessage;
import cn.iocoder.yudao.framework.i18n.core.LangEnum;
import cn.iocoder.yudao.framework.mybatis.core.dataobject.BaseDO;
import cn.iocoder.yudao.framework.mybatis.core.query.LambdaQueryWrapperX;
import cn.iocoder.yudao.framework.mybatis.core.service.AbstractService;
......@@ -2620,26 +2621,56 @@ public class OrderWarehouseInServiceImpl extends AbstractService<OrderWarehouseI
UserRespDTO user = memberUserApi.getUser(userId);
if (user != null && StringUtils.isNotEmpty(user.getNickname())) {
String title = "";
String titleEn = "";
String titleFr = "";
String content = "";
String contentEn = "";
String contentFr = "";
if (orderDO.getTransportId() == 3) {
if (StringUtils.isNotBlank(exceptionContent)) {
// 空运有异常入仓
title = String.format(I18nMessage.getMessage("app.message.air.exception.warehousein.title"), orderDO.getOrderNo());
title = String.format(I18nMessage.getMessage("app.message.air.exception.warehousein.title", LangEnum.ZH.getLang()), orderDO.getOrderNo());
titleEn = String.format(I18nMessage.getMessage("app.message.air.exception.warehousein.title", LangEnum.EN.getLang()), orderDO.getOrderNo());
titleFr = String.format(I18nMessage.getMessage("app.message.air.exception.warehousein.title", LangEnum.FR.getLang()), orderDO.getOrderNo());
// 订单号:%s(唛头:%s)已入仓,存在异常:%s 请联系售前客服协助处理。如有疑问请于工作时间内(9:00--18:00)与我司客服联系:400-900-9962
content = String.format(I18nMessage.getMessage("app.message.air.exception.warehousein.content"),
content = String.format(I18nMessage.getMessage("app.message.air.exception.warehousein.content", LangEnum.ZH.getLang()),
orderDO.getOrderNo(), orderDO.getMarks(), exceptionContent);
contentEn = String.format(I18nMessage.getMessage("app.message.air.exception.warehousein.content", LangEnum.EN.getLang()),
orderDO.getOrderNo(), orderDO.getMarks(), exceptionContent);
contentFr = String.format(I18nMessage.getMessage("app.message.air.exception.warehousein.content", LangEnum.FR.getLang()),
orderDO.getOrderNo(), orderDO.getMarks(), exceptionContent);
} else {
// 空运无异常入仓
title = String.format(I18nMessage.getMessage("app.message.air.warehousein.title"), orderDO.getOrderNo());
title = String.format(I18nMessage.getMessage("app.message.air.warehousein.title"), orderDO.getOrderNo(), LangEnum.ZH.getLang());
titleEn = String.format(I18nMessage.getMessage("app.message.air.warehousein.title"), orderDO.getOrderNo(), LangEnum.EN.getLang());
titleFr = String.format(I18nMessage.getMessage("app.message.air.warehousein.title"), orderDO.getOrderNo(), LangEnum.FR.getLang());
// 尊敬的 %s(先生/女士),捷道货运通知您:您的唛头为%s,%s箱, %sCBM, %sKg, 入仓号为%s的货物已于%s 送到%s(起运港仓库),如有疑问请于工作时间内(9:00--18:00)与我司客服联系:400-900-9962
content = String.format(I18nMessage.getMessage("app.message.air.warehousein.content"),
content = String.format(I18nMessage.getMessage("app.message.air.warehousein.content", LangEnum.ZH.getLang()),
user.getNickname(), orderDO.getMarks(), orderDO.getSumNum(), orderDO.getSumVolume().toPlainString(),
orderDO.getSumWeight().toPlainString(), orderDO.getOrderNo(), DateUtil.format(ruchang, "yyyy年MM月dd日"),
startWarehouseName);
contentEn = String.format(I18nMessage.getMessage("app.message.air.warehousein.content", LangEnum.EN.getLang()),
user.getNickname(), orderDO.getMarks(), orderDO.getSumNum(), orderDO.getSumVolume().toPlainString(),
orderDO.getSumWeight().toPlainString(), orderDO.getOrderNo(), DateUtil.format(ruchang, "yyyy年MM月dd日"),
startWarehouseName);
contentFr = String.format(I18nMessage.getMessage("app.message.air.warehousein.content", LangEnum.FR.getLang()),
user.getNickname(), orderDO.getMarks(), orderDO.getSumNum(), orderDO.getSumVolume().toPlainString(),
orderDO.getSumWeight().toPlainString(), orderDO.getOrderNo(), DateUtil.format(ruchang, "yyyy年MM月dd日"),
startWarehouseName);
}
} else {
title = String.format(I18nMessage.getMessage("app.message.warehousein.title"), orderDO.getOrderNo());
content = String.format(I18nMessage.getMessage("app.message.warehousein.content"),
title = String.format(I18nMessage.getMessage("app.message.warehousein.title", LangEnum.ZH.getLang()), orderDO.getOrderNo());
titleEn = String.format(I18nMessage.getMessage("app.message.warehousein.title", LangEnum.EN.getLang()), orderDO.getOrderNo());
titleFr = String.format(I18nMessage.getMessage("app.message.warehousein.title", LangEnum.FR.getLang()), orderDO.getOrderNo());
content = String.format(I18nMessage.getMessage("app.message.warehousein.content", LangEnum.ZH.getLang()),
user.getNickname(), orderDO.getMarks(), orderDO.getSumNum(), orderDO.getSumVolume().toPlainString(),
orderDO.getSumWeight().toPlainString(), orderDO.getOrderNo(), DateUtil.format(ruchang, "yyyy年MM月dd日"),
startWarehouseName);
contentEn = String.format(I18nMessage.getMessage("app.message.warehousein.content", LangEnum.EN.getLang()),
user.getNickname(), orderDO.getMarks(), orderDO.getSumNum(), orderDO.getSumVolume().toPlainString(),
orderDO.getSumWeight().toPlainString(), orderDO.getOrderNo(), DateUtil.format(ruchang, "yyyy年MM月dd日"),
startWarehouseName);
contentFr = String.format(I18nMessage.getMessage("app.message.warehousein.content", LangEnum.FR.getLang()),
user.getNickname(), orderDO.getMarks(), orderDO.getSumNum(), orderDO.getSumVolume().toPlainString(),
orderDO.getSumWeight().toPlainString(), orderDO.getOrderNo(), DateUtil.format(ruchang, "yyyy年MM月dd日"),
startWarehouseName);
......@@ -2649,7 +2680,11 @@ public class OrderWarehouseInServiceImpl extends AbstractService<OrderWarehouseI
.fromId("")
.sendTime(new Date())
.title(title)
.titleEn(titleEn)
.titleFr(titleFr)
.content(content)
.contentEn(contentEn)
.contentFr(contentFr)
.type(3).build();
clientInternalMessageApi.createInternalMessage(dto);
......
......@@ -13,6 +13,7 @@ import cn.iocoder.yudao.framework.common.util.spring.enums.CommonStatusEnum;
import cn.iocoder.yudao.framework.dict.core.dto.DictDataRespDTO;
import cn.iocoder.yudao.framework.dict.core.util.DictFrameworkUtils;
import cn.iocoder.yudao.framework.i18n.core.I18nMessage;
import cn.iocoder.yudao.framework.i18n.core.LangEnum;
import cn.iocoder.yudao.framework.mybatis.core.dataobject.BaseDO;
import cn.iocoder.yudao.framework.mybatis.core.query.LambdaQuery;
import cn.iocoder.yudao.framework.mybatis.core.query.LambdaQueryWrapperX;
......@@ -4361,7 +4362,11 @@ public class BoxServiceImpl extends AbstractService<BoxMapper, BoxDO> implements
.fromId("")
.sendTime(new Date())
.title("预装审核通过")
.titleEn("预装审核通过")
.titleFr("预装审核通过")
.content("自编号:" + boxDO.getSelfNo() + "预装审核通过")
.contentEn("自编号:" + boxDO.getSelfNo() + "预装审核通过")
.contentFr("自编号:" + boxDO.getSelfNo() + "预装审核通过")
.type(1).build();
clientInternalMessageApi.createInternalMessage(dto);
}
......@@ -4433,43 +4438,93 @@ public class BoxServiceImpl extends AbstractService<BoxMapper, BoxDO> implements
}
// TODO 站内信如果有中英文,这里的获取标题与文案业务需要修改
String content = "";
String contentEn = "";
String contentFr = "";
String title = "";
String titleEn = "";
String titleFr = "";
String controlContent = "";
String controlContentEn = "";
String controlContentFr = "";
switch (boxStatusEnum) {
case SEAL_EXAMINE_SUCCESS:
title = String.format(I18nMessage.getMessage("app.message.cabinet.title"),
title = String.format(I18nMessage.getMessage("app.message.cabinet.title", LangEnum.ZH.getLang()),
orderDO.getOrderNo());
content = String.format(I18nMessage.getMessage("app.message.cabinet.content"),
titleEn = String.format(I18nMessage.getMessage("app.message.cabinet.title", LangEnum.EN.getLang()),
orderDO.getOrderNo());
titleFr = String.format(I18nMessage.getMessage("app.message.cabinet.title", LangEnum.FR.getLang()),
orderDO.getOrderNo());
content = String.format(I18nMessage.getMessage("app.message.cabinet.content", LangEnum.ZH.getLang()),
orderDO.getOrderNo(), orderDO.getMarks(), selfNo, date);
contentEn = String.format(I18nMessage.getMessage("app.message.cabinet.content", LangEnum.EN.getLang()),
orderDO.getOrderNo(), orderDO.getMarks(), selfNo, date);
contentFr = String.format(I18nMessage.getMessage("app.message.cabinet.content", LangEnum.FR.getLang()),
orderDO.getOrderNo(), orderDO.getMarks(), selfNo, date);
break;
case SHIPPING:
title = String.format(I18nMessage.getMessage("app.message.shipping.title"),
title = String.format(I18nMessage.getMessage("app.message.shipping.title", LangEnum.ZH.getLang()),
orderDO.getOrderNo(), orderDO.getMarks(), selfNo);
titleEn = String.format(I18nMessage.getMessage("app.message.shipping.title", LangEnum.EN.getLang()),
orderDO.getOrderNo(), orderDO.getMarks(), selfNo);
titleFr = String.format(I18nMessage.getMessage("app.message.shipping.title", LangEnum.FR.getLang()),
orderDO.getOrderNo(), orderDO.getMarks(), selfNo);
content = String.format(I18nMessage.getMessage("app.message.shipping.content"),
content = String.format(I18nMessage.getMessage("app.message.shipping.content", LangEnum.ZH.getLang()),
orderDO.getOrderNo(), orderDO.getMarks(), selfNo, date);
contentEn = String.format(I18nMessage.getMessage("app.message.shipping.content", LangEnum.EN.getLang()),
orderDO.getOrderNo(), orderDO.getMarks(), selfNo, date);
contentFr = String.format(I18nMessage.getMessage("app.message.shipping.content", LangEnum.FR.getLang()),
orderDO.getOrderNo(), orderDO.getMarks(), selfNo, date);
break;
case ARRIVAL_WAIT_DISCHARGE:
title = String.format(I18nMessage.getMessage("app.message.arrival.title"),
title = String.format(I18nMessage.getMessage("app.message.arrival.title", LangEnum.ZH.getLang()),
orderDO.getOrderNo());
titleEn = String.format(I18nMessage.getMessage("app.message.arrival.title", LangEnum.EN.getLang()),
orderDO.getOrderNo());
content = String.format(I18nMessage.getMessage("app.message.arrival.content"),
titleFr = String.format(I18nMessage.getMessage("app.message.arrival.title", LangEnum.FR.getLang()),
orderDO.getOrderNo());
content = String.format(I18nMessage.getMessage("app.message.arrival.content", LangEnum.ZH.getLang()),
orderDO.getOrderNo(), orderDO.getMarks());
contentEn = String.format(I18nMessage.getMessage("app.message.arrival.content", LangEnum.EN.getLang()),
orderDO.getOrderNo(), orderDO.getMarks());
contentFr = String.format(I18nMessage.getMessage("app.message.arrival.content", LangEnum.FR.getLang()),
orderDO.getOrderNo(), orderDO.getMarks());
break;
case CLEARANCE_WAIT_UNLOAD:
title = String.format(I18nMessage.getMessage("app.message.clearance.title"),
title = String.format(I18nMessage.getMessage("app.message.clearance.title", LangEnum.ZH.getLang()),
orderDO.getOrderNo());
titleEn = String.format(I18nMessage.getMessage("app.message.clearance.title", LangEnum.EN.getLang()),
orderDO.getOrderNo());
titleFr = String.format(I18nMessage.getMessage("app.message.clearance.title", LangEnum.FR.getLang()),
orderDO.getOrderNo());
content = String.format(I18nMessage.getMessage("app.message.clearance.content"),
content = String.format(I18nMessage.getMessage("app.message.clearance.content", LangEnum.ZH.getLang()),
orderDO.getOrderNo(), orderDO.getMarks());
contentEn = String.format(I18nMessage.getMessage("app.message.clearance.content", LangEnum.EN.getLang()),
orderDO.getOrderNo(), orderDO.getMarks());
contentFr = String.format(I18nMessage.getMessage("app.message.clearance.content", LangEnum.FR.getLang()),
orderDO.getOrderNo(), orderDO.getMarks());
break;
case UNLOADED:
title = String.format(I18nMessage.getMessage("app.message.unload.title"),
title = String.format(I18nMessage.getMessage("app.message.unload.title", LangEnum.ZH.getLang()),
orderDO.getOrderNo());
titleEn = String.format(I18nMessage.getMessage("app.message.unload.title", LangEnum.EN.getLang()),
orderDO.getOrderNo());
content = String.format(I18nMessage.getMessage("app.message.unload.content"),
titleFr = String.format(I18nMessage.getMessage("app.message.unload.title", LangEnum.FR.getLang()),
orderDO.getOrderNo());
content = String.format(I18nMessage.getMessage("app.message.unload.content", LangEnum.ZH.getLang()),
orderDO.getOrderNo(), orderDO.getMarks());
contentEn = String.format(I18nMessage.getMessage("app.message.unload.content", LangEnum.EN.getLang()),
orderDO.getOrderNo(), orderDO.getMarks());
contentFr = String.format(I18nMessage.getMessage("app.message.unload.content", LangEnum.FR.getLang()),
orderDO.getOrderNo(), orderDO.getMarks());
controlContent = String.format(I18nMessage.getMessage("app.message.unload.cargocontrol.content", LangEnum.ZH.getLang()),
orderDO.getOrderNo(), orderDO.getMarks());
controlContentEn = String.format(I18nMessage.getMessage("app.message.unload.cargocontrol.content", LangEnum.EN.getLang()),
orderDO.getOrderNo(), orderDO.getMarks());
controlContent = String.format(I18nMessage.getMessage("app.message.unload.cargocontrol.content"),
controlContentFr = String.format(I18nMessage.getMessage("app.message.unload.cargocontrol.content", LangEnum.FR.getLang()),
orderDO.getOrderNo(), orderDO.getMarks());
break;
}
......@@ -4482,13 +4537,19 @@ public class BoxServiceImpl extends AbstractService<BoxMapper, BoxDO> implements
//发送站内信
if (controlSet.contains(userId) && boxStatusEnum == UNLOADED) {
content = controlContent;
contentEn = controlContentEn;
contentFr = controlContentFr;
}
InternalMessageCreateDto dto = InternalMessageCreateDto.builder()
.toIdList(Collections.singletonList(userId))
.fromId("")
.sendTime(new Date())
.title(title)
.titleEn(titleEn)
.titleFr(titleFr)
.content(content)
.contentEn(contentEn)
.contentFr(contentFr)
.type(1).build();
clientInternalMessageApi.createInternalMessage(dto);
}
......@@ -4544,47 +4605,97 @@ public class BoxServiceImpl extends AbstractService<BoxMapper, BoxDO> implements
}
// TODO 站内信如果有中英文,这里的获取标题与文案业务需要修改
String content = "";
String contentEn = "";
String contentFr = "";
String title = "";
String titleEn = "";
String titleFr = "";
String controlContent = "";
String controlContentEn = "";
String controlContentFr = "";
switch (boxAirStatusEnum) {
case WAREHOUSED:
// 订单关联出货单出仓
title = String.format(I18nMessage.getMessage("app.message.warehoused.title"),
title = String.format(I18nMessage.getMessage("app.message.warehoused.title", LangEnum.ZH.getLang()),
orderDO.getOrderNo());
content = String.format(I18nMessage.getMessage("app.message.warehoused.content"),
titleEn = String.format(I18nMessage.getMessage("app.message.warehoused.title", LangEnum.EN.getLang()),
orderDO.getOrderNo());
titleFr = String.format(I18nMessage.getMessage("app.message.warehoused.title", LangEnum.FR.getLang()),
orderDO.getOrderNo());
content = String.format(I18nMessage.getMessage("app.message.warehoused.content", LangEnum.ZH.getLang()),
orderDO.getOrderNo(), orderDO.getMarks(), selfNo, date);
contentEn = String.format(I18nMessage.getMessage("app.message.warehoused.content", LangEnum.EN.getLang()),
orderDO.getOrderNo(), orderDO.getMarks(), selfNo, date);
contentFr = String.format(I18nMessage.getMessage("app.message.warehoused.content", LangEnum.FR.getLang()),
orderDO.getOrderNo(), orderDO.getMarks(), selfNo, date);
break;
case FLYING:
// 订单关联出货单起飞
title = String.format(I18nMessage.getMessage("app.message.flying.title"),
title = String.format(I18nMessage.getMessage("app.message.flying.title", LangEnum.ZH.getLang()),
orderDO.getOrderNo(), orderDO.getMarks(), selfNo);
titleEn = String.format(I18nMessage.getMessage("app.message.flying.title", LangEnum.EN.getLang()),
orderDO.getOrderNo(), orderDO.getMarks(), selfNo);
titleFr = String.format(I18nMessage.getMessage("app.message.flying.title", LangEnum.FR.getLang()),
orderDO.getOrderNo(), orderDO.getMarks(), selfNo);
content = String.format(I18nMessage.getMessage("app.message.flying.content"),
content = String.format(I18nMessage.getMessage("app.message.flying.content", LangEnum.ZH.getLang()),
orderDO.getOrderNo(), orderDO.getMarks(), selfNo, date);
contentEn = String.format(I18nMessage.getMessage("app.message.flying.content", LangEnum.EN.getLang()),
orderDO.getOrderNo(), orderDO.getMarks(), selfNo, date);
contentFr = String.format(I18nMessage.getMessage("app.message.flying.content", LangEnum.FR.getLang()),
orderDO.getOrderNo(), orderDO.getMarks(), selfNo, date);
break;
case ARRIVAL_WAIT_DISCHARGE:
// 订单关联出货单到港
title = String.format(I18nMessage.getMessage("app.message.air.arrival.title"),
title = String.format(I18nMessage.getMessage("app.message.air.arrival.title", LangEnum.ZH.getLang()),
orderDO.getOrderNo());
titleEn = String.format(I18nMessage.getMessage("app.message.air.arrival.title", LangEnum.EN.getLang()),
orderDO.getOrderNo());
content = String.format(I18nMessage.getMessage("app.message.air.arrival.content"),
titleFr = String.format(I18nMessage.getMessage("app.message.air.arrival.title", LangEnum.FR.getLang()),
orderDO.getOrderNo());
content = String.format(I18nMessage.getMessage("app.message.air.arrival.content", LangEnum.ZH.getLang()),
orderDO.getOrderNo(), orderDO.getMarks());
contentEn = String.format(I18nMessage.getMessage("app.message.air.arrival.content", LangEnum.EN.getLang()),
orderDO.getOrderNo(), orderDO.getMarks());
contentFr = String.format(I18nMessage.getMessage("app.message.air.arrival.content", LangEnum.FR.getLang()),
orderDO.getOrderNo(), orderDO.getMarks());
break;
case CLEARANCE_WAIT_WAREHOUSE:
// 订单关联出货单清关完成
title = String.format(I18nMessage.getMessage("app.message.air.clearance.title"),
title = String.format(I18nMessage.getMessage("app.message.air.clearance.title", LangEnum.ZH.getLang()),
orderDO.getOrderNo());
titleEn = String.format(I18nMessage.getMessage("app.message.air.clearance.title", LangEnum.EN.getLang()),
orderDO.getOrderNo());
titleFr = String.format(I18nMessage.getMessage("app.message.air.clearance.title", LangEnum.FR.getLang()),
orderDO.getOrderNo());
content = String.format(I18nMessage.getMessage("app.message.air.clearance.content"),
content = String.format(I18nMessage.getMessage("app.message.air.clearance.content", LangEnum.ZH.getLang()),
orderDO.getOrderNo(), orderDO.getMarks());
contentEn = String.format(I18nMessage.getMessage("app.message.air.clearance.content", LangEnum.EN.getLang()),
orderDO.getOrderNo(), orderDO.getMarks());
contentFr = String.format(I18nMessage.getMessage("app.message.air.clearance.content", LangEnum.FR.getLang()),
orderDO.getOrderNo(), orderDO.getMarks());
break;
case TO_WAREHOUSED:
// 订单关联出货单到仓,订单为控货订单
title = String.format(I18nMessage.getMessage("app.message.to.warehoused.title"),
title = String.format(I18nMessage.getMessage("app.message.to.warehoused.title", LangEnum.ZH.getLang()),
orderDO.getOrderNo());
titleEn = String.format(I18nMessage.getMessage("app.message.to.warehoused.title", LangEnum.EN.getLang()),
orderDO.getOrderNo());
content = String.format(I18nMessage.getMessage("app.message.to.warehoused.content"),
titleFr = String.format(I18nMessage.getMessage("app.message.to.warehoused.title", LangEnum.FR.getLang()),
orderDO.getOrderNo());
content = String.format(I18nMessage.getMessage("app.message.to.warehoused.content", LangEnum.ZH.getLang()),
orderDO.getOrderNo(), orderDO.getMarks());
contentEn = String.format(I18nMessage.getMessage("app.message.to.warehoused.content", LangEnum.EN.getLang()),
orderDO.getOrderNo(), orderDO.getMarks());
contentFr = String.format(I18nMessage.getMessage("app.message.to.warehoused.content", LangEnum.FR.getLang()),
orderDO.getOrderNo(), orderDO.getMarks());
controlContent = String.format(I18nMessage.getMessage("app.message.to.warehoused.cargo.control.content", LangEnum.ZH.getLang()),
orderDO.getOrderNo(), orderDO.getMarks());
controlContentEn = String.format(I18nMessage.getMessage("app.message.to.warehoused.cargo.control.content", LangEnum.EN.getLang()),
orderDO.getOrderNo(), orderDO.getMarks());
controlContent = String.format(I18nMessage.getMessage("app.message.to.warehoused.cargo.control.content"),
controlContentFr = String.format(I18nMessage.getMessage("app.message.to.warehoused.cargo.control.content", LangEnum.FR.getLang()),
orderDO.getOrderNo(), orderDO.getMarks());
break;
}
......@@ -4597,13 +4708,19 @@ public class BoxServiceImpl extends AbstractService<BoxMapper, BoxDO> implements
//发送站内信
if (controlSet.contains(userId) && boxAirStatusEnum == TO_WAREHOUSED) {
content = controlContent;
contentEn = controlContentEn;
contentFr = controlContentFr;
}
InternalMessageCreateDto dto = InternalMessageCreateDto.builder()
.toIdList(Collections.singletonList(userId))
.fromId("")
.sendTime(new Date())
.title(title)
.titleEn(titleEn)
.titleFr(titleFr)
.content(content)
.contentEn(contentEn)
.contentFr(contentFr)
.type(1).build();
clientInternalMessageApi.createInternalMessage(dto);
}
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment