Skip to content

Latest commit

 

History

History
340 lines (213 loc) · 11.4 KB

API.md

File metadata and controls

340 lines (213 loc) · 11.4 KB

MediumEditor Object API (v5.0.0)

Initialization Functions

MediumEditor(elements, options)

Creating an instance of MediumEditor will:

  • Convert all passed in elements into contenteditable elements.
  • For any <textarea> elements, hide the <textarea>, create a new <div contenteditable=true> element, and ensure the 2 elements remain sync'd.
  • Initialize any custom extensions or buttons passed in.
  • Create any additional elements needed.
  • Setup all event handling needed to monitor the editable elements.

Arguments

elements (String | HTMLElement | Array):

  1. String: If passed as a string, this is used as a selector in a call to document.querySelectorAll() to find elements on the page. All results are stored in the internal list of elements.

  2. HTMLElement: If passed as a single element, this will be the only element in the internal list of elements.

  3. Array: If passed as an Array of HTMLElements, this will be used as the internal list of elements.

options (Object):

Set of custom options used to initialize MediumEditor.


destroy()

Tear down the editor if already setup by doing the following:

  • Calling the destroy() method on each extension within the editor. This should allow all extension to be torn down and cleaned up, including the toolbar and its elements.
  • Detaching all event listeners from the DOM
  • Detaching all references to custom event listeners
  • Remove any custom attributes from the editor elements
  • Unhide any <textarea> elements and remove any created <div> elements created for <textarea> elements.

setup()

Initialize this instance of the editor if it has been destroyed. This will reuse the elements selector and options object passed in when the editor was instantiated.


Event Functions

on(targets, event, listener, useCapture)

Attaches an event listener to a specific element or elements via the browser's built-in addEventListener(type, listener, useCapture) API. However, this helper method also ensures that when MediumEditor is destroyed, this event listener will be automatically be detached from the DOM.

Arguments

  1. targets (HTMLElement / NodeList):
  • Element or elements to attach listener to via addEventListener(type, listener, useCapture)
  1. event (String):
  • type argument for addEventListener(type, listener, useCapture)
  1. listener (function):

    • listener argument for addEventListener(type, listener, useCapture)
  2. useCapture (boolean):

    • useCapture argument for addEventListener(type, listener, useCapture)

off(targets, event, listener, useCapture)

Detach an event listener from a specific element or elements via the browser's built-in removeEventListener(type, listener, useCapture) API.

Arguments

  1. targets (HTMLElement / NodeList):
  • Element or elements to detach listener from via removeEventListener(type, listener, useCapture)
  1. event (String):
  • type argument for removeEventListener(type, listener, useCapture)
  1. listener (function):

    • listener argument for removeEventListener(type, listener, useCapture)
  2. useCapture (boolean):

    • useCapture argument for removeEventListener(type, listener, useCapture)

subscribe(name, listener)

Attaches a listener for the specified custom event name.

Arguments

  1. name (String):
  • Name of the event to listen to. See the list of built-in Custom Events.
  1. listener(data, editable) (function):
  • Listener method that will be called whenever the custom event is triggered.

Arguments to listener

  1. data (Event | object) * For most custom events, this will be the browser's native Event object for the event that triggered the custom event to fire. * For some custom events, this will be an object containing information describing the event (depending on which custom event it is)
  2. editable (HTMLElement) * A reference to the contenteditable container element that this custom event corresponds to. This is especially useful for instances where one instance of MediumEditor contains multiple elements, or there are multiple instances of MediumEditor on the page. * For example, when blur fires, this argument will be the <div contenteditable=true></div> element that is about to receive focus.

unsubscribe(name, listener)

Detaches a custom event listener for the specified custom event name.

Arguments

  1. name (String):
  • Name of the event to detach the listener for.
  1. listener (function):
  • A reference to the listener to detach. This must be a match by-reference and not a copy.

NOTE

  • Calling destroy() on the MediumEditor object will automatically remove all custom event listeners.

trigger(name, data, editable)

Manually triggers a custom event.

Arguments

  1. name (String):
  • Name of the custom event to trigger.
  1. data (Event | object):
  • Native Event object or custom data object to pass to all the listeners to this custom event.
  1. editable (HTMLElement):
  • The <div contenteditable=true></div> element to pass to all of the listeners to this custom event.

Selection Functions

checkSelection()

If the toolbar is enabled, manually forces the toolbar to update based on the user's current selection. This includes hiding/showing the toolbar, positioning the toolbar, and updating the enabled/disable state of the toolbar buttons.


exportSelection()

Returns a data representation of the selected text, which can be applied via importSelection(selectionState). This data will include the beginning and end of the selection, as well as which of the editor elements the selection was within.


importSelection(selectionState, favorLaterSelectionAnchor)

Restores the selection using a data representation of previously selected text (ie value returned by exportSelection()).

Arguments

  1. selectionState (Object):
  • Data representing the state of the selection to restore.
  1. favorLaterSelectionAnchor (boolean):
  • If true, import the cursor immediately subsequent to an anchor tag if it would otherwise be placed right at the trailing edge inside the anchor. THis cursor positioning, even though visually equivalent to the user, can affect behavior in Internet Explorer.

getFocusedElement()

Returns a reference to the editor element that currently has focus (if the editor has focus).


getSelectedParentElement(range)

Returns a reference to the editor element that the user's selection is currently within.


restoreSelection()

Restores the selection to what was selected the last time saveSelection() was called.


saveSelection()

Internally stores the user's current selection. This can be restored by calling restoreSelection().


selectAllContents()

Expands the selection to contain all text within the focused editor element.


selectElement(element)

Change the user's selection to select the contents of the provided element and update the toolbar to reflect this change.

Arguments

  1. element (HTMLElement):
  • DOM Element -- which is a descendant of one of the editor's elements -- to select.

stopSelectionUpdates()

Stop the toolbar from updating to reflect changes in the user's selection.


startSelectionUpdates()

Enable the toolbar to start updating based on the user's selection, after a call to stopSelectionUpdates()


Editor Action Functions

cleanPaste(text)

convert text to plaintext and replace current selection with result


createLink(opts)

creates a link via the native document.execCommand('createLink') command


execAction(action, opts)

executes an built-in action via document.execCommand


pasteHTML(html, options)

replace the current selection with html


queryCommandState(action)

wrapper around the browser's built in document.queryCommandState(action) for checking whether a specific action has already been applied to the selection.


Helper Functions

checkContentChanged(editable)

Trigger the editor to check for updates to the html, and trigger the editableInput event if needed.

Arguments

  1. editable (HTMLElement): OPTIONAL
  • The <div contenteditable=true></div> element that contains the html that may have changed.
  • If no element is provided, the editor will check the currently 'active' editor element (the element with focus).

delay(fn)

Delay any function from being executed by the amount of time passed as the delay option.

Arguments

  1. fn (function):
  • Function to delay execution for.

getExtensionByName(name)

Get a reference to an extension with the specified name.

Arguments

  1. name (String):
  • The name of the extension to retrieve (ie toolbar).

serialize()

Returns a JSON object including the content of each of the elements inside the editor.


setContent(html, index)

Sets the innerHTML content for the element at index. Trigger the editableInput event.

Arguments

  1. html (string):
  • The content to set the element to
  1. index (integer):
  • Index of the element to set the content on. Defaults to 0 when not provided.