fix calendar popup for weirdly named fields in RT, for the quotes around custom field...
authorivan <ivan>
Wed, 21 Jul 2010 02:06:44 +0000 (02:06 +0000)
committerivan <ivan>
Wed, 21 Jul 2010 02:06:44 +0000 (02:06 +0000)
FS/FS/Mason.pm
rt/share/html/Elements/SelectDate

index 5d860f2..0f14150 100644 (file)
@@ -480,15 +480,17 @@ sub mason_interps {
 
   my $html_defang = new HTML::Defang (%defang_opts);
 
+  my $js_string_sub = sub {
+    #${$_[0]} =~ s/(['\\\n])/'\\'.($1 eq "\n" ? 'n' : $1)/ge;
+    ${$_[0]} =~ s/(['\\])/\\$1/g;
+    ${$_[0]} =~ s/\r/\\r/g;
+    ${$_[0]} =~ s/\n/\\n/g;
+    ${$_[0]} = "'". ${$_[0]}. "'";
+  };
+
   my $fs_interp = new HTML::Mason::Interp (
     %interp,
-    escape_flags => { 'js_string' => sub {
-                        #${$_[0]} =~ s/(['\\\n])/'\\'.($1 eq "\n" ? 'n' : $1)/ge;
-                        ${$_[0]} =~ s/(['\\])/\\$1/g;
-                        ${$_[0]} =~ s/\r/\\r/g;
-                        ${$_[0]} =~ s/\n/\\n/g;
-                        ${$_[0]} = "'". ${$_[0]}. "'";
-                      },
+    escape_flags => { 'js_string' => $js_string_sub,
                       'defang'    => sub {
                         ${$_[0]} = $html_defang->defang(${$_[0]});
                       },
@@ -500,7 +502,9 @@ sub mason_interps {
 
   my $rt_interp = new HTML::Mason::Interp (
     %interp,
-    escape_flags => { 'h' => \&RT::Interface::Web::EscapeUTF8 },
+    escape_flags => { 'h'         => \&RT::Interface::Web::EscapeUTF8,
+                      'js_string' => $js_string_sub,
+                    },
     compiler     => HTML::Mason::Compiler::ToObject->new(
                       default_escape_flags => 'h',
                       allow_globals        => [qw(%session)],
index 183086f..46092ce 100755 (executable)
 <IMG SRC="<%$fsurl%>images/calendar.png" ID="<% $Name %>_date_button" STYLE="cursor: pointer" TITLE="Select date">
 <script type="text/javascript">
 Calendar.setup({
-    inputField: "<%$Name%>",
+    inputField: <% $Name |n,js_string %>,
 % if ( defined($ShowTime) && $ShowTime ) {
     ifFormat:   "%Y-%m-%d %H:%M",
     showsTime:  true,
 % } else {
     ifFormat:   "%Y-%m-%d",
 % }
-    button:     "<%$Name%>_date_button",
+    button:     <% $Name.'_date_button' |n,js_string %>,
 });
 </script>
 <%init>