4 * This file is part of LyX, the document processor.
5 * Licence details can be found in the file COPYING.
7 * \author Lars Gullik Bjornes
9 * \author Abdelrazak Younes
10 * \author Peter Kümmel
12 * Full author contact details are available in file CREDITS.
18 #include "frontends/LyXView.h"
19 #include "FuncRequest.h"
22 #include <QCloseEvent>
23 #include <QMainWindow>
27 class QDragEnterEvent;
38 QWidget * mainWindow();
41 * GuiView - Qt4 implementation of LyXView
43 * qt4-private implementation of the main LyX window.
45 * Note: a QObject emits a destroyed(QObject *) Qt signal when it
46 * is deleted. This might be useful for closing other dialogs
47 * depending on a given GuiView.
49 class GuiView : public QMainWindow, public LyXView
53 /// create a main window of the given dimensions
60 virtual void setFocus();
61 virtual void setGeometry(
66 unsigned int iconSizeXY,
67 const std::string & geometryArg);
68 virtual void saveGeometry();
69 virtual void setBusy(bool);
70 /// add toolbar, if newline==true, add a toolbar break before the toolbar
71 GuiToolbar * makeToolbar(ToolbarInfo const & tbinfo, bool newline);
72 virtual void updateStatusBar();
73 virtual void message(docstring const & str);
74 virtual void clearMessage();
75 virtual bool hasFocus() const;
76 void showMiniBuffer(bool);
77 void openMenu(docstring const &);
78 void openLayoutList();
79 void updateLayoutChoice(bool force);
80 bool isToolbarVisible(std::string const & id);
81 void updateToolbars();
82 ToolbarInfo * getToolbarInfo(std::string const & name);
83 void toggleToolbarState(std::string const & name, bool allowauto);
85 /// show - display the top-level window
88 /// menu item has been selected
89 void activated(FuncRequest const &);
91 QMenu* createPopupMenu();
93 void addTabWorkArea();
100 void update_view_state_qt();
103 void updateWindowTitle(GuiWorkArea * wa);
106 void on_currentWorkAreaChanged(GuiWorkArea *);
108 /// slots to change the icon size
109 void smallSizedIcons();
110 void normalSizedIcons();
111 void bigSizedIcons();
114 /// make sure we quit cleanly
115 virtual void closeEvent(QCloseEvent * e);
117 virtual void resizeEvent(QResizeEvent * e);
119 virtual void moveEvent(QMoveEvent * e);
121 /// \return the \c Workarea associated to \p Buffer
122 /// \retval 0 if no \c WorkArea is found.
123 WorkArea * workArea(Buffer & buffer);
125 /// Add a \c WorkArea
126 /// \return the \c Workarea associated to \p Buffer
127 /// \retval 0 if no \c WorkArea is found.
128 WorkArea * addWorkArea(Buffer & buffer);
129 void setCurrentWorkArea(WorkArea * work_area);
130 void removeWorkArea(WorkArea * work_area);
131 WorkArea const * currentWorkArea() const;
132 WorkArea * currentWorkArea();
136 void dragEnterEvent(QDragEnterEvent * ev);
138 void dropEvent(QDropEvent * ev);
140 /// in order to catch Tab key press.
141 bool event(QEvent * e);
142 bool focusNextPrevChild(bool);
144 QTimer statusbar_timer_;
146 /// are we quitting by the menu?
147 bool quitting_by_menu_;
150 QRect updateFloatingGeometry();
152 QRect floatingGeometry_;
154 void setIconSize(unsigned int size);
163 ToolbarSize toolbarSize_;
165 struct GuiViewPrivate;
170 } // namespace frontend