-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathscript.js
96 lines (67 loc) · 4.46 KB
/
script.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
$(document).ready(function() {
$("#searchBtn").on("click", function(){
event.preventDefault();
var city = $("#location").val().trim();
var genre = $('select').val();
inputQuery(city, genre);
})
function inputQuery (city, genre) {
var ticketMasterAPI = "GzXQkPNDt7ZVTo3fbAmXPspPozArApCc";
var page = 0; //page number, starts from 0
var queryURL = "https://app.ticketmaster.com/discovery/v2/events.json?countryCode=US&city="+city+"&classificationName="+genre+"&size=10&page="+page+"&apikey="+ ticketMasterAPI;
$.ajax({
url: queryURL,
method: "GET"
}).then(function(response) {
//empty out previous query after each search event button press
$(".results").empty();
var resultsHeader= $("<h4>").attr("class", "results-header")
resultsHeader.text("Events Happening:");
$(".results").append(resultsHeader)
$(".results").append($("<hr>"));
//display event name on page
for(var i = 0; i < 10; i++){
var createButtons = $("<li>");
var createLine = $("<hr>");
var getName = response._embedded.events[i].name //use loop to place in placeholder as clickeable links
createButtons.addClass("resultsBtn");
createButtons.attr({"city": city, "keyword": getName}); //set the keyword to the query to pull specific info
createButtons.text(getName);
$(".results").append(createButtons,createLine);
}
$(document).on("click", ".resultsBtn", function(event) {
event.preventDefault();
var keyword = $(this).attr("keyword");
var city = $(this).attr("city");
var eventQueryURL = "https://app.ticketmaster.com/discovery/v2/events.json?countryCode=US&city="+city+"&keyword="+keyword+"&apikey="+ ticketMasterAPI;
$.ajax({
url: eventQueryURL,
method: "GET"
}).then(function(response) {
console.log(response);
var getTitle = response._embedded.events[0].name
$("#eventName").text(getTitle);
var artist = response._embedded.events[0]._embedded.attractions[0].name;
$("#artistName").text("Artist: " + artist).attr("artist-name", artist);
var venueName = response._embedded.events[0]._embedded.venues[0].name;
var venueAddress = response._embedded.events[0]._embedded.venues[0].address.line1;
var venueState = response._embedded.events[0]._embedded.venues[0].state.stateCode;
var venueCity = response._embedded.events[0]._embedded.venues[0].city.name;
var venuePostalCode = response._embedded.events[0]._embedded.venues[0].postalCode;
$("#venueInfo").text("Venue: " + venueName + " ("+venueAddress+", "+venueCity+", "+ venueState+" "+ venuePostalCode +")");
var eventStatus = response._embedded.events[0].dates.status.code;
$("#eventStatus").text("Event Status : " + eventStatus.toUpperCase());
var image = response._embedded.events[0]._embedded.attractions[0].images[4].url;
$("#eventImage").attr("src", image);
var ticketLink = response._embedded.events[0]._embedded.attractions[0].url;
$("#ticketLink").attr("href", ticketLink);
// var ticketLink = response._embedded.events[0]._embedded.attractions[0].url;
// var minPrice = response._embedded.events[0].priceRanges[0].min;
// var maxPrice = response._embedded.events[0].priceRanges[0].max;
// var startDate = response._embedded.events[0].dates.start.localDate;
// var startTime = response._embedded.events[0].dates.start.localTime;
})
})
})
}
})