autopackutils.cpp 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188
  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. if(packes->boxes().isEmpty()) return;
  60. productData.goods_id = packes->goodsID();
  61. productData.code_single = packes->codeSingle();
  62. productData.quantity = packes->quantity;
  63. productData.batch_no = packes->info().batch_no;
  64. productData.category = packes->info().category;
  65. productData.level_id = packes->level_id;
  66. productData.tube_number = packes->tube_number();
  67. productData.gross_weight = packes->gross_weight();
  68. productData.net_weight = packes->net_weight();
  69. productData.machine_no = packes->machine_no;
  70. productData.packing_time = packes->packing_time;
  71. productData.packing_type = packes->packing_type;
  72. productData.carton_type = packes->carton_type;
  73. productData.operator_id = packes->operator_id;
  74. productData.specs = packes->info().specs;
  75. productData.denier = packes->info().denier;
  76. productData.dtex = packes->info().dtex;
  77. productData.fiber = packes->info().fiber;
  78. productData.remark = packes->remark;
  79. if(database.insertProduct(productData)){
  80. qDebug()<<"product数据库添加成功";
  81. return;
  82. }
  83. qDebug()<<"product数据库添加失败";
  84. }
  85. //将打包数据转换为json数据
  86. QJsonObject AutoPackUtils::toJson(QSharedPointer<PackInfo> &info)
  87. {
  88. QJsonObject json;
  89. json.empty();
  90. if(info.isNull()) return json;
  91. if(info->boxes().isEmpty()) return json;
  92. QJsonObject detailsjson;
  93. QJsonArray jsonarray;
  94. for(int i = 0;i<info->boxes().size();i++){
  95. detailsjson.insert("case_number",info->boxes().at(i)->caseNumber());
  96. detailsjson.insert("box_weight",info->boxes().at(i)->box_weight);
  97. detailsjson.insert("tube_number",info->boxes().at(i)->tube_number);
  98. detailsjson.insert("bucket_weight",info->boxes().at(i)->bucket_weight);
  99. detailsjson.insert("gross_weight",info->boxes().at(i)->gross_weight);
  100. detailsjson.insert("net_weight",info->boxes().at(i)->net_weight);
  101. detailsjson.insert("box_weight",info->boxes().at(i)->box_weight);
  102. detailsjson.insert("sort",info->boxes().at(i)->sort);
  103. detailsjson.insert("remark",info->boxes().at(i)->remark);
  104. jsonarray.append(detailsjson);
  105. }
  106. json.insert("goods_id",info->goodsID());
  107. json.insert("code_single",info->codeSingle());
  108. json.insert("quantity",info->quantity);
  109. json.insert("level_id",info->level_id);
  110. json.insert("tube_number",info->tube_number());
  111. json.insert("gross_weight",info->gross_weight());
  112. json.insert("net_weight",info->net_weight());
  113. json.insert("machine_no",info->machine_no);
  114. json.insert("packing_time",info->packing_time);
  115. json.insert("packing_type",info->packing_type);
  116. json.insert("carton_type",info->carton_type);
  117. json.insert("operator",info->operator_id);
  118. json.insert("details",jsonarray);
  119. json.insert("remark",info->remark);
  120. return json;
  121. }
  122. QJsonObject AutoPackUtils::toJsonMap(QMap<QString,QString> product,QList<QMap<QString,QString>> details)
  123. {
  124. // qDebug()<<"自动打包测试";
  125. // qDebug()<<details.at(0).value("code_single");
  126. QJsonObject json;
  127. QJsonObject detailsjson;
  128. QJsonArray jsonarray;
  129. if(product.isEmpty()){
  130. qDebug()<<"product数据为空";
  131. return json;
  132. }
  133. if(details.isEmpty()){
  134. qDebug()<<"details数据为空";
  135. return json;
  136. }
  137. for(int i = 0;i<details.length();i++){
  138. detailsjson.insert("case_number",details.at(i).value("case_number"));
  139. detailsjson.insert("box_weight",details.at(i).value("box_weight"));
  140. detailsjson.insert("tube_number",details.at(i).value("tube_number"));
  141. detailsjson.insert("bucket_weight",details.at(i).value("bucket_weight"));
  142. detailsjson.insert("gross_weight",details.at(i).value("gross_weight"));
  143. detailsjson.insert("net_weight",details.at(i).value("net_weight"));
  144. detailsjson.insert("box_weight",details.at(i).value("box_weight"));
  145. detailsjson.insert("sort",details.at(i).value("sort"));
  146. detailsjson.insert("remark",details.at(i).value("remark"));
  147. jsonarray.append(detailsjson);
  148. }
  149. json.insert("goods_id",product.value("goods_id"));
  150. json.insert("code_single",product.value("code_single"));
  151. json.insert("quantity",product.value("quantity"));
  152. json.insert("level_id",product.value("level_id"));
  153. json.insert("tube_number",product.value("tube_number"));
  154. json.insert("gross_weight",product.value("gross_weight"));
  155. json.insert("net_weight",product.value("net_weight"));
  156. json.insert("machine_no",product.value("machine_no"));
  157. json.insert("packing_time",product.value("packing_time"));
  158. json.insert("packing_type",product.value("packing_type"));
  159. json.insert("carton_type",product.value("carton_type"));
  160. json.insert("operator",product.value("operator_id"));
  161. json.insert("details",jsonarray);
  162. json.insert("remark",product.value("remark"));
  163. return json;
  164. }