controller.go 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197
  1. package controller
  2. import (
  3. "bswas/excel"
  4. "bswas/orm"
  5. "bswas/utilities"
  6. "encoding/json"
  7. "net/http"
  8. )
  9. func Export(w http.ResponseWriter,req *http.Request) {
  10. errorMsg := utilities.NewError()
  11. decoder := json.NewDecoder(req.Body)
  12. var params map[string]string
  13. // 解析参数 存入map
  14. e := decoder.Decode(&params)
  15. if e != nil{
  16. utilities.WriteLog("/api/controller/controller.go:18 参数解析失败!","ERROR")
  17. return
  18. }
  19. file := excel.CreateFile(selectModule(params))
  20. if errorMsg.GetMsg() != "" {
  21. w.Header().Set("Msg",errorMsg.GetMsg())
  22. w.WriteHeader(500)
  23. return
  24. }
  25. if _, err := file.WriteTo(w); err != nil {
  26. utilities.WriteLog("/api/controller/controller.go:28 返回二进制流失败!","ERROR")
  27. return
  28. }
  29. }
  30. type base struct {
  31. ROW []interface{} `json:"row"`
  32. LIST [][]interface{} `json:"list"`
  33. }
  34. func selectModule(params map[string]string) (row []interface{}, list [][]interface{}, mergeRow map[string]string, mergeColumn []string) {
  35. var data []map[string]string
  36. switch params["type"] {
  37. case "base":
  38. var val base
  39. err := json.Unmarshal([]byte(params["data"]),&val)
  40. if err != nil {
  41. utilities.WriteLog("/api/controller/controller.go:44 JSON解析失败!","ERROR")
  42. }
  43. row = val.ROW
  44. list = val.LIST
  45. case "waybill":
  46. data = orm.GetMysqlData(params["sql"])
  47. row, list = WaybillFormat(data)
  48. case "waybillDelivering":
  49. data = orm.GetMysqlData(params["sql"])
  50. row, list = WaybillDeliveringFormat(data)
  51. case "waybillFinancial":
  52. data = orm.GetMysqlData(params["sql"])
  53. row, list = WaybillFinancialFormat(data)
  54. case "rejected":
  55. data = orm.GetMysqlData(params["sql"])
  56. row, list, mergeRow = RejectedFormat(data)
  57. mergeColumn = []string{
  58. "A","B","C","D","E","F","G","H","I","J","K","T","U",
  59. }
  60. case "rejectedStatistics":
  61. data = orm.GetMysqlData(params["sql"])
  62. row, list = RejectedStatisticsFormat(data)
  63. case "order":
  64. data = orm.GetOracleData(params["sql"])
  65. row, list, mergeRow = OrderFormat(data)
  66. mergeColumn = []string{
  67. "A","B","C","D","E","F","G","H","I","J","K","L","M","N","O","P",
  68. "Q","R","S","Z","AA","AB","AC","AD",
  69. }
  70. case "orderWave":
  71. data = orm.GetOracleData(params["sql"])
  72. row, list = OrderWaveFormat(data)
  73. case "package":
  74. data = orm.GetMysqlData(params["sql"])
  75. row, list = PackageFormat(data)
  76. case "packageIssuedException":
  77. data = orm.GetMysqlData(params["sql"])
  78. row, list = PackageIssuedExceptionFormat(data)
  79. case "packageCreateException":
  80. data = orm.GetMysqlData(params["sql"])
  81. row, list = PackageCreateExceptionFormat(data)
  82. case "inventory":
  83. if params["sql"] != "" {
  84. data = orm.GetOracleData(params["sql"])
  85. }else{
  86. err := json.Unmarshal([]byte(params["data"]), &data)
  87. if err != nil {
  88. utilities.WriteLog("/api/controller/controller.go:91 库存数据json解析失败!","ERROR")
  89. }
  90. }
  91. row, list = InventoryFormat(data, true)
  92. case "allInventory":
  93. if params["sql"] != "" {
  94. data = orm.GetOracleData(params["sql"])
  95. }else{
  96. err := json.Unmarshal([]byte(params["data"]), &data)
  97. if err != nil {
  98. utilities.WriteLog("/api/controller/controller.go:101 全部库存数据json解析失败!","ERROR")
  99. }
  100. }
  101. row, list = InventoryFormat(data, false)
  102. case "inventoryDailyLog":
  103. data = orm.GetMysqlData(params["sql"])
  104. row, list = InventoryDailyLogFormat(data)
  105. case "process":
  106. data = orm.GetMysqlData(params["sql"])
  107. row, list, mergeRow = ProcessFormat(data)
  108. mergeColumn = []string{
  109. "A","B","C","D","E","F","G","H","I",
  110. }
  111. case "processStatistic":
  112. data = orm.GetMysqlData(params["sql"])
  113. row, list = ProcessStatisticFormat(data)
  114. case "laborReport":
  115. err := json.Unmarshal([]byte(params["data"]), &data)
  116. if err != nil {
  117. utilities.WriteLog("/api/controller/controller.go:120 临时工报表数据json解析失败!","ERROR")
  118. }
  119. row, list = LaborReportFormat(data)
  120. case "orderIssue":
  121. sqlList := make(map[string]string)
  122. err := json.Unmarshal([]byte(params["sqlList"]), &sqlList)
  123. if err != nil {
  124. utilities.WriteLog("/api/controller/controller.go:129 订单问题件数据json解析失败!","ERROR")
  125. }
  126. if sqlList["orderPackageSql"] == "" || sqlList["secondOrderPackageSql"] == "" || sqlList["orderIssueSql"] == "" || sqlList["rejectedBillItemSql"] == "" || sqlList["logSql"] == ""{
  127. return
  128. }
  129. orderIssues := orm.GetMysqlData(sqlList["orderIssueSql"])
  130. if len(orderIssues) < 1 {
  131. break
  132. }
  133. modelData, orderPackageConditionValue, secondOrderPackageConditionValue, rejectedBillItemConditionValue, logConditionValue := GetOrderIssuesModel(orderIssues)
  134. orderPackages := make([]map[string]string,0)
  135. secondOrderPackages := make([]map[string]string,0)
  136. rejectedBillItems := make([]map[string]string,0)
  137. logs := make([]map[string]string,0)
  138. OP := len(orderPackageConditionValue)
  139. SOP := len(secondOrderPackageConditionValue)
  140. RB := len(rejectedBillItemConditionValue)
  141. L := len(logConditionValue)
  142. if orderPackageConditionValue[OP-2:] != "()"{
  143. if orderPackageConditionValue[OP-2:OP-1] == "," {
  144. orderPackageConditionValue = orderPackageConditionValue[0:OP-2] + orderPackageConditionValue[OP-1:]
  145. }
  146. orderPackages = orm.GetMysqlData(sqlList["orderPackageSql"]+orderPackageConditionValue)
  147. }
  148. if secondOrderPackageConditionValue[len(secondOrderPackageConditionValue)-2:] != "()"{
  149. if secondOrderPackageConditionValue[SOP-2:SOP-1] == "," {
  150. secondOrderPackageConditionValue = secondOrderPackageConditionValue[0:SOP-2] + secondOrderPackageConditionValue[SOP-1:]
  151. }
  152. secondOrderPackages = orm.GetMysqlData(sqlList["secondOrderPackageSql"]+secondOrderPackageConditionValue)
  153. }
  154. if rejectedBillItemConditionValue[len(rejectedBillItemConditionValue)-2:] != "()"{
  155. if rejectedBillItemConditionValue[RB-2:RB-1] == "," {
  156. rejectedBillItemConditionValue = rejectedBillItemConditionValue[0:RB-2] + rejectedBillItemConditionValue[RB-1:]
  157. }
  158. rejectedBillItems = orm.GetMysqlData(sqlList["rejectedBillItemSql"]+rejectedBillItemConditionValue)
  159. }
  160. if logConditionValue[len(logConditionValue)-2:] != "()"{
  161. if logConditionValue[L-2:L-1] == "," {
  162. logConditionValue = logConditionValue[0:L-2] + logConditionValue[L-1:]
  163. }
  164. logs = orm.GetMysqlData(sqlList["logSql"]+logConditionValue)
  165. }
  166. result := MergerOrderIssueData(modelData,orderPackages,secondOrderPackages,rejectedBillItems,logs)
  167. row, list, mergeRow = OrderIssueFormat(result)
  168. mergeColumn = []string{
  169. "A","B","C","D","E","F","G","H","I","J","K","L",
  170. "U","Y","Z","AA","AF","AG","AH","AI","AJ","AK",
  171. }
  172. case "packageStatistic":
  173. type paramList struct {
  174. ROW []interface{} `json:"row"`
  175. LIST []map[int]string `json:"list"`
  176. }
  177. request := paramList{}
  178. err := json.Unmarshal([]byte(params["data"]), &request)
  179. if err != nil {
  180. utilities.WriteLog("/api/controller/controller.go:183 称重统计数据json解析失败!","ERROR")
  181. }
  182. row, list = PackageStatisticFormat(request.ROW, request.LIST)
  183. case "inventoryAccountMission":
  184. err := json.Unmarshal([]byte(params["data"]), &data)
  185. if err != nil {
  186. utilities.WriteLog("/api/controller/controller.go:189 库存盘点数据json解析失败!","ERROR")
  187. }
  188. row, list = InventoryAccountMissionFormat(data)
  189. case "inventoryCompare":
  190. data = orm.GetMysqlData(params["sql"])
  191. row, list = InventoryCompareFormat(data)
  192. }
  193. return row,list,mergeRow,mergeColumn
  194. }