X-Git-Url: https://git.decadent.org.uk/gitweb/?a=blobdiff_plain;f=templates%2Ffactory%2Fmacros;h=8743afc4d1fe53b7e7e9d83abda195288a365395;hb=8b68aa68ac5e83bc439d16c1fda0fb3870ee246c;hp=95dc9730e4a4b31f632f164a84c8a0d0a7d1ab8f;hpb=abd21e88bc4d622a7c43c6d04db28be75a4e7c5b;p=maypole.git
diff --git a/templates/factory/macros b/templates/factory/macros
index 95dc973..8743afc 100644
--- a/templates/factory/macros
+++ b/templates/factory/macros
@@ -7,7 +7,7 @@ system.
=head2 link
-This creates an to a command in the Apache::MVC system by
catenating the base URL, table, command, and any arguments.
#%]
@@ -62,7 +62,8 @@ for some.
ELSIF col == item.stringify_column;
maybe_link_view(item);
ELSE;
- maybe_link_view(item.$col);
+ accessor = item.accessor_name(col);
+ maybe_link_view(item.$accessor);
END;
"";
END;
@@ -117,3 +118,57 @@ MACRO test_xxxx(myblock) BLOCK;
END;
END;
%]
+[%#
+
+=head2 view_item
+
+This takes an object and and displays its properties in a table.
+
+=cut
+
+#%]
+[% MACRO view_item(item) BLOCK; %]
+ [% SET string = item.stringify_column %]
+
[% classmetadata.colnames.$string %] | +[% item.$string %] | +
[% classmetadata.colnames.$col; %] | +
+ [% IF col == "url" && item.url; # Possibly too much magic.
+ ' '; item.url; '';
+ ELSE;
+ maybe_link_view(item.$col);
+ END; %]
+[%#
+
+This tests whether or not the returned value is an object, and if so,
+creates a link to a page viewing that object; if not, it just displays
+the text as normal. The object is linked using its stringified name;
+by default this calls the C |
+