Compare commits

..

5 Commits

@ -1,8 +0,0 @@
<component name="ArtifactManager">
<artifact type="jar" name="weaver-develop:jar">
<output-path>$PROJECT_DIR$/out/artifacts/weaver_develop_jar</output-path>
<root id="archive" name="weaver-develop.jar">
<element id="module-output" name="weaver-develop" />
</root>
</artifact>
</component>

@ -1,3 +0,0 @@
Manifest-Version: 1.0
Main-Class: test.MainTest

@ -0,0 +1,10 @@
package com.api.zkdpoc.web;
/**
* @Author liang.cheng
* @Date 2024/10/14 2:52 PM
* @Description: TODO
* @Version 1.0
*/
public class ProjectSaveAction {
}

@ -0,0 +1,10 @@
package com.engine.zkdpoc.service;
/**
* @Author liang.cheng
* @Date 2024/10/14 2:54 PM
* @Description: TODO
* @Version 1.0
*/
public interface ProjectSaveService {
}

@ -0,0 +1,10 @@
package com.engine.zkdpoc.service.impl;
/**
* @Author liang.cheng
* @Date 2024/10/14 2:55 PM
* @Description: TODO
* @Version 1.0
*/
public class ProjectSaveServiceImpl {
}

@ -0,0 +1,16 @@
package com.engine.zkdpoc.vo;
/**
* @Author liang.cheng
* @Date 2024/10/14 3:02 PM
* @Description: TODO
* @Version 1.0
*/
public class ProjectSaveRemindVo {
}

@ -0,0 +1,10 @@
package com.engine.zkdpoc.web;
/**
* @Author liang.cheng
* @Date 2024/10/14 2:53 PM
* @Description: TODO
* @Version 1.0
*/
public class ProjectSaveAction {
}

@ -1,5 +1,17 @@
package test;
import cn.hutool.core.collection.CollectionUtil;
import org.apache.commons.collections.CollectionUtils;
import weaver.general.TimeUtil;
import weaver.interfaces.zkdpoc.po.EntryWorkflowPo;
import java.time.LocalDate;
import java.time.format.DateTimeFormatter;
import java.time.temporal.ChronoUnit;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
/**
* @Author weaver_cl
* @Description:
@ -10,5 +22,17 @@ public class MainTest {
public static void main(String[] args) {
LocalDate currentDate = LocalDate.now();
DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd");
String formattedDate = currentDate.format(formatter);
String formattedTime = TimeUtil.getOnlyCurrentTimeString();
System.out.println(formattedDate);
System.out.println(formattedTime);
}
}

@ -0,0 +1,77 @@
package weaver.interfaces.zkdpoc.action;
import com.weaver.general.Util;
import weaver.conn.RecordSet;
import weaver.interfaces.workflow.action.Action;
import weaver.interfaces.zkdpoc.po.EntryWorkflowPo;
import weaver.soa.workflow.request.RequestInfo;
import java.time.LocalDate;
import java.time.format.DateTimeFormatter;
import java.time.temporal.ChronoUnit;
import java.util.ArrayList;
import java.util.List;
/**
* @Author liang.cheng
* @Date 2024/10/12 10:47 AM
* @Description: -poc
* @Version 1.0
*/
public class EntryWorkflowAction implements Action {
@Override
public String execute(RequestInfo requestInfo) {
String requestid = requestInfo.getRequestid();
int formid = Math.abs(requestInfo.getRequestManager().getFormid());
RecordSet rs = new RecordSet();
String mainTable = String.format("%s%s", "formtable_main_", formid);
String detaiTable = String.format("%s%s",mainTable,"_dt2");
EntryWorkflowPo entryPo = EntryWorkflowPo.builder().build();
//1.获取表单数据
rs.executeQuery("select id,ksrq,jsrq,rysjid,dw,gw,xced from "+mainTable+" where requestid = ?",requestid);
if (rs.next()) {
entryPo.setId(Util.getIntValue(rs.getString("id")));
entryPo.setStartDate(Util.null2String(rs.getString("ksrq")));
entryPo.setEndDate(Util.null2String(rs.getString("jsrq")));
entryPo.setPersonId(Util.getIntValue(rs.getString("rysjid")));
entryPo.setSubCompanyId(Util.getIntValue(rs.getString("dw")));
entryPo.setJobTitleId(Util.getIntValue(rs.getString("gw")));
entryPo.setSalaryMonth(Util.getDoubleValue(rs.getString("xced")));
}
//2.起始日期不为空时明细赋值操作
if (!"".equals(entryPo.getStartDate()) && !"".equals(entryPo.getEndDate())) {
List<String> months = detailMonth(entryPo.getStartDate(), entryPo.getEndDate());
months.forEach(month -> rs.executeUpdate("insert into "+detaiTable+"(mainid,yd,xm,szdw,gw,ydxz) values(?,?,?,?,?,?)",
entryPo.getId(),month,entryPo.getPersonId(),entryPo.getSubCompanyId(),entryPo.getJobTitleId(),entryPo.getSalaryMonth()));
}
return Action.SUCCESS;
}
private List<String> detailMonth(String startDateStr,String endDateStr) {
DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd");
LocalDate startDate = LocalDate.parse(startDateStr, formatter);
LocalDate endDate = LocalDate.parse(endDateStr, formatter);
List<String> months = new ArrayList<>();
DateTimeFormatter monthFormatter = DateTimeFormatter.ofPattern("yyyy-MM");
while (!startDate.isAfter(endDate)) {
months.add(startDate.format(monthFormatter));
startDate = startDate.plus(1, ChronoUnit.MONTHS);
}
return months;
}
}

