thecore_ui_rails_admin 2.1.8 → 2.1.13

Sign up to get free protection for your applications and to get access to all the features.
Files changed (33) hide show
  1. checksums.yaml +4 -4
  2. data/app/assets/javascripts/rails_admin/ra.widgets.coffee +233 -0
  3. data/app/assets/javascripts/thecore_ui_rails_admin/thecore_rails_admin.js +3 -24
  4. data/app/assets/stylesheets/thecore_ui_rails_admin/apexcharts.scss +7 -0
  5. data/app/assets/stylesheets/thecore_ui_rails_admin/colors.scss +21 -0
  6. data/app/assets/stylesheets/thecore_ui_rails_admin/common.scss +14 -3
  7. data/app/assets/stylesheets/thecore_ui_rails_admin/devise.scss +19 -26
  8. data/app/assets/stylesheets/thecore_ui_rails_admin/flashing.scss +3 -3
  9. data/app/assets/stylesheets/thecore_ui_rails_admin/thecore.scss +19 -4
  10. data/app/assets/stylesheets/thecore_ui_rails_admin/thecore_rails_admin.scss +152 -43
  11. data/app/assets/stylesheets/thecore_ui_rails_admin/togglable-sidebar.scss +5 -2
  12. data/app/views/layouts/rails_admin/_secondary_navigation.html.haml +1 -1
  13. data/app/views/layouts/rails_admin/_user_navigation.html.haml +2 -2
  14. data/app/views/layouts/rails_admin/application.html.haml +2 -7
  15. data/app/views/layouts/rails_admin/pjax.html.haml +4 -1
  16. data/app/views/rails_admin/main/_card.html.haml +2 -1
  17. data/app/views/rails_admin/main/dashboard.html.haml +22 -11
  18. data/app/views/rails_admin/main/index.html.haml +19 -20
  19. data/config/initializers/rails_admin.rb +24 -4
  20. data/config/initializers/thecore_concern.rb +0 -1
  21. data/config/initializers/thecore_ui_rails_admin_app_configs.rb +4 -0
  22. data/config/locales/it.index_cards.custom.yml +1 -1
  23. data/config/locales/thecore_settings.en.yml +31 -0
  24. data/config/locales/thecore_settings.it.yml +0 -1
  25. data/lib/abilities/thecore_ui_rails_admin.rb +0 -1
  26. data/lib/concerns/thecore_ui_rails_admin_permission.rb +32 -0
  27. data/lib/concerns/thecore_ui_rails_admin_role.rb +36 -0
  28. data/lib/concerns/thecore_ui_rails_admin_user.rb +56 -59
  29. data/lib/thecore_ui_rails_admin.rb +3 -0
  30. data/lib/thecore_ui_rails_admin/engine.rb +0 -3
  31. data/lib/thecore_ui_rails_admin/version.rb +1 -1
  32. metadata +22 -3
  33. data/app/assets/javascripts/thecore_ui_rails_admin/thecore.js +0 -0
@@ -1,22 +1,33 @@
1
1
  = breadcrumb
2
- - @list_bg = ['info', 'success', 'danger', 'success', 'info', 'warning', 'danger', 'info', 'success']
2
+ - charts_high = []
3
+ - charts_medium = []
4
+ - self.methods.each do |m|
5
+ - charts_high << m if m.start_with? "charts_high_"
6
+ - charts_medium << m if m.start_with? "charts_medium_"
7
+
8
+ - charts_high.in_groups_of(2, false).each_with_index do |group, i|
9
+ .row
10
+ - group.each do |item|
11
+ .col-sm-6
12
+ .box= self.send(item)
13
+
14
+ - charts_medium.in_groups_of(3, false).each_with_index do |group, i|
15
+ .row
16
+ - group.each do |item|
17
+ .col-sm-4
18
+ .box= self.send(item)
19
+
3
20
  - if @abstract_models
4
21
  .row
5
- - index = 0
6
22
  - @abstract_models.each do |abstract_model|
7
23
  - index_path = index_path(model_name: abstract_model.to_param)
8
- - if authorized?(:index, abstract_model) && !index_path.include?("ckeditor")
9
- - if index == @list_bg.length
10
- - index = 0
11
- - row_class = "box bg-#{ @list_bg[index].to_s } #{"link" if index_path} #{abstract_model.param_key}_links #{abstract_model.config.label_plural}"
24
+ - if authorized?(:index, abstract_model)
12
25
  .col-sm-4
