360 lines
18 KiB
Markdown

# Change History
This document tracks the enhancements and bug fixes between releases of
WYMeditor.
## 1.0.0b5 (Beta 5)
*release-date* July 31, 2013
### Enhancements
* We now have all of the documentation in one place at
[wymeditor.readthedocs.org](https://wymeditor.readthedocs.org)! No more
switching back and forth between the old Trac site and the github Wiki. The
new documentation uses [Sphinx](http://sphinx-doc.org/) and new pull
requests will now be able to come with `docs/` already committed! Thanks to
Nick McLaughlin for the herculean effort in combining the years of spread-out
documentation.
* We now document how to run WYMeditor with jQuery 1.8.x and 1.9.x via
[jquery-migrate](https://github.com/jquery/jquery-migrate/). The unit tests
now also support those versions of jQuery.
* Some community members have created a
[Django-CMS 3](https://github.com/wymeditor/djangocms_wymeditor_plugin)
plugin for WYMeditor. If you're upgrading from Django-CMS 2 to 3, you'll want
to check it out.
* Tables can now be inserted and used in lists. Previously, the editor would
not let the user insert a table anywhere in a list, but now, the user can
insert a table at any point in a list or sublist and can even insert multiple
tables in the same list item. In addition, the tables should properly indent,
outdent, and space themselves within a list.
* Elements in the editor can now easily be flagged to be removed from the
editor output by the XHTML parser. This allows elements to be "editor-only"
in the sense that they will be visible in the editor but not included in the
outputted XHTML from the editor. Simply add the class
`WYMeditor.EDITOR_ONLY_CLASS` to an element to specify it to be removed by
the XHTML parser in this manner.
* Classes can now be specified to be removed from tags' `class` attribute by
the XHTML parser. Simply add a string for each of the class names to remove
to the `WYMeditor.CLASSES_REMOVED_BY_PARSER` array, and the XHTML parser will
remove all of those classes from all the tags in the editor's output.
* `div` elements are now visible and labeled in the editor so that they can
easily be worked with. In addition, `div` containers can now be switched to
other container types using the containers panel. This change was made to
allow for the addition of the selectable default root container feature
described in the following point.
* The default root container used by the editor can now be specified as
an option to be either `p` or `div`. The specified container for this option
will be used by default when an unspecified new container is created in the
root of the editor, and it will also be used as the default container for
wrapping any text or inline elements inserted directly into the editor body.
In addition, the editor will enforce that the unchosen option for the
default root container is not allowed in the root of the document by
converting the unchosen default root container to the chosen default root
container when possible (e.g. if `div` is specified as the default root
container, the editor will convert `p` elements in the root of the document
to `div` elements when the user modifies those containers). The default root
container option can be specified as an option of the new `structureRules`
option in the editor's initialization. For example:
```javascript
jQuery('.wymeditor').wymeditor({
structureRules: {
defaultRootContainer: 'div'
}
});
```
### Bug Fixes
* WYMeditor now works properly in Chrome when using jQuery 1.4 or higher.
Thanks to several folks for outlining the fix and for Nick McLaughlin for the
pull request.
* When using the bold tool in a heading in Chrome, there was an issue where a
span with a style attribute set to `font-weight: normal` would be wrapped
around the header's content. This has been fixed so that this span will no
longer occur after bolding.
* When attempting to insert an image outside of a container in Chrome such as
in the case of inserting an image into a blank document, there was an issue
where the image was being moved outside of the wymeditor body causing none of
the user-entered values for the attributes of the image to be applied to the
image. This has been fixed so that inserting an image properly places it
within the wymeditor body and properly applies the user-entered values for
its attributes.
* When switching between a normal table cell and a table header using the
"Table Header" option in the containers panel in the editor, any `colspan` or
other attributes were being lost in the container conversion. This has been
fixed so that all attributes such as `colspan` are retained when switching
between a normal table cell and a table header.
* In various situations when working in the editor, hitting enter to
create a new container in the root of the document would erroneously
create a `div` container instead of a `p` container. This `div`
container would not be labeled in the editor, and it could not be
converted to another type of container. As part of the feature
addition of a selectable default root container, this issue has been
fixed so that the selected default root container is always inserted
when hitting enter to create a new container in the root of the
document. In addition, `div` containers are now clearly labeled in the
editor and can now be converted to other types of containers using the
containers panel.
* A couple bugs in IE dealing with content not allowed to be in the root of the
editor body not being properly wrapped in containers have been fixed. The
first bug fixed was that text directly typed into the body of the editor was
not being wrapped in a container, but this is now fixed and the text will be
properly wrapped in the default root container. The second bug fixed was that
inline elements not allowable to be directly inserted into the body of the
editor (e.g. `strong`, `em`, `a`, etc.) were not being wrapped in a
container, but this is also now fixed and those elements will be properly
wrapped in the default root container when modified in the body.
### Build Process Improvements
* [Grunt](http://gruntjs.com/) has been set up for the WYMeditor project so
that the unit test suite can now easily be run from the command line in a
headless [Phantom.js](http://phantomjs.org/) browser using the Grunt `test`
task. See the testing section in the README or the docs for more information.
* The WYMeditor project is now set up on [Travis CI](https://travis-ci.org/)
for continuous integration using the unit test suite run with a variety of
jQuery versions using the Grunt `test` task.
* [Selenium2](http://seleniumhq.org/) tests have been set up for the WYMeditor
project to allow for testing coverage of some behaviors that can't be
replicated well with JavaScript. See the README for information on running
the Selenium tests.
### Deprecation
* The `WYMeditor.editor.html()` function has been deprecated and replaced with
the `WYMeditor.editor._html()` function that has the same functionality. This
change was made to discourage users from using the `html()` function (which
is intended only for internal use) as a means to get the HTML output from the
editor because that function bypasses all parsing and cross-browser cleanup
for the HTML. In most cases, users should be using the
`WYMeditor.editor.xhtml()` function to get the HTML output from the editor
because it does parse and apply cross-browser cleanup to the HTML. Now, using
the `html()` function will still work but just give a console warning of its
deprecation, but the function will be fully removed in the release of version
1.0.0.
## 1.0.0b4 (Beta 4)
*release-date* February 15, 2013
### Enhancements
* Added a Danish translation. Thanks Sebastian Kolind.
* The Makefile now supports building a WYMeditor distribution based on Google's
Closure Compiler instead of UglifyJS. Thanks Michael Farrell.
### Bug Fixes
* The editor area is now properly displayed when using the Compact skin and
styling with `white-space: nowrap'`. Thanks to Jorge Salinas for the fix.
* Fixed several bugs related to parsing void elements (br, hr, etc) which could
be either self-closing or not. These usually manifested when used near other
inline elements (eg. span). Thanks to Craig MacGregor for the fix.
* Fixed several XHTML-strict non-compliance problems. WYMeditor aims to always
output fully-compliant XHTML. Thanks Philipp Cordes for the report and fix.
* The Makefile now fails more gracefully when you don't have UglifyJS installed
and you attempt to build a distribution. Thanks to Michael Farrell for the fix.
* Fixed the Slovak translation language code. Thanks to Josef Šimánek for the
fix.
* In 1.0.0b2, we added a bug fix to allow DIV tags to peacefully co-exist with
P tags in document structure. It turned out that this fix was a bit
half-baked and actually broke both P and DIV tags in subtle ways, especially
in webkit browsers. We've reverted that change, so DIVs are now just as
broken as they were previously, but P tags are back to being peachy. The full
fix for mixing DIV and P tags for structure is being worked on as part of
[Issue 360](https://github.com/wymeditor/wymeditor/pull/360) and will
hopefully land in 1.0.0b5, which is now definitely going to be a thing.
### 1.0.0 Blocking Issues
In an attempt to ovary-up (or whatever your preferred genatalia) and actually
get a 1.0.0 out the door, we've moved the goalposts a bit. The applicable 1.0.x
issues have been narrowed down a bit to the major bugs in supported browsers. I
understand that `major` is in the eye of the beholder, but this is an attempt
to more-effectively allocated the project's limited resources. The remaining
issues are listed on the [1.0.0
milestone](https://github.com/wymeditor/wymeditor/issues?milestone=5) and
you'll notice there are no features that made the cut. It's all bug-fix mode.
Folks have been using WYMeditor in production longer than Chrome has existed as
a browser. Perhaps it's time to not pretend like a non-1.0 version number means
anything.
## 1.0.0b3 (Beta 3)
*release-date* June 26, 2012
This is a small hotfix release to fix `jQuery.noConflict()` compatibility,
which is necessary for Drupal integration.
## 1.0.0b2 (Beta 2)
*release-date* June 22, 2012
### Enhancements
* Added a Slovak translation. Thanks Miroslav Bendik.
### Bug Fixes
* A missing space in the tools HTML was triggering quirks mode in FF and other
browsers. Thanks to corphi for the fix.
* Inserting `div` tags via the API or DOM no longer breaks document structure
in chrome and safari. Thanks to Jakub Krčma for the fix.
* It is once again possible to use the Drupal 7 wysiwyg module to integrate
WYMeditor. Thanks to Jean-Francois Hovinne for the patch.
* Newline characters are no longer incorrectly removed in IE, which could cause
words in copy/pasted lists to join together. Thanks to Jakub Krčma for the
fix.
* Tables and images are once again properly inserted at your cursor location
in Internet Explorer. This was a regression bug in 1.0.0b1.
## 1.0.0b1 (Beta 1)
*release-date* February 27, 2012
We're almost there! Following up on the later October alpha release, we're
happy to announce the availability of a beta-quality WYMeditor release. This
release is not without bugs, but we think it is strictly better than 0.5.0rc2
with a variety of enhancements and bug fixes. Users currently on an earlier
alpha or on 0.5.0rc2 are encouraged to try out this release and report any
bugs, especially those that are new since 0.5.0rc2.
Bugs that are determined to be regressions from 0.5.0rc2 will receive the
highest priority fixes.
Any feedback or discussion would be appreciated on the
[WYMeditor Forums](http://community.wymeditor.org/).
Versus 0.5.0rc2 we have:
* *19* major bug fixes
* *8* major enhancements including a new theme.
* A huge internal code refactor to make maintaining and improving WYMeditor easier
* A passing unit test suite containing more than 600 tests across all supported browsers
### Upgrade Cycle
Once all
[milestone 1.0.0 issues](https://github.com/wymeditor/wymeditor/issues?milestone=10&sort=created&direction=desc&state=open)
are completed, this cycle will culminate in a 1.0.0 stable release.
### Enhancements
* The parser now works harder to correct any invalid list nesting that might
occur due to browser-specific problems or HTML that was loaded to begin. On
every list action (indent, outdent, order/unordered conversion), the parser
crawls your list to make any necessary corrections. This ensures a much more
consistent list-editing experience, especially in Internet Explorer.
* A new *pretty* theme option is now available for modern browsers (ie9+, FF,
Chrome, Safari). This theme uses CSS instead of images to provide context
clues for blocks, resulting in fewer HTTP requests and better network
performance. Additionally, the context clues have been expanded to provide a
better "plain english" explanation of the elements. Give this new theme a
swing at [the example](http://wymeditor.no.de/wymeditor/examples/17-pretty-theme.html).
You can enable it in your project by passing the
`iframeBasePath: "wymeditor/iframe/pretty/"` option to your WYMeditor instance.
Thanks to first-time contributor Gyuris Gellért for the theme.
* The Embed plugin now supports embedding via an iframe.
* List indent/outdent has been rewritten to fix several outstanding bugs in
various browsers. Indent and outdent are now always opposites of each other
(outdenting what you just indented returns you to your original state) and
the behavior is consistent across all supported browsers.
* A list plugin is now available that enables tab for list indent and
shift + tab for list outdent.
It is available at `wymeditor/plugins/list/jquery.wymeditor.list.js`.
To enable the plugin, create a ListPlugin object via the
`wymeditor.postInit` option. eg::
$('.wymeditor').wymeditor({
postInit: function(wym) {
var listPlugin = new ListPlugin({}, wym);
}
});
* A new Table editing plugin is now available
The table editing plugin enables the following:
* Users can now add and remove rows and columns from existing tables.
* Users can merge table cells to create either `colspan` or `rowspan`.
* Hitting the `tab` key while inside a table now moves the cursor to the
next cell, improving usability when editing tables. This can be disabled
by passing `enableCellTabbing: false` to the plugin initialization.
The plugin is available at `wymeditor/plugins/table/jquery.wymeditor.table.js`.
To enable the plugin, instantiate it during the `wymeditor.postInit` option.
eg::
$('.wymeditor').wymeditor({
postInit: function(wym) {
var tableEditor = wym.table();
}
});
* Rangy is now included as part of the distribution and used to create
consistent cross-browser selection objects.
* A console warning message is now created if no wymPath option is provided and
it can't be automatically determined. The editor also attempts to continue
with the assumption that your wymPath is your current directory, instead of
throwing an exception immediately.
### Bug Fixes
* A rare bug affecting ie8 users with certain combinations of CSS attributes
has been fixed (with a work-around). This bug would manifest as all content
in the editor temporarily and randomly disappearing after a keypress, only
to re-appear when the user moved their mouse.
* The editor height no longer changes height by a few pixels the first time
someone hovers over a tool.
* Several list indent/outdent bugs that could result in invalid HTML and broken
lists are now fixed. Users can no-longer break their lists with specific
combinations of double indents and outdents.
* The HTML parser/validator now corrects unclosed <li> tags in lists so that if
a piece of HTML has previously been affected by the broken list bug, it will
be automatically corrected.
* It is now always possible to insert tables, preformatted text and blockquotes
at the start and end of documents, as well as in between each other.
Previously, depending on your browser and version, you couldn't do one or more
of these things.
* It is now possible to paste content in to a table when using internet
explorer.
* Fixed some problems with ordered and unordered list nesting in Internet
Explorer caused by a regex failing to account for IE's insertion of
whitespace in list HTML.
* `colSpan` and `rowSpan` attributes are no longer stripped out in Internet
Explorer.
* Fixed a bug making it impossible to use *Paste From Word* inside tables or lists
* Fixed a list indent bug when indenting a list with a previous list item which
had a sublist of a different list type. This used to create a second sublist
of the original list type, which isn't what someone would expect.
* Fixed several related list outdent bugs where content could be re-ordered or
where outdent would fail to occur.
* It's now possible to consistently toggle lists between ordered and unordered
in all supported browsers.
* Turning a top-level item into a list no longer wraps the list in a paragraph
in chrome 16 and higher.
* Fixed indent/outdent when highlighting an inline node instead of the list
(eg. a bolded section).
* Updated the turkish translation (thanks Gokce).
* Attempting to indent with a cursor outside of a list no longer throws a
javascript error.
* Several bugs related to losing/moving your selection when indenting or
outdenting lists are now fixed.
* Outdenting after using backspace to join an item inside a list no longer
loses content in internet explorer.
* `<col />` tags are now automatically self-closing and the parser no longer
forces a closing `</col>` tag.
Thanks to first-time contributor Steven Bufton for the fix.