brick 1.0.115 → 1.0.116

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 6e92e1445b603e8611ad927b8864b6ff04fd819d2f2243051d109d0894838e0d
4
- data.tar.gz: b76bc7adf85927a5ff4988027a0d7ff1d40b84d4a80531d23390867bcca0fc5e
3
+ metadata.gz: b515113ca31f4e0ad1a13e90df981c411e96c4a93507012876c9b2f10e76e68b
4
+ data.tar.gz: e23d63fe9fbbaaacd20d9646c382e914dfa46cfa61a8a504aaee9f3f6352d849
5
5
  SHA512:
6
- metadata.gz: 9caa3d9fdbc5229123058ec526482bf4c6926c42a44012d974a26d4f94f6f0e2f1dd2040ee76b1fbec21e431ea479694030365a1982878c6100245a607803260
7
- data.tar.gz: 0e09bb3d9556bc8b4a442eccc9f19a374684c901dc0f9769030313ebdc57248f31a994e5deb7dbde394f066187b961eab169545e3466ab0851cb6df7636c62f1
6
+ metadata.gz: 78fcea6b98fae7cbb0496a55a824021f4accf8c75eaf3680696333000a90854dda52783cd14a67ee7dcb91f3a48cef871ba4e3ea037f3dbec42f31c1bb485a25
7
+ data.tar.gz: a1191c8adfd3d6dbd8393e85c4bb7857a030db449891e744ac6bc3ea7f9f9cae5303987143f02892374fd088528463aacc1b06c9c4541560a0df0ded1dafe1e5
@@ -352,6 +352,59 @@ window.addEventListener(\"popstate\", linkSchemas);
352
352
  end
353
353
  end
354
354
 
355
+ # Forest Admin compatibility
356
+ if Object.const_defined?('ForestLiana')
357
+ ForestLiana::Bootstrapper.class_exec do
358
+ alias _brick_fetch_models fetch_models
359
+ def fetch_models
360
+ # Auto-create Brick models
361
+ ::Brick.relations.each do |k, v|
362
+ next if k == 'active_admin_comments'
363
+
364
+ begin
365
+ v[:class_name].constantize
366
+ rescue
367
+ end
368
+ end
369
+ _brick_fetch_models
370
+ end
371
+ end
372
+ end
373
+
374
+ # MotorAdmin compatibility
375
+ if Object.const_defined?('Motor') && ::Motor.const_defined?('BuildSchema')
376
+ ::Motor::BuildSchema::LoadFromRails.class_exec do
377
+ class << self
378
+ alias _brick_models models
379
+ def models
380
+ # If RailsAdmin is also present and had already cached its list of models, this builds out the MotorAdmin
381
+ # models differently, so invalidate RailsAdmin's cached list.
382
+ if Object.const_defined?('RailsAdmin') && ::RailsAdmin::Config.class_variable_defined?(:@@system_models)
383
+ ::RailsAdmin::Config.remove_class_variable(:@@system_models)
384
+ ::RailsAdmin::AbstractModel.reset
385
+ end
386
+
387
+ eager_load_models!
388
+ # Auto-create Brick models (except for those related to Motor::ApplicationRecord)
389
+ mar_tables = Motor::ApplicationRecord.descendants.map(&:table_name)
390
+ # Add JSON fields
391
+ if mar_tables.include?('motor_api_configs')
392
+ mac = (::Brick.config.json_columns['motor_api_configs'] ||= [])
393
+ mac += ['preferences', 'credentials']
394
+ end
395
+ (::Brick.config.json_columns['motor_audits'] ||= []) << 'audited_changes' if mar_tables.include?('motor_audits')
396
+ (::Brick.config.json_columns['motor_configs'] ||= []) << 'value' if mar_tables.include?('motor_configs')
397
+ ::Brick.relations.each do |k, v|
398
+ next if mar_tables.include?(k) || k == 'motor_audits'
399
+
400
+ v[:class_name].constantize
401
+ end
402
+ _brick_models.reject { |m| mar_tables.include?(m.table_name) || m.table_name == 'motor_audits' }
403
+ end
404
+ end
405
+ end
406
+ end
407
+
355
408
  # ====================================
356
409
  # Dynamically create generic templates
357
410
  # ====================================
@@ -874,7 +927,9 @@ callbacks = {} %>
874
927
  <path opacity=\"0.25\" d=\"M41.9129 30.649L35.3301 45.0422C35.2023 45.3204 35.0074 45.563 34.7627 45.7484C34.518 45.9337 34.2311 46.0562 33.9274 46.1048C27.3926 47.1897 21.1567 49.6166 15.617 53.2308C15.279 53.4505 14.8783 53.555 14.4753 53.5286C14.0723 53.5022 13.6889 53.3463 13.3827 53.0844C13.0765 52.8225 12.8642 52.4688 12.7777 52.0765C12.6911 51.6842 12.7351 51.2745 12.9029 50.9092L32.0285 8.99382L33.4869 5.7959C32.6687 7.95084 32.7141 10.336 33.6135 12.4586L33.7958 12.8565L41.9129 30.649Z\" fill=\"currentColor\" fill-opacity=\"0.22\"></path>
875
928
  </svg>
876
929
  ".gsub('"', '\"')
877
- }\".html_safe %>"
930
+ }\".html_safe
931
+ aa_png = \"<img src=\\\"\\\">\".html_safe
932
+ %>"
878
933
 
