kima2/src/core/excelreader.cpp

73 lines
2.4 KiB
C++
Raw Normal View History

2018-08-01 15:36:41 +02:00
#include "excelreader.h"
#include "utils.h"
2018-08-01 15:36:41 +02:00
#include <fstream>
2019-02-25 09:04:52 +01:00
#include <xlnt/xlnt.hpp>
2018-08-01 15:36:41 +02:00
2018-08-09 16:37:56 +02:00
namespace fs = std::filesystem;
2022-07-07 15:21:46 +02:00
std::size_t ExcelReader::readSellersFromFile(const fs::path &filePath, Marketplace *market)
2018-08-01 15:36:41 +02:00
{
xlnt::workbook wb;
std::ifstream mystream(filePath, std::ios::binary);
2019-02-25 09:04:52 +01:00
if (!mystream.is_open()) {
throw std::runtime_error("Could not open Excel file");
}
wb.load(mystream);
2022-07-07 15:21:46 +02:00
for (auto &seller : market->getSellers()) {
2018-08-02 14:39:32 +02:00
seller->setState(Seller::State::DELETE);
}
market->storeToDb(true);
2018-08-01 15:36:41 +02:00
auto ws = wb.sheet_by_index(0);
2020-02-12 14:04:15 +01:00
for (auto row : ws.rows(true)) {
// Skip the row if the first value is not a number (= seller no)
if (row[0].data_type() != xlnt::cell::type::number) {
2018-08-01 15:55:13 +02:00
continue;
2018-08-02 11:15:15 +02:00
}
2018-08-02 14:39:32 +02:00
auto seller = std::make_unique<Seller>();
seller->setSellerNo(row[0].value<int>());
seller->setNumArticlesOffered(row[1].value<int>());
// If both, first name and last name, are empty, use N. N.
// Else, use the real values.
if (row[2].value<std::string>().empty() && row[3].value<std::string>().empty()) {
seller->setFirstName("N.");
seller->setLastName("N.");
} else {
std::string firstName = row[2].value<std::string>();
seller->setFirstName(trim(firstName));
std::string lastName = row[3].value<std::string>();
seller->setLastName(trim(lastName));
}
2018-08-02 14:39:32 +02:00
market->getSellers().push_back(std::move(seller));
2018-08-01 15:36:41 +02:00
}
2018-08-07 08:31:43 +02:00
2022-09-24 20:41:15 +02:00
// Add one additional seller "RESERVE RESERVE"
auto seller = std::make_unique<Seller>();
seller->setSellerNo(market->getNextSellerNo());
seller->setFirstName("RESERVE");
seller->setLastName("RESERVE");
market->getSellers().push_back(std::move(seller));
2018-08-07 08:31:43 +02:00
// If there was no special seller "Sonderkonto" in import data, then create one
2019-10-04 15:15:43 +02:00
auto specialSeller = market->findSellerWithSellerNo(0);
2018-08-07 08:31:43 +02:00
if (!specialSeller) {
auto seller = std::make_unique<Seller>();
seller->setSellerNo(0);
seller->setLastName("Sonderkonto");
seller->setFirstName("Sonderkonto");
seller->setNumArticlesOffered(0);
market->getSellers().push_back(std::move(seller));
}
market->sortSellers();
2018-08-02 14:39:32 +02:00
market->storeToDb();
return market->getSellers().size() - 1; // minus 1 because we don't count the "special" seller
2018-08-01 15:55:13 +02:00
}