autopackutils.cpp 6.9 KB

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