879
934
  if ['index', 'show', 'new', 'update'].include?(args.first)
880
935
  poly_cols = []
@@ -1222,6 +1277,19 @@ erDiagram
1222
1277
  title: \"#\{model.name} in Avo\" }
1223
1278
  ) %></td>
1224
1279
  <% end %>
1280
+ <% if Object.const_defined?('ActiveAdmin')
1281
+ ActiveAdmin.application.namespaces.names.each do |ns|
1282
+ td_count += 1 %>
1283
+ <td><%= link_to_brick(
1284
+ aa_png,
1285
+ { index_proc: Proc.new do |aa_model, relation|
1286
+ path_helper = \"#\{ns}_#\{relation.fetch(:auto_prefixed_schema, nil)}#\{rk = aa_model.model_name.route_key}_path\".to_sym
1287
+ send(path_helper) if respond_to?(path_helper)
1288
+ end,
1289
+ title: \"#\{model.name} in ActiveAdmin\" }
1290
+ ) %></td>
1291
+ <% end
1292
+ end %>
1225
1293
  </tr><%= if (page_num = @#{table_name}._brick_page_num)
1226
1294
  \"<tr><td colspan=\\\"#\{td_count}\\\">Page #\{page_num}</td></tr>\".html_safe
1227
1295
  end %></table>#{template_link}<%
@@ -1410,7 +1478,20 @@ erDiagram
1410
1478
  end,
1411
1479
  title: \"#\{page_title} in Avo\" }
1412
1480
  ) %></td>
1413
- <% end %>
1481
+ <% end
1482
+
1483
+ if Object.const_defined?('ActiveAdmin')
1484
+ ActiveAdmin.application.namespaces.names.each do |ns| %>
1485
+ <td><%= link_to_brick(
1486
+ aa_png,
1487
+ { show_proc: Proc.new do |aa_model, relation|
1488
+ path_helper = \"#\{ns}_#\{relation.fetch(:auto_prefixed_schema, nil)}#\{rk = aa_model.model_name.singular_route_key}_path\".to_sym
1489
+ send(path_helper, obj) if respond_to?(path_helper)
1490
+ end,
1491
+ title: \"#\{page_title} in ActiveAdmin\" }
1492
+ ) %></td>
1493
+ <% end
1494
+ end %>
1414
1495
  </table>
1415
1496
  <%
1416
1497
  if (description = (relation = Brick.relations[tbl_name = #{model_name}.table_name])&.fetch(:description, nil)) %><%=
@@ -1849,9 +1930,24 @@ document.querySelectorAll(\"input, select\").forEach(function (inp) {
1849
1930
 
1850
1931
  alias _brick_viable_models viable_models
1851
1932
  def viable_models
1852
- return _brick_viable_models if class_variables.include?(:@@system_models)
1933
+ return _brick_viable_models if ::RailsAdmin::Config.class_variables.include?(:@@system_models)
1934
+
1935
+ brick_models = ::Brick.relations.map { |_k, v| v[:class_name] }
1853
1936
 
1854
- @@system_models = (vm = _brick_viable_models) + (::Brick.auto_models - vm)
1937
+ # The original from RailsAdmin (now aliased as _brick_viable_models) loads all classes
1938
+ # in the whole project. This Brick approach is a little more tame.
1939
+ ::Brick.eager_load_classes
1940
+ # All tables used by non-Brick models
1941
+ ar_tables = (arbd = ActiveRecord::Base.descendants).each_with_object([]) do |ar, s|
1942
+ s << ar.table_name unless brick_models.include?(ar.name)
1943
+ end
1944
+ viable = arbd.each_with_object([]) do |ar, s|
1945
+ # Include all the app's models, plus any Brick models which describe tables not covered by the app's models
1946
+ unless ar.abstract_class? || (brick_models.include?(ar.name) && ar_tables.include?(ar.table_name))
1947
+ s << ar.name
1948
+ end
1949
+ end
1950
+ RailsAdmin::Config.class_variable_set(:@@system_models, viable)
1855
1951
  end
1856
1952
  end
1857
1953
  end
@@ -5,7 +5,7 @@ module Brick
5
5
  module VERSION
6
6
  MAJOR = 1
7
7
  MINOR = 0
8
- TINY = 115
8
+ TINY = 116
9
9
 
10
10
  # PRE is nil unless it's a pre-release (beta, RC, etc.)
11
11
  PRE = nil
data/lib/brick.rb CHANGED
@@ -137,6 +137,7 @@ module Brick
137
137
 
138
138
  attr_accessor :default_schema, :db_schemas, :test_schema,
139
139
  :routes_done, :is_oracle, :is_eager_loading, :auto_models, :initializer_loaded
140
+ ::Brick.auto_models = []
140
141
 
141
142
  def set_db_schema(params = nil)
142
143
  # If Apartment::Tenant.current is not still the default (usually 'public') then an elevator has brought us into
@@ -610,7 +611,7 @@ In config/initializers/brick.rb appropriate entries would look something like:
610
611
 
611
612
  def display_classes(prefix, rels, max_length)
612
613
  rels.sort.each do |rel|
613
- (::Brick.auto_models ||= []) << rel.first
614
+ ::Brick.auto_models << rel.first
614
615
  puts "#{rel.first}#{' ' * (max_length - rel.first.length)} /#{prefix}#{"#{rel[1]}/" if rel[1]}#{rel.last}"
615
616
  end
616
617
  puts "\n"
@@ -890,54 +891,56 @@ In config/initializers/brick.rb appropriate entries would look something like:
890
891
  get("/#{controller_prefix}brick_crosstab/data", to: 'brick_gem#crosstab_data')
891
892
  end
892
893
 
893
- unless ::Brick.routes_done
894
- if Object.const_defined?('Rswag::Ui')
895
- rswag_path = routeset_to_use.routes.find { |r| r.app.app == Rswag::Ui::Engine }&.instance_variable_get(:@path_formatter)&.instance_variable_get(:@parts)&.join
896
- first_endpoint_parts = nil
897
- (doc_endpoints = Rswag::Ui.config.config_object[:urls])&.each do |doc_endpoint|
898
- puts "Mounting OpenApi 3.0 documentation endpoint for \"#{doc_endpoint[:name]}\" on #{doc_endpoint[:url]}"
899
- send(:get, doc_endpoint[:url], { to: 'brick_openapi#index' })
900
- endpoint_parts = doc_endpoint[:url]&.split('/')
901
- first_endpoint_parts ||= endpoint_parts
902
- end
903
- if doc_endpoints.present?
904
- if rswag_path && first_endpoint_parts
905
- puts "API documentation now available when navigating to: /#{first_endpoint_parts&.find(&:present?)}/index.html"
906
- else
907
- puts "In order to make documentation available you can put this into your routes.rb:"
908
- puts " mount Rswag::Ui::Engine => '/#{first_endpoint_parts&.find(&:present?) || 'api-docs'}'"
909
- end
894
+ if Object.const_defined?('Rswag::Ui')
895
+ rswag_path = routeset_to_use.routes.find { |r| r.app.app == Rswag::Ui::Engine }&.instance_variable_get(:@path_formatter)&.instance_variable_get(:@parts)&.join
896
+ first_endpoint_parts = nil
897
+ (doc_endpoints = Rswag::Ui.config.config_object[:urls])&.each do |doc_endpoint|
898
+ puts "Mounting OpenApi 3.0 documentation endpoint for \"#{doc_endpoint[:name]}\" on #{doc_endpoint[:url]}" unless ::Brick.routes_done
899
+ send(:get, doc_endpoint[:url], { to: 'brick_openapi#index' })
900
+ endpoint_parts = doc_endpoint[:url]&.split('/')
901
+ first_endpoint_parts ||= endpoint_parts
902
+ end
903
+ end
904
+ next if ::Brick.routes_done
905
+
906
+ if Object.const_defined?('Rswag::Ui')
907
+ if doc_endpoints.present?
908
+ if rswag_path && first_endpoint_parts
909
+ puts "API documentation now available when navigating to: /#{first_endpoint_parts&.find(&:present?)}/index.html"
910
910
  else
911
- sample_path = rswag_path || '/api-docs'
911
+ puts "In order to make documentation available you can put this into your routes.rb:"
912
+ puts " mount Rswag::Ui::Engine => '/#{first_endpoint_parts&.find(&:present?) || 'api-docs'}'"
913
+ end
914
+ else
915
+ sample_path = rswag_path || '/api-docs'
916
+ puts
917
+ puts "Brick: rswag-ui gem detected -- to make OpenAPI 3.0 documentation available from a path such as '#{sample_path}/v1/swagger.json',"
918
+ puts ' put code such as this in an initializer:'
919
+ puts ' Rswag::Ui.configure do |config|'
920
+ puts " config.swagger_endpoint '#{sample_path}/v1/swagger.json', 'API V1 Docs'"
921
+ puts ' end'
922
+ unless rswag_path
912
923
  puts
913
- puts "Brick: rswag-ui gem detected -- to make OpenAPI 3.0 documentation available from a path such as '#{sample_path}/v1/swagger.json',"
914
- puts ' put code such as this in an initializer:'
915
- puts ' Rswag::Ui.configure do |config|'
916
- puts " config.swagger_endpoint '#{sample_path}/v1/swagger.json', 'API V1 Docs'"
917
- puts ' end'
918
- unless rswag_path
919
- puts
920
- puts ' and put this into your routes.rb:'
921
- puts " mount Rswag::Ui::Engine => '/api-docs'"
922
- end
924
+ puts ' and put this into your routes.rb:'
925
+ puts " mount Rswag::Ui::Engine => '/api-docs'"
923
926
  end
924
927
  end
928
+ end
925
929
 
926
- puts "\n" if tables.present? || views.present?
927
- if tables.present?
928
- puts "Classes that can be built from tables:#{' ' * (table_class_length - 38)} Path:"
929
- puts "======================================#{' ' * (table_class_length - 38)} ====="
930
- ::Brick.display_classes(controller_prefix, tables, table_class_length)
931
- end
932
- if views.present?
933
- puts "Classes that can be built from views:#{' ' * (view_class_length - 37)} Path:"
934
- puts "=====================================#{' ' * (view_class_length - 37)} ====="
935
- ::Brick.display_classes(controller_prefix, views, view_class_length)
936
- end
930
+ puts "\n" if tables.present? || views.present?
931
+ if tables.present?
932
+ puts "Classes that can be built from tables:#{' ' * (table_class_length - 38)} Path:"
933
+ puts "======================================#{' ' * (table_class_length - 38)} ====="
934
+ ::Brick.display_classes(controller_prefix, tables, table_class_length)
935
+ end
936
+ if views.present?
937
+ puts "Classes that can be built from views:#{' ' * (view_class_length - 37)} Path:"
938
+ puts "=====================================#{' ' * (view_class_length - 37)} ====="
939
+ ::Brick.display_classes(controller_prefix, views, view_class_length)
937
940
  end
938
941
  end
939
- ::Brick.routes_done = true
940
942
  super
943
+ ::Brick.routes_done = true
941
944
  end
942
945
  end
943
946
 
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: brick
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.0.115
4
+ version: 1.0.116
5
5
  platform: ruby
6
6
  authors:
7
7
  - Lorin Thwaits
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2023-02-24 00:00:00.000000000 Z
11
+ date: 2023-02-25 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: activerecord