thecore_ui_rails_admin 2.1.8 → 2.1.13

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
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