scinote-web/app/helpers/application_helper.rb

216 lines
6.8 KiB
Ruby
Raw Normal View History

2016-02-12 23:52:43 +08:00
module ApplicationHelper
include ActionView::Helpers::AssetTagHelper
include ActionView::Helpers::UrlHelper
include InputSanitizeHelper
2016-07-29 21:47:41 +08:00
def module_page?
controller_name == 'my_modules'
2016-02-12 23:52:43 +08:00
end
2016-07-29 21:47:41 +08:00
def experiment_page?
controller_name == 'experiments'
2016-02-12 23:52:43 +08:00
end
2016-07-29 21:47:41 +08:00
def project_page?
controller_name == 'projects' &&
action_name.in?(%w(show experiment_archive))
end
def all_projects_page?
controller_name == 'projects' && action_name.in?(%w(index archive))
2016-02-12 23:52:43 +08:00
end
def display_tooltip(message, len = Constants::NAME_TRUNCATION_LENGTH)
return '' unless message
2017-06-19 21:30:38 +08:00
if message.strip.length > len
2017-01-03 05:27:12 +08:00
sanitize_input("<div class='modal-tooltip'> \
#{truncate(message.strip, length: len)} \
<span class='modal-tooltiptext'> \
#{message.strip}</span></div>")
else
truncate(message.strip, length: len)
end
end
def sample_types_page_project?
2016-12-14 17:35:48 +08:00
controller_name == 'sample_types' &&
@my_module.nil? &&
@experiment.nil?
end
def sample_groups_page_project?
2016-12-14 17:35:48 +08:00
controller_name == 'sample_groups' &&
@my_module.nil? &&
@experiment.nil?
end
def sample_types_page_my_module?
2016-12-14 17:35:48 +08:00
controller_name == 'sample_types' && !@my_module.nil?
end
def sample_groups_page_my_module?
2016-12-14 17:35:48 +08:00
controller_name == 'sample_groups' && !@my_module.nil?
end
def sample_groups_page_experiment?
controller_name == 'sample_groups' &&
@my_module.nil? &&
!@experiment.nil?
end
def sample_types_page_expermient?
controller_name == 'sample_types' &&
@my_module.nil? &&
!@experiment.nil?
end
2017-01-10 00:16:39 +08:00
def module_repository_page?
controller_name == 'my_modules' && !@repository.nil?
end
2017-04-06 14:42:16 +08:00
def smart_annotation_notification(options = {})
title = options.fetch(:title) { :title_must_be_present }
message = options.fetch(:message) { :message_must_be_present }
new_text = options.fetch(:new_text) { :new_text_must_be_present }
old_text = options[:old_text] || ''
2017-04-04 15:19:43 +08:00
sa_user = /\[\@(.*?)~([0-9a-zA-Z]+)\]/
2017-04-10 17:21:28 +08:00
# fetch user ids from the previous text
2017-04-06 14:42:16 +08:00
old_user_ids = []
old_text.gsub(sa_user) do |el|
match = el.match(sa_user)
old_user_ids << match[2].base62_decode
end
2017-04-06 21:08:03 +08:00
# fetch user ids from the new text
2017-04-06 14:42:16 +08:00
new_user_ids = []
new_text.gsub(sa_user) do |el|
2017-04-04 15:19:43 +08:00
match = el.match(sa_user)
2017-04-06 14:42:16 +08:00
new_user_ids << match[2].base62_decode
2017-04-04 15:19:43 +08:00
end
2017-04-06 21:08:03 +08:00
# check if the user has been already mentioned
2017-04-06 14:42:16 +08:00
annotated_users = []
new_user_ids.each do |el|
annotated_users << el unless old_user_ids.include?(el)
end
2017-04-06 21:08:03 +08:00
# restrict the list of ids and generate notification
2017-04-04 15:19:43 +08:00
annotated_users.uniq.each do |user_id|
target_user = User.find_by_id(user_id)
next unless target_user
generate_annotation_notification(target_user, title, message)
end
end
def generate_annotation_notification(target_user, title, message)
notification = Notification.create(
type_of: :assignment,
title: sanitize_input(title),
message: sanitize_input(message)
2017-04-04 15:19:43 +08:00
)
if target_user.assignments_notification
UserNotification.create(notification: notification, user: target_user)
end
end
def smart_annotation_parser(text, team = nil)
2017-05-03 21:30:08 +08:00
# sometimes happens that the "team" param gets wrong data: "{nil, []}"
# so we have to check if the "team" param is kind of Team object
2017-04-25 19:44:31 +08:00
team = nil unless team.is_a? Team
new_text = smart_annotation_filter_resources(text)
new_text = smart_annotation_filter_users(new_text, team)
new_text
end
# Check if text have smart annotations of resources
# and outputs a link to resource
def smart_annotation_filter_resources(text)
SmartAnnotations::TagToHtml.new(current_user, text).html
end
2017-01-11 00:05:32 +08:00
# Check if text have smart annotations of users
# and outputs a popover with user information
def smart_annotation_filter_users(text, team)
sa_user = /\[\@(.*?)~([0-9a-zA-Z]+)\]/
new_text = text.gsub(sa_user) do |el|
2017-01-11 00:05:32 +08:00
match = el.match(sa_user)
user = User.find_by_id(match[2].base62_decode)
next unless user
popover_for_user_name(user, team)
2017-01-11 00:05:32 +08:00
end
new_text
2017-01-10 00:16:39 +08:00
end
# Generate smart annotation link for one user object
def popover_for_user_name(user, team = nil, skip_user_status = false)
user_still_in_team = user.teams.include?(team)
user_description = %(<div class='col-xs-4'>
2017-05-03 21:33:23 +08:00
<img src='#{user_avatar_absolute_url(user, :thumb)}'
alt='thumb'></div><div class='col-xs-8'>
<div class='row'><div class='col-xs-9 text-left'><h5>
#{user.full_name}</h5></div><div class='col-xs-3 text-right'>
<span class='fas fa-times' aria-hidden='true'></span>
</div></div><div class='row'><div class='col-xs-12'>
<p class='silver'>#{user.email}</p>)
if user_still_in_team
user_t = user.user_teams
.where('user_teams.team_id = ?', team)
.first
user_description += %(<p>
#{I18n.t('atwho.users.popover_html',
role: user_t.role.capitalize,
team: user_t.team.name,
time: I18n.l(user_t.created_at, format: :full_date))}
</p></div></div></div>)
else
user_description += %(<p></p></div></div></div>)
end
2017-05-09 20:55:23 +08:00
user_name = user.full_name
html =
raw("<img src='#{user_avatar_absolute_url(user, :icon_small)}'" \
"alt='avatar' class='atwho-user-img-popover'" \
" ref='#{'missing-img' if missing_avatar(user, :icon_small)}'>") +
raw('<a onClick="$(this).popover(\'show\')" ' \
'class="atwho-user-popover" data-container="body" ' \
'data-html="true" tabindex="0" data-trigger="focus" ' \
'data-placement="top" data-toggle="popover" data-content="') +
raw(user_description) + raw('" >') + user_name + raw('</a>')
unless skip_user_status || user_still_in_team
html << " #{I18n.t('atwho.res.removed')}"
end
html
end
# Dirty, dirty hack for displaying images in reports
2017-05-03 21:33:23 +08:00
def user_avatar_absolute_url(user, style)
prefix = ''
if ENV['PAPERCLIP_STORAGE'].present? &&
ENV['MAIL_SERVER_URL'].present? &&
ENV['PAPERCLIP_STORAGE'] != 'filesystem'
prefix = ENV['MAIL_SERVER_URL']
end
# for development
prefix = 'localhost:3000' if ENV['MAIL_SERVER_URL'] == 'localhost'
if !prefix.empty? &&
!prefix.include?('http://') &&
!prefix.include?('https://')
2017-06-14 20:48:22 +08:00
prefix = if respond_to?(:request) && request.ssl?
"https://#{prefix}"
else
"http://#{prefix}"
end
end
unless missing_avatar(user, style)
return user.avatar(style, timeout: Constants::URL_LONG_EXPIRE_TIME)
end
url_for(prefix + "/images/#{style}/missing.png")
end
def missing_avatar(user, style)
user.avatar(style) == '/images/icon_small/missing.png' ||
user.avatar(style) == '/images/thumb/missing.png'
end
2016-02-12 23:52:43 +08:00
end