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
@@ -1,3 +1,6 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
# Manager for email confirmation codes
|
1
4
|
class CodeManager::Confirmation < CodeManager
|
2
5
|
# @return [CodeType]
|
3
6
|
def self.code_type
|
@@ -7,20 +10,21 @@ class CodeManager::Confirmation < CodeManager
|
|
7
10
|
# @param [User] user
|
8
11
|
def self.code_for_user(user)
|
9
12
|
code = code_type.codes.active.find_by(user: user)
|
10
|
-
if code.nil?
|
11
|
-
|
12
|
-
end
|
13
|
+
code = code_type.codes.create(user: user, payload: user.email) if code.nil?
|
14
|
+
|
13
15
|
code
|
14
16
|
end
|
15
17
|
|
16
18
|
def code_is_valid?
|
17
19
|
return false if @code.nil?
|
20
|
+
|
18
21
|
@code.active? && @code.code_type == self.class.code_type
|
19
22
|
end
|
20
23
|
|
21
24
|
def activate
|
22
25
|
return if @code.quantity < 1
|
26
|
+
|
23
27
|
@code.decrement!(:quantity)
|
24
28
|
@code.user.update email_confirmed: true if @code.payload == @code.user.email
|
25
29
|
end
|
26
|
-
end
|
30
|
+
end
|
@@ -1,3 +1,6 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
# Manager for invitation codes
|
1
4
|
class CodeManager::Invitation < CodeManager
|
2
5
|
# @return [CodeType]
|
3
6
|
def self.code_type
|
@@ -6,21 +9,22 @@ class CodeManager::Invitation < CodeManager
|
|
6
9
|
|
7
10
|
# @param [User] user
|
8
11
|
def self.code_for_user(user)
|
9
|
-
code = code_type.codes.active.
|
10
|
-
if code.nil?
|
11
|
-
|
12
|
-
end
|
12
|
+
code = code_type.codes.active.find_by(user: user)
|
13
|
+
code = code_type.codes.create(user: user) if code.nil?
|
14
|
+
|
13
15
|
code
|
14
16
|
end
|
15
17
|
|
16
18
|
def code_is_valid?
|
17
19
|
return false if @code.nil?
|
18
|
-
|
20
|
+
|
21
|
+
@code.active? && @code.code_type == self.class.code_type
|
19
22
|
end
|
20
23
|
|
21
24
|
# @param [User] invitee
|
22
25
|
def activate(invitee)
|
23
26
|
return if invitee.nil? || @code.quantity < 1
|
27
|
+
|
24
28
|
@code.decrement!(:quantity)
|
25
29
|
invitee.update(inviter_id: @code.user_id)
|
26
30
|
end
|
@@ -1,3 +1,6 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
# Recovery codes manager
|
1
4
|
class CodeManager::Recovery < CodeManager
|
2
5
|
# @return [CodeType]
|
3
6
|
def self.code_type
|
@@ -7,25 +10,25 @@ class CodeManager::Recovery < CodeManager
|
|
7
10
|
# @param [User] user
|
8
11
|
def self.code_for_user(user)
|
9
12
|
code = code_type.codes.active.find_by(user: user)
|
10
|
-
if code.nil?
|
11
|
-
|
12
|
-
end
|
13
|
+
code = code_type.codes.create(user: user, payload: user.email) if code.nil?
|
14
|
+
|
13
15
|
code
|
14
16
|
end
|
15
17
|
|
16
18
|
def code_is_valid?
|
17
19
|
return false if @code.nil?
|
20
|
+
|
18
21
|
@code.active? && @code.code_type == self.class.code_type
|
19
22
|
end
|
20
23
|
|
21
24
|
# @param [Hash] new_parameters
|
22
25
|
def activate(new_parameters)
|
23
26
|
return false if @code.quantity < 1 || new_parameters[:password].blank?
|
27
|
+
|
24
28
|
new_parameters[:email_confirmed] = true if @code.payload == @code.user.email
|
25
29
|
user_updated = @code.user.update(new_parameters)
|
26
|
-
if user_updated
|
27
|
-
|
28
|
-
end
|
30
|
+
@code.decrement!(:quantity) if user_updated
|
31
|
+
|
29
32
|
user_updated
|
30
33
|
end
|
31
34
|
end
|
@@ -11,19 +11,20 @@ class UserManager
|
|
11
11
|
def self.create(parameters, profile)
|
12
12
|
user = User.new(parameters)
|
13
13
|
|
14
|
-
user.
|
14
|
+
user.data['profile'] = UserProfileHandler.clean_parameters(profile)
|
15
15
|
|
16
|
-
{ user: user, profile: user.
|
16
|
+
{ user: user, profile: user.data['profile'] }
|
17
17
|
end
|
18
18
|
|
19
19
|
# @param [Hash] parameters
|
20
20
|
# @param [Hash] profile
|
21
21
|
def update(parameters, profile)
|
22
22
|
raise 'User is not set' if @user.nil?
|
23
|
-
|
23
|
+
|
24
|
+
parameters['data'] = @user.data.merge(profile: UserProfileHandler.clean_parameters(profile))
|
24
25
|
|
25
26
|
@user.update(parameters)
|
26
27
|
|
27
|
-
{ user: @user, profile: @user.
|
28
|
+
{ user: @user, profile: @user.data['profile'] }
|
28
29
|
end
|
29
30
|
end
|
@@ -1,28 +1,55 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
# Handler for user profile parameters
|
1
4
|
class UserProfileHandler
|
2
|
-
GENDERS = { 0 => 'female', 1 => 'male' }
|
5
|
+
GENDERS = { 0 => 'female', 1 => 'male' }.freeze
|
3
6
|
|
7
|
+
# List of attributes that can be used in user profile
|
8
|
+
#
|
9
|
+
# Change this method in decorators for other values
|
4
10
|
def self.allowed_parameters
|
5
|
-
%w
|
11
|
+
%w[gender name patronymic surname about]
|
6
12
|
end
|
7
13
|
|
14
|
+
# Normalize profile parameters for storage
|
15
|
+
#
|
16
|
+
# Makes consistent format of profile hash.
|
17
|
+
#
|
8
18
|
# @param [Hash] input
|
9
19
|
def self.clean_parameters(input)
|
10
|
-
|
11
|
-
gender_key = input['gender'].blank? ? nil : input['gender'].to_i
|
12
|
-
gender = GENDERS.key?(gender_key) ? gender_key : nil
|
13
|
-
else
|
14
|
-
gender = nil
|
15
|
-
end
|
20
|
+
return {} unless input.respond_to?(:key?)
|
16
21
|
|
17
|
-
output =
|
18
|
-
(allowed_parameters -
|
22
|
+
output = normalized_parameters(input)
|
23
|
+
(allowed_parameters - output.keys).each do |parameter|
|
19
24
|
output[parameter] = input.key?(parameter) ? input[parameter].to_s : nil
|
20
25
|
end
|
21
26
|
output
|
22
27
|
end
|
23
28
|
|
29
|
+
# Prepare search string for simple user search
|
30
|
+
#
|
24
31
|
# @param [User] user
|
25
32
|
def self.search_string(user)
|
26
|
-
"#{user.
|
33
|
+
"#{user.data.dig('profile', 'surname')} #{user.data.dig('profile', 'name')}"
|
34
|
+
end
|
35
|
+
|
36
|
+
# Format parameters that have more restrictions than just "string" type
|
37
|
+
#
|
38
|
+
# Change this method in decorator to add other fields with type enumerable,
|
39
|
+
# integer, etc.
|
40
|
+
#
|
41
|
+
# @param [Hash] input
|
42
|
+
def self.normalized_parameters(input)
|
43
|
+
{ gender: clean_gender(input['gender']) }
|
44
|
+
end
|
45
|
+
|
46
|
+
# Restrict gender to only available values
|
47
|
+
#
|
48
|
+
# Defined gender is stored as integer.
|
49
|
+
#
|
50
|
+
# @param [Integer] input
|
51
|
+
def self.clean_gender(input)
|
52
|
+
gender_key = input.blank? ? nil : input.to_i
|
53
|
+
GENDERS.key?(gender_key) ? gender_key : nil
|
27
54
|
end
|
28
55
|
end
|
@@ -1,3 +1,5 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
class AvatarUploader < CarrierWave::Uploader::Base
|
2
4
|
include CarrierWave::MiniMagick
|
3
5
|
include CarrierWave::BombShelter
|
@@ -9,7 +11,9 @@ class AvatarUploader < CarrierWave::Uploader::Base
|
|
9
11
|
storage :file
|
10
12
|
|
11
13
|
def store_dir
|
12
|
-
"
|
14
|
+
slug = "#{model.id / 10_000}/#{model.id / 100}/#{model.id}"
|
15
|
+
|
16
|
+
"uploads/#{model.class.to_s.underscore}/#{mounted_as}/#{slug}"
|
13
17
|
end
|
14
18
|
|
15
19
|
def default_url
|
@@ -1,10 +1,8 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
# Image uploader for editable pages
|
1
4
|
class EditablePageImageUploader < CarrierWave::Uploader::Base
|
2
5
|
include CarrierWave::MiniMagick
|
3
|
-
include CarrierWave::BombShelter
|
4
|
-
|
5
|
-
def max_pixel_dimensions
|
6
|
-
[4000, 4000]
|
7
|
-
end
|
8
6
|
|
9
7
|
storage :file
|
10
8
|
|
@@ -37,6 +35,6 @@ class EditablePageImageUploader < CarrierWave::Uploader::Base
|
|
37
35
|
# Add a white list of extensions which are allowed to be uploaded.
|
38
36
|
# For images you might use something like this:
|
39
37
|
def extension_whitelist
|
40
|
-
%w
|
38
|
+
%w[jpg jpeg png]
|
41
39
|
end
|
42
40
|
end
|
@@ -1,3 +1,5 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
class MediaFileUploader < CarrierWave::Uploader::Base
|
2
4
|
include CarrierWave::MiniMagick
|
3
5
|
include CarrierWave::BombShelter
|
@@ -6,10 +8,10 @@ class MediaFileUploader < CarrierWave::Uploader::Base
|
|
6
8
|
storage :file
|
7
9
|
# storage :fog
|
8
10
|
|
9
|
-
# Override the directory where uploaded files will be stored.
|
10
|
-
# This is a sensible default for uploaders that are meant to be mounted:
|
11
11
|
def store_dir
|
12
|
-
"
|
12
|
+
slug = "#{model.id / 10_000}/#{model.id / 100}/#{model.id}"
|
13
|
+
|
14
|
+
"uploads/#{model.class.to_s.underscore}/#{mounted_as}/#{slug}"
|
13
15
|
end
|
14
16
|
|
15
17
|
version :medium_2x do
|
@@ -21,7 +23,7 @@ class MediaFileUploader < CarrierWave::Uploader::Base
|
|
21
23
|
end
|
22
24
|
|
23
25
|
def extension_whitelist
|
24
|
-
%w
|
26
|
+
%w[jpg jpeg gif png]
|
25
27
|
end
|
26
28
|
|
27
29
|
def filename
|
@@ -1,3 +1,5 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
class MediaSnapshotUploader < CarrierWave::Uploader::Base
|
2
4
|
include CarrierWave::MiniMagick
|
3
5
|
include CarrierWave::BombShelter
|
@@ -7,7 +9,9 @@ class MediaSnapshotUploader < CarrierWave::Uploader::Base
|
|
7
9
|
# storage :fog
|
8
10
|
|
9
11
|
def store_dir
|
10
|
-
"
|
12
|
+
slug = "#{model.id / 10_000}/#{model.id / 100}/#{model.id}"
|
13
|
+
|
14
|
+
"uploads/#{model.class.to_s.underscore}/#{mounted_as}/#{slug}"
|
11
15
|
end
|
12
16
|
|
13
17
|
def default_url(*args)
|
@@ -23,7 +27,7 @@ class MediaSnapshotUploader < CarrierWave::Uploader::Base
|
|
23
27
|
end
|
24
28
|
|
25
29
|
def extension_whitelist
|
26
|
-
%w
|
30
|
+
%w[jpg jpeg png]
|
27
31
|
end
|
28
32
|
|
29
33
|
def filename
|
@@ -0,0 +1,12 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
# Simple file uploader without any processing
|
4
|
+
class SimpleFileUploader < CarrierWave::Uploader::Base
|
5
|
+
storage :file
|
6
|
+
|
7
|
+
def store_dir
|
8
|
+
slug = "#{model.id / 100}/#{model.id}"
|
9
|
+
|
10
|
+
"uploads/#{model.class.to_s.underscore}/#{mounted_as}/#{slug}"
|
11
|
+
end
|
12
|
+
end
|
@@ -0,0 +1,75 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
# Simple image uploader with scaling
|
4
|
+
class SimpleImageUploader < CarrierWave::Uploader::Base
|
5
|
+
include CarrierWave::MiniMagick
|
6
|
+
|
7
|
+
storage :file
|
8
|
+
|
9
|
+
# Override the directory where uploaded files will be stored.
|
10
|
+
# This is a sensible default for uploaders that are meant to be mounted:
|
11
|
+
def store_dir
|
12
|
+
slug = "#{model.id / 1000}/#{model.id}"
|
13
|
+
|
14
|
+
"uploads/#{model.class.to_s.underscore}/#{mounted_as}/#{slug}"
|
15
|
+
end
|
16
|
+
|
17
|
+
def default_url(*)
|
18
|
+
ActionController::Base.helpers.asset_path('biovision/base/placeholders/1x1.svg')
|
19
|
+
end
|
20
|
+
|
21
|
+
version :hd, if: :raster_image? do
|
22
|
+
resize_to_fit(1920, 1920)
|
23
|
+
end
|
24
|
+
|
25
|
+
version :large, from_version: :hd, if: :raster_image? do
|
26
|
+
resize_to_fit(1280, 1280)
|
27
|
+
end
|
28
|
+
|
29
|
+
version :medium, from_version: :large, if: :raster_image? do
|
30
|
+
resize_to_fit(640, 640)
|
31
|
+
end
|
32
|
+
|
33
|
+
version :small, from_version: :medium, if: :raster_image? do
|
34
|
+
resize_to_fit(320, 320)
|
35
|
+
end
|
36
|
+
|
37
|
+
version :preview, from_version: :small, if: :raster_image? do
|
38
|
+
resize_to_fit(160, 160)
|
39
|
+
end
|
40
|
+
|
41
|
+
# Add a white list of extensions which are allowed to be uploaded.
|
42
|
+
# For images you might use something like this:
|
43
|
+
def extension_whitelist
|
44
|
+
%w[jpg jpeg png svg svgz]
|
45
|
+
end
|
46
|
+
|
47
|
+
# @param [SanitizedFile]
|
48
|
+
def raster_image?(new_file)
|
49
|
+
!new_file.extension.match?(/svgz?\z/i)
|
50
|
+
end
|
51
|
+
|
52
|
+
def raster?
|
53
|
+
!File.extname(path).match?(/\.svgz?\z/i)
|
54
|
+
end
|
55
|
+
|
56
|
+
def preview_url
|
57
|
+
raster? ? preview.url : url
|
58
|
+
end
|
59
|
+
|
60
|
+
def small_url
|
61
|
+
raster? ? small.url : url
|
62
|
+
end
|
63
|
+
|
64
|
+
def medium_url
|
65
|
+
raster? ? medium.url : url
|
66
|
+
end
|
67
|
+
|
68
|
+
def large_url
|
69
|
+
raster? ? large.url : url
|
70
|
+
end
|
71
|
+
|
72
|
+
def hd_url
|
73
|
+
raster? ? hd.url : url
|
74
|
+
end
|
75
|
+
end
|
@@ -17,6 +17,22 @@
|
|
17
17
|
<%= language_name(entity.language) %>
|
18
18
|
</div>
|
19
19
|
<% end %>
|
20
|
+
<% unless entity.nav_group.nil? %>
|
21
|
+
<div class="secondary info">
|
22
|
+
<%= t('activerecord.attributes.editable_page.nav_group') %>:
|
23
|
+
<%= entity.nav_group %>
|
24
|
+
</div>
|
25
|
+
<% end %>
|
26
|
+
|
27
|
+
<%=
|
28
|
+
render(
|
29
|
+
partial: 'shared/admin/toggleable',
|
30
|
+
locals: {
|
31
|
+
entity: entity,
|
32
|
+
url: toggle_admin_editable_page_path(id: entity.id)
|
33
|
+
}
|
34
|
+
)
|
35
|
+
%>
|
20
36
|
|
21
37
|
<ul class="actions">
|
22
38
|
<li><%= edit_icon(edit_editable_page_path(id: entity.id)) %></li>
|
@@ -10,5 +10,12 @@
|
|
10
10
|
<li><%= create_icon(new_editable_page_path) %></li>
|
11
11
|
</ul>
|
12
12
|
|
13
|
-
<%=
|
13
|
+
<%=
|
14
|
+
render(
|
15
|
+
partial: 'shared/admin/list_with_priority',
|
16
|
+
locals: {
|
17
|
+
collection: @collection
|
18
|
+
}
|
19
|
+
)
|
20
|
+
%>
|
14
21
|
</article>
|