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.
Files changed (223) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +5 -21
  3. data/app/assets/images/biovision/base/icons/apply.svg +4 -0
  4. data/app/assets/images/biovision/base/icons/components/contact.svg +26 -0
  5. data/app/assets/images/biovision/base/icons/components/registration.svg +17 -0
  6. data/app/assets/images/biovision/base/icons/destroy.svg +11 -8
  7. data/app/assets/images/biovision/base/icons/settings.svg +41 -0
  8. data/app/assets/images/biovision/base/icons/slider/arrow-left.svg +4 -0
  9. data/app/assets/images/biovision/base/icons/slider/arrow-right.svg +4 -0
  10. data/app/assets/images/biovision/base/placeholders/16x9.svg +10 -3
  11. data/app/assets/images/biovision/base/placeholders/1x1.svg +12 -0
  12. data/app/assets/images/biovision/base/placeholders/3x2.svg +10 -3
  13. data/app/assets/javascripts/biovision/base/biovision.js +780 -461
  14. data/app/assets/javascripts/biovision/base/components/carousel.js +123 -0
  15. data/app/assets/javascripts/biovision/base/polyfills.js +149 -0
  16. data/app/assets/stylesheets/biovision/base/admin.scss +85 -46
  17. data/app/assets/stylesheets/biovision/base/admin/components.scss +141 -0
  18. data/app/assets/stylesheets/biovision/base/biovision.scss +149 -33
  19. data/app/assets/stylesheets/biovision/base/buttons/buttons-common.scss +22 -0
  20. data/app/assets/stylesheets/biovision/base/default.scss +6 -6
  21. data/app/assets/stylesheets/biovision/base/default_admin.scss +25 -8
  22. data/app/assets/stylesheets/biovision/base/themes/simple-layout.scss +0 -3
  23. data/app/controllers/admin/editable_pages_controller.rb +6 -4
  24. data/app/controllers/admin/privileges_controller.rb +2 -3
  25. data/app/controllers/admin/settings_controller.rb +52 -0
  26. data/app/controllers/admin/simple_blocks_controller.rb +28 -0
  27. data/app/controllers/admin/users_controller.rb +1 -1
  28. data/app/controllers/agents_controller.rb +4 -4
  29. data/app/controllers/authentication_controller.rb +28 -6
  30. data/app/controllers/browsers_controller.rb +4 -4
  31. data/app/controllers/concerns/authentication.rb +8 -5
  32. data/app/controllers/concerns/entity_priority.rb +3 -0
  33. data/app/controllers/concerns/lockable_entity.rb +6 -3
  34. data/app/controllers/concerns/removable_image.rb +4 -5
  35. data/app/controllers/concerns/toggleable_entity.rb +4 -5
  36. data/app/controllers/editable_pages_controller.rb +14 -8
  37. data/app/controllers/fallback_controller.rb +7 -2
  38. data/app/controllers/feedback_requests_controller.rb +23 -8
  39. data/app/controllers/metrics_controller.rb +3 -3
  40. data/app/controllers/my/profiles_controller.rb +32 -15
  41. data/app/controllers/privilege_groups_controller.rb +4 -4
  42. data/app/controllers/privileges_controller.rb +7 -26
  43. data/app/controllers/simple_blocks_controller.rb +63 -0
  44. data/app/controllers/stored_values_controller.rb +4 -4
  45. data/app/controllers/tokens_controller.rb +4 -4
  46. data/app/controllers/users_controller.rb +8 -3
  47. data/app/helpers/biovision_users_helper.rb +60 -21
  48. data/app/helpers/editable_pages_helper.rb +22 -0
  49. data/app/helpers/languages_helper.rb +3 -0
  50. data/app/helpers/simple_image_helper.rb +66 -0
  51. data/app/mailers/application_mailer.rb +0 -2
  52. data/app/mailers/code_sender.rb +13 -2
  53. data/app/mailers/feedback_mailer.rb +5 -2
  54. data/app/mailers/user_mailer.rb +6 -1
  55. data/app/models/biovision_component.rb +43 -0
  56. data/app/models/biovision_parameter.rb +34 -0
  57. data/app/models/code.rb +22 -7
  58. data/app/models/code_type.rb +9 -1
  59. data/app/models/concerns/flat_priority.rb +50 -0
  60. data/app/models/concerns/nested_priority.rb +58 -0
  61. data/app/models/concerns/required_unique_slug.rb +5 -2
  62. data/app/models/editable_page.rb +49 -37
  63. data/app/models/foreign_site.rb +5 -3
  64. data/app/models/language.rb +15 -37
  65. data/app/models/metric.rb +2 -4
  66. data/app/models/privilege.rb +23 -45
  67. data/app/models/privilege_group.rb +6 -1
  68. data/app/models/simple_block.rb +66 -0
  69. data/app/models/user.rb +29 -26
  70. data/app/models/user_privilege.rb +1 -1
  71. data/app/services/biovision/components/base_component.rb +115 -0
  72. data/app/services/biovision/components/registration_component.rb +98 -0
  73. data/app/services/code_manager.rb +4 -1
  74. data/app/services/code_manager/confirmation.rb +8 -4
  75. data/app/services/code_manager/invitation.rb +9 -5
  76. data/app/services/code_manager/recovery.rb +9 -6
  77. data/app/services/user_manager.rb +5 -4
  78. data/app/services/user_profile_handler.rb +38 -11
  79. data/app/uploaders/avatar_uploader.rb +5 -1
  80. data/app/uploaders/editable_page_image_uploader.rb +4 -6
  81. data/app/uploaders/media_file_uploader.rb +6 -4
  82. data/app/uploaders/media_snapshot_uploader.rb +6 -2
  83. data/app/uploaders/simple_file_uploader.rb +12 -0
  84. data/app/uploaders/simple_image_uploader.rb +75 -0
  85. data/app/views/about/editable.html.erb +1 -1
  86. data/app/views/admin/agents/_filter.html.erb +1 -1
  87. data/app/views/admin/editable_pages/entity/_in_list.html.erb +16 -0
  88. data/app/views/admin/editable_pages/index.html.erb +8 -1
  89. data/app/views/admin/editable_pages/show.html.erb +21 -17
  90. data/app/views/admin/feedback_requests/entity/_in_list.html.erb +9 -1
  91. data/app/views/admin/index/_biovision_base.html.erb +5 -7
  92. data/app/views/admin/index/_components.html.erb +9 -0
  93. data/app/views/admin/index/dashboard/_editorial.html.erb +2 -2
  94. data/app/views/admin/index/dashboard/_settings.html.erb +2 -2
  95. data/app/views/admin/index/index.html.erb +2 -0
  96. data/app/views/admin/privileges/entity/_groups.html.erb +25 -25
  97. data/app/views/admin/privileges/entity/_in_list.html.erb +30 -9
  98. data/app/views/admin/privileges/index.html.erb +6 -1
  99. data/app/views/admin/privileges/show.html.erb +31 -18
  100. data/app/views/admin/settings/component/_new_parameter.html.erb +62 -0
  101. data/app/views/admin/settings/component/_parameters.html.erb +37 -0
  102. data/app/views/admin/settings/component/_setting.html.erb +18 -0
  103. data/app/views/admin/settings/component/_settings.html.erb +31 -0
  104. data/app/views/admin/settings/index.html.erb +27 -0
  105. data/app/views/admin/settings/show.html.erb +42 -0
  106. data/app/views/admin/simple_blocks/_nav_item.html.erb +6 -0
  107. data/app/views/admin/simple_blocks/entity/_in_list.html.erb +23 -0
  108. data/app/views/admin/simple_blocks/index.html.erb +21 -0
  109. data/app/views/admin/simple_blocks/show.html.erb +51 -0
  110. data/app/views/admin/tokens/_filter.html.erb +1 -1
  111. data/app/views/admin/users/_filter.html.erb +1 -1
  112. data/app/views/admin/users/entity/_privilege.html.erb +12 -21
  113. data/app/views/admin/users/entity/_privilege_tree.html.erb +17 -15
  114. data/app/views/admin/users/privileges.html.erb +9 -1
  115. data/app/views/admin/users/search.jbuilder +3 -3
  116. data/app/views/admin/users/show.html.erb +11 -6
  117. data/app/views/agents/_filter.html.erb +22 -22
  118. data/app/views/agents/_form.html.erb +25 -29
  119. data/app/views/application/forbidden.html.erb +9 -0
  120. data/app/views/application/forbidden.jbuilder +3 -0
  121. data/app/views/authentication/_form.html.erb +13 -13
  122. data/app/views/browsers/_form.html.erb +21 -25
  123. data/app/views/editable_blocks/_entity.html.erb +4 -1
  124. data/app/views/editable_pages/_form.html.erb +63 -62
  125. data/app/views/editable_pages/edit.html.erb +1 -1
  126. data/app/views/editable_pages/entity/_metadata.html.erb +4 -4
  127. data/app/views/editable_pages/new.html.erb +3 -3
  128. data/app/views/fallback/show.html.erb +8 -1
  129. data/app/views/feedback_requests/_form.html.erb +76 -52
  130. data/app/views/feedback_requests/create.js.erb +1 -10
  131. data/app/views/index/index/_editable.html.erb +0 -4
  132. data/app/views/metrics/_form.html.erb +38 -36
  133. data/app/views/my/confirmations/show.html.erb +5 -3
  134. data/app/views/my/profiles/closed.html.erb +7 -0
  135. data/app/views/my/profiles/edit/_form.html.erb +9 -9
  136. data/app/views/my/profiles/new.html.erb +9 -1
  137. data/app/views/my/profiles/new/_form.html.erb +22 -1
  138. data/app/views/my/recoveries/show.html.erb +2 -2
  139. data/app/views/privilege_groups/_form.html.erb +48 -21
  140. data/app/views/privileges/_form.html.erb +68 -36
  141. data/app/views/profiles/_profile.html.erb +3 -3
  142. data/app/views/shared/_pagination.jbuilder +7 -5
  143. data/app/views/shared/admin/_breadcrumbs.html.erb +1 -1
  144. data/app/views/shared/forms/_meta_texts.html.erb +3 -3
  145. data/app/views/shared/forms/_priority.html.erb +12 -0
  146. data/app/views/shared/forms/_state_container.html.erb +1 -0
  147. data/app/views/simple_blocks/_empty.html.erb +0 -0
  148. data/app/views/simple_blocks/_form.html.erb +120 -0
  149. data/app/views/simple_blocks/_simple_block.html.erb +26 -0
  150. data/app/views/simple_blocks/edit.html.erb +17 -0
  151. data/app/views/simple_blocks/new.html.erb +15 -0
  152. data/app/views/stored_values/_form.html.erb +57 -28
  153. data/app/views/tokens/_form.html.erb +31 -26
  154. data/app/views/users/_form.html.erb +1 -1
  155. data/config/initializers/carrierwave.rb +7 -2
  156. data/config/locales/common-ru.yml +5 -0
  157. data/config/locales/components-ru.yml +50 -0
  158. data/config/locales/editable-pages-en.yml +2 -0
  159. data/config/locales/editable-pages-ru.yml +50 -7
  160. data/config/locales/editable-pages-sv.yml +2 -0
  161. data/config/locales/feedback-ru.yml +1 -0
  162. data/config/locales/users-en.yml +0 -1
  163. data/config/locales/users-ru.yml +6 -1
  164. data/config/locales/users-sv.yml +0 -1
  165. data/config/routes.rb +32 -6
  166. data/db/migrate/20181217000000_create_biovision_components.rb +80 -0
  167. data/db/migrate/20181217000010_create_metrics.rb +40 -0
  168. data/db/migrate/20181217000015_create_browsers.rb +38 -0
  169. data/db/migrate/20181217000020_create_languages.rb +30 -0
  170. data/db/migrate/20181217000030_create_users.rb +118 -0
  171. data/db/migrate/20181217000035_create_codes.rb +51 -0
  172. data/db/migrate/20181217000040_create_privileges.rb +142 -0
  173. data/db/migrate/20181217000100_create_media_folders.rb +53 -0
  174. data/db/migrate/20181217000110_create_editable_pages.rb +90 -0
  175. data/db/migrate/20181217000200_create_feedback_requests.rb +27 -0
  176. data/db/migrate/20181217121211_add_uuid_to_users.rb +12 -0
  177. data/db/migrate/20181217121212_update_fields181217.rb +29 -0
  178. data/db/migrate/20190311121212_convert_json_columns.rb +47 -0
  179. data/db/migrate/20190324181818_add_data_to_feedback_requests.rb +14 -0
  180. data/db/migrate/20190326120000_create_simple_blocks.rb +31 -0
  181. data/db/{migrate → obsolete_migrations}/20171223333333_amend_foreign_keys.rb +0 -0
  182. data/db/{migrate → obsolete_migrations}/20180117151515_add_language_to_models.rb +0 -0
  183. data/db/{migrate → obsolete_migrations}/20180321000000_add_profile_data_to_users.rb +4 -4
  184. data/db/{migrate → obsolete_migrations}/20180405000000_add_consent_to_users.rb +0 -0
  185. data/db/{migrate → obsolete_migrations}/20180610222222_add_consent_to_feedback_requests.rb +0 -0
  186. data/db/{migrate → obsolete_migrations}/20180612111111_add_administrative_to_privilege.rb +0 -0
  187. data/db/{migrate → obsolete_migrations}/20180619121212_add_image_alt_text_to_editable_page.rb +0 -0
  188. data/db/{migrate → obsolete_migrations}/20180703111111_add_fields_to_editable_blocks.rb +0 -0
  189. data/db/{migrate → obsolete_migrations}/20180722222222_add_active_to_languages.rb +0 -0
  190. data/db/{migrate → obsolete_migrations}/20180725111111_add_referral_link_to_users.rb +0 -0
  191. data/db/obsolete_migrations/20181012222222_add_deletable_to_privileges.rb +19 -0
  192. data/db/obsolete_migrations/20181012222223_convert_stored_values.rb +13 -0
  193. data/db/obsolete_migrations/20181030080808_update_editable_pages_meta.rb +20 -0
  194. data/lib/biovision/base/base_methods.rb +19 -2
  195. data/lib/biovision/base/version.rb +3 -1
  196. data/lib/tasks/users.rake +19 -1
  197. metadata +75 -40
  198. data/app/views/admin/privileges/_list.html.erb +0 -15
  199. data/db/migrate/20170228000000_create_languages.rb +0 -23
  200. data/db/migrate/20170301000001_create_metrics.rb +0 -23
  201. data/db/migrate/20170301000002_create_metric_values.rb +0 -19
  202. data/db/migrate/20170301000101_create_browsers.rb +0 -22
  203. data/db/migrate/20170301000102_create_agents.rb +0 -22
  204. data/db/migrate/20170302000001_create_users.rb +0 -55
  205. data/db/migrate/20170302000003_create_tokens.rb +0 -23
  206. data/db/migrate/20170302000004_create_code_types.rb +0 -20
  207. data/db/migrate/20170302000005_create_codes.rb +0 -24
  208. data/db/migrate/20170302000101_create_privileges.rb +0 -41
  209. data/db/migrate/20170302000102_create_user_privileges.rb +0 -18
  210. data/db/migrate/20170302000103_create_privilege_groups.rb +0 -23
  211. data/db/migrate/20170302000104_create_privilege_group_privileges.rb +0 -24
  212. data/db/migrate/20170320000000_create_editable_pages.rb +0 -52
  213. data/db/migrate/20170425000001_create_foreign_sites.rb +0 -18
  214. data/db/migrate/20170425000002_create_foreign_users.rb +0 -23
  215. data/db/migrate/20170629120000_create_login_attempts.rb +0 -19
  216. data/db/migrate/20170823000001_create_stored_values.rb +0 -19
  217. data/db/migrate/20171202000000_create_media_folders.rb +0 -28
  218. data/db/migrate/20171202000001_create_media_files.rb +0 -27
  219. data/db/migrate/20171211000000_create_feedback_requests.rb +0 -33
  220. data/db/migrate/20180117160000_create_user_languages.rb +0 -17
  221. data/db/migrate/20180622140000_create_link_blocks.rb +0 -29
  222. data/db/migrate/20180622140001_create_link_block_items.rb +0 -23
  223. data/db/migrate/20180627190000_create_editable_blocks.rb +0 -39
