From 5e141e869d0817ab179e287967451a7def135674 Mon Sep 17 00:00:00 2001 From: Omar Roth Date: Thu, 11 Apr 2019 12:08:43 -0500 Subject: [PATCH] Add subtitles to download widget --- src/invidious.cr | 14 +++++++++++++- src/invidious/views/watch.ecr | 5 +++++ 2 files changed, 18 insertions(+), 1 deletion(-) diff --git a/src/invidious.cr b/src/invidious.cr index 2a314218c..9a2bd260a 100644 --- a/src/invidious.cr +++ b/src/invidious.cr @@ -2722,6 +2722,11 @@ get "/api/v1/captions/:id" do |env| END_CUE end + if title = env.params.query["title"]? + # https://blog.fastmail.com/2011/06/24/download-non-english-filenames/ + env.response.headers["Content-Disposition"] = "attachment; filename=\"#{URI.escape(title)}\"; filename*=UTF-8''#{URI.escape(title)}" + end + webvtt end @@ -4214,11 +4219,18 @@ end get "/latest_version" do |env| if env.params.query["download_widget"]? download_widget = JSON.parse(env.params.query["download_widget"]) + id = download_widget["id"].as_s - itag = download_widget["itag"].as_s title = download_widget["title"].as_s + + if label = download_widget["label"]? + env.redirect "/api/v1/captions/#{id}?label=#{label}&title=#{title}" + next + else + itag = download_widget["itag"].as_s local = "true" end + end id ||= env.params.query["id"]? itag ||= env.params.query["itag"]? diff --git a/src/invidious/views/watch.ecr b/src/invidious/views/watch.ecr index 18cbdef79..bd49709e1 100644 --- a/src/invidious/views/watch.ecr +++ b/src/invidious/views/watch.ecr @@ -79,6 +79,11 @@ <%= itag_to_metadata?(option["itag"]).try &.["height"]? || "~240" %>p - <%= option["type"].split(";")[0] %> <% end %> + <% captions.each do |caption| %> + + <% end %>