%EDITTABLE{}% directly above the table. This can be added to tables that are formatted with TablePlugin: add the EDITTABLE macro just above or below the TABLE tag. It can also be used without any TABLE tag.
Customize entry fields by specifying the format: use a text field, a drop down box, a date field, radio buttons or checkboxes.
Multiple tables per topic are editable, but only one at a time can be edited.
%EDITTABLE{...}% macro just before an existing table to make it editable, or add the variable anywhere in a topic to start a new table.
 | Attribute | Comment | Default | 
|---|---|---|
| header | Specify the header format of a new table like "|*Food*|*Drink*|". Useful to start a table with only a button | (no header) | 
| format | The format of one column when editing the table. A cell can be a text input field, or any of these edit field types: • Text input field (1 line): | text, <size>, <initial value> |• Textarea input field: | textarea, <rows>x<columns>, <initial value> |• Drop down box: | select, <size>, <option 1>, <option 2>, etc* |*only one item can be selected• Radio buttons: | radio, <size*>, <option 1>, <option 2>, etc |*size indicates the number of buttons per line in edit mode• Checkboxes: | checkbox, <size*>, <option 1>, <option 2>, etc |*size indicates the number of checkboxes per line in edit mode• Fixed label: | label, 0, <label text> |• Row number: | row, <offset> |• Date: | date, <size>, <initial value>, <DHTML date format> |(see Date Field Type) | "text, 16"for all cells | 
| changerows | Rows can be added and removed if "on"Rows can be added but not removed if "add"Rows cannot be added or removed if "off" | CHANGEROWSplugin setting | 
| quietsave | Quiet Save button is shown if "on", hidden if"off" | QUIETSAVEplugin setting | 
| include | Other topic defining the EDITTABLEparameters. The first%EDITTABLE%in the topic is used. This is useful if you have many topics with the same table format and you want to update the format in one place. Usetopicorweb.topicnotation. | (none) | 
| helptopic | Topic name containing help text shown below the table when editing a table. The %STARTINCLUDE% and %STOPINCLUDE% macros can be used in the topic to specify what is shown. | (no help text) | 
| headerislabel | Table header cells are read-only (labels) if "on"; header cells can be edited if"off"or "0" | "on" | 
| editbutton | Set edit button text, e.g. "Edit this table"; set button image with alt text, e.g."Edit table, %PUBURL%/%SYSTEMWEB%/DocumentGraphics/edittopic.gif"; hide edit button at the end of the table with"hide"(Note: Button is automatically hidden if an edit button is present in a cell) | EDITBUTTONplugin setting | 
| buttonrow | Set to topto put the edit buttons above the table. | bottom | 
| javascriptinterface | Use javascript to directly move and delete row without page refresh. Enable with "on", disable with"off". | JAVASCRIPTINTERFACEplugin setting | 
<initial value> (of text input field) and <label text> (of fixed label) get expanded when a new row is added. This can be used for example to add a timestamp to a label. You can escape characters with format tokens if you do not want that.
Any macro inside a table cell will be preserved. For instance, %TOPIC% will not get expanded to the current topic name.
The format tokens are the same as with FormattedSearch:
| Escape: | Expands To: | 
|---|---|
| $nor$n() | New line. Use $n()if followed by alphanumeric character, e.g. writeFoo$n()Barinstead ofFoo$nBar | 
| $nopor$nop() | Is a "no operation". | 
| $quot | Double quote ( ") | 
| $percnt | Percent sign ( %) | 
| $dollar | Dollar sign ( $) | 
 The
The date field type allows one to choose a date with a popup calendar. Popup calendar works with all modern browsers. The date picker button is inactive if the browser cannot support the popup calendar or if Javascript is disabled. 
The optional date format specifiers are described in the JSCalendarContrib documentation. When time specifiers are used, the calendar allows one to choose a date and a time.
In some rare cases, if you pass the date format in %EDITTABLE{format="..."}% and the date format components are adjacent, you must escape the % characters to $percnt to prevent that the components are expanded as macros. For example:
%EDITTABLE{format="|date,15,,$percntY$percntm$percntd|"}%
%EDITCELL{ "type, ..." }% macro at the end of the cell content. This is useful to override the per column %EDITTABLE{ format="..." }% settings, or to create tables with key/value rows. All edit field types of the format="..." parameter are supported. For example, to define a text field, type: | cell content %EDITCELL{ "text, 20" }% |
It is also possible to place the edit button inside a cell instead of default location below the table. Type | %EDITCELL{ "editbutton, 1, Edit this table" }% | to show a button, or | %EDITCELL{ "editbutton, 1, Edit table, Image-URL" }% | to show a button image with alternate text.
Note: The %EDITCELL{ }% macro cannot be used by itself; place an %EDITTABLE{ }% variable at the beginning of a table where you want to use %EDITCELL{ }% variables.
%EDITTABLE{ format="| row, -1 | text, 20, init | select, 1, one, two, three, four | radio, 3,:-),:-I,:-( | label, 0, %SERVERTIME{"$day $mon $year $hour:$min"}% |" changerows="on" }%
%EDITTABLE{ format="| row, -1 | text, 20, init | select, 1, one, two, three, four | radio, 3,:-),:-I,:-( | label, 0, 26 Oct 2025 09:56 |" changerows="on" }%
| Nr | Text field | Drop down | Mood | Timestamp | 
|---|---|---|---|---|
| 1 | hello table | one |   | 26 Jun 2002 12:30 | 
| 2 | two |   | 27 Jun 2002 12:40 | 
| Nr | Text field | Drop down | Mood | Timestamp | 
|---|---|---|---|---|
| 1 |       | 26 Jun 2002 12:30 | ||
| 2 |       | 27 Jun 2002 12:40 | 
%TABLE{"headerrows="1"}%
%EDITTABLE{ format="| label | text, 40 |" changerows="off" }%
|*Key*|*Value*|
| Name: | John Smith |
| Gender: | M %EDITCELL{select, 1, , F, M}% |
| DOB: | 1999/12/31 %EDITCELL{date, 10}% |
| City: | New York |
| You get: | Table in edit mode: | 
|---|---|
|   |   | 
%MAKETEXT{}% are translated into other languages.
| Preference | Meaning | Default   | 
|---|---|---|
| EDITTABLEPLUGIN_JAVASCRIPTINTERFACE | Set to 0 to be disable the ability to directly move and delete row without page refresh. Can be overridden with parameter javascriptinterface | 1 | 
| EDITTABLEPLUGIN_ADD_ROW_BUTTON | Specify button text, oralternate text, image URL. | Add row | 
| EDITTABLEPLUGIN_CANCEL_BUTTON | Specify button text, oralternate text, image URL. | Cancel | 
| EDITTABLEPLUGIN_DELETE_LAST_ROW_BUTTON | Specify button text, oralternate text, image URL. | Delete last row | 
| EDITTABLEPLUGIN_EDIT_BUTTON | Specify button text, oralternate text, image URL. | Edit this table,   | 
| EDITTABLEPLUGIN_CHANGEROWS | Default for change rows flag: on,off,add | on | 
| EDITTABLEPLUGIN_QUIETSAVE | Default flag for quiet save option: onto show the Quiet Save button,offto hide | on | 
| EDITTABLEPLUGIN_QUIET_SAVE_BUTTON | Specify button text, oralternate text, image URL. | Quiet save | 
| EDITTABLEPLUGIN_SAVE_BUTTON | Specify button text, oralternate text, image URL. | Save table | 
| EDITTABLEPLUGIN_INCLUDED_TOPIC_DOES_NOT_EXIST | Default help texts | Warning: 'include' topic does not exist! | 
| ... ||) and cell justification (e.g. |  centered  |   right |)
%EDITTABLE{}% statements on the same line in the source
select,1,%<nop>X%,%<nop>Y%
%EDITTABLE{}% macro may not be split over multiple lines
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.
Test if the Plugin is correctly installed: | 06 Aug 2023: | 4.47: Foswikitask:Item15151: add warnings and strictness | 
| 04 Apr 2017: | 4.46: Item14324: Unescaped left brace - Perl 5.25.10 | 
| 28 Nov 2016: | 4.45: Released with Foswiki 2.1.3 Foswikitask:Item14236: Include compressed and gziped versions of css and js. | 
| 19 Sep 2015: | 4.44: Foswikitask:Item13730: EditTablePlugin uses unescaped braces and calls CGI::param in list context. | 
| 28 Nov 2012: | 4.43: Foswikitask:Item11267: Convert to perl version strings. Release with Foswiki 1.1.6 | 
| 06 Apr 2012: | 4.42: Foswikitask:Item11445: References to Sandboxshould use %SANDBOXWEB% macro. Release with Foswiki 1.1.5. | 
| 05 Dec 2011: | 4.41: Version released with Foswiki 1.1.4. Minor code and documentation cleanup. | 
| 11 Apr 2011: | 4.40: Version released with Foswiki 1.1.3. Only a minor change related to how the plugin is being upgraded | 
| 20 Jan 2011: | 4.39: Arthur Clemens: Foswikitask:Item10274 - Collision between Date formatting and Wiki variables | 
| 06 Dec 2010: | 4.38: Andrew Jones: Foswikitask:Item10126 - Intermittent rendering issues under FastCGI | 
| 06 Nov 2010: | 4.37: Paul Harvey: Foswikitask:Item9963 - Revert usage of $percentback to$percnt | 
| 31 Jul 2010: | 4.35: Paul Harvey: Foswikitask:Item9415 - Documentation updates | 
| 23 Dec 2009: | 4.34: Arthur Clemens: Fixed a problem that the button "Delete last row" would remove newly added rows. | 
| 16 Sep 2009: | 4.33: Kenneth Lavrsen: Removed debug alert when deleting rows | 
| 13 Sep 2009: | 4.32: Arthur Clemens: Fix possible sorting issue on edit screen when no TABLE tag is present. | 
| 02 Sep 2009: | 4.31: Kenneth Lavrsen: Disabled the display of SpreadSheetPlugin "CALC" in headers and footers as this caused the string CALC to be saved instead of the real formular. | 
| 14 Jun 2009: | 4.30: Arthur Clemens: Major code refactoring to let EditTablePlugin work together with SpreadSheetPlugin. | 
| 18 Apr 2009: | 4.22: Ignore all saving unless it happened by saving a form using POST method. Fixed including edit parameters from subwebs. Removed support for settings in the plugin topic which is a bad idea anyway as they get overwritten at each Foswiki upgrade. Define the global settings in Main.SitePreferences instead. | 
| 26 Mar 2009: | 4.21: Fixed a problem with plugin going into deep recursive orbit when a table is followed by text containing vertical bars but not valid table row. | 
| 17 Mar 2009: | 4.20: Fixed several bugs related to use of macros in EDITTABLE and TABLE tags | 
| 08 Feb 2009: | 4.13: Fixed incidental removal of EDITCELLtags when a different table in the topic is edited. Improved display of linebreaks and TML inside cells. | 
| 07 Feb 2009: | 4.12: Protect verbatim class="xxx"during edit. | 
| 16 Dec 2008: | 4.11: Kenneth Lavrsen: Foswiki version | 
| 01 Nov 2008: | 4.9: Arthur Clemens: Fixed rendering of verbatimblocks when editing. Added parameterbuttonrow="top"to allow the buttons to be positioned at the top of the table. | 
| 26 Sep 2008: | 4.8.7: Arthur Clemens: Let empty table initialize more than one column from headerparameter | 
| 24 Sep 2008: | 4.8.6: Arthur Clemens: Fix parsing of header labels | 
| 21 Sep 2008: | 4.8.5: Arthur Clemens: Fix rendering of TML inside label | 
| 03 Aug 2008: | 4.8.4: TWiki 4.2.1 release version | 
| 19 Jul 2008: | 4.8.3: Bugfix release | 
| 20 Mar 2008: | 4.8: Arthur Clemens: Code refactoring; disabled table sort when editing; removed usage of $percntto prevent variable expansion (is now done automatically); made Javascript interface aware of headers and footers, and ofchangerows="off"; improved feedback on row move. | 
| 25 Dec 2007: | 4.7.1: Arthur Clemens: Added warning if includeparameter topic does not exist. | 
| 22 Dec 2007: | 4.7: Arthur Clemens: Changed handling of escaped variables. To escape TWiki variable, use formatting tokens such as $percnt. | 
| 16 Dec 2007: | 4.6: Kenneth Lavrsen: The plugin prevents TablePlugin from initsorting the table being edited. This is done by temporarily appending the attribute disableallsort="on" to the TABLE tag of a table being edited. Additionally all header sorting is disabled while editing a table by setting a hidden formfield sortto "off". Disabling sorting while editing is needed now that the EditTablePlugin supports moving rows up and down. | 
| 01 Dec 2007: | 4.3: Arthur Clemens: added support for TablePlugin headerrowsandfooterrows; updated edit button | 
| 16 Oct 2007: | 4.2: Arthur Clemens: refactoring, bug fixes. | 
| 07 Oct 2007: | 15182: PTh: Added VarEDITTABLE to have it listed in TWikiVariables | 
| 15 Mar 2007: | Arthur Clemens: Fixed eating of double newlines; icons for Javascript buttons and interface improvements. By default the Javascript interface is turned off, set JAVASCRIPTINTERFACEto use it in edit mode. | 
| 05 Mar 2007: | Byron Darrah: Added ability to dynamically move and delete rows. | 
| 12 Oct 2006: | Item2982 Use default date format from JSCalendarContrib | 
| 02 Oct 2006: | Item2884 Check also for access permission in meta data; proper fix to not warn if oneself has a lock on topic | 
| 30 Aug 2006: | Item2829 Remove whitespace from select, radio and checkbox items; restored topic lock if $TWiki::Plugins::VERSION < 1.1 | 
| 29 Jul 2006: | Item2684 - Quietly ignore topic edit locks on table edit | 
| 21 Jan 2006: | TWiki:Main.CrawfordCurrie ported to TWiki-4.0.0, changed to use JSCalendarContrib | 
| 16 Sep 2004: | Added radio buttons and checkbox controls; escaped "|" pipe symbol found in input fields to preserve tables | 
| 01 Aug 2004: | Fixed bug where edittable did not work if at the end of a topic | 
| 07 Apr 2004: | Fixed bug where two tables got updated when you edit and save a table included into a topic containing other edit tables | 
| 02 Mar 2004: | Default for %EDITCELL{editbutton}%is EDITBUTTON preference | 
| 27 Feb 2004: | Added QUIETSAVE setting and quietsaveparameter; image for Edit button | 
| 18 Feb 2004: | Doc fixes; allow edit button anywhere in a cell not just at the end of a cell | 
| 17 Feb 2004: | Added per cell definition of edit field types with %EDITCELL{}%variable; addedheaderislabelandeditbuttonparameters | 
| 20 Dec 2003: | Fixed bug where calendar did not work after adding a row (TWiki:Main/PaulineCheung); added all language files of Mishoo DHTML calendar 0.9.5 | 
| 13 Dec 2003: | Added CHANGEROWS, JSCALENDARDATEFORMAT, JSCALENDARLANGUAGE, JSCALENDAROPTIONS settings | 
| 16 Oct 2003: | small typo fixed (garbled if ---+ header on top) | 
| 15 Oct 2003: | new date field type with Javascript calendar - CN | 
| 14 Oct 2003: | docfix: the documentation page was an old one - CN | 
| 13 Oct 2003: | bugfix: %-vars in select were resetted to first on add/del row - CN | 
| 18 Sep 2003: | incompatibility: changed default of changerowstoon; support for %-vars, Quiet save for saving without notification; all other fixes in Dev topic integrated - CN | 
| 08 Nov 2002: | Prevent variable expansion in label text; added escape characters | 
| 27 Jun 2002: | New helptopicparameter | 
| 26 Jun 2002: | Support for variables in included EDITTABLE parameters; fixed problem with HTML in cells | 
| 21 May 2002: | Added fixed label format; new changerows="add"parameter | 
| 27 Apr 2002: | Fixed bug where text after a double quote in a cell disappeared | 
| 18 Apr 2002: | Fixed bug where table was breaking when pasting multiple lines into an edit field using Netscape on Unix | 
| 08 Apr 2002: | Check for change permission and edit lock of topic | 
| 05 Apr 2002: | Initial version | 
| Author | ProjectContributor | 
| Version | 4.47 | 
| Release | 06 Aug 2023 | 
| Description | Edit tables using edit fields, date pickers and drop down boxes | 
| Repository | https://github.com/foswiki/EditTablePlugin | 
| Copyright | © 2008-2012, Arthur Clemens, 2008-2023, Foswiki Contributors; Copyright © 2002-2007 Peter Thoeny, peter@thoeny.org and TWiki Contributors | 
| License | GPL (GNU General Public License) | 
| Home | http://foswiki.org/Extensions/EditTablePlugin | 
| Support | http://foswiki.org/Support/EditTablePlugin | 
 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.