brick 1.0.115 → 1.0.117

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: 2ed704f637bf6db73f5856be2959ba3490eb721e6de052008914d12cd029a673
4
+ data.tar.gz: 327a383fc224aebce1c96ba96b02c8a8a8604136bf61355b13b0029c203ff5c2
5
5
  SHA512:
6
- metadata.gz: 9caa3d9fdbc5229123058ec526482bf4c6926c42a44012d974a26d4f94f6f0e2f1dd2040ee76b1fbec21e431ea479694030365a1982878c6100245a607803260
7
- data.tar.gz: 0e09bb3d9556bc8b4a442eccc9f19a374684c901dc0f9769030313ebdc57248f31a994e5deb7dbde394f066187b961eab169545e3466ab0851cb6df7636c62f1
6
+ metadata.gz: eec983fb53ff9e5f010473e7a7f1b4f1b6d07f4b8d166f4dccb66b701565a61fb91ebf30c84145dffd585e83ce13bb86c7746906b2751bbb6702ee2dc09eb7a4
7
+ data.tar.gz: 339edb3796933184d06de44def59b3ad5fd7d1c37995a73ffab4d62e7bb5dac0d8b63c28cb387e951e9899524ca8513fa938848449460aa234d901c28532f6c5
@@ -350,6 +350,74 @@ window.addEventListener(\"popstate\", linkSchemas);
350
350
  end
351
351
  end
352
352
  end
353
+ # Build out the main dashboard with default boilerplate if it's missing
354
+ if (namespace = ::ActiveAdmin.application.namespaces.names.first&.to_s) &&
355
+ !Object.const_defined?("#{namespace.camelize}::Dashboard")
356
+ ::ActiveAdmin.register_page "Dashboard" do
357
+ menu priority: 1, label: proc { I18n.t("active_admin.dashboard") }
358
+ content title: proc { I18n.t("active_admin.dashboard") } do
359
+ div class: "blank_slate_container", id: "dashboard_default_message" do
360
+ span class: "blank_slate" do
361
+ span I18n.t("active_admin.dashboard_welcome.welcome")
362
+ small I18n.t("active_admin.dashboard_welcome.call_to_action")
363
+ end
364
+ end
365
+ end
366
+ end
367
+ end
368
+ end
369
+
370
+ # Forest Admin compatibility
371
+ if Object.const_defined?('ForestLiana')
372
+ ForestLiana::Bootstrapper.class_exec do
373
+ alias _brick_fetch_models fetch_models
374
+ def fetch_models
375
+ # Auto-create Brick models
376
+ ::Brick.relations.each do |k, v|
377
+ next if k == 'active_admin_comments'
378
+
379
+ begin
380
+ v[:class_name].constantize
381
+ rescue
382
+ end
383
+ end
384
+ _brick_fetch_models
385
+ end
386
+ end
387
+ end
388
+
389
+ # MotorAdmin compatibility
390
+ if Object.const_defined?('Motor') && ::Motor.const_defined?('BuildSchema')
391
+ ::Motor::BuildSchema::LoadFromRails.class_exec do
392
+ class << self
393
+ alias _brick_models models
394
+ def models
395
+ # If RailsAdmin is also present and had already cached its list of models, this builds out the MotorAdmin
396
+ # models differently, so invalidate RailsAdmin's cached list.
397
+ if Object.const_defined?('RailsAdmin') && ::RailsAdmin::Config.class_variable_defined?(:@@system_models)
398
+ ::RailsAdmin::Config.remove_class_variable(:@@system_models)
399
+ ::RailsAdmin::AbstractModel.reset
400
+ end
401
+
402
+ eager_load_models!
403
+ # Auto-create Brick models (except for those related to Motor::ApplicationRecord)
404
+ mar_tables = Motor::ApplicationRecord.descendants.map(&:table_name)
405
+ # Add JSON fields
406
+ if mar_tables.include?('motor_api_configs')
407
+ mac = (::Brick.config.json_columns['motor_api_configs'] ||= [])
408
+ mac += ['preferences', 'credentials']
409
+ end
410
+ (::Brick.config.json_columns['motor_audits'] ||= []) << 'audited_changes' if mar_tables.include?('motor_audits')
411
+ (::Brick.config.json_columns['motor_configs'] ||= []) << 'value' if mar_tables.include?('motor_configs')
412
+ ::Brick.relations.each do |k, v|
413
+ next if mar_tables.include?(k) || k == 'motor_audits'
414
+
415
+ v[:class_name].constantize
416
+ end
417
+ _brick_models.reject { |m| mar_tables.include?(m.table_name) || m.table_name == 'motor_audits' }
418
+ end
419
+ end
420
+ end
353
421
  end
354
422
 
355
423
  # ====================================
@@ -874,7 +942,9 @@ callbacks = {} %>
874
942
  <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
943
  </svg>
876
944
  ".gsub('"', '\"')
877
- }\".html_safe %>"
945
+ }\".html_safe
946
+ aa_png = \"<img src=\\\"\\\">\".html_safe
947
+ %>"
878
948
 
