summaryrefslogtreecommitdiffstats
path: root/kmymoney2/wizards/newaccountwizard/knewaccountwizard.h
diff options
context:
space:
mode:
Diffstat (limited to 'kmymoney2/wizards/newaccountwizard/knewaccountwizard.h')
-rw-r--r--kmymoney2/wizards/newaccountwizard/knewaccountwizard.h182
1 files changed, 182 insertions, 0 deletions
diff --git a/kmymoney2/wizards/newaccountwizard/knewaccountwizard.h b/kmymoney2/wizards/newaccountwizard/knewaccountwizard.h
new file mode 100644
index 0000000..c8a149c
--- /dev/null
+++ b/kmymoney2/wizards/newaccountwizard/knewaccountwizard.h
@@ -0,0 +1,182 @@
+/***************************************************************************
+ knewaccountwizard.h
+ -------------------
+ begin : Tue Sep 25 2007
+ copyright : (C) 2007 Thomas Baumgart
+ email : Thomas Baumgart <[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 KNEWACCOUNTWIZARD_H
+#define KNEWACCOUNTWIZARD_H
+
+// ----------------------------------------------------------------------------
+// QT Includes
+
+class QString;
+
+// ----------------------------------------------------------------------------
+// Project Includes
+
+#include <kmymoney/kmymoneywizard.h>
+class MyMoneyPrice;
+
+/**
+ * @author Thomas Baumgart
+ */
+namespace NewAccountWizard {
+
+class AccountTypePage;
+class InstitutionPage;
+class BrokeragePage;
+class CreditCardSchedulePage;
+class GeneralLoanInfoPage;
+class LoanDetailsPage;
+class LoanPaymentPage;
+class LoanSchedulePage;
+class LoanPayoutPage;
+class HierarchyPage;
+class AccountSummaryPage;
+
+/**
+ * @author Thomas Baumgart
+ *
+ * This class implements the new account wizard which is used to gather
+ * the required information from the user to create a new account
+ */
+class Wizard : public KMyMoneyWizard
+{
+ friend class AccountTypePage;
+ friend class InstitutionPage;
+ friend class BrokeragePage;
+ friend class CreditCardSchedulePage;
+ friend class GeneralLoanInfoPage;
+ friend class LoanDetailsPage;
+ friend class LoanPaymentPage;
+ friend class LoanSchedulePage;
+ friend class LoanPayoutPage;
+ friend class HierarchyPage;
+ friend class AccountSummaryPage;
+
+ Q_OBJECT
+public:
+ Wizard(QWidget* parent = 0, const char* name = 0, bool modal = false, WFlags flags = 0);
+
+ /**
+ * Returns the information about the account as entered by
+ * the user.
+ */
+ const MyMoneyAccount& account(void);
+
+ /**
+ * Method to load the generated account information back into the widget
+ */
+ void setAccount(const MyMoneyAccount& acc);
+
+ /**
+ * Returns the information about the parent account as entered by
+ * the user.
+ * @note For now it's either fixed as Asset or Liability. We will provide
+ * user selected parent accounts later.
+ */
+ const MyMoneyAccount& parentAccount(void);
+
+ /**
+ * Returns information about the schedule. If the returned value
+ * equals MyMoneySchedule() then the user did not select to create
+ * a schedule.
+ */
+ const MyMoneySchedule& schedule(void);
+
+ /**
+ * This method returns the value of the opening balance
+ * entered by the user
+ */
+ MyMoneyMoney openingBalance(void) const;
+
+ /**
+ * This method returns the interest rate as factor, ie an
+ * interest rate of 6.5% will be returned as 0.065
+ */
+ MyMoneyMoney interestRate(void) const;
+
+ /**
+ * This method returns the payout transaction for loans.
+ * If the account to be created is not a loan or no
+ * payout transaction should be generated, this method
+ * returns an emtpy transaction.
+ */
+ MyMoneyTransaction payoutTransaction(void);
+
+ /**
+ * This method returns a MyMoneyAccount() object filled
+ * with the data to create a brokerage account. If the
+ * user selected not to create a brokerage account or
+ * the account type is not able to create a brokerage
+ * account, an empty MyMoneyAccount() object is returned.
+ *
+ * @note Make sure to call the account() method before you call this method.
+ * Otherwise the returned object might contain unexpected results.
+ */
+ MyMoneyAccount brokerageAccount(void) const;
+
+ /**
+ * This method returns the conversion rate
+ */
+ MyMoneyPrice conversionRate(void) const;
+
+protected:
+ /**
+ * This method returns the currently selected currency for the account
+ */
+ const MyMoneySecurity& currency(void) const;
+
+ /**
+ * This method returns the precision in digits for the selected currency.
+ * @sa currency()
+ */
+ int precision(void) const;
+
+ /**
+ * This method returns information about the selection of the user
+ * if the loan is for borrowing or lending money.
+ *
+ * @retval true loan is for money borrowed
+ * @retval false loan is for money lent
+ */
+ bool moneyBorrowed() const;
+
+signals:
+ void createInstitution(MyMoneyInstitution& institution);
+ void createAccount(MyMoneyAccount& account);
+ void createCategory(MyMoneyAccount&, const MyMoneyAccount&);
+
+private:
+ InstitutionPage* m_institutionPage;
+ AccountTypePage* m_accountTypePage;
+ BrokeragePage* m_brokeragepage;
+ CreditCardSchedulePage* m_schedulePage;
+ GeneralLoanInfoPage* m_generalLoanInfoPage;
+ LoanDetailsPage* m_loanDetailsPage;
+ LoanPaymentPage* m_loanPaymentPage;
+ LoanSchedulePage* m_loanSchedulePage;
+ LoanPayoutPage* m_loanPayoutPage;
+ HierarchyPage* m_hierarchyPage;
+ AccountSummaryPage* m_accountSummaryPage;
+
+ MyMoneyAccountLoan m_account;
+ MyMoneySchedule m_schedule;
+};
+
+}; // namespace
+
+
+#endif