JQDataTablesPlugin

JQuery based progressive enhancement of tables

Overview

This plugin implements a widget to enhance normal HTML tables with extra navigation features such as sorting, filtering and paginating through datasets. The %DATATABLE macro is specifically tailored towards datasets created on the base of DataForms. It lets you easily compile an overview of data of that kind stored in a web as well as select specific records for further use in wiki apps.

JQDataTablesPlugin can be used in two distinct ways:

  • by means of the %DATATABLE macro
  • by means of HTML5 and JSON to enhance HTML tables directly

%DATATABLE takes a pointer to a DataForm definition and then creates a table based on the known formfields in that definition to create columns of a kind matching the formfield types. It then uses a connector fetch the data from the backend. There are several kinds of connectors available at the moment based on the additional functionality installed on your Foswiki:

  • search: this one uses the normal native search feature of Foswiki also used by the %SEARCH macro
  • dbcache: this one uses DBCachePlugin which is implementing a faster still native search, also available via its %DBQUERY macro
  • solr: this connector uses the SolrPlugin which uses a Solr fulltext search engine integrated into Foswiki.

A default connector can be defined as required. Note however, that even though %DATATABLE tries to hide the differences of available connectors behind the scene, connectors will behave differently, i.e. when it comes to filtering. Also, performance is vastly different with the search connector being the slowest one. It is strongly recommended that you at least install DBCachePlugin for acceptable performance in every-day usage.

DATATABLE

Using a %DATATABLE you can query a set of topics and display their structured data in a dynamic table. Results are best when querying structured data attached to your topics as each formfield defined in the DataForm directly correlates to a column in the generated table. In this case you may specify the form definition in the form parameter and formfields in the columns parameter. The %DATATABLE will then use this information to properly display formfield values as well as sort columns along the technical representation. For example a date formfield will properly be displayed according to your locale's date format while sorting by date uses date values represented as epoch seconds.

Syntax: %DATATABLE{"<query>" parameter="..." parameter="..." ...}%

