1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
|
/***************************************************************************
kendingbalancedlg.h
-------------------
copyright : (C) 2000 by Michael Edwardes
email : [email protected]
***************************************************************************/
/***************************************************************************
* *
* This program 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 2 of the License, or *
* (at your option) any later version. *
* *
***************************************************************************/
#ifndef KENDINGBALANCEDLG_H
#define KENDINGBALANCEDLG_H
// ----------------------------------------------------------------------------
// QT Includes
#include <qwidget.h>
#include <qgroupbox.h>
#include <qlabel.h>
#include <qpushbutton.h>
#include <qdialog.h>
#include <qdatetime.h>
// ----------------------------------------------------------------------------
// KDE Includes
#include <klocale.h>
// ----------------------------------------------------------------------------
// Project Includes
class kMyMoneyEdit;
#include <kmymoney/kmymoneydateinput.h>
#include <kmymoney/mymoneyaccount.h>
#include "../dialogs/kendingbalancedlgdecl.h"
/**
* This dialog is wizard based and used to enter additional
* information required to start the reconciliation process.
* This version implements the behaviour for checkings,
* savings and credit card accounts.
*
* @author Thomas Baumgart
*/
class KEndingBalanceDlg : public KEndingBalanceDlgDecl
{
Q_OBJECT
public:
KEndingBalanceDlg(const MyMoneyAccount& account, QWidget *parent=0, const char *name=0);
~KEndingBalanceDlg();
const MyMoneyMoney endingBalance(void) const;
const MyMoneyMoney previousBalance(void) const;
const QDate statementDate(void) const { return m_statementDate->date(); };
const MyMoneyTransaction interestTransaction(void);
const MyMoneyTransaction chargeTransaction(void);
protected:
bool createTransaction(MyMoneyTransaction& t, const int sign, kMyMoneyEdit *amountEdit, KMyMoneyCategory *categoryEdit, kMyMoneyDateInput* dateEdit);
const MyMoneyMoney adjustedReturnValue(const MyMoneyMoney& v) const;
void createCategory(const QString& txt, QString& id, const MyMoneyAccount& parent);
protected slots:
void slotCheckPageFinished(void);
void slotReloadEditWidgets(void);
void help(void);
void slotCreateInterestCategory(const QString& txt, QString& id);
void slotCreateChargesCategory(const QString& txt, QString& id);
void accept(void);
void slotUpdateBalances(void);
signals:
/**
* proxy signal for KMyMoneyPayeeCombo::createItem(const QString&, QString&)
*/
void createPayee(const QString&, QString&);
/**
* emit when a category is about to be created
*/
void createCategory(MyMoneyAccount& acc, const MyMoneyAccount& parent);
private:
/// \internal d-pointer class.
class Private;
/// \internal d-pointer instance.
Private* const d;
};
/**
* This dialog is wizard based and used to enter additional
* information required to start the reconciliation process.
* This version is implements the behaviour for loan accounts.
*/
class KEndingBalanceLoanDlg : public KEndingBalanceDlgDecl
{
Q_OBJECT
public:
KEndingBalanceLoanDlg(const MyMoneyAccount& account, QWidget *parent=0, const char *name=0);
~KEndingBalanceLoanDlg();
/**
* This method returns the adjustment transaction if one
* has been created. If not, an empty transaction will be returned.
*/
const MyMoneyTransaction adjustmentTransaction(void) const;
/**
* This method returns the starting date of the statement as provided
* by the user. The value returned is only valid if the dialog returned
* with QDialog::accept.
*/
const QDate startDate(void) const { return m_startDateEdit->date(); };
/**
* This method returns the ending date of the statement as provided
* by the user. The value returned is only valid if the dialog returned
* with QDialog::accept.
*/
const QDate endDate(void) const { return m_endDateEdit->date(); };
protected:
const MyMoneyMoney totalInterest(const QDate& start, const QDate& end) const;
const MyMoneyMoney totalAmortization(const QDate& start, const QDate& end) const;
public slots:
void next();
protected slots:
void slotCheckPageFinished(void);
void help(void);
private:
/// \internal d-pointer class.
class Private;
/// \internal d-pointer instance.
Private* const d;
};
#endif
|