biovision-base 0.9.171227 → 0.11.180127
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/app/assets/javascripts/biovision/base/biovision-sliders.js +3 -17
- data/app/assets/javascripts/biovision/base/biovision.js +17 -5
- data/app/assets/stylesheets/biovision/base/admin.scss +0 -12
- data/app/assets/stylesheets/biovision/base/biovision.scss +2 -179
- data/app/assets/stylesheets/biovision/base/default_admin.scss +0 -1
- data/app/controllers/admin/privileges_controller.rb +0 -6
- data/app/controllers/admin/users_controller.rb +2 -2
- data/app/models/editable_page.rb +41 -3
- data/app/models/feedback_request.rb +1 -0
- data/app/models/language.rb +49 -0
- data/app/models/privilege.rb +16 -16
- data/app/models/user.rb +3 -2
- data/app/models/user_language.rb +6 -0
- data/app/models/user_privilege.rb +3 -14
- data/app/views/admin/agents/entity/_in_list.html.erb +1 -1
- data/app/views/admin/agents/index.html.erb +1 -1
- data/app/views/admin/agents/show.html.erb +2 -2
- data/app/views/admin/browsers/entity/_in_list.html.erb +2 -1
- data/app/views/admin/browsers/index.html.erb +1 -1
- data/app/views/admin/browsers/show.html.erb +2 -2
- data/app/views/admin/codes/index.html.erb +1 -1
- data/app/views/admin/codes/show.html.erb +1 -1
- data/app/views/admin/editable_pages/index.html.erb +1 -1
- data/app/views/admin/editable_pages/show.html.erb +1 -1
- data/app/views/admin/index/_biovision_base.html.erb +2 -1
- data/app/views/admin/media_files/show.html.erb +0 -1
- data/app/views/admin/metrics/index.html.erb +1 -1
- data/app/views/admin/metrics/show.html.erb +1 -1
- data/app/views/admin/privilege_groups/index.html.erb +1 -1
- data/app/views/admin/privilege_groups/show.html.erb +1 -1
- data/app/views/admin/privileges/entity/_in_list.html.erb +1 -1
- data/app/views/admin/privileges/index.html.erb +1 -1
- data/app/views/admin/privileges/show.html.erb +2 -2
- data/app/views/admin/privileges/users.html.erb +1 -1
- data/app/views/admin/stored_values/index.html.erb +1 -1
- data/app/views/admin/tokens/entity/_in_list.html.erb +1 -1
- data/app/views/admin/tokens/index.html.erb +1 -1
- data/app/views/admin/tokens/show.html.erb +2 -2
- data/app/views/admin/users/codes.html.erb +1 -1
- data/app/views/admin/users/entity/_in_list.html.erb +2 -1
- data/app/views/admin/users/entity/_privilege.html.erb +1 -1
- data/app/views/admin/users/index.html.erb +1 -1
- data/app/views/admin/users/show.html.erb +4 -4
- data/app/views/admin/users/tokens.html.erb +1 -1
- data/app/views/agents/edit.html.erb +1 -1
- data/app/views/agents/new.html.erb +1 -1
- data/app/views/application/error.html.erb +1 -1
- data/app/views/browsers/edit.html.erb +1 -1
- data/app/views/browsers/new.html.erb +1 -1
- data/app/views/codes/edit.html.erb +1 -1
- data/app/views/codes/new.html.erb +1 -1
- data/app/views/editable_pages/edit.html.erb +1 -1
- data/app/views/editable_pages/new.html.erb +1 -1
- data/app/views/errors/error.html.erb +1 -1
- data/app/views/feedback_requests/_form.html.erb +1 -3
- data/app/views/feedback_requests/create.js.erb +2 -2
- data/app/views/layouts/admin/_footer.html.erb +1 -1
- data/app/views/layouts/admin/_header.html.erb +3 -3
- data/app/views/metrics/edit.html.erb +1 -1
- data/app/views/privilege_groups/edit.html.erb +1 -1
- data/app/views/privilege_groups/new.html.erb +1 -1
- data/app/views/privileges/edit.html.erb +1 -1
- data/app/views/privileges/new.html.erb +1 -1
- data/app/views/shared/forms/_default_ajax_handler.html.erb +2 -0
- data/app/views/stored_values/edit.html.erb +1 -1
- data/app/views/stored_values/new.html.erb +1 -1
- data/app/views/tokens/edit.html.erb +1 -1
- data/app/views/tokens/new.html.erb +1 -1
- data/app/views/users/edit.html.erb +1 -1
- data/config/locales/common-en.yml +10 -2
- data/config/locales/common-ru.yml +10 -2
- data/config/locales/editable-pages-en.yml +76 -0
- data/config/locales/editable-pages-ru.yml +1 -0
- data/config/locales/feedback-en.yml +1 -0
- data/config/locales/feedback-ru.yml +1 -0
- data/config/locales/media-en.yml +92 -0
- data/config/locales/users-ru.yml +1 -0
- data/config/routes.rb +0 -10
- data/db/migrate/20170228000000_create_languages.rb +22 -0
- data/db/migrate/20170302000001_create_users.rb +2 -1
- data/db/migrate/20170302000101_create_privileges.rb +7 -6
- data/db/migrate/20170302000102_create_user_privileges.rb +1 -1
- data/db/migrate/20170302000103_create_privilege_groups.rb +0 -1
- data/db/migrate/20170302000104_create_privilege_group_privileges.rb +0 -4
- data/db/migrate/20170320000000_create_editable_pages.rb +12 -3
- data/db/migrate/20171025222222_add_new_fields_171026.rb +0 -8
- data/db/migrate/20171211000000_create_feedback_requests.rb +1 -0
- data/db/migrate/20171223333333_amend_foreign_keys.rb +1 -3
- data/db/migrate/20180117151515_add_language_to_models.rb +25 -0
- data/db/migrate/20180117160000_create_user_languages.rb +17 -0
- data/lib/biovision/base/base_methods.rb +1 -1
- data/lib/biovision/base/engine.rb +0 -1
- data/lib/biovision/base/privilege_methods.rb +3 -21
- data/lib/biovision/base/version.rb +1 -1
- metadata +13 -34
- data/app/assets/images/biovision/base/placeholders/region_image.svg +0 -1
- data/app/assets/stylesheets/biovision/base/regions.scss +0 -9
- data/app/controllers/admin/regions_controller.rb +0 -28
- data/app/controllers/regions_controller.rb +0 -73
- data/app/helpers/biovision_regions_helper.rb +0 -22
- data/app/models/central_region.rb +0 -53
- data/app/models/region.rb +0 -110
- data/app/uploaders/header_image_uploader.rb +0 -50
- data/app/uploaders/region_image_uploader.rb +0 -53
- data/app/views/admin/agents/_toggleable.html.erb +0 -7
- data/app/views/admin/browsers/_toggleable.html.erb +0 -7
- data/app/views/admin/index/dashboard/_biovision_region.html.erb +0 -8
- data/app/views/admin/privileges/_toggleable.html.erb +0 -7
- data/app/views/admin/privileges/entity/_region.html.erb +0 -12
- data/app/views/admin/privileges/regions.jbuilder +0 -10
- data/app/views/admin/regions/_nav_item.html.erb +0 -2
- data/app/views/admin/regions/_toggleable.html.erb +0 -7
- data/app/views/admin/regions/entity/_in_list.html.erb +0 -32
- data/app/views/admin/regions/index.html.erb +0 -22
- data/app/views/admin/regions/show.html.erb +0 -95
- data/app/views/admin/tokens/_toggleable.html.erb +0 -7
- data/app/views/admin/users/_toggleable.html.erb +0 -7
- data/app/views/regions/_form.html.erb +0 -73
- data/app/views/regions/edit.html.erb +0 -20
- data/app/views/regions/new.html.erb +0 -17
- data/config/locales/regions-ru.yml +0 -62
- data/db/migrate/20170301000201_create_regions.rb +0 -35
- data/lib/tasks/regions.rake +0 -105
@@ -0,0 +1,49 @@
|
|
1
|
+
class Language < ApplicationRecord
|
2
|
+
SLUG_LIMIT = 20
|
3
|
+
CODE_LIMIT = 8
|
4
|
+
PRIORITY_RANGE = (1..999)
|
5
|
+
|
6
|
+
has_many :users, dependent: :nullify
|
7
|
+
has_many :user_languages, dependent: :delete_all
|
8
|
+
has_many :editable_pages, dependent: :nullify
|
9
|
+
has_many :feedback_requests, dependent: :nullify
|
10
|
+
|
11
|
+
after_initialize :set_next_priority
|
12
|
+
|
13
|
+
before_validation :normalize_priority
|
14
|
+
|
15
|
+
validates_presence_of :code, :slug
|
16
|
+
validates_format_of :code, with: /\A[a-z][a-z_]*[a-z]\z/i
|
17
|
+
validates_format_of :slug, with: /\A[a-z][a-z_]+[a-z]\z/
|
18
|
+
validates_length_of :code, maximum: CODE_LIMIT
|
19
|
+
validates_length_of :slug, maximum: SLUG_LIMIT
|
20
|
+
validates_uniqueness_of :code
|
21
|
+
validates_uniqueness_of :slug
|
22
|
+
|
23
|
+
scope :ordered_by_priority, -> { order('priority asc') }
|
24
|
+
|
25
|
+
# @param [Integer] delta
|
26
|
+
def change_priority(delta)
|
27
|
+
new_priority = priority + delta
|
28
|
+
adjacent = self.class.find_by(priority: new_priority)
|
29
|
+
if adjacent.is_a?(self.class) && (adjacent.id != id)
|
30
|
+
adjacent.update!(priority: priority)
|
31
|
+
end
|
32
|
+
update(priority: new_priority)
|
33
|
+
|
34
|
+
self.class.ordered_by_priority.map { |e| [e.id, e.priority] }.to_h
|
35
|
+
end
|
36
|
+
|
37
|
+
private
|
38
|
+
|
39
|
+
def set_next_priority
|
40
|
+
if id.nil? && priority == 1
|
41
|
+
self.priority = self.class.maximum(:priority).to_i + 1
|
42
|
+
end
|
43
|
+
end
|
44
|
+
|
45
|
+
def normalize_priority
|
46
|
+
self.priority = PRIORITY_RANGE.first if priority < PRIORITY_RANGE.first
|
47
|
+
self.priority = PRIORITY_RANGE.last if priority > PRIORITY_RANGE.last
|
48
|
+
end
|
49
|
+
end
|
data/app/models/privilege.rb
CHANGED
@@ -91,33 +91,33 @@ class Privilege < ApplicationRecord
|
|
91
91
|
end
|
92
92
|
|
93
93
|
# @param [User] user
|
94
|
-
# @param [
|
95
|
-
def has_user?(user,
|
94
|
+
# @param [Array] region_ids
|
95
|
+
def has_user?(user, region_ids = [])
|
96
96
|
return false if user.nil?
|
97
97
|
return true if user.super_user?
|
98
98
|
result = user_in_non_regional_branch?(user)
|
99
99
|
|
100
|
-
if regional? &&
|
101
|
-
result = user_in_regional_branch?(user,
|
100
|
+
if regional? && region_ids.any? && !result
|
101
|
+
result = user_in_regional_branch?(user, region_ids)
|
102
102
|
end
|
103
103
|
result
|
104
104
|
end
|
105
105
|
|
106
106
|
# @param [User] user
|
107
|
-
# @param [
|
108
|
-
def grant(user,
|
107
|
+
# @param [Integer] region_id
|
108
|
+
def grant(user, region_id = nil)
|
109
109
|
return if user.nil?
|
110
|
-
criteria
|
111
|
-
criteria[:
|
110
|
+
criteria = { privilege: self, user: user }
|
111
|
+
criteria[:region_id] = region_id if regional?
|
112
112
|
UserPrivilege.create(criteria) unless UserPrivilege.exists?(criteria)
|
113
113
|
end
|
114
114
|
|
115
115
|
# @param [User] user
|
116
|
-
# @param [
|
117
|
-
def revoke(user,
|
116
|
+
# @param [Integer] region_id
|
117
|
+
def revoke(user, region_id = nil)
|
118
118
|
return if user.nil?
|
119
|
-
criteria
|
120
|
-
criteria[:
|
119
|
+
criteria = { privilege: self, user: user }
|
120
|
+
criteria[:region_id] = region_id if regional?
|
121
121
|
UserPrivilege.where(criteria).delete_all
|
122
122
|
end
|
123
123
|
|
@@ -161,14 +161,14 @@ class Privilege < ApplicationRecord
|
|
161
161
|
end
|
162
162
|
|
163
163
|
# @param [User] user
|
164
|
-
# @param [
|
165
|
-
def user_in_regional_branch?(user,
|
164
|
+
# @param [Array] region_ids
|
165
|
+
def user_in_regional_branch?(user, region_ids)
|
166
166
|
selected_ids = Privilege.where(regional: true, id: branch_ids).pluck(:id)
|
167
167
|
if selected_ids.any?
|
168
168
|
criteria = {
|
169
169
|
privilege_id: selected_ids,
|
170
|
-
region_id:
|
171
|
-
user:
|
170
|
+
region_id: region_ids,
|
171
|
+
user: user
|
172
172
|
}
|
173
173
|
UserPrivilege.exists?(criteria)
|
174
174
|
else
|
data/app/models/user.rb
CHANGED
@@ -19,9 +19,9 @@ class User < ApplicationRecord
|
|
19
19
|
|
20
20
|
mount_uploader :image, AvatarUploader
|
21
21
|
|
22
|
+
belongs_to :language, optional: true, counter_cache: true
|
22
23
|
belongs_to :agent, optional: true
|
23
24
|
belongs_to :inviter, class_name: User.to_s, optional: true
|
24
|
-
belongs_to :region, optional: true, counter_cache: true
|
25
25
|
has_one :user_profile, dependent: :destroy
|
26
26
|
has_many :invitees, class_name: User.to_s, foreign_key: :inviter_id, dependent: :nullify
|
27
27
|
has_many :tokens, dependent: :delete_all
|
@@ -30,6 +30,7 @@ class User < ApplicationRecord
|
|
30
30
|
has_many :privileges, through: :user_privileges
|
31
31
|
has_many :foreign_users, dependent: :delete_all
|
32
32
|
has_many :login_attempts, dependent: :delete_all
|
33
|
+
has_many :user_languages, dependent: :delete_all
|
33
34
|
|
34
35
|
before_save :normalize_slug
|
35
36
|
before_save :prepare_search_string
|
@@ -56,7 +57,7 @@ class User < ApplicationRecord
|
|
56
57
|
|
57
58
|
# @param [Integer] page
|
58
59
|
# @param [String] search_query
|
59
|
-
def self.page_for_administration(page, search_query)
|
60
|
+
def self.page_for_administration(page, search_query = '')
|
60
61
|
search(search_query).order('id desc').page(page).per(PER_PAGE)
|
61
62
|
end
|
62
63
|
|
@@ -3,7 +3,6 @@ class UserPrivilege < ApplicationRecord
|
|
3
3
|
|
4
4
|
belongs_to :user
|
5
5
|
belongs_to :privilege, counter_cache: :users_count
|
6
|
-
belongs_to :region, optional: true
|
7
6
|
|
8
7
|
validates_uniqueness_of :privilege_id, scope: [:user_id, :region_id]
|
9
8
|
|
@@ -17,12 +16,12 @@ class UserPrivilege < ApplicationRecord
|
|
17
16
|
|
18
17
|
# @param [User] user
|
19
18
|
# @param [String|Symbol] privilege_name
|
20
|
-
# @param [
|
21
|
-
def self.user_has_privilege?(user, privilege_name,
|
19
|
+
# @param [Array] region_ids
|
20
|
+
def self.user_has_privilege?(user, privilege_name, region_ids = [])
|
22
21
|
return false if user.nil?
|
23
22
|
return true if user.super_user?
|
24
23
|
privilege = Privilege.find_by(slug: privilege_name)
|
25
|
-
privilege&.has_user?(user,
|
24
|
+
privilege&.has_user?(user, region_ids)
|
26
25
|
end
|
27
26
|
|
28
27
|
# @param [User] user
|
@@ -41,14 +40,4 @@ class UserPrivilege < ApplicationRecord
|
|
41
40
|
return false if privilege_ids.blank?
|
42
41
|
exists?(user: user, privilege_id: privilege_ids)
|
43
42
|
end
|
44
|
-
|
45
|
-
private
|
46
|
-
|
47
|
-
def regional_ids(region)
|
48
|
-
|
49
|
-
end
|
50
|
-
|
51
|
-
def simple_ids
|
52
|
-
|
53
|
-
end
|
54
43
|
end
|
@@ -3,7 +3,7 @@
|
|
3
3
|
<% unless entity.browser.nil? %>
|
4
4
|
<div class="info"><%= admin_browser_link(entity.browser) %></div>
|
5
5
|
<% end %>
|
6
|
-
<%= render partial: 'admin/
|
6
|
+
<%= render partial: 'shared/admin/toggleable', locals: { entity: entity, url: toggle_admin_agent_path(entity.id) } %>
|
7
7
|
<ul class="actions">
|
8
8
|
<li class="lockable <%= entity.locked? ? 'hidden' : '' %>">
|
9
9
|
<%= edit_icon edit_agent_path(entity) %>
|
@@ -4,7 +4,7 @@
|
|
4
4
|
<span><%= @entity.name %></span>
|
5
5
|
<% end %>
|
6
6
|
|
7
|
-
<article
|
7
|
+
<article>
|
8
8
|
<h1><%= @entity.name %></h1>
|
9
9
|
|
10
10
|
<ul class="actions">
|
@@ -24,5 +24,5 @@
|
|
24
24
|
</dl>
|
25
25
|
<% end %>
|
26
26
|
|
27
|
-
<%= render partial: 'admin/
|
27
|
+
<%= render partial: 'shared/admin/toggleable', locals: { entity: @entity, url: toggle_admin_agent_path(@entity.id) } %>
|
28
28
|
</article>
|
@@ -3,7 +3,8 @@
|
|
3
3
|
<div class="info">
|
4
4
|
<%= t(:agent_count, count: entity.agents_count) %>
|
5
5
|
</div>
|
6
|
-
<%= render partial: 'admin/
|
6
|
+
<%= render partial: 'shared/admin/toggleable', locals: { entity: entity, url: toggle_admin_browser_path(entity.id) } %>
|
7
|
+
|
7
8
|
<ul class="actions">
|
8
9
|
<li class="lockable <%= entity.locked? ? 'hidden' : '' %>">
|
9
10
|
<%= edit_icon edit_browser_path(entity.id) %>
|
@@ -4,7 +4,7 @@
|
|
4
4
|
<span><%= @entity.name %></span>
|
5
5
|
<% end %>
|
6
6
|
|
7
|
-
<article
|
7
|
+
<article>
|
8
8
|
<h1><%= @entity.name %></h1>
|
9
9
|
<ul class="actions">
|
10
10
|
<li><%= create_icon new_browser_path %></li>
|
@@ -15,7 +15,7 @@
|
|
15
15
|
<% end %>
|
16
16
|
</ul>
|
17
17
|
|
18
|
-
<%= render partial: 'admin/
|
18
|
+
<%= render partial: 'shared/admin/toggleable', locals: { entity: @entity, url: toggle_admin_browser_path(@entity.id) } %>
|
19
19
|
|
20
20
|
<section id="browser-agents">
|
21
21
|
<h2><%= t('admin.agents.index.heading') %></h2>
|
@@ -1,6 +1,7 @@
|
|
1
1
|
<%= render 'admin/index/dashboard/settings' %>
|
2
2
|
<%= render 'admin/index/dashboard/biovision_track' %>
|
3
|
-
<%= render 'admin/index/dashboard/
|
3
|
+
<%= render 'admin/index/dashboard/biovision_regions' if Gem.loaded_specs.key?('biovision-regions') %>
|
4
4
|
<%= render 'admin/index/dashboard/biovision_user' %>
|
5
5
|
<%= render 'admin/index/dashboard/editorial' %>
|
6
|
+
<%= render 'admin/index/dashboard/biovision_post' if Gem.loaded_specs.key?('biovision-post') %>
|
6
7
|
<%= render 'admin/index/dashboard/biovision_feedback' %>
|
@@ -8,7 +8,7 @@
|
|
8
8
|
<div><%= entity.privilege_groups.map(&:name).join(', ') %></div>
|
9
9
|
<div><%= link_to t(:user_count, count: entity.users_count), users_admin_privilege_path(entity.id) %></div>
|
10
10
|
</div>
|
11
|
-
<%= render partial: 'admin/
|
11
|
+
<%= render partial: 'shared/admin/toggleable', locals: { entity: entity, url: toggle_admin_privilege_path(entity.id) } %>
|
12
12
|
|
13
13
|
<ul class="actions">
|
14
14
|
<li class="lockable <%= entity.locked? ? 'hidden' : '' %>">
|
@@ -7,7 +7,7 @@
|
|
7
7
|
<span><%= @entity.name %></span>
|
8
8
|
<% end %>
|
9
9
|
|
10
|
-
<article
|
10
|
+
<article>
|
11
11
|
<h1><%= @entity.name %></h1>
|
12
12
|
|
13
13
|
<ul class="actions">
|
@@ -44,7 +44,7 @@
|
|
44
44
|
<% end %>
|
45
45
|
</dl>
|
46
46
|
|
47
|
-
<%= render partial: 'admin/
|
47
|
+
<%= render partial: 'shared/admin/toggleable', locals: { entity: @entity, url: toggle_admin_privilege_path(@entity.id) } %>
|
48
48
|
|
49
49
|
<nav>
|
50
50
|
<ul>
|
@@ -17,7 +17,7 @@
|
|
17
17
|
<div class="truncate"><%= entity.agent.name %></div>
|
18
18
|
<% end %>
|
19
19
|
</div>
|
20
|
-
<%= render partial: 'admin/
|
20
|
+
<%= render partial: 'shared/admin/toggleable', locals: { entity: entity, url: toggle_admin_token_path(entity.id) } %>
|
21
21
|
|
22
22
|
<ul class="actions">
|
23
23
|
<li><%= edit_icon edit_token_path(entity) %></li>
|