@ -0,0 +1,89 @@
package weaver.interfaces.zkdpoc.crob;
import cn.hutool.core.collection.CollectionUtil;
import org.apache.commons.collections.CollectionUtils;
import weaver.conn.RecordSet;
import weaver.general.TimeUtil;
import weaver.general.Util;
import weaver.interfaces.schedule.BaseCronJob;
import weaver.interfaces.zkdpoc.po.PersonInfoCutPo;
import java.time.LocalDate;
import java.time.format.DateTimeFormatter;
import java.util.ArrayList;
import java.util.List;
/**
* @Author liang.cheng
* @Date 2024/10/15 9:34 AM
* @Description: poc
* @Version 1.0
*/
public class PersonInfoCutCrob extends BaseCronJob {
@Override
public void execute() {
RecordSet rs = new RecordSet();
LocalDate currentDate = LocalDate.now();
DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd");
String formattedDate = currentDate.format(formatter);
String formattedTime = TimeUtil.getOnlyCurrentTimeString();
//模块ID
Integer modeId = 335;
List<Integer> ids = new ArrayList<>();
//1.主表数据复制切片
rs.executeQuery("select id from formtable_main_492 where qprq = ?",formattedDate);
while (rs.next()) {
ids.add(Util.getIntValue(rs.getString("id")));
}
if (CollectionUtils.isNotEmpty(ids)) {
String join = CollectionUtil.join(ids, ",");
rs.execute("delete from formtable_main_492 where id in ("+join+")");
rs.execute("delete from formtable_main_492_dt1 where mainid in ("+join+")");
}
rs.execute("insert into formtable_main_492(sjyid,zt,field001,field002,field003,field004,field005,field006,field007,zp,fb,gw,htbh,htpq,\n" +
"htksrq,htjsrq,remark,qx,gwlb,zyjszw,bzlb,sfgjbsh,gjbshjzrq,gjbshczrq,qprq) select id,zt,field001,field002,field003,field004,field005,field006,field007,zp,fb,gw,htbh,htpq,\n" +
"htksrq,htjsrq,remark,qx,gwlb,zyjszw,bzlb,sfgjbsh,gjbshjzrq,gjbshczrq,DATE_FORMAT(CURDATE(), '%Y-%m-%d') from uf_ryxx");
//2.更新查询列表所需字段
rs.executeUpdate("update formtable_main_492 set formmodeid = ?,modedatacreater = ?,modedatacreatedate = ?,modedatacreatetime = ? where" +
" qprq = ?", modeId,1,formattedDate,formattedTime,formattedDate);
//3.更新明细表
List<PersonInfoCutPo> personInfoCutPos = new ArrayList<>();
rs.executeQuery("select a.id,a.sjyid,b.field001,b.field002,b.field003,b.field004,b.lcmxid from formtable_main_492 a \n" +
"INNER JOIN uf_ryxx_dt1 b on a.sjyid = b.mainid where a.qprq = ?",formattedDate);
while (rs.next()) {
personInfoCutPos.add(PersonInfoCutPo.builder()
.id(Util.getIntValue(rs.getString("id")))
.oldId(Util.getIntValue(rs.getString("sjyid")))
.memberName(Util.null2String(rs.getString("field001")))
.namely(Util.null2String(rs.getString("field002")))
.workName(Util.null2String(rs.getString("field003")))
.jobType(Util.null2String(rs.getString("field004")))
.requestId(Util.null2String(rs.getString("lcmxid")))
.build());
}
personInfoCutPos.forEach(item -> rs.executeUpdate("insert into formtable_main_492_dt1(mainid,field001,field002,field003,field004,lcmxid) values(?,?,?,?,?,?)",
item.getId(),item.getMemberName(),item.getNamely(),item.getWorkName(),item.getJobType(),item.getRequestId()));
}
}

