广告平台(站长使用)
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.
 
 
 
 
 

236 lines
8.4 KiB

  1. package svc
  2. import (
  3. "applet/app/e"
  4. "applet/app/md"
  5. "applet/app/utils"
  6. db "code.fnuoos.com/zhimeng/model.git/src"
  7. "code.fnuoos.com/zhimeng/model.git/src/super/implement"
  8. "encoding/json"
  9. "github.com/gin-gonic/gin"
  10. )
  11. func FinanceCenterMediumInvoiceSave(c *gin.Context, req md.InvoiceReq) {
  12. engine := db.Db
  13. NewMediumSettlementDb := implement.NewMediumSettlementDb(engine)
  14. data, _ := NewMediumSettlementDb.GetMediumSettlementById(utils.StrToInt(req.Id))
  15. if data.State != 3 {
  16. e.OutErr(c, 400, e.NewErr(400, "媒体未完成签订"))
  17. return
  18. }
  19. if data.PayState == 5 {
  20. e.OutErr(c, 400, e.NewErr(400, "结算单已付款,不能调整"))
  21. return
  22. }
  23. NewMediumInvoiceDb := implement.NewMediumInvoiceDb(engine)
  24. invoice, _ := NewMediumInvoiceDb.GetMediumInvoice(data.Id)
  25. if req.State == "1" {
  26. data.PayState = 4
  27. invoice.State = 1
  28. for k := range req.File {
  29. req.File[k].State = "1"
  30. }
  31. }
  32. if req.State == "2" {
  33. invoice.State = 2
  34. data.PayState = 3
  35. for k, v := range req.File {
  36. if v.State == "0" {
  37. req.File[k].State = "1"
  38. }
  39. }
  40. }
  41. invoice.File = utils.SerializeStr(req.File)
  42. engine.Where("id=?", data.Id).Cols("pay_state").Update(data)
  43. engine.Where("id=?", invoice.Id).Cols("state,file").Update(invoice)
  44. e.OutSuc(c, "success", nil)
  45. return
  46. }
  47. func FinanceCenterMediumSettleFileSave(c *gin.Context, req md.SettleFileReq) {
  48. engine := db.Db
  49. NewMediumSettlementDb := implement.NewMediumSettlementDb(engine)
  50. data, _ := NewMediumSettlementDb.GetMediumSettlementById(utils.StrToInt(req.Id))
  51. if data.State >= 2 {
  52. e.OutErr(c, 400, e.NewErr(400, "已推送给媒体,不能再调整"))
  53. return
  54. }
  55. data.State = 2
  56. data.SettleFile = req.File
  57. engine.Where("id=?", data.Id).Cols("state,settle_file").Update(data)
  58. e.OutSuc(c, "success", nil)
  59. return
  60. }
  61. func FinanceCenterMediumPaySave(c *gin.Context, req md.CommDetailReq) {
  62. engine := db.Db
  63. NewMediumSettlementDb := implement.NewMediumSettlementDb(engine)
  64. data, _ := NewMediumSettlementDb.GetMediumSettlementById(utils.StrToInt(req.Id))
  65. if data.PayState < 4 {
  66. e.OutErr(c, 400, e.NewErr(400, "不能再调整"))
  67. return
  68. }
  69. data.PayState = 5
  70. engine.Where("id=?", data.Id).Cols("pay_state").Update(data)
  71. e.OutSuc(c, "success", nil)
  72. return
  73. }
  74. func FinanceCenterMediumCheckSave(c *gin.Context, req md.CommDetailReq) {
  75. engine := db.Db
  76. NewMediumSettlementDb := implement.NewMediumSettlementDb(engine)
  77. data, _ := NewMediumSettlementDb.GetMediumSettlementById(utils.StrToInt(req.Id))
  78. if data.State > 1 {
  79. e.OutErr(c, 400, e.NewErr(400, "不能再调整"))
  80. return
  81. }
  82. data.State = 1
  83. engine.Where("id=?", data.Id).Cols("state").Update(data)
  84. e.OutSuc(c, "success", nil)
  85. return
  86. }
  87. func FinanceCenterMediumOtherIncomeSave(c *gin.Context, req md.OtherIncomeReq) {
  88. engine := db.Db
  89. NewMediumSettlementDb := implement.NewMediumSettlementDb(engine)
  90. data, _ := NewMediumSettlementDb.GetMediumSettlementById(utils.StrToInt(req.Id))
  91. if data.State >= 2 {
  92. e.OutErr(c, 400, e.NewErr(400, "已推送给媒体,不能再调整"))
  93. return
  94. }
  95. data.OtherIncome = int(utils.StrToFloat64(req.Amount) * 100)
  96. engine.Where("id=?", data.Id).Cols("other_income").Update(data)
  97. e.OutSuc(c, "success", nil)
  98. return
  99. }
  100. func FinanceCenterMediumDetail(c *gin.Context, req md.CommDetailReq) md.FinanceCenterDataDetailRes {
  101. engine := db.Db
  102. NewMediumSettlementDb := implement.NewMediumSettlementDb(engine)
  103. data, _ := NewMediumSettlementDb.GetMediumSettlementById(utils.StrToInt(req.Id))
  104. file := make([]md.InvoiceFile, 0)
  105. invoice := md.Invoice{
  106. Type: "0",
  107. Time: "",
  108. Count: "0",
  109. File: file,
  110. }
  111. //发票
  112. NewMediumInvoiceDb := implement.NewMediumInvoiceDb(engine)
  113. invoiceData, _ := NewMediumInvoiceDb.GetMediumInvoice(data.Id)
  114. if invoiceData != nil {
  115. invoice.Type = utils.IntToStr(invoiceData.Type)
  116. invoice.Time = invoiceData.UpdateAt
  117. invoice.Count = utils.IntToStr(invoiceData.Count)
  118. json.Unmarshal([]byte(invoiceData.File), &file)
  119. invoice.File = file
  120. }
  121. tmp := md.FinanceCenterDataDetail{
  122. Source: "手动导入",
  123. SettleFile: data.SettleFile,
  124. Invoice: invoice,
  125. AllIncome: utils.Float64ToStr(float64(data.OtherIncome+data.BasicIncome) / 100),
  126. TopIncome: utils.Float64ToStr(float64(data.OriginalIncome) / 100),
  127. CommissionIncome: utils.Float64ToStr(float64(data.CommissionRetention) / 100),
  128. PlatformIncome: utils.Float64ToStr(float64(data.PlatformRetention) / 100),
  129. ChangeIncome: utils.Float64ToStr(float64(data.PriceAdjustmentRetention) / 100),
  130. MediumIncome: utils.Float64ToStr(float64(data.BasicIncome) / 100),
  131. OtherIncome: utils.Float64ToStr(float64(data.OtherIncome) / 100),
  132. TimeStr: data.StartDate,
  133. PayState: utils.IntToStr(data.PayState),
  134. State: utils.IntToStr(data.State),
  135. }
  136. if data.EndDate != "" && data.EndDate != "0000-00-00" {
  137. if data.EndDate != data.StartDate {
  138. tmp.TimeStr += "~" + data.EndDate
  139. }
  140. }
  141. tmpMedium := GetMediumInfo(c, data.MediumId)
  142. if tmpMedium["name"] != "" {
  143. tmp.Name = tmpMedium["name"]
  144. }
  145. if tmpMedium["account"] != "" {
  146. tmp.Account = tmpMedium["account"]
  147. }
  148. res := md.FinanceCenterDataDetailRes{
  149. Data: tmp,
  150. InvoiceCate: md.InvoiceCate,
  151. SettleType: md.AccountSettleState,
  152. BusinessKind: md.BusinessKind,
  153. SettlePayState: md.SettlePayState,
  154. SettleState: md.SettleState,
  155. InvoiceState: md.InvoiceState,
  156. }
  157. return res
  158. }
  159. func FinanceCenterMediumList(c *gin.Context, req md.FinanceCenterDataReq) md.FinanceCenterDataRes {
  160. engine := db.Db
  161. NewMediumSettlementDb := implement.NewMediumSettlementDb(engine)
  162. MediumList, total, _ := NewMediumSettlementDb.FindMediumSettlementList(c.GetString("mid"), "", "", req.PayState, "", req.StartTime, req.EndTime, utils.StrToInt(req.Page), utils.StrToInt(req.Limit))
  163. data := make([]md.FinanceCenterDataData, 0)
  164. if len(MediumList) > 0 {
  165. for _, v := range MediumList {
  166. var tmp = md.FinanceCenterDataData{
  167. Id: utils.IntToStr(v.Id),
  168. Name: "",
  169. AllIncome: utils.Float64ToStr(float64(v.OtherIncome+v.BasicIncome) / 100),
  170. TopIncome: utils.Float64ToStr(float64(v.OriginalIncome) / 100),
  171. CommissionIncome: utils.Float64ToStr(float64(v.CommissionRetention) / 100),
  172. PlatformIncome: utils.Float64ToStr(float64(v.PlatformRetention) / 100),
  173. ChangeIncome: utils.Float64ToStr(float64(v.PriceAdjustmentRetention) / 100),
  174. MediumIncome: utils.Float64ToStr(float64(v.BasicIncome) / 100),
  175. OtherIncome: utils.Float64ToStr(float64(v.OtherIncome) / 100),
  176. TimeStr: v.StartDate,
  177. SettleType: utils.IntToStr(v.Kind),
  178. PayState: utils.IntToStr(v.PayState),
  179. State: utils.IntToStr(v.State),
  180. Label: "预估",
  181. }
  182. tmpMedium := GetMediumInfo(c, v.MediumId)
  183. if tmpMedium["name"] != "" {
  184. tmp.Name = tmpMedium["name"]
  185. }
  186. if v.EndDate != "" && v.EndDate != "0000-00-00" {
  187. if v.EndDate != v.StartDate {
  188. tmp.TimeStr += "~" + v.EndDate
  189. }
  190. tmp.Label = ""
  191. }
  192. data = append(data, tmp)
  193. }
  194. }
  195. res := md.FinanceCenterDataRes{
  196. List: data,
  197. Total: total,
  198. SettleType: md.AccountSettleState,
  199. BusinessKind: md.BusinessKind,
  200. SettlePayState: md.SettlePayState,
  201. SettleState: md.SettleState,
  202. }
  203. return res
  204. }
  205. func FinanceCenterPlatformList(c *gin.Context, req md.FinanceCenterPlatformDataReq) md.FinanceCenterPlatformDataRes {
  206. engine := db.Db
  207. NewPlatformSettlementDb := implement.NewPlatformSettlementDb(engine)
  208. MediumList, total, _ := NewPlatformSettlementDb.FindPlatformSettlementList(c.GetString("mid"), req.Date, req.StartTime, req.EndTime, utils.StrToInt(req.Page), utils.StrToInt(req.Limit))
  209. data := make([]md.FinanceCenterPlatformDataData, 0)
  210. if len(MediumList) > 0 {
  211. for _, v := range MediumList {
  212. var tmp = md.FinanceCenterPlatformDataData{
  213. Id: utils.IntToStr(v.Id),
  214. TopIncome: utils.Float64ToStr(float64(v.OriginalIncome) / 100),
  215. CommissionIncome: utils.Float64ToStr(float64(v.CommissionRetention) / 100),
  216. PlatformIncome: utils.Float64ToStr(float64(v.PlatformRetention) / 100),
  217. ChangeIncome: utils.Float64ToStr(float64(v.PriceAdjustmentRetention) / 100),
  218. MediumIncome: utils.Float64ToStr(float64(v.MediumIncome) / 100),
  219. AgentIncome: utils.Float64ToStr(float64(v.AgentIncome) / 100),
  220. TimeStr: v.StartDate,
  221. UpdateAt: v.UpdateAt,
  222. }
  223. data = append(data, tmp)
  224. }
  225. }
  226. res := md.FinanceCenterPlatformDataRes{
  227. List: data,
  228. Total: total,
  229. }
  230. return res
  231. }