[ Mini Kiebo ]
Server: Windows NT DESKTOP-5B8S0D4 6.2 build 9200 (Windows 8 Professional Edition) i586
Path:
D:
/
Backup
/
05122024
/
htdocs
/
tracer
/
assets
/
tinymce
/
src
/
core
/
src
/
test
/
js
/
browser
/
[
Home
]
File: InsertContentTest.js
asynctest( 'browser.tinymce.core.InsertContentTest', [ 'ephox.agar.api.Pipeline', 'ephox.mcagar.api.LegacyUnit', 'ephox.mcagar.api.TinyLoader', 'tinymce.core.InsertContent', 'tinymce.themes.modern.Theme' ], function (Pipeline, LegacyUnit, TinyLoader, InsertContent, Theme) { var success = arguments[arguments.length - 2]; var failure = arguments[arguments.length - 1]; var suite = LegacyUnit.createSuite(); Theme(); var assertSelection = function (editor, selector, offset) { var node = editor.$(selector)[0]; var rng = editor.selection.getRng(); LegacyUnit.equalDom(rng.startContainer, node.firstChild); LegacyUnit.equal(rng.startOffset, offset); LegacyUnit.equal(rng.collapsed, true); }; suite.test('insertAtCaret - i inside text, converts to em', function (editor) { editor.setContent('<p>1234</p>'); editor.focus(); LegacyUnit.setSelection(editor, 'p', 2); InsertContent.insertAtCaret(editor, '<i>a</i>'); LegacyUnit.equal(editor.getContent(), '<p>12<em>a</em>34</p>'); }); suite.test('insertAtCaret - ul at beginning of li', function (editor) { editor.setContent('<ul><li>12</li></ul>'); editor.focus(); LegacyUnit.setSelection(editor, 'li', 0); InsertContent.insertAtCaret(editor, { content: '<ul><li>a</li></ul>', paste: true }); LegacyUnit.equal(editor.getContent(), '<ul><li>a</li><li>12</li></ul>'); assertSelection(editor, 'li:nth-child(2)', 0); }); suite.test('insertAtCaret - ul with multiple items at beginning of li', function (editor) { editor.setContent('<ul><li>12</li></ul>'); editor.focus(); LegacyUnit.setSelection(editor, 'li', 0); InsertContent.insertAtCaret(editor, { content: '<ul><li>a</li><li>b</li></ul>', paste: true }); LegacyUnit.equal(editor.getContent(), '<ul><li>a</li><li>b</li><li>12</li></ul>'); assertSelection(editor, 'li:nth-child(3)', 0); }); suite.test('insertAtCaret - ul at end of li', function (editor) { editor.setContent('<ul><li>12</li></ul>'); editor.focus(); LegacyUnit.setSelection(editor, 'li', 2); InsertContent.insertAtCaret(editor, { content: '<ul><li>a</li></ul>', paste: true }); LegacyUnit.equal(editor.getContent(), '<ul><li>12</li><li>a</li></ul>'); assertSelection(editor, 'li:nth-child(2)', 1); }); suite.test('insertAtCaret - ul with multiple items at end of li', function (editor) { editor.setContent('<ul><li>12</li></ul>'); editor.focus(); LegacyUnit.setSelection(editor, 'li', 2); InsertContent.insertAtCaret(editor, { content: '<ul><li>a</li><li>b</li><li>c</li></ul>', paste: true }); LegacyUnit.equal(editor.getContent(), '<ul><li>12</li><li>a</li><li>b</li><li>c</li></ul>'); assertSelection(editor, 'li:nth-child(4)', 1); }); suite.test('insertAtCaret - ul with multiple items in middle of li', function (editor) { editor.setContent('<ul><li>12</li></ul>'); editor.focus(); LegacyUnit.setSelection(editor, 'li', 1); InsertContent.insertAtCaret(editor, { content: '<ul><li>a</li><li>b</li></ul>', paste: true }); LegacyUnit.equal(editor.getContent(), '<ul><li>1</li><li>a</li><li>b</li><li>2</li></ul>'); assertSelection(editor, 'li:nth-child(4)', 1); }); suite.test('insertAtCaret - ul in middle of li with formatting', function (editor) { editor.setContent('<ul><li><em><strong>12</strong></em></li></ul>'); editor.focus(); LegacyUnit.setSelection(editor, 'strong', 1); InsertContent.insertAtCaret(editor, { content: '<ul><li>a</li></ul>', paste: true }); LegacyUnit.equal( editor.getContent(), '<ul><li><em><strong>1</strong></em></li><li>a</li><li><em><strong>2</strong></em></li></ul>' ); assertSelection(editor, 'li:nth-child(3) strong', 1); }); suite.test('insertAtCaret - ul with trailing empty block in middle of li', function (editor) { editor.setContent('<ul><li>a</li><li>d</li></ul>'); editor.focus(); LegacyUnit.setSelection(editor, 'li:nth-child(1)', 1); InsertContent.insertAtCaret(editor, { content: '<ul><li>b</li><li>c</li></ul><p>\u00a0</p>', paste: true }); LegacyUnit.equal( editor.getContent(), '<ul><li>a</li><li>b</li><li>c</li><li>d</li></ul>' ); assertSelection(editor, 'li:nth-child(4)', 1); }); suite.test('insertAtCaret - ul at beginning of li with empty end li', function (editor) { editor.setContent('<ul><li>12</li></ul>'); editor.focus(); LegacyUnit.setSelection(editor, 'li', 0); InsertContent.insertAtCaret(editor, { content: '<ul><li>a</li><li></li></ul>', paste: true }); LegacyUnit.equal(editor.getContent(), '<ul><li>a</li><li>12</li></ul>'); assertSelection(editor, 'li:nth-child(2)', 0); }); suite.test('insertAtCaret - merge inline elements', function (editor) { editor.setContent('<strong><em>abc</em></strong>'); editor.focus(); LegacyUnit.setSelection(editor, 'em', 1); InsertContent.insertAtCaret(editor, { content: '<em><strong>123</strong></em>', merge: true }); LegacyUnit.equal(editor.getContent(), '<p><strong><em>a123bc</em></strong></p>'); }); suite.test('insertAtCaret - list into empty table cell with invalid contents #TINY-1231', function (editor) { editor.getBody().innerHTML = '<table class="mce-item-table"><tbody><tr><td><br></td></tr></tbody></table>'; editor.focus(); var rng = editor.dom.createRng(); rng.setStart(editor.dom.select('td')[0], 0); rng.setEnd(editor.dom.select('td')[0], 0); editor.selection.setRng(rng); InsertContent.insertAtCaret(editor, { content: '<meta http-equiv="content-type" content="text/html; charset=utf-8"><ul><li>a</li></ul>', paste: true }); LegacyUnit.equal(editor.getBody().innerHTML, '<table class="mce-item-table"><tbody><tr><td><ul><li>a</li></ul></td></tr></tbody></table>'); assertSelection(editor, 'li', 1); }); TinyLoader.setup(function (editor, onSuccess, onFailure) { Pipeline.async({}, suite.toSteps(editor), onSuccess, onFailure); }, { selector: "textarea", add_unload_trigger: false, disable_nodechange: true, entities: 'raw', indent: false, skin_url: '/project/src/skins/lightgray/dist/lightgray' }, success, failure); } );