Sun, 20 Mar 2022 21:24:13 +0100
Profile Styles now on the mainscreen.
CMakeLists.txt | file | annotate | diff | comparison | revisions | |
src/MainWindow.cpp | file | annotate | diff | comparison | revisions | |
src/ProfileStyles.cpp | file | annotate | diff | comparison | revisions | |
src/ProfileStyles.h | file | annotate | diff | comparison | revisions | |
ui/ProfileStyles.ui | file | annotate | diff | comparison | revisions |
--- a/CMakeLists.txt Sun Mar 20 20:59:05 2022 +0100 +++ b/CMakeLists.txt Sun Mar 20 21:24:13 2022 +0100 @@ -175,7 +175,6 @@ ${UIDIR}/EditEquipment.ui ${UIDIR}/EditProfileWater.ui ${UIDIR}/EditProfileMash.ui - ${UIDIR}/ProfileStyles.ui ${UIDIR}/EditProfileStyle.ui ${UIDIR}/ProfileFerments.ui ${UIDIR}/EditProfileFerment.ui
--- a/src/MainWindow.cpp Sun Mar 20 20:59:05 2022 +0100 +++ b/src/MainWindow.cpp Sun Mar 20 21:24:13 2022 +0100 @@ -291,8 +291,11 @@ void MainWindow::fromProfileStyles() { qDebug() << Q_FUNC_INFO; + ui->mainStack->setCurrentIndex(-1); + ui->mainStack->removeWidget(ProfileStylesWindow); delete ProfileStylesWindow; - this->show(); + setWindowTitle( QString("BMSapp - %1").arg(VERSIONSTRING) ); + ui->menuBar->setVisible(true); } @@ -300,9 +303,11 @@ { qDebug() << Q_FUNC_INFO; ProfileStylesWindow = new ProfileStyles(this); - QObject::connect(ProfileStylesWindow, SIGNAL(firstWindow()), this, SLOT(fromProfileStyles())); - this->hide(); // Close the main window - ProfileStylesWindow->show(); // Show a second window + int index = ui->mainStack->count(); + ui->mainStack->addWidget(ProfileStylesWindow); + ui->mainStack->setCurrentIndex(index); + setWindowTitle(QString("BMSapp - %1 - Styles Profiles").arg(VERSIONSTRING)); + ui->menuBar->setVisible(false); }
--- a/src/ProfileStyles.cpp Sun Mar 20 20:59:05 2022 +0100 +++ b/src/ProfileStyles.cpp Sun Mar 20 21:24:13 2022 +0100 @@ -16,19 +16,58 @@ */ #include "ProfileStyles.h" #include "EditProfileStyle.h" -#include "../ui/ui_ProfileStyles.h" +#include "MainWindow.h" #include "config.h" #include "bmsapp.h" -ProfileStyles::ProfileStyles(QWidget *parent) : QDialog(parent), ui(new Ui::ProfileStyles) +ProfileStyles::ProfileStyles(QWidget *parent) : QDialog(parent) { qDebug() << "ProfileStyles start"; - ui->setupUi(this); + gridLayout = new QGridLayout(this); + gridLayout->setObjectName(QString::fromUtf8("gridLayout")); + tableStyles = new QTableWidget(this); + tableStyles->setObjectName(QString::fromUtf8("tableStyles")); + tableStyles->setEnabled(true); + QSizePolicy sizePolicy(QSizePolicy::Fixed, QSizePolicy::Expanding); + sizePolicy.setHorizontalStretch(0); + sizePolicy.setVerticalStretch(0); + tableStyles->setSizePolicy(sizePolicy); + tableStyles->setMinimumSize(QSize(1049, 0)); + gridLayout->addWidget(tableStyles, 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); + + 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(fromProfileStyles())); + connect(insertButton, SIGNAL(clicked()), this, SLOT(on_insertButton_clicked())); emit refreshTable(); - - setWindowTitle( QString("BMSapp - %1 - Profile Styles").arg(VERSIONSTRING) ); } @@ -45,96 +84,95 @@ const QStringList labels({tr("Guide"), tr("Gr"), tr("Name"), tr("OG"), tr("OG"), tr("FG"), tr("FG"), tr("IBU"), tr("IBU"), tr("EBC"), tr("EBC"), tr("Co2"), tr("Co2"), tr("ABV"), tr("ABV"), tr("Edit")}); - ui->tableStyles->setColumnCount(16); - ui->tableStyles->setColumnWidth(0, 100); /* Guide */ - ui->tableStyles->setColumnWidth(1, 25); /* Group */ - ui->tableStyles->setColumnWidth(2, 300); /* Name */ - ui->tableStyles->setColumnWidth(3, 50); /* OG */ - ui->tableStyles->setColumnWidth(4, 50); - ui->tableStyles->setColumnWidth(5, 50); /* FG */ - ui->tableStyles->setColumnWidth(6, 50); - ui->tableStyles->setColumnWidth(7, 40); /* IBU */ - ui->tableStyles->setColumnWidth(8, 40); - ui->tableStyles->setColumnWidth(9, 40); /* EBC */ - ui->tableStyles->setColumnWidth(10, 40); - ui->tableStyles->setColumnWidth(11, 40); /* Co2 */ - ui->tableStyles->setColumnWidth(12, 40); - ui->tableStyles->setColumnWidth(13, 40); /* ABV */ - ui->tableStyles->setColumnWidth(14, 40); - ui->tableStyles->setColumnWidth(15, 80); /* Edit button */ - ui->tableStyles->setRowCount(query.size()); - ui->tableStyles->setHorizontalHeaderLabels(labels); - ui->tableStyles->verticalHeader()->hide(); - ui->tableStyles->setFixedSize(1025 + 24, 640); /* Even if this is too large, it works */ + this->tableStyles->setColumnCount(16); + this->tableStyles->setColumnWidth(0, 100); /* Guide */ + this->tableStyles->setColumnWidth(1, 25); /* Group */ + this->tableStyles->setColumnWidth(2, 300); /* Name */ + this->tableStyles->setColumnWidth(3, 50); /* OG */ + this->tableStyles->setColumnWidth(4, 50); + this->tableStyles->setColumnWidth(5, 50); /* FG */ + this->tableStyles->setColumnWidth(6, 50); + this->tableStyles->setColumnWidth(7, 40); /* IBU */ + this->tableStyles->setColumnWidth(8, 40); + this->tableStyles->setColumnWidth(9, 40); /* EBC */ + this->tableStyles->setColumnWidth(10, 40); + this->tableStyles->setColumnWidth(11, 40); /* Co2 */ + this->tableStyles->setColumnWidth(12, 40); + this->tableStyles->setColumnWidth(13, 40); /* ABV */ + this->tableStyles->setColumnWidth(14, 40); + this->tableStyles->setColumnWidth(15, 80); /* Edit button */ + this->tableStyles->setRowCount(query.size()); + this->tableStyles->setHorizontalHeaderLabels(labels); + this->tableStyles->verticalHeader()->hide(); QTableWidgetItem *rightitem = new QTableWidgetItem(); rightitem->setTextAlignment(Qt::AlignRight); query.first(); for (int ridx = 0 ; ridx < query.size() ; ridx++ ) { - ui->tableStyles->setItem(ridx, 0, new QTableWidgetItem(query.value(5).toString())); /* Guide */ - ui->tableStyles->setItem(ridx, 1, new QTableWidgetItem(query.value(4).toString())); /* Goup */ - ui->tableStyles->setItem(ridx, 2, new QTableWidgetItem(query.value(1).toString())); /* Name */ + this->tableStyles->setItem(ridx, 0, new QTableWidgetItem(query.value(5).toString())); /* Guide */ + this->tableStyles->setItem(ridx, 1, new QTableWidgetItem(query.value(4).toString())); /* Goup */ + this->tableStyles->setItem(ridx, 2, new QTableWidgetItem(query.value(1).toString())); /* Name */ w = QString("%1").arg(query.value(7).toDouble(), 4, 'f', 3, '0' ); /* OG */ QTableWidgetItem *item = new QTableWidgetItem(w); item->setTextAlignment(Qt::AlignRight|Qt::AlignVCenter); - ui->tableStyles->setItem(ridx, 3, item); + this->tableStyles->setItem(ridx, 3, item); w = QString("%1").arg(query.value(8).toDouble(), 4, 'f', 3, '0' ); /* OG */ item = new QTableWidgetItem(w); item->setTextAlignment(Qt::AlignRight|Qt::AlignVCenter); - ui->tableStyles->setItem(ridx, 4, item); + this->tableStyles->setItem(ridx, 4, item); w = QString("%1").arg(query.value(9).toDouble(), 4, 'f', 3, '0' ); /* FG */ item = new QTableWidgetItem(w); item->setTextAlignment(Qt::AlignRight|Qt::AlignVCenter); - ui->tableStyles->setItem(ridx, 5, item); + this->tableStyles->setItem(ridx, 5, item); w = QString("%1").arg(query.value(10).toDouble(), 4, 'f', 3, '0' ); /* FG */ item = new QTableWidgetItem(w); item->setTextAlignment(Qt::AlignRight|Qt::AlignVCenter); - ui->tableStyles->setItem(ridx, 6, item); + this->tableStyles->setItem(ridx, 6, item); w = QString("%1").arg(query.value(11).toDouble(), 1, 'f', 0, '0' ); /* IBU */ item = new QTableWidgetItem(w); item->setTextAlignment(Qt::AlignRight|Qt::AlignVCenter); - ui->tableStyles->setItem(ridx, 7, item); + this->tableStyles->setItem(ridx, 7, item); w = QString("%1").arg(query.value(12).toDouble(), 1, 'f', 0, '0' ); /* IBU */ item = new QTableWidgetItem(w); item->setTextAlignment(Qt::AlignRight|Qt::AlignVCenter); - ui->tableStyles->setItem(ridx, 8, item); + this->tableStyles->setItem(ridx, 8, item); w = QString("%1").arg(query.value(13).toDouble(), 1, 'f', 0, '0' ); /* EBC */ item = new QTableWidgetItem(w); item->setTextAlignment(Qt::AlignRight|Qt::AlignVCenter); - ui->tableStyles->setItem(ridx, 9, item); + this->tableStyles->setItem(ridx, 9, item); w = QString("%1").arg(query.value(14).toDouble(), 1, 'f', 0, '0' ); /* EBC */ item = new QTableWidgetItem(w); item->setTextAlignment(Qt::AlignRight|Qt::AlignVCenter); - ui->tableStyles->setItem(ridx, 10, item); + this->tableStyles->setItem(ridx, 10, item); w = QString("%1").arg(query.value(15).toDouble(), 2, 'f', 1, '0' ); /* Co2 */ item = new QTableWidgetItem(w); item->setTextAlignment(Qt::AlignRight|Qt::AlignVCenter); - ui->tableStyles->setItem(ridx, 11, item); + this->tableStyles->setItem(ridx, 11, item); w = QString("%1").arg(query.value(16).toDouble(), 2, 'f', 1, '0' ); /* Co2 */ item = new QTableWidgetItem(w); item->setTextAlignment(Qt::AlignRight|Qt::AlignVCenter); - ui->tableStyles->setItem(ridx, 12, item); + this->tableStyles->setItem(ridx, 12, item); w = QString("%1").arg(query.value(17).toDouble(), 2, 'f', 1, '0' ); /* ABV */ item = new QTableWidgetItem(w); item->setTextAlignment(Qt::AlignRight|Qt::AlignVCenter); - ui->tableStyles->setItem(ridx, 13, item); + this->tableStyles->setItem(ridx, 13, item); w = QString("%1").arg(query.value(18).toDouble(), 2, 'f', 1, '0' ); /* ABV */ item = new QTableWidgetItem(w); item->setTextAlignment(Qt::AlignRight|Qt::AlignVCenter); - ui->tableStyles->setItem(ridx, 14, item); + this->tableStyles->setItem(ridx, 14, item); /* Add the Edit button */ pWidget = new QWidget(); @@ -146,25 +184,17 @@ pLayout->addWidget(btn_edit); pLayout->setContentsMargins(5, 0, 5, 0); pWidget->setLayout(pLayout); - ui->tableStyles->setCellWidget(ridx, 15, pWidget); + this->tableStyles->setCellWidget(ridx, 15, pWidget); query.next(); } - - setWindowTitle( QString("BMSapp - %1 - Profile Styles").arg(VERSIONSTRING) ); } -ProfileStyles::~ProfileStyles() -{ - qDebug() << "ProfileStyles done"; - delete ui; -} +ProfileStyles::~ProfileStyles() {} void ProfileStyles::edit(int recno) { - qDebug() << "ProfileStyles edit:" << recno; - EditProfileStyle dialog(recno, this); /* Signal from editor if a refresh is needed */ connect(&dialog, SIGNAL(entry_changed()), this, SLOT(refreshTable())); @@ -177,20 +207,13 @@ { QPushButton *pb = qobject_cast<QPushButton *>(QObject::sender()); int recno = pb->objectName().toInt(); - qDebug() << Q_FUNC_INFO << recno; edit(recno); } void ProfileStyles::on_insertButton_clicked() { - qDebug() << Q_FUNC_INFO; edit(-1); } -void ProfileStyles::on_quitButton_clicked() -{ - emit firstWindow(); -} -
--- a/src/ProfileStyles.h Sun Mar 20 20:59:05 2022 +0100 +++ b/src/ProfileStyles.h Sun Mar 20 21:24:13 2022 +0100 @@ -2,6 +2,12 @@ #define _PROFILESTYLES_H #include <QDialog> +#include <QtWidgets/QGridLayout> +#include <QtWidgets/QGroupBox> +#include <QtWidgets/QHBoxLayout> +#include <QtWidgets/QHeaderView> +#include <QtWidgets/QPushButton> +#include <QtWidgets/QTableWidget> namespace Ui { class ProfileStyles; @@ -15,17 +21,19 @@ explicit ProfileStyles(QWidget *parent = nullptr); ~ProfileStyles(); -signals: - void firstWindow(); - private slots: - void on_quitButton_clicked(); void on_insertButton_clicked(); void on_editButton_clicked(); void refreshTable(void); private: - Ui::ProfileStyles *ui; + QGridLayout *gridLayout; + QTableWidget *tableStyles; + QGroupBox *groupBox; + QHBoxLayout *horizontalLayout; + QPushButton *quitButton; + QPushButton *insertButton; + void edit(int recno); };
--- a/ui/ProfileStyles.ui Sun Mar 20 20:59:05 2022 +0100 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,103 +0,0 @@ -<?xml version="1.0" encoding="UTF-8"?> -<ui version="4.0"> - <class>ProfileStyles</class> - <widget class="QDialog" name="ProfileStyles"> - <property name="geometry"> - <rect> - <x>0</x> - <y>0</y> - <width>1280</width> - <height>640</height> - </rect> - </property> - <property name="windowTitle"> - <string>Dialog</string> - </property> - <layout class="QGridLayout" name="gridLayout"> - <item row="0" column="0"> - <widget class="QTableWidget" name="tableStyles"> - <property name="enabled"> - <bool>true</bool> - </property> - </widget> - </item> - <item row="1" column="0"> - <widget class="QGroupBox" name="groupBox"> - <property name="enabled"> - <bool>true</bool> - </property> - <property name="flat"> - <bool>false</bool> - </property> - <layout class="QHBoxLayout" name="horizontalLayout"> - <property name="spacing"> - <number>6</number> - </property> - <property name="leftMargin"> - <number>0</number> - </property> - <property name="topMargin"> - <number>0</number> - </property> - <property name="rightMargin"> - <number>0</number> - </property> - <property name="bottomMargin"> - <number>0</number> - </property> - <item alignment="Qt::AlignLeft"> - <widget class="QPushButton" name="quitButton"> - <property name="sizePolicy"> - <sizepolicy hsizetype="Fixed" vsizetype="Fixed"> - <horstretch>0</horstretch> - <verstretch>0</verstretch> - </sizepolicy> - </property> - <property name="minimumSize"> - <size> - <width>80</width> - <height>24</height> - </size> - </property> - <property name="text"> - <string>Quit</string> - </property> - <property name="icon"> - <iconset> - <normaloff>:icons/silk/door_out.png</normaloff>:icons/silk/door_out.png</iconset> - </property> - </widget> - </item> - <item> - <widget class="QPushButton" name="insertButton"> - <property name="sizePolicy"> - <sizepolicy hsizetype="Fixed" vsizetype="Fixed"> - <horstretch>0</horstretch> - <verstretch>0</verstretch> - </sizepolicy> - </property> - <property name="minimumSize"> - <size> - <width>80</width> - <height>24</height> - </size> - </property> - <property name="text"> - <string>New</string> - </property> - <property name="icon"> - <iconset> - <normaloff>:icons/silk/table_row_insert.png</normaloff>:icons/silk/table_row_insert.png</iconset> - </property> - </widget> - </item> - </layout> - </widget> - </item> - </layout> - </widget> - <resources> - <include location="../../../../../../home/mbroek/MyProjects/bmsapp/resources/icons.qrc"/> - </resources> - <connections/> -</ui>