@ -0,0 +1,95 @@
package weaver.interfaces.zkdpoc.crob;
import com.weaver.general.BaseBean;
import com.weaver.general.Util;
import weaver.conn.RecordSet;
import weaver.interfaces.schedule.BaseCronJob;
import weaver.interfaces.zkdpoc.po.SalaryPayProcessPo;
import java.time.LocalDate;
import java.time.format.DateTimeFormatter;
import java.time.temporal.ChronoUnit;
import java.util.ArrayList;
import java.util.List;
/**
* @Author liang.cheng
* @Date 2024/10/11 5:39 PM
* @Description: POC
* @Version 1.0
*/
public class SalaryPayProcessCrob extends BaseCronJob {
@Override
public void execute() {
List<SalaryPayProcessPo> salaryPayProcessList = new ArrayList<>();
BaseBean bb = new BaseBean();
RecordSet rs = new RecordSet();
//1.获取需要更新的缴纳情况人数
rs.executeQuery("select ryxm from uf_ryxzjnqk");
while (rs.next()) {
SalaryPayProcessPo processPo = new SalaryPayProcessPo();
processPo.setPersonId(Util.getIntValue(rs.getString("ryxm")));
salaryPayProcessList.add(processPo);
}
LocalDate now = LocalDate.now();
DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM");
String localDate = now.format(formatter);
salaryPayProcessList.forEach(item -> {
rs.executeQuery("select yd,ydxz from uf_ryxzbzkd where jkqk = 1 and xm = ? order by yd desc limit 1",item.getPersonId());
if (rs.next()){
String payMonth = Util.null2String(rs.getString("yd"));
double ydxz = Util.getDoubleValue(rs.getString("ydxz"));
int monthsDiff = calculateMonthDiff(payMonth,localDate);
if (monthsDiff > 3) {
item.setPayProcess(0);
}else if (monthsDiff >= 0) {
item.setPayProcess(1);
}else {
item.setPayProcess(2);
double dueMoney = Math.abs(monthsDiff) * ydxz;
bb.writeLog("ydxz-a",+ydxz);
bb.writeLog("monthsDiff",+Math.abs(monthsDiff));
bb.writeLog("dueMoney"+dueMoney);
item.setDueMoney(dueMoney);
item.setDueStartMonth(payMonth);
item.setDueEndMonth(localDate);
}
bb.writeLog("SalaryPayProcessPo-item"+item.toString());
if (monthsDiff >= 0) {
rs.executeUpdate("update uf_ryxzjnqk set jkjd = ? where ryxm = ?",item.getPayProcess(),item.getPersonId());
}else {
rs.executeUpdate("update uf_ryxzjnqk set jkjd = ?,qfsdq = ?,qfsdz = ?,qfje = ? where ryxm = ?", item.getPayProcess(),item.getDueStartMonth(),item.getDueEndMonth(),item.getDueMoney(),item.getPersonId());
}
}else {
//不存在缴款数据情况 todo poc待定
}
});
}
private int calculateMonthDiff(String payMonth,String localDate){
LocalDate date1 = LocalDate.parse(localDate + "-01");
LocalDate date2 = LocalDate.parse(payMonth + "-01");
return (int) ChronoUnit.MONTHS.between(date1, date2);
}
}

@ -0,0 +1,35 @@
package weaver.interfaces.zkdpoc.po;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
/**
* @Author liang.cheng
* @Date 2024/10/12 10:57 AM
* @Description: TODO
* @Version 1.0
*/
@Data
@Builder
@AllArgsConstructor
@NoArgsConstructor
public class EntryWorkflowPo {
private Integer id;
private String startDate;
private String endDate;
private Integer personId;
private Integer subCompanyId;
private Integer jobTitleId;
private double salaryMonth;
}

@ -0,0 +1,90 @@
package weaver.interfaces.zkdpoc.po;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
/**
* @Author liang.cheng
* @Date 2024/10/15 10:28 AM
* @Description: TODO
* @Version 1.0
*/
@Data
@Builder
@AllArgsConstructor
@NoArgsConstructor
public class PersonInfoCutPo {
private Integer id;
private Integer oldId;
private String cutDate;
/**
*
*/
private Integer status;
private String lastName;
private Integer sex;
private String birthday;
private String idCard;
private String mobile;
private String email;
private String address;
private Integer photos;
private Integer subCompanyId;
private Integer jobTitle;
private String htNo;
private String htDate;
private String htStartDate;
private String htEndDate;
private String remark;
private Integer nextGo;
private Integer nextContent;
private Integer jobGroub;
private Integer staffType;
/**
*
*/
private Integer postDoctoral;
private String postGoDate;
private String postOutDate;
/**
*
*/
private String memberName;
private String namely;
private String workName;
private String jobType;
private String requestId;
}

@ -0,0 +1,33 @@
package weaver.interfaces.zkdpoc.po;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
/**
* @Author liang.cheng
* @Date 2024/10/11 5:53 PM
* @Description:
* @Version 1.0
*/
@Data
@Builder
@AllArgsConstructor
@NoArgsConstructor
public class SalaryPayPo {
private Integer personId;
/**
*
*/
private String payMonth;
/**
*
*/
private double salaryMonth;
}

@ -0,0 +1,38 @@
package weaver.interfaces.zkdpoc.po;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
/**
* @Author liang.cheng
* @Date 2024/10/11 5:47 PM
* @Description: TODO
* @Version 1.0
*/
@Data
@Builder
@AllArgsConstructor
@NoArgsConstructor
public class SalaryPayProcessPo {
private Integer personId;
/**
*
*/
private Integer payProcess;
private String dueStartMonth;
private String dueEndMonth;
private double dueMoney;
}
Loading…
Cancel
Save