Merge pull request #24 from omarroth/split-comments
Split Reddit comments into separate request
This commit is contained in:
commit
8c121528e9
3 changed files with 84 additions and 30 deletions
|
@ -12,3 +12,16 @@ div {
|
||||||
overflow-wrap: break-word;
|
overflow-wrap: break-word;
|
||||||
word-wrap: break-word;
|
word-wrap: break-word;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.loading {
|
||||||
|
animation: spin 2s linear infinite;
|
||||||
|
}
|
||||||
|
|
||||||
|
@keyframes spin {
|
||||||
|
0% {
|
||||||
|
transform: rotate(0deg);
|
||||||
|
}
|
||||||
|
100% {
|
||||||
|
transform: rotate(360deg);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -374,19 +374,6 @@ get "/watch" do |env|
|
||||||
k2 = k2.join(", ")
|
k2 = k2.join(", ")
|
||||||
end
|
end
|
||||||
|
|
||||||
reddit_client = make_client(REDDIT_URL)
|
|
||||||
headers = HTTP::Headers{"User-Agent" => "web:invidio.us:v0.1.0 (by /u/omarroth)"}
|
|
||||||
begin
|
|
||||||
reddit_comments, reddit_thread = get_reddit_comments(id, reddit_client, headers)
|
|
||||||
reddit_html = template_comments(reddit_comments)
|
|
||||||
|
|
||||||
reddit_html = fill_links(reddit_html, "https", "www.reddit.com")
|
|
||||||
reddit_html = add_alt_links(reddit_html)
|
|
||||||
rescue ex
|
|
||||||
reddit_thread = nil
|
|
||||||
reddit_html = ""
|
|
||||||
end
|
|
||||||
|
|
||||||
video.description = fill_links(video.description, "https", "www.youtube.com")
|
video.description = fill_links(video.description, "https", "www.youtube.com")
|
||||||
video.description = add_alt_links(video.description)
|
video.description = add_alt_links(video.description)
|
||||||
|
|
||||||
|
@ -395,6 +382,40 @@ get "/watch" do |env|
|
||||||
templated "watch"
|
templated "watch"
|
||||||
end
|
end
|
||||||
|
|
||||||
|
get "/comments/:id" do |env|
|
||||||
|
id = env.params.url["id"]
|
||||||
|
|
||||||
|
source = env.params.query["source"]?
|
||||||
|
source ||= "youtube"
|
||||||
|
|
||||||
|
format = env.params.query["format"]?
|
||||||
|
format ||= "html"
|
||||||
|
|
||||||
|
if source == "reddit"
|
||||||
|
reddit_client = make_client(REDDIT_URL)
|
||||||
|
headers = HTTP::Headers{"User-Agent" => "web:invidio.us:v0.1.0 (by /u/omarroth)"}
|
||||||
|
begin
|
||||||
|
reddit_comments, reddit_thread = get_reddit_comments(id, reddit_client, headers)
|
||||||
|
reddit_html = template_comments(reddit_comments)
|
||||||
|
|
||||||
|
reddit_html = fill_links(reddit_html, "https", "www.reddit.com")
|
||||||
|
reddit_html = add_alt_links(reddit_html)
|
||||||
|
rescue ex
|
||||||
|
reddit_thread = nil
|
||||||
|
reddit_html = ""
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
if !reddit_thread
|
||||||
|
halt env, status_code: 404
|
||||||
|
end
|
||||||
|
|
||||||
|
env.response.content_type = "application/json"
|
||||||
|
{"title" => reddit_thread.title,
|
||||||
|
"permalink" => reddit_thread.permalink,
|
||||||
|
"content_html" => reddit_html}.to_json
|
||||||
|
end
|
||||||
|
|
||||||
get "/embed/:id" do |env|
|
get "/embed/:id" do |env|
|
||||||
if env.params.url["id"]?
|
if env.params.url["id"]?
|
||||||
id = env.params.url["id"]
|
id = env.params.url["id"]
|
||||||
|
|
|
@ -133,6 +133,41 @@ for ( var i = 0; i < currentSources.length; i++ ) {
|
||||||
|
|
||||||
player.src(currentSources);
|
player.src(currentSources);
|
||||||
<% end %>
|
<% end %>
|
||||||
|
|
||||||
|
fetch("/comments/<%= video.id %>?source=reddit")
|
||||||
|
.then(function(response) {
|
||||||
|
return response.json();
|
||||||
|
})
|
||||||
|
.then(function(jsonResponse) {
|
||||||
|
comments = document.getElementById('comments');
|
||||||
|
comments.innerHTML = `
|
||||||
|
<div>
|
||||||
|
<h3>
|
||||||
|
<a href="javascript:void(0)" onclick="toggle_comments(this)">[ - ]</a>
|
||||||
|
{title}
|
||||||
|
</h3>
|
||||||
|
<b>
|
||||||
|
<a target="_blank" href="https://reddit.com{permalink}">View more comments on Reddit</a>
|
||||||
|
</b>
|
||||||
|
</div>
|
||||||
|
<div>{content_html}</div>
|
||||||
|
</div>
|
||||||
|
<hr style="margin-left:1em; margin-right:1em;">`.supplant({
|
||||||
|
title: jsonResponse.title,
|
||||||
|
permalink: jsonResponse.permalink,
|
||||||
|
content_html: jsonResponse.content_html
|
||||||
|
})
|
||||||
|
});
|
||||||
|
|
||||||
|
String.prototype.supplant = function (o) {
|
||||||
|
return this.replace(/{([^{}]*)}/g,
|
||||||
|
function (a, b) {
|
||||||
|
var r = o[b];
|
||||||
|
return typeof r === 'string' || typeof r === 'number' ? r : a;
|
||||||
|
}
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<div class="h-box">
|
<div class="h-box">
|
||||||
|
@ -207,26 +242,11 @@ player.src(currentSources);
|
||||||
<%= video.description %>
|
<%= video.description %>
|
||||||
</div>
|
</div>
|
||||||
<hr style="margin-left:1em; margin-right:1em;">
|
<hr style="margin-left:1em; margin-right:1em;">
|
||||||
<% if reddit_thread && !reddit_html.empty? %>
|
<div id="comments">
|
||||||
<div id="Comments">
|
<h3><center><i class="loading fas fa-spinner"></i></center></h3>
|
||||||
<div>
|
|
||||||
<h3>
|
|
||||||
<a href="javascript:void(0)" onclick="toggle_comments(this)">[ - ]</a>
|
|
||||||
<%= reddit_thread.title %>
|
|
||||||
</h3>
|
|
||||||
<b>
|
|
||||||
<a target="_blank" href="https://reddit.com<%= reddit_thread.permalink %>">View more comments on Reddit</a>
|
|
||||||
</b>
|
|
||||||
</div>
|
|
||||||
<div>
|
|
||||||
<%= reddit_html %>
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
<hr style="margin-left:1em; margin-right:1em;">
|
|
||||||
<% end %>
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="pure-u-1 pure-u-md-1-5">
|
<div class="pure-u-1 pure-u-md-1-5">
|
||||||
<div class="h-box">
|
<div class="h-box">
|
||||||
<% rvs.each do |rv| %>
|
<% rvs.each do |rv| %>
|
||||||
|
|
Loading…
Reference in a new issue