TinyMCEPlugin

Integration of the TinyMCE WYSIWYG Editor

Introduction

This is an integration of the fast and highly functional TinyMCE WYSIWYG editor. It supports a wide range of browsers such as Firefox, IE, Safari, Opera and Google Chrome - see compatibility chart. This plugin includes TinyMCE version 3.5.8.

The integration uses the WysiwygPlugin to translate text to and from a format that TinyMCE can edit.

This plugin is able to swap out standard text areas and replace them with WYSIWYG editors. This means you get WYSIWYG editors for textareas in forms, as well as for the main text of the topic. It can also co-exist alongside other WYSIWYG editors.

The editor automatically "switches itself off" (i.e. reverts to the old text-only window) when editing topics that contain TWiki content it can't handle, such as complex TWiki variables.

Editor Notes

The editor uses a translator module to convert from TWiki Markup Language (TML) to HTML and back. The translator converts special variables - such as %VARIABLES% - to plain text, and encloses them within HTML spans using a special style called WYSIWYG_PROTECTED. In this way the editor can detect text that is not meant to be HTML formatted. This style is also used to protect special text you enter into the editor from being interpreted when the topic is translated back into TML. If you want to add any special features that are sensitive to formatting, such as Set statements, then you should format those regions using 'Protect on save' or 'Protect forever'.

Installation Instructions

NOTES:

  • This plugin is pre-installed in TWiki. You should only need to re-install if there is an upgrade to the plugin.
  • It requires the very latest revision of the WysiwygPlugin.
  • When installed, it replaces the old "textarea" editor. You may still access the plain text editor with the "Wiki Text" button provided in the toolbar, however this does not necessarily give you the original raw/wiki text version of the topic content. To bypass the TML to HTML conversion process entirely, use the Raw Edit link provided by the default TWiki skin at the bottom of the page.

First follow the installation instructions to install the Plugin:

  • For an automated installation, run the configure script and follow "Find More Extensions" in the in the Extensions section.

  • Or, follow these manual installation steps:
    • Download the ZIP file from the extension home on twiki.org (see below).
    • Unzip TinyMCEPlugin.zip in your twiki installation directory.
    • Set the ownership of the extracted directories and files to the webserver user.
    • Install the dependencies (if any).

  • Plugin configuration and testing:
    • Run the configure script and enable the plugin in the Plugins section.
    • Configure additional plugin settings in the Extensions section if needed.
    • Test if the installation was successful using the examples provided.

  • Enable the WysiwygPlugin in configure.
  • Enable the TinyMCEPlugin in configure.
  • Click on edit of any topic.

Preferences

The default configuration of TinyMCEPlugin should prove sufficient for most users. The TinyMCE editor itself is customized through a Javascript object holding a substantial number of initialization parameters. Up to TinyMCEPlugin version 2011-07-10, a text string making up the Javascript object was held in an ordinary TINYMCEPLUGIN_INIT preferences setting. This setting should be removed and replaced with TINYMCEPLUGIN_INIT_TOPIC (described below).

TINYMCEPLUGIN_INIT_TOPIC

To make configuration easier and less error-prone, configuration is held in a topic section. The name of the topic is set in the TINYMCEPLUGIN_INIT_TOPIC preferences setting, from which the section named TINYMCEPLUGIN_INIT is used. TINYMCEPLUGIN_INIT_TOPIC setting is currently set to TWiki.TinyMCEPlugin.

For a full explanation and guidance on configuration of available TinyMCE options, see the Moxicode TinyMCE Wiki.

Below is the default configuration. If it is to be modified, it should be copied (including %START/ENDSECTION{}% macros) to a different topic to avoid customizations being overwritten when TinyMCEPlugin is upgraded.

TINYMCEPLUGIN_INIT

