mirror of
				https://gitea.invidious.io/iv-org/invidious.git
				synced 2024-08-15 00:53:41 +00:00 
			
		
		
		
	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…
	
	Add table
		Add a link
		
	
		Reference in a new issue