879
949
  if ['index', 'show', 'new', 'update'].include?(args.first)
880
950
  poly_cols = []
@@ -1222,6 +1292,19 @@ erDiagram
1222
1292
  title: \"#\{model.name} in Avo\" }
1223
1293
  ) %></td>
1224
1294
  <% end %>
1295
+ <% if Object.const_defined?('ActiveAdmin')
1296
+ ActiveAdmin.application.namespaces.names.each do |ns|
1297
+ td_count += 1 %>
1298
+ <td><%= link_to_brick(
1299
+ aa_png,
1300
+ { index_proc: Proc.new do |aa_model, relation|
1301
+ path_helper = \"#\{ns}_#\{relation.fetch(:auto_prefixed_schema, nil)}#\{rk = aa_model.model_name.route_key}_path\".to_sym
1302
+ send(path_helper) if respond_to?(path_helper)
1303
+ end,
1304
+ title: \"#\{model.name} in ActiveAdmin\" }
1305
+ ) %></td>
1306
+ <% end
1307
+ end %>
1225
1308
  </tr><%= if (page_num = @#{table_name}._brick_page_num)
1226
1309
  \"<tr><td colspan=\\\"#\{td_count}\\\">Page #\{page_num}</td></tr>\".html_safe
1227
1310
  end %></table>#{template_link}<%
@@ -1410,7 +1493,20 @@ erDiagram
1410
1493
  end,
1411
1494
  title: \"#\{page_title} in Avo\" }
1412
1495
  ) %></td>
1413
- <% end %>
1496
+ <% end
1497
+
1498
+ if Object.const_defined?('ActiveAdmin')
1499
+ ActiveAdmin.application.namespaces.names.each do |ns| %>
1500
+ <td><%= link_to_brick(
1501
+ aa_png,
1502
+ { show_proc: Proc.new do |aa_model, relation|
1503
+ path_helper = \"#\{ns}_#\{relation.fetch(:auto_prefixed_schema, nil)}#\{rk = aa_model.model_name.singular_route_key}_path\".to_sym
1504
+ send(path_helper, obj) if respond_to?(path_helper)
1505
+ end,
1506
+ title: \"#\{page_title} in ActiveAdmin\" }
1507
+ ) %></td>
1508
+ <% end
1509
+ end %>
1414
1510
  </table>
1415
1511
  <%
1416
1512
  if (description = (relation = Brick.relations[tbl_name = #{model_name}.table_name])&.fetch(:description, nil)) %><%=
@@ -1849,9 +1945,24 @@ document.querySelectorAll(\"input, select\").forEach(function (inp) {
1849
1945
 
1850
1946
  alias _brick_viable_models viable_models
1851
1947
  def viable_models
1852
- return _brick_viable_models if class_variables.include?(:@@system_models)
1948
+ return _brick_viable_models if ::RailsAdmin::Config.class_variables.include?(:@@system_models)
1853
1949
 
1854
- @@system_models = (vm = _brick_viable_models) + (::Brick.auto_models - vm)
1950
+ brick_models = ::Brick.relations.map { |_k, v| v[:class_name] }
1951
+
1952
+ # The original from RailsAdmin (now aliased as _brick_viable_models) loads all classes
1953
+ # in the whole project. This Brick approach is a little more tame.
1954
+ ::Brick.eager_load_classes
1955
+ # All tables used by non-Brick models
1956
+ ar_tables = (arbd = ActiveRecord::Base.descendants).each_with_object([]) do |ar, s|
1957
+ s << ar.table_name unless brick_models.include?(ar.name)
1958
+ end
1959
+ viable = arbd.each_with_object([]) do |ar, s|
1960
+ # Include all the app's models, plus any Brick models which describe tables not covered by the app's models
1961
+ unless ar.abstract_class? || (brick_models.include?(ar.name) && ar_tables.include?(ar.table_name))
1962
+ s << ar.name
1963
+ end
1964
+ end
1965
+ RailsAdmin::Config.class_variable_set(:@@system_models, viable)
1855
1966
  end
1856
1967
  end
1857
1968
  end
@@ -5,7 +5,7 @@ module Brick
5
5
  module VERSION
6
6
  MAJOR = 1
7
7
  MINOR = 0
8
- TINY = 115
8
+ TINY = 117
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.117
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-26 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: activerecord