mirror of
				https://github.com/iv-org/invidious.git
				synced 2025-10-26 02:38:30 -05:00 
			
		
		
		
	Move options lists to constants under 'Preferences'
Also fix the lists for the homepage and feeds. They have to be different (e.g Search is not a feed, but a valid homepage)
This commit is contained in:
		
							parent
							
								
									faa66aba51
								
							
						
					
					
						commit
						8aaa66c252
					
				| @ -2,6 +2,43 @@ struct Preferences | |||||||
|   include JSON::Serializable |   include JSON::Serializable | ||||||
|   include YAML::Serializable |   include YAML::Serializable | ||||||
| 
 | 
 | ||||||
|  |   # ------------------- | ||||||
|  |   #  Constants | ||||||
|  |   # ------------------- | ||||||
|  | 
 | ||||||
|  |   SPEEDS = {2.0, 1.75, 1.5, 1.25, 1.0, 0.75, 0.5, 0.25} | ||||||
|  | 
 | ||||||
|  |   QUALITIES = {"dash", "hd720", "medium", "small"} | ||||||
|  | 
 | ||||||
|  |   DASH_QUALITIES = { | ||||||
|  |     "auto", "best", "4320p", "2160p", "1440p", "1080p", | ||||||
|  |     "720p", "480p", "360p", "240p", "144p", "worst", | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   COMMENT_SOURCES = {"none", "youtube", "reddit"} | ||||||
|  | 
 | ||||||
|  |   THEMES        = {"auto", "light", "dark"} | ||||||
|  |   PLAYER_STYLES = {"invidious", "youtube"} | ||||||
|  | 
 | ||||||
|  |   FEED_OPTIONS      = {"none", "Popular", "trending"} | ||||||
|  |   FEED_OPTIONS_USER = {"none", "Popular", "trending", "Subscriptions", "Playlists"} | ||||||
|  | 
 | ||||||
|  |   HOMEPAGES      = {"Search", "Popular", "trending"} | ||||||
|  |   HOMEPAGES_USER = {"Search", "Popular", "trending", "Subscriptions", "Playlists"} | ||||||
|  | 
 | ||||||
|  |   SORT_OPTIONS = { | ||||||
|  |     "published", | ||||||
|  |     "published - reverse", | ||||||
|  |     "alphabetically", | ||||||
|  |     "alphabetically - reverse", | ||||||
|  |     "channel name", | ||||||
|  |     "channel name - reverse", | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   # ------------------- | ||||||
|  |   #  Properties | ||||||
|  |   # ------------------- | ||||||
|  | 
 | ||||||
|   property annotations : Bool = CONFIG.default_user_preferences.annotations |   property annotations : Bool = CONFIG.default_user_preferences.annotations | ||||||
|   property annotations_subscribed : Bool = CONFIG.default_user_preferences.annotations_subscribed |   property annotations_subscribed : Bool = CONFIG.default_user_preferences.annotations_subscribed | ||||||
|   property autoplay : Bool = CONFIG.default_user_preferences.autoplay |   property autoplay : Bool = CONFIG.default_user_preferences.autoplay | ||||||
| @ -56,6 +93,10 @@ struct Preferences | |||||||
|   property volume : Int32 = CONFIG.default_user_preferences.volume |   property volume : Int32 = CONFIG.default_user_preferences.volume | ||||||
|   property save_player_pos : Bool = CONFIG.default_user_preferences.save_player_pos |   property save_player_pos : Bool = CONFIG.default_user_preferences.save_player_pos | ||||||
| 
 | 
 | ||||||
|  |   # ------------------- | ||||||
|  |   #  Converter modules | ||||||
|  |   # ------------------- | ||||||
|  | 
 | ||||||
|   module BoolToString |   module BoolToString | ||||||
|     def self.to_json(value : String, json : JSON::Builder) |     def self.to_json(value : String, json : JSON::Builder) | ||||||
|       json.string value |       json.string value | ||||||
|  | |||||||
| @ -40,20 +40,20 @@ | |||||||
|             <div class="pure-control-group"> |             <div class="pure-control-group"> | ||||||
|                 <label for="speed"><%= translate(locale, "preferences_speed_label") %></label> |                 <label for="speed"><%= translate(locale, "preferences_speed_label") %></label> | ||||||
|                 <select name="speed" id="speed"> |                 <select name="speed" id="speed"> | ||||||
|                     <% {2.0, 1.75, 1.5, 1.25, 1.0, 0.75, 0.5, 0.25}.each do |option| %> |                     <%- Preferences::SPEEDS.each do |option| -%> | ||||||
|                         <option <% if preferences.speed == option %> selected <% end %>><%= option %></option> |                         <option <% if preferences.speed == option %> selected <% end %>><%= option %></option> | ||||||
|                     <% end %> |                     <%- end -%> | ||||||
|                 </select> |                 </select> | ||||||
|             </div> |             </div> | ||||||
| 
 | 
 | ||||||
|             <div class="pure-control-group"> |             <div class="pure-control-group"> | ||||||
|                 <label for="quality"><%= translate(locale, "preferences_quality_label") %></label> |                 <label for="quality"><%= translate(locale, "preferences_quality_label") %></label> | ||||||
|                 <select name="quality" id="quality"> |                 <select name="quality" id="quality"> | ||||||
|                     <% {"dash", "hd720", "medium", "small"}.each do |option| %> |                     <%- Preferences::QUALITIES.each do |option| -%> | ||||||
|                         <% if !(option == "dash" && CONFIG.disabled?("dash")) %> |                         <%- if !(option == "dash" && CONFIG.disabled?("dash")) -%> | ||||||
|                             <option value="<%= option %>" <% if preferences.quality == option %> selected <% end %>><%= translate(locale, "preferences_quality_option_" + option) %></option> |                             <option value="<%= option %>" <% if preferences.quality == option %> selected <% end %>><%= translate(locale, "preferences_quality_option_" + option) %></option> | ||||||
|                         <% end %> |                         <%- end -%> | ||||||
|                     <% end %> |                     <%- end -%> | ||||||
|                 </select> |                 </select> | ||||||
|             </div> |             </div> | ||||||
| 
 | 
 | ||||||
| @ -61,9 +61,9 @@ | |||||||
|                 <div class="pure-control-group"> |                 <div class="pure-control-group"> | ||||||
|                     <label for="quality_dash"><%= translate(locale, "preferences_quality_dash_label") %></label> |                     <label for="quality_dash"><%= translate(locale, "preferences_quality_dash_label") %></label> | ||||||
|                     <select name="quality_dash" id="quality_dash"> |                     <select name="quality_dash" id="quality_dash"> | ||||||
|                         <% {"auto", "best", "4320p", "2160p", "1440p", "1080p", "720p", "480p", "360p", "240p", "144p", "worst"}.each do |option| %> |                         <%- Preferences::DASH_QUALITIES.each do |option| -%> | ||||||
|                             <option value="<%= option %>" <% if preferences.quality_dash == option %> selected <% end %>><%= translate(locale, "preferences_quality_dash_option_" + option) %></option> |                             <option value="<%= option %>" <% if preferences.quality_dash == option %> selected <% end %>><%= translate(locale, "preferences_quality_dash_option_" + option) %></option> | ||||||
|                         <% end %> |                         <%- end -%> | ||||||
|                     </select> |                     </select> | ||||||
|                 </div> |                 </div> | ||||||
|             <% end %> |             <% end %> | ||||||
| @ -78,9 +78,9 @@ | |||||||
|                 <label for="comments[0]"><%= translate(locale, "preferences_comments_label") %></label> |                 <label for="comments[0]"><%= translate(locale, "preferences_comments_label") %></label> | ||||||
|                 <% preferences.comments.each_with_index do |comments, index| %> |                 <% preferences.comments.each_with_index do |comments, index| %> | ||||||
|                     <select name="comments[<%= index %>]" id="comments[<%= index %>]"> |                     <select name="comments[<%= index %>]" id="comments[<%= index %>]"> | ||||||
|                         <% {"", "youtube", "reddit"}.each do |option| %> |                         <%- Preferences::COMMENT_SOURCES.each do |option| -%> | ||||||
|                             <option value="<%= option %>" <% if preferences.comments[index] == option %> selected <% end %>><%= translate(locale, option.blank? ? "none" : option) %></option> |                             <option value="<%= option %>" <% if preferences.comments[index] == option %> selected <% end %>><%= translate(locale, option) %></option> | ||||||
|                         <% end %> |                         <%- end -%> | ||||||
|                     </select> |                     </select> | ||||||
|                 <% end %> |                 <% end %> | ||||||
|             </div> |             </div> | ||||||
| @ -144,18 +144,18 @@ | |||||||
|             <div class="pure-control-group"> |             <div class="pure-control-group"> | ||||||
|                 <label for="player_style"><%= translate(locale, "preferences_player_style_label") %></label> |                 <label for="player_style"><%= translate(locale, "preferences_player_style_label") %></label> | ||||||
|                 <select name="player_style" id="player_style"> |                 <select name="player_style" id="player_style"> | ||||||
|                     <% {"invidious", "youtube"}.each do |option| %> |                     <%- Preferences::PLAYER_STYLES.each do |option| -%> | ||||||
|                         <option value="<%= option %>" <% if preferences.player_style == option %> selected <% end %>><%= translate(locale, option) %></option> |                         <option value="<%= option %>" <% if preferences.player_style == 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="dark_mode"><%= translate(locale, "preferences_dark_mode_label") %></label> |                 <label for="dark_mode"><%= translate(locale, "preferences_dark_mode_label") %></label> | ||||||
|                 <select name="dark_mode" id="dark_mode"> |                 <select name="dark_mode" id="dark_mode"> | ||||||
|                     <% {"", "light", "dark"}.each do |option| %> |                     <%- Preferences::THEMES.each do |option| -%> | ||||||
|                         <option value="<%= option %>" <% if preferences.dark_mode == option %> selected <% end %>><%= translate(locale, option.blank? ? "auto" : option) %></option> |                         <option value="<%= option %>" <% if preferences.dark_mode == option %> selected <% end %>><%= translate(locale, option) %></option> | ||||||
|                     <% end %> |                     <%- end -%> | ||||||
|                 </select> |                 </select> | ||||||
|             </div> |             </div> | ||||||
| 
 | 
 | ||||||
| @ -164,30 +164,34 @@ | |||||||
|                 <input name="thin_mode" id="thin_mode" type="checkbox" <% if 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") %> |             <%- | ||||||
|                 <% feed_options = {"", "Popular", "Trending", "Subscriptions", "Playlists"} %> |               if env.get?("user") | ||||||
|             <% else %> |                 feed_options = Preferences::FEED_OPTIONS_USER | ||||||
|                 <% feed_options = {"", "Popular", "Trending"} %> |                 homepages = Preferences::HOMEPAGES_USER | ||||||
|             <% end %> |               else | ||||||
|  |                 feed_options = Preferences::FEED_OPTIONS | ||||||
|  |                 homepages = Preferences::HOMEPAGES | ||||||
|  |               end | ||||||
|  |             -%> | ||||||
| 
 | 
 | ||||||
|             <div class="pure-control-group"> |             <div class="pure-control-group"> | ||||||
|                 <label for="default_home"><%= translate(locale, "preferences_default_home_label") %></label> |                 <label for="default_home"><%= translate(locale, "preferences_default_home_label") %></label> | ||||||
|                 <select name="default_home" id="default_home"> |                 <select name="default_home" id="default_home"> | ||||||
|                     <% feed_options.each do |option| %> |                     <%- homepages.each do |option| -%> | ||||||
|                         <option value="<%= option %>" <% if preferences.default_home == option %> selected <% end %>><%= translate(locale, option.blank? ? "Search" : option) %></option> |                         <option value="<%= option %>" <% if preferences.default_home == 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="feed_menu"><%= translate(locale, "preferences_feed_menu_label") %></label> |                 <label for="feed_menu"><%= translate(locale, "preferences_feed_menu_label") %></label> | ||||||
|                 <% (feed_options.size - 1).times do |index| %> |                 <%- (feed_options.size - 1).times do |index| -%> | ||||||
|                     <select name="feed_menu[<%= index %>]" id="feed_menu[<%= index %>]"> |                     <select name="feed_menu[<%= index %>]" id="feed_menu[<%= index %>]"> | ||||||
|                         <% feed_options.each do |option| %> |                         <%- feed_options.each do |option| -%> | ||||||
|                             <option value="<%= option %>" <% if preferences.feed_menu[index]? == option %> selected <% end %>><%= translate(locale, option.blank? ? "Search" : option) %></option> |                             <option value="<%= option %>" <% if preferences.feed_menu[index]? == option %> selected <% end %>><%= translate(locale, option) %></option> | ||||||
|                         <% end %> |                         <%- end -%> | ||||||
|                     </select> |                     </select> | ||||||
|                 <% end %> |                 <%- end -%> | ||||||
|             </div> |             </div> | ||||||
|             <% if env.get? "user" %> |             <% if env.get? "user" %> | ||||||
|                 <div class="pure-control-group"> |                 <div class="pure-control-group"> | ||||||
| @ -224,9 +228,9 @@ | |||||||
|                 <div class="pure-control-group"> |                 <div class="pure-control-group"> | ||||||
|                     <label for="sort"><%= translate(locale, "preferences_sort_label") %></label> |                     <label for="sort"><%= translate(locale, "preferences_sort_label") %></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| %> |                         <%- Preferences::SORT_OPTIONS.each do |option| -%> | ||||||
|                             <option value="<%= option %>" <% if 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> | ||||||
| 
 | 
 | ||||||
| @ -265,21 +269,21 @@ | |||||||
|                 <div class="pure-control-group"> |                 <div class="pure-control-group"> | ||||||
|                     <label for="admin_default_home"><%= translate(locale, "preferences_default_home_label") %></label> |                     <label for="admin_default_home"><%= translate(locale, "preferences_default_home_label") %></label> | ||||||
|                     <select name="admin_default_home" id="admin_default_home"> |                     <select name="admin_default_home" id="admin_default_home"> | ||||||
|                         <% feed_options.each do |option| %> |                         <%- homepages.each do |option| -%> | ||||||
|                             <option value="<%= option %>" <% if CONFIG.default_user_preferences.default_home == option %> selected <% end %>><%= translate(locale, option.blank? ? "none" : option) %></option> |                             <option value="<%= option %>" <% if CONFIG.default_user_preferences.default_home == 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="admin_feed_menu"><%= translate(locale, "preferences_feed_menu_label") %></label> |                     <label for="admin_feed_menu"><%= translate(locale, "preferences_feed_menu_label") %></label> | ||||||
|                     <% (feed_options.size - 1).times do |index| %> |                     <%- (feed_options.size - 1).times do |index| -%> | ||||||
|                         <select name="admin_feed_menu[<%= index %>]" id="admin_feed_menu[<%= index %>]"> |                         <select name="admin_feed_menu[<%= index %>]" id="admin_feed_menu[<%= index %>]"> | ||||||
|                             <% feed_options.each do |option| %> |                             <%- feed_options.each do |option| -%> | ||||||
|                                 <option value="<%= option %>" <% if CONFIG.default_user_preferences.feed_menu[index]? == option %> selected <% end %>><%= translate(locale, option.blank? ? "none" : option) %></option> |                                 <option value="<%= option %>" <% if CONFIG.default_user_preferences.feed_menu[index]? == option %> selected <% end %>><%= translate(locale, option) %></option> | ||||||
|                             <% end %> |                             <%- end -%> | ||||||
|                         </select> |                         </select> | ||||||
|                     <% end %> |                     <%- end -%> | ||||||
|                 </div> |                 </div> | ||||||
| 
 | 
 | ||||||
|                 <div class="pure-control-group"> |                 <div class="pure-control-group"> | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user