enterprise/worker/staff.go

163 lines
5.3 KiB
Go
Raw Normal View History

2023-08-31 22:20:40 +08:00
package worker
import (
"enterprise/common/dao"
2023-10-08 21:22:49 +08:00
"enterprise/common/global"
2023-08-31 22:20:40 +08:00
"enterprise/common/model"
2024-11-04 23:00:55 +08:00
"enterprise/service"
2023-10-08 21:22:49 +08:00
"fmt"
2023-08-31 22:20:40 +08:00
log "github.com/sirupsen/logrus"
2023-09-01 20:01:30 +08:00
"github.com/smbrave/goutil"
2023-08-31 22:20:40 +08:00
"github.com/spf13/cast"
2023-09-01 20:01:30 +08:00
"strings"
"time"
2023-08-31 22:20:40 +08:00
)
2024-01-07 17:17:33 +08:00
type Staff struct {
}
2025-03-11 00:49:14 +08:00
func NewStaff() *Staff {
return &Staff{}
}
2025-03-04 23:14:09 +08:00
func (s *Staff) MontorWorkAge(corpId int64) {
2025-03-11 17:06:52 +08:00
staffs, _, err := dao.NewStaffUserDao().Query(1, -1, corpId, model.StaffUserStatusOnline, "", "", "", "")
2024-09-21 18:46:51 +08:00
if err != nil {
log.Errorf("db error :%s", err.Error())
return
}
nowDate := time.Now()
for _, staff := range staffs {
//离职的忽略
if staff.LeaveDate != "" {
continue
}
entryDate, _ := time.ParseInLocation("2006-01-02", staff.EntryDate, time.Local)
2024-12-03 12:45:34 +08:00
OfficialDate, _ := time.ParseInLocation("2006-01-02", staff.OfficialDate, time.Local)
2024-09-21 18:46:51 +08:00
2024-12-03 12:45:34 +08:00
entryMonth := (nowDate.Year()-entryDate.Year())*12 + int(nowDate.Month()) - int(entryDate.Month())
2024-12-04 14:04:52 +08:00
officalDay := (OfficialDate.Unix() - nowDate.Unix()) / 86400
2024-12-03 12:45:34 +08:00
log.Infof("staff[%s] entryDate[%s] spanMonth[%.1f]", staff.Username, staff.EntryDate, float64(entryMonth)/12.0)
2025-03-04 23:14:09 +08:00
salary := staff.GetSalary()
2024-12-03 12:45:34 +08:00
if nowDate.Day() == 1 && entryMonth%6 == 0 {
message := make([]string, 0)
message = append(message, fmt.Sprintf("【员工半年提醒】[%s]", staff.Realname))
message = append(message, fmt.Sprintf("入职时间:%s", staff.EntryDate))
message = append(message, fmt.Sprintf("入职年限:%.1f", float64(entryMonth)/12))
2025-03-04 23:14:09 +08:00
message = append(message, fmt.Sprintf("基本工资:%s", salary.Base))
message = append(message, fmt.Sprintf("绩效工资:%s", salary.Target))
2024-12-03 12:45:34 +08:00
message = append(message, fmt.Sprintf("身份证号:%s", staff.Idno))
if err := global.SendMessage([]string{"jiangyong"}, strings.Join(message, "\n")); err != nil {
log.Errorf("send message error :%s", err.Error())
}
2024-09-21 18:46:51 +08:00
}
2024-12-03 12:45:34 +08:00
2024-12-04 14:04:52 +08:00
if officalDay > 0 && officalDay <= 30 && officalDay%7 == 0 {
2024-12-03 12:45:34 +08:00
message := make([]string, 0)
2024-12-04 14:05:20 +08:00
message = append(message, fmt.Sprintf("【员工转正提醒】[%s]", staff.Realname))
2024-12-03 12:45:34 +08:00
message = append(message, fmt.Sprintf("入职时间:%s", staff.EntryDate))
message = append(message, fmt.Sprintf("转正时间:%s", staff.OfficialDate))
2025-03-04 23:14:09 +08:00
message = append(message, fmt.Sprintf("基本工资:%s", salary.Base))
message = append(message, fmt.Sprintf("绩效工资:%s", salary.Target))
2024-12-03 12:45:34 +08:00
message = append(message, fmt.Sprintf("身份证号:%s", staff.Idno))
if err := global.SendMessage([]string{"jiangyong"}, strings.Join(message, "\n")); err != nil {
log.Errorf("send message error :%s", err.Error())
}
2024-09-21 18:46:51 +08:00
}
}
}
2025-03-04 23:14:09 +08:00
func (s *Staff) SendStaffSalaryBill(corpId int64, month string) {
2025-03-12 23:57:24 +08:00
staffSalarys, err := dao.NewStaffSalaryDao().QueryAll(corpId, month)
2023-10-08 21:22:49 +08:00
if err != nil {
log.Errorf("db error :%s", err.Error())
return
}
2025-03-04 23:14:09 +08:00
2023-10-08 21:22:49 +08:00
for _, staffSalary := range staffSalarys {
2025-03-04 23:14:09 +08:00
if staffSalary.Salary < 0.1 {
2023-10-08 21:22:49 +08:00
continue
}
2025-03-04 23:14:09 +08:00
user, err := dao.NewStaffUserDao().Get(staffSalary.UserId)
2024-04-07 17:08:39 +08:00
if err != nil {
log.Errorf("db error :%s", err.Error())
continue
}
2025-03-04 23:14:09 +08:00
2023-10-08 21:22:49 +08:00
message := make([]string, 0)
2025-03-04 23:14:09 +08:00
message = append(message, fmt.Sprintf("【工资单】[%s][%s]", user.Username, month))
message = append(message, fmt.Sprintf("基本工资:%.2f", staffSalary.Salary))
if staffSalary.AttendSalary >= 0.1 {
message = append(message, fmt.Sprintf("出勤工资:%.2f", staffSalary.AttendSalary))
}
2023-10-08 21:22:49 +08:00
if staffSalary.AwardSalary >= 0.1 {
2025-03-04 23:14:09 +08:00
message = append(message, fmt.Sprintf("奖金收入:%.2f", staffSalary.AwardSalary))
2023-10-08 21:22:49 +08:00
}
2025-03-04 23:14:09 +08:00
if staffSalary.OtherSalary >= 0.1 {
message = append(message, fmt.Sprintf("其他收入:%.2f", staffSalary.OtherSalary))
2024-11-05 12:44:09 +08:00
}
2025-03-04 23:14:09 +08:00
message = append(message, fmt.Sprintf("社保扣除:%.2f", staffSalary.SocialDeduct+staffSalary.HouseDeduct))
message = append(message, fmt.Sprintf("个税扣除:%.2f", staffSalary.PersonalDeduct))
message = append(message, fmt.Sprintf("实发工资:%.2f", staffSalary.GetRealSalary()))
2023-10-08 21:22:49 +08:00
if err := global.SendMessage([]string{"jiangyong"}, strings.Join(message, "\n")); err != nil {
log.Errorf("send message error :%s", err.Error())
}
2023-08-31 22:20:40 +08:00
}
}
2023-09-01 20:01:30 +08:00
2025-03-04 23:14:09 +08:00
func (s *Staff) SyncStaffSalary(corpId int64, month string) {
2023-09-04 19:14:02 +08:00
if month == "" {
month = time.Now().AddDate(0, -1, 0).Format("2006-01")
}
month = strings.ReplaceAll(month, "-", "")
2024-01-31 20:49:43 +08:00
2025-03-11 17:06:52 +08:00
staffs, _, err := dao.NewStaffUserDao().Query(1, -1, corpId, 0, "", "", "", "")
2024-01-31 20:49:43 +08:00
if err != nil {
2024-01-31 22:54:06 +08:00
log.Errorf("query staff db error :%s", err.Error())
2024-01-31 20:49:43 +08:00
return
}
2023-09-01 20:01:30 +08:00
for _, staff := range staffs {
2024-07-04 21:04:50 +08:00
// 已离职的员工不处理
2024-11-04 23:00:55 +08:00
if staff.LeaveDate != "" {
leaveTime, _ := time.ParseInLocation("2006-01-02", staff.LeaveDate, time.Local)
isLeaveMonth := goutil.If(cast.ToInt(leaveTime.Format("200601")) == cast.ToInt(month), true, false)
if !isLeaveMonth {
continue
}
2023-09-01 20:01:30 +08:00
}
2024-01-31 22:54:06 +08:00
2025-03-04 23:14:09 +08:00
salary, err := dao.NewStaffSalaryDao().GetBy(corpId, staff.Id, month)
2024-01-31 20:49:43 +08:00
if err != nil {
log.Errorf("db error :%s", err.Error())
continue
}
2024-11-01 13:19:45 +08:00
2025-03-04 23:14:09 +08:00
staffService := service.NewStaffSalary(staff)
salary, err = staffService.CalcSalary(salary, month)
if err != nil {
log.Errorf("username[%s] staffService.CalcSalary error :%s", staff.Username, err.Error())
continue
}
if salary == nil {
continue
2024-01-31 22:54:06 +08:00
}
2023-09-01 20:01:30 +08:00
if salary.Id == 0 {
_, err = dao.NewStaffSalaryDao().Create(salary)
} else {
err = dao.NewStaffSalaryDao().Update(salary)
}
if err != nil {
log.Errorf("db error :%s", err.Error())
}
}
}