brick 1.0.215 → 1.0.217

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: 53a4013353cb1918fd78cd37988cb934a83be74305a3351ede0082e95ce971db
4
- data.tar.gz: 8cee272dceee0c0938675e999f36ad3df9d833d0b11a62c07a595cd1664dd21b
3
+ metadata.gz: 6058423ea3fdcc6b213efcbffc1dd2d5171a08949c08338950f0dd75c35d9351
4
+ data.tar.gz: 876598fc0c0bd95725340fe830af39d318bb4aa1893c6178ef2ff0547dbd1960
5
5
  SHA512:
6
- metadata.gz: 99ad38c47011412ed7d145f4315c8e971ceab2d301d2a84be35471313fcc73686dec7c105aede9ef33b7202c16e50878139e753dd0cc3b0359cf84db5d8ad033
7
- data.tar.gz: f3b9d54daeb4d49d3abddf50a4d267a315ea280a4b3f59d812107d25b46d5c13be0fe1f83d518cd6f91e2a248e87bc65dd35d18e3430fc5a44f2fd1bf2e32f4e
6
+ metadata.gz: 93604235b727723b236ce5fca50f6644b53a478918acd7d20e4e60f454f62d46cf98d5c791f043db98268ad6ee77a43ed29278abf47c60ca3228347ebcd9c739
7
+ data.tar.gz: 0f2a06b4b4261bf186823dca721d09c3e18a808f9449448f233738167a640d990391b309b55247c45fe8850ceab173cf2c5e5e5d62b05c0e129351bc37b61251
data/lib/brick/config.rb CHANGED
@@ -243,6 +243,7 @@ module Brick
243
243
  tables.each_with_object({}) do |v, s|
244
244
  # If it's :constellation, or anything else in a hash, we'll take its value
245
245
  # (and hopefully in this case that would be either a string or nil)
246
+ # binding.pry
246
247
  dsl = ((v.last.is_a?(Symbol) && v.last) || v.last&.values&.last)
247
248
  unless (dsl ||= '').is_a?(String) || dsl.is_a?(Symbol)
248
249
  puts "Was really expecting #{v.first} / #{v.last.first&.first} / #{dsl} to be a string, " +
@@ -429,6 +430,19 @@ module Brick
429
430
  end
430
431
  end
431
432
 
433
+ def acts_as_list_cols
434
+ @mutex.synchronize { @acts_as_list || {} }
435
+ end
436
+
437
+ # Get something like:
438
+ # { 'on_call_list' => { _brick_default: [:last_name, :first_name] } }
439
+ # { 'on_call_list' => { _brick_default: :sequence } }
440
+ def acts_as_list_cols=(position_cols)
441
+ @mutex.synchronize do
442
+ @acts_as_list ||= position_cols
443
+ end
444
+ end
445
+
432
446
  def metadata_columns
433
447
  @mutex.synchronize { @metadata_columns ||= ['created_at', 'updated_at', 'deleted_at'] }
434
448
  end
@@ -867,6 +867,15 @@ module ActiveRecord
867
867
  end
868
868
  v1 << id_for_tables[v.first].compact
869
869
  end
870
+ # if k1.name == 'ActiveStorage::Attachment'
871
+ # binding.pry
872
+ # (@_brick_includes ||= {})[v1.first.first.to_s] = [v1.first[1..-1], 'blob']
873
+ # # x = 5
874
+ # # elsif k1.name == 'ActiveStorage::Blob'
875
+ # # binding.pry
876
+ # # (@_brick_includes ||= {})[v1.first.first.to_s] = v1[0..1]
877
+ # # # x = 5
878
+ # end
870
879
  end
871
880
  end
872
881
  join_array.each do |assoc_name|
@@ -908,7 +917,12 @@ module ActiveRecord
908
917
  through_sources.push(src_ref) unless src_ref.belongs_to?
909
918
  from_clause = +"#{_br_quoted_name(through_sources.first.table_name)} br_t0"
