v3_1
This commit is contained in:
@@ -3,19 +3,23 @@ package system
|
||||
import (
|
||||
"context"
|
||||
"encoding/json"
|
||||
"errors"
|
||||
"fmt"
|
||||
"strconv"
|
||||
"time"
|
||||
|
||||
"management/internal/db/model/dto"
|
||||
db "management/internal/db/sqlc"
|
||||
"management/internal/erpserver/model/form"
|
||||
"management/internal/erpserver/model/view"
|
||||
"management/internal/pkg/convertor"
|
||||
"management/internal/pkg/know"
|
||||
"management/internal/pkg/redis"
|
||||
)
|
||||
|
||||
type DepartmentBiz interface {
|
||||
Create(ctx context.Context, arg *db.CreateSysDepartmentParams) (*db.SysDepartment, error)
|
||||
Update(ctx context.Context, arg *db.UpdateSysDepartmentParams) (*db.SysDepartment, error)
|
||||
Create(ctx context.Context, req *form.Department) error
|
||||
Update(ctx context.Context, req *form.Department) error
|
||||
All(ctx context.Context) ([]*db.SysDepartment, error)
|
||||
List(ctx context.Context, q dto.SearchDto) ([]*db.SysDepartment, int64, error)
|
||||
Get(ctx context.Context, id int32) (*db.SysDepartment, error)
|
||||
@@ -96,12 +100,79 @@ func (b *departmentBiz) Get(ctx context.Context, id int32) (*db.SysDepartment, e
|
||||
return b.store.GetSysDepartment(ctx, id)
|
||||
}
|
||||
|
||||
func (b *departmentBiz) Create(ctx context.Context, arg *db.CreateSysDepartmentParams) (*db.SysDepartment, error) {
|
||||
return b.store.CreateSysDepartment(ctx, arg)
|
||||
func (b *departmentBiz) Create(ctx context.Context, req *form.Department) error {
|
||||
parent := &db.SysDepartment{
|
||||
ID: 0,
|
||||
ParentID: 0,
|
||||
ParentPath: ",0,",
|
||||
}
|
||||
if *req.ParentID > 0 {
|
||||
var err error
|
||||
parent, err = b.store.GetSysDepartment(ctx, *req.ParentID)
|
||||
if err != nil {
|
||||
return errors.New("父级节点错误")
|
||||
}
|
||||
}
|
||||
|
||||
var order int32 = 6666
|
||||
if *req.Sort > 0 {
|
||||
order = *req.Sort
|
||||
}
|
||||
|
||||
arg := &db.CreateSysDepartmentParams{
|
||||
Name: req.Name,
|
||||
ParentID: parent.ID,
|
||||
ParentPath: convertor.HandleParentPath(fmt.Sprintf("%s,%d,", parent.ParentPath, parent.ID)),
|
||||
Status: *req.Status,
|
||||
Sort: order,
|
||||
CreatedAt: time.Now(),
|
||||
UpdatedAt: time.Now(),
|
||||
}
|
||||
_, err := b.store.CreateSysDepartment(ctx, arg)
|
||||
if err != nil {
|
||||
if db.IsUniqueViolation(err) {
|
||||
return errors.New("部门已存在")
|
||||
}
|
||||
return err
|
||||
}
|
||||
return nil
|
||||
}
|
||||
|
||||
func (b *departmentBiz) Update(ctx context.Context, arg *db.UpdateSysDepartmentParams) (*db.SysDepartment, error) {
|
||||
return b.store.UpdateSysDepartment(ctx, arg)
|
||||
func (b *departmentBiz) Update(ctx context.Context, req *form.Department) error {
|
||||
parent := &db.SysDepartment{
|
||||
ID: 0,
|
||||
ParentID: 0,
|
||||
ParentPath: ",0,",
|
||||
}
|
||||
if *req.ParentID > 0 {
|
||||
var err error
|
||||
parent, err = b.store.GetSysDepartment(ctx, *req.ParentID)
|
||||
if err != nil {
|
||||
return errors.New("父级节点错误")
|
||||
}
|
||||
}
|
||||
|
||||
depart, err := b.store.GetSysDepartment(ctx, *req.ID)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
var order int32 = 6666
|
||||
if *req.Sort > 0 {
|
||||
order = *req.Sort
|
||||
}
|
||||
|
||||
arg := &db.UpdateSysDepartmentParams{
|
||||
ID: depart.ID,
|
||||
Name: req.Name,
|
||||
ParentID: parent.ID,
|
||||
ParentPath: convertor.HandleParentPath(fmt.Sprintf("%s,%d,", parent.ParentPath, parent.ID)),
|
||||
Status: *req.Status,
|
||||
Sort: order,
|
||||
UpdatedAt: time.Now(),
|
||||
}
|
||||
_, err = b.store.UpdateSysDepartment(ctx, arg)
|
||||
return err
|
||||
}
|
||||
|
||||
func (b *departmentBiz) Refresh(ctx context.Context) ([]*db.SysDepartment, error) {
|
||||
|
||||
Reference in New Issue
Block a user