diff -r abac28effb21 -r 228cb2a01acf src/InventoryHops.cpp --- a/src/InventoryHops.cpp Sun Mar 20 15:51:09 2022 +0100 +++ b/src/InventoryHops.cpp Sun Mar 20 16:13:26 2022 +0100 @@ -16,19 +16,79 @@ */ #include "InventoryHops.h" #include "EditHop.h" -#include "../ui/ui_InventoryHops.h" +#include "MainWindow.h" #include "config.h" #include "bmsapp.h" -InventoryHops::InventoryHops(QWidget *parent) : QDialog(parent), ui(new Ui::InventoryHops) +InventoryHops::InventoryHops(QWidget *parent) : QDialog(parent) { qDebug() << "InventoryHops start"; - ui->setupUi(this); + gridLayout = new QGridLayout(this); + gridLayout->setObjectName(QString::fromUtf8("gridLayout")); + tableHops = new QTableWidget(this); + tableHops->setObjectName(QString::fromUtf8("tableHops")); + tableHops->setEnabled(true); + QSizePolicy sizePolicy(QSizePolicy::Fixed, QSizePolicy::Expanding); + sizePolicy.setHorizontalStretch(0); + sizePolicy.setVerticalStretch(0); + //sizePolicy.setHeightForWidth(tableHops->sizePolicy().hasHeightForWidth()); + tableHops->setSizePolicy(sizePolicy); + tableHops->setMinimumSize(QSize(1124, 0)); + gridLayout->addWidget(tableHops, 0, 0, 1, 1); + + groupBox = new QGroupBox(this); + groupBox->setObjectName(QString::fromUtf8("groupBox")); + groupBox->setEnabled(true); + groupBox->setFlat(false); + horizontalLayout = new QHBoxLayout(groupBox); + horizontalLayout->setSpacing(6); + horizontalLayout->setObjectName(QString::fromUtf8("horizontalLayout")); + horizontalLayout->setContentsMargins(0, 0, 0, 0); + + quitButton = new QPushButton(groupBox); + quitButton->setObjectName(QString::fromUtf8("quitButton")); + quitButton->setMinimumSize(QSize(80, 24)); + quitButton->setText(tr("Quit")); + QIcon icon; + icon.addFile(QString::fromUtf8(":icons/silk/door_out.png"), QSize(), QIcon::Normal, QIcon::Off); + quitButton->setIcon(icon); + horizontalLayout->addWidget(quitButton, 0, Qt::AlignLeft); + + exportButton = new QPushButton(groupBox); + exportButton->setObjectName(QString::fromUtf8("exportButton")); + exportButton->setMinimumSize(QSize(80, 24)); + exportButton->setText(tr("Export")); + QIcon icon1; + icon1.addFile(QString::fromUtf8(":/icons/silk/database_save.png"), QSize(), QIcon::Normal, QIcon::Off); + exportButton->setIcon(icon1); + horizontalLayout->addWidget(exportButton, 0, Qt::AlignRight); + + importButton = new QPushButton(groupBox); + importButton->setObjectName(QString::fromUtf8("importButton")); + importButton->setMinimumSize(QSize(80, 24)); + importButton->setText(tr("Import")); + QIcon icon2; + icon2.addFile(QString::fromUtf8(":/icons/silk/database_add.png"), QSize(), QIcon::Normal, QIcon::Off); + importButton->setIcon(icon2); + horizontalLayout->addWidget(importButton, 0, Qt::AlignRight); + + insertButton = new QPushButton(groupBox); + insertButton->setObjectName(QString::fromUtf8("insertButton")); + insertButton->setMinimumSize(QSize(80, 24)); + insertButton->setText(tr("New")); + QIcon icon3; + icon3.addFile(QString::fromUtf8(":icons/silk/table_row_insert.png"), QSize(), QIcon::Normal, QIcon::Off); + insertButton->setIcon(icon3); + horizontalLayout->addWidget(insertButton, 0, Qt::AlignRight); + gridLayout->addWidget(groupBox, 1, 0, 1, 1); + + connect(quitButton, SIGNAL(clicked()), parent, SLOT(fromInventoryHops())); + connect(insertButton, SIGNAL(clicked()), this, SLOT(on_insertButton_clicked())); + connect(exportButton, SIGNAL(clicked()), this, SLOT(on_exportButton_clicked())); +// connect(importButton, SIGNAL(clicked()), this, SLOT(on_importButton_clicked())); emit refreshTable(); - - setWindowTitle( QString("BMSapp - %1 - Inventory Hops").arg(VERSIONSTRING) ); } @@ -44,55 +104,54 @@ const QStringList form({tr("Pellet"), tr("Plug"), tr("Leaf"), tr("Leaf Wet"), tr("Cryo")}); /* origin supplier name type graintype color yield inventory Edit */ - ui->tableHops->setColumnCount(11); - ui->tableHops->setColumnWidth(0, 130); /* Origin */ - ui->tableHops->setColumnWidth(1, 250); /* Name */ - ui->tableHops->setColumnWidth(2, 80); /* Type */ - ui->tableHops->setColumnWidth(3, 80); /* Form */ - ui->tableHops->setColumnWidth(4, 80); /* Alpha */ - ui->tableHops->setColumnWidth(5, 80); /* Beta */ - ui->tableHops->setColumnWidth(6, 80); /* cohumulone */ - ui->tableHops->setColumnWidth(7, 80); /* HSI */ - ui->tableHops->setColumnWidth(8, 80); /* Harvest date */ - ui->tableHops->setColumnWidth(9, 80); /* Stock */ - ui->tableHops->setColumnWidth(10, 80); /* Edit button */ - ui->tableHops->setRowCount(query.size()); - ui->tableHops->setHorizontalHeaderLabels(labels); - ui->tableHops->verticalHeader()->hide(); - ui->tableHops->setFixedSize(1100 + 24, 640); /* Even if this is too large, it works */ + this->tableHops->setColumnCount(11); + this->tableHops->setColumnWidth(0, 130); /* Origin */ + this->tableHops->setColumnWidth(1, 250); /* Name */ + this->tableHops->setColumnWidth(2, 80); /* Type */ + this->tableHops->setColumnWidth(3, 80); /* Form */ + this->tableHops->setColumnWidth(4, 80); /* Alpha */ + this->tableHops->setColumnWidth(5, 80); /* Beta */ + this->tableHops->setColumnWidth(6, 80); /* cohumulone */ + this->tableHops->setColumnWidth(7, 80); /* HSI */ + this->tableHops->setColumnWidth(8, 80); /* Harvest date */ + this->tableHops->setColumnWidth(9, 80); /* Stock */ + this->tableHops->setColumnWidth(10, 80); /* Edit button */ + this->tableHops->setRowCount(query.size()); + this->tableHops->setHorizontalHeaderLabels(labels); + this->tableHops->verticalHeader()->hide(); QTableWidgetItem *rightitem = new QTableWidgetItem(); rightitem->setTextAlignment(Qt::AlignRight); query.first(); for (int ridx = 0 ; ridx < query.size() ; ridx++ ) { - ui->tableHops->setItem(ridx, 0, new QTableWidgetItem(query.value(12).toString())); /* Origin */ - ui->tableHops->setItem(ridx, 1, new QTableWidgetItem(query.value(1).toString())); /* Name */ - ui->tableHops->setItem(ridx, 2, new QTableWidgetItem(types[query.value(9).toInt()])); /* Type */ - ui->tableHops->setItem(ridx, 3, new QTableWidgetItem(form[query.value(10).toInt()])); /* Form */ + this->tableHops->setItem(ridx, 0, new QTableWidgetItem(query.value(12).toString())); /* Origin */ + this->tableHops->setItem(ridx, 1, new QTableWidgetItem(query.value(1).toString())); /* Name */ + this->tableHops->setItem(ridx, 2, new QTableWidgetItem(types[query.value(9).toInt()])); /* Type */ + this->tableHops->setItem(ridx, 3, new QTableWidgetItem(form[query.value(10).toInt()])); /* Form */ w = QString("%1 %").arg(query.value(2).toDouble(), 2, 'f', 1, '0' ); /* Alpha% */ QTableWidgetItem *item = new QTableWidgetItem(w); item->setTextAlignment(Qt::AlignRight|Qt::AlignVCenter); - ui->tableHops->setItem(ridx, 4, item); + this->tableHops->setItem(ridx, 4, item); w = QString("%1 %").arg(query.value(3).toDouble(), 2, 'f', 1, '0' ); /* Beta% */ item = new QTableWidgetItem(w); item->setTextAlignment(Qt::AlignRight|Qt::AlignVCenter); - ui->tableHops->setItem(ridx, 5, item); + this->tableHops->setItem(ridx, 5, item); w = QString("%1 %").arg(query.value(6).toDouble(), 2, 'f', 1, '0' ); /* Cohumulone */ item = new QTableWidgetItem(w); item->setTextAlignment(Qt::AlignRight|Qt::AlignVCenter); - ui->tableHops->setItem(ridx, 6, item); + this->tableHops->setItem(ridx, 6, item); w = QString("%1").arg(query.value(8).toDouble(), 2, 'f', 1, '0' ); /* HSI */ item = new QTableWidgetItem(w); item->setTextAlignment(Qt::AlignRight|Qt::AlignVCenter); - ui->tableHops->setItem(ridx, 7, item); + this->tableHops->setItem(ridx, 7, item); if (query.value(15).toDouble() > 0) - ui->tableHops->setItem(ridx, 8, new QTableWidgetItem(query.value(17).toString())); /* Harvest */ + this->tableHops->setItem(ridx, 8, new QTableWidgetItem(query.value(17).toString())); /* Harvest */ else - ui->tableHops->setItem(ridx, 8, new QTableWidgetItem(QString(""))); + this->tableHops->setItem(ridx, 8, new QTableWidgetItem(QString(""))); w = QString(""); if (query.value(15).toDouble() > 0) { @@ -104,7 +163,7 @@ } item = new QTableWidgetItem(w); item->setTextAlignment(Qt::AlignRight|Qt::AlignVCenter); - ui->tableHops->setItem(ridx, 9, item); + this->tableHops->setItem(ridx, 9, item); /* Add the Edit button */ QWidget* pWidget = new QWidget(); @@ -116,25 +175,17 @@ pLayout->addWidget(btn_edit); pLayout->setContentsMargins(5, 0, 5, 0); pWidget->setLayout(pLayout); - ui->tableHops->setCellWidget(ridx, 10, pWidget); + this->tableHops->setCellWidget(ridx, 10, pWidget); query.next(); } - - setWindowTitle( QString("BMSapp - %1 - Inventory Hops").arg(VERSIONSTRING) ); } -InventoryHops::~InventoryHops() -{ - qDebug() << "InventoryHops done"; - delete ui; -} +InventoryHops::~InventoryHops() {} void InventoryHops::edit(int recno) { - qDebug() << "InventoryHops edit:" << recno; - EditHop dialog(recno, this); /* Signal from editor if a refresh is needed */ connect(&dialog, SIGNAL(entry_changed()), this, SLOT(refreshTable())); @@ -147,14 +198,12 @@ { QPushButton *pb = qobject_cast(QObject::sender()); int recno = pb->objectName().toInt(); - qDebug() << Q_FUNC_INFO << recno; edit(recno); } void InventoryHops::on_insertButton_clicked() { - qDebug() << Q_FUNC_INFO; edit(-1); } @@ -166,9 +215,9 @@ QSqlQuery query("SELECT * FROM inventory_hops ORDER BY origin,name"); const QStringList types({ "Bittering", "Aroma", "Both" }); const QStringList forms({ "Pellet", "Plug", "Leaf", "Leaf", "Pellet" }); - /* "Leaf Wet", "Cryo" */ - /* We use more hp forms then beerxml knows about, so we send known names */ - /* instead of what we internally use. */ + /* "Leaf Wet", "Cryo" */ + /* We use more hop forms then beerxml knows about, so we send known names */ + /* instead of what we internally use. */ QString fileName = QFileDialog::getSaveFileName(this, tr("Save File"), QDir::homePath() + "/hops.xml", tr("Files (*.xml)")); if (fileName == 0) { @@ -220,8 +269,3 @@ } -void InventoryHops::on_quitButton_clicked() -{ - emit firstWindow(); -} -