From 7a0a35d895bea51f6219e9e1d53e57bd9122d7fc Mon Sep 17 00:00:00 2001 From: Johny Ho Date: Tue, 30 Jul 2024 19:16:56 -0400 Subject: [PATCH] Additional implementation details for key override This adds a helpful note to the change key format section in case someone REALLY wants to change the way keys are formatted. --- README.md | 26 ++++++++++++++++++++++---- 1 file changed, 22 insertions(+), 4 deletions(-) diff --git a/README.md b/README.md index 9672664..7d0fb16 100644 --- a/README.md +++ b/README.md @@ -585,8 +585,10 @@ json.flash flash.to_h will render Layout first, then the template when `yield json` is used. ## Change key format -By default, keys are not formatted. If you want to change this behavior, -override it in an initializer: +By default, keys are not formatted. This is intentional. By being explicity with your keys, +it makes your views quicker and more easily searchable when working in Javascript land. + +If you must change this behavior, override it in an initializer and cache the value: ```ruby # default behavior @@ -607,7 +609,15 @@ Props::BaseWithExtensions.class_eval do # # -> { "firstValue" => "first", "secondValue" => "second" } def key_format(key) - key.to_s.camelize(:lower) + @key_cache ||= {} + @key_cache[key] ||= key.to_s.camelize(:lower) + @key_cache[key] + end + + def result! + result = super + @key_cache = {} + result end end @@ -618,7 +628,15 @@ Props::BaseWithExtensions.class_eval do # # -> { "first_value" => "first", "second_value" => "second" } def key_format(key) - key.to_s.underscore + @key_cache ||= {} + @key_cache[key] ||= key.to_s.underscore + @key_cache[key] + end + + def result! + result = super + @key_cache = {} + result end end ```