BudgetPostNumController.java 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516
  1. package cn.com.lzt.budget.postnum.controller;
  2. import cn.com.lzt.budget.costhrscheme.entity.BudgetCostHrSchemeDetailEntity;
  3. import cn.com.lzt.budget.costhrscheme.entity.BudgetCostHrSchemeEntity;
  4. import cn.com.lzt.budget.costpostmaterialscheme.entity.BudgetCostPostMaterialSchemeEntity;
  5. import cn.com.lzt.budget.post.entity.BudgetPostEntity;
  6. import cn.com.lzt.budget.postnum.entity.BudgetPostNumDetailEntity;
  7. import cn.com.lzt.budget.postnum.entity.BudgetPostNumEntity;
  8. import cn.com.lzt.budget.postnum.service.BudgetPostNumServiceI;
  9. import java.math.BigDecimal;
  10. import java.util.ArrayList;
  11. import java.util.List;
  12. import java.text.SimpleDateFormat;
  13. import javax.servlet.http.HttpServletRequest;
  14. import javax.servlet.http.HttpServletResponse;
  15. import org.apache.commons.collections.map.HashedMap;
  16. import org.apache.commons.lang.StringUtils;
  17. import org.apache.log4j.Logger;
  18. import org.springframework.beans.factory.annotation.Autowired;
  19. import org.springframework.stereotype.Controller;
  20. import org.springframework.ui.ModelMap;
  21. import org.springframework.web.bind.annotation.*;
  22. import org.springframework.web.servlet.ModelAndView;
  23. import org.jeecgframework.core.common.controller.BaseController;
  24. import org.jeecgframework.core.common.exception.BusinessException;
  25. import org.jeecgframework.core.common.hibernate.qbc.CriteriaQuery;
  26. import org.jeecgframework.core.common.model.common.TreeChildCount;
  27. import org.jeecgframework.core.common.model.json.AjaxJson;
  28. import org.jeecgframework.core.common.model.json.DataGrid;
  29. import org.jeecgframework.core.constant.Globals;
  30. import org.jeecgframework.core.util.StringUtil;
  31. import org.jeecgframework.tag.core.easyui.TagUtil;
  32. import org.jeecgframework.web.system.pojo.base.TSDepart;
  33. import org.jeecgframework.web.system.service.SystemService;
  34. import org.jeecgframework.core.util.MyBeanUtils;
  35. import java.io.OutputStream;
  36. import org.jeecgframework.core.util.BrowserUtils;
  37. import org.jeecgframework.poi.excel.ExcelExportUtil;
  38. import org.jeecgframework.poi.excel.ExcelImportUtil;
  39. import org.jeecgframework.poi.excel.entity.ExportParams;
  40. import org.jeecgframework.poi.excel.entity.ImportParams;
  41. import org.jeecgframework.poi.excel.entity.TemplateExportParams;
  42. import org.jeecgframework.poi.excel.entity.vo.NormalExcelConstants;
  43. import org.jeecgframework.poi.excel.entity.vo.TemplateExcelConstants;
  44. import org.apache.poi.hssf.usermodel.HSSFWorkbook;
  45. import org.jeecgframework.core.util.ResourceUtil;
  46. import java.io.IOException;
  47. import org.springframework.web.multipart.MultipartFile;
  48. import org.springframework.web.multipart.MultipartHttpServletRequest;
  49. import java.util.Map;
  50. import java.util.HashMap;
  51. import org.jeecgframework.core.util.ExceptionUtil;
  52. import org.springframework.http.ResponseEntity;
  53. import org.springframework.stereotype.Controller;
  54. import org.springframework.web.bind.annotation.RequestMapping;
  55. import org.springframework.web.bind.annotation.RequestMethod;
  56. import org.springframework.web.bind.annotation.ResponseBody;
  57. import org.springframework.http.HttpHeaders;
  58. import org.springframework.http.HttpStatus;
  59. import org.jeecgframework.core.beanvalidator.BeanValidators;
  60. import java.util.Set;
  61. import javax.validation.ConstraintViolation;
  62. import javax.validation.Validator;
  63. import java.net.URI;
  64. import org.springframework.http.MediaType;
  65. import org.springframework.web.util.UriComponentsBuilder;
  66. /**
  67. * @Title: Controller
  68. * @Description: 预算岗位人数表
  69. * @author onlineGenerator
  70. * @date 2020-10-19 09:23:29
  71. * @version V1.0
  72. *
  73. */
  74. @Controller
  75. @RequestMapping("/budgetPostNumController")
  76. public class BudgetPostNumController extends BaseController {
  77. /**
  78. * Logger for this class
  79. */
  80. private static final Logger logger = Logger.getLogger(BudgetPostNumController.class);
  81. @Autowired
  82. private BudgetPostNumServiceI budgetPostNumService;
  83. @Autowired
  84. private SystemService systemService;
  85. @Autowired
  86. private Validator validator;
  87. /**
  88. * 预算岗位人数表列表 页面跳转
  89. *
  90. * @return
  91. */
  92. @RequestMapping(params = "list")
  93. public ModelAndView list(HttpServletRequest request) {
  94. return new ModelAndView("cn/com/lzt/budget/postnum/budgetPostNumList");
  95. }
  96. /**
  97. * easyui AJAX请求数据
  98. *
  99. * @param request
  100. * @param response
  101. * @param dataGrid
  102. */
  103. @RequestMapping(params = "datagrid")
  104. public void datagrid(BudgetPostNumEntity budgetPostNum,HttpServletRequest request, HttpServletResponse response, DataGrid dataGrid) {
  105. CriteriaQuery cq = new CriteriaQuery(BudgetPostNumEntity.class, dataGrid);
  106. //查询条件组装器
  107. org.jeecgframework.core.extend.hqlsearch.HqlGenerateUtil.installHql(cq, budgetPostNum, request.getParameterMap());
  108. try{
  109. //自定义追加查询条件
  110. }catch (Exception e) {
  111. throw new BusinessException(e.getMessage());
  112. }
  113. cq.add();
  114. this.budgetPostNumService.getDataGridReturn(cq, true);
  115. TagUtil.datagrid(response, dataGrid);
  116. }
  117. /**
  118. * 删除预算岗位人数表
  119. *
  120. * @return
  121. */
  122. @RequestMapping(params = "doDel")
  123. @ResponseBody
  124. public AjaxJson doDel(BudgetPostNumEntity budgetPostNum, HttpServletRequest request) {
  125. String message = null;
  126. AjaxJson j = new AjaxJson();
  127. budgetPostNum = systemService.getEntity(BudgetPostNumEntity.class, budgetPostNum.getId());
  128. message = "预算岗位人数表删除成功";
  129. try{
  130. budgetPostNumService.delete(budgetPostNum);
  131. systemService.addLog(message, Globals.Log_Type_DEL, Globals.Log_Leavel_INFO);
  132. }catch(Exception e){
  133. e.printStackTrace();
  134. message = "预算岗位人数表删除失败";
  135. throw new BusinessException(e.getMessage());
  136. }
  137. j.setMsg(message);
  138. return j;
  139. }
  140. /**
  141. * 批量删除预算岗位人数表
  142. *
  143. * @return
  144. */
  145. @RequestMapping(params = "doBatchDel")
  146. @ResponseBody
  147. public AjaxJson doBatchDel(String ids,HttpServletRequest request){
  148. String message = null;
  149. AjaxJson j = new AjaxJson();
  150. message = "预算岗位人数表删除成功";
  151. try{
  152. for(String id:ids.split(",")){
  153. BudgetPostNumEntity budgetPostNum = systemService.getEntity(BudgetPostNumEntity.class,
  154. id
  155. );
  156. budgetPostNumService.delete(budgetPostNum);
  157. systemService.addLog(message, Globals.Log_Type_DEL, Globals.Log_Leavel_INFO);
  158. }
  159. }catch(Exception e){
  160. e.printStackTrace();
  161. message = "预算岗位人数表删除失败";
  162. throw new BusinessException(e.getMessage());
  163. }
  164. j.setMsg(message);
  165. return j;
  166. }
  167. /**
  168. * 添加预算岗位人数表
  169. *
  170. * @return
  171. */
  172. @RequestMapping(params = "doAdd")
  173. @ResponseBody
  174. public AjaxJson doAdd(BudgetPostNumEntity budgetPostNum, HttpServletRequest request) {
  175. String message = null;
  176. AjaxJson j = new AjaxJson();
  177. message = "预算岗位人数表添加成功";
  178. try{
  179. StringBuilder desn = new StringBuilder();
  180. Double totalNum = 0d;
  181. BigDecimal costPostMaterialSchemeAmount= new BigDecimal("0");
  182. if(StringUtils.isBlank(budgetPostNum.getId())){
  183. systemService.save(budgetPostNum);
  184. }
  185. List<BudgetPostNumDetailEntity> postNumDetailEntities = budgetPostNum.getPostNumDetailEntities();
  186. for(BudgetPostNumDetailEntity detailEntity:postNumDetailEntities){
  187. String sql = "delete from t_b_budget_post_num_detail where post_num_id=? and post_id=? ";
  188. systemService.executeSql(sql,budgetPostNum.getId(),detailEntity.getPostId());
  189. detailEntity.setPostNumId(budgetPostNum.getId());
  190. systemService.save(detailEntity);
  191. Double num = detailEntity.getNum();
  192. if(num==null) {
  193. num=0d;
  194. detailEntity.setNum(0d);
  195. }
  196. if(num>0) {
  197. totalNum+=num;
  198. desn.append(detailEntity.getPostName()).append("(").append(num).append("),");
  199. String costPostMaterialSchemeId = detailEntity.getCostPostMaterialSchemeId();
  200. if(StringUtils.isNotBlank(costPostMaterialSchemeId)){
  201. BudgetCostPostMaterialSchemeEntity costPostMaterialScheme = systemService.getEntity(BudgetCostPostMaterialSchemeEntity.class, costPostMaterialSchemeId);
  202. costPostMaterialSchemeAmount=costPostMaterialSchemeAmount.add(costPostMaterialScheme.getTotalAmount().multiply(new BigDecimal(num)));
  203. }
  204. }
  205. systemService.save(detailEntity);
  206. }
  207. if(desn.length()>0) {
  208. budgetPostNum.setDescn(desn.substring(0, desn.length() - 1));
  209. }else {
  210. budgetPostNum.setDescn("");
  211. }
  212. budgetPostNum.setTotalNum(totalNum);
  213. Map<String,Object> map = new HashMap<>();
  214. map.put("id", budgetPostNum.getId());
  215. map.put("descn",budgetPostNum.getDescn() );
  216. map.put("totalNum", totalNum);
  217. map.put("costPostMaterialSchemeAmount",costPostMaterialSchemeAmount );
  218. j.setAttributes(map);
  219. systemService.addLog(message, Globals.Log_Type_INSERT, Globals.Log_Leavel_INFO);
  220. }catch(Exception e){
  221. e.printStackTrace();
  222. message = "预算岗位人数表添加失败";
  223. throw new BusinessException(e.getMessage());
  224. }
  225. j.setMsg(message);
  226. return j;
  227. }
  228. /**
  229. * 更新预算岗位人数表
  230. *
  231. * @return
  232. */
  233. @RequestMapping(params = "doUpdate")
  234. @ResponseBody
  235. public AjaxJson doUpdate(BudgetPostNumEntity budgetPostNum, HttpServletRequest request) {
  236. String message = null;
  237. AjaxJson j = new AjaxJson();
  238. message = "预算岗位人数表更新成功";
  239. BudgetPostNumEntity t = budgetPostNumService.get(BudgetPostNumEntity.class, budgetPostNum.getId());
  240. try {
  241. MyBeanUtils.copyBeanNotNull2Bean(budgetPostNum, t);
  242. budgetPostNumService.saveOrUpdate(t);
  243. systemService.addLog(message, Globals.Log_Type_UPDATE, Globals.Log_Leavel_INFO);
  244. } catch (Exception e) {
  245. e.printStackTrace();
  246. message = "预算岗位人数表更新失败";
  247. throw new BusinessException(e.getMessage());
  248. }
  249. j.setMsg(message);
  250. return j;
  251. }
  252. /**
  253. * 预算岗位人数表新增页面跳转
  254. *
  255. * @return
  256. */
  257. @RequestMapping(params = "goAdd")
  258. public ModelAndView goAdd(BudgetPostNumEntity budgetPostNum, HttpServletRequest req) {
  259. // List<BudgetPostEntity> list = systemService.getList(BudgetPostEntity.class);
  260. String postType=req.getParameter("postType");
  261. String hql = "from BudgetPostEntity where deleteFlag=? and status=? and type=? ";
  262. List<BudgetPostEntity> budgetPostEntityList= systemService.findHql(hql,Globals.Delete_Normal.toString(),Globals.Enabled_Status.toString(),postType);
  263. req.setAttribute("budgetPostEntityList", budgetPostEntityList);
  264. if (StringUtil.isNotEmpty(budgetPostNum.getId())) {
  265. budgetPostNum = budgetPostNumService.getEntity(BudgetPostNumEntity.class, budgetPostNum.getId());
  266. req.setAttribute("entity", budgetPostNum);
  267. String detailHql = "from BudgetPostNumDetailEntity where postNumId=? ";
  268. List<BudgetPostNumDetailEntity> detailList = systemService.findHql(detailHql,budgetPostNum.getId());
  269. Map<String,BudgetPostNumDetailEntity> detailMap = new HashedMap();
  270. for(BudgetPostNumDetailEntity detailEntity:detailList){
  271. detailMap.put(detailEntity.getPostId(),detailEntity);
  272. }
  273. req.setAttribute("detailMap", detailMap);
  274. }
  275. return new ModelAndView("cn/com/lzt/budget/postnum/budgetPostNum-add");
  276. }
  277. /**
  278. * 预算岗位人数表编辑页面跳转
  279. *
  280. * @return
  281. */
  282. @RequestMapping(params = "goUpdate")
  283. public ModelAndView goUpdate(BudgetPostNumEntity budgetPostNum, HttpServletRequest req) {
  284. if (StringUtil.isNotEmpty(budgetPostNum.getId())) {
  285. budgetPostNum = budgetPostNumService.getEntity(BudgetPostNumEntity.class, budgetPostNum.getId());
  286. req.setAttribute("budgetPostNumPage", budgetPostNum);
  287. }
  288. return new ModelAndView("cn/com/lzt/budget/postnum/budgetPostNum-update");
  289. }
  290. /**
  291. * 导入功能跳转
  292. *
  293. * @return
  294. */
  295. @RequestMapping(params = "upload")
  296. public ModelAndView upload(HttpServletRequest req) {
  297. req.setAttribute("controller_name","budgetPostNumController");
  298. return new ModelAndView("common/upload/pub_excel_upload");
  299. }
  300. /**
  301. * 导出excel
  302. *
  303. * @param request
  304. * @param response
  305. */
  306. @RequestMapping(params = "exportXls")
  307. public String exportXls(BudgetPostNumEntity budgetPostNum,HttpServletRequest request,HttpServletResponse response
  308. , DataGrid dataGrid,ModelMap modelMap) {
  309. CriteriaQuery cq = new CriteriaQuery(BudgetPostNumEntity.class, dataGrid);
  310. org.jeecgframework.core.extend.hqlsearch.HqlGenerateUtil.installHql(cq, budgetPostNum, request.getParameterMap());
  311. List<BudgetPostNumEntity> budgetPostNums = this.budgetPostNumService.getListByCriteriaQuery(cq,false);
  312. modelMap.put(NormalExcelConstants.FILE_NAME,"预算岗位人数表");
  313. modelMap.put(NormalExcelConstants.CLASS,BudgetPostNumEntity.class);
  314. modelMap.put(NormalExcelConstants.PARAMS,new ExportParams("预算岗位人数表列表", "导出人:"+ResourceUtil.getSessionUser().getRealName(),
  315. "导出信息"));
  316. modelMap.put(NormalExcelConstants.DATA_LIST,budgetPostNums);
  317. return NormalExcelConstants.JEECG_EXCEL_VIEW;
  318. }
  319. /**
  320. * 导出excel 使模板
  321. *
  322. * @param request
  323. * @param response
  324. */
  325. @RequestMapping(params = "exportXlsByT")
  326. public String exportXlsByT(BudgetPostNumEntity budgetPostNum,HttpServletRequest request,HttpServletResponse response
  327. , DataGrid dataGrid,ModelMap modelMap) {
  328. modelMap.put(NormalExcelConstants.FILE_NAME,"预算岗位人数表");
  329. modelMap.put(NormalExcelConstants.CLASS,BudgetPostNumEntity.class);
  330. modelMap.put(NormalExcelConstants.PARAMS,new ExportParams("预算岗位人数表列表", "导出人:"+ResourceUtil.getSessionUser().getRealName(),
  331. "导出信息"));
  332. modelMap.put(NormalExcelConstants.DATA_LIST,new ArrayList());
  333. return NormalExcelConstants.JEECG_EXCEL_VIEW;
  334. }
  335. @SuppressWarnings("unchecked")
  336. @RequestMapping(params = "importExcel", method = RequestMethod.POST)
  337. @ResponseBody
  338. public AjaxJson importExcel(HttpServletRequest request, HttpServletResponse response) {
  339. AjaxJson j = new AjaxJson();
  340. MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request;
  341. Map<String, MultipartFile> fileMap = multipartRequest.getFileMap();
  342. for (Map.Entry<String, MultipartFile> entity : fileMap.entrySet()) {
  343. MultipartFile file = entity.getValue();// 获取上传文件对象
  344. ImportParams params = new ImportParams();
  345. params.setTitleRows(2);
  346. params.setHeadRows(1);
  347. params.setNeedSave(true);
  348. try {
  349. List<BudgetPostNumEntity> listBudgetPostNumEntitys = ExcelImportUtil.importExcel(file.getInputStream(),BudgetPostNumEntity.class,params);
  350. for (BudgetPostNumEntity budgetPostNum : listBudgetPostNumEntitys) {
  351. budgetPostNumService.save(budgetPostNum);
  352. }
  353. j.setMsg("文件导入成功!");
  354. } catch (Exception e) {
  355. j.setMsg("文件导入失败!");
  356. logger.error(ExceptionUtil.getExceptionMessage(e));
  357. }finally{
  358. try {
  359. file.getInputStream().close();
  360. } catch (IOException e) {
  361. e.printStackTrace();
  362. }
  363. }
  364. }
  365. return j;
  366. }
  367. @RequestMapping(method = RequestMethod.GET)
  368. @ResponseBody
  369. public List<BudgetPostNumEntity> list() {
  370. List<BudgetPostNumEntity> listBudgetPostNums=budgetPostNumService.getList(BudgetPostNumEntity.class);
  371. return listBudgetPostNums;
  372. }
  373. @RequestMapping(value = "/{id}", method = RequestMethod.GET)
  374. @ResponseBody
  375. public ResponseEntity<?> get(@PathVariable("id") String id) {
  376. BudgetPostNumEntity task = budgetPostNumService.get(BudgetPostNumEntity.class, id);
  377. if (task == null) {
  378. return new ResponseEntity(HttpStatus.NOT_FOUND);
  379. }
  380. return new ResponseEntity(task, HttpStatus.OK);
  381. }
  382. @RequestMapping(method = RequestMethod.POST, consumes = MediaType.APPLICATION_JSON_VALUE)
  383. @ResponseBody
  384. public ResponseEntity<?> create(@RequestBody BudgetPostNumEntity budgetPostNum, UriComponentsBuilder uriBuilder) {
  385. //调用JSR303 Bean Validator进行校验,如果出错返回含400错误码及json格式的错误信息.
  386. Set<ConstraintViolation<BudgetPostNumEntity>> failures = validator.validate(budgetPostNum);
  387. if (!failures.isEmpty()) {
  388. return new ResponseEntity(BeanValidators.extractPropertyAndMessage(failures), HttpStatus.BAD_REQUEST);
  389. }
  390. //保存
  391. try{
  392. budgetPostNumService.save(budgetPostNum);
  393. } catch (Exception e) {
  394. e.printStackTrace();
  395. return new ResponseEntity(HttpStatus.NO_CONTENT);
  396. }
  397. //按照Restful风格约定,创建指向新任务的url, 也可以直接返回id或对象.
  398. String id = budgetPostNum.getId();
  399. URI uri = uriBuilder.path("/rest/budgetPostNumController/" + id).build().toUri();
  400. HttpHeaders headers = new HttpHeaders();
  401. headers.setLocation(uri);
  402. return new ResponseEntity(headers, HttpStatus.CREATED);
  403. }
  404. @RequestMapping(value = "/{id}", method = RequestMethod.PUT, consumes = MediaType.APPLICATION_JSON_VALUE)
  405. public ResponseEntity<?> update(@RequestBody BudgetPostNumEntity budgetPostNum) {
  406. //调用JSR303 Bean Validator进行校验,如果出错返回含400错误码及json格式的错误信息.
  407. Set<ConstraintViolation<BudgetPostNumEntity>> failures = validator.validate(budgetPostNum);
  408. if (!failures.isEmpty()) {
  409. return new ResponseEntity(BeanValidators.extractPropertyAndMessage(failures), HttpStatus.BAD_REQUEST);
  410. }
  411. //保存
  412. try{
  413. budgetPostNumService.saveOrUpdate(budgetPostNum);
  414. } catch (Exception e) {
  415. e.printStackTrace();
  416. return new ResponseEntity(HttpStatus.NO_CONTENT);
  417. }
  418. //按Restful约定,返回204状态码, 无内容. 也可以返回200状态码.
  419. return new ResponseEntity(HttpStatus.NO_CONTENT);
  420. }
  421. @RequestMapping(value = "/{id}", method = RequestMethod.DELETE)
  422. @ResponseStatus(HttpStatus.NO_CONTENT)
  423. public void delete(@PathVariable("id") String id) {
  424. budgetPostNumService.deleteEntityById(BudgetPostNumEntity.class, id);
  425. }
  426. @RequestMapping(params = "estimate")
  427. @ResponseBody
  428. public AjaxJson estimate(BudgetPostNumEntity budgetPostNum, HttpServletRequest request) {
  429. String message = null;
  430. AjaxJson j = new AjaxJson();
  431. String schemeId = request.getParameter("schemeId");
  432. // BudgetCostHrSchemeEntity schemeEntity = systemService.getEntity(BudgetCostHrSchemeEntity.class,schemeId);
  433. List<BudgetPostNumDetailEntity> postNumDetailEntities = budgetPostNum.getPostNumDetailEntities();
  434. String hql = "from BudgetCostHrSchemeDetailEntity where schemeId=? and postId=? ";
  435. Double total = 0d;
  436. for(BudgetPostNumDetailEntity detailEntity:postNumDetailEntities){
  437. String postId = detailEntity.getPostId();
  438. Double num= detailEntity.getNum();
  439. if(num>0) {
  440. List<BudgetCostHrSchemeDetailEntity> list = systemService.findHql(hql, schemeId, postId);
  441. if (!list.isEmpty()) {
  442. BudgetPostEntity postEntity = systemService.get(BudgetPostEntity.class,postId);
  443. String postUserType = postEntity.getUserType();
  444. BudgetCostHrSchemeDetailEntity schemeDetailEntity = list.get(0);
  445. Double monthly = schemeDetailEntity.getMothly();
  446. Double cert = schemeDetailEntity.getCert();
  447. Double socialBase = schemeDetailEntity.getSocialBase();
  448. Double socialPer = schemeDetailEntity.getSocialPer()/100;
  449. Double pBase = schemeDetailEntity.getProvidentFundBase();
  450. Double pPer = schemeDetailEntity.getProvidentFundPer()/100;
  451. Double mealOvertime = schemeDetailEntity.getMealOvertime();
  452. Double jiaojinPer=schemeDetailEntity.getJiaojinPer()/100;
  453. Double niangongzi = monthly*12+cert*12;
  454. Double gaowen = 0d;
  455. if(StringUtils.equals(postUserType, "yxwg")){
  456. gaowen=1200d;
  457. }else {
  458. gaowen =800d;
  459. }
  460. Double canbu =mealOvertime*12;
  461. Double social=socialBase*socialPer*12*jiaojinPer;
  462. Double provident=pBase*pPer*12*jiaojinPer;
  463. Double chunjie=200d;
  464. Double nianyefan=150d;
  465. Double lvyou = 0d;
  466. if(StringUtils.equals(postUserType, "glry")){
  467. lvyou=2000d;
  468. }
  469. Double one = niangongzi+gaowen+canbu+social+provident+chunjie+nianyefan+lvyou;
  470. total =total +one*num;
  471. }
  472. }
  473. }
  474. j.setObj(new BigDecimal(total).setScale(2,BigDecimal.ROUND_HALF_UP).doubleValue());
  475. return j;
  476. }
  477. }