src/InventoryHops.cpp

changeset 69
228cb2a01acf
parent 44
5a9a159c2d34
child 79
e726db72da3c
--- 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<QPushButton *>(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();
-}
-

mercurial