%STARTSECTION{"TINYMCEPLUGIN_INIT"}%
"mode" : "textareas",
"editor_selector" : "twikiTextarea",
"save_on_tinymce_forms" : true,
"table_default_cellpadding" : 0,
"table_default_cellspacing" : 1,
"table_default_border" : 1,
"theme" : "advanced",
"convert_urls" : true,
"relative_urls" : false,
"remove_script_host" : false,
"dialog_type" : "modal",
"extended_valid_elements" : "li[type],a[rel|rev|charset|hreflang|tabindex|accesskey|type|name|href|target|title|class|onfocus|onblur|data*]",
"setupcontent_callback" : "TWikiTiny.setUpContent",
"urlconverter_callback" : "TWikiTiny.convertLink",
"twikipuburl_callback" : "TWikiTiny.convertPubURL",
"save_callback" : "TWikiTiny.saveCallback",%IF{
    "$TINYMCEPLUGIN_DEBUG"
    then="
\"debug\" : true,"
}%
"plugins" : "%IF{
    "defined 'TINYMCEPLUGIN_MCEPLUGINS'"
    then="%TINYMCEPLUGIN_MCEPLUGINS%"
    else="%STARTSECTION{"MCEPLUGINS"}%contextmenu, table, searchreplace, autosave, paste, legacyoutput, inlinepopups, fullscreen, -twiki, -twikibuttons, -twikiimage%ENDSECTION{"MCEPLUGINS"}%"
}%%IF{
    "defined 'TINYMCEPLUGIN_ADDITIONAL_MCEPLUGINS'"
    then=", %TINYMCEPLUGIN_ADDITIONAL_MCEPLUGINS%"
}%",
"twiki_plugin_urls" : {
    "twiki" : "%PUBURLPATH%/%SYSTEMWEB%/TinyMCEPlugin/plugins/twiki/editor_plugin%IF{"$TINYMCEPLUGIN_DEBUG" then="_src"}%.js",
    "twikibuttons" : "%PUBURLPATH%/%SYSTEMWEB%/TinyMCEPlugin/plugins/twikibuttons/editor_plugin%IF{"$TINYMCEPLUGIN_DEBUG" then="_src"}%.js",
    "twikiimage" : "%PUBURLPATH%/%SYSTEMWEB%/TinyMCEPlugin/plugins/twikiimage/editor_plugin%IF{"$TINYMCEPLUGIN_DEBUG" then="_src"}%.js"
 },
