brick 1.0.169 → 1.0.170

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: 7e02fcd0507dcd442f5868b054f8224d33050a0dcb89a291db764360dbe57147
4
- data.tar.gz: 9cbcb2f58a7123e34d7dbde43ff956cb30a9068e4e357d84c25895fa9691f0c4
3
+ metadata.gz: 3f802431e56f45276546a47b94f3571a6b23a2d0701c34b1f27964fd7ecf5b8f
4
+ data.tar.gz: 3fd88c0f0626bc9abf08e9317187baf3e755adb5840ac9b56b18c04ddc2577c7
5
5
  SHA512:
6
- metadata.gz: 72101cc3b9123bb3b4c9ef033fa7b15d3e90450aa92d4a45816f68ba67ca63ce7ad35984cc6663247c095ce96056e4702bb3942cb7f9f5511e72eb3648197c79
7
- data.tar.gz: 2104035f4d13f8f13cb0aace1c7f4b0adf0d51f3324591f2ab4249c095ceb94ac2f0771966fc5eb5a9703ef35903c2497463d7e1f73f326cdc0dc69ead005f07
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 }
@@ -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][:hmt_fks].each do |k, hmt_fk|
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: -29px;
854
+ top: -33px;
855
855
  }
856
856
  #headerButtonBox {
857
857
  display: inline-block;
@@ -5,7 +5,7 @@ module Brick
5
5
  module VERSION
6
6
  MAJOR = 1
7
7
  MINOR = 0
8
- TINY = 169
8
+ TINY = 170
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
@@ -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.169
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-30 00:00:00.000000000 Z
11
+ date: 2023-08-31 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: activerecord