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
148
149
|
/***************************************************************************
kendingbalancedlg.h
-------------------
copyright : (C) 2000 by Michael Edwardes
email : mte@users.sourceforge.net
***************************************************************************/
/***************************************************************************
* *
* 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 <tqwidget.h>
#include <tqgroupbox.h>
#include <tqlabel.h>
#include <tqpushbutton.h>
#include <tqdialog.h>
#include <tqdatetime.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, TQWidget *parent=0, const char *name=0);
~KEndingBalanceDlg();
const MyMoneyMoney endingBalance(void) const;
const MyMoneyMoney previousBalance(void) const;
const TQDate 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 TQString& txt, TQString& id, const MyMoneyAccount& parent);
protected slots:
void slotCheckPageFinished(void);
void slotReloadEditWidgets(void);
void help(void);
void slotCreateInterestCategory(const TQString& txt, TQString& id);
void slotCreateChargesCategory(const TQString& txt, TQString& id);
void accept(void);
void slotUpdateBalances(void);
signals:
/**
* proxy signal for KMyMoneyPayeeCombo::createItem(const TQString&, TQString&)
*/
void createPayee(const TQString&, TQString&);
/**
* 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, TQWidget *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 TQDialog::accept.
*/
const TQDate 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 TQDialog::accept.
*/
const TQDate endDate(void) const { return m_endDateEdit->date(); };
protected:
const MyMoneyMoney totalInterest(const TQDate& start, const TQDate& end) const;
const MyMoneyMoney totalAmortization(const TQDate& start, const TQDate& 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
|