@@ -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, ->(slug) { where('slug ilike ?', "%#{slug}%") unless slug.blank? }
10
- scope :with_slug, ->(slug) { where('lower(slug) = lower(?)', slug) unless slug.blank? }
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
@@ -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
- PRIORITY_RANGE = (1..999)
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 :title, maximum: META_LIMIT
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 :with_slug_like, ->(slug) { where('slug ilike ?', "%#{slug}%") unless slug.blank? }
32
- scope :with_slug, ->(slug) { where('lower(slug) = lower(?)', slug) unless slug.blank? }
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(body description image image_alt_text keywords language_id name nav_group title slug url)
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
- # @param [User] user
66
- def editable_by?(user)
67
- UserPrivilege.user_has_privilege?(user, :chief_editor)
87
+ # @deprecated use #meta_title
88
+ def title
89
+ name
68
90
  end
69
91
 
70
- # @param [Integer] delta
71
- def change_priority(delta)
72
- new_priority = priority + delta
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
- private
83
-
84
- def set_next_priority
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
- def normalize_priority
91
- self.priority = PRIORITY_RANGE.first if priority < PRIORITY_RANGE.first
92
- self.priority = PRIORITY_RANGE.last if priority > PRIORITY_RANGE.last
102
+ # @param [User] user
103
+ def editable_by?(user)
104
+ UserPrivilege.user_has_privilege?(user, :content_manager)
93
105
  end
