phlexi-form 0.5.10 → 0.6.0

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: 85ded0c728aafa222d32ba3cf6002fae6d078208f132b90f880c11ddc1e92821
4
- data.tar.gz: bdab2b38de0a2081d10973c773acded70451abeaa03e6a16087c960afe67d45d
3
+ metadata.gz: 2112fb7333817aef3f7d477f109c96258e03bd3d5a56900021c424c17976de85
4
+ data.tar.gz: 96facfa8646307cd82cbcd69c4679ef4a31dd59be3a0df33926490830667a538
5
5
  SHA512:
6
- metadata.gz: 7c48a34c2da5205abc312a2f0d51782de3b7fbaf6903a43fa746774c85cdca8ead40fa8957df5e997bd7c6422908cd676c46e0abcc4e353a97c0be1e2eb31d2a
7
- data.tar.gz: 67dac3769567c4e3052e4e65c85078631fd8e2133da1b39d7572ce2c6d7364d659f50db6f0f86d69cc7af4a127c8a9a64bb5fb8d02f25d1d8668b5ff7bc32b3a
6
+ metadata.gz: 48f8143f6cf980a6ae60a9b269e5dafa17bfe6712178de1f42be026a80a69419e76fd1d082946fadde620a0b80d64a7bcb6fadb4f7aeffbcef0e439ac8d9f141
7
+ data.tar.gz: 5df2b6fa53da946d5c901cccade7002db1e2769edae64f75187c47ab923b91ac41dce168275f33b7926cb040c850d82412681f015166bf0ee6c3c561c5b2839a
@@ -161,15 +161,8 @@ module Phlexi
161
161
  create_component(Components::Select, :select, **, &)
162
162
  end
163
163
 
164
- def belongs_to_tag(**options, &)
165
- options.fetch(:input_param) {
166
- options[:input_param] = if association_reflection.respond_to?(:options) && association_reflection.options[:foreign_key]
167
- association_reflection.options[:foreign_key]
168
- else
169
- :"#{association_reflection.name}_id"
170
- end
171
- }
172
- select_tag(**options, &)
164
+ def belongs_to_tag(**, &)
165
+ create_component(Components::BelongsTo, :has_many, **, &)
173
166
  end
174
167
 
175
168
  def polymorphic_belongs_to_tag(**, &)
@@ -182,12 +175,8 @@ module Phlexi
182
175
  raise NotImplementedError, "has_one associations are NOT supported"
183
176
  end
184
177
 
185
- def has_many_tag(**options, &)
186
- options.fetch(:input_param) {
187
- options[:input_param] = :"#{association_reflection.name.to_s.singularize}_ids"
188
- }
189
-
190
- select_tag(**options, &)
178
+ def has_many_tag(**, &)
179
+ create_component(Components::HasMany, :has_many, **, &)
191
180
  end
192
181
  alias_method :has_and_belongs_to_many_tag, :has_many_tag
193
182
 
@@ -0,0 +1,29 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Phlexi
4
+ module Form
5
+ module Components
6
+ class BelongsTo < Select
7
+ protected
8
+
9
+ delegate :association_reflection, to: :field
10
+
11
+ def build_attributes
12
+ super
13
+
14
+ build_belongs_to_attributes
15
+ end
16
+
17
+ def build_belongs_to_attributes
18
+ attributes.fetch(:input_param) do
19
+ attributes[:input_param] = if association_reflection.respond_to?(:options) && association_reflection.options[:foreign_key]
20
+ association_reflection.options[:foreign_key]
21
+ else
22
+ :"#{association_reflection.name}_id"
23
+ end
24
+ end
25
+ end
26
+ end
27
+ end
28
+ end
29
+ end
@@ -0,0 +1,25 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Phlexi
4
+ module Form
5
+ module Components
6
+ class HasMany < Select
7
+ protected
8
+
9
+ delegate :association_reflection, to: :field
10
+
11
+ def build_attributes
12
+ super
13
+
14
+ build_has_many_attributes
15
+ end
16
+
17
+ def build_has_many_attributes
18
+ attributes.fetch(:input_param) {
19
+ attributes[:input_param] = :"#{association_reflection.name.to_s.singularize}_ids"
20
+ }
21
+ end
22
+ end
23
+ end
24
+ end
25
+ end
@@ -50,13 +50,15 @@ module Phlexi
50
50
  attributes.fetch(:autofocus) { attributes[:autofocus] = field.focused? }
51
51
  attributes.fetch(:required) { attributes[:required] = field.required? }
52
52
  attributes.fetch(:multiple) { attributes[:multiple] = field.multiple? }
53
- when :date, :time, :"datetime-local"
53
+ when :date, :time, :"datetime-local", :datetime
54
54
  attributes.fetch(:autofocus) { attributes[:autofocus] = field.focused? }
55
55
  attributes.fetch(:readonly) { attributes[:readonly] = field.readonly? }
