History Plugin

This plugin shows a complete or partial history of a document. The output can arbitrarily be formatted. An example for a Wikipedia-like history is included.

When using PatternSkin enabling the HistoryPlugin changes the "History" link in the bottom action bar so it opens a page with a nice user interface where you can select the versions to compare.

With other skins for Foswiki you will need to tweak the templates.

If CompareRevisionsAddOn is installed and activated the "History" user interface will allow you to choose how the changes are rendered (interweaved vs side-by-side, and context).

If RevCommentPlugin is installed and activated the "History" page will show the comments entered for each revision.

This plugins is designed to work together with CompareRevisionsAddOn and RevCommentPlugin but works well on its own or with just one of the two other plugins.

Syntax Rules

  • %HISTORY%
  • %HISTORY{parameters}
    Supported parameters:
    Parameter Description Default
    "format" or format="format" Format of one line, may include any variable which is supported by %REVINFO% "r$rev - $date - $wikiusername"
    topic="topic" Topic name Current topic
    web="web" Web name Current web
    nrev="nrev" Number of revisions to show. Ignored, if both rev1 and rev2 are specified Plugin preference variable NREV
    rev2="rev2" Newest revision to show rev1+nrev, if rev1 is specified, latest revision otherwise
    rev1="rev1" Oldest revision to show rev2-nrev
    reverse="on/off" Show newest revisions first, if on "on"
    header="text" Text to print before the list. May contain the variables $next and $previous (see below) "$next"
    footer="text" Text to print after the list. May contain the variables $next and $previous (see below) "$previous"

The parameters header and footer may contain the variables $next and $previous, which will only be evaluated, if there are newer or older revisions available for the topic which are not listed according to rev1, rev2, nrev. These variables take the syntax $next{'text' url='url'} (analog for $previous). text is the text which should be printed, url is the url for a corresponding link. The variables $rev1, $rev2, $nrev in text or url will be replaced by appropriate values for the next or previous block of revisions. See the attached oopshistory.tmpl for an example of how to use this.

The following variables are replaced only, if there is a corresponding %HISTORY% on the page. If more than one %HISTORY% is used on the same page, the values from the last one will be used.

  • %HISTORY_REV1%: Oldest revision from the printed history
  • %HISTORY_REV2%: Latest revision from the printed history
  • %HISTORY_NREV%: Number of the printed revisions
  • %HISTORY_MAXREV%: Latest available revision of the document

Examples

The call %HISTORY% shows a simple list of available revisions like

r3 - 17 Feb 2005 - 09:56 - AnUser
r2 - 31 Dec 2004 - 10:22 - AnotherUser
r1 - 15 Nov 2003 - 01:23 - YetAnotherUser

For a more complex example see the attached oopshistory.tmpl which also allows the comparison of two selected revisions.

Example screenshot of the topic history with HistoryPlugin enabled and working with CompareRevisionsAddOn and RevCommentPlugin

screenshot.png

Plugin Installation Instructions

Note: You do not need to install anything on the browser to use this plugin. The following instructions are for the administrator who installs the plugin on the server where Foswiki is running.

  • Download the ZIP file from the Plugin web (see below)
  • Unzip HistoryPlugin.zip in your twiki installation directory. Content:
    File: Description:
    data/System/HistoryPlugin.txt  
    lib/Foswiki/Plugins/HistoryPlugin.pm  
    pub/System/HistoryPlugin/screenshot.png  
    templates/oopshistory.tmpl  

  • Visit configure in your Foswiki installation, and enable the plugin in the {Plugins} section.
  • Test if the installation was successful:
    • Here should appear the history of this document inline:
      r1.2 - 2010-02-10 - 20:39 - AdminUser
      r1.1 - 2010-02-10 - 20:39 - AdminUser

Plugin Info

Plugin Author: Foswiki:Main.KennethLavrsen
Copyright ©: 2006, JChristophFuchs; 2008 Kenneth Lavrsen and Foswiki Contributors
License: GPL (GNU General Public License)
Plugin Version: 08 Dec 2008: (V1.4)
Change History:  
08 Dec 2008: 1.4 Kenneth Lavrsen: Changed the author to myself. JChristophFuchs is the original author but announced in 2006 that he no longer maintains this plugin. So now I officially take the task as maintainer. Plugin is changed to Foswiki namespace and tested and works under Foswiki 1.0.0
09 Dec 2007: 1.3 Kenneth Lavrsen: Restored the features that were lost in revision 1.1 including: Showing comments made by RevCommentPlugin, selection of render styles "interweave" and "side by side" provided by CompareRevisionsAddOn, and link to rdiff history. Restored compatibility with TWiki-4.1 which means removing the dependency of 4.2 only CSS feature. Updated the default rev format to 4.X format.
13 Nov 2007: 1.2 Michael Daum: removed cruft from plugin, updates to use modern TWiki APIs, added some more flexibility to create a diff interface, removed plugin topic options
07 Nov 2007: 1.1 Arthur Clemens: updated to TWiki 4.2; improved user interface.
19 Jan 2007: 1.002 Corrected coding error that causes the plugin to fail with HISTORY tag in topic
9 Apr 2006: 1.001 Updated for new PatternSkin in TWikiRelease04x00x02
17 Feb 2005: Initial version
Foswiki Dependency: $Foswiki::Plugins::VERSION 1.024
CPAN Dependencies: none
Other Dependencies: none
Perl Version: 5.008
Plugin Home: http://foswiki.org/Extensions/HistoryPlugin
Feedback: http://foswiki.org/Extensions/HistoryPluginDev

Related Topics: DefaultPreferences, SitePreferences, Plugins

Topic attachments
I Attachment Action Size Date Who Comment
pngpng screenshot.png manage 59.8 K 2008-12-17 - 09:40 AdminUser Saved by install script
Topic revision: r2 - 2010-02-10 - 20:39:28 - AdminUser
 
This site is powered by FoswikiCopyright © by the contributing authors. All material on this site is the property of the contributing authors.
Ideas, requests, problems regarding STALklubben? Send feedback