From 4303d0be47526b35e5bb3e3be001da227dae5d96 Mon Sep 17 00:00:00 2001 From: rtk0c Date: Fri, 9 Apr 2021 23:17:45 -0700 Subject: Fix crash on load entries - TODO format time properly - TODO add Purchases table visualization --- core/src/Model/TransactionsModel.hpp | 55 ++++++++++++++++++++++++++++++++++++ 1 file changed, 55 insertions(+) create mode 100644 core/src/Model/TransactionsModel.hpp (limited to 'core/src/Model/TransactionsModel.hpp') diff --git a/core/src/Model/TransactionsModel.hpp b/core/src/Model/TransactionsModel.hpp new file mode 100644 index 0000000..beed663 --- /dev/null +++ b/core/src/Model/TransactionsModel.hpp @@ -0,0 +1,55 @@ +#pragma once + +#include "cplt_fwd.hpp" + +#include +#include +#include + +class SalesTable { +public: + SQLite::Statement GetRowsStatement; + SQLite::Statement FilterRowsStatement; + +public: + SalesTable(TransactionModel& db); +}; + +class PurchasesTable { +public: + PurchasesTable(TransactionModel& db); +}; + +class DeliveryTable { +public: + DeliveryTable(TransactionModel& db); +}; + +// TODO fuck SQLite::Statement has move ctor but not move assignment operator +class TransactionModel { +private: + class DatabaseWrapper { + public: + SQLite::Database mSqlite; + DatabaseWrapper(TransactionModel& self); + }; + + Project* mProject; + DatabaseWrapper mDbWrapper; + SalesTable mSales; + PurchasesTable mPurchases; + DeliveryTable mDeliveries; + +public: + TransactionModel(Project& project); + + const SQLite::Database& GetSQLite() const; + SQLite::Database& GetSQLite(); + + const SalesTable& GetSales() const; + SalesTable& GetSales(); + const PurchasesTable& GetPurchases() const; + PurchasesTable& GetPurchases(); + const DeliveryTable& GetDeliveries() const; + DeliveryTable& GetDeliveries(); +}; -- cgit v1.2.3-70-g09d2