PHP Classes

File: public/js/tinymce/src/core/src/test/js/browser/focus/EditorFocusTest.js

Recommend this page to a friend!
  Classes of Abed Nego Ragil Putra   GoLavaCMS   public/js/tinymce/src/core/src/test/js/browser/focus/EditorFocusTest.js   Download  
File: public/js/tinymce/src/core/src/test/js/browser/focus/EditorFocusTest.js
Role: Auxiliary data
Content type: text/plain
Description: Auxiliary data
Class: GoLavaCMS
Publish content on Web pages with SEO support
Author: By
Last change:
Date: 6 years ago
Size: 5,183 bytes
 

Contents

Class file image Download
asynctest( 'browser.tinymce.core.focus.EditorFocusTest', [ 'ephox.agar.api.Assertions', 'ephox.agar.api.Chain', 'ephox.agar.api.GeneralSteps', 'ephox.agar.api.Logger', 'ephox.agar.api.Pipeline', 'ephox.sugar.api.dom.Focus', 'ephox.sugar.api.dom.Hierarchy', 'ephox.sugar.api.node.Element', 'tinymce.core.EditorManager', 'tinymce.core.focus.EditorFocus', 'tinymce.core.test.ViewBlock', 'tinymce.themes.modern.Theme' ], function (Assertions, Chain, GeneralSteps, Logger, Pipeline, Focus, Hierarchy, Element, EditorManager, EditorFocus, ViewBlock, Theme) { var success = arguments[arguments.length - 2]; var failure = arguments[arguments.length - 1]; var viewBlock = new ViewBlock(); Theme(); var cCreateInlineEditor = function (html) { return Chain.on(function (viewBlock, next, die) { viewBlock.update(html); EditorManager.init({ selector: '.tinymce-editor', inline: true, skin_url: '/project/src/skins/lightgray/dist/lightgray', setup: function (editor) { editor.on('SkinLoaded', function () { next(Chain.wrap(editor)); }); } }); }); }; var cFocusEditor = Chain.op(function (editor) { EditorFocus.focus(editor, false); }); var cFocusElement = function (elementPath) { return Chain.op(function (editor) { var element = Hierarchy.follow(Element.fromDom(editor.getBody()), elementPath).getOrDie(); element.dom().focus(); }); }; var cSetSelection = function (startPath, startOffset, endPath, endOffset) { return Chain.op(function (editor) { var startContainer = Hierarchy.follow(Element.fromDom(editor.getBody()), startPath).getOrDie(); var endContainer = Hierarchy.follow(Element.fromDom(editor.getBody()), endPath).getOrDie(); var rng = editor.dom.createRng(); rng.setStart(startContainer.dom(), startOffset); rng.setEnd(endContainer.dom(), endOffset); editor.selection.setRng(rng); }); }; var cAssertSelection = function (startPath, startOffset, endPath, endOffset) { return Chain.op(function (editor) { var startContainer = Hierarchy.follow(Element.fromDom(editor.getBody()), startPath).getOrDie(); var endContainer = Hierarchy.follow(Element.fromDom(editor.getBody()), endPath).getOrDie(); var rng = editor.selection.getRng(); Assertions.assertDomEq('Should be expected from start container', startContainer, Element.fromDom(rng.startContainer)); Assertions.assertEq('Should be expected from start offset', startOffset, rng.startOffset); Assertions.assertDomEq('Should be expected end container', endContainer, Element.fromDom(rng.endContainer)); Assertions.assertEq('Should be expected end offset', endOffset, rng.endOffset); }); }; var cAssertHasFocus = function (elementPath) { return Chain.op(function (editor) { var element = Hierarchy.follow(Element.fromDom(editor.getBody()), elementPath).getOrDie(); Assertions.assertEq('Should have focus on the editor', true, EditorFocus.hasFocus(editor)); Assertions.assertDomEq('Should be the expected activeElement', element, Focus.active().getOrDie()); }); }; var cRemoveEditor = Chain.op(function (editor) { editor.remove(); }); viewBlock.attach(); Pipeline.async({}, [ Logger.t('Focus editor', GeneralSteps.sequence([ Logger.t('Focus editor initialized on a table', Chain.asStep(viewBlock, [ cCreateInlineEditor('<table class="tinymce-editor"><tbody><tr><td>a</td></tr></tbody></table>'), cFocusEditor, cAssertSelection([0, 0, 0, 0], 0, [0, 0, 0, 0], 0), cRemoveEditor ])), Logger.t('Focus editor initialized on a div with p', Chain.asStep(viewBlock, [ cCreateInlineEditor('<div class="tinymce-editor"><p>a</p></div>'), cFocusEditor, cAssertSelection([0, 0], 0, [0, 0], 0), cRemoveEditor ])), Logger.t('Focus editor initialized on a list', Chain.asStep(viewBlock, [ cCreateInlineEditor('<ul class="tinymce-editor"><li>a</li></ul>'), cFocusEditor, cAssertSelection([0, 0], 0, [0, 0], 0), cRemoveEditor ])) ])), Logger.t('hasFocus', GeneralSteps.sequence([ Logger.t('Focus on normal paragraph', Chain.asStep(viewBlock, [ cCreateInlineEditor('<div class="tinymce-editor"><p>a</p></div>'), cFocusEditor, cAssertHasFocus([]), cRemoveEditor ])), Logger.t('Focus on cE=true inside a cE=false', Chain.asStep(viewBlock, [ cCreateInlineEditor('<div class="tinymce-editor"><div contenteditable="false">a<div contenteditable="true">b</div></div></div>'), cSetSelection([0, 1, 0], 0, [0, 1, 0], 0), cFocusElement([0, 1]), cAssertHasFocus([0, 1]), cRemoveEditor ])) ])) ], function () { viewBlock.detach(); success(); }, failure); } );