From: Anton Khorev Date: Wed, 23 Aug 2023 16:59:30 +0000 (+0300) Subject: Rearrange data in blocks table to start/end/status columns X-Git-Tag: live~4^2~1 X-Git-Url: https://git.openstreetmap.org./rails.git/commitdiff_plain/30da09c5a1d0a788c3becae49cdeee822c23b298?hp=572d1adaae6a8f7100c829ce9d3da4dbf07bb7fd Rearrange data in blocks table to start/end/status columns --- diff --git a/app/helpers/user_blocks_helper.rb b/app/helpers/user_blocks_helper.rb index e2770eb69..a1cd26308 100644 --- a/app/helpers/user_blocks_helper.rb +++ b/app/helpers/user_blocks_helper.rb @@ -25,6 +25,44 @@ module UserBlocksHelper end end + def block_short_status(block) + if block.active? + if block.needs_view? + if block.ends_at > Time.now.utc + t("user_blocks.helper.short.until_end_and_login") + else + t("user_blocks.helper.short.until_login") + end + else + t("user_blocks.helper.short.until_end") + end + else + if block.revoker_id.nil? + t("user_blocks.helper.short.ended") + else + t("user_blocks.helper.short.revoked_html", :name => link_to(block.revoker.display_name, block.revoker, + :class => "username d-inline-block text-truncate text-wrap align-bottom", + :dir => "auto")) + end + end + end + + def block_short_time_in_future(time) + tag.time l(time.to_date), + :datetime => time.xmlschema, + :title => t("user_blocks.helper.short.time_in_future_title", + :time_absolute => l(time, :format => :friendly), + :time_relative => time_ago_in_words(time)) + end + + def block_short_time_in_past(time) + tag.time l(time.to_date), + :datetime => time.xmlschema, + :title => t("user_blocks.helper.short.time_in_past_title", + :time_absolute => l(time, :format => :friendly), + :time_relative => time_ago_in_words(time, :scope => :"datetime.distance_in_words_ago")) + end + def block_duration_in_words(duration) # Ensure the requested duration isn't negative, even by a millisecond duration = 0 if duration.negative? diff --git a/app/views/user_blocks/_block.html.erb b/app/views/user_blocks/_block.html.erb index 8ae1408c6..ef790103e 100644 --- a/app/views/user_blocks/_block.html.erb +++ b/app/views/user_blocks/_block.html.erb @@ -6,14 +6,13 @@ <%= link_to block.creator.display_name, block.creator, :class => "username d-inline-block text-truncate text-wrap", :dir => "auto" %> <% end %> <%= h truncate(block.reason) %> - <%= h block_status(block) %> - - <% if block.revoker_id.nil? %> - <%= t(".not_revoked") %> - <% else %> - <%= link_to block.revoker.display_name, block.revoker, :class => "username d-inline-block text-truncate text-wrap", :dir => "auto" %> - <% end %> - + <%= block_short_time_in_past(block.created_at) %> + <% if block.active? %> + <%= block_short_time_in_future(block.ends_at) %> + <% else %> + <%= block_short_time_in_past([block.ends_at, block.updated_at].max) %> + <% end %> + <%= h block_short_status(block) %> <%= link_to t(".show"), block %> <% if can?(:edit, block) %><%= link_to t(".edit"), edit_user_block_path(block) %><% end %> diff --git a/app/views/user_blocks/_page.html.erb b/app/views/user_blocks/_page.html.erb index 8c8557f60..c2e516170 100644 --- a/app/views/user_blocks/_page.html.erb +++ b/app/views/user_blocks/_page.html.erb @@ -9,8 +9,9 @@ <%= t ".creator_name" %> <% end %> <%= t ".reason" %> + <%= t ".start" %> + <%= t ".end" %> <%= t ".status" %> - <%= t ".revoker_name" %> diff --git a/config/locales/en.yml b/config/locales/en.yml index b190c2ca0..6baa96331 100644 --- a/config/locales/en.yml +++ b/config/locales/en.yml @@ -2895,6 +2895,14 @@ en: years: one: "%{count} year" other: "%{count} years" + short: + ended: "ended" + revoked_html: "revoked by %{name}" + until_end: "until end" + until_login: "until login" + until_end_and_login: "until end & login" + time_in_future_title: "%{time_absolute}; in %{time_relative}" + time_in_past_title: "%{time_absolute}; %{time_relative}" blocks_on: title: "Blocks on %{name}" heading_html: "List of Blocks on %{name}" @@ -2913,15 +2921,15 @@ en: reason: "Reason for block:" revoker: "Revoker:" block: - not_revoked: "(not revoked)" show: "Show" edit: "Edit" page: display_name: "Blocked User" creator_name: "Creator" reason: "Reason for block" + start: "Start" + end: "End" status: "Status" - revoker_name: "Revoked by" navigation: all_blocks: "All Blocks" blocks_on_me: "Blocks on Me"