|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import javax.annotation.Resource; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import com.panzhihua.common.utlis.Snowflake; | 
|---|
|  |  |  | import org.springframework.beans.BeanUtils; | 
|---|
|  |  |  | import org.springframework.stereotype.Service; | 
|---|
|  |  |  | import org.springframework.transaction.annotation.Transactional; | 
|---|
|  |  |  | 
|---|
|  |  |  | import com.panzhihua.service_community.model.dos.ConvenientViewStatisticsDO; | 
|---|
|  |  |  | import com.panzhihua.service_community.service.ConvenientMerchantService; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import lombok.extern.slf4j.Slf4j; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * @title: ConvenientMerchantServiceImpl | 
|---|
|  |  |  | * @projectName: 成都呐喊信息技术有限公司-智慧社区项目 | 
|---|
|  |  |  | 
|---|
|  |  |  | * @date: 2021/09/16 16:14 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Service | 
|---|
|  |  |  | @Slf4j | 
|---|
|  |  |  | public class ConvenientMerchantServiceImpl extends ServiceImpl<ConvenientMerchantDAO, ConvenientMerchantDO> implements ConvenientMerchantService { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Resource | 
|---|
|  |  |  | 
|---|
|  |  |  | @Resource | 
|---|
|  |  |  | private ConvenientViewStatisticsDAO convenientViewStatisticsDAO; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private static final String DQ="510402"; | 
|---|
|  |  |  | private static final String RHQ="510411"; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | @Transactional(rollbackFor = Exception.class) | 
|---|
|  |  |  | public R addMerchant(ConvenientMerchantDTO convenientMerchantDTO) { | 
|---|
|  |  |  | ComActDO comActDO = comActDAO.selectById(convenientMerchantDTO.getCommunityId()); | 
|---|
|  |  |  | ConvenientMerchantDO convenientMerchantDO = new ConvenientMerchantDO(); | 
|---|
|  |  |  | BeanUtils.copyProperties(convenientMerchantDTO, convenientMerchantDO); | 
|---|
|  |  |  | if(convenientMerchantDTO.getCommunityId()==0){ | 
|---|
|  |  |  | if(DQ.equals(convenientMerchantDTO.getAreaCode())){ | 
|---|
|  |  |  | convenientMerchantDO.setCommunityName("东区社区"); | 
|---|
|  |  |  | }else if(RHQ.equals(convenientMerchantDTO.getAreaCode())){ | 
|---|
|  |  |  | convenientMerchantDO.setCommunityName("仁和区社区"); | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | convenientMerchantDO.setCommunityName("西区社区"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else { | 
|---|
|  |  |  | ComActDO comActDO = comActDAO.selectById(convenientMerchantDTO.getCommunityId()); | 
|---|
|  |  |  | convenientMerchantDO.setCommunityName(comActDO.getName()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | convenientMerchantDO.setUserId(0L); | 
|---|
|  |  |  | convenientMerchantDO.setCommunityName(comActDO.getName()); | 
|---|
|  |  |  | convenientMerchantDO.setCreatedAt(new Date()); | 
|---|
|  |  |  | int insertResult = this.baseMapper.insert(convenientMerchantDO); | 
|---|
|  |  |  | if (insertResult > 0) { | 
|---|
|  |  |  | 
|---|
|  |  |  | List<Long> serviceIds = convenientMerchantDTO.getServiceIds(); | 
|---|
|  |  |  | serviceIds.forEach(serviceId -> { | 
|---|
|  |  |  | ConvenientServiceCategoryDO convenientServiceCategoryDO = convenientServiceCategoryDAO.selectById(serviceId); | 
|---|
|  |  |  | convenientServiceCategoryDAO.createMerchantServiceRelation(merchantId, serviceId, | 
|---|
|  |  |  | convenientServiceCategoryDAO.createMerchantServiceRelation(Snowflake.getId(),merchantId, serviceId, | 
|---|
|  |  |  | convenientServiceCategoryDO.getName(), convenientMerchantDTO.getCreatedBy()); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | //添加user | 
|---|
|  |  |  | R addUserResult = userService.addConvenientMerchantUser(convenientMerchantDTO); | 
|---|
|  |  |  | if (R.isOk(addUserResult)) { | 
|---|
|  |  |  | Long merchantUserId = ((Integer) addUserResult.getData()).longValue(); | 
|---|
|  |  |  | Long merchantUserId =Long.parseLong(addUserResult.getData().toString()); | 
|---|
|  |  |  | convenientMerchantDO.setUserId(merchantUserId); | 
|---|
|  |  |  | this.baseMapper.updateById(convenientMerchantDO); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | 
|---|
|  |  |  | Long communityId = convenientMerchantDTO.getCommunityId(); | 
|---|
|  |  |  | if (nonNull(communityId)) { | 
|---|
|  |  |  | ComActDO comActDO = comActDAO.selectById(communityId); | 
|---|
|  |  |  | convenientMerchantDO.setCommunityName(comActDO.getName()); | 
|---|
|  |  |  | if(comActDO!=null){ | 
|---|
|  |  |  | convenientMerchantDO.setCommunityName(comActDO.getName()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else { | 
|---|
|  |  |  | convenientMerchantDO.setCommunityName("西区社区"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | String account = convenientMerchantDTO.getAccount(); | 
|---|
|  |  |  | if (isNotBlank(account)) { | 
|---|
|  |  |  | 
|---|
|  |  |  | convenientServiceCategoryDAO.deleteMerchantServiceRelation(merchantId); | 
|---|
|  |  |  | serviceIds.forEach(serviceId -> { | 
|---|
|  |  |  | ConvenientServiceCategoryDO convenientServiceCategoryDO = convenientServiceCategoryDAO.selectById(serviceId); | 
|---|
|  |  |  | convenientServiceCategoryDAO.createMerchantServiceRelation(merchantId, serviceId, | 
|---|
|  |  |  | convenientServiceCategoryDAO.createMerchantServiceRelation(Snowflake.getId(),merchantId, serviceId, | 
|---|
|  |  |  | convenientServiceCategoryDO.getName(), convenientMerchantDTO.getCreatedBy()); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | SimpleDateFormat dayFormat = new SimpleDateFormat("yyyy-MM-dd"); | 
|---|
|  |  |  | String moth = mothFormat.format(nowDate); | 
|---|
|  |  |  | String day = dayFormat.format(nowDate); | 
|---|
|  |  |  | int consultationCount = convenientConsultationStatisticsDAO.selectCount(new QueryWrapper<ConvenientConsultationStatisticsDO>() | 
|---|
|  |  |  | .lambda().eq(ConvenientConsultationStatisticsDO::getMerchantId, merchantId)); | 
|---|
|  |  |  | int consultationCount = convenientConsultationStatisticsDAO.selectTotalConsultationVolume(merchantId); | 
|---|
|  |  |  | int monthConsultationVolume = convenientConsultationStatisticsDAO.selectMonthConsultationVolume(merchantId, moth); | 
|---|
|  |  |  | int dayConsultationVolume = convenientConsultationStatisticsDAO.selectDayConsultationVolume(merchantId, day); | 
|---|
|  |  |  | Integer viewCount = convenientViewStatisticsDAO.selectCount(new QueryWrapper<ConvenientViewStatisticsDO>() | 
|---|
|  |  |  | .lambda().eq(ConvenientViewStatisticsDO::getMerchantId, merchantId)); | 
|---|
|  |  |  | Integer viewCount = convenientViewStatisticsDAO.selectTotalViewNum(merchantId); | 
|---|
|  |  |  | int monthViewNum = convenientViewStatisticsDAO.selectMonthViewNum(merchantId, moth); | 
|---|
|  |  |  | int dayViewNum = convenientViewStatisticsDAO.selectDayViewNum(merchantId, day); | 
|---|
|  |  |  | convenientMerchantVO.setConsultationVolume(consultationCount); | 
|---|
|  |  |  | 
|---|
|  |  |  | Page page = new Page<>(); | 
|---|
|  |  |  | page.setSize(pagePopularMerchantDTO.getPageSize()); | 
|---|
|  |  |  | page.setCurrent(pagePopularMerchantDTO.getPageNum()); | 
|---|
|  |  |  | IPage<ConvenientMerchantVO> merchantVOList = this.baseMapper.getPopularMerchants(page, pagePopularMerchantDTO.getCommunityId(), currentMon); | 
|---|
|  |  |  | IPage<ConvenientMerchantVO> merchantVOList = this.baseMapper.getPopularMerchants(page, pagePopularMerchantDTO.getCommunityId(), currentMon,pagePopularMerchantDTO.getAreaCode()); | 
|---|
|  |  |  | if(pagePopularMerchantDTO.getPageNum().equals(1L)){ | 
|---|
|  |  |  | //第一页默认把犇师傅维修中心加载到第一个 | 
|---|
|  |  |  | List<ConvenientMerchantVO> merchantList = this.baseMapper.selectMerchantByName(pagePopularMerchantDTO.getCommunityId(), currentMon); | 
|---|
|  |  |  | if(merchantList != null && merchantList.size() > 0){ | 
|---|
|  |  |  | merchantList.addAll(merchantVOList.getRecords()); | 
|---|
|  |  |  | merchantVOList.setRecords(merchantList); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return R.ok(merchantVOList); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | this.baseMapper.batchUpdateMerchantViewNum(viewVOList); | 
|---|
|  |  |  | return R.ok(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * check商家/店铺是否有效 | 
|---|
|  |  |  | * @param userId | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public Boolean checkStoreIsValid(Long userId) { | 
|---|
|  |  |  | R<LoginUserInfoVO> loginUserInfo = userService.getUserInfoByUserId(userId.toString()); | 
|---|
|  |  |  | LoginUserInfoVO loginUserInfoVO = | 
|---|
|  |  |  | JSONObject.parseObject(JSONObject.toJSONString(loginUserInfo.getData()), LoginUserInfoVO.class); | 
|---|
|  |  |  | if (isNull(loginUserInfoVO) || !loginUserInfoVO.getType().equals(10) || loginUserInfoVO.getStatus() != 1) { | 
|---|
|  |  |  | return false; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return true; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|