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 class ExtendedListItemDelegate;
29 class LocationListView;
32 class RouteWaypointListView;
35 * @brief Class for sliding routing panel
37 * @author Jussi Laitinen - jussi.laitinen (at) ixonos.com
39 class RoutingPanel : public QWidget
45 * @brief Default constructor
49 RoutingPanel(QWidget *parent = 0);
51 /*******************************************************************************
52 * BASE CLASS INHERITED AND REIMPLEMENTED MEMBER FUNCTIONS
53 ******************************************************************************/
56 * @brief Re-implemented from QWidget::hideEvent()
58 * Calls clearListsSelections()
62 void hideEvent(QHideEvent *event);
64 /*******************************************************************************
65 * MEMBER FUNCTIONS AND SLOTS
66 ******************************************************************************/
69 * @brief Clears lists' selections.
71 * Does call setRouteButtonDisabled().
73 void clearListsSelections();
76 * @brief Populates location list view.
78 * @param locations list of Location objects
80 void populateLocationListView(const QList<Location> &locations);
83 * @brief Routes to selected location.
85 * Emits routeToLocation if location is selected from list.
87 void routeToSelectedLocation();
90 * @brief Sets route to the panel.
92 * Appends route waypoint list with route segments.
93 * @param route Route item containing parsed route details
95 void setRoute(Route &route);
98 * @brief Sets route button disabled.
100 * Disabled if there isn't any list item selected.
102 void setRouteButtonDisabled();
104 /*******************************************************************************
106 ******************************************************************************/
109 * @brief Signal for location item clicked.
111 * @param swBound south-west bound GeoCoordinate
112 * @param neBound north-east bound GeoCoordinate
114 void locationItemClicked(const GeoCoordinate &swBound, const GeoCoordinate &neBound);
117 * @brief Signal for requesting searching location.
119 void requestSearchLocation();
122 * @brief Signal for routing to location.
124 * @param coordinates location's geo coordinates
126 void routeToLocation(const GeoCoordinate &coordinates);
129 * @brief Signal for route waypoint item clicked.
131 * @param coordinate waypoint item's coordinate
133 void routeWaypointItemClicked(const GeoCoordinate &coordinate);
136 * @brief Signal for requesting a panel to be opened
138 * @param widget Pointer to the widget that emitted the signal
140 void showPanelRequested(QWidget *widget);
142 /*******************************************************************************
144 ******************************************************************************/
146 QLabel *m_locationListLabel; ///< Location list label
148 QPushButton *m_routeButton; ///< Route to location button
149 QPushButton *m_searchLocationButton; ///< Search location button
151 QWidget *m_locationListHeaderWidget; ///< Location list header widget
153 LocationListView *m_locationListView; ///< Location list view
154 RouteWaypointListView *m_routeWaypointListView; ///< Route waypoint list view
157 #endif // ROUTINGPANEL_H