From 3e05b6a51765c016d2467a34a4033856413ff73c Mon Sep 17 00:00:00 2001 From: "rong.liu" Date: Wed, 27 Dec 2023 20:37:00 +0800 Subject: [PATCH 1/5] =?UTF-8?q?=E5=AE=A1=E6=A0=B8=E5=A2=9E=E5=8A=A0?= =?UTF-8?q?=E6=9C=8D=E5=8A=A1=E9=80=9A=E7=9F=A5?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../controller/EnterpriseCertificationController.java | 3 ++- .../src/main/java/com/huoran/nakadai/utils/WeChatUtil.java | 6 +++--- 2 files changed, 5 insertions(+), 4 deletions(-) diff --git a/nakadai/src/main/java/com/huoran/nakadai/controller/EnterpriseCertificationController.java b/nakadai/src/main/java/com/huoran/nakadai/controller/EnterpriseCertificationController.java index 1df2504..d7d59d2 100644 --- a/nakadai/src/main/java/com/huoran/nakadai/controller/EnterpriseCertificationController.java +++ b/nakadai/src/main/java/com/huoran/nakadai/controller/EnterpriseCertificationController.java @@ -149,7 +149,7 @@ public class EnterpriseCertificationController { wxMssVo.setRequest_url("https://api.weixin.qq.com/cgi-bin/message/subscribe/send?access_token=" + accessToken); //将模板中的值一一赋值 发送到小程序的数据要转化为json格式 可以使用下面的方法直接拼接成JSONObject //使用map结合模板 后续再加遍历拼接成JSONObject - HashMap map = new HashMap<>(3); + HashMap map = new HashMap<>(4); map.put("thing1", details.getCompanyName());//公司名称 SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); @@ -161,6 +161,7 @@ public class EnterpriseCertificationController { //通过:更改认证状态 认证状态(0默认未认证 1.认证中2.已认证) enterpriseCertification.setAuthenticationStatus(2); authenticationStatus = "通过"; + map.put("thing3", "无");//备注 break; case 3: //不通过 diff --git a/nakadai/src/main/java/com/huoran/nakadai/utils/WeChatUtil.java b/nakadai/src/main/java/com/huoran/nakadai/utils/WeChatUtil.java index cdba470..64e81c3 100644 --- a/nakadai/src/main/java/com/huoran/nakadai/utils/WeChatUtil.java +++ b/nakadai/src/main/java/com/huoran/nakadai/utils/WeChatUtil.java @@ -60,9 +60,9 @@ public class WeChatUtil { // String appid = PropUtils.getProp("APPID"); // String appsecret = PropUtils.getProp("APPSECRET"); // 微信小程序ID - String appid = WeChatPropertiesUtil.PARTNER_WX_OPEN_APP_ID; + String appid = WeChatPropertiesUtil.KINDERGARTEN_WX_OPEN_APP_ID; // 微信小程序秘钥 - String appsecret =WeChatPropertiesUtil.PARTNER_WX_OPEN_APP_SECRET; + String appsecret =WeChatPropertiesUtil.KINDERGARTEN_WX_OPEN_APP_SECRET; //构建url,用于向微信服务器请求用户的openId StringBuffer url = new StringBuffer("https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&"); @@ -75,7 +75,7 @@ public class WeChatUtil { HttpResponse httpResponse = client.execute(httpGet); HttpEntity result = httpResponse.getEntity(); String resultStr = EntityUtils.toString(result); - System.out.println(resultStr); + System.err.println(resultStr); JSONObject resultJsonObject = JSONUtil.parseObj(resultStr); String accessToken = (String) resultJsonObject.get("access_token"); return accessToken; From 2cfb1e13277da069e78e3cf1cd2bda830adc8f61 Mon Sep 17 00:00:00 2001 From: "rong.liu" Date: Wed, 27 Dec 2023 22:07:26 +0800 Subject: [PATCH 2/5] =?UTF-8?q?=E6=B4=BB=E5=8A=A8=E5=A2=9E=E5=8A=A0?= =?UTF-8?q?=E5=88=86=E7=B1=BB?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../CompetitionClassificationController.java | 70 +++++++++++++++++++ .../controller/CompetitionController.java | 4 ++ .../competition/entity/Competition.java | 7 +- .../entity/CompetitionClassification.java | 43 ++++++++++++ .../req/AfterLoginPageCompetitionListReq.java | 3 + .../competition/entity/vo/CompetitionVO.java | 7 ++ .../CompetitionClassificationMapper.java | 16 +++++ .../xml/CompetitionClassificationMapper.xml | 5 ++ .../mapper/xml/CompetitionMapper.xml | 19 ++++- .../CompetitionClassificationService.java | 16 +++++ .../CompetitionClassificationServiceImpl.java | 20 ++++++ competition/src/test/java/CodeGenerator.java | 2 +- 12 files changed, 207 insertions(+), 5 deletions(-) create mode 100644 competition/src/main/java/com/huoran/competition/controller/CompetitionClassificationController.java create mode 100644 competition/src/main/java/com/huoran/competition/entity/CompetitionClassification.java create mode 100644 competition/src/main/java/com/huoran/competition/mapper/CompetitionClassificationMapper.java create mode 100644 competition/src/main/java/com/huoran/competition/mapper/xml/CompetitionClassificationMapper.xml create mode 100644 competition/src/main/java/com/huoran/competition/service/CompetitionClassificationService.java create mode 100644 competition/src/main/java/com/huoran/competition/service/impl/CompetitionClassificationServiceImpl.java diff --git a/competition/src/main/java/com/huoran/competition/controller/CompetitionClassificationController.java b/competition/src/main/java/com/huoran/competition/controller/CompetitionClassificationController.java new file mode 100644 index 0000000..ff13ba8 --- /dev/null +++ b/competition/src/main/java/com/huoran/competition/controller/CompetitionClassificationController.java @@ -0,0 +1,70 @@ +package com.huoran.competition.controller; + +import com.baomidou.mybatisplus.core.metadata.IPage; +import com.baomidou.mybatisplus.extension.plugins.pagination.Page; +import com.huoran.api.UserClient; +import com.huoran.common.response.R; +import com.huoran.common.utils.TokenUtils; +import com.huoran.competition.entity.CompetitionClassification; +import com.huoran.competition.service.CompetitionClassificationService; +import io.swagger.annotations.Api; +import io.swagger.annotations.ApiOperation; +import io.swagger.annotations.ApiParam; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.web.bind.annotation.*; + +import javax.servlet.http.HttpServletRequest; +import java.util.List; + +/** + * @描述:活动活动分类控制类 + * @作者: Rong + * @日期: 2023-12-27 + */ +@RestController +@RequestMapping("/competitionClassification") +@Api(value = "活动分类:CompetitionClassificationController", tags = "活动分类") +public class CompetitionClassificationController { + + @Autowired + public CompetitionClassificationService service; + + @Autowired + private UserClient userClient; + + @PostMapping("/categoryList") + @ApiOperation(value = "分类列表", response = CompetitionClassification.class) + public R categoryList() { + List list = service.list( null); + return R.ok().put("page",list); + } + + + @PostMapping("/save") + @ApiOperation(value = "自定义新增活动分类", response = CompetitionClassification.class) + public R save(@RequestBody @ApiParam(name = "活动活动分类对象", value = "传入json格式", required = true) CompetitionClassification competitionClassification, HttpServletRequest request) { + String accountId = TokenUtils.getIdByJwtToken(request); + competitionClassification.setAccountId(Integer.valueOf(accountId)); + boolean addState = service.save(competitionClassification); + return addState ? R.ok() : R.error("新增失败"); + } + + + @PostMapping("/update") + @ApiOperation(value = "修改活动分类", response = CompetitionClassification.class) + public R update(@RequestBody @ApiParam(name = "活动活动分类对象", value = "传入json格式", required = true) CompetitionClassification competitionClassification, HttpServletRequest request) { + String accountId = TokenUtils.getIdByJwtToken(request); + competitionClassification.setAccountId(Integer.valueOf(accountId)); + boolean updateState = service.updateById(competitionClassification); + return updateState ? R.ok() : R.error("编辑失败"); + } + + + @PostMapping("/batchDeletion") + @ApiOperation(value = "批量删除活动分类", response = CompetitionClassification.class) + public R batchDeletion(@ApiParam(name = "ids", value = "主键", required = true) @RequestBody List ids) { + boolean delState = service.removeByIds(ids); + return delState ? R.ok() : R.error("删除失败"); + } +} + diff --git a/competition/src/main/java/com/huoran/competition/controller/CompetitionController.java b/competition/src/main/java/com/huoran/competition/controller/CompetitionController.java index cce2e03..783921e 100644 --- a/competition/src/main/java/com/huoran/competition/controller/CompetitionController.java +++ b/competition/src/main/java/com/huoran/competition/controller/CompetitionController.java @@ -51,6 +51,9 @@ public class CompetitionController { @Autowired private UserClient userClient; + + @Autowired + public CompetitionClassificationService competitionClassificationService; @Autowired private CompetitionService competitionService; @@ -150,6 +153,7 @@ public class CompetitionController { public R getCompetition(@ApiParam(name = "competitionId", value = "活动ID", required = true) @RequestParam("competitionId") String competitionId, HttpServletRequest request) { String accountId = TokenUtils.getIdByJwtToken(request); Competition competition = competitionService.getById(competitionId); + // 查询活动报名表 QueryWrapper wrapper = new QueryWrapper<>(); wrapper.eq("competition_id", competitionId); diff --git a/competition/src/main/java/com/huoran/competition/entity/Competition.java b/competition/src/main/java/com/huoran/competition/entity/Competition.java index c9c2eb4..27489b7 100644 --- a/competition/src/main/java/com/huoran/competition/entity/Competition.java +++ b/competition/src/main/java/com/huoran/competition/entity/Competition.java @@ -108,6 +108,9 @@ public class Competition implements Serializable { @ApiModelProperty(value = "数量上限限制") private Integer quantityLimit; + @ApiModelProperty(value = "活动分类id") + private Integer classificationId; + @ApiModelProperty(value = "邀请码") private String invitationCode; @@ -137,6 +140,8 @@ public class Competition implements Serializable { @TableField(exist = false) private CompetitionRegistration competitionRegistration; - + @ApiModelProperty(value = "活动分类名称") + @TableField(exist = false) + private String classificationName; } diff --git a/competition/src/main/java/com/huoran/competition/entity/CompetitionClassification.java b/competition/src/main/java/com/huoran/competition/entity/CompetitionClassification.java new file mode 100644 index 0000000..c4dca54 --- /dev/null +++ b/competition/src/main/java/com/huoran/competition/entity/CompetitionClassification.java @@ -0,0 +1,43 @@ +package com.huoran.competition.entity; + +import com.baomidou.mybatisplus.annotation.*; +import io.swagger.annotations.ApiModel; +import io.swagger.annotations.ApiModelProperty; +import lombok.Data; + +import java.io.Serializable; +import java.util.Date; + +/** + * @描述:活动分类 + * @作者: Rong + * @日期: 2023-12-27 + */ +@Data +@ApiModel(value = "活动分类") +@TableName("c_competition_classification") +public class CompetitionClassification implements Serializable { + + private static final long serialVersionUID = 1L; + + @TableId(type = IdType.AUTO) + @ApiModelProperty(value = "活动分类主键") + private Integer id; + + @ApiModelProperty(value = "活动分类名称") + private String classificationName; + + @ApiModelProperty(value = "创建人") + private Integer accountId; + + + @ApiModelProperty(value = "创建时间") + @TableField(fill = FieldFill.INSERT) + private Date createTime; + + @ApiModelProperty(value = "更新时间") + @TableField(fill = FieldFill.INSERT_UPDATE) + private Date updateTime; + + +} \ No newline at end of file diff --git a/competition/src/main/java/com/huoran/competition/entity/req/AfterLoginPageCompetitionListReq.java b/competition/src/main/java/com/huoran/competition/entity/req/AfterLoginPageCompetitionListReq.java index f48250b..a8c28ca 100644 --- a/competition/src/main/java/com/huoran/competition/entity/req/AfterLoginPageCompetitionListReq.java +++ b/competition/src/main/java/com/huoran/competition/entity/req/AfterLoginPageCompetitionListReq.java @@ -35,4 +35,7 @@ public class AfterLoginPageCompetitionListReq extends PageReq{ @ApiModelProperty(value = "读取的列表(0:首页活动/1.已报名活动)", example = "5") private Integer listType; + + @ApiModelProperty(value = "活动分类id") + private Integer classificationId; } \ No newline at end of file diff --git a/competition/src/main/java/com/huoran/competition/entity/vo/CompetitionVO.java b/competition/src/main/java/com/huoran/competition/entity/vo/CompetitionVO.java index 9ecee45..3d2347a 100644 --- a/competition/src/main/java/com/huoran/competition/entity/vo/CompetitionVO.java +++ b/competition/src/main/java/com/huoran/competition/entity/vo/CompetitionVO.java @@ -153,4 +153,11 @@ public class CompetitionVO implements Serializable { @ApiModelProperty(value = "是否展示报名人员(0否,1是)") private String whetherToShowApplicants; + @ApiModelProperty(value = "分类名称") + private String classificationName; + + @ApiModelProperty(value = "活动分类id") + private Integer classificationId; + + } diff --git a/competition/src/main/java/com/huoran/competition/mapper/CompetitionClassificationMapper.java b/competition/src/main/java/com/huoran/competition/mapper/CompetitionClassificationMapper.java new file mode 100644 index 0000000..563687c --- /dev/null +++ b/competition/src/main/java/com/huoran/competition/mapper/CompetitionClassificationMapper.java @@ -0,0 +1,16 @@ +package com.huoran.competition.mapper; + +import com.huoran.competition.entity.CompetitionClassification; +import com.baomidou.mybatisplus.core.mapper.BaseMapper; + +/** + *

+ * 活动分类 Mapper 接口 + *

+ * + * @author cheney + * @since 2023-12-27 + */ +public interface CompetitionClassificationMapper extends BaseMapper { + +} diff --git a/competition/src/main/java/com/huoran/competition/mapper/xml/CompetitionClassificationMapper.xml b/competition/src/main/java/com/huoran/competition/mapper/xml/CompetitionClassificationMapper.xml new file mode 100644 index 0000000..996e00c --- /dev/null +++ b/competition/src/main/java/com/huoran/competition/mapper/xml/CompetitionClassificationMapper.xml @@ -0,0 +1,5 @@ + + + + + diff --git a/competition/src/main/java/com/huoran/competition/mapper/xml/CompetitionMapper.xml b/competition/src/main/java/com/huoran/competition/mapper/xml/CompetitionMapper.xml index 753caa7..d341c33 100644 --- a/competition/src/main/java/com/huoran/competition/mapper/xml/CompetitionMapper.xml +++ b/competition/src/main/java/com/huoran/competition/mapper/xml/CompetitionMapper.xml @@ -696,16 +696,22 @@ ( CASE create_source WHEN 0 THEN '平台创建' WHEN 1 THEN '组织创建' ELSE '无' END ) AS createSource, IF ( - ( SELECT r.id FROM c_competition_registration r WHERE r.competition_id = c.id AND r.account_id = #{req.accountId} ) IS NULL, + ( SELECT r.id FROM c_competition_registration r WHERE r.competition_id = c.id AND r.account_id = 4940 ) IS NULL, 1, 0 - ) AS whetherToSignUp + ) AS whetherToSignUp, + cla.classification_name, + c.classification_id FROM c_competition c + INNER JOIN c_competition_classification cla ON c.classification_id = cla.id WHERE c.is_open = 0 AND c.publish_status = 1 + + and c.classification_id=#{req.classificationId} + and create_time between #{req.startTime} and #{req.endTime} @@ -771,10 +777,13 @@ c.is_open, create_source, ( CASE create_source WHEN 0 THEN '平台创建' WHEN 1 THEN '组织创建' ELSE '无' END ) AS createSource, - ( SELECT d.id FROM c_competition_user_del d WHERE d.account_id = r.account_id AND d.competition_id = c.id ) AS isDelCompetition + ( SELECT d.id FROM c_competition_user_del d WHERE d.account_id = r.account_id AND d.competition_id = c.id ) AS isDelCompetition, + cla.classification_name, + c.classification_id FROM c_competition_registration r INNER JOIN c_competition c ON c.id = r.competition_id + INNER JOIN c_competition_classification cla ON c.classification_id = cla.id WHERE r.account_id = #{req.accountId} @@ -783,6 +792,10 @@ WHERE t.isDelCompetition IS NULL + + and t.classification_id =#{req.classificationId} + + and t.create_time between #{req.startTime} and #{req.endTime} diff --git a/competition/src/main/java/com/huoran/competition/service/CompetitionClassificationService.java b/competition/src/main/java/com/huoran/competition/service/CompetitionClassificationService.java new file mode 100644 index 0000000..de43b11 --- /dev/null +++ b/competition/src/main/java/com/huoran/competition/service/CompetitionClassificationService.java @@ -0,0 +1,16 @@ +package com.huoran.competition.service; + +import com.huoran.competition.entity.CompetitionClassification; +import com.baomidou.mybatisplus.extension.service.IService; + +/** + *

+ * 活动分类 服务类 + *

+ * + * @author cheney + * @since 2023-12-27 + */ +public interface CompetitionClassificationService extends IService { + +} diff --git a/competition/src/main/java/com/huoran/competition/service/impl/CompetitionClassificationServiceImpl.java b/competition/src/main/java/com/huoran/competition/service/impl/CompetitionClassificationServiceImpl.java new file mode 100644 index 0000000..fe31107 --- /dev/null +++ b/competition/src/main/java/com/huoran/competition/service/impl/CompetitionClassificationServiceImpl.java @@ -0,0 +1,20 @@ +package com.huoran.competition.service.impl; + +import com.huoran.competition.entity.CompetitionClassification; +import com.huoran.competition.mapper.CompetitionClassificationMapper; +import com.huoran.competition.service.CompetitionClassificationService; +import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import org.springframework.stereotype.Service; + +/** + *

+ * 活动分类 服务实现类 + *

+ * + * @author cheney + * @since 2023-12-27 + */ +@Service +public class CompetitionClassificationServiceImpl extends ServiceImpl implements CompetitionClassificationService { + +} diff --git a/competition/src/test/java/CodeGenerator.java b/competition/src/test/java/CodeGenerator.java index cebfc46..a90c5cc 100644 --- a/competition/src/test/java/CodeGenerator.java +++ b/competition/src/test/java/CodeGenerator.java @@ -60,7 +60,7 @@ public class CodeGenerator { // 5、策略配置 StrategyConfig strategy = new StrategyConfig(); - strategy.setInclude("c_competition_user_del"); + strategy.setInclude("c_competition_classification"); strategy.setNaming(NamingStrategy.underline_to_camel);//数据库表映射到实体的命名策略 strategy.setTablePrefix("c_"); //生成实体时去掉表前缀 From 4079690f2ddb476d0e638959154cb7887dbcbafc Mon Sep 17 00:00:00 2001 From: "rong.liu" Date: Thu, 28 Dec 2023 13:49:21 +0800 Subject: [PATCH 3/5] =?UTF-8?q?=E5=AE=8C=E5=96=84?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../com/huoran/competition/mapper/xml/CompetitionMapper.xml | 6 ++++-- .../controller/SupplierClassificationController.java | 2 +- .../com/huoran/nakadai/entity/SupplierClassification.java | 5 +++++ .../huoran/nakadai/entity/SupplierClassificationConfig.java | 1 + 4 files changed, 11 insertions(+), 3 deletions(-) diff --git a/competition/src/main/java/com/huoran/competition/mapper/xml/CompetitionMapper.xml b/competition/src/main/java/com/huoran/competition/mapper/xml/CompetitionMapper.xml index d341c33..36406c7 100644 --- a/competition/src/main/java/com/huoran/competition/mapper/xml/CompetitionMapper.xml +++ b/competition/src/main/java/com/huoran/competition/mapper/xml/CompetitionMapper.xml @@ -81,13 +81,15 @@ ) AS applicant_num, c.is_open, create_source, - ( CASE create_source WHEN 0 THEN '平台创建' WHEN 1 THEN '组织创建' ELSE '无' END ) AS createSource + ( CASE create_source WHEN 0 THEN '平台创建' WHEN 1 THEN '组织创建' ELSE '无' END ) AS createSource, + cla.classification_name, + c.classification_id FROM c_competition c + INNER JOIN c_competition_classification cla ON c.classification_id = cla.id WHERE 1 = 1 - and create_time between #{req.startTime} and #{req.endTime} diff --git a/nakadai/src/main/java/com/huoran/nakadai/controller/SupplierClassificationController.java b/nakadai/src/main/java/com/huoran/nakadai/controller/SupplierClassificationController.java index b1d622a..2c87523 100644 --- a/nakadai/src/main/java/com/huoran/nakadai/controller/SupplierClassificationController.java +++ b/nakadai/src/main/java/com/huoran/nakadai/controller/SupplierClassificationController.java @@ -36,7 +36,7 @@ public class SupplierClassificationController { @PostMapping("/treeStructureList") @ApiOperation(value = "树结构列表", response = SupplierClassification.class) - public R treeStructureList(@RequestBody SupplierClassificationReq supplierClassification) { + public R treeStructureList() { /*QueryWrapper queryWrapper = new QueryWrapper<>(); queryWrapper.eq("parent_id", supplierClassification.getParentId());*/ List list = service.list(null); diff --git a/nakadai/src/main/java/com/huoran/nakadai/entity/SupplierClassification.java b/nakadai/src/main/java/com/huoran/nakadai/entity/SupplierClassification.java index 62d72e2..bed6a28 100644 --- a/nakadai/src/main/java/com/huoran/nakadai/entity/SupplierClassification.java +++ b/nakadai/src/main/java/com/huoran/nakadai/entity/SupplierClassification.java @@ -1,5 +1,6 @@ package com.huoran.nakadai.entity; +import com.baomidou.mybatisplus.annotation.FieldFill; import com.baomidou.mybatisplus.annotation.IdType; import com.baomidou.mybatisplus.annotation.TableField; import com.baomidou.mybatisplus.annotation.TableId; @@ -54,12 +55,16 @@ public class SupplierClassification implements Serializable { //使用@JsonIgnore注解,忽略此属性,前端不会拿到该属性 @JsonIgnore @ApiModelProperty(value = "创建时间") + @TableField(fill = FieldFill.INSERT) private Date createTime; //使用@JsonIgnore注解,忽略此属性,前端不会拿到该属性 @JsonIgnore @ApiModelProperty(value = "修改时间") + @TableField(fill = FieldFill.INSERT_UPDATE) private Date updateTime; + + @ApiModelProperty(value = "子分类集合") @TableField(exist = false) diff --git a/nakadai/src/main/java/com/huoran/nakadai/entity/SupplierClassificationConfig.java b/nakadai/src/main/java/com/huoran/nakadai/entity/SupplierClassificationConfig.java index dc80357..ee55ff2 100644 --- a/nakadai/src/main/java/com/huoran/nakadai/entity/SupplierClassificationConfig.java +++ b/nakadai/src/main/java/com/huoran/nakadai/entity/SupplierClassificationConfig.java @@ -26,6 +26,7 @@ public class SupplierClassificationConfig implements Serializable { private static final long serialVersionUID = 1L; @ApiModelProperty(value = "主键") + @TableId(value = "id", type = IdType.AUTO) private Integer id; @ApiModelProperty(value = "分类id") From ce0b3b1b42df3f7e2aaf906bbb5799aeca828b70 Mon Sep 17 00:00:00 2001 From: "rong.liu" Date: Thu, 28 Dec 2023 20:29:54 +0800 Subject: [PATCH 4/5] =?UTF-8?q?=E5=AE=8C=E5=96=84?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../PlatformTeamAccountController.java | 92 +++++++++++-------- .../entity/EnterpriseCertification.java | 9 ++ .../req/EnterpriseCertificationLIstReq.java | 6 ++ .../huoran/nakadai/entity/req/TeamInfo.java | 8 +- .../entity/vo/TeamClassificationVO.java | 35 +++++++ .../nakadai/mapper/PlatformTeamMapper.java | 7 ++ .../SupplierClassificationConfigMapper.java | 2 + .../xml/EnterpriseCertificationMapper.xml | 12 ++- .../nakadai/mapper/xml/PlatformTeamMapper.xml | 28 ++++++ .../SupplierClassificationConfigMapper.xml | 3 + .../nakadai/service/PlatformTeamService.java | 8 +- .../SupplierClassificationConfigService.java | 3 +- .../service/impl/PlatformTeamServiceImpl.java | 12 +++ ...pplierClassificationConfigServiceImpl.java | 4 + 14 files changed, 183 insertions(+), 46 deletions(-) create mode 100644 nakadai/src/main/java/com/huoran/nakadai/entity/vo/TeamClassificationVO.java diff --git a/nakadai/src/main/java/com/huoran/nakadai/controller/PlatformTeamAccountController.java b/nakadai/src/main/java/com/huoran/nakadai/controller/PlatformTeamAccountController.java index be0d108..10707a7 100644 --- a/nakadai/src/main/java/com/huoran/nakadai/controller/PlatformTeamAccountController.java +++ b/nakadai/src/main/java/com/huoran/nakadai/controller/PlatformTeamAccountController.java @@ -6,12 +6,16 @@ import com.huoran.common.exception.CustomException; import com.huoran.common.exception.ExceptionEnum; import com.huoran.common.response.R; import com.huoran.common.utils.TokenUtils; -import com.huoran.nakadai.entity.*; +import com.huoran.nakadai.entity.PlatformTeam; +import com.huoran.nakadai.entity.PlatformTeamClassification; import com.huoran.nakadai.entity.req.*; import com.huoran.nakadai.entity.res.PartnerAccountResp; import com.huoran.nakadai.entity.res.PlatformTeamAccountResp; -import com.huoran.nakadai.entity.vo.TeamMemberVo; -import com.huoran.nakadai.service.*; +import com.huoran.nakadai.entity.vo.TeamClassificationVO; +import com.huoran.nakadai.service.PlatformTeamAccountService; +import com.huoran.nakadai.service.PlatformTeamClassificationService; +import com.huoran.nakadai.service.PlatformTeamService; +import com.huoran.nakadai.service.SupplierClassificationConfigService; import com.huoran.nakadai.utils.GenerateCodeUtil; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; @@ -25,6 +29,7 @@ import org.springframework.web.bind.annotation.*; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.validation.Valid; +import java.util.List; import java.util.Map; import java.util.Objects; import java.util.concurrent.TimeUnit; @@ -51,34 +56,33 @@ public class PlatformTeamAccountController { @Autowired public PlatformTeamClassificationService platformTeamClassificationService; + @Autowired + public SupplierClassificationConfigService supplierClassificationConfigService; + @Autowired private RedisTemplate redisTemplate; @PostMapping("/generateInvitationCode") @ApiOperation(value = "生成不同平台专属邀请码") - public R generateInvitationCode( - @ApiParam(name = "platformId", value = "平台id", required = true) - @RequestParam("platformId") String platformId,HttpServletRequest request) { + public R generateInvitationCode(@ApiParam(name = "platformId", value = "平台id", required = true) @RequestParam("platformId") String platformId, HttpServletRequest request) { //平台唯一标识码 - String uniqueIdentification = platformId+TokenUtils.getIdByJwtToken(request)+"kindergartenInvitationCode"; + String uniqueIdentification = platformId + TokenUtils.getIdByJwtToken(request) + "kindergartenInvitationCode"; //存在直接返回邀请码 String code = redisTemplate.opsForValue().get(uniqueIdentification); - if (StringUtils.isEmpty(code)){ + if (StringUtils.isEmpty(code)) { code = GenerateCodeUtil.generateCode(); - redisTemplate.opsForValue().set(uniqueIdentification,code,7, TimeUnit.DAYS); + redisTemplate.opsForValue().set(uniqueIdentification, code, 7, TimeUnit.DAYS); } //过期时间 Long expireTime = redisTemplate.opsForValue().getOperations().getExpire(uniqueIdentification); - return Objects.requireNonNull(R.ok().put("invitationCode", code)).put("expireTime",expireTime); + return Objects.requireNonNull(R.ok().put("invitationCode", code)).put("expireTime", expireTime); } @ApiOperation(value = "平台邀请二维码生成") - @GetMapping(value = "/generationQrCode",produces = "image/png") - public void generationQrCode( - @ApiParam(name = "url", value = "链接", required = true) - @RequestParam String url, HttpServletResponse response){ - platformTeamAccountService.generationQrCode(url,response); + @GetMapping(value = "/generationQrCode", produces = "image/png") + public void generationQrCode(@ApiParam(name = "url", value = "链接", required = true) @RequestParam String url, HttpServletResponse response) { + platformTeamAccountService.generationQrCode(url, response); } @@ -145,11 +149,7 @@ public class PlatformTeamAccountController { @GetMapping("/removeOrganization") @ApiOperation(value = "移除组织") - public R removeOrganization( - @ApiParam(name = "teamId", value = "团队id") - @RequestParam Integer teamId, - @ApiParam(name = "manageId", value = "组织id") - @RequestParam Integer manageId) { + public R removeOrganization(@ApiParam(name = "teamId", value = "团队id") @RequestParam Integer teamId, @ApiParam(name = "manageId", value = "组织id") @RequestParam Integer manageId) { PlatformTeamClassification teamClassification = platformTeamClassificationService.getById(teamId); if (teamClassification.getIsTeam() == 1) { throw new CustomException(ExceptionEnum.PARTNER_REMOVAL); @@ -158,46 +158,40 @@ public class PlatformTeamAccountController { platformTeamClassificationService.removeById(teamId); //TODO 删除该团队相关角色信息 platformTeamAccountService.removeById(manageId); - boolean remove = platformTeamService.remove(new QueryWrapper(). - eq("manage_id", manageId). - eq("classification_id", teamId)); + boolean remove = platformTeamService.remove(new QueryWrapper().eq("manage_id", manageId).eq("classification_id", teamId)); return remove ? R.ok() : R.error(); } @ApiOperation(value = "后台更新团队状态,禁用无法查询到该组织") @PostMapping("/updateTeamStatus") - public R updateTeamStatus( - @RequestParam("teamId") @ApiParam(value = "团队id") Integer teamId, - @RequestParam("isEnable") @ApiParam(value = "是否禁用(1->禁用,0->启用)") Integer isEnable) { + public R updateTeamStatus(@RequestParam("teamId") @ApiParam(value = "团队id") Integer teamId, @RequestParam("isEnable") @ApiParam(value = "是否禁用(1->禁用,0->启用)") Integer isEnable) { PlatformTeamClassification platformTeamClassification = new PlatformTeamClassification(); platformTeamClassification.setId(teamId); platformTeamClassification.setIsEnable(isEnable); boolean update = platformTeamClassificationService.updateById(platformTeamClassification); - return update? R.ok() : R.error(); + return update ? R.ok() : R.error(); } //================================以下接口为小程序调用=================================== @ApiOperation(value = "幼教产品微信小程序回调登录") @PostMapping("/weChatAppletCallbackByKindergarten") public R weChatAppletCallbackByKindergarten(@RequestBody @Valid AppletCallbackReq appletCallbackReq, HttpServletResponse response) throws Exception { - Map result = platformTeamAccountService.kindergartenWeChatAccountApplication(appletCallbackReq); - return R.ok().put("data",result); + Map result = platformTeamAccountService.kindergartenWeChatAccountApplication(appletCallbackReq); + return R.ok().put("data", result); } @ApiOperation(value = "幼教产品微信小程序账号注册(根据openid)") @PostMapping("/kindergartenWeChatApplication") - public R kindergartenWeChatApplication(@RequestBody @Valid AppletCallbackReq appletCallbackReq) { + public R kindergartenWeChatApplication(@RequestBody @Valid AppletCallbackReq appletCallbackReq) { return platformTeamAccountService.kindergartenWeChatApplication(appletCallbackReq); } @ApiOperation(value = "获取当前平台用户的团队信息", response = PartnerAccountResp.class) @GetMapping("/getTeamsByPlatformId") - public R getTeamsByPlatformId( - @ApiParam(name = "platformId", value = "平台id") - @RequestParam Integer platformId,HttpServletRequest request) { + public R getTeamsByPlatformId(@ApiParam(name = "platformId", value = "平台id") @RequestParam Integer platformId, HttpServletRequest request) { String accountId = TokenUtils.getIdByJwtToken(request); - return platformTeamAccountService.getTeamsByPlatformId(accountId,platformId); + return platformTeamAccountService.getTeamsByPlatformId(accountId, platformId); } @PostMapping("/platformTeamAccountList") @@ -210,18 +204,36 @@ public class PlatformTeamAccountController { @PostMapping("/updateTeamInfo") public R updateTeamInfo(@RequestBody TeamInfo teamInfo) { PlatformTeamClassification platformTeamClassification = new PlatformTeamClassification(); - BeanUtils.copyProperties(teamInfo,platformTeamClassification); + BeanUtils.copyProperties(teamInfo, platformTeamClassification); + // 供应商角色下编辑分类 + // 查询供应商的分类信息(只有当前团队为供应商才有supplierClassification数据) + + Integer accountId = platformTeamService.getAccountIdByTeamId(teamInfo.getId()); + + //删除原有分类重新新增分类配置信息 + supplierClassificationConfigService.deleteByAccountId(accountId); + //设置分类配置信息中的accountId + teamInfo.getSupplierClassificationConfigs().forEach(config -> config.setAccountId(accountId)); + + //新增分类配置信息 + supplierClassificationConfigService.saveBatch(teamInfo.getSupplierClassificationConfigs()); + + + boolean update = platformTeamClassificationService.updateById(platformTeamClassification); - return update? R.ok() : R.error(); + return update ?R.ok():R.error(); } + + + @ApiOperation(value = "查询团队信息") @GetMapping("/queryTeamInfo") - public R queryTeamInfo( - @ApiParam(value = "团队id") - @RequestParam("teamId") Integer teamId) { + public R queryTeamInfo(@ApiParam(value = "团队id") @RequestParam("teamId") Integer teamId) { PlatformTeamClassification teamInfo = platformTeamClassificationService.getById(teamId); - return R.ok().put("teamInfo",teamInfo); + //查询供应商的分类信息(只有当前团队为供应商才有supplierClassification数据) + List supplierClassification = platformTeamService.getTeamClassificationVOByTeamId(teamId); + return R.ok().put("teamInfo", teamInfo).put("supplierClassification", supplierClassification); } @PostMapping("/inviteJoinOrganization") diff --git a/nakadai/src/main/java/com/huoran/nakadai/entity/EnterpriseCertification.java b/nakadai/src/main/java/com/huoran/nakadai/entity/EnterpriseCertification.java index b1731c3..96a5b97 100644 --- a/nakadai/src/main/java/com/huoran/nakadai/entity/EnterpriseCertification.java +++ b/nakadai/src/main/java/com/huoran/nakadai/entity/EnterpriseCertification.java @@ -129,4 +129,13 @@ public class EnterpriseCertification implements Serializable { @ApiModelProperty(value = "微信唯一标识") private String openId; + + + @ApiModelProperty(value = "供应商分类id") + @TableField(exist = false) + private Integer supplierClassificationId; + + @ApiModelProperty(value = "供应商分类名称") + @TableField(exist = false) + private String supplierClassificationName; } diff --git a/nakadai/src/main/java/com/huoran/nakadai/entity/req/EnterpriseCertificationLIstReq.java b/nakadai/src/main/java/com/huoran/nakadai/entity/req/EnterpriseCertificationLIstReq.java index 47b5eab..f4c6aad 100644 --- a/nakadai/src/main/java/com/huoran/nakadai/entity/req/EnterpriseCertificationLIstReq.java +++ b/nakadai/src/main/java/com/huoran/nakadai/entity/req/EnterpriseCertificationLIstReq.java @@ -47,6 +47,12 @@ public class EnterpriseCertificationLIstReq { @ApiModelProperty(value = "市") private String city; + @ApiModelProperty(value = "供应商分类id") + private Integer supplierClassificationId; + + /*@ApiModelProperty(value = "供应商分类名称") + private String supplierClassificationName;*/ + @ApiModelProperty(value = "当前页数", name = "pageNum", example = "1", required = true) private Integer pageNum; @ApiModelProperty(value = "当前页需要显示的数量", name = "pageSize", example = "10", required = true) diff --git a/nakadai/src/main/java/com/huoran/nakadai/entity/req/TeamInfo.java b/nakadai/src/main/java/com/huoran/nakadai/entity/req/TeamInfo.java index 60bb646..6f16136 100644 --- a/nakadai/src/main/java/com/huoran/nakadai/entity/req/TeamInfo.java +++ b/nakadai/src/main/java/com/huoran/nakadai/entity/req/TeamInfo.java @@ -1,10 +1,11 @@ package com.huoran.nakadai.entity.req; -import com.baomidou.mybatisplus.annotation.IdType; -import com.baomidou.mybatisplus.annotation.TableId; +import com.huoran.nakadai.entity.SupplierClassificationConfig; import io.swagger.annotations.ApiModelProperty; import lombok.Data; +import java.util.List; + @Data public class TeamInfo { @@ -55,4 +56,7 @@ public class TeamInfo { @ApiModelProperty(value = "phone") private String phone; + + @ApiModelProperty(value = "供应商分类配置") + private List supplierClassificationConfigs; } diff --git a/nakadai/src/main/java/com/huoran/nakadai/entity/vo/TeamClassificationVO.java b/nakadai/src/main/java/com/huoran/nakadai/entity/vo/TeamClassificationVO.java new file mode 100644 index 0000000..8c2054f --- /dev/null +++ b/nakadai/src/main/java/com/huoran/nakadai/entity/vo/TeamClassificationVO.java @@ -0,0 +1,35 @@ +package com.huoran.nakadai.entity.vo; + +import io.swagger.annotations.ApiModelProperty; +import lombok.Data; + +/** + *

+ * 幼教产业团队账号与分类中间表 + *

+ * + * @author chen + * @since 2023-12-12 + */ +@Data +public class TeamClassificationVO { + + + @ApiModelProperty(value = "团队id") + private Integer teamId; + + @ApiModelProperty(value = "账户id") + private Integer accountId; + + @ApiModelProperty(value = "供应商分类id") + private Integer supplierClassificationId; + + @ApiModelProperty(value = "供应商分类名称") + private String supplierClassificationName; + + @ApiModelProperty(value = "供应商分类配置id") + private Integer classificationConfigId; + + + +} diff --git a/nakadai/src/main/java/com/huoran/nakadai/mapper/PlatformTeamMapper.java b/nakadai/src/main/java/com/huoran/nakadai/mapper/PlatformTeamMapper.java index 6945dc6..59be365 100644 --- a/nakadai/src/main/java/com/huoran/nakadai/mapper/PlatformTeamMapper.java +++ b/nakadai/src/main/java/com/huoran/nakadai/mapper/PlatformTeamMapper.java @@ -2,7 +2,11 @@ package com.huoran.nakadai.mapper; import com.huoran.nakadai.entity.PlatformTeam; import com.baomidou.mybatisplus.core.mapper.BaseMapper; +import com.huoran.nakadai.entity.vo.TeamClassificationVO; import org.apache.ibatis.annotations.Mapper; +import org.apache.ibatis.annotations.Param; + +import java.util.List; /** *

@@ -14,5 +18,8 @@ import org.apache.ibatis.annotations.Mapper; */ @Mapper public interface PlatformTeamMapper extends BaseMapper { + List getTeamClassificationVOByTeamId(@Param("teamId") Integer teamId); + + Integer getAccountIdByTeamId(@Param("teamId") Integer teamId); } diff --git a/nakadai/src/main/java/com/huoran/nakadai/mapper/SupplierClassificationConfigMapper.java b/nakadai/src/main/java/com/huoran/nakadai/mapper/SupplierClassificationConfigMapper.java index 8265739..ced6384 100644 --- a/nakadai/src/main/java/com/huoran/nakadai/mapper/SupplierClassificationConfigMapper.java +++ b/nakadai/src/main/java/com/huoran/nakadai/mapper/SupplierClassificationConfigMapper.java @@ -2,6 +2,7 @@ package com.huoran.nakadai.mapper; import com.huoran.nakadai.entity.SupplierClassificationConfig; import com.baomidou.mybatisplus.core.mapper.BaseMapper; +import org.apache.ibatis.annotations.Param; /** *

@@ -13,4 +14,5 @@ import com.baomidou.mybatisplus.core.mapper.BaseMapper; */ public interface SupplierClassificationConfigMapper extends BaseMapper { + boolean deleteByAccountId(@Param("accountId") Integer accountId); } diff --git a/nakadai/src/main/java/com/huoran/nakadai/mapper/xml/EnterpriseCertificationMapper.xml b/nakadai/src/main/java/com/huoran/nakadai/mapper/xml/EnterpriseCertificationMapper.xml index c217aed..84000cd 100644 --- a/nakadai/src/main/java/com/huoran/nakadai/mapper/xml/EnterpriseCertificationMapper.xml +++ b/nakadai/src/main/java/com/huoran/nakadai/mapper/xml/EnterpriseCertificationMapper.xml @@ -46,7 +46,9 @@ cla.id AS teamId, logo_url, brief_introduction, - cla.create_time as organizationCreationTime + cla.create_time AS organizationCreationTime, + cc.classification_id as supplierClassificationId, + sc.classification_name as supplierClassificationName FROM hr_enterprise_certification c INNER JOIN hr_user_account a ON a.id = c.account_id @@ -55,6 +57,8 @@ LEFT JOIN k_platform_team_account ta ON ta.account_id = a.id LEFT JOIN k_platform_team t ON ta.manage_id = t.manage_id LEFT JOIN k_platform_team_classification cla ON cla.id = t.classification_id + LEFT JOIN supplier_classification_config cc ON cc.account_id = c.account_id + LEFT JOIN supplier_classification sc ON sc.id = cc.classification_id AND is_team = 1 AND cla.is_del = 0 WHERE @@ -62,7 +66,11 @@ AND u.is_del = 0 ) t WHERE - t.platform_source = #{req.platformSource} + t.platform_source = #{req.platformSource} + + + and t.supplierClassificationId =#{req.supplierClassificationId} + diff --git a/nakadai/src/main/java/com/huoran/nakadai/mapper/xml/PlatformTeamMapper.xml b/nakadai/src/main/java/com/huoran/nakadai/mapper/xml/PlatformTeamMapper.xml index 57e926f..679e153 100644 --- a/nakadai/src/main/java/com/huoran/nakadai/mapper/xml/PlatformTeamMapper.xml +++ b/nakadai/src/main/java/com/huoran/nakadai/mapper/xml/PlatformTeamMapper.xml @@ -2,4 +2,32 @@ + + diff --git a/nakadai/src/main/java/com/huoran/nakadai/mapper/xml/SupplierClassificationConfigMapper.xml b/nakadai/src/main/java/com/huoran/nakadai/mapper/xml/SupplierClassificationConfigMapper.xml index 360d81a..889fa73 100644 --- a/nakadai/src/main/java/com/huoran/nakadai/mapper/xml/SupplierClassificationConfigMapper.xml +++ b/nakadai/src/main/java/com/huoran/nakadai/mapper/xml/SupplierClassificationConfigMapper.xml @@ -2,4 +2,7 @@ + + DELETE from supplier_classification_config WHERE account_id = #{accountId} + diff --git a/nakadai/src/main/java/com/huoran/nakadai/service/PlatformTeamService.java b/nakadai/src/main/java/com/huoran/nakadai/service/PlatformTeamService.java index 239d37b..1ad009a 100644 --- a/nakadai/src/main/java/com/huoran/nakadai/service/PlatformTeamService.java +++ b/nakadai/src/main/java/com/huoran/nakadai/service/PlatformTeamService.java @@ -1,7 +1,10 @@ package com.huoran.nakadai.service; -import com.huoran.nakadai.entity.PlatformTeam; import com.baomidou.mybatisplus.extension.service.IService; +import com.huoran.nakadai.entity.PlatformTeam; +import com.huoran.nakadai.entity.vo.TeamClassificationVO; + +import java.util.List; /** *

@@ -12,5 +15,8 @@ import com.baomidou.mybatisplus.extension.service.IService; * @since 2023-12-12 */ public interface PlatformTeamService extends IService { + List getTeamClassificationVOByTeamId(Integer teamId); + //根据团队id获取团队负责人账号id + Integer getAccountIdByTeamId(Integer teamId); } diff --git a/nakadai/src/main/java/com/huoran/nakadai/service/SupplierClassificationConfigService.java b/nakadai/src/main/java/com/huoran/nakadai/service/SupplierClassificationConfigService.java index 0ad5603..5e3e895 100644 --- a/nakadai/src/main/java/com/huoran/nakadai/service/SupplierClassificationConfigService.java +++ b/nakadai/src/main/java/com/huoran/nakadai/service/SupplierClassificationConfigService.java @@ -12,5 +12,6 @@ import com.baomidou.mybatisplus.extension.service.IService; * @since 2023-12-27 */ public interface SupplierClassificationConfigService extends IService { - + //删除用户的供应商配置信息 + boolean deleteByAccountId(Integer accountId); } diff --git a/nakadai/src/main/java/com/huoran/nakadai/service/impl/PlatformTeamServiceImpl.java b/nakadai/src/main/java/com/huoran/nakadai/service/impl/PlatformTeamServiceImpl.java index f61de8a..a010415 100644 --- a/nakadai/src/main/java/com/huoran/nakadai/service/impl/PlatformTeamServiceImpl.java +++ b/nakadai/src/main/java/com/huoran/nakadai/service/impl/PlatformTeamServiceImpl.java @@ -1,11 +1,14 @@ package com.huoran.nakadai.service.impl; import com.huoran.nakadai.entity.PlatformTeam; +import com.huoran.nakadai.entity.vo.TeamClassificationVO; import com.huoran.nakadai.mapper.PlatformTeamMapper; import com.huoran.nakadai.service.PlatformTeamService; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import org.springframework.stereotype.Service; +import java.util.List; + /** *

* 幼教产业团队账号与分类中间表 服务实现类 @@ -17,4 +20,13 @@ import org.springframework.stereotype.Service; @Service public class PlatformTeamServiceImpl extends ServiceImpl implements PlatformTeamService { + @Override + public List getTeamClassificationVOByTeamId(Integer teamId) { + return baseMapper.getTeamClassificationVOByTeamId(teamId); + } + + @Override + public Integer getAccountIdByTeamId(Integer teamId) { + return baseMapper.getAccountIdByTeamId(teamId); + } } diff --git a/nakadai/src/main/java/com/huoran/nakadai/service/impl/SupplierClassificationConfigServiceImpl.java b/nakadai/src/main/java/com/huoran/nakadai/service/impl/SupplierClassificationConfigServiceImpl.java index 7ac2e95..e8bfed1 100644 --- a/nakadai/src/main/java/com/huoran/nakadai/service/impl/SupplierClassificationConfigServiceImpl.java +++ b/nakadai/src/main/java/com/huoran/nakadai/service/impl/SupplierClassificationConfigServiceImpl.java @@ -17,4 +17,8 @@ import org.springframework.stereotype.Service; @Service public class SupplierClassificationConfigServiceImpl extends ServiceImpl implements SupplierClassificationConfigService { + @Override + public boolean deleteByAccountId(Integer accountId) { + return baseMapper.deleteByAccountId(accountId); + } } From 1e6be8154ddf7a73743f4a679c79ea926150c301 Mon Sep 17 00:00:00 2001 From: "rong.liu" Date: Thu, 28 Dec 2023 20:38:18 +0800 Subject: [PATCH 5/5] =?UTF-8?q?=E5=AE=8C=E5=96=84?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../com/huoran/competition/mapper/xml/CompetitionMapper.xml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/competition/src/main/java/com/huoran/competition/mapper/xml/CompetitionMapper.xml b/competition/src/main/java/com/huoran/competition/mapper/xml/CompetitionMapper.xml index 36406c7..93e9248 100644 --- a/competition/src/main/java/com/huoran/competition/mapper/xml/CompetitionMapper.xml +++ b/competition/src/main/java/com/huoran/competition/mapper/xml/CompetitionMapper.xml @@ -698,7 +698,7 @@ ( CASE create_source WHEN 0 THEN '平台创建' WHEN 1 THEN '组织创建' ELSE '无' END ) AS createSource, IF ( - ( SELECT r.id FROM c_competition_registration r WHERE r.competition_id = c.id AND r.account_id = 4940 ) IS NULL, + ( SELECT r.id FROM c_competition_registration r WHERE r.competition_id = c.id AND r.account_id = #{req.accountId} ) IS NULL, 1, 0 ) AS whetherToSignUp,