2017-11-17 03:03:44 +08:00
|
|
|
module ProtocolsIoHelper
|
2017-11-20 07:59:32 +08:00
|
|
|
#=============================================================================
|
|
|
|
# Protocols.io limits
|
|
|
|
#=============================================================================
|
|
|
|
TEXT_MAX_LENGTH = Constants::TEXT_MAX_LENGTH
|
|
|
|
|
2017-11-22 02:20:15 +08:00
|
|
|
PIO_ELEMENT_RESERVED_LENGTH_BIG = TEXT_MAX_LENGTH * 0.015
|
|
|
|
PIO_ELEMENT_RESERVED_LENGTH_MEDIUM = TEXT_MAX_LENGTH * 0.01
|
|
|
|
PIO_ELEMENT_RESERVED_LENGTH_SMALL = TEXT_MAX_LENGTH * 0.005
|
2017-11-20 07:59:32 +08:00
|
|
|
|
2017-11-22 02:20:15 +08:00
|
|
|
# PROTOCOLS.IO PROTOCOL ATTRIBUTES
|
2017-11-21 06:19:34 +08:00
|
|
|
PIO_P_AVAILABLE_LENGTH =
|
|
|
|
TEXT_MAX_LENGTH -
|
2017-11-22 02:20:15 +08:00
|
|
|
(PIO_ELEMENT_RESERVED_LENGTH_SMALL * 2 +
|
|
|
|
PIO_ELEMENT_RESERVED_LENGTH_MEDIUM * 8 +
|
2017-11-24 18:49:57 +08:00
|
|
|
PIO_ELEMENT_RESERVED_LENGTH_BIG * 2)
|
2017-11-23 06:38:22 +08:00
|
|
|
# -- 2 small = created at , publish date PROTOCOL ATTRIBUTES
|
|
|
|
# -- 8 medium = description,tags,before_start,warning,guidelines,
|
|
|
|
# manuscript_citation,keywords,vendor_name PROTOCOL ATTRIBUTES
|
|
|
|
# -- 2 big = vendor_link, link PROTOCOL ATTRIBUTES
|
2017-11-21 06:19:34 +08:00
|
|
|
|
2017-11-20 07:59:32 +08:00
|
|
|
# PROTOCOLS.IO STEP ATTRIBUTES
|
2017-11-21 06:19:34 +08:00
|
|
|
PIO_S_AVAILABLE_LENGTH =
|
|
|
|
TEXT_MAX_LENGTH -
|
2017-11-24 18:49:57 +08:00
|
|
|
(PIO_ELEMENT_RESERVED_LENGTH_SMALL * 20)
|
2017-11-24 08:45:40 +08:00
|
|
|
# -- 20 small = description,expected_result,safety_information
|
|
|
|
# software_package version, software_package os_name,
|
|
|
|
# software_package os_version,software_package link,
|
|
|
|
# software_package repository,software_package developer,software_package name
|
|
|
|
# commands os_version,commands os_name, commands name,commands description,
|
|
|
|
# sub protocol full name (author), sub protocol name, sub protocol link,
|
|
|
|
# dataset link,dataset name, safety_information link,
|
|
|
|
# -- 0 medium =
|
|
|
|
# -- 0 big =
|
2017-11-20 07:59:32 +08:00
|
|
|
|
2017-11-21 06:19:34 +08:00
|
|
|
PIO_TITLE_TOOLONG_LEN =
|
2017-11-24 08:45:40 +08:00
|
|
|
I18n.t('protocols.protocols_io_import.title_too_long').length + 2
|
2017-11-21 06:19:34 +08:00
|
|
|
PIO_STEP_TOOLONG_LEN =
|
2017-11-24 18:18:12 +08:00
|
|
|
I18n.t('protocols.protocols_io_import.too_long').length
|
|
|
|
# The + 2 above (in title) is there because if the length was at the limit,
|
2017-11-24 08:45:40 +08:00
|
|
|
# the cutter method had issues, this gives it some space
|
2017-11-17 03:03:44 +08:00
|
|
|
def protocolsio_string_to_table_element(description_string)
|
|
|
|
string_without_tables = string_html_table_remove(description_string)
|
|
|
|
table_regex = %r{<table\b[^>]*>(.*?)<\/table>}m
|
|
|
|
tr_regex = %r{<tr\b[^>]*>(.*?)<\/tr>}m
|
|
|
|
td_regex = %r{<td\b[^>]*>(.*?)<\/td>}m
|
|
|
|
tables = {}
|
|
|
|
table_strings = description_string.scan(table_regex)
|
|
|
|
table_strings.each_with_index do |table, table_counter|
|
|
|
|
tables[table_counter.to_s] = {}
|
|
|
|
tr_strings = table[0].scan(tr_regex)
|
|
|
|
contents = {}
|
|
|
|
contents['data'] = []
|
|
|
|
tr_strings.each_with_index do |tr, tr_counter|
|
|
|
|
td_strings = tr[0].scan(td_regex)
|
|
|
|
contents['data'][tr_counter] = []
|
|
|
|
td_strings.each do |td|
|
|
|
|
td_stripped = ActionController::Base.helpers.strip_tags(td[0])
|
|
|
|
contents['data'][tr_counter].push(td_stripped)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
tables[table_counter.to_s]['contents'] = Base64.encode64(
|
|
|
|
contents.to_s.sub('=>', ':')
|
|
|
|
)
|
|
|
|
tables[table_counter.to_s]['name'] = nil
|
|
|
|
end
|
|
|
|
# return string_without_tables, tables
|
|
|
|
return tables, string_without_tables
|
|
|
|
end
|
|
|
|
|
|
|
|
def string_html_table_remove(description_string)
|
|
|
|
description_string.remove!("\n", "\t", "\r", "\f")
|
|
|
|
table_whole_regex = %r{(<table\b[^>]*>.*?<\/table>)}m
|
|
|
|
table_pattern_array = description_string.scan(table_whole_regex)
|
|
|
|
string_without_tables = description_string
|
|
|
|
table_pattern_array.each do |table_pattern|
|
|
|
|
string_without_tables = string_without_tables.gsub(
|
|
|
|
table_pattern[0],
|
|
|
|
t('protocols.protocols_io_import.comp_append.table_moved').html_safe
|
|
|
|
)
|
|
|
|
end
|
|
|
|
string_without_tables
|
|
|
|
end
|
|
|
|
|
2017-11-20 07:59:32 +08:00
|
|
|
def pio_eval_prot_desc(text, attribute_name)
|
|
|
|
case attribute_name
|
|
|
|
when 'publish_date'
|
2017-11-22 02:20:15 +08:00
|
|
|
pio_eval_len(text, ProtocolsIoHelper::PIO_ELEMENT_RESERVED_LENGTH_SMALL)
|
2017-11-23 06:38:22 +08:00
|
|
|
when 'vendor_link', 'link'
|
2017-11-22 02:20:15 +08:00
|
|
|
pio_eval_len(text, ProtocolsIoHelper::PIO_ELEMENT_RESERVED_LENGTH_BIG)
|
2017-11-20 07:59:32 +08:00
|
|
|
else
|
2017-11-22 04:27:19 +08:00
|
|
|
pio_eval_len(text, ProtocolsIoHelper::PIO_ELEMENT_RESERVED_LENGTH_MEDIUM)
|
2017-11-17 03:03:44 +08:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2017-11-21 06:19:34 +08:00
|
|
|
def pio_eval_title_len(text)
|
2017-11-24 08:45:40 +08:00
|
|
|
if text
|
|
|
|
text += ' ' if text.length < Constants::NAME_MIN_LENGTH
|
|
|
|
if text.length > Constants::NAME_MAX_LENGTH
|
|
|
|
text =
|
|
|
|
text[0..(Constants::NAME_MAX_LENGTH - PIO_TITLE_TOOLONG_LEN)] +
|
|
|
|
t('protocols.protocols_io_import.title_too_long')
|
|
|
|
@toolong = true
|
|
|
|
end
|
|
|
|
text
|
2017-11-17 03:03:44 +08:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2017-11-21 06:19:34 +08:00
|
|
|
def pio_eval_len(text, reserved)
|
|
|
|
if text
|
|
|
|
text_end = reserved + @remaining - PIO_STEP_TOOLONG_LEN
|
2017-11-24 18:18:12 +08:00
|
|
|
text_end = 2 if text_end < 2
|
2017-11-24 08:45:40 +08:00
|
|
|
# Since steps have very low reserved values now (below 100),
|
|
|
|
# the above sets their index to 1 if its negative
|
|
|
|
# (length of toolong text is about 90 chars, and if remaining is 0,
|
|
|
|
# then the negative index just gets set to 1. this is a workaround
|
|
|
|
|
|
|
|
# it would also be possible to not count the length of the "too long" text
|
|
|
|
# or setting the import reserved value to 95,but then available characters
|
|
|
|
# will be like before (around 7600)
|
2017-11-21 06:19:34 +08:00
|
|
|
if text.length - reserved > @remaining
|
|
|
|
text =
|
2017-11-23 06:38:22 +08:00
|
|
|
close_open_html_tags(
|
|
|
|
text[0..text_end] + t('protocols.protocols_io_import.too_long')
|
|
|
|
)
|
2017-11-21 06:19:34 +08:00
|
|
|
@toolong = true
|
2017-11-22 02:20:15 +08:00
|
|
|
@remaining = 0
|
2017-11-24 08:45:40 +08:00
|
|
|
elsif (text.length - reserved) > 0
|
|
|
|
@remaining -= text.length - reserved
|
2017-11-21 06:19:34 +08:00
|
|
|
end
|
2017-11-21 18:42:42 +08:00
|
|
|
text
|
2017-11-21 06:19:34 +08:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# Checks so that null values are returned as zero length strings
|
|
|
|
# Did this so views arent as ugly (i avoid using if present statements)
|
|
|
|
def not_null(attribute)
|
|
|
|
if attribute
|
|
|
|
attribute
|
|
|
|
else
|
|
|
|
''
|
2017-11-17 03:03:44 +08:00
|
|
|
end
|
|
|
|
end
|
2017-11-21 18:15:09 +08:00
|
|
|
|
2017-11-22 02:20:15 +08:00
|
|
|
def close_open_html_tags(text)
|
2017-11-21 18:15:09 +08:00
|
|
|
Nokogiri::HTML::DocumentFragment.parse(text).to_html
|
|
|
|
end
|
2017-11-17 03:03:44 +08:00
|
|
|
end
|