910
919
  # ActiveStorage will not get the correct count unless we do some extra filtering later
911
- tbl_nm = 'br_t0' if Object.const_defined?('ActiveStorage') && through_sources.first.klass <= ::ActiveStorage::Attachment
920
+ if Object.const_defined?('ActiveStorage') && through_sources.first.klass <= ::ActiveStorage::Attachment
921
+ # binding.pry
922
+ tbl_nm = 'br_t0'
923
+ # Need to somehow have this kind of an include in order to avoid an N+1 problem:
924
+ # .include(images_attachments: [blob: { variant_records: :blob }])
925
+ end
912
926
  fk_col = through_sources.shift.foreign_key
913
927
 
914
928
  idx = 0
@@ -1111,8 +1125,12 @@ JOIN (SELECT #{hm_selects.map { |s| _br_quoted_name("#{'br_t0.' if from_clause}#
1111
1125
  end
1112
1126
 
1113
1127
  # ActiveStorage compatibility
1114
- selects << 'service_name' if klass.name == 'ActiveStorage::Blob' && ::ActiveStorage::Blob.columns_hash.key?('service_name')
1115
- selects << 'blob_id' if klass.name == 'ActiveStorage::Attachment' && ::ActiveStorage::Attachment.columns_hash.key?('blob_id')
1128
+ if klass.name == 'ActiveStorage::Blob' && ::ActiveStorage::Blob.columns_hash.key?('service_name')
1129
+ selects << 'service_name'
1130
+ end
1131
+ if klass.name == 'ActiveStorage::Attachment' && ::ActiveStorage::Attachment.columns_hash.key?('blob_id')
1132
+ selects << 'blob_id'
1133
+ end
1116
1134
  # Pay gem compatibility
1117
1135
  selects << 'processor' if klass.name == 'Pay::Customer' && Pay::Customer.columns_hash.key?('processor')
1118
1136
  selects << 'customer_id' if klass.name == 'Pay::Subscription' && Pay::Subscription.columns_hash.key?('customer_id')
@@ -2349,7 +2367,7 @@ class Object
2349
2367
 
2350
2368
  # %%% Allow params to define which columns to use for order_by
2351
2369
  # Overriding the default by providing a querystring param?
2352
- order_by = params['_brick_order']&.split(',')&.map(&:to_s) || Object.send(:default_ordering, table_name, pk)
2370
+ order_by = params['_brick_order']&.split(',')&.map(&:to_sym) || Object.send(:default_ordering, table_name, pk)
2353
2371
 
2354
2372
  ar_relation = ActiveRecord.version < Gem::Version.new('4') ? real_model.preload : real_model.all
2355
2373
  params['_brick_is_api'] = true if (is_api = request.format == :js || current_api_root)
@@ -779,246 +779,9 @@ window.addEventListener(\"popstate\", linkSchemas);
779
779
  table_options << "<option value=\"#{prefix}brick_status\">(Status)</option>".html_safe if ::Brick.config.add_status
780
780
  table_options << "<option value=\"#{prefix}brick_orphans\">(Orphans)</option>".html_safe if is_orphans
781
781
  table_options << "<option value=\"#{prefix}brick_crosstab\">(Crosstab)</option>".html_safe if is_crosstab
782
- css = +"<style>
783
- #titleSticky {
784
- position: sticky;
785
- display: inline-block;
786
- left: 0;
787
- z-index: 2;
788
- }
789
-
790
- .flashNotice {
791
- color: green;
792
- }
793
- .flashAlert {
794
- color: red;
795
- }
796
-
797
- h1, h3 {
798
- margin-bottom: 0;
799
- }
800
- #rowCount {
801
- display: table-cell;
802
- height: 32px;
803
- vertical-align: middle;
804
- font-size: 0.9em;
805
- font-family: sans-serif;
806
- }
807
- #imgErd {
808
- display: table-cell;
809
- background-image:url();
810
- background-repeat: no-repeat;
811
- background-size: 100% 100%;
812
- width: 28px;
813
- height: 32px;
814
- cursor: pointer;
815
- }
816
- #mermaidErd {
817
- display: none;
818
- }
819
- #mermaidErd .exclude {
820
- position: absolute;
821
- color: red;
822
- top: 0;
823
- right: 0;
824
- cursor: pointer;
825
- }
826
- .relatedModel {
827
- cursor: pointer;
828
- }
829
-
830
- #dropper {
831
- background-color: #eee;
832
- }
833
- #btnImport {
834
- display: none;
835
- }
836
-
837
- #headerTopContainer {
838
- position: sticky;
839
- display: inline-block;
840
- top: 0px;
841
- background-color: white;
842
- z-index: 1;
843
- }
844
- #headerTopAddNew {
845
- position: absolute;
846
- width: 100%;
847
- top: -33px;
848
- }
849
- #headerButtonBox {
850
- display: inline-block;
851
- position: sticky;
852
- right: 0px;
853
- float: right;
854
- }
855
- #headerButtonBox a, #headerButtonBox svg {
856
- display: table-cell;
857
- height: 24px;
858
- width: 24px;
859
- padding: 2px;
860
- }
861
- #addNew {
862
- background-color: #008061;
863
- }
864
-
865
- table {
866
- border-collapse: collapse;
867
- font-size: 0.9em;
868
- font-family: sans-serif;
869
- }
870
- table.shadow {
871
- min-width: 400px;
872
- box-shadow: 0 0 20px rgba(0, 0, 0, 0.15);
873
- }
874
-
875
- tr th {
876
- background-color: #009879;
877
- color: #fff;
878
- text-align: left;
879
- }
880
- .col-sticky {
881
- position: sticky;
882
- left: 0;
883
- }
884
- #headerTop tr th {
885
- position: relative;
886
- }
887
- #headerTop tr th .exclude {
888
- position: absolute;
889
- display: none;
890
- top: 0;
891
- right: 0;
892
- cursor: pointer;
893
- }
894
- #headerTop tr th:hover, #headerTop tr th.highlight {
895
- background-color: #28B898;
896
- }
897
- #exclusions {
898
- font-size: 0.7em;
899
- }
900
- #exclusions div {
901
- border: 1px solid blue;
902
- display: inline-block;
903
- cursor: copy;
904
- }
905
- #headerTop tr th:hover .exclude {
906
- display: inline;
907
- cursor: pointer;
908
- color: red;
909
- }
910
- tr th a {
911
- color: #80FFB8;
912
- }
913
- .add-hm-related {
914
- float: right;
915
- }
916
- #tblAddCol {
917
- position: relative;
918
- z-index: 2;
919
- border: 2px solid blue;
920
- }
921
- tr th, tr td {
922
- padding: 0.2em 0.5em;
923
- }
924
-
925
- tr td.highlight {
926
- background-color: #B0B0FF;
927
- }
928
-
929
- table tr .col-sticky {
930
- background-color: #28B898;
931
- }
932
-
933
- .show-field {
934
- background-color: #004998;
935
- }
936
- .show-field a {
937
- color: #80B8D2;
938
- }
939
-
940
- table.shadow > tbody > tr {
941
- border-bottom: thin solid #dddddd;
942
- }
943
-
944
- table tbody tr:nth-of-type(even) {
945
- background-color: #f3f3f3;
946
- }
947
- table tbody tr:nth-of-type(even) .alternating-gray {
948
- background-color: #fff;
949
- }
950
- table tbody tr:nth-of-type(odd) .alternating-gray {
951
- background-color: #f3f3f3;
952
- }
953
-
954
- table.shadow > tbody > tr:last-of-type {
955
- border-bottom: 2px solid #009879;
956
- }
957
-
958
- table tbody tr.active-row {
959
- font-weight: bold;
960
- color: #009879;
961
- }
962
-
963
- a.show-arrow {
964
- font-size: 1.5em;
965
- text-decoration: none;
966
- }
967
- a.big-arrow {
968
- font-size: 2.5em;
969
- text-decoration: none;
970
- }
971
- .dimmed {
972
- background-color: #C0C0C0;
973
- text-align: center;
974
- }
975
- .right {
976
- text-align: right;
977
- }
978
- .paddingBottomZero {
979
- padding-bottom: 0px;
980
- }
981
- .paddingTopZero {
982
- padding-top: 0px;
983
- }
984
- .orphan {
985
- color: red;
986
- white-space: nowrap;
987
- }
988
- .thumbImg {
989
- max-width: 96px;
990
- max-height: 96px;
991
- }
992
- .danger {
993
- background-color: red;
994
- color: white;
995
- }
996
- .brick-note {
997
- font-size: 0.7em;
998
- color: #A0FFA0;
999
- max-width: 0;
1000
- }
1001
-
1002
- #revertTemplate {
1003
- display: none;
1004
- }
1005
- svg.revert {
1006
- display: none;
1007
- margin-left: 0.25em;
1008
- }
1009
- input+svg.revert {
1010
- top: 0.5em;
1011
- }
1012
-
1013
- .update {
1014
- position: sticky;
1015
- right: 1em;
1016
- float: right;
1017
- background-color: #004998;
1018
- color: #FFF;
1019
- }
1020
- </style>
1021
- <script>
782
+ css = +''
783
+ css << ::Brick::Rails::BRICK_CSS
784
+ css << "<script>
1022
785
  if (window.history.state && window.history.state.turbo)
1023
786
  window.addEventListener(\"popstate\", function () { location.reload(true); });
1024
787
  </script>
@@ -93,10 +93,21 @@ module Brick::Rails::FormTags
93
93
  # TinyTds::Error: Adaptive Server connection timed out
94
94
  # (After restarting the server it worked fine again.)
95
95
  row_count = 0
96
+ # binding.pry
97
+ # if @_brick_join_array&.include?()
98
+ enumerator = relation.each # Runs the SQL query
99
+ # Add proxied info for @_brick_includes
100
+ # proxy = relation.instance_variable_get(:@proxy) || relation.instance_variable_set(:@proxy, {})
101
+ bi = relation.instance_variable_get(:@_brick_includes)
96
102
  relation.each do |obj|
97
103
  out << "<tr>\n"
98
104
  out << "<td class=\"col-sticky alternating-gray\">#{link_to('⇛', send("#{klass._brick_index(:singular)}_path".to_sym,
99
105
  pk.map { |pk_part| obj.send(pk_part.to_sym) }), { class: 'big-arrow' })}</td>\n" if pk.present?
106
+ ac = obj.instance_variable_get(:@association_cache) || obj.instance_variable_set(:@association_cache, {})
107
+ # included =
108
+ bi&.each do |bi_key|
109
+ (ac[col_name.to_sym] ||= []) << val if bi&.key?(col_name) # Add to any proxy things
110
+ end
100
111
  sequence.each_with_index do |col_name, idx|
