add a marker and a notice if the table did not contain any rows
[scpubgit/JSON-Tree-Viewer.git] / br.pl
diff --git a/br.pl b/br.pl
index 2c63bd1..f900028 100644 (file)
--- a/br.pl
+++ b/br.pl
@@ -40,7 +40,11 @@ sub dispatch_request {
     },
   },
   sub (/**/) {
-    $self->structure(split '/', $_[1]);
+    $self->structure(map {
+      s{\\/}{/}g;
+      s{\\\\}{\\}g;
+      $_;
+    } split qr{(?<!\\)/}, $_[1]);
   },
 }
 
@@ -155,11 +159,15 @@ sub mangle_structure {
 sub link_to {
   my ($self, @to) = @_;
   use HTML::Tags;
-  my @link = map uri_escape(uri_escape($_)), @to;
+  my @link = map {
+    s{\\}{\\\\}g;
+    s{/}{\\/}g;
+    $_;
+  } @to;
   my $link = join('/', @link, '');
   my $to = $to[-1];
   my $html = join '', HTML::Tags::to_html_string(
-    <a href="${link}">, "Explore $to", </a>
+    <a href="./${link}">, "Explore $to", </a>
   );
   return \$html;
 }
@@ -171,7 +179,7 @@ sub descend {
     $target = $self->json->decode(scalar $target->all);
   }
   return $target unless @path;
-  my $step = uri_unescape(uri_unescape( shift @path));
+  my $step = shift @path;
   $self->descend($target->{$step}, @path);
 }
 
@@ -187,13 +195,17 @@ sub render_table {
       <html>, <body>, "\n",
       ($data->{wrapper}||sub{@_})->(
         '', <table>, "\n",
-          (map { my $el = $_;
-            '  ', ($el->{key} eq '__error__') ? <tr class="error"> : <tr>,
-              (map {
-                <td>, $self->render_el($el, $_, $el->{$_}), </td>
-              } @{$data->{columns}}),
-            </tr>, "\n"
-          } @rows),
+          @rows
+          ? (map { my $el = $_;
+              '  ', ($el->{key} eq '__error__') ? <tr class="error"> : <tr>,
+                (map {
+                  <td>, $self->render_el($el, $_, $el->{$_}), </td>
+                } @{$data->{columns}}),
+              </tr>, "\n"
+            } @rows)
+          : (<tr class="no-rows">,
+              <td>, 'No entries in this data structure', </td>,
+            </tr>),
         '', </table>, "\n",
       ),
       </body>, </html>, "\n",
@@ -210,9 +222,11 @@ sub render_el {
       } elsif ($whole->{name}) {
         return $self->link_to($whole->{name}, $key);
       }
-      $part = '(complex)';
     }
-    return join(', ', @$part);
+    return join ', ', @$part
+      if @$part < 5;
+    use HTML::Tags;
+    return <ul>, (map { (<li>, $_, </li>) } @$part), </ul>;
   }
   if (ref($part) eq 'HASH') {
     if ($whole->{key}) {