| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297 |
- #include "packdetailform.h"
- #include "ui_packdetailform.h"
- #include "packinfo.h"
- #include <pqQtlib/utils/pqfileutils.h>
- PackDetailForm::PackDetailForm(QWidget *parent) :
- QWidget(parent),
- ui(new Ui::PackDetailForm)
- {
- ui->setupUi(this);
- productList();
- detailsList();
- ui->treeWidget->header()->setSectionResizeMode(QHeaderView::ResizeToContents);
- }
- PackDetailForm::~PackDetailForm()
- {
- delete ui;
- }
- void PackDetailForm::on_pushBack_clicked()
- {
- emit back();
- }
- void PackDetailForm::on_pushButton_clicked()
- {
- nowPageNum = 0;
- // changeTable(database.GetValues("product",productSqlList));
- QString condition = "";
- if(!ui->codeSingleLine->text().isEmpty()){
- condition.append("code_single="+ui->codeSingleLine->text()+" ");
- }
- if(!ui->batch_noLine->text().isEmpty()){
- if(!condition.isEmpty()){
- condition.append("and ");
- }
- condition.append("batch_no="+ui->batch_noLine->text()+" ");
- }
- if(!condition.isEmpty()){
- condition = "where "+ condition;
- }
- condition.append("limit 0,20");
- // qDebug()<<condition;
- // changeTreeWidget(database.GetValues("product",productSqlList,/*"limit 0,20"*/condition));
- //// ui->pagesNum->setText(QString::number(pageNum)+"/"+QString::number(product.size()/20));
- // int pageListNum = database.GetTablePage();
- // pageNumAll = pageListNum / 20;
- // if(pageListNum % 20 > 0)
- // pageNumAll ++;
- ui->pagesNum->setText(QString("%1/%2").arg(nowPageNum+1).arg(pageNumAll));
- }
- //往treewidget添加数据
- void PackDetailForm::changeTreeWidget(QList<QMap<QString,QString>> productList)
- {
- if(productList.isEmpty()){
- QMessageBox::information(this,tr("提示"),tr("数据为空"));
- return;
- }
- ui->treeWidget->clear();
- product = productList;
- /******************************************************************/
- //循环添加数据
- for(int i = 0;i<productList.size();i++){
- QStringList list;
- list.append(productList.at(i).value("tongbu") == "0" ? "未同步" : "已同步");
- if(productList.at(i).value("tongbu") == "0"){
- }
- list.append(productList.at(i).value("code_single"));
- list.append(productList.at(i).value("batch_no"));
- list.append(getDecimalbit(productList.at(i).value("gross_weight").toDouble()/1000.00));
- list.append(getDecimalbit(productList.at(i).value("net_weight").toDouble()/1000.00));
- list.append(productList.at(i).value("quantity"));
- auto item = new QTreeWidgetItem(list);
- auto tongbu_btn = new QPushButton("同步");
- connect(tongbu_btn,&QPushButton::clicked,[item,i,this](){this->tongbu_clicked(item,i);});
- // connect(tongbu_btn, SIGNAL(clicked(bool)), this, SLOT(tongbu_clicked()));
- auto code_single_btn = new QPushButton("打印码单");
- connect(code_single_btn,&QPushButton::clicked,[i,this](){this->code_single_clicked(i);});
- auto case_nember_btn = new QPushButton("打印箱单");
- connect(case_nember_btn,SIGNAL(clicked(bool)),this,SLOT(case_number_clicked()));
- ui->treeWidget->addTopLevelItem(item);
- ui->treeWidget->setItemWidget(item,7,tongbu_btn);
- ui->treeWidget->setItemWidget(item,8,code_single_btn);
- ui->treeWidget->setItemWidget(item,9,case_nember_btn);
- details = database.GetValues("details",detailSqlList," where code_single = "+product.at(i).value("code_single"));
- /*************************子项目****************************/
- //treewidget子项目标题
- QStringList columItemList;
- QTreeWidgetItem *child;
- columItemList<<"箱号"<<"毛重(千克/kg)"<<"净重(千克/kg)";
- child = new QTreeWidgetItem(columItemList);
- item->addChild(child);
- ui->treeWidget->setCurrentItem(child);
- //treewidget子项目数据循环添加
- for(int i=0; i<details.length(); ++i)
- {
- QStringList columItemList;
- QTreeWidgetItem *child;
- columItemList<<details.at(i).value("case_number")<<QString::number(details.at(i).value("gross_weight").toDouble()/1000)<<QString::number(details.at(i).value("net_weight").toDouble()/1000);
- child = new QTreeWidgetItem(columItemList);
- item->addChild(child);
- ui->treeWidget->setCurrentItem(child);
- }
- }
- /**************************************************************/
- ui->pageDataNum->setText("本页数据:"+QString::number(product.length()));
- ui->pagesNum->setText(QString("%1/%2").arg(nowPageNum+1).arg(pageNumAll));
- }
- //同步按钮
- void PackDetailForm::tongbu_clicked(QTreeWidgetItem * item,int row)
- {
- // qDebug()<<item->text(0);
- if(item->text(0) != "未同步"){
- QMessageBox::information(this,tr("提示"),tr("请刷新"));
- return;
- }
- QString condition = " where code_single="+product.at(row).value("code_single");
- details = database.GetValues("details",detailSqlList,condition);
- autoPack.doSend(autoPack.toJsonMap(product.at(row),details));
- item->setText(0,"请刷新");
- }
- void PackDetailForm::code_single_clicked(int row)
- {
- qDebug()<<"打印码单";
- // QStringList list;
- // list.append("net_weight");
- QString condition = " where code_single="+product.at(row).value("code_single");
- djmb.mapPrintPackInfo(product.at(row),database.GetValuesList("details","net_weight",condition));
- }
- void PackDetailForm::case_number_clicked()
- {
- qDebug()<<"打印箱单";//暂时不知道打哪个
- }
- //上一页
- void PackDetailForm::on_prevoiusPage_clicked()
- {
- if(nowPageNum<=0){
- return;
- }
- nowPageNum--;
- changeTreeWidget(database.GetValues("product",productSqlList,"limit "+QString::number(nowPageNum*20)+",20"));
- }
- //下一页
- void PackDetailForm::on_nextPage_clicked()
- {
- if(nowPageNum>=pageNumAll-1){
- return;
- }
- nowPageNum++;
- changeTreeWidget(database.GetValues("product",productSqlList,"limit "+QString::number(nowPageNum*20)+",20"));
- }
- //跳转
- void PackDetailForm::on_jump_clicked()
- {
- //判断jumpPage是否为数字,如果不是return
- if(ui->jumpPage->text().toInt() == false){
- return;
- }
- //判断jumpPage页数是否大于总页数,如果是return
- if(ui->jumpPage->text().toInt()>pageNumAll){
- return;
- }
- nowPageNum = ui->jumpPage->text().toInt()-1;
- changeTreeWidget(database.GetValues("product",productSqlList,"limit "+QString::number(nowPageNum*20)+",20"));
- }
- //用作product数据库要查询的字段
- void PackDetailForm::productList()
- {
- productSqlList.append("tongbu");
- productSqlList.append("goods_id");
- productSqlList.append("code_single");
- productSqlList.append("quantity");
- productSqlList.append("batch_no");
- productSqlList.append("level_id");
- productSqlList.append("tube_number");
- productSqlList.append("gross_weight");
- productSqlList.append("net_weight");
- productSqlList.append("machine_no");
- productSqlList.append("packing_time");
- productSqlList.append("packing_type");
- productSqlList.append("carton_type");
- productSqlList.append("operator_id");
- productSqlList.append("category");
- productSqlList.append("specs");
- productSqlList.append("denier");
- productSqlList.append("dtex");
- productSqlList.append("fiber");
- productSqlList.append("remark");
- }
- //用作details数据库要查询的字段
- void PackDetailForm::detailsList()
- {
- detailSqlList.append("code_single");
- detailSqlList.append("case_number");
- detailSqlList.append("box_weight");
- detailSqlList.append("tube_number");
- detailSqlList.append("bucket_weight");
- detailSqlList.append("gross_weight");
- detailSqlList.append("net_weight");
- detailSqlList.append("sort");
- detailSqlList.append("remark");
- }
- ////往QTableWidget里添加数据
- //void PackDetailForm::changeTable(QList<QMap<QString,QString>> productList)
- //{
- //// qDebug()<<productList.at(0).value("goods_id");
- // if(productList.isEmpty()){
- // QMessageBox::information(this,tr("提示"),tr("数据为空"));
- // return;
- // }
- // product = productList;
- // ui->tableWidget->setColumnCount(11);
- // for(int i = 0;i<productList.size();i++){
- // ui->tableWidget->insertRow(i);
- // ui->tableWidget->setItem(i,0,new QTableWidgetItem(productList.at(i).value("tongbu") == "0" ? "未同步" : "同步"));
- // if(ui->tableWidget->item(i,0)->text()=="未同步"){
- // ui->tableWidget->item(i,0)->setBackground(QBrush(QColor(255, 0, 0,180)));
- // }else{
- // ui->tableWidget->item(i,0)->setBackground(QBrush(QColor(0, 255, 255)));
- // }
- // ui->tableWidget->setItem(i,1,new QTableWidgetItem(productList.at(i).value("code_single")));
- // ui->tableWidget->setItem(i,2,new QTableWidgetItem(productList.at(i).value("batch_no")));
- // ui->tableWidget->setItem(i,3,new QTableWidgetItem(productList.at(i).value("gross_weight")));
- // ui->tableWidget->setItem(i,4,new QTableWidgetItem(productList.at(i).value("net_weight")));
- // ui->tableWidget->setItem(i,5,new QTableWidgetItem(productList.at(i).value("quantity")));
- // ui->tableWidget->setItem(i,6,new QTableWidgetItem(productList.at(i).value("packing_time")));
- // auto tongbu_btn = new QPushButton("同步");
- // connect(tongbu_btn,&QPushButton::clicked,[i,this](){this->tongbu_clicked(i);});
- //// connect(tongbu_btn, SIGNAL(clicked(bool)), this, SLOT(tongbu_clicked()));
- // auto code_single_btn = new QPushButton("打印码单");
- // connect(code_single_btn,SIGNAL(clicked(bool)),this,SLOT(code_single_clicked()));
- // auto case_nember_btn = new QPushButton("打印箱单");
- // connect(case_nember_btn,SIGNAL(clicked(bool)),this,SLOT(case_number_clicked()));
- // auto details = new QTreeWidget(this);
- //// auto details_btn = new QPushButton("");
- // ui->tableWidget->setCellWidget(i,7,tongbu_btn);
- // ui->tableWidget->setCellWidget(i,8,code_single_btn);
- // ui->tableWidget->setCellWidget(i,9,case_nember_btn);
- // ui->tableWidget->setCellWidget(i,10,details);
- // details->setWindowTitle("tree");
- // QTreeWidgetItem* detail = new QTreeWidgetItem(QStringList()<<"详情");
- //// detail->setCheckState(0, Qt::Checked);
- //// details->setSortingEnabled(true);
- // details->header()->setSortIndicator(0,Qt::AscendingOrder);
- // details->addTopLevelItem(detail);
- // details->header()->setVisible(false);
- // for(int i=0; i<10; ++i)
- // {
- // QStringList columItemList;
- // QTreeWidgetItem *child;
- // columItemList<<"list";
- // child = new QTreeWidgetItem(columItemList);
- // detail->addChild(child);
- // details->setItemWidget(child,1,new QSpinBox);
- // }
- // }
- //}
- //同步
- //void PackDetailForm::tongbu_clicked(int row)
- //{
- // qDebug()<<"行数:" << row;
- // if(ui->tableWidget->item(row,0)->text()!="未同步"){
- // QMessageBox::information(this,tr("提示"),tr("请刷新"));
- // return;
- // }
- // QString condition = " where code_single="+product.at(row).value("code_single");
- // details = database.GetValues("details",detailSqlList,condition);
- // autoPack.doSend(autoPack.toJsonMap(product.at(row),details));
- // ui->tableWidget->setItem(row,0,new QTableWidgetItem("请刷新"));
- // ui->tableWidget->item(row,0)->setBackground(QBrush(QColor(255,255,0)));
- //}
|