13
- .box{class: row_class, :"data-link" => index_path}
26
+ %a.box.pjax{href: index_path}
14
27
  %i{class: "icon-bg #{abstract_model.config.navigation_icon.present? ? abstract_model.config.navigation_icon : 'file' }"}
15
28
  .text-center
16
- %p= capitalize_first_letter(abstract_model.config.label_plural)
17
- %strong= @count[abstract_model.model.name].to_s
18
- %p= link_to t('admin.rollincode.show'), index_path, class: 'btn btn-black pjax'
19
- - index += 1
29
+ %p.model= capitalize_first_letter(abstract_model.config.label_plural)
30
+ %strong.count= @count[abstract_model.model.name].to_s
20
31
 
21
32
  - if @auditing_adapter && authorized?(:history_index)
22
33
  #block-tables.block
@@ -24,10 +24,10 @@
24
24
  = bulk_menu
25
25
  - if filterable_fields.present?
26
26
  %li.dropdown{style: 'float:right'}
27
- %a.dropdown-toggle{href: '#', :'data-toggle' => "dropdown"}
27
+ %a.dropdown-toggle#filters-menu{ :'data-toggle' => "dropdown", :'aria-haspopup'=>"true", :'aria-expanded'=>"true"}
28
28
  = t('admin.misc.add_filter')
29
29
  %b.caret
30
- %ul.dropdown-menu#filters{style: 'left:auto; right:0;'}
30
+ %ul.dropdown-menu#filters{style: 'left:auto; right:0;', :'aria-labelledby'=>"filters-menu"}
31
31
  - filterable_fields.each do |field|
32
32
  - field_options = case field.type
33
33
  - when :enum
@@ -44,27 +44,26 @@
44
44
 
45
45
  #list
46
46
  = form_tag(index_path(params.except(*%w[page f query])), method: :get, class: "pjax-form form-inline") do
47
- .well
48
- %span#filters_box{data: {options: ordered_filter_options.to_json}}
49
- %hr.filters_box{style: "display:#{ordered_filters.empty? ? 'none' : 'block'}"}
50
- .input-group
51
- %input.form-control.input-small{name: "query", type: "search", value: query, placeholder: t("admin.misc.filter")}
52
- %span.input-group-btn
53
- %button.btn.btn-primary{type: 'submit', :'data-disable-with' => '<i class="icon-white icon-refresh"></i> '.html_safe + t('admin.misc.refresh')}
54
- %i.icon-white.icon-refresh
55
- = t('admin.misc.refresh')
56
- %button#remove_filter.btn.btn-info{title: "Reset filters"}
57
- %i.icon-white.icon-remove
58
- - if export_action
59
- %span{style: 'float:right'}= link_to wording_for(:link, export_action), export_path(params.except('set').except('page')), class: 'btn btn-info'
47
+ %span#filters_box{data: {options: ordered_filter_options.to_json}}
48
+ %hr.filters_box{style: "display:#{ordered_filters.empty? ? 'none' : 'block'}"}
49
+ .input-group
50
+ %input.form-control.input-small{name: "query", type: "search", value: query, placeholder: t("admin.misc.filter")}
51
+ %span.input-group-btn
52
+ %button.btn.btn-primary{type: 'submit', :'data-disable-with' => '<i class="icon-white icon-refresh"></i> '.html_safe + t('admin.misc.refresh')}
53
+ %i.icon-white.icon-refresh
54
+ = t('admin.misc.refresh')
55
+ %button#remove_filter.btn.btn-info{title: "Reset filters"}
56
+ %i.icon-white.icon-remove
57
+ - if export_action
58
+ %span{style: 'float:right'}= link_to wording_for(:link, export_action), export_path(params.except('set').except('page')), class: 'btn btn-info'
60
59
 
61
60
  - unless @model_config.list.scopes.empty?
62
- %ul.nav.nav-tabs#scope_selector
63
- - @model_config.list.scopes.each_with_index do |scope, index|
61
+ %ul.nav.nav-tabs.nav-justified#scope_selector
62
+ - @model_config.list.scopes.each do |scope|
64
63
  - scope = '_all' if scope.nil?