101
112
  val = obj.attributes[col_name]
102
113
  bt = bts[col_name] || composite_bt_names[col_name]
@@ -107,6 +118,7 @@ module Brick::Rails::FormTags
107
118
  (classes ||= []) << 'right' if val.is_a?(Numeric) && !bt
108
119
  out << " class=\"#{classes.join(' ')}\"" if classes&.present?
109
120
  out << '>'
121
+ # binding.pry if col_name == 'event_image_attachment' && obj.id == 6
110
122
  if bt
111
123
  if bt[2] && obj.respond_to?(poly_id_col = "#{bt.first}_id") # Polymorphic?
112
124
  if (poly_id = obj.send(poly_id_col))
@@ -350,7 +362,7 @@ module Brick::Rails::FormTags
350
362
  <thead><tr><td class=\"brick-note\">Checkbox changes are saved immediately</td>"
351
363
  # Header row with X axis values
352
364
  # (In order for grid highlighting to function, these TH elements must have no whitespace between them.
353
- # In this way the Javascript headerCols array will be set properly.
365
+ # In this way the Javascript headerCols array will be set properly.)
354
366
  x_list.each do |x_item|
355
367
  out << "<th>#{x_item.first}</th>"
356
368
  end
@@ -502,6 +514,11 @@ module Brick::Rails::FormTags
502
514
  out
