biovision-base 0.22.180920.0 → 0.34.190331.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/README.md +5 -21
- data/app/assets/images/biovision/base/icons/apply.svg +4 -0
- data/app/assets/images/biovision/base/icons/components/contact.svg +26 -0
- data/app/assets/images/biovision/base/icons/components/registration.svg +17 -0
- data/app/assets/images/biovision/base/icons/destroy.svg +11 -8
- data/app/assets/images/biovision/base/icons/settings.svg +41 -0
- data/app/assets/images/biovision/base/icons/slider/arrow-left.svg +4 -0
- data/app/assets/images/biovision/base/icons/slider/arrow-right.svg +4 -0
- data/app/assets/images/biovision/base/placeholders/16x9.svg +10 -3
- data/app/assets/images/biovision/base/placeholders/1x1.svg +12 -0
- data/app/assets/images/biovision/base/placeholders/3x2.svg +10 -3
- data/app/assets/javascripts/biovision/base/biovision.js +780 -461
- data/app/assets/javascripts/biovision/base/components/carousel.js +123 -0
- data/app/assets/javascripts/biovision/base/polyfills.js +149 -0
- data/app/assets/stylesheets/biovision/base/admin.scss +85 -46
- data/app/assets/stylesheets/biovision/base/admin/components.scss +141 -0
- data/app/assets/stylesheets/biovision/base/biovision.scss +149 -33
- data/app/assets/stylesheets/biovision/base/buttons/buttons-common.scss +22 -0
- data/app/assets/stylesheets/biovision/base/default.scss +6 -6
- data/app/assets/stylesheets/biovision/base/default_admin.scss +25 -8
- data/app/assets/stylesheets/biovision/base/themes/simple-layout.scss +0 -3
- data/app/controllers/admin/editable_pages_controller.rb +6 -4
- data/app/controllers/admin/privileges_controller.rb +2 -3
- data/app/controllers/admin/settings_controller.rb +52 -0
- data/app/controllers/admin/simple_blocks_controller.rb +28 -0
- data/app/controllers/admin/users_controller.rb +1 -1
- data/app/controllers/agents_controller.rb +4 -4
- data/app/controllers/authentication_controller.rb +28 -6
- data/app/controllers/browsers_controller.rb +4 -4
- data/app/controllers/concerns/authentication.rb +8 -5
- data/app/controllers/concerns/entity_priority.rb +3 -0
- data/app/controllers/concerns/lockable_entity.rb +6 -3
- data/app/controllers/concerns/removable_image.rb +4 -5
- data/app/controllers/concerns/toggleable_entity.rb +4 -5
- data/app/controllers/editable_pages_controller.rb +14 -8
- data/app/controllers/fallback_controller.rb +7 -2
- data/app/controllers/feedback_requests_controller.rb +23 -8
- data/app/controllers/metrics_controller.rb +3 -3
- data/app/controllers/my/profiles_controller.rb +32 -15
- data/app/controllers/privilege_groups_controller.rb +4 -4
- data/app/controllers/privileges_controller.rb +7 -26
- data/app/controllers/simple_blocks_controller.rb +63 -0
- data/app/controllers/stored_values_controller.rb +4 -4
- data/app/controllers/tokens_controller.rb +4 -4
- data/app/controllers/users_controller.rb +8 -3
- data/app/helpers/biovision_users_helper.rb +60 -21
- data/app/helpers/editable_pages_helper.rb +22 -0
- data/app/helpers/languages_helper.rb +3 -0
- data/app/helpers/simple_image_helper.rb +66 -0
- data/app/mailers/application_mailer.rb +0 -2
- data/app/mailers/code_sender.rb +13 -2
- data/app/mailers/feedback_mailer.rb +5 -2
- data/app/mailers/user_mailer.rb +6 -1
- data/app/models/biovision_component.rb +43 -0
- data/app/models/biovision_parameter.rb +34 -0
- data/app/models/code.rb +22 -7
- data/app/models/code_type.rb +9 -1
- data/app/models/concerns/flat_priority.rb +50 -0
- data/app/models/concerns/nested_priority.rb +58 -0
- data/app/models/concerns/required_unique_slug.rb +5 -2
- data/app/models/editable_page.rb +49 -37
- data/app/models/foreign_site.rb +5 -3
- data/app/models/language.rb +15 -37
- data/app/models/metric.rb +2 -4
- data/app/models/privilege.rb +23 -45
- data/app/models/privilege_group.rb +6 -1
- data/app/models/simple_block.rb +66 -0
- data/app/models/user.rb +29 -26
- data/app/models/user_privilege.rb +1 -1
- data/app/services/biovision/components/base_component.rb +115 -0
- data/app/services/biovision/components/registration_component.rb +98 -0
- data/app/services/code_manager.rb +4 -1
- data/app/services/code_manager/confirmation.rb +8 -4
- data/app/services/code_manager/invitation.rb +9 -5
- data/app/services/code_manager/recovery.rb +9 -6
- data/app/services/user_manager.rb +5 -4
- data/app/services/user_profile_handler.rb +38 -11
- data/app/uploaders/avatar_uploader.rb +5 -1
- data/app/uploaders/editable_page_image_uploader.rb +4 -6
- data/app/uploaders/media_file_uploader.rb +6 -4
- data/app/uploaders/media_snapshot_uploader.rb +6 -2
- data/app/uploaders/simple_file_uploader.rb +12 -0
- data/app/uploaders/simple_image_uploader.rb +75 -0
- data/app/views/about/editable.html.erb +1 -1
- data/app/views/admin/agents/_filter.html.erb +1 -1
- data/app/views/admin/editable_pages/entity/_in_list.html.erb +16 -0
- data/app/views/admin/editable_pages/index.html.erb +8 -1
- data/app/views/admin/editable_pages/show.html.erb +21 -17
- data/app/views/admin/feedback_requests/entity/_in_list.html.erb +9 -1
- data/app/views/admin/index/_biovision_base.html.erb +5 -7
- data/app/views/admin/index/_components.html.erb +9 -0
- data/app/views/admin/index/dashboard/_editorial.html.erb +2 -2
- data/app/views/admin/index/dashboard/_settings.html.erb +2 -2
- data/app/views/admin/index/index.html.erb +2 -0
- data/app/views/admin/privileges/entity/_groups.html.erb +25 -25
- data/app/views/admin/privileges/entity/_in_list.html.erb +30 -9
- data/app/views/admin/privileges/index.html.erb +6 -1
- data/app/views/admin/privileges/show.html.erb +31 -18
- data/app/views/admin/settings/component/_new_parameter.html.erb +62 -0
- data/app/views/admin/settings/component/_parameters.html.erb +37 -0
- data/app/views/admin/settings/component/_setting.html.erb +18 -0
- data/app/views/admin/settings/component/_settings.html.erb +31 -0
- data/app/views/admin/settings/index.html.erb +27 -0
- data/app/views/admin/settings/show.html.erb +42 -0
- data/app/views/admin/simple_blocks/_nav_item.html.erb +6 -0
- data/app/views/admin/simple_blocks/entity/_in_list.html.erb +23 -0
- data/app/views/admin/simple_blocks/index.html.erb +21 -0
- data/app/views/admin/simple_blocks/show.html.erb +51 -0
- data/app/views/admin/tokens/_filter.html.erb +1 -1
- data/app/views/admin/users/_filter.html.erb +1 -1
- data/app/views/admin/users/entity/_privilege.html.erb +12 -21
- data/app/views/admin/users/entity/_privilege_tree.html.erb +17 -15
- data/app/views/admin/users/privileges.html.erb +9 -1
- data/app/views/admin/users/search.jbuilder +3 -3
- data/app/views/admin/users/show.html.erb +11 -6
- data/app/views/agents/_filter.html.erb +22 -22
- data/app/views/agents/_form.html.erb +25 -29
- data/app/views/application/forbidden.html.erb +9 -0
- data/app/views/application/forbidden.jbuilder +3 -0
- data/app/views/authentication/_form.html.erb +13 -13
- data/app/views/browsers/_form.html.erb +21 -25
- data/app/views/editable_blocks/_entity.html.erb +4 -1
- data/app/views/editable_pages/_form.html.erb +63 -62
- data/app/views/editable_pages/edit.html.erb +1 -1
- data/app/views/editable_pages/entity/_metadata.html.erb +4 -4
- data/app/views/editable_pages/new.html.erb +3 -3
- data/app/views/fallback/show.html.erb +8 -1
- data/app/views/feedback_requests/_form.html.erb +76 -52
- data/app/views/feedback_requests/create.js.erb +1 -10
- data/app/views/index/index/_editable.html.erb +0 -4
- data/app/views/metrics/_form.html.erb +38 -36
- data/app/views/my/confirmations/show.html.erb +5 -3
- data/app/views/my/profiles/closed.html.erb +7 -0
- data/app/views/my/profiles/edit/_form.html.erb +9 -9
- data/app/views/my/profiles/new.html.erb +9 -1
- data/app/views/my/profiles/new/_form.html.erb +22 -1
- data/app/views/my/recoveries/show.html.erb +2 -2
- data/app/views/privilege_groups/_form.html.erb +48 -21
- data/app/views/privileges/_form.html.erb +68 -36
- data/app/views/profiles/_profile.html.erb +3 -3
- data/app/views/shared/_pagination.jbuilder +7 -5
- data/app/views/shared/admin/_breadcrumbs.html.erb +1 -1
- data/app/views/shared/forms/_meta_texts.html.erb +3 -3
- data/app/views/shared/forms/_priority.html.erb +12 -0
- data/app/views/shared/forms/_state_container.html.erb +1 -0
- data/app/views/simple_blocks/_empty.html.erb +0 -0
- data/app/views/simple_blocks/_form.html.erb +120 -0
- data/app/views/simple_blocks/_simple_block.html.erb +26 -0
- data/app/views/simple_blocks/edit.html.erb +17 -0
- data/app/views/simple_blocks/new.html.erb +15 -0
- data/app/views/stored_values/_form.html.erb +57 -28
- data/app/views/tokens/_form.html.erb +31 -26
- data/app/views/users/_form.html.erb +1 -1
- data/config/initializers/carrierwave.rb +7 -2
- data/config/locales/common-ru.yml +5 -0
- data/config/locales/components-ru.yml +50 -0
- data/config/locales/editable-pages-en.yml +2 -0
- data/config/locales/editable-pages-ru.yml +50 -7
- data/config/locales/editable-pages-sv.yml +2 -0
- data/config/locales/feedback-ru.yml +1 -0
- data/config/locales/users-en.yml +0 -1
- data/config/locales/users-ru.yml +6 -1
- data/config/locales/users-sv.yml +0 -1
- data/config/routes.rb +32 -6
- data/db/migrate/20181217000000_create_biovision_components.rb +80 -0
- data/db/migrate/20181217000010_create_metrics.rb +40 -0
- data/db/migrate/20181217000015_create_browsers.rb +38 -0
- data/db/migrate/20181217000020_create_languages.rb +30 -0
- data/db/migrate/20181217000030_create_users.rb +118 -0
- data/db/migrate/20181217000035_create_codes.rb +51 -0
- data/db/migrate/20181217000040_create_privileges.rb +142 -0
- data/db/migrate/20181217000100_create_media_folders.rb +53 -0
- data/db/migrate/20181217000110_create_editable_pages.rb +90 -0
- data/db/migrate/20181217000200_create_feedback_requests.rb +27 -0
- data/db/migrate/20181217121211_add_uuid_to_users.rb +12 -0
- data/db/migrate/20181217121212_update_fields181217.rb +29 -0
- data/db/migrate/20190311121212_convert_json_columns.rb +47 -0
- data/db/migrate/20190324181818_add_data_to_feedback_requests.rb +14 -0
- data/db/migrate/20190326120000_create_simple_blocks.rb +31 -0
- data/db/{migrate → obsolete_migrations}/20171223333333_amend_foreign_keys.rb +0 -0
- data/db/{migrate → obsolete_migrations}/20180117151515_add_language_to_models.rb +0 -0
- data/db/{migrate → obsolete_migrations}/20180321000000_add_profile_data_to_users.rb +4 -4
- data/db/{migrate → obsolete_migrations}/20180405000000_add_consent_to_users.rb +0 -0
- data/db/{migrate → obsolete_migrations}/20180610222222_add_consent_to_feedback_requests.rb +0 -0
- data/db/{migrate → obsolete_migrations}/20180612111111_add_administrative_to_privilege.rb +0 -0
- data/db/{migrate → obsolete_migrations}/20180619121212_add_image_alt_text_to_editable_page.rb +0 -0
- data/db/{migrate → obsolete_migrations}/20180703111111_add_fields_to_editable_blocks.rb +0 -0
- data/db/{migrate → obsolete_migrations}/20180722222222_add_active_to_languages.rb +0 -0
- data/db/{migrate → obsolete_migrations}/20180725111111_add_referral_link_to_users.rb +0 -0
- data/db/obsolete_migrations/20181012222222_add_deletable_to_privileges.rb +19 -0
- data/db/obsolete_migrations/20181012222223_convert_stored_values.rb +13 -0
- data/db/obsolete_migrations/20181030080808_update_editable_pages_meta.rb +20 -0
- data/lib/biovision/base/base_methods.rb +19 -2
- data/lib/biovision/base/version.rb +3 -1
- data/lib/tasks/users.rake +19 -1
- metadata +75 -40
- data/app/views/admin/privileges/_list.html.erb +0 -15
- data/db/migrate/20170228000000_create_languages.rb +0 -23
- data/db/migrate/20170301000001_create_metrics.rb +0 -23
- data/db/migrate/20170301000002_create_metric_values.rb +0 -19
- data/db/migrate/20170301000101_create_browsers.rb +0 -22
- data/db/migrate/20170301000102_create_agents.rb +0 -22
- data/db/migrate/20170302000001_create_users.rb +0 -55
- data/db/migrate/20170302000003_create_tokens.rb +0 -23
- data/db/migrate/20170302000004_create_code_types.rb +0 -20
- data/db/migrate/20170302000005_create_codes.rb +0 -24
- data/db/migrate/20170302000101_create_privileges.rb +0 -41
- data/db/migrate/20170302000102_create_user_privileges.rb +0 -18
- data/db/migrate/20170302000103_create_privilege_groups.rb +0 -23
- data/db/migrate/20170302000104_create_privilege_group_privileges.rb +0 -24
- data/db/migrate/20170320000000_create_editable_pages.rb +0 -52
- data/db/migrate/20170425000001_create_foreign_sites.rb +0 -18
- data/db/migrate/20170425000002_create_foreign_users.rb +0 -23
- data/db/migrate/20170629120000_create_login_attempts.rb +0 -19
- data/db/migrate/20170823000001_create_stored_values.rb +0 -19
- data/db/migrate/20171202000000_create_media_folders.rb +0 -28
- data/db/migrate/20171202000001_create_media_files.rb +0 -27
- data/db/migrate/20171211000000_create_feedback_requests.rb +0 -33
- data/db/migrate/20180117160000_create_user_languages.rb +0 -17
- data/db/migrate/20180622140000_create_link_blocks.rb +0 -29
- data/db/migrate/20180622140001_create_link_block_items.rb +0 -23
- data/db/migrate/20180627190000_create_editable_blocks.rb +0 -39
data/app/models/code_type.rb
CHANGED
@@ -1,11 +1,19 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
# Code type
|
4
|
+
#
|
5
|
+
# Attributes:
|
6
|
+
# - name [String]
|
7
|
+
# - slug [String]
|
1
8
|
class CodeType < ApplicationRecord
|
2
9
|
include RequiredUniqueName
|
3
10
|
include RequiredUniqueSlug
|
4
11
|
|
5
|
-
SLUG_LIMIT = 20
|
6
12
|
NAME_LIMIT = 100
|
13
|
+
SLUG_LIMIT = 20
|
7
14
|
|
8
15
|
validates_length_of :name, maximum: NAME_LIMIT
|
16
|
+
validates_length_of :slug, maximum: SLUG_LIMIT
|
9
17
|
|
10
18
|
has_many :codes, dependent: :delete_all
|
11
19
|
end
|
@@ -0,0 +1,50 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
# Model has flat priority field
|
4
|
+
#
|
5
|
+
# Adds sorting items by priority
|
6
|
+
# @author Maxim Khan-Magomedov <maxim.km@gmail.com>
|
7
|
+
module FlatPriority
|
8
|
+
extend ActiveSupport::Concern
|
9
|
+
|
10
|
+
included do
|
11
|
+
after_initialize :set_next_priority
|
12
|
+
before_validation :normalize_priority
|
13
|
+
|
14
|
+
scope :ordered_by_priority, -> { order('priority asc, id asc') }
|
15
|
+
|
16
|
+
def self.priority_range
|
17
|
+
(1..32_767)
|
18
|
+
end
|
19
|
+
end
|
20
|
+
|
21
|
+
# @param [Integer] delta
|
22
|
+
def change_priority(delta)
|
23
|
+
swap_priority_with_adjacent(priority + delta)
|
24
|
+
|
25
|
+
self.class.ordered_by_priority.map { |e| [e.id, e.priority] }.to_h
|
26
|
+
end
|
27
|
+
|
28
|
+
protected
|
29
|
+
|
30
|
+
# @param [Integer] new_priority
|
31
|
+
def swap_priority_with_adjacent(new_priority)
|
32
|
+
adjacent = self.class.find_by(priority: new_priority)
|
33
|
+
if adjacent.is_a?(self.class) && (adjacent.id != id)
|
34
|
+
adjacent.update!(priority: priority)
|
35
|
+
end
|
36
|
+
update(priority: new_priority)
|
37
|
+
end
|
38
|
+
|
39
|
+
def set_next_priority
|
40
|
+
return unless id.nil? && priority == 1
|
41
|
+
|
42
|
+
self.priority = self.class.maximum(:priority).to_i + 1
|
43
|
+
end
|
44
|
+
|
45
|
+
def normalize_priority
|
46
|
+
range = self.class.priority_range
|
47
|
+
self.priority = range.first if priority < range.first
|
48
|
+
self.priority = range.last if priority > range.last
|
49
|
+
end
|
50
|
+
end
|
@@ -0,0 +1,58 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
# Model has nested priority field
|
4
|
+
#
|
5
|
+
# Adds sorting items by priority with siblings
|
6
|
+
# @author Maxim Khan-Magomedov <maxim.km@gmail.com>
|
7
|
+
module NestedPriority
|
8
|
+
extend ActiveSupport::Concern
|
9
|
+
|
10
|
+
included do
|
11
|
+
after_initialize :set_next_priority
|
12
|
+
before_validation :normalize_priority
|
13
|
+
|
14
|
+
scope :ordered_by_priority, -> { order('priority asc, id asc') }
|
15
|
+
|
16
|
+
def self.priority_range
|
17
|
+
(1..32_767)
|
18
|
+
end
|
19
|
+
|
20
|
+
# Change this method in models to get siblings
|
21
|
+
#
|
22
|
+
# @param [ApplicationRecord] _entity
|
23
|
+
def self.siblings(_entity)
|
24
|
+
all
|
25
|
+
end
|
26
|
+
end
|
27
|
+
|
28
|
+
# @param [Integer] delta
|
29
|
+
def change_priority(delta)
|
30
|
+
swap_priority_with_adjacent(priority + delta)
|
31
|
+
|
32
|
+
siblings = self.class.siblings(self)
|
33
|
+
siblings.ordered_by_priority.map { |e| [e.id, e.priority] }.to_h
|
34
|
+
end
|
35
|
+
|
36
|
+
protected
|
37
|
+
|
38
|
+
# @param [Integer] new_priority
|
39
|
+
def swap_priority_with_adjacent(new_priority)
|
40
|
+
adjacent = self.class.siblings(self).find_by(priority: new_priority)
|
41
|
+
if adjacent.is_a?(self.class) && (adjacent.id != id)
|
42
|
+
adjacent.update!(priority: priority)
|
43
|
+
end
|
44
|
+
update(priority: new_priority)
|
45
|
+
end
|
46
|
+
|
47
|
+
def set_next_priority
|
48
|
+
return unless id.nil? && priority == 1
|
49
|
+
|
50
|
+
self.priority = self.class.siblings(self).maximum(:priority).to_i + 1
|
51
|
+
end
|
52
|
+
|
53
|
+
def normalize_priority
|
54
|
+
range = self.class.priority_range
|
55
|
+
self.priority = range.first if priority < range.first
|
56
|
+
self.priority = range.last if priority > range.last
|
57
|
+
end
|
58
|
+
end
|
@@ -1,3 +1,6 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
# Mixin for adding required unique slug constrain
|
1
4
|
module RequiredUniqueSlug
|
2
5
|
extend ActiveSupport::Concern
|
3
6
|
|
@@ -6,7 +9,7 @@ module RequiredUniqueSlug
|
|
6
9
|
validates :slug, uniqueness: { case_sensitive: false }, presence: true
|
7
10
|
|
8
11
|
scope :ordered_by_slug, -> { order('slug asc') }
|
9
|
-
scope :with_slug_like, ->(
|
10
|
-
scope :with_slug, ->(
|
12
|
+
scope :with_slug_like, ->(v) { where('slug ilike ?', "%#{v}%") unless v.blank? }
|
13
|
+
scope :with_slug, ->(v) { where('lower(slug) = lower(?)', v) unless v.blank? }
|
11
14
|
end
|
12
15
|
end
|
data/app/models/editable_page.rb
CHANGED
@@ -1,44 +1,66 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
# Editable page for site
|
4
|
+
#
|
5
|
+
# Attributes:
|
6
|
+
# - body [String]
|
7
|
+
# - image [EditablePageImageUploader], optional
|
8
|
+
# - image_alt_text [String], optional
|
9
|
+
# - language_id [Language]
|
10
|
+
# - meta_description [String], optional
|
11
|
+
# - meta_keywords [String], optional
|
12
|
+
# - meta_title [String], optional
|
13
|
+
# - name [String]
|
14
|
+
# - nav_group [String], optional
|
15
|
+
# - priority [Integer]
|
16
|
+
# - slug [String]
|
17
|
+
# - url [String], optional
|
18
|
+
# - visible [Boolean]
|
1
19
|
class EditablePage < ApplicationRecord
|
2
20
|
include RequiredUniqueName
|
21
|
+
include FlatPriority
|
22
|
+
include MetaTexts
|
23
|
+
include Checkable
|
24
|
+
include Toggleable
|
3
25
|
|
26
|
+
BODY_LIMIT = 65_535
|
27
|
+
META_LIMIT = 255
|
4
28
|
NAME_LIMIT = 100
|
5
29
|
SLUG_LIMIT = 100
|
6
|
-
META_LIMIT = 250
|
7
|
-
BODY_LIMIT = 65535
|
8
30
|
|
9
|
-
|
31
|
+
toggleable :visible
|
10
32
|
|
11
33
|
mount_uploader :image, EditablePageImageUploader
|
12
34
|
|
13
35
|
belongs_to :language, optional: true
|
14
36
|
|
15
|
-
after_initialize :set_next_priority
|
16
37
|
before_validation { self.slug = slug.strip unless slug.nil? }
|
17
|
-
before_validation :normalize_priority
|
18
38
|
|
19
39
|
validates_presence_of :slug
|
40
|
+
validates_uniqueness_of :slug, scope: [:language_id]
|
41
|
+
validates_length_of :body, maximum: BODY_LIMIT
|
42
|
+
validates_length_of :image_alt_text, maximum: META_LIMIT
|
20
43
|
validates_length_of :name, maximum: NAME_LIMIT
|
21
44
|
validates_length_of :slug, maximum: SLUG_LIMIT
|
22
|
-
validates_length_of :
|
23
|
-
validates_length_of :image_alt_text, maximum: META_LIMIT
|
24
|
-
validates_length_of :keywords, maximum: META_LIMIT
|
25
|
-
validates_length_of :description, maximum: META_LIMIT
|
26
|
-
validates_length_of :body, maximum: BODY_LIMIT
|
27
|
-
validates_uniqueness_of :slug, scope: [:language_id]
|
45
|
+
validates_length_of :url, maximum: META_LIMIT
|
28
46
|
|
29
|
-
scope :ordered_by_priority, -> { order('priority asc, slug asc') }
|
30
47
|
scope :ordered_by_slug, -> { order('slug asc') }
|
31
|
-
scope :
|
32
|
-
scope :
|
48
|
+
scope :visible, -> { where(visible: true) }
|
49
|
+
scope :with_slug_like, ->(v) { where('slug ilike ?', "%#{v}%") unless v.blank? }
|
50
|
+
scope :with_slug, ->(v) { where(slug: v) unless v.blank? }
|
51
|
+
scope :for_group, ->(v) { where(nav_group: v) }
|
52
|
+
scope :for_language, ->(v) { where(language: v) }
|
33
53
|
scope :siblings, ->(s) { where(language: s.language, nav_group: s.nav_group) }
|
34
54
|
scope :list_for_administration, -> { ordered_by_priority }
|
55
|
+
scope :list_for_visitors, -> { visible.ordered_by_priority }
|
35
56
|
|
36
57
|
def self.page_for_administration
|
37
58
|
ordered_by_slug
|
38
59
|
end
|
39
60
|
|
40
61
|
def self.entity_parameters
|
41
|
-
%i
|
62
|
+
data = %i[body image image_alt_text language_id name nav_group slug url]
|
63
|
+
data + meta_text_fields
|
42
64
|
end
|
43
65
|
|
44
66
|
# @param [String] slug
|
@@ -62,33 +84,23 @@ class EditablePage < ApplicationRecord
|
|
62
84
|
find_by(url: url, language: language) || find_by(url: url)
|
63
85
|
end
|
64
86
|
|
65
|
-
# @
|
66
|
-
def
|
67
|
-
|
87
|
+
# @deprecated use #meta_title
|
88
|
+
def title
|
89
|
+
name
|
68
90
|
end
|
69
91
|
|
70
|
-
# @
|
71
|
-
def
|
72
|
-
|
73
|
-
adjacent = self.class.find_by(priority: new_priority)
|
74
|
-
if adjacent.is_a?(self.class) && (adjacent.id != id)
|
75
|
-
adjacent.update!(priority: priority)
|
76
|
-
end
|
77
|
-
update(priority: new_priority)
|
78
|
-
|
79
|
-
self.class.ordered_by_priority.map { |e| [e.id, e.priority] }.to_h
|
92
|
+
# @deprecated use #meta_keywords
|
93
|
+
def keywords
|
94
|
+
meta_keywords
|
80
95
|
end
|
81
96
|
|
82
|
-
|
83
|
-
|
84
|
-
|
85
|
-
if id.nil? && priority == 1
|
86
|
-
self.priority = self.class.maximum(:priority).to_i + 1
|
87
|
-
end
|
97
|
+
# @deprecated use #meta_description
|
98
|
+
def description
|
99
|
+
meta_description
|
88
100
|
end
|
89
101
|
|
90
|
-
|
91
|
-
|
92
|
-
|
102
|
+
# @param [User] user
|
103
|
+
def editable_by?(user)
|
104
|
+
UserPrivilege.user_has_privilege?(user, :content_manager)
|
93
105
|
end
|
94
106
|
end
|
data/app/models/foreign_site.rb
CHANGED
@@ -65,9 +65,11 @@ class ForeignSite < ApplicationRecord
|
|
65
65
|
screen_name: screen_name.blank? ? data[:name] : screen_name,
|
66
66
|
password_digest: BCrypt::Engine.hash_secret(password, hash_salt),
|
67
67
|
email_confirmed: true,
|
68
|
-
|
69
|
-
|
70
|
-
|
68
|
+
data: {
|
69
|
+
profile: {
|
70
|
+
name: data[:info][:first_name],
|
71
|
+
surname: data[:info][:last_name]
|
72
|
+
}
|
71
73
|
}
|
72
74
|
}.merge(tracking)
|
73
75
|
|
data/app/models/language.rb
CHANGED
@@ -1,16 +1,20 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
# Language
|
4
|
+
#
|
5
|
+
# Attributes:
|
6
|
+
# active [Boolean]
|
7
|
+
# code [String]
|
8
|
+
# created_at [DateTime]
|
9
|
+
# priority [Integer]
|
10
|
+
# slug [String]
|
11
|
+
# updated_at [DateTime]
|
12
|
+
# users_count [Integer]
|
1
13
|
class Language < ApplicationRecord
|
2
|
-
|
3
|
-
CODE_LIMIT = 8
|
4
|
-
PRIORITY_RANGE = (1..999)
|
14
|
+
include FlatPriority
|
5
15
|
|
6
|
-
|
7
|
-
|
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
|
16
|
+
SLUG_LIMIT = 20
|
17
|
+
CODE_LIMIT = 8
|
14
18
|
|
15
19
|
validates_presence_of :code, :slug
|
16
20
|
validates_format_of :code, with: /\A[a-z][a-z_]*[a-z]\z/i
|
@@ -20,31 +24,5 @@ class Language < ApplicationRecord
|
|
20
24
|
validates_uniqueness_of :code
|
21
25
|
validates_uniqueness_of :slug
|
22
26
|
|
23
|
-
scope :ordered_by_priority, -> { order('priority asc') }
|
24
27
|
scope :active, -> { where(active: true) }
|
25
|
-
|
26
|
-
# @param [Integer] delta
|
27
|
-
def change_priority(delta)
|
28
|
-
new_priority = priority + delta
|
29
|
-
adjacent = self.class.find_by(priority: new_priority)
|
30
|
-
if adjacent.is_a?(self.class) && (adjacent.id != id)
|
31
|
-
adjacent.update!(priority: priority)
|
32
|
-
end
|
33
|
-
update(priority: new_priority)
|
34
|
-
|
35
|
-
self.class.ordered_by_priority.map { |e| [e.id, e.priority] }.to_h
|
36
|
-
end
|
37
|
-
|
38
|
-
private
|
39
|
-
|
40
|
-
def set_next_priority
|
41
|
-
if id.nil? && priority == 1
|
42
|
-
self.priority = self.class.maximum(:priority).to_i + 1
|
43
|
-
end
|
44
|
-
end
|
45
|
-
|
46
|
-
def normalize_priority
|
47
|
-
self.priority = PRIORITY_RANGE.first if priority < PRIORITY_RANGE.first
|
48
|
-
self.priority = PRIORITY_RANGE.last if priority > PRIORITY_RANGE.last
|
49
|
-
end
|
50
28
|
end
|
data/app/models/metric.rb
CHANGED
@@ -1,8 +1,7 @@
|
|
1
1
|
class Metric < ApplicationRecord
|
2
2
|
include RequiredUniqueName
|
3
3
|
|
4
|
-
|
5
|
-
PERIOD_RANGE = (1..365)
|
4
|
+
PERIOD_RANGE = (1..365).freeze
|
6
5
|
|
7
6
|
METRIC_HTTP_400 = 'errors.http.bad_request.hit'
|
8
7
|
METRIC_HTTP_401 = 'errors.http.unauthorized.hit'
|
@@ -15,14 +14,13 @@ class Metric < ApplicationRecord
|
|
15
14
|
has_many :metric_values, dependent: :destroy
|
16
15
|
|
17
16
|
before_validation :normalize_period
|
18
|
-
validates_length_of :description, maximum: DESCRIPTION_LIMIT
|
19
17
|
|
20
18
|
def self.page_for_administration
|
21
19
|
order('name asc')
|
22
20
|
end
|
23
21
|
|
24
22
|
def self.entity_parameters
|
25
|
-
%i
|
23
|
+
%i[incremental start_with_zero show_on_dashboard default_period description]
|
26
24
|
end
|
27
25
|
|
28
26
|
# @param [String] name
|
data/app/models/privilege.rb
CHANGED
@@ -1,15 +1,16 @@
|
|
1
1
|
class Privilege < ApplicationRecord
|
2
|
+
include Checkable
|
2
3
|
include Toggleable
|
3
4
|
|
4
5
|
DESCRIPTION_LIMIT = 350
|
5
6
|
NAME_LIMIT = 250
|
6
7
|
SLUG_LIMIT = 250
|
7
|
-
PRIORITY_RANGE = (1..
|
8
|
+
PRIORITY_RANGE = (1..32_767).freeze
|
8
9
|
|
9
|
-
toggleable :
|
10
|
+
toggleable :administrative
|
10
11
|
|
11
12
|
belongs_to :parent, class_name: Privilege.to_s, optional: true
|
12
|
-
has_many :
|
13
|
+
has_many :child_privileges, class_name: Privilege.to_s, foreign_key: :parent_id
|
13
14
|
has_many :user_privileges, dependent: :destroy
|
14
15
|
has_many :users, through: :user_privileges
|
15
16
|
has_many :privilege_group_privileges, dependent: :destroy
|
@@ -19,10 +20,11 @@ class Privilege < ApplicationRecord
|
|
19
20
|
|
20
21
|
before_validation { self.name = name.strip unless name.nil? }
|
21
22
|
before_validation { self.slug = Canonizer.transliterate(name.to_s) if slug.blank? }
|
22
|
-
before_validation { self.regional = true if parent&.regional? }
|
23
23
|
before_validation :normalize_priority
|
24
24
|
|
25
|
-
before_save
|
25
|
+
before_save { children_cache.uniq! }
|
26
|
+
after_create :cache_parents!
|
27
|
+
after_save { parent&.cache_children! }
|
26
28
|
|
27
29
|
validates_presence_of :name, :slug, :priority
|
28
30
|
validates :name, uniqueness: { case_sensitive: false, scope: [:parent_id] }
|
@@ -33,7 +35,7 @@ class Privilege < ApplicationRecord
|
|
33
35
|
|
34
36
|
scope :ordered_by_priority, -> { order('priority asc, name asc') }
|
35
37
|
scope :ordered_by_name, -> { order('name asc, slug asc') }
|
36
|
-
scope :visible, -> { where(visible: true
|
38
|
+
scope :visible, -> { where(visible: true) }
|
37
39
|
scope :administrative, -> { where(administrative: true) }
|
38
40
|
scope :for_tree, ->(parent_id = nil) { where(parent_id: parent_id).ordered_by_priority }
|
39
41
|
scope :siblings, ->(item) { where(parent_id: item.parent_id) }
|
@@ -44,11 +46,11 @@ class Privilege < ApplicationRecord
|
|
44
46
|
end
|
45
47
|
|
46
48
|
def self.entity_parameters
|
47
|
-
%i
|
49
|
+
%i[administrative description name priority slug]
|
48
50
|
end
|
49
51
|
|
50
52
|
def self.creation_parameters
|
51
|
-
entity_parameters + %i
|
53
|
+
entity_parameters + %i[parent_id]
|
52
54
|
end
|
53
55
|
|
54
56
|
# @return [String]
|
@@ -58,7 +60,7 @@ class Privilege < ApplicationRecord
|
|
58
60
|
|
59
61
|
# @deprecated use #subbranch_ids
|
60
62
|
def ids
|
61
|
-
|
63
|
+
subbranch_ids
|
62
64
|
end
|
63
65
|
|
64
66
|
# @return [Array<Integer>]
|
@@ -81,20 +83,20 @@ class Privilege < ApplicationRecord
|
|
81
83
|
|
82
84
|
def cache_parents!
|
83
85
|
return if parent.nil?
|
86
|
+
|
84
87
|
self.parents_cache = "#{parent.parents_cache},#{parent_id}".gsub(/\A,/, '')
|
85
88
|
save!
|
86
89
|
end
|
87
90
|
|
88
91
|
def cache_children!
|
89
|
-
|
92
|
+
child_privileges.order('id asc').each do |child|
|
90
93
|
self.children_cache += [child.id] + child.children_cache
|
91
94
|
end
|
92
95
|
save!
|
93
|
-
parent&.cache_children!
|
94
96
|
end
|
95
97
|
|
96
98
|
def can_be_deleted?
|
97
|
-
|
99
|
+
deletable? && child_privileges.count < 1
|
98
100
|
end
|
99
101
|
|
100
102
|
# @param [User] user
|
@@ -102,20 +104,16 @@ class Privilege < ApplicationRecord
|
|
102
104
|
def has_user?(user, region_ids = [])
|
103
105
|
return false if user.nil?
|
104
106
|
return true if user.super_user?
|
105
|
-
result = user_in_non_regional_branch?(user)
|
106
107
|
|
107
|
-
|
108
|
-
result = user_in_regional_branch?(user, region_ids)
|
109
|
-
end
|
110
|
-
result
|
108
|
+
user_in_non_regional_branch?(user)
|
111
109
|
end
|
112
110
|
|
113
111
|
# @param [User] user
|
114
112
|
# @param [Integer] region_id
|
115
113
|
def grant(user, region_id = nil)
|
116
114
|
return if user.nil?
|
117
|
-
|
118
|
-
criteria
|
115
|
+
|
116
|
+
criteria = { privilege: self, user: user }
|
119
117
|
UserPrivilege.create(criteria) unless UserPrivilege.exists?(criteria)
|
120
118
|
end
|
121
119
|
|
@@ -123,8 +121,8 @@ class Privilege < ApplicationRecord
|
|
123
121
|
# @param [Integer] region_id
|
124
122
|
def revoke(user, region_id = nil)
|
125
123
|
return if user.nil?
|
126
|
-
|
127
|
-
criteria
|
124
|
+
|
125
|
+
criteria = { privilege: self, user: user }
|
128
126
|
UserPrivilege.where(criteria).delete_all
|
129
127
|
end
|
130
128
|
|
@@ -144,9 +142,9 @@ class Privilege < ApplicationRecord
|
|
144
142
|
private
|
145
143
|
|
146
144
|
def set_next_priority
|
147
|
-
|
148
|
-
|
149
|
-
|
145
|
+
return unless id.nil? && priority == 1
|
146
|
+
|
147
|
+
self.priority = self.class.siblings(self).maximum(:priority).to_i + 1
|
150
148
|
end
|
151
149
|
|
152
150
|
def normalize_priority
|
@@ -154,33 +152,13 @@ class Privilege < ApplicationRecord
|
|
154
152
|
self.priority = PRIORITY_RANGE.last if priority > PRIORITY_RANGE.last
|
155
153
|
end
|
156
154
|
|
157
|
-
def compact_children_cache
|
158
|
-
self.children_cache.uniq!
|
159
|
-
end
|
160
|
-
|
161
155
|
# @param [User] user
|
162
156
|
def user_in_non_regional_branch?(user)
|
163
|
-
selected_ids = Privilege.where(
|
157
|
+
selected_ids = Privilege.where(id: branch_ids).pluck(:id)
|
164
158
|
if selected_ids.any?
|
165
159
|
UserPrivilege.exists?(privilege_id: selected_ids, user: user)
|
166
160
|
else
|
167
161
|
false
|
168
162
|
end
|
169
163
|
end
|
170
|
-
|
171
|
-
# @param [User] user
|
172
|
-
# @param [Array] region_ids
|
173
|
-
def user_in_regional_branch?(user, region_ids)
|
174
|
-
selected_ids = Privilege.where(regional: true, id: branch_ids).pluck(:id)
|
175
|
-
if selected_ids.any?
|
176
|
-
criteria = {
|
177
|
-
privilege_id: selected_ids,
|
178
|
-
region_id: region_ids,
|
179
|
-
user: user
|
180
|
-
}
|
181
|
-
UserPrivilege.exists?(criteria)
|
182
|
-
else
|
183
|
-
false
|
184
|
-
end
|
185
|
-
end
|
186
164
|
end
|