Add multi month operation support : Normal operation with description "... (XX/YY)" will be automatically forwarded to next month
This commit is contained in:
parent
fe6bb52c52
commit
38770639be
13
ChangeLog
13
ChangeLog
|
@ -1,3 +1,16 @@
|
||||||
|
v0.8 (06/08/2018)
|
||||||
|
** User **
|
||||||
|
Add multi month operation support : Normal operation with description "... (XX/YY)" will be forwarded to next month
|
||||||
|
** Dev **
|
||||||
|
** Bugs **
|
||||||
|
|
||||||
|
|
||||||
|
v0.7.1 (07/05/2018)
|
||||||
|
** User **
|
||||||
|
** Dev **
|
||||||
|
** Bugs **
|
||||||
|
web: start and end date only compared to current date and not selected one
|
||||||
|
|
||||||
v0.7 (25/03/2018)
|
v0.7 (25/03/2018)
|
||||||
** User **
|
** User **
|
||||||
Set background calendar color to red or yellow when one account is negative or less than 200€ (configurable)
|
Set background calendar color to red or yellow when one account is negative or less than 200€ (configurable)
|
||||||
|
|
|
@ -25,6 +25,8 @@
|
||||||
|
|
||||||
#include <view/view.hpp>
|
#include <view/view.hpp>
|
||||||
|
|
||||||
|
#include <QRegularExpression>
|
||||||
|
|
||||||
std::vector<ImportEngine*> * KissCount::_importEngines;
|
std::vector<ImportEngine*> * KissCount::_importEngines;
|
||||||
std::vector<ExportEngine*> * KissCount::_exportEngines;
|
std::vector<ExportEngine*> * KissCount::_exportEngines;
|
||||||
|
|
||||||
|
@ -285,12 +287,62 @@ std::map<int, std::vector<int> > KissCount::GetAllOperations()
|
||||||
return _db->GetAllOperations(_user);
|
return _db->GetAllOperations(_user);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int KissCount::CopyGeneratedOperation(int monthTo, int yearTo, Operation& opOrig, Operation& opDest,
|
||||||
|
std::map<int, int> &meta, QRegularExpression *regexp=0)
|
||||||
|
{
|
||||||
|
opDest = opOrig;
|
||||||
|
opDest.month = monthTo;
|
||||||
|
opDest.year = yearTo;
|
||||||
|
opDest.checked = false;
|
||||||
|
opDest.id = AddOperation(opDest);
|
||||||
|
opDest.childs.clear();
|
||||||
|
if (opOrig.meta)
|
||||||
|
meta[opOrig.id] = opDest.id;
|
||||||
|
|
||||||
|
if (regexp)
|
||||||
|
{
|
||||||
|
QRegularExpressionMatch match;
|
||||||
|
int first, second;
|
||||||
|
|
||||||
|
match = regexp->match(opOrig.description);
|
||||||
|
if (match.hasMatch())
|
||||||
|
{
|
||||||
|
first = match.captured(1).toInt();
|
||||||
|
second = match.captured(2).toInt();
|
||||||
|
|
||||||
|
if (first < second)
|
||||||
|
{
|
||||||
|
first++;
|
||||||
|
opDest.description = opOrig.description.left(match.capturedStart(1));
|
||||||
|
opDest.description += QString::number(first) + QString("/") + QString::number(second);
|
||||||
|
opDest.description += opOrig.description.right(opOrig.description.length()-match.capturedEnd(2));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!QDate::isValid(opDest.year, opDest.month+1, opDest.day+1))
|
||||||
|
{
|
||||||
|
QDate d(opDest.year, opDest.month+1, 1);
|
||||||
|
opDest.day = d.daysInMonth()-1;
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
int KissCount::GenerateMonth(int monthFrom, int yearFrom, int monthTo, int yearTo)
|
int KissCount::GenerateMonth(int monthFrom, int yearFrom, int monthTo, int yearTo)
|
||||||
{
|
{
|
||||||
std::vector<Operation>::iterator it, it2;
|
std::vector<Operation>::iterator it, it2;
|
||||||
|
std::vector<int>::iterator childIt, copyIt;
|
||||||
std::map<int, int> meta;
|
std::map<int, int> meta;
|
||||||
Operation op;
|
Operation op, op2, parentOp, childOp;
|
||||||
int nb_update_days = 0;
|
std::vector<int> toCopy;
|
||||||
|
int nb_update_days = 0, first, second;
|
||||||
|
QRegularExpressionMatch match;
|
||||||
|
bool hasmatch;
|
||||||
|
/* Try to find something like XXX(1/5)XXX */
|
||||||
|
QRegularExpression regexp(".+\\((\\d+)/(\\d+)\\).*");
|
||||||
|
QString newDescription;
|
||||||
|
|
||||||
_db->GenerateMonth(_user, monthFrom, yearFrom, monthTo, yearTo);
|
_db->GenerateMonth(_user, monthFrom, yearFrom, monthTo, yearTo);
|
||||||
|
|
||||||
|
@ -305,26 +357,56 @@ int KissCount::GenerateMonth(int monthFrom, int yearFrom, int monthTo, int yearT
|
||||||
it != (*_user->_operations[yearFrom])[monthFrom].end();
|
it != (*_user->_operations[yearFrom])[monthFrom].end();
|
||||||
it++)
|
it++)
|
||||||
{
|
{
|
||||||
if (!it->fix_cost) continue;
|
hasmatch = false;
|
||||||
op = *it;
|
|
||||||
op.month = monthTo;
|
|
||||||
op.year = yearTo;
|
|
||||||
op.checked = false;
|
|
||||||
op.id = AddOperation(op);
|
|
||||||
op.childs.clear();
|
|
||||||
if (op.meta)
|
|
||||||
meta[it->id] = op.id;
|
|
||||||
|
|
||||||
if (!QDate::isValid(op.year, op.month+1, op.day+1))
|
if (!it->fix_cost)
|
||||||
{
|
{
|
||||||
QDate d(op.year, op.month+1, 1);
|
match = regexp.match(it->description);
|
||||||
op.day = d.daysInMonth()-1;
|
if (!match.hasMatch())
|
||||||
nb_update_days++;
|
continue;
|
||||||
|
hasmatch = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (hasmatch)
|
||||||
|
{
|
||||||
|
first = match.captured(1).toInt();
|
||||||
|
second = match.captured(2).toInt();
|
||||||
|
|
||||||
|
if (first >= second)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
if (!std::count(toCopy.begin(), toCopy.end(), it->id))
|
||||||
|
{
|
||||||
|
/* Copy only parent if has */
|
||||||
|
if (it->parent)
|
||||||
|
{
|
||||||
|
if (std::count(toCopy.begin(), toCopy.end(), it->parent))
|
||||||
|
continue;
|
||||||
|
|
||||||
|
toCopy.push_back(it->parent);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
toCopy.push_back(it->id);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
nb_update_days += CopyGeneratedOperation(monthTo, yearTo, *it, op, meta);
|
||||||
(*_user->_operations[yearTo])[monthTo].push_back(op);
|
(*_user->_operations[yearTo])[monthTo].push_back(op);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Restart search and filter by copy */
|
||||||
|
for(it = (*_user->_operations[yearFrom])[monthFrom].begin();
|
||||||
|
it != (*_user->_operations[yearFrom])[monthFrom].end();
|
||||||
|
it++)
|
||||||
|
{
|
||||||
|
if (std::count(toCopy.begin(), toCopy.end(), it->id) ||
|
||||||
|
(it->parent && std::count(toCopy.begin(), toCopy.end(), it->parent)))
|
||||||
|
{
|
||||||
|
nb_update_days += CopyGeneratedOperation(monthTo, yearTo, *it, childOp, meta, ®exp);
|
||||||
|
(*_user->_operations[yearTo])[monthTo].push_back(childOp);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Re Generate parents
|
// Re Generate parents
|
||||||
for(it = (*_user->_operations[yearTo])[monthTo].begin();
|
for(it = (*_user->_operations[yearTo])[monthTo].begin();
|
||||||
it != (*_user->_operations[yearTo])[monthTo].end();
|
it != (*_user->_operations[yearTo])[monthTo].end();
|
||||||
|
|
|
@ -165,6 +165,9 @@ private:
|
||||||
|
|
||||||
static std::vector<ImportEngine*> *_importEngines;
|
static std::vector<ImportEngine*> *_importEngines;
|
||||||
static std::vector<ExportEngine*> *_exportEngines;
|
static std::vector<ExportEngine*> *_exportEngines;
|
||||||
|
|
||||||
|
int CopyGeneratedOperation(int monthTo, int yearTo, Operation& opOrig, Operation& opDest,
|
||||||
|
std::map<int, int> &meta, QRegularExpression *regexp);
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
Loading…
Reference in New Issue
Block a user