brick 1.0.169 → 1.0.170
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.
- checksums.yaml +4 -4
- data/lib/brick/config.rb +9 -0
- data/lib/brick/extensions.rb +15 -1
- data/lib/brick/frameworks/rails/engine.rb +2 -2
- data/lib/brick/version_number.rb +1 -1
- data/lib/brick.rb +6 -0
- data/lib/generators/brick/install_generator.rb +3 -0
- 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: 3f802431e56f45276546a47b94f3571a6b23a2d0701c34b1f27964fd7ecf5b8f
|
4
|
+
data.tar.gz: 3fd88c0f0626bc9abf08e9317187baf3e755adb5840ac9b56b18c04ddc2577c7
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 3d5e4731d7956222b2c0ab28f19c5ac60addcea87b556a0765dd28a998c2364148bb348a57a9b3541096da71c6d9e2a4440cf6a038fb40d0b2d5c42aadf01ce5
|
7
|
+
data.tar.gz: c955e2d400887fe6e8ff3869bb6ca2e5a996898187e47d16764676b36e6a68a9ece28cf5593e993760c960cb25ba9c479904a2e327e824dd485e592df0d72d79
|
data/lib/brick/config.rb
CHANGED
@@ -213,6 +213,15 @@ module Brick
|
|
213
213
|
@mutex.synchronize { @nested_attributes = anaf }
|
214
214
|
end
|
215
215
|
|
216
|
+
# Associations for which to auto-create a has_many ___, through: ___
|
217
|
+
def hmts
|
218
|
+
@mutex.synchronize { @hmts }
|
219
|
+
end
|
220
|
+
|
221
|
+
def hmts=(assocs)
|
222
|
+
@mutex.synchronize { @hmts = assocs }
|
223
|
+
end
|
224
|
+
|
216
225
|
# Polymorphic associations
|
217
226
|
def polymorphics
|
218
227
|
@mutex.synchronize { @polymorphics }
|
data/lib/brick/extensions.rb
CHANGED
@@ -1798,11 +1798,25 @@ class Object
|
|
1798
1798
|
|
1799
1799
|
# Prepare a list of entries for "has_many :through"
|
1800
1800
|
if macro == :has_many
|
1801
|
-
relations[inverse_table]
|
1801
|
+
relations[inverse_table].fetch(:hmt_fks, nil)&.each do |k, hmt_fk|
|
1802
1802
|
next if k == assoc[:fk]
|
1803
1803
|
|
1804
1804
|
hmts[ActiveSupport::Inflector.pluralize(hmt_fk.last)] << [assoc, hmt_fk.first]
|
1805
1805
|
end
|
1806
|
+
|
1807
|
+
# Add any relevant user-requested HMTs
|
1808
|
+
Brick.config.hmts.each do |hmt|
|
1809
|
+
# Make sure this HMT lines up with the current HM
|
1810
|
+
next unless hmt.first == table_name && hmt[1] == inverse_table &&
|
1811
|
+
# And has not already been auto-created
|
1812
|
+
!(y = hmts.fetch(hmt[2], nil)&.find { |x| x.first[:assoc_name] == hmt[1] })
|
1813
|
+
|
1814
|
+
# Good so far -- now see if we have appropriate HM -> BT/HM associations by which we can create this user-requested HMT
|
1815
|
+
if (hm_assoc = relation[:fks].find { |_k, v| !v[:is_bt] && v[:assoc_name] == hmt[1] }.last) &&
|
1816
|
+
(hmt_assoc = relations[hm_assoc[:inverse_table]][:fks]&.find { |_k, v| v[:inverse_table] == hmt[2] }.last)
|
1817
|
+
hmts[hmt[2]] << [hm_assoc, hmt_assoc[:assoc_name]]
|
1818
|
+
end
|
1819
|
+
end
|
1806
1820
|
end
|
1807
1821
|
# And finally create a has_one, has_many, or belongs_to for this association
|
1808
1822
|
assoc_name = assoc_name.tr('.', '_').to_sym
|
@@ -815,9 +815,9 @@ h1, h3 {
|
|
815
815
|
#imgErd {
|
816
816
|
display: table-cell;
|
817
817
|
background-image:url();
|
818
|
+
background-repeat: no-repeat;
|
818
819
|
background-size: 100% 100%;
|
819
820
|
width: 28px;
|
820
|
-
height: 28px;
|
821
821
|
cursor: pointer;
|
822
822
|
}
|
823
823
|
#mermaidErd {
|
@@ -851,7 +851,7 @@ h1, h3 {
|
|
851
851
|
#headerTopAddNew {
|
852
852
|
position: absolute;
|
853
853
|
width: 100%;
|
854
|
-
top: -
|
854
|
+
top: -33px;
|
855
855
|
}
|
856
856
|
#headerButtonBox {
|
857
857
|
display: inline-block;
|
data/lib/brick/version_number.rb
CHANGED
data/lib/brick.rb
CHANGED
@@ -499,6 +499,12 @@ module Brick
|
|
499
499
|
Brick.config.nested_attributes = anaf
|
500
500
|
end
|
501
501
|
|
502
|
+
# Associations for which to auto-create a has_many ___, through: ___
|
503
|
+
# @api public
|
504
|
+
def hmts=(assocs)
|
505
|
+
Brick.config.hmts = assocs
|
506
|
+
end
|
507
|
+
|
502
508
|
# Polymorphic associations
|
503
509
|
def polymorphics=(polys)
|
504
510
|
polys = polys.each_with_object({}) { |poly, s| s[poly] = nil } if polys.is_a?(Array)
|
@@ -294,6 +294,9 @@ if ActiveRecord::Base.respond_to?(:brick_select) && !::Brick.initializer_loaded
|
|
294
294
|
# # This video to demonstrates how this works: https://github.com/lorint/brick/assets/5301131/82ac4f6d-bc23-4a55-adab-bc754bcb0f26
|
295
295
|
# Brick.nested_attributes = { 'User' => ['profile', 'posts'] }
|
296
296
|
|
297
|
+
# # Auto-create specific has_many ___, through: ___ associations
|
298
|
+
# Brick.hmts = [['recipes', 'recipe_ingredients', 'ingredients']]
|
299
|
+
|
297
300
|
# # We normally don't show the timestamp columns \"created_at\", \"updated_at\", and \"deleted_at\", and also do
|
298
301
|
# # not consider them when finding associative tables to support an N:M association. (That is, ones that can be a
|
299
302
|
# # part of a has_many :through association.) If you want to use different exclusion columns than our defaults
|
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.170
|
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-08-
|
11
|
+
date: 2023-08-31 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: activerecord
|