mirror of
https://github.com/scinote-eln/scinote-web.git
synced 2025-01-01 21:21:50 +08:00
Fix smart annotations in demo project
Closes SCI-3097, SCI-3102.
This commit is contained in:
parent
2464a45f83
commit
30bc536d07
1 changed files with 77 additions and 28 deletions
|
@ -1,4 +1,7 @@
|
||||||
module FirstTimeDataGenerator
|
module FirstTimeDataGenerator
|
||||||
|
# Default inventory repository
|
||||||
|
REPO_SAMPLES_NAME = 'Samples'.freeze
|
||||||
|
|
||||||
# Create data for demo for new users
|
# Create data for demo for new users
|
||||||
def seed_demo_data(user, team, asset_queue = :demo)
|
def seed_demo_data(user, team, asset_queue = :demo)
|
||||||
@user = user
|
@user = user
|
||||||
|
@ -8,28 +11,49 @@ module FirstTimeDataGenerator
|
||||||
# Do nothing
|
# Do nothing
|
||||||
return unless team
|
return unless team
|
||||||
|
|
||||||
# create custom repository samples
|
# check if samples repo already exist, then create custom repository samples
|
||||||
repository = Repository.create(
|
repository = Repository.where(team: team).where(name: REPO_SAMPLES_NAME)
|
||||||
name: 'Samples',
|
repository =
|
||||||
|
if repository.blank?
|
||||||
|
if team.repositories.count < Rails.configuration.x.repositories_limit
|
||||||
|
Repository.create(
|
||||||
|
name: REPO_SAMPLES_NAME,
|
||||||
team: team,
|
team: team,
|
||||||
created_by: user
|
created_by: user
|
||||||
)
|
)
|
||||||
|
else
|
||||||
|
# User first repo just as a placeholder, this call will fail anyhow
|
||||||
|
Repository.create(
|
||||||
|
name: team.repositories.first.name,
|
||||||
|
team: team,
|
||||||
|
created_by: user
|
||||||
|
)
|
||||||
|
end
|
||||||
|
else
|
||||||
|
repository.first
|
||||||
|
end
|
||||||
|
|
||||||
# create list value column for sample types
|
# create list value column for sample types
|
||||||
repository_column_sample_types = RepositoryColumn.create(
|
repo_columns = []
|
||||||
repository: repository,
|
['Sample Types', 'Sample Groups'].each do |repo_name|
|
||||||
created_by: user,
|
repo_column = repository.repository_columns.where(name: repo_name)
|
||||||
data_type: :RepositoryListValue,
|
|
||||||
name: 'Sample Types'
|
|
||||||
)
|
|
||||||
|
|
||||||
# create list value column for sample groups
|
repo_columns <<
|
||||||
repository_column_sample_groups = RepositoryColumn.create(
|
if repo_column.blank?
|
||||||
|
RepositoryColumn.create(
|
||||||
repository: repository,
|
repository: repository,
|
||||||
created_by: user,
|
created_by: user,
|
||||||
data_type: :RepositoryListValue,
|
data_type: :RepositoryListValue,
|
||||||
name: 'Sample Groups'
|
name: repo_name
|
||||||
)
|
)
|
||||||
|
else
|
||||||
|
repo_column.first
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
# Maintain old names
|
||||||
|
repository_column_sample_types, repository_column_sample_groups =
|
||||||
|
repo_columns
|
||||||
|
|
||||||
# create few list items for sample types
|
# create few list items for sample types
|
||||||
repository_items_sample_types = []
|
repository_items_sample_types = []
|
||||||
|
@ -41,7 +65,15 @@ module FirstTimeDataGenerator
|
||||||
repository_column: repository_column_sample_types,
|
repository_column: repository_column_sample_types,
|
||||||
repository: repository
|
repository: repository
|
||||||
)
|
)
|
||||||
|
|
||||||
|
# Check if it already exists
|
||||||
|
if item.persisted?
|
||||||
repository_items_sample_types << item
|
repository_items_sample_types << item
|
||||||
|
else
|
||||||
|
repository_items_sample_types << repository_column_sample_types
|
||||||
|
.repository_list_items
|
||||||
|
.where(data: name).first
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
# create few list items for sample groups
|
# create few list items for sample groups
|
||||||
|
@ -54,7 +86,15 @@ module FirstTimeDataGenerator
|
||||||
repository_column: repository_column_sample_groups,
|
repository_column: repository_column_sample_groups,
|
||||||
repository: repository
|
repository: repository
|
||||||
)
|
)
|
||||||
|
|
||||||
|
# Check if it already exists
|
||||||
|
if item.persisted?
|
||||||
repository_items_sample_groups << item
|
repository_items_sample_groups << item
|
||||||
|
else
|
||||||
|
repository_items_sample_groups << repository_column_sample_groups
|
||||||
|
.repository_list_items
|
||||||
|
.where(data: name).first
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
repository_rows_to_assign = []
|
repository_rows_to_assign = []
|
||||||
|
@ -585,19 +625,22 @@ module FirstTimeDataGenerator
|
||||||
'Collection of potatoes'
|
'Collection of potatoes'
|
||||||
]
|
]
|
||||||
|
|
||||||
|
second_rep_item = smart_annotate_rep_item(repository_rows_to_assign.second)
|
||||||
|
third_rep_item = smart_annotate_rep_item(repository_rows_to_assign.third)
|
||||||
|
fifth_rep_item = smart_annotate_rep_item(repository_rows_to_assign.fifth)
|
||||||
module_step_descriptions = [
|
module_step_descriptions = [
|
||||||
'<html>
|
'<html>
|
||||||
<body>
|
<body>
|
||||||
<p>50% of samples should be mock inoculated
|
<p>50% of samples should be mock inoculated
|
||||||
<span class=\"atwho-inserted\"contenteditable=\"false\"
|
<span class=\"atwho-inserted\"contenteditable=\"false\"
|
||||||
data-atwho-at-query=\"#\">[#' + sample_name + '3~rep_item~3]</span>
|
data-atwho-at-query=\"#\">[#' + third_rep_item + ']</span>
|
||||||
<span class=\"atwho-inserted\" contenteditable=\"false\"
|
<span class=\"atwho-inserted\" contenteditable=\"false\"
|
||||||
data-atwho-at-query=\"#\">[#' + sample_name + '5~rep_item~5]</span>
|
data-atwho-at-query=\"#\">[#' + fifth_rep_item + ']</span>
|
||||||
while other 50% with PVY NTN virus
|
while other 50% with PVY NTN virus
|
||||||
<span class=\"atwho-inserted\" contenteditable=\"false\"
|
<span class=\"atwho-inserted\" contenteditable=\"false\"
|
||||||
data-atwho-at-query=\"#\">[#' + sample_name + '3~rep_item~3]</span>
|
data-atwho-at-query=\"#\">[#' + third_rep_item + ']</span>
|
||||||
<span class=\"atwho-inserted\" contenteditable=\"false\"
|
<span class=\"atwho-inserted\" contenteditable=\"false\"
|
||||||
data-atwho-at-query=\"#\">[#' + sample_name + '5~rep_item~5]</span>.
|
data-atwho-at-query=\"#\">[#' + fifth_rep_item + ']</span>.
|
||||||
</p>
|
</p>
|
||||||
</body>
|
</body>
|
||||||
</html>',
|
</html>',
|
||||||
|
@ -611,6 +654,9 @@ module FirstTimeDataGenerator
|
||||||
module_step_names,
|
module_step_names,
|
||||||
module_step_descriptions)
|
module_step_descriptions)
|
||||||
|
|
||||||
|
# Delete repository items, if we went over the limit
|
||||||
|
repository_rows_to_assign.map(&:destroy) unless repository.id
|
||||||
|
|
||||||
# Add table to existig step
|
# Add table to existig step
|
||||||
step = my_modules[1].protocol.steps.where('position = 0').take
|
step = my_modules[1].protocol.steps.where('position = 0').take
|
||||||
Table.create(
|
Table.create(
|
||||||
|
@ -627,12 +673,11 @@ module FirstTimeDataGenerator
|
||||||
file_name: 'PVY-inoculated_plant_symptoms.JPG'
|
file_name: 'PVY-inoculated_plant_symptoms.JPG'
|
||||||
)
|
)
|
||||||
# Add comment to step 1
|
# Add comment to step 1
|
||||||
user_annotation = '[@' + user.name + '~' + user.id.to_s + ']'
|
user_annotation = user.name
|
||||||
generate_step_comment(
|
generate_step_comment(
|
||||||
step,
|
step,
|
||||||
user,
|
user,
|
||||||
user_annotation + ' I have used different sample [#' + sample_name +
|
"#{user_annotation} I have used different sample [##{second_rep_item}]"
|
||||||
'2~rep_item~2]'
|
|
||||||
)
|
)
|
||||||
# Add comment to step 3
|
# Add comment to step 3
|
||||||
step = my_modules[1].protocol.steps.where('position = 2').take
|
step = my_modules[1].protocol.steps.where('position = 2').take
|
||||||
|
@ -1666,4 +1711,8 @@ module FirstTimeDataGenerator
|
||||||
step_name: step.name)
|
step_name: step.name)
|
||||||
).sneaky_save
|
).sneaky_save
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def smart_annotate_rep_item(item)
|
||||||
|
"#{item.name}~rep_item~#{Base62.encode(item.id)}"
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue