zhongrj
2024-04-02 566e7986291e73051d30ee252b0ebf852b1577a7
src/main/java/org/springblade/modules/article/service/impl/ArticleServiceImpl.java
@@ -1,5 +1,6 @@
package org.springblade.modules.article.service.impl;
import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
@@ -9,9 +10,15 @@
import org.springblade.core.secure.utils.AuthUtil;
import org.springblade.core.tool.utils.SpringUtil;
import org.springblade.modules.article.entity.Article;
import org.springblade.modules.article.entity.ArticleIntegralEntity;
import org.springblade.modules.article.mapper.ArticleMapper;
import org.springblade.modules.article.service.ArticleService;
import org.springblade.modules.article.service.IArticleIntegralService;
import org.springblade.modules.article.vo.ArticleVO;
import org.springblade.modules.district.entity.DistrictEntity;
import org.springblade.modules.district.service.IDistrictService;
import org.springblade.modules.house.entity.HouseholdEntity;
import org.springblade.modules.house.service.IHouseholdService;
import org.springblade.modules.property.entity.PropertyCompanyDistrictEntity;
import org.springblade.modules.property.entity.PropertyCompanyEntity;
import org.springblade.modules.property.service.IPropertyCompanyDistrictService;
@@ -77,9 +84,11 @@
         article.setPropertyFlag(1);
      }
      if (userRole.contains("jdgly")) {
         IDistrictService districtService = SpringUtils.getBean(IDistrictService.class);
         List<String> regionChildCodesList = SysCache.getRegionChildCodesByDeptId(AuthUtil.getDeptId());
         if (regionChildCodesList.size() > 0) {
            article.setDistrictIdList(regionChildCodesList);
         List<DistrictEntity> list = districtService.list(Wrappers.<DistrictEntity>lambdaQuery().in(DistrictEntity::getCommunityCode, regionChildCodesList));
         if (list.size() > 0) {
            article.setDistrictIdList(list.stream().map(item -> item.getId()).collect(Collectors.toList()));
         }
      }
      return page.setRecords(baseMapper.selectArticlePage(page, article));
@@ -97,7 +106,16 @@
      // 查询用户小区的id
      String districId = baseMapper.getDistrictId(article.getHouseCode());
      article.setDistrictId(districId);
      article.setUserId(AuthUtil.getUserId());
      IHouseholdService householdService = SpringUtils.getBean(IHouseholdService.class);
      HouseholdEntity householdEntity = householdService.getOne(Wrappers.<HouseholdEntity>lambdaQuery()
         .eq(HouseholdEntity::getHouseCode, article.getHouseCode())
         .eq(HouseholdEntity::getAssociatedUserId,AuthUtil.getUserId())
         .eq(HouseholdEntity::getIsDeleted,0)
         .last("limit 1"));
      if (householdEntity != null) {
         article.setHouseholdId(householdEntity.getId());
      }
      List<ArticleVO> articleVOS = baseMapper.selectArticlePageByApp(page, article);
      return page.setRecords(articleVOS);
   }
@@ -180,4 +198,32 @@
      article.setDistrictIdList(stringList);
      return baseMapper.getArticleByDistrictId(article);
   }
   /**
    * 文章信息更新
    * @param objectUpdateWrapper
    * @param id
    * @param houseCode
    * @return
    */
   @Override
   public boolean updateArticle(UpdateWrapper<Article> objectUpdateWrapper, Long id, String houseCode) {
      boolean update = update(null, objectUpdateWrapper);
      if (update){
         // 查询对应的文章
         Article article = getById(id);
         // 只有反诈的有浏览积分
         if (article.getType()==6) {
            // 添加浏览记录信息
            ArticleIntegralEntity integralEntity = new ArticleIntegralEntity();
            integralEntity.setScore(article.getScore());
            integralEntity.setArticleId(id);
            integralEntity.setHouseCode(houseCode);
            // 插入记录
            update = SpringUtils.getBean(IArticleIntegralService.class).save(integralEntity);
         }
      }
      // 返回
      return update;
   }
}