"twiki_secret_id" : "%WYSIWYG_SECRET_ID%",
"twiki_vars" : {
    "PUBURLPATH" : "%PUBURLPATH%",
    "PUBURL" : "%PUBURL%",
    "WEB" : "%BASEWEB%",
    "TOPIC" : "%BASETOPIC%",
    "ATTACHURL" : "%PUBURL%/%BASEWEB%/%BASETOPIC%",
    "ATTACHURLPATH" : "%PUBURLPATH%/%BASEWEB%/%BASETOPIC%",
    "VIEWSCRIPTURL" : "%SCRIPTURL{view}%",
    "SCRIPTSUFFIX" : "%SCRIPTSUFFIX%",
    "SCRIPTURL" : "%SCRIPTURL%",
    "SYSTEMWEB" : "%SYSTEMWEB%"
},
"theme_advanced_toolbar_align" : "left",
"twikibuttons_formats" : {
    /* Use 'attributes : { class : "foo" }' instead of 'classes: "foo"'
     * because this is how it's done in the default advanced theme shipped
     * with TinyMCE which seems to be a few ms faster on cursor movement
     */
    "Normal" : { "remove" : "all" },
    "Heading 1" : { "block" : "h1",  "remove" : "all" },
    "Heading 2" : { "block" : "h2",  "remove" : "all" },
    "Heading 3" : { "block" : "h3",  "remove" : "all" },
    "Heading 4" : { "block" : "h4",  "remove" : "all" },
    "Heading 5" : { "block" : "h5",  "remove" : "all" },
    "Heading 6" : { "block" : "h6",  "remove" : "all" },
    "VERBATIM"  : { "block" : "pre", "remove" : "all", "attributes" : { "class" : "TMLverbatim" } }, 
    "LITERAL"   : { "block" : "div", "remove" : "all", "attributes" : { "class" : "WYSIWYG_LITERAL" } },
    "Protect on save" : { "block" : "div", "remove" : "all", "attributes" : { "class" : "WYSIWYG_PROTECTED" } },
    "Protect forever" : { "block" : "div", "remove" : "all", "attributes" : { "class" : "WYSIWYG_STICKY" } }
},
"twikibuttons_cursoridletime" : 250,
"paste_create_paragraphs" : true,
"paste_create_linebreaks" : false,
"paste_convert_middot_lists" : true,
"paste_convert_headers_to_strong" : false,
"paste_remove_spans" : true,
"paste_remove_styles" : true,
"paste_strip_class_attributes" : "all",
"theme_advanced_buttons1" : "%IF{
    "defined 'TINYMCEPLUGIN_BUTTONS1'"
    then="%TINYMCEPLUGIN_BUTTONS1%"
    else="%STARTSECTION{"BUTTONS1"}%twikiformat, separator, bold, italic, tt, colour, removeformat, separator, bullist, numlist, %IF{"context SUPPORTS_PARA_INDENT" then="fwexdent, fwindent" else="outdent, indent"}%, blockquote, separator, link, unlink, anchor, separator, undo, redo, separator, search, replace%ENDSECTION{"BUTTONS1"}%"
}%%IF{
    "defined 'TINYMCEPLUGIN_ADDITIONAL_BUTTONS1'"
    then=", %TINYMCEPLUGIN_ADDITIONAL_BUTTONS1%"
}%",
"theme_advanced_buttons2" : "%IF{
    "defined 'TINYMCEPLUGIN_BUTTONS2'"
    then="%TINYMCEPLUGIN_BUTTONS2%"
    else="%STARTSECTION{"BUTTONS2"}%tablecontrols, separator, attach, image, charmap, hr, separator, restoredraft, fullscreen, code, hide%ENDSECTION{"BUTTONS2"}%"
}%%IF{
    "defined 'TINYMCEPLUGIN_ADDITIONAL_BUTTONS2'"
    then=", %TINYMCEPLUGIN_ADDITIONAL_BUTTONS2%"
}%",
"theme_advanced_buttons3" : "%IF{
    "defined 'TINYMCEPLUGIN_BUTTONS3'"
    then="%TINYMCEPLUGIN_BUTTONS3%"
}%%IF{
    "defined 'TINYMCEPLUGIN_ADDITIONAL_BUTTONS3'"
    then=", %TINYMCEPLUGIN_ADDITIONAL_BUTTONS3%"
}%",
"setup" : function(ed) {
    /* example custom button; list this named button in TINYMCEPLUGIN_ADDITIONAL_BUTTONS1 setting */
    ed.addButton('helloworld', {
        title : 'Hello world',
        image : '%ICONURLPATH{globe}%',
        onclick : function() {
            ed.focus();
            ed.selection.setContent('Hello world!');
        }
    });
},
"autosave_interval" : "%IF{
    "defined 'TINYMCEPLUGIN_AUTOSAVE_INTERVAL'"
    then="%TINYMCEPLUGIN_AUTOSAVE_INTERVAL%"
    else="%STARTSECTION{"AUTOSAVE_INTERVAL"}%180s%ENDSECTION{"AUTOSAVE_INTERVAL"}%"
}%",
"autosave_retention" : "%IF{
    "defined 'TINYMCEPLUGIN_AUTOSAVE_RETENTION'"
    then="%TINYMCEPLUGIN_AUTOSAVE_RETENTION%"
    else="%STARTSECTION{"AUTOSAVE_RETENTION"}%4320m%ENDSECTION{"AUTOSAVE_RETENTION"}%"
}%",
"entity_encoding" : "%IF{
    "defined 'TINYMCEPLUGIN_ENTITY_ENCODING'"
    then="%TINYMCEPLUGIN_ENTITY_ENCODING%"
    else="%STARTSECTION{"ENTITY_ENCODING"}%numeric%ENDSECTION{"ENTITY_ENCODING"}%"
}%",
"theme_advanced_toolbar_location" : "top",
"theme_advanced_resize_horizontal" : false,
"theme_advanced_resizing" : true,
"theme_advanced_path" : false,
"theme_advanced_statusbar_location" : "bottom",
"skin" : "%IF{
    "defined 'TINYMCEPLUGIN_MCESKIN'"
    then="%TINYMCEPLUGIN_MCESKIN%"
    else="%STARTSECTION{"MCESKIN"}%o2k7%ENDSECTION{"MCESKIN"}%"
}%",
%IF{
    "defined 'TINYMCEPLUGIN_MCESKIN_VARIANT' AND $'TINYMCEPLUGIN_MCESKIN_VARIANT'"
    then="\"skin_variant\" : \"%TINYMCEPLUGIN_MCESKIN_VARIANT%\",$n"
    else="%IF{
      "NOT defined 'TINYMCEPLUGIN_MCESKIN' OR $'TINYMCEPLUGIN_MCESKIN'='o2k7'"
      then="\\"skin_variant\\" : \\"%STARTSECTION{"MCESKIN_VARIANT"}%silver%ENDSECTION{"MCESKIN_VARIANT"}%\\",$dollarn"
    }%"
}%"keep_styles" : false,
"content_css" : "%PUBURLPATH%/%SYSTEMWEB%/TinyMCEPlugin/wysiwyg%IF{
    "$TINYMCEPLUGIN_DEBUG"
    then="_src"
}%.css,%PUBURLPATH%/%SYSTEMWEB%/TWikiTemplates/base.css,%TWIKISTYLEURL%,%TWIKICOLORSURL%"
%ENDSECTION{"TINYMCEPLUGIN_INIT"}%

How to customize these settings:

  • Create a TinyMCEPluginSettings topic in the Main web, and copying above text.
  • Update the TINYMCEPLUGIN_INIT_TOPIC variable to point to the newly created topic, e.g. in TWikiPreferences or MyWeb.WebPreferences:
       * Set TINYMCEPLUGIN_INIT_TOPIC = Main.TinyMCEPluginSettings

Settings

