This plugin redesigns the way how users interact with topics and attachments in various ways:
Other features are:
 
 
 
 
 
topicinteraction to your SKIN path setting in your SitePreferences, like
    * Set SKIN = topicinteraction, pattern
Use the insidetab setting of MetaCommentPlugin to render comments inside a tab at the bottom of the page:
    * Set SKIN = topicinteraction, metacomment, pattern
    * Set DISPLAYCOMMENTS = on
    * Set COMMENTFORMAT = insidetab
Note you won't need using Foswiki:Extensions/NatSkin as that's integrated automatically.
TopicInteractionPlugin extens the standard way of inserting links to an attachment. Instead of only distinguishing between images and other kinds of attachments you may now specify different code to be inserted into the topic based on the mime type of an attachment. You may specify a set of various preference settings. The actual setting being used is chosen in the given precedence:
ATTACHED_<file-extension>_FORMAT 
ATTACHED_<mime-type>_FORMAT 
ATTACHEDIMAGEFORMAT (provided for compatibility, left out in below examples)
ATTACHED_FILE_FORMAT
ATTACHEDFILELINKFORMAT (provided for compatibility, left out in below examples)
<file-extension> and <mime-type> are uppercase). For example, when inserting a link to an attachment named screenshot.png the following
settings are looked up:
 ATTACHED_PNG_FORMAT
ATTACHED_IMAGE_FORMAT
ATTACHED_FILE_FORMAT
IMAGE, VIDEO, TEXT, AUDIO etc just to name the most interesting ones. There are a couple of more mime types that are grouped together
in a meaningful way to form the group DOCUMENT which are application/.*(document|msword|msexcel|rtf).*, as well as PDF which are application/pdf
and application/postscript. 
For example the following settings might be quite useful:
Using DocumentViewerPlugin:
   * Set ATTACHED_ODT_FORMAT = $percntDOCUMENTVIEWER{"$filename"}$percnt
   * Set ATTACHED_PDF_FORMAT = $percntDOCUMENTVIEWER{"$filename"}$percnt
Using ImagePlugin:
   * Set ATTACHED_IMAGE_FORMAT = $percntIMAGE{"$filename" size="200" caption="$comment"}$percnt 
Using MediaElementPlugin:
   * Set ATTACHED_VIDEO_FORMAT = $percntVIDEO{"$filename"}$percnt
   * Set ATTACHED_AUDIO_FORMAT = $percntAUDIO{"$filename"}$percnt
