diff --git a/resource/WEB-INF/prop/hrmSalary.properties b/resource/WEB-INF/prop/hrmSalary.properties
index d95554ef6..55360c99a 100644
--- a/resource/WEB-INF/prop/hrmSalary.properties
+++ b/resource/WEB-INF/prop/hrmSalary.properties
@@ -1,5 +1,5 @@
log=false
defaultCloseNonStandard149=true
AESEncryptScrect=990EB004A1C862721C1513AE90038C9E
-version=3.0.0.2503.01
+version=3.0.1.2503.01
openFormulaForcedEditing=false
\ No newline at end of file
diff --git a/resource/sqlupgrade/DM/sql202411190103.sql b/resource/sqlupgrade/DM/sql202411190103.sql
new file mode 100644
index 000000000..1ed27c6fd
--- /dev/null
+++ b/resource/sqlupgrade/DM/sql202411190103.sql
@@ -0,0 +1,70 @@
+CREATE TABLE hrsa_push_setting
+(
+ id NUMBER(38,0) primary key NOT NULL,
+ name varchar2(200),
+ able number,
+ salary_sob_ids varchar2(2000),
+ mode_id number,
+ mode_name varchar2(200),
+ table_name varchar2(200),
+ creator NUMBER(38,0),
+ create_time date,
+ update_time date,
+ delete_type number,
+ tenant_key varchar2(10)
+);
+/
+
+CREATE TABLE hrsa_push_setting_item
+(
+ id NUMBER(38,0) NOT NULL,
+ setting_id NUMBER(38,0),
+ source varchar2(100),
+ item varchar2(200),
+ item_name varchar2(200),
+ field_name varchar2(200),
+ field_type number,
+ creator NUMBER(38,0),
+ create_time date,
+ update_time date,
+ delete_type number,
+ tenant_key varchar2(10)
+);
+/
+
+CREATE TABLE hrsa_push_record
+(
+ id NUMBER(38,0) NOT NULL,
+ name varchar2(200),
+ setting_id NUMBER(38,0),
+ mode_id number,
+ table_name varchar2(100),
+ acct_record_id NUMBER(38,0),
+ type number,
+ status number,
+ start_time date,
+ end_time date,
+ creator NUMBER(38,0),
+ create_time date,
+ update_time date,
+ delete_type number,
+ tenant_key varchar2(10)
+);
+/
+
+CREATE TABLE hrsa_push_record_detail
+(
+ id NUMBER(38,0) NOT NULL,
+ record_id NUMBER(38,0),
+ acct_emp_id NUMBER(38,0),
+ execute CLOB,
+ execute_time date,
+ status number,
+ creator NUMBER(38,0),
+ create_time date,
+ update_time date,
+ delete_type number,
+ tenant_key varchar2(10)
+);
+/
+
diff --git a/resource/sqlupgrade/DM/sql202504020203.sql b/resource/sqlupgrade/DM/sql202504020203.sql
new file mode 100644
index 000000000..d54eff0ca
--- /dev/null
+++ b/resource/sqlupgrade/DM/sql202504020203.sql
@@ -0,0 +1,6 @@
+ALTER TABLE hrsa_push_record ADD fail_reason varchar2(4000);
+/
+
+ALTER TABLE hrsa_push_record_detail ADD fail_reason varchar2(4000);
+/
+
diff --git a/resource/sqlupgrade/DM/sql202504030103.sql b/resource/sqlupgrade/DM/sql202504030103.sql
new file mode 100644
index 000000000..013d261c1
--- /dev/null
+++ b/resource/sqlupgrade/DM/sql202504030103.sql
@@ -0,0 +1,6 @@
+ALTER TABLE hrsa_push_setting_item ADD sorted_index NUMBER;
+/
+
+ALTER TABLE hrsa_push_record_detail ADD data_id NUMBER(38,0);
+/
+
diff --git a/resource/sqlupgrade/GS/sql202411190103.sql b/resource/sqlupgrade/GS/sql202411190103.sql
new file mode 100644
index 000000000..1ed27c6fd
--- /dev/null
+++ b/resource/sqlupgrade/GS/sql202411190103.sql
@@ -0,0 +1,70 @@
+CREATE TABLE hrsa_push_setting
+(
+ id NUMBER(38,0) primary key NOT NULL,
+ name varchar2(200),
+ able number,
+ salary_sob_ids varchar2(2000),
+ mode_id number,
+ mode_name varchar2(200),
+ table_name varchar2(200),
+ creator NUMBER(38,0),
+ create_time date,
+ update_time date,
+ delete_type number,
+ tenant_key varchar2(10)
+);
+/
+
+CREATE TABLE hrsa_push_setting_item
+(
+ id NUMBER(38,0) NOT NULL,
+ setting_id NUMBER(38,0),
+ source varchar2(100),
+ item varchar2(200),
+ item_name varchar2(200),
+ field_name varchar2(200),
+ field_type number,
+ creator NUMBER(38,0),
+ create_time date,
+ update_time date,
+ delete_type number,
+ tenant_key varchar2(10)
+);
+/
+
+CREATE TABLE hrsa_push_record
+(
+ id NUMBER(38,0) NOT NULL,
+ name varchar2(200),
+ setting_id NUMBER(38,0),
+ mode_id number,
+ table_name varchar2(100),
+ acct_record_id NUMBER(38,0),
+ type number,
+ status number,
+ start_time date,
+ end_time date,
+ creator NUMBER(38,0),
+ create_time date,
+ update_time date,
+ delete_type number,
+ tenant_key varchar2(10)
+);
+/
+
+CREATE TABLE hrsa_push_record_detail
+(
+ id NUMBER(38,0) NOT NULL,
+ record_id NUMBER(38,0),
+ acct_emp_id NUMBER(38,0),
+ execute CLOB,
+ execute_time date,
+ status number,
+ creator NUMBER(38,0),
+ create_time date,
+ update_time date,
+ delete_type number,
+ tenant_key varchar2(10)
+);
+/
+
diff --git a/resource/sqlupgrade/GS/sql202504020203.sql b/resource/sqlupgrade/GS/sql202504020203.sql
new file mode 100644
index 000000000..d54eff0ca
--- /dev/null
+++ b/resource/sqlupgrade/GS/sql202504020203.sql
@@ -0,0 +1,6 @@
+ALTER TABLE hrsa_push_record ADD fail_reason varchar2(4000);
+/
+
+ALTER TABLE hrsa_push_record_detail ADD fail_reason varchar2(4000);
+/
+
diff --git a/resource/sqlupgrade/GS/sql202504030103.sql b/resource/sqlupgrade/GS/sql202504030103.sql
new file mode 100644
index 000000000..013d261c1
--- /dev/null
+++ b/resource/sqlupgrade/GS/sql202504030103.sql
@@ -0,0 +1,6 @@
+ALTER TABLE hrsa_push_setting_item ADD sorted_index NUMBER;
+/
+
+ALTER TABLE hrsa_push_record_detail ADD data_id NUMBER(38,0);
+/
+
diff --git a/resource/sqlupgrade/JC/sql202411190103.sql b/resource/sqlupgrade/JC/sql202411190103.sql
new file mode 100644
index 000000000..1ed27c6fd
--- /dev/null
+++ b/resource/sqlupgrade/JC/sql202411190103.sql
@@ -0,0 +1,70 @@
+CREATE TABLE hrsa_push_setting
+(
+ id NUMBER(38,0) primary key NOT NULL,
+ name varchar2(200),
+ able number,
+ salary_sob_ids varchar2(2000),
+ mode_id number,
+ mode_name varchar2(200),
+ table_name varchar2(200),
+ creator NUMBER(38,0),
+ create_time date,
+ update_time date,
+ delete_type number,
+ tenant_key varchar2(10)
+);
+/
+
+CREATE TABLE hrsa_push_setting_item
+(
+ id NUMBER(38,0) NOT NULL,
+ setting_id NUMBER(38,0),
+ source varchar2(100),
+ item varchar2(200),
+ item_name varchar2(200),
+ field_name varchar2(200),
+ field_type number,
+ creator NUMBER(38,0),
+ create_time date,
+ update_time date,
+ delete_type number,
+ tenant_key varchar2(10)
+);
+/
+
+CREATE TABLE hrsa_push_record
+(
+ id NUMBER(38,0) NOT NULL,
+ name varchar2(200),
+ setting_id NUMBER(38,0),
+ mode_id number,
+ table_name varchar2(100),
+ acct_record_id NUMBER(38,0),
+ type number,
+ status number,
+ start_time date,
+ end_time date,
+ creator NUMBER(38,0),
+ create_time date,
+ update_time date,
+ delete_type number,
+ tenant_key varchar2(10)
+);
+/
+
+CREATE TABLE hrsa_push_record_detail
+(
+ id NUMBER(38,0) NOT NULL,
+ record_id NUMBER(38,0),
+ acct_emp_id NUMBER(38,0),
+ execute CLOB,
+ execute_time date,
+ status number,
+ creator NUMBER(38,0),
+ create_time date,
+ update_time date,
+ delete_type number,
+ tenant_key varchar2(10)
+);
+/
+
diff --git a/resource/sqlupgrade/JC/sql202504020203.sql b/resource/sqlupgrade/JC/sql202504020203.sql
new file mode 100644
index 000000000..d54eff0ca
--- /dev/null
+++ b/resource/sqlupgrade/JC/sql202504020203.sql
@@ -0,0 +1,6 @@
+ALTER TABLE hrsa_push_record ADD fail_reason varchar2(4000);
+/
+
+ALTER TABLE hrsa_push_record_detail ADD fail_reason varchar2(4000);
+/
+
diff --git a/resource/sqlupgrade/JC/sql202504030103.sql b/resource/sqlupgrade/JC/sql202504030103.sql
new file mode 100644
index 000000000..013d261c1
--- /dev/null
+++ b/resource/sqlupgrade/JC/sql202504030103.sql
@@ -0,0 +1,6 @@
+ALTER TABLE hrsa_push_setting_item ADD sorted_index NUMBER;
+/
+
+ALTER TABLE hrsa_push_record_detail ADD data_id NUMBER(38,0);
+/
+
diff --git a/resource/sqlupgrade/Mysql/sql202411190103.sql b/resource/sqlupgrade/Mysql/sql202411190103.sql
index 9ceb2c5b9..98b55261c 100644
--- a/resource/sqlupgrade/Mysql/sql202411190103.sql
+++ b/resource/sqlupgrade/Mysql/sql202411190103.sql
@@ -33,3 +33,39 @@ CREATE TABLE hrsa_push_setting_item
PRIMARY KEY (id) USING BTREE
);
+
+CREATE TABLE hrsa_push_record
+(
+ id bigint(0) NOT NULL,
+ name varchar(200),
+ setting_id bigint(0),
+ mode_id int(0),
+ table_name varchar(100),
+ acct_record_id bigint(0),
+ type int(0),
+ status int(0),
+ start_time datetime(0),
+ end_time datetime(0),
+ creator bigint(0),
+ create_time datetime(0),
+ update_time datetime(0),
+ delete_type int(0),
+ tenant_key varchar(10),
+ PRIMARY KEY (id) USING BTREE
+);
+
+CREATE TABLE hrsa_push_record_detail
+(
+ id bigint(0) NOT NULL,
+ record_id bigint(0),
+ acct_emp_id bigint(0),
+ execute text,
+ execute_time datetime(0),
+ status int(0),
+ creator bigint(0),
+ create_time datetime(0),
+ update_time datetime(0),
+ delete_type int(0),
+ tenant_key varchar(10),
+ PRIMARY KEY (id) USING BTREE
+);
\ No newline at end of file
diff --git a/resource/sqlupgrade/Mysql/sql202504020203.sql b/resource/sqlupgrade/Mysql/sql202504020203.sql
new file mode 100644
index 000000000..f7f94d4b6
--- /dev/null
+++ b/resource/sqlupgrade/Mysql/sql202504020203.sql
@@ -0,0 +1,3 @@
+ALTER TABLE hrsa_push_record ADD COLUMN fail_reason varchar(4000);
+
+ALTER TABLE hrsa_push_record_detail ADD COLUMN fail_reason varchar(4000) ;
diff --git a/resource/sqlupgrade/Mysql/sql202504030103.sql b/resource/sqlupgrade/Mysql/sql202504030103.sql
new file mode 100644
index 000000000..f21868d14
--- /dev/null
+++ b/resource/sqlupgrade/Mysql/sql202504030103.sql
@@ -0,0 +1,3 @@
+ALTER TABLE hrsa_push_setting_item ADD COLUMN sorted_index int(0);
+
+ALTER TABLE hrsa_push_record_detail ADD COLUMN data_id bigint(0);
diff --git a/resource/sqlupgrade/Oracle/sql202411190103.sql b/resource/sqlupgrade/Oracle/sql202411190103.sql
new file mode 100644
index 000000000..27e5d3cc9
--- /dev/null
+++ b/resource/sqlupgrade/Oracle/sql202411190103.sql
@@ -0,0 +1,71 @@
+CREATE TABLE hrsa_push_setting
+(
+ id NUMBER(38,0) primary key NOT NULL,
+ name varchar2(200),
+ able number,
+ salary_sob_ids varchar2(2000),
+ mode_id number,
+ mode_name varchar2(200),
+ table_name varchar2(200),
+ creator NUMBER(38,0),
+ create_time date,
+ update_time date,
+ delete_type number,
+ tenant_key varchar2(10)
+)
+/
+
+
+CREATE TABLE hrsa_push_setting_item
+(
+ id NUMBER(38,0) NOT NULL,
+ setting_id NUMBER(38,0),
+ source varchar2(100),
+ item varchar2(200),
+ item_name varchar2(200),
+ field_name varchar2(200),
+ field_type number,
+ creator NUMBER(38,0),
+ create_time date,
+ update_time date,
+ delete_type number,
+ tenant_key varchar2(10)
+)
+/
+
+
+CREATE TABLE hrsa_push_record
+(
+ id NUMBER(38,0) NOT NULL,
+ name varchar2(200),
+ setting_id NUMBER(38,0),
+ mode_id number,
+ table_name varchar2(100),
+ acct_record_id NUMBER(38,0),
+ type number,
+ status number,
+ start_time date,
+ end_time date,
+ creator NUMBER(38,0),
+ create_time date,
+ update_time date,
+ delete_type number,
+ tenant_key varchar2(10)
+)
+/
+
+CREATE TABLE hrsa_push_record_detail
+(
+ id NUMBER(38,0) NOT NULL,
+ record_id NUMBER(38,0),
+ acct_emp_id NUMBER(38,0),
+ execute CLOB,
+ execute_time date,
+ status number,
+ creator NUMBER(38,0),
+ create_time date,
+ update_time date,
+ delete_type number,
+ tenant_key varchar2(10)
+)
+/
\ No newline at end of file
diff --git a/resource/sqlupgrade/Oracle/sql202504020203.sql b/resource/sqlupgrade/Oracle/sql202504020203.sql
new file mode 100644
index 000000000..ea71581d2
--- /dev/null
+++ b/resource/sqlupgrade/Oracle/sql202504020203.sql
@@ -0,0 +1,5 @@
+ALTER TABLE hrsa_push_record ADD fail_reason varchar2(4000);
+/
+
+ALTER TABLE hrsa_push_record_detail ADD fail_reason varchar2(4000);
+/
\ No newline at end of file
diff --git a/resource/sqlupgrade/Oracle/sql202504030103.sql b/resource/sqlupgrade/Oracle/sql202504030103.sql
new file mode 100644
index 000000000..8c2ab620f
--- /dev/null
+++ b/resource/sqlupgrade/Oracle/sql202504030103.sql
@@ -0,0 +1,5 @@
+ALTER TABLE hrsa_push_setting_item ADD sorted_index NUMBER;
+/
+
+ALTER TABLE hrsa_push_record_detail ADD data_id NUMBER(38,0);
+/
\ No newline at end of file
diff --git a/resource/sqlupgrade/PG/sql202411190103.sql b/resource/sqlupgrade/PG/sql202411190103.sql
new file mode 100644
index 000000000..0e2ba412e
--- /dev/null
+++ b/resource/sqlupgrade/PG/sql202411190103.sql
@@ -0,0 +1,71 @@
+CREATE TABLE hrsa_push_setting
+(
+ id bigint NOT NULL,
+ name varchar(200),
+ able int,
+ salary_sob_ids varchar(2000),
+ mode_id int,
+ mode_name varchar(200),
+ table_name varchar(200),
+ creator bigint,
+ create_time timestamp,
+ update_time timestamp,
+ delete_type int,
+ tenant_key varchar(10),
+ PRIMARY KEY (id)
+);
+
+
+CREATE TABLE hrsa_push_setting_item
+(
+ id bigint NOT NULL,
+ setting_id bigint,
+ source varchar(100),
+ item varchar(200),
+ item_name varchar(200),
+ field_name varchar(200),
+ field_type int,
+ creator bigint,
+ create_time timestamp,
+ update_time timestamp,
+ delete_type int,
+ tenant_key varchar(10),
+ PRIMARY KEY (id)
+);
+
+
+CREATE TABLE hrsa_push_record
+(
+ id bigint NOT NULL,
+ name varchar(200),
+ setting_id bigint,
+ mode_id int,
+ table_name varchar(100),
+ acct_record_id bigint,
+ type int,
+ status int,
+ start_time timestamp,
+ end_time timestamp,
+ creator bigint,
+ create_time timestamp,
+ update_time timestamp,
+ delete_type int,
+ tenant_key varchar(10),
+ PRIMARY KEY (id)
+);
+
+CREATE TABLE hrsa_push_record_detail
+(
+ id bigint NOT NULL,
+ record_id bigint,
+ acct_emp_id bigint,
+ execute text,
+ execute_time timestamp,
+ status int,
+ creator bigint,
+ create_time timestamp,
+ update_time timestamp,
+ delete_type int,
+ tenant_key varchar(10),
+ PRIMARY KEY (id)
+);
\ No newline at end of file
diff --git a/resource/sqlupgrade/PG/sql202504020203.sql b/resource/sqlupgrade/PG/sql202504020203.sql
new file mode 100644
index 000000000..adb7b31e2
--- /dev/null
+++ b/resource/sqlupgrade/PG/sql202504020203.sql
@@ -0,0 +1,3 @@
+alter table hrsa_push_record add fail_reason VARCHAR(4000) ;
+
+alter table hrsa_push_record_detail add fail_reason VARCHAR(4000) ;
\ No newline at end of file
diff --git a/resource/sqlupgrade/PG/sql202504030103.sql b/resource/sqlupgrade/PG/sql202504030103.sql
new file mode 100644
index 000000000..a0bda613d
--- /dev/null
+++ b/resource/sqlupgrade/PG/sql202504030103.sql
@@ -0,0 +1,3 @@
+alter table hrsa_push_setting_item add sorted_index int ;
+
+alter table hrsa_push_record_detail add data_id bigint ;
\ No newline at end of file
diff --git a/resource/sqlupgrade/SQLServer/sql202411190103.sql b/resource/sqlupgrade/SQLServer/sql202411190103.sql
new file mode 100644
index 000000000..fd993c777
--- /dev/null
+++ b/resource/sqlupgrade/SQLServer/sql202411190103.sql
@@ -0,0 +1,75 @@
+CREATE TABLE hrsa_push_setting
+(
+ id bigint NOT NULL,
+ name varchar(200),
+ able int,
+ salary_sob_ids varchar(2000),
+ mode_id int,
+ mode_name varchar(200),
+ table_name varchar(200),
+ creator bigint,
+ create_time datetime,
+ update_time datetime,
+ delete_type int,
+ tenant_key varchar(10),
+ PRIMARY KEY (id)
+)
+GO
+
+
+CREATE TABLE hrsa_push_setting_item
+(
+ id bigint NOT NULL,
+ setting_id bigint,
+ source varchar(100),
+ item varchar(200),
+ item_name varchar(200),
+ field_name varchar(200),
+ field_type int,
+ creator bigint,
+ create_time datetime,
+ update_time datetime,
+ delete_type int,
+ tenant_key varchar(10),
+ PRIMARY KEY (id)
+)
+GO
+
+
+CREATE TABLE hrsa_push_record
+(
+ id bigint NOT NULL,
+ name varchar(200),
+ setting_id bigint,
+ mode_id int,
+ table_name varchar(100),
+ acct_record_id bigint,
+ type int,
+ status int,
+ start_time datetime,
+ end_time datetime,
+ creator bigint,
+ create_time datetime,
+ update_time datetime,
+ delete_type int,
+ tenant_key varchar(10),
+ PRIMARY KEY (id)
+)
+GO
+
+CREATE TABLE hrsa_push_record_detail
+(
+ id bigint NOT NULL,
+ record_id bigint,
+ acct_emp_id bigint,
+ execute text,
+ execute_time datetime,
+ status int,
+ creator bigint,
+ create_time datetime,
+ update_time datetime,
+ delete_type int,
+ tenant_key varchar(10),
+ PRIMARY KEY (id)
+)
+GO
\ No newline at end of file
diff --git a/resource/sqlupgrade/SQLServer/sql202504020203.sql b/resource/sqlupgrade/SQLServer/sql202504020203.sql
new file mode 100644
index 000000000..312077f79
--- /dev/null
+++ b/resource/sqlupgrade/SQLServer/sql202504020203.sql
@@ -0,0 +1,5 @@
+alter table hrsa_push_record add fail_reason VARCHAR(4000)
+go
+
+alter table hrsa_push_record_detail add fail_reason VARCHAR(4000)
+go
\ No newline at end of file
diff --git a/resource/sqlupgrade/SQLServer/sql202504030103.sql b/resource/sqlupgrade/SQLServer/sql202504030103.sql
new file mode 100644
index 000000000..db030fdb3
--- /dev/null
+++ b/resource/sqlupgrade/SQLServer/sql202504030103.sql
@@ -0,0 +1,5 @@
+alter table hrsa_push_setting_item add sorted_index int
+go
+
+alter table hrsa_push_record_detail add data_id bigint
+go
\ No newline at end of file
diff --git a/resource/sqlupgrade/ST/sql202411190103.sql b/resource/sqlupgrade/ST/sql202411190103.sql
new file mode 100644
index 000000000..1ed27c6fd
--- /dev/null
+++ b/resource/sqlupgrade/ST/sql202411190103.sql
@@ -0,0 +1,70 @@
+CREATE TABLE hrsa_push_setting
+(
+ id NUMBER(38,0) primary key NOT NULL,
+ name varchar2(200),
+ able number,
+ salary_sob_ids varchar2(2000),
+ mode_id number,
+ mode_name varchar2(200),
+ table_name varchar2(200),
+ creator NUMBER(38,0),
+ create_time date,
+ update_time date,
+ delete_type number,
+ tenant_key varchar2(10)
+);
+/
+
+CREATE TABLE hrsa_push_setting_item
+(
+ id NUMBER(38,0) NOT NULL,
+ setting_id NUMBER(38,0),
+ source varchar2(100),
+ item varchar2(200),
+ item_name varchar2(200),
+ field_name varchar2(200),
+ field_type number,
+ creator NUMBER(38,0),
+ create_time date,
+ update_time date,
+ delete_type number,
+ tenant_key varchar2(10)
+);
+/
+
+CREATE TABLE hrsa_push_record
+(
+ id NUMBER(38,0) NOT NULL,
+ name varchar2(200),
+ setting_id NUMBER(38,0),
+ mode_id number,
+ table_name varchar2(100),
+ acct_record_id NUMBER(38,0),
+ type number,
+ status number,
+ start_time date,
+ end_time date,
+ creator NUMBER(38,0),
+ create_time date,
+ update_time date,
+ delete_type number,
+ tenant_key varchar2(10)
+);
+/
+
+CREATE TABLE hrsa_push_record_detail
+(
+ id NUMBER(38,0) NOT NULL,
+ record_id NUMBER(38,0),
+ acct_emp_id NUMBER(38,0),
+ execute CLOB,
+ execute_time date,
+ status number,
+ creator NUMBER(38,0),
+ create_time date,
+ update_time date,
+ delete_type number,
+ tenant_key varchar2(10)
+);
+/
+
diff --git a/resource/sqlupgrade/ST/sql202504020203.sql b/resource/sqlupgrade/ST/sql202504020203.sql
new file mode 100644
index 000000000..d54eff0ca
--- /dev/null
+++ b/resource/sqlupgrade/ST/sql202504020203.sql
@@ -0,0 +1,6 @@
+ALTER TABLE hrsa_push_record ADD fail_reason varchar2(4000);
+/
+
+ALTER TABLE hrsa_push_record_detail ADD fail_reason varchar2(4000);
+/
+
diff --git a/resource/sqlupgrade/ST/sql202504030103.sql b/resource/sqlupgrade/ST/sql202504030103.sql
new file mode 100644
index 000000000..013d261c1
--- /dev/null
+++ b/resource/sqlupgrade/ST/sql202504030103.sql
@@ -0,0 +1,6 @@
+ALTER TABLE hrsa_push_setting_item ADD sorted_index NUMBER;
+/
+
+ALTER TABLE hrsa_push_record_detail ADD data_id NUMBER(38,0);
+/
+
diff --git a/src/com/engine/salary/entity/push/dto/PushRecordDTO.java b/src/com/engine/salary/entity/push/dto/PushRecordDTO.java
index af5dd4d2a..74df0f8d4 100644
--- a/src/com/engine/salary/entity/push/dto/PushRecordDTO.java
+++ b/src/com/engine/salary/entity/push/dto/PushRecordDTO.java
@@ -3,6 +3,7 @@ package com.engine.salary.entity.push.dto;
import com.engine.hrmelog.annotation.ElogTransform;
import com.engine.salary.annotation.TableTitle;
import com.engine.salary.enums.push.PushRecordStatusEnum;
+import com.fasterxml.jackson.annotation.JsonFormat;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
@@ -50,7 +51,7 @@ public class PushRecordDTO {
/**
* 数据库表名
*/
- @TableTitle(title = "记录名", dataIndex = "name", key = "name")
+ @TableTitle(title = "数据表名", dataIndex = "tableName", key = "tableName")
private String tableName;
@@ -59,56 +60,53 @@ public class PushRecordDTO {
*
* @see PushRecordStatusEnum
*/
- @TableTitle(title = "推送状态", dataIndex = "status", key = "status")
+ @TableTitle(title = "推送状态", dataIndex = "statusName", key = "statusName")
+ private String statusName;
private Integer status;
/**
* 执行时间
*/
- @TableTitle(title = "执行时间", dataIndex = "startTime", key = "startTime")
+ @TableTitle(title = "执行开始时间", dataIndex = "startTime", key = "startTime")
+ @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
private Date startTime;
/**
* 结束时间
*/
- @ElogTransform(name = "结束时间")
+ @TableTitle(title = "执行结束时间", dataIndex = "endTime", key = "endTime")
+ @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
private Date endTime;
/**
* 推送类型,0推送,1撤回
*/
- @ElogTransform(name = "推送类型")
private Integer type;
/**
* 创建时间
*/
- @ElogTransform(name = "创建时间")
private Date createTime;
/**
* 创建人
*/
- @ElogTransform(name = "创建人")
private Long creator;
/**
* 是否已删除。0:未删除、1:已删除
*/
- @ElogTransform(name = "是否已删除。0:未删除、1:已删除")
private Integer deleteType;
/**
* 租户ID
*/
- @ElogTransform(name = "租户ID")
private String tenantKey;
/**
* 更新时间
*/
- @ElogTransform(name = "更新时间")
private Date updateTime;
diff --git a/src/com/engine/salary/entity/push/dto/PushRecordDetailDTO.java b/src/com/engine/salary/entity/push/dto/PushRecordDetailDTO.java
index 2807eaf69..de9d56fe5 100644
--- a/src/com/engine/salary/entity/push/dto/PushRecordDetailDTO.java
+++ b/src/com/engine/salary/entity/push/dto/PushRecordDetailDTO.java
@@ -33,18 +33,22 @@ public class PushRecordDetailDTO {
*/
private Long acctEmpId;
+ @TableTitle(title = "人员", dataIndex = "username",key = "username")
+ private String username;
+
/**
* 执行状态
* @see com.engine.salary.enums.push.PushRecordDetailStatusEnum
*/
- @TableTitle(title = "执行状态", dataIndex = "status",key = "status")
+ @TableTitle(title = "执行状态", dataIndex = "statusName",key = "statusName")
+ private String statusName;
private Integer status;
/**
* 失败原因
*/
@TableTitle(title = "失败原因", dataIndex = "fail_reason",key = "status")
- private String fail_reason;
+ private String failReason;
/**
* 执行sql
diff --git a/src/com/engine/salary/entity/push/dto/PushSettingItemDTO.java b/src/com/engine/salary/entity/push/dto/PushSettingItemDTO.java
index a45d4635f..22c8832d6 100644
--- a/src/com/engine/salary/entity/push/dto/PushSettingItemDTO.java
+++ b/src/com/engine/salary/entity/push/dto/PushSettingItemDTO.java
@@ -59,4 +59,7 @@ public class PushSettingItemDTO {
@TableTitle(title = "字段类型", dataIndex = "fieldTypeName", key = "fieldTypeName")
private String fieldTypeName;
+ @TableTitle(title = "排序", dataIndex = "sortedIndex", key = "sortedIndex")
+ private Integer sortedIndex;
+
}
\ No newline at end of file
diff --git a/src/com/engine/salary/entity/push/param/CreatePushParam.java b/src/com/engine/salary/entity/push/param/CreatePushParam.java
new file mode 100644
index 000000000..5ef10fef4
--- /dev/null
+++ b/src/com/engine/salary/entity/push/param/CreatePushParam.java
@@ -0,0 +1,29 @@
+package com.engine.salary.entity.push.param;
+
+import lombok.AllArgsConstructor;
+import lombok.Builder;
+import lombok.Data;
+import lombok.NoArgsConstructor;
+
+import java.util.List;
+
+
+/**
+ * 创建推送记录
+ *
Copyright: Copyright (c) 2024
+ * Company: 泛微软件
+ *
+ * @author qiantao
+ * @version 1.0
+ **/
+@Data
+@Builder
+@NoArgsConstructor
+@AllArgsConstructor
+public class CreatePushParam {
+
+
+ private List salaryAcctRecordIds;
+
+
+}
\ No newline at end of file
diff --git a/src/com/engine/salary/entity/push/param/PushParam.java b/src/com/engine/salary/entity/push/param/PushParam.java
index 24f8c257e..f653c639b 100644
--- a/src/com/engine/salary/entity/push/param/PushParam.java
+++ b/src/com/engine/salary/entity/push/param/PushParam.java
@@ -13,6 +13,8 @@ import lombok.NoArgsConstructor;
public class PushParam {
+ private Long id;
+
private Long salaryAcctRecordId;
diff --git a/src/com/engine/salary/entity/push/param/PushSettingItemSaveParam.java b/src/com/engine/salary/entity/push/param/PushSettingItemSaveParam.java
index 57f46c330..d095b9697 100644
--- a/src/com/engine/salary/entity/push/param/PushSettingItemSaveParam.java
+++ b/src/com/engine/salary/entity/push/param/PushSettingItemSaveParam.java
@@ -59,6 +59,11 @@ public class PushSettingItemSaveParam {
@DataCheck(require = true, message = "字段类型为空")
private PushItemFieldEnum fieldType;
+ /**
+ * 排序
+ */
+ private Integer sortedIndex;
+
//主键id集合
private Collection ids;
diff --git a/src/com/engine/salary/entity/push/po/PushRecordDetailPO.java b/src/com/engine/salary/entity/push/po/PushRecordDetailPO.java
index 64e27ed08..f971532e6 100644
--- a/src/com/engine/salary/entity/push/po/PushRecordDetailPO.java
+++ b/src/com/engine/salary/entity/push/po/PushRecordDetailPO.java
@@ -34,6 +34,11 @@ public class PushRecordDetailPO {
@ElogTransform(name = "核算人员id")
private Long acctEmpId;
+ /**
+ * 核算人员id
+ */
+ private Long dataId;
+
/**
* 执行状态
* @see com.engine.salary.enums.push.PushRecordDetailStatusEnum
@@ -45,7 +50,7 @@ public class PushRecordDetailPO {
* 失败原因
*/
@ElogTransform(name = "失败原因")
- private String fail_reason;
+ private String failReason;
/**
* 执行sql
diff --git a/src/com/engine/salary/entity/push/po/PushRecordPO.java b/src/com/engine/salary/entity/push/po/PushRecordPO.java
index 6101e4b18..a0ed7080a 100644
--- a/src/com/engine/salary/entity/push/po/PushRecordPO.java
+++ b/src/com/engine/salary/entity/push/po/PushRecordPO.java
@@ -64,7 +64,7 @@ public class PushRecordPO {
* 失败原因
*/
@ElogTransform(name = "失败原因")
- private String fail_reason;
+ private String failReason;
/**
* 开始时间
diff --git a/src/com/engine/salary/entity/push/po/PushSettingItemPO.java b/src/com/engine/salary/entity/push/po/PushSettingItemPO.java
index ad7f97da1..71b16e335 100644
--- a/src/com/engine/salary/entity/push/po/PushSettingItemPO.java
+++ b/src/com/engine/salary/entity/push/po/PushSettingItemPO.java
@@ -62,6 +62,10 @@ public class PushSettingItemPO {
@ElogTransform(name = "字段类型")
private Integer fieldType;
+
+ @ElogTransform(name = "排序")
+ private Integer sortedIndex;
+
/**
* 租户ID
*/
diff --git a/src/com/engine/salary/enums/push/PushRecordDetailStatusEnum.java b/src/com/engine/salary/enums/push/PushRecordDetailStatusEnum.java
index 47245a544..c2d677d42 100644
--- a/src/com/engine/salary/enums/push/PushRecordDetailStatusEnum.java
+++ b/src/com/engine/salary/enums/push/PushRecordDetailStatusEnum.java
@@ -17,7 +17,8 @@ public enum PushRecordDetailStatusEnum implements BaseEnum {
PREPARE(0, "待推送", 87625),
SUCCESS(1, "推送成功", 85393),
FAIL(2, "推送失败", 85393),
- WITHDRAW(3, "已撤回", 85393);
+ WITHDRAW_SUCCESS(3, "已撤回", 85393),
+ WITHDRAW_FAIL(4, "撤回失败", 85393);
private int value;
@@ -52,7 +53,7 @@ public enum PushRecordDetailStatusEnum implements BaseEnum {
return salaryDataSourceEnum;
}
}
- return null;
+ return PREPARE;
}
public static String getDefaultLabelByValue(Integer value) {
diff --git a/src/com/engine/salary/enums/push/PushRecordStatusEnum.java b/src/com/engine/salary/enums/push/PushRecordStatusEnum.java
index 7b537e28e..3e3ea14c4 100644
--- a/src/com/engine/salary/enums/push/PushRecordStatusEnum.java
+++ b/src/com/engine/salary/enums/push/PushRecordStatusEnum.java
@@ -14,13 +14,14 @@ import java.util.Objects;
* @version 1.0
**/
public enum PushRecordStatusEnum implements BaseEnum {
- DATA_PREPARE(0, "数据构建", 87625),
- DATA_FINISH(1, "构建完毕", 87625),
- RUN_WAITING(2, "等待执行", 87625),
- RUN_PROGRESS(3, "执行中", 85393),
- RUN_COMPLETE(4, "执行完毕", 85393),
- RUN_SUCCESS(5, "执行成功", 85393),
- RUN_FAIL(6, "执行失败", 85393);
+ DATA_PREPARE(0, "准备中", 87625),
+ DATA_FINISH(1, "准备完毕", 87625),
+ RUN_PROGRESS(2, "推送中", 85393),
+ RUN_SUCCESS(3, "推送成功", 85393),
+ RUN_FAIL(4, "推送失败", 85393),
+ WITHDRAW(5, "撤回中", 85393),
+ WITHDRAW_SUCCESS(6, "已撤回", 85393),
+ WITHDRAW_FAIL(7, "撤回失败", 85393);
private int value;
@@ -55,7 +56,7 @@ public enum PushRecordStatusEnum implements BaseEnum {
return salaryDataSourceEnum;
}
}
- return null;
+ return DATA_PREPARE;
}
public static String getDefaultLabelByValue(Integer value) {
diff --git a/src/com/engine/salary/mapper/push/PushRecordDetailMapper.java b/src/com/engine/salary/mapper/push/PushRecordDetailMapper.java
index 5ad4a105f..1c63a36c2 100644
--- a/src/com/engine/salary/mapper/push/PushRecordDetailMapper.java
+++ b/src/com/engine/salary/mapper/push/PushRecordDetailMapper.java
@@ -1,5 +1,6 @@
package com.engine.salary.mapper.push;
+import com.engine.salary.entity.push.dto.PushRecordDetailDTO;
import com.engine.salary.entity.push.po.PushRecordDetailPO;
import org.apache.ibatis.annotations.Param;
@@ -21,7 +22,9 @@ public interface PushRecordDetailMapper {
* @return 返回集合,没有返回空List
*/
List listSome(PushRecordDetailPO pushRecordDetail);
-
+
+ List listDTO(PushRecordDetailDTO dto);
+
/**
* 根据主键查询
diff --git a/src/com/engine/salary/mapper/push/PushRecordDetailMapper.xml b/src/com/engine/salary/mapper/push/PushRecordDetailMapper.xml
index ecbeef0cd..bdbee38fc 100644
--- a/src/com/engine/salary/mapper/push/PushRecordDetailMapper.xml
+++ b/src/com/engine/salary/mapper/push/PushRecordDetailMapper.xml
@@ -12,6 +12,8 @@
+
+
@@ -28,6 +30,8 @@
, t.status
, t.tenant_key
, t.update_time
+ , t.fail_reason
+ , t.data_id
@@ -88,6 +92,54 @@
#{id}
+ ORDER BY id DESC
+
+
+
@@ -127,6 +179,12 @@
update_time,
+
+ fail_reason,
+
+
+ data_id,
+
@@ -159,6 +217,12 @@
#{updateTime},
+
+ #{failReason},
+
+
+ #{dataId},
+
@@ -175,6 +239,8 @@
status=#{status},
tenant_key=#{tenantKey},
update_time=#{updateTime},
+ fail_reason=#{failReason},
+ data_id=#{dataId},
WHERE id = #{id} AND delete_type = 0
@@ -211,6 +277,12 @@
update_time=#{updateTime},
+
+ fail_reason=#{failReason},
+
+
+ data_id=#{dataId},
+
WHERE id = #{id} AND delete_type = 0
diff --git a/src/com/engine/salary/mapper/push/PushRecordMapper.xml b/src/com/engine/salary/mapper/push/PushRecordMapper.xml
index 7009997ee..48e1a2765 100644
--- a/src/com/engine/salary/mapper/push/PushRecordMapper.xml
+++ b/src/com/engine/salary/mapper/push/PushRecordMapper.xml
@@ -3,18 +3,21 @@
+
+
+
-
-
-
-
+
+
+
+
@@ -34,6 +37,9 @@
, t.tenant_key
, t.type
, t.update_time
+ , t.fail_reason
+ , t.start_time
+ , t.end_time
@@ -98,6 +104,15 @@
AND update_time = #{updateTime}
+
+ AND fail_reason = #{failReason}
+
+
+ AND start_time = #{startTime}
+
+
+ AND end_time = #{endTime}
+
AND id IN
@@ -152,6 +167,15 @@
update_time,
+
+ fail_reason,
+
+
+ start_time,
+
+
+ end_time,
+
@@ -193,6 +217,15 @@
#{updateTime},
+
+ #{failReason},
+
+
+ #{startTime},
+
+
+ #{endTime},
+
@@ -212,6 +245,9 @@
tenant_key=#{tenantKey},
type=#{type},
update_time=#{updateTime},
+ fail_reason=#{failReason},
+ start_time=#{startTime},
+ end_time=#{endTime},
WHERE id = #{id} AND delete_type = 0
@@ -257,6 +293,15 @@
update_time=#{updateTime},
+
+ fail_reason=#{failReason},
+
+
+ start_time=#{startTime},
+
+
+ end_time=#{endTime},
+
WHERE id = #{id} AND delete_type = 0
diff --git a/src/com/engine/salary/mapper/push/PushSettingItemMapper.xml b/src/com/engine/salary/mapper/push/PushSettingItemMapper.xml
index f708ed48c..2c5322940 100644
--- a/src/com/engine/salary/mapper/push/PushSettingItemMapper.xml
+++ b/src/com/engine/salary/mapper/push/PushSettingItemMapper.xml
@@ -12,6 +12,7 @@
+
@@ -32,6 +33,7 @@
, t.setting_id
, t.tenant_key
, t.update_time
+ , t.sorted_index
@@ -40,6 +42,7 @@
FROM hrsa_push_setting_item t
WHERE delete_type = 0
+ ORDER BY sorted_index DESC
@@ -85,6 +88,9 @@
AND setting_id = #{settingId}
+
+
+ AND sorted_index = #{sortedIndex}
AND tenant_key = #{tenantKey}
@@ -98,7 +104,7 @@
#{id}
- ORDER BY id DESC
+ ORDER BY sorted_index DESC
@@ -137,6 +143,9 @@
setting_id,
+
+ sorted_index,
+
tenant_key,
@@ -175,6 +184,9 @@
#{settingId},
+
+ #{sortedIndex},
+
#{tenantKey},
@@ -197,6 +209,7 @@
item_name=#{itemName},
source=#{source},
setting_id=#{settingId},
+ sorted_index=#{sortedIndex},
tenant_key=#{tenantKey},
update_time=#{updateTime},
@@ -235,6 +248,9 @@
setting_id=#{settingId},
+
+ sorted_index=#{sortedIndex},
+
tenant_key=#{tenantKey},
diff --git a/src/com/engine/salary/service/PushService.java b/src/com/engine/salary/service/PushService.java
index e84690d73..59a6f311d 100644
--- a/src/com/engine/salary/service/PushService.java
+++ b/src/com/engine/salary/service/PushService.java
@@ -58,19 +58,18 @@ public interface PushService {
*/
void deleteItem(Long id);
- /**
- * 推送一条核算记录下的所有数据
- *
- * @param salaryAcctRecordId
- * @return
- */
- void pushOneRecord(Long salaryAcctRecordId);
-
void createPushRecord(Long salaryAcctRecordId);
+ void withdrawPushRecord(Long salaryAcctRecordId);
+
+ void push(Long id);
+
+ void withdraw(Long id);
+
void removeRecords(List records);
PageInfo recordList(RecordListQueryParam param);
PageInfo recordDetailList(RecordDetailListQueryParam param);
+
}
diff --git a/src/com/engine/salary/service/impl/PushServiceImpl.java b/src/com/engine/salary/service/impl/PushServiceImpl.java
index 214eae1a3..ac7a8902e 100644
--- a/src/com/engine/salary/service/impl/PushServiceImpl.java
+++ b/src/com/engine/salary/service/impl/PushServiceImpl.java
@@ -1,5 +1,6 @@
package com.engine.salary.service.impl;
+import cn.hutool.core.collection.CollUtil;
import cn.hutool.core.util.StrUtil;
import com.engine.common.util.ServiceUtil;
import com.engine.core.impl.Service;
@@ -190,6 +191,7 @@ public class PushServiceImpl extends Service implements PushService {
.fieldName(po.getFieldName())
.fieldType(PushItemFieldEnum.parseByValue(po.getFieldType()))
.fieldTypeName(PushItemFieldEnum.parseByValue(po.getFieldType()).getDefaultLabel())
+ .sortedIndex(po.getSortedIndex())
.build()
).collect(Collectors.toList());
@@ -211,6 +213,7 @@ public class PushServiceImpl extends Service implements PushService {
.source(param.getSource())
.fieldName(param.getFieldName())
.fieldType(param.getFieldType().getValue())
+ .sortedIndex(param.getSortedIndex())
.creator((long) user.getUID())
.createTime(now)
.updateTime(now)
@@ -231,6 +234,7 @@ public class PushServiceImpl extends Service implements PushService {
po.setSource(param.getSource());
po.setFieldName(param.getFieldName());
po.setFieldType(param.getFieldType().getValue());
+ po.setSortedIndex(param.getSortedIndex());
po.setUpdateTime(now);
getPushSettingItemMapper().update(po);
@@ -245,120 +249,6 @@ public class PushServiceImpl extends Service implements PushService {
getPushSettingItemMapper().delete(PushSettingItemPO.builder().id(id).build());
}
- @Override
- public void pushOneRecord(Long salaryAcctRecordId) {
-
- SalaryAcctRecordPO salaryAcctRecordPO = getSalaryAcctRecordService(user).getById(salaryAcctRecordId);
-
- if (salaryAcctRecordPO == null) {
- throw new SalaryRunTimeException("核算记录不存在!");
- }
-
- //查询核算人员
- List salaryAcctEmployeePOS = getSalaryAcctEmployeeService(user).listBySalaryAcctRecordId(salaryAcctRecordPO.getId());
-
- //薪资项目
- List salaryItemPOS = getSalaryItemService(user).listAll();
- //查询薪资核算记录的薪资周期、考勤周期等
- SalarySobCycleDTO salarySobCycleDTO = getSalaryAcctRecordService(user).getSalarySobCycleById(salaryAcctRecordPO.getId());
-
- SalaryAcctCalculateBO salaryAcctCalculateBO = new SalaryAcctCalculateBO()
- .setSalaryAcctRecordPO(salaryAcctRecordPO)
- .setSalarySobPO(new SalarySobPO())
- .setSalarySobCycleDTO(salarySobCycleDTO)
- .setOtherSalaryAcctRecordPOS(new ArrayList<>())
- .setSalarySobItemPOS(new ArrayList<>())
- .setSalaryItemIdWithPriorityList(new ArrayList<>())
- .setExpressFormulas(new ArrayList<>())
- .setSalaryItemPOS(salaryItemPOS)
- .setSalarySobAdjustRulePOS(new ArrayList<>())
- .setWelfareColumns(new HashMap<>())
- .setAttendQuoteFieldListDTOS(new ArrayList<>())
- .setSalaryAcctEmployeePOS(salaryAcctEmployeePOS)
- .setIssuedFieldIds(new HashSet<>())
- .setChildMonitor(null)
- .setResults(null)
- .setCalculateKey(null)
- .setVariableItems(new ArrayList<>())
- .setTaxDeclarationFunction(TaxDeclarationFunctionEnum.OPEN);
-
-
- List employeeIds = SalaryEntityUtil.properties(salaryAcctCalculateBO.getSalaryAcctEmployeePOS(), SalaryAcctEmployeePO::getEmployeeId, Collectors.toList());
- List simpleEmployees = getSalaryEmployeeService(user).getEmployeeByIdsAll(employeeIds);
-
- List salaryAcctEmployeeIds = SalaryEntityUtil.properties(salaryAcctCalculateBO.getSalaryAcctEmployeePOS(), SalaryAcctEmployeePO::getId, Collectors.toList());
- List salaryAcctResultPOS = getSalaryAcctResultService(user).listBySalaryAcctEmployeeIds(salaryAcctEmployeeIds);
-
- CalculateFormulaVarBO calculateFormulaVarBO = new CalculateFormulaVarBO(simpleEmployees, new ArrayList<>(), new ArrayList<>(), new ArrayList<>(), new ArrayList<>(), new ArrayList<>(), new ArrayList<>(), salaryAcctResultPOS, new ArrayList<>(),new ArrayList<>());
- Map> formulaVarMap = calculateFormulaVarBO.convert2FormulaVar(salaryAcctCalculateBO);
-
-
- List pushSettingPOS = getPushSettingMapper().listSome(PushSettingPO.builder().able(1).build());
- pushSettingPOS.stream()
- .filter(po -> po.getSalarySobIds().contains(salaryAcctRecordPO.getSalarySobId()))
- .forEach(setting -> {
-
- Long id = setting.getId();
- List pushSettingItemPOS = getPushSettingItemMapper().listSome(PushSettingItemPO.builder().settingId(id).build());
-
-
- //每个人插入一条
- for (SalaryAcctEmployeePO emp : salaryAcctEmployeePOS) {
- //1 获取当前薪资核算人员的公式中的变量的值
- List formulaVarValues = formulaVarMap.get(emp.getEmployeeId() + "_" + emp.getTaxAgentId());
- //2 人员信息
- List empInfo = formulaVarMap.get(emp.getEmployeeId() + "");
- formulaVarValues.addAll(empInfo);
- Map formulaVarValueMap = SalaryEntityUtil.convert2Map(formulaVarValues, CalculateFormulaVarBO.FormulaVarValue::getFieldId, CalculateFormulaVarBO.FormulaVarValue::getFieldValue);
-
- Integer modeId = setting.getModeId();
-
- List fields = new ArrayList() {{
- add("formmodeid");
- add("modedatacreater");
- add("modedatacreatertype");
- add("modedatacreatedate");
- add("modedatacreatetime");
- }};
- String currDate = TimeUtil.getCurrentDateString();
- SimpleDateFormat sdf = new SimpleDateFormat("HH:mm:ss");
- String currTime = sdf.format(new Date());
- List