You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

116 lines
3.2 KiB

/*
* @desc:岗位处理
*
*
* @Date: 2022/4/7 23:18
*/
package service
import (
"context"
"github.com/gogf/gf/v2/frame/g"
"github.com/gogf/gf/v2/util/gconv"
"tyj_admin/api/v1/system"
"tyj_admin/internal/consts"
"tyj_admin/internal/dao"
"tyj_admin/internal/model/do"
"tyj_admin/internal/model/entity"
"tyj_admin/library/liberr"
)
type IPost interface {
List(ctx context.Context, req *system.PostSearchReq) (res *system.PostSearchRes, err error)
Add(ctx context.Context, req *system.PostAddReq) (err error)
Edit(ctx context.Context, req *system.PostEditReq) (err error)
Delete(ctx context.Context, ids []int) (err error)
GetUsedPost(ctx context.Context) (list []*entity.SysPost, err error)
}
type postImpl struct {
}
var postService = postImpl{}
func Post() IPost {
return &postService
}
// List 岗位列表
func (s *postImpl) List(ctx context.Context, req *system.PostSearchReq) (res *system.PostSearchRes, err error) {
res = new(system.PostSearchRes)
err = g.Try(ctx, func(ctx context.Context) {
m := dao.SysPost.Ctx(ctx)
if req != nil {
if req.PostCode != "" {
m = m.Where("post_code like ?", "%"+req.PostCode+"%")
}
if req.PostName != "" {
m = m.Where("post_name like ?", "%"+req.PostName+"%")
}
if req.Status != "" {
m = m.Where("status", gconv.Uint(req.Status))
}
}
res.Total, err = m.Count()
liberr.ErrIsNil(ctx, err, "获取岗位失败")
if req.PageNum == 0 {
req.PageNum = 1
}
if req.PageSize == 0 {
req.PageSize = consts.PageSize
}
res.CurrentPage = req.PageNum
err = m.Page(req.PageNum, req.PageSize).Order("post_sort asc,post_id asc").Scan(&res.PostList)
liberr.ErrIsNil(ctx, err, "获取岗位失败")
})
return
}
func (s *postImpl) Add(ctx context.Context, req *system.PostAddReq) (err error) {
err = g.Try(ctx, func(ctx context.Context) {
_, err = dao.SysPost.Ctx(ctx).Insert(do.SysPost{
PostCode: req.PostCode,
PostName: req.PostName,
PostSort: req.PostSort,
Status: req.Status,
Remark: req.Remark,
CreatedBy: Context().GetUserId(ctx),
})
liberr.ErrIsNil(ctx, err, "添加岗位失败")
})
return
}
func (s *postImpl) Edit(ctx context.Context, req *system.PostEditReq) (err error) {
err = g.Try(ctx, func(ctx context.Context) {
_, err = dao.SysPost.Ctx(ctx).WherePri(req.PostId).Update(do.SysPost{
PostCode: req.PostCode,
PostName: req.PostName,
PostSort: req.PostSort,
Status: req.Status,
Remark: req.Remark,
UpdatedBy: Context().GetUserId(ctx),
})
liberr.ErrIsNil(ctx, err, "修改岗位失败")
})
return
}
func (s *postImpl) Delete(ctx context.Context, ids []int) (err error) {
err = g.Try(ctx, func(ctx context.Context) {
_, err = dao.SysPost.Ctx(ctx).Where(dao.SysPost.Columns().PostId+" in(?)", ids).Delete()
liberr.ErrIsNil(ctx, err, "删除失败")
})
return
}
// GetUsedPost 获取正常状态的岗位
func (s *postImpl) GetUsedPost(ctx context.Context) (list []*entity.SysPost, err error) {
err = g.Try(ctx, func(ctx context.Context) {
err = dao.SysPost.Ctx(ctx).Where(dao.SysPost.Columns().Status, 1).
Order(dao.SysPost.Columns().PostSort + " ASC, " + dao.SysPost.Columns().PostId + " ASC ").Scan(&list)
liberr.ErrIsNil(ctx, err, "获取岗位数据失败")
})
return
}