controller.go 8.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253
  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. }
  18. file := excel.CreateFile(selectCreateFormat(params))
  19. if errorMsg.GetMsg() != "" {
  20. w.Header().Set("Msg",errorMsg.GetMsg())
  21. w.WriteHeader(500)
  22. return
  23. }
  24. if _, err := file.WriteTo(w); err != nil {
  25. utilities.WriteLog("/api/controller/controller.go:27 返回二进制流失败!","ERROR")
  26. return
  27. }
  28. }
  29. type base struct {
  30. ROW []interface{} `json:"row"`
  31. LIST [][]interface{} `json:"list"`
  32. }
  33. func selectCreateFormat(params map[string]string) (row []interface{}, list [][]interface{}, mergeRow map[string]string, mergeColumn []string){
  34. switch params["createFormat"] {
  35. case "merge":
  36. row, list, mergeRow, mergeColumn = selectModule(params)
  37. default:
  38. row, list, _, _ = selectModule(params)
  39. }
  40. return
  41. }
  42. func selectModule(params map[string]string) (row []interface{}, list [][]interface{}, mergeRow map[string]string, mergeColumn []string) {
  43. var data []map[string]string
  44. switch params["type"] {
  45. case "base":
  46. var val base
  47. err := json.Unmarshal([]byte(params["data"]),&val)
  48. if err != nil {
  49. utilities.WriteLog("/api/controller/controller.go:53 JSON解析失败!","ERROR")
  50. }
  51. row = val.ROW
  52. list = val.LIST
  53. case "waybill":
  54. data = orm.GetMysqlData(params["sql"])
  55. row, list = WaybillFormat(data)
  56. case "waybillDelivering":
  57. data = orm.GetMysqlData(params["sql"])
  58. row, list = WaybillDeliveringFormat(data)
  59. case "waybillFinancial":
  60. data = orm.GetMysqlData(params["sql"])
  61. row, list = WaybillFinancialFormat(data)
  62. case "rejected":
  63. data = orm.GetMysqlData(params["sql"])
  64. row, list, mergeRow = RejectedFormat(data)
  65. mergeColumn = []string{
  66. "A","B","C","D","E","F","G","H","I","J","K","T","U",
  67. }
  68. case "rejectedStatistics":
  69. data = orm.GetMysqlData(params["sql"])
  70. row, list = RejectedStatisticsFormat(data)
  71. case "order":
  72. data = orm.GetOracleData(params["sql"])
  73. row, list, mergeRow = OrderFormat(data)
  74. mergeColumn = []string{
  75. "A","B","C","D","E","F","G","H","I","J","K","L","M","N","O","P",
  76. "Q","R","S","Z","AA","AB","AC","AD",
  77. }
  78. case "orderWave":
  79. data = orm.GetOracleData(params["sql"])
  80. row, list = OrderWaveFormat(data)
  81. case "package":
  82. data = orm.GetMysqlData(params["sql"])
  83. row, list = PackageFormat(data)
  84. case "packageIssuedException":
  85. data = orm.GetMysqlData(params["sql"])
  86. row, list = PackageIssuedExceptionFormat(data)
  87. case "packageCreateException":
  88. data = orm.GetMysqlData(params["sql"])
  89. row, list = PackageCreateExceptionFormat(data)
  90. case "inventory":
  91. if params["sql"] != "" {
  92. data = orm.GetOracleData(params["sql"])
  93. }else{
  94. err := json.Unmarshal([]byte(params["data"]), &data)
  95. if err != nil {
  96. utilities.WriteLog("/api/controller/controller.go:100 库存数据json解析失败!","ERROR")
  97. }
  98. }
  99. row, list = InventoryFormat(data, true)
  100. case "allInventory":
  101. if params["sql"] != "" {
  102. data = orm.GetOracleData(params["sql"])
  103. }else{
  104. err := json.Unmarshal([]byte(params["data"]), &data)
  105. if err != nil {
  106. utilities.WriteLog("/api/controller/controller.go:110 全部库存数据json解析失败!","ERROR")
  107. }
  108. }
  109. row, list = InventoryFormat(data, false)
  110. case "process":
  111. data = orm.GetMysqlData(params["sql"])
  112. row, list, mergeRow = ProcessFormat(data)
  113. mergeColumn = []string{
  114. "A","B","C","D","E","F","G","H","I",
  115. }
  116. case "processStatistic":
  117. data = orm.GetMysqlData(params["sql"])
  118. row, list = ProcessStatisticFormat(data)
  119. case "laborReport":
  120. err := json.Unmarshal([]byte(params["data"]), &data)
  121. if err != nil {
  122. utilities.WriteLog("/api/controller/controller.go:126 临时工报表数据json解析失败!","ERROR")
  123. }
  124. row, list = LaborReportFormat(data)
  125. case "orderIssue":
  126. sqlList := make(map[string]string)
  127. err := json.Unmarshal([]byte(params["sqlList"]), &sqlList)
  128. if err != nil {
  129. utilities.WriteLog("/api/controller/controller.go:133 订单问题件数据json解析失败!","ERROR")
  130. }
  131. if sqlList["orderPackageSql"] == "" || sqlList["secondOrderPackageSql"] == "" || sqlList["orderIssueSql"] == "" || sqlList["rejectedBillItemSql"] == "" || sqlList["logSql"] == ""{
  132. return
  133. }
  134. orderIssues := orm.GetMysqlData(sqlList["orderIssueSql"])
  135. if len(orderIssues) < 1 {
  136. break
  137. }
  138. modelData, orderPackageConditionValue, secondOrderPackageConditionValue, rejectedBillItemConditionValue, logConditionValue := GetOrderIssuesModel(orderIssues)
  139. orderPackages := make([]map[string]string,0)
  140. secondOrderPackages := make([]map[string]string,0)
  141. rejectedBillItems := make([]map[string]string,0)
  142. logs := make([]map[string]string,0)
  143. OP := len(orderPackageConditionValue)
  144. SOP := len(secondOrderPackageConditionValue)
  145. RB := len(rejectedBillItemConditionValue)
  146. L := len(logConditionValue)
  147. if orderPackageConditionValue[OP-2:] != "()"{
  148. if orderPackageConditionValue[OP-2:OP-1] == "," {
  149. orderPackageConditionValue = orderPackageConditionValue[0:OP-2] + orderPackageConditionValue[OP-1:]
  150. }
  151. orderPackages = orm.GetMysqlData(sqlList["orderPackageSql"]+orderPackageConditionValue)
  152. }
  153. if secondOrderPackageConditionValue[len(secondOrderPackageConditionValue)-2:] != "()"{
  154. if secondOrderPackageConditionValue[SOP-2:SOP-1] == "," {
  155. secondOrderPackageConditionValue = secondOrderPackageConditionValue[0:SOP-2] + secondOrderPackageConditionValue[SOP-1:]
  156. }
  157. secondOrderPackages = orm.GetMysqlData(sqlList["secondOrderPackageSql"]+secondOrderPackageConditionValue)
  158. }
  159. if rejectedBillItemConditionValue[len(rejectedBillItemConditionValue)-2:] != "()"{
  160. if rejectedBillItemConditionValue[RB-2:RB-1] == "," {
  161. rejectedBillItemConditionValue = rejectedBillItemConditionValue[0:RB-2] + rejectedBillItemConditionValue[RB-1:]
  162. }
  163. rejectedBillItems = orm.GetMysqlData(sqlList["rejectedBillItemSql"]+rejectedBillItemConditionValue)
  164. }
  165. if logConditionValue[len(logConditionValue)-2:] != "()"{
  166. if logConditionValue[L-2:L-1] == "," {
  167. logConditionValue = logConditionValue[0:L-2] + logConditionValue[L-1:]
  168. }
  169. logs = orm.GetMysqlData(sqlList["logSql"]+logConditionValue)
  170. }
  171. result := MergerOrderIssueData(modelData,orderPackages,secondOrderPackages,rejectedBillItems,logs)
  172. row, list, mergeRow = OrderIssueFormat(result)
  173. mergeColumn = []string{
  174. "A","B","C","D","E","F","G","H","I","J","K","L",
  175. "U","Y","Z","AA","AF","AG","AH","AI","AJ","AK",
  176. }
  177. case "packageStatistic":
  178. type paramList struct {
  179. ROW []interface{} `json:"row"`
  180. LIST []map[int]string `json:"list"`
  181. }
  182. request := paramList{}
  183. err := json.Unmarshal([]byte(params["data"]), &request)
  184. if err != nil {
  185. utilities.WriteLog("/api/controller/controller.go:189 称重统计数据json解析失败!","ERROR")
  186. }
  187. row, list = PackageStatisticFormat(request.ROW, request.LIST)
  188. case "inventoryAccountMission":
  189. err := json.Unmarshal([]byte(params["data"]), &data)
  190. if err != nil {
  191. utilities.WriteLog("/api/controller/controller.go:195 库存盘点数据json解析失败!","ERROR")
  192. }
  193. row, list = InventoryAccountMissionFormat(data)
  194. case "inventoryCompare":
  195. data = orm.GetMysqlData(params["sql"])
  196. row, list = InventoryCompareFormat(data)
  197. case "unify":
  198. var column []string
  199. var rule map[string]string
  200. err := json.Unmarshal([]byte(params["row"]), &row)
  201. if err != nil {
  202. utilities.WriteLog("/api/controller/controller.go:206 参数传递错误!","ERROR")
  203. }
  204. err = json.Unmarshal([]byte(params["column"]), &column)
  205. if err != nil {
  206. utilities.WriteLog("/api/controller/controller.go:210 参数传递错误!","ERROR")
  207. }
  208. err = json.Unmarshal([]byte(params["rule"]), &rule)
  209. if params["connection"] == "oracle" {
  210. data = orm.GetOracleData(params["sql"])
  211. }else{
  212. data = orm.GetMysqlData(params["sql"])
  213. }
  214. list = unifyFormat(data, column, rule)
  215. }
  216. return row,list,mergeRow,mergeColumn
  217. }
  218. func unifyFormat(data []map[string]string, row []string, rule map[string]string) [][]interface{}{
  219. rowLen := len(row)
  220. column := make(map[string]int,rowLen)
  221. for i,c := range row {
  222. column[c] = i
  223. }
  224. list := make([][]interface{},len(data))
  225. for k,v := range data{
  226. line := make([]interface{},rowLen)
  227. for key,value := range column {
  228. if rule[key] != ""{
  229. line[value] = dataFormat(rule[key], v[key])
  230. continue
  231. }
  232. line[value] = v[key]
  233. }
  234. list[k] = line
  235. }
  236. return list
  237. }
  238. func dataFormat(ruleType string,value string)string{
  239. switch ruleType {
  240. case "oracleDate":
  241. value = utilities.DateFormat(value, "2006-01-02T15:04:05+08:00")
  242. case "mysqlDate":
  243. value = utilities.DateFormat(value,"2006-01-02T15:04:05Z")
  244. }
  245. return value
  246. }