Variable Default Description
TINYMCEPLUGIN_INIT - A string holding the TinyMCE initialisation object. If set, TINYMCEPLUGIN_INIT_TOPIC is ignored
TINYMCEPLUGIN_INIT_TOPIC TWiki.TinyMCEPlugin The fully qualified Web.Topic containing a section named TINYMCEPLUGIN_INIT which holds the TinyMCE initialisation parameters
TINYMCEPLUGIN_MCEPLUGINS contextmenu, table, searchreplace, autosave, paste, legacyoutput, inlinepopups, fullscreen, -twiki, -twikibuttons, -twikiimage Comma separated list of TinyMCE plugins to initialize
TINYMCEPLUGIN_ADDITIONAL_MCEPLUGINS   Comma separated list of additional TinyMCE plugins to initialize.
TINYMCEPLUGIN_BUTTONS1 twikiformat, separator, bold, italic, tt, colour, removeformat, separator, bullist, numlist, outdent, indent, blockquote, separator, link, unlink, anchor, separator, undo, redo, separator, search, replace Comma separated list of toolbar buttons (in order) for the first, second and third rows (of buttons)
TINYMCEPLUGIN_BUTTONS2 tablecontrols, separator, attach, image, charmap, hr, separator, restoredraft, fullscreen, code, hide
TINYMCEPLUGIN_BUTTONS3  
TINYMCEPLUGIN_ADDITIONAL_BUTTONS1,
TINYMCEPLUGIN_ADDITIONAL_BUTTONS2,
TINYMCEPLUGIN_ADDITIONAL_BUTTONS3
  Comma separated list of toolbar buttons (in order) to be appended to the end of a button row
TINYMCEPLUGIN_AUTOSAVE_RETENTION 4320m Autosave drafts stored in the web browser are expired after this length of time (minutes or seconds). See autosave plugin notes
TINYMCEPLUGIN_AUTOSAVE_INTERVAL 180s Frequency (in minutes or seconds) that the autosave plugin updates the draft stored in the web browser
TINYMCEPLUGIN_INIT_browser See Browser Specific Settings below Add extra parameters to TINYMCEPLUGIN_INIT string for a specific _browser
EDITMETHOD wysiwyg Set to wysiwyg to use the WYSIWYG editor (default), or set to raw to use the raw text area editor
TINYMCEPLUGIN_DISABLE 0 If set to 1, disables TinyMCEPlugin. Please use EDITMETHOD instead
NOWYSIWYG 0 If this global setting is set to 1, TinyMCEPlugin (and all other WYSIWYG editors) will be disabled. Please use EDITMETHOD instead
TINYMCEPLUGIN_BAD_BROWSERS (?i-xsm:Konqueror) A regular expression that matches the user-agent string of any browser for which TinyMCE should not be loaded.
TINYMCEPLUGIN_DEBUG 0 If set to 1, the uncompressed version of TinyMCE Javascript and CSS sources will be loaded by the browser. Useful for debugging.
TINYMCEPLUGIN_ENTITY_ENCODING numeric Controls how entities/characters get processed by TinyMCE. Allowed values: named, numeric, raw
TINYMCEPLUGIN_MCESKIN o2k7 The TinyMCE skin to use. Possible values: default, highcontrast, o2k7
TINYMCEPLUGIN_MCESKIN_VARIANT silver A TinyMCE skin may have variants. o2k7 skin has silver and black variants.

Browser Specific Settings

Additional options may be set for specific browsers. You can define extra options for MSIE, OPERA, GECKO and SAFARI. For example,

   * Set TINYMCEPLUGIN_INIT_MSIE = "paste_auto_cleanup_on_paste" : false 
The defaults are:
    MSIE => '',
    OPERA => '',
    GECKO => '"gecko_spellcheck" : true',
    SAFARI => '',
    CHROME => ''

TinyMCE Plugins & Toolbar Buttons

Documentation for standard plugins shipped with TinyMCE can be found at http://wiki.moxiecode.com/index.php/TinyMCE:Plugins.

Documentation for standard theme_advanced toolbar buttons (Eg. superscript/subscript, strikethrough, highlight colours etc) can be found at http://wiki.moxiecode.com/index.php/TinyMCE:Control_reference.

Default Plugins

These plugins are enabled by default in the standard distribution of TWiki.

Plugin Name Toolbar buttons Description Notes
autosave restoredraft Saves the editor content to your web browser's local storage periodically so that it may be restored later See TINYMCEPLUGIN_AUTOSAVE_INTERVAL and defaults to 180s; TINYMCEPLUGIN_AUTOSAVE_RETENTION defaults to 4320m
contextmenu   Provides context (right-click) menu capability Allows the table plugin to offer copy & paste of rows & columns  
twiki - Fixup TinyMCE bugs, TWiki integration issues init param twiki_autosave_no_fixup prevents fixup of autosave plugin if true; only works if twiki is after autosave in the plugins list
twikibuttons tt, colour, attach, hide Provides toolbar buttons, dialogues and formatting styles for TWiki List of formats populated from twikibuttons_formats init param; ms of cursor idle time required before update of toolbar buttons/format state is set from twikibuttons_cursoridletime param
twikiimage image Provides image toolbar button, dialogue for TWiki  
fullscreen fullscreen Provides fullscreen capability  
legacyoutput   Maintains compatibility for <font>, <u>, <b>, <strike> etc. tags  
paste pastetext, pasteword, selectall "Cleans" content pasted from clipboard; useful when pasting from MS Office  
searchreplace search, replace Refer to TinyMCE documentation  
table tablecontrols, others Refer to TinyMCE documentation  

