actionview 7.1.5.1 → 7.2.0.beta1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG.md +41 -456
- data/lib/action_view/base.rb +19 -1
- data/lib/action_view/cache_expiry.rb +9 -3
- data/lib/action_view/dependency_tracker/{ripper_tracker.rb → ruby_tracker.rb} +4 -3
- data/lib/action_view/dependency_tracker.rb +1 -1
- data/lib/action_view/gem_version.rb +3 -3
- data/lib/action_view/helpers/asset_tag_helper.rb +18 -6
- data/lib/action_view/helpers/csrf_helper.rb +1 -1
- data/lib/action_view/helpers/form_helper.rb +197 -192
- data/lib/action_view/helpers/form_tag_helper.rb +76 -43
- data/lib/action_view/helpers/output_safety_helper.rb +4 -4
- data/lib/action_view/helpers/tag_helper.rb +208 -18
- data/lib/action_view/helpers/url_helper.rb +6 -82
- data/lib/action_view/layouts.rb +2 -4
- data/lib/action_view/log_subscriber.rb +8 -4
- data/lib/action_view/railtie.rb +0 -1
- data/lib/action_view/render_parser/prism_render_parser.rb +127 -0
- data/lib/action_view/{ripper_ast_parser.rb → render_parser/ripper_render_parser.rb} +152 -9
- data/lib/action_view/render_parser.rb +21 -169
- data/lib/action_view/renderer/abstract_renderer.rb +1 -1
- data/lib/action_view/renderer/renderer.rb +32 -38
- data/lib/action_view/rendering.rb +4 -4
- data/lib/action_view/template/renderable.rb +7 -1
- data/lib/action_view/template/resolver.rb +0 -2
- data/lib/action_view/template.rb +18 -1
- data/lib/action_view/test_case.rb +7 -9
- data/lib/assets/compiled/rails-ujs.js +777 -0
- metadata +20 -18
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: e667c2e3d2154547c2f51d406d07515af42cc9074e21e8179fdab642126821e4
|
4
|
+
data.tar.gz: 26339190cf4ab15b06913451c1ea6a750d5399ba4f7963cdc55b7f59db818ada
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: b7e494e368f95c7b398f30d88d15bcc9a6aa3cc033cd339c432447959ebf7cff2090c11bece1360303414228100a1a72a29c95aa7044ccd6861547693785f711
|
7
|
+
data.tar.gz: 732c61233f0a1c25291232981ef399afca94c0ebff7a8215b1f810696e24e8a72fa49afc2c65ce1bac92967bff1fe2aa4802c8c2bbd9cfaefd0cc8fbc8798210
|
data/CHANGELOG.md
CHANGED
@@ -1,88 +1,54 @@
|
|
1
|
-
## Rails 7.
|
1
|
+
## Rails 7.2.0.beta1 (May 29, 2024) ##
|
2
2
|
|
3
|
-
*
|
3
|
+
* Add queries count to template rendering instrumentation.
|
4
4
|
|
5
|
+
```
|
6
|
+
# Before
|
7
|
+
Completed 200 OK in 3804ms (Views: 41.0ms | ActiveRecord: 33.5ms | Allocations: 112788)
|
5
8
|
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
## Rails 7.1.4.2 (October 23, 2024) ##
|
12
|
-
|
13
|
-
* No changes.
|
14
|
-
|
15
|
-
|
16
|
-
## Rails 7.1.4.1 (October 15, 2024) ##
|
17
|
-
|
18
|
-
* No changes.
|
19
|
-
|
9
|
+
# After
|
10
|
+
Completed 200 OK in 3804ms (Views: 41.0ms | ActiveRecord: 33.5ms (2 queries, 1 cached) | Allocations: 112788)
|
11
|
+
```
|
20
12
|
|
21
|
-
|
13
|
+
*fatkodima*
|
22
14
|
|
23
|
-
*
|
15
|
+
* Raise `ArgumentError` if `:renderable` object does not respond to `#render_in`.
|
24
16
|
|
25
17
|
*Sean Doyle*
|
26
18
|
|
27
|
-
*
|
28
|
-
|
29
|
-
*Jean Boussier*
|
30
|
-
|
31
|
-
* Fix threading issue with strict locals.
|
32
|
-
|
33
|
-
*Robert Fletcher*
|
34
|
-
|
35
|
-
|
36
|
-
## Rails 7.1.3.4 (June 04, 2024) ##
|
37
|
-
|
38
|
-
* No changes.
|
39
|
-
|
40
|
-
|
41
|
-
## Rails 7.1.3.3 (May 16, 2024) ##
|
42
|
-
|
43
|
-
* No changes.
|
44
|
-
|
45
|
-
|
46
|
-
## Rails 7.1.3.2 (February 21, 2024) ##
|
47
|
-
|
48
|
-
* No changes.
|
49
|
-
|
50
|
-
|
51
|
-
## Rails 7.1.3.1 (February 21, 2024) ##
|
52
|
-
|
53
|
-
* No changes.
|
19
|
+
* Add the `nonce: true` option for `stylesheet_link_tag` helper to support automatic nonce generation for Content Security Policy.
|
54
20
|
|
21
|
+
Works the same way as `javascript_include_tag nonce: true` does.
|
55
22
|
|
56
|
-
|
23
|
+
*Akhil G Krishnan*, *AJ Esler*
|
57
24
|
|
58
|
-
*
|
25
|
+
* Parse `ActionView::TestCase#rendered` HTML content as `Nokogiri::XML::DocumentFragment` instead of `Nokogiri::XML::Document`.
|
59
26
|
|
60
|
-
*
|
61
|
-
|
62
|
-
* Fix `word_wrap` with empty string.
|
63
|
-
|
64
|
-
*Jonathan Hefner*
|
27
|
+
*Sean Doyle*
|
65
28
|
|
66
29
|
* Rename `ActionView::TestCase::Behavior::Content` to `ActionView::TestCase::Behavior::RenderedViewContent`.
|
67
30
|
|
68
|
-
Make `RenderedViewContent` inherit from `String`. Make private API with `:nodoc
|
31
|
+
Make `RenderedViewContent` inherit from `String`. Make private API with `:nodoc:`
|
69
32
|
|
70
33
|
*Sean Doyle*
|
71
34
|
|
72
|
-
*
|
35
|
+
* Deprecate passing `nil` as value for the `model:` argument to the `form_with` method.
|
73
36
|
|
74
|
-
|
37
|
+
*Collin Jilbert*
|
75
38
|
|
76
|
-
|
39
|
+
* Alias `field_set_tag` helper to `fieldset_tag` to match `<fieldset>` element.
|
77
40
|
|
41
|
+
*Sean Doyle*
|
42
|
+
|
43
|
+
* Deprecate passing content to void elements when using `tag.br` type tag builders.
|
78
44
|
|
79
|
-
|
45
|
+
*Hartley McGuire*
|
80
46
|
|
81
47
|
* Fix the `number_to_human_size` view helper to correctly work with negative numbers.
|
82
48
|
|
83
49
|
*Earlopain*
|
84
50
|
|
85
|
-
* Automatically discard the implicit locals injected by collection rendering for template that can't accept them
|
51
|
+
* Automatically discard the implicit locals injected by collection rendering for template that can't accept them.
|
86
52
|
|
87
53
|
When rendering a collection, two implicit variables are injected, which breaks templates with strict locals.
|
88
54
|
|
@@ -90,20 +56,17 @@
|
|
90
56
|
|
91
57
|
*Yasha Krasnou*, *Jean Boussier*
|
92
58
|
|
93
|
-
* Fix `@rails/ujs` calling `start()` an extra time when using bundlers
|
59
|
+
* Fix `@rails/ujs` calling `start()` an extra time when using bundlers.
|
94
60
|
|
95
61
|
*Hartley McGuire*, *Ryunosuke Sato*
|
96
62
|
|
97
|
-
* Fix the `capture` view helper compatibility with HAML and Slim
|
63
|
+
* Fix the `capture` view helper compatibility with HAML and Slim.
|
98
64
|
|
99
65
|
When a blank string was captured in HAML or Slim (and possibly other template engines)
|
100
66
|
it would instead return the entire buffer.
|
101
67
|
|
102
68
|
*Jean Boussier*
|
103
69
|
|
104
|
-
|
105
|
-
## Rails 7.1.1 (October 11, 2023) ##
|
106
|
-
|
107
70
|
* Updated `@rails/ujs` files to ignore certain data-* attributes when element is contenteditable.
|
108
71
|
|
109
72
|
This fix was already landed in >= 7.0.4.3, < 7.1.0.
|
@@ -111,406 +74,28 @@
|
|
111
74
|
|
112
75
|
*Ryunosuke Sato*
|
113
76
|
|
77
|
+
* Added validation for HTML tag names in the `tag` and `content_tag` helper method.
|
114
78
|
|
115
|
-
|
116
|
-
|
117
|
-
|
118
|
-
|
119
|
-
|
120
|
-
## Rails 7.1.0.rc2 (October 01, 2023) ##
|
121
|
-
|
122
|
-
* No changes.
|
123
|
-
|
124
|
-
|
125
|
-
## Rails 7.1.0.rc1 (September 27, 2023) ##
|
126
|
-
|
127
|
-
* Introduce `ActionView::TestCase.register_parser`
|
128
|
-
|
129
|
-
```ruby
|
130
|
-
register_parser :rss, -> rendered { RSS::Parser.parse(rendered) }
|
131
|
-
|
132
|
-
test "renders RSS" do
|
133
|
-
article = Article.create!(title: "Hello, world")
|
134
|
-
|
135
|
-
render formats: :rss, partial: article
|
136
|
-
|
137
|
-
assert_equal "Hello, world", rendered.rss.items.last.title
|
138
|
-
end
|
139
|
-
```
|
140
|
-
|
141
|
-
By default, register parsers for `:html` and `:json`.
|
142
|
-
|
143
|
-
*Sean Doyle*
|
144
|
-
|
145
|
-
|
146
|
-
## Rails 7.1.0.beta1 (September 13, 2023) ##
|
147
|
-
|
148
|
-
* Fix `simple_format` with blank `wrapper_tag` option returns plain html tag
|
149
|
-
|
150
|
-
By default `simple_format` method returns the text wrapped with `<p>`. But if we explicitly specify
|
151
|
-
the `wrapper_tag: nil` in the options, it returns the text wrapped with `<></>` tag.
|
152
|
-
|
153
|
-
Before:
|
154
|
-
|
155
|
-
```ruby
|
156
|
-
simple_format("Hello World", {}, { wrapper_tag: nil })
|
157
|
-
# <>Hello World</>
|
158
|
-
```
|
159
|
-
|
160
|
-
After:
|
161
|
-
|
162
|
-
```ruby
|
163
|
-
simple_format("Hello World", {}, { wrapper_tag: nil })
|
164
|
-
# <p>Hello World</p>
|
165
|
-
```
|
166
|
-
|
167
|
-
*Akhil G Krishnan*, *Junichi Ito*
|
168
|
-
|
169
|
-
* Don't double-encode nested `field_id` and `field_name` index values
|
170
|
-
|
171
|
-
Pass `index: @options` as a default keyword argument to `field_id` and
|
172
|
-
`field_name` view helper methods.
|
173
|
-
|
174
|
-
*Sean Doyle*
|
175
|
-
|
176
|
-
* Allow opting in/out of `Link preload` headers when calling `stylesheet_link_tag` or `javascript_include_tag`
|
177
|
-
|
178
|
-
```ruby
|
179
|
-
# will exclude header, even if setting is enabled:
|
180
|
-
javascript_include_tag("http://example.com/all.js", preload_links_header: false)
|
181
|
-
|
182
|
-
# will include header, even if setting is disabled:
|
183
|
-
stylesheet_link_tag("http://example.com/all.js", preload_links_header: true)
|
184
|
-
```
|
185
|
-
|
186
|
-
*Alex Ghiculescu*
|
187
|
-
|
188
|
-
* Stop generating `Link preload` headers once it has reached 1KB.
|
189
|
-
|
190
|
-
Some proxies have trouble handling large headers, but more importantly preload links
|
191
|
-
have diminishing returns so it's preferable not to go overboard with them.
|
192
|
-
|
193
|
-
If tighter control is needed, it's recommended to disable automatic generation of preloads
|
194
|
-
and to generate them manually from the controller or from a middleware.
|
195
|
-
|
196
|
-
*Jean Boussier*
|
197
|
-
|
198
|
-
* `simple_format` helper now handles a `:sanitize_options` - any extra options you want appending to the sanitize.
|
199
|
-
|
200
|
-
Before:
|
201
|
-
```ruby
|
202
|
-
simple_format("<a target=\"_blank\" href=\"http://example.com\">Continue</a>")
|
203
|
-
# => "<p><a href=\"http://example.com\">Continue</a></p>"
|
204
|
-
```
|
205
|
-
|
206
|
-
After:
|
207
|
-
```ruby
|
208
|
-
simple_format("<a target=\"_blank\" href=\"http://example.com\">Continue</a>", {}, { sanitize_options: { attributes: %w[target href] } })
|
209
|
-
# => "<p><a target=\"_blank\" href=\"http://example.com\">Continue</a></p>"
|
210
|
-
```
|
211
|
-
|
212
|
-
*Andrei Andriichuk*
|
213
|
-
|
214
|
-
* Add support for HTML5 standards-compliant sanitizers, and default to `Rails::HTML5::Sanitizer`
|
215
|
-
in the Rails 7.1 configuration if it is supported.
|
216
|
-
|
217
|
-
Action View's HTML sanitizers can be configured by setting
|
218
|
-
`config.action_view.sanitizer_vendor`. Supported values are `Rails::HTML4::Sanitizer` or
|
219
|
-
`Rails::HTML5::Sanitizer`.
|
220
|
-
|
221
|
-
The Rails 7.1 configuration will set this to `Rails::HTML5::Sanitizer` when it is supported, and
|
222
|
-
fall back to `Rails::HTML4::Sanitizer`. Previous configurations default to
|
223
|
-
`Rails::HTML4::Sanitizer`.
|
224
|
-
|
225
|
-
*Mike Dalessio*
|
226
|
-
|
227
|
-
* `config.dom_testing_default_html_version` controls the HTML parser used by
|
228
|
-
`ActionView::TestCase#document_root_element`, which creates the DOM used by the assertions in
|
229
|
-
Rails::Dom::Testing.
|
230
|
-
|
231
|
-
The Rails 7.1 default configuration opts into the HTML5 parser when it is supported, to better
|
232
|
-
represent what the DOM would be in a browser user agent. Previously this test helper always used
|
233
|
-
Nokogiri's HTML4 parser.
|
234
|
-
|
235
|
-
*Mike Dalessio*
|
236
|
-
|
237
|
-
* Add support for the HTML picture tag. It supports passing a String, an Array or a Block.
|
238
|
-
Supports passing properties directly to the img tag via the `:image` key.
|
239
|
-
Since the picture tag requires an img tag, the last element you provide will be used for the img tag.
|
240
|
-
For complete control over the picture tag, a block can be passed, which will populate the contents of the tag accordingly.
|
241
|
-
|
242
|
-
Can be used like this for a single source:
|
243
|
-
```erb
|
244
|
-
<%= picture_tag("picture.webp") %>
|
245
|
-
```
|
246
|
-
which will generate the following:
|
247
|
-
```html
|
248
|
-
<picture>
|
249
|
-
<img src="/images/picture.webp" />
|
250
|
-
</picture>
|
251
|
-
```
|
252
|
-
|
253
|
-
For multiple sources:
|
254
|
-
```erb
|
255
|
-
<%= picture_tag("picture.webp", "picture.png", :class => "mt-2", :image => { alt: "Image", class: "responsive-img" }) %>
|
256
|
-
```
|
257
|
-
will generate:
|
258
|
-
```html
|
259
|
-
<picture class="mt-2">
|
260
|
-
<source srcset="/images/picture.webp" />
|
261
|
-
<source srcset="/images/picture.png" />
|
262
|
-
<img alt="Image" class="responsive-img" src="/images/picture.png" />
|
263
|
-
</picture>
|
264
|
-
```
|
265
|
-
|
266
|
-
Full control via a block:
|
267
|
-
```erb
|
268
|
-
<%= picture_tag(:class => "my-class") do %>
|
269
|
-
<%= tag(:source, :srcset => image_path("picture.webp")) %>
|
270
|
-
<%= tag(:source, :srcset => image_path("picture.png")) %>
|
271
|
-
<%= image_tag("picture.png", :alt => "Image") %>
|
272
|
-
<% end %>
|
273
|
-
```
|
274
|
-
will generate:
|
275
|
-
```html
|
276
|
-
<picture class="my-class">
|
277
|
-
<source srcset="/images/picture.webp" />
|
278
|
-
<source srcset="/images/picture.png" />
|
279
|
-
<img alt="Image" src="/images/picture.png" />
|
280
|
-
</picture>
|
281
|
-
```
|
282
|
-
|
283
|
-
*Juan Pablo Balarini*
|
284
|
-
|
285
|
-
* Remove deprecated support to passing instance variables as locals to partials.
|
286
|
-
|
287
|
-
*Rafael Mendonça França*
|
288
|
-
|
289
|
-
* Remove deprecated constant `ActionView::Path`.
|
290
|
-
|
291
|
-
*Rafael Mendonça França*
|
292
|
-
|
293
|
-
* Guard `token_list` calls from escaping HTML too often
|
294
|
-
|
295
|
-
*Sean Doyle*
|
296
|
-
|
297
|
-
* `select` can now be called with a single hash containing options and some HTML options
|
298
|
-
|
299
|
-
Previously this would not work as expected:
|
300
|
-
|
301
|
-
```erb
|
302
|
-
<%= select :post, :author, authors, required: true %>
|
303
|
-
```
|
304
|
-
|
305
|
-
Instead you needed to do this:
|
306
|
-
|
307
|
-
```erb
|
308
|
-
<%= select :post, :author, authors, {}, required: true %>
|
309
|
-
```
|
79
|
+
The `tag` and `content_tag` method now checks that the provided tag name adheres to the HTML
|
80
|
+
specification. If an invalid HTML tag name is provided, the method raises an `ArgumentError`
|
81
|
+
with an appropriate error message.
|
310
82
|
|
311
|
-
|
83
|
+
Examples:
|
312
84
|
|
313
|
-
*Alex Ghiculescu*
|
314
|
-
|
315
|
-
* Datetime form helpers (`time_field`, `date_field`, `datetime_field`, `week_field`, `month_field`) now accept an instance of Time/Date/DateTime as `:value` option.
|
316
|
-
|
317
|
-
Before:
|
318
|
-
```erb
|
319
|
-
<%= form.datetime_field :written_at, value: Time.current.strftime("%Y-%m-%dT%T") %>
|
320
|
-
```
|
321
|
-
|
322
|
-
After:
|
323
|
-
```erb
|
324
|
-
<%= form.datetime_field :written_at, value: Time.current %>
|
325
|
-
```
|
326
|
-
|
327
|
-
*Andrey Samsonov*
|
328
|
-
|
329
|
-
* Choices of `select` can optionally contain html attributes as the last element
|
330
|
-
of the child arrays when using grouped/nested collections
|
331
|
-
|
332
|
-
```erb
|
333
|
-
<%= form.select :foo, [["North America", [["United States","US"],["Canada","CA"]], { disabled: "disabled" }]] %>
|
334
|
-
# => <select><optgroup label="North America" disabled="disabled"><option value="US">United States</option><option value="CA">Canada</option></optgroup></select>
|
335
|
-
```
|
336
|
-
|
337
|
-
*Chris Gunther*
|
338
|
-
|
339
|
-
* `check_box_tag` and `radio_button_tag` now accept `checked` as a keyword argument
|
340
|
-
|
341
|
-
This is to make the API more consistent with the `FormHelper` variants. You can now
|
342
|
-
provide `checked` as a positional or keyword argument:
|
343
|
-
|
344
|
-
```erb
|
345
|
-
= check_box_tag "admin", "1", false
|
346
|
-
= check_box_tag "admin", "1", checked: false
|
347
|
-
|
348
|
-
= radio_button_tag 'favorite_color', 'maroon', false
|
349
|
-
= radio_button_tag 'favorite_color', 'maroon', checked: false
|
350
|
-
```
|
351
|
-
|
352
|
-
*Alex Ghiculescu*
|
353
|
-
|
354
|
-
* Allow passing a class to `dom_id`.
|
355
|
-
You no longer need to call `new` when passing a class to `dom_id`.
|
356
|
-
This makes `dom_id` behave like `dom_class` in this regard.
|
357
|
-
Apart from saving a few keystrokes, it prevents Ruby from needing
|
358
|
-
to instantiate a whole new object just to generate a string.
|
359
|
-
|
360
|
-
Before:
|
361
|
-
```ruby
|
362
|
-
dom_id(Post) # => NoMethodError: undefined method `to_key' for Post:Class
|
363
|
-
```
|
364
|
-
|
365
|
-
After:
|
366
85
|
```ruby
|
367
|
-
|
368
|
-
|
86
|
+
# Raises ArgumentError: Invalid HTML5 tag name: 12p
|
87
|
+
content_tag("12p") # Starting with a number
|
369
88
|
|
370
|
-
|
89
|
+
# Raises ArgumentError: Invalid HTML5 tag name: ""
|
90
|
+
content_tag("") # Empty tag name
|
371
91
|
|
372
|
-
|
92
|
+
# Raises ArgumentError: Invalid HTML5 tag name: div/
|
93
|
+
tag("div/") # Contains a solidus
|
373
94
|
|
374
|
-
|
375
|
-
|
376
|
-
{
|
377
|
-
identifier: "/Users/adam/projects/notifications/app/views/posts/index.html.erb",
|
378
|
-
layout: "layouts/application"
|
379
|
-
}
|
380
|
-
```
|
381
|
-
|
382
|
-
After:
|
383
|
-
```ruby
|
384
|
-
{
|
385
|
-
identifier: "/Users/adam/projects/notifications/app/views/posts/index.html.erb",
|
386
|
-
layout: "layouts/application",
|
387
|
-
locals: {foo: "bar"}
|
388
|
-
}
|
389
|
-
```
|
390
|
-
|
391
|
-
*Aaron Gough*
|
392
|
-
|
393
|
-
* Strip `break_sequence` at the end of `word_wrap`.
|
394
|
-
|
395
|
-
This fixes a bug where `word_wrap` didn't properly strip off break sequences that had printable characters.
|
396
|
-
|
397
|
-
For example, compare the outputs of this template:
|
398
|
-
|
399
|
-
```erb
|
400
|
-
# <%= word_wrap("11 22\n33 44", line_width: 2, break_sequence: "\n# ") %>
|
95
|
+
# Raises ArgumentError: Invalid HTML5 tag name: "image file"
|
96
|
+
tag("image file") # Contains a space
|
401
97
|
```
|
402
98
|
|
403
|
-
|
404
|
-
|
405
|
-
```
|
406
|
-
# 11
|
407
|
-
# 22
|
408
|
-
#
|
409
|
-
# 33
|
410
|
-
# 44
|
411
|
-
#
|
412
|
-
```
|
413
|
-
|
414
|
-
After:
|
415
|
-
|
416
|
-
```
|
417
|
-
# 11
|
418
|
-
# 22
|
419
|
-
# 33
|
420
|
-
# 44
|
421
|
-
```
|
422
|
-
|
423
|
-
*Max Chernyak*
|
424
|
-
|
425
|
-
* Allow templates to set strict `locals`.
|
426
|
-
|
427
|
-
By default, templates will accept any `locals` as keyword arguments. To define what `locals` a template accepts, add a `locals` magic comment:
|
428
|
-
|
429
|
-
```erb
|
430
|
-
<%# locals: (message:) -%>
|
431
|
-
<%= message %>
|
432
|
-
```
|
433
|
-
|
434
|
-
Default values can also be provided:
|
435
|
-
|
436
|
-
```erb
|
437
|
-
<%# locals: (message: "Hello, world!") -%>
|
438
|
-
<%= message %>
|
439
|
-
```
|
440
|
-
|
441
|
-
Or `locals` can be disabled entirely:
|
442
|
-
|
443
|
-
```erb
|
444
|
-
<%# locals: () %>
|
445
|
-
```
|
446
|
-
|
447
|
-
*Joel Hawksley*
|
448
|
-
|
449
|
-
* Add `include_seconds` option for `datetime_local_field`
|
450
|
-
|
451
|
-
This allows to omit seconds part in the input field, by passing `include_seconds: false`
|
452
|
-
|
453
|
-
*Wojciech Wnętrzak*
|
454
|
-
|
455
|
-
* Guard against `ActionView::Helpers::FormTagHelper#field_name` calls with nil
|
456
|
-
`object_name` arguments. For example:
|
457
|
-
|
458
|
-
```erb
|
459
|
-
<%= fields do |f| %>
|
460
|
-
<%= f.field_name :body %>
|
461
|
-
<% end %>
|
462
|
-
```
|
463
|
-
|
464
|
-
*Sean Doyle*
|
465
|
-
|
466
|
-
* Strings returned from `strip_tags` are correctly tagged `html_safe?`
|
467
|
-
|
468
|
-
Because these strings contain no HTML elements and the basic entities are escaped, they are safe
|
469
|
-
to be included as-is as PCDATA in HTML content. Tagging them as html-safe avoids double-escaping
|
470
|
-
entities when being concatenated to a SafeBuffer during rendering.
|
471
|
-
|
472
|
-
Fixes [rails/rails-html-sanitizer#124](https://github.com/rails/rails-html-sanitizer/issues/124)
|
473
|
-
|
474
|
-
*Mike Dalessio*
|
475
|
-
|
476
|
-
* Move `convert_to_model` call from `form_for` into `form_with`
|
477
|
-
|
478
|
-
Now that `form_for` is implemented in terms of `form_with`, remove the
|
479
|
-
`convert_to_model` call from `form_for`.
|
480
|
-
|
481
|
-
*Sean Doyle*
|
482
|
-
|
483
|
-
* Fix and add protections for XSS in `ActionView::Helpers` and `ERB::Util`.
|
484
|
-
|
485
|
-
Escape dangerous characters in names of tags and names of attributes in the
|
486
|
-
tag helpers, following the XML specification. Rename the option
|
487
|
-
`:escape_attributes` to `:escape`, to simplify by applying the option to the
|
488
|
-
whole tag.
|
489
|
-
|
490
|
-
*Álvaro Martín Fraguas*
|
491
|
-
|
492
|
-
* Extend audio_tag and video_tag to accept Active Storage attachments.
|
493
|
-
|
494
|
-
Now it's possible to write
|
495
|
-
|
496
|
-
```ruby
|
497
|
-
audio_tag(user.audio_file)
|
498
|
-
video_tag(user.video_file)
|
499
|
-
```
|
500
|
-
|
501
|
-
Instead of
|
502
|
-
|
503
|
-
```ruby
|
504
|
-
audio_tag(polymorphic_path(user.audio_file))
|
505
|
-
video_tag(polymorphic_path(user.video_file))
|
506
|
-
```
|
507
|
-
|
508
|
-
`image_tag` already supported that, so this follows the same pattern.
|
509
|
-
|
510
|
-
*Matheus Richard*
|
511
|
-
|
512
|
-
* Ensure models passed to `form_for` attempt to call `to_model`.
|
513
|
-
|
514
|
-
*Sean Doyle*
|
99
|
+
*Akhil G Krishnan*
|
515
100
|
|
516
|
-
Please check [7-
|
101
|
+
Please check [7-1-stable](https://github.com/rails/rails/blob/7-1-stable/actionview/CHANGELOG.md) for previous changes.
|
data/lib/action_view/base.rb
CHANGED
@@ -80,6 +80,23 @@ module ActionView # :nodoc:
|
|
80
80
|
# This is useful in cases where you aren't sure if the local variable has been assigned. Alternatively, you could also use
|
81
81
|
# <tt>defined? headline</tt> to first check if the variable has been assigned before using it.
|
82
82
|
#
|
83
|
+
# By default, templates will accept any <tt>locals</tt> as keyword arguments. To restrict what <tt>locals</tt> a template accepts, add a <tt>locals:</tt> magic comment:
|
84
|
+
#
|
85
|
+
# <%# locals: (headline:) %>
|
86
|
+
#
|
87
|
+
# Headline: <%= headline %>
|
88
|
+
#
|
89
|
+
# In cases where the local variables are optional, declare the keyword argument with a default value:
|
90
|
+
#
|
91
|
+
# <%# locals: (headline: nil) %>
|
92
|
+
#
|
93
|
+
# <% unless headline.nil? %>
|
94
|
+
# Headline: <%= headline %>
|
95
|
+
# <% end %>
|
96
|
+
#
|
97
|
+
# Read more about strict locals in {Action View Overview}[https://guides.rubyonrails.org/action_view_overview.html#strict-locals]
|
98
|
+
# in the guides.
|
99
|
+
#
|
83
100
|
# === Template caching
|
84
101
|
#
|
85
102
|
# By default, \Rails will compile each template to a method in order to render it. When you alter a template,
|
@@ -256,7 +273,8 @@ module ActionView # :nodoc:
|
|
256
273
|
message.
|
257
274
|
gsub("unknown keyword:", "unknown local:").
|
258
275
|
gsub("missing keyword:", "missing local:").
|
259
|
-
gsub("no keywords accepted", "no locals accepted")
|
276
|
+
gsub("no keywords accepted", "no locals accepted").
|
277
|
+
concat(" for #{@current_template.short_identifier}")
|
260
278
|
)
|
261
279
|
end
|
262
280
|
else
|
@@ -10,16 +10,17 @@ module ActionView
|
|
10
10
|
@watcher = nil
|
11
11
|
@previous_change = false
|
12
12
|
|
13
|
-
rebuild_watcher
|
14
|
-
|
15
13
|
ActionView::PathRegistry.file_system_resolver_hooks << method(:rebuild_watcher)
|
16
14
|
end
|
17
15
|
|
18
16
|
def updated?
|
17
|
+
build_watcher unless @watcher
|
19
18
|
@previous_change || @watcher.updated?
|
20
19
|
end
|
21
20
|
|
22
21
|
def execute
|
22
|
+
return unless @watcher
|
23
|
+
|
23
24
|
watcher = nil
|
24
25
|
@mutex.synchronize do
|
25
26
|
@previous_change = false
|
@@ -33,7 +34,7 @@ module ActionView
|
|
33
34
|
ActionView::LookupContext::DetailsKey.clear
|
34
35
|
end
|
35
36
|
|
36
|
-
def
|
37
|
+
def build_watcher
|
37
38
|
@mutex.synchronize do
|
38
39
|
old_watcher = @watcher
|
39
40
|
|
@@ -51,6 +52,11 @@ module ActionView
|
|
51
52
|
end
|
52
53
|
end
|
53
54
|
|
55
|
+
def rebuild_watcher
|
56
|
+
return unless @watcher
|
57
|
+
build_watcher
|
58
|
+
end
|
59
|
+
|
54
60
|
def dirs_to_watch
|
55
61
|
all_view_paths.uniq.sort
|
56
62
|
end
|
@@ -2,7 +2,7 @@
|
|
2
2
|
|
3
3
|
module ActionView
|
4
4
|
class DependencyTracker # :nodoc:
|
5
|
-
class
|
5
|
+
class RubyTracker # :nodoc:
|
6
6
|
EXPLICIT_DEPENDENCY = /# Template Dependency: (\S+)/
|
7
7
|
|
8
8
|
def self.call(name, template, view_paths = nil)
|
@@ -17,8 +17,9 @@ module ActionView
|
|
17
17
|
true
|
18
18
|
end
|
19
19
|
|
20
|
-
def initialize(name, template, view_paths = nil)
|
20
|
+
def initialize(name, template, view_paths = nil, parser_class: RenderParser::Default)
|
21
21
|
@name, @template, @view_paths = name, template, view_paths
|
22
|
+
@parser_class = parser_class
|
22
23
|
end
|
23
24
|
|
24
25
|
private
|
@@ -29,7 +30,7 @@ module ActionView
|
|
29
30
|
|
30
31
|
compiled_source = template.handler.call(template, template.source)
|
31
32
|
|
32
|
-
|
33
|
+
@parser_class.new(@name, compiled_source).render_calls.filter_map do |render_call|
|
33
34
|
next if render_call.end_with?("/_")
|
34
35
|
render_call.gsub(%r|/_|, "/")
|
35
36
|
end
|