Compare commits

...

2 commits

Author SHA1 Message Date
2812f582a1 more on sellers 2018-07-16 18:04:25 +02:00
a2ad2eb57d more on sellers 2018-07-16 15:30:24 +02:00
11 changed files with 165 additions and 44 deletions

View file

@ -145,7 +145,7 @@ void Database::beginTransaction() { exec("BEGIN TRANSACTION"); }
void Database::endTransaction() { exec("END TRANSACTION"); } void Database::endTransaction() { exec("END TRANSACTION"); }
unsigned int Database::storeSellers(std::vector<std::shared_ptr<Seller>>& sellers) unsigned int Database::storeSellers(std::vector<std::unique_ptr<Seller>>& sellers)
{ {
int retCode{}; int retCode{};
int count{}; int count{};
@ -165,10 +165,9 @@ unsigned int Database::storeSellers(std::vector<std::shared_ptr<Seller>>& seller
if (retCode != SQLITE_OK) if (retCode != SQLITE_OK)
throw std::runtime_error(sqlite3_errmsg(db_)); throw std::runtime_error(sqlite3_errmsg(db_));
int test = sqlite3_bind_text(stmt, sqlite3_bind_parameter_index(stmt, ":uuid"), sqlite3_bind_text(stmt, sqlite3_bind_parameter_index(stmt, ":uuid"),
boost::uuids::to_string(seller->getUuid()).c_str(), -1, boost::uuids::to_string(seller->getUuid()).c_str(), -1,
SQLITE_TRANSIENT); SQLITE_TRANSIENT);
std::cout << "!!! TEST: " << test << "\n";
sqlite3_bind_int(stmt, sqlite3_bind_parameter_index(stmt, ":seller_no"), sqlite3_bind_int(stmt, sqlite3_bind_parameter_index(stmt, ":seller_no"),
seller->getSellerNo()); seller->getSellerNo());
sqlite3_bind_text(stmt, sqlite3_bind_parameter_index(stmt, ":first_name"), sqlite3_bind_text(stmt, sqlite3_bind_parameter_index(stmt, ":first_name"),
@ -254,12 +253,14 @@ unsigned int Database::storeSellers(std::vector<std::shared_ptr<Seller>>& seller
endTransaction(); endTransaction();
// Everything went fine, so we can now update our objects // Everything went fine, so we can now update our objects
sellers.erase( sellers.erase(std::remove_if(sellers.begin(), sellers.end(),
std::remove_if(begin(sellers), end(sellers), [](const std::shared_ptr<Seller>& seller) { [](const std::unique_ptr<Seller>& seller) {
return seller->getState() == Seller::State::DELETE; return (seller->getState() == Seller::State::DELETE);
})); }),
for (const auto& seller : sellers) { sellers.end());
for (auto& seller : sellers) {
seller->cleanupArticles(); seller->cleanupArticles();
seller->setState(Seller::State::OK); seller->setState(Seller::State::OK);
} }

View file

@ -16,7 +16,7 @@ class Database
Database& operator=(const Database&) = delete; Database& operator=(const Database&) = delete;
void exec(const std::string& sql); void exec(const std::string& sql);
void init(); void init();
unsigned int storeSellers(std::vector<std::shared_ptr<Seller>>& sellers); unsigned int storeSellers(std::vector<std::unique_ptr<Seller>>& sellers);
private: private:
sqlite3* db_; sqlite3* db_;

View file

@ -1,10 +1,13 @@
#include "marketplace.h" #include "marketplace.h"
#include "database.h" #include "database.h"
#include <algorithm>
Marketplace::Marketplace() Marketplace::Marketplace()
{ {
auto seller = std::make_shared<Seller>("Max", "Mustermann"); auto seller = std::make_unique<Seller>("Max", "Mustermann");
sellers_.push_back(seller); seller->createUuid();
sellers_.push_back(std::move(seller));
} }
void Marketplace::storeToDb() void Marketplace::storeToDb()
@ -12,7 +15,20 @@ void Marketplace::storeToDb()
const std::string DB_PATH{"/tmp/kima2.db"}; const std::string DB_PATH{"/tmp/kima2.db"};
Database db(DB_PATH); Database db(DB_PATH);
db.init();
db.storeSellers(sellers_); db.storeSellers(sellers_);
} }
std::vector<std::shared_ptr<Seller>>& Marketplace::getSellers() { return sellers_; } void Marketplace::loadFromDb() {}
std::vector<std::unique_ptr<Seller>>& Marketplace::getSellers() { return sellers_; }
int Marketplace::getNextSellerNo()
{
auto iter = std::max_element(
sellers_.begin(), sellers_.end(),
[](const std::unique_ptr<Seller>& a, const std::unique_ptr<Seller>& b) -> bool {
return a->getSellerNo() < b->getSellerNo();
});
return (*iter)->getSellerNo() + 1;
}

View file

@ -13,11 +13,12 @@ class Marketplace
Marketplace(); Marketplace();
void storeToDb(); void storeToDb();
void loadFromDb(); void loadFromDb();
std::vector<std::shared_ptr<Seller>>& getSellers(); std::vector<std::unique_ptr<Seller>>& getSellers();
int getNextSellerNo();
private: private:
std::vector<std::shared_ptr<Seller>> sellers_; std::vector<std::unique_ptr<Seller>> sellers_;
std::vector<std::shared_ptr<Sale>> sales_; std::vector<std::unique_ptr<Sale>> sales_;
}; };
#endif #endif

View file

@ -14,11 +14,11 @@ Seller::Seller(const std::string& firstName, const std::string& lastName, int se
void Seller::setSellerNo(int seller_no) { sellerNo_ = seller_no; } void Seller::setSellerNo(int seller_no) { sellerNo_ = seller_no; }
inline void Seller::setFirstName(const std::string& firstName) { firstName_ = firstName; } void Seller::setFirstName(const std::string& firstName) { firstName_ = firstName; }
inline void Seller::setLastName(const std::string& lastName) { lastName_ = lastName; } void Seller::setLastName(const std::string& lastName) { lastName_ = lastName; }
inline void Seller::setNumArticlesOffered(int number) { numArticlesOffered_ = number; } void Seller::setNumArticlesOffered(int number) { numArticlesOffered_ = number; }
void Seller::addArticle(std::shared_ptr<Article> article) void Seller::addArticle(std::shared_ptr<Article> article)
{ {
@ -51,10 +51,11 @@ int Seller::numArticlesOffered() const { return numArticlesOffered_; }
void Seller::cleanupArticles() void Seller::cleanupArticles()
{ {
articles_.erase(std::remove_if(begin(articles_), end(articles_), articles_.erase(std::remove_if(articles_.begin(), articles_.end(),
[](const std::shared_ptr<Article>& article) { [](const std::shared_ptr<Article>& article) {
return article->getState() == Article::State::DELETE; return article->getState() == Article::State::DELETE;
})); }),
articles_.end());
for (auto& article : articles_) { for (auto& article : articles_) {
article->setState(Article::State::OK); article->setState(Article::State::OK);

View file

@ -15,5 +15,10 @@ MainWindow::MainWindow()
void MainWindow::on_actionEditSeller_triggered() void MainWindow::on_actionEditSeller_triggered()
{ {
auto dialog = std::make_unique<SellerDialog>(this); auto dialog = std::make_unique<SellerDialog>(this);
dialog->exec(); int retCode = dialog->exec();
if (retCode == QDialog::Accepted) {
marketplace_->storeToDb();
} else {
marketplace_->loadFromDb();
}
} }

View file

@ -2,11 +2,34 @@
#include "mainwindow.h" #include "mainwindow.h"
#include <QMessageBox>
SellerDialog::SellerDialog(QWidget* parent, Qt::WindowFlags f) : QDialog(parent, f) SellerDialog::SellerDialog(QWidget* parent, Qt::WindowFlags f) : QDialog(parent, f)
{ {
ui_.setupUi(this); ui_.setupUi(this);
SellerModel* model = new SellerModel( SellerModel* model =
dynamic_cast<MainWindow*>(parent)->getMarketplace()->getSellers(), ui_.tableView); new SellerModel(dynamic_cast<MainWindow*>(parent)->getMarketplace(), ui_.tableView);
ui_.tableView->setModel(model); ui_.tableView->setModel(model);
ui_.tableView->setColumnHidden(0, true); // hide the uuid ui_.tableView->setColumnHidden(0, true); // hide the uuid
connect(ui_.newButton, &QPushButton::clicked, this, &SellerDialog::on_newButton_clicked);
}
void SellerDialog::on_newButton_clicked()
{
ui_.tableView->model()->insertRows(ui_.tableView->model()->rowCount(), 1);
ui_.tableView->scrollToBottom();
}
void SellerDialog::accept()
{
Marketplace* market = dynamic_cast<MainWindow*>(parentWidget())->getMarketplace();
for (const auto& seller : market->getSellers()) {
if (seller->getFirstName().empty() || seller->getLastName().empty()) {
QMessageBox(QMessageBox::Icon::Critical, "Fehler",
"Bitte geben Sie bei jedem Verkäufer Vorname und Nachname an.",
QMessageBox::StandardButton::Ok, this).exec();
return;
}
}
QDialog::accept();
} }

View file

@ -16,6 +16,8 @@ class SellerDialog : public QDialog
Qt::WindowFlags f = Qt::WindowTitleHint | Qt::WindowSystemMenuHint); Qt::WindowFlags f = Qt::WindowTitleHint | Qt::WindowSystemMenuHint);
private: private:
void on_newButton_clicked();
virtual void accept() override;
Ui::SellerDialog ui_; Ui::SellerDialog ui_;
}; };

View file

@ -1,11 +1,18 @@
#include "sellermodel.h" #include "sellermodel.h"
SellerModel::SellerModel(std::vector<std::shared_ptr<Seller>>& sellers, QObject* parent) #include <algorithm>
: QAbstractTableModel(parent), sellers_(&sellers)
#include <QMessageBox>
SellerModel::SellerModel(Marketplace* market, QObject* parent)
: QAbstractTableModel(parent), marketplace_(market)
{ {
} }
int SellerModel::rowCount(const QModelIndex& parent) const { return sellers_->size(); } int SellerModel::rowCount(const QModelIndex& parent) const
{
return marketplace_->getSellers().size();
}
int SellerModel::columnCount(const QModelIndex& parent) const { return 5; } int SellerModel::columnCount(const QModelIndex& parent) const { return 5; }
@ -14,7 +21,7 @@ QVariant SellerModel::data(const QModelIndex& index, int role) const
if (role != Qt::DisplayRole) if (role != Qt::DisplayRole)
return QVariant(); return QVariant();
Seller* seller = sellers_->at(index.row()).get(); Seller* seller = marketplace_->getSellers().at(index.row()).get();
switch (index.column()) { switch (index.column()) {
case 0: case 0:
return seller->getUuidAsString().c_str(); return seller->getUuidAsString().c_str();
@ -56,3 +63,66 @@ QVariant SellerModel::headerData(int section, Qt::Orientation orientation, int r
} else } else
return ""; return "";
} }
Qt::ItemFlags SellerModel::flags(const QModelIndex& index) const
{
return QAbstractTableModel::flags(index) | Qt::ItemFlag::ItemIsEditable;
}
bool SellerModel::setData(const QModelIndex& index, const QVariant& value, int role)
{
if (role != Qt::EditRole)
return false;
Seller* seller = marketplace_->getSellers().at(index.row()).get();
switch (index.column()) {
case 0:
seller->setUuidFromString(value.toString().toStdString());
break;
case 1: {
if (value.toInt() < 0)
return false;
auto iter =
std::find_if(marketplace_->getSellers().begin(), marketplace_->getSellers().end(),
[&value](const std::unique_ptr<Seller>& seller) {
return value.toInt() == seller->getSellerNo();
});
if (iter != marketplace_->getSellers().end()) {
/* QMessageBox(QMessageBox::Icon::Warning, "Fehler",
"Die Verkäufernummer muss eindeutig sein.", QMessageBox::StandardButton::Ok)
.exec(); */
return false;
}
seller->setSellerNo(value.toInt());
break;
}
case 2:
seller->setFirstName(value.toString().toStdString());
break;
case 3:
seller->setLastName(value.toString().toStdString());
break;
case 4:
seller->setNumArticlesOffered(value.toInt());
break;
default:
return false;
}
if (seller->getState() == Seller::State::OK)
seller->setState(Seller::State::UPDATE);
dataChanged(index, index);
return true;
}
bool SellerModel::insertRows(int row, int count, const QModelIndex& parent)
{
beginInsertRows(parent, row, row + count - 1);
auto seller = std::make_unique<Seller>();
seller->createUuid();
seller->setSellerNo(marketplace_->getNextSellerNo());
marketplace_->getSellers().push_back(std::move(seller));
endInsertRows();
return true;
}

View file

@ -8,14 +8,17 @@
class SellerModel : public QAbstractTableModel class SellerModel : public QAbstractTableModel
{ {
public: public:
explicit SellerModel(std::vector<std::shared_ptr<Seller>>& sellers, QObject* parent = nullptr); explicit SellerModel(Marketplace* market, QObject* parent = nullptr);
virtual int rowCount(const QModelIndex& parent = QModelIndex()) const override; virtual int rowCount(const QModelIndex& parent = QModelIndex()) const override;
virtual int columnCount(const QModelIndex& parent = QModelIndex()) const override; virtual int columnCount(const QModelIndex& parent = QModelIndex()) const override;
virtual QVariant data(const QModelIndex& index, int role = Qt::DisplayRole) const override; virtual QVariant data(const QModelIndex& index, int role = Qt::DisplayRole) const override;
virtual QVariant headerData(int section, Qt::Orientation orientation, int role) const override; virtual QVariant headerData(int section, Qt::Orientation orientation, int role) const override;
virtual Qt::ItemFlags flags(const QModelIndex& index) const override;
virtual bool setData(const QModelIndex& index, const QVariant& value, int role = Qt::EditRole);
virtual bool insertRows(int row, int count, const QModelIndex& parent = QModelIndex()) override;
private: private:
std::vector<std::shared_ptr<Seller>>* sellers_; Marketplace* marketplace_;
}; };
#endif #endif

View file

@ -17,20 +17,20 @@ BOOST_AUTO_TEST_CASE(store_seller_fail)
{ {
Database db(":memory:"); Database db(":memory:");
db.init(); db.init();
std::vector<std::shared_ptr<Seller>> sellers; std::vector<std::unique_ptr<Seller>> sellers;
sellers.push_back(std::make_shared<Seller>()); sellers.push_back(std::make_unique<Seller>());
sellers.push_back(std::make_shared<Seller>()); sellers.push_back(std::make_unique<Seller>());
BOOST_CHECK_THROW(db.storeSellers(sellers), std::runtime_error); BOOST_CHECK_THROW(db.storeSellers(sellers), std::runtime_error);
} }
BOOST_AUTO_TEST_CASE(store_sellers_succ) BOOST_AUTO_TEST_CASE(store_sellers_succ)
{ {
Database db(":memory:"); Database db(":memory:");
db.init(); db.init();
std::vector<std::shared_ptr<Seller>> sellers; std::vector<std::unique_ptr<Seller>> sellers;
auto a = std::make_shared<Seller>(); auto a = std::make_unique<Seller>();
a->createUuid(); a->createUuid();
a->setSellerNo(1); a->setSellerNo(1);
auto b = std::make_shared<Seller>("Max", "Mustermann"); auto b = std::make_unique<Seller>("Max", "Mustermann");
b->createUuid(); b->createUuid();
b->setSellerNo(2); b->setSellerNo(2);
auto c = std::make_shared<Article>(); auto c = std::make_shared<Article>();
@ -39,8 +39,8 @@ BOOST_AUTO_TEST_CASE(store_sellers_succ)
c->setDescription("Test"); c->setDescription("Test");
b->addArticle(c); b->addArticle(c);
BOOST_TEST(a->getUuid() != b->getUuid()); BOOST_TEST(a->getUuid() != b->getUuid());
sellers.push_back(a); sellers.push_back(std::move(a));
sellers.push_back(b); sellers.push_back(std::move(b));
BOOST_CHECK_NO_THROW(db.storeSellers(sellers)); BOOST_CHECK_NO_THROW(db.storeSellers(sellers));
} }
@ -48,12 +48,11 @@ BOOST_AUTO_TEST_CASE(seller_states)
{ {
Database db(":memory:"); Database db(":memory:");
db.init(); db.init();
std::vector<std::shared_ptr<Seller>> sellers; std::vector<std::unique_ptr<Seller>> sellers;
auto a = std::make_shared<Seller>(); auto a = std::make_unique<Seller>();
a->setSellerNo(3); a->setSellerNo(3);
a->createUuid(); a->createUuid();
sellers.push_back(a); sellers.push_back(std::move(a));
std::cout << "Anzahl sellers: " << sellers.size() << "\n";
BOOST_TEST((sellers.at(0)->getState() == Entity::State::NEW)); BOOST_TEST((sellers.at(0)->getState() == Entity::State::NEW));
BOOST_TEST(db.storeSellers(sellers) == 1); BOOST_TEST(db.storeSellers(sellers) == 1);
BOOST_TEST((sellers.at(0)->getState() == Entity::State::OK)); BOOST_TEST((sellers.at(0)->getState() == Entity::State::OK));