mirror of
				https://github.com/iv-org/invidious.git
				synced 2025-10-24 17:58:30 -05:00 
			
		
		
		
	Routes: Simplify actions in subscription_ajax
This commit is contained in:
		
							parent
							
								
									7e4b3b182a
								
							
						
					
					
						commit
						e453a2a682
					
				| @ -111,7 +111,7 @@ | |||||||
|         var count = document.getElementById('count'); |         var count = document.getElementById('count'); | ||||||
|         count.textContent--; |         count.textContent--; | ||||||
| 
 | 
 | ||||||
|         var url = '/subscription_ajax?action_remove_subscriptions=1&redirect=false' + |         var url = '/subscription_ajax?action=remove_subscriptions&redirect=false' + | ||||||
|             '&referer=' + encodeURIComponent(location.href) + |             '&referer=' + encodeURIComponent(location.href) + | ||||||
|             '&c=' + target.getAttribute('data-ucid'); |             '&c=' + target.getAttribute('data-ucid'); | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -16,7 +16,7 @@ function subscribe() { | |||||||
|     subscribe_button.onclick = unsubscribe; |     subscribe_button.onclick = unsubscribe; | ||||||
|     subscribe_button.innerHTML = '<b>' + subscribe_data.unsubscribe_text + ' | ' + subscribe_data.sub_count_text + '</b>'; |     subscribe_button.innerHTML = '<b>' + subscribe_data.unsubscribe_text + ' | ' + subscribe_data.sub_count_text + '</b>'; | ||||||
| 
 | 
 | ||||||
|     var url = '/subscription_ajax?action_create_subscription_to_channel=1&redirect=false' + |     var url = '/subscription_ajax?action=create_subscription_to_channel&redirect=false' + | ||||||
|         '&c=' + subscribe_data.ucid; |         '&c=' + subscribe_data.ucid; | ||||||
| 
 | 
 | ||||||
|     helpers.xhr('POST', url, {payload: payload, retries: 5, entity_name: 'subscribe request'}, { |     helpers.xhr('POST', url, {payload: payload, retries: 5, entity_name: 'subscribe request'}, { | ||||||
| @ -32,7 +32,7 @@ function unsubscribe() { | |||||||
|     subscribe_button.onclick = subscribe; |     subscribe_button.onclick = subscribe; | ||||||
|     subscribe_button.innerHTML = '<b>' + subscribe_data.subscribe_text + ' | ' + subscribe_data.sub_count_text + '</b>'; |     subscribe_button.innerHTML = '<b>' + subscribe_data.subscribe_text + ' | ' + subscribe_data.sub_count_text + '</b>'; | ||||||
| 
 | 
 | ||||||
|     var url = '/subscription_ajax?action_remove_subscriptions=1&redirect=false' + |     var url = '/subscription_ajax?action=remove_subscriptions&redirect=false' + | ||||||
|         '&c=' + subscribe_data.ucid; |         '&c=' + subscribe_data.ucid; | ||||||
| 
 | 
 | ||||||
|     helpers.xhr('POST', url, {payload: payload, retries: 5, entity_name: 'unsubscribe request'}, { |     helpers.xhr('POST', url, {payload: payload, retries: 5, entity_name: 'unsubscribe request'}, { | ||||||
|  | |||||||
| @ -32,24 +32,16 @@ module Invidious::Routes::Subscriptions | |||||||
|       end |       end | ||||||
|     end |     end | ||||||
| 
 | 
 | ||||||
|     if env.params.query["action_create_subscription_to_channel"]?.try &.to_i?.try &.== 1 |  | ||||||
|       action = "action_create_subscription_to_channel" |  | ||||||
|     elsif env.params.query["action_remove_subscriptions"]?.try &.to_i?.try &.== 1 |  | ||||||
|       action = "action_remove_subscriptions" |  | ||||||
|     else |  | ||||||
|       return env.redirect referer |  | ||||||
|     end |  | ||||||
| 
 |  | ||||||
|     channel_id = env.params.query["c"]? |     channel_id = env.params.query["c"]? | ||||||
|     channel_id ||= "" |     channel_id ||= "" | ||||||
| 
 | 
 | ||||||
|     case action |     case action = env.params.query["action"]? | ||||||
|     when "action_create_subscription_to_channel" |     when "create_subscription_to_channel" | ||||||
|       if !user.subscriptions.includes? channel_id |       if !user.subscriptions.includes? channel_id | ||||||
|         get_channel(channel_id) |         get_channel(channel_id) | ||||||
|         Invidious::Database::Users.subscribe_channel(user, channel_id) |         Invidious::Database::Users.subscribe_channel(user, channel_id) | ||||||
|       end |       end | ||||||
|     when "action_remove_subscriptions" |     when "remove_subscriptions" | ||||||
|       Invidious::Database::Users.unsubscribe_channel(user, channel_id) |       Invidious::Database::Users.unsubscribe_channel(user, channel_id) | ||||||
|     else |     else | ||||||
|       return error_json(400, "Unsupported action #{action}") |       return error_json(400, "Unsupported action #{action}") | ||||||
|  | |||||||
| @ -1,13 +1,13 @@ | |||||||
| <% if user %> | <% if user %> | ||||||
|     <% if subscriptions.includes? ucid %> |     <% if subscriptions.includes? ucid %> | ||||||
|             <form action="/subscription_ajax?action_remove_subscriptions=1&c=<%= ucid %>&referer=<%= env.get("current_page") %>" method="post"> |             <form action="/subscription_ajax?action=remove_subscriptions&c=<%= ucid %>&referer=<%= env.get("current_page") %>" method="post"> | ||||||
|                 <input type="hidden" name="csrf_token" value="<%= HTML.escape(env.get?("csrf_token").try &.as(String) || "") %>"> |                 <input type="hidden" name="csrf_token" value="<%= HTML.escape(env.get?("csrf_token").try &.as(String) || "") %>"> | ||||||
|                 <button data-type="unsubscribe" id="subscribe" class="pure-button pure-button-primary"> |                 <button data-type="unsubscribe" id="subscribe" class="pure-button pure-button-primary"> | ||||||
|                     <b><input style="all:unset" type="submit" value="<%= translate(locale, "Unsubscribe") %> | <%= sub_count_text %>"></b> |                     <b><input style="all:unset" type="submit" value="<%= translate(locale, "Unsubscribe") %> | <%= sub_count_text %>"></b> | ||||||
|                 </button> |                 </button> | ||||||
|             </form> |             </form> | ||||||
|     <% else %> |     <% else %> | ||||||
|             <form action="/subscription_ajax?action_create_subscription_to_channel=1&c=<%= ucid %>&referer=<%= env.get("current_page") %>" method="post"> |             <form action="/subscription_ajax?action=create_subscription_to_channel&c=<%= ucid %>&referer=<%= env.get("current_page") %>" method="post"> | ||||||
|                 <input type="hidden" name="csrf_token" value="<%= HTML.escape(env.get?("csrf_token").try &.as(String) || "") %>"> |                 <input type="hidden" name="csrf_token" value="<%= HTML.escape(env.get?("csrf_token").try &.as(String) || "") %>"> | ||||||
|                 <button data-type="subscribe" id="subscribe" class="pure-button pure-button-primary"> |                 <button data-type="subscribe" id="subscribe" class="pure-button pure-button-primary"> | ||||||
|                     <b><input style="all:unset" type="submit" value="<%= translate(locale, "Subscribe") %> | <%= sub_count_text %>"></b> |                     <b><input style="all:unset" type="submit" value="<%= translate(locale, "Subscribe") %> | <%= sub_count_text %>"></b> | ||||||
|  | |||||||
| @ -37,7 +37,7 @@ | |||||||
|             <div class="pure-u-2-5"></div> |             <div class="pure-u-2-5"></div> | ||||||
|             <div class="pure-u-1-5" style="text-align:right"> |             <div class="pure-u-1-5" style="text-align:right"> | ||||||
|                 <h3 style="padding-right:0.5em"> |                 <h3 style="padding-right:0.5em"> | ||||||
|                     <form data-onsubmit="return_false" action="/subscription_ajax?action_remove_subscriptions=1&c=<%= channel.id %>&referer=<%= env.get("current_page") %>" method="post"> |                     <form data-onsubmit="return_false" action="/subscription_ajax?action=remove_subscriptions&c=<%= channel.id %>&referer=<%= env.get("current_page") %>" method="post"> | ||||||
|                         <input type="hidden" name="csrf_token" value="<%= HTML.escape(env.get?("csrf_token").try &.as(String) || "") %>"> |                         <input type="hidden" name="csrf_token" value="<%= HTML.escape(env.get?("csrf_token").try &.as(String) || "") %>"> | ||||||
|                         <input style="all:unset" type="submit" data-onclick="remove_subscription" data-ucid="<%= channel.id %>" value="<%= translate(locale, "unsubscribe") %>"> |                         <input style="all:unset" type="submit" data-onclick="remove_subscription" data-ucid="<%= channel.id %>" value="<%= translate(locale, "unsubscribe") %>"> | ||||||
|                     </form> |                     </form> | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user