UNPKG

jodit

Version:

Jodit is awesome and usefully wysiwyg editor with filebrowser

1,268 lines (1,068 loc) 43.7 kB
describe('Tables Jodit Editor Tests', function() { describe('Methods', function() { it('After init container must has one element .jodit_table_resizer', function() { var editor = new Jodit(appendTestArea()); expect(editor.editor.querySelector('.jodit_table_resizer')).to.equal(null); editor.selection.insertNode(editor.create.inside.element('table')); editor.selection.insertNode(editor.create.inside.element('table')); expect(editor.container.querySelectorAll('.jodit_table_resizer').length).to.equal(1); }); it('Process wrong tabel', function() { var editor = new Jodit(appendTestArea()); editor.setEditorValue('<table>' + '<tr>' + '<td data-jodit-selected-cell="1">1</td>' + '<td data-jodit-selected-cell="1">2</td>' + '<td rowspan="2">3</td>' + '</tr>' + '<tr><td>4</td></tr>' + '</table>'); // var table = new Jodit.modules.Table(editor); Jodit.modules.Table.mergeSelected(editor.editor.firstChild); expect(editor.container.querySelectorAll('.jodit_table_resizer').length).to.equal(1); }); it('Method getRowsCount should return TR count', function() { var editor = new Jodit(appendTestArea()); editor.setEditorValue('<table>' + [1, 2, 3, 4].map(function() { return '<tr>' + '<td>1</td>' + '<td>2</td>' + '</tr>'; }).join('') + '</table>'); // var table = new Jodit.modules.Table(editor); expect(Jodit.modules.Table.getRowsCount(editor.editor.firstChild)).to.equal(4); }); it('Method getColumnsCount should return maximum of TH or TD in one row in table', function() { var editor = new Jodit(appendTestArea()); editor.setEditorValue('<table>' + '<tr><td>1</td><td>2</td><td>3</td></tr>' + '<tr><td>1</td><td>2</td><td>3</td></tr>' + '<tr><td colspan="2">12</td><td>3</td></tr>' + '<tr><td colspan="3">123</td></tr>' + '<tr><td colspan="3">123</td><td>4</td></tr>' + // 4 cells - wrong table but will suit '</table>'); expect(Jodit.modules.Table.getColumnsCount(editor.editor.firstChild)).to.equal(4); }); it('Method appendRow should append one row in the end of table', function() { var editor = new Jodit(appendTestArea()); editor.setEditorValue('<table>' + '<tr><td>1</td><td>2</td><td>3</td></tr>' + '</table>'); Jodit.modules.Table.appendRow(editor.editor.firstChild); expect(editor.getEditorValue()).to.equal('<table><tbody><tr><td>1</td><td>2</td><td>3</td></tr><tr><td></td><td></td><td></td></tr></tbody></table>'); }); it('Method appendRow with second argument should append one row after row', function() { var editor = new Jodit(appendTestArea()); editor.setEditorValue('<table>' + '<tr><td>1</td><td>2</td><td>3</td></tr>' + '<tr><td>2</td><td>3</td><td>4</td></tr>' + '</table>'); Jodit.modules.Table.appendRow(editor.editor.firstChild, editor.editor.firstChild.querySelector('tr')); expect(editor.getEditorValue()).to.equal('<table><tbody><tr><td>1</td><td>2</td><td>3</td></tr><tr><td></td><td></td><td></td></tr><tr><td>2</td><td>3</td><td>4</td></tr></tbody></table>'); }); it('Method appendRow with second=TR and third=false arguments should append and one row before row', function() { var editor = new Jodit(appendTestArea()); editor.setEditorValue('<table>' + '<tr><td>1</td><td>2</td><td>3</td></tr>' + '<tr><td>2</td><td>3</td><td>4</td></tr>' + '</table>'); Jodit.modules.Table.appendRow(editor.editor.firstChild, editor.editor.firstChild.querySelector('tr'), false); expect(editor.getEditorValue()).to.equal('<table><tbody><tr><td></td><td></td><td></td></tr><tr><td>1</td><td>2</td><td>3</td></tr><tr><td>2</td><td>3</td><td>4</td></tr></tbody></table>'); }); it('Method appendColumn should append column in the end', function() { var editor = new Jodit(appendTestArea()); editor.setEditorValue('<table>' + '<tr><td>1</td><td>2</td></tr>' + '<tr><td colspan="2">3</td></tr>' + '</table>'); Jodit.modules.Table.appendColumn(editor.editor.firstChild); expect(editor.getEditorValue().toLowerCase()).to.equal('<table>' + '<tbody>' + '<tr><td>1</td><td>2</td><td></td></tr>' + '<tr><td colspan="2">3</td><td></td></tr>' + '</tbody>' + '</table>'); }); it('Method appendColumn with second argument should append column after that column', function() { var editor = new Jodit(appendTestArea()); editor.setEditorValue('<table>' + '<tr><td>1</td><td>2</td></tr>' + '<tr><td colspan="2">3</td></tr>' + '</table>'); Jodit.modules.Table.appendColumn(editor.editor.firstChild, 0); expect(editor.getEditorValue().toLowerCase()).to.equal('<table>' + '<tbody>' + '<tr><td>1</td><td></td><td>2</td></tr>' + '<tr><td colspan="3">3</td></tr>' + '</tbody>' + '</table>'); }); it('Method appendColumn with second argument and third = false should append column before that column', function() { var editor = new Jodit(appendTestArea()); editor.setEditorValue('<table>' + '<tr><td>1</td><td>2</td></tr>' + '<tr><td colspan="2">3</td></tr>' + '</table>'); Jodit.modules.Table.appendColumn(editor.editor.firstChild, 1, false); expect(editor.getEditorValue().toLowerCase()).to.equal('<table>' + '<tbody>' + '<tr><td>1</td><td></td><td>2</td></tr>' + '<tr><td colspan="3">3</td></tr>' + '</tbody>' + '</table>'); }); it('Remove row should delete TR from table', function() { var editor = new Jodit(appendTestArea()); editor.setEditorValue('<table>' + '<tr><td>1</td><td>2</td><td>3</td></tr>' + '<tr><td rowspan="2">4</td><td>5</td><td>6</td></tr>' + '<tr><td>7</td><td>8</td></tr>' + '</table>'); simulateEvent('mousedown', Jodit.KEY_TAB, editor.editor.querySelectorAll('td')[4]); Jodit.modules.Table.removeRow(editor.editor.firstChild, 1); expect(editor.getEditorValue().toLowerCase()).to.equal('<table>' + '<tbody>' + '<tr><td>1</td><td>2</td><td>3</td></tr>' + '<tr><td>4</td><td>7</td><td>8</td></tr>' + '</tbody>' + '</table>'); }); describe('Method merge selected cells', function() { it('Simple should merge all selected cells into one ', function() { var editor = new Jodit(appendTestArea()); editor.setEditorValue('<table>' + '<tr><td data-jodit-selected-cell="1">1</td><td data-jodit-selected-cell="1">2</td></tr>' + '<tr><td data-jodit-selected-cell="1">3</td><td data-jodit-selected-cell="1">4</td></tr>' + '<tr><td>5</td><td>6</td></tr>' + '</table>'); // var table = new Jodit.modules.Table(editor); Jodit.modules.Table.mergeSelected(editor.editor.firstChild); expect(sortAttributes(editor.editor.innerHTML)).to.equal( '<table>' + '<tbody>' + '<tr>' + '<td colspan="2" data-jodit-selected-cell="1">1<br>2<br>3<br>4</td>' + '</tr>' + '<tr>' + '<td>5</td>' + '<td>6</td>' + '</tr>' + '</tbody>' + '</table>' ); }); it('With colspan and rowspan into one ', function() { var editor = new Jodit(appendTestArea()); editor.setEditorValue('<table>' + '<tr><td colspan="2" data-jodit-selected-cell="1">1</td></tr>' + '<tr><td data-jodit-selected-cell="1">3</td><td data-jodit-selected-cell="1">4</td></tr>' + '<tr><td rowspan="2" data-jodit-selected-cell="1">5</td><td data-jodit-selected-cell="1">6</td></tr>' + '<tr><td data-jodit-selected-cell="1">7</td></tr>' + '<tr><td>8</td><td>9</td></tr>' + '</table>'); // var table = new Jodit.modules.Table(editor); Jodit.modules.Table.mergeSelected(editor.editor.firstChild); expect(sortAttributes(editor.editor.innerHTML)).to.equal( '<table>' + '<tbody>' + '<tr>' + '<td colspan="2" data-jodit-selected-cell="1">' + '1<br>3<br>4<br>5<br>6<br>7' + '</td>' + '</tr>' + '<tr>' + '<td>8</td>' + '<td>9</td>' + '</tr>' + '</tbody>' + '</table>' ); }); it('A few cells with colspan and rowspan', function() { var editor = new Jodit(appendTestArea()); editor.setEditorValue( '<table style="width: 100%;">' + '<tbody>' + '<tr><td data-jodit-selected-cell="1" colspan="3">0,0<br>0,1<br>0,2<br></td><td>0,3</td></tr>' + '<tr><td data-jodit-selected-cell="1" rowspan="3">1,0<br>2,0<br>3,0<br></td><td data-jodit-selected-cell="1">1,1</td><td data-jodit-selected-cell="1">1,2</td><td>1,3</td></tr>' + '<tr><td data-jodit-selected-cell="1">2,1</td><td data-jodit-selected-cell="1">2,2</td><td>2,3</td></tr>' + '<tr><td data-jodit-selected-cell="1">3,1</td><td data-jodit-selected-cell="1">3,2</td><td>3,3</td></tr>' + '</tbody></table>'); // var table = new Jodit.modules.Table(editor); Jodit.modules.Table.mergeSelected(editor.editor.firstChild); expect(sortAttributes(editor.editor.innerHTML)).to.equal( '<table style="width:100%">' + '<tbody>' + '<tr>' + '<td data-jodit-selected-cell="1" rowspan="4">' + '0,0<br>0,1<br>0,2<br><br>' + '1,0<br>2,0<br>3,0<br><br>' + '1,1<br>' + '1,2<br>' + '2,1<br>' + '2,2<br>' + '3,1<br>' + '3,2' + '</td>' + '<td>0,3</td>' + '</tr>' + '<tr>' + '<td>1,3</td>' + '</tr>' + '<tr>' + '<td>2,3</td>' + '</tr>' + '<tr>' + '<td>3,3</td>' + '</tr>' + '</tbody>' + '</table>' ); }); it('Merge cells in center', function() { var editor = new Jodit(appendTestArea()); editor.setEditorValue( '<table style="width: 100%;">' + '<tbody>' + '<tr><td colspan="3" class="">0,0<br>0,1<br>0,2<br></td><td>0,3</td></tr>' + '<tr>' + '<td rowspan="3" class="">1,0<br>2,0<br>3,0<br></td>' + '<td data-jodit-selected-cell="1">1,1</td><td data-jodit-selected-cell="1">1,2</td>' + '<td data-jodit-selected-cell="1">1,3</td>' + '</tr>' + '<tr>' + '<td data-jodit-selected-cell="1">2,1</td>' + '<td data-jodit-selected-cell="1">2,2</td>' + '<td data-jodit-selected-cell="1">2,3</td>' + '</tr>' + '<tr>' + '<td class="">3,1</td>' + '<td class="">3,2</td>' + '<td>3,3</td></tr>' + '</tbody>' + '</table>'); // var table = new Jodit.modules.Table(editor); Jodit.modules.Table.mergeSelected(editor.editor.firstChild); expect(sortAttributes(editor.editor.innerHTML)).to.equal( '<table style="width:100%">' + '<tbody>' + '<tr>' + '<td colspan="3">0,0<br>0,1<br>0,2<br></td><td>0,3</td>' + '</tr>' + '<tr>' + '<td rowspan="2">1,0<br>2,0<br>3,0<br></td>' + '<td colspan="3" data-jodit-selected-cell="1">1,1<br>1,2<br>1,3<br>2,1<br>2,2<br>2,3</td>' + '</tr>' + '<tr>' + '<td>3,1</td><td>3,2</td><td>3,3</td>' + '</tr>' + '</tbody>' + '</table>' ); }); it('Normalize merged cells', function() { var editor = new Jodit(appendTestArea()); editor.setEditorValue( '<table>' + '<tbody>' + '<tr>' + '<td colspan="3" data-jodit-selected-cell="1" rowspan="4">1</td>' + '<td data-jodit-selected-cell="1" rowspan="4">2</td>' + '</tr>' + '<tr></tr>' + '<tr></tr>' + '<tr></tr>' + '</tbody>' + '</table>'); // var table = new Jodit.modules.Table(editor); Jodit.modules.Table.mergeSelected(editor.editor.firstChild); expect(sortAttributes(editor.editor.innerHTML)).to.equal( '<table>' + '<tbody>' + '<tr>' + '<td data-jodit-selected-cell="1">1<br>2</td>' + '</tr>' + '</tbody>' + '</table>' ); }); }); describe('Split selected cells', function() { it('Split cell by Horizontal', function() { var editor = new Jodit(appendTestArea()); editor.setEditorValue( '<table>' + '<tbody>' + '<tr><td data-jodit-selected-cell="1">0,0</td></tr>' + '<tr><td>1,0</td></tr>' + '</tbody>' + '</table>' ); // var table = new Jodit.modules.Table(editor); Jodit.modules.Table.splitHorizontal(editor.editor.firstChild); expect(sortAttributes(editor.editor.innerHTML)).to.equal( '<table>' + '<tbody>' + '<tr><td>0,0</td></tr>' + '<tr><td><br></td></tr>' + '<tr><td>1,0</td></tr>' + '</tbody>' + '</table>' ); }); it('Split cell with rowspan by horizontal ', function() { var editor = new Jodit(appendTestArea()); editor.setEditorValue( '<table>' + '<tbody>' + '<tr><td>0,0</td><td>0,1</td><td>0,2</td></tr>' + '<tr>' + '<td rowspan="2" data-jodit-selected-cell="1">1,0</td>' + '<td>1,1</td>' + '<td rowspan="2">1,2</td>' + '</tr>' + '<tr><td><br></td></tr>' + '<tr><td>2,0</td><td>2,1</td><td>2,2</td></tr>' + '</tbody>' + '</table>' ); // var table = new Jodit.modules.Table(editor); Jodit.modules.Table.splitHorizontal(editor.editor.firstChild); expect(sortAttributes(editor.editor.innerHTML)).to.equal( '<table>' + '<tbody>' + '<tr><td>0,0</td><td>0,1</td><td>0,2</td></tr>' + '<tr>' + '<td>1,0</td>' + '<td>1,1</td>' + '<td rowspan="2">1,2</td>' + '</tr>' + '<tr><td><br></td><td><br></td></tr>' + '<tr><td>2,0</td><td>2,1</td><td>2,2</td></tr>' + '</tbody>' + '</table>' ); }); it('Split cell with rowspan by horizontal 2', function() { var editor = new Jodit(appendTestArea()); editor.setEditorValue( '<table>' + '<tbody>' + '<tr><td>0,0</td><td>0,1</td><td>0,2</td></tr>' + '<tr>' + '<td rowspan="2">1,0</td>' + '<td rowspan="2" data-jodit-selected-cell="1">1,1</td>' + '<td>1,2</td>' + '</tr>' + '<tr><td><br></td></tr>' + '<tr><td>2,0</td><td>2,1</td><td>2,2</td></tr>' + '</tbody>' + '</table>' ); // var table = new Jodit.modules.Table(editor); Jodit.modules.Table.splitHorizontal(editor.editor.firstChild); expect(sortAttributes(editor.editor.innerHTML)).to.equal( '<table>' + '<tbody>' + '<tr><td>0,0</td><td>0,1</td><td>0,2</td></tr>' + '<tr>' + '<td rowspan="2">1,0</td>' + '<td>1,1</td>' + '<td>1,2</td>' + '</tr>' + '<tr><td><br></td><td><br></td></tr>' + '<tr><td>2,0</td><td>2,1</td><td>2,2</td></tr>' + '</tbody>' + '</table>' ); }); it('Split cell by vertical', function() { var editor = new Jodit(appendTestArea()); editor.setEditorValue( '<table style="width: 300px;">' + '<tbody>' + '<tr><td style="width:100px" data-jodit-selected-cell="1">0,0</td><td>0,1</td></tr>' + '<tr><td>1,0</td><td>1,1</td></tr>' + '</tbody>' + '</table>' ); // var table = new Jodit.modules.Table(editor); Jodit.modules.Table.splitVertical(editor.editor.firstChild); expect(sortAttributes(editor.editor.innerHTML)).to.equal( '<table style="width:300px">' + '<tbody>' + '<tr><td style="width:16.66%">0,0</td><td style="width:16.66%"><br></td><td>0,1</td></tr>' + '<tr><td colspan="2">1,0</td><td>1,1</td></tr>' + '</tbody>' + '</table>' ); }); }); }); describe('Work with tables', function() { it('Create table and insert into cell some text', function() { var editor = new Jodit(appendTestArea()); editor.ownerWindow.focus(); editor.value = ''; var table = editor.create.inside.element('table'), tr = editor.create.inside.element('tr'), td = editor.create.inside.element('td'), td2 = editor.create.inside.element('td'); tr.appendChild(td); tr.appendChild(td2); table.appendChild(tr); editor.selection.focus(); editor.selection.insertNode(table, false); editor.selection.setCursorIn(table, false); // set cursor in last cell editor.selection.insertNode(editor.create.inside.text('ok')); expect(editor.value).to.equal('<table><tr><td></td><td>ok</td></tr></table>'); }); it('After insert table like html without tbody, it should be appear', function() { var editor = new Jodit(appendTestArea()); editor.setEditorValue('<table>' + '<tr>' + '<td>1</td>' + '<td>2</td>' + '</tr>' + '</table>'); expect(editor.getEditorValue()).to.equal('<table><tbody><tr><td>1</td><td>2</td></tr></tbody></table>'); }); it('After press Tab button cursor should be in next cell in table', function() { var editor = new Jodit(appendTestArea()); editor.setEditorValue('<table>' + '<tr>' + '<td>1</td>' + '<td>2</td>' + '</tr>' + '</table>'); editor.selection.setCursorIn(editor.editor.querySelector('td')); simulateEvent('keydown', Jodit.KEY_TAB, editor.editor); editor.selection.insertNode(editor.create.inside.text('test'), false); expect(editor.value.replace('<br>', '')).to.equal('<table><tbody><tr><td>1</td><td>test</td></tr></tbody></table>'); }); it('After press Tab + Shift buttons cursor should be in next cell in table', function() { var editor = new Jodit(appendTestArea()); editor.setEditorValue('<table>' + '<tr>' + '<td>1</td>' + '<td>2</td>' + '</tr>' + '</table>'); editor.selection.setCursorIn(editor.editor.querySelector('td').nextSibling); simulateEvent('keydown', Jodit.KEY_TAB, editor.editor, function(evnt) { evnt.shiftKey = true; }); editor.selection.insertNode(editor.create.inside.text('test'), false); expect(editor.value.replace('<br>', '')).to.equal('<table><tbody><tr><td>test</td><td>2</td></tr></tbody></table>'); }); it('After press Right arrow not in the end of cell it should do nothing', function() { var editor = new Jodit(appendTestArea()); editor.setEditorValue('<table>' + '<tr>' + '<td>1</td>' + '<td>2</td>' + '</tr>' + '</table>'); editor.selection.setCursorIn(editor.editor.querySelector('td'), true); // set cursor before 1 simulateEvent('keydown', Jodit.KEY_RIGHT, editor.editor); // not work but in real cursor move after 1 editor.selection.insertNode(editor.create.inside.text('test'), false); expect(editor.getEditorValue()).to.equal('<table><tbody><tr><td>test1</td><td>2</td></tr></tbody></table>'); }); it('After press Left arrow in the start of cell it should work like tab + shift', function() { var editor = new Jodit(appendTestArea()); editor.setEditorValue('<table>' + '<tr>' + '<td>1</td>' + '<td>2</td>' + '</tr>' + '</table>'); editor.selection.setCursorIn(editor.editor.querySelector('td').nextSibling, true); // set cursor before 1 simulateEvent('keydown', Jodit.KEY_LEFT, editor.editor); // not work but in real cursor move after 1 editor.selection.insertNode(editor.create.inside.text('test'), false); expect(editor.getEditorValue()).to.equal('<table><tbody>' + '<tr>' + '<td>1test</td>' + '<td>2</td>' + '</tr>' + '</tbody></table>'); }); it('After press Top arrow in the first cell\'s line cursor should move into top cell', function() { var editor = new Jodit(appendTestArea()); editor.setEditorValue('<table>' + '<tr>' + '<td>1</td>' + '<td>2</td>' + '</tr>' + '<tr>' + '<td>3</td>' + '<td>4<br>5<br>6</td>' + '</tr>' + '</table>'); editor.selection.setCursorAfter(editor.editor.querySelectorAll('td')[3].firstChild); // set cursor after 4 simulateEvent('keydown', Jodit.KEY_UP, editor.editor); editor.selection.insertNode(editor.create.inside.text('test'), false); expect(editor.getEditorValue()).to.equal('<table><tbody>' + '<tr>' + '<td>1</td>' + '<td>2test</td></tr>' + '<tr>' + '<td>3</td>' + '<td>' + '4<br>' + '5<br>' + '6' + '</td>' + '</tr>' + '</tbody></table>'); }); it('After press Bottom arrow in the first cell\'s line cursor should move into bottom cell', function() { var editor = new Jodit(appendTestArea()); editor.setEditorValue('<table>' + '<tr>' + '<td>1</td>' + '<td>2<br>3</td>' + '</tr>' + '<tr>' + '<td>4</td>' + '<td>5</td>' + '</tr>' + '</table>'); editor.selection.setCursorAfter(editor.editor.querySelectorAll('td')[1].lastChild); // set cursor after 3 simulateEvent('keydown', Jodit.KEY_DOWN, editor.editor); editor.selection.insertNode(editor.create.inside.text('test'), false); expect(editor.getEditorValue()).to.equal('<table><tbody>' + '<tr>' + '<td>1</td>' + '<td>2<br>3</td>' + '</tr>' + '<tr>' + '<td>4</td>' + '<td>test5</td>' + '</tr>' + '</tbody></table>'); }); it('After press Tab in last table\'s cell in table should add new row and move into first cell form it', function() { var editor = new Jodit(appendTestArea()); editor.setEditorValue('<table>' + '<tr>' + '<td>1</td>' + '<td>2</td>' + '</tr>' + '</table>'); editor.selection.setCursorAfter(editor.editor.querySelectorAll('td')[1].lastChild); // set cursor after 2 simulateEvent('keydown', Jodit.KEY_TAB, editor.editor); editor.selection.insertNode(editor.create.inside.text('test'), false); expect(editor.getEditorValue()).to.equal('<table><tbody>' + '<tr>' + '<td>1</td>' + '<td>2</td>' + '</tr>' + '<tr>' + '<td>test<br></td>' + '<td></td>' + '</tr>' + '</tbody></table>'); }); describe('Remove row', function() { it('Remove simple row without rowspan should simple remove row', function() { var editor = new Jodit(appendTestArea()); editor.setEditorValue('<table>' + '<tr><td>1</td><td>2</td></tr>' + '<tr><td>3</td><td>4</td></tr>' + '</table>'); var table = new Jodit.modules.Table(editor); Jodit.modules.Table.removeRow(editor.editor.firstChild, 0); expect(editor.getEditorValue().toLowerCase()).to.equal('<table>' + '<tbody>' + '<tr><td>3</td><td>4</td></tr>' + '</tbody>' + '</table>'); }); it('Remove row which not consists td, because of in previous row was cell with rowspan should simple remove row and decrement rowspan', function() { var editor = new Jodit(appendTestArea()); editor.setEditorValue('<table>' + '<tr><td rowspan="2">1</td><td>2</td></tr>' + '<tr><td>3</td></tr>' + '</table>'); // var table = new Jodit.modules.Table(editor); Jodit.modules.Table.removeRow(editor.editor.firstChild, 1); expect(editor.getEditorValue().toLowerCase()).to.equal('<table>' + '<tbody>' + '<tr><td>1</td><td>2</td></tr>' + '</tbody>' + '</table>'); }); it('Remove row which not consists td, because of in previous row was cell with rowspan and colspan should simple remove row and decrement rowspan once time', function() { var editor = new Jodit(appendTestArea()); editor.setEditorValue('<table>' + '<tr><td rowspan="3" colspan="2">1</td><td>2</td></tr>' + '<tr><td>3</td></tr>' + '<tr><td>4</td></tr>' + '<tr><td>5</td><td>6</td><td>7</td></tr>' + '</table>'); // var table = new Jodit.modules.Table(editor); Jodit.modules.Table.removeRow(editor.editor.firstChild, 1); expect(editor.getEditorValue().toLowerCase()).to.equal('<table>' + '<tbody>' + '<tr><td rowspan="2" colspan="2">1</td><td>2</td></tr>' + '<tr><td>4</td></tr>' + '<tr><td>5</td><td>6</td><td>7</td></tr>' + '</tbody>' + '</table>'); }); it('Remove row which consists td with rowspan should simple remove row and decrement rowspan and move that cell into next row', function() { var editor = new Jodit(appendTestArea()); editor.setEditorValue('<table>' + '<tr><td rowspan="2">1</td><td>2</td></tr>' + '<tr><td>3</td></tr>' + '</table>'); // var table = new Jodit.modules.Table(editor); Jodit.modules.Table.removeRow(editor.editor.firstChild, 0); expect(editor.getEditorValue().toLowerCase()).to.equal('<table>' + '<tbody>' + '<tr><td>1</td><td>3</td></tr>' + '</tbody>' + '</table>'); }); it('Remove row which consists td with rowspan and colspan should simple remove row and decrement rowspan and move that cell into next row', function() { var editor = new Jodit(appendTestArea()); editor.setEditorValue('<table>' + '<tr><td rowspan="2" colspan="2">1</td><td>2</td></tr>' + '<tr><td>3</td></tr>' + '<tr><td>4</td><td>5</td><td>6</td></tr>' + '</table>'); // var table = new Jodit.modules.Table(editor); Jodit.modules.Table.removeRow(editor.editor.firstChild, 0); expect(editor.getEditorValue().toLowerCase()).to.equal('<table>' + '<tbody>' + '<tr><td colspan="2">1</td><td>3</td></tr>' + '<tr><td>4</td><td>5</td><td>6</td></tr>' + '</tbody>' + '</table>'); }); it('Remove row which consists last td with rowspan and colspan should simple remove row and decrement rowspan and move that cell into next row in last position', function() { var editor = new Jodit(appendTestArea()); editor.setEditorValue('<table>' + '<tr><td>1</td><td>2</td><td>3</td></tr>' + '<tr><td>4</td><td colspan="2" rowspan="2">5</td></tr>' + '<tr><td>6</td></tr>' + '</table>'); // var table = new Jodit.modules.Table(editor); Jodit.modules.Table.removeRow(editor.editor.firstChild, 1); expect(editor.getEditorValue().toLowerCase()).to.equal('<table>' + '<tbody>' + '<tr><td>1</td><td>2</td><td>3</td></tr>' + '<tr><td>6</td><td colspan="2">5</td></tr>' + '</tbody>' + '</table>'); }); }); describe('Remove column', function() { it('Remove simple column without colspan should simple remove all cells in column', function() { var editor = new Jodit(appendTestArea()); editor.setEditorValue('<table>' + '<tr><td>1</td><td>2</td></tr>' + '<tr><td>3</td><td>4</td></tr>' + '<tr><td>5</td><td>6</td></tr>' + '</table>'); // var table = new Jodit.modules.Table(editor); Jodit.modules.Table.removeColumn(editor.editor.firstChild, 0); expect(editor.getEditorValue().toLowerCase()).to.equal('<table>' + '<tbody>' + '<tr><td>2</td></tr>' + '<tr><td>4</td></tr>' + '<tr><td>6</td></tr>' + '</tbody>' + '</table>'); }); it('Remove column which consists td with colspan should remove all cells in column but that td should decrement colspan', function() { var editor = new Jodit(appendTestArea()); editor.setEditorValue('<table>' + '<tr><td>1</td><td>2</td></tr>' + '<tr><td colspan="2">3</td></tr>' + '<tr><td>4</td><td>5</td></tr>' + '</table>'); // var table = new Jodit.modules.Table(editor); Jodit.modules.Table.removeColumn(editor.editor.firstChild, 0); expect(editor.getEditorValue().toLowerCase()).to.equal('<table>' + '<tbody>' + '<tr><td>2</td></tr>' + '<tr><td>3</td></tr>' + '<tr><td>5</td></tr>' + '</tbody>' + '</table>'); }); it('Remove column which not consists td with colspan should remove all cells in column but that td should decrement colspan too', function() { var editor = new Jodit(appendTestArea()); editor.setEditorValue('<table>' + '<tr><td>1</td><td>2</td></tr>' + '<tr><td colspan="2">3</td></tr>' + '<tr><td>4</td><td>5</td></tr>' + '</table>'); // var table = new Jodit.modules.Table(editor); Jodit.modules.Table.removeColumn(editor.editor.firstChild, 1); expect(editor.getEditorValue().toLowerCase()).to.equal('<table>' + '<tbody>' + '<tr><td>1</td></tr>' + '<tr><td>3</td></tr>' + '<tr><td>4</td></tr>' + '</tbody>' + '</table>'); }); it('Remove column part of that td (colspan and rowspan) in another column should remove all cells in column but that td should decrement colspan once time', function() { var editor = new Jodit(appendTestArea()); editor.setEditorValue('<table>' + '<tr><td>1</td><td>2</td><td>3</td><td>4</td></tr>' + '<tr><td>5</td><td colspan="3" rowspan="2">6</td></tr>' + '<tr><td>7</td></tr>' + '</table>'); // var table = new Jodit.modules.Table(editor); Jodit.modules.Table.removeColumn(editor.editor.firstChild, 3); var result = editor.getEditorValue().toLowerCase(); // in ie colspan and rowspan change places but it is not so important result = result.replace('rowspan', 'colspan'); expect(result).to.equal('<table>' + '<tbody>' + '<tr><td>1</td><td>2</td><td>3</td></tr>' + '<tr><td>5</td><td colspan="2" colspan="2">6</td></tr>' + '<tr><td>7</td></tr>' + '</tbody>' + '</table>'); }); }); describe('Select cells', function() { it('When we press mouse button over cell and move mouse to another cell, it should select all cells in bound', function() { var editor = new Jodit(appendTestArea()); editor.setEditorValue('<table>' + '<tr><td>1</td><td>2</td></tr>' + '<tr><td>3</td><td>4</td></tr>' + '<tr><td>5</td><td>6</td></tr>' + '</table>'); simulateEvent('mousedown', 1, editor.editor.querySelector('td')); simulateEvent('mousemove', 1, editor.editor.querySelectorAll('td')[3]); simulateEvent('mouseup', 1, editor.editor.querySelectorAll('td')[3]); expect(sortAttributes(editor.editor.innerHTML)).to.equal( '<table>' + '<tbody>' + '<tr>' + '<td data-jodit-selected-cell="1">1</td>' + '<td data-jodit-selected-cell="1">2</td>' + '</tr>' + '<tr>' + '<td data-jodit-selected-cell="1">3</td>' + '<td data-jodit-selected-cell="1">4</td>' + '</tr>' + '<tr>' + '<td>5</td>' + '<td>6</td>' + '</tr>' + '</tbody>' + '</table>' ); }); it('When we press mouse button over cell in subtable and move mouse to another cell, it should select all cells in bound in that table', function() { var editor = new Jodit(appendTestArea()); editor.setEditorValue('<table>' + '<tr><td>1</td><td>2</td></tr>' + '<tr>' + '<td>3</td>' + '<td class="test">' + '<table>' + '<tr><td>1</td><td>2</td></tr>' + '<tr><td>3</td><td>4</td></tr>' + '<tr><td>5</td><td>6</td></tr>' + '</table>' + '</td>' + '</tr>' + '<tr><td>5</td><td>6</td></tr>' + '</table>'); //var table = new Jodit.modules.Table(editor); //editor.selection.setCursorIn(editor.editor.querySelector('td')); simulateEvent('mousedown', 1, editor.editor.querySelector('.test').querySelector('td')); simulateEvent('mousemove', 1, editor.editor.querySelector('.test').querySelectorAll('td')[3]); simulateEvent('mouseup', 1, editor.editor.querySelector('.test').querySelectorAll('td')[3]); expect(sortAttributes(editor.editor.innerHTML)).to.equal('<table><tbody><tr><td>1</td><td>2</td></tr><tr><td>3</td><td class="test"><table><tbody><tr><td data-jodit-selected-cell="1">1</td><td data-jodit-selected-cell="1">2</td></tr><tr><td data-jodit-selected-cell="1">3</td><td data-jodit-selected-cell="1">4</td></tr><tr><td>5</td><td>6</td></tr></tbody></table></td></tr><tr><td>5</td><td>6</td></tr></tbody></table>'); }); it('When we press mouse button over cell and move mouse to another cell, it should select all cells in bound even if between be colspan and rowspan', function() { var editor = new Jodit(appendTestArea()); editor.setEditorValue( '<table style="width: 100%;">' + '<tbody>' + '<tr><td colspan="3">0,0<br>0,1<br>0,2<br></td><td>0,3</td></tr>' + '<tr><td rowspan="3">1,0<br>2,0<br>3,0<br></td><td>1,1</td><td>1,2</td><td>1,3</td></tr>' + '<tr><td>2,1</td><td>2,2</td><td>2,3</td></tr>' + '<tr><td>3,1</td><td>3,2</td><td>3,3</td></tr>' + '</tbody>' + '</table>' ); //var table = new Jodit.modules.Table(editor); //editor.selection.setCursorIn(editor.editor.querySelector('td')); simulateEvent('mousedown', 1, editor.editor.querySelectorAll('td')[0]); simulateEvent('mousemove', 1, editor.editor.querySelectorAll('td')[7]); simulateEvent('mouseup', 1, editor.editor.querySelectorAll('td')[7]); expect( sortAttributes(editor.editor.innerHTML) // ie change position between colspan and class ).to.equal( '<table style="width:100%"><tbody><tr><td colspan="3" data-jodit-selected-cell="1">0,0<br>0,1<br>0,2<br></td><td>0,3</td></tr><tr><td data-jodit-selected-cell="1" rowspan="3">1,0<br>2,0<br>3,0<br></td><td data-jodit-selected-cell="1">1,1</td><td data-jodit-selected-cell="1">1,2</td><td>1,3</td></tr><tr><td data-jodit-selected-cell="1">2,1</td><td data-jodit-selected-cell="1">2,2</td><td>2,3</td></tr><tr><td data-jodit-selected-cell="1">3,1</td><td data-jodit-selected-cell="1">3,2</td><td>3,3</td></tr></tbody></table>' ); }); }); describe('Resize column', function() { describe('Move mouse over edge of cell', function() { before(function() { var brs = []; for (i = 0; i < 100; i += 1) { brs.push(document.createElement('br')); brs[brs.length - 1].classList.add('test'); document.body.appendChild(brs[brs.length - 1]); } }); describe('Normal scroll', function() { it('should show resizer element', function(done) { var editor = new Jodit(appendTestArea()); window.scrollTo(0, Jodit.modules.Helpers.offset(editor.container, editor, editor.ownerDocument).top + 50); editor.setEditorValue('<table>' + '<tr><td>1</td><td>2</td></tr>' + '</table><p>3</p>'); var box = Jodit.modules.Helpers.offset(editor.editor.querySelectorAll('td')[1], editor, editor.editorDocument); var tablebox = Jodit.modules.Helpers.offset(editor.editor.querySelector('table'), editor, editor.editorDocument); simulateEvent('mousemove', 1, editor.editor.getElementsByTagName('td')[1], function(options) { options.clientX = box.left; options.clientY = box.top; options.pageX = 0; options.pageY = 0; }); var resizer = editor.container.querySelector('.jodit_table_resizer'); expect(resizer).to.be.not.equal(null); expect(resizer.style.display === 'block').to.equal(true); var resizerBox = Jodit.modules.Helpers.offset(resizer, editor, editor.ownerDocument); expect(Math.abs(resizerBox.left - box.left) < 10).to.be.true; expect(Math.abs(resizerBox.top - tablebox.top) < 10).to.be.true; simulateEvent('mouseleave', 1, editor.editor.querySelector('table'), function(options) { options.relatedTarget = editor.editor.querySelector('p'); }); simulateEvent('mousemove', 1, editor.editor.querySelector('p')); expect(resizer.style.display === 'none').to.equal(true); done(); }); }); after(function() { [].slice.call(document.querySelectorAll('br.test')).forEach(function(br) { br.parentNode && br.parentNode.removeChild(br); }); }); }); it('When move mouse over left edge of cell and press mouse button and move cursor to right in 500 pixels - resizer should be nearby next edge', function(done) { var editor = new Jodit(appendTestArea()); editor.setEditorValue('<table style="width: 100px; border-collapse: separate;" cellspacing="0">' + '<tr><td>1</td><td>2</td><td>3</td><td>4</td><td>5</td></tr>' + '</table>'); var td = editor.editor.querySelectorAll('td')[1], box = td.getBoundingClientRect(); simulateEvent('mousemove', 1, td, function(options) { options.clientX = box.left; options.offsetX = 0; options.pageX = 0; options.pageY = 0; }); simulateEvent('mousedown', 1, editor.container.querySelector('.jodit_table_resizer'), function(options) { options.clientX = box.left; options.pageX = 0; options.pageY = 0; }); simulateEvent('mousemove', 1, editor.editorWindow, function(options) { options.clientX = box.left + 500; // can move only on 5 pixels options.pageX = 0; options.pageY = 0; }); expect(parseInt(editor.container.querySelector('.jodit_table_resizer').style.left, 10) < 55).to.equal(true); done(); }); describe('Resize column', function() { describe('When move mouse over left edge of cell and press mouse button and move cursor to right in 5 pixels', function(done) { it('should decrease the width of the right column and the width of the left column should increase', function(done) { var editor = new Jodit(appendTestArea()); editor.setEditorValue('<table style="width: 100px; border-collapse: separate;" cellspacing="0">' + '<tr><td>1</td><td>2</td><td>3</td><td>4</td></tr>' + '</table>'); var td = editor.editor.querySelectorAll('td')[1], box = td.getBoundingClientRect(); simulateEvent('mousemove', 1, td, function(options) { options.clientX = box.left; options.offsetX = 0; options.pageX = 0; options.pageY = 0; }); simulateEvent('mousedown', 1, editor.container.querySelector('.jodit_table_resizer'), function(options) { options.clientX = box.left; options.pageX = 0; options.pageY = 0; }); simulateEvent('mousemove', 1, editor.editorWindow, function(options) { options.clientX = box.left + 5; // move on 5 pixels options.pageX = 0; options.pageY = 0; }); simulateEvent('mouseup', 1, window, function(options) { options.clientX = box.left + 5; // move on 5 pixels options.pageX = 0; options.pageY = 0; }); expect(editor.editor.innerHTML.toLowerCase()).to.equal( '<table style="width: 100px; border-collapse: separate;" cellspacing="0"><tbody>' + '<tr>' + '<td style="width: 30%;">1</td>' + '<td style="width: 20%;">2</td>' + '<td>3</td>' + '<td>4</td>' + '</tr>' + '</tbody></table>' ); done(); }); describe('After resize', function() { it('it should restore selection', function(done) { var editor = new Jodit(appendTestArea()); editor.value = '<p>test</p><table style="width: 100px; border-collapse: separate;" cellspacing="0">' + '<tr><td>1</td><td>2</td><td>3</td><td>4</td></tr>' + '</table>'; var td = editor.editor.querySelectorAll('td')[1], box = td.getBoundingClientRect(); editor.selection.setCursorIn(editor.editor.firstChild); simulateEvent('mousemove', 1, td, function(options) { options.clientX = box.left; options.offsetX = 0; options.pageX = 0; options.pageY = 0; }); simulateEvent('mousedown', 1, editor.container.querySelector('.jodit_table_resizer'), function(options) { options.clientX = box.left; options.pageX = 0; options.pageY = 0; }); simulateEvent('mousemove', 1, editor.editorWindow, function(options) { options.clientX = box.left + 5; // move on 5 pixels options.pageX = 0; options.pageY = 0; }); simulateEvent('mouseup', 1, editor.ownerWindow, function(options) { options.clientX = box.left + 5; // move on 5 pixels options.pageX = 0; options.pageY = 0; }); editor.selection.insertHTML('stop'); expect(sortAttributes(editor.value)).to.equal( '<p>teststop</p>' + '<table cellspacing="0" style="border-collapse:separate;width:100px">' + '<tbody>' + '<tr>' + '<td style="width:30%">1</td>' + '<td style="width:20%">2</td>' + '<td>3</td>' + '<td>4</td>' + '</tr>' + '</tbody>' + '</table>' ); done(); }); }); }); }); it('When move mouse over right edge of last cell and press mouse button and move cursor to right in 50 pixels - the width of the whole table should increase', function() { var editor = new Jodit(appendTestArea()); getBox().style.width = '202px'; editor.setEditorValue('<table style="width: 100px; border-collapse: separate;" cellspacing="0">' + '<tr><td>1</td><td>2</td><td>3</td><td>5</td></tr>' + '</table>'); var td = editor.editor.querySelectorAll('td')[3], box = td.getBoundingClientRect(); simulateEvent('mousemove', 1, td, function(options) { options.clientX = box.left + box.width; options.offsetX = box.width; }); simulateEvent('mousedown', 1, editor.container.querySelector('.jodit_table_resizer'), function(options) { options.clientX = box.left + box.width; }); simulateEvent('mousemove', 1, window, function(options) { options.clientX = box.left + box.width + 50; }); simulateEvent('mouseup', 1, window, function(options) { options.clientX = box.left + box.width + 50; }); expect(sortAttributes(editor.editor.innerHTML.toLowerCase())).to.equal( '<table cellspacing="0" style="border-collapse:separate;width:83.33%"><tbody>' + '<tr>' + '<td>1</td>' + '<td>2</td>' + '<td>3</td>' + '<td>5</td>' + '</tr>' + '</tbody></table>' ); }); it('When move mouse over left edge of first cell and press mouse button and move cursor to left in 50 pixels - the width of the whole table should increase', function() { var editor = new Jodit(appendTestArea()); getBox().style.width = '202px'; editor.setEditorValue('<table style="width: 100px">' + '<tr><td>1</td><td>2</td><td>3</td><td>4</td></tr>' + '</table>'); var td = editor.editor.querySelectorAll('td')[0], box = td.getBoundingClientRect(); simulateEvent('mousemove', 1, td, function(options) { options.clientX = box.left; options.offsetX = 0; }); simulateEvent('mousedown', 1, editor.container.querySelector('.jodit_table_resizer'), function(options) { options.clientX = box.left; }); simulateEvent('mousemove', 1, window, function(options) { options.clientX = box.left + 50; }); simulateEvent('mouseup', 1, window, function(options) { options.clientX = box.left + 50; }); expect(sortAttributes(editor.editor.innerHTML.toLowerCase())).to.equal('<table style="margin-left:27.77%;width:27.77%">' + '<tbody>' + '<tr>' + '<td>1</td>' + '<td>2</td>' + '<td>3</td>' + '<td>4</td>' + '</tr>' + '</tbody>' + '</table>'); }); }); describe('Resize table', function() { describe('Image in cell', function() { describe('Mouse down on the Image', function() { it('should show resizer for this image', function() { var area = document.createElement('textarea'); area.setAttribute('id', 'should_show_resizer_for_this_image'); document.body.appendChild(area); var editor = new Jodit(area); editor.setEditorValue('<table>' + '<tr>' + '<td>1</td>' + '<td>2</td>' + '<td>3</td>' + '<td>4</td>' + '<td>5</td>' + '<td>6</td>' + '<td>7</td>' + '<td><img style="width:30px" src="tests/artio.jpg"></td>' + '</tr>' + '</table>'); simulateEvent('mousedown', 1, editor.editor.querySelector('img')); var resizer = editor.ownerDocument.querySelector('.jodit_resizer[data-editor_id=should_show_resizer_for_this_image]'); expect(resizer && resizer.style.display === 'block').to.equal(true); var positionResizer = offset(resizer); var positionImg = offset(editor.editor.querySelector('img')); expect(Math.abs(positionResizer.left - positionImg.left) < 10).to.be.true; expect(Math.abs(positionResizer.top - positionImg.top) < 10).to.be.true; document.body.removeChild(area); }); }); }); }); }); afterEach(removeStuff); });