diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/Toolbar.cc | 23 | ||||
-rw-r--r-- | src/Toolbar.hh | 8 |
2 files changed, 12 insertions, 19 deletions
diff --git a/src/Toolbar.cc b/src/Toolbar.cc index 1f03cc5..5d508e4 100644 --- a/src/Toolbar.cc +++ b/src/Toolbar.cc | |||
@@ -22,18 +22,20 @@ | |||
22 | // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER | 22 | // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER |
23 | // DEALINGS IN THE SOFTWARE. | 23 | // DEALINGS IN THE SOFTWARE. |
24 | 24 | ||
25 | // $Id: Toolbar.cc,v 1.119 2003/08/28 15:04:47 fluxgen Exp $ | 25 | // $Id: Toolbar.cc,v 1.120 2003/08/29 00:44:41 fluxgen Exp $ |
26 | 26 | ||
27 | #include "Toolbar.hh" | 27 | #include "Toolbar.hh" |
28 | 28 | ||
29 | // themes | 29 | // themes |
30 | #include "ToolbarTheme.hh" | 30 | #include "ToolbarTheme.hh" |
31 | #include "WorkspaceNameTheme.hh" | ||
31 | 32 | ||
32 | // tools | 33 | // tools |
33 | #include "IconbarTool.hh" | 34 | #include "IconbarTool.hh" |
34 | #include "WorkspaceNameTool.hh" | 35 | #include "WorkspaceNameTool.hh" |
35 | #include "ClockTool.hh" | 36 | #include "ClockTool.hh" |
36 | #include "SystemTray.hh" | 37 | #include "SystemTray.hh" |
38 | |||
37 | 39 | ||
38 | #include "I18n.hh" | 40 | #include "I18n.hh" |
39 | #include "fluxbox.hh" | 41 | #include "fluxbox.hh" |
@@ -216,7 +218,6 @@ Toolbar::Frame::~Frame() { | |||
216 | } | 218 | } |
217 | 219 | ||
218 | Toolbar::Toolbar(BScreen &scrn, FbTk::XLayer &layer, FbTk::Menu &menu, size_t width): | 220 | Toolbar::Toolbar(BScreen &scrn, FbTk::XLayer &layer, FbTk::Menu &menu, size_t width): |
219 | m_editing(false), | ||
220 | m_hidden(false), | 221 | m_hidden(false), |
221 | frame(*this, scrn.screenNumber()), | 222 | frame(*this, scrn.screenNumber()), |
222 | m_window_pm(0), | 223 | m_window_pm(0), |
@@ -232,7 +233,7 @@ Toolbar::Toolbar(BScreen &scrn, FbTk::XLayer &layer, FbTk::Menu &menu, size_t wi | |||
232 | true), | 233 | true), |
233 | m_theme(scrn.screenNumber()), | 234 | m_theme(scrn.screenNumber()), |
234 | m_clock_theme(scrn.screenNumber(), "toolbar.clock", "Toolbar.Clock"), | 235 | m_clock_theme(scrn.screenNumber(), "toolbar.clock", "Toolbar.Clock"), |
235 | m_workspace_theme(scrn.screenNumber(), "toolbar.workspace", "Toolbar.Workspace"), | 236 | m_workspace_theme(new WorkspaceNameTheme(scrn.screenNumber(), "toolbar.workspace", "Toolbar.Workspace")), |
236 | m_iconbar_theme(scrn.screenNumber(), "toolbar.iconbar", "Toolbar.Iconbar"), | 237 | m_iconbar_theme(scrn.screenNumber(), "toolbar.iconbar", "Toolbar.Iconbar"), |
237 | m_layeritem(frame.window, layer), | 238 | m_layeritem(frame.window, layer), |
238 | m_strut(0), | 239 | m_strut(0), |
@@ -279,7 +280,7 @@ Toolbar::Toolbar(BScreen &scrn, FbTk::XLayer &layer, FbTk::Menu &menu, size_t wi | |||
279 | // set antialias on themes | 280 | // set antialias on themes |
280 | m_clock_theme.setAntialias(screen().antialias()); | 281 | m_clock_theme.setAntialias(screen().antialias()); |
281 | m_iconbar_theme.setAntialias(screen().antialias()); | 282 | m_iconbar_theme.setAntialias(screen().antialias()); |
282 | m_workspace_theme.setAntialias(screen().antialias()); | 283 | m_workspace_theme->setAntialias(screen().antialias()); |
283 | 284 | ||
284 | // setup hide timer | 285 | // setup hide timer |
285 | m_hide_timer.setTimeout(Fluxbox::instance()->getAutoRaiseDelay()); | 286 | m_hide_timer.setTimeout(Fluxbox::instance()->getAutoRaiseDelay()); |
@@ -378,7 +379,7 @@ void Toolbar::lower() { | |||
378 | void Toolbar::reconfigure() { | 379 | void Toolbar::reconfigure() { |
379 | m_clock_theme.setAntialias(screen().antialias()); | 380 | m_clock_theme.setAntialias(screen().antialias()); |
380 | m_iconbar_theme.setAntialias(screen().antialias()); | 381 | m_iconbar_theme.setAntialias(screen().antialias()); |
381 | m_workspace_theme.setAntialias(screen().antialias()); | 382 | m_workspace_theme->setAntialias(screen().antialias()); |
382 | 383 | ||
383 | 384 | ||
384 | 385 | ||
@@ -425,7 +426,7 @@ void Toolbar::reconfigure() { | |||
425 | StringList::const_iterator item_it_end = m_tools.end(); | 426 | StringList::const_iterator item_it_end = m_tools.end(); |
426 | for (; item_it != item_it_end; ++item_it) { | 427 | for (; item_it != item_it_end; ++item_it) { |
427 | if (*item_it == "workspacename") { | 428 | if (*item_it == "workspacename") { |
428 | WorkspaceNameTool *item = new WorkspaceNameTool(frame.window, m_workspace_theme, screen()); | 429 | WorkspaceNameTool *item = new WorkspaceNameTool(frame.window, *m_workspace_theme, screen()); |
429 | using namespace FbTk; | 430 | using namespace FbTk; |
430 | RefCount<Command> showmenu(new ShowMenuAboveToolbar(*this)); | 431 | RefCount<Command> showmenu(new ShowMenuAboveToolbar(*this)); |
431 | item->button().setOnClick(showmenu); | 432 | item->button().setOnClick(showmenu); |
@@ -621,8 +622,8 @@ void Toolbar::setPlacement(Toolbar::Placement where) { | |||
621 | if (max_height < m_clock_theme.font().height()) | 622 | if (max_height < m_clock_theme.font().height()) |
622 | max_height = m_clock_theme.font().height(); | 623 | max_height = m_clock_theme.font().height(); |
623 | 624 | ||
624 | if (max_height < m_workspace_theme.font().height()) | 625 | if (max_height < m_workspace_theme->font().height()) |
625 | max_height = m_workspace_theme.font().height(); | 626 | max_height = m_workspace_theme->font().height(); |
626 | 627 | ||
627 | if (max_height < m_iconbar_theme.focusedText().font().height()) | 628 | if (max_height < m_iconbar_theme.focusedText().font().height()) |
628 | max_height = m_iconbar_theme.focusedText().font().height(); | 629 | max_height = m_iconbar_theme.focusedText().font().height(); |
@@ -761,12 +762,6 @@ void Toolbar::setPlacement(Toolbar::Placement where) { | |||
761 | } | 762 | } |
762 | 763 | ||
763 | void Toolbar::toggleHidden() { | 764 | void Toolbar::toggleHidden() { |
764 | if (isEditing()) { // don't hide if we're editing workspace label | ||
765 | m_hide_timer.fireOnce(false); | ||
766 | m_hide_timer.start(); // restart timer and try next timeout | ||
767 | return; | ||
768 | } | ||
769 | |||
770 | m_hide_timer.fireOnce(true); | 765 | m_hide_timer.fireOnce(true); |
771 | 766 | ||
772 | // toggle hidden | 767 | // toggle hidden |
diff --git a/src/Toolbar.hh b/src/Toolbar.hh index 981fb1a..719dac3 100644 --- a/src/Toolbar.hh +++ b/src/Toolbar.hh | |||
@@ -22,7 +22,7 @@ | |||
22 | // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER | 22 | // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER |
23 | // DEALINGS IN THE SOFTWARE. | 23 | // DEALINGS IN THE SOFTWARE. |
24 | 24 | ||
25 | // $Id: Toolbar.hh,v 1.45 2003/08/28 13:58:17 fluxgen Exp $ | 25 | // $Id: Toolbar.hh,v 1.46 2003/08/29 00:44:41 fluxgen Exp $ |
26 | 26 | ||
27 | #ifndef TOOLBAR_HH | 27 | #ifndef TOOLBAR_HH |
28 | #define TOOLBAR_HH | 28 | #define TOOLBAR_HH |
@@ -114,8 +114,6 @@ public: | |||
114 | inline FbTk::Menu &layermenu() { return m_layermenu; } | 114 | inline FbTk::Menu &layermenu() { return m_layermenu; } |
115 | inline const FbTk::Menu &layermenu() const { return m_layermenu; } | 115 | inline const FbTk::Menu &layermenu() const { return m_layermenu; } |
116 | 116 | ||
117 | /// are we in workspacename editing? | ||
118 | inline bool isEditing() const { return m_editing; } | ||
119 | /// are we hidden? | 117 | /// are we hidden? |
120 | inline bool isHidden() const { return m_hidden; } | 118 | inline bool isHidden() const { return m_hidden; } |
121 | /// do we auto hide the toolbar? | 119 | /// do we auto hide the toolbar? |
@@ -146,7 +144,6 @@ private: | |||
146 | void clearStrut(); | 144 | void clearStrut(); |
147 | void updateStrut(); | 145 | void updateStrut(); |
148 | 146 | ||
149 | bool m_editing; ///< edit workspace label mode | ||
150 | bool m_hidden; ///< hidden state | 147 | bool m_hidden; ///< hidden state |
151 | 148 | ||
152 | /// Toolbar frame | 149 | /// Toolbar frame |
@@ -171,7 +168,8 @@ private: | |||
171 | 168 | ||
172 | // themes | 169 | // themes |
173 | ToolbarTheme m_theme; | 170 | ToolbarTheme m_theme; |
174 | ToolTheme m_clock_theme, m_workspace_theme; | 171 | ToolTheme m_clock_theme; |
172 | std::auto_ptr<ToolTheme> m_workspace_theme; | ||
175 | IconbarTheme m_iconbar_theme; | 173 | IconbarTheme m_iconbar_theme; |
176 | 174 | ||
177 | FbTk::XLayerItem m_layeritem; | 175 | FbTk::XLayerItem m_layeritem; |