summaryrefslogtreecommitdiff
path: root/src/IconbarTool.cc
diff options
context:
space:
mode:
Diffstat (limited to 'src/IconbarTool.cc')
-rw-r--r--src/IconbarTool.cc76
1 files changed, 75 insertions, 1 deletions
diff --git a/src/IconbarTool.cc b/src/IconbarTool.cc
index ee6095e..c14e056 100644
--- a/src/IconbarTool.cc
+++ b/src/IconbarTool.cc
@@ -20,7 +20,7 @@
20// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER 20// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
21// DEALINGS IN THE SOFTWARE. 21// DEALINGS IN THE SOFTWARE.
22 22
23// $Id: IconbarTool.cc,v 1.21 2003/12/10 23:08:03 fluxgen Exp $ 23// $Id: IconbarTool.cc,v 1.22 2003/12/12 14:36:22 fluxgen Exp $
24 24
25#include "IconbarTool.hh" 25#include "IconbarTool.hh"
26 26
@@ -63,6 +63,35 @@ void FbTk::Resource<IconbarTool::Mode>::setFromString(const char *strval) {
63 setDefaultValue(); 63 setDefaultValue();
64} 64}
65 65
66template<>
67void FbTk::Resource<Container::Alignment>::setDefaultValue() {
68 m_value = Container::RELATIVE;
69}
70
71template<>
72string FbTk::Resource<Container::Alignment>::getString() {
73 switch (m_value) {
74 case Container::LEFT:
75 return string("Left");
76 case Container::RIGHT:
77 return string("Right");
78 case Container::RELATIVE:
79 return string("Relative");
80 }
81 return string("Left");
82}
83
84template<>
85void FbTk::Resource<Container::Alignment>::setFromString(const char *str) {
86 if (strcasecmp(str, "Left") == 0)
87 m_value = Container::LEFT;
88 else if (strcasecmp(str, "Right") == 0)
89 m_value = Container::RIGHT;
90 else if (strcasecmp(str, "RELATIVE") == 0)
91 m_value = Container::RELATIVE;
92 else
93 setDefaultValue();
94}
66 95
67template<> 96template<>
68string FbTk::Resource<IconbarTool::Mode>::getString() { 97string FbTk::Resource<IconbarTool::Mode>::getString() {
@@ -108,6 +137,24 @@ private:
108 IconbarTool::Mode m_mode; 137 IconbarTool::Mode m_mode;
109}; 138};
110 139
140class ToolbarAlignMenuItem: public FbTk::MenuItem {
141public:
142 ToolbarAlignMenuItem(const char *label, IconbarTool &handler,
143 Container::Alignment mode,
144 FbTk::RefCount<FbTk::Command> &cmd):
145 FbTk::MenuItem(label, cmd), m_handler(handler), m_mode(mode) {
146 }
147 bool isEnabled() const { return m_handler.alignment() != m_mode; }
148 void click(int button, int time) {
149 m_handler.setAlignment(m_mode);
150 FbTk::MenuItem::click(button, time);
151 }
152
153private:
154 IconbarTool &m_handler;
155 Container::Alignment m_mode;
156};
157
111void setupModeMenu(FbTk::Menu &menu, IconbarTool &handler) { 158void setupModeMenu(FbTk::Menu &menu, IconbarTool &handler) {
112 using namespace FbTk; 159 using namespace FbTk;
113 160
@@ -129,6 +176,14 @@ void setupModeMenu(FbTk::Menu &menu, IconbarTool &handler) {
129 IconbarTool::WORKSPACE, saverc_cmd)); 176 IconbarTool::WORKSPACE, saverc_cmd));
130 menu.insert(new ToolbarModeMenuItem("All Windows", handler, 177 menu.insert(new ToolbarModeMenuItem("All Windows", handler,
131 IconbarTool::ALLWINDOWS, saverc_cmd)); 178 IconbarTool::ALLWINDOWS, saverc_cmd));
179 menu.insert("---"); // separator line
180 menu.insert(new ToolbarAlignMenuItem("Left", handler,
181 Container::LEFT, saverc_cmd));
182 menu.insert(new ToolbarAlignMenuItem("Relative", handler,
183 Container::RELATIVE, saverc_cmd));
184 menu.insert(new ToolbarAlignMenuItem("Right", handler,
185 Container::RIGHT, saverc_cmd));
186 menu.insert("---"); // separator line
132 menu.update(); 187 menu.update();
133} 188}
134 189
@@ -184,6 +239,10 @@ IconbarTool::IconbarTool(const FbTk::FbWindow &parent, IconbarTheme &theme, BScr
184 m_empty_pm(0), 239 m_empty_pm(0),
185 m_rc_mode(screen.resourceManager(), WORKSPACE, 240 m_rc_mode(screen.resourceManager(), WORKSPACE,
186 screen.name() + ".iconbar.mode", screen.altName() + ".Iconbar.Mode"), 241 screen.name() + ".iconbar.mode", screen.altName() + ".Iconbar.Mode"),
242 m_rc_alignment(screen.resourceManager(), Container::LEFT,
243 screen.name() + ".iconbar.alignment", screen.altName() + ".Iconbar.Alignment"),
244 m_rc_client_width(screen.resourceManager(), 70,
245 screen.name() + ".iconbar.clientWidth", screen.altName() + ".Iconbar.ClientWidth"),
187 m_rc_use_pixmap(screen.resourceManager(), true, 246 m_rc_use_pixmap(screen.resourceManager(), true,
188 screen.name() + ".iconbar.usePixmap", screen.altName() + ".Iconbar.UsePixmap"), 247 screen.name() + ".iconbar.usePixmap", screen.altName() + ".Iconbar.UsePixmap"),
189 m_menu(*screen.menuTheme(), screen.imageControl(), 248 m_menu(*screen.menuTheme(), screen.imageControl(),
@@ -254,6 +313,11 @@ void IconbarTool::hide() {
254 m_icon_container.hide(); 313 m_icon_container.hide();
255} 314}
256 315
316void IconbarTool::setAlignment(Container::Alignment align) {
317 *m_rc_alignment = align;
318 update(0);
319}
320
257void IconbarTool::setMode(Mode mode) { 321void IconbarTool::setMode(Mode mode) {
258 if (mode == *m_rc_mode) 322 if (mode == *m_rc_mode)
259 return; 323 return;
@@ -306,6 +370,16 @@ void IconbarTool::update(FbTk::Subject *subj) {
306 if (m_screen.isShuttingdown()) 370 if (m_screen.isShuttingdown())
307 return; 371 return;
308 372
373 m_icon_container.setAlignment(*m_rc_alignment);
374 // clamp to normal values
375 if (*m_rc_client_width < 1)
376 *m_rc_client_width = 10;
377 else if (*m_rc_client_width > 400)
378 *m_rc_client_width = 400;
379
380 m_icon_container.setMaxSizePerClient(*m_rc_client_width);
381
382
309 if (mode() == NONE) { 383 if (mode() == NONE) {
310 if (subj != 0 && typeid(*subj) == typeid(IconbarTheme)) 384 if (subj != 0 && typeid(*subj) == typeid(IconbarTheme))
311 renderTheme(); 385 renderTheme();