KissCount/src/model/User.cpp

337 lines
7.7 KiB
C++
Raw Normal View History

2010-07-10 16:34:30 +02:00
/*
2012-02-01 11:02:54 +01:00
Copyright 2010-2012 Grégory Soutadé
2010-07-10 16:34:30 +02:00
This file is part of KissCount.
2010-07-10 16:34:30 +02:00
KissCount 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.
2010-07-10 16:34:30 +02:00
KissCount 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.
2010-07-10 16:34:30 +02:00
You should have received a copy of the GNU General Public License
along with KissCount. If not, see <http://www.gnu.org/licenses/>.
2010-07-10 16:34:30 +02:00
*/
2011-08-20 11:43:12 +02:00
#include <algorithm>
2011-08-27 18:35:36 +02:00
#include <QString>
2011-08-20 14:02:47 +02:00
#include <view/view.hpp>
#include "User.hpp"
2010-05-15 11:21:42 +02:00
2010-10-24 16:04:56 +02:00
User::User(Database* db) : _db(db)
{}
2010-05-15 11:21:42 +02:00
User::~User()
{
InvalidateOperations();
}
void User::InvalidateOperations()
2010-05-15 11:21:42 +02:00
{
std::map<unsigned int, std::map<unsigned int, std::vector<Operation> >* >::iterator it;
2010-05-15 11:21:42 +02:00
for (it = _operations.begin(); it != _operations.end(); it++)
2010-05-15 11:21:42 +02:00
{
if (_operations[it->first])
2010-05-15 11:21:42 +02:00
{
delete it->second;
2010-05-15 11:21:42 +02:00
}
}
_operations.clear();
2010-05-15 11:21:42 +02:00
}
2010-05-24 20:14:15 +02:00
2011-08-25 17:45:41 +02:00
Category User::GetCategory(int catId)
2010-06-22 12:29:36 +02:00
{
Category cat;
2011-08-14 19:26:54 +02:00
std::vector<Category>::iterator it = std::find(_categories.begin(), _categories.end(), catId);
2010-06-22 12:29:36 +02:00
2011-08-14 19:26:54 +02:00
if (it !=_categories.end()) return *it;
2010-06-22 12:29:36 +02:00
2011-08-25 17:45:41 +02:00
if (_db->LoadCategory(catId, "", cat))
2010-10-24 16:04:56 +02:00
return cat;
2011-08-25 17:45:41 +02:00
cat.id = 0;
cat.parent = 0;
cat.name = _("Unknown");
2011-08-25 17:45:41 +02:00
cat.font = "";
cat.backcolor = view::OWN_GREEN;
2011-08-27 18:35:36 +02:00
cat.forecolor = Qt::black;
2010-06-22 12:29:36 +02:00
return cat;
2010-06-22 12:29:36 +02:00
}
2011-08-27 18:35:36 +02:00
QString User::GetCategoryName(int catId)
2010-05-24 20:14:15 +02:00
{
2010-10-24 16:04:56 +02:00
Category cat;
2011-08-14 19:26:54 +02:00
std::vector<Category>::iterator it = std::find(_categories.begin(), _categories.end(), catId);
2010-10-24 16:04:56 +02:00
2011-08-14 19:26:54 +02:00
if (it !=_categories.end()) return it->name;
2010-06-22 12:29:36 +02:00
2011-08-25 17:45:41 +02:00
if (_db->LoadCategory(catId, "", cat))
2010-10-24 16:04:56 +02:00
return cat.name;
return _("Unknown") ;
2010-05-24 20:14:15 +02:00
}
2011-08-27 18:35:36 +02:00
int User::GetCategoryId(const QString& catName)
2010-06-03 18:28:38 +02:00
{
std::vector<Category>::iterator it;
2010-10-24 16:04:56 +02:00
Category cat;
for (it=_categories.begin(); it !=_categories.end(); it++)
2011-08-27 18:35:36 +02:00
if (_(it->name.toStdString().c_str()) == catName)
return it->id;
2010-06-03 18:28:38 +02:00
2011-08-27 18:35:36 +02:00
if ( _db->LoadCategory(0, catName, cat))
2010-10-24 16:04:56 +02:00
return cat.id;
2011-08-25 17:45:41 +02:00
return 0 ;
2010-06-03 18:28:38 +02:00
}
2011-08-25 17:45:41 +02:00
const QFont User::GetCategoryFont(int catId)
2010-09-08 11:02:03 +02:00
{
DEFAULT_FONT(f);
2010-10-24 16:04:56 +02:00
Category cat;
2010-09-08 11:02:03 +02:00
for (unsigned int i=0; i<_categories.size(); i++)
if (_categories[i].id == catId)
return _categoriesFonts[i];
2011-08-25 17:45:41 +02:00
if (_db->LoadCategory(catId, "", cat))
2010-10-24 16:04:56 +02:00
return KissCount::ExtractFont(cat.font);
2010-09-08 11:02:03 +02:00
return f;
}
void User::AddCategory(const Category& cat)
{
_categories.push_back(cat);
2011-08-25 17:45:41 +02:00
_categoriesFonts.push_back(KissCount::ExtractFont(""));
}
void User::UpdateCategory(const Category& cat)
{
std::vector<Category>::iterator it = std::find(_categories.begin(), _categories.end(), cat.id);
if (it !=_categories.end())
{
*it = cat;
_categoriesFonts[it-_categories.begin()] = KissCount::ExtractFont(cat.font);
}
}
void User::DeleteCategory(const Category& cat)
{
std::vector<Category>::iterator it = std::find(_categories.begin(), _categories.end(), cat.id);
if (it !=_categories.end())
{
int pos = it - _categories.begin();
_categories.erase(_categories.begin()+pos);
_categoriesFonts.erase(_categoriesFonts.begin()+pos);
}
}
2011-08-25 17:45:41 +02:00
Account User::GetAccount(int accountId) throw (AccountNotFound)
{
2011-08-14 19:26:54 +02:00
std::vector<Account>::iterator it = std::find(_accounts.begin(), _accounts.end(), accountId);
if (it != _accounts.end())
return *it;
throw AccountNotFound();
}
2011-08-27 18:35:36 +02:00
QString User::GetAccountName(int accountId)
2010-05-24 20:14:15 +02:00
{
2011-08-14 19:26:54 +02:00
std::vector<Account>::iterator it = std::find(_accounts.begin(), _accounts.end(), accountId);
if (it != _accounts.end()) return it->name;
2010-06-21 13:02:02 +02:00
return _("Unknown") ;
2010-05-24 20:14:15 +02:00
}
2010-05-27 21:09:02 +02:00
2011-08-27 18:35:36 +02:00
int User::GetAccountId(const QString& accountName)
2010-06-03 18:28:38 +02:00
{
std::vector<Account>::iterator it;
for (it=_accounts.begin(); it !=_accounts.end(); it++)
if (it->name == accountName)
return it->id;
2010-06-03 18:28:38 +02:00
2011-08-25 17:45:41 +02:00
return 0 ;
2010-06-03 18:28:38 +02:00
}
2011-08-27 18:35:36 +02:00
int User::GetAccountIdFromAccountNumber(const QString& accountNumber)
{
std::vector<Account>::iterator it;
for (it=_accounts.begin(); it !=_accounts.end(); it++)
if (it->number == accountNumber)
return it->id;
return 0 ;
}
void User::AddAccount(Account& ac)
{
_accounts.push_back(ac);
}
void User::UpdateAccount(Account& ac)
{
std::vector<Account>::iterator it = std::find(_accounts.begin(), _accounts.end(), ac.id);
if (it != _accounts.end())
*it = ac;
}
void User::DeleteAccount(Account& ac)
{
std::vector<Account>::iterator it = std::find(_accounts.begin(), _accounts.end(), ac.id);
if (it != _accounts.end())
_accounts.erase(it);
}
2010-05-27 21:09:02 +02:00
int User::GetCategoriesNumber()
{
return _categories.size();
2010-05-27 21:09:02 +02:00
}
2010-06-02 22:14:11 +02:00
int User::GetAccountsNumber()
{
return _accounts.size();
2010-06-02 22:14:11 +02:00
}
int User::GetOperationsNumber(int month, int year)
{
return (*_operations[year])[month].size();
2010-06-02 22:14:11 +02:00
}
2010-07-06 20:59:02 +02:00
2011-08-27 18:35:36 +02:00
QString User::GetLanguage()
2010-07-06 20:59:02 +02:00
{
2011-08-25 17:45:41 +02:00
return _preferences["language"];
// long val;
2010-07-06 20:59:02 +02:00
2011-08-25 17:45:41 +02:00
// if (!res.Length())
// return wxLANGUAGE_ENGLISH ;
2010-07-06 20:59:02 +02:00
2011-08-25 17:45:41 +02:00
// res.ToLong(&val);
2010-07-06 20:59:02 +02:00
2011-08-25 17:45:41 +02:00
// return (wxLanguage)val;
2010-07-06 20:59:02 +02:00
}
void User::LinkOrUnlinkOperation(Operation& op)
{
std::vector<Operation>::iterator it;
2011-02-14 20:56:59 +01:00
Account account, account2;
if (!_operations[op.year])
_db->LoadYear(this, op.year);
if (!_operations[op.year])
return;
// Not Linked
2011-08-25 17:45:41 +02:00
if (!op.transfert)
{
for (it = (*_operations[op.year])[op.month].begin(); it != (*_operations[op.year])[op.month].end(); it++)
{
if (it->id != op.id && it->transfert == op.id)
{
2011-08-25 17:45:41 +02:00
it->transfert = 0;
2011-02-14 20:56:59 +01:00
it->_virtual = false;
return;
}
}
}
// Linked
else
{
for (it = (*_operations[op.year])[op.month].begin(); it != (*_operations[op.year])[op.month].end(); it++)
{
if (it->id != op.id && it->id == op.transfert)
{
2011-02-14 20:56:59 +01:00
account = GetAccount(it->account);
account2 = GetAccount(op.account);
it->transfert = op.id;
2011-02-14 20:56:59 +01:00
it->_virtual = account._virtual || account2._virtual;
op._virtual = account._virtual || account2._virtual;
return;
}
}
2011-08-25 17:45:41 +02:00
op.transfert = 0;
2011-02-14 20:56:59 +01:00
op._virtual = false;
}
}
bool User::Group(std::vector<Operation>* ops, const Operation& op)
{
std::vector<Operation>::iterator it;
2011-08-25 17:45:41 +02:00
std::vector<int>::iterator it2;
for (it = ops->begin(); it != ops->end(); it++)
{
if (it->id == op.parent)
{
2011-08-14 19:26:54 +02:00
it2 = std::find(it->childs.begin(), it->childs.end(), op.id);
2011-12-18 13:51:04 +01:00
if (it2 == it->childs.end())
it->childs.push_back(op.id);
return true;
}
}
2010-10-24 16:04:56 +02:00
return false ;
}
void User::Group(const Operation& op)
{
2011-12-18 13:51:04 +01:00
std::vector<Operation>::iterator it;
if (!Group(&(*_operations[op.year])[op.month], op)
&& _db->LoadOperation(this, op.parent))
2010-10-24 16:04:56 +02:00
{
2011-12-18 13:51:04 +01:00
it = std::find ((*_operations[op.year])[op.month].begin(), (*_operations[op.year])[op.month].end(), op.parent);
if (it != (*_operations[op.year])[op.month].end())
it->childs.push_back(op.id);
2010-10-24 16:04:56 +02:00
}
}
void User::UnGroup(const Operation& op)
{
std::vector<Operation>::iterator it;
2011-08-25 17:45:41 +02:00
std::vector<int>::iterator it2;
for (it = (*_operations[op.year])[op.month].begin(); it != (*_operations[op.year])[op.month].end(); it++)
{
if (it->id == op.parent)
{
for (it2 = it->childs.begin(); it2 != it->childs.end(); it2++)
if (*it2 == op.id)
{
it->childs.erase(it2);
return;
}
}
}
}
void User::ResolveGroups(int year)
{
unsigned int i;
std::map<unsigned int, std::vector<Operation> >::iterator it;
for (it = _operations[year]->begin(); it != _operations[year]->end(); it++)
{
for (i=0; i<it->second.size(); i++)
2011-08-27 18:35:36 +02:00
if (it->second[i].parent)
Group(((*_operations[year])[it->first])[i]);
}
}