module ProposalsDashboardHelper def my_proposal_menu_class return 'is-active' if controller_name == 'proposals_dashboard' && action_name == 'index' nil end def progress_menu_class return 'is-active' if progress_menu_active? nil end def progress_menu_active? is_proposed_action_request? || (controller_name == 'proposals_dashboard' && action_name == 'progress') end def resources_menu_visible?(proposal, resources) can?(:manage_polls, proposal) || resources.any? end def resources_menu(&block) menu_group('resources-menu', resources_menu_active?, &block) end def polls_menu(&block) menu_entry(polls_menu_active?, &block) end def resources_menu_active? polls_menu_active? || is_resource_request? end def polls_menu_active? controller_name == 'polls' end def menu_group(id, active, &block) html_class = nil html_class = 'is-active' if active content_tag(:ul, id: id, class: html_class) do yield end end def menu_entry(active, &block) content = capture(&block) html_class = nil html_class = 'is-active' if active content_tag(:li, content, class: html_class) end def is_resource_request? controller_name == 'proposals_dashboard' && action_name == 'new_request' && proposal_dashboard_action&.resource? end def is_proposed_action_request? controller_name == 'proposals_dashboard' && action_name == 'new_request' && proposal_dashboard_action&.proposed_action? end def is_request_active(id) controller_name == 'proposals_dashboard' && action_name == 'new_request' && proposal_dashboard_action&.id == id end def resoure_availability_label(resource) label = [] label << t('.required_days', days: resource.day_offset) if resource.day_offset > 0 label << t('.required_supports', supports: number_with_delimiter(resource.required_supports, delimiter: '.')) if resource.required_supports > 0 label.join(" #{t('.and')}
") end end