forked from Fijxu/invidious
Allow user to save preferences without creating an account
This commit is contained in:
parent
7f75a7ca0b
commit
ebcb21dbfe
3 changed files with 204 additions and 142 deletions
276
src/invidious.cr
276
src/invidious.cr
|
@ -175,6 +175,7 @@ before_all do |env|
|
||||||
|
|
||||||
locale = user.preferences.locale
|
locale = user.preferences.locale
|
||||||
env.set "user", user
|
env.set "user", user
|
||||||
|
env.set "preferences", user.preferences
|
||||||
env.set "sid", sid
|
env.set "sid", sid
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
|
@ -187,12 +188,20 @@ before_all do |env|
|
||||||
|
|
||||||
locale = user.preferences.locale
|
locale = user.preferences.locale
|
||||||
env.set "user", user
|
env.set "user", user
|
||||||
|
env.set "preferences", user.preferences
|
||||||
env.set "sid", sid
|
env.set "sid", sid
|
||||||
rescue ex
|
rescue ex
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
if env.request.cookies.has_key? "PREFS"
|
||||||
|
preferences = Preferences.from_json(env.request.cookies["PREFS"].value)
|
||||||
|
|
||||||
|
locale = preferences.locale
|
||||||
|
env.set "preferences", preferences
|
||||||
|
end
|
||||||
|
|
||||||
locale = env.params.query["hl"]? || locale
|
locale = env.params.query["hl"]? || locale
|
||||||
locale ||= "en-US"
|
locale ||= "en-US"
|
||||||
env.set "locale", locale
|
env.set "locale", locale
|
||||||
|
@ -268,11 +277,12 @@ get "/watch" do |env|
|
||||||
nojs ||= "0"
|
nojs ||= "0"
|
||||||
nojs = nojs == "1"
|
nojs = nojs == "1"
|
||||||
|
|
||||||
user = env.get? "user"
|
if env.get? "preferences"
|
||||||
if user
|
preferences = env.get("preferences").as(Preferences)
|
||||||
user = user.as(User)
|
end
|
||||||
|
|
||||||
preferences = user.preferences
|
if env.get? "user"
|
||||||
|
user = env.get("user").as(User)
|
||||||
subscriptions = user.subscriptions
|
subscriptions = user.subscriptions
|
||||||
watched = user.watched
|
watched = user.watched
|
||||||
end
|
end
|
||||||
|
@ -866,17 +876,31 @@ post "/login" do |env|
|
||||||
|
|
||||||
host = URI.parse(env.request.headers["Host"]).host
|
host = URI.parse(env.request.headers["Host"]).host
|
||||||
|
|
||||||
|
if Kemal.config.ssl || CONFIG.https_only
|
||||||
|
secure = true
|
||||||
|
else
|
||||||
|
secure = false
|
||||||
|
end
|
||||||
|
|
||||||
login.cookies.each do |cookie|
|
login.cookies.each do |cookie|
|
||||||
if Kemal.config.ssl || CONFIG.https_only
|
if Kemal.config.ssl || CONFIG.https_only
|
||||||
cookie.secure = true
|
cookie.secure = secure
|
||||||
else
|
else
|
||||||
cookie.secure = false
|
cookie.secure = secure
|
||||||
end
|
end
|
||||||
|
|
||||||
cookie.extension = cookie.extension.not_nil!.gsub(".youtube.com", host)
|
cookie.extension = cookie.extension.not_nil!.gsub(".youtube.com", host)
|
||||||
cookie.extension = cookie.extension.not_nil!.gsub("Secure; ", "")
|
cookie.extension = cookie.extension.not_nil!.gsub("Secure; ", "")
|
||||||
end
|
end
|
||||||
|
|
||||||
|
if env.request.cookies["PREFS"]?
|
||||||
|
preferences = env.get("preferences").as(Preferences)
|
||||||
|
PG_DB.exec("UPDATE users SET preferences = $1 WHERE email = $2", preferences, user.email)
|
||||||
|
|
||||||
|
login.cookies["PREFS"] = HTTP::Cookie.new(name: "PREFS", value: "", expires: Time.new(1990, 1, 1),
|
||||||
|
secure: secure, http_only: true)
|
||||||
|
end
|
||||||
|
|
||||||
login.cookies.add_response_headers(env.response.headers)
|
login.cookies.add_response_headers(env.response.headers)
|
||||||
|
|
||||||
env.redirect referer
|
env.redirect referer
|
||||||
|
@ -985,6 +1009,12 @@ post "/login" do |env|
|
||||||
error_message = translate(locale, "Invalid username or password")
|
error_message = translate(locale, "Invalid username or password")
|
||||||
next templated "error"
|
next templated "error"
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Since this user has already registered, we don't want to overwrite their preferences
|
||||||
|
if env.request.cookies["PREFS"]?
|
||||||
|
env.response.cookies["PREFS"] = HTTP::Cookie.new(name: "PREFS", value: "", expires: Time.new(1990, 1, 1),
|
||||||
|
secure: secure, http_only: true)
|
||||||
|
end
|
||||||
elsif action == "register"
|
elsif action == "register"
|
||||||
if password.empty?
|
if password.empty?
|
||||||
error_message = translate(locale, "Password cannot be empty")
|
error_message = translate(locale, "Password cannot be empty")
|
||||||
|
@ -1032,6 +1062,14 @@ post "/login" do |env|
|
||||||
env.response.cookies["SID"] = HTTP::Cookie.new(name: "SID", value: sid, expires: Time.now + 2.years,
|
env.response.cookies["SID"] = HTTP::Cookie.new(name: "SID", value: sid, expires: Time.now + 2.years,
|
||||||
secure: secure, http_only: true)
|
secure: secure, http_only: true)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
if env.request.cookies["PREFS"]?
|
||||||
|
preferences = env.get("preferences").as(Preferences)
|
||||||
|
PG_DB.exec("UPDATE users SET preferences = $1 WHERE email = $2", preferences, user.email)
|
||||||
|
|
||||||
|
env.response.cookies["PREFS"] = HTTP::Cookie.new(name: "PREFS", value: "", expires: Time.new(1990, 1, 1),
|
||||||
|
secure: secure, http_only: true)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
env.redirect referer
|
env.redirect referer
|
||||||
|
@ -1073,121 +1111,121 @@ end
|
||||||
|
|
||||||
get "/preferences" do |env|
|
get "/preferences" do |env|
|
||||||
locale = LOCALES[env.get("locale").as(String)]?
|
locale = LOCALES[env.get("locale").as(String)]?
|
||||||
|
|
||||||
user = env.get? "user"
|
|
||||||
referer = get_referer(env)
|
referer = get_referer(env)
|
||||||
|
|
||||||
if user
|
if preferences = env.get? "preferences"
|
||||||
user = user.as(User)
|
preferences = preferences.as(Preferences)
|
||||||
|
|
||||||
templated "preferences"
|
templated "preferences"
|
||||||
else
|
else
|
||||||
env.redirect referer
|
preferences = DEFAULT_USER_PREFERENCES
|
||||||
|
|
||||||
|
templated "preferences"
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
post "/preferences" do |env|
|
post "/preferences" do |env|
|
||||||
locale = LOCALES[env.get("locale").as(String)]?
|
locale = LOCALES[env.get("locale").as(String)]?
|
||||||
|
|
||||||
user = env.get? "user"
|
|
||||||
referer = get_referer(env)
|
referer = get_referer(env)
|
||||||
|
|
||||||
if user
|
video_loop = env.params.body["video_loop"]?.try &.as(String)
|
||||||
|
video_loop ||= "off"
|
||||||
|
video_loop = video_loop == "on"
|
||||||
|
|
||||||
|
autoplay = env.params.body["autoplay"]?.try &.as(String)
|
||||||
|
autoplay ||= "off"
|
||||||
|
autoplay = autoplay == "on"
|
||||||
|
|
||||||
|
continue = env.params.body["continue"]?.try &.as(String)
|
||||||
|
continue ||= "off"
|
||||||
|
continue = continue == "on"
|
||||||
|
|
||||||
|
listen = env.params.body["listen"]?.try &.as(String)
|
||||||
|
listen ||= "off"
|
||||||
|
listen = listen == "on"
|
||||||
|
|
||||||
|
speed = env.params.body["speed"]?.try &.as(String).to_f?
|
||||||
|
speed ||= DEFAULT_USER_PREFERENCES.speed
|
||||||
|
|
||||||
|
quality = env.params.body["quality"]?.try &.as(String)
|
||||||
|
quality ||= DEFAULT_USER_PREFERENCES.quality
|
||||||
|
|
||||||
|
volume = env.params.body["volume"]?.try &.as(String).to_i?
|
||||||
|
volume ||= DEFAULT_USER_PREFERENCES.volume
|
||||||
|
|
||||||
|
comments_0 = env.params.body["comments_0"]?.try &.as(String) || DEFAULT_USER_PREFERENCES.comments[0]
|
||||||
|
comments_1 = env.params.body["comments_1"]?.try &.as(String) || DEFAULT_USER_PREFERENCES.comments[1]
|
||||||
|
comments = [comments_0, comments_1]
|
||||||
|
|
||||||
|
captions_0 = env.params.body["captions_0"]?.try &.as(String) || DEFAULT_USER_PREFERENCES.captions[0]
|
||||||
|
captions_1 = env.params.body["captions_1"]?.try &.as(String) || DEFAULT_USER_PREFERENCES.captions[1]
|
||||||
|
captions_2 = env.params.body["captions_2"]?.try &.as(String) || DEFAULT_USER_PREFERENCES.captions[2]
|
||||||
|
captions = [captions_0, captions_1, captions_2]
|
||||||
|
|
||||||
|
related_videos = env.params.body["related_videos"]?.try &.as(String)
|
||||||
|
related_videos ||= "off"
|
||||||
|
related_videos = related_videos == "on"
|
||||||
|
|
||||||
|
redirect_feed = env.params.body["redirect_feed"]?.try &.as(String)
|
||||||
|
redirect_feed ||= "off"
|
||||||
|
redirect_feed = redirect_feed == "on"
|
||||||
|
|
||||||
|
locale = env.params.body["locale"]?.try &.as(String)
|
||||||
|
locale ||= DEFAULT_USER_PREFERENCES.locale
|
||||||
|
|
||||||
|
dark_mode = env.params.body["dark_mode"]?.try &.as(String)
|
||||||
|
dark_mode ||= "off"
|
||||||
|
dark_mode = dark_mode == "on"
|
||||||
|
|
||||||
|
thin_mode = env.params.body["thin_mode"]?.try &.as(String)
|
||||||
|
thin_mode ||= "off"
|
||||||
|
thin_mode = thin_mode == "on"
|
||||||
|
|
||||||
|
max_results = env.params.body["max_results"]?.try &.as(String).to_i?
|
||||||
|
max_results ||= DEFAULT_USER_PREFERENCES.max_results
|
||||||
|
|
||||||
|
sort = env.params.body["sort"]?.try &.as(String)
|
||||||
|
sort ||= DEFAULT_USER_PREFERENCES.sort
|
||||||
|
|
||||||
|
latest_only = env.params.body["latest_only"]?.try &.as(String)
|
||||||
|
latest_only ||= "off"
|
||||||
|
latest_only = latest_only == "on"
|
||||||
|
|
||||||
|
unseen_only = env.params.body["unseen_only"]?.try &.as(String)
|
||||||
|
unseen_only ||= "off"
|
||||||
|
unseen_only = unseen_only == "on"
|
||||||
|
|
||||||
|
notifications_only = env.params.body["notifications_only"]?.try &.as(String)
|
||||||
|
notifications_only ||= "off"
|
||||||
|
notifications_only = notifications_only == "on"
|
||||||
|
|
||||||
|
preferences = {
|
||||||
|
"video_loop" => video_loop,
|
||||||
|
"autoplay" => autoplay,
|
||||||
|
"continue" => continue,
|
||||||
|
"listen" => listen,
|
||||||
|
"speed" => speed,
|
||||||
|
"quality" => quality,
|
||||||
|
"volume" => volume,
|
||||||
|
"comments" => comments,
|
||||||
|
"captions" => captions,
|
||||||
|
"related_videos" => related_videos,
|
||||||
|
"redirect_feed" => redirect_feed,
|
||||||
|
"locale" => locale,
|
||||||
|
"dark_mode" => dark_mode,
|
||||||
|
"thin_mode" => thin_mode,
|
||||||
|
"max_results" => max_results,
|
||||||
|
"sort" => sort,
|
||||||
|
"latest_only" => latest_only,
|
||||||
|
"unseen_only" => unseen_only,
|
||||||
|
"notifications_only" => notifications_only,
|
||||||
|
}.to_json
|
||||||
|
|
||||||
|
if user = env.get? "user"
|
||||||
user = user.as(User)
|
user = user.as(User)
|
||||||
|
|
||||||
video_loop = env.params.body["video_loop"]?.try &.as(String)
|
|
||||||
video_loop ||= "off"
|
|
||||||
video_loop = video_loop == "on"
|
|
||||||
|
|
||||||
autoplay = env.params.body["autoplay"]?.try &.as(String)
|
|
||||||
autoplay ||= "off"
|
|
||||||
autoplay = autoplay == "on"
|
|
||||||
|
|
||||||
continue = env.params.body["continue"]?.try &.as(String)
|
|
||||||
continue ||= "off"
|
|
||||||
continue = continue == "on"
|
|
||||||
|
|
||||||
listen = env.params.body["listen"]?.try &.as(String)
|
|
||||||
listen ||= "off"
|
|
||||||
listen = listen == "on"
|
|
||||||
|
|
||||||
speed = env.params.body["speed"]?.try &.as(String).to_f?
|
|
||||||
speed ||= DEFAULT_USER_PREFERENCES.speed
|
|
||||||
|
|
||||||
quality = env.params.body["quality"]?.try &.as(String)
|
|
||||||
quality ||= DEFAULT_USER_PREFERENCES.quality
|
|
||||||
|
|
||||||
volume = env.params.body["volume"]?.try &.as(String).to_i?
|
|
||||||
volume ||= DEFAULT_USER_PREFERENCES.volume
|
|
||||||
|
|
||||||
comments_0 = env.params.body["comments_0"]?.try &.as(String) || DEFAULT_USER_PREFERENCES.comments[0]
|
|
||||||
comments_1 = env.params.body["comments_1"]?.try &.as(String) || DEFAULT_USER_PREFERENCES.comments[1]
|
|
||||||
comments = [comments_0, comments_1]
|
|
||||||
|
|
||||||
captions_0 = env.params.body["captions_0"]?.try &.as(String) || DEFAULT_USER_PREFERENCES.captions[0]
|
|
||||||
captions_1 = env.params.body["captions_1"]?.try &.as(String) || DEFAULT_USER_PREFERENCES.captions[1]
|
|
||||||
captions_2 = env.params.body["captions_2"]?.try &.as(String) || DEFAULT_USER_PREFERENCES.captions[2]
|
|
||||||
captions = [captions_0, captions_1, captions_2]
|
|
||||||
|
|
||||||
related_videos = env.params.body["related_videos"]?.try &.as(String)
|
|
||||||
related_videos ||= "off"
|
|
||||||
related_videos = related_videos == "on"
|
|
||||||
|
|
||||||
redirect_feed = env.params.body["redirect_feed"]?.try &.as(String)
|
|
||||||
redirect_feed ||= "off"
|
|
||||||
redirect_feed = redirect_feed == "on"
|
|
||||||
|
|
||||||
locale = env.params.body["locale"]?.try &.as(String)
|
|
||||||
locale ||= DEFAULT_USER_PREFERENCES.locale
|
|
||||||
|
|
||||||
dark_mode = env.params.body["dark_mode"]?.try &.as(String)
|
|
||||||
dark_mode ||= "off"
|
|
||||||
dark_mode = dark_mode == "on"
|
|
||||||
|
|
||||||
thin_mode = env.params.body["thin_mode"]?.try &.as(String)
|
|
||||||
thin_mode ||= "off"
|
|
||||||
thin_mode = thin_mode == "on"
|
|
||||||
|
|
||||||
max_results = env.params.body["max_results"]?.try &.as(String).to_i?
|
|
||||||
max_results ||= DEFAULT_USER_PREFERENCES.max_results
|
|
||||||
|
|
||||||
sort = env.params.body["sort"]?.try &.as(String)
|
|
||||||
sort ||= DEFAULT_USER_PREFERENCES.sort
|
|
||||||
|
|
||||||
latest_only = env.params.body["latest_only"]?.try &.as(String)
|
|
||||||
latest_only ||= "off"
|
|
||||||
latest_only = latest_only == "on"
|
|
||||||
|
|
||||||
unseen_only = env.params.body["unseen_only"]?.try &.as(String)
|
|
||||||
unseen_only ||= "off"
|
|
||||||
unseen_only = unseen_only == "on"
|
|
||||||
|
|
||||||
notifications_only = env.params.body["notifications_only"]?.try &.as(String)
|
|
||||||
notifications_only ||= "off"
|
|
||||||
notifications_only = notifications_only == "on"
|
|
||||||
|
|
||||||
preferences = {
|
|
||||||
"video_loop" => video_loop,
|
|
||||||
"autoplay" => autoplay,
|
|
||||||
"continue" => continue,
|
|
||||||
"listen" => listen,
|
|
||||||
"speed" => speed,
|
|
||||||
"quality" => quality,
|
|
||||||
"volume" => volume,
|
|
||||||
"comments" => comments,
|
|
||||||
"captions" => captions,
|
|
||||||
"related_videos" => related_videos,
|
|
||||||
"redirect_feed" => redirect_feed,
|
|
||||||
"locale" => locale,
|
|
||||||
"dark_mode" => dark_mode,
|
|
||||||
"thin_mode" => thin_mode,
|
|
||||||
"max_results" => max_results,
|
|
||||||
"sort" => sort,
|
|
||||||
"latest_only" => latest_only,
|
|
||||||
"unseen_only" => unseen_only,
|
|
||||||
"notifications_only" => notifications_only,
|
|
||||||
}.to_json
|
|
||||||
|
|
||||||
PG_DB.exec("UPDATE users SET preferences = $1 WHERE email = $2", preferences, user.email)
|
PG_DB.exec("UPDATE users SET preferences = $1 WHERE email = $2", preferences, user.email)
|
||||||
|
else
|
||||||
|
env.response.cookies["PREFS"] = preferences
|
||||||
end
|
end
|
||||||
|
|
||||||
env.redirect referer
|
env.redirect referer
|
||||||
|
@ -1195,21 +1233,24 @@ end
|
||||||
|
|
||||||
get "/toggle_theme" do |env|
|
get "/toggle_theme" do |env|
|
||||||
locale = LOCALES[env.get("locale").as(String)]?
|
locale = LOCALES[env.get("locale").as(String)]?
|
||||||
|
|
||||||
user = env.get? "user"
|
|
||||||
referer = get_referer(env)
|
referer = get_referer(env)
|
||||||
|
|
||||||
if user
|
if user = env.get? "user"
|
||||||
user = user.as(User)
|
user = user.as(User)
|
||||||
preferences = user.preferences
|
preferences = user.preferences
|
||||||
|
preferences.dark_mode = !preferences.dark_mode
|
||||||
if preferences.dark_mode
|
|
||||||
preferences.dark_mode = false
|
|
||||||
else
|
|
||||||
preferences.dark_mode = true
|
|
||||||
end
|
|
||||||
|
|
||||||
PG_DB.exec("UPDATE users SET preferences = $1 WHERE email = $2", preferences.to_json, user.email)
|
PG_DB.exec("UPDATE users SET preferences = $1 WHERE email = $2", preferences.to_json, user.email)
|
||||||
|
elsif preferences = env.get? "preferences"
|
||||||
|
preferences = preferences.as(Preferences)
|
||||||
|
preferences.dark_mode = !preferences.dark_mode
|
||||||
|
|
||||||
|
env.response.cookies["PREFS"] = preferences.to_json
|
||||||
|
else
|
||||||
|
preferences = DEFAULT_USER_PREFERENCES
|
||||||
|
preferences.dark_mode = true
|
||||||
|
|
||||||
|
env.response.cookies["PREFS"] = preferences.to_json
|
||||||
end
|
end
|
||||||
|
|
||||||
env.redirect referer
|
env.redirect referer
|
||||||
|
@ -4210,6 +4251,7 @@ add_handler FilteredCompressHandler.new
|
||||||
add_handler DenyFrame.new
|
add_handler DenyFrame.new
|
||||||
add_handler APIHandler.new
|
add_handler APIHandler.new
|
||||||
add_context_storage_type(User)
|
add_context_storage_type(User)
|
||||||
|
add_context_storage_type(Preferences)
|
||||||
|
|
||||||
Kemal.config.logger = logger
|
Kemal.config.logger = logger
|
||||||
Kemal.run
|
Kemal.run
|
||||||
|
|
|
@ -15,29 +15,29 @@ function update_value(element) {
|
||||||
|
|
||||||
<div class="pure-control-group">
|
<div class="pure-control-group">
|
||||||
<label for="video_loop"><%= translate(locale, "Always loop: ") %></label>
|
<label for="video_loop"><%= translate(locale, "Always loop: ") %></label>
|
||||||
<input name="video_loop" id="video_loop" type="checkbox" <% if user.preferences.video_loop %>checked<% end %>>
|
<input name="video_loop" id="video_loop" type="checkbox" <% if preferences.video_loop %>checked<% end %>>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="pure-control-group">
|
<div class="pure-control-group">
|
||||||
<label for="autoplay"><%= translate(locale, "Autoplay: ") %></label>
|
<label for="autoplay"><%= translate(locale, "Autoplay: ") %></label>
|
||||||
<input name="autoplay" id="autoplay" type="checkbox" <% if user.preferences.autoplay %>checked<% end %>>
|
<input name="autoplay" id="autoplay" type="checkbox" <% if preferences.autoplay %>checked<% end %>>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="pure-control-group">
|
<div class="pure-control-group">
|
||||||
<label for="continue"><%= translate(locale, "Autoplay next video: ") %></label>
|
<label for="continue"><%= translate(locale, "Autoplay next video: ") %></label>
|
||||||
<input name="continue" id="continue" type="checkbox" <% if user.preferences.continue %>checked<% end %>>
|
<input name="continue" id="continue" type="checkbox" <% if preferences.continue %>checked<% end %>>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="pure-control-group">
|
<div class="pure-control-group">
|
||||||
<label for="listen"><%= translate(locale, "Listen by default: ") %></label>
|
<label for="listen"><%= translate(locale, "Listen by default: ") %></label>
|
||||||
<input name="listen" id="listen" type="checkbox" <% if user.preferences.listen %>checked<% end %>>
|
<input name="listen" id="listen" type="checkbox" <% if preferences.listen %>checked<% end %>>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="pure-control-group">
|
<div class="pure-control-group">
|
||||||
<label for="speed"><%= translate(locale, "Default speed: ") %></label>
|
<label for="speed"><%= translate(locale, "Default speed: ") %></label>
|
||||||
<select name="speed" id="speed">
|
<select name="speed" id="speed">
|
||||||
<% {2.0, 1.5, 1.0, 0.5}.each do |option| %>
|
<% {2.0, 1.5, 1.0, 0.5}.each do |option| %>
|
||||||
<option <% if user.preferences.speed == option %> selected <% end %>><%= option %></option>
|
<option <% if preferences.speed == option %> selected <% end %>><%= option %></option>
|
||||||
<% end %>
|
<% end %>
|
||||||
</select>
|
</select>
|
||||||
</div>
|
</div>
|
||||||
|
@ -46,22 +46,22 @@ function update_value(element) {
|
||||||
<label for="quality"><%= translate(locale, "Preferred video quality: ") %></label>
|
<label for="quality"><%= translate(locale, "Preferred video quality: ") %></label>
|
||||||
<select name="quality" id="quality">
|
<select name="quality" id="quality">
|
||||||
<% {"dash", "hd720", "medium", "small"}.each do |option| %>
|
<% {"dash", "hd720", "medium", "small"}.each do |option| %>
|
||||||
<option value="<%= option %>" <% if user.preferences.quality == option %> selected <% end %>><%= translate(locale, option) %></option>
|
<option value="<%= option %>" <% if preferences.quality == option %> selected <% end %>><%= translate(locale, option) %></option>
|
||||||
<% end %>
|
<% end %>
|
||||||
</select>
|
</select>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="pure-control-group">
|
<div class="pure-control-group">
|
||||||
<label for="volume"><%= translate(locale, "Player volume: ") %></label>
|
<label for="volume"><%= translate(locale, "Player volume: ") %></label>
|
||||||
<input name="volume" id="volume" oninput="update_value(this);" type="range" min="0" max="100" step="5" value="<%= user.preferences.volume %>">
|
<input name="volume" id="volume" oninput="update_value(this);" type="range" min="0" max="100" step="5" value="<%= preferences.volume %>">
|
||||||
<span class="pure-form-message-inline" id="volume-value"><%= user.preferences.volume %></span>
|
<span class="pure-form-message-inline" id="volume-value"><%= preferences.volume %></span>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="pure-control-group">
|
<div class="pure-control-group">
|
||||||
<label for="comments_0"><%= translate(locale, "Default comments: ") %></label>
|
<label for="comments_0"><%= translate(locale, "Default comments: ") %></label>
|
||||||
<select name="comments_0" id="comments_0">
|
<select name="comments_0" id="comments_0">
|
||||||
<% {"", "youtube", "reddit"}.each do |option| %>
|
<% {"", "youtube", "reddit"}.each do |option| %>
|
||||||
<option value="<%= option %>" <% if user.preferences.comments[0] == option %> selected <% end %>><%= translate(locale, option) %></option>
|
<option value="<%= option %>" <% if preferences.comments[0] == option %> selected <% end %>><%= translate(locale, option) %></option>
|
||||||
<% end %>
|
<% end %>
|
||||||
</select>
|
</select>
|
||||||
</div>
|
</div>
|
||||||
|
@ -70,7 +70,7 @@ function update_value(element) {
|
||||||
<label for="comments_1"><%= translate(locale, "Fallback comments: ") %></label>
|
<label for="comments_1"><%= translate(locale, "Fallback comments: ") %></label>
|
||||||
<select name="comments_1" id="comments_1">
|
<select name="comments_1" id="comments_1">
|
||||||
<% {"", "youtube", "reddit"}.each do |option| %>
|
<% {"", "youtube", "reddit"}.each do |option| %>
|
||||||
<option value="<%= option %>" <% if user.preferences.comments[1] == option %> selected <% end %>><%= translate(locale, option) %></option>
|
<option value="<%= option %>" <% if preferences.comments[1] == option %> selected <% end %>><%= translate(locale, option) %></option>
|
||||||
<% end %>
|
<% end %>
|
||||||
</select>
|
</select>
|
||||||
</div>
|
</div>
|
||||||
|
@ -79,7 +79,7 @@ function update_value(element) {
|
||||||
<label for="captions_0"><%= translate(locale, "Default captions: ") %></label>
|
<label for="captions_0"><%= translate(locale, "Default captions: ") %></label>
|
||||||
<select class="pure-u-1-5" name="captions_0" id="captions_0">
|
<select class="pure-u-1-5" name="captions_0" id="captions_0">
|
||||||
<% CAPTION_LANGUAGES.each do |option| %>
|
<% CAPTION_LANGUAGES.each do |option| %>
|
||||||
<option value="<%= option %>" <% if user.preferences.captions[0] == option %> selected <% end %>><%= translate(locale, option) %></option>
|
<option value="<%= option %>" <% if preferences.captions[0] == option %> selected <% end %>><%= translate(locale, option) %></option>
|
||||||
<% end %>
|
<% end %>
|
||||||
</select>
|
</select>
|
||||||
</div>
|
</div>
|
||||||
|
@ -88,20 +88,20 @@ function update_value(element) {
|
||||||
<label for="captions_fallback"><%= translate(locale, "Fallback captions: ") %></label>
|
<label for="captions_fallback"><%= translate(locale, "Fallback captions: ") %></label>
|
||||||
<select class="pure-u-1-5" name="captions_1" id="captions_1">
|
<select class="pure-u-1-5" name="captions_1" id="captions_1">
|
||||||
<% CAPTION_LANGUAGES.each do |option| %>
|
<% CAPTION_LANGUAGES.each do |option| %>
|
||||||
<option value="<%= option %>" <% if user.preferences.captions[1] == option %> selected <% end %>><%= translate(locale, option) %></option>
|
<option value="<%= option %>" <% if preferences.captions[1] == option %> selected <% end %>><%= translate(locale, option) %></option>
|
||||||
<% end %>
|
<% end %>
|
||||||
</select>
|
</select>
|
||||||
|
|
||||||
<select class="pure-u-1-5" name="captions_2" id="captions_2">
|
<select class="pure-u-1-5" name="captions_2" id="captions_2">
|
||||||
<% CAPTION_LANGUAGES.each do |option| %>
|
<% CAPTION_LANGUAGES.each do |option| %>
|
||||||
<option value="<%= option %>" <% if user.preferences.captions[2] == option %> selected <% end %>><%= translate(locale, option) %></option>
|
<option value="<%= option %>" <% if preferences.captions[2] == option %> selected <% end %>><%= translate(locale, option) %></option>
|
||||||
<% end %>
|
<% end %>
|
||||||
</select>
|
</select>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="pure-control-group">
|
<div class="pure-control-group">
|
||||||
<label for="related_videos"><%= translate(locale, "Show related videos? ") %></label>
|
<label for="related_videos"><%= translate(locale, "Show related videos? ") %></label>
|
||||||
<input name="related_videos" id="related_videos" type="checkbox" <% if user.preferences.related_videos %>checked<% end %>>
|
<input name="related_videos" id="related_videos" type="checkbox" <% if preferences.related_videos %>checked<% end %>>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<legend><%= translate(locale, "Visual preferences") %></legend>
|
<legend><%= translate(locale, "Visual preferences") %></legend>
|
||||||
|
@ -110,61 +110,64 @@ function update_value(element) {
|
||||||
<label for="locale"><%= translate(locale, "Language: ") %></label>
|
<label for="locale"><%= translate(locale, "Language: ") %></label>
|
||||||
<select name="locale" id="locale">
|
<select name="locale" id="locale">
|
||||||
<% LOCALES.each_key do |option| %>
|
<% LOCALES.each_key do |option| %>
|
||||||
<option value="<%= option %>" <% if user.preferences.locale == option %> selected <% end %>><%= option %></option>
|
<option value="<%= option %>" <% if preferences.locale == option %> selected <% end %>><%= option %></option>
|
||||||
<% end %>
|
<% end %>
|
||||||
</select>
|
</select>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="pure-control-group">
|
<div class="pure-control-group">
|
||||||
<label for="dark_mode"><%= translate(locale, "Dark mode: ") %></label>
|
<label for="dark_mode"><%= translate(locale, "Dark mode: ") %></label>
|
||||||
<input name="dark_mode" id="dark_mode" type="checkbox" <% if user.preferences.dark_mode %>checked<% end %>>
|
<input name="dark_mode" id="dark_mode" type="checkbox" <% if preferences.dark_mode %>checked<% end %>>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="pure-control-group">
|
<div class="pure-control-group">
|
||||||
<label for="thin_mode"><%= translate(locale, "Thin mode: ") %></label>
|
<label for="thin_mode"><%= translate(locale, "Thin mode: ") %></label>
|
||||||
<input name="thin_mode" id="thin_mode" type="checkbox" <% if user.preferences.thin_mode %>checked<% end %>>
|
<input name="thin_mode" id="thin_mode" type="checkbox" <% if preferences.thin_mode %>checked<% end %>>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<% if env.get? "user" %>
|
||||||
<legend><%= translate(locale, "Subscription preferences") %></legend>
|
<legend><%= translate(locale, "Subscription preferences") %></legend>
|
||||||
|
|
||||||
<div class="pure-control-group">
|
<div class="pure-control-group">
|
||||||
<label for="redirect_feed"><%= translate(locale, "Redirect homepage to feed: ") %></label>
|
<label for="redirect_feed"><%= translate(locale, "Redirect homepage to feed: ") %></label>
|
||||||
<input name="redirect_feed" id="redirect_feed" type="checkbox" <% if user.preferences.redirect_feed %>checked<% end %>>
|
<input name="redirect_feed" id="redirect_feed" type="checkbox" <% if preferences.redirect_feed %>checked<% end %>>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="pure-control-group">
|
<div class="pure-control-group">
|
||||||
<label for="max_results"><%= translate(locale, "Number of videos shown in feed: ") %></label>
|
<label for="max_results"><%= translate(locale, "Number of videos shown in feed: ") %></label>
|
||||||
<input name="max_results" id="max_results" type="number" value="<%= user.preferences.max_results %>">
|
<input name="max_results" id="max_results" type="number" value="<%= preferences.max_results %>">
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="pure-control-group">
|
<div class="pure-control-group">
|
||||||
<label for="sort"><%= translate(locale, "Sort videos by: ") %></label>
|
<label for="sort"><%= translate(locale, "Sort videos by: ") %></label>
|
||||||
<select name="sort" id="sort">
|
<select name="sort" id="sort">
|
||||||
<% {"published", "published - reverse", "alphabetically", "alphabetically - reverse", "channel name", "channel name - reverse"}.each do |option| %>
|
<% {"published", "published - reverse", "alphabetically", "alphabetically - reverse", "channel name", "channel name - reverse"}.each do |option| %>
|
||||||
<option value="<%= option %>" <% if user.preferences.sort == option %> selected <% end %>><%= translate(locale, option) %></option>
|
<option value="<%= option %>" <% if preferences.sort == option %> selected <% end %>><%= translate(locale, option) %></option>
|
||||||
<% end %>
|
<% end %>
|
||||||
</select>
|
</select>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="pure-control-group">
|
<div class="pure-control-group">
|
||||||
<% if user.preferences.unseen_only %>
|
<% if preferences.unseen_only %>
|
||||||
<label for="latest_only"><%= translate(locale, "Only show latest unwatched video from channel: ") %></label>
|
<label for="latest_only"><%= translate(locale, "Only show latest unwatched video from channel: ") %></label>
|
||||||
<% else %>
|
<% else %>
|
||||||
<label for="latest_only"><%= translate(locale, "Only show latest video from channel: ") %></label>
|
<label for="latest_only"><%= translate(locale, "Only show latest video from channel: ") %></label>
|
||||||
<% end %>
|
<% end %>
|
||||||
<input name="latest_only" id="latest_only" type="checkbox" <% if user.preferences.latest_only %>checked<% end %>>
|
<input name="latest_only" id="latest_only" type="checkbox" <% if preferences.latest_only %>checked<% end %>>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="pure-control-group">
|
<div class="pure-control-group">
|
||||||
<label for="unseen_only"><%= translate(locale, "Only show unwatched: ") %></label>
|
<label for="unseen_only"><%= translate(locale, "Only show unwatched: ") %></label>
|
||||||
<input name="unseen_only" id="unseen_only" type="checkbox" <% if user.preferences.unseen_only %>checked<% end %>>
|
<input name="unseen_only" id="unseen_only" type="checkbox" <% if preferences.unseen_only %>checked<% end %>>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="pure-control-group">
|
<div class="pure-control-group">
|
||||||
<label for="notifications_only"><%= translate(locale, "Only show notifications (if there are any): ") %></label>
|
<label for="notifications_only"><%= translate(locale, "Only show notifications (if there are any): ") %></label>
|
||||||
<input name="notifications_only" id="notifications_only" type="checkbox" <% if user.preferences.notifications_only %>checked<% end %>>
|
<input name="notifications_only" id="notifications_only" type="checkbox" <% if preferences.notifications_only %>checked<% end %>>
|
||||||
</div>
|
</div>
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
<% if env.get? "user" %>
|
||||||
<legend><%= translate(locale, "Data preferences") %></legend>
|
<legend><%= translate(locale, "Data preferences") %></legend>
|
||||||
|
|
||||||
<div class="pure-control-group">
|
<div class="pure-control-group">
|
||||||
|
@ -186,6 +189,7 @@ function update_value(element) {
|
||||||
<div class="pure-control-group">
|
<div class="pure-control-group">
|
||||||
<a href="/delete_account?referer=<%= URI.escape(referer) %>"><%= translate(locale, "Delete account") %></a>
|
<a href="/delete_account?referer=<%= URI.escape(referer) %>"><%= translate(locale, "Delete account") %></a>
|
||||||
</div>
|
</div>
|
||||||
|
<% end %>
|
||||||
|
|
||||||
<div class="pure-controls">
|
<div class="pure-controls">
|
||||||
<button type="submit" class="pure-button pure-button-primary"><%= translate(locale, "Save preferences") %></button>
|
<button type="submit" class="pure-button pure-button-primary"><%= translate(locale, "Save preferences") %></button>
|
||||||
|
|
|
@ -18,7 +18,7 @@
|
||||||
<link rel="stylesheet" href="/css/grids-responsive-min.css">
|
<link rel="stylesheet" href="/css/grids-responsive-min.css">
|
||||||
<link rel="stylesheet" href="/css/ionicons.min.css">
|
<link rel="stylesheet" href="/css/ionicons.min.css">
|
||||||
<link rel="stylesheet" href="/css/default.css">
|
<link rel="stylesheet" href="/css/default.css">
|
||||||
<% if env.get?("user") && env.get("user").as(User).preferences.dark_mode %>
|
<% if env.get?("preferences").try &.as(Preferences).dark_mode %>
|
||||||
<link rel="stylesheet" href="/css/darktheme.css">
|
<link rel="stylesheet" href="/css/darktheme.css">
|
||||||
<% else %>
|
<% else %>
|
||||||
<link rel="stylesheet" href="/css/lighttheme.css">
|
<link rel="stylesheet" href="/css/lighttheme.css">
|
||||||
|
@ -75,9 +75,25 @@
|
||||||
</a>
|
</a>
|
||||||
</div>
|
</div>
|
||||||
<% else %>
|
<% else %>
|
||||||
|
<div class="pure-u-1-3">
|
||||||
|
<a href="/toggle_theme?referer=<%= env.get?("current_page") %>" class="pure-menu-heading">
|
||||||
|
<% if env.get?("preferences").try &.as(Preferences).dark_mode %>
|
||||||
|
<i class="icon ion-ios-sunny"></i>
|
||||||
|
<% else %>
|
||||||
|
<i class="icon ion-ios-moon"></i>
|
||||||
|
<% end %>
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
<div class="pure-u-1-3">
|
||||||
|
<a href="/preferences?referer=<%= env.get?("current_page") %>" class="pure-menu-heading">
|
||||||
|
<i class="icon ion-ios-cog"></i>
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
<div class="pure-u-1-3">
|
||||||
<a href="/login?referer=<%= env.get?("current_page") %>" class="pure-menu-heading">
|
<a href="/login?referer=<%= env.get?("current_page") %>" class="pure-menu-heading">
|
||||||
<%= translate(locale, "Login") %>
|
<%= translate(locale, "Login") %>
|
||||||
</a>
|
</a>
|
||||||
|
</div>
|
||||||
<% end %>
|
<% end %>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
Loading…
Reference in a new issue