503
515
  end # brick_header
504
516
 
517
+ # All the standard CSS with teal colouration for use with Brick
518
+ def brick_css(theme = nil)
519
+ ::Brick::Rails::BRICK_CSS.html_safe
520
+ end
521
+
505
522
  # -----------------------------------------------------------------------------------------------
506
523
  def set_grid_javascript(klass, pk, show_new_button = nil, row_count = nil, total_row_count = nil)
507
524
  table_name = klass.table_name.split('.').last
@@ -288,6 +288,247 @@ erDiagram
288
288
 
289
289
  # CONSTANTS
290
290
 
291
+ BRICK_CSS = "<style>
292
+ #titleSticky {
293
+ position: sticky;
294
+ display: inline-block;
295
+ left: 0;
296
+ z-index: 2;
297
+ }
298
+
299
+ .flashNotice {
300
+ color: green;
301
+ }
302
+ .flashAlert {
303
+ color: red;
304
+ }
305
+
306
+ h1, h3 {
307
+ margin-bottom: 0;
308
+ }
309
+ #rowCount {
310
+ display: table-cell;
311
+ height: 32px;
312
+ vertical-align: middle;
313
+ font-size: 0.9em;
314
+ font-family: sans-serif;
315
+ }
316
+ #imgErd {
317
+ display: table-cell;
318
+ background-image:url();
319
+ background-repeat: no-repeat;
320
+ background-size: 100% 100%;
321
+ width: 28px;
322
+ height: 32px;
323
+ cursor: pointer;
324
+ }
325
+ #mermaidErd {
326
+ display: none;
327
+ }
328
+ #mermaidErd .exclude {
329
+ position: absolute;
330
+ color: red;
331
+ top: 0;
332
+ right: 0;
333
+ cursor: pointer;
334
+ }
335
+ .relatedModel {
336
+ cursor: pointer;
337
+ }
338
+
339
+ #dropper {
340
+ background-color: #eee;
341
+ }
342
+ #btnImport {
343
+ display: none;
344
+ }
345
+
346
+ #headerTopContainer {
347
+ position: sticky;
348
+ display: inline-block;
349
+ top: 0px;
350
+ background-color: white;
351
+ z-index: 1;
352
+ }
353
+ #headerTopAddNew {
354
+ position: absolute;
355
+ width: 100%;
356
+ top: -33px;
357
+ }
358
+ #headerButtonBox {
359
+ display: inline-block;
360
+ position: sticky;
361
+ right: 0px;
362
+ float: right;
363
+ }
364
+ #headerButtonBox a, #headerButtonBox svg {
365
+ display: table-cell;
366
+ height: 24px;
367
+ width: 24px;
368
+ padding: 2px;
369
+ }
370
+ #addNew {
371
+ background-color: #008061;
372
+ }
373
+
374
+ table {
375
+ border-collapse: collapse;
376
+ font-size: 0.9em;
377
+ font-family: sans-serif;
378
+ }
379
+ table.shadow {
380
+ min-width: 400px;
381
+ box-shadow: 0 0 20px rgba(0, 0, 0, 0.15);
382
+ }
383
+
384
+ tr th {
385
+ background-color: #009879;
386
+ color: #fff;
387
+ text-align: left;
388
+ }
389
+ .col-sticky {
390
+ position: sticky;
391
+ left: 0;
392
+ }
393
+ #headerTop tr th {
394
+ position: relative;
395
+ }
396
+ #headerTop tr th .exclude {
397
+ position: absolute;
398
+ display: none;
399
+ top: 0;
400
+ right: 0;
401
+ cursor: pointer;
402
+ }
403
+ #headerTop tr th:hover, #headerTop tr th.highlight {
404
+ background-color: #28B898;
405
+ }
406
+ #exclusions {
407
+ font-size: 0.7em;
408
+ }
409
+ #exclusions div {
410
+ border: 1px solid blue;
411
+ display: inline-block;
412
+ cursor: copy;
413
+ }
414
+ #headerTop tr th:hover .exclude {
415
+ display: inline;
416
+ cursor: pointer;
417
+ color: red;
418
+ }
419
+ tr th a {
420
+ color: #80FFB8;
421
+ }
422
+ .add-hm-related {
423
+ float: right;
424
+ }
425
+ #tblAddCol {
426
+ position: relative;
427
+ z-index: 2;
428
+ border: 2px solid blue;
429
+ }
430
+ tr th, tr td {
431
+ padding: 0.2em 0.5em;
432
+ }
433
+
434
+ tr td.highlight {
435
+ background-color: #B0B0FF;
436
+ }
437
+
438
+ table tr .col-sticky {
439
+ background-color: #28B898;
440
+ }
441
+
442
+ .show-field {
443
+ background-color: #004998;
444
+ }
445
+ .show-field a {
446
+ color: #80B8D2;
447
+ }
448
+
449
+ table.shadow > tbody > tr {
450
+ border-bottom: thin solid #dddddd;
451
+ }
452
+
453
+ table tbody tr:nth-of-type(even) {
454
+ background-color: #f3f3f3;
455
+ }
456
+ table tbody tr:nth-of-type(even) .alternating-gray {
457
+ background-color: #fff;
458
+ }
459
+ table tbody tr:nth-of-type(odd) .alternating-gray {
460
+ background-color: #f3f3f3;
461
+ }
462
+
463
+ table.shadow > tbody > tr:last-of-type {
464
+ border-bottom: 2px solid #009879;
465
+ }
466
+
467
+ table tbody tr.active-row {
468
+ font-weight: bold;
469
+ color: #009879;
470
+ }
471
+
472
+ a.show-arrow {
473
+ font-size: 1.5em;
474
+ text-decoration: none;
475
+ }
476
+ a.big-arrow {
477
+ font-size: 2.5em;
478
+ text-decoration: none;
479
+ }
480
+ .dimmed {
481
+ background-color: #C0C0C0;
482
+ text-align: center;
483
+ }
484
+ .right {
485
+ text-align: right;
486
+ }
487
+ .paddingBottomZero {
488
+ padding-bottom: 0px;
489
+ }
490
+ .paddingTopZero {
491
+ padding-top: 0px;
492
+ }
493
+ .orphan {
494
+ color: red;
495
+ white-space: nowrap;
496
+ }
497
+ .thumbImg {
498
+ max-width: 96px;
499
+ max-height: 96px;
500
+ }
501
+ .danger {
502
+ background-color: red;
503
+ color: white;
504
+ }
505
+ .brick-note {
506
+ font-size: 0.7em;
507
+ color: #A0FFA0;
508
+ max-width: 0;
509
+ }
510
+
511
+ #revertTemplate {
512
+ display: none;
513
+ }
514
+ svg.revert {
515
+ display: none;
516
+ margin-left: 0.25em;
517
+ }
518
+ input+svg.revert {
519
+ top: 0.5em;
520
+ }
521
+
522
+ .update {
523
+ position: sticky;
524
+ right: 1em;
525
+ float: right;
526
+ background-color: #004998;
527
+ color: #FFF;
528
+ }
529
+ </style>
530
+ "
531
+
291
532
  AVO_SVG = "<svg version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 84 90\" height=\"30\" fill=\"#3096F7\">
