You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
kmymoney/kmymoney2/dialogs/kexportdlg.h

182 lines
5.8 KiB

/***************************************************************************
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 TQIF format.
* It relies upon the TQIF file handling routines in MyMoneyQifProfile and
* MyMoneyQifWriter to do the actual writing of TQIF files.
*
* It uses the global KConfig 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 TQIF format.
**/
class KExportDlg : public KExportDlgDecl
{
Q_OBJECT
TQ_OBJECT
public:
KExportDlg(TQWidget *tqparent);
~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 TQIF 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