/* panel-bar.hpp - Declaration of the panel bar widget Copyright (C) Lumiera.org 2009, Joel Holdsworth This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. * *****************************************************/ #include "gui/widgets/panel-bar.hpp" #include "gui/workspace/workspace-window.hpp" #include "gui/workspace/panel-manager.hpp" #include "gui/panels/panel.hpp" #include "gui/util/rectangle.hpp" #include "include/logging.h" #include #include using namespace Gtk; using namespace Glib; using namespace sigc; using namespace std; using namespace gui::workspace; namespace gui { namespace widgets { PanelBar::PanelBar(panels::Panel &owner_panel, const gchar *stock_id) : Box(), panel(owner_panel), panelButton(StockID(stock_id)), lockItem(NULL) { set_border_width(1); panelButton.set_relief(RELIEF_NONE); panelButton.set_can_focus(false); panelButton.show(); pack_start(panelButton, PACK_SHRINK); setup_panel_button(); } void PanelBar::setup_panel_button() { REQUIRE(lockItem == NULL); // Add items for each type of panel for(int i = 0; i < PanelManager::get_panel_description_count(); i++) { uString title = uString(PanelManager::get_panel_title(i)); uString slug (title); /** Slug should be a char only string, no spaces, numbers, or * symbols. Currently all panel titles are single words. So * the above works ok for now. */ slot func = bind(mem_fun(*this, &PanelBar::on_panel_type), i); panelButton.append (slug, title, func); /** Keeping this snippet for easy reference * list.push_back( Menu_Helpers::StockMenuElem( * StockID(PanelManager::get_panel_stock_id(i)), * bind(mem_fun(*this, &PanelBar::on_panel_type), i) )); **/ } FIXME("Update for gtk3"); #if 0 list.push_back( Menu_Helpers::SeparatorElem() ); #endif // Add extra commands slot hide = mem_fun(*this, &PanelBar::on_hide); panelButton.append("Hide","_Hide", hide); slot lock = mem_fun(*this, &PanelBar::on_lock); panelButton.append("Lock", "_Lock", lock); FIXME("Update for gtk3"); #if 0 lockItem = dynamic_cast(&list.back()); ENSURE(lockItem); lockItem->set_active(panel.is_locked()); #endif slot hfunc = bind(mem_fun(*this, &PanelBar::on_split_panel), ORIENTATION_HORIZONTAL); panelButton.append("SplitHorizontal", "Split _Horizontal",hfunc); slot vfunc = bind(mem_fun(*this, &PanelBar::on_split_panel), ORIENTATION_VERTICAL); panelButton.append("SplitVertical", "Split _Vertical", vfunc); } void PanelBar::on_panel_type(int type_index) { panel.get_panel_manager().switch_panel(panel, type_index); } void PanelBar::on_hide() { panel.show(false); } void PanelBar::on_lock() { static bool is_locking = false; REQUIRE(lockItem); if(!is_locking) { is_locking = true; const bool lock = !panel.is_locked(); panel.lock(lock); lockItem->set_active(lock); is_locking = false; } } void PanelBar::on_split_panel(Gtk::Orientation split_direction) { panel.get_panel_manager().split_panel(panel, split_direction); } } // widgets } // gui