forked from mirrors/gecko-dev
		
	 e824d800fb
			
		
	
	
		e824d800fb
		
	
	
	
	
		
			
			This enables the editor directory to be linted, and fixes the remaining issues raised by ESLint. Various rules were fixed here including, no-shadow, no-undef, no-unused-vars and others. I've generally gone conservative, disabling rules where it doesn't make sense to fix them (e.g. sometimes suggests use-services for tests, but it is only used once, or within a Chrome script). Depends on D5585 Differential Revision: https://phabricator.services.mozilla.com/D5587 --HG-- extra : moz-landing-system : lando
		
			
				
	
	
		
			97 lines
		
	
	
	
		
			3.6 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			97 lines
		
	
	
	
		
			3.6 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| <!DOCTYPE HTML>
 | |
| <html>
 | |
| <!--
 | |
| https://bugzilla.mozilla.org/show_bug.cgi?id=1330796
 | |
| -->
 | |
| <head>
 | |
|   <meta charset="utf-8">
 | |
|   <title>Test for Bug 772796</title>
 | |
|   <script type="application/javascript" src="/tests/SimpleTest/SimpleTest.js"></script>
 | |
|   <script type="application/javascript" src="/tests/SimpleTest/EventUtils.js"></script>
 | |
|   <link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css"/>
 | |
|   <style> .pre { white-space: pre } </style>
 | |
| </head>
 | |
| <body>
 | |
| <a target="_blank" href="https://bugzilla.mozilla.org/show_bug.cgi?id=772796">Mozilla Bug 1330796</a>
 | |
| <p id="display"></p>
 | |
| <div id="content" style="display: none">
 | |
| </div>
 | |
| 
 | |
| <div id="editable" contenteditable></div>
 | |
| 
 | |
| <pre id="test">
 | |
| 
 | |
| <script type="application/javascript">
 | |
| // We want to test what happens when the user splits a mail cite by clicking
 | |
| // at the start, the middle and the end of the cite and hitting the enter key.
 | |
| // Mail cites are spans, and since bug 1288911 they are displayed as blocks.
 | |
| // The _moz_quote attribute is used to give the cite a blue color via CSS.
 | |
| // As an internal attribute, it's not returned from the innerHTML.
 | |
| // To the user the tests look like:
 | |
| // > mailcite
 | |
| // This text is 10 characters long, so we position at 0, 5 and 10.
 | |
| // Althought since bug 1288911 those cites are displayed as block,
 | |
| // the tests are repeated also for inline display.
 | |
| // Each entry of the 'tests' array has the original HTML, the offset to click
 | |
| // at and the expected result HTML.
 | |
| var tests = [
 | |
|   // With style="display: block;".
 | |
|   [ "<span _moz_quote=true style=\"display: block;\">> mailcite<br></span>", 0,
 | |
|     "x<br><span style=\"display: block;\">> mailcite<br></span>" ],
 | |
|   [ "<span _moz_quote=true style=\"display: block;\">> mailcite<br></span>", 5,
 | |
|     "<span style=\"display: block;\">> mai<br></span>x<br><span style=\"display: block;\">lcite<br></span>"],
 | |
|   [ "<span _moz_quote=true style=\"display: block;\">> mailcite<br></span>", 10,
 | |
|     "<span style=\"display: block;\">> mailcite<br></span>x<br>" ],
 | |
|   // No <br> at the end to simulate prior deletion to the end of the quote.
 | |
|   [ "<span _moz_quote=true style=\"display: block;\">> mailcite</span>", 10,
 | |
|     "<span style=\"display: block;\">> mailcite<br></span>x<br>" ],
 | |
| 
 | |
|   // Without style="display: block;".
 | |
|   [ "<span _moz_quote=true>> mailcite<br></span>", 0,
 | |
|     "x<br><span>> mailcite<br></span>" ],
 | |
|   [ "<span _moz_quote=true>> mailcite<br></span>", 5,
 | |
|     "<span>> mai</span><br>x<br><span>lcite<br></span>" ],
 | |
|   [ "<span _moz_quote=true>> mailcite<br></span>", 10,
 | |
|     "<span>> mailcite<br></span>x<br>" ],
 | |
|   // No <br> at the end to simulate prior deletion to the end of the quote.
 | |
|   [ "<span _moz_quote=true>> mailcite</span>", 10,
 | |
|     "<span>> mailcite</span><br>x<br>" ],
 | |
| ];
 | |
| 
 | |
| /** Test for Bug 1330796 **/
 | |
| 
 | |
| SimpleTest.waitForExplicitFinish();
 | |
| 
 | |
| SimpleTest.waitForFocus(function() {
 | |
| 
 | |
|   var sel = window.getSelection();
 | |
|   var theEdit = document.getElementById("editable");
 | |
|   makeMailEditor();
 | |
| 
 | |
|   for (let i = 0; i < tests.length; i++) {
 | |
|     theEdit.innerHTML = tests[i][0];
 | |
|     theEdit.focus();
 | |
|     var theText = theEdit.firstChild.firstChild;
 | |
|     // Position set at the beginning , middle and end of the text.
 | |
|     sel.collapse(theText, tests[i][1]);
 | |
| 
 | |
|     synthesizeKey("KEY_Enter");
 | |
|     sendString("x");
 | |
|     is(theEdit.innerHTML, tests[i][2], "unexpected HTML for test " + i.toString());
 | |
|   }
 | |
| 
 | |
|   SimpleTest.finish();
 | |
| 
 | |
| });
 | |
| 
 | |
| function makeMailEditor() {
 | |
|   var Ci = SpecialPowers.Ci;
 | |
|   var editingSession = SpecialPowers.wrap(window).docShell.editingSession;
 | |
|   var editor = editingSession.getEditorForWindow(window);
 | |
|   editor.flags |= Ci.nsIPlaintextEditor.eEditorMailMask;
 | |
| }
 | |
| </script>
 | |
| 
 | |
| </pre>
 | |
| </body>
 | |
| </html>
 |