‘linchangsheng’ 1 day ago
parent
commit
17cf9ea9fd

+ 54 - 0
src/main/java/com/gree/mall/contest/controller/pc/tag/TagController.java

@@ -0,0 +1,54 @@
+package com.gree.mall.contest.controller.pc.tag;
+
+
+import com.baomidou.mybatisplus.core.metadata.IPage;
+import com.gree.mall.contest.helper.ResponseHelper;
+import com.gree.mall.contest.logic.tag.TagLogic;
+import com.gree.mall.contest.plus.entity.Tag;
+import io.swagger.v3.oas.annotations.Parameter;
+import io.swagger.v3.oas.annotations.media.Schema;
+
+import lombok.extern.slf4j.Slf4j;
+import me.chanjar.weixin.common.error.WxErrorException;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.web.bind.annotation.GetMapping;
+import org.springframework.web.bind.annotation.RequestMapping;
+import org.springframework.web.bind.annotation.RequestParam;
+import org.springframework.web.bind.annotation.RestController;
+
+import javax.servlet.http.HttpServletRequest;
+
+@Slf4j
+@RestController
+@io.swagger.v3.oas.annotations.tags.Tag(name =  "标签管理", description ="标签管理" )
+@RequestMapping(value = "pc/tag", produces = "application/json; charset=utf-8")
+public class TagController {
+
+    @Autowired
+    TagLogic tagLogic;
+
+
+    @GetMapping("/list")
+     @Schema(description ="微信标签列表")
+    public ResponseHelper<IPage<Tag>> list(
+            HttpServletRequest request,
+            @Parameter(description =  "页号",required = true) @RequestParam Integer pageNum,
+            @Parameter(description =  "页大小",required = true) @RequestParam Integer pageSize
+    ){
+        IPage<Tag> list = tagLogic.list(request, pageNum, pageSize);
+        return ResponseHelper.success(list);
+    }
+
+    @GetMapping("/sync")
+     @Schema(description ="同步最新的企业微信标签")
+    public ResponseHelper sync(HttpServletRequest request) throws WxErrorException {
+        tagLogic.sync(request);
+        return ResponseHelper.success();
+    }
+
+
+
+
+
+
+}

+ 63 - 0
src/main/java/com/gree/mall/contest/logic/tag/TagLogic.java

@@ -0,0 +1,63 @@
+package com.gree.mall.contest.logic.tag;
+
+import com.baomidou.mybatisplus.core.metadata.IPage;
+import com.baomidou.mybatisplus.core.toolkit.CollectionUtils;
+import com.baomidou.mybatisplus.core.toolkit.StringUtils;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+
+import com.gree.mall.contest.bean.admin.AdminUserCom;
+import com.gree.mall.contest.exception.RemoteServiceException;
+import com.gree.mall.contest.logic.common.CommonLogic;
+import com.gree.mall.contest.plus.entity.Tag;
+import com.gree.mall.contest.plus.service.TagGroupService;
+import com.gree.mall.contest.plus.service.TagService;
+import me.chanjar.weixin.common.error.WxErrorException;
+
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.stereotype.Service;
+
+import javax.servlet.http.HttpServletRequest;
+import java.util.ArrayList;
+import java.util.Date;
+import java.util.List;
+
+@Service
+public class TagLogic {
+
+    @Autowired
+    CommonLogic commonLogic;
+    @Autowired
+    TagService tagService;
+    @Autowired
+    private TagGroupService tagGroupService;
+
+    /**
+     * 标签列表
+     *
+     * @param pageNum
+     * @param pageSize
+     * @return
+     */
+    public IPage<Tag> list(HttpServletRequest request, Integer pageNum, Integer pageSize) {
+        AdminUserCom adminUser = commonLogic.getAdminUser(request);
+        List<String> companyWechatIds = adminUser.getCompanyWechatIds();
+
+        return tagService.lambdaQuery()
+                .in(CollectionUtils.isNotEmpty(companyWechatIds), Tag::getCompanyId, companyWechatIds)
+                .orderByDesc(Tag::getGroupId)
+                .page(new Page<>(pageNum, pageSize));
+    }
+
+    /**
+     * 同步企业标签
+     *
+     * @return
+     * @throws WxErrorException
+     */
+    public void sync(HttpServletRequest request) throws WxErrorException {
+
+    }
+
+
+
+}