292
533
  <path d=\"M83.8304 81.0201C83.8343 82.9343 83.2216 84.7996 82.0822 86.3423C80.9427 87.8851 79.3363 89.0244 77.4984 89.5931C75.6606 90.1618 73.6878 90.1302 71.8694 89.5027C70.0509 88.8753 68.4823 87.6851 67.3935 86.1065L67.0796 85.6029C66.9412 85.378 66.8146 85.1463 66.6998 84.9079L66.8821 85.3007C64.1347 81.223 60.419 77.8817 56.0639 75.5723C51.7087 73.263 46.8484 72.057 41.9129 72.0609C31.75 72.0609 22.372 77.6459 16.9336 85.336C17.1412 84.7518 17.7185 83.6137 17.9463 83.0446L19.1059 80.5265L19.1414 80.456C25.2533 68.3694 37.7252 59.9541 52.0555 59.9541C53.1949 59.9541 54.3241 60.0095 55.433 60.1102C60.748 60.6134 65.8887 62.2627 70.4974 64.9433C75.1061 67.6238 79.0719 71.2712 82.1188 75.6314C82.1188 75.6314 82.1441 75.6717 82.1593 75.6868C82.1808 75.717 82.1995 75.749 82.215 75.7825C82.2821 75.8717 82.3446 75.9641 82.4024 76.0595C82.4682 76.1653 82.534 76.4221 82.5999 76.5279C82.6657 76.6336 82.772 76.82 82.848 76.9711L83.1822 77.7063C83.6094 78.7595 83.8294 79.8844 83.8304 81.0201V81.0201Z\" fill=\"currentColor\" fill-opacity=\"0.22\"></path>
