import { Pipeline } from '@ephox/agar'; import { LegacyUnit, TinyLoader } from '@ephox/mcagar'; import EditorManager from 'tinymce/core/api/EditorManager'; import Env from 'tinymce/core/api/Env'; import HtmlUtils from '../module/test/HtmlUtils'; import URI from 'tinymce/core/api/util/URI'; import Theme from 'tinymce/themes/modern/Theme'; import { UnitTest } from '@ephox/bedrock'; UnitTest.asynctest('browser.tinymce.core.EditorTest', function () { const success = arguments[arguments.length - 2]; const failure = arguments[arguments.length - 1]; const suite = LegacyUnit.createSuite(); Theme(); suite.test('Event: change', function (editor) { let level, lastLevel; editor.on('change', function (e) { level = e.level; lastLevel = e.lastLevel; }); editor.setContent(''); editor.insertContent('a'); LegacyUnit.equal(level.content.toLowerCase(), '

a

'); LegacyUnit.equal(lastLevel.content, editor.undoManager.data[0].content); editor.off('change'); }); suite.test('Event: beforeExecCommand', function (editor) { let cmd, ui, value; editor.on('BeforeExecCommand', function (e) { cmd = e.command; ui = e.ui; value = e.value; e.preventDefault(); }); editor.setContent(''); editor.insertContent('a'); LegacyUnit.equal(editor.getContent(), ''); LegacyUnit.equal(cmd, 'mceInsertContent'); LegacyUnit.equal(ui, false); LegacyUnit.equal(value, 'a'); editor.off('BeforeExecCommand'); editor.setContent(''); editor.insertContent('a'); LegacyUnit.equal(editor.getContent(), '

a

'); }); suite.test('urls - relativeURLs', function (editor) { editor.settings.relative_urls = true; editor.documentBaseURI = new URI('http://www.site.com/dirA/dirB/dirC/'); editor.setContent('test'); LegacyUnit.equal(editor.getContent(), '

test

'); editor.setContent('test'); LegacyUnit.equal(editor.getContent(), '

test

'); editor.setContent('test'); LegacyUnit.equal(editor.getContent(), '

test

'); editor.setContent('test'); LegacyUnit.equal(editor.getContent(), '

test

'); editor.setContent('test'); LegacyUnit.equal(editor.getContent(), '

test

'); editor.setContent('test'); LegacyUnit.equal(editor.getContent(), '

test

'); editor.setContent('test'); LegacyUnit.equal(editor.getContent(), '

test

'); }); suite.test('urls - absoluteURLs', function (editor) { editor.settings.relative_urls = false; editor.settings.remove_script_host = true; editor.documentBaseURI = new URI('http://www.site.com/dirA/dirB/dirC/'); editor.setContent('test'); LegacyUnit.equal(editor.getContent(), '

test

'); editor.setContent('test'); LegacyUnit.equal(editor.getContent(), '

test

'); editor.setContent('test'); LegacyUnit.equal(editor.getContent(), '

test

'); editor.setContent('test'); LegacyUnit.equal(editor.getContent(), '

test

'); editor.settings.relative_urls = false; editor.settings.remove_script_host = false; editor.setContent('test'); LegacyUnit.equal(editor.getContent(), '

test

'); editor.setContent('test'); LegacyUnit.equal(editor.getContent(), '

test

'); editor.setContent('test'); LegacyUnit.equal(editor.getContent(), '

test

'); editor.setContent('test'); LegacyUnit.equal(editor.getContent(), '

test

'); editor.setContent('test'); LegacyUnit.equal(editor.getContent(), '

test

'); editor.setContent('test'); LegacyUnit.equal(editor.getContent(), '

test

'); }); suite.test('WebKit Serialization range bug', function (editor) { if (Env.webkit) { // Note that if we create the P with this invalid content directly, Chrome cleans it up differently to other browsers so we don't // wind up testing the serialization functionality we were aiming for and the test fails. const p = editor.dom.create('p', {}, '123
X
456'); editor.dom.replace(p, editor.getBody().firstChild); LegacyUnit.equal(editor.getContent(), '

123

X

456

'); } }); suite.test('editor_methods - getParam', function (editor) { editor.settings.test = 'a,b,c'; LegacyUnit.equal(editor.getParam('test', '', 'hash').c, 'c'); editor.settings.test = 'a'; LegacyUnit.equal(editor.getParam('test', '', 'hash').a, 'a'); editor.settings.test = 'a=b'; LegacyUnit.equal(editor.getParam('test', '', 'hash').a, 'b'); editor.settings.test = 'a=b;c=d,e'; LegacyUnit.equal(editor.getParam('test', '', 'hash').c, 'd,e'); editor.settings.test = 'a=b,c=d'; LegacyUnit.equal(editor.getParam('test', '', 'hash').c, 'd'); }); suite.test('setContent', function (editor) { let count; const callback = function (e) { e.content = e.content.replace(/test/, 'X'); count++; }; editor.on('SetContent', callback); editor.on('BeforeSetContent', callback); count = 0; editor.setContent('

test

'); LegacyUnit.equal(editor.getContent(), '

X

'); LegacyUnit.equal(count, 2); editor.off('SetContent', callback); editor.off('BeforeSetContent', callback); count = 0; editor.setContent('

test

'); LegacyUnit.equal(editor.getContent(), '

test

'); LegacyUnit.equal(count, 0); }); suite.test('setContent with comment bug #4409', function (editor) { editor.setContent('
'); editor.settings.disable_nodechange = false; editor.nodeChanged(); editor.settings.disable_nodechange = true; LegacyUnit.equal(editor.getContent(), '

\u00a0

'); }); suite.test('custom elements', function (editor) { editor.setContent('c1c1'); LegacyUnit.equal(editor.getContent(), 'c1

c1

'); }); suite.test('Store/restore tabindex', function (editor) { editor.setContent('abc'); LegacyUnit.equal(editor.getContent({ format: 'raw' }).toLowerCase(), '

abc

'); LegacyUnit.equal(editor.getContent(), '

abc

'); }); suite.test('show/hide/isHidden and events', function (editor) { let lastEvent; editor.on('show hide', function (e) { lastEvent = e; }); LegacyUnit.equal(editor.isHidden(), false, 'Initial isHidden state'); editor.hide(); LegacyUnit.equal(editor.isHidden(), true, 'After hide isHidden state'); LegacyUnit.equal(lastEvent.type, 'hide'); lastEvent = null; editor.hide(); LegacyUnit.equal(lastEvent, null); editor.show(); LegacyUnit.equal(editor.isHidden(), false, 'After show isHidden state'); LegacyUnit.equal(lastEvent.type, 'show'); lastEvent = null; editor.show(); LegacyUnit.equal(lastEvent, null); }); suite.test('hide save content and hidden state while saving', function (editor) { let lastEvent, hiddenStateWhileSaving; editor.on('SaveContent', function (e) { lastEvent = e; hiddenStateWhileSaving = editor.isHidden(); }); editor.setContent('xyz'); editor.hide(); const elm: any = document.getElementById(editor.id); LegacyUnit.equal(hiddenStateWhileSaving, false, 'False isHidden state while saving'); LegacyUnit.equal(lastEvent.content, '

xyz

'); LegacyUnit.equal(elm.value, '

xyz

'); editor.show(); }); suite.test('insertContent', function (editor) { editor.setContent('

ab

'); LegacyUnit.setSelection(editor, 'p', 1); editor.insertContent('c'); LegacyUnit.equal(editor.getContent(), '

acb

'); }); suite.test('insertContent merge', function (editor) { editor.setContent('

a

'); LegacyUnit.setSelection(editor, 'p', 1); editor.insertContent('b', { merge: true }); LegacyUnit.equal(editor.getContent(), '

ab

'); }); suite.test('addCommand', function (editor) { const scope = {}; let lastScope, lastArgs; const callback = function () { // eslint-disable-next-line lastScope = this; lastArgs = arguments; }; editor.addCommand('CustomCommand1', callback, scope); editor.addCommand('CustomCommand2', callback); editor.execCommand('CustomCommand1', false, 'value', { extra: true }); LegacyUnit.equal(lastArgs[0], false); LegacyUnit.equal(lastArgs[1], 'value'); LegacyUnit.equal(lastScope === scope, true); editor.execCommand('CustomCommand2'); LegacyUnit.equal(typeof lastArgs[0], 'undefined'); LegacyUnit.equal(typeof lastArgs[1], 'undefined'); LegacyUnit.equal(lastScope === editor, true); }); suite.test('addQueryStateHandler', function (editor) { const scope = {}; let lastScope, currentState; const callback = function () { // eslint-disable-next-line lastScope = this; return currentState; }; editor.addQueryStateHandler('CustomCommand1', callback, scope); editor.addQueryStateHandler('CustomCommand2', callback); currentState = false; LegacyUnit.equal(editor.queryCommandState('CustomCommand1'), false); LegacyUnit.equal(lastScope === scope, true, 'Scope is not custom scope'); currentState = true; LegacyUnit.equal(editor.queryCommandState('CustomCommand2'), true); LegacyUnit.equal(lastScope === editor, true, 'Scope is not editor'); }); suite.test('Block script execution', function (editor) { editor.setContent('

x

'); LegacyUnit.equal( HtmlUtils.cleanHtml(editor.getBody().innerHTML), '' + '' + '' + '

x

' ); LegacyUnit.equal( editor.getContent(), '' + '' + '' + '

x

' ); }); suite.test('addQueryValueHandler', function (editor) { const scope = {}; let lastScope, currentValue; const callback = function () { // eslint-disable-next-line lastScope = this; return currentValue; }; editor.addQueryValueHandler('CustomCommand1', callback, scope); editor.addQueryValueHandler('CustomCommand2', callback); currentValue = 'a'; LegacyUnit.equal(editor.queryCommandValue('CustomCommand1'), 'a'); LegacyUnit.equal(lastScope === scope, true, 'Scope is not custom scope'); currentValue = 'b'; LegacyUnit.equal(editor.queryCommandValue('CustomCommand2'), 'b'); LegacyUnit.equal(lastScope === editor, true, 'Scope is not editor'); }); suite.test('setDirty/isDirty', function (editor) { let lastArgs = null; editor.on('dirty', function (e) { lastArgs = e; }); editor.setDirty(false); LegacyUnit.equal(lastArgs, null); LegacyUnit.equal(editor.isDirty(), false); editor.setDirty(true); LegacyUnit.equal(lastArgs.type, 'dirty'); LegacyUnit.equal(editor.isDirty(), true); lastArgs = null; editor.setDirty(true); LegacyUnit.equal(lastArgs, null); LegacyUnit.equal(editor.isDirty(), true); editor.setDirty(false); LegacyUnit.equal(lastArgs, null); LegacyUnit.equal(editor.isDirty(), false); }); suite.test('setMode', function (editor) { let clickCount = 0; editor.on('click', function () { clickCount++; }); editor.dom.fire(editor.getBody(), 'click'); LegacyUnit.equal(clickCount, 1); editor.setMode('readonly'); LegacyUnit.equal(editor.theme.panel.find('button:last')[2].disabled(), true); editor.dom.fire(editor.getBody(), 'click'); LegacyUnit.equal(clickCount, 1); editor.setMode('design'); editor.dom.fire(editor.getBody(), 'click'); LegacyUnit.equal(editor.theme.panel.find('button:last')[2].disabled(), false); LegacyUnit.equal(clickCount, 2); }); suite.test('translate', function (editor) { EditorManager.addI18n('en_US', { 'input i18n': 'output i18n', 'value:{0}{1}': 'value translation:{0}{1}' }); LegacyUnit.equal(editor.translate('input i18n'), 'output i18n'); LegacyUnit.equal(editor.translate(['value:{0}{1}', 'a', 'b']), 'value translation:ab'); }); suite.test('Treat some paragraphs as empty contents', function (editor) { editor.setContent('


'); LegacyUnit.equal(editor.getContent(), ''); editor.setContent('

\u00a0

'); LegacyUnit.equal(editor.getContent(), ''); }); suite.test('kamer word boundaries', function (editor) { editor.setContent('

!\u200b!\u200b!

'); LegacyUnit.equal(editor.getContent(), '

!\u200b!\u200b!

'); }); suite.test('Padd empty elements with br', function (editor) { editor.settings.padd_empty_with_br = true; editor.setContent('

a

'); LegacyUnit.equal(editor.getContent(), '

a


'); delete editor.settings.padd_empty_with_br; }); suite.test('Padd empty elements with br on insert at caret', function (editor) { editor.settings.padd_empty_with_br = true; editor.setContent('

a

'); LegacyUnit.setSelection(editor, 'p', 1); editor.insertContent('

b

'); LegacyUnit.equal(editor.getContent(), '

a

b


'); delete editor.settings.padd_empty_with_br; }); suite.test('Preserve whitespace pre elements', function (editor) { editor.setContent('
 
'); LegacyUnit.equal(editor.getContent(), '
 
'); }); suite.test('hasFocus', function (editor) { editor.focus(); LegacyUnit.equal(editor.hasFocus(), true); const input = document.createElement('input'); document.body.appendChild(input); input.focus(); LegacyUnit.equal(editor.hasFocus(), false); editor.focus(); LegacyUnit.equal(editor.hasFocus(), true); input.parentNode.removeChild(input); }); TinyLoader.setup(function (editor, onSuccess, onFailure) { Pipeline.async({}, suite.toSteps(editor), function () { onSuccess(); }, onFailure); }, { selector: 'textarea', add_unload_trigger: false, disable_nodechange: true, custom_elements: 'custom1,~custom2', extended_valid_elements: 'custom1,custom2,script[*]', entities: 'raw', indent: false, skin_url: '/project/js/tinymce/skins/lightgray' }, success, failure); });