biovision-base 0.5.170614
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/MIT-LICENSE +20 -0
- data/README.md +42 -0
- data/Rakefile +26 -0
- data/app/assets/config/biovision_base_manifest.js +0 -0
- data/app/assets/images/biovision/base/icons/alert.svg +15 -0
- data/app/assets/images/biovision/base/icons/back.svg +28 -0
- data/app/assets/images/biovision/base/icons/create.svg +1 -0
- data/app/assets/images/biovision/base/icons/destroy.svg +3 -0
- data/app/assets/images/biovision/base/icons/edit.svg +22 -0
- data/app/assets/images/biovision/base/icons/exit.svg +1 -0
- data/app/assets/images/biovision/base/icons/foreign/facebook.svg +1 -0
- data/app/assets/images/biovision/base/icons/gear.svg +4 -0
- data/app/assets/images/biovision/base/icons/lock-closed.svg +1 -0
- data/app/assets/images/biovision/base/icons/lock-open.svg +1 -0
- data/app/assets/images/biovision/base/icons/notice.svg +1 -0
- data/app/assets/images/biovision/base/icons/return.svg +1 -0
- data/app/assets/images/biovision/base/icons/warning.svg +43 -0
- data/app/assets/images/biovision/base/icons/world.svg +4 -0
- data/app/assets/images/biovision/base/placeholders/image.svg +19 -0
- data/app/assets/images/biovision/base/placeholders/photo.svg +23 -0
- data/app/assets/images/biovision/base/placeholders/user.svg +21 -0
- data/app/assets/javascripts/biovision/base/biovision.js +238 -0
- data/app/assets/stylesheets/biovision/base/admin.scss +58 -0
- data/app/assets/stylesheets/biovision/base/biovision.scss +472 -0
- data/app/assets/stylesheets/biovision/base/buttons.scss +90 -0
- data/app/assets/stylesheets/biovision/base/default.scss +45 -0
- data/app/assets/stylesheets/biovision/base/filters.scss +53 -0
- data/app/assets/stylesheets/biovision/base/fonts.scss +9 -0
- data/app/assets/stylesheets/biovision/base/message-box.scss +60 -0
- data/app/assets/stylesheets/biovision/base/pagination.scss +42 -0
- data/app/assets/stylesheets/biovision/base/tootik.scss +385 -0
- data/app/assets/stylesheets/biovision/base/track.scss +28 -0
- data/app/controllers/admin/agents_controller.rb +30 -0
- data/app/controllers/admin/browsers_controller.rb +30 -0
- data/app/controllers/admin/codes_controller.rb +25 -0
- data/app/controllers/admin/editable_pages_controller.rb +25 -0
- data/app/controllers/admin/index_controller.rb +5 -0
- data/app/controllers/admin/metrics_controller.rb +29 -0
- data/app/controllers/admin/privilege_groups_controller.rb +48 -0
- data/app/controllers/admin/privileges_controller.rb +5 -0
- data/app/controllers/admin/tokens_controller.rb +28 -0
- data/app/controllers/admin/users_controller.rb +87 -0
- data/app/controllers/admin_controller.rb +10 -0
- data/app/controllers/agents_controller.rb +67 -0
- data/app/controllers/authentication_controller.rb +70 -0
- data/app/controllers/browsers_controller.rb +63 -0
- data/app/controllers/codes_controller.rb +60 -0
- data/app/controllers/concerns/authentication.rb +19 -0
- data/app/controllers/concerns/biovision/admin/privileges.rb +34 -0
- data/app/controllers/concerns/entity_priority.rb +7 -0
- data/app/controllers/concerns/lockable_entity.rb +23 -0
- data/app/controllers/concerns/toggleable_entity.rb +7 -0
- data/app/controllers/editable_pages_controller.rb +60 -0
- data/app/controllers/index_controller.rb +5 -0
- data/app/controllers/metrics_controller.rb +33 -0
- data/app/controllers/my/confirmations_controller.rb +37 -0
- data/app/controllers/my/index_controller.rb +7 -0
- data/app/controllers/my/profiles_controller.rb +81 -0
- data/app/controllers/my/recoveries_controller.rb +68 -0
- data/app/controllers/privilege_groups_controller.rb +57 -0
- data/app/controllers/privileges_controller.rb +74 -0
- data/app/controllers/profiles_controller.rb +22 -0
- data/app/controllers/tokens_controller.rb +60 -0
- data/app/controllers/users_controller.rb +57 -0
- data/app/helpers/biovision_helper.rb +81 -0
- data/app/helpers/biovision_users_helper.rb +52 -0
- data/app/helpers/codes_helper.rb +10 -0
- data/app/helpers/editable_pages_helper.rb +20 -0
- data/app/helpers/privileges_helper.rb +11 -0
- data/app/helpers/tracking_helper.rb +17 -0
- data/app/jobs/application_job.rb +7 -0
- data/app/jobs/clean_tokens_job.rb +8 -0
- data/app/mailers/code_sender.rb +15 -0
- data/app/models/agent.rb +38 -0
- data/app/models/application_record.rb +3 -0
- data/app/models/browser.rb +22 -0
- data/app/models/code.rb +58 -0
- data/app/models/code_type.rb +11 -0
- data/app/models/concerns/biovision/privilege_base.rb +143 -0
- data/app/models/concerns/biovision/user_base.rb +124 -0
- data/app/models/concerns/biovision/user_privilege_base.rb +46 -0
- data/app/models/concerns/has_owner.rb +19 -0
- data/app/models/concerns/required_unique_name.rb +13 -0
- data/app/models/concerns/required_unique_slug.rb +12 -0
- data/app/models/concerns/toggleable.rb +29 -0
- data/app/models/editable_page.rb +30 -0
- data/app/models/foreign_site.rb +75 -0
- data/app/models/foreign_user.rb +26 -0
- data/app/models/metric.rb +67 -0
- data/app/models/metric_value.rb +15 -0
- data/app/models/privilege.rb +3 -0
- data/app/models/privilege_group.rb +50 -0
- data/app/models/privilege_group_privilege.rb +6 -0
- data/app/models/token.rb +75 -0
- data/app/models/user.rb +3 -0
- data/app/models/user_privilege.rb +3 -0
- data/app/services/canonizer.rb +29 -0
- data/app/services/code_manager.rb +16 -0
- data/app/services/code_manager/confirmation.rb +26 -0
- data/app/services/code_manager/invitation.rb +27 -0
- data/app/services/code_manager/recovery.rb +31 -0
- data/app/uploaders/avatar_uploader.rb +62 -0
- data/app/uploaders/editable_page_image_uploader.rb +38 -0
- data/app/views/admin/agents/_filter.html.erb +16 -0
- data/app/views/admin/agents/_list.html.erb +17 -0
- data/app/views/admin/agents/_nav_item.html.erb +6 -0
- data/app/views/admin/agents/_toggleable.html.erb +7 -0
- data/app/views/admin/agents/entity/_in_list.html.erb +13 -0
- data/app/views/admin/agents/index.html.erb +17 -0
- data/app/views/admin/agents/show.html.erb +28 -0
- data/app/views/admin/browsers/_list.html.erb +17 -0
- data/app/views/admin/browsers/_nav_item.html.erb +6 -0
- data/app/views/admin/browsers/_toggleable.html.erb +7 -0
- data/app/views/admin/browsers/agents/_add.html.erb +79 -0
- data/app/views/admin/browsers/entity/_in_list.html.erb +13 -0
- data/app/views/admin/browsers/index.html.erb +17 -0
- data/app/views/admin/browsers/show.html.erb +29 -0
- data/app/views/admin/codes/_list.html.erb +11 -0
- data/app/views/admin/codes/_nav_item.html.erb +6 -0
- data/app/views/admin/codes/entity/_in_list.html.erb +24 -0
- data/app/views/admin/codes/index.html.erb +16 -0
- data/app/views/admin/codes/show.html.erb +51 -0
- data/app/views/admin/editable_pages/_list.html.erb +11 -0
- data/app/views/admin/editable_pages/_nav_item.html.erb +6 -0
- data/app/views/admin/editable_pages/entity/_in_list.html.erb +13 -0
- data/app/views/admin/editable_pages/index.html.erb +14 -0
- data/app/views/admin/editable_pages/show.html.erb +47 -0
- data/app/views/admin/index/index.html.erb +25 -0
- data/app/views/admin/metrics/_list.html.erb +26 -0
- data/app/views/admin/metrics/_nav_item.html.erb +6 -0
- data/app/views/admin/metrics/data.jbuilder +6 -0
- data/app/views/admin/metrics/index.html.erb +14 -0
- data/app/views/admin/metrics/show.html.erb +52 -0
- data/app/views/admin/privilege_groups/_list.html.erb +11 -0
- data/app/views/admin/privilege_groups/_nav_item.html.erb +6 -0
- data/app/views/admin/privilege_groups/entity/_in_list.html.erb +10 -0
- data/app/views/admin/privilege_groups/index.html.erb +14 -0
- data/app/views/admin/privilege_groups/show.html.erb +31 -0
- data/app/views/admin/privileges/_list.html.erb +15 -0
- data/app/views/admin/privileges/_nav_item.html.erb +6 -0
- data/app/views/admin/privileges/entity/_groups.html.erb +34 -0
- data/app/views/admin/privileges/entity/_in_list.html.erb +25 -0
- data/app/views/admin/privileges/index.html.erb +20 -0
- data/app/views/admin/privileges/show.html.erb +66 -0
- data/app/views/admin/privileges/users.html.erb +24 -0
- data/app/views/admin/tokens/_filter.html.erb +17 -0
- data/app/views/admin/tokens/_list.html.erb +11 -0
- data/app/views/admin/tokens/_nav_item.html.erb +6 -0
- data/app/views/admin/tokens/_toggleable.html.erb +7 -0
- data/app/views/admin/tokens/entity/_in_list.html.erb +25 -0
- data/app/views/admin/tokens/index.html.erb +19 -0
- data/app/views/admin/tokens/show.html.erb +43 -0
- data/app/views/admin/users/_filter.html.erb +22 -0
- data/app/views/admin/users/_list.html.erb +17 -0
- data/app/views/admin/users/_nav_item.html.erb +6 -0
- data/app/views/admin/users/_search.html.erb +5 -0
- data/app/views/admin/users/_toggleable.html.erb +7 -0
- data/app/views/admin/users/codes.html.erb +24 -0
- data/app/views/admin/users/entity/_in_list.html.erb +24 -0
- data/app/views/admin/users/entity/_privilege.html.erb +10 -0
- data/app/views/admin/users/entity/_privilege_tree.html.erb +17 -0
- data/app/views/admin/users/index.html.erb +19 -0
- data/app/views/admin/users/privileges.html.erb +35 -0
- data/app/views/admin/users/search.jbuilder +10 -0
- data/app/views/admin/users/search/_results.html.erb +11 -0
- data/app/views/admin/users/show.html.erb +94 -0
- data/app/views/admin/users/tokens.html.erb +24 -0
- data/app/views/agents/_agent.jbuilder +20 -0
- data/app/views/agents/_filter.html.erb +53 -0
- data/app/views/agents/_form.html.erb +33 -0
- data/app/views/agents/edit.html.erb +17 -0
- data/app/views/agents/index.jbuilder +5 -0
- data/app/views/agents/new.html.erb +15 -0
- data/app/views/agents/show.jbuilder +3 -0
- data/app/views/application/not_found.html.erb +9 -0
- data/app/views/application/not_found.jbuilder +3 -0
- data/app/views/application/service_unavailable.html.erb +9 -0
- data/app/views/application/unauthorized.html.erb +11 -0
- data/app/views/application/unauthorized.jbuilder +3 -0
- data/app/views/authentication/_form.html.erb +16 -0
- data/app/views/authentication/_info.html.erb +8 -0
- data/app/views/authentication/new.html.erb +10 -0
- data/app/views/browsers/_form.html.erb +28 -0
- data/app/views/browsers/edit.html.erb +17 -0
- data/app/views/browsers/new.html.erb +15 -0
- data/app/views/code_sender/email.text.erb +9 -0
- data/app/views/code_sender/password.text.erb +10 -0
- data/app/views/codes/_form.html.erb +49 -0
- data/app/views/codes/edit.html.erb +17 -0
- data/app/views/codes/new.html.erb +15 -0
- data/app/views/editable_pages/_form.html.erb +63 -0
- data/app/views/editable_pages/edit.html.erb +17 -0
- data/app/views/editable_pages/form/_ckeditor.html.erb +11 -0
- data/app/views/editable_pages/new.html.erb +15 -0
- data/app/views/index/index.html.erb +5 -0
- data/app/views/layouts/admin.html.erb +23 -0
- data/app/views/layouts/admin/_footer.html.erb +0 -0
- data/app/views/layouts/admin/_header.html.erb +11 -0
- data/app/views/layouts/admin/header/_logo.html.erb +3 -0
- data/app/views/metrics/_form.html.erb +41 -0
- data/app/views/metrics/edit.html.erb +17 -0
- data/app/views/metrics/index.jbuilder +7 -0
- data/app/views/metrics/show.jbuilder +3 -0
- data/app/views/my/confirmations/show.html.erb +30 -0
- data/app/views/my/index/index.html.erb +17 -0
- data/app/views/my/profiles/edit.html.erb +10 -0
- data/app/views/my/profiles/edit/_form.html.erb +70 -0
- data/app/views/my/profiles/new.html.erb +7 -0
- data/app/views/my/profiles/new/_form.html.erb +34 -0
- data/app/views/my/profiles/show.html.erb +3 -0
- data/app/views/my/recoveries/show.html.erb +39 -0
- data/app/views/privilege_groups/_form.html.erb +25 -0
- data/app/views/privilege_groups/edit.html.erb +17 -0
- data/app/views/privilege_groups/new.html.erb +15 -0
- data/app/views/privileges/_form.html.erb +42 -0
- data/app/views/privileges/edit.html.erb +21 -0
- data/app/views/privileges/new.html.erb +14 -0
- data/app/views/profiles/_profile.html.erb +48 -0
- data/app/views/profiles/show.html.erb +4 -0
- data/app/views/shared/_flash_messages.html.erb +7 -0
- data/app/views/shared/_list_of_errors.html.erb +11 -0
- data/app/views/shared/_meta_texts.html.erb +17 -0
- data/app/views/shared/_nothing_found.html.erb +1 -0
- data/app/views/shared/_track.html.erb +10 -0
- data/app/views/shared/actions/_locks.html.erb +4 -0
- data/app/views/shared/actions/_priority_changer.html.erb +4 -0
- data/app/views/shared/admin/_breadcrumbs.html.erb +6 -0
- data/app/views/shared/editable_pages/_body.html.erb +12 -0
- data/app/views/shared/filter/_flag.html.erb +17 -0
- data/app/views/tokens/_form.html.erb +30 -0
- data/app/views/tokens/edit.html.erb +17 -0
- data/app/views/tokens/new.html.erb +15 -0
- data/app/views/users/_form.html.erb +78 -0
- data/app/views/users/edit.html.erb +18 -0
- data/app/views/users/new.html.erb +15 -0
- data/config/initializers/carrierwave.rb +22 -0
- data/config/initializers/pluralization.rb +2 -0
- data/config/locales/common-ru.yml +96 -0
- data/config/locales/editable-pages-ru.yml +43 -0
- data/config/locales/plurals.rb +17 -0
- data/config/locales/track-ru.yml +102 -0
- data/config/locales/users-ru.yml +324 -0
- data/config/routes.rb +92 -0
- data/db/migrate/20170301000001_create_metrics.rb +23 -0
- data/db/migrate/20170301000002_create_metric_values.rb +19 -0
- data/db/migrate/20170301000101_create_browsers.rb +22 -0
- data/db/migrate/20170301000102_create_agents.rb +22 -0
- data/db/migrate/20170302000001_create_users.rb +52 -0
- data/db/migrate/20170302000002_create_tokens.rb +23 -0
- data/db/migrate/20170302000003_create_code_types.rb +20 -0
- data/db/migrate/20170302000004_create_codes.rb +24 -0
- data/db/migrate/20170302000101_create_privileges.rb +34 -0
- data/db/migrate/20170302000102_create_user_privileges.rb +17 -0
- data/db/migrate/20170302000103_create_privilege_groups.rb +23 -0
- data/db/migrate/20170302000104_create_privilege_group_privileges.rb +24 -0
- data/db/migrate/20170320000000_create_editable_pages.rb +22 -0
- data/db/migrate/20170425000001_create_foreign_sites.rb +18 -0
- data/db/migrate/20170425000002_create_foreign_users.rb +23 -0
- data/lib/biovision/base.rb +9 -0
- data/lib/biovision/base/base_methods.rb +96 -0
- data/lib/biovision/base/engine.rb +17 -0
- data/lib/biovision/base/privilege_methods.rb +35 -0
- data/lib/biovision/base/version.rb +5 -0
- data/lib/tasks/biovision/agents.rake +38 -0
- data/lib/tasks/biovision/base_tasks.rake +4 -0
- data/lib/tasks/biovision/browsers.rake +38 -0
- data/lib/tasks/biovision/codes.rake +49 -0
- data/lib/tasks/biovision/tokens.rake +54 -0
- data/lib/tasks/biovision/users.rake +67 -0
- metadata +467 -0
data/app/models/user.rb
ADDED
@@ -0,0 +1,29 @@
|
|
1
|
+
class Canonizer
|
2
|
+
TRANSLITERATION_MAP = {
|
3
|
+
'а' => 'a', 'б' => 'b', 'в' => 'v', 'г' => 'g', 'д' => 'd', 'е' => 'e', 'ё' => 'yo',
|
4
|
+
'ж' => 'zh', 'з' => 'z', 'и' => 'i', 'й' => 'j', 'к' => 'k', 'л' => 'l', 'м' => 'm',
|
5
|
+
'н' => 'n', 'о' => 'o', 'п' => 'p', 'р' => 'r', 'с' => 's', 'т' => 't', 'у' => 'u',
|
6
|
+
'ф' => 'f', 'х' => 'kh', 'ц' => 'c', 'ч' => 'ch', 'ш' => 'sh', 'щ' => 'shh', 'ъ' => '',
|
7
|
+
'ы' => 'y', 'ь' => '', 'э' => 'e', 'ю' => 'yu', 'я' => 'ya',
|
8
|
+
}
|
9
|
+
|
10
|
+
# @param [String] text
|
11
|
+
def self.transliterate(text)
|
12
|
+
result = text.mb_chars.downcase.to_s
|
13
|
+
TRANSLITERATION_MAP.each { |r, e| result.gsub!(r, e) }
|
14
|
+
result.downcase.gsub(/[^-a-z0-9_]/, '-').gsub(/^[-_]*([-a-z0-9_]*[a-z0-9]+)[-_]*$/, '\1').gsub(/--+/, '-')
|
15
|
+
end
|
16
|
+
|
17
|
+
# @param [String] input
|
18
|
+
def self.canonize(input)
|
19
|
+
lowered = input.mb_chars.downcase.to_s.strip
|
20
|
+
canonized = lowered.gsub(/[^a-zа-я0-9ё]/, '')
|
21
|
+
canonized.empty? ? lowered : canonized
|
22
|
+
end
|
23
|
+
|
24
|
+
# @param [String] input
|
25
|
+
def self.urlize(input)
|
26
|
+
lowered = input.mb_chars.downcase.to_s.squish
|
27
|
+
lowered.gsub(/[^a-zа-я0-9ё]/, '-').gsub(/-\z/, '')
|
28
|
+
end
|
29
|
+
end
|
@@ -0,0 +1,16 @@
|
|
1
|
+
class CodeManager
|
2
|
+
attr_accessor :user, :code
|
3
|
+
|
4
|
+
# @param [Symbol|String] slug
|
5
|
+
def self.handler(slug)
|
6
|
+
class_name = "#{self.class}::#{slug.split('_').map(&:capitalize).join}"
|
7
|
+
Object.const_get(class_name)
|
8
|
+
end
|
9
|
+
|
10
|
+
# @param [Code] code
|
11
|
+
# @param [User] user
|
12
|
+
def initialize(code, user = nil)
|
13
|
+
@code = code
|
14
|
+
@user = user
|
15
|
+
end
|
16
|
+
end
|
@@ -0,0 +1,26 @@
|
|
1
|
+
class CodeManager::Confirmation < CodeManager
|
2
|
+
# @return [CodeType]
|
3
|
+
def self.code_type
|
4
|
+
@code_type ||= CodeType.find_by!(slug: 'confirmation')
|
5
|
+
end
|
6
|
+
|
7
|
+
# @param [User] user
|
8
|
+
def self.code_for_user(user)
|
9
|
+
code = code_type.codes.active.find_by(user: user)
|
10
|
+
if code.nil?
|
11
|
+
code = code_type.codes.create(user: user, payload: user.email)
|
12
|
+
end
|
13
|
+
code
|
14
|
+
end
|
15
|
+
|
16
|
+
def code_is_valid?
|
17
|
+
return false if @code.nil?
|
18
|
+
@code.owned_by?(@user) && @code.active? && @code.code_type == self.code_type
|
19
|
+
end
|
20
|
+
|
21
|
+
def activate
|
22
|
+
return if @code.quantity < 1
|
23
|
+
@code.decrement!(:quantity)
|
24
|
+
@code.user.update email_confirmed: true if @code.payload == @code.user.email
|
25
|
+
end
|
26
|
+
end
|
@@ -0,0 +1,27 @@
|
|
1
|
+
class CodeManager::Invitation < CodeManager
|
2
|
+
# @return [CodeType]
|
3
|
+
def self.code_type
|
4
|
+
@code_type ||= CodeType.find_by!(slug: 'invitation')
|
5
|
+
end
|
6
|
+
|
7
|
+
# @param [User] user
|
8
|
+
def self.code_for_user(user)
|
9
|
+
code = code_type.codes.active.owned_by(user).first
|
10
|
+
if code.nil?
|
11
|
+
code = code_type.codes.create(user: user)
|
12
|
+
end
|
13
|
+
code
|
14
|
+
end
|
15
|
+
|
16
|
+
def code_is_valid?
|
17
|
+
return false if @code.nil?
|
18
|
+
@code.active? && @code.code_type == self.code_type
|
19
|
+
end
|
20
|
+
|
21
|
+
# @param [User] invitee
|
22
|
+
def activate(invitee)
|
23
|
+
return if invitee.nil? || @code.quantity < 1
|
24
|
+
@code.decrement!(:quantity)
|
25
|
+
invitee.update(inviter_id: @code.user_id)
|
26
|
+
end
|
27
|
+
end
|
@@ -0,0 +1,31 @@
|
|
1
|
+
class CodeManager::Recovery < CodeManager
|
2
|
+
# @return [CodeType]
|
3
|
+
def self.code_type
|
4
|
+
@code_type ||= CodeType.find_by!(slug: 'recovery')
|
5
|
+
end
|
6
|
+
|
7
|
+
# @param [User] user
|
8
|
+
def self.code_for_user(user)
|
9
|
+
code = code_type.codes.active.find_by(user: user)
|
10
|
+
if code.nil?
|
11
|
+
code = code_type.codes.create(user: user, payload: user.email)
|
12
|
+
end
|
13
|
+
code
|
14
|
+
end
|
15
|
+
|
16
|
+
def code_is_valid?
|
17
|
+
return false if @code.nil?
|
18
|
+
@code.active? && @code.code_type == self.class.code_type
|
19
|
+
end
|
20
|
+
|
21
|
+
# @param [Hash] new_parameters
|
22
|
+
def activate(new_parameters)
|
23
|
+
return false if @code.quantity < 1 || new_parameters[:password].blank?
|
24
|
+
new_parameters[:email_confirmed] = true if @code.payload == @code.user.email
|
25
|
+
user_updated = @code.user.update(new_parameters)
|
26
|
+
if user_updated
|
27
|
+
@code.decrement!(:quantity)
|
28
|
+
end
|
29
|
+
user_updated
|
30
|
+
end
|
31
|
+
end
|
@@ -0,0 +1,62 @@
|
|
1
|
+
class AvatarUploader < CarrierWave::Uploader::Base
|
2
|
+
include CarrierWave::MiniMagick
|
3
|
+
include CarrierWave::BombShelter
|
4
|
+
|
5
|
+
def max_pixel_dimensions
|
6
|
+
[4000, 4000]
|
7
|
+
end
|
8
|
+
|
9
|
+
storage :file
|
10
|
+
|
11
|
+
def store_dir
|
12
|
+
"uploads/#{model.class.to_s.underscore}/#{mounted_as}/#{model.id/10000.floor}/#{model.id/100.floor}/#{model.id}"
|
13
|
+
end
|
14
|
+
|
15
|
+
def default_url
|
16
|
+
ActionController::Base.helpers.asset_path('biovision/base/placeholders/user.svg')
|
17
|
+
end
|
18
|
+
|
19
|
+
process :auto_orient
|
20
|
+
|
21
|
+
def auto_orient
|
22
|
+
manipulate! do |image|
|
23
|
+
image.tap(&:auto_orient)
|
24
|
+
end
|
25
|
+
end
|
26
|
+
|
27
|
+
version :big_2x do
|
28
|
+
resize_to_fit(1280, 1280)
|
29
|
+
end
|
30
|
+
|
31
|
+
version :big, from_version: :big_2x do
|
32
|
+
resize_to_fit(640, 640)
|
33
|
+
end
|
34
|
+
|
35
|
+
version :profile_2x, from_version: :big do
|
36
|
+
resize_to_fit(640, 640)
|
37
|
+
end
|
38
|
+
|
39
|
+
version :profile, from_version: :profile_2x do
|
40
|
+
resize_to_fit(320, 320)
|
41
|
+
end
|
42
|
+
|
43
|
+
version :preview_2x, from_version: :profile do
|
44
|
+
resize_to_fit(160, 160)
|
45
|
+
end
|
46
|
+
|
47
|
+
version :preview, from_version: :preview_2x do
|
48
|
+
resize_to_fit(80, 80)
|
49
|
+
end
|
50
|
+
|
51
|
+
version :tiny_2x, from_version: :preview do
|
52
|
+
resize_to_fit(48, 48)
|
53
|
+
end
|
54
|
+
|
55
|
+
version :tiny, from_version: :tiny_2x do
|
56
|
+
resize_to_fit(24, 24)
|
57
|
+
end
|
58
|
+
|
59
|
+
def extension_white_list
|
60
|
+
%w(jpg jpeg png)
|
61
|
+
end
|
62
|
+
end
|
@@ -0,0 +1,38 @@
|
|
1
|
+
class EditablePageImageUploader < CarrierWave::Uploader::Base
|
2
|
+
include CarrierWave::MiniMagick
|
3
|
+
include CarrierWave::BombShelter
|
4
|
+
|
5
|
+
def max_pixel_dimensions
|
6
|
+
[2000, 2000]
|
7
|
+
end
|
8
|
+
|
9
|
+
storage :file
|
10
|
+
|
11
|
+
# Override the directory where uploaded files will be stored.
|
12
|
+
# This is a sensible default for uploaders that are meant to be mounted:
|
13
|
+
def store_dir
|
14
|
+
"uploads/#{model.class.to_s.underscore}/#{mounted_as}/#{model.id}"
|
15
|
+
end
|
16
|
+
|
17
|
+
version :medium_2x do
|
18
|
+
resize_to_fit 1280, 1280
|
19
|
+
end
|
20
|
+
|
21
|
+
version :medium, from_version: :medium_2x do
|
22
|
+
resize_to_fit 640, 640
|
23
|
+
end
|
24
|
+
|
25
|
+
version :preview_2x, from_version: :medium do
|
26
|
+
resize_to_fit 160, 160
|
27
|
+
end
|
28
|
+
|
29
|
+
version :preview, from_version: :preview_2x do
|
30
|
+
resize_to_fit 80, 80
|
31
|
+
end
|
32
|
+
|
33
|
+
# Add a white list of extensions which are allowed to be uploaded.
|
34
|
+
# For images you might use something like this:
|
35
|
+
def extension_whitelist
|
36
|
+
%w(jpg jpeg png)
|
37
|
+
end
|
38
|
+
end
|
@@ -0,0 +1,16 @@
|
|
1
|
+
<%= form_tag admin_agents_path, method: :get, class: :filter do %>
|
2
|
+
<fieldset>
|
3
|
+
<legend><%= t(:filter) %></legend>
|
4
|
+
|
5
|
+
<div>
|
6
|
+
<div><%= label_tag 'filter_name', t('activerecord.attributes.agent.name') %></div>
|
7
|
+
<div><%= search_field_tag 'filter[name]', filter[:name], size: 30, results: 5, autosave: 'agent_name' %></div>
|
8
|
+
</div>
|
9
|
+
|
10
|
+
<%= render partial: 'shared/filter/flag', locals: { title: t('activerecord.attributes.agent.bot'), name: 'bots', state: filter[:bots] } %>
|
11
|
+
<%= render partial: 'shared/filter/flag', locals: { title: t('activerecord.attributes.agent.mobile'), name: 'mobile', state: filter[:mobile] } %>
|
12
|
+
<%= render partial: 'shared/filter/flag', locals: { title: t('activerecord.attributes.agent.active'), name: 'active', state: filter[:active] } %>
|
13
|
+
|
14
|
+
<div class="button"><%= button_tag t(:submit), type: :submit, name: '' %></div>
|
15
|
+
</fieldset>
|
16
|
+
<% end %>
|
@@ -0,0 +1,17 @@
|
|
1
|
+
<% if collection.any? %>
|
2
|
+
<ul class="list-of-entities">
|
3
|
+
<% collection.each do |entity| %>
|
4
|
+
<% if entity.deleted? %>
|
5
|
+
<li class="deleted">
|
6
|
+
<%= t(:deleted_entity) %>, id: <%= entity.id %>
|
7
|
+
</li>
|
8
|
+
<% else %>
|
9
|
+
<li data-id="<%= entity.id %>">
|
10
|
+
<%= render partial: 'admin/agents/entity/in_list', locals: { entity: entity } %>
|
11
|
+
</li>
|
12
|
+
<% end %>
|
13
|
+
<% end %>
|
14
|
+
</ul>
|
15
|
+
<% else %>
|
16
|
+
<%= render 'shared/nothing_found' %>
|
17
|
+
<% end %>
|
@@ -0,0 +1,7 @@
|
|
1
|
+
<div class="toggleable" data-url="<%= toggle_admin_agent_path(entity) %>">
|
2
|
+
<% Agent.toggleable_attributes.each do |flag| %>
|
3
|
+
<span class="<%= entity.attributes[flag.to_s] ? 'active' : 'inactive' %>" data-flag="<%= flag %>">
|
4
|
+
<%= t("activerecord.attributes.agent.#{flag}") %>
|
5
|
+
</span>
|
6
|
+
<% end %>
|
7
|
+
</div>
|
@@ -0,0 +1,13 @@
|
|
1
|
+
<div class="data">
|
2
|
+
<div class="truncate"><%= admin_agent_link(entity) %></div>
|
3
|
+
<% unless entity.browser.nil? %>
|
4
|
+
<div class="info"><%= admin_browser_link(entity.browser) %></div>
|
5
|
+
<% end %>
|
6
|
+
<%= render partial: 'admin/agents/toggleable', locals: { entity: entity } %>
|
7
|
+
<ul class="actions">
|
8
|
+
<li class="lockable <%= entity.locked? ? 'hidden' : '' %>">
|
9
|
+
<%= edit_icon edit_agent_path(entity) %>
|
10
|
+
</li>
|
11
|
+
<%= render partial: 'shared/actions/locks', locals: { path: lock_admin_agent_path(entity), entity: entity } %>
|
12
|
+
</ul>
|
13
|
+
</div>
|
@@ -0,0 +1,17 @@
|
|
1
|
+
<% content_for :meta_title, t('.title', page: current_page) %>
|
2
|
+
<% content_for :breadcrumbs do %>
|
3
|
+
<span><%= t('admin.agents.nav_item.text') %></span>
|
4
|
+
<% end %>
|
5
|
+
|
6
|
+
<article class="entity-page">
|
7
|
+
<h1><%= t('.heading') %></h1>
|
8
|
+
<ul class="actions">
|
9
|
+
<li><%= back_icon(admin_path) %></li>
|
10
|
+
</ul>
|
11
|
+
|
12
|
+
<%= render partial: 'filter', locals: { filter: @filter } %>
|
13
|
+
|
14
|
+
<%= paginate @collection %>
|
15
|
+
<%= render partial: 'list', locals: { collection: @collection } %>
|
16
|
+
<%= paginate @collection %>
|
17
|
+
</article>
|
@@ -0,0 +1,28 @@
|
|
1
|
+
<% content_for :meta_title, t('.title', name: @entity.name) %>
|
2
|
+
<% content_for :breadcrumbs do %>
|
3
|
+
<%= link_to(t('admin.agents.nav_item.text'), admin_agents_path) %>
|
4
|
+
<span><%= @entity.name %></span>
|
5
|
+
<% end %>
|
6
|
+
|
7
|
+
<article class="entity-page">
|
8
|
+
<h1><%= @entity.name %></h1>
|
9
|
+
|
10
|
+
<ul class="actions">
|
11
|
+
<li><%= return_icon(admin_agents_path) %></li>
|
12
|
+
<% unless @entity.locked? %>
|
13
|
+
<li><%= edit_icon edit_agent_path(@entity.id) %></li>
|
14
|
+
<li class="danger"><%= destroy_icon @entity %></li>
|
15
|
+
<% end %>
|
16
|
+
</ul>
|
17
|
+
|
18
|
+
<% unless @entity.browser.nil? %>
|
19
|
+
<dl>
|
20
|
+
<dt><%= t('activerecord.attributes.agent.browser_id') %></dt>
|
21
|
+
<dd>
|
22
|
+
<%= admin_browser_link(@entity.browser) %>
|
23
|
+
</dd>
|
24
|
+
</dl>
|
25
|
+
<% end %>
|
26
|
+
|
27
|
+
<%= render partial: 'admin/agents/toggleable', locals: { entity: @entity } %>
|
28
|
+
</article>
|
@@ -0,0 +1,17 @@
|
|
1
|
+
<% if collection.any? %>
|
2
|
+
<ul class="list-of-entities">
|
3
|
+
<% collection.each do |entity| %>
|
4
|
+
<% if entity.deleted? %>
|
5
|
+
<li class="deleted">
|
6
|
+
<%= t(:deleted_entity) %>, id: <%= entity.id %>
|
7
|
+
</li>
|
8
|
+
<% else %>
|
9
|
+
<li data-id="<%= entity.id %>">
|
10
|
+
<%= render partial: 'admin/browsers/entity/in_list', locals: { entity: entity } %>
|
11
|
+
</li>
|
12
|
+
<% end %>
|
13
|
+
<% end %>
|
14
|
+
</ul>
|
15
|
+
<% else %>
|
16
|
+
<%= render 'shared/nothing_found' %>
|
17
|
+
<% end %>
|
@@ -0,0 +1,7 @@
|
|
1
|
+
<div class="toggleable" data-url="<%= toggle_admin_browser_path(entity) %>">
|
2
|
+
<% Browser.toggleable_attributes.each do |flag| %>
|
3
|
+
<span class="<%= entity.attributes[flag.to_s] ? 'active' : 'inactive' %>" data-flag="<%= flag %>">
|
4
|
+
<%= t("activerecord.attributes.browser.#{flag}") %>
|
5
|
+
</span>
|
6
|
+
<% end %>
|
7
|
+
</div>
|
@@ -0,0 +1,79 @@
|
|
1
|
+
<section>
|
2
|
+
<h2><%= t('agents.new.title') %></h2>
|
3
|
+
|
4
|
+
<%= render partial: 'admin/agents/filter', locals: { filter: Hash.new } %>
|
5
|
+
|
6
|
+
<ul id="found-agents" class="list-of-entities dynamic" data-browser-id="<%= browser.id %>">
|
7
|
+
|
8
|
+
</ul>
|
9
|
+
</section>
|
10
|
+
|
11
|
+
<script>
|
12
|
+
"use strict";
|
13
|
+
|
14
|
+
$(function () {
|
15
|
+
let $container = $('#found-agents');
|
16
|
+
|
17
|
+
function show_found_agents(agents) {
|
18
|
+
$container.html('');
|
19
|
+
|
20
|
+
$(agents).each(function() {
|
21
|
+
let agent = $(this)[0]['agent'];
|
22
|
+
let $li = $('<li data-url="' + agent['url'] + '">');
|
23
|
+
|
24
|
+
$li.html('<div class="add"><button type="button">+</button></div>' + agent['html']);
|
25
|
+
|
26
|
+
$container.append($li);
|
27
|
+
});
|
28
|
+
}
|
29
|
+
|
30
|
+
function add_agent(agent) {
|
31
|
+
let $section = $('#browser-agents');
|
32
|
+
let $notice = $section.find('div.warning');
|
33
|
+
let $container;
|
34
|
+
let $li = $('<li>');
|
35
|
+
|
36
|
+
if ($notice.hasOwnProperty(0)) {
|
37
|
+
$notice.remove();
|
38
|
+
$container = $('<ul class="list-of-entities">');
|
39
|
+
$section.append($container);
|
40
|
+
} else {
|
41
|
+
$container = $section.find('ul.list-of-entities');
|
42
|
+
}
|
43
|
+
|
44
|
+
$li.html(agent['html']);
|
45
|
+
$container.append($li);
|
46
|
+
}
|
47
|
+
|
48
|
+
$('#agents-filter').on('submit', function () {
|
49
|
+
$.get($(this).attr('action'), $(this).serialize(), function (response) {
|
50
|
+
if (response.hasOwnProperty('data') && response['data'].hasOwnProperty('agents')) {
|
51
|
+
show_found_agents(response['data']['agents']);
|
52
|
+
}
|
53
|
+
}).fail(handle_ajax_failure);
|
54
|
+
|
55
|
+
return false;
|
56
|
+
});
|
57
|
+
|
58
|
+
$(document).on('click', '#found-agents > li button', function () {
|
59
|
+
let $li = $(this).closest('li');
|
60
|
+
let url = $li.data('url');
|
61
|
+
let data = {
|
62
|
+
agent: {
|
63
|
+
browser_id: $(this).closest('ul').data('browser-id')
|
64
|
+
}
|
65
|
+
};
|
66
|
+
|
67
|
+
$.ajax(url, {
|
68
|
+
method: 'patch',
|
69
|
+
data: data,
|
70
|
+
success: function(response) {
|
71
|
+
if (response.hasOwnProperty('data') && response['data'].hasOwnProperty('agent')) {
|
72
|
+
$li.addClass('hidden');
|
73
|
+
add_agent(response['data']['agent']);
|
74
|
+
}
|
75
|
+
}
|
76
|
+
}).fail(handle_ajax_failure);
|
77
|
+
});
|
78
|
+
});
|
79
|
+
</script>
|