-/* $Id$
-
-This file is part of the MSP Märklin suite
-Copyright © 2009 Mikkosoft Productions, Mikko Rasa
-Distributed under the GPL
-*/
-
-#include <msp/gltk/button.h>
-#include <msp/strings/formatter.h>
-#include "designer.h"
+#include <msp/gltk/row.h>
#include "toolbar.h"
using namespace std;
using namespace Msp;
-using namespace Marklin;
-Toolbar::Toolbar(Designer &d):
- GLtk::Widget(d.get_ui_resources()),
- GLtk::Panel(d.get_ui_resources()),
- designer(d)
+Toolbar::Toolbar(const string &name):
+ expanded(true)
{
- set_size(370, 40);
-
- GLtk::Button *btn;
- GLtk::Label *lbl;
-
- add(*(btn=new GLtk::Button(res, "Load")));
- btn->set_geometry(GLtk::Geometry(5, 10, 40, 24));
-
- add(*(btn=new GLtk::Button(res, "Save")));
- btn->set_geometry(GLtk::Geometry(45, 10, 40, 24));
- btn->signal_clicked.connect(sigc::mem_fun(&designer, &Designer::save));
-
- add(*(btn=new GLtk::Button(res, "Quit")));
- btn->set_geometry(GLtk::Geometry(85, 10, 40, 24));
- btn->set_style("red");
- btn->signal_clicked.connect(sigc::mem_fun(&designer, &Designer::quit));
-
- add(*(btn=new GLtk::Button(res, "Trnt")));
- btn->set_geometry(GLtk::Geometry(135, 10, 40, 24));
-
- add(*(btn=new GLtk::Button(res, "Sens")));
- btn->set_geometry(GLtk::Geometry(175, 10, 40, 24));
-
- add(*(lbl=new GLtk::Label(res, "Routes:")));
- lbl->set_geometry(GLtk::Geometry(225, 22, 40, 13));
-
- add(*(drp_routes=new GLtk::Dropdown(res)));
- drp_routes->set_geometry(GLtk::Geometry(225, 5, 100, 17));
- drp_routes->append("(new route)");
- drp_routes->signal_item_selected.connect(sigc::mem_fun(this, &Toolbar::route_selected));
-
- add(*(btn=new GLtk::Button(res, "AddT")));
- btn->set_geometry(GLtk::Geometry(325, 10, 40, 24));
- btn->signal_clicked.connect(sigc::mem_fun(&designer, &Designer::add_selection_to_route));
-
- designer.get_layout()->signal_route_added.connect(sigc::hide(sigc::mem_fun(this, &Toolbar::update_routes)));
- designer.get_layout()->signal_route_removed.connect(sigc::hide(sigc::mem_fun(this, &Toolbar::update_routes)));
- update_routes();
+ set_focusable(false);
+ set_layout(new GLtk::Layout);
+ GLtk::Row row(*layout);
+ layout->set_margin(GLtk::Sides(6, 10));
+ layout->set_column_spacing(10);
+
+ add(*(lbl_title = new GLtk::Label(name)));
+
+ add(*(btn_expand = new GLtk::Button));
+ btn_expand->set_style("arrow_left");
+ btn_expand->set_tooltip("Collapse toolbar");
+ btn_expand->signal_clicked.connect(sigc::mem_fun(this, &Toolbar::expand_clicked));
+
+ add(*(pnl_content = new GLtk::Panel));
+ pnl_content->set_style("group");
+ GLtk::Layout *content_layout = new GLtk::Layout;
+ // XXX This needs to get deleted somehow
+ new GLtk::Row(*content_layout);
+ pnl_content->set_layout(content_layout);
+ content_layout->set_margin(0);
}
-void Toolbar::route_selected(unsigned index, const string &)
+void Toolbar::expand(bool e)
{
- if(index==drp_routes->get_n_items()-1)
- {
- Route *route = new Route(format("Route %d", designer.get_layout()->get_routes().size()+1));
- designer.get_layout()->add_route(*route);
- designer.edit_route(*route);
+ expanded = e;
+ btn_expand->set_style(expanded ? "arrow_left" : "arrow_right");
+ btn_expand->set_tooltip(expanded ? "Collapse toolbar" : "Expand toolbar");
+ pnl_content->set_visible(expanded);
+ signal_autosize_changed.emit();
- const set<Route *> &routes = designer.get_layout()->get_routes();
- int selected = -1;
- unsigned n = 0;
- for(set<Route *>::const_iterator i=routes.begin(); (selected<0 && i!=routes.end()); ++i, ++n)
- if(*i==route)
- selected = n;
- drp_routes->set_selected_index(selected);
- }
- else
- {
- const set<Route *> &routes = designer.get_layout()->get_routes();
- set<Route *>::const_iterator i = routes.begin();
- advance(i, index);
- designer.edit_route(**i);
- }
+ signal_expanded.emit(expanded);
}
-void Toolbar::update_routes()
+void Toolbar::expand_clicked()
{
- drp_routes->clear();
- const set<Route *> &routes = designer.get_layout()->get_routes();
- int selected = -1;
- unsigned n = 0;
- for(set<Route *>::const_iterator i=routes.begin(); i!=routes.end(); ++i, ++n)
- {
- drp_routes->append((*i)->get_name());
- if(*i==designer.get_current_route())
- selected = n;
- }
- drp_routes->append("(new route)");
- drp_routes->set_selected_index(selected);
+ expand(!expanded);
}