mirror of
https://github.com/scinote-eln/scinote-web.git
synced 2025-01-01 21:21:50 +08:00
Merge pull request #1309 from biosistemika/release-1.14.5
Merge release-1.14.5 into master
This commit is contained in:
commit
5d6881bae1
4 changed files with 30 additions and 22 deletions
2
VERSION
2
VERSION
|
@ -1 +1 @@
|
||||||
1.14.4
|
1.14.5
|
||||||
|
|
|
@ -173,7 +173,6 @@ class SearchController < ApplicationController
|
||||||
@protocol_search_count = fetch_cached_count Protocol
|
@protocol_search_count = fetch_cached_count Protocol
|
||||||
@step_search_count = fetch_cached_count Step
|
@step_search_count = fetch_cached_count Step
|
||||||
@checklist_search_count = fetch_cached_count Checklist
|
@checklist_search_count = fetch_cached_count Checklist
|
||||||
@sample_search_count = fetch_cached_count Sample
|
|
||||||
@repository_search_count_total = count_by_repository
|
@repository_search_count_total = count_by_repository
|
||||||
@asset_search_count = fetch_cached_count Asset
|
@asset_search_count = fetch_cached_count Asset
|
||||||
@table_search_count = fetch_cached_count Table
|
@table_search_count = fetch_cached_count Table
|
||||||
|
@ -188,7 +187,6 @@ class SearchController < ApplicationController
|
||||||
@search_results_count += @protocol_search_count
|
@search_results_count += @protocol_search_count
|
||||||
@search_results_count += @step_search_count
|
@search_results_count += @step_search_count
|
||||||
@search_results_count += @checklist_search_count
|
@search_results_count += @checklist_search_count
|
||||||
@search_results_count += @sample_search_count
|
|
||||||
@search_results_count += @repository_search_count_total
|
@search_results_count += @repository_search_count_total
|
||||||
@search_results_count += @asset_search_count
|
@search_results_count += @asset_search_count
|
||||||
@search_results_count += @table_search_count
|
@search_results_count += @table_search_count
|
||||||
|
|
|
@ -98,23 +98,31 @@ class Asset < ApplicationRecord
|
||||||
options = {}
|
options = {}
|
||||||
)
|
)
|
||||||
|
|
||||||
project_ids =
|
teams = user.teams.select(:id)
|
||||||
Project
|
|
||||||
.search(user, include_archived, nil, Constants::SEARCH_NO_LIMIT)
|
|
||||||
.pluck(:id)
|
|
||||||
team_ids = user.teams.pluck(:id)
|
|
||||||
|
|
||||||
new_query =
|
assets_in_steps = Asset.joins(:step).where(
|
||||||
Asset
|
'steps.id IN (?)',
|
||||||
.distinct
|
Step.search(user, include_archived, nil, Constants::SEARCH_NO_LIMIT)
|
||||||
.left_outer_joins(:asset_text_datum)
|
.select(:id)
|
||||||
.left_outer_joins(
|
).pluck(:id)
|
||||||
step: { protocol: { my_module: { experiment: :project } } }
|
|
||||||
)
|
assets_in_results = Asset.joins(:result).where(
|
||||||
.left_outer_joins(result: { my_module: { experiment: :project } })
|
'results.id IN (?)',
|
||||||
.left_outer_joins(repository_cell: { repository_column: :repository })
|
Result.search(user, include_archived, nil, Constants::SEARCH_NO_LIMIT)
|
||||||
.where('projects.id IN (?) OR repositories.team_id IN (?)',
|
.select(:id)
|
||||||
project_ids, team_ids)
|
).pluck(:id)
|
||||||
|
|
||||||
|
assets_in_inventories = Asset.joins(
|
||||||
|
repository_cell: { repository_column: :repository }
|
||||||
|
).where('repositories.team_id IN (?)', teams).pluck(:id)
|
||||||
|
|
||||||
|
assets =
|
||||||
|
Asset.distinct
|
||||||
|
.where('assets.id IN (?) OR assets.id IN (?) OR assets.id IN (?)',
|
||||||
|
assets_in_steps, assets_in_results, assets_in_inventories)
|
||||||
|
|
||||||
|
new_query = Asset.left_outer_joins(:asset_text_datum)
|
||||||
|
.from(assets, 'assets')
|
||||||
|
|
||||||
a_query = s_query = ''
|
a_query = s_query = ''
|
||||||
|
|
||||||
|
|
|
@ -34,16 +34,19 @@ class Repository < ApplicationRecord
|
||||||
repository = nil,
|
repository = nil,
|
||||||
options = {}
|
options = {}
|
||||||
)
|
)
|
||||||
repositories = repository ? repository : Repository.where(team: user.teams)
|
repositories = repository || Repository.where(team: user.teams)
|
||||||
|
|
||||||
includes_json = { repository_cells: Extends::REPOSITORY_SEARCH_INCLUDES }
|
includes_json = { repository_cells: Extends::REPOSITORY_SEARCH_INCLUDES }
|
||||||
searchable_attributes = ['repository_rows.name', 'users.full_name'] +
|
searchable_attributes = ['repository_rows.name', 'users.full_name'] +
|
||||||
Extends::REPOSITORY_EXTRA_SEARCH_ATTR
|
Extends::REPOSITORY_EXTRA_SEARCH_ATTR
|
||||||
|
|
||||||
|
all_rows = RepositoryRow.where(repository: repositories)
|
||||||
|
|
||||||
new_query = RepositoryRow
|
new_query = RepositoryRow
|
||||||
|
.distinct
|
||||||
|
.from(all_rows, 'repository_rows')
|
||||||
.left_outer_joins(:created_by)
|
.left_outer_joins(:created_by)
|
||||||
.left_outer_joins(includes_json)
|
.left_outer_joins(includes_json)
|
||||||
.where(repository: repositories)
|
|
||||||
.where_attributes_like(searchable_attributes, query, options)
|
.where_attributes_like(searchable_attributes, query, options)
|
||||||
|
|
||||||
# Show all results if needed
|
# Show all results if needed
|
||||||
|
@ -56,7 +59,6 @@ class Repository < ApplicationRecord
|
||||||
.group('repositories.id')
|
.group('repositories.id')
|
||||||
else
|
else
|
||||||
new_query
|
new_query
|
||||||
.distinct
|
|
||||||
.limit(Constants::SEARCH_LIMIT)
|
.limit(Constants::SEARCH_LIMIT)
|
||||||
.offset((page - 1) * Constants::SEARCH_LIMIT)
|
.offset((page - 1) * Constants::SEARCH_LIMIT)
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue