From 527fa421708a16105370f133744c089c3ae15f4e Mon Sep 17 00:00:00 2001 From: syeopite Date: Fri, 9 Apr 2021 21:36:16 -0700 Subject: [PATCH] Declutter search bar to only show search query This commit changes the way search filters are parsed. Instead of directly appending the data into the search query and creating k:v pairs, all of the search filters are now a URL parameter. This results in a clear look overall and hides much of the logic from the end user. Closes #1969 --- src/invidious/routes/playlists.cr | 2 +- src/invidious/search.cr | 31 ++++++++----------------------- src/invidious/views/search.ecr | 12 ++++++------ 3 files changed, 15 insertions(+), 30 deletions(-) diff --git a/src/invidious/routes/playlists.cr b/src/invidious/routes/playlists.cr index 5ab15093..59536c36 100644 --- a/src/invidious/routes/playlists.cr +++ b/src/invidious/routes/playlists.cr @@ -244,7 +244,7 @@ module Invidious::Routes::Playlists query = env.params.query["q"]? if query begin - search_query, count, items, operators = process_search_query(query, page, user, region: nil) + search_query, count, items, operators = process_search_query(env.params.query, query, page, user, region: nil) videos = items.select { |item| item.is_a? SearchVideo }.map { |item| item.as(SearchVideo) } rescue ex videos = [] of SearchVideo diff --git a/src/invidious/search.cr b/src/invidious/search.cr index d95d802e..2c8ed454 100644 --- a/src/invidious/search.cr +++ b/src/invidious/search.cr @@ -169,7 +169,7 @@ def produce_channel_search_continuation(ucid, query, page) return continuation end -def process_search_query(query, page, user, region) +def process_search_query(url_params, query, page, user, region) if user user = user.as(User) view_name = "subscriptions_#{sha256(user.email)}" @@ -183,13 +183,13 @@ def process_search_query(query, page, user, region) sort = "relevance" subscriptions = nil - operators = query.split(" ").select { |a| a.match(/\w+:[\w,]+/) } - operators.each do |operator| - key, value = operator.downcase.split(":") + # operators = url_params.split(" ").select { |a| a.match(/\w+:[\,]+/) } + url_params.each do |operator| + key, value = operator case key when "channel", "user" - channel = operator.split(":")[-1] + channel = value when "content_type", "type" content_type = value when "date" @@ -203,11 +203,11 @@ def process_search_query(query, page, user, region) when "subscriptions" subscriptions = value == "true" else - operators.delete(operator) + url_params.delete(key) end end - search_query = (query.split(" ") - operators).join(" ") + search_query = query if channel count, items = channel_search(search_query, page, channel) @@ -232,20 +232,5 @@ def process_search_query(query, page, user, region) count, items = search(search_query, search_params, region).as(Tuple) end - # Light processing to flatten search results out of Categories. - # They should ideally be supported in the future. - items_without_category = [] of SearchItem | ChannelVideo - items.each do |i| - if i.is_a? Category - i.contents.each do |nest_i| - if !nest_i.is_a? Video - items_without_category << nest_i - end - end - else - items_without_category << i - end - end - - {search_query, items_without_category.size, items_without_category, operators} + {search_query, count, items, url_params} end diff --git a/src/invidious/views/search.ecr b/src/invidious/views/search.ecr index fd176e41..d2bc1c40 100644 --- a/src/invidious/views/search.ecr +++ b/src/invidious/views/search.ecr @@ -23,7 +23,7 @@ <% if operator_hash.fetch("date", "all") == date %> <%= translate(locale, date) %> <% else %> - &page=<%= page %>"> + <%= translate(locale, date) %> <% end %> @@ -38,7 +38,7 @@ <% if operator_hash.fetch("content_type", "all") == content_type %> <%= translate(locale, content_type) %> <% else %> - &page=<%= page %>"> + <%= translate(locale, content_type) %> <% end %> @@ -53,7 +53,7 @@ <% if operator_hash.fetch("duration", "all") == duration %> <%= translate(locale, duration) %> <% else %> - &page=<%= page %>"> + <%= translate(locale, duration) %> <% end %> @@ -68,11 +68,11 @@ <% if operator_hash.fetch("features", "all").includes?(feature) %> <%= translate(locale, feature) %> <% elsif operator_hash.has_key?("features") %> - &page=<%= page %>"> + "> <%= translate(locale, feature) %> <% else %> - &page=<%= page %>"> + <%= translate(locale, feature) %> <% end %> @@ -87,7 +87,7 @@ <% if operator_hash.fetch("sort", "relevance") == sort %> <%= translate(locale, sort) %> <% else %> - &page=<%= page %>"> + <%= translate(locale, sort) %> <% end %>