94
106
  end
@@ -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
- profile_data: {
69
- name: data[:info][:first_name],
70
- surname: data[:info][:last_name]
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
 
@@ -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
- SLUG_LIMIT = 20
3
- CODE_LIMIT = 8
4
- PRIORITY_RANGE = (1..999)
14
+ include FlatPriority
5
15
 
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
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
- DESCRIPTION_LIMIT = 250
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(incremental start_with_zero show_on_dashboard default_period description)
23
+ %i[incremental start_with_zero show_on_dashboard default_period description]
26
24
  end
27
25
 
28
26
  # @param [String] name
@@ -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..32767)
8
+ PRIORITY_RANGE = (1..32_767).freeze
8
9
 
9
- toggleable :regional, :administrative
10
+ toggleable :administrative
10
11
 
11
12
  belongs_to :parent, class_name: Privilege.to_s, optional: true
12
- has_many :children, class_name: Privilege.to_s, foreign_key: :parent_id
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 :compact_children_cache
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, deleted: false) }
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(administrative description name priority regional slug)
49
+ %i[administrative description name priority slug]
48
50
  end
49
51
 
50
52
  def self.creation_parameters
51
- entity_parameters + %i(parent_id)
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
- [id] + children_cache
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
- children.order('id asc').map do |child|
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
- children.count < 1
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
- if regional? && region_ids.any? && !result
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
- criteria = { privilege: self, user: user }
118
- criteria[:region_id] = region_id if regional?
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
- criteria = { privilege: self, user: user }
127
- criteria[:region_id] = region_id if regional?
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
- if id.nil? && priority == 1
148
- self.priority = self.class.siblings(self).maximum(:priority).to_i + 1
149
- end
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(regional: false, id: branch_ids).pluck(:id)
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