X-Git-Url: https://git.decadent.org.uk/gitweb/?a=blobdiff_plain;f=templates%2Ffactory%2Fmacros;fp=templates%2Ffactory%2Fmacros;h=afa2a74952c39db5f997f4d82d1278d3b2377021;hb=1fb6cf1887bddb2a3a003d6e148a0c016ea780b0;hp=367d74faaeaea8e69bfcab9163754694e03c01f1;hpb=271fd90b8a1b9f843853601a75a1334407ff87c4;p=maypole.git diff --git a/templates/factory/macros b/templates/factory/macros index 367d74f..afa2a74 100644 --- a/templates/factory/macros +++ b/templates/factory/macros @@ -117,3 +117,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 %] +
[% item.$string %]
+ [% INCLUDE navbar %] + + + + + + [% FOR col = classmetadata.columns.list; + NEXT IF col == "id" OR col == string; + NEXT UNLESS item.$col; + %] +[%# + +=for doc + +It gets the displayable form of a column's name from the hash returned +from the C method: + +#%] + + + + + [% END; %] +
[% 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 method, or returns the object's ID +if there is no C method or other stringification method defined. + +=cut + +#%] +
+[% END %]