293
534
  <path opacity=\"0.25\" d=\"M83.8303 81.015C83.8354 82.9297 83.2235 84.7956 82.0844 86.3393C80.9453 87.8829 79.339 89.0229 77.5008 89.5923C75.6627 90.1617 73.6895 90.1304 71.8706 89.5031C70.0516 88.8758 68.4826 87.6854 67.3935 86.1065L67.0796 85.6029C66.9412 85.3746 66.8146 85.1429 66.6998 84.9079L66.8821 85.3007C64.1353 81.222 60.4199 77.8797 56.0647 75.5695C51.7095 73.2593 46.8488 72.0524 41.9129 72.0558C31.75 72.0558 22.372 77.6408 16.9336 85.3309C17.1412 84.7467 17.7185 83.6086 17.9463 83.0395L19.1059 80.5214L19.1414 80.4509C22.1906 74.357 26.8837 69.2264 32.6961 65.6326C38.5086 62.0387 45.2114 60.1232 52.0555 60.1001C53.1949 60.1001 54.3241 60.1555 55.433 60.2562C60.7479 60.7594 65.8887 62.4087 70.4974 65.0893C75.1061 67.7698 79.0719 71.4172 82.1188 75.7775C82.1188 75.7775 82.1441 75.8177 82.1593 75.8328C82.1808 75.863 82.1995 75.895 82.215 75.9285C82.2821 76.0177 82.3446 76.1101 82.4024 76.2055L82.5999 76.5228C82.6859 76.6638 82.772 76.8149 82.848 76.966L83.1822 77.7012C83.6093 78.7544 83.8294 79.8793 83.8303 81.015Z\" fill=\"currentColor\" fill-opacity=\"0.22\"></path>
@@ -5,7 +5,7 @@ module Brick
5
5
  module VERSION
6
6
  MAJOR = 1
7
7
  MINOR = 0
8
- TINY = 215
8
+ TINY = 217
9
9
 
10
10
  # PRE is nil unless it's a pre-release (beta, RC, etc.)
11
11
  PRE = nil
@@ -142,6 +142,7 @@ module Brick
142
142
  inv_tbl = fk[:inverse_table].gsub('.', '__')
143
143
  fk_vals << "#{fk[:assoc_name]}: #{inv_tbl}_#{brick_escape(val)}" if val
144
144
  else
145
+ val = val.to_s if val.is_a?(ActiveStorage::Filename)
145
146
  data << "#{col}: #{val.inspect}"
146
147
  end
147
148
  end
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.215
4
+ version: 1.0.217
5
5
  platform: ruby
6
6
  authors:
7
7
  - Lorin Thwaits
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2024-06-08 00:00:00.000000000 Z
11
+ date: 2024-06-15 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: activerecord