123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105 |
- module( 'plugins.charts' );
- test( '图表命令检测', function() {
- expect(3);
- var container = te.obj[0].container,
- editor = null,
- count = 0;
- UE.delEditor( te.obj[0] );
- container.parentNode.removeChild( container );
- container = document.createElement( "div" );
- container.id = "container";
- document.body.appendChild( container );
- editor = UE.getEditor( "container", {
- initialContent: '<table><tbody><tr><td width="147" valign="top">' +
- '<br></td><td width="147" valign="top"><br></td>' +
- '<td width="147" valign="top"><br></td><td width="147" valign="top">' +
- '<br></td><td width="147" valign="top"><br></td></tr></tbody></table>'
- } );
- stop();
- editor.ready( function () {
- var firstTd = editor.body.getElementsByTagName("td")[0];
- var range = new baidu.editor.dom.Range(editor.document);
- range.selectNode( firstTd).collapse(true).select();
- equal( editor.queryCommandState( 'charts' ), -1, '数据验证失败, 状态为禁用' );
- //设置数据格式合法的表格
- editor.setContent('<table width="992"><tbody><tr class="firstRow"><th valign="null" width="141"><br></th><th width="141">a</th><th width="141">b</th><th width="142">c</th><th width="142">d</th><th width="142">e</th><th width="142">f</th></tr><tr><th valign="null" width="141">1999</th><td valign="top" width="141">1</td><td valign="top" width="141">2</td><td valign="top" width="142">3</td><td valign="top" width="142">4</td><td valign="top" width="142">5</td><td valign="top" width="142">6</td></tr></tbody></table>');
- firstTd = editor.body.getElementsByTagName("td")[0];
- range.setStart( firstTd,0).collapse(true).select();
- equal( editor.queryCommandState( 'charts' ) != -1, true, '数据合法, 状态可用' );
- editor.execCommand( 'charts', {
- title: '测试标题',
- subTitle: '标题2',
- xTitle: 'X轴标题',
- yTitle: 'Y轴标题',
- suffix: '后缀',
- tip: '提示',
- dataFormat: '1',
- chartType: 1
- } );
- var tableNode = editor.body.getElementsByTagName("table")[0];
- equal( tableNode.getAttribute("data-chart") !== null, true, '插入图表命令执行成功' );
- setTimeout(function(){
- UE.delEditor("container");
- document.getElementById("container")&&te.dom.push( document.getElementById("container"));
- start();
- },300);
- } );
- } );
- test( '图表命令检测', function() {
- // expect(5);
- UE.delEditor( te.obj[0] );
- var div = document.createElement( "div" );
- div.id = "container";
- document.body.appendChild( div );
- var editor = UE.getEditor( "container", {
- initialContent: '<table><tbody><tr><td width="147" valign="top">' +
- '<br></td></tr><tr><td width="147" valign="top"><br></td></tr></tbody></table>'
- } );
- stop();
- editor.ready( function () {
- var range = editor.selection.getRange();
- range.selectNode( editor.body.getElementsByTagName("td")[0]).collapse(true).select();
- equal( editor.queryCommandState( 'charts' ), -1, '列数不够, 状态为禁用' );
- // <table><tbody><tr class="firstRow"><th></th><th></th></tr><tr><td width="483" valign="top" style="word-break: break-all;">1</td><td width="483" valign="top" style="word-break: break-all;">2</td></tr><tr><td width="483" valign="top" style="word-break: break-all;">2</td><td width="483" valign="top" style="word-break: break-all;">2</td></tr></tbody></table>
- editor.setContent('<table><tbody><tr class="firstRow"><th></th><td>e</td></tr><tr><td width="483" valign="top" style="word-break: break-all;">1</td><td width="483" valign="top" style="word-break: break-all;">2</td></tr><tr><td width="483" valign="top" style="word-break: break-all;">2</td><td width="483" valign="top" style="word-break: break-all;">2</td></tr></tbody></table>');
- range.selectNode( editor.body.getElementsByTagName("td")[0]).collapse(true).select();
- equal( editor.queryCommandState( 'charts' ), -1, '第一行不都是th, 状态为禁用' );
- editor.setContent('<table><tbody><tr class="firstRow"><th></th><th>e</th></tr><tr><td width="483" valign="top" style="word-break: break-all;">1</td><td width="483" valign="top" style="word-break: break-all;">2</td></tr><tr><td width="483" valign="top" style="word-break: break-all;">2</td><td width="483" valign="top" style="word-break: break-all;">2</td></tr></tbody></table>');
- range.selectNode( editor.body.getElementsByTagName("td")[0]).collapse(true).select();
- equal( editor.queryCommandState( 'charts' ), -1, '第一列不是th, 状态为禁用' );
- editor.setContent('<table width="992" ><tbody><tr class="firstRow"><th width="364"></th><th width="364"></th><th width="364"></th></tr><tr><th valign="null" width="263">5</th><td valign="top" style="word-break: break-all;" width="364" rowspan="2" colspan="1">5</td><td valign="top" style="word-break: break-all;" width="364">2</td></tr><tr><th valign="null" width="263"></th><td valign="top" style="word-break: break-all;" width="364">2</td></tr> <tr><th></th><td valign="top" colspan="1" rowspan="1">2</td><td valign="top" colspan="1" rowspan="1">4</td></tr></tbody></table>');
- range.selectNode( editor.body.getElementsByTagName("td")[0]).collapse(true).select();
- equal( editor.queryCommandState( 'charts' ), -1, '每行单元格数不匹配, 状态为禁用' );
- editor.setContent('<table width="992"><tbody><tr class="firstRow"><th valign="null" width="263"></th><th width="364"></th><th width="364"></th></tr><tr><th valign="null" width="263"></th><td valign="top" style="word-break: break-all;" width="364" class="selectTdClass">1</td><td valign="top" style="word-break: break-all;" width="364">ee</td></tr><tr><th valign="null" width="263"></th><td valign="top" style="word-break: break-all;" width="364" class="selectTdClass">2</td><td valign="top" style="word-break: break-all;" width="364">2</td></tr></tbody></table>');
- range.selectNode( editor.body.getElementsByTagName("td")[0]).collapse(true).select();
- equal( editor.queryCommandState( 'charts' ), -1, '内容不是数字, 状态为禁用' );
- setTimeout(function(){
- UE.delEditor("container");
- document.getElementById("container")&&te.dom.push( document.getElementById("container"));
- start();
- },300);
- } );
- } );
|