The Rich Text Editor is a UI control that allows for the rich formatting of text content, including common structural treatments like lists, formatting treatments like bold and italic text.

The current release of the Rich Text Editor for YUI 3 is the base utility layers that provide a foundation on which you can create an Editor. This version of Editor does not contain a GUI of any kind.

{{>getting-started}}

Creating an Editor

This simple example will create an Editable area inside of another Node. It will not contain a GUI, only the iframe. You can use various Editor events to wire up your own toolbar.

``` YUI().use('editor-base', function(Y) { var editor = new Y.EditorBase({ content: 'This is a test This is a test ' }); //Add the BiDi plugin editor.plug(Y.Plugin.EditorBidi); //Focusing the Editor when the frame is ready.. editor.on('frame:ready', function() { this.focus(); }); //Rendering the Editor. editor.render('#editor'); }); ```

Frame Instance

When the Editor is created, it creates a YUI instance inside itself and attaches that instance to the editable iframe. This means that you now have the full power of YUI 3 inside the Editor iframe. You can use Event, Stylesheet, Node and even DD inside the iframe, without having to load all the JavaScript inside the document.

Getting access to this instance is simple. Just use the `getInstance` method on the Editor instance, like this:

``` YUI().use('editor-base', function(Y) { var editor = new Y.EditorBase({ content: 'This is a test This is a test ' }); //Add the BiDi plugin editor.plug(Y.Plugin.EditorBidi); //Focusing the Editor when the frame is ready.. editor.on('frame:ready', function() { this.focus(); var inst = this.getInstance(); //inst is now an instance of YUI that is bound to the iframe. var body = inst.one('body'); //body is a Node instance of the BODY element "inside" the iframe. var strongs = inst.all('strong'); //strongs is a NodeList instance of all the STRONG elements "inside" the iframe. }); //Rendering the Editor. editor.render('#editor'); }); ```

Events

By default, the frame instance under the hood of Editor attaches a listener for all known DOM events. The example below shows how you can listen and interact with them.

``` YUI().use('editor-base', function(Y) { var editor = new Y.EditorBase({ content: 'This is a test This is a test ' }); //Add the BiDi plugin editor.plug(Y.Plugin.EditorBidi); editor.on('frame:keydown', function(e) { //Listen for the keydown event inside the Editor. /* This event object contains 3 new properties: frameEvent frameTarget frameCurrentTarget These properties are the original properties before the Event was fired, so you can use them like: e.frameEvent.halt(); */ }); editor.on('frame:mouseup', function(e) { //Listen for the mouseup event inside the Editor. }); //Rendering the Editor. editor.render('#editor'); }); ```

Node Change Event

The `nodeChange` event is a special event that Editor emits so that you can react to certain important moments that occured.

The most common use for the `nodeChange` event is to update the state of a Toolbar.

nodeChange event properties

This list contains the properties that are added to the Event object when the `nodeChange` event is fired.

Event Property Description
`changedEvent` The event that caused the nodeChange
`changedNode` The node that was interacted with
`changedType` The type of change: mousedown, mouseup, right, left, backspace, tab, enter, etc..
`commands` The list of execCommands that belong to this change and the dompath that's associated with the changedNode
`classNames` An array of classNames that are applied to the changedNode and all of its parents
`dompath` A sorted array of node instances that make up the DOM path from the changedNode to body.
`backgroundColor` The cascaded backgroundColor of the changedNode
`fontColor` The cascaded fontColor of the changedNode
`fontFamily` The cascaded fontFamily of the changedNode
`fontSize` The cascaded fontSize of the changedNode

Module Descriptions

Using YUI 3's plugin architecture, this version of the Rich Text Editor is even more modular and extensible than the previous version. Almost every part of the Editor infrastructure is a plugin or extension. Below you will find the current list of plugins shipped with Editor.

Module Name Description
`frame` Controls the creation and set up of the editable area
`editor-selection` Cross-browser selection normalization
`exec-command` Plugs into frame to extend `document.execCommand` support.
`editor-tab` Overrides the default tab key handler and indents/outdents the current block level element.
`editor-para` Paragraph support (opposite of `editor-br`)
`editor-br` Line break support (opposite of `editor-para`)
`editor-bidi` Paragraph/Bi-Directional support
`createlink-base` Simple `prompt` based link creation.
`editor-base` Rollup of the above modules
`editor` Rollup of the above modules

Note: Either `editor-br` or `editor-para` should be plugged. One, but not both, is required for proper functionality.