klastera 1.5.3 → 1.5.4

Sign up to get free protection for your applications and to get access to all the features.
Files changed (64) hide show
  1. checksums.yaml +4 -4
  2. data/MIT-LICENSE +20 -0
  3. data/README.rdoc +3 -0
  4. data/Rakefile +37 -0
  5. data/app/assets/javascripts/klastera/application.js +13 -0
  6. data/app/assets/javascripts/klastera/clusters.js +2 -0
  7. data/app/assets/stylesheets/klastera/clusters.scss +46 -0
  8. data/app/controllers/klastera/application_controller.rb +29 -0
  9. data/app/controllers/klastera/clusters_controller.rb +60 -0
  10. data/app/helpers/klastera/application_helper.rb +40 -0
  11. data/app/models/klastera/cluster.rb +5 -0
  12. data/app/models/klastera/cluster_entity.rb +5 -0
  13. data/app/models/klastera/cluster_filter.rb +5 -0
  14. data/app/models/klastera/cluster_user.rb +5 -0
  15. data/app/models/klastera/concerns/cluster.rb +67 -0
  16. data/app/models/klastera/concerns/cluster_entity.rb +18 -0
  17. data/app/models/klastera/concerns/cluster_filter.rb +22 -0
  18. data/app/models/klastera/concerns/cluster_user.rb +41 -0
  19. data/app/models/klastera/concerns/clusterizable.rb +57 -0
  20. data/app/models/klastera/concerns/organization.rb +49 -0
  21. data/app/models/klastera/concerns/transfer.rb +45 -0
  22. data/app/models/klastera/concerns/user.rb +77 -0
  23. data/app/models/klastera/transfer.rb +5 -0
  24. data/app/views/klastera/clusters/_filter.html.erb +0 -0
  25. data/app/views/klastera/clusters/_form.html.erb +22 -0
  26. data/app/views/klastera/clusters/_form_transfer.html.erb +34 -0
  27. data/app/views/klastera/clusters/_table.html.erb +33 -0
  28. data/app/views/klastera/clusters/create.js.erb +1 -0
  29. data/app/views/klastera/clusters/destroy.js.erb +6 -0
  30. data/app/views/klastera/clusters/edit.html.erb +10 -0
  31. data/app/views/klastera/clusters/index.html.erb +21 -0
  32. data/app/views/klastera/clusters/new.html.erb +10 -0
  33. data/app/views/klastera/clusters/transfer.html.erb +10 -0
  34. data/app/views/klastera/clusters/update.js.erb +1 -0
  35. data/app/views/layouts/klastera/_cluster_entity_fields.html.erb +10 -0
  36. data/app/views/layouts/klastera/_cluster_filter.html.erb +23 -0
  37. data/app/views/layouts/klastera/_cluster_role.html.erb +48 -0
  38. data/app/views/layouts/klastera/_cluster_selector.html.erb +21 -0
  39. data/app/views/layouts/klastera/_cluster_user_fields.html.erb +10 -0
  40. data/app/views/layouts/klastera/_nested_cluster_entity.html.erb +43 -0
  41. data/app/views/layouts/klastera/_nested_cluster_user.html.erb +22 -0
  42. data/app/views/layouts/klastera/_options.html.erb +21 -0
  43. data/config/locales/es.yml +96 -0
  44. data/config/routes.rb +7 -0
  45. data/db/migrate/20200324203929_create_klastera_clusters.rb +12 -0
  46. data/db/migrate/20200326111219_add_cluster_options_to_organizations.rb +6 -0
  47. data/db/migrate/20200330010551_create_klastera_cluster_users.rb +9 -0
  48. data/db/migrate/20200330221601_add_order_field_to_clusters.rb +5 -0
  49. data/db/migrate/20200518142609_create_klastera_cluster_entities.rb +8 -0
  50. data/db/migrate/20200908180057_add_cluster_config_to_organization.rb +5 -0
  51. data/db/migrate/20220602222332_add_unique_index_to_cluster_entities.rb +5 -0
  52. data/lib/klastera/engine.rb +5 -0
  53. data/lib/klastera/version.rb +3 -0
  54. data/lib/klastera.rb +236 -0
  55. data/lib/tasks/klastera_tasks.rake +32 -0
  56. data/test/controllers/klastera/clusters_controller_test.rb +52 -0
  57. data/test/fixtures/klastera/cluster_users.yml +9 -0
  58. data/test/fixtures/klastera/clusters.yml +11 -0
  59. data/test/integration/navigation_test.rb +8 -0
  60. data/test/klastera_test.rb +7 -0
  61. data/test/models/klastera/cluster_test.rb +9 -0
  62. data/test/models/klastera/cluster_user_test.rb +9 -0
  63. data/test/test_helper.rb +21 -0
  64. metadata +77 -7
