123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596 |
- package worknode
- import (
- "errors"
- "zhiyuan/models"
- "zhiyuan/pkg/app"
- "zhiyuan/pkg/db"
- "zhiyuan/services/form"
- )
- var WorkNode models.WorkNode
- func Add(form form.WorkNodeAdd) (int64, error) {
- if CheckWorkNodeDuplicate(form.Name) {
- return 0, errors.New("节点已存在")
- }
- workNodeMap := map[string]interface{}{
- "`name`": form.Name,
- "`color`": form.Color,
- "`logo`": form.Logo,
- "`work_type_id`": form.WorkTypeId,
- "`designer_presence`": form.DesignerPresence,
- "`quality_accept`": form.QualityAccept,
- "`state`": form.State,
- }
- workNodeID, err := db.InsertOne(WorkNode.TableName(), workNodeMap)
- if err != nil {
- return 0, nil
- }
- return workNodeID, nil
- }
- func EditByID(form form.WorkNodeAdd, id int) error {
- info, err := GetInfoByID(id, nil, nil)
- if info == nil {
- return errors.New("invalid id")
- }
- if info.Name != form.Name && CheckWorkNodeDuplicate(form.Name) {
- return errors.New("节点已存在")
- }
- workNodeMap := map[string]interface{}{
- "`name`": form.Name,
- "`color`": form.Color,
- "`logo`": form.Logo,
- "`work_type_id`": form.WorkTypeId,
- "`designer_presence`": form.DesignerPresence,
- "`quality_accept`": form.QualityAccept,
- "`state`": form.State,
- }
- _, err = db.Update(WorkNode.TableName(), map[string]interface{}{"id": id}, workNodeMap)
- return err
- }
- func DeleteByID(id int) error {
- info, _ := GetInfoByID(id, nil, nil)
- if info == nil {
- return errors.New("invalid id")
- }
- _, err := db.DeleteSoft(WorkNode.TableName(), map[string]interface{}{"id": id})
- return err
- }
- func Count(where map[string]interface{}) (int64, error) {
- return db.Count(WorkNode.TableName(), where)
- }
- func CountRaw(where string, param map[string]interface{}) (int64, error) {
- query := "`zy_work_node` WHERE " + where
- return db.CountRaw(query, param)
- }
- func GetList(where map[string]interface{}, fields []string, page app.Page, retVal interface{}) ([]*models.WorkNode, error) {
- if page.PageNum > 0 && page.PageSize > 0 {
- where["_limit"] = db.GetOffset(uint(page.PageNum), uint(page.PageSize))
- }
- return WorkNode.GetMulti(where, fields, retVal)
- }
- func GetWorkNodesRaw(where map[string]string, param map[string]interface{}, retVal interface{}) error {
- field := "SELECT `zy_work_node`.*, `zy_work_type`.`name` as `work_type_name` FROM `zy_work_node` left join `zy_work_type` on `zy_work_type`.`id` = `zy_work_node`.`work_type_id` "
- return db.GetMultiRaw(field, where, param, retVal)
- }
- func GetOne(where map[string]interface{}, fields []string, retVal interface{}) (*models.WorkNode, error) {
- return WorkNode.GetOne(where, fields, retVal)
- }
- func GetInfoByID(id int, fields []string, retVal interface{}) (*models.WorkNode, error) {
- return GetOne(map[string]interface{}{"id": id}, fields, retVal)
- }
- func CheckWorkNodeDuplicate(name string) bool {
- workNodeInfo, err := GetOne(map[string]interface{}{"name": name, "deleted_at": 0}, nil, nil)
- return workNodeInfo != nil && err == nil
- }
|