|
|
|
/***************************************************************************
|
|
|
|
kexportdlg.h - description
|
|
|
|
-------------------
|
|
|
|
begin : Tue May 22 2001
|
|
|
|
copyright : (C) 2001 by Michael Edwardes
|
|
|
|
email : mte@users.sourceforge.net
|
|
|
|
Javier Campos Morales <javi_c@ctv.es>
|
|
|
|
Felix Rodriguez <frodriguez@mail.wesleyan.edu>
|
|
|
|
Thomas Baumgart <ipwizard@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 KEXPORTDLG_H
|
|
|
|
#define KEXPORTDLG_H
|
|
|
|
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// QT Headers
|
|
|
|
|
|
|
|
#include <tqstring.h>
|
|
|
|
#include <tqcheckbox.h>
|
|
|
|
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// KDE Headers
|
|
|
|
|
|
|
|
#include <kcombobox.h>
|
|
|
|
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// Project Headers
|
|
|
|
|
|
|
|
#include "../widgets/kmymoneydateinput.h"
|
|
|
|
#include "../dialogs/kexportdlgdecl.h"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This class is used to select the required user input to export
|
|
|
|
* a specified account to the popular QIF format.
|
|
|
|
* It relies upon the QIF file handling routines in MyMoneyQifProfile and
|
|
|
|
* MyMoneyQifWriter to do the actual writing of QIF files.
|
|
|
|
*
|
|
|
|
* It uses the global TDEConfig object to read and write the application
|
|
|
|
* settings.
|
|
|
|
*
|
|
|
|
* @see MyMoneyAccount, MyMoneyQifProfile, MyMoneyQifProfileEditor
|
|
|
|
*
|
|
|
|
* @author Felix Rodriguez, Michael Edwardes, Thomas Baumgart 2000-2003
|
|
|
|
*
|
|
|
|
* @short A class to select user data required to export a specified account to the popular QIF format.
|
|
|
|
**/
|
|
|
|
class KExportDlg : public KExportDlgDecl
|
|
|
|
{
|
|
|
|
Q_OBJECT
|
|
|
|
|
|
|
|
|
|
|
|
public:
|
|
|
|
KExportDlg(TQWidget *parent);
|
|
|
|
~KExportDlg();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This method returns the filename entered into the edit field
|
|
|
|
*
|
|
|
|
* @return TQString with filename
|
|
|
|
*/
|
|
|
|
const TQString filename(void) const { return m_qlineeditFile->text(); };
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This method returns the account id that has been selected for export
|
|
|
|
*
|
|
|
|
* @return TQString with account id
|
|
|
|
*/
|
|
|
|
TQString accountId(void) const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This method returns the name of the profile that has been selected
|
|
|
|
* for the export operation
|
|
|
|
*
|
|
|
|
* @return TQString with profile name
|
|
|
|
*/
|
|
|
|
const TQString profile(void) const { return m_profileComboBox->currentText(); };
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This method returns the start date of the export dialog
|
|
|
|
*/
|
|
|
|
const TQDate startDate(void) const { return m_kmymoneydateStart->date(); };
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This method returns the end date of the export dialog
|
|
|
|
*/
|
|
|
|
const TQDate endDate(void) const { return m_kmymoneydateEnd->date(); };
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This method returns the state of the account checkbox
|
|
|
|
*/
|
|
|
|
bool accountSelected(void) const { return m_qcheckboxAccount->isChecked(); };
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This method returns the state of the account checkbox
|
|
|
|
*/
|
|
|
|
bool categorySelected(void) const { return m_qcheckboxCategories->isChecked(); };
|
|
|
|
|
|
|
|
protected slots:
|
|
|
|
/**
|
|
|
|
* Called when the user clicked on the OK button
|
|
|
|
*/
|
|
|
|
void slotOkClicked();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Called when the user needs to browse the filesystem for a QIF file
|
|
|
|
*/
|
|
|
|
void slotBrowse();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Called when the user needs a new profile
|
|
|
|
*/
|
|
|
|
void slotNewProfile(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This slot checks whether all data is correct to enable
|
|
|
|
* the 'Export' button. The enable state of the 'Export' button
|
|
|
|
* is updated appropriately.
|
|
|
|
*
|
|
|
|
* If the parameter @p account is not empty, then it is assumed
|
|
|
|
* a new account is selected and the date fields will be loaded
|
|
|
|
* with the date of the first and last transaction within this
|
|
|
|
* account.
|
|
|
|
*
|
|
|
|
* @param account The id of the selected account.
|
|
|
|
*/
|
|
|
|
void checkData(const TQString& account = TQString());
|
|
|
|
|
|
|
|
private:
|
|
|
|
void readConfig(void);
|
|
|
|
void writeConfig(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This method loads the available profiles into
|
|
|
|
* the combo box. The parameter @p selectLast controls if
|
|
|
|
* the last profile used is preset or not. If preset is not
|
|
|
|
* selected, the current selection remains. If the currently selected
|
|
|
|
* text is not present in the list anymore, the first item will be
|
|
|
|
* selected.
|
|
|
|
*
|
|
|
|
* @param selectLast If true, the last used profile is selected. The
|
|
|
|
* default is false.
|
|
|
|
*/
|
|
|
|
void loadProfiles(const bool selectLast = false);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This method is used to load the available accounts into the
|
|
|
|
* combo box for selection.
|
|
|
|
*/
|
|
|
|
void loadAccounts(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This method is used to load an account hierarchy into a string list
|
|
|
|
*
|
|
|
|
* @param strList Reference to the string list to setup
|
|
|
|
* @param id Account id to add
|
|
|
|
* @param leadIn constant leadin to be added in front of the account name
|
|
|
|
*/
|
|
|
|
// void addCategories(TQStringList& strList, const TQString& id, const TQString& leadIn) const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This method is used to return the account id of a given account name
|
|
|
|
*
|
|
|
|
* @param account name of the account
|
|
|
|
* @return the ID of the account will be returned.
|
|
|
|
* See MyMoneyFile::nameToAccount() for details.
|
|
|
|
*/
|
|
|
|
// TQString accountId(const TQString& account) const;
|
|
|
|
|
|
|
|
private:
|
|
|
|
TQString m_lastAccount;
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|