2 Situare - A location system for Facebook
3 Copyright (C) 2010 Ixonos Plc. Authors:
5 Kaj Wallin - kaj.wallin@ixonos.com
6 Pekka Nissinen - pekka.nissinen@ixonos.com
8 Situare is free software; you can redistribute it and/or
9 modify it under the terms of the GNU General Public License
10 version 2 as published by the Free Software Foundation.
12 Situare is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
17 You should have received a copy of the GNU General Public License
18 along with Situare; if not, write to the Free Software
19 Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
28 #include "panelcommon.h"
30 class QPropertyAnimation;
31 class QSignalTransition;
36 class PanelContentStack;
37 class PanelContextButtonBar;
41 * @brief Class for tabbed panels
43 * @author Kaj Wallin - kaj.wallin (at) ixonos.com
44 * @author Pekka Nissinen - pekka.nissinen (at) ixonos.com
46 class TabbedPanel : public QWidget
54 * @param parent Parent
56 TabbedPanel(QWidget *parent = 0);
58 /*******************************************************************************
59 * MEMBER FUNCTIONS AND SLOTS
60 ******************************************************************************/
63 * @brief Adds a tab to the panel
65 * Adds a tab with the given widget and icon into the tabbed panel and returns the index of the
68 * @param widget Widget to be added into the tab
69 * @param icon Icon of the tab
71 int addTab(QWidget *widget, const QIcon& icon);
74 * @brief Inserts a tab to the panel
76 * Inserts a tab with the given widget and icon into the tabbed panel at the specified index,
77 * and returns the index of the inserted tab.
79 * If index is out of range, the tab is simply appended. Otherwise it is inserted at the
82 * @param index Index of the tab
83 * @param widget Widget to be inserted into the tab
84 * @param icon Icon of the tab
86 int insertTab(int index, QWidget *widget, const QIcon& icon);
89 * @brief Removes a tab from the panel
91 * Removes a tab and its widget from the panel at index position. The widget itself is not
94 * @param index Index of the tab
96 void removeTab(int index);
100 * @brief Slot that closes the panel
105 * @brief Slot that opens the panel
107 * If widget pointer is provided the corresponding tab is also set active
109 * @param widget Widget
111 void openPanel(QWidget *widget = 0);
114 * @brief Slot to redraw the panel after window resize event
116 * @param size Size of the new window
118 void resizePanel(const QSize &size);
122 * @brief Calculates mask for tabbed panel
124 * Mask is constructed from PanelTabBar, PanelContextButtonBar and panel content sizes.
126 void calculateMask();
129 * @brief Repositions context button bar
131 void repositionContextButtonBar();
134 * @brief Sets the panel at current index active
136 * @param index Index of the panel
138 void setCurrentIndex(int index);
141 * @brief Internal slot used to set the panel state
145 /*******************************************************************************
147 ******************************************************************************/
150 * @brief This signal is emitted whenever the current tab page changes
152 * @param index Index of the new tab page
154 void currentChanged(int index);
157 * @brief Signal that is sent when panel is closed
165 * @brief Signal that is sent when panel is opened
173 * @brief Signal that is sent when the panel state must be changed
180 /*******************************************************************************
182 ******************************************************************************/
184 bool m_open; ///< Current state of the panel
185 bool m_closeRequestPending; ///< Indicates wheater the panel is waiting to be closed
187 QState *m_stateClosed; ///< State of the closed panel
188 QState *m_stateOpened; ///< State of the opened panel
190 PanelBar *m_panelBar; ///< Widget for panel bar
191 PanelContentStack *m_panelContentStack; ///< Stack for panel widgets
192 PanelContextButtonBar * m_panelContextButtonBar; ///< Widget for panel context button bar
193 PanelTabBar *m_panelTabBar; ///< Widget for panel tab bar
196 #endif // TABBEDPANEL_H