Additional Plugins

To enable extra plugins, set the TINYMCEPLUGIN_ADDITIONAL_MCEPLUGINS variable in your Main.TWikiPreferences. If the plugin also offers a toolbar button, you will need to add it into the appropriate place in the TINYMCEPLUGIN_ADDITIONAL_BUTTONS* variables.

For example, to make use of the emotions and wordcount plugins add the following to Main.TWikiPreferences:

---++ TinyMCE customizations

   * Set TINYMCEPLUGIN_ADDITIONAL_MCEPLUGINS = emotions, wordcount
   * Set TINYMCEPLUGIN_ADDITIONAL_BUTTONS2 = emotions

Some notable plugins:

Plugin Name Toolbar buttons Description Notes
autoresize - Automatically resizes the editor to the content inside it  
emotions emotions Insert smiley images into the TinyMCE editable area  
iespell iespell Provides spell check for Internet Explorers  
insertdatetime insertdate, inserttime Provides buttons to insert customized date and time strings  
media media Handles embedded media such as QuickTime, Flash, ShockWave, RealPlayer and Windows Media Player Requires customisation of edit templates
spellchecker spellchecker Adds spellchecker functionality to TinyMCE by providing a new button that performs a AJAX call to a backend PHP page that uses PSpell/ASpell or Google spellchecker  
style styleprops Adds CSS style editing support to TinyMCE, this will enable you to edit almost any CSS style property in a visual way. Generally, HTML/CSS markup in topics is not desirable
visualchars visualchars Adds the possibility to see invisible characters like &nbsp;  
wordcount - Display the number of words down in the right corner of the editor.  
xhtmlxtras cite, ins, del, abbr, acronym Adds support for some XHTML elements, including cite, ins, del, abbr, and acronym. Generally, XHTML markup in topics is not desirable. TWiki plugins exist to provide similar functions with more friendly TML markup

Frequently Asked Questions

The topic TinyMCEFrequentlyAskedQuestions contains more help with things like: "How do I configure the buttons in my skin?", "How do I disable the WYSIWYG?" etc.

WysiwygPlugin Settings

See WysiwygPluginSettings for more information

Upgrading TinyMCEPlugin older than version 2013-09-12

The TINYMCEPLUGIN_INIT string needs to be built differently, due to the API change affecting the way custom formats are applied in TinyMCE 3.3.x since 3.2.x

If a customized TINYMCEPLUGIN_INIT string is in use, it should be re-built based on the content of this documentation. The customizations should be reviewed to determine if they are still necessary.

