2006-03-05 17:24:44 +00:00
|
|
|
// -*- C++ -*-
|
|
|
|
/**
|
2007-09-03 05:59:32 +00:00
|
|
|
* \file ButtonController.h
|
2006-03-05 17:24:44 +00:00
|
|
|
* This file is part of LyX, the document processor.
|
|
|
|
* Licence details can be found in the file COPYING.
|
|
|
|
*
|
|
|
|
* \author Allan Rae
|
|
|
|
*
|
|
|
|
* Full author contact details are available in file CREDITS.
|
|
|
|
*/
|
|
|
|
|
2007-09-03 05:59:32 +00:00
|
|
|
#ifndef BUTTONCONTROLLER_H
|
|
|
|
#define BUTTONCONTROLLER_H
|
2006-03-05 17:24:44 +00:00
|
|
|
|
2007-09-03 05:59:32 +00:00
|
|
|
#include "ButtonPolicy.h"
|
2007-11-22 22:20:51 +00:00
|
|
|
|
2006-03-05 17:24:44 +00:00
|
|
|
class QWidget;
|
|
|
|
class QPushButton;
|
2007-09-02 08:19:43 +00:00
|
|
|
class QLineEdit;
|
2009-01-18 14:33:51 +00:00
|
|
|
class QCheckBox;
|
2006-03-05 17:24:44 +00:00
|
|
|
|
|
|
|
namespace lyx {
|
|
|
|
namespace frontend {
|
|
|
|
|
|
|
|
/** General purpose button controller for up to four buttons.
|
|
|
|
Controls the activation of the OK, Apply and Cancel buttons.
|
|
|
|
Actually supports 4 buttons in all and it's up to the user to decide on
|
|
|
|
the activation policy and which buttons correspond to which output of the
|
|
|
|
state machine.
|
|
|
|
*/
|
2007-09-01 20:44:14 +00:00
|
|
|
|
2007-09-03 05:59:32 +00:00
|
|
|
|
|
|
|
/** \c ButtonController controls the activation of the OK, Apply and
|
|
|
|
* Cancel buttons.
|
|
|
|
*
|
|
|
|
* It actually supports 4 buttons in all and it's up to the user to decide on
|
|
|
|
* the activation policy and which buttons correspond to which output of the
|
|
|
|
* state machine.
|
|
|
|
*/
|
|
|
|
|
|
|
|
class ButtonController
|
2007-09-01 20:44:14 +00:00
|
|
|
{
|
2006-03-05 17:24:44 +00:00
|
|
|
public:
|
2007-09-03 05:59:32 +00:00
|
|
|
ButtonController();
|
2008-04-19 09:12:34 +00:00
|
|
|
~ButtonController();
|
2007-09-03 05:59:32 +00:00
|
|
|
|
|
|
|
//@{
|
2010-01-27 18:10:33 +00:00
|
|
|
/// Methods to set and get the ButtonPolicy.
|
2007-09-03 05:59:32 +00:00
|
|
|
void setPolicy(ButtonPolicy::Policy policy);
|
2008-04-19 09:12:34 +00:00
|
|
|
ButtonPolicy const & policy() const;
|
|
|
|
ButtonPolicy & policy();
|
2007-09-03 05:59:32 +00:00
|
|
|
//@}
|
|
|
|
|
2006-03-05 17:24:44 +00:00
|
|
|
///
|
2007-09-03 05:59:32 +00:00
|
|
|
void input(ButtonPolicy::SMInput);
|
|
|
|
|
|
|
|
//@{
|
|
|
|
/// Tell the BC that a particular button has been pressed.
|
|
|
|
void ok();
|
|
|
|
void apply();
|
|
|
|
void cancel();
|
|
|
|
void restore();
|
2009-01-18 14:33:51 +00:00
|
|
|
void autoApply();
|
2007-09-03 05:59:32 +00:00
|
|
|
//@}
|
|
|
|
|
|
|
|
/// Tell the BC that the dialog is being hidden
|
|
|
|
void hide();
|
|
|
|
|
|
|
|
/**Refresh the activation state of the Ok, Apply, Close and
|
|
|
|
* Restore buttons.
|
|
|
|
*/
|
|
|
|
void refresh() const;
|
|
|
|
|
|
|
|
/** Passthrough function -- returns its input value
|
|
|
|
* Tell the BC about the read-only status of the underlying buffer.
|
|
|
|
*/
|
2008-04-19 09:12:34 +00:00
|
|
|
bool setReadOnly(bool);
|
2007-09-03 05:59:32 +00:00
|
|
|
|
2010-01-27 18:10:33 +00:00
|
|
|
/**
|
2007-09-03 05:59:32 +00:00
|
|
|
* Sets the activation state of the buttons immediately.
|
2010-01-27 18:10:33 +00:00
|
|
|
* \param validity Tell the BC that the data is, or is not, valid.
|
2007-09-03 05:59:32 +00:00
|
|
|
*/
|
2008-04-19 09:12:34 +00:00
|
|
|
void setValid(bool);
|
2007-09-03 05:59:32 +00:00
|
|
|
|
|
|
|
//
|
|
|
|
// View
|
|
|
|
//
|
2007-09-01 20:44:14 +00:00
|
|
|
|
|
|
|
//@{
|
2018-12-20 12:56:30 +01:00
|
|
|
/// Store pointers to these widgets. \param default_button determines
|
|
|
|
/// the default button of the dialog (bound to return). This is
|
|
|
|
/// OK by default.
|
|
|
|
void setOK(QPushButton * obj, bool const default_button = true);
|
|
|
|
void setApply(QPushButton * obj, bool const default_button = false);
|
|
|
|
void setCancel(QPushButton * obj, bool const default_button = false);
|
|
|
|
void setRestore(QPushButton * obj, bool const default_button = false);
|
2009-01-18 14:33:51 +00:00
|
|
|
void setAutoApply(QCheckBox * obj);
|
2007-09-01 20:44:14 +00:00
|
|
|
//@}
|
|
|
|
|
|
|
|
/** Add a pointer to the list of widgets whose activation
|
|
|
|
* state is dependent upon the read-only status of the
|
|
|
|
* underlying buffer.
|
|
|
|
*/
|
2008-04-19 09:12:34 +00:00
|
|
|
void addReadOnly(QWidget * obj);
|
2006-03-05 17:24:44 +00:00
|
|
|
|
2007-09-02 07:53:07 +00:00
|
|
|
/** Add a widget to the list of all widgets whose validity should
|
|
|
|
* be checked explicitly when the buttons are refreshed.
|
|
|
|
*/
|
2007-09-02 08:19:43 +00:00
|
|
|
void addCheckedLineEdit(QLineEdit * input, QWidget * label = 0);
|
2007-09-02 07:53:07 +00:00
|
|
|
|
2007-09-03 05:59:32 +00:00
|
|
|
private:
|
2008-04-19 09:12:34 +00:00
|
|
|
/// noncopyable
|
|
|
|
ButtonController(ButtonController const &);
|
|
|
|
void operator=(ButtonController const &);
|
2017-07-03 13:45:58 -04:00
|
|
|
|
2008-04-19 09:12:34 +00:00
|
|
|
/// pimpl
|
|
|
|
class Private;
|
|
|
|
Private * d;
|
2006-03-05 17:24:44 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace frontend
|
|
|
|
} // namespace lyx
|
|
|
|
|
2007-09-03 05:59:32 +00:00
|
|
|
#endif // BUTTONCONTROLLER_H
|