-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathscript.babel
More file actions
111 lines (99 loc) · 2.35 KB
/
script.babel
File metadata and controls
111 lines (99 loc) · 2.35 KB
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
function inIframe() {
try {
return window.self !== window.top;
} catch (e) {
return true;
}
}
var colors = [
"#16a085",
"#27ae60",
"#2c3e50",
"#f39c12",
"#e74c3c",
"#9b59b6",
"#FB6964",
"#342224",
"#472E32",
"#BDBB99",
"#77B1A9",
"#73A857"
];
var currentQuote = "",
currentAuthor = "";
function openURL(url) {
window.open(
url,
"Share",
"width=550, height=400, toolbar=0, scrollbars=1 ,location=0 ,statusbar=0,menubar=0, resizable=0"
);
}
function getQuotes() {
return $.ajax({
headers: {
Accept: "application/json"
},
url:
"https://gist.githubusercontent.com/camperbot/5a022b72e96c4c9585c32bf6a75f62d9/raw/e3c6895ce42069f0ee7e991229064f167fe8ccdc/quotes.json",
success: function(jsonQuotes) {
if (typeof jsonQuotes === "string") {
quotesData = JSON.parse(jsonQuotes);
console.log("quotesData");
console.log(quotesData);
}
}
});
}
function getRandomQuote() {
return quotesData.quotes[
Math.floor(Math.random() * quotesData.quotes.length)
];
}
function getQuote() {
let randomQuote = getRandomQuote();
currentQuote = randomQuote.quote;
currentAuthor = randomQuote.author;
if (inIframe()) {
$("#tweet-quote").attr(
"href",
"https://twitter.com/intent/tweet?hashtags=quotes&related=freecodecamp&text=" +
encodeURIComponent('"' + currentQuote + '" ' + currentAuthor)
);
}
$(".quote-text").animate({ opacity: 0 }, 500, function() {
$(this).animate({ opacity: 1 }, 500);
$("#text").text(randomQuote.quote);
});
$(".quote-author").animate({ opacity: 0 }, 500, function() {
$(this).animate({ opacity: 1 }, 500);
$("#author").html(randomQuote.author);
});
var color = Math.floor(Math.random() * colors.length);
$("html body").animate(
{
backgroundColor: colors[color],
color: colors[color]
},
1000
);
$(".button").animate(
{
backgroundColor: colors[color]
},
1000
);
}
$(document).ready(function() {
getQuotes().then(() => {
getQuote();
});
$("#new-quote").on("click", getQuote);
$("#tweet-quote").on("click", function() {
if (!inIframe()) {
openURL(
"https://twitter.com/intent/tweet?hashtags=quotes&related=freecodecamp&text=" +
encodeURIComponent('"' + currentQuote + '" ' + currentAuthor)
);
}
});
});