Parameter Description Default
<query>, query specify a search query to filter rows on the server-side; NOTE: the query language might vary depending on the connector being used, e.g. dbcache vs search vs solr  
connector connector to be used to fetch data dynamically from the backend; possible values are search (using Foswiki's native %SEARCH), dbcache (needs Foswiki:Extensions/DBCachePlugin), solr (needs Foswiki:Extensions/SolrPlugin), additional connectors may be implemented by plugins; NOTE: for general-purpose search dbcache is the best choice defined in $Foswiki::cfg{JQDataTablesPlugin}{DefaultConnector}
class additional css class to be added to the widget in addition to foswikiTable  
width width of table, e.g. 100% and the like  
web, webs web or list of webs to query for data current web
topics list of topics to query per web  
include regular expression topics must match to be included  
exclude regular expression topics must not match to be included  
form data form definition  
buttons list of buttons to add; available buttons are: print, csv, excel, copy, pdf  
paging, pager switch on/off paging data; NOTE: this parameter is deactivated when scrolling is specifed as well (see docu) off
pagelength, rows number of rows to be displayed when paging is enabled (see docu) 10
lengthmenu switches on a menu element to change the page length (see docu) 10, 25, 50, 100
scrolling, scroller switch on/off dynamic scrolling; data will be fetched from the backend as you are scrolling up and down; NOTE: this parameter disables paging as these two features are mutual exclusive off
searching switch on/off the global search box (see docu) off
searchmode defines how to search, either using one search box covering all columns (global), or using one search box per column (multi) global
searchdelay delay before changes in a search box will cause new data to be fetched from the backend 400
sort specifies the column for initial ordering; note that sorting is performed on the server side by default first column
reverse specifies the initial ordering direction off
savestate switch on/off remembering the state the datatable was in when coming back to the page; this includes sorting, paging as well as filtering; state information is stored in the browser's session store, that is state information is specific to the browser tab; closing a browser tab will purge all state infos of datatables with it off
info switch on/off the info about the number of rows in the set (see docu) off
ordering switch on/off the ability to sort the table by clicking on a column header (see docu) on
scrollx switch on/off horizontal scrolling (see docu) off
scrolly specify vertical scrolling (see docu) off
scrollcollapse switch on/off collapsing of the table height on small data sets (see docu) off
columns comma-separated list of formfield names to be displayed; see the notes on special columns below all formfields of the DataForm specified by form
rowgroup comma-separated list of columns that should be used to create groups of rows  
selecting switch on/off select extension  
selectproperty specifies the property of a row to be selected when selection is enabled topic
selectname specifies the name of the data be submitted when selection is enabled <selectproperty>
selectmode possible values are os, single, multi, this specifies the way a selection is made (see docu) multi
responsive switch on/off responsive extension  
fixedheader switch on/off fixed header extension  
hidecolumns comma-separated list of columns to hide from the output; while hidden column data is still fetched available for further processing such as grouping or styling a row  
rowclass javascript function that is supposed to return a css class when a row is rendered; the string returned is added as a class to the row elements of the table  
rowcss javascript function that is supposed to return a string or an object to apply inline css to all cells of a row  
autocolor comma-separted list of columns to auto-color based on the cell content; note this needs the JQAutoColorContrib to be installed and activated  
datetimeformat date format to be recognized by the frontend  
<field-name>_title a column title for a given field-name, e.g. ProjectState_title="Status" name of the formfield as specified in columns
<field-name>_width column width for a given field, e.g. ProjectID_width=5em  

DATATABLESECTION, ENDDATATABLESECTION

This makro can be used to start wrapping HTML tables inside a dedicated section to augment them in functionality.

Syntax:

%DATATABLESECTION{<parameters>}% 

... one or more HTML tables ... 

%ENDDATATABLESECTION%

All HTML tables inside a datatables section will be assigned the same set of parameters. All of the parameters of a regular %DATATABLE can be used as defined above except columns, query and connector. Instead of fetching data from the backend using ajax data is embeded as a HTML table inside the page. No backend interaction will take place other than the initial HTML page embeding all data beforehand.

Special column names

In general column names specified in the columns parameter of the %DATATABLE parameter directly relate to a formfield of an attached DataForm. Values are displayed and sorted according the the type of the formfield. There are however a few column names that have a special meaning or trigger an additional behavior on data in this column:

  • index: this is an auto-generated column enumerating the rows in a table
  • Date, Changed, Modified, Created, info.date, createdate: these fields are all date fields and treated accordingly
  • Topic: alias for topic
  • TopicTitle: displays the TopicTitle of a topic linking to it
  • By: alias for author of recent topic revision
  • Creator, createauthor, info.author: author if the initial topic revision
  • publishauthor: author that published the topic, defaults to createauthor in case there is no explicit Author field in the form
  • publishdate: date when the publishauthor created the initial revision, defaults to createdate in case there is no explicut PublishDate field in the form
  • worflow: name of the workflow assigned to a topic
  • QMPlugin fields:
    • qmstate: title of the current workflow state
    • qmstate_id: id of the current workflow state
    • qmstate_pendingReviewers: list of users that still need to action on a state change in a parralel transition
    • qmstate_possibleReviewers: list of users that might change the current state
    • qmstate_pendingApprover: list of users that might transition the current state to the "approved" state
    • qmstate_reviewers: list of users that reviewed the current state
    • qmstate_comments: coments of all reviews of the current state
  • access control settings of the current topic
    • allowchange
    • allowview
    • allowapprove
    • allowcomment
    • allowcreate
    • denychange
    • denyview
    • denyapprove
    • denycomment
    • denycreate
  • MetaDataCommentPlugin fields:
    • comments: number of comments of the current topic

Examples

DATATABLESECTION simple example

%STARTSECTION{"example0"}%
%DATATABLESECTION%
| *Header* | *Header* | *Header* | *Header* |
| Data | Data | Data | Data |
| Data | Data | Data | Data |
| Data | Data | Data | Data |
| Data | Data | Data | Data |
%ENDDATATABLESECTION%
%ENDSECTION{"example0"}%

Header Header Header Header
Data Data Data Data
Data Data Data Data
Data Data Data Data
Data Data Data Data

This example generates a table dynamically using a FormattedSearch:

%STARTSECTION{"example1"}%
%DATATABLESECTION{paging="on" searching="on" info="on"}%
%SEARCH{
  "1"
  type="query"
  topic="*Plugin"
  header="| *Name* | *Date* | *Author* |"
  format="| $topic | $date | $wikiusername |"
  nonoise="on"
}%
%ENDDATATABLESECTION%
%ENDSECTION{"example1"}%

Name Date Author
AttachContentPlugin 03 Feb 2021 - 02:22 AdminUser
AutoTemplatePlugin 12 Nov 2019 - 08:09 ProjectContributor
AutoViewTemplatePlugin 17 Jun 2022 - 12:27 ProjectContributor
BatchUploadPlugin 31 Oct 2004 - 16:51 ProjectContributor
BeautifierPlugin 09 Apr 2010 - 17:08 ProjectContributor
BibliographyPlugin 29 Aug 2005 - 02:43 ProjectContributor
BreadCrumbsPlugin 01 Feb 2018 - 08:05 ProjectContributor
CalendarPlugin 31 Aug 2015 - 02:01 ProjectContributor
ChecklistPlugin 11 Jun 2018 - 11:09 ProjectContributor
CommentPlugin 06 Aug 2023 - 10:33 ProjectContributor
CompareRevisionsAddonPlugin 17 Jun 2022 - 12:27 ProjectContributor
ConfigurePlugin 06 Aug 2023 - 11:15 ProjectContributor
DBCachePlugin 26 Oct 2023 - 09:10 ProjectContributor
DBIPlugin 29 Mar 2022 - 10:24 ProjectContributor
DateTimePlugin 28 Jun 2024 - 09:55 UweKahlert
DeeplPlugin 31 Jan 2024 - 12:23 ProjectContributor
DigestPlugin 17 Nov 2009 - 13:38 ProjectContributor
DirectedGraphPlugin 19 Jul 2015 - 02:39 ProjectContributor
DirectedGraphWebMapPlugin 15 Oct 2010 - 09:37 ProjectContributor
DocumentViewerPlugin 28 Sep 2015 - 06:50 ProjectContributor
EditChapterPlugin 12 Nov 2019 - 10:42 ProjectContributor
EditRowPlugin 12 Jan 2024 - 15:43 ProjectContributor
EditTablePlugin 06 Aug 2023 - 11:15 ProjectContributor
EmptyPlugin 09 Mar 2016 - 04:04 ProjectContributor
FilterPlugin 25 Oct 2018 - 06:40 ProjectContributor
FlexFormPlugin 12 Nov 2019 - 11:04 ProjectContributor
FlexWebListPlugin 28 May 2018 - 13:31 ProjectContributor
FormPlugin 30 Apr 2011 - 19:38 ProjectContributor
GnuPlotPlugin 11 Jul 2016 - 11:26 ProjectContributor
GoogleMapsPlugin 12 Nov 2019 - 11:30 ProjectContributor
GraphvizPlugin 19 Nov 2019 - 10:09 micha
GridLayoutPlugin 12 Nov 2019 - 11:35 ProjectContributor
HijaxPlugin 28 Jun 2024 - 09:56 UweKahlert
HistoryPlugin 22 Jun 2022 - 11:57 ProjectContributor
HomePagePlugin 17 Jun 2022 - 12:27 ProjectContributor
ImageGalleryPlugin 05 Dec 2016 - 14:17 micha
ImageGeneratorPlugin 25 Jan 2024 - 12:37 micha
ImagePlugin 12 Nov 2019 - 11:49 ProjectContributor
InterwikiPlugin 06 Aug 2023 - 11:15 ProjectContributor
JHotDrawPlugin 29 Oct 2010 - 21:57 ProjectContributor
JQDataTablesPlugin 17 Nov 2022 - 08:36 ProjectContributor
JQTablePlugin 24 Nov 2014 - 18:02 ProjectContributor
JQueryPlugin 26 Apr 2023 - 07:24 ProjectContributor
LikePlugin 18 Nov 2019 - 13:41 ProjectContributor
LoremIpsumPlugin 03 Apr 2024 - 15:10 ProjectContributor
MailerContribPlugin 05 May 2015 - 18:00 ProjectContributor
MathModePlugin 23 Dec 2012 - 16:06 ProjectContributor
MediaElementPlugin 18 Nov 2019 - 13:52 ProjectContributor
MediaPlugin 08 Mar 2009 - 00:30 ProjectContributor
MenuListPlugin 21 Jun 2024 - 08:20 UweKahlert
MetaCommentPlugin 19 Nov 2020 - 16:53 ProjectContributor
MetaDataPlugin 30 Jan 2019 - 14:39 ProjectContributor
MimeIconPlugin 18 Nov 2019 - 13:57 ProjectContributor
MoreFormfieldsPlugin 19 Mar 2024 - 09:15 ProjectContributor
MultiLingualPlugin 16 Jul 2018 - 14:17 ProjectContributor
NatEditPlugin 11 Jul 2023 - 11:24 ProjectContributor
NewUserPlugin 24 Dec 2014 - 20:37 ProjectContributor
PhotoGalleryPlugin 25 Feb 2016 - 21:28 ProjectContributor
PreferencesPlugin 17 Jun 2022 - 12:27 ProjectContributor
PubLinkFixupPlugin 14 Sep 2015 - 00:51 ProjectContributor
RedDotPlugin 17 Jul 2015 - 17:50 ProjectContributor
RenderListPlugin 06 Aug 2023 - 11:15 ProjectContributor
RenderPlugin 17 Jun 2022 - 15:06 ProjectContributor
SetFormValuesPlugin 30 Jul 2015 - 16:18 UnknownUser
SetTopicValuesPlugin 25 Feb 2009 - 23:04 UnknownUser
SetVariablePlugin 11 Jun 2018 - 13:52 ProjectContributor
SlideShowPlugin 17 Jun 2022 - 12:27 ProjectContributor
SmiliesPlugin 17 Jun 2022 - 12:27 ProjectContributor
SolrPlugin 31 Jan 2019 - 11:07 ProjectContributor
SpreadsheetReaderPlugin 31 May 2018 - 07:59 ProjectContributor
SubscribePlugin 06 Aug 2023 - 11:15 ProjectContributor
SyntaxHighlightingPlugin 26 Apr 2022 - 12:30 micha
TWikiCompatibilityPlugin 17 Jun 2022 - 12:27 ProjectContributor
TablePlugin 22 Jun 2022 - 11:57 ProjectContributor
TagCloudPlugin 15 May 2014 - 11:51 ProjectContributor
TagMePlugin 11 Jan 2017 - 03:16 UnknownUser
TinyMCEPlugin 17 Jun 2022 - 12:27 ProjectContributor
ToolTipPlugin 21 Jun 2024 - 08:22 UweKahlert
TopicInteractionPlugin 26 Nov 2018 - 17:45 ProjectContributor
TopicTitlePlugin 28 May 2018 - 10:42 ProjectContributor
TwistyPlugin 11 Jul 2023 - 11:17 ProjectContributor
UpdatesPlugin 17 Jan 2023 - 11:48 ProjectContributor
WikiDrawPlugin 24 Oct 2010 - 03:43 AdminUser
WorkflowPlugin 01 Aug 2017 - 08:54 ProjectContributor
WysiwygPlugin 22 Jun 2022 - 11:57 ProjectContributor

Client side sorting

JQDataTablesPlugin comes with additional sorting features for specific types of data:

  • numeric
  • string
  • date (extended to be able to parse Foswiki's default date format)
  • currency
  • metrics (e.g. killo, mega, giga, tera, ...)

Click on the table headers to sort the columns according to their data type.

%STARTSECTION{"example2"}%
%DATATABLESECTION%
| *#* | *String* | *Date* | *Number* | *Currency* | *Size* |
| 3 | ActionTrackerPlugin | 27 Jan 2010 - 17:07 | 1 | 1,00 | 10KB |
| 1 | AntiWikiSpamPlugin | 03 Jan 2013 - 09:07 | 10 | 10,00 | 3GB |
| 2 | RenderListPlugin | 13 May 2012 - 02:59 | 0.01 | 1,01 | 100MB |
| 5 | CommentPlugin | 10 Apr 2011 - 23:39 | 100 | 0,10 | 2024kB |
| 4 | FindElsewherePlugin | 23 Dec 2012 - 17:06 | 20 | 100,- | 0.1kB |
| 6 | JsonRpcContrib |  | 0 | -100,- | 1024TB |
%ENDDATATABLESECTION%
%ENDSECTION{"example2"}%

# String Date Number Currency Size
3 ActionTrackerPlugin 27 Jan 2010 - 17:07 1 1,00 10KB
1 AntiWikiSpamPlugin 03 Jan 2013 - 09:07 10 10,00 3GB
2 RenderListPlugin 13 May 2012 - 02:59 0.01 1,01 100MB
5 CommentPlugin 10 Apr 2011 - 23:39 100 0,10 2024kB
4 FindElsewherePlugin 23 Dec 2012 - 17:06 20 100,- 0.1kB
6 JsonRpcContrib   0 -100,- 1024TB

List of PackageForm topics

Below example lists all topics in the System web that have the PackageForm attached to it:

%STARTSECTION{"example3"}%
%DATATABLE{
   web="%SYSTEMWEB%"
   form="%SYSTEMWEB%.PackageForm"
   paging="on"
   searching="on"
   info="on"
   pagelength="10"
   lengthmenu="5, 10, 20, 50, 100"
   columns="index, Topic, Description, Version, Release, Author"
}%
%ENDSECTION{"example3"}%

index Topic Description Version Release Author

Selecting topics

%STARTSECTION{"example4"}%
<form action="%SCRIPTURLPATH{"view"}%/%WEB%/%TOPIC%" method="post">
%DATATABLE{
   web="System"
   class="foswikiFlatTable foswikiStripes"
   form="%SYSTEMWEB%.PackageForm"
   sort="TopicTitle"
   columns="index, TopicTitle, Description, Author, Changed"
   TopicTitle_title="Title" 
   info="on"
   paging="on" 
   rows="10"
   selecting="on"
   selectmode="multi"
   selectproperty="Topic"
   selection="%URLPARAM{"Topic"}%"
}%
%BUTTON{"%TRANSLATE{"Submit"}%" type="submit" icon="tick"}%
</form>
%ENDSECTION{"example4"}%

Topic index TopicTitle Description Author Changed

Submit

Coloring rows using inline CSS

%STARTSECTION{"example5"}%
%DATATABLE{
   query="form~'FAQForm' AND topic!='FAQTemplate'"
   class="foswikiFlatTable foswikiStripes"
   web="%SYSTEMWEB%"
   paging="on"
   columns="Topic,TopicSummary,TopicClassification,Changed"
   TopicSummary_title="Summary"
   TopicClassification_title="Category"
   RelatedTopics_title="Related"
   rows="10"
   sort="TopicSummary"
   ordering="off"
   searching="on"
   rowcss="var css = { 
      'SupportQuestion': '#FFC107', 
      'FrequentlyAskedQuestion': {
         'background-color': '#4Caf40', 
         'color': '#fff'
      },
      'SupplementalDoc': '#f44336', 
      'AdminTopic': {
         'background-color': '#b22222',
         'color': '#fff'
      }
   }; return css[data.TopicClassification.raw];"
}%
%ENDSECTION{"example5"}%

Topic TopicSummary TopicClassification Changed

Coloring rows using classes

This example is not fully working. It depends on a DataForm definition for Invoice topics, that have at least formfields

  • Client: client that is invoiced
  • Total: amount of money
  • IssueDate: date when the invoice was sent to the client
  • DueDate: date until when the invoice has to be paid
  • State: the state the invoice is in: created, invoiced, overdue, reminded, disputed, paid, partial, withdrawn

We will use two properties of invoices to color the table. Depeding in the property values css classes will be applied that we crawft styles for. The invoice column will be colored depending on the State of an invoice. A blue line will be drawn below which all invoices have to be paid, that is the table will be devided in two parts below and above the line where above the line invoices will be paid in the future and below the line invoices should have to be paid up to today.

To make this work we create a small javascript fragment that returns the rowclass.

In addition, any client cell will auto-colored using Foswiki:Extensions/JQAutoColorContrib.

%STARTSECTION{"example6"}%
%DATATABLE{
   form="Invoice"
   class="foswikiFlatTable foswikiTable foswikiStripes"
   web="%SYSTEMWEB%"
   paging="on"
   columns="Topic,Client,Total,State,IssueDate,DueDate"
   rows="10"
   sort="DueDate"
   ordering="off"
   searching="on"
   autocolor="Client"
   rowclass="
      var now = Date.now() / 1000; 
      var cls = data.State.raw; 
      if (data.DueDate.epoch <= now) { 
         cls += ' past'
      }; 
      return cls; "
}%
%JQREQUIRE{"autocolor"}%
<style>
.dataTable tr.past {
  border-top: 3px solid #3e89d3;
}
.dataTable tr.past:first-of-type,
.dataTable tr.past + tr.past {
   border-top:0;
}
.dataTable tr.invoiced > td:nth-child(4) {
   background-color:#FFC107 !important;
}
.dataTable tr.reminded > td:nth-child(4) {
   background-color:#b22222 !important;
   color:#fff !important;
}
.dataTable tr.paid > td:nth-child(4) {
   background-color:#4Caf40 !important;
   color:#fff !important;
}
.dataTable tr.overdue > td:nth-child(4) {
   background-color:#f44336 !important;
   color:#fff !important;
}
</style>
%ENDSECTION{"example6"}%

Installation

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> install

If 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.

Dependencies

NameVersionDescription
Foswiki::Plugins::JQueryPlugin >= 4.10Required
Foswiki::Contrib::JQMomentContrib >= 3.00Required
Foswiki::Plugins::MultiLingualPlugin >= 4.00Optional
Foswiki::Plugins::DBCachePlugin >= 13.00Optional
Foswiki::Plugins::TopicTitlePlugin>1.00Required for Foswiki < 2.2

Change History

29 Apr 2024: fixed sort/hide/select columns when using datatable sections
22 Jan 2024: new perl api to register more datatable connectors; added parameter datetimeformat; fixed display of value-mapped columns/fields; fixed query builder of solr backend
23 Oct 2023: add Web and TopicType columns
04 May 2022: added DATATABLESECTION, ENDDATATABLESECTION, deprecate HTML5 approach; removed special / prefix from column names; new api Foswiki::Plugins::JQDataTablesPluginEnabled::describeColumn() to register custom datatable columns
06 Nov 2020: don't return empty result rows as this breaks jquery.datatables; extended documentation of special column names
15 Oct 2020: added buttons parameter and excel export; added parameters topics, include and exclude to DATATABLE macro; added support for multi-dimensional sorting (only available for DBCachePlugin connector); redesign of connector classes for better sortability & searchability: fixes SEARCH and SOLR backends
01 Jul 2019: updated to latest upstream version of Datatables; added parameters rowgroup, rowclass, rowcss, hidecolumns and autocolor
07 Jan 2019: added webs parameter to DATATABLE to query multiple webs at once
26 Nov 2018: add docu for newly added savestate parameter to DATATABLE; fixed rendering image columns in DBCacheConnector
01 Oct 2018: use JQMomentContrib for better parsing and sorting of date columns on the client side; make use of new TopicTitlePlugin; add support for MultiLingualPlugin
25 Sep 2017: fixed html5 data attributes
30 Aug 2017: disabled Author auto-column; added publishdate and publishauthor auto-columns
23 Jan 2017: don't report back an url parameter in the error message
02 Sep 2016: added default english translation files
13 Jun 2016: fixed parsing of dates that are already epoch seconds; improved default settings of table layout
25 May 2016: updated to latest version of DataTables
22 Apr 2016: implemented server-side grid widget
18 Mar 2014: remove console.log() leftover; improve sorting date columns
09 Nov 2013: implemented sorting for currency, and metrics
08 Nov 2013: make it work under {NoConflict}; enable jquery-ui theming by default now; created a non-goofy default look and feel to play nicely with a skin's table design; only add DataTables support to specific tables, not all; make it configurable with declarative metadata; compress and minify plugin assets; remove files not required by the plugin; clean up controls and css classes added by TablePlugin's; added type detector for foswiki date columns
18 Jan 2013: Initial version

PackageForm edit

Author Foswiki:Main.MichaelDaum, Foswiki:Main.SvenDowideit
Version 7.30
Release 29 Apr 2024
Description JQuery based progressive enhancement of tables
Repository https://github.com/foswiki/JQDataTablesPlugin
Copyright © 2012 SvenDowideit@fosiki.com, 2013-2024 Michael Daum
License GPL (GNU General Public License)
Home https://foswiki.org/Extensions/JQDataTablesPlugin
Support https://foswiki.org/Support/JQDataTablesPlugin
Topic revision: r1 - 17 Nov 2022, ProjectContributor
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 Foswiki? Send feedback