|
|
@@ -7,6 +7,7 @@ import com.github.yulichang.wrapper.MPJLambdaWrapper;
|
|
|
import com.xjrsoft.common.model.result.RT;
|
|
|
import com.xjrsoft.common.utils.VoToColumnUtil;
|
|
|
import com.xjrsoft.module.base.entity.BaseClass;
|
|
|
+import com.xjrsoft.module.base.entity.BaseCourseSubject;
|
|
|
import com.xjrsoft.module.base.mapper.BaseClassMapper;
|
|
|
import com.xjrsoft.module.base.service.IBaseClassService;
|
|
|
import com.xjrsoft.module.oa.entity.NewsRelation;
|
|
|
@@ -15,16 +16,15 @@ import com.xjrsoft.module.system.entity.Databaselink;
|
|
|
import com.xjrsoft.module.system.entity.DictionaryDetail;
|
|
|
import com.xjrsoft.module.system.entity.File;
|
|
|
import com.xjrsoft.module.textbook.dto.AddTextbookWarehouseRecordDto;
|
|
|
+import com.xjrsoft.module.textbook.dto.TextbookSubscriptionExportQueryListDto;
|
|
|
import com.xjrsoft.module.textbook.dto.UpdateWfTextbookSubscriptionDto;
|
|
|
-import com.xjrsoft.module.textbook.entity.Textbook;
|
|
|
-import com.xjrsoft.module.textbook.entity.TextbookSubscriptionRecord;
|
|
|
-import com.xjrsoft.module.textbook.entity.WfTextbookSubscriptionItem;
|
|
|
+import com.xjrsoft.module.textbook.entity.*;
|
|
|
import com.xjrsoft.module.textbook.mapper.TextbookSubscriptionRecordMapper;
|
|
|
import com.xjrsoft.module.textbook.mapper.WfTextbookSubscriptionItemMapper;
|
|
|
-import com.xjrsoft.module.textbook.entity.WfTextbookSubscription;
|
|
|
import com.xjrsoft.module.textbook.mapper.WfTextbookSubscriptionMapper;
|
|
|
import com.xjrsoft.module.textbook.service.ITextbookService;
|
|
|
import com.xjrsoft.module.textbook.service.IWfTextbookSubscriptionService;
|
|
|
+import com.xjrsoft.module.textbook.vo.TextbookSubscriptionExportQueryListVo;
|
|
|
import com.xjrsoft.module.textbook.vo.WfTextbookSubscriptionItemVo;
|
|
|
import com.xjrsoft.module.textbook.vo.WfTextbookSubscriptionPageVo;
|
|
|
import com.xjrsoft.module.textbook.vo.WfTextbookSubscriptionVo;
|
|
|
@@ -170,20 +170,23 @@ public class WfTextbookSubscriptionServiceImpl extends MPJBaseServiceImpl<WfText
|
|
|
|
|
|
MPJLambdaWrapper<WfTextbookSubscriptionItem> mpjLambdaWrapper = new MPJLambdaWrapper<>();
|
|
|
mpjLambdaWrapper
|
|
|
+ .selectAs(BaseCourseSubject::getName, WfTextbookSubscriptionItemVo::getCourseSubjectIdCn)
|
|
|
.select(WfTextbookSubscriptionItem.class,x -> VoToColumnUtil.fieldsToColumns(WfTextbookSubscriptionItemVo.class).contains(x.getProperty()))
|
|
|
- .select(Textbook.class,x -> VoToColumnUtil.fieldsToColumns(WfTextbookSubscriptionItemVo.class).contains(x.getProperty()))
|
|
|
+ .select(Textbook.class, x -> VoToColumnUtil.fieldsToColumns(WfTextbookSubscriptionItemVo.class).contains(x.getProperty()))
|
|
|
.leftJoin(Textbook.class, Textbook::getId, WfTextbookSubscriptionItem::getTextbookId)
|
|
|
.leftJoin(DictionaryDetail.class, DictionaryDetail::getCode, Textbook::getTextbookType,
|
|
|
ext -> ext.selectAs(DictionaryDetail::getName, WfTextbookSubscriptionItemVo::getTextbookTypeCn))
|
|
|
+ .leftJoin(BaseCourseSubject.class, BaseCourseSubject::getId, Textbook::getCourseSubjectId)
|
|
|
.eq(WfTextbookSubscriptionItem::getWfTextbookSubscriptionId, wfTextbookSubscription.getId())
|
|
|
;
|
|
|
List<WfTextbookSubscriptionItemVo> itemList = wfTextbookSubscriptionWfTextbookSubscriptionItemMapper.selectJoinList(WfTextbookSubscriptionItemVo.class, mpjLambdaWrapper);
|
|
|
|
|
|
//处理班级
|
|
|
+ String classIds = "";
|
|
|
List<String> classIdList = new ArrayList<>();
|
|
|
StringBuilder sb = new StringBuilder();
|
|
|
if(!itemList.isEmpty() && itemList.get(0).getClassIds() != null && !itemList.get(0).getClassIds().equals("")){
|
|
|
- String classIds = itemList.get(0).getClassIds();
|
|
|
+ classIds = itemList.get(0).getClassIds();
|
|
|
String[] classIdArr = classIds.split(",");
|
|
|
classIdList = Arrays.asList(classIdArr);
|
|
|
if(!classIdList.isEmpty()){
|
|
|
@@ -218,6 +221,7 @@ public class WfTextbookSubscriptionServiceImpl extends MPJBaseServiceImpl<WfText
|
|
|
}
|
|
|
|
|
|
wfTextbookSubscriptionVo.setClassIdsCn(sb.toString());
|
|
|
+ wfTextbookSubscriptionVo.setClassIds(classIds);
|
|
|
wfTextbookSubscriptionVo.setStudentSubscriptionNumberSum(stuSum);
|
|
|
wfTextbookSubscriptionVo.setTeacherSubscriptionNumberSum(teaSum);
|
|
|
wfTextbookSubscriptionVo.setSum(stuSum + teaSum);
|
|
|
@@ -225,4 +229,55 @@ public class WfTextbookSubscriptionServiceImpl extends MPJBaseServiceImpl<WfText
|
|
|
|
|
|
return wfTextbookSubscriptionVo;
|
|
|
}
|
|
|
+
|
|
|
+ @Override
|
|
|
+ public List<TextbookSubscriptionExportQueryListVo> textbookSubscriptionExportQuery(TextbookSubscriptionExportQueryListDto dto) {
|
|
|
+ WfTextbookSubscription wfTextbookSubscription = this.getById(dto.getWfTextbookSubscriptionId());
|
|
|
+ if(wfTextbookSubscription == null){
|
|
|
+ return null;
|
|
|
+ }
|
|
|
+
|
|
|
+ MPJLambdaWrapper<WfTextbookSubscriptionItem> mpjLambdaWrapper = new MPJLambdaWrapper<>();
|
|
|
+ mpjLambdaWrapper
|
|
|
+ .selectAs(BaseCourseSubject::getName, TextbookSubscriptionExportQueryListVo::getCourseName)
|
|
|
+ .select(WfTextbookSubscriptionItem.class,x -> VoToColumnUtil.fieldsToColumns(TextbookSubscriptionExportQueryListVo.class).contains(x.getProperty()))
|
|
|
+ .select(Textbook.class, x -> VoToColumnUtil.fieldsToColumns(TextbookSubscriptionExportQueryListVo.class).contains(x.getProperty()))
|
|
|
+ .leftJoin(Textbook.class, Textbook::getId, WfTextbookSubscriptionItem::getTextbookId)
|
|
|
+ .leftJoin(DictionaryDetail.class, DictionaryDetail::getCode, Textbook::getTextbookType,
|
|
|
+ ext -> ext.selectAs(DictionaryDetail::getName, TextbookSubscriptionExportQueryListVo::getTextbookTypeCn))
|
|
|
+ .leftJoin(BaseCourseSubject.class, BaseCourseSubject::getId, Textbook::getCourseSubjectId)
|
|
|
+ .eq(WfTextbookSubscriptionItem::getWfTextbookSubscriptionId, wfTextbookSubscription.getId())
|
|
|
+ ;
|
|
|
+ List<TextbookSubscriptionExportQueryListVo> itemList = wfTextbookSubscriptionWfTextbookSubscriptionItemMapper.selectJoinList(TextbookSubscriptionExportQueryListVo.class, mpjLambdaWrapper);
|
|
|
+
|
|
|
+ //处理班级
|
|
|
+ String classIds = "";
|
|
|
+ List<String> classIdList = new ArrayList<>();
|
|
|
+ StringBuilder sb = new StringBuilder();
|
|
|
+ if(!itemList.isEmpty() && itemList.get(0).getClassIds() != null && !itemList.get(0).getClassIds().equals("")){
|
|
|
+ classIds = itemList.get(0).getClassIds();
|
|
|
+ String[] classIdArr = classIds.split(",");
|
|
|
+ classIdList = Arrays.asList(classIdArr);
|
|
|
+ /*if(!classIdList.isEmpty()){
|
|
|
+ List<BaseClass> baseClassList = baseClassMapper.selectList(Wrappers.<BaseClass>query().lambda().in(BaseClass::getId, classIdList));
|
|
|
+ Map<Long, BaseClass> baseClassMap = baseClassList.stream()
|
|
|
+ .collect(Collectors.toMap(BaseClass::getId, baseClass -> baseClass));
|
|
|
+
|
|
|
+ for (String classId : classIdList){
|
|
|
+ BaseClass baseClass = baseClassMap.get(Long.parseLong(classId));
|
|
|
+ if(baseClass != null){
|
|
|
+ sb.append(baseClass.getName());
|
|
|
+ sb.append(",");
|
|
|
+ }
|
|
|
+ }
|
|
|
+ sb.deleteCharAt(sb.length() - 1);
|
|
|
+ }*/
|
|
|
+ }
|
|
|
+
|
|
|
+ for (TextbookSubscriptionExportQueryListVo w : itemList){
|
|
|
+ w.setClassNum(classIdList.size());
|
|
|
+ }
|
|
|
+
|
|
|
+ return itemList;
|
|
|
+ }
|
|
|
}
|