Using WebDAVContrib (please adjust the webdav://wiki/dav prefix to your needs):
   * Set OFFICELINK = <a href='webdav://wiki/dav/%WEB%/%TOPIC%/%DEFAULT{default=""}%' class='jqWebDAVLink' title='Edit Office Attachment' rel='nofollow'>%DEFAULT{default=""}%</a>
   * Set ATTACHED_DOCUMENT_FORMAT = $percntOFFICELINK{"$filename"}$percnt
   * Set WEBDAV_OFFICE_SUITE = msoffice, libreoffice or openoffice (defaults to settings in =configure=)
The ..._FORMAT strings support the following variables:
 $filename: the name of the file
$fileext: the filename extension (string following the last period, if present) or an empty string.
$fileurl: URL of the filename
$comment: the file comment from the upload dialog
$size: the filesize (%ATTACHEDIMAGEFORMAT% only)
$width: image width
$height: image width
$date: modification date of attachment
$percnt, $dollar, etc.
ATTACHEDFILEFORMAT settings and the way TopicInteractionPlugin does. 
 $percnt and $dollar. As such previous settings might be incompatible with TopicInteractionPlugin     settings of the same kind.
$date instead.
TopicInteractionPlugin implements some macros to actually implement the user interface. These macros can be used for other purposes too of course.
| %ATTACHMENTS%, %ATTACHMENTS{"<topic>" ...}% | |
|---|---|
| "<topic>" | topic with attachments to be included | 
| attr="..." | match the attachments' attribute | 
| autoattached="yes,no,undef" | limit attachments to those that are (not) autoattached | 
| casesensitive="on/off" | specify string comparison mode when filtering attachments, defaults to on | 
| comment="..." | match the attachments' comment | 
| maxdate="..." | specify latest attachment | 
| maxsize="..." | specify biggest attachment | 
| mindate="..." | specify earliest attachment | 
| minsize="..." | specify smallest attachment | 
| names="..." | regular expression matching the name of attachments to be include in the list | 
| user="..." | regular expression matching the attachments' user who uploaded it | 
| include="..." | general regular expression that the name, user, comment and attributes must match | 
| exclude="..." | general regular expression that the name, user, comment and attributes must not match | 
| footer="..." | format string appended to the result | 
| format="..." | how to format each attachment | 
| header="..." | format string prefixing the resulting output | 
| separator="..." | format string put between each formatted attachment | 
| hidenull="on,off" | hide/display the empty result; only the header and the footer are included if set to "off" and there's no attachment at the given topic | 
| nullformat="..." | format string to be used when no attachments have been found and hidenullis switched off | 
| nullheader="..." | header string to be used when no attachments have been found and hidenullis switched off | 
| nullfooter="..." | footer string to be used when no attachments have been found and hidenullis switched off | 
| sort="name,date,size,user,comment,comment:name,random,type" | sort results by specified property | 
| reverse="on/off" | enable reverse sorting | 
| limit="..." | limit the number of attachments to the given number; by default show all | 
| dateformat="..." | custom date format string, defaults to the system's default date format | 
0 or 1 depending on the file being hidden or not
$date;$user;$rev;$comment
%ATTACHMENTS{
  header="| * * | *Name* | *Url* | *Size* | *Author* | $n"
  format="| $idnex | $name: | $url | $sizeK |"
}%
generates:
| # | Icon | Name | Size | Author | Date | 
|---|---|---|---|---|---|
| 1 |   | LibreOfficeWebDAV.reg | 1.10 KB | ProjectContributor | 26 Nov 2018 - 17:45 | 
| 2 |   | TopicInteractionPluginSnap1.png | 15.82 KB | ProjectContributor | 26 Nov 2018 - 17:45 | 
| 3 |   | TopicInteractionPluginSnap2.png | 108.42 KB | ProjectContributor | 26 Nov 2018 - 17:45 | 
| 4 |   | TopicInteractionPluginSnap3.png | 97.24 KB | ProjectContributor | 26 Nov 2018 - 17:45 | 
| 5 |   | TopicInteractionPluginSnap4.png | 43.98 KB | ProjectContributor | 26 Nov 2018 - 17:45 | 
| 6 |   | TopicInteractionPluginSnap5.png | 35.37 KB | ProjectContributor | 26 Nov 2018 - 17:45 | 
You do not need to install anything in the browser to use this extension. The following instructions are for the administrator who installs the extension on the server.
Open configure, and open the "Extensions" section. "Extensions Operation and Maintenance" Tab → "Install, Update or Remove extensions" Tab. Click the "Search for Extensions" button. Enter part of the extension name or description and press search. Select the desired extension(s) and click install. If an extension is already installed, it will not show up in the search results. You can also install from the shell by running the extension installer as the web server user: (Be sure to run as the webserver user, not as root!)cd /path/to/foswiki perl tools/extension_installer <NameOfExtension> installIf you have any problems, or if the extension isn't available in
configure, then you can still install manually from the command-line. See https://foswiki.org/Support/ManuallyInstallingExtensions for more help.
| Name | Version | Description | 
|---|---|---|
| Foswiki::Contrib::JQPhotoSwipeContrib | >=1.00 | Optional | 
| Foswiki::Plugins::FilterPlugin | >=2.07 | Required | 
| Foswiki::Plugins::FlexFormPlugin | >=2.40 | Required | 
| Foswiki::Plugins::DocumentViewerPlugin | >=1.0 | Optional | 
| Foswiki::Plugins::ImageGalleryPlugin | >=6.00 | Optional | 
| Foswiki::Plugins::ImagePlugin | >=2.41 | Optional | 
| Foswiki::Plugins::JQueryPlugin | >=7.20 | Required | 
| Foswiki::Plugins::MediaElementPlugin | >=1.00 | Optional | 
| Foswiki::Plugins::MetaCommentPlugin | >=1.11 | Optional | 
| Foswiki::Plugins::LikePlugin | >=2.00 | Optional | 
| Foswiki::Plugins::MimeIconPlugin | >=1.1 | Required | 
| Foswiki::Plugins::RenderPlugin | >=3.01 | Required | 
| Archive::Zip | >=0 | Required | 
| Digest::MD5 | >=2.36 | Required | 
| JSON | >=2.17 | Required | 
| Foswiki::Plugins::ZonePlugin | >=3.1 | Required for Foswiki < 1.1 | 
| 12 Jul 2022: | remove DRY flag from move-attachment action | 
| 01 Jul 2022: | fixed detection of multi-file upload capabilities of foswiki core | 
| 29 Jun 2022: | validate web, topic and filename parameters properly; fixed some Perl::Critic violations; support multi-file upload capabilities of newer Foswiki cores | 
| 09 Jun 2022: | zip archives need to flag filenames as unicode explicitly; fixed encoding of attachment comments | 
| 05 Mar 2022: | added support for a custom TRASHWEB;                   improved %ATTACHMENTSmacro in various ways;                   allow uploader to be disabled using the%TOPICINTERACTION_UPLOADERENABLEDpreference setting;                   sanitizing attachment names using the{UploadFilter};                   improvedChangePropertiesto be more robust against storage errros;                   improved "insert link" feature | 
| 26 Nov 2018: | added compatibility with AttachmentListPlugin; added support for Foswiki:Extensions/MimeIconPlugin to render attachment icons; added sort by type option to %ATTACHMENTS makro | 
| 06 Nov 2018: | removed excess div in templates; moved progress bar into js land | 
| 24 Oct 2018: | improved "insert link" action; added "create link & hide file" action; performance improvements to other actions | 
| 05 Mar 2018: | fixed selecting attachments with brackets in its filename | 
| 16 Feb 2018: | added a legacy uploader to be somewhat backwards compatible to the old plupload just enough to please natedit | 
| 16 Jan 2018: | check access permissions in %ATTACHMENTS makro; fixed url encoding of unicode files | 
| 13 Sep 2017: | replace outdated plupload uploader with jquery-file-upload | 
| 18 Nov 2016: | oo-ified core; added humanized file size display, removed flash backend from default; improved webdav integration for one-click editing office documents; fixed sanitizing attachemnt names during upload using the standard mechanism again; removed (optional) dependency on FlexPaperPlugin (flash) in favour of DocumentViewerPlugin (html5); fixed url construction in javascript land; add support for JQPhotoSwipeContrib, a much nicer lightbox image preview; added support for LikePlugin to rate attachments; replaced famfamfam icons with fontawsome ones; added registry entry to use register LibreOffice to be used for one-click edits on windows | 
| 11 Oct 2016: | using jquery-i18n for translations now | 
| 17 Jul 2015: | added support for Foswiki-2.0; added support for Foswiki:Extensions/WebDAVContrib | 
| 16 Dec 2014: | add support for Foswiki:Extensions/MediaElementPlugin to preview audio and video attachments | 
| 29 Aug 2014: | fully specify rest security | 
| 28 May 2014: | improve performance on bulk operations on attachments; fixed tooltip poping up automatically | 
| 04 Apr 2014: | flag rest handlers that don't require authentication | 
| 18 Mar 2014: | render correct form data when displaying an old revision | 
| 20 Feb 2014: | fixed permission checking of actions; added one-click editing of office documents | 
| 08 Jan 2014: | fixed file corruption under Windows; fixed too aggressive renaming of files during upload | 
| 12 Dec 2013: | fixed initialization of defaults | 
| 07 Nov 2013: | fixed malformed JSON on some remote procedures | 
| 01 Nov 2013: | have a checkbox in the properties dialog to mark an image attachment to be used as a thumbnail in search results; better support for WebDavContrib: one-click edit of office attachments; jslinting javascript code (excluding 3rd party upstream code) | 
| 08 Apr 2013: | fixed html error | 
| 14 Mar 2013: | default to chunked upload; fixed handling of attachments with commas in their name | 
| 01 Feb 2013: | fixed error handling; hiding access to edit actions when not authorized anyway; fixed uploading files with special chars in their name; fixed initialization of flash backend; fixed reading foswiki preference settings; fixed uploading files with commas in their name | 
| 31 Jan 2013: | using ATTACHLINKBOX to control the default state of the "create link" checkbox | 
| 25 Jan 2013: | fixed auto-start feature; fixed registration of uploader component | 
| 18 Jan 2013: | improved compatibility with PatternSkin;                   fixed configurebarfing on an undef value | 
| 24 Sep 2012: | updated to latest plupload version; allow to add arbitary properties, not only comments, createlink, hide-file flags | 
| 10 Jul 2012: | replaced all simplemodals with jquery-ui dialogs; added nullformat,nullheader,nullfooter to %ATTACHMENTS macro; removed dependency on WebDAVLinkPlugin to render webdav-enabled urls | 
| 08 May 2012: | fixed silent dependency on DBCachePlugin; fixed integration with PatternSkin; fixed dependency on Foswiki:Extensions/RenderPlugin; fixed interaction with Foswiki:Extensions/MetaCommentPlugin | 
| 26 Apr 2012: | initial release | 
| Author | Michael Daum | 
| Version | 9.23 | 
| Release | 01 Jul 2022 | 
| Description | Improved interaction with attachments and DataForms | 
| Repository | https://github.com/foswiki/TopicInteractionPlugin | 
| Copyright | © 2010-2022 Michael Daum | 
| License | GPL (Gnu General Public License) | 
| Home | Foswiki:Extensions/TopicInteractionPlugin | 
| Support | Foswiki:Support/TopicInteractionPlugin | 
| I   | Attachment | Action | Size | Date | Who | Comment | 
|---|---|---|---|---|---|---|
|  reg | LibreOfficeWebDAV.reg | manage | 1 K | 2018-11-26 - 17:45 | ProjectContributor | |
|  png | TopicInteractionPluginSnap1.png | manage | 15 K | 2018-11-26 - 17:45 | ProjectContributor | |
|  png | TopicInteractionPluginSnap2.png | manage | 108 K | 2018-11-26 - 17:45 | ProjectContributor | |
|  png | TopicInteractionPluginSnap3.png | manage | 97 K | 2018-11-26 - 17:45 | ProjectContributor | |
|  png | TopicInteractionPluginSnap4.png | manage | 43 K | 2018-11-26 - 17:45 | ProjectContributor | |
|  png | TopicInteractionPluginSnap5.png | manage | 35 K | 2018-11-26 - 17:45 | ProjectContributor | 
 Copyright &© by the contributing authors. All material on this site is the property of the contributing authors.
Copyright &© by the contributing authors. All material on this site is the property of the contributing authors.