/*
* productinventory.h a part of ProductInventory
* An inventory system designed for makeup and related things
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
*/
#ifndef PRODUCTINVENTORY_H
#define PRODUCTINVENTORY_H
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
namespace Ui {
class ProductInventory;
}
class ProductInventory : public QMainWindow
{
Q_OBJECT
public:
explicit ProductInventory(QWidget *parent = nullptr);
~ProductInventory();
bool getConnectionStatus(); // get database connection status
void statusMessage(QString msg, int ms); // overload, show message in status bar for ms milliseconds
void statusMessage(QString msg, QString color, int ms); // show message in status bar for ms milliseconds
void genericMessageBox(QString msg, QString title); // display a generic message box
QSqlQuery *genericQuery(QString query); // run generic query and return a pointer to the new object
private slots:
void statusChanged(QString msg); // called when the status bar value is changed
void on_connectButton_clicked(); // called when the connect button is pressed
void on_mustHaveImagesCheckBox_clicked(); // called when must have images filter selected
void on_mustNotHaveImagesCheckBox_clicked(); // called when must not have images filter selected
void on_selectAllButton_clicked();
void on_unselectAllButton_clicked();
void on_checkBox_2_clicked();
void on_filterSortAlphaCheckBox_clicked();
void on_filterSortRevAlphaCheckBox_clicked();
void on_filterSortAlphabeticalCheckBox_clicked();
void on_filterSortReverseAlphabeticalCheckbox_clicked();
void on_filterSortReverseAlphabeticalCheckBox_clicked();
void on_newestFirstCheckBox_clicked();
void on_oldestFirstCheckBox_clicked();
private:
Ui::ProductInventory *ui;
QString conStatus; // connection status text
QString conColor; // color of current connection status
bool isConnected; // store our conection status
bool dbConnect(); // connect to database
bool dbDisconnect(); // disconnect from database
QSqlDatabase db; // database object
void resizeEvent(QResizeEvent *event); // called when the window is resized
void populateInterface(); // called when we want to populate interface elements
void addItemToTable(QTableWidget *table,
QList *values); // add item to the specified table with the provided values
void clearTables(); // clear and delete every QTabeWidgetItem in each table
QList tables; // store our tables
int createTable(QString category); // create a table and add it to our tables list with a header, returns index in list or -1
QStringList headerLabels; // labels used for table headers
QList labels; // labels used for table names
void resizeRows(); // resize all table rows to fit the content
QList checkboxes; // checkboxes used to filter product categories
};
#endif // PRODUCTINVENTORY_H