forked from toepoke/mapsed
-
Notifications
You must be signed in to change notification settings - Fork 0
/
06-full-example.js
324 lines (272 loc) · 12.3 KB
/
06-full-example.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
//
// Map style to use when loading the map
//
var _avocadoStyle = [{"featureType":"water","elementType":"geometry","stylers":[{"visibility":"on"},{"color":"#aee2e0"}]},{"featureType":"landscape","elementType":"geometry.fill","stylers":[{"color":"#abce83"}]},{"featureType":"poi","elementType":"geometry.fill","stylers":[{"color":"#769E72"}]},{"featureType":"poi","elementType":"labels.text.fill","stylers":[{"color":"#7B8758"}]},{"featureType":"poi","elementType":"labels.text.stroke","stylers":[{"color":"#EBF4A4"}]},{"featureType":"poi.park","elementType":"geometry","stylers":[{"visibility":"simplified"},{"color":"#8dab68"}]},{"featureType":"road","elementType":"geometry.fill","stylers":[{"visibility":"simplified"}]},{"featureType":"road","elementType":"labels.text.fill","stylers":[{"color":"#5B5B3F"}]},{"featureType":"road","elementType":"labels.text.stroke","stylers":[{"color":"#ABCE83"}]},{"featureType":"road","elementType":"labels.icon","stylers":[{"visibility":"off"}]},{"featureType":"road.local","elementType":"geometry","stylers":[{"color":"#A4C67D"}]},{"featureType":"road.arterial","elementType":"geometry","stylers":[{"color":"#9BBF72"}]},{"featureType":"road.highway","elementType":"geometry","stylers":[{"color":"#EBF4A4"}]},{"featureType":"transit","stylers":[{"visibility":"off"}]},{"featureType":"administrative","elementType":"geometry.stroke","stylers":[{"visibility":"on"},{"color":"#87ae79"}]},{"featureType":"administrative","elementType":"geometry.fill","stylers":[{"color":"#7f2200"},{"visibility":"off"}]},{"featureType":"administrative","elementType":"labels.text.stroke","stylers":[{"color":"#ffffff"},{"visibility":"on"},{"weight":4.1}]},{"featureType":"administrative","elementType":"labels.text.fill","stylers":[{"color":"#495421"}]},{"featureType":"administrative.neighborhood","elementType":"labels","stylers":[{"visibility":"off"}]}];
//
// Some custom themes, outlinging how additional controls can be added
// ... in this example there's a SELECT dropdown list with themes that can be picked
//
var _snazzyMaps = [
{
"name": "Avocado",
"theme":
_avocadoStyle
}
,
{
"name": "Pale Dawn",
"theme":
[{"featureType":"water","stylers":[{"visibility":"on"},{"color":"#acbcc9"}]},{"featureType":"landscape","stylers":[{"color":"#f2e5d4"}]},{"featureType":"road.highway","elementType":"geometry","stylers":[{"color":"#c5c6c6"}]},{"featureType":"road.arterial","elementType":"geometry","stylers":[{"color":"#e4d7c6"}]},{"featureType":"road.local","elementType":"geometry","stylers":[{"color":"#fbfaf7"}]},{"featureType":"poi.park","elementType":"geometry","stylers":[{"color":"#c5dac6"}]},{"featureType":"administrative","stylers":[{"visibility":"on"},{"lightness":33}]},{"featureType":"road"},{"featureType":"poi.park","elementType":"labels","stylers":[{"visibility":"on"},{"lightness":20}]},{},{"featureType":"road","stylers":[{"lightness":20}]}]
}
,
{
"name": "Blue water",
"theme":
[{"featureType":"water","stylers":[{"color":"#46bcec"},{"visibility":"on"}]},{"featureType":"landscape","stylers":[{"color":"#f2f2f2"}]},{"featureType":"road","stylers":[{"saturation":-100},{"lightness":45}]},{"featureType":"road.highway","stylers":[{"visibility":"simplified"}]},{"featureType":"road.arterial","elementType":"labels.icon","stylers":[{"visibility":"off"}]},{"featureType":"administrative","elementType":"labels.text.fill","stylers":[{"color":"#444444"}]},{"featureType":"transit","stylers":[{"visibility":"off"}]},{"featureType":"poi","stylers":[{"visibility":"off"}]}]
}
];
// Some custom places to show when loading the full map, again to illustrate how it's done
var _places = [
// City Varieties
{
// Flag this place should be shown as tooltip once the map has finished loading
autoShow: true,
// "canEdit" flags that the user can edit the contents of this place
// once the user has finished editing you will get the "onEditOK" event
canEdit: true,
lat: 53.798823,
lng:-1.5426760000000286,
// The "reference" is a Google Places reference string
// This is used to query Google Places for the details of the marker
// Useful if you only want to store references rather than a whole place object in your database
// Note: Google Places CANNOT be edited, only CUSTOM places can (see next place below)
reference: "CoQBfAAAAPw-5BTCS53grSLDwX8rwo5BnWnEWnA72lmOjxdgWg2ODGfC5lLjGyoz428IEaln1vJ6rq1jI96Npzlm-N-wmPH2jdJMGfOLxno_rmgnajAnMPzNzuI8UjexIOdHVZPBPvQGloC-tRhudGeKkbdTT-IWNP5hp4DIl4XOLWuYFOVYEhBxNPxaXZdW9uhKIETXf60hGhTc9yKchnS6oO-6z5XZJkK2ekewYQ",
addInfo:
"<p>Ordering drinks for the <br/>interval is an idea!</p>"
},
// Random made up CUSTOM place
{
// Flag this place can edited (tooltip has an "Edit" button)
// Once editing has completed a callback is fired so you can save the details to your DB
canEdit: true,
lat: 53.79,
lng: -1.59,
name: "Somewhere",
street: "Over the rainbow, Up high way",
userData: 99
}
];
//
// Theme dropdown change event code, applies the selected theme
//
function onThemeChange(me, mapsed) {
var themeName = me.val(),
themeJSON = ""
;
for (var i=0; i < _snazzyMaps.length; i++) {
var currTheme = _snazzyMaps[i];
if (currTheme.name === themeName) {
// found it, so apply the theme
mapsed.getGoogleMap().setOptions({ styles: currTheme.theme });
break;
}
}
} // onThemeChange
//
// Helper method for displaying the details of a place in this demo.
//
function getPlaceHtml(details) {
var html =
"UserData: " + details.userData + "<br/><br/>" +
"Location: " + details.lat + " / " + details.lng + "<br/><br/>" +
"Name: " + details.name + "<br/><br/>" +
"Address: " + details.street +
", " + details.town +
", " + details.area +
", " + details.postCode +
"<br/><br/>" +
"website: <a href='" + details.website + "'>website</a><br/>" +
"g+ <a href='" + details.url + "'>google+ page</a><br/>" +
"Tel: " + details.telNo
return html;
}
//
// Builds up the mapsed object for the demo, wires up default options and
// event handlers.
// There's quite a lot here as we're illustrating pretty much everything.
// Don't be put off ... you won't need anywhere near this level ... probably :oD
//
function fullWindowExample(e) {
e.preventDefault();
$.fn.mapsed({
// Map initialisation options to pass onto Google Maps
mapOptions: {
zoom: 15,
center: new google.maps.LatLng(51.501364 , -0.14189),
styles: _avocadoStyle // see variables.js
},
// Adds a predictive search box
searchOptions: {
enabled: true,
//initSearch: "Football in Leeds",
placeholder: "Search for \"5aside\" ..."
},
// Turn geo button on
allowGeo: true,
// Emulate places being loaded from a db
showOnLoad: _places,
// Adds the "+" button to the control bar at the top right of the map
allowAdd: true,
// Illustrating custom behaviour
// ... changing the added marker to have _some_data_
onAdd: function(m, marker) {
// use a timeout to emulate an ajax lookup
// note marker has "lat" and "lng" properties to use for querying google maps
setTimeout(function() {
marker.details.name = "Test name";
marker.details.street = "Test street";
marker.details.town = "Test town";
marker.details.area = "Test area";
marker.details.postCode = "Test postcode";
marker.details.telNo = "Test telNo";
marker.details.website = "example.com";
marker.details.url = "http://example.com";
// pass control back to mapsed
m.showAddDialog(marker);
}, 2000);
},
// Enables place selection
// ... note the presence of the callback is
// ... all that's required to enable selection
onSelect: function(m, details) {
var msg = getPlaceHtml(details);
m.showMsg("YOUR SELECTION CODE HERE", msg);
// indicate tip should be closed
return true;
},
// Enables edit of new places (to your web application, not Google Maps!)
// ... again the presence of the callback enables the functionality
onSave: function(m, newPlace) {
var missing = [];
// detect errors starting at bottom
// ... we only have space for one error at a time, so this way we'll report
// ... from the top down
if (newPlace.postCode === "") missing.push("postcode");
if (newPlace.street === "") missing.push("street");
if (newPlace.name === "") missing.push("name");
// anything missing?
if (missing.length > 0) {
// return the error message so the callback doesn't progress
return "Required: " + missing.join();
}
if (newPlace) {
if (newPlace.markerType == "new") {
// simulate a primary key being save to a db
newPlace.userData = parseInt(Math.random() * 100000);
}
var msg = getPlaceHtml(newPlace);
m.showMsg("YOUR SAVE CODE HERE!", msg);
}
// indicate form was OK and saved
return "";
},
// Allows the user to delete a "custom" place they've previously
// ... added
confirmDelete: true,
onDelete: function(m, placeToDelete) {
m.showMsg(
"YOUR DELETE CODE HERE",
"<strong>" + placeToDelete.name + "</strong> has been removed."
);
// here would be code your application to do the actual delete
// return true to confirm it was deleted OK and remove marker from the map
// return false if the delete failed
return true;
},
// Custom marker images
getMarkerImage: function(m, markerType, title) {
var imageUrl = "";
if (markerType == "custom")
// a place dervied from "your" database
imageUrl = "examples/images/view-place.png";
else if (markerType == "new")
// user has clicked on the add place (+) icon to add a new place
imageUrl = "examples/images/add-place.png";
else
// normal Google Places result
imageUrl = "examples/images/google-place.png";
return {
url: imageUrl,
size: new google.maps.Size(28, 40),
origin: new google.maps.Point(0, 0),
// where the little cross-hair appears (on new markers) relative to the image
anchor: new google.maps.Point(14, 45)
};
},
// shows additional instructions to the user
getHelpWindow: function(m) {
var html =
"<div class='mapsed-help'>" +
"<h3>Find a venue</h3>" +
"<ol>" +
"<li>Simply use the <strong>search</strong> box to find a venue in your area.</li>" +
"<li>On the pop-up, click <strong>Select</strong> to pick a pitch.</li>" +
"</ol>" +
"<h3>New venues</h3>" +
"<ol>" +
"<li>Your venue isn't displayed? Simply click on the map where your pitch is.</li>" +
"<li>Fill in the details in the dialog.</li>" +
"<li>You can drag the marker around to pinpoint the right location.</li>" +
"<li>Once you're happy, click the <strong>OK</strong> button</li>" +
"</ol>" +
"</div>"
;
return html;
},
showHelpOnLoad: true,
// Callback for when the user tries to load the map
onClose: function(mapsed) {
var closeMap = confirm("Close map?");
// you can cancel the close of the map by returning false
return closeMap;
},
// Fired once the mapsed object has initialised, but before the map
// has been drawn. If you wish to add custom controls, this is where to do it
onPreInit: function(mapsed) {
var html = "",
$select = null,
$mapContainer = null
;
// build up the theme picker
html += "<select id='themePicker' title='Pick an alternative map style...' class='mapsed-control-button'>";
for (var i=0; i < _snazzyMaps.length; i++) {
var theme = _snazzyMaps[i];
html += "<option value='" + theme.name + "'>" + theme.name + "</option>";
}
html += "</select>";
$select = mapsed.addMapControl(html, google.maps.ControlPosition.TOP_RIGHT);
// wire up the change event to pick a new theme
$select.on("change", function() {
onThemeChange($(this), mapsed);
});
// add warning about problems with POI being turn off with custom maps
html =
"<div>" +
"<p>Please note that POI cannot be turned off when using styled maps.</p>" +
"</div>"
;
mapsed.addMapControl(html, google.maps.ControlPosition.BOTTOM_LEFT);
},
// Fired once the map has completed loading
onInit: function(m) {
}
});
}
$(document).ready(function() {
// wire up examples
// wire up full window example
$("#show-full-window")
.on("click", fullWindowExample)
//.trigger("click")
;
});