56
56
  attributes.fetch(:required) { attributes[:required] = field.required? }
57
57
  attributes.fetch(:min) { attributes[:min] = field.min }
58
58
  attributes.fetch(:max) { attributes[:max] = field.max }
59
59
 
60
+ attributes[:type] = :"datetime-local" if attributes[:type] == :datetime
61
+
60
62
  # TODO: Investigate if this is Timezone complaint
61
63
  if field.value.respond_to?(:strftime)
62
64
  attributes[:value] = case attributes[:type]
@@ -18,8 +18,8 @@ module Phlexi
18
18
  def calculate_max
19
19
  if (numericality_validator = find_numericality_validator)
20
20
  get_max_from_validator(numericality_validator)
21
- elsif (max = get_max_from_attribute(key))
22
- max
21
+ else
22
+ get_max_from_attribute(key)
23
23
  end
24
24
  end
25
25
 
@@ -44,8 +44,8 @@ module Phlexi
44
44
  if object.class.respond_to?(:attribute_types) && (attribute_type = object.class.attribute_types[attribute.to_s])
45
45
  if (range = attribute_type.instance_variable_get(:@range))
46
46
  range.max
47
- elsif attribute_type.respond_to?(:precision) && (precision = attribute_type.precision)
48
- (precision**8) - ((step && step != "any") ? step : 0.000001)
47
+ # elsif attribute_type.respond_to?(:precision) && (precision = attribute_type.precision)
48
+ # (precision**8) - ((step && step != "any") ? step : 0.000001)
49
49
  end
50
50
  end
51
51
  end
@@ -18,8 +18,8 @@ module Phlexi
18
18
  def calculate_min
19
19
  if (numericality_validator = find_numericality_validator)
20
20
  get_min_from_validator(numericality_validator)
21
- elsif (min = get_min_from_attribute(key))
22
- min
21
+ else
22
+ get_min_from_attribute(key)
23
23
  end
24
24
  end
25
25
 
@@ -44,8 +44,8 @@ module Phlexi
44
44
  if object.class.respond_to?(:attribute_types) && (attribute_type = object.class.attribute_types[attribute.to_s])
45
45
  if (range = attribute_type.instance_variable_get(:@range))
46
46
  range.min
47
- elsif attribute_type.respond_to?(:precision) && (precision = attribute_type.precision)
48
- -((precision**8) - ((step && step != "any") ? step : 0.000001))
47
+ # elsif attribute_type.respond_to?(:precision) && (precision = attribute_type.precision)
48
+ # -((precision**8) - ((step && step != "any") ? step : 0.000001))
49
49
  end
50
50
  end
51
51
  end
@@ -130,7 +130,19 @@ module Phlexi
130
130
  file: :input,
131
131
  valid_file: :valid_input,
132
132
  invalid_file: :invalid_input,
133
- neutral_file: :neutral_input
133
+ neutral_file: :neutral_input,
134
+
135
+ # BelongsTo
136
+ belongs_to: :select,
137
+ valid_belongs_to: :valid_select,
138
+ invalid_belongs_to: :invalid_select,
139
+ neutral_belongs_to: :neutral_select,
140
+
141
+ # HasMany
142
+ has_many: :select,
143
+ valid_has_many: :valid_select,
144
+ invalid_has_many: :invalid_select,
145
+ neutral_has_many: :neutral_select
134
146
 
135
147
  }.freeze
136
148
  end
@@ -2,6 +2,6 @@
2
2
 
3
3
  module Phlexi
4
4
  module Form
5
- VERSION = "0.5.10"
5
+ VERSION = "0.6.0"
6
6
  end
7
7
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: phlexi-form
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.5.10
4
+ version: 0.6.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Stefan Froelich
8
8
  autorequire:
9
9
  bindir: exe
10
10
  cert_chain: []
11
- date: 2024-11-30 00:00:00.000000000 Z
11
+ date: 2024-12-02 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: phlex
@@ -207,6 +207,7 @@ files:
207
207
  - lib/phlexi/form/builder.rb
208
208
  - lib/phlexi/form/choices_mapper.rb
209
209
  - lib/phlexi/form/components/base.rb
210
+ - lib/phlexi/form/components/belongs_to.rb
210
211
  - lib/phlexi/form/components/checkbox.rb
211
212
  - lib/phlexi/form/components/collection_checkboxes.rb
212
213
  - lib/phlexi/form/components/collection_radio_buttons.rb
@@ -220,6 +221,7 @@ files:
220
221
  - lib/phlexi/form/components/file_input.rb
221
222
  - lib/phlexi/form/components/form_errors.rb
222
223
  - lib/phlexi/form/components/full_error.rb
224
+ - lib/phlexi/form/components/has_many.rb
223
225
  - lib/phlexi/form/components/hint.rb
224
226
  - lib/phlexi/form/components/input.rb
225
227
  - lib/phlexi/form/components/input_array.rb