mirror of
https://github.com/fastmail/Squire.git
synced 2025-01-03 13:16:31 -05:00
Merge pull request #141 from gertsonderby/test/hasFormat
Added test suite that checks a number of cases for hasFormat().
This commit is contained in:
commit
8d178e1a65
4 changed files with 113 additions and 2 deletions
|
@ -2803,6 +2803,20 @@ proto.hasFormat = function ( tag, attributes, range ) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Sanitize range to prevent weird IE artifacts
|
||||||
|
if ( !range.collapsed &&
|
||||||
|
range.startContainer.nodeType === TEXT_NODE &&
|
||||||
|
range.startOffset === range.startContainer.length &&
|
||||||
|
range.startContainer.nextSibling ) {
|
||||||
|
range.setStartBefore( range.startContainer.nextSibling );
|
||||||
|
}
|
||||||
|
if ( !range.collapsed &&
|
||||||
|
range.endContainer.nodeType === TEXT_NODE &&
|
||||||
|
range.endOffset === 0 &&
|
||||||
|
range.endContainer.previousSibling ) {
|
||||||
|
range.setEndAfter( range.endContainer.previousSibling );
|
||||||
|
}
|
||||||
|
|
||||||
// If the common ancestor is inside the tag we require, we definitely
|
// If the common ancestor is inside the tag we require, we definitely
|
||||||
// have the format.
|
// have the format.
|
||||||
var root = range.commonAncestorContainer,
|
var root = range.commonAncestorContainer,
|
||||||
|
|
File diff suppressed because one or more lines are too long
|
@ -684,6 +684,20 @@ proto.hasFormat = function ( tag, attributes, range ) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Sanitize range to prevent weird IE artifacts
|
||||||
|
if ( !range.collapsed &&
|
||||||
|
range.startContainer.nodeType === TEXT_NODE &&
|
||||||
|
range.startOffset === range.startContainer.length &&
|
||||||
|
range.startContainer.nextSibling ) {
|
||||||
|
range.setStartBefore( range.startContainer.nextSibling );
|
||||||
|
}
|
||||||
|
if ( !range.collapsed &&
|
||||||
|
range.endContainer.nodeType === TEXT_NODE &&
|
||||||
|
range.endOffset === 0 &&
|
||||||
|
range.endContainer.previousSibling ) {
|
||||||
|
range.setEndAfter( range.endContainer.previousSibling );
|
||||||
|
}
|
||||||
|
|
||||||
// If the common ancestor is inside the tag we require, we definitely
|
// If the common ancestor is inside the tag we require, we definitely
|
||||||
// have the format.
|
// have the format.
|
||||||
var root = range.commonAncestorContainer,
|
var root = range.commonAncestorContainer,
|
||||||
|
|
|
@ -32,6 +32,88 @@ describe('Squire RTE', function () {
|
||||||
editor.setSelection(range);
|
editor.setSelection(range);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
describe('hasFormat', function () {
|
||||||
|
var startHTML;
|
||||||
|
beforeEach( function () {
|
||||||
|
startHTML = '<div>one <b>two three</b> four <i>five</i></div>';
|
||||||
|
editor.setHTML(startHTML);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('returns false when range not touching format', function () {
|
||||||
|
var range = doc.createRange();
|
||||||
|
range.setStart(doc.body.childNodes.item(0), 0);
|
||||||
|
range.setEnd(doc.body.childNodes.item(0), 1);
|
||||||
|
editor.setSelection(range);
|
||||||
|
expect(editor.hasFormat('b'), 'to be false');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('returns false when range inside other format', function () {
|
||||||
|
var range = doc.createRange();
|
||||||
|
range.setStart(doc.querySelector('i').childNodes[0], 1);
|
||||||
|
range.setEnd(doc.querySelector('i').childNodes[0], 2);
|
||||||
|
editor.setSelection(range);
|
||||||
|
expect(editor.hasFormat('b'), 'to be false');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('returns false when range covers anything outside format', function () {
|
||||||
|
var range = doc.createRange();
|
||||||
|
range.setStart(doc.querySelector('b').previousSibling, 2);
|
||||||
|
range.setEnd(doc.querySelector('b').childNodes[0], 8);
|
||||||
|
editor.setSelection(range);
|
||||||
|
expect(editor.hasFormat('b'), 'to be false');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('returns true when range inside format', function () {
|
||||||
|
var range = doc.createRange();
|
||||||
|
range.setStart(doc.querySelector('b').childNodes[0], 2);
|
||||||
|
range.setEnd(doc.querySelector('b').childNodes[0], 8);
|
||||||
|
editor.setSelection(range);
|
||||||
|
expect(editor.hasFormat('b'), 'to be true');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('returns true when range covers start of format', function () {
|
||||||
|
var range = doc.createRange();
|
||||||
|
range.setStartBefore(doc.querySelector('b'));
|
||||||
|
range.setEnd(doc.querySelector('b').childNodes[0], 8);
|
||||||
|
editor.setSelection(range);
|
||||||
|
expect(editor.hasFormat('b'), 'to be true');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('returns true when range covers start of format, even in weird cases', function () {
|
||||||
|
var range = doc.createRange();
|
||||||
|
var prev = doc.querySelector('b').previousSibling;
|
||||||
|
range.setStart(prev, prev.length);
|
||||||
|
range.setEnd(doc.querySelector('b').childNodes[0], 8);
|
||||||
|
editor.setSelection(range);
|
||||||
|
expect(editor.hasFormat('b'), 'to be true');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('returns true when range covers end of format', function () {
|
||||||
|
var range = doc.createRange();
|
||||||
|
range.setStart(doc.querySelector('b').childNodes[0], 2);
|
||||||
|
range.setEndAfter(doc.querySelector('b'));
|
||||||
|
editor.setSelection(range);
|
||||||
|
expect(editor.hasFormat('b'), 'to be true');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('returns true when range covers end of format, even in weird cases', function () {
|
||||||
|
var range = doc.createRange();
|
||||||
|
range.setStart(doc.querySelector('b').childNodes[0], 2);
|
||||||
|
var next = doc.querySelector('b').nextSibling;
|
||||||
|
range.setEnd(next, 0);
|
||||||
|
editor.setSelection(range);
|
||||||
|
expect(editor.hasFormat('b'), 'to be true');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('returns true when range covers all of format', function () {
|
||||||
|
var range = doc.createRange();
|
||||||
|
range.setStartBefore(doc.querySelector('b'));
|
||||||
|
range.setEndAfter(doc.querySelector('b'));
|
||||||
|
editor.setSelection(range);
|
||||||
|
expect(editor.hasFormat('b'), 'to be true');
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
describe('removeAllFormatting', function () {
|
describe('removeAllFormatting', function () {
|
||||||
// Trivial cases
|
// Trivial cases
|
||||||
it('removes inline styles', function () {
|
it('removes inline styles', function () {
|
||||||
|
|
Loading…
Reference in a new issue