actionview 6.1.7 → 7.0.0.alpha1
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of actionview might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/CHANGELOG.md +89 -357
- data/MIT-LICENSE +2 -1
- data/lib/action_view/base.rb +3 -3
- data/lib/action_view/buffers.rb +2 -2
- data/lib/action_view/cache_expiry.rb +46 -32
- data/lib/action_view/dependency_tracker/erb_tracker.rb +154 -0
- data/lib/action_view/dependency_tracker/ripper_tracker.rb +59 -0
- data/lib/action_view/dependency_tracker.rb +6 -147
- data/lib/action_view/digestor.rb +7 -4
- data/lib/action_view/flows.rb +4 -4
- data/lib/action_view/gem_version.rb +4 -4
- data/lib/action_view/helpers/active_model_helper.rb +1 -1
- data/lib/action_view/helpers/asset_tag_helper.rb +84 -29
- data/lib/action_view/helpers/asset_url_helper.rb +7 -7
- data/lib/action_view/helpers/atom_feed_helper.rb +3 -4
- data/lib/action_view/helpers/cache_helper.rb +51 -3
- data/lib/action_view/helpers/capture_helper.rb +2 -2
- data/lib/action_view/helpers/controller_helper.rb +2 -2
- data/lib/action_view/helpers/csp_helper.rb +1 -1
- data/lib/action_view/helpers/csrf_helper.rb +1 -1
- data/lib/action_view/helpers/date_helper.rb +6 -7
- data/lib/action_view/helpers/debug_helper.rb +3 -1
- data/lib/action_view/helpers/form_helper.rb +72 -12
- data/lib/action_view/helpers/form_options_helper.rb +65 -33
- data/lib/action_view/helpers/form_tag_helper.rb +75 -32
- data/lib/action_view/helpers/javascript_helper.rb +3 -5
- data/lib/action_view/helpers/number_helper.rb +3 -4
- data/lib/action_view/helpers/output_safety_helper.rb +2 -2
- data/lib/action_view/helpers/rendering_helper.rb +1 -1
- data/lib/action_view/helpers/sanitize_helper.rb +2 -2
- data/lib/action_view/helpers/tag_helper.rb +25 -44
- data/lib/action_view/helpers/tags/base.rb +3 -15
- data/lib/action_view/helpers/tags/check_box.rb +2 -2
- data/lib/action_view/helpers/tags/collection_select.rb +1 -1
- data/lib/action_view/helpers/tags/hidden_field.rb +0 -4
- data/lib/action_view/helpers/tags/time_field.rb +10 -1
- data/lib/action_view/helpers/tags/weekday_select.rb +27 -0
- data/lib/action_view/helpers/tags.rb +3 -2
- data/lib/action_view/helpers/text_helper.rb +24 -13
- data/lib/action_view/helpers/translation_helper.rb +1 -2
- data/lib/action_view/helpers/url_helper.rb +102 -77
- data/lib/action_view/helpers.rb +25 -25
- data/lib/action_view/lookup_context.rb +33 -52
- data/lib/action_view/model_naming.rb +1 -1
- data/lib/action_view/path_set.rb +16 -22
- data/lib/action_view/railtie.rb +14 -1
- data/lib/action_view/render_parser.rb +188 -0
- data/lib/action_view/renderer/abstract_renderer.rb +2 -2
- data/lib/action_view/renderer/partial_renderer.rb +0 -34
- data/lib/action_view/renderer/renderer.rb +4 -4
- data/lib/action_view/renderer/streaming_template_renderer.rb +3 -3
- data/lib/action_view/renderer/template_renderer.rb +6 -2
- data/lib/action_view/rendering.rb +2 -2
- data/lib/action_view/ripper_ast_parser.rb +198 -0
- data/lib/action_view/routing_url_for.rb +1 -1
- data/lib/action_view/template/error.rb +108 -13
- data/lib/action_view/template/handlers/erb.rb +6 -0
- data/lib/action_view/template/handlers.rb +3 -3
- data/lib/action_view/template/html.rb +3 -3
- data/lib/action_view/template/inline.rb +3 -3
- data/lib/action_view/template/raw_file.rb +3 -3
- data/lib/action_view/template/resolver.rb +84 -311
- data/lib/action_view/template/text.rb +3 -3
- data/lib/action_view/template/types.rb +14 -12
- data/lib/action_view/template.rb +10 -1
- data/lib/action_view/template_details.rb +66 -0
- data/lib/action_view/template_path.rb +64 -0
- data/lib/action_view/test_case.rb +6 -2
- data/lib/action_view/testing/resolvers.rb +11 -12
- data/lib/action_view/unbound_template.rb +33 -7
- data/lib/action_view.rb +3 -4
- metadata +25 -19
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 488edff5bf41873248138efbc0c8ee4ecd1809793a99ebe520870d35e2a6e459
|
4
|
+
data.tar.gz: 429fd7c60ef3fb02df47871d05a7289cfda25e21586928dc1accebaa45678a7d
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 3db204604fb84ce3ab96976aad76fffb4938a2ec6ad7f965b2dc59a785622888867f92df3282ae560d6fb594fecc215a1c18340329ea912bed58c74d457e6824
|
7
|
+
data.tar.gz: 7eb29f984ea723f25728f8ae0c06127b7728501e18e690b0b73972d34a3bd467783760c293d50bc474f1fba9ddc824c02678af7653edcab8a5703766a572b96f
|
data/CHANGELOG.md
CHANGED
@@ -1,141 +1,109 @@
|
|
1
|
-
## Rails
|
1
|
+
## Rails 7.0.0.alpha1 (September 15, 2021) ##
|
2
2
|
|
3
|
-
*
|
3
|
+
* Improves the performance of ActionView::Helpers::NumberHelper formatters by avoiding the use of
|
4
|
+
exceptions as flow control.
|
4
5
|
|
6
|
+
*Mike Dalessio*
|
5
7
|
|
6
|
-
|
7
|
-
|
8
|
-
* No changes.
|
9
|
-
|
10
|
-
|
11
|
-
## Rails 6.1.6 (May 09, 2022) ##
|
12
|
-
|
13
|
-
* No changes.
|
14
|
-
|
15
|
-
|
16
|
-
## Rails 6.1.5.1 (April 26, 2022) ##
|
17
|
-
|
18
|
-
* Fix and add protections for XSS in `ActionView::Helpers` and `ERB::Util`.
|
19
|
-
|
20
|
-
Escape dangerous characters in names of tags and names of attributes in the
|
21
|
-
tag helpers, following the XML specification. Rename the option
|
22
|
-
`:escape_attributes` to `:escape`, to simplify by applying the option to the
|
23
|
-
whole tag.
|
24
|
-
|
25
|
-
*Álvaro Martín Fraguas*
|
26
|
-
|
27
|
-
## Rails 6.1.5 (March 09, 2022) ##
|
28
|
-
|
29
|
-
* `preload_link_tag` properly inserts `as` attributes for files with `image` MIME
|
30
|
-
types, such as JPG or SVG.
|
8
|
+
* `preload_link_tag` properly inserts `as` attributes for files with `image` MIME types, such as JPG or SVG.
|
31
9
|
|
32
10
|
*Nate Berkopec*
|
33
11
|
|
34
|
-
* Add `
|
35
|
-
|
36
|
-
Fixes #42610.
|
37
|
-
|
38
|
-
*Ryan Baumann*
|
39
|
-
|
40
|
-
* Fix `current_page?` when URL has trailing slash.
|
41
|
-
|
42
|
-
This fixes the `current_page?` helper when the given URL has a trailing slash,
|
43
|
-
and is an absolute URL or also has query params.
|
44
|
-
|
45
|
-
Fixes #33956.
|
46
|
-
|
47
|
-
*Jonathan Hefner*
|
48
|
-
|
12
|
+
* Add `weekday_options_for_select` and `weekday_select` helper methods. Also adds `weekday_select` to `FormBuilder`.
|
49
13
|
|
50
|
-
|
14
|
+
*Drew Bragg*, *Dana Kashubeck*, *Kasper Timm Hansen*
|
51
15
|
|
52
|
-
*
|
16
|
+
* Add `caching?` helper that returns whether the current code path is being cached and `uncacheable!` to denote helper methods that can't participate in fragment caching.
|
53
17
|
|
18
|
+
*Ben Toews*, *John Hawthorn*, *Kasper Timm Hansen*, *Joel Hawksley*
|
54
19
|
|
55
|
-
|
20
|
+
* Add `include_seconds` option for `time_field`.
|
56
21
|
|
57
|
-
|
22
|
+
<%= form.time_field :foo, include_seconds: false %>
|
23
|
+
# => <input value="16:22" type="time" />
|
58
24
|
|
25
|
+
Default includes seconds:
|
59
26
|
|
60
|
-
|
27
|
+
<%= form.time_field :foo %>
|
28
|
+
# => <input value="16:22:01.440" type="time" />
|
61
29
|
|
62
|
-
|
30
|
+
This allows you to take advantage of [different rendering options](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/time#time_value_format) in some browsers.
|
63
31
|
|
32
|
+
*Alex Ghiculescu*
|
64
33
|
|
65
|
-
|
34
|
+
* Improve error messages when template file does not exist at absolute filepath.
|
66
35
|
|
67
|
-
*
|
36
|
+
*Ted Whang*
|
68
37
|
|
38
|
+
* Add `:country_code` option to `sms_to` for consistency with `phone_to`.
|
69
39
|
|
70
|
-
|
71
|
-
|
72
|
-
* No changes.
|
73
|
-
|
74
|
-
|
75
|
-
## Rails 6.1.4.2 (December 14, 2021) ##
|
76
|
-
|
77
|
-
* No changes.
|
78
|
-
|
79
|
-
|
80
|
-
## Rails 6.1.4.1 (August 19, 2021) ##
|
81
|
-
|
82
|
-
* No changes.
|
40
|
+
*Jonathan Hefner*
|
83
41
|
|
42
|
+
* OpenSSL constants are now used for Digest computations.
|
84
43
|
|
85
|
-
|
44
|
+
*Dirkjan Bussink*
|
86
45
|
|
87
46
|
* The `translate` helper now passes `default` values that aren't
|
88
47
|
translation keys through `I18n.translate` for interpolation.
|
89
48
|
|
90
49
|
*Jonathan Hefner*
|
91
50
|
|
92
|
-
*
|
93
|
-
|
94
|
-
*David Heinemeier Hansson*
|
95
|
-
|
96
|
-
* Allow both `current_page?(url_hash)` and `current_page?(**url_hash)` on Ruby 2.7.
|
51
|
+
* Adds option `extname` to `stylesheet_link_tag` to skip default
|
52
|
+
`.css` extension appended to the stylesheet path.
|
97
53
|
|
98
|
-
|
54
|
+
Before:
|
99
55
|
|
56
|
+
```ruby
|
57
|
+
stylesheet_link_tag "style.less"
|
58
|
+
# <link href="/stylesheets/style.less.scss" rel="stylesheet">
|
59
|
+
```
|
100
60
|
|
101
|
-
|
102
|
-
|
103
|
-
* No changes.
|
104
|
-
|
105
|
-
|
106
|
-
## Rails 6.1.3.1 (March 26, 2021) ##
|
107
|
-
|
108
|
-
* No changes.
|
109
|
-
|
110
|
-
|
111
|
-
## Rails 6.1.3 (February 17, 2021) ##
|
112
|
-
|
113
|
-
* No changes.
|
114
|
-
|
61
|
+
After:
|
115
62
|
|
116
|
-
|
63
|
+
```ruby
|
64
|
+
stylesheet_link_tag "style.less", extname: false, skip_pipeline: true, rel: "stylesheet/less"
|
65
|
+
# <link href="/stylesheets/style.less" rel="stylesheet/less">
|
66
|
+
```
|
117
67
|
|
118
|
-
*
|
68
|
+
*Abhay Nikam*
|
119
69
|
|
70
|
+
* Deprecate `render` locals to be assigned to instance variables.
|
120
71
|
|
121
|
-
|
72
|
+
*Petrik de Heus*
|
122
73
|
|
123
|
-
*
|
74
|
+
* Remove legacy default `media=screen` from `stylesheet_link_tag`.
|
124
75
|
|
76
|
+
*André Luis Leal Cardoso Junior*
|
125
77
|
|
126
|
-
|
78
|
+
* Change `ActionView::Helpers::FormBuilder#button` to transform `formmethod`
|
79
|
+
attributes into `_method="$VERB"` Form Data to enable varied same-form actions:
|
127
80
|
|
128
|
-
|
81
|
+
<%= form_with model: post, method: :put do %>
|
82
|
+
<%= form.button "Update" %>
|
83
|
+
<%= form.button "Delete", formmethod: :delete %>
|
84
|
+
<% end %>
|
85
|
+
<%# => <form action="posts/1">
|
86
|
+
=> <input type="hidden" name="_method" value="put">
|
87
|
+
=> <button type="submit">Update</button>
|
88
|
+
=> <button type="submit" formmethod="post" name="_method" value="delete">Delete</button>
|
89
|
+
=> </form>
|
90
|
+
%>
|
129
91
|
|
130
|
-
*
|
92
|
+
*Sean Doyle*
|
131
93
|
|
132
|
-
*
|
94
|
+
* Change `ActionView::Helpers::UrlHelper#button_to` to *always* render a
|
95
|
+
`<button>` element, regardless of whether or not the content is passed as
|
96
|
+
the first argument or as a block.
|
133
97
|
|
134
|
-
|
98
|
+
<%= button_to "Delete", post_path(@post), method: :delete %>
|
99
|
+
# => <form action="/posts/1"><input type="hidden" name="_method" value="delete"><button type="submit">Delete</button></form>
|
135
100
|
|
136
|
-
|
101
|
+
<%= button_to post_path(@post), method: :delete do %>
|
102
|
+
Delete
|
103
|
+
<% end %>
|
104
|
+
# => <form action="/posts/1"><input type="hidden" name="_method" value="delete"><button type="submit">Delete</button></form>
|
137
105
|
|
138
|
-
|
106
|
+
*Sean Doyle*, *Dusan Orlovic*
|
139
107
|
|
140
108
|
* Add `config.action_view.preload_links_header` to allow disabling of
|
141
109
|
the `Link` header being added by default when using `stylesheet_link_tag`
|
@@ -148,282 +116,46 @@
|
|
148
116
|
|
149
117
|
*Jonathan Hefner*
|
150
118
|
|
119
|
+
* Add `config.action_view.image_loading` to configure the default value of
|
120
|
+
the `image_tag` `:loading` option.
|
151
121
|
|
152
|
-
|
153
|
-
|
154
|
-
* SanitizeHelper.sanitized_allowed_attributes and SanitizeHelper.sanitized_allowed_tags
|
155
|
-
call safe_list_sanitizer's class method
|
156
|
-
|
157
|
-
Fixes #39586
|
158
|
-
|
159
|
-
*Taufiq Muhammadi*
|
160
|
-
|
161
|
-
* Change form_with to generate non-remote forms by default.
|
162
|
-
|
163
|
-
`form_with` would generate a remote form by default. This would confuse
|
164
|
-
users because they were forced to handle remote requests.
|
165
|
-
|
166
|
-
All new 6.1 applications will generate non-remote forms by default.
|
167
|
-
When upgrading a 6.0 application you can enable remote forms by default by
|
168
|
-
setting `config.action_view.form_with_generates_remote_forms` to `true`.
|
169
|
-
|
170
|
-
*Petrik de Heus*
|
171
|
-
|
172
|
-
* Yield translated strings to calls of `ActionView::FormBuilder#button`
|
173
|
-
when a block is given.
|
174
|
-
|
175
|
-
*Sean Doyle*
|
176
|
-
|
177
|
-
* Alias `ActionView::Helpers::Tags::Label::LabelBuilder#translation` to
|
178
|
-
`#to_s` so that `form.label` calls can yield that value to their blocks.
|
179
|
-
|
180
|
-
*Sean Doyle*
|
122
|
+
By setting `config.action_view.image_loading = "lazy"`, an application can opt in to
|
123
|
+
lazy loading images sitewide, without changing view code.
|
181
124
|
|
182
|
-
*
|
183
|
-
and make the original available as an alias.
|
125
|
+
*Jonathan Hefner*
|
184
126
|
|
185
|
-
|
186
|
-
|
127
|
+
* `ActionView::Helpers::FormBuilder#id` returns the value
|
128
|
+
of the `<form>` element's `id` attribute. With a `method` argument, returns
|
129
|
+
the `id` attribute for a form field with that name.
|
187
130
|
|
188
|
-
|
131
|
+
<%= form_for @post do |f| %>
|
132
|
+
<%# ... %>
|
189
133
|
|
190
|
-
|
191
|
-
|
192
|
-
|
193
|
-
|
194
|
-
tag.input type: 'checkbox', name: 'published', aria: {
|
195
|
-
invalid: @post.errors[:published].any?,
|
196
|
-
labelledby: ['published_context', 'published_label'],
|
197
|
-
describedby: { published_errors: @post.errors[:published].any? }
|
198
|
-
}
|
199
|
-
#=> <input
|
200
|
-
type="checkbox" name="published" aria-invalid="true"
|
201
|
-
aria-labelledby="published_context published_label"
|
202
|
-
aria-describedby="published_errors"
|
203
|
-
>
|
134
|
+
<% content_for :sticky_footer do %>
|
135
|
+
<%= form.button(form: f.id) %>
|
136
|
+
<% end %>
|
137
|
+
<% end %>
|
204
138
|
|
205
139
|
*Sean Doyle*
|
206
140
|
|
207
|
-
*
|
208
|
-
|
209
|
-
*Rafael Mendonça França*
|
210
|
-
|
211
|
-
* Remove deprecated `find_all_anywhere` from `ActionView::Resolver`.
|
212
|
-
|
213
|
-
*Rafael Mendonça França*
|
214
|
-
|
215
|
-
* Remove deprecated `formats` from `ActionView::Template::HTML`.
|
216
|
-
|
217
|
-
*Rafael Mendonça França*
|
218
|
-
|
219
|
-
* Remove deprecated `formats` from `ActionView::Template::RawFile`.
|
220
|
-
|
221
|
-
*Rafael Mendonça França*
|
222
|
-
|
223
|
-
* Remove deprecated `formats` from `ActionView::Template::Text`.
|
224
|
-
|
225
|
-
*Rafael Mendonça França*
|
226
|
-
|
227
|
-
* Remove deprecated `find_file` from `ActionView::PathSet`.
|
228
|
-
|
229
|
-
*Rafael Mendonça França*
|
230
|
-
|
231
|
-
* Remove deprecated `rendered_format` from `ActionView::LookupContext`.
|
232
|
-
|
233
|
-
*Rafael Mendonça França*
|
234
|
-
|
235
|
-
* Remove deprecated `find_file` from `ActionView::ViewPaths`.
|
141
|
+
* `ActionView::Helpers::FormBuilder#field_id` returns the value generated by
|
142
|
+
the FormBuilder for the given attribute name.
|
236
143
|
|
237
|
-
|
238
|
-
|
239
|
-
|
240
|
-
|
241
|
-
*Rafael Mendonça França*
|
242
|
-
|
243
|
-
* Remove deprecated support to pass an object that is not a `ActionView::LookupContext` as the first argument
|
244
|
-
in `ActionView::Base#initialize`.
|
245
|
-
|
246
|
-
*Rafael Mendonça França*
|
247
|
-
|
248
|
-
* Remove deprecated `format` argument `ActionView::Base#initialize`.
|
249
|
-
|
250
|
-
*Rafael Mendonça França*
|
251
|
-
|
252
|
-
* Remove deprecated `ActionView::Template#refresh`.
|
253
|
-
|
254
|
-
*Rafael Mendonça França*
|
255
|
-
|
256
|
-
* Remove deprecated `ActionView::Template#original_encoding`.
|
257
|
-
|
258
|
-
*Rafael Mendonça França*
|
259
|
-
|
260
|
-
* Remove deprecated `ActionView::Template#variants`.
|
261
|
-
|
262
|
-
*Rafael Mendonça França*
|
263
|
-
|
264
|
-
* Remove deprecated `ActionView::Template#formats`.
|
265
|
-
|
266
|
-
*Rafael Mendonça França*
|
267
|
-
|
268
|
-
* Remove deprecated `ActionView::Template#virtual_path=`.
|
269
|
-
|
270
|
-
*Rafael Mendonça França*
|
271
|
-
|
272
|
-
* Remove deprecated `ActionView::Template#updated_at`.
|
273
|
-
|
274
|
-
*Rafael Mendonça França*
|
275
|
-
|
276
|
-
* Remove deprecated `updated_at` argument required on `ActionView::Template#initialize`.
|
277
|
-
|
278
|
-
*Rafael Mendonça França*
|
279
|
-
|
280
|
-
* Make `locals` argument required on `ActionView::Template#initialize`.
|
281
|
-
|
282
|
-
*Rafael Mendonça França*
|
283
|
-
|
284
|
-
* Remove deprecated `ActionView::Template.finalize_compiled_template_methods`.
|
285
|
-
|
286
|
-
*Rafael Mendonça França*
|
287
|
-
|
288
|
-
* Remove deprecated `config.action_view.finalize_compiled_template_methods`
|
289
|
-
|
290
|
-
*Rafael Mendonça França*
|
291
|
-
|
292
|
-
* Remove deprecated support to calling `ActionView::ViewPaths#with_fallback` with a block.
|
293
|
-
|
294
|
-
*Rafael Mendonça França*
|
295
|
-
|
296
|
-
* Remove deprecated support to passing absolute paths to `render template:`.
|
297
|
-
|
298
|
-
*Rafael Mendonça França*
|
299
|
-
|
300
|
-
* Remove deprecated support to passing relative paths to `render file:`.
|
301
|
-
|
302
|
-
*Rafael Mendonça França*
|
303
|
-
|
304
|
-
* Remove support to template handlers that don't accept two arguments.
|
305
|
-
|
306
|
-
*Rafael Mendonça França*
|
307
|
-
|
308
|
-
* Remove deprecated pattern argument in `ActionView::Template::PathResolver`.
|
309
|
-
|
310
|
-
*Rafael Mendonça França*
|
311
|
-
|
312
|
-
* Remove deprecated support to call private methods from object in some view helpers.
|
313
|
-
|
314
|
-
*Rafael Mendonça França*
|
315
|
-
|
316
|
-
* `ActionView::Helpers::TranslationHelper#translate` accepts a block, yielding
|
317
|
-
the translated text and the fully resolved translation key:
|
318
|
-
|
319
|
-
<%= translate(".relative_key") do |translation, resolved_key| %>
|
320
|
-
<span title="<%= resolved_key %>"><%= translation %></span>
|
144
|
+
<%= form_for @post do |f| %>
|
145
|
+
<%= f.label :title %>
|
146
|
+
<%= f.text_field :title, aria: { describedby: f.field_id(:title, :error) } %>
|
147
|
+
<%= tag.span("is blank", id: f.field_id(:title, :error) %>
|
321
148
|
<% end %>
|
322
149
|
|
323
150
|
*Sean Doyle*
|
324
151
|
|
325
|
-
*
|
326
|
-
|
327
|
-
virtual_path keyword arguments found in CacheHelper as they no longer possess
|
328
|
-
any function following 1581cab.
|
329
|
-
|
330
|
-
Fixes #38984.
|
331
|
-
|
332
|
-
*Aaron Lipman*
|
333
|
-
|
334
|
-
* Deprecate `config.action_view.raise_on_missing_translations` in favor of
|
335
|
-
`config.i18n.raise_on_missing_translations`.
|
336
|
-
|
337
|
-
New generalized configuration option now determines whether an error should be raised
|
338
|
-
for missing translations in controllers and views.
|
339
|
-
|
340
|
-
*fatkodima*
|
341
|
-
|
342
|
-
* Instrument layout rendering in `TemplateRenderer#render_with_layout` as `render_layout.action_view`,
|
343
|
-
and include (when necessary) the layout's virtual path in notification payloads for collection and partial renders.
|
344
|
-
|
345
|
-
*Zach Kemp*
|
346
|
-
|
347
|
-
* `ActionView::Base.annotate_rendered_view_with_filenames` annotates HTML output with template file names.
|
348
|
-
|
349
|
-
*Joel Hawksley*, *Aaron Patterson*
|
350
|
-
|
351
|
-
* `ActionView::Helpers::TranslationHelper#translate` returns nil when
|
352
|
-
passed `default: nil` without a translation matching `I18n#translate`.
|
353
|
-
|
354
|
-
*Stefan Wrobel*
|
355
|
-
|
356
|
-
* `OptimizedFileSystemResolver` prefers template details in order of locale,
|
357
|
-
formats, variants, handlers.
|
358
|
-
|
359
|
-
*Iago Pimenta*
|
360
|
-
|
361
|
-
* Added `class_names` helper to create a CSS class value with conditional classes.
|
362
|
-
|
363
|
-
*Joel Hawksley*, *Aaron Patterson*
|
364
|
-
|
365
|
-
* Add support for conditional values to TagBuilder.
|
366
|
-
|
367
|
-
*Joel Hawksley*
|
152
|
+
* Add `tag.attributes` to transform a Hash into HTML Attributes, ready to be
|
153
|
+
interpolated into ERB.
|
368
154
|
|
369
|
-
|
155
|
+
<input <%= tag.attributes(type: :text, aria: { label: "Search" }) %> >
|
156
|
+
# => <input type="text" aria-label="Search">
|
370
157
|
|
371
|
-
|
372
|
-
@post = Post.new
|
373
|
-
@post.category = nil
|
374
|
-
|
375
|
-
# Before
|
376
|
-
select("post", "category", none: nil, programming: 1, economics: 2)
|
377
|
-
# =>
|
378
|
-
# <select name="post[category]" id="post_category">
|
379
|
-
# <option value="">none</option>
|
380
|
-
# <option value="1">programming</option>
|
381
|
-
# <option value="2">economics</option>
|
382
|
-
# </select>
|
383
|
-
|
384
|
-
# After
|
385
|
-
select("post", "category", none: nil, programming: 1, economics: 2)
|
386
|
-
# =>
|
387
|
-
# <select name="post[category]" id="post_category">
|
388
|
-
# <option selected="selected" value="">none</option>
|
389
|
-
# <option value="1">programming</option>
|
390
|
-
# <option value="2">economics</option>
|
391
|
-
# </select>
|
392
|
-
```
|
393
|
-
|
394
|
-
*bogdanvlviv*
|
395
|
-
|
396
|
-
* Log lines for partial renders and started template renders are now
|
397
|
-
emitted at the `DEBUG` level instead of `INFO`.
|
398
|
-
|
399
|
-
Completed template renders are still logged at the `INFO` level.
|
400
|
-
|
401
|
-
*DHH*
|
402
|
-
|
403
|
-
* ActionView::Helpers::SanitizeHelper: support rails-html-sanitizer 1.1.0.
|
404
|
-
|
405
|
-
*Juanito Fatas*
|
406
|
-
|
407
|
-
* Added `phone_to` helper method to create a link from mobile numbers.
|
408
|
-
|
409
|
-
*Pietro Moro*
|
410
|
-
|
411
|
-
* annotated_source_code returns an empty array so TemplateErrors without a
|
412
|
-
template in the backtrace are surfaced properly by DebugExceptions.
|
413
|
-
|
414
|
-
*Guilherme Mansur*, *Kasper Timm Hansen*
|
415
|
-
|
416
|
-
* Add autoload for SyntaxErrorInTemplate so syntax errors are correctly raised by DebugExceptions.
|
417
|
-
|
418
|
-
*Guilherme Mansur*, *Gannon McGibbon*
|
419
|
-
|
420
|
-
* `RenderingHelper` supports rendering objects that `respond_to?` `:render_in`.
|
421
|
-
|
422
|
-
*Joel Hawksley*, *Natasha Umer*, *Aaron Patterson*, *Shawn Allen*, *Emily Plummer*, *Diana Mounter*, *John Hawthorn*, *Nathan Herald*, *Zaid Zawaideh*, *Zach Ahn*
|
423
|
-
|
424
|
-
* Fix `select_tag` so that it doesn't change `options` when `include_blank` is present.
|
425
|
-
|
426
|
-
*Younes SERRAJ*
|
158
|
+
*Sean Doyle*
|
427
159
|
|
428
160
|
|
429
|
-
Please check [6-
|
161
|
+
Please check [6-1-stable](https://github.com/rails/rails/blob/6-1-stable/actionview/CHANGELOG.md) for previous changes.
|
data/MIT-LICENSE
CHANGED
@@ -1,4 +1,4 @@
|
|
1
|
-
Copyright (c) 2004-
|
1
|
+
Copyright (c) 2004-2021 David Heinemeier Hansson
|
2
2
|
|
3
3
|
Permission is hereby granted, free of charge, to any person obtaining
|
4
4
|
a copy of this software and associated documentation files (the
|
@@ -18,3 +18,4 @@ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
|
18
18
|
LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
19
19
|
OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
20
20
|
WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
21
|
+
|
data/lib/action_view/base.rb
CHANGED
@@ -9,7 +9,7 @@ require "action_view/context"
|
|
9
9
|
require "action_view/template"
|
10
10
|
require "action_view/lookup_context"
|
11
11
|
|
12
|
-
module ActionView
|
12
|
+
module ActionView # :nodoc:
|
13
13
|
# = Action View Base
|
14
14
|
#
|
15
15
|
# Action View templates can be written in several ways.
|
@@ -179,7 +179,7 @@ module ActionView #:nodoc:
|
|
179
179
|
ActionView::Resolver.caching = value
|
180
180
|
end
|
181
181
|
|
182
|
-
def xss_safe?
|
182
|
+
def xss_safe? # :nodoc:
|
183
183
|
true
|
184
184
|
end
|
185
185
|
|
@@ -227,7 +227,7 @@ module ActionView #:nodoc:
|
|
227
227
|
|
228
228
|
# :startdoc:
|
229
229
|
|
230
|
-
def initialize(lookup_context, assigns, controller)
|
230
|
+
def initialize(lookup_context, assigns, controller) # :nodoc:
|
231
231
|
@_config = ActiveSupport::InheritableOptions.new
|
232
232
|
|
233
233
|
@lookup_context = lookup_context
|
data/lib/action_view/buffers.rb
CHANGED
@@ -18,7 +18,7 @@ module ActionView
|
|
18
18
|
# sbuf << 5
|
19
19
|
# puts sbuf # => "hello\u0005"
|
20
20
|
#
|
21
|
-
class OutputBuffer < ActiveSupport::SafeBuffer
|
21
|
+
class OutputBuffer < ActiveSupport::SafeBuffer # :nodoc:
|
22
22
|
def initialize(*)
|
23
23
|
super
|
24
24
|
encode!
|
@@ -38,7 +38,7 @@ module ActionView
|
|
38
38
|
alias :safe_append= :safe_concat
|
39
39
|
end
|
40
40
|
|
41
|
-
class StreamingBuffer
|
41
|
+
class StreamingBuffer # :nodoc:
|
42
42
|
def initialize(block)
|
43
43
|
@block = block
|
44
44
|
end
|
@@ -4,49 +4,63 @@ module ActionView
|
|
4
4
|
class CacheExpiry
|
5
5
|
class Executor
|
6
6
|
def initialize(watcher:)
|
7
|
-
@
|
7
|
+
@execution_lock = Concurrent::ReadWriteLock.new
|
8
|
+
@cache_expiry = ViewModificationWatcher.new(watcher: watcher) do
|
9
|
+
clear_cache
|
10
|
+
end
|
8
11
|
end
|
9
12
|
|
10
|
-
def
|
11
|
-
|
13
|
+
def run
|
14
|
+
ActiveSupport::Dependencies.interlock.permit_concurrent_loads do
|
15
|
+
@cache_expiry.execute_if_updated
|
16
|
+
@execution_lock.acquire_read_lock
|
17
|
+
end
|
12
18
|
end
|
13
|
-
end
|
14
|
-
|
15
|
-
def initialize(watcher:)
|
16
|
-
@watched_dirs = nil
|
17
|
-
@watcher_class = watcher
|
18
|
-
@watcher = nil
|
19
|
-
@mutex = Mutex.new
|
20
|
-
end
|
21
19
|
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
return if watched_dirs.empty?
|
20
|
+
def complete(_)
|
21
|
+
@execution_lock.release_read_lock
|
22
|
+
end
|
26
23
|
|
27
|
-
|
28
|
-
|
29
|
-
@
|
30
|
-
|
24
|
+
private
|
25
|
+
def clear_cache
|
26
|
+
@execution_lock.with_write_lock do
|
27
|
+
ActionView::LookupContext::DetailsKey.clear
|
31
28
|
end
|
32
|
-
@watcher.execute
|
33
|
-
else
|
34
|
-
@watcher.execute_if_updated
|
35
29
|
end
|
36
|
-
end
|
37
|
-
end
|
38
|
-
|
39
|
-
def clear_cache
|
40
|
-
ActionView::LookupContext::DetailsKey.clear
|
41
30
|
end
|
42
31
|
|
43
|
-
|
44
|
-
def
|
45
|
-
|
32
|
+
class ViewModificationWatcher
|
33
|
+
def initialize(watcher:, &block)
|
34
|
+
@watched_dirs = nil
|
35
|
+
@watcher_class = watcher
|
36
|
+
@watcher = nil
|
37
|
+
@mutex = Mutex.new
|
38
|
+
@block = block
|
46
39
|
end
|
47
40
|
|
48
|
-
def
|
49
|
-
|
41
|
+
def execute_if_updated
|
42
|
+
@mutex.synchronize do
|
43
|
+
watched_dirs = dirs_to_watch
|
44
|
+
return if watched_dirs.empty?
|
45
|
+
|
46
|
+
if watched_dirs != @watched_dirs
|
47
|
+
@watched_dirs = watched_dirs
|
48
|
+
@watcher = @watcher_class.new([], watched_dirs, &@block)
|
49
|
+
@watcher.execute
|
50
|
+
else
|
51
|
+
@watcher.execute_if_updated
|
52
|
+
end
|
53
|
+
end
|
50
54
|
end
|
55
|
+
|
56
|
+
private
|
57
|
+
def dirs_to_watch
|
58
|
+
all_view_paths.grep(FileSystemResolver).map!(&:path).tap(&:uniq!).sort!
|
59
|
+
end
|
60
|
+
|
61
|
+
def all_view_paths
|
62
|
+
ActionView::ViewPaths.all_view_paths.flat_map(&:paths)
|
63
|
+
end
|
64
|
+
end
|
51
65
|
end
|
52
66
|
end
|