|
|
|
/*
|
|
|
|
* pickfileradio.h - radio button with an associated file picker
|
|
|
|
* Program: kalarm
|
|
|
|
* Copyright (C) 2005 by David Jarvie <software@astrojar.org.uk>
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License along
|
|
|
|
* with this program; if not, write to the Free Software Foundation, Inc.,
|
|
|
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef PICKFILERADIO_H
|
|
|
|
#define PICKFILERADIO_H
|
|
|
|
|
|
|
|
/** @file pickfileradio.h - radio button with an associated file picker */
|
|
|
|
|
|
|
|
#include "radiobutton.h"
|
|
|
|
|
|
|
|
class TQPushButton;
|
|
|
|
class LineEdit;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @short Radio button with associated file picker controls.
|
|
|
|
*
|
|
|
|
* The PickFileRadio class is a radio button with an associated button to choose
|
|
|
|
* a file, and an optional file name edit box. Its purpose is to ensure that while
|
|
|
|
* the radio button is selected, the chosen file name is never blank.
|
|
|
|
*
|
|
|
|
* To achieve this, whenever the button is newly selected and the
|
|
|
|
* file name is currently blank, the file picker dialogue is displayed to choose a
|
|
|
|
* file. If the dialogue exits without a file being chosen, the radio button selection
|
|
|
|
* is reverted to the previously selected button in the parent button group.
|
|
|
|
*
|
|
|
|
* The class handles the activation of the file picker dialogue (via a virtual method
|
|
|
|
* which must be supplied by deriving a class from this one). It also handles all
|
|
|
|
* enabling and disabling of the browse button and edit box when the enable state of
|
|
|
|
* the radio button is changed, and when the radio button selection changes.
|
|
|
|
*
|
|
|
|
* @author David Jarvie <software@astrojar.org.uk>
|
|
|
|
*/
|
|
|
|
class PickFileRadio : public RadioButton
|
|
|
|
{
|
|
|
|
Q_OBJECT
|
|
|
|
|
|
|
|
public:
|
|
|
|
/** Constructor.
|
|
|
|
* @param button Push button to invoke the file picker dialogue.
|
|
|
|
* @param edit File name edit widget, or null if there is none.
|
|
|
|
* @param text Radio button's text.
|
|
|
|
* @param parent Button group which is to be the parent object for the radio button.
|
|
|
|
* @param name The name of this widget.
|
|
|
|
*/
|
|
|
|
PickFileRadio(TQPushButton* button, LineEdit* edit, const TQString& text, TQButtonGroup* parent, const char* name = 0);
|
|
|
|
/** Constructor.
|
|
|
|
* The init() method must be called before the widget can be used.
|
|
|
|
* @param text Radio button's text.
|
|
|
|
* @param parent Button group which is to be the parent object for the radio button.
|
|
|
|
* @param name The name of this widget.
|
|
|
|
*/
|
|
|
|
PickFileRadio(const TQString& text, TQButtonGroup* parent, const char* name = 0);
|
|
|
|
/** Initialises the widget.
|
|
|
|
* @param button Push button to invoke the file picker dialogue.
|
|
|
|
* @param edit File name edit widget, or null if there is none.
|
|
|
|
*/
|
|
|
|
void init(TQPushButton* button, LineEdit* edit = 0);
|
|
|
|
/** Sets whether the radio button and associated widgets are read-only for the user.
|
|
|
|
* If read-only, their states cannot be changed by the user.
|
|
|
|
* @param readOnly True to set the widgets read-only, false to set them read-write.
|
|
|
|
*/
|
|
|
|
virtual void setReadOnly(bool readOnly);
|
|
|
|
/** Chooses a file, for example by displaying a file selection dialogue.
|
|
|
|
* This method is called when the push button is clicked - the client
|
|
|
|
* should not activate a file selection dialogue directly.
|
|
|
|
* @return Selected file name, or TQString() if no selection made.
|
|
|
|
*/
|
|
|
|
virtual TQString pickFile() = 0;
|
|
|
|
/** Notifies the widget of the currently selected file name.
|
|
|
|
* This should only be used when no file name edit box is used.
|
|
|
|
* It should be called to initialise the widget's data, and also any time the file
|
|
|
|
* name is changed without using the push button.
|
|
|
|
*/
|
|
|
|
void setFile(const TQString& file);
|
|
|
|
/** Returns the currently selected file name. */
|
|
|
|
TQString file() const;
|
|
|
|
/** Returns the associated file name edit widget, or null if none. */
|
|
|
|
LineEdit* fileEdit() const { return mEdit; }
|
|
|
|
/** Returns the associated file browse push button. */
|
|
|
|
TQPushButton* pushButton() const { return mButton; }
|
|
|
|
|
|
|
|
public slots:
|
|
|
|
/** Enables or disables the radio button, and adjusts the enabled state of the
|
|
|
|
* associated browse button and file name edit box.
|
|
|
|
*/
|
|
|
|
virtual void setEnabled(bool);
|
|
|
|
|
|
|
|
private slots:
|
|
|
|
void slotSelectionChanged(int id);
|
|
|
|
void slotPickFile();
|
|
|
|
void setLastId();
|
|
|
|
|
|
|
|
private:
|
|
|
|
bool pickFileIfNone();
|
|
|
|
|
|
|
|
TQButtonGroup* mGroup; // button group which radio button is in
|
|
|
|
LineEdit* mEdit; // file name edit box, or null if none
|
|
|
|
TQPushButton* mButton; // push button to pick a file
|
|
|
|
TQString mFile; // saved file name (if mEdit is null)
|
|
|
|
int mLastId; // previous radio button selected
|
|
|
|
bool mRevertId; // true to revert to the previous radio button selection
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif // PICKFILERADIO_H
|