data/lib/klastera.rb ADDED
@@ -0,0 +1,236 @@
1
+ require "klastera/engine"
2
+
3
+ module Klastera
4
+ mattr_accessor :organization_class
5
+
6
+ extend ActiveSupport::Concern
7
+
8
+ UNCLUSTERED_POSITION = 9999
9
+ UNCLUSTERED_ENTITY = 'without_cluster'.freeze
10
+ KLSTR_HELPERS = %i[ cluster_user cluster_organization cluster_list cluster_scope cluster_scope_through_of user_clusters_string_list cluster_scope_left_join ].freeze
11
+
12
+ class << self
13
+
14
+ ##
15
+ # TODO:
16
+ # Implement a validation to ensure that
17
+ # object is a ActiveRecord::Base class
18
+ # (or just try to guess how to retrieve the argument class)
19
+ #
20
+ ##
21
+ def scope_class(object)
22
+ object
23
+ end
24
+
25
+ ##
26
+ # Returns which clusters a user can see avoiding unnecessary queries if the cluster restraint doesn't apply
27
+ #
28
+ def cluster_list!(organization,user,include_unclustered=true)
29
+ # Only the cluster mode on and the mandatory user-cluster relation will use a join clause to get the clusters list
30
+ if organization.is_in_cluster_mode? && user.cannot_skip_cluster_clause?
31
+ active_record_collection = ::ClusterUser.clusters_of(organization,user)
32
+ else
33
+ active_record_collection = ::Cluster.where({ organization_id: organization }).order(order: :asc)
34
+ end
35
+
36
+ active_record_collection = active_record_collection.order(order: :asc)
37
+
38
+ if include_unclustered && organization.optional_suborganization_mode? # For show and use modes only
39
+ active_record_collection.to_a.append(
40
+ ::Cluster.new({nid: UNCLUSTERED_ENTITY, name: I18n.t("klastera.#{UNCLUSTERED_ENTITY}"), order: UNCLUSTERED_POSITION })
41
+ )
42
+ end
43
+ active_record_collection
44
+ end
45
+
46
+ ##
47
+ # Return a string with cluster attribute separated by separator argument
48
+ # A array of cluster ids can be passed fo filter the result
49
+ #
50
+ def entity_clusters_string_list!(cluster_entities,separator,attribute=:name,allowed_cluster_ids=nil)
51
+ _cluster_entities = cluster_entities.reject(&:nil?)
52
+ if allowed_cluster_ids.is_a?(Array)
53
+ _cluster_entities.select!{|ce| allowed_cluster_ids.include?(ce.cluster_id)}
54
+ end
55
+ _cluster_entities.map do |ce|
56
+ ce.cluster.try(attribute)
57
+ end.compact.sort.join(separator)
58
+ end
59
+
60
+ ##
61
+ # cluster_list! needs a user and a organization. that why we perfomed this logic here
62
+ #
63
+ def user_clusters_string_list!(user,organization,cluster_entities,separator,attribute=:name)
64
+ @clusters_session ||= Klastera.cluster_list!(organization,user)
65
+ self.entity_clusters_string_list!(cluster_entities, separator, attribute, @clusters_session.map(&:id))
66
+ end
67
+
68
+ #
69
+ # We will try to avoid cluster clause except when:
70
+ # 1.- cluster mode is active
71
+ # AND
72
+ # 2a.- cluster_filter is present (someone wants to filter by cluster)
73
+ # OR
74
+ # 2b.- the current user has some limitations and must checks they cluster relation
75
+ # - User is having clusters in optional_suborganization mode
76
+ # - User IS NOT having clusters in required_suborganization mode
77
+ #
78
+ # For the other hand, with force_cluster_clause we can skip the previous logic if
79
+ # cluster_filter_id is present when the optional_suborganization mode is on. BUT!
80
+ # Be aware that if the cluster_filter is not present, the value of force_cluster_clause
81
+ # will be overridden by the returned value of cannot_skip_cluster_clause? method.
82
+ def should_clusterize_scope?(user, organization, cluster_filter=nil, force_cluster_clause=false)
83
+ should = false # I don't know if this is a good idea
84
+ if organization.is_in_cluster_mode? && ( cluster_filter.present? || force_cluster_clause = user.cannot_skip_cluster_clause? ) # yes, this is an assignation
85
+ cluster_ids = []
86
+ # Set another variable as array to get the cluster id(s)
87
+ if cluster_filter.present?
88
+ cluster_ids = cluster_filter.is_a?(Array) ? cluster_filter : [cluster_filter]
89
+ elsif force_cluster_clause
90
+ cluster_ids = ::ClusterUser.clusters_of(organization,user).map(&:id)
91
+ end
92
+ # We will avoid the query unless cluster_ids is having values OR force_cluster_clause is set (see method description)
93
+ if cluster_ids.present? || force_cluster_clause
94
+ # We add the unclustered if the value of cluster_filter have the special without_cluster string or as method description says
95
+ if cluster_ids.delete(UNCLUSTERED_ENTITY) || ( force_cluster_clause && organization.optional_suborganization_mode? )
96
+ cluster_ids << nil
97
+ end
98
+ should = true
99
+ end
100
+ end
101
+ yield(should,cluster_ids)
102
+ end
103
+
104
+ #
105
+ # The cleanest and fast way to clusterize a entity!
106
+ #
107
+ def cluster_scope!(scope_klass, user, organization, cluster_filter=nil, force_cluster_clause=false)
108
+ scope = scope_class(scope_klass)
109
+ should_clusterize_scope?(user,organization,cluster_filter,force_cluster_clause) do |should,cluster_ids|
110
+ if should
111
+ scope = scope.eager_load(:organization,cluster_entities: :cluster).where( cluster_entities: { cluster_id: cluster_ids } )
112
+ end
113
+ end
114
+ scope.where(organization_id: organization)
115
+ end
116
+
117
+
118
+ # Filter non-clustered entity through a clusterized one
119
+ #
120
+ def cluster_scope_through_of!(relation, cluster_entity_klass, scope_klass, user, organization, cluster_filter=nil, force_cluster_clause=false)
121
+ unclusterized_scope = scope_class(scope_klass)
122
+
123
+ if organization.is_in_cluster_mode? && ( force_cluster_clause || user.cannot_skip_cluster_clause? )
124
+ unclusterized_scope = unclusterized_scope.joins(relation).joins(Klastera::ClusterEntity.left_join_sources_of(cluster_entity_klass))
125
+ end
126
+
127
+ if scope_klass.respond_to?(:organization)
128
+ unclusterized_scope = unclusterized_scope.where(organization_id: organization)
129
+ end
130
+
131
+ unclusterized_scope.where("#{relation}_id" => cluster_scope!(cluster_entity_klass, user, organization, cluster_filter, force_cluster_clause))
132
+ end
133
+
134
+ #
135
+ # Returns an array with a clusterized scoped result and its grouped version
136
+ #
137
+ def group_by_cluster_scope!(scope_klass, user, organization, cluster_filter=[], scope_scopes=[])
138
+ cluster_ids = cluster_filter.is_a?(Array) ? cluster_filter : [cluster_filter]
139
+ kluster_scope = cluster_scope!(scope_klass, user, organization, cluster_ids.compact, organization.is_in_cluster_mode? )
140
+
141
+ scope_scopes.each do |tuple_scope|
142
+ scope_name, scope_arg = tuple_scope
143
+ kluster_scope = scope_arg.present? ? kluster_scope.send(scope_name,scope_arg) : kluster_scope.send(scope_name)
144
+ end
145
+
146
+ group_by_block = ->(o) {
147
+ if organization.is_in_cluster_mode?
148
+ o.cluster.present? ? o.cluster.name : UNCLUSTERED_POSITION
149
+ else
150
+ I18n.t("klastera.group_by_cluster_scope.#{scope_klass.model_name.plural}")
151
+ end
152
+ }
153
+
154
+ grouped_cluster_scope = kluster_scope.group_by(&group_by_block).sort_by{|k,v|k.to_s}
155
+
156
+ grouped_cluster_scope.dup.each do |group|
157
+ if group.first == UNCLUSTERED_POSITION
158
+ grouped_cluster_scope.delete(group)
159
+ group[0] = I18n.t("klastera.#{UNCLUSTERED_ENTITY}")
160
+ grouped_cluster_scope.append(group)
161
+ end
162
+ end
163
+
164
+ [ kluster_scope, grouped_cluster_scope ]
165
+ end
166
+
167
+ #
168
+ # A helper that returns a CLUSTER SCOPE to build queries that need explicit LEFT OUTER JOIN clause,
169
+ # instead of the default INNER JOIN provide by ActiveRecord's joins method
170
+ #
171
+ def cluster_scope_left_join!(scope_klass,organization)
172
+ cluster_entities_arel_table = Klastera::ClusterEntity.arel_table
173
+ cluster_arel_table = ::Cluster.arel_table
174
+ cluster_entities_cluster = cluster_entities_arel_table.join(cluster_arel_table, Arel::Nodes::OuterJoin).on(
175
+ cluster_entities_arel_table[:cluster_id].eq(cluster_arel_table[:id]),
176
+ ).join_sources
177
+
178
+ scope_class(scope_klass).where(organization_id: organization).joins(Klastera::ClusterEntity.left_join_sources_of(scope_klass)).joins(cluster_entities_cluster)
179
+ end
180
+ end
181
+
182
+ ##################################################################################################################################################
183
+
184
+ def cluster_user
185
+ current_user
186
+ end
187
+
188
+ def cluster_organization
189
+ current_organization
190
+ end
191
+
192
+ def set_cluster_filter
193
+ cluster_filter_params = params.require(:cluster_filter) rescue {}
194
+ @cluster_filter = ::ClusterFilter.new(
195
+ cluster_filter_params.present? ? cluster_filter_params.permit(
196
+ [ :cluster_id ].concat( ::ClusterFilter.attributes )
197
+ ) : {}
198
+ )
199
+ end
200
+
201
+ def cluster_list(include_unclustered=true)
202
+ Klastera.cluster_list!(cluster_organization, cluster_user, include_unclustered)
203
+ end
204
+
205
+ def cluster_scope(scope_klass, cluster_filter=nil, force_cluster_clause=false)
206
+ Klastera.cluster_scope!(scope_klass, cluster_user, cluster_organization, cluster_filter, force_cluster_clause)
207
+ end
208
+
209
+ def cluster_scope_through_of(relation, cluster_entity_klass, scope_klass, cluster_filter=nil, force_cluster_clause=false)
210
+ Klastera.cluster_scope_through_of!(relation, cluster_entity_klass, scope_klass, cluster_user, cluster_organization, cluster_filter, force_cluster_clause)
211
+ end
212
+
213
+ def group_by_cluster_scope(scope_klass, cluster_filter=[], scope_scopes=[])
214
+ Klastera.group_by_cluster_scope!(scope_klass, cluster_user, cluster_organization, cluster_filter, scope_scopes)
215
+ end
216
+
217
+ def user_clusters_string_list(object_entity, separator, attribute=:name)
218
+ Klastera.user_clusters_string_list!(cluster_user, cluster_organization, object_entity.try(:cluster_entities), separator, attribute)
219
+ end
220
+
221
+ def cluster_scope_left_join(scope_klass)
222
+ Klastera.cluster_scope_left_join!(scope_klas,cluster_organization)
223
+ end
224
+
225
+ included do
226
+ Klastera::KLSTR_HELPERS.each do |action|
227
+ if respond_to?(:helper_method)
228
+ helper_method(action)
229
+ end
230
+ if respond_to?(:hide_action)
231
+ hide_action(helper)
232
+ hide_action("#{helper}=")
233
+ end
234
+ end
235
+ end
236
+ end
@@ -0,0 +1,32 @@
1
+ # desc "Explaining what the task does"
2
+ # task :klastera do
3
+ # # Task goes here
4
+ # end
5
+
6
+
7
+ namespace :klastera do
8
+ namespace :seed do
9
+
10
+ desc "Move cluster_id to cluster_entities"
11
+ task :cluster_entities, [:entity] => :environment do |task,args|
12
+ begin
13
+ klass = args.entity.constantize
14
+ ActiveRecord::Base.transaction do
15
+ klass.where.not(cluster_id: nil).each do |entity|
16
+ if entity.cluster.blank?
17
+ puts "Cluster ID #{entity.cluster_id} was not found!"
18
+ puts "skip..."
19
+ next
20
+ end
21
+ Klastera::ClusterEntity.create(entity: entity, cluster: entity.cluster)
22
+ end
23
+ end
24
+ rescue NameError => ne
25
+ puts "NameError Exception: #{ne}"
26
+ rescue ActiveRecord::StatementInvalid => asi
27
+ puts "ActiveRecord::StatementInvalid Exception #{asi}"
28
+ end
29
+ end
30
+
31
+ end
32
+ end
@@ -0,0 +1,52 @@
1
+ require 'test_helper'
2
+
3
+ module Klastera
4
+ class ClustersControllerTest < ActionController::TestCase
5
+ setup do
6
+ @cluster = klastera_clusters(:one)
7
+ @routes = Engine.routes
8
+ end
9
+
10
+ test "should get index" do
11
+ get :index
12
+ assert_response :success
13
+ assert_not_nil assigns(:clusters)
14
+ end
15
+
16
+ test "should get new" do
17
+ get :new
18
+ assert_response :success
19
+ end
20
+
21
+ test "should create cluster" do
22
+ assert_difference('Cluster.count') do
23
+ post :create, cluster: { color: @cluster.color, name: @cluster.name, nid: @cluster.nid }
24
+ end
25
+
26
+ assert_redirected_to cluster_path(assigns(:cluster))
27
+ end
28
+
29
+ test "should show cluster" do
30
+ get :show, id: @cluster
31
+ assert_response :success
32
+ end
33
+
34
+ test "should get edit" do
35
+ get :edit, id: @cluster
36
+ assert_response :success
37
+ end
38
+
39
+ test "should update cluster" do
40
+ patch :update, id: @cluster, cluster: { color: @cluster.color, name: @cluster.name, nid: @cluster.nid }
41
+ assert_redirected_to cluster_path(assigns(:cluster))
42
+ end
43
+
44
+ test "should destroy cluster" do
45
+ assert_difference('Cluster.count', -1) do
46
+ delete :destroy, id: @cluster
47
+ end
48
+
49
+ assert_redirected_to clusters_path
50
+ end
51
+ end
52
+ end
@@ -0,0 +1,9 @@
1
+ # Read about fixtures at http://api.rubyonrails.org/classes/ActiveRecord/FixtureSet.html
2
+
3
+ one:
4
+ user_id: 1
5
+ cluster_id: MyString
6
+
7
+ two:
8
+ user_id: 1
9
+ cluster_id: MyString
@@ -0,0 +1,11 @@
1
+ # Read about fixtures at http://api.rubyonrails.org/classes/ActiveRecord/FixtureSet.html
2
+
3
+ one:
4
+ nid: MyString
5
+ name: MyText
6
+ color: MyString
7
+
8
+ two:
9
+ nid: MyString
10
+ name: MyText
11
+ color: MyString
@@ -0,0 +1,8 @@
1
+ require 'test_helper'
2
+
3
+ class NavigationTest < ActionDispatch::IntegrationTest
4
+ # test "the truth" do
5
+ # assert true
6
+ # end
7
+ end
8
+
@@ -0,0 +1,7 @@
1
+ require 'test_helper'
2
+
3
+ class KlasteraTest < ActiveSupport::TestCase
4
+ test "truth" do
5
+ assert_kind_of Module, Klastera
6
+ end
7
+ end
@@ -0,0 +1,9 @@
1
+ require 'test_helper'
2
+
3
+ module Klastera
4
+ class ClusterTest < ActiveSupport::TestCase
5
+ # test "the truth" do
6
+ # assert true
7
+ # end
8
+ end
9
+ end
@@ -0,0 +1,9 @@
1
+ require 'test_helper'
2
+
3
+ module Klastera
4
+ class ClusterUserTest < ActiveSupport::TestCase
5
+ # test "the truth" do
6
+ # assert true
7
+ # end
8
+ end
9
+ end
@@ -0,0 +1,21 @@
1
+ # Configure Rails Environment
2
+ ENV["RAILS_ENV"] = "test"
3
+
4
+ require File.expand_path("../../test/dummy/config/environment.rb", __FILE__)
5
+ ActiveRecord::Migrator.migrations_paths = [File.expand_path("../../test/dummy/db/migrate", __FILE__)]
6
+ ActiveRecord::Migrator.migrations_paths << File.expand_path('../../db/migrate', __FILE__)
7
+ require "rails/test_help"
8
+
9
+ # Filter out Minitest backtrace while allowing backtrace from other libraries
10
+ # to be shown.
11
+ Minitest.backtrace_filter = Minitest::BacktraceFilter.new
12
+
13
+ # Load support files
14
+ Dir["#{File.dirname(__FILE__)}/support/**/*.rb"].each { |f| require f }
15
+
16
+ # Load fixtures from the engine
17
+ if ActiveSupport::TestCase.respond_to?(:fixture_path=)
18
+ ActiveSupport::TestCase.fixture_path = File.expand_path("../fixtures", __FILE__)
19
+ ActionDispatch::IntegrationTest.fixture_path = ActiveSupport::TestCase.fixture_path
20
+ ActiveSupport::TestCase.fixtures :all
21
+ end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: klastera
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.5.3
4
+ version: 1.5.4
5
5
  platform: ruby
