PHP Classes

File: public/js/tinymce/src/plugins/contextmenu/src/test/js/browser/ContextMenuPluginTest.js

Recommend this page to a friend!
  Classes of Abed Nego Ragil Putra   GoLavaCMS   public/js/tinymce/src/plugins/contextmenu/src/test/js/browser/ContextMenuPluginTest.js   Download  
File: public/js/tinymce/src/plugins/contextmenu/src/test/js/browser/ContextMenuPluginTest.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: 3,249 bytes
 

Contents

Class file image Download
asynctest( 'browser.tinymce.plugins.contextmenu.ContextMenuPluginTest', [ 'ephox.agar.api.ApproxStructure', 'ephox.agar.api.GeneralSteps', 'ephox.agar.api.Logger', 'ephox.agar.api.Mouse', 'ephox.agar.api.Pipeline', 'ephox.agar.api.Step', 'ephox.mcagar.api.TinyApis', 'ephox.mcagar.api.TinyLoader', 'ephox.mcagar.api.TinyUi', 'ephox.sugar.api.dom.Hierarchy', 'ephox.sugar.api.node.Element', 'tinymce.plugins.contextmenu.Plugin', 'tinymce.themes.modern.Theme' ], function (ApproxStructure, GeneralSteps, Logger, Mouse, Pipeline, Step, TinyApis, TinyLoader, TinyUi, Hierarchy, Element, ContextMenuPlugin, ModernTheme) { var success = arguments[arguments.length - 2]; var failure = arguments[arguments.length - 1]; ModernTheme(); ContextMenuPlugin(); var sContextMenuClickInMiddleOf = function (editor, elementPath) { return Step.sync(function () { var element = Hierarchy.follow(Element.fromDom(editor.getBody()), elementPath).getOrDie().dom(); var rect = element.getBoundingClientRect(); var clientX = (rect.left + rect.width / 2), clientY = (rect.top + rect.height / 2); editor.fire('mousedown', { target: element, clientX: clientX, clientY: clientY, button: 2 }); editor.fire('mouseup', { target: element, clientX: clientX, clientY: clientY, button: 2 }); editor.fire('contextmenu', { target: element, clientX: clientX, clientY: clientY }); }); }; TinyLoader.setup(function (editor, onSuccess, onFailure) { var tinyUi = TinyUi(editor); var tinyApis = TinyApis(editor); Pipeline.async({}, [ Logger.t('Context menu click on text', GeneralSteps.sequence([ tinyApis.sSetContent('<p>a</p>'), tinyApis.sSetSelection([0, 0], 0, [0, 0], 1), Mouse.sContextMenuOn(Element.fromDom(editor.getBody()), 'p'), tinyUi.sWaitForUi('wait for context', 'div.mce-contextmenu'), tinyUi.sClickOnUi('click on link in context', 'div.mce-contextmenu span:contains("Bold")'), tinyApis.sAssertContentStructure(ApproxStructure.build(function (s, str) { return s.element('body', { children: [ s.element('p', { children: [ s.element('strong', { children: [ s.text(str.is('a')) ] }) ] }) ] }); })) ])), Logger.t('Do not select image if the context menu click is inside the currently selected range', GeneralSteps.sequence([ tinyApis.sSetContent('<p>a<img src="" width="100" height="100"></p>'), tinyApis.sSetSelection([0, 0], 0, [0], 2), sContextMenuClickInMiddleOf(editor, [0, 1]), tinyApis.sAssertSelection([0, 0], 0, [0], 2) ])) ], onSuccess, onFailure); }, { plugins: 'contextmenu', toolbar: 'contextmenu', contextmenu: 'bold', skin_url: '/project/src/skins/lightgray/dist/lightgray' }, success, failure); } );