UserActivitiDataController.java 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278
  1. package cn.com.lzt.useractiviti.data.controller;
  2. import cn.com.lzt.arrangeduty.dto.ProjectDepartDto;
  3. import cn.com.lzt.common.util.PdfUtil;
  4. import cn.com.lzt.common.util.UserUtil;
  5. import cn.com.lzt.cost.activiti.costrequest.entity.TBActivitiCostRequestEntity;
  6. import cn.com.lzt.cost.activiti.costrequest.service.TBActivitiCostRequestServiceI;
  7. import cn.com.lzt.cost.activiti.payinneruser.entity.TBActivitiCostPayInnerUserDetailEntity;
  8. import cn.com.lzt.cost.activiti.payinneruser.service.TBActivitiCostPayInnerUserServiceI;
  9. import cn.com.lzt.cost.activiti.tmpcompany.service.TBActivitiCostPayTmpCompanyServiceI;
  10. import cn.com.lzt.cost.actualstatis.service.CostYearActualStatisServiceI;
  11. import cn.com.lzt.duties.entity.DutiesEntity;
  12. import cn.com.lzt.ordersfixasset.service.OrdersFixAssetServiceI;
  13. import cn.com.lzt.projectpostdetail.entity.ProjectPostDetailEntity;
  14. import cn.com.lzt.useractiviti.data.dao.UseractivitiDataDao;
  15. import cn.com.lzt.useractiviti.data.dto.ActivitiUserInfoDto;
  16. import cn.com.lzt.useractiviti.data.service.UseractivitiDataServiceI;
  17. import cn.com.lzt.useractiviti.data.util.ActivitiTools;
  18. import cn.com.lzt.userwage.dto.UserWageDto;
  19. import com.lowagie.text.Element;
  20. import com.xcgl.projecttask.entity.ProjecttaskEntity;
  21. import org.apache.commons.lang.StringUtils;
  22. import org.jeecgframework.core.common.hibernate.qbc.CriteriaQuery;
  23. import org.jeecgframework.core.common.model.json.AjaxJson;
  24. import org.jeecgframework.core.common.model.json.DataGrid;
  25. import org.jeecgframework.core.constant.Globals;
  26. import org.jeecgframework.core.util.DateUtils;
  27. import org.jeecgframework.core.util.ResourceUtil;
  28. import org.jeecgframework.tag.core.easyui.TagUtil;
  29. import org.jeecgframework.web.system.pojo.base.TSUser;
  30. import org.jeecgframework.web.system.service.SystemService;
  31. import org.springframework.beans.factory.annotation.Autowired;
  32. import org.springframework.stereotype.Controller;
  33. import org.springframework.web.bind.annotation.RequestMapping;
  34. import org.springframework.web.bind.annotation.RequestMethod;
  35. import org.springframework.web.bind.annotation.RequestParam;
  36. import org.springframework.web.bind.annotation.ResponseBody;
  37. import javax.servlet.http.HttpServletRequest;
  38. import javax.servlet.http.HttpServletResponse;
  39. import java.math.BigDecimal;
  40. import java.util.ArrayList;
  41. import java.util.Calendar;
  42. import java.util.Date;
  43. import java.util.List;
  44. @Controller
  45. @RequestMapping("/userActivitiDataController")
  46. public class UserActivitiDataController {
  47. @Autowired
  48. private UseractivitiDataDao useractivitiDataDao;
  49. @Autowired
  50. private SystemService systemService;
  51. @Autowired
  52. private TBActivitiCostRequestServiceI tBActivitiCostRequestService;
  53. @Autowired
  54. private UseractivitiDataServiceI useractivitiDataService;
  55. @Autowired
  56. private OrdersFixAssetServiceI ordersFixAssetService;
  57. @Autowired
  58. private CostYearActualStatisServiceI costYearActualStatisService;
  59. @Autowired
  60. private TBActivitiCostPayInnerUserServiceI tBActivitiCostPayInnerUserService;
  61. @Autowired
  62. private TBActivitiCostPayTmpCompanyServiceI tBActivitiCostPayTmpCompanyService;
  63. /**
  64. * 选择用户所有部门 ,包括兼容机构
  65. * @return
  66. */
  67. @RequestMapping(params = "depSelect")
  68. public String depSelect(){
  69. return "cn/com/lzt/useractiviti/data/dep_select";
  70. }
  71. @RequestMapping(params = "depSelectDatagrid")
  72. public void depSelectDatagrid(ProjectDepartDto projectDepartDto, HttpServletRequest request, HttpServletResponse response, DataGrid dataGrid){
  73. TSUser user = ResourceUtil.getSessionUser();
  74. List<ProjectDepartDto> list = useractivitiDataDao.getUserAllDep(user.getId(),projectDepartDto);
  75. dataGrid.setResults(list);
  76. TagUtil.datagrid(response, dataGrid);
  77. }
  78. @RequestMapping(params = "depPostSelect")
  79. public String depPostSelect(){
  80. return "cn/com/lzt/useractiviti/data/dep_post_select";
  81. }
  82. @RequestMapping(params = "depPostSelectDatagrid")
  83. public void depSelectDatagrid(HttpServletRequest request, HttpServletResponse response, DataGrid dataGrid){
  84. String departId = request.getParameter("departId");
  85. CriteriaQuery cq = new CriteriaQuery(ProjectPostDetailEntity.class,dataGrid);
  86. cq.eq("pid",departId);
  87. cq.eq("deleteFlag",String.valueOf(Globals.Delete_Normal));
  88. String ptjPostName =request.getParameter("ptjPostName");
  89. if(StringUtils.isNotBlank(ptjPostName)){
  90. cq.like("ptjPostName","%"+ptjPostName+"%");
  91. }
  92. cq.add();
  93. systemService.getDataGridReturn(cq,false);
  94. TagUtil.datagrid(response, dataGrid);
  95. }
  96. /**
  97. * 选择职务,基本职务,非树形结构
  98. * @return
  99. */
  100. @RequestMapping(params = "leafDutySelect")
  101. public String leafDutySelect(){
  102. return "cn/com/lzt/useractiviti/data/leaf_duty_select";
  103. }
  104. @RequestMapping(params = "leafDutySelectDatagrid")
  105. public void leafDutySelectDatagrid(DutiesEntity entity, HttpServletRequest request, HttpServletResponse response, DataGrid dataGrid){
  106. CriteriaQuery cq = new CriteriaQuery(DutiesEntity.class,dataGrid);
  107. cq.notEq("deleteFlag","1");
  108. cq.notEq("status","1");
  109. if(StringUtils.isNotBlank(entity.getDutiesName())){
  110. cq.like("dutiesName","%"+entity.getDutiesName()+"%");
  111. }
  112. cq.add();
  113. systemService.getDataGridReturn(cq, false);
  114. List<DutiesEntity> list = dataGrid.getResults();
  115. List<DutiesEntity> leafList = new ArrayList<>();
  116. for(DutiesEntity duty:list){
  117. //根据id判断是否有子节点
  118. String sql = "select count(1) from t_bus_duties t where t.parent_dutiesid =? and delete_flag <> '1' and status <> '1'";
  119. Object[] params = new Object[]{duty.getId()};
  120. long count = this.systemService.getCountForJdbcParam(sql, params);
  121. if(count==0){
  122. leafList.add(duty);
  123. }
  124. }
  125. dataGrid.setResults(leafList);
  126. dataGrid.setTotal(leafList.size());
  127. TagUtil.datagrid(response, dataGrid);
  128. }
  129. @RequestMapping(params = "dutyType")
  130. @ResponseBody
  131. public String dutyType(@RequestParam("userId") String userId){
  132. // UserUtil.getDutyTypeByUserId();
  133. return null;
  134. }
  135. /**
  136. * 打印
  137. */
  138. @RequestMapping(params = "printPdf")
  139. public void printPdf(@RequestParam("procInstanceIds") String procInstanceIds
  140. ,@RequestParam("ids") String ids
  141. ,@RequestParam("procDefIds") String procDefIds
  142. ,HttpServletRequest request
  143. ,HttpServletResponse response
  144. ){
  145. String[] procInstanceArray = StringUtils.split(procInstanceIds,",");
  146. List<List<Element>> list = new ArrayList<>(procInstanceArray.length);
  147. for(int i =0;i<procInstanceArray.length;i++){
  148. String procInstId = procInstanceArray[i];
  149. ActivitiTools tools = ActivitiTools.getInstance(procInstId);
  150. if(tools!=null) {
  151. if(procInstanceArray.length==1) {
  152. tools.exportToResponse(response);
  153. break;
  154. }else {
  155. list.add(tools.printElementList());
  156. }
  157. }
  158. }
  159. if(list.size()>1){
  160. PdfUtil.export(list,response,"审批打印"+ DateUtils.formatDate(new Date(),"yyyyMMddHHmmss"));
  161. }
  162. }
  163. /**
  164. * 审批流发起的执行流情况
  165. * @return
  166. */
  167. @RequestMapping(params = "activitiTaskResult")
  168. public String activitiTaskResult(){
  169. return "cn/com/lzt/useractiviti/data/activiti_task_result";
  170. }
  171. @RequestMapping(params = "activitiTaskResultDatagrid")
  172. public void activitiTaskResultDatagrid(ProjecttaskEntity projecttaskEntity, HttpServletRequest request, HttpServletResponse response, DataGrid dataGrid){
  173. CriteriaQuery cq = new CriteriaQuery(ProjecttaskEntity.class, dataGrid);
  174. cq.eq("sourcetype","activititask");
  175. cq.eq("sourceid",projecttaskEntity.getSourceid());
  176. // org.jeecgframework.core.extend.hqlsearch.HqlGenerateUtil.installHql(cq, projecttaskEntity, request.getParameterMap());
  177. cq.add();
  178. this.systemService.getDataGridReturn(cq, false);
  179. TagUtil.datagrid(response, dataGrid);
  180. }
  181. //财务支付驳回
  182. @RequestMapping(params = "rejectFinishedActiviti")
  183. @ResponseBody
  184. public AjaxJson rejectFinishedActiviti(@RequestParam("tableName") String tableName, @RequestParam("id") String id, HttpServletRequest request){
  185. AjaxJson json = new AjaxJson();
  186. String updateSql = "update "+tableName+" set bpm_status ='1' ,proc_inst_id=null,step_name='已驳回' where id =? ";
  187. String delSql = "delete from t_s_basebus where id=? ";
  188. try{
  189. systemService.executeSql(updateSql,id);
  190. systemService.executeSql(delSql,id);
  191. if(StringUtils.equals(tableName, "t_b_activiti_cost_pay_inner_user")){
  192. List<TBActivitiCostPayInnerUserDetailEntity> list =systemService.findByProperty(TBActivitiCostPayInnerUserDetailEntity.class,"costPayInnerUserId",id);
  193. for(TBActivitiCostPayInnerUserDetailEntity entity :list){
  194. entity.setBpmStatus(Globals.BPM_STATUS_Normal.toString());
  195. systemService.updateEntitie(entity);
  196. }
  197. }else if(StringUtils.equals(tableName, "t_b_activiti_cost_pay_tmp_company")){
  198. }else if(StringUtils.equals(tableName, "t_b_activiti_cost_request")){//申请单作废
  199. TBActivitiCostRequestEntity entity = systemService.getEntity(TBActivitiCostRequestEntity.class,id );
  200. Calendar c = Calendar.getInstance();
  201. c.setTime(entity.getCreateDate());
  202. String year = String.valueOf(c.get(Calendar.YEAR));
  203. costYearActualStatisService.addStatisMoney(year,entity.getDepartId(),entity.getUserid(),entity.getCostType(),entity.getExpectMoney().negate(),BigDecimal.ZERO);
  204. }
  205. }catch (Exception e){
  206. json.setSuccess(false);
  207. }
  208. return json;
  209. }
  210. @RequestMapping(params = "isHr")
  211. @ResponseBody
  212. public AjaxJson isHr(HttpServletRequest request){
  213. AjaxJson json = new AjaxJson();
  214. boolean isHr = UserUtil.isHr(ResourceUtil.getSessionUser().getId());
  215. json.setObj(isHr);
  216. return json;
  217. }
  218. @RequestMapping(params = "userInfo",method = RequestMethod.POST)
  219. @ResponseBody
  220. public AjaxJson userInfo(HttpServletRequest request
  221. ,@RequestParam("userId") String userId
  222. ){
  223. AjaxJson json = new AjaxJson();
  224. ActivitiUserInfoDto dto = useractivitiDataService.getUserInfo(userId);
  225. List<UserWageDto> list = dto.getUserWageDtoList();
  226. if(list!=null &&!list.isEmpty()){
  227. dto.setLastMonthWage(list.get(0).getActualMoney());
  228. dto.setUserWageDtoList(null);
  229. }
  230. json.setObj(dto);
  231. return json;
  232. }
  233. /**
  234. *获得岗位编制数
  235. * @param request
  236. * @return
  237. */
  238. @RequestMapping(params = "getPostNeedNum",method = RequestMethod.POST)
  239. @ResponseBody
  240. public AjaxJson getPostNeedNum(HttpServletRequest request
  241. ,@RequestParam("departId") String departId
  242. ,@RequestParam("postId") String postId
  243. ){
  244. AjaxJson json = new AjaxJson();
  245. Integer num = useractivitiDataService.getPostNeedNum(departId,postId);
  246. json.setObj(num);
  247. return json;
  248. }
  249. }