workcraft.go 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. package workcraft
  2. import (
  3. "errors"
  4. "zhiyuan/models"
  5. "zhiyuan/pkg/app"
  6. "zhiyuan/pkg/db"
  7. "zhiyuan/services/form"
  8. )
  9. var WorkCraft models.WorkCraft
  10. func Add(form form.WorkCraftAdd) (int64, error) {
  11. if CheckWorkCraftDuplicate(form.NodeId, form.Name) {
  12. return 0, errors.New("工艺已存在")
  13. }
  14. workCraftMap := map[string]interface{}{
  15. "`node_id`": form.NodeId,
  16. "`name`": form.Name,
  17. "`cover`": form.Cover,
  18. "`pictures`": form.Pictures,
  19. "`purpose`": form.Purpose,
  20. "`content`": form.Content,
  21. "`state`": form.State,
  22. }
  23. workCraftID, err := db.InsertOne(WorkCraft.TableName(), workCraftMap)
  24. if err != nil {
  25. return 0, nil
  26. }
  27. return workCraftID, nil
  28. }
  29. func EditByID(form form.WorkCraftAdd, id int) error {
  30. info, err := GetInfoByID(id, nil, nil)
  31. if info == nil {
  32. return errors.New("invalid id")
  33. }
  34. if info.Name != form.Name && CheckWorkCraftDuplicate(form.NodeId, form.Name) {
  35. return errors.New("工艺已存在")
  36. }
  37. workCraftMap := map[string]interface{}{
  38. "`node_id`": form.NodeId,
  39. "`name`": form.Name,
  40. "`cover`": form.Cover,
  41. "`pictures`": form.Pictures,
  42. "`purpose`": form.Purpose,
  43. "`content`": form.Content,
  44. "`state`": form.State,
  45. }
  46. _, err = db.Update(WorkCraft.TableName(), map[string]interface{}{"id": id}, workCraftMap)
  47. return err
  48. }
  49. func DeleteByID(id int) error {
  50. info, _ := GetInfoByID(id, nil, nil)
  51. if info == nil {
  52. return errors.New("invalid id")
  53. }
  54. _, err := db.DeleteSoft(WorkCraft.TableName(), map[string]interface{}{"id": id})
  55. return err
  56. }
  57. func Count(where map[string]interface{}) (int64, error) {
  58. return db.Count(WorkCraft.TableName(), where)
  59. }
  60. func CountRaw(where string, param map[string]interface{}) (int64, error) {
  61. query := "`zy_work_craft` WHERE " + where
  62. return db.CountRaw(query, param)
  63. }
  64. func GetList(where map[string]interface{}, fields []string, page app.Page, retVal interface{}) ([]*models.WorkCraft, error) {
  65. if page.PageNum > 0 && page.PageSize > 0 {
  66. where["_limit"] = db.GetOffset(uint(page.PageNum), uint(page.PageSize))
  67. }
  68. return WorkCraft.GetMulti(where, fields, retVal)
  69. }
  70. func GetWorkCraftsRaw(where map[string]string, param map[string]interface{}, retVal interface{}) ([]*models.WorkCraft, error) {
  71. return WorkCraft.GetMultiRaw(where, param, retVal)
  72. }
  73. func GetOne(where map[string]interface{}, fields []string, retVal interface{}) (*models.WorkCraft, error) {
  74. return WorkCraft.GetOne(where, fields, retVal)
  75. }
  76. func GetInfoByID(id int, fields []string, retVal interface{}) (*models.WorkCraft, error) {
  77. return GetOne(map[string]interface{}{"id": id}, fields, retVal)
  78. }
  79. func CheckWorkCraftDuplicate(nodeId int, name string) bool {
  80. workCraftInfo, err := GetOne(map[string]interface{}{"node_id": nodeId, "name": name, "deleted_at": 0}, nil, nil)
  81. return workCraftInfo != nil && err == nil
  82. }