6
6
  authors:
7
7
  - Gino Barahona
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2024-01-17 00:00:00.000000000 Z
11
+ date: 2024-09-12 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: rails
@@ -16,14 +16,14 @@ dependencies:
16
16
  requirements:
17
17
  - - "~>"
18
18
  - !ruby/object:Gem::Version
19
- version: 6.1.3
19
+ version: 7.1.3.2
20
20
  type: :runtime
21
21
  prerelease: false
22
22
  version_requirements: !ruby/object:Gem::Requirement
23
23
  requirements:
24
24
  - - "~>"
25
25
  - !ruby/object:Gem::Version
26
- version: 6.1.3
26
+ version: 7.1.3.2
27
27
  - !ruby/object:Gem::Dependency
28
28
  name: pg
29
29
  requirement: !ruby/object:Gem::Requirement
@@ -44,7 +44,69 @@ email:
44
44
  executables: []
45
45
  extensions: []
46
46
  extra_rdoc_files: []
47
- files: []
47
+ files:
48
+ - MIT-LICENSE
49
+ - README.rdoc
50
+ - Rakefile
51
+ - app/assets/javascripts/klastera/application.js
52
+ - app/assets/javascripts/klastera/clusters.js
53
+ - app/assets/stylesheets/klastera/clusters.scss
54
+ - app/controllers/klastera/application_controller.rb
55
+ - app/controllers/klastera/clusters_controller.rb
56
+ - app/helpers/klastera/application_helper.rb
57
+ - app/models/klastera/cluster.rb
58
+ - app/models/klastera/cluster_entity.rb
59
+ - app/models/klastera/cluster_filter.rb
60
+ - app/models/klastera/cluster_user.rb
61
+ - app/models/klastera/concerns/cluster.rb
62
+ - app/models/klastera/concerns/cluster_entity.rb
63
+ - app/models/klastera/concerns/cluster_filter.rb
64
+ - app/models/klastera/concerns/cluster_user.rb
65
+ - app/models/klastera/concerns/clusterizable.rb
66
+ - app/models/klastera/concerns/organization.rb
67
+ - app/models/klastera/concerns/transfer.rb
68
+ - app/models/klastera/concerns/user.rb
69
+ - app/models/klastera/transfer.rb
70
+ - app/views/klastera/clusters/_filter.html.erb
71
+ - app/views/klastera/clusters/_form.html.erb
72
+ - app/views/klastera/clusters/_form_transfer.html.erb
73
+ - app/views/klastera/clusters/_table.html.erb
74
+ - app/views/klastera/clusters/create.js.erb
75
+ - app/views/klastera/clusters/destroy.js.erb
76
+ - app/views/klastera/clusters/edit.html.erb
77
+ - app/views/klastera/clusters/index.html.erb
78
+ - app/views/klastera/clusters/new.html.erb
79
+ - app/views/klastera/clusters/transfer.html.erb
80
+ - app/views/klastera/clusters/update.js.erb
81
+ - app/views/layouts/klastera/_cluster_entity_fields.html.erb
82
+ - app/views/layouts/klastera/_cluster_filter.html.erb
83
+ - app/views/layouts/klastera/_cluster_role.html.erb
84
+ - app/views/layouts/klastera/_cluster_selector.html.erb
85
+ - app/views/layouts/klastera/_cluster_user_fields.html.erb
86
+ - app/views/layouts/klastera/_nested_cluster_entity.html.erb
87
+ - app/views/layouts/klastera/_nested_cluster_user.html.erb
88
+ - app/views/layouts/klastera/_options.html.erb
89
+ - config/locales/es.yml
90
+ - config/routes.rb
91
+ - db/migrate/20200324203929_create_klastera_clusters.rb
92
+ - db/migrate/20200326111219_add_cluster_options_to_organizations.rb
93
+ - db/migrate/20200330010551_create_klastera_cluster_users.rb
94
+ - db/migrate/20200330221601_add_order_field_to_clusters.rb
95
+ - db/migrate/20200518142609_create_klastera_cluster_entities.rb
96
+ - db/migrate/20200908180057_add_cluster_config_to_organization.rb
97
+ - db/migrate/20220602222332_add_unique_index_to_cluster_entities.rb
98
+ - lib/klastera.rb
99
+ - lib/klastera/engine.rb
100
+ - lib/klastera/version.rb
101
+ - lib/tasks/klastera_tasks.rake
102
+ - test/controllers/klastera/clusters_controller_test.rb
103
+ - test/fixtures/klastera/cluster_users.yml
104
+ - test/fixtures/klastera/clusters.yml
105
+ - test/integration/navigation_test.rb
106
+ - test/klastera_test.rb
107
+ - test/models/klastera/cluster_test.rb
108
+ - test/models/klastera/cluster_user_test.rb
109
+ - test/test_helper.rb
48
110
  homepage: https://github.com/ginosx/klastera
49
111
  licenses:
50
112
  - MIT
@@ -64,8 +126,16 @@ required_rubygems_version: !ruby/object:Gem::Requirement
64
126
  - !ruby/object:Gem::Version
65
127
  version: '0'
66
128
  requirements: []
67
- rubygems_version: 3.1.6
129
+ rubygems_version: 3.4.10
68
130
  signing_key:
69
131
  specification_version: 4
70
132
  summary: Clusterization Engine
71
- test_files: []
133
+ test_files:
134
+ - test/controllers/klastera/clusters_controller_test.rb
135
+ - test/fixtures/klastera/cluster_users.yml
136
+ - test/fixtures/klastera/clusters.yml
137
+ - test/integration/navigation_test.rb
138
+ - test/klastera_test.rb
139
+ - test/models/klastera/cluster_test.rb
140
+ - test/models/klastera/cluster_user_test.rb
141
+ - test/test_helper.rb