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 +4 -4
- data/lib/brick/frameworks/rails/engine.rb +115 -4
- data/lib/brick/version_number.rb +1 -1
- data/lib/brick.rb +44 -41
- metadata +2 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 2ed704f637bf6db73f5856be2959ba3490eb721e6de052008914d12cd029a673
|
4
|
+
data.tar.gz: 327a383fc224aebce1c96ba96b02c8a8a8604136bf61355b13b0029c203ff5c2
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
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
|
-
|
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
|
data/lib/brick/version_number.rb
CHANGED
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
|
-
|
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
|
-
|
894
|
-
|
895
|
-
|
896
|
-
|
897
|
-
|
898
|
-
|
899
|
-
|
900
|
-
|
901
|
-
|
902
|
-
|
903
|
-
|
904
|
-
|
905
|
-
|
906
|
-
|
907
|
-
|
908
|
-
|
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
|
-
|
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
|
914
|
-
puts
|
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
|
-
|
927
|
-
|
928
|
-
|
929
|
-
|
930
|
-
|
931
|
-
|
932
|
-
|
933
|
-
|
934
|
-
|
935
|
-
|
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.
|
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-
|
11
|
+
date: 2023-02-26 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: activerecord
|