visit.go 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172
  1. package order
  2. import (
  3. "errors"
  4. "fmt"
  5. "time"
  6. "zhiyuan/models"
  7. "zhiyuan/pkg/db"
  8. "zhiyuan/pkg/logger"
  9. "zhiyuan/pkg/utils"
  10. "zhiyuan/services/form"
  11. )
  12. var ASOrderVisit models.ASOrderVisit
  13. func GetVisits(where map[string]interface{}, fields []string, retVal interface{}) ([]*models.ASOrderVisit, error) {
  14. return ASOrderVisit.GetMulti(where, fields, retVal)
  15. }
  16. func GetVisit(where map[string]interface{}, fields []string, retVal interface{}) (*models.ASOrderVisit, error) {
  17. return ASOrderVisit.GetOne(where, fields, retVal)
  18. }
  19. func AddVisit(form form.OrderVisitAdd) error {
  20. formatTime := utils.DateParseUnix(form.VisitTime, "Y-m-d")
  21. if formatTime == 0 {
  22. return errors.New("日期格式有误")
  23. }
  24. visitMap := map[string]interface{}{
  25. "order_id": form.OrderID,
  26. "visit_time": formatTime,
  27. }
  28. if _, err := db.InsertOne(ASOrderVisit.TableName(), visitMap); err != nil {
  29. return errors.New("操作失败")
  30. }
  31. UpdateOrderVisitTime(form.OrderID)
  32. return nil
  33. }
  34. func UpdateOrderVisitTime(orderID int) error {
  35. visitTime := 0
  36. if recentVisit, _ := GetVisit(map[string]interface{}{"order_id": orderID, "_orderby": "visit_time ASC", "state": 1, "deleted_at": 0}, nil, nil); recentVisit != nil {
  37. visitTime = recentVisit.VisitTime
  38. }
  39. db.Update(ASOrder.TableName(), map[string]interface{}{"id": orderID}, map[string]interface{}{"recent_visit_time": visitTime})
  40. return nil
  41. }
  42. func DelVisit(id int) error {
  43. visitInfo, err := GetVisit(map[string]interface{}{"id": id}, nil, nil)
  44. if err != nil {
  45. return err
  46. }
  47. if visitInfo.Type1 == 1 || visitInfo.Type2 == 1 || visitInfo.Type3 == 1 || visitInfo.Type4 == 1 {
  48. return errors.New("不能删除系统安排的回访")
  49. }
  50. if visitInfo.State != 1 {
  51. return errors.New("不能删除已完成的回访")
  52. }
  53. _, err = db.DeleteSoft(ASOrderVisit.TableName(), map[string]interface{}{"id": id})
  54. return err
  55. }
  56. func FinishVisit(form form.OrderVisitEdit, id int) error {
  57. formatTime := utils.DateParseUnix(form.FinishedAt, "Y-m-d")
  58. if formatTime == 0 {
  59. return errors.New("日期格式有误")
  60. }
  61. if _, err := GetVisit(map[string]interface{}{"id": id}, nil, nil); err == nil {
  62. //if visitInfo, err := GetVisit(map[string]interface{}{"id": id}, nil, nil); err == nil {
  63. //if visitInfo.VisitTime > formatTime {
  64. // return errors.New("完成时间不能早于预计时间")
  65. //}
  66. } else {
  67. return errors.New("回访信息有误")
  68. }
  69. visitMap := map[string]interface{}{
  70. "order_id": form.OrderID,
  71. "content": form.Content,
  72. "finished_at": formatTime,
  73. "state": 2,
  74. "contact_state": form.ContactState,
  75. }
  76. _, err := db.Update(ASOrderVisit.TableName(), map[string]interface{}{"id": id}, visitMap)
  77. if err != nil {
  78. return errors.New("操作失败")
  79. }
  80. if form.ContactState == 1 {
  81. AddTypeVisit(form.OrderID, int64(formatTime), 1)
  82. } else {
  83. deleteVisit(form.OrderID, 1)
  84. }
  85. UpdateOrderVisitTime(form.OrderID)
  86. return nil
  87. }
  88. func AddTypeVisit(orderID int, times int64, typ int) error {
  89. t := time.Unix(times+24*60*60, 0).In(time.Local)
  90. formatTime := time.Date(t.Year(), t.Month(), t.Day(), 0, 0, 0, 0, time.Local).Unix()
  91. logger.Sugar.Infof("formatTime: %v", formatTime)
  92. if formatTime == 0 {
  93. return errors.New("日期格式有误")
  94. }
  95. if typ == 3 {
  96. o, _ := models.ASOrderVisit{}.GetOne(map[string]interface{}{
  97. "order_id": orderID,
  98. "type3": 1,
  99. "state": 1,
  100. "deleted_at": 0,
  101. }, nil, nil)
  102. if o != nil {
  103. return nil
  104. }
  105. deleteVisit(orderID, 2)
  106. } else {
  107. deleteVisit(orderID, typ)
  108. }
  109. visitMap := map[string]interface{}{
  110. "order_id": orderID,
  111. "visit_time": formatTime,
  112. }
  113. v, _ := models.ASOrderVisit{}.GetOne(map[string]interface{}{
  114. "order_id": orderID,
  115. "visit_time": formatTime,
  116. "state": 1,
  117. "deleted_at": 0,
  118. }, nil, nil)
  119. for _, n := range []int{1, 2, 3, 4} {
  120. t := 0
  121. if v != nil {
  122. switch n {
  123. case 1:
  124. t = v.Type1
  125. case 2:
  126. t = v.Type2
  127. case 3:
  128. t = v.Type3
  129. case 4:
  130. t = v.Type4
  131. }
  132. }
  133. if typ == n {
  134. t = 1
  135. }
  136. visitMap[fmt.Sprintf("type%d", n)] = t
  137. }
  138. if v == nil {
  139. if _, err := db.InsertOne(ASOrderVisit.TableName(), visitMap); err != nil {
  140. return errors.New("操作失败")
  141. }
  142. } else {
  143. db.Update(ASOrderVisit.TableName(), map[string]interface{}{"id": v.ID}, visitMap)
  144. }
  145. UpdateOrderVisitTime(orderID)
  146. return nil
  147. }
  148. func deleteVisit(orderID int, typ int) {
  149. delValues := []interface{}{time.Now().Unix(), orderID}
  150. upFmts := []interface{}{typ, typ}
  151. for _, n := range []int{1, 2, 3, 4} {
  152. t := 0
  153. if typ == n {
  154. t = 1
  155. } else {
  156. upFmts = append(upFmts, n)
  157. }
  158. delValues = append(delValues, t)
  159. }
  160. db.Exec("UPDATE zy_as_order_visit SET deleted_at=? WHERE (order_id=? and type1=? and type2=? and type3=? and type4=? and state = 1 and deleted_at = 0)", delValues)
  161. db.Exec(fmt.Sprintf("UPDATE zy_as_order_visit SET type%d=0 WHERE (order_id=? and type%d=1 and (type%d!=0 or type%d!=0 and type%d!=0) and state = 1 and deleted_at = 0)", upFmts...), []interface{}{orderID})
  162. }