65
- %li{class: "#{'active' if scope.to_s == params[:scope] || (params[:scope].blank? && index == 0)}"}
66
- %a{href: index_path(params.merge(scope: scope, page: nil)), class: 'pjax'}= I18n.t("admin.scopes.#{@abstract_model.to_param}.#{scope}", default: I18n.t("admin.scopes.#{scope}", default: scope.to_s.titleize))
67
-
64
+ %li{ class: "#{ scope.to_s == params[:scope] || (params[:scope].nil? && scope == "_all") ? "selected" : "inactive"}"}
65
+ %a.nav-link{href: index_path(params.merge(scope: scope, page: nil)), class: 'pjax'}= I18n.t("admin.scopes.#{@abstract_model.to_param}.#{scope}", default: I18n.t("admin.scopes.#{scope}", default: scope.to_s.titleize))
66
+
68
67
  = form_tag bulk_action_path(model_name: @abstract_model.to_param), method: :post, id: "bulk_form", class: ["form", frozen_columns ? 'ra-sidescroll' : nil], data: (frozen_columns ? {ra_sidescroll: frozen_columns} : {}) do
69
68
  = hidden_field_tag :bulk_action
70
69
  - if description.present?
@@ -1,14 +1,34 @@
1
1
  require 'rails_admin'
2
2
 
3
3
  RailsAdmin.config do |config|
4
- # config.main_app_name = Proc.new { |controller|
5
- # [(Settings.app_name rescue (ENV["APP_NAME"] || "TheCore App")), "#{controller.params[:action].try(:titleize)} (#{Time.zone.now.to_s(:time)})"]
6
- # }
4
+ # Link for background Job
5
+ (config.navigation_static_links ||= {}).merge! "Background Monitor" => "#{ENV['RAILS_RELATIVE_URL_ROOT']}/app/sidekiq"
6
+
7
7
  ### Popular gems integration
8
8
  config.model "RoleUser" do
9
9
  visible false
10
10
  end
11
11
 
12
+ config.model "Predicate" do
13
+ visible false
14
+ end
15
+
16
+ config.model "Target" do
17
+ visible false
18
+ end
19
+
20
+ config.model "Action" do
21
+ visible false
22
+ end
23
+
24
+ config.model "PermissionRole" do
25
+ visible false
26
+ end
27
+
28
+ config.model "Permission" do
29
+ visible false
30
+ end
31
+
12
32
  config.model "ActionText::RichText" do
13
33
  visible false
14
34
  end
@@ -32,7 +52,7 @@ RailsAdmin.config do |config|
32
52
 
33
53
  ## == PaperTrail ==
34
54
  # config.audit_with :paper_trail, 'User', 'PaperTrail::Version' # PaperTrail >= 3.0.0
35
-
55
+ config.show_gravatar = false
36
56
  ### More at https://github.com/sferik/rails_admin/wiki/Base-configuration
37
57
  config.label_methods.unshift(:display_name)
38
58
 
@@ -12,7 +12,6 @@ module ThecoreConcern
12
12
  redirect_to main_app.root_url, :alert => exception.message
13
13
  end
14
14
  include HttpAcceptLanguage::AutoLocale
15
- Rails.logger.debug "Selected Locale: #{I18n.locale}"
16
15
  before_action :store_user_location!, if: :storable_location?
17
16
  before_action :configure_permitted_parameters, if: :devise_controller?
18
17
  before_action :reject_locked!, if: :devise_controller?
@@ -1,4 +1,6 @@
1
1
  Rails.application.configure do
2
+ # config.assets.paths << root.join("app", "assets", "stylesheets", "thecore_ui_rails_admin")
3
+ # config.assets.paths << root.join("app", "assets", "javascripts", "thecore_ui_rails_admin")
2
4
  # Login Page and pages not in RailsAdmin
3
5
  config.assets.precompile += %w( thecore_ui_rails_admin/thecore.css thecore_ui_rails_admin/thecore.js )
4
6
  # Pages under Rails Admin
@@ -9,5 +11,7 @@ Rails.application.configure do
9
11
  RailsAdmin::Config::Actions::BulkDelete.send(:include, BulkDeleteConcern)
10
12
  RailsAdminSettings::Setting.send(:include, RailsAdminSettings::RailsAdminExtensionConfig)
11
13
  User.send(:include, ThecoreUiRailsAdminUser)
