summaryrefslogtreecommitdiff
path: root/src/Toolbar.cc
diff options
context:
space:
mode:
authorDana Jansens <danakj@orodu.net>2002-04-11 03:20:38 +0000
committerDana Jansens <danakj@orodu.net>2002-04-11 03:20:38 +0000
commitdfc5f034581f5a26cba5c4811500438f89f0634a (patch)
treeefb1e3af799383aa5835a736cabf658d18db4be5 /src/Toolbar.cc
parent17532e906b1dd6340bb1eccd2d9724643637958b (diff)
Initial revision
Diffstat (limited to 'src/Toolbar.cc')
-rw-r--r--src/Toolbar.cc1260
1 files changed, 1260 insertions, 0 deletions
diff --git a/src/Toolbar.cc b/src/Toolbar.cc
new file mode 100644
index 00000000..d2e39c85
--- /dev/null
+++ b/src/Toolbar.cc
@@ -0,0 +1,1260 @@
+// Toolbar.cc for Openbox
+// Copyright (c) 2001 Sean 'Shaleh' Perry <shaleh@debian.org>
+// Copyright (c) 1997 - 2000 Brad Hughes (bhughes@tcac.net)
+//
+// Permission is hereby granted, free of charge, to any person obtaining a
+// copy of this software and associated documentation files (the "Software"),
+// to deal in the Software without restriction, including without limitation
+// the rights to use, copy, modify, merge, publish, distribute, sublicense,
+// and/or sell copies of the Software, and to permit persons to whom the
+// Software is furnished to do so, subject to the following conditions:
+//
+// The above copyright notice and this permission notice shall be included in
+// all copies or substantial portions of the Software.
+//
+// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
+// THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
+// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
+// DEALINGS IN THE SOFTWARE.
+
+// stupid macros needed to access some functions in version 2 of the GNU C
+// library
+#ifndef _GNU_SOURCE
+#define _GNU_SOURCE
+#endif // _GNU_SOURCE
+
+#ifdef HAVE_CONFIG_H
+# include "../config.h"
+#endif // HAVE_CONFIG_H
+
+#include "i18n.h"
+#include "openbox.h"
+#include "Clientmenu.h"
+#include "Iconmenu.h"
+#include "Rootmenu.h"
+#include "Screen.h"
+#include "Toolbar.h"
+#include "Window.h"
+#include "Workspace.h"
+#include "Workspacemenu.h"
+
+#include <X11/Xutil.h>
+#include <X11/keysym.h>
+
+#ifdef STDC_HEADERS
+# include <string.h>
+#endif // STDC_HEADERS
+
+#ifdef HAVE_STDIO_H
+# include <stdio.h>
+#endif // HAVE_STDIO_H
+
+#ifdef TIME_WITH_SYS_TIME
+# include <sys/time.h>
+# include <time.h>
+#else // !TIME_WITH_SYS_TIME
+# ifdef HAVE_SYS_TIME_H
+# include <sys/time.h>
+# else // !HAVE_SYS_TIME_H
+# include <time.h>
+# endif // HAVE_SYS_TIME_H
+#endif // TIME_WITH_SYS_TIME
+
+
+Toolbar::Toolbar(BScreen *scrn) {
+ screen = scrn;
+ openbox = screen->getOpenbox();
+
+ // get the clock updating every minute
+ clock_timer = new BTimer(openbox, this);
+ timeval now;
+ gettimeofday(&now, 0);
+ clock_timer->setTimeout((60 - (now.tv_sec % 60)) * 1000);
+ clock_timer->start();
+
+ hide_handler.toolbar = this;
+ hide_timer = new BTimer(openbox, &hide_handler);
+ hide_timer->setTimeout(openbox->getAutoRaiseDelay());
+ hide_timer->fireOnce(True);
+
+ image_ctrl = screen->getImageControl();
+
+ on_top = screen->isToolbarOnTop();
+ hidden = do_auto_hide = screen->doToolbarAutoHide();
+
+ editing = False;
+ new_workspace_name = (char *) 0;
+ new_name_pos = 0;
+ frame.grab_x = frame.grab_y = 0;
+
+ toolbarmenu = new Toolbarmenu(this);
+
+ display = openbox->getXDisplay();
+ XSetWindowAttributes attrib;
+ unsigned long create_mask = CWBackPixmap | CWBackPixel | CWBorderPixel |
+ CWColormap | CWOverrideRedirect | CWEventMask;
+ attrib.background_pixmap = None;
+ attrib.background_pixel = attrib.border_pixel =
+ screen->getBorderColor()->getPixel();
+ attrib.colormap = screen->getColormap();
+ attrib.override_redirect = True;
+ attrib.event_mask = ButtonPressMask | ButtonReleaseMask |
+ EnterWindowMask | LeaveWindowMask;
+
+ frame.window =
+ XCreateWindow(display, screen->getRootWindow(), 0, 0, 1, 1, 0,
+ screen->getDepth(), InputOutput, screen->getVisual(),
+ create_mask, &attrib);
+ openbox->saveToolbarSearch(frame.window, this);
+
+ attrib.event_mask = ButtonPressMask | ButtonReleaseMask | ExposureMask |
+ KeyPressMask | EnterWindowMask;
+
+ frame.workspace_label =
+ XCreateWindow(display, frame.window, 0, 0, 1, 1, 0, screen->getDepth(),
+ InputOutput, screen->getVisual(), create_mask, &attrib);
+ openbox->saveToolbarSearch(frame.workspace_label, this);
+
+ frame.window_label =
+ XCreateWindow(display, frame.window, 0, 0, 1, 1, 0, screen->getDepth(),
+ InputOutput, screen->getVisual(), create_mask, &attrib);
+ openbox->saveToolbarSearch(frame.window_label, this);
+
+ frame.clock =
+ XCreateWindow(display, frame.window, 0, 0, 1, 1, 0, screen->getDepth(),
+ InputOutput, screen->getVisual(), create_mask, &attrib);
+ openbox->saveToolbarSearch(frame.clock, this);
+
+ frame.psbutton =
+ XCreateWindow(display ,frame.window, 0, 0, 1, 1, 0, screen->getDepth(),
+ InputOutput, screen->getVisual(), create_mask, &attrib);
+ openbox->saveToolbarSearch(frame.psbutton, this);
+
+ frame.nsbutton =
+ XCreateWindow(display ,frame.window, 0, 0, 1, 1, 0, screen->getDepth(),
+ InputOutput, screen->getVisual(), create_mask, &attrib);
+ openbox->saveToolbarSearch(frame.nsbutton, this);
+
+ frame.pwbutton =
+ XCreateWindow(display ,frame.window, 0, 0, 1, 1, 0, screen->getDepth(),
+ InputOutput, screen->getVisual(), create_mask, &attrib);
+ openbox->saveToolbarSearch(frame.pwbutton, this);
+
+ frame.nwbutton =
+ XCreateWindow(display ,frame.window, 0, 0, 1, 1, 0, screen->getDepth(),
+ InputOutput, screen->getVisual(), create_mask, &attrib);
+ openbox->saveToolbarSearch(frame.nwbutton, this);
+
+ frame.base = frame.label = frame.wlabel = frame.clk = frame.button =
+ frame.pbutton = None;
+
+ reconfigure();
+
+ XMapSubwindows(display, frame.window);
+ XMapWindow(display, frame.window);
+}
+
+
+Toolbar::~Toolbar(void) {
+ XUnmapWindow(display, frame.window);
+
+ if (frame.base) image_ctrl->removeImage(frame.base);
+ if (frame.label) image_ctrl->removeImage(frame.label);
+ if (frame.wlabel) image_ctrl->removeImage(frame.wlabel);
+ if (frame.clk) image_ctrl->removeImage(frame.clk);
+ if (frame.button) image_ctrl->removeImage(frame.button);
+ if (frame.pbutton) image_ctrl->removeImage(frame.pbutton);
+
+ openbox->removeToolbarSearch(frame.window);
+ openbox->removeToolbarSearch(frame.workspace_label);
+ openbox->removeToolbarSearch(frame.window_label);
+ openbox->removeToolbarSearch(frame.clock);
+ openbox->removeToolbarSearch(frame.psbutton);
+ openbox->removeToolbarSearch(frame.nsbutton);
+ openbox->removeToolbarSearch(frame.pwbutton);
+ openbox->removeToolbarSearch(frame.nwbutton);
+
+ XDestroyWindow(display, frame.workspace_label);
+ XDestroyWindow(display, frame.window_label);
+ XDestroyWindow(display, frame.clock);
+
+ XDestroyWindow(display, frame.window);
+
+ delete hide_timer;
+ delete clock_timer;
+ delete toolbarmenu;
+}
+
+
+void Toolbar::reconfigure(void) {
+ frame.bevel_w = screen->getBevelWidth();
+ frame.width = screen->getWidth() * screen->getToolbarWidthPercent() / 100;
+
+ if (i18n->multibyte())
+ frame.height =
+ screen->getToolbarStyle()->fontset_extents->max_ink_extent.height;
+ else
+ frame.height = screen->getToolbarStyle()->font->ascent +
+ screen->getToolbarStyle()->font->descent;
+ frame.button_w = frame.height;
+ frame.height += 2;
+ frame.label_h = frame.height;
+ frame.height += (frame.bevel_w * 2);
+
+ switch (screen->getToolbarPlacement()) {
+ case TopLeft:
+ frame.x = 0;
+ frame.y = 0;
+ frame.x_hidden = 0;
+ frame.y_hidden = screen->getBevelWidth() - screen->getBorderWidth()
+ - frame.height;
+ break;
+
+ case BottomLeft:
+ frame.x = 0;
+ frame.y = screen->getHeight() - frame.height
+ - (screen->getBorderWidth() * 2);
+ frame.x_hidden = 0;
+ frame.y_hidden = screen->getHeight() - screen->getBevelWidth()
+ - screen->getBorderWidth();
+ break;
+
+ case TopCenter:
+ frame.x = (screen->getWidth() - frame.width) / 2;
+ frame.y = 0;
+ frame.x_hidden = frame.x;
+ frame.y_hidden = screen->getBevelWidth() - screen->getBorderWidth()
+ - frame.height;
+ break;
+
+ case BottomCenter:
+ default:
+ frame.x = (screen->getWidth() - frame.width) / 2;
+ frame.y = screen->getHeight() - frame.height
+ - (screen->getBorderWidth() * 2);
+ frame.x_hidden = frame.x;
+ frame.y_hidden = screen->getHeight() - screen->getBevelWidth()
+ - screen->getBorderWidth();
+ break;
+
+ case TopRight:
+ frame.x = screen->getWidth() - frame.width
+ - (screen->getBorderWidth() * 2);
+ frame.y = 0;
+ frame.x_hidden = frame.x;
+ frame.y_hidden = screen->getBevelWidth() - screen->getBorderWidth()
+ - frame.height;
+ break;
+
+ case BottomRight:
+ frame.x = screen->getWidth() - frame.width
+ - (screen->getBorderWidth() * 2);
+ frame.y = screen->getHeight() - frame.height
+ - (screen->getBorderWidth() * 2);
+ frame.x_hidden = frame.x;
+ frame.y_hidden = screen->getHeight() - screen->getBevelWidth()
+ - screen->getBorderWidth();
+ break;
+ }
+
+#ifdef HAVE_STRFTIME
+ time_t ttmp = time(NULL);
+ struct tm *tt = 0;
+
+ if (ttmp != -1) {
+ tt = localtime(&ttmp);
+ if (tt) {
+ char t[1024], *time_string = (char *) 0;
+ int len = strftime(t, 1024, screen->getStrftimeFormat(), tt);
+
+ if (i18n->multibyte()) {
+ XRectangle ink, logical;
+ XmbTextExtents(screen->getToolbarStyle()->fontset, t, len, &ink,
+ &logical);
+ frame.clock_w = logical.width;
+
+ // ben's additional solution to pad some space beside the numbers
+ frame.clock_w +=
+ screen->getToolbarStyle()->fontset_extents->max_logical_extent.width *
+ 4;
+
+ // brad's solution, which is currently buggy, too big
+ //frame.clock_w =
+ // screen->getToolbarStyle()->fontset_extents->max_logical_extent.width
+ // * len;
+ } else {
+ frame.clock_w = XTextWidth(screen->getToolbarStyle()->font, t, len);
+ // ben's additional solution to pad some space beside the numbers
+ frame.clock_w += screen->getToolbarStyle()->font->max_bounds.width * 4;
+ // brad's solution again, too big
+ //frame.clock_w = screen->getToolbarStyle()->font->max_bounds.width * len;
+ }
+ frame.clock_w += (frame.bevel_w * 4);
+
+ delete [] time_string;
+ } else {
+ frame.clock_w = 0;
+ }
+ } else {
+ frame.clock_w = 0;
+ }
+#else // !HAVE_STRFTIME
+ frame.clock_w =
+ XTextWidth(screen->getToolbarStyle()->font,
+ i18n->getMessage(ToolbarSet, ToolbarNoStrftimeLength,
+ "00:00000"),
+ strlen(i18n->getMessage(ToolbarSet, ToolbarNoStrftimeLength,
+ "00:00000"))) + (frame.bevel_w * 4);
+#endif // HAVE_STRFTIME
+
+ int i;
+ unsigned int w = 0;
+ frame.workspace_label_w = 0;
+
+ for (i = 0; i < screen->getCount(); i++) {
+ if (i18n->multibyte()) {
+ XRectangle ink, logical;
+ XmbTextExtents(screen->getToolbarStyle()->fontset,
+ screen->getWorkspace(i)->getName(),
+ strlen(screen->getWorkspace(i)->getName()),
+ &ink, &logical);
+ w = logical.width;
+ } else {
+ w = XTextWidth(screen->getToolbarStyle()->font,
+ screen->getWorkspace(i)->getName(),
+ strlen(screen->getWorkspace(i)->getName()));
+ }
+ w += (frame.bevel_w * 4);
+
+ if (w > frame.workspace_label_w) frame.workspace_label_w = w;
+ }
+
+ if (frame.workspace_label_w < frame.clock_w)
+ frame.workspace_label_w = frame.clock_w;
+ else if (frame.workspace_label_w > frame.clock_w)
+ frame.clock_w = frame.workspace_label_w;
+
+ frame.window_label_w =
+ (frame.width - (frame.clock_w + (frame.button_w * 4) +
+ frame.workspace_label_w + (frame.bevel_w * 8) + 6));
+
+ if (hidden) {
+ XMoveResizeWindow(display, frame.window, frame.x_hidden, frame.y_hidden,
+ frame.width, frame.height);
+ } else {
+ XMoveResizeWindow(display, frame.window, frame.x, frame.y,
+ frame.width, frame.height);
+ }
+
+ XMoveResizeWindow(display, frame.workspace_label, frame.bevel_w,
+ frame.bevel_w, frame.workspace_label_w,
+ frame.label_h);
+ XMoveResizeWindow(display, frame.psbutton, (frame.bevel_w * 2) +
+ frame.workspace_label_w + 1, frame.bevel_w + 1,
+ frame.button_w, frame.button_w);
+ XMoveResizeWindow(display ,frame.nsbutton, (frame.bevel_w * 3) +
+ frame.workspace_label_w + frame.button_w + 2,
+ frame.bevel_w + 1, frame.button_w, frame.button_w);
+ XMoveResizeWindow(display, frame.window_label, (frame.bevel_w * 4) +
+ (frame.button_w * 2) + frame.workspace_label_w + 3,
+ frame.bevel_w, frame.window_label_w, frame.label_h);
+ XMoveResizeWindow(display, frame.pwbutton, (frame.bevel_w * 5) +
+ (frame.button_w * 2) + frame.workspace_label_w +
+ frame.window_label_w + 4, frame.bevel_w + 1,
+ frame.button_w, frame.button_w);
+ XMoveResizeWindow(display, frame.nwbutton, (frame.bevel_w * 6) +
+ (frame.button_w * 3) + frame.workspace_label_w +
+ frame.window_label_w + 5, frame.bevel_w + 1,
+ frame.button_w, frame.button_w);
+ XMoveResizeWindow(display, frame.clock, frame.width - frame.clock_w -
+ frame.bevel_w, frame.bevel_w, frame.clock_w,
+ frame.label_h);
+
+ Pixmap tmp = frame.base;
+ BTexture *texture = &(screen->getToolbarStyle()->toolbar);
+ if (texture->getTexture() == (BImage_Flat | BImage_Solid)) {
+ frame.base = None;
+ XSetWindowBackground(display, frame.window,
+ texture->getColor()->getPixel());
+ } else {
+ frame.base =
+ image_ctrl->renderImage(frame.width, frame.height, texture);
+ XSetWindowBackgroundPixmap(display, frame.window, frame.base);
+ }
+ if (tmp) image_ctrl->removeImage(tmp);
+
+ tmp = frame.label;
+ texture = &(screen->getToolbarStyle()->window);
+ if (texture->getTexture() == (BImage_Flat | BImage_Solid)) {
+ frame.label = None;
+ XSetWindowBackground(display, frame.window_label,
+ texture->getColor()->getPixel());
+ } else {
+ frame.label =
+ image_ctrl->renderImage(frame.window_label_w, frame.label_h, texture);
+ XSetWindowBackgroundPixmap(display, frame.window_label, frame.label);
+ }
+ if (tmp) image_ctrl->removeImage(tmp);
+
+ tmp = frame.wlabel;
+ texture = &(screen->getToolbarStyle()->label);
+ if (texture->getTexture() == (BImage_Flat | BImage_Solid)) {
+ frame.wlabel = None;
+ XSetWindowBackground(display, frame.workspace_label,
+ texture->getColor()->getPixel());
+ } else {
+ frame.wlabel =
+ image_ctrl->renderImage(frame.workspace_label_w, frame.label_h, texture);
+ XSetWindowBackgroundPixmap(display, frame.workspace_label, frame.wlabel);
+ }
+ if (tmp) image_ctrl->removeImage(tmp);
+
+ tmp = frame.clk;
+ texture = &(screen->getToolbarStyle()->clock);
+ if (texture->getTexture() == (BImage_Flat | BImage_Solid)) {
+ frame.clk = None;
+ XSetWindowBackground(display, frame.clock,
+ texture->getColor()->getPixel());
+ } else {
+ frame.clk =
+ image_ctrl->renderImage(frame.clock_w, frame.label_h, texture);
+ XSetWindowBackgroundPixmap(display, frame.clock, frame.clk);
+ }
+ if (tmp) image_ctrl->removeImage(tmp);
+
+ tmp = frame.button;
+ texture = &(screen->getToolbarStyle()->button);
+ if (texture->getTexture() == (BImage_Flat | BImage_Solid)) {
+ frame.button = None;
+
+ frame.button_pixel = texture->getColor()->getPixel();
+ XSetWindowBackground(display, frame.psbutton, frame.button_pixel);
+ XSetWindowBackground(display, frame.nsbutton, frame.button_pixel);
+ XSetWindowBackground(display, frame.pwbutton, frame.button_pixel);
+ XSetWindowBackground(display, frame.nwbutton, frame.button_pixel);
+ } else {
+ frame.button =
+ image_ctrl->renderImage(frame.button_w, frame.button_w, texture);
+
+ XSetWindowBackgroundPixmap(display, frame.psbutton, frame.button);
+ XSetWindowBackgroundPixmap(display, frame.nsbutton, frame.button);
+ XSetWindowBackgroundPixmap(display, frame.pwbutton, frame.button);
+ XSetWindowBackgroundPixmap(display, frame.nwbutton, frame.button);
+ }
+ if (tmp) image_ctrl->removeImage(tmp);
+
+ tmp = frame.pbutton;
+ texture = &(screen->getToolbarStyle()->pressed);
+ if (texture->getTexture() == (BImage_Flat | BImage_Solid)) {
+ frame.pbutton = None;
+ frame.pbutton_pixel = texture->getColor()->getPixel();
+ } else {
+ frame.pbutton =
+ image_ctrl->renderImage(frame.button_w, frame.button_w, texture);
+ }
+ if (tmp) image_ctrl->removeImage(tmp);
+
+ XSetWindowBorder(display, frame.window,
+ screen->getBorderColor()->getPixel());
+ XSetWindowBorderWidth(display, frame.window, screen->getBorderWidth());
+
+ XClearWindow(display, frame.window);
+ XClearWindow(display, frame.workspace_label);
+ XClearWindow(display, frame.window_label);
+ XClearWindow(display, frame.clock);
+ XClearWindow(display, frame.psbutton);
+ XClearWindow(display, frame.nsbutton);
+ XClearWindow(display, frame.pwbutton);
+ XClearWindow(display, frame.nwbutton);
+
+ redrawWindowLabel();
+ redrawWorkspaceLabel();
+ redrawPrevWorkspaceButton();
+ redrawNextWorkspaceButton();
+ redrawPrevWindowButton();
+ redrawNextWindowButton();
+ checkClock(True);
+
+ toolbarmenu->reconfigure();
+}
+
+
+#ifdef HAVE_STRFTIME
+void Toolbar::checkClock(Bool redraw) {
+#else // !HAVE_STRFTIME
+void Toolbar::checkClock(Bool redraw, Bool date) {
+#endif // HAVE_STRFTIME
+ time_t tmp = 0;
+ struct tm *tt = 0;
+
+ if ((tmp = time(NULL)) != -1) {
+ if (! (tt = localtime(&tmp))) return;
+ if (tt->tm_min != frame.minute || tt->tm_hour != frame.hour) {
+ frame.hour = tt->tm_hour;
+ frame.minute = tt->tm_min;
+ XClearWindow(display, frame.clock);
+ redraw = True;
+ }
+ }
+
+ if (redraw) {
+#ifdef HAVE_STRFTIME
+ char t[1024];
+ if (! strftime(t, 1024, screen->getStrftimeFormat(), tt))
+ return;
+#else // !HAVE_STRFTIME
+ char t[9];
+ if (date) {
+ // format the date... with special consideration for y2k ;)
+ if (screen->getDateFormat() == Openbox::B_EuropeanDate)
+ sprintf(t, 18n->getMessage(ToolbarSet, ToolbarNoStrftimeDateFormatEu,
+ "%02d.%02d.%02d"),
+ tt->tm_mday, tt->tm_mon + 1,
+ (tt->tm_year >= 100) ? tt->tm_year - 100 : tt->tm_year);
+ else
+ sprintf(t, i18n->getMessage(ToolbarSet, ToolbarNoStrftimeDateFormat,
+ "%02d/%02d/%02d"),
+ tt->tm_mon + 1, tt->tm_mday,
+ (tt->tm_year >= 100) ? tt->tm_year - 100 : tt->tm_year);
+ } else {
+ if (screen->isClock24Hour())
+ sprintf(t, i18n->getMessage(ToolbarSet, ToolbarNoStrftimeTimeFormat24,
+ " %02d:%02d "),
+ frame.hour, frame.minute);
+ else
+ sprintf(t, i18n->getMessage(ToolbarSet, ToolbarNoStrftimeTimeFormat12,
+ "%02d:%02d %sm"),
+ ((frame.hour > 12) ? frame.hour - 12 :
+ ((frame.hour == 0) ? 12 : frame.hour)), frame.minute,
+ ((frame.hour >= 12) ?
+ i18n->getMessage(ToolbarSet,
+ ToolbarNoStrftimeTimeFormatP, "p") :
+ i18n->getMessage(ToolbarSet,
+ ToolbarNoStrftimeTimeFormatA, "a")));
+ }
+#endif // HAVE_STRFTIME
+
+ int dx = (frame.bevel_w * 2), dlen = strlen(t);
+ unsigned int l;
+
+ if (i18n->multibyte()) {
+ XRectangle ink, logical;
+ XmbTextExtents(screen->getToolbarStyle()->fontset,
+ t, dlen, &ink, &logical);
+ l = logical.width;
+ } else {
+ l = XTextWidth(screen->getToolbarStyle()->font, t, dlen);
+ }
+
+ l += (frame.bevel_w * 4);
+
+ if (l > frame.clock_w) {
+ for (; dlen >= 0; dlen--) {
+ if (i18n->multibyte()) {
+ XRectangle ink, logical;
+ XmbTextExtents(screen->getToolbarStyle()->fontset,
+ t, dlen, &ink, &logical);
+ l = logical.width;
+ } else {
+ l = XTextWidth(screen->getToolbarStyle()->font, t, dlen);
+ }
+ l+= (frame.bevel_w * 4);
+
+ if (l < frame.clock_w)
+ break;
+ }
+ }
+ switch (screen->getToolbarStyle()->justify) {
+ case BScreen::RightJustify:
+ dx += frame.clock_w - l;
+ break;
+
+ case BScreen::CenterJustify:
+ dx += (frame.clock_w - l) / 2;
+ break;
+ }
+
+ ToolbarStyle *style = screen->getToolbarStyle();
+ if (i18n->multibyte())
+ XmbDrawString(display, frame.clock, style->fontset, style->c_text_gc,
+ dx, (1 - style->fontset_extents->max_ink_extent.y),
+ t, dlen);
+ else
+ XDrawString(display, frame.clock, style->c_text_gc, dx,
+ (style->font->ascent + 1), t, dlen);
+ }
+}
+
+
+void Toolbar::redrawWindowLabel(Bool redraw) {
+ if (screen->getOpenbox()->getFocusedWindow()) {
+ if (redraw)
+ XClearWindow(display, frame.window_label);
+
+ OpenboxWindow *foc = screen->getOpenbox()->getFocusedWindow();
+ if (foc->getScreen() != screen) return;
+
+ int dx = (frame.bevel_w * 2), dlen = strlen(*foc->getTitle());
+ unsigned int l;
+
+ if (i18n->multibyte()) {
+ XRectangle ink, logical;
+ XmbTextExtents(screen->getToolbarStyle()->fontset, *foc->getTitle(),
+ dlen, &ink, &logical);
+ l = logical.width;
+ } else {
+ l = XTextWidth(screen->getToolbarStyle()->font, *foc->getTitle(), dlen);
+ }
+ l += (frame.bevel_w * 4);
+
+ if (l > frame.window_label_w) {
+ for (; dlen >= 0; dlen--) {
+ if (i18n->multibyte()) {
+ XRectangle ink, logical;
+ XmbTextExtents(screen->getToolbarStyle()->fontset,
+ *foc->getTitle(), dlen, &ink, &logical);
+ l = logical.width;
+ } else {
+ l = XTextWidth(screen->getToolbarStyle()->font,
+ *foc->getTitle(), dlen);
+ }
+ l += (frame.bevel_w * 4);
+
+ if (l < frame.window_label_w)
+ break;
+ }
+ }
+ switch (screen->getToolbarStyle()->justify) {
+ case BScreen::RightJustify:
+ dx += frame.window_label_w - l;
+ break;
+
+ case BScreen::CenterJustify:
+ dx += (frame.window_label_w - l) / 2;
+ break;
+ }
+
+ ToolbarStyle *style = screen->getToolbarStyle();
+ if (i18n->multibyte())
+ XmbDrawString(display, frame.window_label, style->fontset,
+ style->w_text_gc, dx,
+ (1 - style->fontset_extents->max_ink_extent.y),
+ *foc->getTitle(), dlen);
+ else
+ XDrawString(display, frame.window_label, style->w_text_gc, dx,
+ (style->font->ascent + 1), *foc->getTitle(), dlen);
+ } else {
+ XClearWindow(display, frame.window_label);
+ }
+}
+
+
+void Toolbar::redrawWorkspaceLabel(Bool redraw) {
+ if (screen->getCurrentWorkspace()->getName()) {
+ if (redraw)
+ XClearWindow(display, frame.workspace_label);
+
+ int dx = (frame.bevel_w * 2), dlen =
+ strlen(screen->getCurrentWorkspace()->getName());
+ unsigned int l;
+
+ if (i18n->multibyte()) {
+ XRectangle ink, logical;
+ XmbTextExtents(screen->getToolbarStyle()->fontset,
+ screen->getCurrentWorkspace()->getName(), dlen,
+ &ink, &logical);
+ l = logical.width;
+ } else {
+ l = XTextWidth(screen->getToolbarStyle()->font,
+ screen->getCurrentWorkspace()->getName(), dlen);
+ }
+ l += (frame.bevel_w * 4);
+
+ if (l > frame.workspace_label_w) {
+ for (; dlen >= 0; dlen--) {
+ if (i18n->multibyte()) {
+ XRectangle ink, logical;
+ XmbTextExtents(screen->getToolbarStyle()->fontset,
+ screen->getCurrentWorkspace()->getName(), dlen,
+ &ink, &logical);
+ l = logical.width;
+ } else {
+ l = XTextWidth(screen->getWindowStyle()->font,
+ screen->getCurrentWorkspace()->getName(), dlen);
+ }
+ l += (frame.bevel_w * 4);
+
+ if (l < frame.workspace_label_w)
+ break;
+ }
+ }
+ switch (screen->getToolbarStyle()->justify) {
+ case BScreen::RightJustify:
+ dx += frame.workspace_label_w - l;
+ break;
+
+ case BScreen::CenterJustify:
+ dx += (frame.workspace_label_w - l) / 2;
+ break;
+ }
+
+ ToolbarStyle *style = screen->getToolbarStyle();
+ if (i18n->multibyte())
+ XmbDrawString(display, frame.workspace_label, style->fontset,
+ style->l_text_gc, dx,
+ (1 - style->fontset_extents->max_ink_extent.y),
+ (char *) screen->getCurrentWorkspace()->getName(), dlen);
+ else
+ XDrawString(display, frame.workspace_label, style->l_text_gc, dx,
+ (style->font->ascent + 1),
+ (char *) screen->getCurrentWorkspace()->getName(), dlen);
+ }
+}
+
+
+void Toolbar::redrawPrevWorkspaceButton(Bool pressed, Bool redraw) {
+ if (redraw) {
+ if (pressed) {
+ if (frame.pbutton)
+ XSetWindowBackgroundPixmap(display, frame.psbutton, frame.pbutton);
+ else
+ XSetWindowBackground(display, frame.psbutton, frame.pbutton_pixel);
+ } else {
+ if (frame.button)
+ XSetWindowBackgroundPixmap(display, frame.psbutton, frame.button);
+ else
+ XSetWindowBackground(display, frame.psbutton, frame.button_pixel);
+ }
+ XClearWindow(display, frame.psbutton);
+ }
+
+ int hh = frame.button_w / 2, hw = frame.button_w / 2;
+
+ XPoint pts[3];
+ pts[0].x = hw - 2; pts[0].y = hh;
+ pts[1].x = 4; pts[1].y = 2;
+ pts[2].x = 0; pts[2].y = -4;
+
+ XFillPolygon(display, frame.psbutton, screen->getToolbarStyle()->b_pic_gc,
+ pts, 3, Convex, CoordModePrevious);
+}
+
+
+void Toolbar::redrawNextWorkspaceButton(Bool pressed, Bool redraw) {
+ if (redraw) {
+ if (pressed) {
+ if (frame.pbutton)
+ XSetWindowBackgroundPixmap(display, frame.nsbutton, frame.pbutton);
+ else
+ XSetWindowBackground(display, frame.nsbutton, frame.pbutton_pixel);
+ } else {
+ if (frame.button)
+ XSetWindowBackgroundPixmap(display, frame.nsbutton, frame.button);
+ else
+ XSetWindowBackground(display, frame.nsbutton, frame.button_pixel);
+ }
+ XClearWindow(display, frame.nsbutton);
+ }
+
+ int hh = frame.button_w / 2, hw = frame.button_w / 2;
+
+ XPoint pts[3];
+ pts[0].x = hw - 2; pts[0].y = hh - 2;
+ pts[1].x = 4; pts[1].y = 2;
+ pts[2].x = -4; pts[2].y = 2;
+
+ XFillPolygon(display, frame.nsbutton, screen->getToolbarStyle()->b_pic_gc,
+ pts, 3, Convex, CoordModePrevious);
+}
+
+
+void Toolbar::redrawPrevWindowButton(Bool pressed, Bool redraw) {
+ if (redraw) {
+ if (pressed) {
+ if (frame.pbutton)
+ XSetWindowBackgroundPixmap(display, frame.pwbutton, frame.pbutton);
+ else
+ XSetWindowBackground(display, frame.pwbutton, frame.pbutton_pixel);
+ } else {
+ if (frame.button)
+ XSetWindowBackgroundPixmap(display, frame.pwbutton, frame.button);
+ else
+ XSetWindowBackground(display, frame.pwbutton, frame.button_pixel);
+ }
+ XClearWindow(display, frame.pwbutton);
+ }
+
+ int hh = frame.button_w / 2, hw = frame.button_w / 2;
+
+ XPoint pts[3];
+ pts[0].x = hw - 2; pts[0].y = hh;
+ pts[1].x = 4; pts[1].y = 2;
+ pts[2].x = 0; pts[2].y = -4;
+
+ XFillPolygon(display, frame.pwbutton, screen->getToolbarStyle()->b_pic_gc,
+ pts, 3, Convex, CoordModePrevious);
+}
+
+
+void Toolbar::redrawNextWindowButton(Bool pressed, Bool redraw) {
+ if (redraw) {
+ if (pressed) {
+ if (frame.pbutton)
+ XSetWindowBackgroundPixmap(display, frame.nwbutton, frame.pbutton);
+ else
+ XSetWindowBackground(display, frame.nwbutton, frame.pbutton_pixel);
+ } else {
+ if (frame.button)
+ XSetWindowBackgroundPixmap(display, frame.nwbutton, frame.button);
+ else
+ XSetWindowBackground(display, frame.nwbutton, frame.button_pixel);
+ }
+ XClearWindow(display, frame.nwbutton);
+ }
+
+ int hh = frame.button_w / 2, hw = frame.button_w / 2;
+
+ XPoint pts[3];
+ pts[0].x = hw - 2; pts[0].y = hh - 2;
+ pts[1].x = 4; pts[1].y = 2;
+ pts[2].x = -4; pts[2].y = 2;
+
+ XFillPolygon(display, frame.nwbutton, screen->getToolbarStyle()->b_pic_gc,
+ pts, 3, Convex, CoordModePrevious);
+}
+
+
+void Toolbar::edit(void) {
+ Window window;
+ int foo;
+
+ editing = True;
+ if (XGetInputFocus(display, &window, &foo) &&
+ window == frame.workspace_label)
+ return;
+
+ XSetInputFocus(display, frame.workspace_label,
+ ((screen->isSloppyFocus()) ? RevertToPointerRoot :
+ RevertToParent),
+ CurrentTime);
+ XClearWindow(display, frame.workspace_label);
+
+ openbox->setNoFocus(True);
+ if (openbox->getFocusedWindow())
+ openbox->getFocusedWindow()->setFocusFlag(False);
+
+ XDrawRectangle(display, frame.workspace_label,
+ screen->getWindowStyle()->l_text_focus_gc,
+ frame.workspace_label_w / 2, 0, 1,
+ frame.label_h - 1);
+
+ // change the background of the window to that of an active window label
+ Pixmap tmp = frame.wlabel;
+ BTexture *texture = &(screen->getWindowStyle()->l_focus);
+ if (texture->getTexture() == (BImage_Flat | BImage_Solid)) {
+ frame.wlabel = None;
+ XSetWindowBackground(display, frame.workspace_label,
+ texture->getColor()->getPixel());
+ } else {
+ frame.wlabel =
+ image_ctrl->renderImage(frame.workspace_label_w, frame.label_h, texture);
+ XSetWindowBackgroundPixmap(display, frame.workspace_label, frame.wlabel);
+ }
+ if (tmp) image_ctrl->removeImage(tmp);
+}
+
+
+void Toolbar::buttonPressEvent(XButtonEvent *be) {
+ if (be->button == 1) {
+ if (be->window == frame.psbutton)
+ redrawPrevWorkspaceButton(True, True);
+ else if (be->window == frame.nsbutton)
+ redrawNextWorkspaceButton(True, True);
+ else if (be->window == frame.pwbutton)
+ redrawPrevWindowButton(True, True);
+ else if (be->window == frame.nwbutton)
+ redrawNextWindowButton(True, True);
+#ifndef HAVE_STRFTIME
+ else if (be->window == frame.clock) {
+ XClearWindow(display, frame.clock);
+ checkClock(True, True);
+ }
+#endif // HAVE_STRFTIME
+ else if (! on_top) {
+ Window w[1] = { frame.window };
+ screen->raiseWindows(w, 1);
+ }
+ } else if (be->button == 2 && (! on_top)) {
+ XLowerWindow(display, frame.window);
+ } else if (be->button == 3) {
+ if (! toolbarmenu->isVisible()) {
+ int x, y;
+
+ x = be->x_root - (toolbarmenu->getWidth() / 2);
+ y = be->y_root - (toolbarmenu->getHeight() / 2);
+
+ if (x < 0)
+ x = 0;
+ else if (x + toolbarmenu->getWidth() > screen->getWidth())
+ x = screen->getWidth() - toolbarmenu->getWidth();
+
+ if (y < 0)
+ y = 0;
+ else if (y + toolbarmenu->getHeight() > screen->getHeight())
+ y = screen->getHeight() - toolbarmenu->getHeight();
+
+ toolbarmenu->move(x, y);
+ toolbarmenu->show();
+ } else
+ toolbarmenu->hide();
+ }
+}
+
+
+
+void Toolbar::buttonReleaseEvent(XButtonEvent *re) {
+ if (re->button == 1) {
+ if (re->window == frame.psbutton) {
+ redrawPrevWorkspaceButton(False, True);
+
+ if (re->x >= 0 && re->x < (signed) frame.button_w &&
+ re->y >= 0 && re->y < (signed) frame.button_w)
+ if (screen->getCurrentWorkspace()->getWorkspaceID() > 0)
+ screen->changeWorkspaceID(screen->getCurrentWorkspace()->
+ getWorkspaceID() - 1);
+ else
+ screen->changeWorkspaceID(screen->getCount() - 1);
+ } else if (re->window == frame.nsbutton) {
+ redrawNextWorkspaceButton(False, True);
+
+ if (re->x >= 0 && re->x < (signed) frame.button_w &&
+ re->y >= 0 && re->y < (signed) frame.button_w)
+ if (screen->getCurrentWorkspace()->getWorkspaceID() <
+ screen->getCount() - 1)
+ screen->changeWorkspaceID(screen->getCurrentWorkspace()->
+ getWorkspaceID() + 1);
+ else
+ screen->changeWorkspaceID(0);
+ } else if (re->window == frame.pwbutton) {
+ redrawPrevWindowButton(False, True);
+
+ if (re->x >= 0 && re->x < (signed) frame.button_w &&
+ re->y >= 0 && re->y < (signed) frame.button_w)
+ screen->prevFocus();
+ } else if (re->window == frame.nwbutton) {
+ redrawNextWindowButton(False, True);
+
+ if (re->x >= 0 && re->x < (signed) frame.button_w &&
+ re->y >= 0 && re->y < (signed) frame.button_w)
+ screen->nextFocus();
+ } else if (re->window == frame.window_label)
+ screen->raiseFocus();
+#ifndef HAVE_STRFTIME
+ else if (re->window == frame.clock) {
+ XClearWindow(display, frame.clock);
+ checkClock(True);
+ }
+#endif // HAVE_STRFTIME
+ }
+}
+
+
+void Toolbar::enterNotifyEvent(XCrossingEvent *) {
+ if (! do_auto_hide)
+ return;
+
+ if (hidden) {
+ if (! hide_timer->isTiming()) hide_timer->start();
+ } else {
+ if (hide_timer->isTiming()) hide_timer->stop();
+ }
+}
+
+void Toolbar::leaveNotifyEvent(XCrossingEvent *) {
+ if (! do_auto_hide)
+ return;
+
+ if (hidden) {
+ if (hide_timer->isTiming()) hide_timer->stop();
+ } else if (! toolbarmenu->isVisible()) {
+ if (! hide_timer->isTiming()) hide_timer->start();
+ }
+}
+
+
+void Toolbar::exposeEvent(XExposeEvent *ee) {
+ if (ee->window == frame.clock) checkClock(True);
+ else if (ee->window == frame.workspace_label && (! editing))
+ redrawWorkspaceLabel();
+ else if (ee->window == frame.window_label) redrawWindowLabel();
+ else if (ee->window == frame.psbutton) redrawPrevWorkspaceButton();
+ else if (ee->window == frame.nsbutton) redrawNextWorkspaceButton();
+ else if (ee->window == frame.pwbutton) redrawPrevWindowButton();
+ else if (ee->window == frame.nwbutton) redrawNextWindowButton();
+}
+
+
+void Toolbar::keyPressEvent(XKeyEvent *ke) {
+ if (ke->window == frame.workspace_label && editing) {
+ openbox->grab();
+
+ if (! new_workspace_name) {
+ new_workspace_name = new char[128];
+ new_name_pos = 0;
+
+ if (! new_workspace_name) return;
+ }
+
+ KeySym ks;
+ char keychar[1];
+ XLookupString(ke, keychar, 1, &ks, 0);
+
+ // either we are told to end with a return or we hit the end of the buffer
+ if (ks == XK_Return || new_name_pos == 127) {
+ *(new_workspace_name + new_name_pos) = 0;
+
+ editing = False;
+
+ openbox->setNoFocus(False);
+ if (openbox->getFocusedWindow()) {
+ openbox->getFocusedWindow()->setInputFocus();
+ openbox->getFocusedWindow()->setFocusFlag(True);
+ } else {
+ XSetInputFocus(display, PointerRoot, None, CurrentTime);
+ }
+ // check to make sure that new_name[0] != 0... otherwise we have a null
+ // workspace name which causes serious problems, especially for the
+ // Openbox::LoadRC() method.
+ if (*new_workspace_name) {
+ screen->getCurrentWorkspace()->setName(new_workspace_name);
+ screen->getCurrentWorkspace()->getMenu()->hide();
+ screen->getWorkspacemenu()->
+ remove(screen->getCurrentWorkspace()->getWorkspaceID() + 2);
+ screen->getWorkspacemenu()->
+ insert(screen->getCurrentWorkspace()->getName(),
+ screen->getCurrentWorkspace()->getMenu(),
+ screen->getCurrentWorkspace()->getWorkspaceID() + 2);
+ screen->getWorkspacemenu()->update();
+ }
+
+ delete [] new_workspace_name;
+ new_workspace_name = (char *) 0;
+ new_name_pos = 0;
+
+ // reset the background to that of the workspace label (its normal
+ // setting)
+ Pixmap tmp = frame.wlabel;
+ BTexture *texture = &(screen->getToolbarStyle()->label);
+ if (texture->getTexture() == (BImage_Flat | BImage_Solid)) {
+ frame.wlabel = None;
+ XSetWindowBackground(display, frame.workspace_label,
+ texture->getColor()->getPixel());
+ } else {
+ frame.wlabel =
+ image_ctrl->renderImage(frame.workspace_label_w, frame.label_h, texture);
+ XSetWindowBackgroundPixmap(display, frame.workspace_label, frame.wlabel);
+ }
+ if (tmp) image_ctrl->removeImage(tmp);
+
+ reconfigure();
+ } else if (! (ks == XK_Shift_L || ks == XK_Shift_R ||
+ ks == XK_Control_L || ks == XK_Control_R ||
+ ks == XK_Caps_Lock || ks == XK_Shift_Lock ||
+ ks == XK_Meta_L || ks == XK_Meta_R ||
+ ks == XK_Alt_L || ks == XK_Alt_R ||
+ ks == XK_Super_L || ks == XK_Super_R ||
+ ks == XK_Hyper_L || ks == XK_Hyper_R)) {
+ if (ks == XK_BackSpace) {
+ if (new_name_pos > 0) {
+ --new_name_pos;
+ *(new_workspace_name + new_name_pos) = '\0';
+ } else {
+ *new_workspace_name = '\0';
+ }
+ } else {
+ *(new_workspace_name + new_name_pos) = *keychar;
+ ++new_name_pos;
+ *(new_workspace_name + new_name_pos) = '\0';
+ }
+
+ XClearWindow(display, frame.workspace_label);
+ int l = strlen(new_workspace_name), tw, x;
+
+ if (i18n->multibyte()) {
+ XRectangle ink, logical;
+ XmbTextExtents(screen->getToolbarStyle()->fontset,
+ new_workspace_name, l, &ink, &logical);
+ tw = logical.width;
+ } else {
+ tw = XTextWidth(screen->getToolbarStyle()->font,
+ new_workspace_name, l);
+ }
+ x = (frame.workspace_label_w - tw) / 2;
+
+ if (x < (signed) frame.bevel_w) x = frame.bevel_w;
+
+ WindowStyle *style = screen->getWindowStyle();
+ if (i18n->multibyte())
+ XmbDrawString(display, frame.workspace_label, style->fontset,
+ style->l_text_focus_gc, x,
+ (1 - style->fontset_extents->max_ink_extent.y),
+ new_workspace_name, l);
+ else
+ XDrawString(display, frame.workspace_label, style->l_text_focus_gc, x,
+ (style->font->ascent + 1),
+ new_workspace_name, l);
+
+ XDrawRectangle(display, frame.workspace_label,
+ screen->getWindowStyle()->l_text_focus_gc, x + tw, 0, 1,
+ frame.label_h - 1);
+ }
+
+ openbox->ungrab();
+ }
+}
+
+
+void Toolbar::timeout(void) {
+ checkClock(True);
+
+ timeval now;
+ gettimeofday(&now, 0);
+ clock_timer->setTimeout((60 - (now.tv_sec % 60)) * 1000);
+}
+
+
+void Toolbar::HideHandler::timeout(void) {
+ toolbar->hidden = ! toolbar->hidden;
+ if (toolbar->hidden)
+ XMoveWindow(toolbar->display, toolbar->frame.window,
+ toolbar->frame.x_hidden, toolbar->frame.y_hidden);
+ else
+ XMoveWindow(toolbar->display, toolbar->frame.window,
+ toolbar->frame.x, toolbar->frame.y);
+}
+
+
+Toolbarmenu::Toolbarmenu(Toolbar *tb) : Basemenu(tb->screen) {
+ toolbar = tb;
+
+ setLabel(i18n->getMessage(ToolbarSet, ToolbarToolbarTitle, "Toolbar"));
+ setInternalMenu();
+
+ placementmenu = new Placementmenu(this);
+
+ insert(i18n->getMessage(CommonSet, CommonPlacementTitle, "Placement"),
+ placementmenu);
+ insert(i18n->getMessage(CommonSet, CommonAlwaysOnTop, "Always on top"), 1);
+ insert(i18n->getMessage(CommonSet, CommonAutoHide, "Auto hide"), 2);
+ insert(i18n->getMessage(ToolbarSet, ToolbarEditWkspcName,
+ "Edit current workspace name"), 3);
+
+ update();
+
+ if (toolbar->isOnTop()) setItemSelected(1, True);
+ if (toolbar->doAutoHide()) setItemSelected(2, True);
+}
+
+
+Toolbarmenu::~Toolbarmenu(void) {
+ delete placementmenu;
+}
+
+
+void Toolbarmenu::itemSelected(int button, int index) {
+ if (button != 1)
+ return;
+
+ BasemenuItem *item = find(index);
+ if (! item) return;
+
+ switch (item->function()) {
+ case 1: { // always on top
+ Bool change = ((toolbar->isOnTop()) ? False : True);
+ toolbar->on_top = change;
+ setItemSelected(1, change);
+
+ if (toolbar->isOnTop()) toolbar->screen->raiseWindows((Window *) 0, 0);
+ break;
+ }
+
+ case 2: { // auto hide
+ Bool change = ((toolbar->doAutoHide()) ? False : True);
+ toolbar->do_auto_hide = change;
+ setItemSelected(2, change);
+
+#ifdef SLIT
+ toolbar->screen->getSlit()->reposition();
+#endif // SLIT
+ break;
+ }
+
+ case 3: { // edit current workspace name
+ toolbar->edit();
+ hide();
+
+ break;
+ }
+ } // switch
+}
+
+
+void Toolbarmenu::internal_hide(void) {
+ Basemenu::internal_hide();
+ if (toolbar->doAutoHide() && ! toolbar->isEditing())
+ toolbar->hide_handler.timeout();
+}
+
+
+void Toolbarmenu::reconfigure(void) {
+ placementmenu->reconfigure();
+
+ Basemenu::reconfigure();
+}
+
+
+Toolbarmenu::Placementmenu::Placementmenu(Toolbarmenu *tm)
+ : Basemenu(tm->toolbar->screen) {
+ toolbarmenu = tm;
+
+ setLabel(i18n->getMessage(ToolbarSet, ToolbarToolbarPlacement,
+ "Toolbar Placement"));
+ setInternalMenu();
+ setMinimumSublevels(3);
+
+ insert(i18n->getMessage(CommonSet, CommonPlacementTopLeft,
+ "Top Left"), Toolbar::TopLeft);
+ insert(i18n->getMessage(CommonSet, CommonPlacementBottomLeft,
+ "Bottom Left"), Toolbar::BottomLeft);
+ insert(i18n->getMessage(CommonSet, CommonPlacementTopCenter,
+ "Top Center"), Toolbar::TopCenter);
+ insert(i18n->getMessage(CommonSet, CommonPlacementBottomCenter,
+ "Bottom Center"), Toolbar::BottomCenter);
+ insert(i18n->getMessage(CommonSet, CommonPlacementTopRight,
+ "Top Right"), Toolbar::TopRight);
+ insert(i18n->getMessage(CommonSet, CommonPlacementBottomRight,
+ "Bottom Right"), Toolbar::BottomRight);
+ update();
+}
+
+
+void Toolbarmenu::Placementmenu::itemSelected(int button, int index) {
+ if (button != 1)
+ return;
+
+ BasemenuItem *item = find(index);
+ if (! item) return;
+
+ toolbarmenu->toolbar->screen->saveToolbarPlacement(item->function());
+ hide();
+ toolbarmenu->toolbar->reconfigure();
+
+#ifdef SLIT
+ // reposition the slit as well to make sure it doesn't intersect the
+ // toolbar
+ toolbarmenu->toolbar->screen->getSlit()->reposition();
+#endif // SLIT
+}