2 Situare - A location system for Facebook
3 Copyright (C) 2010 Ixonos Plc. Authors:
5 Jussi Laitinen - jussi.laitinen@ixonos.com
7 Situare is free software; you can redistribute it and/or
8 modify it under the terms of the GNU General Public License
9 version 2 as published by the Free Software Foundation.
11 Situare is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
16 You should have received a copy of the GNU General Public License
17 along with Situare; if not, write to the Free Software
18 Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
22 #ifndef ROUTINGPANEL_H
23 #define ROUTINGPANEL_H
27 #include "panelbase.h"
29 class ExtendedListItemDelegate;
33 class LocationListView;
35 class RouteWaypointListView;
38 * @brief Class for sliding routing panel
40 * @author Jussi Laitinen - jussi.laitinen (at) ixonos.com
42 class RoutingPanel : public PanelBase
48 * @brief Default constructor
52 RoutingPanel(QWidget *parent = 0);
54 /*******************************************************************************
55 * BASE CLASS INHERITED AND REIMPLEMENTED MEMBER FUNCTIONS
56 ******************************************************************************/
59 * @brief Re-implemented from QWidget::hideEvent()
61 * Calls clearListsSelections()
65 void hideEvent(QHideEvent *event);
67 /*******************************************************************************
68 * MEMBER FUNCTIONS AND SLOTS
69 ******************************************************************************/
72 * @brief Clears lists' selections.
74 * Does call setRouteButtonDisabled().
76 void clearListsSelections();
79 * @brief Populates location list view.
81 * @param locations list of Location objects
83 void populateLocationListView(const QList<Location> &locations);
86 * @brief Routes to selected location.
88 * Emits routeToLocation if location is selected from list.
90 void routeToSelectedLocation();
93 * @brief Sets route to the panel.
95 * Appends route waypoint list with route segments.
96 * @param route Route item containing parsed route details
98 void setRoute(Route &route);
101 * @brief Sets route button disabled.
103 * Disabled if there isn't any list item selected.
105 void setRouteButtonDisabled();
107 /*******************************************************************************
109 ******************************************************************************/
112 * @brief Signal for location item clicked.
114 * @param swBound south-west bound GeoCoordinate
115 * @param neBound north-east bound GeoCoordinate
117 void locationItemClicked(const GeoCoordinate &swBound, const GeoCoordinate &neBound);
120 * @brief Signal for requesting searching location.
122 void requestSearchLocation();
125 * @brief Signal for routing to location.
127 * @param coordinates location's geo coordinates
129 void routeToLocation(const GeoCoordinate &coordinates);
132 * @brief Signal for route waypoint item clicked.
134 * @param coordinate waypoint item's coordinate
136 void routeWaypointItemClicked(const GeoCoordinate &coordinate);
139 * @brief Signal for requesting a panel to be opened
141 * @param widget Pointer to the widget that emitted the signal
143 void showPanelRequested(QWidget *widget);
145 /*******************************************************************************
147 ******************************************************************************/
149 QLabel *m_locationListLabel; ///< Location list label
151 QPushButton *m_searchLocationButton; ///< Search location button
153 QWidget *m_locationListHeaderWidget; ///< Location list header widget
155 ImageButton *m_routeButton; ///< Route to location button
156 LocationListView *m_locationListView; ///< Location list view
157 RouteWaypointListView *m_routeWaypointListView; ///< Route waypoint list view
160 #endif // ROUTINGPANEL_H