14
+ Role.send(:include, ThecoreUiRailsAdminRole)
15
+ Permission.send(:include, ThecoreUiRailsAdminPermission)
12
16
  end
13
17
  end
@@ -14,7 +14,7 @@ it:
14
14
  scopes: ⋔
15
15
  add_filter: ⋔
16
16
  add_new: ⋔
17
- refresh: ""
17
+ refresh: Apply Filters
18
18
  bulk_menu_title: ☰✔
19
19
  select:
20
20
  toggle: ☑
@@ -0,0 +1,31 @@
1
+ en:
2
+ settings:
3
+ namespaces:
4
+ main: Main
5
+ names:
6
+ app_name: Application Name
7
+ admin:
8
+ settings:
9
+ label: Settings
10
+ phone_invalid: Invalid Telephone
11
+ phones_invalid: "Invalid Telephones: %{phones}"
12
+ email_invalid: Invalid Email
13
+ yaml_invalid: Invalid Email
14
+ color_invalid: Invalid Color
15
+ mongoid: &mongoid
16
+ models:
17
+ rails_admin_settings/setting: Configurations
18
+ attributes:
19
+ rails_admin_settings/setting:
20
+ c_at: Created
21
+ u_at: Modified
22
+ enabled: Enabled
23
+ ns: Group
24
+ name: Name
25
+ key: Key
26
+ raw: Value
27
+ type: Type
28
+ kind: Type
29
+ label: Label
30
+ activerecord:
31
+ <<: *mongoid
@@ -7,7 +7,6 @@ it:
7
7
  admin:
8
8
  settings:
9
9
  label: 'Impostazioni'
10
- no_ckeditor_detected: CKEditor non trovato &mdash; mostro il campo come semplice testo
11
10
  phone_invalid: Telefono non valido
12
11
  phones_invalid: "Telefono non valido: %{phones}"
13
12
  email_invalid: Email non valida
@@ -2,7 +2,6 @@ module Abilities
2
2
  class ThecoreUiRailsAdmin
3
3
  include CanCan::Ability
4
4
  def initialize user
5
- puts "LAMMEEEEEEEEERDAAAAAAAAAAAAAAAAAAAAAAAA"
6
5
  # No one is allowed to add or destroy settings
7
6
  # just list or edit existing
8
7
  cannot :create, RailsAdminSettings::Setting
@@ -0,0 +1,32 @@
1
+ require 'active_support/concern'
2
+
3
+ module ThecoreUiRailsAdminPermission
4
+ extend ActiveSupport::Concern
5
+
6
+ included do
7
+
8
+ rails_admin do
9
+ field :predicate
10
+ field :action
11
+ field :target
12
+ list do
13
+ field :created_at
14
+ exclude_fields :lock_version
15
+ end
16
+ show do
17
+ exclude_fields :id
18
+ exclude_fields :lock_version
19
+ end
20
+ create do
21
+ field :lock_version, :hidden do
22
+ visible true
23
+ end
24
+ end
25
+ edit do
26
+ field :lock_version, :hidden do
27
+ visible true
28
+ end
29
+ end
30
+ end
31
+ end
32
+ end
@@ -0,0 +1,36 @@
1
+ require 'active_support/concern'
2
+
3
+ module ThecoreUiRailsAdminRole
4
+ extend ActiveSupport::Concern
5
+
6
+ included do
7
+
8
+ rails_admin do
9
+ navigation_label I18n.t("admin.settings.label")
10
+ navigation_icon 'fa fa-group'
11
+ desc I18n.t("activerecord.descriptions.role")
12
+
13
+ field :name
14
+ field :permissions, :selectize
15
+ list do
16
+ field :created_at
17
+ exclude_fields :lock_version
18
+ end
19
+ show do
20
+ exclude_fields :id
21
+ exclude_fields :lock_version
22
+ end
23
+ create do
24
+ field :lock_version, :hidden do
25
+ visible true
26
+ end
27
+ # include UserRailsAdminCreateConcern
28
+ end
29
+ edit do
30
+ field :lock_version, :hidden do
31
+ visible true
32
+ end
33
+ end
34
+ end
35
+ end
36
+ end
@@ -5,73 +5,70 @@ module ThecoreUiRailsAdminUser
5
5
 
6
6
  included do
7
7
 