Known Issues of TinyMCEPlugin

  • TWiki introduces errant spaces into table cells
  • X11 environments: TinyMCEPlugin editor copies current topic onto the "Primary Selection"
  • Outdenting list items in Firefox soemtimes does not work correctly
    • Description: The list symbol (number, bullet, etc) sometimes disappears from the item after being outdented. When this happens, it is also not possible to outdent the item another level.
    • Work-around: Position the cursor to the beginning of the line (where the symbol should appear) and press the enter key. The symbol should be restored and another outdent will be possible.
  • After inserting new table at top of document: unable to position cursor above
    • Work-around: Use 'Save and continue' or switch to WikiText and back to WYSIWYG again to allow WysiwygPlugin to add an empty <p/> above the table
  • International characters (example, Š) are converted to HTML entities (IE. &Scaron; or &#352;)
    • Ensure you are using the latest version of WysiwygPlugin, check TWiki:Plugins.WysiwygPlugin.
    • Work-around: Try changing the TINYMCEPLUGIN_ENTITY_ENCODING setting to raw. It's possible this may cause problems on older browsers.

Known Issues of WysiwygPlugin (partial list)

For the full list, consult WysiwygPlugin documentation

  • Anchors are not handled by WysiwygPlugin
  • WysiwygPlugin fails to roundtrip tables with align="center", border attributes, etc.
    • Description: Sometimes tables will fail to be converted to TML syntax (will stay as HTML) because there are attributes on the table (such as alignment or border decorations) that the WysiwygPlugin does not know how to preserve. If such attributes are necessary, please use VarTABLE instead.
    • Work-around:
      • Click inside the problematic table
      • Click the table toolbar button (usually used to create a new table)
      • With the exception of Cols and Rows, delete/reset all content from the fields on the 'General' and 'Advanced' tabs.
      • Write a VarTABLE variable above the offending table that adds the desired attributes safely

Check TWiki:Plugins.TinyMCEPlugin for updates.

Plugin Info

Author: Crawford Currie
Copyright: © 2007-2010 Crawford Currie http://c-dot.co.uk
© 2010-2012 Foswiki Contributors
© 2007-2018 Peter Thoeny and TWiki:TWiki.TWikiContributor
License: GPL (Gnu General Public License)
  This package also includes the complete sources for version 3.4.9 of the TinyMCE editor which is covered by its own license.
Sponsors: ILOG, Carrier Corporation, Twiki Inc, Wave Systems Corp
Plugin Version: 2018-07-10
2018-07-10: TWikibug:Item7841: Copyright update to 2018
2016-01-13: TWikibug:Item7710: Document how to add custom toolbar button to TinyMCE editor -- TWiki:Main.PeterThoeny
2016-01-09: TWikibug:Item7708: Copyright update to 2016
2015-02-16: TWikibug:Item7604: Switch from GPL v2 to v3
2013-09-18: TWikibug:Item7339: Upgrade to TinyMCE 3.5.8 -- TWiki:Main.PeterThoeny
2013-09-13: TWikibug:Item7339: Import TinyMCE plugin fixes 2008-2013; upgrade to TinyMCE 3.4.9 -- TWiki:Main.PeterThoeny
2013-07-19: TWikibug:Item7300: Plugin to be conditionally disabled -- TWiki:Main.HideyoImazu
21 Dec 2012 (1.2.9) Changing a wikiword should not require visiting the TinyMCE link dialog. Changes TINYMCEPLUGIN_INIT settings
28 Nov 2012 (1.2.8) Add missing syntax highlighting classes, and make menus more user friendly.
Convert to perl version strings
Clean up hex markers left behind by TinyMCEPlugin Editor
22 May 2012 (1.2.7) Upgrade to TinyMCE 3.4.9
Add watermark for hidden blocks
Set initial table defaults consistent with TWiki defaults
23 Mar 2012 (1.2.6) Strike-out <del>, <s> tags are lost in WYSIWYG transition
Add Javascript callbacks to get notified after editor changes to/from Raw or WYSIWYG mode.
Allow templates to control WYSIWYG button placement.
"Please wait... retrieving page from server" looks too much like an error. Change to "Loading" JS Animation
Cannot edit on IE8.
22 Dec 2011 (1.2.5) Fix JS autosave error in IE7 when editing topics in nested webs
19 Dec 2011 (1.2.4) Added support for indented plain paragraphs. NOTE: requires an update to TINYMCEPLUGIN_INIT, if you have customized it.
22 Nov 2011 (1.2.3) Remove bogus dependency on BehaviourContrib
08 Nov 2011 (1.2.2) Update to TinyMCE 3.4.7.
24 Sep 2011 (1.2.1) Testing release of TinyMCE 3.4.6.
Fixed in TinyMCE 3.4 (copy and paste list items)
20 Aug 2011 (1.2.0) Testing release of TinyMCE 3.4.4
05 Dec 2011 (1.1.12) Prevent save if in fullscreen mode. Other minor code cleanup.
22 Nov 2011 (1.1.11) Remove bogus dependency on BehaviourContrib
10 May 2011 (1.1.10) Revert back to TinyMCE 3.3.9.3; 3.3.9.4 caused JS errors in IE8
09 May 2011 (1.1.9) Update to TinyMCE 3.3.9.4
11 Apr 2011 (1.1.8) Version released with TWiki 1.1.3. Only a minor change related to how the plugin is being upgraded
19 Jan 2011 (1.1.7) Update to TinyMCE 3.3.9.3 and switch to using x.y.z version numbering
Fix problem where topic names with international characters prevented attach dialogue working correctly
Added TINYMCEPLUGIN_ENTITY_ENCODING setting; default to numeric
JS fix for deleting encoded-TML-whitespace on Firefox
2010-11-05 TWikibug:Item6604: Add documentation for EDITMETHOD setting -- TWiki:Main.PeterThoeny
04 Nov 2010 Upgrade to TinyMCE 3.3.9.2
Fix JS error transitioning to WikiText from fullscreen
Fix bold & italics buttons not activating on already bolded/italicized text properly
Fix JS error switching tabs on the attach dialogue
25 Oct 2010 Fix JS error on Internet Explorers
28 Sep 2010 Enable contextmenu TinyMCE plugin, allows table row/column copy & paste
Fix autosave breaking on IECollections' IE6
Use non-jQuery build to avoid IE8 resizing quirks on jquery-1.3.2
Only update button state if cursor has been idle > 300ms, improves cursor movement responsiveness in >250KiB documents on IE/slow PCs
Documentation updates
Make table text larger, to be the same size as normal paragraph text
Apply background to protected and literal text (similar to verbatim), so that it is easier to see these special regions
01 Jul 2010 Fix colour formatting problem and JS error transitioning to fullscreen
Fix autosave implementation compatibility with TWiki 1.0.x JQueryPlugin
Upgrade to TinyMCE 3.3.8
28 Jun 2010 Fix applying non-heading formats in TinyMCE 3.3
Change attach dialogue button text from 'cancel' to 'close'
Improve attach dialogue usability: auto-refresh attachment list after switching from upload tab; auto-select upload tab if there are zero existing attachments
Fix dialogue window sizes are too small for link, attachments and colour dialogues
Replace TINYMCEPLUGIN_INIT in favour of TINYMCEPLUGIN_INIT_TOPIC sections
Fix misbehaving %AQUA% colour in the colours dialogue; grouped standard colours separate to extended colours
Make autosave plugin functional
Fixed in TinyMCE 3.3: (IE only) Cursor jumps to beginning of document unintendedly
Fixed in TinyMCE 3.3: TinyMCE strips out 'type' arguments when pasting TWiki variables from MS Word
2010-04-24 TWikibug:Item6433: Doc improvements, prepare for TWiki 5.0 release
20 Mar 2010 Change TWiki integration to use more JQueryPlugin features. Fixes bug where IE6 users with latest NatSkin get: "Unable to install TinyMCE; <META..."
05 Mar 2010 Upgrade to TinyMCE 3.3, TWiki now uses jQuery version
19 Feb 2010 Fix for sites with latest JQueryPlugin where IE users get: "Unable to install TinyMCE; <META..."
24 Jan 2010 add TINYMCEPLUGIN_ADDITIONAL_MCEPLUGINS and TINYMCEPLUGIN_BUTTONS(123) to allow wiki, web and topic specific plugins to be added SD
29 Dec 2009 Fix unable to apply "Normal" format in some browsers (notes added to System topic).
Block attachments to unsaved AUTOINC topics
25 Nov 2009 Inserting images - fixed a problem where it wasn't easy (impossible unless > 1 attachments) to select the first image in the attachment list; improved layout of dialog window where preview obscures insert/cancel buttons.
09 Nov 2009 Added blockquote button and rearranged toolbars slightly; cleaned up System topic
29 Oct 2009 Updated documentation, removed redundant setting: paste_auto_cleanup_on_paste : true for MSIE browsers (TinyMCE now defaults to true for all browsers)
21 Oct 2009 TinyMCE project now supports Opera, so remove it from _BAD_BROWSERS
18 Oct 2009 Fix wordcount plugin to show correct count when user first enters edit mode
17 Oct 2009 Upgrade to TinyMCE 3.2.7
20 Sep 2009 Remove 2 MB of developer files that are not used
19 Sep 2009 Fix fullscreen-to-WikiText transition
18 Sep 2009 Fixed a problem where editor wants to put text elements into blocks causing unwanted new lines.
Fixed a problem so that editor does not convert TML lettered and roman numeral lists back to numbered lists.
2009-09-08 TWikibug:Item6334: Upgrade plugin to latest TinyMCE version 3.2.4.1 from 2.1.1.1 -- TWiki:Main.SopanShewale
03 Jul 2009 Check that the help elements are present before hiding or showing them, as they are not present in all skins.
06 Jun 2009 Make browser reload the javascript when this plugin is upgraded (Michael Tempest, Colas Nahaboo). Disable "Wiki text" button until editor has loaded topic text (Michael Tempest)
24 May 2009 add support for global NOWYSIWYG flag. keep TML lettered & roman numeral lists (Michael Tempest). fix typewriter text (Michael Tempest). fix data-loss warning when saving from wiki-text (Michael Tempest)
10 Apr 2009 fixed colour handling. added safari,inlinepopups,fullscreen plugins, fixed some minor bugs on IE
03 Apr 2009 Optimized the preferences. fixed the pickaxe
15 Mar 2009 Crawford Currie upgraded to Tiny MCE 3.2.2 and recoded all the standard plugins that had to be recoded
21 Jan 2009 added SYSTEMWEB to twiki_vars, simplifying the activation of the twikilink dialog of TinyMCEUsabilityUpgradePlugin - Eugen Mayer
06 Dec 2008 removed XHR headers that were banjaxing NTLM - Eugen Mayer
03 Aug 2008 TWiki 4.2.1 release version
04 May 2008 TWikibug:Item5547: Change mechanism by which TMCE recognizes textareas to camp on. Use class instead of element name.
12 Apr 2008 TWikibug:Item4946: I think I have finally fixed non-iso-8859-1 character sets. Painful.
31 Mar 2008 TWikibug:Item5314: TWikibug:Item5457: Fixed pickaxe mode for editing UTF-8. Characters above 255 are converted to entitites, which is a bit of a PITA, but at least it no longer corrupts topics. NOTE: YOU MUST UPGRADE WysiwygPlugin TO 16600 OR LATER
28 Mar 2008 TWikibug:Item5432: added upper case file extensions for images TWikibug:Item5206: fixed expansion of simple filenames entered in image popup TWikibug:Item5462: fixed hide attachment switch
25 Jan 2008 TWikibug:Item5287: links entered through dialog weren't working
24 Jan 2008 TWikibug:Item4840: TWikibug:Item5138: UTF8 fixes, TWikibug:Item5022: made TT font size same as verbatim. Had to add a new style to do it, as TMCE didn't want to play with TT or CODE tags. TWikibug:Item5138: post-conversion of 8-bit entities to characters to aid searching, TWikibug:Item5254: non-fatal JS error fixed, TWikibug:Item5263: remove preview on WYSIWYG edit, TWikibug:Item5116: added Opera to bad browsers filter
20 Dec 2007 TWikibug:Item5047: disable save and preview during page load TWikibug:Item5111: make the entry in the format menu sensitive to where the cursor is TWikibug:Item5022: made TT font size same as verbatim. Had to add a new style to do it, as TMCE didn't want to play with TT or CODE tags.
19 Nov 2007 TWikibug:Item4742: auto-disable if Wysiwyg is not enabled TWikibug:Item4820: validate mandatory fields on save TWikibug:Item4747: add <sticky> TWikibug:Item4811: noautolink looks like an HTML construct but in fact is not; the tag is infact an "on-off" switch and does not imply any HTML structure, so cannot be converted to a DIV or a span, so has to be removed. TWikibug:Item4817: added typewriter text button TWikibug:Item4850: added font colour controls TWikibug:Item4645: added attachment management features TWikibug:Item4945: added switch to raw and back
16 Sep 2007 TWikibug:Item4630: polished up the way the secret string is done, to ensure synch between perl and JS. TWikibug:Item4622: added UTF-8 handling steps that fixup malformed UTF8 strings before presenting them to the editor (saves Moz) and stops the editor passing them back to TWiki (saves IE). TWikibug:Item4603: added the draft help, so we can at least build the beta without the nasty warning
13 Sep 2007 TWikibug:Item4613 fixed navigate-away prompt when unchanged TWikibug:Item4583 TWikibug:Item4604 TWikibug:Item4614 TWikibug:Item4616 A clutch of issues caused by use of the wrong encoding function when passing UTF8 parameters to REST using XMLHttpRequest.
12 Sep 2007 TWikibug:Item4604 Converted to REST call for content conversion, to provide safe callback if JS is disabled in the browser TWikibug:Item4583 relaxed regex to try and make it work for UTF-8 topic names
11 Sep 2007 TWikibug:Item4535 refinements to link handling to improve topic name recognition
07 Sep 2007 TWikibug:Item4503 excess empty lines TWikibug:Item4486 no toc headers with unofficial syntax TWikibug:Item4560: empty lines lost TWikibug:Item4566: corrupted table on save
06 Sep 2007 TWikibug:Item4557 added missing files to package
04 Sep 2007 TWikibug:Item4534 TWikibug:Item4535 fixed
14679 TWikibug:Item4481 TWikibug:Item4524 fixed
14668 Bugfixes and refinements done as part of 4.2 release
14543 Added PROTECTED style, to allow protection of special text. Disable on unsupported browsers (untested)
14538 First release
Dependencies:
NameVersionDescription
TWiki::Plugins::WysiwygPlugin>=1Translator module
TWiki::Plugins::JQueryPlugin>=1jQuery library
Plugin Home: http://twiki.org/cgi-bin/view/Plugins/TinyMCEPlugin
Feedback: http://twiki.org/cgi-bin/view/Plugins/TinyMCEPluginDev
Appraisal: http://twiki.org/cgi-bin/view/Plugins/TinyMCEPluginAppraisal

Related Topics: TinyMCEFrequentlyAskedQuestions, TinyMCEQuickHelp, WysiwygPlugin, TWikiPreferences, TWikiPlugins

Edit | Attach | Watch | Print version | History: r17 < r16 < r15 < r14 < r13 | Backlinks | Raw View | Raw edit | More topic actions
Topic revision: r17 - 2018-07-10 - TWikiContributor
 
This site is powered by the TWiki collaboration platform Powered by PerlCopyright © 1999-2024 by the contributing authors. All material on this collaboration platform is the property of the contributing authors.
Ideas, requests, problems regarding TWiki? Send feedback
Note: Please contribute updates to this topic on TWiki.org at TWiki:TWiki.TinyMCEPlugin.