Difference between revisions of "API:EPrints/DataObj/Document"
| Line 10: | Line 10: | ||
| '''EPrints::DataObj::Document''' - A single format of a record. | '''EPrints::DataObj::Document''' - A single format of a record. | ||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
| <h4><span style='display:none'>User Comments</span></h4> | <h4><span style='display:none'>User Comments</span></h4> | ||
| Line 143: | Line 91: | ||
| ===security (namedset)=== | ===security (namedset)=== | ||
| − | The security type of this document - who can view it. One of the types of the  | + | The security type of this document - who can view it. One of the types of the dataset "security". | 
| <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
| Line 150: | Line 98: | ||
| − | <!-- Pod2Wiki= | + | <!-- Pod2Wiki=item_main --></div> | 
| − | === | + | ===main (text)=== | 
| − | The  | + | The file which we should link to. For something like a PDF file this is the only file. For an HTML document with images it would be the name of the actual HTML file. | 
| <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
| Line 160: | Line 108: | ||
| − | <!-- Pod2Wiki= | + | <!-- Pod2Wiki=item_documents --></div> | 
| − | === | + | ===documents (subobject, multiple)=== | 
| + | |||
| + | A virtual field which represents the list of Documents which are part of this record. | ||
| + | |||
| + | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
| + | <h4><span style='display:none'>User Comments</span></h4> | ||
| + | <!-- Edit below this comment --> | ||
| − | |||
| + | <!-- Pod2Wiki=head_methods --></div> | ||
| + | ==METHODS== | ||
| <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
| <h4><span style='display:none'>User Comments</span></h4> | <h4><span style='display:none'>User Comments</span></h4> | ||
| Line 170: | Line 125: | ||
| − | <!-- Pod2Wiki= | + | <!-- Pod2Wiki=item_get_system_field_info --></div> | 
| − | === | + | ===$metadata = EPrints::DataObj::Document->get_system_field_info=== | 
| − | + | Return an array describing the system metadata of the Document dataset. | |
| <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
| Line 180: | Line 135: | ||
| − | <!-- Pod2Wiki= | + | <!-- Pod2Wiki=item_get_dataset_id --></div> | 
| − | === | + | ===$dataset = EPrints::DataObj::Document->get_dataset_id=== | 
| − | + | Returns the id of the [[API:EPrints/DataSet|EPrints::DataSet]] object to which this record belongs. | |
| <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
| Line 190: | Line 145: | ||
| − | <!-- Pod2Wiki= | + | <!-- Pod2Wiki=item_get_defaults --></div> | 
| − | == | + | ===$defaults = EPrints::DataObj::Document->get_defaults( $session, $data )=== | 
| + | |||
| + | Return default values for this object based on the starting data. | ||
| + | |||
| <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
| <h4><span style='display:none'>User Comments</span></h4> | <h4><span style='display:none'>User Comments</span></h4> | ||
| Line 201: | Line 159: | ||
| Attempt to clone this document. Both the document metadata and the actual files. The clone will be associated with the given EPrint. | Attempt to clone this document. Both the document metadata and the actual files. The clone will be associated with the given EPrint. | ||
| + | |||
| + | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
| + | <h4><span style='display:none'>User Comments</span></h4> | ||
| + | <!-- Edit below this comment --> | ||
| + | |||
| + | |||
| + | <!-- Pod2Wiki=item_remove --></div> | ||
| + | ===$success = $doc->remove=== | ||
| + | |||
| + | Attempt to completely delete this document | ||
| <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
| Line 213: | Line 181: | ||
| This is a synonym for get_parent(). | This is a synonym for get_parent(). | ||
| + | |||
| + | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
| + | <h4><span style='display:none'>User Comments</span></h4> | ||
| + | <!-- Edit below this comment --> | ||
| + | |||
| + | |||
| + | <!-- Pod2Wiki=item_get_baseurl --></div> | ||
| + | ===$url = $doc->get_baseurl( [$staff] )=== | ||
| + | |||
| + | Return the base URL of the document. Overrides the stub in DataObj. $staff is currently ignored. | ||
| <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
| Line 232: | Line 210: | ||
| ===$url = $doc->get_url( [$file] )=== | ===$url = $doc->get_url( [$file] )=== | ||
| − | Return the full URL of the document.   | + | Return the full URL of the document. Overrides the stub in DataObj. | 
| If file is not specified then the "main" file is used. | If file is not specified then the "main" file is used. | ||
| Line 271: | Line 249: | ||
| − | <!-- Pod2Wiki= | + | <!-- Pod2Wiki=item_set_main --></div> | 
| − | ===$ | + | ===$doc->set_main( $main_file )=== | 
| + | |||
| + | Sets the main file. Won't affect the database until a $doc->commit(). | ||
| + | |||
| + | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
| + | <h4><span style='display:none'>User Comments</span></h4> | ||
| + | <!-- Edit below this comment --> | ||
| + | |||
| + | |||
| + | <!-- Pod2Wiki=item_get_main --></div> | ||
| + | ===$filename = $doc->get_main=== | ||
| − | + | Return the name of the main file in this document. | |
| <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
| Line 281: | Line 269: | ||
| − | <!-- Pod2Wiki= | + | <!-- Pod2Wiki=item_set_format --></div> | 
| − | ===$doc-> | + | ===$doc->set_format( $format )=== | 
| + | |||
| + | Set format. Won't affect the database until a commit(). Just an alias  for $doc->set_value( "format" , $format ); | ||
| + | |||
| + | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
| + | <h4><span style='display:none'>User Comments</span></h4> | ||
| + | <!-- Edit below this comment --> | ||
| + | |||
| − | + | <!-- Pod2Wiki=item_set_format_desc --></div> | |
| + | ===$doc->set_format_desc( $format_desc )=== | ||
| − | + | Set the format description.  Won't affect the database until a commit(). Just an alias for $doc->set_value( "format_desc" , $format_desc ); | |
| <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
| Line 311: | Line 307: | ||
| If $preserve_path then keep the filename as is (including subdirs and spaces) | If $preserve_path then keep the filename as is (including subdirs and spaces) | ||
| + | |||
| + | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
| + | <h4><span style='display:none'>User Comments</span></h4> | ||
| + | <!-- Edit below this comment --> | ||
| + | |||
| + | |||
| + | <!-- Pod2Wiki=item_sanitise --></div> | ||
| + | ===$cleanfilename = sanitise( $filename )=== | ||
| + | |||
| + | Return just the filename (no leading path) and convert any naughty characters to underscore. | ||
| <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
| Line 359: | Line 365: | ||
| This (by default) uses wget. The details can be configured in SystemSettings. | This (by default) uses wget. The details can be configured in SystemSettings. | ||
| + | |||
| + | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
| + | <h4><span style='display:none'>User Comments</span></h4> | ||
| + | <!-- Edit below this comment --> | ||
| + | |||
| + | |||
| + | <!-- Pod2Wiki=item_commit --></div> | ||
| + | ===$success = $doc->commit=== | ||
| + | |||
| + | Commit any changes that have been made to this object to the database. | ||
| + | |||
| + | Calls "set_document_automatic_fields" in the ArchiveConfig first to set any automatic fields that may be needed. | ||
| + | |||
| + | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
| + | <h4><span style='display:none'>User Comments</span></h4> | ||
| + | <!-- Edit below this comment --> | ||
| + | |||
| + | |||
| + | <!-- Pod2Wiki=item_validate --></div> | ||
| + | ===$problems = $doc->validate( [$for_archive] )=== | ||
| + | |||
| + | Return an array of XHTML DOM objects describing validation problems with the entire document, including the metadata and repository config specific requirements. | ||
| + | |||
| + | A reference to an empty array indicates no problems. | ||
| + | |||
| + | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
| + | <h4><span style='display:none'>User Comments</span></h4> | ||
| + | <!-- Edit below this comment --> | ||
| + | |||
| + | |||
| + | <!-- Pod2Wiki=item_get_type --></div> | ||
| + | ===$type = $doc->get_type=== | ||
| + | |||
| + | Return the type of this document. | ||
| + | |||
| + | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
| + | <h4><span style='display:none'>User Comments</span></h4> | ||
| + | <!-- Edit below this comment --> | ||
| + | |||
| + | |||
| + | <!-- Pod2Wiki=item_files_modified --></div> | ||
| + | ===$doc->files_modified=== | ||
| + | |||
| + | This method does all the things that need doing when a file has been modified. | ||
| + | |||
| + | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
| + | <h4><span style='display:none'>User Comments</span></h4> | ||
| + | <!-- Edit below this comment --> | ||
| + | |||
| + | |||
| + | <!-- Pod2Wiki=item_rehash --></div> | ||
| + | ===$doc->rehash=== | ||
| + | |||
| + | Recalculate the hash value of the document. Uses MD5 of the files (in alphabetic order), but can use user specified hashing function instead. | ||
| + | |||
| + | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
| + | <h4><span style='display:none'>User Comments</span></h4> | ||
| + | <!-- Edit below this comment --> | ||
| + | |||
| + | |||
| + | <!-- Pod2Wiki=item_make_indexcodes --></div> | ||
| + | ===$doc = $doc->make_indexcodes()=== | ||
| + | |||
| + | Make the indexcodes document for this document. Returns the generated document or undef on failure. | ||
| + | |||
| + | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
| + | <h4><span style='display:none'>User Comments</span></h4> | ||
| + | <!-- Edit below this comment --> | ||
| + | |||
| + | |||
| + | <!-- Pod2Wiki=item_remove_indexcodes --></div> | ||
| + | ===$doc = $doc->remove_indexcodes()=== | ||
| + | |||
| + | Remove any documents containing index codes for this document. Returns the number of documents removed. | ||
| + | |||
| + | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
| + | <h4><span style='display:none'>User Comments</span></h4> | ||
| + | <!-- Edit below this comment --> | ||
| + | |||
| + | |||
| + | <!-- Pod2Wiki=item_cache_file --></div> | ||
| + | ===$filename = $doc->cache_file( $suffix );=== | ||
| + | |||
| + | Return a cache filename for this document with the givven suffix. | ||
| + | |||
| + | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
| + | <h4><span style='display:none'>User Comments</span></h4> | ||
| + | <!-- Edit below this comment --> | ||
| + | |||
| + | |||
| + | <!-- Pod2Wiki=item_render_icon_link --></div> | ||
| + | ===$frag = $doc->render_icon_link( %opts )=== | ||
| + | |||
| + | Render a link to the icon for this document. | ||
| + | |||
| + | Options: | ||
| <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
| Line 399: | Line 501: | ||
| Show thumbnail/preview on all docs if poss. | Show thumbnail/preview on all docs if poss. | ||
| + | |||
| + | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
| + | <h4><span style='display:none'>User Comments</span></h4> | ||
| + | <!-- Edit below this comment --> | ||
| + | |||
| + | |||
| + | <!-- Pod2Wiki=item_render_preview_link --></div> | ||
| + | ===$frag = $doc->render_preview_link( %opts )=== | ||
| + | |||
| + | Render a link to the preview for this document (if available) using a lightbox. | ||
| + | |||
| + | Options: | ||
| <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
Revision as of 16:34, 12 February 2010
EPrints 3 Reference: Directory Structure - Metadata Fields - Repository Configuration - XML Config Files - XML Export Format - EPrints data structure - Core API - Data Objects
Latest Source Code (3.4, 3.3) | Revision Log | Before editing this page please read Pod2Wiki
NAME
EPrints::DataObj::Document - A single format of a record.
DESCRIPTION
Document represents a single format of an EPrint (eg. PDF) - the actual file(s) rather than the metadata.
This class is a subclass of DataObj, with the following metadata fields:
docid (text)
The unique ID of the document. This is a string of the format 123-02 where the first number is the eprint id and the second is the document number within that eprint.
This should probably have been and "int" but isn't. I later version of EPrints may change this.
eprintid (itemref)
The id number of the eprint to which this document belongs.
placement (int)
Placement of the document - the order documents should be shown in.
format (namedset)
The format of this document. One of the types of the dataset "document".
formatdesc (text)
An additional description of this document. For example the specific version of a format.
language (namedset)
The ISO ID of the language of this document. The default configuration of EPrints does not set this.
security (namedset)
The security type of this document - who can view it. One of the types of the dataset "security".
main (text)
The file which we should link to. For something like a PDF file this is the only file. For an HTML document with images it would be the name of the actual HTML file.
documents (subobject, multiple)
A virtual field which represents the list of Documents which are part of this record.
METHODS
$metadata = EPrints::DataObj::Document->get_system_field_info
Return an array describing the system metadata of the Document dataset.
$dataset = EPrints::DataObj::Document->get_dataset_id
Returns the id of the EPrints::DataSet object to which this record belongs.
$defaults = EPrints::DataObj::Document->get_defaults( $session, $data )
Return default values for this object based on the starting data.
$newdoc = $doc->clone( $eprint )
Attempt to clone this document. Both the document metadata and the actual files. The clone will be associated with the given EPrint.
$success = $doc->remove
Attempt to completely delete this document
$eprint = $doc->get_eprint
Return the EPrint this document is associated with.
This is a synonym for get_parent().
$url = $doc->get_baseurl( [$staff] )
Return the base URL of the document. Overrides the stub in DataObj. $staff is currently ignored.
$boolean = $doc->is_public()
True if this document has no security set and is in the live archive.
$url = $doc->get_url( [$file] )
Return the full URL of the document. Overrides the stub in DataObj.
If file is not specified then the "main" file is used.
$path = $doc->local_path
Return the full path of the directory where this document is stored in the filesystem.
%files = $doc->files
Return a hash, the keys of which are all the files belonging to this document (relative to $doc->local_path). The values are the sizes of the files, in bytes.
$success = $doc->remove_file( $filename )
Attempt to remove the given file. Give the filename as it is returned by get_files().
$doc->set_main( $main_file )
Sets the main file. Won't affect the database until a $doc->commit().
$filename = $doc->get_main
Return the name of the main file in this document.
$doc->set_format( $format )
Set format. Won't affect the database until a commit(). Just an alias for $doc->set_value( "format" , $format );
$doc->set_format_desc( $format_desc )
Set the format description. Won't affect the database until a commit(). Just an alias for $doc->set_value( "format_desc" , $format_desc );
$success = $doc->upload( $filehandle, $filename [, $preserve_path [, $filesize ] ] )
Upload the contents of the given file handle into this document as the given filename.
If $preserve_path then make any subdirectories needed, otherwise place this in the top level.
$success = $doc->add_file( $file, $filename, [$preserve_path] )
$file is the full path to a file to be added to the document, with name $filename.
If $preserve_path then keep the filename as is (including subdirs and spaces)
$cleanfilename = sanitise( $filename )
Return just the filename (no leading path) and convert any naughty characters to underscore.
$success = $doc->upload_archive( $filehandle, $filename, $archive_format )
Upload the contents of the given archive file. How to deal with the archive format is configured in SystemSettings.
(In case the over-loading of the word "archive" is getting confusing, in this context we mean ".zip" or ".tar.gz" archive.)
$success = $doc->add_archive( $file, $archive_format )
$file is the full path to an archive file, eg. zip or .tar.gz
This function will add the contents of that archive to the document.
$success = $doc->add_directory( $directory )
Upload the contents of $directory to this document. This will not set the main file.
This method expects $directory to have a trailing slash (/).
$success = $doc->upload_url( $url )
Attempt to grab stuff from the given URL. Grabbing HTML stuff this way is always problematic, so (by default): only relative links will be followed and only links to files in the same directory or subdirectory will be followed.
This (by default) uses wget. The details can be configured in SystemSettings.
$success = $doc->commit
Commit any changes that have been made to this object to the database.
Calls "set_document_automatic_fields" in the ArchiveConfig first to set any automatic fields that may be needed.
$problems = $doc->validate( [$for_archive] )
Return an array of XHTML DOM objects describing validation problems with the entire document, including the metadata and repository config specific requirements.
A reference to an empty array indicates no problems.
$type = $doc->get_type
Return the type of this document.
$doc->files_modified
This method does all the things that need doing when a file has been modified.
$doc->rehash
Recalculate the hash value of the document. Uses MD5 of the files (in alphabetic order), but can use user specified hashing function instead.
$doc = $doc->make_indexcodes()
Make the indexcodes document for this document. Returns the generated document or undef on failure.
$doc = $doc->remove_indexcodes()
Remove any documents containing index codes for this document. Returns the number of documents removed.
$filename = $doc->cache_file( $suffix );
Return a cache filename for this document with the givven suffix.
$frag = $doc->render_icon_link( %opts )
Render a link to the icon for this document.
Options:
new_window => 1
Make link go to _blank not current window.
preview => 1
If possible, provide a preview pop-up.
public => 0
Show thumbnail/preview only on public docs.
public => 1
Show thumbnail/preview on all docs if poss.
$frag = $doc->render_preview_link( %opts )
Render a link to the preview for this document (if available) using a lightbox.
Options:
caption => $frag
XHTML fragment to use as the caption, defaults to empty.
set => "foo"
The name of the set this document belongs to, defaults to none (preview won't be shown as part of a set).
