2018-12-05 23:21:45 +05:30
# frozen_string_literal: true
2020-06-23 00:09:42 +05:30
module TimeboxesHelper
2018-10-15 14:42:47 +05:30
include EntityDateHelper
2018-11-29 20:51:05 +05:30
include Gitlab :: Utils :: StrongMemoize
2018-10-15 14:42:47 +05:30
2019-12-26 22:10:19 +05:30
def milestone_status_string ( milestone )
if milestone . closed?
_ ( 'Closed' )
elsif milestone . expired?
_ ( 'Past due' )
elsif milestone . upcoming?
_ ( 'Upcoming' )
else
_ ( 'Open' )
end
end
2015-04-26 12:48:37 +05:30
def milestones_filter_path ( opts = { } )
if @project
2017-09-10 17:25:29 +05:30
project_milestones_path ( @project , opts )
2015-04-26 12:48:37 +05:30
elsif @group
group_milestones_path ( @group , opts )
else
dashboard_milestones_path ( opts )
end
end
2020-04-22 19:07:51 +05:30
def milestones_issues_path ( opts = { } )
2016-06-02 11:05:42 +05:30
if @project
2017-09-10 17:25:29 +05:30
project_issues_path ( @project , opts )
2016-06-02 11:05:42 +05:30
elsif @group
issues_group_path ( @group , opts )
else
issues_dashboard_path ( opts )
end
end
2023-03-04 22:38:38 +05:30
def milestones_browse_issuables_path ( milestone , type : , state : nil )
2017-08-17 22:00:37 +05:30
opts = { milestone_title : milestone . title , state : state }
2016-06-02 11:05:42 +05:30
if @project
2020-10-24 23:57:45 +05:30
polymorphic_path ( [ @project , type ] , opts )
2016-06-02 11:05:42 +05:30
elsif @group
polymorphic_url ( [ type , @group ] , opts )
else
polymorphic_url ( [ type , :dashboard ] , opts )
end
end
def milestone_issues_by_label_count ( milestone , label , state : )
2018-03-17 18:26:18 +05:30
issues = milestone . issues . with_label ( label . title )
issues =
case state
when :opened
issues . opened
when :closed
issues . closed
else
2019-07-31 22:56:46 +05:30
raise ArgumentError , _ ( " invalid milestone state `%{state}` " ) % { state : state }
2018-03-17 18:26:18 +05:30
end
issues . size
2016-06-02 11:05:42 +05:30
end
2018-10-15 14:42:47 +05:30
def milestone_progress_tooltip_text ( milestone )
2020-04-08 14:13:33 +05:30
has_issues = milestone . total_issues_count > 0
2018-10-15 14:42:47 +05:30
if has_issues
[
_ ( 'Progress' ) ,
2020-04-08 14:13:33 +05:30
_ ( " %{percent}%% complete " ) % { percent : milestone . percent_complete }
2018-10-15 14:42:47 +05:30
] . join ( '<br />' )
else
_ ( 'Progress' )
end
end
2015-04-26 12:48:37 +05:30
def milestone_progress_bar ( milestone )
2022-11-25 23:54:43 +05:30
render Pajamas :: ProgressComponent . new (
value : milestone . percent_complete ,
variant : :success
)
2015-04-26 12:48:37 +05:30
end
2018-10-15 14:42:47 +05:30
def milestone_time_for ( date , date_type )
title = date_type == :start ? " Start date " : " End date "
if date
2018-12-05 23:21:45 +05:30
time_ago = time_ago_in_words ( date ) . sub ( " about " , " " )
state = if date . past?
" ago "
else
" remaining "
end
2018-10-15 14:42:47 +05:30
content = [
title ,
" <br /> " ,
date . to_s ( :medium ) ,
2018-12-05 23:21:45 +05:30
" ( #{ time_ago } #{ state } ) "
2018-10-15 14:42:47 +05:30
] . join ( " " )
2017-08-17 22:00:37 +05:30
content . html_safe
2018-10-15 14:42:47 +05:30
else
title
end
end
def milestone_issues_tooltip_text ( milestone )
2020-04-08 14:13:33 +05:30
total = milestone . total_issues_count
opened = milestone . opened_issues_count
closed = milestone . closed_issues_count
2018-10-15 14:42:47 +05:30
2020-10-24 23:57:45 +05:30
return _ ( " Issues " ) if total == 0
2018-10-15 14:42:47 +05:30
content = [ ]
2020-04-08 14:13:33 +05:30
if opened > 0
content << n_ ( " 1 open issue " , " %{issues} open issues " , opened ) % { issues : opened }
2019-07-31 22:56:46 +05:30
end
2020-04-08 14:13:33 +05:30
if closed > 0
content << n_ ( " 1 closed issue " , " %{issues} closed issues " , closed ) % { issues : closed }
2019-07-31 22:56:46 +05:30
end
2018-10-15 14:42:47 +05:30
content . join ( '<br />' ) . html_safe
end
def milestone_merge_requests_tooltip_text ( milestone )
merge_requests = milestone . merge_requests
return _ ( " Merge requests " ) if merge_requests . empty?
content = [ ]
2019-07-31 22:56:46 +05:30
content << n_ ( " 1 open merge request " , " %{merge_requests} open merge requests " , merge_requests . opened . count ) % { merge_requests : merge_requests . opened . count } if merge_requests . opened . any?
content << n_ ( " 1 closed merge request " , " %{merge_requests} closed merge requests " , merge_requests . closed . count ) % { merge_requests : merge_requests . closed . count } if merge_requests . closed . any?
content << n_ ( " 1 merged merge request " , " %{merge_requests} merged merge requests " , merge_requests . merged . count ) % { merge_requests : merge_requests . merged . count } if merge_requests . merged . any?
2018-10-15 14:42:47 +05:30
content . join ( '<br />' ) . html_safe
end
2019-12-26 22:10:19 +05:30
def milestone_releases_tooltip_text ( milestone )
count = milestone . releases . count
2020-10-24 23:57:45 +05:30
return _ ( " Releases " ) if count == 0
2019-12-26 22:10:19 +05:30
n_ ( " %{releases} release " , " %{releases} releases " , count ) % { releases : count }
end
2022-07-01 11:34:44 +05:30
def recent_releases_with_counts ( milestone , user )
2019-12-26 22:10:19 +05:30
total_count = milestone . releases . size
return [ [ ] , 0 , 0 ] if total_count == 0
2022-07-01 11:34:44 +05:30
recent_releases = milestone . releases . recent . filter { | release | Ability . allowed? ( user , :read_release , release ) }
2019-12-26 22:10:19 +05:30
more_count = total_count - recent_releases . size
[ recent_releases , total_count , more_count ]
end
2018-10-15 14:42:47 +05:30
def milestone_tooltip_due_date ( milestone )
if milestone . due_date
2019-02-15 15:39:39 +05:30
" #{ milestone . due_date . to_s ( :medium ) } ( #{ remaining_days_in_words ( milestone . due_date , milestone . start_date ) } ) "
2018-11-08 19:23:39 +05:30
else
_ ( 'Milestone' )
2017-08-17 22:00:37 +05:30
end
end
2020-06-23 00:09:42 +05:30
def timebox_date_range ( timebox )
if timebox . start_date && timebox . due_date
2022-10-11 01:57:18 +05:30
s_ ( " DateRange|%{start_date}– %{end_date} " ) % { start_date : l ( timebox . start_date , format : Date :: DATE_FORMATS [ :medium ] ) ,
end_date : l ( timebox . due_date , format : Date :: DATE_FORMATS [ :medium ] ) }
2020-06-23 00:09:42 +05:30
elsif timebox . due_date
if timebox . due_date . past?
2022-10-11 01:57:18 +05:30
_ ( " expired on %{timebox_due_date} " ) % { timebox_due_date : l ( timebox . due_date , format : Date :: DATE_FORMATS [ :medium ] ) }
2017-08-17 22:00:37 +05:30
else
2022-10-11 01:57:18 +05:30
_ ( " expires on %{timebox_due_date} " ) % { timebox_due_date : l ( timebox . due_date , format : Date :: DATE_FORMATS [ :medium ] ) }
2017-08-17 22:00:37 +05:30
end
2020-06-23 00:09:42 +05:30
elsif timebox . start_date
if timebox . start_date . past?
2022-10-11 01:57:18 +05:30
_ ( " started on %{timebox_start_date} " ) % { timebox_start_date : l ( timebox . start_date , format : Date :: DATE_FORMATS [ :medium ] ) }
2017-08-17 22:00:37 +05:30
else
2022-10-11 01:57:18 +05:30
_ ( " starts on %{timebox_start_date} " ) % { timebox_start_date : l ( timebox . start_date , format : Date :: DATE_FORMATS [ :medium ] ) }
2017-08-17 22:00:37 +05:30
end
end
end
2020-06-23 00:09:42 +05:30
alias_method :milestone_date_range , :timebox_date_range
2017-08-17 22:00:37 +05:30
2021-01-03 14:25:43 +05:30
def milestone_tab_path ( milestone , tab , params = { } )
url_for ( params . merge ( action : tab , format : :json ) )
2017-08-17 22:00:37 +05:30
end
2019-12-26 22:10:19 +05:30
def update_milestone_path ( milestone , params = { } )
if milestone . project_milestone?
project_milestone_path ( milestone . project , milestone , milestone : params )
2017-09-10 17:25:29 +05:30
else
2019-12-26 22:10:19 +05:30
group_milestone_route ( milestone , params )
2017-09-10 17:25:29 +05:30
end
end
def group_milestone_route ( milestone , params = { } )
params = nil if params . empty?
2020-06-23 00:09:42 +05:30
group_milestone_path ( milestone . group , milestone . iid , milestone : params )
2016-04-02 18:10:28 +05:30
end
2018-11-18 11:00:15 +05:30
2019-02-15 15:39:39 +05:30
def group_or_project_milestone_path ( milestone )
params =
if milestone . group_milestone?
{ milestone : { title : milestone . title } }
else
{ title : milestone . title }
end
milestone_path ( milestone . milestone , params )
2018-11-18 11:00:15 +05:30
end
2018-11-29 20:51:05 +05:30
2019-12-26 22:10:19 +05:30
def edit_milestone_path ( milestone )
if milestone . group_milestone?
edit_group_milestone_path ( milestone . group , milestone )
elsif milestone . project_milestone?
edit_project_milestone_path ( milestone . project , milestone )
end
end
2018-11-29 20:51:05 +05:30
def can_admin_project_milestones?
strong_memoize ( :can_admin_project_milestones ) do
can? ( current_user , :admin_milestone , @project )
end
end
def can_admin_group_milestones?
strong_memoize ( :can_admin_group_milestones ) do
can? ( current_user , :admin_milestone , @project . group )
end
end
2020-04-22 19:07:51 +05:30
def display_issues_count_warning? ( milestone )
milestone_visible_issues_count ( milestone ) > Milestone :: DISPLAY_ISSUES_LIMIT
end
def milestone_issues_count_message ( milestone )
total_count = milestone_visible_issues_count ( milestone )
limit = Milestone :: DISPLAY_ISSUES_LIMIT
link_options = { milestone_title : @milestone . title }
message = _ ( 'Showing %{limit} of %{total_count} issues. ' ) % { limit : limit , total_count : total_count }
message += link_to ( _ ( 'View all issues' ) , milestones_issues_path ( link_options ) )
message . html_safe
end
private
def milestone_visible_issues_count ( milestone )
@milestone_visible_issues_count || = milestone . issues_visible_to_user ( current_user ) . size
end
2015-04-26 12:48:37 +05:30
end
2019-12-04 20:38:33 +05:30
2021-06-08 01:23:25 +05:30
TimeboxesHelper . prepend_mod_with ( 'TimeboxesHelper' )