8
- RailsAdmin.config do |config|
9
- config.model self.name.underscore.capitalize.constantize do
10
- # rails_admin do
11
- navigation_label I18n.t("admin.settings.label")
12
- navigation_icon 'fa fa-user-circle'
13
- desc I18n.t("activerecord.descriptions.user")
14
-
15
- weight 1000
16
- # Field present Everywhere
17
- field :email do
18
- required true
8
+ rails_admin do
9
+ # rails_admin do
10
+ navigation_label I18n.t("admin.settings.label")
11
+ navigation_icon 'fa fa-user-circle'
12
+ desc I18n.t("activerecord.descriptions.user")
13
+
14
+ # Field present Everywhere
15
+ field :email do
16
+ required true
17
+ end
18
+ field :username do
19
+ required true
20
+ end
21
+ field :admin do
22
+ visible do
23
+ bindings[:view].current_user.admin? && bindings[:view].current_user.id != bindings[:object].id
19
24
  end
20
- field :username do
21
- required true
25
+ end
26
+ field :locked do
27
+ visible do
28
+ bindings[:view].current_user.admin? && bindings[:view].current_user.id != bindings[:object].id
29
+ end
30
+ end
31
+ field :roles, :selectize
32
+ # include UserRailsAdminConcern
33
+
34
+ # Fields only in lists and forms
35
+ list do
36
+ field :created_at
37
+ configure :email do
38
+ visible false
22
39
  end
23
- field :admin do
24
- visible do
25
- bindings[:view].current_user.admin? && bindings[:view].current_user.id != bindings[:object].id
26
- end
40
+ exclude_fields :lock_version
41
+ # include UserRailsAdminListConcern
42
+ end
43
+ show do
44
+ #exclude_fields :id
45
+ exclude_fields :lock_version
46
+ end
47
+ create do
48
+ field :password do
49
+ required true
27
50
  end
28
- field :locked do
29
- visible do
30
- bindings[:view].current_user.admin? && bindings[:view].current_user.id != bindings[:object].id
31
- end
51
+ field :password_confirmation do
52
+ required true
32
53
  end
33
- field :roles
34
- # include UserRailsAdminConcern
35
-
36
- # Fields only in lists and forms
37
- list do
38
- field :created_at
39
- configure :email do
40
- visible false
41
- end
42
- exclude_fields :lock_version
43
- field :authentication_token
44
- # include UserRailsAdminListConcern
54
+ field :lock_version, :hidden do
55
+ visible true
45
56
  end
46
- show do
47
- #exclude_fields :id
48
- exclude_fields :lock_version
57
+ # include UserRailsAdminCreateConcern
58
+ end
59
+ edit do
60
+ field :password do
61
+ required false
49
62
  end
50
- create do
51
- field :password do
52
- required true
53
- end
54
- field :password_confirmation do
55
- required true
56
- end
57
- field :lock_version, :hidden do
58
- visible true
59
- end
60
- # include UserRailsAdminCreateConcern
63
+ field :password_confirmation do
64
+ required false
61
65
  end
62
- edit do
63
- field :password do
64
- required false
65
- end
66
- field :password_confirmation do
67
- required false
68
- end
69
-
70
- field :lock_version, :hidden do
71
- visible true
72
- end
73
- # include UserRailsAdminEditConcern
66
+
67
+ field :lock_version, :hidden do
68
+ visible true
74
69
  end
70
+ # include UserRailsAdminEditConcern
71
+
75
72
  end
76
73
  end
77
74
  end
@@ -7,6 +7,7 @@ require 'rails_admin-i18n'
7
7
  require 'safe_yaml'
8
8
  require 'rails_admin_toggleable'
9
9
  require 'rails_admin_settings'
10
+ require 'rails_admin_selectize'
10
11
  require 'concerns/rails_admin_requirements'
11
12
  # Abilities
12
13
  require 'abilities/thecore_ui_rails_admin'
@@ -15,6 +16,8 @@ require 'jquery-ui-rails'
15
16
  require 'bootstrap-sass'
16
17
 
17
18
  require 'concerns/thecore_ui_rails_admin_user'
19
+ require 'concerns/thecore_ui_rails_admin_role'
20
+ require 'concerns/thecore_ui_rails_admin_permission'
18
21
  require 'concerns/thecore_rails_admin_export_concern'
19
22
  require 'concerns/thecore_rails_admin_bulk_delete_concern'
20
23