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 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