autopackutils.cpp 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  1. #include "autopackutils.h"
  2. /**
  3. * @brief AutoPackForm工具类
  4. */
  5. AutoPackUtils::AutoPackUtils()
  6. {
  7. connect(&_request,&HttpRequest::result,this,&AutoPackUtils::httpResult);
  8. }
  9. /**
  10. * @brief 把打包数据存入本地数据库后,上传服务器打包数据
  11. * @param info
  12. */
  13. void AutoPackUtils::doSend(QJsonObject json)
  14. {
  15. if(json.isEmpty()) return;
  16. //保存码单,上传服务器成功后,以codeSingle为条件更改同步字段;
  17. this->codeSingle = json["code_single"].toString();
  18. // qDebug()<<codeSingle;
  19. _request.setUserToken(QString::number(GlobalInfo::this_()->user().accountId),GlobalInfo::this_()->user().acessToken);
  20. // qDebug()<<QString::number(GlobalInfo::this_()->user().accountId);
  21. // qDebug()<<GlobalInfo::this_()->user().acessToken;
  22. _request.post(GlobalInfo::this_()->config().baseUrl+"/v1/product/pending",json);
  23. }
  24. void AutoPackUtils::httpResult(int emitcode, const QJsonObject body)
  25. {
  26. qDebug()<<emitcode;
  27. qDebug()<<body;
  28. if(emitcode==200&&body["message"].toString() == ""){
  29. if(database.changeState(codeSingle)){
  30. qDebug()<<"同步成功";
  31. return;
  32. }
  33. qDebug()<<"同步失败";
  34. }
  35. }
  36. //把BoxInfo数据添加到deetails数据库里;
  37. void AutoPackUtils::insertDetailsSQL(QSharedPointer<BoxInfo> boxes,QString codeSingle)
  38. {
  39. // qDebug()<<boxes->caseNumber();
  40. detailsData.code_single = codeSingle;
  41. detailsData.case_number = boxes->caseNumber();
  42. detailsData.box_weight = boxes->box_weight;
  43. detailsData.tube_number = boxes->tube_number;
  44. detailsData.bucket_weight = boxes->bucket_weight;
  45. detailsData.gross_weight = boxes->gross_weight;
  46. detailsData.net_weight = boxes->net_weight;
  47. detailsData.sort = boxes->sort;
  48. detailsData.remark = boxes->remark;
  49. if(database.insertDetails(detailsData)){
  50. qDebug()<<"details数据库添加成功";
  51. return;
  52. }
  53. qDebug()<<"details数据库添加失败";
  54. }
  55. //把PackInfo添加到product数据库里;
  56. void AutoPackUtils::insertProductSQL(QSharedPointer<PackInfo> packes)
  57. {
  58. if(packes.isNull()) return;
  59. productData.goods_id = packes->goodsID();
  60. productData.code_single = packes->codeSingle();
  61. productData.quantity = packes->quantity;
  62. productData.batch_no = packes->info().batch_no;
  63. productData.category = packes->info().category;
  64. productData.level_id = packes->level_id;
  65. productData.tube_number = packes->tube_number();
  66. productData.gross_weight = packes->gross_weight();
  67. productData.net_weight = packes->net_weight();
  68. productData.machine_no = packes->machine_no;
  69. productData.packing_time = packes->packing_time;
  70. productData.packing_type = packes->packing_type;
  71. productData.carton_type = packes->carton_type;
  72. productData.operator_id = packes->operator_id;
  73. productData.remark = packes->remark;
  74. if(database.insertProduct(productData)){
  75. qDebug()<<"product数据库添加成功";
  76. return;
  77. }
  78. qDebug()<<"product数据库添加失败";
  79. }
  80. //将打包数据转换为json数据
  81. QJsonObject AutoPackUtils::toJson(QSharedPointer<PackInfo> &info)
  82. {
  83. QJsonObject json;
  84. QJsonObject detailsjson;
  85. QJsonArray jsonarray;
  86. if(info.isNull()) return json;
  87. for(int i = 0;i<info->boxes().size();i++){
  88. detailsjson.insert("case_number",info->boxes().at(i)->caseNumber());
  89. detailsjson.insert("box_weight",info->boxes().at(i)->box_weight);
  90. detailsjson.insert("tube_number",info->boxes().at(i)->tube_number);
  91. detailsjson.insert("bucket_weight",info->boxes().at(i)->bucket_weight);
  92. detailsjson.insert("gross_weight",info->boxes().at(i)->gross_weight);
  93. detailsjson.insert("net_weight",info->boxes().at(i)->net_weight);
  94. detailsjson.insert("box_weight",info->boxes().at(i)->box_weight);
  95. detailsjson.insert("sort",info->boxes().at(i)->sort);
  96. detailsjson.insert("remark",info->boxes().at(i)->remark);
  97. jsonarray.append(detailsjson);
  98. }
  99. json.insert("goods_id",info->goodsID());
  100. json.insert("code_single",info->codeSingle());
  101. json.insert("quantity",info->quantity);
  102. json.insert("level_id",info->level_id);
  103. json.insert("tube_number",info->tube_number());
  104. json.insert("gross_weight",info->gross_weight());
  105. json.insert("net_weight",info->net_weight());
  106. json.insert("machine_no",info->machine_no);
  107. json.insert("packing_time",info->packing_time);
  108. json.insert("packing_type",info->packing_type);
  109. json.insert("carton_type",info->carton_type);
  110. json.insert("operator",info->operator_id);
  111. json.insert("details",jsonarray);
  112. json.insert("remark",info->remark);
  113. return json;
  114. }
  115. QJsonObject AutoPackUtils::toJsonMap(QMap<QString,QString> product,QList<QMap<QString,QString>> details)
  116. {
  117. // qDebug()<<"自动打包测试";
  118. // qDebug()<<details.at(0).value("code_single");
  119. QJsonObject json;
  120. QJsonObject detailsjson;
  121. QJsonArray jsonarray;
  122. if(product.isEmpty()){
  123. qDebug()<<"product数据为空";
  124. return json;
  125. }
  126. if(details.isEmpty()){
  127. qDebug()<<"details数据为空";
  128. return json;
  129. }
  130. for(int i = 0;i<details.length();i++){
  131. detailsjson.insert("case_number",details.at(i).value("case_number"));
  132. detailsjson.insert("box_weight",details.at(i).value("box_weight"));
  133. detailsjson.insert("tube_number",details.at(i).value("tube_number"));
  134. detailsjson.insert("bucket_weight",details.at(i).value("bucket_weight"));
  135. detailsjson.insert("gross_weight",details.at(i).value("gross_weight"));
  136. detailsjson.insert("net_weight",details.at(i).value("net_weight"));
  137. detailsjson.insert("box_weight",details.at(i).value("box_weight"));
  138. detailsjson.insert("sort",details.at(i).value("sort"));
  139. detailsjson.insert("remark",details.at(i).value("remark"));
  140. jsonarray.append(detailsjson);
  141. }
  142. json.insert("goods_id",product.value("goods_id"));
  143. json.insert("code_single",product.value("code_single"));
  144. json.insert("quantity",product.value("quantity"));
  145. json.insert("level_id",product.value("level_id"));
  146. json.insert("tube_number",product.value("tube_number"));
  147. json.insert("gross_weight",product.value("gross_weight"));
  148. json.insert("net_weight",product.value("net_weight"));
  149. json.insert("machine_no",product.value("machine_no"));
  150. json.insert("packing_time",product.value("packing_time"));
  151. json.insert("packing_type",product.value("packing_type"));
  152. json.insert("carton_type",product.value("carton_type"));
  153. json.insert("operator",product.value("operator_id"));
  154. json.insert("details",jsonarray);
  155. json.insert("remark",product.value("remark"));
  156. return json;
  157. }