* This file is part of LyX, the document processor.
* Licence details can be found in the file COPYING.
*
- * \author Lars Gullik Bjønnes
+ * \author Lars Gullik Bjønnes
* \author John Levon
* \author Jean-Marc Lasgouttes
* \author Angus Leeming
#ifndef GUITOOLBAR_H
#define GUITOOLBAR_H
-#include "Session.h"
-
#include <QList>
#include <QToolBar>
-#include <QComboBox>
+#include <QToolButton>
namespace lyx {
-class TextClass;
-class ToolbarItem;
+class DocumentClass;
+class Inset;
namespace frontend {
+class Action;
class GuiCommandBuffer;
+class GuiLayoutFilterModel;
+class GuiToolbar;
class GuiView;
-class Action;
-
+class LayoutBox;
+class ToolbarInfo;
+class ToolbarItem;
-class GuiLayoutBox : public QComboBox
+class MenuButton : public QToolButton
{
Q_OBJECT
public:
- GuiLayoutBox(GuiView &);
+ ///
+ MenuButton(GuiToolbar * bar, ToolbarItem const & item,
+ bool const sticky = false);
- /// select the right layout in the combobox.
- void set(docstring const & layout);
- /// Populate the layout combobox.
- void updateContents(bool reset);
- /// Add Item to Layout box according to sorting settings from preferences
- void addItemSort(QString const & item, bool sorted);
+private:
+ ///
+ void initialize();
+ ///
+ GuiToolbar * bar_;
+ ///
+ ToolbarItem const & tbitem_;
private Q_SLOTS:
- void selected(const QString & str);
-
-private:
- GuiView & owner_;
- TextClass const * text_class_;
+ ///
+ void actionTriggered(QAction * action);
+ ///
+ void updateTriggered();
};
+
class GuiToolbar : public QToolBar
{
Q_OBJECT
public:
+ ///
GuiToolbar(ToolbarInfo const &, GuiView &);
+
+ /// Reimplemented from QToolbar to detect whether the
+ /// toolbar is restored with MainWindow::restoreState().
+ void setVisible(bool visible);
+
+ ///
+ void setVisibility(int visibility);
/// Add a button to the bar.
void add(ToolbarItem const & item);
- /** update toolbar information
- * ToolbarInfo will then be saved by session
- */
- void saveInfo(ToolbarSection::ToolbarInfo & info);
+
+ /// Session key.
+ /**
+ * This key must be used for any session setting.
+ **/
+ QString sessionKey() const;
+ /// Save session settings.
+ void saveSession() const;
+ /// Restore session settings.
+ void restoreSession();
+
+ ///
+ bool isRestored() const;
+
/// Refresh the contents of the bar.
- void updateContents();
+ void update(int context = 0);
+
+ ///
+ void toggle();
+
///
GuiCommandBuffer * commandBuffer() { return command_buffer_; }
+ ///
Action * addItem(ToolbarItem const & item);
Q_SIGNALS:
+ ///
void updated();
private:
+ // load flags with saved values
+ void initFlags();
+ ///
+ void fill();
+ ///
+ void showEvent(QShowEvent *);
+ ///
QList<Action *> actions_;
+ /// initial visibility flags
+ int visibility_;
+ ///
GuiView & owner_;
-
- GuiLayoutBox * layout_;
+ ///
GuiCommandBuffer * command_buffer_;
+ ///
+ ToolbarInfo const & tbinfo_;
+ ///
+ bool filled_;
+ ///
+ bool restored_;
};
} // namespace frontend